mirror of https://github.com/M66B/FairEmail.git
Added folders refresh
This commit is contained in:
parent
59b13d15dd
commit
9391a0f2a3
|
@ -39,6 +39,13 @@ public interface DaoFolder {
|
||||||
" AND (account.synchronize AND NOT account.ondemand)")
|
" AND (account.synchronize AND NOT account.ondemand)")
|
||||||
List<EntityFolder> getFoldersAutoSync();
|
List<EntityFolder> getFoldersAutoSync();
|
||||||
|
|
||||||
|
@Query("SELECT folder.* FROM folder" +
|
||||||
|
" JOIN account ON account.id = folder.account" +
|
||||||
|
" WHERE folder.synchronize" +
|
||||||
|
" AND account.id = :account" +
|
||||||
|
" AND (account.synchronize AND account.ondemand)")
|
||||||
|
List<EntityFolder> getFoldersOnDemandSync(long account);
|
||||||
|
|
||||||
@Query("SELECT folder.* FROM folder" +
|
@Query("SELECT folder.* FROM folder" +
|
||||||
" JOIN account ON account.id = folder.account" +
|
" JOIN account ON account.id = folder.account" +
|
||||||
" WHERE account.synchronize AND folder.synchronize AND unified")
|
" WHERE account.synchronize AND folder.synchronize AND unified")
|
||||||
|
|
|
@ -19,7 +19,11 @@ package eu.faircode.email;
|
||||||
Copyright 2018-2019 by Marcel Bokhorst (M66B)
|
Copyright 2018-2019 by Marcel Bokhorst (M66B)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
|
import android.graphics.Color;
|
||||||
|
import android.net.ConnectivityManager;
|
||||||
|
import android.net.NetworkInfo;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.preference.PreferenceManager;
|
import android.preference.PreferenceManager;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
|
@ -31,6 +35,7 @@ import android.view.ViewGroup;
|
||||||
import android.widget.ImageButton;
|
import android.widget.ImageButton;
|
||||||
|
|
||||||
import com.google.android.material.floatingactionbutton.FloatingActionButton;
|
import com.google.android.material.floatingactionbutton.FloatingActionButton;
|
||||||
|
import com.google.android.material.snackbar.Snackbar;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
@ -41,8 +46,11 @@ import androidx.fragment.app.FragmentTransaction;
|
||||||
import androidx.lifecycle.Observer;
|
import androidx.lifecycle.Observer;
|
||||||
import androidx.recyclerview.widget.LinearLayoutManager;
|
import androidx.recyclerview.widget.LinearLayoutManager;
|
||||||
import androidx.recyclerview.widget.RecyclerView;
|
import androidx.recyclerview.widget.RecyclerView;
|
||||||
|
import androidx.swiperefreshlayout.widget.SwipeRefreshLayout;
|
||||||
|
|
||||||
public class FragmentFolders extends FragmentBase {
|
public class FragmentFolders extends FragmentBase {
|
||||||
|
private ViewGroup view;
|
||||||
|
private SwipeRefreshLayout swipeRefresh;
|
||||||
private ImageButton ibHintActions;
|
private ImageButton ibHintActions;
|
||||||
private ImageButton ibHintSync;
|
private ImageButton ibHintSync;
|
||||||
private RecyclerView rvFolder;
|
private RecyclerView rvFolder;
|
||||||
|
@ -71,9 +79,10 @@ public class FragmentFolders extends FragmentBase {
|
||||||
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
|
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
|
||||||
setHasOptionsMenu(true);
|
setHasOptionsMenu(true);
|
||||||
|
|
||||||
View view = inflater.inflate(R.layout.fragment_folders, container, false);
|
view = (ViewGroup) inflater.inflate(R.layout.fragment_folders, container, false);
|
||||||
|
|
||||||
// Get controls
|
// Get controls
|
||||||
|
swipeRefresh = view.findViewById(R.id.swipeRefresh);
|
||||||
ibHintActions = view.findViewById(R.id.ibHintActions);
|
ibHintActions = view.findViewById(R.id.ibHintActions);
|
||||||
ibHintSync = view.findViewById(R.id.ibHintSync);
|
ibHintSync = view.findViewById(R.id.ibHintSync);
|
||||||
rvFolder = view.findViewById(R.id.rvFolder);
|
rvFolder = view.findViewById(R.id.rvFolder);
|
||||||
|
@ -87,6 +96,16 @@ public class FragmentFolders extends FragmentBase {
|
||||||
|
|
||||||
final SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(getContext());
|
final SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(getContext());
|
||||||
|
|
||||||
|
int colorPrimary = Helper.resolveColor(getContext(), R.attr.colorPrimary);
|
||||||
|
swipeRefresh.setColorSchemeColors(Color.WHITE, Color.WHITE, Color.WHITE);
|
||||||
|
swipeRefresh.setProgressBackgroundColorSchemeColor(colorPrimary);
|
||||||
|
swipeRefresh.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
|
||||||
|
@Override
|
||||||
|
public void onRefresh() {
|
||||||
|
onSwipeRefresh();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
ibHintActions.setOnClickListener(new View.OnClickListener() {
|
ibHintActions.setOnClickListener(new View.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
|
@ -204,6 +223,93 @@ public class FragmentFolders extends FragmentBase {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void onSwipeRefresh() {
|
||||||
|
Bundle args = new Bundle();
|
||||||
|
args.putLong("account", account);
|
||||||
|
|
||||||
|
new SimpleTask<Boolean>() {
|
||||||
|
@Override
|
||||||
|
protected void onPostExecute(Bundle args) {
|
||||||
|
swipeRefresh.setRefreshing(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Boolean onExecute(Context context, Bundle args) {
|
||||||
|
long aid = args.getLong("account");
|
||||||
|
|
||||||
|
ConnectivityManager cm = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||||
|
NetworkInfo ni = cm.getActiveNetworkInfo();
|
||||||
|
boolean internet = (ni != null && ni.isConnected());
|
||||||
|
|
||||||
|
DB db = DB.getInstance(context);
|
||||||
|
try {
|
||||||
|
db.beginTransaction();
|
||||||
|
|
||||||
|
boolean now = false;
|
||||||
|
boolean nointernet = false;
|
||||||
|
|
||||||
|
if (aid < 0) {
|
||||||
|
// Unified inbox
|
||||||
|
List<EntityFolder> folders = db.folder().getFoldersSynchronizingUnified();
|
||||||
|
for (EntityFolder folder : folders) {
|
||||||
|
EntityAccount account = db.account().getAccount(folder.account);
|
||||||
|
if (account.ondemand)
|
||||||
|
if (internet) {
|
||||||
|
now = true;
|
||||||
|
ServiceUI.sync(context, folder.id);
|
||||||
|
} else
|
||||||
|
nointernet = true;
|
||||||
|
else {
|
||||||
|
now = "connected".equals(account.state);
|
||||||
|
EntityOperation.sync(context, db, folder.id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
EntityAccount account = db.account().getAccount(aid);
|
||||||
|
if (account.ondemand) {
|
||||||
|
if (internet) {
|
||||||
|
now = true;
|
||||||
|
List<EntityFolder> folders = db.folder().getFoldersOnDemandSync(aid);
|
||||||
|
for (EntityFolder folder : folders)
|
||||||
|
ServiceUI.sync(context, folder.id);
|
||||||
|
} else
|
||||||
|
nointernet = true;
|
||||||
|
} else {
|
||||||
|
if (internet) {
|
||||||
|
now = true;
|
||||||
|
ServiceSynchronize.reload(getContext(), "refresh folders");
|
||||||
|
} else
|
||||||
|
nointernet = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
db.setTransactionSuccessful();
|
||||||
|
|
||||||
|
if (nointernet)
|
||||||
|
throw new IllegalArgumentException(context.getString(R.string.title_no_internet));
|
||||||
|
|
||||||
|
return now;
|
||||||
|
} finally {
|
||||||
|
db.endTransaction();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onExecuted(Bundle args, Boolean now) {
|
||||||
|
if (!now)
|
||||||
|
Snackbar.make(view, R.string.title_sync_delayed, Snackbar.LENGTH_LONG).show();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onException(Bundle args, Throwable ex) {
|
||||||
|
if (ex instanceof IllegalArgumentException)
|
||||||
|
Snackbar.make(view, ex.getMessage(), Snackbar.LENGTH_LONG).show();
|
||||||
|
else
|
||||||
|
Helper.unexpectedError(getContext(), getViewLifecycleOwner(), ex);
|
||||||
|
}
|
||||||
|
}.execute(FragmentFolders.this, args, "folders:refresh");
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
|
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
|
||||||
inflater.inflate(R.menu.menu_folders, menu);
|
inflater.inflate(R.menu.menu_folders, menu);
|
||||||
|
|
|
@ -488,6 +488,11 @@ public class FragmentMessages extends FragmentBase {
|
||||||
args.putLong("folder", folder);
|
args.putLong("folder", folder);
|
||||||
|
|
||||||
new SimpleTask<Boolean>() {
|
new SimpleTask<Boolean>() {
|
||||||
|
@Override
|
||||||
|
protected void onPostExecute(Bundle args) {
|
||||||
|
swipeRefresh.setRefreshing(false);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Boolean onExecute(Context context, Bundle args) {
|
protected Boolean onExecute(Context context, Bundle args) {
|
||||||
long fid = args.getLong("folder");
|
long fid = args.getLong("folder");
|
||||||
|
@ -548,16 +553,12 @@ public class FragmentMessages extends FragmentBase {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onExecuted(Bundle args, Boolean now) {
|
protected void onExecuted(Bundle args, Boolean now) {
|
||||||
if (!now) {
|
if (!now)
|
||||||
swipeRefresh.setRefreshing(false);
|
|
||||||
Snackbar.make(view, R.string.title_sync_delayed, Snackbar.LENGTH_LONG).show();
|
Snackbar.make(view, R.string.title_sync_delayed, Snackbar.LENGTH_LONG).show();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onException(Bundle args, Throwable ex) {
|
protected void onException(Bundle args, Throwable ex) {
|
||||||
swipeRefresh.setRefreshing(false);
|
|
||||||
|
|
||||||
if (ex instanceof IllegalArgumentException)
|
if (ex instanceof IllegalArgumentException)
|
||||||
Snackbar.make(view, ex.getMessage(), Snackbar.LENGTH_LONG).show();
|
Snackbar.make(view, ex.getMessage(), Snackbar.LENGTH_LONG).show();
|
||||||
else
|
else
|
||||||
|
|
|
@ -6,119 +6,124 @@
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
tools:context=".ActivityView">
|
tools:context=".ActivityView">
|
||||||
|
|
||||||
<androidx.constraintlayout.widget.ConstraintLayout
|
<androidx.swiperefreshlayout.widget.SwipeRefreshLayout
|
||||||
|
android:id="@+id/swipeRefresh"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent">
|
||||||
tools:context=".ActivityView">
|
|
||||||
|
|
||||||
<TextView
|
<androidx.constraintlayout.widget.ConstraintLayout
|
||||||
android:id="@+id/tvHintActions"
|
|
||||||
android:layout_width="0dp"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_marginStart="6dp"
|
|
||||||
android:layout_marginTop="6dp"
|
|
||||||
android:layout_marginEnd="6dp"
|
|
||||||
android:gravity="center_vertical"
|
|
||||||
android:minHeight="33dp"
|
|
||||||
android:text="@string/title_hint_folder_actions"
|
|
||||||
android:textAppearance="@style/TextAppearance.AppCompat.Small"
|
|
||||||
android:textColor="?android:attr/textColorPrimary"
|
|
||||||
app:layout_constraintEnd_toStartOf="@+id/ibHintActions"
|
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
|
||||||
app:layout_constraintTop_toTopOf="parent" />
|
|
||||||
|
|
||||||
<ImageButton
|
|
||||||
android:id="@+id/ibHintActions"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:src="@drawable/baseline_close_24"
|
|
||||||
app:layout_constraintBottom_toBottomOf="@id/tvHintActions"
|
|
||||||
app:layout_constraintEnd_toEndOf="parent"
|
|
||||||
app:layout_constraintTop_toTopOf="@id/tvHintActions" />
|
|
||||||
|
|
||||||
<View
|
|
||||||
android:id="@+id/vSeparatorActions"
|
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="1dp"
|
android:layout_height="match_parent">
|
||||||
android:layout_marginTop="6dp"
|
|
||||||
android:background="?attr/colorSeparator"
|
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
|
||||||
app:layout_constraintTop_toBottomOf="@id/tvHintActions" />
|
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/tvHintSync"
|
android:id="@+id/tvHintActions"
|
||||||
android:layout_width="0dp"
|
android:layout_width="0dp"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginStart="6dp"
|
android:layout_marginStart="6dp"
|
||||||
android:layout_marginTop="6dp"
|
android:layout_marginTop="6dp"
|
||||||
android:layout_marginEnd="6dp"
|
android:layout_marginEnd="6dp"
|
||||||
android:gravity="center_vertical"
|
android:gravity="center_vertical"
|
||||||
android:minHeight="33dp"
|
android:minHeight="33dp"
|
||||||
android:text="@string/title_hint_folder_sync"
|
android:text="@string/title_hint_folder_actions"
|
||||||
android:textAppearance="@style/TextAppearance.AppCompat.Small"
|
android:textAppearance="@style/TextAppearance.AppCompat.Small"
|
||||||
android:textColor="?android:attr/textColorPrimary"
|
android:textColor="?android:attr/textColorPrimary"
|
||||||
app:layout_constraintEnd_toStartOf="@+id/ibHintSync"
|
app:layout_constraintEnd_toStartOf="@+id/ibHintActions"
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
app:layout_constraintTop_toBottomOf="@id/vSeparatorActions" />
|
app:layout_constraintTop_toTopOf="parent" />
|
||||||
|
|
||||||
<ImageButton
|
<ImageButton
|
||||||
android:id="@+id/ibHintSync"
|
android:id="@+id/ibHintActions"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:src="@drawable/baseline_close_24"
|
android:src="@drawable/baseline_close_24"
|
||||||
app:layout_constraintBottom_toBottomOf="@id/tvHintSync"
|
app:layout_constraintBottom_toBottomOf="@id/tvHintActions"
|
||||||
app:layout_constraintEnd_toEndOf="parent"
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
app:layout_constraintTop_toTopOf="@id/tvHintSync" />
|
app:layout_constraintTop_toTopOf="@id/tvHintActions" />
|
||||||
|
|
||||||
<View
|
<View
|
||||||
android:id="@+id/vSeparatorSync"
|
android:id="@+id/vSeparatorActions"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="1dp"
|
android:layout_height="1dp"
|
||||||
android:layout_marginTop="6dp"
|
android:layout_marginTop="6dp"
|
||||||
android:background="?attr/colorSeparator"
|
android:background="?attr/colorSeparator"
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
app:layout_constraintTop_toBottomOf="@id/tvHintSync" />
|
app:layout_constraintTop_toBottomOf="@id/tvHintActions" />
|
||||||
|
|
||||||
<androidx.recyclerview.widget.RecyclerView
|
<TextView
|
||||||
android:id="@+id/rvFolder"
|
android:id="@+id/tvHintSync"
|
||||||
android:layout_width="0dp"
|
android:layout_width="0dp"
|
||||||
android:layout_height="0dp"
|
android:layout_height="wrap_content"
|
||||||
android:scrollbarStyle="outsideOverlay"
|
android:layout_marginStart="6dp"
|
||||||
android:scrollbars="vertical"
|
android:layout_marginTop="6dp"
|
||||||
app:layout_constraintBottom_toBottomOf="parent"
|
android:layout_marginEnd="6dp"
|
||||||
app:layout_constraintEnd_toEndOf="parent"
|
android:gravity="center_vertical"
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
android:minHeight="33dp"
|
||||||
app:layout_constraintTop_toBottomOf="@id/vSeparatorSync" />
|
android:text="@string/title_hint_folder_sync"
|
||||||
|
android:textAppearance="@style/TextAppearance.AppCompat.Small"
|
||||||
|
android:textColor="?android:attr/textColorPrimary"
|
||||||
|
app:layout_constraintEnd_toStartOf="@+id/ibHintSync"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toBottomOf="@id/vSeparatorActions" />
|
||||||
|
|
||||||
<eu.faircode.email.ContentLoadingProgressBar
|
<ImageButton
|
||||||
android:id="@+id/pbWait"
|
android:id="@+id/ibHintSync"
|
||||||
style="@style/Base.Widget.AppCompat.ProgressBar"
|
android:layout_width="wrap_content"
|
||||||
android:layout_width="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:src="@drawable/baseline_close_24"
|
||||||
android:indeterminate="true"
|
app:layout_constraintBottom_toBottomOf="@id/tvHintSync"
|
||||||
app:layout_constraintBottom_toBottomOf="parent"
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
app:layout_constraintEnd_toEndOf="parent"
|
app:layout_constraintTop_toTopOf="@id/tvHintSync" />
|
||||||
app:layout_constraintStart_toStartOf="parent"
|
|
||||||
app:layout_constraintTop_toTopOf="parent" />
|
|
||||||
|
|
||||||
<androidx.constraintlayout.widget.Group
|
<View
|
||||||
android:id="@+id/grpHintActions"
|
android:id="@+id/vSeparatorSync"
|
||||||
android:layout_width="0dp"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="0dp"
|
android:layout_height="1dp"
|
||||||
app:constraint_referenced_ids="tvHintActions,ibHintActions,vSeparatorActions" />
|
android:layout_marginTop="6dp"
|
||||||
|
android:background="?attr/colorSeparator"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toBottomOf="@id/tvHintSync" />
|
||||||
|
|
||||||
<androidx.constraintlayout.widget.Group
|
<androidx.recyclerview.widget.RecyclerView
|
||||||
android:id="@+id/grpHintSync"
|
android:id="@+id/rvFolder"
|
||||||
android:layout_width="0dp"
|
android:layout_width="0dp"
|
||||||
android:layout_height="0dp"
|
android:layout_height="0dp"
|
||||||
app:constraint_referenced_ids="tvHintSync,ibHintSync,vSeparatorSync" />
|
android:scrollbarStyle="outsideOverlay"
|
||||||
|
android:scrollbars="vertical"
|
||||||
|
app:layout_constraintBottom_toBottomOf="parent"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toBottomOf="@id/vSeparatorSync" />
|
||||||
|
|
||||||
<androidx.constraintlayout.widget.Group
|
<eu.faircode.email.ContentLoadingProgressBar
|
||||||
android:id="@+id/grpReady"
|
android:id="@+id/pbWait"
|
||||||
android:layout_width="0dp"
|
style="@style/Base.Widget.AppCompat.ProgressBar"
|
||||||
android:layout_height="0dp"
|
android:layout_width="wrap_content"
|
||||||
app:constraint_referenced_ids="rvFolder" />
|
android:layout_height="wrap_content"
|
||||||
</androidx.constraintlayout.widget.ConstraintLayout>
|
android:indeterminate="true"
|
||||||
|
app:layout_constraintBottom_toBottomOf="parent"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toTopOf="parent" />
|
||||||
|
|
||||||
|
<androidx.constraintlayout.widget.Group
|
||||||
|
android:id="@+id/grpHintActions"
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="0dp"
|
||||||
|
app:constraint_referenced_ids="tvHintActions,ibHintActions,vSeparatorActions" />
|
||||||
|
|
||||||
|
<androidx.constraintlayout.widget.Group
|
||||||
|
android:id="@+id/grpHintSync"
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="0dp"
|
||||||
|
app:constraint_referenced_ids="tvHintSync,ibHintSync,vSeparatorSync" />
|
||||||
|
|
||||||
|
<androidx.constraintlayout.widget.Group
|
||||||
|
android:id="@+id/grpReady"
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="0dp"
|
||||||
|
app:constraint_referenced_ids="rvFolder" />
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
||||||
|
</androidx.swiperefreshlayout.widget.SwipeRefreshLayout>
|
||||||
|
|
||||||
<com.google.android.material.floatingactionbutton.FloatingActionButton
|
<com.google.android.material.floatingactionbutton.FloatingActionButton
|
||||||
android:id="@+id/fab"
|
android:id="@+id/fab"
|
||||||
|
|
|
@ -213,7 +213,6 @@
|
||||||
android:layout_height="0dp"
|
android:layout_height="0dp"
|
||||||
app:constraint_referenced_ids="rvMessage" />
|
app:constraint_referenced_ids="rvMessage" />
|
||||||
</androidx.constraintlayout.widget.ConstraintLayout>
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
||||||
|
|
||||||
</androidx.swiperefreshlayout.widget.SwipeRefreshLayout>
|
</androidx.swiperefreshlayout.widget.SwipeRefreshLayout>
|
||||||
|
|
||||||
<com.google.android.material.floatingactionbutton.FloatingActionButton
|
<com.google.android.material.floatingactionbutton.FloatingActionButton
|
||||||
|
|
Loading…
Reference in New Issue