Compare commits

..

No commits in common. "45e5c2e44decd72c5255024f93fdf46977ffa4a2" and "7ec4325973d13e5e8fb9829cdcbcd17b34977b08" have entirely different histories.

227 changed files with 3458 additions and 6602 deletions

View File

@ -24,14 +24,20 @@ exclude: |
)
repos:
# Code Upgrades
- repo: https://github.com/astral-sh/ruff-pre-commit
rev: v0.9.9
hooks:
# Run the linter, and only the linter
- id: ruff
- repo: https://github.com/adamchainz/django-upgrade
rev: 1.25.0
rev: 1.23.1
hooks:
- id: django-upgrade
args: [--target-version=5.2]
- repo: https://github.com/asottile/pyupgrade
rev: v3.20.0
args: [--target-version=5.1]
- repo: https://github.com/asottile/pyupgrade # Ruff doesnt get everything.
rev: v3.19.1
hooks:
- id: pyupgrade
args: [--py310-plus]
@ -67,31 +73,30 @@ repos:
- id: check-executables-have-shebangs
- id: end-of-file-fixer
- repo: https://github.com/editorconfig-checker/editorconfig-checker.python
rev: 3.2.1
rev: 3.2.0
hooks:
- id: editorconfig-checker
- repo: https://github.com/igorshubovych/markdownlint-cli
rev: v0.45.0
rev: v0.44.0
hooks:
- id: markdownlint
language: node
args:
- --disable=MD013
# Infrastructure
- repo: https://github.com/tox-dev/pyproject-fmt
rev: v2.6.0
rev: v2.5.1
hooks:
- id: pyproject-fmt
args:
- --indent=4
additional_dependencies:
- tox==4.26.0 # https://github.com/tox-dev/tox/releases/latest
- tox==4.24.1 # https://github.com/tox-dev/tox/releases/latest
- repo: https://github.com/tox-dev/tox-ini-fmt
rev: 1.5.0
hooks:
- id: tox-ini-fmt
- repo: https://github.com/abravalheri/validate-pyproject
rev: v0.24.1
rev: v0.23
hooks:
- id: validate-pyproject

View File

@ -1,15 +1,15 @@
# Alliance Auth
[![License](https://img.shields.io/badge/license-GPLv2-green)](https://pypi.org/project/allianceauth/)
[![Python Versions](https://img.shields.io/pypi/pyversions/allianceauth)](https://pypi.org/project/allianceauth/)
[![Django Versions](https://img.shields.io/pypi/djversions/allianceauth?label=django)](https://pypi.org/project/allianceauth/)
[![Stable AA Version](https://img.shields.io/pypi/v/allianceauth?label=release)](https://pypi.org/project/allianceauth/)
[![Pipeline Status](https://gitlab.com/allianceauth/allianceauth/badges/master/pipeline.svg)](https://gitlab.com/allianceauth/allianceauth/commits/master)
[![license](https://img.shields.io/badge/license-GPLv2-green)](https://pypi.org/project/allianceauth/)
[![python](https://img.shields.io/pypi/pyversions/allianceauth)](https://pypi.org/project/allianceauth/)
[![django](https://img.shields.io/pypi/djversions/allianceauth?label=django)](https://pypi.org/project/allianceauth/)
[![version](https://img.shields.io/pypi/v/allianceauth?label=release)](https://pypi.org/project/allianceauth/)
[![pipeline status](https://gitlab.com/allianceauth/allianceauth/badges/master/pipeline.svg)](https://gitlab.com/allianceauth/allianceauth/commits/master)
[![Documentation Status](https://readthedocs.org/projects/allianceauth/badge/?version=latest)](https://allianceauth.readthedocs.io/?badge=latest)
[![Test Coverage Report](https://gitlab.com/allianceauth/allianceauth/badges/master/coverage.svg)](https://gitlab.com/allianceauth/allianceauth/commits/master)
[![coverage report](https://gitlab.com/allianceauth/allianceauth/badges/master/coverage.svg)](https://gitlab.com/allianceauth/allianceauth/commits/master)
[![Chat on Discord](https://img.shields.io/discord/399006117012832262.svg)](https://discord.gg/fjnHAmk)
A flexible authentication platform for EVE Online to help in-game organizations manage access to applications and services. AA provides both, a stable core, and a robust framework for community development and custom applications.
An auth system for EVE Online to help in-game organizations manage online service access.
## Content
@ -22,17 +22,17 @@ A flexible authentication platform for EVE Online to help in-game organizations
## Overview
Alliance Auth (AA) is a platform that helps Eve Online organizations efficiently manage access to applications and services.
Alliance Auth (AA) is a web site that helps Eve Online organizations efficiently manage access to applications and services.
Main features:
- Automatically grants or revokes user access to external services (e.g.: Discord, Mumble) based on the user's current membership to [a variety of EVE Online affiliation](https://allianceauth.readthedocs.io/en/latest/features/core/states/) and [groups](https://allianceauth.readthedocs.io/en/latest/features/core/groups/)
- Automatically grants or revokes user access to external services (e.g. Discord, Mumble) and web apps (e.g. SRP requests) based on the user's current membership to [in-game organizations](https://allianceauth.readthedocs.io/en/latest/features/core/states/) and [groups](https://allianceauth.readthedocs.io/en/latest/features/core/groups/)
- Provides a central web site where users can directly access web apps (e.g. SRP requests, Fleet Schedule) and manage their access to external services and groups.
- Includes a set of connectors (called ["Services"](https://allianceauth.readthedocs.io/en/latest/features/services/)) for integrating access management with many popular external applications / services like Discord, Mumble, Teamspeak 3, SMF and others
- Includes a set of connectors (called ["services"](https://allianceauth.readthedocs.io/en/latest/features/services/)) for integrating access management with many popular external applications / services like Discord, Mumble, Teamspeak 3, SMF and others
- Includes a set of web [Apps](https://allianceauth.readthedocs.io/en/latest/features/apps/) which add many useful functions, e.g.: fleet schedule, timer board, SRP request management, fleet activity tracker
- Includes a set of web [apps](https://allianceauth.readthedocs.io/en/latest/features/apps/) which add many useful functions, e.g.: fleet schedule, timer board, SRP request management, fleet activity tracker
- Can be easily extended with additional services and apps. Many are provided by the community and can be found here: [Community Creations](https://gitlab.com/allianceauth/community-creations)
@ -42,15 +42,9 @@ For further details about AA - including an installation guide and a full list o
## Screenshot
Here is an example of the Alliance Auth web site with a mixture of Services, Apps and Community Creations enabled:
Here is an example of the Alliance Auth web site with some plug-ins apps and services enabled:
### Flatly Theme
![Flatly Theme](docs/_static/images/promotion/SampleInstallation-Flatly.png)
### Darkly Theme
![Darkly Theme](docs/_static/images/promotion/SampleInstallation-Darkly.png)
![screenshot](https://i.imgur.com/2tnX9kD.png)
## Support

View File

@ -5,7 +5,7 @@ manage online service access.
# This will make sure the app is always imported when
# Django starts so that shared_task will use this app.
__version__ = '5.0.0a3'
__title__ = 'AllianceAuth'
__version__ = '5.0.0a1'
__title__ = 'Alliance Auth'
__url__ = 'https://gitlab.com/allianceauth/allianceauth'
NAME = f'{__title__} v{__version__}'

View File

@ -1,19 +0,0 @@
"""Admin site for admin status applicaton"""
from django.contrib import admin
from allianceauth.admin_status.models import ApplicationAnnouncement
@admin.register(ApplicationAnnouncement)
class ApplicationAnnouncementAdmin(admin.ModelAdmin):
list_display = ["application_name", "announcement_number", "announcement_text", "hide_announcement"]
list_filter = ["hide_announcement"]
ordering = ["application_name", "announcement_number"]
readonly_fields = ["application_name", "announcement_number", "announcement_text", "announcement_url"]
fields = ["application_name", "announcement_number", "announcement_text", "announcement_url", "hide_announcement"]
def has_add_permission(self, request):
return False
def has_delete_permission(self, request, obj=None):
return False

View File

@ -1,6 +0,0 @@
from django.apps import AppConfig
class AdminStatusApplication(AppConfig):
name = 'allianceauth.admin_status'
label = 'admin_status'

View File

@ -1,207 +0,0 @@
import hashlib
import logging
from dataclasses import dataclass
from enum import Enum
from urllib.parse import quote_plus
import requests
from django.core.cache import cache
from allianceauth.hooks import get_hooks, register
logger = logging.getLogger(__name__)
# timeout for all requests
REQUESTS_TIMEOUT = 5 # 5 seconds
# max pages to be fetched from gitlab
MAX_PAGES = 50
# Cache time
NOTIFICATION_CACHE_TIME = 300 # 5 minutes
@dataclass
class Announcement:
"""
Dataclass storing all data for an announcement to be sent arround
"""
application_name: str
announcement_url: str
announcement_number: int
announcement_text: str
@classmethod
def build_from_gitlab_issue_dict(cls, application_name: str, gitlab_issue: dict) -> "Announcement":
"""Builds the announcement from the JSON dict of a GitLab issue"""
return Announcement(application_name, gitlab_issue["web_url"], gitlab_issue["iid"], gitlab_issue["title"])
@classmethod
def build_from_github_issue_dict(cls, application_name: str, github_issue: dict) -> "Announcement":
"""Builds the announcement from the JSON dict of a GitHub issue"""
return Announcement(application_name, github_issue["html_url"], github_issue["number"], github_issue["title"])
def get_hash(self):
"""Get a hash of the Announcement for comparison"""
name = f"{self.application_name}.{self.announcement_number}"
hash_value = hashlib.sha256(name.encode("utf-8")).hexdigest()
return hash_value
@dataclass
class AppAnnouncementHook:
"""
A hook for an application to send GitHub/GitLab issues as announcements on the dashboard
Args:
- app_name: The name of your application
- repository_namespace: The namespace of the remote repository of your application source code.
It should look like `<username>/<application_name>`.
- repository_kind: Enumeration to determine if your repository is a GitHub or GitLab repository.
- label: The label applied to issues that should be seen as announcements, case-sensitive.
Default value: `announcement`
"""
class Service(Enum):
"""Simple enumeration to determine which api should be called to access issues"""
GITLAB = "gitlab"
GITHUB = "github"
app_name: str
repository_namespace: str
repository_kind: Service
label: str = "announcement"
def get_announcement_list(self) -> list[Announcement]:
"""
Checks the application repository to find issues with the `Announcement` tag and return their title and link to
be displayed.
"""
logger.debug("Getting announcement list for the app %s", self.app_name)
match self.repository_kind:
case AppAnnouncementHook.Service.GITHUB:
announcement_list = self._get_github_announcement_list()
case AppAnnouncementHook.Service.GITLAB:
announcement_list = self._get_gitlab_announcement_list()
case _:
announcement_list = []
logger.debug("Announcements for app %s: %s", self.app_name, announcement_list)
return announcement_list
def _get_github_announcement_list(self) -> list[Announcement]:
"""
Return the issue list for a GitHub repository
Will filter if the `pull_request` attribute is present
"""
raw_list = _fetch_list_from_github(
f"https://api.github.com/repos/{self.repository_namespace}/issues"
f"?labels={self.label}"
)
return [Announcement.build_from_github_issue_dict(self.app_name, github_issue) for github_issue in raw_list]
def _get_gitlab_announcement_list(self) -> list[Announcement]:
"""Return the issues list for a GitLab repository"""
raw_list = _fetch_list_from_gitlab(
f"https://gitlab.com/api/v4/projects/{quote_plus(self.repository_namespace)}/issues"
f"?labels={self.label}&state=opened")
return [Announcement.build_from_gitlab_issue_dict(self.app_name, gitlab_issue) for gitlab_issue in raw_list]
@register("app_announcement_hook")
def alliance_auth_announcements_hook():
return AppAnnouncementHook("AllianceAuth", "allianceauth/allianceauth", AppAnnouncementHook.Service.GITLAB)
def get_all_applications_announcements() -> list[Announcement]:
"""
Retrieve all known application announcements and returns them
"""
application_notifications = []
hooks = [fn() for fn in get_hooks("app_announcement_hook")]
for hook in hooks:
logger.debug(hook)
try:
application_notifications.extend(cache.get_or_set(
f"{hook.app_name}_notification_issues",
hook.get_announcement_list,
NOTIFICATION_CACHE_TIME,
))
except requests.HTTPError:
logger.warning("Error when getting %s notifications", hook, exc_info=True)
logger.debug(application_notifications)
if application_notifications:
application_notifications = application_notifications[:10]
return application_notifications
def _fetch_list_from_gitlab(url: str, max_pages: int = MAX_PAGES) -> list:
"""returns a list from the GitLab API. Supports paging"""
result = []
for page in range(1, max_pages + 1):
try:
request = requests.get(
url, params={'page': page}, timeout=REQUESTS_TIMEOUT
)
request.raise_for_status()
except requests.exceptions.RequestException as e:
error_str = str(e)
logger.warning(
f'Unable to fetch from GitLab API. Error: {error_str}',
exc_info=True,
)
return result
result += request.json()
if 'x-total-pages' in request.headers:
try:
total_pages = int(request.headers['x-total-pages'])
except ValueError:
total_pages = None
else:
total_pages = None
if not total_pages or page >= total_pages:
break
return result
def _fetch_list_from_github(url: str, max_pages: int = MAX_PAGES) -> list:
"""returns a list from the GitHub API. Supports paging"""
result = []
for page in range(1, max_pages+1):
try:
request = requests.get(
url,
params={'page': page},
headers={
"Accept": "application/vnd.github+json",
"X-GitHub-Api-Version": "2022-11-28"
},
timeout=REQUESTS_TIMEOUT,
)
request.raise_for_status()
except requests.exceptions.RequestException as e:
error_str = str(e)
logger.warning(
f'Unable to fetch from GitHub API. Error: {error_str}',
exc_info=True,
)
return result
result += request.json()
logger.debug(request.json())
# https://docs.github.com/en/rest/using-the-rest-api/using-pagination-in-the-rest-api?apiVersion=2022-11-28
# See Example creating a pagination method
if not ('link' in request.headers and 'rel=\"next\"' in request.headers['link']):
break
return result

View File

@ -1,57 +0,0 @@
from typing import TYPE_CHECKING
from django.db import models
from allianceauth.admin_status.hooks import (
Announcement,
get_all_applications_announcements,
)
from allianceauth.services.hooks import get_extension_logger
if TYPE_CHECKING:
from .models import ApplicationAnnouncement
logger = get_extension_logger(__name__)
class ApplicationAnnouncementManager(models.Manager):
def sync_and_return(self):
"""
Checks all hooks if new notifications need to be created.
Return all notification objects after
"""
logger.info("Syncing announcements")
current_announcements = get_all_applications_announcements()
self._delete_obsolete_announcements(current_announcements)
self._store_new_announcements(current_announcements)
return self.all()
def _delete_obsolete_announcements(self, current_announcements: list[Announcement]):
"""Deletes all announcements stored in the database that aren't retrieved anymore"""
hashes = [announcement.get_hash() for announcement in current_announcements]
self.exclude(announcement_hash__in=hashes).delete()
def _store_new_announcements(self, current_announcements: list[Announcement]):
"""Stores a new database object for new application announcements"""
for current_announcement in current_announcements:
try:
announcement = self.get(announcement_hash=current_announcement.get_hash())
except self.model.DoesNotExist:
self.create_from_announcement(current_announcement)
else:
# if exists update the text only
if announcement.announcement_text != current_announcement.announcement_text:
announcement.announcement_text = current_announcement.announcement_text
announcement.save()
def create_from_announcement(self, announcement: Announcement) -> "ApplicationAnnouncement":
"""Creates from the Announcement dataclass"""
return self.create(
application_name=announcement.application_name,
announcement_number=announcement.announcement_number,
announcement_text=announcement.announcement_text,
announcement_url=announcement.announcement_url,
announcement_hash=announcement.get_hash(),
)

View File

@ -1,33 +0,0 @@
# Generated by Django 5.1.9 on 2025-05-18 15:43
import django.db.models.manager
from django.db import migrations, models
class Migration(migrations.Migration):
initial = True
dependencies = [
]
operations = [
migrations.CreateModel(
name='ApplicationAnnouncement',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('application_name', models.CharField(help_text='Name of the application that issued the announcement', max_length=50)),
('announcement_number', models.IntegerField(help_text='Issue number on the notification source')),
('announcement_text', models.TextField(help_text='Issue title text displayed on the dashboard', max_length=300)),
('announcement_url', models.TextField(max_length=200)),
('announcement_hash', models.CharField(default=None, editable=False, help_text='hash of an announcement. Must be nullable for unique comparison.', max_length=64, null=True, unique=True)),
('hide_announcement', models.BooleanField(default=False, help_text='Set to true if the announcement should not be displayed on the dashboard')),
],
options={
'constraints': [models.UniqueConstraint(fields=('application_name', 'announcement_number'), name='functional_pk_applicationissuenumber')],
},
managers=[
('object', django.db.models.manager.Manager()),
],
),
]

View File

@ -1,45 +0,0 @@
from django.db import models
from django.utils.translation import gettext_lazy as _
from allianceauth.admin_status.managers import ApplicationAnnouncementManager
class ApplicationAnnouncement(models.Model):
"""
Announcement originating from an application
"""
object = ApplicationAnnouncementManager()
application_name = models.CharField(max_length=50, help_text=_("Name of the application that issued the announcement"))
announcement_number = models.IntegerField(help_text=_("Issue number on the notification source"))
announcement_text = models.TextField(max_length=300, help_text=_("Issue title text displayed on the dashboard"))
announcement_url = models.TextField(max_length=200)
announcement_hash = models.CharField(
max_length=64,
default=None,
unique=True,
editable=False,
help_text="hash of an announcement."
)
hide_announcement = models.BooleanField(
default=False,
help_text=_("Set to true if the announcement should not be displayed on the dashboard")
)
class Meta:
# Should be updated to a composite key when the switch to Django 5.2 is made
# https://docs.djangoproject.com/en/5.2/topics/composite-primary-key/
constraints = [
models.UniqueConstraint(
fields=["application_name", "announcement_number"], name="functional_pk_applicationissuenumber"
)
]
def __str__(self):
return f"{self.application_name} announcement #{self.announcement_number}"
def is_hidden(self) -> bool:
"""Function in case rules are made in the future to force hide/force show some announcements"""
return self.hide_announcement

View File

@ -1,194 +0,0 @@
import requests_mock
from allianceauth.admin_status.hooks import Announcement
from allianceauth.services.hooks import AppAnnouncementHook
from allianceauth.utils.testing import NoSocketsTestCase
class TestHooks(NoSocketsTestCase):
@requests_mock.mock()
def test_fetch_gitlab(self, requests_mocker):
# given
announcement_hook = AppAnnouncementHook("test GitLab app", "r0kym/allianceauth-example-plugin",
AppAnnouncementHook.Service.GITLAB)
requests_mocker.get(
"https://gitlab.com/api/v4/projects/r0kym%2Fallianceauth-example-plugin/issues?labels=announcement&state=opened",
json=[
{
"id": 166279127,
"iid": 1,
"project_id": 67653102,
"title": "Test GitLab issue",
"description": "Test issue",
"state": "opened",
"created_at": "2025-04-20T21:26:57.914Z",
"updated_at": "2025-04-21T11:04:30.501Z",
"closed_at": None,
"closed_by": None,
"labels": [
"announcement"
],
"milestone": None,
"assignees": [],
"author": {
"id": 14491514,
"username": "r0kym",
"public_email": "",
"name": "T'rahk Rokym",
"state": "active",
"locked": False,
"avatar_url": "https://gitlab.com/uploads/-/system/user/avatar/14491514/avatar.png",
"web_url": "https://gitlab.com/r0kym"
},
"type": "ISSUE",
"assignee": None,
"user_notes_count": 0,
"merge_requests_count": 0,
"upvotes": 0,
"downvotes": 0,
"due_date": None,
"confidential": False,
"discussion_locked": None,
"issue_type": "issue",
"web_url": "https://gitlab.com/r0kym/allianceauth-example-plugin/-/issues/1",
"time_stats": {
"time_estimate": 0,
"total_time_spent": 0,
"human_time_estimate": None,
"human_total_time_spent": None
},
"task_completion_status": {
"count": 0,
"completed_count": 0
},
"blocking_issues_count": 0,
"has_tasks": True,
"task_status": "0 of 0 checklist items completed",
"_links": {
"self": "https://gitlab.com/api/v4/projects/67653102/issues/1",
"notes": "https://gitlab.com/api/v4/projects/67653102/issues/1/notes",
"award_emoji": "https://gitlab.com/api/v4/projects/67653102/issues/1/award_emoji",
"project": "https://gitlab.com/api/v4/projects/67653102",
"closed_as_duplicate_of": None
},
"references": {
"short": "#1",
"relative": "#1",
"full": "r0kym/allianceauth-example-plugin#1"
},
"severity": "UNKNOWN",
"moved_to_id": None,
"imported": False,
"imported_from": "none",
"service_desk_reply_to": None
}
]
)
# when
announcements = announcement_hook.get_announcement_list()
# then
self.assertEqual(len(announcements), 1)
self.assertIn(Announcement(
application_name="test GitLab app",
announcement_url="https://gitlab.com/r0kym/allianceauth-example-plugin/-/issues/1",
announcement_number=1,
announcement_text="Test GitLab issue"
), announcements)
@requests_mock.mock()
def test_fetch_github(self, requests_mocker):
# given
announcement_hook = AppAnnouncementHook("test GitHub app", "r0kym/test", AppAnnouncementHook.Service.GITHUB)
requests_mocker.get(
"https://api.github.com/repos/r0kym/test/issues?labels=announcement",
json=[
{
"url": "https://api.github.com/repos/r0kym/test/issues/1",
"repository_url": "https://api.github.com/repos/r0kym/test",
"labels_url": "https://api.github.com/repos/r0kym/test/issues/1/labels{/name}",
"comments_url": "https://api.github.com/repos/r0kym/test/issues/1/comments",
"events_url": "https://api.github.com/repos/r0kym/test/issues/1/events",
"html_url": "https://github.com/r0kym/test/issues/1",
"id": 3007269496,
"node_id": "I_kwDOOc2YvM6zP0p4",
"number": 1,
"title": "GitHub issue",
"user": {
"login": "r0kym",
"id": 56434393,
"node_id": "MDQ6VXNlcjU2NDM0Mzkz",
"avatar_url": "https://avatars.githubusercontent.com/u/56434393?v=4",
"gravatar_id": "",
"url": "https://api.github.com/users/r0kym",
"html_url": "https://github.com/r0kym",
"followers_url": "https://api.github.com/users/r0kym/followers",
"following_url": "https://api.github.com/users/r0kym/following{/other_user}",
"gists_url": "https://api.github.com/users/r0kym/gists{/gist_id}",
"starred_url": "https://api.github.com/users/r0kym/starred{/owner}{/repo}",
"subscriptions_url": "https://api.github.com/users/r0kym/subscriptions",
"organizations_url": "https://api.github.com/users/r0kym/orgs",
"repos_url": "https://api.github.com/users/r0kym/repos",
"events_url": "https://api.github.com/users/r0kym/events{/privacy}",
"received_events_url": "https://api.github.com/users/r0kym/received_events",
"type": "User",
"user_view_type": "public",
"site_admin": False
},
"labels": [
{
"id": 8487814480,
"node_id": "LA_kwDOOc2YvM8AAAAB-enFUA",
"url": "https://api.github.com/repos/r0kym/test/labels/announcement",
"name": "announcement",
"color": "aaaaaa",
"default": False,
"description": None
}
],
"state": "open",
"locked": False,
"assignee": None,
"assignees": [],
"milestone": None,
"comments": 0,
"created_at": "2025-04-20T22:41:10Z",
"updated_at": "2025-04-21T11:05:08Z",
"closed_at": None,
"author_association": "OWNER",
"active_lock_reason": None,
"sub_issues_summary": {
"total": 0,
"completed": 0,
"percent_completed": 0
},
"body": None,
"closed_by": None,
"reactions": {
"url": "https://api.github.com/repos/r0kym/test/issues/1/reactions",
"total_count": 0,
"+1": 0,
"-1": 0,
"laugh": 0,
"hooray": 0,
"confused": 0,
"heart": 0,
"rocket": 0,
"eyes": 0
},
"timeline_url": "https://api.github.com/repos/r0kym/test/issues/1/timeline",
"performed_via_github_app": None,
"state_reason": None
}
]
)
# when
announcements = announcement_hook.get_announcement_list()
# then
self.assertEqual(len(announcements), 1)
self.assertIn(Announcement(
application_name="test GitHub app",
announcement_url="https://github.com/r0kym/test/issues/1",
announcement_number=1,
announcement_text="GitHub issue"
), announcements)

View File

@ -1,75 +0,0 @@
from unittest.mock import patch
from allianceauth.admin_status.hooks import Announcement
from allianceauth.admin_status.models import ApplicationAnnouncement
from allianceauth.utils.testing import NoSocketsTestCase
MODULE_PATH = 'allianceauth.admin_status.managers'
DEFAULT_ANNOUNCEMENTS = [
Announcement(
application_name="Test GitHub Application",
announcement_number=1,
announcement_text="GitHub issue",
announcement_url="https://github.com/r0kym/test/issues/1",
),
Announcement(
application_name="Test Gitlab Application",
announcement_number=1,
announcement_text="GitLab issue",
announcement_url="https://gitlab.com/r0kym/allianceauth-example-plugin/-/issues/1",
)
]
class TestSyncManager(NoSocketsTestCase):
def setUp(self):
ApplicationAnnouncement.object.create(
application_name="Test GitHub Application",
announcement_number=1,
announcement_text="GitHub issue",
announcement_url="https://github.com/r0kym/test/issues/1",
announcement_hash="9dbedb9c47529bb43cfecb704768a35d085b145930e13cced981623e5f162a85",
)
ApplicationAnnouncement.object.create(
application_name="Test Gitlab Application",
announcement_number=1,
announcement_text="GitLab issue",
announcement_url="https://gitlab.com/r0kym/allianceauth-example-plugin/-/issues/1",
announcement_hash="8955a9c12a1cfa9e1776662bdaf111147b84e35c79f24bfb758e35333a18b1bd",
)
@patch(MODULE_PATH + '.get_all_applications_announcements')
def test_announcements_stay_as_is(self, all_announcements_mocker):
# given
announcement_ids = set(ApplicationAnnouncement.object.values_list("id", flat=True))
all_announcements_mocker.return_value = DEFAULT_ANNOUNCEMENTS
# when
ApplicationAnnouncement.object.sync_and_return()
# then
self.assertEqual(ApplicationAnnouncement.object.count(), 2)
self.assertEqual(set(ApplicationAnnouncement.object.values_list("id", flat=True)), announcement_ids)
@patch(MODULE_PATH + '.get_all_applications_announcements')
def test_announcement_add(self, all_announcements_mocker):
# given
returned_announcements = DEFAULT_ANNOUNCEMENTS + [Announcement(application_name="Test Application", announcement_number=1, announcement_text="New test announcement", announcement_url="https://example.com")]
all_announcements_mocker.return_value = returned_announcements
# when
ApplicationAnnouncement.object.sync_and_return()
# then
self.assertEqual(ApplicationAnnouncement.object.count(), 3)
self.assertTrue(ApplicationAnnouncement.object.filter(application_name="Test Application", announcement_number=1, announcement_text="New test announcement", announcement_url="https://example.com"))
@patch(MODULE_PATH + '.get_all_applications_announcements')
def test_announcement_remove(self, all_announcements_mocker):
# given
all_announcements_mocker.return_value = DEFAULT_ANNOUNCEMENTS
ApplicationAnnouncement.object.sync_and_return()
self.assertEqual(ApplicationAnnouncement.object.count(), 2)
all_announcements_mocker.return_value = DEFAULT_ANNOUNCEMENTS[:1]
# when
ApplicationAnnouncement.object.sync_and_return()
# then
self.assertEqual(ApplicationAnnouncement.object.count(), 1)
self.assertTrue(ApplicationAnnouncement.object.filter(application_name="Test GitHub Application").exists())

View File

@ -1,8 +1,6 @@
from django.apps import AppConfig
from django.utils.translation import gettext_lazy as _
class AnalyticsConfig(AppConfig):
name = 'allianceauth.analytics'
label = 'analytics'
verbose_name = _('Analytics')

View File

@ -1,56 +0,0 @@
# Generated by Django 5.1.6 on 2025-03-04 01:03
# This was built by Deleting Every Migration, Creating one from scratch
# And porting in anything necessary
import uuid
from django.db import migrations, models
def add_aa_team_token(apps, schema_editor):
Tokens = apps.get_model('analytics', 'AnalyticsTokens')
token = Tokens()
token.type = 'GA-V4'
token.token = 'G-6LYSMYK8DE'
token.secret = 'KLlpjLZ-SRGozS5f5wb_kw'
token.name = 'AA Team Public Google Analytics (V4)'
token.save()
class Migration(migrations.Migration):
replaces = [('analytics', '0001_initial'), ('analytics', '0002_add_AA_Team_Token'), ('analytics', '0003_Generate_Identifier'), ('analytics', '0004_auto_20211015_0502'), ('analytics', '0005_alter_analyticspath_ignore_path'), ('analytics', '0006_more_ignore_paths'), ('analytics', '0007_analyticstokens_secret'), ('analytics', '0008_add_AA_GA-4_Team_Token '), ('analytics', '0009_remove_analyticstokens_ignore_paths_and_more'), ('analytics', '0010_alter_analyticsidentifier_options')]
initial = True
dependencies = [
]
operations = [
migrations.CreateModel(
name='AnalyticsIdentifier',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('identifier', models.UUIDField(default=uuid.uuid4, editable=False)),
],
options={
'verbose_name': 'Analytics Identifier',
},
),
migrations.CreateModel(
name='AnalyticsTokens',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('name', models.CharField(max_length=254)),
('type', models.CharField(choices=[('GA-U', 'Google Analytics Universal'), ('GA-V4', 'Google Analytics V4')], max_length=254)),
('token', models.CharField(max_length=254)),
('secret', models.CharField(blank=True, max_length=254)),
('send_stats', models.BooleanField(default=False)),
],
),
migrations.RunPython(
add_aa_team_token
),
]

View File

@ -17,7 +17,6 @@ class AnalyticsIdentifier(SingletonModel):
class Meta:
verbose_name = "Analytics Identifier"
class AnalyticsTokens(models.Model):
class Analytics_Type(models.TextChoices):

View File

@ -1,12 +1,10 @@
from django.apps import AppConfig
from django.core.checks import register, Tags
from django.utils.translation import gettext_lazy as _
from django.core.checks import Tags, register
class AuthenticationConfig(AppConfig):
name = "allianceauth.authentication"
label = "authentication"
verbose_name = _("Authentication")
def ready(self):
from allianceauth.authentication import checks, signals # noqa: F401

View File

@ -1,124 +0,0 @@
# Generated by Django 5.1.6 on 2025-03-04 02:44
import django.contrib.auth.models
import django.db.models.deletion
from django.conf import settings
from django.db import migrations, models
import allianceauth.authentication.models
def create_states(apps, schema_editor) -> None:
State = apps.get_model('authentication', 'State')
State.objects.update_or_create(name="Guest", defaults={'priority': 0, 'public': True})[0]
State.objects.update_or_create(name="Blue", defaults={'priority': 50, 'public': False})[0]
State.objects.update_or_create(name="Member", defaults={'priority': 100, 'public': False})[0]
def create_states_reverse(apps, schema_editor) -> None:
pass
class Migration(migrations.Migration):
replaces = [('authentication', '0001_initial'), ('authentication', '0002_auto_20160907_1914'), ('authentication', '0003_authservicesinfo_state'), ('authentication', '0004_create_permissions'), ('authentication', '0005_delete_perms'), ('authentication', '0006_auto_20160910_0542'), ('authentication', '0007_remove_authservicesinfo_is_blue'), ('authentication', '0008_set_state'), ('authentication', '0009_auto_20161021_0228'), ('authentication', '0010_only_one_authservicesinfo'), ('authentication', '0011_authservicesinfo_user_onetoonefield'), ('authentication', '0012_remove_add_delete_authservicesinfo_permissions'), ('authentication', '0013_service_modules'), ('authentication', '0014_fleetup_permission'), ('authentication', '0015_user_profiles'), ('authentication', '0016_ownershiprecord'), ('authentication', '0017_remove_fleetup_permission'), ('authentication', '0018_state_member_factions'), ('authentication', '0018_alter_state_name_length'), ('authentication', '0019_merge_20211026_0919'), ('authentication', '0020_userprofile_language_userprofile_night_mode'), ('authentication', '0021_alter_userprofile_language'), ('authentication', '0022_userprofile_theme'), ('authentication', '0023_alter_userprofile_language'), ('authentication', '0024_alter_userprofile_language')]
initial = True
dependencies = [
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
('esi', '0012_fix_token_type_choices'),
('eveonline', '0019_v5squash'),
]
operations = [
migrations.CreateModel(
name='CharacterOwnership',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('owner_hash', models.CharField(max_length=28, unique=True)),
('character', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='character_ownership', to='eveonline.evecharacter')),
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='character_ownerships', to=settings.AUTH_USER_MODEL)),
],
options={
'default_permissions': ('change', 'delete'),
'ordering': ['user', 'character__character_name'],
},
),
migrations.CreateModel(
name='State',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('name', models.CharField(max_length=32, unique=True)),
('priority', models.IntegerField(help_text='Users get assigned the state with the highest priority available to them.', unique=True)),
('public', models.BooleanField(default=False, help_text='Make this state available to any character.')),
('member_alliances', models.ManyToManyField(blank=True, help_text='Alliances to whose members this state is available.', to='eveonline.eveallianceinfo')),
('member_characters', models.ManyToManyField(blank=True, help_text='Characters to which this state is available.', to='eveonline.evecharacter')),
('member_corporations', models.ManyToManyField(blank=True, help_text='Corporations to whose members this state is available.', to='eveonline.evecorporationinfo')),
('permissions', models.ManyToManyField(blank=True, to='auth.permission')),
('member_factions', models.ManyToManyField(blank=True, help_text='Factions to whose members this state is available.', to='eveonline.evefactioninfo')),
],
options={
'ordering': ['-priority'],
},
),
migrations.CreateModel(
name='UserProfile',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('main_character', models.OneToOneField(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='eveonline.evecharacter')),
('state', models.ForeignKey(default=allianceauth.authentication.models.get_guest_state_pk, on_delete=django.db.models.deletion.SET_DEFAULT, to='authentication.state')),
('user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='profile', to=settings.AUTH_USER_MODEL)),
('night_mode', models.BooleanField(blank=True, null=True, verbose_name='Night Mode')),
('theme', models.CharField(blank=True, help_text='Bootstrap 5 Themes from https://bootswatch.com/ or Community Apps', max_length=200, null=True, verbose_name='Theme')),
('language', models.CharField(blank=True, choices=[('en', 'English'), ('cs-cz', 'Czech'), ('de', 'German'), ('es', 'Spanish'), ('it-it', 'Italian'), ('ja', 'Japanese'), ('ko-kr', 'Korean'), ('fr-fr', 'French'), ('ru', 'Russian'), ('nl-nl', 'Dutch'), ('pl-pl', 'Polish'), ('uk', 'Ukrainian'), ('zh-hans', 'Simplified Chinese')], default='', max_length=10, verbose_name='Language')),
],
options={
'default_permissions': ('change',),
},
),
migrations.CreateModel(
name='Permission',
fields=[
],
options={
'proxy': True,
'verbose_name': 'permission',
'verbose_name_plural': 'permissions',
},
bases=('auth.permission',),
managers=[
('objects', django.contrib.auth.models.PermissionManager()),
],
),
migrations.CreateModel(
name='User',
fields=[
],
options={
'proxy': True,
'verbose_name': 'user',
'verbose_name_plural': 'users',
},
bases=('auth.user',),
managers=[
('objects', django.contrib.auth.models.UserManager()),
],
),
migrations.CreateModel(
name='OwnershipRecord',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('owner_hash', models.CharField(db_index=True, max_length=28)),
('created', models.DateTimeField(auto_now=True)),
('character', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='ownership_records', to='eveonline.evecharacter')),
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='ownership_records', to=settings.AUTH_USER_MODEL)),
],
options={
'ordering': ['-created'],
},
),
migrations.RunPython(create_states, create_states_reverse),
]

View File

@ -1,5 +1,4 @@
import logging
from typing import ClassVar
from django.contrib.auth.models import Permission, User
from django.db import models, transaction
@ -16,30 +15,24 @@ logger = logging.getLogger(__name__)
class State(models.Model):
name = models.CharField(max_length=32, unique=True)
permissions = models.ManyToManyField(Permission, blank=True)
priority = models.IntegerField(
unique=True, help_text="Users get assigned the state with the highest priority available to them."
)
priority = models.IntegerField(unique=True, help_text="Users get assigned the state with the highest priority available to them.")
member_characters = models.ManyToManyField(
EveCharacter, blank=True, help_text="Characters to which this state is available."
)
member_corporations = models.ManyToManyField(
EveCorporationInfo, blank=True, help_text="Corporations to whose members this state is available."
)
member_alliances = models.ManyToManyField(
EveAllianceInfo, blank=True, help_text="Alliances to whose members this state is available."
)
member_factions = models.ManyToManyField(
EveFactionInfo, blank=True, help_text="Factions to whose members this state is available."
)
member_characters = models.ManyToManyField(EveCharacter, blank=True,
help_text="Characters to which this state is available.")
member_corporations = models.ManyToManyField(EveCorporationInfo, blank=True,
help_text="Corporations to whose members this state is available.")
member_alliances = models.ManyToManyField(EveAllianceInfo, blank=True,
help_text="Alliances to whose members this state is available.")
member_factions = models.ManyToManyField(EveFactionInfo, blank=True,
help_text="Factions to whose members this state is available.")
public = models.BooleanField(default=False, help_text="Make this state available to any character.")
objects: ClassVar[StateManager] = StateManager()
objects = StateManager()
class Meta:
ordering = ["-priority"]
ordering = ['-priority']
def __str__(self) -> str:
def __str__(self):
return self.name
def available_to_character(self, character):
@ -55,11 +48,11 @@ class State(models.Model):
super().delete(**kwargs)
def get_guest_state() -> State:
def get_guest_state():
try:
return State.objects.get(name="Guest")
return State.objects.get(name='Guest')
except State.DoesNotExist:
return State.objects.create(name="Guest", priority=0, public=True)
return State.objects.create(name='Guest', priority=0, public=True)
def get_guest_state_pk():
@ -67,58 +60,76 @@ def get_guest_state_pk():
class UserProfile(models.Model):
class Language(models.TextChoices):
"""
Choices for UserProfile.language
"""
# Sorted by Language Code alphabetical order + English at top
ENGLISH = "en", _("English")
CZECH = "cs-cz", _("Czech") # Not yet at 50% translated
GERMAN = "de", _("German")
SPANISH = "es", _("Spanish")
ITALIAN = "it-it", _("Italian")
JAPANESE = "ja", _("Japanese")
KOREAN = "ko-kr", _("Korean")
FRENCH = "fr-fr", _("French")
RUSSIAN = "ru", _("Russian")
DUTCH = "nl-nl", _("Dutch")
POLISH = "pl-pl", _("Polish")
UKRAINIAN = "uk", _("Ukrainian")
CHINESE = "zh-hans", _("Simplified Chinese")
ENGLISH = 'en', _('English')
CZECH = 'cs-cz', _("Czech") # Not yet at 50% translated
GERMAN = 'de', _('German')
SPANISH = 'es', _('Spanish')
ITALIAN = 'it-it', _('Italian')
JAPANESE = 'ja', _('Japanese')
KOREAN = 'ko-kr', _('Korean')
FRENCH = 'fr-fr', _('French')
RUSSIAN = 'ru', _('Russian')
DUTCH = 'nl-nl', _("Dutch")
POLISH = 'pl-pl', _("Polish")
UKRAINIAN = 'uk', _('Ukrainian')
CHINESE = 'zh-hans', _('Simplified Chinese')
user = models.OneToOneField(User, related_name="profile", on_delete=models.CASCADE)
main_character = models.OneToOneField(EveCharacter, blank=True, null=True, on_delete=models.SET_NULL)
state = models.ForeignKey(State, on_delete=models.SET_DEFAULT, default=get_guest_state_pk)
language = models.CharField(_("Language"), max_length=10, choices=Language.choices, blank=True, default="")
night_mode = models.BooleanField(_("Night Mode"), blank=True, null=True)
theme = models.CharField( # noqa:DJ001 Null has a specific meaning, never set by user
user = models.OneToOneField(
User,
related_name='profile',
on_delete=models.CASCADE)
main_character = models.OneToOneField(
EveCharacter,
blank=True,
null=True,
on_delete=models.SET_NULL)
state = models.ForeignKey(
State,
on_delete=models.SET_DEFAULT,
default=get_guest_state_pk)
language = models.CharField(
_("Language"), max_length=10,
choices=Language.choices,
blank=True,
default='')
night_mode = models.BooleanField(
_("Night Mode"),
blank=True,
null=True)
theme = models.CharField(
_("Theme"),
max_length=200,
blank=True,
null=True,
help_text="Bootstrap 5 Themes from https://bootswatch.com/ or Community Apps",
help_text="Bootstrap 5 Themes from https://bootswatch.com/ or Community Apps"
)
class Meta:
default_permissions = ("change",)
default_permissions = ('change',)
def __str__(self) -> str:
return str(self.user)
def assign_state(self, state=None, commit=True) -> None:
def assign_state(self, state=None, commit=True):
if not state:
state = State.objects.get_for_user(self.user)
if self.state != state:
self.state = state
if commit:
logger.info(f"Updating {self.user} state to {self.state}")
self.save(update_fields=["state"])
logger.info(f'Updating {self.user} state to {self.state}')
self.save(update_fields=['state'])
notify(
self.user,
_(f"State changed to: {state}"),
_("Your user's state is now: %(state)s") % ({"state": state}),
"info",
_(f'State changed to: {state}'),
_('Your user\'s state is now: %(state)s')
% ({'state': state}),
'info'
)
from allianceauth.authentication.signals import state_changed
@ -126,33 +137,34 @@ class UserProfile(models.Model):
# Clear all attribute caches and reload the model that will get passed to the signals!
self.refresh_from_db()
state_changed.send(sender=self.__class__, user=self.user, state=self.state)
state_changed.send(
sender=self.__class__, user=self.user, state=self.state
)
class CharacterOwnership(models.Model):
character = models.OneToOneField(EveCharacter, on_delete=models.CASCADE, related_name='character_ownership')
owner_hash = models.CharField(max_length=28, unique=True)
user = models.ForeignKey(User, on_delete=models.CASCADE, related_name="character_ownerships")
objects: ClassVar[CharacterOwnershipManager] = CharacterOwnershipManager()
user = models.ForeignKey(User, on_delete=models.CASCADE, related_name='character_ownerships')
objects = CharacterOwnershipManager()
class Meta:
default_permissions = ('change', 'delete')
ordering = ['user', 'character__character_name']
def __str__(self) -> str:
def __str__(self):
return f"{self.user}: {self.character}"
class OwnershipRecord(models.Model):
character = models.ForeignKey(EveCharacter, on_delete=models.CASCADE, related_name="ownership_records")
character = models.ForeignKey(EveCharacter, on_delete=models.CASCADE, related_name='ownership_records')
owner_hash = models.CharField(max_length=28, db_index=True)
user = models.ForeignKey(User, on_delete=models.CASCADE, related_name="ownership_records")
user = models.ForeignKey(User, on_delete=models.CASCADE, related_name='ownership_records')
created = models.DateTimeField(auto_now=True)
class Meta:
ordering = ["-created"]
ordering = ['-created']
def __str__(self) -> str:
def __str__(self):
return f"{self.user}: {self.character} on {self.created}"

View File

@ -31,7 +31,7 @@
<tr>
<td style="white-space:initial;">
{% for s in t.scopes.all %}
<span class="badge text-bg-secondary">{{ s.name }}</span>
<span class="badge bg-secondary">{{ s.name }}</span>
{% endfor %}
</td>

View File

@ -1,24 +1,24 @@
{% load theme_tags %}
{% load static %}
<!DOCTYPE html>
<html lang="en" {% theme_html_tags %}>
<html lang="en">
<head>
<!-- Required meta tags -->
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<!-- End Required meta tags -->
<meta name="description" content="">
<meta name="author" content="">
<!-- TODO Bundle all the site specific stuff up into its own template for easy override -->
<meta property="og:title" content="{{ SITE_NAME }}">
<meta property="og:image" content="{{ SITE_URL }}{% static 'allianceauth/icons/apple-touch-icon.png' %}">
<meta property="og:description" content="Alliance Auth - An auth system for EVE Online to help in-game organizations manage online service access.">
<!-- Meta tags -->
{% include 'allianceauth/opengraph.html' %}
{% include 'allianceauth/icons.html' %}
<!-- Meta tags -->
<title>{% block title %}{% block page_title %}{% endblock page_title %} - {{ SITE_NAME }}{% endblock title %}</title>
{% theme_css %}
{% include 'bundles/fontawesome.html' %}
{% include 'bundles/auth-framework-css.html' %}
{% block extra_include %}
{% endblock %}

View File

@ -1,15 +1,17 @@
{% load i18n %}
<form class="dropdown-item" action="{% url 'set_language' %}" method="post">
{% csrf_token %}
<div class="dropdown">
<form action="{% url 'set_language' %}" method="post">
{% csrf_token %}
<select class="form-select" onchange="this.form.submit()" class="form-control" id="lang-select" name="language">
{% get_available_languages as LANGUAGES %}
<select class="form-select" onchange="this.form.submit()" class="form-control" id="lang-select" name="language">
{% get_available_languages as LANGUAGES %}
{% for lang_code, lang_name in LANGUAGES %}
<option lang="{{ lang_code }}" value="{{ lang_code }}"{% if lang_code == LANGUAGE_CODE %} selected{% endif %}>
{{ lang_code|language_name_local|capfirst }} ({{ lang_code }})
</option>
{% endfor %}
</select>
</form>
{% for lang_code, lang_name in LANGUAGES %}
<option lang="{{ lang_code }}" value="{{ lang_code }}"{% if lang_code == LANGUAGE_CODE %} selected{% endif %}>
{{ lang_code|language_name_local|capfirst }} ({{ lang_code }})
</option>
{% endfor %}
</select>
</form>
</div>

View File

@ -8,61 +8,23 @@ from packaging.version import Version as Pep440Version
from django.core.cache import cache
from django.test import TestCase
from allianceauth.admin_status.models import ApplicationAnnouncement
from allianceauth.admin_status.templatetags.admin_status import (
from allianceauth.templatetags.admin_status import (
_current_notifications,
_current_version_summary,
_fetch_list_from_gitlab,
_fetch_notification_issues_from_gitlab,
_latests_versions,
status_overview,
)
MODULE_PATH = 'allianceauth.admin_status.templatetags'
MODULE_PATH = 'allianceauth.templatetags'
def create_tags_list(tag_names: list):
return [{'name': str(tag_name)} for tag_name in tag_names]
def get_app_announcement_as_dict(app_announcement: ApplicationAnnouncement) -> dict:
"""Transforms an app announcement object in a dict easy to compare"""
return {
"application_name": app_announcement.application_name,
"announcement_number": app_announcement.announcement_number,
"announcement_text": app_announcement.announcement_text,
"announcement_url": app_announcement.announcement_url,
}
GITHUB_TAGS = create_tags_list(['v2.4.6a1', 'v2.4.5', 'v2.4.0', 'v2.0.0', 'v1.1.1'])
STORED_NOTIFICATIONS = [
ApplicationAnnouncement(
application_name="Test GitHub Application",
announcement_number=1,
announcement_text="GitHub issue",
announcement_url="https://github.com/r0kym/test/issues/1",
announcement_hash="hash1",
),
ApplicationAnnouncement(
application_name="Test Gitlab Application",
announcement_number=1,
announcement_text="GitLab issue",
announcement_url="https://gitlab.com/r0kym/allianceauth-example-plugin/-/issues/1",
announcement_hash="hash2",
),
]
ANNOUNCEMENT_DICT = [
{
"application_name": "Test GitHub Application",
"announcement_number": 1,
"announcement_text": "GitHub issue",
"announcement_url": "https://github.com/r0kym/test/issues/1",
}, {
"application_name": "Test Gitlab Application",
"announcement_number": 1,
"announcement_text": "GitLab issue",
"announcement_url": "https://gitlab.com/r0kym/allianceauth-example-plugin/-/issues/1",
}
]
GITHUB_NOTIFICATION_ISSUES = [
{
'id': 1,
@ -90,10 +52,6 @@ GITHUB_NOTIFICATION_ISSUES = [
},
]
TEST_VERSION = '2.6.5'
GITLAB_AUTH_ANNOUNCEMENT_ISSUES_URL = (
'https://gitlab.com/api/v4/projects/allianceauth%2Fallianceauth/issues'
'?labels=announcement&state=opened'
)
class TestStatusOverviewTag(TestCase):
@ -149,19 +107,18 @@ class TestNotifications(TestCase):
)
requests_mocker.get(url, json=GITHUB_NOTIFICATION_ISSUES)
# when
result = _fetch_list_from_gitlab(GITLAB_AUTH_ANNOUNCEMENT_ISSUES_URL, 10)
result = _fetch_notification_issues_from_gitlab()
# then
self.assertEqual(result, GITHUB_NOTIFICATION_ISSUES)
@patch(MODULE_PATH + '.admin_status.ApplicationAnnouncement')
def test_current_notifications_normal(self, mock_application_announcement):
@patch(MODULE_PATH + '.admin_status.cache')
def test_current_notifications_normal(self, mock_cache):
# given
mock_application_announcement.object.sync_and_return.return_value = STORED_NOTIFICATIONS
mock_cache.get_or_set.return_value = GITHUB_NOTIFICATION_ISSUES
# when
result = _current_notifications()
# then
for notification in result["notifications"]:
self.assertIn(get_app_announcement_as_dict(notification), ANNOUNCEMENT_DICT)
self.assertEqual(result['notifications'], GITHUB_NOTIFICATION_ISSUES[:5])
@requests_mock.mock()
def test_current_notifications_failed(self, requests_mocker):
@ -174,7 +131,16 @@ class TestNotifications(TestCase):
# when
result = _current_notifications()
# then
self.assertEqual(list(result['notifications']), [])
self.assertEqual(result['notifications'], [])
@patch(MODULE_PATH + '.admin_status.cache')
def test_current_notifications_is_none(self, mock_cache):
# given
mock_cache.get_or_set.return_value = None
# when
result = _current_notifications()
# then
self.assertEqual(result['notifications'], [])
class TestCeleryQueueLength(TestCase):

View File

@ -74,14 +74,14 @@ def dashboard_characters(request):
def dashboard_admin(request):
if request.user.is_superuser:
return render_to_string('admin-status/include.html', request=request)
return render_to_string('allianceauth/admin-status/include.html', request=request)
else:
return ""
def dashboard_esi_check(request):
if request.user.is_superuser:
return render_to_string('admin-status/esi_check.html', request=request)
return render_to_string('allianceauth/admin-status/esi_check.html', request=request)
else:
return ""

View File

@ -1,8 +1,6 @@
from django.apps import AppConfig
from django.utils.translation import gettext_lazy as _
class CorpUtilsConfig(AppConfig):
name = 'allianceauth.corputils'
label = 'corputils'
verbose_name = _('Corporation Stats')

View File

@ -1,52 +0,0 @@
# Generated by Django 5.1.6 on 2025-03-04 01:29
# This was built by Deleting Every Migration, Creating one from scratch
# And porting in anything necessary
# Some functions were skipped as they only make sense _if you are migrating in place_
# i.e. permissions migration
import django.db.models.deletion
from django.db import migrations, models
class Migration(migrations.Migration):
replaces = [('corputils', '0001_initial'), ('corputils', '0002_migrate_permissions'), ('corputils', '0003_granular_permissions'), ('corputils', '0004_member_models'), ('corputils', '0005_cleanup_permissions')]
initial = True
dependencies = [
('esi', '0012_fix_token_type_choices'),
('eveonline', '0019_v5squash'),
]
operations = [
migrations.CreateModel(
name='CorpStats',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('last_update', models.DateTimeField(auto_now=True)),
('corp', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, to='eveonline.evecorporationinfo')),
('token', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='esi.token')),
],
options={
'verbose_name': 'corp stats',
'verbose_name_plural': 'corp stats',
'permissions': (('view_corp_corpstats', 'Can view corp stats of their corporation.'), ('view_alliance_corpstats', 'Can view corp stats of members of their alliance.'), ('view_state_corpstats', 'Can view corp stats of members of their auth state.')),
},
),
migrations.CreateModel(
name='CorpMember',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('character_id', models.PositiveIntegerField()),
('character_name', models.CharField(max_length=37)),
('corpstats', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='members', to='corputils.corpstats')),
],
options={
'ordering': ['character_name'],
'unique_together': {('corpstats', 'character_id')},
},
),
]

View File

@ -1,6 +1,5 @@
import logging
import os
from typing import ClassVar
from bravado.exception import HTTPForbidden
@ -34,8 +33,7 @@ class CorpStats(models.Model):
corp = models.OneToOneField(EveCorporationInfo, on_delete=models.CASCADE)
last_update = models.DateTimeField(auto_now=True)
objects: ClassVar[CorpStatsManager] = CorpStatsManager()
objects = CorpStatsManager()
class Meta:
permissions = (
('view_corp_corpstats', 'Can view corp stats of their corporation.'),
@ -45,10 +43,12 @@ class CorpStats(models.Model):
verbose_name = "corp stats"
verbose_name_plural = "corp stats"
def __str__(self) -> str:
def __str__(self):
return f"{self.__class__.__name__} for {self.corp}"
def update(self) -> None:
def update(self):
try:
c = self.token.get_esi_client(spec_file=SWAGGER_SPEC_PATH)
assert c.Character.get_characters_character_id(character_id=self.token.character_id).result()['corporation_id'] == int(self.corp.corporation_id)
@ -101,11 +101,11 @@ class CorpStats(models.Model):
return self.members.count()
@property
def user_count(self) -> int:
def user_count(self):
return len({m.main_character for m in self.members.all() if m.main_character})
@property
def registered_member_count(self) -> int:
def registered_member_count(self):
return len(self.registered_members)
@property
@ -121,7 +121,7 @@ class CorpStats(models.Model):
return self.members.filter(pk__in=[m.pk for m in self.members.all() if not m.registered])
@property
def main_count(self) -> int:
def main_count(self):
return len(self.mains)
@property
@ -134,10 +134,10 @@ class CorpStats(models.Model):
def can_update(self, user):
return self.token.user == user or self.visible_to(user)
def corp_logo(self, size=128) -> str:
def corp_logo(self, size=128):
return self.corp.logo_url(size)
def alliance_logo(self, size=128) -> str:
def alliance_logo(self, size=128):
if self.corp.alliance:
return self.corp.alliance.logo_url(size)
else:
@ -154,11 +154,11 @@ class CorpMember(models.Model):
unique_together = ('corpstats', 'character_id')
ordering = ['character_name']
def __str__(self) -> str:
def __str__(self):
return self.character_name
@property
def character(self) -> EveCharacter | None:
def character(self):
try:
return EveCharacter.objects.get(character_id=self.character_id)
except EveCharacter.DoesNotExist:
@ -179,20 +179,20 @@ class CorpMember(models.Model):
return []
@property
def registered(self) -> bool:
def registered(self):
return CharacterOwnership.objects.filter(character__character_id=self.character_id).exists()
def portrait_url(self, size=32) -> str:
def portrait_url(self, size=32):
return EveCharacter.generic_portrait_url(self.character_id, size)
@property
def portrait_url_32(self) -> str:
def portrait_url_32(self):
return self.portrait_url(32)
@property
def portrait_url_64(self) -> str:
def portrait_url_64(self):
return self.portrait_url(64)
@property
def portrait_url_128(self) -> str:
def portrait_url_128(self):
return self.portrait_url(128)

View File

@ -138,7 +138,7 @@
<td style="width: 30%;">{{ alt.corporation_name }}</td>
<td style="width: 30%;">{{ alt.alliance_name|default_if_none:"" }}</td>
<td style="width: 5%;">
<a href="https://zkillboard.com/character/{{ alt.character_id }}/" class="badge text-bg-danger" target="_blank">
<a href="https://zkillboard.com/character/{{ alt.character_id }}/" class="badge bg-danger" target="_blank">
{% translate "Killboard" %}
</a>
</td>
@ -175,7 +175,7 @@
<td><img src="{{ member.portrait_url }}" class="img-circle" alt="{{ member }}"></td>
<td>{{ member }}</td>
<td>
<a href="https://zkillboard.com/character/{{ member.character_id }}/" class="badge text-bg-danger" target="_blank">{% translate "Killboard" %}</a>
<a href="https://zkillboard.com/character/{{ member.character_id }}/" class="badge bg-danger" target="_blank">{% translate "Killboard" %}</a>
</td>
<td>{{ member.character_ownership.user.profile.main_character.character_name }}</td>
<td>{{ member.character_ownership.user.profile.main_character.corporation_name }}</td>
@ -188,7 +188,7 @@
<td><img src="{{ member.portrait_url }}" class="img-circle" alt="{{ member.character_name }}"></td>
<td>{{ member.character_name }}</td>
<td>
<a href="https://zkillboard.com/character/{{ member.character_id }}/" class="badge text-bg-danger" target="_blank">{% translate "Killboard" %}</a>
<a href="https://zkillboard.com/character/{{ member.character_id }}/" class="badge bg-danger" target="_blank">{% translate "Killboard" %}</a>
</td>
<td></td>
<td></td>
@ -219,7 +219,7 @@
<td><img src="{{ member.portrait_url }}" class="img-circle" alt="{{ member.character_name }}"></td>
<td>{{ member.character_name }}</td>
<td>
<a href="https://zkillboard.com/character/{{ member.character_id }}/" class="badge text-bg-danger" target="_blank">
<a href="https://zkillboard.com/character/{{ member.character_id }}/" class="badge bg-danger" target="_blank">
{% translate "Killboard" %}
</a>
</td>

View File

@ -28,7 +28,7 @@
<td><img src="{{ result.1.portrait_url }}" class="img-circle" alt="{{ result.1.character_name }}"></td>
<td>{{ result.1.character_name }}</td>
<td >{{ result.0.corp.corporation_name }}</td>
<td><a href="https://zkillboard.com/character/{{ result.1.character_id }}/" class="badge text-bg-danger" target="_blank">{% translate "Killboard" %}</a></td>
<td><a href="https://zkillboard.com/character/{{ result.1.character_id }}/" class="badge bg-danger" target="_blank">{% translate "Killboard" %}</a></td>
<td>{{ result.1.main_character.character_name }}</td>
<td>{{ result.1.main_character.corporation_name }}</td>
<td>{{ result.1.main_character.alliance_name }}</td>

View File

@ -3,7 +3,6 @@ Crontab App Config
"""
from django.apps import AppConfig
from django.utils.translation import gettext_lazy as _
class CrontabConfig(AppConfig):
@ -13,4 +12,3 @@ class CrontabConfig(AppConfig):
name = "allianceauth.crontab"
label = "crontab"
verbose_name = _("Crontab")

View File

@ -11,6 +11,7 @@ def random_default() -> float:
class CronOffset(SingletonModel):
minute = models.FloatField(_("Minute Offset"), default=random_default)
hour = models.FloatField(_("Hour Offset"), default=random_default)
day_of_month = models.FloatField(_("Day of Month Offset"), default=random_default)

View File

@ -1,18 +0,0 @@
# Generated by Django 5.1.6 on 2025-03-05 00:59
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('custom_css', '0001_initial'),
]
operations = [
migrations.AlterField(
model_name='customcss',
name='css',
field=models.TextField(blank=True, default='', help_text='This CSS will be added to the site after the default CSS.', verbose_name='Your custom CSS'),
),
]

View File

@ -22,7 +22,6 @@ class CustomCSS(SingletonModel):
css = models.TextField(
blank=True,
verbose_name=_("Your custom CSS"),
default="",
help_text=_("This CSS will be added to the site after the default CSS."),
)
timestamp = models.DateTimeField(auto_now=True)
@ -46,7 +45,7 @@ class CustomCSS(SingletonModel):
return str(_("Custom CSS"))
def save(self, *args, **kwargs) -> None:
def save(self, *args, **kwargs):
"""
Save method for CustomCSS
@ -62,7 +61,9 @@ class CustomCSS(SingletonModel):
if self.css and len(self.css.replace(" ", "")) > 0:
# Write the custom CSS to a file
custom_css_file = open(f"{settings.STATIC_ROOT}allianceauth/custom-styles.css", "w+")
custom_css_file = open(
f"{settings.STATIC_ROOT}allianceauth/custom-styles.css", "w+"
)
custom_css_file.write(self.compress_css())
custom_css_file.close()
else:
@ -104,7 +105,9 @@ class CustomCSS(SingletonModel):
)
# Fragment values can loose zeros
css = re.sub(pattern=r":\s*0(\.\d+([cm]m|e[mx]|in|p[ctx]))\s*;", repl=r":\1;", string=css)
css = re.sub(
pattern=r":\s*0(\.\d+([cm]m|e[mx]|in|p[ctx]))\s*;", repl=r":\1;", string=css
)
for rule in re.findall(pattern=r"([^{]+){([^}]*)}", string=css):
# We don't need spaces around operators

View File

@ -1,8 +1,6 @@
from django.apps import AppConfig
from django.utils.translation import gettext_lazy as _
class EveonlineConfig(AppConfig):
name = 'allianceauth.eveonline'
label = 'eveonline'
verbose_name = _('EVE Online')

View File

@ -1,11 +1,9 @@
from django.apps import AppConfig
from django.utils.translation import gettext_lazy as _
class EveAutogroupsConfig(AppConfig):
name = 'allianceauth.eveonline.autogroups'
label = 'eve_autogroups'
verbose_name = _('EVE Online Autogroups')
def ready(self):
pass

View File

@ -1,7 +1,6 @@
# Generated by Django 5.1.6 on 2025-03-05 02:08
# Generated by Django 1.11.6 on 2017-12-23 04:30
import django.db.models.deletion
from django.conf import settings
from django.db import migrations, models
@ -10,9 +9,9 @@ class Migration(migrations.Migration):
initial = True
dependencies = [
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
('authentication', '0025_v5squash'),
('eveonline', '0019_v5squash'),
('authentication', '0015_user_profiles'),
('auth', '0008_alter_user_username_max_length'),
('eveonline', '0009_on_delete'),
]
operations = [
@ -28,16 +27,27 @@ class Migration(migrations.Migration):
('alliance_name_source', models.CharField(choices=[('ticker', 'Ticker'), ('name', 'Full name')], default='name', max_length=20)),
('replace_spaces', models.BooleanField(default=False)),
('replace_spaces_with', models.CharField(blank=True, default='', help_text='Any spaces in the group name will be replaced with this.', max_length=10)),
('states', models.ManyToManyField(related_name='autogroups', to='authentication.state')),
],
),
migrations.CreateModel(
name='ManagedAllianceGroup',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('alliance', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='eveonline.eveallianceinfo')),
('config', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='eve_autogroups.autogroupsconfig')),
('group', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='auth.group')),
('alliance', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='eveonline.EveAllianceInfo')),
('config', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='eve_autogroups.AutogroupsConfig')),
('group', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='auth.Group')),
],
options={
'abstract': False,
},
),
migrations.CreateModel(
name='ManagedCorpGroup',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('config', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='eve_autogroups.AutogroupsConfig')),
('corp', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='eveonline.EveCorporationInfo')),
('group', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='auth.Group')),
],
options={
'abstract': False,
@ -46,23 +56,16 @@ class Migration(migrations.Migration):
migrations.AddField(
model_name='autogroupsconfig',
name='alliance_managed_groups',
field=models.ManyToManyField(help_text="A list of alliance groups created and maintained by this AutogroupConfig. You should not edit this list unless you know what you're doing.", related_name='alliance_managed_config', through='eve_autogroups.ManagedAllianceGroup', to='auth.group'),
),
migrations.CreateModel(
name='ManagedCorpGroup',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('config', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='eve_autogroups.autogroupsconfig')),
('corp', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='eveonline.evecorporationinfo')),
('group', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='auth.group')),
],
options={
'abstract': False,
},
field=models.ManyToManyField(help_text="A list of alliance groups created and maintained by this AutogroupConfig. You should not edit this list unless you know what you're doing.", related_name='alliance_managed_config', through='eve_autogroups.ManagedAllianceGroup', to='auth.Group'),
),
migrations.AddField(
model_name='autogroupsconfig',
name='corp_managed_groups',
field=models.ManyToManyField(help_text="A list of corporation groups created and maintained by this AutogroupConfig. You should not edit this list unless you know what you're doing.", related_name='corp_managed_config', through='eve_autogroups.ManagedCorpGroup', to='auth.group'),
field=models.ManyToManyField(help_text="A list of corporation groups created and maintained by this AutogroupConfig. You should not edit this list unless you know what you're doing.", related_name='corp_managed_config', through='eve_autogroups.ManagedCorpGroup', to='auth.Group'),
),
migrations.AddField(
model_name='autogroupsconfig',
name='states',
field=models.ManyToManyField(related_name='autogroups', to='authentication.State'),
),
]

View File

@ -1,6 +1,5 @@
import logging
from typing import ClassVar
from django.db import models, transaction
from django.contrib.auth.models import Group, User
from django.core.exceptions import ObjectDoesNotExist
from django.db import models, transaction
@ -40,13 +39,13 @@ class AutogroupsConfigManager(models.Manager):
"""
if state is None:
state = user.profile.state
for config in self.filter(states=state):
# grant user new groups for their state
config.update_group_membership_for_user(user)
for config in self.exclude(states=state):
# ensure user does not have groups from previous state
config.remove_user_from_alliance_groups(user)
config.remove_user_from_corp_groups(user)
for config in self.filter(states=state):
# grant user new groups for their state
config.update_group_membership_for_user(user)
class AutogroupsConfig(models.Model):
@ -80,25 +79,25 @@ class AutogroupsConfig(models.Model):
max_length=10, default='', blank=True,
help_text='Any spaces in the group name will be replaced with this.')
objects: ClassVar[AutogroupsConfigManager] = AutogroupsConfigManager()
objects = AutogroupsConfigManager()
def __str__(self) -> str:
def __str__(self):
return 'States: ' + (' '.join(list(self.states.all().values_list('name', flat=True))) if self.pk else str(None))
def __init__(self, *args, **kwargs) -> None:
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
def __repr__(self) -> str:
def __repr__(self):
return self.__class__.__name__
def update_all_states_group_membership(self) -> None:
def update_all_states_group_membership(self):
list(map(self.update_group_membership_for_state, self.states.all()))
def update_group_membership_for_state(self, state: State):
list(map(self.update_group_membership_for_user, get_users_for_state(state)))
@transaction.atomic
def update_group_membership_for_user(self, user: User) -> None:
def update_group_membership_for_user(self, user: User):
self.update_alliance_group_membership(user)
self.update_corp_group_membership(user)
@ -236,10 +235,9 @@ class ManagedGroup(models.Model):
class Meta:
abstract = True
def __str__(self) -> str:
def __str__(self):
return f"Managed Group: {self.group.name}"
class ManagedCorpGroup(ManagedGroup):
corp = models.ForeignKey(EveCorporationInfo, on_delete=models.CASCADE)

View File

@ -1,4 +1,3 @@
from allianceauth.eveonline.models import EveCorporationInfo
from django.test import TestCase
from allianceauth.tests.auth_utils import AuthUtils
@ -75,51 +74,3 @@ class AutogroupsConfigManagerTestCase(TestCase):
AutogroupsConfig.objects.update_groups_for_user(member)
self.assertTrue(update_groups.called)
def test_update_group_membership_corp_in_two_configs(self):
# given
member = AuthUtils.create_member('test member')
AuthUtils.add_main_character_2(
member,
character_id='1234',
name='test character',
corp_id='2345',
corp_name='corp name',
corp_ticker='TIKK',
)
corp = EveCorporationInfo.objects.create(
corporation_id='2345',
corporation_name='corp name',
corporation_ticker='TIKK',
member_count=10,
)
member_state = AuthUtils.get_member_state()
member_config = AutogroupsConfig.objects.create(corp_groups=True)
member_config.states.add(member_state)
blue_state = AuthUtils.get_blue_state()
blue_state.member_corporations.add(corp)
blue_config = AutogroupsConfig.objects.create(corp_groups=True)
blue_config.states.add(blue_state)
member.profile.state = blue_state
member.profile.save()
AutogroupsConfig.objects.update_groups_for_user(member)
# Checks before test that the role is correctly applied
group = blue_config.get_corp_group(corp)
self.assertIn(group, member.groups.all())
# when
blue_state.member_corporations.remove(corp)
member_state.member_corporations.add(corp)
member.profile.state = member_state
member.profile.save()
# then
AutogroupsConfig.objects.update_groups_for_user(member)
group = member_config.get_corp_group(corp)
self.assertIn(group, member.groups.all())

View File

@ -15,20 +15,10 @@ class EveCharacterProviderManager:
class EveCharacterManager(models.Manager):
provider = EveCharacterProviderManager()
def exclude_biomassed(self):
"""
Get a queryset of EveCharacter objects, excluding the "Doomheim" corporation (1000001).
:return:
:rtype:
"""
return self.exclude(corporation_id=1000001)
def create_character(self, character_id) -> models.Model:
def create_character(self, character_id):
return self.create_character_obj(self.provider.get_character(character_id))
def create_character_obj(self, character: providers.Character) -> models.Model:
def create_character_obj(self, character: providers.Character):
return self.create(
character_id=character.id,
character_name=character.name,

View File

@ -1,28 +0,0 @@
# Generated by Django 5.1.6 on 2025-03-04 01:29
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('eveonline', '0017_alliance_and_corp_names_are_not_unique'),
]
operations = [
migrations.AlterField(
model_name='evecharacter',
name='alliance_name',
field=models.CharField(blank=True, default='', max_length=254, null=True),
),
migrations.AlterField(
model_name='evecharacter',
name='alliance_ticker',
field=models.CharField(blank=True, default='', max_length=5, null=True),
),
migrations.AlterField(
model_name='evecharacter',
name='faction_name',
field=models.CharField(blank=True, default='', max_length=254, null=True),
),
]

View File

@ -1,73 +0,0 @@
# Generated by Django 5.1.6 on 2025-03-05 02:19
import django.db.models.deletion
from django.db import migrations, models
class Migration(migrations.Migration):
replaces = [('eveonline', '0001_initial'), ('eveonline', '0002_remove_eveapikeypair_error_count'), ('eveonline', '0003_auto_20161026_0149'), ('eveonline', '0004_eveapikeypair_sso_verified'), ('eveonline', '0005_remove_eveallianceinfo_member_count'), ('eveonline', '0006_allow_null_evecharacter_alliance'), ('eveonline', '0007_unique_id_name'), ('eveonline', '0008_remove_apikeys'), ('eveonline', '0009_on_delete'), ('eveonline', '0010_alliance_ticker'), ('eveonline', '0011_ids_to_integers'), ('eveonline', '0012_index_additions'), ('eveonline', '0013_evecorporationinfo_ceo_id'), ('eveonline', '0014_auto_20210105_1413'), ('eveonline', '0015_factions'), ('eveonline', '0016_character_names_are_not_unique'), ('eveonline', '0017_alliance_and_corp_names_are_not_unique'), ('eveonline', '0018_alter_evecharacter_alliance_name_and_more')]
initial = True
dependencies = [
('auth', '__first__'),
]
operations = [
migrations.CreateModel(
name='EveAllianceInfo',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('alliance_id', models.PositiveIntegerField(unique=True)),
('alliance_name', models.CharField(db_index=True, max_length=254)),
('alliance_ticker', models.CharField(max_length=254)),
('executor_corp_id', models.PositiveIntegerField()),
],
options={
'indexes': [models.Index(fields=['executor_corp_id'], name='eveonline_e_executo_7f3280_idx')],
},
),
migrations.CreateModel(
name='EveFactionInfo',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('faction_id', models.PositiveIntegerField(db_index=True, unique=True)),
('faction_name', models.CharField(max_length=254, unique=True)),
],
),
migrations.CreateModel(
name='EveCorporationInfo',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('corporation_id', models.PositiveIntegerField(unique=True)),
('corporation_name', models.CharField(db_index=True, max_length=254)),
('corporation_ticker', models.CharField(max_length=254)),
('member_count', models.IntegerField()),
('alliance', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='eveonline.eveallianceinfo')),
('ceo_id', models.PositiveIntegerField(blank=True, default=None, null=True)),
],
options={
'indexes': [models.Index(fields=['ceo_id'], name='eveonline_e_ceo_id_eea7b8_idx')],
},
),
migrations.CreateModel(
name='EveCharacter',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('character_id', models.PositiveIntegerField(unique=True)),
('character_name', models.CharField(db_index=True, max_length=254)),
('corporation_id', models.PositiveIntegerField()),
('corporation_name', models.CharField(max_length=254)),
('corporation_ticker', models.CharField(max_length=5)),
('alliance_id', models.PositiveIntegerField(blank=True, default=None, null=True)),
('alliance_name', models.CharField(blank=True, default='', max_length=254, null=True)),
('alliance_ticker', models.CharField(blank=True, default='', max_length=5, null=True)),
('faction_id', models.PositiveIntegerField(blank=True, default=None, null=True)),
('faction_name', models.CharField(blank=True, default='', max_length=254, null=True)),
],
options={
'indexes': [models.Index(fields=['corporation_id'], name='eveonline_e_corpora_cb4cd9_idx'), models.Index(fields=['alliance_id'], name='eveonline_e_allianc_39ee2a_idx'), models.Index(fields=['corporation_name'], name='eveonline_e_corpora_893c60_idx'), models.Index(fields=['alliance_name'], name='eveonline_e_allianc_63fd98_idx'), models.Index(fields=['faction_id'], name='eveonline_e_faction_d5274e_idx')],
},
),
]

View File

@ -1,5 +1,4 @@
import logging
from typing import ClassVar
from django.core.exceptions import ObjectDoesNotExist
from django.db import models
@ -33,7 +32,7 @@ class EveFactionInfo(models.Model):
provider = providers.provider
def __str__(self) -> str:
def __str__(self):
return self.faction_name
@staticmethod
@ -76,16 +75,14 @@ class EveAllianceInfo(models.Model):
alliance_ticker = models.CharField(max_length=254)
executor_corp_id = models.PositiveIntegerField()
objects: ClassVar[EveAllianceManager] = EveAllianceManager()
provider: ClassVar[EveAllianceProviderManager] = EveAllianceProviderManager()
objects = EveAllianceManager()
provider = EveAllianceProviderManager()
class Meta:
indexes = [models.Index(fields=['executor_corp_id',])]
def __str__(self) -> str:
def __str__(self):
return self.alliance_name
def populate_alliance(self) -> None:
def populate_alliance(self):
alliance = self.provider.get_alliance(self.alliance_id)
for corp_id in alliance.corp_ids:
if not EveCorporationInfo.objects.filter(corporation_id=corp_id).exists():
@ -104,6 +101,8 @@ class EveAllianceInfo(models.Model):
self.save()
return self
@staticmethod
def generic_logo_url(
alliance_id: int, size: int = _DEFAULT_IMAGE_SIZE
@ -148,15 +147,13 @@ class EveCorporationInfo(models.Model):
EveAllianceInfo, blank=True, null=True, on_delete=models.SET_NULL
)
objects: ClassVar[EveCorporationManager] = EveCorporationManager()
objects = EveCorporationManager()
provider = EveCorporationProviderManager()
class Meta:
indexes = [models.Index(fields=['ceo_id',]),]
def __str__(self) -> str:
def __str__(self):
return self.corporation_name
def update_corporation(self, corp: providers.Corporation = None):
if corp is None:
corp = self.provider.get_corporation(self.corporation_id)
@ -169,6 +166,8 @@ class EveCorporationInfo(models.Model):
self.save()
return self
@staticmethod
def generic_logo_url(
corporation_id: int, size: int = _DEFAULT_IMAGE_SIZE
@ -210,12 +209,12 @@ class EveCharacter(models.Model):
corporation_name = models.CharField(max_length=254)
corporation_ticker = models.CharField(max_length=5)
alliance_id = models.PositiveIntegerField(blank=True, null=True, default=None)
alliance_name = models.CharField(max_length=254, blank=True, null=True, default='') # noqa: DJ001
alliance_ticker = models.CharField(max_length=5, blank=True, null=True, default='') # noqa: DJ001
faction_id = models.PositiveIntegerField(blank=True, null=True, default=None)
faction_name = models.CharField(max_length=254, blank=True, null=True, default='') # noqa: DJ001
alliance_name = models.CharField(max_length=254, blank=True, default='')
alliance_ticker = models.CharField(max_length=5, blank=True, default='')
faction_id = models.PositiveIntegerField(blank=True, default=None)
faction_name = models.CharField(max_length=254, blank=True, default='')
objects: ClassVar[EveCharacterManager] = EveCharacterManager()
objects = EveCharacterManager()
provider = EveCharacterProviderManager()
class Meta:
@ -227,7 +226,7 @@ class EveCharacter(models.Model):
models.Index(fields=['faction_id',]),
]
def __str__(self) -> str:
def __str__(self):
return self.character_name
@property

View File

@ -1,8 +1,6 @@
import logging
import os
from typing import Literal
from bravado.client import SwaggerClient
from bravado.exception import HTTPError, HTTPNotFound, HTTPUnprocessableEntity
from jsonschema.exceptions import RefResolutionError
@ -10,7 +8,7 @@ from django.conf import settings
from esi.clients import esi_client_factory
from allianceauth import __version__, __title__, __url__
from allianceauth import __version__
from allianceauth.utils.django import StartupCommand
SWAGGER_SPEC_PATH = os.path.join(os.path.dirname(
@ -38,7 +36,7 @@ class ObjectNotFound(Exception):
self.id = obj_id
self.type = type_name
def __str__(self) -> str:
def __str__(self):
return f'{self.type} with ID {self.id} not found.'
@ -48,13 +46,13 @@ class Entity:
self.id = id
self.name = name
def __str__(self) -> str:
def __str__(self):
return self.name
def __repr__(self) -> str:
def __repr__(self):
return f"<{self.__class__.__name__} ({self.id}): {self.name}>"
def __bool__(self) -> bool:
def __bool__(self):
return bool(self.id)
def __eq__(self, other):
@ -177,11 +175,7 @@ class EveProvider:
class EveSwaggerProvider(EveProvider):
def __init__(self, token=None, adapter=None) -> None:
self._token = token
self.adapter = adapter or self
self._faction_list = None # what are the odds this will change? could cache forever!
def __init__(self, token=None, adapter=None):
if settings.DEBUG or StartupCommand().is_management_command:
self._client = None
logger.info('ESI client will be loaded on-demand')
@ -189,10 +183,9 @@ class EveSwaggerProvider(EveProvider):
logger.info('Loading ESI client')
try:
self._client = esi_client_factory(
token=self._token,
ua_appname=__title__,
ua_version=__version__,
ua_url=__url__,
token=token,
spec_file=SWAGGER_SPEC_PATH,
app_info_text=f"allianceauth v{__version__}"
)
except (HTTPError, RefResolutionError):
logger.exception(
@ -201,18 +194,19 @@ class EveSwaggerProvider(EveProvider):
)
self._client = None
self._token = token
self.adapter = adapter or self
self._faction_list = None # what are the odds this will change? could cache forever!
@property
def client(self) -> SwaggerClient:
def client(self):
if self._client is None:
self._client = esi_client_factory(
token=self._token,
ua_appname=__title__,
ua_version=__version__,
ua_url=__url__,
token=self._token, spec_file=SWAGGER_SPEC_PATH, app_info_text=("allianceauth v" + __version__)
)
return self._client
def __str__(self) -> str:
def __str__(self):
return 'esi'
def get_alliance(self, alliance_id: int) -> Alliance:

File diff suppressed because one or more lines are too long

View File

@ -13,7 +13,7 @@ class BravadoResponseStub:
self.headers = headers if headers else {}
self.raw_bytes = raw_bytes
def __str__(self) -> str:
def __str__(self):
return f"{self.status_code} {self.reason}"

View File

@ -676,6 +676,16 @@ class TestEveSwaggerProvider(TestCase):
self.assertTrue(mock_esi_client_factory.called)
self.assertIsNotNone(my_provider._client)
@patch(MODULE_PATH + '.SWAGGER_SPEC_PATH', SWAGGER_OLD_SPEC_PATH)
@patch(MODULE_PATH + '.settings.DEBUG', False)
@patch('socket.socket')
def test_create_client_on_normal_startup_w_old_swagger_spec(
self, mock_socket
):
mock_socket.side_effect = Exception('Network blocked for testing')
my_provider = EveSwaggerProvider()
self.assertIsNone(my_provider._client)
@patch(MODULE_PATH + '.settings.DEBUG', True)
@patch(MODULE_PATH + '.esi_client_factory')
def test_dont_create_client_on_debug_startup(self, mock_esi_client_factory):
@ -712,6 +722,6 @@ class TestEveSwaggerProvider(TestCase):
my_provider = EveSwaggerProvider()
my_client = my_provider.client
operation = my_client.Universe.get_universe_factions()
self.assertIn(
'AllianceAuth/1.0.0 (dummy@example.net; +https://gitlab.com/allianceauth/allianceauth)', operation.future.request.headers['User-Agent']
self.assertEqual(
operation.future.request.headers['User-Agent'], 'allianceauth v1.0.0 dummy@example.net'
)

View File

@ -1,8 +1,6 @@
from django.apps import AppConfig
from django.utils.translation import gettext_lazy as _
class FatConfig(AppConfig):
name = 'allianceauth.fleetactivitytracking'
label = 'fleetactivitytracking'
verbose_name = _('Fleet Activity Tracking')

View File

@ -1,67 +0,0 @@
# Generated by Django 5.1.6 on 2025-03-04 01:20
import django.db.models.deletion
import django.utils.timezone
from django.conf import settings
from django.db import migrations, models
import allianceauth.framework.api.user
def create_permissions(apps, schema_editor) -> None:
# Remnant of AAv0
User = apps.get_model('auth', 'User')
ContentType = apps.get_model('contenttypes', 'ContentType')
Permission = apps.get_model('auth', 'Permission')
ct = ContentType.objects.get_for_model(User)
Permission.objects.get_or_create(codename="fleetactivitytracking", content_type=ct, name="fleetactivitytracking")
Permission.objects.get_or_create(codename="fleetactivitytracking_statistics", content_type=ct, name="fleetactivitytracking_statistics")
def reverse(apps, schema_editor) -> None:
pass
class Migration(migrations.Migration):
replaces = [('fleetactivitytracking', '0001_initial'), ('fleetactivitytracking', '0002_auto_20160905_2220'), ('fleetactivitytracking', '0003_auto_20160906_2354'), ('fleetactivitytracking', '0004_make_strings_more_stringy'), ('fleetactivitytracking', '0005_remove_fat_name'), ('fleetactivitytracking', '0006_auto_20180803_0430'), ('fleetactivitytracking', '0007_sentinel_user')]
initial = True
dependencies = [
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
('eveonline', '0019_v5squash'),
]
operations = [
migrations.CreateModel(
name='Fatlink',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('fatdatetime', models.DateTimeField(default=django.utils.timezone.now)),
('duration', models.PositiveIntegerField()),
('fleet', models.CharField(max_length=254)),
('hash', models.CharField(max_length=254, unique=True)),
('creator', models.ForeignKey(on_delete=models.SET(allianceauth.framework.api.user.get_sentinel_user), to=settings.AUTH_USER_MODEL)),
],
options={
'permissions': ()
},
),
migrations.CreateModel(
name='Fat',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('system', models.CharField(max_length=30)),
('shiptype', models.CharField(max_length=100)),
('station', models.CharField(max_length=125)),
('character', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='eveonline.evecharacter')),
('fatlink', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='fleetactivitytracking.fatlink')),
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
],
options={
'unique_together': {('character', 'fatlink')},
},
),
migrations.RunPython(create_permissions, reverse)
]

View File

@ -13,15 +13,7 @@ class Fatlink(models.Model):
hash = models.CharField(max_length=254, unique=True)
creator = models.ForeignKey(User, on_delete=models.SET(get_sentinel_user))
class Meta:
permissions = (
# Intentionally Commented out
# AAv0 has these in the Auth_ Content Type
# ('fleetactivitytracking', 'fleetactivitytracking'),
# ('fleetactivitytracking_statistics', 'fleetactivitytracking_statistics'),
)
def __str__(self) -> str:
def __str__(self):
return self.fleet
@ -34,7 +26,7 @@ class Fat(models.Model):
user = models.ForeignKey(User, on_delete=models.CASCADE)
class Meta:
unique_together = (("character", "fatlink"),)
unique_together = (('character', 'fatlink'),)
def __str__(self) -> str:
def __str__(self):
return f"Fat-link for {self.character.character_name}"

View File

@ -36,7 +36,7 @@
<th class="text-center">{% translate "Character" %}</th>
<th class="text-center">{% translate "System" %}</th>
<th class="text-center">{% translate "Ship" %}</th>
<th class="text-center">{% translate "EVE time" %}</th>
<th class="text-center">{% translate "Eve Time" %}</th>
<th></th>
</tr>

View File

@ -72,7 +72,7 @@
<tr>
<th class="text-center">{% translate "Fleet" %}</th>
<th class="text-center">{% translate "Creator" %}</th>
<th class="text-center">{% translate "EVE time" %}</th>
<th class="text-center">{% translate "Eve Time" %}</th>
<th class="text-center">{% translate "Duration" %}</th>
<th class="text-center">{% translate "Edit" %}</th>
</tr>
@ -80,7 +80,7 @@
{% for link in created_fats %}
<tr>
<td class="text-center">
<a href="{% url 'fatlink:click' link.hash %}" class="badge text-bg-primary">
<a href="{% url 'fatlink:click' link.hash %}" class="badge bg-primary">
{{ link.fleet }}
</a>
</td>

View File

@ -41,7 +41,7 @@
<th scope="col" class="text-center">{% translate "Character" %}</th>
<th scope="col" class="text-center">{% translate "System" %}</th>
<th scope="col" class="text-center">{% translate "Ship" %}</th>
<th scope="col" class="text-center">{% translate "EVE time" %}</th>
<th scope="col" class="text-center">{% translate "Eve Time" %}</th>
</tr>
{% for fat in fats %}
@ -89,7 +89,7 @@
<th scope="col" class="text-center">{% translate "Name" %}</th>
<th scope="col" class="text-center">{% translate "Creator" %}</th>
<th scope="col" class="text-center">{% translate "Fleet" %}</th>
<th scope="col" class="text-center">{% translate "EVE time" %}</th>
<th scope="col" class="text-center">{% translate "Eve Time" %}</th>
<th scope="col" class="text-center">{% translate "Duration" %}</th>
<th scope="col" class="text-center">{% translate "Edit" %}</th>
</tr>
@ -97,7 +97,7 @@
{% for link in fatlinks %}
<tr>
<td class="text-center">
<a href="{% url 'fatlink:click' link.hash %}" class="badge text-bg-primary">{{ link.fleet }}</a>
<a href="{% url 'fatlink:click' link.hash %}" class="badge bg-primary">{{ link.fleet }}</a>
</td>
<td class="text-center">{{ link.creator.username }}</td>
<td class="text-center">{{ link.fleet }}</td>

View File

@ -9,39 +9,24 @@ from allianceauth.authentication.models import CharacterOwnership
from allianceauth.eveonline.models import EveCharacter
def get_all_characters_from_user(user: User, main_first: bool = False) -> list:
def get_all_characters_from_user(user: User) -> list:
"""
Get all characters from a user
This function retrieves all characters associated with a given user, optionally ordering them
with the main character first.
If the user is None, an empty list is returned.
Get all characters from a user or an empty list
when no characters are found for the user or the user is None
:param user: The user whose characters are to be retrieved
:type user: User
:param main_first: If True, the main character will be listed first
:type main_first: bool
:return: A list of EveCharacter objects associated with the user
:rtype: list[EveCharacter]
:param user:
:type user:
:return:
:rtype:
"""
if user is None:
return []
try:
if main_first:
characters = [
char.character
for char in CharacterOwnership.objects.filter(user=user).order_by(
"-character__userprofile", "character__character_name"
)
]
else:
characters = [
char.character
for char in CharacterOwnership.objects.filter(user=user).order_by(
"character__character_name"
)
]
characters = [
char.character for char in CharacterOwnership.objects.filter(user=user)
]
except AttributeError:
return []

View File

@ -3,7 +3,6 @@ Framework App Config
"""
from django.apps import AppConfig
from django.utils.translation import gettext_lazy as _
class FrameworkConfig(AppConfig):
@ -13,4 +12,3 @@ class FrameworkConfig(AppConfig):
name = "allianceauth.framework"
label = "framework"
verbose_name = _("Framework")

View File

@ -5,24 +5,6 @@
* to be used throughout Alliance Auth and its Community Apps
*/
/* General
------------------------------------------------------------------------------------- */
@media all {
.navbar-toggler.collapsed {
transform: rotate(180deg);
}
ul#nav-right:has(li) + ul#nav-right-character-control > li:first-child {
display: list-item !important;
}
}
@media all and (max-width: 991px) {
ul#nav-left:has(li) + ul#nav-right + ul#nav-right-character-control > li:first-child {
display: list-item !important;
}
}
/* Bootstrap fixes
------------------------------------------------------------------------------------- */
@media all {

View File

@ -1,105 +0,0 @@
"""
Custom static files storage for Alliance Auth.
This module defines a custom static files storage class for
Alliance Auth, named `AaManifestStaticFilesStorage`.
Using `ManifestStaticFilesStorage` will give us a hashed name for
our static files, which is useful for cache busting.
This storage class extends Django's `ManifestStaticFilesStorage` to ignore missing files,
which the original class does not handle, and log them in debug mode.
It is useful for handling cases where static files may not exist, such as when a
CSS file references a background image that is not present in the static files directory.
With debug mode enabled, it will print a message for each missing file when running `collectstatic`,
which can help identify issues with static file references during development.
"""
from django.conf import settings
from django.contrib.staticfiles.storage import ManifestStaticFilesStorage
class AaManifestStaticFilesStorage(ManifestStaticFilesStorage):
"""
Custom static files storage that ignores missing files.
"""
@classmethod
def _cleanup_name(cls, name: str) -> str:
"""
Clean up the name by removing quotes.
This method is used to ensure that the name does not contain any quotes,
which can cause issues with file paths.
:param name: The name of the static file.
:type name: str
:return: The cleaned-up name without quotes.
:rtype: str
"""
# Remove quotes from the name
return name.replace('"', "").replace("'", "")
def __init__(self, *args, **kwargs):
"""
Initialize the static files storage, ignoring missing files.
:param args:
:type args:
:param kwargs:
:type kwargs:
"""
self.missing_files = []
super().__init__(*args, **kwargs)
def hashed_name(self, name, content=None, filename=None):
"""
Generate a hashed name for the given static file, ignoring missing files.
Ignore missing files, e.g. non-existent background image referenced from css.
Returns the original filename if the referenced file doesn't exist.
:param name: The name of the static file to hash.
:type name: str
:param content: The content of the static file, if available.
:type content: bytes | None
:param filename: The original filename of the static file, if available.
:type filename: str | None
:return: The hashed name of the static file, or the original name if the file is missing.
:rtype: str
"""
try:
clean_name = self._cleanup_name(name)
return super().hashed_name(clean_name, content, filename)
except ValueError as e:
if settings.DEBUG:
# In debug mode, we log the missing file message
message = e.args[0].split(" with ")[0]
self.missing_files.append(message)
# print(f'\x1b[0;30;41m{message}\x1b[0m')
return name
def post_process(self, *args, **kwargs):
"""
Post-process the static files, printing any missing files in debug mode.
:param args:
:type args:
:param kwargs:
:type kwargs:
:return:
:rtype:
"""
yield from super().post_process(*args, **kwargs)
if settings.DEBUG:
# In debug mode, print the missing files
for message in sorted(set(self.missing_files)):
print(f"\x1b[0;30;41m{message}\x1b[0m")

View File

@ -2,14 +2,12 @@
{# {% include "framework/header/page-header.html" with title="Foobar" subtitle="Barfoo" %}#}
{% if title %}
<header class="aa-page-header mb-3">
<h1 class="page-header text-center">
{{ title }}
<h1 class="page-header text-center mb-3">
{{ title }}
{% if subtitle %}
<br>
<small class="text-muted">{{ subtitle }}</small>
{% endif %}
</h1>
</header>
{% if subtitle %}
<br>
<small class="text-muted">{{ subtitle }}</small>
{% endif %}
</h1>
{% endif %}

View File

@ -1,11 +1,10 @@
from django.apps import AppConfig
from django.utils.translation import gettext_lazy as _
class GroupManagementConfig(AppConfig):
name = 'allianceauth.groupmanagement'
label = 'groupmanagement'
verbose_name = _('Group Management')
verbose_name = 'Group Management'
def ready(self):
from . import signals # noqa: F401

View File

@ -1,102 +0,0 @@
# Generated by Django 5.1.6 on 2025-03-04 02:50
import django.contrib.auth.models
import django.db.models.deletion
import django.utils.timezone
from django.conf import settings
from django.db import migrations, models
def create_permissions(apps, schema_editor) -> None:
# Remnant of AAv0
User = apps.get_model('auth', 'User')
ContentType = apps.get_model('contenttypes', 'ContentType')
Permission = apps.get_model('auth', 'Permission')
ct = ContentType.objects.get_for_model(User)
Permission.objects.get_or_create(codename="group_management", content_type=ct, name="group_management")
def reverse(apps, schema_editor) -> None:
pass
class Migration(migrations.Migration):
replaces = [('groupmanagement', '0001_initial'), ('groupmanagement', '0002_auto_20160906_2354'), ('groupmanagement', '0003_default_groups'), ('groupmanagement', '0004_authgroup'), ('groupmanagement', '0005_authgroup_public'), ('groupmanagement', '0006_request_groups_perm'), ('groupmanagement', '0007_on_delete'), ('groupmanagement', '0008_remove_authgroup_permissions'), ('groupmanagement', '0009_requestlog'), ('groupmanagement', '0010_authgroup_states'), ('groupmanagement', '0011_requestlog_date'), ('groupmanagement', '0012_group_leads'), ('groupmanagement', '0013_fix_requestlog_date_field'), ('groupmanagement', '0014_auto_20200918_1412'), ('groupmanagement', '0015_make_descriptions_great_again'), ('groupmanagement', '0016_remove_grouprequest_status_field'), ('groupmanagement', '0017_improve_groups_documentation'), ('groupmanagement', '0018_reservedgroupname'), ('groupmanagement', '0019_adding_restricted_to_groups')]
initial = True
dependencies = [
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
('authentication', '0025_v5squash'),
('eveonline', '0019_v5squash'),
]
operations = [
migrations.CreateModel(
name='GroupRequest',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('leave_request', models.BooleanField(default=0)),
('group', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='auth.group')),
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
],
),
migrations.CreateModel(
name='AuthGroup',
fields=[
('group', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, primary_key=True, serialize=False, to='auth.group')),
('internal', models.BooleanField(default=True, help_text='Internal group, users cannot see, join or request to join this group.<br>Used for groups such as Members, Corp_*, Alliance_* etc.<br><b>Overrides Hidden and Open options when selected.</b>')),
('hidden', models.BooleanField(default=True, help_text='Group is hidden from users but can still join with the correct link.')),
('open', models.BooleanField(default=False, help_text='Group is open and users will be automatically added upon request.<br>If the group is not open users will need their request manually approved.')),
('description', models.TextField(blank=True, help_text='Short description <i>(max. 512 characters)</i> of the group shown to users.', max_length=512)),
('group_leaders', models.ManyToManyField(blank=True, help_text='Group leaders can process requests for this group. Use the <code>auth.group_management</code> permission to allow a user to manage all groups.<br>', related_name='leads_groups', to=settings.AUTH_USER_MODEL)),
('public', models.BooleanField(default=False, help_text='Group is public. Any registered user is able to join this group, with visibility based on the other options set for this group.<br>Auth will not remove users from this group automatically when they are no longer authenticated.')),
('group_leader_groups', models.ManyToManyField(blank=True, help_text='Members of leader groups can process requests for this group. Use the <code>auth.group_management</code> permission to allow a user to manage all groups.<br>', related_name='leads_group_groups', to='auth.group')),
('states', models.ManyToManyField(blank=True, help_text='States listed here will have the ability to join this group provided they have the proper permissions.<br>', related_name='valid_states', to='authentication.state')),
('restricted', models.BooleanField(default=False, help_text='Group is restricted. This means that adding or removing users for this group requires a superuser admin.')),
],
options={
'default_permissions': (),
'permissions': (('request_groups', 'Can request non-public groups'),),
},
),
migrations.CreateModel(
name='Group',
fields=[
],
options={
'verbose_name': 'group',
'indexes': [],
'proxy': True,
'verbose_name_plural': 'groups',
},
bases=('auth.group',),
managers=[
('objects', django.contrib.auth.models.GroupManager()),
],
),
migrations.CreateModel(
name='RequestLog',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('request_type', models.BooleanField(null=True)),
('request_info', models.CharField(max_length=254)),
('action', models.BooleanField(default=0)),
('group', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='auth.group')),
('request_actor', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
('date', models.DateTimeField(auto_now_add=True)),
],
),
migrations.CreateModel(
name='ReservedGroupName',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('name', models.CharField(help_text='Name that can not be used for groups.', max_length=150, unique=True, verbose_name='name')),
('reason', models.TextField(help_text='Reason why this name is reserved.', verbose_name='reason')),
('created_by', models.CharField(help_text='Name of the user who created this entry.', max_length=255, verbose_name='created by')),
('created_at', models.DateTimeField(default=django.utils.timezone.now, help_text='Date when this entry was created', verbose_name='created at')),
],
),
migrations.RunPython(create_permissions, reverse)
]

View File

@ -15,7 +15,7 @@ class GroupRequest(models.Model):
user = models.ForeignKey(User, on_delete=models.CASCADE)
group = models.ForeignKey(Group, on_delete=models.CASCADE)
def __str__(self) -> str:
def __str__(self):
return self.user.username + ":" + self.group.name
@property
@ -50,10 +50,10 @@ class RequestLog(models.Model):
request_actor = models.ForeignKey(User, on_delete=models.CASCADE)
date = models.DateTimeField(auto_now_add=True)
def __str__(self) -> str:
def __str__(self):
return self.pk
def requestor(self) -> str:
def requestor(self):
return self.request_info.split(":")[0]
def type_to_str(self):
@ -176,13 +176,10 @@ class AuthGroup(models.Model):
class Meta:
permissions = (
("request_groups", _("Can request non-public groups")),
# Intentionally Commented out
# AAv0 has these in the Auth_ Content Type
# ('group_management', 'group_management'))
)
default_permissions = ()
def __str__(self) -> str:
def __str__(self):
return self.group.name
def group_request_approvers(self) -> set[User]:

View File

@ -39,12 +39,12 @@
<td>
{% if group.authgroup.hidden %}
<span class="badge text-bg-info">{% translate "Hidden" %}</span>
<span class="badge bg-info">{% translate "Hidden" %}</span>
{% endif %}
{% if group.authgroup.open %}
<span class="badge text-bg-success">{% translate "Open" %}</span>
<span class="badge bg-success">{% translate "Open" %}</span>
{% else %}
<span class="badge text-bg-secondary">{% translate "Requestable" %}</span>
<span class="badge bg-secondary">{% translate "Requestable" %}</span>
{% endif %}
</td>

View File

@ -17,7 +17,7 @@
<li class="nav-item">
<a class="nav-link" href="{% url 'groupmanagement:management' %}">{% translate "Group Management" %}
{% if req_count %}
<span class="badge text-bg-secondary">{{ req_count }}</span>
<span class="badge bg-secondary">{{ req_count }}</span>
{% endif %}
</a>
</li>
@ -33,8 +33,8 @@
<th>{% translate "Description" %}</th>
<th>
{% translate "Leaders" %}<br>
<span class="my-1 me-1 fw-lighter badge text-bg-primary">{% translate "User" %}</span>
<span class="my-1 me-1 fw-lighter badge text-bg-secondary">{% translate "Group" %}</span>
<span class="my-1 me-1 fw-lighter badge bg-primary">{% translate "User" %}</span>
<span class="my-1 me-1 fw-lighter badge bg-secondary">{% translate "Group" %}</span>
</th>
<th></th>
</tr>
@ -53,13 +53,13 @@
{% if g.group.authgroup.group_leaders.all.count %}
{% for leader in g.group.authgroup.group_leaders.all %}
{% if leader.profile.main_character %}
<span class="my-1 me-1 badge text-bg-primary">{{leader.profile.main_character}}</span>
<span class="my-1 me-1 badge bg-primary">{{leader.profile.main_character}}</span>
{% endif %}
{% endfor %}
{% endif %}
{% if g.group.authgroup.group_leader_groups.all.count %}
{% for group in g.group.authgroup.group_leader_groups.all %}
<span class="my-1 me-1 badge text-bg-secondary">{{group.name}}</span>
<span class="my-1 me-1 badge bg-secondary">{{group.name}}</span>
{% endfor %}
{% endif %}
</td>

View File

@ -19,7 +19,7 @@
{% translate "Join Requests" %}
{% if acceptrequests %}
<span class="badge text-bg-secondary">{{ acceptrequests|length }}</span>
<span class="badge bg-secondary">{{ acceptrequests|length }}</span>
{% endif %}
</a>
</li>
@ -30,7 +30,7 @@
{% translate "Leave Requests" %}
{% if leaverequests %}
<span class="badge text-bg-secondary">{{ leaverequests|length }}</span>
<span class="badge bg-secondary">{{ leaverequests|length }}</span>
{% endif %}
</a>
</li>

View File

@ -1,8 +1,6 @@
from django.apps import AppConfig
from django.utils.translation import gettext_lazy as _
class HRApplicationsConfig(AppConfig):
name = 'allianceauth.hrapplications'
label = 'hrapplications'
verbose_name = _('HR Applications')

View File

@ -1,100 +0,0 @@
# Generated by Django 5.1.6 on 2025-03-04 04:31
import sortedm2m.fields
import django.db.models.deletion
from django.conf import settings
from django.db import migrations, models
def create_permissions(apps, schema_editor) -> None:
# Remnant of AAv0
User = apps.get_model('auth', 'User')
ContentType = apps.get_model('contenttypes', 'ContentType')
Permission = apps.get_model('auth', 'Permission')
ct = ContentType.objects.get_for_model(User)
Permission.objects.get_or_create(codename="human_resources", content_type=ct, name="human_resources")
def reverse(apps, schema_editor) -> None:
pass
class Migration(migrations.Migration):
replaces = [('hrapplications', '0001_initial'), ('hrapplications', '0002_choices_for_questions'), ('hrapplications', '0003_applicationquestion_multi_select'), ('hrapplications', '0004_make_strings_more_stringy'), ('hrapplications', '0005_sorted_questions'), ('hrapplications', '0006_remove_legacy_models'), ('hrapplications', '0007_auto_20200918_1412')]
initial = True
dependencies = [
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
('eveonline', '0019_v5squash'),
]
operations = [
migrations.CreateModel(
name='ApplicationQuestion',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('title', models.CharField(max_length=254, verbose_name='Question')),
('help_text', models.CharField(blank=True, max_length=254, null=True)),
('multi_select', models.BooleanField(default=False)),
],
),
migrations.CreateModel(
name='ApplicationForm',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('corp', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, to='eveonline.evecorporationinfo')),
('questions', sortedm2m.fields.SortedManyToManyField(help_text=None, to='hrapplications.applicationquestion')),
],
),
migrations.CreateModel(
name='ApplicationChoice',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('choice_text', models.CharField(max_length=200, verbose_name='Choice')),
('question', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='choices', to='hrapplications.applicationquestion')),
],
),
migrations.CreateModel(
name='Application',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('approved', models.BooleanField(blank=True, default=None, null=True)),
('created', models.DateTimeField(auto_now_add=True)),
('form', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='applications', to='hrapplications.applicationform')),
('reviewer', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to=settings.AUTH_USER_MODEL)),
('reviewer_character', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='eveonline.evecharacter')),
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='applications', to=settings.AUTH_USER_MODEL)),
],
options={
'permissions': (('approve_application', 'Can approve applications'), ('reject_application', 'Can reject applications'), ('view_apis', 'Can view applicant APIs')),
'unique_together': {('form', 'user')},
},
),
migrations.CreateModel(
name='ApplicationComment',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('text', models.TextField()),
('created', models.DateTimeField(auto_now_add=True)),
('application', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='comments', to='hrapplications.application')),
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
],
),
migrations.CreateModel(
name='ApplicationResponse',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('answer', models.TextField()),
('application', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='responses', to='hrapplications.application')),
('question', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='hrapplications.applicationquestion')),
],
options={
'unique_together': {('question', 'application')},
},
),
migrations.RunPython(create_permissions, reverse)
]

View File

@ -1,6 +1,5 @@
from sortedm2m.fields import SortedManyToManyField
from typing import ClassVar
from django.contrib.auth.models import User
from django.db import models
@ -14,7 +13,7 @@ class ApplicationQuestion(models.Model):
help_text = models.CharField(max_length=254, blank=True)
multi_select = models.BooleanField(default=False)
def __str__(self) -> str:
def __str__(self):
return "Question: " + self.title
@ -22,7 +21,7 @@ class ApplicationChoice(models.Model):
question = models.ForeignKey(ApplicationQuestion,on_delete=models.CASCADE,related_name="choices")
choice_text = models.CharField(max_length=200, verbose_name='Choice')
def __str__(self) -> str:
def __str__(self):
return self.choice_text
@ -30,14 +29,7 @@ class ApplicationForm(models.Model):
questions = SortedManyToManyField(ApplicationQuestion)
corp = models.OneToOneField(EveCorporationInfo, on_delete=models.CASCADE)
class Meta:
permissions = (
# Intentionally Commented out
# AAv0 has these in the Auth_ Content Type
# ('human_resources', 'human_resources'))
)
def __str__(self) -> str:
def __str__(self):
return str(self.corp)
@ -49,16 +41,16 @@ class Application(models.Model):
reviewer_character = models.ForeignKey(EveCharacter, on_delete=models.SET_NULL, blank=True, null=True)
created = models.DateTimeField(auto_now_add=True)
objects: ClassVar[ApplicationManager] = ApplicationManager()
objects = ApplicationManager()
class Meta:
permissions = (
('approve_application', 'Can approve applications'),
('reject_application', 'Can reject applications'),
)
('approve_application', 'Can approve applications'), ('reject_application', 'Can reject applications'),
('view_apis', 'Can view applicant APIs'),)
unique_together = ('form', 'user')
def __str__(self) -> str:
def __str__(self):
return str(self.user) + " Application To " + str(self.form)
@property
@ -83,19 +75,19 @@ class ApplicationResponse(models.Model):
question = models.ForeignKey(ApplicationQuestion, on_delete=models.CASCADE)
application = models.ForeignKey(Application, on_delete=models.CASCADE, related_name='responses')
answer = models.TextField()
class Meta:
unique_together = ('question', 'application')
def __str__(self) -> str:
def __str__(self):
return str(self.application) + " Answer To " + str(self.question)
class ApplicationComment(models.Model):
application = models.ForeignKey(Application, on_delete=models.CASCADE, related_name='comments')
user = models.ForeignKey(User, on_delete=models.CASCADE)
text = models.TextField()
created = models.DateTimeField(auto_now_add=True)
def __str__(self) -> str:
def __str__(self):
return str(self.user) + " comment on " + str(self.application)

View File

@ -43,11 +43,11 @@
<td class="text-center">{{ personal_app.form.corp.corporation_name }}</td>
<td class="text-center">
{% if personal_app.approved == None %}
<div class="badge text-bg-warning">{% translate "Pending" %}</div>
<div class="badge bg-warning">{% translate "Pending" %}</div>
{% elif personal_app.approved == True %}
<div class="badge text-bg-success">{% translate "Approved" %}</div>
<div class="badge bg-success">{% translate "Approved" %}</div>
{% else %}
<div class="badge text-bg-danger">{% translate "Rejected" %}</div>
<div class="badge bg-danger">{% translate "Rejected" %}</div>
{% endif %}
</td>
<td class="text-center">
@ -133,14 +133,14 @@
<td class="text-center">
{% if app.approved == None %}
{% if app.reviewer_str %}
<div class="badge text-bg-info">{% translate "Reviewer:" %} {{ app.reviewer_str }}</div>
<div class="badge bg-info">{% translate "Reviewer:" %} {{ app.reviewer_str }}</div>
{% else %}
<div class="badge text-bg-warning">{% translate "Pending" %}</div>
<div class="badge bg-warning">{% translate "Pending" %}</div>
{% endif %}
{% elif app.approved == True %}
<div class="badge text-bg-success">{% translate "Approved" %}</div>
<div class="badge bg-success">{% translate "Approved" %}</div>
{% else %}
<div class="badge text-bg-danger">{% translate "Rejected" %}</div>
<div class="badge bg-danger">{% translate "Rejected" %}</div>
{% endif %}
</td>
<td class="text-center">
@ -177,14 +177,14 @@
<td class="text-center">
{% if app.approved == None %}
{% if app.reviewer_str %}
<div class="badge text-bg-info">{% translate "Reviewer:" %} {{ app.reviewer_str }}</div>
<div class="badge bg-info">{% translate "Reviewer:" %} {{ app.reviewer_str }}</div>
{% else %}
<div class="badge text-bg-warning">{% translate "Pending" %}</div>
<div class="badge bg-warning">{% translate "Pending" %}</div>
{% endif %}
{% elif app.approved == True %}
<div class="badge text-bg-success">{% translate "Approved" %}</div>
<div class="badge bg-success">{% translate "Approved" %}</div>
{% else %}
<div class="badge text-bg-danger">{% translate "Rejected" %}</div>
<div class="badge bg-danger">{% translate "Rejected" %}</div>
{% endif %}
</td>
<td class="text-center">

View File

@ -43,11 +43,11 @@
<td>{{ app.form.corp }}</td>
<td class="text-center">
{% if app.approved == None %}
<div class="badge text-bg-warning">{% translate "Pending" %}</div>
<div class="badge bg-warning">{% translate "Pending" %}</div>
{% elif app.approved == True %}
<div class="badge text-bg-success">{% translate "Approved" %}</div>
<div class="badge bg-success">{% translate "Approved" %}</div>
{% else %}
<div class="badge text-bg-danger">{% translate "Rejected" %}</div>
<div class="badge bg-danger">{% translate "Rejected" %}</div>
{% endif %}
</td>
<td class="text-end">

View File

@ -31,7 +31,7 @@
</div>
<div class="card mb-3">
<div class="card-header text-bg-info">
<div class="card-header bg-info">
<div class="card-title mb-0">{% translate "Applicant" %}</div>
</div>
@ -50,7 +50,7 @@
</div>
<div class="card mb-3">
<div class="card-header text-bg-info">
<div class="card-header bg-info">
<div class="card-title mb-0">{% translate "Characters" %}</div>
</div>

File diff suppressed because it is too large Load Diff

View File

@ -13,7 +13,7 @@ msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2025-06-19 20:23+1000\n"
"POT-Creation-Date: 2025-02-25 19:17+1000\n"
"PO-Revision-Date: 2023-11-08 13:50+0000\n"
"Last-Translator: Peter Pfeufer, 2025\n"
"Language-Team: German (https://app.transifex.com/alliance-auth/teams/107430/de/)\n"
@ -23,10 +23,6 @@ msgstr ""
"Language: de\n"
"Plural-Forms: nplurals=2; plural=(n != 1);\n"
#: allianceauth/analytics/apps.py:8
msgid "Analytics"
msgstr "Analyse"
#: allianceauth/analytics/models.py:22
msgid "Google Analytics Universal"
msgstr "Google Analytics Universal"
@ -35,10 +31,6 @@ msgstr "Google Analytics Universal"
msgid "Google Analytics V4"
msgstr "Google Analytics V4"
#: allianceauth/authentication/apps.py:9
msgid "Authentication"
msgstr "Authentifizierung"
#: allianceauth/authentication/constants.py:6
msgid ""
"This software has exceeded the error limit for ESI. If you are a user, "
@ -53,7 +45,7 @@ msgstr ""
"Antworten zu erhalten. Für Tipps dazu chatte mit uns unter ##3rd-party-dev-"
"and-esi auf dem EVE Online Discord. https://www.eveonline.com/discord"
#: allianceauth/authentication/decorators.py:52
#: allianceauth/authentication/decorators.py:49
msgid "A main character is required to perform that action. Add one below."
msgstr ""
"Zur Ausführung dieser Aktion ist ein Hauptcharakter erforderlich. Füge unten"
@ -69,91 +61,91 @@ msgid "You are not allowed to add or remove these restricted groups: %s"
msgstr ""
"Du kannst diese eingeschränkten Gruppen nicht hinzufügen oder entfernen: %s"
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:106
#: allianceauth/authentication/models.py:70
#: allianceauth/project_template/project_name/settings/base.py:105
msgid "English"
msgstr "Englisch"
#: allianceauth/authentication/models.py:73
#: allianceauth/authentication/models.py:71
msgid "Czech"
msgstr "Tschechisch"
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:108
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:107
msgid "German"
msgstr "Deutsch"
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:109
#: allianceauth/authentication/models.py:73
#: allianceauth/project_template/project_name/settings/base.py:108
msgid "Spanish"
msgstr "Spanisch"
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:110
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:109
msgid "Italian"
msgstr "Italienisch"
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:111
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:110
msgid "Japanese"
msgstr "Japanisch"
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:112
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:111
msgid "Korean"
msgstr "Koreanisch"
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:112
msgid "French"
msgstr "Französisch"
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:116
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:115
msgid "Russian"
msgstr "Russisch"
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:114
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
msgid "Dutch"
msgstr "Niederländisch"
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:115
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:114
msgid "Polish"
msgstr "Polnisch"
#: allianceauth/authentication/models.py:83
#: allianceauth/project_template/project_name/settings/base.py:117
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:116
msgid "Ukrainian"
msgstr "Ukrainisch"
#: allianceauth/authentication/models.py:84
#: allianceauth/project_template/project_name/settings/base.py:118
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:117
msgid "Simplified Chinese"
msgstr "Vereinfachtes Chinesisch"
#: allianceauth/authentication/models.py:100
#: allianceauth/menu/templates/menu/menu-user.html:67
#: allianceauth/authentication/models.py:98
#: allianceauth/menu/templates/menu/menu-user.html:42
msgid "Language"
msgstr "Sprache"
#: allianceauth/authentication/models.py:105
#: allianceauth/authentication/models.py:103
#: allianceauth/templates/allianceauth/night-toggle.html:6
msgid "Night Mode"
msgstr "Nachtmodus"
#: allianceauth/authentication/models.py:109
#: allianceauth/theme/templates/theme/theme_select.html:4
#: allianceauth/authentication/models.py:107
#: allianceauth/menu/templates/menu/menu-user.html:46
msgid "Theme"
msgstr "Theme"
#: allianceauth/authentication/models.py:126
#: allianceauth/authentication/models.py:124
#, python-format
msgid "State changed to: %s"
msgstr "Status geändert zu %s"
#: allianceauth/authentication/models.py:127
#: allianceauth/authentication/models.py:125
#, python-format
msgid "Your user's state is now: %(state)s"
msgstr "Dein Nutzerstatus ist nun %(state)s"
@ -215,8 +207,6 @@ msgstr "Status:"
#: allianceauth/authentication/templates/authentication/tokens.html:7
#: allianceauth/authentication/templates/authentication/tokens.html:11
#: allianceauth/menu/templates/menu/menu-user.html:133
#: allianceauth/menu/templates/menu/menu-user.html:136
#: allianceauth/templates/allianceauth/top-menu-user-dropdown.html:62
msgid "Token Management"
msgstr "Token-Verwaltung"
@ -295,7 +285,7 @@ msgstr "Registrieren"
msgid "Invalid or expired activation link."
msgstr "Ungültiger oder abgelaufener Aktivierungslink."
#: allianceauth/authentication/views.py:158
#: allianceauth/authentication/views.py:157
#, python-format
msgid ""
"Cannot change main character to %(char)s: character owned by a different "
@ -304,24 +294,24 @@ msgstr ""
"Der Haputcharakter kann nicht zu %(char)s geändert werden. Dieser Charakter "
"gehört zu einem anderen Konto."
#: allianceauth/authentication/views.py:165
#: allianceauth/authentication/views.py:164
#, python-format
msgid "Changed main character to %s"
msgstr "Hautpcharakter geändert zu %s"
#: allianceauth/authentication/views.py:179
#: allianceauth/authentication/views.py:178
#, python-format
msgid "Added %(name)s to your account."
msgstr "%(name)s zu Deinem Konto hinzugefügt."
#: allianceauth/authentication/views.py:181
#: allianceauth/authentication/views.py:180
#, python-format
msgid "Failed to add %(name)s to your account: they already have an account."
msgstr ""
"Es ist nicht möglich %(name)s zu Deinem Konto hinzu zu fügen: Dieser hat "
"bereits ein eigenes Konto."
#: allianceauth/authentication/views.py:226
#: allianceauth/authentication/views.py:225
msgid ""
"Unable to authenticate as the selected character. Please log in with the "
"main character associated with this account."
@ -330,11 +320,11 @@ msgstr ""
"Bitte melde Dich mit dem Hauptcharakter an, der mit diesem Konto verknüpft "
"ist."
#: allianceauth/authentication/views.py:293
#: allianceauth/authentication/views.py:292
msgid "Registration token has expired."
msgstr "Token zur Registrierung ist abgelaufen."
#: allianceauth/authentication/views.py:354
#: allianceauth/authentication/views.py:353
msgid ""
"Sent confirmation email. Please follow the link to confirm your email "
"address."
@ -342,15 +332,15 @@ msgstr ""
"Bestätigungs-E-Mail gesendet. Bitte folge dem Link, um Deine E-Mail-Adresse "
"zu bestätigen."
#: allianceauth/authentication/views.py:360
#: allianceauth/authentication/views.py:359
msgid "Confirmed your email address. Please login to continue."
msgstr "Deine E-Mail Adresse wurde bestätigt. Bitte einloggen zum Fortfahren."
#: allianceauth/authentication/views.py:366
#: allianceauth/authentication/views.py:365
msgid "Registration of new accounts is not allowed at this time."
msgstr "Registrierung von neuen Konten ist zur Zeit nicht erlaubt."
#: allianceauth/corputils/apps.py:8 allianceauth/corputils/auth_hooks.py:12
#: allianceauth/corputils/auth_hooks.py:12
msgid "Corporation Stats"
msgstr "Corp Statistiken"
@ -456,10 +446,6 @@ msgstr "Ausgewählte Corp hat bereits ein Statistik Modul."
msgid "Failed to gather corporation statistics with selected token."
msgstr "Fehler beim Sammeln von Corpstatistiken mit ausgewählten Token."
#: allianceauth/crontab/apps.py:16
msgid "Crontab"
msgstr "Crontab"
#: allianceauth/crontab/models.py:13
msgid "Minute Offset"
msgstr "Minuten-Offset"
@ -493,15 +479,6 @@ msgstr "Dein eigenes CSS"
msgid "This CSS will be added to the site after the default CSS."
msgstr "Dieses CSS wird der Site nach dem Standard-CSS hinzugefügt."
#: allianceauth/eveonline/apps.py:8
msgid "EVE Online"
msgstr "EVE Online"
#: allianceauth/eveonline/autogroups/apps.py:8
msgid "EVE Online Autogroups"
msgstr "EVE Online Autogrouppen"
#: allianceauth/fleetactivitytracking/apps.py:8
#: allianceauth/fleetactivitytracking/auth_hooks.py:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/characternotexisting.html:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkcreate.html:11
@ -611,12 +588,10 @@ msgstr "Schiff"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkpersonalmonthlystatisticsview.html:75
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:44
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:92
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/templates/allianceauth/top-menu.html:23
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
#: allianceauth/timerboard/templates/timerboard/timertable.html:12
msgid "EVE time"
msgstr "EVE Zeit"
msgid "Eve Time"
msgstr "Eve Zeit"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkmodify.html:49
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:52
@ -782,11 +757,6 @@ msgstr ""
"Die Flottenteilnahme für {character.character_name} kann nicht registriert "
"werden. Der Charakter muss hierzu online sein."
#: allianceauth/framework/apps.py:16
msgid "Framework"
msgstr "Framework"
#: allianceauth/groupmanagement/apps.py:8
#: allianceauth/groupmanagement/auth_hooks.py:18
#: allianceauth/groupmanagement/templates/groupmanagement/groups.html:18
msgid "Group Management"
@ -1041,7 +1011,7 @@ msgid "Hidden"
msgstr "Verborgen"
#: allianceauth/groupmanagement/templates/groupmanagement/groupmembership.html:45
#: allianceauth/templates/allianceauth/admin-status/overview.html:15
#: allianceauth/templates/allianceauth/admin-status/overview.html:16
msgid "Open"
msgstr "Öffnen"
@ -1094,7 +1064,7 @@ msgstr "Verlassen"
#: allianceauth/hrapplications/templates/hrapplications/management.html:182
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:46
#: allianceauth/hrapplications/templates/hrapplications/view.html:25
#: allianceauth/srp/templates/srp/data.html:120
#: allianceauth/srp/templates/srp/data.html:117
#: allianceauth/srp/templates/srp/management.html:87
msgid "Pending"
msgstr "Beantragt"
@ -1240,10 +1210,6 @@ msgstr "Du hast bereits eine ausstehendes Austrittsanfrage für diese Gruppe."
msgid "Applied to leave group %(group)s."
msgstr "Austrittsanfrage für Gruppe %(group)s gesendet."
#: allianceauth/hrapplications/apps.py:8
msgid "HR Applications"
msgstr "Bewerbungen"
#: allianceauth/hrapplications/auth_hooks.py:15
msgid "Applications"
msgstr "Bewerbungen"
@ -1315,7 +1281,7 @@ msgstr "Benutzername"
#: allianceauth/hrapplications/templates/hrapplications/management.html:185
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:48
#: allianceauth/hrapplications/templates/hrapplications/view.html:21
#: allianceauth/srp/templates/srp/data.html:112
#: allianceauth/srp/templates/srp/data.html:109
msgid "Approved"
msgstr "Akzeptiert"
@ -1323,7 +1289,7 @@ msgstr "Akzeptiert"
#: allianceauth/hrapplications/templates/hrapplications/management.html:143
#: allianceauth/hrapplications/templates/hrapplications/management.html:187
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:50
#: allianceauth/srp/templates/srp/data.html:116
#: allianceauth/srp/templates/srp/data.html:113
msgid "Rejected"
msgstr "Abgelehnt"
@ -1438,7 +1404,7 @@ msgstr "%s Menüeintrag ändern"
msgid "children"
msgstr "untergeordnet"
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:22
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:21
msgid "text"
msgstr "Text"
@ -1450,15 +1416,11 @@ msgstr "benutzerdefiniert"
msgid "visible"
msgstr "sichtbar"
#: allianceauth/menu/apps.py:16
msgid "Menu"
msgstr "Menü"
#: allianceauth/menu/constants.py:16
msgid "app"
msgstr "Anwendung"
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:38
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:37
msgid "folder"
msgstr "Ordner"
@ -1470,27 +1432,27 @@ msgstr "Link"
msgid "type"
msgstr "Typ"
#: allianceauth/menu/models.py:23
#: allianceauth/menu/models.py:22
msgid "Text to show on menu"
msgstr "Menütext"
#: allianceauth/menu/models.py:28
#: allianceauth/menu/models.py:27
msgid "order"
msgstr "Reihenfolge"
#: allianceauth/menu/models.py:29
#: allianceauth/menu/models.py:28
msgid "Order of the menu. Lowest First"
msgstr "Reihenfolge des Menüs. Niedrigste zuerst"
#: allianceauth/menu/models.py:39
#: allianceauth/menu/models.py:38
msgid "Folder this item is in (optional)"
msgstr "Ordner, in dem sich dieses Element befindet (optional)"
#: allianceauth/menu/models.py:43
#: allianceauth/menu/models.py:42
msgid "is hidden"
msgstr "ist ausgeblendet"
#: allianceauth/menu/models.py:45
#: allianceauth/menu/models.py:44
msgid ""
"Hide this menu item.If this item is a folder all items under it will be "
"hidden too"
@ -1498,11 +1460,11 @@ msgstr ""
"Blende dieses Menüelement aus. Wenn es sich bei diesem Element um einen "
"Ordner handelt, werden auch alle darin enthaltenen Elemente ausgeblendet"
#: allianceauth/menu/models.py:60
#: allianceauth/menu/models.py:59
msgid "icon classes"
msgstr "Icon Klassen"
#: allianceauth/menu/models.py:62
#: allianceauth/menu/models.py:61
msgid ""
"Font Awesome classes to show as icon on menu, e.g. <code>fa-solid fa-"
"house</code>"
@ -1510,11 +1472,11 @@ msgstr ""
"Font Awesome-Klassen zur Anzeige als Symbol im Menü, z. B. <code>fa-solid "
"fa-house</code>"
#: allianceauth/menu/models.py:68
#: allianceauth/menu/models.py:67
msgid "url"
msgstr "URL"
#: allianceauth/menu/models.py:69
#: allianceauth/menu/models.py:68
msgid "External URL this menu items will link to"
msgstr "Externe URL, auf die dieses Menüelement verweist"
@ -1523,63 +1485,44 @@ msgid "Add folder"
msgstr "Ordner hinzufügen"
#: allianceauth/menu/templates/menu/menu-notification-block.html:12
#: allianceauth/notifications/apps.py:8
#: allianceauth/notifications/templates/notifications/list.html:7
#: allianceauth/notifications/templates/notifications/list.html:11
#: allianceauth/templates/allianceauth/notifications_menu_item.html:6
msgid "Notifications"
msgstr "Benachrichtigungen"
#: allianceauth/menu/templates/menu/menu-user.html:77
#: allianceauth/menu/templates/menu/menu-user.html:56
msgid "Super User"
msgstr "Super User"
#: allianceauth/menu/templates/menu/menu-user.html:83
#: allianceauth/menu/templates/menu/menu-user.html:86
msgid "Alliance Auth Documentation"
msgstr "Alliance Auth Dokumentation"
#: allianceauth/menu/templates/menu/menu-user.html:94
#: allianceauth/menu/templates/menu/menu-user.html:97
msgid "Alliance Auth Discord"
msgstr "Alliance Auth Discord"
#: allianceauth/menu/templates/menu/menu-user.html:105
#: allianceauth/menu/templates/menu/menu-user.html:108
msgid "Alliance Auth Git"
msgstr "Alliance Auth Git"
#: allianceauth/menu/templates/menu/menu-user.html:118
#: allianceauth/menu/templates/menu/menu-user.html:121
#: allianceauth/menu/templates/menu/menu-user.html:70
#: allianceauth/templates/allianceauth/top-menu-admin.html:9
msgid "Admin"
msgstr "Admin"
#: allianceauth/menu/templates/menu/menu-user.html:144
#: allianceauth/menu/templates/menu/menu-user.html:147
#: allianceauth/menu/templates/menu/menu-user.html:82
msgid "Sign Out"
msgstr "Ausloggen"
#: allianceauth/menu/templates/menu/menu-user.html:155
#: allianceauth/menu/templates/menu/menu-user.html:158
#: allianceauth/menu/templates/menu/menu-user.html:86
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:17
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:18
msgid "Sign In"
msgstr "Einloggen"
#: allianceauth/notifications/models.py:22
#: allianceauth/notifications/models.py:21
msgid "danger"
msgstr "Gefahr"
#: allianceauth/notifications/models.py:23
#: allianceauth/notifications/models.py:22
msgid "warning"
msgstr "Warnung"
#: allianceauth/notifications/models.py:24
#: allianceauth/notifications/models.py:23
msgid "info"
msgstr "Information"
#: allianceauth/notifications/models.py:25
#: allianceauth/notifications/models.py:24
msgid "success"
msgstr "Erfolg"
@ -1636,7 +1579,7 @@ msgstr "Alle Benachrichtigungen als gelesen markieren."
msgid "Deleted all read notifications."
msgstr "Alle gelesenen Benachrichtigungen gelöscht."
#: allianceauth/optimer/apps.py:8 allianceauth/optimer/auth_hooks.py:12
#: allianceauth/optimer/auth_hooks.py:12
msgid "Fleet Operations"
msgstr "Flottenoperationen"
@ -1710,6 +1653,11 @@ msgstr "Operation"
msgid "Form Up System"
msgstr "Startsystem"
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
msgid "EVE Time"
msgstr "EVE Zeit"
#: allianceauth/optimer/templates/optimer/fleetoptable.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:13
msgid "Local Time"
@ -1725,8 +1673,8 @@ msgstr "Flottenoperationen Verwaltung"
#: allianceauth/optimer/templates/optimer/management.html:28
#: allianceauth/timerboard/templates/timerboard/view.html:32
msgid "Current EVE time:"
msgstr "Aktuelle EVE Zeit"
msgid "Current Eve Time:"
msgstr "Aktuelle Eve Zeit"
#: allianceauth/optimer/templates/optimer/management.html:36
msgid "Next Fleet Operations"
@ -1770,7 +1718,6 @@ msgstr "Operation timer für %(opname)s entfernt."
msgid "Saved changes to operation timer for %(opname)s."
msgstr "Änderungen für Operation timer %(opname)s gespeichert."
#: allianceauth/permissions_tool/apps.py:8
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:7
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:11
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:17
@ -1827,7 +1774,7 @@ msgstr "Dieses Dienstkonto existiert bereits"
msgid "Successfully set your {self.service_name} password"
msgstr "Dein {self.service_name} Passwort wurde erfolgreich gesetzt"
#: allianceauth/services/apps.py:8 allianceauth/services/auth_hooks.py:12
#: allianceauth/services/auth_hooks.py:12
msgid "Services"
msgstr "Dienste"
@ -1891,10 +1838,6 @@ msgstr "Passwort"
msgid "Password must be at least 8 characters long."
msgstr "Das Passwort muss mindestens 8 Zeichen lang sein"
#: allianceauth/services/modules/discord/apps.py:8
msgid "Discord Service"
msgstr "Discord Service"
#: allianceauth/services/modules/discord/models.py:187
msgid "Discord Account Disabled"
msgstr "Discord Konto deaktiviert"
@ -1947,10 +1890,6 @@ msgstr ""
"Es gab einen Fehler während der Aktivierung Deines Discord Kontos. Bitte "
"versuche es noch einmal."
#: allianceauth/services/modules/discourse/apps.py:8
msgid "Discourse Service"
msgstr "Discourse Service"
#: allianceauth/services/modules/discourse/templates/services/discourse/discourse_service_ctrl.html:5
msgid "Discourse"
msgstr "Discourse"
@ -1987,14 +1926,6 @@ msgstr ""
"Ungültige Nutzdaten. Bitte wenden Dich an den Support, wenn das Problem "
"weiterhin besteht."
#: allianceauth/services/modules/example/apps.py:8
msgid "Example Service"
msgstr "Beispiel Service"
#: allianceauth/services/modules/ips4/apps.py:8
msgid "IPS4 Service"
msgstr "IPS4 Service"
#: allianceauth/services/modules/ips4/views.py:31
msgid "Activated IPSuite4 account."
msgstr "IP4Suite Konto aktiviert."
@ -2018,10 +1949,6 @@ msgstr "Setze IPSuite4 Passwort."
msgid "Deactivated IPSuite4 account."
msgstr "IP4Suite Konto deaktiviert."
#: allianceauth/services/modules/mumble/apps.py:8
msgid "Mumble Service"
msgstr "Mumble Service"
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:7
msgid "Mumble"
msgstr "Mumble"
@ -2077,10 +2004,6 @@ msgstr "Verbinden"
msgid "Mumble Connection History"
msgstr "Verlauf der Mumbleverbindungen"
#: allianceauth/services/modules/openfire/apps.py:8
msgid "Openfire Service"
msgstr "Openfire Service"
#: allianceauth/services/modules/openfire/auth_hooks.py:27
msgid "Jabber"
msgstr "Jabber"
@ -2132,10 +2055,6 @@ msgstr "Jabber-Übertragung an %s gesendet"
msgid "Set jabber password."
msgstr "Setze Jabber Passwort."
#: allianceauth/services/modules/phpbb3/apps.py:8
msgid "phpBB3 Service"
msgstr "phpBB3 Service"
#: allianceauth/services/modules/phpbb3/views.py:34
msgid "Activated forum account."
msgstr "Forum Konto aktiviert."
@ -2159,10 +2078,6 @@ msgstr "Forum Passwort zurücksetzen."
msgid "Set forum password."
msgstr "Setze Forum Passwort."
#: allianceauth/services/modules/smf/apps.py:8
msgid "SMF Service"
msgstr "SMF Service"
#: allianceauth/services/modules/smf/views.py:52
msgid "Activated SMF account."
msgstr "SMF Konto aktiviert."
@ -2186,10 +2101,6 @@ msgstr "SMF Passwort zurücksetzen."
msgid "Set SMF password."
msgstr "Setze SMF Passwort."
#: allianceauth/services/modules/teamspeak3/apps.py:8
msgid "TeamSpeak 3 Service"
msgstr "TeamSpeak 3 Service"
#: allianceauth/services/modules/teamspeak3/forms.py:14
#, python-format
msgid "Unable to locate user %s on server"
@ -2240,10 +2151,6 @@ msgstr "TeamSpeak3 Konto deaktiviert."
msgid "Reset TeamSpeak3 permission key."
msgstr "TeamSpeak3 Berechtigungsschlüssel zurücksetzen."
#: allianceauth/services/modules/xenforo/apps.py:8
msgid "Xenforo Service"
msgstr "Xenforo Service"
#: allianceauth/services/modules/xenforo/views.py:30
msgid "Activated XenForo account."
msgstr "XenForo Konto aktiviert."
@ -2357,7 +2264,7 @@ msgstr ""
"Einige Dienste bieten unterschiedliche Optionen. Bewege den Mauszeiger über "
"die Schaltflächen, um mehr zu sehen."
#: allianceauth/srp/apps.py:8 allianceauth/srp/auth_hooks.py:14
#: allianceauth/srp/auth_hooks.py:14
msgid "Ship Replacement"
msgstr "Schiffserstattung"
@ -2433,18 +2340,18 @@ msgid "Mark Completed"
msgstr "Als vollständig markieren"
#: allianceauth/srp/templates/srp/data.html:48
#: allianceauth/srp/templates/srp/data.html:142
#: allianceauth/srp/templates/srp/data.html:139
msgid "Total Losses:"
msgstr "Verluste insgesamt:"
#: allianceauth/srp/templates/srp/data.html:49
#: allianceauth/srp/templates/srp/data.html:143
#: allianceauth/srp/templates/srp/data.html:140
#: allianceauth/srp/templates/srp/management.html:36
msgid "Total ISK Cost:"
msgstr "ISK-Kosten insgesamt:"
#: allianceauth/srp/templates/srp/data.html:60
#: allianceauth/srp/templates/srp/data.html:154
#: allianceauth/srp/templates/srp/data.html:151
msgid "Are you sure you want to delete SRP requests?"
msgstr "Bist Du sicher das Du SRP Anfragen löschen willst?"
@ -2478,12 +2385,12 @@ msgstr ""
msgid "Post Time"
msgstr "Veröffentlichungszeit"
#: allianceauth/srp/templates/srp/data.html:102
#: allianceauth/srp/templates/srp/data.html:99
#: allianceauth/srp/templates/srp/management.html:70
msgid "Link"
msgstr "Link"
#: allianceauth/srp/templates/srp/data.html:163
#: allianceauth/srp/templates/srp/data.html:160
msgid "No SRP requests for this fleet."
msgstr "Keine SRP Anfragen für diese Flotte."
@ -2672,48 +2579,52 @@ msgstr "Der Server hat einen ESI-Fehlerantwortcode erhalten"
msgid "Alliance Auth Notifications"
msgstr "Alliance Auth Benachrichtigungen"
#: allianceauth/templates/allianceauth/admin-status/overview.html:20
#: allianceauth/templates/allianceauth/admin-status/overview.html:18
msgid "Closed"
msgstr "Geschlossen"
#: allianceauth/templates/allianceauth/admin-status/overview.html:24
msgid "No notifications at this time"
msgstr "Derzeit liegen keine Benachrichtigungen vor"
#: allianceauth/templates/allianceauth/admin-status/overview.html:29
#: allianceauth/templates/allianceauth/admin-status/overview.html:33
msgid "Powered by GitLab"
msgstr "Unterstützt durch GitLab"
#: allianceauth/templates/allianceauth/admin-status/overview.html:35
#: allianceauth/templates/allianceauth/admin-status/overview.html:39
msgid "Support Discord"
msgstr "Support Discord"
#: allianceauth/templates/allianceauth/admin-status/overview.html:49
#: allianceauth/templates/allianceauth/admin-status/overview.html:53
#: allianceauth/templates/allianceauth/admin-status/overview.html:57
msgid "Software Version"
msgstr "Software Version"
#: allianceauth/templates/allianceauth/admin-status/overview.html:56
#: allianceauth/templates/allianceauth/admin-status/overview.html:60
msgid "Current"
msgstr "Aktuell"
#: allianceauth/templates/allianceauth/admin-status/overview.html:63
#: allianceauth/templates/allianceauth/admin-status/overview.html:67
msgid "Latest Stable"
msgstr "Aktuellste stabile Version"
#: allianceauth/templates/allianceauth/admin-status/overview.html:68
#: allianceauth/templates/allianceauth/admin-status/overview.html:72
msgid "Update available"
msgstr "Update verfügbar"
#: allianceauth/templates/allianceauth/admin-status/overview.html:76
#: allianceauth/templates/allianceauth/admin-status/overview.html:80
msgid "Latest Pre-Release"
msgstr "Aktuellste Testversion"
#: allianceauth/templates/allianceauth/admin-status/overview.html:81
#: allianceauth/templates/allianceauth/admin-status/overview.html:85
msgid "Pre-Release available"
msgstr "Testversion verfügbar"
#: allianceauth/templates/allianceauth/admin-status/overview.html:91
#: allianceauth/templates/allianceauth/admin-status/overview.html:95
msgid "Task Queue"
msgstr "Task-Warteschlange"
#: allianceauth/templates/allianceauth/admin-status/overview.html:96
#: allianceauth/templates/allianceauth/admin-status/overview.html:100
#, python-format
msgid ""
"\n"
@ -2723,11 +2634,11 @@ msgstr ""
"\n"
"Status von %(total)s verarbeiten Aufgaben • in den letzten %(latest)s"
#: allianceauth/templates/allianceauth/admin-status/overview.html:112
#: allianceauth/templates/allianceauth/admin-status/overview.html:116
msgid "running"
msgstr "laufend"
#: allianceauth/templates/allianceauth/admin-status/overview.html:113
#: allianceauth/templates/allianceauth/admin-status/overview.html:117
msgid "queued"
msgstr "eingereiht"
@ -2752,17 +2663,10 @@ msgstr "Ausloggen"
msgid "Toggle navigation"
msgstr "Navigation umschalten"
#: allianceauth/theme/templates/theme/theme_select.html:11
#: allianceauth/theme/templates/theme/theme_select.html:7
msgid "Select Theme"
msgstr "Theme auswählen"
#: allianceauth/timerboard/apps.py:8
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "Strukturen Timer"
#: allianceauth/timerboard/form.py:36
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:8
@ -2949,10 +2853,6 @@ msgstr "Entankernd"
msgid "Abandoned"
msgstr "Aufgegeben"
#: allianceauth/timerboard/models.py:60
msgid "Theft"
msgstr "Diebstahl"
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:7
#: allianceauth/timerboard/templates/timerboard/view.html:54
msgid "Upcoming Timers"
@ -2962,6 +2862,12 @@ msgstr "Anstehende Timer"
msgid "Timer"
msgstr "Timer"
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "Strukturen Timer"
#: allianceauth/timerboard/templates/timerboard/form.html:25
msgid "Structure Timer Details"
msgstr "Strukturen-Timerdetails"

View File

@ -8,7 +8,7 @@ msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2025-07-03 09:07+1000\n"
"POT-Creation-Date: 2025-02-25 19:17+1000\n"
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
"Language-Team: LANGUAGE <LL@li.org>\n"
@ -18,10 +18,6 @@ msgstr ""
"Content-Transfer-Encoding: 8bit\n"
"Plural-Forms: nplurals=2; plural=(n != 1);\n"
#: allianceauth/analytics/apps.py:8
msgid "Analytics"
msgstr ""
#: allianceauth/analytics/models.py:22
msgid "Google Analytics Universal"
msgstr ""
@ -30,10 +26,6 @@ msgstr ""
msgid "Google Analytics V4"
msgstr ""
#: allianceauth/authentication/apps.py:9
msgid "Authentication"
msgstr ""
#: allianceauth/authentication/constants.py:6
msgid ""
"This software has exceeded the error limit for ESI. If you are a user, "
@ -43,7 +35,7 @@ msgid ""
"esi on the EVE Online Discord. https://www.eveonline.com/discord"
msgstr ""
#: allianceauth/authentication/decorators.py:52
#: allianceauth/authentication/decorators.py:49
msgid "A main character is required to perform that action. Add one below."
msgstr ""
@ -56,91 +48,91 @@ msgstr ""
msgid "You are not allowed to add or remove these restricted groups: %s"
msgstr ""
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:104
#: allianceauth/authentication/models.py:70
#: allianceauth/project_template/project_name/settings/base.py:105
msgid "English"
msgstr ""
#: allianceauth/authentication/models.py:73
#: allianceauth/authentication/models.py:71
msgid "Czech"
msgstr ""
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:106
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:107
msgid "German"
msgstr ""
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:107
#: allianceauth/authentication/models.py:73
#: allianceauth/project_template/project_name/settings/base.py:108
msgid "Spanish"
msgstr ""
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:108
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:109
msgid "Italian"
msgstr ""
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:109
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:110
msgid "Japanese"
msgstr ""
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:110
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:111
msgid "Korean"
msgstr ""
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:111
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:112
msgid "French"
msgstr ""
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:115
msgid "Russian"
msgstr ""
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
msgid "Dutch"
msgstr ""
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:114
msgid "Russian"
msgstr ""
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:112
msgid "Dutch"
msgstr ""
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:113
msgid "Polish"
msgstr ""
#: allianceauth/authentication/models.py:83
#: allianceauth/project_template/project_name/settings/base.py:115
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:116
msgid "Ukrainian"
msgstr ""
#: allianceauth/authentication/models.py:84
#: allianceauth/project_template/project_name/settings/base.py:116
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:117
msgid "Simplified Chinese"
msgstr ""
#: allianceauth/authentication/models.py:100
#: allianceauth/menu/templates/menu/menu-user.html:67
#: allianceauth/authentication/models.py:98
#: allianceauth/menu/templates/menu/menu-user.html:42
msgid "Language"
msgstr ""
#: allianceauth/authentication/models.py:105
#: allianceauth/authentication/models.py:103
#: allianceauth/templates/allianceauth/night-toggle.html:6
msgid "Night Mode"
msgstr ""
#: allianceauth/authentication/models.py:109
#: allianceauth/theme/templates/theme/theme_select.html:4
#: allianceauth/authentication/models.py:107
#: allianceauth/menu/templates/menu/menu-user.html:46
msgid "Theme"
msgstr ""
#: allianceauth/authentication/models.py:126
#: allianceauth/authentication/models.py:124
#, python-format
msgid "State changed to: %s"
msgstr ""
#: allianceauth/authentication/models.py:127
#: allianceauth/authentication/models.py:125
#, python-format
msgid "Your user's state is now: %(state)s"
msgstr ""
@ -202,8 +194,6 @@ msgstr ""
#: allianceauth/authentication/templates/authentication/tokens.html:7
#: allianceauth/authentication/templates/authentication/tokens.html:11
#: allianceauth/menu/templates/menu/menu-user.html:133
#: allianceauth/menu/templates/menu/menu-user.html:136
#: allianceauth/templates/allianceauth/top-menu-user-dropdown.html:62
msgid "Token Management"
msgstr ""
@ -277,53 +267,53 @@ msgstr ""
msgid "Invalid or expired activation link."
msgstr ""
#: allianceauth/authentication/views.py:158
#: allianceauth/authentication/views.py:157
#, python-format
msgid ""
"Cannot change main character to %(char)s: character owned by a different "
"account."
msgstr ""
#: allianceauth/authentication/views.py:165
#: allianceauth/authentication/views.py:164
#, python-format
msgid "Changed main character to %s"
msgstr ""
#: allianceauth/authentication/views.py:179
#: allianceauth/authentication/views.py:178
#, python-format
msgid "Added %(name)s to your account."
msgstr ""
#: allianceauth/authentication/views.py:181
#: allianceauth/authentication/views.py:180
#, python-format
msgid "Failed to add %(name)s to your account: they already have an account."
msgstr ""
#: allianceauth/authentication/views.py:226
#: allianceauth/authentication/views.py:225
msgid ""
"Unable to authenticate as the selected character. Please log in with the "
"main character associated with this account."
msgstr ""
#: allianceauth/authentication/views.py:293
#: allianceauth/authentication/views.py:292
msgid "Registration token has expired."
msgstr ""
#: allianceauth/authentication/views.py:354
#: allianceauth/authentication/views.py:353
msgid ""
"Sent confirmation email. Please follow the link to confirm your email "
"address."
msgstr ""
#: allianceauth/authentication/views.py:360
#: allianceauth/authentication/views.py:359
msgid "Confirmed your email address. Please login to continue."
msgstr ""
#: allianceauth/authentication/views.py:366
#: allianceauth/authentication/views.py:365
msgid "Registration of new accounts is not allowed at this time."
msgstr ""
#: allianceauth/corputils/apps.py:8 allianceauth/corputils/auth_hooks.py:12
#: allianceauth/corputils/auth_hooks.py:12
msgid "Corporation Stats"
msgstr ""
@ -429,10 +419,6 @@ msgstr ""
msgid "Failed to gather corporation statistics with selected token."
msgstr ""
#: allianceauth/crontab/apps.py:16
msgid "Crontab"
msgstr ""
#: allianceauth/crontab/models.py:13
msgid "Minute Offset"
msgstr ""
@ -466,15 +452,6 @@ msgstr ""
msgid "This CSS will be added to the site after the default CSS."
msgstr ""
#: allianceauth/eveonline/apps.py:8
msgid "EVE Online"
msgstr ""
#: allianceauth/eveonline/autogroups/apps.py:8
msgid "EVE Online Autogroups"
msgstr ""
#: allianceauth/fleetactivitytracking/apps.py:8
#: allianceauth/fleetactivitytracking/auth_hooks.py:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/characternotexisting.html:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkcreate.html:11
@ -584,11 +561,9 @@ msgstr ""
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkpersonalmonthlystatisticsview.html:75
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:44
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:92
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/templates/allianceauth/top-menu.html:23
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
#: allianceauth/timerboard/templates/timerboard/timertable.html:12
msgid "EVE time"
msgid "Eve Time"
msgstr ""
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkmodify.html:49
@ -753,11 +728,6 @@ msgid ""
"character needs to be online."
msgstr ""
#: allianceauth/framework/apps.py:16
msgid "Framework"
msgstr ""
#: allianceauth/groupmanagement/apps.py:8
#: allianceauth/groupmanagement/auth_hooks.py:18
#: allianceauth/groupmanagement/templates/groupmanagement/groups.html:18
msgid "Group Management"
@ -986,7 +956,7 @@ msgid "Hidden"
msgstr ""
#: allianceauth/groupmanagement/templates/groupmanagement/groupmembership.html:45
#: allianceauth/templates/allianceauth/admin-status/overview.html:15
#: allianceauth/templates/allianceauth/admin-status/overview.html:16
msgid "Open"
msgstr ""
@ -1039,7 +1009,7 @@ msgstr ""
#: allianceauth/hrapplications/templates/hrapplications/management.html:182
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:46
#: allianceauth/hrapplications/templates/hrapplications/view.html:25
#: allianceauth/srp/templates/srp/data.html:120
#: allianceauth/srp/templates/srp/data.html:117
#: allianceauth/srp/templates/srp/management.html:87
msgid "Pending"
msgstr ""
@ -1181,10 +1151,6 @@ msgstr ""
msgid "Applied to leave group %(group)s."
msgstr ""
#: allianceauth/hrapplications/apps.py:8
msgid "HR Applications"
msgstr ""
#: allianceauth/hrapplications/auth_hooks.py:15
msgid "Applications"
msgstr ""
@ -1256,7 +1222,7 @@ msgstr ""
#: allianceauth/hrapplications/templates/hrapplications/management.html:185
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:48
#: allianceauth/hrapplications/templates/hrapplications/view.html:21
#: allianceauth/srp/templates/srp/data.html:112
#: allianceauth/srp/templates/srp/data.html:109
msgid "Approved"
msgstr ""
@ -1264,7 +1230,7 @@ msgstr ""
#: allianceauth/hrapplications/templates/hrapplications/management.html:143
#: allianceauth/hrapplications/templates/hrapplications/management.html:187
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:50
#: allianceauth/srp/templates/srp/data.html:116
#: allianceauth/srp/templates/srp/data.html:113
msgid "Rejected"
msgstr ""
@ -1379,7 +1345,7 @@ msgstr ""
msgid "children"
msgstr ""
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:22
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:21
msgid "text"
msgstr ""
@ -1391,15 +1357,11 @@ msgstr ""
msgid "visible"
msgstr ""
#: allianceauth/menu/apps.py:16
msgid "Menu"
msgstr ""
#: allianceauth/menu/constants.py:16
msgid "app"
msgstr ""
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:38
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:37
msgid "folder"
msgstr ""
@ -1411,47 +1373,47 @@ msgstr ""
msgid "type"
msgstr ""
#: allianceauth/menu/models.py:23
#: allianceauth/menu/models.py:22
msgid "Text to show on menu"
msgstr ""
#: allianceauth/menu/models.py:28
#: allianceauth/menu/models.py:27
msgid "order"
msgstr ""
#: allianceauth/menu/models.py:29
#: allianceauth/menu/models.py:28
msgid "Order of the menu. Lowest First"
msgstr ""
#: allianceauth/menu/models.py:39
#: allianceauth/menu/models.py:38
msgid "Folder this item is in (optional)"
msgstr ""
#: allianceauth/menu/models.py:43
#: allianceauth/menu/models.py:42
msgid "is hidden"
msgstr ""
#: allianceauth/menu/models.py:45
#: allianceauth/menu/models.py:44
msgid ""
"Hide this menu item.If this item is a folder all items under it will be "
"hidden too"
msgstr ""
#: allianceauth/menu/models.py:60
#: allianceauth/menu/models.py:59
msgid "icon classes"
msgstr ""
#: allianceauth/menu/models.py:62
#: allianceauth/menu/models.py:61
msgid ""
"Font Awesome classes to show as icon on menu, e.g. <code>fa-solid fa-house</"
"code>"
msgstr ""
#: allianceauth/menu/models.py:68
#: allianceauth/menu/models.py:67
msgid "url"
msgstr ""
#: allianceauth/menu/models.py:69
#: allianceauth/menu/models.py:68
msgid "External URL this menu items will link to"
msgstr ""
@ -1460,63 +1422,44 @@ msgid "Add folder"
msgstr ""
#: allianceauth/menu/templates/menu/menu-notification-block.html:12
#: allianceauth/notifications/apps.py:8
#: allianceauth/notifications/templates/notifications/list.html:7
#: allianceauth/notifications/templates/notifications/list.html:11
#: allianceauth/templates/allianceauth/notifications_menu_item.html:6
msgid "Notifications"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:77
#: allianceauth/menu/templates/menu/menu-user.html:56
msgid "Super User"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:83
#: allianceauth/menu/templates/menu/menu-user.html:86
msgid "Alliance Auth Documentation"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:94
#: allianceauth/menu/templates/menu/menu-user.html:97
msgid "Alliance Auth Discord"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:105
#: allianceauth/menu/templates/menu/menu-user.html:108
msgid "Alliance Auth Git"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:118
#: allianceauth/menu/templates/menu/menu-user.html:121
#: allianceauth/menu/templates/menu/menu-user.html:70
#: allianceauth/templates/allianceauth/top-menu-admin.html:9
msgid "Admin"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:144
#: allianceauth/menu/templates/menu/menu-user.html:147
#: allianceauth/menu/templates/menu/menu-user.html:82
msgid "Sign Out"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:155
#: allianceauth/menu/templates/menu/menu-user.html:158
#: allianceauth/menu/templates/menu/menu-user.html:86
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:17
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:18
msgid "Sign In"
msgstr ""
#: allianceauth/notifications/models.py:22
#: allianceauth/notifications/models.py:21
msgid "danger"
msgstr ""
#: allianceauth/notifications/models.py:23
#: allianceauth/notifications/models.py:22
msgid "warning"
msgstr ""
#: allianceauth/notifications/models.py:24
#: allianceauth/notifications/models.py:23
msgid "info"
msgstr ""
#: allianceauth/notifications/models.py:25
#: allianceauth/notifications/models.py:24
msgid "success"
msgstr ""
@ -1573,7 +1516,7 @@ msgstr ""
msgid "Deleted all read notifications."
msgstr ""
#: allianceauth/optimer/apps.py:8 allianceauth/optimer/auth_hooks.py:12
#: allianceauth/optimer/auth_hooks.py:12
msgid "Fleet Operations"
msgstr ""
@ -1647,6 +1590,11 @@ msgstr ""
msgid "Form Up System"
msgstr ""
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
msgid "EVE Time"
msgstr ""
#: allianceauth/optimer/templates/optimer/fleetoptable.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:13
msgid "Local Time"
@ -1662,7 +1610,7 @@ msgstr ""
#: allianceauth/optimer/templates/optimer/management.html:28
#: allianceauth/timerboard/templates/timerboard/view.html:32
msgid "Current EVE time:"
msgid "Current Eve Time:"
msgstr ""
#: allianceauth/optimer/templates/optimer/management.html:36
@ -1707,7 +1655,6 @@ msgstr ""
msgid "Saved changes to operation timer for %(opname)s."
msgstr ""
#: allianceauth/permissions_tool/apps.py:8
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:7
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:11
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:17
@ -1764,7 +1711,7 @@ msgstr ""
msgid "Successfully set your {self.service_name} password"
msgstr ""
#: allianceauth/services/apps.py:8 allianceauth/services/auth_hooks.py:12
#: allianceauth/services/auth_hooks.py:12
msgid "Services"
msgstr ""
@ -1828,10 +1775,6 @@ msgstr ""
msgid "Password must be at least 8 characters long."
msgstr ""
#: allianceauth/services/modules/discord/apps.py:8
msgid "Discord Service"
msgstr ""
#: allianceauth/services/modules/discord/models.py:187
msgid "Discord Account Disabled"
msgstr ""
@ -1880,10 +1823,6 @@ msgid ""
"again."
msgstr ""
#: allianceauth/services/modules/discourse/apps.py:8
msgid "Discourse Service"
msgstr ""
#: allianceauth/services/modules/discourse/templates/services/discourse/discourse_service_ctrl.html:5
msgid "Discourse"
msgstr ""
@ -1914,14 +1853,6 @@ msgstr ""
msgid "Invalid payload. Please contact support if this problem persists."
msgstr ""
#: allianceauth/services/modules/example/apps.py:8
msgid "Example Service"
msgstr ""
#: allianceauth/services/modules/ips4/apps.py:8
msgid "IPS4 Service"
msgstr ""
#: allianceauth/services/modules/ips4/views.py:31
msgid "Activated IPSuite4 account."
msgstr ""
@ -1945,10 +1876,6 @@ msgstr ""
msgid "Deactivated IPSuite4 account."
msgstr ""
#: allianceauth/services/modules/mumble/apps.py:8
msgid "Mumble Service"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:7
msgid "Mumble"
msgstr ""
@ -2004,10 +1931,6 @@ msgstr ""
msgid "Mumble Connection History"
msgstr ""
#: allianceauth/services/modules/openfire/apps.py:8
msgid "Openfire Service"
msgstr ""
#: allianceauth/services/modules/openfire/auth_hooks.py:27
msgid "Jabber"
msgstr ""
@ -2059,10 +1982,6 @@ msgstr ""
msgid "Set jabber password."
msgstr ""
#: allianceauth/services/modules/phpbb3/apps.py:8
msgid "phpBB3 Service"
msgstr ""
#: allianceauth/services/modules/phpbb3/views.py:34
msgid "Activated forum account."
msgstr ""
@ -2086,10 +2005,6 @@ msgstr ""
msgid "Set forum password."
msgstr ""
#: allianceauth/services/modules/smf/apps.py:8
msgid "SMF Service"
msgstr ""
#: allianceauth/services/modules/smf/views.py:52
msgid "Activated SMF account."
msgstr ""
@ -2113,10 +2028,6 @@ msgstr ""
msgid "Set SMF password."
msgstr ""
#: allianceauth/services/modules/teamspeak3/apps.py:8
msgid "TeamSpeak 3 Service"
msgstr ""
#: allianceauth/services/modules/teamspeak3/forms.py:14
#, python-format
msgid "Unable to locate user %s on server"
@ -2166,10 +2077,6 @@ msgstr ""
msgid "Reset TeamSpeak3 permission key."
msgstr ""
#: allianceauth/services/modules/xenforo/apps.py:8
msgid "Xenforo Service"
msgstr ""
#: allianceauth/services/modules/xenforo/views.py:30
msgid "Activated XenForo account."
msgstr ""
@ -2279,7 +2186,7 @@ msgid ""
"Some services provide different options. Hover over the buttons to see more."
msgstr ""
#: allianceauth/srp/apps.py:8 allianceauth/srp/auth_hooks.py:14
#: allianceauth/srp/auth_hooks.py:14
msgid "Ship Replacement"
msgstr ""
@ -2354,18 +2261,18 @@ msgid "Mark Completed"
msgstr ""
#: allianceauth/srp/templates/srp/data.html:48
#: allianceauth/srp/templates/srp/data.html:142
#: allianceauth/srp/templates/srp/data.html:139
msgid "Total Losses:"
msgstr ""
#: allianceauth/srp/templates/srp/data.html:49
#: allianceauth/srp/templates/srp/data.html:143
#: allianceauth/srp/templates/srp/data.html:140
#: allianceauth/srp/templates/srp/management.html:36
msgid "Total ISK Cost:"
msgstr ""
#: allianceauth/srp/templates/srp/data.html:60
#: allianceauth/srp/templates/srp/data.html:154
#: allianceauth/srp/templates/srp/data.html:151
msgid "Are you sure you want to delete SRP requests?"
msgstr ""
@ -2397,12 +2304,12 @@ msgstr ""
msgid "Post Time"
msgstr ""
#: allianceauth/srp/templates/srp/data.html:102
#: allianceauth/srp/templates/srp/data.html:99
#: allianceauth/srp/templates/srp/management.html:70
msgid "Link"
msgstr ""
#: allianceauth/srp/templates/srp/data.html:163
#: allianceauth/srp/templates/srp/data.html:160
msgid "No SRP requests for this fleet."
msgstr ""
@ -2586,48 +2493,52 @@ msgstr ""
msgid "Alliance Auth Notifications"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:20
#: allianceauth/templates/allianceauth/admin-status/overview.html:18
msgid "Closed"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:24
msgid "No notifications at this time"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:29
#: allianceauth/templates/allianceauth/admin-status/overview.html:33
msgid "Powered by GitLab"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:35
#: allianceauth/templates/allianceauth/admin-status/overview.html:39
msgid "Support Discord"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:49
#: allianceauth/templates/allianceauth/admin-status/overview.html:53
#: allianceauth/templates/allianceauth/admin-status/overview.html:57
msgid "Software Version"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:56
#: allianceauth/templates/allianceauth/admin-status/overview.html:60
msgid "Current"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:63
#: allianceauth/templates/allianceauth/admin-status/overview.html:67
msgid "Latest Stable"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:68
#: allianceauth/templates/allianceauth/admin-status/overview.html:72
msgid "Update available"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:76
#: allianceauth/templates/allianceauth/admin-status/overview.html:80
msgid "Latest Pre-Release"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:81
#: allianceauth/templates/allianceauth/admin-status/overview.html:85
msgid "Pre-Release available"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:91
#: allianceauth/templates/allianceauth/admin-status/overview.html:95
msgid "Task Queue"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:96
#: allianceauth/templates/allianceauth/admin-status/overview.html:100
#, python-format
msgid ""
"\n"
@ -2636,11 +2547,11 @@ msgid ""
" "
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:112
#: allianceauth/templates/allianceauth/admin-status/overview.html:116
msgid "running"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:113
#: allianceauth/templates/allianceauth/admin-status/overview.html:117
msgid "queued"
msgstr ""
@ -2665,17 +2576,10 @@ msgstr ""
msgid "Toggle navigation"
msgstr ""
#: allianceauth/theme/templates/theme/theme_select.html:11
#: allianceauth/theme/templates/theme/theme_select.html:7
msgid "Select Theme"
msgstr ""
#: allianceauth/timerboard/apps.py:8
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr ""
#: allianceauth/timerboard/form.py:36
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:8
@ -2862,10 +2766,6 @@ msgstr ""
msgid "Abandoned"
msgstr ""
#: allianceauth/timerboard/models.py:60
msgid "Theft"
msgstr ""
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:7
#: allianceauth/timerboard/templates/timerboard/view.html:54
msgid "Upcoming Timers"
@ -2875,6 +2775,12 @@ msgstr ""
msgid "Timer"
msgstr ""
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr ""
#: allianceauth/timerboard/templates/timerboard/form.html:25
msgid "Structure Timer Details"
msgstr ""

File diff suppressed because it is too large Load Diff

View File

@ -20,7 +20,7 @@ msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2025-06-19 20:23+1000\n"
"POT-Creation-Date: 2025-02-25 19:17+1000\n"
"PO-Revision-Date: 2023-11-08 13:50+0000\n"
"Last-Translator: T'rahk Rokym, 2024\n"
"Language-Team: French (France) (https://app.transifex.com/alliance-auth/teams/107430/fr_FR/)\n"
@ -30,10 +30,6 @@ msgstr ""
"Language: fr_FR\n"
"Plural-Forms: nplurals=3; plural=(n == 0 || n == 1) ? 0 : n != 0 && n % 1000000 == 0 ? 1 : 2;\n"
#: allianceauth/analytics/apps.py:8
msgid "Analytics"
msgstr ""
#: allianceauth/analytics/models.py:22
msgid "Google Analytics Universal"
msgstr "Google Analytique Universelle"
@ -42,10 +38,6 @@ msgstr "Google Analytique Universelle"
msgid "Google Analytics V4"
msgstr "Google Analytics V4"
#: allianceauth/authentication/apps.py:9
msgid "Authentication"
msgstr ""
#: allianceauth/authentication/constants.py:6
msgid ""
"This software has exceeded the error limit for ESI. If you are a user, "
@ -61,7 +53,7 @@ msgstr ""
"avec nous dans ##3rd-party-dev-and-esi sur le Discord d'EVE Online. "
"https://www.eveonline.com/discord"
#: allianceauth/authentication/decorators.py:52
#: allianceauth/authentication/decorators.py:49
msgid "A main character is required to perform that action. Add one below."
msgstr ""
"Un personnage principal est nécessaire pour effectuer cette action. Ajoutez-"
@ -78,91 +70,91 @@ msgstr ""
"Vous n'avez pas lautorisation d'ajouter ou d'enlever ces groupes "
"restreints: %s"
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:106
#: allianceauth/authentication/models.py:70
#: allianceauth/project_template/project_name/settings/base.py:105
msgid "English"
msgstr "Anglais"
#: allianceauth/authentication/models.py:73
#: allianceauth/authentication/models.py:71
msgid "Czech"
msgstr ""
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:108
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:107
msgid "German"
msgstr "Allemand"
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:109
#: allianceauth/authentication/models.py:73
#: allianceauth/project_template/project_name/settings/base.py:108
msgid "Spanish"
msgstr "Espagnol"
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:110
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:109
msgid "Italian"
msgstr "Italien"
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:111
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:110
msgid "Japanese"
msgstr "Japonais"
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:112
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:111
msgid "Korean"
msgstr "Coréen"
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:112
msgid "French"
msgstr "Français"
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:116
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:115
msgid "Russian"
msgstr "Russe"
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:114
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
msgid "Dutch"
msgstr ""
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:115
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:114
msgid "Polish"
msgstr "Polonais"
#: allianceauth/authentication/models.py:83
#: allianceauth/project_template/project_name/settings/base.py:117
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:116
msgid "Ukrainian"
msgstr "Ukrainien"
#: allianceauth/authentication/models.py:84
#: allianceauth/project_template/project_name/settings/base.py:118
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:117
msgid "Simplified Chinese"
msgstr ""
#: allianceauth/authentication/models.py:100
#: allianceauth/menu/templates/menu/menu-user.html:67
#: allianceauth/authentication/models.py:98
#: allianceauth/menu/templates/menu/menu-user.html:42
msgid "Language"
msgstr "Langue"
#: allianceauth/authentication/models.py:105
#: allianceauth/authentication/models.py:103
#: allianceauth/templates/allianceauth/night-toggle.html:6
msgid "Night Mode"
msgstr "Mode Nuit"
#: allianceauth/authentication/models.py:109
#: allianceauth/theme/templates/theme/theme_select.html:4
#: allianceauth/authentication/models.py:107
#: allianceauth/menu/templates/menu/menu-user.html:46
msgid "Theme"
msgstr "Thème"
#: allianceauth/authentication/models.py:126
#: allianceauth/authentication/models.py:124
#, python-format
msgid "State changed to: %s"
msgstr "État changé à: %s"
#: allianceauth/authentication/models.py:127
#: allianceauth/authentication/models.py:125
#, python-format
msgid "Your user's state is now: %(state)s"
msgstr "L'état de votre personnage est maintenant: %(state)s"
@ -224,8 +216,6 @@ msgstr "État:"
#: allianceauth/authentication/templates/authentication/tokens.html:7
#: allianceauth/authentication/templates/authentication/tokens.html:11
#: allianceauth/menu/templates/menu/menu-user.html:133
#: allianceauth/menu/templates/menu/menu-user.html:136
#: allianceauth/templates/allianceauth/top-menu-user-dropdown.html:62
msgid "Token Management"
msgstr "Gestion des jetons"
@ -301,7 +291,7 @@ msgstr "S'inscrire"
msgid "Invalid or expired activation link."
msgstr "Lien d'activation invalide ou expiré."
#: allianceauth/authentication/views.py:158
#: allianceauth/authentication/views.py:157
#, python-format
msgid ""
"Cannot change main character to %(char)s: character owned by a different "
@ -310,22 +300,22 @@ msgstr ""
"Impossible de changer le personnage principal à %(char)s. Le personnage "
"appartient à un autre compte."
#: allianceauth/authentication/views.py:165
#: allianceauth/authentication/views.py:164
#, python-format
msgid "Changed main character to %s"
msgstr "Personnage principal changé en %s"
#: allianceauth/authentication/views.py:179
#: allianceauth/authentication/views.py:178
#, python-format
msgid "Added %(name)s to your account."
msgstr "Ajouté %(name)s à votre compte."
#: allianceauth/authentication/views.py:181
#: allianceauth/authentication/views.py:180
#, python-format
msgid "Failed to add %(name)s to your account: they already have an account."
msgstr "Impossible d'ajouter %(name)s à votre compte: ils ont déjà un compte."
#: allianceauth/authentication/views.py:226
#: allianceauth/authentication/views.py:225
msgid ""
"Unable to authenticate as the selected character. Please log in with the "
"main character associated with this account."
@ -333,11 +323,11 @@ msgstr ""
"Impossible de s'authentifier avec le personnage sélectionné. Merci de vous "
"connecter avec le personnage principal associé à ce compte."
#: allianceauth/authentication/views.py:293
#: allianceauth/authentication/views.py:292
msgid "Registration token has expired."
msgstr "Le token d'enregistrement est expiré."
#: allianceauth/authentication/views.py:354
#: allianceauth/authentication/views.py:353
msgid ""
"Sent confirmation email. Please follow the link to confirm your email "
"address."
@ -345,16 +335,16 @@ msgstr ""
"Email de confirmation envoyé. Cliquez sur le lien pour valider votre adresse"
" email."
#: allianceauth/authentication/views.py:360
#: allianceauth/authentication/views.py:359
msgid "Confirmed your email address. Please login to continue."
msgstr ""
"Votre adresse email a été confirmé. Veuillez vous connecter pour continuer."
#: allianceauth/authentication/views.py:366
#: allianceauth/authentication/views.py:365
msgid "Registration of new accounts is not allowed at this time."
msgstr "La création de nouveaux comptes n'est pas actuellement permise."
#: allianceauth/corputils/apps.py:8 allianceauth/corputils/auth_hooks.py:12
#: allianceauth/corputils/auth_hooks.py:12
msgid "Corporation Stats"
msgstr "Statistiques de la Corpo"
@ -461,10 +451,6 @@ msgid "Failed to gather corporation statistics with selected token."
msgstr ""
"Impossible d'obtenir les statistiques de la corpo avec le code choisi."
#: allianceauth/crontab/apps.py:16
msgid "Crontab"
msgstr ""
#: allianceauth/crontab/models.py:13
msgid "Minute Offset"
msgstr ""
@ -498,15 +484,6 @@ msgstr "Votre CSS personnalisé"
msgid "This CSS will be added to the site after the default CSS."
msgstr "Ce CSS être ajouté sur le site après le CSS par défaut"
#: allianceauth/eveonline/apps.py:8
msgid "EVE Online"
msgstr ""
#: allianceauth/eveonline/autogroups/apps.py:8
msgid "EVE Online Autogroups"
msgstr ""
#: allianceauth/fleetactivitytracking/apps.py:8
#: allianceauth/fleetactivitytracking/auth_hooks.py:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/characternotexisting.html:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkcreate.html:11
@ -616,12 +593,10 @@ msgstr "Vaisseau"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkpersonalmonthlystatisticsview.html:75
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:44
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:92
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/templates/allianceauth/top-menu.html:23
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
#: allianceauth/timerboard/templates/timerboard/timertable.html:12
msgid "EVE time"
msgstr ""
msgid "Eve Time"
msgstr "Heure d'EVE"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkmodify.html:49
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:52
@ -789,11 +764,6 @@ msgstr ""
"Impossible d'enregistrer la participation pour {character.character_name}. "
"Le personnage doit être en ligne."
#: allianceauth/framework/apps.py:16
msgid "Framework"
msgstr ""
#: allianceauth/groupmanagement/apps.py:8
#: allianceauth/groupmanagement/auth_hooks.py:18
#: allianceauth/groupmanagement/templates/groupmanagement/groups.html:18
msgid "Group Management"
@ -1048,7 +1018,7 @@ msgid "Hidden"
msgstr "Caché"
#: allianceauth/groupmanagement/templates/groupmanagement/groupmembership.html:45
#: allianceauth/templates/allianceauth/admin-status/overview.html:15
#: allianceauth/templates/allianceauth/admin-status/overview.html:16
msgid "Open"
msgstr "Ouvert"
@ -1101,7 +1071,7 @@ msgstr "Quitter"
#: allianceauth/hrapplications/templates/hrapplications/management.html:182
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:46
#: allianceauth/hrapplications/templates/hrapplications/view.html:25
#: allianceauth/srp/templates/srp/data.html:120
#: allianceauth/srp/templates/srp/data.html:117
#: allianceauth/srp/templates/srp/management.html:87
msgid "Pending"
msgstr "En attente."
@ -1247,10 +1217,6 @@ msgstr "Vous avec déjà une demande de quitter ce groupe en attente."
msgid "Applied to leave group %(group)s."
msgstr "Appliqué pour quitter le groupe %(group)s."
#: allianceauth/hrapplications/apps.py:8
msgid "HR Applications"
msgstr ""
#: allianceauth/hrapplications/auth_hooks.py:15
msgid "Applications"
msgstr "Applications"
@ -1322,7 +1288,7 @@ msgstr "Nom d'utilisateur"
#: allianceauth/hrapplications/templates/hrapplications/management.html:185
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:48
#: allianceauth/hrapplications/templates/hrapplications/view.html:21
#: allianceauth/srp/templates/srp/data.html:112
#: allianceauth/srp/templates/srp/data.html:109
msgid "Approved"
msgstr "Approuvé"
@ -1330,7 +1296,7 @@ msgstr "Approuvé"
#: allianceauth/hrapplications/templates/hrapplications/management.html:143
#: allianceauth/hrapplications/templates/hrapplications/management.html:187
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:50
#: allianceauth/srp/templates/srp/data.html:116
#: allianceauth/srp/templates/srp/data.html:113
msgid "Rejected"
msgstr "Rejeté"
@ -1445,7 +1411,7 @@ msgstr "Changer %s élément de menu"
msgid "children"
msgstr "enfant"
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:22
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:21
msgid "text"
msgstr "texte"
@ -1457,15 +1423,11 @@ msgstr "défini par l'utilisateur"
msgid "visible"
msgstr "visible"
#: allianceauth/menu/apps.py:16
msgid "Menu"
msgstr ""
#: allianceauth/menu/constants.py:16
msgid "app"
msgstr "application"
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:38
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:37
msgid "folder"
msgstr "dossier"
@ -1477,27 +1439,27 @@ msgstr "lien"
msgid "type"
msgstr "type"
#: allianceauth/menu/models.py:23
#: allianceauth/menu/models.py:22
msgid "Text to show on menu"
msgstr "Texte à afficher sur le menu"
#: allianceauth/menu/models.py:28
#: allianceauth/menu/models.py:27
msgid "order"
msgstr "ordre"
#: allianceauth/menu/models.py:29
#: allianceauth/menu/models.py:28
msgid "Order of the menu. Lowest First"
msgstr "Ordre du menu. Plus petit en premier"
#: allianceauth/menu/models.py:39
#: allianceauth/menu/models.py:38
msgid "Folder this item is in (optional)"
msgstr "Dossier dans lequel se trouve cet article (facultatif)"
#: allianceauth/menu/models.py:43
#: allianceauth/menu/models.py:42
msgid "is hidden"
msgstr "est caché"
#: allianceauth/menu/models.py:45
#: allianceauth/menu/models.py:44
msgid ""
"Hide this menu item.If this item is a folder all items under it will be "
"hidden too"
@ -1505,11 +1467,11 @@ msgstr ""
"Cacher cette élément de menu.Si cet élément est un dossier, tous les "
"éléments qui se trouvent sous ce dossier seront également cachés"
#: allianceauth/menu/models.py:60
#: allianceauth/menu/models.py:59
msgid "icon classes"
msgstr "classes d'icônes"
#: allianceauth/menu/models.py:62
#: allianceauth/menu/models.py:61
msgid ""
"Font Awesome classes to show as icon on menu, e.g. <code>fa-solid fa-"
"house</code>"
@ -1517,11 +1479,11 @@ msgstr ""
"Classes Font Awesome à afficher comme icône dans le menu, exemple <code>fa-"
"solid fa-house</code>"
#: allianceauth/menu/models.py:68
#: allianceauth/menu/models.py:67
msgid "url"
msgstr "url"
#: allianceauth/menu/models.py:69
#: allianceauth/menu/models.py:68
msgid "External URL this menu items will link to"
msgstr "URL externe vers lequel cette élément du menu renvoi"
@ -1530,63 +1492,44 @@ msgid "Add folder"
msgstr "Ajouter un dossier"
#: allianceauth/menu/templates/menu/menu-notification-block.html:12
#: allianceauth/notifications/apps.py:8
#: allianceauth/notifications/templates/notifications/list.html:7
#: allianceauth/notifications/templates/notifications/list.html:11
#: allianceauth/templates/allianceauth/notifications_menu_item.html:6
msgid "Notifications"
msgstr "Alertes"
#: allianceauth/menu/templates/menu/menu-user.html:77
#: allianceauth/menu/templates/menu/menu-user.html:56
msgid "Super User"
msgstr "Super Utilisateur"
#: allianceauth/menu/templates/menu/menu-user.html:83
#: allianceauth/menu/templates/menu/menu-user.html:86
msgid "Alliance Auth Documentation"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:94
#: allianceauth/menu/templates/menu/menu-user.html:97
msgid "Alliance Auth Discord"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:105
#: allianceauth/menu/templates/menu/menu-user.html:108
msgid "Alliance Auth Git"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:118
#: allianceauth/menu/templates/menu/menu-user.html:121
#: allianceauth/menu/templates/menu/menu-user.html:70
#: allianceauth/templates/allianceauth/top-menu-admin.html:9
msgid "Admin"
msgstr "Administrateur"
#: allianceauth/menu/templates/menu/menu-user.html:144
#: allianceauth/menu/templates/menu/menu-user.html:147
#: allianceauth/menu/templates/menu/menu-user.html:82
msgid "Sign Out"
msgstr "Se Déconnecter"
#: allianceauth/menu/templates/menu/menu-user.html:155
#: allianceauth/menu/templates/menu/menu-user.html:158
#: allianceauth/menu/templates/menu/menu-user.html:86
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:17
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:18
msgid "Sign In"
msgstr "Se Connecter"
#: allianceauth/notifications/models.py:22
#: allianceauth/notifications/models.py:21
msgid "danger"
msgstr "danger"
#: allianceauth/notifications/models.py:23
#: allianceauth/notifications/models.py:22
msgid "warning"
msgstr "attention"
#: allianceauth/notifications/models.py:24
#: allianceauth/notifications/models.py:23
msgid "info"
msgstr "information"
#: allianceauth/notifications/models.py:25
#: allianceauth/notifications/models.py:24
msgid "success"
msgstr "succès"
@ -1643,7 +1586,7 @@ msgstr "Toutes les notifications ont été marquées comme lues."
msgid "Deleted all read notifications."
msgstr "Supprimer toutes les notifications lues"
#: allianceauth/optimer/apps.py:8 allianceauth/optimer/auth_hooks.py:12
#: allianceauth/optimer/auth_hooks.py:12
msgid "Fleet Operations"
msgstr "Opérations de flotte"
@ -1717,6 +1660,11 @@ msgstr "Opération"
msgid "Form Up System"
msgstr "Système de départ"
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
msgid "EVE Time"
msgstr "Temps EVE"
#: allianceauth/optimer/templates/optimer/fleetoptable.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:13
msgid "Local Time"
@ -1732,8 +1680,8 @@ msgstr "Gestion des opérations de flotte"
#: allianceauth/optimer/templates/optimer/management.html:28
#: allianceauth/timerboard/templates/timerboard/view.html:32
msgid "Current EVE time:"
msgstr ""
msgid "Current Eve Time:"
msgstr "Heure d'Eve actuelle:"
#: allianceauth/optimer/templates/optimer/management.html:36
msgid "Next Fleet Operations"
@ -1777,7 +1725,6 @@ msgstr "Minuteur d'opération supprimé pour %(opname)s."
msgid "Saved changes to operation timer for %(opname)s."
msgstr "Minuteur d'opération modifié pour %(opname)s."
#: allianceauth/permissions_tool/apps.py:8
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:7
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:11
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:17
@ -1834,7 +1781,7 @@ msgstr "Ce compte de service existe déjà."
msgid "Successfully set your {self.service_name} password"
msgstr "Mot de passe {self.service_name} créé avec succès."
#: allianceauth/services/apps.py:8 allianceauth/services/auth_hooks.py:12
#: allianceauth/services/auth_hooks.py:12
msgid "Services"
msgstr "Services"
@ -1898,10 +1845,6 @@ msgstr "Mot de passe"
msgid "Password must be at least 8 characters long."
msgstr "Votre mot de passe doit contenir au moins 8 caractères."
#: allianceauth/services/modules/discord/apps.py:8
msgid "Discord Service"
msgstr ""
#: allianceauth/services/modules/discord/models.py:187
msgid "Discord Account Disabled"
msgstr "Compte Discord Désactivé"
@ -1954,10 +1897,6 @@ msgstr ""
"Une erreur est survenue durant une tentative d'activation de votre compte "
"Discord. Veuillez réessayer plus tard."
#: allianceauth/services/modules/discourse/apps.py:8
msgid "Discourse Service"
msgstr ""
#: allianceauth/services/modules/discourse/templates/services/discourse/discourse_service_ctrl.html:5
msgid "Discourse"
msgstr "Discours"
@ -1993,14 +1932,6 @@ msgid "Invalid payload. Please contact support if this problem persists."
msgstr ""
"Charge invalide. Veuillez contacter le support si ce problème persiste."
#: allianceauth/services/modules/example/apps.py:8
msgid "Example Service"
msgstr ""
#: allianceauth/services/modules/ips4/apps.py:8
msgid "IPS4 Service"
msgstr ""
#: allianceauth/services/modules/ips4/views.py:31
msgid "Activated IPSuite4 account."
msgstr "Compte IPSuite4 activé."
@ -2024,10 +1955,6 @@ msgstr "Définir le mot de passe IPSuite4."
msgid "Deactivated IPSuite4 account."
msgstr "Compte IPSuite4 désactivé."
#: allianceauth/services/modules/mumble/apps.py:8
msgid "Mumble Service"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:7
msgid "Mumble"
msgstr ""
@ -2083,10 +2010,6 @@ msgstr "Connecter"
msgid "Mumble Connection History"
msgstr ""
#: allianceauth/services/modules/openfire/apps.py:8
msgid "Openfire Service"
msgstr ""
#: allianceauth/services/modules/openfire/auth_hooks.py:27
msgid "Jabber"
msgstr "Jabber"
@ -2138,10 +2061,6 @@ msgstr "Envoi d'une diffusion Jabber à %s"
msgid "Set jabber password."
msgstr "Définir le mot de passe Jabber."
#: allianceauth/services/modules/phpbb3/apps.py:8
msgid "phpBB3 Service"
msgstr ""
#: allianceauth/services/modules/phpbb3/views.py:34
msgid "Activated forum account."
msgstr "Compte de forum activé."
@ -2165,10 +2084,6 @@ msgstr "Réinitialiser le mot de passe du forum."
msgid "Set forum password."
msgstr "Définir le mot de passe du forum."
#: allianceauth/services/modules/smf/apps.py:8
msgid "SMF Service"
msgstr ""
#: allianceauth/services/modules/smf/views.py:52
msgid "Activated SMF account."
msgstr "Compte SMF activé"
@ -2192,10 +2107,6 @@ msgstr "Réinitialiser le mot de passe SMF."
msgid "Set SMF password."
msgstr "Définir le mot de passe SMF."
#: allianceauth/services/modules/teamspeak3/apps.py:8
msgid "TeamSpeak 3 Service"
msgstr ""
#: allianceauth/services/modules/teamspeak3/forms.py:14
#, python-format
msgid "Unable to locate user %s on server"
@ -2245,10 +2156,6 @@ msgstr "Compte TeamSpeak3 désactivé"
msgid "Reset TeamSpeak3 permission key."
msgstr "Réinitialisez la clé d'autorisation TeamSpeak3."
#: allianceauth/services/modules/xenforo/apps.py:8
msgid "Xenforo Service"
msgstr ""
#: allianceauth/services/modules/xenforo/views.py:30
msgid "Activated XenForo account."
msgstr "Compte XenForo activé"
@ -2362,7 +2269,7 @@ msgstr ""
"Certains services donne différentes options. Survoler les boutons pour en "
"savoir plus."
#: allianceauth/srp/apps.py:8 allianceauth/srp/auth_hooks.py:14
#: allianceauth/srp/auth_hooks.py:14
msgid "Ship Replacement"
msgstr "Remplacement de vaisseau"
@ -2438,18 +2345,18 @@ msgid "Mark Completed"
msgstr "Marquer Complet"
#: allianceauth/srp/templates/srp/data.html:48
#: allianceauth/srp/templates/srp/data.html:142
#: allianceauth/srp/templates/srp/data.html:139
msgid "Total Losses:"
msgstr "Pertes totales:"
#: allianceauth/srp/templates/srp/data.html:49
#: allianceauth/srp/templates/srp/data.html:143
#: allianceauth/srp/templates/srp/data.html:140
#: allianceauth/srp/templates/srp/management.html:36
msgid "Total ISK Cost:"
msgstr "Coût en ISK total:"
#: allianceauth/srp/templates/srp/data.html:60
#: allianceauth/srp/templates/srp/data.html:154
#: allianceauth/srp/templates/srp/data.html:151
msgid "Are you sure you want to delete SRP requests?"
msgstr "Êtes-vous sûr de vouloir supprimer la requête de SRP ?"
@ -2483,12 +2390,12 @@ msgstr ""
msgid "Post Time"
msgstr "Heure de publication"
#: allianceauth/srp/templates/srp/data.html:102
#: allianceauth/srp/templates/srp/data.html:99
#: allianceauth/srp/templates/srp/management.html:70
msgid "Link"
msgstr "Lien"
#: allianceauth/srp/templates/srp/data.html:163
#: allianceauth/srp/templates/srp/data.html:160
msgid "No SRP requests for this fleet."
msgstr "Aucune requête d'SRP pour cette flotte"
@ -2676,48 +2583,52 @@ msgstr "Votre serveur a reçu une erreur ESI avec pour code"
msgid "Alliance Auth Notifications"
msgstr "Alertes Alliance Auth"
#: allianceauth/templates/allianceauth/admin-status/overview.html:20
#: allianceauth/templates/allianceauth/admin-status/overview.html:18
msgid "Closed"
msgstr "Fermé"
#: allianceauth/templates/allianceauth/admin-status/overview.html:24
msgid "No notifications at this time"
msgstr "Aucune notification pour le moment"
#: allianceauth/templates/allianceauth/admin-status/overview.html:29
#: allianceauth/templates/allianceauth/admin-status/overview.html:33
msgid "Powered by GitLab"
msgstr "Propulsé par Gitlab"
#: allianceauth/templates/allianceauth/admin-status/overview.html:35
#: allianceauth/templates/allianceauth/admin-status/overview.html:39
msgid "Support Discord"
msgstr "Support Discord"
#: allianceauth/templates/allianceauth/admin-status/overview.html:49
#: allianceauth/templates/allianceauth/admin-status/overview.html:53
#: allianceauth/templates/allianceauth/admin-status/overview.html:57
msgid "Software Version"
msgstr "Version du logiciel"
#: allianceauth/templates/allianceauth/admin-status/overview.html:56
#: allianceauth/templates/allianceauth/admin-status/overview.html:60
msgid "Current"
msgstr "Actuelle"
#: allianceauth/templates/allianceauth/admin-status/overview.html:63
#: allianceauth/templates/allianceauth/admin-status/overview.html:67
msgid "Latest Stable"
msgstr "Dernière version stable"
#: allianceauth/templates/allianceauth/admin-status/overview.html:68
#: allianceauth/templates/allianceauth/admin-status/overview.html:72
msgid "Update available"
msgstr "Mise à jour disponible"
#: allianceauth/templates/allianceauth/admin-status/overview.html:76
#: allianceauth/templates/allianceauth/admin-status/overview.html:80
msgid "Latest Pre-Release"
msgstr "Dernière Pre-Release"
#: allianceauth/templates/allianceauth/admin-status/overview.html:81
#: allianceauth/templates/allianceauth/admin-status/overview.html:85
msgid "Pre-Release available"
msgstr "Pre-Release disponible"
#: allianceauth/templates/allianceauth/admin-status/overview.html:91
#: allianceauth/templates/allianceauth/admin-status/overview.html:95
msgid "Task Queue"
msgstr "File d'attente des tâches"
#: allianceauth/templates/allianceauth/admin-status/overview.html:96
#: allianceauth/templates/allianceauth/admin-status/overview.html:100
#, python-format
msgid ""
"\n"
@ -2727,11 +2638,11 @@ msgstr ""
"\n"
" Status de %(total)s tâches traitées • %(latest)s restantes"
#: allianceauth/templates/allianceauth/admin-status/overview.html:112
#: allianceauth/templates/allianceauth/admin-status/overview.html:116
msgid "running"
msgstr "en cours d'exécution"
#: allianceauth/templates/allianceauth/admin-status/overview.html:113
#: allianceauth/templates/allianceauth/admin-status/overview.html:117
msgid "queued"
msgstr "en attente"
@ -2756,17 +2667,10 @@ msgstr "Déconnexion"
msgid "Toggle navigation"
msgstr "Activer navigation"
#: allianceauth/theme/templates/theme/theme_select.html:11
#: allianceauth/theme/templates/theme/theme_select.html:7
msgid "Select Theme"
msgstr "Sélectionner un thème"
#: allianceauth/timerboard/apps.py:8
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "Minuteur de structure"
#: allianceauth/timerboard/form.py:36
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:8
@ -2953,10 +2857,6 @@ msgstr "Désancrage"
msgid "Abandoned"
msgstr ""
#: allianceauth/timerboard/models.py:60
msgid "Theft"
msgstr ""
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:7
#: allianceauth/timerboard/templates/timerboard/view.html:54
msgid "Upcoming Timers"
@ -2966,6 +2866,12 @@ msgstr "Prochaines Échéances"
msgid "Timer"
msgstr "Échéances"
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "Minuteur de structure"
#: allianceauth/timerboard/templates/timerboard/form.html:25
msgid "Structure Timer Details"
msgstr "Détails d'une échéance de structure"

View File

@ -13,7 +13,7 @@ msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2025-06-19 20:23+1000\n"
"POT-Creation-Date: 2025-02-25 19:17+1000\n"
"PO-Revision-Date: 2023-11-08 13:50+0000\n"
"Last-Translator: Tuz, 2024\n"
"Language-Team: Italian (Italy) (https://app.transifex.com/alliance-auth/teams/107430/it_IT/)\n"
@ -23,10 +23,6 @@ msgstr ""
"Language: it_IT\n"
"Plural-Forms: nplurals=3; plural=n == 1 ? 0 : n != 0 && n % 1000000 == 0 ? 1 : 2;\n"
#: allianceauth/analytics/apps.py:8
msgid "Analytics"
msgstr ""
#: allianceauth/analytics/models.py:22
msgid "Google Analytics Universal"
msgstr "Google Analytics Universal"
@ -35,10 +31,6 @@ msgstr "Google Analytics Universal"
msgid "Google Analytics V4"
msgstr "Google Analytics V4"
#: allianceauth/authentication/apps.py:9
msgid "Authentication"
msgstr ""
#: allianceauth/authentication/constants.py:6
msgid ""
"This software has exceeded the error limit for ESI. If you are a user, "
@ -54,7 +46,7 @@ msgstr ""
"chiacchierare con noi in ##3rd-party-dev-and-esi su EVE Online Discord. "
"https://www.eveonline.com/discord"
#: allianceauth/authentication/decorators.py:52
#: allianceauth/authentication/decorators.py:49
msgid "A main character is required to perform that action. Add one below."
msgstr ""
"Per completare questa azione è necessario un personaggio principale. "
@ -69,91 +61,91 @@ msgstr "Indirizzo di posta elettronica"
msgid "You are not allowed to add or remove these restricted groups: %s"
msgstr "Non ti è consentito aggiungere o rimuovere questi gruppi ristretti:%s"
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:106
#: allianceauth/authentication/models.py:70
#: allianceauth/project_template/project_name/settings/base.py:105
msgid "English"
msgstr "Inglese"
#: allianceauth/authentication/models.py:73
#: allianceauth/authentication/models.py:71
msgid "Czech"
msgstr ""
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:108
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:107
msgid "German"
msgstr "Tedesco"
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:109
#: allianceauth/authentication/models.py:73
#: allianceauth/project_template/project_name/settings/base.py:108
msgid "Spanish"
msgstr "Spagnolo"
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:110
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:109
msgid "Italian"
msgstr "Italiano"
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:111
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:110
msgid "Japanese"
msgstr "Giapponese"
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:112
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:111
msgid "Korean"
msgstr "Coreano"
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:112
msgid "French"
msgstr "Francese"
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:116
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:115
msgid "Russian"
msgstr "Russo"
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:114
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
msgid "Dutch"
msgstr ""
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:115
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:114
msgid "Polish"
msgstr ""
#: allianceauth/authentication/models.py:83
#: allianceauth/project_template/project_name/settings/base.py:117
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:116
msgid "Ukrainian"
msgstr "Ucraino"
#: allianceauth/authentication/models.py:84
#: allianceauth/project_template/project_name/settings/base.py:118
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:117
msgid "Simplified Chinese"
msgstr ""
#: allianceauth/authentication/models.py:100
#: allianceauth/menu/templates/menu/menu-user.html:67
#: allianceauth/authentication/models.py:98
#: allianceauth/menu/templates/menu/menu-user.html:42
msgid "Language"
msgstr "Lingua"
#: allianceauth/authentication/models.py:105
#: allianceauth/authentication/models.py:103
#: allianceauth/templates/allianceauth/night-toggle.html:6
msgid "Night Mode"
msgstr "Modalità scura"
#: allianceauth/authentication/models.py:109
#: allianceauth/theme/templates/theme/theme_select.html:4
#: allianceauth/authentication/models.py:107
#: allianceauth/menu/templates/menu/menu-user.html:46
msgid "Theme"
msgstr "Tema"
#: allianceauth/authentication/models.py:126
#: allianceauth/authentication/models.py:124
#, python-format
msgid "State changed to: %s"
msgstr "Stato modificato a: %s"
#: allianceauth/authentication/models.py:127
#: allianceauth/authentication/models.py:125
#, python-format
msgid "Your user's state is now: %(state)s"
msgstr "Il tuo stato utente è ora: %(state)s"
@ -215,8 +207,6 @@ msgstr "Stato:"
#: allianceauth/authentication/templates/authentication/tokens.html:7
#: allianceauth/authentication/templates/authentication/tokens.html:11
#: allianceauth/menu/templates/menu/menu-user.html:133
#: allianceauth/menu/templates/menu/menu-user.html:136
#: allianceauth/templates/allianceauth/top-menu-user-dropdown.html:62
msgid "Token Management"
msgstr "Gestione dei Token"
@ -290,7 +280,7 @@ msgstr "Registrati"
msgid "Invalid or expired activation link."
msgstr "Il link di attivazione è invalido o scaduto."
#: allianceauth/authentication/views.py:158
#: allianceauth/authentication/views.py:157
#, python-format
msgid ""
"Cannot change main character to %(char)s: character owned by a different "
@ -299,24 +289,24 @@ msgstr ""
"Il seguente personaggio %(char)s non può essere reso principale: è già "
"utilizzato da un altro account."
#: allianceauth/authentication/views.py:165
#: allianceauth/authentication/views.py:164
#, python-format
msgid "Changed main character to %s"
msgstr "Cambiato il personaggio principale in %s"
#: allianceauth/authentication/views.py:179
#: allianceauth/authentication/views.py:178
#, python-format
msgid "Added %(name)s to your account."
msgstr "%(name)s è stato aggiunto al tuo profilo."
#: allianceauth/authentication/views.py:181
#: allianceauth/authentication/views.py:180
#, python-format
msgid "Failed to add %(name)s to your account: they already have an account."
msgstr ""
"Impossibile aggiungere %(name)s al tuo account: quel personaggio è già "
"collegato ad un altro account."
#: allianceauth/authentication/views.py:226
#: allianceauth/authentication/views.py:225
msgid ""
"Unable to authenticate as the selected character. Please log in with the "
"main character associated with this account."
@ -324,11 +314,11 @@ msgstr ""
"Impossibile autenticarsi con il personaggio selezionato. Accedere con il "
"personaggio principale associato a questo account."
#: allianceauth/authentication/views.py:293
#: allianceauth/authentication/views.py:292
msgid "Registration token has expired."
msgstr "Il token di registrazione è scaduto."
#: allianceauth/authentication/views.py:354
#: allianceauth/authentication/views.py:353
msgid ""
"Sent confirmation email. Please follow the link to confirm your email "
"address."
@ -336,17 +326,17 @@ msgstr ""
"Una e-mail di conferma è stata inviata. Per favore, utilizza il link per "
"confermare il tuo indirizzo di posta elettronica."
#: allianceauth/authentication/views.py:360
#: allianceauth/authentication/views.py:359
msgid "Confirmed your email address. Please login to continue."
msgstr ""
"Il tuo indirizzo di posta elettronica è stato confermato. Per favore accedi "
"per continuare."
#: allianceauth/authentication/views.py:366
#: allianceauth/authentication/views.py:365
msgid "Registration of new accounts is not allowed at this time."
msgstr "Al momento non è possibile registrare nuovi account."
#: allianceauth/corputils/apps.py:8 allianceauth/corputils/auth_hooks.py:12
#: allianceauth/corputils/auth_hooks.py:12
msgid "Corporation Stats"
msgstr "Statistiche della corporazione"
@ -454,10 +444,6 @@ msgstr ""
"Impossibile raccogliere le statistiche sulla corporazione con il token "
"selezionato."
#: allianceauth/crontab/apps.py:16
msgid "Crontab"
msgstr ""
#: allianceauth/crontab/models.py:13
msgid "Minute Offset"
msgstr ""
@ -491,15 +477,6 @@ msgstr ""
msgid "This CSS will be added to the site after the default CSS."
msgstr ""
#: allianceauth/eveonline/apps.py:8
msgid "EVE Online"
msgstr ""
#: allianceauth/eveonline/autogroups/apps.py:8
msgid "EVE Online Autogroups"
msgstr ""
#: allianceauth/fleetactivitytracking/apps.py:8
#: allianceauth/fleetactivitytracking/auth_hooks.py:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/characternotexisting.html:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkcreate.html:11
@ -610,12 +587,10 @@ msgstr "Nave"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkpersonalmonthlystatisticsview.html:75
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:44
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:92
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/templates/allianceauth/top-menu.html:23
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
#: allianceauth/timerboard/templates/timerboard/timertable.html:12
msgid "EVE time"
msgstr ""
msgid "Eve Time"
msgstr "Ora Eve"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkmodify.html:49
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:52
@ -783,11 +758,6 @@ msgstr ""
"Impossibile registrare la partecipazione alla flotta per "
"{character.character_name}. Il personaggio deve essere online."
#: allianceauth/framework/apps.py:16
msgid "Framework"
msgstr ""
#: allianceauth/groupmanagement/apps.py:8
#: allianceauth/groupmanagement/auth_hooks.py:18
#: allianceauth/groupmanagement/templates/groupmanagement/groups.html:18
msgid "Group Management"
@ -1042,7 +1012,7 @@ msgid "Hidden"
msgstr "Nascosto"
#: allianceauth/groupmanagement/templates/groupmanagement/groupmembership.html:45
#: allianceauth/templates/allianceauth/admin-status/overview.html:15
#: allianceauth/templates/allianceauth/admin-status/overview.html:16
msgid "Open"
msgstr "Aperto"
@ -1095,7 +1065,7 @@ msgstr "Abbandona"
#: allianceauth/hrapplications/templates/hrapplications/management.html:182
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:46
#: allianceauth/hrapplications/templates/hrapplications/view.html:25
#: allianceauth/srp/templates/srp/data.html:120
#: allianceauth/srp/templates/srp/data.html:117
#: allianceauth/srp/templates/srp/management.html:87
msgid "Pending"
msgstr "In attesa"
@ -1246,10 +1216,6 @@ msgstr "Hai già una richiesta di congedo in sospeso per quel gruppo."
msgid "Applied to leave group %(group)s."
msgstr "Hai fatto domanda di congedo per %(group)s."
#: allianceauth/hrapplications/apps.py:8
msgid "HR Applications"
msgstr ""
#: allianceauth/hrapplications/auth_hooks.py:15
msgid "Applications"
msgstr "Domande"
@ -1321,7 +1287,7 @@ msgstr "Nome utente"
#: allianceauth/hrapplications/templates/hrapplications/management.html:185
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:48
#: allianceauth/hrapplications/templates/hrapplications/view.html:21
#: allianceauth/srp/templates/srp/data.html:112
#: allianceauth/srp/templates/srp/data.html:109
msgid "Approved"
msgstr "Approvato"
@ -1329,7 +1295,7 @@ msgstr "Approvato"
#: allianceauth/hrapplications/templates/hrapplications/management.html:143
#: allianceauth/hrapplications/templates/hrapplications/management.html:187
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:50
#: allianceauth/srp/templates/srp/data.html:116
#: allianceauth/srp/templates/srp/data.html:113
msgid "Rejected"
msgstr "Rifiutato"
@ -1444,7 +1410,7 @@ msgstr "Modifica %s voce di menu"
msgid "children"
msgstr "bambini"
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:22
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:21
msgid "text"
msgstr "testo"
@ -1456,15 +1422,11 @@ msgstr "definito dall'utente"
msgid "visible"
msgstr "visibile"
#: allianceauth/menu/apps.py:16
msgid "Menu"
msgstr ""
#: allianceauth/menu/constants.py:16
msgid "app"
msgstr "app"
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:38
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:37
msgid "folder"
msgstr "cartella"
@ -1476,27 +1438,27 @@ msgstr "link"
msgid "type"
msgstr "tipo"
#: allianceauth/menu/models.py:23
#: allianceauth/menu/models.py:22
msgid "Text to show on menu"
msgstr "Testo da mostrare sul menu"
#: allianceauth/menu/models.py:28
#: allianceauth/menu/models.py:27
msgid "order"
msgstr "ordine"
#: allianceauth/menu/models.py:29
#: allianceauth/menu/models.py:28
msgid "Order of the menu. Lowest First"
msgstr "Ordine del menu. Prima il più basso"
#: allianceauth/menu/models.py:39
#: allianceauth/menu/models.py:38
msgid "Folder this item is in (optional)"
msgstr "Cartella in cui si trova questo oggetto (facoltativo)"
#: allianceauth/menu/models.py:43
#: allianceauth/menu/models.py:42
msgid "is hidden"
msgstr "è nascosto"
#: allianceauth/menu/models.py:45
#: allianceauth/menu/models.py:44
msgid ""
"Hide this menu item.If this item is a folder all items under it will be "
"hidden too"
@ -1504,21 +1466,21 @@ msgstr ""
"Nascondi e se questa voce è una cartella, tutte le voci sotto di essa "
"saranno nascoste."
#: allianceauth/menu/models.py:60
#: allianceauth/menu/models.py:59
msgid "icon classes"
msgstr "classi di icone"
#: allianceauth/menu/models.py:62
#: allianceauth/menu/models.py:61
msgid ""
"Font Awesome classes to show as icon on menu, e.g. <code>fa-solid fa-"
"house</code>"
msgstr ""
#: allianceauth/menu/models.py:68
#: allianceauth/menu/models.py:67
msgid "url"
msgstr "url"
#: allianceauth/menu/models.py:69
#: allianceauth/menu/models.py:68
msgid "External URL this menu items will link to"
msgstr ""
@ -1527,63 +1489,44 @@ msgid "Add folder"
msgstr "Aggiungi cartella"
#: allianceauth/menu/templates/menu/menu-notification-block.html:12
#: allianceauth/notifications/apps.py:8
#: allianceauth/notifications/templates/notifications/list.html:7
#: allianceauth/notifications/templates/notifications/list.html:11
#: allianceauth/templates/allianceauth/notifications_menu_item.html:6
msgid "Notifications"
msgstr "Notifiche"
#: allianceauth/menu/templates/menu/menu-user.html:77
#: allianceauth/menu/templates/menu/menu-user.html:56
msgid "Super User"
msgstr "Super User"
#: allianceauth/menu/templates/menu/menu-user.html:83
#: allianceauth/menu/templates/menu/menu-user.html:86
msgid "Alliance Auth Documentation"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:94
#: allianceauth/menu/templates/menu/menu-user.html:97
msgid "Alliance Auth Discord"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:105
#: allianceauth/menu/templates/menu/menu-user.html:108
msgid "Alliance Auth Git"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:118
#: allianceauth/menu/templates/menu/menu-user.html:121
#: allianceauth/menu/templates/menu/menu-user.html:70
#: allianceauth/templates/allianceauth/top-menu-admin.html:9
msgid "Admin"
msgstr "Amministratore"
#: allianceauth/menu/templates/menu/menu-user.html:144
#: allianceauth/menu/templates/menu/menu-user.html:147
#: allianceauth/menu/templates/menu/menu-user.html:82
msgid "Sign Out"
msgstr "Sign Out"
#: allianceauth/menu/templates/menu/menu-user.html:155
#: allianceauth/menu/templates/menu/menu-user.html:158
#: allianceauth/menu/templates/menu/menu-user.html:86
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:17
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:18
msgid "Sign In"
msgstr "Sign In"
#: allianceauth/notifications/models.py:22
#: allianceauth/notifications/models.py:21
msgid "danger"
msgstr "pericolo"
#: allianceauth/notifications/models.py:23
#: allianceauth/notifications/models.py:22
msgid "warning"
msgstr "attenzione"
#: allianceauth/notifications/models.py:24
#: allianceauth/notifications/models.py:23
msgid "info"
msgstr "informazioni"
#: allianceauth/notifications/models.py:25
#: allianceauth/notifications/models.py:24
msgid "success"
msgstr "successo"
@ -1640,7 +1583,7 @@ msgstr "Contrassegna tutte le notifiche come lette."
msgid "Deleted all read notifications."
msgstr "Elimina tutte le notifiche lette."
#: allianceauth/optimer/apps.py:8 allianceauth/optimer/auth_hooks.py:12
#: allianceauth/optimer/auth_hooks.py:12
msgid "Fleet Operations"
msgstr "Operazioni di flotta"
@ -1714,6 +1657,11 @@ msgstr ""
msgid "Form Up System"
msgstr "Sistema di partenza"
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
msgid "EVE Time"
msgstr ""
#: allianceauth/optimer/templates/optimer/fleetoptable.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:13
msgid "Local Time"
@ -1729,8 +1677,8 @@ msgstr "Gestione delle operazioni di flotta"
#: allianceauth/optimer/templates/optimer/management.html:28
#: allianceauth/timerboard/templates/timerboard/view.html:32
msgid "Current EVE time:"
msgstr ""
msgid "Current Eve Time:"
msgstr "Ora EVE attuale:"
#: allianceauth/optimer/templates/optimer/management.html:36
msgid "Next Fleet Operations"
@ -1774,7 +1722,6 @@ msgstr "Rimosso il timer per l'operazione %(opname)s."
msgid "Saved changes to operation timer for %(opname)s."
msgstr "Salvati i cambiamenti per l'operazione %(opname)s."
#: allianceauth/permissions_tool/apps.py:8
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:7
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:11
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:17
@ -1831,7 +1778,7 @@ msgstr "Un account per questo servizio già esiste"
msgid "Successfully set your {self.service_name} password"
msgstr "La password del {self.service_name} è stata impostata con sucesso"
#: allianceauth/services/apps.py:8 allianceauth/services/auth_hooks.py:12
#: allianceauth/services/auth_hooks.py:12
msgid "Services"
msgstr "Servizi"
@ -1895,10 +1842,6 @@ msgstr "Password"
msgid "Password must be at least 8 characters long."
msgstr "La password deve contenere almeno 8 caratteri."
#: allianceauth/services/modules/discord/apps.py:8
msgid "Discord Service"
msgstr ""
#: allianceauth/services/modules/discord/models.py:187
msgid "Discord Account Disabled"
msgstr "Account discord disabilitato"
@ -1952,10 +1895,6 @@ msgstr ""
"Si è verificato un errore durante l'attivazione del tuo account discord. Per"
" favore ritenta."
#: allianceauth/services/modules/discourse/apps.py:8
msgid "Discourse Service"
msgstr ""
#: allianceauth/services/modules/discourse/templates/services/discourse/discourse_service_ctrl.html:5
msgid "Discourse"
msgstr "Discorso"
@ -1989,14 +1928,6 @@ msgstr ""
msgid "Invalid payload. Please contact support if this problem persists."
msgstr "Payload non valido. Contatta l'assistenza se il problema persiste."
#: allianceauth/services/modules/example/apps.py:8
msgid "Example Service"
msgstr ""
#: allianceauth/services/modules/ips4/apps.py:8
msgid "IPS4 Service"
msgstr ""
#: allianceauth/services/modules/ips4/views.py:31
msgid "Activated IPSuite4 account."
msgstr "Attiva account IPSuite4."
@ -2021,10 +1952,6 @@ msgstr "Imposta password IPSuite4."
msgid "Deactivated IPSuite4 account."
msgstr "Disattiva account IPSuite4."
#: allianceauth/services/modules/mumble/apps.py:8
msgid "Mumble Service"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:7
msgid "Mumble"
msgstr ""
@ -2080,10 +2007,6 @@ msgstr "Connect"
msgid "Mumble Connection History"
msgstr ""
#: allianceauth/services/modules/openfire/apps.py:8
msgid "Openfire Service"
msgstr ""
#: allianceauth/services/modules/openfire/auth_hooks.py:27
msgid "Jabber"
msgstr "Jabber"
@ -2135,10 +2058,6 @@ msgstr "Trasmissione Jabber inviata a %s"
msgid "Set jabber password."
msgstr "Imposta password jabber."
#: allianceauth/services/modules/phpbb3/apps.py:8
msgid "phpBB3 Service"
msgstr ""
#: allianceauth/services/modules/phpbb3/views.py:34
msgid "Activated forum account."
msgstr "Account forum attivato."
@ -2163,10 +2082,6 @@ msgstr "Reimposta password forum."
msgid "Set forum password."
msgstr "Imposta password forum."
#: allianceauth/services/modules/smf/apps.py:8
msgid "SMF Service"
msgstr ""
#: allianceauth/services/modules/smf/views.py:52
msgid "Activated SMF account."
msgstr "Attivato account SMF."
@ -2190,10 +2105,6 @@ msgstr "Reimposta password SMF."
msgid "Set SMF password."
msgstr "Imposta password SMF."
#: allianceauth/services/modules/teamspeak3/apps.py:8
msgid "TeamSpeak 3 Service"
msgstr ""
#: allianceauth/services/modules/teamspeak3/forms.py:14
#, python-format
msgid "Unable to locate user %s on server"
@ -2244,10 +2155,6 @@ msgstr "Disattivato account TeamSpeak3."
msgid "Reset TeamSpeak3 permission key."
msgstr "Reimposta la chiave di autorizzazione TeamSpeak3."
#: allianceauth/services/modules/xenforo/apps.py:8
msgid "Xenforo Service"
msgstr ""
#: allianceauth/services/modules/xenforo/views.py:30
msgid "Activated XenForo account."
msgstr "Attivato account XenForo."
@ -2360,7 +2267,7 @@ msgstr ""
"Alcuni servizi offrono diverse opzioni. Passate il mouse sopra per vederne "
"di più."
#: allianceauth/srp/apps.py:8 allianceauth/srp/auth_hooks.py:14
#: allianceauth/srp/auth_hooks.py:14
msgid "Ship Replacement"
msgstr "Sostituzione della nave"
@ -2438,18 +2345,18 @@ msgid "Mark Completed"
msgstr "Contrassegna completo"
#: allianceauth/srp/templates/srp/data.html:48
#: allianceauth/srp/templates/srp/data.html:142
#: allianceauth/srp/templates/srp/data.html:139
msgid "Total Losses:"
msgstr "Perdite totali:"
#: allianceauth/srp/templates/srp/data.html:49
#: allianceauth/srp/templates/srp/data.html:143
#: allianceauth/srp/templates/srp/data.html:140
#: allianceauth/srp/templates/srp/management.html:36
msgid "Total ISK Cost:"
msgstr "Costo totale in ISK:"
#: allianceauth/srp/templates/srp/data.html:60
#: allianceauth/srp/templates/srp/data.html:154
#: allianceauth/srp/templates/srp/data.html:151
msgid "Are you sure you want to delete SRP requests?"
msgstr "Sei sicuro di voler eliminare la richiesta di SRP?"
@ -2483,12 +2390,12 @@ msgstr ""
msgid "Post Time"
msgstr "Ora di pubblicazione"
#: allianceauth/srp/templates/srp/data.html:102
#: allianceauth/srp/templates/srp/data.html:99
#: allianceauth/srp/templates/srp/management.html:70
msgid "Link"
msgstr "Link"
#: allianceauth/srp/templates/srp/data.html:163
#: allianceauth/srp/templates/srp/data.html:160
msgid "No SRP requests for this fleet."
msgstr "Nessuna richiesta di SRP per questa flotta."
@ -2676,48 +2583,52 @@ msgstr "Il server ha ricevuto un codice di risposta di errore ESI pari a "
msgid "Alliance Auth Notifications"
msgstr "Notifiche Auth Alleanza"
#: allianceauth/templates/allianceauth/admin-status/overview.html:20
#: allianceauth/templates/allianceauth/admin-status/overview.html:18
msgid "Closed"
msgstr "Chiuso"
#: allianceauth/templates/allianceauth/admin-status/overview.html:24
msgid "No notifications at this time"
msgstr "Nessuna notifica al momento"
#: allianceauth/templates/allianceauth/admin-status/overview.html:29
#: allianceauth/templates/allianceauth/admin-status/overview.html:33
msgid "Powered by GitLab"
msgstr "Powered by GitLab"
#: allianceauth/templates/allianceauth/admin-status/overview.html:35
#: allianceauth/templates/allianceauth/admin-status/overview.html:39
msgid "Support Discord"
msgstr "Discord di supporto"
#: allianceauth/templates/allianceauth/admin-status/overview.html:49
#: allianceauth/templates/allianceauth/admin-status/overview.html:53
#: allianceauth/templates/allianceauth/admin-status/overview.html:57
msgid "Software Version"
msgstr "Versione del software"
#: allianceauth/templates/allianceauth/admin-status/overview.html:56
#: allianceauth/templates/allianceauth/admin-status/overview.html:60
msgid "Current"
msgstr "Attuale"
#: allianceauth/templates/allianceauth/admin-status/overview.html:63
#: allianceauth/templates/allianceauth/admin-status/overview.html:67
msgid "Latest Stable"
msgstr "Ultima versione stabile"
#: allianceauth/templates/allianceauth/admin-status/overview.html:68
#: allianceauth/templates/allianceauth/admin-status/overview.html:72
msgid "Update available"
msgstr "Aggiornamento disponibile"
#: allianceauth/templates/allianceauth/admin-status/overview.html:76
#: allianceauth/templates/allianceauth/admin-status/overview.html:80
msgid "Latest Pre-Release"
msgstr "Ultima versione preliminare"
#: allianceauth/templates/allianceauth/admin-status/overview.html:81
#: allianceauth/templates/allianceauth/admin-status/overview.html:85
msgid "Pre-Release available"
msgstr "Versione preliminare disponibile"
#: allianceauth/templates/allianceauth/admin-status/overview.html:91
#: allianceauth/templates/allianceauth/admin-status/overview.html:95
msgid "Task Queue"
msgstr "Coda delle attività"
#: allianceauth/templates/allianceauth/admin-status/overview.html:96
#: allianceauth/templates/allianceauth/admin-status/overview.html:100
#, python-format
msgid ""
"\n"
@ -2725,11 +2636,11 @@ msgid ""
" "
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:112
#: allianceauth/templates/allianceauth/admin-status/overview.html:116
msgid "running"
msgstr "in esecuzione"
#: allianceauth/templates/allianceauth/admin-status/overview.html:113
#: allianceauth/templates/allianceauth/admin-status/overview.html:117
msgid "queued"
msgstr "in coda"
@ -2754,17 +2665,10 @@ msgstr "Disconnettersi"
msgid "Toggle navigation"
msgstr "Attiva/disattiva navigazione"
#: allianceauth/theme/templates/theme/theme_select.html:11
#: allianceauth/theme/templates/theme/theme_select.html:7
msgid "Select Theme"
msgstr "Seleziona Tema"
#: allianceauth/timerboard/apps.py:8
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "Timer delle strutture"
#: allianceauth/timerboard/form.py:36
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:8
@ -2951,10 +2855,6 @@ msgstr "In disancoraggio"
msgid "Abandoned"
msgstr ""
#: allianceauth/timerboard/models.py:60
msgid "Theft"
msgstr ""
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:7
#: allianceauth/timerboard/templates/timerboard/view.html:54
msgid "Upcoming Timers"
@ -2964,6 +2864,12 @@ msgstr "Prossimi Timer"
msgid "Timer"
msgstr "Timer"
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "Timer delle strutture"
#: allianceauth/timerboard/templates/timerboard/form.html:25
msgid "Structure Timer Details"
msgstr "Dettagli del timer della struttura"

View File

@ -13,7 +13,7 @@ msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2025-06-19 20:23+1000\n"
"POT-Creation-Date: 2025-02-25 19:17+1000\n"
"PO-Revision-Date: 2023-11-08 13:50+0000\n"
"Last-Translator: kotaneko, 2024\n"
"Language-Team: Japanese (https://app.transifex.com/alliance-auth/teams/107430/ja/)\n"
@ -23,10 +23,6 @@ msgstr ""
"Language: ja\n"
"Plural-Forms: nplurals=1; plural=0;\n"
#: allianceauth/analytics/apps.py:8
msgid "Analytics"
msgstr ""
#: allianceauth/analytics/models.py:22
msgid "Google Analytics Universal"
msgstr "Google ユニバーサル アナリティクス"
@ -35,10 +31,6 @@ msgstr "Google ユニバーサル アナリティクス"
msgid "Google Analytics V4"
msgstr "Google アナリティクス 4"
#: allianceauth/authentication/apps.py:9
msgid "Authentication"
msgstr ""
#: allianceauth/authentication/constants.py:6
msgid ""
"This software has exceeded the error limit for ESI. If you are a user, "
@ -51,7 +43,7 @@ msgstr ""
" Online Discordの##3rd-party-dev-and-"
"esiで私たちと連絡を取り合ってください。https://www.eveonline.com/discord"
#: allianceauth/authentication/decorators.py:52
#: allianceauth/authentication/decorators.py:49
msgid "A main character is required to perform that action. Add one below."
msgstr "実行するためにはメインキャラクターの設定が必要です。設定してください。"
@ -64,91 +56,91 @@ msgstr "メールアドレス"
msgid "You are not allowed to add or remove these restricted groups: %s"
msgstr "これらの制限付きグループを追加または削除することはできません。%s"
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:106
#: allianceauth/authentication/models.py:70
#: allianceauth/project_template/project_name/settings/base.py:105
msgid "English"
msgstr "英語"
#: allianceauth/authentication/models.py:73
#: allianceauth/authentication/models.py:71
msgid "Czech"
msgstr ""
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:108
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:107
msgid "German"
msgstr "ドイツ語"
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:109
#: allianceauth/authentication/models.py:73
#: allianceauth/project_template/project_name/settings/base.py:108
msgid "Spanish"
msgstr "スペイン語"
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:110
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:109
msgid "Italian"
msgstr "イタリア語"
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:111
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:110
msgid "Japanese"
msgstr "日本語"
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:112
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:111
msgid "Korean"
msgstr "韓国語"
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:112
msgid "French"
msgstr "フランス語"
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:116
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:115
msgid "Russian"
msgstr "ロシア語"
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:114
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
msgid "Dutch"
msgstr ""
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:115
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:114
msgid "Polish"
msgstr ""
#: allianceauth/authentication/models.py:83
#: allianceauth/project_template/project_name/settings/base.py:117
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:116
msgid "Ukrainian"
msgstr "ウクライナ語"
#: allianceauth/authentication/models.py:84
#: allianceauth/project_template/project_name/settings/base.py:118
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:117
msgid "Simplified Chinese"
msgstr ""
#: allianceauth/authentication/models.py:100
#: allianceauth/menu/templates/menu/menu-user.html:67
#: allianceauth/authentication/models.py:98
#: allianceauth/menu/templates/menu/menu-user.html:42
msgid "Language"
msgstr "言語"
#: allianceauth/authentication/models.py:105
#: allianceauth/authentication/models.py:103
#: allianceauth/templates/allianceauth/night-toggle.html:6
msgid "Night Mode"
msgstr "ナイトモード"
#: allianceauth/authentication/models.py:109
#: allianceauth/theme/templates/theme/theme_select.html:4
#: allianceauth/authentication/models.py:107
#: allianceauth/menu/templates/menu/menu-user.html:46
msgid "Theme"
msgstr "テーマ"
#: allianceauth/authentication/models.py:126
#: allianceauth/authentication/models.py:124
#, python-format
msgid "State changed to: %s"
msgstr "分類が%sに変更されました。"
#: allianceauth/authentication/models.py:127
#: allianceauth/authentication/models.py:125
#, python-format
msgid "Your user's state is now: %(state)s"
msgstr "あなたの分類は%(state)sになりました。"
@ -210,8 +202,6 @@ msgstr "状態:"
#: allianceauth/authentication/templates/authentication/tokens.html:7
#: allianceauth/authentication/templates/authentication/tokens.html:11
#: allianceauth/menu/templates/menu/menu-user.html:133
#: allianceauth/menu/templates/menu/menu-user.html:136
#: allianceauth/templates/allianceauth/top-menu-user-dropdown.html:62
msgid "Token Management"
msgstr "トークン管理"
@ -285,53 +275,53 @@ msgstr "登録"
msgid "Invalid or expired activation link."
msgstr "アクティベーションリンクが無効か期限切れです。"
#: allianceauth/authentication/views.py:158
#: allianceauth/authentication/views.py:157
#, python-format
msgid ""
"Cannot change main character to %(char)s: character owned by a different "
"account."
msgstr "メインキャラクターを%(char)sへ変更できません。別のアカウントによって利用されています。"
#: allianceauth/authentication/views.py:165
#: allianceauth/authentication/views.py:164
#, python-format
msgid "Changed main character to %s"
msgstr "メインキャラクターをに変更 %s"
#: allianceauth/authentication/views.py:179
#: allianceauth/authentication/views.py:178
#, python-format
msgid "Added %(name)s to your account."
msgstr "%(name)sをアカウントに追加しました。"
#: allianceauth/authentication/views.py:181
#: allianceauth/authentication/views.py:180
#, python-format
msgid "Failed to add %(name)s to your account: they already have an account."
msgstr "%(name)sをアカウントに追加することができません。すでに他のアカウントを持っています。"
#: allianceauth/authentication/views.py:226
#: allianceauth/authentication/views.py:225
msgid ""
"Unable to authenticate as the selected character. Please log in with the "
"main character associated with this account."
msgstr "選択したキャラクターを認証できません。このアカウントに登録されているメインキャラクターでログインしてください。"
#: allianceauth/authentication/views.py:293
#: allianceauth/authentication/views.py:292
msgid "Registration token has expired."
msgstr "Registrationトークンが有効期限切れです。"
#: allianceauth/authentication/views.py:354
#: allianceauth/authentication/views.py:353
msgid ""
"Sent confirmation email. Please follow the link to confirm your email "
"address."
msgstr "確認のメールを送信しました。メール内のリンクをご確認の上、メールアドレスの認証を完了させてください。"
#: allianceauth/authentication/views.py:360
#: allianceauth/authentication/views.py:359
msgid "Confirmed your email address. Please login to continue."
msgstr "メールアドレスを確認しました。続行するにはログインしてください。"
#: allianceauth/authentication/views.py:366
#: allianceauth/authentication/views.py:365
msgid "Registration of new accounts is not allowed at this time."
msgstr "新規アカウントの登録は、現時点ではできません。"
#: allianceauth/corputils/apps.py:8 allianceauth/corputils/auth_hooks.py:12
#: allianceauth/corputils/auth_hooks.py:12
msgid "Corporation Stats"
msgstr "コーポレーション統計"
@ -437,10 +427,6 @@ msgstr "選択されたCorpはすでにStatistics Moduleを導入済みです。
msgid "Failed to gather corporation statistics with selected token."
msgstr "選択されたTokenではCorporation Statisticsを取得できませんでした。"
#: allianceauth/crontab/apps.py:16
msgid "Crontab"
msgstr ""
#: allianceauth/crontab/models.py:13
msgid "Minute Offset"
msgstr ""
@ -474,15 +460,6 @@ msgstr ""
msgid "This CSS will be added to the site after the default CSS."
msgstr ""
#: allianceauth/eveonline/apps.py:8
msgid "EVE Online"
msgstr ""
#: allianceauth/eveonline/autogroups/apps.py:8
msgid "EVE Online Autogroups"
msgstr ""
#: allianceauth/fleetactivitytracking/apps.py:8
#: allianceauth/fleetactivitytracking/auth_hooks.py:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/characternotexisting.html:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkcreate.html:11
@ -592,12 +569,10 @@ msgstr "艦船"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkpersonalmonthlystatisticsview.html:75
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:44
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:92
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/templates/allianceauth/top-menu.html:23
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
#: allianceauth/timerboard/templates/timerboard/timertable.html:12
msgid "EVE time"
msgstr ""
msgid "Eve Time"
msgstr "EVE内時間"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkmodify.html:49
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:52
@ -759,11 +734,6 @@ msgid ""
"character needs to be online."
msgstr "{character.character_name} のフリート参加を登録できません。キャラクターがオンラインである必要があります。"
#: allianceauth/framework/apps.py:16
msgid "Framework"
msgstr ""
#: allianceauth/groupmanagement/apps.py:8
#: allianceauth/groupmanagement/auth_hooks.py:18
#: allianceauth/groupmanagement/templates/groupmanagement/groups.html:18
msgid "Group Management"
@ -1002,7 +972,7 @@ msgid "Hidden"
msgstr "閉じる"
#: allianceauth/groupmanagement/templates/groupmanagement/groupmembership.html:45
#: allianceauth/templates/allianceauth/admin-status/overview.html:15
#: allianceauth/templates/allianceauth/admin-status/overview.html:16
msgid "Open"
msgstr "開く"
@ -1055,7 +1025,7 @@ msgstr "脱退"
#: allianceauth/hrapplications/templates/hrapplications/management.html:182
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:46
#: allianceauth/hrapplications/templates/hrapplications/view.html:25
#: allianceauth/srp/templates/srp/data.html:120
#: allianceauth/srp/templates/srp/data.html:117
#: allianceauth/srp/templates/srp/management.html:87
msgid "Pending"
msgstr "処理中"
@ -1197,10 +1167,6 @@ msgstr "すでに脱退申請を送信済みです。"
msgid "Applied to leave group %(group)s."
msgstr "%(group)sからの脱退申請を送信しました。"
#: allianceauth/hrapplications/apps.py:8
msgid "HR Applications"
msgstr ""
#: allianceauth/hrapplications/auth_hooks.py:15
msgid "Applications"
msgstr "申請"
@ -1272,7 +1238,7 @@ msgstr "ユーザー名"
#: allianceauth/hrapplications/templates/hrapplications/management.html:185
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:48
#: allianceauth/hrapplications/templates/hrapplications/view.html:21
#: allianceauth/srp/templates/srp/data.html:112
#: allianceauth/srp/templates/srp/data.html:109
msgid "Approved"
msgstr "承認"
@ -1280,7 +1246,7 @@ msgstr "承認"
#: allianceauth/hrapplications/templates/hrapplications/management.html:143
#: allianceauth/hrapplications/templates/hrapplications/management.html:187
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:50
#: allianceauth/srp/templates/srp/data.html:116
#: allianceauth/srp/templates/srp/data.html:113
msgid "Rejected"
msgstr "拒否"
@ -1395,7 +1361,7 @@ msgstr "変更 %s メニューアイテム"
msgid "children"
msgstr "子供"
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:22
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:21
msgid "text"
msgstr "テキスト"
@ -1407,15 +1373,11 @@ msgstr "ユーザー定義"
msgid "visible"
msgstr "表示可能"
#: allianceauth/menu/apps.py:16
msgid "Menu"
msgstr ""
#: allianceauth/menu/constants.py:16
msgid "app"
msgstr "app"
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:38
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:37
msgid "folder"
msgstr "フォルダー"
@ -1427,47 +1389,47 @@ msgstr "リンク"
msgid "type"
msgstr "タイプ"
#: allianceauth/menu/models.py:23
#: allianceauth/menu/models.py:22
msgid "Text to show on menu"
msgstr "メニューに表示するテキスト"
#: allianceauth/menu/models.py:28
#: allianceauth/menu/models.py:27
msgid "order"
msgstr "オーダー"
#: allianceauth/menu/models.py:29
#: allianceauth/menu/models.py:28
msgid "Order of the menu. Lowest First"
msgstr "メニューの順序。低い順"
#: allianceauth/menu/models.py:39
#: allianceauth/menu/models.py:38
msgid "Folder this item is in (optional)"
msgstr "このアイテムが入っているフォルダ (オプション)"
#: allianceauth/menu/models.py:43
#: allianceauth/menu/models.py:42
msgid "is hidden"
msgstr "非表示です"
#: allianceauth/menu/models.py:45
#: allianceauth/menu/models.py:44
msgid ""
"Hide this menu item.If this item is a folder all items under it will be "
"hidden too"
msgstr "このメニュー項目を非表示にします。この項目がフォルダの場合、その下にあるすべての項目も非表示になります"
#: allianceauth/menu/models.py:60
#: allianceauth/menu/models.py:59
msgid "icon classes"
msgstr "アイコンクラス"
#: allianceauth/menu/models.py:62
#: allianceauth/menu/models.py:61
msgid ""
"Font Awesome classes to show as icon on menu, e.g. <code>fa-solid fa-"
"house</code>"
msgstr "メニューにアイコンとして表示するFont Awesome クラス、例えば <code>fa-solid fa-house</code>"
#: allianceauth/menu/models.py:68
#: allianceauth/menu/models.py:67
msgid "url"
msgstr "URL"
#: allianceauth/menu/models.py:69
#: allianceauth/menu/models.py:68
msgid "External URL this menu items will link to"
msgstr "このメニュー項目のリンク先となる外部 URL"
@ -1476,63 +1438,44 @@ msgid "Add folder"
msgstr "フォルダーを追加"
#: allianceauth/menu/templates/menu/menu-notification-block.html:12
#: allianceauth/notifications/apps.py:8
#: allianceauth/notifications/templates/notifications/list.html:7
#: allianceauth/notifications/templates/notifications/list.html:11
#: allianceauth/templates/allianceauth/notifications_menu_item.html:6
msgid "Notifications"
msgstr "通知"
#: allianceauth/menu/templates/menu/menu-user.html:77
#: allianceauth/menu/templates/menu/menu-user.html:56
msgid "Super User"
msgstr "スーパーユーザ"
#: allianceauth/menu/templates/menu/menu-user.html:83
#: allianceauth/menu/templates/menu/menu-user.html:86
msgid "Alliance Auth Documentation"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:94
#: allianceauth/menu/templates/menu/menu-user.html:97
msgid "Alliance Auth Discord"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:105
#: allianceauth/menu/templates/menu/menu-user.html:108
msgid "Alliance Auth Git"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:118
#: allianceauth/menu/templates/menu/menu-user.html:121
#: allianceauth/menu/templates/menu/menu-user.html:70
#: allianceauth/templates/allianceauth/top-menu-admin.html:9
msgid "Admin"
msgstr "管理者"
#: allianceauth/menu/templates/menu/menu-user.html:144
#: allianceauth/menu/templates/menu/menu-user.html:147
#: allianceauth/menu/templates/menu/menu-user.html:82
msgid "Sign Out"
msgstr "サインアウト"
#: allianceauth/menu/templates/menu/menu-user.html:155
#: allianceauth/menu/templates/menu/menu-user.html:158
#: allianceauth/menu/templates/menu/menu-user.html:86
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:17
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:18
msgid "Sign In"
msgstr "サインイン"
#: allianceauth/notifications/models.py:22
#: allianceauth/notifications/models.py:21
msgid "danger"
msgstr "危険"
#: allianceauth/notifications/models.py:23
#: allianceauth/notifications/models.py:22
msgid "warning"
msgstr "警告"
#: allianceauth/notifications/models.py:24
#: allianceauth/notifications/models.py:23
msgid "info"
msgstr "情報"
#: allianceauth/notifications/models.py:25
#: allianceauth/notifications/models.py:24
msgid "success"
msgstr "成功"
@ -1589,7 +1532,7 @@ msgstr "確認済みのすべての通知を選択"
msgid "Deleted all read notifications."
msgstr "確認済みのすべての通知を削除"
#: allianceauth/optimer/apps.py:8 allianceauth/optimer/auth_hooks.py:12
#: allianceauth/optimer/auth_hooks.py:12
msgid "Fleet Operations"
msgstr "フリートオペレーション"
@ -1663,6 +1606,11 @@ msgstr "オペレーション"
msgid "Form Up System"
msgstr "フォームアップ星系"
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
msgid "EVE Time"
msgstr "EVE内時間"
#: allianceauth/optimer/templates/optimer/fleetoptable.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:13
msgid "Local Time"
@ -1678,8 +1626,8 @@ msgstr "フリートオペレーション管理"
#: allianceauth/optimer/templates/optimer/management.html:28
#: allianceauth/timerboard/templates/timerboard/view.html:32
msgid "Current EVE time:"
msgstr ""
msgid "Current Eve Time:"
msgstr "現在のゲーム内時間:"
#: allianceauth/optimer/templates/optimer/management.html:36
msgid "Next Fleet Operations"
@ -1723,7 +1671,6 @@ msgstr "%(opname)sのTimerが削除されました。"
msgid "Saved changes to operation timer for %(opname)s."
msgstr "%(opname)sのTimerの変更が保存されました。"
#: allianceauth/permissions_tool/apps.py:8
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:7
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:11
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:17
@ -1780,7 +1727,7 @@ msgstr "そのアカウントは既に存在してます。"
msgid "Successfully set your {self.service_name} password"
msgstr "{self.service_name} のパスワードが正常に設定されました"
#: allianceauth/services/apps.py:8 allianceauth/services/auth_hooks.py:12
#: allianceauth/services/auth_hooks.py:12
msgid "Services"
msgstr "サービス"
@ -1844,10 +1791,6 @@ msgstr "パスワード"
msgid "Password must be at least 8 characters long."
msgstr "Passwordは8 文字以上必要です。"
#: allianceauth/services/modules/discord/apps.py:8
msgid "Discord Service"
msgstr ""
#: allianceauth/services/modules/discord/models.py:187
msgid "Discord Account Disabled"
msgstr "Discordのアカウントを無効化"
@ -1897,10 +1840,6 @@ msgid ""
"again."
msgstr "Discord Accountの有効化中にエラーが発生しました。再度実行してください。"
#: allianceauth/services/modules/discourse/apps.py:8
msgid "Discourse Service"
msgstr ""
#: allianceauth/services/modules/discourse/templates/services/discourse/discourse_service_ctrl.html:5
msgid "Discourse"
msgstr "談話"
@ -1932,14 +1871,6 @@ msgstr "SSO Payload、もしくはSignatureを認証できませんでした。
msgid "Invalid payload. Please contact support if this problem persists."
msgstr "SSO Payloadが無効です。問題が解決しない場合、サポートへ連絡してください。"
#: allianceauth/services/modules/example/apps.py:8
msgid "Example Service"
msgstr ""
#: allianceauth/services/modules/ips4/apps.py:8
msgid "IPS4 Service"
msgstr ""
#: allianceauth/services/modules/ips4/views.py:31
msgid "Activated IPSuite4 account."
msgstr "IPSuite4 アカウントをアクティブ化しました。"
@ -1963,10 +1894,6 @@ msgstr "IPSuite4 のパスワードを設定します。"
msgid "Deactivated IPSuite4 account."
msgstr "IPSuite4 アカウントを非アクティブ化しました。"
#: allianceauth/services/modules/mumble/apps.py:8
msgid "Mumble Service"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:7
msgid "Mumble"
msgstr ""
@ -2022,10 +1949,6 @@ msgstr "接続"
msgid "Mumble Connection History"
msgstr ""
#: allianceauth/services/modules/openfire/apps.py:8
msgid "Openfire Service"
msgstr ""
#: allianceauth/services/modules/openfire/auth_hooks.py:27
msgid "Jabber"
msgstr "Jabber"
@ -2077,10 +2000,6 @@ msgstr "Jabberブロードキャストを %sに送信しました。"
msgid "Set jabber password."
msgstr "Jabber のパスワードを設定します。"
#: allianceauth/services/modules/phpbb3/apps.py:8
msgid "phpBB3 Service"
msgstr ""
#: allianceauth/services/modules/phpbb3/views.py:34
msgid "Activated forum account."
msgstr "フォーラムアカウントをアクティブ化しました。"
@ -2104,10 +2023,6 @@ msgstr "フォーラムのパスワードをリセットします。"
msgid "Set forum password."
msgstr "フォーラムのパスワードを設定します。"
#: allianceauth/services/modules/smf/apps.py:8
msgid "SMF Service"
msgstr ""
#: allianceauth/services/modules/smf/views.py:52
msgid "Activated SMF account."
msgstr "SMF アカウントをアクティブ化しました。"
@ -2131,10 +2046,6 @@ msgstr "SMF のパスワードをリセットします。"
msgid "Set SMF password."
msgstr "SMF のパスワードを設定します。"
#: allianceauth/services/modules/teamspeak3/apps.py:8
msgid "TeamSpeak 3 Service"
msgstr ""
#: allianceauth/services/modules/teamspeak3/forms.py:14
#, python-format
msgid "Unable to locate user %s on server"
@ -2184,10 +2095,6 @@ msgstr "TeamSpeak3 accoutの無効化"
msgid "Reset TeamSpeak3 permission key."
msgstr "TeamSpeak3 の権限キーをリセットします。"
#: allianceauth/services/modules/xenforo/apps.py:8
msgid "Xenforo Service"
msgstr ""
#: allianceauth/services/modules/xenforo/views.py:30
msgid "Activated XenForo account."
msgstr "XenForo のアカウントをアクティブ化しました。"
@ -2297,7 +2204,7 @@ msgid ""
"Some services provide different options. Hover over the buttons to see more."
msgstr "一部のサービスは異なるオプションを提供します。ボタンにカーソルを合わせると詳細が表示されます。"
#: allianceauth/srp/apps.py:8 allianceauth/srp/auth_hooks.py:14
#: allianceauth/srp/auth_hooks.py:14
msgid "Ship Replacement"
msgstr "Ship Replacement Program"
@ -2373,18 +2280,18 @@ msgid "Mark Completed"
msgstr "Mark 完了"
#: allianceauth/srp/templates/srp/data.html:48
#: allianceauth/srp/templates/srp/data.html:142
#: allianceauth/srp/templates/srp/data.html:139
msgid "Total Losses:"
msgstr "損失の合計:"
#: allianceauth/srp/templates/srp/data.html:49
#: allianceauth/srp/templates/srp/data.html:143
#: allianceauth/srp/templates/srp/data.html:140
#: allianceauth/srp/templates/srp/management.html:36
msgid "Total ISK Cost:"
msgstr "ISK 費用の合計:"
#: allianceauth/srp/templates/srp/data.html:60
#: allianceauth/srp/templates/srp/data.html:154
#: allianceauth/srp/templates/srp/data.html:151
msgid "Are you sure you want to delete SRP requests?"
msgstr "SRP申請を削除しますか?"
@ -2419,12 +2326,12 @@ msgstr ""
msgid "Post Time"
msgstr "投稿時間"
#: allianceauth/srp/templates/srp/data.html:102
#: allianceauth/srp/templates/srp/data.html:99
#: allianceauth/srp/templates/srp/management.html:70
msgid "Link"
msgstr "リンク"
#: allianceauth/srp/templates/srp/data.html:163
#: allianceauth/srp/templates/srp/data.html:160
msgid "No SRP requests for this fleet."
msgstr "このフリートにはSRPリクエストはありません。"
@ -2609,48 +2516,52 @@ msgstr "サーバーが ESI エラー応答コードを受信しました "
msgid "Alliance Auth Notifications"
msgstr "アライアンスAuth 通知"
#: allianceauth/templates/allianceauth/admin-status/overview.html:20
#: allianceauth/templates/allianceauth/admin-status/overview.html:18
msgid "Closed"
msgstr "クローズド"
#: allianceauth/templates/allianceauth/admin-status/overview.html:24
msgid "No notifications at this time"
msgstr "現時点では通知はありません"
#: allianceauth/templates/allianceauth/admin-status/overview.html:29
#: allianceauth/templates/allianceauth/admin-status/overview.html:33
msgid "Powered by GitLab"
msgstr "Powered by GitLab"
#: allianceauth/templates/allianceauth/admin-status/overview.html:35
#: allianceauth/templates/allianceauth/admin-status/overview.html:39
msgid "Support Discord"
msgstr "サポートディスコード"
#: allianceauth/templates/allianceauth/admin-status/overview.html:49
#: allianceauth/templates/allianceauth/admin-status/overview.html:53
#: allianceauth/templates/allianceauth/admin-status/overview.html:57
msgid "Software Version"
msgstr "ソフトウェアバージョン"
#: allianceauth/templates/allianceauth/admin-status/overview.html:56
#: allianceauth/templates/allianceauth/admin-status/overview.html:60
msgid "Current"
msgstr "現在"
#: allianceauth/templates/allianceauth/admin-status/overview.html:63
#: allianceauth/templates/allianceauth/admin-status/overview.html:67
msgid "Latest Stable"
msgstr "最新安定版"
#: allianceauth/templates/allianceauth/admin-status/overview.html:68
#: allianceauth/templates/allianceauth/admin-status/overview.html:72
msgid "Update available"
msgstr "アップデート可能"
#: allianceauth/templates/allianceauth/admin-status/overview.html:76
#: allianceauth/templates/allianceauth/admin-status/overview.html:80
msgid "Latest Pre-Release"
msgstr "最新のプレリリース"
#: allianceauth/templates/allianceauth/admin-status/overview.html:81
#: allianceauth/templates/allianceauth/admin-status/overview.html:85
msgid "Pre-Release available"
msgstr "プレリリース利用可能"
#: allianceauth/templates/allianceauth/admin-status/overview.html:91
#: allianceauth/templates/allianceauth/admin-status/overview.html:95
msgid "Task Queue"
msgstr "タスク待ち"
#: allianceauth/templates/allianceauth/admin-status/overview.html:96
#: allianceauth/templates/allianceauth/admin-status/overview.html:100
#, python-format
msgid ""
"\n"
@ -2661,11 +2572,11 @@ msgstr ""
" ステータス %(total)s 処理済みタスク • 残り %(latest)s\n"
" "
#: allianceauth/templates/allianceauth/admin-status/overview.html:112
#: allianceauth/templates/allianceauth/admin-status/overview.html:116
msgid "running"
msgstr "実行中"
#: allianceauth/templates/allianceauth/admin-status/overview.html:113
#: allianceauth/templates/allianceauth/admin-status/overview.html:117
msgid "queued"
msgstr "実行待ち"
@ -2690,17 +2601,10 @@ msgstr "ログアウト"
msgid "Toggle navigation"
msgstr "ナビゲーションを切り替え"
#: allianceauth/theme/templates/theme/theme_select.html:11
#: allianceauth/theme/templates/theme/theme_select.html:7
msgid "Select Theme"
msgstr "テーマを選択"
#: allianceauth/timerboard/apps.py:8
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "ストラクチャタイマー"
#: allianceauth/timerboard/form.py:36
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:8
@ -2887,10 +2791,6 @@ msgstr "Unanchoring"
msgid "Abandoned"
msgstr ""
#: allianceauth/timerboard/models.py:60
msgid "Theft"
msgstr ""
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:7
#: allianceauth/timerboard/templates/timerboard/view.html:54
msgid "Upcoming Timers"
@ -2900,6 +2800,12 @@ msgstr "今後予定されているタイマー"
msgid "Timer"
msgstr "タイマー"
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "ストラクチャタイマー"
#: allianceauth/timerboard/templates/timerboard/form.html:25
msgid "Structure Timer Details"
msgstr "ストラクチャータイマーの詳細"

View File

@ -18,7 +18,7 @@ msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2025-06-19 20:23+1000\n"
"POT-Creation-Date: 2025-02-25 19:17+1000\n"
"PO-Revision-Date: 2023-11-08 13:50+0000\n"
"Last-Translator: Woojin Kang, 2024\n"
"Language-Team: Korean (Korea) (https://app.transifex.com/alliance-auth/teams/107430/ko_KR/)\n"
@ -28,10 +28,6 @@ msgstr ""
"Language: ko_KR\n"
"Plural-Forms: nplurals=1; plural=0;\n"
#: allianceauth/analytics/apps.py:8
msgid "Analytics"
msgstr ""
#: allianceauth/analytics/models.py:22
msgid "Google Analytics Universal"
msgstr "Google 애널리틱스 유니버설"
@ -40,10 +36,6 @@ msgstr "Google 애널리틱스 유니버설"
msgid "Google Analytics V4"
msgstr "Google 애널리틱스 V4"
#: allianceauth/authentication/apps.py:9
msgid "Authentication"
msgstr ""
#: allianceauth/authentication/constants.py:6
msgid ""
"This software has exceeded the error limit for ESI. If you are a user, "
@ -57,7 +49,7 @@ msgstr ""
"https://www.eveonline.com/discord 의 ##3rd-party-dev-and-esi 에서 우리와 함께 토론하는것이"
" 아마 도움이 될 것입니다."
#: allianceauth/authentication/decorators.py:52
#: allianceauth/authentication/decorators.py:49
msgid "A main character is required to perform that action. Add one below."
msgstr "해당 기능을 수행하려면 주 캐릭터가 요구됩니다. 아래에서 하나를 추가하시오."
@ -70,91 +62,91 @@ msgstr "이메일"
msgid "You are not allowed to add or remove these restricted groups: %s"
msgstr "해당 제한된 그룹을 추가하거나 제거할 수 있는 권한이 존재하지 않습니다: %s"
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:106
#: allianceauth/authentication/models.py:70
#: allianceauth/project_template/project_name/settings/base.py:105
msgid "English"
msgstr "영어"
#: allianceauth/authentication/models.py:73
#: allianceauth/authentication/models.py:71
msgid "Czech"
msgstr ""
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:108
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:107
msgid "German"
msgstr "독일어"
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:109
#: allianceauth/authentication/models.py:73
#: allianceauth/project_template/project_name/settings/base.py:108
msgid "Spanish"
msgstr "스페인어"
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:110
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:109
msgid "Italian"
msgstr "이탈리아어"
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:111
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:110
msgid "Japanese"
msgstr "일본어"
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:112
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:111
msgid "Korean"
msgstr "한국어"
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:112
msgid "French"
msgstr "프랑스어"
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:116
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:115
msgid "Russian"
msgstr "러시아어"
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:114
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
msgid "Dutch"
msgstr ""
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:115
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:114
msgid "Polish"
msgstr ""
#: allianceauth/authentication/models.py:83
#: allianceauth/project_template/project_name/settings/base.py:117
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:116
msgid "Ukrainian"
msgstr "우크라이나어"
#: allianceauth/authentication/models.py:84
#: allianceauth/project_template/project_name/settings/base.py:118
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:117
msgid "Simplified Chinese"
msgstr ""
#: allianceauth/authentication/models.py:100
#: allianceauth/menu/templates/menu/menu-user.html:67
#: allianceauth/authentication/models.py:98
#: allianceauth/menu/templates/menu/menu-user.html:42
msgid "Language"
msgstr "언어"
#: allianceauth/authentication/models.py:105
#: allianceauth/authentication/models.py:103
#: allianceauth/templates/allianceauth/night-toggle.html:6
msgid "Night Mode"
msgstr "야간 모드"
#: allianceauth/authentication/models.py:109
#: allianceauth/theme/templates/theme/theme_select.html:4
#: allianceauth/authentication/models.py:107
#: allianceauth/menu/templates/menu/menu-user.html:46
msgid "Theme"
msgstr "테마"
#: allianceauth/authentication/models.py:126
#: allianceauth/authentication/models.py:124
#, python-format
msgid "State changed to: %s"
msgstr "상태가 %s로 변경됐습니다."
#: allianceauth/authentication/models.py:127
#: allianceauth/authentication/models.py:125
#, python-format
msgid "Your user's state is now: %(state)s"
msgstr "사용자의 상태는 %(state)s입니다."
@ -216,8 +208,6 @@ msgstr "상태:"
#: allianceauth/authentication/templates/authentication/tokens.html:7
#: allianceauth/authentication/templates/authentication/tokens.html:11
#: allianceauth/menu/templates/menu/menu-user.html:133
#: allianceauth/menu/templates/menu/menu-user.html:136
#: allianceauth/templates/allianceauth/top-menu-user-dropdown.html:62
msgid "Token Management"
msgstr "토큰 관리"
@ -291,53 +281,53 @@ msgstr "등록"
msgid "Invalid or expired activation link."
msgstr "유효하지 않거나 만료된 활성화 주소"
#: allianceauth/authentication/views.py:158
#: allianceauth/authentication/views.py:157
#, python-format
msgid ""
"Cannot change main character to %(char)s: character owned by a different "
"account."
msgstr "%(char)s를 주 캐릭터로 변경할 수 없음: 다른 계정이 해당 캐릭터를 소유하고 있습니다."
#: allianceauth/authentication/views.py:165
#: allianceauth/authentication/views.py:164
#, python-format
msgid "Changed main character to %s"
msgstr "메인 캐릭터가 %s 로 변경되었습니다"
#: allianceauth/authentication/views.py:179
#: allianceauth/authentication/views.py:178
#, python-format
msgid "Added %(name)s to your account."
msgstr "계정에 %(name)s를 추가했습니다."
#: allianceauth/authentication/views.py:181
#: allianceauth/authentication/views.py:180
#, python-format
msgid "Failed to add %(name)s to your account: they already have an account."
msgstr "계정에 %(name)s를 추가하지 못했습니다. 이미 다른 계정에 추가되었습니다."
#: allianceauth/authentication/views.py:226
#: allianceauth/authentication/views.py:225
msgid ""
"Unable to authenticate as the selected character. Please log in with the "
"main character associated with this account."
msgstr "해당 캐릭터에 대한 인증이 불가합니다. 해당 계정과 연결된 메인 캐릭터로 로그인하여 주십시오."
#: allianceauth/authentication/views.py:293
#: allianceauth/authentication/views.py:292
msgid "Registration token has expired."
msgstr "가입 토큰이 만료되었습니다."
#: allianceauth/authentication/views.py:354
#: allianceauth/authentication/views.py:353
msgid ""
"Sent confirmation email. Please follow the link to confirm your email "
"address."
msgstr "확인 메일 전송됨. 다음 링크를 눌러 이메일 주소를 확인하세요."
#: allianceauth/authentication/views.py:360
#: allianceauth/authentication/views.py:359
msgid "Confirmed your email address. Please login to continue."
msgstr "이메일 주소가 확인되었습니다. 로그인 해주세요."
#: allianceauth/authentication/views.py:366
#: allianceauth/authentication/views.py:365
msgid "Registration of new accounts is not allowed at this time."
msgstr "현재 새로운 계정 등록은 받지않습니다."
#: allianceauth/corputils/apps.py:8 allianceauth/corputils/auth_hooks.py:12
#: allianceauth/corputils/auth_hooks.py:12
msgid "Corporation Stats"
msgstr "코퍼레이션 상태"
@ -443,10 +433,6 @@ msgstr "선택한 코퍼레이션은 이미 통계 모듈을 갖고 있습니다
msgid "Failed to gather corporation statistics with selected token."
msgstr "선택한 토큰으로 코퍼레이션 통계 수집에 실패했습니다."
#: allianceauth/crontab/apps.py:16
msgid "Crontab"
msgstr ""
#: allianceauth/crontab/models.py:13
msgid "Minute Offset"
msgstr ""
@ -480,15 +466,6 @@ msgstr ""
msgid "This CSS will be added to the site after the default CSS."
msgstr ""
#: allianceauth/eveonline/apps.py:8
msgid "EVE Online"
msgstr ""
#: allianceauth/eveonline/autogroups/apps.py:8
msgid "EVE Online Autogroups"
msgstr ""
#: allianceauth/fleetactivitytracking/apps.py:8
#: allianceauth/fleetactivitytracking/auth_hooks.py:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/characternotexisting.html:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkcreate.html:11
@ -598,12 +575,10 @@ msgstr "함선"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkpersonalmonthlystatisticsview.html:75
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:44
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:92
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/templates/allianceauth/top-menu.html:23
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
#: allianceauth/timerboard/templates/timerboard/timertable.html:12
msgid "EVE time"
msgstr ""
msgid "Eve Time"
msgstr "이브 표준시간"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkmodify.html:49
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:52
@ -767,11 +742,6 @@ msgstr ""
"{character.character_name}의 함대 참여를 등록할 수 없습니다. 등록되기 위해서는 해당 캐릭터가 온라인 상태여야 "
"합니다."
#: allianceauth/framework/apps.py:16
msgid "Framework"
msgstr ""
#: allianceauth/groupmanagement/apps.py:8
#: allianceauth/groupmanagement/auth_hooks.py:18
#: allianceauth/groupmanagement/templates/groupmanagement/groups.html:18
msgid "Group Management"
@ -1011,7 +981,7 @@ msgid "Hidden"
msgstr "숨김"
#: allianceauth/groupmanagement/templates/groupmanagement/groupmembership.html:45
#: allianceauth/templates/allianceauth/admin-status/overview.html:15
#: allianceauth/templates/allianceauth/admin-status/overview.html:16
msgid "Open"
msgstr "열기"
@ -1064,7 +1034,7 @@ msgstr "떠나기"
#: allianceauth/hrapplications/templates/hrapplications/management.html:182
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:46
#: allianceauth/hrapplications/templates/hrapplications/view.html:25
#: allianceauth/srp/templates/srp/data.html:120
#: allianceauth/srp/templates/srp/data.html:117
#: allianceauth/srp/templates/srp/management.html:87
msgid "Pending"
msgstr "보류 중"
@ -1206,10 +1176,6 @@ msgstr "해당 그룹의 탈퇴 신청이 접수된 상태입니다."
msgid "Applied to leave group %(group)s."
msgstr "%(group)s그룹의 탈퇴가 신청됨."
#: allianceauth/hrapplications/apps.py:8
msgid "HR Applications"
msgstr ""
#: allianceauth/hrapplications/auth_hooks.py:15
msgid "Applications"
msgstr "지원"
@ -1281,7 +1247,7 @@ msgstr "사용자명"
#: allianceauth/hrapplications/templates/hrapplications/management.html:185
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:48
#: allianceauth/hrapplications/templates/hrapplications/view.html:21
#: allianceauth/srp/templates/srp/data.html:112
#: allianceauth/srp/templates/srp/data.html:109
msgid "Approved"
msgstr "승인"
@ -1289,7 +1255,7 @@ msgstr "승인"
#: allianceauth/hrapplications/templates/hrapplications/management.html:143
#: allianceauth/hrapplications/templates/hrapplications/management.html:187
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:50
#: allianceauth/srp/templates/srp/data.html:116
#: allianceauth/srp/templates/srp/data.html:113
msgid "Rejected"
msgstr "거절"
@ -1404,7 +1370,7 @@ msgstr "%s 메뉴 아이템 변경"
msgid "children"
msgstr "아이들"
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:22
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:21
msgid "text"
msgstr "텍스트"
@ -1416,15 +1382,11 @@ msgstr "확인된 유저"
msgid "visible"
msgstr "보임"
#: allianceauth/menu/apps.py:16
msgid "Menu"
msgstr ""
#: allianceauth/menu/constants.py:16
msgid "app"
msgstr "앱"
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:38
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:37
msgid "folder"
msgstr "폴더"
@ -1436,47 +1398,47 @@ msgstr "링크"
msgid "type"
msgstr "타입"
#: allianceauth/menu/models.py:23
#: allianceauth/menu/models.py:22
msgid "Text to show on menu"
msgstr "메뉴에 띄울 텍스트"
#: allianceauth/menu/models.py:28
#: allianceauth/menu/models.py:27
msgid "order"
msgstr "순서"
#: allianceauth/menu/models.py:29
#: allianceauth/menu/models.py:28
msgid "Order of the menu. Lowest First"
msgstr "메뉴 순서. 가장 낮은 순으로"
#: allianceauth/menu/models.py:39
#: allianceauth/menu/models.py:38
msgid "Folder this item is in (optional)"
msgstr "해당 아이템이 포함되어 있는 폴더 (optional)"
#: allianceauth/menu/models.py:43
#: allianceauth/menu/models.py:42
msgid "is hidden"
msgstr "숨겨짐"
#: allianceauth/menu/models.py:45
#: allianceauth/menu/models.py:44
msgid ""
"Hide this menu item.If this item is a folder all items under it will be "
"hidden too"
msgstr "해당 메뉴 아이템을 숨기십시오. 해당 아이템이 폴더라면 폴더 내부의 모든 아이템들 또한 숨겨져있어야 합니다."
#: allianceauth/menu/models.py:60
#: allianceauth/menu/models.py:59
msgid "icon classes"
msgstr "아이콘 등급"
#: allianceauth/menu/models.py:62
#: allianceauth/menu/models.py:61
msgid ""
"Font Awesome classes to show as icon on menu, e.g. <code>fa-solid fa-"
"house</code>"
msgstr "메뉴의 아이콘으로 보이기 위한 Font Awesome 등급, 예) <code>fa-solid fa-house</code>"
#: allianceauth/menu/models.py:68
#: allianceauth/menu/models.py:67
msgid "url"
msgstr "url"
#: allianceauth/menu/models.py:69
#: allianceauth/menu/models.py:68
msgid "External URL this menu items will link to"
msgstr "해당 메뉴 아이템들의 외부 URL이 링크된 주소:"
@ -1485,63 +1447,44 @@ msgid "Add folder"
msgstr "폴더 추가"
#: allianceauth/menu/templates/menu/menu-notification-block.html:12
#: allianceauth/notifications/apps.py:8
#: allianceauth/notifications/templates/notifications/list.html:7
#: allianceauth/notifications/templates/notifications/list.html:11
#: allianceauth/templates/allianceauth/notifications_menu_item.html:6
msgid "Notifications"
msgstr "알림"
#: allianceauth/menu/templates/menu/menu-user.html:77
#: allianceauth/menu/templates/menu/menu-user.html:56
msgid "Super User"
msgstr "Super User"
#: allianceauth/menu/templates/menu/menu-user.html:83
#: allianceauth/menu/templates/menu/menu-user.html:86
msgid "Alliance Auth Documentation"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:94
#: allianceauth/menu/templates/menu/menu-user.html:97
msgid "Alliance Auth Discord"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:105
#: allianceauth/menu/templates/menu/menu-user.html:108
msgid "Alliance Auth Git"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:118
#: allianceauth/menu/templates/menu/menu-user.html:121
#: allianceauth/menu/templates/menu/menu-user.html:70
#: allianceauth/templates/allianceauth/top-menu-admin.html:9
msgid "Admin"
msgstr "어드민"
#: allianceauth/menu/templates/menu/menu-user.html:144
#: allianceauth/menu/templates/menu/menu-user.html:147
#: allianceauth/menu/templates/menu/menu-user.html:82
msgid "Sign Out"
msgstr "탈퇴"
#: allianceauth/menu/templates/menu/menu-user.html:155
#: allianceauth/menu/templates/menu/menu-user.html:158
#: allianceauth/menu/templates/menu/menu-user.html:86
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:17
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:18
msgid "Sign In"
msgstr "가입"
#: allianceauth/notifications/models.py:22
#: allianceauth/notifications/models.py:21
msgid "danger"
msgstr "위험"
#: allianceauth/notifications/models.py:23
#: allianceauth/notifications/models.py:22
msgid "warning"
msgstr "경고"
#: allianceauth/notifications/models.py:24
#: allianceauth/notifications/models.py:23
msgid "info"
msgstr "정보"
#: allianceauth/notifications/models.py:25
#: allianceauth/notifications/models.py:24
msgid "success"
msgstr "성공"
@ -1598,7 +1541,7 @@ msgstr "모든 알림을 읽음 처리했습니다."
msgid "Deleted all read notifications."
msgstr "모든 읽은 알림을 삭제했습니다."
#: allianceauth/optimer/apps.py:8 allianceauth/optimer/auth_hooks.py:12
#: allianceauth/optimer/auth_hooks.py:12
msgid "Fleet Operations"
msgstr "함대 오퍼레이션"
@ -1672,6 +1615,11 @@ msgstr "오퍼레이션"
msgid "Form Up System"
msgstr "폼업 성계"
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
msgid "EVE Time"
msgstr "인게임 시간"
#: allianceauth/optimer/templates/optimer/fleetoptable.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:13
msgid "Local Time"
@ -1687,8 +1635,8 @@ msgstr "함대 오퍼레이션 관리"
#: allianceauth/optimer/templates/optimer/management.html:28
#: allianceauth/timerboard/templates/timerboard/view.html:32
msgid "Current EVE time:"
msgstr ""
msgid "Current Eve Time:"
msgstr "현재 이브 시간:"
#: allianceauth/optimer/templates/optimer/management.html:36
msgid "Next Fleet Operations"
@ -1732,7 +1680,6 @@ msgstr "%(opname)s 의 오퍼레이션 타이머를 제거했습니다."
msgid "Saved changes to operation timer for %(opname)s."
msgstr "%(opname)s 의 오퍼레이션 타이머 수정사항을 저장했습니다."
#: allianceauth/permissions_tool/apps.py:8
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:7
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:11
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:17
@ -1789,7 +1736,7 @@ msgstr "해당 서비스 계정이 이미 존재함"
msgid "Successfully set your {self.service_name} password"
msgstr "{self.service_name} 비밀번호 설정 완료"
#: allianceauth/services/apps.py:8 allianceauth/services/auth_hooks.py:12
#: allianceauth/services/auth_hooks.py:12
msgid "Services"
msgstr "서드파티"
@ -1853,10 +1800,6 @@ msgstr "비밀번호"
msgid "Password must be at least 8 characters long."
msgstr "비밀번호는 8글자 이상이어야 합니다."
#: allianceauth/services/modules/discord/apps.py:8
msgid "Discord Service"
msgstr ""
#: allianceauth/services/modules/discord/models.py:187
msgid "Discord Account Disabled"
msgstr "Discord 계정 비활성화"
@ -1905,10 +1848,6 @@ msgid ""
"again."
msgstr "Discord 계정 연동 중 오류가 발생했습니다. 다시 시도해 주세요."
#: allianceauth/services/modules/discourse/apps.py:8
msgid "Discourse Service"
msgstr ""
#: allianceauth/services/modules/discourse/templates/services/discourse/discourse_service_ctrl.html:5
msgid "Discourse"
msgstr "담화"
@ -1940,14 +1879,6 @@ msgstr "SSO 페이로드 혹은 시그니쳐가 없습니다. 이 문제가 지
msgid "Invalid payload. Please contact support if this problem persists."
msgstr "페이로드가 유효하지 않습니다. 이문제가 지속된다면 IT 지원을 요청하세요."
#: allianceauth/services/modules/example/apps.py:8
msgid "Example Service"
msgstr ""
#: allianceauth/services/modules/ips4/apps.py:8
msgid "IPS4 Service"
msgstr ""
#: allianceauth/services/modules/ips4/views.py:31
msgid "Activated IPSuite4 account."
msgstr "IPSuite4 계정 활성화 완료"
@ -1971,10 +1902,6 @@ msgstr "IPSuite4 비밀번호 설정"
msgid "Deactivated IPSuite4 account."
msgstr "IPSuite4 계정 비활성화 완료"
#: allianceauth/services/modules/mumble/apps.py:8
msgid "Mumble Service"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:7
msgid "Mumble"
msgstr ""
@ -2030,10 +1957,6 @@ msgstr "연결"
msgid "Mumble Connection History"
msgstr ""
#: allianceauth/services/modules/openfire/apps.py:8
msgid "Openfire Service"
msgstr ""
#: allianceauth/services/modules/openfire/auth_hooks.py:27
msgid "Jabber"
msgstr "재버"
@ -2085,10 +2008,6 @@ msgstr "%s 로 Jabber 방송을 보내십시오."
msgid "Set jabber password."
msgstr "재버 비밀번호 설정"
#: allianceauth/services/modules/phpbb3/apps.py:8
msgid "phpBB3 Service"
msgstr ""
#: allianceauth/services/modules/phpbb3/views.py:34
msgid "Activated forum account."
msgstr "포럼 계정 활성화 완료"
@ -2112,10 +2031,6 @@ msgstr "포럼 비밀번호 재설정"
msgid "Set forum password."
msgstr "포럼 비밀번호 설정"
#: allianceauth/services/modules/smf/apps.py:8
msgid "SMF Service"
msgstr ""
#: allianceauth/services/modules/smf/views.py:52
msgid "Activated SMF account."
msgstr "SMF 계정 활성화 완료"
@ -2139,10 +2054,6 @@ msgstr "SMF 비밀번호 재설정"
msgid "Set SMF password."
msgstr "SMF 비밀번호 설정"
#: allianceauth/services/modules/teamspeak3/apps.py:8
msgid "TeamSpeak 3 Service"
msgstr ""
#: allianceauth/services/modules/teamspeak3/forms.py:14
#, python-format
msgid "Unable to locate user %s on server"
@ -2192,10 +2103,6 @@ msgstr "팀스피크3 계정 비활성화 완료"
msgid "Reset TeamSpeak3 permission key."
msgstr "팀스피크3 인증키 재설정"
#: allianceauth/services/modules/xenforo/apps.py:8
msgid "Xenforo Service"
msgstr ""
#: allianceauth/services/modules/xenforo/views.py:30
msgid "Activated XenForo account."
msgstr "XenForo 계정 활성화 완료"
@ -2305,7 +2212,7 @@ msgid ""
"Some services provide different options. Hover over the buttons to see more."
msgstr "몇몇 서비스는 다른 옵션을 제공합니다. 더 자세한 정보를 보기 위해서는 버튼 위에 마우스를 올려놓으세요."
#: allianceauth/srp/apps.py:8 allianceauth/srp/auth_hooks.py:14
#: allianceauth/srp/auth_hooks.py:14
msgid "Ship Replacement"
msgstr "SRP"
@ -2381,18 +2288,18 @@ msgid "Mark Completed"
msgstr "표시 완료"
#: allianceauth/srp/templates/srp/data.html:48
#: allianceauth/srp/templates/srp/data.html:142
#: allianceauth/srp/templates/srp/data.html:139
msgid "Total Losses:"
msgstr "전체 손실:"
#: allianceauth/srp/templates/srp/data.html:49
#: allianceauth/srp/templates/srp/data.html:143
#: allianceauth/srp/templates/srp/data.html:140
#: allianceauth/srp/templates/srp/management.html:36
msgid "Total ISK Cost:"
msgstr "전체 ISK 비용:"
#: allianceauth/srp/templates/srp/data.html:60
#: allianceauth/srp/templates/srp/data.html:154
#: allianceauth/srp/templates/srp/data.html:151
msgid "Are you sure you want to delete SRP requests?"
msgstr "SRP 보상 요청을 삭제하시겠습니까?"
@ -2424,12 +2331,12 @@ msgstr "금액을 수정하려면 클릭, 저장을 하고 다음으로 가려
msgid "Post Time"
msgstr "작성 시간"
#: allianceauth/srp/templates/srp/data.html:102
#: allianceauth/srp/templates/srp/data.html:99
#: allianceauth/srp/templates/srp/management.html:70
msgid "Link"
msgstr "링크"
#: allianceauth/srp/templates/srp/data.html:163
#: allianceauth/srp/templates/srp/data.html:160
msgid "No SRP requests for this fleet."
msgstr "이 함대에는 SRP 보상 요청이 없습니다."
@ -2614,48 +2521,52 @@ msgstr "당신의 서버에 ESI 에러가 발생하였습니다. 응답코드 :"
msgid "Alliance Auth Notifications"
msgstr "얼라이언스 Auth 알림"
#: allianceauth/templates/allianceauth/admin-status/overview.html:20
#: allianceauth/templates/allianceauth/admin-status/overview.html:18
msgid "Closed"
msgstr "닫혔음"
#: allianceauth/templates/allianceauth/admin-status/overview.html:24
msgid "No notifications at this time"
msgstr "이번에는 알림을 울리지 않기"
#: allianceauth/templates/allianceauth/admin-status/overview.html:29
#: allianceauth/templates/allianceauth/admin-status/overview.html:33
msgid "Powered by GitLab"
msgstr "GitLab 제공"
#: allianceauth/templates/allianceauth/admin-status/overview.html:35
#: allianceauth/templates/allianceauth/admin-status/overview.html:39
msgid "Support Discord"
msgstr "Support Discord"
#: allianceauth/templates/allianceauth/admin-status/overview.html:49
#: allianceauth/templates/allianceauth/admin-status/overview.html:53
#: allianceauth/templates/allianceauth/admin-status/overview.html:57
msgid "Software Version"
msgstr "소프트웨어 버전"
#: allianceauth/templates/allianceauth/admin-status/overview.html:56
#: allianceauth/templates/allianceauth/admin-status/overview.html:60
msgid "Current"
msgstr "현재"
#: allianceauth/templates/allianceauth/admin-status/overview.html:63
#: allianceauth/templates/allianceauth/admin-status/overview.html:67
msgid "Latest Stable"
msgstr "최신 안정화 버전"
#: allianceauth/templates/allianceauth/admin-status/overview.html:68
#: allianceauth/templates/allianceauth/admin-status/overview.html:72
msgid "Update available"
msgstr "업데이트 가능"
#: allianceauth/templates/allianceauth/admin-status/overview.html:76
#: allianceauth/templates/allianceauth/admin-status/overview.html:80
msgid "Latest Pre-Release"
msgstr "최신 사전 출시 버전"
#: allianceauth/templates/allianceauth/admin-status/overview.html:81
#: allianceauth/templates/allianceauth/admin-status/overview.html:85
msgid "Pre-Release available"
msgstr "사전 출시 사용 가능"
#: allianceauth/templates/allianceauth/admin-status/overview.html:91
#: allianceauth/templates/allianceauth/admin-status/overview.html:95
msgid "Task Queue"
msgstr "작업 대기열"
#: allianceauth/templates/allianceauth/admin-status/overview.html:96
#: allianceauth/templates/allianceauth/admin-status/overview.html:100
#, python-format
msgid ""
"\n"
@ -2665,11 +2576,11 @@ msgstr ""
"\n"
" %(total)s 의 진행된 작업 상태 • 잔여 %(latest)s"
#: allianceauth/templates/allianceauth/admin-status/overview.html:112
#: allianceauth/templates/allianceauth/admin-status/overview.html:116
msgid "running"
msgstr "진행중"
#: allianceauth/templates/allianceauth/admin-status/overview.html:113
#: allianceauth/templates/allianceauth/admin-status/overview.html:117
msgid "queued"
msgstr "대기중"
@ -2694,17 +2605,10 @@ msgstr "로그아웃"
msgid "Toggle navigation"
msgstr "네비게이션 전환"
#: allianceauth/theme/templates/theme/theme_select.html:11
#: allianceauth/theme/templates/theme/theme_select.html:7
msgid "Select Theme"
msgstr "테마 선택"
#: allianceauth/timerboard/apps.py:8
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "구조물 타이머"
#: allianceauth/timerboard/form.py:36
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:8
@ -2891,10 +2795,6 @@ msgstr "미고정"
msgid "Abandoned"
msgstr ""
#: allianceauth/timerboard/models.py:60
msgid "Theft"
msgstr ""
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:7
#: allianceauth/timerboard/templates/timerboard/view.html:54
msgid "Upcoming Timers"
@ -2904,6 +2804,12 @@ msgstr "예정 타이머"
msgid "Timer"
msgstr "타이머"
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "구조물 타이머"
#: allianceauth/timerboard/templates/timerboard/form.html:25
msgid "Structure Timer Details"
msgstr "스트럭쳐 타이머 정보"

File diff suppressed because it is too large Load Diff

View File

@ -11,7 +11,7 @@ msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2025-06-19 20:23+1000\n"
"POT-Creation-Date: 2025-02-25 19:17+1000\n"
"PO-Revision-Date: 2023-11-08 13:50+0000\n"
"Last-Translator: MisBimbrownik, 2024\n"
"Language-Team: Polish (Poland) (https://app.transifex.com/alliance-auth/teams/107430/pl_PL/)\n"
@ -21,10 +21,6 @@ msgstr ""
"Language: pl_PL\n"
"Plural-Forms: nplurals=4; plural=(n==1 ? 0 : (n%10>=2 && n%10<=4) && (n%100<12 || n%100>14) ? 1 : n!=1 && (n%10>=0 && n%10<=1) || (n%10>=5 && n%10<=9) || (n%100>=12 && n%100<=14) ? 2 : 3);\n"
#: allianceauth/analytics/apps.py:8
msgid "Analytics"
msgstr ""
#: allianceauth/analytics/models.py:22
msgid "Google Analytics Universal"
msgstr "Google Analytics Universal"
@ -33,10 +29,6 @@ msgstr "Google Analytics Universal"
msgid "Google Analytics V4"
msgstr "Google Analytics wersja 4"
#: allianceauth/authentication/apps.py:9
msgid "Authentication"
msgstr ""
#: allianceauth/authentication/constants.py:6
msgid ""
"This software has exceeded the error limit for ESI. If you are a user, "
@ -53,7 +45,7 @@ msgstr ""
"na ##3rd-party-dev-and-esi na naszym Discordzie EVE Online "
"https://www.eveonline.com/discord."
#: allianceauth/authentication/decorators.py:52
#: allianceauth/authentication/decorators.py:49
msgid "A main character is required to perform that action. Add one below."
msgstr ""
"Niniejsza akcja może być wykonana jedynie przez główną postać na koncie. "
@ -70,91 +62,91 @@ msgstr ""
"Nie masz wystarczających uprawnień aby dodać lub usunąć zastrzeżone grupy: "
"%s"
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:106
#: allianceauth/authentication/models.py:70
#: allianceauth/project_template/project_name/settings/base.py:105
msgid "English"
msgstr "Angielski"
#: allianceauth/authentication/models.py:73
#: allianceauth/authentication/models.py:71
msgid "Czech"
msgstr ""
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:108
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:107
msgid "German"
msgstr "Niemiecki"
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:109
#: allianceauth/authentication/models.py:73
#: allianceauth/project_template/project_name/settings/base.py:108
msgid "Spanish"
msgstr "Hiszpański"
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:110
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:109
msgid "Italian"
msgstr "Włoski"
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:111
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:110
msgid "Japanese"
msgstr "Japoński"
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:112
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:111
msgid "Korean"
msgstr "Koreański"
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:112
msgid "French"
msgstr "Francuski"
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:116
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:115
msgid "Russian"
msgstr "Rosyjski"
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:114
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
msgid "Dutch"
msgstr ""
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:115
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:114
msgid "Polish"
msgstr ""
#: allianceauth/authentication/models.py:83
#: allianceauth/project_template/project_name/settings/base.py:117
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:116
msgid "Ukrainian"
msgstr "Ukraiński"
#: allianceauth/authentication/models.py:84
#: allianceauth/project_template/project_name/settings/base.py:118
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:117
msgid "Simplified Chinese"
msgstr ""
#: allianceauth/authentication/models.py:100
#: allianceauth/menu/templates/menu/menu-user.html:67
#: allianceauth/authentication/models.py:98
#: allianceauth/menu/templates/menu/menu-user.html:42
msgid "Language"
msgstr "Język"
#: allianceauth/authentication/models.py:105
#: allianceauth/authentication/models.py:103
#: allianceauth/templates/allianceauth/night-toggle.html:6
msgid "Night Mode"
msgstr "Tryb nocny"
#: allianceauth/authentication/models.py:109
#: allianceauth/theme/templates/theme/theme_select.html:4
#: allianceauth/authentication/models.py:107
#: allianceauth/menu/templates/menu/menu-user.html:46
msgid "Theme"
msgstr "Styl"
#: allianceauth/authentication/models.py:126
#: allianceauth/authentication/models.py:124
#, python-format
msgid "State changed to: %s"
msgstr "Stan został zmieniony na: %s"
#: allianceauth/authentication/models.py:127
#: allianceauth/authentication/models.py:125
#, python-format
msgid "Your user's state is now: %(state)s"
msgstr "Stan twojego użytkownika to: %(state)s"
@ -216,8 +208,6 @@ msgstr "Stan:"
#: allianceauth/authentication/templates/authentication/tokens.html:7
#: allianceauth/authentication/templates/authentication/tokens.html:11
#: allianceauth/menu/templates/menu/menu-user.html:133
#: allianceauth/menu/templates/menu/menu-user.html:136
#: allianceauth/templates/allianceauth/top-menu-user-dropdown.html:62
msgid "Token Management"
msgstr "Zarządzanie Tokenem"
@ -293,7 +283,7 @@ msgstr "Zarejestruj"
msgid "Invalid or expired activation link."
msgstr "Link aktywacyjny jest niewłaściwy albo wygasł."
#: allianceauth/authentication/views.py:158
#: allianceauth/authentication/views.py:157
#, python-format
msgid ""
"Cannot change main character to %(char)s: character owned by a different "
@ -302,24 +292,24 @@ msgstr ""
"Nie udało się ustawić głównej na %(char)s: postać jest już przypisana do "
"innego konta."
#: allianceauth/authentication/views.py:165
#: allianceauth/authentication/views.py:164
#, python-format
msgid "Changed main character to %s"
msgstr "Zmieniono główną postać na %s"
#: allianceauth/authentication/views.py:179
#: allianceauth/authentication/views.py:178
#, python-format
msgid "Added %(name)s to your account."
msgstr "Dodano %(name)s to twojego konta."
#: allianceauth/authentication/views.py:181
#: allianceauth/authentication/views.py:180
#, python-format
msgid "Failed to add %(name)s to your account: they already have an account."
msgstr ""
"Nie udało się dodać %(name)s do twojego konta: jest ono już przypisane do "
"innego użytkownika."
#: allianceauth/authentication/views.py:226
#: allianceauth/authentication/views.py:225
msgid ""
"Unable to authenticate as the selected character. Please log in with the "
"main character associated with this account."
@ -327,11 +317,11 @@ msgstr ""
"Nie udało się uwierzytelnić jako wybrana postać. Zaloguj się ponownie "
"używając głównej postaci powiązanej z tym kontem."
#: allianceauth/authentication/views.py:293
#: allianceauth/authentication/views.py:292
msgid "Registration token has expired."
msgstr "Token do rejestracji już wygasł."
#: allianceauth/authentication/views.py:354
#: allianceauth/authentication/views.py:353
msgid ""
"Sent confirmation email. Please follow the link to confirm your email "
"address."
@ -339,16 +329,16 @@ msgstr ""
"E-mail potwierdzający rejestrację został wysłany. Kliknij w zawarty nim link"
" aby zweryfikować swój adres mailowy."
#: allianceauth/authentication/views.py:360
#: allianceauth/authentication/views.py:359
msgid "Confirmed your email address. Please login to continue."
msgstr ""
"Adres mailowy został pozytywnie zweryfikowany. Zaloguj się aby kontynuować."
#: allianceauth/authentication/views.py:366
#: allianceauth/authentication/views.py:365
msgid "Registration of new accounts is not allowed at this time."
msgstr "Rejestracja nowych kont użytkowników nie jest obecnie możliwa."
#: allianceauth/corputils/apps.py:8 allianceauth/corputils/auth_hooks.py:12
#: allianceauth/corputils/auth_hooks.py:12
msgid "Corporation Stats"
msgstr "Statystyki Korporacji"
@ -454,10 +444,6 @@ msgstr "Wybrana Korporacja ma już włączony moduł statystyk."
msgid "Failed to gather corporation statistics with selected token."
msgstr "Nie udało się pobrać statystyk korporacji używając wybranego Tokenu."
#: allianceauth/crontab/apps.py:16
msgid "Crontab"
msgstr ""
#: allianceauth/crontab/models.py:13
msgid "Minute Offset"
msgstr ""
@ -491,15 +477,6 @@ msgstr ""
msgid "This CSS will be added to the site after the default CSS."
msgstr ""
#: allianceauth/eveonline/apps.py:8
msgid "EVE Online"
msgstr ""
#: allianceauth/eveonline/autogroups/apps.py:8
msgid "EVE Online Autogroups"
msgstr ""
#: allianceauth/fleetactivitytracking/apps.py:8
#: allianceauth/fleetactivitytracking/auth_hooks.py:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/characternotexisting.html:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkcreate.html:11
@ -609,12 +586,10 @@ msgstr "Okręt"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkpersonalmonthlystatisticsview.html:75
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:44
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:92
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/templates/allianceauth/top-menu.html:23
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
#: allianceauth/timerboard/templates/timerboard/timertable.html:12
msgid "EVE time"
msgstr ""
msgid "Eve Time"
msgstr "Czas EVE"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkmodify.html:49
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:52
@ -784,11 +759,6 @@ msgstr ""
"Nie można zapisać udziału we flocie dla {character.character_name}. Postać "
"nie jest online."
#: allianceauth/framework/apps.py:16
msgid "Framework"
msgstr ""
#: allianceauth/groupmanagement/apps.py:8
#: allianceauth/groupmanagement/auth_hooks.py:18
#: allianceauth/groupmanagement/templates/groupmanagement/groups.html:18
msgid "Group Management"
@ -1039,7 +1009,7 @@ msgid "Hidden"
msgstr "Ukryte"
#: allianceauth/groupmanagement/templates/groupmanagement/groupmembership.html:45
#: allianceauth/templates/allianceauth/admin-status/overview.html:15
#: allianceauth/templates/allianceauth/admin-status/overview.html:16
msgid "Open"
msgstr "Otwarta"
@ -1092,7 +1062,7 @@ msgstr "Opuść"
#: allianceauth/hrapplications/templates/hrapplications/management.html:182
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:46
#: allianceauth/hrapplications/templates/hrapplications/view.html:25
#: allianceauth/srp/templates/srp/data.html:120
#: allianceauth/srp/templates/srp/data.html:117
#: allianceauth/srp/templates/srp/management.html:87
msgid "Pending"
msgstr "Oczekiwanie"
@ -1238,10 +1208,6 @@ msgstr "Złożyłeś już podanie o opuszczenie tej Grupy."
msgid "Applied to leave group %(group)s."
msgstr "Złożyłeś podanie o opuszczenie grupy %(group)s."
#: allianceauth/hrapplications/apps.py:8
msgid "HR Applications"
msgstr ""
#: allianceauth/hrapplications/auth_hooks.py:15
msgid "Applications"
msgstr "Podania"
@ -1313,7 +1279,7 @@ msgstr "Nazwa Użytkownika"
#: allianceauth/hrapplications/templates/hrapplications/management.html:185
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:48
#: allianceauth/hrapplications/templates/hrapplications/view.html:21
#: allianceauth/srp/templates/srp/data.html:112
#: allianceauth/srp/templates/srp/data.html:109
msgid "Approved"
msgstr "Zaakceptowano"
@ -1321,7 +1287,7 @@ msgstr "Zaakceptowano"
#: allianceauth/hrapplications/templates/hrapplications/management.html:143
#: allianceauth/hrapplications/templates/hrapplications/management.html:187
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:50
#: allianceauth/srp/templates/srp/data.html:116
#: allianceauth/srp/templates/srp/data.html:113
msgid "Rejected"
msgstr "Odrzucono"
@ -1436,7 +1402,7 @@ msgstr "Modyfikuj %s w menu"
msgid "children"
msgstr "dziecko"
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:22
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:21
msgid "text"
msgstr "tekst"
@ -1448,15 +1414,11 @@ msgstr "zdefiniowane przez użytkownika"
msgid "visible"
msgstr "widoczne"
#: allianceauth/menu/apps.py:16
msgid "Menu"
msgstr ""
#: allianceauth/menu/constants.py:16
msgid "app"
msgstr "aplikacja"
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:38
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:37
msgid "folder"
msgstr "folder"
@ -1468,27 +1430,27 @@ msgstr "link"
msgid "type"
msgstr "typ"
#: allianceauth/menu/models.py:23
#: allianceauth/menu/models.py:22
msgid "Text to show on menu"
msgstr "Wyświetl w menu"
#: allianceauth/menu/models.py:28
#: allianceauth/menu/models.py:27
msgid "order"
msgstr "kolejność"
#: allianceauth/menu/models.py:29
#: allianceauth/menu/models.py:28
msgid "Order of the menu. Lowest First"
msgstr "Kolejność elementów menu. Najniższy pierwszy."
#: allianceauth/menu/models.py:39
#: allianceauth/menu/models.py:38
msgid "Folder this item is in (optional)"
msgstr "Folder, w którym znajduje się element (opcjonalne)"
#: allianceauth/menu/models.py:43
#: allianceauth/menu/models.py:42
msgid "is hidden"
msgstr "Ukryty"
#: allianceauth/menu/models.py:45
#: allianceauth/menu/models.py:44
msgid ""
"Hide this menu item.If this item is a folder all items under it will be "
"hidden too"
@ -1496,11 +1458,11 @@ msgstr ""
"Ukryj ten element menu. Jeżeli jest to folder, wszystkie zawarte w nim "
"elementy również zostaną ukryte"
#: allianceauth/menu/models.py:60
#: allianceauth/menu/models.py:59
msgid "icon classes"
msgstr "Typy ikon"
#: allianceauth/menu/models.py:62
#: allianceauth/menu/models.py:61
msgid ""
"Font Awesome classes to show as icon on menu, e.g. <code>fa-solid fa-"
"house</code>"
@ -1508,11 +1470,11 @@ msgstr ""
"Obiekty klasy <i>Font Awesome</i>, np. <code>fa-solid fa-house</code>, "
"będzą widoczne jako ikony w menu."
#: allianceauth/menu/models.py:68
#: allianceauth/menu/models.py:67
msgid "url"
msgstr "adres"
#: allianceauth/menu/models.py:69
#: allianceauth/menu/models.py:68
msgid "External URL this menu items will link to"
msgstr "Zewnętrzny adres, na który ten odnośnik będzie wskazywał"
@ -1521,63 +1483,44 @@ msgid "Add folder"
msgstr "Dodaj folder"
#: allianceauth/menu/templates/menu/menu-notification-block.html:12
#: allianceauth/notifications/apps.py:8
#: allianceauth/notifications/templates/notifications/list.html:7
#: allianceauth/notifications/templates/notifications/list.html:11
#: allianceauth/templates/allianceauth/notifications_menu_item.html:6
msgid "Notifications"
msgstr "Powiadomienia"
#: allianceauth/menu/templates/menu/menu-user.html:77
#: allianceauth/menu/templates/menu/menu-user.html:56
msgid "Super User"
msgstr "Super-Użytkownik"
#: allianceauth/menu/templates/menu/menu-user.html:83
#: allianceauth/menu/templates/menu/menu-user.html:86
msgid "Alliance Auth Documentation"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:94
#: allianceauth/menu/templates/menu/menu-user.html:97
msgid "Alliance Auth Discord"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:105
#: allianceauth/menu/templates/menu/menu-user.html:108
msgid "Alliance Auth Git"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:118
#: allianceauth/menu/templates/menu/menu-user.html:121
#: allianceauth/menu/templates/menu/menu-user.html:70
#: allianceauth/templates/allianceauth/top-menu-admin.html:9
msgid "Admin"
msgstr "Administrator"
#: allianceauth/menu/templates/menu/menu-user.html:144
#: allianceauth/menu/templates/menu/menu-user.html:147
#: allianceauth/menu/templates/menu/menu-user.html:82
msgid "Sign Out"
msgstr "Wyloguj"
#: allianceauth/menu/templates/menu/menu-user.html:155
#: allianceauth/menu/templates/menu/menu-user.html:158
#: allianceauth/menu/templates/menu/menu-user.html:86
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:17
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:18
msgid "Sign In"
msgstr "Zaloguj"
#: allianceauth/notifications/models.py:22
#: allianceauth/notifications/models.py:21
msgid "danger"
msgstr "niebezpieczeństwo"
#: allianceauth/notifications/models.py:23
#: allianceauth/notifications/models.py:22
msgid "warning"
msgstr "ostrzeżenie"
#: allianceauth/notifications/models.py:24
#: allianceauth/notifications/models.py:23
msgid "info"
msgstr "informacja"
#: allianceauth/notifications/models.py:25
#: allianceauth/notifications/models.py:24
msgid "success"
msgstr "sukces"
@ -1634,7 +1577,7 @@ msgstr "Oznaczono wszystkie powiadomienia jako przeczytane."
msgid "Deleted all read notifications."
msgstr "Usunięto wszystkie przeczytane powiadomienia."
#: allianceauth/optimer/apps.py:8 allianceauth/optimer/auth_hooks.py:12
#: allianceauth/optimer/auth_hooks.py:12
msgid "Fleet Operations"
msgstr "Operacje Floty"
@ -1708,6 +1651,11 @@ msgstr "Operacja"
msgid "Form Up System"
msgstr "Miejsce zbiórki"
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
msgid "EVE Time"
msgstr "Czas EVE"
#: allianceauth/optimer/templates/optimer/fleetoptable.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:13
msgid "Local Time"
@ -1723,8 +1671,8 @@ msgstr "Zarządzanie operacją floty"
#: allianceauth/optimer/templates/optimer/management.html:28
#: allianceauth/timerboard/templates/timerboard/view.html:32
msgid "Current EVE time:"
msgstr ""
msgid "Current Eve Time:"
msgstr "Obecny czas EVE:"
#: allianceauth/optimer/templates/optimer/management.html:36
msgid "Next Fleet Operations"
@ -1768,7 +1716,6 @@ msgstr "Usunięto czas operacji dla %(opname)s."
msgid "Saved changes to operation timer for %(opname)s."
msgstr "Zapisano zmiany czasu operacji dla %(opname)s."
#: allianceauth/permissions_tool/apps.py:8
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:7
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:11
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:17
@ -1825,7 +1772,7 @@ msgstr "Istnieje już takie konto serwisowe"
msgid "Successfully set your {self.service_name} password"
msgstr "Pomyślnie zmieniono hasło {self.service_name}"
#: allianceauth/services/apps.py:8 allianceauth/services/auth_hooks.py:12
#: allianceauth/services/auth_hooks.py:12
msgid "Services"
msgstr "Usługi"
@ -1889,10 +1836,6 @@ msgstr "Hasło"
msgid "Password must be at least 8 characters long."
msgstr "Hasło musi zawierać przynajmniej 8 znaków."
#: allianceauth/services/modules/discord/apps.py:8
msgid "Discord Service"
msgstr ""
#: allianceauth/services/modules/discord/models.py:187
msgid "Discord Account Disabled"
msgstr "Konto Discorda wyłączone"
@ -1944,10 +1887,6 @@ msgid ""
msgstr ""
"Wystąpił problem w trakcie aktywacji konta Discorda. Spróbuj ponownie."
#: allianceauth/services/modules/discourse/apps.py:8
msgid "Discourse Service"
msgstr ""
#: allianceauth/services/modules/discourse/templates/services/discourse/discourse_service_ctrl.html:5
msgid "Discourse"
msgstr "Dyskusja"
@ -1982,14 +1921,6 @@ msgid "Invalid payload. Please contact support if this problem persists."
msgstr ""
"Niewłaściwe dane. Skontaktuj się z pomocą, o ile ten problem nie ustąpi."
#: allianceauth/services/modules/example/apps.py:8
msgid "Example Service"
msgstr ""
#: allianceauth/services/modules/ips4/apps.py:8
msgid "IPS4 Service"
msgstr ""
#: allianceauth/services/modules/ips4/views.py:31
msgid "Activated IPSuite4 account."
msgstr "Włączono konto IPSuite4."
@ -2013,10 +1944,6 @@ msgstr "Ustaw hasło IPSuite4."
msgid "Deactivated IPSuite4 account."
msgstr "Wyłączono konto IPSuite4."
#: allianceauth/services/modules/mumble/apps.py:8
msgid "Mumble Service"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:7
msgid "Mumble"
msgstr ""
@ -2072,10 +1999,6 @@ msgstr "Połącz"
msgid "Mumble Connection History"
msgstr ""
#: allianceauth/services/modules/openfire/apps.py:8
msgid "Openfire Service"
msgstr ""
#: allianceauth/services/modules/openfire/auth_hooks.py:27
msgid "Jabber"
msgstr "Jabber"
@ -2127,10 +2050,6 @@ msgstr "Wysłano powiadomienie Jabberem do %s"
msgid "Set jabber password."
msgstr "Ustaw hasło Jabbera"
#: allianceauth/services/modules/phpbb3/apps.py:8
msgid "phpBB3 Service"
msgstr ""
#: allianceauth/services/modules/phpbb3/views.py:34
msgid "Activated forum account."
msgstr "Włączono konto Forum."
@ -2154,10 +2073,6 @@ msgstr "Zresetuj hasło Forum."
msgid "Set forum password."
msgstr "Ustaw hasło Forum."
#: allianceauth/services/modules/smf/apps.py:8
msgid "SMF Service"
msgstr ""
#: allianceauth/services/modules/smf/views.py:52
msgid "Activated SMF account."
msgstr "Włączono konto SMF."
@ -2181,10 +2096,6 @@ msgstr "Zresetuj hasło SMF."
msgid "Set SMF password."
msgstr "Ustaw hasło SMF."
#: allianceauth/services/modules/teamspeak3/apps.py:8
msgid "TeamSpeak 3 Service"
msgstr ""
#: allianceauth/services/modules/teamspeak3/forms.py:14
#, python-format
msgid "Unable to locate user %s on server"
@ -2234,10 +2145,6 @@ msgstr "Wyłączono konto TeamSpeak3."
msgid "Reset TeamSpeak3 permission key."
msgstr "Zresetuj klucz dostępu TeamSpeak3."
#: allianceauth/services/modules/xenforo/apps.py:8
msgid "Xenforo Service"
msgstr ""
#: allianceauth/services/modules/xenforo/views.py:30
msgid "Activated XenForo account."
msgstr "Włączono konto XenForo."
@ -2350,7 +2257,7 @@ msgstr ""
"Niektóre z usług oferują różne opcje. Najedź myszą na opcję, aby zobaczyć "
"więcej szczegółów."
#: allianceauth/srp/apps.py:8 allianceauth/srp/auth_hooks.py:14
#: allianceauth/srp/auth_hooks.py:14
msgid "Ship Replacement"
msgstr "Zwrot kosztów (SRP)"
@ -2426,18 +2333,18 @@ msgid "Mark Completed"
msgstr "Oznacz jako Ukończoną"
#: allianceauth/srp/templates/srp/data.html:48
#: allianceauth/srp/templates/srp/data.html:142
#: allianceauth/srp/templates/srp/data.html:139
msgid "Total Losses:"
msgstr "Całkowite straty:"
#: allianceauth/srp/templates/srp/data.html:49
#: allianceauth/srp/templates/srp/data.html:143
#: allianceauth/srp/templates/srp/data.html:140
#: allianceauth/srp/templates/srp/management.html:36
msgid "Total ISK Cost:"
msgstr "Całkowity koszt w ISK:"
#: allianceauth/srp/templates/srp/data.html:60
#: allianceauth/srp/templates/srp/data.html:154
#: allianceauth/srp/templates/srp/data.html:151
msgid "Are you sure you want to delete SRP requests?"
msgstr "Czy jesteś pewien, że chcesz usunąć zgłoszenie o SRP?"
@ -2471,12 +2378,12 @@ msgstr ""
msgid "Post Time"
msgstr "Czas zgłoszenia"
#: allianceauth/srp/templates/srp/data.html:102
#: allianceauth/srp/templates/srp/data.html:99
#: allianceauth/srp/templates/srp/management.html:70
msgid "Link"
msgstr "Odnośnik"
#: allianceauth/srp/templates/srp/data.html:163
#: allianceauth/srp/templates/srp/data.html:160
msgid "No SRP requests for this fleet."
msgstr "Brak możliwości zgłaszania SRP dla tej Floty."
@ -2665,48 +2572,52 @@ msgstr "Twój Serwer otrzymał błąd ESI o kodzie"
msgid "Alliance Auth Notifications"
msgstr "Powiadomienia z Autoryzacji Sojuszu (AA)"
#: allianceauth/templates/allianceauth/admin-status/overview.html:20
#: allianceauth/templates/allianceauth/admin-status/overview.html:18
msgid "Closed"
msgstr "Zakończone"
#: allianceauth/templates/allianceauth/admin-status/overview.html:24
msgid "No notifications at this time"
msgstr "Brak nowych powiadomień"
#: allianceauth/templates/allianceauth/admin-status/overview.html:29
#: allianceauth/templates/allianceauth/admin-status/overview.html:33
msgid "Powered by GitLab"
msgstr "Utworzone przy użyciu GitLab"
#: allianceauth/templates/allianceauth/admin-status/overview.html:35
#: allianceauth/templates/allianceauth/admin-status/overview.html:39
msgid "Support Discord"
msgstr "Potrzebujesz pomocy? Użyj Discord"
#: allianceauth/templates/allianceauth/admin-status/overview.html:49
#: allianceauth/templates/allianceauth/admin-status/overview.html:53
#: allianceauth/templates/allianceauth/admin-status/overview.html:57
msgid "Software Version"
msgstr "Wersja oprogramowania"
#: allianceauth/templates/allianceauth/admin-status/overview.html:56
#: allianceauth/templates/allianceauth/admin-status/overview.html:60
msgid "Current"
msgstr "Aktualne"
#: allianceauth/templates/allianceauth/admin-status/overview.html:63
#: allianceauth/templates/allianceauth/admin-status/overview.html:67
msgid "Latest Stable"
msgstr "Ostatnia stabilna"
#: allianceauth/templates/allianceauth/admin-status/overview.html:68
#: allianceauth/templates/allianceauth/admin-status/overview.html:72
msgid "Update available"
msgstr "Aktualizacja jest dostępna"
#: allianceauth/templates/allianceauth/admin-status/overview.html:76
#: allianceauth/templates/allianceauth/admin-status/overview.html:80
msgid "Latest Pre-Release"
msgstr "Ostatnie przed-produkcyjna"
#: allianceauth/templates/allianceauth/admin-status/overview.html:81
#: allianceauth/templates/allianceauth/admin-status/overview.html:85
msgid "Pre-Release available"
msgstr "Przed-produkcyjna jest dostępna"
#: allianceauth/templates/allianceauth/admin-status/overview.html:91
#: allianceauth/templates/allianceauth/admin-status/overview.html:95
msgid "Task Queue"
msgstr "Kolejka Zadań"
#: allianceauth/templates/allianceauth/admin-status/overview.html:96
#: allianceauth/templates/allianceauth/admin-status/overview.html:100
#, python-format
msgid ""
"\n"
@ -2716,11 +2627,11 @@ msgstr ""
"\n"
"Status %(total)s przeprocesowanych Zadań • ostatnie %(latest)s"
#: allianceauth/templates/allianceauth/admin-status/overview.html:112
#: allianceauth/templates/allianceauth/admin-status/overview.html:116
msgid "running"
msgstr "w trakcie"
#: allianceauth/templates/allianceauth/admin-status/overview.html:113
#: allianceauth/templates/allianceauth/admin-status/overview.html:117
msgid "queued"
msgstr "oczekujące"
@ -2745,17 +2656,10 @@ msgstr "Wyloguj"
msgid "Toggle navigation"
msgstr "Przełącz nawigację"
#: allianceauth/theme/templates/theme/theme_select.html:11
#: allianceauth/theme/templates/theme/theme_select.html:7
msgid "Select Theme"
msgstr "Wybierz styl"
#: allianceauth/timerboard/apps.py:8
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "Zdarzenia powiązane ze Strukturami"
#: allianceauth/timerboard/form.py:36
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:8
@ -2942,10 +2846,6 @@ msgstr "Usunięcie kotwiczenia"
msgid "Abandoned"
msgstr ""
#: allianceauth/timerboard/models.py:60
msgid "Theft"
msgstr ""
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:7
#: allianceauth/timerboard/templates/timerboard/view.html:54
msgid "Upcoming Timers"
@ -2955,6 +2855,12 @@ msgstr "Nadczodzące zdarzenia"
msgid "Timer"
msgstr "Zdarzenie"
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "Zdarzenia powiązane ze Strukturami"
#: allianceauth/timerboard/templates/timerboard/form.html:25
msgid "Structure Timer Details"
msgstr "Szczegóły czasowe Zdarzenia"

View File

@ -16,7 +16,7 @@ msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2025-06-19 20:23+1000\n"
"POT-Creation-Date: 2025-02-25 19:17+1000\n"
"PO-Revision-Date: 2023-11-08 13:50+0000\n"
"Last-Translator: Joel Falknau <ozirascal@gmail.com>, 2024\n"
"Language-Team: Russian (https://app.transifex.com/alliance-auth/teams/107430/ru/)\n"
@ -26,10 +26,6 @@ msgstr ""
"Language: ru\n"
"Plural-Forms: nplurals=4; plural=(n%10==1 && n%100!=11 ? 0 : n%10>=2 && n%10<=4 && (n%100<12 || n%100>14) ? 1 : n%10==0 || (n%10>=5 && n%10<=9) || (n%100>=11 && n%100<=14)? 2 : 3);\n"
#: allianceauth/analytics/apps.py:8
msgid "Analytics"
msgstr ""
#: allianceauth/analytics/models.py:22
msgid "Google Analytics Universal"
msgstr "Google Analytics Universal"
@ -38,10 +34,6 @@ msgstr "Google Analytics Universal"
msgid "Google Analytics V4"
msgstr "Google Analytics V4"
#: allianceauth/authentication/apps.py:9
msgid "Authentication"
msgstr ""
#: allianceauth/authentication/constants.py:6
msgid ""
"This software has exceeded the error limit for ESI. If you are a user, "
@ -51,7 +43,7 @@ msgid ""
"dev-and-esi on the EVE Online Discord. https://www.eveonline.com/discord"
msgstr ""
#: allianceauth/authentication/decorators.py:52
#: allianceauth/authentication/decorators.py:49
msgid "A main character is required to perform that action. Add one below."
msgstr ""
"Для продолжения следует указать основного персонажа. Выберите его ниже."
@ -65,91 +57,91 @@ msgstr "Email"
msgid "You are not allowed to add or remove these restricted groups: %s"
msgstr "Вам не разрешено добавлять или удалять эти ограниченные группы: %s"
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:106
#: allianceauth/authentication/models.py:70
#: allianceauth/project_template/project_name/settings/base.py:105
msgid "English"
msgstr "Английский"
#: allianceauth/authentication/models.py:73
#: allianceauth/authentication/models.py:71
msgid "Czech"
msgstr ""
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:108
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:107
msgid "German"
msgstr "Немецкий"
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:109
#: allianceauth/authentication/models.py:73
#: allianceauth/project_template/project_name/settings/base.py:108
msgid "Spanish"
msgstr "Испанский"
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:110
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:109
msgid "Italian"
msgstr "Итальянский"
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:111
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:110
msgid "Japanese"
msgstr "Японский"
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:112
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:111
msgid "Korean"
msgstr "Корейский"
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:112
msgid "French"
msgstr "Французский"
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:116
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:115
msgid "Russian"
msgstr "Русский"
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:114
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
msgid "Dutch"
msgstr ""
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:115
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:114
msgid "Polish"
msgstr ""
#: allianceauth/authentication/models.py:83
#: allianceauth/project_template/project_name/settings/base.py:117
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:116
msgid "Ukrainian"
msgstr "Украинский"
#: allianceauth/authentication/models.py:84
#: allianceauth/project_template/project_name/settings/base.py:118
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:117
msgid "Simplified Chinese"
msgstr ""
#: allianceauth/authentication/models.py:100
#: allianceauth/menu/templates/menu/menu-user.html:67
#: allianceauth/authentication/models.py:98
#: allianceauth/menu/templates/menu/menu-user.html:42
msgid "Language"
msgstr "Язык"
#: allianceauth/authentication/models.py:105
#: allianceauth/authentication/models.py:103
#: allianceauth/templates/allianceauth/night-toggle.html:6
msgid "Night Mode"
msgstr "Ночной режим"
#: allianceauth/authentication/models.py:109
#: allianceauth/theme/templates/theme/theme_select.html:4
#: allianceauth/authentication/models.py:107
#: allianceauth/menu/templates/menu/menu-user.html:46
msgid "Theme"
msgstr ""
#: allianceauth/authentication/models.py:126
#: allianceauth/authentication/models.py:124
#, python-format
msgid "State changed to: %s"
msgstr "Статус изменен: %s"
#: allianceauth/authentication/models.py:127
#: allianceauth/authentication/models.py:125
#, python-format
msgid "Your user's state is now: %(state)s"
msgstr "Статус пилота: %(state)s"
@ -211,8 +203,6 @@ msgstr ""
#: allianceauth/authentication/templates/authentication/tokens.html:7
#: allianceauth/authentication/templates/authentication/tokens.html:11
#: allianceauth/menu/templates/menu/menu-user.html:133
#: allianceauth/menu/templates/menu/menu-user.html:136
#: allianceauth/templates/allianceauth/top-menu-user-dropdown.html:62
msgid "Token Management"
msgstr "Управление токенами"
@ -287,7 +277,7 @@ msgstr "Регистрация"
msgid "Invalid or expired activation link."
msgstr "Ссылка активации устарела"
#: allianceauth/authentication/views.py:158
#: allianceauth/authentication/views.py:157
#, python-format
msgid ""
"Cannot change main character to %(char)s: character owned by a different "
@ -295,22 +285,22 @@ msgid ""
msgstr ""
"Нельзя сменить основного персонажа на %(char)s: похоже, что Владелец не Вы. "
#: allianceauth/authentication/views.py:165
#: allianceauth/authentication/views.py:164
#, python-format
msgid "Changed main character to %s"
msgstr "Основной персонаж изменён на %s"
#: allianceauth/authentication/views.py:179
#: allianceauth/authentication/views.py:178
#, python-format
msgid "Added %(name)s to your account."
msgstr "Добавлен %(name)s на Ваш аккаунт."
#: allianceauth/authentication/views.py:181
#: allianceauth/authentication/views.py:180
#, python-format
msgid "Failed to add %(name)s to your account: they already have an account."
msgstr "Персонаж %(name)s уже добавлен."
#: allianceauth/authentication/views.py:226
#: allianceauth/authentication/views.py:225
msgid ""
"Unable to authenticate as the selected character. Please log in with the "
"main character associated with this account."
@ -318,25 +308,25 @@ msgstr ""
"Невозможно аутентифицировать выбранным персонажем. Пожалуйста залогиньтесь "
"основным персонажем от данной учётной записи. "
#: allianceauth/authentication/views.py:293
#: allianceauth/authentication/views.py:292
msgid "Registration token has expired."
msgstr "Регистрационный токен просрочен."
#: allianceauth/authentication/views.py:354
#: allianceauth/authentication/views.py:353
msgid ""
"Sent confirmation email. Please follow the link to confirm your email "
"address."
msgstr "Отправить подтверждающее письмо. Пожалуйста, подтвердите почту. "
#: allianceauth/authentication/views.py:360
#: allianceauth/authentication/views.py:359
msgid "Confirmed your email address. Please login to continue."
msgstr "Подтвердите Ваш email адрес. Зайти для подтверждения. "
#: allianceauth/authentication/views.py:366
#: allianceauth/authentication/views.py:365
msgid "Registration of new accounts is not allowed at this time."
msgstr "Регистрация новых аккаунтов в настоящее время невозможна."
#: allianceauth/corputils/apps.py:8 allianceauth/corputils/auth_hooks.py:12
#: allianceauth/corputils/auth_hooks.py:12
msgid "Corporation Stats"
msgstr "Статистика корпорации"
@ -442,10 +432,6 @@ msgstr "Выбранная корпорация уже в модуле стат
msgid "Failed to gather corporation statistics with selected token."
msgstr "Невозможно получить статистику корпорации по данному токену."
#: allianceauth/crontab/apps.py:16
msgid "Crontab"
msgstr ""
#: allianceauth/crontab/models.py:13
msgid "Minute Offset"
msgstr ""
@ -479,15 +465,6 @@ msgstr ""
msgid "This CSS will be added to the site after the default CSS."
msgstr ""
#: allianceauth/eveonline/apps.py:8
msgid "EVE Online"
msgstr ""
#: allianceauth/eveonline/autogroups/apps.py:8
msgid "EVE Online Autogroups"
msgstr ""
#: allianceauth/fleetactivitytracking/apps.py:8
#: allianceauth/fleetactivitytracking/auth_hooks.py:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/characternotexisting.html:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkcreate.html:11
@ -597,12 +574,10 @@ msgstr "Корабль"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkpersonalmonthlystatisticsview.html:75
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:44
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:92
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/templates/allianceauth/top-menu.html:23
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
#: allianceauth/timerboard/templates/timerboard/timertable.html:12
msgid "EVE time"
msgstr ""
msgid "Eve Time"
msgstr "ET"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkmodify.html:49
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:52
@ -772,11 +747,6 @@ msgstr ""
"Не могу зарегистрировать ФлАк для {character.character_name}. Персонаж "
"должен быть онлайн."
#: allianceauth/framework/apps.py:16
msgid "Framework"
msgstr ""
#: allianceauth/groupmanagement/apps.py:8
#: allianceauth/groupmanagement/auth_hooks.py:18
#: allianceauth/groupmanagement/templates/groupmanagement/groups.html:18
msgid "Group Management"
@ -1032,7 +1002,7 @@ msgid "Hidden"
msgstr "Скрытые"
#: allianceauth/groupmanagement/templates/groupmanagement/groupmembership.html:45
#: allianceauth/templates/allianceauth/admin-status/overview.html:15
#: allianceauth/templates/allianceauth/admin-status/overview.html:16
msgid "Open"
msgstr "Открыть"
@ -1085,7 +1055,7 @@ msgstr "Покинуть"
#: allianceauth/hrapplications/templates/hrapplications/management.html:182
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:46
#: allianceauth/hrapplications/templates/hrapplications/view.html:25
#: allianceauth/srp/templates/srp/data.html:120
#: allianceauth/srp/templates/srp/data.html:117
#: allianceauth/srp/templates/srp/management.html:87
msgid "Pending"
msgstr "Ожидание"
@ -1231,10 +1201,6 @@ msgstr "Ваш запрос находится на рассмотрении"
msgid "Applied to leave group %(group)s."
msgstr "Запрос на выход из группы %(group)s."
#: allianceauth/hrapplications/apps.py:8
msgid "HR Applications"
msgstr ""
#: allianceauth/hrapplications/auth_hooks.py:15
msgid "Applications"
msgstr "Запросы"
@ -1306,7 +1272,7 @@ msgstr "Пользователь"
#: allianceauth/hrapplications/templates/hrapplications/management.html:185
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:48
#: allianceauth/hrapplications/templates/hrapplications/view.html:21
#: allianceauth/srp/templates/srp/data.html:112
#: allianceauth/srp/templates/srp/data.html:109
msgid "Approved"
msgstr "Проверено"
@ -1314,7 +1280,7 @@ msgstr "Проверено"
#: allianceauth/hrapplications/templates/hrapplications/management.html:143
#: allianceauth/hrapplications/templates/hrapplications/management.html:187
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:50
#: allianceauth/srp/templates/srp/data.html:116
#: allianceauth/srp/templates/srp/data.html:113
msgid "Rejected"
msgstr "Отменено "
@ -1429,7 +1395,7 @@ msgstr ""
msgid "children"
msgstr ""
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:22
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:21
msgid "text"
msgstr "текст"
@ -1441,15 +1407,11 @@ msgstr ""
msgid "visible"
msgstr ""
#: allianceauth/menu/apps.py:16
msgid "Menu"
msgstr ""
#: allianceauth/menu/constants.py:16
msgid "app"
msgstr ""
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:38
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:37
msgid "folder"
msgstr "папка"
@ -1461,47 +1423,47 @@ msgstr "ссылка"
msgid "type"
msgstr "тип"
#: allianceauth/menu/models.py:23
#: allianceauth/menu/models.py:22
msgid "Text to show on menu"
msgstr "Текст, отображаемый в меню"
#: allianceauth/menu/models.py:28
#: allianceauth/menu/models.py:27
msgid "order"
msgstr "порядок"
#: allianceauth/menu/models.py:29
#: allianceauth/menu/models.py:28
msgid "Order of the menu. Lowest First"
msgstr ""
#: allianceauth/menu/models.py:39
#: allianceauth/menu/models.py:38
msgid "Folder this item is in (optional)"
msgstr ""
#: allianceauth/menu/models.py:43
#: allianceauth/menu/models.py:42
msgid "is hidden"
msgstr ""
#: allianceauth/menu/models.py:45
#: allianceauth/menu/models.py:44
msgid ""
"Hide this menu item.If this item is a folder all items under it will be "
"hidden too"
msgstr ""
#: allianceauth/menu/models.py:60
#: allianceauth/menu/models.py:59
msgid "icon classes"
msgstr ""
#: allianceauth/menu/models.py:62
#: allianceauth/menu/models.py:61
msgid ""
"Font Awesome classes to show as icon on menu, e.g. <code>fa-solid fa-"
"house</code>"
msgstr ""
#: allianceauth/menu/models.py:68
#: allianceauth/menu/models.py:67
msgid "url"
msgstr ""
#: allianceauth/menu/models.py:69
#: allianceauth/menu/models.py:68
msgid "External URL this menu items will link to"
msgstr ""
@ -1510,63 +1472,44 @@ msgid "Add folder"
msgstr ""
#: allianceauth/menu/templates/menu/menu-notification-block.html:12
#: allianceauth/notifications/apps.py:8
#: allianceauth/notifications/templates/notifications/list.html:7
#: allianceauth/notifications/templates/notifications/list.html:11
#: allianceauth/templates/allianceauth/notifications_menu_item.html:6
msgid "Notifications"
msgstr "Уведомления"
#: allianceauth/menu/templates/menu/menu-user.html:77
#: allianceauth/menu/templates/menu/menu-user.html:56
msgid "Super User"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:83
#: allianceauth/menu/templates/menu/menu-user.html:86
msgid "Alliance Auth Documentation"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:94
#: allianceauth/menu/templates/menu/menu-user.html:97
msgid "Alliance Auth Discord"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:105
#: allianceauth/menu/templates/menu/menu-user.html:108
msgid "Alliance Auth Git"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:118
#: allianceauth/menu/templates/menu/menu-user.html:121
#: allianceauth/menu/templates/menu/menu-user.html:70
#: allianceauth/templates/allianceauth/top-menu-admin.html:9
msgid "Admin"
msgstr "Администратор"
#: allianceauth/menu/templates/menu/menu-user.html:144
#: allianceauth/menu/templates/menu/menu-user.html:147
#: allianceauth/menu/templates/menu/menu-user.html:82
msgid "Sign Out"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:155
#: allianceauth/menu/templates/menu/menu-user.html:158
#: allianceauth/menu/templates/menu/menu-user.html:86
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:17
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:18
msgid "Sign In"
msgstr ""
#: allianceauth/notifications/models.py:22
#: allianceauth/notifications/models.py:21
msgid "danger"
msgstr "опасн"
#: allianceauth/notifications/models.py:23
#: allianceauth/notifications/models.py:22
msgid "warning"
msgstr "упрежд"
#: allianceauth/notifications/models.py:24
#: allianceauth/notifications/models.py:23
msgid "info"
msgstr "инфо"
#: allianceauth/notifications/models.py:25
#: allianceauth/notifications/models.py:24
msgid "success"
msgstr "успех"
@ -1623,7 +1566,7 @@ msgstr "Пометить все уведомления как прочитанн
msgid "Deleted all read notifications."
msgstr "Удалить все прочитанные уведомления"
#: allianceauth/optimer/apps.py:8 allianceauth/optimer/auth_hooks.py:12
#: allianceauth/optimer/auth_hooks.py:12
msgid "Fleet Operations"
msgstr "Флотовые операции"
@ -1697,6 +1640,11 @@ msgstr ""
msgid "Form Up System"
msgstr "Система сбора"
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
msgid "EVE Time"
msgstr "EVE Время"
#: allianceauth/optimer/templates/optimer/fleetoptable.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:13
msgid "Local Time"
@ -1712,8 +1660,8 @@ msgstr "Управление флотовыми операциями"
#: allianceauth/optimer/templates/optimer/management.html:28
#: allianceauth/timerboard/templates/timerboard/view.html:32
msgid "Current EVE time:"
msgstr ""
msgid "Current Eve Time:"
msgstr "Текущий EVE Time:"
#: allianceauth/optimer/templates/optimer/management.html:36
msgid "Next Fleet Operations"
@ -1757,7 +1705,6 @@ msgstr "Таймер для %(opname)s удалено. "
msgid "Saved changes to operation timer for %(opname)s."
msgstr "Таймер для %(opname)sобновлен."
#: allianceauth/permissions_tool/apps.py:8
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:7
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:11
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:17
@ -1814,7 +1761,7 @@ msgstr "Этот сервис уже активирован"
msgid "Successfully set your {self.service_name} password"
msgstr "Успешно установлен пароль для вашего {self.service_name}"
#: allianceauth/services/apps.py:8 allianceauth/services/auth_hooks.py:12
#: allianceauth/services/auth_hooks.py:12
msgid "Services"
msgstr "Подключение сервисов"
@ -1878,10 +1825,6 @@ msgstr "Пароль"
msgid "Password must be at least 8 characters long."
msgstr "Пароль должен быть не менее 8 символов."
#: allianceauth/services/modules/discord/apps.py:8
msgid "Discord Service"
msgstr ""
#: allianceauth/services/modules/discord/models.py:187
msgid "Discord Account Disabled"
msgstr "Discord персонаж отключен"
@ -1936,10 +1879,6 @@ msgstr ""
"Во время активации Discord аккаунта возникла ошибка. Попробуйте чуточку "
"позднее. "
#: allianceauth/services/modules/discourse/apps.py:8
msgid "Discourse Service"
msgstr ""
#: allianceauth/services/modules/discourse/templates/services/discourse/discourse_service_ctrl.html:5
msgid "Discourse"
msgstr ""
@ -1977,14 +1916,6 @@ msgstr ""
"Недопустимая \"полезная нагрузка\". Пожалуйста свяжитесь с поддержкой, если "
"данная проблема будет продолжаться."
#: allianceauth/services/modules/example/apps.py:8
msgid "Example Service"
msgstr ""
#: allianceauth/services/modules/ips4/apps.py:8
msgid "IPS4 Service"
msgstr ""
#: allianceauth/services/modules/ips4/views.py:31
msgid "Activated IPSuite4 account."
msgstr "Активирован аккаунт IPSuite4."
@ -2008,10 +1939,6 @@ msgstr "Установить пароль IPSuite4."
msgid "Deactivated IPSuite4 account."
msgstr "Деактивированный аккаунт IPSuite4."
#: allianceauth/services/modules/mumble/apps.py:8
msgid "Mumble Service"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:7
msgid "Mumble"
msgstr ""
@ -2067,10 +1994,6 @@ msgstr "Подключить"
msgid "Mumble Connection History"
msgstr ""
#: allianceauth/services/modules/openfire/apps.py:8
msgid "Openfire Service"
msgstr ""
#: allianceauth/services/modules/openfire/auth_hooks.py:27
msgid "Jabber"
msgstr "Jabber"
@ -2122,10 +2045,6 @@ msgstr ""
msgid "Set jabber password."
msgstr "Установить jabber пароль."
#: allianceauth/services/modules/phpbb3/apps.py:8
msgid "phpBB3 Service"
msgstr ""
#: allianceauth/services/modules/phpbb3/views.py:34
msgid "Activated forum account."
msgstr "Допустить на Форум."
@ -2149,10 +2068,6 @@ msgstr "Сбросить пароль на Форум."
msgid "Set forum password."
msgstr "Установить пароль на Форум."
#: allianceauth/services/modules/smf/apps.py:8
msgid "SMF Service"
msgstr ""
#: allianceauth/services/modules/smf/views.py:52
msgid "Activated SMF account."
msgstr "Активированный аккаунт SMF."
@ -2176,10 +2091,6 @@ msgstr "Сбросить пароль SMF."
msgid "Set SMF password."
msgstr "Установить пароль SMF."
#: allianceauth/services/modules/teamspeak3/apps.py:8
msgid "TeamSpeak 3 Service"
msgstr ""
#: allianceauth/services/modules/teamspeak3/forms.py:14
#, python-format
msgid "Unable to locate user %s on server"
@ -2229,10 +2140,6 @@ msgstr "Отключить TeamSpeak3 аккаунт."
msgid "Reset TeamSpeak3 permission key."
msgstr "Сбросить TeamSpeak3 ключ доступа."
#: allianceauth/services/modules/xenforo/apps.py:8
msgid "Xenforo Service"
msgstr ""
#: allianceauth/services/modules/xenforo/views.py:30
msgid "Activated XenForo account."
msgstr "Активированный аккаунт XenForo."
@ -2342,7 +2249,7 @@ msgid ""
"Some services provide different options. Hover over the buttons to see more."
msgstr ""
#: allianceauth/srp/apps.py:8 allianceauth/srp/auth_hooks.py:14
#: allianceauth/srp/auth_hooks.py:14
msgid "Ship Replacement"
msgstr "Компенсация корабля"
@ -2419,18 +2326,18 @@ msgid "Mark Completed"
msgstr "Пометить законченным"
#: allianceauth/srp/templates/srp/data.html:48
#: allianceauth/srp/templates/srp/data.html:142
#: allianceauth/srp/templates/srp/data.html:139
msgid "Total Losses:"
msgstr "Суммарные потери:"
#: allianceauth/srp/templates/srp/data.html:49
#: allianceauth/srp/templates/srp/data.html:143
#: allianceauth/srp/templates/srp/data.html:140
#: allianceauth/srp/templates/srp/management.html:36
msgid "Total ISK Cost:"
msgstr "Оценочная стоимость, ISK:"
#: allianceauth/srp/templates/srp/data.html:60
#: allianceauth/srp/templates/srp/data.html:154
#: allianceauth/srp/templates/srp/data.html:151
msgid "Are you sure you want to delete SRP requests?"
msgstr "Вы уверенны что хотите удалить запрос на SRP?"
@ -2462,12 +2369,12 @@ msgstr "Нажмите на значение для редактирования
msgid "Post Time"
msgstr "Опубликованно"
#: allianceauth/srp/templates/srp/data.html:102
#: allianceauth/srp/templates/srp/data.html:99
#: allianceauth/srp/templates/srp/management.html:70
msgid "Link"
msgstr "ссылка"
#: allianceauth/srp/templates/srp/data.html:163
#: allianceauth/srp/templates/srp/data.html:160
msgid "No SRP requests for this fleet."
msgstr "SRP запросы отсутствуют"
@ -2655,48 +2562,52 @@ msgstr ""
msgid "Alliance Auth Notifications"
msgstr "Уведомления об Альянсовых авторизациях"
#: allianceauth/templates/allianceauth/admin-status/overview.html:20
#: allianceauth/templates/allianceauth/admin-status/overview.html:18
msgid "Closed"
msgstr "Закрыт"
#: allianceauth/templates/allianceauth/admin-status/overview.html:24
msgid "No notifications at this time"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:29
#: allianceauth/templates/allianceauth/admin-status/overview.html:33
msgid "Powered by GitLab"
msgstr "При поддержке GitLab"
#: allianceauth/templates/allianceauth/admin-status/overview.html:35
#: allianceauth/templates/allianceauth/admin-status/overview.html:39
msgid "Support Discord"
msgstr "Поддержка Discord"
#: allianceauth/templates/allianceauth/admin-status/overview.html:49
#: allianceauth/templates/allianceauth/admin-status/overview.html:53
#: allianceauth/templates/allianceauth/admin-status/overview.html:57
msgid "Software Version"
msgstr "Версия приложения"
#: allianceauth/templates/allianceauth/admin-status/overview.html:56
#: allianceauth/templates/allianceauth/admin-status/overview.html:60
msgid "Current"
msgstr "Текущий"
#: allianceauth/templates/allianceauth/admin-status/overview.html:63
#: allianceauth/templates/allianceauth/admin-status/overview.html:67
msgid "Latest Stable"
msgstr "Стабильная Версия"
#: allianceauth/templates/allianceauth/admin-status/overview.html:68
#: allianceauth/templates/allianceauth/admin-status/overview.html:72
msgid "Update available"
msgstr "Доступно обновление"
#: allianceauth/templates/allianceauth/admin-status/overview.html:76
#: allianceauth/templates/allianceauth/admin-status/overview.html:80
msgid "Latest Pre-Release"
msgstr "Предрелизная Версия"
#: allianceauth/templates/allianceauth/admin-status/overview.html:81
#: allianceauth/templates/allianceauth/admin-status/overview.html:85
msgid "Pre-Release available"
msgstr "Предрелизная Версия"
#: allianceauth/templates/allianceauth/admin-status/overview.html:91
#: allianceauth/templates/allianceauth/admin-status/overview.html:95
msgid "Task Queue"
msgstr "Список задач"
#: allianceauth/templates/allianceauth/admin-status/overview.html:96
#: allianceauth/templates/allianceauth/admin-status/overview.html:100
#, python-format
msgid ""
"\n"
@ -2704,11 +2615,11 @@ msgid ""
" "
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:112
#: allianceauth/templates/allianceauth/admin-status/overview.html:116
msgid "running"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:113
#: allianceauth/templates/allianceauth/admin-status/overview.html:117
msgid "queued"
msgstr ""
@ -2733,17 +2644,10 @@ msgstr "Выход"
msgid "Toggle navigation"
msgstr "Проложить маршрут"
#: allianceauth/theme/templates/theme/theme_select.html:11
#: allianceauth/theme/templates/theme/theme_select.html:7
msgid "Select Theme"
msgstr ""
#: allianceauth/timerboard/apps.py:8
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "Структурные таймера"
#: allianceauth/timerboard/form.py:36
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:8
@ -2930,10 +2834,6 @@ msgstr "Снятие с якоря"
msgid "Abandoned"
msgstr ""
#: allianceauth/timerboard/models.py:60
msgid "Theft"
msgstr ""
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:7
#: allianceauth/timerboard/templates/timerboard/view.html:54
msgid "Upcoming Timers"
@ -2943,6 +2843,12 @@ msgstr ""
msgid "Timer"
msgstr ""
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "Структурные таймера"
#: allianceauth/timerboard/templates/timerboard/form.html:25
msgid "Structure Timer Details"
msgstr ""

View File

@ -7,16 +7,15 @@
# Kristof Swensen, 2023
# Денис Ивченко, 2024
# Andrii Yukhymchak, 2024
# Bandera Primary, 2025
#
#, fuzzy
msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2025-06-19 20:23+1000\n"
"POT-Creation-Date: 2025-02-25 19:17+1000\n"
"PO-Revision-Date: 2023-11-08 13:50+0000\n"
"Last-Translator: Bandera Primary, 2025\n"
"Last-Translator: Andrii Yukhymchak, 2024\n"
"Language-Team: Ukrainian (https://app.transifex.com/alliance-auth/teams/107430/uk/)\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
@ -24,10 +23,6 @@ msgstr ""
"Language: uk\n"
"Plural-Forms: nplurals=4; plural=(n % 1 == 0 && n % 10 == 1 && n % 100 != 11 ? 0 : n % 1 == 0 && n % 10 >= 2 && n % 10 <= 4 && (n % 100 < 12 || n % 100 > 14) ? 1 : n % 1 == 0 && (n % 10 ==0 || (n % 10 >=5 && n % 10 <=9) || (n % 100 >=11 && n % 100 <=14 )) ? 2: 3);\n"
#: allianceauth/analytics/apps.py:8
msgid "Analytics"
msgstr ""
#: allianceauth/analytics/models.py:22
msgid "Google Analytics Universal"
msgstr "Універсальна Google Аналітика"
@ -36,10 +31,6 @@ msgstr "Універсальна Google Аналітика"
msgid "Google Analytics V4"
msgstr "Google Analytics V4"
#: allianceauth/authentication/apps.py:9
msgid "Authentication"
msgstr ""
#: allianceauth/authentication/constants.py:6
msgid ""
"This software has exceeded the error limit for ESI. If you are a user, "
@ -55,7 +46,7 @@ msgstr ""
"поради щодо того, як це зробити, поспілкуйтеся з нами в # #3rd -party-dev-"
"and-esi на EVE Online Discord. https://www.eveonline.com/discord"
#: allianceauth/authentication/decorators.py:52
#: allianceauth/authentication/decorators.py:49
msgid "A main character is required to perform that action. Add one below."
msgstr ""
"Для виконання цієї дії потрібен основний персонаж. Додайте його нижче."
@ -69,91 +60,91 @@ msgstr "Електронна пошта"
msgid "You are not allowed to add or remove these restricted groups: %s"
msgstr "Вам заборонено додавати або видаляти ці обмежені групи: %s"
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:106
#: allianceauth/authentication/models.py:70
#: allianceauth/project_template/project_name/settings/base.py:105
msgid "English"
msgstr "Англійська"
#: allianceauth/authentication/models.py:73
#: allianceauth/authentication/models.py:71
msgid "Czech"
msgstr "Чеська"
msgstr ""
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:108
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:107
msgid "German"
msgstr "Німецька"
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:109
#: allianceauth/authentication/models.py:73
#: allianceauth/project_template/project_name/settings/base.py:108
msgid "Spanish"
msgstr "Іспанська"
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:110
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:109
msgid "Italian"
msgstr "Італійська"
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:111
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:110
msgid "Japanese"
msgstr "Японська"
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:112
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:111
msgid "Korean"
msgstr "Корейська"
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:112
msgid "French"
msgstr "Французька"
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:116
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:115
msgid "Russian"
msgstr "Російська"
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:114
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
msgid "Dutch"
msgstr "Нідерландська"
msgstr ""
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:115
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:114
msgid "Polish"
msgstr "Польська"
msgstr ""
#: allianceauth/authentication/models.py:83
#: allianceauth/project_template/project_name/settings/base.py:117
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:116
msgid "Ukrainian"
msgstr "Українська"
#: allianceauth/authentication/models.py:84
#: allianceauth/project_template/project_name/settings/base.py:118
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:117
msgid "Simplified Chinese"
msgstr "Cпрощена китайська"
msgstr ""
#: allianceauth/authentication/models.py:100
#: allianceauth/menu/templates/menu/menu-user.html:67
#: allianceauth/authentication/models.py:98
#: allianceauth/menu/templates/menu/menu-user.html:42
msgid "Language"
msgstr "Мова"
#: allianceauth/authentication/models.py:105
#: allianceauth/authentication/models.py:103
#: allianceauth/templates/allianceauth/night-toggle.html:6
msgid "Night Mode"
msgstr "Нічний режим"
#: allianceauth/authentication/models.py:109
#: allianceauth/theme/templates/theme/theme_select.html:4
#: allianceauth/authentication/models.py:107
#: allianceauth/menu/templates/menu/menu-user.html:46
msgid "Theme"
msgstr "Тема"
#: allianceauth/authentication/models.py:126
#: allianceauth/authentication/models.py:124
#, python-format
msgid "State changed to: %s"
msgstr "Стан змінено на: %s"
#: allianceauth/authentication/models.py:127
#: allianceauth/authentication/models.py:125
#, python-format
msgid "Your user's state is now: %(state)s"
msgstr "Стан вашого користувача зараз: %(state)s"
@ -215,8 +206,6 @@ msgstr "Стан:"
#: allianceauth/authentication/templates/authentication/tokens.html:7
#: allianceauth/authentication/templates/authentication/tokens.html:11
#: allianceauth/menu/templates/menu/menu-user.html:133
#: allianceauth/menu/templates/menu/menu-user.html:136
#: allianceauth/templates/allianceauth/top-menu-user-dropdown.html:62
msgid "Token Management"
msgstr "Керування токенами"
@ -227,9 +216,6 @@ msgid ""
"your tokens. Always revoke tokens on "
"https://developers.eveonline.com/authorized-apps where possible."
msgstr ""
"Тут ви може видалити токени, але резервні копії або логи бази даних все ще "
"можуть містити їх. Завжди анульовуйте токени на "
"https://developers.eveonline.com/authorized-apps, коли є можливість."
#: allianceauth/authentication/templates/authentication/tokens.html:23
msgid "Scopes"
@ -295,7 +281,7 @@ msgstr "Зареєструватися"
msgid "Invalid or expired activation link."
msgstr "Невірне або прострочене посилання для активації."
#: allianceauth/authentication/views.py:158
#: allianceauth/authentication/views.py:157
#, python-format
msgid ""
"Cannot change main character to %(char)s: character owned by a different "
@ -304,24 +290,24 @@ msgstr ""
"Неможливо змінити основного персонажа на %(char)s: персонаж належить іншому "
"акаунту."
#: allianceauth/authentication/views.py:165
#: allianceauth/authentication/views.py:164
#, python-format
msgid "Changed main character to %s"
msgstr "Основного персонажа змінено на %s"
#: allianceauth/authentication/views.py:179
#: allianceauth/authentication/views.py:178
#, python-format
msgid "Added %(name)s to your account."
msgstr "Додано %(name)s до вашого облікового запису."
#: allianceauth/authentication/views.py:181
#: allianceauth/authentication/views.py:180
#, python-format
msgid "Failed to add %(name)s to your account: they already have an account."
msgstr ""
"Не вдалося додати %(name)s до вашого облікового запису: у них вже є "
"обліковий запис."
#: allianceauth/authentication/views.py:226
#: allianceauth/authentication/views.py:225
msgid ""
"Unable to authenticate as the selected character. Please log in with the "
"main character associated with this account."
@ -330,11 +316,11 @@ msgstr ""
"використовуючи аккаунт основного персонажа, пов'язаним з цим обліковим "
"записом."
#: allianceauth/authentication/views.py:293
#: allianceauth/authentication/views.py:292
msgid "Registration token has expired."
msgstr "Токен реєстрації застарів."
#: allianceauth/authentication/views.py:354
#: allianceauth/authentication/views.py:353
msgid ""
"Sent confirmation email. Please follow the link to confirm your email "
"address."
@ -342,17 +328,17 @@ msgstr ""
"Відправлено лист з підтвердженням. Будь ласка, перейдіть за посиланням, щоб "
"підтвердити свою адресу електронної пошти."
#: allianceauth/authentication/views.py:360
#: allianceauth/authentication/views.py:359
msgid "Confirmed your email address. Please login to continue."
msgstr ""
"Підтверджено вашу адресу електронної пошти. Будь ласка, увійдіть, щоб "
"продовжити."
#: allianceauth/authentication/views.py:366
#: allianceauth/authentication/views.py:365
msgid "Registration of new accounts is not allowed at this time."
msgstr "Реєстрація нових облікових записів наразі не дозволена."
#: allianceauth/corputils/apps.py:8 allianceauth/corputils/auth_hooks.py:12
#: allianceauth/corputils/auth_hooks.py:12
msgid "Corporation Stats"
msgstr "Статистика корпорації"
@ -458,52 +444,39 @@ msgstr "Вибрана корпорація вже має модуль стат
msgid "Failed to gather corporation statistics with selected token."
msgstr "Не вдалося зібрати статистику корпорації з обраним токеном."
#: allianceauth/crontab/apps.py:16
msgid "Crontab"
msgstr ""
#: allianceauth/crontab/models.py:13
msgid "Minute Offset"
msgstr "Зміщення хвилини"
msgstr ""
#: allianceauth/crontab/models.py:14
msgid "Hour Offset"
msgstr "Зміщення години"
msgstr ""
#: allianceauth/crontab/models.py:15
msgid "Day of Month Offset"
msgstr "Зміщення дня місяця"
msgstr ""
#: allianceauth/crontab/models.py:16
msgid "Month of Year Offset"
msgstr "Зміщення місяця року"
msgstr ""
#: allianceauth/crontab/models.py:17
msgid "Day of Week Offset"
msgstr "Зміщення дня тижня"
msgstr ""
#: allianceauth/custom_css/apps.py:13 allianceauth/custom_css/models.py:36
#: allianceauth/custom_css/models.py:37 allianceauth/custom_css/models.py:47
msgid "Custom CSS"
msgstr "Користувацький CSS"
msgstr ""
#: allianceauth/custom_css/models.py:25
msgid "Your custom CSS"
msgstr "Ваш користувацький CSS"
msgstr ""
#: allianceauth/custom_css/models.py:26
msgid "This CSS will be added to the site after the default CSS."
msgstr "Цей CSS буде додано до сайту після базового CSS."
#: allianceauth/eveonline/apps.py:8
msgid "EVE Online"
msgstr ""
#: allianceauth/eveonline/autogroups/apps.py:8
msgid "EVE Online Autogroups"
msgstr ""
#: allianceauth/fleetactivitytracking/apps.py:8
#: allianceauth/fleetactivitytracking/auth_hooks.py:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/characternotexisting.html:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkcreate.html:11
@ -613,12 +586,10 @@ msgstr "Корабель"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkpersonalmonthlystatisticsview.html:75
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:44
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:92
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/templates/allianceauth/top-menu.html:23
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
#: allianceauth/timerboard/templates/timerboard/timertable.html:12
msgid "EVE time"
msgstr ""
msgid "Eve Time"
msgstr "Ігровий час"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkmodify.html:49
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:52
@ -788,11 +759,6 @@ msgstr ""
"Не вдалося зареєструвати участь в флоті для {character.character_name}. "
"Персонаж повинен бути в мережі."
#: allianceauth/framework/apps.py:16
msgid "Framework"
msgstr ""
#: allianceauth/groupmanagement/apps.py:8
#: allianceauth/groupmanagement/auth_hooks.py:18
#: allianceauth/groupmanagement/templates/groupmanagement/groups.html:18
msgid "Group Management"
@ -1046,7 +1012,7 @@ msgid "Hidden"
msgstr "Прихована"
#: allianceauth/groupmanagement/templates/groupmanagement/groupmembership.html:45
#: allianceauth/templates/allianceauth/admin-status/overview.html:15
#: allianceauth/templates/allianceauth/admin-status/overview.html:16
msgid "Open"
msgstr "Відкрита"
@ -1099,7 +1065,7 @@ msgstr "Покинути"
#: allianceauth/hrapplications/templates/hrapplications/management.html:182
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:46
#: allianceauth/hrapplications/templates/hrapplications/view.html:25
#: allianceauth/srp/templates/srp/data.html:120
#: allianceauth/srp/templates/srp/data.html:117
#: allianceauth/srp/templates/srp/management.html:87
msgid "Pending"
msgstr "Очікує"
@ -1245,10 +1211,6 @@ msgstr "Ви вже подали запит на вихід з цієї груп
msgid "Applied to leave group %(group)s."
msgstr "Подано заявку на вихід з групи %(group)s."
#: allianceauth/hrapplications/apps.py:8
msgid "HR Applications"
msgstr ""
#: allianceauth/hrapplications/auth_hooks.py:15
msgid "Applications"
msgstr "Заявки"
@ -1320,7 +1282,7 @@ msgstr "Ім'я користувача"
#: allianceauth/hrapplications/templates/hrapplications/management.html:185
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:48
#: allianceauth/hrapplications/templates/hrapplications/view.html:21
#: allianceauth/srp/templates/srp/data.html:112
#: allianceauth/srp/templates/srp/data.html:109
msgid "Approved"
msgstr "Затверджено"
@ -1328,7 +1290,7 @@ msgstr "Затверджено"
#: allianceauth/hrapplications/templates/hrapplications/management.html:143
#: allianceauth/hrapplications/templates/hrapplications/management.html:187
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:50
#: allianceauth/srp/templates/srp/data.html:116
#: allianceauth/srp/templates/srp/data.html:113
msgid "Rejected"
msgstr "Відхилено"
@ -1443,7 +1405,7 @@ msgstr "Змінити пункт меню %s"
msgid "children"
msgstr "під-елементи"
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:22
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:21
msgid "text"
msgstr "текст"
@ -1455,15 +1417,11 @@ msgstr "визначено користувачем"
msgid "visible"
msgstr "видимий"
#: allianceauth/menu/apps.py:16
msgid "Menu"
msgstr ""
#: allianceauth/menu/constants.py:16
msgid "app"
msgstr "сервіс"
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:38
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:37
msgid "folder"
msgstr "тека"
@ -1475,27 +1433,27 @@ msgstr "посилання"
msgid "type"
msgstr "тип"
#: allianceauth/menu/models.py:23
#: allianceauth/menu/models.py:22
msgid "Text to show on menu"
msgstr "Текст для відображення в меню"
#: allianceauth/menu/models.py:28
#: allianceauth/menu/models.py:27
msgid "order"
msgstr "порядок"
#: allianceauth/menu/models.py:29
#: allianceauth/menu/models.py:28
msgid "Order of the menu. Lowest First"
msgstr "Порядок меню. Найнижчий перший"
#: allianceauth/menu/models.py:39
#: allianceauth/menu/models.py:38
msgid "Folder this item is in (optional)"
msgstr "Папка, в якій знаходиться цей елемент (опціонально)"
#: allianceauth/menu/models.py:43
#: allianceauth/menu/models.py:42
msgid "is hidden"
msgstr "приховано"
#: allianceauth/menu/models.py:45
#: allianceauth/menu/models.py:44
msgid ""
"Hide this menu item.If this item is a folder all items under it will be "
"hidden too"
@ -1503,11 +1461,11 @@ msgstr ""
"Приховати цей пункт меню. Якщо цей пункт є папкою, всі елементи під ним теж "
"будуть приховані"
#: allianceauth/menu/models.py:60
#: allianceauth/menu/models.py:59
msgid "icon classes"
msgstr "класи іконок"
#: allianceauth/menu/models.py:62
#: allianceauth/menu/models.py:61
msgid ""
"Font Awesome classes to show as icon on menu, e.g. <code>fa-solid fa-"
"house</code>"
@ -1515,11 +1473,11 @@ msgstr ""
"Класи Font Awesome для відображення як піктограми в меню, напр. <code>fa-"
"solid fa-house</code>"
#: allianceauth/menu/models.py:68
#: allianceauth/menu/models.py:67
msgid "url"
msgstr "URL"
#: allianceauth/menu/models.py:69
#: allianceauth/menu/models.py:68
msgid "External URL this menu items will link to"
msgstr "Зовнішня URL, на яку будуть посилатися елементи меню"
@ -1528,63 +1486,44 @@ msgid "Add folder"
msgstr "Додати теку"
#: allianceauth/menu/templates/menu/menu-notification-block.html:12
#: allianceauth/notifications/apps.py:8
#: allianceauth/notifications/templates/notifications/list.html:7
#: allianceauth/notifications/templates/notifications/list.html:11
#: allianceauth/templates/allianceauth/notifications_menu_item.html:6
msgid "Notifications"
msgstr "Повідомлення"
#: allianceauth/menu/templates/menu/menu-user.html:77
#: allianceauth/menu/templates/menu/menu-user.html:56
msgid "Super User"
msgstr "Супер користувач"
#: allianceauth/menu/templates/menu/menu-user.html:83
#: allianceauth/menu/templates/menu/menu-user.html:86
msgid "Alliance Auth Documentation"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:94
#: allianceauth/menu/templates/menu/menu-user.html:97
msgid "Alliance Auth Discord"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:105
#: allianceauth/menu/templates/menu/menu-user.html:108
msgid "Alliance Auth Git"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:118
#: allianceauth/menu/templates/menu/menu-user.html:121
#: allianceauth/menu/templates/menu/menu-user.html:70
#: allianceauth/templates/allianceauth/top-menu-admin.html:9
msgid "Admin"
msgstr "Адміністратор"
#: allianceauth/menu/templates/menu/menu-user.html:144
#: allianceauth/menu/templates/menu/menu-user.html:147
#: allianceauth/menu/templates/menu/menu-user.html:82
msgid "Sign Out"
msgstr "Вийти"
#: allianceauth/menu/templates/menu/menu-user.html:155
#: allianceauth/menu/templates/menu/menu-user.html:158
#: allianceauth/menu/templates/menu/menu-user.html:86
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:17
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:18
msgid "Sign In"
msgstr "Увійти"
#: allianceauth/notifications/models.py:22
#: allianceauth/notifications/models.py:21
msgid "danger"
msgstr "небезпека"
#: allianceauth/notifications/models.py:23
#: allianceauth/notifications/models.py:22
msgid "warning"
msgstr "попередження"
#: allianceauth/notifications/models.py:24
#: allianceauth/notifications/models.py:23
msgid "info"
msgstr "інформація"
#: allianceauth/notifications/models.py:25
#: allianceauth/notifications/models.py:24
msgid "success"
msgstr "успіх"
@ -1641,7 +1580,7 @@ msgstr "Всі повідомлення позначено як прочитан
msgid "Deleted all read notifications."
msgstr "Всі прочитані повідомлення видалено."
#: allianceauth/optimer/apps.py:8 allianceauth/optimer/auth_hooks.py:12
#: allianceauth/optimer/auth_hooks.py:12
msgid "Fleet Operations"
msgstr "Флотові операції"
@ -1715,6 +1654,11 @@ msgstr "Операція"
msgid "Form Up System"
msgstr "Система збору флоту"
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
msgid "EVE Time"
msgstr "Час за EVE"
#: allianceauth/optimer/templates/optimer/fleetoptable.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:13
msgid "Local Time"
@ -1730,8 +1674,8 @@ msgstr "Управління флотовими операціями"
#: allianceauth/optimer/templates/optimer/management.html:28
#: allianceauth/timerboard/templates/timerboard/view.html:32
msgid "Current EVE time:"
msgstr ""
msgid "Current Eve Time:"
msgstr "Поточний час Eve:"
#: allianceauth/optimer/templates/optimer/management.html:36
msgid "Next Fleet Operations"
@ -1775,7 +1719,6 @@ msgstr "Видалено таймер операції для %(opname)s."
msgid "Saved changes to operation timer for %(opname)s."
msgstr "Зміни до таймера операції %(opname)s збережено."
#: allianceauth/permissions_tool/apps.py:8
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:7
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:11
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:17
@ -1832,7 +1775,7 @@ msgstr "Такий сервісний обліковий запис вже іс
msgid "Successfully set your {self.service_name} password"
msgstr "Пароль для {self.service_name} успішно встановлено"
#: allianceauth/services/apps.py:8 allianceauth/services/auth_hooks.py:12
#: allianceauth/services/auth_hooks.py:12
msgid "Services"
msgstr "Сервіси"
@ -1896,10 +1839,6 @@ msgstr "Пароль"
msgid "Password must be at least 8 characters long."
msgstr "Пароль повинен містити принаймні 8 символів."
#: allianceauth/services/modules/discord/apps.py:8
msgid "Discord Service"
msgstr ""
#: allianceauth/services/modules/discord/models.py:187
msgid "Discord Account Disabled"
msgstr "Обліковий запис Discord вимкнено"
@ -1952,10 +1891,6 @@ msgstr ""
"Сталася помилка під час спроби активації вашого облікового запису Discord. "
"Будь ласка, спробуйте знову."
#: allianceauth/services/modules/discourse/apps.py:8
msgid "Discourse Service"
msgstr ""
#: allianceauth/services/modules/discourse/templates/services/discourse/discourse_service_ctrl.html:5
msgid "Discourse"
msgstr "Discourse"
@ -1991,14 +1926,6 @@ msgstr ""
"Неправильний пакет даних. Будь ласка, зверніться в підтримку, якщо ця "
"проблема повторюється."
#: allianceauth/services/modules/example/apps.py:8
msgid "Example Service"
msgstr ""
#: allianceauth/services/modules/ips4/apps.py:8
msgid "IPS4 Service"
msgstr ""
#: allianceauth/services/modules/ips4/views.py:31
msgid "Activated IPSuite4 account."
msgstr "Активовано обліковий запис IPSuite4."
@ -2022,51 +1949,47 @@ msgstr "Встановити пароль IPSuite4."
msgid "Deactivated IPSuite4 account."
msgstr "Деактивовано обліковий запис IPSuite4."
#: allianceauth/services/modules/mumble/apps.py:8
msgid "Mumble Service"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:7
msgid "Mumble"
msgstr "Mumble"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:11
msgid "Mumble History"
msgstr "Історія Mumble"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:23
msgid "Server Connection History"
msgstr "Історія підключень до сервера"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:32
msgid "Displayed Name"
msgstr "Відображене ім'я"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:33
msgid "Release"
msgstr "Реліз"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:34
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:68
msgid "Version"
msgstr "Версія"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:35
msgid "Last Connect"
msgstr "Останнє підключення"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:36
msgid "Last Disconnect"
msgstr "Останнє відключення"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:48
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:60
msgid "Server Connection Breakdown"
msgstr "Розбір підключення до сервера"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:69
msgid "Number"
msgstr "Кількість"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_service_ctrl.html:28
#: allianceauth/services/templates/services/service_password.html:26
@ -2079,10 +2002,6 @@ msgstr "Підєднатись"
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_service_ctrl.html:52
msgid "Mumble Connection History"
msgstr "Історія підключень до Mumble"
#: allianceauth/services/modules/openfire/apps.py:8
msgid "Openfire Service"
msgstr ""
#: allianceauth/services/modules/openfire/auth_hooks.py:27
@ -2136,10 +2055,6 @@ msgstr "Відправлено трансляцію Jabber на %s"
msgid "Set jabber password."
msgstr "Встановити пароль Jabber."
#: allianceauth/services/modules/phpbb3/apps.py:8
msgid "phpBB3 Service"
msgstr ""
#: allianceauth/services/modules/phpbb3/views.py:34
msgid "Activated forum account."
msgstr "Активований обліковий запис форуму."
@ -2163,10 +2078,6 @@ msgstr "Скинути пароль форуму."
msgid "Set forum password."
msgstr "Встановити пароль форуму."
#: allianceauth/services/modules/smf/apps.py:8
msgid "SMF Service"
msgstr ""
#: allianceauth/services/modules/smf/views.py:52
msgid "Activated SMF account."
msgstr "Активований обліковий запис SMF."
@ -2190,10 +2101,6 @@ msgstr "Скинути пароль SMF."
msgid "Set SMF password."
msgstr "Встановити пароль SMF."
#: allianceauth/services/modules/teamspeak3/apps.py:8
msgid "TeamSpeak 3 Service"
msgstr ""
#: allianceauth/services/modules/teamspeak3/forms.py:14
#, python-format
msgid "Unable to locate user %s on server"
@ -2243,10 +2150,6 @@ msgstr "Деактивовано обліковий запис TeamSpeak3."
msgid "Reset TeamSpeak3 permission key."
msgstr "Скинути ключ дозволів TeamSpeak3."
#: allianceauth/services/modules/xenforo/apps.py:8
msgid "Xenforo Service"
msgstr ""
#: allianceauth/services/modules/xenforo/views.py:30
msgid "Activated XenForo account."
msgstr "Активовано обліковий запис XenForo."
@ -2359,7 +2262,7 @@ msgstr ""
"Деякі сервіси надають різні варіанти. Наведіть курсор на кнопки, щоб "
"побачити більше."
#: allianceauth/srp/apps.py:8 allianceauth/srp/auth_hooks.py:14
#: allianceauth/srp/auth_hooks.py:14
msgid "Ship Replacement"
msgstr "Компенсації"
@ -2438,18 +2341,18 @@ msgid "Mark Completed"
msgstr "Позначити виконаним"
#: allianceauth/srp/templates/srp/data.html:48
#: allianceauth/srp/templates/srp/data.html:142
#: allianceauth/srp/templates/srp/data.html:139
msgid "Total Losses:"
msgstr "Загальні збитки:"
#: allianceauth/srp/templates/srp/data.html:49
#: allianceauth/srp/templates/srp/data.html:143
#: allianceauth/srp/templates/srp/data.html:140
#: allianceauth/srp/templates/srp/management.html:36
msgid "Total ISK Cost:"
msgstr "Загальна вартість ISK:"
#: allianceauth/srp/templates/srp/data.html:60
#: allianceauth/srp/templates/srp/data.html:154
#: allianceauth/srp/templates/srp/data.html:151
msgid "Are you sure you want to delete SRP requests?"
msgstr "Ви впевнені, що хочете видалити запити SRP?"
@ -2483,12 +2386,12 @@ msgstr ""
msgid "Post Time"
msgstr "Час публікації"
#: allianceauth/srp/templates/srp/data.html:102
#: allianceauth/srp/templates/srp/data.html:99
#: allianceauth/srp/templates/srp/management.html:70
msgid "Link"
msgstr "Посилання"
#: allianceauth/srp/templates/srp/data.html:163
#: allianceauth/srp/templates/srp/data.html:160
msgid "No SRP requests for this fleet."
msgstr "Немає запитів SRP для цього флоту."
@ -2676,48 +2579,52 @@ msgstr "Ваш сервер отримав код відповіді на пом
msgid "Alliance Auth Notifications"
msgstr "Сповіщення Alliance Auth"
#: allianceauth/templates/allianceauth/admin-status/overview.html:20
#: allianceauth/templates/allianceauth/admin-status/overview.html:18
msgid "Closed"
msgstr "Закрито"
#: allianceauth/templates/allianceauth/admin-status/overview.html:24
msgid "No notifications at this time"
msgstr "На даний момент сповіщень немає"
#: allianceauth/templates/allianceauth/admin-status/overview.html:29
#: allianceauth/templates/allianceauth/admin-status/overview.html:33
msgid "Powered by GitLab"
msgstr "Powered by GitLab"
#: allianceauth/templates/allianceauth/admin-status/overview.html:35
#: allianceauth/templates/allianceauth/admin-status/overview.html:39
msgid "Support Discord"
msgstr "Discord підтримки"
#: allianceauth/templates/allianceauth/admin-status/overview.html:49
#: allianceauth/templates/allianceauth/admin-status/overview.html:53
#: allianceauth/templates/allianceauth/admin-status/overview.html:57
msgid "Software Version"
msgstr "Версія програмного забезпечення"
#: allianceauth/templates/allianceauth/admin-status/overview.html:56
#: allianceauth/templates/allianceauth/admin-status/overview.html:60
msgid "Current"
msgstr "Поточна"
#: allianceauth/templates/allianceauth/admin-status/overview.html:63
#: allianceauth/templates/allianceauth/admin-status/overview.html:67
msgid "Latest Stable"
msgstr "Остання стабільна"
#: allianceauth/templates/allianceauth/admin-status/overview.html:68
#: allianceauth/templates/allianceauth/admin-status/overview.html:72
msgid "Update available"
msgstr "Є доступне оновлення"
#: allianceauth/templates/allianceauth/admin-status/overview.html:76
#: allianceauth/templates/allianceauth/admin-status/overview.html:80
msgid "Latest Pre-Release"
msgstr "Останній передрелізний випуск"
#: allianceauth/templates/allianceauth/admin-status/overview.html:81
#: allianceauth/templates/allianceauth/admin-status/overview.html:85
msgid "Pre-Release available"
msgstr "Доступний Попередній Реліз"
#: allianceauth/templates/allianceauth/admin-status/overview.html:91
#: allianceauth/templates/allianceauth/admin-status/overview.html:95
msgid "Task Queue"
msgstr "Черга Завдань"
#: allianceauth/templates/allianceauth/admin-status/overview.html:96
#: allianceauth/templates/allianceauth/admin-status/overview.html:100
#, python-format
msgid ""
"\n"
@ -2728,11 +2635,11 @@ msgstr ""
" Статус %(total)s оброблених завдань • останні %(latest)s\n"
" "
#: allianceauth/templates/allianceauth/admin-status/overview.html:112
#: allianceauth/templates/allianceauth/admin-status/overview.html:116
msgid "running"
msgstr "в праці"
#: allianceauth/templates/allianceauth/admin-status/overview.html:113
#: allianceauth/templates/allianceauth/admin-status/overview.html:117
msgid "queued"
msgstr "у черзі"
@ -2757,17 +2664,10 @@ msgstr "Вихід"
msgid "Toggle navigation"
msgstr "Перемикання навігації"
#: allianceauth/theme/templates/theme/theme_select.html:11
#: allianceauth/theme/templates/theme/theme_select.html:7
msgid "Select Theme"
msgstr "Виберіть тему"
#: allianceauth/timerboard/apps.py:8
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "Таймери структур"
#: allianceauth/timerboard/form.py:36
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:8
@ -2840,11 +2740,11 @@ msgstr "POCO"
#: allianceauth/timerboard/models.py:25
msgid "Orbital Skyhook"
msgstr "Орбітальний скайхук"
msgstr ""
#: allianceauth/timerboard/models.py:26
msgid "Sovereignty Hub"
msgstr "Суверенітетний хаб"
msgstr ""
#: allianceauth/timerboard/models.py:27
msgid "TCU"
@ -2908,7 +2808,7 @@ msgstr "Мост Ансіблекс"
#: allianceauth/timerboard/models.py:42
msgid "Mercenary Den"
msgstr "Кубло найманців"
msgstr ""
#: allianceauth/timerboard/models.py:43
msgid "Moon Mining Cycle"
@ -2916,7 +2816,7 @@ msgstr "Цикл видобутку супутника"
#: allianceauth/timerboard/models.py:44
msgid "Metenox Moon Drill"
msgstr "Бур Метенокс"
msgstr ""
#: allianceauth/timerboard/models.py:45
msgid "Other"
@ -2952,10 +2852,6 @@ msgstr "Зняття з якорю"
#: allianceauth/timerboard/models.py:59
msgid "Abandoned"
msgstr "Покинуто"
#: allianceauth/timerboard/models.py:60
msgid "Theft"
msgstr ""
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:7
@ -2967,6 +2863,12 @@ msgstr "Майбутні таймери"
msgid "Timer"
msgstr "Таймер"
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "Таймери структур"
#: allianceauth/timerboard/templates/timerboard/form.html:25
msgid "Structure Timer Details"
msgstr "Деталі Таймерів структур"

View File

@ -8,16 +8,15 @@
# 85b931f94c2441449e78b527e0a313ae_baf2e99 <639a60f913241ffb1c9bd90bc93a541f_869335>, 2023
# Aaron BuBu <351793078@qq.com>, 2023
# Joel Falknau <ozirascal@gmail.com>, 2023
# Aika Yu, 2025
#
#, fuzzy
msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2025-06-19 20:23+1000\n"
"POT-Creation-Date: 2025-02-25 19:17+1000\n"
"PO-Revision-Date: 2023-11-08 13:50+0000\n"
"Last-Translator: Aika Yu, 2025\n"
"Last-Translator: Joel Falknau <ozirascal@gmail.com>, 2023\n"
"Language-Team: Chinese Simplified (https://app.transifex.com/alliance-auth/teams/107430/zh-Hans/)\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
@ -25,10 +24,6 @@ msgstr ""
"Language: zh-Hans\n"
"Plural-Forms: nplurals=1; plural=0;\n"
#: allianceauth/analytics/apps.py:8
msgid "Analytics"
msgstr ""
#: allianceauth/analytics/models.py:22
msgid "Google Analytics Universal"
msgstr ""
@ -37,10 +32,6 @@ msgstr ""
msgid "Google Analytics V4"
msgstr ""
#: allianceauth/authentication/apps.py:9
msgid "Authentication"
msgstr ""
#: allianceauth/authentication/constants.py:6
msgid ""
"This software has exceeded the error limit for ESI. If you are a user, "
@ -50,7 +41,7 @@ msgid ""
"dev-and-esi on the EVE Online Discord. https://www.eveonline.com/discord"
msgstr ""
#: allianceauth/authentication/decorators.py:52
#: allianceauth/authentication/decorators.py:49
msgid "A main character is required to perform that action. Add one below."
msgstr "只有主要角色才能执行这个操作。在下面添加一个"
@ -63,91 +54,91 @@ msgstr "电子邮箱"
msgid "You are not allowed to add or remove these restricted groups: %s"
msgstr ""
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:106
#: allianceauth/authentication/models.py:70
#: allianceauth/project_template/project_name/settings/base.py:105
msgid "English"
msgstr "英语"
#: allianceauth/authentication/models.py:73
#: allianceauth/authentication/models.py:71
msgid "Czech"
msgstr "捷克语"
msgstr ""
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:108
#: allianceauth/authentication/models.py:72
#: allianceauth/project_template/project_name/settings/base.py:107
msgid "German"
msgstr "德语"
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:109
#: allianceauth/authentication/models.py:73
#: allianceauth/project_template/project_name/settings/base.py:108
msgid "Spanish"
msgstr "西班牙语"
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:110
#: allianceauth/authentication/models.py:74
#: allianceauth/project_template/project_name/settings/base.py:109
msgid "Italian"
msgstr "意大利语"
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:111
#: allianceauth/authentication/models.py:75
#: allianceauth/project_template/project_name/settings/base.py:110
msgid "Japanese"
msgstr "日语"
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:112
#: allianceauth/authentication/models.py:76
#: allianceauth/project_template/project_name/settings/base.py:111
msgid "Korean"
msgstr "韩语"
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
#: allianceauth/authentication/models.py:77
#: allianceauth/project_template/project_name/settings/base.py:112
msgid "French"
msgstr "法语"
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:116
#: allianceauth/authentication/models.py:78
#: allianceauth/project_template/project_name/settings/base.py:115
msgid "Russian"
msgstr "俄语"
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:114
#: allianceauth/authentication/models.py:79
#: allianceauth/project_template/project_name/settings/base.py:113
msgid "Dutch"
msgstr "荷兰语"
msgstr ""
#: allianceauth/authentication/models.py:80
#: allianceauth/project_template/project_name/settings/base.py:114
msgid "Polish"
msgstr ""
#: allianceauth/authentication/models.py:81
#: allianceauth/project_template/project_name/settings/base.py:116
msgid "Ukrainian"
msgstr ""
#: allianceauth/authentication/models.py:82
#: allianceauth/project_template/project_name/settings/base.py:115
msgid "Polish"
msgstr "波兰语"
#: allianceauth/authentication/models.py:83
#: allianceauth/project_template/project_name/settings/base.py:117
msgid "Ukrainian"
msgstr "乌克兰语"
#: allianceauth/authentication/models.py:84
#: allianceauth/project_template/project_name/settings/base.py:118
msgid "Simplified Chinese"
msgstr "简体中文"
msgstr ""
#: allianceauth/authentication/models.py:100
#: allianceauth/menu/templates/menu/menu-user.html:67
#: allianceauth/authentication/models.py:98
#: allianceauth/menu/templates/menu/menu-user.html:42
msgid "Language"
msgstr "语言"
#: allianceauth/authentication/models.py:105
#: allianceauth/authentication/models.py:103
#: allianceauth/templates/allianceauth/night-toggle.html:6
msgid "Night Mode"
msgstr "夜间模式"
#: allianceauth/authentication/models.py:109
#: allianceauth/theme/templates/theme/theme_select.html:4
#: allianceauth/authentication/models.py:107
#: allianceauth/menu/templates/menu/menu-user.html:46
msgid "Theme"
msgstr ""
#: allianceauth/authentication/models.py:126
#: allianceauth/authentication/models.py:124
#, python-format
msgid "State changed to: %s"
msgstr ""
#: allianceauth/authentication/models.py:127
#: allianceauth/authentication/models.py:125
#, python-format
msgid "Your user's state is now: %(state)s"
msgstr ""
@ -209,8 +200,6 @@ msgstr ""
#: allianceauth/authentication/templates/authentication/tokens.html:7
#: allianceauth/authentication/templates/authentication/tokens.html:11
#: allianceauth/menu/templates/menu/menu-user.html:133
#: allianceauth/menu/templates/menu/menu-user.html:136
#: allianceauth/templates/allianceauth/top-menu-user-dropdown.html:62
msgid "Token Management"
msgstr ""
@ -284,53 +273,53 @@ msgstr "注册"
msgid "Invalid or expired activation link."
msgstr "激活链接无效或过期"
#: allianceauth/authentication/views.py:158
#: allianceauth/authentication/views.py:157
#, python-format
msgid ""
"Cannot change main character to %(char)s: character owned by a different "
"account."
msgstr "不能修改主角色为%(char)s这个角色被另一个账户所拥有"
#: allianceauth/authentication/views.py:165
#: allianceauth/authentication/views.py:164
#, python-format
msgid "Changed main character to %s"
msgstr "修改主角色为%s"
msgstr ""
#: allianceauth/authentication/views.py:179
#: allianceauth/authentication/views.py:178
#, python-format
msgid "Added %(name)s to your account."
msgstr "添加%(name)s到您的账户"
#: allianceauth/authentication/views.py:181
#: allianceauth/authentication/views.py:180
#, python-format
msgid "Failed to add %(name)s to your account: they already have an account."
msgstr "添加%(name)s到您的账户失败他们已经在一个账户中了"
#: allianceauth/authentication/views.py:226
#: allianceauth/authentication/views.py:225
msgid ""
"Unable to authenticate as the selected character. Please log in with the "
"main character associated with this account."
msgstr ""
#: allianceauth/authentication/views.py:293
#: allianceauth/authentication/views.py:292
msgid "Registration token has expired."
msgstr "注册令牌过期。"
#: allianceauth/authentication/views.py:354
#: allianceauth/authentication/views.py:353
msgid ""
"Sent confirmation email. Please follow the link to confirm your email "
"address."
msgstr "已经发送了确认邮件。请按照链接确定您的电邮地址"
#: allianceauth/authentication/views.py:360
#: allianceauth/authentication/views.py:359
msgid "Confirmed your email address. Please login to continue."
msgstr "已确认您的电邮地址。请登录以继续"
#: allianceauth/authentication/views.py:366
#: allianceauth/authentication/views.py:365
msgid "Registration of new accounts is not allowed at this time."
msgstr ""
#: allianceauth/corputils/apps.py:8 allianceauth/corputils/auth_hooks.py:12
#: allianceauth/corputils/auth_hooks.py:12
msgid "Corporation Stats"
msgstr "军团统计"
@ -370,11 +359,11 @@ msgstr "最后一次更新"
#: allianceauth/corputils/templates/corputils/corpstats.html:86
msgid "Update Now"
msgstr "立刻更新"
msgstr ""
#: allianceauth/corputils/templates/corputils/corpstats.html:101
msgid "Main character"
msgstr "主要角色"
msgstr ""
#: allianceauth/corputils/templates/corputils/corpstats.html:102
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkmodify.html:29
@ -436,10 +425,6 @@ msgstr "选定的军团已经有了一个统计模块"
msgid "Failed to gather corporation statistics with selected token."
msgstr "未能使用指定的令牌收集军团信息"
#: allianceauth/crontab/apps.py:16
msgid "Crontab"
msgstr ""
#: allianceauth/crontab/models.py:13
msgid "Minute Offset"
msgstr ""
@ -473,15 +458,6 @@ msgstr ""
msgid "This CSS will be added to the site after the default CSS."
msgstr ""
#: allianceauth/eveonline/apps.py:8
msgid "EVE Online"
msgstr ""
#: allianceauth/eveonline/autogroups/apps.py:8
msgid "EVE Online Autogroups"
msgstr ""
#: allianceauth/fleetactivitytracking/apps.py:8
#: allianceauth/fleetactivitytracking/auth_hooks.py:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/characternotexisting.html:10
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkcreate.html:11
@ -560,7 +536,7 @@ msgstr "编辑一个PAP"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkmodify.html:21
msgid "Are you sure?"
msgstr "是否确认?"
msgstr ""
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkmodify.html:22
msgid "Delete fat"
@ -591,17 +567,15 @@ msgstr "舰船"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkpersonalmonthlystatisticsview.html:75
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:44
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:92
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/templates/allianceauth/top-menu.html:23
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
#: allianceauth/timerboard/templates/timerboard/timertable.html:12
msgid "EVE time"
msgstr ""
msgid "Eve Time"
msgstr "EVE时间"
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkmodify.html:49
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkview.html:52
msgid "Docked in"
msgstr "停靠在"
msgstr ""
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkpersonalmonthlystatisticsview.html:6
#: allianceauth/fleetactivitytracking/templates/fleetactivitytracking/fatlinkpersonalstatisticsview.html:6
@ -737,11 +711,11 @@ msgstr "记录中找不到已创建的PAP链接"
#: allianceauth/fleetactivitytracking/views.py:218
msgid "Character does not exist"
msgstr "角色不存在"
msgstr ""
#: allianceauth/fleetactivitytracking/views.py:221
msgid "User does not exist"
msgstr "用户不存在"
msgstr ""
#: allianceauth/fleetactivitytracking/views.py:299
msgid "Fleet participation registered."
@ -758,11 +732,6 @@ msgid ""
"character needs to be online."
msgstr ""
#: allianceauth/framework/apps.py:16
msgid "Framework"
msgstr ""
#: allianceauth/groupmanagement/apps.py:8
#: allianceauth/groupmanagement/auth_hooks.py:18
#: allianceauth/groupmanagement/templates/groupmanagement/groups.html:18
msgid "Group Management"
@ -966,7 +935,7 @@ msgstr "用户组成员"
#: allianceauth/groupmanagement/templates/groupmanagement/groupmembership.html:13
msgid "Join/Leave Requests"
msgstr "加入/退出申请"
msgstr ""
#: allianceauth/groupmanagement/templates/groupmanagement/groupmembership.html:24
#: allianceauth/groupmanagement/templates/groupmanagement/groups.html:33
@ -992,7 +961,7 @@ msgid "Hidden"
msgstr "已隐藏"
#: allianceauth/groupmanagement/templates/groupmanagement/groupmembership.html:45
#: allianceauth/templates/allianceauth/admin-status/overview.html:15
#: allianceauth/templates/allianceauth/admin-status/overview.html:16
msgid "Open"
msgstr "公开"
@ -1045,7 +1014,7 @@ msgstr "离开"
#: allianceauth/hrapplications/templates/hrapplications/management.html:182
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:46
#: allianceauth/hrapplications/templates/hrapplications/view.html:25
#: allianceauth/srp/templates/srp/data.html:120
#: allianceauth/srp/templates/srp/data.html:117
#: allianceauth/srp/templates/srp/management.html:87
msgid "Pending"
msgstr "待定"
@ -1187,10 +1156,6 @@ msgstr "你已经有了该组的未决离开请求"
msgid "Applied to leave group %(group)s."
msgstr "已经离开群组%(group)s"
#: allianceauth/hrapplications/apps.py:8
msgid "HR Applications"
msgstr ""
#: allianceauth/hrapplications/auth_hooks.py:15
msgid "Applications"
msgstr "申请"
@ -1262,7 +1227,7 @@ msgstr "用户名"
#: allianceauth/hrapplications/templates/hrapplications/management.html:185
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:48
#: allianceauth/hrapplications/templates/hrapplications/view.html:21
#: allianceauth/srp/templates/srp/data.html:112
#: allianceauth/srp/templates/srp/data.html:109
msgid "Approved"
msgstr "通过"
@ -1270,7 +1235,7 @@ msgstr "通过"
#: allianceauth/hrapplications/templates/hrapplications/management.html:143
#: allianceauth/hrapplications/templates/hrapplications/management.html:187
#: allianceauth/hrapplications/templates/hrapplications/searchview.html:50
#: allianceauth/srp/templates/srp/data.html:116
#: allianceauth/srp/templates/srp/data.html:113
msgid "Rejected"
msgstr "拒绝"
@ -1385,7 +1350,7 @@ msgstr ""
msgid "children"
msgstr ""
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:22
#: allianceauth/menu/admin.py:90 allianceauth/menu/models.py:21
msgid "text"
msgstr ""
@ -1397,15 +1362,11 @@ msgstr ""
msgid "visible"
msgstr ""
#: allianceauth/menu/apps.py:16
msgid "Menu"
msgstr ""
#: allianceauth/menu/constants.py:16
msgid "app"
msgstr ""
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:38
#: allianceauth/menu/constants.py:17 allianceauth/menu/models.py:37
msgid "folder"
msgstr ""
@ -1417,47 +1378,47 @@ msgstr ""
msgid "type"
msgstr ""
#: allianceauth/menu/models.py:23
#: allianceauth/menu/models.py:22
msgid "Text to show on menu"
msgstr ""
#: allianceauth/menu/models.py:28
#: allianceauth/menu/models.py:27
msgid "order"
msgstr ""
#: allianceauth/menu/models.py:29
#: allianceauth/menu/models.py:28
msgid "Order of the menu. Lowest First"
msgstr ""
#: allianceauth/menu/models.py:39
#: allianceauth/menu/models.py:38
msgid "Folder this item is in (optional)"
msgstr ""
#: allianceauth/menu/models.py:43
#: allianceauth/menu/models.py:42
msgid "is hidden"
msgstr ""
#: allianceauth/menu/models.py:45
#: allianceauth/menu/models.py:44
msgid ""
"Hide this menu item.If this item is a folder all items under it will be "
"hidden too"
msgstr ""
#: allianceauth/menu/models.py:60
#: allianceauth/menu/models.py:59
msgid "icon classes"
msgstr ""
#: allianceauth/menu/models.py:62
#: allianceauth/menu/models.py:61
msgid ""
"Font Awesome classes to show as icon on menu, e.g. <code>fa-solid fa-"
"house</code>"
msgstr ""
#: allianceauth/menu/models.py:68
#: allianceauth/menu/models.py:67
msgid "url"
msgstr ""
#: allianceauth/menu/models.py:69
#: allianceauth/menu/models.py:68
msgid "External URL this menu items will link to"
msgstr ""
@ -1466,63 +1427,44 @@ msgid "Add folder"
msgstr ""
#: allianceauth/menu/templates/menu/menu-notification-block.html:12
#: allianceauth/notifications/apps.py:8
#: allianceauth/notifications/templates/notifications/list.html:7
#: allianceauth/notifications/templates/notifications/list.html:11
#: allianceauth/templates/allianceauth/notifications_menu_item.html:6
msgid "Notifications"
msgstr "通知"
#: allianceauth/menu/templates/menu/menu-user.html:77
#: allianceauth/menu/templates/menu/menu-user.html:56
msgid "Super User"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:83
#: allianceauth/menu/templates/menu/menu-user.html:86
msgid "Alliance Auth Documentation"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:94
#: allianceauth/menu/templates/menu/menu-user.html:97
msgid "Alliance Auth Discord"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:105
#: allianceauth/menu/templates/menu/menu-user.html:108
msgid "Alliance Auth Git"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:118
#: allianceauth/menu/templates/menu/menu-user.html:121
#: allianceauth/menu/templates/menu/menu-user.html:70
#: allianceauth/templates/allianceauth/top-menu-admin.html:9
msgid "Admin"
msgstr "管理员"
#: allianceauth/menu/templates/menu/menu-user.html:144
#: allianceauth/menu/templates/menu/menu-user.html:147
#: allianceauth/menu/templates/menu/menu-user.html:82
msgid "Sign Out"
msgstr "登出"
msgstr ""
#: allianceauth/menu/templates/menu/menu-user.html:155
#: allianceauth/menu/templates/menu/menu-user.html:158
#: allianceauth/menu/templates/menu/menu-user.html:86
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:17
#: allianceauth/templates/allianceauth/top-menu-rh-default.html:18
msgid "Sign In"
msgstr "登入"
msgstr ""
#: allianceauth/notifications/models.py:22
#: allianceauth/notifications/models.py:21
msgid "danger"
msgstr "危险"
#: allianceauth/notifications/models.py:23
#: allianceauth/notifications/models.py:22
msgid "warning"
msgstr "警告"
#: allianceauth/notifications/models.py:24
#: allianceauth/notifications/models.py:23
msgid "info"
msgstr ""
#: allianceauth/notifications/models.py:25
#: allianceauth/notifications/models.py:24
msgid "success"
msgstr ""
@ -1552,7 +1494,7 @@ msgstr "标题"
#: allianceauth/notifications/templates/notifications/list_partial.html:28
msgid "No notifications."
msgstr "暂无通知"
msgstr ""
#: allianceauth/notifications/templates/notifications/view.html:5
#: allianceauth/notifications/templates/notifications/view.html:9
@ -1579,7 +1521,7 @@ msgstr "让所有通知都变成已读"
msgid "Deleted all read notifications."
msgstr "删除所有已读通知"
#: allianceauth/optimer/apps.py:8 allianceauth/optimer/auth_hooks.py:12
#: allianceauth/optimer/auth_hooks.py:12
msgid "Fleet Operations"
msgstr "起队搞事"
@ -1642,7 +1584,7 @@ msgstr ""
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:7
msgid "Upcoming Fleets"
msgstr "接下来的队"
msgstr ""
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:14
msgid "Operation"
@ -1653,6 +1595,11 @@ msgstr ""
msgid "Form Up System"
msgstr "集结点"
#: allianceauth/optimer/templates/optimer/dashboard.ops.html:17
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:18
msgid "EVE Time"
msgstr ""
#: allianceauth/optimer/templates/optimer/fleetoptable.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:13
msgid "Local Time"
@ -1668,8 +1615,8 @@ msgstr "管理搞事队"
#: allianceauth/optimer/templates/optimer/management.html:28
#: allianceauth/timerboard/templates/timerboard/view.html:32
msgid "Current EVE time:"
msgstr ""
msgid "Current Eve Time:"
msgstr "当前EVE游戏内时间"
#: allianceauth/optimer/templates/optimer/management.html:36
msgid "Next Fleet Operations"
@ -1713,7 +1660,6 @@ msgstr "移除了%(opname)s的搞事时间节点咕咕咕"
msgid "Saved changes to operation timer for %(opname)s."
msgstr "对搞事时间节点%(opname)s的修改保存了朝令夕改你是不是合格FC啊"
#: allianceauth/permissions_tool/apps.py:8
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:7
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:11
#: allianceauth/permissions_tool/templates/permissions_tool/audit.html:17
@ -1770,7 +1716,7 @@ msgstr "该服务账户仍然存在"
msgid "Successfully set your {self.service_name} password"
msgstr ""
#: allianceauth/services/apps.py:8 allianceauth/services/auth_hooks.py:12
#: allianceauth/services/auth_hooks.py:12
msgid "Services"
msgstr "服务"
@ -1834,10 +1780,6 @@ msgstr "密码"
msgid "Password must be at least 8 characters long."
msgstr "密码至少要有8个字符啊你也太不注重安全啦"
#: allianceauth/services/modules/discord/apps.py:8
msgid "Discord Service"
msgstr ""
#: allianceauth/services/modules/discord/models.py:187
msgid "Discord Account Disabled"
msgstr ""
@ -1851,17 +1793,17 @@ msgstr ""
#: allianceauth/services/modules/discord/templates/services/discord/discord_service_ctrl.html:26
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_service_ctrl.html:22
msgid "Activate"
msgstr "激活"
msgstr ""
#: allianceauth/services/modules/discord/templates/services/discord/discord_service_ctrl.html:32
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_service_ctrl.html:34
msgid "Reset Password"
msgstr "重置密码"
msgstr ""
#: allianceauth/services/modules/discord/templates/services/discord/discord_service_ctrl.html:38
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_service_ctrl.html:40
msgid "Deactivate"
msgstr "停用"
msgstr ""
#: allianceauth/services/modules/discord/templates/services/discord/discord_service_ctrl.html:45
msgid "Link Discord Server"
@ -1878,7 +1820,7 @@ msgstr "在处理你的Discord账户时出错。"
#: allianceauth/services/modules/discord/views.py:102
msgid "Your Discord account has been successfully activated."
msgstr "你的discord账户已成功停用"
msgstr ""
#: allianceauth/services/modules/discord/views.py:108
msgid ""
@ -1886,10 +1828,6 @@ msgid ""
"again."
msgstr ""
#: allianceauth/services/modules/discourse/apps.py:8
msgid "Discourse Service"
msgstr ""
#: allianceauth/services/modules/discourse/templates/services/discourse/discourse_service_ctrl.html:5
msgid "Discourse"
msgstr ""
@ -1921,14 +1859,6 @@ msgstr "没有在Seat上检测到SSO。如果该问题依然存在请联系
msgid "Invalid payload. Please contact support if this problem persists."
msgstr "无效的SSO验证。如果该问题依然存在请联系技术支持。"
#: allianceauth/services/modules/example/apps.py:8
msgid "Example Service"
msgstr ""
#: allianceauth/services/modules/ips4/apps.py:8
msgid "IPS4 Service"
msgstr ""
#: allianceauth/services/modules/ips4/views.py:31
msgid "Activated IPSuite4 account."
msgstr "完成激活IPSuite4账户"
@ -1952,10 +1882,6 @@ msgstr "修改IPSuite4密码"
msgid "Deactivated IPSuite4 account."
msgstr "停用IPSuite4账户"
#: allianceauth/services/modules/mumble/apps.py:8
msgid "Mumble Service"
msgstr ""
#: allianceauth/services/modules/mumble/templates/services/mumble/mumble_connection_history.html:7
msgid "Mumble"
msgstr ""
@ -2011,10 +1937,6 @@ msgstr ""
msgid "Mumble Connection History"
msgstr ""
#: allianceauth/services/modules/openfire/apps.py:8
msgid "Openfire Service"
msgstr ""
#: allianceauth/services/modules/openfire/auth_hooks.py:27
msgid "Jabber"
msgstr "Jabber"
@ -2066,10 +1988,6 @@ msgstr ""
msgid "Set jabber password."
msgstr "修改jabber密码"
#: allianceauth/services/modules/phpbb3/apps.py:8
msgid "phpBB3 Service"
msgstr ""
#: allianceauth/services/modules/phpbb3/views.py:34
msgid "Activated forum account."
msgstr "成功激活论坛账户"
@ -2093,10 +2011,6 @@ msgstr "重置论坛密码"
msgid "Set forum password."
msgstr "修改论坛密码"
#: allianceauth/services/modules/smf/apps.py:8
msgid "SMF Service"
msgstr ""
#: allianceauth/services/modules/smf/views.py:52
msgid "Activated SMF account."
msgstr "成功激活SMF论坛账户"
@ -2120,10 +2034,6 @@ msgstr "重置SMF密码"
msgid "Set SMF password."
msgstr "修改SMF论坛密码"
#: allianceauth/services/modules/teamspeak3/apps.py:8
msgid "TeamSpeak 3 Service"
msgstr ""
#: allianceauth/services/modules/teamspeak3/forms.py:14
#, python-format
msgid "Unable to locate user %s on server"
@ -2173,10 +2083,6 @@ msgstr "停用TeamSpeak3账户"
msgid "Reset TeamSpeak3 permission key."
msgstr "重置TeamSpeak3授权秘钥"
#: allianceauth/services/modules/xenforo/apps.py:8
msgid "Xenforo Service"
msgstr ""
#: allianceauth/services/modules/xenforo/views.py:30
msgid "Activated XenForo account."
msgstr "成功激活XenForo账户"
@ -2286,7 +2192,7 @@ msgid ""
"Some services provide different options. Hover over the buttons to see more."
msgstr ""
#: allianceauth/srp/apps.py:8 allianceauth/srp/auth_hooks.py:14
#: allianceauth/srp/auth_hooks.py:14
msgid "Ship Replacement"
msgstr "补损"
@ -2326,7 +2232,7 @@ msgstr "补损舰队创建"
#: allianceauth/srp/templates/srp/request.html:11
#: allianceauth/srp/templates/srp/update.html:11
msgid "Ship Replacement Program"
msgstr "补损"
msgstr ""
#: allianceauth/srp/templates/srp/add.html:20
msgid "Create SRP Fleet"
@ -2351,7 +2257,7 @@ msgstr "舰队补损信息"
#: allianceauth/srp/templates/srp/data.html:17
msgid "View Fleets"
msgstr "查看舰队"
msgstr ""
#: allianceauth/srp/templates/srp/data.html:26
msgid "Mark Incomplete"
@ -2362,18 +2268,18 @@ msgid "Mark Completed"
msgstr "标记为已完成"
#: allianceauth/srp/templates/srp/data.html:48
#: allianceauth/srp/templates/srp/data.html:142
#: allianceauth/srp/templates/srp/data.html:139
msgid "Total Losses:"
msgstr "损失总额:"
#: allianceauth/srp/templates/srp/data.html:49
#: allianceauth/srp/templates/srp/data.html:143
#: allianceauth/srp/templates/srp/data.html:140
#: allianceauth/srp/templates/srp/management.html:36
msgid "Total ISK Cost:"
msgstr "ISK花费总额"
#: allianceauth/srp/templates/srp/data.html:60
#: allianceauth/srp/templates/srp/data.html:154
#: allianceauth/srp/templates/srp/data.html:151
msgid "Are you sure you want to delete SRP requests?"
msgstr "老哥,你确定要删了补损请求么?"
@ -2405,12 +2311,12 @@ msgstr "点击数值就可以编辑啦按回车确认按ESC取消"
msgid "Post Time"
msgstr "发布时间"
#: allianceauth/srp/templates/srp/data.html:102
#: allianceauth/srp/templates/srp/data.html:99
#: allianceauth/srp/templates/srp/management.html:70
msgid "Link"
msgstr "链接"
#: allianceauth/srp/templates/srp/data.html:163
#: allianceauth/srp/templates/srp/data.html:160
msgid "No SRP requests for this fleet."
msgstr "这次起队没有补损请求!大捷"
@ -2468,11 +2374,11 @@ msgstr "创建补损请求"
#: allianceauth/srp/templates/srp/request.html:22
msgid "Your SRP request"
msgstr "你的补损请求"
msgstr ""
#: allianceauth/srp/templates/srp/request.html:35
msgid "Create SRP request"
msgstr "创建补损请求"
msgstr ""
#: allianceauth/srp/templates/srp/update.html:7
#: allianceauth/srp/templates/srp/update.html:16
@ -2481,7 +2387,7 @@ msgstr "上传战报链接"
#: allianceauth/srp/templates/srp/update.html:22
msgid "After Action Report"
msgstr "战报"
msgstr ""
#: allianceauth/srp/templates/srp/update.html:31
msgid "SRP Fleet Does Not Exist"
@ -2489,7 +2395,7 @@ msgstr "补损舰队不存在啊,老哥你在好好看看?"
#: allianceauth/srp/templates/srp/update.html:40
msgid "Update AAR link"
msgstr "更新战报链接"
msgstr ""
#: allianceauth/srp/views.py:85
#, python-format
@ -2594,48 +2500,52 @@ msgstr ""
msgid "Alliance Auth Notifications"
msgstr "系统通知"
#: allianceauth/templates/allianceauth/admin-status/overview.html:20
#: allianceauth/templates/allianceauth/admin-status/overview.html:18
msgid "Closed"
msgstr "已关闭"
#: allianceauth/templates/allianceauth/admin-status/overview.html:24
msgid "No notifications at this time"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:29
#: allianceauth/templates/allianceauth/admin-status/overview.html:33
msgid "Powered by GitLab"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:35
#: allianceauth/templates/allianceauth/admin-status/overview.html:39
msgid "Support Discord"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:49
#: allianceauth/templates/allianceauth/admin-status/overview.html:53
#: allianceauth/templates/allianceauth/admin-status/overview.html:57
msgid "Software Version"
msgstr "软件版本"
#: allianceauth/templates/allianceauth/admin-status/overview.html:56
#: allianceauth/templates/allianceauth/admin-status/overview.html:60
msgid "Current"
msgstr "当前版本"
#: allianceauth/templates/allianceauth/admin-status/overview.html:63
#: allianceauth/templates/allianceauth/admin-status/overview.html:67
msgid "Latest Stable"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:68
#: allianceauth/templates/allianceauth/admin-status/overview.html:72
msgid "Update available"
msgstr "有更新!"
#: allianceauth/templates/allianceauth/admin-status/overview.html:76
#: allianceauth/templates/allianceauth/admin-status/overview.html:80
msgid "Latest Pre-Release"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:81
#: allianceauth/templates/allianceauth/admin-status/overview.html:85
msgid "Pre-Release available"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:91
#: allianceauth/templates/allianceauth/admin-status/overview.html:95
msgid "Task Queue"
msgstr "任务队列"
#: allianceauth/templates/allianceauth/admin-status/overview.html:96
#: allianceauth/templates/allianceauth/admin-status/overview.html:100
#, python-format
msgid ""
"\n"
@ -2643,11 +2553,11 @@ msgid ""
" "
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:112
#: allianceauth/templates/allianceauth/admin-status/overview.html:116
msgid "running"
msgstr ""
#: allianceauth/templates/allianceauth/admin-status/overview.html:113
#: allianceauth/templates/allianceauth/admin-status/overview.html:117
msgid "queued"
msgstr ""
@ -2672,17 +2582,10 @@ msgstr "登出"
msgid "Toggle navigation"
msgstr "打开导航栏"
#: allianceauth/theme/templates/theme/theme_select.html:11
#: allianceauth/theme/templates/theme/theme_select.html:7
msgid "Select Theme"
msgstr ""
#: allianceauth/timerboard/apps.py:8
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "建筑时间表"
#: allianceauth/timerboard/form.py:36
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:14
#: allianceauth/timerboard/templates/timerboard/timertable.html:8
@ -2869,10 +2772,6 @@ msgstr "解锚"
msgid "Abandoned"
msgstr ""
#: allianceauth/timerboard/models.py:60
msgid "Theft"
msgstr ""
#: allianceauth/timerboard/templates/timerboard/dashboard.timers.html:7
#: allianceauth/timerboard/templates/timerboard/view.html:54
msgid "Upcoming Timers"
@ -2882,6 +2781,12 @@ msgstr ""
msgid "Timer"
msgstr ""
#: allianceauth/timerboard/templates/timerboard/form.html:10
#: allianceauth/timerboard/templates/timerboard/timer_confirm_delete.html:10
#: allianceauth/timerboard/templates/timerboard/view.html:14
msgid "Structure Timers"
msgstr "建筑时间表"
#: allianceauth/timerboard/templates/timerboard/form.html:25
msgid "Structure Timer Details"
msgstr ""

View File

@ -1,7 +1,6 @@
import logging
from django.apps import AppConfig
from django.utils.translation import gettext_lazy as _
logger = logging.getLogger(__name__)
@ -13,7 +12,6 @@ logger = logging.getLogger(__name__)
class MenuConfig(AppConfig):
name = "allianceauth.menu"
label = "menu"
verbose_name = _("Menu")
def ready(self):
from allianceauth.menu.core import smart_sync

View File

@ -1,18 +0,0 @@
# Generated by Django 5.1.6 on 2025-03-05 00:59
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('menu', '0001_initial'),
]
operations = [
migrations.AlterField(
model_name='menuitem',
name='hook_hash',
field=models.CharField(default=None, editable=False, help_text='hash of a menu item hook. Must be nullable for unique comparison.', max_length=64, null=True, unique=True),
),
]

View File

@ -1,4 +1,3 @@
from typing import ClassVar
from django.db import models
from django.utils.translation import gettext_lazy as _
@ -41,7 +40,10 @@ class MenuItem(models.Model):
is_hidden = models.BooleanField(
default=False,
verbose_name=_("is hidden"),
help_text=_("Hide this menu item." "If this item is a folder all items under it will be hidden too"),
help_text=_(
"Hide this menu item."
"If this item is a folder all items under it will be hidden too"
),
)
# app related properties
@ -51,7 +53,7 @@ class MenuItem(models.Model):
null=True,
unique=True,
editable=False,
help_text="hash of a menu item hook. Must be nullable for unique comparison.",
help_text="hash of a menu item hook. Must be nullable for unique comparison."
)
# user defined properties
@ -60,7 +62,10 @@ class MenuItem(models.Model):
default="",
blank=True,
verbose_name=_("icon classes"),
help_text=_("Font Awesome classes to show as icon on menu, " "e.g. <code>fa-solid fa-house</code>"),
help_text=_(
"Font Awesome classes to show as icon on menu, "
"e.g. <code>fa-solid fa-house</code>"
),
)
url = models.TextField(
default="",
@ -68,12 +73,12 @@ class MenuItem(models.Model):
help_text=_("External URL this menu items will link to"),
)
objects: ClassVar[MenuItemManager] = MenuItemManager()
objects = MenuItemManager()
def __str__(self) -> str:
return self.text
def save(self, *args, **kwargs) -> None:
def save(self, *args, **kwargs):
if not self.hook_hash:
self.hook_hash = None # empty strings can create problems
return super().save(*args, **kwargs)
@ -119,12 +124,14 @@ class MenuItem(models.Model):
if self.is_app_item:
raise ValueError("The related hook objects should be used for app items.")
hook_obj = MenuItemHookCustom(text=self.text, classes=self.classes, url_name="", order=self.order)
hook_obj = MenuItemHookCustom(
text=self.text, classes=self.classes, url_name="", order=self.order
)
hook_obj.navactive = []
if self.is_folder and not self.classes:
hook_obj.classes = DEFAULT_FOLDER_ICON_CLASSES
hook_obj.url = self.url
hook_obj.is_folder = self.is_folder
hook_obj.html_id = f"id-folder-{self.pk}" if self.is_folder else ""
hook_obj.html_id = f"id-folder-{self.id}" if self.is_folder else ""
return hook_obj

View File

@ -27,7 +27,7 @@
</a>
{% if item.count >= 1 %}
<span class="badge text-bg-primary m-2 align-self-center{% if not item.is_folder %} me-2{% endif %}">
<span class="badge bg-primary m-2 align-self-center{% if not item.is_folder %} me-2{% endif %}">
{{ item.count }}
</span>
{% elif item.url %}

Some files were not shown because too many files have changed in this diff Show More