mirror of
https://github.com/pretix/pretix.git
synced 2026-06-10 01:15:05 +00:00
* change linked orderpositions to many-to-many * Update media views to list ops * return last op as fallback for linked_orderposition * add multi-op to export * update media-API * fix media-view filter * update control media forms * fix API orders * fix API orders matching media * remove cached_property linked_orderposition - keep only in API * fix media-issue signal * adapt checkin API for multiple orderpositions * remove unneeded comment * fix create/update logging * fix tests * fix more tests * fix code style * add label to reusablemedium * fix migration NOT NULL * fix tests * update docs * clarify docs updating multiple linked_orderpositions * clarify docs * no need to prefetch linked_orderpositions * improve readability * select_related order instead prefetch * add filter based on op.valid_from/until * rename secret to claim_token * Update docs for claim_token * unifiy deprecated style * Update reusablemedia.rst * Update reusablemedia.rst * Update reusablemedia.rst * fix missing claim_token in serializer * fix flake8 * add add_to_reusable_medium to order-serializer * fix tests regarding claim_token * fix flake8 * Clarify docs * list ops comma-separated in export * Add test for order-API add_to_reusable_medium * fix linked_orderpositions filter in checkinrpc * add test * Add help-text * fix multi-op media filter * fix flake8 * improve check * Fix sorting of reusable media type in overview * Add copy and qr button to reusable medium detail view * Rebase against origin/master * Add logentrytype reusable_medium.linked_orderposition.removed * add missing label_from_instance for SafeOrderPositionMultipleChoiceField * add tests for create with linked_orderposition * API add test for fallback-values in medium patch * fix flake8 * Fix indentation * fix migrations numbering * fix test * unify qutation marks * fix flake8 * micro-improve linked_op-removal-logging * simplify filter instead of annotate/get * Do not translate API-errors Co-authored-by: Raphael Michel <michel@pretix.eu> * Fix typos in doc Co-authored-by: Raphael Michel <mail@raphaelmichel.de> * Update versionchanged in docs Co-authored-by: Raphael Michel <michel@pretix.eu> * Change log to always added not changed * Add test for checkinrpc for ops out of timerang or canceled * improve tests mixing ops from different organizers * Fix logging of changed order_positions * properly log added/removed when using UI * refactor logging code * unify logging adding/removing ops via API * fix flake8 * remove unnecessary prefetch as already prefetched * optimize fetching ops * combine addon match and time-based validity match * fix combined valid and product check * re-number migrations * Apply suggestion from @raphaelm Co-authored-by: Raphael Michel <michel@pretix.eu> * fix flake8 * New attempt at logic * Improve op_candidate-selection for error message if no op matches check-in * Fix typo * fix valid_from start time being included * use the datetime parameter for the comparison time so that the simulator works too --------- Co-authored-by: Maximilian Richt <richt@pretix.eu> Co-authored-by: Martin Gross <gross@rami.io> Co-authored-by: Raphael Michel <michel@pretix.eu> Co-authored-by: Raphael Michel <mail@raphaelmichel.de>
86 lines
3.6 KiB
Python
86 lines
3.6 KiB
Python
#
|
|
# This file is part of pretix (Community Edition).
|
|
#
|
|
# Copyright (C) 2014-2020 Raphael Michel and contributors
|
|
# Copyright (C) 2020-today pretix GmbH and contributors
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General
|
|
# Public License as published by the Free Software Foundation in version 3 of the License.
|
|
#
|
|
# ADDITIONAL TERMS APPLY: Pursuant to Section 7 of the GNU Affero General Public License, additional terms are
|
|
# applicable granting you additional permissions and placing additional restrictions on your usage of this software.
|
|
# Please refer to the pretix LICENSE file to obtain the full terms applicable to this work. If you did not receive
|
|
# this file, see <https://pretix.eu/about/en/license>.
|
|
#
|
|
# This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied
|
|
# warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
|
|
# details.
|
|
#
|
|
# You should have received a copy of the GNU Affero General Public License along with this program. If not, see
|
|
# <https://www.gnu.org/licenses/>.
|
|
#
|
|
|
|
from django.db.models import Prefetch
|
|
from django.dispatch import receiver
|
|
from django.utils.formats import date_format
|
|
from django.utils.translation import gettext_lazy as _, pgettext, pgettext_lazy
|
|
|
|
from ..exporter import ListExporter, OrganizerLevelExportMixin
|
|
from ..models import OrderPosition, ReusableMedium
|
|
from ..signals import register_multievent_data_exporters
|
|
|
|
|
|
class ReusableMediaExporter(OrganizerLevelExportMixin, ListExporter):
|
|
identifier = 'reusablemedia'
|
|
verbose_name = _('Reusable media')
|
|
category = pgettext_lazy('export_category', 'Reusable media')
|
|
description = _('Download a spread sheet with the data of all reusable medias on your account.')
|
|
repeatable_read = False
|
|
|
|
@classmethod
|
|
def get_required_organizer_permission(cls) -> str:
|
|
return "organizer.reusablemedia:read"
|
|
|
|
def iterate_list(self, form_data):
|
|
media = ReusableMedium.objects.filter(
|
|
organizer=self.organizer,
|
|
).select_related(
|
|
'customer', 'linked_giftcard',
|
|
).prefetch_related(
|
|
Prefetch('linked_orderpositions', queryset=OrderPosition.objects.select_related("order"))
|
|
).order_by('created')
|
|
|
|
headers = [
|
|
pgettext('reusable_medium', 'Media type'),
|
|
pgettext('reusable_medium', 'Identifier'),
|
|
_('Active'),
|
|
_('Expiration date'),
|
|
_('Customer account'),
|
|
_('Linked ticket'),
|
|
_('Linked gift card'),
|
|
_('Notes'),
|
|
]
|
|
|
|
yield headers
|
|
yield self.ProgressSetTotal(total=media.count())
|
|
|
|
for medium in media.iterator(chunk_size=1000):
|
|
yield [
|
|
medium.type,
|
|
medium.identifier,
|
|
_('Yes') if medium.active else _('No'),
|
|
date_format(medium.expires, 'SHORT_DATETIME_FORMAT') if medium.expires else '',
|
|
medium.customer.identifier if medium.customer_id else '',
|
|
', '.join([f"{op.order.code}-{op.positionid}" for op in medium.linked_orderpositions.all()]),
|
|
medium.linked_giftcard.secret if medium.linked_giftcard_id else '',
|
|
medium.notes,
|
|
]
|
|
|
|
def get_filename(self):
|
|
return f'{self.organizer.slug}_media'
|
|
|
|
|
|
@receiver(register_multievent_data_exporters, dispatch_uid="multiexporter_reusablemedia")
|
|
def register_multievent_i_reusable_media_exporter(sender, **kwargs):
|
|
return ReusableMediaExporter
|