forked from mirrors/Fedilab
comment #702 - Add post local only (Glitch)
This commit is contained in:
parent
64e50bd8b5
commit
508f3c6253
8 changed files with 73 additions and 1 deletions
|
@ -102,6 +102,8 @@ public class Status implements Serializable, Cloneable {
|
||||||
public List<Filter.FilterResult> filtered;
|
public List<Filter.FilterResult> filtered;
|
||||||
@SerializedName("pleroma")
|
@SerializedName("pleroma")
|
||||||
public Pleroma pleroma;
|
public Pleroma pleroma;
|
||||||
|
@SerializedName("local_only")
|
||||||
|
public boolean local_only = false;
|
||||||
@SerializedName("cached")
|
@SerializedName("cached")
|
||||||
public boolean cached = false;
|
public boolean cached = false;
|
||||||
public Attachment art_attachment;
|
public Attachment art_attachment;
|
||||||
|
|
|
@ -218,6 +218,9 @@ public class ComposeWorker extends Worker {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
String language = sharedPreferences.getString(context.getString(R.string.SET_COMPOSE_LANGUAGE) + dataPost.userId + dataPost.instance, null);
|
String language = sharedPreferences.getString(context.getString(R.string.SET_COMPOSE_LANGUAGE) + dataPost.userId + dataPost.instance, null);
|
||||||
|
if (statuses.get(i).local_only) {
|
||||||
|
statuses.get(i).text += " \uD83D\uDC41";
|
||||||
|
}
|
||||||
if (dataPost.scheduledDate == null) {
|
if (dataPost.scheduledDate == null) {
|
||||||
if (dataPost.statusEditId == null) {
|
if (dataPost.statusEditId == null) {
|
||||||
statusCall = mastodonStatusesService.createStatus(null, dataPost.token, statuses.get(i).text, attachmentIds, poll_options, poll_expire_in,
|
statusCall = mastodonStatusesService.createStatus(null, dataPost.token, statuses.get(i).text, attachmentIds, poll_options, poll_expire_in,
|
||||||
|
|
|
@ -1279,6 +1279,7 @@ public class ComposeAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder
|
||||||
holder.binding.buttonEmojiOne.setVisibility(View.VISIBLE);
|
holder.binding.buttonEmojiOne.setVisibility(View.VISIBLE);
|
||||||
if (extraFeatures) {
|
if (extraFeatures) {
|
||||||
holder.binding.buttonTextFormat.setVisibility(View.VISIBLE);
|
holder.binding.buttonTextFormat.setVisibility(View.VISIBLE);
|
||||||
|
holder.binding.buttonLocalOnly.setVisibility(View.VISIBLE);
|
||||||
holder.binding.buttonTextFormat.setOnClickListener(v -> {
|
holder.binding.buttonTextFormat.setOnClickListener(v -> {
|
||||||
AlertDialog.Builder builder = new AlertDialog.Builder(context, Helper.dialogStyle());
|
AlertDialog.Builder builder = new AlertDialog.Builder(context, Helper.dialogStyle());
|
||||||
builder.setTitle(context.getString(R.string.post_format));
|
builder.setTitle(context.getString(R.string.post_format));
|
||||||
|
@ -1304,6 +1305,28 @@ public class ComposeAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder
|
||||||
builder.setNegativeButton(R.string.cancel, (dialog, which) -> dialog.dismiss());
|
builder.setNegativeButton(R.string.cancel, (dialog, which) -> dialog.dismiss());
|
||||||
builder.create().show();
|
builder.create().show();
|
||||||
});
|
});
|
||||||
|
holder.binding.buttonLocalOnly.setOnClickListener(v -> {
|
||||||
|
AlertDialog.Builder builder = new AlertDialog.Builder(context, Helper.dialogStyle());
|
||||||
|
builder.setTitle(context.getString(R.string.local_only));
|
||||||
|
Resources res = context.getResources();
|
||||||
|
boolean[] valArr = new boolean[]{false, true};
|
||||||
|
String[] labelArr = res.getStringArray(R.array.set_local_only);
|
||||||
|
|
||||||
|
int selection = 0;
|
||||||
|
boolean localOnly = sharedpreferences.getBoolean(context.getString(R.string.SET_LOCAL_ONLY) + account.user_id + account.instance, false);
|
||||||
|
if (statusDraft.local_only || localOnly) {
|
||||||
|
selection = 1;
|
||||||
|
}
|
||||||
|
builder.setSingleChoiceItems(labelArr, selection, null);
|
||||||
|
builder.setPositiveButton(R.string.validate, (dialog, which) -> {
|
||||||
|
int selectedPosition = ((AlertDialog) dialog).getListView().getCheckedItemPosition();
|
||||||
|
statusDraft.local_only = valArr[selectedPosition];
|
||||||
|
notifyItemChanged(holder.getLayoutPosition());
|
||||||
|
dialog.dismiss();
|
||||||
|
});
|
||||||
|
builder.setNegativeButton(R.string.cancel, (dialog, which) -> dialog.dismiss());
|
||||||
|
builder.create().show();
|
||||||
|
});
|
||||||
} else {
|
} else {
|
||||||
holder.binding.buttonTextFormat.setVisibility(View.GONE);
|
holder.binding.buttonTextFormat.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1053,6 +1053,13 @@ public class StatusAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder>
|
||||||
ressource = R.drawable.ic_baseline_mail_24;
|
ressource = R.drawable.ic_baseline_mail_24;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (statusToDeal.local_only) {
|
||||||
|
holder.binding.localOnly.setVisibility(View.VISIBLE);
|
||||||
|
} else {
|
||||||
|
holder.binding.localOnly.setVisibility(View.GONE);
|
||||||
|
}
|
||||||
|
|
||||||
if (status.isFocused) {
|
if (status.isFocused) {
|
||||||
holder.binding.statusInfo.setVisibility(View.VISIBLE);
|
holder.binding.statusInfo.setVisibility(View.VISIBLE);
|
||||||
holder.binding.reblogsCount.setText(String.valueOf(status.reblogs_count));
|
holder.binding.reblogsCount.setText(String.valueOf(status.reblogs_count));
|
||||||
|
|
10
app/src/main/res/drawable/ic_baseline_local_only_24.xml
Normal file
10
app/src/main/res/drawable/ic_baseline_local_only_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:tint="?attr/colorControlNormal"
|
||||||
|
android:viewportWidth="24"
|
||||||
|
android:viewportHeight="24">
|
||||||
|
<path
|
||||||
|
android:fillColor="@android:color/white"
|
||||||
|
android:pathData="M10,20v-6h4v6h5v-8h3L12,3 2,12h3v8z" />
|
||||||
|
</vector>
|
|
@ -159,6 +159,14 @@
|
||||||
android:singleLine="true"
|
android:singleLine="true"
|
||||||
tools:text="@tools:sample/full_names" />
|
tools:text="@tools:sample/full_names" />
|
||||||
|
|
||||||
|
<androidx.appcompat.widget.AppCompatImageView
|
||||||
|
android:id="@+id/local_only"
|
||||||
|
android:layout_width="20dp"
|
||||||
|
android:layout_height="20dp"
|
||||||
|
android:layout_marginEnd="5dp"
|
||||||
|
android:contentDescription="@string/local_only"
|
||||||
|
android:src="@drawable/ic_baseline_local_only_24" />
|
||||||
|
|
||||||
<androidx.appcompat.widget.AppCompatImageView
|
<androidx.appcompat.widget.AppCompatImageView
|
||||||
android:id="@+id/visibility_small"
|
android:id="@+id/visibility_small"
|
||||||
android:layout_width="20dp"
|
android:layout_width="20dp"
|
||||||
|
|
|
@ -65,7 +65,7 @@
|
||||||
android:focusable="true"
|
android:focusable="true"
|
||||||
android:gravity="top|start"
|
android:gravity="top|start"
|
||||||
android:inputType="textMultiLine|textCapSentences"
|
android:inputType="textMultiLine|textCapSentences"
|
||||||
android:minLines="6"
|
android:minLines="8"
|
||||||
app:layout_constraintEnd_toStartOf="@id/button_emoji"
|
app:layout_constraintEnd_toStartOf="@id/button_emoji"
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
app:layout_constraintTop_toBottomOf="@id/content_spoiler" />
|
app:layout_constraintTop_toBottomOf="@id/content_spoiler" />
|
||||||
|
@ -103,6 +103,17 @@
|
||||||
app:layout_constraintTop_toBottomOf="@id/button_emoji_one"
|
app:layout_constraintTop_toBottomOf="@id/button_emoji_one"
|
||||||
tools:visibility="visible" />
|
tools:visibility="visible" />
|
||||||
|
|
||||||
|
<com.google.android.material.button.MaterialButton
|
||||||
|
android:id="@+id/button_local_only"
|
||||||
|
style="@style/Fedilab.SmallIconButton"
|
||||||
|
android:layout_marginEnd="6dp"
|
||||||
|
android:contentDescription="@string/local_only"
|
||||||
|
android:visibility="gone"
|
||||||
|
app:icon="@drawable/ic_baseline_remove_red_eye_24"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintTop_toBottomOf="@id/button_text_format"
|
||||||
|
tools:visibility="visible" />
|
||||||
|
|
||||||
<com.google.android.material.checkbox.MaterialCheckBox
|
<com.google.android.material.checkbox.MaterialCheckBox
|
||||||
android:id="@+id/sensitive_media"
|
android:id="@+id/sensitive_media"
|
||||||
android:layout_width="0dp"
|
android:layout_width="0dp"
|
||||||
|
|
|
@ -770,6 +770,12 @@
|
||||||
<item>text/x.misskeymarkdown</item>
|
<item>text/x.misskeymarkdown</item>
|
||||||
</string-array>
|
</string-array>
|
||||||
|
|
||||||
|
|
||||||
|
<string-array name="set_local_only">
|
||||||
|
<item>No</item>
|
||||||
|
<item>Yes</item>
|
||||||
|
</string-array>
|
||||||
|
|
||||||
<string-array name="set_load_media_type_value">
|
<string-array name="set_load_media_type_value">
|
||||||
<item>Always</item>
|
<item>Always</item>
|
||||||
<item>Wifi only</item>
|
<item>Wifi only</item>
|
||||||
|
@ -1435,6 +1441,7 @@
|
||||||
|
|
||||||
<string name="SET_DISPLAY_TRANSLATE" translatable="false">SET_DISPLAY_TRANSLATE</string>
|
<string name="SET_DISPLAY_TRANSLATE" translatable="false">SET_DISPLAY_TRANSLATE</string>
|
||||||
<string name="SET_POST_FORMAT" translatable="false">SET_POST_FORMAT</string>
|
<string name="SET_POST_FORMAT" translatable="false">SET_POST_FORMAT</string>
|
||||||
|
<string name="SET_LOCAL_ONLY" translatable="false">SET_LOCAL_ONLY</string>
|
||||||
|
|
||||||
<string name="SET_TRANSLATOR" translatable="false">SET_TRANSLATOR</string>
|
<string name="SET_TRANSLATOR" translatable="false">SET_TRANSLATOR</string>
|
||||||
<string name="SET_TRANSLATOR_VERSION" translatable="false">SET_TRANSLATOR_VERSION</string>
|
<string name="SET_TRANSLATOR_VERSION" translatable="false">SET_TRANSLATOR_VERSION</string>
|
||||||
|
@ -2186,4 +2193,5 @@
|
||||||
<string name="self">Self</string>
|
<string name="self">Self</string>
|
||||||
<string name="set_remote_profile_title">Remote profiles</string>
|
<string name="set_remote_profile_title">Remote profiles</string>
|
||||||
<string name="set_remote_profile">The app will display publicly profiles to get all messages. Interactions will need an extra step to federate messages.</string>
|
<string name="set_remote_profile">The app will display publicly profiles to get all messages. Interactions will need an extra step to federate messages.</string>
|
||||||
|
<string name="local_only">Local only</string>
|
||||||
</resources>
|
</resources>
|
Loading…
Reference in a new issue