commit
3933f79bda
@ -1,3 +1,11 @@
|
|||||||
|
### Version 1.0.42 Tag: v1.0.42 (2020-07-04)
|
||||||
|
* Added appbar at the top of the SettingsActivity (@Poslovitch)
|
||||||
|
* Improved and added some French translations (@Poslovitch)
|
||||||
|
* Removed translations for untranslatable strings (@Poslovitch)
|
||||||
|
* Add stop button to expanded notification, and stop and switch to audio in video window (@dhk2)
|
||||||
|
* More data in Server search
|
||||||
|
* VideoList timestamp fix
|
||||||
|
|
||||||
### Version 1.0.41 Tag: v1.0.41 (2020-06-28)
|
### Version 1.0.41 Tag: v1.0.41 (2020-06-28)
|
||||||
* Floating window player controls fix (@dhk2)
|
* Floating window player controls fix (@dhk2)
|
||||||
* Updated app icons
|
* Updated app icons
|
||||||
|
@ -6,8 +6,8 @@ android {
|
|||||||
applicationId "net.schueller.peertube"
|
applicationId "net.schueller.peertube"
|
||||||
minSdkVersion 21
|
minSdkVersion 21
|
||||||
targetSdkVersion 29
|
targetSdkVersion 29
|
||||||
versionCode 1041
|
versionCode 1042
|
||||||
versionName "1.0.41"
|
versionName "1.0.42"
|
||||||
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
|
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
|
||||||
ext {
|
ext {
|
||||||
libVersions = [
|
libVersions = [
|
||||||
@ -62,6 +62,12 @@ android {
|
|||||||
implementation "com.google.android.exoplayer:exoplayer-smoothstreaming:$libVersions.exoplayer"
|
implementation "com.google.android.exoplayer:exoplayer-smoothstreaming:$libVersions.exoplayer"
|
||||||
implementation "com.google.android.exoplayer:extension-mediasession:$libVersions.exoplayer"
|
implementation "com.google.android.exoplayer:extension-mediasession:$libVersions.exoplayer"
|
||||||
|
|
||||||
|
// date formatter
|
||||||
|
implementation 'org.ocpsoft.prettytime:prettytime:4.0.4.Final'
|
||||||
|
|
||||||
|
// Version comparison
|
||||||
|
implementation 'org.apache.maven:maven-artifact:3.5.0'
|
||||||
|
|
||||||
// testing
|
// testing
|
||||||
testImplementation 'junit:junit:4.12'
|
testImplementation 'junit:junit:4.12'
|
||||||
androidTestImplementation 'androidx.test:runner:1.2.0'
|
androidTestImplementation 'androidx.test:runner:1.2.0'
|
||||||
|
@ -38,12 +38,25 @@ public class SettingsActivity extends CommonActivity {
|
|||||||
.beginTransaction()
|
.beginTransaction()
|
||||||
.replace(R.id.settings, new SettingsFragment())
|
.replace(R.id.settings, new SettingsFragment())
|
||||||
.commit();
|
.commit();
|
||||||
|
|
||||||
|
// Attaching the layout to the toolbar object
|
||||||
|
Toolbar toolbar = findViewById(R.id.tool_bar_settings);
|
||||||
|
// Setting toolbar as the ActionBar with setSupportActionBar() call
|
||||||
|
setSupportActionBar(toolbar);
|
||||||
|
|
||||||
ActionBar actionBar = getSupportActionBar();
|
ActionBar actionBar = getSupportActionBar();
|
||||||
if (actionBar != null) {
|
if (actionBar != null) {
|
||||||
actionBar.setDisplayHomeAsUpEnabled(true);
|
actionBar.setDisplayHomeAsUpEnabled(true);
|
||||||
|
actionBar.setHomeAsUpIndicator(R.drawable.ic_baseline_close_24);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onSupportNavigateUp() {
|
||||||
|
finish(); // close this activity as oppose to navigating up
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public static class SettingsFragment extends PreferenceFragmentCompat {
|
public static class SettingsFragment extends PreferenceFragmentCompat {
|
||||||
@Override
|
@Override
|
||||||
public void onCreatePreferences(Bundle savedInstanceState, String rootKey) {
|
public void onCreatePreferences(Bundle savedInstanceState, String rootKey) {
|
||||||
|
@ -21,11 +21,16 @@ package net.schueller.peertube.activity;
|
|||||||
|
|
||||||
import android.annotation.SuppressLint;
|
import android.annotation.SuppressLint;
|
||||||
import android.app.AppOpsManager;
|
import android.app.AppOpsManager;
|
||||||
|
import android.app.PendingIntent;
|
||||||
import android.app.PictureInPictureParams;
|
import android.app.PictureInPictureParams;
|
||||||
|
import android.app.RemoteAction;
|
||||||
|
import android.content.BroadcastReceiver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
|
import android.content.IntentFilter;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
|
import android.graphics.drawable.Icon;
|
||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
|
||||||
@ -49,12 +54,18 @@ import net.schueller.peertube.fragment.VideoMetaDataFragment;
|
|||||||
import net.schueller.peertube.fragment.VideoPlayerFragment;
|
import net.schueller.peertube.fragment.VideoPlayerFragment;
|
||||||
import net.schueller.peertube.service.VideoPlayerService;
|
import net.schueller.peertube.service.VideoPlayerService;
|
||||||
|
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
import androidx.fragment.app.FragmentManager;
|
import androidx.fragment.app.FragmentManager;
|
||||||
|
|
||||||
|
|
||||||
//import static net.schueller.peertube.helper.Constants.BACKGROUND_PLAY_PREF_KEY;
|
//import static net.schueller.peertube.helper.Constants.BACKGROUND_PLAY_PREF_KEY;
|
||||||
|
import static com.google.android.exoplayer2.ui.PlayerNotificationManager.ACTION_PAUSE;
|
||||||
|
import static com.google.android.exoplayer2.ui.PlayerNotificationManager.ACTION_PLAY;
|
||||||
|
import static com.google.android.exoplayer2.ui.PlayerNotificationManager.ACTION_STOP;
|
||||||
|
import static net.schueller.peertube.helper.Constants.BACKGROUND_AUDIO;
|
||||||
import static net.schueller.peertube.helper.Constants.DEFAULT_THEME;
|
import static net.schueller.peertube.helper.Constants.DEFAULT_THEME;
|
||||||
import static net.schueller.peertube.helper.Constants.THEME_PREF_KEY;
|
import static net.schueller.peertube.helper.Constants.THEME_PREF_KEY;
|
||||||
|
|
||||||
@ -62,7 +73,108 @@ public class VideoPlayActivity extends AppCompatActivity {
|
|||||||
|
|
||||||
private static final String TAG = "VideoPlayActivity";
|
private static final String TAG = "VideoPlayActivity";
|
||||||
|
|
||||||
|
private static boolean floatMode = false;
|
||||||
|
private static final int REQUEST_CODE = 101;
|
||||||
|
private BroadcastReceiver receiver;
|
||||||
|
//This can only be called when in entering pip mode which can't happen if the device doesn't support pip mode.
|
||||||
|
@SuppressLint("NewApi")
|
||||||
|
public void makePipControls() {
|
||||||
|
FragmentManager fragmentManager = getSupportFragmentManager();
|
||||||
|
VideoPlayerFragment videoPlayerFragment = (VideoPlayerFragment) fragmentManager.findFragmentById(R.id.video_player_fragment);
|
||||||
|
|
||||||
|
ArrayList<RemoteAction> actions = new ArrayList<>();
|
||||||
|
|
||||||
|
Intent actionIntent = new Intent(BACKGROUND_AUDIO);
|
||||||
|
PendingIntent pendingIntent = PendingIntent.getBroadcast(getApplicationContext(), REQUEST_CODE, actionIntent, 0);
|
||||||
|
@SuppressLint({"NewApi", "LocalSuppress"}) Icon icon = Icon.createWithResource(getApplicationContext(), android.R.drawable.stat_sys_speakerphone);
|
||||||
|
@SuppressLint({"NewApi", "LocalSuppress"}) RemoteAction remoteAction = new RemoteAction(icon, "close pip", "from pip window custom command", pendingIntent);
|
||||||
|
actions.add(remoteAction);
|
||||||
|
|
||||||
|
actionIntent = new Intent(ACTION_STOP);
|
||||||
|
pendingIntent = PendingIntent.getBroadcast(getApplicationContext(), REQUEST_CODE, actionIntent, 0);
|
||||||
|
icon = Icon.createWithResource(getApplicationContext(), com.google.android.exoplayer2.ui.R.drawable.exo_notification_stop);
|
||||||
|
remoteAction = new RemoteAction(icon, "play", "stop the media", pendingIntent);
|
||||||
|
actions.add(remoteAction);
|
||||||
|
|
||||||
|
if (videoPlayerFragment.isPaused()){
|
||||||
|
Log.e(TAG,"setting actions with play button");
|
||||||
|
actionIntent = new Intent(ACTION_PLAY);
|
||||||
|
pendingIntent = PendingIntent.getBroadcast(getApplicationContext(), REQUEST_CODE, actionIntent, 0);
|
||||||
|
icon = Icon.createWithResource(getApplicationContext(), com.google.android.exoplayer2.ui.R.drawable.exo_notification_play);
|
||||||
|
remoteAction = new RemoteAction(icon, "play", "play the media", pendingIntent);
|
||||||
|
actions.add(remoteAction);
|
||||||
|
} else {
|
||||||
|
Log.e(TAG,"setting actions with pause button");
|
||||||
|
actionIntent = new Intent(ACTION_PAUSE);
|
||||||
|
pendingIntent = PendingIntent.getBroadcast(getApplicationContext(), REQUEST_CODE, actionIntent, 0);
|
||||||
|
icon = Icon.createWithResource(getApplicationContext(), com.google.android.exoplayer2.ui.R.drawable.exo_notification_pause);
|
||||||
|
remoteAction = new RemoteAction(icon, "pause", "pause the media", pendingIntent);
|
||||||
|
actions.add(remoteAction);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//add custom actions to pip window
|
||||||
|
PictureInPictureParams params =
|
||||||
|
new PictureInPictureParams.Builder()
|
||||||
|
.setActions(actions)
|
||||||
|
.build();
|
||||||
|
setPictureInPictureParams(params);
|
||||||
|
|
||||||
|
}
|
||||||
|
public void changedToPipMode() {
|
||||||
|
FragmentManager fragmentManager = getSupportFragmentManager();
|
||||||
|
VideoPlayerFragment videoPlayerFragment = (VideoPlayerFragment) fragmentManager.findFragmentById(R.id.video_player_fragment);
|
||||||
|
|
||||||
|
videoPlayerFragment.showControls(false);
|
||||||
|
//create custom actions
|
||||||
|
makePipControls();
|
||||||
|
|
||||||
|
//setup receiver to handle customer actions
|
||||||
|
IntentFilter filter = new IntentFilter();
|
||||||
|
filter.addAction(ACTION_STOP);
|
||||||
|
filter.addAction(ACTION_PAUSE);
|
||||||
|
filter.addAction(ACTION_PLAY);
|
||||||
|
filter.addAction((BACKGROUND_AUDIO));
|
||||||
|
receiver = new BroadcastReceiver() {
|
||||||
|
@Override
|
||||||
|
public void onReceive(Context context, Intent intent) {
|
||||||
|
String action = intent.getAction();
|
||||||
|
if (action.equals(ACTION_PAUSE)) {
|
||||||
|
videoPlayerFragment.pauseVideo();
|
||||||
|
makePipControls();
|
||||||
|
}
|
||||||
|
if (action.equals(ACTION_PLAY)) {
|
||||||
|
videoPlayerFragment.unPauseVideo();
|
||||||
|
makePipControls();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (action.equals(BACKGROUND_AUDIO)) {
|
||||||
|
unregisterReceiver(receiver);
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
if (action.equals(ACTION_STOP)) {
|
||||||
|
unregisterReceiver(receiver);
|
||||||
|
finishAndRemoveTask();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
registerReceiver(receiver, filter);
|
||||||
|
|
||||||
|
Log.v(TAG, "switched to pip ");
|
||||||
|
floatMode=true;
|
||||||
|
videoPlayerFragment.showControls(false);
|
||||||
|
}
|
||||||
|
public void changedToNormalMode(){
|
||||||
|
FragmentManager fragmentManager = getSupportFragmentManager();
|
||||||
|
VideoPlayerFragment videoPlayerFragment = (VideoPlayerFragment) fragmentManager.findFragmentById(R.id.video_player_fragment);
|
||||||
|
|
||||||
|
videoPlayerFragment.showControls(true);
|
||||||
|
if (receiver != null) {
|
||||||
|
unregisterReceiver(receiver);
|
||||||
|
}
|
||||||
|
Log.v(TAG,"switched to normal");
|
||||||
|
floatMode=false;
|
||||||
|
}
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
@ -357,9 +469,11 @@ public class VideoPlayActivity extends AppCompatActivity {
|
|||||||
VideoPlayerFragment videoPlayerFragment = (VideoPlayerFragment) fragmentManager.findFragmentById(R.id.video_player_fragment);
|
VideoPlayerFragment videoPlayerFragment = (VideoPlayerFragment) fragmentManager.findFragmentById(R.id.video_player_fragment);
|
||||||
|
|
||||||
if (isInPictureInPictureMode) {
|
if (isInPictureInPictureMode) {
|
||||||
|
changedToPipMode();
|
||||||
Log.v(TAG,"switched to pip ");
|
Log.v(TAG,"switched to pip ");
|
||||||
videoPlayerFragment.useController(false);
|
videoPlayerFragment.useController(false);
|
||||||
} else {
|
} else {
|
||||||
|
changedToNormalMode();
|
||||||
Log.v(TAG,"switched to normal");
|
Log.v(TAG,"switched to normal");
|
||||||
videoPlayerFragment.useController(true);
|
videoPlayerFragment.useController(true);
|
||||||
}
|
}
|
||||||
|
@ -160,7 +160,7 @@ public class ChannelAdapter extends RecyclerView.Adapter<ChannelAdapter.AccountV
|
|||||||
|
|
||||||
AccountViewHolder(View itemView) {
|
AccountViewHolder(View itemView) {
|
||||||
super(itemView);
|
super(itemView);
|
||||||
name = itemView.findViewById(R.id.name);
|
name = itemView.findViewById(R.id.sl_row_name);
|
||||||
thumb = itemView.findViewById(R.id.thumb);
|
thumb = itemView.findViewById(R.id.thumb);
|
||||||
avatar = itemView.findViewById(R.id.avatar);
|
avatar = itemView.findViewById(R.id.avatar);
|
||||||
videoMeta = itemView.findViewById(R.id.videoMeta);
|
videoMeta = itemView.findViewById(R.id.videoMeta);
|
||||||
|
@ -17,13 +17,11 @@
|
|||||||
*/
|
*/
|
||||||
package net.schueller.peertube.adapter;
|
package net.schueller.peertube.adapter;
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.SharedPreferences;
|
|
||||||
import android.preference.PreferenceManager;
|
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
|
import android.widget.ImageView;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
@ -38,6 +36,8 @@ import java.util.ArrayList;
|
|||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.recyclerview.widget.RecyclerView;
|
import androidx.recyclerview.widget.RecyclerView;
|
||||||
|
|
||||||
|
import org.apache.maven.artifact.versioning.DefaultArtifactVersion;
|
||||||
|
|
||||||
import static android.app.Activity.RESULT_OK;
|
import static android.app.Activity.RESULT_OK;
|
||||||
|
|
||||||
|
|
||||||
@ -74,20 +74,38 @@ public class ServerAdapter extends RecyclerView.Adapter<ServerAdapter.AccountVie
|
|||||||
R.string.server_selection_signup_allowed_yes :
|
R.string.server_selection_signup_allowed_yes :
|
||||||
R.string.server_selection_signup_allowed_no
|
R.string.server_selection_signup_allowed_no
|
||||||
)));
|
)));
|
||||||
holder.shortDescription.setText(serverList.get(position).getShortDescription());
|
|
||||||
|
|
||||||
|
holder.videoTotals.setText(
|
||||||
|
activity.getString(R.string.server_selection_video_totals,
|
||||||
|
serverList.get(position).getTotalVideos().toString(),
|
||||||
|
serverList.get(position).getTotalLocalVideos().toString()
|
||||||
|
));
|
||||||
|
|
||||||
|
// don't show description if it hasn't been changes from the default
|
||||||
|
if (!activity.getString(R.string.peertube_instance_search_default_description).equals(serverList.get(position).getShortDescription())) {
|
||||||
|
holder.shortDescription.setText(serverList.get(position).getShortDescription());
|
||||||
|
holder.shortDescription.setVisibility(View.VISIBLE);
|
||||||
|
} else {
|
||||||
|
holder.shortDescription.setVisibility(View.GONE);
|
||||||
|
}
|
||||||
|
|
||||||
|
DefaultArtifactVersion serverVersion = new DefaultArtifactVersion(serverList.get(position).getVersion());
|
||||||
|
|
||||||
|
// at least version 2.2
|
||||||
|
DefaultArtifactVersion minVersion22 = new DefaultArtifactVersion("2.2.0");
|
||||||
|
if (serverVersion.compareTo(minVersion22) >= 0) {
|
||||||
|
// show NSFW Icon
|
||||||
|
if (serverList.get(position).getNSFW()) {
|
||||||
|
holder.isNSFW.setVisibility(View.VISIBLE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// select server
|
||||||
holder.itemView.setOnClickListener(v -> {
|
holder.itemView.setOnClickListener(v -> {
|
||||||
|
|
||||||
// SharedPreferences sharedPref = PreferenceManager.getDefaultSharedPreferences(activity);
|
|
||||||
// SharedPreferences.Editor editor = sharedPref.edit();
|
|
||||||
|
|
||||||
String serverUrl = APIUrlHelper.cleanServerUrl(serverList.get(position).getHost());
|
String serverUrl = APIUrlHelper.cleanServerUrl(serverList.get(position).getHost());
|
||||||
|
|
||||||
// editor.putString("pref_api_base", serverUrl);
|
|
||||||
// editor.apply();
|
|
||||||
//
|
|
||||||
//
|
|
||||||
|
|
||||||
Toast.makeText(activity, activity.getString(R.string.server_selection_set_server, serverUrl), Toast.LENGTH_LONG).show();
|
Toast.makeText(activity, activity.getString(R.string.server_selection_set_server, serverUrl), Toast.LENGTH_LONG).show();
|
||||||
|
|
||||||
Intent intent = new Intent();
|
Intent intent = new Intent();
|
||||||
@ -138,17 +156,19 @@ public class ServerAdapter extends RecyclerView.Adapter<ServerAdapter.AccountVie
|
|||||||
return serverList.size();
|
return serverList.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
class AccountViewHolder extends RecyclerView.ViewHolder {
|
static class AccountViewHolder extends RecyclerView.ViewHolder {
|
||||||
|
|
||||||
TextView name, host, signupAllowed, shortDescription;
|
TextView name, host, signupAllowed, shortDescription, videoTotals;
|
||||||
|
ImageView isNSFW;
|
||||||
|
|
||||||
AccountViewHolder(View itemView) {
|
AccountViewHolder(View itemView) {
|
||||||
super(itemView);
|
super(itemView);
|
||||||
name = itemView.findViewById(R.id.name);
|
name = itemView.findViewById(R.id.sl_row_name);
|
||||||
host = itemView.findViewById(R.id.host);
|
host = itemView.findViewById(R.id.sl_row_host);
|
||||||
signupAllowed = itemView.findViewById(R.id.signupAllowed);
|
signupAllowed = itemView.findViewById(R.id.sl_row_signup_allowed);
|
||||||
shortDescription = itemView.findViewById(R.id.shortDescription);
|
shortDescription = itemView.findViewById(R.id.sl_row_short_description);
|
||||||
|
isNSFW = itemView.findViewById(R.id.sl_row_is_nsfw);
|
||||||
|
videoTotals = itemView.findViewById(R.id.sl_row_video_totals);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -176,7 +176,7 @@ public class VideoAdapter extends RecyclerView.Adapter<VideoAdapter.VideoViewHol
|
|||||||
|
|
||||||
VideoViewHolder(View itemView) {
|
VideoViewHolder(View itemView) {
|
||||||
super(itemView);
|
super(itemView);
|
||||||
name = itemView.findViewById(R.id.name);
|
name = itemView.findViewById(R.id.sl_row_name);
|
||||||
thumb = itemView.findViewById(R.id.thumb);
|
thumb = itemView.findViewById(R.id.thumb);
|
||||||
avatar = itemView.findViewById(R.id.avatar);
|
avatar = itemView.findViewById(R.id.avatar);
|
||||||
videoMeta = itemView.findViewById(R.id.videoMeta);
|
videoMeta = itemView.findViewById(R.id.videoMeta);
|
||||||
|
@ -172,7 +172,7 @@ public class VideoMetaDataFragment extends Fragment {
|
|||||||
|
|
||||||
|
|
||||||
// title / name
|
// title / name
|
||||||
TextView videoName = activity.findViewById(R.id.name);
|
TextView videoName = activity.findViewById(R.id.sl_row_name);
|
||||||
videoName.setText(video.getName());
|
videoName.setText(video.getName());
|
||||||
|
|
||||||
// created at / views
|
// created at / views
|
||||||
|
@ -268,6 +268,17 @@ public class VideoPlayerFragment extends Fragment implements VideoRendererEventL
|
|||||||
mService.player.setPlayWhenReady(!mService.player.getPlayWhenReady());
|
mService.player.setPlayWhenReady(!mService.player.getPlayWhenReady());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
public void unPauseVideo() {
|
||||||
|
if (mBound) {
|
||||||
|
mService.player.setPlayWhenReady(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public boolean isPaused(){
|
||||||
|
return !mService.player.getPlayWhenReady();
|
||||||
|
}
|
||||||
|
public void showControls(boolean value){
|
||||||
|
simpleExoPlayerView.setUseController(value);
|
||||||
|
}
|
||||||
public void stopVideo() {
|
public void stopVideo() {
|
||||||
|
|
||||||
if (mBound) {
|
if (mBound) {
|
||||||
|
@ -21,4 +21,5 @@ public class Constants {
|
|||||||
public static final String THEME_PREF_KEY = "pref_theme";
|
public static final String THEME_PREF_KEY = "pref_theme";
|
||||||
public static final String DEFAULT_THEME = "AppTheme.BLUE";
|
public static final String DEFAULT_THEME = "AppTheme.BLUE";
|
||||||
public static final String BACKGROUND_PLAY_PREF_KEY = "pref_background_play";
|
public static final String BACKGROUND_PLAY_PREF_KEY = "pref_background_play";
|
||||||
|
public static final String BACKGROUND_AUDIO = "BACKGROUND_AUDIO";
|
||||||
}
|
}
|
||||||
|
@ -18,20 +18,30 @@
|
|||||||
package net.schueller.peertube.helper;
|
package net.schueller.peertube.helper;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
|
||||||
import android.text.format.DateUtils;
|
import android.text.format.DateUtils;
|
||||||
|
|
||||||
import net.schueller.peertube.R;
|
import net.schueller.peertube.R;
|
||||||
|
|
||||||
import java.time.Duration;
|
import org.ocpsoft.prettytime.PrettyTime;
|
||||||
import java.time.Period;
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
|
|
||||||
public class MetaDataHelper {
|
public class MetaDataHelper {
|
||||||
|
|
||||||
|
|
||||||
public static String getMetaString(Date getCreatedAt, Integer viewCount, Context context) {
|
public static String getMetaString(Date getCreatedAt, Integer viewCount, Context context) {
|
||||||
return DateUtils.
|
|
||||||
getRelativeTimeSpanString(getCreatedAt.getTime()).toString() +
|
// Compatible with SDK 21+
|
||||||
|
String currentLanguage = Locale.getDefault().getDisplayLanguage();
|
||||||
|
PrettyTime p = new PrettyTime(currentLanguage);
|
||||||
|
String relativeTime = p.format(new Date(getCreatedAt.getTime()));
|
||||||
|
|
||||||
|
return (relativeTime +
|
||||||
context.getResources().getString(R.string.meta_data_seperator) +
|
context.getResources().getString(R.string.meta_data_seperator) +
|
||||||
viewCount + context.getResources().getString(R.string.meta_data_views);
|
viewCount + context.getResources().getString(R.string.meta_data_views));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String getOwnerString(String accountName, String serverHost, Context context) {
|
public static String getOwnerString(String accountName, String serverHost, Context context) {
|
||||||
|
@ -17,6 +17,9 @@
|
|||||||
*/
|
*/
|
||||||
package net.schueller.peertube.model;
|
package net.schueller.peertube.model;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
public class Server {
|
public class Server {
|
||||||
|
|
||||||
private Integer id;
|
private Integer id;
|
||||||
@ -26,16 +29,20 @@ public class Server {
|
|||||||
private String version;
|
private String version;
|
||||||
private Boolean signupAllowed;
|
private Boolean signupAllowed;
|
||||||
private Double userVideoQuota;
|
private Double userVideoQuota;
|
||||||
|
private Category category;
|
||||||
|
private ArrayList<String> languages;
|
||||||
|
private Boolean autoBlacklistUserVideosEnabled;
|
||||||
|
private String defaultNSFWPolicy;
|
||||||
|
private Boolean isNSFW;
|
||||||
private Integer totalUsers;
|
private Integer totalUsers;
|
||||||
private Integer totalVideos;
|
private Integer totalVideos;
|
||||||
private Integer totalLocalVideos;
|
private Integer totalLocalVideos;
|
||||||
private Integer totalInstanceFollowers;
|
private Integer totalInstanceFollowers;
|
||||||
private Integer totalInstanceFollowing;
|
private Integer totalInstanceFollowing;
|
||||||
|
|
||||||
private Boolean supportsIPv6;
|
private Boolean supportsIPv6;
|
||||||
private String country;
|
private String country;
|
||||||
|
|
||||||
private Integer health;
|
private Integer health;
|
||||||
|
private Date createdAt;
|
||||||
|
|
||||||
public Integer getId() {
|
public Integer getId() {
|
||||||
return id;
|
return id;
|
||||||
@ -93,6 +100,46 @@ public class Server {
|
|||||||
this.userVideoQuota = userVideoQuota;
|
this.userVideoQuota = userVideoQuota;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Category getCategory() {
|
||||||
|
return category;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCategory(Category category) {
|
||||||
|
this.category = category;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ArrayList<String> getLanguages() {
|
||||||
|
return languages;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setLanguages(ArrayList<String> languages) {
|
||||||
|
this.languages = languages;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Boolean getAutoBlacklistUserVideosEnabled() {
|
||||||
|
return autoBlacklistUserVideosEnabled;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setAutoBlacklistUserVideosEnabled(Boolean autoBlacklistUserVideosEnabled) {
|
||||||
|
this.autoBlacklistUserVideosEnabled = autoBlacklistUserVideosEnabled;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getDefaultNSFWPolicy() {
|
||||||
|
return defaultNSFWPolicy;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDefaultNSFWPolicy(String defaultNSFWPolicy) {
|
||||||
|
this.defaultNSFWPolicy = defaultNSFWPolicy;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Boolean getNSFW() {
|
||||||
|
return isNSFW;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setNSFW(Boolean NSFW) {
|
||||||
|
isNSFW = NSFW;
|
||||||
|
}
|
||||||
|
|
||||||
public Integer getTotalUsers() {
|
public Integer getTotalUsers() {
|
||||||
return totalUsers;
|
return totalUsers;
|
||||||
}
|
}
|
||||||
@ -156,4 +203,12 @@ public class Server {
|
|||||||
public void setHealth(Integer health) {
|
public void setHealth(Integer health) {
|
||||||
this.health = health;
|
this.health = health;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Date getCreatedAt() {
|
||||||
|
return createdAt;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCreatedAt(Date createdAt) {
|
||||||
|
this.createdAt = createdAt;
|
||||||
|
}
|
||||||
}
|
}
|
@ -64,6 +64,7 @@ import net.schueller.peertube.model.Video;
|
|||||||
|
|
||||||
import static android.media.session.PlaybackState.ACTION_PAUSE;
|
import static android.media.session.PlaybackState.ACTION_PAUSE;
|
||||||
import static android.media.session.PlaybackState.ACTION_PLAY;
|
import static android.media.session.PlaybackState.ACTION_PLAY;
|
||||||
|
import static com.google.android.exoplayer2.ui.PlayerNotificationManager.ACTION_STOP;
|
||||||
import static net.schueller.peertube.activity.VideoListActivity.EXTRA_VIDEOID;
|
import static net.schueller.peertube.activity.VideoListActivity.EXTRA_VIDEOID;
|
||||||
|
|
||||||
public class VideoPlayerService extends Service {
|
public class VideoPlayerService extends Service {
|
||||||
@ -107,6 +108,7 @@ public class VideoPlayerService extends Service {
|
|||||||
if (playbackState == ACTION_PLAY) { // this means that play is available, hence the audio is paused or stopped
|
if (playbackState == ACTION_PLAY) { // this means that play is available, hence the audio is paused or stopped
|
||||||
Log.v(TAG, "ACTION_PAUSE: " + playbackState);
|
Log.v(TAG, "ACTION_PAUSE: " + playbackState);
|
||||||
unregisterReceiver(myNoisyAudioStreamReceiver);
|
unregisterReceiver(myNoisyAudioStreamReceiver);
|
||||||
|
myNoisyAudioStreamReceiver=null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} );
|
} );
|
||||||
@ -243,6 +245,7 @@ public class VideoPlayerService extends Service {
|
|||||||
|
|
||||||
// don't show skip buttons in notification
|
// don't show skip buttons in notification
|
||||||
playerNotificationManager.setUseNavigationActions(false);
|
playerNotificationManager.setUseNavigationActions(false);
|
||||||
|
playerNotificationManager.setUseStopAction(true);
|
||||||
|
|
||||||
playerNotificationManager.setNotificationListener(
|
playerNotificationManager.setNotificationListener(
|
||||||
new PlayerNotificationManager.NotificationListener() {
|
new PlayerNotificationManager.NotificationListener() {
|
||||||
@ -254,9 +257,18 @@ public class VideoPlayerService extends Service {
|
|||||||
@Override
|
@Override
|
||||||
public void onNotificationCancelled(int notificationId) {
|
public void onNotificationCancelled(int notificationId) {
|
||||||
Log.v(TAG, "onNotificationCancelled...");
|
Log.v(TAG, "onNotificationCancelled...");
|
||||||
|
stopForeground(true);
|
||||||
|
Intent killFloat = new Intent(ACTION_STOP);
|
||||||
|
sendBroadcast(killFloat);
|
||||||
|
/*
|
||||||
|
Intent killFloat = new Intent(BROADCAST_ACTION);
|
||||||
|
Intent killFloatingWindow = new Intent(getApplicationContext(),VideoPlayActivity.class);
|
||||||
|
killFloatingWindow.putExtra("killFloat",true);
|
||||||
|
|
||||||
|
startActivity(killFloatingWindow);
|
||||||
// TODO: only kill the notification if we no longer have a bound activity
|
// TODO: only kill the notification if we no longer have a bound activity
|
||||||
stopForeground(true);
|
stopForeground(true);
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
10
app/src/main/res/drawable/ic_baseline_remove_red_eye_24.xml
Normal file
10
app/src/main/res/drawable/ic_baseline_remove_red_eye_24.xml
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:width="24dp"
|
||||||
|
android:height="24dp"
|
||||||
|
android:viewportWidth="24"
|
||||||
|
android:viewportHeight="24"
|
||||||
|
android:tint="?attr/colorControlNormal">
|
||||||
|
<path
|
||||||
|
android:fillColor="@android:color/white"
|
||||||
|
android:pathData="M12,4.5C7,4.5 2.73,7.61 1,12c1.73,4.39 6,7.5 11,7.5s9.27,-3.11 11,-7.5c-1.73,-4.39 -6,-7.5 -11,-7.5zM12,17c-2.76,0 -5,-2.24 -5,-5s2.24,-5 5,-5 5,2.24 5,5 -2.24,5 -5,5zM12,9c-1.66,0 -3,1.34 -3,3s1.34,3 3,3 3,-1.34 3,-3 -1.34,-3 -3,-3z"/>
|
||||||
|
</vector>
|
@ -1,6 +1,21 @@
|
|||||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent">
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<com.google.android.material.appbar.AppBarLayout
|
||||||
|
android:id="@+id/appbar_settings"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<androidx.appcompat.widget.Toolbar
|
||||||
|
android:id="@+id/tool_bar_settings"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:elevation="4dp" />
|
||||||
|
|
||||||
|
</com.google.android.material.appbar.AppBarLayout>
|
||||||
|
|
||||||
<FrameLayout
|
<FrameLayout
|
||||||
android:id="@+id/settings"
|
android:id="@+id/settings"
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
android:paddingEnd="12dp" />
|
android:paddingEnd="12dp" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/name"
|
android:id="@+id/sl_row_name"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_alignParentTop="true"
|
android:layout_alignParentTop="true"
|
||||||
@ -31,7 +31,7 @@
|
|||||||
android:id="@+id/videoMeta"
|
android:id="@+id/videoMeta"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_below="@+id/name"
|
android:layout_below="@+id/sl_row_name"
|
||||||
android:layout_alignParentEnd="true"
|
android:layout_alignParentEnd="true"
|
||||||
android:layout_marginStart="6dp"
|
android:layout_marginStart="6dp"
|
||||||
android:layout_marginTop="0dp"
|
android:layout_marginTop="0dp"
|
||||||
@ -58,7 +58,7 @@
|
|||||||
android:layout_marginStart="-16dp"
|
android:layout_marginStart="-16dp"
|
||||||
android:layout_marginTop="16dp"
|
android:layout_marginTop="16dp"
|
||||||
android:layout_marginEnd="0dp"
|
android:layout_marginEnd="0dp"
|
||||||
android:layout_toEndOf="@+id/name"
|
android:layout_toEndOf="@+id/sl_row_name"
|
||||||
android:background="@null"
|
android:background="@null"
|
||||||
android:contentDescription="@string/descr_overflow_button"
|
android:contentDescription="@string/descr_overflow_button"
|
||||||
android:textAppearance="@style/Base.TextAppearance.AppCompat.Caption" />
|
android:textAppearance="@style/Base.TextAppearance.AppCompat.Caption" />
|
||||||
|
@ -50,7 +50,7 @@
|
|||||||
android:paddingEnd="12dp" />
|
android:paddingEnd="12dp" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/name"
|
android:id="@+id/sl_row_name"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_below="@id/thumb"
|
android:layout_below="@id/thumb"
|
||||||
@ -66,7 +66,7 @@
|
|||||||
android:id="@+id/videoMeta"
|
android:id="@+id/videoMeta"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_below="@+id/name"
|
android:layout_below="@+id/sl_row_name"
|
||||||
android:layout_marginStart="6dp"
|
android:layout_marginStart="6dp"
|
||||||
android:layout_marginTop="0dp"
|
android:layout_marginTop="0dp"
|
||||||
android:layout_marginEnd="6dp"
|
android:layout_marginEnd="6dp"
|
||||||
@ -93,7 +93,7 @@
|
|||||||
android:layout_marginTop="16dp"
|
android:layout_marginTop="16dp"
|
||||||
android:layout_marginStart="-16dp"
|
android:layout_marginStart="-16dp"
|
||||||
android:layout_marginEnd="0dp"
|
android:layout_marginEnd="0dp"
|
||||||
android:layout_toEndOf="@+id/name"
|
android:layout_toEndOf="@+id/sl_row_name"
|
||||||
android:background="@null"
|
android:background="@null"
|
||||||
android:contentDescription="@string/descr_overflow_button"
|
android:contentDescription="@string/descr_overflow_button"
|
||||||
android:textAppearance="@style/Base.TextAppearance.AppCompat.Caption"
|
android:textAppearance="@style/Base.TextAppearance.AppCompat.Caption"
|
||||||
|
@ -50,7 +50,7 @@
|
|||||||
android:paddingEnd="12dp" />
|
android:paddingEnd="12dp" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/name"
|
android:id="@+id/sl_row_name"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_below="@id/thumb"
|
android:layout_below="@id/thumb"
|
||||||
@ -66,7 +66,7 @@
|
|||||||
android:id="@+id/videoMeta"
|
android:id="@+id/videoMeta"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_below="@+id/name"
|
android:layout_below="@+id/sl_row_name"
|
||||||
android:layout_marginStart="6dp"
|
android:layout_marginStart="6dp"
|
||||||
android:layout_marginTop="0dp"
|
android:layout_marginTop="0dp"
|
||||||
android:layout_marginEnd="6dp"
|
android:layout_marginEnd="6dp"
|
||||||
@ -93,7 +93,7 @@
|
|||||||
android:layout_marginTop="16dp"
|
android:layout_marginTop="16dp"
|
||||||
android:layout_marginStart="-16dp"
|
android:layout_marginStart="-16dp"
|
||||||
android:layout_marginEnd="0dp"
|
android:layout_marginEnd="0dp"
|
||||||
android:layout_toEndOf="@+id/name"
|
android:layout_toEndOf="@+id/sl_row_name"
|
||||||
android:background="@null"
|
android:background="@null"
|
||||||
android:contentDescription="@string/descr_overflow_button"
|
android:contentDescription="@string/descr_overflow_button"
|
||||||
android:textAppearance="@style/Base.TextAppearance.AppCompat.Caption"
|
android:textAppearance="@style/Base.TextAppearance.AppCompat.Caption"
|
||||||
|
@ -50,7 +50,7 @@
|
|||||||
android:paddingEnd="12dp" />
|
android:paddingEnd="12dp" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/name"
|
android:id="@+id/sl_row_name"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_below="@id/thumb"
|
android:layout_below="@id/thumb"
|
||||||
@ -66,7 +66,7 @@
|
|||||||
android:id="@+id/videoMeta"
|
android:id="@+id/videoMeta"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_below="@+id/name"
|
android:layout_below="@+id/sl_row_name"
|
||||||
android:layout_marginStart="6dp"
|
android:layout_marginStart="6dp"
|
||||||
android:layout_marginTop="0dp"
|
android:layout_marginTop="0dp"
|
||||||
android:layout_marginEnd="6dp"
|
android:layout_marginEnd="6dp"
|
||||||
@ -93,7 +93,7 @@
|
|||||||
android:layout_marginTop="16dp"
|
android:layout_marginTop="16dp"
|
||||||
android:layout_marginStart="-16dp"
|
android:layout_marginStart="-16dp"
|
||||||
android:layout_marginEnd="0dp"
|
android:layout_marginEnd="0dp"
|
||||||
android:layout_toEndOf="@+id/name"
|
android:layout_toEndOf="@+id/sl_row_name"
|
||||||
android:background="@null"
|
android:background="@null"
|
||||||
android:contentDescription="@string/descr_overflow_button"
|
android:contentDescription="@string/descr_overflow_button"
|
||||||
android:textAppearance="@style/Base.TextAppearance.AppCompat.Caption"
|
android:textAppearance="@style/Base.TextAppearance.AppCompat.Caption"
|
||||||
|
@ -7,15 +7,18 @@
|
|||||||
card_view:cardElevation="0dp"
|
card_view:cardElevation="0dp"
|
||||||
card_view:cardUseCompatPadding="true">
|
card_view:cardUseCompatPadding="true">
|
||||||
|
|
||||||
|
<RelativeLayout
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:padding="12dp">
|
||||||
|
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:orientation="vertical"
|
android:orientation="vertical">
|
||||||
android:padding="12dp">
|
|
||||||
|
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/name"
|
android:id="@+id/sl_row_name"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginStart="6dp"
|
android:layout_marginStart="6dp"
|
||||||
@ -24,7 +27,7 @@
|
|||||||
android:textAppearance="@style/Base.TextAppearance.AppCompat.Headline" />
|
android:textAppearance="@style/Base.TextAppearance.AppCompat.Headline" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/host"
|
android:id="@+id/sl_row_host"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginStart="6dp"
|
android:layout_marginStart="6dp"
|
||||||
@ -33,7 +36,7 @@
|
|||||||
android:textAppearance="@style/Base.TextAppearance.AppCompat.Subhead" />
|
android:textAppearance="@style/Base.TextAppearance.AppCompat.Subhead" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/signupAllowed"
|
android:id="@+id/sl_row_signup_allowed"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginStart="6dp"
|
android:layout_marginStart="6dp"
|
||||||
@ -43,14 +46,45 @@
|
|||||||
|
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/shortDescription"
|
android:id="@+id/sl_row_short_description"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginStart="6dp"
|
android:layout_marginStart="6dp"
|
||||||
android:layout_marginEnd="24dp"
|
android:layout_marginEnd="24dp"
|
||||||
android:paddingTop="0dp"
|
android:paddingTop="0dp"
|
||||||
|
android:visibility="gone"
|
||||||
android:textAppearance="@style/Base.TextAppearance.AppCompat.Subhead" />
|
android:textAppearance="@style/Base.TextAppearance.AppCompat.Subhead" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:paddingTop="0dp"
|
||||||
|
android:layout_marginStart="6dp"
|
||||||
|
android:layout_marginEnd="24dp"
|
||||||
|
android:orientation="horizontal">
|
||||||
|
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/sl_row_video_totals"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:textAppearance="@style/Base.TextAppearance.AppCompat.Subhead" />
|
||||||
|
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:id="@+id/sl_row_is_nsfw"
|
||||||
|
android:src="@drawable/ic_baseline_remove_red_eye_24"
|
||||||
|
android:visibility="gone"
|
||||||
|
android:layout_width="24dp"
|
||||||
|
|
||||||
|
android:layout_alignParentEnd="true"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:contentDescription="@string/server_selection_nsfw_instance" />
|
||||||
|
|
||||||
|
</RelativeLayout>
|
||||||
|
|
||||||
</androidx.cardview.widget.CardView>
|
</androidx.cardview.widget.CardView>
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
xmlns:card_view="http://schemas.android.com/apk/res-auto"
|
xmlns:card_view="http://schemas.android.com/apk/res-auto"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
|
android:focusable="true"
|
||||||
card_view:cardCornerRadius="0dp"
|
card_view:cardCornerRadius="0dp"
|
||||||
card_view:cardElevation="0dp"
|
card_view:cardElevation="0dp"
|
||||||
card_view:contentPadding="0dp"
|
card_view:contentPadding="0dp"
|
||||||
@ -57,7 +58,7 @@
|
|||||||
android:paddingEnd="12dp" />
|
android:paddingEnd="12dp" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/name"
|
android:id="@+id/sl_row_name"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_below="@id/thumb"
|
android:layout_below="@id/thumb"
|
||||||
@ -73,7 +74,7 @@
|
|||||||
android:id="@+id/videoMeta"
|
android:id="@+id/videoMeta"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_below="@+id/name"
|
android:layout_below="@+id/sl_row_name"
|
||||||
android:layout_marginStart="6dp"
|
android:layout_marginStart="6dp"
|
||||||
android:layout_marginTop="0dp"
|
android:layout_marginTop="0dp"
|
||||||
android:layout_marginEnd="6dp"
|
android:layout_marginEnd="6dp"
|
||||||
@ -100,7 +101,7 @@
|
|||||||
android:layout_marginTop="16dp"
|
android:layout_marginTop="16dp"
|
||||||
android:layout_marginStart="-16dp"
|
android:layout_marginStart="-16dp"
|
||||||
android:layout_marginEnd="0dp"
|
android:layout_marginEnd="0dp"
|
||||||
android:layout_toEndOf="@+id/name"
|
android:layout_toEndOf="@+id/sl_row_name"
|
||||||
android:background="@null"
|
android:background="@null"
|
||||||
android:contentDescription="@string/descr_overflow_button"
|
android:contentDescription="@string/descr_overflow_button"
|
||||||
android:textAppearance="@style/Base.TextAppearance.AppCompat.Caption"
|
android:textAppearance="@style/Base.TextAppearance.AppCompat.Caption"
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<resources>
|
<resources>
|
||||||
<string name="app_name">Thorium</string>
|
|
||||||
<string name="title_activity_video_play">نشاط تشغيل الفيديو</string>
|
|
||||||
<string name="title_activity_settings">الإعدادات</string>
|
<string name="title_activity_settings">الإعدادات</string>
|
||||||
<string name="title_activity_login">تسجيل الدخول</string>
|
<string name="title_activity_login">تسجيل الدخول</string>
|
||||||
<!-- Strings related to login -->
|
<!-- Strings related to login -->
|
||||||
@ -24,13 +22,9 @@
|
|||||||
<string name="bottom_nav_title_subscriptions">الإشتراكات</string>
|
<string name="bottom_nav_title_subscriptions">الإشتراكات</string>
|
||||||
<string name="bottom_nav_title_account">الحساب</string>
|
<string name="bottom_nav_title_account">الحساب</string>
|
||||||
<!-- Strings related to Settings -->
|
<!-- Strings related to Settings -->
|
||||||
<string name="peertube_required_server_version">1.0.0-alpha.7</string>
|
|
||||||
<string name="pref_default_api_base_url" formatted="false">https://troll.tv</string>
|
|
||||||
<string name="pref_title_peertube_server">خادوم PeerTube</string>
|
<string name="pref_title_peertube_server">خادوم PeerTube</string>
|
||||||
<!-- Strings related to Video meta data -->
|
<!-- Strings related to Video meta data -->
|
||||||
<string name="meta_data_seperator">\u0020-\u0020</string>
|
|
||||||
<string name="meta_data_views">\u0020 مشاهدات</string>
|
<string name="meta_data_views">\u0020 مشاهدات</string>
|
||||||
<string name="meta_data_owner_seperator">\@</string>
|
|
||||||
<string name="video_row_video_thumbnail">الصورة المصغرة للفيديو</string>
|
<string name="video_row_video_thumbnail">الصورة المصغرة للفيديو</string>
|
||||||
<string name="video_row_account_avatar">الصورة الرمزية للحساب</string>
|
<string name="video_row_account_avatar">الصورة الرمزية للحساب</string>
|
||||||
<string name="pref_title_show_nsfw">عرض NSFW</string>
|
<string name="pref_title_show_nsfw">عرض NSFW</string>
|
||||||
@ -51,7 +45,6 @@
|
|||||||
<string name="no_data_available">لاتوجد نتائج</string>
|
<string name="no_data_available">لاتوجد نتائج</string>
|
||||||
<string name="descr_overflow_button">المزيد</string>
|
<string name="descr_overflow_button">المزيد</string>
|
||||||
<string name="menu_share">مشاركة</string>
|
<string name="menu_share">مشاركة</string>
|
||||||
<string name="playback_channel_name">PeerTube</string>
|
|
||||||
<string name="invalid_url">الرابط غير صالح.</string>
|
<string name="invalid_url">الرابط غير صالح.</string>
|
||||||
<string name="pref_title_dark_mode">الوضع الداكن</string>
|
<string name="pref_title_dark_mode">الوضع الداكن</string>
|
||||||
<string name="pref_description_dark_mode">أعد تشغيل التطبيق لتنشيط الوضع الداكن.</string>
|
<string name="pref_description_dark_mode">أعد تشغيل التطبيق لتنشيط الوضع الداكن.</string>
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<resources>
|
<resources>
|
||||||
<string name="app_name" translatable="false">Thorium</string>
|
|
||||||
<string name="title_activity_video_play">VideoPlayActivity</string>
|
|
||||||
<string name="title_activity_settings">সেটিংস</string>
|
<string name="title_activity_settings">সেটিংস</string>
|
||||||
<string name="title_activity_login">সাইন ইন</string>
|
<string name="title_activity_login">সাইন ইন</string>
|
||||||
<!-- Strings related to login -->
|
<!-- Strings related to login -->
|
||||||
@ -25,13 +23,9 @@
|
|||||||
<string name="bottom_nav_title_subscriptions">সাবস্ক্রিপশন</string>
|
<string name="bottom_nav_title_subscriptions">সাবস্ক্রিপশন</string>
|
||||||
<string name="bottom_nav_title_account">অ্যাকাউন্ট</string>
|
<string name="bottom_nav_title_account">অ্যাকাউন্ট</string>
|
||||||
<!-- Strings related to Settings -->
|
<!-- Strings related to Settings -->
|
||||||
<string name="peertube_required_server_version" translatable="false">1.0.0-alpha.7</string>
|
|
||||||
<string name="pref_default_api_base_url" formatted="false" translatable="false">https://troll.tv</string>
|
|
||||||
<string name="pref_title_peertube_server">পিয়ারটিউব সার্ভার</string>
|
<string name="pref_title_peertube_server">পিয়ারটিউব সার্ভার</string>
|
||||||
<!-- Strings related to Video meta data -->
|
<!-- Strings related to Video meta data -->
|
||||||
<string name="meta_data_seperator" translatable="false">\u0020-\u0020</string>
|
|
||||||
<string name="meta_data_views">" দৃষ্ট"</string>
|
<string name="meta_data_views">" দৃষ্ট"</string>
|
||||||
<string name="meta_data_owner_seperator" translatable="false">\@</string>
|
|
||||||
<string name="video_row_video_thumbnail">ভিডিও থাম্বনেইল</string>
|
<string name="video_row_video_thumbnail">ভিডিও থাম্বনেইল</string>
|
||||||
<string name="video_row_account_avatar">অ্যাকাউন্ট অবতার</string>
|
<string name="video_row_account_avatar">অ্যাকাউন্ট অবতার</string>
|
||||||
<string name="pref_title_show_nsfw">নিষিদ্ধ কন্টেন্ট</string>
|
<string name="pref_title_show_nsfw">নিষিদ্ধ কন্টেন্ট</string>
|
||||||
@ -52,7 +46,6 @@
|
|||||||
<string name="no_data_available">ফলাফল নেই</string>
|
<string name="no_data_available">ফলাফল নেই</string>
|
||||||
<string name="descr_overflow_button">আরও</string>
|
<string name="descr_overflow_button">আরও</string>
|
||||||
<string name="menu_share">শেয়ার</string>
|
<string name="menu_share">শেয়ার</string>
|
||||||
<string name="playback_channel_name" translatable="false">PeerTube</string>
|
|
||||||
<string name="invalid_url">অবৈধ ইউআরএল।</string>
|
<string name="invalid_url">অবৈধ ইউআরএল।</string>
|
||||||
<string name="pref_title_dark_mode">অন্ধকার মোড</string>
|
<string name="pref_title_dark_mode">অন্ধকার মোড</string>
|
||||||
<string name="pref_description_dark_mode">অন্ধকার মোড কার্যকর করার জন্য অ্যাপ্লিকেশন রিস্টার্ট করো।</string>
|
<string name="pref_description_dark_mode">অন্ধকার মোড কার্যকর করার জন্য অ্যাপ্লিকেশন রিস্টার্ট করো।</string>
|
||||||
@ -157,7 +150,7 @@
|
|||||||
<string name="ln">লিনগালা</string>
|
<string name="ln">লিনগালা</string>
|
||||||
<string name="lt">লিথুনীয়</string>
|
<string name="lt">লিথুনীয়</string>
|
||||||
<string name="jbo">লোজবান</string>
|
<string name="jbo">লোজবান</string>
|
||||||
<string name="lu"></string>
|
<string name="lu">লুবা-কাতাঙ্গা</string>
|
||||||
<string name="lb">লাক্সেমবোর্গীয়</string>
|
<string name="lb">লাক্সেমবোর্গীয়</string>
|
||||||
<string name="mk">ম্যাসিডোনিয়</string>
|
<string name="mk">ম্যাসিডোনিয়</string>
|
||||||
<string name="mg">মালাগাসি</string>
|
<string name="mg">মালাগাসি</string>
|
||||||
@ -272,15 +265,6 @@
|
|||||||
<string name="video_speed_10">Normal</string>
|
<string name="video_speed_10">Normal</string>
|
||||||
<string name="video_speed_15">১.৫x</string>
|
<string name="video_speed_15">১.৫x</string>
|
||||||
<string name="video_speed_20">2x</string>
|
<string name="video_speed_20">2x</string>
|
||||||
<string name="video_speed_active_icon" translatable="false">{faw-check}</string>
|
|
||||||
<string name="video_expand_icon" translatable="false">{faw-expand}</string>
|
|
||||||
<string name="video_compress_icon" translatable="false">{faw-compress}</string>
|
|
||||||
<string name="video_more_icon" translatable="false">{faw-ellipsis-v}</string>
|
|
||||||
<string name="video_thumbs_up_icon" translatable="false">{faw-thumbs-up}</string>
|
|
||||||
<string name="video_thumbs_down_icon" translatable="false">{faw-thumbs-down}</string>
|
|
||||||
<string name="video_share_icon" translatable="false">{faw-share}</string>
|
|
||||||
<string name="video_download_icon" translatable="false">{faw-download}</string>
|
|
||||||
<string name="video_save_icon" translatable="false">{faw-save}</string>
|
|
||||||
<string name="pref_title_background_play">ব্যাকগ্রাউন্ড প্লেব্যাক</string>
|
<string name="pref_title_background_play">ব্যাকগ্রাউন্ড প্লেব্যাক</string>
|
||||||
<string name="pref_description_background_play">সক্রিয় থাকলে ব্যাকগ্রাউন্ডে ভিডিও প্লে করতে থাকবে।</string>
|
<string name="pref_description_background_play">সক্রিয় থাকলে ব্যাকগ্রাউন্ডে ভিডিও প্লে করতে থাকবে।</string>
|
||||||
<string name="bottom_nav_title_local">স্থানীয়</string>
|
<string name="bottom_nav_title_local">স্থানীয়</string>
|
||||||
@ -298,15 +282,6 @@
|
|||||||
<string name="video_meta_button_language">ভাষা</string>
|
<string name="video_meta_button_language">ভাষা</string>
|
||||||
<string name="video_meta_button_tags">Tags</string>
|
<string name="video_meta_button_tags">Tags</string>
|
||||||
<!-- Constants, Don't translate -->
|
<!-- Constants, Don't translate -->
|
||||||
<string name="pref_token_access" translatable="false">pref_token_access</string>
|
|
||||||
<string name="pref_token_refresh" translatable="false">pref_token_refresh</string>
|
|
||||||
<string name="pref_token_expiration" translatable="false">pref_token_expiration</string>
|
|
||||||
<string name="pref_token_type" translatable="false">pref_token_type</string>
|
|
||||||
<string name="pref_auth_username" translatable="false">pref_auth_username</string>
|
|
||||||
<string name="pref_auth_password" translatable="false">pref_auth_password</string>
|
|
||||||
<string name="video_rating_none" translatable="false">none</string>
|
|
||||||
<string name="video_rating_like" translatable="false">like</string>
|
|
||||||
<string name="video_rating_dislike" translatable="false">dislike</string>
|
|
||||||
<string name="deeppurple">গাঢ় বেগুনি</string>
|
<string name="deeppurple">গাঢ় বেগুনি</string>
|
||||||
<string name="action_bar_title_account">অ্যাকাউন্ট</string>
|
<string name="action_bar_title_account">অ্যাকাউন্ট</string>
|
||||||
<string name="bottom_nav_title_recent">সাম্প্রতিক</string>
|
<string name="bottom_nav_title_recent">সাম্প্রতিক</string>
|
||||||
@ -331,4 +306,41 @@
|
|||||||
<string name="server_selection_select_a_server">নিচের তালিকা থেকে একটি সার্ভার নিন অথবা সরাসরি একটি সার্ভার দিন।</string>
|
<string name="server_selection_select_a_server">নিচের তালিকা থেকে একটি সার্ভার নিন অথবা সরাসরি একটি সার্ভার দিন।</string>
|
||||||
<string name="video_speed_075">0.75x</string>
|
<string name="video_speed_075">0.75x</string>
|
||||||
<string name="video_speed_125">1.25x</string>
|
<string name="video_speed_125">1.25x</string>
|
||||||
|
<string name="pref_background_behavior">ব্যাকগ্রউন্ড প্লে এর কনফিগারেশন</string>
|
||||||
|
<string name="settings_activity_look_and_feel_category_title">লুক এবং ফিল</string>
|
||||||
|
<string name="server_book_list_has_login">লগইন আছে</string>
|
||||||
|
<string name="pref_background_audio">পেছনে অডিও স্ট্রিম হিসেবে চালু রাখুন</string>
|
||||||
|
<string name="settings_activity_about_category_title">সম্পর্কিত</string>
|
||||||
|
<string name="settings_activity_video_playback_category_title">ভিডিও প্লেব্যাক</string>
|
||||||
|
<string name="settings_activity_video_list_category_title">ভিডিও এর লিস্ট</string>
|
||||||
|
<string name="title_activity_me">আকাউন্ট</string>
|
||||||
|
<string name="title_activity_select_server">সার্ভার পাছন্দ করুন</string>
|
||||||
|
<string name="server_book_del_alert_msg">আপনি কি এই সার্ভার রিমুভ করতে চান সার্ভার বই থেকে\?</string>
|
||||||
|
<string name="server_book_del_alert_title">সার্ভার রিমুভ করুন</string>
|
||||||
|
<string name="title_activity_server_address_book">এড্রেস বই</string>
|
||||||
|
<string name="server_book_add_add_button">যোগ</string>
|
||||||
|
<string name="server_book_add_password">পাসওয়ার্ড</string>
|
||||||
|
<string name="server_book_add_username">ইউজারনেম</string>
|
||||||
|
<string name="server_book_add_pick_server_button">সার্চ</string>
|
||||||
|
<string name="server_book_add_server_url">সার্ভার ইউআরএল</string>
|
||||||
|
<string name="server_book_add_label">লেবেল</string>
|
||||||
|
<string name="me_help_and_feedback_button">সাহায্য ও মতামত</string>
|
||||||
|
<string name="me_logout_button">লগ আউট</string>
|
||||||
|
<string name="server_book_valid_url_is_required">সঠিক ইউ আর এল দরকার</string>
|
||||||
|
<string name="server_book_label_is_required">সার্ভার লেবেল দরকার</string>
|
||||||
|
<string name="server_book_no_servers_found">সার্ভার বই খালি আছে</string>
|
||||||
|
<string name="authentication_login_failed">লগইন সফল হয় নি!</string>
|
||||||
|
<string name="authentication_login_success">লগইন সফল হয়েছে</string>
|
||||||
|
<string name="bn_rBD">বাংলা (বাংলাদেশ)</string>
|
||||||
|
<string name="clear_search_history_prompt">আপনি কি পুরোপুরি সার্চ ইতিহাস মুছে ফেলতে চান\?</string>
|
||||||
|
<string name="clear_search_history">সার্চ ইতিহাস মুছে ফেলুন</string>
|
||||||
|
<string name="pref_background_behavior_summary">চালু ভিডিও কি করবে যখন পেছনে যাবে</string>
|
||||||
|
<string name="settings_permissions_error_float">অ্যান্ড্রয়েড সেটিং এ পিকচার ইন পিকচার পারমিশন বন্ধ আছে এই আয়াপ এ</string>
|
||||||
|
<string name="settings_api_error_float">অ্যান্ড্রয়েড ভার্সন ভাসমান ভিডিও সাপোর্ট করে</string>
|
||||||
|
<string name="pref_background_float">ভাসমান উইন্ডো তে ভিডিও চালু রাখুন</string>
|
||||||
|
<string name="pref_background_stop">সব প্লেব্যাক বন্ধ করুন</string>
|
||||||
|
<string name="pref_description_language_app">ভাষা পছন্দ করুন অ্যাপ্লিকেশান এর জন্য। রিস্টার্ট করুন পরিবর্তন দেখার জন্য।</string>
|
||||||
|
<string name="pref_language_app">অ্যাপ্লিকেশান এর ভাষা</string>
|
||||||
|
<string name="pref_description_back_pause">ভিডিও চলার সময় ব্যাকগ্রাউন্ড প্লে পজ হবে ব্যাক বাটন প্রেস করলে।</string>
|
||||||
|
<string name="pref_title_back_pause">ব্যাক বাটন এ পজ</string>
|
||||||
</resources>
|
</resources>
|
@ -16,7 +16,6 @@
|
|||||||
<string name="bottom_nav_title_subscriptions">Abos</string>
|
<string name="bottom_nav_title_subscriptions">Abos</string>
|
||||||
<string name="bottom_nav_title_account">Konto</string>
|
<string name="bottom_nav_title_account">Konto</string>
|
||||||
<string name="pref_title_peertube_server">PeerTube-Server</string>
|
<string name="pref_title_peertube_server">PeerTube-Server</string>
|
||||||
<string name="title_activity_video_play">VideoPlayActivity</string>
|
|
||||||
<string name="error_invalid_password">Dieses Passwort ist zu kurz</string>
|
<string name="error_invalid_password">Dieses Passwort ist zu kurz</string>
|
||||||
<string name="error_incorrect_password">Dieses Passwort ist falsch</string>
|
<string name="error_incorrect_password">Dieses Passwort ist falsch</string>
|
||||||
<string name="action_bar_title_settings">Einstellungen</string>
|
<string name="action_bar_title_settings">Einstellungen</string>
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<resources>
|
<resources>
|
||||||
<string name="app_name">Thorium</string>
|
|
||||||
<string name="title_activity_video_play">VideoPlayActivity</string>
|
|
||||||
<string name="title_activity_settings">Paramètres</string>
|
<string name="title_activity_settings">Paramètres</string>
|
||||||
<string name="title_activity_login">Se connecter</string>
|
<string name="title_activity_login">Se connecter</string>
|
||||||
<!-- Strings related to login -->
|
<!-- Strings related to login -->
|
||||||
@ -24,13 +22,9 @@
|
|||||||
<string name="bottom_nav_title_subscriptions">Abonnements</string>
|
<string name="bottom_nav_title_subscriptions">Abonnements</string>
|
||||||
<string name="bottom_nav_title_account">Compte</string>
|
<string name="bottom_nav_title_account">Compte</string>
|
||||||
<!-- Strings related to Settings -->
|
<!-- Strings related to Settings -->
|
||||||
<string name="peertube_required_server_version">1.0.0-alpha.7</string>
|
|
||||||
<string name="pref_default_api_base_url" formatted="false">https://troll.tv</string>
|
|
||||||
<string name="pref_title_peertube_server">Serveur Peertube</string>
|
<string name="pref_title_peertube_server">Serveur Peertube</string>
|
||||||
<!-- Strings related to Video meta data -->
|
<!-- Strings related to Video meta data -->
|
||||||
<string name="meta_data_seperator">\u0020-\u0020</string>
|
|
||||||
<string name="meta_data_views">" vues"</string>
|
<string name="meta_data_views">" vues"</string>
|
||||||
<string name="meta_data_owner_seperator">\@</string>
|
|
||||||
<string name="video_row_video_thumbnail">Miniature vidéo</string>
|
<string name="video_row_video_thumbnail">Miniature vidéo</string>
|
||||||
<string name="video_row_account_avatar">Avatar du compte</string>
|
<string name="video_row_account_avatar">Avatar du compte</string>
|
||||||
<string name="pref_title_show_nsfw">Contenu pour adultes</string>
|
<string name="pref_title_show_nsfw">Contenu pour adultes</string>
|
||||||
@ -49,7 +43,6 @@
|
|||||||
<string name="no_data_available">Pas de résultat</string>
|
<string name="no_data_available">Pas de résultat</string>
|
||||||
<string name="descr_overflow_button">Plus</string>
|
<string name="descr_overflow_button">Plus</string>
|
||||||
<string name="menu_share">Partager</string>
|
<string name="menu_share">Partager</string>
|
||||||
<string name="playback_channel_name">PeerTube</string>
|
|
||||||
<string name="invalid_url">URL invalide.</string>
|
<string name="invalid_url">URL invalide.</string>
|
||||||
<string name="pref_title_dark_mode">Mode sombre</string>
|
<string name="pref_title_dark_mode">Mode sombre</string>
|
||||||
<string name="pref_description_dark_mode">Redémarrez l’application pour que le mode sombre soit activé.</string>
|
<string name="pref_description_dark_mode">Redémarrez l’application pour que le mode sombre soit activé.</string>
|
||||||
@ -312,7 +305,7 @@
|
|||||||
<string name="login_current_server_hint">Serveur actuel</string>
|
<string name="login_current_server_hint">Serveur actuel</string>
|
||||||
<string name="video_speed_075">0,75×</string>
|
<string name="video_speed_075">0,75×</string>
|
||||||
<string name="video_speed_125">1,25×</string>
|
<string name="video_speed_125">1,25×</string>
|
||||||
<string name="title_activity_server_address_book">Livre d\'adresse</string>
|
<string name="title_activity_server_address_book">Carnet d\'adresses</string>
|
||||||
<string name="authentication_login_success">Identification réussie</string>
|
<string name="authentication_login_success">Identification réussie</string>
|
||||||
<string name="authentication_login_failed">Identification échouée !</string>
|
<string name="authentication_login_failed">Identification échouée !</string>
|
||||||
<string name="server_book_list_has_login">a un identifiant</string>
|
<string name="server_book_list_has_login">a un identifiant</string>
|
||||||
@ -333,4 +326,21 @@
|
|||||||
<string name="pref_language_app">Langue de l\'application</string>
|
<string name="pref_language_app">Langue de l\'application</string>
|
||||||
<string name="pref_description_back_pause">Mettre la lecture d\'arrière-plan en pause en appuyant sur la touche de retour pendant la lecture de la vidéo.</string>
|
<string name="pref_description_back_pause">Mettre la lecture d\'arrière-plan en pause en appuyant sur la touche de retour pendant la lecture de la vidéo.</string>
|
||||||
<string name="pref_title_back_pause">Pause sur le bouton retour</string>
|
<string name="pref_title_back_pause">Pause sur le bouton retour</string>
|
||||||
|
<string name="settings_activity_look_and_feel_category_title">Apparence</string>
|
||||||
|
<string name="title_activity_settings2">SettingsActivity2</string>
|
||||||
|
<string name="bn_rBD">Bengalais (Bangladesh)</string>
|
||||||
|
<string name="settings_activity_about_category_title">À propos</string>
|
||||||
|
<string name="title_activity_me">Compte</string>
|
||||||
|
<string name="pref_background_behavior">Paramètres de lecture en fond</string>
|
||||||
|
<string name="settings_api_error_float">Votre version Android ne supporte pas la lecture de vidéos dans une fenêtre flottante</string>
|
||||||
|
<string name="settings_permissions_error_float">Le mode Picture-in-Picture est désactivé pour cette applications dans les paramètres Android</string>
|
||||||
|
<string name="settings_activity_video_playback_category_title">Lecture de vidéos</string>
|
||||||
|
<string name="pref_background_audio">Continuer en fond sonore</string>
|
||||||
|
<string name="pref_background_stop">Arrêter de lire la vidéo</string>
|
||||||
|
<string name="pref_background_float">Continuer dans une fenêtre flottante</string>
|
||||||
|
<string name="pref_background_behavior_summary">Sélectionner le mode de fonctionnement de la lecture de vidéo lorsque l\'application est mise en arrière-plan</string>
|
||||||
|
<string name="settings_activity_video_list_category_title">Liste de vidéos</string>
|
||||||
|
<string name="title_activity_select_server">Sélectionner un serveur</string>
|
||||||
|
<string name="server_book_del_alert_title">Retirer un serveur</string>
|
||||||
|
<string name="server_book_del_alert_msg">Voulez-vous vraiment retirer ce serveur de votre carnet d\'adresses ?</string>
|
||||||
</resources>
|
</resources>
|
@ -61,7 +61,6 @@
|
|||||||
<string name="account_about_description">Beskrivelse:</string>
|
<string name="account_about_description">Beskrivelse:</string>
|
||||||
<string name="account_about_joined">Tok del:</string>
|
<string name="account_about_joined">Tok del:</string>
|
||||||
<string name="api_error">Noe gikk galt, prøv igjen senere.</string>
|
<string name="api_error">Noe gikk galt, prøv igjen senere.</string>
|
||||||
<string name="title_activity_video_play">VideoPlayActivity</string>
|
|
||||||
<string name="permission_rationale">Innvilg kontakttilgang for fullføring av e-postadresser.</string>
|
<string name="permission_rationale">Innvilg kontakttilgang for fullføring av e-postadresser.</string>
|
||||||
<string name="bottom_nav_title_trending">Populært</string>
|
<string name="bottom_nav_title_trending">Populært</string>
|
||||||
<string name="meta_data_views">" visninger"</string>
|
<string name="meta_data_views">" visninger"</string>
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<resources>
|
<resources>
|
||||||
<string name="title_activity_video_play">VideoPlayActivity</string>
|
|
||||||
<string name="title_activity_settings">Instellingen</string>
|
<string name="title_activity_settings">Instellingen</string>
|
||||||
<string name="title_activity_login">Inloggen</string>
|
<string name="title_activity_login">Inloggen</string>
|
||||||
<string name="prompt_server">Server</string>
|
<string name="prompt_server">Server</string>
|
||||||
@ -323,4 +322,21 @@
|
|||||||
<string name="pref_language_app">App-taal</string>
|
<string name="pref_language_app">App-taal</string>
|
||||||
<string name="pref_description_back_pause">Pauzeer het afspelen als er op de terugknop wordt gedrukt.</string>
|
<string name="pref_description_back_pause">Pauzeer het afspelen als er op de terugknop wordt gedrukt.</string>
|
||||||
<string name="pref_title_back_pause">Pauzeren na drukken op terugknop</string>
|
<string name="pref_title_back_pause">Pauzeren na drukken op terugknop</string>
|
||||||
|
<string name="settings_activity_look_and_feel_category_title">Uiterlijk</string>
|
||||||
|
<string name="settings_activity_about_category_title">Over</string>
|
||||||
|
<string name="settings_activity_video_playback_category_title">Video afspelen</string>
|
||||||
|
<string name="settings_activity_video_list_category_title">Videolijst</string>
|
||||||
|
<string name="title_activity_settings2">SettingsActivity2</string>
|
||||||
|
<string name="title_activity_me">Account</string>
|
||||||
|
<string name="title_activity_select_server">Server kiezen</string>
|
||||||
|
<string name="server_book_del_alert_msg">Weet je zeker dat je deze server wilt verwijderen uit het adresboek\?</string>
|
||||||
|
<string name="server_book_del_alert_title">Server verwijderen</string>
|
||||||
|
<string name="bn_rBD">Bengaals (Bangladesh)</string>
|
||||||
|
<string name="pref_background_behavior_summary">Hoe een video moet worden afgespeeld op de achtergrond</string>
|
||||||
|
<string name="settings_permissions_error_float">Picture-in-picturemachtiging is niet afgegeven voor deze app in de Android-instellingen</string>
|
||||||
|
<string name="settings_api_error_float">Deze Android-versie ondersteunt geen zwevende video\'s</string>
|
||||||
|
<string name="pref_background_behavior">Afspelen op achtergrond</string>
|
||||||
|
<string name="pref_background_float">Video afspelen in zwevend venster</string>
|
||||||
|
<string name="pref_background_stop">Afspelen stoppen</string>
|
||||||
|
<string name="pref_background_audio">Audio afspelen op achtergrond</string>
|
||||||
</resources>
|
</resources>
|
@ -282,7 +282,6 @@
|
|||||||
<string name="account_about_description">Beskrivning:</string>
|
<string name="account_about_description">Beskrivning:</string>
|
||||||
<string name="account_about_joined">Gick med:</string>
|
<string name="account_about_joined">Gick med:</string>
|
||||||
<string name="api_error">Någonting gick snett, försök gärna igen om en stund!</string>
|
<string name="api_error">Någonting gick snett, försök gärna igen om en stund!</string>
|
||||||
<string name="title_activity_video_play">VideoPlayActivity</string>
|
|
||||||
<string name="permission_rationale">Ge åtkomst till kontakter för komplettering av e-postadresser.</string>
|
<string name="permission_rationale">Ge åtkomst till kontakter för komplettering av e-postadresser.</string>
|
||||||
<string name="title_activity_url_video_play">UrlVideoPlayActivity</string>
|
<string name="title_activity_url_video_play">UrlVideoPlayActivity</string>
|
||||||
<string name="pref_description_license">
|
<string name="pref_description_license">
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<resources>
|
<resources>
|
||||||
<string name="title_activity_video_play">İzleti Oynatma Etkinliği</string>
|
|
||||||
<string name="title_activity_settings">Ayarlar</string>
|
<string name="title_activity_settings">Ayarlar</string>
|
||||||
<string name="title_activity_login">Oturum aç</string>
|
<string name="title_activity_login">Oturum aç</string>
|
||||||
<!-- Strings related to login -->
|
<!-- Strings related to login -->
|
||||||
@ -24,13 +23,9 @@
|
|||||||
<string name="bottom_nav_title_subscriptions">Abonelikler</string>
|
<string name="bottom_nav_title_subscriptions">Abonelikler</string>
|
||||||
<string name="bottom_nav_title_account">Hesap</string>
|
<string name="bottom_nav_title_account">Hesap</string>
|
||||||
<!-- Strings related to Settings -->
|
<!-- Strings related to Settings -->
|
||||||
<string name="peertube_required_server_version" translatable="false">1.0.0-alpha.7</string>
|
|
||||||
<string name="pref_default_api_base_url" formatted="false" translatable="false">https://troll.tv</string>
|
|
||||||
<string name="pref_title_peertube_server">PeerTube Sunucusu</string>
|
<string name="pref_title_peertube_server">PeerTube Sunucusu</string>
|
||||||
<!-- Strings related to Video meta data -->
|
<!-- Strings related to Video meta data -->
|
||||||
<string name="meta_data_seperator" translatable="false">\u0020-\u0020</string>
|
|
||||||
<string name="meta_data_views">" Görüntüleme"</string>
|
<string name="meta_data_views">" Görüntüleme"</string>
|
||||||
<string name="meta_data_owner_seperator" translatable="false">\@</string>
|
|
||||||
<string name="video_row_video_thumbnail">İzleti Küçük Resmi</string>
|
<string name="video_row_video_thumbnail">İzleti Küçük Resmi</string>
|
||||||
<string name="video_row_account_avatar">Hesap Resmi</string>
|
<string name="video_row_account_avatar">Hesap Resmi</string>
|
||||||
<string name="pref_title_show_nsfw">Ahlaksız İçerik</string>
|
<string name="pref_title_show_nsfw">Ahlaksız İçerik</string>
|
||||||
@ -48,7 +43,6 @@
|
|||||||
<string name="no_data_available">Sonuç yok</string>
|
<string name="no_data_available">Sonuç yok</string>
|
||||||
<string name="descr_overflow_button">Daha</string>
|
<string name="descr_overflow_button">Daha</string>
|
||||||
<string name="menu_share">Paylaş</string>
|
<string name="menu_share">Paylaş</string>
|
||||||
<string name="playback_channel_name" translatable="false">PeerTube</string>
|
|
||||||
<string name="invalid_url">Geçersiz bağlantı.</string>
|
<string name="invalid_url">Geçersiz bağlantı.</string>
|
||||||
<string name="pref_title_dark_mode">Karanlık Kipi</string>
|
<string name="pref_title_dark_mode">Karanlık Kipi</string>
|
||||||
<string name="pref_description_dark_mode">Karanlık kipin etkinleşmesi için uygulamayı yeniden başlatın.</string>
|
<string name="pref_description_dark_mode">Karanlık kipin etkinleşmesi için uygulamayı yeniden başlatın.</string>
|
||||||
@ -281,7 +275,7 @@
|
|||||||
<string name="video_share_icon" translatable="false">{faw-share}</string>
|
<string name="video_share_icon" translatable="false">{faw-share}</string>
|
||||||
<string name="video_download_icon" translatable="false">{faw-download}</string>
|
<string name="video_download_icon" translatable="false">{faw-download}</string>
|
||||||
<string name="video_save_icon" translatable="false">{faw-save}</string>
|
<string name="video_save_icon" translatable="false">{faw-save}</string>
|
||||||
<string name="pref_title_background_play">Arkaplanda Oynatma</string>
|
<string name="pref_title_background_play">Arka Planda Oynatma</string>
|
||||||
<string name="pref_description_background_play">Etkinleştirilirse, arka planda izleti oynatmaya devam eder.</string>
|
<string name="pref_description_background_play">Etkinleştirilirse, arka planda izleti oynatmaya devam eder.</string>
|
||||||
<string name="bottom_nav_title_local">Yerel</string>
|
<string name="bottom_nav_title_local">Yerel</string>
|
||||||
<string name="title_activity_account">Hesap</string>
|
<string name="title_activity_account">Hesap</string>
|
||||||
@ -300,15 +294,6 @@
|
|||||||
<string name="menu_video_options_playback_speed">Oynatma hızı</string>
|
<string name="menu_video_options_playback_speed">Oynatma hızı</string>
|
||||||
<string name="menu_video_options_quality">Kalite</string>
|
<string name="menu_video_options_quality">Kalite</string>
|
||||||
<!-- Constants, Don't translate -->
|
<!-- Constants, Don't translate -->
|
||||||
<string name="pref_token_access" translatable="false">pref_token_access</string>
|
|
||||||
<string name="pref_token_refresh" translatable="false">pref_token_refresh</string>
|
|
||||||
<string name="pref_token_expiration" translatable="false">pref_token_expiration</string>
|
|
||||||
<string name="pref_token_type" translatable="false">pref_token_type</string>
|
|
||||||
<string name="pref_auth_username" translatable="false">pref_auth_username</string>
|
|
||||||
<string name="pref_auth_password" translatable="false">pref_auth_password</string>
|
|
||||||
<string name="video_rating_none" translatable="false">none</string>
|
|
||||||
<string name="video_rating_like" translatable="false">like</string>
|
|
||||||
<string name="video_rating_dislike" translatable="false">dislike</string>
|
|
||||||
<string name="action_bar_title_account">Hesap</string>
|
<string name="action_bar_title_account">Hesap</string>
|
||||||
<string name="bottom_nav_title_recent">Yeniler</string>
|
<string name="bottom_nav_title_recent">Yeniler</string>
|
||||||
<string name="account_bottom_menu_videos">İzletiler</string>
|
<string name="account_bottom_menu_videos">İzletiler</string>
|
||||||
@ -351,4 +336,21 @@
|
|||||||
<string name="clear_search_history">Arama Geçmişini Temizle</string>
|
<string name="clear_search_history">Arama Geçmişini Temizle</string>
|
||||||
<string name="pref_description_language_app">Uygulama arayüzü için dil seçin. Değişikliklerin etkili olması için uygulamayı yeniden başlatın.</string>
|
<string name="pref_description_language_app">Uygulama arayüzü için dil seçin. Değişikliklerin etkili olması için uygulamayı yeniden başlatın.</string>
|
||||||
<string name="pref_language_app">Uygulama Dili</string>
|
<string name="pref_language_app">Uygulama Dili</string>
|
||||||
|
<string name="settings_activity_look_and_feel_category_title">Görünüm</string>
|
||||||
|
<string name="settings_activity_about_category_title">Hakkında</string>
|
||||||
|
<string name="settings_activity_video_playback_category_title">Video Oynatma</string>
|
||||||
|
<string name="settings_activity_video_list_category_title">Video Listesi</string>
|
||||||
|
<string name="title_activity_settings2">SettingsActivity2</string>
|
||||||
|
<string name="title_activity_me">Hesap</string>
|
||||||
|
<string name="title_activity_select_server">Sunucu Seç</string>
|
||||||
|
<string name="server_book_del_alert_msg">Bu sunucuyu adres defterinden kaldırmak istediğinizden emin misiniz\?</string>
|
||||||
|
<string name="server_book_del_alert_title">Sunucuyu Kaldır</string>
|
||||||
|
<string name="bn_rBD">Bengalce (Bangladeş)</string>
|
||||||
|
<string name="pref_background_behavior_summary">Arka plana giderken oynatılan bir videonun nasıl yanıt vereceği</string>
|
||||||
|
<string name="settings_permissions_error_float">Android Ayarlarında bu uygulama için resim içinde resim izni devre dışı</string>
|
||||||
|
<string name="settings_api_error_float">Android sürümü kayan videoyu desteklemiyor</string>
|
||||||
|
<string name="pref_background_float">Kayan pencerede video oynatmaya devam et</string>
|
||||||
|
<string name="pref_background_behavior">Arka planda oynatma yapılandırması</string>
|
||||||
|
<string name="pref_background_stop">Tüm oynatmaları durdur</string>
|
||||||
|
<string name="pref_background_audio">Arka planda ses akışı olarak devam et</string>
|
||||||
</resources>
|
</resources>
|
@ -63,7 +63,6 @@
|
|||||||
<string name="pref_description_torrent_player">视频通过一个种子下载,此选项需要存储权限(实验阶段,不稳定!)</string>
|
<string name="pref_description_torrent_player">视频通过一个种子下载,此选项需要存储权限(实验阶段,不稳定!)</string>
|
||||||
<string name="action_bar_title_logout">退出</string>
|
<string name="action_bar_title_logout">退出</string>
|
||||||
<string name="zh">中文</string>
|
<string name="zh">中文</string>
|
||||||
<string name="title_activity_video_play">视频播放Activity</string>
|
|
||||||
<string name="error_field_required">本字段必填</string>
|
<string name="error_field_required">本字段必填</string>
|
||||||
<string name="action_bar_title_account">账户</string>
|
<string name="action_bar_title_account">账户</string>
|
||||||
<string name="bottom_nav_title_recent">最近</string>
|
<string name="bottom_nav_title_recent">最近</string>
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<resources>
|
<resources>
|
||||||
<string name="title_activity_video_play">影片播放活動</string>
|
|
||||||
<string name="title_activity_settings">設定</string>
|
<string name="title_activity_settings">設定</string>
|
||||||
<string name="title_activity_login">登入</string>
|
<string name="title_activity_login">登入</string>
|
||||||
<string name="prompt_server">伺服器</string>
|
<string name="prompt_server">伺服器</string>
|
||||||
@ -323,4 +322,21 @@
|
|||||||
<string name="pref_language_app">應用程式語言</string>
|
<string name="pref_language_app">應用程式語言</string>
|
||||||
<string name="pref_description_back_pause">當影片播放時按下後退鈕後暫停背景播放。</string>
|
<string name="pref_description_back_pause">當影片播放時按下後退鈕後暫停背景播放。</string>
|
||||||
<string name="pref_title_back_pause">在後退鈕上暫停</string>
|
<string name="pref_title_back_pause">在後退鈕上暫停</string>
|
||||||
|
<string name="settings_activity_look_and_feel_category_title">外觀與感覺</string>
|
||||||
|
<string name="settings_activity_about_category_title">關於</string>
|
||||||
|
<string name="settings_activity_video_playback_category_title">影片播放</string>
|
||||||
|
<string name="settings_activity_video_list_category_title">影片清單</string>
|
||||||
|
<string name="title_activity_settings2">SettingsActivity2</string>
|
||||||
|
<string name="title_activity_me">帳號</string>
|
||||||
|
<string name="title_activity_select_server">選取伺服器</string>
|
||||||
|
<string name="server_book_del_alert_msg">您確定您想要從地址簿中移除此伺服器嗎?</string>
|
||||||
|
<string name="server_book_del_alert_title">移除伺服器</string>
|
||||||
|
<string name="bn_rBD">孟加拉語(孟加拉)</string>
|
||||||
|
<string name="pref_background_behavior_summary">播放影片到背景時如何回應</string>
|
||||||
|
<string name="settings_permissions_error_float">在 Android 設定中已停用此應用程式的畫中畫權限</string>
|
||||||
|
<string name="settings_api_error_float">Android 版本不支援懸浮影片</string>
|
||||||
|
<string name="pref_background_behavior">背景播放設定</string>
|
||||||
|
<string name="pref_background_float">繼續以懸浮視窗播放影片</string>
|
||||||
|
<string name="pref_background_stop">停止所有播放</string>
|
||||||
|
<string name="pref_background_audio">以背景音訊串流繼續</string>
|
||||||
</resources>
|
</resources>
|
@ -372,6 +372,10 @@
|
|||||||
<string name="settings_activity_about_category_title">About</string>
|
<string name="settings_activity_about_category_title">About</string>
|
||||||
<string name="settings_activity_look_and_feel_category_title"><![CDATA[Look & Feel]]></string>
|
<string name="settings_activity_look_and_feel_category_title"><![CDATA[Look & Feel]]></string>
|
||||||
|
|
||||||
|
<string name="peertube_instance_search_default_description" translatable="false">PeerTube, a federated (ActivityPub) video streaming platform using P2P (BitTorrent) directly in the web browser with WebTorrent and Angular.</string>
|
||||||
|
<string name="server_selection_nsfw_instance">NSFW Instance</string>
|
||||||
|
<string name="server_selection_video_totals">Videos: %s, Local Videos: %s</string>
|
||||||
|
|
||||||
|
|
||||||
<!-- Constants, Don't translate -->
|
<!-- Constants, Don't translate -->
|
||||||
<string name="pref_token_access" translatable="false">pref_token_access</string>
|
<string name="pref_token_access" translatable="false">pref_token_access</string>
|
||||||
|
Loading…
Reference in New Issue
Block a user