本文整理匯總了Python中django.views.generic.TemplateView方法的典型用法代碼示例。如果您正苦於以下問題:Python generic.TemplateView方法的具體用法?Python generic.TemplateView怎麽用?Python generic.TemplateView使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類django.views.generic
的用法示例。
在下文中一共展示了generic.TemplateView方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: post_rating
# 需要導入模塊: from django.views import generic [as 別名]
# 或者: from django.views.generic import TemplateView [as 別名]
def post_rating(self, request, *args, **kwargs):
self.mrsrequest_uuid = self.request.POST.get(
'rating-mrsrequest_uuid', None)
if not self.has_perm(exists=True):
return http.HttpResponseBadRequest()
self.rating_form = RatingForm(request.POST, prefix='rating')
self.rating_form.instance.mrsrequest = MRSRequest.objects.get(
pk=self.mrsrequest_uuid
)
if self.rating_form.is_valid():
with transaction.atomic():
self.success_rating = self.rating_form.save()
return generic.TemplateView.get(self, request, *args, **kwargs)
示例2: get_queryset
# 需要導入模塊: from django.views import generic [as 別名]
# 或者: from django.views.generic import TemplateView [as 別名]
def get_queryset(self, **kwargs):
queryset = Site.objects.filter(project_id=self.kwargs.get('pk'), is_survey=False, is_active=True)
if self.kwargs.get('region_id') == "0":
object_list = queryset.filter(region=None)
else:
object_list = queryset.filter(region_id=self.kwargs.get('region_id'))
return object_list
# class RegionalSitelist(ProjectRoleMixin, TemplateView):
# def get(self, request, *args, **kwargs):
# queryset = Site.objects.filter(project_id=self.kwargs.get('pk'), is_survey=False, is_active=True)
# if self.kwargs.get('region_id') == "0":
# object_list = queryset.filter(region=None)
# else:
# object_list = queryset.filter(region_id=self.kwargs.get('region_id'))
# if self.kwargs.get('region_id') == "0":
# return render(request, 'fieldsight/site_list.html',{'object_list':object_list, 'project_id':self.kwargs.get('pk'),'type':"Unregioned", 'pk': self.kwargs.get('pk'),'region_id':self.kwargs.get('region_id'),})
# obj = get_object_or_404(Region, id=self.kwargs.get('region_id'))
# return render(request, 'fieldsight/site_list.html',{'object_list':object_list, 'obj':obj, 'type':"region", 'pk': self.kwargs.get('pk'), 'region_id':self.kwargs.get('region_id'),})
# class RegionalSitelist(ProjectRoleMixin, ListView):
# paginate_by = 10
# def get(self, request, *args, **kwargs):
# if self.kwargs.get('region_pk') == "0":
# sites = Site.objects.filter(region=None)
# return render(request, 'fieldsight/site_list.html' ,{'all_sites':sites, 'project_id':self.kwargs.get('pk'),'type':"Unregioned",'pk':self.kwargs.get('region_pk'),})
# obj = get_object_or_404(Region, id=self.kwargs.get('region_pk'))
# sites = Site.objects.filter(region_id=self.kwargs.get('region_pk'))
# return render(request, 'fieldsight/site_list.html',{'all_sites':sites, 'obj':obj, 'type':"region",'pk':self.kwargs.get('region_pk'),})
示例3: get_context_data
# 需要導入模塊: from django.views import generic [as 別名]
# 或者: from django.views.generic import TemplateView [as 別名]
def get_context_data(self, **kwargs):
"""Overriding get_context_data to add additional context."""
context = super(TemplateView, self).get_context_data(**kwargs)
# Provides the base template to extend from
context['template_extends'] = self.template_extends
return context
示例4: get_context_data
# 需要導入模塊: from django.views import generic [as 別名]
# 或者: from django.views.generic import TemplateView [as 別名]
def get_context_data(self, **kwargs):
ctx = super(TemplateView, self).get_context_data(**kwargs)
ctx['return_url'] = self.request.GET.get('return_url', '')
return ctx
示例5: dispatch
# 需要導入模塊: from django.views import generic [as 別名]
# 或者: from django.views.generic import TemplateView [as 別名]
def dispatch(self, request, *args, **kwargs):
self.object = self.get_object()
if not self.object:
self.template_name = 'mrsrequest/notfound.html'
return generic.TemplateView.get(self, request, *args, **kwargs)
return super().dispatch(request, *args, **kwargs)
示例6: post
# 需要導入模塊: from django.views import generic [as 別名]
# 或者: from django.views.generic import TemplateView [as 別名]
def post(self, request, *args, **kwargs):
if self.object.status != self.object.STATUS_NEW:
return http.HttpResponseBadRequest()
self.object.status = self.object.STATUS_CANCELED
self.object.status_datetime = datetime.now()
self.object.save()
self.object.logentries.create(
action=MRSRequest.STATUS_CANCELED,
comment='Annulation',
)
body = template.loader.get_template(
'mrsrequest/cancelation_email.txt'
).render(dict(object=self.object, base_url=settings.BASE_URL)).strip()
Caller(
callback='djcall.django.email_send',
kwargs=dict(
subject=f'MRS: Annulation demande {self.object.display_id}',
body=body.strip(),
to=[self.object.insured.email],
reply_to=[self.object.caisse.liquidation_email],
)
).spool('mail')
return generic.TemplateView.get(self, request, *args, **kwargs)
示例7: post
# 需要導入模塊: from django.views import generic [as 別名]
# 或者: from django.views.generic import TemplateView [as 別名]
def post(self, request, *args, **kwargs):
context = self.get_context_data()
if context['form'].is_valid():
cd = context['form'].cleaned_data
subject = cd['subject']
from_email = cd['email']
message = cd['message']
try:
send_mail(
subject + " from {}".format(from_email),
message,
from_email,
[settings.EMAIL_HOST_USER]
)
except BadHeaderError:
return HttpResponse('Invalid header found.')
ctx = {
'success': """Thankyou, We appreciate that you've
taken the time to write us.
We'll get back to you very soon.
Please come back and see us often."""
}
return render(request, self.template_name, ctx)
return super(generic.TemplateView, self).render_to_response(context)
示例8: get_context_data
# 需要導入模塊: from django.views import generic [as 別名]
# 或者: from django.views.generic import TemplateView [as 別名]
def get_context_data(self, **kwargs):
"""get context from parent class (really only relevant for child classes of this class, as TemplateView does
not have any context variables)"""
context = super().get_context_data(**kwargs)
# get selection from session and add to context
# get simple selection from session
simple_selection = self.request.session.get('selection', False)
# create full selection and import simple selection (if it exists)
selection = Selection()
if simple_selection:
selection.importer(simple_selection)
# context['selection'] = selection
context['selection'] = {}
context['selection']['site_residue_groups'] = selection.site_residue_groups
context['selection']['active_site_residue_group'] = selection.active_site_residue_group
for selection_box, include in self.selection_boxes.items():
if include:
context['selection'][selection_box] = selection.dict(selection_box)['selection'][selection_box]
# get attributes of this class and add them to the context
attributes = inspect.getmembers(self, lambda a:not(inspect.isroutine(a)))
for a in attributes:
if not(a[0].startswith('__') and a[0].endswith('__')):
context[a[0]] = a[1]
return context
示例9: get_context_data
# 需要導入模塊: from django.views import generic [as 別名]
# 或者: from django.views.generic import TemplateView [as 別名]
def get_context_data(self, **kwargs):
context = super(TemplateView, self).get_context_data(**kwargs)
context['regions'] = Region.objects.filter(level=1)
return context
示例10: render_to_response
# 需要導入模塊: from django.views import generic [as 別名]
# 或者: from django.views.generic import TemplateView [as 別名]
def render_to_response(self, *args, **kwargs):
response = super(TabView, self).render_to_response(*args, **kwargs)
# Because Django's TemplateView uses the TemplateResponse class
# to provide deferred rendering (which is usually helpful), if
# a tab group raises an Http302 redirect (from exceptions.handle for
# example) the exception is actually raised *after* the final pass
# of the exception-handling middleware.
response.render()
return response
示例11: render_to_response
# 需要導入模塊: from django.views import generic [as 別名]
# 或者: from django.views.generic import TemplateView [as 別名]
def render_to_response(self, context, **response_kwargs):
response_kwargs["content_type"] = "text/plain"
return super(TemplateView, self).render_to_response(
context, **response_kwargs
)
示例12: get_context_data
# 需要導入模塊: from django.views import generic [as 別名]
# 或者: from django.views.generic import TemplateView [as 別名]
def get_context_data(self, hashtag):
context = super(TemplateView, self).get_context_data()
hashtag = hashtag.lower()
feed = feed_manager.get_feed('user', f'hash_{hashtag}')
activities = feed.get(limit=25)['results']
context['hashtag'] = hashtag
context['activities'] = enricher.enrich_activities(activities)
return context
示例13: post
# 需要導入模塊: from django.views import generic [as 別名]
# 或者: from django.views.generic import TemplateView [as 別名]
def post(self, request, pk, *args, **kwargs):
data = json.loads(self.request.body)
projects = data.get('projects')
users = data.get('users')
group = Group.objects.get(name=data.get('group'))
group_id = Group.objects.get(name="Project Manager").id
user = request.user
org = get_object_or_404(Organization, pk=pk)
task_obj = CeleryTaskProgress.objects.create(user=user, content_object = org, task_type=1)
if task_obj:
task = multiuserassignproject.delay(task_obj.pk, user, pk, projects, users, group_id)
task_obj.task_id=task.id
task_obj.save()
return HttpResponse("Sucess")
else:
return HttpResponse("Failed")
#May need it
# class MultiUserAssignProjectView(OrganizationRoleMixin, TemplateView):
# def get(self, request, pk):
# org_obj = Organization.objects.get(pk=pk)
# return render(request, 'fieldsight/multi_user_assign.html',{'type': "project", 'pk':pk})
# def post(self, request, *args, **kwargs):
# data = json.loads(self.request.body)
# projects = data.get('projects')
# users = data.get('users')
# group = Group.objects.get(name="Project Manager")
# for project_id in projects:
# project = Project.objects.get(pk=project_id)
# for user in users:
# role, created = UserRole.objects.get_or_create(user_id=user, project_id=project_id,
# organization__id=project.organization.id,
# project__id=project_id,
# group=group, ended_at=None)
# if created:
# description = "{0} was assigned as Project Manager in {1}".format(
# role.user.get_full_name(), role.project)
# noti = role.logs.create(source=role.user, type=6, title=description, description=description,
# content_object=role.project, extra_object=self.request.user)
# result = {}
# result['description'] = description
# result['url'] = noti.get_absolute_url()
# ChannelGroup("notify-{}".format(role.organization.id)).send({"text": json.dumps(result)})
# ChannelGroup("project-{}".format(role.project.id)).send({"text": json.dumps(result)})
# ChannelGroup("notify-0").send({"text": json.dumps(result)})
# return HttpResponse("Sucess")
示例14: get_context_data
# 需要導入模塊: from django.views import generic [as 別名]
# 或者: from django.views.generic import TemplateView [as 別名]
def get_context_data(self, **kwargs):
# Make sure both the Community, Project, and mentor are approved
# Note that accessing URL parameters like project_slug off kwargs only
# works because this is a TemplateView. For the various kinds of
# DetailViews, you have to use self.kwargs instead.
project = get_object_or_404(Project,
slug=kwargs['project_slug'],
approval_status=ApprovalStatus.APPROVED,
project_round__community__slug=kwargs['community_slug'],
project_round__participating_round__slug=kwargs['round_slug'],
project_round__approval_status=ApprovalStatus.APPROVED)
current_round = project.round()
# Note that there's no reason to ever keep someone who was a
# coordinator or mentor in a past round from looking at who applied in
# that round.
if not self.request.user.is_staff and not project.project_round.community.is_coordinator(self.request.user) and not project.round().is_mentor(self.request.user):
raise PermissionDenied("You are not an approved mentor for this project.")
contributions = project.contribution_set.filter(
applicant__approval_status=ApprovalStatus.APPROVED).order_by(
"applicant__applicant__public_name", "date_started")
internship_total_days = current_round.internends - current_round.internstarts
try:
mentor_approval = project.mentorapproval_set.approved().get(
mentor__account=self.request.user,
)
except MentorApproval.DoesNotExist:
mentor_approval = None
context = super(ProjectApplicants, self).get_context_data(**kwargs)
context.update({
'current_round': current_round,
'community': project.project_round.community,
'project': project,
'contributions': contributions,
'internship_total_days': internship_total_days,
'approved_mentor': project.is_submitter(self.request.user),
'is_staff': self.request.user.is_staff,
'mentor_approval': mentor_approval,
})
return context