コード例 #1
0
def view_event(request, event_id):
    """
    Display single Event page.
    """
    event = get_object_or_404(Event, pk=event_id)

    if not event.visible():
        raise PermissionDenied

    entry_ids = Entry.all_visible.filter(event=event).values_list('id', flat=True)
    entries_map = Entry.prefetch_entries(entry_ids, show_unapproved=is_contributor(request))

    entries = sorted(entries_map.values(), key=lambda e: e.order)
    sources = list(event.sources_iterator())

    approval_msg = get_config('approval_message')
    if event.review_state == Event.REVIEW_APPROVED:
        approval_explanation = get_config('review_reviewed_explanation')
    elif event.review_state == Event.REVIEW_PENDING:
        approval_explanation = get_config('review_pending_explanation')
    else:
        approval_explanation = ''

    return render(request, 'palanaeum/event.html', {'event': event, 'entries': entries, 'sources': sources,
                                                    'approval_msg': approval_msg,
                                                    'review_message': approval_explanation})
コード例 #2
0
def recent_entries(request):
    """
    Show recent entries, sorted by their assigned date, modification or creation date.
    """
    date_mode = request.GET.get('mode', 'created')

    if date_mode == 'modified':
        entries_ids = Entry.all_visible.order_by('-modified').values_list('id', flat=True)
    elif date_mode == 'recorded':
        entries_ids = EntryVersion.newest.order_by('-entry_date', '-entry_id')\
            .values_list('entry_id', flat=True).distinct()
    else:  # Sort by creation date by default
        entries_ids = Entry.all_visible.order_by('-created').values_list('id', flat=True)

    page_length = UserSettings.get_page_length(request)
    page_num = request.GET.get('page', '1')

    paginator = Paginator(entries_ids, page_length, orphans=page_length // 10)

    try:
        page = paginator.page(page_num)
    except PageNotAnInteger:
        page = paginator.page(1)
    except EmptyPage:
        page = paginator.page(paginator.num_pages)

    to_show = page_numbers_to_show(paginator, page.number)

    entries_map = Entry.prefetch_entries(page, show_unapproved=is_contributor(request))
    entries = [entries_map[entry_id] for entry_id in page]

    return render(request, 'palanaeum/recent_entries.html',
                  {'page_numbers_to_show': to_show, 'page': page, 'entries': entries, 'mode': date_mode,
                   'page_params': 'mode={}'.format(date_mode)})
コード例 #3
0
def sort_entries_page(request, event_id):
    event = get_object_or_404(Event, pk=event_id)
    entries_ids = Entry.objects.filter(event=event).values_list('id', flat=True)
    entries = Entry.prefetch_entries(entries_ids, show_unapproved=True)
    entries = sorted(entries.values(), key=lambda e: e.order)
    return render(request, 'palanaeum/staff/sort_entries.html',
                  {'event': event, 'entries': entries, 'sources': list(event.sources_iterator())})
コード例 #4
0
ファイル: views.py プロジェクト: Hillshum/palanaeum
def show_collection(request, collection_id):
    """
    Check if user can view this collections and display it.
    """
    collection = get_object_or_404(UsersEntryCollection, pk=collection_id)

    if not (collection.public or collection.user == request.user
            or request.user.is_superuser):
        messages.error(request,
                       _('You are not allowed to see this collection.'))
        return redirect('index')
    elif collection.user != request.user and request.user.is_superuser:
        messages.info(request,
                      _('You are viewing a private collection as superuser.'))

    entries_ids = collection.entries.all().values_list('id', flat=True)
    entries = Entry.prefetch_entries(entries_ids)
    entries = [entries[eid] for eid in entries_ids]

    return render(
        request, 'palanaeum/collections/collection.html', {
            'entries': entries,
            'collection': collection,
            'is_owner': collection.user == request.user
        })
コード例 #5
0
ファイル: feeds.py プロジェクト: piyushd26/palanaeum
 def items(self, event):
     entry_ids = Entry.all_visible.filter(event=event).values_list(
         'id', flat=True)
     entries_map = Entry.prefetch_entries(entry_ids, show_unapproved=False)
     return sorted(
         (entry
          for entry in (entries_map[entry_id] for entry_id in entry_ids)
          if entry.last_version is not None),
         key=lambda e: e.order)
コード例 #6
0
ファイル: feeds.py プロジェクト: piyushd26/palanaeum
 def items(self):
     entry_ids = Entry.all_visible.order_by('-created').values_list(
         'id', flat=True)[:10]
     entries_map = Entry.prefetch_entries(entry_ids, show_unapproved=False)
     return [
         entry
         for entry in (entries_map[entry_id] for entry_id in entry_ids)
         if entry.last_version is not None
     ]
コード例 #7
0
def view_event(request, event_id):
    """
    Display single Event page.
    """
    event = get_object_or_404(Event, pk=event_id)

    if not event.visible():
        raise PermissionDenied

    # Caching only responses for anonymous users, as that's the majority of
    # visits and those don't change that much.
    anonymous_user_cache = "anon_event_view_{}".format(event_id)

    if request.user and request.user.is_anonymous:
        cached_response = cache.get(anonymous_user_cache)
        if cached_response is not None:
            cached_response, cache_timestamp = cached_response
            if cache_timestamp <= event.modified_date:
                return cached_response

    entry_ids = Entry.all_visible.filter(event=event).values_list('id',
                                                                  flat=True)
    entries_map = Entry.prefetch_entries(
        entry_ids, show_unapproved=is_contributor(request))

    entries = sorted(entries_map.values(), key=lambda e: e.order)
    sources = list(event.sources_iterator())

    approval_msg = get_config('approval_message')
    if event.review_state == Event.REVIEW_APPROVED:
        approval_explanation = get_config('review_reviewed_explanation')
    elif event.review_state == Event.REVIEW_PENDING:
        approval_explanation = get_config('review_pending_explanation')
    else:
        approval_explanation = ''

    response = render(
        request, 'palanaeum/event.html', {
            'event': event,
            'entries': entries,
            'sources': sources,
            'approval_msg': approval_msg,
            'review_message': approval_explanation
        })

    if request.user and request.user.is_anonymous:
        cache.set(anonymous_user_cache, (response, event.modified_date))

    return response
コード例 #8
0
def staff_cp_suggestions(request):
    source_suggestions = list(AudioSource.objects.filter(is_approved=False))
    source_suggestions.extend(ImageSource.objects.filter(is_approved=False))

    entry_suggestions_id = Entry.objects.filter(versions__is_approved=False).values_list('id', flat=True)
    entry_suggestions = Entry.prefetch_entries(entry_suggestions_id, show_unapproved=True).values()

    all_suggestions = defaultdict(lambda: defaultdict(list))
    for entry in entry_suggestions:
        all_suggestions[entry.event]['entries'].append(entry)

    for source in source_suggestions:
        all_suggestions[source.event]['sources'].append(source)

    return render(request, 'palanaeum/staff/staff_cp_suggestions.html',
                  {'sources': source_suggestions, 'entries': entry_suggestions,
                   'all_suggestions': dict(all_suggestions),
                   'page': 'suggestions'})
コード例 #9
0
ファイル: search.py プロジェクト: piyushd26/palanaeum
def paginate_search_results(request, search_results: list) -> tuple:
    """
    Preload a page of search results. Return loaded entries, paginator object and page object.
    """
    page_length = UserSettings.get_page_length(request)
    paginator = Paginator(search_results,
                          page_length,
                          orphans=page_length // 10)

    page_num = request.GET.get('page', '1')

    try:
        page = paginator.page(page_num)
    except PageNotAnInteger:
        page = paginator.page(1)
    except EmptyPage:
        page = paginator.page(paginator.num_pages)

    entries_ids = [entry[0] for entry in page]
    entries_map = Entry.prefetch_entries(entries_ids)

    entries = [(entries_map[entry_id], rank) for entry_id, rank in page]

    return entries, paginator, page