diff --git a/mastodon/src/main/java/org/joinmastodon/android/MainActivity.java b/mastodon/src/main/java/org/joinmastodon/android/MainActivity.java index 62a85a6774..3da691e008 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/MainActivity.java +++ b/mastodon/src/main/java/org/joinmastodon/android/MainActivity.java @@ -51,50 +51,7 @@ protected void onCreate(@Nullable Bundle savedInstanceState){ super.onCreate(savedInstanceState); if(savedInstanceState==null){ - if(AccountSessionManager.getInstance().getLoggedInAccounts().isEmpty()){ - showFragmentClearingBackStack(new CustomWelcomeFragment()); - }else{ - AccountSession session; - Bundle args=new Bundle(); - Intent intent=getIntent(); - if(intent.hasExtra("fromExternalShare")) { - AccountSessionManager.getInstance() - .setLastActiveAccountID(intent.getStringExtra("account")); - AccountSessionManager.getInstance().maybeUpdateLocalInfo( - AccountSessionManager.getInstance().getLastActiveAccount()); - showFragmentForExternalShare(intent.getExtras()); - return; - } - - boolean fromNotification = intent.getBooleanExtra("fromNotification", false); - boolean hasNotification = intent.hasExtra("notification"); - if(fromNotification){ - String accountID=intent.getStringExtra("accountID"); - try{ - session=AccountSessionManager.getInstance().getAccount(accountID); - if(!hasNotification) args.putString("tab", "notifications"); - }catch(IllegalStateException x){ - session=AccountSessionManager.getInstance().getLastActiveAccount(); - } - }else{ - session=AccountSessionManager.getInstance().getLastActiveAccount(); - } - AccountSessionManager.getInstance().maybeUpdateLocalInfo(session); - args.putString("account", session.getID()); - Fragment fragment=session.activated ? new HomeFragment() : new AccountActivationFragment(); - fragment.setArguments(args); - if(fromNotification && hasNotification){ - Notification notification=Parcels.unwrap(intent.getParcelableExtra("notification")); - showFragmentForNotification(notification, session.getID()); - } else if (intent.getBooleanExtra("compose", false)){ - showCompose(); - } else if (Intent.ACTION_VIEW.equals(intent.getAction())){ - handleURL(intent.getData(), null); - } else { - showFragmentClearingBackStack(fragment); - maybeRequestNotificationsPermission(); - } - } + restartHomeFragment(); } if(GithubSelfUpdater.needSelfUpdating()){ @@ -285,4 +242,51 @@ public void onProvideAssistContent(AssistContent assistContent) { Fragment fragment = getCurrentFragment(); if (fragment != null) callFragmentToProvideAssistContent(fragment, assistContent); } + + public void restartHomeFragment(){ + if(AccountSessionManager.getInstance().getLoggedInAccounts().isEmpty()){ + showFragmentClearingBackStack(new CustomWelcomeFragment()); + }else{ + AccountSession session; + Bundle args=new Bundle(); + Intent intent=getIntent(); + if(intent.hasExtra("fromExternalShare")) { + AccountSessionManager.getInstance() + .setLastActiveAccountID(intent.getStringExtra("account")); + AccountSessionManager.getInstance().maybeUpdateLocalInfo( + AccountSessionManager.getInstance().getLastActiveAccount()); + showFragmentForExternalShare(intent.getExtras()); + return; + } + + boolean fromNotification = intent.getBooleanExtra("fromNotification", false); + boolean hasNotification = intent.hasExtra("notification"); + if(fromNotification){ + String accountID=intent.getStringExtra("accountID"); + try{ + session=AccountSessionManager.getInstance().getAccount(accountID); + if(!hasNotification) args.putString("tab", "notifications"); + }catch(IllegalStateException x){ + session=AccountSessionManager.getInstance().getLastActiveAccount(); + } + }else{ + session=AccountSessionManager.getInstance().getLastActiveAccount(); + } + AccountSessionManager.getInstance().maybeUpdateLocalInfo(session); + args.putString("account", session.getID()); + Fragment fragment=session.activated ? new HomeFragment() : new AccountActivationFragment(); + fragment.setArguments(args); + if(fromNotification && hasNotification){ + Notification notification=Parcels.unwrap(intent.getParcelableExtra("notification")); + showFragmentForNotification(notification, session.getID()); + } else if (intent.getBooleanExtra("compose", false)){ + showCompose(); + } else if (Intent.ACTION_VIEW.equals(intent.getAction())){ + handleURL(intent.getData(), null); + } else { + showFragmentClearingBackStack(fragment); + maybeRequestNotificationsPermission(); + } + } + } } diff --git a/mastodon/src/main/java/org/joinmastodon/android/fragments/onboarding/AccountActivationFragment.java b/mastodon/src/main/java/org/joinmastodon/android/fragments/onboarding/AccountActivationFragment.java index 6395cc415a..75325ad4a6 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/fragments/onboarding/AccountActivationFragment.java +++ b/mastodon/src/main/java/org/joinmastodon/android/fragments/onboarding/AccountActivationFragment.java @@ -165,9 +165,7 @@ public void onError(ErrorResponse error){ private void tryGetAccount(){ if(AccountSessionManager.getInstance().tryGetAccount(accountID)==null){ uiHandler.removeCallbacks(pollRunnable); - getActivity().finish(); - Intent intent=new Intent(getActivity(), MainActivity.class); - startActivity(intent); + ((MainActivity)getActivity()).restartHomeFragment(); return; } currentRequest=new GetOwnAccount() diff --git a/mastodon/src/main/java/org/joinmastodon/android/fragments/settings/SettingsMainFragment.java b/mastodon/src/main/java/org/joinmastodon/android/fragments/settings/SettingsMainFragment.java index b2270001b9..88a608defc 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/fragments/settings/SettingsMainFragment.java +++ b/mastodon/src/main/java/org/joinmastodon/android/fragments/settings/SettingsMainFragment.java @@ -163,9 +163,7 @@ private void onLogOutClick(){ .setMessage(getString(R.string.confirm_log_out, session.getFullUsername())) .setPositiveButton(R.string.log_out, (dialog, which)->account.logOut(getActivity(), ()->{ loggedOut=true; - getActivity().finish(); - Intent intent=new Intent(getActivity(), MainActivity.class); - startActivity(intent); + ((MainActivity)getActivity()).restartHomeFragment(); })) .setNegativeButton(R.string.cancel, null) .show(); diff --git a/mastodon/src/main/java/org/joinmastodon/android/model/EmojiCategory.java b/mastodon/src/main/java/org/joinmastodon/android/model/EmojiCategory.java index 902a60eb28..95eaadf282 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/model/EmojiCategory.java +++ b/mastodon/src/main/java/org/joinmastodon/android/model/EmojiCategory.java @@ -1,5 +1,6 @@ package org.joinmastodon.android.model; +import java.util.ArrayList; import java.util.List; public class EmojiCategory{ @@ -10,4 +11,8 @@ public EmojiCategory(String title, List emojis){ this.title=title; this.emojis=emojis; } + public EmojiCategory(EmojiCategory category){ + this.title = category.title; + this.emojis = new ArrayList<>(category.emojis); + } } diff --git a/mastodon/src/main/java/org/joinmastodon/android/ui/AccountSwitcherSheet.java b/mastodon/src/main/java/org/joinmastodon/android/ui/AccountSwitcherSheet.java index 7cd2b848d8..7e0b1a2ff3 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/ui/AccountSwitcherSheet.java +++ b/mastodon/src/main/java/org/joinmastodon/android/ui/AccountSwitcherSheet.java @@ -8,6 +8,7 @@ import android.graphics.drawable.ColorDrawable; import android.graphics.drawable.Drawable; import android.os.Build; +import android.os.Bundle; import android.view.View; import android.view.ViewGroup; import android.view.WindowInsets; @@ -39,6 +40,7 @@ import androidx.annotation.Nullable; import androidx.annotation.StringRes; import androidx.recyclerview.widget.LinearLayoutManager; +import me.grishka.appkit.FragmentStackActivity; import me.grishka.appkit.Nav; import me.grishka.appkit.api.Callback; import me.grishka.appkit.api.ErrorResponse; @@ -145,21 +147,10 @@ private void confirmLogOutAll(){ } private void logOut(String accountID){ - AccountSession session=AccountSessionManager.getInstance().getAccount(accountID); - new RevokeOauthToken(session.app.clientId, session.app.clientSecret, session.token.accessToken) - .setCallback(new Callback<>(){ - @Override - public void onSuccess(Object result){ - onLoggedOut(accountID); - } - - @Override - public void onError(ErrorResponse error){ - onLoggedOut(accountID); - } - }) - .wrapProgress(activity, R.string.loading, false) - .exec(accountID); + AccountSessionManager.get(accountID).logOut(activity, ()->{ + dismiss(); + ((MainActivity)activity).restartHomeFragment(); + }); } private void logOutAll(){ @@ -327,15 +318,15 @@ private void onExtraBtnClick(View view) { @Override public void onClick(){ setOnDismissListener(null); + dismiss(); if (onClick != null) { - dismiss(); onClick.accept(item.getID(), false); return; } - if(AccountSessionManager.getInstance().tryGetAccount(item.getID())!=null) + if(AccountSessionManager.getInstance().tryGetAccount(item.getID())!=null){ AccountSessionManager.getInstance().setLastActiveAccountID(item.getID()); - activity.finish(); - activity.startActivity(new Intent(activity, MainActivity.class)); + ((MainActivity)activity).restartHomeFragment(); + } } @Override diff --git a/mastodon/src/main/java/org/joinmastodon/android/ui/CustomEmojiPopupKeyboard.java b/mastodon/src/main/java/org/joinmastodon/android/ui/CustomEmojiPopupKeyboard.java index ccf983a29b..5485e3b4da 100644 --- a/mastodon/src/main/java/org/joinmastodon/android/ui/CustomEmojiPopupKeyboard.java +++ b/mastodon/src/main/java/org/joinmastodon/android/ui/CustomEmojiPopupKeyboard.java @@ -17,6 +17,8 @@ import android.view.ViewGroup; import android.view.inputmethod.InputMethodManager; import android.widget.EditText; +import android.widget.Filter; +import android.widget.Filterable; import android.widget.FrameLayout; import android.widget.ImageButton; import android.widget.ImageView; @@ -35,6 +37,7 @@ import org.joinmastodon.android.model.EmojiCategory; import org.joinmastodon.android.ui.utils.UiUtils; +import java.util.ArrayList; import java.util.ArrayList; import java.util.Comparator; import java.util.List; @@ -158,43 +161,52 @@ public boolean onInterceptTouchEvent(MotionEvent e){ ll.addView(list, new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, 0, 1f)); - FrameLayout bottomPanel=new FrameLayout(activity); - bottomPanel.setPadding(V.dp(16), V.dp(8), V.dp(16), V.dp(8)); - bottomPanel.setBackgroundResource(R.drawable.bg_m3_surface2); - ll.addView(bottomPanel, new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT)); - if(forReaction){ - InputMethodManager imm=(InputMethodManager) activity.getSystemService(Context.INPUT_METHOD_SERVICE); + FrameLayout topPanel=new FrameLayout(activity); + topPanel.setPadding(V.dp(16), V.dp(12), V.dp(16), V.dp(12)); + topPanel.setBackgroundResource(R.drawable.bg_m3_surface2); + ll.addView(topPanel, 0, new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT)); - // TODO: support filtering custom emoji + InputMethodManager imm=(InputMethodManager) activity.getSystemService(Context.INPUT_METHOD_SERVICE); EditText input=new EditText(activity); input.setHint(R.string.sk_enter_emoji_hint); input.addTextChangedListener(new TextWatcher() { @Override - public void onTextChanged(CharSequence s, int start, int before, int count) { - if (!s.toString().isEmpty()) { - if (emojiRegex.matcher(s.toString()).find()) { + public void onTextChanged(CharSequence s, int start, int before, int count){ + // Only check the emoji regex if the text field was empty before + if(start == 0){ + if(emojiRegex.matcher(s.toString()).find()){ imm.hideSoftInputFromWindow(input.getWindowToken(), 0); listener.onEmojiSelected(s.toString().substring(before)); input.getText().clear(); - } else { - Toast.makeText(activity, R.string.sk_enter_emoji_toast, Toast.LENGTH_SHORT).show(); - input.getText().clear(); } } + for(int i=0; i implements ImageLoaderRecyclerAdapter{ - private final EmojiCategory category; - private final List requests; + private class SingleCategoryAdapter extends UsableRecyclerView.Adapter implements ImageLoaderRecyclerAdapter, Filterable{ + private EmojiCategory category; + + private final EmojiCategory originalCategory; + private List requests; public SingleCategoryAdapter(EmojiCategory category){ super(imgLoader); this.category=category; + this.originalCategory=new EmojiCategory(category); requests=category.emojis.stream().map(e->new UrlImageLoaderRequest(e.getUrl(playGifs), V.dp(24), V.dp(24))).collect(Collectors.toList()); } @@ -254,17 +269,22 @@ public RecyclerView.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int @Override public void onBindViewHolder(RecyclerView.ViewHolder holder, int position){ + if(category.emojis.size() == 0) { + holder.itemView.setVisibility(View.GONE); + } if(holder instanceof EmojiViewHolder evh){ evh.bind(category.emojis.get(position-1)); evh.positionWithinCategory=position-1; }else if(holder instanceof SectionHeaderViewHolder shvh){ shvh.bind(TextUtils.isEmpty(category.title) ? domain : category.title); } + super.onBindViewHolder(holder, position); } @Override public int getItemCount(){ + if(category.emojis.size() == 0) return 0; return category.emojis.size()+1; } @@ -282,6 +302,39 @@ public int getImageCountForItem(int position){ public ImageLoaderRequest getImageRequest(int position, int image){ return requests.get(position-1); } + + @Override + public Filter getFilter(){ + return emojiFilter; + } + private final Filter emojiFilter = new Filter(){ + @Override + protected FilterResults performFiltering(CharSequence charSequence){ + List filteredEmoji=new ArrayList<>(); + String search=charSequence.toString().toLowerCase().trim(); + + if(charSequence==null || charSequence.length()==0){ + filteredEmoji.addAll(originalCategory.emojis); + }else{ + for(Emoji emoji : originalCategory.emojis){ + if(emoji.shortcode.toLowerCase().contains(search)){ + filteredEmoji.add(emoji); + } + } + + } + FilterResults results=new FilterResults(); + results.values=filteredEmoji; + return results; + } + @Override + protected void publishResults(CharSequence charSequence, FilterResults filterResults){ + category.emojis.clear(); + category.emojis.addAll((List) filterResults.values); + requests=category.emojis.stream().map(e->new UrlImageLoaderRequest(e.getUrl(playGifs), V.dp(24), V.dp(24))).collect(Collectors.toList()); + notifyDataSetChanged(); + } + }; } private class SectionHeaderViewHolder extends BindableViewHolder implements StickyHeadersOverlay.HeaderViewHolder{ diff --git a/mastodon/src/main/res/values-ar/strings_sk.xml b/mastodon/src/main/res/values-ar/strings_sk.xml index 14d38c7a78..9eafdf22e6 100644 --- a/mastodon/src/main/res/values-ar/strings_sk.xml +++ b/mastodon/src/main/res/values-ar/strings_sk.xml @@ -300,4 +300,20 @@ يُرجى إدخال إيموجي ردّا على لا يمكن فتحه في التطبيق + تمكين حذف الإشعارات + أتريد حقا حذف كافة الإشعارات؟ + موجود بالفعل في الفواصل المرجعية + المَورِد غير موجود + أتريد حقا حذف هذا الإشعار؟ + تحرير مسودة أو برمجتها + هذه هي القصص الإخبارية التي يُتَحدّث عنها في خادمكم. + إشعارات المنشورات + هل أنت متأكد من أنك تريد حذف مُسودّة هذا المنشور؟ + لا تُبرمِجه + أتريد حقا مسح لغاتك المُستخدَمة حديثا؟ + هل أنت متأكد من أنك تريد حذف هذا المنشور المُبرمَج؟ + هذه هي المنشورات المثيرة للإهتمام على خادمكم. + هذه هي أحدث المنشورات للأعضاء في فديراليتك. + هذه هي أحدث المنشورات على الشبكة والتي انتقاها مُدراء خادمكم. + برمجة أو تحرير مُسودّة \ No newline at end of file diff --git a/mastodon/src/main/res/values-gl-rES/strings.xml b/mastodon/src/main/res/values-gl-rES/strings.xml index 550afd2608..3eeced4301 100644 --- a/mastodon/src/main/res/values-gl-rES/strings.xml +++ b/mastodon/src/main/res/values-gl-rES/strings.xml @@ -12,6 +12,10 @@ Como resposta a %s Notificacións %s comezou a seguirte + %s enviouche unha solicitude de seguimento + %s marcou como favorita a túa publicación + %s promoveu a túa publicación + Mira os resultados dunha enquisa na que votaches Compartir Axustes Publicar @@ -33,6 +37,7 @@ Seguir Seguindo Editar perfil + Compartir perfil Acalar a %s Deixar de acalar a @%s Bloquear a %s @@ -80,6 +85,10 @@ Queda %d día Quedan %d días + + %,d voto + %,d votos + Pechada Acalar conta Confirma Acalar a %s @@ -98,27 +107,35 @@ Bloqueado Votar Eliminar + Eliminar publicación Tes a certeza de querer eliminar esta publicación? Eliminando… Reproducir música Reproducir Deter + Pechar sesión Engadir conta Procurar Cancelos Novas Para ti + Todo Mencións %d persoa está comentando %d persoas están comentando Denunciar a %s + Cal é o problema con esta publicación? + Cal é o problema con %s? Elixe a mellor coincidencia + Non me gusta Non é algo que queiras ver + É spam Ligazóns perigosas, relacións falsas, ou respostas repetitivas Viola as regras do servidor Descubriches que quebra certas regras en concreto + É outra cousa O problema non entra noutras categorías Que regras foron incumpridas? Elixe todo o que sexa de aplicación @@ -127,8 +144,14 @@ Hai algo máis que creas debamos saber? Comentarios adicionais Enviando a denuncia… + Grazas pola denuncia, investigarémola. + Mentras revisamos esto, podes tomar accións contra %s: Deixar de seguir a %s Deixar de seguir + Non verás as súas publicacións. Poderá seguirte e ver as túas publicacións e non saberá que a silenciaches. + Non vas ver as súas publicacións. Nin verá as túas publicacións nin poderá seguirte. Poderá comprobar que a bloqueaches. + Non queres ver esto? + Aquí tes unhas opcións para controlar o que ves en Mastodon: Volver Nome do servidor ou URL Regras do servidor @@ -155,14 +178,19 @@ Tecnoloxía Mira na caixa de correo + Preme na ligazón que che enviamos para verificar a %s. Agardamos por ti. + Non recibiches unha ligazón? Reenviar Abrir app de email Enviado o email de confirmación + Escribe o que che apeteza Aviso sobre o contido Gardar Engadir texto descritivo Público Só para seguidoras + Só para as mencionadas + Recentes Omitir Novas seguidoras Favoritas @@ -171,8 +199,14 @@ Enquisas Elixir conta Primeiro tes que acceder a Mastodon + + Non podes engadir máis de %d elemento multimedia + Non podes engadir máis de %d elementos multimedia + O ficheiro %s é dun tipo non permitido O ficheiro %1$s supera o límite de %2$s MB + Aparencia + Seguir ao dispositivo Claro Escuro Comportamento @@ -185,6 +219,9 @@ Limpar caché multimedia Mastodon para Android v%1$s (%2$d) Baleiramos a memoria caché + Pechar sesión %s? + A autora marcou este multimedia como sensible. + Ir ao perfil de %s Máis opcións Nova publicación Responder @@ -200,6 +237,7 @@ Visor multimedia Segue a %s Deixaches de seguir a %s + Estás a seguir a %s Solicitaches seguir a %s Abrir nun navegador Agochar promocións de @%s @@ -217,7 +255,13 @@ Produciuse un erro ao gardar o ficheiro Ficheiro gardado Descargando… + Non hai apps para esta acción + Local + Estas son as publicacións en voga en Mastodon. + Estas son as novas historias das que se está a falar en Mastodon. + Estas son as publicacións das usuarias do teu servidor (%s). + Poderían interesarche estas contas en función doutras que segues. Ver novas publicacións Cargar publicacións que faltan Seguir tamén @@ -295,6 +339,7 @@ Benvida outra vez Accede co servidor onde creaches a conta. URL do servidor + Elixiremos un servidor no teu idioma se segues sen seleccionar nada. Calquer idioma Rexistro Instantáneo Revisión manual @@ -307,6 +352,7 @@ Oceanía Non se aceptan novas usuarias Intereses Especiais + Os contrasinais non coinciden Elixe por min Engadir fila Configuración do perfil @@ -315,12 +361,14 @@ Popular en Mastodon Seguir a todas Non aceptar + Resumo: non recollemos nin procesamos nada. Rexeitar %s Biografía Seguindo usuarias… + %1$s non acepta rexistros desde %2$s. Proba outro ou <a>elixe outro servidor</a>. Mostrar igualmente Volver agochar Elixe unha ou varias @@ -333,22 +381,222 @@ Mostrar Agochar Únete a %s + Elixe outro servidor ou Saber máis Benvida a Mastodon Mastodon é unha rede social descentralizada, onde ningunha empresa ten o control. Está formada por moitos servidores independentes comunicándose entre si. Que son os servidores? + Cada conta Mastodon está hospedada nun servidor — cada un coas súas regras, valores e admins. Non importa cal elixas, podes seguir e interactuar con persoas de outros servidores. + Abrindo ligazón… + Esta ligazón non está soportada pola app + Pechar sesión de todas as contas + Pechar sesión de todas as contas? + Volver tentar + Fallou o envío da publicación + %s imaxe + %s vídeo + %s audio + %s ficheiro + Imaxe + Vídeo + Audio + GIF + Ficheiro + %d%% subido + Engadir opción na enquisa + Lonxitude da enquisa + Estilo + Escolla simple + Escolla múltiple + Eliminar opción da enquisa + Estilo da enquisa + Texto Alt + Axuda + Que é o Text Alt? + O Text Alt proporciona descrición das imaxes para as persoas con deficiencias visuais, conexións a internet de baixa calidade ou para engadir contexto ás mesmas.\n\nPodes mellorar a accesibilidade e a comprensión da publicación ao escribir un texto alternativo claro, conciso e obxectivo.\n\n
  • Identifica os elementos importantes
  • \n
  • Inclúe o texto que apareza nas imaxes
  • \n
  • Utiliza sintaxe estándar nas frases
  • \n
  • Evita información redundante
  • \n
  • Céntrate nos elementos principais cando sexan imaxes complexas (como diagramas ou mapas)
+ Editar publicación + Ligazón non verificada + Ver emoji + Atopa as persoas que buscas + Non atopamos nada con estos termos + Idioma + Por defecto + Sistema + Detección do idioma + Non se identificou o idioma + Identificado + Multimedia oculto + Publicación oculta + Denunciar publicación + A conta é doutro servidor. Enviar unha copia anónima da denuncia aló tamén? + Reenviar a %s + Denunciado + Retira o seguimento para non ver máis as súas publicacións na cronoloxía de inicio. + %s foi acalada + Xa bloqueaches a esta usuaria, non tes que facer nada máis ata que revisemos a túa denuncia. + Xa bloqueaches a esta usuaria, non tes que facer nada máis.\n\nGrazas por axudarnos a facer de Mastodon un lugar seguro! + Bloqueaches a %s + Marcar todo como lido + Mostar + Filtros + Vista xeral, regras, moderación + Acerca de %s + Idioma por defecto da publicación + Lembrar engadir Texto Alt + Preguntar antes de deixar de seguir + Preguntar antes de promover + Preguntar antes de borrar publicacións + Deter todo + Apagado + Calquera + Persoas que te seguen + Persoas que segues + Ninguén + Recibir notificacións de + Mencións e respostas + Deter todas as notificacións + + %d semana + %d semanas + + %1$s ás %2$s + hoxe + onte + mañá + Remata en %s + As notificacións volven %s. + Reactivar agora + Ir aos axustes das notificacións + Acerca de + Regras + Administración + Mensaxe a Admin + Activar notificacións nos axustes do dispositivo para ver todas as actualizacións. + Máis axustes + Mostrar avisos sobre o contido + Agochar multimedia sensible + Conta das interaccións + Emoji persoal nos nomes públicos + + en %d segundo + en %d segundos + + + en %d minuto + en %d minutos + + + en %d hora + en %d horas + + + fai %d hora + fai %d horas + + O multimedia non ten Texto Alt + + %s das imaxes non ten Alt Text. Publicar? + %s das imaxes non teñen Alt Text. Publicar? + + + %s dos anexos multimedia non ten Alt Text. Publicar? + %s dos anexos multimedia non teñen Alt Text. Publicar? + + Un + Dous + Tres + Catro + Publicar + Deixar de seguir a %s? + Activa + Inactiva + Engadir filtro + Editar filtro + Duración + Palabras acaladas + Acalar desde + Mostrar cun aviso sobre o contido + Mostrar publicacións incluso se cumplen co filtro, pero detrás dun aviso + Eliminar filtro + Para sempre + Remata %s + + %d palabra ou frase acalada + %d palabras ou frases acaladas + + %1$s e %2$s + %1$s, %2$s e %3$s + %1$s,%2$s e outras %3$d + Inicio & listas + Notificacións + Cronoloxías públicas + Conversas & respostas + Perfís + Título + Eliminar filtro \"%s\"? + Vaise eliminar este filtro da túa conta en todos os teus dispositivos. + Engadir palabra para acalar + Editar palabra acalada + Engadir + Palabra ou frase + As palabras non distinguen as maiúsculas e compara a palabra completa.\n\nSe o filtro compara \"Pataca\", agochará tanto \"pataca\" como \"pATaca\" pero non \"patacaza\". + Eliminar palabra \"%s\"? + Escoller + Escoller todo + Duración do filtro + Personalizado + + Eliminar %d palabra? + Eliminar %d palabras? + + + %d seleccionado + %d seleccionados + + Non pode estar baleiro + Xa está na lista + Actualización preparada + Versión %s + Descargando (%d%%) + Concorda co filtro “%s” + Buscar en Mastodon + Limpar todo + Abrir URL en Mastodon + Publicacións con \"%s\" + Ir a %s + Publicacións con “%s” + Persoas con “%s” + fai %d seg. + fai %d min + fai %d horas + hai %d días + Traducir do %s + Traducido do %1$s usando %2$s + Mostrar o orixinal + Fallou a tradución. É posible que a administración non activase a tradución neste servidor ou que o servidor teña unha versión antiga de Mastodon que non ten soporte para a tradución. + Privacidade e alcance + Perfil destacado e publicacións nos algoritmos de descubrimento + Incluír publicacións públicas nos resultados das buscas + + %,d participante + %,d participantes + + + %,d publicación hoxe + %,d publicacións hoxe + diff --git a/mastodon/src/main/res/values-pt-rBR/strings_sk.xml b/mastodon/src/main/res/values-pt-rBR/strings_sk.xml index 244f05b823..02681d0bc1 100644 --- a/mastodon/src/main/res/values-pt-rBR/strings_sk.xml +++ b/mastodon/src/main/res/values-pt-rBR/strings_sk.xml @@ -342,7 +342,7 @@ Duração Reaja com emoji - Você precisa digitar um emoji + Por favor, digite um emoji Digite para reagir com um emoji Toque novamente para Teclado do Sistema 5 minutos @@ -371,4 +371,26 @@ Lixeira de reciclagem Pesquisar Suicídio + Somente quando a publicação for aberta + Ocultar reações de emoji vazias + Mostrar reações com emojis nas linhas do tempo + Sempre mostrar o botão adicionar + Caso você precise de ajuda… + Desativar indicador de guia ativa em forma de comprimido + Início + Mostrar nomes das guias na barra de navegação + Carregar publicações mais antigas + Não mostrar novamente + Encontre uma linha de apoio + Estas são as notícias mais comentadas em seu servidor. + A publicação contém mídia + Carregar publicações mais recentes + Se você está procurando um sinal para não se matar, aqui está. Por favor, caso esteja deprimido e/ou tendo pensamentos suicidas, considere entrar em contato com uma linha de apoio para prevenção do suicídio. + https://findahelpline.com/br + Essas são as publicações que estão ganhando força no seu servidor. + + publicação + publicações + publicações + \ No newline at end of file diff --git a/mastodon/src/main/res/values-ro-rRO/strings_sk.xml b/mastodon/src/main/res/values-ro-rRO/strings_sk.xml index f627d2e0c5..06a7bb3850 100644 --- a/mastodon/src/main/res/values-ro-rRO/strings_sk.xml +++ b/mastodon/src/main/res/values-ro-rRO/strings_sk.xml @@ -363,23 +363,38 @@ Suprapunere audio Permiteți continuarea redării media curente, suprapunând noua redare Ați fost menționați de către %s - Buton \"Arătați postări noi\" - Afișați reacții emoji în cronologii - - Un utilizator a reacționat cu %2$s - %1$,d utilizatori au reacționat cu %2$s - %1$,d utilizatori au reacționat cu %2$s - - Reacționați cu emoji - Trebuie să tastați un emoji - Scrieți pentru a reacționa cu un emoji - Activați reacții emoji - Afișează reacțiile emoji la postări și vă permite să interacționați cu ele. Unele versiuni modificate de Mastodon acceptă acest lucru, dar Mastodon nu. - Apăsați din nou pentru tastatura de sistem + %d secunde + Doar când postarea este deschisă + %d ore + Ascundeți reacțiile emoji goale + Afișați reacțiile emoji în cronologii postare postări postări - Dacă reacțiile emoji ar trebui să fie afișate pe cronologii. Dacă această opțiune este dezactivată, reacțiile emoji vor fi afișate doar atunci când vizualizați o discuție. + Activați reacții emoji + Sinucidere + Încărcați postări mai noi + %d zile + Afișați mereu butonul adăugare + Găsiți o linie de asistență telefonică + Scrieți pentru a reacționa cu un emoji + Nu mai afișați din nou + http://www.antisuicid.com/ + Vă rugăm scrieți un emoji + Acestea sunt postările care prind tracțiune pe serverul tău. + Reacționați cu un emoji + Încărcați postări mai vechi + Afișează reacțiile emoji la postări și vă permite să le adăugați pe ale dumneavoastră. Diferite servere Fedivers acceptă acest lucru, dar Mastodon nu. + Dacă sunteți în pericol… + %d minute + + Un utilizator a reacționat cu %2$s + %1$,d utilizatori au reacționat cu %2$s + %1$,d de utilizatori au reacționat cu %2$s + + Dacă sunteți în căutarea unui semn pentru a nu vă sinucide, acesta este. Vă rugăm să luați în considerare posibilitatea de a apela la o linie telefonică locală de urgență pentru suicid dacă vă aflați în dificultate. + Acestea sunt știrile despre care se vorbește pe serverul tău. + Postare conține media \ No newline at end of file diff --git a/mastodon/src/main/res/values-vi-rVN/strings.xml b/mastodon/src/main/res/values-vi-rVN/strings.xml index 1b74201cfe..b2298ec8d2 100644 --- a/mastodon/src/main/res/values-vi-rVN/strings.xml +++ b/mastodon/src/main/res/values-vi-rVN/strings.xml @@ -559,6 +559,9 @@ Dịch từ %1$s bằng %2$s Bản gốc Dịch không thành công. Có thể quản trị viên chưa bật dịch trên máy chủ này hoặc máy chủ này đang chạy phiên bản cũ hơn của Mastodon chưa hỗ trợ dịch. + Riêng tư và tiếp cận + Cho phép khám phá hồ sơ + Cho phép hiện tút công khai trong kết quả tìm kiếm %,d người thảo luận diff --git a/mastodon/src/main/res/values/strings_sk.xml b/mastodon/src/main/res/values/strings_sk.xml index 01d926db1d..6c0ecf7aaf 100644 --- a/mastodon/src/main/res/values/strings_sk.xml +++ b/mastodon/src/main/res/values/strings_sk.xml @@ -363,8 +363,8 @@ %1$,d users reacted with %2$s React with emoji - Please type an emoji - Type to react with an emoji + Please type an emoji + Type an emoji or search custom emoji Duration Indefinite 5 minutes