mirror of
https://github.com/M66B/FairEmail.git
synced 2025-01-01 12:44:42 +00:00
Added widget new message count per account
This commit is contained in:
parent
15314464c1
commit
b99fcb48f7
9 changed files with 298 additions and 73 deletions
|
@ -93,6 +93,15 @@
|
||||||
</intent-filter>
|
</intent-filter>
|
||||||
</activity>
|
</activity>
|
||||||
|
|
||||||
|
<activity
|
||||||
|
android:name=".ActivityWidget"
|
||||||
|
android:exported="true">
|
||||||
|
|
||||||
|
<intent-filter>
|
||||||
|
<action android:name="android.appwidget.action.APPWIDGET_CONFIGURE" />
|
||||||
|
</intent-filter>
|
||||||
|
</activity>
|
||||||
|
|
||||||
<activity
|
<activity
|
||||||
android:name=".ActivityWidgetUnified"
|
android:name=".ActivityWidgetUnified"
|
||||||
android:exported="true">
|
android:exported="true">
|
||||||
|
|
130
app/src/main/java/eu/faircode/email/ActivityWidget.java
Normal file
130
app/src/main/java/eu/faircode/email/ActivityWidget.java
Normal file
|
@ -0,0 +1,130 @@
|
||||||
|
package eu.faircode.email;
|
||||||
|
|
||||||
|
/*
|
||||||
|
This file is part of FairEmail.
|
||||||
|
|
||||||
|
FairEmail is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
FairEmail is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with FairEmail. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
Copyright 2018-2019 by Marcel Bokhorst (M66B)
|
||||||
|
*/
|
||||||
|
|
||||||
|
import android.appwidget.AppWidgetManager;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.SharedPreferences;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.ArrayAdapter;
|
||||||
|
import android.widget.Button;
|
||||||
|
import android.widget.Spinner;
|
||||||
|
|
||||||
|
import androidx.constraintlayout.widget.Group;
|
||||||
|
import androidx.preference.PreferenceManager;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class ActivityWidget extends ActivityBase {
|
||||||
|
private int appWidgetId;
|
||||||
|
|
||||||
|
private Spinner spAccount;
|
||||||
|
private Button btnSave;
|
||||||
|
private ContentLoadingProgressBar pbWait;
|
||||||
|
private Group grpReady;
|
||||||
|
|
||||||
|
private ArrayAdapter<EntityAccount> adapterAccount;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
|
Bundle extras = getIntent().getExtras();
|
||||||
|
if (extras == null) {
|
||||||
|
finish();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
appWidgetId = extras.getInt(
|
||||||
|
AppWidgetManager.EXTRA_APPWIDGET_ID, AppWidgetManager.INVALID_APPWIDGET_ID);
|
||||||
|
|
||||||
|
getSupportActionBar().setSubtitle(R.string.title_widget_title_count);
|
||||||
|
setContentView(R.layout.activity_widget);
|
||||||
|
|
||||||
|
spAccount = findViewById(R.id.spAccount);
|
||||||
|
btnSave = findViewById(R.id.btnSave);
|
||||||
|
pbWait = findViewById(R.id.pbWait);
|
||||||
|
grpReady = findViewById(R.id.grpReady);
|
||||||
|
|
||||||
|
final Intent resultValue = new Intent();
|
||||||
|
resultValue.putExtra(AppWidgetManager.EXTRA_APPWIDGET_ID, appWidgetId);
|
||||||
|
|
||||||
|
btnSave.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View view) {
|
||||||
|
EntityAccount account = (EntityAccount) spAccount.getSelectedItem();
|
||||||
|
|
||||||
|
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(ActivityWidget.this);
|
||||||
|
SharedPreferences.Editor editor = prefs.edit();
|
||||||
|
if (account != null && account.id > 0)
|
||||||
|
editor.putString("widget." + appWidgetId + ".name", account.name);
|
||||||
|
else
|
||||||
|
editor.remove("widget." + appWidgetId + ".name");
|
||||||
|
editor.putLong("widget." + appWidgetId + ".account", account == null ? -1L : account.id);
|
||||||
|
editor.apply();
|
||||||
|
|
||||||
|
Widget.init(ActivityWidget.this, appWidgetId);
|
||||||
|
|
||||||
|
setResult(RESULT_OK, resultValue);
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
adapterAccount = new ArrayAdapter<>(this, R.layout.spinner_item1, android.R.id.text1, new ArrayList<EntityAccount>());
|
||||||
|
adapterAccount.setDropDownViewResource(R.layout.spinner_item1_dropdown);
|
||||||
|
spAccount.setAdapter(adapterAccount);
|
||||||
|
|
||||||
|
grpReady.setVisibility(View.GONE);
|
||||||
|
pbWait.setVisibility(View.VISIBLE);
|
||||||
|
|
||||||
|
setResult(RESULT_CANCELED, resultValue);
|
||||||
|
|
||||||
|
new SimpleTask<List<EntityAccount>>() {
|
||||||
|
@Override
|
||||||
|
protected List<EntityAccount> onExecute(Context context, Bundle args) {
|
||||||
|
DB db = DB.getInstance(context);
|
||||||
|
|
||||||
|
return db.account().getSynchronizingAccounts();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onExecuted(Bundle args, List<EntityAccount> accounts) {
|
||||||
|
EntityAccount all = new EntityAccount();
|
||||||
|
all.id = -1L;
|
||||||
|
all.name = getString(R.string.title_widget_account_all);
|
||||||
|
all.primary = false;
|
||||||
|
accounts.add(0, all);
|
||||||
|
|
||||||
|
adapterAccount.addAll(accounts);
|
||||||
|
|
||||||
|
grpReady.setVisibility(View.VISIBLE);
|
||||||
|
pbWait.setVisibility(View.GONE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onException(Bundle args, Throwable ex) {
|
||||||
|
Log.unexpectedError(getSupportFragmentManager(), ex);
|
||||||
|
}
|
||||||
|
}.execute(this, new Bundle(), "widget:accounts");
|
||||||
|
}
|
||||||
|
}
|
|
@ -300,19 +300,27 @@ public interface DaoMessage {
|
||||||
" WHERE message.id = :id")
|
" WHERE message.id = :id")
|
||||||
LiveData<TupleMessageEx> liveMessage(long id);
|
LiveData<TupleMessageEx> liveMessage(long id);
|
||||||
|
|
||||||
String widget = "SELECT COUNT(message.id) AS unseen, SUM(ABS(notifying)) AS notifying" +
|
@Query("SELECT account.id, COUNT(message.id) AS unseen, SUM(ABS(notifying)) AS notifying" +
|
||||||
" FROM message" +
|
" FROM message" +
|
||||||
" JOIN account ON account.id = message.account" +
|
" JOIN account ON account.id = message.account" +
|
||||||
" JOIN folder ON folder.id = message.folder" +
|
" JOIN folder ON folder.id = message.folder" +
|
||||||
" WHERE account.`synchronize`" +
|
" WHERE (:account IS NULL OR account.id = :account)" +
|
||||||
|
" AND account.`synchronize`" +
|
||||||
" AND folder.notify" +
|
" AND folder.notify" +
|
||||||
" AND NOT (message.ui_seen OR message.ui_hide)";
|
" AND NOT (message.ui_seen OR message.ui_hide)" +
|
||||||
|
" GROUP BY account.id" +
|
||||||
|
" ORDER BY account.id")
|
||||||
|
LiveData<List<TupleMessageStats>> liveUnseenWidget(Long account);
|
||||||
|
|
||||||
@Query(widget)
|
@Query("SELECT :account AS account, COUNT(message.id) AS unseen, SUM(ABS(notifying)) AS notifying" +
|
||||||
LiveData<TupleMessageStats> liveUnseenWidget();
|
" FROM message" +
|
||||||
|
" JOIN account ON account.id = message.account" +
|
||||||
@Query(widget)
|
" JOIN folder ON folder.id = message.folder" +
|
||||||
TupleMessageStats getUnseenWidget();
|
" WHERE (:account IS NULL OR account.id = :account)" +
|
||||||
|
" AND account.`synchronize`" +
|
||||||
|
" AND folder.notify" +
|
||||||
|
" AND NOT (message.ui_seen OR message.ui_hide)")
|
||||||
|
TupleMessageStats getUnseenWidget(Long account);
|
||||||
|
|
||||||
@Query("SELECT message.*" +
|
@Query("SELECT message.*" +
|
||||||
", account.pop AS accountProtocol, account.name AS accountName, COALESCE(identity.color, folder.color, account.color) AS accountColor" +
|
", account.pop AS accountProtocol, account.name AS accountName, COALESCE(identity.color, folder.color, account.color) AS accountColor" +
|
||||||
|
|
|
@ -362,23 +362,46 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
|
||||||
|
|
||||||
final SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this);
|
final SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this);
|
||||||
|
|
||||||
db.message().liveUnseenWidget().observe(this, new Observer<TupleMessageStats>() {
|
db.message().liveUnseenWidget(null).observe(this, new Observer<List<TupleMessageStats>>() {
|
||||||
private Integer lastUnseen = null;
|
private List<TupleMessageStats> last = null;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onChanged(TupleMessageStats stats) {
|
public void onChanged(List<TupleMessageStats> stats) {
|
||||||
if (stats == null)
|
if (stats == null)
|
||||||
stats = new TupleMessageStats();
|
stats = new ArrayList<>();
|
||||||
|
|
||||||
|
boolean changed = false;
|
||||||
|
if (last == null || last.size() != stats.size())
|
||||||
|
changed = true;
|
||||||
|
else
|
||||||
|
for (int i = 0; i < stats.size(); i++)
|
||||||
|
if (!last.get(i).equals(stats.get(i))) {
|
||||||
|
changed = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!changed)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Widget.update(ServiceSynchronize.this);
|
||||||
|
|
||||||
|
boolean badge = prefs.getBoolean("badge", true);
|
||||||
boolean unseen_ignored = prefs.getBoolean("unseen_ignored", false);
|
boolean unseen_ignored = prefs.getBoolean("unseen_ignored", false);
|
||||||
Integer unseen = (unseen_ignored ? stats.notifying : stats.unseen);
|
|
||||||
if (unseen == null)
|
|
||||||
unseen = 0;
|
|
||||||
|
|
||||||
if (lastUnseen == null || !lastUnseen.equals(unseen)) {
|
int count = 0;
|
||||||
Log.i("Stats " + stats);
|
for (TupleMessageStats stat : stats) {
|
||||||
lastUnseen = unseen;
|
Integer unseen = (unseen_ignored ? stat.notifying : stat.unseen);
|
||||||
setUnseen(unseen);
|
if (unseen != null)
|
||||||
|
count += unseen;
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
if (count == 0 || !badge)
|
||||||
|
ShortcutBadger.removeCount(ServiceSynchronize.this);
|
||||||
|
else
|
||||||
|
ShortcutBadger.applyCount(ServiceSynchronize.this, count);
|
||||||
|
} catch (Throwable ex) {
|
||||||
|
Log.e(ex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -510,8 +533,6 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
|
||||||
|
|
||||||
liveAccountNetworkState.postDestroy();
|
liveAccountNetworkState.postDestroy();
|
||||||
|
|
||||||
setUnseen(null);
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
stopForeground(true);
|
stopForeground(true);
|
||||||
} catch (Throwable ex) {
|
} catch (Throwable ex) {
|
||||||
|
@ -687,22 +708,6 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
|
||||||
return builder;
|
return builder;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setUnseen(Integer unseen) {
|
|
||||||
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this);
|
|
||||||
boolean badge = prefs.getBoolean("badge", true);
|
|
||||||
|
|
||||||
Widget.update(this, unseen);
|
|
||||||
|
|
||||||
try {
|
|
||||||
if (unseen == null || !badge)
|
|
||||||
ShortcutBadger.removeCount(this);
|
|
||||||
else
|
|
||||||
ShortcutBadger.applyCount(this, unseen);
|
|
||||||
} catch (Throwable ex) {
|
|
||||||
Log.e(ex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void monitorAccount(final EntityAccount account, final Core.State state, final boolean sync) throws NoSuchProviderException {
|
private void monitorAccount(final EntityAccount account, final Core.State state, final boolean sync) throws NoSuchProviderException {
|
||||||
final PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE);
|
final PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE);
|
||||||
final PowerManager.WakeLock wlAccount = pm.newWakeLock(
|
final PowerManager.WakeLock wlAccount = pm.newWakeLock(
|
||||||
|
|
|
@ -25,6 +25,7 @@ import androidx.annotation.Nullable;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
public class TupleMessageStats {
|
public class TupleMessageStats {
|
||||||
|
public Long account;
|
||||||
public Integer unseen;
|
public Integer unseen;
|
||||||
public Integer notifying;
|
public Integer notifying;
|
||||||
|
|
||||||
|
@ -32,7 +33,8 @@ public class TupleMessageStats {
|
||||||
public boolean equals(@Nullable Object obj) {
|
public boolean equals(@Nullable Object obj) {
|
||||||
if (obj instanceof TupleMessageStats) {
|
if (obj instanceof TupleMessageStats) {
|
||||||
TupleMessageStats other = (TupleMessageStats) obj;
|
TupleMessageStats other = (TupleMessageStats) obj;
|
||||||
return (Objects.equals(this.unseen, other.unseen) &&
|
return (Objects.equals(this.account, other.account) &&
|
||||||
|
Objects.equals(this.unseen, other.unseen) &&
|
||||||
Objects.equals(this.notifying, other.notifying));
|
Objects.equals(this.notifying, other.notifying));
|
||||||
} else
|
} else
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -26,6 +26,7 @@ import android.content.ComponentName;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
|
import android.text.TextUtils;
|
||||||
import android.widget.RemoteViews;
|
import android.widget.RemoteViews;
|
||||||
|
|
||||||
import androidx.preference.PreferenceManager;
|
import androidx.preference.PreferenceManager;
|
||||||
|
@ -42,21 +43,49 @@ public class Widget extends AppWidgetProvider {
|
||||||
executor.submit(new Runnable() {
|
executor.submit(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
DB db = DB.getInstance(context);
|
|
||||||
TupleMessageStats stats = db.message().getUnseenWidget();
|
|
||||||
|
|
||||||
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context);
|
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context);
|
||||||
boolean unseen_ignored = prefs.getBoolean("unseen_ignored", false);
|
boolean unseen_ignored = prefs.getBoolean("unseen_ignored", false);
|
||||||
Integer unseen = (unseen_ignored ? stats.notifying : stats.unseen);
|
|
||||||
if (unseen == null)
|
|
||||||
unseen = 0;
|
|
||||||
|
|
||||||
update(context, appWidgetManager, appWidgetIds, unseen);
|
DB db = DB.getInstance(context);
|
||||||
|
NumberFormat nf = NumberFormat.getIntegerInstance();
|
||||||
|
|
||||||
|
Intent view = new Intent(context, ActivityView.class);
|
||||||
|
view.setAction("unified");
|
||||||
|
view.putExtra("refresh", true);
|
||||||
|
view.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
||||||
|
PendingIntent pi = PendingIntent.getActivity(context, ActivityView.REQUEST_UNIFIED, view, PendingIntent.FLAG_UPDATE_CURRENT);
|
||||||
|
|
||||||
|
for (int appWidgetId : appWidgetIds) {
|
||||||
|
long account = prefs.getLong("widget." + appWidgetId + ".account", -1L);
|
||||||
|
String name = prefs.getString("widget." + appWidgetId + ".name", null);
|
||||||
|
|
||||||
|
TupleMessageStats stats = db.message().getUnseenWidget(account < 0 ? null : account);
|
||||||
|
Integer unseen = (unseen_ignored ? stats.notifying : stats.unseen);
|
||||||
|
if (unseen == null)
|
||||||
|
unseen = 0;
|
||||||
|
|
||||||
|
RemoteViews views = new RemoteViews(context.getPackageName(), R.layout.widget);
|
||||||
|
|
||||||
|
views.setOnClickPendingIntent(R.id.widget, pi);
|
||||||
|
|
||||||
|
views.setTextViewText(R.id.tvCount, unseen < 100 ? nf.format(unseen) : "∞");
|
||||||
|
|
||||||
|
if (!TextUtils.isEmpty(name)) {
|
||||||
|
views.setTextViewText(R.id.tvAccount, name);
|
||||||
|
views.setViewVisibility(R.id.tvAccount, ViewStripe.VISIBLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
appWidgetManager.updateAppWidget(appWidgetId, views);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
static void update(Context context, Integer count) {
|
static void init(Context context, int appWidgetId) {
|
||||||
|
update(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void update(Context context) {
|
||||||
AppWidgetManager appWidgetManager = AppWidgetManager.getInstance(context);
|
AppWidgetManager appWidgetManager = AppWidgetManager.getInstance(context);
|
||||||
if (appWidgetManager == null) {
|
if (appWidgetManager == null) {
|
||||||
Log.w("No app widget manager"); // Fairphone FP2
|
Log.w("No app widget manager"); // Fairphone FP2
|
||||||
|
@ -64,31 +93,10 @@ public class Widget extends AppWidgetProvider {
|
||||||
}
|
}
|
||||||
|
|
||||||
int[] appWidgetIds = appWidgetManager.getAppWidgetIds(new ComponentName(context, Widget.class));
|
int[] appWidgetIds = appWidgetManager.getAppWidgetIds(new ComponentName(context, Widget.class));
|
||||||
update(context, appWidgetManager, appWidgetIds, count);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void update(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds, Integer count) {
|
Intent intent = new Intent(context, Widget.class);
|
||||||
NumberFormat nf = NumberFormat.getIntegerInstance();
|
intent.setAction(AppWidgetManager.ACTION_APPWIDGET_UPDATE);
|
||||||
|
intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS, appWidgetIds);
|
||||||
Intent view = new Intent(context, ActivityView.class);
|
context.sendBroadcast(intent);
|
||||||
view.setAction("unified");
|
|
||||||
view.putExtra("refresh", true);
|
|
||||||
view.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
|
||||||
PendingIntent pi = PendingIntent.getActivity(context, ActivityView.REQUEST_UNIFIED, view, PendingIntent.FLAG_UPDATE_CURRENT);
|
|
||||||
|
|
||||||
for (int appWidgetId : appWidgetIds) {
|
|
||||||
RemoteViews views = new RemoteViews(context.getPackageName(), R.layout.widget);
|
|
||||||
|
|
||||||
views.setOnClickPendingIntent(R.id.widget, pi);
|
|
||||||
|
|
||||||
if (count == null)
|
|
||||||
views.setTextViewText(R.id.tvCount, "?");
|
|
||||||
else if (count > 99)
|
|
||||||
views.setTextViewText(R.id.tvCount, "∞");
|
|
||||||
else
|
|
||||||
views.setTextViewText(R.id.tvCount, nf.format(count));
|
|
||||||
|
|
||||||
appWidgetManager.updateAppWidget(appWidgetId, views);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
50
app/src/main/res/layout/activity_widget.xml
Normal file
50
app/src/main/res/layout/activity_widget.xml
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:padding="12dp">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvAccount"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:text="@string/title_widget_account"
|
||||||
|
android:textAppearance="@style/TextAppearance.AppCompat.Small"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toTopOf="parent" />
|
||||||
|
|
||||||
|
<Spinner
|
||||||
|
android:id="@+id/spAccount"
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toBottomOf="@id/tvAccount" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btnSave"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginTop="12dp"
|
||||||
|
android:text="@string/title_save"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toBottomOf="@id/spAccount" />
|
||||||
|
|
||||||
|
<eu.faircode.email.ContentLoadingProgressBar
|
||||||
|
android:id="@+id/pbWait"
|
||||||
|
style="@style/Base.Widget.AppCompat.ProgressBar"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
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/grpReady"
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="0dp"
|
||||||
|
app:constraint_referenced_ids="tvAccount,spAccount,btnSave" />
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
|
@ -11,7 +11,7 @@
|
||||||
android:layout_width="24dp"
|
android:layout_width="24dp"
|
||||||
android:layout_height="0dp"
|
android:layout_height="0dp"
|
||||||
android:layout_gravity="center_horizontal"
|
android:layout_gravity="center_horizontal"
|
||||||
android:layout_weight="1"
|
android:layout_weight="2"
|
||||||
android:contentDescription="@string/title_legend_count"
|
android:contentDescription="@string/title_legend_count"
|
||||||
android:src="@drawable/baseline_mail_24"
|
android:src="@drawable/baseline_mail_24"
|
||||||
android:tint="@color/colorWidgetForeground" />
|
android:tint="@color/colorWidgetForeground" />
|
||||||
|
@ -21,10 +21,22 @@
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="0dp"
|
android:layout_height="0dp"
|
||||||
android:layout_gravity="center_horizontal"
|
android:layout_gravity="center_horizontal"
|
||||||
android:layout_weight="1"
|
android:layout_weight="2"
|
||||||
android:text="\?"
|
android:text="\?"
|
||||||
android:textAppearance="@style/TextAppearance.AppCompat.Medium"
|
android:textAppearance="@style/TextAppearance.AppCompat.Medium"
|
||||||
android:textColor="@color/colorWidgetForeground"
|
android:textColor="@color/colorWidgetForeground"
|
||||||
android:textSize="18dp"
|
android:textSize="18dp"
|
||||||
android:textStyle="bold" />
|
android:textStyle="bold" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/tvAccount"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="0dp"
|
||||||
|
android:layout_gravity="center_horizontal"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:text="account"
|
||||||
|
android:textAppearance="@style/TextAppearance.AppCompat.Small"
|
||||||
|
android:textColor="@color/colorWidgetForeground"
|
||||||
|
android:textSize="12dp"
|
||||||
|
android:visibility="gone" />
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
|
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:configure="eu.faircode.email.ActivityWidget"
|
||||||
android:initialLayout="@layout/widget"
|
android:initialLayout="@layout/widget"
|
||||||
android:minWidth="40dp"
|
android:minWidth="40dp"
|
||||||
android:minHeight="40dp"
|
android:minHeight="40dp"
|
||||||
|
|
Loading…
Reference in a new issue