Merge branch 'develop' into feat/scylladb

This commit is contained in:
Namekuji 2023-07-31 22:57:49 -04:00
commit b8d8e2e5f5
No known key found for this signature in database
GPG key ID: 1D62332C07FBA532
18 changed files with 298 additions and 168 deletions

View file

@ -29,7 +29,7 @@ url: https://example.com/
# The port that your Firefish server should listen on.
port: 3000
# The bind host your Calckey server should listen on.
# The bind host your Firefish server should listen on.
# If unspecified, the wildcard address will be used.
#bind: 127.0.0.1

View file

@ -66,4 +66,3 @@ cache:
- node_modules/
- packages/*/node_modules/
- packages/backend/native-utils/node_modules/
- packages/backend/native-utils/target/

View file

@ -12,9 +12,6 @@ You can contribute without knowing how to code by helping translate here:
[![Translation bars](https://hosted.weblate.org/widgets/firefish/-/multi-auto.svg)](https://hosted.weblate.org/engage/firefish/)
## Roadmap
See [FIREFISH.md](./FIREFISH.md)
## Issues
Before creating an issue, please check the following:
- To avoid duplication, please search for similar issues before creating a new issue.

View file

@ -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
@ -66,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/>

View file

@ -953,9 +953,9 @@ driveCapOverrideCaption: "Gib einen Wert von 0 oder weniger ein, um die Kapazit
auf den Standard zurückzusetzen."
requireAdminForView: "Du musst dich mit einem Administratorkonto anmelden um dies
zu sehen."
isSystemAccount: "Dieses Konto wird vom System erstellt und automatisch verwaltet.
Bitte moderieren, bearbeiten, löschen oder manipulieren Sie dieses Konto nicht,
da es sonst zu einem Server-Absturz kommen könnte."
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"
@ -966,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"
@ -1128,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)"
@ -2191,3 +2191,13 @@ _skinTones:
showPopup: Benutzer mit Popup benachrichtigen
showWithSparkles: Mit Glitzer anzeigen
removeQuote: Zitat entfernen
objectStorageS3ForcePathStyle: Verwende pfadbasierte Endpunkt-URLs
objectStorageS3ForcePathStyleDesc: Wenn aktiviert, werden Endpunkt-URLs im Format
's3.amazonaws.com/<bucket>/' statt '<bucket>.s3.amazonaws.com' erstellt.
origin: Herkunft
delete2fa: 2FA deaktivieren
deletePasskeys: Passkeys löschen
delete2faConfirm: Passkeys werden unwiderruflich von diesem Account gelöscht. Fortfahren?
deletePasskeysConfirm: Alle Passkeys und Security-Keys werden unwiderruflich von diesem
Account gelöscht. Fortfahren?
inputNotMatch: Eingabe stimmt nicht überein

View file

@ -1,5 +1,6 @@
_lang_: "Français"
headlineFirefish: "Réseau relié par des notes"
headlineFirefish: "Une plateforme de réseaux sociaux décentralisé, open source qui
est gratuit pour toujours ! 🚀"
introFirefish: "Bienvenue ! Firefish est une plateforme de réseau social décentralisé
et open source qui est gratuite pour toujours ! 🚀"
monthAndDay: "{day}/{month}"
@ -13,8 +14,8 @@ ok: "OK"
gotIt: "Jai compris !"
cancel: "Annuler"
enterUsername: "Entrer un nom dutilisateur·rice"
renotedBy: "Renoté par {user}"
noNotes: "Aucune note"
renotedBy: "Boosté par {user}"
noNotes: "Aucun post"
noNotifications: "Aucune notification"
instance: "Serveur"
settings: "Paramètres"
@ -45,8 +46,8 @@ copyContent: "Copier le contenu"
copyLink: "Copier le lien"
delete: "Supprimer"
deleteAndEdit: "Supprimer et réécrire"
deleteAndEditConfirm: "Êtes-vous sûr·e de vouloir supprimer cette note et la reformuler
? Vous perdrez toutes les réactions, renotes et réponses y afférentes."
deleteAndEditConfirm: "Êtes-vous sûr·e de vouloir supprimer ce post et le reformuler
? Vous perdrez toutes les réactions, boosts et réponses liées."
addToList: "Ajouter à une liste"
sendMessage: "Envoyer un message"
copyUsername: "Copier le nom dutilisateur·rice"
@ -60,14 +61,14 @@ receiveFollowRequest: "Demande dabonnement reçue"
followRequestAccepted: "La demande dabonnement a été acceptée"
mention: "Mentionner"
mentions: "Mentions"
directNotes: "Notes directes"
directNotes: "Messages directs"
importAndExport: "Import et export"
import: "Importer"
export: "Exporter"
files: "Fichiers"
download: "Télécharger"
driveFileDeleteConfirm: "Êtes-vous sûr·e de vouloir supprimer le fichier \"{name}\"\
\ ? Il sera retiré de toutes ses notes liées."
\ ? Il sera retiré de tous ses posts liées."
unfollowConfirm: "Désirez-vous vous désabonner de {name} ?"
exportRequested: "Vous avez demandé une exportation. Lopération pourrait prendre
un peu de temps. Une terminée, le fichier résultant sera ajouté au Drive."
@ -94,18 +95,18 @@ youShouldUpgradeClient: "Si la page ne s'affiche pas correctement, rechargez-la
enterListName: "Nom de la liste"
privacy: "Confidentialité"
makeFollowManuallyApprove: "Accepter manuellement les demandes dabonnement"
defaultNoteVisibility: "Visibilité des notes par défaut"
defaultNoteVisibility: "Visibilité des posts par défaut"
follow: "Sabonner"
followRequest: "Demande dabonnement"
followRequests: "Demandes dabonnement"
unfollow: "Se désabonner"
followRequestPending: "Demande d'abonnement en attente de confirmation"
enterEmoji: "Insérer un émoji"
renote: "Renoter"
unrenote: "Annuler la Renote"
renoted: "Renoté."
cantRenote: "Ce message ne peut pas être renoté."
cantReRenote: "Impossible de renoter une Renote."
renote: "Booster"
unrenote: "Annuler le boost"
renoted: "Boosté."
cantRenote: "Ce message ne peut pas être boosté."
cantReRenote: "Impossible de partager ce boost."
quote: "Citer"
pinnedNote: "Note épinglée"
pinned: "Épingler sur le profil"
@ -117,9 +118,9 @@ reaction: "Réactions"
reactionSetting: "Réactions à afficher dans le sélecteur de réactions"
reactionSettingDescription2: "Déplacer pour réorganiser, cliquer pour effacer, utiliser
« + » pour ajouter."
rememberNoteVisibility: "Activer l'option \" se souvenir de la visibilité des notes
rememberNoteVisibility: "Activer l'option \" se souvenir de la visibilité des posts
\" vous permet de réutiliser automatiquement la visibilité utilisée lors de la publication
de votre note précédente."
de votre post précédent."
attachCancel: "Supprimer le fichier attaché"
markAsSensitive: "Marquer comme sensible"
unmarkAsSensitive: "Supprimer le marquage comme sensible"
@ -175,9 +176,9 @@ proxyAccount: "Compte proxy"
proxyAccountDescription: "Un compte proxy se comporte, dans certaines conditions,
comme un·e abonné·e distant·e pour les utilisateur·rice·s d'autres serveurs. Par
exemple, quand un·e utilisateur·rice local ajoute un·e utilisateur·rice distant·e
à une liste, ses notes ne seront pas visibles sur le serveur si personne ne suit
à une liste, ses posts ne seront pas visibles sur le serveur si personne ne suit
cet·te utilisateur·rice. Le compte proxy va donc suivre cet·te utilisateur·rice
pour que ses notes soient acheminées."
pour que ses posts soient acheminées."
host: "Serveur distant"
selectUser: "Sélectionner un·e utilisateur·rice"
recipient: "Destinataire"
@ -207,7 +208,7 @@ instanceInfo: "Informations du serveur"
statistics: "Statistiques"
clearQueue: "Vider la file dattente"
clearQueueConfirmTitle: "Êtes-vous sûr·e de vouloir vider la file dattente ?"
clearQueueConfirmText: "Les notes non distribuées ne seront pas délivrées. Normalement,
clearQueueConfirmText: "Les posts non distribués ne seront pas délivrés. Normalement,
vous n'avez pas besoin d'effectuer cette opération."
clearCachedFiles: "Vider le cache"
clearCachedFilesConfirm: "Êtes-vous sûr·e de vouloir vider tout le cache de fichiers
@ -220,8 +221,8 @@ mutedUsers: "Utilisateur·rice·s en sourdine"
blockedUsers: "Utilisateur·rice·s bloqué·e·s"
noUsers: "Il ny a pas dutilisateur·rice·s"
editProfile: "Modifier votre profil"
noteDeleteConfirm: "Êtes-vous sûr·e de vouloir supprimer cette note ?"
pinLimitExceeded: "Vous ne pouvez pas épingler plus de notes"
noteDeleteConfirm: "Êtes-vous sûr·e de vouloir supprimer ce post ?"
pinLimitExceeded: "Vous ne pouvez pas épingler plus de posts"
intro: "Linstallation de Firefish est terminée ! Veuillez créer un compte administrateur."
done: "Terminé"
processing: "Traitement en cours"
@ -366,7 +367,7 @@ pinnedPages: "Pages épinglées"
pinnedPagesDescription: "Inscrivez le chemin des Pages que vous souhaitez épingler
en haut de la page du serveur. Séparez les d'un retour à la ligne."
pinnedClipId: "Identifiant du clip épinglé"
pinnedNotes: "Note épinglée"
pinnedNotes: "Posts épinglée"
hcaptcha: "hCaptcha"
enableHcaptcha: "Activer hCaptcha"
hcaptchaSiteKey: "Clé du site"
@ -386,14 +387,14 @@ antennaKeywords: "Mots clés à recevoir"
antennaExcludeKeywords: "Mots clés à exclure"
antennaKeywordsDescription: "Séparer avec des espaces pour la condition AND. Séparer
avec un saut de ligne pour une condition OR."
notifyAntenna: "Je souhaite recevoir les notifications des nouvelles notes"
withFileAntenna: "Notes ayant des attachements uniquement"
notifyAntenna: "Je souhaite recevoir les notifications des nouveaux posts"
withFileAntenna: "Posts ayant des attachements uniquement"
enableServiceworker: "Activer ServiceWorker"
antennaUsersDescription: "Saisissez un seul nom dutilisateur·rice par ligne"
caseSensitive: "Sensible à la casse"
withReplies: "Inclure les réponses"
connectedTo: "Vous êtes connectés aux services suivants"
notesAndReplies: "Notes et Réponses"
notesAndReplies: "Posts et Réponses"
withFiles: "Avec fichiers joints"
silence: "Mettre en sourdine"
silenceConfirm: "Êtes-vous sûr·e de vouloir mettre lutilisateur·rice en sourdine
@ -431,7 +432,7 @@ notFoundDescription: "Aucune page ne correspond à lURL spécifiée."
uploadFolder: "Emplacement de téléversement par défaut"
cacheClear: "Vider le cache"
markAsReadAllNotifications: "Marquer toutes les notifications comme lues"
markAsReadAllUnreadNotes: "Marquer toutes les notes comme lues"
markAsReadAllUnreadNotes: "Marquer tous les posts comme lus"
markAsReadAllTalkMessages: "Marquer toutes les discussions comme lues"
help: "Aide"
inputMessageHere: "Écrivez votre message ici"
@ -452,7 +453,7 @@ text: "Texte"
enable: "Activer"
next: "Suivant"
retype: "Confirmation"
noteOf: "Notes de {user}"
noteOf: "Posts de {user}"
inviteToGroup: "Inviter dans un groupe"
quoteAttached: "Avec citation"
quoteQuestion: "Souhaitez-vous ajouter une citation ?"
@ -512,8 +513,8 @@ accountSettings: "Paramètres du compte"
promotion: "Promu"
promote: "Promouvoir"
numberOfDays: "Nombre de jours"
hideThisNote: "Masquer cette note"
showFeaturedNotesInTimeline: "Afficher les notes des Tendances dans le fil d'actualité"
hideThisNote: "Masquer ce post"
showFeaturedNotesInTimeline: "Afficher les posts des Tendances dans le fil d'actualité"
objectStorage: "Stockage d'objets"
useObjectStorage: "Utiliser le stockage d'objets"
objectStorageBaseUrl: "Base URL"
@ -544,7 +545,7 @@ objectStorageSetPublicRead: "Régler sur « public » lors de l'envoi"
serverLogs: "Journal du serveur"
deleteAll: "Supprimer tout"
showFixedPostForm: "Afficher le formulaire de publication en haut du fil d'actualité"
newNoteRecived: "Voir les nouvelles notes"
newNoteRecived: "Voir les nouveaux posts"
sounds: "Sons"
listen: "Écouter"
none: "Rien"
@ -594,8 +595,8 @@ addRelay: "Ajouter un relais"
inboxUrl: "Inbox URL"
addedRelays: "Relais ajoutés"
serviceworkerInfo: "Devrait être activé pour les notifications push."
deletedNote: "Note supprimée"
invisibleNote: "Note invisible"
deletedNote: "Post supprimé"
invisibleNote: "Post invisible"
enableInfiniteScroll: "Activer le défilement infini"
visibility: "Visibilité"
poll: "Sondage"
@ -680,7 +681,7 @@ abuseReports: "Signalements"
reportAbuse: "Signaler"
reportAbuseOf: "Signaler {name}"
fillAbuseReportDescription: "Veuillez expliquer les raisons du signalement. S'il s'agit
d'une note particulière, veuillez inclure le lien."
d'un post particulier, veuillez inclure le lien."
abuseReported: "Le rapport est envoyé. Merci."
reporter: "Signalé par"
reporteeOrigin: "Origine du signalement"
@ -693,7 +694,7 @@ openInSideView: "Ouvrir en vue latérale"
defaultNavigationBehaviour: "Navigation par défaut"
editTheseSettingsMayBreakAccount: "La modification de ces paramètres peut endommager
votre compte."
instanceTicker: "Nom du serveur d'origine des notes"
instanceTicker: "Nom du serveur d'origine des posts"
waitingFor: "En attente de {x}"
random: "Aléatoire"
system: "Système"
@ -708,11 +709,11 @@ i18nInfo: "Firefish est traduit dans différentes langues par des bénévoles. V
contribuer à {link}."
manageAccessTokens: "Gérer les jetons d'accès"
accountInfo: " Informations du compte "
notesCount: "Nombre de notes"
notesCount: "Nombre de posts"
repliesCount: "Nombre de réponses envoyées"
renotesCount: "Nombre de notes que vous avez renotées"
renotesCount: "Nombre de boosts que vous avez envoyé"
repliedCount: "Nombre de réponses reçues"
renotedCount: "Nombre de vos notes renotées"
renotedCount: "Nombre de vos posts boostés"
followingCount: "Nombre de comptes suivis"
followersCount: "Nombre d'abonnés"
sentReactionsCount: "Nombre de réactions envoyées"
@ -725,9 +726,9 @@ driveFilesCount: "Nombre de fichiers dans le Drive"
driveUsage: "Utilisation du Drive"
noCrawle: "Refuser l'indexation par les robots"
noCrawleDescription: "Demandez aux moteurs de recherche de ne pas indexer votre page
de profil, vos notes, vos pages, etc."
lockedAccountInfo: "À moins que vous ne définissiez la visibilité de votre note sur
\"Abonné-e-s\", vos notes sont visibles par tous, même si vous exigez que les demandes
de profil, vos posts, vos pages, etc."
lockedAccountInfo: "À moins que vous ne définissiez la visibilité de votre post sur
\"Abonné-e-s\", vos posts sont visibles par tous, même si vous exigez que les demandes
d'abonnement soient approuvées manuellement."
alwaysMarkSensitive: "Marquer les médias comme contenu sensible par défaut"
loadRawImages: "Affichage complet des images jointes au lieu des vignettes"
@ -736,7 +737,7 @@ verificationEmailSent: "Un e-mail de vérification a été envoyé. Veuillez acc
lien pour compléter la vérification."
notSet: "Non défini"
emailVerified: "Votre adresse e-mail a été vérifiée."
noteFavoritesCount: "Nombre de notes dans les favoris"
noteFavoritesCount: "Nombre de posts dans les favoris"
pageLikesCount: "Nombre de pages aimées"
pageLikedCount: "Nombre de vos pages aimées"
contact: "Contact"
@ -747,7 +748,7 @@ developer: "Développeur"
makeExplorable: "Rendre le compte visible sur la page \"Découvrir\"."
makeExplorableDescription: "Si vous désactivez cette option, votre compte n'apparaîtra
pas sur la page \"Découvrir\"."
showGapBetweenNotesInTimeline: "Afficher un écart entre les notes du fil dactualité"
showGapBetweenNotesInTimeline: "Afficher un écart entre les posts du fil dactualité"
duplicate: "Duliquer"
left: "Gauche"
center: "Centrer"
@ -760,7 +761,7 @@ showTitlebar: "Afficher la barre de titre"
clearCache: "Vider le cache"
onlineUsersCount: "{n} utilisateur(s) en ligne"
nUsers: "{n} utilisateur·rice·s"
nNotes: "{n} Notes"
nNotes: "{n} Posts"
sendErrorReports: "Envoyer les rapports derreur"
sendErrorReportsDescription: "Si vous activez l'envoi des rapports d'erreur, vous
contribuerez à améliorer la qualité de Firefish grâce au partage d'informations
@ -805,8 +806,8 @@ unlikeConfirm: "Êtes-vous sûr·e de ne plus vouloir aimer cette publication ?"
fullView: "Plein écran"
quitFullView: "Quitter le plein écran"
addDescription: "Ajouter une description"
userPagePinTip: "Vous pouvez afficher des notes ici en sélectionnant l'option « Épingler
au profil » dans le menu de chaque note."
userPagePinTip: "Vous pouvez afficher des posts ici en sélectionnant l'option « Épingler
au profil » dans le menu de chaque post."
notSpecifiedMentionWarning: "Vous avez mentionné des utilisateur·rice·s qui ne font
pas partie de la liste des destinataires"
info: "Informations"
@ -838,7 +839,7 @@ postToGallery: "Publier dans la galerie"
gallery: "Galerie"
recentPosts: "Les plus récentes"
popularPosts: "Les plus consultées"
shareWithNote: "Partager dans une note"
shareWithNote: "Partager dans un post"
ads: "Bannière communautaire"
expiration: "Échéance"
memo: "Pense-bête"
@ -1121,7 +1122,7 @@ _channel:
owned: "Mes canaux"
following: "Abonné·e"
usersCount: "{n} Participant·e·s"
notesCount: "{n} Notes"
notesCount: "{n} Posts"
nameAndDescription: Nom et description
nameOnly: Nom uniquement
_menuDisplay:
@ -1135,20 +1136,20 @@ _wordMute:
un saut de ligne pour une condition OR."
muteWordsDescription2: "Pour utiliser des expressions régulières (regex), mettez
les mots-clés entre barres obliques."
softDescription: "Masquez de votre fil dactualité les notes qui répondent aux conditions
softDescription: "Masquez de votre fil dactualité les posts qui répondent aux conditions
définies."
hardDescription: "Empêche les notes qui remplissent les conditions définies d'être
hardDescription: "Empêche les posts qui remplissent les conditions définies d'être
ajoutées au fil d'actualité. Cette action est irréversible : si vous modifiez
ces conditions plus tard, les notes précédemment filtrées ne seront pas récupérées."
ces conditions plus tard, les posts précédemment filtrées ne seront pas récupérées."
soft: "Doux"
hard: "Strict"
mutedNotes: "Notes filtrées"
mutedNotes: "Posts filtrés"
_instanceMute:
instanceMuteDescription2: "Séparer avec des sauts de lignes"
title: "Masque les notes venant des serveurs listés."
title: "Masque les posts provenant des serveurs listés."
heading: "Serveurs à mettre en sourdine/masquer"
instanceMuteDescription: Ceci va masquer toute publication ou partage de serveurs
listés, incluant celles des personnes répondant à des personnes des serveurs masqués.
instanceMuteDescription: Ceci va masquer toute posts ou boosts de serveurs listés,
incluant celles des personnes répondant à des personnes des serveurs masqués.
_theme:
explore: "Explorer les thèmes"
install: "Installer un thème"
@ -1199,7 +1200,7 @@ _theme:
hashtag: "Hashtags"
mention: "Mentionner"
mentionMe: "Mentions (Moi)"
renote: "Renoter"
renote: "Booster"
modalBg: "Modal d'arrière-plan"
divider: "Séparateur"
scrollbarHandle: "Poignée de la barre de navigation"
@ -1226,8 +1227,8 @@ _theme:
accentLighten: "Plus clair"
fgHighlighted: "Texte mis en évidence"
_sfx:
note: "Nouvelle note"
noteMy: "Ma note"
note: "Nouveau post"
noteMy: "Mon post"
notification: "Notifications"
chat: "Discuter"
chatBg: "Discussion (arrière-plan)"
@ -1254,14 +1255,14 @@ _tutorial:
step1_2: "On va vous installer. Vous serez opérationnel en un rien de temps"
step2_1: "Tout d'abord, remplissez votre profil"
step2_2: "En fournissant quelques informations sur qui vous êtes, il sera plus facile
pour les autres de savoir s'ils veulent voir vos notes ou vous suivre."
pour les autres de savoir s'ils veulent voir vos posts ou vous suivre."
step3_1: "Maintenant il est temps de suivre des gens !"
step3_2: "Vos fil dactualité Principal et Social sont basés sur les personnes que
vous suivez, alors essayez de suivre quelques comptes pour commencer.\nCliquez
sur le cercle plus en haut à droite d'un profil pour le suivre."
step4_1: "On y va."
step4_2: "Pour votre première note, certaines personnes aiment faire une note {introduction}
ou une simple note 'Bonjours tout le monde !'."
step4_2: "Pour votre premier post, certaines personnes aiment faire un post {introduction}
ou un simple 'Bonjours tout le monde !'"
step5_1: "Des fils, des fils dactualité partout !"
step5_2: "Votre serveur a {timelines} fils différents disponibles !"
step5_3: "Le fil {icon} Principal est l'endroit où vous pouvez voir les publications
@ -1334,7 +1335,7 @@ _permissions:
"write:messaging": "Gérer les discussions"
"read:mutes": "Voir les comptes masqués"
"write:mutes": "Gérer les comptes masqués"
"write:notes": "Créer / supprimer des notes"
"write:notes": "Créer / supprimer des posts"
"read:notifications": "Afficher les notifications"
"write:notifications": "Gérer vos notifications"
"read:reactions": "Lire les réactions"
@ -1363,12 +1364,12 @@ _auth:
copyAsk: "Veuillez coller le code dautorisation suivant dans l'application :"
allPermissions: Accès complet au compte
_antennaSources:
all: "Toutes les notes"
homeTimeline: "Notes provenant des utilisateur·rice·s auxquel·les je suis abonné"
users: "Notes venant de la part dutilisateur·rice·s précis"
userList: "Notes venant dune liste spécifique"
userGroup: "Notes venant dutilisateur·rice·s du groupe spécifié"
instances: Notes de tous les utilisateurs d'un serveur
all: "Tous les posts"
homeTimeline: "Posts provenant des utilisateur·rice·s auxquel·les je suis abonné"
users: "Posts venant de la part dutilisateur·rice·s précis"
userList: "Posts venant dune liste spécifique"
userGroup: "Posts venant dutilisateur·rice·s du groupe spécifié"
instances: Posts de tous les utilisateurs d'un serveur
_weekday:
sunday: "Dimanche"
monday: "Lundi"
@ -1401,7 +1402,7 @@ _widgets:
_userList:
chooseList: Sélectionner une liste
unixClock: Horloge UNIX
meiliIndexCount: Notes indexées
meiliIndexCount: Posts indexés
serverInfo: Info serveur
meiliStatus: État du serveur
meiliSize: Taille de lindex
@ -1446,8 +1447,8 @@ _visibility:
localOnly: "Local seulement"
localOnlyDescription: "Caché pour les utilisateur·rice·s distant"
_postForm:
replyPlaceholder: "Répondre à cette note ..."
quotePlaceholder: "Citez cette note ..."
replyPlaceholder: "Répondre à ce post ..."
quotePlaceholder: "Citez ce post ..."
channelPlaceholder: "Publier sur une chaîne…"
_placeholders:
a: "Quoi de neuf ?"
@ -1473,7 +1474,7 @@ _profile:
locationDescription: Si vous entrez votre ville en premier, votre heure locale sera
affichée aux autres utilisateur·rice·s.
_exportOrImport:
allNotes: "Toutes les notes"
allNotes: "Tous les posts"
followingList: "Abonnements"
muteList: "Comptes masqués"
blockingList: "Comptes bloqués"
@ -1486,10 +1487,10 @@ _charts:
usersIncDec: "Variation du nombre d'utilisateur·rice·s"
usersTotal: "Nombre des utilisateur·rice·s au total"
activeUsers: "Nombre d'utilisateurices actif·ve·s"
notesIncDec: "Variation du nombre des notes"
localNotesIncDec: "Variation du nombre de notes locales"
remoteNotesIncDec: "Variation du nombre de notes distantes"
notesTotal: "Nombre total des notes"
notesIncDec: "Variation du nombre de publications"
localNotesIncDec: "Variation du nombre de publications locales"
remoteNotesIncDec: "Variation du nombre de publications distantes"
notesTotal: "Nombre total des publications"
filesIncDec: "Variation du nombre de fichiers"
filesTotal: "Nombre total de fichiers"
storageUsageIncDec: "Variation de l'utilisation du stockage"
@ -1498,8 +1499,8 @@ _instanceCharts:
requests: "Requêtes"
users: "Variation du nombre d'utilisateur·rice·s"
usersTotal: "Total cumulé du nombre d'utilisateur·rice·s"
notes: "Variation du nombre de notes"
notesTotal: "Nombre total cumulé des notes"
notes: "Variation du nombre de publications"
notesTotal: "Nombre total cumulé des publications"
ff: "Variation des abonné·e·s / abonnements"
ffTotal: "Total cumulé du nombre d'abonné·e·s / abonnements"
cacheSize: "Variation de la taille du cache"
@ -1587,10 +1588,10 @@ _pages:
id: "Toile ID"
width: "Largeur"
height: "Hauteur"
note: "Note intégrée"
note: "Post intégré"
_note:
id: "Identifiant de la note"
idDescription: "Vous pouvez aussi coller ici l'URL ici."
id: "Identifiant du post"
idDescription: "Vous pouvez aussi coller l'URL du post ici."
detailed: "Afficher les détails"
switch: "Interrupteur"
_switch:
@ -1813,7 +1814,7 @@ _notification:
youGotMention: "{name} vous a mentionné"
youGotReply: "Réponse de {name}"
youGotQuote: "Cité·e par {name}"
youRenoted: "{name} vous a Renoté"
youRenoted: "{name} vous a boosté"
youGotPoll: "{name} a participé à votre sondage"
youGotMessagingMessageFromUser: "{name} vous envoyé un message"
youGotMessagingMessageFromGroup: "Un message a été envoyé au groupe {name}"
@ -1828,7 +1829,7 @@ _notification:
follow: "Nouvel·le abonné·e"
mention: "Mentions"
reply: "Réponses"
renote: "Renotes"
renote: "Boosts"
quote: "Citations"
reaction: "Réactions"
pollVote: "Votes dans des sondages"
@ -1840,9 +1841,9 @@ _notification:
_actions:
followBack: "Suivre"
reply: "Répondre"
renote: "Renoter"
renote: "Boosts"
reacted: a réagit à votre Note
renoted: a boosté votre Note
renoted: a boosté votre post
voted: a voté pour votre sondage
_deck:
alwaysShowMainColumn: "Toujours afficher la colonne principale"
@ -1931,7 +1932,7 @@ moveAccountDescription: Ce processus est irréversible. Soyez sûr⋅e que vous
un alias pour ce compte sur votre nouveau compte avant de migrer. Merci d'entrer
la mention du compte formaté comme ceci @personne@server.com
moveAccount: Déplacer le compte !
seperateRenoteQuote: Séparer les renotes et les boutons de citation
seperateRenoteQuote: Séparer les boutons de boosts et de citation
failedToFetchAccountInformation: Impossible de récupérer les informations de compte
noEmailServerWarning: Serveur mail non configuré.
deleteAccount: Supprimer le compte
@ -2002,7 +2003,7 @@ forwardReportIsAnonymous: À la place de votre compte, un compte système anonym
affiché comme rapporteur au serveur distant.
noThankYou: Non merci
addInstance: Ajouter un serveur
renoteMute: Mettre en silence les renotes
renoteMute: Masquer les boosts
flagSpeakAsCat: Parler comme un chat
flagSpeakAsCatDescription: Vos messages seront nyanifiés en mode chat
hiddenTags: Hashtags cachés
@ -2059,14 +2060,14 @@ pushNotificationAlreadySubscribed: Notifications push déjà activées
logoImageUrl: URL de l'image du logo
moveToLabel: 'Compte vers lequel vous migrez:'
moveFrom: Migrer vers ce compte depuis un ancien compte
defaultReaction: Émoji de réaction par défaut pour les notes entrantes et sortantes
defaultReaction: Émoji de réaction par défaut pour les posts entrants et sortants
license: Licence
indexPosts: Indexer les Notes
indexPosts: Indexer les Posts
indexNotice: Indexation en cours. Cela prendra certainement du temps, veuillez ne
pas redémarrer votre serveur pour au moins une heure.
customKaTeXMacro: Macros KaTeX personnalisées
enableCustomKaTeXMacro: Activer les macros KaTeX personnalisées
noteId: ID de Note
noteId: ID des Posts
customKaTeXMacroDescription: "Définissez des macros pour écrire des expressions mathématiques
simplement ! La notation se conforme aux définitions de commandes LaTeX et s'écrit
\\newcommand{\\·name}{content} ou \\newcommand{\\name}[number of arguments]{content}.
@ -2085,7 +2086,7 @@ deleted: Effacé
editNote: Modifier note
edited: 'Modifié à {date} {time}'
flagShowTimelineRepliesDescription: Si activé, affiche dans le fil les réponses des
utilisatieur·rice·s aux notes des autres.
utilisatieur·rice·s aux posts des autres.
_experiments:
alpha: Alpha
beta: Beta
@ -2096,21 +2097,21 @@ _experiments:
peut entraîner des ralentissements lors du chargement si votre file d'attente
est congestionnée.
findOtherInstance: Trouver un autre serveur
userSaysSomethingReasonQuote: '{name} a cité une note contenant {reason}'
userSaysSomethingReasonQuote: '{name} a cité un post contenant {reason}'
signupsDisabled: Les inscriptions sur ce serveur sont actuellement désactivés, mais
vous pouvez toujours vous inscrire sur un autre serveur ! Si vous avez un code d'invitation
pour ce serveur, entrez-le ci-dessous s'il vous plait.
apps: Applications
userSaysSomethingReasonReply: '{noms} a répondu à une note contenant {raison}'
userSaysSomethingReasonReply: '{noms} a répondu à un post contenant {raison}'
defaultValueIs: 'défaut: {valeur}'
searchPlaceholder: Recherchez sur Firefish
removeReaction: Retirer votre réaction
selectChannel: Sélectionner une chaîne
expandOnNoteClick: Ouvrir la note en cliquant
expandOnNoteClick: Ouvrir le post en cliquant
preventAiLearning: Empêcher le récupération de données par des IA
listsDesc: Les listes vous laissent créer des fils personnalisés avec des utilisateur·rice·s
spécifié·e·s. Elles sont accessibles depuis la page des fils.
indexFromDescription: Laisser vide pour indexer toutes les Notes
indexFromDescription: Laisser vide pour indexer toutes les Posts
_feeds:
jsonFeed: flux JSON
atom: Atom
@ -2118,9 +2119,9 @@ _feeds:
rss: RSS
alt: ALT
swipeOnMobile: Permettre le balayage entre les pages
expandOnNoteClickDesc: Si désactivé, vous pourrez toujours ouvrir les Notes dans le
expandOnNoteClickDesc: Si désactivé, vous pourrez toujours ouvrir les posts dans le
menu du clic droit et en cliquant sur lhorodatage.
indexFrom: Indexer à partir de lID des Notes
indexFrom: Indexer à partir de lID des Posts
older: plus ancien
newer: plus récent
accessibility: Accessibilité
@ -2128,7 +2129,7 @@ silencedInstancesDescription: Listez les noms de domaine de serveurs que vous vo
masquer. Les comptes des serveurs listés seront traités comme "Masqués", ne pourront
faire que des demandes dabonnement, et ne pourront pas mentionner les comptes locaux
si non-suivis. Cela naffectera en rien les serveurs bloqués.
antennasDesc: "Les Antennes affichent de nouvelles notes selon les critères que vous
antennasDesc: "Les Antennes affichent de nouveaux posts selon les critères que vous
indiqués.\nElles peuvent être consultées depuis la page des fils."
image: Image
video: Vidéo
@ -2138,10 +2139,10 @@ cw: Avertissement de contenu
xl: XL
reflectMayTakeTime: Il pourra sécouler un certain temps avant que les changements
ne soient reflétés.
userSaysSomethingReasonRenote: '{name} a boosté une note contenant {reason}'
userSaysSomethingReasonRenote: '{name} a boosté un post contenant {reason}'
sendModMail: Envoyer un avis à la modération
clipsDesc: Les clips sont comme des favoris catégorisés pouvant être partagés. Vous
pouvez créer des clips à partir du menu de chaque note.
pouvez créer des clips à partir du menu de chaque post.
unclip: Dé-clipper
secureMode: Mode sécurisé (Authorized Fetch)
secureModeInfo: Quand sollicité depuis d'autres serveurs, ne pas répondre sans preuve.
@ -2174,8 +2175,8 @@ isPatron: Mécène Firefish
_filters:
fromUser: De lutilisateur
withFile: Avec fichier
notesBefore: Notes avant
notesAfter: Notes après
notesBefore: Posts avant
notesAfter: Posts après
followersOnly: Abonnés uniquement
followingOnly: Abonnements uniquement
fromDomain: Du domaine

View file

@ -1,5 +1,6 @@
_lang_: "Bahasa Indonesia"
headlineFirefish: "Jaringan terhubung melalui catatan"
headlineFirefish: "Platform media sosial sumber terbuka dan terdesentralisasi yang
merdeka sepenuhnya! 🚀"
introFirefish: "Selamat datang! Firefish adalah media sosial sumber terbuka dan terdesentralisasi
yang selamanya bebas! 🚀"
monthAndDay: "{day} {month}"
@ -93,7 +94,7 @@ youShouldUpgradeClient: "Untuk melihat halaman ini, mohon muat ulang untuk memut
enterListName: "Masukkan nama daftar"
privacy: "Privasi"
makeFollowManuallyApprove: "Permintaan mengikuti membutuhkan persetujuan"
defaultNoteVisibility: "Privasi bawaan catatan"
defaultNoteVisibility: "Visibilitas bawaan"
follow: "Ikuti"
followRequest: "Permintaan Mengikuti"
followRequests: "Permintaan mengikuti"
@ -743,7 +744,7 @@ developer: "Pengembang"
makeExplorable: "Buat akun tampil di \"Jelajahi\""
makeExplorableDescription: "Jika kamu menonaktifkan ini, akun kamu tidak akan muncul
di bagian \"Jelajahi\"."
showGapBetweenNotesInTimeline: "Tampilkan jarak diantara catatan pada linimasa"
showGapBetweenNotesInTimeline: "Tampilkan jarak diantara postingan pada linimasa"
duplicate: "Duplikat"
left: "Kiri"
center: "Tengah"
@ -1245,8 +1246,7 @@ _tutorial:
step1_2: "Ayo siapkan. Lekas mulai tanpa basa-basi!"
step1_3: "Linimasa kamu kosong, karena kamu belum mencatat catatan apapun atau mengikuti
siapapun."
step2_1: "Selesaikan menyetel profilmu sebelum menulis sebuah catatan atau mengikuti
seseorang."
step2_1: "Pertama, isi profilmu lebih dahulu."
step2_2: "Menyediakan beberapa informasi tentang siapa kamu akan membuatnya lebih
mudah bagi orang lain untuk menentukan jika mereka ingin postinganmu atau mengikutimu."
step3_1: "Sekarang saatnya mengikuti beberapa orang!"
@ -1558,7 +1558,7 @@ _pages:
if: "Jika"
_if:
variable: "Variabel"
post: "Buat catatan"
post: "Formulir posting"
_post:
text: "Isi"
attachCanvasImage: "Posting dengan kanvas sebagai gambar"

View file

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

View file

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

View file

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

View file

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

View file

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

View file

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

View file

@ -174,7 +174,7 @@ export default async (
// rome-ignore lint/suspicious/noAsyncPromiseExecutor: FIXME
new Promise<Note>(async (res, rej) => {
const dontFederateInitially =
data.localOnly || data.visibility === "hidden";
data.localOnly || data.visibility?.startsWith("hidden");
// If you reply outside the channel, match the scope of the target.
// TODO (I think it's a process that could be done on the client side, but it's server side for now.)
@ -208,7 +208,8 @@ export default async (
if (data.channel != null) data.visibility = "public";
if (data.channel != null) data.visibleUsers = [];
if (data.channel != null) data.localOnly = true;
if (data.visibility === "hidden") data.visibility = "public";
if (data.visibility.startsWith("hidden"))
data.visibility = data.visibility.slice(6);
// enforce silent clients on server
if (

View file

@ -430,7 +430,6 @@ function chooseUser() {
onUpdated(() => {
setPosition();
items.value = suggests.value?.children ?? [];
selectNext();
});
onMounted(() => {
@ -449,7 +448,6 @@ onMounted(() => {
exec();
});
},
{ immediate: true },
);
});
});

View file

@ -132,7 +132,7 @@ export default defineComponent({
display: none;
}
> *:not(:last-child) {
&:not(.date-separated-list-nogap) > *:not(:last-child) {
margin-bottom: var(--margin);
}

View file

@ -5,14 +5,15 @@
/></template>
<MkSpacer :content-max="800">
<MkPagination
ref="paginationEl"
v-slot="{ items }"
:pagination="pagination"
class="ruryvtyk _content"
class="ruryvtyk _gaps_m"
>
<section
v-for="(announcement, i) in items"
v-for="announcement in items"
:key="announcement.id"
class="_card announcement"
class="announcement _panel"
>
<div class="_title">
<span v-if="$i && !announcement.isRead">🆕 </span>
@ -31,7 +32,7 @@
/>
</div>
<div v-if="$i && !announcement.isRead" class="_footer">
<MkButton primary @click="read(items, announcement, i)"
<MkButton primary @click="read(announcement.id)"
><i class="ph-check ph-bold ph-lg"></i>
{{ i18n.ts.gotIt }}</MkButton
>
@ -43,7 +44,7 @@
</template>
<script lang="ts" setup>
import {} from "vue";
import { ref } from "vue";
import MkPagination from "@/components/MkPagination.vue";
import MkButton from "@/components/MkButton.vue";
import * as os from "@/os";
@ -55,13 +56,14 @@ const pagination = {
limit: 10,
};
// TODO:
function read(items, announcement, i) {
items[i] = {
...announcement,
isRead: true,
};
os.api("i/read-announcement", { announcementId: announcement.id });
const paginationEl = ref<InstanceType<typeof MkPagination>>();
function read(id: string) {
if (!paginationEl.value) return;
paginationEl.value.updateItem(id, (announcement) => {
announcement.isRead = true;
return announcement;
});
os.api("i/read-announcement", { announcementId: id });
}
const headerActions = $computed(() => []);

View file

@ -46,6 +46,8 @@ html {
tab-size: 2;
scroll-padding: 60px;
overflow-x: clip;
text-size-adjust: none;
-webkit-text-size-adjust: none;
&.useCJKFont {
font-family: "Hiragino Maru Gothic Pro", "BIZ UDGothic", Roboto,