mirror of
https://github.com/pretix/pretix.git
synced 2026-03-27 16:32:26 +00:00
Compare commits
25 Commits
2fa-flowto
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
4c0c775baa | ||
|
|
394652a5ff | ||
|
|
3f50d065ec | ||
|
|
4121061267 | ||
|
|
aed2220139 | ||
|
|
4b2c54d38e | ||
|
|
0113a3dc1f | ||
|
|
c12a8935f1 | ||
|
|
a86a6cc2c7 | ||
|
|
fec2b9a2fc | ||
|
|
d847a7e8f8 | ||
|
|
c58a968196 | ||
|
|
81cbaca162 | ||
|
|
218df7a49f | ||
|
|
f64343d977 | ||
|
|
b36c7cbef3 | ||
|
|
18b39ba7cd | ||
|
|
1383e967df | ||
|
|
c743e9fd3f | ||
|
|
a71efa6747 | ||
|
|
4fed47fb9b | ||
|
|
c143d50290 | ||
|
|
88cd715ece | ||
|
|
3513de6a45 | ||
|
|
fd6d3934c0 |
2
.github/workflows/build.yml
vendored
2
.github/workflows/build.yml
vendored
@@ -24,7 +24,7 @@ jobs:
|
||||
name: Packaging
|
||||
strategy:
|
||||
matrix:
|
||||
python-version: ["3.11"]
|
||||
python-version: ["3.13"]
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Set up Python ${{ matrix.python-version }}
|
||||
|
||||
8
.github/workflows/strings.yml
vendored
8
.github/workflows/strings.yml
vendored
@@ -24,10 +24,10 @@ jobs:
|
||||
name: Check gettext syntax
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Set up Python 3.11
|
||||
- name: Set up Python 3.13
|
||||
uses: actions/setup-python@v5
|
||||
with:
|
||||
python-version: 3.11
|
||||
python-version: 3.13
|
||||
- uses: actions/cache@v4
|
||||
with:
|
||||
path: ~/.cache/pip
|
||||
@@ -49,10 +49,10 @@ jobs:
|
||||
name: Spellcheck
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Set up Python 3.11
|
||||
- name: Set up Python 3.13
|
||||
uses: actions/setup-python@v5
|
||||
with:
|
||||
python-version: 3.11
|
||||
python-version: 3.13
|
||||
- uses: actions/cache@v4
|
||||
with:
|
||||
path: ~/.cache/pip
|
||||
|
||||
12
.github/workflows/style.yml
vendored
12
.github/workflows/style.yml
vendored
@@ -24,10 +24,10 @@ jobs:
|
||||
runs-on: ubuntu-22.04
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Set up Python 3.11
|
||||
- name: Set up Python 3.13
|
||||
uses: actions/setup-python@v5
|
||||
with:
|
||||
python-version: 3.11
|
||||
python-version: 3.13
|
||||
- uses: actions/cache@v4
|
||||
with:
|
||||
path: ~/.cache/pip
|
||||
@@ -44,10 +44,10 @@ jobs:
|
||||
runs-on: ubuntu-22.04
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Set up Python 3.11
|
||||
- name: Set up Python 3.13
|
||||
uses: actions/setup-python@v5
|
||||
with:
|
||||
python-version: 3.11
|
||||
python-version: 3.13
|
||||
- uses: actions/cache@v4
|
||||
with:
|
||||
path: ~/.cache/pip
|
||||
@@ -64,10 +64,10 @@ jobs:
|
||||
runs-on: ubuntu-22.04
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Set up Python 3.11
|
||||
- name: Set up Python 3.13
|
||||
uses: actions/setup-python@v5
|
||||
with:
|
||||
python-version: 3.11
|
||||
python-version: 3.13
|
||||
- name: Install Dependencies
|
||||
run: pip3 install licenseheaders
|
||||
- name: Run licenseheaders
|
||||
|
||||
6
.github/workflows/tests.yml
vendored
6
.github/workflows/tests.yml
vendored
@@ -23,13 +23,15 @@ jobs:
|
||||
name: Tests
|
||||
strategy:
|
||||
matrix:
|
||||
python-version: ["3.10", "3.11", "3.13"]
|
||||
python-version: ["3.11", "3.13", "3.14"]
|
||||
database: [sqlite, postgres]
|
||||
exclude:
|
||||
- database: sqlite
|
||||
python-version: "3.10"
|
||||
- database: sqlite
|
||||
python-version: "3.11"
|
||||
- database: sqlite
|
||||
python-version: "3.12"
|
||||
services:
|
||||
postgres:
|
||||
image: postgres:15
|
||||
@@ -81,4 +83,4 @@ jobs:
|
||||
file: src/coverage.xml
|
||||
token: ${{ secrets.CODECOV_TOKEN }}
|
||||
fail_ci_if_error: false
|
||||
if: matrix.database == 'postgres' && matrix.python-version == '3.11'
|
||||
if: matrix.database == 'postgres' && matrix.python-version == '3.13'
|
||||
|
||||
@@ -3,7 +3,7 @@ name = "pretix"
|
||||
dynamic = ["version"]
|
||||
description = "Reinventing presales, one ticket at a time"
|
||||
readme = "README.rst"
|
||||
requires-python = ">=3.10"
|
||||
requires-python = ">=3.11"
|
||||
license = {file = "LICENSE"}
|
||||
keywords = ["tickets", "web", "shop", "ecommerce"]
|
||||
authors = [
|
||||
@@ -19,10 +19,11 @@ classifiers = [
|
||||
"Topic :: Internet :: WWW/HTTP :: Dynamic Content",
|
||||
"Environment :: Web Environment",
|
||||
"License :: OSI Approved :: GNU Affero General Public License v3",
|
||||
"Programming Language :: Python :: 3.9",
|
||||
"Programming Language :: Python :: 3.10",
|
||||
"Programming Language :: Python :: 3.11",
|
||||
"Framework :: Django :: 4.2",
|
||||
"Programming Language :: Python :: 3.12",
|
||||
"Programming Language :: Python :: 3.13",
|
||||
"Programming Language :: Python :: 3.14",
|
||||
"Framework :: Django :: 5.2",
|
||||
]
|
||||
|
||||
dependencies = [
|
||||
@@ -36,7 +37,7 @@ dependencies = [
|
||||
"css-inline==0.20.*",
|
||||
"defusedcsv>=1.1.0",
|
||||
"dnspython==2.*",
|
||||
"Django[argon2]==4.2.*,>=4.2.26",
|
||||
"Django[argon2]==5.2.*",
|
||||
"django-bootstrap3==26.1",
|
||||
"django-compressor==4.6.0",
|
||||
"django-countries==8.2.*",
|
||||
@@ -59,7 +60,7 @@ dependencies = [
|
||||
"dnspython==2.8.*",
|
||||
"drf_ujson2==1.7.*",
|
||||
"geoip2==5.*",
|
||||
"importlib_metadata==8.*", # Polyfill, we can probably drop this once we require Python 3.10+
|
||||
"importlib_metadata==9.*", # Polyfill, we can probably drop this once we require Python 3.10+
|
||||
"isoweek",
|
||||
"jsonschema",
|
||||
"kombu==5.6.*",
|
||||
@@ -92,7 +93,7 @@ dependencies = [
|
||||
"redis==7.1.*",
|
||||
"reportlab==4.4.*",
|
||||
"requests==2.32.*",
|
||||
"sentry-sdk==2.54.*",
|
||||
"sentry-sdk==2.56.*",
|
||||
"sepaxml==2.7.*",
|
||||
"stripe==7.9.*",
|
||||
"text-unidecode==1.*",
|
||||
|
||||
@@ -45,7 +45,6 @@ import pycountry
|
||||
from django import forms
|
||||
from django.conf import settings
|
||||
from django.contrib import messages
|
||||
from django.contrib.gis.geoip2 import GeoIP2
|
||||
from django.core.exceptions import ValidationError
|
||||
from django.core.files.uploadedfile import SimpleUploadedFile
|
||||
from django.core.validators import (
|
||||
@@ -102,6 +101,7 @@ from pretix.helpers.countries import (
|
||||
from pretix.helpers.escapejson import escapejson_attr
|
||||
from pretix.helpers.http import get_client_ip
|
||||
from pretix.helpers.i18n import get_format_without_seconds
|
||||
from pretix.helpers.security import get_geoip
|
||||
from pretix.presale.signals import question_form_fields
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
@@ -393,7 +393,7 @@ class WrappedPhoneNumberPrefixWidget(PhoneNumberPrefixWidget):
|
||||
|
||||
def guess_country_from_request(request, event):
|
||||
if settings.HAS_GEOIP:
|
||||
g = GeoIP2()
|
||||
g = get_geoip()
|
||||
try:
|
||||
res = g.country(get_client_ip(request))
|
||||
if res['country_code'] and len(res['country_code']) == 2:
|
||||
|
||||
@@ -36,8 +36,9 @@ from django.core.management.commands.makemigrations import Command as Parent
|
||||
|
||||
from ._migrations import monkeypatch_migrations
|
||||
|
||||
monkeypatch_migrations()
|
||||
|
||||
|
||||
class Command(Parent):
|
||||
pass
|
||||
|
||||
def handle(self, *args, **kwargs):
|
||||
monkeypatch_migrations()
|
||||
return super().handle(*args, **kwargs)
|
||||
|
||||
@@ -64,7 +64,7 @@ class Command(BaseCommand):
|
||||
if not periodic_task.receivers or periodic_task.sender_receivers_cache.get(self) is NO_RECEIVERS:
|
||||
return
|
||||
|
||||
for receiver in periodic_task._live_receivers(self):
|
||||
for receiver in periodic_task._live_receivers(self)[0]:
|
||||
name = f'{receiver.__module__}.{receiver.__name__}'
|
||||
if options['list_tasks']:
|
||||
print(name)
|
||||
|
||||
@@ -41,16 +41,20 @@ class Migration(migrations.Migration):
|
||||
name='datetime',
|
||||
field=models.DateTimeField(),
|
||||
),
|
||||
migrations.AlterIndexTogether(
|
||||
name='logentry',
|
||||
index_together={('datetime', 'id')},
|
||||
migrations.AddIndex(
|
||||
'logentry',
|
||||
models.Index(fields=('datetime', 'id'), name="pretixbase__datetim_b1fe5a_idx"),
|
||||
),
|
||||
migrations.AlterIndexTogether(
|
||||
name='order',
|
||||
index_together={('datetime', 'id'), ('last_modified', 'id')},
|
||||
migrations.AddIndex(
|
||||
'order',
|
||||
models.Index(fields=["datetime", "id"], name="pretixbase__datetim_66aff0_idx"),
|
||||
),
|
||||
migrations.AlterIndexTogether(
|
||||
name='transaction',
|
||||
index_together={('datetime', 'id')},
|
||||
migrations.AddIndex(
|
||||
'order',
|
||||
models.Index(fields=["last_modified", "id"], name="pretixbase__last_mo_4ebf8b_idx"),
|
||||
),
|
||||
migrations.AddIndex(
|
||||
'transaction',
|
||||
models.Index(fields=('datetime', 'id'), name="pretixbase__datetim_b20405_idx"),
|
||||
),
|
||||
]
|
||||
|
||||
@@ -61,7 +61,10 @@ class Migration(migrations.Migration):
|
||||
options={
|
||||
'ordering': ('identifier', 'type', 'organizer'),
|
||||
'unique_together': {('identifier', 'type', 'organizer')},
|
||||
'index_together': {('identifier', 'type', 'organizer'), ('updated', 'id')},
|
||||
'indexes': [
|
||||
models.Index(fields=('identifier', 'type', 'organizer'), name='reusable_medium_organizer_index'),
|
||||
models.Index(fields=('updated', 'id'), name="pretixbase__updated_093277_idx")
|
||||
],
|
||||
},
|
||||
bases=(models.Model, pretix.base.models.base.LoggingMixin),
|
||||
),
|
||||
|
||||
@@ -9,31 +9,6 @@ class Migration(migrations.Migration):
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.RenameIndex(
|
||||
model_name="logentry",
|
||||
new_name="pretixbase__datetim_b1fe5a_idx",
|
||||
old_fields=("datetime", "id"),
|
||||
),
|
||||
migrations.RenameIndex(
|
||||
model_name="order",
|
||||
new_name="pretixbase__datetim_66aff0_idx",
|
||||
old_fields=("datetime", "id"),
|
||||
),
|
||||
migrations.RenameIndex(
|
||||
model_name="order",
|
||||
new_name="pretixbase__last_mo_4ebf8b_idx",
|
||||
old_fields=("last_modified", "id"),
|
||||
),
|
||||
migrations.RenameIndex(
|
||||
model_name="reusablemedium",
|
||||
new_name="pretixbase__updated_093277_idx",
|
||||
old_fields=("updated", "id"),
|
||||
),
|
||||
migrations.RenameIndex(
|
||||
model_name="transaction",
|
||||
new_name="pretixbase__datetim_b20405_idx",
|
||||
old_fields=("datetime", "id"),
|
||||
),
|
||||
migrations.AlterField(
|
||||
model_name="attendeeprofile",
|
||||
name="id",
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
# Generated by Django 4.2.10 on 2024-04-02 15:16
|
||||
|
||||
from django.db import migrations
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
@@ -10,8 +10,8 @@ class Migration(migrations.Migration):
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.AlterIndexTogether(
|
||||
name="reusablemedium",
|
||||
index_together=set(),
|
||||
migrations.RemoveIndex(
|
||||
"reusablemedium",
|
||||
'reusable_medium_organizer_index',
|
||||
),
|
||||
]
|
||||
|
||||
@@ -88,7 +88,7 @@ class LogEntry(models.Model):
|
||||
|
||||
class Meta:
|
||||
ordering = ('-datetime', '-id')
|
||||
indexes = [models.Index(fields=["datetime", "id"])]
|
||||
indexes = [models.Index(fields=["datetime", "id"], name="pretixbase__datetim_b1fe5a_idx")]
|
||||
|
||||
def display(self):
|
||||
from pretix.base.logentrytype_registry import log_entry_types
|
||||
|
||||
@@ -122,7 +122,7 @@ class ReusableMedium(LoggedModel):
|
||||
class Meta:
|
||||
unique_together = (("identifier", "type", "organizer"),)
|
||||
indexes = [
|
||||
models.Index(fields=("updated", "id")),
|
||||
models.Index(fields=("updated", "id"), name="pretixbase__updated_093277_idx"),
|
||||
]
|
||||
ordering = "identifier", "type", "organizer"
|
||||
|
||||
|
||||
@@ -336,8 +336,8 @@ class Order(LockModel, LoggedModel):
|
||||
verbose_name_plural = _("Orders")
|
||||
ordering = ("-datetime", "-pk")
|
||||
indexes = [
|
||||
models.Index(fields=["datetime", "id"]),
|
||||
models.Index(fields=["last_modified", "id"]),
|
||||
models.Index(fields=["datetime", "id"], name="pretixbase__datetim_66aff0_idx"),
|
||||
models.Index(fields=["last_modified", "id"], name="pretixbase__last_mo_4ebf8b_idx"),
|
||||
]
|
||||
constraints = [
|
||||
models.UniqueConstraint(fields=["organizer", "code"], name="order_organizer_code_uniq"),
|
||||
@@ -3080,7 +3080,7 @@ class Transaction(models.Model):
|
||||
class Meta:
|
||||
ordering = 'datetime', 'pk'
|
||||
indexes = [
|
||||
models.Index(fields=['datetime', 'id'])
|
||||
models.Index(fields=['datetime', 'id'], name="pretixbase__datetim_b20405_idx")
|
||||
]
|
||||
|
||||
def save(self, *args, **kwargs):
|
||||
|
||||
@@ -100,7 +100,7 @@ def primary_font_kwargs():
|
||||
|
||||
choices = [('Open Sans', 'Open Sans')]
|
||||
choices += sorted([
|
||||
(a, {"title": a, "data": v}) for a, v in get_fonts(pdf_support_required=False).items()
|
||||
(a, FontSelect.FontOption(title=a, data=v)) for a, v in get_fonts(pdf_support_required=False).items()
|
||||
], key=lambda a: a[0])
|
||||
return {
|
||||
'choices': choices,
|
||||
@@ -4148,6 +4148,14 @@ def validate_event_settings(event, settings_dict):
|
||||
)
|
||||
]}
|
||||
)
|
||||
if (
|
||||
settings_dict.get('invoice_address_from_vat_id') and
|
||||
settings_dict.get('invoice_address_from_country') and
|
||||
settings_dict.get('invoice_address_from_country') not in VAT_ID_COUNTRIES
|
||||
):
|
||||
raise ValidationError({
|
||||
'invoice_address_from_vat_id': _('VAT-ID is not supported for "{}".').format(settings_dict.get('invoice_address_from_country'))
|
||||
})
|
||||
|
||||
payment_term_last = settings_dict.get('payment_term_last')
|
||||
if payment_term_last and event.presale_end:
|
||||
|
||||
@@ -32,6 +32,7 @@
|
||||
# distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||
# License for the specific language governing permissions and limitations under the License.
|
||||
|
||||
import logging
|
||||
import warnings
|
||||
from typing import Any, Callable, Generic, List, Tuple, TypeVar
|
||||
|
||||
@@ -48,6 +49,8 @@ from .plugins import (
|
||||
PLUGIN_LEVEL_ORGANIZER,
|
||||
)
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
app_cache = {}
|
||||
T = TypeVar('T')
|
||||
|
||||
@@ -60,23 +63,25 @@ def _populate_app_cache():
|
||||
|
||||
def get_defining_app(o):
|
||||
# If sentry packed this in a wrapper, unpack that
|
||||
if "sentry" in o.__module__:
|
||||
module = getattr(o, "__module__", None)
|
||||
if module and "sentry" in module:
|
||||
o = o.__wrapped__
|
||||
|
||||
if hasattr(o, "__mocked_app"):
|
||||
return o.__mocked_app
|
||||
|
||||
# Find the Django application this belongs to
|
||||
searchpath = o.__module__
|
||||
searchpath = module or getattr(o.__class__, "__module__", None) or ""
|
||||
|
||||
# Core modules are always active
|
||||
if any(searchpath.startswith(cm) for cm in settings.CORE_MODULES):
|
||||
if searchpath and any(searchpath.startswith(cm) for cm in settings.CORE_MODULES):
|
||||
return 'CORE'
|
||||
|
||||
if not app_cache:
|
||||
_populate_app_cache()
|
||||
|
||||
while True:
|
||||
app = None
|
||||
while searchpath:
|
||||
app = app_cache.get(searchpath)
|
||||
if "." not in searchpath or app:
|
||||
break
|
||||
@@ -157,7 +162,7 @@ class PluginSignal(Generic[T], django.dispatch.Signal):
|
||||
if not app_cache:
|
||||
_populate_app_cache()
|
||||
|
||||
for receiver in self._sorted_receivers(sender):
|
||||
for receiver in self._live_receivers(sender)[0]:
|
||||
if self._is_receiver_active(sender, receiver):
|
||||
response = receiver(signal=self, sender=sender, **named)
|
||||
responses.append((receiver, response))
|
||||
@@ -179,7 +184,7 @@ class PluginSignal(Generic[T], django.dispatch.Signal):
|
||||
if not app_cache:
|
||||
_populate_app_cache()
|
||||
|
||||
for receiver in self._sorted_receivers(sender):
|
||||
for receiver in self._live_receivers(sender)[0]:
|
||||
if self._is_receiver_active(sender, receiver):
|
||||
named[chain_kwarg_name] = response
|
||||
response = receiver(signal=self, sender=sender, **named)
|
||||
@@ -204,7 +209,7 @@ class PluginSignal(Generic[T], django.dispatch.Signal):
|
||||
if not app_cache:
|
||||
_populate_app_cache()
|
||||
|
||||
for receiver in self._sorted_receivers(sender):
|
||||
for receiver in self._live_receivers(sender)[0]:
|
||||
if self._is_receiver_active(sender, receiver):
|
||||
try:
|
||||
response = receiver(signal=self, sender=sender, **named)
|
||||
@@ -214,17 +219,35 @@ class PluginSignal(Generic[T], django.dispatch.Signal):
|
||||
responses.append((receiver, response))
|
||||
return responses
|
||||
|
||||
def _sorted_receivers(self, sender):
|
||||
orig_list = self._live_receivers(sender)
|
||||
def asend(self, sender: T, **named):
|
||||
raise NotImplementedError() # NOQA
|
||||
|
||||
def asend_robust(self, sender: T, **named):
|
||||
raise NotImplementedError() # NOQA
|
||||
|
||||
def _live_receivers(self, sender):
|
||||
orig_list, orig_async_list = super()._live_receivers(sender)
|
||||
|
||||
if orig_async_list:
|
||||
logger.error('Async receivers are not supported.')
|
||||
raise NotImplementedError
|
||||
|
||||
def _getattr_fallback_to_class(obj, key):
|
||||
return getattr(obj, key, getattr(obj.__class__, key))
|
||||
|
||||
def _is_core_module(receiver):
|
||||
m = _getattr_fallback_to_class(receiver, "__module__")
|
||||
return any(m.startswith(c) for c in settings.CORE_MODULES)
|
||||
|
||||
sorted_list = sorted(
|
||||
orig_list,
|
||||
key=lambda receiver: (
|
||||
0 if any(receiver.__module__.startswith(m) for m in settings.CORE_MODULES) else 1,
|
||||
receiver.__module__,
|
||||
receiver.__name__,
|
||||
0 if _is_core_module(receiver) else 1,
|
||||
_getattr_fallback_to_class(receiver, "__module__"),
|
||||
_getattr_fallback_to_class(receiver, "__name__"),
|
||||
)
|
||||
)
|
||||
return sorted_list
|
||||
return sorted_list, []
|
||||
|
||||
|
||||
class EventPluginSignal(PluginSignal[Event]):
|
||||
@@ -300,23 +323,41 @@ class GlobalSignal(django.dispatch.Signal):
|
||||
if not self.receivers or self.sender_receivers_cache.get(sender) is NO_RECEIVERS:
|
||||
return response
|
||||
|
||||
for receiver in self._live_receivers(sender):
|
||||
for receiver in self._live_receivers(sender)[0]:
|
||||
named[chain_kwarg_name] = response
|
||||
response = receiver(signal=self, sender=sender, **named)
|
||||
return response
|
||||
|
||||
def asend(self, sender: T, **named):
|
||||
raise NotImplementedError() # NOQA
|
||||
|
||||
def asend_robust(self, sender: T, **named):
|
||||
raise NotImplementedError() # NOQA
|
||||
|
||||
def _live_receivers(self, sender):
|
||||
# Ensure consistent sorting of receivers
|
||||
orig_list = super()._live_receivers(sender)
|
||||
orig_list, orig_async_list = super()._live_receivers(sender)
|
||||
|
||||
if orig_async_list:
|
||||
logger.error('Async receivers are not supported.')
|
||||
raise NotImplementedError
|
||||
|
||||
def _getattr_fallback_to_class(obj, key):
|
||||
return getattr(obj, key, getattr(obj.__class__, key))
|
||||
|
||||
def _is_core_module(receiver):
|
||||
m = _getattr_fallback_to_class(receiver, "__module__")
|
||||
return any(m.startswith(c) for c in settings.CORE_MODULES)
|
||||
|
||||
sorted_list = sorted(
|
||||
orig_list,
|
||||
key=lambda receiver: (
|
||||
0 if any(receiver.__module__.startswith(m) for m in settings.CORE_MODULES) else 1,
|
||||
receiver.__module__,
|
||||
receiver.__name__,
|
||||
0 if _is_core_module(receiver) else 1,
|
||||
_getattr_fallback_to_class(receiver, "__module__"),
|
||||
_getattr_fallback_to_class(receiver, "__name__"),
|
||||
)
|
||||
)
|
||||
return sorted_list
|
||||
return sorted_list, []
|
||||
|
||||
|
||||
class DeprecatedSignal(GlobalSignal):
|
||||
|
||||
@@ -34,6 +34,7 @@
|
||||
|
||||
import datetime
|
||||
import os
|
||||
from dataclasses import dataclass
|
||||
|
||||
from django import forms
|
||||
from django.conf import settings
|
||||
@@ -420,6 +421,11 @@ class SplitDateTimeField(forms.SplitDateTimeField):
|
||||
class FontSelect(forms.RadioSelect):
|
||||
option_template_name = 'pretixcontrol/font_option.html'
|
||||
|
||||
@dataclass
|
||||
class FontOption:
|
||||
title: str
|
||||
data: str
|
||||
|
||||
|
||||
class ItemMultipleChoiceField(SafeModelMultipleChoiceField):
|
||||
def label_from_instance(self, obj):
|
||||
|
||||
@@ -63,7 +63,7 @@ from pretix.base.forms import (
|
||||
from pretix.base.models import Event, Organizer, TaxRule, Team
|
||||
from pretix.base.models.event import EventFooterLink, EventMetaValue, SubEvent
|
||||
from pretix.base.models.organizer import TeamQuerySet
|
||||
from pretix.base.models.tax import TAX_CODE_LISTS
|
||||
from pretix.base.models.tax import TAX_CODE_LISTS, VAT_ID_COUNTRIES
|
||||
from pretix.base.reldate import RelativeDateField, RelativeDateTimeField
|
||||
from pretix.base.services.placeholders import FormPlaceholderMixin
|
||||
from pretix.base.settings import (
|
||||
@@ -73,8 +73,8 @@ from pretix.base.settings import (
|
||||
)
|
||||
from pretix.base.validators import multimail_validate
|
||||
from pretix.control.forms import (
|
||||
MultipleLanguagesWidget, SalesChannelCheckboxSelectMultiple, SlugWidget,
|
||||
SplitDateTimeField, SplitDateTimePickerWidget,
|
||||
FontSelect, MultipleLanguagesWidget, SalesChannelCheckboxSelectMultiple,
|
||||
SlugWidget, SplitDateTimeField, SplitDateTimePickerWidget,
|
||||
)
|
||||
from pretix.control.forms.widgets import Select2
|
||||
from pretix.helpers.countries import CachedCountries
|
||||
@@ -531,6 +531,13 @@ class EventUpdateForm(I18nModelForm):
|
||||
|
||||
class EventSettingsValidationMixin:
|
||||
|
||||
def clean_invoice_address_from_vat_id(self):
|
||||
value = self.cleaned_data.get('invoice_address_from_vat_id')
|
||||
country = self.cleaned_data.get('invoice_address_from_country')
|
||||
if value and country and country not in VAT_ID_COUNTRIES:
|
||||
return None
|
||||
return value
|
||||
|
||||
def clean(self):
|
||||
data = super().clean()
|
||||
settings_dict = self.obj.settings.freeze()
|
||||
@@ -722,7 +729,7 @@ class EventSettingsForm(EventSettingsValidationMixin, FormPlaceholderMixin, Sett
|
||||
del self.fields['event_list_filters']
|
||||
del self.fields['event_calendar_future_only']
|
||||
self.fields['primary_font'].choices = [('Open Sans', 'Open Sans')] + sorted([
|
||||
(a, {"title": a, "data": v}) for a, v in get_fonts(self.event, pdf_support_required=False).items()
|
||||
(a, FontSelect.FontOption(title=a, data=v)) for a, v in get_fonts(self.event, pdf_support_required=False).items()
|
||||
], key=lambda a: a[0])
|
||||
|
||||
# create "virtual" fields for better UX when editing <name>_asked and <name>_required fields
|
||||
|
||||
@@ -363,7 +363,7 @@ def get_global_navigation(request):
|
||||
'icon': 'dashboard',
|
||||
},
|
||||
]
|
||||
if request.user.is_in_any_teams:
|
||||
if request.user.is_in_any_teams or request.user.is_staff:
|
||||
nav += [
|
||||
{
|
||||
'label': _('Events'),
|
||||
|
||||
@@ -6,35 +6,44 @@
|
||||
<h1>{% trans "Add a two-factor authentication device" %}</h1>
|
||||
<form action="" method="post" class="form-horizontal">
|
||||
{% csrf_token %}
|
||||
<input type="hidden" name="flow_token" value="{{ flow_token }}">
|
||||
{% bootstrap_form_errors form %}
|
||||
{% bootstrap_field form.name layout='horizontal' %}
|
||||
|
||||
<div class="form-group">
|
||||
<div class="form-group{% if form.devicetype.errors %} has-error{% endif %}">
|
||||
<label class="col-md-3 control-label">{% trans "Device type" %}</label>
|
||||
<div class="col-md-9">
|
||||
<div class="big-radio radio">
|
||||
<label>
|
||||
<input type="radio" value="totp" name="{{ form.devicetype.html_name }}" {% if form.devicetype.value == "totp" %}checked{% endif %}>
|
||||
<strong>{% trans "Smartphone with the Authenticator application" %}</strong><br>
|
||||
<div class="help-block">
|
||||
{% blocktrans trimmed %}
|
||||
Use your smartphone with any Time-based One-Time-Password app like freeOTP, Google Authenticator or Proton Authenticator.
|
||||
{% endblocktrans %}
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
<div class="big-radio radio">
|
||||
<label>
|
||||
<input type="radio" value="webauthn" name="{{ form.devicetype.html_name }}" {% if form.devicetype.value == "webauthn" %}checked{% endif %}>
|
||||
<strong>{% trans "WebAuthn-compatible hardware token" %}</strong><br>
|
||||
<div class="help-block">
|
||||
{% blocktrans trimmed %}
|
||||
Use a hardware token like the Yubikey, or biometric authentication on iOS, macOS and Android.
|
||||
{% endblocktrans %}
|
||||
</div>
|
||||
</label>
|
||||
<div>
|
||||
<div class="big-radio radio">
|
||||
<label>
|
||||
<input type="radio" required value="totp" name="{{ form.devicetype.html_name }}" {% if form.devicetype.value == "totp" %}checked{% endif %}>
|
||||
<strong>{% trans "Smartphone with Authenticator app" %}</strong><br>
|
||||
<div class="help-block">
|
||||
{% blocktrans trimmed %}
|
||||
Use your smartphone with any Time-based One-Time-Password app like freeOTP, Google Authenticator or Proton Authenticator.
|
||||
{% endblocktrans %}
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
<div class="big-radio radio">
|
||||
<label>
|
||||
<input type="radio" required value="webauthn" name="{{ form.devicetype.html_name }}" {% if form.devicetype.value == "webauthn" %}checked{% endif %}>
|
||||
<strong>{% trans "WebAuthn-compatible hardware token" %}</strong><br>
|
||||
<div class="help-block">
|
||||
{% blocktrans trimmed %}
|
||||
Use a hardware token like the Yubikey, or other biometric authentication like fingerprint or face recognition.
|
||||
{% endblocktrans %}
|
||||
</div>
|
||||
</label>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
{% if form.devicetype.errors %}
|
||||
<div class="help-block">
|
||||
{% for error in form.devicetype.errors %}
|
||||
<p>{{ error|escape }}</p>
|
||||
{% endfor %}
|
||||
</div>
|
||||
{% endif %}
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
@@ -69,11 +69,14 @@
|
||||
{% trans "Enter the displayed code here:" %}
|
||||
<form class="form form-inline" method="post" action="">
|
||||
{% csrf_token %}
|
||||
<input type="hidden" name="flow_token" value="{{ flow_token }}">
|
||||
<input type="number" name="token" class="form-control" required="required">
|
||||
<button class="btn btn-primary" type="submit">
|
||||
{% trans "Continue" %}
|
||||
</button><br>
|
||||
<label>
|
||||
<input type="checkbox" name="activate" checked="checked" value="on">
|
||||
{% trans "Require second factor for future logins" %}
|
||||
</label>
|
||||
</form>
|
||||
</li>
|
||||
</ol>
|
||||
|
||||
@@ -12,9 +12,13 @@
|
||||
</p>
|
||||
<form class="form form-inline" method="post" action="" id="webauthn-form">
|
||||
{% csrf_token %}
|
||||
<input type="hidden" name="flow_token" value="{{ flow_token }}">
|
||||
<input type="hidden" id="webauthn-response" name="token" class="form-control" required="required">
|
||||
|
||||
<p>
|
||||
<label>
|
||||
<input type="checkbox" name="activate" checked="checked" value="on">
|
||||
{% trans "Require second factor for future logins" %}
|
||||
</label>
|
||||
</p>
|
||||
<button class="btn btn-primary sr-only" type="submit"></button>
|
||||
</form>
|
||||
|
||||
|
||||
@@ -6,7 +6,6 @@
|
||||
<h1>{% trans "Delete a two-factor authentication device" %}</h1>
|
||||
<form action="" method="post" class="form-horizontal">
|
||||
{% csrf_token %}
|
||||
<input type="hidden" name="flow_token" value="{{ flow_token }}">
|
||||
<p>{% blocktrans trimmed with device=device.name %}
|
||||
Are you sure you want to delete the authentication device "{{ device }}"?
|
||||
{% endblocktrans %}</p>
|
||||
|
||||
@@ -6,7 +6,6 @@
|
||||
<h1>{% trans "Disable two-factor authentication" %}</h1>
|
||||
<form action="" method="post" class="form-horizontal">
|
||||
{% csrf_token %}
|
||||
<input type="hidden" name="flow_token" value="{{ flow_token }}">
|
||||
<p>
|
||||
{% trans "Do you really want to disable two-factor authentication?" %}
|
||||
</p>
|
||||
|
||||
@@ -1,58 +1,23 @@
|
||||
{% extends "pretixcontrol/base.html" %}
|
||||
{% load i18n %}
|
||||
{% load bootstrap3 %}
|
||||
{% load icon %}
|
||||
{% block title %}{% trans "Enable two-factor authentication" %}{% endblock %}
|
||||
{% block content %}
|
||||
<h1>{% trans "Enable two-factor authentication" %}</h1>
|
||||
<form action="" method="post" class="form-horizontal">
|
||||
{% csrf_token %}
|
||||
<input type="hidden" name="flow_token" value="{{ flow_token }}">
|
||||
<p>
|
||||
{% trans "Do you really want to enable two-factor authentication?" %}
|
||||
</p>
|
||||
<p>
|
||||
{% trans "You will no longer be able to log in to pretix without one of your configured devices." %}
|
||||
{% trans "Please make sure to print out or copy the emergency tokens and store them in a safe place." %}
|
||||
</p>
|
||||
{% if new_emergency_tokens %}
|
||||
<div class="panel panel-default">
|
||||
<div class="panel-heading">
|
||||
<h3 class="panel-title">{% trans "Your emergency codes" %}</h3>
|
||||
</div>
|
||||
<div class="panel-body">
|
||||
<p>
|
||||
{% blocktrans trimmed %}
|
||||
If you lose access to your devices, you can use one of your emergency tokens to log in.
|
||||
We recommend to store them in a safe place, e.g. printed out or in a password manager.
|
||||
Every token can be used at most once.
|
||||
{% endblocktrans %}
|
||||
</p>
|
||||
<ul>
|
||||
{% for code in new_emergency_tokens %}
|
||||
<li>{{ code }}</li>
|
||||
{% endfor %}
|
||||
</ul>
|
||||
<p>
|
||||
<label>
|
||||
<input type="checkbox" required>
|
||||
{% trans "I stored my emergency tokens in a safe place." %}
|
||||
</label>
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
{% else %}
|
||||
<p>
|
||||
{% icon "info-circle" %}
|
||||
{% blocktrans trimmed with generation_date_time=static_tokens_device.created_at %}
|
||||
You generated your emergency tokens on {{ generation_date_time }}.
|
||||
{% endblocktrans %}
|
||||
</p>
|
||||
{% endif %}
|
||||
<div class="form-group submit-group">
|
||||
<a href="{% url "control:user.settings.2fa" %}" class="btn btn-default btn-cancel">
|
||||
{% trans "Cancel" %}
|
||||
</a>
|
||||
<button type="submit" class="btn btn-primary btn-save">
|
||||
<button type="submit" class="btn btn-danger btn-save">
|
||||
{% trans "Enable" %}
|
||||
</button>
|
||||
</div>
|
||||
|
||||
@@ -6,7 +6,6 @@
|
||||
<h1>{% trans "Leave teams that require two-factor authentication" %}</h1>
|
||||
<form action="" method="post" class="form-horizontal">
|
||||
{% csrf_token %}
|
||||
<input type="hidden" name="flow_token" value="{{ flow_token }}">
|
||||
<p>
|
||||
<strong>{% trans "Do you really want to leave the following teams?" %}</strong>
|
||||
</p>
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
{% extends "pretixcontrol/base.html" %}
|
||||
{% load i18n %}
|
||||
{% load icon %}
|
||||
{% load bootstrap3 %}
|
||||
{% block title %}{% trans "Two-factor authentication" %}{% endblock %}
|
||||
{% block content %}
|
||||
@@ -121,7 +120,7 @@
|
||||
Delete
|
||||
</a>
|
||||
{% if d.devicetype == "totp" %}
|
||||
<span class="fa fa-mobile fa-lg"></span>
|
||||
<span class="fa fa-mobile"></span>
|
||||
{% elif d.devicetype == "webauthn" %}
|
||||
<span class="fa fa-usb"></span>
|
||||
{% elif d.devicetype == "u2f" %}
|
||||
@@ -153,30 +152,19 @@
|
||||
</p>
|
||||
{% if static_tokens_device %}
|
||||
<p>
|
||||
{% icon "info-circle" %}
|
||||
{% blocktrans trimmed with generation_date_time=static_tokens_device.created_at %}
|
||||
You generated your emergency tokens on {{ generation_date_time }}.
|
||||
{% endblocktrans %}
|
||||
</p>
|
||||
<a href="{% url "control:user.settings.2fa.regenemergency" %}" class="btn btn-default">
|
||||
<span class="fa fa-refresh"></span>
|
||||
{% trans "Generate new emergency tokens" %}
|
||||
</a>
|
||||
{% elif user.require_2fa %}
|
||||
<p>
|
||||
{% icon "warning" %}
|
||||
<strong>{% trans "You don't have any emergency tokens yet." %}</strong>
|
||||
</p>
|
||||
<a href="{% url "control:user.settings.2fa.regenemergency" %}" class="btn btn-default">
|
||||
<span class="fa fa-refresh"></span>
|
||||
{% trans "Generate emergency tokens" %}
|
||||
</a>
|
||||
{% else %}
|
||||
<p class="help-block">
|
||||
{% icon "info-circle" %}
|
||||
{% trans "Emergency tokens will be generated when you enable two-factor authentication." %}
|
||||
<p>
|
||||
{% trans "You don't have any emergency tokens yet." %}
|
||||
</p>
|
||||
{% endif %}
|
||||
<a href="{% url "control:user.settings.2fa.regenemergency" %}" class="btn btn-default">
|
||||
<span class="fa fa-refresh"></span>
|
||||
{% trans "Generate new emergency tokens" %}
|
||||
</a>
|
||||
</div>
|
||||
</div>
|
||||
{% endblock %}
|
||||
|
||||
@@ -6,7 +6,6 @@
|
||||
<h1>{% trans "Regenerate emergency codes" %}</h1>
|
||||
<form action="" method="post" class="form-horizontal">
|
||||
{% csrf_token %}
|
||||
<input type="hidden" name="flow_token" value="{{ flow_token }}">
|
||||
<p>
|
||||
{% trans "Do you really want to regenerate your emergency codes?" %}
|
||||
</p>
|
||||
|
||||
@@ -8,7 +8,6 @@
|
||||
{% trans "Change login email address" %}
|
||||
</h1>
|
||||
{% csrf_token %}
|
||||
<input type="hidden" name="flow_token" value="{{ flow_token }}">
|
||||
{% bootstrap_form_errors form %}
|
||||
<p class="text-muted">
|
||||
{% trans "This changes the email address used to login to your account, as well as where we send email notifications." %}
|
||||
|
||||
@@ -9,7 +9,6 @@
|
||||
</h1>
|
||||
<br>
|
||||
{% csrf_token %}
|
||||
<input type="hidden" name="flow_token" value="{{ flow_token }}">
|
||||
{% bootstrap_form_errors form %}
|
||||
{% bootstrap_field form.email %}
|
||||
{% bootstrap_field form.old_pw %}
|
||||
|
||||
@@ -641,7 +641,7 @@ def user_index(request):
|
||||
|
||||
ctx = {
|
||||
'widgets': rearrange(widgets),
|
||||
'can_create_event': request.user.teams.with_organizer_permission("organizer.events:create").exists(),
|
||||
'can_create_event': request.user.teams.with_organizer_permission("organizer.events:create").exists() or request.user.is_staff,
|
||||
'upcoming': widgets_for_event_qs(
|
||||
request,
|
||||
annotated_event_query(request, lazy=True).filter(
|
||||
|
||||
@@ -89,31 +89,13 @@ logger = logging.getLogger(__name__)
|
||||
|
||||
class RecentAuthenticationRequiredMixin:
|
||||
max_time = 900
|
||||
max_form_time = 900
|
||||
|
||||
@method_decorator(never_cache)
|
||||
def dispatch(self, request, *args, **kwargs):
|
||||
auth_is_recent = time.time() - request.session.get('pretix_auth_login_time', 0) < self.max_time
|
||||
allowed_by_token = (
|
||||
request.session.pop('pretix_reauthed_flow_token', None) == request.POST.get('flow_token', '')
|
||||
and request.session.pop('pretix_reauthed_flow_allowed_url', None) == request.get_full_path()
|
||||
and time.time() - request.session.pop('pretix_reauthed_flow_start_time', 0) < self.max_form_time
|
||||
)
|
||||
if auth_is_recent or allowed_by_token:
|
||||
return super().dispatch(request, *args, **kwargs)
|
||||
else:
|
||||
tdelta = time.time() - request.session.get('pretix_auth_login_time', 0)
|
||||
if tdelta > self.max_time:
|
||||
return redirect(reverse('control:user.reauth') + '?next=' + quote(request.get_full_path()))
|
||||
|
||||
def get_flow_token(self):
|
||||
self.request.session['pretix_reauthed_flow_allowed_url'] = self.request.get_full_path()
|
||||
self.request.session['pretix_reauthed_flow_token'] = get_random_string(22)
|
||||
self.request.session['pretix_reauthed_flow_start_time'] = time.time()
|
||||
return self.request.session['pretix_reauthed_flow_token']
|
||||
|
||||
def get_context_data(self, **kwargs):
|
||||
ctx = super().get_context_data()
|
||||
ctx['flow_token'] = self.get_flow_token()
|
||||
return ctx
|
||||
return super().dispatch(request, *args, **kwargs)
|
||||
|
||||
|
||||
class ReauthView(TemplateView):
|
||||
@@ -301,7 +283,6 @@ class UserHistoryView(ListView):
|
||||
|
||||
|
||||
class User2FAMainView(RecentAuthenticationRequiredMixin, TemplateView):
|
||||
max_time = 7200
|
||||
template_name = 'pretixcontrol/user/2fa_main.html'
|
||||
|
||||
def get_context_data(self, **kwargs):
|
||||
@@ -484,15 +465,25 @@ class User2FADeviceConfirmWebAuthnView(RecentAuthenticationRequiredMixin, Templa
|
||||
notices = [
|
||||
_('A new two-factor authentication device has been added to your account.')
|
||||
]
|
||||
activate = request.POST.get('activate', '')
|
||||
if activate == 'on' and not self.request.user.require_2fa:
|
||||
self.request.user.require_2fa = True
|
||||
self.request.user.save()
|
||||
self.request.user.log_action('pretix.user.settings.2fa.enabled', user=self.request.user)
|
||||
notices.append(
|
||||
_('Two-factor authentication has been enabled.')
|
||||
)
|
||||
self.request.user.send_security_notice(notices)
|
||||
self.request.user.update_session_token()
|
||||
update_session_auth_hash(self.request, self.request.user)
|
||||
|
||||
messages.success(request, str(_('The device has been verified and can now be used.')))
|
||||
if self.request.user.require_2fa:
|
||||
return redirect(reverse('control:user.settings.2fa'))
|
||||
else:
|
||||
return redirect(reverse('control:user.settings.2fa.enable'))
|
||||
note = ''
|
||||
if not self.request.user.require_2fa:
|
||||
note = ' ' + str(_('Please note that you still need to enable two-factor authentication for your '
|
||||
'account using the buttons below to make a second factor required for logging '
|
||||
'into your account.'))
|
||||
messages.success(request, str(_('The device has been verified and can now be used.')) + note)
|
||||
return redirect(reverse('control:user.settings.2fa'))
|
||||
except Exception:
|
||||
messages.error(request, _('The registration could not be completed. Please try again.'))
|
||||
logger.exception('WebAuthn registration failed')
|
||||
@@ -503,7 +494,6 @@ class User2FADeviceConfirmWebAuthnView(RecentAuthenticationRequiredMixin, Templa
|
||||
|
||||
class User2FADeviceConfirmTOTPView(RecentAuthenticationRequiredMixin, TemplateView):
|
||||
template_name = 'pretixcontrol/user/2fa_confirm_totp.html'
|
||||
max_form_time = 7200 # this should have effectively no timeout, as the user might need to download the 2fa app first
|
||||
|
||||
@cached_property
|
||||
def device(self):
|
||||
@@ -524,6 +514,7 @@ class User2FADeviceConfirmTOTPView(RecentAuthenticationRequiredMixin, TemplateVi
|
||||
|
||||
def post(self, request, *args, **kwargs):
|
||||
token = request.POST.get('token', '')
|
||||
activate = request.POST.get('activate', '')
|
||||
if self.device.verify_token(token):
|
||||
self.device.confirmed = True
|
||||
self.device.save()
|
||||
@@ -535,15 +526,24 @@ class User2FADeviceConfirmTOTPView(RecentAuthenticationRequiredMixin, TemplateVi
|
||||
notices = [
|
||||
_('A new two-factor authentication device has been added to your account.')
|
||||
]
|
||||
if activate == 'on' and not self.request.user.require_2fa:
|
||||
self.request.user.require_2fa = True
|
||||
self.request.user.save()
|
||||
self.request.user.log_action('pretix.user.settings.2fa.enabled', user=self.request.user)
|
||||
notices.append(
|
||||
_('Two-factor authentication has been enabled.')
|
||||
)
|
||||
self.request.user.send_security_notice(notices)
|
||||
self.request.user.update_session_token()
|
||||
update_session_auth_hash(self.request, self.request.user)
|
||||
|
||||
messages.success(request, str(_('The device has been verified and can now be used.')))
|
||||
if self.request.user.require_2fa:
|
||||
return redirect(reverse('control:user.settings.2fa'))
|
||||
else:
|
||||
return redirect(reverse('control:user.settings.2fa.enable'))
|
||||
note = ''
|
||||
if not self.request.user.require_2fa:
|
||||
note = ' ' + str(_('Please note that you still need to enable two-factor authentication for your '
|
||||
'account using the buttons below to make a second factor required for logging '
|
||||
'into your account.'))
|
||||
messages.success(request, str(_('The device has been verified and can now be used.')) + note)
|
||||
return redirect(reverse('control:user.settings.2fa'))
|
||||
else:
|
||||
messages.error(request, _('The code you entered was not valid. If this problem persists, please check '
|
||||
'that the date and time of your phone are configured correctly.'))
|
||||
@@ -576,7 +576,6 @@ class User2FALeaveTeamsView(RecentAuthenticationRequiredMixin, TemplateView):
|
||||
|
||||
class User2FAEnableView(RecentAuthenticationRequiredMixin, TemplateView):
|
||||
template_name = 'pretixcontrol/user/2fa_enable.html'
|
||||
max_form_time = 7200 # this should have effectively no timeout, as the user might take some time to print out their emergency codes, and they would become invalid in case of a timeout
|
||||
|
||||
def dispatch(self, request, *args, **kwargs):
|
||||
if not any(dt.objects.filter(user=self.request.user, confirmed=True) for dt in REAL_DEVICE_TYPES):
|
||||
@@ -585,39 +584,14 @@ class User2FAEnableView(RecentAuthenticationRequiredMixin, TemplateView):
|
||||
return redirect(reverse('control:user.settings.2fa'))
|
||||
return super().dispatch(request, *args, **kwargs)
|
||||
|
||||
def get(self, request, *args, **kwargs):
|
||||
new_tokens = None
|
||||
try:
|
||||
static_tokens_device = StaticDevice.objects.get(user=self.request.user, name='emergency')
|
||||
except StaticDevice.MultipleObjectsReturned:
|
||||
static_tokens_device = StaticDevice.objects.filter(
|
||||
user=self.request.user, name='emergency'
|
||||
).first()
|
||||
except StaticDevice.DoesNotExist:
|
||||
static_tokens_device = None
|
||||
|
||||
new_tokens = [get_random_string(length=12, allowed_chars='1234567890') for _ in range(10)]
|
||||
request.session['pretix_2fa_new_emergency_tokens'] = new_tokens
|
||||
return super().get(request, *args, new_emergency_tokens=new_tokens, static_tokens_device=static_tokens_device, **kwargs)
|
||||
|
||||
def post(self, request, *args, **kwargs):
|
||||
notices = [
|
||||
_('Two-factor authentication has been enabled.')
|
||||
]
|
||||
if 'pretix_2fa_new_emergency_tokens' in request.session:
|
||||
d = StaticDevice.objects.create(user=self.request.user, name='emergency')
|
||||
for code in request.session['pretix_2fa_new_emergency_tokens']:
|
||||
d.token_set.create(token=code)
|
||||
self.request.user.log_action('pretix.user.settings.2fa.regenemergency', user=self.request.user)
|
||||
notices += [
|
||||
_('Your two-factor emergency codes have been regenerated.')
|
||||
]
|
||||
del request.session['pretix_2fa_new_emergency_tokens']
|
||||
self.request.user.require_2fa = True
|
||||
self.request.user.save()
|
||||
self.request.user.log_action('pretix.user.settings.2fa.enabled', user=self.request.user)
|
||||
messages.success(request, _('Two-factor authentication is now enabled for your account.'))
|
||||
self.request.user.send_security_notice(notices)
|
||||
self.request.user.send_security_notice([
|
||||
_('Two-factor authentication has been enabled.')
|
||||
])
|
||||
self.request.user.update_session_token()
|
||||
update_session_auth_hash(self.request, self.request.user)
|
||||
return redirect(reverse('control:user.settings.2fa'))
|
||||
|
||||
@@ -25,7 +25,7 @@ import time
|
||||
|
||||
from django.conf import settings
|
||||
from django.contrib.auth import login as auth_login
|
||||
from django.contrib.gis.geoip2 import GeoIP2
|
||||
from django.contrib.gis import geoip2
|
||||
from django.core.cache import cache
|
||||
from django.utils.timezone import now
|
||||
from django.utils.translation import gettext_lazy as _
|
||||
@@ -63,14 +63,20 @@ def get_user_agent_hash(request):
|
||||
_geoip = None
|
||||
|
||||
|
||||
def _get_country(request):
|
||||
def get_geoip() -> geoip2.GeoIP2:
|
||||
# See https://code.djangoproject.com/ticket/36988#ticket
|
||||
global _geoip
|
||||
|
||||
if not _geoip:
|
||||
_geoip = GeoIP2()
|
||||
geoip2.SUPPORTED_DATABASE_TYPES.add("Geoacumen-Country")
|
||||
|
||||
if not _geoip:
|
||||
_geoip = geoip2.GeoIP2()
|
||||
return _geoip
|
||||
|
||||
|
||||
def _get_country(request):
|
||||
try:
|
||||
res = _geoip.country(get_client_ip(request))
|
||||
res = get_geoip().country(get_client_ip(request))
|
||||
except AddressNotFoundError:
|
||||
return None
|
||||
return res['country_code']
|
||||
|
||||
@@ -8,8 +8,8 @@ msgstr ""
|
||||
"Project-Id-Version: PACKAGE VERSION\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2026-03-17 14:05+0000\n"
|
||||
"PO-Revision-Date: 2026-02-10 16:49+0000\n"
|
||||
"Last-Translator: Michele Pagnozzi <michele.pagnozzi@gmail.com>\n"
|
||||
"PO-Revision-Date: 2026-03-27 09:03+0000\n"
|
||||
"Last-Translator: Ivano Voghera <ivano.voghera@gmail.com>\n"
|
||||
"Language-Team: Italian <https://translate.pretix.eu/projects/pretix/pretix/"
|
||||
"it/>\n"
|
||||
"Language: it\n"
|
||||
@@ -17,7 +17,7 @@ msgstr ""
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
"Content-Transfer-Encoding: 8bit\n"
|
||||
"Plural-Forms: nplurals=2; plural=n != 1;\n"
|
||||
"X-Generator: Weblate 5.15.2\n"
|
||||
"X-Generator: Weblate 5.16.2\n"
|
||||
|
||||
#: pretix/_base_settings.py:87
|
||||
msgid "English"
|
||||
@@ -412,9 +412,8 @@ msgstr ""
|
||||
|
||||
#: pretix/api/serializers/organizer.py:482
|
||||
#: pretix/control/views/organizer.py:1039
|
||||
#, fuzzy
|
||||
msgid "Account invitation"
|
||||
msgstr "Informazioni account modificate"
|
||||
msgstr "Invito account"
|
||||
|
||||
#: pretix/api/serializers/organizer.py:503
|
||||
#: pretix/control/views/organizer.py:1138
|
||||
@@ -656,22 +655,16 @@ msgid "Customer account anonymized"
|
||||
msgstr "Account del cliente anonimizzato"
|
||||
|
||||
#: pretix/api/webhooks.py:470
|
||||
#, fuzzy
|
||||
#| msgid "Gift card code"
|
||||
msgid "Gift card added"
|
||||
msgstr "Codice carta regalo"
|
||||
msgstr "Carta regalo aggiunta"
|
||||
|
||||
#: pretix/api/webhooks.py:474
|
||||
#, fuzzy
|
||||
#| msgid "Gift card code"
|
||||
msgid "Gift card modified"
|
||||
msgstr "Codice carta regalo"
|
||||
msgstr "Carta regalo modificata"
|
||||
|
||||
#: pretix/api/webhooks.py:478
|
||||
#, fuzzy
|
||||
#| msgid "Gift card transactions"
|
||||
msgid "Gift card used in transaction"
|
||||
msgstr "Transazioni con carta regalo"
|
||||
msgstr "Carta regalo usata nella transazione"
|
||||
|
||||
#: pretix/base/addressvalidation.py:100 pretix/base/addressvalidation.py:103
|
||||
#: pretix/base/addressvalidation.py:108 pretix/base/forms/questions.py:1054
|
||||
@@ -1237,7 +1230,7 @@ msgstr "Caricamento dei file di risposta alle domande"
|
||||
#: pretix/plugins/reports/exporters.py:666
|
||||
msgctxt "export_category"
|
||||
msgid "Order data"
|
||||
msgstr "Dati dell'ordine"
|
||||
msgstr "Data dell'ordine"
|
||||
|
||||
#: pretix/base/exporters/answers.py:56
|
||||
msgid ""
|
||||
@@ -2324,6 +2317,10 @@ msgid ""
|
||||
"contain at least one position of this product. The order totals etc. still "
|
||||
"include all products contained in the order."
|
||||
msgstr ""
|
||||
"Se non ne viene selezionato nessuno, saranno inclusi tutti i prodotti. Gli "
|
||||
"ordini vengono inclusi se contengono almeno un articolo di questo prodotto. "
|
||||
"I totali dell'ordine ecc. includeranno comunque tutti i prodotti contenuti "
|
||||
"nell'ordine."
|
||||
|
||||
#: pretix/base/exporters/orderlist.py:283
|
||||
#: pretix/base/exporters/orderlist.py:479
|
||||
@@ -2590,16 +2587,12 @@ msgid "Voucher"
|
||||
msgstr "Voucher"
|
||||
|
||||
#: pretix/base/exporters/orderlist.py:655
|
||||
#, fuzzy
|
||||
#| msgid "Voucher deleted"
|
||||
msgid "Voucher budget usage"
|
||||
msgstr "Buono eliminato"
|
||||
msgstr "Utilizzo budget del buono"
|
||||
|
||||
#: pretix/base/exporters/orderlist.py:656
|
||||
#, fuzzy
|
||||
#| msgid "Voucher"
|
||||
msgid "Voucher tag"
|
||||
msgstr "Voucher"
|
||||
msgstr "Voucher tag"
|
||||
|
||||
#: pretix/base/exporters/orderlist.py:657
|
||||
msgid "Pseudonymization ID"
|
||||
@@ -3418,39 +3411,34 @@ msgid "Street and Number"
|
||||
msgstr "Indirizzo e numero civico"
|
||||
|
||||
#: pretix/base/forms/questions.py:893
|
||||
#, fuzzy, python-brace-format
|
||||
#| msgid "Please enter a shorter name."
|
||||
#, python-brace-format
|
||||
msgid "Please enter a date between {min} and {max}."
|
||||
msgstr "Per favore inserisci un nome più breve."
|
||||
msgstr "Per favore inserisci una data inclusa tra {min} e {max}."
|
||||
|
||||
#: pretix/base/forms/questions.py:899
|
||||
#, fuzzy, python-brace-format
|
||||
#| msgid "Please enter a valid sales channel."
|
||||
#, python-brace-format
|
||||
msgid "Please enter a date no earlier than {min}."
|
||||
msgstr "Inserire un canale di vendita valido."
|
||||
msgstr "Per favore inserisci una data successiva a {min}."
|
||||
|
||||
#: pretix/base/forms/questions.py:904
|
||||
#, fuzzy, python-brace-format
|
||||
#| msgid "Please enter a shorter name."
|
||||
#, python-brace-format
|
||||
msgid "Please enter a date no later than {max}."
|
||||
msgstr "Per favore inserisci un nome più breve."
|
||||
msgstr "Per favore inserisci una data precedente a {max}."
|
||||
|
||||
#: pretix/base/forms/questions.py:942
|
||||
#, python-brace-format
|
||||
msgid "Please enter a date and time between {min} and {max}."
|
||||
msgstr ""
|
||||
msgstr "Per favore inserisci data e orario compresi tra {min} e {max}."
|
||||
|
||||
#: pretix/base/forms/questions.py:948
|
||||
#, fuzzy, python-brace-format
|
||||
#| msgid "Please enter a valid sales channel."
|
||||
#, python-brace-format
|
||||
msgid "Please enter a date and time no earlier than {min}."
|
||||
msgstr "Inserire un canale di vendita valido."
|
||||
msgstr "Per favore inserisci data e orario successivi a {min}."
|
||||
|
||||
#: pretix/base/forms/questions.py:953
|
||||
#, fuzzy, python-brace-format
|
||||
#| msgid "Please enter the correct result."
|
||||
#, python-brace-format
|
||||
msgid "Please enter a date and time no later than {max}."
|
||||
msgstr "Per favore inserisci il risultato corretto."
|
||||
msgstr "Per favore inserisci data e orario precedenti a {max}."
|
||||
|
||||
#: pretix/base/forms/questions.py:1172
|
||||
msgid ""
|
||||
@@ -3957,7 +3945,7 @@ msgstr ""
|
||||
|
||||
#: pretix/base/invoicing/peppol.py:166
|
||||
msgid "The Peppol participant ID is not registered on the Peppol network."
|
||||
msgstr ""
|
||||
msgstr "L'ID partecipante Peppol non è registrato nella rete Peppol."
|
||||
|
||||
#: pretix/base/invoicing/peppol.py:192
|
||||
msgid "Peppol participant ID"
|
||||
@@ -3965,7 +3953,7 @@ msgstr "ID partecipante Peppol"
|
||||
|
||||
#: pretix/base/invoicing/peppol.py:211
|
||||
msgid "The Peppol participant ID does not match your VAT ID."
|
||||
msgstr ""
|
||||
msgstr "L'ID partecipante Peppol non corrisponde alla tua Partita IVA."
|
||||
|
||||
#: pretix/base/invoicing/peppol.py:214
|
||||
msgctxt "peppol_invoice"
|
||||
@@ -4336,7 +4324,7 @@ msgstr "Permetti di superare la quota"
|
||||
#: pretix/control/templates/pretixcontrol/vouchers/detail.html:70
|
||||
#: pretix/control/views/vouchers.py:121
|
||||
msgid "Price effect"
|
||||
msgstr ""
|
||||
msgstr "Variazione di prezzo"
|
||||
|
||||
#: pretix/base/modelimport_vouchers.py:150
|
||||
#, fuzzy, python-brace-format
|
||||
@@ -5339,7 +5327,6 @@ msgstr "trasmesso"
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mail.html:44
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mails.html:145
|
||||
#: pretix/plugins/sendmail/models.py:51
|
||||
#, fuzzy
|
||||
msgid "failed"
|
||||
msgstr "fallito"
|
||||
|
||||
@@ -5401,7 +5388,7 @@ msgstr "Categoria normale"
|
||||
|
||||
#: pretix/base/models/items.py:115 pretix/control/forms/item.py:111
|
||||
msgid "Normal + cross-selling category"
|
||||
msgstr "Categoria normale + cross-selling"
|
||||
msgstr "Normale + Categoria cross-selling"
|
||||
|
||||
#: pretix/base/models/items.py:116 pretix/control/forms/item.py:106
|
||||
msgid "Cross-selling category"
|
||||
@@ -6449,13 +6436,13 @@ msgstr "Fine"
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mail.html:38
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mails.html:139
|
||||
msgid "queued"
|
||||
msgstr ""
|
||||
msgstr "in coda"
|
||||
|
||||
#: pretix/base/models/mail.py:53
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mail.html:40
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mails.html:141
|
||||
msgid "being sent"
|
||||
msgstr ""
|
||||
msgstr "invio in corso"
|
||||
|
||||
#: pretix/base/models/mail.py:54
|
||||
#, fuzzy
|
||||
@@ -6467,25 +6454,25 @@ msgstr "Voce in lista d'attesa"
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mail.html:48
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mails.html:149
|
||||
msgid "withheld"
|
||||
msgstr ""
|
||||
msgstr "trattenuto"
|
||||
|
||||
#: pretix/base/models/mail.py:57
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mail.html:50
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mails.html:151
|
||||
msgid "aborted"
|
||||
msgstr ""
|
||||
msgstr "annullato"
|
||||
|
||||
#: pretix/base/models/mail.py:58
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mail.html:52
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mails.html:153
|
||||
msgid "sent"
|
||||
msgstr ""
|
||||
msgstr "inviato"
|
||||
|
||||
#: pretix/base/models/mail.py:59
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mail.html:46
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mails.html:147
|
||||
msgid "bounced"
|
||||
msgstr ""
|
||||
msgstr "rimbalzato"
|
||||
|
||||
#: pretix/base/models/memberships.py:44
|
||||
#: pretix/presale/templates/pretixpresale/organizers/customer_memberships.html:28
|
||||
@@ -6689,7 +6676,7 @@ msgstr "confermato"
|
||||
#: pretix/base/models/orders.py:1734
|
||||
msgctxt "payment_state"
|
||||
msgid "canceled"
|
||||
msgstr "annullato"
|
||||
msgstr "cancellato"
|
||||
|
||||
#: pretix/base/models/orders.py:1735
|
||||
msgctxt "payment_state"
|
||||
@@ -6920,7 +6907,7 @@ msgstr "Ammissione all'evento"
|
||||
#: pretix/base/models/organizer.py:379
|
||||
#: pretix/control/templates/pretixcontrol/organizers/team_edit.html:34
|
||||
msgid "Event permissions"
|
||||
msgstr ""
|
||||
msgstr "Permessi dell'evento"
|
||||
|
||||
#: pretix/base/models/organizer.py:380
|
||||
#, fuzzy
|
||||
@@ -6930,7 +6917,7 @@ msgstr "Impostazioni account"
|
||||
#: pretix/base/models/organizer.py:381
|
||||
#: pretix/control/templates/pretixcontrol/organizers/team_edit.html:25
|
||||
msgid "Organizer permissions"
|
||||
msgstr ""
|
||||
msgstr "Permessi dell'organizzatore"
|
||||
|
||||
#: pretix/base/models/organizer.py:401
|
||||
#, python-format
|
||||
@@ -8435,7 +8422,7 @@ msgstr "Il tuo file di layout non è un layout valido. Messaggio di errore: {}"
|
||||
#: pretix/base/permissions.py:314 pretix/base/permissions.py:331
|
||||
msgctxt "permission_level"
|
||||
msgid "View"
|
||||
msgstr ""
|
||||
msgstr "Vista"
|
||||
|
||||
#: pretix/base/permissions.py:164 pretix/base/permissions.py:169
|
||||
#: pretix/base/permissions.py:174 pretix/base/permissions.py:179
|
||||
@@ -8447,12 +8434,14 @@ msgstr "Salva modifiche"
|
||||
|
||||
#: pretix/base/permissions.py:168
|
||||
msgid "API only"
|
||||
msgstr ""
|
||||
msgstr "Solo API"
|
||||
|
||||
#: pretix/base/permissions.py:173
|
||||
msgid ""
|
||||
"Menu item will only show up if the user has permission for general settings."
|
||||
msgstr ""
|
||||
"La voce di menu apparirà solo se l'utente ha il permesso per le impostazioni "
|
||||
"generali."
|
||||
|
||||
#: pretix/base/permissions.py:177 pretix/base/permissions.py:231
|
||||
#: pretix/base/permissions.py:285 pretix/base/permissions.py:313
|
||||
@@ -8474,12 +8463,14 @@ msgid ""
|
||||
"This includes access to all settings not listed explicitly below, including "
|
||||
"plugin settings."
|
||||
msgstr ""
|
||||
"Include l'accesso a tutte le impostazioni non elencate esplicitamente di "
|
||||
"seguito, comprese le impostazioni dei plugin."
|
||||
|
||||
#: pretix/base/permissions.py:197
|
||||
#: pretix/control/templates/pretixcontrol/event/payment.html:6
|
||||
#: pretix/control/templates/pretixcontrol/event/payment_provider.html:5
|
||||
msgid "Payment settings"
|
||||
msgstr ""
|
||||
msgstr "Impostazioni di pagamento"
|
||||
|
||||
#: pretix/base/permissions.py:203
|
||||
#: pretix/control/templates/pretixcontrol/event/tax.html:120
|
||||
@@ -8488,10 +8479,8 @@ msgid "Tax settings"
|
||||
msgstr "Impostazioni account"
|
||||
|
||||
#: pretix/base/permissions.py:209
|
||||
#, fuzzy
|
||||
#| msgid "Login settings"
|
||||
msgid "Invoicing settings"
|
||||
msgstr "Impostazioni login"
|
||||
msgstr "Impostazioni Fattura"
|
||||
|
||||
#: pretix/base/permissions.py:215
|
||||
#, fuzzy
|
||||
@@ -8508,7 +8497,7 @@ msgstr "Nome prodotto e variante"
|
||||
|
||||
#: pretix/base/permissions.py:224
|
||||
msgid "Also includes related objects like categories or discounts."
|
||||
msgstr ""
|
||||
msgstr "Include anche gli oggetti correlati come categorie o sconti."
|
||||
|
||||
#: pretix/base/permissions.py:232
|
||||
#, fuzzy
|
||||
@@ -8519,7 +8508,7 @@ msgstr "Filtra per stato"
|
||||
#: pretix/base/permissions.py:233
|
||||
msgctxt "permission_level"
|
||||
msgid "View all"
|
||||
msgstr ""
|
||||
msgstr "Vedi tutto"
|
||||
|
||||
#: pretix/base/permissions.py:234
|
||||
#, fuzzy
|
||||
@@ -8530,15 +8519,15 @@ msgstr "Filtra per stato"
|
||||
#: pretix/base/permissions.py:235
|
||||
msgctxt "permission_level"
|
||||
msgid "View all and change"
|
||||
msgstr ""
|
||||
msgstr "Vedi e modifica tutto"
|
||||
|
||||
#: pretix/base/permissions.py:236
|
||||
msgid "Includes the ability to cancel and refund individual orders."
|
||||
msgstr ""
|
||||
msgstr "Include il permesso di cancellare e rimborsare ordini individuali."
|
||||
|
||||
#: pretix/base/permissions.py:238
|
||||
msgid "Also includes related objects like the waiting list."
|
||||
msgstr ""
|
||||
msgstr "Include anche gli oggetti correlati come la lista d'attesa."
|
||||
|
||||
#: pretix/base/permissions.py:248
|
||||
#, fuzzy
|
||||
@@ -8562,17 +8551,19 @@ msgstr "Tasse"
|
||||
#: pretix/base/permissions.py:268
|
||||
msgctxt "permission_level"
|
||||
msgid "Access existing events"
|
||||
msgstr ""
|
||||
msgstr "Accedere agli eventi esistenti"
|
||||
|
||||
#: pretix/base/permissions.py:269
|
||||
msgctxt "permission_level"
|
||||
msgid "Access existing and create new events"
|
||||
msgstr ""
|
||||
msgstr "Accedere agli eventi esistenti e crearne di nuovi"
|
||||
|
||||
#: pretix/base/permissions.py:271
|
||||
msgid ""
|
||||
"The level of access to events is determined in detail by the settings below."
|
||||
msgstr ""
|
||||
"Il livello di accesso agli eventi è determinato nel dettaglio dalle "
|
||||
"impostazioni sottostanti."
|
||||
|
||||
#: pretix/base/permissions.py:275 pretix/control/navigation.py:143
|
||||
#: pretix/control/navigation.py:462 pretix/control/navigation.py:512
|
||||
@@ -8591,6 +8582,8 @@ msgid ""
|
||||
"This includes access to all organizer-level functionality not listed "
|
||||
"explicitly below, including plugin settings."
|
||||
msgstr ""
|
||||
"Include l'accesso a tutte le funzionalità a livello di organizzatore non "
|
||||
"elencate esplicitamente di seguito, comprese le impostazioni dei plugin."
|
||||
|
||||
#: pretix/base/permissions.py:287
|
||||
msgid ""
|
||||
@@ -8625,7 +8618,7 @@ msgstr "Piano dei posti a sedere"
|
||||
#: pretix/base/permissions.py:327 pretix/control/navigation.py:712
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mails.html:8
|
||||
msgid "Outgoing emails"
|
||||
msgstr ""
|
||||
msgstr "Email in uscita"
|
||||
|
||||
#: pretix/base/plugins.py:138
|
||||
#: pretix/control/templates/pretixcontrol/event/quick_setup.html:132
|
||||
@@ -10097,6 +10090,11 @@ msgid ""
|
||||
"placing an order, the restriction only becomes active after the customer "
|
||||
"account is activated."
|
||||
msgstr ""
|
||||
"Se abilitato, gli utenti che erano autenticati al momento dell'acquisto "
|
||||
"dovranno effettuare l'accesso anche per consultare le informazioni sul "
|
||||
"proprio ordine. Se un account cliente viene creato durante l'effettuazione "
|
||||
"di un ordine, la restrizione diventerà attiva solo dopo l'attivazione "
|
||||
"dell'account stesso."
|
||||
|
||||
#: pretix/base/settings.py:203
|
||||
msgid "Match orders based on email address"
|
||||
@@ -13190,6 +13188,9 @@ msgid ""
|
||||
"logged email contents. This will also remove the association to customer "
|
||||
"accounts."
|
||||
msgstr ""
|
||||
"Questo rimuoverà tutti gli indirizzi email dagli ordini e dai partecipanti, "
|
||||
"così come il contenuto delle email registrate. Rimuoverà inoltre "
|
||||
"l'associazione agli account cliente."
|
||||
|
||||
#: pretix/base/shredder.py:373
|
||||
msgid ""
|
||||
@@ -16579,19 +16580,19 @@ msgstr "Salva modifiche"
|
||||
|
||||
#: pretix/control/forms/rrule.py:35
|
||||
msgid "year(s)"
|
||||
msgstr ""
|
||||
msgstr "anno/i"
|
||||
|
||||
#: pretix/control/forms/rrule.py:36
|
||||
msgid "month(s)"
|
||||
msgstr "mese(i)"
|
||||
msgstr "mese/i"
|
||||
|
||||
#: pretix/control/forms/rrule.py:37
|
||||
msgid "week(s)"
|
||||
msgstr "settimana (e)"
|
||||
msgstr "settimana/e"
|
||||
|
||||
#: pretix/control/forms/rrule.py:38
|
||||
msgid "day(s)"
|
||||
msgstr ""
|
||||
msgstr "giorno/i"
|
||||
|
||||
#: pretix/control/forms/rrule.py:43
|
||||
msgid "Interval"
|
||||
@@ -16628,7 +16629,7 @@ msgstr ""
|
||||
#: pretix/control/forms/rrule.py:111 pretix/control/forms/rrule.py:150
|
||||
#: pretix/presale/templates/pretixpresale/fragment_calendar_nav.html:20
|
||||
msgid "Day"
|
||||
msgstr ""
|
||||
msgstr "Giorno"
|
||||
|
||||
#: pretix/control/forms/rrule.py:113 pretix/control/forms/rrule.py:152
|
||||
msgid "Weekend day"
|
||||
@@ -17230,9 +17231,8 @@ msgid ""
|
||||
msgstr ""
|
||||
|
||||
#: pretix/control/logdisplay.py:529
|
||||
#, fuzzy
|
||||
msgid "The customer account has been changed."
|
||||
msgstr "La data dell'evento è stata modificata."
|
||||
msgstr "L'account cliente è stato modificato."
|
||||
|
||||
#: pretix/control/logdisplay.py:530
|
||||
msgid "The order locale has been changed."
|
||||
@@ -18914,7 +18914,7 @@ msgstr ""
|
||||
#: pretix/presale/templates/pretixpresale/postmessage.html:27
|
||||
#: pretix/presale/templates/pretixpresale/waiting.html:42
|
||||
msgid "If this takes longer than a few minutes, please contact us."
|
||||
msgstr ""
|
||||
msgstr "Se questa operazione richiede alcuni minuti, si prega di contattarci."
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/boxoffice/payment.html:4
|
||||
#: pretix/control/templates/pretixcontrol/organizers/devices.html:75
|
||||
@@ -20687,8 +20687,6 @@ msgid "Payment reminder"
|
||||
msgstr ""
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/event/mail.html:108
|
||||
#, fuzzy
|
||||
#| msgid "Payment confirmed"
|
||||
msgid "Payment failed"
|
||||
msgstr "Pagamento rifiutato"
|
||||
|
||||
@@ -20739,7 +20737,7 @@ msgstr ""
|
||||
#: pretix/control/templates/pretixcontrol/event/payment.html:78
|
||||
msgctxt "unit"
|
||||
msgid "days"
|
||||
msgstr ""
|
||||
msgstr "giorni"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/event/payment_provider.html:13
|
||||
#: pretix/control/templates/pretixcontrol/events/create_base.html:24
|
||||
@@ -21616,7 +21614,7 @@ msgstr ""
|
||||
#: pretix/control/templates/pretixcontrol/fragment_quota_box_paid.html:3
|
||||
#, python-format
|
||||
msgid "Currently available: %(num)s"
|
||||
msgstr ""
|
||||
msgstr "Attualmente disponibili: %(num)s"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/global_license.html:8
|
||||
msgid ""
|
||||
@@ -21862,6 +21860,8 @@ msgid ""
|
||||
"This product is currently not being sold since you configured below that it "
|
||||
"should only be available in a certain timeframe."
|
||||
msgstr ""
|
||||
"Questo prodotto non è attualmente in vendita, poiché è stato configurato per "
|
||||
"essere disponibile solo in un determinato intervallo di tempo."
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/item/base.html:41
|
||||
msgid ""
|
||||
@@ -22367,6 +22367,8 @@ msgstr "Crea un nuovo organizzatore"
|
||||
msgid ""
|
||||
"Currently unavailable since a limited timeframe for this product has been set"
|
||||
msgstr ""
|
||||
"Attualmente non disponibile poiché è stato impostato un intervallo di tempo "
|
||||
"limitato per questo prodotto"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/items/discounts.html:119
|
||||
msgid "Condition:"
|
||||
@@ -22863,12 +22865,13 @@ msgstr ""
|
||||
#: pretix/presale/templates/pretixpresale/event/order.html:483
|
||||
#: pretix/presale/templates/pretixpresale/event/order_cancel.html:7
|
||||
msgid "Cancel order"
|
||||
msgstr ""
|
||||
msgstr "Elimina ordine"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/order/cancel.html:12
|
||||
#: pretix/control/templates/pretixcontrol/order/deny.html:11
|
||||
msgid "Do you really want to cancel this order? You cannot revert this action."
|
||||
msgstr ""
|
||||
"Vuoi davvero eliminare questo ordine? Questa azione non può essere annullata."
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/order/cancel.html:16
|
||||
msgid ""
|
||||
@@ -22887,12 +22890,12 @@ msgstr ""
|
||||
#: pretix/control/templates/pretixcontrol/order/cancel.html:51
|
||||
#: pretix/presale/templates/pretixpresale/event/order_cancel.html:220
|
||||
msgid "Yes, cancel order"
|
||||
msgstr ""
|
||||
msgstr "Si, elimina ordine"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/order/cancellation_request_delete.html:4
|
||||
#: pretix/control/templates/pretixcontrol/order/cancellation_request_delete.html:8
|
||||
msgid "Ignore cancellation request"
|
||||
msgstr ""
|
||||
msgstr "Ignora la richiesta di cancellazione"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/order/cancellation_request_delete.html:10
|
||||
msgid ""
|
||||
@@ -23002,9 +23005,8 @@ msgid ""
|
||||
msgstr ""
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/order/change.html:220
|
||||
#, fuzzy
|
||||
msgid "Ticket block"
|
||||
msgstr "Codice biglietto"
|
||||
msgstr "Biglietto bloccato"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/order/change.html:226
|
||||
msgid "Blocked due to external constraints"
|
||||
@@ -25151,9 +25153,8 @@ msgid "Organizer logs"
|
||||
msgstr "Organizzatore"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/organizers/mail.html:60
|
||||
#, fuzzy
|
||||
msgid "Customer account registration"
|
||||
msgstr "Invia ordine"
|
||||
msgstr "Registrazione account cliente"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/organizers/mail.html:63
|
||||
#, fuzzy
|
||||
@@ -26182,7 +26183,7 @@ msgstr ""
|
||||
#: pretix/control/templates/pretixcontrol/subevents/bulk.html:10
|
||||
msgctxt "subevent"
|
||||
msgid "Create multiple dates"
|
||||
msgstr ""
|
||||
msgstr "Crea date multiple"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/subevents/bulk.html:35
|
||||
#: pretix/control/templates/pretixcontrol/subevents/bulk.html:146
|
||||
@@ -26275,10 +26276,9 @@ msgstr ""
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/subevents/bulk_edit.html:9
|
||||
#: pretix/control/templates/pretixcontrol/subevents/bulk_edit.html:12
|
||||
#, fuzzy
|
||||
msgctxt "subevent"
|
||||
msgid "Change multiple dates"
|
||||
msgstr "Solo ordini pagati"
|
||||
msgstr "Cambia date multiple"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/subevents/bulk_edit.html:154
|
||||
msgid "Item prices"
|
||||
@@ -27208,6 +27208,12 @@ msgid ""
|
||||
"quota is available) or you can press the big button below this text to send "
|
||||
"out as many vouchers as currently possible to the persons who waited longest."
|
||||
msgstr ""
|
||||
"Hai configurato il sistema affinché i voucher <strong>non</strong> vengano "
|
||||
"inviati automaticamente. Puoi inviarli singolarmente nell'ordine che "
|
||||
"preferisci cliccando sui pulsanti accanto a ogni riga di questa tabella (se "
|
||||
"la quota è sufficiente), oppure puoi premere il pulsante grande sotto questo "
|
||||
"testo per inviare quanti più voucher possibile alle persone in attesa da più "
|
||||
"tempo."
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/waitinglist/index.html:79
|
||||
msgid "Send as many vouchers as possible"
|
||||
@@ -33293,10 +33299,9 @@ msgstr ""
|
||||
|
||||
#: pretix/presale/forms/renderers.py:66
|
||||
#: pretix/presale/templates/pretixpresale/event/fragment_voucher_form.html:14
|
||||
#, fuzzy
|
||||
msgctxt "form"
|
||||
msgid "required"
|
||||
msgstr "Carrello scaduto"
|
||||
msgstr "obbligatorio"
|
||||
|
||||
#: pretix/presale/ical.py:87 pretix/presale/ical.py:146
|
||||
#: pretix/presale/ical.py:182
|
||||
@@ -33629,7 +33634,7 @@ msgstr "Invia ordine"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/checkout_customer.html:19
|
||||
msgid "Log in with a customer account"
|
||||
msgstr ""
|
||||
msgstr "Accedi con un account cliente"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/checkout_customer.html:26
|
||||
msgid "You are currently logged in with the following credentials."
|
||||
@@ -34002,7 +34007,7 @@ msgstr ""
|
||||
#: pretix/presale/templates/pretixpresale/event/fragment_availability.html:25
|
||||
#: pretix/presale/templates/pretixpresale/event/fragment_product_list.html:91
|
||||
msgid "FULLY BOOKED"
|
||||
msgstr ""
|
||||
msgstr "TUTTO PRENOTATO"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/fragment_availability.html:37
|
||||
#: pretix/presale/templates/pretixpresale/event/fragment_product_list.html:101
|
||||
@@ -34514,7 +34519,7 @@ msgstr ""
|
||||
#: pretix/presale/templates/pretixpresale/event/fragment_quota_left.html:4
|
||||
#, python-format
|
||||
msgid "%(num)s currently available"
|
||||
msgstr ""
|
||||
msgstr "%(num)s attualmente disponibili"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/fragment_subevent_calendar.html:5
|
||||
#: pretix/presale/templates/pretixpresale/event/fragment_subevent_calendar_week.html:5
|
||||
@@ -34751,18 +34756,14 @@ msgstr ""
|
||||
"completo."
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/order.html:56
|
||||
#, fuzzy
|
||||
#| msgid ""
|
||||
#| "Please bookmark or save the link to this exact page if you want to access "
|
||||
#| "your order later. We also sent you an email containing the link to the "
|
||||
#| "address you specified."
|
||||
msgid ""
|
||||
"Please bookmark or save the link to this exact page if you want to access "
|
||||
"your order later. We also sent you an email to the address you specified "
|
||||
"containing the link to this page."
|
||||
msgstr ""
|
||||
"Salva questa pagina nei preferiti se vuoi accedervi in seguito. Ti abbiamo "
|
||||
"anche inviato una email contenente il link a questa pagina."
|
||||
"Salva questa pagina nei preferiti se vuoi accedere al tuo ordine in seguito. "
|
||||
"Ti abbiamo anche inviato una email all'indirizzo che hai indicato contenente "
|
||||
"il link a questa pagina."
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/order.html:60
|
||||
#, fuzzy
|
||||
@@ -34877,7 +34878,7 @@ msgstr "Riferimento Interno"
|
||||
#: pretix/presale/templates/pretixpresale/event/order.html:354
|
||||
msgctxt "action"
|
||||
msgid "Change or cancel your order"
|
||||
msgstr ""
|
||||
msgstr "Modifica o cancella il tuo ordine"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/order.html:356
|
||||
#, fuzzy
|
||||
@@ -34887,10 +34888,9 @@ msgid "Change your order"
|
||||
msgstr "Cambia ordine"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/order.html:358
|
||||
#, fuzzy
|
||||
msgctxt "action"
|
||||
msgid "Cancel your order"
|
||||
msgstr "Solo ordini pagati"
|
||||
msgstr "Cancella il tuo ordine"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/order.html:366
|
||||
msgid ""
|
||||
@@ -34984,7 +34984,7 @@ msgstr ""
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/order.html:472
|
||||
msgid "You can cancel this order using the following button."
|
||||
msgstr ""
|
||||
msgstr "Puoi cancellare questo ordine usando il bottone di seguito."
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/order_cancel.html:11
|
||||
#, python-format
|
||||
@@ -35271,7 +35271,7 @@ msgstr "Devi selezionare almeno %(number)s prodotti."
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/waitinglist.html:5
|
||||
msgid "Add me to the waiting list"
|
||||
msgstr ""
|
||||
msgstr "Aggiungimi alla lista d'attesa"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/waitinglist.html:22
|
||||
#, python-format
|
||||
@@ -35280,6 +35280,10 @@ msgid ""
|
||||
"waiting list. If we notify you, you'll have %(hours)s hours time to buy a "
|
||||
"ticket until we assign it to the next person on the list."
|
||||
msgstr ""
|
||||
"Se i biglietti dovessero tornare disponibili, informeremo le prime persone "
|
||||
"in lista d'attesa. Se ti avvisiamo, avrai %(hours)s ore di tempo per "
|
||||
"acquistare un biglietto prima che venga assegnato alla persona successiva in "
|
||||
"lista."
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/waitinglist.html:28
|
||||
msgid ""
|
||||
@@ -35287,6 +35291,9 @@ msgid ""
|
||||
"you need to add yourself to the waiting list multiple times. There is no "
|
||||
"guarantee that you will receive a certain number of tickets."
|
||||
msgstr ""
|
||||
"Tieni presente che riceverai un solo biglietto. Se hai bisogno di più "
|
||||
"biglietti, dovrai iscriverti alla lista d'attesa più volte. Non è garantito "
|
||||
"che riceverai un numero esatto di biglietti."
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/waitinglist.html:32
|
||||
msgid ""
|
||||
@@ -35295,6 +35302,10 @@ msgid ""
|
||||
"email addresses. There is no guarantee that you will receive a certain "
|
||||
"number of tickets."
|
||||
msgstr ""
|
||||
"Tieni presente che riceverai un solo biglietto. Se hai bisogno di più "
|
||||
"biglietti, dovrai iscriverti alla lista d'attesa più volte utilizzando "
|
||||
"indirizzi email diversi. Non è garantito che riceverai un numero esatto di "
|
||||
"biglietti."
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/waitinglist.html:38
|
||||
msgid ""
|
||||
@@ -35302,15 +35313,17 @@ msgid ""
|
||||
"been added to the waiting list. We will only contact you once a spot opens "
|
||||
"up."
|
||||
msgstr ""
|
||||
"<strong>Non</strong> riceverai un'email di conferma dopo essere stato "
|
||||
"aggiunto alla lista d'attesa. Ti contatteremo solo quando si libererà un "
|
||||
"posto."
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/waitinglist.html:44
|
||||
msgid "Add me to the list"
|
||||
msgstr ""
|
||||
msgstr "Aggiungimi alla lista"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/waitinglist_remove.html:5
|
||||
#, fuzzy
|
||||
msgid "Remove me from the waiting list"
|
||||
msgstr "Informazioni dell'ordine modificate"
|
||||
msgstr "Cancellami dalla lista d'attesa"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/waitinglist_remove.html:9
|
||||
msgid ""
|
||||
@@ -35320,10 +35333,9 @@ msgid ""
|
||||
msgstr ""
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/waitinglist_remove.html:16
|
||||
#, fuzzy
|
||||
msgctxt "waitinglist"
|
||||
msgid "Yes, remove my ticket"
|
||||
msgstr "Aggiungi o rimuovi biglietti"
|
||||
msgstr "Si, cancella i miei biglietti"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/fragment_calendar.html:7
|
||||
msgid "Calendar"
|
||||
@@ -35347,9 +35359,8 @@ msgstr "(continua)"
|
||||
#: pretix/presale/templates/pretixpresale/fragment_event_list_status.html:14
|
||||
#: pretix/presale/templates/pretixpresale/fragment_week_calendar.html:58
|
||||
#: pretix/presale/views/widget.py:440
|
||||
#, fuzzy
|
||||
msgid "Few tickets left"
|
||||
msgstr "Abilita formato biglietti"
|
||||
msgstr "Pochi biglietti rimasti"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/fragment_calendar.html:92
|
||||
#: pretix/presale/templates/pretixpresale/fragment_day_calendar.html:97
|
||||
@@ -35397,10 +35408,9 @@ msgid "iCal"
|
||||
msgstr "iCal"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/fragment_day_calendar.html:25
|
||||
#, fuzzy
|
||||
msgctxt "day calendar"
|
||||
msgid "Single events"
|
||||
msgstr "Prezzo netto"
|
||||
msgstr "Singoli eventi"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/fragment_day_calendar.html:79
|
||||
msgctxt "timerange"
|
||||
@@ -35426,13 +35436,12 @@ msgstr ""
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/fragment_login_status.html:5
|
||||
msgid "customer account"
|
||||
msgstr ""
|
||||
msgstr "account cliente"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/fragment_login_status.html:8
|
||||
#: pretix/presale/templates/pretixpresale/fragment_login_status.html:9
|
||||
#, fuzzy
|
||||
msgid "View customer account"
|
||||
msgstr "Vedi un'altra data"
|
||||
msgstr "Vedi account cliente"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/fragment_modals.html:18
|
||||
#, fuzzy
|
||||
@@ -35630,9 +35639,8 @@ msgid "Change account information"
|
||||
msgstr "Le tue informazioni"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/organizers/customer_base.html:41
|
||||
#, fuzzy
|
||||
msgid "customer account information"
|
||||
msgstr "Invia ordine"
|
||||
msgstr "Informazioni account cliente"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/organizers/customer_giftcards.html:28
|
||||
#, fuzzy, python-format
|
||||
@@ -35790,7 +35798,7 @@ msgstr "Ripeti la nuova password"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/organizers/index.html:11
|
||||
msgid "Event list"
|
||||
msgstr ""
|
||||
msgstr "Lista eventi"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/organizers/index.html:35
|
||||
msgid "Past events"
|
||||
@@ -35801,10 +35809,9 @@ msgid "Upcoming events"
|
||||
msgstr "Prossimi eventi"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/organizers/index.html:56
|
||||
#, fuzzy
|
||||
msgctxt "subevent"
|
||||
msgid "Multiple dates"
|
||||
msgstr "Solo ordini pagati"
|
||||
msgstr "Date multiple"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/organizers/index.html:105
|
||||
msgid "No archived events found."
|
||||
@@ -36147,6 +36154,8 @@ msgid ""
|
||||
"You cannot add yourself to the waiting list as this product is currently "
|
||||
"available."
|
||||
msgstr ""
|
||||
"Non puoi aggiungerti alla lista d'attesa in quanto questo prodotto è "
|
||||
"attualmente disponibile."
|
||||
|
||||
#: pretix/presale/views/waiting.py:180
|
||||
#, python-brace-format
|
||||
|
||||
@@ -8,8 +8,8 @@ msgstr ""
|
||||
"Project-Id-Version: PACKAGE VERSION\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2026-03-17 14:06+0000\n"
|
||||
"PO-Revision-Date: 2026-02-10 16:49+0000\n"
|
||||
"Last-Translator: Raffaele Doretto <ced@comune.portogruaro.ve.it>\n"
|
||||
"PO-Revision-Date: 2026-03-25 14:14+0000\n"
|
||||
"Last-Translator: Pietro Isotti <isottipietro@gmail.com>\n"
|
||||
"Language-Team: Italian <https://translate.pretix.eu/projects/pretix/pretix-"
|
||||
"js/it/>\n"
|
||||
"Language: it\n"
|
||||
@@ -17,7 +17,7 @@ msgstr ""
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
"Content-Transfer-Encoding: 8bit\n"
|
||||
"Plural-Forms: nplurals=2; plural=n != 1;\n"
|
||||
"X-Generator: Weblate 5.15.2\n"
|
||||
"X-Generator: Weblate 5.16.2\n"
|
||||
|
||||
#: pretix/plugins/banktransfer/static/pretixplugins/banktransfer/ui.js:56
|
||||
#: pretix/plugins/banktransfer/static/pretixplugins/banktransfer/ui.js:62
|
||||
@@ -310,9 +310,8 @@ msgid "Ticket code revoked/changed"
|
||||
msgstr "Codice biglietto annullato/modificato"
|
||||
|
||||
#: pretix/plugins/webcheckin/static/pretixplugins/webcheckin/main.js:63
|
||||
#, fuzzy
|
||||
msgid "Ticket blocked"
|
||||
msgstr "Biglietto non pagato"
|
||||
msgstr "Biglietto bloccato"
|
||||
|
||||
#: pretix/plugins/webcheckin/static/pretixplugins/webcheckin/main.js:64
|
||||
msgid "Ticket not valid at this time"
|
||||
@@ -429,7 +428,7 @@ msgstr ""
|
||||
|
||||
#: pretix/static/pretixbase/js/asynctask.js:276
|
||||
msgid "If this takes longer than a few minutes, please contact us."
|
||||
msgstr ""
|
||||
msgstr "Se questa operazione richiede alcuni minuti, si prega di contattarci."
|
||||
|
||||
#: pretix/static/pretixbase/js/asynctask.js:331
|
||||
msgid "Close message"
|
||||
|
||||
@@ -8,7 +8,7 @@ msgstr ""
|
||||
"Project-Id-Version: PACKAGE VERSION\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2026-03-17 14:05+0000\n"
|
||||
"PO-Revision-Date: 2026-03-09 12:52+0000\n"
|
||||
"PO-Revision-Date: 2026-03-23 21:00+0000\n"
|
||||
"Last-Translator: Hijiri Umemoto <hijiri@umemoto.org>\n"
|
||||
"Language-Team: Japanese <https://translate.pretix.eu/projects/pretix/pretix/"
|
||||
"ja/>\n"
|
||||
@@ -399,10 +399,8 @@ msgstr ""
|
||||
|
||||
#: pretix/api/serializers/organizer.py:482
|
||||
#: pretix/control/views/organizer.py:1039
|
||||
#, fuzzy
|
||||
#| msgid "Account information"
|
||||
msgid "Account invitation"
|
||||
msgstr "アカウント情報"
|
||||
msgstr "アカウントに招待"
|
||||
|
||||
#: pretix/api/serializers/organizer.py:503
|
||||
#: pretix/control/views/organizer.py:1138
|
||||
@@ -3926,10 +3924,8 @@ msgid "Peppol participant ID"
|
||||
msgstr "Peppol参加者ID"
|
||||
|
||||
#: pretix/base/invoicing/peppol.py:211
|
||||
#, fuzzy
|
||||
#| msgid "The Peppol participant ID is not registered on the Peppol network."
|
||||
msgid "The Peppol participant ID does not match your VAT ID."
|
||||
msgstr "Peppol参加者IDはPeppolネットワークに登録されていません。"
|
||||
msgstr "Peppolの参加者IDがVAT IDと一致しません。"
|
||||
|
||||
#: pretix/base/invoicing/peppol.py:214
|
||||
msgctxt "peppol_invoice"
|
||||
@@ -6766,10 +6762,8 @@ msgstr ""
|
||||
"かかる場合があります。"
|
||||
|
||||
#: pretix/base/models/organizer.py:378
|
||||
#, fuzzy
|
||||
#| msgid "Event permissions"
|
||||
msgid "All event permissions"
|
||||
msgstr "イベントの権限"
|
||||
msgstr "すべてのイベントの権限"
|
||||
|
||||
#: pretix/base/models/organizer.py:379
|
||||
#: pretix/control/templates/pretixcontrol/organizers/team_edit.html:34
|
||||
@@ -6777,10 +6771,8 @@ msgid "Event permissions"
|
||||
msgstr "イベントの権限"
|
||||
|
||||
#: pretix/base/models/organizer.py:380
|
||||
#, fuzzy
|
||||
#| msgid "Organizer permissions"
|
||||
msgid "All organizer permissions"
|
||||
msgstr "主催者の権限"
|
||||
msgstr "全ての主催者の権限"
|
||||
|
||||
#: pretix/base/models/organizer.py:381
|
||||
#: pretix/control/templates/pretixcontrol/organizers/team_edit.html:25
|
||||
@@ -8244,36 +8236,30 @@ msgstr ""
|
||||
#: pretix/base/permissions.py:314 pretix/base/permissions.py:331
|
||||
msgctxt "permission_level"
|
||||
msgid "View"
|
||||
msgstr ""
|
||||
msgstr "見る"
|
||||
|
||||
#: pretix/base/permissions.py:164 pretix/base/permissions.py:169
|
||||
#: pretix/base/permissions.py:174 pretix/base/permissions.py:179
|
||||
#: pretix/base/permissions.py:286 pretix/base/permissions.py:315
|
||||
#, fuzzy
|
||||
#| msgid "Save and check"
|
||||
msgctxt "permission_level"
|
||||
msgid "View and change"
|
||||
msgstr "保存してチェックします"
|
||||
msgstr "確認と変更"
|
||||
|
||||
#: pretix/base/permissions.py:168
|
||||
#, fuzzy
|
||||
#| msgid "API tokens"
|
||||
msgid "API only"
|
||||
msgstr "APIトークン"
|
||||
msgstr "APIのみ"
|
||||
|
||||
#: pretix/base/permissions.py:173
|
||||
msgid ""
|
||||
"Menu item will only show up if the user has permission for general settings."
|
||||
msgstr ""
|
||||
msgstr "メニュー項目は、ユーザーが一般設定の権限を持っている場合にのみ表示されます。"
|
||||
|
||||
#: pretix/base/permissions.py:177 pretix/base/permissions.py:231
|
||||
#: pretix/base/permissions.py:285 pretix/base/permissions.py:313
|
||||
#: pretix/base/permissions.py:330
|
||||
#, fuzzy
|
||||
#| msgid "Revoke access"
|
||||
msgctxt "permission_level"
|
||||
msgid "No access"
|
||||
msgstr "アクセスを取り消す"
|
||||
msgstr "アクセスなし"
|
||||
|
||||
#: pretix/base/permissions.py:188
|
||||
#: pretix/control/templates/pretixcontrol/event/settings.html:7
|
||||
@@ -8287,6 +8273,8 @@ msgid ""
|
||||
"This includes access to all settings not listed explicitly below, including "
|
||||
"plugin settings."
|
||||
msgstr ""
|
||||
"これには、以下に明示的に記載されていないすべての設定(プラグイン設定を含む)"
|
||||
"へのアクセスが含まれます。"
|
||||
|
||||
#: pretix/base/permissions.py:197
|
||||
#: pretix/control/templates/pretixcontrol/event/payment.html:6
|
||||
@@ -8300,100 +8288,77 @@ msgid "Tax settings"
|
||||
msgstr "税の設定"
|
||||
|
||||
#: pretix/base/permissions.py:209
|
||||
#, fuzzy
|
||||
#| msgid "Invoice settings"
|
||||
msgid "Invoicing settings"
|
||||
msgstr "請求書の設定"
|
||||
msgstr "請求の設定"
|
||||
|
||||
#: pretix/base/permissions.py:215
|
||||
#, fuzzy
|
||||
#| msgctxt "subevent"
|
||||
#| msgid "Event series date added"
|
||||
msgid "Event series dates"
|
||||
msgstr "イベントシリーズに日程が追加されました"
|
||||
msgstr "イベントシリーズの日程"
|
||||
|
||||
#: pretix/base/permissions.py:221
|
||||
#, fuzzy
|
||||
#| msgid "Product name and variation"
|
||||
msgid "Products, quotas and questions"
|
||||
msgstr "製品名とバリエーション"
|
||||
msgstr "製品、クオータおよび質問"
|
||||
|
||||
#: pretix/base/permissions.py:224
|
||||
msgid "Also includes related objects like categories or discounts."
|
||||
msgstr ""
|
||||
msgstr "カテゴリや割引などの関連オブジェクトも含まれます。"
|
||||
|
||||
#: pretix/base/permissions.py:232
|
||||
#, fuzzy
|
||||
#| msgid "All check-ins"
|
||||
msgctxt "permission_level"
|
||||
msgid "Only check-in"
|
||||
msgstr "すべてのチェックイン"
|
||||
msgstr "チェックインのみ"
|
||||
|
||||
#: pretix/base/permissions.py:233
|
||||
#, fuzzy
|
||||
#| msgid "View full log"
|
||||
msgctxt "permission_level"
|
||||
msgid "View all"
|
||||
msgstr "フルログを表示します"
|
||||
msgstr "すべてを表示"
|
||||
|
||||
#: pretix/base/permissions.py:234
|
||||
#, fuzzy
|
||||
#| msgid "Valid check-in"
|
||||
msgctxt "permission_level"
|
||||
msgid "View all and check-in"
|
||||
msgstr "有効なチェックイン"
|
||||
msgstr "すべてを表示してチェックイン"
|
||||
|
||||
#: pretix/base/permissions.py:235
|
||||
#, fuzzy
|
||||
#| msgid "View all upcoming events"
|
||||
msgctxt "permission_level"
|
||||
msgid "View all and change"
|
||||
msgstr "すべての予定されているイベントを表示します"
|
||||
msgstr "すべてを表示して変更する"
|
||||
|
||||
#: pretix/base/permissions.py:236
|
||||
msgid "Includes the ability to cancel and refund individual orders."
|
||||
msgstr ""
|
||||
msgstr "個別の注文をキャンセルおよび返金する機能が含まれています。"
|
||||
|
||||
#: pretix/base/permissions.py:238
|
||||
#, fuzzy
|
||||
#| msgid "An entry has been added to the waiting list."
|
||||
msgid "Also includes related objects like the waiting list."
|
||||
msgstr "空席待ちリストに登録が追加されました。"
|
||||
msgstr "待機リストなどの関連オブジェクトも含まれます。"
|
||||
|
||||
#: pretix/base/permissions.py:248
|
||||
#, fuzzy
|
||||
#| msgid "Generate cancellation"
|
||||
msgid "Full event or date cancellation"
|
||||
msgstr "キャンセルを生成します"
|
||||
msgstr "イベント全体または日程のキャンセル"
|
||||
|
||||
#: pretix/base/permissions.py:252
|
||||
#, fuzzy
|
||||
#| msgid "Sale not allowed"
|
||||
msgctxt "permission_level"
|
||||
msgid "Not allowed"
|
||||
msgstr "販売は許可されていません"
|
||||
msgstr "許可されていません"
|
||||
|
||||
#: pretix/base/permissions.py:253
|
||||
#, fuzzy
|
||||
#| msgid "Allowed titles"
|
||||
msgctxt "permission_level"
|
||||
msgid "Allowed"
|
||||
msgstr "選択可能な敬称"
|
||||
msgstr "許可されている"
|
||||
|
||||
#: pretix/base/permissions.py:268
|
||||
msgctxt "permission_level"
|
||||
msgid "Access existing events"
|
||||
msgstr ""
|
||||
msgstr "既存のイベントにアクセス"
|
||||
|
||||
#: pretix/base/permissions.py:269
|
||||
msgctxt "permission_level"
|
||||
msgid "Access existing and create new events"
|
||||
msgstr ""
|
||||
msgstr "既存のイベントにアクセスし、新しいイベントを作成する"
|
||||
|
||||
#: pretix/base/permissions.py:271
|
||||
msgid ""
|
||||
"The level of access to events is determined in detail by the settings below."
|
||||
msgstr ""
|
||||
msgstr "イベントへのアクセスレベルは、以下の設定によって詳細に決定されます。"
|
||||
|
||||
#: pretix/base/permissions.py:275 pretix/control/navigation.py:143
|
||||
#: pretix/control/navigation.py:462 pretix/control/navigation.py:512
|
||||
@@ -8412,12 +8377,14 @@ msgid ""
|
||||
"This includes access to all organizer-level functionality not listed "
|
||||
"explicitly below, including plugin settings."
|
||||
msgstr ""
|
||||
"これには、以下に明示的に記載されていないすべてのオーガナイザーレベル機能への"
|
||||
"アクセスが含まれ、プラグイン設定も含まれます。"
|
||||
|
||||
#: pretix/base/permissions.py:287
|
||||
msgid ""
|
||||
"Includes the ability to give someone (including oneself) additional "
|
||||
"permissions."
|
||||
msgstr ""
|
||||
msgstr "自分自身を含む誰かに追加の権限を付与する機能が含まれています。"
|
||||
|
||||
#: pretix/base/permissions.py:298 pretix/control/navigation.py:608
|
||||
#: pretix/control/templates/pretixcontrol/organizers/customers.html:6
|
||||
@@ -8435,12 +8402,12 @@ msgid ""
|
||||
"Includes the ability to give access to events and data oneself does not have "
|
||||
"access to."
|
||||
msgstr ""
|
||||
"自らがアクセスできないイベントやデータへのアクセス権を付与する機能が含まれま"
|
||||
"す。"
|
||||
|
||||
#: pretix/base/permissions.py:321
|
||||
#, fuzzy
|
||||
#| msgid "Seating plan"
|
||||
msgid "Seating plans"
|
||||
msgstr "座席表"
|
||||
msgstr "座席プラン"
|
||||
|
||||
#: pretix/base/permissions.py:327 pretix/control/navigation.py:712
|
||||
#: pretix/control/templates/pretixcontrol/organizers/outgoing_mails.html:8
|
||||
@@ -9043,12 +9010,12 @@ msgid "Czech National Bank"
|
||||
msgstr "チェコ国立銀行"
|
||||
|
||||
#: pretix/base/services/export.py:94 pretix/base/services/export.py:154
|
||||
#, fuzzy
|
||||
#| msgid "You do not have sufficient permission to perform this export."
|
||||
msgid ""
|
||||
"Export not found or you do not have sufficient permission to perform this "
|
||||
"export."
|
||||
msgstr "このエクスポートを実行するための十分な権限がありません。"
|
||||
msgstr ""
|
||||
"エクスポートが見つからないか、エクスポートを実行するための十分な権限がありま"
|
||||
"せん。"
|
||||
|
||||
#: pretix/base/services/export.py:107 pretix/base/services/export.py:179
|
||||
#: pretix/base/services/export.py:357
|
||||
@@ -13334,25 +13301,7 @@ msgid "Contact"
|
||||
msgstr "連絡先"
|
||||
|
||||
#: pretix/base/templates/pretixbase/email/shred_completed.txt:2
|
||||
#, fuzzy, python-format
|
||||
#| msgid ""
|
||||
#| "Hello,\n"
|
||||
#| "\n"
|
||||
#| "we hereby confirm that the following data shredding job has been "
|
||||
#| "completed:\n"
|
||||
#| "\n"
|
||||
#| "Organizer: %(organizer)s\n"
|
||||
#| "\n"
|
||||
#| "Event: %(event)s\n"
|
||||
#| "\n"
|
||||
#| "Data selection: %(shredders)s\n"
|
||||
#| "\n"
|
||||
#| "Start time: %(start_time)s (new data added after this time might not have "
|
||||
#| "been deleted)\n"
|
||||
#| "\n"
|
||||
#| "Best regards,\n"
|
||||
#| "\n"
|
||||
#| "Your pretix team\n"
|
||||
#, python-format
|
||||
msgid ""
|
||||
"Hello,\n"
|
||||
"\n"
|
||||
@@ -13386,7 +13335,7 @@ msgstr ""
|
||||
"\n"
|
||||
"敬具\n"
|
||||
"\n"
|
||||
"担当 pretix チーム\n"
|
||||
"担当 %(instance)sチーム\n"
|
||||
|
||||
#: pretix/base/templates/pretixbase/forms/widgets/checkbox_sales_channel_option.html:16
|
||||
msgid ""
|
||||
@@ -13940,16 +13889,12 @@ msgid "This is an event series"
|
||||
msgstr "これはイベントシリーズです"
|
||||
|
||||
#: pretix/control/forms/event.py:135 pretix/control/forms/event.py:363
|
||||
#, fuzzy
|
||||
#| msgid ""
|
||||
#| "You do not have sufficient permission to enable plugins that need to be "
|
||||
#| "enabled for the entire organizer account."
|
||||
msgid ""
|
||||
"You do not have a sufficient level of access on the event you selected to "
|
||||
"copy it to the desired organizer."
|
||||
msgstr ""
|
||||
"主催者アカウント全体で有効化する必要があるプラグインを有効にするのに十分な権"
|
||||
"限がありません。"
|
||||
"選択したイベントに対して、目的の主催者にコピーするための十分なアクセス権があ"
|
||||
"りません。"
|
||||
|
||||
#: pretix/control/forms/event.py:143
|
||||
msgid ""
|
||||
@@ -14028,6 +13973,8 @@ msgid ""
|
||||
"You cannot choose a team that would give you more access than you have on "
|
||||
"the event you are copying."
|
||||
msgstr ""
|
||||
"コピーしているイベントに対して、より多くのアクセス権が付与されるチームを選択"
|
||||
"することはできません。"
|
||||
|
||||
#: pretix/control/forms/event.py:344
|
||||
msgid "Copy configuration from"
|
||||
@@ -14043,6 +13990,8 @@ msgid ""
|
||||
"You cannot choose an event on which you have less access than the team you "
|
||||
"selected in the previous step."
|
||||
msgstr ""
|
||||
"前のステップで選択したチームよりもアクセス権が少ないイベントを選択することは"
|
||||
"できません。"
|
||||
|
||||
#: pretix/control/forms/event.py:387 pretix/control/forms/item.py:1304
|
||||
#: pretix/control/forms/subevents.py:411
|
||||
@@ -14992,7 +14941,7 @@ msgstr "すべての参加者"
|
||||
#: pretix/plugins/checkinlists/exporters.py:109
|
||||
#: pretix/plugins/checkinlists/exporters.py:501
|
||||
msgid "Checked in"
|
||||
msgstr "チェックインしました"
|
||||
msgstr "チェックイン済み"
|
||||
|
||||
#: pretix/control/forms/filter.py:2043
|
||||
#: pretix/plugins/checkinlists/exporters.py:110
|
||||
@@ -15010,7 +14959,7 @@ msgstr "チェックインしたが退出済み"
|
||||
#: pretix/control/templates/pretixcontrol/checkin/index.html:178
|
||||
#: pretix/plugins/checkinlists/exporters.py:112
|
||||
msgid "Not checked in"
|
||||
msgstr "未チェックイン"
|
||||
msgstr "チェックイン未了"
|
||||
|
||||
#: pretix/control/forms/filter.py:2064
|
||||
msgctxt "subevent"
|
||||
@@ -16347,7 +16296,7 @@ msgstr "1つの組織ドメインのみを設定できます。"
|
||||
|
||||
#: pretix/control/forms/organizer.py:322
|
||||
msgid "Provided by a plugin"
|
||||
msgstr ""
|
||||
msgstr "プラグインによって提供"
|
||||
|
||||
#: pretix/control/forms/organizer.py:438
|
||||
msgid ""
|
||||
@@ -17216,10 +17165,8 @@ msgid "The order has been denied (comment: \"{comment}\")."
|
||||
msgstr "注文は拒否されました(コメント:\"{comment}\")。"
|
||||
|
||||
#: pretix/control/logdisplay.py:521
|
||||
#, fuzzy
|
||||
#| msgid "The order has been overpaid."
|
||||
msgid "The customer VAT ID has been verified."
|
||||
msgstr "注文が過払いされました。"
|
||||
msgstr "顧客のVAT IDが確認されました。"
|
||||
|
||||
#: pretix/control/logdisplay.py:522
|
||||
#, python-brace-format
|
||||
@@ -17498,10 +17445,9 @@ msgid "{user} has been invited to the team."
|
||||
msgstr "{user} がチームに招待されました。"
|
||||
|
||||
#: pretix/control/logdisplay.py:644
|
||||
#, fuzzy, python-brace-format
|
||||
#| msgid "Invite for {user} has been resent."
|
||||
#, python-brace-format
|
||||
msgid "Invite for {user} has been deleted."
|
||||
msgstr "{user}への招待状が再送されました。"
|
||||
msgstr "{user}への招待が削除されました。"
|
||||
|
||||
#: pretix/control/logdisplay.py:645
|
||||
#, python-brace-format
|
||||
@@ -19779,21 +19725,7 @@ msgid "Add property"
|
||||
msgstr "プロパティを追加"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/email/confirmation_code.txt:1
|
||||
#, fuzzy, python-format
|
||||
#| msgid ""
|
||||
#| "Hello,\n"
|
||||
#| "\n"
|
||||
#| "%(reason)s\n"
|
||||
#| "\n"
|
||||
#| " %(code)s\n"
|
||||
#| "\n"
|
||||
#| "Please do never give this code to another person. Our support team will "
|
||||
#| "never ask for this code.\n"
|
||||
#| "\n"
|
||||
#| "If this code was not requested by you, please contact us immediately.\n"
|
||||
#| "\n"
|
||||
#| "Best regards,\n"
|
||||
#| "Your pretix team\n"
|
||||
#, python-format
|
||||
msgid ""
|
||||
"Hello,\n"
|
||||
"\n"
|
||||
@@ -19821,7 +19753,7 @@ msgstr ""
|
||||
"このコードにお心当たりがない場合は、直ちにご連絡ください。\n"
|
||||
"\n"
|
||||
"よろしくお願いいたします。\n"
|
||||
"pretixチーム\n"
|
||||
"%(instance)sチーム\n"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/email/email_setup.txt:1
|
||||
#, python-format
|
||||
@@ -19859,17 +19791,7 @@ msgstr ""
|
||||
"%(instance)s チーム\n"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/email/forgot.txt:1
|
||||
#, fuzzy, python-format
|
||||
#| msgid ""
|
||||
#| "Hello,\n"
|
||||
#| "\n"
|
||||
#| "you requested a new password. Please go to the following page to reset "
|
||||
#| "your password:\n"
|
||||
#| "\n"
|
||||
#| "%(url)s\n"
|
||||
#| "\n"
|
||||
#| "Best regards, \n"
|
||||
#| "Your pretix team\n"
|
||||
#, python-format
|
||||
msgid ""
|
||||
"Hello,\n"
|
||||
"\n"
|
||||
@@ -19889,27 +19811,10 @@ msgstr ""
|
||||
"%(url)s\n"
|
||||
"\n"
|
||||
"よろしくお願いします、 \n"
|
||||
"あなたのpretixチーム\n"
|
||||
"あなたの%(instance)sチーム\n"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/email/invitation.txt:1
|
||||
#, fuzzy, python-format
|
||||
#| msgid ""
|
||||
#| "Hello,\n"
|
||||
#| "\n"
|
||||
#| "you have been invited to a team on pretix, a platform to perform event\n"
|
||||
#| "ticket sales.\n"
|
||||
#| "\n"
|
||||
#| "Organizer: %(organizer)s\n"
|
||||
#| "Team: %(team)s\n"
|
||||
#| "\n"
|
||||
#| "If you want to join that team, just click on the following link:\n"
|
||||
#| "%(url)s\n"
|
||||
#| "\n"
|
||||
#| "If you do not want to join, you can safely ignore or delete this email.\n"
|
||||
#| "\n"
|
||||
#| "Best regards, \n"
|
||||
#| "\n"
|
||||
#| "Your pretix team\n"
|
||||
#, python-format
|
||||
msgid ""
|
||||
"Hello,\n"
|
||||
"\n"
|
||||
@@ -19931,7 +19836,7 @@ msgid ""
|
||||
msgstr ""
|
||||
"こんにちは、\n"
|
||||
"\n"
|
||||
"あなたは、pretixというイベントチケット販売プラットフォームの\n"
|
||||
"あなたは、%(instance)sというイベントチケット販売プラットフォームの\n"
|
||||
"チームに招待されました。\n"
|
||||
"\n"
|
||||
"主催者: %(organizer)s\n"
|
||||
@@ -19944,7 +19849,7 @@ msgstr ""
|
||||
"\n"
|
||||
"よろしくお願いします。\n"
|
||||
"\n"
|
||||
"pretixチーム\n"
|
||||
"%(instance)sチーム\n"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/email/login_notice.txt:1
|
||||
#, python-format
|
||||
@@ -19981,24 +19886,7 @@ msgstr ""
|
||||
"%(instance)sチーム\n"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/email/security_notice.txt:1
|
||||
#, fuzzy, python-format
|
||||
#| msgid ""
|
||||
#| "Hello,\n"
|
||||
#| "\n"
|
||||
#| "this is to inform you that the account information of your pretix account "
|
||||
#| "has been\n"
|
||||
#| "changed. In particular, the following changes have been performed:\n"
|
||||
#| "\n"
|
||||
#| "%(messages)s\n"
|
||||
#| "\n"
|
||||
#| "If this change was not performed by you, please contact us immediately.\n"
|
||||
#| "\n"
|
||||
#| "You can review and change your account settings here:\n"
|
||||
#| "\n"
|
||||
#| "%(url)s\n"
|
||||
#| "\n"
|
||||
#| "Best regards, \n"
|
||||
#| "Your pretix team\n"
|
||||
#, python-format
|
||||
msgid ""
|
||||
"Hello,\n"
|
||||
"\n"
|
||||
@@ -20019,20 +19907,21 @@ msgid ""
|
||||
msgstr ""
|
||||
"こんにちは\n"
|
||||
"\n"
|
||||
"お客様のpretixアカウントの情報が変更されましたので、お知らせいたします。\n"
|
||||
"あなたの%(instance)sのアカウント情報が変更されましたので、お知らせいたします"
|
||||
"。\n"
|
||||
"具体的には、以下の変更が行われました:\n"
|
||||
"\n"
|
||||
"%(messages)s\n"
|
||||
"\n"
|
||||
"もしもこの変更がお客様自身によるものでない場合は、直ちにお問い合わせくださ"
|
||||
"い。\n"
|
||||
"もしもこの変更がお客様自身によるものでない場合は、直ちにお問い合わせください"
|
||||
"。\n"
|
||||
"\n"
|
||||
"アカウント設定の確認や変更はこちらから行えます:\n"
|
||||
"\n"
|
||||
"%(url)s\n"
|
||||
"\n"
|
||||
"以上、よろしくお願いいたします。 \n"
|
||||
"pretixチームより\n"
|
||||
"%(instance)sチームより\n"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/email_setup.html:8
|
||||
#: pretix/control/templates/pretixcontrol/email_setup_simple.html:8
|
||||
@@ -20287,10 +20176,8 @@ msgstr ""
|
||||
"ルと払い戻しを行うことができます。"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/event/dangerzone.html:51
|
||||
#, fuzzy
|
||||
#| msgid "Permissions"
|
||||
msgid "No permission"
|
||||
msgstr "権限"
|
||||
msgstr "権限なし"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/event/dangerzone.html:59
|
||||
#: pretix/control/templates/pretixcontrol/event/dangerzone.html:72
|
||||
@@ -22768,10 +22655,8 @@ msgid "Edit question"
|
||||
msgstr "質問を編集"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/items/question.html:55
|
||||
#, fuzzy
|
||||
#| msgid "You do not have permission to view this content."
|
||||
msgid "No permission to view answers."
|
||||
msgstr "このコンテンツを表示する権限がありません。"
|
||||
msgstr "回答を閲覧する権限がありません。"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/items/question.html:63
|
||||
msgid "No matching answers found."
|
||||
@@ -24382,10 +24267,8 @@ msgstr "次の実行は予定されていない"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/orders/export.html:37
|
||||
#: pretix/control/templates/pretixcontrol/organizers/export.html:37
|
||||
#, fuzzy
|
||||
#| msgid "Exporter not found"
|
||||
msgid "Exporter not found or no permission"
|
||||
msgstr "エクスポーターが見つかりません"
|
||||
msgstr "エクスポーターが見つからない、または権限がありません"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/orders/export.html:42
|
||||
#: pretix/control/templates/pretixcontrol/organizers/export.html:42
|
||||
@@ -24428,10 +24311,8 @@ msgstr "新規ユーザー向けのおすすめです"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/orders/export.html:120
|
||||
#: pretix/control/templates/pretixcontrol/organizers/export.html:120
|
||||
#, fuzzy
|
||||
#| msgid "There are no add-ons available for this product."
|
||||
msgid "There are no exporters available for you."
|
||||
msgstr "この製品に利用可能なアドオンはありません。"
|
||||
msgstr "ご利用いただけるエクスポーターがありません。"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/orders/export_delete.html:4
|
||||
#: pretix/control/templates/pretixcontrol/orders/export_delete.html:6
|
||||
@@ -26329,7 +26210,7 @@ msgstr ""
|
||||
#: pretix/control/templates/pretixcontrol/pdf/index.html:274
|
||||
#, python-format
|
||||
msgid "max. %(size)s, smaller is better"
|
||||
msgstr ""
|
||||
msgstr "最大%(size)sで、より少ない数値が望ましい"
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/pdf/index.html:282
|
||||
msgid "Download current background"
|
||||
@@ -29023,16 +28904,12 @@ msgstr ""
|
||||
"い。"
|
||||
|
||||
#: pretix/control/views/orders.py:2798 pretix/control/views/organizer.py:2131
|
||||
#, fuzzy
|
||||
#| msgid ""
|
||||
#| "Your user account does not have sufficient permission to run this report, "
|
||||
#| "therefore you cannot schedule it."
|
||||
msgid ""
|
||||
"Your user account does not have sufficient permission to run this report, "
|
||||
"therefore you cannot change it."
|
||||
msgstr ""
|
||||
"ユーザーアカウントにはこのレポートを実行するのに十分な権限がないため、スケ"
|
||||
"ジュールを設定できません。"
|
||||
"あなたのユーザーアカウントにはこのレポートを実行する十分な権限がありませんの"
|
||||
"で、変更することはできません。"
|
||||
|
||||
#: pretix/control/views/orders.py:2807 pretix/control/views/organizer.py:2140
|
||||
msgid ""
|
||||
@@ -32995,7 +32872,7 @@ msgstr "Stripe経由でiDEAL"
|
||||
|
||||
#: pretix/plugins/stripe/payment.py:1572
|
||||
msgid "iDEAL | Wero"
|
||||
msgstr ""
|
||||
msgstr "iDEAL | Wero"
|
||||
|
||||
#: pretix/plugins/stripe/payment.py:1575
|
||||
msgid ""
|
||||
@@ -35905,6 +35782,8 @@ msgid ""
|
||||
"the shop that affect quotas, such as the validity period of carts and "
|
||||
"vouchers."
|
||||
msgstr ""
|
||||
"変更された時間は、カートやバウチャーの有効期間など、クォータに影響を与える"
|
||||
"ショップの項目については考慮されませんので、ご了承ください。"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/timemachine.html:31
|
||||
msgid "Enable time machine"
|
||||
|
||||
@@ -8,7 +8,7 @@ msgstr ""
|
||||
"Project-Id-Version: PACKAGE VERSION\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2026-03-17 14:06+0000\n"
|
||||
"PO-Revision-Date: 2026-02-23 10:00+0000\n"
|
||||
"PO-Revision-Date: 2026-03-23 21:00+0000\n"
|
||||
"Last-Translator: Hijiri Umemoto <hijiri@umemoto.org>\n"
|
||||
"Language-Team: Japanese <https://translate.pretix.eu/projects/pretix/pretix-"
|
||||
"js/ja/>\n"
|
||||
@@ -17,7 +17,7 @@ msgstr ""
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
"Content-Transfer-Encoding: 8bit\n"
|
||||
"Plural-Forms: nplurals=1; plural=0;\n"
|
||||
"X-Generator: Weblate 5.16\n"
|
||||
"X-Generator: Weblate 5.16.2\n"
|
||||
|
||||
#: pretix/plugins/banktransfer/static/pretixplugins/banktransfer/ui.js:56
|
||||
#: pretix/plugins/banktransfer/static/pretixplugins/banktransfer/ui.js:62
|
||||
@@ -60,7 +60,7 @@ msgstr "PayPal後払い"
|
||||
|
||||
#: pretix/plugins/paypal2/static/pretixplugins/paypal2/pretix-paypal.js:41
|
||||
msgid "iDEAL | Wero"
|
||||
msgstr ""
|
||||
msgstr "iDEAL | Wero"
|
||||
|
||||
#: pretix/plugins/paypal2/static/pretixplugins/paypal2/pretix-paypal.js:42
|
||||
msgid "SEPA Direct Debit"
|
||||
|
||||
@@ -8,7 +8,7 @@ msgstr ""
|
||||
"Project-Id-Version: PACKAGE VERSION\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2026-03-17 14:05+0000\n"
|
||||
"PO-Revision-Date: 2026-03-18 23:00+0000\n"
|
||||
"PO-Revision-Date: 2026-03-25 12:41+0000\n"
|
||||
"Last-Translator: Ruud Hendrickx <ruud@leckxicon.eu>\n"
|
||||
"Language-Team: Dutch (Belgium) <https://translate.pretix.eu/projects/pretix/"
|
||||
"pretix/nl_BE/>\n"
|
||||
@@ -29442,163 +29442,177 @@ msgid ""
|
||||
"The order has been canceled. You can now select how you want to transfer the "
|
||||
"money back to the user."
|
||||
msgstr ""
|
||||
"De bestelling is geannuleerd. U kunt nu kiezen hoe u het geld wilt overmaken "
|
||||
"naar de gebruiker."
|
||||
|
||||
#: pretix/control/views/orders.py:1627 pretix/control/views/orders.py:1631
|
||||
msgid "No VAT ID specified."
|
||||
msgstr ""
|
||||
msgstr "Geen btw-nummer opgegeven."
|
||||
|
||||
#: pretix/control/views/orders.py:1635
|
||||
msgid "No country specified."
|
||||
msgstr ""
|
||||
msgstr "Geen land opgegeven."
|
||||
|
||||
#: pretix/control/views/orders.py:1639
|
||||
msgid "VAT ID could not be checked since this country is not supported."
|
||||
msgstr ""
|
||||
"Btw-nummer kon niet gecontroleerd worden, omdat dit land niet ondersteund "
|
||||
"wordt."
|
||||
|
||||
#: pretix/control/views/orders.py:1658
|
||||
msgid ""
|
||||
"The VAT ID could not be checked, as the VAT checking service of the country "
|
||||
"is currently not available."
|
||||
msgstr ""
|
||||
"Uw btw-nummer kon niet gecontroleerd worden, omdat de btw-controledienst van "
|
||||
"uw land momenteel niet beschikbaar is."
|
||||
|
||||
#: pretix/control/views/orders.py:1661
|
||||
msgid "This VAT ID is valid."
|
||||
msgstr ""
|
||||
msgstr "Dit btw-nummer is geldig."
|
||||
|
||||
#: pretix/control/views/orders.py:1675 pretix/control/views/orders.py:1709
|
||||
#: pretix/control/views/orders.py:1741
|
||||
msgid "Unknown invoice."
|
||||
msgstr ""
|
||||
msgstr "Onbekende factuur."
|
||||
|
||||
#: pretix/control/views/orders.py:1678
|
||||
msgid "Invoices may not be changed after they are created."
|
||||
msgstr ""
|
||||
msgstr "Facturen kunnen niet gewijzigd worden nadat ze zijn aangemaakt."
|
||||
|
||||
#: pretix/control/views/orders.py:1680
|
||||
msgid "Invoices may not be changed after they are transmitted."
|
||||
msgstr ""
|
||||
msgstr "Facturen kunnen niet gewijzigd worden nadat ze verstuurd zijn."
|
||||
|
||||
#: pretix/control/views/orders.py:1682 pretix/control/views/orders.py:1744
|
||||
msgid "The invoice has already been canceled."
|
||||
msgstr ""
|
||||
msgstr "De factuur is al geannuleerd."
|
||||
|
||||
#: pretix/control/views/orders.py:1684
|
||||
msgid "The invoice file has already been exported."
|
||||
msgstr ""
|
||||
msgstr "Het factuurbestand is al geëxporteerd."
|
||||
|
||||
#: pretix/control/views/orders.py:1686
|
||||
msgid "The invoice file is too old to be regenerated."
|
||||
msgstr ""
|
||||
msgstr "Het factuurbestand is te oud om opnieuw te worden gegenereerd."
|
||||
|
||||
#: pretix/control/views/orders.py:1688 pretix/control/views/orders.py:1746
|
||||
msgid "The invoice has been cleaned of personal data."
|
||||
msgstr ""
|
||||
msgstr "Persoonlijke gegevens zijn uit de factuur verwijderd."
|
||||
|
||||
#: pretix/control/views/orders.py:1713
|
||||
msgid ""
|
||||
"The invoice is currently being transmitted. You can start a new attempt "
|
||||
"after the current one has been completed."
|
||||
msgstr ""
|
||||
"De factuur wordt momenteel verzonden. U kunt een nieuwe poging doen nadat de "
|
||||
"huidige voltooid is."
|
||||
|
||||
#: pretix/control/views/orders.py:1720
|
||||
msgid "The invoice has been scheduled for retransmission."
|
||||
msgstr ""
|
||||
msgstr "De factuur is ingepland voor herverzending."
|
||||
|
||||
#: pretix/control/views/orders.py:1754
|
||||
msgid "The invoice has been canceled."
|
||||
msgstr ""
|
||||
msgstr "De factuur is geannuleerd."
|
||||
|
||||
#: pretix/control/views/orders.py:1793
|
||||
msgid "The email has been queued to be sent."
|
||||
msgstr ""
|
||||
msgstr "De e-mail is opgeslagen om te worden verzonden."
|
||||
|
||||
#: pretix/control/views/orders.py:1817 pretix/presale/views/order.py:1369
|
||||
msgid "This invoice has not been found"
|
||||
msgstr ""
|
||||
msgstr "Deze factuur is niet gevonden"
|
||||
|
||||
#: pretix/control/views/orders.py:1824 pretix/presale/views/order.py:1376
|
||||
msgid "The invoice file is no longer stored on the server."
|
||||
msgstr ""
|
||||
msgstr "Het factuurbestand is niet meer opgeslagen op de server."
|
||||
|
||||
#: pretix/control/views/orders.py:1829 pretix/presale/views/order.py:1381
|
||||
msgid ""
|
||||
"The invoice file has not yet been generated, we will generate it for you "
|
||||
"now. Please try again in a few seconds."
|
||||
msgstr ""
|
||||
"Het factuurbestand is nog niet gegenereerd, we zullen het nu voor u "
|
||||
"genereren. Probeer het over een paar seconden opnieuw."
|
||||
|
||||
#: pretix/control/views/orders.py:1857
|
||||
msgid "The payment term has been changed."
|
||||
msgstr ""
|
||||
msgstr "De betalingstermijn is gewijzigd."
|
||||
|
||||
#: pretix/control/views/orders.py:1862 pretix/control/views/orders.py:1919
|
||||
msgid ""
|
||||
"We were not able to process the request completely as the server was too "
|
||||
"busy."
|
||||
msgstr ""
|
||||
msgstr "We konden uw verzoek niet verwerken, omdat de server het te druk heeft."
|
||||
|
||||
#: pretix/control/views/orders.py:1870
|
||||
msgid "This action is only allowed for pending orders."
|
||||
msgstr ""
|
||||
msgstr "Deze actie is alleen toegestaan voor openstaande bestellingen."
|
||||
|
||||
#: pretix/control/views/orders.py:1925
|
||||
msgid "This action is only allowed for canceled orders."
|
||||
msgstr ""
|
||||
msgstr "Deze actie is alleen toegestaan voor geannuleerde bestellingen."
|
||||
|
||||
#: pretix/control/views/orders.py:2183 pretix/presale/views/order.py:1664
|
||||
msgid "An error occurred. Please see the details below."
|
||||
msgstr ""
|
||||
msgstr "Er is een fout opgetreden. Zie de details hieronder."
|
||||
|
||||
#: pretix/control/views/orders.py:2191
|
||||
msgid "The order has been changed and the user has been notified."
|
||||
msgstr ""
|
||||
msgstr "De bestelling is gewijzigd en de gebruiker is op de hoogte gesteld."
|
||||
|
||||
#: pretix/control/views/orders.py:2193 pretix/control/views/orders.py:2329
|
||||
#: pretix/control/views/orders.py:2366 pretix/presale/views/order.py:1700
|
||||
msgid "The order has been changed."
|
||||
msgstr ""
|
||||
msgstr "De bestelling is gewijzigd."
|
||||
|
||||
#: pretix/control/views/orders.py:2220 pretix/presale/checkoutflow.py:943
|
||||
#: pretix/presale/views/order.py:845 pretix/presale/views/order.py:981
|
||||
msgid ""
|
||||
"We had difficulties processing your input. Please review the errors below."
|
||||
msgstr ""
|
||||
"We hadden problemen met het verwerken van uw invoer. Zie de fouten hieronder."
|
||||
|
||||
#: pretix/control/views/orders.py:2331
|
||||
msgid "Nothing about the order had to be changed."
|
||||
msgstr ""
|
||||
msgstr "Er is geen wijziging aangebracht aan de bestelling."
|
||||
|
||||
#: pretix/control/views/orders.py:2412 pretix/plugins/sendmail/views.py:176
|
||||
msgid "We could not send the email. See below for details."
|
||||
msgstr ""
|
||||
msgstr "We konden de e-mail niet versturen. Zie onder voor details."
|
||||
|
||||
#: pretix/control/views/orders.py:2428 pretix/control/views/orders.py:2492
|
||||
#: pretix/plugins/sendmail/views.py:204 pretix/plugins/sendmail/views.py:671
|
||||
#, python-brace-format
|
||||
msgid "Subject: {subject}"
|
||||
msgstr ""
|
||||
msgstr "Onderwerp: {subject}"
|
||||
|
||||
#: pretix/control/views/orders.py:2446 pretix/control/views/orders.py:2511
|
||||
#, python-brace-format
|
||||
msgid "Your message has been queued and will be sent to {}."
|
||||
msgstr ""
|
||||
msgstr "Uw bericht is in de wachtrij gezet en zal verstuurd worden naar {}."
|
||||
|
||||
#: pretix/control/views/orders.py:2564 pretix/presale/views/order.py:1151
|
||||
msgid ""
|
||||
"This link is no longer valid. Please go back, refresh the page, and try "
|
||||
"again."
|
||||
msgstr ""
|
||||
"Deze link is niet meer geldig. Ga terug, ververs de pagina, en probeer het "
|
||||
"opnieuw."
|
||||
|
||||
#: pretix/control/views/orders.py:2645
|
||||
msgid "There is no order with the given order code."
|
||||
msgstr ""
|
||||
msgstr "Er is geen bestelling met de gegeven bestelcode."
|
||||
|
||||
#: pretix/control/views/orders.py:2751 pretix/control/views/organizer.py:2085
|
||||
msgid "The selected exporter was not found."
|
||||
msgstr ""
|
||||
msgstr "Het geselecteerde exportformaat is niet gevonden."
|
||||
|
||||
#: pretix/control/views/orders.py:2761 pretix/control/views/organizer.py:2095
|
||||
msgid "There was a problem processing your input. See below for error details."
|
||||
msgstr ""
|
||||
"Er was een probleem met het verwerken van uw invoer. Zie onder voor details."
|
||||
|
||||
#: pretix/control/views/orders.py:2798 pretix/control/views/organizer.py:2131
|
||||
msgid ""
|
||||
@@ -29613,6 +29627,8 @@ msgid ""
|
||||
"Your user account does not have sufficient permission to run this report, "
|
||||
"therefore you cannot schedule it."
|
||||
msgstr ""
|
||||
"Uw gebruikersaccount heeft onvoldoende rechten om dit rapport uit te voeren. "
|
||||
"Daarom kunt u het niet plannen."
|
||||
|
||||
#: pretix/control/views/orders.py:2823 pretix/control/views/organizer.py:2156
|
||||
#, python-brace-format
|
||||
@@ -29620,15 +29636,17 @@ msgid ""
|
||||
"Your export schedule has been saved. The next export will start around "
|
||||
"{datetime}."
|
||||
msgstr ""
|
||||
"De geplande export is opgeslagen. De volgende export begint omstreeks "
|
||||
"{datetime}."
|
||||
|
||||
#: pretix/control/views/orders.py:2828 pretix/control/views/organizer.py:2161
|
||||
msgid "Your export schedule has been saved, but no next export is planned."
|
||||
msgstr ""
|
||||
msgstr "De geplande export is opgeslagen, maar er is geen volgende run gepland."
|
||||
|
||||
#: pretix/control/views/orders.py:2873 pretix/control/views/organizer.py:2207
|
||||
#, python-brace-format
|
||||
msgid "Export: {title}"
|
||||
msgstr ""
|
||||
msgstr "Export: {title}"
|
||||
|
||||
#: pretix/control/views/orders.py:2874 pretix/control/views/organizer.py:2209
|
||||
#, python-brace-format
|
||||
@@ -29637,6 +29655,9 @@ msgid ""
|
||||
"\n"
|
||||
"attached to this email, you can find a new scheduled report for {name}."
|
||||
msgstr ""
|
||||
"Hallo,\n"
|
||||
"\n"
|
||||
"Als bijlage bij deze e-mail vindt u een nieuw gepland rapport voor {name}."
|
||||
|
||||
#: pretix/control/views/orders.py:2980 pretix/control/views/organizer.py:2343
|
||||
msgid ""
|
||||
@@ -29644,10 +29665,13 @@ msgid ""
|
||||
"Depending on system load and type and size of export, this may take a few "
|
||||
"minutes."
|
||||
msgstr ""
|
||||
"We hebben de export gepland. Het resultaat wordt per e-mail verzonden. "
|
||||
"Afhankelijk van de systeembelasting, het type en de grootte van de export "
|
||||
"kan dit enkele minuten duren."
|
||||
|
||||
#: pretix/control/views/orders.py:3067 pretix/control/views/orders.py:3148
|
||||
msgid "All orders have been canceled."
|
||||
msgstr ""
|
||||
msgstr "Alle bestellingen zijn geannuleerd."
|
||||
|
||||
#: pretix/control/views/orders.py:3069 pretix/control/views/orders.py:3150
|
||||
#, python-brace-format
|
||||
@@ -29655,28 +29679,32 @@ msgid ""
|
||||
"The orders have been canceled. An error occurred with {count} orders, please "
|
||||
"check all uncanceled orders."
|
||||
msgstr ""
|
||||
"De bestellingen zijn geannuleerd. Bij {count} bestellingen is er een fout "
|
||||
"opgetreden, controleer alstublieft alle nog niet geannuleerde bestellingen."
|
||||
|
||||
#: pretix/control/views/orders.py:3097 pretix/control/views/orders.py:3171
|
||||
msgid "Your input was not valid."
|
||||
msgstr ""
|
||||
msgstr "Uw invoer was ongeldig."
|
||||
|
||||
#: pretix/control/views/organizer.py:178
|
||||
msgid "Token name"
|
||||
msgstr ""
|
||||
msgstr "Tokennaam"
|
||||
|
||||
#: pretix/control/views/organizer.py:408
|
||||
msgid "This organizer can not be deleted."
|
||||
msgstr ""
|
||||
msgstr "Deze organisator kan niet verwijderd worden."
|
||||
|
||||
#: pretix/control/views/organizer.py:431
|
||||
msgid "The organizer has been deleted."
|
||||
msgstr ""
|
||||
msgstr "De organisator is verwijderd."
|
||||
|
||||
#: pretix/control/views/organizer.py:435
|
||||
msgid ""
|
||||
"The organizer could not be deleted as some constraints (e.g. data created by "
|
||||
"plug-ins) do not allow it."
|
||||
msgstr ""
|
||||
"De organisator kon niet verwijderd worden, omdat sommige beperkingen (bijv. "
|
||||
"data aangemaakt door plug-ins) het niet toestaan."
|
||||
|
||||
#: pretix/control/views/organizer.py:445
|
||||
#, python-brace-format
|
||||
@@ -29684,30 +29712,33 @@ msgid ""
|
||||
"The following database models still contain data that cannot be deleted "
|
||||
"automatically: {affected_models}"
|
||||
msgstr ""
|
||||
"De volgende databasemodellen bevatten nog steeds gegevens die niet "
|
||||
"automatisch verwijderd kunnen worden: {affected_models}"
|
||||
|
||||
#: pretix/control/views/organizer.py:585
|
||||
msgid "The new organizer has been created."
|
||||
msgstr ""
|
||||
msgstr "De nieuwe organisator is aangemaakt."
|
||||
|
||||
#: pretix/control/views/organizer.py:588
|
||||
msgid "Administrators"
|
||||
msgstr ""
|
||||
msgstr "Beheerders"
|
||||
|
||||
#: pretix/control/views/organizer.py:806
|
||||
msgid "Unknown plugin."
|
||||
msgstr ""
|
||||
msgstr "Onbekende plug-in."
|
||||
|
||||
#: pretix/control/views/organizer.py:812
|
||||
msgid "This plugin is currently not active on the organizer account."
|
||||
msgstr ""
|
||||
"Deze plug-in is momenteel niet actief op het account van de organisator."
|
||||
|
||||
#: pretix/control/views/organizer.py:816
|
||||
msgid "This plugin is currently not allowed for this organizer account."
|
||||
msgstr ""
|
||||
msgstr "Deze plug-in is momenteel niet toegestaan voor dit organisatoraccount."
|
||||
|
||||
#: pretix/control/views/organizer.py:905
|
||||
msgid "The team has been created. You can now add members to the team."
|
||||
msgstr ""
|
||||
msgstr "Het team is aangemaakt. U kunt nu leden aan het team toevoegen."
|
||||
|
||||
#: pretix/control/views/organizer.py:913 pretix/control/views/organizer.py:946
|
||||
#: pretix/control/views/organizer.py:1182
|
||||
@@ -29728,70 +29759,78 @@ msgstr ""
|
||||
#: pretix/control/views/organizer.py:3568
|
||||
#: pretix/control/views/organizer.py:3612
|
||||
msgid "Your changes could not be saved."
|
||||
msgstr ""
|
||||
msgstr "Uw wijzigingen konden niet worden opgeslagen."
|
||||
|
||||
#: pretix/control/views/organizer.py:980
|
||||
msgid "The selected team cannot be deleted."
|
||||
msgstr ""
|
||||
msgstr "Het gekozen team kan niet verwijderd worden."
|
||||
|
||||
#: pretix/control/views/organizer.py:992
|
||||
msgid ""
|
||||
"The team could not be deleted because the team or one of its API tokens is "
|
||||
"part of historical audit logs."
|
||||
msgstr ""
|
||||
"Dit team kan niet verwijderd worden, omdat een van de bijbehorende API-"
|
||||
"tokens deel uitmaakt van de systeemlogboeken."
|
||||
|
||||
#: pretix/control/views/organizer.py:1000
|
||||
msgid ""
|
||||
"The team could not be deleted as some constraints (e.g. data created by plug-"
|
||||
"ins) do not allow it."
|
||||
msgstr ""
|
||||
"Het team kon niet verwijderd worden, omdat sommige beperkingen (bijv. data "
|
||||
"aangemaakt door plug-ins) het niet toestaan."
|
||||
|
||||
#: pretix/control/views/organizer.py:1006
|
||||
msgid "The selected team has been deleted."
|
||||
msgstr ""
|
||||
msgstr "Het geselecteerde team is verwijderd."
|
||||
|
||||
#: pretix/control/views/organizer.py:1069
|
||||
msgid ""
|
||||
"You cannot remove the last member from this team as no one would be left "
|
||||
"with the permission to change teams."
|
||||
msgstr ""
|
||||
"U kunt het laatste lid niet uit dit team verwijderen, omdat er niemand meer "
|
||||
"zou zijn met de machtiging om teams te beheren."
|
||||
|
||||
#: pretix/control/views/organizer.py:1080
|
||||
msgid "The member has been removed from the team."
|
||||
msgstr ""
|
||||
msgstr "Het lid is verwijderd uit het team."
|
||||
|
||||
#: pretix/control/views/organizer.py:1087
|
||||
#: pretix/control/views/organizer.py:1103
|
||||
msgid "Invalid invite selected."
|
||||
msgstr ""
|
||||
msgstr "Ongeldige uitnodiging geselecteerd."
|
||||
|
||||
#: pretix/control/views/organizer.py:1096
|
||||
msgid "The invite has been revoked."
|
||||
msgstr ""
|
||||
msgstr "De uitnodiging is ingetrokken."
|
||||
|
||||
#: pretix/control/views/organizer.py:1112
|
||||
msgid "The invite has been resent."
|
||||
msgstr ""
|
||||
msgstr "De uitnodiging is opnieuw verstuurd."
|
||||
|
||||
#: pretix/control/views/organizer.py:1119
|
||||
msgid "Invalid token selected."
|
||||
msgstr ""
|
||||
msgstr "Ongeldig token geselecteerd."
|
||||
|
||||
#: pretix/control/views/organizer.py:1129
|
||||
msgid "The token has been revoked."
|
||||
msgstr ""
|
||||
msgstr "Het token is ingetrokken."
|
||||
|
||||
#: pretix/control/views/organizer.py:1141
|
||||
msgid "Users need to have a pretix account before they can be invited."
|
||||
msgstr ""
|
||||
"Gebruikers moeten een pretix-account hebben voordat ze uitgenodigd kunnen "
|
||||
"worden."
|
||||
|
||||
#: pretix/control/views/organizer.py:1151
|
||||
msgid "The new member has been invited to the team."
|
||||
msgstr ""
|
||||
msgstr "Het nieuwe lid is uitgenodigd voor het team."
|
||||
|
||||
#: pretix/control/views/organizer.py:1166
|
||||
msgid "The new member has been added to the team."
|
||||
msgstr ""
|
||||
msgstr "Het nieuwe lid is toegevoegd aan het team."
|
||||
|
||||
#: pretix/control/views/organizer.py:1177
|
||||
#, python-brace-format
|
||||
@@ -29800,101 +29839,108 @@ msgid ""
|
||||
"Please copy this secret to a safe place. You will not be able to view it "
|
||||
"again here."
|
||||
msgstr ""
|
||||
"Er is een nieuw API-token aangemaakt met de volgende sleutel: {}\n"
|
||||
"Bewaar deze sleutel op een veilige plek. U kunt hem hier later niet meer "
|
||||
"opvragen."
|
||||
|
||||
#: pretix/control/views/organizer.py:1474
|
||||
msgid "This device has been set up successfully."
|
||||
msgstr ""
|
||||
msgstr "Het apparaat is succesvol geïnstalleerd."
|
||||
|
||||
#: pretix/control/views/organizer.py:1502
|
||||
msgid "This device currently does not have access."
|
||||
msgstr ""
|
||||
msgstr "Dit apparaat heeft momenteel geen toegang."
|
||||
|
||||
#: pretix/control/views/organizer.py:1514
|
||||
msgid "Access for this device has been revoked."
|
||||
msgstr ""
|
||||
msgstr "De toegang voor dit apparaat is ingetrokken."
|
||||
|
||||
#: pretix/control/views/organizer.py:1635
|
||||
msgid ""
|
||||
"All requests will now be scheduled for an immediate attempt. Please allow "
|
||||
"for a few minutes before they are processed."
|
||||
msgstr ""
|
||||
"Alle wachtende webhooks worden nu ingepland voor een nieuwe poging "
|
||||
"binnenkort. Even geduld a.u.b. totdat de verwerking voltooid is."
|
||||
|
||||
#: pretix/control/views/organizer.py:1642
|
||||
msgid "All unprocessed webhooks have been stopped from retrying."
|
||||
msgstr ""
|
||||
msgstr "Alle onverwerkte webhooks worden niet meer uitgevoerd."
|
||||
|
||||
#: pretix/control/views/organizer.py:1677
|
||||
msgid "The selected organizer has been invited."
|
||||
msgstr ""
|
||||
msgstr "De geselecteerde organisator is uitgenodigd."
|
||||
|
||||
#: pretix/control/views/organizer.py:1717
|
||||
#: pretix/control/views/organizer.py:1731
|
||||
msgid "The selected connection has been removed."
|
||||
msgstr ""
|
||||
msgstr "De geselecteerde verbinding is verwijderd."
|
||||
|
||||
#: pretix/control/views/organizer.py:1745
|
||||
msgid "The selected connection has been accepted."
|
||||
msgstr ""
|
||||
msgstr "De geselecteerde verbinding is geaccepteerd."
|
||||
|
||||
#: pretix/control/views/organizer.py:1805
|
||||
#: pretix/control/views/organizer.py:1842
|
||||
msgid "Gift cards are not allowed to have negative values."
|
||||
msgstr ""
|
||||
msgstr "Cadeaubonnen kunnen geen negatieve waarde hebben."
|
||||
|
||||
#: pretix/control/views/organizer.py:1832
|
||||
msgid "The transaction could not be reversed."
|
||||
msgstr ""
|
||||
msgstr "De transactie kon niet teruggedraaid worden."
|
||||
|
||||
#: pretix/control/views/organizer.py:1834
|
||||
msgid "The transaction has been reversed."
|
||||
msgstr ""
|
||||
msgstr "De transactie is teruggedraaid."
|
||||
|
||||
#: pretix/control/views/organizer.py:1839
|
||||
msgid "Your input was invalid, please try again."
|
||||
msgstr ""
|
||||
msgstr "Uw invoer was ongeldig, probeer het opnieuw."
|
||||
|
||||
#: pretix/control/views/organizer.py:1859
|
||||
msgid "The manual transaction has been saved."
|
||||
msgstr ""
|
||||
msgstr "De handmatige transactie is opgeslagen."
|
||||
|
||||
#: pretix/control/views/organizer.py:1901
|
||||
msgid "The gift card has been created and can now be used."
|
||||
msgstr ""
|
||||
msgstr "De cadeaubon is aangemaakt en kan nu gebruikt worden."
|
||||
|
||||
#: pretix/control/views/organizer.py:2008
|
||||
msgid "All events (that I have access to)"
|
||||
msgstr ""
|
||||
msgstr "Alle evenementen (waar ik toegang toe heb)"
|
||||
|
||||
#: pretix/control/views/organizer.py:2450
|
||||
msgid "The selected gate has been deleted."
|
||||
msgstr ""
|
||||
msgstr "De geselecteerde ingang is verwijderd."
|
||||
|
||||
#: pretix/control/views/organizer.py:2493
|
||||
msgid "You cannot set a default value that is not a valid value."
|
||||
msgstr ""
|
||||
"U kunt geen standaardwaarde instellen die niet in de lijst met toegestane "
|
||||
"waarden staat."
|
||||
|
||||
#: pretix/control/views/organizer.py:2520
|
||||
msgid "The property has been created."
|
||||
msgstr ""
|
||||
msgstr "De eigenschap is aangemaakt."
|
||||
|
||||
#: pretix/control/views/organizer.py:2587
|
||||
msgid "The selected property has been deleted."
|
||||
msgstr ""
|
||||
msgstr "De geselecteerde eigenschap is verwijderd."
|
||||
|
||||
#: pretix/control/views/organizer.py:2611
|
||||
msgid "The order of properties has been updated."
|
||||
msgstr ""
|
||||
msgstr "De volgorde van eigenschappen is bijgewerkt."
|
||||
|
||||
#: pretix/control/views/organizer.py:2790
|
||||
#: pretix/control/views/organizer.py:2906
|
||||
#: pretix/control/views/organizer.py:3036
|
||||
#: pretix/control/views/organizer.py:3305
|
||||
msgid "The selected object has been deleted."
|
||||
msgstr ""
|
||||
msgstr "Het geselecteerde object is verwijderd."
|
||||
|
||||
#: pretix/control/views/organizer.py:2825
|
||||
msgid "The provider has been created."
|
||||
msgstr ""
|
||||
msgstr "De provider is aangemaakt."
|
||||
|
||||
#: pretix/control/views/organizer.py:2945
|
||||
#, python-brace-format
|
||||
@@ -29902,6 +29948,8 @@ msgid ""
|
||||
"The SSO client has been created. Please note down the following client "
|
||||
"secret, it will never be shown again: {secret}"
|
||||
msgstr ""
|
||||
"De SSO-client is aangemaakt. Noteer de volgende geheime sleutel. Hij wordt "
|
||||
"nooit meer weergegeven: {secret}"
|
||||
|
||||
#: pretix/control/views/organizer.py:2995
|
||||
#, python-brace-format
|
||||
@@ -29909,30 +29957,36 @@ msgid ""
|
||||
"Your changes have been saved. Please note down the following client secret, "
|
||||
"it will never be shown again: {secret}"
|
||||
msgstr ""
|
||||
"Uw wijzigingen zijn opgeslagen. Sla de geheime sleutel veilig op, want hij "
|
||||
"zal hierna nooit meer getoond worden: {secret}"
|
||||
|
||||
#: pretix/control/views/organizer.py:3105
|
||||
msgid ""
|
||||
"We've sent the customer an email with further instructions on resetting your "
|
||||
"password."
|
||||
msgstr ""
|
||||
"We hebben de klant een e-mail gestuurd met verdere instructies om het "
|
||||
"wachtwoord te resetten."
|
||||
|
||||
#: pretix/control/views/organizer.py:3370
|
||||
msgid "The customer account has been anonymized."
|
||||
msgstr ""
|
||||
msgstr "Het klantenaccount is geanonimiseerd."
|
||||
|
||||
#: pretix/control/views/organizer.py:3640
|
||||
msgid "This channel can not be deleted."
|
||||
msgstr ""
|
||||
msgstr "Dit kanaal kan niet verwijderd worden."
|
||||
|
||||
#: pretix/control/views/organizer.py:3645
|
||||
msgid "The selected sales channel has been deleted."
|
||||
msgstr ""
|
||||
msgstr "Het geselecteerde verkoopskanaal is verwijderd."
|
||||
|
||||
#: pretix/control/views/organizer.py:3647
|
||||
msgid ""
|
||||
"The channel could not be deleted as some constraints (e.g. data created by "
|
||||
"plug-ins) did not allow it."
|
||||
msgstr ""
|
||||
"Het kanaal kon niet verwijderd worden, omdat sommige beperkingen (bijv. data "
|
||||
"aangemaakt door plug-ins) het niet toestaan."
|
||||
|
||||
#: pretix/control/views/organizer.py:3672
|
||||
msgid "The order of sales channels has been updated."
|
||||
|
||||
@@ -8,8 +8,8 @@ msgstr ""
|
||||
"Project-Id-Version: PACKAGE VERSION\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2026-03-17 14:05+0000\n"
|
||||
"PO-Revision-Date: 2026-03-11 07:08+0000\n"
|
||||
"Last-Translator: Pedro Orlando <scramblerdoodle@gmail.com>\n"
|
||||
"PO-Revision-Date: 2026-03-25 08:00+0000\n"
|
||||
"Last-Translator: Renne Rocha <renne@rocha.dev.br>\n"
|
||||
"Language-Team: Portuguese (Brazil) <https://translate.pretix.eu/projects/"
|
||||
"pretix/pretix/pt_BR/>\n"
|
||||
"Language: pt_BR\n"
|
||||
@@ -405,10 +405,8 @@ msgstr ""
|
||||
|
||||
#: pretix/api/serializers/organizer.py:482
|
||||
#: pretix/control/views/organizer.py:1039
|
||||
#, fuzzy
|
||||
#| msgid "Account information"
|
||||
msgid "Account invitation"
|
||||
msgstr "Informações da conta"
|
||||
msgstr "Convite de conta"
|
||||
|
||||
#: pretix/api/serializers/organizer.py:503
|
||||
#: pretix/control/views/organizer.py:1138
|
||||
@@ -6840,10 +6838,8 @@ msgstr ""
|
||||
"alguns minutos para entrar em vigor para todos os usuários."
|
||||
|
||||
#: pretix/base/models/organizer.py:378
|
||||
#, fuzzy
|
||||
#| msgid "Event permissions"
|
||||
msgid "All event permissions"
|
||||
msgstr "Permissões de Evento"
|
||||
msgstr "Todas as permissões de evento"
|
||||
|
||||
#: pretix/base/models/organizer.py:379
|
||||
#: pretix/control/templates/pretixcontrol/organizers/team_edit.html:34
|
||||
@@ -6851,10 +6847,8 @@ msgid "Event permissions"
|
||||
msgstr "Permissões de Evento"
|
||||
|
||||
#: pretix/base/models/organizer.py:380
|
||||
#, fuzzy
|
||||
#| msgid "Organizer permissions"
|
||||
msgid "All organizer permissions"
|
||||
msgstr "Permissões de Organizador"
|
||||
msgstr "Todas as permissões de organizador"
|
||||
|
||||
#: pretix/base/models/organizer.py:381
|
||||
#: pretix/control/templates/pretixcontrol/organizers/team_edit.html:25
|
||||
@@ -8352,22 +8346,18 @@ msgstr "Seu arquivo de layout não é um layout válido. Mensagem de erro: {}"
|
||||
#: pretix/base/permissions.py:314 pretix/base/permissions.py:331
|
||||
msgctxt "permission_level"
|
||||
msgid "View"
|
||||
msgstr ""
|
||||
msgstr "Visualizar"
|
||||
|
||||
#: pretix/base/permissions.py:164 pretix/base/permissions.py:169
|
||||
#: pretix/base/permissions.py:174 pretix/base/permissions.py:179
|
||||
#: pretix/base/permissions.py:286 pretix/base/permissions.py:315
|
||||
#, fuzzy
|
||||
#| msgid "Save and check"
|
||||
msgctxt "permission_level"
|
||||
msgid "View and change"
|
||||
msgstr "Salvar e checar"
|
||||
msgstr "Visualizar e alterar"
|
||||
|
||||
#: pretix/base/permissions.py:168
|
||||
#, fuzzy
|
||||
#| msgid "API tokens"
|
||||
msgid "API only"
|
||||
msgstr "Tokens de API"
|
||||
msgstr "Apenas API"
|
||||
|
||||
#: pretix/base/permissions.py:173
|
||||
msgid ""
|
||||
@@ -8377,11 +8367,9 @@ msgstr ""
|
||||
#: pretix/base/permissions.py:177 pretix/base/permissions.py:231
|
||||
#: pretix/base/permissions.py:285 pretix/base/permissions.py:313
|
||||
#: pretix/base/permissions.py:330
|
||||
#, fuzzy
|
||||
#| msgid "Revoke access"
|
||||
msgctxt "permission_level"
|
||||
msgid "No access"
|
||||
msgstr "Revogar acesso"
|
||||
msgstr "Sem acesso"
|
||||
|
||||
#: pretix/base/permissions.py:188
|
||||
#: pretix/control/templates/pretixcontrol/event/settings.html:7
|
||||
@@ -8408,10 +8396,8 @@ msgid "Tax settings"
|
||||
msgstr "Configurações de impostos"
|
||||
|
||||
#: pretix/base/permissions.py:209
|
||||
#, fuzzy
|
||||
#| msgid "Invoice settings"
|
||||
msgid "Invoicing settings"
|
||||
msgstr "Configurações de fatura"
|
||||
msgstr "Configurações de faturamento"
|
||||
|
||||
#: pretix/base/permissions.py:215
|
||||
#, fuzzy
|
||||
@@ -8421,52 +8407,40 @@ msgid "Event series dates"
|
||||
msgstr "Data da série de eventos adicionada"
|
||||
|
||||
#: pretix/base/permissions.py:221
|
||||
#, fuzzy
|
||||
#| msgid "Product name and variation"
|
||||
msgid "Products, quotas and questions"
|
||||
msgstr "Nome do produto e variação"
|
||||
msgstr "Produtos, cotas e perguntas"
|
||||
|
||||
#: pretix/base/permissions.py:224
|
||||
msgid "Also includes related objects like categories or discounts."
|
||||
msgstr ""
|
||||
|
||||
#: pretix/base/permissions.py:232
|
||||
#, fuzzy
|
||||
#| msgid "All check-ins"
|
||||
msgctxt "permission_level"
|
||||
msgid "Only check-in"
|
||||
msgstr "Todos os check-ins"
|
||||
msgstr "Apenas check-in"
|
||||
|
||||
#: pretix/base/permissions.py:233
|
||||
#, fuzzy
|
||||
#| msgid "View full log"
|
||||
msgctxt "permission_level"
|
||||
msgid "View all"
|
||||
msgstr "Ver log completo"
|
||||
msgstr "Visualizar tudo"
|
||||
|
||||
#: pretix/base/permissions.py:234
|
||||
#, fuzzy
|
||||
#| msgid "Valid check-in"
|
||||
msgctxt "permission_level"
|
||||
msgid "View all and check-in"
|
||||
msgstr "Check-in válido"
|
||||
msgstr "Visualizar tudo e check-in"
|
||||
|
||||
#: pretix/base/permissions.py:235
|
||||
#, fuzzy
|
||||
#| msgid "View all upcoming events"
|
||||
msgctxt "permission_level"
|
||||
msgid "View all and change"
|
||||
msgstr "Ver todos eventos futuros"
|
||||
msgstr "Visualizar tudo e alterar"
|
||||
|
||||
#: pretix/base/permissions.py:236
|
||||
msgid "Includes the ability to cancel and refund individual orders."
|
||||
msgstr ""
|
||||
msgstr "Incluir a habilidade de cancelar e reembolsar pedidos individuais."
|
||||
|
||||
#: pretix/base/permissions.py:238
|
||||
#, fuzzy
|
||||
#| msgid "An entry has been added to the waiting list."
|
||||
msgid "Also includes related objects like the waiting list."
|
||||
msgstr "Uma entrada foi adicionada à lista de espera."
|
||||
msgstr "Também inclui objetos relacionados como a lista de espera."
|
||||
|
||||
#: pretix/base/permissions.py:248
|
||||
#, fuzzy
|
||||
@@ -8475,18 +8449,14 @@ msgid "Full event or date cancellation"
|
||||
msgstr "Gerar cancelamento"
|
||||
|
||||
#: pretix/base/permissions.py:252
|
||||
#, fuzzy
|
||||
#| msgid "Sale not allowed"
|
||||
msgctxt "permission_level"
|
||||
msgid "Not allowed"
|
||||
msgstr "Venda não permitida"
|
||||
msgstr "Não permitida"
|
||||
|
||||
#: pretix/base/permissions.py:253
|
||||
#, fuzzy
|
||||
#| msgid "Allowed titles"
|
||||
msgctxt "permission_level"
|
||||
msgid "Allowed"
|
||||
msgstr "Títulos permitidos"
|
||||
msgstr "Permitida"
|
||||
|
||||
#: pretix/base/permissions.py:268
|
||||
msgctxt "permission_level"
|
||||
@@ -23995,7 +23965,7 @@ msgstr "Reembolso por pagamento em excesso"
|
||||
#: pretix/control/templates/pretixcontrol/order/index.html:118
|
||||
#, python-format
|
||||
msgid "This order is currently overpaid by %(amount)s."
|
||||
msgstr "O pedidos está pago em excesso por %(amount)s."
|
||||
msgstr "Este pedido está pago em excesso por %(amount)s."
|
||||
|
||||
#: pretix/control/templates/pretixcontrol/order/index.html:122
|
||||
#, python-format
|
||||
@@ -33294,7 +33264,7 @@ msgstr "iDEAL via Stripe"
|
||||
|
||||
#: pretix/plugins/stripe/payment.py:1572
|
||||
msgid "iDEAL | Wero"
|
||||
msgstr ""
|
||||
msgstr "iDEAL | Wero"
|
||||
|
||||
#: pretix/plugins/stripe/payment.py:1575
|
||||
msgid ""
|
||||
|
||||
@@ -8,7 +8,7 @@ msgstr ""
|
||||
"Project-Id-Version: PACKAGE VERSION\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2026-03-17 14:06+0000\n"
|
||||
"PO-Revision-Date: 2026-01-26 22:00+0000\n"
|
||||
"PO-Revision-Date: 2026-03-25 08:00+0000\n"
|
||||
"Last-Translator: Renne Rocha <renne@rocha.dev.br>\n"
|
||||
"Language-Team: Portuguese (Brazil) <https://translate.pretix.eu/projects/"
|
||||
"pretix/pretix-js/pt_BR/>\n"
|
||||
@@ -17,7 +17,7 @@ msgstr ""
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
"Content-Transfer-Encoding: 8bit\n"
|
||||
"Plural-Forms: nplurals=2; plural=n > 1;\n"
|
||||
"X-Generator: Weblate 5.15.2\n"
|
||||
"X-Generator: Weblate 5.16.2\n"
|
||||
|
||||
#: pretix/plugins/banktransfer/static/pretixplugins/banktransfer/ui.js:56
|
||||
#: pretix/plugins/banktransfer/static/pretixplugins/banktransfer/ui.js:62
|
||||
@@ -60,7 +60,7 @@ msgstr "PayPal Pay Later"
|
||||
|
||||
#: pretix/plugins/paypal2/static/pretixplugins/paypal2/pretix-paypal.js:41
|
||||
msgid "iDEAL | Wero"
|
||||
msgstr ""
|
||||
msgstr "iDEAL | Wero"
|
||||
|
||||
#: pretix/plugins/paypal2/static/pretixplugins/paypal2/pretix-paypal.js:42
|
||||
msgid "SEPA Direct Debit"
|
||||
|
||||
@@ -8,7 +8,7 @@ msgstr ""
|
||||
"Project-Id-Version: PACKAGE VERSION\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2026-03-17 14:05+0000\n"
|
||||
"PO-Revision-Date: 2026-01-16 22:00+0000\n"
|
||||
"PO-Revision-Date: 2026-03-27 09:03+0000\n"
|
||||
"Last-Translator: Linnea Thelander <linnea@coeo.events>\n"
|
||||
"Language-Team: Swedish <https://translate.pretix.eu/projects/pretix/pretix/"
|
||||
"sv/>\n"
|
||||
@@ -17,7 +17,7 @@ msgstr ""
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
"Content-Transfer-Encoding: 8bit\n"
|
||||
"Plural-Forms: nplurals=2; plural=n != 1;\n"
|
||||
"X-Generator: Weblate 5.15.2\n"
|
||||
"X-Generator: Weblate 5.16.2\n"
|
||||
|
||||
#: pretix/_base_settings.py:87
|
||||
msgid "English"
|
||||
@@ -35279,10 +35279,8 @@ msgid "We're now trying to book these add-ons for you!"
|
||||
msgstr "Vi försöker nu reservera dessa tillval till dig!"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/checkout_addons.html:28
|
||||
#, fuzzy
|
||||
#| msgid "Additional settings"
|
||||
msgid "Additional options for"
|
||||
msgstr "Ytterligare inställningar"
|
||||
msgstr "Ytterligare val för"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/checkout_addons.html:60
|
||||
#, fuzzy
|
||||
@@ -35628,13 +35626,10 @@ msgstr[0] "Du måste välja exakt ett alternativ från denna kategori."
|
||||
msgstr[1] "Du måste välja %(min_count)s alternativ från denna kategori."
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/fragment_addon_choice.html:26
|
||||
#, fuzzy, python-format
|
||||
#| msgid "You can choose %(max_count)s option from this category."
|
||||
#| msgid_plural ""
|
||||
#| "You can choose up to %(max_count)s options from this category."
|
||||
#, python-format
|
||||
msgid "You can choose one option from this category."
|
||||
msgid_plural "You can choose up to %(max_count)s options from this category."
|
||||
msgstr[0] "Du kan välja %(max_count)s alternativ från denna kategori."
|
||||
msgstr[0] "Du kan välja ett alternativ från denna kategori."
|
||||
msgstr[1] "Du kan välja upp till %(max_count)s alternativ från denna kategori."
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/fragment_addon_choice.html:34
|
||||
@@ -36329,12 +36324,11 @@ msgstr "Visa fullstor bild av %(item)s"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/fragment_product_list.html:131
|
||||
#: pretix/presale/templates/pretixpresale/event/fragment_product_list.html:288
|
||||
#, fuzzy, python-format
|
||||
#| msgid "%(count)s elements"
|
||||
#, python-format
|
||||
msgid "%(amount)s× in your cart"
|
||||
msgid_plural "%(amount)s× in your cart"
|
||||
msgstr[0] "%(count)s element"
|
||||
msgstr[1] "%(count)s element"
|
||||
msgstr[0] "%(amount)sx i din kundvagn"
|
||||
msgstr[1] "%(amount)sx i din kundvagn"
|
||||
|
||||
#: pretix/presale/templates/pretixpresale/event/fragment_product_list.html:209
|
||||
#: pretix/presale/templates/pretixpresale/event/fragment_product_list.html:374
|
||||
|
||||
@@ -8,7 +8,7 @@ msgstr ""
|
||||
"Project-Id-Version: PACKAGE VERSION\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"POT-Creation-Date: 2026-03-17 14:06+0000\n"
|
||||
"PO-Revision-Date: 2025-10-10 17:00+0000\n"
|
||||
"PO-Revision-Date: 2026-03-26 14:29+0000\n"
|
||||
"Last-Translator: Linnea Thelander <linnea@coeo.events>\n"
|
||||
"Language-Team: Swedish <https://translate.pretix.eu/projects/pretix/pretix-"
|
||||
"js/sv/>\n"
|
||||
@@ -17,7 +17,7 @@ msgstr ""
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
"Content-Transfer-Encoding: 8bit\n"
|
||||
"Plural-Forms: nplurals=2; plural=n != 1;\n"
|
||||
"X-Generator: Weblate 5.13.3\n"
|
||||
"X-Generator: Weblate 5.16.2\n"
|
||||
|
||||
#: pretix/plugins/banktransfer/static/pretixplugins/banktransfer/ui.js:56
|
||||
#: pretix/plugins/banktransfer/static/pretixplugins/banktransfer/ui.js:62
|
||||
@@ -1023,7 +1023,6 @@ msgid "Waiting list"
|
||||
msgstr "Väntelista"
|
||||
|
||||
#: pretix/static/pretixpresale/js/widget/widget.js:55
|
||||
#, fuzzy
|
||||
msgctxt "widget"
|
||||
msgid ""
|
||||
"You currently have an active cart for this event. If you select more "
|
||||
|
||||
@@ -576,7 +576,7 @@ def filter_subevents_with_plugins(subevents, sales_channel=None):
|
||||
if not app_cache:
|
||||
_populate_app_cache()
|
||||
|
||||
for receiver in filter_subevents._live_receivers(None):
|
||||
for receiver in filter_subevents._live_receivers(None)[0]:
|
||||
app = get_defining_app(receiver)
|
||||
event_state = {}
|
||||
|
||||
|
||||
@@ -49,7 +49,7 @@ from django.views.decorators.cache import cache_page
|
||||
from django.views.decorators.gzip import gzip_page
|
||||
from django.views.decorators.http import condition
|
||||
from django.views.i18n import (
|
||||
JavaScriptCatalog, get_formats, js_catalog_template,
|
||||
JavaScriptCatalog, builtin_template_path, get_formats,
|
||||
)
|
||||
from lxml import html
|
||||
|
||||
@@ -170,7 +170,8 @@ def generate_widget_js(version, lang):
|
||||
'September', 'October', 'November', 'December'
|
||||
)
|
||||
catalog = dict((k, v) for k, v in catalog.items() if k.startswith('widget\u0004') or k in str_wl)
|
||||
template = Engine().from_string(js_catalog_template)
|
||||
with builtin_template_path("i18n_catalog.js").open(encoding="utf-8") as fh:
|
||||
template = Engine().from_string(fh.read())
|
||||
context = Context({
|
||||
'catalog_str': indent(json.dumps(
|
||||
catalog, sort_keys=True, indent=2)) if catalog else None,
|
||||
|
||||
@@ -534,6 +534,7 @@ X_FRAME_OPTIONS = 'DENY'
|
||||
|
||||
# URL settings
|
||||
ROOT_URLCONF = 'pretix.multidomain.maindomain_urlconf'
|
||||
FORMS_URLFIELD_ASSUME_HTTPS = True # transitional for django 6.0
|
||||
|
||||
WSGI_APPLICATION = 'pretix.wsgi.application'
|
||||
|
||||
|
||||
@@ -23,9 +23,7 @@ filterwarnings =
|
||||
error
|
||||
ignore:.*invalid escape sequence.*:
|
||||
ignore:The 'warn' method is deprecated:DeprecationWarning
|
||||
ignore::django.utils.deprecation.RemovedInDjango51Warning:django.core.files.storage
|
||||
ignore:.*index_together.*:django.utils.deprecation.RemovedInDjango51Warning:
|
||||
ignore:.*get_storage_class.*:django.utils.deprecation.RemovedInDjango51Warning:compressor
|
||||
ignore::django.utils.deprecation.RemovedInDjango60Warning:
|
||||
ignore:.*This signal will soon be only available for plugins that declare to be organizer-level.*:DeprecationWarning:
|
||||
ignore::DeprecationWarning:mt940
|
||||
ignore::DeprecationWarning:cbor2
|
||||
|
||||
@@ -19,14 +19,13 @@
|
||||
# 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 datetime import datetime, timedelta
|
||||
from datetime import datetime, timedelta, timezone
|
||||
|
||||
import aiohttp
|
||||
import pytest
|
||||
import pytest_asyncio
|
||||
from django.utils.timezone import now
|
||||
from django_scopes import scopes_disabled
|
||||
from pytz import UTC
|
||||
|
||||
from pretix.base.models import (
|
||||
Device, Event, Item, Organizer, Quota, SeatingPlan,
|
||||
@@ -53,7 +52,7 @@ def organizer():
|
||||
def event(organizer):
|
||||
e = Event.objects.create(
|
||||
organizer=organizer, name='Dummy', slug='dummy',
|
||||
date_from=datetime(2017, 12, 27, 10, 0, 0, tzinfo=UTC),
|
||||
date_from=datetime(2017, 12, 27, 10, 0, 0, tzinfo=timezone.utc),
|
||||
presale_end=now() + timedelta(days=300),
|
||||
plugins='pretix.plugins.banktransfer,pretix.plugins.ticketoutputpdf',
|
||||
is_public=True, live=True
|
||||
@@ -109,8 +108,8 @@ def customer(event, membership_type):
|
||||
def membership(event, membership_type, customer):
|
||||
return customer.memberships.create(
|
||||
membership_type=membership_type,
|
||||
date_start=datetime(2017, 1, 1, 0, 0, tzinfo=UTC),
|
||||
date_end=datetime(2099, 1, 1, 0, 0, tzinfo=UTC),
|
||||
date_start=datetime(2017, 1, 1, 0, 0, tzinfo=timezone.utc),
|
||||
date_end=datetime(2099, 1, 1, 0, 0, tzinfo=timezone.utc),
|
||||
)
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user