Merge branch 'develop' into beta

This commit is contained in:
ThatOneCalculator 2023-08-01 22:44:02 -07:00
commit b03bb28a98
No known key found for this signature in database
GPG Key ID: 8703CACD01000000
166 changed files with 6351 additions and 2784 deletions

View File

@ -34,7 +34,7 @@ port: 3000
#───┘ PostgreSQL configuration └────────────────────────────────
db:
host: database
host: postgres
port: 5432
# Database name

View File

@ -29,6 +29,10 @@ url: https://example.com/
# The port that your Firefish server should listen on.
port: 3000
# The bind host your Firefish server should listen on.
# If unspecified, the wildcard address will be used.
#bind: 127.0.0.1
# ┌──────────────────────────┐
#───┘ PostgreSQL configuration └────────────────────────────────

1
.gitignore vendored
View File

@ -1,6 +1,7 @@
# Visual Studio Code
/.vscode
!/.vscode/extensions.json
!/.vscode/launch.json
# Intelij-IDEA
/.idea

68
.gitlab-ci.yml Normal file
View File

@ -0,0 +1,68 @@
# This file is a template, and might need editing before it works on your project.
# You can copy and paste this template into a new `.gitlab-ci.yml` file.
# You should not add this template to an existing `.gitlab-ci.yml` file by using the `include:` keyword.
#
# To contribute improvements to CI/CD templates, please follow the Development guide at:
# https://docs.gitlab.com/ee/development/cicd/templates.html
# This specific template is located at:
# https://gitlab.com/gitlab-org/gitlab/-/blob/master/lib/gitlab/ci/templates/Nodejs.gitlab-ci.yml
# Official framework image. Look for the different tagged releases at:
# https://hub.docker.com/r/library/node/tags/
image: node:alpine
stages:
- build
# Pick zero or more services to be used on all builds.
# Only needed when using a docker container to run your tests in.
# Check out: https://docs.gitlab.com/ee/ci/services/index.html
variables:
POSTGRES_PASSWORD: test
# POSTGRES_DB: $POSTGRES_DB
# POSTGRES_USER: $POSTGRES_USER
# POSTGRES_PASSWORD: $POSTGRES_PASSWORD
# POSTGRES_HOST_AUTH_METHOD: trust
services:
- postgres:15
- redis
before_script:
- apk add --no-cache cargo python3 make g++
- cp .config/ci.yml .config/default.yml
- corepack enable
- corepack prepare pnpm@latest --activate
testCommit:
stage: build
script:
- pnpm i --frozen-lockfile
- pnpm run build:debug
- pnpm run migrate
only:
- main
- beta
- develop
- /^feature\/.*$/
dockerPush:
stage: .post
image: docker:latest
services:
- docker:dind
script:
- docker build -t $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG .
- echo $CI_JOB_TOKEN | docker login -u $CI_REGISTRY_USER --password-stdin $CI_REGISTRY
- docker push $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
only:
- main
- beta
# This folder is cached between builds
# https://docs.gitlab.com/ee/ci/yaml/index.html#cache
cache:
paths:
- node_modules/
- packages/*/node_modules/
- packages/backend/native-utils/node_modules/

View File

@ -0,0 +1,29 @@
<!-- 💖 Thanks for taking the time to fill out this bug report!
💁 Having trouble with deployment? [Ask the support chat.](https://matrix.to/#/%23firefish:matrix.fedibird.com)
🔒 Found a security vulnerability? [Please disclose it responsibly.](https://git.joinfirefish.org/firefish/firefish/src/branch/develop/SECURITY.md)
🤝 By submitting this issue, you agree to follow our [Contribution Guidelines.](https://git.joinfirefish.org/firefish/firefish/-/blob/develop/CONTRIBUTING.md) -->
**What happened?** _(Please give us a brief description of what happened.)_
**What did you expect to happen?** _(Please give us a brief description of what you expected to happen.)_
**Version** _(What version of firefish is your instance running? You can find this by clicking your instance's logo at the bottom left and then clicking instance information.)_
**Instance** _(What instance of firefish are you using?)_
**What type of issue is this?** _(If this happens on your device and has to do with the user interface, it's client-side. If this happens on either with the API or the backend, or you got a server-side error in the client, it's server-side.)_
**What browser are you using? (Client-side issues only)**
**What operating system are you using? (Client-side issues only)**
**How do you deploy Firefish on your server? (Server-side issues only)**
**What operating system are you using? (Server-side issues only)**
**Relevant log output** _(Please copy and paste any relevant log output. You can find your log by inspecting the page, and going to the "console" tab. This will be automatically formatted into code, so no need for backticks.)_
**Contribution Guidelines**
By submitting this issue, you agree to follow our [Contribution Guidelines](https://git.joinfirefish.org/firefish/firefish/-/blob/develop/CONTRIBUTING.md)
- [ ] I agree to follow this project's Contribution Guidelines
- [ ] I have searched the issue tracker for similar issues, and this is not a duplicate.

View File

@ -0,0 +1,17 @@
<!-- 💖 Thanks for taking the time to fill out this bug report!
💁 Having trouble with deployment? [Ask the support chat.](https://matrix.to/#/%23firefish:matrix.fedibird.com)
🔒 Found a security vulnerability? [Please disclose it responsibly.](https://git.joinfirefish.org/firefish/firefish/src/branch/develop/SECURITY.md)
🤝 By submitting this feature request, you agree to follow our [Contribution Guidelines.](https://git.joinfirefish.org/firefish/firefish/-/blob/develop/CONTRIBUTING.md) -->
**What feature would you like implemented?** _(Please give us a brief description of what you'd like.)_
**Why should we add this feature?** _(Please give us a brief description of why your feature is important.)_
**Version** _(What version of firefish is your instance running? You can find this by clicking your instance's logo at the bottom left and then clicking instance information.)_
**Instance** _(What instance of firefish are you using?)_
**Contribution Guidelines**
By submitting this issue, you agree to follow our [Contribution Guidelines](https://git.joinfirefish.org/firefish/firefish/-/blob/develop/CONTRIBUTING.md)
- [ ] I agree to follow this project's Contribution Guidelines
- [ ] I have searched the issue tracker for similar requests, and this is not a duplicate.

View File

@ -0,0 +1,9 @@
<!-- Thanks for taking the time to make Firefish better! It's not required, but please consider using [Conventional Commits](https://www.conventionalcommits.org/en/v1.0.0/) when making your commits. If you use VSCode, please use the [Conventional Commits extension](https://marketplace.visualstudio.com/items?itemName=vivaxy.vscode-conventional-commits). -->
**What does this PR do?** _(Please give us a brief description of what this PR does.)_
**Contribution Guidelines**
By submitting this issue, you agree to follow our [Contribution Guidelines](https://git.joinfirefish.org/firefish/firefish/-/blob/develop/CONTRIBUTING.md)
- [ ] I agree to follow this project's Contribution Guidelines
- [ ] I have made sure to test this pull request
- [ ] I have made sure to run `pnpm run format` before submitting this pull request

20
.vscode/launch.json vendored Normal file
View File

@ -0,0 +1,20 @@
{
// Use IntelliSense to learn about possible attributes.
// Hover to view descriptions of existing attributes.
// For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
"version": "0.2.0",
"configurations": [
{
"type": "node",
"request": "launch",
"name": "Launch PNPM Debug Script",
"skipFiles": [
"<node_internals>/**"
],
"runtimeExecutable": "pnpm",
"runtimeArgs": [
"run", "debug"
]
}
]
}

View File

@ -67,7 +67,7 @@ Closes #10313
- Fix: :bug: don't convert time since epoch for ratelimit
https://calckey.social/notes/9gkasnzglmi07rpa
https://firefish.social/notes/9gkasnzglmi07rpa
- Fix: :bug: fix tapping parent on mobile causing side effects
@ -1834,7 +1834,7 @@ Closes #9843
- Fix: :recycle: use locale for error
https://calckey.social/notes/9fippqiwhl287b5m
https://firefish.social/notes/9fippqiwhl287b5m
- Fix mfm-cheat-sheet styling
@ -14998,3 +14998,65 @@ Co-authored-by: Johann150 <johann@qwertqwefsday.eu>
<!-- generated by git-cliff -->
## FoundKey
In the commits above, a few of these changes were added from [FoundKey](https://akkoma.dev/FoundKeyGang/FoundKey), although the majority have been refactored. Below is a historical list of all commits that were cherry picked:
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/0ece67b04c3f0365057624c1068808276ccab981: refactor pages/auth.form.vue to composition API
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/4bc9610d8bf5af736b5e89e4782395705de45d7d: remove unnecessary joins
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/9ee609d70082f7a6dc119a5d83c0e7c5e1208676: enhance privacy of notes
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/0fec6e10477b1c1b95d9469fbaf4e249a3722f12: remove ms dependency
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/46fff77accbe8bf0fd3cc88170d67b997bf2bdc3: client uses new API for child notes depth
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/c35372a20d22cddb75e93a0b407f2b652cd7faf0: pack children without detail
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/aca724e0bfff3e58b4d273f3ee744e3f3aa9c39b: enable to fetch replies recursively
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/2fe64c11502fd8d89c126558cd715e095c83754e: Refactor components/page/page.textarea.vue to composition API
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/6d3181f9835955e5b79bde5484c74bd70e7f9535: Refactor components/page/page.text.vue to composition API
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/b630cd7eacd695bb705e6748c87f38425ec4ed45: refactor: add NoteReactions.packMany
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/3fe351df6d4e21f7748c46adfa6ca165abd030c0: fix: catch errors from packing with detail
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/63591da33e233b2ed0ab331ae6bb3c9eff5020ae: refactor: colours in queue chart
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/0f6d94f1e7e1f58cfbf8d07e5f835f8de626842e: backend: improve mutes and blocks
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/e2bf2715a6462ed377b033956d65260157f042ea: fix spelling error
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/09a7eabda137e77f81ab31f65d69329670693c8d: backend: fix lint "no-throw-literal"
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/4fbe2e065e75ed3e5b4dfdfd4be3baa03cc447c3: client: fix lint "quotes"
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/585e4f5c42cfafb6cdf7eb601ab435d6a4d85a96: fix textarea not updating properly
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/30d8bc9259cb6b72ed76d67b21dbb4cdceca8327: refactor: welcome.setup.vue to composition api
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/751921e24f37ed707fe44a40d88eebb1299efa35: make emoji picker case insensitive
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/298febeb9c9501e3e3df16982c08657d1da474e0: enhance: add re-collapsing to quoted notes
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/b0fdedb264db87575063abed45e52ad71ce4a6af: fix lints in folder.vue
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/6fed87f85d132304eb84b0a59b84dce299a1822f: fix pagination.vue lints
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/384e8c49b738f576ba8843296de6cebf01c1b247: server: allow to like own gallery posts
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/4c5aa9e53887cca5561fcec6ab0754e018f589a5: server: allow to like own pages
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/923c93da1228458dd65be47483c198a1a9191bcf: use await for notes.countBy
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/ca90cedba0a0704b503c2778694230f5a7dfbace: server: reduce dead instance detection to 7 days
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/e9ab42c10afb4e27516c2d2b5e3e06630efe9edd: Alt text in image viewer
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/ed9d4023d41bba7c4ac53a1a3422246feed37de2: add argon2 support
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/c414f24a2c123774246c7eca65edda4d3afaf8b3: feat: per-user renote muting

View File

@ -2,7 +2,7 @@
We're glad you're interested in contributing Firefish! In this document you will find the information you need to contribute to the project.
## Translation (i18n)
Firefish uses [Weblate](hhttps://hosted.weblate.org/engage/firefish/) for translation and internationalization management.
Firefish uses [Weblate](https://hosted.weblate.org/engage/firefish/) for translation and internationalization management.
If your language is not listed in Weblate, please open an issue.
@ -12,9 +12,6 @@ You can contribute without knowing how to code by helping translate here:
[![Translation bars](https://hosted.weblate.org/widgets/firefish/-/multi-auto.svg)](https://hosted.weblate.org/engage/firefish/)
## Roadmap
See [FIREFISH.md](./FIREFISH.md)
## Issues
Before creating an issue, please check the following:
- To avoid duplication, please search for similar issues before creating a new issue.

View File

@ -1,166 +0,0 @@
# All the changes to Firefish from stock Misskey
> **Warning**
> This list is incomplete. Please check the [Releases](https://git.joinfirefish.org/firefish/firefish/releases) and [Changelog](https://git.joinfirefish.org/firefish/firefish/src/branch/develop/CHANGELOG.md) for a more complete list of changes. There have been [>4000 commits (laggy link)](https://git.joinfirefish.org/firefish/firefish/compare/700a7110f7e34f314b070987aa761c451ec34efc...develop) since we forked Misskey!
## Planned
- Stucture
- Rewrite backend in Rust and [Rocket](https://rocket.rs/)
- Function
- User "choices" (recommended users) and featured hashtags like Mastodon and Soapbox
- Join Reason system like Mastodon/Pleroma
- Option to publicize server blocks
- More antenna options
- Groups
## Work in progress
- Better Messaging UI
- Better API Documentation
- Remote follow button
- Improve accesibility
- Timeline filters
- Events
- Fully revamp non-logged-in screen
- Optionally use [ScyllaDB](https://www.scylladb.com/open-source-nosql-database/) for storing notes
## Implemented
- A lot of general bugfixes
- pnpm instead of yarn
- Fix Dockerfile @hanna
- Upgrade packages with security vunrabilities
- Saner defaults
- Fediverse account migration
- Recommended servers timeline
- OCR image captioning
- Improve mobile UX
- Swipe through pages on mobile
- Redesigned mobile bottom nav bar
- Post button on TL
- Star as default reaction
- Like/star button
- Rosé Pine by default (+ non-themable elements made Rosé Pine)
- Better sidebar/navbar
- Better intro tutorial/onboarding
- Add back groups
- Integrate groups UI into chats UI
- MOTD (customizable by admins!)
- Custom randomized splash icons
- Self hosted, newly designed error images
- Illustrated by [Henki](https://www.youtube.com/c/Henkiwashere)!
- Licensed under the CC-BY-SA 4.0.
- Better timeline top bar
- Improved note style
- Make more of the post clickable like every other SNS
- No more details tag for reply attachments
- Better CW button
- Mark as read from notifications widget
- Less cluttered notification summary
- Better welcome screen (not logged in)
- vue-plyr as video/audio player
- Ability to turn off "Connection lost" message
- Raw server info only for moderators
- New spinner animation
- Spinner instead of "Loading..."
- Always signToActivityPubGet
- Spacing on group items
- Quotes have solid border
- Reply limit bug fixed
- Make showing the update popup optional
- Improve PWA manifest
- Fix incoming chat scrolling globally
- Update notifier
- Allow admins to set logo URL via admin settings
- Allow importing follows from Pixelfed
- Phosphor icons instead of FontAwesome
- Fully deprecate MkEmojiPickerWindow in favor of MkEmojiPickerDialog
- Link hover effect
- Replace all `$ts` with i18n
- AVIF support
- Page drafts
- Patron list
- Animations respect reduced motion
- Undo renote button inside original note
- Custom locales
- Obliteration of Ai-chan
- Switch to [Firefish.js](https://git.joinfirefish.org/firefish/firefish.js)
- Woozy mode 🥴
- Improve blocking servers
- Release notes
- New post style
- Admins set default reaction emoji
- Allows custom emoji
- Fix lint errors
- Use Rome instead of ESLint
- Mastodon API support
- More antenna options
- New dashboard
- Backfill follower counts
- Compile time compression
- Sonic search
- Popular color schemes, including Nord, Gruvbox, and Catppuccin
- Non-nyaify cat mode
- Post imports from other Firefish/Misskey/Mastodon/Pleroma/Akkoma servers
- Improve Classic mode
- Proper Helm/Kubernetes config
- Multiple boost visibilities
- Improve system emails
- Mod mail
- Focus trapping and button labels
- Meilisearch with filters
- Post editing
- Display remaining time on rate-limits
- Proper 2FA input dialog
- Let moderators see moderation nodes
- Non-mangled unicode emojis
- Skin tone selection support
- [DragonflyDB](https://dragonflydb.io/) support as a Redis alternative
- Link verification
- Importing posts from other Firefish/Misskey/Mastodon/Akkoma/Pleroma instances
## Implemented (remote)
- MissV: [fix Misskey Forkbomb](https://code.vtopia.live/Vtopia/MissV/commit/40b23c070bd4adbb3188c73546c6c625138fb3c1)
- [Make showing ads optional](https://github.com/misskey-dev/misskey/pull/8996)
- [Tapping avatar in mobile opens account modal](https://github.com/misskey-dev/misskey/pull/9056)
- [OAuth bearer token authentication](https://github.com/misskey-dev/misskey/pull/9021)
- [Styled Repair Tools](https://github.com/misskey-dev/misskey/pull/8956)
- [Option to make enter send message](https://github.com/misskey-dev/misskey/pull/8954)
- [Autocomplete in messaging](https://github.com/misskey-dev/misskey/pull/8955)
- [Profile background as banner](https://codeberg.org/Freeplay/Misskey-Tweaks/src/branch/main/snippets/profile-background.styl)
- [Star is generic like/favorite](https://github.com/JakeMBauer/Misskey-Extras/blob/master/patches/star-is-like.patch)
- 👍 also triggers generic like/favorite
- [Add additional background for acrylic popups if backdrop-filter is unsupported](https://github.com/misskey-dev/misskey/pull/8671)
- [Add parameters to MFM rotate](https://github.com/misskey-dev/misskey/pull/8549)
- Many changes from [FoundKey](https://akkoma.dev/FoundKeyGang/FoundKey)
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/0ece67b04c3f0365057624c1068808276ccab981: refactor pages/auth.form.vue to composition API
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/4bc9610d8bf5af736b5e89e4782395705de45d7d: remove unnecessary joins
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/9ee609d70082f7a6dc119a5d83c0e7c5e1208676: enhance privacy of notes
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/0fec6e10477b1c1b95d9469fbaf4e249a3722f12: remove ms dependency
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/46fff77accbe8bf0fd3cc88170d67b997bf2bdc3: client uses new API for child notes depth
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/c35372a20d22cddb75e93a0b407f2b652cd7faf0: pack children without detail
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/aca724e0bfff3e58b4d273f3ee744e3f3aa9c39b: enable to fetch replies recursively
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/2fe64c11502fd8d89c126558cd715e095c83754e: Refactor components/page/page.textarea.vue to composition API
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/6d3181f9835955e5b79bde5484c74bd70e7f9535: Refactor components/page/page.text.vue to composition API
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/b630cd7eacd695bb705e6748c87f38425ec4ed45: refactor: add NoteReactions.packMany
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/3fe351df6d4e21f7748c46adfa6ca165abd030c0: fix: catch errors from packing with detail
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/63591da33e233b2ed0ab331ae6bb3c9eff5020ae: refactor: colours in queue chart
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/0f6d94f1e7e1f58cfbf8d07e5f835f8de626842e: backend: improve mutes and blocks
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/e2bf2715a6462ed377b033956d65260157f042ea: fix spelling error
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/09a7eabda137e77f81ab31f65d69329670693c8d: backend: fix lint "no-throw-literal"
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/4fbe2e065e75ed3e5b4dfdfd4be3baa03cc447c3: client: fix lint "quotes"
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/585e4f5c42cfafb6cdf7eb601ab435d6a4d85a96: fix textarea not updating properly
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/30d8bc9259cb6b72ed76d67b21dbb4cdceca8327: refactor: welcome.setup.vue to composition api
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/751921e24f37ed707fe44a40d88eebb1299efa35: make emoji picker case insensitive
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/298febeb9c9501e3e3df16982c08657d1da474e0: enhance: add re-collapsing to quoted notes
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/b0fdedb264db87575063abed45e52ad71ce4a6af: fix lints in folder.vue
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/6fed87f85d132304eb84b0a59b84dce299a1822f: fix pagination.vue lints
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/384e8c49b738f576ba8843296de6cebf01c1b247: server: allow to like own gallery posts
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/4c5aa9e53887cca5561fcec6ab0754e018f589a5: server: allow to like own pages
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/923c93da1228458dd65be47483c198a1a9191bcf: use await for notes.countBy
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/ca90cedba0a0704b503c2778694230f5a7dfbace: server: reduce dead instance detection to 7 days
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/e9ab42c10afb4e27516c2d2b5e3e06630efe9edd: Alt text in image viewer
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/ed9d4023d41bba7c4ac53a1a3422246feed37de2: add argon2 support
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/c414f24a2c123774246c7eca65edda4d3afaf8b3: feat: per-user renote muting

View File

@ -23,7 +23,6 @@
- Firefish is based off of Misskey, a powerful microblogging server on ActivityPub with features such as emoji reactions, a customizable web UI, rich chatting, and much more!
- Firefish adds many quality of life changes and bug fixes for users and server admins alike.
- Read **[this document](./FIREFISH.md)** all for current and future differences.
- Notable differences:
- Improved UI/UX (especially on mobile)
- Post editing
@ -40,7 +39,9 @@
- Backfill user information
- Advanced search
- Many more user and admin settings
- [So much more!](./FIREFISH.md)
- Many bug fixes and performance improvements
- Link verification
- So much more!
</div>
@ -64,7 +65,7 @@
- Donate publicly to get your name on the Patron list!
- 🚢 Flagship server: <https://firefish.social>
- 💁 Matrix support room: <https://matrix.to/#/#firefish:matrix.fedibird.com>
- 📣 Official account: <https://i.firefish.cloud/@firefish>
- 📣 Official account: <a href="https://fedi.software/@firefish" rel="me">@firefish</a>
- 📜 Server list: <https://joinfirefish.org/join>
- ✍️ Weblate: <https://hosted.weblate.org/engage/firefish/>
- ️️📬 Contact: <https://joinfirefish.org/contact/>
@ -85,9 +86,7 @@ This guide will work for both **starting from scratch** and **migrating from Mis
If you have access to a server that supports one of the sources below, I recommend you use it! Note that these methods *won't* allow you to migrate from Misskey without manual intervention.
<!-- [![Install on the Arch User Repository](https://pool.jortage.com/voringme/misskey/ba2a5c07-f078-43f1-8483-2e01acca9c40.png)](https://aur.archlinux.org/packages/firefish)   -->
[![Install on Ubuntu](https://pool.jortage.com/voringme/misskey/3b62a443-1b44-45cf-8f9e-f1c588f803ed.png)](https://gitlab.prometheus.systems/firefish/ubuntu-bash-install)  [![Install Firefish with YunoHost](https://install-app.yunohost.org/install-with-yunohost.svg)](https://install-app.yunohost.org/?app=firefish)
[![Install on Ubuntu](https://pool.jortage.com/voringme/misskey/3b62a443-1b44-45cf-8f9e-f1c588f803ed.png)](https://git.joinfirefish.org/firefish/ubuntu-bash-install)  [![Install on the Arch User Repository](https://pool.jortage.com/voringme/misskey/ba2a5c07-f078-43f1-8483-2e01acca9c40.png)](https://aur.archlinux.org/packages/firefish)  [![Install Firefish with YunoHost](https://install-app.yunohost.org/install-with-yunohost.svg)](https://install-app.yunohost.org/?app=firefish)
## 🛳️ Containerization

View File

@ -1,13 +0,0 @@
# Replace example.tld with your domain
<VirtualHost *:80>
ServerName example.tld
# For WebSocket
ProxyPass "/streaming" "ws://127.0.0.1:3000/streaming/"
# Proxy to Node
ProxyPass "/" "http://127.0.0.1:3000/"
ProxyPassReverse "/" "http://127.0.0.1:3000/"
ProxyPreserveHost On
# For files proxy
AllowEncodedSlashes On
</VirtualHost>

View File

@ -53,7 +53,7 @@ A fun, new, open way to experience social media https://joinfirefish.org
| elasticsearch | object | `{"auth":{},"enabled":false,"hostname":"","port":9200,"ssl":false}` | https://github.com/bitnami/charts/tree/master/bitnami/elasticsearch#parameters |
| fullnameOverride | string | `""` | |
| image.pullPolicy | string | `"IfNotPresent"` | |
| image.repository | string | `"docker.io/thatonecalculator/firefish"` | |
| image.repository | string | `"registry.joinfirefish.org/firefish/firefish"` | |
| image.tag | string | `""` | |
| imagePullSecrets | list | `[]` | |
| ingress.annotations | object | `{}` | |

View File

@ -5,7 +5,7 @@
replicaCount: 1
image:
repository: docker.io/thatonecalculator/firefish
repository: registry.joinfirefish.org/firefish/firefish
pullPolicy: IfNotPresent
# Overrides the image tag whose default is the chart appVersion.
tag: ""

Binary file not shown.

Before

Width:  |  Height:  |  Size: 57 KiB

After

Width:  |  Height:  |  Size: 40 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 55 KiB

After

Width:  |  Height:  |  Size: 9.9 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 56 KiB

After

Width:  |  Height:  |  Size: 9.1 KiB

View File

@ -2,7 +2,7 @@ version: "3"
services:
web:
image: docker.io/thatonecalculator/firefish
image: registry.joinfirefish.org/firefish/firefish
build: ..
container_name: firefish_web
restart: always

View File

@ -2,7 +2,7 @@ version: "3"
services:
web:
image: docker.io/thatonecalculator/firefish
image: registry.joinfirefish.org/firefish/firefish
container_name: firefish_web
restart: unless-stopped
depends_on:

View File

@ -1,7 +1,7 @@
# 🐳 Running a Firefish server with Docker
## Pre-built docker container
[thatonecalculator/firefish](https://hub.docker.com/r/thatonecalculator/firefish)
[registry.joinfirefish.org/firefish/firefish](https://git.joinfirefish.org/firefish/firefish/container_registry)
## `docker-compose`
@ -29,7 +29,7 @@ Everything else can be left as-is.
## Running docker-compose
The [prebuilt container for firefish](https://hub.docker.com/r/thatonecalculator/firefish) is fairly large, and may take a few minutes to download and extract using docker.
The [prebuilt container for firefish](https://git.joinfirefish.org/firefish/firefish/container_registry) is fairly large, and may take a few minutes to download and extract using docker.
Copy `docker-compose.yml` and the `config/` to a directory, then run the **docker-compose** command:
`docker-compose up -d`.

View File

@ -1,136 +0,0 @@
name: 🐛 Bug Report
about: File a bug report
title: "[Bug]: "
blank_issues_enabled: true
contact_links:
- name: 💁 Support Matrix
url: https://matrix.to/#/%23firefish:matrix.fedibird.com
about: Having trouble with deployment? Ask the support chat.
- name: 🔒 Resposible Disclosure
url: https://git.joinfirefish.org/firefish/firefish/src/branch/develop/SECURITY.md
about: Found a security vulnerability? Please disclose it responsibly.
body:
- type: markdown
attributes:
value: |
💖 Thanks for taking the time to fill out this bug report!
💁 Having trouble with deployment? [Ask the support chat.](https://matrix.to/#/%23firefish:matrix.fedibird.com)
🔒 Found a security vulnerability? [Please disclose it responsibly.](https://git.joinfirefish.org/firefish/firefish/src/branch/develop/SECURITY.md)
🤝 By submitting this issue, you agree to follow our [Contribution Guidelines.](https://git.joinfirefish.org/firefish/firefish/src/branch/develop/CONTRIBUTING.md)
- type: textarea
id: what-happened
attributes:
label: What happened?
description: Please give us a brief description of what happened.
placeholder: Tell us what you see!
validations:
required: true
- type: textarea
id: what-is-expected
attributes:
label: What did you expect to happen?
description: Please give us a brief description of what you expected to happen.
placeholder: Tell us what you wish happened!
validations:
required: true
- type: input
id: version
attributes:
label: Version
description: What version of firefish is your instance running? You can find this by clicking your instance's logo at the bottom left and then clicking instance information.
placeholder: v13.1.4.1
validations:
required: true
- type: input
id: instance
attributes:
label: Instance
description: What instance of firefish are you using?
placeholder: firefish.social
validations:
required: false
- type: dropdown
id: issue-type
attributes:
label: What type of issue is this?
description: If this happens on your device and has to do with the user interface, it's client-side. If this happens on either with the API or the backend, or you got a server-side error in the client, it's server-side.
multiple: false
options:
- Client-side
- Server-side
- Other (Please Specify)
- type: dropdown
id: browsers
attributes:
label: What browser are you using? (Client-side issues only)
multiple: false
options:
- N/A
- Firefox
- Chrome
- Brave
- Librewolf
- Chromium
- Safari
- Microsoft Edge
- Other (Please Specify)
- type: dropdown
id: device
attributes:
label: What operating system are you using? (Client-side issues only)
multiple: false
options:
- N/A
- Windows
- MacOS
- Linux
- Android
- iOS
- Other (Please Specify)
- type: dropdown
id: deplotment-method
attributes:
label: How do you deploy Firefish on your server? (Server-side issues only)
multiple: false
options:
- N/A
- Manual
- Ubuntu Install Script
- Docker Compose
- Docker Prebuilt Image
- Helm Chart
- YunoHost
- AUR Package
- Other (Please Specify)
- type: dropdown
id: operating-system
attributes:
label: What operating system are you using? (Server-side issues only)
multiple: false
options:
- N/A
- Ubuntu >= 22.04
- Ubuntu < 22.04
- Debian
- Arch
- RHEL (CentOS/AlmaLinux/Rocky Linux)
- FreeBSD
- OpenBSD
- Android
- Other (Please Specify)
- type: textarea
id: logs
attributes:
label: Relevant log output
description: Please copy and paste any relevant log output. You can find your log by inspecting the page, and going to the "console" tab. This will be automatically formatted into code, so no need for backticks.
render: shell
- type: checkboxes
id: terms
attributes:
label: Contribution Guidelines
description: By submitting this issue, you agree to follow our [Contribution Guidelines](https://git.joinfirefish.org/firefish/firefish/src/branch/develop/CONTRIBUTING.md)
options:
- label: I agree to follow this project's Contribution Guidelines
required: true
- label: I have searched the issue tracker for similar issues, and this is not a duplicate.
required: true

View File

@ -1,61 +0,0 @@
name: ✨ Feature Request
about: Request a Feature
title: "[Feature]: "
blank_issues_enabled: true
contact_links:
- name: 💁 Support Matrix
url: https://matrix.to/#/%23firefish:matrix.fedibird.com
about: Having trouble with deployment? Ask the support chat.
- name: 🔒 Resposible Disclosure
url: https://git.joinfirefish.org/firefish/firefish/src/branch/develop/SECURITY.md
about: Found a security vulnerability? Please disclose it responsibly.
body:
- type: markdown
attributes:
value: |
💖 Thanks for taking the time to fill out this feature request!
💁 Having trouble with deployment? [Ask the support chat.](https://matrix.to/#/%23firefish:matrix.fedibird.com)
🔒 Found a security vulnerability? [Please disclose it responsibly.](https://git.joinfirefish.org/firefish/firefish/src/branch/develop/SECURITY.md)
🤝 By submitting this issue, you agree to follow our [Contribution Guidelines.](https://git.joinfirefish.org/firefish/firefish/src/branch/develop/CONTRIBUTING.md)
- type: textarea
id: what-feature
attributes:
label: What feature would you like implemented?
description: Please give us a brief description of what you'd like.
placeholder: Tell us what you want!
validations:
required: true
- type: textarea
id: why-add-feature
attributes:
label: Why should we add this feature?
description: Please give us a brief description of why your feature is important.
placeholder: Tell us why you want this feature!
validations:
required: true
- type: input
id: version
attributes:
label: Version
description: What version of firefish is your instance running? You can find this by clicking your instance's logo at the bottom left and then clicking instance information.
placeholder: Firefish Version 13.1.4.1
validations:
required: true
- type: input
id: instance
attributes:
label: Instance
description: What instance of firefish are you using?
placeholder: firefish.social
validations:
required: false
- type: checkboxes
id: terms
attributes:
label: Contribution Guidelines
description: By submitting this issue, you agree to follow our [Contribution Guidelines](https://git.joinfirefish.org/firefish/firefish/src/branch/develop/CONTRIBUTING.md)
options:
- label: I agree to follow this project's Contribution Guidelines
required: true
- label: I have searched the issue tracker for similar requests, and this is not a duplicate.
required: true

View File

@ -1,7 +1,7 @@
---
_lang_: "العربية"
headlineMisskey: "شبكة مرتبطة بالملاحظات"
introMisskey: "اهلا بك! ميسكي هو منصة تدوين مصغر لا مركزية ومفتوحة المصدر.\nيمكنك مشاركة \"ملاحظات\" عن ما يجري حولك، وإخبار الجميع عن نفسك 📡\nتسمح لك \"الانفعالات\" بتعبير عن شعورك حول ملاحظات الآخرين 👍\nاكتشف عالمًا جديدًا 🚀"
headlineFirefish: "شبكة مرتبطة بالملاحظات"
introFirefish: "اهلا بك! ميسكي هو منصة تدوين مصغر لا مركزية ومفتوحة المصدر.\nيمكنك مشاركة \"ملاحظات\" عن ما يجري حولك، وإخبار الجميع عن نفسك 📡\nتسمح لك \"الانفعالات\" بتعبير عن شعورك حول ملاحظات الآخرين 👍\nاكتشف عالمًا جديدًا 🚀"
monthAndDay: "{day}/{month}"
search: "البحث"
notifications: "الإشعارات"

View File

@ -1,7 +1,7 @@
---
_lang_: "বাংলা"
headlineMisskey: "নোট ব্যাবহার করে সংযুক্ত নেটওয়ার্ক"
introMisskey: "স্বাগতম! মিসকি একটি ওপেন সোর্স, ডিসেন্ট্রালাইজড মাইক্রোব্লগিং পরিষেবা। \n\"নোট\" তৈরির মাধ্যমে যা ঘটছে তা সবার সাথে শেয়ার করুন 📡\n\"রিঅ্যাকশন\" গুলির মাধ্যমে যেকোনো নোট সম্পর্কে আপনার অনুভূতি ব্যাক্ত করতে পারেন 👍\nএকটি নতুন দুনিয়া ঘুরে দেখুন 🚀\n"
headlineFirefish: "নোট ব্যাবহার করে সংযুক্ত নেটওয়ার্ক"
introFirefish: "স্বাগতম! মিসকি একটি ওপেন সোর্স, ডিসেন্ট্রালাইজড মাইক্রোব্লগিং পরিষেবা। \n\"নোট\" তৈরির মাধ্যমে যা ঘটছে তা সবার সাথে শেয়ার করুন 📡\n\"রিঅ্যাকশন\" গুলির মাধ্যমে যেকোনো নোট সম্পর্কে আপনার অনুভূতি ব্যাক্ত করতে পারেন 👍\nএকটি নতুন দুনিয়া ঘুরে দেখুন 🚀\n"
monthAndDay: "{day}/{month}"
search: "খুঁজুন"
notifications: "বিজ্ঞপ্তি"

View File

@ -1 +1,421 @@
{}
_lang_: Български
cancel: Отмяна
noNotes: Няма публикации
settings: Настройки
headlineFirefish: Децентрализирана социална медийна платформа с отворен код, която
е безплатна завинаги! 🚀
notifications: Известия
forgotPassword: Забравена парола
uploading: Качване...
addInstance: Добави сървър
favorite: Добави в отметки
delete: Изтрий
unpin: Откачи от профила
copyLink: Копирай връзката
pin: Закачи в профила
deleted: Изтрито
deleteAndEditConfirm: Сигурни ли сте, че искате да изтриете тази публикация и да я
редактирате? Ще загубите всички реакции, подсилвания и отговори към нея.
copyUsername: Копирай потребителското име
searchUser: Търсене на потребител
reply: Отговори
showMore: Покажи още
loadMore: Зареди още
followRequestAccepted: Заявка за последване приета
importAndExport: Импорт/Експорт на Данни
import: Импортиране
download: Свали
export: Експортиране
files: Файлове
unblock: Отблокирай
_sensitiveMediaDetection:
setSensitiveFlagAutomatically: Маркиране като деликатно
searchWith: 'Търсене: {q}'
smtpUser: Потребителско име
notificationType: Тип известие
searchResult: Резултати от търсенето
searchByGoogle: Търсене
markAsReadAllNotifications: Маркирай всички известия като прочетени
settingGuide: Препоръчителни настройки
smtpPass: Парола
newPasswordIs: Новата парола е "{password}"
members: Членове
help: Помощ
hide: Скрий
group: Група
groups: Групи
incorrectPassword: Грешна парола.
leaveGroup: Напусни групата
numberOfColumn: Брой колони
passwordLessLogin: Вписване без парола
newPasswordRetype: Въведи отново парола
saveAs: Запази като...
resetPassword: Нулиране на парола
saveConfirm: Запазване на промените?
inputNewFolderName: Въведи ново име на папка
upload: Качване
retypedNotMatch: Въвежданията не съвпадат.
_ago:
weeksAgo: преди {n}с
secondsAgo: преди {n}сек
hoursAgo: преди {n}ч
minutesAgo: преди {n}мин
daysAgo: преди {n}д
monthsAgo: преди {n}м
yearsAgo: преди {n}г
future: Бъдеще
justNow: Точно сега
folderName: Име на папка
renameFile: Преименувай файл
_widgets:
activity: Дейност
notifications: Известия
timeline: Инфопоток
instanceSecurity: Сигурност на сървъра
uploadFolder: Папка по подразбиране за качвания
instanceInfo: Информация за сървъра
statistics: Статистика
fileName: Име на файл
selectFile: Избери файл
editProfile: Редактирай профил
instances: Сървъри
selectUser: Избери потребител
createNew: Създай ново
blockThisInstance: Блокирай този сървър
_profile:
metadata: Допълнителна информация
username: Потребителско име
name: Име
description: Биография
metadataContent: Съдържание
addAccount: Добави акаунт
followRequestPending: Заявка за последване в изчакване
signinHistory: История на вписванията
or: Или
noUsers: Няма потребители
notes: Публикации
newNoteRecived: Има нови публикации
note: Публикация
instanceFollowing: Последвани на сървъра
_filters:
followersOnly: Само последователи
notesAfter: Публикации след
fromDomain: От домейн
_notification:
_types:
follow: Нови последователи
mention: Споменавания
reaction: Реакции
_channel:
notesCount: '{n} Публикации'
unfollow: Отследване
noLists: Нямаш никакви списъци
markAsReadAllUnreadNotes: Маркирай всички публикации като прочетени
markAsReadAllTalkMessages: Маркирай всички съобщения като прочетени
_time:
second: Секунд(а/и)
hour: Час(а)
day: Дни
minute: Минут(а/и)
create: Създай
lists: Списъци
reportAbuseOf: Докладвай {name}
reporter: Докладчик
abuseReports: Доклади
logoImageUrl: URL на лого изображение
reportAbuse: Доклад
latestRequestReceivedAt: Последно получена заявка
location: Местонахождение
keepOriginalUploading: Запази оригиналното изображение
renotesCount: Брой изпратени подсилвания
license: Лиценз
lastUsedDate: Последно използвано на
rename: Преименувай
customEmojis: Персонализирани емоджита
emoji: Емоджи
_aboutFirefish:
translation: Преведи Calckey
translatedFrom: Преведено от {x}
i18nInfo: Calckey се превежда на различни езици от доброволци. Можете да помогнете
на адрес {link}.
image: Изображение
recipient: Получател(и)
notesAndReplies: Публикации и отговори
noSuchUser: Потребителят не е намерен
pinnedPages: Закачени страници
pinLimitExceeded: Не може да закачаш повече публикации
flagShowTimelineReplies: Показване на отговори в инфопотока
followersCount: Брой последователи
receivedReactionsCount: Брой получени реакции
federation: Федерация
today: Днес
yearX: '{year}'
registeredAt: Регистриран на
monthX: '{month}'
dayX: '{day}'
registration: Регистрация
popularUsers: Популярни потребители
details: Детайли
tenMinutes: 10 минути
oneDay: Един ден
file: Файл
oneHour: Един час
video: Видео
createNewClip: Създай нова подборка
clips: Подборки
active: Активен
menu: Меню
itsOff: Изключено
remindMeLater: Може би по-късно
removed: Успешно изтриване
deleteAllFiles: Изтрий всички файлове
deletedNote: Изтрита публикация
deleteConfirm: Потвърждавате ли изтриването?
hasChildFilesOrFolders: Тъй като тази папка не е празна, тя не може да бъде изтрита.
nsfw: Деликатно съдържание
default: По подразбиране
_theme:
defaultValue: Стойност по подразбиране
keys:
mention: Споменаване
renote: Подсили
color: Цвят
_pages:
script:
blocks:
_dailyRannum:
arg1: Минимална стойност
arg2: Максимална стойност
_join:
arg1: Списъци
add: Добави
_rannum:
arg1: Минимална стойност
arg2: Максимална стойност
_seedRannum:
arg3: Максимална стойност
arg2: Минимална стойност
categories:
value: Стойности
list: Списъци
blocks:
_textInput:
default: Стойност по подразбиране
_switch:
default: Стойност по подразбиране
_textareaInput:
default: Стойност по подразбиране
_numberInput:
default: Стойност по подразбиране
_radioButton:
default: Стойност по подразбиране
_deck:
_columns:
notifications: Известия
mentions: Споменавания
tl: Инфопоток
direct: Директни съобщения
_mfm:
mention: Споменаване
search: Търсене
_messaging:
groups: Групи
apps: Приложения
introFirefish: Добре дошли! Calckey е децентрализирана социална медийна платформа с
отворен код, която е безплатна завинаги! 🚀
monthAndDay: '{day}/{month}'
search: Търсене
searchPlaceholder: Търсене в Calckey
username: Потребителско име
password: Парола
fetchingAsApObject: Извличане от федивърса
ok: Добре
gotIt: Разбрах!
noThankYou: Не, благодаря
enterUsername: Въведи потребителско име
renotedBy: Подсилено от {user}
noNotifications: Няма известия
instance: Сървър
basicSettings: Основни Настройки
otherSettings: Други Настройки
openInWindow: Отвори в прозорец
profile: Профил
timeline: Инфопоток
noAccountDescription: Този потребител все още не е написал своята биография.
login: Впиши се
loggingIn: Вписване
logout: Отпиши се
signup: Регистрирай се
save: Запазване
users: Потребители
addUser: Добави потребител
favorites: Отметки
unfavorite: Премахни от отметки
favorited: Добавено в отметки.
alreadyFavorited: Вече е добавено в отметки.
cantFavorite: Неуспешно добавяне в отметки.
copyContent: Копирай съдържанието
deleteAndEdit: Изтрий и редактирай
editNote: Редактирай бележка
edited: Редактирано на {date} {time}
addToList: Добави в списък
sendMessage: Изпрати съобщение
jumpToPrevious: Премини към предишно
newer: по-ново
older: по-старо
showLess: Затвори
youGotNewFollower: те последва
receiveFollowRequest: Заявка за последване получена
mention: Споменаване
mentions: Споменавания
directNotes: Директни съобщения
cw: Предупреждение за съдържание
followers: Последователи
following: Последвани
followsYou: Следва те
createList: Създай списък
error: Грешка
manageLists: Управление на списъци
retry: Повторен опит
follow: Следване
followRequest: Заявка за последване
followRequests: Заявки за последване
defaultNoteVisibility: Видимост по подразбиране
unrenote: Върни обратно подсилване
renoted: Подсилено.
cantRenote: Тази публикация не може да бъде подсилена.
renote: Подсили
enterEmoji: Въведи емоджи
sensitive: Деликатно съдържание
add: Добави
pinned: Закачено в профила
quote: Цитирай
pinnedNote: Закачена публикация
cantReRenote: Подсилване не може да бъде подсилено.
clickToShow: Кликни за показване
you: Ти
reaction: Реакции
removeReaction: Премахни реакцията си
enterFileName: Въведи име на файл
unmarkAsSensitive: Отмаркирай като деликатно
markAsSensitive: Маркирай като деликатно
block: Блокирай
emojis: Емоджита
addEmoji: Добави
emojiName: Име на емоджи
emojiUrl: URL на емоджи
loginFailed: Неуспешно вписване
flagAsCat: Котка ли си? 😺
flagSpeakAsCat: Говори като котка
youHaveNoLists: Нямаш никакви списъци
selectInstance: Избери сървър
annotation: Коментари
latestRequestSentAt: Последно изпратена заявка
stopActivityDelivery: Спри изпращането на дейности
version: Версия
clearCachedFiles: Изтрий кеш
noInstances: Няма сървъри
federating: Федериране
defaultValueIs: 'По подразбиране: {value}'
noCustomEmojis: Няма емоджи
changePassword: Промени парола
currentPassword: Настояща парола
instanceUsers: Потребители на този сървър
security: Сигурност
instanceFollowers: Последователи на сървъра
newPassword: Нова парола
more: Още!
remove: Изтрий
saved: Запазено
messaging: Чат
birthday: Рожден ден
images: Изображения
activity: Дейност
createFolder: Създай папка
renameFolder: Преименувай тази папка
selectFolders: Избери папки
selectFolder: Избери папка
selectFiles: Избери файлове
addFile: Добави на файл
inputNewFileName: Въведи ново име на файл
deleteFolder: Изтрий тази папка
emptyFolder: Тази папка е празна
copyUrl: Копирай URL
pages: Страници
thisYear: Година
thisMonth: Месец
pinnedNotes: Закачени публикации
pinnedUsers: Закачени потребители
hcaptcha: hCaptcha
recaptcha: reCAPTCHA
name: Име
enableRecaptcha: Включване на reCAPTCHA
enableHcaptcha: Включване на hCaptcha
exploreUsersCount: Има {count} потребители
userList: Списъци
moderator: Модератор
moderation: Модерация
administrator: Администратор
lastUsed: Последно използвано
unregister: Отрегистрация
share: Сподели
notFound: Не е намерено
inputMessageHere: Въведи съобщение тук
createGroup: Създай група
close: Затвори
next: Следващо
title: Заглавие
messagingWithGroup: Групов чат
enable: Включи
retype: Въведи отново
noteOf: Публикация от {user}
quoteAttached: Цитат
newMessageExists: Има нови съобщения
noMessagesYet: Все още няма съобщения
language: Език
createAccount: Създай акаунт
existingAccount: Съществуващ акаунт
deleteAll: Изтрий всички
enableAll: Включване на всички
disableAll: Изключване на всички
copy: Копирай
reporteeOrigin: Произход на докладвания
reporterOrigin: Произход на докладчика
clip: Подборка
unclip: Премахни от подборка
followingCount: Брой последвани акаунти
renotedCount: Брой получени подсилвания
notesCount: Брой публикации
repliesCount: Брой изпратени отговори
repliedCount: Брой получени отговори
sentReactionsCount: Брой изпратени реакции
yes: Да
no: Не
alwaysMarkSensitive: Маркирай като деликатно по подразбиране
noteFavoritesCount: Брой публикации с отметки
left: Ляво
nNotes: '{n} Публикации'
value: Стойност
createdAt: Създадено на
invalidValue: Невалидна стойност.
currentVersion: Настояща версия
latestVersion: Най-нова версия
typingUsers: '{users} пише'
user: Потребител
enabled: Включено
disabled: Изключено
whatIsNew: Покажи промените
translate: Преведи
itsOn: Включено
oneWeek: Една седмица
audio: Звук
removeQuote: Премахни цитат
_sfx:
notification: Известия
_2fa:
renewTOTPCancel: Отмяна
_permissions:
"read:favorites": Виж списъка си с отметки
"write:favorites": Редактирай списъка си с отметки
_visibility:
followers: Последователи

View File

@ -1,7 +1,7 @@
_lang_: "Català"
headlineMisskey: "Una xarxa social de codi obert, descentralitzada i gratuïta per
headlineFirefish: "Una xarxa social de codi obert, descentralitzada i gratuïta per
a sempre! 🚀"
introMisskey: "Benvinguts! Firefish és una plataforma social de codi obert, descentralitzada
introFirefish: "Benvinguts! Firefish és una plataforma social de codi obert, descentralitzada
i gratuïta per a sempre! 🚀"
monthAndDay: "{day}/{month}"
search: "Cerca"
@ -116,7 +116,7 @@ reaction: "Reaccions"
reactionSetting: "Reaccions a mostrar al selector de reaccions"
reactionSettingDescription2: "Arrossega per reordenar, fes clic per suprimir, prem
\"+\" per afegir."
rememberNoteVisibility: "Recorda la configuració de visibilitat de les notes"
rememberNoteVisibility: "Recorda la configuració de visibilitat de les publicacions"
attachCancel: "Elimina el fitxer adjunt"
markAsSensitive: "Marca com a NSFW"
unmarkAsSensitive: "Desmarca com a NSFW"
@ -418,7 +418,7 @@ _exportOrImport:
blockingList: "Bloqueja"
userLists: "Llistes"
excludeMutingUsers: Exclou els usuaris silenciats
allNotes: Totes les notes
allNotes: Totes les publicacions
excludeInactiveUsers: Exclou usuaris inactius
_pages:
script:
@ -633,7 +633,7 @@ _pages:
if: Si
_if:
variable: Variable
post: Formulari de notes
post: Formulari de publicació
_post:
text: Contingut
attachCanvasImage: Adjuntar imatge de llenç
@ -841,7 +841,7 @@ blockedUsers: Usuaris blocats
noUsers: No hi ha cap usuari
editProfile: Edita el perfil
noteDeleteConfirm: Segur que vols eliminar la publicació?
pinLimitExceeded: No pots fixar més notes
pinLimitExceeded: No pots fixar més publicacions
muteAndBlock: Silenciats i blocats
mutedUsers: Usuaris silenciats
done: Fet
@ -1044,7 +1044,7 @@ pinnedClipId: ID del clip que vols fixar
hcaptcha: hCaptcha
manageAntennas: Gestiona les Antenes
name: Nom
notesAndReplies: Notes i respostes
notesAndReplies: Publicacions i respostes
silence: Posa en silenci
withFiles: Amb fitxers
popularUsers: Usuaris populars
@ -1070,7 +1070,7 @@ notFoundDescription: No es pot trobar cap pàgina que correspongui a aquesta adr
uploadFolder: Carpeta per defecte per pujar arxius
cacheClear: Netejar la memòria cau
markAsReadAllNotifications: Marca totes les notificacions com llegides
markAsReadAllUnreadNotes: Marca totes les notes com a llegides
markAsReadAllUnreadNotes: Marca totes les publicacions com a llegides
markAsReadAllTalkMessages: Marca tots els missatges com llegits
help: Ajuda
inputMessageHere: Escriu aquí el missatge
@ -1140,7 +1140,7 @@ promote: Promoure
numberOfDays: Nombre de dies
objectStorageBaseUrl: Adreça URL base
hideThisNote: Amaga aquesta publicació
showFeaturedNotesInTimeline: Mostra les notes destacades a les líneas de temps
showFeaturedNotesInTimeline: Mostra les publicacions destacades a les línees de temps
objectStorage: Emmagatzematge d'objectes
useObjectStorage: Fes servir l'emmagatzema d'objectes
expandTweet: Amplia el tuit
@ -1211,7 +1211,7 @@ notificationSetting: Preferències de notificacions
makeActive: Activar
notificationSettingDesc: Tria el tipus de notificació que es veure.
notifyAntenna: Notificar publicacions noves
withFileAntenna: Només notes amb fitxers
withFileAntenna: Només publicacions amb fitxers
enableServiceworker: Activa les notificacions push per al teu navegador
antennaUsersDescription: Escriu un nom d'usuari per línea
antennaInstancesDescription: Escriu la adreça d'un servidor per línea
@ -1294,7 +1294,7 @@ defaultNavigationBehaviour: Navegació per defecte
editTheseSettingsMayBreakAccount: Si edites aquestes configuracions pots fer mal bé
el teu compte.
userSilenced: Aquest usuari ha sigut silenciat.
instanceTicker: Informació de notes del servidor
instanceTicker: Informació de publicacions del servidor
waitingFor: Esperant a {x}
random: Aleatori
system: Sistema
@ -1312,18 +1312,18 @@ no: No
noCrawle: Rebutjar la indexació dels restrejadors
driveUsage: Espai fet servir al Disk
noCrawleDescription: No permetre que els buscadors guardin la informació de les pàgines
de perfil, notes, Pàgines, etc.
de perfil, publicacions, Pàgines, etc.
alwaysMarkSensitive: Marcar per defecte com a NSFW
lockedAccountInfo: Si has configurat la visibilitat del compte per "Només seguidors"
les teves notes no seren visibles per a ningú més, inclús si has d'aprovar els teus
seguidors manualment.
les teves publicacions no serien visibles per a ningú més, inclús si has d'aprovar
els teus seguidors manualment.
disableShowingAnimatedImages: No reproduir les imatges animades
verificationEmailSent: S'ha enviat correu electrònic de verificació. Si us plau segueix
les instruccions per completar la verificació.
notSet: Sense especificar
emailVerified: El correu electrònic s'ha verificat
loadRawImages: Carregar les imatges originals en comptes de mostrar les miniatures
noteFavoritesCount: Nombre de notes afegides a favorits
noteFavoritesCount: Nombre de publicacions afegides a favorits
useSystemFont: Fes servir la font per defecte del sistema
contact: Contacte
clips: Retalls
@ -1331,7 +1331,7 @@ experimentalFeatures: Característiques experimentals
developer: Desenvolupador
makeExplorableDescription: Si desactives aquesta funció el teu compte no sortirà a
la secció "Explora".
showGapBetweenNotesInTimeline: Mostra un espai entre notes a la línea de temps
showGapBetweenNotesInTimeline: Mostra un espai entre publicacions a la línea de temps
makeExplorable: Fes el compte visible a "Explora"
duplicate: Duplicar
left: Esquerra
@ -1343,14 +1343,14 @@ needReloadToApply: Es requereix recarregar la pàgina perquè això surti efecte
showTitlebar: Mostrar la barra de títol
onlineUsersCount: Hi han {n} usuaris connectats
nUsers: '{n} Usuaris'
nNotes: '{n} Notes'
nNotes: '{n} Publicacions'
sendErrorReports: Enviar informe d'error
clearCache: Netejar memòria cau
switchAccount: Canvia de compte
enabled: Activat
configure: Configurar
noBotProtectionWarning: La protecció contra bots no està configurada.
ads: Publicitat
ads: Bàners comunitaris
ratio: Ràtio
global: Global
sent: Enviat
@ -1445,7 +1445,7 @@ _ad:
reduceFrequencyOfThisAd: Mostrar aquest anunci menys
_gallery:
my: La meva Galeria
liked: Notes que m'han agradat
liked: Publicacions que m'han agradat
unlike: Elimina m'agrada
like: M'agrada
_forgotPassword:
@ -1605,8 +1605,8 @@ _aboutFirefish:
patronsList: Llistats cronològicament, no per la quantitat donada. Fes una donació
amb l'enllaç de dalt per veure el teu nom aquí!
donateTitle: T'agrada Firefish?
pleaseDonateToFirefish: Penseu en fer una donació a Firefish per donar suport al seu
desenvolupament.
pleaseDonateToFirefish: Penseu en fer una donació a Firefish per donar suport al
seu desenvolupament.
pleaseDonateToHost: Penseu també en fer una donació a la vostre instància, {host},
per ajudar-lo a suportar els costos de funcionament.
donateHost: Fes una donació a {host}
@ -1617,7 +1617,7 @@ youAreRunningUpToDateClient: Estás fent servir la versió del client més nova.
unlikeConfirm: Vols treure el teu m'agrada?
fullView: Vista complerta
desktop: Escritori
notesCount: Nombre de notes
notesCount: Nombre de publicacions
confirmToUnclipAlreadyClippedNote: Aquesta publicació ja és al clip "{name}". La vols
treure d'aquest clip?
driveFilesCount: Nombre de fitxers al Disk
@ -1651,7 +1651,7 @@ privateModeInfo: Quan està activat, només els servidors a la llista blanca es
useBlurEffect: Utilitzeu efectes de desenfocament a la interfície d'usuari
accountDeletionInProgress: La supressió del compte està en curs
unmuteThread: Desfés el silenci al fil
deleteAccountConfirm: Això suprimirà el vostre compte de manera irreversible. Procedir?
deleteAccountConfirm: Això suprimirà aquest compte de manera irreversible. Procedir?
requireAdminForView: Heu d'iniciar sessió amb un compte d'administrador per veure-ho.
enableAutoSensitiveDescription: Permet la detecció i el marcatge automàtics dels mitjans
NSFW mitjançant Machine Learning sempre que sigui possible. Fins i tot si aquesta
@ -1671,7 +1671,7 @@ objectStorageRegion: Regió
objectStoragePrefix: Prefix
objectStoragePrefixDesc: Els fitxers es guardaran dins de carpetes amb aquest prefix.
objectStorageEndpoint: Extrem
newNoteRecived: Hi han notes noves
newNoteRecived: Hi han publicacions noves
sounds: Sons
listen: Escoltar
none: Res
@ -1686,7 +1686,8 @@ objectStorageUseProxyDesc: Desactiva això si no faràs servir un servidor Proxy
objectStorageSetPublicRead: Fixar com a "public-read" al pujar
serverLogs: Registres del servidor
deleteAll: Esborrar tot
showFixedPostForm: Mostrar el formulari de notes al principi de la línia de temps
showFixedPostForm: Mostrar el formulari de publicacions al principi de la línia de
temps
unableToProcess: Aquesta operació no es pot acabar
recentUsed: Fet servir fa poc
install: Instal·lar
@ -1719,9 +1720,9 @@ accentColor: Color principal
textColor: Color del text
value: Valor
sendErrorReportsDescription: "Quan està activat, quan es produeixi un problema la
informació detallada d'errors es compartirà amb Firefish, ajudant a millorar la qualitat
de Firefish.\nAixò inclourà informació com la versió del vostre sistema operatiu,
quin navegador utilitzeu, la vostra activitat a Firefish, etc."
informació detallada d'errors es compartirà amb Firefish, ajudant a millorar la
qualitat de Firefish.\nAixò inclourà informació com la versió del vostre sistema
operatiu, quin navegador utilitzeu, la vostra activitat a Firefish, etc."
myTheme: El meu tema
backgroundColor: Color de fons
saveAs: Desa com...
@ -1760,7 +1761,7 @@ sendPushNotificationReadMessage: Suprimeix les notificacions push un cop s'hagin
sendPushNotificationReadMessageCaption: Es mostrarà una notificació amb el text "{emptyPushNotificationMessage}"
durant un breu temps. Això pot augmentar l'ús de la bateria del vostre dispositiu,
si escau.
showAds: Mostrar publicitat
showAds: Mostrar bàners de la comunitat
enterSendsMessage: Pren retorn al formulari del missatge per enviar (quant no s'activa
es Ctrl + Return)
customMOTD: MOTD personalitzat (missatges de la pantalla de benvinguda)
@ -1778,7 +1779,7 @@ migrationConfirm: "Esteu absolutament segur que voleu migrar el vostre compte a
Un cop ho feu, no podreu revertir-ho i no podreu tornar a utilitzar el vostre compte
amb normalitat.\nA més, assegureu-vos d'haver configurat aquest compte actual com
el compte del qual us moveu."
defaultReaction: Reacció d'emoji predeterminada per a notes sortints i entrants
defaultReaction: Reacció d'emoji predeterminades per a publicacions sortints i entrants
enableCustomKaTeXMacro: Activa les macros KaTeX personalitzades
noteId: ID de la publicació
_nsfw:
@ -1841,7 +1842,7 @@ pushNotificationAlreadySubscribed: Les notificacions push ja estan activades
pushNotificationNotSupported: El vostre navegador o servidor no admet notificacions
push
license: Llicència
indexPosts: Índex de notes
indexPosts: Índex de publicacions
indexFrom: Índex a partir de l'ID de Publicacions
indexFromDescription: Deixeu en blanc per indexar cada publicació
indexNotice: Ara indexant. Això probablement trigarà una estona, si us plau, no reinicieu
@ -1864,7 +1865,7 @@ _channel:
owned: Propietari
usersCount: '{n} Participants'
following: Seguit per
notesCount: '{n} Notes'
notesCount: '{n} Publicacions'
nameAndDescription: Nom i descripció
nameOnly: Només nom
_instanceMute:
@ -1912,7 +1913,7 @@ _tutorial:
Firefish. Aquest sí que sí! És una mica complicat, però ho aconseguiràs en poc
temps.
step2_2: Proporcionar informació sobre qui sou facilitarà que altres puguin saber
si volen veure les vostres notes o seguir-vos.
si volen veure les vostres publicacions o seguir-vos.
step3_1: Ara toca seguir a algunes persones!
step3_2: "Les teves líneas de temps d'inici i social es basen en qui seguiu, així
que proveu de seguir un parell de comptes per començar.\nFeu clic al cercle més
@ -1934,9 +1935,9 @@ _permissions:
"write:notifications": Gestiona les teves notificacions
"write:user-groups": Editar o suprimir grups d'usuaris
"write:blocks": Editar la llista d'usuaris bloquejats
"write:notes": Redactar o suprimir notes
"write:notes": Redactar o suprimir publicacions
"write:channels": Editar els teus canals
"read:gallery-likes": Consulta la llista de notes que t'agraden de la galeria
"read:gallery-likes": Consulta la llista de publicacions que t'agraden de la galeria
"write:drive": Editar o suprimir fitxers i carpetes del Disc
"read:favorites": Consulta la teva llista d'adreces d'interès
"write:favorites": Editeu la teva llista d'adreces d'interès
@ -1950,7 +1951,7 @@ _permissions:
"read:channels": Consulta els teus canals
"read:gallery": Consulta la teva galeria
"write:gallery": Edita la teva galeria
"write:gallery-likes": Edita la llista de notes que t'agraden de la galeria
"write:gallery-likes": Edita la llista de publicacions que t'agraden de la galeria
"read:following": Consulta la informació sobre a qui segueixes
"read:reactions": Consulta les teves reaccions
"read:pages": Consulta la teva pàgina
@ -1994,10 +1995,10 @@ _charts:
apRequest: Sol·licituds
usersTotal: Nombre total d'usuaris
activeUsers: Usuaris actius
notesIncDec: Diferència en el nombre de notes
localNotesIncDec: Diferència en el nombre de notes locals
remoteNotesIncDec: Diferència en el nombre de notes remotes
notesTotal: Nombre total de notes
notesIncDec: Diferència en el nombre de publicacions
localNotesIncDec: Diferència en el nombre de publicacions locals
remoteNotesIncDec: Diferència en el nombre de publicacions remotes
notesTotal: Nombre total de publicacions
filesIncDec: Diferència en el nombre de fitxers
filesTotal: Nombre total de fitxers
storageUsageTotal: Ús total d'emmagatzematge
@ -2006,13 +2007,13 @@ _instanceCharts:
requests: Sol·licituds
users: Diferència en el nombre d'usuaris
usersTotal: Nombre acumulat d'usuaris
notes: Diferència en el nombre de notes
notes: Diferència en el nombre de publicacions
ffTotal: Nombre acumulat d'usuaris que segueixes/et segueixen
cacheSize: Diferència en la mida de la memòria cau
cacheSizeTotal: Mida total acumulada de la memòria cau
files: Diferència en el nombre de fitxers
filesTotal: Nombre acumulat de fitxers
notesTotal: Nombre acumulat de notes
notesTotal: Nombre acumulat de publicacions
ff: "Diferència en el nombre d'usuaris que segueixes/que et segueixen "
_timelines:
home: Inici
@ -2033,12 +2034,12 @@ _wordMute:
hard: Dur
muteWordsDescription2: Envolta les paraules clau amb barres inclinades per utilitzar
expressions regulars.
softDescription: Amaga les notes que compleixen les condicions establertes de la
línia de temps.
hardDescription: Evita que les notes que compleixin les condicions establertes s'afegeixin
a la línia de temps. A més, aquestes notes no s'afegiran a la línia de temps encara
que es modifiquin les condicions.
mutedNotes: Notes silenciades
softDescription: Amaga les publicacions que compleixen les condicions establertes
de la línia de temps.
hardDescription: Evita que les publicacions que compleixin les condicions establertes
s'afegeixin a la línia de temps. A més, aquestes publicacions no s'afegiran a
la línia de temps encara que es modifiquin les condicions.
mutedNotes: Publicacions silenciades
_auth:
shareAccessAsk: Estàs segur que vols autoritzar aquesta aplicació per accedir al
teu compte?
@ -2061,11 +2062,11 @@ _messaging:
groups: Grups
dms: Privat
_antennaSources:
all: Totes les notes
all: Totes les publicacions
homeTimeline: Publicacions dels usuaris que segueixes
users: Notes d'usuaris concrets
userGroup: Notes d'usuaris d'un grup determinat
userList: Notes d'una llista determinada d'usuaris
users: Publicacions d'usuaris concrets
userGroup: Publicacions d'usuaris d'un grup determinat
userList: Publicacions d'una llista determinada d'usuaris
instances: Publicacions de tots els usuaris d'un servidor
_relayStatus:
requesting: Pendent
@ -2120,7 +2121,7 @@ clipsDesc: Els clips són com marcadors categoritzats que es poden compartir. Po
crear clips des del menú de publicacions individuals.
selectChannel: Selecciona un canal
isLocked: Aquest compte té les següents aprovacions
isPatron: Mecenes de Calkey
isPatron: Mecenes de Firefish
isBot: Aquest compte és un bot
isModerator: Moderador
isAdmin: Administrador
@ -2168,3 +2169,13 @@ _feeds:
atom: Atom
jsonFeed: Feed JSON
copyFeed: Copiar feed
origin: Origen
objectStorageS3ForcePathStyle: Feu servir rutes URLs per a endpoints
objectStorageS3ForcePathStyleDesc: Activeu aquesta opció per crear URL per endpoints
en el format "s3.amazonaws.com/<bucket>/" sobre "<bucket>.s3.amazonaws.com".
deletePasskeys: Suprimeix les contrasenyes
deletePasskeysConfirm: Això suprimirà de manera irreversible totes les contrasenyes
i claus de seguretat d'aquest compte. Procedir?
inputNotMatch: L'entrada no coincideix
delete2fa: Desactivar 2FA
delete2faConfirm: Això suprimirà irreversiblement 2FA en aquest compte. Procedir?

View File

@ -1,9 +1,9 @@
_lang_: "Čeština"
headlineMisskey: "Síť propojená poznámkami"
introMisskey: "Vítejte! Firefish je otevřený a decentralizovaný microblogový servis.\n\
\"Poznámkami\" můžete sdílet co se zrovna děje se všemi ve Vašem okolí. \U0001F4E1\
\nPomocí \"reakcí\" můžete sdílet své názory a pocity na ostatní poznámky. \U0001F44D\
\nPojďte objevovat nový svět! \U0001F680"
headlineFirefish: "Síť propojená poznámkami"
introFirefish: "Vítejte! Firefish je otevřený a decentralizovaný microblogový servis.\n\
\"Poznámkami\" můžete sdílet co se zrovna děje se všemi ve Vašem okolí. 📡\nPomocí
\"reakcí\" můžete sdílet své názory a pocity na ostatní poznámky. 👍\nPojďte objevovat
nový svět! 🚀"
monthAndDay: "{day}. {month}."
search: "Vyhledávání"
notifications: "Oznámení"
@ -18,7 +18,7 @@ enterUsername: "Zadej uživatelské jméno"
renotedBy: "{user} přeposla/a"
noNotes: "Žádné poznámky"
noNotifications: "Žádná oznámení"
instance: "Instance"
instance: "Server"
settings: "Nastavení"
basicSettings: "Obecná nastavení"
otherSettings: "Rozšířená nastavení"
@ -46,8 +46,8 @@ copyContent: "Zkopírovat obsah"
copyLink: "Kopírovat odkaz"
delete: "Smazat"
deleteAndEdit: "Smazat a upravit"
deleteAndEditConfirm: "Jste si jistí že chcete smazat tuto poznámku a editovat ji?\
\ Ztratíte tím všechny reakce, sdílení a odpovědi na ni."
deleteAndEditConfirm: "Jste si jistí že chcete smazat tuto poznámku a editovat ji?
Ztratíte tím všechny reakce, sdílení a odpovědi na ni."
addToList: "Přidat do seznamu"
sendMessage: "Odeslat zprávu"
copyUsername: "Kopírovat uživatelské jméno"
@ -66,11 +66,11 @@ import: "Importovat"
export: "Exportovat"
files: "Soubor(ů)"
download: "Stáhnout"
driveFileDeleteConfirm: "Opravdu chcete smazat soubor \"{name}\"? Soubor bude odstraněn\
\ ze všech příspěvků, které ji obsahují jako přílohu."
driveFileDeleteConfirm: "Opravdu chcete smazat soubor \"{name}\"? Soubor bude odstraněn
ze všech příspěvků, které ji obsahují jako přílohu."
unfollowConfirm: "Jste si jisti že už nechcete sledovat {name}?"
exportRequested: "Požádali jste o export. To může chvíli trvat. Přidáme ho na váš\
\ Disk až bude dokončen."
exportRequested: "Požádali jste o export. To může chvíli trvat. Přidáme ho na váš
Disk až bude dokončen."
importRequested: "Požádali jste o export. To může chvilku trvat."
lists: "Seznamy"
noLists: "Nemáte žádné seznamy"
@ -86,8 +86,8 @@ somethingHappened: "Jejda. Něco se nepovedlo."
retry: "Opakovat"
pageLoadError: "Nepodařilo se načíst stránku"
serverIsDead: "Server neodpovídá. Počkejte chvíli a zkuste to znovu."
youShouldUpgradeClient: "Pro zobrazení této stránky obnovte stránku pro aktualizaci\
\ klienta."
youShouldUpgradeClient: "Pro zobrazení této stránky obnovte stránku pro aktualizaci
klienta."
enterListName: "Jméno seznamu"
privacy: "Soukromí"
makeFollowManuallyApprove: "Žádosti o sledování vyžadují potvrzení"
@ -111,8 +111,8 @@ clickToShow: "Klikněte pro zobrazení"
sensitive: "NSFW"
add: "Přidat"
reaction: "Reakce"
reactionSettingDescription2: "Přetažením změníte pořadí, kliknutím smažete, zmáčkněte\
\ \"+\" k přidání"
reactionSettingDescription2: "Přetažením změníte pořadí, kliknutím smažete, zmáčkněte
\"+\" k přidání"
rememberNoteVisibility: "Zapamatovat nastavení zobrazení poznámky"
attachCancel: "Odstranit přílohu"
markAsSensitive: "Označit jako NSFW"
@ -141,18 +141,18 @@ emojiUrl: "URL obrázku"
addEmoji: "Přidat emoji"
settingGuide: "Doporučené nastavení"
cacheRemoteFiles: "Ukládání vzdálených souborů do mezipaměti"
cacheRemoteFilesDescription: "Zakázání tohoto nastavení způsobí, že vzdálené soubory\
\ budou odkazovány přímo, místo aby byly ukládány do mezipaměti. Tím se ušetří úložiště\
\ na serveru, ale zvýší se provoz, protože se negenerují miniatury."
cacheRemoteFilesDescription: "Zakázání tohoto nastavení způsobí, že vzdálené soubory
budou odkazovány přímo, místo aby byly ukládány do mezipaměti. Tím se ušetří úložiště
na serveru, ale zvýší se provoz, protože se negenerují miniatury."
flagAsBot: "Tento účet je bot"
flagAsBotDescription: "Pokud je tento účet kontrolován programem zaškrtněte tuto možnost.\
\ To označí tento účet jako bot pro ostatní vývojáře a zabrání tak nekonečným interakcím\
\ s ostatními boty a upraví Firefish systém aby se choval k tomuhle účtu jako bot."
flagAsBotDescription: "Pokud je tento účet kontrolován programem zaškrtněte tuto možnost.
To označí tento účet jako bot pro ostatní vývojáře a zabrání tak nekonečným interakcím
s ostatními boty a upraví Firefish systém aby se choval k tomuhle účtu jako bot."
flagAsCat: "Tenhle účet je kočka"
flagAsCatDescription: "Vyberte tuto možnost aby tento účet byl označen jako kočka."
flagShowTimelineReplies: "Zobrazovat odpovědi na časové ose"
flagShowTimelineRepliesDescription: "Je-li zapnuto, zobrazí odpovědi uživatelů na\
\ poznámky jiných uživatelů na vaší časové ose."
flagShowTimelineRepliesDescription: "Je-li zapnuto, zobrazí odpovědi uživatelů na
poznámky jiných uživatelů na vaší časové ose."
autoAcceptFollowed: "Automaticky akceptovat následování od účtů které sledujete"
addAccount: "Přidat účet"
loginFailed: "Přihlášení se nezdařilo."
@ -165,10 +165,10 @@ searchWith: "Hledat: {q}"
youHaveNoLists: "Nemáte žádné seznamy"
followConfirm: "Jste si jisti, že chcete sledovat {name}?"
proxyAccount: "Proxy účet"
proxyAccountDescription: "Proxy účet je účet, který za určitých podmínek sleduje uživatele\
\ na dálku vaším jménem. Například když uživatel zařadí vzdáleného uživatele do\
\ seznamu, pokud nikdo nesleduje uživatele na seznamu, aktivita nebude doručena\
\ instanci, takže místo toho bude uživatele sledovat účet proxy."
proxyAccountDescription: "Proxy účet je účet, který za určitých podmínek sleduje uživatele
na dálku vaším jménem. Například když uživatel zařadí vzdáleného uživatele do seznamu,
pokud nikdo nesleduje uživatele na seznamu, aktivita nebude doručena instanci, takže
místo toho bude uživatele sledovat účet proxy."
host: "Hostitel"
selectUser: "Vyberte uživatele"
recipient: "Pro"
@ -253,8 +253,8 @@ agreeTo: "Souhlasím s {0}"
tos: "Podmínky užívání"
start: "Začít"
home: "Domů"
remoteUserCaution: "Tyto informace nemusí být aktuální jelikož uživatel je ze vzdálené\
\ instance."
remoteUserCaution: "Tyto informace nemusí být aktuální jelikož uživatel je ze vzdálené
instance."
activity: "Aktivita"
images: "Obrázky"
birthday: "Datum narození"
@ -563,8 +563,8 @@ info: "Informace"
unknown: "Neznámý"
onlineStatus: "Online status"
hideOnlineStatus: "Skrýt Váš online status"
hideOnlineStatusDescription: "Skrytí vašeho online stavu může snížit funkcionalitu\
\ některých funkcí, například vyhledávání."
hideOnlineStatusDescription: "Skrytí vašeho online stavu může snížit funkcionalitu
některých funkcí, například vyhledávání."
online: "Online"
active: "Aktivní"
offline: "Offline"
@ -983,7 +983,7 @@ emptyDrive: Váš disk je prázdný
inputNewDescription: Zadejte nový popisek
hasChildFilesOrFolders: Složka nemůže být smazána, protože není prázdná.
noThankYou: Ne, děkuji
addInstance: Přidat instance
addInstance: Přidat server
selectInstance: Vybrat si instance
blockedUsers: Zablokovaní uživatelé
muteAndBlock: Ztlumení a blokace
@ -1007,3 +1007,6 @@ renoteMute: Ztlumit přeposílání
renoteUnmute: Zrušit ztlumení přeposílání
flagSpeakAsCat: Mluvit jako kočka
flagSpeakAsCatDescription: Vaše příspěvky budou v kočičím režimu nyanifikovány.
newer: novější
older: starší
jumpToPrevious: Skočit na předchozí

View File

@ -157,9 +157,9 @@ pageLoadErrorDescription: Dette er normalt på grund af netværksproblemer eller
browser's cache. Prøv at ryd cachen og så gentage efter et styk tid.
serverIsDead: Serveren svarer ikke. Vær sød at vente et styk tid og prøv igen.
editWidgetsExit: Færdig
headlineMisskey: En åben-kildekode, decentraliseret social-media platform som er frit
headlineFirefish: En åben-kildekode, decentraliseret social-media platform som er frit
forevigt! 🚀
introMisskey: Velkommen! Firefish er en åbent-kildekode, decentraliseret social-media
introFirefish: Velkommen! Firefish er en åbent-kildekode, decentraliseret social-media
platform som er frit forevigt!🚀
enableEmojiReactions: Aktivere emoji reaktioner
unsuspendConfirm: Er du sikker på at du vil ikke suspendere denne konto endnu længere?

View File

@ -1,9 +1,9 @@
_lang_: "Deutsch"
headlineMisskey: "Eine dezentralisierte Open-Source Social Media Plattform, die für
headlineFirefish: "Eine dezentralisierte Open-Source Social Media Plattform, die für
immer gratis bleibt! 🚀"
introMisskey: "Willkommen! Firefish ist eine dezentralisierte Open-Source Social Media
Plattform, die für immer gratis bleibt!🚀"
monthAndDay: "{month}/{day}"
introFirefish: "Willkommen! Firefish ist eine dezentralisierte Open-Source Social
Media Plattform, die für immer gratis bleibt!🚀"
monthAndDay: "{day}.{month}."
search: "Suchen"
notifications: "Benachrichtigungen"
username: "Nutzername"
@ -67,7 +67,7 @@ export: "Export"
files: "Dateien"
download: "Herunterladen"
driveFileDeleteConfirm: "Möchtest du die Datei \"{name}\" wirklich löschen? Es wird
aus allen Beiträgen entfernt, die die Datei als Anhang enthalten."
aus allen Beiträgen entfernt, welche die Datei als Anhang enthalten."
unfollowConfirm: "Bist du dir sicher, daß du {name} nicht mehr folgen möchtest?"
exportRequested: "Du hast einen Export angefragt. Dies kann etwas Zeit in Anspruch
nehmen. Sobald der Export abgeschlossen ist, wird er deinem Laufwerk hinzugefügt."
@ -117,7 +117,7 @@ sensitive: "NSFW"
add: "Hinzufügen"
reaction: "Reaktionen"
reactionSetting: "Reaktionen, die in der Reaktionsauswahl angezeigt werden sollen"
reactionSettingDescription2: "Ziehen Sie, um neu zu ordnen,\nklicken Sie, um zu löschen,\n
reactionSettingDescription2: "Ziehen Sie, um neu zu ordnen, klicken Sie, um zu löschen,
drücken Sie \"+\", um hinzuzufügen."
rememberNoteVisibility: "Einstellungen für die Sichtbarkeit von Beiträgen speichern"
attachCancel: "Anhang entfernen"
@ -595,7 +595,7 @@ yourAccountSuspendedDescription: "Dieses Nutzerkonto wurde gesperrt, da es gegen
menu: "Menü"
divider: "Trenner"
addItem: "Element hinzufügen"
relays: "Relays"
relays: "Relais"
addRelay: "Relay hinzufügen"
inboxUrl: "inbox-URL"
addedRelays: "Hinzugefügte Relays"
@ -666,7 +666,7 @@ overview: "Übersicht"
logs: "Protokolle"
delayed: "Verzögert"
database: "Datenbank"
channel: "Channels"
channel: "Kanäle"
create: "Erstellen"
notificationSetting: "Benachrichtigungseinstellungen"
notificationSettingDesc: "Wähle die Art der anzuzeigenden Benachrichtigungen."
@ -777,10 +777,10 @@ nUsers: "{n} Nutzer"
nNotes: "{n} Beiträge"
sendErrorReports: "Fehlerberichte senden"
sendErrorReportsDescription: "Ist diese Option aktiviert, so werden beim Auftreten
von Fehlern detaillierte Fehlerinformationen an Firefish weitergegeben, was zur Verbesserung
der Qualität von Firefish beiträgt.\nEnthalten in diesen Informationen sind u.a.
die Version deines Betriebssystems, welchen Browser du verwendest und ein Verlauf
deiner Aktivitäten innerhalb Firefish."
von Fehlern detaillierte Fehlerinformationen an Firefish weitergegeben, was zur
Verbesserung der Qualität von Firefish beiträgt.\nEnthalten in diesen Informationen
sind u.a. die Version deines Betriebssystems, welchen Browser du verwendest und
ein Verlauf deiner Aktivitäten innerhalb Firefish."
myTheme: "Meine Farbkombination"
backgroundColor: "Hintergrundfarbe"
accentColor: "Akzentfarbe"
@ -835,7 +835,7 @@ active: "Aktiv"
offline: "Offline"
notRecommended: "Nicht empfohlen"
botProtection: "Schutz vor Bots"
instanceBlocking: "Verbundene Server verwalten"
instanceBlocking: "Föderation verwalten"
selectAccount: "Nutzerkonto auswählen"
switchAccount: "Konto wechseln"
enabled: "Aktiviert"
@ -853,7 +853,7 @@ gallery: "Bilder-Galerie"
recentPosts: "Neue Beiträge"
popularPosts: "Beliebte Beiträge"
shareWithNote: "Mit Beitrag teilen"
ads: "Werbeanzeigen"
ads: "Community-Banner"
expiration: "Frist"
memo: "Merkzettel"
priority: "Priorität"
@ -900,14 +900,14 @@ manageAccounts: "Nutzerkonten verwalten"
makeReactionsPublic: "Reaktionsverlauf veröffentlichen"
makeReactionsPublicDescription: "Jeder wird die Liste deiner gesendeten Reaktionen
einsehen können."
classic: "Mittig/zentriert"
classic: "Zentriert"
muteThread: "Thread stummschalten"
unmuteThread: "Threadstummschaltung aufheben"
ffVisibility: "Sichtbarkeit von Gefolgten/Followern"
ffVisibilityDescription: "Konfiguriere wer sehen kann, wem du folgst sowie wer dir
folgt."
continueThread: "Beitrag fortsetzen"
deleteAccountConfirm: "Dein Nutzerkonto wird unwiderruflich gelöscht. Trotzdem fortfahren?"
deleteAccountConfirm: "Das Nutzerkonto wird unwiderruflich gelöscht. Trotzdem fortfahren?"
incorrectPassword: "Falsches Passwort."
voteConfirm: "Wirklich für „{choice}“ abstimmen?"
hide: "Inhalt verbergen"
@ -947,14 +947,15 @@ recentNDays: "Die letzten {n} Tage"
noEmailServerWarning: "Es ist kein Email-Server konfiguriert."
thereIsUnresolvedAbuseReportWarning: "Es liegen ungelöste Meldungen vor."
recommended: "Favoriten"
check: "Kontrolle"
check: "Überprüfe"
driveCapOverrideLabel: "Die Cloud-Drive-Kapazität dieses Nutzers verändern"
driveCapOverrideCaption: "Gib einen Wert von 0 oder weniger ein, um die Kapazität
auf den Standard zurückzusetzen."
requireAdminForView: "Melde dich mit einem Administratorkonto an, um dies einzusehen."
isSystemAccount: "Dieses Konto wird vom System erstellt und automatisch verwaltet.
Bitte moderieren, bearbeiten, löschen oder manipulieren Sie dieses Konto nicht,
da es sonst zu einem Server-Absturz kommen könnte."
requireAdminForView: "Du musst dich mit einem Administratorkonto anmelden um dies
zu sehen."
isSystemAccount: "Ein Nutzerkonto, dass durch das System erstellt und automatisch
kontrolliert wird. Jede Anpassung, Veränderung oder Löschung dieses Nutzerkontos,
kann zu schwerwiegenden Fehlern auf diesem Server führen."
typeToConfirm: "Bitte gib zur Bestätigung {x} ein"
deleteAccount: "Nutzerkonto löschen"
document: "Dokumentation"
@ -965,7 +966,7 @@ logoutConfirm: "Wirklich abmelden?"
lastActiveDate: "Zuletzt verwendet am"
statusbar: "Statusleiste"
pleaseSelect: "Wähle eine Option"
reverse: "Umkehren"
reverse: "Rückgängig machen"
colored: "Farbig"
refreshInterval: "Aktualisierungsintervall "
label: "Beschriftung"
@ -977,12 +978,12 @@ sensitiveMediaDetection: "Erkennung von NSFW-Medien"
localOnly: "Nur Lokal"
remoteOnly: "Nur für andere/fremde Server"
failedToUpload: "Hochladen fehlgeschlagen"
cannotUploadBecauseInappropriate: "Diese Datei kann nicht hochgeladen werden, da Anteile
der Datei als möglicherweise NSFW festgestellt wurden."
cannotUploadBecauseInappropriate: "Diese Datei kann nicht hochgeladen werden, da Teile
der Datei möglicherweise NSFW-Inhalt enthalten."
cannotUploadBecauseNoFreeSpace: "Die Datei konnte nicht hochgeladen werden, da dein
Cloud-Drive-Speicherplatz aufgebraucht ist."
beta: "Beta"
enableAutoSensitive: "Selbstständige NSFW-Kennzeichnung"
enableAutoSensitive: "Automatische NSFW-Kennzeichnung"
enableAutoSensitiveDescription: "Erlaubt, wo möglich, die automatische Erkennung und
Kennzeichnung von NSFW-Medien durch maschinelles Lernen. Auch wenn diese Option
deaktiviert ist, kann sie über den Server aktiviert sein."
@ -1005,8 +1006,8 @@ _sensitiveMediaDetection:
setSensitiveFlagAutomaticallyDescription: "Die Resultate der internen Erkennung
werden beibehalten, auch wenn diese Option deaktiviert ist."
analyzeVideos: "Videoanalyse aktivieren"
analyzeVideosDescription: "Analysiert zusätzlich zu Bildern auch Videos. Die Last
des Servers wird hierdurch etwas erhöht."
analyzeVideosDescription: "Analysiert zusätzlich zu Bildern auch Videos. Die Serverlast
wird hierdurch etwas erhöht."
_emailUnavailable:
used: "Diese Email-Adresse wird bereits verwendet"
format: "Das Format dieser Email-Adresse ist ungültig"
@ -1020,17 +1021,17 @@ _ffVisibility:
_signup:
almostThere: "Fast geschafft"
emailAddressInfo: "Bitte gib deine Email-Adresse ein. Sie wird nicht öffentlich
einsehbar sein."
sichtbar sein."
emailSent: "An deine Email-Adresse ({email}) wurde soeben eine Bestätigungsmail
geschickt. Bitte klicke auf den enthaltenen Link, um die Erstellung deines Nutzerkontos
abzuschließen."
_accountDelete:
accountDelete: "Nutzerkonto löschen"
mayTakeTime: "Da die Löschung eines Nutzerkontos ein aufwendiger Prozess ist, kann
dessen Dauer davon abhängen, wie viel Inhalt von diesem erstellt wurde oder wie
dessen Dauer davon abhängen, wie viel Inhalt von diesem erstellt wurde und wie
viele Dateien von diesem hochgeladen wurden."
sendEmail: "Sobald die Löschung abgeschlossen ist, wird an die mit ihm verknüpfte
Email-Adresse eine Benachrichtigung versendet."
sendEmail: "Sobald die Löschung abgeschlossen ist, wird an die registrierte Email-Adresse
eine Benachrichtigung versendet."
requestAccountDelete: "Löschung deines Nutzerkontos anfordern"
started: "Die Löschung wurde eingeleitet."
inProgress: "Löschung in Bearbeitung"
@ -1060,19 +1061,19 @@ _plugin:
manage: "Plugins verwalten"
_preferencesBackups:
list: "Erstellte Backups"
saveNew: "Neu erstellen"
saveNew: "Neues Backup speichern"
loadFile: "Von Datei laden"
apply: "Auf dieses Gerät anwenden"
save: "Speichern"
save: "Änderungen speichern"
inputName: "Gib einen Namen für dieses Backup ein"
cannotSave: "Speichern fehlgeschlagen"
nameAlreadyExists: "Es existiert bereits ein Backup unter dem Namen \"{name}\".
Bitte gib einen anderen Namen ein."
applyConfirm: "Wirklich das Backup \"{name}\" auf dieses Gerät anwenden? Bestehende
Einstellungen darauf werden überschrieben."
saveConfirm: "Als {name} speichern?"
saveConfirm: "Backup als {name} speichern?"
deleteConfirm: "Das Backup {name} löschen?"
renameConfirm: "Soll dieses Backup von \"{old}\" zu \"{new}\" umbenannt werden?"
renameConfirm: "Backup von \"{old}\" zu \"{new}\" umbenennen?"
noBackups: "Keine Backups existieren. Backups können über \"Neu erstellen\" erstelllt
werden."
createdAt: "Erstellt am: {date} {time}"
@ -1096,10 +1097,19 @@ _aboutFirefish:
morePatrons: "Wir schätzen ebenso die Unterstützung vieler anderer hier nicht gelisteter
Personen sehr. Danke! 🥰"
patrons: "UnterstützerInnen"
patronsList: Auflistung chonologisch, nicht nach Spenden-Größe. Spende über den
Link oben, um hier aufgeführt zu werden!
donateTitle: Gefällt dir Firefish?
pleaseDonateToFirefish: Bitte erwäge eine Spende an Firefish, um dessen Entwicklung
zu unterstützen.
pleaseDonateToHost: Bitte erwäge auch, an deinen Heimatserver {host} zu spenden,
um bei der Deckung der Betriebskosten zu helfen.
sponsors: Firefish-Sponsoren
donateHost: Spende an {host}
_nsfw:
respect: "Mit NSFW gekennzeichnete Bilder verbergen"
ignore: "Mit NSFW gekennzeichnete Bilder nicht verbergen"
force: "Alle Medien verbergen"
respect: "Mit NSFW gekennzeichnete Mediendateien verbergen"
ignore: "Mit NSFW gekennzeichnete Mediendateien nicht verbergen"
force: "Alle Mediendateien verbergen"
_mfm:
cheatSheet: "MFM Spickzettel"
intro: "MFM ist eine Markup-Sprache, die in Misskey, Firefish, Akkoma und anderen
@ -1118,7 +1128,7 @@ _mfm:
bold: "Fett"
boldDescription: "Zeichen zur Betonung dicker erscheinen lassen."
small: "Klein"
smallDescription: "Inhalt klein und dünn erscheinen lassen."
smallDescription: "Inhalt klein und dünn anzeigen."
center: "Zentrieren"
centerDescription: "Inhalt zentriert anzeigen."
inlineCode: "Code (Eingebettet)"
@ -1138,7 +1148,7 @@ _mfm:
search: "Suche"
searchDescription: "Eine vorgefertige Suchanfragebox anzeigen."
flip: "Spiegelung"
flipDescription: "Inhalt horizontal oder vertikal gespiegelt anzeigen."
flipDescription: "Inhalt horizontal oder vertikal spiegeln."
jelly: "Animation (Dehnen)"
jellyDescription: "Verleiht Inhalt eine sich dehnende Animation."
tada: "Animation (Tada)"
@ -1183,14 +1193,15 @@ _mfm:
crop: Zuschneiden
scale: Maßstab
scaleDescription: Skaliere den Inhalt um einen bestimmten Betrag.
foregroundDescription: Ändern der Vordergrundfarbe von Text.
backgroundDescription: Ändern der Hintergrundfarbe von Text
foregroundDescription: Vordergrundfarbe des Texts ändern.
backgroundDescription: Hintergrundfarbe des Texts ändern.
play: MFM abspielen
stop: MFM anhalten
warn: MFM können schnell bewegte oder anderweitig auffallende Animationen enthalten
alwaysPlay: Alle animierten MFM immer automatisch abspielen
advancedDescription: Wenn diese Funktion deaktiviert ist, können nur einfache Formatierungen
vorgenommen werden, es sei denn, animiertes MFM ist aktiviert
advanced: Erweitertes MFM
_instanceTicker:
none: "Nie anzeigen"
remote: "Für Nutzer eines anderen Servers anzeigen"
@ -1404,6 +1415,7 @@ _2fa:
registerTOTPBeforeKey: Bitte registriere eine Authentificator App, um einen Hardware-Security-Key
oder einen Passkey zu nutzen.
securityKeyName: Gib einen Namen für den Key ein
token: 2FA Token
_permissions:
"read:account": "Deine Nutzerkontoinformationen lesen"
"write:account": "Deine Nutzerkontoinformationen bearbeiten"
@ -1444,11 +1456,12 @@ _auth:
zu können?"
shareAccessAsk: "Bist du dir sicher, dass du diese Anwendung authorisieren möchtest,
auf dein Nutzerkonto zugreifen zu können?"
permissionAsk: "Diese Anwendung fordert folgende Berechtigungen"
permissionAsk: "Diese Anwendung fordert folgende Berechtigungen:"
pleaseGoBack: "Bitte kehre zur Anwendung zurück"
callback: "Es wird zur Anwendung zurückgekehrt"
denied: "Zugriff verweigert"
copyAsk: Bitte fügen Sie den folgenden Autorisierungscode in die Anwendung ein
copyAsk: 'Bitte fügen Sie den folgenden Autorisierungscode in die Anwendung ein:'
allPermissions: Vollständiger Kontozugriff
_antennaSources:
all: "Alle Beiträge"
homeTimeline: "Beiträge von Nutzern, denen gefolgt wird"
@ -1482,7 +1495,7 @@ _widgets:
postForm: "Beitragsfeld"
slideshow: "Diashow"
button: "Knopf"
onlineUsers: "Nutzer Online"
onlineUsers: "Nutzer online"
jobQueue: "Job-Warteschlange"
serverMetric: "Servermetriken"
aiscript: "AiScript-Konsole"
@ -1523,11 +1536,12 @@ _poll:
remainingSeconds: "{s} Sekunde(n) verbleibend"
_visibility:
public: "Öffentlich"
publicDescription: "Dein Beitrag wird global für alle Nutzer sichtbar sein"
publicDescription: "Dein Beitrag wird global in allen öffentlichen Timelines sichtbar
sein"
home: "nicht aufgelistet"
homeDescription: "Beitrag nur auf der Home-Timeline anzeigen"
followers: "Follower"
followersDescription: "Nur für Follower sichtbar"
followersDescription: "Nur für Follower und erwähnte Nutzer sichtbar"
specified: "Direkt"
specifiedDescription: "Nur für bestimmte Nutzer sichtbar"
localOnly: "Nur Lokal"
@ -1551,7 +1565,8 @@ _profile:
metadata: "Zusätzliche Informationen"
metadataEdit: "Zusätzliche Informationen bearbeiten"
metadataDescription: "Hierdurch kannst du auf deinem Profil zusätzliche Informationsblöcke
anzeigen lassen. Sie können ein {a}-Tag oder ein {l}-Tag mit {rel} hinzufügen, um den Link in Ihrem Profil zu überprüfen!"
anzeigen lassen. Sie können ein {a}-Tag oder ein {l}-Tag mit {rel} hinzufügen,
um den Link in Ihrem Profil zu überprüfen!"
metadataLabel: "Beschriftung"
metadataContent: "Inhalt"
changeAvatar: "Profilbild ändern"
@ -1574,7 +1589,7 @@ _charts:
activeUsers: "Aktive Nutzer"
notesIncDec: "Unterschied bei der Anzahl an Beiträgen"
localNotesIncDec: "Unterschied bei der Anzahl an lokalen Beiträgen"
remoteNotesIncDec: "Differenz zur Anzahl von Beiträgen von anderen Servern."
remoteNotesIncDec: "Differenz bei der Anzahl an Beiträgen von anderen Servern"
notesTotal: "Anzahl aller Beiträge"
filesIncDec: "Unterschied in der Anzahl an Dateien"
filesTotal: "Anzahl aller Dateien"
@ -1628,7 +1643,7 @@ _pages:
hideTitleWhenPinned: "Nutzer-Seitentitel wenn angeheftet ausblenden"
font: "Schriftart"
fontSerif: "Serif"
fontSansSerif: "sans-serif"
fontSansSerif: "Sans Serif"
eyeCatchingImageSet: "Vorschaubild festlegen"
eyeCatchingImageRemove: "Vorschaubild entfernen"
chooseBlock: "Block hinzufügen"
@ -1643,7 +1658,7 @@ _pages:
text: "Text"
textarea: "Textfeld"
section: "Abschnitt"
image: "Bild"
image: "Bilder"
button: "Knopf"
if: "Falls"
_if:
@ -1971,9 +1986,8 @@ enableEmojiReactions: Emoji-Reaktionen aktivieren
flagSpeakAsCat: Wie eine Katze sprechen
showEmojisInReactionNotifications: Emojis in Reaktionsbenachrichtigungen anzeigen
userSaysSomethingReason: '{name} sagte {reason}'
hiddenTagsDescription: 'Geben sie hier die Schlagworte (ohne #hashtag) an, die vom
"Trending and Explore" ausgeschlossen werden sollen. Versteckte Schlagworte sind
immer noch über andere Wege auffindbar.'
hiddenTagsDescription: 'Liste die Hashtags (ohne #) welche du von Trending und Explore
verstecken möchtest. Versteckte Hashtags sind durch andere Wege weiterhin auffindbar.'
addInstance: Server hinzufügen
flagSpeakAsCatDescription: Deine Beiträge werden im Katzenmodus nyanisiert
hiddenTags: Versteckte Hashtags
@ -1983,8 +1997,8 @@ renoteMute: Boosts stummschalten
renoteUnmute: Stummschaltung von Boosts aufheben
noInstances: Keine Server gefunden
privateModeInfo: Wenn diese Option aktiviert ist, können nur als vertrauenswürdig
eingestufte Server mit diesem Server kommunizieren. Alle Beiträge werden für die
Öffentlichkeit verborgen.
eingestufte Server mit diesem Server föderieren. Alle Beiträge werden für die Öffentlichkeit
verborgen.
allowedInstances: Vertrauenswürdige Server
selectInstance: Wähle einen Server aus
silencedInstancesDescription: Liste die Hostnamen der Server auf, die du stummschalten
@ -2019,14 +2033,14 @@ moveAccountDescription: 'Dieser Vorgang kann nicht rückgängig gemacht werden!
wie folgt ein: @name@server.xyz'
findOtherInstance: Einen anderen Server finden
sendPushNotificationReadMessage: Löschung der Push-Benachrichtigungen sobald die entsprechenden
Benachrichtigungen oder Beiträge gelesen wurden.
Benachrichtigungen oder Nachrichten gelesen wurden
signupsDisabled: Derzeit sind keine Anmeldungen auf diesem Server möglich! Anmeldungen
auf anderen Servern sind jedoch möglich! Wenn Sie einen Einladungscode für diesen
Server haben, geben Sie ihn bitte unten ein.
swipeOnDesktop: Am Desktop PC das Wischen wie bei mobilen Geräten zulassen
enterSendsMessage: Drücken sie zum Senden des Beitrages die Eingabetaste (Strg-Taste
ausgeschaltet)
showUpdates: Zeigt ein Popup-Fenster an, wenn Firefish aktualisiert wird.
showUpdates: Zeige ein Popup-Fenster an, wenn Firefish aktualisiert wird
socialTimeline: Social-Timeline
moveFrom: Bisheriges Nutzerkonto zu diesem Nutzerkonto umziehen
_messaging:
@ -2039,7 +2053,7 @@ userSaysSomethingReasonReply: '{name} hat auf einen Beitrag geantwortet der {rea
userSaysSomethingReasonRenote: '{name} hat einen Beitrag geteilt der {reason} beinhaltet'
userSaysSomethingReasonQuote: '{name} hat einen Beitrag zitiert der {reason} beinhaltet'
seperateRenoteQuote: Getrennte Boost- und Zitat-Schaltflächen
showAds: Anzeigen anzeigen
showAds: Community-Banner anzeigen
splash: Begrüßungsbildschirm
customSplashIconsDescription: URLs für benutzerdefinierte Splash-Screen-Symbole, die
durch Zeilenumbrüche getrennt sind und nach dem Zufallsprinzip jedes Mal angezeigt
@ -2053,18 +2067,17 @@ adminCustomCssWarn: Diese Einstellung sollte nur verwendet werden, wenn Sie wiss
mehr normal funktionieren. Bitte stellen Sie sicher, dass Ihr CSS ordnungsgemäß
funktioniert, indem Sie es in Ihren Benutzereinstellungen testen.
customMOTD: Benutzerdefinierte Meldung des Tages (Begrüßungsbildschirmmeldungen)
allowedInstancesDescription: Hosts von Servern, die zur Verbindung auf die Liste vertrauenswürdiger
Server gesetzt werden sollen, werden jeweils durch eine neue Zeile getrennt eingegeben
(gilt nur im privaten Modus).
allowedInstancesDescription: Hostnamen von Servern, die auf der Liste vertrauenswürdiger
Server für die Föderation stehen sollen, jeweils getrennt in einer neuen Zeile (tritt
nur im privaten Modus in Kraft).
migration: Migration
updateAvailable: Es könnte eine Aktualisierung verfügbar sein!
updateAvailable: Es könnte ein Update verfügbar sein!
showAdminUpdates: Anzeigen, dass eine neue Firefish-Version verfügbar ist (nur Administrator)
customMOTDDescription: Benutzerdefinierte Meldungen für die Meldung des Tages (Begrüßungsbildschirm),
die durch Zeilenumbrüche getrennt sind und nach dem Zufallsprinzip jedes Mal angezeigt
werden, wenn ein Benutzer die Seite (neu) lädt.
recommendedInstancesDescription: Empfohlene Server, die durch Zeilenumbrüche getrennt
sind, werden in der "Favoriten"-Timeline angezeigt. Fügen Sie NICHT "https://" hinzu,
sondern NUR die Domain.
sind, werden in der "Favoriten"-Timeline angezeigt.
sendModMail: Moderationshinweis senden
moveFromDescription: 'Dadurch wird ein Alias Ihres alten Nutzerkontos festgelegt,
sodass Sie von ihrem bisherigen Konto zu diesem Nutzerkonto wechseln können. Tun
@ -2073,7 +2086,7 @@ moveFromDescription: 'Dadurch wird ein Alias Ihres alten Nutzerkontos festgelegt
preventAiLearning: KI gestütztes bot-scraping unterdrücken
preventAiLearningDescription: Fordern Sie KI-Sprachmodelle von Drittanbietern auf,
die von Ihnen hochgeladenen Inhalte, wie z. B. Beiträge und Bilder, nicht zu untersuchen.
license: Genehmigung
license: Lizenz
indexPosts: Gelistete Beiträge
migrationConfirm: "Sind Sie absolut sicher, dass Sie Ihr Nutzerkonto zu diesem {account}
umziehen möchten? Sobald Sie dies bestätigt haben, kann dies nicht mehr rückgängig
@ -2106,12 +2119,12 @@ indexFrom: Indexieren ab Beitragskennung aufwärts
indexNotice: Wird jetzt indexiert. Dies wird wahrscheinlich eine Weile dauern, bitte
starten Sie Ihren Server für mindestens eine Stunde nicht neu.
customKaTeXMacroDescription: "Richten Sie Makros ein, um mathematische Ausdrücke einfach
zu schreiben! Die Notation entspricht den LaTeX-Befehlsdefinitionen und wird als\n
\\newcommand{\\name}{content} or \\newcommand{\\name}[number of arguments]{content}\n
geschrieben.\nZum Beispiel wird\n\\newcommand{\\add}[2]{#1 + #2} \\add{3}{foo} um
3 + foo erweitert.\nDie geschweiften Klammern, die den Makronamen umgeben, können
in runde oder eckige Klammern geändert werden. Dies hat Auswirkungen auf die Klammern,
die für die Argumente verwendet werden. Pro Zeile kann ein (und nur ein) Makro definiert
zu schreiben! Die Notation entspricht den LaTeX-Befehlsdefinitionen und wird als
\\newcommand{\\name}{content} oder \\newcommand{\\name}[number of arguments]{content}
geschrieben. Zum Beispiel wird \\newcommand{\\add}[2]{#1 + #2} \\add{3}{foo} erweitern
zu 3 + foo. Die geschweiften Klammern, die den Makro-Namen umgeben, können in runde
oder eckige Klammern geändert werden. Dies hat Auswirkungen auf die Klammern, die
für die Argumente verwendet werden. Pro Zeile kann ein (und nur ein) Makro definiert
werden, und Sie können die Zeile nicht mitten in der Definition umbrechen. Ungültige
Zeilen werden einfach ignoriert. Es werden nur einfache Funktionen zur Substitution
von Zeichenketten unterstützt; erweiterte Syntax, wie z. B. bedingte Verzweigungen,
@ -2131,6 +2144,7 @@ _filters:
fromDomain: Von Domain
notesBefore: Beiträge vor
followingOnly: Nur Folgende
followersOnly: Nur Follower
isBot: Dieses Konto ist ein Bot
isModerator: Moderator
isAdmin: Administrator
@ -2141,7 +2155,7 @@ _dialog:
searchPlaceholder: Firefish durchsuchen
antennasDesc: "Antennen zeigen neue Posts an, die deinen definierten Kriterien entsprechen!\n
Sie können von der Timeline-Seite aufgerufen werden."
isPatron: Firefish Patron
isPatron: Firefish-Patron
removeReaction: Entferne deine Reaktion
listsDesc: Listen lassen dich Timelines mit bestimmten Nutzer:innen erstellen. Sie
können von der Timeline-Seite erreicht werden.
@ -2150,3 +2164,40 @@ clipsDesc: Clips sind wie teilbare, kategorisierte Lesezeichen. Du kannst Clips
channelFederationWarn: Kanäle föderieren noch nicht zu anderen Servern
reactionPickerSkinTone: Bevorzugte Emoji-Hautfarbe
swipeOnMobile: Wischen zwischen den Seiten erlauben
enableServerMachineStats: Server-Hardware-Statistik einschalten
enableIdenticonGeneration: Identicon-Generierung einschalten
verifiedLink: Verifizierter Link
_feeds:
copyFeed: Feed kopieren
jsonFeed: JSON-Feed
rss: RSS
atom: Atom
youHaveUnreadAnnouncements: Du hast ungelesene Ankündigungen
donationLink: Link zur Spenden-Seite
remindMeLater: Vielleicht später
neverShow: Nicht wieder zeigen
removeRecipient: Empfänger entfernen
removeMember: Mitglied entfernen
alt: ALT
xl: XL
isLocked: Dieser Account hat Folge-Anfragen aktiviert
_skinTones:
mediumLight: Mittelhell
yellow: Gelb
light: Hell
medium: Mittel
dark: Dunkel
mediumDark: Mitteldunkel
showPopup: Benutzer mit Popup benachrichtigen
showWithSparkles: Mit Glitzer anzeigen
removeQuote: Zitat entfernen
objectStorageS3ForcePathStyle: Verwende pfadbasierte Endpunkt-URLs
objectStorageS3ForcePathStyleDesc: Wenn aktiviert, werden Endpunkt-URLs im Format
's3.amazonaws.com/<bucket>/' statt '<bucket>.s3.amazonaws.com' erstellt.
origin: Herkunft
delete2fa: 2FA deaktivieren
deletePasskeys: Passkeys löschen
delete2faConfirm: Passkeys werden unwiderruflich von diesem Account gelöscht. Fortfahren?
deletePasskeysConfirm: Alle Passkeys und Security-Keys werden unwiderruflich von diesem
Account gelöscht. Fortfahren?
inputNotMatch: Eingabe stimmt nicht überein

View File

@ -568,9 +568,9 @@ yourAccountSuspendedTitle: Αυτός ο λογαριασμός έχει απο
leaveConfirm: Υπάρχουν αλλαγές που δεν έχουν σωθεί. Θέλετε να τις απορρίψετε;
height: Ύψος
edit: Επεξεργασία
headlineMisskey: Μία ανοιχτού λογισμικού, αποκεντρωμένη πλατφόρμα κοινωνικής δικτύωσης
headlineFirefish: Μία ανοιχτού λογισμικού, αποκεντρωμένη πλατφόρμα κοινωνικής δικτύωσης
που θα είναι για πάντα ελεύθερη! 🚀
introMisskey: Καλώς ήρθατε! Το Firefish είναι μία ανοιχτού λογισμικού, αποκεντρωμένη
introFirefish: Καλώς ήρθατε! Το Firefish είναι μία ανοιχτού λογισμικού, αποκεντρωμένη
πλατφόρμα κοινωνικής δικτύωσης που θα είναι για πάντα ελεύθερη! 🚀
markAsSensitive: Επισήμανση ως Ευαίσθητο Περιεχόμενο (NSFW)
autoAcceptFollowed: Αυτόματη έγκριση αιτημάτων ακολούθησης από λογαριασμούς που ακολουθείτε

View File

@ -1,7 +1,7 @@
_lang_: "English"
headlineMisskey: "An open source, decentralized social media platform that's free
headlineFirefish: "An open source, decentralized social media platform that's free
forever! 🚀"
introMisskey: "Welcome! Firefish is an open source, decentralized social media platform
introFirefish: "Welcome! Firefish is an open source, decentralized social media platform
that's free forever! 🚀"
monthAndDay: "{month}/{day}"
search: "Search"
@ -566,6 +566,9 @@ objectStorageUseProxy: "Connect over Proxy"
objectStorageUseProxyDesc: "Turn this off if you are not going to use a Proxy for
API connections"
objectStorageSetPublicRead: "Set \"public-read\" on upload"
objectStorageS3ForcePathStyle: "Use path-based endpoint URLs"
objectStorageS3ForcePathStyleDesc: "Turn this on to construct endpoint URLs in the
format of 's3.amazonaws.com/<bucket>/' over '<bucket>.s3.amazonaws.com'."
serverLogs: "Server logs"
deleteAll: "Delete all"
showFixedPostForm: "Display the posting form at the top of the timeline"
@ -872,7 +875,7 @@ gallery: "Gallery"
recentPosts: "Recent pages"
popularPosts: "Popular pages"
shareWithNote: "Share with post"
ads: "Advertisements"
ads: "Community banners"
expiration: "Deadline"
memo: "Memo"
priority: "Priority"
@ -938,7 +941,7 @@ ffVisibility: "Follows/Followers Visibility"
ffVisibilityDescription: "Allows you to configure who can see who you follow and who
follows you."
continueThread: "Continue thread"
deleteAccountConfirm: "This will irreversibly delete your account. Proceed?"
deleteAccountConfirm: "This will irreversibly delete this account. Proceed?"
incorrectPassword: "Incorrect password."
voteConfirm: "Confirm your vote for \"{choice}\"?"
hide: "Hide"
@ -1035,7 +1038,7 @@ sendPushNotificationReadMessage: "Delete push notifications once the relevant no
sendPushNotificationReadMessageCaption: "A notification containing the text \"{emptyPushNotificationMessage}\"\
\ will be displayed for a short time. This may increase the battery usage of your
device, if applicable."
showAds: "Show ads"
showAds: "Show community banners"
enterSendsMessage: "Press Return in Messaging to send message (off is Ctrl + Return)"
adminCustomCssWarn: "This setting should only be used if you know what it does. Entering
improper values may cause EVERYONE'S clients to stop functioning normally. Please
@ -1125,6 +1128,13 @@ removeQuote: "Remove quote"
removeRecipient: "Remove recipient"
removeMember: "Remove member"
verifiedLink: "Verified link"
origin: "Origin"
delete2fa: "Disable 2FA"
deletePasskeys: "Delete passkeys"
delete2faConfirm: "This will irreversibly delete 2FA on this account. Proceed?"
deletePasskeysConfirm: "This will irreversibly delete all passkeys and security keys on this account. Proceed?"
inputNotMatch: "Input does not match"
addRe: "Add \"re:\" at the beginning of comment in reply to a post with a content warning"
_sensitiveMediaDetection:
description: "Reduces the effort of server moderation through automatically recognizing
@ -1220,6 +1230,7 @@ _aboutFirefish:
development since 2022."
contributors: "Main contributors"
allContributors: "All contributors"
misskeyContributors: "Misskey contributors"
source: "Source code"
translation: "Translate Firefish"
donate: "Donate to Firefish"

View File

@ -1,7 +1,7 @@
_lang_: "Español"
headlineMisskey: "¡Un proyecto de código abierto y una plataforma de medios de comunicación
headlineFirefish: "¡Un proyecto de código abierto y una plataforma de medios de comunicación
descentralizada que es gratis para siempre! 🚀"
introMisskey: "¡Bienvenido! ¡Firefish es un proyecto de código abierto, plataforma
introFirefish: "¡Bienvenido! ¡Firefish es un proyecto de código abierto, plataforma
descentralizado medios de comunicación social que es gratis para siempre! 🚀"
monthAndDay: "{day}/{month}"
search: "Buscar"
@ -161,7 +161,7 @@ autoAcceptFollowed: "Aceptar automáticamente las solicitudes de seguimiento de
usuarios que sigues"
addAccount: "Agregar Cuenta"
loginFailed: "Error al iniciar sesión"
showOnRemote: "Ver en servidor remoto"
showOnRemote: "Abrir página original"
general: "General"
wallpaper: "Fondo de pantalla"
setWallpaper: "Establecer fondo de pantalla"
@ -540,7 +540,7 @@ objectStorageSetPublicRead: "Seleccionar \"public-read\" al subir "
serverLogs: "Registros del servidor"
deleteAll: "Eliminar todos"
showFixedPostForm: "Mostrar el formulario de las entradas encima de la línea de tiempo"
newNoteRecived: "Tienes unas publicaciones nuevas"
newNoteRecived: "Hay publicaciones nuevas"
sounds: "Sonidos"
listen: "Escuchar"
none: "Ninguna"
@ -690,7 +690,7 @@ instanceTicker: "Información de publicaciones de el servidor"
waitingFor: "Esperando a {x}"
random: "Aleatorio"
system: "Sistema"
switchUi: "Cambiar interfaz de usuario"
switchUi: "Interfaz"
desktop: "Escritorio"
clip: "Clip"
createNew: "Crear"
@ -700,15 +700,15 @@ unclip: "Quitar clip"
confirmToUnclipAlreadyClippedNote: "Esta publicación ya está incluida en el clip \"\
{name}\". ¿Quiere quitar la nota del clip?"
public: "Público"
i18nInfo: "Firefish está siendo traducido a varios idiomas gracias a voluntarios. Se
puede colaborar traduciendo en {link}"
i18nInfo: "Firefish está siendo traducido a varios idiomas gracias a voluntarios.
Se puede colaborar traduciendo en {link}"
manageAccessTokens: "Administrar tokens de acceso"
accountInfo: "Información de la Cuenta"
notesCount: "Cantidad de publicaciones"
repliesCount: "Cantidad de respuestas hechas"
renotesCount: "Cantidad de renotas hechas"
renotesCount: "Número de impulsos enviados"
repliedCount: "Cantidad de respuestas recibidas"
renotedCount: "Cantidad de renotas recibidas"
renotedCount: "Cantidad de impulsos recibidos"
followingCount: "Cantidad de seguidos"
followersCount: "Cantidad de seguidores"
sentReactionsCount: "Cantidad de reacciones hechas"
@ -722,9 +722,9 @@ driveUsage: "Uso del drive"
noCrawle: "Rechazar indexación del crawler"
noCrawleDescription: "Pedir a los motores de búsqueda que no indexen tu perfil, publicaciones,
páginas, etc."
lockedAccountInfo: "A menos que configures la visibilidad de tus notas como \"Sólo
seguidores\", tus notas serán visibles para cualquiera, incluso si requieres que
los seguidores sean aprobados manualmente."
lockedAccountInfo: "A menos que configures la visibilidad de tus publicaciones como
\"Sólo seguidores\", tus publicaciones serán visibles para cualquiera, incluso si
requieres que los seguidores sean aprobados manualmente."
alwaysMarkSensitive: "Marcar los medios de comunicación como contenido sensible por
defecto"
loadRawImages: "Cargar las imágenes originales en lugar de mostrar las miniaturas"
@ -758,7 +758,7 @@ showTitlebar: "Mostrar la barra de título"
clearCache: "Limpiar caché"
onlineUsersCount: "{n} usuarios en línea"
nUsers: "{n} Usuarios"
nNotes: "{n} Notas"
nNotes: "{n} Publicaciones"
sendErrorReports: "Envíar informe de errores"
sendErrorReportsDescription: "Si habilita esta opción, los detalles de los errores
serán compartidos con Firefish cuando ocurra un problema, lo que ayudará a mejorar
@ -788,7 +788,7 @@ capacity: "Capacidad"
inUse: "Usado"
editCode: "Editar código"
apply: "Aplicar"
receiveAnnouncementFromInstance: "Recibir notificaciones de la instancia"
receiveAnnouncementFromInstance: "Recibir notificaciones de este servidor"
emailNotification: "Notificaciones por correo electrónico"
publish: "Publicar"
inChannelSearch: "Buscar en el canal"
@ -804,9 +804,10 @@ unlikeConfirm: "¿Quitar como favorito?"
fullView: "Vista completa"
quitFullView: "quitar vista completa"
addDescription: "Agregar descripción"
userPagePinTip: "Puede mantener sus notas visibles aquí seleccionando Pin en el menú
de notas individuales"
notSpecifiedMentionWarning: "Algunas menciones no están incluidas en el destino"
userPagePinTip: "Puede mantener tus publicaciones visibles aquí seleccionando Pin
en el menú de notas individuales."
notSpecifiedMentionWarning: "Esta publicacion contiene menciones a usuarios no incluídos
como destinatarios"
info: "Información"
userInfo: "Información del usuario"
unknown: "Desconocido"
@ -819,7 +820,7 @@ active: "Activo"
offline: "Sin conexión"
notRecommended: "obsoleto"
botProtection: "Protección contra bots"
instanceBlocking: "Instancias bloqueadas"
instanceBlocking: "Gestión de la Federación"
selectAccount: "Elija una cuenta"
switchAccount: "Cambiar de cuenta"
enabled: "Activado"
@ -836,8 +837,8 @@ postToGallery: "Crear una nueva publicación en la galería"
gallery: "Galería"
recentPosts: "Posts recientes"
popularPosts: "Más vistos"
shareWithNote: "Compartir con una nota"
ads: "Anuncios"
shareWithNote: "Compartir con una publicación"
ads: "Banners"
expiration: "Termina el"
memo: "Notas"
priority: "Prioridad"
@ -885,14 +886,14 @@ manageAccounts: "Administrar cuenta"
makeReactionsPublic: "Hacer el historial de reacciones público"
makeReactionsPublicDescription: "Todas las reacciones que hayas hecho serán públicamente
visibles."
classic: "Clásico"
classic: "Centrado"
muteThread: "Ocultar hilo"
unmuteThread: "Mostrar hilo"
ffVisibility: "Visibilidad de seguidores y seguidos"
ffVisibilityDescription: "Puedes configurar quien puede ver a quienes sigues y quienes
te siguen"
continueThread: "Ver la continuación del hilo"
deleteAccountConfirm: "La cuenta será borrada. ¿Está seguro?"
deleteAccountConfirm: "La cuenta será borrada irreversiblemente. ¿Está seguro?"
incorrectPassword: "La contraseña es incorrecta"
voteConfirm: "¿Confirma su voto a {choice}?"
hide: "Ocultar"
@ -934,7 +935,9 @@ driveCapOverrideLabel: "Cambiar la capacidad de la unidad para este usuario"
driveCapOverrideCaption: "Restablecer la capacidad a su predeterminado ingresando
un valor de 0 o menos"
requireAdminForView: "Necesitas iniciar sesión como administrador para ver esto."
isSystemAccount: "Cuenta creada y operada automáticamente por el sistema"
isSystemAccount: "Esta cuenta es creada y operada automaticamente por el sistema.
Porfavor no moderar, editar, borrar o manipular de ninguna forma esta cuenta, o
podría romper tu servidor."
typeToConfirm: "Ingrese {x} para confirmar"
deleteAccount: "Borrar cuenta"
document: "Documento"
@ -1019,8 +1022,9 @@ _forgotPassword:
enterEmail: "Ingrese el correo usado para registrar la cuenta. Se enviará un link
para resetear la contraseña."
ifNoEmail: "Si no utilizó un correo para crear la cuenta, contáctese con el administrador."
contactAdmin: "Esta instancia no admite el uso de direcciones de correo electrónico,
póngase en contacto con el administrador de la instancia para restablecer su contraseña"
contactAdmin: "Este servidor no admite el uso de direcciones de correo electrónico,
póngase en contacto con la persona que administra el servidor para restablecer
su contraseña."
_gallery:
my: "Mi galería"
liked: "Publicaciones que me gustan"
@ -1073,6 +1077,14 @@ _aboutFirefish:
morePatrons: "También apreciamos el apoyo de muchos más que no están enlistados
aquí. ¡Gracias! 🥰"
patrons: "Mecenas de Firefish"
pleaseDonateToFirefish: Por favor considera donar a Firefish para apollar su desarrollo.
donateHost: Dona a {host}
patronsList: Listados cronológicamente no por monto de la donación. ¡Dona con el
vínculo de arriba para que tu nombre aparezca aquí!
donateTitle: ¿Te gusta Firefish?
pleaseDonateToHost: También considera donar a tu propio servidor , {host}, para
ayudar con los costos de operación.
sponsors: Patrocinadores de Firefish
_nsfw:
respect: "Ocultar medios NSFW"
ignore: "No esconder medios NSFW "
@ -1080,8 +1092,8 @@ _nsfw:
_mfm:
cheatSheet: "Hoja de referencia de MFM"
intro: "MFM es un lenguaje de marcado dedicado que se puede usar en varios lugares
dentro de Misskey, Firefish, Akkoma, y mucho más. Aquí puede ver una lista de sintaxis
disponibles en MFM."
dentro de Misskey, Firefish, Akkoma, y mucho más. Aquí puede ver una lista de
sintaxis disponibles en MFM."
dummy: "Firefish expande el mundo de la Fediverso"
mention: "Menciones"
mentionDescription: "El signo @ seguido de un nombre de usuario se puede utilizar
@ -1106,7 +1118,7 @@ _mfm:
inlineMath: "Fórmula (insertado)"
inlineMathDescription: "Muestra fórmulas (KaTeX) insertadas"
blockMath: "Fórmula (bloque)"
blockMathDescription: "Muestra fórmulas (KaTeX) de varias líneas en un bloque"
blockMathDescription: "Muestra fórmulas matemáticas (KaTeX) en un bloque"
quote: "Citar"
quoteDescription: "Muestra el contenido como una cita"
emoji: "Emojis personalizados"
@ -1151,6 +1163,22 @@ _mfm:
plainDescription: "Desactiva los efectos de todo el contenido MFM con este efecto
MFM."
position: Posición
warn: MFM podría contener movimientos rápidos o animaciones destellantes
advancedDescription: Si está desactivado, solo permitir markup básico, excepto cuando
un MFM animado se reproduce
scale: Escalar
foreground: Color en primer plano
scaleDescription: Ajustar el contenido según un valor especificado.
stop: Detener MFM
crop: Recortar
cropDescription: Recortar contenido.
backgroundDescription: Cambiar el color de fondo del texto.
alwaysPlay: Siempre reproducir todos los MFM animados
fade: Fundido
advanced: MFM avanzado
play: Reproducir MFM
foregroundDescription: Cambiar el color en primer plano del texto.
background: Color de fondo
_instanceTicker:
none: "No mostrar"
remote: "Mostrar a usuarios remotos"
@ -1169,7 +1197,7 @@ _channel:
owned: "Dueño"
following: "Siguiendo"
usersCount: "{n} participantes"
notesCount: "{n} notas"
notesCount: "{n} publicaciones"
nameOnly: Nombre solamente
nameAndDescription: Nombre y descripción
_menuDisplay:
@ -1183,18 +1211,20 @@ _wordMute:
con lineas nuevas indica una declaracion Or。"
muteWordsDescription2: "Encerrar las palabras clave entre numerales para usar expresiones
regulares"
softDescription: "Ocultar en la linea de tiempo las notas que cumplen las condiciones"
hardDescription: "Evitar que se agreguen a la linea de tiempo las notas que cumplen
las condiciones. Las notas no agregadas seguirán quitadas aunque cambien las condiciones."
softDescription: "Ocultar en la linea de tiempo las publicaciones que cumplen las
condiciones"
hardDescription: "Evitar que se agreguen a la linea de tiempo las publicaciones
que cumplen las condiciones, estas no serán agregadas a la linea de tiempo incluso
si cambian las condiciones."
soft: "Suave"
hard: "Duro"
mutedNotes: "Notas silenciadas"
mutedNotes: "Publicaciones silenciadas"
_instanceMute:
instanceMuteDescription: "Silencia todas las notas y reposts de la instancias seleccionadas,
incluyendo respuestas a los usuarios de las mismas"
instanceMuteDescription: "Silencia todas las publicaciones e impusos de los servidores
seleccionados, incluyendo respuestas a los usuarios de las mismas."
instanceMuteDescription2: "Separar por líneas"
title: "Oculta las notas de las instancias listadas."
heading: "Instancias a silenciar"
title: "Oculta las publicaciones de los servidores listados."
heading: "Servidores a silenciar"
_theme:
explore: "Explorar temas"
install: "Instalar tema"
@ -1243,7 +1273,7 @@ _theme:
hashtag: "Hashtag"
mention: "Menciones"
mentionMe: "Menciones (yo)"
renote: "Renotar"
renote: "Impulsar"
modalBg: "Fondo modal"
divider: "Divisor"
scrollbarHandle: "Cuadro de la barra de desplazamiento"
@ -1270,23 +1300,23 @@ _theme:
accentLighten: "Acento (claro)"
fgHighlighted: "Texto resaltado"
_sfx:
note: "Notas"
note: "Nueva publicación"
noteMy: "Nota (a mí mismo)"
notification: "Notificaciones"
chat: "Chat"
chatBg: "Chat (Fondo)"
antenna: "Antena receptora"
antenna: "Antenas"
channel: "Notificaciones del canal"
_ago:
future: "Futuro"
justNow: "Recién ahora"
secondsAgo: "Hace {n} segundos"
minutesAgo: "Hace {n} minutos"
hoursAgo: "Hace {n} horas"
daysAgo: "Hace {n} días"
weeksAgo: "Hace {n} semanas"
monthsAgo: "Hace {n} meses"
yearsAgo: "Hace {n} años"
secondsAgo: "Hace {n} segundo(s)"
minutesAgo: "Hace {n} minuto(s)"
hoursAgo: "Hace {n} hora(s)"
daysAgo: "Hace {n} día(s)"
weeksAgo: "Hace {n} semana(s)"
monthsAgo: "Hace {n} mes(es)"
yearsAgo: "Hace {n} año(s)"
_time:
second: "Segundos"
minute: "Minutos"
@ -1298,16 +1328,16 @@ _tutorial:
step1_2: "Vamos a configurarte. ¡Estarás listo y funcionando en poco tiempo!"
step2_1: "En primer lugar, rellena tu perfil"
step2_2: "Proporcionar algo de información sobre quién eres hará que sea más fácil
para los demás saber si quieren ver tus notas o seguirte."
para los demás saber si quieren ver tus publicaciones o seguirte."
step3_1: "¡Ahora es el momento de seguir a algunas personas!"
step3_2: "Tu página de inicio y tus líneas de tiempo sociales se basan en quién
sigues, así que intenta seguir un par de cuentas para empezar.\nHaz clic en el
círculo más en la parte superior derecha de un perfil para seguirlos."
step4_1: "Vamos a salir a la calle"
step4_2: "Para tu primer post, a algunas personas les gusta hacer un post de {introduction}
o un simple \"¡Hola mundo!\""
step4_2: "Para tu primer publicación, a algunas personas les gusta escribir una
{introduction} o un simple \"¡Hola mundo!\""
step5_1: "¡Líneas de tiempo, líneas de tiempo por todas partes!"
step5_2: "Su instancia tiene {timelines} diferentes líneas de tiempo habilitadas"
step5_2: "Tu servidor tiene {timelines} diferentes líneas de tiempo habilitadas."
step5_3: "La línea de tiempo Inicio {icon} es donde puedes ver las publicaciones
de tus seguidores."
step5_4: "La línea de tiempo Local {icon} es donde puedes ver las publicaciones
@ -1475,7 +1505,8 @@ _profile:
youCanIncludeHashtags: "Puedes añadir hashtags"
metadata: "información adicional"
metadataEdit: "Editar información adicional"
metadataDescription: "Muestra la información adicional en el perfil. ¡Puede agregar una etiqueta {a} o una etiqueta {l} con {rel} para verificar el enlace en su perfil!"
metadataDescription: "Muestra la información adicional en el perfil. ¡Puede agregar
una etiqueta {a} o una etiqueta {l} con {rel} para verificar el enlace en su perfil!"
metadataLabel: "Etiqueta"
metadataContent: "Contenido"
changeAvatar: "Cambiar avatar"
@ -1887,7 +1918,7 @@ renoteUnmute: Dejar de silenciar impulsos
flagSpeakAsCat: Habla como un gato
selectInstance: Selecciona un servidor
flagSpeakAsCatDescription: Tu publicación se "nyanified" cuando esté en modo gato
allowedInstances: Instancias en la lista blanca
allowedInstances: Servidores autorizados
breakFollowConfirm: ¿Estás seguro de que quieres eliminar el seguidor?
subscribePushNotification: Habilitar notificaciones
unsubscribePushNotification: Desactivar notificaciones
@ -1904,12 +1935,12 @@ hiddenTags: Etiquetas Ocultas
noInstances: No hay servidores
accountMoved: 'Usuario ha movido a una cuenta nueva:'
caption: Auto Subtítulos
showAds: Mostrar Anuncios
showAds: Mostrar banners
enterSendsMessage: Presione "RETORNO" en los mensajes para enviar el mensaje (para
apagarlo es Ctrl + RETORNO)
recommendedInstances: Instancias Recomendadas
instanceSecurity: Seguridad de la instancia
seperateRenoteQuote: Separar impulsados y Citar botones
instanceSecurity: Seguridad del servidor
seperateRenoteQuote: Separar botones de Impulsar y Citar
_messaging:
groups: Grupos
dms: Privado
@ -1941,3 +1972,53 @@ hiddenTagsDescription: 'Escriba los hashtags (sin el #) que desea ocultar de las
jumpToPrevious: Ver anterior
enableEmojiReactions: Habilitar reacciones de emoji
cw: Aviso de contenido
sendPushNotificationReadMessage: Eliminar notificaciones una vez que la notificación
o mensaje ha sido leído
sendPushNotificationReadMessageCaption: Una notificación con el texto "{emptyPushNotificationMessage}"
será mostrada por un breve período. Esto podría aumentar el uso de batería de tu
dispositivo.
enableServerMachineStats: Permitir estadísticas del hardware del servidor
customMOTD: Mensaje del día personalizado (mensajes de la pantalla de presentación)
antennasDesc: "Las Antennas muestran nuevas publicaciones que conciden con los criterios
que estableciste.\nPueden ser accedidas desde la sección de Lineas de tiempo."
antennaInstancesDescription: Escribe un servidor por cada linea
expandOnNoteClickDesc: Si está desactivado, puedes abrir publicaciones usando el menú
del botón derecho del ratón o presionando sobre la fecha.
channelFederationWarn: Los Canales aún no federan con otras instancias
clipsDesc: Los clips como marcadores categorizados que pueden ser compartidos. Puedes
crear clips desde el menú de publicaciones.
verifiedLink: Vínculo verificado
cannotUploadBecauseExceedsFileSizeLimit: Este archivo no pudo ser cargado porque excede
el tamaño máximo permitido.
accessibility: Accesibilidad
_filters:
fromUser: Del usuario
fromDomain: Desde el dominio
notesAfter: Publicaciones posteriores
userSaysSomethingReasonReply: '{name} respondió a una publicación que contiene {reason}'
userSaysSomethingReasonQuote: '{name} citó una publicación que contiene {reason}'
privateModeInfo: Al activar, solo servidores autorizados podrán federar con tu servidor.
Todas las publicaiones estáran ocultas del público.
customMOTDDescription: Mensajes del día personalizados (MOTD) de la pantalla de presentación,
separados cada salto de linea. Para ser mostrados aleatoriamente cada vez que un
usuario carga/recarga una página.
customSplashIcons: Icono personalizado de la pantalla de presentación (url)
donationLink: Vinculo a página de donación
delete2fa: Desactivar autentificación en dos pasos
delete2faConfirm: Esto eliminara irreversiblemente la autentificación en dos pasos
de esta cuenta. ¿Quieres continuar?
allowedInstancesDescription: Host de los servidores autorizados para federar, cada
uno separado por una nueva linea (solo aplica en modo pivado).
adminCustomCssWarn: Está configuración solo debería ser utilizado si sabes lo que
hace. Ingresar valores erroneos podría causar que TODOS los clientes dejaran de
funcionar normalmente. Porfavor asegurate que tus CSS funcionan adecuadamente al
probar los en tus configuraciones de usuario.
image: Imagen
showPopup: Notificar a los usuarios con una ventana emergente
showWithSparkles: Mostrar con destellos
youHaveUnreadAnnouncements: Tienes anuncios sin leer
neverShow: No mostrar nuevamente
remindMeLater: Recordar nuevamente
removeQuote: Eliminar cita
removeRecipient: Eliminar destinatario
removeMember: Eliminar miembro

View File

@ -55,7 +55,7 @@ attachCancel: Poista liite
enterFileName: Anna tiedostonimi
mute: Hiljennä
unmute: Poista hiljennys
headlineMisskey: Avoimen lähdekoodin, hajautettu sosiaalisen median alusta, joka on
headlineFirefish: Avoimen lähdekoodin, hajautettu sosiaalisen median alusta, joka on
ikuisesti ilmainen! 🚀
monthAndDay: '{day}/{month}'
deleteAndEditConfirm: Oletko varma, että haluat poistaa tämän lähetyksen ja muokata
@ -214,7 +214,7 @@ perDay: Päivässä
version: Versio
statistics: Tilastot
clearQueueConfirmTitle: Oletko varma, että haluat tyhjentää jonon?
introMisskey: Tervetuloa! Firefish on avoimen lähdekoodin, hajautettu sosiaalisen median
introFirefish: Tervetuloa! Firefish on avoimen lähdekoodin, hajautettu sosiaalisen median
alusta, joka on ikuisesti ilmainen! 🚀
clearQueueConfirmText: Mitkään välittämättömät lähetykset, jotka ovat jonossa, eivät
federoidu. Yleensä tätä toimintoa ei tarvita.

File diff suppressed because it is too large Load Diff

View File

@ -1,5 +1,5 @@
_lang_: Inglés
introMisskey: Benvida! Firefish é unha plataforma de medios sociais de código aberto,
introFirefish: Benvida! Firefish é unha plataforma de medios sociais de código aberto,
descentralizada e gratuíta para sempre!🚀
monthAndDay: '{day}/{month}'
notifications: Notificacións
@ -8,10 +8,277 @@ forgotPassword: Esquecín o contrasinal
gotIt: Vale!
cancel: Cancelar
noThankYou: Non, grazas
headlineMisskey: Plataforma de medios sociais de código aberto e descentralizada,
headlineFirefish: Plataforma de medios sociais de código aberto e descentralizada,
gratuíta para sempre!🚀
search: Buscar
searchPlaceholder: Buscar en Firefish
username: Identificador
fetchingAsApObject: Descargando desde o Fediverso
ok: OK
youShouldUpgradeClient: Actualiza esta páxina para recibir os últimos contidos no
teu cliente.
privacy: Privacidade
makeFollowManuallyApprove: As solicitudes de seguimento requiren aprobación
defaultNoteVisibility: Visibilidade por defecto
follow: Seguir
followRequests: Solicitudes de seguimento
followRequestPending: Solicitude de seguimento pendente
renote: Promover
unrenote: Retirar promoción
renoted: Promovida.
cantReRenote: Unha promoción non pode ser promovida.
quote: Citar
pinnedNote: Publicación fixada
pinned: Fixar no perfil
you: Ti
clickToShow: Preme para mostrar
sensitive: NSFW
add: Engadir
reaction: Reaccións
removeReaction: Quitar a túa reacción
enableEmojiReactions: Activar as reaccións con emojis
showEmojisInReactionNotifications: Mostrar emojis nas notificacións das reaccións
reactionSetting: Reaccións mostradas no selector de reaccións
reactionSettingDescription2: Arrastra para reordenar, preme para eliminar, preme "+"
para engadir.
rememberNoteVisibility: Lembrar os axustes da visibilidade da publicación
attachCancel: Quitar o anexo
markAsSensitive: Marcar como NSFW
unmarkAsSensitive: Retirar marca NSFW
enterFileName: Escribe nome do ficheiro
mute: Acalar
unmute: Reactivar
renoteMute: Acalar promocións
renoteUnmute: Reactivar promocións
block: Bloquear
unblock: Desbloquear
suspend: Suspender
unsuspend: Retirar suspensión
timeline: Cronoloxía
noAccountDescription: Esta usuaria aínda non escribiu a súa bio.
login: Acceder
loggingIn: Accedendo
logout: Pechar sesión
signup: Crear conta
uploading: Subindo...
save: Gardar
users: Usuarias
addUser: Engadir unha usuaria
addInstance: Engadir un servidor
favorite: Engadir aos marcadores
favorites: Marcadores
unfavorite: Quitar dos marcadores
favorited: Engadido aos marcadores.
alreadyFavorited: Xa está nos marcadores.
cantFavorite: Non se puido engadir aos marcadores.
pin: Fixar no perfil
unpin: Soltar do perfil
copyContent: Copiar contidos
copyLink: Copiar ligazón
delete: Eliminar
deleted: Eliminado
deleteAndEdit: Eliminar e editar
blockConfirm: Tes a certeza de querer bloquear esta conta?
deleteAndEditConfirm: Tes a certeza de querer eliminar esta publicación e editala?
Perderás todas as súas reaccións, promocións e respostas.
editNote: Editar nota
edited: Editado o {date} {time}
sendMessage: Enviar unha mensaxe
copyUsername: Copiar identificador
searchUser: Buscar unha usuaria
reply: Responder
jumpToPrevious: Ir á anterior
loadMore: Cargar máis
showMore: Mostrar máis
newer: máis novo
older: máis antigo
showLess: Pechar
youGotNewFollower: seguíute
receiveFollowRequest: Recibida solicitude de seguimento
followRequestAccepted: Solicitude de seguimento aceptada
mention: Mención
mentions: Mencións
directNotes: Mensaxes directas
cw: Aviso sobre o contido
importAndExport: Importar/Exportar datos
import: Importar
export: Exportar
files: Ficheiros
download: Descargar
unblockConfirm: Tes a certeza de querer retirarlle o bloqueo a esta conta?
suspendConfirm: Tes a certeza de querer suspender esta conta?
unsuspendConfirm: Tes a certeza de querer retirarlle a suspensión a esta conta?
selectList: Elixe unha lista
selectAntenna: Elixe unha antena
selectWidget: Elixe un widget
selectChannel: Elixe unha canle
editWidgets: Editar widgets
editWidgetsExit: Feito
customEmojis: Emoji personalizado
emoji: Emoji
emojis: Emoji
emojiName: Nome do emoji
emojiUrl: URL do emoji
addEmoji: Engadir
settingGuide: Axustes recomendados
cacheRemoteFiles: Gardar na caché ficheiros remotos
cacheRemoteFilesDescription: Se desactivas este axuste, os ficheiros remotos cárganse
directamente desde o servidor remoto. Ao desactivalo diminuirá a almacenaxe usada,
pero incrementarás o tráfico, xa que non se crearán miniaturas.
flagAsBotDescription: Activa esta opción se esta conta está controlada por un programa.
Se está activada, será unha marca para que outras desenvolvedoras eviten interaccións
en bucle con outros bots e axustará os sistemas internos de Firefish para tratar
esta conta como un bot.
flagAsCat: Es un gato? 😺
flagAsCatDescription: Vas ter orellas de gato e falar como un gato!
flagSpeakAsCat: Fala como un gato
flagSpeakAsCatDescription: As túas publicacións serán gatificadas ao estar no modo
gato
flagShowTimelineReplies: Mostrar respostas na cronoloxía
flagShowTimelineRepliesDescription: Se está activado mostra as respostas das usuarias
a publicacións de outras usuarias na cronoloxía.
autoAcceptFollowed: Aprobar automáticamente as solicitudes de seguimento das persoas
que ti xa segues
addAccount: Engadir conta
loginFailed: Fallou o inicio de sesión
showOnRemote: Abrir páxina orixinal
general: Xeral
accountMoved: 'A usuaria está nunha nova conta:'
wallpaper: Fondo de pantalla
setWallpaper: Establecer fondo
removeWallpaper: Eliminar fondo
searchWith: 'Buscar: {q}'
youHaveNoLists: Non tes ningunha lista
stopActivityDelivery: Deixar de enviar actividades
perDay: Por día
blockThisInstance: Bloquear este servidor
silenceThisInstance: Acalar este servidor
operations: Operacións
software: Software
version: Versión
metadata: Metadatos
monitor: Monitor
cantRenote: Non se pode promover esta publicación.
clearCachedFiles: Limpar caché
jobQueue: Cola de tarefas
cpuAndMemory: CPU e Memoria
network: Rede
disk: Disco
instanceInfo: Información do servidor
statistics: Estatísticas
clearQueue: Limpar cola
clearQueueConfirmTitle: Tes a certeza de querer limpara a cola?
clearQueueConfirmText: Todas as publicacións que aínda non fosen entregadas non estarán
federadas. Esta operación, normalmente, non é necesaria.
clearCachedFilesConfirm: Tes a certeza de que queres eliminar todos os ficheiros remotos
da caché?
blockedInstances: Servidores bloqueados
blockedInstancesDescription: Lista dos nomes dos servidores que queres bloquear. Os
servidores da lista non poderán comunicarse con este servidor.
silencedInstances: Servidores acalados
silencedInstancesDescription: Lista cos nomes de servidores que queres acalar. As
contas dos servidores acalados serán tratadas como "Silenciadas", só poden facer
solicitudes de seguimento e non poden mencionar contas locais se non a están a seguir.
Isto non afecta aos servidores bloqueados.
hiddenTags: Cancelos agochados
hiddenTagsDescription: 'Lista cos cancelos (sen o #) que queres ocultar das seccións
descubrir e en voga. Os cancelos agochados seguirán sendo accesibles por outros
medios.'
muteAndBlock: Bloquear e Silenciar
mutedUsers: Usuarias acaladas
blockedUsers: Usuarias bloqueadas
noUsers: Sen usuarias
noInstances: Sen servidores
editProfile: Editar perfil
noteDeleteConfirm: Tes a certeza de querer eliminar esta publicación?
pinLimitExceeded: Xa non podes fixar máis publicacións
intro: Rematou a instalación de Fishfox! Por favor crea a usuaria administradora.
done: Feito
processing: Procesando
preview: Vista previa
default: Por defecto
defaultValueIs: 'Por defecto: {value}'
noCustomEmojis: Non hai emojis
noJobs: Non hai tarefas
blocked: Bloqueado
federating: Federación
silenced: Acalado
suspended: Suspendido
all: Todo
subscribing: Subscrición
publishing: Publicar
notResponding: Non responde
instanceFollowing: Seguindo no servidor
instanceFollowers: Seguidoras desde o servidor
instanceUsers: Usuarias neste servidor
security: Seguridade
retypedNotMatch: Os valores escritos non concordan.
changePassword: Cambiar contrasinal
currentPassword: Contrasinal actual
newPassword: Novo contrasinal
newPasswordRetype: Volve escribir o contrasinal
attachFile: Adxunta ficheiros
more: Máis!
featured: Destacado
usernameOrUserId: Identificador ou id de usuaria
noSuchUser: Non se atopa a usuaria
remove: Eliminar
removed: Eliminada correctamente
removeAreYouSure: Tes a certeza de querer eliminar "{x}"?
announcements: Anuncios
imageUrl: URL da imaxe
enterUsername: Escribir identificador
renotedBy: Promovido por {user}
noNotes: Sen publicacións
noNotifications: Sen notificacións
instance: Servidor
settings: Axustes
basicSettings: Axustes básicos
otherSettings: Outros axustes
openInWindow: Abrir na ventá
profile: Perfil
addToList: Engadir á lista
lists: Listas
listsDesc: As listas permítenche crear cronoloxías coas usuarias escollidas. Podes
acceder a elas desde a páxina de cronoloxías.
noLists: Non tes ningunha lista
note: Publicación
notes: Publicacións
following: Seguindo
followers: Seguidoras
followsYou: Séguete
createList: Crear lista
manageLists: Xestionar listas
error: Erro
somethingHappened: Houbo un fallo
retry: Volver a intentar
pageLoadError: Algo fallou ao cargar a páxina.
pageLoadErrorDescription: Normalmente isto débese a problemas na rede ou na caché
do navegador. Intenta limpar a caché e volve a intentalo dentro dun anaco.
serverIsDead: Este servidor non responde. Agarda un anaco e volve intentalo.
enterListName: Dalle un nome á lista
unfollow: Deixar de seguir
enterEmoji: Escribe un emoji
flagAsBot: Marcar a conta como bot
followConfirm: Tes a certeza de querer seguir a {name}?
proxyAccount: Conta proxy
proxyAccountDescription: Unha conta proxy é unha conta que en determinadas situacións
actúa como unha seguidora remota para as usuarias. Por exemplo, cando unha usuaria
engade unha usuaria remota a unha lista, a actividade da usuaria remota non se entrega
ao servidor se a usuaria local non segue a esa outra usuaria, así a conta proxy
fará o seguimento no seu lugar.
host: Hóspede
selectUser: Escolle unha usuaria
selectInstance: Escolle un servidor
recipient: Correpondente(s)
annotation: Comentarios
federation: Federación
instances: Servidores
registeredAt: Data do rexistro
latestRequestSentAt: Última solicitude enviada
latestRequestReceivedAt: Última solicitude recibida
latestStatus: Último estado
storageUsage: Uso da almacenaxe
charts: Gráficas
perHour: Por hora
followRequest: Solicitar seguimento

File diff suppressed because it is too large Load Diff

View File

@ -71,15 +71,15 @@ module.exports = Object.entries(locales).reduce(
(a[k] = (() => {
const [lang] = k.split("-");
switch (k) {
case "ja-JP":
return v;
case "ja-KS":
case "en-US":
return merge(locales["ja-JP"], v);
return v;
case "ja-JP":
case "ja-KS":
return merge(locales["en-US"], v);
default:
return merge(
locales["ja-JP"],
locales["en-US"],
locales["ja-JP"],
locales[`${lang}-${primaries[lang]}`] || {},
v,
);

View File

@ -1,6 +1,6 @@
_lang_: "Italiano"
headlineMisskey: "Rete collegata tramite note"
introMisskey: "Benvenut@! Firefish è un servizio di microblogging decentralizzato,
headlineFirefish: "Rete collegata tramite note"
introFirefish: "Benvenut@! Firefish è un servizio di microblogging decentralizzato,
libero e aperto. \nScrivi \"note\" per condividere ciò che sta succedendo adesso
o per dire a tutti qualcosa di te. 📡\nGrazie alla funzione \"reazioni\" puoi anche
mandare reazioni rapide alle note delle altre persone del Fediverso. 👍\nEsplora

View File

@ -1,6 +1,6 @@
_lang_: "日本語"
headlineMisskey: "ずっと無料でオープンソースの非中央集権型ソーシャルメディアプラットフォーム🚀"
introMisskey: "ようこそFirefishは、オープンソースの非中央集権型ソーシャルメディアプラットフォームです。\nいま起こっていることを共有したり、あなたについて皆に発信しましょう📡\n\
headlineFirefish: "ずっと無料でオープンソースの非中央集権型ソーシャルメディアプラットフォーム🚀"
introFirefish: "ようこそFirefishは、オープンソースの非中央集権型ソーシャルメディアプラットフォームです。\nいま起こっていることを共有したり、あなたについて皆に発信しましょう📡\n\
「リアクション」機能で、皆の投稿に素早く反応を追加できます👍\n新しい世界を探検しよう🚀"
monthAndDay: "{month}月 {day}日"
search: "検索"
@ -156,7 +156,7 @@ flagShowTimelineRepliesDescription: "オンにすると、タイムラインに
autoAcceptFollowed: "フォローしているユーザーからのフォロー申請を自動承認"
addAccount: "アカウントを追加"
loginFailed: "ログインに失敗しました"
showOnRemote: "リモートで表示"
showOnRemote: "オリジナルのページを開く"
general: "全般"
accountMoved: "このユーザーは新しいアカウントに移行しました"
wallpaper: "壁紙"
@ -517,6 +517,8 @@ objectStorageUseSSLDesc: "API接続にhttpsを使用しない場合はオフに
objectStorageUseProxy: "Proxyを利用する"
objectStorageUseProxyDesc: "API接続にproxyを利用しない場合はオフにしてください"
objectStorageSetPublicRead: "アップロード時に'public-read'を設定する"
objectStorageS3ForcePathStyle: "DNS名ではなくてパスを使用する"
objectStorageS3ForcePathStyleDesc: "EndpointのURLを作る際には、'<bucket>.s3.amazonaws.com'の代わりに's3.amazonaws.com/<bucket>/'のようなスタイルを使用します。"
serverLogs: "サーバーログ"
deleteAll: "全て削除"
showFixedPostForm: "タイムライン上部に投稿フォームを表示する"
@ -854,7 +856,7 @@ unmuteThread: "スレッドのミュートを解除"
ffVisibility: "つながりの公開範囲"
ffVisibilityDescription: "自分のフォロー/フォロワー情報の公開範囲を設定できます。"
continueThread: "さらにスレッドを見る"
deleteAccountConfirm: "アカウントが削除されます。よろしいですか?"
deleteAccountConfirm: "このアカウントが削除されます。よろしいですか?"
incorrectPassword: "パスワードが間違っています。"
voteConfirm: "「{choice}」に投票しますか?"
hide: "隠す"
@ -985,6 +987,7 @@ showWithSparkles: "タイトルをキラキラさせる"
youHaveUnreadAnnouncements: "未読のお知らせがあります"
neverShow: "今後表示しない"
remindMeLater: "また後で"
addRe: "閲覧注意の投稿への返信で、注釈の先頭に\"re:\"を追加する"
_sensitiveMediaDetection:
description: "機械学習を使って自動でセンシティブなメディアを検出し、モデレーションに役立てられます。サーバーの負荷が少し増えます。"
@ -1064,6 +1067,7 @@ _aboutFirefish:
about: "Firefishは、2022年に生まれたThatOneCalculatorによるMisskeyのforkです。"
contributors: "主なコントリビューター"
allContributors: "全てのコントリビューター"
misskeyContributors: "フォーク元のMisskeyの主なコントリビューター"
source: "ソースコード"
translation: "Firefishを翻訳"
donate: "Firefishに寄付"
@ -1074,6 +1078,7 @@ _aboutFirefish:
pleaseDonateToHost: また、このサーバー {host} の運営者への寄付もご検討ください。
donateHost: '{host} に寄付する'
donateTitle: Firefishを気に入りましたか
sponsors: Firefish の支援者
_nsfw:
respect: "閲覧注意のメディアは隠す"
ignore: "閲覧注意のメディアを隠さない"
@ -1959,3 +1964,10 @@ donationLink: 寄付ページへのリンク
removeMember: メンバーを削除
removeQuote: 引用を削除
removeRecipient: 宛先を削除
verifiedLink: 認証済みリンク
_feeds:
atom: Atom
rss: RSS
jsonFeed: JSONフィード
copyFeed: フィードのURLをコピー
origin: 起源

View File

@ -1,7 +1,7 @@
---
_lang_: "日本語 (関西弁)"
headlineMisskey: "ノートでつながるネットワーク"
introMisskey: "ようお越しMisskeyは、オープンソースの分散型マイクロブログサービスやねん。\n「ート」を作って、いま起こっとることを共有したり、あんたについて皆に発信しよう📡\n「リアクション」機能で、皆のートに素早く反応を追加したりもできるで✌\nほな新しい世界を探検しよか🚀"
headlineFirefish: "ノートでつながるネットワーク"
introFirefish: "ようお越しMisskeyは、オープンソースの分散型マイクロブログサービスやねん。\n「ート」を作って、いま起こっとることを共有したり、あんたについて皆に発信しよう📡\n「リアクション」機能で、皆のートに素早く反応を追加したりもできるで✌\nほな新しい世界を探検しよか🚀"
monthAndDay: "{month}月 {day}日"
search: "探す"
notifications: "通知"

View File

@ -1,6 +1,6 @@
---
_lang_: "ಕನ್ನಡ"
introMisskey: "ಸ್ವಾಗತ! Firefish ಓಪನ್ ಸೋರ್ಸ್ ಒಕ್ಕೂಟ ಮೈಕ್ರೋಬ್ಲಾಗಿಂಗ್ ಸೇವೆಯಾಗಿದೆ.\n ಏನಾಗುತ್ತಿದೆ ಎಂಬುದನ್ನು ಹಂಚಿಕೊಳ್ಳಲು ಅಥವಾ ನಿಮ್ಮ ಬಗ್ಗೆ ಎಲ್ಲರಿಗೂ ಹೇಳಲು \"ಟಿಪ್ಪಣಿ\"ಗಳನ್ನು ರಚಿಸಿ📡\n \"ಸ್ಪಂದನೆ\" ಕ್ರಿಯೆಯೊಂದಿಗೆ, ನೀವು ಎಲ್ಲರ ಟಿಪ್ಪಣಿಗಳಿಗೆ ತ್ವರಿತವಾಗಿ ಸ್ಪಂದನೆಗಳನ್ನು ಕೂಡ ಸೇರಿಸಬಹುದು.👍\n ಹೊಸ ಜಗತ್ತನ್ನು ಅನ್ವೇಷಿಸಿ🚀"
introFirefish: "ಸ್ವಾಗತ! Firefish ಓಪನ್ ಸೋರ್ಸ್ ಒಕ್ಕೂಟ ಮೈಕ್ರೋಬ್ಲಾಗಿಂಗ್ ಸೇವೆಯಾಗಿದೆ.\n ಏನಾಗುತ್ತಿದೆ ಎಂಬುದನ್ನು ಹಂಚಿಕೊಳ್ಳಲು ಅಥವಾ ನಿಮ್ಮ ಬಗ್ಗೆ ಎಲ್ಲರಿಗೂ ಹೇಳಲು \"ಟಿಪ್ಪಣಿ\"ಗಳನ್ನು ರಚಿಸಿ📡\n \"ಸ್ಪಂದನೆ\" ಕ್ರಿಯೆಯೊಂದಿಗೆ, ನೀವು ಎಲ್ಲರ ಟಿಪ್ಪಣಿಗಳಿಗೆ ತ್ವರಿತವಾಗಿ ಸ್ಪಂದನೆಗಳನ್ನು ಕೂಡ ಸೇರಿಸಬಹುದು.👍\n ಹೊಸ ಜಗತ್ತನ್ನು ಅನ್ವೇಷಿಸಿ🚀"
monthAndDay: "{month}ನೇ ತಿಂಗಳ {day}ನೇ ದಿನ"
search: "ಹುಡುಕು"
notifications: "ಅಧಿಸೂಚನೆಗಳು"

View File

@ -1,7 +1,8 @@
---
_lang_: "한국어"
headlineMisskey: "노트로 연결되는 네트워크"
introMisskey: "환영합니다! Firefish 는 오픈 소스 분산형 마이크로 블로그 서비스입니다.\n\"노트\" 를 작성해서, 지금 일어나고 있는 일을 공유하거나, 당신만의 이야기를 모두에게 발신하세요📡\n\"리액션\" 기능으로, 친구의 노트에 총알같이 반응을 추가할 수도 있습니다👍\n새로운 세계를 탐험해 보세요🚀"
headlineFirefish: "노트로 연결되는 네트워크"
introFirefish: "환영합니다! Firefish 는 오픈 소스 분산형 마이크로 블로그 서비스입니다.\n\"노트\" 를 작성해서, 지금 일어나고
있는 일을 공유하거나, 당신만의 이야기를 모두에게 발신하세요📡\n\"리액션\" 기능으로, 친구의 노트에 총알같이 반응을 추가할 수도 있습니다👍\n
새로운 세계를 탐험해 보세요🚀"
monthAndDay: "{month}월 {day}일"
search: "검색"
notifications: "알림"
@ -16,7 +17,7 @@ enterUsername: "유저명 입력"
renotedBy: "{user}님이 Renote"
noNotes: "노트가 없습니다"
noNotifications: "표시할 알림이 없습니다"
instance: "인스턴스"
instance: "서버"
settings: "설정"
basicSettings: "기본 설정"
otherSettings: "기타 설정"
@ -64,7 +65,7 @@ import: "가져오기"
export: "내보내기"
files: "파일"
download: "다운로드"
driveFileDeleteConfirm: "파일 \"{name}\" 을 삭제하시겠습니까? 이 파일이 첨부된 노트도 함께 삭제됩니다."
driveFileDeleteConfirm: "파일 \"{name}\" 을 삭제하시겠습니까? 이 파일이 첨부되었더 노트에서도 같이 삭제됩니다."
unfollowConfirm: "{name}님을 언팔로우하시겠습니까?"
exportRequested: "내보내기를 요청하였습니다. 이 작업은 시간이 걸릴 수 있습니다. 내보내기가 완료되면 \"드라이브\"에 추가됩니다."
importRequested: "가져오기를 요청하였습니다. 이 작업에는 시간이 걸릴 수 있습니다."
@ -81,7 +82,8 @@ error: "오류"
somethingHappened: "오류가 발생했습니다"
retry: "다시 시도"
pageLoadError: "페이지를 불러오지 못했습니다."
pageLoadErrorDescription: "네트워크 연결 또는 브라우저 캐시로 인해 발생했을 가능성이 높습니다. 캐시를 삭제하거나, 잠시 후 다시 시도해 주세요."
pageLoadErrorDescription: "네트워크 연결 또는 브라우저 캐시로 인해 발생했을 가능성이 높습니다. 캐시를 삭제하거나, 잠시 후
다시 시도해 주세요."
serverIsDead: "서버로부터 응답이 없습니다. 잠시 후 다시 시도해주세요."
youShouldUpgradeClient: "이 페이지를 표시하려면 새로고침하여 새로운 버전의 클라이언트를 이용해 주십시오."
enterListName: "리스트 이름을 입력"
@ -137,9 +139,11 @@ emojiUrl: "이모지 URL"
addEmoji: "이모지 추가"
settingGuide: "추천 설정"
cacheRemoteFiles: "리모트 파일을 캐시"
cacheRemoteFilesDescription: "이 설정을 해지하면 리모트 파일을 캐시하지 않고 해당 파일을 직접 링크하게 됩니다. 그에 따라 서버의 저장 공간을 절약할 수 있지만, 썸네일이 생성되지 않기 때문에 통신량이 증가합니다."
cacheRemoteFilesDescription: "이 설정을 해지하면 리모트 파일을 캐시하지 않고 해당 파일을 직접 링크하게 됩니다. 그에 따라
서버의 저장 공간을 절약할 수 있지만, 썸네일이 생성되지 않기 때문에 통신량이 증가합니다."
flagAsBot: "나는 봇입니다"
flagAsBotDescription: "이 계정을 자동화된 수단으로 운용할 경우에 활성화해 주세요. 이 플래그를 활성화하면, 다른 봇이 이를 참고하여 봇 끼리의 무한 연쇄 반응을 회피하거나, 이 계정의 시스템 상에서의 취급이 Bot 운영에 최적화되는 등의 변화가 생깁니다."
flagAsBotDescription: "이 계정을 자동화된 수단으로 운용할 경우에 활성화해 주세요. 이 플래그를 활성화하면, 다른 봇이 이를 참고하여
봇 끼리의 무한 연쇄 반응을 회피하거나, 이 계정의 시스템 상에서의 취급이 Bot 운영에 최적화되는 등의 변화가 생깁니다."
flagAsCat: "나는 고양이다냥"
flagAsCatDescription: "이 계정이 고양이라면 활성화 해주세요."
flagShowTimelineReplies: "타임라인에 노트의 답글을 표시하기"
@ -147,7 +151,7 @@ flagShowTimelineRepliesDescription: "이 설정을 활성화하면 타임라인
autoAcceptFollowed: "팔로우 중인 유저로부터의 팔로우 요청을 자동 수락"
addAccount: "계정 추가"
loginFailed: "로그인에 실패했습니다"
showOnRemote: "리모트에서 보기"
showOnRemote: "원본 페이지 열기"
general: "일반"
wallpaper: "배경"
setWallpaper: "배경화면 설정"
@ -156,13 +160,15 @@ searchWith: "검색: {q}"
youHaveNoLists: "리스트가 없습니다"
followConfirm: "{name}님을 팔로우 하시겠습니까?"
proxyAccount: "프록시 계정"
proxyAccountDescription: "프록시 계정은 특정 조건 하에서 유저의 리모트 팔로우를 대행하는 계정입니다. 예를 들면, 유저가 리모트 유저를 리스트에 넣었을 때, 리스트에 들어간 유저를 아무도 팔로우한 적이 없다면 액티비티가 인스턴스로 배달되지 않기 때문에, 대신 프록시 계정이 해당 유저를 팔로우하도록 합니다."
proxyAccountDescription: "프록시 계정은 특정 조건 하에서 유저의 리모트 팔로우를 대행하는 계정입니다. 예를 들면, 유저가 리모트
유저를 리스트에 넣었을 때, 리스트에 들어간 유저를 아무도 팔로우한 적이 없다면 액티비티가 서버로 배달되지 않기 때문에, 대신 프록시 계정이 해당
유저를 팔로우하도록 합니다."
host: "호스트"
selectUser: "유저 선택"
recipient: "수신인"
annotation: "내용에 대한 주석"
federation: "연합"
instances: "인스턴스"
instances: "서버"
registeredAt: "등록 날짜"
latestRequestSentAt: "마지막으로 요청을 보낸 시간"
latestRequestReceivedAt: "마지막으로 요청을 받은 시간"
@ -172,7 +178,7 @@ charts: "차트"
perHour: "1시간마다"
perDay: "1일마다"
stopActivityDelivery: "액티비티 보내지 않기"
blockThisInstance: "이 인스턴스를 차단"
blockThisInstance: "이 서버를 차단"
operations: "작업"
software: "소프트웨어"
version: "버전"
@ -182,21 +188,22 @@ jobQueue: "작업 대기열"
cpuAndMemory: "CPU와 메모리"
network: "네트워크"
disk: "디스크"
instanceInfo: "인스턴스 정보"
instanceInfo: "서버 정보"
statistics: "통계"
clearQueue: "대기열 비우기"
clearQueueConfirmTitle: "대기열을 비우시겠습니까?"
clearQueueConfirmText: "대기열에 남아 있는 노트는 더이상 연합되지 않습니다. 보통의 경우 이 작업은 필요하지 않습니다."
clearQueueConfirmText: "대기열에 남아 있는 게시물이 연합되지 않습니다. 보통의 경우 이 작업은 필요하지 않습니다."
clearCachedFiles: "캐시 비우기"
clearCachedFilesConfirm: "캐시된 리모트 파일을 모두 삭제하시겠습니까?"
blockedInstances: "차단된 인스턴스"
blockedInstancesDescription: "차단하려는 인스턴스의 호스트 이름을 줄바꿈으로 구분하여 설정합니다. 차단된 인스턴스는 이 인스턴스와 통신할 수 없게 됩니다."
blockedInstances: "차단한 서버"
blockedInstancesDescription: "차단하려는 서버의 호스트 이름을 줄바꿈으로 구분하여 설정합니다. 차단된 서버는 이 서버와 통신할
수 없게 됩니다."
muteAndBlock: "뮤트 및 차단"
mutedUsers: "뮤트한 유저"
blockedUsers: "차단한 유저"
noUsers: "아무도 없습니다"
editProfile: "프로필 수정"
noteDeleteConfirm: "이 노트를 삭제하시겠습니까?"
noteDeleteConfirm: "이 게시물을 삭제하시겠습니까?"
pinLimitExceeded: "더 이상 고정할 수 없습니다."
intro: "Misskey의 설치가 완료되었습니다! 관리자 계정을 생성해주세요."
done: "완료"
@ -213,9 +220,9 @@ all: "전체"
subscribing: "구독 중"
publishing: "배포 중"
notResponding: "응답 없음"
instanceFollowing: "인스턴스의 팔로잉"
instanceFollowers: "인스턴스의 팔로워"
instanceUsers: "인스턴스의 유저"
instanceFollowing: "서버 팔로잉"
instanceFollowers: "서버 팔로워"
instanceUsers: "서버 유저"
changePassword: "비밀번호 변경"
security: "보안"
retypedNotMatch: "입력이 일치하지 않습니다."
@ -239,7 +246,8 @@ saved: "저장하였습니다"
messaging: "대화"
upload: "업로드"
keepOriginalUploading: "원본 이미지를 유지"
keepOriginalUploadingDescription: "이미지를 업로드할 때에 원본을 그대로 유지합니다. 비활성화하면 업로드할 때 브라우저에서 웹 공개용 이미지를 생성합니다."
keepOriginalUploadingDescription: "이미지를 업로드할 때에 원본을 그대로 유지합니다. 비활성화하면 업로드할 때 브라우저에서
웹 공개용 이미지를 생성합니다."
fromDrive: "드라이브에서"
fromUrl: "URL로부터"
uploadFromUrl: "URL 업로드"
@ -305,8 +313,8 @@ unwatch: "지켜보기 해제"
accept: "허가"
reject: "거부"
normal: "정상"
instanceName: "인스턴스 이름"
instanceDescription: "인스턴스 소개"
instanceName: "서버 이름"
instanceDescription: "서버 소개"
maintainerName: "관리자 이름"
maintainerEmail: "관리자 이메일"
tosUrl: "이용약관 URL"
@ -336,9 +344,9 @@ basicInfo: "기본 정보"
pinnedUsers: "고정된 유저"
pinnedUsersDescription: "\"발견하기\" 페이지 등에 고정하고 싶은 유저를 한 줄에 한 명씩 적습니다."
pinnedPages: "고정한 페이지"
pinnedPagesDescription: "인스턴스의 대문에 고정하고 싶은 페이지의 경로를 한 줄에 하나씩 적습니다."
pinnedPagesDescription: "서버 대문에 고정할 페이지의 경로를 한 줄에 하나씩 적습니다."
pinnedClipId: "고정할 클립의 ID"
pinnedNotes: "고정해놓은 노트"
pinnedNotes: "고정한 글"
hcaptcha: "hCaptcha"
enableHcaptcha: "hCaptcha 활성화"
hcaptchaSiteKey: "사이트 키"
@ -347,7 +355,8 @@ recaptcha: "reCAPTCHA"
enableRecaptcha: "reCAPTCHA 활성화"
recaptchaSiteKey: "사이트 키"
recaptchaSecretKey: "시크릿 키"
avoidMultiCaptchaConfirm: "여러 Captcha를 사용하는 경우 간섭이 발생할 가능성이 있습니다. 다른 Captcha를 비활성화하시겠습니까? 취소를 눌러 여러 Captcha를 활성화한 상태로 두는 것도 가능합니다."
avoidMultiCaptchaConfirm: "여러 Captcha를 사용하는 경우 간섭이 발생할 가능성이 있습니다. 다른 Captcha를 비활성화하시겠습니까?
취소를 눌러 여러 Captcha를 활성화한 상태로 두는 것도 가능합니다."
antennas: "안테나"
manageAntennas: "안테나 관리"
name: "이름"
@ -355,8 +364,8 @@ antennaSource: "받을 소스"
antennaKeywords: "받을 키워드"
antennaExcludeKeywords: "제외할 키워드"
antennaKeywordsDescription: "공백으로 구분하는 경우 AND, 줄바꿈으로 구분하는 경우 OR로 지정됩니다"
notifyAntenna: "새로운 노트를 알림"
withFileAntenna: "파일이 첨부된 노트만"
notifyAntenna: "새로운 글을 알림"
withFileAntenna: "파일이 첨부된 게시물만"
enableServiceworker: "ServiceWorker 사용"
antennaUsersDescription: "유저명을 한 줄에 한 명씩 적습니다"
caseSensitive: "대소문자를 구분"
@ -420,7 +429,7 @@ text: "텍스트"
enable: "사용"
next: "다음"
retype: "다시 입력"
noteOf: "{user}의 노트"
noteOf: "{user}의 게시물"
inviteToGroup: "그룹에 초대하기"
quoteAttached: "인용함"
quoteQuestion: "인용해서 작성하시겠습니까?"
@ -478,20 +487,25 @@ accountSettings: "계정 설정"
promotion: "프로모션"
promote: "프로모션하기"
numberOfDays: "며칠동안"
hideThisNote: "이 노트를 숨기기"
showFeaturedNotesInTimeline: "타임라인에 추천 노트를 표시"
hideThisNote: "이 글을 숨기기"
showFeaturedNotesInTimeline: "타임라인에 추천 게시물을 표시"
objectStorage: "오브젝트 스토리지"
useObjectStorage: "오브젝트 스토리지를 사용"
objectStorageBaseUrl: "Base URL"
objectStorageBaseUrlDesc: "오브젝트 (미디어) 참조 URL 을 만들 때 사용되는 URL입니다. CDN 또는 프록시를 사용하는 경우 그 URL을 지정하고, 그 외의 경우 사용할 서비스의 가이드에 따라 공개적으로 액세스 할 수 있는 주소를 지정해 주세요. 예를 들어, AWS S3의 경우 'https://<bucket>.s3.amazonaws.com', GCS등의 경우 'https://storage.googleapis.com/<bucket>' 와 같이 지정합니다."
objectStorageBaseUrlDesc: "오브젝트 (미디어) 참조 URL 을 만들 때 사용되는 URL입니다. CDN 또는 프록시를 사용하는
경우 그 URL을 지정하고, 그 외의 경우 사용할 서비스의 가이드에 따라 공개적으로 액세스 할 수 있는 주소를 지정해 주세요. 예를 들어, AWS
S3의 경우 'https://<bucket>.s3.amazonaws.com', GCS등의 경우 'https://storage.googleapis.com/<bucket>'
와 같이 지정합니다."
objectStorageBucket: "Bucket"
objectStorageBucketDesc: "사용 서비스의 bucket명을 지정해주세요."
objectStoragePrefix: "Prefix"
objectStoragePrefixDesc: "이 Prefix 의 디렉토리 아래에 파일이 저장됩니다."
objectStorageEndpoint: "Endpoint"
objectStorageEndpointDesc: "AWS S3의 경우 공란, 다른 서비스의 경우 각 서비스의 가이드에 맞게 endpoint를 설정해주세요. '<host>' 혹은 '<host>:<port>' 와 같이 지정합니다."
objectStorageEndpointDesc: "AWS S3의 경우 공란, 다른 서비스의 경우 각 서비스의 가이드에 맞게 endpoint를 설정해주세요.
'<host>' 혹은 '<host>:<port>' 와 같이 지정합니다."
objectStorageRegion: "Region"
objectStorageRegionDesc: "'xx-east-1'와 같이 region을 지정해주세요. 사용하는 서비스에 region 개념이 없는 경우, 비워 두거나 'us-east-1'으로 설정해 주세요."
objectStorageRegionDesc: "'xx-east-1'와 같이 region을 지정해주세요. 사용하는 서비스에 region 개념이 없는
경우, 비워 두거나 'us-east-1'으로 설정해 주세요."
objectStorageUseSSL: "SSL 사용"
objectStorageUseSSLDesc: "API 호출시 HTTPS 를 사용하지 않는 경우 OFF 로 설정해 주세요"
objectStorageUseProxy: "연결에 프록시를 사용"
@ -500,7 +514,7 @@ objectStorageSetPublicRead: "업로드할 때 'public-read'를 설정하기"
serverLogs: "서버 로그"
deleteAll: "모두 삭제"
showFixedPostForm: "타임라인 상단에 글 작성란을 표시"
newNoteRecived: "새 노트가 있습니다"
newNoteRecived: "새 글이 있습니다"
sounds: "소리"
listen: "듣기"
none: "없음"
@ -523,7 +537,8 @@ sort: "정렬"
ascendingOrder: "오름차순"
descendingOrder: "내림차순"
scratchpad: "스크래치 패드"
scratchpadDescription: "스크래치 패드는 AiScript 의 테스트 환경을 제공합니다. Firefish 와 상호 작용하는 코드를 작성, 실행 및 결과를 확인할 수 있습니다."
scratchpadDescription: "스크래치 패드는 AiScript 의 테스트 환경을 제공합니다. Firefish 와 상호 작용하는 코드를 작성,
실행 및 결과를 확인할 수 있습니다."
output: "출력"
script: "스크립트"
disablePagesScript: "Pages 에서 AiScript 를 사용하지 않음"
@ -531,11 +546,13 @@ updateRemoteUser: "리모트 유저 정보 갱신"
deleteAllFiles: "모든 파일 삭제"
deleteAllFilesConfirm: "모든 파일을 삭제하시겠습니까?"
removeAllFollowing: "모든 팔로잉 해제"
removeAllFollowingDescription: "{host}(으)로부터 모든 팔로잉을 해제합니다. 해당 인스턴스가 더 이상 존재하지 않게 된 경우 등에 실행해 주세요."
removeAllFollowingDescription: "{host}(으)로부터 모든 팔로잉을 해제합니다. 해당 서버가 더 이상 존재하지 않게 된
경우 등에 실행해 주세요."
userSuspended: "이 계정은 정지된 상태입니다."
userSilenced: "이 계정은 사일런스된 상태입니다."
yourAccountSuspendedTitle: "계정이 정지되었습니다"
yourAccountSuspendedDescription: "이 계정은 서버의 이용 약관을 위반하거나, 기타 다른 이유로 인해 정지되었습니다. 자세한 사항은 관리자에게 문의해 주십시오. 계정을 새로 생성하지 마십시오."
yourAccountSuspendedDescription: "이 계정은 서버의 이용 약관을 위반하거나, 기타 다른 이유로 인해 정지되었습니다. 자세한
사항은 관리자에게 문의해 주십시오. 계정을 새로 생성하지 마십시오."
menu: "메뉴"
divider: "구분선"
addItem: "항목 추가"
@ -544,8 +561,8 @@ addRelay: "릴레이 추가"
inboxUrl: "Inbox 주소"
addedRelays: "추가된 릴레이"
serviceworkerInfo: "푸시 알림을 수행하려면 활성화해야 합니다."
deletedNote: "삭제된 노트"
invisibleNote: "비공개 노트"
deletedNote: "삭제된 "
invisibleNote: "비공개 "
enableInfiniteScroll: "자동으로 좀 더 보기"
visibility: "공개 범위"
poll: "투표"
@ -596,7 +613,7 @@ testEmail: "이메일 전송 테스트"
wordMute: "단어 뮤트"
regexpError: "정규 표현식 오류"
regexpErrorDescription: "{tab}단어 뮤트 {line}행의 정규 표현식에 오류가 발생했습니다:"
instanceMute: "인스턴스 뮤트"
instanceMute: "서버 뮤트"
userSaysSomething: "{name}님이 무언가를 말했습니다"
makeActive: "활성화"
display: "표시"
@ -614,7 +631,8 @@ useGlobalSetting: "글로벌 설정을 사용하기"
useGlobalSettingDesc: "활성화하면 계정의 알림 설정이 적용됩니다. 비활성화하면 개별적으로 설정할 수 있게 됩니다."
other: "기타"
regenerateLoginToken: "로그인 토큰을 재생성"
regenerateLoginTokenDescription: "로그인할 때 사용되는 내부 토큰을 재생성합니다. 일반적으로 이 작업을 실행할 필요는 없습니다. 이 기능을 사용하면 이 계정으로 로그인한 모든 기기에서 로그아웃됩니다."
regenerateLoginTokenDescription: "로그인할 때 사용되는 내부 토큰을 재생성합니다. 일반적으로 이 작업을 실행할 필요는 없습니다.
이 기능을 사용하면 이 계정으로 로그인한 모든 기기에서 로그아웃됩니다."
setMultipleBySeparatingWithSpace: "공백으로 구분하여 여러 개 설정할 수 있습니다."
fileIdOrUrl: "파일 ID 또는 URL"
behavior: "동작"
@ -627,35 +645,35 @@ abuseReported: "신고를 보냈습니다. 신고해 주셔서 감사합니다."
reporter: "신고자"
reporteeOrigin: "피신고자"
reporterOrigin: "신고자"
forwardReport: "리모트 인스턴스에도 신고 내용 보내기"
forwardReportIsAnonymous: "리모트 인스턴스에서는 나의 정보를 볼 수 없으며, 익명의 시스템 계정으로 표시됩니다."
forwardReport: "리모트 서버에도 신고 내용 보내기"
forwardReportIsAnonymous: "리모트 서버에서는 나의 정보를 볼 수 없으며, 익명의 시스템 계정으로 표시됩니다."
send: "전송"
abuseMarkAsResolved: "해결됨으로 표시"
openInNewTab: "새 탭에서 열기"
openInSideView: "사이드뷰로 열기"
defaultNavigationBehaviour: "기본 탐색 동작"
editTheseSettingsMayBreakAccount: "이 설정을 변경하면 계정이 손상될 수 있습니다."
instanceTicker: "노트의 인스턴스 정보"
instanceTicker: "게시물의 인스턴스 정보"
waitingFor: "{x}을(를) 기다리고 있습니다"
random: "랜덤"
system: "시스템"
switchUi: "UI 전환"
switchUi: "레이아웃"
desktop: "데스크탑"
clip: "클립"
createNew: "새로 만들기"
optional: "옵션"
createNewClip: "새 클립 만들기"
unclip: "클립 해제"
confirmToUnclipAlreadyClippedNote: "이 노트는 이미 \"{name}\" 클립에 포함되어 있습니다. 클립을 해제하시겠습니까?"
confirmToUnclipAlreadyClippedNote: "이 글은 이미 \"{name}\" 클립에 포함되어 있습니다. 클립을 해제하시겠습니까?"
public: "공개"
i18nInfo: "Firefish는 자원봉사자들에 의해 다양한 언어로 번역되고 있습니다. {link}에서 번역에 참가할 수 있습니다."
manageAccessTokens: "액세스 토큰 관리"
accountInfo: "계정 정보"
notesCount: "노트 수"
notesCount: " 수"
repliesCount: "답글 수"
renotesCount: "Renote 수"
renotesCount: "부스트 수"
repliedCount: "받은 답글 수"
renotedCount: "받은 Renote 수"
renotedCount: "받은 부스트 수"
followingCount: "팔로우 수"
followersCount: "팔로워 수"
sentReactionsCount: "보낸 리액션 수"
@ -667,15 +685,15 @@ no: "아니오"
driveFilesCount: "드라이브 파일 개수"
driveUsage: "드라이브 사용량"
noCrawle: "검색엔진의 인덱싱 거부"
noCrawleDescription: "검색엔진에 사용자 페이지, 노트, 페이지 등의 콘텐츠를 인덱싱되지 않게 합니다."
lockedAccountInfo: "팔로우를 승인으로 승인받더라도 노트의 공개 범위를 '팔로워'로 하지 않는 한 누구나 당신의 노트를 볼 수 있습니다."
noCrawleDescription: "검색엔진에 사용자 페이지, 게시물, 페이지 등의 콘텐츠를 인덱싱되지 않게 합니다."
lockedAccountInfo: "팔로우를 승인으로 승인받더라도 게시물의 공개 범위를 '팔로워'로 하지 않는 한 누구나 당신의 글을 볼 수 있습니다."
alwaysMarkSensitive: "미디어를 항상 열람 주의로 설정"
loadRawImages: "첨부한 이미지의 썸네일을 원본화질로 표시"
disableShowingAnimatedImages: "움직이는 이미지를 자동으로 재생하지 않음"
verificationEmailSent: "확인 메일을 발송하였습니다. 설정을 완료하려면 메일에 첨부된 링크를 확인해 주세요."
notSet: "설정되지 않음"
emailVerified: "메일 주소가 확인되었습니다."
noteFavoritesCount: "즐겨찾기한 노트 수"
noteFavoritesCount: "즐겨찾기한 게시물 수"
pageLikesCount: "좋아요 한 Page 수"
pageLikedCount: "Page에 받은 좋아요 수"
contact: "연락처"
@ -697,9 +715,11 @@ showTitlebar: "타이틀 바를 표시하기"
clearCache: "캐시 비우기"
onlineUsersCount: "{n}명이 접속 중"
nUsers: "{n} 유저"
nNotes: "{n} 노트"
nNotes: "{n} 게시물"
sendErrorReports: "오류 보고서 보내기"
sendErrorReportsDescription: "이 설정을 활성화하면, 문제가 발생했을 때 오류에 대한 상세 정보를 Misskey에 보내어 더 나은 소프트웨어를 만드는 데에 도움을 줄 수 있습니다."
sendErrorReportsDescription: "이 설정을 활성화하면, 문제가 발생했을 때 오류에 대한 상세 정보를 Firefish에 보내어
더 나은 소프트웨어를 만드는 데에 도움을 줄 수 있습니다.\n 상세 정보에는 OS 버전, 브라우저 정보, Firefish에서의 활동 정보 등이
포함됩니다."
myTheme: "내 테마"
backgroundColor: "배경 색"
accentColor: "강조 색상"
@ -723,7 +743,7 @@ capacity: "용량"
inUse: "사용중"
editCode: "코드 수정"
apply: "적용"
receiveAnnouncementFromInstance: "이 인스턴스의 알림을 이메일로 수신할게요"
receiveAnnouncementFromInstance: "이 서버의 알림을 이메일로 수신"
emailNotification: "메일 알림"
publish: "게시"
inChannelSearch: "채널에서 검색"
@ -738,7 +758,7 @@ unlikeConfirm: "좋아요를 취소할까요?"
fullView: "전체 화면"
quitFullView: "전체 화면 해제"
addDescription: "설명 추가"
userPagePinTip: "각 노트의 메뉴에서 「프로필에 고정」을 선택하는 것으로, 여기에 노트를 표시해 둘 수 있어요."
userPagePinTip: "각 게시물의 메뉴에서 「프로필에 고정」을 선택하는 것으로, 여기에 노트를 표시해 둘 수 있어요."
notSpecifiedMentionWarning: "수신자가 선택되지 않은 멘션이 있어요"
info: "정보"
userInfo: "유저 정보"
@ -751,7 +771,7 @@ active: "최근에 활동함"
offline: "오프라인"
notRecommended: "추천하지 않음"
botProtection: "Bot 방어"
instanceBlocking: "인스턴스 차단"
instanceBlocking: "서버 차단"
selectAccount: "계정 선택"
switchAccount: "계정 바꾸기"
enabled: "활성화"
@ -768,7 +788,7 @@ postToGallery: "갤러리에 업로드"
gallery: "갤러리"
recentPosts: "최근 포스트"
popularPosts: "인기 포스트"
shareWithNote: "노트로 공유"
shareWithNote: "게시물로 공유"
ads: "광고"
expiration: "기한"
memo: "메모"
@ -780,7 +800,8 @@ emailNotConfiguredWarning: "메일 주소가 설정되어 있지 않습니다."
ratio: "비율"
previewNoteText: "본문 미리보기"
customCss: "CSS 사용자화"
customCssWarn: "이 설정은 기능을 알고 있는 경우에만 사용해야 합니다. 잘못된 값을 입력하면 클라이언트가 정상적으로 작동하지 않을 수 있습니다."
customCssWarn: "이 설정은 기능을 알고 있는 경우에만 사용해야 합니다. 잘못된 값을 입력하면 클라이언트가 정상적으로 작동하지 않을 수
있습니다."
global: "글로벌"
squareAvatars: "프로필 아이콘을 사각형으로 표시"
sent: "전송"
@ -795,7 +816,8 @@ whatIsNew: "패치 정보 보기"
translate: "번역"
translatedFrom: "{x}에서 번역"
accountDeletionInProgress: "계정 삭제 작업을 진행하고 있습니다"
usernameInfo: "서버상에서 계정을 식별하기 위한 이름. 알파벳(a~z, A~Z), 숫자(0~9) 및 언더바(_)를 사용할 수 있습니다. 사용자명은 나중에 변경할 수 없습니다."
usernameInfo: "서버상에서 계정을 식별하기 위한 이름. 알파벳(a~z, A~Z), 숫자(0~9) 및 언더바(_)를 사용할 수 있습니다.
사용자명은 나중에 변경할 수 없습니다."
aiChanMode: "아이 모드"
keepCw: "CW 유지하기"
pubSub: "Pub/Sub 계정"
@ -812,7 +834,7 @@ controlPanel: "제어판"
manageAccounts: "계정 관리"
makeReactionsPublic: "리액션 목록을 공개하기"
makeReactionsPublicDescription: "나의 리액션을 누구나 볼 수 있게 합니다."
classic: "클래식"
classic: "중앙"
muteThread: "이 글타래를 뮤트"
unmuteThread: "글타래 뮤트 해제"
ffVisibility: "내 인맥의 공개 범위"
@ -835,8 +857,8 @@ themeColor: "테마 컬러"
size: "크기"
numberOfColumn: "한 줄에 보일 리액션의 수"
searchByGoogle: "검색"
instanceDefaultLightTheme: "인스턴스 기본 라이트 테마"
instanceDefaultDarkTheme: "인스턴스 기본 다크 테마"
instanceDefaultLightTheme: "서버 기본 라이트 테마"
instanceDefaultDarkTheme: "서버 기본 다크 테마"
instanceDefaultThemeDescription: "객체 형식의 테마 코드를 입력해 주세요."
mutePeriod: "뮤트할 기간"
indefinitely: "무기한"
@ -859,7 +881,8 @@ check: "체크"
driveCapOverrideLabel: "이 유저의 드라이브 용량을 변경"
driveCapOverrideCaption: "0 이하를 지정하면 해제됩니다."
requireAdminForView: "열람하려면 관리자 계정으로 로그인해야 합니다."
isSystemAccount: "시스템에 의해 자동으로 생성되어 관리되는 계정입니다."
isSystemAccount: "시스템에 의해 자동으로 생성되어 관리되는 계정입니다. 이 계정에 대해 모더레이션, 수정, 삭제 등을 수행하면 서버가
오작동할 수 있으므로 조작하지 마십시오."
typeToConfirm: "계속하시려면 {x} 을 입력하세요"
deleteAccount: "계정 삭제"
document: "문서"
@ -884,8 +907,10 @@ cannotUploadBecauseInappropriate: "이 파일은 부적절한 내용을 포함
cannotUploadBecauseNoFreeSpace: "드라이브 용량이 부족하여 업로드할 수 없습니다."
beta: "베타"
enableAutoSensitive: "자동 NSFW 탐지"
enableAutoSensitiveDescription: "이용 가능할 경우 기계학습을 통해 자동으로 미디어 NSFW를 설정합니다. 이 기능을 해제하더라도, 인스턴스 정책에 따라 자동으로 설정될 수 있습니다."
activeEmailValidationDescription: "유저가 입력한 메일 주소가 일회용 메일인지, 실제로 통신할 수 있는 지 엄격하게 검사합니다. 해제할 경우 이메일 형식에 대해서만 검사합니다."
enableAutoSensitiveDescription: "이용 가능할 경우 기계학습을 통해 자동으로 미디어 NSFW를 설정합니다. 이 기능을 해제하더라도,
서버 정책에 따라 자동으로 설정될 수 있습니다."
activeEmailValidationDescription: "유저가 입력한 메일 주소가 일회용 메일인지, 실제로 통신할 수 있는 지 엄격하게 검사합니다.
해제할 경우 이메일 형식에 대해서만 검사합니다."
navbar: "네비게이션 바"
shuffle: "셔플"
account: "계정"
@ -893,7 +918,8 @@ move: "이동"
_sensitiveMediaDetection:
description: "기계학습을 통해 자동으로 민감한 미디어를 탐지하여, 모더레이션에 참고할 수 있도록 합니다. 서버의 부하를 약간 증가시킵니다."
sensitivity: "탐지 민감도"
sensitivityDescription: "민감도가 낮을수록 안전한 미디어가 잘못 탐지될 확률이 줄어들며, 높을수록 민감한 미디어가 탐지되지 않을 확률이 줄어듭니다."
sensitivityDescription: "민감도가 낮을수록 안전한 미디어가 잘못 탐지될 확률이 줄어들며, 높을수록 민감한 미디어가 탐지되지
않을 확률이 줄어듭니다."
setSensitiveFlagAutomatically: "자동으로 NSFW로 설정하기"
setSensitiveFlagAutomaticallyDescription: "이 설정을 해제해도 탐지 결과는 유지됩니다."
analyzeVideos: "동영상도 같이 확인하기"
@ -911,7 +937,8 @@ _ffVisibility:
_signup:
almostThere: "거의 다 끝났습니다"
emailAddressInfo: "당신이 사용하고 있는 이메일 주소를 입력해 주세요. 이메일 주소는 다른 유저에게 공개되지 않습니다."
emailSent: "입력하신 메일 주소({email})로 확인 메일을 보내드렸습니다. 가입을 완료하시려면 보내드린 메일에 있는 링크로 접속해 주세요."
emailSent: "입력하신 메일 주소({email})로 확인 메일을 보내드렸습니다. 가입을 완료하시려면 보내드린 메일에 있는 링크로 접속해
주세요."
_accountDelete:
accountDelete: "계정 삭제"
mayTakeTime: "계정 삭제는 서버에 부하를 가하기 때문에, 작성한 콘텐츠나 업로드한 파일의 수가 많으면 완료까지 시간이 걸릴 수 있습니다."
@ -924,8 +951,8 @@ _ad:
reduceFrequencyOfThisAd: "이 광고의 표시 빈도 낮추기"
_forgotPassword:
enterEmail: "여기에 계정에 등록한 메일 주소를 입력해 주세요. 입력한 메일 주소로 비밀번호 재설정 링크를 발송합니다."
ifNoEmail: "메일 주소를 등록하지 않은 경우, 관리자에 문의해 주십시오."
contactAdmin: "이 인스턴스에서는 메일 기능이 지원되지 않습니다. 비밀번호를 재설정하려면 관리자에게 문의해 주십시오."
ifNoEmail: "메일 주소를 등록하지 않은 경우, 서버 관리자에 문의해 주십시오."
contactAdmin: "이 서버에서는 메일 기능이 지원되지 않습니다. 비밀번호를 재설정하려면 관리자에게 문의해 주십시오."
_gallery:
my: "내 갤러리"
liked: "좋아요 한 갤러리"
@ -973,13 +1000,20 @@ _aboutFirefish:
donate: "Misskey에 기부하기"
morePatrons: "이 외에도 다른 많은 분들이 도움을 주시고 계십니다. 감사합니다🥰"
patrons: "후원자"
patronsList: 기부 금액이 아닌 시간 순서로 정렬합니다. 위 링크를 통해 후원하여 당신의 이름을 새겨 보세요!
sponsors: Firefish 스폰서
pleaseDonateToHost: 또한, 이 서버 {host} 의 운영자에게 기부하는 것도 검토하여 주십시오.
pleaseDonateToFirefish: Firefish의 개발에 후원하는 것을 검토하여 주십시오.
donateHost: '{host} 에게 기부하기'
donateTitle: Firefish가 마음에 드시나요?
_nsfw:
respect: "열람주의로 설정된 미디어 숨기기"
ignore: "열람 주의 미디어 항상 표시"
force: "미디어 항상 숨기기"
_mfm:
cheatSheet: "MFM 도움말"
intro: "MFM는 Misskey의 다양한 곳에서 사용할 수 있는 전용 마크업 언어입니다. 여기에서는 MFM에서 사용할 수 있는 구문을 확인할 수 있습니다."
intro: "MFM는 Misskey의 다양한 곳에서 사용할 수 있는 전용 마크업 언어입니다. 여기에서는 MFM에서 사용할 수 있는 구문을 확인할
수 있습니다."
dummy: "Misskey로 연합우주의 세계가 펼쳐집니다"
mention: "멘션"
mentionDescription: "골뱅이표(@) 뒤에 사용자명을 넣어 특정 유저를 나타낼 수 있습니다."
@ -1002,7 +1036,7 @@ _mfm:
inlineMath: "수식(인라인)"
inlineMathDescription: "수식(KaTeX)를 인라인으로 보이게 합니다."
blockMath: "수식(블록)"
blockMathDescription: "여러 줄의 수식(KaTeX)를 블록으로 보이게 합니다."
blockMathDescription: "수식(KaTeX)을 블록으로 보이게 합니다."
quote: "인용"
quoteDescription: "내용을 인용문으로 표시합니다."
emoji: "커스텀 이모지"
@ -1043,6 +1077,24 @@ _mfm:
rotateDescription: "지정한 각도로 회전시킵니다."
plain: "평문"
plainDescription: "안에 있는 MFM 구문을 모두 무시하고 평문으로 표시합니다."
stop: MFM 멈춤
play: MFM 재생
advancedDescription: 비활성화하면 MFM 재생 중을 제외하고 기본적인 MFM만 표시합니다
fade: '페이드'
advanced: 고급 MFM
warn: 빠르게 움직이거나 반짝이는 애니메이션을 포함할 가능성이 있습니다
alwaysPlay: MFM 애니메이션을 자동 재생하기
cropDescription: 내용을 잘라냅니다.
scale: 확대/축소
positionDescription: 내용을 지정한 값 만큼 이동합니다.
position: 위치
crop: 크롭
fadeDescription: 서서히 보인 뒤 서서히 사라집니다.
scaleDescription: 크기를 지정한 값 만큼 확대/축소합니다.
foregroundDescription: 문자 색상을 변경합니다.
backgroundDescription: 배경 색상을 변경합니다.
foreground: 문자색
background: 배경색
_instanceTicker:
none: "보이지 않음"
remote: "리모트 유저에게만 보이기"
@ -1051,6 +1103,7 @@ _serverDisconnectedBehavior:
reload: "자동으로 새로고침"
dialog: "경고창 표시"
quiet: "조용히 경고"
nothing: 아무것도 하지 않음
_channel:
create: "채널 생성"
edit: "채널 편집"
@ -1060,7 +1113,9 @@ _channel:
owned: "관리중"
following: "팔로잉"
usersCount: "{n}명 참여 중"
notesCount: "{n}노트"
notesCount: "{n} 게시물"
nameAndDescription: 이름과 설명
nameOnly: 이름만
_menuDisplay:
sideFull: "가로"
sideIcon: "가로(아이콘)"
@ -1070,16 +1125,17 @@ _wordMute:
muteWords: "뮤트할 단어"
muteWordsDescription: "공백으로 구분하는 경우 AND, 줄바꿈으로 구분하는 경우 OR로 지정됩니다。"
muteWordsDescription2: "정규 표현식을 사용하려면 키워드를 빗금표(/)로 감싸 주세요."
softDescription: "지정한 조건의 노트를 타임라인에서 숨깁니다."
hardDescription: "지정한 조건의 노트를 타임라인에 추가하지 않습니다. 타임라인에 추가되지 않은 노트는 조건을 변경해도 표시되지 않습니다."
softDescription: "지정한 조건의 게시물을 타임라인에서 숨깁니다."
hardDescription: "지정한 조건의 게시물을 타임라인에 추가하지 않습니다. 타임라인에 추가되지 않은 게시물은 조건을 변경해도 표시되지
않습니다."
soft: "보통"
hard: "보다 높은 수준"
mutedNotes: "뮤트된 노트"
mutedNotes: "뮤트된 게시물"
_instanceMute:
instanceMuteDescription: "뮤트한 인스턴스에서 오는 답글을 포함한 모든 노트와 Renote를 뮤트합니다."
instanceMuteDescription: "뮤트한 서버에서 오는 답글을 포함한 모든 게시물과 부스트를 뮤트합니다."
instanceMuteDescription2: "한 줄에 하나씩 입력해 주세요"
title: "지정한 인스턴스의 노트를 숨깁니다."
heading: "뮤트할 인스턴스"
title: "지정한 서버의 노트를 숨깁니다."
heading: "뮤트할 서버"
_theme:
explore: "테마 찾아보기"
install: "테마 설치"
@ -1128,7 +1184,7 @@ _theme:
hashtag: "해시태그"
mention: "멘션"
mentionMe: "나에게 보낸 멘션"
renote: "Renote"
renote: "부스트"
modalBg: "모달 배경"
divider: "구분선"
scrollbarHandle: "스크롤바 핸들"
@ -1155,8 +1211,8 @@ _theme:
accentLighten: "강조 색상 (밝음)"
fgHighlighted: "강조된 텍스트"
_sfx:
note: "새 노트"
noteMy: "내 노트"
note: "새 게시물"
noteMy: "나의 게시"
notification: "알림"
chat: "대화"
chatBg: "대화 (백그라운드)"
@ -1186,7 +1242,23 @@ _2fa:
step2Url: "데스크톱 앱에서는 다음 URL을 입력하세요:"
step3: "앱에 표시된 토큰을 입력하시면 완료됩니다."
step4: "다음 로그인부터는 토큰을 입력해야 합니다."
securityKeyInfo: "FIDO2를 지원하는 하드웨어 보안 키 혹은 디바이스의 지문인식이나 화면잠금 PIN을 이용해서 로그인하도록 설정할 수 있습니다."
securityKeyInfo: "FIDO2를 지원하는 하드웨어 보안 키 혹은 디바이스의 지문인식이나 화면잠금 PIN을 이용해서 로그인하도록 설정할
수 있습니다."
step2Click: QR 코드를 클릭하여 사용 중인 보안 키 또는 인증 앱을 등록할 수 있습니다.
step3Title: 확인 코드를 입력
registerTOTPBeforeKey: 보안 키/패스 키를 등록하시려면 우선 인증 앱 설정을 마치십시오.
securityKeyNotSupported: 이 브라우저는 보안 키를 지원하지 않습니다.
chromePasskeyNotSupported: 현재 Chrome의 패스키는 지원하지 않습니다.
token: 2차 인증 토큰
removeKey: 보안 키를 삭제
removeKeyConfirm: '{name}을 삭제하시겠습니까?'
renewTOTPCancel: 취소
renewTOTPConfirm: 지금 사용 중인 인증 앱의 확인 코드는 사용할 수 없게 됩니다
securityKeyName: 키 이름 입력
renewTOTPOk: 재설정
whyTOTPOnlyRenew: 보안 키가 등록되어 있는 상태에서 인증 앱 설정을 해제할 수 없습니다.
renewTOTP: 인증 앱을 재설정
tapSecurityKey: 브라우저의 지시에 따라 보안 키나 패스 키를 등록하십시오
_permissions:
"read:account": "계정의 정보를 봅니다"
"write:account": "계정의 정보를 변경합니다"
@ -1202,7 +1274,7 @@ _permissions:
"write:messaging": "대화를 시작하거나 메시지를 보냅니다"
"read:mutes": "뮤트 여부를 확인합니다"
"write:mutes": "뮤트를 하거나 해제합니다"
"write:notes": "노트를 작성하거나 삭제합니다"
"write:notes": "게시물을 작성하거나 삭제합니다"
"read:notifications": "알림을 확인합니다"
"write:notifications": "알림을 모두 읽음 처리합니다"
"read:reactions": "리액션을 확인합니다"
@ -1227,12 +1299,15 @@ _auth:
pleaseGoBack: "앱으로 돌아가서 시도해 주세요"
callback: "앱으로 돌아갑니다"
denied: "접근이 거부되었습니다"
allPermissions: 모든 접근 권한
copyAsk: '아래 인증 코드를 어플리케이션에 붙여넣으십시오:'
_antennaSources:
all: "모든 노트"
homeTimeline: "팔로우중인 유저의 노트"
users: "지정한 한 명 혹은 여러 명의 유저의 노트"
userList: "지정한 리스트에 속한 유저의 노트"
userGroup: "지정한 그룹에 속한 유저의 노트"
all: "모든 게시물"
homeTimeline: "팔로우 중인 유저의 게시물"
users: "지정한 한 명 혹은 여러 명의 유저의 게시물"
userList: "지정한 리스트에 속한 유저의 게시물"
userGroup: "지정한 그룹에 속한 유저의 게시물"
instances: 지정한 서버의 모든 유저의 게시물
_weekday:
sunday: "일요일"
monday: "월요일"
@ -1263,6 +1338,14 @@ _widgets:
serverMetric: "서버 통계"
aiscript: "AiScript 콘솔"
aichan: "아이"
serverInfo: 서버 정보
_userList:
chooseList: 리스트 선택
meiliStatus: 서버 정보
userList: 유저 목록
meiliSize: 인덱스 크기
meiliIndexCount: 인덱싱 완료된 게시물
rssTicker: RSS Ticker
_cw:
hide: "숨기기"
show: "더 보기"
@ -1293,17 +1376,17 @@ _poll:
_visibility:
public: "공개"
publicDescription: "모든 유저에게 공개"
home: ""
home: "미등재"
homeDescription: "홈 타임라인에만 공개"
followers: "팔로워"
followersDescription: "팔로워에게만 공개"
followersDescription: "팔로워 및 멘션한 유저에게만 공개"
specified: "다이렉트"
specifiedDescription: "지정한 유저에게만 공개"
localOnly: "로컬에만"
localOnlyDescription: "리모트 유저에게 보이지 않기"
_postForm:
replyPlaceholder: "이 노트에 답글..."
quotePlaceholder: "이 노트를 인용..."
replyPlaceholder: "이 에 답글..."
quotePlaceholder: "이 글을 인용..."
channelPlaceholder: "채널에 게시하기..."
_placeholders:
a: "지금 무엇을 하고 있나요?"
@ -1319,13 +1402,15 @@ _profile:
youCanIncludeHashtags: "해시 태그를 포함할 수 있습니다."
metadata: "추가 정보"
metadataEdit: "추가 정보 편집"
metadataDescription: "프로필에 추가 정보를 표시할 수 있어요. {rel}과 함께 {a} 태그 또는 {l} 태그를 추가하여 프로필의 링크를 확인할 수 있습니다!"
metadataDescription: "프로필에 추가 정보를 표시할 수 있어요. {rel}과 함께 {a} 태그 또는 {l} 태그를 추가하여 프로필의
링크를 확인할 수 있습니다!"
metadataLabel: "라벨"
metadataContent: "내용"
changeAvatar: "아바타 이미지 변경"
changeBanner: "배너 이미지 변경"
locationDescription: 영문 도시명을 입력하면, 현재 시간대의 시각이 유저 페이지에 표시됩니다.
_exportOrImport:
allNotes: "모든 노트"
allNotes: "모든 게시물"
followingList: "팔로잉"
muteList: "뮤트"
blockingList: "차단"
@ -1338,10 +1423,10 @@ _charts:
usersIncDec: "유저 수 증감"
usersTotal: "유저 수 합계"
activeUsers: "활성 유저 수"
notesIncDec: "노트 수 증감"
localNotesIncDec: "로컬 노트 수 증감"
remoteNotesIncDec: "리모트 노트 수 증감"
notesTotal: "노트 수 합계"
notesIncDec: "게시물 수 증감"
localNotesIncDec: "로컬 게시물 수 증감"
remoteNotesIncDec: "리모트 게시물 수 증감"
notesTotal: "게시물 수 합계"
filesIncDec: "파일 수 증감"
filesTotal: "파일 수 합계"
storageUsageIncDec: "스토리지 사용량 증감"
@ -1350,8 +1435,8 @@ _instanceCharts:
requests: "요청"
users: "유저 수 증감"
usersTotal: "누적 유저 수"
notes: "노트 수 증감"
notesTotal: "누적 노트 수"
notes: "게시물 수 증감"
notesTotal: "누적 게시물 수"
ff: "팔로잉/팔로워 증감"
ffTotal: "누적 팔로잉/팔로워 수"
cacheSize: "캐시 용량 증감"
@ -1363,6 +1448,7 @@ _timelines:
local: "로컬"
social: "소셜"
global: "글로벌"
recommended: 추천
_pages:
newPage: "페이지 만들기"
editPage: "페이지 수정"
@ -1437,10 +1523,10 @@ _pages:
id: "캔버스 ID"
width: "폭"
height: "높이"
note: "노트필기"
note: "게시물 삽입"
_note:
id: "노트 ID"
idDescription: "노트 URL을 붙여넣어 설정할 수도 있습니다."
id: "게시물 ID"
idDescription: "게시물 URL을 붙여넣어 설정할 수도 있습니다."
detailed: "세부 정보 보기"
switch: "스위치"
_switch:
@ -1661,7 +1747,7 @@ _notification:
youGotMention: "{name}님이 멘션함"
youGotReply: "{name}님이 답글함"
youGotQuote: "{name}님이 인용함"
youRenoted: "{name}님이 Renote"
youRenoted: "{name}님이 Boost"
youGotPoll: "{name}님이 투표함"
youGotMessagingMessageFromUser: "{name} 님이 보낸 채팅이 있어요"
youGotMessagingMessageFromGroup: "{name}에서 보낸 채팅이 있어요"
@ -1676,7 +1762,7 @@ _notification:
follow: "팔로잉"
mention: "멘션"
reply: "답글"
renote: "Renote"
renote: "부스트"
quote: "인용"
reaction: "리액션"
pollVote: "투표 참여"
@ -1688,7 +1774,10 @@ _notification:
_actions:
followBack: "팔로우"
reply: "답글"
renote: "Renote"
renote: "부스트"
reacted: 님의 리액션
renoted: 님이 부스트
voted: 님이 투표함
_deck:
alwaysShowMainColumn: "메인 칼럼 항상 표시"
columnAlign: "칼럼 정렬"
@ -1700,9 +1789,9 @@ _deck:
swapDown: "아래로 이동"
stackLeft: "왼쪽에 쌓기"
popRight: "오른쪽으로 빼기"
profile: "프로파일"
newProfile: "새 프로파일"
deleteProfile: "프로파일 삭제"
profile: "작업 공간"
newProfile: "새 작업 공간"
deleteProfile: "작업 공간 삭제"
introduction: "칼럼을 조합해서 나만의 인터페이스를 구성해 보아요!"
introduction2: "나중에라도 화면 우측의 + 버튼을 눌러 새 칼럼을 추가할 수 있습니다."
widgetsIntroduction: "칼럼 메뉴의 \"위젯 편집\"에서 위젯을 추가해 주세요"
@ -1715,3 +1804,202 @@ _deck:
list: "리스트"
mentions: "받은 멘션"
direct: "다이렉트"
channel: 채널
renameProfile: 워크스페이스명을 변경
nameAlreadyExists: 같은 이름의 워크스페이스가 이미 존재합니다.
removeReaction: 리액션 취소
flagSpeakAsCat: 고양이체로 말하기
silenceThisInstance: 이 서버를 사일런스
silencedInstancesDescription: 사일런스할 서버의 호스트를 한 줄에 하나씩 입력합니다. 사일런스된 서버의 유저는 모두 사일런스인
것처럼 취급되며, 이 서버에서의 팔로우가 모두 팔로우 요청으로 바뀌고, 팔로워가 아닌 로컬 계정은 멘션할 수 없습니다. 차단한 서버에는 적용되지
않습니다.
noInstances: 서버가 없습니다
silenced: 사일런스됨
manageGroups: 그룹 관리
clipsDesc: 클립은 분류 및 공유가 가능한 북마크입니다. 각 게시물의 메뉴에서 클립을 작성할 수 있습니다.
privateMode: 비공개 모드
audio: 오디오
customKaTeXMacro: 커스텀 KaTeX 매크로
replayTutorial: 튜토리얼 다시 보기
renoteMute: 부스트 뮤트
antennaInstancesDescription: 서버 호스트를 한 줄에 하나씩 입력하세요
userSaysSomethingReason: '{name} 님이 {reason}에 대해 말했습니다'
userSaysSomethingReasonQuote: '{name} 님이 {reason} 을 포함하는 노트를 인용했습니다'
pushNotification: 푸시 알림
channelFederationWarn: 현재 채널은 다른 서버로 연합되지 않습니다
enableServerMachineStats: 서버의 머신 정보를 공개
sendModMail: 모더레이션 알림을 보내기
instanceSecurity: 서버 보안
privateModeInfo: 활성화하면 허가된 서버에서의 요청에만 응답합니다.
seperateRenoteQuote: 부스트와 인용 버튼을 나누기
cannotUploadBecauseExceedsFileSizeLimit: 파일 크기 제한을 초과하여 업로드할 수 없습니다.
pushNotificationNotSupported: 브라우저 및 서버가 푸시 알림을 지원하지 않습니다
enableRecommendedTimeline: 추천 타임라인을 활성화
pushNotificationAlreadySubscribed: 푸시 알림이 활성화되었습니다
caption: 자동 캡션
findOtherInstance: 다른 서버 둘러보기
enableIdenticonGeneration: 유저 별 Identicon의 생성을 활성화
secureModeInfo: 인증 정보가 없는 리모트 서버로부터의 요청에 응답하지 않습니다.
allowedInstances: 허가된 서버
flagSpeakAsCatDescription: 고양이체를 활성화하면 게시물이 '나'가 '냐'로 바뀌는 등의 변화가 생깁니다
showUpdates: Firefish 업데이트가 있을 때 알리기
noGraze: '"Graze for Mastodon" 확장 기능은 Firefish의 정상적인 동작을 방해므로, 비활성화해 주시기 바랍니다.'
adminCustomCssWarn: 이 설정은 기능을 알고 있는 경우에만 사용해야 합니다. 잘못된 값을 입력하면 모든 유저의 클라이언트가 정상적으로
작동하지 않을 수 있습니다. 개인 클라이언트 설정에서 적용하여 정상적으로 동작하는 지 확인하십시오.
customSplashIconsDescription: 유저가 페이지를 로딩/새로고침할 때 마다 무작위로 표시할 아이콘을 한 줄에 하나씩 입력합니다.
이미지는 되도록 정적 URL으로 구성하고, 192x192 해상도로 조정하여 주십시오.
moveFromDescription: '이전 계정에 대한 별칭을 작성하여, 이 계정으로 옮길 수 있도록 합니다. 반드시 계정을 이전하기 전에 수행해야
합니다. 이전 계정을 다음과 같은 형식으로 입력하여 주십시오: @person@server.com'
indexFromDescription: 빈 칸으로 두면 모든 게시물을 인덱싱합니다
customKaTeXMacroDescription: 'KaTeX 매크로를 지정하여 수식을 더욱 편리하게 입력하세요! LaTeX의 커맨드 정의와 동일하게
\newcommand{\ 이름}{내용} 또는 \newcommand{\이름}[인수 갯수]{내용} 와 같이 입력하십시오. 예를 들어 \newcommand{\add}[2]{#1
+ #2} 와 같이 정의한 경우 \add{3}{foo} 를 입력하면 3 + foo 으로 치환됩니다.매크로의 이름을 감싸는 중괄호를 소괄호() 또는
대괄호[]로 변경할 경우, 매크로 인수에 사용하는 괄호도 같이 변경됩니다. 매크로는 한 줄에 하나씩 입력해야 하며, 반대로 매크로 정의에서 줄바꿈은
사용할 수 없습니다. 올바르지 않은 정의는 무시됩니다. 문자열을 치환하는 수준에서만 지원하며, 조건 분기와 같은 고도의 구문은 사용할 수 없습니다.'
reactionPickerSkinTone: 선호하는 이모지 피부 톤
selectInstance: 서버 선택
showAds: 광고 보이기
searchPlaceholder: Firefish에서 검색
addInstance: 서버 추가
listsDesc: 리스트를 사용하여 특정 유저로 이루어진 타임라인을 구성할 수 있습니다. 리스트는 '타임라인' 페이지에서 접근할 수 있습니다.
enableEmojiReactions: 이모지 리액션을 활성화
showEmojisInReactionNotifications: 리액션 알림에 이모지 보이기
hiddenTagsDescription: 트렌드와 '발견하기'에서 제외할 해시태그를 ('#'을 제외하고) 한 줄에 하나씩 입력하여 주십시오. 이 설정은
트렌드와 '발견하기' 외에는 영향을 주지 않습니다.
antennasDesc: "안테나에서는 조건에 맞는 게시물이 표시됩니다.\n'타임라인' 페이지에서 접근할 수 있습니다."
expandOnNoteClick: 노트를 클릭하여 자세히 표시
expandOnNoteClickDesc: 비활성화한 경우에도 우클릭 메뉴 또는 타임스탬프를 클릭하여 열 수 있습니다.
customMOTDDescription: 유저가 페이지를 로딩/새로고침할 때 마다 무작위로 표시할 메시지를 한 줄에 하나씩 입력합니다.
moveFrom: 다른 계정에서 이 계정으로 이사하기
moveAccount: 이사하기!
enterSendsMessage: 메시지에서 Return 키를 눌러 전송 (기본값 Ctrl + Return)
verifiedLink: 인증된 링크
alt: 설명
statusbar: 스테이터스 바
subscribePushNotification: 푸시 알림을 활성화
sendPushNotificationReadMessage: 알림이나 메시지를 읽은 뒤에 푸시 알림을 삭제
sendPushNotificationReadMessageCaption: '"{emptyPushNotificationMessage}" 라는 알림을 짧은
기간 동안 표시합니다. 기기의 배터리 소모가 늘어날 수 있습니다.'
recommendedInstancesDescription: 추천 타임라인에 표시할 서버를 한 줄에 하나씩 입력하여 주십시오.
enableCustomKaTeXMacro: 커스텀 KaTeX 매크로를 사용
swipeOnMobile: 페이지 간 스와이프를 활성화
swipeOnDesktop: 데스크톱에서도 모바일과 같은 스와이프를 사용
migration: 계정 이사
moveTo: 이 계정에서 새로운 계정으로 이사
deleted: 삭제됨
editNote: 노트 편집
edited: '편짐됨: {date} {time}'
customMOTD: 사용자 지정 MOTD (스플래시 화면 메시지)
selectChannel: 채널 선택
allowedInstancesDescription: 연합을 허가하려는 서버를 한 줄에 하나씩 입력합니다. 비공개 모드에서만 유효합니다.
splash: 스플래시 화면
preventAiLearningDescription: 업로드한 게시물이나 미디어를 AI 모델이 학습하지 말기를 요구합니다.
isBot: 이 계정은 봇입니다
isAdmin: 관리자
newer: 새로운 노트
older: 이전 노트
renoteUnmute: 부스트 뮤트 해제
accountMoved: '이 유저는 다른 계정으로 이사했습니다:'
silencedInstances: 사일런스한 서버
accessibility: 접근성
userSaysSomethingReasonReply: '{name} 님이 {reason} 을 포함하는 노트에 답글했습니다'
userSaysSomethingReasonRenote: '{name} 님이 {reason} 을 포함하는 노트를 부스트했습니다'
breakFollowConfirm: 팔로워를 해제하시겠습니까?
indexFrom: 이 게시물 ID부터 인덱싱하기
noThankYou: 괜찮습니다
hiddenTags: 숨길 해시태그
image: 이미지
video: 동영상
jumpToPrevious: 이전으로
cw: 열람주의
secureMode: 보안 모드 (Authorized Fetch)
xl: 매우 크게
unsubscribePushNotification: 푸시 알림을 끄기
customSplashIcons: 사용자 지정 스플래시 화면 아이콘 (URL)
recommendedInstances: 추천 서버
updateAvailable: 업데이트가 있습니다!
logoImageUrl: 로고 이미지 URL
showAdminUpdates: 새로운 Firefish 버전이 있을 때 알리기 (관리자 전용)
moveToLabel: '이사 갈 계정:'
moveAccountDescription: '이 작업은 되돌릴 수 없습니다. 계정을 옮기기 전에, 새로운 계정에서 이 계정에 대한 별칭을 지정하여
주십시오. 별칭을 지정하였다면, 이사 갈 계정을 다음과 같은 형식으로 입력하여 주십시오: @person@server.com'
defaultReaction: 리모트와 로컬 게시물에 대한 기본 이모지 리액션
showPopup: 유저에게 팝업으로 알리기
showWithSparkles: 제목에 스파클 효과 넣기
youHaveUnreadAnnouncements: 읽지 않은 공지사항이 있습니다
donationLink: 기부 페이지 링크
moveFromLabel: '이사하기 전의 계정:'
neverShow: 앞으로 표시하지 않기
remindMeLater: 나중에
removeQuote: 인용을 삭제
removeRecipient: 수신인을 삭제
removeMember: 멤버를 삭제
license: 라이선스
migrationConfirm: "정말로 이 계정을 {account}로 이사하시겠습니까? 한 번 이사하면, 현재 이 계정은 두 번 다시 사용할 수
없게 됩니다.\n또한, 이사 갈 계정에 현재 사용 중인 계정의 별칭을 올바르게 작성하였는지 다시 한 번 확인하십시오."
indexPosts: 게시물을 인덱싱
indexNotice: 인덱싱을 시작했습니다. 이 작업은 시간이 많이 소요되므로, 최소 1시간 이내에 서버를 재시작하지 마십시오.
noteId: 게시물 ID
signupsDisabled: 현재 이 서버에서는 신규 등록을 받고 있지 않습니다. 초대 코드를 가지고 계신 경우 아래 칸에 입력해 주십시오. 초대
코드를 가지고 있지 않더라도, 신규 등록이 열려 있는 다른 서버에 등록하실 수 있습니다!
apps:
preventAiLearning: AI에 의한 학습을 막기
isLocked: 이 계정은 팔로우를 수동으로 승인합니다
silencedWarning: 관리자가 사일런스한 서버에 속한 유저이며, 스팸이거나 원치 않는 내용을 포함할 가능성이 있습니다.
isModerator: 모더레이터
isPatron: Firefish 후원자
_experiments:
postImportsCaption: 유저가 과거에 작성한 게시물을 Firefish(Firefish), Misskey, Mastodon, Akkoma,
Pleroma 등에서 가져올 수 있게 합니다. 작업 대기열의 처리 속도가 느릴 경우 서비스에 영향이 갈 수 있습니다.
enablePostImports: 게시물 가져오기를 활성화
title: 실험실
_messaging:
groups: 그룹
dms: 개인 메시지
_tutorial:
title: Firefly의 사용 방법
step5_5: '{icon} 소셜 타임라인은 홈 타임라인과 소셜 타임라인을 합친 것과 같습니다.'
step4_1: 첫 노트를 올려 봅시다.
step5_3: '{icon} 홈 타임라인은 내가 팔로우하고 있는 계정의 게시물을 볼 수 있는 타임라인입니다.'
step6_2: 이 서버에 가입을 마친 당신은 단순히 Firefish 서버의 유저가 아닌, 수많은 서버가 서로 상호작용하는 연합우주에 참가하시게
된 것입니다.
step5_4: '{icon} 로컬 타임라인은 이 서버의 모든 유저가 올린 게시물을 볼 수 있는 타임라인입니다.'
step5_2: 이 서버에는 {timelines} 개의 타임라인이 존재합니다.
step2_2: 나에 대한 정보를 미리 실어 놓으면, 다른 사람이 나의 게시물을 보거나 팔로우할 때에 도움이 됩니다.
step3_2: "홈 타임라인과 소셜 타임라인은 내가 팔로우하는 유저로 구성됩니다. 우선 몇 명을 팔로우해 볼까요?\n각 프로필 우측 상단의 둥근
+ 버튼을 눌러 팔로우할 수 있습니다."
step2_1: 우선 프로필을 작성합니다.
step3_1: 이제 누군가를 팔로우해 봅시다!
step5_1: 여기도 타임라인, 저기도 타임라인
step5_6: '{icon} 추천 타임라인은 이 서버의 관리자가 추천하는 서버의 게시물을 볼 수 있는 타임라인입니다.'
step5_7: '{icon} 글로벌 타임라인에서는 이 서버와 연결된 모든 서버의 게시물을 볼 수 있습니다.'
step1_1: 환영합니다!
step1_2: Firefly를 시작하기 전에, 몇 가지 설정을 해 보아요. 금방 끝날 거에요!
step6_1: 그래서… 여기는 어떤 곳이죠?
step4_2: 처음엔 {introduction}를 올리거나, 가볍게 '안녕하세요!' 라고 올리는 것도 좋아요!
step6_4: 튜토리얼은 여기까지입니다. 즐거운 시간 되세요!
step6_3: 각각의 서버는 서로 다른 규칙과 환경을 가지고 있으며, Firefish가 아닌 서버 또한 존재한답니다. 이 서버도 다른 서버에서
보면 마찬가지이고요. 갑자기 어려워 보일 지 몰라도 걱정하지 마세요, 금방 익숙해 질 거니까요.
_skinTones:
medium: 중간
mediumLight: 약간 밝음
yellow: 노랑
mediumDark: 약간 어두움
dark: 어두움
light: 밝음
_filters:
withFile: 첨부 파일 있음
fromUser: 유저를 선택
fromDomain: 도메인 지정
notesBefore: '... 이전의 게시물'
notesAfter: '... 이후의 게시물'
followingOnly: 팔로우 중인 유저만
followersOnly: 팔로워만
_feeds:
jsonFeed: JSON 피드
rss: RSS
atom: Atom
copyFeed: 피드 URL 복사
_dialog:
charactersExceeded: 글자 수 제한을 초과했습니다! 현재 {current}자 / 최대 {max}자
charactersBelow: 최소 글자 수 보다 작습니다! 현재 {current}자 / 최소 {max}자

View File

@ -1,7 +1,7 @@
_lang_: "Nederlands"
headlineMisskey: "Een open source, gedecentraliseerd, social media platform dat voor
headlineFirefish: "Een open source, gedecentraliseerd, social media platform dat voor
altijd gratis is! 🚀"
introMisskey: "Welkom! Firefish is een open source, gedecentraliseerde microblogdienst.\n
introFirefish: "Welkom! Firefish is een open source, gedecentraliseerde microblogdienst.\n
Maak \"notities\" om je gedachten te delen met iedereen om je heen. 📡\nMet \"reacties\"\
\ kun je ook snel je mening geven over berichten van anderen. 👍\nLaten we een nieuwe
wereld verkennen! 🚀"

View File

@ -21,7 +21,7 @@ noAccountDescription: Denne brukeren har ikke fylt ut bio'en sin ennå.
login: Logg inn
loggingIn: Logger inn
signup: Oppretter bruker
uploading: Laster opp..
uploading: Laster opp...
enterUsername: Skriv inn brukernavn
noNotifications: Ingen meldinger
users: Brukere
@ -63,9 +63,9 @@ alreadyFavorited: Allerede lagt til i bokmerker.
delete: Slett
openInWindow: Åpne i vindu
basicSettings: Grunnleggende innstillinger
headlineMisskey: En desentralisert sosialt media-plattform, basert på åpen kildekode,
headlineFirefish: En desentralisert sosialt media-plattform, basert på åpen kildekode,
som alltid vil være gratis! 🚀
introMisskey: Velkommen! Firefish er en desentralisert sosialt media-plattform, basert
introFirefish: Velkommen! Firefish er en desentralisert sosialt media-plattform, basert
på åpen kildekode, som alltid vil være gratis! 🚀
exportRequested: Du har bedt om en eksportering. Dette vil ta litt tid. Den vil bli
lagt til på disken din når den er ferdig.
@ -81,3 +81,36 @@ followRequestAccepted: Følgeforespørsel godtatt
import: Importer
export: Eksporter
logout: Logger ut
removeReaction: Fjern dine reaksjoner
renotedBy: Fremhevet av {user}
deleteAndEditConfirm: Er du sikker på at du vil slette og redigere denne posten? Du
vil miste alle reaksjoner, fremhevinger og svar til den.
pageLoadError: En feil oppsto ved lasting av siden.
privacy: Personvern
enterEmoji: Legg inn emoji
renoted: Fremhevet.
cantRenote: Denne posten kan ikke fremheves.
cantReRenote: En fremheving kan ikke fremheves.
quote: Sitér
pinned: Fest til profil
clickToShow: Klikk for å vise
enableEmojiReactions: Slå på emoji-reaksjoner
makeFollowManuallyApprove: Følgeforespørsler må godkjennes
enterListName: Gi listen et navn
follow: Følg
followRequest: Følgerforespørsel
unfollow: Avfølg
followRequestPending: Ubehandlet følgerforespørsel
add: Legg til
followRequests: Følgerforespørsler
reaction: Reaksjoner
driveFileDeleteConfirm: Er du sikker på at du vil slette filen «{name}»? Den vil fjernes
fra alle poster den er vedlagt i.
defaultNoteVisibility: Standard synlighet
unrenote: Fjern fremmheving
unpin: Løsne fra profilen
youGotNewFollower: følger deg
mention: Omtale
mentions: Omtaler
edited: Redigert {date} {time}
cw: Innholdsadvarsel

View File

@ -1,7 +1,7 @@
_lang_: "Polski"
headlineMisskey: "Otwartoźródłowa, zdecentralizowana sieć społecznościowa, która zawsze
headlineFirefish: "Otwartoźródłowa, zdecentralizowana sieć społecznościowa, która zawsze
będzie darmowa! 🚀"
introMisskey: "Hej! Firefish to otwartoźródłowa oraz zdecentralizowana sieć społecznościowa,
introFirefish: "Hej! Firefish to otwartoźródłowa oraz zdecentralizowana sieć społecznościowa,
która zawsze będzie darmowa! 🚀"
monthAndDay: "{month}-{day}"
search: "Szukaj"
@ -1404,7 +1404,8 @@ _profile:
metadata: "Dodatkowe informacje"
metadataEdit: "Edytuj dodatkowe informacje"
metadataDescription: "Możesz wyświetlać do czterech sekcji dodatkowych informacji
na swoim profilu. Możesz dodać tag {a} lub tag {l} z {rel}, aby zweryfikować link w swoim profilu!"
na swoim profilu. Możesz dodać tag {a} lub tag {l} z {rel}, aby zweryfikować link
w swoim profilu!"
metadataLabel: "Etykieta"
metadataContent: "Treść"
changeAvatar: "Zmień awatar"

View File

@ -1,7 +1,7 @@
---
_lang_: "Português"
headlineMisskey: "Uma rede ligada por notas"
introMisskey: "Bem-vindo! Firefish é um serviço de microblogue descentralizado de código aberto.\nCria \"notas\" e partilha o que te ocorre com todos à tua volta. 📡\nCom \"reações\" podes também expressar logo o que sentes às notas de todos. 👍\nExploremos um novo mundo! 🚀"
headlineFirefish: "Uma rede ligada por notas"
introFirefish: "Bem-vindo! Firefish é um serviço de microblogue descentralizado de código aberto.\nCria \"notas\" e partilha o que te ocorre com todos à tua volta. 📡\nCom \"reações\" podes também expressar logo o que sentes às notas de todos. 👍\nExploremos um novo mundo! 🚀"
monthAndDay: "{day}/{month}"
search: "Buscar"
notifications: "Notificações"

View File

@ -1,11 +1,11 @@
username: Nome de usuário
ok: OK
_lang_: Inglês
headlineMisskey: Uma plataforma de mídia social descentralizada e de código aberto
headlineFirefish: Uma plataforma de mídia social descentralizada e de código aberto
que é gratuita para sempre! 🚀
search: Pesquisar
gotIt: Entendi!
introMisskey: Bem vinde! Firefish é uma plataforma de mídia social descentralizada
introFirefish: Bem vinde! Firefish é uma plataforma de mídia social descentralizada
e de código aberto que é gratuita para sempre! 🚀
searchPlaceholder: Pesquise no Firefish
notifications: Notificações

View File

@ -1,7 +1,7 @@
---
_lang_: "Română"
headlineMisskey: "O rețea conectată prin note"
introMisskey: "Bine ai venit! Firefish este un serviciu de microblogging open source și decentralizat.\nCreează \"note\" cu care să îți poți împărți gândurile cu oricine din jurul tău. 📡\nCu \"reacții\" îți poți expirma rapid părerea despre notele oricui. 👍\nHai să explorăm o lume nouă! 🚀"
headlineFirefish: "O rețea conectată prin note"
introFirefish: "Bine ai venit! Firefish este un serviciu de microblogging open source și decentralizat.\nCreează \"note\" cu care să îți poți împărți gândurile cu oricine din jurul tău. 📡\nCu \"reacții\" îți poți expirma rapid părerea despre notele oricui. 👍\nHai să explorăm o lume nouă! 🚀"
monthAndDay: "{day}/{month}"
search: "Caută"
notifications: "Notificări"

View File

@ -1,6 +1,6 @@
_lang_: "Русский"
headlineMisskey: "Сеть, сплетённая из заметок"
introMisskey: "Firefish - это децентрализованная платформа социальных сетей с открытым
headlineFirefish: "Сеть, сплетённая из заметок"
introFirefish: "Firefish - это децентрализованная платформа социальных сетей с открытым
исходным кодом, которая свободна навсегда! 🚀"
monthAndDay: "{day}.{month}"
search: "Поиск"
@ -27,7 +27,7 @@ noAccountDescription: "Пользователь ничего не написал
login: "Войти"
loggingIn: "Выполняется вход"
logout: "Выйти"
signup: "Регистрация"
signup: "Зарегистрироваться"
uploading: "Загрузка..."
save: "Сохранить"
users: "Пользователи"
@ -51,7 +51,7 @@ sendMessage: "Отправить сообщение"
copyUsername: "Скопировать имя пользователя"
searchUser: "Поиск людей"
reply: "Ответить"
loadMore: "Показать еще"
loadMore: "Загрузить ещё"
showMore: "Показать еще"
showLess: "Закрыть"
youGotNewFollower: "Новый подписчик"
@ -752,8 +752,8 @@ nUsers: "Пользователей: {n}"
nNotes: "Постов: {n}"
sendErrorReports: "Посылать отчёты о сбоях"
sendErrorReportsDescription: "Если включено, когда возникнет какая-нибудь техническая
проблема, подробные сведения об этом будут отправлены разработчикам Firefish.\n Это
очень помогает делать программу лучше. В отчёты попадают тип и версия ОС, браузера,
проблема, подробные сведения об этом будут отправлены разработчикам Firefish.\n
Это очень помогает делать программу лучше. В отчёты попадают тип и версия ОС, браузера,
журнал действий (что привело к сбою) и тому подобное."
myTheme: "Личная тема"
backgroundColor: "Фон"
@ -844,7 +844,7 @@ squareAvatars: "Квадратные аватарки"
sent: "Отправить"
received: "Получено"
searchResult: "Результаты поиска"
hashtags: "Хэштег"
hashtags: "Хэштеги"
troubleshooting: "Разрешение проблем"
useBlurEffect: "Размытие в интерфейсе"
learnMore: "Подробнее"
@ -911,9 +911,9 @@ label: "Метка"
localOnly: "Локально"
beta: "Бета"
enableAutoSensitive: "Автоматическое определение NSFW"
enableAutoSensitiveDescription: "Если доступно, используйте машинное обучение для
автоматической установки флага NSFW на носителе. Даже если эта функция отключена,
она может быть установлена автоматически в зависимости от инстанта."
enableAutoSensitiveDescription: "Позволяет автоматически обнаруживать и маркировать
медиафайлы NSFW с помощью машинного обучения, где это возможно. Даже если эта опция
отключена, она может быть включена на всем сервере."
account: "Учётные записи"
_sensitiveMediaDetection:
description: "Машинное обучение может быть использовано для автоматического обнаружения
@ -959,7 +959,7 @@ _forgotPassword:
enterEmail: "Введите адрес электронной почты, который ввели при регистрации. На
неё будет выслана ссылка для смены пароля."
ifNoEmail: "Если вы не ввели свой адрес электронной почты, свяжитесь с администратором
ресурса, чтобы сменить пароль."
сервера, чтобы сменить пароль."
contactAdmin: "Здесь не используются адреса электронной почты, так что свяжитесь
с администратором, чтобы поменять пароль."
_gallery:
@ -982,7 +982,7 @@ _registry:
keys: "Ключ"
domain: "Домен"
createKey: "Новый ключ"
_aboutMisskey:
_aboutFirefish:
about: "Firefish это форк Firefish, сделанный ThatOneCalculator, разработка которого
началась с 2022."
contributors: "Основные соавторы"
@ -993,15 +993,23 @@ _aboutMisskey:
morePatrons: "Большое спасибо и многим другим, кто принял участие в этом проекте!
🥰"
patrons: "Материальная поддержка"
patronsList: Перечислены в хронологическом порядке, а не по размеру пожертвования.
Сделайте взнос по ссылке выше, чтобы ваше имя было здесь!
sponsors: Спонсоры Firefish
donateTitle: Понравился Firefish?
pleaseDonateToFirefish: Пожалуйста, поддержите разработку Firefish.
pleaseDonateToHost: Также не забудьте поддержать ваш домашний сервер {host}, чтобы
помочь с его операционными расходами.
donateHost: Пожертвовать на {host}
_nsfw:
respect: "Скрывать содержимое не для всех"
ignore: "Показывать содержимое не для всех"
force: "Скрывать вообще все файлы"
_mfm:
cheatSheet: "Подсказка по разметке MFM"
intro: "MFM — язык оформления текста,используемый в Firefish, Firefish, Akkoma и готов
для применения во многих местах. На этой странице собраны и кратко изложены способы
его использовать."
intro: "MFM — язык оформления текста, используемый в Misskey, Firefish, Akkoma,
который можно использовать во многих местах. На этой странице собраны и кратко
изложены способы его использовать."
dummy: "Firefish расширяет границы Федиверса"
mention: "Упоминание"
mentionDescription: "При помощи знака «собака» перед именем можно упомянуть какого-нибудь
@ -1027,7 +1035,7 @@ _mfm:
inlineMathDescription: "Позволяет вставлять математические выражения внутрь текста
при помощи языка KaTeX"
blockMath: "Математическое выражение (блок)"
blockMathDescription: "Оформляет математическое выражение (KaTeX) на отдельной строке"
blockMathDescription: "Отображать математические формулы (KaTeX) блоками"
quote: "Цитата"
quoteDescription: "Так можно процитировать чей-то текст."
emoji: "Собственные эмодзи"
@ -1069,6 +1077,25 @@ _mfm:
rotateDescription: "Поворачивает на заданный угол."
plain: Обычный текст
plainDescription: Деактивирует эффекты всех MFM, содержащихся в этом эффекте MFM.
play: Воспроизвести MFM
warn: 'MFM может содержать быстро-движущуюся или яркую анимацию'
advanced: Расширенные MFM
advancedDescription: Если выключено, позволяет только базовую разметку, если не
воспроизводится анимированный MFM
background: Цвет фона
backgroundDescription: Изменить цвет фона текста.
crop: Обрезать
cropDescription: Обрезать содержимое.
stop: Остановить MFM
scale: Масштабировать
fade: Затухание
position: Расположение
alwaysPlay: Всегда автозапускать все анимированные MFM
fadeDescription: Уменьшает и увеличивает видимость контента.
foreground: Цвет переднего плана
foregroundDescription: Изменить цвет текста на переднем плане.
positionDescription: Переместить содержимое на указанное значение.
scaleDescription: Масштабировать содержимое на указанную величину.
_instanceTicker:
none: "Не показывать"
remote: "Только для других сайтов"
@ -1088,6 +1115,8 @@ _channel:
following: "Подписки"
usersCount: "Участников: {n}"
notesCount: "Постов: {n}"
nameOnly: Только название
nameAndDescription: Название и описание
_menuDisplay:
sideFull: "Сторона"
sideIcon: "Сторона (иконки)"
@ -1107,11 +1136,11 @@ _wordMute:
hard: "Жёсткий"
mutedNotes: "Скрытые посты"
_instanceMute:
heading: "Список заглушенных инстансов"
heading: "Список заглушенных серверов"
instanceMuteDescription2: Разделить переносом строки
instanceMuteDescription: Это будет скрывать все посты/репосты с указанных инстансов,
включая ответы пользователю с заглушенного инстанса.
title: Скрывает посты с указанных инстансов.
instanceMuteDescription: Это будет скрывать все посты/репосты с указанных серверов,
включая ответы пользователю с заглушенного сервера.
title: Скрывает посты с указанных серверов.
_theme:
explore: "Обзор"
install: "Установить тему"
@ -1217,7 +1246,7 @@ _tutorial:
step2_1: "Сначала, пожалуйста, заполните свой профиль."
step2_2: "Предоставив некоторую информацию о себе, другим людям будет легче понять,
хотят ли они видеть ваши записи или следить за вами."
step3_1: "Теперь пора следить за некоторыми людьми!"
step3_1: "Теперь пришло время на кого-то подписаться!"
step3_2: "Ваша домашняя и социальная ленты основаны на том, за кем вы следите, поэтому
для начала попробуйте следить за парой аккаунтов.\nНажмите на кружок с плюсом
в правом верхнем углу профиля, чтобы следить за ним."
@ -1225,22 +1254,19 @@ _tutorial:
step4_2: "Для своего первого сообщения некоторые люди любят делать {introduction}
сообщение или простое \"Hello world!\""
step5_1: "Временные рамки, везде временные рамки!"
step5_2: "В вашем экземпляре включены {timelines} различных временных линий."
step5_3: "Главная {icon} лента - это лента, где вы можете видеть сообщения ваших
подписок и других на этом инстансе. Если вы хотите чтобы главная лента показывала
только посты ваших подписок вы можете легко это изменить в настройках!"
step5_2: "В вашем сервере включены {timelines} разные ленты."
step5_3: "Домашняя {icon} лента - это лента, где вы можете видеть посты тех, на
кого вы подписались."
step5_4: "Местная {icon} лента - это лента где вы можете видеть сообщения всех остальных
пользователей данного инстанса."
step5_5: "Лента Социальная {icon} - это лента, где вы можете видеть посты только
от аккаунтов, на которые вы подписаны."
step5_6: "Лента Рекомендованная {icon} это лента, где вы можете видеть посты с инстансов,
рекомендованных администраторами."
пользователей данного сервера."
step5_5: "Социальная лента {icon} - это комбинация домашней и местной лент."
step5_6: "На ленте Рекомендованных {icon} вы можете видеть посты с серверов, которые
рекомендуют администраторы."
step5_7: "Глобальная {icon} лента - это место, где вы можете видеть сообщения от
всех других подключенных экземпляров."
всех других подключенных серверов."
step6_1: "Итак, что это за место?"
step6_2: "Ну, вы не просто присоединились к Кальки. Вы присоединились к порталу
в Fediverse, взаимосвязанной сети из тысяч серверов, называемых \"инстансами\"\
."
step6_2: "Ну, вы не просто присоединились к Firefish. Вы вошли в Fediverse, взаимосвязанную
сеть из тысяч серверов."
step6_3: "Каждый сервер работает по-своему, и не на всех серверах работает Firefish.
Но этот работает! Это немного сложно, но вы быстро разберетесь."
step6_4: "Теперь идите, изучайте и развлекайтесь!"
@ -1257,6 +1283,26 @@ _2fa:
securityKeyInfo: "Вы можете настроить вход с помощью аппаратного ключа безопасности,
поддерживающего FIDO2, или отпечатка пальца или PIN-кода на устройстве."
step2Url: 'Вы также можете ввести этот URL если используете программу на компьютере:'
securityKeyName: Введите название ключа
removeKeyConfirm: Действительно удалить ключ {name}?
removeKey: Удалить ключ безопасности
step2Click: Нажав на этот QR-код, вы сможете зарегистрировать 2FA в вашем ключе
безопасности или приложении-аутентификаторе для телефона.
registerTOTPBeforeKey: Пожалуйста, настройте приложение-аутентификатор, чтобы зарегистрировать
ключ безопасности или пароль.
chromePasskeyNotSupported: Пароли Chrome пока не поддерживаются.
renewTOTP: Перенастроить приложение-аутентификатор
renewTOTPConfirm: Это приведет к тому, что коды подтверждения из предыдущего приложения
перестанут работать
renewTOTPOk: Перенастроить
renewTOTPCancel: Отменить
token: 2FA Токен
whyTOTPOnlyRenew: Приложение аутентификатора нельзя удалить, пока зарегистрирован
ключ безопасности.
tapSecurityKey: Пожалуйста, следуйте инструкциям вашего браузера, чтобы зарегистрировать
ключ безопасности или ключ-пароль
step3Title: Введите код аутентификации
securityKeyNotSupported: Ваш браузер не поддерживает ключи безопасности.
_permissions:
"read:account": "Просматривать данные учётной записи"
"write:account": "Изменять данные учётной записи"
@ -1293,18 +1339,19 @@ _permissions:
_auth:
shareAccess: "Дать доступ для «{name}» к вашей учётной записи?"
shareAccessAsk: "Уверены, что хотите дать приложению доступ к своей учётной записи?"
permissionAsk: "Приложение запрашивает следующие разрешения"
permissionAsk: "Приложение запрашивает следующие разрешения:"
pleaseGoBack: "Вернитесь, пожалуйста, в приложение"
callback: "Возврат в приложение"
denied: "Доступ закрыт"
copyAsk: Пожалуйста, вставьте следующий код авторизации в приложение
copyAsk: 'Пожалуйста, вставьте следующий код авторизации в приложение:'
allPermissions: Полный доступ к аккаунту
_antennaSources:
all: "Все посты"
homeTimeline: "Посты тех на которых вы подписаны"
users: "Посты выбранных пользователей"
userList: "Посты пользователей из выбранных списков"
userGroup: "Посты от пользователей из заданной группы"
instances: Посты от всех пользователей на инстансе
instances: Посты от всех пользователей на сервере
_weekday:
sunday: "Воскресенье"
monday: "Понедельник"
@ -1320,28 +1367,32 @@ _widgets:
calendar: "Календарь"
trends: "Актуальное"
clock: "Часы"
rss: "Просмотр RSS"
rss: "RSS-читалка"
activity: "Активность"
photos: "Фото"
digitalClock: "Цифровые часы"
federation: "Федерация"
postForm: "Форма отправки"
postForm: "Создание поста"
slideshow: "Показ слайдов"
button: "Кнопка"
onlineUsers: "Пользователи сейчас с сети"
onlineUsers: "Пользователи онлайн"
jobQueue: "Очередь заданий"
serverMetric: "Показатели сервера"
aiscript: "Консоль AiScript"
aichan: "Ай"
rssTicker: RSS-тикер
unixClock: UNIX часы
instanceCloud: Облачко инстансов
instanceCloud: Облачко серверов
userList: Список пользователей
_userList:
chooseList: Выберите список
meiliStatus: Состояние сервера
meiliSize: Размер индекса
meiliIndexCount: Индексированные посты
serverInfo: Информация о сервере
_cw:
hide: "Спрятать"
show: "Показать еще"
show: "Показать содержимое"
chars: "знаков: {count}"
files: "файлов: {count}"
_poll:
@ -1368,11 +1419,12 @@ _poll:
remainingSeconds: "Осталось {s} с"
_visibility:
public: "Общедоступно"
publicDescription: "Открыто для всех"
publicDescription: "Ваш пост будет виден во всех публичных лентах"
home: "Скрытый"
homeDescription: "Не для общих лент"
followers: "Для подписчиков"
followersDescription: "Только вашим подписчикам"
followersDescription: "Сделать видимым только для ваших подписчиков и упомянутых
пользователей"
specified: "Личное"
specifiedDescription: "Тем, кого укажете"
localOnly: "Локально"
@ -1696,7 +1748,7 @@ _pages:
pick: "Выбор из списка"
_pick:
arg1: "Списки"
arg2: "Индекс"
arg2: "Позиция"
listLen: "Количество элементов в списке"
_listLen:
arg1: "Списки"
@ -1759,7 +1811,7 @@ _notification:
quote: "Цитаты"
reaction: "Реакции"
pollVote: "Голосования"
receiveFollowRequest: "Получен запрос на подписку"
receiveFollowRequest: "Полученные запросы на подписку"
followRequestAccepted: "Запрос на подписку одобрен"
groupInvited: "Приглашение в группы"
app: "Уведомления из приложений"
@ -1770,6 +1822,9 @@ _notification:
followBack: Подписался на вас обратно
emptyPushNotificationMessage: Пуш уведомления были обновлены
pollEnded: Результаты опроса стали доступны
reacted: отреагировал на ваш пост
renoted: распространил ваш пост
voted: проголосовал в вашем опросе
_deck:
alwaysShowMainColumn: "Всегда показывать главную колонку"
columnAlign: "Выравнивание колонок"
@ -1787,10 +1842,11 @@ _deck:
widgets: "Виджеты"
notifications: "Уведомления"
tl: "Лента"
antenna: "Антенны"
antenna: "Антенна"
list: "Списки"
mentions: "Упоминания"
direct: "Личное"
channel: Канал
deleteProfile: Удалить воркспейс
introduction: Создайте идеальный интерфейс для себя, свободно расположив столбцы!
introduction2: Нажмите на + в правой части экрана, чтобы добавлять новые столбцы
@ -1891,7 +1947,7 @@ socialTimeline: Социальная лента
driveCapOverrideCaption: Сбросить до настроек по умолчанию введя значение 0 или меньше.
deleteAccount: Удалить аккаунт
numberOfPageCache: Число кэшируемых страниц
pushNotificationNotSupported: Ваш браузер или инстанс не поддерживает пуш уведомления
pushNotificationNotSupported: Ваш браузер или сервер не поддерживает пуш уведомления
sendPushNotificationReadMessageCaption: Уведомление содержащее текст "{emptyPushNotificationMessage}"
будет показано на короткое время. Это может увеличить расход батареи вашего устройства,
если это применимо.
@ -1903,7 +1959,7 @@ adminCustomCssWarn: Этот параметр следует использов
клиенты перестанут нормально функционировать. Пожалуйста, убедитесь, что ваш CSS
работает должным образом, протестировав его в настройках вашего пользователя.
showUpdates: Показывать всплывающее окно при обновлении Firefish
recommendedInstances: Рекомендованные инстансы
recommendedInstances: Рекомендованные серверы
defaultReaction: Эмодзи реакция по умолчанию для выходящих и исходящих постов
license: Лицензия
indexPosts: Индексировать посты
@ -1949,7 +2005,7 @@ shuffle: Перемешать
moveFrom: Переместится на этот аккаунт с старого аккаунта
moveFromLabel: 'Аккаунт с которого перемещаетесь:'
moveAccountDescription: Этот процесс необратим. Убедитесь что вы сделали псевдоним
для этого аккаунта до перемещения. Пожалуйста введите аккаунт в формате @person@instance.com
для этого аккаунта до перемещения. Пожалуйста введите аккаунт в формате @person@server.com
moveTo: Переместить текущий аккаунт на новый аккаунт
_messaging:
groups: Группы
@ -1971,10 +2027,10 @@ hiddenTagsDescription: 'Список хештегов (без #), которые
и "обзор". Скрытые хэштеги по-прежнему можно обнаружить в других местах.'
moveFromDescription: Это установит псевдоним для старого аккаунта, так что вы сможете
переместить тот аккаунт на текущий. Делайте это ДО перемещения со старого аккаунта.
Пожалуйста введите аккаунт в формате @person@instance.com
Пожалуйста введите аккаунт в формате @person@server.com
customKaTeXMacroDescription: 'Настройте макросы чтобы легко писать математические
выражения! Обозначение соответствует определениям команд LaTeX и записывается как
\newcommand{\название}{содержание} или \newcommand{\название}[количество аргументов]{содержание}.
\newcommand{\ название}{содержание} или \newcommand{\название}[количество аргументов]{содержание}.
Для примера, \add{3}[2]{#1 + #2} будет раскрывать \add{3}{foo} до 3 + foo. Фигурные
скобки, окружающие имя макроса, можно заменить на круглые или квадратные скобки.
Это влияет на квадратные скобки, используемые для аргументов. Для каждой строки
@ -2016,3 +2072,68 @@ channelFederationWarn: Каналы пока не федерируются с д
image: Изображение
cw: Предупреждение о содержании
xl: Очень крупно
_experiments:
enablePostImports: Включить импорт постов
postImportsCaption: Позволяет пользователям импортировать свои посты из прошлых
учетных записей Firefish, Misskey, Mastodon, Akkoma и Pleroma. Это может вызвать
снижение скорости при загрузке, если ваша очередь перегружена.
title: Эксперименты
_skinTones:
yellow: Жёлтый
dark: Тёмный
mediumLight: Средне-светлый
mediumDark: Средне-тёмный
medium: Средний
light: Светлый
_filters:
fromUser: От пользователя
withFile: С файлом
followingOnly: Только подписки
followersOnly: Только подписчики
fromDomain: С домена
notesBefore: Посты до
notesAfter: Посты после
_dialog:
charactersExceeded: 'Превышено максимальное количество символов! Ограничение: {current}/{max}'
charactersBelow: 'Недостаточно символов! Ограничение: {current}/{min}'
_feeds:
copyFeed: Скопировать ленту
rss: RSS
jsonFeed: JSON-лента
atom: Atom
enableServerMachineStats: Включить статистику серверного оборудования
enableIdenticonGeneration: Включить генерацию Identicon
reactionPickerSkinTone: Предпочитаемый цвет кожи эмодзи
sendModMail: Отправить сообщение о модерации
findOtherInstance: Найти другой сервер
signupsDisabled: Регистрация на этом сервере сейчас отключена, но вы всегда можете
зарегистрироваться на другом сервере! Если у вас есть код приглашения на этот сервер,
пожалуйста, введите его ниже.
preventAiLearningDescription: Попросить сторонние языковые модели ИИ не изучать загружаемый
вами контент, например, посты и изображения.
verifiedLink: Проверенная ссылка
swipeOnMobile: Разрешить перелистывание между страницами
preventAiLearning: Защита от скрепинга ИИ-ботов
userSaysSomethingReasonReply: '{name} ответил на пост с {reason}'
userSaysSomethingReasonRenote: '{name} распространил пост с {reason}'
userSaysSomethingReasonQuote: '{name} процитировал пост с {reason}'
isBot: Этот аккаунт является ботом
isAdmin: Администратор
isPatron: Патрон Firefish
showPopup: Оповещать пользователей всплывающим окном
neverShow: Не показывать снова
remindMeLater: Возможно позже
removeQuote: Удалить цитату
silencedWarning: Эта страница отображается потому, что эти пользователи с серверов,
которые ваш администратор заглушил, поэтому они потенциально могут быть спамом.
isModerator: Модератор
noGraze: Пожалуйста, отключите расширение браузера "Graze для Mastodon", поскольку
оно мешает работе Firefish.
newer: новее
older: старее
showWithSparkles: Показать с блеском
youHaveUnreadAnnouncements: У вас есть непрочитанные объявления
donationLink: Ссылка на страницу для взносов
isLocked: Этот аккаунт имеет одобрение запросов на подписку
removeRecipient: Удалить получателя
removeMember: Удалить участника

View File

@ -1,7 +1,7 @@
---
_lang_: "Slovenčina"
headlineMisskey: "Sieť prepojená poznámkami"
introMisskey: "Vitajte! Firefish je otvorená a decentralizovaná mikroblogovacia služba.\n\"Poznámkami\" môžete zdieľať svoje myšlienky so všetkými okolo. 📡\nPomocou \"reakcií\" môžete rýchlo vyjadri svoje pocity o každého poznámkach. 👍\nPoďte objavovať svet! 🚀"
headlineFirefish: "Sieť prepojená poznámkami"
introFirefish: "Vitajte! Firefish je otvorená a decentralizovaná mikroblogovacia služba.\n\"Poznámkami\" môžete zdieľať svoje myšlienky so všetkými okolo. 📡\nPomocou \"reakcií\" môžete rýchlo vyjadri svoje pocity o každého poznámkach. 👍\nPoďte objavovať svet! 🚀"
monthAndDay: "{day}. {month}."
search: "Hľadať"
notifications: "Oznámenia"

View File

@ -1,7 +1,10 @@
---
_lang_: "Svenska"
headlineMisskey: "Ett nätverk kopplat av noter"
introMisskey: "Välkommen! Firefish är en öppen och decentraliserad mikrobloggningstjänst.\nSkapa en \"not\" och dela dina tankar med alla runtomkring dig. 📡\nMed \"reaktioner\" kan du snabbt uttrycka dina känslor kring andras noter.👍\nLåt oss utforska en nya värld!🚀"
headlineFirefish: "En öppen källkod och decentraliserad social media plattform som
är gratis för all framtid! 🚀"
introFirefish: "Välkommen! Firefish är en öppen och decentraliserad mikrobloggningstjänst.\n
Skapa en \"not\" och dela dina tankar med alla runtomkring dig. 📡\nMed \"reaktioner\"\
\ kan du snabbt uttrycka dina känslor kring andras noter.👍\nLåt oss utforska en
nya värld!🚀"
monthAndDay: "{day}/{month}"
search: "Sök"
notifications: "Notifikationer"
@ -16,7 +19,7 @@ enterUsername: "Ange användarnamn"
renotedBy: "Omnoterad av {user}"
noNotes: "Inga noteringar"
noNotifications: "Inga aviseringar"
instance: "Instanser"
instance: "Server Instans"
settings: "Inställningar"
basicSettings: "Basinställningar"
otherSettings: "Andra inställningar"
@ -44,7 +47,8 @@ copyContent: "Kopiera innehåll"
copyLink: "Kopiera länk"
delete: "Radera"
deleteAndEdit: "Radera och ändra"
deleteAndEditConfirm: "Är du säker att du vill radera denna not och ändra den? Du kommer förlora alla reaktioner, omnoteringar och svar till den."
deleteAndEditConfirm: "Är du säker att du vill radera denna not och ändra den? Du
kommer förlora alla reaktioner, omnoteringar och svar till den."
addToList: "Lägg till i lista"
sendMessage: "Skicka ett meddelande"
copyUsername: "Kopiera användarnamn"
@ -63,9 +67,11 @@ import: "Importera"
export: "Exportera"
files: "Filer"
download: "Nedladdning"
driveFileDeleteConfirm: "Är du säker att du vill radera filen \"{name}\"? Noter med denna fil bifogad kommer också raderas."
driveFileDeleteConfirm: "Är du säker att du vill radera filen \"{name}\"? Notera att
denna kommer att bli raderad från alla poster som har den bifogad."
unfollowConfirm: "Är du säker att du vill avfölja {name}?"
exportRequested: "Du har begärt en export. Detta kan ta lite tid. Den kommer läggas till i din Drive när den blir klar."
exportRequested: "Du har begärt en export. Detta kan ta lite tid. Den kommer läggas
till i din Drive när den blir klar."
importRequested: "Du har begärt en import. Detta kan ta lite tid."
lists: "Listor"
noLists: "Du har inga listor"
@ -80,9 +86,11 @@ error: "Fel!"
somethingHappened: "Ett fel har uppstått"
retry: "Försök igen"
pageLoadError: "Det gick inte att ladda sidan."
pageLoadErrorDescription: "Detta händer oftast p.g.a. nätverksfel eller din webbläsarcache. Försök tömma din cache och testa sedan igen efter en liten stund."
pageLoadErrorDescription: "Detta händer oftast p.g.a. nätverksfel eller din webbläsarcache.
Försök tömma din cache och testa sedan igen efter en liten stund."
serverIsDead: "Servern svarar inte. Vänta ett litet tag och försök igen."
youShouldUpgradeClient: "För att kunna se denna sida, vänligen ladda om sidan för att uppdatera din klient."
youShouldUpgradeClient: "För att kunna se denna sida, vänligen ladda om sidan för
att uppdatera din klient."
enterListName: "Skriv ett namn till listan"
privacy: "Integritet"
makeFollowManuallyApprove: "Följarförfrågningar kräver manuellt godkännande"
@ -107,7 +115,8 @@ sensitive: "Känsligt innehåll"
add: "Lägg till"
reaction: "Reaktioner"
reactionSetting: "Reaktioner som ska visas i reaktionsväljaren"
reactionSettingDescription2: "Dra för att omordna, klicka för att radera, tryck \"+\" för att lägga till."
reactionSettingDescription2: "Dra för att omordna, klicka för att radera, tryck \"\
+\" för att lägga till."
rememberNoteVisibility: "Komihåg notvisningsinställningar"
attachCancel: "Ta bort bilaga"
markAsSensitive: "Markera som känsligt innehåll"
@ -136,13 +145,20 @@ emojiUrl: "Emoji länk"
addEmoji: "Lägg till emoji"
settingGuide: "Rekommenderade inställningar"
cacheRemoteFiles: "Spara externa filer till cachen"
cacheRemoteFilesDescription: "När denna inställning är avstängd kommer externa filer laddas direkt från den externa instansen. Genom att stänga av detta kommer lagringsutrymme minska i användning men kommer öka datatrafiken eftersom miniatyrer inte kommer genereras."
cacheRemoteFilesDescription: "När denna inställning är avstängd kommer externa filer
laddas direkt från den externa instansen. Genom att stänga av detta kommer lagringsutrymme
minska i användning men kommer öka datatrafiken eftersom miniatyrer inte kommer
genereras."
flagAsBot: "Markera konto som bot"
flagAsBotDescription: "Aktivera det här alternativet om kontot är kontrollerat av ett program. Om aktiverat kommer den fungera som en flagga för andra utvecklare för att hindra ändlösa kedjor med andra bottar. Det kommer också få Misskeys interna system att hantera kontot som en bot."
flagAsBotDescription: "Aktivera det här alternativet om kontot är kontrollerat av
ett program. Om aktiverat kommer den fungera som en flagga för andra utvecklare
för att hindra ändlösa kedjor med andra bottar. Det kommer också få Firefish interna
system att hantera kontot som en bot."
flagAsCat: "Markera konto som katt"
flagAsCatDescription: "Aktivera denna inställning för att markera kontot som en katt."
flagShowTimelineReplies: "Visa svar i tidslinje"
flagShowTimelineRepliesDescription: "Visar användarsvar till andra användares noter i tidslinjen om påslagen."
flagShowTimelineRepliesDescription: "Visar användarsvar till andra användares noter
i tidslinjen om påslagen."
autoAcceptFollowed: "Godkänn följarförfrågningar från användare du följer automatiskt"
addAccount: "Lägg till konto"
loginFailed: "Inloggningen misslyckades"
@ -155,7 +171,11 @@ searchWith: "Sök: {q}"
youHaveNoLists: "Du har inga listor"
followConfirm: "Är du säker att du vill följa {name}?"
proxyAccount: "Proxykonto"
proxyAccountDescription: "Ett proxykonto är ett konto som agerar som en extern följare för användare under vissa villkor. Till exempel, när en användare lägger till en extern användare till en lista så kommer den externa användarens aktivitet inte levireras till instansen om ingen lokal användare följer det kontot, så proxykontot används istället."
proxyAccountDescription: "Ett proxykonto är ett konto som agerar som en extern följare
för användare under vissa villkor. Till exempel, när en användare lägger till en
extern användare till en lista så kommer den externa användarens aktivitet inte
levereras till instansen om ingen lokal användare följer det kontot, så proxykontot
används istället."
host: "Värd"
selectUser: "Välj användare"
recipient: "Mottagare"
@ -185,11 +205,13 @@ instanceInfo: "Instansinformation"
statistics: "Statistik"
clearQueue: "Rensa kö"
clearQueueConfirmTitle: "Är du säker att du vill rensa kön?"
clearQueueConfirmText: "Om någon not är olevererad i kön kommer den inte federeras. Vanligtvis behövs inte denna handling."
clearQueueConfirmText: "Om någon not är olevererad i kön kommer den inte federeras.
Vanligtvis behövs inte denna handling."
clearCachedFiles: "Rensa cache"
clearCachedFilesConfirm: "Är du säker att du vill radera alla cachade externa filer?"
blockedInstances: "Blockerade instanser"
blockedInstancesDescription: "Lista adressnamn av instanser som du vill blockera. Listade instanser kommer inte längre kommunicera med denna instans."
blockedInstancesDescription: "Lista adressnamn av instanser som du vill blockera.
Listade instanser kommer inte längre kommunicera med denna instans."
muteAndBlock: "Tystningar och blockeringar"
mutedUsers: "Tystade användare"
blockedUsers: "Blockerade användare"
@ -318,3 +340,444 @@ _deck:
tl: "Tidslinje"
list: "Listor"
mentions: "Omnämningar"
removeReaction: Radera från dina reaktioner
renoteMute: Tysta boostningar
renoteUnmute: Ljuda boostningar
flagSpeakAsCat: Prata som en katt
noInstances: Det finns inga servrar
keepOriginalUploadingDescription: Sparar originalen av uppladdade bilder som de är.
Om avstängt, kommer en ny version genererad vid uppladdning.
fromUrl: från URL
explore: Utforska
messageRead: Läs
noMoreHistory: Det finns ingen framtida historik
startMessaging: Starta en ny chatt
agreeTo: Jag accepterar till {0}
drive: Enhet
fileName: Filnamn
inputNewDescription: Ange en ny benämning
inputNewFolderName: Ange ett nytt mappnamn
hasChildFilesOrFolders: Eftersom denna mappen inte är tom, kan den inte bli raderad.
copyUrl: Kopiera URL
watch: Bevaka
thisMonth: Månad
today: Idag
dayX: '{day}'
monthX: '{month}'
yearX: '{year}'
connectService: Anslut
disconnectService: Bortkoppla
enableLocalTimeline: Anslut till lokal tidslinje
invite: Bjud in
driveCapacityPerLocalAccount: Enhetens kapacitet per lokal användare
inMb: I megabyte
pinnedPagesDescription: Ange sökväg till sidor som du vill fästa på topp av sidorna
på denna server, separerade av sidbrytningar.
hcaptcha: hCaptcha
antennasDesc: "Antenner visar nya poster som matchar de kriterier som du anger\nDe
kan nås från sidlinje sidan."
unsilenceConfirm: Är du säker på att du vill ångra tystningen av denna användare?
securityKey: Säkerhetsnyckel
markAsReadAllNotifications: Markera alla notifikationer som lästa
quoteQuestion: Lägg till som en citering?
noMessagesYet: Inga meddelande ännu
newMessageExists: Det finns inga nya meddelanden
weakPassword: Svagt lösenord
normalPassword: Dugligt lösenord
strongPassword: Starkt lösenord
passwordMatched: Matchar
passwordNotMatched: Matchar inte
signinWith: Logga in med {x}
disableAnimatedMfm: Inaktivera MFM med animering
noFollowRequests: Du har inte några väntande följbekräftelser
clientSettings: Klientinställningar
promote: Befordra
numberOfDays: Antalet dagar
objectStorageUseSSL: Använd SSL
objectStorageUseSSLDesc: Stäng av detta om du inte kommer använda HTTPS för API anslutningar.
recentUsed: Senast använd
nothing: Det finns inget att visa här
lastUsedDate: Senaste använd vid
state: Stat
disablePagesScript: Inaktivera AiScript på sidor
expandOnNoteClick: Öppna post vid klick
updateRemoteUser: Uppdatera fjärranvändarinformation
deleteAllFiles: Radera alla filer
userSuspended: Denna användare har blivit avstängd.
inboxUrl: Inbox URL
serviceworkerInfo: Måste vara aktiverat för push-notifikationer.
deletedNote: Radera poster
expandTweet: Expandera tweet
themeEditor: Thema redigerare
describeFile: Lägg till bildtext
enterFileDescription: Beskriv bildtext
manage: Hantering
useBlurEffectForModal: Använd oskärpa effekter för modeller
width: Bredd
small: Liten
disableAll: Inaktivera alla
tokenRequested: Tillåt tillgång till konto
channelFederationWarn: Kanalerna federeras inte till andra servrar ännu
manageGroups: Hantera grupper
tos: Användarvillkor
start: Starta
home: Hem
activity: Aktivitet
themeForDarkMode: Teman som används i Mörkt läge
maintainerEmail: Underhållare e-post
enableHcaptcha: Aktivera hCaptcha
hcaptchaSiteKey: Sidnyckel
recaptchaSecretKey: Hemlig nyckel
withFiles: Inkludera filer
popularTags: Populära taggar
notFound: Kan inte hittas
uploadFolder: Standardmappar för uppladdning
retype: Ange igen
next: Nästa
checking: Kontrollerar...
or: Eller
groupInvited: Du har blivit inbjuden till en grupp
docSource: Källa till detta dokument
createAccount: Skapa konto
total: Total
objectStorage: Objektlagring
objectStorageRegion: Region
objectStorageUseProxy: Anslut över Proxy
objectStorageUseProxyDesc: Stäng av detta om du inte kommer använde en Proxy för API
anslutningar
sounds: Ljud
details: Detaljer
installedApps: Auktoriserade applikationer
installedDate: Auktoriserad vid
script: Skript
removeAllFollowingDescription: Körning av detta kommer sluta följa alla konton från
{host}. Vänligen kör detta om servern t.ex. inte längre existerar.
userSilenced: Denna användare har blivit tystnad.
visibility: Synlighet
delayed: Fördröjning
useGlobalSetting: Använd globala inställningar
selectInstance: Välj en server
instanceName: Servernamn
searchPlaceholder: Sök Firefish
noThankYou: Nej tack
jumpToPrevious: Hoppa till föregående
listsDesc: Listor låter dig skapa en tidlinje med specificerade användare. Dessa kan
sedan bli nådda från tidlinje sidan.
flagSpeakAsCatDescription: Dina poster kommer ge en nyans som om du är i katt-läge
silencedInstances: Tystade instanser
hiddenTags: Dolda Hashtaggar
silenced: Tystad
nUsersRead: Läs med {n}
themeForLightMode: Teman som används i Ljust Läge
light: Ljus
recaptcha: reCAPTCHA
enableRecaptcha: Aktivera reCAPTCHA
help: Hjälp
groupName: Gruppnamn
name: Namn
resetPassword: Återställ lösenord
newPasswordIs: Ditt nya lösenord är "{password}"
cacheClear: Rensa cache
markAsReadAllTalkMessages: Markera alla meddelanden som lästa
uiLanguage: Användargränssnitt
disableDrawer: Använd inte byrålådor-stil menyer
tapSecurityKey: Klicka in din säkerhetsnyckel.
language: Språk
objectStorageRegionDesc: Ange en region som 'xx-east-1'. Om du anger din tjänst som
inte skiljer mellan regioner, lämna detta blankt eller ange som 'us-east-1'.
objectStorageSetPublicRead: Ställ in "public-read" vid uppladdningar
scratchpadDescription: Scratchpaden tillgängliggör en miljö för AiScript experiment.
Du kan skriva, köra och checka ut resultaten från den när du interagerar med Firefish.
yourAccountSuspendedDescription: Detta kontot har blivit avstängt eftersom det bröt
mot serverns användaravtal eller liknande. Vänligen kontakta administratörer om
du vill veta mer detaljerade anledningar. Vänligen skapa inte ett nytt konto.
divider: Fördelare
addItem: Lägg till artikel
poll: Opinionsundersökning
useCw: Dölj innehåll
enablePlayer: Öppna videospelare
disablePlayer: Stäng videospelare
description: Beskrivning
author: Författare
accessibility: Tillgänglighet
useObjectStorage: Använd objektlagring
objectStorageBaseUrl: Grundläggande URL
deleteAllFilesConfirm: Är du säker på att du vill radera alla filer?
menu: Meny
regexpError: Regular expression fel
wordMute: Ord tystning
regexpErrorDescription: 'Ett fel skedde vid regular expression på linje {line} av
dina {tab} ord tystningar:'
instanceMute: Server tystningar
userSaysSomething: '{name} sa något'
userSaysSomethingReason: '{name} sade {reason}'
makeActive: Aktivera
notificationSettingDesc: Välj typerna av notifieringsinställningarna att visa.
fromDrive: Från Enhet
uploadFromUrlMayTakeTime: Det kan ta en tid innan uppladdningen är slutförd.
uploadFromUrlRequested: Uppladdning som förfrågat
unwatch: Sluta bevaka
enableRecommendedTimeline: Aktivera rekommenderad tidslinje
showLess: Stäng
regenerate: Återskapa
promotion: Befordrad
doNothing: Ignorera
thisYear: År
manageAntennas: Hantera Antenner
deleted: Raderad
editNote: Redigera anteckning
edited: Redigerad vid {date} {time}
syncDeviceDarkMode: Synkronisera mörkt läge med dina enhetsinställningar
dayOverDayChanges: Ändringar från igår
selectChannel: Välj en kanal
lightThemes: Ljusa teman
dark: Mörk
inputNewFileName: Ange ett nytt filnamn
whenServerDisconnected: När den tappar uppkopplingen till servern
disconnectedFromServer: Anslutning till server har tappats
iconUrl: Ikon URL
bannerUrl: Banner bild URL
hcaptchaSecretKey: Hemlig nyckel
onlyOneFileCanBeAttached: Du kan endast ange en bilaga till ett meddelande
signinFailed: Kan inte logga in. Ange korrekt användarnamn och lösenord.
notesAndReplies: Poster och svar
token: Token
twoStepAuthentication: Två-faktor-autentisering
antennaInstancesDescription: Lista en servervärd per linje
moderator: Moderator
moderation: Moderering
chooseEmoji: Välj en emoji
unableToProcess: Operationen kunde inte slutföras
output: Output
expandOnNoteClickDesc: Om inaktiverad, kan du öppna posten vid högerklicksmenyn eller
genom att klicka på tidsstämpeln.
aboutFirefish: Om Firefish
older: Äldre
hiddenTagsDescription: 'Lista hashtaggar (utan # symbolen) för de hashtaggar du vill
dölja från trendande och utforska. Dolda hashtaggar kan fortfarande hittas via andra
funktioner.'
darkThemes: Mörka teman
images: Bilder
selectFiles: Välj filer
renameFile: Byt namn på fil
folderName: Filnamn
createFolder: Skapa en mapp
renameFolder: Byt namn på denna mapp
emptyDrive: Din enhet är tom
emptyFolder: Denna mapp är tom
unableToDelete: Kan inte radera
rename: Byt namn
deleteFolder: Radera denna mapp
addFile: Lägg till en fil
banner: Banner
reload: Uppdatera
reloadConfirm: Vill du uppdatera din tidslinje?
accept: Acceptera
tosUrl: Användarvillkor URL
pages: Sidor
disablingTimelinesInfo: Administratörer och moderatorer har alltid tillgång till alla
tidslinjer, även om de inte är aktiverade
registration: Registrera
enableRegistration: Aktivera ny användarregistrering
driveCapacityPerRemoteAccount: Enhetskapacitet per extern användare
enableGlobalTimeline: Aktivera global tidslinje
antennaSource: Antennkällor
notifyAntenna: Informera vid nya poster
withFileAntenna: Ange poster med filer
exploreFediverse: Upptäck ett fidiverse
markAsReadAllUnreadNotes: Markera alla poster som lästa
inputMessageHere: Ange meddelande här
members: Medlemmar
available: Tillgänglig
usernameInvalidFormat: Du kan ange versaler eller gemener, nummer och underskrifter.
tooLong: För lång
joinOrCreateGroup: Bli inbjuden till en grupp eller skapa en egen.
doing: Bearbetar...
youHaveNoGroups: Du har inga grupper
aboutX: Om {x}
existingAccount: Existerande konto
install: Installera
uninstall: Avinstallera
sort: Sortera
ascendingOrder: Stigande
leaveConfirm: Ändringar har inte sparats. Vill du kasta dem?
plugins: Plugin
preferencesBackups: Backup av inställningar
enableEmail: Aktivera epost distribuering
smtpSecure: Använd strikt SSL/TLS vid SMTP anslutningar
smtpSecureInfo: Stäng av detta vid användning av STARTTLS
testEmail: Test av epost leverans
userSaysSomethingReasonReply: '{name} svarade på en post innehållande {reason}'
userSaysSomethingReasonRenote: '{name} boosted en post innehållande {reason}'
userSaysSomethingReasonQuote: '{name} citerade en post innehållande {reason}'
logs: Loggar
database: Databas
channel: Kanaler
create: Skapa
notificationSetting: Notisinställningar
objectStorageS3ForcePathStyle: Använd filmapp-baserade slutpunkter för URL:er
newNoteRecived: Det finns nya poster
deck: Däck
undeck: Lämna däck
large: Stor
newer: Nyare
silenceThisInstance: Tysta denna instans
silencedInstancesDescription: Lista värdnamn på server som du vill tysta. Konton på
listade instanser behandlas som om de är "Tystade", de kan endast göra följbekräftelser
och kan inte nämna lokala konton som inte följs. Detta påverkar inte blockerade
instanser.
uploadFromUrl: Uppladdad från URL
birthday: Födelsedag
theme: Teman
avatar: Avatar
uploadFromUrlDescription: URL av filen som du vill ladda upp
remoteUserCaution: Informationen från en avlägsen användare kan inte slutföras
yearsOld: '{age} år gammal'
location: Plats
selectFile: Välj en fil
registeredDate: Registrerade på
selectFolder: Välj en mapp
circularReferenceFolder: Destinationsmappen är en undermapp till mappen som du försöker
flytta.
instanceDescription: Serverbeskrivning
selectFolders: Välj mappar
reject: Neka
normal: Normal
withReplies: Inkludera svar
registerSecurityKey: Registrera en säkerhetsnyckel
enableServiceworker: Aktivera push-notifikationer för din webbläsare
maintainerName: Underhållare
pinnedPages: Fästa sidor
basicInfo: Grundläggande info
pinnedUsers: Pinnade användare
backgroundImageUrl: Bakgrundsbild URL
pinnedUsersDescription: Lista användarnamn separerade med radbrytning att bli fäst
i "Utforska" fliken
recaptchaSiteKey: Sid nyckel
pinnedClipId: ID av klippet du vill fästa
avoidMultiCaptchaConfirm: Användning av flera Captcha system kan orsaka problem. Vill
du inaktivera andra Captcha system som är aktiverade i nuläget? Om du vill att de
ska fortsätta vara inaktiverade, tryck ångra.
antennas: Antenner
antennaKeywords: Nyckelord att följa
antennaExcludeKeywords: Nyckelord att exkludera
antennaKeywordsDescription: Separera med mellanrum för ett OCH villkor eller med sidbrytning
för ett ELLER villkor.
caseSensitive: Skiftlägeskänsliga
recentlyDiscoveredUsers: Senaste upptäckta användare
antennaUsersDescription: Lista ett användarnamn per linje
silenceConfirm: Är du säker att du vill tysta denna användare?
connectedTo: Följande konton är anslutna
unsilence: Ångra tystning
recentlyRegisteredUsers: Senaste användare
exploreUsersCount: Det finns {count} användare
silence: Tysta
popularUsers: Populära användare
recentlyUpdatedUsers: Senaste aktiva användare
administrator: Administratör
passwordLessLogin: Lösenordslös-inloggning
about: Om
nUsersMentioned: Benämnd av {n} användare
securityKeyName: Nyckelnamn
share: Dela
reduceUiAnimation: Minska UI animeringar
notFoundDescription: Ingen sida som korresponderar med denna URL kunde hittas
close: Stäng
group: Grupp
transfer: Överför
category: Kategori
createGroup: Skapa en grupp
ownedGroups: Ägda grupper
invites: Inbjudningar
groups: Grupper
title: Titel
joinedGroups: Deltagande grupper
tooShort: För kort
signinHistory: Inloggningshistorik
enable: Aktivera
text: Text
inviteToGroup: Bjud in till grupp
quoteAttached: Citera
messagingWithUser: Privatchatt
messagingWithGroup: Gruppchatt
invitationCode: Inbjudningskod
noteOf: Postad av {user}
unavailable: Inte tillgänglig
invitations: Inbjudningar
useOsNativeEmojis: Använd operativsystemets lokala emojis
noHistory: Historik saknas
tags: Taggar
openImageInNewTab: Öppna bilder i ny flik
fontSize: Teckenstorlek
dashboard: Användargränssnitt
weekOverWeekChanges: Ändringar till föregående vecka
appearance: Utseende
accountSettings: Kontoinställningar
objectStorageBaseUrlDesc: "Denna URL används som referens. Ange URL för din CDN eller
Proxy om du använder någon.\nFör S3 använd 'https://<bucket>.s3.amazonaws.com' och
för GCS eller likvärdig tjänst använd 'https://storage.googleapis.com/<bucket>',
m.m."
objectStorageEndpointDesc: Lämna denna tom om du använder AWS S3, annars ange slutpunkten
som '<host>' eller '<host>:<port>', beroende på tjänsten som du använder.
objectStorageS3ForcePathStyleDesc: Aktivera detta vid konstruering av slutpunkter
i URL som är i format för 's3.amazonaws.com/<bucket>/' vid '<bucket>.s3.amazonaws.com'.
popout: Poppa-ut
showFixedPostForm: Visa postens form vid toppen av tidslinjen
listen: Lystna
none: Inga
showInPage: Visa på sida
masterVolume: Huvudvolym
volume: Volym
descendingOrder: Nedåtgående
scratchpad: Scratchpad
yourAccountSuspendedTitle: Detta kontot har blivit avstängt
email: Epost
relays: Reläer
invisibleNote: Osynliga poster
addRelay: Lägg till relä
enableInfiniteScroll: Ladda fler automatiskt
edit: Redigera
useFullReactionPicker: Använd full-storlek för reaktionsväljaren
notificationType: Notifieringstyp
pluginTokenRequestedDescription: Detta plugin kommer använda tillgänglighet inställd
här.
generateAccessToken: Generera tillgångstoken
permission: Tillstånd
smtpConfig: SMPT server inställningar
emailServer: Epost server
emailConfigInfo: Används för att bekräfta din epost vid registrering om du glömmer
till lösenord
emptyToDisableSmtpAuth: Lämna användarnamn och lösenord tomt vid inaktivering av SMTP
verifiering
emailAddress: Epost adress
smtpPort: Port
metrics: Metrik
display: Visa
copy: Kopiera
overview: Översikt
lastUsed: Senast använd
unregister: Avregistrera
addInstance: Lägg till server
objectStorageBucketDesc: Vänligen ange hink-namn som du använder som din leverantör.
accountMoved: Användaren har flyttat till ett nytt konto
hideThisNote: Dölj denna post
showFeaturedNotesInTimeline: Visa presenterade poster i tidslinjen
objectStorageBucket: Hink
objectStoragePrefix: Prefix
local: Lokal
remote: Avlägsen
objectStoragePrefixDesc: Filer som lagras under mappar kommer använda detta prefix.
objectStorageEndpoint: Slutpunkt
addedRelays: Tillagda reläer
height: Höjd
enableAll: Tillåt alla
cw: Innehållsvarning
enableEmojiReactions: Aktivera emoji reaktioner
showEmojisInReactionNotifications: Visa emojis i reaktion notifikationer
signinRequired: Vänligen registrera eller logga in innan du fortsätter
serverLogs: Serverloggar
deleteAll: Radera alla
removeAllFollowing: Sluta följa alla följda användare
medium: Mellan
integration: Integreringar
xl: XL

View File

@ -1,7 +1,7 @@
---
_lang_: "ภาษาไทย"
headlineMisskey: "เชื่อมต่อเครือข่ายโดยโน้ต"
introMisskey: "ยินดีต้อนรับจ้าาา! Firefish เป็นบริการไมโครบล็อกโอเพ่นซอร์ส แบบการกระจายอำนาจ\nสร้าง \"โน้ต\" เพื่อแบ่งปันความคิดของคุณกับทุกคนรอบตัวคุณกันเถอะ 📡\nด้วยการ \"รีแอคชั่นผู้คน\" คุณยังสามารถแสดงความรู้สึกของคุณเกี่ยวกับบันทึกของทุกคนได้อย่างรวดเร็ว 👍\n\nแล้วมาท่องสำรวจโลกใบใหม่กันเถอะ! 🚀"
headlineFirefish: "เชื่อมต่อเครือข่ายโดยโน้ต"
introFirefish: "ยินดีต้อนรับจ้าาา! Firefish เป็นบริการไมโครบล็อกโอเพ่นซอร์ส แบบการกระจายอำนาจ\nสร้าง \"โน้ต\" เพื่อแบ่งปันความคิดของคุณกับทุกคนรอบตัวคุณกันเถอะ 📡\nด้วยการ \"รีแอคชั่นผู้คน\" คุณยังสามารถแสดงความรู้สึกของคุณเกี่ยวกับบันทึกของทุกคนได้อย่างรวดเร็ว 👍\n\nแล้วมาท่องสำรวจโลกใบใหม่กันเถอะ! 🚀"
monthAndDay: "{เดือน}/{วัน}"
search: "ค้นหา"
notifications: "การเเจ้งเตือน"

View File

@ -1,6 +1,6 @@
_lang_: "Türkçe"
introMisskey: "Hoş geldin! Firefish, sonsuza kadar ücretsiz olan, açık kaynaklı, merkezi
olmayan bir sosyal medya platformudur! 🚀"
introFirefish: "Hoş geldin! Firefish, sonsuza kadar ücretsiz olan, açık kaynaklı,
merkezi olmayan bir sosyal medya platformudur! 🚀"
monthAndDay: "{month}Ay {day}Gün"
search: "Arama"
notifications: "Bildirimler"
@ -182,7 +182,9 @@ _profile:
gösterecektir.
youCanIncludeHashtags: Hakkımdan'da etiket kullanabilirsin.
description: Hakkımda
metadataDescription: 'Bunları kullanarak profilinizde ek bilgi alanları görüntüleyebilirsiniz. Profilinizdeki bağlantıyı doğrulamak için {rel} ile bir {a} etiketi veya {l} etiketi ekleyebilirsiniz!'
metadataDescription: 'Bunları kullanarak profilinizde ek bilgi alanları görüntüleyebilirsiniz.
Profilinizdeki bağlantıyı doğrulamak için {rel} ile bir {a} etiketi veya {l} etiketi
ekleyebilirsiniz!'
metadata: Ek Bilgi
metadataContent: İçerik
metadataLabel: Etiket
@ -231,8 +233,8 @@ cantFavorite: Favorilere eklenemedi.
edited: '{date} tarihinde ve {time} vaktinde düzenlendi'
loggingIn: Giriş Yapılıyor
save: Kaydet
headlineMisskey: Sonsuza kadar ücretsiz, açık kaynak kodlu, merkeziyetsiz sosyal medya
platformu! 🚀
headlineFirefish: Sonsuza kadar ücretsiz, açık kaynak kodlu, merkeziyetsiz sosyal
medya platformu! 🚀
loadMore: Daha fazla yükle
instance: Sunucu
fetchingAsApObject: Fediverse'den çekiliyor
@ -286,7 +288,7 @@ notifyAntenna: Yeni gönderileribildir
recentlyUpdatedUsers: En son aktif kullanıcılar
about: Hakkında
twoStepAuthentication: İki-adımlı doğrulama
securityKeyName: Key name
securityKeyName: Anahtar ismi
help: Yardım
inputMessageHere: Mesajını buraya gir
ownedGroups: Gruplarım
@ -505,7 +507,7 @@ normal: Normal
thisMonth: Ay
enableRecaptcha: reCAPTCHA'yı Aktif Et
antennas: Antenler
recaptchaSiteKey: Site key
recaptchaSiteKey: İnternet sitesi anahtarı
withFileAntenna: Sadece dosyalı gönderiler
antennaInstancesDescription: Sunucu başı bir satır kullanın
moderator: Moderatör
@ -664,7 +666,7 @@ withFiles: Dosya içeren
recentlyRegisteredUsers: Yeni katılmış kullanıcılar
recentlyDiscoveredUsers: Yeni keşfedilmiş kullanıcılar
nUsersMentioned: '{n} kullanıcı tarafından bahsedildi'
securityKey: Security key
securityKey: Güvenlik Anahtarı
title: Başlık
total: Toplam
sounds: Sesler
@ -723,7 +725,7 @@ emojis: Emoji
flagAsCat: Kedi misin? 😺
selectChannel: Kanal seç
emojiName: Emoji adı
showOnRemote: Uzak sunucuda görüntüle
showOnRemote: Orijinal sayfayı
flagSpeakAsCatDescription: Gönderileriniz kedi modundayken nyanifiye edilecek
flagShowTimelineReplies: Yanıtları zaman çizelgesinde göster
silenceThisInstance: Bu sunucuyu sustur
@ -749,7 +751,7 @@ upload: Yükle
fromUrl: URL'den
agreeTo: '{0} kabul ediyorum'
tos: Kullanım Koşulları
drive: Drive
drive: Bulut Depolama
selectFolder: Klasör seç
inputNewFileName: Yeni dosya ismi gir
whenServerDisconnected: Sunucuyla bağlantı kesildiğinde
@ -763,8 +765,8 @@ connectService: Bağlan
registration: Kayıt
hcaptcha: hCaptcha
pinnedNotes: Sabitlenmiş gönderiler
hcaptchaSiteKey: Site key
hcaptchaSecretKey: Secret key
hcaptchaSiteKey: Site anahtarı
hcaptchaSecretKey: Gizli Anahtar
antennaSource: Anten kaynağı
antennaKeywords: Dinlenecek anahtar kelimeler
antennaExcludeKeywords: Hariç tutulacak anahtar kelimeler
@ -892,7 +894,7 @@ bannerUrl: Afiş resmi URL
backgroundImageUrl: Arkaplan URL'si
recaptcha: reCAPTCHA
iconUrl: Ikon URL
recaptchaSecretKey: Secret key
recaptchaSecretKey: Gizli anahtar
avoidMultiCaptchaConfirm: Birden fazla Captcha sistemi kullanmak aralarında etkileşime
neden olabilir. Şu anda etkin olan diğer Captcha sistemlerini devre dışı bırakmak
ister misiniz? Etkin kalmalarını istiyorsanız, iptal düğmesine basın.
@ -1013,7 +1015,7 @@ failedToFetchAccountInformation: Hesap bilgileri getirilemedi
rateLimitExceeded: Hız limiti aşıldı
renotedBy: '{user} Yükseltti'
host: Host
objectStorage: Object Storage
objectStorage: Nesne Depolaması
objectStorageUseSSLDesc: API bağlantıları için HTTPS kullanmayacaksanız bunu kapatın
objectStorageUseProxyDesc: API bağlantıları için Proxy kullanmayacaksanız bunu kapatın
objectStorageSetPublicRead: Yüklendiğinde "public-read" kullan
@ -1219,8 +1221,8 @@ ascendingOrder: Artan
tags: Etiketler
descendingOrder: Azalan
scratchpadDescription: Karalama defteri, AiScript deneyleri için bir ortam sağlar.
İçinde Firefish ile etkileşime girerek sonuçlarını yazabilir, çalıştırabilir ve kontrol
edebilirsiniz.
İçinde Firefish ile etkileşime girerek sonuçlarını yazabilir, çalıştırabilir ve
kontrol edebilirsiniz.
local: Yerel
remote: Uzak
addRelay: Röle Ekle
@ -1247,9 +1249,9 @@ desktop: Masaüstü
confirmToUnclipAlreadyClippedNote: Bu gönderi zaten "{name}" atacının bir parçası.
Bunun yerine onu bu ataçtan kaldırmak istiyor musunuz?
sendErrorReportsDescription: "Açıldığında, bir sorun oluştuğunda ayrıntılı hata bilgileri
Firefish ile paylaşılarak Firefish kalitesinin artırılmasına yardımcı olur.\nBu, işletim
sisteminizin sürümü, kullandığınız tarayıcı, Firefish'deki etkinliğiniz vb. bilgileri
içerecektir."
Firefish ile paylaşılarak Firefish kalitesinin artırılmasına yardımcı olur.\nBu,
işletim sisteminizin sürümü, kullandığınız tarayıcı, Firefish'deki etkinliğiniz
vb. bilgileri içerecektir."
closeAccount: Hesabı kapat
markAllAsRead: Okunmuş olarak işaretle
allowedInstances: Beyaz Listedeki Sunucular
@ -1929,7 +1931,7 @@ _preferencesBackups:
loadFile: Dosyadan yükle
updatedAt: 'Güncelleme tarihi: {date} {time}'
cannotLoad: Yüklenemedi
_aboutMisskey:
_aboutFirefish:
patronsList: Bağış büyüklüğüne göre değil, kronolojik olarak listelenmiştir. Adınızı
buraya almak için yukarıdaki bağlantıyla bağış yapın!
about: Firefish, 2022'den beri geliştirilmekte olan ThatOneCalculator tarafından
@ -2124,3 +2126,9 @@ _ffVisibility:
followers: Takipçilere açık
private: Gizli
public: Herkese açık
verifiedLink: Doğrulanmış bağlantı
_feeds:
copyFeed: Akışı kopyala
rss: RSS
atom: Atom
jsonFeed: JSON akışı

View File

@ -1,9 +1,9 @@
_lang_: "Українська"
headlineMisskey: "Мережа об'єднана записами"
introMisskey: "Ласкаво просимо! Firefish - децентралізована служба мікроблогів з відкритим
кодом.\nСтворюйте \"нотатки\", щоб поділитися тим, що відбувається, і розповісти
всім про себе 📡\nЗа допомогою \"реакцій\" ви також можете швидко висловити свої
почуття щодо нотаток інших 👍\nДосліджуймо новий світ! 🚀"
headlineFirefish: "Мережа об'єднана записами"
introFirefish: "Ласкаво просимо! Firefish - децентралізована служба мікроблогів з
відкритим кодом.\nСтворюйте \"нотатки\", щоб поділитися тим, що відбувається, і
розповісти всім про себе 📡\nЗа допомогою \"реакцій\" ви також можете швидко висловити
свої почуття щодо нотаток інших 👍\nДосліджуймо новий світ! 🚀"
monthAndDay: "{month}/{day}"
search: "Пошук"
notifications: "Сповіщення"
@ -400,7 +400,7 @@ recentlyUpdatedUsers: "Нещодавно активні користувачі"
recentlyRegisteredUsers: "Нещодавно зареєстровані користувачі"
recentlyDiscoveredUsers: "Нещодавно знайдені користувачі"
exploreUsersCount: "{count} користувачів"
exploreFediverse: "Огляд федіверсу"
exploreFediverse: "Досліджуйте Fediverse"
popularTags: "Популярні теги"
userList: "Списки"
about: "Інформація"
@ -579,7 +579,7 @@ divider: "Розділювач"
addItem: "Додати елемент"
relays: "Ретранслятори"
addRelay: "Додати ретранслятор"
inboxUrl: "Inbox URL"
inboxUrl: "URL скриньки вхідних повідомлень"
addedRelays: "Додані ретранслятори"
serviceworkerInfo: "Повинен бути ввімкнений для push-сповіщень."
deletedNote: "Видалений запис"
@ -693,8 +693,8 @@ createNew: "Створити новий"
optional: "Необов'язково"
createNewClip: "Створити підбірку"
public: "Публічний"
i18nInfo: "Firefish перекладається на різні мови волонтерами. Ви можете допомогти за
посиланням: {link}."
i18nInfo: "Firefish перекладається на різні мови волонтерами. Ви можете допомогти
за посиланням: {link}."
manageAccessTokens: "Керування токенами доступу"
accountInfo: "Інформація про акаунт"
notesCount: "Кількість записів"
@ -808,7 +808,7 @@ _ad:
back: "Назад"
reduceFrequencyOfThisAd: Менше показувати цю рекламу
_gallery:
unlike: "Не вподобати"
unlike: "Видалити вподобайку"
liked: Вподобані записи
like: Подобається
my: Моя галерея
@ -823,9 +823,9 @@ _registry:
domain: "Домен"
createKey: "Створити ключ"
scope: Область
_aboutMisskey:
about: "Misskey - це програмне забезпечення з відкритим кодом, яке розробляє syuilo
з 2014 року."
_aboutFirefish:
about: "Firefish - це форк Misskey з відкритим кодом, яке розробляє ThatOneCalculator
з 2022 року."
contributors: "Головні помічники"
allContributors: "Всі помічники"
source: "Вихідний код"
@ -918,7 +918,7 @@ _mfm:
scale: Масштабувати
positionDescription: Перемістити вміст на вказане значення.
scaleDescription: Масштабувати вміст на вказану величину.
background: Фоновий колір
background: Колір фону
foreground: Колір переднього плану
foregroundDescription: Змінити колір тексту на передньому плані.
bounceDescription: Надає контенту пружної анімації.
@ -1071,7 +1071,7 @@ _time:
hour: "г"
day: "д"
_tutorial:
title: "Як використовувати Firefish"
title: "Як користуватися Firefish"
step1_1: "Ласкаво просимо!"
step1_2: "Давайте налаштуємо вас. Ви будете працювати в найкоротші терміни!"
step2_1: "Спочатку, будь ласка, заповніть свій профіль."
@ -1086,7 +1086,7 @@ _tutorial:
повідомлення або просте \"Hello world!\""
step5_1: "Стрічки, скрізь одні стрічки!"
step5_2: "У вашому сервері включені {timelines} різні стрічки."
step5_3: "Головна {icon} стрічка - це стрічка, де ви можете бачити записи тих, на
step5_3: "Домашня {icon} стрічка - це стрічка, де ви можете бачити записи тих, на
кого ви підписалися."
step5_4: "Місцева {icon} стрічка - це стрічка, де ви можете бачити записи всіх інших
користувачів даного серверу."
@ -1096,10 +1096,10 @@ _tutorial:
step5_7: "Глобальна {icon} стрічка - це місце, де ви можете бачити записи від усіх
інших приєднаних серверів."
step6_1: "Отже, що це за місце?"
step6_2: "Ну, ви не просто приєдналися до Firefish. Ви увійшли в Fediverse, взаємопов'язану
step6_2: "Ну, ви не просто приєдналися до Firefish. Ви увійшли до Fediverse, взаємопов'язану
мережу з тисяч серверів."
step6_3: "Кожен сервер працює по-своєму, і не на всіх серверах працює Firefish. Але
цей працює! Це трохи складно, але ви швидко розберетеся."
step6_3: "Кожен сервер працює по-своєму, і не на всіх серверах працює Firefish.
Але цей працює! Це трохи складно, але ви швидко розберетеся."
step6_4: "Тепер ідіть, вивчайте і розважайтеся!"
_2fa:
registerSecurityKey: "Зареєструвати новий ключ безпеки"
@ -1340,7 +1340,7 @@ _pages:
viewSource: "Переглянути вихідний код"
viewPage: "Переглянути свої сторінки"
like: "Вподобати"
unlike: "Не вподобати"
unlike: "Видалити вподобайку"
my: "Мої сторінки"
liked: "Вподобані сторінки"
featured: "Популярні"
@ -1705,7 +1705,7 @@ emailRequiredForSignup: Вимагати адресу електронної п
moderation: Модерація
selectInstance: Оберіть сервер
instanceSecurity: Безпека сервера
searchPlaceholder: Шукати в Firefish
searchPlaceholder: Шукати у Firefish
editNote: Відредагувати запис
enableEmojiReactions: Ввімкнути реакції емодзі
low: Низький
@ -1870,9 +1870,9 @@ _instanceMute:
_experiments:
enablePostImports: Ввімкнути імпорт записів
title: Експерименти
postImportsCaption: Дозволяє користувачам імпортувати свої публікації з минулих
облікових записів Firefish, Misskey, Mastodon, Akkoma і Pleroma. Це може спричинити
зниження швидкості під час завантаження, якщо ваша черга перевантажена.
postImportsCaption: Дозволяє користувачам імпортувати свої записи з минулих облікових
записів Firefish, Misskey, Mastodon, Akkoma і Pleroma. Це може спричинити зниження
швидкості під час завантаження, якщо ваша черга перевантажена.
_dialog:
charactersExceeded: 'Перевищено максимальну кількість символів! Обмеження: {current}/{max}'
charactersBelow: 'Недостатньо символів! Обмеження: {current}/{min}'
@ -2022,9 +2022,9 @@ _plugin:
installWarn: Будь ласка, не встановлюйте ненадійні плагіни.
_skinTones:
yellow: Жовтий
mediumLight: Помірно-світлий
medium: Помірний
mediumDark: Помірно-темний
mediumLight: Середньо-світлий
medium: Середній
mediumDark: Середньо-темний
dark: Темний
light: Світлий
tenMinutes: 10 хвилин
@ -2133,3 +2133,9 @@ customSplashIconsDescription: URL-адреси іконок для застав
сторінку. Будь ласка, переконайтеся, що зображення знаходяться на статичній URL-адресі,
бажано, щоб вони були змінені до розміру 192x192.
verifiedLink: Перевірене посилання
_feeds:
copyFeed: Скопіювати стрічку
rss: RSS
jsonFeed: JSON-стрічка
atom: Atom
origin: Походження

View File

@ -1,7 +1,9 @@
---
_lang_: "Tiếng Việt"
headlineMisskey: "Mạng xã hội liên hợp"
introMisskey: "Xin chào! Firefish là một nền tảng tiểu blog phi tập trung mã nguồn mở.\nViết \"tút\" để chia sẻ những suy nghĩ của bạn 📡\nBằng \"biểu cảm\", bạn có thể bày tỏ nhanh chóng cảm xúc của bạn với các tút 👍\nHãy khám phá một thế giới mới! 🚀"
headlineFirefish: "Mạng xã hội liên hợp"
introFirefish: "Xin chào! Firefish là một nền tảng tiểu blog phi tập trung mã nguồn
mở.\nViết \"tút\" để chia sẻ những suy nghĩ của bạn 📡\nBằng \"biểu cảm\", bạn có
thể bày tỏ nhanh chóng cảm xúc của bạn với các tút 👍\nHãy khám phá một thế giới
mới! 🚀"
monthAndDay: "{day} tháng {month}"
search: "Tìm kiếm"
notifications: "Thông báo"
@ -13,7 +15,7 @@ ok: "Đồng ý"
gotIt: "Đã hiểu!"
cancel: "Hủy"
enterUsername: "Nhập tên người dùng"
renotedBy: "Chia sẻ bởi {user}"
renotedBy: "{user} đăng lại"
noNotes: "Chưa có tút nào."
noNotifications: "Không có thông báo"
instance: "Máy chủ"
@ -44,11 +46,12 @@ copyContent: "Chép nội dung"
copyLink: "Chép liên kết"
delete: "Xóa"
deleteAndEdit: "Sửa"
deleteAndEditConfirm: "Bạn có chắc muốn sửa tút này? Những biểu cảm, lượt trả lời và đăng lại sẽ bị mất."
deleteAndEditConfirm: "Bạn có chắc muốn sửa tút này? Những biểu cảm, lượt trả lời
và đăng lại sẽ bị mất."
addToList: "Thêm vào danh sách"
sendMessage: "Gửi tin nhắn"
copyUsername: "Chép tên người dùng"
searchUser: "Tìm kiếm người dùng"
searchUser: "Tìm người"
reply: "Trả lời"
loadMore: "Tải thêm"
showMore: "Xem thêm"
@ -64,9 +67,11 @@ import: "Nhập dữ liệu"
export: "Xuất dữ liệu"
files: "Tập tin"
download: "Tải xuống"
driveFileDeleteConfirm: "Bạn có chắc muốn xóa tập tin \"{name}\"? Tút liên quan cũng sẽ bị xóa theo."
driveFileDeleteConfirm: "Bạn có chắc muốn xóa tập tin \"{name}\"? Tút liên quan cũng
sẽ bị xóa theo."
unfollowConfirm: "Bạn có chắc muốn ngưng theo dõi {name}?"
exportRequested: "Đang chuẩn bị xuất tập tin. Quá trình này có thể mất ít phút. Nó sẽ được tự động thêm vào Drive sau khi hoàn thành."
exportRequested: "Đang chuẩn bị xuất tập tin. Quá trình này có thể mất ít phút. Nó
sẽ được tự động thêm vào Drive sau khi hoàn thành."
importRequested: "Bạn vừa yêu cầu nhập dữ liệu. Quá trình này có thể mất ít phút."
lists: "Danh sách"
noLists: "Bạn chưa có danh sách nào"
@ -81,7 +86,8 @@ error: "Lỗi"
somethingHappened: "Xảy ra lỗi"
retry: "Thử lại"
pageLoadError: "Xảy ra lỗi khi tải trang."
pageLoadErrorDescription: "Có thể là do bộ nhớ đệm của trình duyệt. Hãy thử xóa bộ nhớ đệm và thử lại sau ít phút."
pageLoadErrorDescription: "Có thể là do bộ nhớ đệm của trình duyệt. Hãy thử xóa bộ
nhớ đệm và thử lại sau ít phút."
serverIsDead: "Máy chủ không phản hồi. Vui lòng thử lại sau giây lát."
youShouldUpgradeClient: "Để xem trang này, hãy làm tươi để cập nhật ứng dụng."
enterListName: "Đặt tên cho danh sách"
@ -129,7 +135,7 @@ selectAntenna: "Chọn một antenna"
selectWidget: "Chọn tiện ích"
editWidgets: "Sửa tiện ích"
editWidgetsExit: "Xong"
customEmojis: "Tùy chỉnh emoji"
customEmojis: "Emoji"
emoji: "Emoji"
emojis: "Emoji"
emojiName: "Tên emoji"
@ -137,18 +143,24 @@ emojiUrl: "URL Emoji"
addEmoji: "Thêm emoji"
settingGuide: "Cài đặt đề xuất"
cacheRemoteFiles: "Tập tin cache từ xa"
cacheRemoteFilesDescription: "Khi tùy chọn này bị tắt, các tập tin từ xa sẽ được tải trực tiếp từ máy chủ khác. Điều này sẽ giúp giảm dung lượng lưu trữ nhưng lại tăng lưu lượng truy cập, vì hình thu nhỏ sẽ không được tạo."
cacheRemoteFilesDescription: "Khi tùy chọn này bị tắt, các tập tin từ xa sẽ được tải
trực tiếp từ máy chủ khác. Điều này sẽ giúp giảm dung lượng lưu trữ nhưng lại tăng
lưu lượng truy cập, vì hình thu nhỏ sẽ không được tạo."
flagAsBot: "Đánh dấu đây là tài khoản bot"
flagAsBotDescription: "Bật tùy chọn này nếu tài khoản này được kiểm soát bởi một chương trình. Nếu được bật, nó sẽ được đánh dấu để các nhà phát triển khác ngăn chặn chuỗi tương tác vô tận với các bot khác và điều chỉnh hệ thống nội bộ của Firefish để coi tài khoản này như một bot."
flagAsBotDescription: "Bật tùy chọn này nếu tài khoản này được kiểm soát bởi một chương
trình. Nếu được bật, nó sẽ được đánh dấu để các nhà phát triển khác ngăn chặn chuỗi
tương tác vô tận với các bot khác và điều chỉnh hệ thống nội bộ của Firefish để
coi tài khoản này như một bot."
flagAsCat: "Tài khoản này là mèo"
flagAsCatDescription: "Bật tùy chọn này để đánh dấu tài khoản là một con mèo."
flagShowTimelineReplies: "Hiện lượt trả lời trong bảng tin"
flagShowTimelineRepliesDescription: "Hiện lượt trả lời của người bạn theo dõi trên tút của những người khác."
flagShowTimelineRepliesDescription: "Hiện lượt trả lời của người bạn theo dõi trên
tút của những người khác."
autoAcceptFollowed: "Tự động phê duyệt theo dõi từ những người mà bạn đang theo dõi"
addAccount: "Thêm tài khoản"
loginFailed: "Đăng nhập không thành công"
showOnRemote: "Truy cập trang của người này"
general: "Tổng quan"
general: "Tổng quát"
wallpaper: "Ảnh bìa"
setWallpaper: "Đặt ảnh bìa"
removeWallpaper: "Xóa ảnh bìa"
@ -156,7 +168,11 @@ searchWith: "Tìm kiếm: {q}"
youHaveNoLists: "Bạn chưa có danh sách nào"
followConfirm: "Bạn có chắc muốn theo dõi {name}"
proxyAccount: "Tài khoản proxy"
proxyAccountDescription: "Tài khoản proxy là tài khoản hoạt động như một người theo dõi từ xa cho người dùng trong những điều kiện nhất định. Ví dụ: khi người dùng thêm người dùng từ xa vào danh sách, hoạt động của người dùng từ xa sẽ không được chuyển đến phiên bản nếu không có người dùng cục bộ nào theo dõi người dùng đó, vì vậy tài khoản proxy sẽ theo dõi."
proxyAccountDescription: "Tài khoản proxy là tài khoản hoạt động như một người theo
dõi từ xa cho người dùng trong những điều kiện nhất định. Ví dụ: khi người dùng
thêm người dùng từ xa vào danh sách, hoạt động của người dùng từ xa sẽ không được
chuyển đến phiên bản nếu không có người dùng cục bộ nào theo dõi người dùng đó,
vì vậy tài khoản proxy sẽ theo dõi."
host: "Host"
selectUser: "Chọn người dùng"
recipient: "Người nhận"
@ -168,9 +184,9 @@ latestRequestSentAt: "Yêu cầu cuối gửi lúc"
latestRequestReceivedAt: "Yêu cầu cuối nhận lúc"
latestStatus: "Trạng thái cuối cùng"
storageUsage: "Dung lượng lưu trữ"
charts: "Đồ thị"
perHour: "Mỗi Giờ"
perDay: "Mỗi Ngày"
charts: "Biểu đồ"
perHour: "Mỗi giờ"
perDay: "Mỗi ngày"
stopActivityDelivery: "Ngưng gửi hoạt động"
blockThisInstance: "Chặn máy chủ này"
operations: "Vận hành"
@ -186,11 +202,13 @@ instanceInfo: "Thông tin máy chủ"
statistics: "Thống kê"
clearQueue: "Xóa hàng đợi"
clearQueueConfirmTitle: "Bạn có chắc muốn xóa hàng đợi?"
clearQueueConfirmText: "Mọi tút chưa được gửi còn lại trong hàng đợi sẽ không được liên hợp. Thông thường thao tác này không cần thiết."
clearQueueConfirmText: "Mọi tút chưa được gửi còn lại trong hàng đợi sẽ không được
liên hợp. Thông thường thao tác này không cần thiết."
clearCachedFiles: "Xóa bộ nhớ đệm"
clearCachedFilesConfirm: "Bạn có chắc muốn xóa sạch bộ nhớ đệm?"
blockedInstances: "Máy chủ đã chặn"
blockedInstancesDescription: "Danh sách những máy chủ bạn muốn chặn. Chúng sẽ không thể giao tiếp với máy chủy này nữa."
blockedInstancesDescription: "Danh sách những máy chủ bạn muốn chặn. Chúng sẽ không
thể giao tiếp với máy chủy này nữa."
muteAndBlock: "Ẩn và Chặn"
mutedUsers: "Người đã ẩn"
blockedUsers: "Người đã chặn"
@ -239,14 +257,15 @@ saved: "Đã lưu"
messaging: "Trò chuyện"
upload: "Tải lên"
keepOriginalUploading: "Giữ hình ảnh gốc"
keepOriginalUploadingDescription: "Giữ nguyên như hình ảnh được tải lên ban đầu. Nếu tắt, một phiên bản để hiển thị trên web sẽ được tạo khi tải lên."
keepOriginalUploadingDescription: "Giữ nguyên như hình ảnh được tải lên ban đầu. Nếu
tắt, một phiên bản để hiển thị trên web sẽ được tạo khi tải lên."
fromDrive: "Từ ổ đĩa"
fromUrl: "Từ URL"
uploadFromUrl: "Tải lên bằng một URL"
uploadFromUrlDescription: "URL của tập tin bạn muốn tải lên"
uploadFromUrlRequested: "Đã yêu cầu tải lên"
uploadFromUrlMayTakeTime: "Sẽ mất một khoảng thời gian để tải lên xong."
explore: "Khám phá"
explore: "Khám phó"
messageRead: "Đã đọc"
noMoreHistory: "Không còn gì để đọc"
startMessaging: "Bắt đầu trò chuyện"
@ -255,7 +274,8 @@ agreeTo: "Tôi đồng ý {0}"
tos: "Điều khoản dịch vụ"
start: "Bắt đầu"
home: "Trang chính"
remoteUserCaution: "Vì người dùng này ở máy chủ khác, thông tin hiển thị có thể không đầy đủ."
remoteUserCaution: "Vì người dùng này ở máy chủ khác, thông tin hiển thị có thể không
đầy đủ."
activity: "Hoạt động"
images: "Hình ảnh"
birthday: "Sinh nhật"
@ -288,7 +308,8 @@ unableToDelete: "Không thể xóa"
inputNewFileName: "Nhập tên mới cho tập tin"
inputNewDescription: "Nhập mô tả mới"
inputNewFolderName: "Nhập tên mới cho thư mục"
circularReferenceFolder: "Thư mục đích là một thư mục con của thư mục bạn muốn di chuyển."
circularReferenceFolder: "Thư mục đích là một thư mục con của thư mục bạn muốn di
chuyển."
hasChildFilesOrFolders: "Không thể xóa cho đến khi không còn gì trong thư mục."
copyUrl: "Sao chép URL"
rename: "Đổi tên"
@ -322,7 +343,8 @@ connectService: "Kết nối"
disconnectService: "Ngắt kết nối"
enableLocalTimeline: "Bật bảng tin máy chủ"
enableGlobalTimeline: "Bật bảng tin liên hợp"
disablingTimelinesInfo: "Quản trị viên và Kiểm duyệt viên luôn có quyền truy cập mọi bảng tin, kể cả khi chúng không được bật."
disablingTimelinesInfo: "Quản trị viên và Kiểm duyệt viên luôn có quyền truy cập mọi
bảng tin, kể cả khi chúng không được bật."
registration: "Đăng ký"
enableRegistration: "Cho phép đăng ký mới"
invite: "Mời"
@ -334,7 +356,8 @@ bannerUrl: "URL Ảnh bìa"
backgroundImageUrl: "URL Ảnh nền"
basicInfo: "Thông tin cơ bản"
pinnedUsers: "Những người thú vị"
pinnedUsersDescription: "Liệt kê mỗi hàng một tên người dùng xuống dòng để ghim trên tab \"Khám phá\"."
pinnedUsersDescription: "Liệt kê mỗi hàng một tên người dùng xuống dòng để ghim trên
tab \"Khám phá\"."
pinnedPages: "Trang đã ghim"
pinnedPagesDescription: "Liệt kê các trang thú vị để ghim trên máy chủ."
pinnedClipId: "ID của clip muốn ghim"
@ -347,14 +370,17 @@ recaptcha: "reCAPTCHA"
enableRecaptcha: "Bật reCAPTCHA"
recaptchaSiteKey: "Khóa của trang"
recaptchaSecretKey: "Khóa bí mật"
avoidMultiCaptchaConfirm: "Dùng nhiều hệ thống Captcha có thể gây nhiễu giữa chúng. Bạn có muốn tắt các hệ thống Captcha khác hiện đang hoạt động không? Nếu bạn muốn chúng tiếp tục được bật, hãy nhấn hủy."
avoidMultiCaptchaConfirm: "Dùng nhiều hệ thống Captcha có thể gây nhiễu giữa chúng.
Bạn có muốn tắt các hệ thống Captcha khác hiện đang hoạt động không? Nếu bạn muốn
chúng tiếp tục được bật, hãy nhấn hủy."
antennas: "Trạm phát sóng"
manageAntennas: "Quản lý trạm phát sóng"
name: "Tên"
antennaSource: "Nguồn trạm phát sóng"
antennaKeywords: "Từ khóa để nghe"
antennaExcludeKeywords: "Từ khóa để lọc ra"
antennaKeywordsDescription: "Phân cách bằng dấu cách cho điều kiện AND hoặc bằng xuống dòng cho điều kiện OR."
antennaKeywordsDescription: "Phân cách bằng dấu cách cho điều kiện AND hoặc bằng xuống
dòng cho điều kiện OR."
notifyAntenna: "Thông báo có tút mới"
withFileAntenna: "Chỉ những tút có media"
enableServiceworker: "Bật ServiceWorker"
@ -362,7 +388,7 @@ antennaUsersDescription: "Liệt kê mỗi hàng một tên người dùng"
caseSensitive: "Trường hợp nhạy cảm"
withReplies: "Bao gồm lượt trả lời"
connectedTo: "Những tài khoản sau đã kết nối"
notesAndReplies: "Tút kèm trả lời"
notesAndReplies: "Lượt trả lời"
withFiles: "Media"
silence: "Ẩn"
silenceConfirm: "Bạn có chắc muốn ẩn người này?"
@ -433,7 +459,8 @@ invitationCode: "Mã mời"
checking: "Đang kiểm tra..."
available: "Khả dụng"
unavailable: "Không khả dụng"
usernameInvalidFormat: "Bạn có thể dùng viết hoa/viết thường, chữ số, và dấu gạch dưới."
usernameInvalidFormat: "Bạn có thể dùng viết hoa/viết thường, chữ số, và dấu gạch
dưới."
tooShort: "Quá ngắn"
tooLong: "Quá dài"
weakPassword: "Mật khẩu yếu"
@ -442,7 +469,8 @@ strongPassword: "Mật khẩu mạnh"
passwordMatched: "Trùng khớp"
passwordNotMatched: "Không trùng khớp"
signinWith: "Đăng nhập bằng {x}"
signinFailed: "Không thể đăng nhập. Vui lòng kiểm tra tên người dùng và mật khẩu của bạn."
signinFailed: "Không thể đăng nhập. Vui lòng kiểm tra tên người dùng và mật khẩu của
bạn."
tapSecurityKey: "Nhấn mã bảo mật của bạn"
or: "Hoặc"
language: "Ngôn ngữ"
@ -483,15 +511,20 @@ showFeaturedNotesInTimeline: "Hiện tút nổi bật trong bảng tin"
objectStorage: "Đối tượng lưu trữ"
useObjectStorage: "Dùng đối tượng lưu trữ"
objectStorageBaseUrl: "Base URL"
objectStorageBaseUrlDesc: "URL được sử dụng làm tham khảo. Chỉ định URL của CDN hoặc Proxy của bạn nếu bạn đang sử dụng. Với S3 dùng 'https://<bucket>.s3.amazonaws.com', còn GCS hoặc dịch vụ tương tự dùng 'https://storage.googleapis.com/<bucket>', etc."
objectStorageBaseUrlDesc: "URL được sử dụng làm tham khảo. Chỉ định URL của CDN hoặc
Proxy của bạn nếu bạn đang sử dụng. Với S3 dùng 'https://<bucket>.s3.amazonaws.com',
còn GCS hoặc dịch vụ tương tự dùng 'https://storage.googleapis.com/<bucket>', etc."
objectStorageBucket: "Bucket"
objectStorageBucketDesc: "Nhập tên bucket dùng ở nhà cung cấp của bạn."
objectStoragePrefix: "Tiền tố"
objectStoragePrefixDesc: "Các tập tin sẽ được lưu trữ trong các thư mục có tiền tố này."
objectStoragePrefixDesc: "Các tập tin sẽ được lưu trữ trong các thư mục có tiền tố
này."
objectStorageEndpoint: "Đầu cuối"
objectStorageEndpointDesc: "Để trống nếu bạn đang dùng AWS S3, nếu không thì chỉ định đầu cuối là '<host>' hoặc '<host>:<port>', tùy thuộc vào nhà cung cấp dịch vụ."
objectStorageEndpointDesc: "Để trống nếu bạn đang dùng AWS S3, nếu không thì chỉ định
đầu cuối là '<host>' hoặc '<host>:<port>', tùy thuộc vào nhà cung cấp dịch vụ."
objectStorageRegion: "Khu vực"
objectStorageRegionDesc: "Nhập một khu vực cụ thể như 'xx-east-1'. Nếu nhà cung cấp dịch vụ của bạn không phân biệt giữa các khu vực, hãy để trống hoặc nhập 'us-east-1'."
objectStorageRegionDesc: "Nhập một khu vực cụ thể như 'xx-east-1'. Nếu nhà cung cấp
dịch vụ của bạn không phân biệt giữa các khu vực, hãy để trống hoặc nhập 'us-east-1'."
objectStorageUseSSL: "Dùng SSL"
objectStorageUseSSLDesc: "Tắt nếu bạn không dùng HTTPS để kết nối API"
objectStorageUseProxy: "Kết nối thông qua Proxy"
@ -523,7 +556,8 @@ sort: "Sắp xếp"
ascendingOrder: "Tăng dần"
descendingOrder: "Giảm dần"
scratchpad: "Scratchpad"
scratchpadDescription: "Scratchpad cung cấp môi trường cho các thử nghiệm AiScript. Bạn có thể viết, thực thi và kiểm tra kết quả tương tác với Firefish trong đó."
scratchpadDescription: "Scratchpad cung cấp môi trường cho các thử nghiệm AiScript.
Bạn có thể viết, thực thi và kiểm tra kết quả tương tác với Firefish trong đó."
output: "Nguồn ra"
script: "Kịch bản"
disablePagesScript: "Tắt AiScript trên Trang"
@ -531,11 +565,14 @@ updateRemoteUser: "Cập nhật thông tin người dùng ở máy chủ khác"
deleteAllFiles: "Xóa toàn bộ tập tin"
deleteAllFilesConfirm: "Bạn có chắc xóa toàn bộ tập tin?"
removeAllFollowing: "Ngưng theo dõi tất cả mọi người"
removeAllFollowingDescription: "Thực hiện điều này sẽ ngưng theo dõi tất cả các tài khoản khỏi {host}. Chỉ thực hiện điều này nếu máy chủ không còn tồn tại."
removeAllFollowingDescription: "Thực hiện điều này sẽ ngưng theo dõi tất cả các tài
khoản khỏi {host}. Chỉ thực hiện điều này nếu máy chủ không còn tồn tại."
userSuspended: "Người này đã bị vô hiệu hóa."
userSilenced: "Người này đã bị ẩn"
yourAccountSuspendedTitle: "Tài khoản bị vô hiệu hóa"
yourAccountSuspendedDescription: "Tài khoản này đã bị vô hiệu hóa do vi phạm quy tắc máy chủ hoặc điều tương tự. Liên hệ với quản trị viên nếu bạn muốn biết lý do chi tiết hơn. Vui lòng không tạo tài khoản mới."
yourAccountSuspendedDescription: "Tài khoản này đã bị vô hiệu hóa do vi phạm quy tắc
máy chủ hoặc điều tương tự. Liên hệ với quản trị viên nếu bạn muốn biết lý do chi
tiết hơn. Vui lòng không tạo tài khoản mới."
menu: "Menu"
divider: "Phân chia"
addItem: "Thêm mục"
@ -576,12 +613,14 @@ permission: "Cho phép "
enableAll: "Bật toàn bộ"
disableAll: "Tắt toàn bộ"
tokenRequested: "Cấp quyền truy cập vào tài khoản"
pluginTokenRequestedDescription: "Plugin này sẽ có thể sử dụng các quyền được đặt ở đây."
pluginTokenRequestedDescription: "Plugin này sẽ có thể sử dụng các quyền được đặt
ở đây."
notificationType: "Loại thông báo"
edit: "Sửa"
emailServer: "Email máy chủ"
enableEmail: "Bật phân phối email"
emailConfigInfo: "Được dùng để xác minh email của bạn lúc đăng ký hoặc nếu bạn quên mật khẩu của mình"
emailConfigInfo: "Được dùng để xác minh email của bạn lúc đăng ký hoặc nếu bạn quên
mật khẩu của mình"
email: "Email"
emailAddress: "Địa chỉ email"
smtpConfig: "Cấu hình máy chủ SMTP"
@ -602,7 +641,7 @@ makeActive: "Kích hoạt"
display: "Hiển thị"
copy: "Sao chép"
metrics: "Số liệu"
overview: "Tổng quan"
overview: "Chung"
logs: "Nhật ký"
delayed: "Độ trễ"
database: "Cơ sở dữ liệu"
@ -611,10 +650,13 @@ create: "Tạo"
notificationSetting: "Cài đặt thông báo"
notificationSettingDesc: "Chọn loại thông báo bạn muốn hiển thị."
useGlobalSetting: "Dùng thiết lập chung"
useGlobalSettingDesc: "Nếu được bật, cài đặt thông báo của bạn sẽ được áp dụng. Nếu bị tắt, có thể thực hiện các thiết lập riêng lẻ."
useGlobalSettingDesc: "Nếu được bật, cài đặt thông báo của bạn sẽ được áp dụng. Nếu
bị tắt, có thể thực hiện các thiết lập riêng lẻ."
other: "Khác"
regenerateLoginToken: "Tạo lại mã đăng nhập"
regenerateLoginTokenDescription: "Tạo lại mã nội bộ có thể dùng để đăng nhập. Thông thường hành động này là không cần thiết. Nếu được tạo lại, tất cả các thiết bị sẽ bị đăng xuất."
regenerateLoginTokenDescription: "Tạo lại mã nội bộ có thể dùng để đăng nhập. Thông
thường hành động này là không cần thiết. Nếu được tạo lại, tất cả các thiết bị sẽ
bị đăng xuất."
setMultipleBySeparatingWithSpace: "Tách nhiều mục nhập bằng dấu cách."
fileIdOrUrl: "ID tập tin hoặc URL"
behavior: "Thao tác"
@ -622,19 +664,22 @@ sample: "Ví dụ"
abuseReports: "Lượt báo cáo"
reportAbuse: "Báo cáo"
reportAbuseOf: "Báo cáo {name}"
fillAbuseReportDescription: "Vui lòng điền thông tin chi tiết về báo cáo này. Nếu đó là về một tút cụ thể, hãy kèm theo URL của tút."
fillAbuseReportDescription: "Vui lòng điền thông tin chi tiết về báo cáo này. Nếu
đó là về một tút cụ thể, hãy kèm theo URL của tút."
abuseReported: "Báo cáo đã được gửi. Cảm ơn bạn nhiều."
reporter: "Người báo cáo"
reporteeOrigin: "Bị báo cáo"
reporterOrigin: "Máy chủ người báo cáo"
forwardReport: "Chuyển tiếp báo cáo cho máy chủ từ xa"
forwardReportIsAnonymous: "Thay vì tài khoản của bạn, một tài khoản hệ thống ẩn danh sẽ được hiển thị dưới dạng người báo cáo ở máy chủ từ xa."
forwardReportIsAnonymous: "Thay vì tài khoản của bạn, một tài khoản hệ thống ẩn danh
sẽ được hiển thị dưới dạng người báo cáo ở máy chủ từ xa."
send: "Gửi"
abuseMarkAsResolved: "Đánh dấu đã xử lý"
openInNewTab: "Mở trong tab mới"
openInSideView: "Mở trong thanh bên"
defaultNavigationBehaviour: "Thao tác điều hướng mặc định"
editTheseSettingsMayBreakAccount: "Việc chỉnh sửa các cài đặt này có thể làm hỏng tài khoản của bạn."
editTheseSettingsMayBreakAccount: "Việc chỉnh sửa các cài đặt này có thể làm hỏng
tài khoản của bạn."
instanceTicker: "Thông tin máy chủ của tút"
waitingFor: "Đang đợi {x}"
random: "Ngẫu nhiên"
@ -646,9 +691,11 @@ createNew: "Tạo mới"
optional: "Không bắt buộc"
createNewClip: "Tạo một ghim mới"
unclip: "Bỏ ghim"
confirmToUnclipAlreadyClippedNote: "Bài đăng này là một phần của \"{name}\" ghim. Bạn có muốn bỏ khỏi ghim?"
confirmToUnclipAlreadyClippedNote: "Bài đăng này là một phần của \"{name}\" ghim.
Bạn có muốn bỏ khỏi ghim?"
public: "Công khai"
i18nInfo: "Firefish đang được các tình nguyện viên dịch sang nhiều thứ tiếng khác nhau. Bạn có thể hỗ trợ tại {link}."
i18nInfo: "Firefish đang được các tình nguyện viên dịch sang nhiều thứ tiếng khác
nhau. Bạn có thể hỗ trợ tại {link}."
manageAccessTokens: "Tạo mã truy cập"
accountInfo: "Thông tin tài khoản"
notesCount: "Số lượng tút"
@ -667,12 +714,15 @@ no: "Từ chối"
driveFilesCount: "Số tập tin trong Ổ đĩa"
driveUsage: "Dung lượng ổ đĩa"
noCrawle: "Từ chối lập chỉ mục"
noCrawleDescription: "Không cho công cụ tìm kiếm lập chỉ mục trang hồ sơ, tút, Trang, etc."
lockedAccountInfo: "Ghi chú của bạn sẽ hiển thị với bất kỳ ai, trừ khi bạn đặt chế độ hiển thị tút của mình thành \"Chỉ người theo dõi\"."
noCrawleDescription: "Không cho công cụ tìm kiếm lập chỉ mục trang hồ sơ, tút, Trang,
etc."
lockedAccountInfo: "Ghi chú của bạn sẽ hiển thị với bất kỳ ai, trừ khi bạn đặt chế
độ hiển thị tút của mình thành \"Chỉ người theo dõi\"."
alwaysMarkSensitive: "Luôn đánh dấu NSFW"
loadRawImages: "Tải ảnh gốc thay vì ảnh thu nhỏ"
disableShowingAnimatedImages: "Không phát ảnh động"
verificationEmailSent: "Một email xác minh đã được gửi. Vui lòng nhấn vào liên kết đính kèm để hoàn tất xác minh."
verificationEmailSent: "Một email xác minh đã được gửi. Vui lòng nhấn vào liên kết
đính kèm để hoàn tất xác minh."
notSet: "Chưa đặt"
emailVerified: "Email đã được xác minh"
noteFavoritesCount: "Số lượng tút yêu thích"
@ -684,14 +734,16 @@ clips: "Ghim"
experimentalFeatures: "Tính năng thử nghiệm"
developer: "Nhà phát triển"
makeExplorable: "Không hiện tôi trong \"Khám phá\""
makeExplorableDescription: "Nếu bạn tắt, tài khoản của bạn sẽ không hiện trong mục \"Khám phá\"."
makeExplorableDescription: "Nếu bạn tắt, tài khoản của bạn sẽ không hiện trong mục
\"Khám phá\"."
showGapBetweenNotesInTimeline: "Hiện dải phân cách giữa các tút trên bảng tin"
duplicate: "Tạo bản sao"
left: "Bên trái"
center: "Giữa"
wide: "Rộng"
narrow: "Thu hẹp"
reloadToApplySetting: "Cài đặt này sẽ chỉ áp dụng sau khi tải lại trang. Tải lại ngay bây giờ?"
reloadToApplySetting: "Cài đặt này sẽ chỉ áp dụng sau khi tải lại trang. Tải lại ngay
bây giờ?"
needReloadToApply: "Cần tải lại để điều này được áp dụng."
showTitlebar: "Hiện thanh tựa đề"
clearCache: "Xóa bộ nhớ đệm"
@ -699,7 +751,10 @@ onlineUsersCount: "{n} người đang online"
nUsers: "{n} Người"
nNotes: "{n} Tút"
sendErrorReports: "Báo lỗi"
sendErrorReportsDescription: "Khi được bật, thông tin chi tiết về lỗi sẽ được chia sẻ với Firefish khi xảy ra sự cố, giúp nâng cao chất lượng của Firefish.\nBao gồm thông tin như phiên bản hệ điều hành của bạn, trình duyệt bạn đang sử dụng, hoạt động của bạn trong Firefish, v.v."
sendErrorReportsDescription: "Khi được bật, thông tin chi tiết về lỗi sẽ được chia
sẻ với Firefish khi xảy ra sự cố, giúp nâng cao chất lượng của Firefish.\nBao gồm
thông tin như phiên bản hệ điều hành của bạn, trình duyệt bạn đang sử dụng, hoạt
động của bạn trong Firefish, v.v."
myTheme: "Theme của tôi"
backgroundColor: "Màu nền"
accentColor: "Màu phụ"
@ -708,7 +763,7 @@ saveAs: "Lưu thành"
advanced: "Nâng cao"
value: "Giá trị"
createdAt: "Ngày tạo"
updatedAt: "Cập nhật lúc"
updatedAt: "Cập nhật"
saveConfirm: "Lưu thay đổi?"
deleteConfirm: "Bạn có muốn xóa không?"
invalidValue: "Giá trị không hợp lệ."
@ -738,14 +793,16 @@ unlikeConfirm: "Bạn có chắc muốn bỏ thích ?"
fullView: "Kích thước đầy đủ"
quitFullView: "Thoát toàn màn hình"
addDescription: "Thêm mô tả"
userPagePinTip: "Bạn có thể hiển thị các tút ở đây bằng cách chọn \"Ghim vào hồ sơ\" từ menu của mỗi tút."
userPagePinTip: "Bạn có thể hiển thị các tút ở đây bằng cách chọn \"Ghim vào hồ sơ\"\
\ từ menu của mỗi tút."
notSpecifiedMentionWarning: "Tút này có đề cập đến những người không mong muốn"
info: "Giới thiệu"
userInfo: "Thông tin người dùng"
unknown: "Chưa biết"
onlineStatus: "Trạng thái"
hideOnlineStatus: "Ẩn trạng thái online"
hideOnlineStatusDescription: "Ẩn trạng thái online của bạn làm giảm sự tiện lợi của một số tính năng như tìm kiếm."
hideOnlineStatusDescription: "Ẩn trạng thái online của bạn làm giảm sự tiện lợi của
một số tính năng như tìm kiếm."
online: "Online"
active: "Hoạt động"
offline: "Offline"
@ -780,12 +837,13 @@ emailNotConfiguredWarning: "Chưa đặt địa chỉ email."
ratio: "Tỷ lệ"
previewNoteText: "Hiện xem trước"
customCss: "Tùy chỉnh CSS"
customCssWarn: "Chỉ sử dụng những cài đặt này nếu bạn biết rõ về nó. Việc nhập các giá trị không đúng có thể khiến máy chủ hoạt động không bình thường."
customCssWarn: "Chỉ sử dụng những cài đặt này nếu bạn biết rõ về nó. Việc nhập các
giá trị không đúng có thể khiến máy chủ hoạt động không bình thường."
global: "Toàn cầu"
squareAvatars: "Ảnh đại diện vuông"
sent: "Gửi"
received: "Đã nhận"
searchResult: "Kết quả tìm kiếm"
searchResult: "Tìm thấy"
hashtags: "Hashtag"
troubleshooting: "Khắc phục sự cố"
useBlurEffect: "Dùng hiệu ứng làm mờ trong giao diện"
@ -795,7 +853,8 @@ whatIsNew: "Hiện những thay đổi"
translate: "Dịch"
translatedFrom: "Dịch từ {x}"
accountDeletionInProgress: "Đang xử lý việc xóa tài khoản"
usernameInfo: "Bạn có thể sử dụng chữ cái (a ~ z, A ~ Z), chữ số (0 ~ 9) hoặc dấu gạch dưới (_). Tên người dùng không thể thay đổi sau này."
usernameInfo: "Bạn có thể sử dụng chữ cái (a ~ z, A ~ Z), chữ số (0 ~ 9) hoặc dấu
gạch dưới (_). Tên người dùng không thể thay đổi sau này."
aiChanMode: "Chế độ Ai"
keepCw: "Giữ cảnh báo nội dung"
pubSub: "Tài khoản Chính/Phụ"
@ -811,12 +870,14 @@ filter: "Bộ lọc"
controlPanel: "Bảng điều khiển"
manageAccounts: "Quản lý tài khoản"
makeReactionsPublic: "Đặt lịch sử biểu cảm công khai"
makeReactionsPublicDescription: "Điều này sẽ hiển thị công khai danh sách tất cả các biểu cảm trước đây của bạn."
makeReactionsPublicDescription: "Điều này sẽ hiển thị công khai danh sách tất cả các
biểu cảm trước đây của bạn."
classic: "Cổ điển"
muteThread: "Không quan tâm nữa"
unmuteThread: "Quan tâm tút này"
ffVisibility: "Hiển thị Theo dõi/Người theo dõi"
ffVisibilityDescription: "Quyết định ai có thể xem những người bạn theo dõi và những người theo dõi bạn."
ffVisibilityDescription: "Quyết định ai có thể xem những người bạn theo dõi và những
người theo dõi bạn."
continueThread: "Tiếp tục xem chuỗi tút"
deleteAccountConfirm: "Điều này sẽ khiến tài khoản bị xóa vĩnh viễn. Vẫn tiếp tục?"
incorrectPassword: "Sai mật khẩu."
@ -857,14 +918,17 @@ thereIsUnresolvedAbuseReportWarning: "Có báo cáo chưa xử lí."
recommended: "Được đề xuất"
check: "Kiểm tra"
driveCapOverrideLabel: "Thay đổi dung lượng drive cho người này"
driveCapOverrideCaption: "Đặt dung lượng drive về mặc định bằng cách nhập 0 hoặc số âm."
driveCapOverrideCaption: "Đặt dung lượng drive về mặc định bằng cách nhập 0 hoặc số
âm."
requireAdminForView: "Bạn phải đăng nhập như là quản trị viên mới xem được."
isSystemAccount: "Đã tạo một tài khoản và tự động vận hành bởi hệ thống."
typeToConfirm: "Nhấn {x} để xác nhận"
deleteAccount: "Xóa tài khoản"
document: "Tài liệu"
numberOfPageCache: "Số lượng trang bộ nhớ đệm"
numberOfPageCacheDescription: "Việc tăng con số này sẽ cải thiện sự thuận tiện cho người dùng nhưng gây ra nhiều áp lực hơn cho máy chủ cũng như sử dụng nhiều bộ nhớ hơn."
numberOfPageCacheDescription: "Việc tăng con số này sẽ cải thiện sự thuận tiện cho
người dùng nhưng gây ra nhiều áp lực hơn cho máy chủ cũng như sử dụng nhiều bộ nhớ
hơn."
logoutConfirm: "Bạn có chắc muốn đăng xuất?"
lastActiveDate: "Lần cuối vào"
statusbar: "Thanh trạng thái"
@ -881,24 +945,33 @@ sensitiveMediaDetection: "Tự động phát hiện NSFW"
localOnly: "Chỉ trên máy chủ"
remoteOnly: "Chỉ máy chủ từ xa"
failedToUpload: "Tải lên thất bại"
cannotUploadBecauseInappropriate: "Không thể tải lên tập tin này vì các phần của tập tin đã được phát hiện có khả năng là NSFW."
cannotUploadBecauseInappropriate: "Không thể tải lên tập tin này vì các phần của tập
tin đã được phát hiện có khả năng là NSFW."
cannotUploadBecauseNoFreeSpace: "Tải lên không thành công do thiếu dung lượng Drive."
beta: "Beta"
enableAutoSensitive: "Tự động đánh dấu NSFW"
enableAutoSensitiveDescription: "Cho phép tự động phát hiện và đánh dấu media NSFW thông qua học máy, nếu có thể. Ngay cả khi tùy chọn này bị tắt, nó vẫn có thể được bật trên toàn máy chủ."
activeEmailValidationDescription: "Cho phép xác minh địa chỉ email chặt chẽ hơn, bao gồm việc kiểm tra các địa chỉ dùng một lần và xem nó có thực sự được giao tiếp hay không. Khi bỏ chọn, chỉ định dạng của email được xác minh."
enableAutoSensitiveDescription: "Cho phép tự động phát hiện và đánh dấu media NSFW
thông qua học máy, nếu có thể. Ngay cả khi tùy chọn này bị tắt, nó vẫn có thể được
bật trên toàn máy chủ."
activeEmailValidationDescription: "Cho phép xác minh địa chỉ email chặt chẽ hơn, bao
gồm việc kiểm tra các địa chỉ dùng một lần và xem nó có thực sự được giao tiếp hay
không. Khi bỏ chọn, chỉ định dạng của email được xác minh."
navbar: "Thanh điều hướng"
shuffle: "Xáo trộn"
account: "Tài khoản của bạn"
move: "Di chuyển"
_sensitiveMediaDetection:
description: "Giảm nỗ lực kiểm duyệt máy chủ thông qua việc tự động nhận dạng media NSFW thông qua học máy. Điều này sẽ làm tăng một chút áp lực trên máy chủ."
description: "Giảm nỗ lực kiểm duyệt máy chủ thông qua việc tự động nhận dạng media
NSFW thông qua học máy. Điều này sẽ làm tăng một chút áp lực trên máy chủ."
sensitivity: "Phát hiện nhạy cảm"
sensitivityDescription: "Giảm độ nhạy sẽ dẫn đến ít phát hiện sai hơn (dương tính giả), tăng nó sẽ dẫn đến ít phát hiện sai hơn (âm tính giả)."
sensitivityDescription: "Giảm độ nhạy sẽ dẫn đến ít phát hiện sai hơn (dương tính
giả), tăng nó sẽ dẫn đến ít phát hiện sai hơn (âm tính giả)."
setSensitiveFlagAutomatically: "Đánh dấu là NSFW"
setSensitiveFlagAutomaticallyDescription: "Kết quả của phát hiện nội bộ sẽ được giữ lại ngay cả khi tùy chọn này bị tắt."
setSensitiveFlagAutomaticallyDescription: "Kết quả của phát hiện nội bộ sẽ được
giữ lại ngay cả khi tùy chọn này bị tắt."
analyzeVideos: "Bật chuẩn đoán video"
analyzeVideosDescription: "Phân tích video bên cạnh hình ảnh. Điều này sẽ làm tăng một chút áp lực trên máy chủ."
analyzeVideosDescription: "Phân tích video bên cạnh hình ảnh. Điều này sẽ làm tăng
một chút áp lực trên máy chủ."
_emailUnavailable:
used: "Địa chỉ email đã được sử dụng"
format: "Địa chỉ email không hợp lệ"
@ -912,11 +985,15 @@ _ffVisibility:
_signup:
almostThere: "Gần xong rồi"
emailAddressInfo: "Hãy điền địa chỉ email của bạn. Nó sẽ không được công khai."
emailSent: "Một email xác minh đã được gửi đến địa chỉ email ({email}) của bạn. Vui lòng nhấn vào liên kết trong đó để hoàn tất việc tạo tài khoản."
emailSent: "Một email xác minh đã được gửi đến địa chỉ email ({email}) của bạn.
Vui lòng nhấn vào liên kết trong đó để hoàn tất việc tạo tài khoản."
_accountDelete:
accountDelete: "Xóa tài khoản"
mayTakeTime: "Vì xóa tài khoản là một quá trình tốn nhiều tài nguyên nên có thể mất một khoảng thời gian để hoàn thành, tùy thuộc vào lượng nội dung bạn đã tạo và số lượng tập tin bạn đã tải lên."
sendEmail: "Sau khi hoàn tất việc xóa tài khoản, một email sẽ được gửi đến địa chỉ email đã đăng ký tài khoản này."
mayTakeTime: "Vì xóa tài khoản là một quá trình tốn nhiều tài nguyên nên có thể
mất một khoảng thời gian để hoàn thành, tùy thuộc vào lượng nội dung bạn đã tạo
và số lượng tập tin bạn đã tải lên."
sendEmail: "Sau khi hoàn tất việc xóa tài khoản, một email sẽ được gửi đến địa chỉ
email đã đăng ký tài khoản này."
requestAccountDelete: "Yêu cầu xóa tài khoản"
started: "Đang bắt đầu xóa tài khoản."
inProgress: "Đang xóa dần tài khoản."
@ -924,9 +1001,12 @@ _ad:
back: "Quay lại"
reduceFrequencyOfThisAd: "Hiện ít lại"
_forgotPassword:
enterEmail: "Nhập địa chỉ email bạn đã sử dụng để đăng ký. Một liên kết mà bạn có thể đặt lại mật khẩu của mình sau đó sẽ được gửi đến nó."
ifNoEmail: "Nếu bạn không sử dụng email lúc đăng ký, vui lòng liên hệ với quản trị viên."
contactAdmin: "Máy chủ này không hỗ trợ sử dụng địa chỉ email, vui lòng liên hệ với quản trị viên để đặt lại mật khẩu của bạn."
enterEmail: "Nhập địa chỉ email bạn đã sử dụng để đăng ký. Một liên kết mà bạn có
thể đặt lại mật khẩu của mình sau đó sẽ được gửi đến nó."
ifNoEmail: "Nếu bạn không sử dụng email lúc đăng ký, vui lòng liên hệ với quản trị
viên."
contactAdmin: "Máy chủ này không hỗ trợ sử dụng địa chỉ email, vui lòng liên hệ
với quản trị viên để đặt lại mật khẩu của bạn."
_gallery:
my: "Kho Ảnh"
liked: "Tút Đã Thích"
@ -950,11 +1030,13 @@ _preferencesBackups:
inputName: "Nhập tên bản sao lưu"
cannotSave: "Không thể lưu"
nameAlreadyExists: "Bản sao lưu \"{name}\" đã tồn tại. Xin nhập tên khác."
applyConfirm: "Bạn có chắc muốn áp dụng bản sao lưu \"{name}\" cho thiết bị này? Thiết lập hiện tại sẽ bị ghi đè."
applyConfirm: "Bạn có chắc muốn áp dụng bản sao lưu \"{name}\" cho thiết bị này?
Thiết lập hiện tại sẽ bị ghi đè."
saveConfirm: "Lưu bản sao lưu {name}?"
deleteConfirm: "Xóa bản sao lưu {name}?"
renameConfirm: "Đổi tên bản sao lưu \"{old}\" thành \"{new}\"?"
noBackups: "Chưa có bản sao lưu. Bạn có thể sao lưu thiết lập trên máy chủ này bằng cách sử dụng \"Tạo sao lưu\"."
noBackups: "Chưa có bản sao lưu. Bạn có thể sao lưu thiết lập trên máy chủ này bằng
cách sử dụng \"Tạo sao lưu\"."
createdAt: "Tạo vào: {time} {date}"
updatedAt: "Cập nhật: {time} {date}"
cannotLoad: "Tải thất bại"
@ -972,15 +1054,22 @@ _aboutFirefish:
source: "Mã nguồn"
translation: "Dịch Firefish"
donate: "Ủng hộ Firefish"
morePatrons: "Chúng tôi cũng trân trọng sự hỗ trợ của nhiều người đóng góp khác không được liệt kê ở đây. Cảm ơn! 🥰"
morePatrons: "Chúng tôi cũng trân trọng sự hỗ trợ của nhiều người đóng góp khác
không được liệt kê ở đây. Cảm ơn! 🥰"
patrons: "Người ủng hộ"
patronsList: Liệt kê theo thứ tự, không theo số tiền ủng hộ. Hãy để tên bạn ở đây!
donateTitle: Thích Firefish?
pleaseDonateToFirefish: Hãy cân nhắc ủng hộ Firefish phát triển.
donateHost: Ủng hộ {host}
pleaseDonateToHost: Cũng như ủng hộ chi phí vận hành máy chủ {host} của bạn.
_nsfw:
respect: "Ẩn nội dung NSFW"
ignore: "Hiện nội dung NSFW"
force: "Ẩn mọi media"
_mfm:
cheatSheet: "MFM Cheatsheet"
intro: "MFM là ngôn ngữ phát triển độc quyền của Firefish có thể được sử dụng ở nhiều nơi. Tại đây bạn có thể xem danh sách tất cả các cú pháp MFM có sẵn."
intro: "MFM là ngôn ngữ phát triển độc quyền của Firefish có thể được sử dụng ở
nhiều nơi. Tại đây bạn có thể xem danh sách tất cả các cú pháp MFM có sẵn."
dummy: "Firefish mở rộng thế giới Fediverse"
mention: "Nhắc đến"
mentionDescription: "Bạn có thể nhắc đến ai đó bằng cách sử dụng @tên người dùng."
@ -999,11 +1088,13 @@ _mfm:
inlineCode: "Mã (Trong dòng)"
inlineCodeDescription: "Hiển thị tô sáng cú pháp trong dòng cho mã (chương trình)."
blockCode: "Mã (Khối)"
blockCodeDescription: "Hiển thị tô sáng cú pháp cho mã nhiều dòng (chương trình) trong một khối."
blockCodeDescription: "Hiển thị tô sáng cú pháp cho mã nhiều dòng (chương trình)
trong một khối."
inlineMath: "Toán học (Trong dòng)"
inlineMathDescription: "Hiển thị công thức toán (KaTeX) trong dòng"
blockMath: "Toán học (Khối)"
blockMathDescription: "Hiển thị công thức toán học nhiều dòng (KaTeX) trong một khối"
blockMathDescription: "Hiển thị công thức toán học nhiều dòng (KaTeX) trong một
khối"
quote: "Trích dẫn"
quoteDescription: "Hiển thị nội dung dạng lời trích dạng."
emoji: "Tùy chỉnh emoji"
@ -1044,6 +1135,9 @@ _mfm:
rotateDescription: "Xoay nội dung theo một góc cụ thể."
plain: "Đơn giản"
plainDescription: "Vô hiệu hóa mọi hiệu ứng MFM chứa trong hiệu ứng MFM này."
stop: Dừng CĐN
play: Phát CĐN
warn: CĐN có thể gây đau mắt hoặc chóng mặt
_instanceTicker:
none: "Không hiển thị"
remote: "Hiện cho người dùng từ máy chủ khác"
@ -1069,15 +1163,20 @@ _menuDisplay:
hide: "Ẩn"
_wordMute:
muteWords: "Ẩn từ ngữ"
muteWordsDescription: "Separate with spaces for an AND condition or with line breaks for an OR condition."
muteWordsDescription2: "Bao quanh các từ khóa bằng dấu gạch chéo để sử dụng cụm từ thông dụng."
muteWordsDescription: "Separate with spaces for an AND condition or with line breaks
for an OR condition."
muteWordsDescription2: "Bao quanh các từ khóa bằng dấu gạch chéo để sử dụng cụm
từ thông dụng."
softDescription: "Ẩn các tút phù hợp điều kiện đã đặt khỏi bảng tin."
hardDescription: "Ngăn các tút đáp ứng các điều kiện đã đặt xuất hiện trên bảng tin. Lưu ý, những tút này sẽ không được thêm vào bảng tin ngay cả khi các điều kiện được thay đổi."
hardDescription: "Ngăn các tút đáp ứng các điều kiện đã đặt xuất hiện trên bảng
tin. Lưu ý, những tút này sẽ không được thêm vào bảng tin ngay cả khi các điều
kiện được thay đổi."
soft: "Yếu"
hard: "Mạnh"
mutedNotes: "Những tút đã ẩn"
_instanceMute:
instanceMuteDescription: "Thao tác này sẽ ẩn mọi tút/lượt đăng lại từ các máy chủ được liệt kê, bao gồm cả những tút dạng trả lời từ máy chủ bị ẩn."
instanceMuteDescription: "Thao tác này sẽ ẩn mọi tút/lượt đăng lại từ các máy chủ
được liệt kê, bao gồm cả những tút dạng trả lời từ máy chủ bị ẩn."
instanceMuteDescription2: "Tách bằng cách xuống dòng"
title: "Ẩn tút từ những máy chủ đã liệt kê."
heading: "Danh sách những máy chủ bị ẩn"
@ -1109,7 +1208,8 @@ _theme:
darken: "Độ tối"
lighten: "Độ sáng"
inputConstantName: "Nhập tên cho hằng số này"
importInfo: "Nếu bạn nhập mã theme ở đây, bạn có thể nhập mã đó vào trình chỉnh sửa theme"
importInfo: "Nếu bạn nhập mã theme ở đây, bạn có thể nhập mã đó vào trình chỉnh
sửa theme"
deleteConstantConfirm: "Bạn có chắc muốn xóa hằng số {const} không?"
keys:
accent: "Màu phụ"
@ -1168,7 +1268,7 @@ _ago:
justNow: "Vừa xong"
secondsAgo: "{n}s trước"
minutesAgo: "{n} phút trước"
hoursAgo: "{n} giờ trước"
hoursAgo: "{n} giờ"
daysAgo: "{n} ngày trước"
weeksAgo: "{n} tuần trước"
monthsAgo: "{n} tháng trước"
@ -1183,32 +1283,47 @@ _tutorial:
step1_1: "Welcome!"
step1_2: "Let's get you set up. You'll be up and running in no time!"
step2_1: "First, please fill out your profile."
step2_2: "Providing some information about who you are will make it easier for others to tell if they want to see your notes or follow you."
step2_2: "Providing some information about who you are will make it easier for others
to tell if they want to see your notes or follow you."
step3_1: "Now time to follow some people!"
step3_2: "Your home and social timelines are based off of who you follow, so try following a couple accounts to get started.\nClick the plus circle on the top right of a profile to follow them."
step3_2: "Your home and social timelines are based off of who you follow, so try
following a couple accounts to get started.\nClick the plus circle on the top
right of a profile to follow them."
step4_1: "Let's get you out there."
step4_2: "For your first post, some people like to made a {introduction} post or a simple \"Hello world!\""
step4_2: "For your first post, some people like to made a {introduction} post or
a simple \"Hello world!\""
step5_1: "Timelines, timelines everywhere!"
step5_2: "Your instance has {timelines} different timelines enabled."
step5_3: "The Home {icon} timeline is where you can see posts from your followers."
step5_4: "The Local {icon} timeline is where you can see posts from everyone else on this instance."
step5_5: "The Recommended {icon} timeline is where you can see posts from instances the admins recommend."
step5_6: "The Social {icon} timeline is where you can see posts from friends of your followers."
step5_7: "The Global {icon} timeline is where you can see posts from every other connected instance."
step5_4: "The Local {icon} timeline is where you can see posts from everyone else
on this instance."
step5_5: "The Recommended {icon} timeline is where you can see posts from instances
the admins recommend."
step5_6: "The Social {icon} timeline is where you can see posts from friends of
your followers."
step5_7: "The Global {icon} timeline is where you can see posts from every other
connected instance."
step6_1: "So, what is this place?"
step6_2: "Well, you didn't just join Firefish. You joined a portal to the Fediverse, an interconnected network of thousands of servers, called \"instances\"."
step6_3: "Each server works in different ways, and not all servers run Firefish. This one does though! It's a bit complicated, but you'll get the hang of it in no time."
step6_4: "Now go, explore, and have fun!"
step6_2: "Well, you didn't just join Firefish. You joined a portal to the Fediverse,
an interconnected network of thousands of servers, called \"instances\"."
step6_3: "Each server works in different ways, and not all servers run Firefish.
This one does though! It's a bit complicated, but you'll get the hang of it in
no time."
step6_4: "Bây giờ bắt đầu khám phá, và vui thôi!"
_2fa:
alreadyRegistered: "Bạn đã đăng ký thiết bị xác minh 2 bước."
registerTOTP: "Đăng ký một thiết bị"
registerSecurityKey: "Đăng ký một mã bảo vệ"
step1: "Trước tiên, hãy cài đặt một ứng dụng xác minh (chẳng hạn như {a} hoặc {b}) trên thiết bị của bạn."
step1: "Trước tiên, hãy cài đặt một ứng dụng xác minh (chẳng hạn như {a} hoặc {b})
trên thiết bị của bạn."
step2: "Sau đó, quét mã QR hiển thị trên màn hình này."
step2Url: "Bạn cũng có thể nhập URL này nếu sử dụng một chương trình máy tính:"
step3: "Nhập mã token do ứng dụng của bạn cung cấp để hoàn tất thiết lập."
step4: "Kể từ bây giờ, những lần đăng nhập trong tương lai sẽ yêu cầu mã token đăng nhập đó."
securityKeyInfo: "Bên cạnh xác minh bằng vân tay hoặc mã PIN, bạn cũng có thể thiết lập xác minh thông qua khóa bảo mật phần cứng hỗ trợ FIDO2 để bảo mật hơn nữa cho tài khoản của mình."
step4: "Kể từ bây giờ, những lần đăng nhập trong tương lai sẽ yêu cầu mã token đăng
nhập đó."
securityKeyInfo: "Bên cạnh xác minh bằng vân tay hoặc mã PIN, bạn cũng có thể thiết
lập xác minh thông qua khóa bảo mật phần cứng hỗ trợ FIDO2 để bảo mật hơn nữa
cho tài khoản của mình."
_permissions:
"read:account": "Xem thông tin tài khoản của bạn"
"write:account": "Sửa thông tin tài khoản của bạn"
@ -1244,7 +1359,8 @@ _permissions:
"write:gallery-likes": "Sửa danh sách các tút đã thích trong thư viện của tôi"
_auth:
shareAccess: "Bạn có muốn cho phép \"{name}\" truy cập vào tài khoản này không?"
shareAccessAsk: "Bạn có chắc muốn cho phép ứng dụng này truy cập vào tài khoản của mình không?"
shareAccessAsk: "Bạn có chắc muốn cho phép ứng dụng này truy cập vào tài khoản của
mình không?"
permissionAsk: "Ứng dụng này yêu cầu các quyền sau"
pleaseGoBack: "Vui lòng quay lại ứng dụng"
callback: "Quay lại ứng dụng"
@ -1304,7 +1420,7 @@ _poll:
deadlineTime: "giờ"
duration: "Thời hạn"
votesCount: "{n} bình chọn"
totalVotes: "{n} tổng bình chọn"
totalVotes: "{n} lượt bình chọn"
vote: "Bình chọn"
showResult: "Xem kết quả"
voted: "Đã bình chọn"
@ -1342,7 +1458,9 @@ _profile:
youCanIncludeHashtags: "Bạn có thể dùng hashtag trong tiểu sử."
metadata: "Thông tin bổ sung"
metadataEdit: "Sửa thông tin bổ sung"
metadataDescription: "Sử dụng phần này, bạn có thể hiển thị các mục thông tin bổ sung trong hồ sơ của mình. Bạn có thể thêm thẻ {a} hoặc thẻ {l} với {rel} để xác minh liên kết trên tiểu sử của mình!"
metadataDescription: "Sử dụng phần này, bạn có thể hiển thị các mục thông tin bổ
sung trong hồ sơ của mình. Bạn có thể thêm thẻ {a} hoặc thẻ {l} với {rel} để xác
minh liên kết trên tiểu sử của mình!"
metadataLabel: "Nhãn"
metadataContent: "Nội dung"
changeAvatar: "Đổi ảnh đại diện"
@ -1616,7 +1734,8 @@ _pages:
_dailyRannum:
arg1: "Giá trị tối thiểu"
arg2: "Giá trị tối đa"
dailyRandomPick: "Chọn ngẫu nhiên từ một danh sách (Đổi mỗi người một lần mỗi ngày)"
dailyRandomPick: "Chọn ngẫu nhiên từ một danh sách (Đổi mỗi người một lần mỗi
ngày)"
_dailyRandomPick:
arg1: "Danh sách"
seedRandom: "Ngẫu nhiên (với seed)"
@ -1663,7 +1782,8 @@ _pages:
_for:
arg1: "Số lần lặp lại"
arg2: "Hành động"
typeError: "Chỗ {slot} chấp nhận các giá trị thuộc loại \"{expect}\", nhưng giá trị được cung cấp thuộc loại \"{actual}\"!"
typeError: "Chỗ {slot} chấp nhận các giá trị thuộc loại \"{expect}\", nhưng giá
trị được cung cấp thuộc loại \"{actual}\"!"
thereIsEmptySlot: "Chỗ {slot} đang trống!"
types:
string: "Văn bản"
@ -1727,7 +1847,8 @@ _deck:
newProfile: "Hồ sơ mới"
deleteProfile: "Xóa hồ sơ"
introduction: "Kết hợp các cột để tạo giao diện của riêng bạn!"
introduction2: "Bạn có thể thêm cột bất kỳ lúc nào bằng cách nhấn + ở bên phải màn hình."
introduction2: "Bạn có thể thêm cột bất kỳ lúc nào bằng cách nhấn + ở bên phải màn
hình."
widgetsIntroduction: "Chọn \"Sửa widget\" trong menu cột và thêm một widget."
_columns:
main: "Chính"
@ -1738,3 +1859,11 @@ _deck:
list: "Danh sách"
mentions: "Lượt nhắc"
direct: "Nhắn riêng"
renoteMute: Ẩn lượt chia sẻ
renoteUnmute: Bỏ ẩn lượt chia sẻ
searchPlaceholder: Lướt Firefish
edited: Đã sửa {date} {time}
findOtherInstance: Tìm máy chủ khác
noThankYou: Từ chối
_filters:
withFile: Có file

View File

@ -1,6 +1,6 @@
_lang_: "简体中文"
headlineMisskey: "一个开源、去中心化的社交媒体平台,永远免费!🚀"
introMisskey: "欢迎! Firefish 是一个开源、去中心化的社交媒体平台,永久免费!🚀"
headlineFirefish: "一个开源、去中心化的社交媒体平台,永远免费!🚀"
introFirefish: "欢迎! Firefish 是一个开源、去中心化的社交媒体平台,永久免费!🚀"
monthAndDay: "{month} 月 {day} 日"
search: "搜索"
notifications: "通知"
@ -521,7 +521,7 @@ recentUsed: "最近使用"
install: "安装"
uninstall: "卸载"
installedApps: "已授权的应用"
nothing: "没有"
nothing: "暂无更多内容"
installedDate: "授权日期"
lastUsedDate: "最近使用时间"
state: "状态"
@ -641,7 +641,7 @@ openInNewTab: "在新标签页中打开"
openInSideView: "在侧边栏中打开"
defaultNavigationBehaviour: "默认导航"
editTheseSettingsMayBreakAccount: "编辑这些设置可能会损坏您的账号。"
instanceTicker: "帖子所在的服务器信息"
instanceTicker: "帖子的实例信息"
waitingFor: "等待 {x}"
random: "随机"
system: "系统"
@ -825,7 +825,7 @@ unmuteThread: "取消静音帖子串"
ffVisibility: "关注/关注者 可见性"
ffVisibilityDescription: "您可以设置谁可以看到您的关注/关注者信息。"
continueThread: "查看更多帖子"
deleteAccountConfirm: "将要删除账号。是否继续?"
deleteAccountConfirm: "将不可逆的删除账号,是否继续?"
incorrectPassword: "密码错误。"
voteConfirm: "确定投给 “{choice}” "
hide: "隐藏"
@ -866,7 +866,7 @@ check: "检查"
driveCapOverrideLabel: "修改此用户的网盘容量"
driveCapOverrideCaption: "输入 0 或以下的值将容量重置为默认值。"
requireAdminForView: "需要使用管理员账号登录才能查看。"
isSystemAccount: "该账号由系统自动创建和管理。请不要修改、编辑、删除或以其它方式篡改这个账号,否则可能会破坏您的服务器。"
isSystemAccount: "该账号由系统自动创建。请不要修改、编辑、删除或以其它方式篡改这个账号,否则可能会破坏您的服务器。"
typeToConfirm: "输入 {x} 以确认操作"
deleteAccount: "删除账号"
document: "文档"
@ -988,9 +988,9 @@ _aboutFirefish:
morePatrons: "还有很多其它的人也在支持我们,非常感谢🥰"
patrons: "Firefish 赞助者"
patronsList: 按时间顺序而不是捐赠金额排列。通过上面的链接捐款,让您的名字出现在这里!
sponsors: Calckey 赞助者们
donateTitle: 喜欢 Calckey 吗?
pleaseDonateToCalckey: 请考虑赞助 Calckey 以支持其开发。
sponsors: Firefish 赞助者们
donateTitle: 喜欢 Firefish 吗?
pleaseDonateToFirefish: 请考虑赞助 Firefish 以支持其开发。
pleaseDonateToHost: 也请考虑赞助您的主服务器 {host},以帮助支持其运营成本。
donateHost: 赞助 {host}
_nsfw:
@ -1231,10 +1231,10 @@ _tutorial:
step5_1: "时间线,无处不在的时间线!"
step5_2: "您的服务器已启用 {timelines} 种不同的时间线。"
step5_3: "主页 {icon} 时间线是您可以看到您关注账号的帖子的时间线。"
step5_4: "本地 {icon} 时间线是您可以看到此服务器上其它用户的帖子的时间线。"
step5_5: "社交 {icon} 时间线是主页和本地时间线的结合。"
step5_6: "推荐 {icon} 时间线是您可以看到管理员推荐服务器的帖子的时间线。"
step5_7: "全球 {icon} 时间线是您可以看到来自其它所有互联服务器的帖子的时间线。"
step5_4: "本地{icon}时间线是您可以看到此服务器上其它用户的帖子的时间线。"
step5_5: "社交{icon}时间线是主页和本地时间线的结合。"
step5_6: "推荐{icon}时间线是您可以看到管理员推荐服务器的帖子的时间线。"
step5_7: "全球{icon}时间线是您可以看到来自其它所有互联服务器的帖子的时间线。"
step6_1: "那么,这里是什么地方?"
step6_2: "好吧,您不只是加入 Firefish。您已经加入了 Fediverse 的一个门户,这是一个由成千上万台服务器组成的互联网络。"
step6_3: "每个服务器的工作方式不同,并不是所有的服务器都运行 Firefish。但这个服务器是的! 这有点复杂,但您很快就会明白的。"
@ -1965,3 +1965,4 @@ remindMeLater: 稍后再说
removeQuote: 移除引用
removeRecipient: 移除接收者
removeMember: 移除成员
origin: 起源

View File

@ -1,6 +1,6 @@
_lang_: "繁體中文"
headlineMisskey: "貼文連繫網路"
introMisskey: "歡迎! Firefish是一個開源、去中心化且永遠免費的社群網路平台🚀"
headlineFirefish: "貼文連繫網路"
introFirefish: "歡迎! Firefish是一個開源、去中心化且永遠免費的社群網路平台🚀"
monthAndDay: "{month}月 {day}日"
search: "搜尋"
notifications: "通知"
@ -996,7 +996,7 @@ _nsfw:
force: "隱藏所有內容"
_mfm:
cheatSheet: "MFM代碼小抄"
intro: "MFM是Misskey專用的標記語言,可以在Misskey中的各個位置使用。 您可以這裏看到MFM可用語法列表。"
intro: "MFM是Misskey、Firefish、Akkoma等專用的標記語言,可以在各個位置使用。 您可以這裏看到MFM可用語法列表。"
dummy: "Firefish拓展了Fediverse的世界"
mention: "提及"
mentionDescription: "透過 @+用戶名 來標示特定使用者。"
@ -1068,6 +1068,16 @@ _mfm:
positionDescription: 按指定數量移動內容。
advancedDescription: 如果禁用,則僅允許基本標記,除非正在播放 MFM 動畫
advanced: 高級MFM
fade: 淡出
foreground: 文字顏色
crop: 裁切
scale: 縮放
scaleDescription: 按指定數量縮放內容。
fadeDescription: 將內容淡入淡出。
background: 背景顏色
backgroundDescription: 改變背景顏色。
cropDescription: 裁切內容。
foregroundDescription: 改變文字顏色。
_instanceTicker:
none: "隱藏"
remote: "向遠端使用者顯示"
@ -1236,6 +1246,18 @@ _2fa:
step3: "輸入您的App提供的權杖以完成設定。"
step4: "從現在開始,任何登入操作都將要求您提供權杖。"
securityKeyInfo: "您可以設定使用支援FIDO2的硬體安全鎖、終端設備的指纹認證或者PIN碼來登入。"
renewTOTPCancel: 取消
removeKey: 移除安全金鑰
removeKeyConfirm: 真的要刪掉 {name} 嗎?
renewTOTP: 重新配置身份驗證器應用程式
chromePasskeyNotSupported: 目前不支持 Chrome 密鑰。
whyTOTPOnlyRenew: 只要註冊了安全金鑰,就無法刪除身份驗證器應用程式。
renewTOTPConfirm: 這將導致您之前的身分驗證器應用程式停止工作
securityKeyName: 取一個金鑰的名字
tapSecurityKey: 請按照您的瀏覽器註冊安全金鑰或密碼
token: 兩步驟驗證金鑰
registerTOTPBeforeKey: 請設置身份驗證器應用程式以註冊安全金鑰或密碼。
renewTOTPOk: 重新配置
_permissions:
"read:account": "查看我的帳戶資訊"
"write:account": "更改我的帳戶資訊"
@ -1272,16 +1294,19 @@ _permissions:
_auth:
shareAccess: "要授權「“{name}”」存取您的帳戶嗎?"
shareAccessAsk: "您確定要授權這個應用程式使用您的帳戶嗎?"
permissionAsk: "此應用程式需要以下權限"
permissionAsk: "此應用程式需要以下權限"
pleaseGoBack: "請返回至應用程式"
callback: "回到應用程式"
denied: "拒絕訪問"
copyAsk: 請將以下授權代碼貼上到應用程式中:
allPermissions: 完全帳戶訪問許可權
_antennaSources:
all: "全部貼文"
homeTimeline: "來自已追隨使用者的貼文"
users: "來自特定使用者的貼文"
userList: "來自特定清單中的貼文"
userGroup: "來自特定群組的貼文"
instances: 伺服器上所有使用者的貼文
_weekday:
sunday: "週日"
monday: "週一"
@ -1297,22 +1322,29 @@ _widgets:
calendar: "行事曆"
trends: "發燒貼文"
clock: "時鐘"
rss: "RSS閱讀器"
rssTicker: "RSS跑馬燈"
rss: "RSS 閱讀器"
rssTicker: "RSS 跑馬燈"
activity: "動態"
photos: "照片"
digitalClock: "電子時鐘"
unixClock: "UNIX時間"
federation: "聯邦宇宙"
instanceCloud: "伺服器雲"
instanceCloud: "伺服器雲"
postForm: "發佈窗口"
slideshow: "幻燈片"
button: "按鈕"
onlineUsers: "線上的用戶"
jobQueue: "佇列"
serverMetric: "伺服器指標"
aiscript: "AiScript控制台"
aiscript: "AiScript 控制台"
aichan: "小藍"
serverInfo: 伺服器資訊
userList: 使用者列表
_userList:
chooseList: 選擇一個清單
meiliIndexCount: 編入索引的帖子
meiliStatus: 伺服器狀態
meiliSize: 索引大小
_cw:
hide: "隱藏"
show: "瀏覽更多"
@ -1342,11 +1374,11 @@ _poll:
remainingSeconds: "{s}秒後截止"
_visibility:
public: "公開"
publicDescription: "發布給所有用戶"
publicDescription: "發佈至公開時間線"
home: "不在主頁顯示"
homeDescription: "僅發送至首頁的時間線"
followers: "追隨者"
followersDescription: "僅發至關注者"
followersDescription: "僅發至關注者"
specified: "指定使用者"
specifiedDescription: "僅發送至指定使用者"
localOnly: "僅限本地"
@ -1741,6 +1773,7 @@ _notification:
followBack: "回關"
reply: "回覆"
renote: "轉發"
reacted: 對您的貼文做出了反應
_deck:
alwaysShowMainColumn: "總是顯示主欄"
columnAlign: "對齊欄位"
@ -1848,7 +1881,7 @@ subscribePushNotification: 啟用推送通知
unsubscribePushNotification: 禁用推送通知
pushNotificationAlreadySubscribed: 推送通知已經啟用
recommendedInstancesDescription: 以每行分隔的推薦伺服器出現在推薦的時間線中。
searchPlaceholder: 聯邦網路上搜尋
searchPlaceholder: Firefish 上搜尋
cw: 內容警告
selectChannel: 選擇一個頻道
newer: 較新
@ -1899,3 +1932,14 @@ removeQuote: 删除引用
removeRecipient: 刪除收件者
removeMember: 刪除成員
isBot: 此帳戶是機器人
verifiedLink: 已驗證連結
_filters:
followersOnly: 只顯示關注者的
fromDomain: 從域名
notesBefore: 指定時間以前
notesAfter: 指定時間以後
followingOnly: 只顯示關注的
fromUser: 從使用者
withFile: 有檔案
alt: 替代文字
xl: 特大

View File

@ -1,6 +1,6 @@
{
"name": "firefish",
"version": "1.0.3",
"version": "1.0.4-dev10",
"codename": "aqua",
"repository": {
"type": "git",
@ -22,6 +22,8 @@
"dev": "pnpm node ./scripts/dev.js",
"dev:staging": "NODE_OPTIONS=--max_old_space_size=3072 NODE_ENV=development pnpm run build && pnpm run start",
"lint": "pnpm -r --parallel run lint",
"debug": "pnpm run build:debug && pnpm run start",
"build:debug": "pnpm -r --parallel run build:debug && pnpm run gulp",
"cy:open": "cypress open --browser --e2e --config-file=cypress.config.ts",
"cy:run": "cypress run",
"e2e": "start-server-and-test start:test http://localhost:61812 cy:run",

View File

@ -1,4 +1,4 @@
Copyright 2023 Calckey
Copyright 2023 Firefish
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.

View File

@ -42,13 +42,15 @@ async fn main() {
None => "redis",
Some(_) => "rediss",
};
let redis_uri_userpass = match redis_conf.user {
None => "".to_string(),
Some(user) => format!("{}:{}@", user, encode(&redis_conf.pass.unwrap_or_default())),
};
let redis_user = redis_conf.user.unwrap_or("default".to_string());
let redis_uri_userpass = format!(
"{}:{}",
redis_user,
encode(&redis_conf.pass.unwrap_or_default())
);
let redis_uri_hostport = format!("{}:{}", redis_conf.host, redis_conf.port);
let redis_uri = format!(
"{}://{}{}/{}",
"{}://{}@{}/{}",
redis_proto, redis_uri_userpass, redis_uri_hostport, redis_conf.db
);
env::set_var(CACHE_URL_ENV, redis_uri);

View File

@ -36,8 +36,8 @@
"artifacts": "napi artifacts",
"build": "pnpm run build:napi && pnpm run build:migration",
"build:napi": "napi build --features napi --platform --release ./built/",
"build:migration": "cargo build --locked --release --manifest-path ./migration/Cargo.toml && cp ./target/release/migration ./built/migration",
"build:debug": "napi build --platform ./built/ && cargo build --manifest-path ./migration/Cargo.toml",
"build:migration": "cargo build --locked --release --manifest-path ./migration/Cargo.toml && cp -v ./target/release/migration ./built/migration",
"build:debug": "napi build --features napi --platform ./built/ && cargo build --locked --manifest-path ./migration/Cargo.toml && cp -v ./target/debug/migration ./built/migration",
"prepublishOnly": "napi prepublish -t npm",
"test": "pnpm run cargo:test && pnpm run build:napi && ava",
"universal": "napi universal",

View File

@ -14,6 +14,7 @@
"revertmigration:cargo": "./native-utils/built/migration down",
"check:connect": "node ./check_connect.js",
"build": "pnpm swc src -d built -D",
"build:debug": "pnpm swc src -d built -s -D",
"watch": "pnpm swc src -d built -D -w",
"lint": "pnpm rome check --apply *",
"mocha": "cross-env NODE_ENV=test TS_NODE_FILES=true TS_NODE_TRANSPILE_ONLY=true TS_NODE_PROJECT=\"./test/tsconfig.json\" mocha",

View File

@ -31,13 +31,41 @@ function greet() {
if (!envOption.quiet) {
//#region Firefish logo
const v = `v${meta.version}`;
console.log(themeColor(" ▄▄▄▄▄▄▄ ▄▄▄ ▄▄▄▄▄▄ ▄▄▄▄▄▄▄ ▄▄▄▄▄▄▄ ▄▄▄ ▄▄▄▄▄▄▄ ▄▄ ▄▄ ◯ "));
console.log(themeColor("█ █ █ ▄ █ █ █ █ █ █ █ █ █ ○ ▄ ▄"));
console.log(themeColor("█ ▄▄▄█ █ █ █ █ █ ▄▄▄█ ▄▄▄█ █ ▄▄▄▄▄█ █▄█ █ ⚬ █▄▄ █▄▄ "));
console.log(themeColor("█ █▄▄▄█ █ █▄▄█▄█ █▄▄▄█ █▄▄▄█ █ █▄▄▄▄▄█ █ ▄▄▄▄▄▄ ▄"));
console.log(themeColor("█ ▄▄▄█ █ ▄▄ █ ▄▄▄█ ▄▄▄█ █▄▄▄▄▄ █ ▄ █ █ █ █▄▄"));
console.log(themeColor("█ █ █ █ █ █ █ █▄▄▄█ █ █ █▄▄▄▄▄█ █ █ █ █ █ ● ● █"));
console.log(themeColor("█▄▄▄█ █▄▄▄█▄▄▄█ █▄█▄▄▄▄▄▄▄█▄▄▄█ █▄▄▄█▄▄▄▄▄▄▄█▄▄█ █▄▄█ ▀▄▄▄▄▄▄▀"));
console.log(
themeColor(
" ▄▄▄▄▄▄▄ ▄▄▄ ▄▄▄▄▄▄ ▄▄▄▄▄▄▄ ▄▄▄▄▄▄▄ ▄▄▄ ▄▄▄▄▄▄▄ ▄▄ ▄▄ ◯ ",
),
);
console.log(
themeColor(
"█ █ █ ▄ █ █ █ █ █ █ █ █ █ ○ ▄ ▄",
),
);
console.log(
themeColor(
"█ ▄▄▄█ █ █ █ █ █ ▄▄▄█ ▄▄▄█ █ ▄▄▄▄▄█ █▄█ █ ⚬ █▄▄ █▄▄ ",
),
);
console.log(
themeColor(
"█ █▄▄▄█ █ █▄▄█▄█ █▄▄▄█ █▄▄▄█ █ █▄▄▄▄▄█ █ ▄▄▄▄▄▄ ▄",
),
);
console.log(
themeColor(
"█ ▄▄▄█ █ ▄▄ █ ▄▄▄█ ▄▄▄█ █▄▄▄▄▄ █ ▄ █ █ █ █▄▄",
),
);
console.log(
themeColor(
"█ █ █ █ █ █ █ █▄▄▄█ █ █ █▄▄▄▄▄█ █ █ █ █ █ ● ● █",
),
);
console.log(
themeColor(
"█▄▄▄█ █▄▄▄█▄▄▄█ █▄█▄▄▄▄▄▄▄█▄▄▄█ █▄▄▄█▄▄▄▄▄▄▄█▄▄█ █▄▄█ ▀▄▄▄▄▄▄▀",
),
);
//#endregion
console.log(
@ -78,7 +106,11 @@ export async function masterMain() {
config = loadConfigBoot();
await connectDb();
} catch (e) {
bootLogger.error("Fatal error occurred during initialization", null, true);
bootLogger.error(
`Fatal error occurred during initialization: ${e}`,
null,
true,
);
process.exit(1);
}

View File

@ -41,6 +41,7 @@ export default function load() {
config.url = url.origin;
config.port = config.port || parseInt(process.env.PORT || "", 10);
config.bind = config.bind || process.env.BIND;
mixin.version = meta.version;
mixin.host = url.host;

View File

@ -6,6 +6,7 @@ export type Source = {
feedback_url?: string;
url: string;
port: number;
bind?: string;
disableHsts?: boolean;
db: {
host: string;

View File

@ -37,6 +37,7 @@ export default function () {
mem: {
used: round(memStats.used - memStats.buffers - memStats.cached),
active: round(memStats.active),
total: round(memStats.total),
},
net: {
rx: round(Math.max(0, netStats.rx_sec)),

View File

@ -121,6 +121,19 @@ if (hasConfig) {
),
);
posts
.updateRankingRules([
"sort",
"words",
"typo",
"proximity",
"attribute",
"exactness",
])
.catch((e) => {
logger.error("Failed to set ranking rules, sorting won't work properly.");
});
logger.info("Connected to MeiliSearch");
}
@ -160,6 +173,7 @@ export default hasConfig
limit: number,
offset: number,
userCtx: ILocalUser | null,
overrideSort: string | null,
) => {
/// Advanced search syntax
/// from:user => filter by user + optional domain
@ -170,8 +184,10 @@ export default hasConfig
/// "text" => get posts with exact text between quotes
/// filter:following => show results only from users you follow
/// filter:followers => show results only from followers
/// order:desc/asc => order results ascending or descending
const constructedFilters: string[] = [];
let sortRules: string[] = [];
const splitSearch = query.split(" ");
@ -195,9 +211,9 @@ export default hasConfig
// Determine if we got a webfinger address or a single username
if (user.split("@").length > 1) {
let splitUser = user.split("@");
const splitUser = user.split("@");
let domain = splitUser.pop();
const domain = splitUser.pop();
user = splitUser.join("@");
constructedFilters.push(
@ -215,7 +231,7 @@ export default hasConfig
} else if (term.startsWith("after:")) {
const timestamp = term.slice(6);
let unix = timestampToUnix(timestamp);
const unix = timestampToUnix(timestamp);
if (unix !== 0) constructedFilters.push(`createdAt > ${unix}`);
@ -223,7 +239,7 @@ export default hasConfig
} else if (term.startsWith("before:")) {
const timestamp = term.slice(7);
let unix = timestampToUnix(timestamp);
const unix = timestampToUnix(timestamp);
if (unix !== 0) constructedFilters.push(`createdAt < ${unix}`);
return null;
@ -278,6 +294,14 @@ export default hasConfig
);
}
return null;
} else if (term.startsWith("order:desc")) {
sortRules.push("createdAt:desc");
return null;
} else if (term.startsWith("order:asc")) {
sortRules.push("createdAt:asc");
return null;
}
@ -286,14 +310,27 @@ export default hasConfig
)
).filter((term) => term !== null);
const sortRules = [];
// An empty search term with defined filters means we have a placeholder search => https://www.meilisearch.com/docs/reference/api/search#placeholder-search
// These have to be ordered manually, otherwise the *oldest* posts are returned first, which we don't want
if (filteredSearchTerms.length === 0 && constructedFilters.length > 0) {
// If the user has defined a sort rule, don't mess with it
if (
filteredSearchTerms.length === 0 &&
constructedFilters.length > 0 &&
sortRules.length === 0
) {
sortRules.push("createdAt:desc");
}
// More than one sorting rule doesn't make sense. We only keep the first one, otherwise weird stuff may happen.
if (sortRules.length > 1) {
sortRules = [sortRules[0]];
}
// An override sort takes precedence, user sorting is ignored here
if (overrideSort) {
sortRules = [overrideSort];
}
logger.info(`Searching for ${filteredSearchTerms.join(" ")}`);
logger.info(`Limit: ${limit}`);
logger.info(`Offset: ${offset}`);

View File

@ -156,7 +156,7 @@ export function toHtml(
search(node) {
const a = doc.createElement("a");
a.href = `https://search.annoyingorange.xyz/search?q=${node.props.query}`;
a.href = `/search/${node.props.query}`;
a.textContent = node.props.content;
return a;
},

View File

@ -1,16 +1,18 @@
export type Post = {
text: string | null;
text: string | undefined;
cw: string | null;
localOnly: boolean;
createdAt: Date;
visibility: string;
};
export function parse(acct: any): Post {
return {
text: acct.text,
text: acct.text || undefined,
cw: acct.cw,
localOnly: acct.localOnly,
createdAt: new Date(acct.createdAt),
visibility: "hidden" + (acct.visibility || ""),
};
}

View File

@ -28,6 +28,7 @@ import {
backgroundQueue,
} from "./queues.js";
import type { ThinUser } from "./types.js";
import { Note } from "@/models/entities/note.js";
function renderError(e: Error): any {
return {
@ -358,6 +359,7 @@ export function createImportCkPostJob(
user: ThinUser,
post: any,
signatureCheck: boolean,
parent: Note | null = null,
) {
return dbQueue.add(
"importCkPost",
@ -365,6 +367,7 @@ export function createImportCkPostJob(
user: user,
post: post,
signatureCheck: signatureCheck,
parent: parent,
},
{
removeOnComplete: true,

View File

@ -3,7 +3,13 @@ import create from "@/services/note/create.js";
import { Users } from "@/models/index.js";
import type { DbUserImportMastoPostJobData } from "@/queue/types.js";
import { queueLogger } from "../../logger.js";
import { uploadFromUrl } from "@/services/drive/upload-from-url.js";
import type { DriveFile } from "@/models/entities/drive-file.js";
import type Bull from "bull";
import { createImportCkPostJob } from "@/queue/index.js";
import { Notes, NoteEdits } from "@/models/index.js";
import type { Note } from "@/models/entities/note.js";
import { genId } from "@/misc/gen-id.js";
const logger = queueLogger.createSubLogger("import-firefish-post");
@ -17,6 +23,7 @@ export async function importCkPost(
return;
}
const post = job.data.post;
/*
if (post.replyId != null) {
done();
return;
@ -29,23 +36,74 @@ export async function importCkPost(
done();
return;
}
const { text, cw, localOnly, createdAt } = Post.parse(post);
const note = await create(user, {
*/
const urls = (post.files || [])
.map((x: any) => x.url)
.filter((x: String) => x.startsWith("http"));
const files: DriveFile[] = [];
for (const url of urls) {
try {
const file = await uploadFromUrl({
url: url,
user: user,
});
files.push(file);
} catch (e) {
logger.error(`Skipped adding file to drive: ${url}`);
}
}
const { text, cw, localOnly, createdAt, visibility } = Post.parse(post);
let note = await Notes.findOneBy({
createdAt: createdAt,
files: undefined,
poll: undefined,
text: text || undefined,
reply: null,
renote: null,
cw: cw,
localOnly,
visibility: "hidden",
visibleUsers: [],
channel: null,
apMentions: new Array(0),
apHashtags: undefined,
apEmojis: undefined,
text: text,
userId: user.id,
});
if (note && (note?.fileIds?.length || 0) < files.length) {
const update: Partial<Note> = {};
update.fileIds = files.map((x) => x.id);
await Notes.update(note.id, update);
await NoteEdits.insert({
id: genId(),
noteId: note.id,
text: note.text || undefined,
cw: note.cw,
fileIds: note.fileIds,
updatedAt: new Date(),
});
logger.info(`Note file updated`);
}
if (!note) {
note = await create(user, {
createdAt: createdAt,
files: files.length == 0 ? undefined : files,
poll: undefined,
text: text || undefined,
reply: post.replyId ? job.data.parent : null,
renote: post.renoteId ? job.data.parent : null,
cw: cw,
localOnly,
visibility: visibility,
visibleUsers: [],
channel: null,
apMentions: new Array(0),
apHashtags: undefined,
apEmojis: undefined,
});
logger.info(`Create new note`);
} else {
logger.info(`Note exist`);
}
logger.succ("Imported");
if (post.childNotes) {
for (const child of post.childNotes) {
createImportCkPostJob(
job.data.user,
child,
job.data.signatureCheck,
note,
);
}
}
done();
}

View File

@ -8,6 +8,9 @@ import { resolveNote } from "@/remote/activitypub/models/note.js";
import { Note } from "@/models/entities/note.js";
import { uploadFromUrl } from "@/services/drive/upload-from-url.js";
import type { DriveFile } from "@/models/entities/drive-file.js";
import { Notes, NoteEdits } from "@/models/index.js";
import type { Note } from "@/models/entities/note.js";
import { genId } from "@/misc/gen-id.js";
const logger = queueLogger.createSubLogger("import-masto-post");
@ -67,23 +70,47 @@ export async function importMastoPost(
}
}
}
const note = await create(user, {
let note = await Notes.findOneBy({
createdAt: new Date(post.object.published),
files: files.length == 0 ? undefined : files,
poll: undefined,
text: text || undefined,
reply,
renote: null,
cw: post.object.sensitive ? post.object.summary : undefined,
localOnly: false,
visibility: "hidden",
visibleUsers: [],
channel: null,
apMentions: new Array(0),
apHashtags: undefined,
apEmojis: undefined,
text: text,
userId: user.id,
});
if (note && (note?.fileIds?.length || 0) < files.length) {
const update: Partial<Note> = {};
update.fileIds = files.map((x) => x.id);
await Notes.update(note.id, update);
await NoteEdits.insert({
id: genId(),
noteId: note.id,
text: note.text || undefined,
cw: note.cw,
fileIds: note.fileIds,
updatedAt: new Date(),
});
logger.info(`Note file updated`);
}
if (!note) {
note = await create(user, {
createdAt: new Date(post.object.published),
files: files.length == 0 ? undefined : files,
poll: undefined,
text: text || undefined,
reply,
renote: null,
cw: post.object.sensitive ? post.object.summary : undefined,
localOnly: false,
visibility: "hiddenpublic",
visibleUsers: [],
channel: null,
apMentions: new Array(0),
apHashtags: undefined,
apEmojis: undefined,
});
logger.info(`Create new note`);
} else {
logger.info(`Note exist`);
}
job.progress(100);
done();

View File

@ -57,7 +57,8 @@ export async function importPosts(
const parsed = JSON.parse(json);
if (parsed instanceof Array) {
logger.info("Parsing key style posts");
for (const post of JSON.parse(json)) {
const arr = recreateChain(parsed);
for (const post of arr) {
createImportCkPostJob(job.data.user, post, job.data.signatureCheck);
}
} else if (parsed instanceof Object) {
@ -74,3 +75,32 @@ export async function importPosts(
logger.succ("Imported");
done();
}
function recreateChain(arr: any[]): any {
type NotesMap = {
[id: string]: any;
};
const notesTree: any[] = [];
const lookup: NotesMap = {};
for (const note of arr) {
lookup[`${note.id}`] = note;
note.childNotes = [];
if (note.replyId == null && note.renoteId == null) {
notesTree.push(note);
}
}
for (const note of arr) {
let parent = null;
if (note.replyId != null) {
parent = lookup[`${note.replyId}`];
}
if (note.renoteId != null) {
parent = lookup[`${note.renoteId}`];
}
if (parent) {
parent.childNotes.push(note);
}
}
return notesTree;
}

View File

@ -48,6 +48,6 @@ export default async function cleanRemoteFiles(
job.progress(deletedCount / total);
}
logger.succ("All cahced remote files has been deleted.");
logger.succ("All cached remote files has been deleted.");
done();
}

View File

@ -52,6 +52,7 @@ export type DbUserImportMastoPostJobData = {
user: ThinUser;
post: any;
signatureCheck: boolean;
parent: Note | null;
};
export type ObjectStorageJobData =

View File

@ -94,7 +94,7 @@ function groupingAudience(ids: string[], actor: CacheableRemoteUser) {
function isPublic(id: string) {
return [
"https://www.w3.org/ns/activitystreams#Public",
"as#Public",
"as:Public",
"Public",
].includes(id);
}

View File

@ -33,7 +33,9 @@ export default (endpoint: IEndpoint, ctx: Koa.Context) =>
code: y!.code,
id: y!.id,
kind: y!.kind,
...(y!.info ? { info: y!.info } : {}),
...(y!.info && process.env.NODE_ENV !== "production"
? { info: y!.info }
: {}),
},
};
} else {

View File

@ -1,11 +1,9 @@
import type { IEndpoint } from "./endpoints";
import * as cp___instance_info from "./endpoints/compatibility/instance-info.js";
import * as cp___custom_emojis from "./endpoints/compatibility/custom-emojis.js";
import * as ep___instance_peers from "./endpoints/compatibility/peers.js";
const cps = [
["v1/instance", cp___instance_info],
["v1/custom_emojis", cp___custom_emojis],
["v1/instance/peers", ep___instance_peers],
];

View File

@ -65,6 +65,8 @@ import * as ep___admin_unsuspendUser from "./endpoints/admin/unsuspend-user.js";
import * as ep___admin_updateMeta from "./endpoints/admin/update-meta.js";
import * as ep___admin_vacuum from "./endpoints/admin/vacuum.js";
import * as ep___admin_deleteAccount from "./endpoints/admin/delete-account.js";
import * as ep___admin_delete2fa from "./endpoints/admin/delete-2fa.js";
import * as ep___admin_deletePasskeys from "./endpoints/admin/delete-passkeys.js";
import * as ep___admin_updateUserNote from "./endpoints/admin/update-user-note.js";
import * as ep___announcements from "./endpoints/announcements.js";
import * as ep___antennas_create from "./endpoints/antennas/create.js";
@ -418,6 +420,8 @@ const eps = [
["admin/update-meta", ep___admin_updateMeta],
["admin/vacuum", ep___admin_vacuum],
["admin/delete-account", ep___admin_deleteAccount],
["admin/delete-2fa", ep___admin_delete2fa],
["admin/delete-passkeys", ep___admin_deletePasskeys],
["admin/update-user-note", ep___admin_updateUserNote],
["announcements", ep___announcements],
["antennas/create", ep___antennas_create],

View File

@ -0,0 +1,40 @@
import { Users, UserProfiles } from "@/models/index.js";
import { publishMainStream } from "@/services/stream.js";
import define from "../../define.js";
export const meta = {
tags: ["admin"],
requireCredential: true,
requireAdmin: true,
res: {},
} as const;
export const paramDef = {
type: "object",
properties: {
userId: { type: "string", format: "misskey:id" },
},
required: ["userId"],
} as const;
export default define(meta, paramDef, async (ps) => {
const user = await Users.findOneByOrFail({ id: ps.userId });
if (user.isDeleted) {
return;
}
await UserProfiles.update(user.id, {
twoFactorSecret: null,
twoFactorEnabled: false,
usePasswordLessLogin: false,
});
const iObj = await Users.pack(user.id, user, {
detail: true,
includeSecrets: true,
});
publishMainStream(user.id, "meUpdated", iObj);
});

View File

@ -0,0 +1,42 @@
import { Users, UserProfiles, UserSecurityKeys } from "@/models/index.js";
import { publishMainStream } from "@/services/stream.js";
import define from "../../define.js";
export const meta = {
tags: ["admin"],
requireCredential: true,
requireAdmin: true,
res: {},
} as const;
export const paramDef = {
type: "object",
properties: {
userId: { type: "string", format: "misskey:id" },
},
required: ["userId"],
} as const;
export default define(meta, paramDef, async (ps) => {
const user = await Users.findOneByOrFail({ id: ps.userId });
if (user.isDeleted) {
return;
}
await UserSecurityKeys.delete({
userId: user.id,
});
await UserProfiles.update(user.id, {
usePasswordLessLogin: false,
});
const iObj = await Users.pack(user.id, user, {
detail: true,
includeSecrets: true,
});
publishMainStream(user.id, "meUpdated", iObj);
});

View File

@ -60,13 +60,14 @@ export default define(meta, paramDef, async (ps, user) => {
throw new ApiError(meta.errors.noSuchAntenna);
}
const limit = ps.limit + (ps.untilId ? 1 : 0) + (ps.sinceId ? 1 : 0); // untilIdに指定したものも含まれるため+1
const noteIdsRes = await redisClient.xrevrange(
`antennaTimeline:${antenna.id}`,
ps.untilDate || "+",
"-",
ps.untilDate ?? "+",
ps.sinceDate ?? "-",
"COUNT",
ps.limit + 1,
); // untilIdに指定したものも含まれるため+1
limit,
);
if (noteIdsRes.length === 0) {
return [];
@ -74,7 +75,7 @@ export default define(meta, paramDef, async (ps, user) => {
const noteIds = noteIdsRes
.map((x) => x[1][1])
.filter((x) => x !== ps.untilId);
.filter((x) => x !== ps.untilId && x !== ps.sinceId);
if (noteIds.length === 0) {
return [];
@ -105,7 +106,7 @@ export default define(meta, paramDef, async (ps, user) => {
generateMutedUserQuery(query, user);
generateBlockedUserQuery(query, user);
const notes = await query.take(ps.limit).getMany();
const notes = await query.take(limit).getMany();
if (notes.length > 0) {
readNote(user.id, notes);

View File

@ -1,232 +0,0 @@
import * as mfm from "mfm-js";
import { toHtml } from "@/mfm/to-html.js";
import config from "@/config/index.js";
import { fetchMeta } from "@/misc/fetch-meta.js";
import {
Users,
Notes,
Instances,
UserProfiles,
Emojis,
DriveFiles,
} from "@/models/index.js";
import type { Emoji } from "@/models/entities/emoji.js";
import type { User } from "@/models/entities/user.js";
import { IsNull, In } from "typeorm";
import { MAX_NOTE_TEXT_LENGTH, FILE_TYPE_BROWSERSAFE } from "@/const.js";
import define from "../../define.js";
export const meta = {
requireCredential: false,
requireCredentialPrivateMode: true,
allowGet: true,
tags: ["meta"],
} as const;
export const paramDef = {
type: "object",
properties: {},
required: [],
} as const;
export default define(meta, paramDef, async () => {
const now = Date.now();
const [meta, total, localPosts, instanceCount, firstAdmin, emojis] =
await Promise.all([
fetchMeta(true),
Users.count({ where: { host: IsNull() } }),
Notes.count({ where: { userHost: IsNull(), replyId: IsNull() } }),
Instances.count(),
Users.findOne({
where: {
host: IsNull(),
isAdmin: true,
isDeleted: false,
isBot: false,
},
order: { id: "ASC" },
}),
Emojis.find({
where: { host: IsNull(), type: In(FILE_TYPE_BROWSERSAFE) },
select: ["id", "name", "originalUrl", "publicUrl"],
}).then((l) =>
l.reduce((a, e) => {
a[e.name] = e;
return a;
}, {} as Record<string, Emoji>),
),
]);
const descSplit = splitN(meta.description, "\n", 2);
const shortDesc = markup(descSplit.length > 0 ? descSplit[0] : "");
const longDesc = markup(meta.description ?? "");
return {
uri: config.hostname,
title: meta.name,
short_description: shortDesc,
description: longDesc,
email: meta.maintainerEmail,
version: config.version,
urls: {
streaming_api: `wss://${config.host}`,
},
stats: {
user_count: total,
status_count: localPosts,
domain_count: instanceCount,
},
thumbnail: meta.logoImageUrl,
languages: meta.langs,
registrations: !meta.disableRegistration,
approval_required: false,
invites_enabled: false,
configuration: {
accounts: {
max_featured_tags: 16,
},
statuses: {
max_characters: MAX_NOTE_TEXT_LENGTH,
max_media_attachments: 16,
characters_reserved_per_url: 0,
},
media_attachments: {
supported_mime_types: FILE_TYPE_BROWSERSAFE,
image_size_limit: 10485760,
image_matrix_limit: 16777216,
video_size_limit: 41943040,
video_frame_rate_limit: 60,
video_matrix_limit: 2304000,
},
polls: {
max_options: 10,
max_characters_per_option: 50,
min_expiration: 15,
max_expiration: -1,
},
},
contact_account: await getContact(firstAdmin, emojis),
rules: [],
};
});
const splitN = (s: string | null, split: string, n: number): string[] => {
const ret: string[] = [];
if (s == null) return ret;
if (s === "") {
ret.push(s);
return ret;
}
let start = 0;
let pos = s.indexOf(split);
if (pos === -1) {
ret.push(s);
return ret;
}
for (let i = 0; i < n - 1; i++) {
ret.push(s.substring(start, pos));
start = pos + split.length;
pos = s.indexOf(split, start);
if (pos === -1) break;
}
ret.push(s.substring(start));
return ret;
};
type ContactType = {
id: string;
username: string;
acct: string;
display_name: string;
note?: string;
noindex?: boolean;
fields?: {
name: string;
value: string;
verified_at: string | null;
}[];
locked: boolean;
bot: boolean;
created_at: string;
url: string;
followers_count: number;
following_count: number;
statuses_count: number;
last_status_at?: string;
emojis: any;
} | null;
const getContact = async (
user: User | null,
emojis: Record<string, Emoji>,
): Promise<ContactType> => {
if (!user) return null;
let contact: ContactType = {
id: user.id,
username: user.username,
acct: user.username,
display_name: user.name ?? user.username,
locked: user.isLocked,
bot: user.isBot,
created_at: user.createdAt.toISOString(),
url: `${config.url}/@${user.username}`,
followers_count: user.followersCount,
following_count: user.followingCount,
statuses_count: user.notesCount,
last_status_at: user.lastActiveDate?.toISOString(),
emojis: emojis
? user.emojis
.filter((e, i, a) => e in emojis && a.indexOf(e) === i)
.map((e) => ({
shortcode: e,
static_url: emojis[e].publicUrl,
url: emojis[e].originalUrl,
visible_in_picker: true,
}))
: [],
};
const [profile] = await Promise.all([
UserProfiles.findOne({ where: { userId: user.id } }),
loadDriveFiles(contact, "avatar", user.avatarId),
loadDriveFiles(contact, "header", user.bannerId),
]);
if (!profile) {
return contact;
}
contact = {
...contact,
note: markup(profile.description ?? ""),
noindex: profile.noCrawle,
fields: profile.fields.map((f) => ({
name: f.name,
value: f.value,
verified_at: null,
})),
};
return contact;
};
const loadDriveFiles = async (
contact: any,
key: string,
fileId: string | null,
) => {
if (fileId) {
const file = await DriveFiles.findOneBy({ id: fileId });
if (file) {
contact[key] = file.webpublicUrl ?? file.url;
contact[`${key}_static`] = contact[key];
}
}
};
const markup = (text: string): string => toHtml(mfm.parse(text)) ?? "";

View File

@ -1,6 +1,7 @@
import { IsNull } from "typeorm";
import { Emojis } from "@/models/index.js";
import define from "../define.js";
import { ApiError } from "../error.js";
export const meta = {
tags: ["meta"],
@ -9,6 +10,15 @@ export const meta = {
allowGet: true,
cacheSec: 3600,
errors: {
noSuchEmoji: {
message: "No such emoji.",
code: "NO_SUCH_EMOJI",
id: "6a5e3be7-5ac3-44a6-a425-9937cd66f8e1",
httpStatusCode: 404,
},
},
res: {
type: "object",
optional: false,
@ -28,12 +38,16 @@ export const paramDef = {
} as const;
export default define(meta, paramDef, async (ps, me) => {
const emoji = await Emojis.findOneOrFail({
const emoji = await Emojis.findOne({
where: {
name: ps.name,
host: IsNull(),
},
});
if (!emoji) {
throw new ApiError(meta.errors.noSuchEmoji);
}
return Emojis.pack(emoji);
});

View File

@ -394,6 +394,12 @@ export const meta = {
optional: "true",
nullable: true,
},
enableServerMachineStats: {
type: "boolean",
optional: "true",
nullable: false,
default: false,
},
},
},
} as const;
@ -497,6 +503,8 @@ export default define(meta, paramDef, async (ps, me) => {
instance.deeplAuthKey != null || instance.libreTranslateApiUrl != null,
defaultReaction: instance.defaultReaction,
donationLink: instance.donationLink,
enableServerMachineStats: instance.enableServerMachineStats,
enableIdenticonGeneration: instance.enableIdenticonGeneration,
...(ps.detail
? {

View File

@ -1,4 +1,4 @@
import { In } from "typeorm";
import { FindManyOptions, In } from "typeorm";
import { Notes } from "@/models/index.js";
import { Note } from "@/models/entities/note.js";
import config from "@/config/index.js";
@ -58,6 +58,11 @@ export const paramDef = {
nullable: true,
default: null,
},
order: {
type: "string",
default: "chronological",
nullable: true,
},
},
required: ["query"],
} as const;
@ -156,9 +161,6 @@ export default define(meta, paramDef, async (ps, me) => {
where: {
id: In(chunk),
},
order: {
id: "DESC",
},
});
// The notes are checked for visibility and muted/blocked users when packed
@ -175,19 +177,31 @@ export default define(meta, paramDef, async (ps, me) => {
} else if (meilisearch) {
let start = 0;
const chunkSize = 100;
const sortByDate = ps.order !== "relevancy";
type NoteResult = {
id: string;
createdAt: number;
};
const extractedNotes: NoteResult[] = [];
// Use meilisearch to fetch and step through all search results that could match the requirements
const ids = [];
while (true) {
const results = await meilisearch.search(ps.query, chunkSize, start, me);
const searchRes = await meilisearch.search(
ps.query,
chunkSize,
start,
me,
sortByDate ? "createdAt:desc" : null,
);
const results: MeilisearchNote[] = searchRes.hits as MeilisearchNote[];
start += chunkSize;
if (results.hits.length === 0) {
if (results.length === 0) {
break;
}
const res = results.hits
const res = results
.filter((key: MeilisearchNote) => {
if (ps.userId && key.userId !== ps.userId) {
return false;
@ -203,34 +217,45 @@ export default define(meta, paramDef, async (ps, me) => {
}
return true;
})
.map((key) => key.id);
.map((key) => {
return {
id: key.id,
createdAt: key.createdAt,
};
});
ids.push(...res);
extractedNotes.push(...res);
}
// Sort all the results by note id DESC (newest first)
ids.sort((a, b) => b - a);
// Fetch the notes from the database until we have enough to satisfy the limit
start = 0;
const found = [];
while (found.length < ps.limit && start < ids.length) {
const chunk = ids.slice(start, start + chunkSize);
const notes: Note[] = await Notes.find({
const noteIDs = extractedNotes.map((note) => note.id);
// Index the ID => index number into a map, so we can restore the array ordering efficiently later
const idIndexMap = new Map(noteIDs.map((id, index) => [id, index]));
while (found.length < ps.limit && start < noteIDs.length) {
const chunk = noteIDs.slice(start, start + chunkSize);
let query: FindManyOptions = {
where: {
id: In(chunk),
},
order: {
id: "DESC",
},
});
};
const notes: Note[] = await Notes.find(query);
// Re-order the note result according to the noteIDs array (cannot be undefined, we map this earlier)
// @ts-ignore
notes.sort((a, b) => idIndexMap.get(a.id) - idIndexMap.get(b.id));
// The notes are checked for visibility and muted/blocked users when packed
found.push(...(await Notes.packMany(notes, me)));
start += chunkSize;
}
// If we have more results than the limit, trim them
// If we have more results than the limit, trim the results down
if (found.length > ps.limit) {
found.length = ps.limit;
}

View File

@ -8,8 +8,14 @@ import { apiTimelineMastodon } from "./endpoints/timeline.js";
import { apiNotificationsMastodon } from "./endpoints/notifications.js";
import { apiSearchMastodon } from "./endpoints/search.js";
import { getInstance } from "./endpoints/meta.js";
import { convertAnnouncement, convertFilter } from "./converters.js";
import {
convertAccount,
convertAnnouncement,
convertFilter,
} from "./converters.js";
import { convertId, IdType } from "../index.js";
import { Users } from "@/models/index.js";
import { IsNull } from "typeorm";
export function getClient(
BASE_URL: string,
@ -52,7 +58,20 @@ export function apiMastodonCompatible(router: Router): void {
// displayed without being logged in
try {
const data = await client.getInstance();
ctx.body = await getInstance(data.data);
const admin = await Users.findOne({
where: {
host: IsNull(),
isAdmin: true,
isDeleted: false,
isSuspended: false,
},
order: { id: "ASC" },
});
const contact =
admin == null
? null
: convertAccount((await client.getAccount(admin.id)).data);
ctx.body = await getInstance(data.data, contact);
} catch (e: any) {
console.error(e);
ctx.status = 401;

View File

@ -32,12 +32,20 @@ export function convertNotification(notification: Entity.Notification) {
notification.id = convertId(notification.id, IdType.MastodonId);
if (notification.status)
notification.status = convertStatus(notification.status);
if (notification.reaction)
notification.reaction = convertReaction(notification.reaction);
return notification;
}
export function convertPoll(poll: Entity.Poll) {
return simpleConvert(poll);
}
export function convertReaction(reaction: Entity.Reaction) {
if (reaction.accounts) {
reaction.accounts = reaction.accounts.map(convertAccount);
}
return reaction;
}
export function convertRelationship(relationship: Entity.Relationship) {
return simpleConvert(relationship);
}
@ -61,6 +69,8 @@ export function convertStatus(status: Entity.Status) {
}));
if (status.poll) status.poll = convertPoll(status.poll);
if (status.reblog) status.reblog = convertStatus(status.reblog);
if (status.quote) status.quote = convertStatus(status.quote);
status.reactions = status.reactions.map(convertReaction);
return status;
}

View File

@ -2,13 +2,19 @@ import { Entity } from "megalodon";
import config from "@/config/index.js";
import { fetchMeta } from "@/misc/fetch-meta.js";
import { Users, Notes } from "@/models/index.js";
import { IsNull, MoreThan } from "typeorm";
import { IsNull } from "typeorm";
import { MAX_NOTE_TEXT_LENGTH, FILE_TYPE_BROWSERSAFE } from "@/const.js";
export async function getInstance(
response: Entity.Instance,
contact: Entity.Account,
) {
const [meta, totalUsers, totalStatuses] = await Promise.all([
fetchMeta(true),
Users.count({ where: { host: IsNull() } }),
Notes.count({ where: { userHost: IsNull() } }),
]);
// TODO: add firefish features
export async function getInstance(response: Entity.Instance) {
const meta = await fetchMeta(true);
const totalUsers = Users.count({ where: { host: IsNull() } });
const totalStatuses = Notes.count({ where: { userHost: IsNull() } });
return {
uri: response.uri,
title: response.title || "Firefish",
@ -35,41 +41,12 @@ export async function getInstance(response: Entity.Instance) {
max_featured_tags: 20,
},
statuses: {
max_characters: 3000,
max_media_attachments: 4,
max_characters: MAX_NOTE_TEXT_LENGTH,
max_media_attachments: 16,
characters_reserved_per_url: response.uri.length,
},
media_attachments: {
supported_mime_types: [
"image/jpeg",
"image/png",
"image/gif",
"image/heic",
"image/heif",
"image/webp",
"image/avif",
"video/webm",
"video/mp4",
"video/quicktime",
"video/ogg",
"audio/wave",
"audio/wav",
"audio/x-wav",
"audio/x-pn-wave",
"audio/vnd.wave",
"audio/ogg",
"audio/vorbis",
"audio/mpeg",
"audio/mp3",
"audio/webm",
"audio/flac",
"audio/aac",
"audio/m4a",
"audio/x-m4a",
"audio/mp4",
"audio/3gpp",
"video/x-ms-asf",
],
supported_mime_types: FILE_TYPE_BROWSERSAFE,
image_size_limit: 10485760,
image_matrix_limit: 16777216,
video_size_limit: 41943040,
@ -77,36 +54,16 @@ export async function getInstance(response: Entity.Instance) {
video_matrix_limit: 2304000,
},
polls: {
max_options: 8,
max_options: 10,
max_characters_per_option: 50,
min_expiration: 300,
min_expiration: 50,
max_expiration: 2629746,
},
reactions: {
max_reactions: 1,
},
},
contact_account: {
id: "1",
username: "admin",
acct: "admin",
display_name: "admin",
locked: true,
bot: true,
discoverable: false,
group: false,
created_at: new Date().toISOString(),
note: "<p>Please refer to the original instance for the actual admin contact.</p>",
url: `${response.uri}/`,
avatar: `${response.uri}/static-assets/badges/info.png`,
avatar_static: `${response.uri}/static-assets/badges/info.png`,
header: "/static-assets/transparent.png",
header_static: "/static-assets/transparent.png",
followers_count: -1,
following_count: 0,
statuses_count: 0,
last_status_at: new Date().toISOString(),
noindex: true,
emojis: [],
fields: [],
},
contact_account: contact,
rules: [],
};
}

View File

@ -27,6 +27,8 @@ export function apiStatusMastodon(router: Router): void {
let body: any = ctx.request.body;
if (body.in_reply_to_id)
body.in_reply_to_id = convertId(body.in_reply_to_id, IdType.FirefishId);
if (body.quote_id)
body.quote_id = convertId(body.quote_id, IdType.FirefishId);
if (
(!body.poll && body["poll[options][]"]) ||
(!body.media_ids && body["media_ids[]"])
@ -48,7 +50,7 @@ export function apiStatusMastodon(router: Router): void {
try {
const id = body.in_reply_to_id;
const post = await client.getStatus(id);
const react = post.data.emoji_reactions.filter((e) => e.me)[0].name;
const react = post.data.reactions.filter((e) => e.me)[0].name;
const data = await client.deleteEmojiReaction(id, react);
ctx.body = data.data;
} catch (e: any) {
@ -367,6 +369,47 @@ export function apiStatusMastodon(router: Router): void {
}
},
);
router.post<{ Params: { id: string; name: string } }>(
"/v1/statuses/:id/react/:name",
async (ctx) => {
const BASE_URL = `${ctx.protocol}://${ctx.hostname}`;
const accessTokens = ctx.headers.authorization;
const client = getClient(BASE_URL, accessTokens);
try {
const data = await client.reactStatus(
convertId(ctx.params.id, IdType.FirefishId),
ctx.params.name,
);
ctx.body = convertStatus(data.data);
} catch (e: any) {
console.error(e);
ctx.status = 401;
ctx.body = e.response.data;
}
},
);
router.post<{ Params: { id: string; name: string } }>(
"/v1/statuses/:id/unreact/:name",
async (ctx) => {
const BASE_URL = `${ctx.protocol}://${ctx.hostname}`;
const accessTokens = ctx.headers.authorization;
const client = getClient(BASE_URL, accessTokens);
try {
const data = await client.unreactStatus(
convertId(ctx.params.id, IdType.FirefishId),
ctx.params.name,
);
ctx.body = convertStatus(data.data);
} catch (e: any) {
console.error(e);
ctx.status = 401;
ctx.body = e.response.data;
}
},
);
router.get<{ Params: { id: string } }>("/v1/media/:id", async (ctx) => {
const BASE_URL = `${ctx.protocol}://${ctx.hostname}`;
const accessTokens = ctx.headers.authorization;

View File

@ -18,6 +18,10 @@ export function argsToBools(q: ParsedUrlQuery) {
const toBoolean = (value: string) =>
!["0", "f", "F", "false", "FALSE", "off", "OFF"].includes(value);
// Keys taken from:
// - https://docs.joinmastodon.org/methods/accounts/#statuses
// - https://docs.joinmastodon.org/methods/timelines/#public
// - https://docs.joinmastodon.org/methods/timelines/#tag
let object: any = q;
if (q.only_media)
if (typeof q.only_media === "string")
@ -25,6 +29,13 @@ export function argsToBools(q: ParsedUrlQuery) {
if (q.exclude_replies)
if (typeof q.exclude_replies === "string")
object.exclude_replies = toBoolean(q.exclude_replies);
if (q.exclude_reblogs)
if (typeof q.exclude_reblogs === "string")
object.exclude_reblogs = toBoolean(q.exclude_reblogs);
if (q.pinned)
if (typeof q.pinned === "string") object.pinned = toBoolean(q.pinned);
if (q.local)
if (typeof q.local === "string") object.local = toBoolean(q.local);
return q;
}

View File

@ -0,0 +1,221 @@
import { Readable, ReadableOptions } from "node:stream";
import { Buffer, constants as BufferConstants } from "node:buffer";
import * as fs from "node:fs";
interface ByteRange {
start: bigint;
end: bigint;
size: bigint;
}
const BOUNDARY_CHARS =
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
const BYTERANGE_SPEC_REGEX = /^bytes=(.+)$/;
const BYTERANGE_REGEX = /(\d*)-(\d*)/;
const BIGINT_0 = BigInt(0);
const BIGINT_1 = BigInt(1);
const BOUNDARY_SIZE = 40;
function extractRanges(
fileSize: bigint,
maxByteRanges: number,
rangeHeaderValue: string,
): ByteRange[] {
const ranges: ByteRange[] = [];
if (!rangeHeaderValue) return ranges;
const rangeSpecMatch = rangeHeaderValue.match(BYTERANGE_SPEC_REGEX);
if (!rangeSpecMatch) return [];
const rangeSpecs = rangeSpecMatch[1].split(",");
for (let i = 0; i < rangeSpecs.length; i = i + 1) {
const byteRange = rangeSpecs[i].match(BYTERANGE_REGEX);
if (!byteRange) return [];
let start: bigint;
let end: bigint;
let size: bigint;
if (byteRange[1]) {
start = BigInt(byteRange[1]);
}
if (byteRange[2]) {
end = BigInt(byteRange[2]);
}
if (start === undefined && end === undefined) {
/* some invalid range like bytes=- */
return [];
}
if (start === undefined) {
/* end-of-file range like -500 */
start = fileSize - end;
end = fileSize - BIGINT_1;
if (start < BIGINT_0) return []; /* range larger than file, return */
}
if (end === undefined) {
/* range like 0- */
end = fileSize - BIGINT_1;
}
if (start > end || end >= fileSize) {
/* return empty range to issue regular 200 */
return [];
}
size = end - start + BIGINT_1;
if (1 > maxByteRanges - ranges.length) return [];
ranges.push({
start: start,
end: end,
size: size,
});
}
return ranges;
}
function createBoundary(len: number): string {
let chars = [];
for (let i = 0; i < len; i = i + 1) {
chars[i] = BOUNDARY_CHARS.charAt(
Math.floor(Math.random() * BOUNDARY_CHARS.length),
);
}
return chars.join("");
}
class ByteRangeReadable extends Readable {
size: bigint; /* the total size in bytes */
boundary: string; /* boundary marker to use in multipart headers */
private fd: number;
private ranges: ByteRange[];
private index: number; /* index within ranges */
private position: bigint;
private end: bigint;
private contentType: string;
private fileSize: bigint;
private headers: Buffer[];
private trailer: Buffer;
static parseByteRanges(
fileSize: bigint,
maxByteRanges: number,
rangeHeaderValue?: string,
): ByteRange[] {
return extractRanges(fileSize, maxByteRanges, rangeHeaderValue);
}
private createPartHeader(range: ByteRange): Buffer {
return Buffer.from(
[
"",
`--${this.boundary}`,
`Content-Type: ${this.contentType}`,
`Content-Range: bytes ${range.start}-${range.end}/${this.fileSize}`,
"",
"",
].join("\r\n"),
);
}
constructor(
fd: number,
fileSize: bigint,
ranges: ByteRange[],
contentType: string,
opts?: ReadableOptions,
) {
super(opts);
if (ranges.length === 0) {
throw Error("this requires at least 1 byte range");
}
this.fd = fd;
this.ranges = ranges;
this.fileSize = fileSize;
this.contentType = contentType;
this.position = BIGINT_1;
this.end = BIGINT_0;
this.index = -1;
this.headers = [];
this.size = BIGINT_0;
if (this.ranges.length === 1) {
this.size = this.ranges[0].size;
} else {
this.boundary = createBoundary(BOUNDARY_SIZE);
this.ranges.forEach((r) => {
const header = this.createPartHeader(r);
this.headers.push(header);
this.size += BigInt(header.length) + r.size;
});
this.trailer = Buffer.from(`\r\n--${this.boundary}--\r\n`);
this.size += BigInt(this.trailer.length);
}
}
_read(n) {
if (this.index == this.ranges.length) {
this.push(null);
return;
}
if (this.position > this.end) {
/* move ahead to the next index */
this.index++;
if (this.index === this.ranges.length) {
if (this.trailer) {
this.push(this.trailer);
return;
}
this.push(null);
return;
}
this.position = this.ranges[this.index].start;
this.end = this.ranges[this.index].end;
if (this.ranges.length > 1) {
this.push(this.headers[this.index]);
return;
}
}
const max = this.end - this.position + BIGINT_1;
if (n > max) n = Number(max);
const buf = Buffer.alloc(n);
fs.read(this.fd, buf, 0, n, this.position, (err, bytesRead) => {
if (err) {
this.destroy(err);
return;
}
if (bytesRead == 0) {
/* something seems to have gone wrong? */
this.push(null);
return;
}
if (bytesRead > n) bytesRead = n;
this.position += BigInt(bytesRead);
this.push(buf.slice(0, bytesRead));
});
}
}
export { ByteRange, ByteRangeReadable };

View File

@ -14,6 +14,7 @@ import { detectType } from "@/misc/get-file-info.js";
import { convertToWebp } from "@/services/drive/image-processor.js";
import { GenerateVideoThumbnail } from "@/services/drive/generate-video-thumbnail.js";
import { StatusError } from "@/misc/fetch.js";
import { ByteRangeReadable } from "./byte-range-readable.js";
import { FILE_TYPE_BROWSERSAFE } from "@/const.js";
const _filename = fileURLToPath(import.meta.url);
@ -21,6 +22,8 @@ const _dirname = dirname(_filename);
const assets = `${_dirname}/../../server/file/assets/`;
const MAX_BYTE_RANGES = 10;
const commonReadableHandlerGenerator =
(ctx: Koa.Context) => (e: Error): void => {
serverLogger.error(e);
@ -122,31 +125,88 @@ export default async function (ctx: Koa.Context) {
return;
}
let contentType;
let filename;
let fileHandle;
if (isThumbnail || isWebpublic) {
const { mime, ext } = await detectType(InternalStorage.resolvePath(key));
const filename = rename(file.name, {
suffix: isThumbnail ? "-thumb" : "-web",
extname: ext ? `.${ext}` : undefined,
}).toString();
(contentType = FILE_TYPE_BROWSERSAFE.includes(mime)
? mime
: "application/octet-stream"),
(filename = rename(file.name, {
suffix: isThumbnail ? "-thumb" : "-web",
extname: ext ? `.${ext}` : undefined,
}).toString());
ctx.body = InternalStorage.read(key);
ctx.set(
"Content-Type",
FILE_TYPE_BROWSERSAFE.includes(mime) ? mime : "application/octet-stream",
);
ctx.set("Cache-Control", "max-age=31536000, immutable");
ctx.set("Content-Disposition", contentDisposition("inline", filename));
fileHandle = await InternalStorage.open(key, "r");
} else {
const readable = InternalStorage.read(file.accessKey!);
readable.on("error", commonReadableHandlerGenerator(ctx));
ctx.body = readable;
ctx.set(
"Content-Type",
FILE_TYPE_BROWSERSAFE.includes(file.type)
? file.type
: "application/octet-stream",
);
ctx.set("Cache-Control", "max-age=31536000, immutable");
ctx.set("Content-Disposition", contentDisposition("inline", file.name));
(contentType = FILE_TYPE_BROWSERSAFE.includes(file.type)
? file.type
: "application/octet-stream"),
(filename = file.name);
fileHandle = await InternalStorage.open(file.accessKey!, "r");
}
// We can let Koa evaluate conditionals by setting
// the status to 200, along with the lastModified
// and etag properties, then checking ctx.fresh.
// Additionally, Range is ignored if a conditional GET would
// result in a 304 response, so we can return early here.
ctx.status = 200;
ctx.etag = file.md5;
ctx.lastModified = file.createdAt;
// When doing a conditional request, we MUST return a "Cache-Control" header
// if a normal 200 response would have included.
ctx.set("Cache-Control", "max-age=31536000, immutable");
if (ctx.fresh) {
ctx.status = 304;
return;
}
ctx.length = file.size;
ctx.set("Content-Disposition", contentDisposition("inline", filename));
ctx.set("Content-Type", contentType);
const ranges = ByteRangeReadable.parseByteRanges(
BigInt(file.size),
MAX_BYTE_RANGES,
ctx.headers["range"],
);
const readable =
ranges.length === 0
? fileHandle.createReadStream()
: new ByteRangeReadable(
fileHandle.fd,
BigInt(file.size),
ranges,
contentType,
);
readable.on("error", commonReadableHandlerGenerator(ctx));
ctx.body = readable;
if (ranges.length === 0) {
ctx.set("Accept-Ranges", "bytes");
} else {
ctx.status = 206;
ctx.length = readable.size;
readable.on("close", async () => {
await fileHandle.close();
});
if (ranges.length === 1) {
ctx.set(
"Content-Range",
`bytes ${ranges[0].start}-${ranges[0].end}/${file.size}`,
);
} else {
ctx.set(
"Content-Type",
`multipart/byteranges; boundary=${readable.boundary}`,
);
}
}
}

View File

@ -221,7 +221,10 @@ export const startServer = () => {
initializeStreamingServer(server);
server.listen(config.port);
server.listen({
port: config.port,
host: config.bind,
});
return server;
};
@ -257,6 +260,11 @@ export default () =>
}
});
// @ts-ignore
server.listen(config.port, resolve);
server.listen(
{
port: config.port,
host: config.bind,
},
() => resolve(undefined),
);
});

View File

@ -114,24 +114,48 @@ const router = new Router();
//#region static assets
router.get("/static-assets/(.*)", async (ctx) => {
await send(ctx as any, ctx.path.replace("/static-assets/", ""), {
root: staticAssets,
maxage: 7 * DAY,
});
try {
await send(ctx as any, ctx.path.replace("/static-assets/", ""), {
root: staticAssets,
maxage: 7 * DAY,
});
} catch (e) {
if (e.status === 404) {
ctx.throw(404, "File not found");
} else {
throw e;
}
}
});
router.get("/client-assets/(.*)", async (ctx) => {
await send(ctx as any, ctx.path.replace("/client-assets/", ""), {
root: clientAssets,
maxage: 7 * DAY,
});
try {
await send(ctx as any, ctx.path.replace("/client-assets/", ""), {
root: clientAssets,
maxage: 7 * DAY,
});
} catch (e) {
if (e.status === 404) {
ctx.throw(404, "File not found");
} else {
throw e;
}
}
});
router.get("/assets/(.*)", async (ctx) => {
await send(ctx as any, ctx.path.replace("/assets/", ""), {
root: assets,
maxage: 7 * DAY,
});
try {
await send(ctx as any, ctx.path.replace("/assets/", ""), {
root: assets,
maxage: 7 * DAY,
});
} catch (e) {
if (e.status === 404) {
ctx.throw(404, "File not found");
} else {
throw e;
}
}
});
// Apple touch icon

View File

@ -14,10 +14,13 @@ export const manifestHandler = async (ctx: Koa.Context) => {
res.name = instance.name || "Firefish";
if (instance.themeColor) res.theme_color = instance.themeColor;
for (const icon of res.icons) {
icon.src = `${icon.src}?v=${config.version.replace(/[^0-9]/g, '')}`;
icon.src = `${icon.src}?v=${config.version.replace(/[^0-9]/g, "")}`;
}
for (const screenshot of res.screenshots) {
screenshot.src = `${screenshot.src}?v=${config.version.replace(/[^0-9]/g, '')}`;
screenshot.src = `${screenshot.src}?v=${config.version.replace(
/[^0-9]/g,
"",
)}`;
}
ctx.set("Cache-Control", "max-age=300");
ctx.body = res;

View File

@ -37,6 +37,32 @@ import { deleteFile } from "./delete-file.js";
const logger = driveLogger.createSubLogger("register", "yellow");
type PathPartLike = string | null;
// Joins an array of elements into a URL pathname, possibly with a base URL object to append to.
// Null or 0-length parts will be left out.
function urlPathJoin(
baseOrParts: URL | PathPartLike[],
pathParts?: PathPartLike[],
): string {
if (baseOrParts instanceof URL) {
const url = new URL(baseOrParts as URL);
if (pathParts) {
pathParts.unshift(
url.pathname.endsWith("/") ? url.pathname.slice(0, -1) : url.pathname,
);
url.pathname = pathParts
.filter((x) => x !== null && x.toString().length > 0)
.join("/");
}
return url.toString();
}
const baseParts = baseOrParts.concat(pathParts ?? []);
return baseParts
.filter((x) => x !== null && x.toString().length > 0)
.join("/");
}
/***
* Save file
* @param path Path for original
@ -77,17 +103,16 @@ async function save(
ext = "";
}
const baseUrl =
meta.objectStorageBaseUrl ||
const baseUrl = new URL(
meta.objectStorageBaseUrl ?? `/${meta.objectStorageBucket}`,
`${meta.objectStorageUseSSL ? "https" : "http"}://${
meta.objectStorageEndpoint
}${meta.objectStoragePort ? `:${meta.objectStoragePort}` : ""}/${
meta.objectStorageBucket
}`;
}${meta.objectStoragePort ? `:${meta.objectStoragePort}` : ""}`,
);
// for original
const key = `${meta.objectStoragePrefix}/${uuid()}${ext}`;
const url = `${baseUrl}/${key}`;
const key = urlPathJoin([meta.objectStoragePrefix, `${uuid()}${ext}`]);
const url = urlPathJoin(baseUrl, [key]);
// for alts
let webpublicKey: string | null = null;
@ -101,10 +126,11 @@ async function save(
const uploads = [upload(key, fs.createReadStream(path), type, name)];
if (alts.webpublic) {
webpublicKey = `${meta.objectStoragePrefix}/webpublic-${uuid()}.${
alts.webpublic.ext
}`;
webpublicUrl = `${baseUrl}/${webpublicKey}`;
webpublicKey = urlPathJoin([
meta.objectStoragePrefix,
`webpublic-${uuid()}.${alts.webpublic.ext}`,
]);
webpublicUrl = urlPathJoin(baseUrl, [webpublicKey]);
logger.info(`uploading webpublic: ${webpublicKey}`);
uploads.push(
@ -113,10 +139,11 @@ async function save(
}
if (alts.thumbnail) {
thumbnailKey = `${meta.objectStoragePrefix}/thumbnail-${uuid()}.${
alts.thumbnail.ext
}`;
thumbnailUrl = `${baseUrl}/${thumbnailKey}`;
thumbnailKey = urlPathJoin([
meta.objectStoragePrefix,
`thumbnail-${uuid()}.${alts.thumbnail.ext}`,
]);
thumbnailUrl = urlPathJoin(baseUrl, [thumbnailKey]);
logger.info(`uploading thumbnail: ${thumbnailKey}`);
uploads.push(

View File

@ -1,4 +1,5 @@
import * as fs from "node:fs";
import * as fsPromises from "node:fs/promises";
import * as Path from "node:path";
import { fileURLToPath } from "node:url";
import { dirname } from "node:path";
@ -13,6 +14,10 @@ export class InternalStorage {
public static resolvePath = (key: string) =>
Path.resolve(InternalStorage.path, key);
public static open(key: string, flags: string) {
return fsPromises.open(InternalStorage.resolvePath(key), flags);
}
public static read(key: string) {
return fs.createReadStream(InternalStorage.resolvePath(key));
}

View File

@ -11,17 +11,23 @@ export function getS3(meta: Meta) {
}`
: `${meta.objectStorageUseSSL ? "https://" : "http://"}example.net`;
return new S3({
endpoint: meta.objectStorageEndpoint || undefined,
accessKeyId: meta.objectStorageAccessKey!,
secretAccessKey: meta.objectStorageSecretKey!,
region: meta.objectStorageRegion || undefined,
sslEnabled: meta.objectStorageUseSSL,
s3ForcePathStyle: !meta.objectStorageEndpoint // AWS with endPoint omitted
? false
: meta.objectStorageS3ForcePathStyle,
httpOptions: {
agent: getAgentByUrl(new URL(u), !meta.objectStorageUseProxy),
},
});
try {
return new S3({
endpoint: meta.objectStorageEndpoint || undefined,
accessKeyId: meta.objectStorageAccessKey!,
secretAccessKey: meta.objectStorageSecretKey!,
region: meta.objectStorageRegion || undefined,
sslEnabled: meta.objectStorageUseSSL,
s3ForcePathStyle: !meta.objectStorageEndpoint // AWS with endPoint omitted
? false
: meta.objectStorageS3ForcePathStyle,
httpOptions: {
agent: getAgentByUrl(new URL(u), !meta.objectStorageUseProxy),
},
});
} catch (e) {
throw new Error(
`Failed to construct S3 client, assembled S3 URL: ${u}\n${e}`,
);
}
}

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