Merge branch firefish:develop into fix/10404-object-storage-prefix

This commit is contained in:
yumeko 2023-07-27 09:53:16 +00:00
commit a4838c7ee4
101 changed files with 3276 additions and 1934 deletions

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

View File

@ -1,6 +1,25 @@
# Changelog
All changes from v13.0.0 onwards, for a list of differences read FIREFISH.md
## [1.0.3] - 2023-07-21
### Bug Fixes
- Fix: :bento: fix old favicon
- Fix: :bento: asset versioning, screenshots
- Fix: :adhesive_bandage: version manifest assets based on instance version
### Refactor
- Refactor: :recycle: create drive file endpoint
Adjusts ratelimit to 250 files every 10 minutes, fixes error text, fixes reused variable name.
- Refactor: sticky-container class
- Refactor: :recycle: new git repo
## [1.0.0] - 2023-07-19
@ -14979,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

@ -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

@ -40,7 +40,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>

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

@ -4,7 +4,6 @@
# changelog header
header = """
# Changelog\n
All changes from v13.0.0 onwards, for a list of differences read FIREFISH.md\n
"""
# template for the changelog body
# https://tera.netlify.app/docs/#introduction

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

@ -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,7 +1343,7 @@ 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
@ -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...
@ -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,4 @@ _feeds:
atom: Atom
jsonFeed: Feed JSON
copyFeed: Copiar feed
origin: Origen

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"
@ -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,11 +947,12 @@ 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."
requireAdminForView: "Du musst dich mit einem Administratorkonto anmelden um dies
zu sehen."
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."
@ -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
@ -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:
@ -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,30 @@ 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

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"
@ -938,7 +938,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"
@ -1125,6 +1125,7 @@ removeQuote: "Remove quote"
removeRecipient: "Remove recipient"
removeMember: "Remove member"
verifiedLink: "Verified link"
origin: "Origin"
_sensitiveMediaDetection:
description: "Reduces the effort of server moderation through automatically recognizing

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"

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.

View File

@ -1,6 +1,6 @@
_lang_: "Français"
headlineMisskey: "Réseau relié par des notes"
introMisskey: "Bienvenue ! Firefish est un service de microblogage décentralisé, libre
headlineFirefish: "Réseau relié par des notes"
introFirefish: "Bienvenue ! Firefish est un service de microblogage décentralisé, libre
et ouvert.\nÉcrivez des « notes » et partagez ce qui se passe à linstant présent,
autour de vous avec les autres 📡\nLa fonction « réactions », vous permet également
dajouter une réaction rapide aux notes des autres utilisateur·rice·s 👍\nExplorons

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: "壁紙"
@ -854,7 +854,7 @@ unmuteThread: "スレッドのミュートを解除"
ffVisibility: "つながりの公開範囲"
ffVisibilityDescription: "自分のフォロー/フォロワー情報の公開範囲を設定できます。"
continueThread: "さらにスレッドを見る"
deleteAccountConfirm: "アカウントが削除されます。よろしいですか?"
deleteAccountConfirm: "このアカウントが削除されます。よろしいですか?"
incorrectPassword: "パスワードが間違っています。"
voteConfirm: "「{choice}」に投票しますか?"
hide: "隠す"
@ -1074,6 +1074,7 @@ _aboutFirefish:
pleaseDonateToHost: また、このサーバー {host} の運営者への寄付もご検討ください。
donateHost: '{host} に寄付する'
donateTitle: Firefishを気に入りましたか
sponsors: Firefish の支援者
_nsfw:
respect: "閲覧注意のメディアは隠す"
ignore: "閲覧注意のメディアを隠さない"
@ -1959,8 +1960,9 @@ donationLink: 寄付ページへのリンク
removeMember: メンバーを削除
removeQuote: 引用を削除
removeRecipient: 宛先を削除
verifiedLink: 認証済みリンク
_feeds:
copyFeed: "フィードのURLをコピー"
rss: "RSS"
atom: "Atom"
jsonFeed: "JSONフィード"
atom: Atom
rss: RSS
jsonFeed: JSONフィード
copyFeed: フィードのURLをコピー

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

@ -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.

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,7 @@
---
_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: "Ett nätverk kopplat av noter"
introFirefish: "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!🚀"
monthAndDay: "{day}/{month}"
search: "Sök"
notifications: "Notifikationer"

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"
@ -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,7 +257,8 @@ 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"
@ -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: "Tường"
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,7 +837,8 @@ 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"
@ -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ụ"
@ -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: "隐藏"
@ -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-dev2",
"codename": "aqua",
"repository": {
"type": "git",

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

@ -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(

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

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

@ -106,8 +106,7 @@ export default define(meta, paramDef, async (ps, user) => {
generateMutedUserQuery(query, user);
generateBlockedUserQuery(query, user);
const notes = await query.getMany();
notes.sort((a, b) => (a.id > b.id ? -1 : 1));
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

@ -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

@ -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,6 +32,8 @@ 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;
}
@ -68,7 +70,7 @@ 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.emoji_reactions = status.mentions.map(convertReaction);
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,13 @@ 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,
},
},
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

@ -48,7 +48,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 +367,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

@ -114,24 +114,48 @@ const router = new Router();
//#region static assets
router.get("/static-assets/(.*)", async (ctx) => {
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) => {
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) => {
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

@ -115,6 +115,10 @@ export default class Logger {
console.log(important ? chalk.bold(log) : log);
if (level === "error" && data !== null) {
console.log(data);
}
if (store) {
if (this.syslogClient) {
const send =

View File

@ -1068,6 +1068,8 @@ onMounted(() => {
position: absolute;
top: 0;
right: 0;
display: flex;
align-items: center;
> .text-count {
opacity: 0.7;
@ -1082,6 +1084,10 @@ onMounted(() => {
& + .localOnly {
margin-left: 0 !important;
}
> span:only-child > i {
display: block;
}
}
> .local-only {
@ -1093,7 +1099,7 @@ onMounted(() => {
display: inline-block;
padding: 0;
margin: 0 8px 0 0;
font-size: 16px;
font-size: inherit !important;
width: 34px;
height: 34px;
border-radius: 6px;

View File

@ -6,6 +6,7 @@
>
<svg
v-if="defaultStore.state.woozyMode === true"
style="transform: translateY(2px);"
width="1.1em"
height="1.1em"
viewBox="0 0 36 36"
@ -13,6 +14,8 @@
<g fill="currentColor">
<path
d="m17.809-0.20898c-9.9294 2.3e-7 -18 8.0706-18 18 5.8e-7 9.9294 8.0706 18 18 18 9.9294 0 18-8.0706 18-18 0-9.9294-8.0706-18-18-18zm0 1.9785c8.8604 1e-7 16.021 7.1611 16.021 16.021 0 8.8604-7.1611 16.023-16.021 16.023-8.8604 0-16.021-7.163-16.021-16.023-3e-7 -8.8604 7.1611-16.021 16.021-16.021z"
stroke="currentColor"
stroke-width="2"
/>
<path
d="m6.001 11c-0.552 0-1-0.448-1-1 0-0.551 0.445-0.998 0.996-1 0.156-2e-3 3.569-0.086 6.205-3.6 0.331-0.44 0.957-0.532 1.4-0.2 0.442 0.331 0.531 0.958 0.2 1.4-3.263 4.35-7.617 4.4-7.801 4.4zm24.986 2.393c0.128 0.537-0.204 1.077-0.741 1.205-0.536 0.128-1.074-0.202-1.204-0.737-0.038-0.151-0.911-3.452-4.941-5.201-0.505-0.22-0.739-0.808-0.519-1.315s0.809-0.739 1.315-0.519c4.989 2.165 6.047 6.388 6.09 6.567z"

View File

@ -5,7 +5,7 @@
$style.root,
{ yellow: user.isSilenced, red: user.isSuspended, gray: false },
]"
:to="userPage(user)"
:to="props.showAboutPage ? `/user-info/${user.id}` : userPage(user)"
>
<MkAvatar
class="avatar"
@ -33,9 +33,11 @@ const props = withDefaults(
defineProps<{
user: misskey.entities.User;
withChart?: boolean;
showAboutPage?: boolean;
}>(),
{
withChart: true,
showAboutPage: false,
},
);
@ -99,6 +101,12 @@ if (props.withChart) {
overflow: hidden;
text-overflow: ellipsis;
}
// > :global(.moderation) {
// display: flex;
// gap: 1rem;
// margin-right: 1rem;
// }
}
> :global(.chart) {

View File

@ -84,7 +84,7 @@ function tick() {
if (
!invalid &&
props.origin === null &&
!props.origin &&
(props.mode === "relative" || props.mode === "detail")
) {
onMounted(() => {

View File

@ -5,10 +5,6 @@ import * as os from "@/os";
import { i18n } from "@/i18n";
import { ui } from "@/config";
import { unisonReload } from "@/scripts/unison-reload";
import { defaultStore } from "@/store";
import { instance } from "@/instance";
import { host } from "@/config";
import XTutorial from "@/components/MkTutorialDialog.vue";
export const navbarItemDef = reactive({
notifications: {
@ -60,14 +56,6 @@ export const navbarItemDef = reactive({
show: computed(() => $i != null),
to: "/my/lists",
},
/*
groups: {
title: 'groups',
icon: 'ph-users-three ph-bold ph-lg',
show: computed(() => $i != null),
to: '/my/groups',
},
*/
antennas: {
title: "antennas",
icon: "ph-flying-saucer ph-bold ph-lg",

View File

@ -34,11 +34,7 @@
<div class="content">
<img
ref="instanceIcon"
:src="
$instance.iconUrl ||
$instance.faviconUrl ||
'/favicon.ico'
"
:src="iconSrc"
aria-label="none"
class="icon"
:class="instanceIconAnimation"
@ -211,8 +207,9 @@ withDefaults(
let stats = $ref(null);
let instanceIcon = $ref<HTMLImageElement>();
let instanceIconAnimation = "none";
let iconClicks = 0;
let iconSrc = ref(instance.iconUrl || instance.faviconUrl || "/favicon.ico");
let instanceIconAnimation = ref("");
let tabs = ["overview", "emojis", "charts"];
let tab = $ref(tabs[0]);
watch($$(tab), () => syncSlide(tabs.indexOf(tab)));
@ -261,38 +258,43 @@ definePageMetadata(
})),
);
async function sleep(seconds) {
return new Promise((resolve) => setTimeout(resolve, seconds * 1000));
}
onMounted(() => {
if (defaultStore.state.woozyMode) {
instanceIcon.src = "/static-assets/woozy.png";
if (defaultStore.state.woozyMode === true) {
iconSrc.value = "/static-assets/woozy.png";
instanceIcon.src = iconSrc.value;
}
});
function easterEgg() {
iconClicks++;
instanceIconAnimation = "noAnimation";
console.log(instanceIconAnimation);
sleep(0.1);
const normalizedCount = (iconClicks % 3) + 1;
instanceIconAnimation = `shake${normalizedCount}`;
if (iconClicks % 3 === 0) {
defaultStore.state.woozyMode = !defaultStore.state.woozyMode;
sleep(0.4);
instanceIconAnimation = "noAnimation";
instanceIconAnimation = "doSpinY";
console.log(instanceIconAnimation);
defaultStore.set("woozyMode", defaultStore.state.woozyMode);
if (instanceIcon) {
instanceIconAnimation.value = "spin";
setTimeout(() => {
if (iconClicks % 6 === 0) {
instanceIcon.src =
instance.iconUrl || instance.faviconUrl || "/favicon.ico";
iconSrc.value =
instance.iconUrl ||
instance.faviconUrl ||
"/favicon.ico";
} else {
instanceIcon.src = "/static-assets/woozy.png";
iconSrc.value = "/static-assets/woozy.png";
}
instanceIcon.src = iconSrc.value;
}, 500);
}
}
}
watch(iconSrc, (newValue, oldValue) => {
if (newValue !== oldValue) {
setTimeout(() => {
instanceIconAnimation.value = "";
}, 500);
}
});
let swiperRef = null;
function setSwiperRef(swiper) {
@ -310,123 +312,6 @@ function syncSlide(index) {
</script>
<style lang="scss" scoped>
@keyframes iconShake1 {
0% {
transform: translate(2px, 0px) rotate(-1deg);
}
10% {
transform: translate(2px, -3px) rotate(5deg);
}
20% {
transform: translate(-1px, -3px) rotate(3deg);
}
30% {
transform: translate(-2px, 0px) rotate(-1deg);
}
40% {
transform: translate(-2px, -1px) rotate(4deg);
}
50% {
transform: translate(-1px, -1px) rotate(1deg);
}
60% {
transform: translate(-2px, 0px) rotate(-8deg);
}
70% {
transform: translate(1px, 2px) rotate(-2deg);
}
80% {
transform: translate(-1px, 2px) rotate(4deg);
}
90% {
transform: translate(-1px, 1px) rotate(11deg);
}
100% {
transform: translate(-3px, -3px) rotate(-5deg);
}
}
@keyframes iconShake2 {
0% {
transform: translate(-1px, 5px) rotate(33deg);
}
10% {
transform: translate(-2px, 7px) rotate(20deg);
}
20% {
transform: translate(8px, 5px) rotate(31deg);
}
30% {
transform: translate(-2px, 5px) rotate(3deg);
}
40% {
transform: translate(4px, 6px) rotate(16deg);
}
50% {
transform: translate(8px, -3px) rotate(19deg);
}
60% {
transform: translate(7px, -2px) rotate(0deg);
}
70% {
transform: translate(4px, 4px) rotate(8deg);
}
80% {
transform: translate(7px, -3px) rotate(13deg);
}
90% {
transform: translate(6px, 7px) rotate(4deg);
}
100% {
transform: translate(4px, -2px) rotate(-2deg);
}
}
@keyframes iconShake3 {
0% {
transform: translate(12px, -2px) rotate(57deg);
}
10% {
transform: translate(10px, 2px) rotate(12deg);
}
20% {
transform: translate(10px, 4px) rotate(3deg);
}
30% {
transform: translate(17px, 11px) rotate(15deg);
}
40% {
transform: translate(12px, 20px) rotate(-11deg);
}
50% {
transform: translate(5px, 12px) rotate(43deg);
}
60% {
transform: translate(16px, 8px) rotate(-4deg);
}
70% {
transform: translate(14px, 11px) rotate(22deg);
}
80% {
transform: translate(9px, 19px) rotate(-3deg);
}
90% {
transform: translate(0px, 12px) rotate(-3deg);
}
100% {
transform: translate(17px, 3px) rotate(57deg);
}
}
@keyframes spinY {
0% {
transform: perspective(128px) rotateY(0deg);
}
100% {
transform: perspective(128px) rotateY(360deg);
}
}
.fwhjspax {
text-align: center;
border-radius: 10px;
@ -441,27 +326,10 @@ function syncSlide(index) {
display: block;
margin: 16px auto 0 auto;
height: 64px;
border-radius: 8px;
&.noAnimation {
animation: none;
}
&.shake1 {
animation: iconShake1 0.1s 1;
}
&.shake2 {
animation: iconShake2 0.2s 1;
}
&.shake3 {
animation: iconShake3 0.3s 1;
}
&.doSpinY {
animation: spinY 0.9s 1;
}
> .spin {
animation: spinY 1s linear infinite;
}
> .name {

View File

@ -478,7 +478,6 @@ defineExpose({
display: block;
margin: auto;
height: 42px;
border-radius: 8px;
}
}
}

View File

@ -84,8 +84,8 @@ const diskAvailable = $computed(() => meta.fs.total - meta.fs.used);
function onStats(stats) {
cpuUsage = stats.cpu;
memUsage = stats.mem.active / meta.mem.total;
memTotal = meta.mem.total;
memUsage = stats.mem.active / stats.mem.total;
memTotal = stats.mem.total;
memUsed = stats.mem.active;
memFree = memTotal - memUsed;

View File

@ -100,19 +100,20 @@
:pagination="pagination"
class="users"
>
<MkA
<MkUserCardMini
v-for="user in items"
:key="user.id"
v-tooltip.mfm="
`Last posted: ${new Date(
user.updatedAt
? `Last posted: ${new Date(
user.updatedAt,
).toLocaleString()}`
: 'Never posted'
"
class="user"
:to="`/user-info/${user.id}`"
>
<MkUserCardMini :user="user" />
</MkA>
:user="user"
:show-about-page="true"
/>
</MkPagination>
</div>
</div>

View File

@ -128,7 +128,7 @@
<MkFolder class="_gap">
<template #header
><i
class="ph-rocke-launch ph-bold ph-lg ph-fw"
class="ph-rocket-launch ph-bold ph-lg ph-fw"
style="margin-right: 0.5em"
></i
>{{ i18n.ts.recentlyDiscoveredUsers }}</template

View File

@ -8,7 +8,8 @@
<template #caption>
<I18n :src="i18n.ts.i18nInfo" tag="span">
<template #link>
<MkLink url="https://hosted.weblate.org/engage/firefish/"
<MkLink
url="https://hosted.weblate.org/engage/firefish/"
>Weblate</MkLink
>
</template>

View File

@ -1,13 +1,44 @@
<template>
<div class="_formRoot">
<FormTextarea v-model="items" tall manual-save class="_formBlock">
<template #label>{{ i18n.ts.navbar }}</template>
<template #caption
><button class="_textButton" @click="addItem">
{{ i18n.ts.addItem }}
</button></template
<FormSlot>
<VueDraggable v-model="items" animation="150" delay="50">
<div
v-for="(element, index) in items"
:key="index"
class="item"
>
</FormTextarea>
<i class="itemHandle ph-list ph-bold ph-lg"></i>
<i
:class="
navbarItemDef[element]?.icon ??
'ph-arrows-out-line-vertical ph-bold ph-lg'
"
></i>
<span class="itemText">{{
i18n.ts[navbarItemDef[element]?.title] ??
i18n.ts.divider
}}</span>
<button
class="_button itemRemove"
@click="removeItem(index)"
>
<i class="ph-x ph-bold ph-lg"></i>
</button>
</div>
</VueDraggable>
<FormSection>
<div style="display: flex; gap: var(--margin); flex-wrap: wrap">
<FormButton primary @click="addItem">
<i class="ph-plus ph-bold ph-lg"></i>
{{ i18n.ts.addItem }}
</FormButton>
<FormButton @click="reloadAsk">
<i class="ph-floppy-disk-back ph-bold ph-lg"></i>
{{ i18n.ts.apply }}
</FormButton>
</div>
</FormSection>
</FormSlot>
<FormRadios v-model="menuDisplay" class="_formBlock">
<template #label>{{ i18n.ts.display }}</template>
@ -31,24 +62,20 @@
<script lang="ts" setup>
import { computed, ref, watch } from "vue";
import FormTextarea from "@/components/form/textarea.vue";
import FormSlot from "@/components/form/slot.vue";
import FormRadios from "@/components/form/radios.vue";
import FormButton from "@/components/MkButton.vue";
import FormSection from "@/components/form/section.vue";
import * as os from "@/os";
import { navbarItemDef } from "@/navbar";
import { defaultStore } from "@/store";
import { unisonReload } from "@/scripts/unison-reload";
import { i18n } from "@/i18n";
import { VueDraggable } from "vue-draggable-plus";
import { definePageMetadata } from "@/scripts/page-metadata";
const items = ref(defaultStore.state.menu.join("\n"));
const items = ref(defaultStore.state.menu);
const split = computed(() =>
items.value
.trim()
.split("\n")
.filter((x) => x.trim() !== ""),
);
const menuDisplay = computed(defaultStore.makeGetterSetter("menuDisplay"));
async function reloadAsk() {
@ -79,17 +106,20 @@ async function addItem() {
],
});
if (canceled) return;
items.value = [...split.value, item].join("\n");
items.value = [...items.value, item];
}
async function removeItem(index) {
items.value = items.value.filter((_, i) => i !== index);
}
async function save() {
defaultStore.set("menu", split.value);
await reloadAsk();
defaultStore.set("menu", items.value);
}
function reset() {
defaultStore.reset("menu");
items.value = defaultStore.state.menu.join("\n");
items.value = defaultStore.state.menu;
}
watch(items, async () => {
@ -109,3 +139,47 @@ definePageMetadata({
icon: "ph-list-bullets ph-bold ph-lg",
});
</script>
<style lang="scss" scoped>
.item {
position: relative;
display: block;
line-height: 2.85rem;
text-overflow: ellipsis;
overflow: hidden;
white-space: nowrap;
border-radius: var(--radius);
margin-bottom: 0.5rem;
color: var(--navFg);
background-color: var(--panel);
> .itemIcon {
position: relative;
}
> .itemText {
position: relative;
font-size: 0.9em;
margin-left: 1rem;
}
> .itemRemove {
position: absolute;
z-index: 10000;
width: 32px;
height: 32px;
color: var(--error);
top: 4px;
right: 8px;
opacity: 0.8;
}
> .itemHandle {
cursor: move;
width: 32px;
height: 32px;
margin: 0 1rem;
opacity: 0.5;
}
}
</style>

View File

@ -363,11 +363,11 @@
>
<template v-if="narrow">
<XPhotos :key="user.id" :user="user" />
<XActivity
<!-- <XActivity
:key="user.id"
:user="user"
style="margin-top: var(--margin)"
/>
/> -->
</template>
</div>
<div>
@ -387,7 +387,7 @@
</template>
<script lang="ts" setup>
import { defineAsyncComponent, onMounted, onUnmounted } from "vue";
import { ref, defineAsyncComponent, onMounted, onUnmounted } from "vue";
import calcAge from "s-age";
import cityTimezones from "city-timezones";
import XUserTimeline from "./index.timeline.vue";
@ -422,6 +422,7 @@ let parallaxAnimationId = $ref<null | number>(null);
let narrow = $ref<null | boolean>(null);
let rootEl = $ref<null | HTMLElement>(null);
let bannerEl = $ref<null | HTMLElement>(null);
let patrons = ref([]);
const age = $computed(() => {
return calcAge(props.user.birthday);
@ -467,9 +468,8 @@ const timeForThem = $computed(() => {
return "";
});
let patrons = [];
const patronsResp = await os.api("patrons");
patrons = patronsResp.patrons;
patrons.value = patronsResp.patrons;
function parallaxLoop() {
parallaxAnimationId = window.requestAnimationFrame(parallaxLoop);

View File

@ -45,7 +45,9 @@
<div class="about">
<div
class="desc"
v-html="meta.description || i18n.ts.headlineMisskey"
v-html="
meta.description || i18n.ts.headlineFirefish
"
></div>
</div>
<div class="action">
@ -296,7 +298,6 @@ function showMenu(ev) {
> .icon {
width: 85px;
margin-top: -47px;
border-radius: 100%;
vertical-align: bottom;
}

View File

@ -15,7 +15,7 @@
<div class="about">
<div
class="desc"
v-html="meta.description || i18n.ts.headlineMisskey"
v-html="meta.description || i18n.ts.headlineFirefish"
></div>
</div>
<div class="action">

View File

@ -30,7 +30,7 @@
<div
class="desc"
v-html="
meta.description || i18n.ts.headlineMisskey
meta.description || i18n.ts.headlineFirefish
"
></div>
</div>

View File

@ -361,7 +361,7 @@ export function getNoteMenu(props: {
appearNote.url || appearNote.uri
? {
icon: "ph-link-simple ph-bold ph-lg",
text: `${i18n.ts.copyLink} (${i18n.ts.remote})`,
text: `${i18n.ts.copyLink} (${i18n.ts.origin})`,
action: copyOriginal,
}
: undefined,
@ -420,6 +420,7 @@ export function getNoteMenu(props: {
? {
icon: "ph-eraser ph-bold ph-lg",
text: i18n.ts.deleteAndEdit,
danger: true,
action: delEdit,
}
: undefined,
@ -465,7 +466,7 @@ export function getNoteMenu(props: {
appearNote.url || appearNote.uri
? {
icon: "ph-link-simple ph-bold ph-lg",
text: `${i18n.ts.copyLink} (${i18n.ts.remote})`,
text: `${i18n.ts.copyLink} (${i18n.ts.origin})`,
action: copyOriginal,
}
: undefined,

View File

@ -625,7 +625,6 @@ hr {
vertical-align: bottom;
height: 128px;
margin-bottom: 16px;
border-radius: 16px;
}
}
@ -825,6 +824,15 @@ hr {
}
}
@keyframes spinY {
0% {
transform: perspective(128px) rotateY(0deg);
}
100% {
transform: perspective(128px) rotateY(360deg);
}
}
.ph-xxs {
font-size: 0.5em;
}

View File

@ -16,7 +16,7 @@
<div v-if="meta" class="about">
<div
class="desc"
v-html="meta.description || i18n.ts.introMisskey"
v-html="meta.description || i18n.ts.introFirefish"
></div>
</div>
<div class="action">

View File

@ -26,7 +26,7 @@
<div v-if="meta" class="about">
<div
class="desc"
v-html="meta.description || i18n.ts.introMisskey"
v-html="meta.description || i18n.ts.introFirefish"
></div>
</div>
<div class="action">

View File

@ -131,7 +131,7 @@ function onStats(connStats) {
]);
const memPolylinePointsStats = stats.map((s, i) => [
viewBoxX - (stats.length - 1 - i),
(1 - s.mem.active / props.meta.mem.total) * viewBoxY,
(1 - s.mem.active / s.mem.total) * viewBoxY,
]);
cpuPolylinePoints = cpuPolylinePointsStats
.map((xy) => `${xy[0]},${xy[1]}`)
@ -153,7 +153,7 @@ function onStats(connStats) {
memHeadY = memPolylinePointsStats[memPolylinePointsStats.length - 1][1];
cpuP = (connStats.cpu * 100).toFixed(0);
memP = ((connStats.mem.active / props.meta.mem.total) * 100).toFixed(0);
memP = ((connStats.mem.active / connStats.mem.total) * 100).toFixed(0);
}
function onStatsLog(statsLog) {

View File

@ -12,7 +12,15 @@
<i class="ph-sort-ascending ph-bold ph-lg"></i></button
></template>
<div v-if="meta" class="mkw-serverMetric">
<div v-if="!instance.enableServerMachineStats" class="mkw-serverMetric">
<h3 style="text-align: center; color: var(--error)">
{{ i18n.ts.disabled }}
</h3>
</div>
<div
v-else-if="meta && instance.enableServerMachineStats"
class="mkw-serverMetric"
>
<XCpuMemory
v-if="widgetProps.view === 0"
:connection="connection"

View File

@ -26,8 +26,8 @@ let usage: number = $ref(0),
free: number = $ref(0);
function onStats(stats) {
usage = stats.mem.active / props.meta.mem.total;
total = props.meta.mem.total;
usage = stats.mem.active / stats.mem.total;
total = stats.mem.total;
used = stats.mem.active;
free = total - used;
}

View File

@ -7,7 +7,7 @@ namespace Entity {
created_at: string;
id: string;
status?: Status;
emoji?: string;
reaction?: Reaction;
type: NotificationType;
};

View File

@ -6,6 +6,7 @@ namespace Entity {
me: boolean;
name: string;
url?: string;
static_url?: string;
accounts?: Array<Account>;
};
}

View File

@ -38,7 +38,7 @@ namespace Entity {
application: Application | null;
language: string | null;
pinned: boolean | null;
emoji_reactions: Array<Reaction>;
reactions: Array<Reaction>;
quote: Status | null;
bookmarked: boolean;
};

View File

@ -857,6 +857,21 @@ export interface MegalodonInterface {
* @return Status
*/
unpinStatus(id: string): Promise<Response<Entity.Status>>;
/**
* POST /api/v1/statuses/:id/react/:name
* @param id The target status id.
* @param name The name of the emoji reaction to add.
* @return Status
*/
reactStatus(id: string, name: string): Promise<Response<Entity.Status>>;
/**
* POST /api/v1/statuses/:id/unreact/:name
*
* @param id The target status id.
* @param name The name of the emoji reaction to remove.
* @return Status
*/
unreactStatus(id: string, name: string): Promise<Response<Entity.Status>>;
// ======================================
// statuses/media
// ======================================

View File

@ -2009,6 +2009,63 @@ export default class Misskey implements MegalodonInterface {
}));
}
/**
* Convert a Unicode emoji or custom emoji name to a Misskey reaction.
* @see Misskey's reaction-lib.ts
*/
private reactionName(name: string): string {
// See: https://github.com/tc39/proposal-regexp-unicode-property-escapes#matching-emoji
const isUnicodeEmoji = /\p{Emoji_Modifier_Base}\p{Emoji_Modifier}?|\p{Emoji_Presentation}|\p{Emoji}\uFE0F/gu.test(name);
if (isUnicodeEmoji) {
return name;
}
return `:${name}:`;
}
/**
* POST /api/notes/reactions/create
*/
public async reactStatus(id: string, name: string): Promise<Response<Entity.Status>> {
await this.client.post<{}>("/api/notes/reactions/create", {
noteId: id,
reaction: this.reactionName(name),
});
return this.client
.post<MisskeyAPI.Entity.Note>("/api/notes/show", {
noteId: id,
})
.then(async (res) => ({
...res,
data: await this.noteWithDetails(
res.data,
this.baseUrlToHost(this.baseUrl),
this.getFreshAccountCache(),
),
}));
}
/**
* POST /api/notes/reactions/delete
*/
public async unreactStatus(id: string, name: string): Promise<Response<Entity.Status>> {
await this.client.post<{}>("/api/notes/reactions/delete", {
noteId: id,
reaction: this.reactionName(name),
});
return this.client
.post<MisskeyAPI.Entity.Note>("/api/notes/show", {
noteId: id,
})
.then(async (res) => ({
...res,
data: await this.noteWithDetails(
res.data,
this.baseUrlToHost(this.baseUrl),
this.getFreshAccountCache(),
),
}));
}
// ======================================
// statuses/media
// ======================================

View File

@ -321,7 +321,10 @@ namespace MisskeyAPI {
content: n.text ? this.escapeMFM(n.text) : "",
plain_content: n.text ? n.text : null,
created_at: n.createdAt,
emojis: n.emojis.map((e) => this.emoji(e)),
// Remove reaction emojis with names containing @ from the emojis list.
emojis: n.emojis
.filter((e) => e.name.indexOf("@") === -1)
.map((e) => this.emoji(e)),
replies_count: n.repliesCount,
reblogs_count: n.renoteCount,
favourites_count: this.getTotalReactions(n.reactions),
@ -339,28 +342,36 @@ namespace MisskeyAPI {
application: null,
language: null,
pinned: null,
emoji_reactions: this.mapReactions(n.reactions, n.myReaction),
// Use emojis list to provide URLs for emoji reactions.
reactions: this.mapReactions(n.emojis, n.reactions, n.myReaction),
bookmarked: false,
quote: n.renote && n.text ? this.note(n.renote, host) : null,
};
};
mapReactions = (
emojis: Array<MisskeyEntity.Emoji>,
r: { [key: string]: number },
myReaction?: string,
): Array<MegalodonEntity.Reaction> => {
// Map of emoji shortcodes to image URLs.
const emojiUrls = new Map<string, string>(
emojis.map((e) => [e.name, e.url]),
);
return Object.keys(r).map((key) => {
if (myReaction && key === myReaction) {
// Strip colons from custom emoji reaction names to match emoji shortcodes.
const shortcode = key.replaceAll(":", "");
// If this is a custom emoji (vs. a Unicode emoji), find its image URL.
const url = emojiUrls.get(shortcode);
// Finally, remove trailing @. from local custom emoji reaction names.
const name = shortcode.replace("@.", "");
return {
count: r[key],
me: true,
name: key,
};
}
return {
count: r[key],
me: false,
name: key,
me: key === myReaction,
name,
url,
// We don't actually have a static version of the asset, but clients expect one anyway.
static_url: url,
};
});
};
@ -422,7 +433,7 @@ namespace MisskeyAPI {
case NotificationType.Mention:
return MisskeyNotificationType.Reply;
case NotificationType.Favourite:
case NotificationType.EmojiReaction:
case NotificationType.Reaction:
return MisskeyNotificationType.Reaction;
case NotificationType.Reblog:
return MisskeyNotificationType.Renote;
@ -448,7 +459,7 @@ namespace MisskeyAPI {
case MisskeyNotificationType.Quote:
return NotificationType.Reblog;
case MisskeyNotificationType.Reaction:
return NotificationType.EmojiReaction;
return NotificationType.Reaction;
case MisskeyNotificationType.PollEnded:
return NotificationType.Poll;
case MisskeyNotificationType.ReceiveFollowRequest:
@ -496,12 +507,12 @@ namespace MisskeyAPI {
account: this.note(n.note, host).account,
});
}
}
if (n.reaction) {
notification = Object.assign(notification, {
emoji: n.reaction,
reaction: this.mapReactions(n.note.emojis, { [n.reaction]: 1 })[0],
});
}
}
return notification;
};

View File

@ -5,7 +5,7 @@ namespace NotificationType {
export const Favourite: Entity.NotificationType = "favourite";
export const Reblog: Entity.NotificationType = "reblog";
export const Mention: Entity.NotificationType = "mention";
export const EmojiReaction: Entity.NotificationType = "emoji_reaction";
export const Reaction: Entity.NotificationType = "reaction";
export const FollowRequest: Entity.NotificationType = "follow_request";
export const Status: Entity.NotificationType = "status";
export const Poll: Entity.NotificationType = "poll";

View File

@ -163,7 +163,7 @@ describe('getNotifications', () => {
},
{
event: reaction,
expected: MegalodonNotificationType.EmojiReaction,
expected: MegalodonNotificationType.Reaction,
title: 'reaction'
},
{

View File

@ -34,7 +34,7 @@ describe('api_client', () => {
dist: MisskeyNotificationType.Reaction
},
{
src: MegalodonNotificationType.EmojiReaction,
src: MegalodonNotificationType.Reaction,
dist: MisskeyNotificationType.Reaction
},
{
@ -80,7 +80,7 @@ describe('api_client', () => {
},
{
src: MisskeyNotificationType.Reaction,
dist: MegalodonNotificationType.EmojiReaction
dist: MegalodonNotificationType.Reaction
},
{
src: MisskeyNotificationType.PollEnded,

View File

@ -54,7 +54,7 @@ const status: Entity.Status = {
} as Entity.Application,
language: null,
pinned: null,
emoji_reactions: [],
reactions: [],
bookmarked: false,
quote: null
}

View File

@ -3,7 +3,7 @@
/* Basic Options */
"target": "es5", /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017','ES2018' or 'ESNEXT'. */
"module": "commonjs", /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', or 'ESNext'. */
"lib": ["es6", "dom"], /* Specify library files to be included in the compilation. */
"lib": ["es2021", "dom"], /* Specify library files to be included in the compilation. */
// "allowJs": true, /* Allow javascript files to be compiled. */
// "checkJs": true, /* Report errors in .js files. */
// "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */

View File

@ -1,13 +1,13 @@
{
"patrons": [
"@atomicpoet@firefish.social",
"@atomicpoet@calckey.social",
"@shoq@mastodon.social",
"@pikadude@erisly.social",
"@sage@stop.voring.me",
"@sky@therian.club",
"@panos@electricrequiem.com",
"@redhunt07@www.foxyhole.io",
"@griff@stop.voring.me",
"@griff@calckey.social",
"@cafkafk@ck.cafkafk.com",
"@privateger@plasmatrap.com",
"@effye@toot.thoughtworks.com",
@ -17,57 +17,56 @@
"@topher@mastodon.online",
"@hanicef@stop.voring.me",
"@nmkj@calckey.jp",
"@unattributed@firefish.social",
"@unattributed@calckey.social",
"@cody@misskey.codingneko.com",
"@kate@blahaj.zone",
"@emtk@mkkey.net",
"@jovikowi@firefish.social",
"@padraig@firefish.social",
"@jovikowi@calckey.social",
"@padraig@calckey.social",
"@pancakes@cats.city",
"@theresmiling@firefish.social",
"@AlderForrest@firefish.social",
"@kristian@firefish.social",
"@theresmiling@calckey.social",
"@kristian@calckey.social",
"@jo@blahaj.zone",
"@narF@firefish.social",
"@AlderForrest@firefish.social",
"@box464@firefish.social",
"@MariaTheMartian@firefish.social",
"@nisemikol@firefish.social",
"@narF@calckey.social",
"@AlderForrest@raining.anvil.top",
"@box464@calckey.social",
"@MariaTheMartian@calckey.social",
"@nisemikol@calckey.social",
"@smallpatatas@blahaj.zone",
"@bayra@stop.voring.me",
"@frost@wolfdo.gg",
"@joebiden@fuckgov.org",
"@nyaa@firefish.social",
"@Dan@firefish.social",
"@dana@firefish.social",
"@Jdreben@firefish.social",
"@nyaa@calckey.social",
"@Dan@calckey.social",
"@dana@calckey.social",
"@Jdreben@calckey.social",
"@natalie@prismst.one",
"@KelsonV@wandering.shop",
"@breakfastmtn@firefish.social",
"@breakfastmtn@calckey.social",
"@richardazia@mastodon.social",
"@joestone@firefish.social",
"@aj@firefish.social",
"@joestone@calckey.social",
"@aj@calckey.social",
"@zepfanman@ramblingreaders.org",
"@kimby@stop.voring.me",
"@fyrfli@bkgrdclrschm.link",
"@fyrfli@fyrfli.social",
"@riversidebryan@firefish.lgbt",
"@aRubes@sloth.run",
"@andreasdotorg@firefish.social",
"@andreasdotorg@calckey.social",
"@ozzy@calckey.online",
"@leni@windycity.style",
"@mhzmodels@calckey.art",
"@ReflexVE@firefish.social",
"@mark@firefish.social",
"@ReflexVE@calckey.social",
"@mark@calckey.social",
"@skyizwhite@himagine.club",
"@Uwu@firefish.social",
"@jGoose@firefish.social",
"@Uwu@calckey.social",
"@jGoose@calckey.social",
"@kunev@blewsky.social",
"@Simoto@electricrequiem.com",
"@Evoterra@firefish.social",
"@Evoterra@calckey.social",
"@LauraLangdon@procial.tchncs.de",
"@mho@social.heise.de",
"@richardazia@firefish.social",
"@blues653@firefish.social",
"@richardazia@calckey.social",
"@blues653@calckey.social",
"@rafale_blue@calc.04.si",
"@esm@lethallava.land",
"@vmstan@vmst.io",
@ -75,32 +74,44 @@
"@renere@distance.blue",
"@theking@kitsunes.club",
"@toof@fedi.toofie.net",
"@Punko@firefish.social",
"@joesbrat67@firefish.social",
"@arth@firefish.social",
"@Punko@calckey.social",
"@joesbrat67@calckey.social",
"@arth@calckey.social",
"@octofloofy@ck.octofloofy.ink",
"@pauliehedron@infosec.town",
"@soulthunk@lethallava.land",
"@bumble@ibe.social",
"@DarrenNevares@firefish.social",
"@irfan@firefish.social",
"@DarrenNevares@calckey.social",
"@irfan@calckey.social",
"@dvd@dvd.chat",
"@charlie2alpha@electricrequiem.com",
"@arndot@layer8.space",
"@ryan@c.ryanccn.dev",
"@lapastora_deprova@firefish.social",
"@rameez@firefish.social",
"@lapastora_deprova@calckey.social",
"@rameez@calckey.social",
"@dracoling@firetribe.org",
"@Space6host@firefish.social",
"@Space6host@calckey.social",
"@zakalwe@plasmatrap.com",
"@seasicksailor@firefish.social",
"@geerue@firefish.social",
"@seasicksailor@calckey.social",
"@geerue@calckey.social",
"@WXFanatic@m.ai6yr.org",
"@Hunkabilly@calckey.world"
"@Hunkabilly@calckey.world",
"@samleegray@calckey.social",
"@schwarzewald@kodow.net",
"@Conatusprinciple@calckey.social",
"@183231bcb@firefish.lgbt",
"@wiase@calckey.social",
"@leonieke@vitaulium.nl",
"@soulfire@wackywolf.xyz",
"@elbullazul@pub.elbullazul.com",
"@rafale_blue@calc.04.si",
"@firnin@federation.network",
"@clement@ck.villisek.fr",
"@hryggrbyr@ibe.social"
],
"sponsors": [
"@atomicpoet@firefish.social",
"@unattributed@firefish.social",
"@atomicpoet@calckey.social",
"@unattributed@calckey.social",
"@jtbennett@noc.social",
"\nInterkosmos Link"
]

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