Merge branch 'develop' into beta
This commit is contained in:
commit
b03bb28a98
166 changed files with 6351 additions and 2784 deletions
|
@ -34,7 +34,7 @@ port: 3000
|
|||
#───┘ PostgreSQL configuration └────────────────────────────────
|
||||
|
||||
db:
|
||||
host: database
|
||||
host: postgres
|
||||
port: 5432
|
||||
|
||||
# Database name
|
||||
|
|
|
@ -29,6 +29,10 @@ url: https://example.com/
|
|||
# The port that your Firefish server should listen on.
|
||||
port: 3000
|
||||
|
||||
# The bind host your Firefish server should listen on.
|
||||
# If unspecified, the wildcard address will be used.
|
||||
#bind: 127.0.0.1
|
||||
|
||||
# ┌──────────────────────────┐
|
||||
#───┘ PostgreSQL configuration └────────────────────────────────
|
||||
|
||||
|
|
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -1,6 +1,7 @@
|
|||
# Visual Studio Code
|
||||
/.vscode
|
||||
!/.vscode/extensions.json
|
||||
!/.vscode/launch.json
|
||||
|
||||
# Intelij-IDEA
|
||||
/.idea
|
||||
|
|
68
.gitlab-ci.yml
Normal file
68
.gitlab-ci.yml
Normal file
|
@ -0,0 +1,68 @@
|
|||
# This file is a template, and might need editing before it works on your project.
|
||||
# You can copy and paste this template into a new `.gitlab-ci.yml` file.
|
||||
# You should not add this template to an existing `.gitlab-ci.yml` file by using the `include:` keyword.
|
||||
#
|
||||
# To contribute improvements to CI/CD templates, please follow the Development guide at:
|
||||
# https://docs.gitlab.com/ee/development/cicd/templates.html
|
||||
# This specific template is located at:
|
||||
# https://gitlab.com/gitlab-org/gitlab/-/blob/master/lib/gitlab/ci/templates/Nodejs.gitlab-ci.yml
|
||||
|
||||
# Official framework image. Look for the different tagged releases at:
|
||||
# https://hub.docker.com/r/library/node/tags/
|
||||
image: node:alpine
|
||||
|
||||
stages:
|
||||
- build
|
||||
|
||||
# Pick zero or more services to be used on all builds.
|
||||
# Only needed when using a docker container to run your tests in.
|
||||
# Check out: https://docs.gitlab.com/ee/ci/services/index.html
|
||||
variables:
|
||||
POSTGRES_PASSWORD: test
|
||||
# POSTGRES_DB: $POSTGRES_DB
|
||||
# POSTGRES_USER: $POSTGRES_USER
|
||||
# POSTGRES_PASSWORD: $POSTGRES_PASSWORD
|
||||
# POSTGRES_HOST_AUTH_METHOD: trust
|
||||
|
||||
services:
|
||||
- postgres:15
|
||||
- redis
|
||||
|
||||
before_script:
|
||||
- apk add --no-cache cargo python3 make g++
|
||||
- cp .config/ci.yml .config/default.yml
|
||||
- corepack enable
|
||||
- corepack prepare pnpm@latest --activate
|
||||
|
||||
testCommit:
|
||||
stage: build
|
||||
script:
|
||||
- pnpm i --frozen-lockfile
|
||||
- pnpm run build:debug
|
||||
- pnpm run migrate
|
||||
only:
|
||||
- main
|
||||
- beta
|
||||
- develop
|
||||
- /^feature\/.*$/
|
||||
|
||||
dockerPush:
|
||||
stage: .post
|
||||
image: docker:latest
|
||||
services:
|
||||
- docker:dind
|
||||
script:
|
||||
- docker build -t $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG .
|
||||
- echo $CI_JOB_TOKEN | docker login -u $CI_REGISTRY_USER --password-stdin $CI_REGISTRY
|
||||
- docker push $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
|
||||
only:
|
||||
- main
|
||||
- beta
|
||||
|
||||
# This folder is cached between builds
|
||||
# https://docs.gitlab.com/ee/ci/yaml/index.html#cache
|
||||
cache:
|
||||
paths:
|
||||
- node_modules/
|
||||
- packages/*/node_modules/
|
||||
- packages/backend/native-utils/node_modules/
|
29
.gitlab/issue_templates/bug.md
Normal file
29
.gitlab/issue_templates/bug.md
Normal 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.
|
17
.gitlab/issue_templates/feature.md
Normal file
17
.gitlab/issue_templates/feature.md
Normal 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.
|
9
.gitlab/merge_request_templates/default.md
Normal file
9
.gitlab/merge_request_templates/default.md
Normal file
|
@ -0,0 +1,9 @@
|
|||
<!-- Thanks for taking the time to make Firefish better! It's not required, but please consider using [Conventional Commits](https://www.conventionalcommits.org/en/v1.0.0/) when making your commits. If you use VSCode, please use the [Conventional Commits extension](https://marketplace.visualstudio.com/items?itemName=vivaxy.vscode-conventional-commits). -->
|
||||
|
||||
**What does this PR do?** _(Please give us a brief description of what this PR does.)_
|
||||
|
||||
**Contribution Guidelines**
|
||||
By submitting this issue, you agree to follow our [Contribution Guidelines](https://git.joinfirefish.org/firefish/firefish/-/blob/develop/CONTRIBUTING.md)
|
||||
- [ ] I agree to follow this project's Contribution Guidelines
|
||||
- [ ] I have made sure to test this pull request
|
||||
- [ ] I have made sure to run `pnpm run format` before submitting this pull request
|
20
.vscode/launch.json
vendored
Normal file
20
.vscode/launch.json
vendored
Normal file
|
@ -0,0 +1,20 @@
|
|||
{
|
||||
// Use IntelliSense to learn about possible attributes.
|
||||
// Hover to view descriptions of existing attributes.
|
||||
// For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
|
||||
"version": "0.2.0",
|
||||
"configurations": [
|
||||
{
|
||||
"type": "node",
|
||||
"request": "launch",
|
||||
"name": "Launch PNPM Debug Script",
|
||||
"skipFiles": [
|
||||
"<node_internals>/**"
|
||||
],
|
||||
"runtimeExecutable": "pnpm",
|
||||
"runtimeArgs": [
|
||||
"run", "debug"
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
66
CHANGELOG.md
66
CHANGELOG.md
|
@ -67,7 +67,7 @@ Closes #10313
|
|||
|
||||
- Fix: :bug: don't convert time since epoch for ratelimit
|
||||
|
||||
https://calckey.social/notes/9gkasnzglmi07rpa
|
||||
https://firefish.social/notes/9gkasnzglmi07rpa
|
||||
|
||||
- Fix: :bug: fix tapping parent on mobile causing side effects
|
||||
|
||||
|
@ -1834,7 +1834,7 @@ Closes #9843
|
|||
|
||||
- Fix: :recycle: use locale for error
|
||||
|
||||
https://calckey.social/notes/9fippqiwhl287b5m
|
||||
https://firefish.social/notes/9fippqiwhl287b5m
|
||||
|
||||
- Fix mfm-cheat-sheet styling
|
||||
|
||||
|
@ -14998,3 +14998,65 @@ Co-authored-by: Johann150 <johann@qwertqwefsday.eu>
|
|||
|
||||
|
||||
<!-- generated by git-cliff -->
|
||||
|
||||
## FoundKey
|
||||
|
||||
In the commits above, a few of these changes were added from [FoundKey](https://akkoma.dev/FoundKeyGang/FoundKey), although the majority have been refactored. Below is a historical list of all commits that were cherry picked:
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/0ece67b04c3f0365057624c1068808276ccab981: refactor pages/auth.form.vue to composition API
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/4bc9610d8bf5af736b5e89e4782395705de45d7d: remove unnecessary joins
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/9ee609d70082f7a6dc119a5d83c0e7c5e1208676: enhance privacy of notes
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/0fec6e10477b1c1b95d9469fbaf4e249a3722f12: remove ms dependency
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/46fff77accbe8bf0fd3cc88170d67b997bf2bdc3: client uses new API for child notes depth
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/c35372a20d22cddb75e93a0b407f2b652cd7faf0: pack children without detail
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/aca724e0bfff3e58b4d273f3ee744e3f3aa9c39b: enable to fetch replies recursively
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/2fe64c11502fd8d89c126558cd715e095c83754e: Refactor components/page/page.textarea.vue to composition API
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/6d3181f9835955e5b79bde5484c74bd70e7f9535: Refactor components/page/page.text.vue to composition API
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/b630cd7eacd695bb705e6748c87f38425ec4ed45: refactor: add NoteReactions.packMany
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/3fe351df6d4e21f7748c46adfa6ca165abd030c0: fix: catch errors from packing with detail
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/63591da33e233b2ed0ab331ae6bb3c9eff5020ae: refactor: colours in queue chart
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/0f6d94f1e7e1f58cfbf8d07e5f835f8de626842e: backend: improve mutes and blocks
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/e2bf2715a6462ed377b033956d65260157f042ea: fix spelling error
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/09a7eabda137e77f81ab31f65d69329670693c8d: backend: fix lint "no-throw-literal"
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/4fbe2e065e75ed3e5b4dfdfd4be3baa03cc447c3: client: fix lint "quotes"
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/585e4f5c42cfafb6cdf7eb601ab435d6a4d85a96: fix textarea not updating properly
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/30d8bc9259cb6b72ed76d67b21dbb4cdceca8327: refactor: welcome.setup.vue to composition api
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/751921e24f37ed707fe44a40d88eebb1299efa35: make emoji picker case insensitive
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/298febeb9c9501e3e3df16982c08657d1da474e0: enhance: add re-collapsing to quoted notes
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/b0fdedb264db87575063abed45e52ad71ce4a6af: fix lints in folder.vue
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/6fed87f85d132304eb84b0a59b84dce299a1822f: fix pagination.vue lints
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/384e8c49b738f576ba8843296de6cebf01c1b247: server: allow to like own gallery posts
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/4c5aa9e53887cca5561fcec6ab0754e018f589a5: server: allow to like own pages
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/923c93da1228458dd65be47483c198a1a9191bcf: use await for notes.countBy
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/ca90cedba0a0704b503c2778694230f5a7dfbace: server: reduce dead instance detection to 7 days
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/e9ab42c10afb4e27516c2d2b5e3e06630efe9edd: Alt text in image viewer
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/ed9d4023d41bba7c4ac53a1a3422246feed37de2: add argon2 support
|
||||
|
||||
- https://akkoma.dev/FoundKeyGang/FoundKey/commit/c414f24a2c123774246c7eca65edda4d3afaf8b3: feat: per-user renote muting
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
We're glad you're interested in contributing Firefish! In this document you will find the information you need to contribute to the project.
|
||||
|
||||
## Translation (i18n)
|
||||
Firefish uses [Weblate](hhttps://hosted.weblate.org/engage/firefish/) for translation and internationalization management.
|
||||
Firefish uses [Weblate](https://hosted.weblate.org/engage/firefish/) for translation and internationalization management.
|
||||
|
||||
If your language is not listed in Weblate, please open an issue.
|
||||
|
||||
|
@ -12,9 +12,6 @@ You can contribute without knowing how to code by helping translate here:
|
|||
|
||||
[![Translation bars](https://hosted.weblate.org/widgets/firefish/-/multi-auto.svg)](https://hosted.weblate.org/engage/firefish/)
|
||||
|
||||
## Roadmap
|
||||
See [FIREFISH.md](./FIREFISH.md)
|
||||
|
||||
## Issues
|
||||
Before creating an issue, please check the following:
|
||||
- To avoid duplication, please search for similar issues before creating a new issue.
|
||||
|
|
166
FIREFISH.md
166
FIREFISH.md
|
@ -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
|
11
README.md
11
README.md
|
@ -23,7 +23,6 @@
|
|||
|
||||
- Firefish is based off of Misskey, a powerful microblogging server on ActivityPub with features such as emoji reactions, a customizable web UI, rich chatting, and much more!
|
||||
- Firefish adds many quality of life changes and bug fixes for users and server admins alike.
|
||||
- Read **[this document](./FIREFISH.md)** all for current and future differences.
|
||||
- Notable differences:
|
||||
- Improved UI/UX (especially on mobile)
|
||||
- Post editing
|
||||
|
@ -40,7 +39,9 @@
|
|||
- Backfill user information
|
||||
- Advanced search
|
||||
- Many more user and admin settings
|
||||
- [So much more!](./FIREFISH.md)
|
||||
- Many bug fixes and performance improvements
|
||||
- Link verification
|
||||
- So much more!
|
||||
|
||||
</div>
|
||||
|
||||
|
@ -64,7 +65,7 @@
|
|||
- Donate publicly to get your name on the Patron list!
|
||||
- 🚢 Flagship server: <https://firefish.social>
|
||||
- 💁 Matrix support room: <https://matrix.to/#/#firefish:matrix.fedibird.com>
|
||||
- 📣 Official account: <https://i.firefish.cloud/@firefish>
|
||||
- 📣 Official account: <a href="https://fedi.software/@firefish" rel="me">@firefish</a>
|
||||
- 📜 Server list: <https://joinfirefish.org/join>
|
||||
- ✍️ Weblate: <https://hosted.weblate.org/engage/firefish/>
|
||||
- ️️📬 Contact: <https://joinfirefish.org/contact/>
|
||||
|
@ -85,9 +86,7 @@ This guide will work for both **starting from scratch** and **migrating from Mis
|
|||
|
||||
If you have access to a server that supports one of the sources below, I recommend you use it! Note that these methods *won't* allow you to migrate from Misskey without manual intervention.
|
||||
|
||||
<!-- [![Install on the Arch User Repository](https://pool.jortage.com/voringme/misskey/ba2a5c07-f078-43f1-8483-2e01acca9c40.png)](https://aur.archlinux.org/packages/firefish) -->
|
||||
|
||||
[![Install on Ubuntu](https://pool.jortage.com/voringme/misskey/3b62a443-1b44-45cf-8f9e-f1c588f803ed.png)](https://gitlab.prometheus.systems/firefish/ubuntu-bash-install) [![Install Firefish with YunoHost](https://install-app.yunohost.org/install-with-yunohost.svg)](https://install-app.yunohost.org/?app=firefish)
|
||||
[![Install on Ubuntu](https://pool.jortage.com/voringme/misskey/3b62a443-1b44-45cf-8f9e-f1c588f803ed.png)](https://git.joinfirefish.org/firefish/ubuntu-bash-install) [![Install on the Arch User Repository](https://pool.jortage.com/voringme/misskey/ba2a5c07-f078-43f1-8483-2e01acca9c40.png)](https://aur.archlinux.org/packages/firefish) [![Install Firefish with YunoHost](https://install-app.yunohost.org/install-with-yunohost.svg)](https://install-app.yunohost.org/?app=firefish)
|
||||
|
||||
## 🛳️ Containerization
|
||||
|
||||
|
|
|
@ -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>
|
|
@ -53,7 +53,7 @@ A fun, new, open way to experience social media https://joinfirefish.org
|
|||
| elasticsearch | object | `{"auth":{},"enabled":false,"hostname":"","port":9200,"ssl":false}` | https://github.com/bitnami/charts/tree/master/bitnami/elasticsearch#parameters |
|
||||
| fullnameOverride | string | `""` | |
|
||||
| image.pullPolicy | string | `"IfNotPresent"` | |
|
||||
| image.repository | string | `"docker.io/thatonecalculator/firefish"` | |
|
||||
| image.repository | string | `"registry.joinfirefish.org/firefish/firefish"` | |
|
||||
| image.tag | string | `""` | |
|
||||
| imagePullSecrets | list | `[]` | |
|
||||
| ingress.annotations | object | `{}` | |
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
replicaCount: 1
|
||||
|
||||
image:
|
||||
repository: docker.io/thatonecalculator/firefish
|
||||
repository: registry.joinfirefish.org/firefish/firefish
|
||||
pullPolicy: IfNotPresent
|
||||
# Overrides the image tag whose default is the chart appVersion.
|
||||
tag: ""
|
||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 57 KiB After Width: | Height: | Size: 40 KiB |
Binary file not shown.
Before Width: | Height: | Size: 55 KiB After Width: | Height: | Size: 9.9 KiB |
Binary file not shown.
Before Width: | Height: | Size: 56 KiB After Width: | Height: | Size: 9.1 KiB |
|
@ -2,7 +2,7 @@ version: "3"
|
|||
|
||||
services:
|
||||
web:
|
||||
image: docker.io/thatonecalculator/firefish
|
||||
image: registry.joinfirefish.org/firefish/firefish
|
||||
build: ..
|
||||
container_name: firefish_web
|
||||
restart: always
|
||||
|
|
|
@ -2,7 +2,7 @@ version: "3"
|
|||
|
||||
services:
|
||||
web:
|
||||
image: docker.io/thatonecalculator/firefish
|
||||
image: registry.joinfirefish.org/firefish/firefish
|
||||
container_name: firefish_web
|
||||
restart: unless-stopped
|
||||
depends_on:
|
||||
|
|
|
@ -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`.
|
||||
|
|
|
@ -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
|
|
@ -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
|
|
@ -1,7 +1,7 @@
|
|||
---
|
||||
_lang_: "العربية"
|
||||
headlineMisskey: "شبكة مرتبطة بالملاحظات"
|
||||
introMisskey: "اهلا بك! ميسكي هو منصة تدوين مصغر لا مركزية ومفتوحة المصدر.\nيمكنك مشاركة \"ملاحظات\" عن ما يجري حولك، وإخبار الجميع عن نفسك 📡\nتسمح لك \"الانفعالات\" بتعبير عن شعورك حول ملاحظات الآخرين 👍\nاكتشف عالمًا جديدًا 🚀"
|
||||
headlineFirefish: "شبكة مرتبطة بالملاحظات"
|
||||
introFirefish: "اهلا بك! ميسكي هو منصة تدوين مصغر لا مركزية ومفتوحة المصدر.\nيمكنك مشاركة \"ملاحظات\" عن ما يجري حولك، وإخبار الجميع عن نفسك 📡\nتسمح لك \"الانفعالات\" بتعبير عن شعورك حول ملاحظات الآخرين 👍\nاكتشف عالمًا جديدًا 🚀"
|
||||
monthAndDay: "{day}/{month}"
|
||||
search: "البحث"
|
||||
notifications: "الإشعارات"
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
---
|
||||
_lang_: "বাংলা"
|
||||
headlineMisskey: "নোট ব্যাবহার করে সংযুক্ত নেটওয়ার্ক"
|
||||
introMisskey: "স্বাগতম! মিসকি একটি ওপেন সোর্স, ডিসেন্ট্রালাইজড মাইক্রোব্লগিং পরিষেবা। \n\"নোট\" তৈরির মাধ্যমে যা ঘটছে তা সবার সাথে শেয়ার করুন 📡\n\"রিঅ্যাকশন\" গুলির মাধ্যমে যেকোনো নোট সম্পর্কে আপনার অনুভূতি ব্যাক্ত করতে পারেন 👍\nএকটি নতুন দুনিয়া ঘুরে দেখুন 🚀\n"
|
||||
headlineFirefish: "নোট ব্যাবহার করে সংযুক্ত নেটওয়ার্ক"
|
||||
introFirefish: "স্বাগতম! মিসকি একটি ওপেন সোর্স, ডিসেন্ট্রালাইজড মাইক্রোব্লগিং পরিষেবা। \n\"নোট\" তৈরির মাধ্যমে যা ঘটছে তা সবার সাথে শেয়ার করুন 📡\n\"রিঅ্যাকশন\" গুলির মাধ্যমে যেকোনো নোট সম্পর্কে আপনার অনুভূতি ব্যাক্ত করতে পারেন 👍\nএকটি নতুন দুনিয়া ঘুরে দেখুন 🚀\n"
|
||||
monthAndDay: "{day}/{month}"
|
||||
search: "খুঁজুন"
|
||||
notifications: "বিজ্ঞপ্তি"
|
||||
|
|
|
@ -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: Последователи
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
_lang_: "Català"
|
||||
headlineMisskey: "Una xarxa social de codi obert, descentralitzada i gratuïta per
|
||||
headlineFirefish: "Una xarxa social de codi obert, descentralitzada i gratuïta per
|
||||
a sempre! 🚀"
|
||||
introMisskey: "Benvinguts! Firefish és una plataforma social de codi obert, descentralitzada
|
||||
introFirefish: "Benvinguts! Firefish és una plataforma social de codi obert, descentralitzada
|
||||
i gratuïta per a sempre! 🚀"
|
||||
monthAndDay: "{day}/{month}"
|
||||
search: "Cerca"
|
||||
|
@ -116,7 +116,7 @@ reaction: "Reaccions"
|
|||
reactionSetting: "Reaccions a mostrar al selector de reaccions"
|
||||
reactionSettingDescription2: "Arrossega per reordenar, fes clic per suprimir, prem
|
||||
\"+\" per afegir."
|
||||
rememberNoteVisibility: "Recorda la configuració de visibilitat de les notes"
|
||||
rememberNoteVisibility: "Recorda la configuració de visibilitat de les publicacions"
|
||||
attachCancel: "Elimina el fitxer adjunt"
|
||||
markAsSensitive: "Marca com a NSFW"
|
||||
unmarkAsSensitive: "Desmarca com a NSFW"
|
||||
|
@ -418,7 +418,7 @@ _exportOrImport:
|
|||
blockingList: "Bloqueja"
|
||||
userLists: "Llistes"
|
||||
excludeMutingUsers: Exclou els usuaris silenciats
|
||||
allNotes: Totes les notes
|
||||
allNotes: Totes les publicacions
|
||||
excludeInactiveUsers: Exclou usuaris inactius
|
||||
_pages:
|
||||
script:
|
||||
|
@ -633,7 +633,7 @@ _pages:
|
|||
if: Si
|
||||
_if:
|
||||
variable: Variable
|
||||
post: Formulari de notes
|
||||
post: Formulari de publicació
|
||||
_post:
|
||||
text: Contingut
|
||||
attachCanvasImage: Adjuntar imatge de llenç
|
||||
|
@ -841,7 +841,7 @@ blockedUsers: Usuaris blocats
|
|||
noUsers: No hi ha cap usuari
|
||||
editProfile: Edita el perfil
|
||||
noteDeleteConfirm: Segur que vols eliminar la publicació?
|
||||
pinLimitExceeded: No pots fixar més notes
|
||||
pinLimitExceeded: No pots fixar més publicacions
|
||||
muteAndBlock: Silenciats i blocats
|
||||
mutedUsers: Usuaris silenciats
|
||||
done: Fet
|
||||
|
@ -1044,7 +1044,7 @@ pinnedClipId: ID del clip que vols fixar
|
|||
hcaptcha: hCaptcha
|
||||
manageAntennas: Gestiona les Antenes
|
||||
name: Nom
|
||||
notesAndReplies: Notes i respostes
|
||||
notesAndReplies: Publicacions i respostes
|
||||
silence: Posa en silenci
|
||||
withFiles: Amb fitxers
|
||||
popularUsers: Usuaris populars
|
||||
|
@ -1070,7 +1070,7 @@ notFoundDescription: No es pot trobar cap pàgina que correspongui a aquesta adr
|
|||
uploadFolder: Carpeta per defecte per pujar arxius
|
||||
cacheClear: Netejar la memòria cau
|
||||
markAsReadAllNotifications: Marca totes les notificacions com llegides
|
||||
markAsReadAllUnreadNotes: Marca totes les notes com a llegides
|
||||
markAsReadAllUnreadNotes: Marca totes les publicacions com a llegides
|
||||
markAsReadAllTalkMessages: Marca tots els missatges com llegits
|
||||
help: Ajuda
|
||||
inputMessageHere: Escriu aquí el missatge
|
||||
|
@ -1140,7 +1140,7 @@ promote: Promoure
|
|||
numberOfDays: Nombre de dies
|
||||
objectStorageBaseUrl: Adreça URL base
|
||||
hideThisNote: Amaga aquesta publicació
|
||||
showFeaturedNotesInTimeline: Mostra les notes destacades a les líneas de temps
|
||||
showFeaturedNotesInTimeline: Mostra les publicacions destacades a les línees de temps
|
||||
objectStorage: Emmagatzematge d'objectes
|
||||
useObjectStorage: Fes servir l'emmagatzema d'objectes
|
||||
expandTweet: Amplia el tuit
|
||||
|
@ -1211,7 +1211,7 @@ notificationSetting: Preferències de notificacions
|
|||
makeActive: Activar
|
||||
notificationSettingDesc: Tria el tipus de notificació que es veure.
|
||||
notifyAntenna: Notificar publicacions noves
|
||||
withFileAntenna: Només notes amb fitxers
|
||||
withFileAntenna: Només publicacions amb fitxers
|
||||
enableServiceworker: Activa les notificacions push per al teu navegador
|
||||
antennaUsersDescription: Escriu un nom d'usuari per línea
|
||||
antennaInstancesDescription: Escriu la adreça d'un servidor per línea
|
||||
|
@ -1294,7 +1294,7 @@ defaultNavigationBehaviour: Navegació per defecte
|
|||
editTheseSettingsMayBreakAccount: Si edites aquestes configuracions pots fer mal bé
|
||||
el teu compte.
|
||||
userSilenced: Aquest usuari ha sigut silenciat.
|
||||
instanceTicker: Informació de notes del servidor
|
||||
instanceTicker: Informació de publicacions del servidor
|
||||
waitingFor: Esperant a {x}
|
||||
random: Aleatori
|
||||
system: Sistema
|
||||
|
@ -1312,18 +1312,18 @@ no: No
|
|||
noCrawle: Rebutjar la indexació dels restrejadors
|
||||
driveUsage: Espai fet servir al Disk
|
||||
noCrawleDescription: No permetre que els buscadors guardin la informació de les pàgines
|
||||
de perfil, notes, Pàgines, etc.
|
||||
de perfil, publicacions, Pàgines, etc.
|
||||
alwaysMarkSensitive: Marcar per defecte com a NSFW
|
||||
lockedAccountInfo: Si has configurat la visibilitat del compte per "Només seguidors"
|
||||
les teves notes no seren visibles per a ningú més, inclús si has d'aprovar els teus
|
||||
seguidors manualment.
|
||||
les teves publicacions no serien visibles per a ningú més, inclús si has d'aprovar
|
||||
els teus seguidors manualment.
|
||||
disableShowingAnimatedImages: No reproduir les imatges animades
|
||||
verificationEmailSent: S'ha enviat correu electrònic de verificació. Si us plau segueix
|
||||
les instruccions per completar la verificació.
|
||||
notSet: Sense especificar
|
||||
emailVerified: El correu electrònic s'ha verificat
|
||||
loadRawImages: Carregar les imatges originals en comptes de mostrar les miniatures
|
||||
noteFavoritesCount: Nombre de notes afegides a favorits
|
||||
noteFavoritesCount: Nombre de publicacions afegides a favorits
|
||||
useSystemFont: Fes servir la font per defecte del sistema
|
||||
contact: Contacte
|
||||
clips: Retalls
|
||||
|
@ -1331,7 +1331,7 @@ experimentalFeatures: Característiques experimentals
|
|||
developer: Desenvolupador
|
||||
makeExplorableDescription: Si desactives aquesta funció el teu compte no sortirà a
|
||||
la secció "Explora".
|
||||
showGapBetweenNotesInTimeline: Mostra un espai entre notes a la línea de temps
|
||||
showGapBetweenNotesInTimeline: Mostra un espai entre publicacions a la línea de temps
|
||||
makeExplorable: Fes el compte visible a "Explora"
|
||||
duplicate: Duplicar
|
||||
left: Esquerra
|
||||
|
@ -1343,14 +1343,14 @@ needReloadToApply: Es requereix recarregar la pàgina perquè això surti efecte
|
|||
showTitlebar: Mostrar la barra de títol
|
||||
onlineUsersCount: Hi han {n} usuaris connectats
|
||||
nUsers: '{n} Usuaris'
|
||||
nNotes: '{n} Notes'
|
||||
nNotes: '{n} Publicacions'
|
||||
sendErrorReports: Enviar informe d'error
|
||||
clearCache: Netejar memòria cau
|
||||
switchAccount: Canvia de compte
|
||||
enabled: Activat
|
||||
configure: Configurar
|
||||
noBotProtectionWarning: La protecció contra bots no està configurada.
|
||||
ads: Publicitat
|
||||
ads: Bàners comunitaris
|
||||
ratio: Ràtio
|
||||
global: Global
|
||||
sent: Enviat
|
||||
|
@ -1445,7 +1445,7 @@ _ad:
|
|||
reduceFrequencyOfThisAd: Mostrar aquest anunci menys
|
||||
_gallery:
|
||||
my: La meva Galeria
|
||||
liked: Notes que m'han agradat
|
||||
liked: Publicacions que m'han agradat
|
||||
unlike: Elimina m'agrada
|
||||
like: M'agrada
|
||||
_forgotPassword:
|
||||
|
@ -1605,8 +1605,8 @@ _aboutFirefish:
|
|||
patronsList: Llistats cronològicament, no per la quantitat donada. Fes una donació
|
||||
amb l'enllaç de dalt per veure el teu nom aquí!
|
||||
donateTitle: T'agrada Firefish?
|
||||
pleaseDonateToFirefish: Penseu en fer una donació a Firefish per donar suport al seu
|
||||
desenvolupament.
|
||||
pleaseDonateToFirefish: Penseu en fer una donació a Firefish per donar suport al
|
||||
seu desenvolupament.
|
||||
pleaseDonateToHost: Penseu també en fer una donació a la vostre instància, {host},
|
||||
per ajudar-lo a suportar els costos de funcionament.
|
||||
donateHost: Fes una donació a {host}
|
||||
|
@ -1617,7 +1617,7 @@ youAreRunningUpToDateClient: Estás fent servir la versió del client més nova.
|
|||
unlikeConfirm: Vols treure el teu m'agrada?
|
||||
fullView: Vista complerta
|
||||
desktop: Escritori
|
||||
notesCount: Nombre de notes
|
||||
notesCount: Nombre de publicacions
|
||||
confirmToUnclipAlreadyClippedNote: Aquesta publicació ja és al clip "{name}". La vols
|
||||
treure d'aquest clip?
|
||||
driveFilesCount: Nombre de fitxers al Disk
|
||||
|
@ -1651,7 +1651,7 @@ privateModeInfo: Quan està activat, només els servidors a la llista blanca es
|
|||
useBlurEffect: Utilitzeu efectes de desenfocament a la interfície d'usuari
|
||||
accountDeletionInProgress: La supressió del compte està en curs
|
||||
unmuteThread: Desfés el silenci al fil
|
||||
deleteAccountConfirm: Això suprimirà el vostre compte de manera irreversible. Procedir?
|
||||
deleteAccountConfirm: Això suprimirà aquest compte de manera irreversible. Procedir?
|
||||
requireAdminForView: Heu d'iniciar sessió amb un compte d'administrador per veure-ho.
|
||||
enableAutoSensitiveDescription: Permet la detecció i el marcatge automàtics dels mitjans
|
||||
NSFW mitjançant Machine Learning sempre que sigui possible. Fins i tot si aquesta
|
||||
|
@ -1671,7 +1671,7 @@ objectStorageRegion: Regió
|
|||
objectStoragePrefix: Prefix
|
||||
objectStoragePrefixDesc: Els fitxers es guardaran dins de carpetes amb aquest prefix.
|
||||
objectStorageEndpoint: Extrem
|
||||
newNoteRecived: Hi han notes noves
|
||||
newNoteRecived: Hi han publicacions noves
|
||||
sounds: Sons
|
||||
listen: Escoltar
|
||||
none: Res
|
||||
|
@ -1686,7 +1686,8 @@ objectStorageUseProxyDesc: Desactiva això si no faràs servir un servidor Proxy
|
|||
objectStorageSetPublicRead: Fixar com a "public-read" al pujar
|
||||
serverLogs: Registres del servidor
|
||||
deleteAll: Esborrar tot
|
||||
showFixedPostForm: Mostrar el formulari de notes al principi de la línia de temps
|
||||
showFixedPostForm: Mostrar el formulari de publicacions al principi de la línia de
|
||||
temps
|
||||
unableToProcess: Aquesta operació no es pot acabar
|
||||
recentUsed: Fet servir fa poc
|
||||
install: Instal·lar
|
||||
|
@ -1719,9 +1720,9 @@ accentColor: Color principal
|
|||
textColor: Color del text
|
||||
value: Valor
|
||||
sendErrorReportsDescription: "Quan està activat, quan es produeixi un problema la
|
||||
informació detallada d'errors es compartirà amb Firefish, ajudant a millorar la qualitat
|
||||
de Firefish.\nAixò inclourà informació com la versió del vostre sistema operatiu,
|
||||
quin navegador utilitzeu, la vostra activitat a Firefish, etc."
|
||||
informació detallada d'errors es compartirà amb Firefish, ajudant a millorar la
|
||||
qualitat de Firefish.\nAixò inclourà informació com la versió del vostre sistema
|
||||
operatiu, quin navegador utilitzeu, la vostra activitat a Firefish, etc."
|
||||
myTheme: El meu tema
|
||||
backgroundColor: Color de fons
|
||||
saveAs: Desa com...
|
||||
|
@ -1760,7 +1761,7 @@ sendPushNotificationReadMessage: Suprimeix les notificacions push un cop s'hagin
|
|||
sendPushNotificationReadMessageCaption: Es mostrarà una notificació amb el text "{emptyPushNotificationMessage}"
|
||||
durant un breu temps. Això pot augmentar l'ús de la bateria del vostre dispositiu,
|
||||
si escau.
|
||||
showAds: Mostrar publicitat
|
||||
showAds: Mostrar bàners de la comunitat
|
||||
enterSendsMessage: Pren retorn al formulari del missatge per enviar (quant no s'activa
|
||||
es Ctrl + Return)
|
||||
customMOTD: MOTD personalitzat (missatges de la pantalla de benvinguda)
|
||||
|
@ -1778,7 +1779,7 @@ migrationConfirm: "Esteu absolutament segur que voleu migrar el vostre compte a
|
|||
Un cop ho feu, no podreu revertir-ho i no podreu tornar a utilitzar el vostre compte
|
||||
amb normalitat.\nA més, assegureu-vos d'haver configurat aquest compte actual com
|
||||
el compte del qual us moveu."
|
||||
defaultReaction: Reacció d'emoji predeterminada per a notes sortints i entrants
|
||||
defaultReaction: Reacció d'emoji predeterminades per a publicacions sortints i entrants
|
||||
enableCustomKaTeXMacro: Activa les macros KaTeX personalitzades
|
||||
noteId: ID de la publicació
|
||||
_nsfw:
|
||||
|
@ -1841,7 +1842,7 @@ pushNotificationAlreadySubscribed: Les notificacions push ja estan activades
|
|||
pushNotificationNotSupported: El vostre navegador o servidor no admet notificacions
|
||||
push
|
||||
license: Llicència
|
||||
indexPosts: Índex de notes
|
||||
indexPosts: Índex de publicacions
|
||||
indexFrom: Índex a partir de l'ID de Publicacions
|
||||
indexFromDescription: Deixeu en blanc per indexar cada publicació
|
||||
indexNotice: Ara indexant. Això probablement trigarà una estona, si us plau, no reinicieu
|
||||
|
@ -1864,7 +1865,7 @@ _channel:
|
|||
owned: Propietari
|
||||
usersCount: '{n} Participants'
|
||||
following: Seguit per
|
||||
notesCount: '{n} Notes'
|
||||
notesCount: '{n} Publicacions'
|
||||
nameAndDescription: Nom i descripció
|
||||
nameOnly: Només nom
|
||||
_instanceMute:
|
||||
|
@ -1912,7 +1913,7 @@ _tutorial:
|
|||
Firefish. Aquest sí que sí! És una mica complicat, però ho aconseguiràs en poc
|
||||
temps.
|
||||
step2_2: Proporcionar informació sobre qui sou facilitarà que altres puguin saber
|
||||
si volen veure les vostres notes o seguir-vos.
|
||||
si volen veure les vostres publicacions o seguir-vos.
|
||||
step3_1: Ara toca seguir a algunes persones!
|
||||
step3_2: "Les teves líneas de temps d'inici i social es basen en qui seguiu, així
|
||||
que proveu de seguir un parell de comptes per començar.\nFeu clic al cercle més
|
||||
|
@ -1934,9 +1935,9 @@ _permissions:
|
|||
"write:notifications": Gestiona les teves notificacions
|
||||
"write:user-groups": Editar o suprimir grups d'usuaris
|
||||
"write:blocks": Editar la llista d'usuaris bloquejats
|
||||
"write:notes": Redactar o suprimir notes
|
||||
"write:notes": Redactar o suprimir publicacions
|
||||
"write:channels": Editar els teus canals
|
||||
"read:gallery-likes": Consulta la llista de notes que t'agraden de la galeria
|
||||
"read:gallery-likes": Consulta la llista de publicacions que t'agraden de la galeria
|
||||
"write:drive": Editar o suprimir fitxers i carpetes del Disc
|
||||
"read:favorites": Consulta la teva llista d'adreces d'interès
|
||||
"write:favorites": Editeu la teva llista d'adreces d'interès
|
||||
|
@ -1950,7 +1951,7 @@ _permissions:
|
|||
"read:channels": Consulta els teus canals
|
||||
"read:gallery": Consulta la teva galeria
|
||||
"write:gallery": Edita la teva galeria
|
||||
"write:gallery-likes": Edita la llista de notes que t'agraden de la galeria
|
||||
"write:gallery-likes": Edita la llista de publicacions que t'agraden de la galeria
|
||||
"read:following": Consulta la informació sobre a qui segueixes
|
||||
"read:reactions": Consulta les teves reaccions
|
||||
"read:pages": Consulta la teva pàgina
|
||||
|
@ -1994,10 +1995,10 @@ _charts:
|
|||
apRequest: Sol·licituds
|
||||
usersTotal: Nombre total d'usuaris
|
||||
activeUsers: Usuaris actius
|
||||
notesIncDec: Diferència en el nombre de notes
|
||||
localNotesIncDec: Diferència en el nombre de notes locals
|
||||
remoteNotesIncDec: Diferència en el nombre de notes remotes
|
||||
notesTotal: Nombre total de notes
|
||||
notesIncDec: Diferència en el nombre de publicacions
|
||||
localNotesIncDec: Diferència en el nombre de publicacions locals
|
||||
remoteNotesIncDec: Diferència en el nombre de publicacions remotes
|
||||
notesTotal: Nombre total de publicacions
|
||||
filesIncDec: Diferència en el nombre de fitxers
|
||||
filesTotal: Nombre total de fitxers
|
||||
storageUsageTotal: Ús total d'emmagatzematge
|
||||
|
@ -2006,13 +2007,13 @@ _instanceCharts:
|
|||
requests: Sol·licituds
|
||||
users: Diferència en el nombre d'usuaris
|
||||
usersTotal: Nombre acumulat d'usuaris
|
||||
notes: Diferència en el nombre de notes
|
||||
notes: Diferència en el nombre de publicacions
|
||||
ffTotal: Nombre acumulat d'usuaris que segueixes/et segueixen
|
||||
cacheSize: Diferència en la mida de la memòria cau
|
||||
cacheSizeTotal: Mida total acumulada de la memòria cau
|
||||
files: Diferència en el nombre de fitxers
|
||||
filesTotal: Nombre acumulat de fitxers
|
||||
notesTotal: Nombre acumulat de notes
|
||||
notesTotal: Nombre acumulat de publicacions
|
||||
ff: "Diferència en el nombre d'usuaris que segueixes/que et segueixen "
|
||||
_timelines:
|
||||
home: Inici
|
||||
|
@ -2033,12 +2034,12 @@ _wordMute:
|
|||
hard: Dur
|
||||
muteWordsDescription2: Envolta les paraules clau amb barres inclinades per utilitzar
|
||||
expressions regulars.
|
||||
softDescription: Amaga les notes que compleixen les condicions establertes de la
|
||||
línia de temps.
|
||||
hardDescription: Evita que les notes que compleixin les condicions establertes s'afegeixin
|
||||
a la línia de temps. A més, aquestes notes no s'afegiran a la línia de temps encara
|
||||
que es modifiquin les condicions.
|
||||
mutedNotes: Notes silenciades
|
||||
softDescription: Amaga les publicacions que compleixen les condicions establertes
|
||||
de la línia de temps.
|
||||
hardDescription: Evita que les publicacions que compleixin les condicions establertes
|
||||
s'afegeixin a la línia de temps. A més, aquestes publicacions no s'afegiran a
|
||||
la línia de temps encara que es modifiquin les condicions.
|
||||
mutedNotes: Publicacions silenciades
|
||||
_auth:
|
||||
shareAccessAsk: Estàs segur que vols autoritzar aquesta aplicació per accedir al
|
||||
teu compte?
|
||||
|
@ -2061,11 +2062,11 @@ _messaging:
|
|||
groups: Grups
|
||||
dms: Privat
|
||||
_antennaSources:
|
||||
all: Totes les notes
|
||||
all: Totes les publicacions
|
||||
homeTimeline: Publicacions dels usuaris que segueixes
|
||||
users: Notes d'usuaris concrets
|
||||
userGroup: Notes d'usuaris d'un grup determinat
|
||||
userList: Notes d'una llista determinada d'usuaris
|
||||
users: Publicacions d'usuaris concrets
|
||||
userGroup: Publicacions d'usuaris d'un grup determinat
|
||||
userList: Publicacions d'una llista determinada d'usuaris
|
||||
instances: Publicacions de tots els usuaris d'un servidor
|
||||
_relayStatus:
|
||||
requesting: Pendent
|
||||
|
@ -2120,7 +2121,7 @@ clipsDesc: Els clips són com marcadors categoritzats que es poden compartir. Po
|
|||
crear clips des del menú de publicacions individuals.
|
||||
selectChannel: Selecciona un canal
|
||||
isLocked: Aquest compte té les següents aprovacions
|
||||
isPatron: Mecenes de Calkey
|
||||
isPatron: Mecenes de Firefish
|
||||
isBot: Aquest compte és un bot
|
||||
isModerator: Moderador
|
||||
isAdmin: Administrador
|
||||
|
@ -2168,3 +2169,13 @@ _feeds:
|
|||
atom: Atom
|
||||
jsonFeed: Feed JSON
|
||||
copyFeed: Copiar feed
|
||||
origin: Origen
|
||||
objectStorageS3ForcePathStyle: Feu servir rutes URLs per a endpoints
|
||||
objectStorageS3ForcePathStyleDesc: Activeu aquesta opció per crear URL per endpoints
|
||||
en el format "s3.amazonaws.com/<bucket>/" sobre "<bucket>.s3.amazonaws.com".
|
||||
deletePasskeys: Suprimeix les contrasenyes
|
||||
deletePasskeysConfirm: Això suprimirà de manera irreversible totes les contrasenyes
|
||||
i claus de seguretat d'aquest compte. Procedir?
|
||||
inputNotMatch: L'entrada no coincideix
|
||||
delete2fa: Desactivar 2FA
|
||||
delete2faConfirm: Això suprimirà irreversiblement 2FA en aquest compte. Procedir?
|
||||
|
|
|
@ -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í
|
||||
|
|
|
@ -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?
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
_lang_: "Deutsch"
|
||||
headlineMisskey: "Eine dezentralisierte Open-Source Social Media Plattform, die für
|
||||
headlineFirefish: "Eine dezentralisierte Open-Source Social Media Plattform, die für
|
||||
immer gratis bleibt! 🚀"
|
||||
introMisskey: "Willkommen! Firefish ist eine dezentralisierte Open-Source Social Media
|
||||
Plattform, die für immer gratis bleibt!🚀"
|
||||
monthAndDay: "{month}/{day}"
|
||||
introFirefish: "Willkommen! Firefish ist eine dezentralisierte Open-Source Social
|
||||
Media Plattform, die für immer gratis bleibt!🚀"
|
||||
monthAndDay: "{day}.{month}."
|
||||
search: "Suchen"
|
||||
notifications: "Benachrichtigungen"
|
||||
username: "Nutzername"
|
||||
|
@ -67,7 +67,7 @@ export: "Export"
|
|||
files: "Dateien"
|
||||
download: "Herunterladen"
|
||||
driveFileDeleteConfirm: "Möchtest du die Datei \"{name}\" wirklich löschen? Es wird
|
||||
aus allen Beiträgen entfernt, die die Datei als Anhang enthalten."
|
||||
aus allen Beiträgen entfernt, welche die Datei als Anhang enthalten."
|
||||
unfollowConfirm: "Bist du dir sicher, daß du {name} nicht mehr folgen möchtest?"
|
||||
exportRequested: "Du hast einen Export angefragt. Dies kann etwas Zeit in Anspruch
|
||||
nehmen. Sobald der Export abgeschlossen ist, wird er deinem Laufwerk hinzugefügt."
|
||||
|
@ -117,7 +117,7 @@ sensitive: "NSFW"
|
|||
add: "Hinzufügen"
|
||||
reaction: "Reaktionen"
|
||||
reactionSetting: "Reaktionen, die in der Reaktionsauswahl angezeigt werden sollen"
|
||||
reactionSettingDescription2: "Ziehen Sie, um neu zu ordnen,\nklicken Sie, um zu löschen,\n
|
||||
reactionSettingDescription2: "Ziehen Sie, um neu zu ordnen, klicken Sie, um zu löschen,
|
||||
drücken Sie \"+\", um hinzuzufügen."
|
||||
rememberNoteVisibility: "Einstellungen für die Sichtbarkeit von Beiträgen speichern"
|
||||
attachCancel: "Anhang entfernen"
|
||||
|
@ -595,7 +595,7 @@ yourAccountSuspendedDescription: "Dieses Nutzerkonto wurde gesperrt, da es gegen
|
|||
menu: "Menü"
|
||||
divider: "Trenner"
|
||||
addItem: "Element hinzufügen"
|
||||
relays: "Relays"
|
||||
relays: "Relais"
|
||||
addRelay: "Relay hinzufügen"
|
||||
inboxUrl: "inbox-URL"
|
||||
addedRelays: "Hinzugefügte Relays"
|
||||
|
@ -666,7 +666,7 @@ overview: "Übersicht"
|
|||
logs: "Protokolle"
|
||||
delayed: "Verzögert"
|
||||
database: "Datenbank"
|
||||
channel: "Channels"
|
||||
channel: "Kanäle"
|
||||
create: "Erstellen"
|
||||
notificationSetting: "Benachrichtigungseinstellungen"
|
||||
notificationSettingDesc: "Wähle die Art der anzuzeigenden Benachrichtigungen."
|
||||
|
@ -777,10 +777,10 @@ nUsers: "{n} Nutzer"
|
|||
nNotes: "{n} Beiträge"
|
||||
sendErrorReports: "Fehlerberichte senden"
|
||||
sendErrorReportsDescription: "Ist diese Option aktiviert, so werden beim Auftreten
|
||||
von Fehlern detaillierte Fehlerinformationen an Firefish weitergegeben, was zur Verbesserung
|
||||
der Qualität von Firefish beiträgt.\nEnthalten in diesen Informationen sind u.a.
|
||||
die Version deines Betriebssystems, welchen Browser du verwendest und ein Verlauf
|
||||
deiner Aktivitäten innerhalb Firefish."
|
||||
von Fehlern detaillierte Fehlerinformationen an Firefish weitergegeben, was zur
|
||||
Verbesserung der Qualität von Firefish beiträgt.\nEnthalten in diesen Informationen
|
||||
sind u.a. die Version deines Betriebssystems, welchen Browser du verwendest und
|
||||
ein Verlauf deiner Aktivitäten innerhalb Firefish."
|
||||
myTheme: "Meine Farbkombination"
|
||||
backgroundColor: "Hintergrundfarbe"
|
||||
accentColor: "Akzentfarbe"
|
||||
|
@ -835,7 +835,7 @@ active: "Aktiv"
|
|||
offline: "Offline"
|
||||
notRecommended: "Nicht empfohlen"
|
||||
botProtection: "Schutz vor Bots"
|
||||
instanceBlocking: "Verbundene Server verwalten"
|
||||
instanceBlocking: "Föderation verwalten"
|
||||
selectAccount: "Nutzerkonto auswählen"
|
||||
switchAccount: "Konto wechseln"
|
||||
enabled: "Aktiviert"
|
||||
|
@ -853,7 +853,7 @@ gallery: "Bilder-Galerie"
|
|||
recentPosts: "Neue Beiträge"
|
||||
popularPosts: "Beliebte Beiträge"
|
||||
shareWithNote: "Mit Beitrag teilen"
|
||||
ads: "Werbeanzeigen"
|
||||
ads: "Community-Banner"
|
||||
expiration: "Frist"
|
||||
memo: "Merkzettel"
|
||||
priority: "Priorität"
|
||||
|
@ -900,14 +900,14 @@ manageAccounts: "Nutzerkonten verwalten"
|
|||
makeReactionsPublic: "Reaktionsverlauf veröffentlichen"
|
||||
makeReactionsPublicDescription: "Jeder wird die Liste deiner gesendeten Reaktionen
|
||||
einsehen können."
|
||||
classic: "Mittig/zentriert"
|
||||
classic: "Zentriert"
|
||||
muteThread: "Thread stummschalten"
|
||||
unmuteThread: "Threadstummschaltung aufheben"
|
||||
ffVisibility: "Sichtbarkeit von Gefolgten/Followern"
|
||||
ffVisibilityDescription: "Konfiguriere wer sehen kann, wem du folgst sowie wer dir
|
||||
folgt."
|
||||
continueThread: "Beitrag fortsetzen"
|
||||
deleteAccountConfirm: "Dein Nutzerkonto wird unwiderruflich gelöscht. Trotzdem fortfahren?"
|
||||
deleteAccountConfirm: "Das Nutzerkonto wird unwiderruflich gelöscht. Trotzdem fortfahren?"
|
||||
incorrectPassword: "Falsches Passwort."
|
||||
voteConfirm: "Wirklich für „{choice}“ abstimmen?"
|
||||
hide: "Inhalt verbergen"
|
||||
|
@ -947,14 +947,15 @@ recentNDays: "Die letzten {n} Tage"
|
|||
noEmailServerWarning: "Es ist kein Email-Server konfiguriert."
|
||||
thereIsUnresolvedAbuseReportWarning: "Es liegen ungelöste Meldungen vor."
|
||||
recommended: "Favoriten"
|
||||
check: "Kontrolle"
|
||||
check: "Überprüfe"
|
||||
driveCapOverrideLabel: "Die Cloud-Drive-Kapazität dieses Nutzers verändern"
|
||||
driveCapOverrideCaption: "Gib einen Wert von 0 oder weniger ein, um die Kapazität
|
||||
auf den Standard zurückzusetzen."
|
||||
requireAdminForView: "Melde dich mit einem Administratorkonto an, um dies einzusehen."
|
||||
isSystemAccount: "Dieses Konto wird vom System erstellt und automatisch verwaltet.
|
||||
Bitte moderieren, bearbeiten, löschen oder manipulieren Sie dieses Konto nicht,
|
||||
da es sonst zu einem Server-Absturz kommen könnte."
|
||||
requireAdminForView: "Du musst dich mit einem Administratorkonto anmelden um dies
|
||||
zu sehen."
|
||||
isSystemAccount: "Ein Nutzerkonto, dass durch das System erstellt und automatisch
|
||||
kontrolliert wird. Jede Anpassung, Veränderung oder Löschung dieses Nutzerkontos,
|
||||
kann zu schwerwiegenden Fehlern auf diesem Server führen."
|
||||
typeToConfirm: "Bitte gib zur Bestätigung {x} ein"
|
||||
deleteAccount: "Nutzerkonto löschen"
|
||||
document: "Dokumentation"
|
||||
|
@ -965,7 +966,7 @@ logoutConfirm: "Wirklich abmelden?"
|
|||
lastActiveDate: "Zuletzt verwendet am"
|
||||
statusbar: "Statusleiste"
|
||||
pleaseSelect: "Wähle eine Option"
|
||||
reverse: "Umkehren"
|
||||
reverse: "Rückgängig machen"
|
||||
colored: "Farbig"
|
||||
refreshInterval: "Aktualisierungsintervall "
|
||||
label: "Beschriftung"
|
||||
|
@ -977,12 +978,12 @@ sensitiveMediaDetection: "Erkennung von NSFW-Medien"
|
|||
localOnly: "Nur Lokal"
|
||||
remoteOnly: "Nur für andere/fremde Server"
|
||||
failedToUpload: "Hochladen fehlgeschlagen"
|
||||
cannotUploadBecauseInappropriate: "Diese Datei kann nicht hochgeladen werden, da Anteile
|
||||
der Datei als möglicherweise NSFW festgestellt wurden."
|
||||
cannotUploadBecauseInappropriate: "Diese Datei kann nicht hochgeladen werden, da Teile
|
||||
der Datei möglicherweise NSFW-Inhalt enthalten."
|
||||
cannotUploadBecauseNoFreeSpace: "Die Datei konnte nicht hochgeladen werden, da dein
|
||||
Cloud-Drive-Speicherplatz aufgebraucht ist."
|
||||
beta: "Beta"
|
||||
enableAutoSensitive: "Selbstständige NSFW-Kennzeichnung"
|
||||
enableAutoSensitive: "Automatische NSFW-Kennzeichnung"
|
||||
enableAutoSensitiveDescription: "Erlaubt, wo möglich, die automatische Erkennung und
|
||||
Kennzeichnung von NSFW-Medien durch maschinelles Lernen. Auch wenn diese Option
|
||||
deaktiviert ist, kann sie über den Server aktiviert sein."
|
||||
|
@ -1005,8 +1006,8 @@ _sensitiveMediaDetection:
|
|||
setSensitiveFlagAutomaticallyDescription: "Die Resultate der internen Erkennung
|
||||
werden beibehalten, auch wenn diese Option deaktiviert ist."
|
||||
analyzeVideos: "Videoanalyse aktivieren"
|
||||
analyzeVideosDescription: "Analysiert zusätzlich zu Bildern auch Videos. Die Last
|
||||
des Servers wird hierdurch etwas erhöht."
|
||||
analyzeVideosDescription: "Analysiert zusätzlich zu Bildern auch Videos. Die Serverlast
|
||||
wird hierdurch etwas erhöht."
|
||||
_emailUnavailable:
|
||||
used: "Diese Email-Adresse wird bereits verwendet"
|
||||
format: "Das Format dieser Email-Adresse ist ungültig"
|
||||
|
@ -1020,17 +1021,17 @@ _ffVisibility:
|
|||
_signup:
|
||||
almostThere: "Fast geschafft"
|
||||
emailAddressInfo: "Bitte gib deine Email-Adresse ein. Sie wird nicht öffentlich
|
||||
einsehbar sein."
|
||||
sichtbar sein."
|
||||
emailSent: "An deine Email-Adresse ({email}) wurde soeben eine Bestätigungsmail
|
||||
geschickt. Bitte klicke auf den enthaltenen Link, um die Erstellung deines Nutzerkontos
|
||||
abzuschließen."
|
||||
_accountDelete:
|
||||
accountDelete: "Nutzerkonto löschen"
|
||||
mayTakeTime: "Da die Löschung eines Nutzerkontos ein aufwendiger Prozess ist, kann
|
||||
dessen Dauer davon abhängen, wie viel Inhalt von diesem erstellt wurde oder wie
|
||||
dessen Dauer davon abhängen, wie viel Inhalt von diesem erstellt wurde und wie
|
||||
viele Dateien von diesem hochgeladen wurden."
|
||||
sendEmail: "Sobald die Löschung abgeschlossen ist, wird an die mit ihm verknüpfte
|
||||
Email-Adresse eine Benachrichtigung versendet."
|
||||
sendEmail: "Sobald die Löschung abgeschlossen ist, wird an die registrierte Email-Adresse
|
||||
eine Benachrichtigung versendet."
|
||||
requestAccountDelete: "Löschung deines Nutzerkontos anfordern"
|
||||
started: "Die Löschung wurde eingeleitet."
|
||||
inProgress: "Löschung in Bearbeitung"
|
||||
|
@ -1060,19 +1061,19 @@ _plugin:
|
|||
manage: "Plugins verwalten"
|
||||
_preferencesBackups:
|
||||
list: "Erstellte Backups"
|
||||
saveNew: "Neu erstellen"
|
||||
saveNew: "Neues Backup speichern"
|
||||
loadFile: "Von Datei laden"
|
||||
apply: "Auf dieses Gerät anwenden"
|
||||
save: "Speichern"
|
||||
save: "Änderungen speichern"
|
||||
inputName: "Gib einen Namen für dieses Backup ein"
|
||||
cannotSave: "Speichern fehlgeschlagen"
|
||||
nameAlreadyExists: "Es existiert bereits ein Backup unter dem Namen \"{name}\".
|
||||
Bitte gib einen anderen Namen ein."
|
||||
applyConfirm: "Wirklich das Backup \"{name}\" auf dieses Gerät anwenden? Bestehende
|
||||
Einstellungen darauf werden überschrieben."
|
||||
saveConfirm: "Als {name} speichern?"
|
||||
saveConfirm: "Backup als {name} speichern?"
|
||||
deleteConfirm: "Das Backup {name} löschen?"
|
||||
renameConfirm: "Soll dieses Backup von \"{old}\" zu \"{new}\" umbenannt werden?"
|
||||
renameConfirm: "Backup von \"{old}\" zu \"{new}\" umbenennen?"
|
||||
noBackups: "Keine Backups existieren. Backups können über \"Neu erstellen\" erstelllt
|
||||
werden."
|
||||
createdAt: "Erstellt am: {date} {time}"
|
||||
|
@ -1096,10 +1097,19 @@ _aboutFirefish:
|
|||
morePatrons: "Wir schätzen ebenso die Unterstützung vieler anderer hier nicht gelisteter
|
||||
Personen sehr. Danke! 🥰"
|
||||
patrons: "UnterstützerInnen"
|
||||
patronsList: Auflistung chonologisch, nicht nach Spenden-Größe. Spende über den
|
||||
Link oben, um hier aufgeführt zu werden!
|
||||
donateTitle: Gefällt dir Firefish?
|
||||
pleaseDonateToFirefish: Bitte erwäge eine Spende an Firefish, um dessen Entwicklung
|
||||
zu unterstützen.
|
||||
pleaseDonateToHost: Bitte erwäge auch, an deinen Heimatserver {host} zu spenden,
|
||||
um bei der Deckung der Betriebskosten zu helfen.
|
||||
sponsors: Firefish-Sponsoren
|
||||
donateHost: Spende an {host}
|
||||
_nsfw:
|
||||
respect: "Mit NSFW gekennzeichnete Bilder verbergen"
|
||||
ignore: "Mit NSFW gekennzeichnete Bilder nicht verbergen"
|
||||
force: "Alle Medien verbergen"
|
||||
respect: "Mit NSFW gekennzeichnete Mediendateien verbergen"
|
||||
ignore: "Mit NSFW gekennzeichnete Mediendateien nicht verbergen"
|
||||
force: "Alle Mediendateien verbergen"
|
||||
_mfm:
|
||||
cheatSheet: "MFM Spickzettel"
|
||||
intro: "MFM ist eine Markup-Sprache, die in Misskey, Firefish, Akkoma und anderen
|
||||
|
@ -1118,7 +1128,7 @@ _mfm:
|
|||
bold: "Fett"
|
||||
boldDescription: "Zeichen zur Betonung dicker erscheinen lassen."
|
||||
small: "Klein"
|
||||
smallDescription: "Inhalt klein und dünn erscheinen lassen."
|
||||
smallDescription: "Inhalt klein und dünn anzeigen."
|
||||
center: "Zentrieren"
|
||||
centerDescription: "Inhalt zentriert anzeigen."
|
||||
inlineCode: "Code (Eingebettet)"
|
||||
|
@ -1138,7 +1148,7 @@ _mfm:
|
|||
search: "Suche"
|
||||
searchDescription: "Eine vorgefertige Suchanfragebox anzeigen."
|
||||
flip: "Spiegelung"
|
||||
flipDescription: "Inhalt horizontal oder vertikal gespiegelt anzeigen."
|
||||
flipDescription: "Inhalt horizontal oder vertikal spiegeln."
|
||||
jelly: "Animation (Dehnen)"
|
||||
jellyDescription: "Verleiht Inhalt eine sich dehnende Animation."
|
||||
tada: "Animation (Tada)"
|
||||
|
@ -1183,14 +1193,15 @@ _mfm:
|
|||
crop: Zuschneiden
|
||||
scale: Maßstab
|
||||
scaleDescription: Skaliere den Inhalt um einen bestimmten Betrag.
|
||||
foregroundDescription: Ändern der Vordergrundfarbe von Text.
|
||||
backgroundDescription: Ändern der Hintergrundfarbe von Text
|
||||
foregroundDescription: Vordergrundfarbe des Texts ändern.
|
||||
backgroundDescription: Hintergrundfarbe des Texts ändern.
|
||||
play: MFM abspielen
|
||||
stop: MFM anhalten
|
||||
warn: MFM können schnell bewegte oder anderweitig auffallende Animationen enthalten
|
||||
alwaysPlay: Alle animierten MFM immer automatisch abspielen
|
||||
advancedDescription: Wenn diese Funktion deaktiviert ist, können nur einfache Formatierungen
|
||||
vorgenommen werden, es sei denn, animiertes MFM ist aktiviert
|
||||
advanced: Erweitertes MFM
|
||||
_instanceTicker:
|
||||
none: "Nie anzeigen"
|
||||
remote: "Für Nutzer eines anderen Servers anzeigen"
|
||||
|
@ -1404,6 +1415,7 @@ _2fa:
|
|||
registerTOTPBeforeKey: Bitte registriere eine Authentificator App, um einen Hardware-Security-Key
|
||||
oder einen Passkey zu nutzen.
|
||||
securityKeyName: Gib einen Namen für den Key ein
|
||||
token: 2FA Token
|
||||
_permissions:
|
||||
"read:account": "Deine Nutzerkontoinformationen lesen"
|
||||
"write:account": "Deine Nutzerkontoinformationen bearbeiten"
|
||||
|
@ -1444,11 +1456,12 @@ _auth:
|
|||
zu können?"
|
||||
shareAccessAsk: "Bist du dir sicher, dass du diese Anwendung authorisieren möchtest,
|
||||
auf dein Nutzerkonto zugreifen zu können?"
|
||||
permissionAsk: "Diese Anwendung fordert folgende Berechtigungen"
|
||||
permissionAsk: "Diese Anwendung fordert folgende Berechtigungen:"
|
||||
pleaseGoBack: "Bitte kehre zur Anwendung zurück"
|
||||
callback: "Es wird zur Anwendung zurückgekehrt"
|
||||
denied: "Zugriff verweigert"
|
||||
copyAsk: Bitte fügen Sie den folgenden Autorisierungscode in die Anwendung ein
|
||||
copyAsk: 'Bitte fügen Sie den folgenden Autorisierungscode in die Anwendung ein:'
|
||||
allPermissions: Vollständiger Kontozugriff
|
||||
_antennaSources:
|
||||
all: "Alle Beiträge"
|
||||
homeTimeline: "Beiträge von Nutzern, denen gefolgt wird"
|
||||
|
@ -1482,7 +1495,7 @@ _widgets:
|
|||
postForm: "Beitragsfeld"
|
||||
slideshow: "Diashow"
|
||||
button: "Knopf"
|
||||
onlineUsers: "Nutzer Online"
|
||||
onlineUsers: "Nutzer online"
|
||||
jobQueue: "Job-Warteschlange"
|
||||
serverMetric: "Servermetriken"
|
||||
aiscript: "AiScript-Konsole"
|
||||
|
@ -1523,11 +1536,12 @@ _poll:
|
|||
remainingSeconds: "{s} Sekunde(n) verbleibend"
|
||||
_visibility:
|
||||
public: "Öffentlich"
|
||||
publicDescription: "Dein Beitrag wird global für alle Nutzer sichtbar sein"
|
||||
publicDescription: "Dein Beitrag wird global in allen öffentlichen Timelines sichtbar
|
||||
sein"
|
||||
home: "nicht aufgelistet"
|
||||
homeDescription: "Beitrag nur auf der Home-Timeline anzeigen"
|
||||
followers: "Follower"
|
||||
followersDescription: "Nur für Follower sichtbar"
|
||||
followersDescription: "Nur für Follower und erwähnte Nutzer sichtbar"
|
||||
specified: "Direkt"
|
||||
specifiedDescription: "Nur für bestimmte Nutzer sichtbar"
|
||||
localOnly: "Nur Lokal"
|
||||
|
@ -1551,7 +1565,8 @@ _profile:
|
|||
metadata: "Zusätzliche Informationen"
|
||||
metadataEdit: "Zusätzliche Informationen bearbeiten"
|
||||
metadataDescription: "Hierdurch kannst du auf deinem Profil zusätzliche Informationsblöcke
|
||||
anzeigen lassen. Sie können ein {a}-Tag oder ein {l}-Tag mit {rel} hinzufügen, um den Link in Ihrem Profil zu überprüfen!"
|
||||
anzeigen lassen. Sie können ein {a}-Tag oder ein {l}-Tag mit {rel} hinzufügen,
|
||||
um den Link in Ihrem Profil zu überprüfen!"
|
||||
metadataLabel: "Beschriftung"
|
||||
metadataContent: "Inhalt"
|
||||
changeAvatar: "Profilbild ändern"
|
||||
|
@ -1574,7 +1589,7 @@ _charts:
|
|||
activeUsers: "Aktive Nutzer"
|
||||
notesIncDec: "Unterschied bei der Anzahl an Beiträgen"
|
||||
localNotesIncDec: "Unterschied bei der Anzahl an lokalen Beiträgen"
|
||||
remoteNotesIncDec: "Differenz zur Anzahl von Beiträgen von anderen Servern."
|
||||
remoteNotesIncDec: "Differenz bei der Anzahl an Beiträgen von anderen Servern"
|
||||
notesTotal: "Anzahl aller Beiträge"
|
||||
filesIncDec: "Unterschied in der Anzahl an Dateien"
|
||||
filesTotal: "Anzahl aller Dateien"
|
||||
|
@ -1628,7 +1643,7 @@ _pages:
|
|||
hideTitleWhenPinned: "Nutzer-Seitentitel wenn angeheftet ausblenden"
|
||||
font: "Schriftart"
|
||||
fontSerif: "Serif"
|
||||
fontSansSerif: "sans-serif"
|
||||
fontSansSerif: "Sans Serif"
|
||||
eyeCatchingImageSet: "Vorschaubild festlegen"
|
||||
eyeCatchingImageRemove: "Vorschaubild entfernen"
|
||||
chooseBlock: "Block hinzufügen"
|
||||
|
@ -1643,7 +1658,7 @@ _pages:
|
|||
text: "Text"
|
||||
textarea: "Textfeld"
|
||||
section: "Abschnitt"
|
||||
image: "Bild"
|
||||
image: "Bilder"
|
||||
button: "Knopf"
|
||||
if: "Falls"
|
||||
_if:
|
||||
|
@ -1971,9 +1986,8 @@ enableEmojiReactions: Emoji-Reaktionen aktivieren
|
|||
flagSpeakAsCat: Wie eine Katze sprechen
|
||||
showEmojisInReactionNotifications: Emojis in Reaktionsbenachrichtigungen anzeigen
|
||||
userSaysSomethingReason: '{name} sagte {reason}'
|
||||
hiddenTagsDescription: 'Geben sie hier die Schlagworte (ohne #hashtag) an, die vom
|
||||
"Trending and Explore" ausgeschlossen werden sollen. Versteckte Schlagworte sind
|
||||
immer noch über andere Wege auffindbar.'
|
||||
hiddenTagsDescription: 'Liste die Hashtags (ohne #) welche du von Trending und Explore
|
||||
verstecken möchtest. Versteckte Hashtags sind durch andere Wege weiterhin auffindbar.'
|
||||
addInstance: Server hinzufügen
|
||||
flagSpeakAsCatDescription: Deine Beiträge werden im Katzenmodus nyanisiert
|
||||
hiddenTags: Versteckte Hashtags
|
||||
|
@ -1983,8 +1997,8 @@ renoteMute: Boosts stummschalten
|
|||
renoteUnmute: Stummschaltung von Boosts aufheben
|
||||
noInstances: Keine Server gefunden
|
||||
privateModeInfo: Wenn diese Option aktiviert ist, können nur als vertrauenswürdig
|
||||
eingestufte Server mit diesem Server kommunizieren. Alle Beiträge werden für die
|
||||
Öffentlichkeit verborgen.
|
||||
eingestufte Server mit diesem Server föderieren. Alle Beiträge werden für die Öffentlichkeit
|
||||
verborgen.
|
||||
allowedInstances: Vertrauenswürdige Server
|
||||
selectInstance: Wähle einen Server aus
|
||||
silencedInstancesDescription: Liste die Hostnamen der Server auf, die du stummschalten
|
||||
|
@ -2019,14 +2033,14 @@ moveAccountDescription: 'Dieser Vorgang kann nicht rückgängig gemacht werden!
|
|||
wie folgt ein: @name@server.xyz'
|
||||
findOtherInstance: Einen anderen Server finden
|
||||
sendPushNotificationReadMessage: Löschung der Push-Benachrichtigungen sobald die entsprechenden
|
||||
Benachrichtigungen oder Beiträge gelesen wurden.
|
||||
Benachrichtigungen oder Nachrichten gelesen wurden
|
||||
signupsDisabled: Derzeit sind keine Anmeldungen auf diesem Server möglich! Anmeldungen
|
||||
auf anderen Servern sind jedoch möglich! Wenn Sie einen Einladungscode für diesen
|
||||
Server haben, geben Sie ihn bitte unten ein.
|
||||
swipeOnDesktop: Am Desktop PC das Wischen wie bei mobilen Geräten zulassen
|
||||
enterSendsMessage: Drücken sie zum Senden des Beitrages die Eingabetaste (Strg-Taste
|
||||
ausgeschaltet)
|
||||
showUpdates: Zeigt ein Popup-Fenster an, wenn Firefish aktualisiert wird.
|
||||
showUpdates: Zeige ein Popup-Fenster an, wenn Firefish aktualisiert wird
|
||||
socialTimeline: Social-Timeline
|
||||
moveFrom: Bisheriges Nutzerkonto zu diesem Nutzerkonto umziehen
|
||||
_messaging:
|
||||
|
@ -2039,7 +2053,7 @@ userSaysSomethingReasonReply: '{name} hat auf einen Beitrag geantwortet der {rea
|
|||
userSaysSomethingReasonRenote: '{name} hat einen Beitrag geteilt der {reason} beinhaltet'
|
||||
userSaysSomethingReasonQuote: '{name} hat einen Beitrag zitiert der {reason} beinhaltet'
|
||||
seperateRenoteQuote: Getrennte Boost- und Zitat-Schaltflächen
|
||||
showAds: Anzeigen anzeigen
|
||||
showAds: Community-Banner anzeigen
|
||||
splash: Begrüßungsbildschirm
|
||||
customSplashIconsDescription: URLs für benutzerdefinierte Splash-Screen-Symbole, die
|
||||
durch Zeilenumbrüche getrennt sind und nach dem Zufallsprinzip jedes Mal angezeigt
|
||||
|
@ -2053,18 +2067,17 @@ adminCustomCssWarn: Diese Einstellung sollte nur verwendet werden, wenn Sie wiss
|
|||
mehr normal funktionieren. Bitte stellen Sie sicher, dass Ihr CSS ordnungsgemäß
|
||||
funktioniert, indem Sie es in Ihren Benutzereinstellungen testen.
|
||||
customMOTD: Benutzerdefinierte Meldung des Tages (Begrüßungsbildschirmmeldungen)
|
||||
allowedInstancesDescription: Hosts von Servern, die zur Verbindung auf die Liste vertrauenswürdiger
|
||||
Server gesetzt werden sollen, werden jeweils durch eine neue Zeile getrennt eingegeben
|
||||
(gilt nur im privaten Modus).
|
||||
allowedInstancesDescription: Hostnamen von Servern, die auf der Liste vertrauenswürdiger
|
||||
Server für die Föderation stehen sollen, jeweils getrennt in einer neuen Zeile (tritt
|
||||
nur im privaten Modus in Kraft).
|
||||
migration: Migration
|
||||
updateAvailable: Es könnte eine Aktualisierung verfügbar sein!
|
||||
updateAvailable: Es könnte ein Update verfügbar sein!
|
||||
showAdminUpdates: Anzeigen, dass eine neue Firefish-Version verfügbar ist (nur Administrator)
|
||||
customMOTDDescription: Benutzerdefinierte Meldungen für die Meldung des Tages (Begrüßungsbildschirm),
|
||||
die durch Zeilenumbrüche getrennt sind und nach dem Zufallsprinzip jedes Mal angezeigt
|
||||
werden, wenn ein Benutzer die Seite (neu) lädt.
|
||||
recommendedInstancesDescription: Empfohlene Server, die durch Zeilenumbrüche getrennt
|
||||
sind, werden in der "Favoriten"-Timeline angezeigt. Fügen Sie NICHT "https://" hinzu,
|
||||
sondern NUR die Domain.
|
||||
sind, werden in der "Favoriten"-Timeline angezeigt.
|
||||
sendModMail: Moderationshinweis senden
|
||||
moveFromDescription: 'Dadurch wird ein Alias Ihres alten Nutzerkontos festgelegt,
|
||||
sodass Sie von ihrem bisherigen Konto zu diesem Nutzerkonto wechseln können. Tun
|
||||
|
@ -2073,7 +2086,7 @@ moveFromDescription: 'Dadurch wird ein Alias Ihres alten Nutzerkontos festgelegt
|
|||
preventAiLearning: KI gestütztes bot-scraping unterdrücken
|
||||
preventAiLearningDescription: Fordern Sie KI-Sprachmodelle von Drittanbietern auf,
|
||||
die von Ihnen hochgeladenen Inhalte, wie z. B. Beiträge und Bilder, nicht zu untersuchen.
|
||||
license: Genehmigung
|
||||
license: Lizenz
|
||||
indexPosts: Gelistete Beiträge
|
||||
migrationConfirm: "Sind Sie absolut sicher, dass Sie Ihr Nutzerkonto zu diesem {account}
|
||||
umziehen möchten? Sobald Sie dies bestätigt haben, kann dies nicht mehr rückgängig
|
||||
|
@ -2106,12 +2119,12 @@ indexFrom: Indexieren ab Beitragskennung aufwärts
|
|||
indexNotice: Wird jetzt indexiert. Dies wird wahrscheinlich eine Weile dauern, bitte
|
||||
starten Sie Ihren Server für mindestens eine Stunde nicht neu.
|
||||
customKaTeXMacroDescription: "Richten Sie Makros ein, um mathematische Ausdrücke einfach
|
||||
zu schreiben! Die Notation entspricht den LaTeX-Befehlsdefinitionen und wird als\n
|
||||
\\newcommand{\\name}{content} or \\newcommand{\\name}[number of arguments]{content}\n
|
||||
geschrieben.\nZum Beispiel wird\n\\newcommand{\\add}[2]{#1 + #2} \\add{3}{foo} um
|
||||
3 + foo erweitert.\nDie geschweiften Klammern, die den Makronamen umgeben, können
|
||||
in runde oder eckige Klammern geändert werden. Dies hat Auswirkungen auf die Klammern,
|
||||
die für die Argumente verwendet werden. Pro Zeile kann ein (und nur ein) Makro definiert
|
||||
zu schreiben! Die Notation entspricht den LaTeX-Befehlsdefinitionen und wird als
|
||||
\\newcommand{\\name}{content} oder \\newcommand{\\name}[number of arguments]{content}
|
||||
geschrieben. Zum Beispiel wird \\newcommand{\\add}[2]{#1 + #2} \\add{3}{foo} erweitern
|
||||
zu 3 + foo. Die geschweiften Klammern, die den Makro-Namen umgeben, können in runde
|
||||
oder eckige Klammern geändert werden. Dies hat Auswirkungen auf die Klammern, die
|
||||
für die Argumente verwendet werden. Pro Zeile kann ein (und nur ein) Makro definiert
|
||||
werden, und Sie können die Zeile nicht mitten in der Definition umbrechen. Ungültige
|
||||
Zeilen werden einfach ignoriert. Es werden nur einfache Funktionen zur Substitution
|
||||
von Zeichenketten unterstützt; erweiterte Syntax, wie z. B. bedingte Verzweigungen,
|
||||
|
@ -2131,6 +2144,7 @@ _filters:
|
|||
fromDomain: Von Domain
|
||||
notesBefore: Beiträge vor
|
||||
followingOnly: Nur Folgende
|
||||
followersOnly: Nur Follower
|
||||
isBot: Dieses Konto ist ein Bot
|
||||
isModerator: Moderator
|
||||
isAdmin: Administrator
|
||||
|
@ -2141,7 +2155,7 @@ _dialog:
|
|||
searchPlaceholder: Firefish durchsuchen
|
||||
antennasDesc: "Antennen zeigen neue Posts an, die deinen definierten Kriterien entsprechen!\n
|
||||
Sie können von der Timeline-Seite aufgerufen werden."
|
||||
isPatron: Firefish Patron
|
||||
isPatron: Firefish-Patron
|
||||
removeReaction: Entferne deine Reaktion
|
||||
listsDesc: Listen lassen dich Timelines mit bestimmten Nutzer:innen erstellen. Sie
|
||||
können von der Timeline-Seite erreicht werden.
|
||||
|
@ -2150,3 +2164,40 @@ clipsDesc: Clips sind wie teilbare, kategorisierte Lesezeichen. Du kannst Clips
|
|||
channelFederationWarn: Kanäle föderieren noch nicht zu anderen Servern
|
||||
reactionPickerSkinTone: Bevorzugte Emoji-Hautfarbe
|
||||
swipeOnMobile: Wischen zwischen den Seiten erlauben
|
||||
enableServerMachineStats: Server-Hardware-Statistik einschalten
|
||||
enableIdenticonGeneration: Identicon-Generierung einschalten
|
||||
verifiedLink: Verifizierter Link
|
||||
_feeds:
|
||||
copyFeed: Feed kopieren
|
||||
jsonFeed: JSON-Feed
|
||||
rss: RSS
|
||||
atom: Atom
|
||||
youHaveUnreadAnnouncements: Du hast ungelesene Ankündigungen
|
||||
donationLink: Link zur Spenden-Seite
|
||||
remindMeLater: Vielleicht später
|
||||
neverShow: Nicht wieder zeigen
|
||||
removeRecipient: Empfänger entfernen
|
||||
removeMember: Mitglied entfernen
|
||||
alt: ALT
|
||||
xl: XL
|
||||
isLocked: Dieser Account hat Folge-Anfragen aktiviert
|
||||
_skinTones:
|
||||
mediumLight: Mittelhell
|
||||
yellow: Gelb
|
||||
light: Hell
|
||||
medium: Mittel
|
||||
dark: Dunkel
|
||||
mediumDark: Mitteldunkel
|
||||
showPopup: Benutzer mit Popup benachrichtigen
|
||||
showWithSparkles: Mit Glitzer anzeigen
|
||||
removeQuote: Zitat entfernen
|
||||
objectStorageS3ForcePathStyle: Verwende pfadbasierte Endpunkt-URLs
|
||||
objectStorageS3ForcePathStyleDesc: Wenn aktiviert, werden Endpunkt-URLs im Format
|
||||
's3.amazonaws.com/<bucket>/' statt '<bucket>.s3.amazonaws.com' erstellt.
|
||||
origin: Herkunft
|
||||
delete2fa: 2FA deaktivieren
|
||||
deletePasskeys: Passkeys löschen
|
||||
delete2faConfirm: Passkeys werden unwiderruflich von diesem Account gelöscht. Fortfahren?
|
||||
deletePasskeysConfirm: Alle Passkeys und Security-Keys werden unwiderruflich von diesem
|
||||
Account gelöscht. Fortfahren?
|
||||
inputNotMatch: Eingabe stimmt nicht überein
|
||||
|
|
|
@ -568,9 +568,9 @@ yourAccountSuspendedTitle: Αυτός ο λογαριασμός έχει απο
|
|||
leaveConfirm: Υπάρχουν αλλαγές που δεν έχουν σωθεί. Θέλετε να τις απορρίψετε;
|
||||
height: Ύψος
|
||||
edit: Επεξεργασία
|
||||
headlineMisskey: Μία ανοιχτού λογισμικού, αποκεντρωμένη πλατφόρμα κοινωνικής δικτύωσης
|
||||
headlineFirefish: Μία ανοιχτού λογισμικού, αποκεντρωμένη πλατφόρμα κοινωνικής δικτύωσης
|
||||
που θα είναι για πάντα ελεύθερη! 🚀
|
||||
introMisskey: Καλώς ήρθατε! Το Firefish είναι μία ανοιχτού λογισμικού, αποκεντρωμένη
|
||||
introFirefish: Καλώς ήρθατε! Το Firefish είναι μία ανοιχτού λογισμικού, αποκεντρωμένη
|
||||
πλατφόρμα κοινωνικής δικτύωσης που θα είναι για πάντα ελεύθερη! 🚀
|
||||
markAsSensitive: Επισήμανση ως Ευαίσθητο Περιεχόμενο (NSFW)
|
||||
autoAcceptFollowed: Αυτόματη έγκριση αιτημάτων ακολούθησης από λογαριασμούς που ακολουθείτε
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
_lang_: "English"
|
||||
headlineMisskey: "An open source, decentralized social media platform that's free
|
||||
headlineFirefish: "An open source, decentralized social media platform that's free
|
||||
forever! 🚀"
|
||||
introMisskey: "Welcome! Firefish is an open source, decentralized social media platform
|
||||
introFirefish: "Welcome! Firefish is an open source, decentralized social media platform
|
||||
that's free forever! 🚀"
|
||||
monthAndDay: "{month}/{day}"
|
||||
search: "Search"
|
||||
|
@ -566,6 +566,9 @@ objectStorageUseProxy: "Connect over Proxy"
|
|||
objectStorageUseProxyDesc: "Turn this off if you are not going to use a Proxy for
|
||||
API connections"
|
||||
objectStorageSetPublicRead: "Set \"public-read\" on upload"
|
||||
objectStorageS3ForcePathStyle: "Use path-based endpoint URLs"
|
||||
objectStorageS3ForcePathStyleDesc: "Turn this on to construct endpoint URLs in the
|
||||
format of 's3.amazonaws.com/<bucket>/' over '<bucket>.s3.amazonaws.com'."
|
||||
serverLogs: "Server logs"
|
||||
deleteAll: "Delete all"
|
||||
showFixedPostForm: "Display the posting form at the top of the timeline"
|
||||
|
@ -872,7 +875,7 @@ gallery: "Gallery"
|
|||
recentPosts: "Recent pages"
|
||||
popularPosts: "Popular pages"
|
||||
shareWithNote: "Share with post"
|
||||
ads: "Advertisements"
|
||||
ads: "Community banners"
|
||||
expiration: "Deadline"
|
||||
memo: "Memo"
|
||||
priority: "Priority"
|
||||
|
@ -938,7 +941,7 @@ ffVisibility: "Follows/Followers Visibility"
|
|||
ffVisibilityDescription: "Allows you to configure who can see who you follow and who
|
||||
follows you."
|
||||
continueThread: "Continue thread"
|
||||
deleteAccountConfirm: "This will irreversibly delete your account. Proceed?"
|
||||
deleteAccountConfirm: "This will irreversibly delete this account. Proceed?"
|
||||
incorrectPassword: "Incorrect password."
|
||||
voteConfirm: "Confirm your vote for \"{choice}\"?"
|
||||
hide: "Hide"
|
||||
|
@ -1035,7 +1038,7 @@ sendPushNotificationReadMessage: "Delete push notifications once the relevant no
|
|||
sendPushNotificationReadMessageCaption: "A notification containing the text \"{emptyPushNotificationMessage}\"\
|
||||
\ will be displayed for a short time. This may increase the battery usage of your
|
||||
device, if applicable."
|
||||
showAds: "Show ads"
|
||||
showAds: "Show community banners"
|
||||
enterSendsMessage: "Press Return in Messaging to send message (off is Ctrl + Return)"
|
||||
adminCustomCssWarn: "This setting should only be used if you know what it does. Entering
|
||||
improper values may cause EVERYONE'S clients to stop functioning normally. Please
|
||||
|
@ -1125,6 +1128,13 @@ removeQuote: "Remove quote"
|
|||
removeRecipient: "Remove recipient"
|
||||
removeMember: "Remove member"
|
||||
verifiedLink: "Verified link"
|
||||
origin: "Origin"
|
||||
delete2fa: "Disable 2FA"
|
||||
deletePasskeys: "Delete passkeys"
|
||||
delete2faConfirm: "This will irreversibly delete 2FA on this account. Proceed?"
|
||||
deletePasskeysConfirm: "This will irreversibly delete all passkeys and security keys on this account. Proceed?"
|
||||
inputNotMatch: "Input does not match"
|
||||
addRe: "Add \"re:\" at the beginning of comment in reply to a post with a content warning"
|
||||
|
||||
_sensitiveMediaDetection:
|
||||
description: "Reduces the effort of server moderation through automatically recognizing
|
||||
|
@ -1220,6 +1230,7 @@ _aboutFirefish:
|
|||
development since 2022."
|
||||
contributors: "Main contributors"
|
||||
allContributors: "All contributors"
|
||||
misskeyContributors: "Misskey contributors"
|
||||
source: "Source code"
|
||||
translation: "Translate Firefish"
|
||||
donate: "Donate to Firefish"
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
_lang_: "Español"
|
||||
headlineMisskey: "¡Un proyecto de código abierto y una plataforma de medios de comunicación
|
||||
headlineFirefish: "¡Un proyecto de código abierto y una plataforma de medios de comunicación
|
||||
descentralizada que es gratis para siempre! 🚀"
|
||||
introMisskey: "¡Bienvenido! ¡Firefish es un proyecto de código abierto, plataforma
|
||||
introFirefish: "¡Bienvenido! ¡Firefish es un proyecto de código abierto, plataforma
|
||||
descentralizado medios de comunicación social que es gratis para siempre! 🚀"
|
||||
monthAndDay: "{day}/{month}"
|
||||
search: "Buscar"
|
||||
|
@ -161,7 +161,7 @@ autoAcceptFollowed: "Aceptar automáticamente las solicitudes de seguimiento de
|
|||
usuarios que sigues"
|
||||
addAccount: "Agregar Cuenta"
|
||||
loginFailed: "Error al iniciar sesión"
|
||||
showOnRemote: "Ver en servidor remoto"
|
||||
showOnRemote: "Abrir página original"
|
||||
general: "General"
|
||||
wallpaper: "Fondo de pantalla"
|
||||
setWallpaper: "Establecer fondo de pantalla"
|
||||
|
@ -540,7 +540,7 @@ objectStorageSetPublicRead: "Seleccionar \"public-read\" al subir "
|
|||
serverLogs: "Registros del servidor"
|
||||
deleteAll: "Eliminar todos"
|
||||
showFixedPostForm: "Mostrar el formulario de las entradas encima de la línea de tiempo"
|
||||
newNoteRecived: "Tienes unas publicaciones nuevas"
|
||||
newNoteRecived: "Hay publicaciones nuevas"
|
||||
sounds: "Sonidos"
|
||||
listen: "Escuchar"
|
||||
none: "Ninguna"
|
||||
|
@ -690,7 +690,7 @@ instanceTicker: "Información de publicaciones de el servidor"
|
|||
waitingFor: "Esperando a {x}"
|
||||
random: "Aleatorio"
|
||||
system: "Sistema"
|
||||
switchUi: "Cambiar interfaz de usuario"
|
||||
switchUi: "Interfaz"
|
||||
desktop: "Escritorio"
|
||||
clip: "Clip"
|
||||
createNew: "Crear"
|
||||
|
@ -700,15 +700,15 @@ unclip: "Quitar clip"
|
|||
confirmToUnclipAlreadyClippedNote: "Esta publicación ya está incluida en el clip \"\
|
||||
{name}\". ¿Quiere quitar la nota del clip?"
|
||||
public: "Público"
|
||||
i18nInfo: "Firefish está siendo traducido a varios idiomas gracias a voluntarios. Se
|
||||
puede colaborar traduciendo en {link}"
|
||||
i18nInfo: "Firefish está siendo traducido a varios idiomas gracias a voluntarios.
|
||||
Se puede colaborar traduciendo en {link}"
|
||||
manageAccessTokens: "Administrar tokens de acceso"
|
||||
accountInfo: "Información de la Cuenta"
|
||||
notesCount: "Cantidad de publicaciones"
|
||||
repliesCount: "Cantidad de respuestas hechas"
|
||||
renotesCount: "Cantidad de renotas hechas"
|
||||
renotesCount: "Número de impulsos enviados"
|
||||
repliedCount: "Cantidad de respuestas recibidas"
|
||||
renotedCount: "Cantidad de renotas recibidas"
|
||||
renotedCount: "Cantidad de impulsos recibidos"
|
||||
followingCount: "Cantidad de seguidos"
|
||||
followersCount: "Cantidad de seguidores"
|
||||
sentReactionsCount: "Cantidad de reacciones hechas"
|
||||
|
@ -722,9 +722,9 @@ driveUsage: "Uso del drive"
|
|||
noCrawle: "Rechazar indexación del crawler"
|
||||
noCrawleDescription: "Pedir a los motores de búsqueda que no indexen tu perfil, publicaciones,
|
||||
páginas, etc."
|
||||
lockedAccountInfo: "A menos que configures la visibilidad de tus notas como \"Sólo
|
||||
seguidores\", tus notas serán visibles para cualquiera, incluso si requieres que
|
||||
los seguidores sean aprobados manualmente."
|
||||
lockedAccountInfo: "A menos que configures la visibilidad de tus publicaciones como
|
||||
\"Sólo seguidores\", tus publicaciones serán visibles para cualquiera, incluso si
|
||||
requieres que los seguidores sean aprobados manualmente."
|
||||
alwaysMarkSensitive: "Marcar los medios de comunicación como contenido sensible por
|
||||
defecto"
|
||||
loadRawImages: "Cargar las imágenes originales en lugar de mostrar las miniaturas"
|
||||
|
@ -758,7 +758,7 @@ showTitlebar: "Mostrar la barra de título"
|
|||
clearCache: "Limpiar caché"
|
||||
onlineUsersCount: "{n} usuarios en línea"
|
||||
nUsers: "{n} Usuarios"
|
||||
nNotes: "{n} Notas"
|
||||
nNotes: "{n} Publicaciones"
|
||||
sendErrorReports: "Envíar informe de errores"
|
||||
sendErrorReportsDescription: "Si habilita esta opción, los detalles de los errores
|
||||
serán compartidos con Firefish cuando ocurra un problema, lo que ayudará a mejorar
|
||||
|
@ -788,7 +788,7 @@ capacity: "Capacidad"
|
|||
inUse: "Usado"
|
||||
editCode: "Editar código"
|
||||
apply: "Aplicar"
|
||||
receiveAnnouncementFromInstance: "Recibir notificaciones de la instancia"
|
||||
receiveAnnouncementFromInstance: "Recibir notificaciones de este servidor"
|
||||
emailNotification: "Notificaciones por correo electrónico"
|
||||
publish: "Publicar"
|
||||
inChannelSearch: "Buscar en el canal"
|
||||
|
@ -804,9 +804,10 @@ unlikeConfirm: "¿Quitar como favorito?"
|
|||
fullView: "Vista completa"
|
||||
quitFullView: "quitar vista completa"
|
||||
addDescription: "Agregar descripción"
|
||||
userPagePinTip: "Puede mantener sus notas visibles aquí seleccionando Pin en el menú
|
||||
de notas individuales"
|
||||
notSpecifiedMentionWarning: "Algunas menciones no están incluidas en el destino"
|
||||
userPagePinTip: "Puede mantener tus publicaciones visibles aquí seleccionando Pin
|
||||
en el menú de notas individuales."
|
||||
notSpecifiedMentionWarning: "Esta publicacion contiene menciones a usuarios no incluídos
|
||||
como destinatarios"
|
||||
info: "Información"
|
||||
userInfo: "Información del usuario"
|
||||
unknown: "Desconocido"
|
||||
|
@ -819,7 +820,7 @@ active: "Activo"
|
|||
offline: "Sin conexión"
|
||||
notRecommended: "obsoleto"
|
||||
botProtection: "Protección contra bots"
|
||||
instanceBlocking: "Instancias bloqueadas"
|
||||
instanceBlocking: "Gestión de la Federación"
|
||||
selectAccount: "Elija una cuenta"
|
||||
switchAccount: "Cambiar de cuenta"
|
||||
enabled: "Activado"
|
||||
|
@ -836,8 +837,8 @@ postToGallery: "Crear una nueva publicación en la galería"
|
|||
gallery: "Galería"
|
||||
recentPosts: "Posts recientes"
|
||||
popularPosts: "Más vistos"
|
||||
shareWithNote: "Compartir con una nota"
|
||||
ads: "Anuncios"
|
||||
shareWithNote: "Compartir con una publicación"
|
||||
ads: "Banners"
|
||||
expiration: "Termina el"
|
||||
memo: "Notas"
|
||||
priority: "Prioridad"
|
||||
|
@ -885,14 +886,14 @@ manageAccounts: "Administrar cuenta"
|
|||
makeReactionsPublic: "Hacer el historial de reacciones público"
|
||||
makeReactionsPublicDescription: "Todas las reacciones que hayas hecho serán públicamente
|
||||
visibles."
|
||||
classic: "Clásico"
|
||||
classic: "Centrado"
|
||||
muteThread: "Ocultar hilo"
|
||||
unmuteThread: "Mostrar hilo"
|
||||
ffVisibility: "Visibilidad de seguidores y seguidos"
|
||||
ffVisibilityDescription: "Puedes configurar quien puede ver a quienes sigues y quienes
|
||||
te siguen"
|
||||
continueThread: "Ver la continuación del hilo"
|
||||
deleteAccountConfirm: "La cuenta será borrada. ¿Está seguro?"
|
||||
deleteAccountConfirm: "La cuenta será borrada irreversiblemente. ¿Está seguro?"
|
||||
incorrectPassword: "La contraseña es incorrecta"
|
||||
voteConfirm: "¿Confirma su voto a {choice}?"
|
||||
hide: "Ocultar"
|
||||
|
@ -934,7 +935,9 @@ driveCapOverrideLabel: "Cambiar la capacidad de la unidad para este usuario"
|
|||
driveCapOverrideCaption: "Restablecer la capacidad a su predeterminado ingresando
|
||||
un valor de 0 o menos"
|
||||
requireAdminForView: "Necesitas iniciar sesión como administrador para ver esto."
|
||||
isSystemAccount: "Cuenta creada y operada automáticamente por el sistema"
|
||||
isSystemAccount: "Esta cuenta es creada y operada automaticamente por el sistema.
|
||||
Porfavor no moderar, editar, borrar o manipular de ninguna forma esta cuenta, o
|
||||
podría romper tu servidor."
|
||||
typeToConfirm: "Ingrese {x} para confirmar"
|
||||
deleteAccount: "Borrar cuenta"
|
||||
document: "Documento"
|
||||
|
@ -1019,8 +1022,9 @@ _forgotPassword:
|
|||
enterEmail: "Ingrese el correo usado para registrar la cuenta. Se enviará un link
|
||||
para resetear la contraseña."
|
||||
ifNoEmail: "Si no utilizó un correo para crear la cuenta, contáctese con el administrador."
|
||||
contactAdmin: "Esta instancia no admite el uso de direcciones de correo electrónico,
|
||||
póngase en contacto con el administrador de la instancia para restablecer su contraseña"
|
||||
contactAdmin: "Este servidor no admite el uso de direcciones de correo electrónico,
|
||||
póngase en contacto con la persona que administra el servidor para restablecer
|
||||
su contraseña."
|
||||
_gallery:
|
||||
my: "Mi galería"
|
||||
liked: "Publicaciones que me gustan"
|
||||
|
@ -1073,6 +1077,14 @@ _aboutFirefish:
|
|||
morePatrons: "También apreciamos el apoyo de muchos más que no están enlistados
|
||||
aquí. ¡Gracias! 🥰"
|
||||
patrons: "Mecenas de Firefish"
|
||||
pleaseDonateToFirefish: Por favor considera donar a Firefish para apollar su desarrollo.
|
||||
donateHost: Dona a {host}
|
||||
patronsList: Listados cronológicamente no por monto de la donación. ¡Dona con el
|
||||
vínculo de arriba para que tu nombre aparezca aquí!
|
||||
donateTitle: ¿Te gusta Firefish?
|
||||
pleaseDonateToHost: También considera donar a tu propio servidor , {host}, para
|
||||
ayudar con los costos de operación.
|
||||
sponsors: Patrocinadores de Firefish
|
||||
_nsfw:
|
||||
respect: "Ocultar medios NSFW"
|
||||
ignore: "No esconder medios NSFW "
|
||||
|
@ -1080,8 +1092,8 @@ _nsfw:
|
|||
_mfm:
|
||||
cheatSheet: "Hoja de referencia de MFM"
|
||||
intro: "MFM es un lenguaje de marcado dedicado que se puede usar en varios lugares
|
||||
dentro de Misskey, Firefish, Akkoma, y mucho más. Aquí puede ver una lista de sintaxis
|
||||
disponibles en MFM."
|
||||
dentro de Misskey, Firefish, Akkoma, y mucho más. Aquí puede ver una lista de
|
||||
sintaxis disponibles en MFM."
|
||||
dummy: "Firefish expande el mundo de la Fediverso"
|
||||
mention: "Menciones"
|
||||
mentionDescription: "El signo @ seguido de un nombre de usuario se puede utilizar
|
||||
|
@ -1106,7 +1118,7 @@ _mfm:
|
|||
inlineMath: "Fórmula (insertado)"
|
||||
inlineMathDescription: "Muestra fórmulas (KaTeX) insertadas"
|
||||
blockMath: "Fórmula (bloque)"
|
||||
blockMathDescription: "Muestra fórmulas (KaTeX) de varias líneas en un bloque"
|
||||
blockMathDescription: "Muestra fórmulas matemáticas (KaTeX) en un bloque"
|
||||
quote: "Citar"
|
||||
quoteDescription: "Muestra el contenido como una cita"
|
||||
emoji: "Emojis personalizados"
|
||||
|
@ -1151,6 +1163,22 @@ _mfm:
|
|||
plainDescription: "Desactiva los efectos de todo el contenido MFM con este efecto
|
||||
MFM."
|
||||
position: Posición
|
||||
warn: MFM podría contener movimientos rápidos o animaciones destellantes
|
||||
advancedDescription: Si está desactivado, solo permitir markup básico, excepto cuando
|
||||
un MFM animado se reproduce
|
||||
scale: Escalar
|
||||
foreground: Color en primer plano
|
||||
scaleDescription: Ajustar el contenido según un valor especificado.
|
||||
stop: Detener MFM
|
||||
crop: Recortar
|
||||
cropDescription: Recortar contenido.
|
||||
backgroundDescription: Cambiar el color de fondo del texto.
|
||||
alwaysPlay: Siempre reproducir todos los MFM animados
|
||||
fade: Fundido
|
||||
advanced: MFM avanzado
|
||||
play: Reproducir MFM
|
||||
foregroundDescription: Cambiar el color en primer plano del texto.
|
||||
background: Color de fondo
|
||||
_instanceTicker:
|
||||
none: "No mostrar"
|
||||
remote: "Mostrar a usuarios remotos"
|
||||
|
@ -1169,7 +1197,7 @@ _channel:
|
|||
owned: "Dueño"
|
||||
following: "Siguiendo"
|
||||
usersCount: "{n} participantes"
|
||||
notesCount: "{n} notas"
|
||||
notesCount: "{n} publicaciones"
|
||||
nameOnly: Nombre solamente
|
||||
nameAndDescription: Nombre y descripción
|
||||
_menuDisplay:
|
||||
|
@ -1183,18 +1211,20 @@ _wordMute:
|
|||
con lineas nuevas indica una declaracion Or。"
|
||||
muteWordsDescription2: "Encerrar las palabras clave entre numerales para usar expresiones
|
||||
regulares"
|
||||
softDescription: "Ocultar en la linea de tiempo las notas que cumplen las condiciones"
|
||||
hardDescription: "Evitar que se agreguen a la linea de tiempo las notas que cumplen
|
||||
las condiciones. Las notas no agregadas seguirán quitadas aunque cambien las condiciones."
|
||||
softDescription: "Ocultar en la linea de tiempo las publicaciones que cumplen las
|
||||
condiciones"
|
||||
hardDescription: "Evitar que se agreguen a la linea de tiempo las publicaciones
|
||||
que cumplen las condiciones, estas no serán agregadas a la linea de tiempo incluso
|
||||
si cambian las condiciones."
|
||||
soft: "Suave"
|
||||
hard: "Duro"
|
||||
mutedNotes: "Notas silenciadas"
|
||||
mutedNotes: "Publicaciones silenciadas"
|
||||
_instanceMute:
|
||||
instanceMuteDescription: "Silencia todas las notas y reposts de la instancias seleccionadas,
|
||||
incluyendo respuestas a los usuarios de las mismas"
|
||||
instanceMuteDescription: "Silencia todas las publicaciones e impusos de los servidores
|
||||
seleccionados, incluyendo respuestas a los usuarios de las mismas."
|
||||
instanceMuteDescription2: "Separar por líneas"
|
||||
title: "Oculta las notas de las instancias listadas."
|
||||
heading: "Instancias a silenciar"
|
||||
title: "Oculta las publicaciones de los servidores listados."
|
||||
heading: "Servidores a silenciar"
|
||||
_theme:
|
||||
explore: "Explorar temas"
|
||||
install: "Instalar tema"
|
||||
|
@ -1243,7 +1273,7 @@ _theme:
|
|||
hashtag: "Hashtag"
|
||||
mention: "Menciones"
|
||||
mentionMe: "Menciones (yo)"
|
||||
renote: "Renotar"
|
||||
renote: "Impulsar"
|
||||
modalBg: "Fondo modal"
|
||||
divider: "Divisor"
|
||||
scrollbarHandle: "Cuadro de la barra de desplazamiento"
|
||||
|
@ -1270,23 +1300,23 @@ _theme:
|
|||
accentLighten: "Acento (claro)"
|
||||
fgHighlighted: "Texto resaltado"
|
||||
_sfx:
|
||||
note: "Notas"
|
||||
note: "Nueva publicación"
|
||||
noteMy: "Nota (a mí mismo)"
|
||||
notification: "Notificaciones"
|
||||
chat: "Chat"
|
||||
chatBg: "Chat (Fondo)"
|
||||
antenna: "Antena receptora"
|
||||
antenna: "Antenas"
|
||||
channel: "Notificaciones del canal"
|
||||
_ago:
|
||||
future: "Futuro"
|
||||
justNow: "Recién ahora"
|
||||
secondsAgo: "Hace {n} segundos"
|
||||
minutesAgo: "Hace {n} minutos"
|
||||
hoursAgo: "Hace {n} horas"
|
||||
daysAgo: "Hace {n} días"
|
||||
weeksAgo: "Hace {n} semanas"
|
||||
monthsAgo: "Hace {n} meses"
|
||||
yearsAgo: "Hace {n} años"
|
||||
secondsAgo: "Hace {n} segundo(s)"
|
||||
minutesAgo: "Hace {n} minuto(s)"
|
||||
hoursAgo: "Hace {n} hora(s)"
|
||||
daysAgo: "Hace {n} día(s)"
|
||||
weeksAgo: "Hace {n} semana(s)"
|
||||
monthsAgo: "Hace {n} mes(es)"
|
||||
yearsAgo: "Hace {n} año(s)"
|
||||
_time:
|
||||
second: "Segundos"
|
||||
minute: "Minutos"
|
||||
|
@ -1298,16 +1328,16 @@ _tutorial:
|
|||
step1_2: "Vamos a configurarte. ¡Estarás listo y funcionando en poco tiempo!"
|
||||
step2_1: "En primer lugar, rellena tu perfil"
|
||||
step2_2: "Proporcionar algo de información sobre quién eres hará que sea más fácil
|
||||
para los demás saber si quieren ver tus notas o seguirte."
|
||||
para los demás saber si quieren ver tus publicaciones o seguirte."
|
||||
step3_1: "¡Ahora es el momento de seguir a algunas personas!"
|
||||
step3_2: "Tu página de inicio y tus líneas de tiempo sociales se basan en quién
|
||||
sigues, así que intenta seguir un par de cuentas para empezar.\nHaz clic en el
|
||||
círculo más en la parte superior derecha de un perfil para seguirlos."
|
||||
step4_1: "Vamos a salir a la calle"
|
||||
step4_2: "Para tu primer post, a algunas personas les gusta hacer un post de {introduction}
|
||||
o un simple \"¡Hola mundo!\""
|
||||
step4_2: "Para tu primer publicación, a algunas personas les gusta escribir una
|
||||
{introduction} o un simple \"¡Hola mundo!\""
|
||||
step5_1: "¡Líneas de tiempo, líneas de tiempo por todas partes!"
|
||||
step5_2: "Su instancia tiene {timelines} diferentes líneas de tiempo habilitadas"
|
||||
step5_2: "Tu servidor tiene {timelines} diferentes líneas de tiempo habilitadas."
|
||||
step5_3: "La línea de tiempo Inicio {icon} es donde puedes ver las publicaciones
|
||||
de tus seguidores."
|
||||
step5_4: "La línea de tiempo Local {icon} es donde puedes ver las publicaciones
|
||||
|
@ -1475,7 +1505,8 @@ _profile:
|
|||
youCanIncludeHashtags: "Puedes añadir hashtags"
|
||||
metadata: "información adicional"
|
||||
metadataEdit: "Editar información adicional"
|
||||
metadataDescription: "Muestra la información adicional en el perfil. ¡Puede agregar una etiqueta {a} o una etiqueta {l} con {rel} para verificar el enlace en su perfil!"
|
||||
metadataDescription: "Muestra la información adicional en el perfil. ¡Puede agregar
|
||||
una etiqueta {a} o una etiqueta {l} con {rel} para verificar el enlace en su perfil!"
|
||||
metadataLabel: "Etiqueta"
|
||||
metadataContent: "Contenido"
|
||||
changeAvatar: "Cambiar avatar"
|
||||
|
@ -1887,7 +1918,7 @@ renoteUnmute: Dejar de silenciar impulsos
|
|||
flagSpeakAsCat: Habla como un gato
|
||||
selectInstance: Selecciona un servidor
|
||||
flagSpeakAsCatDescription: Tu publicación se "nyanified" cuando esté en modo gato
|
||||
allowedInstances: Instancias en la lista blanca
|
||||
allowedInstances: Servidores autorizados
|
||||
breakFollowConfirm: ¿Estás seguro de que quieres eliminar el seguidor?
|
||||
subscribePushNotification: Habilitar notificaciones
|
||||
unsubscribePushNotification: Desactivar notificaciones
|
||||
|
@ -1904,12 +1935,12 @@ hiddenTags: Etiquetas Ocultas
|
|||
noInstances: No hay servidores
|
||||
accountMoved: 'Usuario ha movido a una cuenta nueva:'
|
||||
caption: Auto Subtítulos
|
||||
showAds: Mostrar Anuncios
|
||||
showAds: Mostrar banners
|
||||
enterSendsMessage: Presione "RETORNO" en los mensajes para enviar el mensaje (para
|
||||
apagarlo es Ctrl + RETORNO)
|
||||
recommendedInstances: Instancias Recomendadas
|
||||
instanceSecurity: Seguridad de la instancia
|
||||
seperateRenoteQuote: Separar impulsados y Citar botones
|
||||
instanceSecurity: Seguridad del servidor
|
||||
seperateRenoteQuote: Separar botones de Impulsar y Citar
|
||||
_messaging:
|
||||
groups: Grupos
|
||||
dms: Privado
|
||||
|
@ -1941,3 +1972,53 @@ hiddenTagsDescription: 'Escriba los hashtags (sin el #) que desea ocultar de las
|
|||
jumpToPrevious: Ver anterior
|
||||
enableEmojiReactions: Habilitar reacciones de emoji
|
||||
cw: Aviso de contenido
|
||||
sendPushNotificationReadMessage: Eliminar notificaciones una vez que la notificación
|
||||
o mensaje ha sido leído
|
||||
sendPushNotificationReadMessageCaption: Una notificación con el texto "{emptyPushNotificationMessage}"
|
||||
será mostrada por un breve período. Esto podría aumentar el uso de batería de tu
|
||||
dispositivo.
|
||||
enableServerMachineStats: Permitir estadísticas del hardware del servidor
|
||||
customMOTD: Mensaje del día personalizado (mensajes de la pantalla de presentación)
|
||||
antennasDesc: "Las Antennas muestran nuevas publicaciones que conciden con los criterios
|
||||
que estableciste.\nPueden ser accedidas desde la sección de Lineas de tiempo."
|
||||
antennaInstancesDescription: Escribe un servidor por cada linea
|
||||
expandOnNoteClickDesc: Si está desactivado, puedes abrir publicaciones usando el menú
|
||||
del botón derecho del ratón o presionando sobre la fecha.
|
||||
channelFederationWarn: Los Canales aún no federan con otras instancias
|
||||
clipsDesc: Los clips como marcadores categorizados que pueden ser compartidos. Puedes
|
||||
crear clips desde el menú de publicaciones.
|
||||
verifiedLink: Vínculo verificado
|
||||
cannotUploadBecauseExceedsFileSizeLimit: Este archivo no pudo ser cargado porque excede
|
||||
el tamaño máximo permitido.
|
||||
accessibility: Accesibilidad
|
||||
_filters:
|
||||
fromUser: Del usuario
|
||||
fromDomain: Desde el dominio
|
||||
notesAfter: Publicaciones posteriores
|
||||
userSaysSomethingReasonReply: '{name} respondió a una publicación que contiene {reason}'
|
||||
userSaysSomethingReasonQuote: '{name} citó una publicación que contiene {reason}'
|
||||
privateModeInfo: Al activar, solo servidores autorizados podrán federar con tu servidor.
|
||||
Todas las publicaiones estáran ocultas del público.
|
||||
customMOTDDescription: Mensajes del día personalizados (MOTD) de la pantalla de presentación,
|
||||
separados cada salto de linea. Para ser mostrados aleatoriamente cada vez que un
|
||||
usuario carga/recarga una página.
|
||||
customSplashIcons: Icono personalizado de la pantalla de presentación (url)
|
||||
donationLink: Vinculo a página de donación
|
||||
delete2fa: Desactivar autentificación en dos pasos
|
||||
delete2faConfirm: Esto eliminara irreversiblemente la autentificación en dos pasos
|
||||
de esta cuenta. ¿Quieres continuar?
|
||||
allowedInstancesDescription: Host de los servidores autorizados para federar, cada
|
||||
uno separado por una nueva linea (solo aplica en modo pivado).
|
||||
adminCustomCssWarn: Está configuración solo debería ser utilizado si sabes lo que
|
||||
hace. Ingresar valores erroneos podría causar que TODOS los clientes dejaran de
|
||||
funcionar normalmente. Porfavor asegurate que tus CSS funcionan adecuadamente al
|
||||
probar los en tus configuraciones de usuario.
|
||||
image: Imagen
|
||||
showPopup: Notificar a los usuarios con una ventana emergente
|
||||
showWithSparkles: Mostrar con destellos
|
||||
youHaveUnreadAnnouncements: Tienes anuncios sin leer
|
||||
neverShow: No mostrar nuevamente
|
||||
remindMeLater: Recordar nuevamente
|
||||
removeQuote: Eliminar cita
|
||||
removeRecipient: Eliminar destinatario
|
||||
removeMember: Eliminar miembro
|
||||
|
|
|
@ -55,7 +55,7 @@ attachCancel: Poista liite
|
|||
enterFileName: Anna tiedostonimi
|
||||
mute: Hiljennä
|
||||
unmute: Poista hiljennys
|
||||
headlineMisskey: Avoimen lähdekoodin, hajautettu sosiaalisen median alusta, joka on
|
||||
headlineFirefish: Avoimen lähdekoodin, hajautettu sosiaalisen median alusta, joka on
|
||||
ikuisesti ilmainen! 🚀
|
||||
monthAndDay: '{day}/{month}'
|
||||
deleteAndEditConfirm: Oletko varma, että haluat poistaa tämän lähetyksen ja muokata
|
||||
|
@ -214,7 +214,7 @@ perDay: Päivässä
|
|||
version: Versio
|
||||
statistics: Tilastot
|
||||
clearQueueConfirmTitle: Oletko varma, että haluat tyhjentää jonon?
|
||||
introMisskey: Tervetuloa! Firefish on avoimen lähdekoodin, hajautettu sosiaalisen median
|
||||
introFirefish: Tervetuloa! Firefish on avoimen lähdekoodin, hajautettu sosiaalisen median
|
||||
alusta, joka on ikuisesti ilmainen! 🚀
|
||||
clearQueueConfirmText: Mitkään välittämättömät lähetykset, jotka ovat jonossa, eivät
|
||||
federoidu. Yleensä tätä toimintoa ei tarvita.
|
||||
|
|
File diff suppressed because it is too large
Load diff
271
locales/gl.yml
271
locales/gl.yml
|
@ -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
|
||||
|
|
1109
locales/id-ID.yml
1109
locales/id-ID.yml
File diff suppressed because it is too large
Load diff
|
@ -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,
|
||||
);
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
_lang_: "日本語"
|
||||
headlineMisskey: "ずっと無料でオープンソースの非中央集権型ソーシャルメディアプラットフォーム🚀"
|
||||
introMisskey: "ようこそ!Firefishは、オープンソースの非中央集権型ソーシャルメディアプラットフォームです。\nいま起こっていることを共有したり、あなたについて皆に発信しましょう📡\n\
|
||||
headlineFirefish: "ずっと無料でオープンソースの非中央集権型ソーシャルメディアプラットフォーム🚀"
|
||||
introFirefish: "ようこそ!Firefishは、オープンソースの非中央集権型ソーシャルメディアプラットフォームです。\nいま起こっていることを共有したり、あなたについて皆に発信しましょう📡\n\
|
||||
「リアクション」機能で、皆の投稿に素早く反応を追加できます👍\n新しい世界を探検しよう🚀"
|
||||
monthAndDay: "{month}月 {day}日"
|
||||
search: "検索"
|
||||
|
@ -156,7 +156,7 @@ flagShowTimelineRepliesDescription: "オンにすると、タイムラインに
|
|||
autoAcceptFollowed: "フォローしているユーザーからのフォロー申請を自動承認"
|
||||
addAccount: "アカウントを追加"
|
||||
loginFailed: "ログインに失敗しました"
|
||||
showOnRemote: "リモートで表示"
|
||||
showOnRemote: "オリジナルのページを開く"
|
||||
general: "全般"
|
||||
accountMoved: "このユーザーは新しいアカウントに移行しました"
|
||||
wallpaper: "壁紙"
|
||||
|
@ -517,6 +517,8 @@ objectStorageUseSSLDesc: "API接続にhttpsを使用しない場合はオフに
|
|||
objectStorageUseProxy: "Proxyを利用する"
|
||||
objectStorageUseProxyDesc: "API接続にproxyを利用しない場合はオフにしてください"
|
||||
objectStorageSetPublicRead: "アップロード時に'public-read'を設定する"
|
||||
objectStorageS3ForcePathStyle: "DNS名ではなくてパスを使用する"
|
||||
objectStorageS3ForcePathStyleDesc: "EndpointのURLを作る際には、'<bucket>.s3.amazonaws.com'の代わりに's3.amazonaws.com/<bucket>/'のようなスタイルを使用します。"
|
||||
serverLogs: "サーバーログ"
|
||||
deleteAll: "全て削除"
|
||||
showFixedPostForm: "タイムライン上部に投稿フォームを表示する"
|
||||
|
@ -854,7 +856,7 @@ unmuteThread: "スレッドのミュートを解除"
|
|||
ffVisibility: "つながりの公開範囲"
|
||||
ffVisibilityDescription: "自分のフォロー/フォロワー情報の公開範囲を設定できます。"
|
||||
continueThread: "さらにスレッドを見る"
|
||||
deleteAccountConfirm: "アカウントが削除されます。よろしいですか?"
|
||||
deleteAccountConfirm: "このアカウントが削除されます。よろしいですか?"
|
||||
incorrectPassword: "パスワードが間違っています。"
|
||||
voteConfirm: "「{choice}」に投票しますか?"
|
||||
hide: "隠す"
|
||||
|
@ -985,6 +987,7 @@ showWithSparkles: "タイトルをキラキラさせる"
|
|||
youHaveUnreadAnnouncements: "未読のお知らせがあります"
|
||||
neverShow: "今後表示しない"
|
||||
remindMeLater: "また後で"
|
||||
addRe: "閲覧注意の投稿への返信で、注釈の先頭に\"re:\"を追加する"
|
||||
|
||||
_sensitiveMediaDetection:
|
||||
description: "機械学習を使って自動でセンシティブなメディアを検出し、モデレーションに役立てられます。サーバーの負荷が少し増えます。"
|
||||
|
@ -1064,6 +1067,7 @@ _aboutFirefish:
|
|||
about: "Firefishは、2022年に生まれたThatOneCalculatorによるMisskeyのforkです。"
|
||||
contributors: "主なコントリビューター"
|
||||
allContributors: "全てのコントリビューター"
|
||||
misskeyContributors: "フォーク元のMisskeyの主なコントリビューター"
|
||||
source: "ソースコード"
|
||||
translation: "Firefishを翻訳"
|
||||
donate: "Firefishに寄付"
|
||||
|
@ -1074,6 +1078,7 @@ _aboutFirefish:
|
|||
pleaseDonateToHost: また、このサーバー {host} の運営者への寄付もご検討ください。
|
||||
donateHost: '{host} に寄付する'
|
||||
donateTitle: Firefishを気に入りましたか?
|
||||
sponsors: Firefish の支援者
|
||||
_nsfw:
|
||||
respect: "閲覧注意のメディアは隠す"
|
||||
ignore: "閲覧注意のメディアを隠さない"
|
||||
|
@ -1959,3 +1964,10 @@ donationLink: 寄付ページへのリンク
|
|||
removeMember: メンバーを削除
|
||||
removeQuote: 引用を削除
|
||||
removeRecipient: 宛先を削除
|
||||
verifiedLink: 認証済みリンク
|
||||
_feeds:
|
||||
atom: Atom
|
||||
rss: RSS
|
||||
jsonFeed: JSONフィード
|
||||
copyFeed: フィードのURLをコピー
|
||||
origin: 起源
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
---
|
||||
_lang_: "日本語 (関西弁)"
|
||||
headlineMisskey: "ノートでつながるネットワーク"
|
||||
introMisskey: "ようお越し!Misskeyは、オープンソースの分散型マイクロブログサービスやねん。\n「ノート」を作って、いま起こっとることを共有したり、あんたについて皆に発信しよう📡\n「リアクション」機能で、皆のノートに素早く反応を追加したりもできるで✌\nほな新しい世界を探検しよか🚀"
|
||||
headlineFirefish: "ノートでつながるネットワーク"
|
||||
introFirefish: "ようお越し!Misskeyは、オープンソースの分散型マイクロブログサービスやねん。\n「ノート」を作って、いま起こっとることを共有したり、あんたについて皆に発信しよう📡\n「リアクション」機能で、皆のノートに素早く反応を追加したりもできるで✌\nほな新しい世界を探検しよか🚀"
|
||||
monthAndDay: "{month}月 {day}日"
|
||||
search: "探す"
|
||||
notifications: "通知"
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
---
|
||||
_lang_: "ಕನ್ನಡ"
|
||||
introMisskey: "ಸ್ವಾಗತ! Firefish ಓಪನ್ ಸೋರ್ಸ್ ಒಕ್ಕೂಟ ಮೈಕ್ರೋಬ್ಲಾಗಿಂಗ್ ಸೇವೆಯಾಗಿದೆ.\n ಏನಾಗುತ್ತಿದೆ ಎಂಬುದನ್ನು ಹಂಚಿಕೊಳ್ಳಲು ಅಥವಾ ನಿಮ್ಮ ಬಗ್ಗೆ ಎಲ್ಲರಿಗೂ ಹೇಳಲು \"ಟಿಪ್ಪಣಿ\"ಗಳನ್ನು ರಚಿಸಿ📡\n \"ಸ್ಪಂದನೆ\" ಕ್ರಿಯೆಯೊಂದಿಗೆ, ನೀವು ಎಲ್ಲರ ಟಿಪ್ಪಣಿಗಳಿಗೆ ತ್ವರಿತವಾಗಿ ಸ್ಪಂದನೆಗಳನ್ನು ಕೂಡ ಸೇರಿಸಬಹುದು.👍\n ಹೊಸ ಜಗತ್ತನ್ನು ಅನ್ವೇಷಿಸಿ🚀"
|
||||
introFirefish: "ಸ್ವಾಗತ! Firefish ಓಪನ್ ಸೋರ್ಸ್ ಒಕ್ಕೂಟ ಮೈಕ್ರೋಬ್ಲಾಗಿಂಗ್ ಸೇವೆಯಾಗಿದೆ.\n ಏನಾಗುತ್ತಿದೆ ಎಂಬುದನ್ನು ಹಂಚಿಕೊಳ್ಳಲು ಅಥವಾ ನಿಮ್ಮ ಬಗ್ಗೆ ಎಲ್ಲರಿಗೂ ಹೇಳಲು \"ಟಿಪ್ಪಣಿ\"ಗಳನ್ನು ರಚಿಸಿ📡\n \"ಸ್ಪಂದನೆ\" ಕ್ರಿಯೆಯೊಂದಿಗೆ, ನೀವು ಎಲ್ಲರ ಟಿಪ್ಪಣಿಗಳಿಗೆ ತ್ವರಿತವಾಗಿ ಸ್ಪಂದನೆಗಳನ್ನು ಕೂಡ ಸೇರಿಸಬಹುದು.👍\n ಹೊಸ ಜಗತ್ತನ್ನು ಅನ್ವೇಷಿಸಿ🚀"
|
||||
monthAndDay: "{month}ನೇ ತಿಂಗಳ {day}ನೇ ದಿನ"
|
||||
search: "ಹುಡುಕು"
|
||||
notifications: "ಅಧಿಸೂಚನೆಗಳು"
|
||||
|
|
|
@ -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}자
|
||||
|
|
|
@ -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! 🚀"
|
||||
|
|
|
@ -21,7 +21,7 @@ noAccountDescription: Denne brukeren har ikke fylt ut bio'en sin ennå.
|
|||
login: Logg inn
|
||||
loggingIn: Logger inn
|
||||
signup: Oppretter bruker
|
||||
uploading: Laster opp..
|
||||
uploading: Laster opp...
|
||||
enterUsername: Skriv inn brukernavn
|
||||
noNotifications: Ingen meldinger
|
||||
users: Brukere
|
||||
|
@ -63,9 +63,9 @@ alreadyFavorited: Allerede lagt til i bokmerker.
|
|||
delete: Slett
|
||||
openInWindow: Åpne i vindu
|
||||
basicSettings: Grunnleggende innstillinger
|
||||
headlineMisskey: En desentralisert sosialt media-plattform, basert på åpen kildekode,
|
||||
headlineFirefish: En desentralisert sosialt media-plattform, basert på åpen kildekode,
|
||||
som alltid vil være gratis! 🚀
|
||||
introMisskey: Velkommen! Firefish er en desentralisert sosialt media-plattform, basert
|
||||
introFirefish: Velkommen! Firefish er en desentralisert sosialt media-plattform, basert
|
||||
på åpen kildekode, som alltid vil være gratis! 🚀
|
||||
exportRequested: Du har bedt om en eksportering. Dette vil ta litt tid. Den vil bli
|
||||
lagt til på disken din når den er ferdig.
|
||||
|
@ -81,3 +81,36 @@ followRequestAccepted: Følgeforespørsel godtatt
|
|||
import: Importer
|
||||
export: Eksporter
|
||||
logout: Logger ut
|
||||
removeReaction: Fjern dine reaksjoner
|
||||
renotedBy: Fremhevet av {user}
|
||||
deleteAndEditConfirm: Er du sikker på at du vil slette og redigere denne posten? Du
|
||||
vil miste alle reaksjoner, fremhevinger og svar til den.
|
||||
pageLoadError: En feil oppsto ved lasting av siden.
|
||||
privacy: Personvern
|
||||
enterEmoji: Legg inn emoji
|
||||
renoted: Fremhevet.
|
||||
cantRenote: Denne posten kan ikke fremheves.
|
||||
cantReRenote: En fremheving kan ikke fremheves.
|
||||
quote: Sitér
|
||||
pinned: Fest til profil
|
||||
clickToShow: Klikk for å vise
|
||||
enableEmojiReactions: Slå på emoji-reaksjoner
|
||||
makeFollowManuallyApprove: Følgeforespørsler må godkjennes
|
||||
enterListName: Gi listen et navn
|
||||
follow: Følg
|
||||
followRequest: Følgerforespørsel
|
||||
unfollow: Avfølg
|
||||
followRequestPending: Ubehandlet følgerforespørsel
|
||||
add: Legg til
|
||||
followRequests: Følgerforespørsler
|
||||
reaction: Reaksjoner
|
||||
driveFileDeleteConfirm: Er du sikker på at du vil slette filen «{name}»? Den vil fjernes
|
||||
fra alle poster den er vedlagt i.
|
||||
defaultNoteVisibility: Standard synlighet
|
||||
unrenote: Fjern fremmheving
|
||||
unpin: Løsne fra profilen
|
||||
youGotNewFollower: følger deg
|
||||
mention: Omtale
|
||||
mentions: Omtaler
|
||||
edited: Redigert {date} {time}
|
||||
cw: Innholdsadvarsel
|
||||
|
|
|
@ -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"
|
||||
|
|
|
@ -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"
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -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"
|
||||
|
|
|
@ -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: Удалить участника
|
||||
|
|
|
@ -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"
|
||||
|
|
|
@ -1,7 +1,10 @@
|
|||
---
|
||||
_lang_: "Svenska"
|
||||
headlineMisskey: "Ett nätverk kopplat av noter"
|
||||
introMisskey: "Välkommen! Firefish är en öppen och decentraliserad mikrobloggningstjänst.\nSkapa en \"not\" och dela dina tankar med alla runtomkring dig. 📡\nMed \"reaktioner\" kan du snabbt uttrycka dina känslor kring andras noter.👍\nLåt oss utforska en nya värld!🚀"
|
||||
headlineFirefish: "En öppen källkod och decentraliserad social media plattform som
|
||||
är gratis för all framtid! 🚀"
|
||||
introFirefish: "Välkommen! Firefish är en öppen och decentraliserad mikrobloggningstjänst.\n
|
||||
Skapa en \"not\" och dela dina tankar med alla runtomkring dig. 📡\nMed \"reaktioner\"\
|
||||
\ kan du snabbt uttrycka dina känslor kring andras noter.👍\nLåt oss utforska en
|
||||
nya värld!🚀"
|
||||
monthAndDay: "{day}/{month}"
|
||||
search: "Sök"
|
||||
notifications: "Notifikationer"
|
||||
|
@ -16,7 +19,7 @@ enterUsername: "Ange användarnamn"
|
|||
renotedBy: "Omnoterad av {user}"
|
||||
noNotes: "Inga noteringar"
|
||||
noNotifications: "Inga aviseringar"
|
||||
instance: "Instanser"
|
||||
instance: "Server Instans"
|
||||
settings: "Inställningar"
|
||||
basicSettings: "Basinställningar"
|
||||
otherSettings: "Andra inställningar"
|
||||
|
@ -44,7 +47,8 @@ copyContent: "Kopiera innehåll"
|
|||
copyLink: "Kopiera länk"
|
||||
delete: "Radera"
|
||||
deleteAndEdit: "Radera och ändra"
|
||||
deleteAndEditConfirm: "Är du säker att du vill radera denna not och ändra den? Du kommer förlora alla reaktioner, omnoteringar och svar till den."
|
||||
deleteAndEditConfirm: "Är du säker att du vill radera denna not och ändra den? Du
|
||||
kommer förlora alla reaktioner, omnoteringar och svar till den."
|
||||
addToList: "Lägg till i lista"
|
||||
sendMessage: "Skicka ett meddelande"
|
||||
copyUsername: "Kopiera användarnamn"
|
||||
|
@ -63,9 +67,11 @@ import: "Importera"
|
|||
export: "Exportera"
|
||||
files: "Filer"
|
||||
download: "Nedladdning"
|
||||
driveFileDeleteConfirm: "Är du säker att du vill radera filen \"{name}\"? Noter med denna fil bifogad kommer också raderas."
|
||||
driveFileDeleteConfirm: "Är du säker att du vill radera filen \"{name}\"? Notera att
|
||||
denna kommer att bli raderad från alla poster som har den bifogad."
|
||||
unfollowConfirm: "Är du säker att du vill avfölja {name}?"
|
||||
exportRequested: "Du har begärt en export. Detta kan ta lite tid. Den kommer läggas till i din Drive när den blir klar."
|
||||
exportRequested: "Du har begärt en export. Detta kan ta lite tid. Den kommer läggas
|
||||
till i din Drive när den blir klar."
|
||||
importRequested: "Du har begärt en import. Detta kan ta lite tid."
|
||||
lists: "Listor"
|
||||
noLists: "Du har inga listor"
|
||||
|
@ -80,9 +86,11 @@ error: "Fel!"
|
|||
somethingHappened: "Ett fel har uppstått"
|
||||
retry: "Försök igen"
|
||||
pageLoadError: "Det gick inte att ladda sidan."
|
||||
pageLoadErrorDescription: "Detta händer oftast p.g.a. nätverksfel eller din webbläsarcache. Försök tömma din cache och testa sedan igen efter en liten stund."
|
||||
pageLoadErrorDescription: "Detta händer oftast p.g.a. nätverksfel eller din webbläsarcache.
|
||||
Försök tömma din cache och testa sedan igen efter en liten stund."
|
||||
serverIsDead: "Servern svarar inte. Vänta ett litet tag och försök igen."
|
||||
youShouldUpgradeClient: "För att kunna se denna sida, vänligen ladda om sidan för att uppdatera din klient."
|
||||
youShouldUpgradeClient: "För att kunna se denna sida, vänligen ladda om sidan för
|
||||
att uppdatera din klient."
|
||||
enterListName: "Skriv ett namn till listan"
|
||||
privacy: "Integritet"
|
||||
makeFollowManuallyApprove: "Följarförfrågningar kräver manuellt godkännande"
|
||||
|
@ -107,7 +115,8 @@ sensitive: "Känsligt innehåll"
|
|||
add: "Lägg till"
|
||||
reaction: "Reaktioner"
|
||||
reactionSetting: "Reaktioner som ska visas i reaktionsväljaren"
|
||||
reactionSettingDescription2: "Dra för att omordna, klicka för att radera, tryck \"+\" för att lägga till."
|
||||
reactionSettingDescription2: "Dra för att omordna, klicka för att radera, tryck \"\
|
||||
+\" för att lägga till."
|
||||
rememberNoteVisibility: "Komihåg notvisningsinställningar"
|
||||
attachCancel: "Ta bort bilaga"
|
||||
markAsSensitive: "Markera som känsligt innehåll"
|
||||
|
@ -136,13 +145,20 @@ emojiUrl: "Emoji länk"
|
|||
addEmoji: "Lägg till emoji"
|
||||
settingGuide: "Rekommenderade inställningar"
|
||||
cacheRemoteFiles: "Spara externa filer till cachen"
|
||||
cacheRemoteFilesDescription: "När denna inställning är avstängd kommer externa filer laddas direkt från den externa instansen. Genom att stänga av detta kommer lagringsutrymme minska i användning men kommer öka datatrafiken eftersom miniatyrer inte kommer genereras."
|
||||
cacheRemoteFilesDescription: "När denna inställning är avstängd kommer externa filer
|
||||
laddas direkt från den externa instansen. Genom att stänga av detta kommer lagringsutrymme
|
||||
minska i användning men kommer öka datatrafiken eftersom miniatyrer inte kommer
|
||||
genereras."
|
||||
flagAsBot: "Markera konto som bot"
|
||||
flagAsBotDescription: "Aktivera det här alternativet om kontot är kontrollerat av ett program. Om aktiverat kommer den fungera som en flagga för andra utvecklare för att hindra ändlösa kedjor med andra bottar. Det kommer också få Misskeys interna system att hantera kontot som en bot."
|
||||
flagAsBotDescription: "Aktivera det här alternativet om kontot är kontrollerat av
|
||||
ett program. Om aktiverat kommer den fungera som en flagga för andra utvecklare
|
||||
för att hindra ändlösa kedjor med andra bottar. Det kommer också få Firefish interna
|
||||
system att hantera kontot som en bot."
|
||||
flagAsCat: "Markera konto som katt"
|
||||
flagAsCatDescription: "Aktivera denna inställning för att markera kontot som en katt."
|
||||
flagShowTimelineReplies: "Visa svar i tidslinje"
|
||||
flagShowTimelineRepliesDescription: "Visar användarsvar till andra användares noter i tidslinjen om påslagen."
|
||||
flagShowTimelineRepliesDescription: "Visar användarsvar till andra användares noter
|
||||
i tidslinjen om påslagen."
|
||||
autoAcceptFollowed: "Godkänn följarförfrågningar från användare du följer automatiskt"
|
||||
addAccount: "Lägg till konto"
|
||||
loginFailed: "Inloggningen misslyckades"
|
||||
|
@ -155,7 +171,11 @@ searchWith: "Sök: {q}"
|
|||
youHaveNoLists: "Du har inga listor"
|
||||
followConfirm: "Är du säker att du vill följa {name}?"
|
||||
proxyAccount: "Proxykonto"
|
||||
proxyAccountDescription: "Ett proxykonto är ett konto som agerar som en extern följare för användare under vissa villkor. Till exempel, när en användare lägger till en extern användare till en lista så kommer den externa användarens aktivitet inte levireras till instansen om ingen lokal användare följer det kontot, så proxykontot används istället."
|
||||
proxyAccountDescription: "Ett proxykonto är ett konto som agerar som en extern följare
|
||||
för användare under vissa villkor. Till exempel, när en användare lägger till en
|
||||
extern användare till en lista så kommer den externa användarens aktivitet inte
|
||||
levereras till instansen om ingen lokal användare följer det kontot, så proxykontot
|
||||
används istället."
|
||||
host: "Värd"
|
||||
selectUser: "Välj användare"
|
||||
recipient: "Mottagare"
|
||||
|
@ -185,11 +205,13 @@ instanceInfo: "Instansinformation"
|
|||
statistics: "Statistik"
|
||||
clearQueue: "Rensa kö"
|
||||
clearQueueConfirmTitle: "Är du säker att du vill rensa kön?"
|
||||
clearQueueConfirmText: "Om någon not är olevererad i kön kommer den inte federeras. Vanligtvis behövs inte denna handling."
|
||||
clearQueueConfirmText: "Om någon not är olevererad i kön kommer den inte federeras.
|
||||
Vanligtvis behövs inte denna handling."
|
||||
clearCachedFiles: "Rensa cache"
|
||||
clearCachedFilesConfirm: "Är du säker att du vill radera alla cachade externa filer?"
|
||||
blockedInstances: "Blockerade instanser"
|
||||
blockedInstancesDescription: "Lista adressnamn av instanser som du vill blockera. Listade instanser kommer inte längre kommunicera med denna instans."
|
||||
blockedInstancesDescription: "Lista adressnamn av instanser som du vill blockera.
|
||||
Listade instanser kommer inte längre kommunicera med denna instans."
|
||||
muteAndBlock: "Tystningar och blockeringar"
|
||||
mutedUsers: "Tystade användare"
|
||||
blockedUsers: "Blockerade användare"
|
||||
|
@ -318,3 +340,444 @@ _deck:
|
|||
tl: "Tidslinje"
|
||||
list: "Listor"
|
||||
mentions: "Omnämningar"
|
||||
removeReaction: Radera från dina reaktioner
|
||||
renoteMute: Tysta boostningar
|
||||
renoteUnmute: Ljuda boostningar
|
||||
flagSpeakAsCat: Prata som en katt
|
||||
noInstances: Det finns inga servrar
|
||||
keepOriginalUploadingDescription: Sparar originalen av uppladdade bilder som de är.
|
||||
Om avstängt, kommer en ny version genererad vid uppladdning.
|
||||
fromUrl: från URL
|
||||
explore: Utforska
|
||||
messageRead: Läs
|
||||
noMoreHistory: Det finns ingen framtida historik
|
||||
startMessaging: Starta en ny chatt
|
||||
agreeTo: Jag accepterar till {0}
|
||||
drive: Enhet
|
||||
fileName: Filnamn
|
||||
inputNewDescription: Ange en ny benämning
|
||||
inputNewFolderName: Ange ett nytt mappnamn
|
||||
hasChildFilesOrFolders: Eftersom denna mappen inte är tom, kan den inte bli raderad.
|
||||
copyUrl: Kopiera URL
|
||||
watch: Bevaka
|
||||
thisMonth: Månad
|
||||
today: Idag
|
||||
dayX: '{day}'
|
||||
monthX: '{month}'
|
||||
yearX: '{year}'
|
||||
connectService: Anslut
|
||||
disconnectService: Bortkoppla
|
||||
enableLocalTimeline: Anslut till lokal tidslinje
|
||||
invite: Bjud in
|
||||
driveCapacityPerLocalAccount: Enhetens kapacitet per lokal användare
|
||||
inMb: I megabyte
|
||||
pinnedPagesDescription: Ange sökväg till sidor som du vill fästa på topp av sidorna
|
||||
på denna server, separerade av sidbrytningar.
|
||||
hcaptcha: hCaptcha
|
||||
antennasDesc: "Antenner visar nya poster som matchar de kriterier som du anger\nDe
|
||||
kan nås från sidlinje sidan."
|
||||
unsilenceConfirm: Är du säker på att du vill ångra tystningen av denna användare?
|
||||
securityKey: Säkerhetsnyckel
|
||||
markAsReadAllNotifications: Markera alla notifikationer som lästa
|
||||
quoteQuestion: Lägg till som en citering?
|
||||
noMessagesYet: Inga meddelande ännu
|
||||
newMessageExists: Det finns inga nya meddelanden
|
||||
weakPassword: Svagt lösenord
|
||||
normalPassword: Dugligt lösenord
|
||||
strongPassword: Starkt lösenord
|
||||
passwordMatched: Matchar
|
||||
passwordNotMatched: Matchar inte
|
||||
signinWith: Logga in med {x}
|
||||
disableAnimatedMfm: Inaktivera MFM med animering
|
||||
noFollowRequests: Du har inte några väntande följbekräftelser
|
||||
clientSettings: Klientinställningar
|
||||
promote: Befordra
|
||||
numberOfDays: Antalet dagar
|
||||
objectStorageUseSSL: Använd SSL
|
||||
objectStorageUseSSLDesc: Stäng av detta om du inte kommer använda HTTPS för API anslutningar.
|
||||
recentUsed: Senast använd
|
||||
nothing: Det finns inget att visa här
|
||||
lastUsedDate: Senaste använd vid
|
||||
state: Stat
|
||||
disablePagesScript: Inaktivera AiScript på sidor
|
||||
expandOnNoteClick: Öppna post vid klick
|
||||
updateRemoteUser: Uppdatera fjärranvändarinformation
|
||||
deleteAllFiles: Radera alla filer
|
||||
userSuspended: Denna användare har blivit avstängd.
|
||||
inboxUrl: Inbox URL
|
||||
serviceworkerInfo: Måste vara aktiverat för push-notifikationer.
|
||||
deletedNote: Radera poster
|
||||
expandTweet: Expandera tweet
|
||||
themeEditor: Thema redigerare
|
||||
describeFile: Lägg till bildtext
|
||||
enterFileDescription: Beskriv bildtext
|
||||
manage: Hantering
|
||||
useBlurEffectForModal: Använd oskärpa effekter för modeller
|
||||
width: Bredd
|
||||
small: Liten
|
||||
disableAll: Inaktivera alla
|
||||
tokenRequested: Tillåt tillgång till konto
|
||||
channelFederationWarn: Kanalerna federeras inte till andra servrar ännu
|
||||
manageGroups: Hantera grupper
|
||||
tos: Användarvillkor
|
||||
start: Starta
|
||||
home: Hem
|
||||
activity: Aktivitet
|
||||
themeForDarkMode: Teman som används i Mörkt läge
|
||||
maintainerEmail: Underhållare e-post
|
||||
enableHcaptcha: Aktivera hCaptcha
|
||||
hcaptchaSiteKey: Sidnyckel
|
||||
recaptchaSecretKey: Hemlig nyckel
|
||||
withFiles: Inkludera filer
|
||||
popularTags: Populära taggar
|
||||
notFound: Kan inte hittas
|
||||
uploadFolder: Standardmappar för uppladdning
|
||||
retype: Ange igen
|
||||
next: Nästa
|
||||
checking: Kontrollerar...
|
||||
or: Eller
|
||||
groupInvited: Du har blivit inbjuden till en grupp
|
||||
docSource: Källa till detta dokument
|
||||
createAccount: Skapa konto
|
||||
total: Total
|
||||
objectStorage: Objektlagring
|
||||
objectStorageRegion: Region
|
||||
objectStorageUseProxy: Anslut över Proxy
|
||||
objectStorageUseProxyDesc: Stäng av detta om du inte kommer använde en Proxy för API
|
||||
anslutningar
|
||||
sounds: Ljud
|
||||
details: Detaljer
|
||||
installedApps: Auktoriserade applikationer
|
||||
installedDate: Auktoriserad vid
|
||||
script: Skript
|
||||
removeAllFollowingDescription: Körning av detta kommer sluta följa alla konton från
|
||||
{host}. Vänligen kör detta om servern t.ex. inte längre existerar.
|
||||
userSilenced: Denna användare har blivit tystnad.
|
||||
visibility: Synlighet
|
||||
delayed: Fördröjning
|
||||
useGlobalSetting: Använd globala inställningar
|
||||
selectInstance: Välj en server
|
||||
instanceName: Servernamn
|
||||
searchPlaceholder: Sök Firefish
|
||||
noThankYou: Nej tack
|
||||
jumpToPrevious: Hoppa till föregående
|
||||
listsDesc: Listor låter dig skapa en tidlinje med specificerade användare. Dessa kan
|
||||
sedan bli nådda från tidlinje sidan.
|
||||
flagSpeakAsCatDescription: Dina poster kommer ge en nyans som om du är i katt-läge
|
||||
silencedInstances: Tystade instanser
|
||||
hiddenTags: Dolda Hashtaggar
|
||||
silenced: Tystad
|
||||
nUsersRead: Läs med {n}
|
||||
themeForLightMode: Teman som används i Ljust Läge
|
||||
light: Ljus
|
||||
recaptcha: reCAPTCHA
|
||||
enableRecaptcha: Aktivera reCAPTCHA
|
||||
help: Hjälp
|
||||
groupName: Gruppnamn
|
||||
name: Namn
|
||||
resetPassword: Återställ lösenord
|
||||
newPasswordIs: Ditt nya lösenord är "{password}"
|
||||
cacheClear: Rensa cache
|
||||
markAsReadAllTalkMessages: Markera alla meddelanden som lästa
|
||||
uiLanguage: Användargränssnitt
|
||||
disableDrawer: Använd inte byrålådor-stil menyer
|
||||
tapSecurityKey: Klicka in din säkerhetsnyckel.
|
||||
language: Språk
|
||||
objectStorageRegionDesc: Ange en region som 'xx-east-1'. Om du anger din tjänst som
|
||||
inte skiljer mellan regioner, lämna detta blankt eller ange som 'us-east-1'.
|
||||
objectStorageSetPublicRead: Ställ in "public-read" vid uppladdningar
|
||||
scratchpadDescription: Scratchpaden tillgängliggör en miljö för AiScript experiment.
|
||||
Du kan skriva, köra och checka ut resultaten från den när du interagerar med Firefish.
|
||||
yourAccountSuspendedDescription: Detta kontot har blivit avstängt eftersom det bröt
|
||||
mot serverns användaravtal eller liknande. Vänligen kontakta administratörer om
|
||||
du vill veta mer detaljerade anledningar. Vänligen skapa inte ett nytt konto.
|
||||
divider: Fördelare
|
||||
addItem: Lägg till artikel
|
||||
poll: Opinionsundersökning
|
||||
useCw: Dölj innehåll
|
||||
enablePlayer: Öppna videospelare
|
||||
disablePlayer: Stäng videospelare
|
||||
description: Beskrivning
|
||||
author: Författare
|
||||
accessibility: Tillgänglighet
|
||||
useObjectStorage: Använd objektlagring
|
||||
objectStorageBaseUrl: Grundläggande URL
|
||||
deleteAllFilesConfirm: Är du säker på att du vill radera alla filer?
|
||||
menu: Meny
|
||||
regexpError: Regular expression fel
|
||||
wordMute: Ord tystning
|
||||
regexpErrorDescription: 'Ett fel skedde vid regular expression på linje {line} av
|
||||
dina {tab} ord tystningar:'
|
||||
instanceMute: Server tystningar
|
||||
userSaysSomething: '{name} sa något'
|
||||
userSaysSomethingReason: '{name} sade {reason}'
|
||||
makeActive: Aktivera
|
||||
notificationSettingDesc: Välj typerna av notifieringsinställningarna att visa.
|
||||
fromDrive: Från Enhet
|
||||
uploadFromUrlMayTakeTime: Det kan ta en tid innan uppladdningen är slutförd.
|
||||
uploadFromUrlRequested: Uppladdning som förfrågat
|
||||
unwatch: Sluta bevaka
|
||||
enableRecommendedTimeline: Aktivera rekommenderad tidslinje
|
||||
showLess: Stäng
|
||||
regenerate: Återskapa
|
||||
promotion: Befordrad
|
||||
doNothing: Ignorera
|
||||
thisYear: År
|
||||
manageAntennas: Hantera Antenner
|
||||
deleted: Raderad
|
||||
editNote: Redigera anteckning
|
||||
edited: Redigerad vid {date} {time}
|
||||
syncDeviceDarkMode: Synkronisera mörkt läge med dina enhetsinställningar
|
||||
dayOverDayChanges: Ändringar från igår
|
||||
selectChannel: Välj en kanal
|
||||
lightThemes: Ljusa teman
|
||||
dark: Mörk
|
||||
inputNewFileName: Ange ett nytt filnamn
|
||||
whenServerDisconnected: När den tappar uppkopplingen till servern
|
||||
disconnectedFromServer: Anslutning till server har tappats
|
||||
iconUrl: Ikon URL
|
||||
bannerUrl: Banner bild URL
|
||||
hcaptchaSecretKey: Hemlig nyckel
|
||||
onlyOneFileCanBeAttached: Du kan endast ange en bilaga till ett meddelande
|
||||
signinFailed: Kan inte logga in. Ange korrekt användarnamn och lösenord.
|
||||
notesAndReplies: Poster och svar
|
||||
token: Token
|
||||
twoStepAuthentication: Två-faktor-autentisering
|
||||
antennaInstancesDescription: Lista en servervärd per linje
|
||||
moderator: Moderator
|
||||
moderation: Moderering
|
||||
chooseEmoji: Välj en emoji
|
||||
unableToProcess: Operationen kunde inte slutföras
|
||||
output: Output
|
||||
expandOnNoteClickDesc: Om inaktiverad, kan du öppna posten vid högerklicksmenyn eller
|
||||
genom att klicka på tidsstämpeln.
|
||||
aboutFirefish: Om Firefish
|
||||
older: Äldre
|
||||
hiddenTagsDescription: 'Lista hashtaggar (utan # symbolen) för de hashtaggar du vill
|
||||
dölja från trendande och utforska. Dolda hashtaggar kan fortfarande hittas via andra
|
||||
funktioner.'
|
||||
darkThemes: Mörka teman
|
||||
images: Bilder
|
||||
selectFiles: Välj filer
|
||||
renameFile: Byt namn på fil
|
||||
folderName: Filnamn
|
||||
createFolder: Skapa en mapp
|
||||
renameFolder: Byt namn på denna mapp
|
||||
emptyDrive: Din enhet är tom
|
||||
emptyFolder: Denna mapp är tom
|
||||
unableToDelete: Kan inte radera
|
||||
rename: Byt namn
|
||||
deleteFolder: Radera denna mapp
|
||||
addFile: Lägg till en fil
|
||||
banner: Banner
|
||||
reload: Uppdatera
|
||||
reloadConfirm: Vill du uppdatera din tidslinje?
|
||||
accept: Acceptera
|
||||
tosUrl: Användarvillkor URL
|
||||
pages: Sidor
|
||||
disablingTimelinesInfo: Administratörer och moderatorer har alltid tillgång till alla
|
||||
tidslinjer, även om de inte är aktiverade
|
||||
registration: Registrera
|
||||
enableRegistration: Aktivera ny användarregistrering
|
||||
driveCapacityPerRemoteAccount: Enhetskapacitet per extern användare
|
||||
enableGlobalTimeline: Aktivera global tidslinje
|
||||
antennaSource: Antennkällor
|
||||
notifyAntenna: Informera vid nya poster
|
||||
withFileAntenna: Ange poster med filer
|
||||
exploreFediverse: Upptäck ett fidiverse
|
||||
markAsReadAllUnreadNotes: Markera alla poster som lästa
|
||||
inputMessageHere: Ange meddelande här
|
||||
members: Medlemmar
|
||||
available: Tillgänglig
|
||||
usernameInvalidFormat: Du kan ange versaler eller gemener, nummer och underskrifter.
|
||||
tooLong: För lång
|
||||
joinOrCreateGroup: Bli inbjuden till en grupp eller skapa en egen.
|
||||
doing: Bearbetar...
|
||||
youHaveNoGroups: Du har inga grupper
|
||||
aboutX: Om {x}
|
||||
existingAccount: Existerande konto
|
||||
install: Installera
|
||||
uninstall: Avinstallera
|
||||
sort: Sortera
|
||||
ascendingOrder: Stigande
|
||||
leaveConfirm: Ändringar har inte sparats. Vill du kasta dem?
|
||||
plugins: Plugin
|
||||
preferencesBackups: Backup av inställningar
|
||||
enableEmail: Aktivera epost distribuering
|
||||
smtpSecure: Använd strikt SSL/TLS vid SMTP anslutningar
|
||||
smtpSecureInfo: Stäng av detta vid användning av STARTTLS
|
||||
testEmail: Test av epost leverans
|
||||
userSaysSomethingReasonReply: '{name} svarade på en post innehållande {reason}'
|
||||
userSaysSomethingReasonRenote: '{name} boosted en post innehållande {reason}'
|
||||
userSaysSomethingReasonQuote: '{name} citerade en post innehållande {reason}'
|
||||
logs: Loggar
|
||||
database: Databas
|
||||
channel: Kanaler
|
||||
create: Skapa
|
||||
notificationSetting: Notisinställningar
|
||||
objectStorageS3ForcePathStyle: Använd filmapp-baserade slutpunkter för URL:er
|
||||
newNoteRecived: Det finns nya poster
|
||||
deck: Däck
|
||||
undeck: Lämna däck
|
||||
large: Stor
|
||||
newer: Nyare
|
||||
silenceThisInstance: Tysta denna instans
|
||||
silencedInstancesDescription: Lista värdnamn på server som du vill tysta. Konton på
|
||||
listade instanser behandlas som om de är "Tystade", de kan endast göra följbekräftelser
|
||||
och kan inte nämna lokala konton som inte följs. Detta påverkar inte blockerade
|
||||
instanser.
|
||||
uploadFromUrl: Uppladdad från URL
|
||||
birthday: Födelsedag
|
||||
theme: Teman
|
||||
avatar: Avatar
|
||||
uploadFromUrlDescription: URL av filen som du vill ladda upp
|
||||
remoteUserCaution: Informationen från en avlägsen användare kan inte slutföras
|
||||
yearsOld: '{age} år gammal'
|
||||
location: Plats
|
||||
selectFile: Välj en fil
|
||||
registeredDate: Registrerade på
|
||||
selectFolder: Välj en mapp
|
||||
circularReferenceFolder: Destinationsmappen är en undermapp till mappen som du försöker
|
||||
flytta.
|
||||
instanceDescription: Serverbeskrivning
|
||||
selectFolders: Välj mappar
|
||||
reject: Neka
|
||||
normal: Normal
|
||||
withReplies: Inkludera svar
|
||||
registerSecurityKey: Registrera en säkerhetsnyckel
|
||||
enableServiceworker: Aktivera push-notifikationer för din webbläsare
|
||||
maintainerName: Underhållare
|
||||
pinnedPages: Fästa sidor
|
||||
basicInfo: Grundläggande info
|
||||
pinnedUsers: Pinnade användare
|
||||
backgroundImageUrl: Bakgrundsbild URL
|
||||
pinnedUsersDescription: Lista användarnamn separerade med radbrytning att bli fäst
|
||||
i "Utforska" fliken
|
||||
recaptchaSiteKey: Sid nyckel
|
||||
pinnedClipId: ID av klippet du vill fästa
|
||||
avoidMultiCaptchaConfirm: Användning av flera Captcha system kan orsaka problem. Vill
|
||||
du inaktivera andra Captcha system som är aktiverade i nuläget? Om du vill att de
|
||||
ska fortsätta vara inaktiverade, tryck ångra.
|
||||
antennas: Antenner
|
||||
antennaKeywords: Nyckelord att följa
|
||||
antennaExcludeKeywords: Nyckelord att exkludera
|
||||
antennaKeywordsDescription: Separera med mellanrum för ett OCH villkor eller med sidbrytning
|
||||
för ett ELLER villkor.
|
||||
caseSensitive: Skiftlägeskänsliga
|
||||
recentlyDiscoveredUsers: Senaste upptäckta användare
|
||||
antennaUsersDescription: Lista ett användarnamn per linje
|
||||
silenceConfirm: Är du säker att du vill tysta denna användare?
|
||||
connectedTo: Följande konton är anslutna
|
||||
unsilence: Ångra tystning
|
||||
recentlyRegisteredUsers: Senaste användare
|
||||
exploreUsersCount: Det finns {count} användare
|
||||
silence: Tysta
|
||||
popularUsers: Populära användare
|
||||
recentlyUpdatedUsers: Senaste aktiva användare
|
||||
administrator: Administratör
|
||||
passwordLessLogin: Lösenordslös-inloggning
|
||||
about: Om
|
||||
nUsersMentioned: Benämnd av {n} användare
|
||||
securityKeyName: Nyckelnamn
|
||||
share: Dela
|
||||
reduceUiAnimation: Minska UI animeringar
|
||||
notFoundDescription: Ingen sida som korresponderar med denna URL kunde hittas
|
||||
close: Stäng
|
||||
group: Grupp
|
||||
transfer: Överför
|
||||
category: Kategori
|
||||
createGroup: Skapa en grupp
|
||||
ownedGroups: Ägda grupper
|
||||
invites: Inbjudningar
|
||||
groups: Grupper
|
||||
title: Titel
|
||||
joinedGroups: Deltagande grupper
|
||||
tooShort: För kort
|
||||
signinHistory: Inloggningshistorik
|
||||
enable: Aktivera
|
||||
text: Text
|
||||
inviteToGroup: Bjud in till grupp
|
||||
quoteAttached: Citera
|
||||
messagingWithUser: Privatchatt
|
||||
messagingWithGroup: Gruppchatt
|
||||
invitationCode: Inbjudningskod
|
||||
noteOf: Postad av {user}
|
||||
unavailable: Inte tillgänglig
|
||||
invitations: Inbjudningar
|
||||
useOsNativeEmojis: Använd operativsystemets lokala emojis
|
||||
noHistory: Historik saknas
|
||||
tags: Taggar
|
||||
openImageInNewTab: Öppna bilder i ny flik
|
||||
fontSize: Teckenstorlek
|
||||
dashboard: Användargränssnitt
|
||||
weekOverWeekChanges: Ändringar till föregående vecka
|
||||
appearance: Utseende
|
||||
accountSettings: Kontoinställningar
|
||||
objectStorageBaseUrlDesc: "Denna URL används som referens. Ange URL för din CDN eller
|
||||
Proxy om du använder någon.\nFör S3 använd 'https://<bucket>.s3.amazonaws.com' och
|
||||
för GCS eller likvärdig tjänst använd 'https://storage.googleapis.com/<bucket>',
|
||||
m.m."
|
||||
objectStorageEndpointDesc: Lämna denna tom om du använder AWS S3, annars ange slutpunkten
|
||||
som '<host>' eller '<host>:<port>', beroende på tjänsten som du använder.
|
||||
objectStorageS3ForcePathStyleDesc: Aktivera detta vid konstruering av slutpunkter
|
||||
i URL som är i format för 's3.amazonaws.com/<bucket>/' vid '<bucket>.s3.amazonaws.com'.
|
||||
popout: Poppa-ut
|
||||
showFixedPostForm: Visa postens form vid toppen av tidslinjen
|
||||
listen: Lystna
|
||||
none: Inga
|
||||
showInPage: Visa på sida
|
||||
masterVolume: Huvudvolym
|
||||
volume: Volym
|
||||
descendingOrder: Nedåtgående
|
||||
scratchpad: Scratchpad
|
||||
yourAccountSuspendedTitle: Detta kontot har blivit avstängt
|
||||
email: Epost
|
||||
relays: Reläer
|
||||
invisibleNote: Osynliga poster
|
||||
addRelay: Lägg till relä
|
||||
enableInfiniteScroll: Ladda fler automatiskt
|
||||
edit: Redigera
|
||||
useFullReactionPicker: Använd full-storlek för reaktionsväljaren
|
||||
notificationType: Notifieringstyp
|
||||
pluginTokenRequestedDescription: Detta plugin kommer använda tillgänglighet inställd
|
||||
här.
|
||||
generateAccessToken: Generera tillgångstoken
|
||||
permission: Tillstånd
|
||||
smtpConfig: SMPT server inställningar
|
||||
emailServer: Epost server
|
||||
emailConfigInfo: Används för att bekräfta din epost vid registrering om du glömmer
|
||||
till lösenord
|
||||
emptyToDisableSmtpAuth: Lämna användarnamn och lösenord tomt vid inaktivering av SMTP
|
||||
verifiering
|
||||
emailAddress: Epost adress
|
||||
smtpPort: Port
|
||||
metrics: Metrik
|
||||
display: Visa
|
||||
copy: Kopiera
|
||||
overview: Översikt
|
||||
lastUsed: Senast använd
|
||||
unregister: Avregistrera
|
||||
addInstance: Lägg till server
|
||||
objectStorageBucketDesc: Vänligen ange hink-namn som du använder som din leverantör.
|
||||
accountMoved: Användaren har flyttat till ett nytt konto
|
||||
hideThisNote: Dölj denna post
|
||||
showFeaturedNotesInTimeline: Visa presenterade poster i tidslinjen
|
||||
objectStorageBucket: Hink
|
||||
objectStoragePrefix: Prefix
|
||||
local: Lokal
|
||||
remote: Avlägsen
|
||||
objectStoragePrefixDesc: Filer som lagras under mappar kommer använda detta prefix.
|
||||
objectStorageEndpoint: Slutpunkt
|
||||
addedRelays: Tillagda reläer
|
||||
height: Höjd
|
||||
enableAll: Tillåt alla
|
||||
cw: Innehållsvarning
|
||||
enableEmojiReactions: Aktivera emoji reaktioner
|
||||
showEmojisInReactionNotifications: Visa emojis i reaktion notifikationer
|
||||
signinRequired: Vänligen registrera eller logga in innan du fortsätter
|
||||
serverLogs: Serverloggar
|
||||
deleteAll: Radera alla
|
||||
removeAllFollowing: Sluta följa alla följda användare
|
||||
medium: Mellan
|
||||
integration: Integreringar
|
||||
xl: XL
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
---
|
||||
_lang_: "ภาษาไทย"
|
||||
headlineMisskey: "เชื่อมต่อเครือข่ายโดยโน้ต"
|
||||
introMisskey: "ยินดีต้อนรับจ้าาา! Firefish เป็นบริการไมโครบล็อกโอเพ่นซอร์ส แบบการกระจายอำนาจ\nสร้าง \"โน้ต\" เพื่อแบ่งปันความคิดของคุณกับทุกคนรอบตัวคุณกันเถอะ 📡\nด้วยการ \"รีแอคชั่นผู้คน\" คุณยังสามารถแสดงความรู้สึกของคุณเกี่ยวกับบันทึกของทุกคนได้อย่างรวดเร็ว 👍\n\nแล้วมาท่องสำรวจโลกใบใหม่กันเถอะ! 🚀"
|
||||
headlineFirefish: "เชื่อมต่อเครือข่ายโดยโน้ต"
|
||||
introFirefish: "ยินดีต้อนรับจ้าาา! Firefish เป็นบริการไมโครบล็อกโอเพ่นซอร์ส แบบการกระจายอำนาจ\nสร้าง \"โน้ต\" เพื่อแบ่งปันความคิดของคุณกับทุกคนรอบตัวคุณกันเถอะ 📡\nด้วยการ \"รีแอคชั่นผู้คน\" คุณยังสามารถแสดงความรู้สึกของคุณเกี่ยวกับบันทึกของทุกคนได้อย่างรวดเร็ว 👍\n\nแล้วมาท่องสำรวจโลกใบใหม่กันเถอะ! 🚀"
|
||||
monthAndDay: "{เดือน}/{วัน}"
|
||||
search: "ค้นหา"
|
||||
notifications: "การเเจ้งเตือน"
|
||||
|
|
|
@ -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ı aç
|
||||
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ışı
|
||||
|
|
|
@ -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: Походження
|
||||
|
|
|
@ -1,7 +1,9 @@
|
|||
---
|
||||
_lang_: "Tiếng Việt"
|
||||
headlineMisskey: "Mạng xã hội liên hợp"
|
||||
introMisskey: "Xin chào! Firefish là một nền tảng tiểu blog phi tập trung mã nguồn mở.\nViết \"tút\" để chia sẻ những suy nghĩ của bạn 📡\nBằng \"biểu cảm\", bạn có thể bày tỏ nhanh chóng cảm xúc của bạn với các tút 👍\nHãy khám phá một thế giới mới! 🚀"
|
||||
headlineFirefish: "Mạng xã hội liên hợp"
|
||||
introFirefish: "Xin chào! Firefish là một nền tảng tiểu blog phi tập trung mã nguồn
|
||||
mở.\nViết \"tút\" để chia sẻ những suy nghĩ của bạn 📡\nBằng \"biểu cảm\", bạn có
|
||||
thể bày tỏ nhanh chóng cảm xúc của bạn với các tút 👍\nHãy khám phá một thế giới
|
||||
mới! 🚀"
|
||||
monthAndDay: "{day} tháng {month}"
|
||||
search: "Tìm kiếm"
|
||||
notifications: "Thông báo"
|
||||
|
@ -13,7 +15,7 @@ ok: "Đồng ý"
|
|||
gotIt: "Đã hiểu!"
|
||||
cancel: "Hủy"
|
||||
enterUsername: "Nhập tên người dùng"
|
||||
renotedBy: "Chia sẻ bởi {user}"
|
||||
renotedBy: "{user} đăng lại"
|
||||
noNotes: "Chưa có tút nào."
|
||||
noNotifications: "Không có thông báo"
|
||||
instance: "Máy chủ"
|
||||
|
@ -44,11 +46,12 @@ copyContent: "Chép nội dung"
|
|||
copyLink: "Chép liên kết"
|
||||
delete: "Xóa"
|
||||
deleteAndEdit: "Sửa"
|
||||
deleteAndEditConfirm: "Bạn có chắc muốn sửa tút này? Những biểu cảm, lượt trả lời và đăng lại sẽ bị mất."
|
||||
deleteAndEditConfirm: "Bạn có chắc muốn sửa tút này? Những biểu cảm, lượt trả lời
|
||||
và đăng lại sẽ bị mất."
|
||||
addToList: "Thêm vào danh sách"
|
||||
sendMessage: "Gửi tin nhắn"
|
||||
copyUsername: "Chép tên người dùng"
|
||||
searchUser: "Tìm kiếm người dùng"
|
||||
searchUser: "Tìm người"
|
||||
reply: "Trả lời"
|
||||
loadMore: "Tải thêm"
|
||||
showMore: "Xem thêm"
|
||||
|
@ -64,9 +67,11 @@ import: "Nhập dữ liệu"
|
|||
export: "Xuất dữ liệu"
|
||||
files: "Tập tin"
|
||||
download: "Tải xuống"
|
||||
driveFileDeleteConfirm: "Bạn có chắc muốn xóa tập tin \"{name}\"? Tút liên quan cũng sẽ bị xóa theo."
|
||||
driveFileDeleteConfirm: "Bạn có chắc muốn xóa tập tin \"{name}\"? Tút liên quan cũng
|
||||
sẽ bị xóa theo."
|
||||
unfollowConfirm: "Bạn có chắc muốn ngưng theo dõi {name}?"
|
||||
exportRequested: "Đang chuẩn bị xuất tập tin. Quá trình này có thể mất ít phút. Nó sẽ được tự động thêm vào Drive sau khi hoàn thành."
|
||||
exportRequested: "Đang chuẩn bị xuất tập tin. Quá trình này có thể mất ít phút. Nó
|
||||
sẽ được tự động thêm vào Drive sau khi hoàn thành."
|
||||
importRequested: "Bạn vừa yêu cầu nhập dữ liệu. Quá trình này có thể mất ít phút."
|
||||
lists: "Danh sách"
|
||||
noLists: "Bạn chưa có danh sách nào"
|
||||
|
@ -81,7 +86,8 @@ error: "Lỗi"
|
|||
somethingHappened: "Xảy ra lỗi"
|
||||
retry: "Thử lại"
|
||||
pageLoadError: "Xảy ra lỗi khi tải trang."
|
||||
pageLoadErrorDescription: "Có thể là do bộ nhớ đệm của trình duyệt. Hãy thử xóa bộ nhớ đệm và thử lại sau ít phút."
|
||||
pageLoadErrorDescription: "Có thể là do bộ nhớ đệm của trình duyệt. Hãy thử xóa bộ
|
||||
nhớ đệm và thử lại sau ít phút."
|
||||
serverIsDead: "Máy chủ không phản hồi. Vui lòng thử lại sau giây lát."
|
||||
youShouldUpgradeClient: "Để xem trang này, hãy làm tươi để cập nhật ứng dụng."
|
||||
enterListName: "Đặt tên cho danh sách"
|
||||
|
@ -129,7 +135,7 @@ selectAntenna: "Chọn một antenna"
|
|||
selectWidget: "Chọn tiện ích"
|
||||
editWidgets: "Sửa tiện ích"
|
||||
editWidgetsExit: "Xong"
|
||||
customEmojis: "Tùy chỉnh emoji"
|
||||
customEmojis: "Emoji"
|
||||
emoji: "Emoji"
|
||||
emojis: "Emoji"
|
||||
emojiName: "Tên emoji"
|
||||
|
@ -137,18 +143,24 @@ emojiUrl: "URL Emoji"
|
|||
addEmoji: "Thêm emoji"
|
||||
settingGuide: "Cài đặt đề xuất"
|
||||
cacheRemoteFiles: "Tập tin cache từ xa"
|
||||
cacheRemoteFilesDescription: "Khi tùy chọn này bị tắt, các tập tin từ xa sẽ được tải trực tiếp từ máy chủ khác. Điều này sẽ giúp giảm dung lượng lưu trữ nhưng lại tăng lưu lượng truy cập, vì hình thu nhỏ sẽ không được tạo."
|
||||
cacheRemoteFilesDescription: "Khi tùy chọn này bị tắt, các tập tin từ xa sẽ được tải
|
||||
trực tiếp từ máy chủ khác. Điều này sẽ giúp giảm dung lượng lưu trữ nhưng lại tăng
|
||||
lưu lượng truy cập, vì hình thu nhỏ sẽ không được tạo."
|
||||
flagAsBot: "Đánh dấu đây là tài khoản bot"
|
||||
flagAsBotDescription: "Bật tùy chọn này nếu tài khoản này được kiểm soát bởi một chương trình. Nếu được bật, nó sẽ được đánh dấu để các nhà phát triển khác ngăn chặn chuỗi tương tác vô tận với các bot khác và điều chỉnh hệ thống nội bộ của Firefish để coi tài khoản này như một bot."
|
||||
flagAsBotDescription: "Bật tùy chọn này nếu tài khoản này được kiểm soát bởi một chương
|
||||
trình. Nếu được bật, nó sẽ được đánh dấu để các nhà phát triển khác ngăn chặn chuỗi
|
||||
tương tác vô tận với các bot khác và điều chỉnh hệ thống nội bộ của Firefish để
|
||||
coi tài khoản này như một bot."
|
||||
flagAsCat: "Tài khoản này là mèo"
|
||||
flagAsCatDescription: "Bật tùy chọn này để đánh dấu tài khoản là một con mèo."
|
||||
flagShowTimelineReplies: "Hiện lượt trả lời trong bảng tin"
|
||||
flagShowTimelineRepliesDescription: "Hiện lượt trả lời của người bạn theo dõi trên tút của những người khác."
|
||||
flagShowTimelineRepliesDescription: "Hiện lượt trả lời của người bạn theo dõi trên
|
||||
tút của những người khác."
|
||||
autoAcceptFollowed: "Tự động phê duyệt theo dõi từ những người mà bạn đang theo dõi"
|
||||
addAccount: "Thêm tài khoản"
|
||||
loginFailed: "Đăng nhập không thành công"
|
||||
showOnRemote: "Truy cập trang của người này"
|
||||
general: "Tổng quan"
|
||||
general: "Tổng quát"
|
||||
wallpaper: "Ảnh bìa"
|
||||
setWallpaper: "Đặt ảnh bìa"
|
||||
removeWallpaper: "Xóa ảnh bìa"
|
||||
|
@ -156,7 +168,11 @@ searchWith: "Tìm kiếm: {q}"
|
|||
youHaveNoLists: "Bạn chưa có danh sách nào"
|
||||
followConfirm: "Bạn có chắc muốn theo dõi {name}?"
|
||||
proxyAccount: "Tài khoản proxy"
|
||||
proxyAccountDescription: "Tài khoản proxy là tài khoản hoạt động như một người theo dõi từ xa cho người dùng trong những điều kiện nhất định. Ví dụ: khi người dùng thêm người dùng từ xa vào danh sách, hoạt động của người dùng từ xa sẽ không được chuyển đến phiên bản nếu không có người dùng cục bộ nào theo dõi người dùng đó, vì vậy tài khoản proxy sẽ theo dõi."
|
||||
proxyAccountDescription: "Tài khoản proxy là tài khoản hoạt động như một người theo
|
||||
dõi từ xa cho người dùng trong những điều kiện nhất định. Ví dụ: khi người dùng
|
||||
thêm người dùng từ xa vào danh sách, hoạt động của người dùng từ xa sẽ không được
|
||||
chuyển đến phiên bản nếu không có người dùng cục bộ nào theo dõi người dùng đó,
|
||||
vì vậy tài khoản proxy sẽ theo dõi."
|
||||
host: "Host"
|
||||
selectUser: "Chọn người dùng"
|
||||
recipient: "Người nhận"
|
||||
|
@ -168,9 +184,9 @@ latestRequestSentAt: "Yêu cầu cuối gửi lúc"
|
|||
latestRequestReceivedAt: "Yêu cầu cuối nhận lúc"
|
||||
latestStatus: "Trạng thái cuối cùng"
|
||||
storageUsage: "Dung lượng lưu trữ"
|
||||
charts: "Đồ thị"
|
||||
perHour: "Mỗi Giờ"
|
||||
perDay: "Mỗi Ngày"
|
||||
charts: "Biểu đồ"
|
||||
perHour: "Mỗi giờ"
|
||||
perDay: "Mỗi ngày"
|
||||
stopActivityDelivery: "Ngưng gửi hoạt động"
|
||||
blockThisInstance: "Chặn máy chủ này"
|
||||
operations: "Vận hành"
|
||||
|
@ -186,11 +202,13 @@ instanceInfo: "Thông tin máy chủ"
|
|||
statistics: "Thống kê"
|
||||
clearQueue: "Xóa hàng đợi"
|
||||
clearQueueConfirmTitle: "Bạn có chắc muốn xóa hàng đợi?"
|
||||
clearQueueConfirmText: "Mọi tút chưa được gửi còn lại trong hàng đợi sẽ không được liên hợp. Thông thường thao tác này không cần thiết."
|
||||
clearQueueConfirmText: "Mọi tút chưa được gửi còn lại trong hàng đợi sẽ không được
|
||||
liên hợp. Thông thường thao tác này không cần thiết."
|
||||
clearCachedFiles: "Xóa bộ nhớ đệm"
|
||||
clearCachedFilesConfirm: "Bạn có chắc muốn xóa sạch bộ nhớ đệm?"
|
||||
blockedInstances: "Máy chủ đã chặn"
|
||||
blockedInstancesDescription: "Danh sách những máy chủ bạn muốn chặn. Chúng sẽ không thể giao tiếp với máy chủy này nữa."
|
||||
blockedInstancesDescription: "Danh sách những máy chủ bạn muốn chặn. Chúng sẽ không
|
||||
thể giao tiếp với máy chủy này nữa."
|
||||
muteAndBlock: "Ẩn và Chặn"
|
||||
mutedUsers: "Người đã ẩn"
|
||||
blockedUsers: "Người đã chặn"
|
||||
|
@ -239,14 +257,15 @@ saved: "Đã lưu"
|
|||
messaging: "Trò chuyện"
|
||||
upload: "Tải lên"
|
||||
keepOriginalUploading: "Giữ hình ảnh gốc"
|
||||
keepOriginalUploadingDescription: "Giữ nguyên như hình ảnh được tải lên ban đầu. Nếu tắt, một phiên bản để hiển thị trên web sẽ được tạo khi tải lên."
|
||||
keepOriginalUploadingDescription: "Giữ nguyên như hình ảnh được tải lên ban đầu. Nếu
|
||||
tắt, một phiên bản để hiển thị trên web sẽ được tạo khi tải lên."
|
||||
fromDrive: "Từ ổ đĩa"
|
||||
fromUrl: "Từ URL"
|
||||
uploadFromUrl: "Tải lên bằng một URL"
|
||||
uploadFromUrlDescription: "URL của tập tin bạn muốn tải lên"
|
||||
uploadFromUrlRequested: "Đã yêu cầu tải lên"
|
||||
uploadFromUrlMayTakeTime: "Sẽ mất một khoảng thời gian để tải lên xong."
|
||||
explore: "Khám phá"
|
||||
explore: "Khám phó"
|
||||
messageRead: "Đã đọc"
|
||||
noMoreHistory: "Không còn gì để đọc"
|
||||
startMessaging: "Bắt đầu trò chuyện"
|
||||
|
@ -255,7 +274,8 @@ agreeTo: "Tôi đồng ý {0}"
|
|||
tos: "Điều khoản dịch vụ"
|
||||
start: "Bắt đầu"
|
||||
home: "Trang chính"
|
||||
remoteUserCaution: "Vì người dùng này ở máy chủ khác, thông tin hiển thị có thể không đầy đủ."
|
||||
remoteUserCaution: "Vì người dùng này ở máy chủ khác, thông tin hiển thị có thể không
|
||||
đầy đủ."
|
||||
activity: "Hoạt động"
|
||||
images: "Hình ảnh"
|
||||
birthday: "Sinh nhật"
|
||||
|
@ -288,7 +308,8 @@ unableToDelete: "Không thể xóa"
|
|||
inputNewFileName: "Nhập tên mới cho tập tin"
|
||||
inputNewDescription: "Nhập mô tả mới"
|
||||
inputNewFolderName: "Nhập tên mới cho thư mục"
|
||||
circularReferenceFolder: "Thư mục đích là một thư mục con của thư mục bạn muốn di chuyển."
|
||||
circularReferenceFolder: "Thư mục đích là một thư mục con của thư mục bạn muốn di
|
||||
chuyển."
|
||||
hasChildFilesOrFolders: "Không thể xóa cho đến khi không còn gì trong thư mục."
|
||||
copyUrl: "Sao chép URL"
|
||||
rename: "Đổi tên"
|
||||
|
@ -322,7 +343,8 @@ connectService: "Kết nối"
|
|||
disconnectService: "Ngắt kết nối"
|
||||
enableLocalTimeline: "Bật bảng tin máy chủ"
|
||||
enableGlobalTimeline: "Bật bảng tin liên hợp"
|
||||
disablingTimelinesInfo: "Quản trị viên và Kiểm duyệt viên luôn có quyền truy cập mọi bảng tin, kể cả khi chúng không được bật."
|
||||
disablingTimelinesInfo: "Quản trị viên và Kiểm duyệt viên luôn có quyền truy cập mọi
|
||||
bảng tin, kể cả khi chúng không được bật."
|
||||
registration: "Đăng ký"
|
||||
enableRegistration: "Cho phép đăng ký mới"
|
||||
invite: "Mời"
|
||||
|
@ -334,7 +356,8 @@ bannerUrl: "URL Ảnh bìa"
|
|||
backgroundImageUrl: "URL Ảnh nền"
|
||||
basicInfo: "Thông tin cơ bản"
|
||||
pinnedUsers: "Những người thú vị"
|
||||
pinnedUsersDescription: "Liệt kê mỗi hàng một tên người dùng xuống dòng để ghim trên tab \"Khám phá\"."
|
||||
pinnedUsersDescription: "Liệt kê mỗi hàng một tên người dùng xuống dòng để ghim trên
|
||||
tab \"Khám phá\"."
|
||||
pinnedPages: "Trang đã ghim"
|
||||
pinnedPagesDescription: "Liệt kê các trang thú vị để ghim trên máy chủ."
|
||||
pinnedClipId: "ID của clip muốn ghim"
|
||||
|
@ -347,14 +370,17 @@ recaptcha: "reCAPTCHA"
|
|||
enableRecaptcha: "Bật reCAPTCHA"
|
||||
recaptchaSiteKey: "Khóa của trang"
|
||||
recaptchaSecretKey: "Khóa bí mật"
|
||||
avoidMultiCaptchaConfirm: "Dùng nhiều hệ thống Captcha có thể gây nhiễu giữa chúng. Bạn có muốn tắt các hệ thống Captcha khác hiện đang hoạt động không? Nếu bạn muốn chúng tiếp tục được bật, hãy nhấn hủy."
|
||||
avoidMultiCaptchaConfirm: "Dùng nhiều hệ thống Captcha có thể gây nhiễu giữa chúng.
|
||||
Bạn có muốn tắt các hệ thống Captcha khác hiện đang hoạt động không? Nếu bạn muốn
|
||||
chúng tiếp tục được bật, hãy nhấn hủy."
|
||||
antennas: "Trạm phát sóng"
|
||||
manageAntennas: "Quản lý trạm phát sóng"
|
||||
name: "Tên"
|
||||
antennaSource: "Nguồn trạm phát sóng"
|
||||
antennaKeywords: "Từ khóa để nghe"
|
||||
antennaExcludeKeywords: "Từ khóa để lọc ra"
|
||||
antennaKeywordsDescription: "Phân cách bằng dấu cách cho điều kiện AND hoặc bằng xuống dòng cho điều kiện OR."
|
||||
antennaKeywordsDescription: "Phân cách bằng dấu cách cho điều kiện AND hoặc bằng xuống
|
||||
dòng cho điều kiện OR."
|
||||
notifyAntenna: "Thông báo có tút mới"
|
||||
withFileAntenna: "Chỉ những tút có media"
|
||||
enableServiceworker: "Bật ServiceWorker"
|
||||
|
@ -362,7 +388,7 @@ antennaUsersDescription: "Liệt kê mỗi hàng một tên người dùng"
|
|||
caseSensitive: "Trường hợp nhạy cảm"
|
||||
withReplies: "Bao gồm lượt trả lời"
|
||||
connectedTo: "Những tài khoản sau đã kết nối"
|
||||
notesAndReplies: "Tút kèm trả lời"
|
||||
notesAndReplies: "Lượt trả lời"
|
||||
withFiles: "Media"
|
||||
silence: "Ẩn"
|
||||
silenceConfirm: "Bạn có chắc muốn ẩn người này?"
|
||||
|
@ -433,7 +459,8 @@ invitationCode: "Mã mời"
|
|||
checking: "Đang kiểm tra..."
|
||||
available: "Khả dụng"
|
||||
unavailable: "Không khả dụng"
|
||||
usernameInvalidFormat: "Bạn có thể dùng viết hoa/viết thường, chữ số, và dấu gạch dưới."
|
||||
usernameInvalidFormat: "Bạn có thể dùng viết hoa/viết thường, chữ số, và dấu gạch
|
||||
dưới."
|
||||
tooShort: "Quá ngắn"
|
||||
tooLong: "Quá dài"
|
||||
weakPassword: "Mật khẩu yếu"
|
||||
|
@ -442,7 +469,8 @@ strongPassword: "Mật khẩu mạnh"
|
|||
passwordMatched: "Trùng khớp"
|
||||
passwordNotMatched: "Không trùng khớp"
|
||||
signinWith: "Đăng nhập bằng {x}"
|
||||
signinFailed: "Không thể đăng nhập. Vui lòng kiểm tra tên người dùng và mật khẩu của bạn."
|
||||
signinFailed: "Không thể đăng nhập. Vui lòng kiểm tra tên người dùng và mật khẩu của
|
||||
bạn."
|
||||
tapSecurityKey: "Nhấn mã bảo mật của bạn"
|
||||
or: "Hoặc"
|
||||
language: "Ngôn ngữ"
|
||||
|
@ -483,15 +511,20 @@ showFeaturedNotesInTimeline: "Hiện tút nổi bật trong bảng tin"
|
|||
objectStorage: "Đối tượng lưu trữ"
|
||||
useObjectStorage: "Dùng đối tượng lưu trữ"
|
||||
objectStorageBaseUrl: "Base URL"
|
||||
objectStorageBaseUrlDesc: "URL được sử dụng làm tham khảo. Chỉ định URL của CDN hoặc Proxy của bạn nếu bạn đang sử dụng. Với S3 dùng 'https://<bucket>.s3.amazonaws.com', còn GCS hoặc dịch vụ tương tự dùng 'https://storage.googleapis.com/<bucket>', etc."
|
||||
objectStorageBaseUrlDesc: "URL được sử dụng làm tham khảo. Chỉ định URL của CDN hoặc
|
||||
Proxy của bạn nếu bạn đang sử dụng. Với S3 dùng 'https://<bucket>.s3.amazonaws.com',
|
||||
còn GCS hoặc dịch vụ tương tự dùng 'https://storage.googleapis.com/<bucket>', etc."
|
||||
objectStorageBucket: "Bucket"
|
||||
objectStorageBucketDesc: "Nhập tên bucket dùng ở nhà cung cấp của bạn."
|
||||
objectStoragePrefix: "Tiền tố"
|
||||
objectStoragePrefixDesc: "Các tập tin sẽ được lưu trữ trong các thư mục có tiền tố này."
|
||||
objectStoragePrefixDesc: "Các tập tin sẽ được lưu trữ trong các thư mục có tiền tố
|
||||
này."
|
||||
objectStorageEndpoint: "Đầu cuối"
|
||||
objectStorageEndpointDesc: "Để trống nếu bạn đang dùng AWS S3, nếu không thì chỉ định đầu cuối là '<host>' hoặc '<host>:<port>', tùy thuộc vào nhà cung cấp dịch vụ."
|
||||
objectStorageEndpointDesc: "Để trống nếu bạn đang dùng AWS S3, nếu không thì chỉ định
|
||||
đầu cuối là '<host>' hoặc '<host>:<port>', tùy thuộc vào nhà cung cấp dịch vụ."
|
||||
objectStorageRegion: "Khu vực"
|
||||
objectStorageRegionDesc: "Nhập một khu vực cụ thể như 'xx-east-1'. Nếu nhà cung cấp dịch vụ của bạn không phân biệt giữa các khu vực, hãy để trống hoặc nhập 'us-east-1'."
|
||||
objectStorageRegionDesc: "Nhập một khu vực cụ thể như 'xx-east-1'. Nếu nhà cung cấp
|
||||
dịch vụ của bạn không phân biệt giữa các khu vực, hãy để trống hoặc nhập 'us-east-1'."
|
||||
objectStorageUseSSL: "Dùng SSL"
|
||||
objectStorageUseSSLDesc: "Tắt nếu bạn không dùng HTTPS để kết nối API"
|
||||
objectStorageUseProxy: "Kết nối thông qua Proxy"
|
||||
|
@ -523,7 +556,8 @@ sort: "Sắp xếp"
|
|||
ascendingOrder: "Tăng dần"
|
||||
descendingOrder: "Giảm dần"
|
||||
scratchpad: "Scratchpad"
|
||||
scratchpadDescription: "Scratchpad cung cấp môi trường cho các thử nghiệm AiScript. Bạn có thể viết, thực thi và kiểm tra kết quả tương tác với Firefish trong đó."
|
||||
scratchpadDescription: "Scratchpad cung cấp môi trường cho các thử nghiệm AiScript.
|
||||
Bạn có thể viết, thực thi và kiểm tra kết quả tương tác với Firefish trong đó."
|
||||
output: "Nguồn ra"
|
||||
script: "Kịch bản"
|
||||
disablePagesScript: "Tắt AiScript trên Trang"
|
||||
|
@ -531,11 +565,14 @@ updateRemoteUser: "Cập nhật thông tin người dùng ở máy chủ khác"
|
|||
deleteAllFiles: "Xóa toàn bộ tập tin"
|
||||
deleteAllFilesConfirm: "Bạn có chắc xóa toàn bộ tập tin?"
|
||||
removeAllFollowing: "Ngưng theo dõi tất cả mọi người"
|
||||
removeAllFollowingDescription: "Thực hiện điều này sẽ ngưng theo dõi tất cả các tài khoản khỏi {host}. Chỉ thực hiện điều này nếu máy chủ không còn tồn tại."
|
||||
removeAllFollowingDescription: "Thực hiện điều này sẽ ngưng theo dõi tất cả các tài
|
||||
khoản khỏi {host}. Chỉ thực hiện điều này nếu máy chủ không còn tồn tại."
|
||||
userSuspended: "Người này đã bị vô hiệu hóa."
|
||||
userSilenced: "Người này đã bị ẩn"
|
||||
yourAccountSuspendedTitle: "Tài khoản bị vô hiệu hóa"
|
||||
yourAccountSuspendedDescription: "Tài khoản này đã bị vô hiệu hóa do vi phạm quy tắc máy chủ hoặc điều tương tự. Liên hệ với quản trị viên nếu bạn muốn biết lý do chi tiết hơn. Vui lòng không tạo tài khoản mới."
|
||||
yourAccountSuspendedDescription: "Tài khoản này đã bị vô hiệu hóa do vi phạm quy tắc
|
||||
máy chủ hoặc điều tương tự. Liên hệ với quản trị viên nếu bạn muốn biết lý do chi
|
||||
tiết hơn. Vui lòng không tạo tài khoản mới."
|
||||
menu: "Menu"
|
||||
divider: "Phân chia"
|
||||
addItem: "Thêm mục"
|
||||
|
@ -576,12 +613,14 @@ permission: "Cho phép "
|
|||
enableAll: "Bật toàn bộ"
|
||||
disableAll: "Tắt toàn bộ"
|
||||
tokenRequested: "Cấp quyền truy cập vào tài khoản"
|
||||
pluginTokenRequestedDescription: "Plugin này sẽ có thể sử dụng các quyền được đặt ở đây."
|
||||
pluginTokenRequestedDescription: "Plugin này sẽ có thể sử dụng các quyền được đặt
|
||||
ở đây."
|
||||
notificationType: "Loại thông báo"
|
||||
edit: "Sửa"
|
||||
emailServer: "Email máy chủ"
|
||||
enableEmail: "Bật phân phối email"
|
||||
emailConfigInfo: "Được dùng để xác minh email của bạn lúc đăng ký hoặc nếu bạn quên mật khẩu của mình"
|
||||
emailConfigInfo: "Được dùng để xác minh email của bạn lúc đăng ký hoặc nếu bạn quên
|
||||
mật khẩu của mình"
|
||||
email: "Email"
|
||||
emailAddress: "Địa chỉ email"
|
||||
smtpConfig: "Cấu hình máy chủ SMTP"
|
||||
|
@ -602,7 +641,7 @@ makeActive: "Kích hoạt"
|
|||
display: "Hiển thị"
|
||||
copy: "Sao chép"
|
||||
metrics: "Số liệu"
|
||||
overview: "Tổng quan"
|
||||
overview: "Chung"
|
||||
logs: "Nhật ký"
|
||||
delayed: "Độ trễ"
|
||||
database: "Cơ sở dữ liệu"
|
||||
|
@ -611,10 +650,13 @@ create: "Tạo"
|
|||
notificationSetting: "Cài đặt thông báo"
|
||||
notificationSettingDesc: "Chọn loại thông báo bạn muốn hiển thị."
|
||||
useGlobalSetting: "Dùng thiết lập chung"
|
||||
useGlobalSettingDesc: "Nếu được bật, cài đặt thông báo của bạn sẽ được áp dụng. Nếu bị tắt, có thể thực hiện các thiết lập riêng lẻ."
|
||||
useGlobalSettingDesc: "Nếu được bật, cài đặt thông báo của bạn sẽ được áp dụng. Nếu
|
||||
bị tắt, có thể thực hiện các thiết lập riêng lẻ."
|
||||
other: "Khác"
|
||||
regenerateLoginToken: "Tạo lại mã đăng nhập"
|
||||
regenerateLoginTokenDescription: "Tạo lại mã nội bộ có thể dùng để đăng nhập. Thông thường hành động này là không cần thiết. Nếu được tạo lại, tất cả các thiết bị sẽ bị đăng xuất."
|
||||
regenerateLoginTokenDescription: "Tạo lại mã nội bộ có thể dùng để đăng nhập. Thông
|
||||
thường hành động này là không cần thiết. Nếu được tạo lại, tất cả các thiết bị sẽ
|
||||
bị đăng xuất."
|
||||
setMultipleBySeparatingWithSpace: "Tách nhiều mục nhập bằng dấu cách."
|
||||
fileIdOrUrl: "ID tập tin hoặc URL"
|
||||
behavior: "Thao tác"
|
||||
|
@ -622,19 +664,22 @@ sample: "Ví dụ"
|
|||
abuseReports: "Lượt báo cáo"
|
||||
reportAbuse: "Báo cáo"
|
||||
reportAbuseOf: "Báo cáo {name}"
|
||||
fillAbuseReportDescription: "Vui lòng điền thông tin chi tiết về báo cáo này. Nếu đó là về một tút cụ thể, hãy kèm theo URL của tút."
|
||||
fillAbuseReportDescription: "Vui lòng điền thông tin chi tiết về báo cáo này. Nếu
|
||||
đó là về một tút cụ thể, hãy kèm theo URL của tút."
|
||||
abuseReported: "Báo cáo đã được gửi. Cảm ơn bạn nhiều."
|
||||
reporter: "Người báo cáo"
|
||||
reporteeOrigin: "Bị báo cáo"
|
||||
reporterOrigin: "Máy chủ người báo cáo"
|
||||
forwardReport: "Chuyển tiếp báo cáo cho máy chủ từ xa"
|
||||
forwardReportIsAnonymous: "Thay vì tài khoản của bạn, một tài khoản hệ thống ẩn danh sẽ được hiển thị dưới dạng người báo cáo ở máy chủ từ xa."
|
||||
forwardReportIsAnonymous: "Thay vì tài khoản của bạn, một tài khoản hệ thống ẩn danh
|
||||
sẽ được hiển thị dưới dạng người báo cáo ở máy chủ từ xa."
|
||||
send: "Gửi"
|
||||
abuseMarkAsResolved: "Đánh dấu đã xử lý"
|
||||
openInNewTab: "Mở trong tab mới"
|
||||
openInSideView: "Mở trong thanh bên"
|
||||
defaultNavigationBehaviour: "Thao tác điều hướng mặc định"
|
||||
editTheseSettingsMayBreakAccount: "Việc chỉnh sửa các cài đặt này có thể làm hỏng tài khoản của bạn."
|
||||
editTheseSettingsMayBreakAccount: "Việc chỉnh sửa các cài đặt này có thể làm hỏng
|
||||
tài khoản của bạn."
|
||||
instanceTicker: "Thông tin máy chủ của tút"
|
||||
waitingFor: "Đang đợi {x}"
|
||||
random: "Ngẫu nhiên"
|
||||
|
@ -646,9 +691,11 @@ createNew: "Tạo mới"
|
|||
optional: "Không bắt buộc"
|
||||
createNewClip: "Tạo một ghim mới"
|
||||
unclip: "Bỏ ghim"
|
||||
confirmToUnclipAlreadyClippedNote: "Bài đăng này là một phần của \"{name}\" ghim. Bạn có muốn bỏ khỏi ghim?"
|
||||
confirmToUnclipAlreadyClippedNote: "Bài đăng này là một phần của \"{name}\" ghim.
|
||||
Bạn có muốn bỏ khỏi ghim?"
|
||||
public: "Công khai"
|
||||
i18nInfo: "Firefish đang được các tình nguyện viên dịch sang nhiều thứ tiếng khác nhau. Bạn có thể hỗ trợ tại {link}."
|
||||
i18nInfo: "Firefish đang được các tình nguyện viên dịch sang nhiều thứ tiếng khác
|
||||
nhau. Bạn có thể hỗ trợ tại {link}."
|
||||
manageAccessTokens: "Tạo mã truy cập"
|
||||
accountInfo: "Thông tin tài khoản"
|
||||
notesCount: "Số lượng tút"
|
||||
|
@ -667,12 +714,15 @@ no: "Từ chối"
|
|||
driveFilesCount: "Số tập tin trong Ổ đĩa"
|
||||
driveUsage: "Dung lượng ổ đĩa"
|
||||
noCrawle: "Từ chối lập chỉ mục"
|
||||
noCrawleDescription: "Không cho công cụ tìm kiếm lập chỉ mục trang hồ sơ, tút, Trang, etc."
|
||||
lockedAccountInfo: "Ghi chú của bạn sẽ hiển thị với bất kỳ ai, trừ khi bạn đặt chế độ hiển thị tút của mình thành \"Chỉ người theo dõi\"."
|
||||
noCrawleDescription: "Không cho công cụ tìm kiếm lập chỉ mục trang hồ sơ, tút, Trang,
|
||||
etc."
|
||||
lockedAccountInfo: "Ghi chú của bạn sẽ hiển thị với bất kỳ ai, trừ khi bạn đặt chế
|
||||
độ hiển thị tút của mình thành \"Chỉ người theo dõi\"."
|
||||
alwaysMarkSensitive: "Luôn đánh dấu NSFW"
|
||||
loadRawImages: "Tải ảnh gốc thay vì ảnh thu nhỏ"
|
||||
disableShowingAnimatedImages: "Không phát ảnh động"
|
||||
verificationEmailSent: "Một email xác minh đã được gửi. Vui lòng nhấn vào liên kết đính kèm để hoàn tất xác minh."
|
||||
verificationEmailSent: "Một email xác minh đã được gửi. Vui lòng nhấn vào liên kết
|
||||
đính kèm để hoàn tất xác minh."
|
||||
notSet: "Chưa đặt"
|
||||
emailVerified: "Email đã được xác minh"
|
||||
noteFavoritesCount: "Số lượng tút yêu thích"
|
||||
|
@ -684,14 +734,16 @@ clips: "Ghim"
|
|||
experimentalFeatures: "Tính năng thử nghiệm"
|
||||
developer: "Nhà phát triển"
|
||||
makeExplorable: "Không hiện tôi trong \"Khám phá\""
|
||||
makeExplorableDescription: "Nếu bạn tắt, tài khoản của bạn sẽ không hiện trong mục \"Khám phá\"."
|
||||
makeExplorableDescription: "Nếu bạn tắt, tài khoản của bạn sẽ không hiện trong mục
|
||||
\"Khám phá\"."
|
||||
showGapBetweenNotesInTimeline: "Hiện dải phân cách giữa các tút trên bảng tin"
|
||||
duplicate: "Tạo bản sao"
|
||||
left: "Bên trái"
|
||||
center: "Giữa"
|
||||
wide: "Rộng"
|
||||
narrow: "Thu hẹp"
|
||||
reloadToApplySetting: "Cài đặt này sẽ chỉ áp dụng sau khi tải lại trang. Tải lại ngay bây giờ?"
|
||||
reloadToApplySetting: "Cài đặt này sẽ chỉ áp dụng sau khi tải lại trang. Tải lại ngay
|
||||
bây giờ?"
|
||||
needReloadToApply: "Cần tải lại để điều này được áp dụng."
|
||||
showTitlebar: "Hiện thanh tựa đề"
|
||||
clearCache: "Xóa bộ nhớ đệm"
|
||||
|
@ -699,7 +751,10 @@ onlineUsersCount: "{n} người đang online"
|
|||
nUsers: "{n} Người"
|
||||
nNotes: "{n} Tút"
|
||||
sendErrorReports: "Báo lỗi"
|
||||
sendErrorReportsDescription: "Khi được bật, thông tin chi tiết về lỗi sẽ được chia sẻ với Firefish khi xảy ra sự cố, giúp nâng cao chất lượng của Firefish.\nBao gồm thông tin như phiên bản hệ điều hành của bạn, trình duyệt bạn đang sử dụng, hoạt động của bạn trong Firefish, v.v."
|
||||
sendErrorReportsDescription: "Khi được bật, thông tin chi tiết về lỗi sẽ được chia
|
||||
sẻ với Firefish khi xảy ra sự cố, giúp nâng cao chất lượng của Firefish.\nBao gồm
|
||||
thông tin như phiên bản hệ điều hành của bạn, trình duyệt bạn đang sử dụng, hoạt
|
||||
động của bạn trong Firefish, v.v."
|
||||
myTheme: "Theme của tôi"
|
||||
backgroundColor: "Màu nền"
|
||||
accentColor: "Màu phụ"
|
||||
|
@ -708,7 +763,7 @@ saveAs: "Lưu thành"
|
|||
advanced: "Nâng cao"
|
||||
value: "Giá trị"
|
||||
createdAt: "Ngày tạo"
|
||||
updatedAt: "Cập nhật lúc"
|
||||
updatedAt: "Cập nhật"
|
||||
saveConfirm: "Lưu thay đổi?"
|
||||
deleteConfirm: "Bạn có muốn xóa không?"
|
||||
invalidValue: "Giá trị không hợp lệ."
|
||||
|
@ -738,14 +793,16 @@ unlikeConfirm: "Bạn có chắc muốn bỏ thích ?"
|
|||
fullView: "Kích thước đầy đủ"
|
||||
quitFullView: "Thoát toàn màn hình"
|
||||
addDescription: "Thêm mô tả"
|
||||
userPagePinTip: "Bạn có thể hiển thị các tút ở đây bằng cách chọn \"Ghim vào hồ sơ\" từ menu của mỗi tút."
|
||||
userPagePinTip: "Bạn có thể hiển thị các tút ở đây bằng cách chọn \"Ghim vào hồ sơ\"\
|
||||
\ từ menu của mỗi tút."
|
||||
notSpecifiedMentionWarning: "Tút này có đề cập đến những người không mong muốn"
|
||||
info: "Giới thiệu"
|
||||
userInfo: "Thông tin người dùng"
|
||||
unknown: "Chưa biết"
|
||||
onlineStatus: "Trạng thái"
|
||||
hideOnlineStatus: "Ẩn trạng thái online"
|
||||
hideOnlineStatusDescription: "Ẩn trạng thái online của bạn làm giảm sự tiện lợi của một số tính năng như tìm kiếm."
|
||||
hideOnlineStatusDescription: "Ẩn trạng thái online của bạn làm giảm sự tiện lợi của
|
||||
một số tính năng như tìm kiếm."
|
||||
online: "Online"
|
||||
active: "Hoạt động"
|
||||
offline: "Offline"
|
||||
|
@ -780,12 +837,13 @@ emailNotConfiguredWarning: "Chưa đặt địa chỉ email."
|
|||
ratio: "Tỷ lệ"
|
||||
previewNoteText: "Hiện xem trước"
|
||||
customCss: "Tùy chỉnh CSS"
|
||||
customCssWarn: "Chỉ sử dụng những cài đặt này nếu bạn biết rõ về nó. Việc nhập các giá trị không đúng có thể khiến máy chủ hoạt động không bình thường."
|
||||
customCssWarn: "Chỉ sử dụng những cài đặt này nếu bạn biết rõ về nó. Việc nhập các
|
||||
giá trị không đúng có thể khiến máy chủ hoạt động không bình thường."
|
||||
global: "Toàn cầu"
|
||||
squareAvatars: "Ảnh đại diện vuông"
|
||||
sent: "Gửi"
|
||||
received: "Đã nhận"
|
||||
searchResult: "Kết quả tìm kiếm"
|
||||
searchResult: "Tìm thấy"
|
||||
hashtags: "Hashtag"
|
||||
troubleshooting: "Khắc phục sự cố"
|
||||
useBlurEffect: "Dùng hiệu ứng làm mờ trong giao diện"
|
||||
|
@ -795,7 +853,8 @@ whatIsNew: "Hiện những thay đổi"
|
|||
translate: "Dịch"
|
||||
translatedFrom: "Dịch từ {x}"
|
||||
accountDeletionInProgress: "Đang xử lý việc xóa tài khoản"
|
||||
usernameInfo: "Bạn có thể sử dụng chữ cái (a ~ z, A ~ Z), chữ số (0 ~ 9) hoặc dấu gạch dưới (_). Tên người dùng không thể thay đổi sau này."
|
||||
usernameInfo: "Bạn có thể sử dụng chữ cái (a ~ z, A ~ Z), chữ số (0 ~ 9) hoặc dấu
|
||||
gạch dưới (_). Tên người dùng không thể thay đổi sau này."
|
||||
aiChanMode: "Chế độ Ai"
|
||||
keepCw: "Giữ cảnh báo nội dung"
|
||||
pubSub: "Tài khoản Chính/Phụ"
|
||||
|
@ -811,12 +870,14 @@ filter: "Bộ lọc"
|
|||
controlPanel: "Bảng điều khiển"
|
||||
manageAccounts: "Quản lý tài khoản"
|
||||
makeReactionsPublic: "Đặt lịch sử biểu cảm công khai"
|
||||
makeReactionsPublicDescription: "Điều này sẽ hiển thị công khai danh sách tất cả các biểu cảm trước đây của bạn."
|
||||
makeReactionsPublicDescription: "Điều này sẽ hiển thị công khai danh sách tất cả các
|
||||
biểu cảm trước đây của bạn."
|
||||
classic: "Cổ điển"
|
||||
muteThread: "Không quan tâm nữa"
|
||||
unmuteThread: "Quan tâm tút này"
|
||||
ffVisibility: "Hiển thị Theo dõi/Người theo dõi"
|
||||
ffVisibilityDescription: "Quyết định ai có thể xem những người bạn theo dõi và những người theo dõi bạn."
|
||||
ffVisibilityDescription: "Quyết định ai có thể xem những người bạn theo dõi và những
|
||||
người theo dõi bạn."
|
||||
continueThread: "Tiếp tục xem chuỗi tút"
|
||||
deleteAccountConfirm: "Điều này sẽ khiến tài khoản bị xóa vĩnh viễn. Vẫn tiếp tục?"
|
||||
incorrectPassword: "Sai mật khẩu."
|
||||
|
@ -857,14 +918,17 @@ thereIsUnresolvedAbuseReportWarning: "Có báo cáo chưa xử lí."
|
|||
recommended: "Được đề xuất"
|
||||
check: "Kiểm tra"
|
||||
driveCapOverrideLabel: "Thay đổi dung lượng drive cho người này"
|
||||
driveCapOverrideCaption: "Đặt dung lượng drive về mặc định bằng cách nhập 0 hoặc số âm."
|
||||
driveCapOverrideCaption: "Đặt dung lượng drive về mặc định bằng cách nhập 0 hoặc số
|
||||
âm."
|
||||
requireAdminForView: "Bạn phải đăng nhập như là quản trị viên mới xem được."
|
||||
isSystemAccount: "Đã tạo một tài khoản và tự động vận hành bởi hệ thống."
|
||||
typeToConfirm: "Nhấn {x} để xác nhận"
|
||||
deleteAccount: "Xóa tài khoản"
|
||||
document: "Tài liệu"
|
||||
numberOfPageCache: "Số lượng trang bộ nhớ đệm"
|
||||
numberOfPageCacheDescription: "Việc tăng con số này sẽ cải thiện sự thuận tiện cho người dùng nhưng gây ra nhiều áp lực hơn cho máy chủ cũng như sử dụng nhiều bộ nhớ hơn."
|
||||
numberOfPageCacheDescription: "Việc tăng con số này sẽ cải thiện sự thuận tiện cho
|
||||
người dùng nhưng gây ra nhiều áp lực hơn cho máy chủ cũng như sử dụng nhiều bộ nhớ
|
||||
hơn."
|
||||
logoutConfirm: "Bạn có chắc muốn đăng xuất?"
|
||||
lastActiveDate: "Lần cuối vào"
|
||||
statusbar: "Thanh trạng thái"
|
||||
|
@ -881,24 +945,33 @@ sensitiveMediaDetection: "Tự động phát hiện NSFW"
|
|||
localOnly: "Chỉ trên máy chủ"
|
||||
remoteOnly: "Chỉ máy chủ từ xa"
|
||||
failedToUpload: "Tải lên thất bại"
|
||||
cannotUploadBecauseInappropriate: "Không thể tải lên tập tin này vì các phần của tập tin đã được phát hiện có khả năng là NSFW."
|
||||
cannotUploadBecauseInappropriate: "Không thể tải lên tập tin này vì các phần của tập
|
||||
tin đã được phát hiện có khả năng là NSFW."
|
||||
cannotUploadBecauseNoFreeSpace: "Tải lên không thành công do thiếu dung lượng Drive."
|
||||
beta: "Beta"
|
||||
enableAutoSensitive: "Tự động đánh dấu NSFW"
|
||||
enableAutoSensitiveDescription: "Cho phép tự động phát hiện và đánh dấu media NSFW thông qua học máy, nếu có thể. Ngay cả khi tùy chọn này bị tắt, nó vẫn có thể được bật trên toàn máy chủ."
|
||||
activeEmailValidationDescription: "Cho phép xác minh địa chỉ email chặt chẽ hơn, bao gồm việc kiểm tra các địa chỉ dùng một lần và xem nó có thực sự được giao tiếp hay không. Khi bỏ chọn, chỉ định dạng của email được xác minh."
|
||||
enableAutoSensitiveDescription: "Cho phép tự động phát hiện và đánh dấu media NSFW
|
||||
thông qua học máy, nếu có thể. Ngay cả khi tùy chọn này bị tắt, nó vẫn có thể được
|
||||
bật trên toàn máy chủ."
|
||||
activeEmailValidationDescription: "Cho phép xác minh địa chỉ email chặt chẽ hơn, bao
|
||||
gồm việc kiểm tra các địa chỉ dùng một lần và xem nó có thực sự được giao tiếp hay
|
||||
không. Khi bỏ chọn, chỉ định dạng của email được xác minh."
|
||||
navbar: "Thanh điều hướng"
|
||||
shuffle: "Xáo trộn"
|
||||
account: "Tài khoản của bạn"
|
||||
move: "Di chuyển"
|
||||
_sensitiveMediaDetection:
|
||||
description: "Giảm nỗ lực kiểm duyệt máy chủ thông qua việc tự động nhận dạng media NSFW thông qua học máy. Điều này sẽ làm tăng một chút áp lực trên máy chủ."
|
||||
description: "Giảm nỗ lực kiểm duyệt máy chủ thông qua việc tự động nhận dạng media
|
||||
NSFW thông qua học máy. Điều này sẽ làm tăng một chút áp lực trên máy chủ."
|
||||
sensitivity: "Phát hiện nhạy cảm"
|
||||
sensitivityDescription: "Giảm độ nhạy sẽ dẫn đến ít phát hiện sai hơn (dương tính giả), tăng nó sẽ dẫn đến ít phát hiện sai hơn (âm tính giả)."
|
||||
sensitivityDescription: "Giảm độ nhạy sẽ dẫn đến ít phát hiện sai hơn (dương tính
|
||||
giả), tăng nó sẽ dẫn đến ít phát hiện sai hơn (âm tính giả)."
|
||||
setSensitiveFlagAutomatically: "Đánh dấu là NSFW"
|
||||
setSensitiveFlagAutomaticallyDescription: "Kết quả của phát hiện nội bộ sẽ được giữ lại ngay cả khi tùy chọn này bị tắt."
|
||||
setSensitiveFlagAutomaticallyDescription: "Kết quả của phát hiện nội bộ sẽ được
|
||||
giữ lại ngay cả khi tùy chọn này bị tắt."
|
||||
analyzeVideos: "Bật chuẩn đoán video"
|
||||
analyzeVideosDescription: "Phân tích video bên cạnh hình ảnh. Điều này sẽ làm tăng một chút áp lực trên máy chủ."
|
||||
analyzeVideosDescription: "Phân tích video bên cạnh hình ảnh. Điều này sẽ làm tăng
|
||||
một chút áp lực trên máy chủ."
|
||||
_emailUnavailable:
|
||||
used: "Địa chỉ email đã được sử dụng"
|
||||
format: "Địa chỉ email không hợp lệ"
|
||||
|
@ -912,11 +985,15 @@ _ffVisibility:
|
|||
_signup:
|
||||
almostThere: "Gần xong rồi"
|
||||
emailAddressInfo: "Hãy điền địa chỉ email của bạn. Nó sẽ không được công khai."
|
||||
emailSent: "Một email xác minh đã được gửi đến địa chỉ email ({email}) của bạn. Vui lòng nhấn vào liên kết trong đó để hoàn tất việc tạo tài khoản."
|
||||
emailSent: "Một email xác minh đã được gửi đến địa chỉ email ({email}) của bạn.
|
||||
Vui lòng nhấn vào liên kết trong đó để hoàn tất việc tạo tài khoản."
|
||||
_accountDelete:
|
||||
accountDelete: "Xóa tài khoản"
|
||||
mayTakeTime: "Vì xóa tài khoản là một quá trình tốn nhiều tài nguyên nên có thể mất một khoảng thời gian để hoàn thành, tùy thuộc vào lượng nội dung bạn đã tạo và số lượng tập tin bạn đã tải lên."
|
||||
sendEmail: "Sau khi hoàn tất việc xóa tài khoản, một email sẽ được gửi đến địa chỉ email đã đăng ký tài khoản này."
|
||||
mayTakeTime: "Vì xóa tài khoản là một quá trình tốn nhiều tài nguyên nên có thể
|
||||
mất một khoảng thời gian để hoàn thành, tùy thuộc vào lượng nội dung bạn đã tạo
|
||||
và số lượng tập tin bạn đã tải lên."
|
||||
sendEmail: "Sau khi hoàn tất việc xóa tài khoản, một email sẽ được gửi đến địa chỉ
|
||||
email đã đăng ký tài khoản này."
|
||||
requestAccountDelete: "Yêu cầu xóa tài khoản"
|
||||
started: "Đang bắt đầu xóa tài khoản."
|
||||
inProgress: "Đang xóa dần tài khoản."
|
||||
|
@ -924,9 +1001,12 @@ _ad:
|
|||
back: "Quay lại"
|
||||
reduceFrequencyOfThisAd: "Hiện ít lại"
|
||||
_forgotPassword:
|
||||
enterEmail: "Nhập địa chỉ email bạn đã sử dụng để đăng ký. Một liên kết mà bạn có thể đặt lại mật khẩu của mình sau đó sẽ được gửi đến nó."
|
||||
ifNoEmail: "Nếu bạn không sử dụng email lúc đăng ký, vui lòng liên hệ với quản trị viên."
|
||||
contactAdmin: "Máy chủ này không hỗ trợ sử dụng địa chỉ email, vui lòng liên hệ với quản trị viên để đặt lại mật khẩu của bạn."
|
||||
enterEmail: "Nhập địa chỉ email bạn đã sử dụng để đăng ký. Một liên kết mà bạn có
|
||||
thể đặt lại mật khẩu của mình sau đó sẽ được gửi đến nó."
|
||||
ifNoEmail: "Nếu bạn không sử dụng email lúc đăng ký, vui lòng liên hệ với quản trị
|
||||
viên."
|
||||
contactAdmin: "Máy chủ này không hỗ trợ sử dụng địa chỉ email, vui lòng liên hệ
|
||||
với quản trị viên để đặt lại mật khẩu của bạn."
|
||||
_gallery:
|
||||
my: "Kho Ảnh"
|
||||
liked: "Tút Đã Thích"
|
||||
|
@ -950,11 +1030,13 @@ _preferencesBackups:
|
|||
inputName: "Nhập tên bản sao lưu"
|
||||
cannotSave: "Không thể lưu"
|
||||
nameAlreadyExists: "Bản sao lưu \"{name}\" đã tồn tại. Xin nhập tên khác."
|
||||
applyConfirm: "Bạn có chắc muốn áp dụng bản sao lưu \"{name}\" cho thiết bị này? Thiết lập hiện tại sẽ bị ghi đè."
|
||||
applyConfirm: "Bạn có chắc muốn áp dụng bản sao lưu \"{name}\" cho thiết bị này?
|
||||
Thiết lập hiện tại sẽ bị ghi đè."
|
||||
saveConfirm: "Lưu bản sao lưu {name}?"
|
||||
deleteConfirm: "Xóa bản sao lưu {name}?"
|
||||
renameConfirm: "Đổi tên bản sao lưu \"{old}\" thành \"{new}\"?"
|
||||
noBackups: "Chưa có bản sao lưu. Bạn có thể sao lưu thiết lập trên máy chủ này bằng cách sử dụng \"Tạo sao lưu\"."
|
||||
noBackups: "Chưa có bản sao lưu. Bạn có thể sao lưu thiết lập trên máy chủ này bằng
|
||||
cách sử dụng \"Tạo sao lưu\"."
|
||||
createdAt: "Tạo vào: {time} {date}"
|
||||
updatedAt: "Cập nhật: {time} {date}"
|
||||
cannotLoad: "Tải thất bại"
|
||||
|
@ -972,15 +1054,22 @@ _aboutFirefish:
|
|||
source: "Mã nguồn"
|
||||
translation: "Dịch Firefish"
|
||||
donate: "Ủng hộ Firefish"
|
||||
morePatrons: "Chúng tôi cũng trân trọng sự hỗ trợ của nhiều người đóng góp khác không được liệt kê ở đây. Cảm ơn! 🥰"
|
||||
morePatrons: "Chúng tôi cũng trân trọng sự hỗ trợ của nhiều người đóng góp khác
|
||||
không được liệt kê ở đây. Cảm ơn! 🥰"
|
||||
patrons: "Người ủng hộ"
|
||||
patronsList: Liệt kê theo thứ tự, không theo số tiền ủng hộ. Hãy để tên bạn ở đây!
|
||||
donateTitle: Thích Firefish?
|
||||
pleaseDonateToFirefish: Hãy cân nhắc ủng hộ Firefish phát triển.
|
||||
donateHost: Ủng hộ {host}
|
||||
pleaseDonateToHost: Cũng như ủng hộ chi phí vận hành máy chủ {host} của bạn.
|
||||
_nsfw:
|
||||
respect: "Ẩn nội dung NSFW"
|
||||
ignore: "Hiện nội dung NSFW"
|
||||
force: "Ẩn mọi media"
|
||||
_mfm:
|
||||
cheatSheet: "MFM Cheatsheet"
|
||||
intro: "MFM là ngôn ngữ phát triển độc quyền của Firefish có thể được sử dụng ở nhiều nơi. Tại đây bạn có thể xem danh sách tất cả các cú pháp MFM có sẵn."
|
||||
intro: "MFM là ngôn ngữ phát triển độc quyền của Firefish có thể được sử dụng ở
|
||||
nhiều nơi. Tại đây bạn có thể xem danh sách tất cả các cú pháp MFM có sẵn."
|
||||
dummy: "Firefish mở rộng thế giới Fediverse"
|
||||
mention: "Nhắc đến"
|
||||
mentionDescription: "Bạn có thể nhắc đến ai đó bằng cách sử dụng @tên người dùng."
|
||||
|
@ -999,11 +1088,13 @@ _mfm:
|
|||
inlineCode: "Mã (Trong dòng)"
|
||||
inlineCodeDescription: "Hiển thị tô sáng cú pháp trong dòng cho mã (chương trình)."
|
||||
blockCode: "Mã (Khối)"
|
||||
blockCodeDescription: "Hiển thị tô sáng cú pháp cho mã nhiều dòng (chương trình) trong một khối."
|
||||
blockCodeDescription: "Hiển thị tô sáng cú pháp cho mã nhiều dòng (chương trình)
|
||||
trong một khối."
|
||||
inlineMath: "Toán học (Trong dòng)"
|
||||
inlineMathDescription: "Hiển thị công thức toán (KaTeX) trong dòng"
|
||||
blockMath: "Toán học (Khối)"
|
||||
blockMathDescription: "Hiển thị công thức toán học nhiều dòng (KaTeX) trong một khối"
|
||||
blockMathDescription: "Hiển thị công thức toán học nhiều dòng (KaTeX) trong một
|
||||
khối"
|
||||
quote: "Trích dẫn"
|
||||
quoteDescription: "Hiển thị nội dung dạng lời trích dạng."
|
||||
emoji: "Tùy chỉnh emoji"
|
||||
|
@ -1044,6 +1135,9 @@ _mfm:
|
|||
rotateDescription: "Xoay nội dung theo một góc cụ thể."
|
||||
plain: "Đơn giản"
|
||||
plainDescription: "Vô hiệu hóa mọi hiệu ứng MFM chứa trong hiệu ứng MFM này."
|
||||
stop: Dừng CĐN
|
||||
play: Phát CĐN
|
||||
warn: CĐN có thể gây đau mắt hoặc chóng mặt
|
||||
_instanceTicker:
|
||||
none: "Không hiển thị"
|
||||
remote: "Hiện cho người dùng từ máy chủ khác"
|
||||
|
@ -1069,15 +1163,20 @@ _menuDisplay:
|
|||
hide: "Ẩn"
|
||||
_wordMute:
|
||||
muteWords: "Ẩn từ ngữ"
|
||||
muteWordsDescription: "Separate with spaces for an AND condition or with line breaks for an OR condition."
|
||||
muteWordsDescription2: "Bao quanh các từ khóa bằng dấu gạch chéo để sử dụng cụm từ thông dụng."
|
||||
muteWordsDescription: "Separate with spaces for an AND condition or with line breaks
|
||||
for an OR condition."
|
||||
muteWordsDescription2: "Bao quanh các từ khóa bằng dấu gạch chéo để sử dụng cụm
|
||||
từ thông dụng."
|
||||
softDescription: "Ẩn các tút phù hợp điều kiện đã đặt khỏi bảng tin."
|
||||
hardDescription: "Ngăn các tút đáp ứng các điều kiện đã đặt xuất hiện trên bảng tin. Lưu ý, những tút này sẽ không được thêm vào bảng tin ngay cả khi các điều kiện được thay đổi."
|
||||
hardDescription: "Ngăn các tút đáp ứng các điều kiện đã đặt xuất hiện trên bảng
|
||||
tin. Lưu ý, những tút này sẽ không được thêm vào bảng tin ngay cả khi các điều
|
||||
kiện được thay đổi."
|
||||
soft: "Yếu"
|
||||
hard: "Mạnh"
|
||||
mutedNotes: "Những tút đã ẩn"
|
||||
_instanceMute:
|
||||
instanceMuteDescription: "Thao tác này sẽ ẩn mọi tút/lượt đăng lại từ các máy chủ được liệt kê, bao gồm cả những tút dạng trả lời từ máy chủ bị ẩn."
|
||||
instanceMuteDescription: "Thao tác này sẽ ẩn mọi tút/lượt đăng lại từ các máy chủ
|
||||
được liệt kê, bao gồm cả những tút dạng trả lời từ máy chủ bị ẩn."
|
||||
instanceMuteDescription2: "Tách bằng cách xuống dòng"
|
||||
title: "Ẩn tút từ những máy chủ đã liệt kê."
|
||||
heading: "Danh sách những máy chủ bị ẩn"
|
||||
|
@ -1109,7 +1208,8 @@ _theme:
|
|||
darken: "Độ tối"
|
||||
lighten: "Độ sáng"
|
||||
inputConstantName: "Nhập tên cho hằng số này"
|
||||
importInfo: "Nếu bạn nhập mã theme ở đây, bạn có thể nhập mã đó vào trình chỉnh sửa theme"
|
||||
importInfo: "Nếu bạn nhập mã theme ở đây, bạn có thể nhập mã đó vào trình chỉnh
|
||||
sửa theme"
|
||||
deleteConstantConfirm: "Bạn có chắc muốn xóa hằng số {const} không?"
|
||||
keys:
|
||||
accent: "Màu phụ"
|
||||
|
@ -1168,7 +1268,7 @@ _ago:
|
|||
justNow: "Vừa xong"
|
||||
secondsAgo: "{n}s trước"
|
||||
minutesAgo: "{n} phút trước"
|
||||
hoursAgo: "{n} giờ trước"
|
||||
hoursAgo: "{n} giờ"
|
||||
daysAgo: "{n} ngày trước"
|
||||
weeksAgo: "{n} tuần trước"
|
||||
monthsAgo: "{n} tháng trước"
|
||||
|
@ -1183,32 +1283,47 @@ _tutorial:
|
|||
step1_1: "Welcome!"
|
||||
step1_2: "Let's get you set up. You'll be up and running in no time!"
|
||||
step2_1: "First, please fill out your profile."
|
||||
step2_2: "Providing some information about who you are will make it easier for others to tell if they want to see your notes or follow you."
|
||||
step2_2: "Providing some information about who you are will make it easier for others
|
||||
to tell if they want to see your notes or follow you."
|
||||
step3_1: "Now time to follow some people!"
|
||||
step3_2: "Your home and social timelines are based off of who you follow, so try following a couple accounts to get started.\nClick the plus circle on the top right of a profile to follow them."
|
||||
step3_2: "Your home and social timelines are based off of who you follow, so try
|
||||
following a couple accounts to get started.\nClick the plus circle on the top
|
||||
right of a profile to follow them."
|
||||
step4_1: "Let's get you out there."
|
||||
step4_2: "For your first post, some people like to made a {introduction} post or a simple \"Hello world!\""
|
||||
step4_2: "For your first post, some people like to made a {introduction} post or
|
||||
a simple \"Hello world!\""
|
||||
step5_1: "Timelines, timelines everywhere!"
|
||||
step5_2: "Your instance has {timelines} different timelines enabled."
|
||||
step5_3: "The Home {icon} timeline is where you can see posts from your followers."
|
||||
step5_4: "The Local {icon} timeline is where you can see posts from everyone else on this instance."
|
||||
step5_5: "The Recommended {icon} timeline is where you can see posts from instances the admins recommend."
|
||||
step5_6: "The Social {icon} timeline is where you can see posts from friends of your followers."
|
||||
step5_7: "The Global {icon} timeline is where you can see posts from every other connected instance."
|
||||
step5_4: "The Local {icon} timeline is where you can see posts from everyone else
|
||||
on this instance."
|
||||
step5_5: "The Recommended {icon} timeline is where you can see posts from instances
|
||||
the admins recommend."
|
||||
step5_6: "The Social {icon} timeline is where you can see posts from friends of
|
||||
your followers."
|
||||
step5_7: "The Global {icon} timeline is where you can see posts from every other
|
||||
connected instance."
|
||||
step6_1: "So, what is this place?"
|
||||
step6_2: "Well, you didn't just join Firefish. You joined a portal to the Fediverse, an interconnected network of thousands of servers, called \"instances\"."
|
||||
step6_3: "Each server works in different ways, and not all servers run Firefish. This one does though! It's a bit complicated, but you'll get the hang of it in no time."
|
||||
step6_4: "Now go, explore, and have fun!"
|
||||
step6_2: "Well, you didn't just join Firefish. You joined a portal to the Fediverse,
|
||||
an interconnected network of thousands of servers, called \"instances\"."
|
||||
step6_3: "Each server works in different ways, and not all servers run Firefish.
|
||||
This one does though! It's a bit complicated, but you'll get the hang of it in
|
||||
no time."
|
||||
step6_4: "Bây giờ bắt đầu khám phá, và vui thôi!"
|
||||
_2fa:
|
||||
alreadyRegistered: "Bạn đã đăng ký thiết bị xác minh 2 bước."
|
||||
registerTOTP: "Đăng ký một thiết bị"
|
||||
registerSecurityKey: "Đăng ký một mã bảo vệ"
|
||||
step1: "Trước tiên, hãy cài đặt một ứng dụng xác minh (chẳng hạn như {a} hoặc {b}) trên thiết bị của bạn."
|
||||
step1: "Trước tiên, hãy cài đặt một ứng dụng xác minh (chẳng hạn như {a} hoặc {b})
|
||||
trên thiết bị của bạn."
|
||||
step2: "Sau đó, quét mã QR hiển thị trên màn hình này."
|
||||
step2Url: "Bạn cũng có thể nhập URL này nếu sử dụng một chương trình máy tính:"
|
||||
step3: "Nhập mã token do ứng dụng của bạn cung cấp để hoàn tất thiết lập."
|
||||
step4: "Kể từ bây giờ, những lần đăng nhập trong tương lai sẽ yêu cầu mã token đăng nhập đó."
|
||||
securityKeyInfo: "Bên cạnh xác minh bằng vân tay hoặc mã PIN, bạn cũng có thể thiết lập xác minh thông qua khóa bảo mật phần cứng hỗ trợ FIDO2 để bảo mật hơn nữa cho tài khoản của mình."
|
||||
step4: "Kể từ bây giờ, những lần đăng nhập trong tương lai sẽ yêu cầu mã token đăng
|
||||
nhập đó."
|
||||
securityKeyInfo: "Bên cạnh xác minh bằng vân tay hoặc mã PIN, bạn cũng có thể thiết
|
||||
lập xác minh thông qua khóa bảo mật phần cứng hỗ trợ FIDO2 để bảo mật hơn nữa
|
||||
cho tài khoản của mình."
|
||||
_permissions:
|
||||
"read:account": "Xem thông tin tài khoản của bạn"
|
||||
"write:account": "Sửa thông tin tài khoản của bạn"
|
||||
|
@ -1244,7 +1359,8 @@ _permissions:
|
|||
"write:gallery-likes": "Sửa danh sách các tút đã thích trong thư viện của tôi"
|
||||
_auth:
|
||||
shareAccess: "Bạn có muốn cho phép \"{name}\" truy cập vào tài khoản này không?"
|
||||
shareAccessAsk: "Bạn có chắc muốn cho phép ứng dụng này truy cập vào tài khoản của mình không?"
|
||||
shareAccessAsk: "Bạn có chắc muốn cho phép ứng dụng này truy cập vào tài khoản của
|
||||
mình không?"
|
||||
permissionAsk: "Ứng dụng này yêu cầu các quyền sau"
|
||||
pleaseGoBack: "Vui lòng quay lại ứng dụng"
|
||||
callback: "Quay lại ứng dụng"
|
||||
|
@ -1304,7 +1420,7 @@ _poll:
|
|||
deadlineTime: "giờ"
|
||||
duration: "Thời hạn"
|
||||
votesCount: "{n} bình chọn"
|
||||
totalVotes: "{n} tổng bình chọn"
|
||||
totalVotes: "{n} lượt bình chọn"
|
||||
vote: "Bình chọn"
|
||||
showResult: "Xem kết quả"
|
||||
voted: "Đã bình chọn"
|
||||
|
@ -1342,7 +1458,9 @@ _profile:
|
|||
youCanIncludeHashtags: "Bạn có thể dùng hashtag trong tiểu sử."
|
||||
metadata: "Thông tin bổ sung"
|
||||
metadataEdit: "Sửa thông tin bổ sung"
|
||||
metadataDescription: "Sử dụng phần này, bạn có thể hiển thị các mục thông tin bổ sung trong hồ sơ của mình. Bạn có thể thêm thẻ {a} hoặc thẻ {l} với {rel} để xác minh liên kết trên tiểu sử của mình!"
|
||||
metadataDescription: "Sử dụng phần này, bạn có thể hiển thị các mục thông tin bổ
|
||||
sung trong hồ sơ của mình. Bạn có thể thêm thẻ {a} hoặc thẻ {l} với {rel} để xác
|
||||
minh liên kết trên tiểu sử của mình!"
|
||||
metadataLabel: "Nhãn"
|
||||
metadataContent: "Nội dung"
|
||||
changeAvatar: "Đổi ảnh đại diện"
|
||||
|
@ -1616,7 +1734,8 @@ _pages:
|
|||
_dailyRannum:
|
||||
arg1: "Giá trị tối thiểu"
|
||||
arg2: "Giá trị tối đa"
|
||||
dailyRandomPick: "Chọn ngẫu nhiên từ một danh sách (Đổi mỗi người một lần mỗi ngày)"
|
||||
dailyRandomPick: "Chọn ngẫu nhiên từ một danh sách (Đổi mỗi người một lần mỗi
|
||||
ngày)"
|
||||
_dailyRandomPick:
|
||||
arg1: "Danh sách"
|
||||
seedRandom: "Ngẫu nhiên (với seed)"
|
||||
|
@ -1663,7 +1782,8 @@ _pages:
|
|||
_for:
|
||||
arg1: "Số lần lặp lại"
|
||||
arg2: "Hành động"
|
||||
typeError: "Chỗ {slot} chấp nhận các giá trị thuộc loại \"{expect}\", nhưng giá trị được cung cấp thuộc loại \"{actual}\"!"
|
||||
typeError: "Chỗ {slot} chấp nhận các giá trị thuộc loại \"{expect}\", nhưng giá
|
||||
trị được cung cấp thuộc loại \"{actual}\"!"
|
||||
thereIsEmptySlot: "Chỗ {slot} đang trống!"
|
||||
types:
|
||||
string: "Văn bản"
|
||||
|
@ -1727,7 +1847,8 @@ _deck:
|
|||
newProfile: "Hồ sơ mới"
|
||||
deleteProfile: "Xóa hồ sơ"
|
||||
introduction: "Kết hợp các cột để tạo giao diện của riêng bạn!"
|
||||
introduction2: "Bạn có thể thêm cột bất kỳ lúc nào bằng cách nhấn + ở bên phải màn hình."
|
||||
introduction2: "Bạn có thể thêm cột bất kỳ lúc nào bằng cách nhấn + ở bên phải màn
|
||||
hình."
|
||||
widgetsIntroduction: "Chọn \"Sửa widget\" trong menu cột và thêm một widget."
|
||||
_columns:
|
||||
main: "Chính"
|
||||
|
@ -1738,3 +1859,11 @@ _deck:
|
|||
list: "Danh sách"
|
||||
mentions: "Lượt nhắc"
|
||||
direct: "Nhắn riêng"
|
||||
renoteMute: Ẩn lượt chia sẻ
|
||||
renoteUnmute: Bỏ ẩn lượt chia sẻ
|
||||
searchPlaceholder: Lướt Firefish
|
||||
edited: Đã sửa {date} {time}
|
||||
findOtherInstance: Tìm máy chủ khác
|
||||
noThankYou: Từ chối
|
||||
_filters:
|
||||
withFile: Có file
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
_lang_: "简体中文"
|
||||
headlineMisskey: "一个开源、去中心化的社交媒体平台,永远免费!🚀"
|
||||
introMisskey: "欢迎! Firefish 是一个开源、去中心化的社交媒体平台,永久免费!🚀"
|
||||
headlineFirefish: "一个开源、去中心化的社交媒体平台,永远免费!🚀"
|
||||
introFirefish: "欢迎! Firefish 是一个开源、去中心化的社交媒体平台,永久免费!🚀"
|
||||
monthAndDay: "{month} 月 {day} 日"
|
||||
search: "搜索"
|
||||
notifications: "通知"
|
||||
|
@ -521,7 +521,7 @@ recentUsed: "最近使用"
|
|||
install: "安装"
|
||||
uninstall: "卸载"
|
||||
installedApps: "已授权的应用"
|
||||
nothing: "没有"
|
||||
nothing: "暂无更多内容"
|
||||
installedDate: "授权日期"
|
||||
lastUsedDate: "最近使用时间"
|
||||
state: "状态"
|
||||
|
@ -641,7 +641,7 @@ openInNewTab: "在新标签页中打开"
|
|||
openInSideView: "在侧边栏中打开"
|
||||
defaultNavigationBehaviour: "默认导航"
|
||||
editTheseSettingsMayBreakAccount: "编辑这些设置可能会损坏您的账号。"
|
||||
instanceTicker: "帖子所在的服务器信息"
|
||||
instanceTicker: "帖子的实例信息"
|
||||
waitingFor: "等待 {x}"
|
||||
random: "随机"
|
||||
system: "系统"
|
||||
|
@ -825,7 +825,7 @@ unmuteThread: "取消静音帖子串"
|
|||
ffVisibility: "关注/关注者 可见性"
|
||||
ffVisibilityDescription: "您可以设置谁可以看到您的关注/关注者信息。"
|
||||
continueThread: "查看更多帖子"
|
||||
deleteAccountConfirm: "将要删除账号。是否继续?"
|
||||
deleteAccountConfirm: "将不可逆的删除账号,是否继续?"
|
||||
incorrectPassword: "密码错误。"
|
||||
voteConfirm: "确定投给 “{choice}” ?"
|
||||
hide: "隐藏"
|
||||
|
@ -866,7 +866,7 @@ check: "检查"
|
|||
driveCapOverrideLabel: "修改此用户的网盘容量"
|
||||
driveCapOverrideCaption: "输入 0 或以下的值将容量重置为默认值。"
|
||||
requireAdminForView: "需要使用管理员账号登录才能查看。"
|
||||
isSystemAccount: "该账号由系统自动创建和管理。请不要修改、编辑、删除或以其它方式篡改这个账号,否则可能会破坏您的服务器。"
|
||||
isSystemAccount: "该账号由系统自动创建。请不要修改、编辑、删除或以其它方式篡改这个账号,否则可能会破坏您的服务器。"
|
||||
typeToConfirm: "输入 {x} 以确认操作"
|
||||
deleteAccount: "删除账号"
|
||||
document: "文档"
|
||||
|
@ -988,9 +988,9 @@ _aboutFirefish:
|
|||
morePatrons: "还有很多其它的人也在支持我们,非常感谢🥰"
|
||||
patrons: "Firefish 赞助者"
|
||||
patronsList: 按时间顺序而不是捐赠金额排列。通过上面的链接捐款,让您的名字出现在这里!
|
||||
sponsors: Calckey 赞助者们
|
||||
donateTitle: 喜欢 Calckey 吗?
|
||||
pleaseDonateToCalckey: 请考虑赞助 Calckey 以支持其开发。
|
||||
sponsors: Firefish 赞助者们
|
||||
donateTitle: 喜欢 Firefish 吗?
|
||||
pleaseDonateToFirefish: 请考虑赞助 Firefish 以支持其开发。
|
||||
pleaseDonateToHost: 也请考虑赞助您的主服务器 {host},以帮助支持其运营成本。
|
||||
donateHost: 赞助 {host}
|
||||
_nsfw:
|
||||
|
@ -1231,10 +1231,10 @@ _tutorial:
|
|||
step5_1: "时间线,无处不在的时间线!"
|
||||
step5_2: "您的服务器已启用 {timelines} 种不同的时间线。"
|
||||
step5_3: "主页 {icon} 时间线是您可以看到您关注账号的帖子的时间线。"
|
||||
step5_4: "本地 {icon} 时间线是您可以看到此服务器上其它用户的帖子的时间线。"
|
||||
step5_5: "社交 {icon} 时间线是主页和本地时间线的结合。"
|
||||
step5_6: "推荐 {icon} 时间线是您可以看到管理员推荐服务器的帖子的时间线。"
|
||||
step5_7: "全球 {icon} 时间线是您可以看到来自其它所有互联服务器的帖子的时间线。"
|
||||
step5_4: "本地{icon}时间线是您可以看到此服务器上其它用户的帖子的时间线。"
|
||||
step5_5: "社交{icon}时间线是主页和本地时间线的结合。"
|
||||
step5_6: "推荐{icon}时间线是您可以看到管理员推荐服务器的帖子的时间线。"
|
||||
step5_7: "全球{icon}时间线是您可以看到来自其它所有互联服务器的帖子的时间线。"
|
||||
step6_1: "那么,这里是什么地方?"
|
||||
step6_2: "好吧,您不只是加入 Firefish。您已经加入了 Fediverse 的一个门户,这是一个由成千上万台服务器组成的互联网络。"
|
||||
step6_3: "每个服务器的工作方式不同,并不是所有的服务器都运行 Firefish。但这个服务器是的! 这有点复杂,但您很快就会明白的。"
|
||||
|
@ -1965,3 +1965,4 @@ remindMeLater: 稍后再说
|
|||
removeQuote: 移除引用
|
||||
removeRecipient: 移除接收者
|
||||
removeMember: 移除成员
|
||||
origin: 起源
|
||||
|
|
|
@ -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: 特大
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
{
|
||||
"name": "firefish",
|
||||
"version": "1.0.3",
|
||||
"version": "1.0.4-dev10",
|
||||
"codename": "aqua",
|
||||
"repository": {
|
||||
"type": "git",
|
||||
|
@ -22,6 +22,8 @@
|
|||
"dev": "pnpm node ./scripts/dev.js",
|
||||
"dev:staging": "NODE_OPTIONS=--max_old_space_size=3072 NODE_ENV=development pnpm run build && pnpm run start",
|
||||
"lint": "pnpm -r --parallel run lint",
|
||||
"debug": "pnpm run build:debug && pnpm run start",
|
||||
"build:debug": "pnpm -r --parallel run build:debug && pnpm run gulp",
|
||||
"cy:open": "cypress open --browser --e2e --config-file=cypress.config.ts",
|
||||
"cy:run": "cypress run",
|
||||
"e2e": "start-server-and-test start:test http://localhost:61812 cy:run",
|
||||
|
|
|
@ -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.
|
||||
|
|
|
@ -42,13 +42,15 @@ async fn main() {
|
|||
None => "redis",
|
||||
Some(_) => "rediss",
|
||||
};
|
||||
let redis_uri_userpass = match redis_conf.user {
|
||||
None => "".to_string(),
|
||||
Some(user) => format!("{}:{}@", user, encode(&redis_conf.pass.unwrap_or_default())),
|
||||
};
|
||||
let redis_user = redis_conf.user.unwrap_or("default".to_string());
|
||||
let redis_uri_userpass = format!(
|
||||
"{}:{}",
|
||||
redis_user,
|
||||
encode(&redis_conf.pass.unwrap_or_default())
|
||||
);
|
||||
let redis_uri_hostport = format!("{}:{}", redis_conf.host, redis_conf.port);
|
||||
let redis_uri = format!(
|
||||
"{}://{}{}/{}",
|
||||
"{}://{}@{}/{}",
|
||||
redis_proto, redis_uri_userpass, redis_uri_hostport, redis_conf.db
|
||||
);
|
||||
env::set_var(CACHE_URL_ENV, redis_uri);
|
||||
|
|
|
@ -36,8 +36,8 @@
|
|||
"artifacts": "napi artifacts",
|
||||
"build": "pnpm run build:napi && pnpm run build:migration",
|
||||
"build:napi": "napi build --features napi --platform --release ./built/",
|
||||
"build:migration": "cargo build --locked --release --manifest-path ./migration/Cargo.toml && cp ./target/release/migration ./built/migration",
|
||||
"build:debug": "napi build --platform ./built/ && cargo build --manifest-path ./migration/Cargo.toml",
|
||||
"build:migration": "cargo build --locked --release --manifest-path ./migration/Cargo.toml && cp -v ./target/release/migration ./built/migration",
|
||||
"build:debug": "napi build --features napi --platform ./built/ && cargo build --locked --manifest-path ./migration/Cargo.toml && cp -v ./target/debug/migration ./built/migration",
|
||||
"prepublishOnly": "napi prepublish -t npm",
|
||||
"test": "pnpm run cargo:test && pnpm run build:napi && ava",
|
||||
"universal": "napi universal",
|
||||
|
|
|
@ -14,6 +14,7 @@
|
|||
"revertmigration:cargo": "./native-utils/built/migration down",
|
||||
"check:connect": "node ./check_connect.js",
|
||||
"build": "pnpm swc src -d built -D",
|
||||
"build:debug": "pnpm swc src -d built -s -D",
|
||||
"watch": "pnpm swc src -d built -D -w",
|
||||
"lint": "pnpm rome check --apply *",
|
||||
"mocha": "cross-env NODE_ENV=test TS_NODE_FILES=true TS_NODE_TRANSPILE_ONLY=true TS_NODE_PROJECT=\"./test/tsconfig.json\" mocha",
|
||||
|
|
|
@ -31,13 +31,41 @@ function greet() {
|
|||
if (!envOption.quiet) {
|
||||
//#region Firefish logo
|
||||
const v = `v${meta.version}`;
|
||||
console.log(themeColor(" ▄▄▄▄▄▄▄ ▄▄▄ ▄▄▄▄▄▄ ▄▄▄▄▄▄▄ ▄▄▄▄▄▄▄ ▄▄▄ ▄▄▄▄▄▄▄ ▄▄ ▄▄ ◯ "));
|
||||
console.log(themeColor("█ █ █ ▄ █ █ █ █ █ █ █ █ █ ○ ▄ ▄"));
|
||||
console.log(themeColor("█ ▄▄▄█ █ █ █ █ █ ▄▄▄█ ▄▄▄█ █ ▄▄▄▄▄█ █▄█ █ ⚬ █▄▄ █▄▄ "));
|
||||
console.log(themeColor("█ █▄▄▄█ █ █▄▄█▄█ █▄▄▄█ █▄▄▄█ █ █▄▄▄▄▄█ █ ▄▄▄▄▄▄ ▄"));
|
||||
console.log(themeColor("█ ▄▄▄█ █ ▄▄ █ ▄▄▄█ ▄▄▄█ █▄▄▄▄▄ █ ▄ █ █ █ █▄▄"));
|
||||
console.log(themeColor("█ █ █ █ █ █ █ █▄▄▄█ █ █ █▄▄▄▄▄█ █ █ █ █ █ ● ● █"));
|
||||
console.log(themeColor("█▄▄▄█ █▄▄▄█▄▄▄█ █▄█▄▄▄▄▄▄▄█▄▄▄█ █▄▄▄█▄▄▄▄▄▄▄█▄▄█ █▄▄█ ▀▄▄▄▄▄▄▀"));
|
||||
console.log(
|
||||
themeColor(
|
||||
" ▄▄▄▄▄▄▄ ▄▄▄ ▄▄▄▄▄▄ ▄▄▄▄▄▄▄ ▄▄▄▄▄▄▄ ▄▄▄ ▄▄▄▄▄▄▄ ▄▄ ▄▄ ◯ ",
|
||||
),
|
||||
);
|
||||
console.log(
|
||||
themeColor(
|
||||
"█ █ █ ▄ █ █ █ █ █ █ █ █ █ ○ ▄ ▄",
|
||||
),
|
||||
);
|
||||
console.log(
|
||||
themeColor(
|
||||
"█ ▄▄▄█ █ █ █ █ █ ▄▄▄█ ▄▄▄█ █ ▄▄▄▄▄█ █▄█ █ ⚬ █▄▄ █▄▄ ",
|
||||
),
|
||||
);
|
||||
console.log(
|
||||
themeColor(
|
||||
"█ █▄▄▄█ █ █▄▄█▄█ █▄▄▄█ █▄▄▄█ █ █▄▄▄▄▄█ █ ▄▄▄▄▄▄ ▄",
|
||||
),
|
||||
);
|
||||
console.log(
|
||||
themeColor(
|
||||
"█ ▄▄▄█ █ ▄▄ █ ▄▄▄█ ▄▄▄█ █▄▄▄▄▄ █ ▄ █ █ █ █▄▄",
|
||||
),
|
||||
);
|
||||
console.log(
|
||||
themeColor(
|
||||
"█ █ █ █ █ █ █ █▄▄▄█ █ █ █▄▄▄▄▄█ █ █ █ █ █ ● ● █",
|
||||
),
|
||||
);
|
||||
console.log(
|
||||
themeColor(
|
||||
"█▄▄▄█ █▄▄▄█▄▄▄█ █▄█▄▄▄▄▄▄▄█▄▄▄█ █▄▄▄█▄▄▄▄▄▄▄█▄▄█ █▄▄█ ▀▄▄▄▄▄▄▀",
|
||||
),
|
||||
);
|
||||
//#endregion
|
||||
|
||||
console.log(
|
||||
|
@ -78,7 +106,11 @@ export async function masterMain() {
|
|||
config = loadConfigBoot();
|
||||
await connectDb();
|
||||
} catch (e) {
|
||||
bootLogger.error("Fatal error occurred during initialization", null, true);
|
||||
bootLogger.error(
|
||||
`Fatal error occurred during initialization: ${e}`,
|
||||
null,
|
||||
true,
|
||||
);
|
||||
process.exit(1);
|
||||
}
|
||||
|
||||
|
|
|
@ -41,6 +41,7 @@ export default function load() {
|
|||
config.url = url.origin;
|
||||
|
||||
config.port = config.port || parseInt(process.env.PORT || "", 10);
|
||||
config.bind = config.bind || process.env.BIND;
|
||||
|
||||
mixin.version = meta.version;
|
||||
mixin.host = url.host;
|
||||
|
|
|
@ -6,6 +6,7 @@ export type Source = {
|
|||
feedback_url?: string;
|
||||
url: string;
|
||||
port: number;
|
||||
bind?: string;
|
||||
disableHsts?: boolean;
|
||||
db: {
|
||||
host: string;
|
||||
|
|
|
@ -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)),
|
||||
|
|
|
@ -121,6 +121,19 @@ if (hasConfig) {
|
|||
),
|
||||
);
|
||||
|
||||
posts
|
||||
.updateRankingRules([
|
||||
"sort",
|
||||
"words",
|
||||
"typo",
|
||||
"proximity",
|
||||
"attribute",
|
||||
"exactness",
|
||||
])
|
||||
.catch((e) => {
|
||||
logger.error("Failed to set ranking rules, sorting won't work properly.");
|
||||
});
|
||||
|
||||
logger.info("Connected to MeiliSearch");
|
||||
}
|
||||
|
||||
|
@ -160,6 +173,7 @@ export default hasConfig
|
|||
limit: number,
|
||||
offset: number,
|
||||
userCtx: ILocalUser | null,
|
||||
overrideSort: string | null,
|
||||
) => {
|
||||
/// Advanced search syntax
|
||||
/// from:user => filter by user + optional domain
|
||||
|
@ -170,8 +184,10 @@ export default hasConfig
|
|||
/// "text" => get posts with exact text between quotes
|
||||
/// filter:following => show results only from users you follow
|
||||
/// filter:followers => show results only from followers
|
||||
/// order:desc/asc => order results ascending or descending
|
||||
|
||||
const constructedFilters: string[] = [];
|
||||
let sortRules: string[] = [];
|
||||
|
||||
const splitSearch = query.split(" ");
|
||||
|
||||
|
@ -195,9 +211,9 @@ export default hasConfig
|
|||
|
||||
// Determine if we got a webfinger address or a single username
|
||||
if (user.split("@").length > 1) {
|
||||
let splitUser = user.split("@");
|
||||
const splitUser = user.split("@");
|
||||
|
||||
let domain = splitUser.pop();
|
||||
const domain = splitUser.pop();
|
||||
user = splitUser.join("@");
|
||||
|
||||
constructedFilters.push(
|
||||
|
@ -215,7 +231,7 @@ export default hasConfig
|
|||
} else if (term.startsWith("after:")) {
|
||||
const timestamp = term.slice(6);
|
||||
|
||||
let unix = timestampToUnix(timestamp);
|
||||
const unix = timestampToUnix(timestamp);
|
||||
|
||||
if (unix !== 0) constructedFilters.push(`createdAt > ${unix}`);
|
||||
|
||||
|
@ -223,7 +239,7 @@ export default hasConfig
|
|||
} else if (term.startsWith("before:")) {
|
||||
const timestamp = term.slice(7);
|
||||
|
||||
let unix = timestampToUnix(timestamp);
|
||||
const unix = timestampToUnix(timestamp);
|
||||
if (unix !== 0) constructedFilters.push(`createdAt < ${unix}`);
|
||||
|
||||
return null;
|
||||
|
@ -278,6 +294,14 @@ export default hasConfig
|
|||
);
|
||||
}
|
||||
|
||||
return null;
|
||||
} else if (term.startsWith("order:desc")) {
|
||||
sortRules.push("createdAt:desc");
|
||||
|
||||
return null;
|
||||
} else if (term.startsWith("order:asc")) {
|
||||
sortRules.push("createdAt:asc");
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
|
@ -286,14 +310,27 @@ export default hasConfig
|
|||
)
|
||||
).filter((term) => term !== null);
|
||||
|
||||
const sortRules = [];
|
||||
|
||||
// An empty search term with defined filters means we have a placeholder search => https://www.meilisearch.com/docs/reference/api/search#placeholder-search
|
||||
// These have to be ordered manually, otherwise the *oldest* posts are returned first, which we don't want
|
||||
if (filteredSearchTerms.length === 0 && constructedFilters.length > 0) {
|
||||
// If the user has defined a sort rule, don't mess with it
|
||||
if (
|
||||
filteredSearchTerms.length === 0 &&
|
||||
constructedFilters.length > 0 &&
|
||||
sortRules.length === 0
|
||||
) {
|
||||
sortRules.push("createdAt:desc");
|
||||
}
|
||||
|
||||
// More than one sorting rule doesn't make sense. We only keep the first one, otherwise weird stuff may happen.
|
||||
if (sortRules.length > 1) {
|
||||
sortRules = [sortRules[0]];
|
||||
}
|
||||
|
||||
// An override sort takes precedence, user sorting is ignored here
|
||||
if (overrideSort) {
|
||||
sortRules = [overrideSort];
|
||||
}
|
||||
|
||||
logger.info(`Searching for ${filteredSearchTerms.join(" ")}`);
|
||||
logger.info(`Limit: ${limit}`);
|
||||
logger.info(`Offset: ${offset}`);
|
||||
|
|
|
@ -156,7 +156,7 @@ export function toHtml(
|
|||
|
||||
search(node) {
|
||||
const a = doc.createElement("a");
|
||||
a.href = `https://search.annoyingorange.xyz/search?q=${node.props.query}`;
|
||||
a.href = `/search/${node.props.query}`;
|
||||
a.textContent = node.props.content;
|
||||
return a;
|
||||
},
|
||||
|
|
|
@ -1,16 +1,18 @@
|
|||
export type Post = {
|
||||
text: string | null;
|
||||
text: string | undefined;
|
||||
cw: string | null;
|
||||
localOnly: boolean;
|
||||
createdAt: Date;
|
||||
visibility: string;
|
||||
};
|
||||
|
||||
export function parse(acct: any): Post {
|
||||
return {
|
||||
text: acct.text,
|
||||
text: acct.text || undefined,
|
||||
cw: acct.cw,
|
||||
localOnly: acct.localOnly,
|
||||
createdAt: new Date(acct.createdAt),
|
||||
visibility: "hidden" + (acct.visibility || ""),
|
||||
};
|
||||
}
|
||||
|
||||
|
|
|
@ -28,6 +28,7 @@ import {
|
|||
backgroundQueue,
|
||||
} from "./queues.js";
|
||||
import type { ThinUser } from "./types.js";
|
||||
import { Note } from "@/models/entities/note.js";
|
||||
|
||||
function renderError(e: Error): any {
|
||||
return {
|
||||
|
@ -358,6 +359,7 @@ export function createImportCkPostJob(
|
|||
user: ThinUser,
|
||||
post: any,
|
||||
signatureCheck: boolean,
|
||||
parent: Note | null = null,
|
||||
) {
|
||||
return dbQueue.add(
|
||||
"importCkPost",
|
||||
|
@ -365,6 +367,7 @@ export function createImportCkPostJob(
|
|||
user: user,
|
||||
post: post,
|
||||
signatureCheck: signatureCheck,
|
||||
parent: parent,
|
||||
},
|
||||
{
|
||||
removeOnComplete: true,
|
||||
|
|
|
@ -3,7 +3,13 @@ import create from "@/services/note/create.js";
|
|||
import { Users } from "@/models/index.js";
|
||||
import type { DbUserImportMastoPostJobData } from "@/queue/types.js";
|
||||
import { queueLogger } from "../../logger.js";
|
||||
import { uploadFromUrl } from "@/services/drive/upload-from-url.js";
|
||||
import type { DriveFile } from "@/models/entities/drive-file.js";
|
||||
import type Bull from "bull";
|
||||
import { createImportCkPostJob } from "@/queue/index.js";
|
||||
import { Notes, NoteEdits } from "@/models/index.js";
|
||||
import type { Note } from "@/models/entities/note.js";
|
||||
import { genId } from "@/misc/gen-id.js";
|
||||
|
||||
const logger = queueLogger.createSubLogger("import-firefish-post");
|
||||
|
||||
|
@ -17,6 +23,7 @@ export async function importCkPost(
|
|||
return;
|
||||
}
|
||||
const post = job.data.post;
|
||||
/*
|
||||
if (post.replyId != null) {
|
||||
done();
|
||||
return;
|
||||
|
@ -29,23 +36,74 @@ export async function importCkPost(
|
|||
done();
|
||||
return;
|
||||
}
|
||||
const { text, cw, localOnly, createdAt } = Post.parse(post);
|
||||
const note = await create(user, {
|
||||
*/
|
||||
const urls = (post.files || [])
|
||||
.map((x: any) => x.url)
|
||||
.filter((x: String) => x.startsWith("http"));
|
||||
const files: DriveFile[] = [];
|
||||
for (const url of urls) {
|
||||
try {
|
||||
const file = await uploadFromUrl({
|
||||
url: url,
|
||||
user: user,
|
||||
});
|
||||
files.push(file);
|
||||
} catch (e) {
|
||||
logger.error(`Skipped adding file to drive: ${url}`);
|
||||
}
|
||||
}
|
||||
const { text, cw, localOnly, createdAt, visibility } = Post.parse(post);
|
||||
let note = await Notes.findOneBy({
|
||||
createdAt: createdAt,
|
||||
files: undefined,
|
||||
poll: undefined,
|
||||
text: text || undefined,
|
||||
reply: null,
|
||||
renote: null,
|
||||
cw: cw,
|
||||
localOnly,
|
||||
visibility: "hidden",
|
||||
visibleUsers: [],
|
||||
channel: null,
|
||||
apMentions: new Array(0),
|
||||
apHashtags: undefined,
|
||||
apEmojis: undefined,
|
||||
text: text,
|
||||
userId: user.id,
|
||||
});
|
||||
|
||||
if (note && (note?.fileIds?.length || 0) < files.length) {
|
||||
const update: Partial<Note> = {};
|
||||
update.fileIds = files.map((x) => x.id);
|
||||
await Notes.update(note.id, update);
|
||||
await NoteEdits.insert({
|
||||
id: genId(),
|
||||
noteId: note.id,
|
||||
text: note.text || undefined,
|
||||
cw: note.cw,
|
||||
fileIds: note.fileIds,
|
||||
updatedAt: new Date(),
|
||||
});
|
||||
logger.info(`Note file updated`);
|
||||
}
|
||||
if (!note) {
|
||||
note = await create(user, {
|
||||
createdAt: createdAt,
|
||||
files: files.length == 0 ? undefined : files,
|
||||
poll: undefined,
|
||||
text: text || undefined,
|
||||
reply: post.replyId ? job.data.parent : null,
|
||||
renote: post.renoteId ? job.data.parent : null,
|
||||
cw: cw,
|
||||
localOnly,
|
||||
visibility: visibility,
|
||||
visibleUsers: [],
|
||||
channel: null,
|
||||
apMentions: new Array(0),
|
||||
apHashtags: undefined,
|
||||
apEmojis: undefined,
|
||||
});
|
||||
logger.info(`Create new note`);
|
||||
} else {
|
||||
logger.info(`Note exist`);
|
||||
}
|
||||
logger.succ("Imported");
|
||||
if (post.childNotes) {
|
||||
for (const child of post.childNotes) {
|
||||
createImportCkPostJob(
|
||||
job.data.user,
|
||||
child,
|
||||
job.data.signatureCheck,
|
||||
note,
|
||||
);
|
||||
}
|
||||
}
|
||||
done();
|
||||
}
|
||||
|
|
|
@ -8,6 +8,9 @@ import { resolveNote } from "@/remote/activitypub/models/note.js";
|
|||
import { Note } from "@/models/entities/note.js";
|
||||
import { uploadFromUrl } from "@/services/drive/upload-from-url.js";
|
||||
import type { DriveFile } from "@/models/entities/drive-file.js";
|
||||
import { Notes, NoteEdits } from "@/models/index.js";
|
||||
import type { Note } from "@/models/entities/note.js";
|
||||
import { genId } from "@/misc/gen-id.js";
|
||||
|
||||
const logger = queueLogger.createSubLogger("import-masto-post");
|
||||
|
||||
|
@ -67,23 +70,47 @@ export async function importMastoPost(
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
const note = await create(user, {
|
||||
let note = await Notes.findOneBy({
|
||||
createdAt: new Date(post.object.published),
|
||||
files: files.length == 0 ? undefined : files,
|
||||
poll: undefined,
|
||||
text: text || undefined,
|
||||
reply,
|
||||
renote: null,
|
||||
cw: post.object.sensitive ? post.object.summary : undefined,
|
||||
localOnly: false,
|
||||
visibility: "hidden",
|
||||
visibleUsers: [],
|
||||
channel: null,
|
||||
apMentions: new Array(0),
|
||||
apHashtags: undefined,
|
||||
apEmojis: undefined,
|
||||
text: text,
|
||||
userId: user.id,
|
||||
});
|
||||
|
||||
if (note && (note?.fileIds?.length || 0) < files.length) {
|
||||
const update: Partial<Note> = {};
|
||||
update.fileIds = files.map((x) => x.id);
|
||||
await Notes.update(note.id, update);
|
||||
await NoteEdits.insert({
|
||||
id: genId(),
|
||||
noteId: note.id,
|
||||
text: note.text || undefined,
|
||||
cw: note.cw,
|
||||
fileIds: note.fileIds,
|
||||
updatedAt: new Date(),
|
||||
});
|
||||
logger.info(`Note file updated`);
|
||||
}
|
||||
if (!note) {
|
||||
note = await create(user, {
|
||||
createdAt: new Date(post.object.published),
|
||||
files: files.length == 0 ? undefined : files,
|
||||
poll: undefined,
|
||||
text: text || undefined,
|
||||
reply,
|
||||
renote: null,
|
||||
cw: post.object.sensitive ? post.object.summary : undefined,
|
||||
localOnly: false,
|
||||
visibility: "hiddenpublic",
|
||||
visibleUsers: [],
|
||||
channel: null,
|
||||
apMentions: new Array(0),
|
||||
apHashtags: undefined,
|
||||
apEmojis: undefined,
|
||||
});
|
||||
logger.info(`Create new note`);
|
||||
} else {
|
||||
logger.info(`Note exist`);
|
||||
}
|
||||
job.progress(100);
|
||||
done();
|
||||
|
||||
|
|
|
@ -57,7 +57,8 @@ export async function importPosts(
|
|||
const parsed = JSON.parse(json);
|
||||
if (parsed instanceof Array) {
|
||||
logger.info("Parsing key style posts");
|
||||
for (const post of JSON.parse(json)) {
|
||||
const arr = recreateChain(parsed);
|
||||
for (const post of arr) {
|
||||
createImportCkPostJob(job.data.user, post, job.data.signatureCheck);
|
||||
}
|
||||
} else if (parsed instanceof Object) {
|
||||
|
@ -74,3 +75,32 @@ export async function importPosts(
|
|||
logger.succ("Imported");
|
||||
done();
|
||||
}
|
||||
|
||||
function recreateChain(arr: any[]): any {
|
||||
type NotesMap = {
|
||||
[id: string]: any;
|
||||
};
|
||||
const notesTree: any[] = [];
|
||||
const lookup: NotesMap = {};
|
||||
for (const note of arr) {
|
||||
lookup[`${note.id}`] = note;
|
||||
note.childNotes = [];
|
||||
if (note.replyId == null && note.renoteId == null) {
|
||||
notesTree.push(note);
|
||||
}
|
||||
}
|
||||
for (const note of arr) {
|
||||
let parent = null;
|
||||
if (note.replyId != null) {
|
||||
parent = lookup[`${note.replyId}`];
|
||||
}
|
||||
if (note.renoteId != null) {
|
||||
parent = lookup[`${note.renoteId}`];
|
||||
}
|
||||
|
||||
if (parent) {
|
||||
parent.childNotes.push(note);
|
||||
}
|
||||
}
|
||||
return notesTree;
|
||||
}
|
||||
|
|
|
@ -48,6 +48,6 @@ export default async function cleanRemoteFiles(
|
|||
job.progress(deletedCount / total);
|
||||
}
|
||||
|
||||
logger.succ("All cahced remote files has been deleted.");
|
||||
logger.succ("All cached remote files has been deleted.");
|
||||
done();
|
||||
}
|
||||
|
|
|
@ -52,6 +52,7 @@ export type DbUserImportMastoPostJobData = {
|
|||
user: ThinUser;
|
||||
post: any;
|
||||
signatureCheck: boolean;
|
||||
parent: Note | null;
|
||||
};
|
||||
|
||||
export type ObjectStorageJobData =
|
||||
|
|
|
@ -94,7 +94,7 @@ function groupingAudience(ids: string[], actor: CacheableRemoteUser) {
|
|||
function isPublic(id: string) {
|
||||
return [
|
||||
"https://www.w3.org/ns/activitystreams#Public",
|
||||
"as#Public",
|
||||
"as:Public",
|
||||
"Public",
|
||||
].includes(id);
|
||||
}
|
||||
|
|
|
@ -33,7 +33,9 @@ export default (endpoint: IEndpoint, ctx: Koa.Context) =>
|
|||
code: y!.code,
|
||||
id: y!.id,
|
||||
kind: y!.kind,
|
||||
...(y!.info ? { info: y!.info } : {}),
|
||||
...(y!.info && process.env.NODE_ENV !== "production"
|
||||
? { info: y!.info }
|
||||
: {}),
|
||||
},
|
||||
};
|
||||
} else {
|
||||
|
|
|
@ -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],
|
||||
];
|
||||
|
|
|
@ -65,6 +65,8 @@ import * as ep___admin_unsuspendUser from "./endpoints/admin/unsuspend-user.js";
|
|||
import * as ep___admin_updateMeta from "./endpoints/admin/update-meta.js";
|
||||
import * as ep___admin_vacuum from "./endpoints/admin/vacuum.js";
|
||||
import * as ep___admin_deleteAccount from "./endpoints/admin/delete-account.js";
|
||||
import * as ep___admin_delete2fa from "./endpoints/admin/delete-2fa.js";
|
||||
import * as ep___admin_deletePasskeys from "./endpoints/admin/delete-passkeys.js";
|
||||
import * as ep___admin_updateUserNote from "./endpoints/admin/update-user-note.js";
|
||||
import * as ep___announcements from "./endpoints/announcements.js";
|
||||
import * as ep___antennas_create from "./endpoints/antennas/create.js";
|
||||
|
@ -418,6 +420,8 @@ const eps = [
|
|||
["admin/update-meta", ep___admin_updateMeta],
|
||||
["admin/vacuum", ep___admin_vacuum],
|
||||
["admin/delete-account", ep___admin_deleteAccount],
|
||||
["admin/delete-2fa", ep___admin_delete2fa],
|
||||
["admin/delete-passkeys", ep___admin_deletePasskeys],
|
||||
["admin/update-user-note", ep___admin_updateUserNote],
|
||||
["announcements", ep___announcements],
|
||||
["antennas/create", ep___antennas_create],
|
||||
|
|
|
@ -0,0 +1,40 @@
|
|||
import { Users, UserProfiles } from "@/models/index.js";
|
||||
import { publishMainStream } from "@/services/stream.js";
|
||||
import define from "../../define.js";
|
||||
|
||||
export const meta = {
|
||||
tags: ["admin"],
|
||||
|
||||
requireCredential: true,
|
||||
requireAdmin: true,
|
||||
|
||||
res: {},
|
||||
} as const;
|
||||
|
||||
export const paramDef = {
|
||||
type: "object",
|
||||
properties: {
|
||||
userId: { type: "string", format: "misskey:id" },
|
||||
},
|
||||
required: ["userId"],
|
||||
} as const;
|
||||
|
||||
export default define(meta, paramDef, async (ps) => {
|
||||
const user = await Users.findOneByOrFail({ id: ps.userId });
|
||||
if (user.isDeleted) {
|
||||
return;
|
||||
}
|
||||
|
||||
await UserProfiles.update(user.id, {
|
||||
twoFactorSecret: null,
|
||||
twoFactorEnabled: false,
|
||||
usePasswordLessLogin: false,
|
||||
});
|
||||
|
||||
const iObj = await Users.pack(user.id, user, {
|
||||
detail: true,
|
||||
includeSecrets: true,
|
||||
});
|
||||
|
||||
publishMainStream(user.id, "meUpdated", iObj);
|
||||
});
|
|
@ -0,0 +1,42 @@
|
|||
import { Users, UserProfiles, UserSecurityKeys } from "@/models/index.js";
|
||||
import { publishMainStream } from "@/services/stream.js";
|
||||
import define from "../../define.js";
|
||||
|
||||
export const meta = {
|
||||
tags: ["admin"],
|
||||
|
||||
requireCredential: true,
|
||||
requireAdmin: true,
|
||||
|
||||
res: {},
|
||||
} as const;
|
||||
|
||||
export const paramDef = {
|
||||
type: "object",
|
||||
properties: {
|
||||
userId: { type: "string", format: "misskey:id" },
|
||||
},
|
||||
required: ["userId"],
|
||||
} as const;
|
||||
|
||||
export default define(meta, paramDef, async (ps) => {
|
||||
const user = await Users.findOneByOrFail({ id: ps.userId });
|
||||
if (user.isDeleted) {
|
||||
return;
|
||||
}
|
||||
|
||||
await UserSecurityKeys.delete({
|
||||
userId: user.id,
|
||||
});
|
||||
|
||||
await UserProfiles.update(user.id, {
|
||||
usePasswordLessLogin: false,
|
||||
});
|
||||
|
||||
const iObj = await Users.pack(user.id, user, {
|
||||
detail: true,
|
||||
includeSecrets: true,
|
||||
});
|
||||
|
||||
publishMainStream(user.id, "meUpdated", iObj);
|
||||
});
|
|
@ -60,13 +60,14 @@ export default define(meta, paramDef, async (ps, user) => {
|
|||
throw new ApiError(meta.errors.noSuchAntenna);
|
||||
}
|
||||
|
||||
const limit = ps.limit + (ps.untilId ? 1 : 0) + (ps.sinceId ? 1 : 0); // untilIdに指定したものも含まれるため+1
|
||||
const noteIdsRes = await redisClient.xrevrange(
|
||||
`antennaTimeline:${antenna.id}`,
|
||||
ps.untilDate || "+",
|
||||
"-",
|
||||
ps.untilDate ?? "+",
|
||||
ps.sinceDate ?? "-",
|
||||
"COUNT",
|
||||
ps.limit + 1,
|
||||
); // untilIdに指定したものも含まれるため+1
|
||||
limit,
|
||||
);
|
||||
|
||||
if (noteIdsRes.length === 0) {
|
||||
return [];
|
||||
|
@ -74,7 +75,7 @@ export default define(meta, paramDef, async (ps, user) => {
|
|||
|
||||
const noteIds = noteIdsRes
|
||||
.map((x) => x[1][1])
|
||||
.filter((x) => x !== ps.untilId);
|
||||
.filter((x) => x !== ps.untilId && x !== ps.sinceId);
|
||||
|
||||
if (noteIds.length === 0) {
|
||||
return [];
|
||||
|
@ -105,7 +106,7 @@ export default define(meta, paramDef, async (ps, user) => {
|
|||
generateMutedUserQuery(query, user);
|
||||
generateBlockedUserQuery(query, user);
|
||||
|
||||
const notes = await query.take(ps.limit).getMany();
|
||||
const notes = await query.take(limit).getMany();
|
||||
|
||||
if (notes.length > 0) {
|
||||
readNote(user.id, notes);
|
||||
|
|
|
@ -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)) ?? "";
|
|
@ -1,6 +1,7 @@
|
|||
import { IsNull } from "typeorm";
|
||||
import { Emojis } from "@/models/index.js";
|
||||
import define from "../define.js";
|
||||
import { ApiError } from "../error.js";
|
||||
|
||||
export const meta = {
|
||||
tags: ["meta"],
|
||||
|
@ -9,6 +10,15 @@ export const meta = {
|
|||
allowGet: true,
|
||||
cacheSec: 3600,
|
||||
|
||||
errors: {
|
||||
noSuchEmoji: {
|
||||
message: "No such emoji.",
|
||||
code: "NO_SUCH_EMOJI",
|
||||
id: "6a5e3be7-5ac3-44a6-a425-9937cd66f8e1",
|
||||
httpStatusCode: 404,
|
||||
},
|
||||
},
|
||||
|
||||
res: {
|
||||
type: "object",
|
||||
optional: false,
|
||||
|
@ -28,12 +38,16 @@ export const paramDef = {
|
|||
} as const;
|
||||
|
||||
export default define(meta, paramDef, async (ps, me) => {
|
||||
const emoji = await Emojis.findOneOrFail({
|
||||
const emoji = await Emojis.findOne({
|
||||
where: {
|
||||
name: ps.name,
|
||||
host: IsNull(),
|
||||
},
|
||||
});
|
||||
|
||||
if (!emoji) {
|
||||
throw new ApiError(meta.errors.noSuchEmoji);
|
||||
}
|
||||
|
||||
return Emojis.pack(emoji);
|
||||
});
|
||||
|
|
|
@ -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
|
||||
? {
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import { In } from "typeorm";
|
||||
import { FindManyOptions, In } from "typeorm";
|
||||
import { Notes } from "@/models/index.js";
|
||||
import { Note } from "@/models/entities/note.js";
|
||||
import config from "@/config/index.js";
|
||||
|
@ -58,6 +58,11 @@ export const paramDef = {
|
|||
nullable: true,
|
||||
default: null,
|
||||
},
|
||||
order: {
|
||||
type: "string",
|
||||
default: "chronological",
|
||||
nullable: true,
|
||||
},
|
||||
},
|
||||
required: ["query"],
|
||||
} as const;
|
||||
|
@ -156,9 +161,6 @@ export default define(meta, paramDef, async (ps, me) => {
|
|||
where: {
|
||||
id: In(chunk),
|
||||
},
|
||||
order: {
|
||||
id: "DESC",
|
||||
},
|
||||
});
|
||||
|
||||
// The notes are checked for visibility and muted/blocked users when packed
|
||||
|
@ -175,19 +177,31 @@ export default define(meta, paramDef, async (ps, me) => {
|
|||
} else if (meilisearch) {
|
||||
let start = 0;
|
||||
const chunkSize = 100;
|
||||
const sortByDate = ps.order !== "relevancy";
|
||||
|
||||
type NoteResult = {
|
||||
id: string;
|
||||
createdAt: number;
|
||||
};
|
||||
const extractedNotes: NoteResult[] = [];
|
||||
|
||||
// Use meilisearch to fetch and step through all search results that could match the requirements
|
||||
const ids = [];
|
||||
while (true) {
|
||||
const results = await meilisearch.search(ps.query, chunkSize, start, me);
|
||||
const searchRes = await meilisearch.search(
|
||||
ps.query,
|
||||
chunkSize,
|
||||
start,
|
||||
me,
|
||||
sortByDate ? "createdAt:desc" : null,
|
||||
);
|
||||
const results: MeilisearchNote[] = searchRes.hits as MeilisearchNote[];
|
||||
|
||||
start += chunkSize;
|
||||
|
||||
if (results.hits.length === 0) {
|
||||
if (results.length === 0) {
|
||||
break;
|
||||
}
|
||||
|
||||
const res = results.hits
|
||||
const res = results
|
||||
.filter((key: MeilisearchNote) => {
|
||||
if (ps.userId && key.userId !== ps.userId) {
|
||||
return false;
|
||||
|
@ -203,34 +217,45 @@ export default define(meta, paramDef, async (ps, me) => {
|
|||
}
|
||||
return true;
|
||||
})
|
||||
.map((key) => key.id);
|
||||
.map((key) => {
|
||||
return {
|
||||
id: key.id,
|
||||
createdAt: key.createdAt,
|
||||
};
|
||||
});
|
||||
|
||||
ids.push(...res);
|
||||
extractedNotes.push(...res);
|
||||
}
|
||||
|
||||
// Sort all the results by note id DESC (newest first)
|
||||
ids.sort((a, b) => b - a);
|
||||
|
||||
// Fetch the notes from the database until we have enough to satisfy the limit
|
||||
start = 0;
|
||||
const found = [];
|
||||
while (found.length < ps.limit && start < ids.length) {
|
||||
const chunk = ids.slice(start, start + chunkSize);
|
||||
const notes: Note[] = await Notes.find({
|
||||
const noteIDs = extractedNotes.map((note) => note.id);
|
||||
|
||||
// Index the ID => index number into a map, so we can restore the array ordering efficiently later
|
||||
const idIndexMap = new Map(noteIDs.map((id, index) => [id, index]));
|
||||
|
||||
while (found.length < ps.limit && start < noteIDs.length) {
|
||||
const chunk = noteIDs.slice(start, start + chunkSize);
|
||||
|
||||
let query: FindManyOptions = {
|
||||
where: {
|
||||
id: In(chunk),
|
||||
},
|
||||
order: {
|
||||
id: "DESC",
|
||||
},
|
||||
});
|
||||
};
|
||||
|
||||
const notes: Note[] = await Notes.find(query);
|
||||
|
||||
// Re-order the note result according to the noteIDs array (cannot be undefined, we map this earlier)
|
||||
// @ts-ignore
|
||||
notes.sort((a, b) => idIndexMap.get(a.id) - idIndexMap.get(b.id));
|
||||
|
||||
// The notes are checked for visibility and muted/blocked users when packed
|
||||
found.push(...(await Notes.packMany(notes, me)));
|
||||
start += chunkSize;
|
||||
}
|
||||
|
||||
// If we have more results than the limit, trim them
|
||||
// If we have more results than the limit, trim the results down
|
||||
if (found.length > ps.limit) {
|
||||
found.length = ps.limit;
|
||||
}
|
||||
|
|
|
@ -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;
|
||||
|
|
|
@ -32,12 +32,20 @@ export function convertNotification(notification: Entity.Notification) {
|
|||
notification.id = convertId(notification.id, IdType.MastodonId);
|
||||
if (notification.status)
|
||||
notification.status = convertStatus(notification.status);
|
||||
if (notification.reaction)
|
||||
notification.reaction = convertReaction(notification.reaction);
|
||||
return notification;
|
||||
}
|
||||
|
||||
export function convertPoll(poll: Entity.Poll) {
|
||||
return simpleConvert(poll);
|
||||
}
|
||||
export function convertReaction(reaction: Entity.Reaction) {
|
||||
if (reaction.accounts) {
|
||||
reaction.accounts = reaction.accounts.map(convertAccount);
|
||||
}
|
||||
return reaction;
|
||||
}
|
||||
export function convertRelationship(relationship: Entity.Relationship) {
|
||||
return simpleConvert(relationship);
|
||||
}
|
||||
|
@ -61,6 +69,8 @@ export function convertStatus(status: Entity.Status) {
|
|||
}));
|
||||
if (status.poll) status.poll = convertPoll(status.poll);
|
||||
if (status.reblog) status.reblog = convertStatus(status.reblog);
|
||||
if (status.quote) status.quote = convertStatus(status.quote);
|
||||
status.reactions = status.reactions.map(convertReaction);
|
||||
|
||||
return status;
|
||||
}
|
||||
|
|
|
@ -2,13 +2,19 @@ import { Entity } from "megalodon";
|
|||
import config from "@/config/index.js";
|
||||
import { fetchMeta } from "@/misc/fetch-meta.js";
|
||||
import { Users, Notes } from "@/models/index.js";
|
||||
import { IsNull, MoreThan } from "typeorm";
|
||||
import { IsNull } from "typeorm";
|
||||
import { MAX_NOTE_TEXT_LENGTH, FILE_TYPE_BROWSERSAFE } from "@/const.js";
|
||||
|
||||
export async function getInstance(
|
||||
response: Entity.Instance,
|
||||
contact: Entity.Account,
|
||||
) {
|
||||
const [meta, totalUsers, totalStatuses] = await Promise.all([
|
||||
fetchMeta(true),
|
||||
Users.count({ where: { host: IsNull() } }),
|
||||
Notes.count({ where: { userHost: IsNull() } }),
|
||||
]);
|
||||
|
||||
// TODO: add firefish features
|
||||
export async function getInstance(response: Entity.Instance) {
|
||||
const meta = await fetchMeta(true);
|
||||
const totalUsers = Users.count({ where: { host: IsNull() } });
|
||||
const totalStatuses = Notes.count({ where: { userHost: IsNull() } });
|
||||
return {
|
||||
uri: response.uri,
|
||||
title: response.title || "Firefish",
|
||||
|
@ -35,41 +41,12 @@ export async function getInstance(response: Entity.Instance) {
|
|||
max_featured_tags: 20,
|
||||
},
|
||||
statuses: {
|
||||
max_characters: 3000,
|
||||
max_media_attachments: 4,
|
||||
max_characters: MAX_NOTE_TEXT_LENGTH,
|
||||
max_media_attachments: 16,
|
||||
characters_reserved_per_url: response.uri.length,
|
||||
},
|
||||
media_attachments: {
|
||||
supported_mime_types: [
|
||||
"image/jpeg",
|
||||
"image/png",
|
||||
"image/gif",
|
||||
"image/heic",
|
||||
"image/heif",
|
||||
"image/webp",
|
||||
"image/avif",
|
||||
"video/webm",
|
||||
"video/mp4",
|
||||
"video/quicktime",
|
||||
"video/ogg",
|
||||
"audio/wave",
|
||||
"audio/wav",
|
||||
"audio/x-wav",
|
||||
"audio/x-pn-wave",
|
||||
"audio/vnd.wave",
|
||||
"audio/ogg",
|
||||
"audio/vorbis",
|
||||
"audio/mpeg",
|
||||
"audio/mp3",
|
||||
"audio/webm",
|
||||
"audio/flac",
|
||||
"audio/aac",
|
||||
"audio/m4a",
|
||||
"audio/x-m4a",
|
||||
"audio/mp4",
|
||||
"audio/3gpp",
|
||||
"video/x-ms-asf",
|
||||
],
|
||||
supported_mime_types: FILE_TYPE_BROWSERSAFE,
|
||||
image_size_limit: 10485760,
|
||||
image_matrix_limit: 16777216,
|
||||
video_size_limit: 41943040,
|
||||
|
@ -77,36 +54,16 @@ export async function getInstance(response: Entity.Instance) {
|
|||
video_matrix_limit: 2304000,
|
||||
},
|
||||
polls: {
|
||||
max_options: 8,
|
||||
max_options: 10,
|
||||
max_characters_per_option: 50,
|
||||
min_expiration: 300,
|
||||
min_expiration: 50,
|
||||
max_expiration: 2629746,
|
||||
},
|
||||
reactions: {
|
||||
max_reactions: 1,
|
||||
},
|
||||
},
|
||||
contact_account: {
|
||||
id: "1",
|
||||
username: "admin",
|
||||
acct: "admin",
|
||||
display_name: "admin",
|
||||
locked: true,
|
||||
bot: true,
|
||||
discoverable: false,
|
||||
group: false,
|
||||
created_at: new Date().toISOString(),
|
||||
note: "<p>Please refer to the original instance for the actual admin contact.</p>",
|
||||
url: `${response.uri}/`,
|
||||
avatar: `${response.uri}/static-assets/badges/info.png`,
|
||||
avatar_static: `${response.uri}/static-assets/badges/info.png`,
|
||||
header: "/static-assets/transparent.png",
|
||||
header_static: "/static-assets/transparent.png",
|
||||
followers_count: -1,
|
||||
following_count: 0,
|
||||
statuses_count: 0,
|
||||
last_status_at: new Date().toISOString(),
|
||||
noindex: true,
|
||||
emojis: [],
|
||||
fields: [],
|
||||
},
|
||||
contact_account: contact,
|
||||
rules: [],
|
||||
};
|
||||
}
|
||||
|
|
|
@ -27,6 +27,8 @@ export function apiStatusMastodon(router: Router): void {
|
|||
let body: any = ctx.request.body;
|
||||
if (body.in_reply_to_id)
|
||||
body.in_reply_to_id = convertId(body.in_reply_to_id, IdType.FirefishId);
|
||||
if (body.quote_id)
|
||||
body.quote_id = convertId(body.quote_id, IdType.FirefishId);
|
||||
if (
|
||||
(!body.poll && body["poll[options][]"]) ||
|
||||
(!body.media_ids && body["media_ids[]"])
|
||||
|
@ -48,7 +50,7 @@ export function apiStatusMastodon(router: Router): void {
|
|||
try {
|
||||
const id = body.in_reply_to_id;
|
||||
const post = await client.getStatus(id);
|
||||
const react = post.data.emoji_reactions.filter((e) => e.me)[0].name;
|
||||
const react = post.data.reactions.filter((e) => e.me)[0].name;
|
||||
const data = await client.deleteEmojiReaction(id, react);
|
||||
ctx.body = data.data;
|
||||
} catch (e: any) {
|
||||
|
@ -367,6 +369,47 @@ export function apiStatusMastodon(router: Router): void {
|
|||
}
|
||||
},
|
||||
);
|
||||
|
||||
router.post<{ Params: { id: string; name: string } }>(
|
||||
"/v1/statuses/:id/react/:name",
|
||||
async (ctx) => {
|
||||
const BASE_URL = `${ctx.protocol}://${ctx.hostname}`;
|
||||
const accessTokens = ctx.headers.authorization;
|
||||
const client = getClient(BASE_URL, accessTokens);
|
||||
try {
|
||||
const data = await client.reactStatus(
|
||||
convertId(ctx.params.id, IdType.FirefishId),
|
||||
ctx.params.name,
|
||||
);
|
||||
ctx.body = convertStatus(data.data);
|
||||
} catch (e: any) {
|
||||
console.error(e);
|
||||
ctx.status = 401;
|
||||
ctx.body = e.response.data;
|
||||
}
|
||||
},
|
||||
);
|
||||
|
||||
router.post<{ Params: { id: string; name: string } }>(
|
||||
"/v1/statuses/:id/unreact/:name",
|
||||
async (ctx) => {
|
||||
const BASE_URL = `${ctx.protocol}://${ctx.hostname}`;
|
||||
const accessTokens = ctx.headers.authorization;
|
||||
const client = getClient(BASE_URL, accessTokens);
|
||||
try {
|
||||
const data = await client.unreactStatus(
|
||||
convertId(ctx.params.id, IdType.FirefishId),
|
||||
ctx.params.name,
|
||||
);
|
||||
ctx.body = convertStatus(data.data);
|
||||
} catch (e: any) {
|
||||
console.error(e);
|
||||
ctx.status = 401;
|
||||
ctx.body = e.response.data;
|
||||
}
|
||||
},
|
||||
);
|
||||
|
||||
router.get<{ Params: { id: string } }>("/v1/media/:id", async (ctx) => {
|
||||
const BASE_URL = `${ctx.protocol}://${ctx.hostname}`;
|
||||
const accessTokens = ctx.headers.authorization;
|
||||
|
|
|
@ -18,6 +18,10 @@ export function argsToBools(q: ParsedUrlQuery) {
|
|||
const toBoolean = (value: string) =>
|
||||
!["0", "f", "F", "false", "FALSE", "off", "OFF"].includes(value);
|
||||
|
||||
// Keys taken from:
|
||||
// - https://docs.joinmastodon.org/methods/accounts/#statuses
|
||||
// - https://docs.joinmastodon.org/methods/timelines/#public
|
||||
// - https://docs.joinmastodon.org/methods/timelines/#tag
|
||||
let object: any = q;
|
||||
if (q.only_media)
|
||||
if (typeof q.only_media === "string")
|
||||
|
@ -25,6 +29,13 @@ export function argsToBools(q: ParsedUrlQuery) {
|
|||
if (q.exclude_replies)
|
||||
if (typeof q.exclude_replies === "string")
|
||||
object.exclude_replies = toBoolean(q.exclude_replies);
|
||||
if (q.exclude_reblogs)
|
||||
if (typeof q.exclude_reblogs === "string")
|
||||
object.exclude_reblogs = toBoolean(q.exclude_reblogs);
|
||||
if (q.pinned)
|
||||
if (typeof q.pinned === "string") object.pinned = toBoolean(q.pinned);
|
||||
if (q.local)
|
||||
if (typeof q.local === "string") object.local = toBoolean(q.local);
|
||||
return q;
|
||||
}
|
||||
|
||||
|
|
221
packages/backend/src/server/file/byte-range-readable.ts
Normal file
221
packages/backend/src/server/file/byte-range-readable.ts
Normal file
|
@ -0,0 +1,221 @@
|
|||
import { Readable, ReadableOptions } from "node:stream";
|
||||
import { Buffer, constants as BufferConstants } from "node:buffer";
|
||||
import * as fs from "node:fs";
|
||||
|
||||
interface ByteRange {
|
||||
start: bigint;
|
||||
end: bigint;
|
||||
size: bigint;
|
||||
}
|
||||
|
||||
const BOUNDARY_CHARS =
|
||||
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
|
||||
const BYTERANGE_SPEC_REGEX = /^bytes=(.+)$/;
|
||||
const BYTERANGE_REGEX = /(\d*)-(\d*)/;
|
||||
|
||||
const BIGINT_0 = BigInt(0);
|
||||
const BIGINT_1 = BigInt(1);
|
||||
const BOUNDARY_SIZE = 40;
|
||||
|
||||
function extractRanges(
|
||||
fileSize: bigint,
|
||||
maxByteRanges: number,
|
||||
rangeHeaderValue: string,
|
||||
): ByteRange[] {
|
||||
const ranges: ByteRange[] = [];
|
||||
|
||||
if (!rangeHeaderValue) return ranges;
|
||||
|
||||
const rangeSpecMatch = rangeHeaderValue.match(BYTERANGE_SPEC_REGEX);
|
||||
if (!rangeSpecMatch) return [];
|
||||
|
||||
const rangeSpecs = rangeSpecMatch[1].split(",");
|
||||
for (let i = 0; i < rangeSpecs.length; i = i + 1) {
|
||||
const byteRange = rangeSpecs[i].match(BYTERANGE_REGEX);
|
||||
if (!byteRange) return [];
|
||||
|
||||
let start: bigint;
|
||||
let end: bigint;
|
||||
let size: bigint;
|
||||
|
||||
if (byteRange[1]) {
|
||||
start = BigInt(byteRange[1]);
|
||||
}
|
||||
|
||||
if (byteRange[2]) {
|
||||
end = BigInt(byteRange[2]);
|
||||
}
|
||||
|
||||
if (start === undefined && end === undefined) {
|
||||
/* some invalid range like bytes=- */
|
||||
return [];
|
||||
}
|
||||
|
||||
if (start === undefined) {
|
||||
/* end-of-file range like -500 */
|
||||
start = fileSize - end;
|
||||
end = fileSize - BIGINT_1;
|
||||
if (start < BIGINT_0) return []; /* range larger than file, return */
|
||||
}
|
||||
|
||||
if (end === undefined) {
|
||||
/* range like 0- */
|
||||
end = fileSize - BIGINT_1;
|
||||
}
|
||||
|
||||
if (start > end || end >= fileSize) {
|
||||
/* return empty range to issue regular 200 */
|
||||
return [];
|
||||
}
|
||||
size = end - start + BIGINT_1;
|
||||
|
||||
if (1 > maxByteRanges - ranges.length) return [];
|
||||
|
||||
ranges.push({
|
||||
start: start,
|
||||
end: end,
|
||||
size: size,
|
||||
});
|
||||
}
|
||||
|
||||
return ranges;
|
||||
}
|
||||
|
||||
function createBoundary(len: number): string {
|
||||
let chars = [];
|
||||
for (let i = 0; i < len; i = i + 1) {
|
||||
chars[i] = BOUNDARY_CHARS.charAt(
|
||||
Math.floor(Math.random() * BOUNDARY_CHARS.length),
|
||||
);
|
||||
}
|
||||
return chars.join("");
|
||||
}
|
||||
|
||||
class ByteRangeReadable extends Readable {
|
||||
size: bigint; /* the total size in bytes */
|
||||
boundary: string; /* boundary marker to use in multipart headers */
|
||||
|
||||
private fd: number;
|
||||
private ranges: ByteRange[];
|
||||
private index: number; /* index within ranges */
|
||||
private position: bigint;
|
||||
private end: bigint;
|
||||
private contentType: string;
|
||||
private fileSize: bigint;
|
||||
private headers: Buffer[];
|
||||
private trailer: Buffer;
|
||||
|
||||
static parseByteRanges(
|
||||
fileSize: bigint,
|
||||
maxByteRanges: number,
|
||||
rangeHeaderValue?: string,
|
||||
): ByteRange[] {
|
||||
return extractRanges(fileSize, maxByteRanges, rangeHeaderValue);
|
||||
}
|
||||
|
||||
private createPartHeader(range: ByteRange): Buffer {
|
||||
return Buffer.from(
|
||||
[
|
||||
"",
|
||||
`--${this.boundary}`,
|
||||
`Content-Type: ${this.contentType}`,
|
||||
`Content-Range: bytes ${range.start}-${range.end}/${this.fileSize}`,
|
||||
"",
|
||||
"",
|
||||
].join("\r\n"),
|
||||
);
|
||||
}
|
||||
|
||||
constructor(
|
||||
fd: number,
|
||||
fileSize: bigint,
|
||||
ranges: ByteRange[],
|
||||
contentType: string,
|
||||
opts?: ReadableOptions,
|
||||
) {
|
||||
super(opts);
|
||||
|
||||
if (ranges.length === 0) {
|
||||
throw Error("this requires at least 1 byte range");
|
||||
}
|
||||
|
||||
this.fd = fd;
|
||||
this.ranges = ranges;
|
||||
this.fileSize = fileSize;
|
||||
this.contentType = contentType;
|
||||
|
||||
this.position = BIGINT_1;
|
||||
this.end = BIGINT_0;
|
||||
this.index = -1;
|
||||
this.headers = [];
|
||||
|
||||
this.size = BIGINT_0;
|
||||
|
||||
if (this.ranges.length === 1) {
|
||||
this.size = this.ranges[0].size;
|
||||
} else {
|
||||
this.boundary = createBoundary(BOUNDARY_SIZE);
|
||||
this.ranges.forEach((r) => {
|
||||
const header = this.createPartHeader(r);
|
||||
this.headers.push(header);
|
||||
|
||||
this.size += BigInt(header.length) + r.size;
|
||||
});
|
||||
this.trailer = Buffer.from(`\r\n--${this.boundary}--\r\n`);
|
||||
this.size += BigInt(this.trailer.length);
|
||||
}
|
||||
}
|
||||
|
||||
_read(n) {
|
||||
if (this.index == this.ranges.length) {
|
||||
this.push(null);
|
||||
return;
|
||||
}
|
||||
|
||||
if (this.position > this.end) {
|
||||
/* move ahead to the next index */
|
||||
this.index++;
|
||||
|
||||
if (this.index === this.ranges.length) {
|
||||
if (this.trailer) {
|
||||
this.push(this.trailer);
|
||||
return;
|
||||
}
|
||||
this.push(null);
|
||||
return;
|
||||
}
|
||||
|
||||
this.position = this.ranges[this.index].start;
|
||||
this.end = this.ranges[this.index].end;
|
||||
|
||||
if (this.ranges.length > 1) {
|
||||
this.push(this.headers[this.index]);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
const max = this.end - this.position + BIGINT_1;
|
||||
|
||||
if (n > max) n = Number(max);
|
||||
const buf = Buffer.alloc(n);
|
||||
|
||||
fs.read(this.fd, buf, 0, n, this.position, (err, bytesRead) => {
|
||||
if (err) {
|
||||
this.destroy(err);
|
||||
return;
|
||||
}
|
||||
if (bytesRead == 0) {
|
||||
/* something seems to have gone wrong? */
|
||||
this.push(null);
|
||||
return;
|
||||
}
|
||||
|
||||
if (bytesRead > n) bytesRead = n;
|
||||
|
||||
this.position += BigInt(bytesRead);
|
||||
this.push(buf.slice(0, bytesRead));
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
export { ByteRange, ByteRangeReadable };
|
|
@ -14,6 +14,7 @@ import { detectType } from "@/misc/get-file-info.js";
|
|||
import { convertToWebp } from "@/services/drive/image-processor.js";
|
||||
import { GenerateVideoThumbnail } from "@/services/drive/generate-video-thumbnail.js";
|
||||
import { StatusError } from "@/misc/fetch.js";
|
||||
import { ByteRangeReadable } from "./byte-range-readable.js";
|
||||
import { FILE_TYPE_BROWSERSAFE } from "@/const.js";
|
||||
|
||||
const _filename = fileURLToPath(import.meta.url);
|
||||
|
@ -21,6 +22,8 @@ const _dirname = dirname(_filename);
|
|||
|
||||
const assets = `${_dirname}/../../server/file/assets/`;
|
||||
|
||||
const MAX_BYTE_RANGES = 10;
|
||||
|
||||
const commonReadableHandlerGenerator =
|
||||
(ctx: Koa.Context) => (e: Error): void => {
|
||||
serverLogger.error(e);
|
||||
|
@ -122,31 +125,88 @@ export default async function (ctx: Koa.Context) {
|
|||
return;
|
||||
}
|
||||
|
||||
let contentType;
|
||||
let filename;
|
||||
let fileHandle;
|
||||
|
||||
if (isThumbnail || isWebpublic) {
|
||||
const { mime, ext } = await detectType(InternalStorage.resolvePath(key));
|
||||
const filename = rename(file.name, {
|
||||
suffix: isThumbnail ? "-thumb" : "-web",
|
||||
extname: ext ? `.${ext}` : undefined,
|
||||
}).toString();
|
||||
(contentType = FILE_TYPE_BROWSERSAFE.includes(mime)
|
||||
? mime
|
||||
: "application/octet-stream"),
|
||||
(filename = rename(file.name, {
|
||||
suffix: isThumbnail ? "-thumb" : "-web",
|
||||
extname: ext ? `.${ext}` : undefined,
|
||||
}).toString());
|
||||
|
||||
ctx.body = InternalStorage.read(key);
|
||||
ctx.set(
|
||||
"Content-Type",
|
||||
FILE_TYPE_BROWSERSAFE.includes(mime) ? mime : "application/octet-stream",
|
||||
);
|
||||
ctx.set("Cache-Control", "max-age=31536000, immutable");
|
||||
ctx.set("Content-Disposition", contentDisposition("inline", filename));
|
||||
fileHandle = await InternalStorage.open(key, "r");
|
||||
} else {
|
||||
const readable = InternalStorage.read(file.accessKey!);
|
||||
readable.on("error", commonReadableHandlerGenerator(ctx));
|
||||
ctx.body = readable;
|
||||
ctx.set(
|
||||
"Content-Type",
|
||||
FILE_TYPE_BROWSERSAFE.includes(file.type)
|
||||
? file.type
|
||||
: "application/octet-stream",
|
||||
);
|
||||
ctx.set("Cache-Control", "max-age=31536000, immutable");
|
||||
ctx.set("Content-Disposition", contentDisposition("inline", file.name));
|
||||
(contentType = FILE_TYPE_BROWSERSAFE.includes(file.type)
|
||||
? file.type
|
||||
: "application/octet-stream"),
|
||||
(filename = file.name);
|
||||
fileHandle = await InternalStorage.open(file.accessKey!, "r");
|
||||
}
|
||||
|
||||
// We can let Koa evaluate conditionals by setting
|
||||
// the status to 200, along with the lastModified
|
||||
// and etag properties, then checking ctx.fresh.
|
||||
// Additionally, Range is ignored if a conditional GET would
|
||||
// result in a 304 response, so we can return early here.
|
||||
|
||||
ctx.status = 200;
|
||||
ctx.etag = file.md5;
|
||||
ctx.lastModified = file.createdAt;
|
||||
|
||||
// When doing a conditional request, we MUST return a "Cache-Control" header
|
||||
// if a normal 200 response would have included.
|
||||
ctx.set("Cache-Control", "max-age=31536000, immutable");
|
||||
|
||||
if (ctx.fresh) {
|
||||
ctx.status = 304;
|
||||
return;
|
||||
}
|
||||
|
||||
ctx.length = file.size;
|
||||
ctx.set("Content-Disposition", contentDisposition("inline", filename));
|
||||
ctx.set("Content-Type", contentType);
|
||||
|
||||
const ranges = ByteRangeReadable.parseByteRanges(
|
||||
BigInt(file.size),
|
||||
MAX_BYTE_RANGES,
|
||||
ctx.headers["range"],
|
||||
);
|
||||
const readable =
|
||||
ranges.length === 0
|
||||
? fileHandle.createReadStream()
|
||||
: new ByteRangeReadable(
|
||||
fileHandle.fd,
|
||||
BigInt(file.size),
|
||||
ranges,
|
||||
contentType,
|
||||
);
|
||||
readable.on("error", commonReadableHandlerGenerator(ctx));
|
||||
ctx.body = readable;
|
||||
|
||||
if (ranges.length === 0) {
|
||||
ctx.set("Accept-Ranges", "bytes");
|
||||
} else {
|
||||
ctx.status = 206;
|
||||
ctx.length = readable.size;
|
||||
readable.on("close", async () => {
|
||||
await fileHandle.close();
|
||||
});
|
||||
|
||||
if (ranges.length === 1) {
|
||||
ctx.set(
|
||||
"Content-Range",
|
||||
`bytes ${ranges[0].start}-${ranges[0].end}/${file.size}`,
|
||||
);
|
||||
} else {
|
||||
ctx.set(
|
||||
"Content-Type",
|
||||
`multipart/byteranges; boundary=${readable.boundary}`,
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -221,7 +221,10 @@ export const startServer = () => {
|
|||
|
||||
initializeStreamingServer(server);
|
||||
|
||||
server.listen(config.port);
|
||||
server.listen({
|
||||
port: config.port,
|
||||
host: config.bind,
|
||||
});
|
||||
|
||||
return server;
|
||||
};
|
||||
|
@ -257,6 +260,11 @@ export default () =>
|
|||
}
|
||||
});
|
||||
|
||||
// @ts-ignore
|
||||
server.listen(config.port, resolve);
|
||||
server.listen(
|
||||
{
|
||||
port: config.port,
|
||||
host: config.bind,
|
||||
},
|
||||
() => resolve(undefined),
|
||||
);
|
||||
});
|
||||
|
|
|
@ -114,24 +114,48 @@ const router = new Router();
|
|||
//#region static assets
|
||||
|
||||
router.get("/static-assets/(.*)", async (ctx) => {
|
||||
await send(ctx as any, ctx.path.replace("/static-assets/", ""), {
|
||||
root: staticAssets,
|
||||
maxage: 7 * DAY,
|
||||
});
|
||||
try {
|
||||
await send(ctx as any, ctx.path.replace("/static-assets/", ""), {
|
||||
root: staticAssets,
|
||||
maxage: 7 * DAY,
|
||||
});
|
||||
} catch (e) {
|
||||
if (e.status === 404) {
|
||||
ctx.throw(404, "File not found");
|
||||
} else {
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
router.get("/client-assets/(.*)", async (ctx) => {
|
||||
await send(ctx as any, ctx.path.replace("/client-assets/", ""), {
|
||||
root: clientAssets,
|
||||
maxage: 7 * DAY,
|
||||
});
|
||||
try {
|
||||
await send(ctx as any, ctx.path.replace("/client-assets/", ""), {
|
||||
root: clientAssets,
|
||||
maxage: 7 * DAY,
|
||||
});
|
||||
} catch (e) {
|
||||
if (e.status === 404) {
|
||||
ctx.throw(404, "File not found");
|
||||
} else {
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
router.get("/assets/(.*)", async (ctx) => {
|
||||
await send(ctx as any, ctx.path.replace("/assets/", ""), {
|
||||
root: assets,
|
||||
maxage: 7 * DAY,
|
||||
});
|
||||
try {
|
||||
await send(ctx as any, ctx.path.replace("/assets/", ""), {
|
||||
root: assets,
|
||||
maxage: 7 * DAY,
|
||||
});
|
||||
} catch (e) {
|
||||
if (e.status === 404) {
|
||||
ctx.throw(404, "File not found");
|
||||
} else {
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
// Apple touch icon
|
||||
|
|
|
@ -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;
|
||||
|
|
|
@ -37,6 +37,32 @@ import { deleteFile } from "./delete-file.js";
|
|||
|
||||
const logger = driveLogger.createSubLogger("register", "yellow");
|
||||
|
||||
type PathPartLike = string | null;
|
||||
|
||||
// Joins an array of elements into a URL pathname, possibly with a base URL object to append to.
|
||||
// Null or 0-length parts will be left out.
|
||||
function urlPathJoin(
|
||||
baseOrParts: URL | PathPartLike[],
|
||||
pathParts?: PathPartLike[],
|
||||
): string {
|
||||
if (baseOrParts instanceof URL) {
|
||||
const url = new URL(baseOrParts as URL);
|
||||
if (pathParts) {
|
||||
pathParts.unshift(
|
||||
url.pathname.endsWith("/") ? url.pathname.slice(0, -1) : url.pathname,
|
||||
);
|
||||
url.pathname = pathParts
|
||||
.filter((x) => x !== null && x.toString().length > 0)
|
||||
.join("/");
|
||||
}
|
||||
return url.toString();
|
||||
}
|
||||
const baseParts = baseOrParts.concat(pathParts ?? []);
|
||||
return baseParts
|
||||
.filter((x) => x !== null && x.toString().length > 0)
|
||||
.join("/");
|
||||
}
|
||||
|
||||
/***
|
||||
* Save file
|
||||
* @param path Path for original
|
||||
|
@ -77,17 +103,16 @@ async function save(
|
|||
ext = "";
|
||||
}
|
||||
|
||||
const baseUrl =
|
||||
meta.objectStorageBaseUrl ||
|
||||
const baseUrl = new URL(
|
||||
meta.objectStorageBaseUrl ?? `/${meta.objectStorageBucket}`,
|
||||
`${meta.objectStorageUseSSL ? "https" : "http"}://${
|
||||
meta.objectStorageEndpoint
|
||||
}${meta.objectStoragePort ? `:${meta.objectStoragePort}` : ""}/${
|
||||
meta.objectStorageBucket
|
||||
}`;
|
||||
}${meta.objectStoragePort ? `:${meta.objectStoragePort}` : ""}`,
|
||||
);
|
||||
|
||||
// for original
|
||||
const key = `${meta.objectStoragePrefix}/${uuid()}${ext}`;
|
||||
const url = `${baseUrl}/${key}`;
|
||||
const key = urlPathJoin([meta.objectStoragePrefix, `${uuid()}${ext}`]);
|
||||
const url = urlPathJoin(baseUrl, [key]);
|
||||
|
||||
// for alts
|
||||
let webpublicKey: string | null = null;
|
||||
|
@ -101,10 +126,11 @@ async function save(
|
|||
const uploads = [upload(key, fs.createReadStream(path), type, name)];
|
||||
|
||||
if (alts.webpublic) {
|
||||
webpublicKey = `${meta.objectStoragePrefix}/webpublic-${uuid()}.${
|
||||
alts.webpublic.ext
|
||||
}`;
|
||||
webpublicUrl = `${baseUrl}/${webpublicKey}`;
|
||||
webpublicKey = urlPathJoin([
|
||||
meta.objectStoragePrefix,
|
||||
`webpublic-${uuid()}.${alts.webpublic.ext}`,
|
||||
]);
|
||||
webpublicUrl = urlPathJoin(baseUrl, [webpublicKey]);
|
||||
|
||||
logger.info(`uploading webpublic: ${webpublicKey}`);
|
||||
uploads.push(
|
||||
|
@ -113,10 +139,11 @@ async function save(
|
|||
}
|
||||
|
||||
if (alts.thumbnail) {
|
||||
thumbnailKey = `${meta.objectStoragePrefix}/thumbnail-${uuid()}.${
|
||||
alts.thumbnail.ext
|
||||
}`;
|
||||
thumbnailUrl = `${baseUrl}/${thumbnailKey}`;
|
||||
thumbnailKey = urlPathJoin([
|
||||
meta.objectStoragePrefix,
|
||||
`thumbnail-${uuid()}.${alts.thumbnail.ext}`,
|
||||
]);
|
||||
thumbnailUrl = urlPathJoin(baseUrl, [thumbnailKey]);
|
||||
|
||||
logger.info(`uploading thumbnail: ${thumbnailKey}`);
|
||||
uploads.push(
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import * as fs from "node:fs";
|
||||
import * as fsPromises from "node:fs/promises";
|
||||
import * as Path from "node:path";
|
||||
import { fileURLToPath } from "node:url";
|
||||
import { dirname } from "node:path";
|
||||
|
@ -13,6 +14,10 @@ export class InternalStorage {
|
|||
public static resolvePath = (key: string) =>
|
||||
Path.resolve(InternalStorage.path, key);
|
||||
|
||||
public static open(key: string, flags: string) {
|
||||
return fsPromises.open(InternalStorage.resolvePath(key), flags);
|
||||
}
|
||||
|
||||
public static read(key: string) {
|
||||
return fs.createReadStream(InternalStorage.resolvePath(key));
|
||||
}
|
||||
|
|
|
@ -11,17 +11,23 @@ export function getS3(meta: Meta) {
|
|||
}`
|
||||
: `${meta.objectStorageUseSSL ? "https://" : "http://"}example.net`;
|
||||
|
||||
return new S3({
|
||||
endpoint: meta.objectStorageEndpoint || undefined,
|
||||
accessKeyId: meta.objectStorageAccessKey!,
|
||||
secretAccessKey: meta.objectStorageSecretKey!,
|
||||
region: meta.objectStorageRegion || undefined,
|
||||
sslEnabled: meta.objectStorageUseSSL,
|
||||
s3ForcePathStyle: !meta.objectStorageEndpoint // AWS with endPoint omitted
|
||||
? false
|
||||
: meta.objectStorageS3ForcePathStyle,
|
||||
httpOptions: {
|
||||
agent: getAgentByUrl(new URL(u), !meta.objectStorageUseProxy),
|
||||
},
|
||||
});
|
||||
try {
|
||||
return new S3({
|
||||
endpoint: meta.objectStorageEndpoint || undefined,
|
||||
accessKeyId: meta.objectStorageAccessKey!,
|
||||
secretAccessKey: meta.objectStorageSecretKey!,
|
||||
region: meta.objectStorageRegion || undefined,
|
||||
sslEnabled: meta.objectStorageUseSSL,
|
||||
s3ForcePathStyle: !meta.objectStorageEndpoint // AWS with endPoint omitted
|
||||
? false
|
||||
: meta.objectStorageS3ForcePathStyle,
|
||||
httpOptions: {
|
||||
agent: getAgentByUrl(new URL(u), !meta.objectStorageUseProxy),
|
||||
},
|
||||
});
|
||||
} catch (e) {
|
||||
throw new Error(
|
||||
`Failed to construct S3 client, assembled S3 URL: ${u}\n${e}`,
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue