diff --git a/app/src/main/java/eu/faircode/email/ActivityBase.java b/app/src/main/java/eu/faircode/email/ActivityBase.java
index d40e54a58d..dc918a7618 100644
--- a/app/src/main/java/eu/faircode/email/ActivityBase.java
+++ b/app/src/main/java/eu/faircode/email/ActivityBase.java
@@ -73,6 +73,8 @@ import androidx.lifecycle.LifecycleOwner;
import androidx.lifecycle.OnLifecycleEvent;
import androidx.preference.PreferenceManager;
+import com.google.android.material.appbar.AppBarLayout;
+
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
@@ -106,19 +108,31 @@ abstract class ActivityBase extends AppCompatActivity implements SharedPreferenc
public void setContentView(View view) {
LayoutInflater inflater = LayoutInflater.from(this);
- ViewGroup container = (ViewGroup) inflater.inflate(R.layout.toolbar_holder, null);
- View placeholder = container.findViewById(R.id.placeholder);
- container.removeView(placeholder);
- container.addView(view, placeholder.getLayoutParams());
+ ViewGroup holder = (ViewGroup) inflater.inflate(R.layout.toolbar_holder, null);
+
+ AppBarLayout appbar = holder.findViewById(R.id.appbar);
+ Toolbar toolbar = holder.findViewById(R.id.toolbar);
+ View placeholder = holder.findViewById(R.id.placeholder);
- Toolbar toolbar = container.findViewById(R.id.toolbar);
toolbar.setPopupTheme(getThemeId());
-
setSupportActionBar(toolbar);
- FragmentDialogTheme.setBackground(this, container, this instanceof ActivityCompose);
+ holder.removeView(placeholder);
+ holder.addView(view, placeholder.getLayoutParams());
- ViewCompat.setOnApplyWindowInsetsListener(container, (v, windowInsets) -> {
+ int abh = Helper.getActionBarHeight(this);
+ appbar.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {
+ @Override
+ public void onOffsetChanged(AppBarLayout appBarLayout, int i) {
+ ViewGroup.MarginLayoutParams mlp = (ViewGroup.MarginLayoutParams) view.getLayoutParams();
+ mlp.topMargin = abh + i;
+ view.setLayoutParams(mlp);
+ }
+ });
+
+ FragmentDialogTheme.setBackground(this, holder, this instanceof ActivityCompose);
+
+ ViewCompat.setOnApplyWindowInsetsListener(holder, (v, windowInsets) -> {
Insets insets = windowInsets.getInsets(WindowInsetsCompat.Type.systemBars());
ViewGroup.MarginLayoutParams mlp = (ViewGroup.MarginLayoutParams) v.getLayoutParams();
@@ -133,7 +147,7 @@ abstract class ActivityBase extends AppCompatActivity implements SharedPreferenc
if (this instanceof ActivityCompose)
ViewCompat.setWindowInsetsAnimationCallback(
- container,
+ holder,
new WindowInsetsAnimationCompat.Callback(WindowInsetsAnimationCompat.Callback.DISPATCH_MODE_STOP) {
@NonNull
@Override
@@ -146,7 +160,7 @@ abstract class ActivityBase extends AppCompatActivity implements SharedPreferenc
Insets insets = windowInsets.getInsets(WindowInsetsCompat.Type.systemBars());
int bottom = windowInsets.getInsets(WindowInsetsCompat.Type.ime()).bottom;
int pad = bottom - insets.bottom;
- container.setPaddingRelative(0, 0, 0, pad < 0 ? 0 : pad);
+ holder.setPaddingRelative(0, 0, 0, pad < 0 ? 0 : pad);
break;
}
@@ -154,7 +168,7 @@ abstract class ActivityBase extends AppCompatActivity implements SharedPreferenc
}
});
- super.setContentView(container);
+ super.setContentView(holder);
int colorPrimaryDark = Helper.resolveColor(this, androidx.appcompat.R.attr.colorPrimaryDark);
view.post(new RunnableEx("setBackgroundColor") {
diff --git a/app/src/main/res/layout/toolbar_holder.xml b/app/src/main/res/layout/toolbar_holder.xml
index f0b5b5b4d4..4721ed51fc 100644
--- a/app/src/main/res/layout/toolbar_holder.xml
+++ b/app/src/main/res/layout/toolbar_holder.xml
@@ -1,71 +1,78 @@
-
-
+ android:layout_height="wrap_content">
-
+ android:layout_height="?attr/actionBarSize"
+ android:background="?attr/colorPrimary"
+ android:elevation="8dp"
+ app:layout_constraintEnd_toEndOf="parent"
+ app:layout_constraintStart_toStartOf="parent"
+ app:layout_constraintTop_toTopOf="parent"
+ app:layout_scrollFlags="scroll|enterAlways"
+ app:theme="@style/actionBarStyle">
-
+
-
+
-
-
-
+
+
+
+
+
+
-
+