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


Python Page.q方法代碼示例

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


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

示例1: statement_log

# 需要導入模塊: from packages.bin.bin import Page [as 別名]
# 或者: from packages.bin.bin.Page import q [as 別名]
def statement_log(request, qk=None, pk=None, method=None):

    if qk is None:
        HttpResponseRedirect('/404/hack/')

    s = Auth().isAuth(request)
    if not s:
        return Auth.routeLogin

    second_base = 'asset/'

    #practitioner factory
    obj_practitioner = Practitioner.objects.get(pk=qk)

    # asset factory
    page = Page(request)
    page.title = 'Practitioner\'s Asset Financial Record - Log'
    page.icon = 'glyphicons glyphicons-credit_card'
    page.form_name = 'practitionerFR'
    template = base_template + second_base + 'snippets/list-financial.html'
    page.q = str(qk) + '/'
    errors = []

    obj = Asset.objects.filter(status__exact=1, practitioner__id=qk)

    # display financial log
    table = Table()
    table.cols = ['Photo', 'Asset Detail', 'Billing Start', 'Billing End', 'Amount', 'Running Balance']
    table.rows = []
    running_balance = 0
    for val in AssetFR.objects.filter(txn_date=pk):
        running_balance += val.amount
        asset_name = "<b>[%s - %s]</b><br/>%s,<br/>%s" % (val.asset.longitude, val.asset.latitude, val.asset.line1,
                    val.asset.line2)

        try:
            tmp_image = "<a href='%s'><img src='%s' class='img-responsive' alt='...'></a>" % \
                        (get_thumb(val.asset.photo1.url, '512x512'), get_thumb(val.asset.photo1.url, '64x64'))
        except (ValueError):
            tmp_image = ""

        table.rows.append({
            'id': val.id,
            'fields': [
                {'field': tmp_image},
                {'field': asset_name},
                {'field': val.billing_start},
                {'field': val.billing_end},
                {'field': format(val.amount, ',.2f')},
                {'field': format(running_balance, ',.2f')}
            ]
        })

    #  SCRIPT
    page.script = '''
    <script>
    </script>
    '''

    #render to browser
    return render_to_response(template,
        {'s': s, 'page': page, 'table': table, 'obj': obj,
         'practitioner': obj_practitioner},
        context_instance=RequestContext(request)
    )
開發者ID:pukonu,項目名稱:doas,代碼行數:67,代碼來源:views+copy.py

示例2: credit

# 需要導入模塊: from packages.bin.bin import Page [as 別名]
# 或者: from packages.bin.bin.Page import q [as 別名]
def credit(request, qk=None, pk=None, method=None):

    if qk is None:
        HttpResponseRedirect('/404/hack/')

    s = Auth().isAuth(request)
    if not s:
        return Auth.routeLogin

    second_base = 'asset/'

    #practitioner factory
    obj_practitioner = Practitioner.objects.get(pk=qk)

    # asset factory
    page = Page(request)
    page.title = 'Practitioner\'s Deposit Form'
    page.icon = 'glyphicons glyphicons-display'
    page.form_name = 'practitionerFR'
    template = base_template + second_base + 'snippets/manage-financial.html'
    page.q = str(qk) + '/'
    errors = []

    #form processing
    if pk is not None:
        instance = FRSummary.objects.get(pk=pk)
        form = forms.FormPractitionerFR(instance=instance, data=model_to_dict(instance))
        page.form_action = base_url + 'credit/' + str(qk)+'/'+str(pk)+'/'
        template = base_template + second_base + 'snippets/manage-financial.html'
    else:
        instance = FRSummary()
        form = forms.FormPractitionerFR(instance=instance)
        page.form_action = base_url + 'credit/' + str(qk)+'/'
        template = base_template + second_base + 'snippets/manage-financial.html'

    #  SCRIPT
    page.script = '''
    <script>

    </script>
    '''

    #  CREATE & UPDATE
    if request.method == "POST":

        template = base_template + second_base + 'snippets/manage-financial.html'

        form = forms.FormPractitionerFR(request.POST, instance=instance)
        if form.is_valid():
            #do method to process
            posts = request.POST
            for post in posts:
                if hasattr(instance, post):
                    setattr(instance, post, form.cleaned_data[post])

        #  non field specific errors
        if instance.credit < 100:
            errors.append('Amount entered is too low')

        page.non_field_errors = errors

        if not errors and not form.errors:
            instance.balance = instance.credit
            instance.practitioner = obj_practitioner
            instance.save()

            return HttpResponseRedirect(base_url + 'statement/' + '%s/' % qk)

    #render to browser
    return render_to_response(template,
        {'s': s, 'form': form, 'page': page, 'obj': instance,
         'practitioner': obj_practitioner},
        context_instance=RequestContext(request)
    )
開發者ID:pukonu,項目名稱:doas,代碼行數:76,代碼來源:views+copy.py

示例3: statement

# 需要導入模塊: from packages.bin.bin import Page [as 別名]
# 或者: from packages.bin.bin.Page import q [as 別名]
def statement(request, qk=None, pk=None, method=None):

    if qk is None:
        HttpResponseRedirect('/404/hack/')

    s = Auth().isAuth(request)
    if not s:
        return Auth.routeLogin

    second_base = 'asset/'

    #practitioner factory
    obj_practitioner = Practitioner.objects.get(pk=qk)

    # asset factory
    page = Page(request)
    page.title = 'Practitioner\'s Asset Financial Record'
    page.icon = 'glyphicons glyphicons-credit_card'
    page.form_name = 'practitionerFR'
    template = base_template + second_base + 'snippets/list-financial.html'
    page.q = str(qk) + '/'
    errors = []

    obj = Asset.objects.filter(status__exact=1, practitioner__id=qk)

    # reproduce practitioners billing by checking individual board and adding up its financials to the account statement
    # this is entirely based on the billing period on the asset table. Skip suspended boards
    # billing date is 26th of every month and first month is pro-rated

    today = datetime.date.today()
    year = today.year
    month = today.month
    day = today.day

    # lets retrieve the date object for 60 days ahead of now
    today + timedelta(60)

    if today.day >= 26:
        # place billing period as 26th of current month
        billing_date = datetime.date(year, month, 26)

    else:
        # place billing period as 26th of the previous month except if month is january
        if month == 1:
            billing_date = datetime.date(year-1, 12, 26)
        else:
            billing_date = datetime.date(year, month-1, 26)

    boards = Asset.objects.filter(status__exact=1, practitioner__id=qk)
    aggregate = 0
    for board in boards:
        billing_start = board.billing_date
        if billing_start is not None and billing_start != "" and billing_start < billing_date:
            # check the days between today and the last billing date and do the deductions
            fee_days = board.fee/365
            billing_period = billing_date - billing_start
            amount = billing_period.days * fee_days
            aggregate += amount

            # process data and save to database

            # AssetFR
            asset_fr = AssetFR(asset=board, practitioner=obj_practitioner, amount=amount, billing_start=billing_start,
                                billing_end=billing_date, txn_date=today)
            asset_fr.save()

        # change the billing date to current billing date
        board.billing_date = billing_date
        board.save()

    #record summarized data to customer billing page
    if(aggregate != 0):
        comment = 'Debit on assets; Billing as at %s' % str(billing_date)
        fr_summary = FRSummary(practitioner=obj_practitioner, debit=aggregate, balance=(-1 * aggregate),
                               txn_date=today, comment=comment)
        fr_summary.save()

    # process expiry status (if total credit/total debits is less than 0.6)
    from django.db.models import Sum

    fr_credit = FRSummary.objects.filter(practitioner=obj_practitioner).aggregate(Sum('credit'))
    fr_debit = FRSummary.objects.filter(practitioner=obj_practitioner).aggregate(Sum('debit'))
    fr_fraction = fr_credit['credit__sum']/fr_debit['debit__sum']

    # give allowance for 3rd party practitioners
    if obj_practitioner.type == '3rd Party':
        if fr_fraction < 0.6:
            boards.update(c_status=3)
        elif fr_fraction < 0.8 and fr_fraction >= 0.6:
            boards.update(c_status=2)
        else:
            boards.update(c_status=1)

    # no allowance for other practitioners
    else:
        if fr_fraction < 1:
            boards.update(c_status=3)
        elif fr_fraction < 1.2 and fr_fraction >= 1:
            boards.update(c_status=2)
        else:
#.........這裏部分代碼省略.........
開發者ID:pukonu,項目名稱:doas,代碼行數:103,代碼來源:views+copy.py

示例4: asset

# 需要導入模塊: from packages.bin.bin import Page [as 別名]
# 或者: from packages.bin.bin.Page import q [as 別名]
def asset(request, qk=None, pk=None, method=None):

    if qk is None:
        HttpResponseRedirect('/404/hack/')

    s = Auth().isAuth(request)
    if not s:
        return Auth.routeLogin

    second_base = 'asset/'

    #practitioner factory
    obj_practitioner = Practitioner.objects.get(pk=qk)

    # asset factory
    page = Page(request)
    page.title = 'Practitioner\'s Asset Management'
    page.icon = 'glyphicons glyphicons-display'
    page.form_name = 'practitionerAsset'
    template = base_template + second_base + 'snippets/list.html'
    page.q = str(qk) + '/'
    errors = []

    obj_list = Asset.objects.filter(status__exact=1, practitioner__id=qk)

    #search logic
    q = request.GET.get('q')
    if q:
        sQuery = get_query(q, ['practitioner__name', 'category', 'type', 'longitude', 'latitude'])
        obj_list = obj_list.filter(sQuery)

    #build pagination
    page, obj = paginate(page, obj_list, request, q)

    #form processing
    if method is None or method == 'asset':
        form = forms.FormAsset()
        template = base_template + second_base + 'snippets/list.html'
    elif pk is not None:
        instance = Asset.objects.get(pk=pk)
        prev_instance = Asset.objects.get(pk=pk)
        form = forms.FormAsset(instance=instance, data=model_to_dict(instance))
        page.form_action = base_url + second_base + 'update/'+str(qk)+'/'+str(pk)+'/'
        template = base_template + second_base + 'snippets/manage.html'
    else:
        instance = Asset()
        form = forms.FormAsset(instance=instance)
        page.form_action = base_url + second_base + 'new/'+str(qk)+'/'
        template = base_template + second_base + 'snippets/manage.html'

    obj_settings = [
        {'link': base_url + second_base + 'update/'+str(qk)+'/', 'icon': Actions().Icon.edit},
        {'link': base_url + 'delete/asset/'+str(qk)+'/', 'icon': Actions().Icon.delete},
    ]

    table = Table()
    table.cols = ['Photo', 'Longitude', 'Latitude', 'Category', 'Type', 'Road Clearance', 'Ground Clearance', 'Width', 'Height', 'Sides', 'Commission Date']
    table.rows = []
    for val in obj:
        try:
            tmp_image = "<a href='%s'><img src='%s' class='img-responsive' alt='...'></a>" % (get_thumb(val.photo1.url, '512x512'), get_thumb(val.photo1.url, '64x64'))
        except (ValueError):
            tmp_image = ""
        table.rows.append({
            'id': val.id,
            'fields': [
                {'field': tmp_image},
                {'field': val.longitude},
                {'field': val.latitude},
                {'field': val.category},
                {'field': val.type},
                {'field': val.road_clearance},
                {'field': val.ground_clearance},
                {'field': val.width},
                {'field': val.height},
                {'field': val.sides},
                {'field': val.commission_date},
            ]
        })

    #  SCRIPT
    page.script = '''
    <script>
    $('#id_longitude').mask('9.99999');
    $('#id_latitude').mask('9.99999');
    </script>
    '''

    #  CREATE & UPDATE
    if request.method == "POST":

        template = base_template + second_base + 'snippets/manage.html'

        form = forms.FormAsset(request.POST, request.FILES, instance=instance)
        if form.is_valid():
            #do method to process
            posts = request.POST
            for post in posts:
                if hasattr(instance, post):
                    setattr(instance, post, form.cleaned_data[post])
#.........這裏部分代碼省略.........
開發者ID:pukonu,項目名稱:doas,代碼行數:103,代碼來源:views+copy.py


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