diff --git a/README.md b/README.md
index 8a5351ec..b86699d0 100755
--- a/README.md
+++ b/README.md
@@ -27,12 +27,12 @@ Version status:  -
- -
- -
- -
- -
- +
+ +
+ +
+ +
+ +
+ +
+ ## We need maintainers!
 
diff --git a/app/src/github/res/values-de/strings.xml b/app/src/github/res/values-de/strings.xml
index 078fa6a8..38331667 100644
--- a/app/src/github/res/values-de/strings.xml
+++ b/app/src/github/res/values-de/strings.xml
@@ -1,6 +1,6 @@
 
 
-    Enable Sentry
-    Sentry is a listener/handler for errors that asynchronously sends out the error/event to Sentry.io
-    Sentry will start on next launch
+    Aktiviere Sentry
+    Sentry ist ein Listener/Handler für Fehler, der den Fehler/das Ereignis asynchron an Sentry.io sendet
+    Sentry startet beim nächsten Start
 
diff --git a/app/src/github/res/values-ko/strings.xml b/app/src/github/res/values-ko/strings.xml
new file mode 100644
index 00000000..272483b2
--- /dev/null
+++ b/app/src/github/res/values-ko/strings.xml
@@ -0,0 +1,6 @@
+
+
+    Sentry 활성화
+    Sentry는 Sentry.io에 오류를 비동기적으로 보내는 오류 처리기입니다
+    Sentry는 다음 출시에 시작됩니다
+
diff --git a/app/src/github/res/values-nl/strings.xml b/app/src/github/res/values-nl/strings.xml
index 078fa6a8..e043c9b9 100644
--- a/app/src/github/res/values-nl/strings.xml
+++ b/app/src/github/res/values-nl/strings.xml
@@ -1,6 +1,6 @@
 
 
-    Enable Sentry
-    Sentry is a listener/handler for errors that asynchronously sends out the error/event to Sentry.io
-    Sentry will start on next launch
+    Sentry inschakelen
+    Sentry is een luister/handler voor fouten die asynchroon de fout/gebeurtenis versturen naar Sentry.io
+    Sentry zal starten bij de volgende lancering
 
diff --git a/app/src/github/res/values-ru/strings.xml b/app/src/github/res/values-ru/strings.xml
index 0de74041..ecd5d235 100644
--- a/app/src/github/res/values-ru/strings.xml
+++ b/app/src/github/res/values-ru/strings.xml
@@ -1,6 +1,6 @@
 
 
-    Включить режим \"часового\"
-    \"Часовой\" - это слушатель/обработчик ошибок, который асинхронно отправляет ошибку/событие на Sentry.io
-    \"Часовой\" будет запущен при следующем запуске
+    Включить Sentry
+    Sentry - это обработчик событий, который асинхронно отправляет сообщения об ошибках/поломках на Sentry.io
+    Sentry включится при следующем запуске приложения
 
diff --git a/app/src/github/res/values-vi/strings.xml b/app/src/github/res/values-vi/strings.xml
index 078fa6a8..8669fe96 100644
--- a/app/src/github/res/values-vi/strings.xml
+++ b/app/src/github/res/values-vi/strings.xml
@@ -1,6 +1,6 @@
 
 
-    Enable Sentry
-    Sentry is a listener/handler for errors that asynchronously sends out the error/event to Sentry.io
-    Sentry will start on next launch
+    Bật Sentry
+    Sentry là một thiết bị nghe/giải quyết cho những lỗi mà gửi những lỗi/sự kiện đến Sentry.io một cách tách biệt
+    Sentry sẽ được bật vào lần khởi động kế tiếp
 
diff --git a/app/src/main/java/awais/instagrabber/activities/MainActivity.java b/app/src/main/java/awais/instagrabber/activities/MainActivity.java
index b981f442..f4aa44d6 100644
--- a/app/src/main/java/awais/instagrabber/activities/MainActivity.java
+++ b/app/src/main/java/awais/instagrabber/activities/MainActivity.java
@@ -702,7 +702,7 @@ public class MainActivity extends BaseLanguageActivity implements FragmentManage
                         Log.e(TAG, "showPostView: ", e);
                     }
                 }
-                Toast.makeText(getApplicationContext(), R.string.post_not_found, Toast.LENGTH_SHORT).show();
+                else Toast.makeText(getApplicationContext(), R.string.post_not_found, Toast.LENGTH_SHORT).show();
                 alertDialog.dismiss();
             }
 
diff --git a/app/src/main/java/awais/instagrabber/fragments/main/ProfileFragment.java b/app/src/main/java/awais/instagrabber/fragments/main/ProfileFragment.java
index 1dca8751..19a3ff14 100644
--- a/app/src/main/java/awais/instagrabber/fragments/main/ProfileFragment.java
+++ b/app/src/main/java/awais/instagrabber/fragments/main/ProfileFragment.java
@@ -917,6 +917,7 @@ public class ProfileFragment extends Fragment implements SwipeRefreshLayout.OnRe
 
     private void setupButtons(final long profileId) {
         profileDetailsBinding.btnTagged.setVisibility(isReallyPrivate() ? View.GONE : View.VISIBLE);
+        profileDetailsBinding.favChip.setVisibility(View.VISIBLE);
         if (isLoggedIn) {
             if (Objects.equals(profileId, myId)) {
                 profileDetailsBinding.btnTagged.setVisibility(View.VISIBLE);
@@ -932,7 +933,6 @@ public class ProfileFragment extends Fragment implements SwipeRefreshLayout.OnRe
             profileDetailsBinding.btnLiked.setVisibility(View.GONE);
             profileDetailsBinding.btnDM.setVisibility(disableDm ? View.GONE : View.VISIBLE);
             profileDetailsBinding.btnFollow.setVisibility(View.VISIBLE);
-            profileDetailsBinding.favChip.setVisibility(View.VISIBLE);
             final Context context = getContext();
             if (context == null) return;
             if (profileModel.getFriendshipStatus().isFollowing() || profileModel.getFriendshipStatus().isFollowedBy()) {
diff --git a/app/src/main/java/awais/instagrabber/fragments/settings/PreferenceKeys.java b/app/src/main/java/awais/instagrabber/fragments/settings/PreferenceKeys.java
deleted file mode 100644
index 878b9678..00000000
--- a/app/src/main/java/awais/instagrabber/fragments/settings/PreferenceKeys.java
+++ /dev/null
@@ -1,40 +0,0 @@
-package awais.instagrabber.fragments.settings;
-
-public final class PreferenceKeys {
-    // new boolean prefs
-    public static final String PREF_ENABLE_DM_NOTIFICATIONS = "enable_dm_notifications";
-    public static final String PREF_ENABLE_DM_AUTO_REFRESH = "enable_dm_auto_refresh";
-    public static final String PREF_ENABLE_DM_AUTO_REFRESH_FREQ_UNIT = "enable_dm_auto_refresh_freq_unit";
-    public static final String PREF_ENABLE_DM_AUTO_REFRESH_FREQ_NUMBER = "enable_dm_auto_refresh_freq_number";
-    public static final String PREF_ENABLE_SENTRY = "enable_sentry";
-    public static final String PREF_TAB_ORDER = "tab_order";
-    public static final String PREF_SHOWN_COUNT_TOOLTIP = "shown_count_tooltip";
-    public static final String PREF_SEARCH_FOCUS_KEYBOARD = "search_focus_keyboard";
-    // string prefs
-    public static final String FOLDER_PATH = "custom_path";
-    public static final String DATE_TIME_FORMAT = "date_time_format";
-    public static final String DATE_TIME_SELECTION = "date_time_selection";
-    public static final String CUSTOM_DATE_TIME_FORMAT = "date_time_custom_format";
-    public static final String APP_THEME = "app_theme_v19";
-    public static final String APP_LANGUAGE = "app_language_v19";
-    public static final String STORY_SORT = "story_sort";
-    // set string prefs
-    public static final String KEYWORD_FILTERS = "keyword_filters";
-    // old boolean prefs
-    public static final String DOWNLOAD_USER_FOLDER = "download_user_folder";
-    public static final String TOGGLE_KEYWORD_FILTER = "toggle_keyword_filter";
-    public static final String DOWNLOAD_PREPEND_USER_NAME = "download_user_name";
-    public static final String PLAY_IN_BACKGROUND = "play_in_background";
-    public static final String FOLDER_SAVE_TO = "saved_to";
-    public static final String AUTOPLAY_VIDEOS = "autoplay_videos";
-    public static final String MUTED_VIDEOS = "muted_videos";
-    public static final String SHOW_CAPTIONS = "show_captions";
-    public static final String CUSTOM_DATE_TIME_FORMAT_ENABLED = "data_time_custom_enabled";
-    public static final String SWAP_DATE_TIME_FORMAT_ENABLED = "swap_date_time_enabled";
-    public static final String MARK_AS_SEEN = "mark_as_seen";
-    public static final String HIDE_MUTED_REELS = "hide_muted_reels";
-    public static final String DM_MARK_AS_SEEN = "dm_mark_as_seen";
-    public static final String CHECK_ACTIVITY = "check_activity";
-    public static final String CHECK_UPDATES = "check_updates";
-    public static final String FLAG_SECURE = "flag_secure";
-}
diff --git a/app/src/main/java/awais/instagrabber/fragments/settings/PreferenceKeys.kt b/app/src/main/java/awais/instagrabber/fragments/settings/PreferenceKeys.kt
new file mode 100644
index 00000000..bdc8a77c
--- /dev/null
+++ b/app/src/main/java/awais/instagrabber/fragments/settings/PreferenceKeys.kt
@@ -0,0 +1,43 @@
+package awais.instagrabber.fragments.settings
+
+object PreferenceKeys {
+    // new boolean prefs
+    const val PREF_ENABLE_DM_NOTIFICATIONS = "enable_dm_notifications"
+    const val PREF_ENABLE_DM_AUTO_REFRESH = "enable_dm_auto_refresh"
+    const val PREF_ENABLE_DM_AUTO_REFRESH_FREQ_UNIT = "enable_dm_auto_refresh_freq_unit"
+    const val PREF_ENABLE_DM_AUTO_REFRESH_FREQ_NUMBER = "enable_dm_auto_refresh_freq_number"
+    const val PREF_ENABLE_SENTRY = "enable_sentry"
+    const val PREF_TAB_ORDER = "tab_order"
+    const val PREF_SHOWN_COUNT_TOOLTIP = "shown_count_tooltip"
+    const val PREF_SEARCH_FOCUS_KEYBOARD = "search_focus_keyboard"
+
+    // string prefs
+    const val FOLDER_PATH = "custom_path"
+    const val DATE_TIME_FORMAT = "date_time_format"
+    const val DATE_TIME_SELECTION = "date_time_selection"
+    const val CUSTOM_DATE_TIME_FORMAT = "date_time_custom_format"
+    const val APP_THEME = "app_theme_v19"
+    const val APP_LANGUAGE = "app_language_v19"
+    const val STORY_SORT = "story_sort"
+
+    // set string prefs
+    const val KEYWORD_FILTERS = "keyword_filters"
+
+    // old boolean prefs
+    const val DOWNLOAD_USER_FOLDER = "download_user_folder"
+    const val TOGGLE_KEYWORD_FILTER = "toggle_keyword_filter"
+    const val DOWNLOAD_PREPEND_USER_NAME = "download_user_name"
+    const val PLAY_IN_BACKGROUND = "play_in_background"
+    const val FOLDER_SAVE_TO = "saved_to"
+    const val AUTOPLAY_VIDEOS = "autoplay_videos"
+    const val MUTED_VIDEOS = "muted_videos"
+    const val SHOW_CAPTIONS = "show_captions"
+    const val CUSTOM_DATE_TIME_FORMAT_ENABLED = "data_time_custom_enabled"
+    const val SWAP_DATE_TIME_FORMAT_ENABLED = "swap_date_time_enabled"
+    const val MARK_AS_SEEN = "mark_as_seen"
+    const val HIDE_MUTED_REELS = "hide_muted_reels"
+    const val DM_MARK_AS_SEEN = "dm_mark_as_seen"
+    const val CHECK_ACTIVITY = "check_activity"
+    const val CHECK_UPDATES = "check_updates"
+    const val FLAG_SECURE = "flag_secure"
+}
\ No newline at end of file
diff --git a/app/src/main/java/awais/instagrabber/utils/Constants.java b/app/src/main/java/awais/instagrabber/utils/Constants.java
deleted file mode 100644
index 357b4c24..00000000
--- a/app/src/main/java/awais/instagrabber/utils/Constants.java
+++ /dev/null
@@ -1,95 +0,0 @@
-package awais.instagrabber.utils;
-
-public final class Constants {
-    public static final String CRASH_REPORT_EMAIL = "barinsta@austinhuang.me";
-
-    // int prefs, do not export
-    public static final String PREV_INSTALL_VERSION = "prevVersion";
-    public static final String BROWSER_UA_CODE = "browser_ua_code";
-    public static final String APP_UA_CODE = "app_ua_code";
-    // never Export
-    public static final String COOKIE = "cookie";
-    // deprecated: public static final String SHOW_QUICK_ACCESS_DIALOG = "show_quick_dlg";
-    public static final String DEVICE_UUID = "device_uuid";
-    public static final String BROWSER_UA = "browser_ua";
-    public static final String APP_UA = "app_ua";
-    //////////////////////// EXTRAS ////////////////////////
-    public static final String EXTRAS_USER = "user";
-    public static final String EXTRAS_HASHTAG = "hashtag";
-    public static final String EXTRAS_LOCATION = "location";
-    public static final String EXTRAS_USERNAME = "username";
-    public static final String EXTRAS_ID = "id";
-    public static final String EXTRAS_POST = "post";
-    public static final String EXTRAS_PROFILE = "profile";
-    public static final String EXTRAS_TYPE = "type";
-    public static final String EXTRAS_NAME = "name";
-    public static final String EXTRAS_STORIES = "stories";
-    public static final String EXTRAS_HIGHLIGHT = "highlight";
-    public static final String EXTRAS_INDEX = "index";
-    public static final String EXTRAS_THREAD_MODEL = "threadModel";
-    public static final String EXTRAS_FOLLOWERS = "followers";
-    public static final String EXTRAS_SHORTCODE = "shortcode";
-    public static final String EXTRAS_END_CURSOR = "endCursor";
-    public static final String FEED = "feed";
-    public static final String FEED_ORDER = "feedOrder";
-
-    // Notification ids
-    public static final int ACTIVITY_NOTIFICATION_ID = 10;
-    public static final int DM_UNREAD_PARENT_NOTIFICATION_ID = 20;
-    public static final int DM_CHECK_NOTIFICATION_ID = 11;
-
-    // see https://github.com/dilame/instagram-private-api/blob/master/src/core/constants.ts
-//    public static final String SUPPORTED_CAPABILITIES = "[ { \"name\": \"SUPPORTED_SDK_VERSIONS\", \"value\":" +
-//            " \"13.0,14.0,15.0,16.0,17.0,18.0,19.0,20.0,21.0,22.0,23.0,24.0,25.0,26.0,27.0,28.0,29.0,30.0,31.0," +
-//            "32.0,33.0,34.0,35.0,36.0,37.0,38.0,39.0,40.0,41.0,42.0,43.0,44.0,45.0,46.0,47.0,48.0,49.0,50.0,51.0," +
-//            "52.0,53.0,54.0,55.0,56.0,57.0,58.0,59.0,60.0,61.0,62.0,63.0,64.0,65.0,66.0\" }, { \"name\": \"FACE_TRACKER_VERSION\", " +
-//            "\"value\": 12 }, { \"name\": \"segmentation\", \"value\": \"segmentation_enabled\" }, { \"name\": \"COMPRESSION\", " +
-//            "\"value\": \"ETC2_COMPRESSION\" }, { \"name\": \"world_tracker\", \"value\": \"world_tracker_enabled\" }, { \"name\": " +
-//            "\"gyroscope\", \"value\": \"gyroscope_enabled\" } ]";
-//    public static final String SIGNATURE_VERSION = "4";
-//    public static final String SIGNATURE_KEY = "9193488027538fd3450b83b7d05286d4ca9599a0f7eeed90d8c85925698a05dc";
-    public static final String BREADCRUMB_KEY = "iN4$aGr0m";
-    public static final int LOGIN_RESULT_CODE = 5000;
-    public static final String SKIPPED_VERSION = "skipped_version";
-    public static final String DEFAULT_TAB = "default_tab";
-    public static final String PREF_DARK_THEME = "dark_theme";
-    public static final String PREF_LIGHT_THEME = "light_theme";
-    public static final String DEFAULT_HASH_TAG_PIC = "https://www.instagram.com/static/images/hashtag/search-hashtag-default-avatar.png/1d8417c9a4f5.png";
-    public static final String SHARED_PREFERENCES_NAME = "settings";
-    public static final String PREF_POSTS_LAYOUT = "posts_layout";
-    public static final String PREF_PROFILE_POSTS_LAYOUT = "profile_posts_layout";
-    public static final String PREF_TOPIC_POSTS_LAYOUT = "topic_posts_layout";
-    public static final String PREF_HASHTAG_POSTS_LAYOUT = "hashtag_posts_layout";
-    public static final String PREF_LOCATION_POSTS_LAYOUT = "location_posts_layout";
-    public static final String PREF_LIKED_POSTS_LAYOUT = "liked_posts_layout";
-    public static final String PREF_TAGGED_POSTS_LAYOUT = "tagged_posts_layout";
-    public static final String PREF_SAVED_POSTS_LAYOUT = "saved_posts_layout";
-    public static final String PREF_EMOJI_VARIANTS = "emoji_variants";
-    public static final String PREF_REACTIONS = "reactions";
-
-    public static final String ACTIVITY_CHANNEL_ID = "activity";
-    public static final String ACTIVITY_CHANNEL_NAME = "Activity";
-    public static final String DOWNLOAD_CHANNEL_ID = "download";
-    public static final String DOWNLOAD_CHANNEL_NAME = "Downloads";
-    public static final String DM_UNREAD_CHANNEL_ID = "dmUnread";
-    public static final String DM_UNREAD_CHANNEL_NAME = "Messages";
-    public static final String SILENT_NOTIFICATIONS_CHANNEL_ID = "silentNotifications";
-    public static final String SILENT_NOTIFICATIONS_CHANNEL_NAME = "Silent notifications";
-
-    public static final String NOTIF_GROUP_NAME = "awais.instagrabber.InstaNotif";
-    public static final String GROUP_KEY_DM = "awais.instagrabber.MESSAGES";
-    public static final String GROUP_KEY_SILENT_NOTIFICATIONS = "awais.instagrabber.SILENT_NOTIFICATIONS";
-
-    public static final int SHOW_ACTIVITY_REQUEST_CODE = 1738;
-    public static final int SHOW_DM_THREAD = 2000;
-    public static final int DM_SYNC_SERVICE_REQUEST_CODE = 3000;
-    public static final int GLOBAL_NETWORK_ERROR_DIALOG_REQUEST_CODE = 7777;
-
-    public static final String ACTION_SHOW_ACTIVITY = "show_activity";
-    public static final String ACTION_SHOW_DM_THREAD = "show_dm_thread";
-
-    public static final String DM_THREAD_ACTION_EXTRA_THREAD_ID = "thread_id";
-    public static final String DM_THREAD_ACTION_EXTRA_THREAD_TITLE = "thread_title";
-
-    public static final String X_IG_APP_ID = "936619743392459";
-}
\ No newline at end of file
diff --git a/app/src/main/java/awais/instagrabber/utils/Constants.kt b/app/src/main/java/awais/instagrabber/utils/Constants.kt
new file mode 100644
index 00000000..8cf96e03
--- /dev/null
+++ b/app/src/main/java/awais/instagrabber/utils/Constants.kt
@@ -0,0 +1,92 @@
+package awais.instagrabber.utils
+
+object Constants {
+    const val CRASH_REPORT_EMAIL = "barinsta@austinhuang.me"
+
+    // int prefs, do not export
+    const val PREV_INSTALL_VERSION = "prevVersion"
+    const val BROWSER_UA_CODE = "browser_ua_code"
+    const val APP_UA_CODE = "app_ua_code"
+
+    // never Export
+    const val COOKIE = "cookie"
+
+    // deprecated: public static final String SHOW_QUICK_ACCESS_DIALOG = "show_quick_dlg";
+    const val DEVICE_UUID = "device_uuid"
+    const val BROWSER_UA = "browser_ua"
+    const val APP_UA = "app_ua"
+
+    //////////////////////// EXTRAS ////////////////////////
+    const val EXTRAS_USER = "user"
+    const val EXTRAS_HASHTAG = "hashtag"
+    const val EXTRAS_LOCATION = "location"
+    const val EXTRAS_USERNAME = "username"
+    const val EXTRAS_ID = "id"
+    const val EXTRAS_POST = "post"
+    const val EXTRAS_PROFILE = "profile"
+    const val EXTRAS_TYPE = "type"
+    const val EXTRAS_NAME = "name"
+    const val EXTRAS_STORIES = "stories"
+    const val EXTRAS_HIGHLIGHT = "highlight"
+    const val EXTRAS_INDEX = "index"
+    const val EXTRAS_THREAD_MODEL = "threadModel"
+    const val EXTRAS_FOLLOWERS = "followers"
+    const val EXTRAS_SHORTCODE = "shortcode"
+    const val EXTRAS_END_CURSOR = "endCursor"
+    const val FEED = "feed"
+    const val FEED_ORDER = "feedOrder"
+
+    // Notification ids
+    const val ACTIVITY_NOTIFICATION_ID = 10
+    const val DM_UNREAD_PARENT_NOTIFICATION_ID = 20
+    const val DM_CHECK_NOTIFICATION_ID = 11
+
+    // see https://github.com/dilame/instagram-private-api/blob/master/src/core/constants.ts
+    //    public static final String SUPPORTED_CAPABILITIES = "[ { \"name\": \"SUPPORTED_SDK_VERSIONS\", \"value\":" +
+    //            " \"13.0,14.0,15.0,16.0,17.0,18.0,19.0,20.0,21.0,22.0,23.0,24.0,25.0,26.0,27.0,28.0,29.0,30.0,31.0," +
+    //            "32.0,33.0,34.0,35.0,36.0,37.0,38.0,39.0,40.0,41.0,42.0,43.0,44.0,45.0,46.0,47.0,48.0,49.0,50.0,51.0," +
+    //            "52.0,53.0,54.0,55.0,56.0,57.0,58.0,59.0,60.0,61.0,62.0,63.0,64.0,65.0,66.0\" }, { \"name\": \"FACE_TRACKER_VERSION\", " +
+    //            "\"value\": 12 }, { \"name\": \"segmentation\", \"value\": \"segmentation_enabled\" }, { \"name\": \"COMPRESSION\", " +
+    //            "\"value\": \"ETC2_COMPRESSION\" }, { \"name\": \"world_tracker\", \"value\": \"world_tracker_enabled\" }, { \"name\": " +
+    //            "\"gyroscope\", \"value\": \"gyroscope_enabled\" } ]";
+    //    public static final String SIGNATURE_VERSION = "4";
+    //    public static final String SIGNATURE_KEY = "9193488027538fd3450b83b7d05286d4ca9599a0f7eeed90d8c85925698a05dc";
+    const val BREADCRUMB_KEY = "iN4\$aGr0m"
+    const val LOGIN_RESULT_CODE = 5000
+    const val SKIPPED_VERSION = "skipped_version"
+    const val DEFAULT_TAB = "default_tab"
+    const val PREF_DARK_THEME = "dark_theme"
+    const val PREF_LIGHT_THEME = "light_theme"
+    const val DEFAULT_HASH_TAG_PIC = "https://www.instagram.com/static/images/hashtag/search-hashtag-default-avatar.png/1d8417c9a4f5.png"
+    const val SHARED_PREFERENCES_NAME = "settings"
+    const val PREF_POSTS_LAYOUT = "posts_layout"
+    const val PREF_PROFILE_POSTS_LAYOUT = "profile_posts_layout"
+    const val PREF_TOPIC_POSTS_LAYOUT = "topic_posts_layout"
+    const val PREF_HASHTAG_POSTS_LAYOUT = "hashtag_posts_layout"
+    const val PREF_LOCATION_POSTS_LAYOUT = "location_posts_layout"
+    const val PREF_LIKED_POSTS_LAYOUT = "liked_posts_layout"
+    const val PREF_TAGGED_POSTS_LAYOUT = "tagged_posts_layout"
+    const val PREF_SAVED_POSTS_LAYOUT = "saved_posts_layout"
+    const val PREF_EMOJI_VARIANTS = "emoji_variants"
+    const val PREF_REACTIONS = "reactions"
+    const val ACTIVITY_CHANNEL_ID = "activity"
+    const val ACTIVITY_CHANNEL_NAME = "Activity"
+    const val DOWNLOAD_CHANNEL_ID = "download"
+    const val DOWNLOAD_CHANNEL_NAME = "Downloads"
+    const val DM_UNREAD_CHANNEL_ID = "dmUnread"
+    const val DM_UNREAD_CHANNEL_NAME = "Messages"
+    const val SILENT_NOTIFICATIONS_CHANNEL_ID = "silentNotifications"
+    const val SILENT_NOTIFICATIONS_CHANNEL_NAME = "Silent notifications"
+    const val NOTIF_GROUP_NAME = "awais.instagrabber.InstaNotif"
+    const val GROUP_KEY_DM = "awais.instagrabber.MESSAGES"
+    const val GROUP_KEY_SILENT_NOTIFICATIONS = "awais.instagrabber.SILENT_NOTIFICATIONS"
+    const val SHOW_ACTIVITY_REQUEST_CODE = 1738
+    const val SHOW_DM_THREAD = 2000
+    const val DM_SYNC_SERVICE_REQUEST_CODE = 3000
+    const val GLOBAL_NETWORK_ERROR_DIALOG_REQUEST_CODE = 7777
+    const val ACTION_SHOW_ACTIVITY = "show_activity"
+    const val ACTION_SHOW_DM_THREAD = "show_dm_thread"
+    const val DM_THREAD_ACTION_EXTRA_THREAD_ID = "thread_id"
+    const val DM_THREAD_ACTION_EXTRA_THREAD_TITLE = "thread_title"
+    const val X_IG_APP_ID = "936619743392459"
+}
\ No newline at end of file
diff --git a/app/src/main/java/awais/instagrabber/utils/ExoplayerUtils.java b/app/src/main/java/awais/instagrabber/utils/ExoplayerUtils.java
deleted file mode 100644
index d942ff59..00000000
--- a/app/src/main/java/awais/instagrabber/utils/ExoplayerUtils.java
+++ /dev/null
@@ -1,26 +0,0 @@
-package awais.instagrabber.utils;
-
-import android.content.Context;
-
-import androidx.annotation.NonNull;
-
-import com.google.android.exoplayer2.database.ExoDatabaseProvider;
-import com.google.android.exoplayer2.source.DefaultMediaSourceFactory;
-import com.google.android.exoplayer2.upstream.DefaultHttpDataSourceFactory;
-import com.google.android.exoplayer2.upstream.cache.CacheDataSource;
-import com.google.android.exoplayer2.upstream.cache.LeastRecentlyUsedCacheEvictor;
-import com.google.android.exoplayer2.upstream.cache.SimpleCache;
-
-public final class ExoplayerUtils {
-    private static final long MAX_CACHE_BYTES = 1048576;
-    private static final LeastRecentlyUsedCacheEvictor cacheEvictor = new LeastRecentlyUsedCacheEvictor(MAX_CACHE_BYTES);
-
-    public static DefaultMediaSourceFactory getCachedMediaSourceFactory(@NonNull final Context context) {
-        final ExoDatabaseProvider exoDatabaseProvider = new ExoDatabaseProvider(context);
-        final SimpleCache simpleCache = new SimpleCache(context.getCacheDir(), cacheEvictor, exoDatabaseProvider);
-        final CacheDataSource.Factory cacheDataSourceFactory = new CacheDataSource.Factory()
-                .setCache(simpleCache)
-                .setUpstreamDataSourceFactory(new DefaultHttpDataSourceFactory());
-        return new DefaultMediaSourceFactory(cacheDataSourceFactory);
-    }
-}
diff --git a/app/src/main/java/awais/instagrabber/utils/ExoplayerUtils.kt b/app/src/main/java/awais/instagrabber/utils/ExoplayerUtils.kt
new file mode 100644
index 00000000..cc09440b
--- /dev/null
+++ b/app/src/main/java/awais/instagrabber/utils/ExoplayerUtils.kt
@@ -0,0 +1,22 @@
+package awais.instagrabber.utils
+
+import android.content.Context
+import com.google.android.exoplayer2.database.ExoDatabaseProvider
+import com.google.android.exoplayer2.source.DefaultMediaSourceFactory
+import com.google.android.exoplayer2.upstream.DefaultHttpDataSourceFactory
+import com.google.android.exoplayer2.upstream.cache.CacheDataSource
+import com.google.android.exoplayer2.upstream.cache.LeastRecentlyUsedCacheEvictor
+import com.google.android.exoplayer2.upstream.cache.SimpleCache
+
+object ExoplayerUtils {
+    private const val MAX_CACHE_BYTES: Long = 1048576
+    private val cacheEvictor = LeastRecentlyUsedCacheEvictor(MAX_CACHE_BYTES)
+    fun getCachedMediaSourceFactory(context: Context): DefaultMediaSourceFactory {
+        val exoDatabaseProvider = ExoDatabaseProvider(context)
+        val simpleCache = SimpleCache(context.cacheDir, cacheEvictor, exoDatabaseProvider)
+        val cacheDataSourceFactory = CacheDataSource.Factory()
+                .setCache(simpleCache)
+                .setUpstreamDataSourceFactory(DefaultHttpDataSourceFactory())
+        return DefaultMediaSourceFactory(cacheDataSourceFactory)
+    }
+}
\ No newline at end of file
diff --git a/app/src/main/java/awais/instagrabber/utils/PasswordUtils.java b/app/src/main/java/awais/instagrabber/utils/PasswordUtils.java
deleted file mode 100644
index 2cc380bc..00000000
--- a/app/src/main/java/awais/instagrabber/utils/PasswordUtils.java
+++ /dev/null
@@ -1,47 +0,0 @@
-package awais.instagrabber.utils;
-
-import android.util.Base64;
-
-import androidx.annotation.NonNull;
-
-import java.security.GeneralSecurityException;
-import java.security.InvalidAlgorithmParameterException;
-import java.security.InvalidKeyException;
-import java.security.NoSuchAlgorithmException;
-
-import javax.crypto.BadPaddingException;
-import javax.crypto.Cipher;
-import javax.crypto.IllegalBlockSizeException;
-import javax.crypto.NoSuchPaddingException;
-import javax.crypto.spec.IvParameterSpec;
-import javax.crypto.spec.SecretKeySpec;
-
-public final class PasswordUtils {
-    private static final String cipherAlgo = "AES";
-    private static final String cipherTran = "AES/CBC/PKCS5Padding";
-
-    public static byte[] dec(final String encrypted, final byte[] keyValue) throws Exception {
-        try {
-            final Cipher cipher = Cipher.getInstance(cipherTran);
-            final SecretKeySpec secretKey = new SecretKeySpec(keyValue, cipherAlgo);
-            cipher.init(Cipher.DECRYPT_MODE, secretKey, new IvParameterSpec(new byte[16]));
-            return cipher.doFinal(Base64.decode(encrypted, Base64.DEFAULT | Base64.NO_PADDING | Base64.NO_WRAP));
-        } catch (NoSuchAlgorithmException | NoSuchPaddingException | InvalidAlgorithmParameterException | InvalidKeyException | BadPaddingException | IllegalBlockSizeException e) {
-            throw new IncorrectPasswordException(e);
-        }
-    }
-
-    public static byte[] enc(@NonNull final String str, final byte[] keyValue) throws Exception {
-        final Cipher cipher = Cipher.getInstance(cipherTran);
-        final SecretKeySpec secretKey = new SecretKeySpec(keyValue, cipherAlgo);
-        cipher.init(Cipher.ENCRYPT_MODE, secretKey, new IvParameterSpec(new byte[16]));
-        final byte[] bytes = cipher.doFinal(str.getBytes());
-        return Base64.encode(bytes, Base64.DEFAULT | Base64.NO_PADDING | Base64.NO_WRAP);
-    }
-
-    public static class IncorrectPasswordException extends Exception {
-        public IncorrectPasswordException(final GeneralSecurityException e) {
-            super(e);
-        }
-    }
-}
diff --git a/app/src/main/java/awais/instagrabber/utils/PasswordUtils.kt b/app/src/main/java/awais/instagrabber/utils/PasswordUtils.kt
new file mode 100644
index 00000000..2d4b13c6
--- /dev/null
+++ b/app/src/main/java/awais/instagrabber/utils/PasswordUtils.kt
@@ -0,0 +1,52 @@
+package awais.instagrabber.utils
+
+import android.util.Base64
+import java.security.GeneralSecurityException
+import java.security.InvalidAlgorithmParameterException
+import java.security.InvalidKeyException
+import java.security.NoSuchAlgorithmException
+import javax.crypto.BadPaddingException
+import javax.crypto.Cipher
+import javax.crypto.IllegalBlockSizeException
+import javax.crypto.NoSuchPaddingException
+import javax.crypto.spec.IvParameterSpec
+import javax.crypto.spec.SecretKeySpec
+
+object PasswordUtils {
+    private const val cipherAlgo = "AES"
+    private const val cipherTran = "AES/CBC/PKCS5Padding"
+    @JvmStatic
+    @Throws(Exception::class)
+    fun dec(encrypted: String?, keyValue: ByteArray?): ByteArray {
+        return try {
+            val cipher = Cipher.getInstance(cipherTran)
+            val secretKey = SecretKeySpec(keyValue, cipherAlgo)
+            cipher.init(Cipher.DECRYPT_MODE, secretKey, IvParameterSpec(ByteArray(16)))
+            cipher.doFinal(Base64.decode(encrypted, Base64.DEFAULT or Base64.NO_PADDING or Base64.NO_WRAP))
+        } catch (e: NoSuchAlgorithmException) {
+            throw IncorrectPasswordException(e)
+        } catch (e: NoSuchPaddingException) {
+            throw IncorrectPasswordException(e)
+        } catch (e: InvalidAlgorithmParameterException) {
+            throw IncorrectPasswordException(e)
+        } catch (e: InvalidKeyException) {
+            throw IncorrectPasswordException(e)
+        } catch (e: BadPaddingException) {
+            throw IncorrectPasswordException(e)
+        } catch (e: IllegalBlockSizeException) {
+            throw IncorrectPasswordException(e)
+        }
+    }
+
+    @JvmStatic
+    @Throws(Exception::class)
+    fun enc(str: String, keyValue: ByteArray?): ByteArray {
+        val cipher = Cipher.getInstance(cipherTran)
+        val secretKey = SecretKeySpec(keyValue, cipherAlgo)
+        cipher.init(Cipher.ENCRYPT_MODE, secretKey, IvParameterSpec(ByteArray(16)))
+        val bytes = cipher.doFinal(str.toByteArray())
+        return Base64.encode(bytes, Base64.DEFAULT or Base64.NO_PADDING or Base64.NO_WRAP)
+    }
+
+    class IncorrectPasswordException(e: GeneralSecurityException?) : Exception(e)
+}
\ No newline at end of file
diff --git a/app/src/main/java/awais/instagrabber/utils/TextUtils.java b/app/src/main/java/awais/instagrabber/utils/TextUtils.java
deleted file mode 100644
index 5df3ac08..00000000
--- a/app/src/main/java/awais/instagrabber/utils/TextUtils.java
+++ /dev/null
@@ -1,122 +0,0 @@
-package awais.instagrabber.utils;
-
-import android.content.Context;
-import android.text.SpannableString;
-import android.text.format.DateFormat;
-import android.text.format.DateUtils;
-import android.text.style.URLSpan;
-import android.util.Patterns;
-
-import androidx.annotation.NonNull;
-
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.Collections;
-import java.util.Date;
-import java.util.List;
-import java.util.Locale;
-import java.util.regex.Matcher;
-import java.util.stream.Collectors;
-
-public final class TextUtils {
-    // extracted from String class
-    public static int indexOfChar(@NonNull final CharSequence sequence, final int ch, final int startIndex) {
-        final int max = sequence.length();
-        if (startIndex < max) {
-            if (ch < Character.MIN_SUPPLEMENTARY_CODE_POINT) {
-                for (int i = startIndex; i < max; i++) if (sequence.charAt(i) == ch) return i;
-            } else if (Character.isValidCodePoint(ch)) {
-                final char hi = (char) ((ch >>> 10) + (Character.MIN_HIGH_SURROGATE - (Character.MIN_SUPPLEMENTARY_CODE_POINT >>> 10)));
-                final char lo = (char) ((ch & 0x3ff) + Character.MIN_LOW_SURROGATE);
-                for (int i = startIndex; i < max; i++)
-                    if (sequence.charAt(i) == hi && sequence.charAt(i + 1) == lo) return i;
-            }
-        }
-        return -1;
-    }
-
-    public static CharSequence getSpannableUrl(final String url) {
-        if (isEmpty(url)) return url;
-        final int httpIndex = url.indexOf("http:");
-        final int httpsIndex = url.indexOf("https:");
-        if (httpIndex == -1 && httpsIndex == -1) return url;
-
-        final int length = url.length();
-
-        final int startIndex = httpIndex != -1 ? httpIndex : httpsIndex;
-        final int spaceIndex = url.indexOf(' ', startIndex + 1);
-
-        final int endIndex = (spaceIndex != -1 ? spaceIndex : length);
-
-        final String extractUrl = url.substring(startIndex, Math.min(length, endIndex));
-
-        final SpannableString spannableString = new SpannableString(url);
-        spannableString.setSpan(new URLSpan(extractUrl), startIndex, endIndex, 0);
-
-        return spannableString;
-    }
-
-    public static boolean isEmpty(final CharSequence charSequence) {
-        if (charSequence == null || charSequence.length() < 1) return true;
-        if (charSequence instanceof String) {
-            String str = (String) charSequence;
-            if ("".equals(str) || "null".equals(str) || str.isEmpty()) return true;
-            str = str.trim();
-            return "".equals(str) || "null".equals(str) || str.isEmpty();
-        }
-        return "null".contentEquals(charSequence) || "".contentEquals(charSequence);
-    }
-
-    public static String millisToTimeString(final long millis) {
-        return millisToTimeString(millis, false);
-    }
-
-    public static String millisToTimeString(final long millis, final boolean includeHoursAlways) {
-        final int sec = (int) (millis / 1000) % 60;
-        int min = (int) (millis / (1000 * 60));
-        if (min >= 60) {
-            min = (int) ((millis / (1000 * 60)) % 60);
-            final int hr = (int) ((millis / (1000 * 60 * 60)) % 24);
-            return String.format(Locale.ENGLISH, "%02d:%02d:%02d", hr, min, sec);
-        }
-        if (includeHoursAlways) {
-            return String.format(Locale.ENGLISH, "%02d:%02d:%02d", 0, min, sec);
-        }
-        return String.format(Locale.ENGLISH, "%02d:%02d", min, sec);
-    }
-
-    public static String getRelativeDateTimeString(final Context context, final long from) {
-        final Date now = new Date();
-        final Date then = new Date(from);
-        int days = daysBetween(from, now.getTime());
-        if (days == 0) {
-            return DateFormat.getTimeFormat(context).format(then);
-        }
-        return DateFormat.getDateFormat(context).format(then);
-    }
-
-    private static int daysBetween(long d1, long d2) {
-        return (int) ((d2 - d1) / DateUtils.DAY_IN_MILLIS);
-    }
-
-    public static List extractUrls(final String text) {
-        if (isEmpty(text)) return Collections.emptyList();
-        final Matcher matcher = Patterns.WEB_URL.matcher(text);
-        final List urls = new ArrayList<>();
-        while (matcher.find()) {
-            urls.add(matcher.group());
-        }
-        return urls;
-    }
-
-    // https://github.com/notslang/instagram-id-to-url-segment
-    public static long shortcodeToId(final String shortcode) {
-        long result = 0L;
-        for (int i = 0; i < shortcode.length() && i < 11; i++){
-            final char c = shortcode.charAt(i);
-            final int k = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_".indexOf(c);
-            result = result * 64 + k;
-        }
-        return result;
-    }
-}
diff --git a/app/src/main/java/awais/instagrabber/utils/TextUtils.kt b/app/src/main/java/awais/instagrabber/utils/TextUtils.kt
new file mode 100644
index 00000000..598cabdf
--- /dev/null
+++ b/app/src/main/java/awais/instagrabber/utils/TextUtils.kt
@@ -0,0 +1,75 @@
+package awais.instagrabber.utils
+
+import android.content.Context
+import android.text.format.DateFormat
+import android.text.format.DateUtils
+import android.util.Patterns
+import java.util.*
+
+object TextUtils {
+    @JvmStatic
+    fun isEmpty(charSequence: CharSequence?): Boolean {
+        if (charSequence == null || charSequence.length < 1) return true
+        if (charSequence is String) {
+            var str = charSequence
+            if ("" == str || "null" == str || str.isEmpty()) return true
+            str = str.trim { it <= ' ' }
+            return "" == str || "null" == str || str.isEmpty()
+        }
+        return "null".contentEquals(charSequence) || "".contentEquals(charSequence)
+    }
+
+    @JvmStatic
+    @JvmOverloads
+    fun millisToTimeString(millis: Long, includeHoursAlways: Boolean = false): String {
+        val sec = (millis / 1000).toInt() % 60
+        var min = (millis / (1000 * 60)).toInt()
+        if (min >= 60) {
+            min = (millis / (1000 * 60) % 60).toInt()
+            val hr = (millis / (1000 * 60 * 60) % 24).toInt()
+            return String.format(Locale.ENGLISH, "%02d:%02d:%02d", hr, min, sec)
+        }
+        return if (includeHoursAlways) {
+            String.format(Locale.ENGLISH, "%02d:%02d:%02d", 0, min, sec)
+        } else String.format(Locale.ENGLISH, "%02d:%02d", min, sec)
+    }
+
+    @JvmStatic
+    fun getRelativeDateTimeString(context: Context?, from: Long): String {
+        val now = Date()
+        val then = Date(from)
+        val days = daysBetween(from, now.time)
+        return if (days == 0) {
+            DateFormat.getTimeFormat(context).format(then)
+        } else DateFormat.getDateFormat(context).format(then)
+    }
+
+    private fun daysBetween(d1: Long, d2: Long): Int {
+        return ((d2 - d1) / DateUtils.DAY_IN_MILLIS).toInt()
+    }
+
+    @JvmStatic
+    fun extractUrls(text: String?): List {
+        if (isEmpty(text)) return emptyList()
+        val matcher = Patterns.WEB_URL.matcher(text)
+        val urls: MutableList = ArrayList()
+        while (matcher.find()) {
+            urls.add(matcher.group())
+        }
+        return urls
+    }
+
+    // https://github.com/notslang/instagram-id-to-url-segment
+    @JvmStatic
+    fun shortcodeToId(shortcode: String): Long {
+        var result = 0L
+        var i = 0
+        while (i < shortcode.length && i < 11) {
+            val c = shortcode[i]
+            val k = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_".indexOf(c)
+            result = result * 64 + k
+            i++
+        }
+        return result
+    }
+}
\ No newline at end of file
diff --git a/app/src/main/java/awais/instagrabber/utils/UrlEncoder.java b/app/src/main/java/awais/instagrabber/utils/UrlEncoder.java
deleted file mode 100755
index 4795ad97..00000000
--- a/app/src/main/java/awais/instagrabber/utils/UrlEncoder.java
+++ /dev/null
@@ -1,74 +0,0 @@
-package awais.instagrabber.utils;
-
-import androidx.annotation.NonNull;
-
-import java.io.CharArrayWriter;
-import java.util.BitSet;
-
-// same as java.net.URLEncoder
-public final class UrlEncoder {
-    private static final BitSet dontNeedEncoding = new BitSet(256);
-    private static final int caseDiff = ('a' - 'A');
-
-    static {
-        int i;
-        for (i = 'a'; i <= 'z'; i++) dontNeedEncoding.set(i);
-        for (i = 'A'; i <= 'Z'; i++) dontNeedEncoding.set(i);
-        for (i = '0'; i <= '9'; i++) dontNeedEncoding.set(i);
-        dontNeedEncoding.set(' ');
-        dontNeedEncoding.set('-');
-        dontNeedEncoding.set('_');
-        dontNeedEncoding.set('.');
-        dontNeedEncoding.set('*');
-    }
-
-    @NonNull
-    public static String encodeUrl(@NonNull final String s) {
-        final StringBuilder out = new StringBuilder(s.length());
-        final CharArrayWriter charArrayWriter = new CharArrayWriter();
-
-        boolean needToChange = false;
-        for (int i = 0; i < s.length(); ) {
-            int c = s.charAt(i);
-
-            if (dontNeedEncoding.get(c)) {
-                if (c == ' ') {
-                    c = '+';
-                    needToChange = true;
-                }
-
-                out.append((char) c);
-                i++;
-            } else {
-                do {
-                    charArrayWriter.write(c);
-                    if (c >= 0xD800 && c <= 0xDBFF && i + 1 < s.length()) {
-                        final int d = s.charAt(i + 1);
-                        if (d >= 0xDC00 && d <= 0xDFFF) {
-                            charArrayWriter.write(d);
-                            i++;
-                        }
-                    }
-                    i++;
-                } while (i < s.length() && !dontNeedEncoding.get(c = s.charAt(i)));
-
-                charArrayWriter.flush();
-
-                final byte[] ba = charArrayWriter.toString().getBytes();
-                for (final byte b : ba) {
-                    out.append('%');
-                    char ch = Character.forDigit((b >> 4) & 0xF, 16);
-                    if (Character.isLetter(ch)) ch -= caseDiff;
-                    out.append(ch);
-                    ch = Character.forDigit(b & 0xF, 16);
-                    if (Character.isLetter(ch)) ch -= caseDiff;
-                    out.append(ch);
-                }
-                charArrayWriter.reset();
-                needToChange = true;
-            }
-        }
-
-        return (needToChange ? out.toString() : s);
-    }
-}
\ No newline at end of file
diff --git a/app/src/main/res/values-ca/arrays.xml b/app/src/main/res/values-ca/arrays.xml
index 34d4e174..eabc9c46 100644
--- a/app/src/main/res/values-ca/arrays.xml
+++ b/app/src/main/res/values-ca/arrays.xml
@@ -24,6 +24,8 @@
 
 ## We need maintainers!
 
diff --git a/app/src/github/res/values-de/strings.xml b/app/src/github/res/values-de/strings.xml
index 078fa6a8..38331667 100644
--- a/app/src/github/res/values-de/strings.xml
+++ b/app/src/github/res/values-de/strings.xml
@@ -1,6 +1,6 @@
 
 
-    Enable Sentry
-    Sentry is a listener/handler for errors that asynchronously sends out the error/event to Sentry.io
-    Sentry will start on next launch
+    Aktiviere Sentry
+    Sentry ist ein Listener/Handler für Fehler, der den Fehler/das Ereignis asynchron an Sentry.io sendet
+    Sentry startet beim nächsten Start
 
diff --git a/app/src/github/res/values-ko/strings.xml b/app/src/github/res/values-ko/strings.xml
new file mode 100644
index 00000000..272483b2
--- /dev/null
+++ b/app/src/github/res/values-ko/strings.xml
@@ -0,0 +1,6 @@
+
+
+    Sentry 활성화
+    Sentry는 Sentry.io에 오류를 비동기적으로 보내는 오류 처리기입니다
+    Sentry는 다음 출시에 시작됩니다
+
diff --git a/app/src/github/res/values-nl/strings.xml b/app/src/github/res/values-nl/strings.xml
index 078fa6a8..e043c9b9 100644
--- a/app/src/github/res/values-nl/strings.xml
+++ b/app/src/github/res/values-nl/strings.xml
@@ -1,6 +1,6 @@
 
 
-    Enable Sentry
-    Sentry is a listener/handler for errors that asynchronously sends out the error/event to Sentry.io
-    Sentry will start on next launch
+    Sentry inschakelen
+    Sentry is een luister/handler voor fouten die asynchroon de fout/gebeurtenis versturen naar Sentry.io
+    Sentry zal starten bij de volgende lancering
 
diff --git a/app/src/github/res/values-ru/strings.xml b/app/src/github/res/values-ru/strings.xml
index 0de74041..ecd5d235 100644
--- a/app/src/github/res/values-ru/strings.xml
+++ b/app/src/github/res/values-ru/strings.xml
@@ -1,6 +1,6 @@
 
 
-    Включить режим \"часового\"
-    \"Часовой\" - это слушатель/обработчик ошибок, который асинхронно отправляет ошибку/событие на Sentry.io
-    \"Часовой\" будет запущен при следующем запуске
+    Включить Sentry
+    Sentry - это обработчик событий, который асинхронно отправляет сообщения об ошибках/поломках на Sentry.io
+    Sentry включится при следующем запуске приложения
 
diff --git a/app/src/github/res/values-vi/strings.xml b/app/src/github/res/values-vi/strings.xml
index 078fa6a8..8669fe96 100644
--- a/app/src/github/res/values-vi/strings.xml
+++ b/app/src/github/res/values-vi/strings.xml
@@ -1,6 +1,6 @@
 
 
-    Enable Sentry
-    Sentry is a listener/handler for errors that asynchronously sends out the error/event to Sentry.io
-    Sentry will start on next launch
+    Bật Sentry
+    Sentry là một thiết bị nghe/giải quyết cho những lỗi mà gửi những lỗi/sự kiện đến Sentry.io một cách tách biệt
+    Sentry sẽ được bật vào lần khởi động kế tiếp
 
diff --git a/app/src/main/java/awais/instagrabber/activities/MainActivity.java b/app/src/main/java/awais/instagrabber/activities/MainActivity.java
index b981f442..f4aa44d6 100644
--- a/app/src/main/java/awais/instagrabber/activities/MainActivity.java
+++ b/app/src/main/java/awais/instagrabber/activities/MainActivity.java
@@ -702,7 +702,7 @@ public class MainActivity extends BaseLanguageActivity implements FragmentManage
                         Log.e(TAG, "showPostView: ", e);
                     }
                 }
-                Toast.makeText(getApplicationContext(), R.string.post_not_found, Toast.LENGTH_SHORT).show();
+                else Toast.makeText(getApplicationContext(), R.string.post_not_found, Toast.LENGTH_SHORT).show();
                 alertDialog.dismiss();
             }
 
diff --git a/app/src/main/java/awais/instagrabber/fragments/main/ProfileFragment.java b/app/src/main/java/awais/instagrabber/fragments/main/ProfileFragment.java
index 1dca8751..19a3ff14 100644
--- a/app/src/main/java/awais/instagrabber/fragments/main/ProfileFragment.java
+++ b/app/src/main/java/awais/instagrabber/fragments/main/ProfileFragment.java
@@ -917,6 +917,7 @@ public class ProfileFragment extends Fragment implements SwipeRefreshLayout.OnRe
 
     private void setupButtons(final long profileId) {
         profileDetailsBinding.btnTagged.setVisibility(isReallyPrivate() ? View.GONE : View.VISIBLE);
+        profileDetailsBinding.favChip.setVisibility(View.VISIBLE);
         if (isLoggedIn) {
             if (Objects.equals(profileId, myId)) {
                 profileDetailsBinding.btnTagged.setVisibility(View.VISIBLE);
@@ -932,7 +933,6 @@ public class ProfileFragment extends Fragment implements SwipeRefreshLayout.OnRe
             profileDetailsBinding.btnLiked.setVisibility(View.GONE);
             profileDetailsBinding.btnDM.setVisibility(disableDm ? View.GONE : View.VISIBLE);
             profileDetailsBinding.btnFollow.setVisibility(View.VISIBLE);
-            profileDetailsBinding.favChip.setVisibility(View.VISIBLE);
             final Context context = getContext();
             if (context == null) return;
             if (profileModel.getFriendshipStatus().isFollowing() || profileModel.getFriendshipStatus().isFollowedBy()) {
diff --git a/app/src/main/java/awais/instagrabber/fragments/settings/PreferenceKeys.java b/app/src/main/java/awais/instagrabber/fragments/settings/PreferenceKeys.java
deleted file mode 100644
index 878b9678..00000000
--- a/app/src/main/java/awais/instagrabber/fragments/settings/PreferenceKeys.java
+++ /dev/null
@@ -1,40 +0,0 @@
-package awais.instagrabber.fragments.settings;
-
-public final class PreferenceKeys {
-    // new boolean prefs
-    public static final String PREF_ENABLE_DM_NOTIFICATIONS = "enable_dm_notifications";
-    public static final String PREF_ENABLE_DM_AUTO_REFRESH = "enable_dm_auto_refresh";
-    public static final String PREF_ENABLE_DM_AUTO_REFRESH_FREQ_UNIT = "enable_dm_auto_refresh_freq_unit";
-    public static final String PREF_ENABLE_DM_AUTO_REFRESH_FREQ_NUMBER = "enable_dm_auto_refresh_freq_number";
-    public static final String PREF_ENABLE_SENTRY = "enable_sentry";
-    public static final String PREF_TAB_ORDER = "tab_order";
-    public static final String PREF_SHOWN_COUNT_TOOLTIP = "shown_count_tooltip";
-    public static final String PREF_SEARCH_FOCUS_KEYBOARD = "search_focus_keyboard";
-    // string prefs
-    public static final String FOLDER_PATH = "custom_path";
-    public static final String DATE_TIME_FORMAT = "date_time_format";
-    public static final String DATE_TIME_SELECTION = "date_time_selection";
-    public static final String CUSTOM_DATE_TIME_FORMAT = "date_time_custom_format";
-    public static final String APP_THEME = "app_theme_v19";
-    public static final String APP_LANGUAGE = "app_language_v19";
-    public static final String STORY_SORT = "story_sort";
-    // set string prefs
-    public static final String KEYWORD_FILTERS = "keyword_filters";
-    // old boolean prefs
-    public static final String DOWNLOAD_USER_FOLDER = "download_user_folder";
-    public static final String TOGGLE_KEYWORD_FILTER = "toggle_keyword_filter";
-    public static final String DOWNLOAD_PREPEND_USER_NAME = "download_user_name";
-    public static final String PLAY_IN_BACKGROUND = "play_in_background";
-    public static final String FOLDER_SAVE_TO = "saved_to";
-    public static final String AUTOPLAY_VIDEOS = "autoplay_videos";
-    public static final String MUTED_VIDEOS = "muted_videos";
-    public static final String SHOW_CAPTIONS = "show_captions";
-    public static final String CUSTOM_DATE_TIME_FORMAT_ENABLED = "data_time_custom_enabled";
-    public static final String SWAP_DATE_TIME_FORMAT_ENABLED = "swap_date_time_enabled";
-    public static final String MARK_AS_SEEN = "mark_as_seen";
-    public static final String HIDE_MUTED_REELS = "hide_muted_reels";
-    public static final String DM_MARK_AS_SEEN = "dm_mark_as_seen";
-    public static final String CHECK_ACTIVITY = "check_activity";
-    public static final String CHECK_UPDATES = "check_updates";
-    public static final String FLAG_SECURE = "flag_secure";
-}
diff --git a/app/src/main/java/awais/instagrabber/fragments/settings/PreferenceKeys.kt b/app/src/main/java/awais/instagrabber/fragments/settings/PreferenceKeys.kt
new file mode 100644
index 00000000..bdc8a77c
--- /dev/null
+++ b/app/src/main/java/awais/instagrabber/fragments/settings/PreferenceKeys.kt
@@ -0,0 +1,43 @@
+package awais.instagrabber.fragments.settings
+
+object PreferenceKeys {
+    // new boolean prefs
+    const val PREF_ENABLE_DM_NOTIFICATIONS = "enable_dm_notifications"
+    const val PREF_ENABLE_DM_AUTO_REFRESH = "enable_dm_auto_refresh"
+    const val PREF_ENABLE_DM_AUTO_REFRESH_FREQ_UNIT = "enable_dm_auto_refresh_freq_unit"
+    const val PREF_ENABLE_DM_AUTO_REFRESH_FREQ_NUMBER = "enable_dm_auto_refresh_freq_number"
+    const val PREF_ENABLE_SENTRY = "enable_sentry"
+    const val PREF_TAB_ORDER = "tab_order"
+    const val PREF_SHOWN_COUNT_TOOLTIP = "shown_count_tooltip"
+    const val PREF_SEARCH_FOCUS_KEYBOARD = "search_focus_keyboard"
+
+    // string prefs
+    const val FOLDER_PATH = "custom_path"
+    const val DATE_TIME_FORMAT = "date_time_format"
+    const val DATE_TIME_SELECTION = "date_time_selection"
+    const val CUSTOM_DATE_TIME_FORMAT = "date_time_custom_format"
+    const val APP_THEME = "app_theme_v19"
+    const val APP_LANGUAGE = "app_language_v19"
+    const val STORY_SORT = "story_sort"
+
+    // set string prefs
+    const val KEYWORD_FILTERS = "keyword_filters"
+
+    // old boolean prefs
+    const val DOWNLOAD_USER_FOLDER = "download_user_folder"
+    const val TOGGLE_KEYWORD_FILTER = "toggle_keyword_filter"
+    const val DOWNLOAD_PREPEND_USER_NAME = "download_user_name"
+    const val PLAY_IN_BACKGROUND = "play_in_background"
+    const val FOLDER_SAVE_TO = "saved_to"
+    const val AUTOPLAY_VIDEOS = "autoplay_videos"
+    const val MUTED_VIDEOS = "muted_videos"
+    const val SHOW_CAPTIONS = "show_captions"
+    const val CUSTOM_DATE_TIME_FORMAT_ENABLED = "data_time_custom_enabled"
+    const val SWAP_DATE_TIME_FORMAT_ENABLED = "swap_date_time_enabled"
+    const val MARK_AS_SEEN = "mark_as_seen"
+    const val HIDE_MUTED_REELS = "hide_muted_reels"
+    const val DM_MARK_AS_SEEN = "dm_mark_as_seen"
+    const val CHECK_ACTIVITY = "check_activity"
+    const val CHECK_UPDATES = "check_updates"
+    const val FLAG_SECURE = "flag_secure"
+}
\ No newline at end of file
diff --git a/app/src/main/java/awais/instagrabber/utils/Constants.java b/app/src/main/java/awais/instagrabber/utils/Constants.java
deleted file mode 100644
index 357b4c24..00000000
--- a/app/src/main/java/awais/instagrabber/utils/Constants.java
+++ /dev/null
@@ -1,95 +0,0 @@
-package awais.instagrabber.utils;
-
-public final class Constants {
-    public static final String CRASH_REPORT_EMAIL = "barinsta@austinhuang.me";
-
-    // int prefs, do not export
-    public static final String PREV_INSTALL_VERSION = "prevVersion";
-    public static final String BROWSER_UA_CODE = "browser_ua_code";
-    public static final String APP_UA_CODE = "app_ua_code";
-    // never Export
-    public static final String COOKIE = "cookie";
-    // deprecated: public static final String SHOW_QUICK_ACCESS_DIALOG = "show_quick_dlg";
-    public static final String DEVICE_UUID = "device_uuid";
-    public static final String BROWSER_UA = "browser_ua";
-    public static final String APP_UA = "app_ua";
-    //////////////////////// EXTRAS ////////////////////////
-    public static final String EXTRAS_USER = "user";
-    public static final String EXTRAS_HASHTAG = "hashtag";
-    public static final String EXTRAS_LOCATION = "location";
-    public static final String EXTRAS_USERNAME = "username";
-    public static final String EXTRAS_ID = "id";
-    public static final String EXTRAS_POST = "post";
-    public static final String EXTRAS_PROFILE = "profile";
-    public static final String EXTRAS_TYPE = "type";
-    public static final String EXTRAS_NAME = "name";
-    public static final String EXTRAS_STORIES = "stories";
-    public static final String EXTRAS_HIGHLIGHT = "highlight";
-    public static final String EXTRAS_INDEX = "index";
-    public static final String EXTRAS_THREAD_MODEL = "threadModel";
-    public static final String EXTRAS_FOLLOWERS = "followers";
-    public static final String EXTRAS_SHORTCODE = "shortcode";
-    public static final String EXTRAS_END_CURSOR = "endCursor";
-    public static final String FEED = "feed";
-    public static final String FEED_ORDER = "feedOrder";
-
-    // Notification ids
-    public static final int ACTIVITY_NOTIFICATION_ID = 10;
-    public static final int DM_UNREAD_PARENT_NOTIFICATION_ID = 20;
-    public static final int DM_CHECK_NOTIFICATION_ID = 11;
-
-    // see https://github.com/dilame/instagram-private-api/blob/master/src/core/constants.ts
-//    public static final String SUPPORTED_CAPABILITIES = "[ { \"name\": \"SUPPORTED_SDK_VERSIONS\", \"value\":" +
-//            " \"13.0,14.0,15.0,16.0,17.0,18.0,19.0,20.0,21.0,22.0,23.0,24.0,25.0,26.0,27.0,28.0,29.0,30.0,31.0," +
-//            "32.0,33.0,34.0,35.0,36.0,37.0,38.0,39.0,40.0,41.0,42.0,43.0,44.0,45.0,46.0,47.0,48.0,49.0,50.0,51.0," +
-//            "52.0,53.0,54.0,55.0,56.0,57.0,58.0,59.0,60.0,61.0,62.0,63.0,64.0,65.0,66.0\" }, { \"name\": \"FACE_TRACKER_VERSION\", " +
-//            "\"value\": 12 }, { \"name\": \"segmentation\", \"value\": \"segmentation_enabled\" }, { \"name\": \"COMPRESSION\", " +
-//            "\"value\": \"ETC2_COMPRESSION\" }, { \"name\": \"world_tracker\", \"value\": \"world_tracker_enabled\" }, { \"name\": " +
-//            "\"gyroscope\", \"value\": \"gyroscope_enabled\" } ]";
-//    public static final String SIGNATURE_VERSION = "4";
-//    public static final String SIGNATURE_KEY = "9193488027538fd3450b83b7d05286d4ca9599a0f7eeed90d8c85925698a05dc";
-    public static final String BREADCRUMB_KEY = "iN4$aGr0m";
-    public static final int LOGIN_RESULT_CODE = 5000;
-    public static final String SKIPPED_VERSION = "skipped_version";
-    public static final String DEFAULT_TAB = "default_tab";
-    public static final String PREF_DARK_THEME = "dark_theme";
-    public static final String PREF_LIGHT_THEME = "light_theme";
-    public static final String DEFAULT_HASH_TAG_PIC = "https://www.instagram.com/static/images/hashtag/search-hashtag-default-avatar.png/1d8417c9a4f5.png";
-    public static final String SHARED_PREFERENCES_NAME = "settings";
-    public static final String PREF_POSTS_LAYOUT = "posts_layout";
-    public static final String PREF_PROFILE_POSTS_LAYOUT = "profile_posts_layout";
-    public static final String PREF_TOPIC_POSTS_LAYOUT = "topic_posts_layout";
-    public static final String PREF_HASHTAG_POSTS_LAYOUT = "hashtag_posts_layout";
-    public static final String PREF_LOCATION_POSTS_LAYOUT = "location_posts_layout";
-    public static final String PREF_LIKED_POSTS_LAYOUT = "liked_posts_layout";
-    public static final String PREF_TAGGED_POSTS_LAYOUT = "tagged_posts_layout";
-    public static final String PREF_SAVED_POSTS_LAYOUT = "saved_posts_layout";
-    public static final String PREF_EMOJI_VARIANTS = "emoji_variants";
-    public static final String PREF_REACTIONS = "reactions";
-
-    public static final String ACTIVITY_CHANNEL_ID = "activity";
-    public static final String ACTIVITY_CHANNEL_NAME = "Activity";
-    public static final String DOWNLOAD_CHANNEL_ID = "download";
-    public static final String DOWNLOAD_CHANNEL_NAME = "Downloads";
-    public static final String DM_UNREAD_CHANNEL_ID = "dmUnread";
-    public static final String DM_UNREAD_CHANNEL_NAME = "Messages";
-    public static final String SILENT_NOTIFICATIONS_CHANNEL_ID = "silentNotifications";
-    public static final String SILENT_NOTIFICATIONS_CHANNEL_NAME = "Silent notifications";
-
-    public static final String NOTIF_GROUP_NAME = "awais.instagrabber.InstaNotif";
-    public static final String GROUP_KEY_DM = "awais.instagrabber.MESSAGES";
-    public static final String GROUP_KEY_SILENT_NOTIFICATIONS = "awais.instagrabber.SILENT_NOTIFICATIONS";
-
-    public static final int SHOW_ACTIVITY_REQUEST_CODE = 1738;
-    public static final int SHOW_DM_THREAD = 2000;
-    public static final int DM_SYNC_SERVICE_REQUEST_CODE = 3000;
-    public static final int GLOBAL_NETWORK_ERROR_DIALOG_REQUEST_CODE = 7777;
-
-    public static final String ACTION_SHOW_ACTIVITY = "show_activity";
-    public static final String ACTION_SHOW_DM_THREAD = "show_dm_thread";
-
-    public static final String DM_THREAD_ACTION_EXTRA_THREAD_ID = "thread_id";
-    public static final String DM_THREAD_ACTION_EXTRA_THREAD_TITLE = "thread_title";
-
-    public static final String X_IG_APP_ID = "936619743392459";
-}
\ No newline at end of file
diff --git a/app/src/main/java/awais/instagrabber/utils/Constants.kt b/app/src/main/java/awais/instagrabber/utils/Constants.kt
new file mode 100644
index 00000000..8cf96e03
--- /dev/null
+++ b/app/src/main/java/awais/instagrabber/utils/Constants.kt
@@ -0,0 +1,92 @@
+package awais.instagrabber.utils
+
+object Constants {
+    const val CRASH_REPORT_EMAIL = "barinsta@austinhuang.me"
+
+    // int prefs, do not export
+    const val PREV_INSTALL_VERSION = "prevVersion"
+    const val BROWSER_UA_CODE = "browser_ua_code"
+    const val APP_UA_CODE = "app_ua_code"
+
+    // never Export
+    const val COOKIE = "cookie"
+
+    // deprecated: public static final String SHOW_QUICK_ACCESS_DIALOG = "show_quick_dlg";
+    const val DEVICE_UUID = "device_uuid"
+    const val BROWSER_UA = "browser_ua"
+    const val APP_UA = "app_ua"
+
+    //////////////////////// EXTRAS ////////////////////////
+    const val EXTRAS_USER = "user"
+    const val EXTRAS_HASHTAG = "hashtag"
+    const val EXTRAS_LOCATION = "location"
+    const val EXTRAS_USERNAME = "username"
+    const val EXTRAS_ID = "id"
+    const val EXTRAS_POST = "post"
+    const val EXTRAS_PROFILE = "profile"
+    const val EXTRAS_TYPE = "type"
+    const val EXTRAS_NAME = "name"
+    const val EXTRAS_STORIES = "stories"
+    const val EXTRAS_HIGHLIGHT = "highlight"
+    const val EXTRAS_INDEX = "index"
+    const val EXTRAS_THREAD_MODEL = "threadModel"
+    const val EXTRAS_FOLLOWERS = "followers"
+    const val EXTRAS_SHORTCODE = "shortcode"
+    const val EXTRAS_END_CURSOR = "endCursor"
+    const val FEED = "feed"
+    const val FEED_ORDER = "feedOrder"
+
+    // Notification ids
+    const val ACTIVITY_NOTIFICATION_ID = 10
+    const val DM_UNREAD_PARENT_NOTIFICATION_ID = 20
+    const val DM_CHECK_NOTIFICATION_ID = 11
+
+    // see https://github.com/dilame/instagram-private-api/blob/master/src/core/constants.ts
+    //    public static final String SUPPORTED_CAPABILITIES = "[ { \"name\": \"SUPPORTED_SDK_VERSIONS\", \"value\":" +
+    //            " \"13.0,14.0,15.0,16.0,17.0,18.0,19.0,20.0,21.0,22.0,23.0,24.0,25.0,26.0,27.0,28.0,29.0,30.0,31.0," +
+    //            "32.0,33.0,34.0,35.0,36.0,37.0,38.0,39.0,40.0,41.0,42.0,43.0,44.0,45.0,46.0,47.0,48.0,49.0,50.0,51.0," +
+    //            "52.0,53.0,54.0,55.0,56.0,57.0,58.0,59.0,60.0,61.0,62.0,63.0,64.0,65.0,66.0\" }, { \"name\": \"FACE_TRACKER_VERSION\", " +
+    //            "\"value\": 12 }, { \"name\": \"segmentation\", \"value\": \"segmentation_enabled\" }, { \"name\": \"COMPRESSION\", " +
+    //            "\"value\": \"ETC2_COMPRESSION\" }, { \"name\": \"world_tracker\", \"value\": \"world_tracker_enabled\" }, { \"name\": " +
+    //            "\"gyroscope\", \"value\": \"gyroscope_enabled\" } ]";
+    //    public static final String SIGNATURE_VERSION = "4";
+    //    public static final String SIGNATURE_KEY = "9193488027538fd3450b83b7d05286d4ca9599a0f7eeed90d8c85925698a05dc";
+    const val BREADCRUMB_KEY = "iN4\$aGr0m"
+    const val LOGIN_RESULT_CODE = 5000
+    const val SKIPPED_VERSION = "skipped_version"
+    const val DEFAULT_TAB = "default_tab"
+    const val PREF_DARK_THEME = "dark_theme"
+    const val PREF_LIGHT_THEME = "light_theme"
+    const val DEFAULT_HASH_TAG_PIC = "https://www.instagram.com/static/images/hashtag/search-hashtag-default-avatar.png/1d8417c9a4f5.png"
+    const val SHARED_PREFERENCES_NAME = "settings"
+    const val PREF_POSTS_LAYOUT = "posts_layout"
+    const val PREF_PROFILE_POSTS_LAYOUT = "profile_posts_layout"
+    const val PREF_TOPIC_POSTS_LAYOUT = "topic_posts_layout"
+    const val PREF_HASHTAG_POSTS_LAYOUT = "hashtag_posts_layout"
+    const val PREF_LOCATION_POSTS_LAYOUT = "location_posts_layout"
+    const val PREF_LIKED_POSTS_LAYOUT = "liked_posts_layout"
+    const val PREF_TAGGED_POSTS_LAYOUT = "tagged_posts_layout"
+    const val PREF_SAVED_POSTS_LAYOUT = "saved_posts_layout"
+    const val PREF_EMOJI_VARIANTS = "emoji_variants"
+    const val PREF_REACTIONS = "reactions"
+    const val ACTIVITY_CHANNEL_ID = "activity"
+    const val ACTIVITY_CHANNEL_NAME = "Activity"
+    const val DOWNLOAD_CHANNEL_ID = "download"
+    const val DOWNLOAD_CHANNEL_NAME = "Downloads"
+    const val DM_UNREAD_CHANNEL_ID = "dmUnread"
+    const val DM_UNREAD_CHANNEL_NAME = "Messages"
+    const val SILENT_NOTIFICATIONS_CHANNEL_ID = "silentNotifications"
+    const val SILENT_NOTIFICATIONS_CHANNEL_NAME = "Silent notifications"
+    const val NOTIF_GROUP_NAME = "awais.instagrabber.InstaNotif"
+    const val GROUP_KEY_DM = "awais.instagrabber.MESSAGES"
+    const val GROUP_KEY_SILENT_NOTIFICATIONS = "awais.instagrabber.SILENT_NOTIFICATIONS"
+    const val SHOW_ACTIVITY_REQUEST_CODE = 1738
+    const val SHOW_DM_THREAD = 2000
+    const val DM_SYNC_SERVICE_REQUEST_CODE = 3000
+    const val GLOBAL_NETWORK_ERROR_DIALOG_REQUEST_CODE = 7777
+    const val ACTION_SHOW_ACTIVITY = "show_activity"
+    const val ACTION_SHOW_DM_THREAD = "show_dm_thread"
+    const val DM_THREAD_ACTION_EXTRA_THREAD_ID = "thread_id"
+    const val DM_THREAD_ACTION_EXTRA_THREAD_TITLE = "thread_title"
+    const val X_IG_APP_ID = "936619743392459"
+}
\ No newline at end of file
diff --git a/app/src/main/java/awais/instagrabber/utils/ExoplayerUtils.java b/app/src/main/java/awais/instagrabber/utils/ExoplayerUtils.java
deleted file mode 100644
index d942ff59..00000000
--- a/app/src/main/java/awais/instagrabber/utils/ExoplayerUtils.java
+++ /dev/null
@@ -1,26 +0,0 @@
-package awais.instagrabber.utils;
-
-import android.content.Context;
-
-import androidx.annotation.NonNull;
-
-import com.google.android.exoplayer2.database.ExoDatabaseProvider;
-import com.google.android.exoplayer2.source.DefaultMediaSourceFactory;
-import com.google.android.exoplayer2.upstream.DefaultHttpDataSourceFactory;
-import com.google.android.exoplayer2.upstream.cache.CacheDataSource;
-import com.google.android.exoplayer2.upstream.cache.LeastRecentlyUsedCacheEvictor;
-import com.google.android.exoplayer2.upstream.cache.SimpleCache;
-
-public final class ExoplayerUtils {
-    private static final long MAX_CACHE_BYTES = 1048576;
-    private static final LeastRecentlyUsedCacheEvictor cacheEvictor = new LeastRecentlyUsedCacheEvictor(MAX_CACHE_BYTES);
-
-    public static DefaultMediaSourceFactory getCachedMediaSourceFactory(@NonNull final Context context) {
-        final ExoDatabaseProvider exoDatabaseProvider = new ExoDatabaseProvider(context);
-        final SimpleCache simpleCache = new SimpleCache(context.getCacheDir(), cacheEvictor, exoDatabaseProvider);
-        final CacheDataSource.Factory cacheDataSourceFactory = new CacheDataSource.Factory()
-                .setCache(simpleCache)
-                .setUpstreamDataSourceFactory(new DefaultHttpDataSourceFactory());
-        return new DefaultMediaSourceFactory(cacheDataSourceFactory);
-    }
-}
diff --git a/app/src/main/java/awais/instagrabber/utils/ExoplayerUtils.kt b/app/src/main/java/awais/instagrabber/utils/ExoplayerUtils.kt
new file mode 100644
index 00000000..cc09440b
--- /dev/null
+++ b/app/src/main/java/awais/instagrabber/utils/ExoplayerUtils.kt
@@ -0,0 +1,22 @@
+package awais.instagrabber.utils
+
+import android.content.Context
+import com.google.android.exoplayer2.database.ExoDatabaseProvider
+import com.google.android.exoplayer2.source.DefaultMediaSourceFactory
+import com.google.android.exoplayer2.upstream.DefaultHttpDataSourceFactory
+import com.google.android.exoplayer2.upstream.cache.CacheDataSource
+import com.google.android.exoplayer2.upstream.cache.LeastRecentlyUsedCacheEvictor
+import com.google.android.exoplayer2.upstream.cache.SimpleCache
+
+object ExoplayerUtils {
+    private const val MAX_CACHE_BYTES: Long = 1048576
+    private val cacheEvictor = LeastRecentlyUsedCacheEvictor(MAX_CACHE_BYTES)
+    fun getCachedMediaSourceFactory(context: Context): DefaultMediaSourceFactory {
+        val exoDatabaseProvider = ExoDatabaseProvider(context)
+        val simpleCache = SimpleCache(context.cacheDir, cacheEvictor, exoDatabaseProvider)
+        val cacheDataSourceFactory = CacheDataSource.Factory()
+                .setCache(simpleCache)
+                .setUpstreamDataSourceFactory(DefaultHttpDataSourceFactory())
+        return DefaultMediaSourceFactory(cacheDataSourceFactory)
+    }
+}
\ No newline at end of file
diff --git a/app/src/main/java/awais/instagrabber/utils/PasswordUtils.java b/app/src/main/java/awais/instagrabber/utils/PasswordUtils.java
deleted file mode 100644
index 2cc380bc..00000000
--- a/app/src/main/java/awais/instagrabber/utils/PasswordUtils.java
+++ /dev/null
@@ -1,47 +0,0 @@
-package awais.instagrabber.utils;
-
-import android.util.Base64;
-
-import androidx.annotation.NonNull;
-
-import java.security.GeneralSecurityException;
-import java.security.InvalidAlgorithmParameterException;
-import java.security.InvalidKeyException;
-import java.security.NoSuchAlgorithmException;
-
-import javax.crypto.BadPaddingException;
-import javax.crypto.Cipher;
-import javax.crypto.IllegalBlockSizeException;
-import javax.crypto.NoSuchPaddingException;
-import javax.crypto.spec.IvParameterSpec;
-import javax.crypto.spec.SecretKeySpec;
-
-public final class PasswordUtils {
-    private static final String cipherAlgo = "AES";
-    private static final String cipherTran = "AES/CBC/PKCS5Padding";
-
-    public static byte[] dec(final String encrypted, final byte[] keyValue) throws Exception {
-        try {
-            final Cipher cipher = Cipher.getInstance(cipherTran);
-            final SecretKeySpec secretKey = new SecretKeySpec(keyValue, cipherAlgo);
-            cipher.init(Cipher.DECRYPT_MODE, secretKey, new IvParameterSpec(new byte[16]));
-            return cipher.doFinal(Base64.decode(encrypted, Base64.DEFAULT | Base64.NO_PADDING | Base64.NO_WRAP));
-        } catch (NoSuchAlgorithmException | NoSuchPaddingException | InvalidAlgorithmParameterException | InvalidKeyException | BadPaddingException | IllegalBlockSizeException e) {
-            throw new IncorrectPasswordException(e);
-        }
-    }
-
-    public static byte[] enc(@NonNull final String str, final byte[] keyValue) throws Exception {
-        final Cipher cipher = Cipher.getInstance(cipherTran);
-        final SecretKeySpec secretKey = new SecretKeySpec(keyValue, cipherAlgo);
-        cipher.init(Cipher.ENCRYPT_MODE, secretKey, new IvParameterSpec(new byte[16]));
-        final byte[] bytes = cipher.doFinal(str.getBytes());
-        return Base64.encode(bytes, Base64.DEFAULT | Base64.NO_PADDING | Base64.NO_WRAP);
-    }
-
-    public static class IncorrectPasswordException extends Exception {
-        public IncorrectPasswordException(final GeneralSecurityException e) {
-            super(e);
-        }
-    }
-}
diff --git a/app/src/main/java/awais/instagrabber/utils/PasswordUtils.kt b/app/src/main/java/awais/instagrabber/utils/PasswordUtils.kt
new file mode 100644
index 00000000..2d4b13c6
--- /dev/null
+++ b/app/src/main/java/awais/instagrabber/utils/PasswordUtils.kt
@@ -0,0 +1,52 @@
+package awais.instagrabber.utils
+
+import android.util.Base64
+import java.security.GeneralSecurityException
+import java.security.InvalidAlgorithmParameterException
+import java.security.InvalidKeyException
+import java.security.NoSuchAlgorithmException
+import javax.crypto.BadPaddingException
+import javax.crypto.Cipher
+import javax.crypto.IllegalBlockSizeException
+import javax.crypto.NoSuchPaddingException
+import javax.crypto.spec.IvParameterSpec
+import javax.crypto.spec.SecretKeySpec
+
+object PasswordUtils {
+    private const val cipherAlgo = "AES"
+    private const val cipherTran = "AES/CBC/PKCS5Padding"
+    @JvmStatic
+    @Throws(Exception::class)
+    fun dec(encrypted: String?, keyValue: ByteArray?): ByteArray {
+        return try {
+            val cipher = Cipher.getInstance(cipherTran)
+            val secretKey = SecretKeySpec(keyValue, cipherAlgo)
+            cipher.init(Cipher.DECRYPT_MODE, secretKey, IvParameterSpec(ByteArray(16)))
+            cipher.doFinal(Base64.decode(encrypted, Base64.DEFAULT or Base64.NO_PADDING or Base64.NO_WRAP))
+        } catch (e: NoSuchAlgorithmException) {
+            throw IncorrectPasswordException(e)
+        } catch (e: NoSuchPaddingException) {
+            throw IncorrectPasswordException(e)
+        } catch (e: InvalidAlgorithmParameterException) {
+            throw IncorrectPasswordException(e)
+        } catch (e: InvalidKeyException) {
+            throw IncorrectPasswordException(e)
+        } catch (e: BadPaddingException) {
+            throw IncorrectPasswordException(e)
+        } catch (e: IllegalBlockSizeException) {
+            throw IncorrectPasswordException(e)
+        }
+    }
+
+    @JvmStatic
+    @Throws(Exception::class)
+    fun enc(str: String, keyValue: ByteArray?): ByteArray {
+        val cipher = Cipher.getInstance(cipherTran)
+        val secretKey = SecretKeySpec(keyValue, cipherAlgo)
+        cipher.init(Cipher.ENCRYPT_MODE, secretKey, IvParameterSpec(ByteArray(16)))
+        val bytes = cipher.doFinal(str.toByteArray())
+        return Base64.encode(bytes, Base64.DEFAULT or Base64.NO_PADDING or Base64.NO_WRAP)
+    }
+
+    class IncorrectPasswordException(e: GeneralSecurityException?) : Exception(e)
+}
\ No newline at end of file
diff --git a/app/src/main/java/awais/instagrabber/utils/TextUtils.java b/app/src/main/java/awais/instagrabber/utils/TextUtils.java
deleted file mode 100644
index 5df3ac08..00000000
--- a/app/src/main/java/awais/instagrabber/utils/TextUtils.java
+++ /dev/null
@@ -1,122 +0,0 @@
-package awais.instagrabber.utils;
-
-import android.content.Context;
-import android.text.SpannableString;
-import android.text.format.DateFormat;
-import android.text.format.DateUtils;
-import android.text.style.URLSpan;
-import android.util.Patterns;
-
-import androidx.annotation.NonNull;
-
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.Collections;
-import java.util.Date;
-import java.util.List;
-import java.util.Locale;
-import java.util.regex.Matcher;
-import java.util.stream.Collectors;
-
-public final class TextUtils {
-    // extracted from String class
-    public static int indexOfChar(@NonNull final CharSequence sequence, final int ch, final int startIndex) {
-        final int max = sequence.length();
-        if (startIndex < max) {
-            if (ch < Character.MIN_SUPPLEMENTARY_CODE_POINT) {
-                for (int i = startIndex; i < max; i++) if (sequence.charAt(i) == ch) return i;
-            } else if (Character.isValidCodePoint(ch)) {
-                final char hi = (char) ((ch >>> 10) + (Character.MIN_HIGH_SURROGATE - (Character.MIN_SUPPLEMENTARY_CODE_POINT >>> 10)));
-                final char lo = (char) ((ch & 0x3ff) + Character.MIN_LOW_SURROGATE);
-                for (int i = startIndex; i < max; i++)
-                    if (sequence.charAt(i) == hi && sequence.charAt(i + 1) == lo) return i;
-            }
-        }
-        return -1;
-    }
-
-    public static CharSequence getSpannableUrl(final String url) {
-        if (isEmpty(url)) return url;
-        final int httpIndex = url.indexOf("http:");
-        final int httpsIndex = url.indexOf("https:");
-        if (httpIndex == -1 && httpsIndex == -1) return url;
-
-        final int length = url.length();
-
-        final int startIndex = httpIndex != -1 ? httpIndex : httpsIndex;
-        final int spaceIndex = url.indexOf(' ', startIndex + 1);
-
-        final int endIndex = (spaceIndex != -1 ? spaceIndex : length);
-
-        final String extractUrl = url.substring(startIndex, Math.min(length, endIndex));
-
-        final SpannableString spannableString = new SpannableString(url);
-        spannableString.setSpan(new URLSpan(extractUrl), startIndex, endIndex, 0);
-
-        return spannableString;
-    }
-
-    public static boolean isEmpty(final CharSequence charSequence) {
-        if (charSequence == null || charSequence.length() < 1) return true;
-        if (charSequence instanceof String) {
-            String str = (String) charSequence;
-            if ("".equals(str) || "null".equals(str) || str.isEmpty()) return true;
-            str = str.trim();
-            return "".equals(str) || "null".equals(str) || str.isEmpty();
-        }
-        return "null".contentEquals(charSequence) || "".contentEquals(charSequence);
-    }
-
-    public static String millisToTimeString(final long millis) {
-        return millisToTimeString(millis, false);
-    }
-
-    public static String millisToTimeString(final long millis, final boolean includeHoursAlways) {
-        final int sec = (int) (millis / 1000) % 60;
-        int min = (int) (millis / (1000 * 60));
-        if (min >= 60) {
-            min = (int) ((millis / (1000 * 60)) % 60);
-            final int hr = (int) ((millis / (1000 * 60 * 60)) % 24);
-            return String.format(Locale.ENGLISH, "%02d:%02d:%02d", hr, min, sec);
-        }
-        if (includeHoursAlways) {
-            return String.format(Locale.ENGLISH, "%02d:%02d:%02d", 0, min, sec);
-        }
-        return String.format(Locale.ENGLISH, "%02d:%02d", min, sec);
-    }
-
-    public static String getRelativeDateTimeString(final Context context, final long from) {
-        final Date now = new Date();
-        final Date then = new Date(from);
-        int days = daysBetween(from, now.getTime());
-        if (days == 0) {
-            return DateFormat.getTimeFormat(context).format(then);
-        }
-        return DateFormat.getDateFormat(context).format(then);
-    }
-
-    private static int daysBetween(long d1, long d2) {
-        return (int) ((d2 - d1) / DateUtils.DAY_IN_MILLIS);
-    }
-
-    public static List extractUrls(final String text) {
-        if (isEmpty(text)) return Collections.emptyList();
-        final Matcher matcher = Patterns.WEB_URL.matcher(text);
-        final List urls = new ArrayList<>();
-        while (matcher.find()) {
-            urls.add(matcher.group());
-        }
-        return urls;
-    }
-
-    // https://github.com/notslang/instagram-id-to-url-segment
-    public static long shortcodeToId(final String shortcode) {
-        long result = 0L;
-        for (int i = 0; i < shortcode.length() && i < 11; i++){
-            final char c = shortcode.charAt(i);
-            final int k = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_".indexOf(c);
-            result = result * 64 + k;
-        }
-        return result;
-    }
-}
diff --git a/app/src/main/java/awais/instagrabber/utils/TextUtils.kt b/app/src/main/java/awais/instagrabber/utils/TextUtils.kt
new file mode 100644
index 00000000..598cabdf
--- /dev/null
+++ b/app/src/main/java/awais/instagrabber/utils/TextUtils.kt
@@ -0,0 +1,75 @@
+package awais.instagrabber.utils
+
+import android.content.Context
+import android.text.format.DateFormat
+import android.text.format.DateUtils
+import android.util.Patterns
+import java.util.*
+
+object TextUtils {
+    @JvmStatic
+    fun isEmpty(charSequence: CharSequence?): Boolean {
+        if (charSequence == null || charSequence.length < 1) return true
+        if (charSequence is String) {
+            var str = charSequence
+            if ("" == str || "null" == str || str.isEmpty()) return true
+            str = str.trim { it <= ' ' }
+            return "" == str || "null" == str || str.isEmpty()
+        }
+        return "null".contentEquals(charSequence) || "".contentEquals(charSequence)
+    }
+
+    @JvmStatic
+    @JvmOverloads
+    fun millisToTimeString(millis: Long, includeHoursAlways: Boolean = false): String {
+        val sec = (millis / 1000).toInt() % 60
+        var min = (millis / (1000 * 60)).toInt()
+        if (min >= 60) {
+            min = (millis / (1000 * 60) % 60).toInt()
+            val hr = (millis / (1000 * 60 * 60) % 24).toInt()
+            return String.format(Locale.ENGLISH, "%02d:%02d:%02d", hr, min, sec)
+        }
+        return if (includeHoursAlways) {
+            String.format(Locale.ENGLISH, "%02d:%02d:%02d", 0, min, sec)
+        } else String.format(Locale.ENGLISH, "%02d:%02d", min, sec)
+    }
+
+    @JvmStatic
+    fun getRelativeDateTimeString(context: Context?, from: Long): String {
+        val now = Date()
+        val then = Date(from)
+        val days = daysBetween(from, now.time)
+        return if (days == 0) {
+            DateFormat.getTimeFormat(context).format(then)
+        } else DateFormat.getDateFormat(context).format(then)
+    }
+
+    private fun daysBetween(d1: Long, d2: Long): Int {
+        return ((d2 - d1) / DateUtils.DAY_IN_MILLIS).toInt()
+    }
+
+    @JvmStatic
+    fun extractUrls(text: String?): List {
+        if (isEmpty(text)) return emptyList()
+        val matcher = Patterns.WEB_URL.matcher(text)
+        val urls: MutableList = ArrayList()
+        while (matcher.find()) {
+            urls.add(matcher.group())
+        }
+        return urls
+    }
+
+    // https://github.com/notslang/instagram-id-to-url-segment
+    @JvmStatic
+    fun shortcodeToId(shortcode: String): Long {
+        var result = 0L
+        var i = 0
+        while (i < shortcode.length && i < 11) {
+            val c = shortcode[i]
+            val k = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_".indexOf(c)
+            result = result * 64 + k
+            i++
+        }
+        return result
+    }
+}
\ No newline at end of file
diff --git a/app/src/main/java/awais/instagrabber/utils/UrlEncoder.java b/app/src/main/java/awais/instagrabber/utils/UrlEncoder.java
deleted file mode 100755
index 4795ad97..00000000
--- a/app/src/main/java/awais/instagrabber/utils/UrlEncoder.java
+++ /dev/null
@@ -1,74 +0,0 @@
-package awais.instagrabber.utils;
-
-import androidx.annotation.NonNull;
-
-import java.io.CharArrayWriter;
-import java.util.BitSet;
-
-// same as java.net.URLEncoder
-public final class UrlEncoder {
-    private static final BitSet dontNeedEncoding = new BitSet(256);
-    private static final int caseDiff = ('a' - 'A');
-
-    static {
-        int i;
-        for (i = 'a'; i <= 'z'; i++) dontNeedEncoding.set(i);
-        for (i = 'A'; i <= 'Z'; i++) dontNeedEncoding.set(i);
-        for (i = '0'; i <= '9'; i++) dontNeedEncoding.set(i);
-        dontNeedEncoding.set(' ');
-        dontNeedEncoding.set('-');
-        dontNeedEncoding.set('_');
-        dontNeedEncoding.set('.');
-        dontNeedEncoding.set('*');
-    }
-
-    @NonNull
-    public static String encodeUrl(@NonNull final String s) {
-        final StringBuilder out = new StringBuilder(s.length());
-        final CharArrayWriter charArrayWriter = new CharArrayWriter();
-
-        boolean needToChange = false;
-        for (int i = 0; i < s.length(); ) {
-            int c = s.charAt(i);
-
-            if (dontNeedEncoding.get(c)) {
-                if (c == ' ') {
-                    c = '+';
-                    needToChange = true;
-                }
-
-                out.append((char) c);
-                i++;
-            } else {
-                do {
-                    charArrayWriter.write(c);
-                    if (c >= 0xD800 && c <= 0xDBFF && i + 1 < s.length()) {
-                        final int d = s.charAt(i + 1);
-                        if (d >= 0xDC00 && d <= 0xDFFF) {
-                            charArrayWriter.write(d);
-                            i++;
-                        }
-                    }
-                    i++;
-                } while (i < s.length() && !dontNeedEncoding.get(c = s.charAt(i)));
-
-                charArrayWriter.flush();
-
-                final byte[] ba = charArrayWriter.toString().getBytes();
-                for (final byte b : ba) {
-                    out.append('%');
-                    char ch = Character.forDigit((b >> 4) & 0xF, 16);
-                    if (Character.isLetter(ch)) ch -= caseDiff;
-                    out.append(ch);
-                    ch = Character.forDigit(b & 0xF, 16);
-                    if (Character.isLetter(ch)) ch -= caseDiff;
-                    out.append(ch);
-                }
-                charArrayWriter.reset();
-                needToChange = true;
-            }
-        }
-
-        return (needToChange ? out.toString() : s);
-    }
-}
\ No newline at end of file
diff --git a/app/src/main/res/values-ca/arrays.xml b/app/src/main/res/values-ca/arrays.xml
index 34d4e174..eabc9c46 100644
--- a/app/src/main/res/values-ca/arrays.xml
+++ b/app/src/main/res/values-ca/arrays.xml
@@ -24,6 +24,8 @@
         - 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Automàtic / Predeterminat del sistemadiff --git a/app/src/main/res/values-ca/strings.xml b/app/src/main/res/values-ca/strings.xml
index 90b7a5da..e31de7a6 100644
--- a/app/src/main/res/values-ca/strings.xml
+++ b/app/src/main/res/values-ca/strings.xml
@@ -123,6 +123,7 @@
     Silenciar publicacions
     No silenciar les històries
     No silenciar les publicacions
+    Remove follower
     Copiar bio
     Traduir bio
     Mutu
@@ -211,7 +212,7 @@
     Donar \"m\'agrada\" al comentari
     Treure \"m\'agrada\" al comentari
     Traduir comentari
-    Esborrar comentari
+    Delete comment
     No als comentaris buits!
     Vols cercar el nom d\'usuari?
     Vols cercar l\'etiqueta?
@@ -232,7 +233,7 @@
     Aprovar la sol·licitud
     Rebutjar la sol·licitud
     Comparteix aquesta publicació pública a…
-    Aquesta és una publicació privada! Comparteix-la amb aquells que la puguin veure!
+    This is a private post! Share to those who can view it.
     Aquesta categoria està buida d\'alguna manera…
     Hi ha disponible una actualització! (%s)
     Recordatori: Si has baixat l\'app des de F-Droid, l\'has d\'actualitzar des d\'allà! El mateix s\'aplica a GitHub.
@@ -264,6 +265,7 @@
     No ho tornis a mostrar fins a la propera actualització
     Versió
     Pantalla d\'inici
+    Show keyboard on search
     General
     Tema
     Descàrregues
@@ -367,6 +369,10 @@
- %d m\'agrada
- %d m\'agrades+    
+
- %d reply+
- %d replies+
- %d comentari
- %d comentaris@@ -484,4 +490,8 @@
     Top
     Recent
     Clear
+    No Map app found!
+    Click to show full like count
+    No profile pic found!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-cs/arrays.xml b/app/src/main/res/values-cs/arrays.xml
index 2a36e922..fe8d3a5c 100644
--- a/app/src/main/res/values-cs/arrays.xml
+++ b/app/src/main/res/values-cs/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Automaticky / Podle systémudiff --git a/app/src/main/res/values-cs/strings.xml b/app/src/main/res/values-cs/strings.xml
index afdd3ee2..1327be32 100644
--- a/app/src/main/res/values-cs/strings.xml
+++ b/app/src/main/res/values-cs/strings.xml
@@ -22,13 +22,13 @@
     Aktivita
     Zkontrolovat aktualizace při spuštění
     Blokovat snímky obrazovky a náhled aplikace
-    Stáhnout příspěvky do složek s uživatelským jménem
-    Připojit uživatelské jméno k názvu souboru
-    Označit příběhy po zhlédnutí jako zobrazené
+    Stáhnout příspěvky do složek se jmény uživatelů
+    Připojit jméno uživatele k názvu souboru
+    Po zobrazení označit příběhy jako zobrazené
     Autor příběhu bude vědět, že jste si jej zobrazili
     Skrýt ztišené příběhy z kanálu
-    Označovat zprávy po zhlédnutí jako zobrazené
-    Ostatní členové uvidí, že jste si ji ji zobrazili
+    Označovat zprávy po zobrazení jako zobrazené
+    Ostatní členové uvidí, že jste si ji je zobrazili
     Povolit oznámení o aktivitě
     Řazení kanálu příběhů
     Chyba při načítání profilu! Je uživatelské jméno platné? Pokud ano, jste možná omezeni Instagramem.
@@ -61,7 +61,7 @@
- %s\nSledujících%s\nSleduje
-    Videa spouštět automaticky
+    Automaticky přehrávat videa
     Pokračovat v přehrávání na pozadí
     Nepozastavovat videa při opuštění aplikace
     Vždy ztlumit videa
@@ -83,7 +83,7 @@
     Odpověď úspěšně odeslána!
- %d odpověď, průměrně %s-
- %d odpovědí, průměrně %s+
- %d odpovědi, průměrně %s
- %d odpovědí, průměrně %s
- %d odpovědí, průměrně %s@@ -114,7 +114,7 @@
     Odebrat ze sbírky
     Líbí se
     Uložené
-    Označeno
+    Označení
     Zpráva
     To se mi líbí
     Už se mi to nelíbí
@@ -131,8 +131,9 @@
     Ztlumit příspěvky
     Zrušit ztlumení příběhů
     Zrušit ztlumení příspěvků
-    Kopírovat bio
-    Přeložit bio
+    Odebrat sledujícího
+    Kopírovat životopis
+    Přeložit životopis
     Vzájemní
     Sleduje
     Sledující
@@ -154,7 +155,7 @@
     Náhled
     Prohodit pozice času a data
     Nemůžete smazat aktuálně používaný účet
-    Opravdu chcete smazat \'%s\'?
+    Opravdu chcete smazat \"%s\"?
     Otevřít profil
     Zobrazit příběh
     Zobrazit obrázek profilu
@@ -240,7 +241,7 @@
     Schválit žádost
     Zamítnout žádost
     Sdílejte tento veřejný příspěvek na…
-    Toto je soukromý příspěvek! Sdílejte jej s těmi, kdo jej mohou vidět!
+    Toto je soukromý příspěvek! Sdílejte jej s těmi, kdo jej mohou vidět.
     Tato kategorie je nějak prázdná…
     Je k dispozici aktualizace! (%s)
     Připomínka: Pokud jste aplikaci stáhli z F-Droidu, musíte ji z něj i aktualizovat! To stejné platí pro GitHub.
@@ -272,6 +273,7 @@
     Do další aktualizace znovu nezobrazovat
     Verze
     Úvodní obrazovka
+    Při otevření vyhledávání zobrazit klávesnici
     Obecné
     Motiv
     Stažené
@@ -377,6 +379,12 @@
- %d se líbí
- %d se líbí+    
+
- %d odpověď+
- %d odpovědi+
- %d odpovědí+
- %d odpovědí+
- %d komentář
- %d komentáře@@ -497,7 +505,11 @@
     Po uložení budou při příštím spuštění vypnuty všechny funkce související s posíláním zpráv
     Kopírovat popisek
     Kopírovat odpověď
-    Top
-    Recent
-    Clear
+    Populární
+    Nedávné
+    Vymazat
+    Nemáte žádnou aplikaci pro mapy!
+    Klepnutím zobrazíte přesný počet \"to se mi líbí\"
+    Nebyl nalezen žádný obrázek profilu!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-de/arrays.xml b/app/src/main/res/values-de/arrays.xml
index 77ce0c18..b232a802 100644
--- a/app/src/main/res/values-de/arrays.xml
+++ b/app/src/main/res/values-de/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Auto / Systemstandarddiff --git a/app/src/main/res/values-de/strings.xml b/app/src/main/res/values-de/strings.xml
index e79dcd1b..60e7d253 100644
--- a/app/src/main/res/values-de/strings.xml
+++ b/app/src/main/res/values-de/strings.xml
@@ -23,14 +23,14 @@
     Beim Start auf Updates prüfen
     Bildschirmfotos & App-Voschau verhindern
     Beiträge in Benutzernamen-Ordner herunterladen
-    Prepend Username to Filename
+    Benutzername dem Dateinamen voranstellen
     Stories nach dem Ansehen als gesehen markieren
     Die Person wird wissen, dass du dir die Story angesehen hast
     Stummgeschaltete Stories im Feed ausblenden
     Direktnachrichten nach dem Ansehen als gesehen markieren
     Andere Mitglieder werden wissen, dass du sie gesehen hast
     Aktivitätsbenachrichtigungen aktivieren
-    Sortierung Storyfeed
+    Sortierung des Storyfeeds
     Fehler beim Laden des Profils! Ist der Benutzername gültig? Wenn ja, könnte es sein, dass deine Zugriffe begrenzt werden.
     Fehler beim Laden des Profils! Ist der Benutzername gültig? Oder haben sie dich blockiert?
     Fehler beim Laden des Hashtags! Ist der Name gültig?
@@ -59,7 +59,7 @@
     Videos im Hintergrund fortführen
     Videos nicht pausieren, wenn die App nicht aktiv ist
     Videos immer stummschalten
-    Bildtext immer anzeigen
+    Bildunterschrift immer anzeigen
     Datei zum Download auswählen
     Aktuell
     Gesamtes Album
@@ -95,7 +95,7 @@
     Abmelden
     Instagram anonym durchsuchen
     Alle Konten entfernen
-    Dadurch werden alle hinzugefügten Konten aus der App entfernt!\nUm nur ein Konto zu entfernen, tippe lange auf das Konto aus dem Kontowechseldialog.\nMöchtest du fortfahren?
+    Dadurch werden alle hinzugefügten Konten aus der App entfernt!\nUm nur ein Konto zu entfernen, tippe lange auf das Konto im Dialogfeld für den Kontowechsel.\nMöchtest du fortfahren?
     Datumsformat
     Neue Sammlung anlegen
     Sammlungsname bearbeiten
@@ -123,6 +123,7 @@
     Beiträge stummschalten
     Stummschaltung von Stories aufheben
     Stummschaltung von Beiträgen aufheben
+    Remove follower
     Steckbrief kopieren
     Steckbrief übersetzen
     Gegenseitig
@@ -158,7 +159,7 @@
     %s hat ein Video geteilt
     %s hat eine Nachricht gesendet
     %s hat ein GIF geteilt
-    %s shared a sticker
+    %s hat einen Sticker geteilt
     %s hat ein Profil geteilt: @%s
     %s hat einen Standort geteilt: %s
     %s teilte ein Story Highlight von @%s
@@ -183,7 +184,7 @@
     Empfohlen
     Screenshot erstellt
     Kann nicht zugestellt werden
-    Unseen count response is null!
+    Ungelesen-Zähler Antwort ist null!
     Nachricht...
     Für Audioaufnahme drücken und halten
     Aktualisieren...
@@ -232,7 +233,7 @@
     Anfrage annehmen
     Anfrage ablehnen
     Diesen öffentlichen Beitrag teilen mit…
-    Dies ist ein privater Beitrag! Teile ihn mit denen, die ihn sehen können!
+    This is a private post! Share to those who can view it.
     Diese Kategorie ist leer…
     Ein Update ist verfügbar! (%s)
     Erinnerung: Wenn du die App von F-Droid heruntergeladen hast, musst du sie dort aktualisieren! Das gilt auch für GitHub.
@@ -250,8 +251,8 @@
     %d gelikte Kommentare
     %d Benutzertags
     %d Likes
-    %d photos of you
-    %d follow requests
+    %d Fotos von dir
+    %d Anfragen dir zu folgen
     Hast du dich abgemeldet, bevor du auf diese Benachrichtigung geklickt hast?
     Feed
     Profil
@@ -264,18 +265,19 @@
     Nicht erneut anzeigen bis zum nächsten Update
     Version
     Startbildschirm
+    Show keyboard on search
     Allgemein
     Design
     Downloads
     Sprache
     Account
-    Aktueller Login funktioniert nicht? Fügen das Konto erneut hinzu.
+    Aktueller Login funktioniert nicht? Füge das Konto erneut hinzu.
     Account hinzufügen
     Lizenz (nur auf Englisch)
     Besuche unsere Webseite
     Bekomme Unterstützung, diskutiere, treffe andere und hab Spaß!
     Quellcode auf GitHub einsehen
-    Prüfe den Code, melde Bugs, werde teil des Projekts und hab (nochmal) Spaß!
+    Prüfe den Code, melde Fehler, werde Teil des Projekts und hab (nochmal) Spaß!
     Feedback per E-Mail senden
     Integration von Drittanbietern
     Erinnerung
@@ -294,10 +296,10 @@
     Unbekannt
     Aus Favoriten entfernt!
     Sichern & Wiederherstellen
-    Backup Barinsta app settings, account login data, and/or favorites to a plain text or encrypted backup file for later restoration.
-    If you\'re backing up account login data, treat the file as confidential and keep it somewhere safe!
-    Erstelle neue Sicherungsdatei
-    Wiederherstellen aus existierender Sicherungsdatei
+    Sichere die Einstellungen der Barinsta-App, die Anmeldedaten des Kontos und/oder die Favoriten in einer Klartext- oder verschlüsselten Sicherungsdatei zur späteren Wiederherstellung.
+    Wenn du die Anmeldedaten eines Kontos sicherst, behandle die Datei vertraulich und bewahre sie an einem sicheren Ort auf!
+    Neue Sicherungsdatei erstellen
+    Aus vorhandener Sicherungsdatei wiederherstellen
     Datei:
     Passwort eingeben
     Wähle eine Sicherungsdatei (.zaai/.backup)
@@ -349,7 +351,7 @@
     Sättigung
     Schärfe
     Belichtung
-    Center
+    Zentrieren
     Farbe
     Beginn
     Ende
@@ -367,6 +369,10 @@
- %d Person gefällt das
- %d Personen gefällt das+    
+
- %d Antwort+
- %d Antworten+
- %d Kommentar
- %d Kommentare@@ -437,28 +443,28 @@
     Chat beenden?
     Alle Mitglieder werden aus der Gruppe entfernt. Sie werden weiterhin in der Lage sein, den Chatverlauf anzuzeigen.
     Ausstehende Anfragen
-    Accept request from %1s (%2s)?
+    Anfrage von %1s (%2s) akzeptieren?
     Ablehnen
     Aktzeptieren
     Du
     Keine ausstehenden Anfragen
-    Checking for new messages
+    Auf neue Nachrichten prüfen
     Stories
     PN
     Benachrichtigungen
     Beitrag
     PN-Benachrichtigungen aktivieren
-    Auto refresh messages
-    Auto refresh every
+    Lade neue Nachrichten automatisch
+    Automatisch neuladen alle
     Sek.
     Min.
     GIPHY durchsuchen
-    Response is null!
-    Response status is not ok!
+    Antwort ist Null!
+    Antwortstatus ist nicht in Ordnung!
     Anfrage fehlgeschlagen!
-    Keyword
-    Enable keyword filter
-    Edit keyword filters
+    Suchbegriff
+    Aktiviere Suchbegriff-Filter
+    Suchbegriff-Filter bearbeiten
     Added keyword: %s to filter list
     Removed keyword: %s from filter list
     Als gesehen markieren
@@ -467,21 +473,25 @@
     Fehler
     Dieses Konto wurde abgemeldet.
     Anmeldung erforderlich!
-    Sentry block.
+    Sentry Block.
     Benutzer ist inaktiv!
     Barinsta Absturzbericht
     Wähle eine E-Mail-App zum Senden von Absturzprotokollen
     Nicht gefunden!
     Instagram hat die Zugriffe mit deiner IP begrenzt. Warte eine Stunde lang und versuche es erneut.
     Dieses Update überspringen
-    You\'re already on the latest version
+    Du bist bereits auf der neuesten Version
     Reihenfolge der Anzeige
     Andere Registerkarten
     Die Reihenfolge der Registerkarten wird beim nächsten Start übernommen
     Wenn übernommen, werden alle PN-bezogenen Funktionen beim nächsten Start deaktiviert
-    Copy caption
-    Copy reply
-    Top
-    Recent
-    Clear
+    Bildunterschrift kopieren
+    Antwort kopieren
+    Anfang
+    Neueste
+    Leeren
+    Keine Karten-App gefunden!
+    Click to show full like count
+    Kein Profilbild gefunden!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-el/arrays.xml b/app/src/main/res/values-el/arrays.xml
index 73e78c08..2848f429 100644
--- a/app/src/main/res/values-el/arrays.xml
+++ b/app/src/main/res/values-el/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Αυτόματα / Ακολούθηση Συστήματοςdiff --git a/app/src/main/res/values-el/strings.xml b/app/src/main/res/values-el/strings.xml
index f1349a66..b3af63ce 100644
--- a/app/src/main/res/values-el/strings.xml
+++ b/app/src/main/res/values-el/strings.xml
@@ -123,6 +123,7 @@
     Σίγαση δημοσιεύσεων
     Άρση σίγασης ιστοριών
     Άρση σίγασης δημοσιεύσεων
+    Αφαίρεση ακόλουθου
     Αντιγραφή βιογραφικού
     Μετάφραση βιογραφικού
     Κοινά
@@ -232,7 +233,7 @@
     Έγκριση αιτήματος
     Απόρριψη αιτήματος
     Κοινοποιήστε αυτή τη δημόσια δημοσίευση στο…
-    Αυτή είναι ιδιωτική δημοσίευση! Κοινοποιήστε τη σε εκείνους που μπορούν να τη δουν!
+    Ιδιωτική δημοσίευση! Κοινοποιήστε την σε όσους μπορούν να τη δουν.
     Αυτή η κατηγορία είναι κατά κάποιον τρόπο κενή…
     Υπάρχει διαθέσιμη ενημέρωση! (%s)
     Υπενθύμιση: Εάν η εγκατάσταση έγινε από το F-Droid, από εκεί θα χρειαστεί να γίνουν κι οι ενημερώσεις! Το ίδιο ισχύει και για το GitHub.
@@ -264,6 +265,7 @@
     Να μην εμφανιστεί ξανά μέχρι την επόμενη ενημέρωση
     Έκδοση
     Οθόνη εκκίνησης
+    Εμφάνιση πληκτρολογίου στην αναζήτηση
     Γενικά
     Θέμα
     Λήψεις
@@ -367,6 +369,10 @@
- Αρέσει σε %d
- Αρέσει σε %d+    
+
- %d απάντηση+
- %d απαντήσεις+
- %d σχόλιο
- %d σχόλια@@ -481,7 +487,11 @@
     Εάν αποθηκευτεί, όλες οι λειτουργίες που είναι σχετικές με τα Μηνύματα, θα είναι απενεργοποιημένες στην επόμενη εκκίνηση
     Αντιγραφή λεζάντας
     Αντιγραφή απάντησης
-    Top
-    Recent
-    Clear
+    Κορυφή
+    Πρόσφατα
+    Εκκαθάριση
+    Δε βρέθηκε εφαρμογή για χάρτες!
+    Σε πόσους ακριβώς αρέσει
+    Δε βρέθηκε εικόνα προφίλ!
+    Είστε βέβαιος για το άνοιγμα αυτού του συνδέσμου;
 
diff --git a/app/src/main/res/values-es/arrays.xml b/app/src/main/res/values-es/arrays.xml
index 4d5bed14..1d115c10 100755
--- a/app/src/main/res/values-es/arrays.xml
+++ b/app/src/main/res/values-es/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Auto / Seguir al sistemadiff --git a/app/src/main/res/values-es/strings.xml b/app/src/main/res/values-es/strings.xml
index 89e604e2..3557df23 100755
--- a/app/src/main/res/values-es/strings.xml
+++ b/app/src/main/res/values-es/strings.xml
@@ -123,6 +123,7 @@
     Silenciar publicaciones
     Quitar silencio a historias
     Quitar silencio a publicaciones
+    Quitar seguidor
     Copiar biografía
     Traducir biografía
     Mutuo
@@ -232,7 +233,7 @@
     Aprobar solicitud
     Rechazar solicitud
     Compartir esta publicación pública a…
-    ¡Esta es una publicación privada! ¡Comparta con aquellos que puedan verla!
+    ¡Esta es una publicación privada! Comparte con quienes puedan verla.
     Esta categoría está de alguna manera vacía…
     ¡Hay una actualización disponible! (%s)
     Recordatorio: si ha descargado de F-Droid, ¡debe actualizar desde él! Lo mismo se aplica a GitHub.
@@ -264,6 +265,7 @@
     No mostrar de nuevo hasta la siguiente actualización
     Versión
     Pantalla de inicio
+    Mostrar teclado al buscar
     General
     Tema
     Descargas
@@ -367,6 +369,10 @@
- %d me gusta
- %d me gustas+    
+
- %d respuesta+
- %d respuestas+
- %d comentario
- %d comentarios@@ -481,7 +487,11 @@
     Si se guarda, todas las funcionalidades relacionadas con MDs se desactivarán en el próximo lanzamiento
     Copiar título
     Copiar respuesta
-    Top
-    Recent
-    Clear
+    Arriba
+    Reciente
+    Eliminar
+    ¡No se encontró una aplicación de mapa!
+    Clic para ver el recuento completo de me gustas
+    ¡No se encontró foto de perfil!
+    ¿Está seguro de querer abrir este enlace?
 
diff --git a/app/src/main/res/values-eu/arrays.xml b/app/src/main/res/values-eu/arrays.xml
index 9e98429a..3d3a56b6 100644
--- a/app/src/main/res/values-eu/arrays.xml
+++ b/app/src/main/res/values-eu/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Automatikoa / Jarraitu sistemadiff --git a/app/src/main/res/values-eu/strings.xml b/app/src/main/res/values-eu/strings.xml
index ca7935ec..fa007f57 100644
--- a/app/src/main/res/values-eu/strings.xml
+++ b/app/src/main/res/values-eu/strings.xml
@@ -123,6 +123,7 @@
     Mute posts
     Unmute stories
     Unmute posts
+    Remove follower
     Kopiatu biografia
     Itzuli biografia
     Alde bikoa
@@ -211,7 +212,7 @@
     Atsegin iruzkina
     Ez dut atsegin
     Itzuli iruzkina
-    Ezabatu iruzkina
+    Delete comment
     Iruzkin hutsik ez!
     Erabiltzaile-izena bilatu nahi duzu?
     Traol-hitza bilatu nahi duzu?
@@ -232,7 +233,7 @@
     Onartu eskaera
     Baztertu eskaera
     Partekatu bidalketa publiko hau…
-    Bidalketa pribatua da. Partekatu ikus dezaketen horiekin!
+    This is a private post! Share to those who can view it.
     Kategoria hau hutsik dago…
     Eguneratze bat eskuragarri dago (%s)
     F-Droidetik deskargatu baduzu, bertatik eguneratu behar duzu. GitHubekin ere hori egin behar da.
@@ -264,6 +265,7 @@
     Ez erakutsi hurrengo eguneratzera arte
     Bertsioa
     Hasierako pantaila
+    Show keyboard on search
     Orokorra
     Gaia
     Deskargak
@@ -367,6 +369,10 @@
- atsegite %d
- %d atsegite+    
+
- %d reply+
- %d replies+
- Iruzkin %d
- %d iruzkin@@ -484,4 +490,8 @@
     Top
     Recent
     Clear
+    No Map app found!
+    Click to show full like count
+    No profile pic found!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-fa/arrays.xml b/app/src/main/res/values-fa/arrays.xml
index b52e999e..224e3847 100644
--- a/app/src/main/res/values-fa/arrays.xml
+++ b/app/src/main/res/values-fa/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- خودکار / پیرو سامانهdiff --git a/app/src/main/res/values-fa/strings.xml b/app/src/main/res/values-fa/strings.xml
index 43c21b1e..729a7f72 100644
--- a/app/src/main/res/values-fa/strings.xml
+++ b/app/src/main/res/values-fa/strings.xml
@@ -124,6 +124,7 @@
     Mute posts
     Unmute stories
     Unmute posts
+    Remove follower
     Copy bio
     Translate bio
     Mutual
@@ -212,7 +213,7 @@
     پسندیدن دیدگاه
     نپسندیدن دیدگاه
     گرداندن دیدگاه
-    هذف دیدگاه
+    Delete comment
     بدون دیدگاه تهی!
     ایا میخواهید نام کاربری جستوجو کنید ؟
     آیا میخواهید هشتگ جستوجو کنید؟
@@ -233,7 +234,7 @@
     قبول درخواست
     رد درخواست
     همرسانی این پیک همگانی به…
-    این پست شخصی است! آنهایی رو به اشتراک بزارید که میتوانید ببینید!
+    This is a private post! Share to those who can view it.
     This category is somehow empty…
     یک بروزرسانی آمده است! (%s)
     یادآور: اگه شما از F-Droid دانلود کرده اید، شما باید از همانجا بروزرسانی کنید! برای GitHub هم همینطور.
@@ -265,6 +266,7 @@
     دوباره نمایش نده تا بروزرسانی بعدی
     نگارش
     صفحه آغازین
+    Show keyboard on search
     فراگیر
     پوسته
     دریافتها
@@ -368,6 +370,10 @@
- %d پسند
- %d پسند+    
+
- %d reply+
- %d replies+
- %d دیدگاه
- %d دیدگاه@@ -485,4 +491,8 @@
     Top
     Recent
     Clear
+    No Map app found!
+    Click to show full like count
+    No profile pic found!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-fr/arrays.xml b/app/src/main/res/values-fr/arrays.xml
index b2c5109e..3e1ff302 100755
--- a/app/src/main/res/values-fr/arrays.xml
+++ b/app/src/main/res/values-fr/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Automatique (Système)diff --git a/app/src/main/res/values-fr/strings.xml b/app/src/main/res/values-fr/strings.xml
index 419d965e..519224e2 100755
--- a/app/src/main/res/values-fr/strings.xml
+++ b/app/src/main/res/values-fr/strings.xml
@@ -123,6 +123,7 @@
     Mute les publications
     Démute les stories
     Démutez les publications
+    Remove follower
     Copier la bio
     Traduire la bio
     Mutuel
@@ -232,7 +233,7 @@
     Approuver la demande
     Refuser la demande
     Partage cette publication publique…
-    C\'est post privé ! Partagez avec ceux qui peuvent le voir !
+    This is a private post! Share to those who can view it.
     Cette catégorie est en quelque sorte vide…
     Une mise-à-jour est disponible! (%s)
     Rappel : Si vous avez téléchargé l\'application à partir de F-Droid, vous devez la mettre à jour depuis là ! Il en va de même pour GitHub.
@@ -264,6 +265,7 @@
     Ne plus afficher jusqu\'à la prochaine mise à jour
     Version
     Écran d\'accueil
+    Show keyboard on search
     Général
     Thème
     Téléch.
@@ -367,6 +369,10 @@
- %d j\'aime
- %d j\'aimes+    
+
- %d réponse+
- %d réponses+
- %d commentaire
- %d commentaires@@ -481,7 +487,11 @@
     Si enregistré, toutes les fonctionnalités liées aux DM seront désactivées au prochain lancement
     Copie de la légende
     Copie de la réponse
-    Top
-    Recent
-    Clear
+    Retour vers le haut
+    Récent
+    Nettoyer
+    Aucune application de carte trouvée!
+    Click to show full like count
+    Aucune photo de profil trouvée !
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-hi/arrays.xml b/app/src/main/res/values-hi/arrays.xml
index cf9cde1c..031806e6 100644
--- a/app/src/main/res/values-hi/arrays.xml
+++ b/app/src/main/res/values-hi/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- सिस्टम के अनुसारdiff --git a/app/src/main/res/values-hi/strings.xml b/app/src/main/res/values-hi/strings.xml
index 1b4546c0..2d54df98 100644
--- a/app/src/main/res/values-hi/strings.xml
+++ b/app/src/main/res/values-hi/strings.xml
@@ -124,6 +124,7 @@
     Mute posts
     Unmute stories
     Unmute posts
+    Remove follower
     विवरण कॉपी करें
     Translate bio
     Mutual
@@ -212,7 +213,7 @@
     टिप्पणी को पसन्द करें
     टिप्पणी को पसन्द न करें
     Translate comment
-    टिप्पणी हटाएँ
+    Delete comment
     रिक्त टिप्पणी न करें!
     युज़रनेम को ढूंढ़ना चाहते हैं?
     हैशटैग को ढूंढ़ना चाहते हैं?
@@ -233,7 +234,7 @@
     निवेदन को ग्रहण करें
     अनुरोध प्रत्याख्यान करें
     इसी सार्वजनिक पोस्ट को भेजें...
-    यह एक गुप्त पोस्ट है! उन लोगों को बांटना जो उन्हें देख सकते हैं!
+    This is a private post! Share to those who can view it.
     यह वर्ग रिक्त है...
     नया संस्करण उपलब्ध है! (%s)
     याद रखें: अगर आपने f-droid से डाउनलोड किया है तो उसी से ही अपडेट करें! Github के लिये भी बही।
@@ -265,6 +266,7 @@
     Do not show again until next update
     संस्करण
     प्रारंभ पृष्ठ
+    Show keyboard on search
     सामान्य
     थीम
     डाउनलोड
@@ -368,6 +370,10 @@
- %d like
- %d likes+    
+
- %d reply+
- %d replies+
- %d comment
- %d comments@@ -485,4 +491,8 @@
     Top
     Recent
     Clear
+    No Map app found!
+    Click to show full like count
+    No profile pic found!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-in/arrays.xml b/app/src/main/res/values-in/arrays.xml
index 1ce3efc0..a565871d 100644
--- a/app/src/main/res/values-in/arrays.xml
+++ b/app/src/main/res/values-in/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Otomatis / Ikuti Sistemdiff --git a/app/src/main/res/values-in/strings.xml b/app/src/main/res/values-in/strings.xml
index 8ebaa05e..43c647f2 100644
--- a/app/src/main/res/values-in/strings.xml
+++ b/app/src/main/res/values-in/strings.xml
@@ -119,6 +119,7 @@
     Mute posts
     Unmute stories
     Unmute posts
+    Remove follower
     Salin bio
     Terjemahkan bio
     Mutual
@@ -207,7 +208,7 @@
     Suka komentar
     Batal suka komentar
     Terjemahkan komentar
-    Hapus komentar
+    Delete comment
     Ups, komentar kosong!
     Apakah anda ingin mencari nama pengguna ini?
     Apakah anda ingin mencari tagar ini?
@@ -228,7 +229,7 @@
     Terima permintaan
     Tolak permintaan
     Bagikan kiriman publik ini ke…
-    Kiriman privat! Bagikan kepada orang yang bisa melihatnya!
+    This is a private post! Share to those who can view it.
     Entah bagaimana kategori ini kosong…
     Ada pembaruan! (%s)
     Kiat: Jika anda mengunduh InstaGrabber dari F-Droid, perbarui dari situ. Juga berlaku jika diunduh lewat GitHub.
@@ -260,6 +261,7 @@
     Jangan tampilkan lagi sampai pembaruan berikutnya
     Versi
     Layar mulai
+    Show keyboard on search
     Umum
     Tema
     Unduhan
@@ -362,6 +364,9 @@
- %d suka+    
+
- %d replies+
- %d komentar@@ -476,4 +481,8 @@
     Top
     Recent
     Clear
+    No Map app found!
+    Click to show full like count
+    No profile pic found!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-it/arrays.xml b/app/src/main/res/values-it/arrays.xml
index b95a3a1a..95d3f066 100755
--- a/app/src/main/res/values-it/arrays.xml
+++ b/app/src/main/res/values-it/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Automatico / Basato sul Sistemadiff --git a/app/src/main/res/values-it/strings.xml b/app/src/main/res/values-it/strings.xml
index c4249bea..2d73e7ad 100755
--- a/app/src/main/res/values-it/strings.xml
+++ b/app/src/main/res/values-it/strings.xml
@@ -123,6 +123,7 @@
     Silenzia post
     Riattiva storie
     Riattiva i post
+    Rimuovi seguace
     Copia bio
     Traduci bio
     Interesse reciproco
@@ -232,7 +233,7 @@
     Approva richiesta
     Rifiuta richiesta
     Condividi questo post pubblico a…
-    Questo è un post privato! Condividilo con chi può visualizzarlo!
+    Questo è un post privato! Condividi con coloro che possono vederlo.
     Questa categoria è in qualche modo vuota…
     Un aggiornamento è disponibile! (%s)
     Promemoria: Se hai scaricato da F-Droid, devi aggiornare da lì! Lo stesso vale per GitHub.
@@ -264,6 +265,7 @@
     Non mostrare più fino al prossimo aggiornamento
     Versione
     Schermata iniziale
+    Mostra la tastiera nella ricerca
     Generale
     Tema
     Scaricati
@@ -367,6 +369,10 @@
- %d Mi piace
- %d Mi piace+    
+
- %d risposta+
- %d risposte+
- %d commento
- %d commenti@@ -481,7 +487,11 @@
     Se salvate, tutte le funzionalità correlate a DM saranno disabilitate al prossimo avvio
     Copia didascalia
     Copia risposta
-    Top
-    Recent
-    Clear
+    Torna su
+    Recente
+    Pulisci
+    Nessuna app mappa trovata!
+    Clicca per mostrare il conteggio completo
+    Nessuna foto profilo trovata!
+    Sei sicuro di voler aprire questo link?
 
diff --git a/app/src/main/res/values-ja/arrays.xml b/app/src/main/res/values-ja/arrays.xml
index f47c31b0..3a84bc38 100644
--- a/app/src/main/res/values-ja/arrays.xml
+++ b/app/src/main/res/values-ja/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- 自動/システム設定に従うdiff --git a/app/src/main/res/values-ja/strings.xml b/app/src/main/res/values-ja/strings.xml
index 27a59ddb..70c6b264 100644
--- a/app/src/main/res/values-ja/strings.xml
+++ b/app/src/main/res/values-ja/strings.xml
@@ -119,6 +119,7 @@
     投稿をミュート
     ストーリーズのミュートを解除
     投稿のミュートを解除
+    Remove follower
     プロフィールをコピー
     プロフィールを翻訳する
     相互フォロー
@@ -228,7 +229,7 @@
     リクエストを承認
     リクエストを拒否
     シェア先…
-    これはプライベートな投稿です!閲覧できる人に共有してください!
+    This is a private post! Share to those who can view it.
     このカテゴリは空です…
     アップデートが利用可能です! (%s)
     注意: F-Droidからダウンロードした場合は、そちらからアップデートする必要があります。GitHubでも同様です。
@@ -240,13 +241,13 @@
     おすすめのユーザー
     画像を選択
     アップロード中…
-    You have:
+    あなたのステータス:
     %d 人のフォロワー
     %d コメント
     %d 個のコメントへのいいね!
     %d 個のタグ付け
     %d いいね!
-    %d photos of you
+    %d 枚のあなたの写真
     %d 件のフォローリクエスト
     この通知をクリックする前にログアウトしましたか?
     フィード
@@ -260,6 +261,7 @@
     次回の更新まで再表示しない
     バージョン
     起動画面
+    Show keyboard on search
     全般
     テーマ
     ダウンロード
@@ -362,6 +364,9 @@
- %d いいね!+    
+
- %d 件の返信+
- %d コメント@@ -401,42 +406,42 @@
     %sに返信しました
     あなたへの返信
     Replied to themself
-    You reacted to their story
-    Reacted to your story
-    You mentioned them in your story
-    Mentioned you in their story
-    You replied to their story
-    Replied to your story
-    Image has expired
-    Image will expire when seen
-    Video has expired
-    Video will expire when seen
-    Message has expired
-    Message will expire when seen
-    \@%s\'s story
-    \@%s\'s story highlight
+    次のストーリーに返信しました
+    あなたのストーリーに反応しました
+    ストーリーでメンションしました
+    ストーリーであなたをメンションしました
+    ストーリーに返信しました
+    あなたのストーリーに返信しました
+    画像が期限切れです
+    画像が表示されると期限切れになります
+    ビデオが期限切れです
+    ビデオが表示されると期限切れになります
+    メッセージが期限切れです
+    メッセージが表示されると期限切れになります
+    \@%sのストーリー
+    \@%sのストーリーハイライト
     写真
     ビデオ
     ボイスメッセージ
     ポスト
     参加には承認が必要です
-    Requests
-    Admins only
-    Added by %s
-    Admin approval required
-    An admin approval will be required to add new members to the group
-    End chat
-    End chat?
-    All members will be removed from the group. They will still be able to view the chat history.
-    Pending Requests
+    リクエスト
+    管理者のみ
+    %sに追加されました
+    管理者の承認が必要です
+    グループに新しいメンバーを追加するには管理者の承認が必要です
+    チャットを終了
+    チャットを終了しますか?
+    すべてのメンバーがグループから削除されます。メンバーはチャット履歴を表示することができます。
+    保留中のリクエスト
     %1s (%2s) からのリクエストを承認しますか?
-    Decline
-    Accept
+    拒否する
+    承認する
     You
-    No pending requests
-    Checking for new messages
-    Stories
-    DM
+    保留中のリクエストはありません
+    新着メッセージを確認中
+    ストーリーズ
+    メッセージ
     通知
     ポスト
     DMの通知を有効にする
@@ -453,7 +458,7 @@
     キーワードフィルタを編集する
     リストをフィルタするキーワード: %s を追加しました
     リストをフィルタするキーワード: %s を削除しました
-    Marked as seen
+    既読にする
     削除に失敗しました
     APIリクエストが多すぎるためInstagramから制限を受けました。しばらく待ってから再試行してください。
     エラー
@@ -465,15 +470,19 @@
     クラッシュログを送信するメールアプリを選択してください
     見つかりません!
     あなたのIPアドレスはInstagramによって制限されています。1時間待ってからもう一度お試しください。
-    Skip this update
-    You\'re already on the latest version
+    このアップデートをスキップ
+    すでに最新バージョンをご利用中です
     Screen order
     Other tabs
-    The tab order will be reflected on next launch
+    タブの順序は次回の起動時に反映されます
     If saved, all DM related features will be disabled on next launch
-    Copy caption
-    Copy reply
-    Top
-    Recent
-    Clear
+    キャプションをコピー
+    返信をコピー
+    関連
+    最近
+    クリア
+    有効な地図アプリが見つかりません
+    Click to show full like count
+    プロフィール写真が見つかりません!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-ko/arrays.xml b/app/src/main/res/values-ko/arrays.xml
new file mode 100644
index 00000000..865d45c1
--- /dev/null
+++ b/app/src/main/res/values-ko/arrays.xml
@@ -0,0 +1,62 @@
+
+
+    
+
- 시스템 기본 설정+
- English+
- Français+
- Español+
- 简体中文+
- Bahasa Indonesia+
- Italiano+
- Deutsch+
- Polski+
- Türkçe+
- Português (Brasil)+
- پارسی+
- Македонски+
- Tiếng Việt+
- 繁體中文+
- Català+
- Русский+
- हिन्दी+
- Nederlands+
- Slovenčina+
- 日本語+
- Ελληνικά+
- Euskara+
- Svenska+
- 한국어+    
+    
+
- 오토 / 시스템 따르기+
- 오토 / 배터리 따르기+
- 다크 모드+
- 라이트 모드+    
+    
+
- 인스타그램 기본 설정+
- 최신순+
- 오래된순+    
+    
+
- 없음+
- \@+
- 에+
- 에+
- \|+
- -+    
+    
+    
+    
+    
+    
+    
+    
+    
+    
+    
+
- 초+
- 분+    
+
diff --git a/app/src/main/res/values-ko/strings.xml b/app/src/main/res/values-ko/strings.xml
new file mode 100644
index 00000000..8d20db42
--- /dev/null
+++ b/app/src/main/res/values-ko/strings.xml
@@ -0,0 +1,488 @@
+
+
+    정보
+    다이렉트
+    설정
+    다운로드
+    사용자 이름 검색
+    비교
+    텍스트 복사 오류
+    클립보드에 복사됨
+    신고
+    비밀번호로 파일 보호
+    비밀번호
+    OK
+    네
+    취소
+    아니오
+    확인
+    즐겨찾기
+    발견
+    댓글
+    활동
+    시작시 업데이트 확인
+    Block screenshots & app preview
+    Download posts to username folders
+    Prepend Username to Filename
+    Mark stories as seen after viewing
+    Story author will know you viewed it
+    Hide muted stories from feed
+    Mark DM as seen after viewing
+    Other members will know you viewed it
+    Enable activity notifications
+    Feed stories sort
+    Error loading profile! Is the username valid? If so, you may be ratelimited.
+    Error loading profile! Is the username valid? Or did they block you?
+    Error loading hashtag! Is the name valid?
+    Error loading location! Is the URL valid?
+    Error creating Download folder(s).
+    Save to custom folder
+    폴더 선택
+    테마
+    Only affects logged-in users:
+    Only affects anonymous users:
+    언어
+    
+
- %s\n게시물+    
+    
+
- %s 게시물+    
+    
+
- %s\n팔로워+    
+    %s\n팔로잉
+    비디오 자동 재생
+    백그라운드에서 비디오 계속
+    앱의 초점이 맞지 않을 때 비디오를 일시 중지하지 않음
+    비디오 항상 음소거
+    게시물 문구 항상 보임
+    다운로드할 것을 선택하십시오
+    현재
+    앨범 전체
+    스토리 보임
+    새 스토리 없음
+    기다려주세요.
+    게시물 보기
+    게시물 보기
+    Spotify
+    투표
+    투표 성공!
+    이미 투표하셨습니다
+    메시지 보내기
+    답변...
+    답변 성공!
+    
+
- %d 개의 반응 평균 %s+    
+    내 답변: %s
+    스토리 답장 보내기
+    답글 달기...
+    퀴즈
+    슬라이더
+    이미 답변하셨습나다.
+    언급
+    비공개 계정입니다
+    언팔로우하면 게시물을 볼 수 없겠습니다. 확실합니까?
+    You can log in via More -> Account on the bottom-right corner or you can view public accounts without login!
+    계정에 게시물이 없음
+    게시물 없음
+    로그인
+    로그아웃
+    인스타그램에서 익명으로 검색하기
+    모든 계정 제거
+    This will remove all added accounts from the app!\nTo remove just one account, long tap the account from the account switcher dialog.\nDo you want to continue?
+    날짜 형식
+    새 컬렉션 만들기
+    컬렉션 이름 수정
+    컬렉션 삭제
+    Are you sure you want to delete this collection?
+    All contained media will remain in other collections.
+    컬렉션에 저장...
+    컬렉션에서 제거
+    좋아하는 게시물
+    저장됨
+    태그됨
+    메시지
+    좋아요
+    좋아요 취소
+    북마크 하기
+    북마크에서 제거
+    팔로우
+    팔로우 취소
+    즐겨찾기
+    차단
+    차단 해제
+    제한
+    제한 해제
+    스토리 음소거
+    게시물 음소거
+    스토리 음소거 해제
+    게시물 음소거 해제
+    Remove follower
+    소개 복사
+    소개 번역
+    서로친구
+    팔로잉
+    팔로워
+    맵
+    계정
+    설정
+    즐겨찾기
+    Successfully imported!
+    Failed to import!
+    Successfully exported!
+    Failed to export!
+    새로고침
+    Get cookies
+    Desktop Mode
+    Use custom format
+    Separator
+    시간 형식
+    날짜 형식
+    미리 보기
+    Swap Time and Date positions
+    Cannot delete currently in use account
+    Are you sure you want to delete \'%s\'?
+    프로필 보기
+    스토리 보기
+    프로필 사진 보기
+    Unsupported message type
+    보내기 취소
+    GIPHY에서 보기
+    %s shared a post by @%s
+    %s shared an image
+    %s shared a video
+    %s sent a message
+    %s shared a gif
+    %s shared a sticker
+    %s shared a profile: @%s
+    %s shared a location: %s
+    %s shared a story highlight by @%s
+    %s shared a story by @%s
+    %s sent a voice message
+    %s shared a clip by @%s
+    %s shared an IGTV video by @%s
+    You replied to their story: %s
+    %s replied to your story: %s
+    You reacted to their story: %s
+    %s reacted to your story: %s
+    You mentioned @%s in your story
+    %s mentioned you in their story
+    Unknown media type
+    Media expired!
+    전달됨
+    전송됨
+    확인함
+    재생
+    전송중…
+    차단됨
+    추천
+    스크린샷
+    Cannot deliver
+    Unseen count response is null!
+    메시지...
+    Press and hold to record audio
+    Updating...
+    채팅 나가기
+    이 채팅에서 나가시겠습니까?
+    Kick
+    Left users
+    Invalid user
+    Instagram does not allow uploading videos longer than 60 secs for DM.
+    Instagram does not allow uploading audio longer than 60 secs.
+    Download directly
+    Downloads posts directly to the phone!
+    Fetching post(s)
+    Download completed
+    Downloading post…
+    Downloading media
+    Downloading profile picture
+    Unknown error occurred!!!
+    Error creating folder!
+    Error downloading file
+    You can only download 100 posts at a time. Don\'t be too greedy!
+    댓글 복사
+    좋아요 보기
+    답글 달기
+    댓글 좋아요
+    댓글 좋아요 삭제
+    댓글 번역
+    댓글 삭제
+    빈 댓글이 안 됍니다.
+    Do you want to search the username?
+    Do you want to search the hashtag?
+    팔로워
+    팔로잉
+    Comparing followers & following
+    Both following each other
+    not following %s
+    %s is not following
+    Error loading cookies
+    Write a new comment…
+    Write a new message…
+    Liked your post
+    Commented on your post:
+    Started following you
+    Tagged you in a post
+    Requested following you
+    Approve request
+    Reject request
+    Share this public post to…
+    This is a private post! Share to those who can view it.
+    This category is somehow empty…
+    An update is available! (%s)
+    Reminder: If you downloaded from F-Droid, you must update from it! Same applies for GitHub.
+    Thank you for updating Barinsta!
+    App crashed
+    Oops.. the app crashed, but don\'t worry you can send error report to the developer to help him fix the issue. (:
+    활동
+    보관됨 스토리
+    프로필 추천
+    사진 선택
+    업로드 중…
+    You have:
+    %d follows
+    %d comments
+    %d comment likes
+    %d usertags
+    %d likes
+    %d photos of you
+    %d follow requests
+    You logged out before clicking this notification?!
+    피드
+    프로필
+    더 보기
+    메시지
+    %d selected
+    Successfully logged out!
+    정보
+    Mark as seen
+    Do not show again until next update
+    Version
+    시작 화면
+    Show keyboard on search
+    일반
+    테마
+    다운로드
+    Locale
+    계정
+    Current login not working? Simply add the account again.
+    계정 추가하기
+    License (English only)
+    Visit our website
+    Get support, discuss, meet others, and have fun!
+    See our source code on GitHub
+    Audit, star, report bugs, contribute, and have fun (again)!
+    Send feedback by email
+    Third-Party Attributions
+    알람
+    Please use this app responsibly. Downloaded images should only be used for purposes allowed by applicable laws.
+    흰색
+    검은색
+    라이트테마
+    다크테마
+    Barista
+    머티리얼 다크
+    즐겨찾기에 추가되었습니다!
+    즐겨찾기에 추가
+    계정
+    해시태그
+    위치
+    알 수 없음
+    즐겨찾기에서 삭제되었습니다!
+    Backup & Restore
+    Backup Barinsta app settings, account login data, and/or favorites to a plain text or encrypted backup file for later restoration.
+    If you\'re backing up account login data, treat the file as confidential and keep it somewhere safe!
+    Create new backup file
+    Restore from existing backup file
+    파일:
+    비밀번호를 입력하세요
+    Select a backup file (.zaai/.backup)
+    적용
+    저장
+    문구
+    문구 수정
+    문구 번역
+    동영상 플레이어 타임라인
+    좋아요 중...
+    좋아요 실패
+    좋아요 취소 실패
+    좋아요 취소 중...
+    제어
+    저장 중...
+    제거중...
+    저장 실패
+    제거 실패
+    다운로드 중...
+    %2$d중에 %1$d 다운로드
+    삭제
+    댓글 달기
+    레이아웃
+    피드 스토리
+    게시물 열기 중...
+    공유
+    레이아웃 스타일
+    Column count
+    2
+    3
+    이름 표시
+    아바타 표시
+    아바타 크기
+    모서리
+    그리드 간격 표시
+    애니메이션 비활성화
+    Please wait for the current task to complete first!
+    Depending on user counts, this can take a while to load. Please be patient.
+    게시글을 찾지 못했습니다.
+    URL을 여는 앱이 없습니다.
+    갤러리
+    카메라
+    모든 사진
+    모든 미디어
+    모든 동영상
+    밝기
+    대비
+    생동감
+    채도
+    선명하게
+    노출
+    중앙
+    색
+    시작
+    끝
+    양측 블러
+    배경 흐리게
+    박스 흐림
+    세피아
+    Clarendon
+    1977
+    Aden
+    리셋
+    잘라내기
+    보통
+    
+
- 좋아요 %d개+    
+    
+
- 답장 %d개+    
+    
+
- 댓글 %d개+    
+    
+
- 조회수 %d+    
+    
+
- %s개 스토리+    
+    Storage permission not granted!
+    상세내용
+    제목
+    멤버
+    관리자
+    초청자
+    메시지 알림 해제
+    언급 알림 해제
+    멤버 추가
+    검색
+    완료
+    관리자로 지정
+    관리자 제거
+    Edit was unsuccessful
+    메시지
+    답장
+    제거하려면 탭하세요
+    전달
+    회원님이 메시지를 전달했습니다.
+    메시지를 전달했습니다.
+    추가
+    보내기
+    자신에게 답장 중
+    %s에게 답장 중
+    회원님이 자신에게 답장했습니다
+    회원님이 답장했습니다
+    회원님이 %s에게 답장했습니다
+    %s에게 답장했습니다
+    회원님에게 답장했습니다
+    Replied to themself
+    회원님이 스토리에 공감했습니다
+    회원님의 스토리에 공감했습니다
+    You mentioned them in your story
+    Mentioned you in their story
+    회원님이 스토리에 답장을 보냈습니다
+    회원님의 스토리에 답장을 보냈습니다
+    Image has expired
+    Image will expire when seen
+    Video has expired
+    Video will expire when seen
+    Message has expired
+    Message will expire when seen
+    \@%s\'s story
+    \@%s\'s story highlight
+    사진
+    동영상
+    음성 메시지
+    게시물
+    가입하려면 승인 필요
+    요청
+    관리자 전용
+    %s님이 추가했습니다
+    관리자 승인 필요
+    An admin approval will be required to add new members to the group
+    End chat
+    End chat?
+    All members will be removed from the group. They will still be able to view the chat history.
+    Pending Requests
+    Accept request from %1s (%2s)?
+    거절
+    확인
+    당신
+    No pending requests
+    Checking for new messages
+    스토리
+    메시지
+    알림
+    게시물
+    통화 일림 활성화
+    Auto refresh messages
+    Auto refresh every
+    초
+    분
+    GIPHY 검색
+    Response is null!
+    Response status is not ok!
+    Request failed!
+    Keyword
+    Enable keyword filter
+    Edit keyword filters
+    Added keyword: %s to filter list
+    Removed keyword: %s from filter list
+    Marked as seen
+    Delete unsuccessful
+    Throttled by Instagram because of too many API requests. Wait for some time before retrying.
+    오류
+    This account has been logged out.
+    Login required!
+    Sentry block.
+    User is inactive!
+    Barinsta Crash Report
+    Select an email app to send crash logs
+    Not found!
+    Your IP has been rate limited by Instagram. Wait for an hour and try again.
+    Skip this update
+    You\'re already on the latest version
+    Screen order
+    Other tabs
+    The tab order will be reflected on next launch
+    If saved, all DM related features will be disabled on next launch
+    문구 복사
+    답장 복사
+    상단
+    최근
+    치우기
+    지도 앱이 없습니다!
+    Click to show full like count
+    No profile pic found!
+    Are you sure you want to open this link?
+
diff --git a/app/src/main/res/values-mk/arrays.xml b/app/src/main/res/values-mk/arrays.xml
index 98c7373a..878d50bc 100644
--- a/app/src/main/res/values-mk/arrays.xml
+++ b/app/src/main/res/values-mk/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Автоматска темаdiff --git a/app/src/main/res/values-mk/strings.xml b/app/src/main/res/values-mk/strings.xml
index eb99f7cb..22e9b721 100644
--- a/app/src/main/res/values-mk/strings.xml
+++ b/app/src/main/res/values-mk/strings.xml
@@ -123,6 +123,7 @@
     Игнорирај Објави
     Одигнорирај приказни
     Одигнорирај Објави
+    Remove follower
     Копирај био
     Преведи био
     Блиски
@@ -211,7 +212,7 @@
     Лајкни коментар
     Одлајкни коментар
     Преведи коментар
-    Избриши коментар
+    Delete comment
     Не смее празни коментари!
     Дали сакате да го пребарате ова корисничко име?
     Дали сакате да го пребарате овај хаштаг?
@@ -232,7 +233,7 @@
     Одобри барање
     Не одобрувај барање
     Сподели ја оваа јавна објава до…
-    Оваја објава е приватна! Споделете ја со оние кои можат да ја видат!
+    This is a private post! Share to those who can view it.
     Оваа категорија е празна…
     Нова надоградба е присутна! (%s)
     Потсетник: Ако ја имате превземено оваа апликација со F-Droid, морате од таму да надоградите! Истото важи и за верзиите од GitHub.
@@ -264,6 +265,7 @@
     Прескокни ажурирање
     Верзија
     Почетна страна
+    Show keyboard on search
     Општо
     Изглед
     Превземања
@@ -367,6 +369,10 @@
- %d лајк
- %d лајкови+    
+
- %d reply+
- %d replies+
- %d коментар
- %d коментари@@ -484,4 +490,8 @@
     Top
     Recent
     Clear
+    No Map app found!
+    Click to show full like count
+    No profile pic found!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-nl/arrays.xml b/app/src/main/res/values-nl/arrays.xml
index 4fa7ccb6..f7c8eb11 100644
--- a/app/src/main/res/values-nl/arrays.xml
+++ b/app/src/main/res/values-nl/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Automatisch / Volgsysteem@@ -54,7 +56,7 @@
     
     
     
-
- secs-
- mins+
- seconden+
- minutendiff --git a/app/src/main/res/values-nl/strings.xml b/app/src/main/res/values-nl/strings.xml
index 8a0c1396..e64a8560 100644
--- a/app/src/main/res/values-nl/strings.xml
+++ b/app/src/main/res/values-nl/strings.xml
@@ -9,7 +9,7 @@
     Fout bij kopiëren van tekst
     Gekopiëerd naar klembord!
     Melden
-    Protect file with password
+    Bescherm bestand met wachtwoord
     Wachtwoord
     Oké
     Ja
@@ -21,20 +21,20 @@
     Opmerkingen
     Activiteit
     Controleer op updates bij het opstarten
-    Block screenshots & app preview
+    Screenshots & app voorbeeld blokkeren
     Download berichten naar gebruikersnaam mappen
-    Prepend Username to Filename
+    Gebruikersnaam toevoegen aan bestandsnaam
     Markeer verhalen als gelezen na bekijken
     Verhaalmaker zal het weten als je het bekeken hebt
-    Hide muted stories from feed
+    Verberg gedempte verhalen uit feed
     Markeer privéberichten als gelezen na bekijken
     Andere gebruikers zullen het weten als je het hebt bekeken
     Activiteitmeldingen inschakelen
     Feedverhalen sorteren
-    Error loading profile! Is the username valid? If so, you may be ratelimited.
-    Error loading profile! Is the username valid? Or did they block you?
-    Error loading hashtag! Is the name valid?
-    Error loading location! Is the URL valid?
+    Fout bij het laden van profiel! Is de gebruikersnaam geldig? Zo ja, dan kan je geratelimiteerd zijn.
+    Fout bij het laden van profiel! Is de gebruikersnaam geldig? Of blokkeert ze u?
+    Fout bij het laden van hashtag! Is de naam geldig?
+    Fout bij het laden van locatie! Is de URL geldig?
     Fout bij maken download map(en).
     Opslaan in aangepaste map
     Selecteer map
@@ -44,22 +44,22 @@
     Taal
- %s\nPost-
- %s\nBerichten+
- %s\nPosts
- %s Post
- %s Berichten-
- %s\nFollower+
- %s\nVolger
- %s\nVolgers%s\nVolgend
     Video\'s automatisch afspelen
-    Continue videos in background
-    Do not pause videos when the app is out of focus
+    Doorgaan met video\'s op achtergrond
+    Video\'s niet pauzeren als de app niet meer op focus is
     Video\'s altijd dempen
-    Always show post captions
+    Toon altijd post bijschriften
     Selecteer wat je wil downloaden
     Huidige
     Volledige Album
@@ -76,14 +76,14 @@
     Antwoord…
     Antwoord gelukt!
     
-
- %d response averaging %s-
- %d responses averaging %s+
- %d reactie gemiddeld %s+
- %d reacties gemiddeld %s-    Your answer: %s
+    Uw antwoord: %s
     Reageer op het verhaal
     Reageer…
     Quiz
-    Slider
+    Schuifregelaar
     Je hebt al geantwoord!
     Vermeldingen
     Dit Account is Privé
@@ -97,13 +97,13 @@
     Verwijder alle accounts
     Dit zal alle toegevoegde accounts van de app verwijderen\nOm alleen één account te verwijderen, houdt het account lang ingedrukt bij het account-wisselscherm\nWil je doorgaan?
     Datumnotatie
-    Create new collection
-    Edit collection name
-    Delete collection
-    Are you sure you want to delete this collection?
-    All contained media will remain in other collections.
-    Add to collection...
-    Remove from collection
+    Nieuwe collectie maken
+    Verander collectienaam
+    Verwijder collectie
+    Weet u zeker dat u deze collectie wilt verwijderen?
+    Alle opgenomen media blijven in andere collecties.
+    Aan collectie toevoegen...
+    Uit collectie verwijderen
     Leuk gevonden
     Opgeslagen
     Getagd
@@ -119,15 +119,16 @@
     Deblokkeer
     Beperk
     De-restrict
-    Mute stories
-    Mute posts
-    Unmute stories
-    Unmute posts
-    Copy bio
-    Translate bio
-    Mutual
-    Following
-    Follower
+    Verhalen uitschakelen
+    Berichten dempen
+    Verhalen uitzetten
+    Berichten uitschakelen
+    Remove follower
+    Bio kopiëren
+    Bio vertalen
+    Wederzijds
+    Volgt
+    Volger
     Kaart
     Accounts
     Instellingen
@@ -148,30 +149,30 @@
     Kan momenteel niet het account verwijderen dat in gebruik is
     Weet je zeker dat je \'%s\' wilt verwijderen?
     Open profiel
-    View story
+    Verhaal bekijken
     Bekijk profielfoto
-    Unsupported message type
+    Niet-ondersteund berichttype
     Maak bericht ongedaan
-    View on GIPHY
-    %s shared a post by @%s
-    %s shared an image
-    %s shared a video
-    %s sent a message
-    %s shared a gif
-    %s shared a sticker
-    %s shared a profile: @%s
-    %s shared a location: %s
-    %s shared a story highlight by @%s
-    %s shared a story by @%s
-    %s sent a voice message
-    %s shared a clip by @%s
-    %s shared an IGTV video by @%s
-    You replied to their story: %s
-    %s replied to your story: %s
-    You reacted to their story: %s
-    %s reacted to your story: %s
-    You mentioned @%s in your story
-    %s mentioned you in their story
+    Bekijk op GIPHY
+    %s heeft een post gedeeld door @%s
+    %s heeft een afbeelding gedeeld
+    %s heeft een video gedeeld
+    %s heeft een bericht verzonden
+    %s heeft een Gif gedeeld
+    %s heeft een sticker gedeeld
+    %s heeft een profiel gedeeld: @%s
+    %s deelde een locatie: %s
+    %s heeft een verhaalmarkering gedeeld door @%s
+    %s heeft een verhaal gedeeld door @%s
+    %s heeft een spraakbericht gestuurd
+    %s deelde een clip met @%s
+    %s deelde een IGTV-video van @%s
+    Je hebt gereageerd op hun verhaal: %s
+    %s heeft gereageerd op je verhaal: %s
+    Je hebt gereageerd op hun verhaal: %s
+    %s reageerde op je verhaal: %s
+    U heeft @%s genoemd in uw verhaal
+    %s heeft je genoemd in hun verhaal
     Onbekend mediatype
     Media verlopen!
     Afgeleverd
@@ -183,17 +184,17 @@
     Voorgesteld
     Screenshot genomen
     Kan niet afleveren
-    Unseen count response is null!
-    Message...
-    Press and hold to record audio
-    Updating...
-    Leave chat
+    Ongeziene graaf reactie is nul!
+    Bericht...
+    Ingedrukt houden om audio op te nemen
+    Bijwerken...
+    Verlaat chat
     Deze chat verlaten?
     Kick
     Gebruikers verlaten
-    Invalid user
-    Instagram does not allow uploading videos longer than 60 secs for DM.
-    Instagram does not allow uploading audio longer than 60 secs.
+    Ongeldige gebruikersnaam
+    Instagram staat niet toe dat video\'s langer dan 60 seconden worden geüpload voor DM.
+    Instagram staat niet toe dat audio langer dan 60 seconden wordt geüpload.
     Rechtstreeks downloaden
     Download rechtstreeks naar het apparaat!
     Post(s) ophalen
@@ -206,12 +207,12 @@
     Fout bij downloaden bestand
     Je kunt slechts 100 berichten per keer downloaden. Wees niet te hebberig!
     Kopieer reactie
-    View comment likers
+    Bekijk reacties likers
     Reageer op opmerking
     Vind reactie leuk
     Vind reactie niet meer leuk
-    Translate comment
-    Verwijder opmerking
+    Reactie vertalen
+    Verwijder reactie
     Geen lege reacties!
     Wil je de gebruikersnaam zoeken?
     Wil je de hashtag zoeken?
@@ -232,7 +233,7 @@
     Verzoek accepteren
     Verzoek afwijzen
     Deel dit openbare bericht met…
-    Dit is een privébericht! Deel het met mensen die hem kunnen zien!
+    This is a private post! Share to those who can view it.
     Deze categorie is op de een of andere manier leeg…
     Een update is beschikbaar(%s)
     Herinnering: Als je via F-Droid hebt gedownload, moet je ook updaten via F-Droid! Hetzelfde geldt voor GitHub.
@@ -240,8 +241,8 @@
     App is gecrasht
     Oeps.. de app is gecrasht, maar geen zorgen. Je kan een foutrapportage naar de ontwikkelaar sturen om hem te helpen met oplossen. (:
     Activiteit
-    Story archive
-    Suggested users
+    Verhaalarchief
+    Voorgestelde gebruikers
     Selecteer Afbeelding
     Bezig met uploaden…
     Je hebt:
@@ -250,8 +251,8 @@
     %d opmerking-likes
     %d gebruikerstags
     %d likes
-    %d photos of you
-    %d follow requests
+    %d foto\'s van jou
+    %d volgverzoeken
     Bent u uitgelogd voordat u op deze melding klikt?!
     Feed
     Profiel
@@ -264,6 +265,7 @@
     Niet meer weergeven tot de volgende update
     Versie
     Startscherm
+    Show keyboard on search
     Algemeen
     Thema
     Downloads
@@ -286,26 +288,26 @@
     Donker thema
     Barista
     Materiaal Donker
-    Added to Favorites!
-    Add to Favorites
+    Toegevoegd aan favorieten!
+    Voeg toe aan Favorieten
     Accounts
     Hashtags
     Locaties
     Onbekend
-    Removed from Favourites!
-    Backup & Restore
-    Backup Barinsta app settings, account login data, and/or favorites to a plain text or encrypted backup file for later restoration.
-    If you\'re backing up account login data, treat the file as confidential and keep it somewhere safe!
-    Create new backup file
-    Restore from existing backup file
+    Verwijderd uit Favorieten!
+    Backup & Herstel
+    Back-up maken van Barinsta app-instellingen, accountloggegevens en/of favorieten naar een platte tekst of versleuteld back-up bestand voor later herstellen.
+    Als u een back-up van accountaanmeldgegevens maakt, het bestand vertrouwelijk behandelt en ergens veilig houdt!
+    Nieuw back-upbestand maken
+    Herstellen vanuit bestaand back-upbestand
     Bestand:
     Voer wachtwoord in
     Backup-bestand selecteren (.zaai/.backup)
     Toepassen
     Opslaan
     Bijschrift
-    Edit caption
-    Translate caption
+    Bewerk onderschrift
+    Vertaal bijschrift
     Videospeler tijdlijn
     Liken…
     Like niet gelukt
@@ -317,11 +319,11 @@
     Opslaan mislukt
     Verwijderen mislukt
     Downloaden…
-    Download item %1$d of %2$d
+    Download item %1$d van %2$d
     Verwijder
     Reageeer
     Lay-out
-    Feed stories
+    Feed verhalen
     Bericht openen...
     Delen
     Lay-out stijl
@@ -335,153 +337,161 @@
     Rasterruimte weergeven
     Animatie uitschakelen
     Wacht eerst tot de huidige taak voltooid is!
-    Depending on user counts, this can take a while to load. Please be patient.
+    Afhankelijk van het aantal gebruikers, kan het laden even duren. Gelieve geduldig te zijn.
     Bericht niet gevonden!
     Geen app gevonden om URL\'s te openen
-    Gallery
+    Galerij
     Camera
-    All Photos
-    All Media
-    All Videos
-    Brightness
+    Alle Foto\'s
+    Alle Media
+    Alle Video\'s
+    Helderheid
     Contrast
-    Vibrance
-    Saturation
-    Sharpen
-    Exposure
-    Center
-    Color
+    Levendigheid
+    Verzadiging
+    Scherpen
+    Blootstelling
+    Centreren
+    Kleur
     Start
-    End
-    Bilateral Blur
+    Einde
+    Bilaterale vervaging
     Vignette
-    Box blur
+    Vak vervagen
     Sepia
     Clarendon
     1977
     Aden
-    Reset
-    Crop
-    Normal
+    Opnieuw
+    Knip af
+    Normaal
- %d vind-ik-leuk
- %d vind-ik-leuks+    
+
- %d antwoord+
- %d antwoorden+
- %d opmerking
- %d opmerkingen-
- %d view-
- %d views+
- %d bekijken+
- %d bekeken-
- %s story-
- %s stories+
- %s verhaal+
- %s verhalen-    Storage permission not granted!
+    Opslag toestemming niet verleend!
     Details
-    Title
+    Titel
     Members
-    Admin
-    Inviter
-    Mute messages
-    Mute mentions
-    Add members
-    Search
-    Done
-    Make Admin
-    Remove as Admin
-    Edit was unsuccessful
-    Message
-    Reply
-    Tap to remove
-    Forward
-    You forwarded a message
-    Forwarded a message
-    Add
-    Send
-    Replying to yourself
-    Replying to %s
-    You replied to yourself
-    You replied
-    You replied to %s
-    Replied to %s
-    Replied to you
-    Replied to themself
-    You reacted to their story
-    Reacted to your story
-    You mentioned them in your story
-    Mentioned you in their story
-    You replied to their story
-    Replied to your story
-    Image has expired
-    Image will expire when seen
-    Video has expired
-    Video will expire when seen
-    Message has expired
-    Message will expire when seen
-    \@%s\'s story
-    \@%s\'s story highlight
-    Photo
+    Beheerder
+    Uitnodiger
+    Berichten dempen
+    Demp vermeldingen
+    Leden toevoegen
+    Zoeken
+    Gedaan
+    Beheerder maken
+    Verwijderen als Admin
+    Bewerken is mislukt
+    Bericht
+    Antwoorden
+    Tik om te verwijderen
+    Doorsturen
+    U heeft een bericht doorgestuurd
+    Bericht doorgestuurd
+    Toevoegen
+    Versturen
+    Antwoorden op jezelf
+    Antwoorden op %s
+    Je antwoordde op jezelf
+    Je antwoordde
+    Je antwoordde op %s
+    Geantwoord op %s
+    Beantwoord jou
+    Beantwoord aan zichzelf
+    Je hebt gereageerd op hun verhaal
+    Reageerde op je verhaal
+    Je hebt ze genoemd in je verhaal
+    Heeft je genoemd in hun verhaal
+    Je hebt gereageerd op hun verhaal
+    Heeft gereageerd op je verhaal
+    Beeld is verlopen
+    Beeld zal verlopen wanneer gezien
+    Video is verlopen
+    Video zal verlopen wanneer gezien
+    Bericht is verlopen
+    Bericht vervalt wanneer gezien
+    \@%s\'s verhaal
+    \@%s\'s verhaal highlight
+    Foto
     Video
-    Voice message
+    Spraakbericht
     Post
-    Approval required to join
-    Requests
-    Admins only
-    Added by %s
-    Admin approval required
-    An admin approval will be required to add new members to the group
-    End chat
-    End chat?
-    All members will be removed from the group. They will still be able to view the chat history.
-    Pending Requests
-    Accept request from %1s (%2s)?
-    Decline
-    Accept
-    You
-    No pending requests
-    Checking for new messages
-    Stories
+    Goedkeuring vereist om toe te treden
+    Verzoeken
+    Alleen admins
+    Toegevoegd door %s
+    Goedkeuring door de beheerder vereist
+    Een admin goedkeuring zal nodig zijn om nieuwe leden aan de groep toe te voegen
+    Einde chatsessie
+    Einde chatsessie?
+    Alle leden zullen uit de groep verwijderd worden. Zij zullen nog steeds de chatgeschiedenis kunnen bekijken.
+    Hangende aanvragen
+    Accepteer verzoek van %1s (%2s)?
+    Geweigerd
+    Accepteer
+    Jij
+    Geen lopende verzoeken
+    Controleren op nieuwe berichten
+    Verhalen
     DM
-    Notifications
+    Meldingen
     Post
-    Enable DM notifications
-    Auto refresh messages
-    Auto refresh every
-    secs
-    mins
-    Search GIPHY
-    Response is null!
-    Response status is not ok!
-    Request failed!
-    Keyword
-    Enable keyword filter
-    Edit keyword filters
-    Added keyword: %s to filter list
-    Removed keyword: %s from filter list
-    Marked as seen
-    Delete unsuccessful
-    Throttled by Instagram because of too many API requests. Wait for some time before retrying.
+    DM meldingen inschakelen
+    Berichten automatisch vernieuwen
+    Automatisch vernieuwen elke
+    sec
+    min
+    Zoek GIPHY
+    Antwoord is leeg!
+    Antwoord status is niet goed!
+    Verzoek mislukt!
+    Sleutelwoord
+    Sleutelwoordfilter inschakelen
+    Sleutelwoordfilters bewerken
+    Sleutelwoord toegevoegd: %s aan filterlijst
+    Sleutelwoord verwijderd: %s uit filterlijst
+    Gemarkeerd als gezien
+    Verwijderen niet gelukt
+    Gestreefd door Instagram vanwege te veel API verzoeken. Wacht even voor je opnieuw probeert.
     Error
-    This account has been logged out.
-    Login required!
-    Sentry block.
-    User is inactive!
-    Barinsta Crash Report
-    Select an email app to send crash logs
-    Not found!
-    Your IP has been rate limited by Instagram. Wait for an hour and try again.
-    Skip this update
-    You\'re already on the latest version
-    Screen order
-    Other tabs
-    The tab order will be reflected on next launch
-    If saved, all DM related features will be disabled on next launch
-    Copy caption
-    Copy reply
+    Deze account is afgemeld.
+    Inloggen verplicht!
+    Sentry blok.
+    Gebruiker is inactief!
+    Barinsta Crash Rapport
+    Selecteer een email app om crashlogs te verzenden
+    Niet gevonden!
+    Uw IP is beperkt door Instagram. Wacht een uur en probeer het opnieuw.
+    Deze update overslaan
+    Je bent al op de nieuwste versie
+    Scherm volgorde
+    Andere tabbladen
+    De tabvolgorde zal weerspiegeld worden bij de volgende start
+    Indien opgeslagen, zullen alle DM gerelateerde functies worden uitgeschakeld bij volgende start
+    Kopieer opschrift
+    Antwoord kopiëren
     Top
     Recent
-    Clear
+    Wissen
+    Geen Kaartapp gevonden!
+    Click to show full like count
+    Geen profielfoto gevonden!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-or/arrays.xml b/app/src/main/res/values-or/arrays.xml
index 05187416..a0c13f67 100644
--- a/app/src/main/res/values-or/arrays.xml
+++ b/app/src/main/res/values-or/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- ସ୍ୱୟଂକ୍ରିୟ /ସିସ୍ଟମ ଅନୁସାରେdiff --git a/app/src/main/res/values-or/strings.xml b/app/src/main/res/values-or/strings.xml
index 5605e2a2..c1e6bb41 100644
--- a/app/src/main/res/values-or/strings.xml
+++ b/app/src/main/res/values-or/strings.xml
@@ -123,6 +123,7 @@
     Mute posts
     Unmute stories
     Unmute posts
+    Remove follower
     Copy bio
     Translate bio
     Mutual
@@ -232,7 +233,7 @@
     Approve request
     Reject request
     Share this public post to…
-    This is a private post! Share to those who can view them!
+    This is a private post! Share to those who can view it.
     This category is somehow empty…
     An update is available! (%s)
     Reminder: If you downloaded from F-Droid, you must update from it! Same applies for GitHub.
@@ -264,6 +265,7 @@
     Do not show again until next update
     Version
     Start screen
+    Show keyboard on search
     General
     Theme
     Downloads
@@ -367,6 +369,10 @@
- %d like
- %d likes+    
+
- %d reply+
- %d replies+
- %d comment
- %d comments@@ -484,4 +490,8 @@
     Top
     Recent
     Clear
+    No Map app found!
+    Click to show full like count
+    No profile pic found!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-pl/arrays.xml b/app/src/main/res/values-pl/arrays.xml
index a7e40411..36602b5c 100644
--- a/app/src/main/res/values-pl/arrays.xml
+++ b/app/src/main/res/values-pl/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Auto / Ustawienia systemudiff --git a/app/src/main/res/values-pl/strings.xml b/app/src/main/res/values-pl/strings.xml
index e9dfd61e..c493ce40 100644
--- a/app/src/main/res/values-pl/strings.xml
+++ b/app/src/main/res/values-pl/strings.xml
@@ -131,6 +131,7 @@
     Wycisz posty
     Wyłącz wyciszenie relacji
     Wyłącz wyciszenie postów
+    Remove follower
     Skopiuj bio
     Przetłumacz bio
     Wspólne
@@ -240,7 +241,7 @@
     Potwierdź
     Odrzuć
     Udostępnij ten publiczny post do…
-    To jest prywatny post! Udostępnij tym, którzy mogą je zobaczyć!
+    To jest prywatny post! Udostępnij wszystkim, którzy mogą go zobaczyć.
     Ta kategoria jest jakoś pusta…
     Aktualizacja jest dostępna! (%s)
     Przypomnienie: Jeśli pobrałeś z F-Droid, musisz go zaktualizować! To samo dotyczy GitHub.
@@ -272,6 +273,7 @@
     Nie pokazuj ponownie do następnej aktualizacji
     Wersja
     Ekran startowy
+    Show keyboard on search
     Ogólne
     Motyw
     Pobieranie
@@ -377,6 +379,12 @@
- %d polubień
- %d polubień+    
+
- %d reply+
- %d replies+
- %d replies+
- %d replies+
- %d komentarz
- %d komentarzy@@ -498,6 +506,10 @@
     Kopiuj podpis
     Kopiuj odpowiedź
     Top
-    Recent
-    Clear
+    Najnowsze
+    Wyczyść
+    No Map app found!
+    Click to show full like count
+    Nie znaleziono zdjęcia profilowego!
+    Czy na pewno chcesz otworzyć ten link?
 
diff --git a/app/src/main/res/values-pt/arrays.xml b/app/src/main/res/values-pt/arrays.xml
index fb832f13..d932b811 100644
--- a/app/src/main/res/values-pt/arrays.xml
+++ b/app/src/main/res/values-pt/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Automático (Definido pelo sistema)diff --git a/app/src/main/res/values-pt/strings.xml b/app/src/main/res/values-pt/strings.xml
index b3e55d0f..4a10e659 100644
--- a/app/src/main/res/values-pt/strings.xml
+++ b/app/src/main/res/values-pt/strings.xml
@@ -123,6 +123,7 @@
     Silenciar publicações
     Reativar stories
     Reativar publicações
+    Remover seguidor
     Copiar bio
     Traduzir bio
     Mútuo
@@ -232,7 +233,7 @@
     Aprovar pedido
     Rejeitar pedido
     Compartilhar esta publicação pública com…
-    Esta é uma publicação privada! Compartilhe com quem pode visualizá-la!
+    Este é um posto privado! Compartilhe com aqueles que podem vê-lo.
     Esta categoria está vazia…
     Uma atualização está disponível! (%s)
     Lembrete: se você baixou do F-Droid, você deve atualizar a partir dele! O mesmo se aplica ao GitHub.
@@ -264,6 +265,7 @@
     Não mostrar novamente até a próxima atualização
     Versão
     Tela inicial
+    Mostrar teclado na busca
     Geral
     Tema
     Downloads
@@ -367,6 +369,10 @@
- %d curtida
- %d curtidas+    
+
- %d resposta+
- %d respostas+
- %d comentário
- %d comentários@@ -481,7 +487,11 @@
     Se salvo, todos os recursos relacionados a DM serão desativados no próximo início
     Copiar legenda
     Copiar resposta
-    Top
-    Recent
-    Clear
+    Início
+    Recente
+    Limpar
+    Nenhum aplicativo de mapa foi encontrado!
+    Clique para mostrar a contagem completa de curtidas
+    Nenhuma foto de perfil encontrada!
+    Tem certeza que quer abrir este link?
 
diff --git a/app/src/main/res/values-ru/arrays.xml b/app/src/main/res/values-ru/arrays.xml
index 8a7d9564..25c702e3 100644
--- a/app/src/main/res/values-ru/arrays.xml
+++ b/app/src/main/res/values-ru/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Автоматически / Оглядка на системуdiff --git a/app/src/main/res/values-ru/strings.xml b/app/src/main/res/values-ru/strings.xml
index 7aa1912a..649ab5bf 100644
--- a/app/src/main/res/values-ru/strings.xml
+++ b/app/src/main/res/values-ru/strings.xml
@@ -131,6 +131,7 @@
     Заглушить публикации
     Включить звук историй
     Включить звук публикаций
+    Remove follower
     Копировать биографию
     Перевести биографию
     Взаимное
@@ -240,7 +241,7 @@
     Одобрить запрос
     Отклонить запрос
     Поделиться публичной записью с…
-    Это личная запись! Поделитесь с теми, кто может их просматривать!
+    This is a private post! Share to those who can view it.
     Эта категория каким-то образом пуста…
     Доступно обновление! (%s)
     Напоминание: Если вы скачали с F-Droid, вы должны обновлять с него! Это же относится и к GitHub.
@@ -272,6 +273,7 @@
     Не показывать снова до следующего обновления
     Версия
     Начальный экран
+    Show keyboard on search
     Общее
     Тема
     Загрузки
@@ -377,6 +379,12 @@
- %d понравилось
- %d понравилось+    
+
- %d ответ+
- %d ответа+
- %d ответов+
- %d ответы+
- %d комментарий
- %d комментария@@ -497,7 +505,11 @@
     При сохранении, все функции, связанные с ЛС, будут отключены при следующем запуске
     Копировать подпись
     Копировать ответ
-    Top
-    Recent
-    Clear
+    В лидерах
+    Недавние
+    Очистить
+    Не найдено картографического приложения!
+    Click to show full like count
+    Картинка профиля не найдена!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-sk/arrays.xml b/app/src/main/res/values-sk/arrays.xml
index 2e5b71d2..3bdab111 100644
--- a/app/src/main/res/values-sk/arrays.xml
+++ b/app/src/main/res/values-sk/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Automaticky / podľa systémudiff --git a/app/src/main/res/values-sk/strings.xml b/app/src/main/res/values-sk/strings.xml
index 55be2132..591c228f 100644
--- a/app/src/main/res/values-sk/strings.xml
+++ b/app/src/main/res/values-sk/strings.xml
@@ -131,6 +131,7 @@
     Mute posts
     Unmute stories
     Unmute posts
+    Remove follower
     Skopírovať bio
     Preložiť bio
     Spoločné
@@ -219,7 +220,7 @@
     Páči sa mi
     Nepáči sa mi
     Preložiť komentár
-    Odstrániť komentár
+    Delete comment
     Komentár je prázdny!
     Chcete vyhľadať používeteľské meno?
     Chcete vyhľadať hashtag?
@@ -240,7 +241,7 @@
     Schváliť žiadosť
     Odmietnuť žiadosť
     Zdieľať tento príspevok…
-    Toto je súkromný príspevok! Zdieľaj iba tým ktorý ho môžu vidieť!
+    This is a private post! Share to those who can view it.
     Táto kategória je nejaká prázdna…
     Aktualizácia je pripravená! (%s)
     Upomienka: Ak si sťahoval/a z F-Droid, musíš aktualizovať z nej! To platí aj pre GitHub.
@@ -272,6 +273,7 @@
     Neukazovať do ďalšej aktualizácie
     Verzia
     Úvodná obrazovka
+    Show keyboard on search
     Všeobecné
     Téma
     Stiahnuté
@@ -377,6 +379,12 @@
- %d sa páči
- %d sa páči+    
+
- %d reply+
- %d replies+
- %d replies+
- %d replies+
- %d komentár
- %d komentáre@@ -500,4 +508,8 @@
     Top
     Recent
     Clear
+    No Map app found!
+    Click to show full like count
+    No profile pic found!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-sv/arrays.xml b/app/src/main/res/values-sv/arrays.xml
index 4bdd3b70..bd2fd32a 100644
--- a/app/src/main/res/values-sv/arrays.xml
+++ b/app/src/main/res/values-sv/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Auto / Följ systemdiff --git a/app/src/main/res/values-sv/strings.xml b/app/src/main/res/values-sv/strings.xml
index 067d45a8..ed1f9fe8 100644
--- a/app/src/main/res/values-sv/strings.xml
+++ b/app/src/main/res/values-sv/strings.xml
@@ -37,14 +37,14 @@
     Fel uppstod när platsen laddades! Är URL:en giltig?
     Fel inträffade när mapp(arna) för nerladdning skapades.
     Spara till en anpassad mapp
-    Select folder
-    Theme
-    Only affects logged-in users:
-    Only affects anonymous users:
-    Language
+    Välj mapp
+    Tema
+    Påverkar endast inloggade användare:
+    Påverkar endast anonyma användare:
+    Språk
- %s\nPost-
- %s\nPosts+
- %s\nInläggen
- %s Post@@ -54,51 +54,51 @@
- %s\nFollower
- %s\nFollowers-    %s\nFollowing
-    Autoplay videos
-    Continue videos in background
-    Do not pause videos when the app is out of focus
-    Always mute videos
+    %s\nFöljer
+    Spela upp videor automatiskt
+    Fortsätt spela videorna i bakgrunden
+    Pausa inte videorna när appen inte längre är i fokus
+    Stäng alltid av ljudet i videorna
     Always show post captions
-    Select what to download
-    Current
-    Whole Album
-    Show stories
-    No more stories!
-    Be patient!
-    View Post
-    View Post
+    Välj det som ska laddas ner
+    Nuvarande
+    Hela albumet
+    Visa historier
+    Inga mer historier!
+    Håll dig lugn!
+    Visa inlägg
+    Visa inlägg
     Spotify
-    Vote
-    Vote successful!
-    You have already voted!
-    Respond
-    Answer…
+    Rösta
+    Röstningen lyckades!
+    Du har redan röstat!
+    Svara
+    Svar…
     Answer successful!
- %d response averaging %s
- %d responses averaging %s-    Your answer: %s
-    Reply to story
-    Reply…
-    Quiz
+    Ditt svar: %s
+    Svara till historien
+    Svara…
+    Frågesport
     Slider
-    You have already answered!
-    Mentions
-    This Account is Private
+    Du har redan svarat!
+    Omnämnanden
+    Det här kontot är Privat
     You won\'t be able to access posts after unfollowing! Are you sure?
     You can log in via More -> Account on the bottom-right corner or you can view public accounts without login!
-    This Account has No Posts
-    No Such Posts!
-    Login
-    Logout
+    Det här kontot har inga inlägg
+    Inga sådana inlägg!
+    Logga in
+    Logga ut
     Browse Instagram anonymously
-    Remove all accounts
+    Ta bort alla konton
     This will remove all added accounts from the app!\nTo remove just one account, long tap the account from the account switcher dialog.\nDo you want to continue?
-    Date format
-    Create new collection
-    Edit collection name
+    Datumformat
+    Skapa ny samling
+    Redigera samlingens namn
     Ta bort samling
     Är du säker på att du vill ta bort den här samlingen?
     All contained media will remain in other collections.
@@ -114,15 +114,16 @@
     Ta bort bokmärke
     Följ
     Sluta följa
-    Favorite
+    Favorit
     Blockera
     Ta bort blockering
     Begränsa
     Ta bort begränsning
-    Mute stories
-    Mute posts
+    Tysta ner historier
+    Tysta ner inlägg
     Unmute stories
     Unmute posts
+    Remove follower
     Kopiera bio
     Översätt bio
     Ömsesidig
@@ -182,14 +183,14 @@
     Blocked
     Suggested
     Screenshotted
-    Cannot deliver
+    Kan inte leverera
     Unseen count response is null!
-    Message...
-    Press and hold to record audio
-    Updating...
-    Leave chat
-    Leave this chat?
-    Kick
+    Meddelande...
+    Tryck och håll in för att spela in ljud
+    Uppdaterar...
+    Lämna chatt
+    Lämna den här chatten?
+    Sparka
     Left users
     Ogiltig användare
     Instagram tillåter inte uppladdning av videor som är längre än 60 sekunder för DM.
@@ -211,7 +212,7 @@
     Gilla kommentaren
     Sluta gilla kommentaren
     Översätt kommentaren
-    Ta bort kommentaren
+    Delete comment
     Inga tomma kommentarer!
     Vill du söka på användarnamnet?
     Vill du söka på hash-taggen?
@@ -232,7 +233,7 @@
     Godkänn begäran
     Neka begäran
     Dela det här publika inlägget till…
-    This is a private post! Share to those who can view them!
+    This is a private post! Share to those who can view it.
     Den här kategorin är på något sätt tom…
     En uppdatering är tillgänglig! (%s)
     Påminnelse: Om du har laddat ner från F-Droid så måste du uppdatera från det! Samma gäller från GitHub.
@@ -242,37 +243,38 @@
     Aktivitet
     Story archive
     Suggested users
-    Select Picture
-    Uploading…
-    You have:
-    %d follows
-    %d comments
-    %d comment likes
+    Välj bild
+    Laddar upp…
+    Du har:
+    %d följer
+    %d kommentarer
+    %d gillade kommentarer
     %d usertags
-    %d likes
-    %d photos of you
+    %d gillanden
+    %d bilder på dig
     %d follow requests
     You logged out before clicking this notification?!
-    Feed
-    Profile
-    More
+    Flöde
+    Profil
+    Mer
     DM
-    %d selected
-    Successfully logged out!
+    %d valdes
+    Utloggningen lyckades!
     Info
-    Mark as seen
+    Markera som sedd
     Do not show again until next update
     Version
-    Start screen
-    General
-    Theme
-    Downloads
+    Startskärm
+    Show keyboard on search
+    Generellt
+    Tema
+    Nerladdningar
     Locale
-    Account
+    Konto
     Current login not working? Simply add the account again.
-    Add account
-    License (English only)
-    Visit our website
+    Lägg till konto
+    Licens (Endast på Engelska)
+    Besök vår hemsida
     Get support, discuss, meet others, and have fun!
     See our source code on GitHub
     Audit, star, report bugs, contribute, and have fun (again)!
@@ -348,25 +350,29 @@
     Vibrance
     Saturation
     Sharpen
-    Exposure
+    Exponering
     Center
-    Color
+    Färg
     Start
-    End
-    Bilateral Blur
+    Slut
+    Bilateral oskärpa
     Vignette
     Box blur
     Sepia
     Clarendon
     1977
     Aden
-    Reset
-    Crop
+    Återställ
+    Beskär
     Normal
- %d like
- %d likes+    
+
- %d reply+
- %d replies+
- %d comment
- %d comments@@ -380,9 +386,9 @@
- %s storiesStorage permission not granted!
-    Details
-    Title
-    Members
+    Detaljer
+    Titel
+    Medlemmar
     Admin
     Inviter
     Mute messages
@@ -411,10 +417,10 @@
     Svarade till sig själva
     Du reagerade på deras historia
     Reagerade på din historia
-    You mentioned them in your story
-    Mentioned you in their story
-    You replied to their story
-    Replied to your story
+    Du nämnde dem i din historia
+    Nämnde dig i deras historia
+    Du svarade på deras historia
+    Svarade på deras historia
     Image has expired
     Image will expire when seen
     Video has expired
@@ -423,14 +429,14 @@
     Message will expire when seen
     \@%s\'s story
     \@%s\'s story highlight
-    Photo
+    Foto
     Video
-    Voice message
+    Röstmeddelande
     Post
     Approval required to join
-    Requests
-    Admins only
-    Added by %s
+    Förfrågningar
+    Endast administratörer
+    Lades till av %s
     Admin approval required
     An admin approval will be required to add new members to the group
     End chat
@@ -456,32 +462,36 @@
     Response is null!
     Response status is not ok!
     Request failed!
-    Keyword
+    Nyckelord
     Enable keyword filter
     Edit keyword filters
     Added keyword: %s to filter list
     Removed keyword: %s from filter list
-    Marked as seen
+    Markerad som sedd
     Delete unsuccessful
     Throttled by Instagram because of too many API requests. Wait for some time before retrying.
-    Error
-    This account has been logged out.
-    Login required!
+    Fel
+    Det här kontot har blivit utloggat.
+    Inloggning krävs!
     Sentry block.
-    User is inactive!
-    Barinsta Crash Report
-    Select an email app to send crash logs
-    Not found!
+    Användaren är inaktiv!
+    Kraschrapport för Barinsta
+    Välj en e-postapplikation för att skicka kraschloggar
+    Hittades inte!
     Your IP has been rate limited by Instagram. Wait for an hour and try again.
-    Skip this update
-    You\'re already on the latest version
+    Hoppa över den här uppdateringen
+    Du har redan den senaste versionen
     Screen order
-    Other tabs
+    Andra flikar
     The tab order will be reflected on next launch
     If saved, all DM related features will be disabled on next launch
     Copy caption
     Copy reply
-    Top
-    Recent
-    Clear
+    Topp
+    Senaste
+    Rensa bort
+    No Map app found!
+    Click to show full like count
+    No profile pic found!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-tr/arrays.xml b/app/src/main/res/values-tr/arrays.xml
index d1cc9560..ee19c5f6 100644
--- a/app/src/main/res/values-tr/arrays.xml
+++ b/app/src/main/res/values-tr/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Otomatik / Sistemi Takip Etdiff --git a/app/src/main/res/values-tr/strings.xml b/app/src/main/res/values-tr/strings.xml
index b11816d8..4f6d3de0 100644
--- a/app/src/main/res/values-tr/strings.xml
+++ b/app/src/main/res/values-tr/strings.xml
@@ -123,6 +123,7 @@
     Gönderileri sustur
     Hikayelerin sesini aç
     Gönderilerin sesini aç
+    Remove follower
     Biyoyu kopyala
     Biyoyu çevir
     Karşılıklı
@@ -211,7 +212,7 @@
     Yorumu beğen
     Yorum beğenisini geri al
     Yorumu çevir
-    Yorumu sil
+    Delete comment
     Boş yorum yapılamaz!
     Kullanıcı adını aratmak istiyor musun?
     Etiketi aratmak istiyor musun?
@@ -232,7 +233,7 @@
     İsteği onayla
     İsteği reddet
     Bu genel gönderiyi paylaş…
-    Bu gizli bir gönderi! Onu görebilen kişilerle paylaş!
+    This is a private post! Share to those who can view it.
     Bu kategori nasıl oluyorsa boş…
     Yeni bir güncelleme mevcut! (%s)
     Hatırlatıcı: Eğer F-Droid kullanarak kurduysanız güncellemeyi oradan yapmalısınız. Aynısı GitHub için de geçerli.
@@ -264,6 +265,7 @@
     Sonraki güncellemeye kadar gösterme
     Sürüm
     Başlangıç ekranı
+    Show keyboard on search
     Genel
     Tema
     İndirmeler
@@ -367,6 +369,10 @@
- %d beğeni
- %d beğeni+    
+
- %d reply+
- %d replies+
- %d yorum
- %d yorum@@ -484,4 +490,8 @@
     Top
     Recent
     Clear
+    No Map app found!
+    Click to show full like count
+    No profile pic found!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-vi/arrays.xml b/app/src/main/res/values-vi/arrays.xml
index 97d23d29..e5f8c681 100644
--- a/app/src/main/res/values-vi/arrays.xml
+++ b/app/src/main/res/values-vi/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- Tự động / Theo hệ thốngdiff --git a/app/src/main/res/values-vi/strings.xml b/app/src/main/res/values-vi/strings.xml
index 1c6a26a3..376b16fd 100644
--- a/app/src/main/res/values-vi/strings.xml
+++ b/app/src/main/res/values-vi/strings.xml
@@ -23,10 +23,10 @@
     Kiểm tra cập nhật khi khởi động
     Chặn chụp ảnh màn hình & xem trước ứng dụng
     Tải bài viết xuống theo thư mục tên người dùng trong Downloads
-    Prepend Username to Filename
+    Thêm tên người dùng vào tên tệp
     Đánh dấu story là đã xem sau khi xem
     Người đăng story sẽ biết bạn đã xem nó
-    Hide muted stories from feed
+    Ẩn những story đã chặn khỏi bảng tin
     Đánh dấu DM là đã xem sau khi xem
     Những thành viên khác sẽ biết bạn đã xem nó
     Kích hoạt thông báo hoạt động
@@ -53,8 +53,8 @@
     
     %s\nĐang theo dõi
     Tự động phát video
-    Continue videos in background
-    Do not pause videos when the app is out of focus
+    Tiếp tục video trong nền
+    Không dừng video khi app trong đa nhiệm
     Luôn luôn tắt âm thanh video
     Luôn hiển thị tiêu đề của bài viết
     Chọn mục tải xuống
@@ -119,6 +119,7 @@
     Chặn bài đăng
     Bỏ chặn story
     Bỏ chặn bài đăng
+    Remove follower
     Sao chép thông tin
     Dịch thông tin
     Chung
@@ -167,7 +168,7 @@
     Bạn đã bày tỏ cảm xúc story của họ: %s
     %s đã bày tỏ cảm xúc story của bạn: %s
     Bạn đã gắn thẻ @%s trong story của mình
-    %s mentioned you in their story
+    %s đã nhắc đến bạn trong story của họ
     Phương tiện không xác định
     Phương tiện đã hết hạn!
     Đã gửi
@@ -179,17 +180,17 @@
     Gợi ý
     Đã chụp màn hình
     Không thể gửi
-    Unseen count response is null!
-    Message...
-    Press and hold to record audio
-    Updating...
-    Leave chat
+    Đánh đấu chưa xem không có giá trị!
+    Tin nhắn...
+    Chạm và giữ để ghi âm
+    Đang cập nhật...
+    Rời khỏi trò chuyện
     Rời khỏi nhóm này?
     Đá
     Người dùng đã rời đi
-    Invalid user
-    Instagram does not allow uploading videos longer than 60 secs for DM.
-    Instagram does not allow uploading audio longer than 60 secs.
+    Người dùng không hợp lệ
+    Instagram không cho phép đăng tải video trên 60 giây trong DM.
+    Instagram không cho phép đăng tải ghi âm trên 60 giây.
     Tải xuống trực tiếp
     Tải bài viết xuống trực tiếp về điện thoại!
     Đang nạp bài viết
@@ -202,11 +203,11 @@
     Lỗi khi tải xuống tệp
     Bạn chỉ có thể tải xuống 100 bài cùng một lúc. Đừng tham lam quá!
     Sao chép bình luận
-    View comment likers
+    Xem những người đã thích bình luận
     Trả lời bình luận
     Thích bình luận
     Bỏ thích bình luận
-    Translate comment
+    Dịch bình luận
     Xóa bình luận
     Không được để trống bình luận!
     Bạn có muốn tìm tên người dùng không?
@@ -228,7 +229,7 @@
     Duyệt yêu cầu
     Từ chối yêu cầu
     Chia sẻ bài viết công khai này đến…
-    Đây là một bài viết riêng tư! Hãy chia sẻ đến những ai có thể xem chúng!
+    This is a private post! Share to those who can view it.
     Mục này đang bị bỏ trống…
     Đã có bản cập nhật! (%s)
     Nhắc nhở: Nếu bạn tải về từ F-Droid, bạn phải cập nhật từ nó! Điều tương tự cho GitHub.
@@ -236,8 +237,8 @@
     Ứng dụng đã bị crash
     Ối.. ứng dụng đã bị crash, nhưng đừng lo bạn có thể gửi báo cáo lỗi đến cho nhà phát triển để giúp anh ấy sửa vấn đề. (:
     Hoạt động
-    Story archive
-    Suggested users
+    Bảo lưu story
+    Người dùng được đề xuất
     Chọn hình ảnh
     Đang tải lên…
     Bạn có:
@@ -246,8 +247,8 @@
     %d lượt thích bình luận
     %d gắn thẻ
     %d lượt thích
-    %d photos of you
-    %d follow requests
+    %d Ảnh của bạn
+    %d yêu cầu theo dõi
     Bạn đã đăng xuất trước khi ấn vào thông báo này?!
     Bảng tin
     Hồ sơ
@@ -260,6 +261,7 @@
     Không hiện lại cho đến cập nhật tiếp theo
     Phiên bản
     Màn hình khởi động
+    Show keyboard on search
     Chung
     Giao diện
     Tải xuống
@@ -282,26 +284,26 @@
     Giao diện tối
     Barista
     Material Tối
-    Added to Favorites!
-    Add to Favorites
+    Đã thêm vào mục Ưa thích!
+    Thêm vào mục yêu thích
     Tài khoản
     Hashtags
     Địa điểm
     Không rõ
-    Removed from Favourites!
-    Backup & Restore
-    Backup Barinsta app settings, account login data, and/or favorites to a plain text or encrypted backup file for later restoration.
-    If you\'re backing up account login data, treat the file as confidential and keep it somewhere safe!
-    Create new backup file
-    Restore from existing backup file
+    Đã loại bỏ khỏi danh sách yêu thích!
+    Sao lưu & Khôi phục
+    Sao lưu cài đặt của ứng dụng Barinsta, thông tin đăng nhập, và/hoặc mục yêu thích thành một tệp chữ hoặc được mã hóa cho những lần khôi phục sau.
+    Nếu bạn đang sao lưu thông tin đăng nhập, hãy xem tệp tin đó như tối mật và hãy giữ nó nơi nào đó an toàn!
+    Tạo tệp sao lưu mới
+    Khôi phục từ tập tin sao lưu
     Tập tin:
     Nhập mật khẩu
     Chọn tệp sao lưu (.zaai/.backup)
     Áp dụng
     Lưu
     Chú thích
-    Edit caption
-    Translate caption
+    Chỉnh sửa chú thích
+    Dịch chú thích
     Thanh thời gian của trình phát video
     Đang thích…
     Không thể thích
@@ -313,11 +315,11 @@
     Không thể lưu
     Không thể xóa
     Đang tải xuống…
-    Download item %1$d of %2$d
+    Tải tệp %1$d từ %2$d
     Xóa
     Bình luận
     Giao diện
-    Feed stories
+    Story trên bảng tin
     Đang mở bài đăng...
     Chia sẻ
     Phong cach giao diện
@@ -331,149 +333,156 @@
     Hiển thị khoảng trống lưới
     Tắt hoạt ảnh
     Xin hãy đợi công việc hiện tại hoàn thành trước!
-    Depending on user counts, this can take a while to load. Please be patient.
+    Tùy thuộc vào trường hợp của người dùng, có thể sẽ mất một lúc để tải. Xin hãy kiên nhẫn.
     Không tìm thấy bài viết!
     Không có app nào để mở link này
-    Gallery
-    Camera
-    All Photos
-    All Media
-    All Videos
-    Brightness
-    Contrast
-    Vibrance
-    Saturation
-    Sharpen
-    Exposure
-    Center
-    Color
-    Start
-    End
-    Bilateral Blur
-    Vignette
-    Box blur
-    Sepia
+    Thư viện
+    Máy ảnh
+    Tất cả ảnh
+    Tất cả phương tiện
+    Tất cả Video
+    Độ sáng
+    Độ tương phản
+    Dao động
+    Độ bão hoà
+    Làm sắc nét
+    Độ phơi sáng
+    Trung tâm
+    Màu săc
+    Bắt đầu
+    Kết thúc
+    Làm mờ hai bên
+    Mờ viền
+    Hộp mờ
+    Màu nâu đỏ
     Clarendon
     1977
     Aden
-    Reset
-    Crop
-    Normal
+    Đặt lại
+    Cắt
+    Bình thường
- %d thích+    
+
- %d phản hồi+
- %d bình luận-
- %d views+
- %d lượt xem-
- %s stories+
- %s story-    Storage permission not granted!
-    Details
-    Title
-    Members
-    Admin
-    Inviter
-    Mute messages
-    Mute mentions
-    Add members
-    Search
-    Done
-    Make Admin
-    Remove as Admin
-    Edit was unsuccessful
-    Message
-    Reply
-    Tap to remove
-    Forward
-    You forwarded a message
-    Forwarded a message
-    Add
-    Send
-    Replying to yourself
-    Replying to %s
-    You replied to yourself
-    You replied
-    You replied to %s
-    Replied to %s
-    Replied to you
-    Replied to themself
-    You reacted to their story
-    Reacted to your story
-    You mentioned them in your story
-    Mentioned you in their story
-    You replied to their story
-    Replied to your story
-    Image has expired
-    Image will expire when seen
-    Video has expired
-    Video will expire when seen
-    Message has expired
-    Message will expire when seen
-    \@%s\'s story
-    \@%s\'s story highlight
-    Photo
+    Chưa cấp quyền bộ nhớ!
+    Chi tiết
+    Tiêu đề
+    Thành viên
+    Quản trị viên
+    Người mời
+    Tắt thông báo tin nhắn
+    Tắt thông báo nhắc đến
+    Thêm thành viên
+    Tìm kiếm
+    Xong
+    Đặt quản trị viên
+    Xóa quyền quản trị
+    Chỉnh sửa thành công
+    Tin nhắn
+    Trả lời
+    Chạm Để Gỡ
+    Chuyển tiếp
+    Bạn đã chuyển tiếp một tin nhắn
+    Đã chuyển tiếp một tin nhắn
+    Thêm
+    Gửi
+    Đang trở lời bản thân
+    Trả lời đến: %s
+    Bạn đã trả lời bản thân mình
+    Bạn đã trả lời
+    Bạn đã trả lời %s
+    Đã trả lời %s
+    Đã trả lời bạn
+    Đã trả lời chính họ
+    Bạn đã bày tỏ cảm xúc story của họ
+    Đã bày tỏ cảm xúc story của bạn
+    Bạn đã nhắc đến họ trong story của mình
+    Đã nhắc đến bạn trong story của họ
+    Bạn đã phản hồi story của họ
+    Đã phản hồi story của bạn
+    Ảnh đã hết hạn
+    Ảnh sẽ hết hạn khi được xem
+    Video đã hết hạn
+    Video sẽ hết hạn khi được xem
+    Tin nhắn đã hết hạn
+    Tin nhắn sẽ hết hạn khi được xem
+    Story của @%s
+    Story highlight của @%s
+    Ảnh
     Video
-    Voice message
-    Post
-    Approval required to join
-    Requests
-    Admins only
-    Added by %s
-    Admin approval required
-    An admin approval will be required to add new members to the group
-    End chat
-    End chat?
-    All members will be removed from the group. They will still be able to view the chat history.
-    Pending Requests
-    Accept request from %1s (%2s)?
-    Decline
-    Accept
-    You
-    No pending requests
-    Checking for new messages
-    Stories
+    Tin nhắn thoại
+    Bài đăng
+    Yêu cầu phê duyệt để tham gia
+    Yêu cầu
+    Chỉ dành cho admin
+    Đã thêm bởi %s
+    Yêu cầu cho phép của quản trị viên
+    Cần có sự cho phép của quản trị viên để thêm thành viên mới vào nhóm
+    Kết thúc cuộc trò chuyện
+    Kết thúc cuộc trò chuyện?
+    Tất cả thành viên sẽ được xóa khỏi nhóm. Họ vẫn sẽ có thể xem lịch sử cuộc trò chuyện.
+    Lời mời đang chờ chấp nhận
+    Chấp nhận yêu cầu từ %1s (%2s)?
+    Từ chối
+    Chấp nhận
+    Bạn
+    Không có yêu cầu đang chờ duyệt
+    Đang kiểm tra các tin nhắn mới
+    Story
     DM
-    Notifications
-    Post
-    Enable DM notifications
-    Auto refresh messages
-    Auto refresh every
-    secs
-    mins
-    Search GIPHY
-    Response is null!
-    Response status is not ok!
-    Request failed!
-    Keyword
-    Enable keyword filter
-    Edit keyword filters
-    Added keyword: %s to filter list
-    Removed keyword: %s from filter list
-    Marked as seen
-    Delete unsuccessful
-    Throttled by Instagram because of too many API requests. Wait for some time before retrying.
-    Error
-    This account has been logged out.
-    Login required!
-    Sentry block.
-    User is inactive!
-    Barinsta Crash Report
-    Select an email app to send crash logs
-    Not found!
-    Your IP has been rate limited by Instagram. Wait for an hour and try again.
-    Skip this update
-    You\'re already on the latest version
-    Screen order
-    Other tabs
-    The tab order will be reflected on next launch
-    If saved, all DM related features will be disabled on next launch
-    Copy caption
-    Copy reply
-    Top
-    Recent
-    Clear
+    Thông báo
+    Bài đăng
+    Bật thông báo DM
+    Tự động làm mới tin nhắn
+    Tự động làm mới mỗi
+    giây
+    phút
+    Tìm trên GIPHY
+    Phản hồi vô giá trị!
+    Trạng thái trả lời không ổn định!
+    Yêu cầu thất bại!
+    Từ khóa
+    Bật lọc từ khóa
+    Chỉnh lọc từ khóa
+    Đã thêm từ khóa: %s vào danh sách lọc
+    Đã loại từ khóa: %s khỏi danh sách lọc
+    Đánh dấu là đã đọc
+    Không thể xóa
+    Đã bị nghẽn bởi Instagram do có quá nhiều yêu cầu API. Xin hãy đợi một lát trước khi thử lại.
+    Lỗi
+    Tài khoản này đã đăng xuất.
+    Yêu cầu đăng nhập!
+    Chặn Sentry.
+    Người dùng đang không hoạt động!
+    Báo cáo crash Barinsta
+    Chọn một app email để gửi báo cáo
+    Không tìm thấy!
+    IP của bạn đã bị giới hạn bởi Instagram. Hãy đợi một giờ và thử lại.
+    Bỏ qua bản cập nhật này
+    Đã là phiên bản mới nhất
+    Thứ tự màn hình
+    Những tab khác
+    Thứ tự tab này sẽ hiệu nghiệm vào lần khởi động kế tiếp
+    Nếu đã lưu, tất cả tính năng DM sẽ được vô hiệu hóa vào lần khởi động kế tiếp
+    Sao chép chú thích
+    Sao chép phản hồi
+    Hàng đầu
+    Gần đây
+    Xóa
+    Không tìm thấy ứng dụng bản đồ!
+    Click to show full like count
+    No profile pic found!
+    Are you sure you want to open this link?
 
diff --git a/app/src/main/res/values-zh-rCN/arrays.xml b/app/src/main/res/values-zh-rCN/arrays.xml
index 9a8d9fd0..20f06ff9 100644
--- a/app/src/main/res/values-zh-rCN/arrays.xml
+++ b/app/src/main/res/values-zh-rCN/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- 自动 / 跟随系统diff --git a/app/src/main/res/values-zh-rCN/strings.xml b/app/src/main/res/values-zh-rCN/strings.xml
index 111324f5..3d487a73 100644
--- a/app/src/main/res/values-zh-rCN/strings.xml
+++ b/app/src/main/res/values-zh-rCN/strings.xml
@@ -119,6 +119,7 @@
     隐藏ta的帖子
     取消隐藏ta的快拍
     取消隐藏ta的帖子
+    移除粉丝
     复制简介
     翻译简介
     相互关注
@@ -228,7 +229,7 @@
     同意请求
     拒绝请求
     分享公开帖...
-    这是一个私密帖!分享给那些可以查看他们的人!
+    这是一个私密帖!请确定分享对象能查看本帖。
     这个板块居然是空的...
     检测到有新版本! (%s)
     注意:若您下载的是F-Droid版本,那您还得在F-Droid更新!GitHub版本也是如此。
@@ -260,6 +261,7 @@
     在下次更新之前不再显示
     版本
     初始界面
+    搜索时显示键盘
     常规设置
     主题
     下载
@@ -362,6 +364,9 @@
- %d 个赞+    
+
- %d 条回复+
- %d 条评论@@ -473,7 +478,11 @@
     若您如此保存,所有私信功能将会在下次启动时被禁用
     复制说明
     复制回复
-    Top
-    Recent
-    Clear
+    热门
+    近期搜索
+    清空
+    未找到地图应用!
+    点击显示完整点赞计数
+    未找到用户头像!
+    您确定要打开此链接吗?
 
diff --git a/app/src/main/res/values-zh-rTW/arrays.xml b/app/src/main/res/values-zh-rTW/arrays.xml
index 8bfea859..65b0f1eb 100644
--- a/app/src/main/res/values-zh-rTW/arrays.xml
+++ b/app/src/main/res/values-zh-rTW/arrays.xml
@@ -24,6 +24,8 @@
- 日本語
- Ελληνικά
- Euskara+
- Svenska+
- 한국어
- 自動/跟隨系統diff --git a/app/src/main/res/values-zh-rTW/strings.xml b/app/src/main/res/values-zh-rTW/strings.xml
index 714f072c..6c3d2b27 100644
--- a/app/src/main/res/values-zh-rTW/strings.xml
+++ b/app/src/main/res/values-zh-rTW/strings.xml
@@ -21,7 +21,7 @@
     評論
     動態
     啟動時檢查更新
-    阻擋截圖 & 應用程式預覽
+    阻擋截圖及應用程式預覽
     將貼文下載到用戶名資料夾
     在檔案名稱前添加用戶名
     檢視完限時動態後標記為已讀
@@ -115,10 +115,11 @@
     解除封鎖
     限制
     移除限制
-    隱藏此用戶的限時動態
-    隱藏此用戶的貼文
-    取消隱藏此用戶的限時動態
-    取消隱藏此用戶的貼文
+    隱藏限時動態
+    隱藏貼文
+    取消隱藏限時動態
+    取消隱藏貼文
+    Remove follower
     複製簡介
     翻譯簡介
     正彼此追蹤
@@ -207,7 +208,7 @@
     對此評論說讚
     收回評論的讚
     翻譯評論
-    刪除評論
+    Delete comment
     無空評論!
     您要搜尋用戶名嗎?
     您要搜尋主題標籤嗎?
@@ -228,7 +229,7 @@
     接受要求
     略過要求
     分享這則公開貼文給…
-    這個是私人貼文!分享給可以查看的人!
+    This is a private post! Share to those who can view it.
     這個類別是空的…
     有可用的更新! (%s)
     提醒:如果您是從F-Droid 下載的,您必須透過其進行更新! GitHub 也是如此。
@@ -260,6 +261,7 @@
     在下次更新之前不再顯示
     版本
     開始畫面
+    Show keyboard on search
     一般
     主題
     下載
@@ -289,9 +291,9 @@
     地點
     未知
     已從收藏中移除!
-    備份 & 還原
+    備份與還原
     備份 Barinsta 的設定、登入資料、及收藏中的內容至純文字或加密後的檔案,以便日後還原。
-    如果您選擇備份登入相關資訊,請將此檔案視為密碼看待並妥善保存!
+    如果您選擇備份登入相關資訊,請將此檔案視為密碼看待,並妥善保存!
     建立備份檔
     以備份檔還原
     檔案:
@@ -300,7 +302,7 @@
     套用
     儲存
     說明
-    編輯貼文
+    編輯說明
     翻譯說明
     影片播放器時間軸
     按讚中…
@@ -362,6 +364,9 @@
- %d 個讚+    
+
- %d replies+
- %d 個評論@@ -397,7 +402,7 @@
     回覆 %s
     您回覆了自己
     您回覆了
-    你回覆了 %s 的限時動態
+    您回覆了 %s
     回覆了 %s 的限時動態
     回覆給您
     回覆給他自己
@@ -476,4 +481,8 @@
     Top
     Recent
     Clear
+    No Map app found!
+    Click to show full like count
+    No profile pic found!
+    Are you sure you want to open this link?