當前位置: 首頁>>代碼示例>>Python>>正文


Python MonthPeriod.find_create_by_date方法代碼示例

本文整理匯總了Python中snisi_core.models.Periods.MonthPeriod.find_create_by_date方法的典型用法代碼示例。如果您正苦於以下問題:Python MonthPeriod.find_create_by_date方法的具體用法?Python MonthPeriod.find_create_by_date怎麽用?Python MonthPeriod.find_create_by_date使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在snisi_core.models.Periods.MonthPeriod的用法示例。


在下文中一共展示了MonthPeriod.find_create_by_date方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: boundaries

# 需要導入模塊: from snisi_core.models.Periods import MonthPeriod [as 別名]
# 或者: from snisi_core.models.Periods.MonthPeriod import find_create_by_date [as 別名]
 def boundaries(cls, date_obj):
     date_obj = normalize_date(date_obj, as_aware=True)
     start = date_obj.replace(day=29, hour=0, minute=0,
                              second=0, microsecond=0)
     end = MonthPeriod.find_create_by_date(date_obj,
                                           dont_create=True).following() \
                      .start_on - ONE_MICROSECOND_DELTA
     return (start, end)
開發者ID:yeleman,項目名稱:snisi,代碼行數:10,代碼來源:FixedWeekPeriods.py

示例2: following_week

# 需要導入模塊: from snisi_core.models.Periods import MonthPeriod [as 別名]
# 或者: from snisi_core.models.Periods.MonthPeriod import find_create_by_date [as 別名]
 def following_week(cls, reference):
     idx = cls.week_classes.index(reference.__class__)
     if idx == len(cls.week_classes) - 1:
         ncls = cls.week_classes[0]
         nmonth = MonthPeriod.find_create_by_date(reference.middle())
         at = nmonth.next().middle()
     else:
         ncls = cls.week_classes[idx + 1]
         at = reference.middle()
     return ncls.find_create_by_date(at)
開發者ID:yeleman,項目名稱:snisi,代碼行數:12,代碼來源:FixedWeekPeriods.py

示例3: previous_week

# 需要導入模塊: from snisi_core.models.Periods import MonthPeriod [as 別名]
# 或者: from snisi_core.models.Periods.MonthPeriod import find_create_by_date [as 別名]
 def previous_week(cls, reference):
     idx = cls.week_classes.index(reference.__class__)
     if idx == 0:
         ncls = cls.week_classes[-1]
         nmonth = MonthPeriod.find_create_by_date(reference.middle())
         at = nmonth.previous().middle()
     else:
         ncls = cls.week_classes[idx - 1]
         at = reference.middle()
     return ncls.find_create_by_date(at)
開發者ID:yeleman,項目名稱:snisi,代碼行數:12,代碼來源:FixedWeekPeriods.py

示例4: _check

# 需要導入模塊: from snisi_core.models.Periods import MonthPeriod [as 別名]
# 或者: from snisi_core.models.Periods.MonthPeriod import find_create_by_date [as 別名]
    def _check(self, **options):
        # period
        period = MonthPeriod.find_create_by_date(self.get('submit_time'))
        self.set('clean_period', period)

        # entity (district)
        entity = Entity.get_or_none(self.get('district'),
                                    type_slug='health_district')
        if entity is None:
            self.add_error("Aucun District ne correspond "
                           "au code {}".format(self.get('district')),
                           field='district', blocking=True)
        self.set('clean_entity', entity)

        # check auth for user at district
        user_district = self.get('submitter').location.get_health_district()
        if (user_district is None
                or not user_district == entity
                or self.get('submitter').role.slug
                not in ('tt_tso', 'tt_opt', 'tt_amo',
                        'tt_surgeon', 'charge_sis')):
            self.add_error("Vous n'êtes pas autorisé à créer un rapport de "
                           "mission pour ce district: {}".format(entity),
                           blocking=True, field='submitter')

        # expected reporting defines if report is expeted or not
        expected_reporting = ExpectedReporting.get_or_none(
            report_class__slug='cat_mission',
            period=period,
            within_period=True,
            entity=entity,
            within_entity=False)

        self.set('expected_reporting', expected_reporting)

        # should have already been checked in checker.
        if expected_reporting is None:
            self.add_error("Aucune mission cataracte attendue à {} pour "
                           "la période de {}".format(entity, period),
                           blocking=True)

        if expected_reporting.completion_status \
                == ExpectedReporting.COMPLETION_COMPLETE:
            self.add_error("Aucune mission cataracte attendue à {} pour "
                           "la période de {}".format(entity, period),
                           blocking=True)

        # no creation if exist open
        open_missions = CATMissionR.objects.filter(
            entity=entity,
            created_by=self.get('submitter'),
            ).exclude(completion_status=CATMissionR.COMPLETE)

        if open_missions.count():
            self.add_error("Vous avez déjà une mission en cours à {}. "
                           "Cloturez la d'abord.".format(entity, period),
                           blocking=True)

        # started_on must be <= today
        today = datetime.date.today()
        started_on = parse_date_string(self.get('started_on'), as_date=True)
        if started_on is None:
            self.add_error("La date de démarrage est incorrecte: "
                           "{}.".format(self.get('started_on')),
                           blocking=True, field='started_on')
        if started_on > today:
            self.add_error("La date de démarrage est dans "
                           "le futur: {}.".format(started_on),
                           blocking=True, field='started_on')

        if started_on < today - datetime.timedelta(days=21):
            self.add_error("La date de démarrage est trop "
                           "ancienne: {}.".format(started_on),
                           blocking=True, field='started_on')

        self.set('clean_started_on', started_on)

        # operator type
        operator_type = {
            'amo': cat_models.AMO,
            'tso': cat_models.TSO,
            'opt': cat_models.OPT,
            'surgeon': cat_models.SURGEON,
        }.get(self.get('operator_type').lower())
        if operator_type not in cat_models.OPERATOR_TYPES.keys():
            self.add_error("Profil agent innatendu: "
                           "{}.".format(self.get('operator_type')),
                           blocking=True, field='operator')
        self.set('clean_operator_type', operator_type)

        # strategy
        strategy = {
            'fixed': cat_models.FIXED,
            'mobile': cat_models.MOBILE,
            'advanced': cat_models.ADVANCED
        }.get(self.get('strategy').lower())
        if strategy not in cat_models.STRATEGIES.keys():
            self.add_error("Strategie innatendue: "
                           "{}.".format(self.get('strategy')),
                           blocking=True, field='strategy')
#.........這裏部分代碼省略.........
開發者ID:yeleman,項目名稱:snisi,代碼行數:103,代碼來源:integrity.py

示例5: cataract_mission_browser

# 需要導入模塊: from snisi_core.models.Periods import MonthPeriod [as 別名]
# 或者: from snisi_core.models.Periods.MonthPeriod import find_create_by_date [as 別名]
def cataract_mission_browser(request,
                             entity_slug=None,
                             period_str=None,
                             **kwargs):
    context = {}

    root = request.user.location
    cluster = Cluster.get_or_none('cataract')

    entity = Entity.get_or_none(entity_slug)
    if entity is None:
        entity = root

    if entity is None:
        raise Http404("Aucune entité pour le code {}".format(entity_slug))

    # make sure requested entity is in cluster
    ensure_entity_in_cluster(cluster, entity)

    # check permissions on this entity and raise 403
    provider_allowed_or_denied(request.user, 'access_cataract', entity)

    # mission browser is reserved to district-level and above
    ensure_entity_at_least(entity, 'health_district')

    def period_from_strid(period_str, reportcls=None):
        period = None
        if period_str:
            try:
                period = Period.from_url_str(period_str).casted()
            except:
                pass
        return period
    period = period_from_strid(period_str)
    if period is None:
        period = MonthPeriod.current()

    try:
        first_period = MonthPeriod.find_create_by_date(
            CATMissionR.objects.all()
            .order_by('period__start_on')[0].period.middle())
    except IndexError:
        first_period = MonthPeriod.current()
    all_periods = MonthPeriod.all_from(first_period)

    context.update({
        'all_periods': [(p.strid(), p) for p in reversed(all_periods)],
        'period': period,
        'base_url': get_base_url_for_period(
            view_name='cataract_missions', entity=entity,
            period_str=period_str or period.strid())
    })

    context.update(entity_browser_context(
        root=root, selected_entity=entity,
        full_lineage=['country', 'health_region', 'health_district'],
        cluster=cluster))

    # retrieve list of missions for that period
    missions = CATMissionR.objects.filter(
        period=period,
        entity__slug__in=[e.slug for e in entity.get_health_districts()])

    context.update({'missions': missions})

    return render(request,
                  kwargs.get('template_name', 'cataract/missions_list.html'),
                  context)
開發者ID:yeleman,項目名稱:snisi,代碼行數:70,代碼來源:views.py

示例6: cataract_dashboard

# 需要導入模塊: from snisi_core.models.Periods import MonthPeriod [as 別名]
# 或者: from snisi_core.models.Periods.MonthPeriod import find_create_by_date [as 別名]
def cataract_dashboard(request,
                       entity_slug=None,
                       perioda_str=None,
                       periodb_str=None,
                       **kwargs):
    context = {}

    root = request.user.location
    cluster = Cluster.get_or_none('cataract')

    entity = Entity.get_or_none(entity_slug)
    if entity is None:
        entity = root

    if entity is None:
        raise Http404("Aucune entité pour le code {}".format(entity_slug))

    # make sure requested entity is in cluster
    ensure_entity_in_cluster(cluster, entity)

    # check permissions on this entity and raise 403
    provider_allowed_or_denied(request.user, 'access_cataract', entity)

    # mission browser is reserved to district-level and above
    ensure_entity_at_least(entity, 'health_district')

    def period_from_strid(period_str, reportcls=None):
        period = None
        if period_str:
            try:
                period = Period.from_url_str(period_str).casted()
            except:
                pass
        return period
    perioda = period_from_strid(perioda_str)
    periodb = period_from_strid(periodb_str)
    if periodb is None:
        periodb = MonthPeriod.current()
    if perioda is None:
        perioda = periodb

    if perioda is None or periodb is None:
        raise Http404("Période incorrecte.")

    if perioda > periodb:
        t = perioda
        perioda = periodb
        periodb = t
        del(t)

    try:
        first_period = MonthPeriod.find_create_by_date(
            CATMissionR.objects.all().order_by(
                'period__start_on')[0].period.middle())
    except IndexError:
        first_period = MonthPeriod.current()
    all_periods = MonthPeriod.all_from(first_period)
    periods = MonthPeriod.all_from(perioda, periodb)

    context.update({
        'all_periods': [(p.strid(), p) for p in reversed(all_periods)],
        'periods': periods,
        'perioda': perioda,
        'periodb': periodb,
        'base_url': get_base_url_for_periods(
            view_name='cataract_dashboard',
            entity=entity,
            perioda_str=perioda_str or perioda.strid(),
            periodb_str=periodb_str or periodb.strid())
    })

    context.update(entity_browser_context(
        root=root, selected_entity=entity,
        full_lineage=['country', 'health_region', 'health_district'],
        cluster=cluster))

    # retrieve Indicator Table
    from snisi_cataract.indicators import (MissionDataSummary,
                                           CumulativeSurgeryData)

    missions_followup = MissionDataSummary(entity=entity,
                                           periods=periods)
    cumulative_surgeries = CumulativeSurgeryData(entity=entity,
                                                 periods=periods)

    context.update({
        'missions_followup': missions_followup,
        'cumulative_surgeries': cumulative_surgeries,
    })

    return render(request,
                  kwargs.get('template_name', 'cataract/dashboard.html'),
                  context)
開發者ID:yeleman,項目名稱:snisi,代碼行數:95,代碼來源:views.py


注:本文中的snisi_core.models.Periods.MonthPeriod.find_create_by_date方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。