mirror of https://github.com/M66B/FairEmail.git
Replace action mode by action bar
This commit is contained in:
parent
3020eb2ba9
commit
bcbcdf6e54
|
@ -36,7 +36,8 @@ import androidx.core.view.inputmethod.InputConnectionCompat;
|
||||||
import androidx.core.view.inputmethod.InputContentInfoCompat;
|
import androidx.core.view.inputmethod.InputContentInfoCompat;
|
||||||
|
|
||||||
public class EditTextCompose extends AppCompatEditText {
|
public class EditTextCompose extends AppCompatEditText {
|
||||||
private IInputContentListener listener = null;
|
private ISelection selectionListener = null;
|
||||||
|
private IInputContentListener inputContentListener = null;
|
||||||
|
|
||||||
public EditTextCompose(Context context) {
|
public EditTextCompose(Context context) {
|
||||||
super(context);
|
super(context);
|
||||||
|
@ -50,6 +51,13 @@ public class EditTextCompose extends AppCompatEditText {
|
||||||
super(context, attrs, defStyleAttr);
|
super(context, attrs, defStyleAttr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onSelectionChanged(int selStart, int selEnd) {
|
||||||
|
super.onSelectionChanged(selStart, selEnd);
|
||||||
|
if (selectionListener != null)
|
||||||
|
selectionListener.onSelected(hasSelection());
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onTextContextMenuItem(int id) {
|
public boolean onTextContextMenuItem(int id) {
|
||||||
try {
|
try {
|
||||||
|
@ -117,14 +125,14 @@ public class EditTextCompose extends AppCompatEditText {
|
||||||
public boolean onCommitContent(InputContentInfoCompat info, int flags, Bundle opts) {
|
public boolean onCommitContent(InputContentInfoCompat info, int flags, Bundle opts) {
|
||||||
Log.i("Uri=" + info.getContentUri());
|
Log.i("Uri=" + info.getContentUri());
|
||||||
try {
|
try {
|
||||||
if (listener == null)
|
if (inputContentListener == null)
|
||||||
throw new IllegalArgumentException("InputContent listener not set");
|
throw new IllegalArgumentException("InputContent listener not set");
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N_MR1 &&
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N_MR1 &&
|
||||||
(flags & InputConnectionCompat.INPUT_CONTENT_GRANT_READ_URI_PERMISSION) != 0)
|
(flags & InputConnectionCompat.INPUT_CONTENT_GRANT_READ_URI_PERMISSION) != 0)
|
||||||
info.requestPermission();
|
info.requestPermission();
|
||||||
|
|
||||||
listener.onInputContent(info.getContentUri());
|
inputContentListener.onInputContent(info.getContentUri());
|
||||||
return true;
|
return true;
|
||||||
} catch (Throwable ex) {
|
} catch (Throwable ex) {
|
||||||
Log.w(ex);
|
Log.w(ex);
|
||||||
|
@ -135,10 +143,18 @@ public class EditTextCompose extends AppCompatEditText {
|
||||||
}
|
}
|
||||||
|
|
||||||
void setInputContentListener(IInputContentListener listener) {
|
void setInputContentListener(IInputContentListener listener) {
|
||||||
this.listener = listener;
|
this.inputContentListener = listener;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface IInputContentListener {
|
interface IInputContentListener {
|
||||||
void onInputContent(Uri uri);
|
void onInputContent(Uri uri);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void setSelectionListener(ISelection listener) {
|
||||||
|
this.selectionListener = listener;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface ISelection {
|
||||||
|
void onSelected(boolean selection);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -74,7 +74,6 @@ import android.text.style.URLSpan;
|
||||||
import android.text.style.UnderlineSpan;
|
import android.text.style.UnderlineSpan;
|
||||||
import android.util.DisplayMetrics;
|
import android.util.DisplayMetrics;
|
||||||
import android.util.TypedValue;
|
import android.util.TypedValue;
|
||||||
import android.view.ActionMode;
|
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.Menu;
|
import android.view.Menu;
|
||||||
import android.view.MenuInflater;
|
import android.view.MenuInflater;
|
||||||
|
@ -183,6 +182,7 @@ public class FragmentCompose extends FragmentBase {
|
||||||
private ImageButton ibReferenceDelete;
|
private ImageButton ibReferenceDelete;
|
||||||
private ImageButton ibReferenceEdit;
|
private ImageButton ibReferenceEdit;
|
||||||
private ImageButton ibReferenceImages;
|
private ImageButton ibReferenceImages;
|
||||||
|
private BottomNavigationView style_bar;
|
||||||
private BottomNavigationView media_bar;
|
private BottomNavigationView media_bar;
|
||||||
private BottomNavigationView bottom_navigation;
|
private BottomNavigationView bottom_navigation;
|
||||||
private ContentLoadingProgressBar pbWait;
|
private ContentLoadingProgressBar pbWait;
|
||||||
|
@ -278,6 +278,7 @@ public class FragmentCompose extends FragmentBase {
|
||||||
ibReferenceDelete = view.findViewById(R.id.ibReferenceDelete);
|
ibReferenceDelete = view.findViewById(R.id.ibReferenceDelete);
|
||||||
ibReferenceEdit = view.findViewById(R.id.ibReferenceEdit);
|
ibReferenceEdit = view.findViewById(R.id.ibReferenceEdit);
|
||||||
ibReferenceImages = view.findViewById(R.id.ibReferenceImages);
|
ibReferenceImages = view.findViewById(R.id.ibReferenceImages);
|
||||||
|
style_bar = view.findViewById(R.id.style_bar);
|
||||||
media_bar = view.findViewById(R.id.media_bar);
|
media_bar = view.findViewById(R.id.media_bar);
|
||||||
bottom_navigation = view.findViewById(R.id.bottom_navigation);
|
bottom_navigation = view.findViewById(R.id.bottom_navigation);
|
||||||
|
|
||||||
|
@ -346,8 +347,6 @@ public class FragmentCompose extends FragmentBase {
|
||||||
|
|
||||||
setZoom();
|
setZoom();
|
||||||
|
|
||||||
etBody.setCustomSelectionActionModeCallback(actionCallback);
|
|
||||||
|
|
||||||
etBody.setInputContentListener(new EditTextCompose.IInputContentListener() {
|
etBody.setInputContentListener(new EditTextCompose.IInputContentListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onInputContent(Uri uri) {
|
public void onInputContent(Uri uri) {
|
||||||
|
@ -355,6 +354,13 @@ public class FragmentCompose extends FragmentBase {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
etBody.setSelectionListener(new EditTextCompose.ISelection() {
|
||||||
|
@Override
|
||||||
|
public void onSelected(boolean selection) {
|
||||||
|
style_bar.setVisibility(selection ? View.VISIBLE : View.GONE);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
cbSignature.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
|
cbSignature.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onCheckedChanged(CompoundButton compoundButton, boolean checked) {
|
public void onCheckedChanged(CompoundButton compoundButton, boolean checked) {
|
||||||
|
@ -422,6 +428,13 @@ public class FragmentCompose extends FragmentBase {
|
||||||
etBody.setTypeface(monospaced ? Typeface.MONOSPACE : Typeface.DEFAULT);
|
etBody.setTypeface(monospaced ? Typeface.MONOSPACE : Typeface.DEFAULT);
|
||||||
tvReference.setTypeface(monospaced ? Typeface.MONOSPACE : Typeface.DEFAULT);
|
tvReference.setTypeface(monospaced ? Typeface.MONOSPACE : Typeface.DEFAULT);
|
||||||
|
|
||||||
|
style_bar.setOnNavigationItemSelectedListener(new BottomNavigationView.OnNavigationItemSelectedListener() {
|
||||||
|
@Override
|
||||||
|
public boolean onNavigationItemSelected(@NonNull MenuItem item) {
|
||||||
|
return onActionStyle(item.getItemId());
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
PackageManager pm = getContext().getPackageManager();
|
PackageManager pm = getContext().getPackageManager();
|
||||||
Intent take_photo = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
|
Intent take_photo = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
|
||||||
Intent record_audio = new Intent(MediaStore.Audio.Media.RECORD_SOUND_ACTION);
|
Intent record_audio = new Intent(MediaStore.Audio.Media.RECORD_SOUND_ACTION);
|
||||||
|
@ -497,6 +510,7 @@ public class FragmentCompose extends FragmentBase {
|
||||||
ibReferenceEdit.setVisibility(View.GONE);
|
ibReferenceEdit.setVisibility(View.GONE);
|
||||||
ibReferenceImages.setVisibility(View.GONE);
|
ibReferenceImages.setVisibility(View.GONE);
|
||||||
tvReference.setVisibility(View.GONE);
|
tvReference.setVisibility(View.GONE);
|
||||||
|
style_bar.setVisibility(View.GONE);
|
||||||
media_bar.setVisibility(View.GONE);
|
media_bar.setVisibility(View.GONE);
|
||||||
bottom_navigation.setVisibility(View.GONE);
|
bottom_navigation.setVisibility(View.GONE);
|
||||||
pbWait.setVisibility(View.VISIBLE);
|
pbWait.setVisibility(View.VISIBLE);
|
||||||
|
@ -1048,6 +1062,106 @@ public class FragmentCompose extends FragmentBase {
|
||||||
fragment.show(getFragmentManager(), "compose:answer");
|
fragment.show(getFragmentManager(), "compose:answer");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean onActionStyle(int action) {
|
||||||
|
Log.i("Style action=" + action);
|
||||||
|
|
||||||
|
int start = etBody.getSelectionStart();
|
||||||
|
int end = etBody.getSelectionEnd();
|
||||||
|
|
||||||
|
if (start < 0)
|
||||||
|
start = 0;
|
||||||
|
if (end < 0)
|
||||||
|
end = 0;
|
||||||
|
|
||||||
|
if (start > end) {
|
||||||
|
int tmp = start;
|
||||||
|
start = end;
|
||||||
|
end = tmp;
|
||||||
|
}
|
||||||
|
|
||||||
|
SpannableString ss = new SpannableString(etBody.getText());
|
||||||
|
|
||||||
|
switch (action) {
|
||||||
|
case R.id.menu_bold:
|
||||||
|
case R.id.menu_italic: {
|
||||||
|
int style = (action == R.id.menu_bold ? Typeface.BOLD : Typeface.ITALIC);
|
||||||
|
boolean has = false;
|
||||||
|
for (StyleSpan span : ss.getSpans(start, end, StyleSpan.class))
|
||||||
|
if (span.getStyle() == style) {
|
||||||
|
has = true;
|
||||||
|
ss.removeSpan(span);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!has)
|
||||||
|
ss.setSpan(new StyleSpan(style), start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
|
||||||
|
|
||||||
|
etBody.setText(ss);
|
||||||
|
etBody.setSelection(start, end);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
case R.id.menu_underline: {
|
||||||
|
boolean has = false;
|
||||||
|
for (UnderlineSpan span : ss.getSpans(start, end, UnderlineSpan.class)) {
|
||||||
|
has = true;
|
||||||
|
ss.removeSpan(span);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!has)
|
||||||
|
ss.setSpan(new UnderlineSpan(), start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
|
||||||
|
|
||||||
|
etBody.setText(ss);
|
||||||
|
etBody.setSelection(start, end);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
case R.id.menu_size: {
|
||||||
|
RelativeSizeSpan[] spans = ss.getSpans(start, end, RelativeSizeSpan.class);
|
||||||
|
float size = (spans.length > 0 ? spans[0].getSizeChange() : 1.0f);
|
||||||
|
|
||||||
|
// Match small/big
|
||||||
|
if (size == 0.8f)
|
||||||
|
size = 1.0f;
|
||||||
|
else if (size == 1.0)
|
||||||
|
size = 1.25f;
|
||||||
|
else
|
||||||
|
size = 0.8f;
|
||||||
|
|
||||||
|
for (RelativeSizeSpan span : spans)
|
||||||
|
ss.removeSpan(span);
|
||||||
|
|
||||||
|
if (size != 1.0f)
|
||||||
|
ss.setSpan(new RelativeSizeSpan(size), start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
|
||||||
|
|
||||||
|
etBody.setText(ss);
|
||||||
|
etBody.setSelection(start, end);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
case R.id.menu_color: {
|
||||||
|
Bundle args = new Bundle();
|
||||||
|
args.putInt("start", start);
|
||||||
|
args.putInt("end", end);
|
||||||
|
|
||||||
|
ForegroundColorSpan[] spans = ss.getSpans(start, end, ForegroundColorSpan.class);
|
||||||
|
int color = (spans.length > 0 ? spans[0].getForegroundColor() : Color.TRANSPARENT);
|
||||||
|
|
||||||
|
FragmentDialogColor fragment = new FragmentDialogColor();
|
||||||
|
fragment.initialize(R.string.title_style_color, color, args, getContext());
|
||||||
|
fragment.setTargetFragment(FragmentCompose.this, REQUEST_COLOR);
|
||||||
|
fragment.show(getFragmentManager(), "account:color");
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void onActionRecordAudio() {
|
private void onActionRecordAudio() {
|
||||||
Intent intent = new Intent(MediaStore.Audio.Media.RECORD_SOUND_ACTION);
|
Intent intent = new Intent(MediaStore.Audio.Media.RECORD_SOUND_ACTION);
|
||||||
startActivityForResult(intent, REQUEST_RECORD_AUDIO);
|
startActivityForResult(intent, REQUEST_RECORD_AUDIO);
|
||||||
|
@ -1607,8 +1721,9 @@ public class FragmentCompose extends FragmentBase {
|
||||||
for (ForegroundColorSpan span : ss.getSpans(start, end, ForegroundColorSpan.class))
|
for (ForegroundColorSpan span : ss.getSpans(start, end, ForegroundColorSpan.class))
|
||||||
ss.removeSpan(span);
|
ss.removeSpan(span);
|
||||||
ss.setSpan(new ForegroundColorSpan(color), start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
|
ss.setSpan(new ForegroundColorSpan(color), start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
|
||||||
|
|
||||||
etBody.setText(ss);
|
etBody.setText(ss);
|
||||||
etBody.setSelection(end, end);
|
etBody.setSelection(start, end);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onContactGroupSelected(Bundle args) {
|
private void onContactGroupSelected(Bundle args) {
|
||||||
|
@ -3349,129 +3464,6 @@ public class FragmentCompose extends FragmentBase {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
private ActionMode.Callback actionCallback = new ActionMode.Callback() {
|
|
||||||
@Override
|
|
||||||
public boolean onCreateActionMode(ActionMode mode, Menu menu) {
|
|
||||||
menu.add(1, R.string.title_style_bold, 1, R.string.title_style_bold).setIcon(R.drawable.baseline_format_bold_24);
|
|
||||||
menu.add(1, R.string.title_style_italic, 2, R.string.title_style_italic).setIcon(R.drawable.baseline_format_italic_24);
|
|
||||||
menu.add(1, R.string.title_style_underline, 3, R.string.title_style_underline).setIcon(R.drawable.baseline_format_underlined_24);
|
|
||||||
menu.add(1, R.string.title_style_size, 4, R.string.title_style_size).setIcon(R.drawable.baseline_format_size_24);
|
|
||||||
menu.add(1, R.string.title_style_color, 5, R.string.title_style_color).setIcon(R.drawable.baseline_format_color_text_24);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onPrepareActionMode(ActionMode mode, Menu menu) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onActionItemClicked(ActionMode mode, MenuItem item) {
|
|
||||||
Log.i("Action=" + item.getGroupId() + ":" + item.getItemId());
|
|
||||||
|
|
||||||
if (item.getGroupId() != 1)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
int start = etBody.getSelectionStart();
|
|
||||||
int end = etBody.getSelectionEnd();
|
|
||||||
|
|
||||||
if (start < 0)
|
|
||||||
start = 0;
|
|
||||||
if (end < 0)
|
|
||||||
end = 0;
|
|
||||||
|
|
||||||
if (start > end) {
|
|
||||||
int tmp = start;
|
|
||||||
start = end;
|
|
||||||
end = tmp;
|
|
||||||
}
|
|
||||||
|
|
||||||
SpannableString ss = new SpannableString(etBody.getText());
|
|
||||||
|
|
||||||
switch (item.getItemId()) {
|
|
||||||
case R.string.title_style_bold:
|
|
||||||
case R.string.title_style_italic: {
|
|
||||||
int style = (item.getItemId() == R.string.title_style_bold ? Typeface.BOLD : Typeface.ITALIC);
|
|
||||||
boolean has = false;
|
|
||||||
for (StyleSpan span : ss.getSpans(start, end, StyleSpan.class))
|
|
||||||
if (span.getStyle() == style) {
|
|
||||||
has = true;
|
|
||||||
ss.removeSpan(span);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!has)
|
|
||||||
ss.setSpan(new StyleSpan(style), start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
|
|
||||||
|
|
||||||
etBody.setText(ss);
|
|
||||||
etBody.setSelection(end, end);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
case R.string.title_style_underline: {
|
|
||||||
boolean has = false;
|
|
||||||
for (UnderlineSpan span : ss.getSpans(start, end, UnderlineSpan.class)) {
|
|
||||||
has = true;
|
|
||||||
ss.removeSpan(span);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!has)
|
|
||||||
ss.setSpan(new UnderlineSpan(), start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
|
|
||||||
|
|
||||||
etBody.setText(ss);
|
|
||||||
etBody.setSelection(end, end);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
case R.string.title_style_size: {
|
|
||||||
RelativeSizeSpan[] spans = ss.getSpans(start, end, RelativeSizeSpan.class);
|
|
||||||
float size = (spans.length > 0 ? spans[0].getSizeChange() : 1.0f);
|
|
||||||
|
|
||||||
// Match small/big
|
|
||||||
if (size == 0.8f)
|
|
||||||
size = 1.0f;
|
|
||||||
else if (size == 1.0)
|
|
||||||
size = 1.25f;
|
|
||||||
else
|
|
||||||
size = 0.8f;
|
|
||||||
|
|
||||||
for (RelativeSizeSpan span : spans)
|
|
||||||
ss.removeSpan(span);
|
|
||||||
|
|
||||||
if (size != 1.0f)
|
|
||||||
ss.setSpan(new RelativeSizeSpan(size), start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
|
|
||||||
|
|
||||||
etBody.setText(ss);
|
|
||||||
etBody.setSelection(end, end);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
case R.string.title_style_color: {
|
|
||||||
Bundle args = new Bundle();
|
|
||||||
args.putInt("start", start);
|
|
||||||
args.putInt("end", end);
|
|
||||||
|
|
||||||
ForegroundColorSpan[] spans = ss.getSpans(start, end, ForegroundColorSpan.class);
|
|
||||||
int color = (spans.length > 0 ? spans[0].getForegroundColor() : Color.TRANSPARENT);
|
|
||||||
|
|
||||||
FragmentDialogColor fragment = new FragmentDialogColor();
|
|
||||||
fragment.initialize(R.string.title_style_color, color, args, getContext());
|
|
||||||
fragment.setTargetFragment(FragmentCompose.this, REQUEST_COLOR);
|
|
||||||
fragment.show(getFragmentManager(), "account:color");
|
|
||||||
|
|
||||||
etBody.setSelection(end, end);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
default:
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onDestroyActionMode(ActionMode mode) {
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private ViewTreeObserver.OnGlobalLayoutListener layoutListener = new ViewTreeObserver.OnGlobalLayoutListener() {
|
private ViewTreeObserver.OnGlobalLayoutListener layoutListener = new ViewTreeObserver.OnGlobalLayoutListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onGlobalLayout() {
|
public void onGlobalLayout() {
|
||||||
|
|
|
@ -14,7 +14,7 @@
|
||||||
<ScrollView
|
<ScrollView
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="0dp"
|
android:layout_height="0dp"
|
||||||
app:layout_constraintBottom_toTopOf="@+id/media_bar"
|
app:layout_constraintBottom_toTopOf="@+id/style_bar"
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
app:layout_constraintTop_toTopOf="parent">
|
app:layout_constraintTop_toTopOf="parent">
|
||||||
|
|
||||||
|
@ -417,6 +417,19 @@
|
||||||
</androidx.constraintlayout.widget.ConstraintLayout>
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
||||||
</ScrollView>
|
</ScrollView>
|
||||||
|
|
||||||
|
<com.google.android.material.bottomnavigation.BottomNavigationView
|
||||||
|
android:id="@+id/style_bar"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="36dp"
|
||||||
|
android:background="?attr/colorActionBackground"
|
||||||
|
app:itemIconTint="@color/action_foreground"
|
||||||
|
app:itemTextColor="@color/action_foreground"
|
||||||
|
app:labelVisibilityMode="unlabeled"
|
||||||
|
app:layout_constraintBottom_toTopOf="@+id/media_bar"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:menu="@menu/action_compose_style" />
|
||||||
|
|
||||||
<com.google.android.material.bottomnavigation.BottomNavigationView
|
<com.google.android.material.bottomnavigation.BottomNavigationView
|
||||||
android:id="@+id/media_bar"
|
android:id="@+id/media_bar"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
|
@ -428,7 +441,7 @@
|
||||||
app:layout_constraintBottom_toTopOf="@+id/bottom_navigation"
|
app:layout_constraintBottom_toTopOf="@+id/bottom_navigation"
|
||||||
app:layout_constraintEnd_toEndOf="parent"
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
app:menu="@menu/action_media" />
|
app:menu="@menu/action_compose_media" />
|
||||||
|
|
||||||
<com.google.android.material.bottomnavigation.BottomNavigationView
|
<com.google.android.material.bottomnavigation.BottomNavigationView
|
||||||
android:id="@+id/bottom_navigation"
|
android:id="@+id/bottom_navigation"
|
||||||
|
|
|
@ -0,0 +1,27 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<menu xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
<item
|
||||||
|
android:id="@+id/menu_bold"
|
||||||
|
android:icon="@drawable/baseline_format_bold_24"
|
||||||
|
android:title="@string/title_style_bold" />
|
||||||
|
|
||||||
|
<item
|
||||||
|
android:id="@+id/menu_italic"
|
||||||
|
android:icon="@drawable/baseline_format_italic_24"
|
||||||
|
android:title="@string/title_style_italic" />
|
||||||
|
|
||||||
|
<item
|
||||||
|
android:id="@+id/menu_underline"
|
||||||
|
android:icon="@drawable/baseline_format_underlined_24"
|
||||||
|
android:title="@string/title_style_underline" />
|
||||||
|
|
||||||
|
<item
|
||||||
|
android:id="@+id/menu_size"
|
||||||
|
android:icon="@drawable/baseline_format_size_24"
|
||||||
|
android:title="@string/title_style_size" />
|
||||||
|
|
||||||
|
<item
|
||||||
|
android:id="@+id/menu_color"
|
||||||
|
android:icon="@drawable/baseline_format_color_text_24"
|
||||||
|
android:title="@string/title_style_color" />
|
||||||
|
</menu>
|
Loading…
Reference in New Issue