Skip to content

Commit eaf4798

Browse files
committed
NMC-2258: Snackbar theme customized.
NMC-2047: Customized floating action button.
1 parent d97218f commit eaf4798

File tree

12 files changed

+244
-11
lines changed

12 files changed

+244
-11
lines changed
Lines changed: 40 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,40 @@
1+
package com.nmc.android.utils
2+
3+
import android.content.Context
4+
import android.content.res.ColorStateList
5+
import android.graphics.Color
6+
import com.google.android.material.floatingactionbutton.FloatingActionButton
7+
import com.owncloud.android.R
8+
9+
object FabThemeUtils {
10+
@JvmStatic
11+
fun colorFloatingActionButton(
12+
context: Context,
13+
button: FloatingActionButton
14+
) {
15+
val primaryColor = context.resources.getColor(R.color.primary, null)
16+
val disableColor = context.resources.getColor(R.color.grey_0, null)
17+
18+
val bgStates = arrayOf(
19+
intArrayOf(android.R.attr.state_enabled),
20+
intArrayOf(-android.R.attr.state_enabled),
21+
)
22+
val bgColors = intArrayOf(
23+
primaryColor,
24+
disableColor
25+
)
26+
27+
button.backgroundTintList = ColorStateList(bgStates, bgColors)
28+
29+
val imageStates = arrayOf(
30+
intArrayOf(android.R.attr.state_enabled),
31+
intArrayOf(-android.R.attr.state_enabled),
32+
)
33+
val imageColors = intArrayOf(
34+
Color.WHITE,
35+
disableColor
36+
)
37+
38+
button.imageTintList = ColorStateList(imageStates, imageColors)
39+
}
40+
}

app/src/main/java/com/owncloud/android/ui/activity/EditorWebView.java

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -88,7 +88,6 @@ public void onUrlLoaded(String loadedUrl) {
8888
R.string.timeout_richDocuments, Snackbar.LENGTH_INDEFINITE)
8989
.setAction(R.string.common_cancel, v -> closeView());
9090

91-
viewThemeUtils.material.themeSnackbar(snackbar);
9291
setLoadingSnackbar(snackbar);
9392
snackbar.show();
9493
}

app/src/main/java/com/owncloud/android/ui/activity/FileActivity.java

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -728,7 +728,6 @@ public static void copyAndShareFileLink(FileActivity activity,
728728
Snackbar snackbar = Snackbar.make(activity.findViewById(android.R.id.content), R.string.clipboard_text_copied,
729729
Snackbar.LENGTH_LONG)
730730
.setAction(R.string.share, v -> showShareLinkDialog(activity, file, link));
731-
viewThemeUtils.material.themeSnackbar(snackbar);
732731
snackbar.show();
733732
}
734733
}
@@ -798,7 +797,6 @@ private void onUpdateShareInformation(RemoteOperationResult result, @StringRes i
798797
snackbar = Snackbar.make(sharingFragment.getView(), result.getMessage(), Snackbar.LENGTH_LONG);
799798
}
800799

801-
viewThemeUtils.material.themeSnackbar(snackbar);
802800
snackbar.show();
803801
}
804802
}
@@ -875,7 +873,6 @@ private void onCreateShareViaLinkOperationFinish(CreateShareViaLinkOperation ope
875873
operation,
876874
getResources()),
877875
Snackbar.LENGTH_LONG);
878-
viewThemeUtils.material.themeSnackbar(snackbar);
879876
snackbar.show();
880877
}
881878
}

app/src/main/java/com/owncloud/android/ui/fragment/OCFileListFragment.java

Lines changed: 11 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -55,6 +55,7 @@
5555
import com.nextcloud.common.NextcloudClient;
5656
import com.nextcloud.ui.fileactions.FileActionsBottomSheet;
5757
import com.nextcloud.utils.EditorUtils;
58+
import com.nmc.android.utils.FabThemeUtils;
5859
import com.nextcloud.utils.ShortcutUtil;
5960
import com.nextcloud.utils.extensions.BundleExtensionsKt;
6061
import com.nextcloud.utils.extensions.FileExtensionsKt;
@@ -334,7 +335,8 @@ public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container,
334335

335336
if (mFabMain != null) {
336337
// is not available in FolderPickerActivity
337-
viewThemeUtils.material.themeFAB(mFabMain);
338+
//NMC customization
339+
FabThemeUtils.colorFloatingActionButton(requireContext(), mFabMain);
338340
}
339341

340342
Log_OC.i(TAG, "onCreateView() end");
@@ -502,7 +504,8 @@ public void registerFabListener() {
502504

503505
if (mFabMain != null) {
504506
// is not available in FolderPickerActivity
505-
viewThemeUtils.material.themeFAB(mFabMain);
507+
//NMC customization
508+
FabThemeUtils.colorFloatingActionButton(requireContext(), mFabMain);
506509
mFabMain.setOnClickListener(v -> {
507510
PermissionUtil.requestMediaLocationPermission(activity);
508511

@@ -2221,7 +2224,8 @@ public void setFabVisible(final boolean visible) {
22212224
getActivity().runOnUiThread(() -> {
22222225
if (visible) {
22232226
mFabMain.show();
2224-
viewThemeUtils.material.themeFAB(mFabMain);
2227+
//NMC customization
2228+
FabThemeUtils.colorFloatingActionButton(requireContext(), mFabMain);
22252229
} else {
22262230
mFabMain.hide();
22272231
}
@@ -2271,10 +2275,12 @@ public void setFabEnabled(final boolean enabled) {
22712275
getActivity().runOnUiThread(() -> {
22722276
if (enabled) {
22732277
mFabMain.setEnabled(true);
2274-
viewThemeUtils.material.themeFAB(mFabMain);
2278+
//NMC customization
2279+
FabThemeUtils.colorFloatingActionButton(requireContext(), mFabMain);
22752280
} else {
22762281
mFabMain.setEnabled(false);
2277-
viewThemeUtils.material.themeFAB(mFabMain);
2282+
//NMC customization
2283+
FabThemeUtils.colorFloatingActionButton(requireContext(), mFabMain);
22782284
}
22792285
});
22802286
}

app/src/main/java/com/owncloud/android/ui/preview/PreviewTextStringFragment.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,7 @@
1919
import com.google.android.material.floatingactionbutton.FloatingActionButton;
2020
import com.nextcloud.android.lib.richWorkspace.RichWorkspaceDirectEditingRemoteOperation;
2121
import com.nextcloud.utils.extensions.FileExtensionsKt;
22+
import com.nmc.android.utils.FabThemeUtils;
2223
import com.owncloud.android.R;
2324
import com.owncloud.android.lib.common.operations.RemoteOperationResult;
2425
import com.owncloud.android.ui.activity.FileDisplayActivity;
@@ -85,7 +86,8 @@ public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container,
8586
fabMain.setOnClickListener(v -> edit());
8687

8788
fabMain.setImageResource(R.drawable.ic_edit);
88-
viewThemeUtils.material.themeFAB(fabMain);
89+
//NMC customization
90+
FabThemeUtils.colorFloatingActionButton(requireActivity(), fabMain);
8991

9092
return view;
9193
}

app/src/main/java/com/owncloud/android/utils/PermissionUtil.kt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -188,7 +188,7 @@ object PermissionUtil {
188188
Snackbar.LENGTH_INDEFINITE
189189
).setAction(R.string.common_ok) {
190190
doRequest()
191-
}.also { viewThemeUtils.material.themeSnackbar(it) }.show()
191+
}.show()
192192
} else {
193193
// No explanation needed, request the permission.
194194
doRequest()

app/src/main/res/values-night/colors.xml

Lines changed: 64 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -39,4 +39,68 @@
3939
<color name="fontAppbar">@android:color/white</color>
4040

4141
<color name="actionbar_color">#101418</color>
42+
43+
<!-- NMC Colors -->
44+
<color name="icon_color">#FFFFFF</color>
45+
<color name="sort_text_color">@color/grey_30</color>
46+
<color name="list_icon_color">@color/grey_30</color>
47+
<color name="warning_icon_color">#CCCCCC</color>
48+
<color name="divider_color">@color/grey_70</color>
49+
<color name="spinner_bg_color">@color/grey_80</color>
50+
<color name="refresh_layout_bg_color">#2D2D2D</color>
51+
<color name="primary_button_disabled_color">@color/grey_70</color>
52+
<color name="toolbar_divider_color">@color/grey_70</color>
53+
54+
<!-- Snackbar Colors -->
55+
<color name="snackbar_bg_color">@color/grey_80</color>
56+
<color name="snackbar_txt_color">@color/grey_0</color>
57+
58+
<!-- Alert Dialog Colors -->
59+
<color name="alert_bg_color">@color/grey_80</color>
60+
<color name="alert_txt_color">@color/grey_0</color>
61+
62+
<!-- NavigationView colors -->
63+
<color name="nav_selected_bg_color">@color/grey_60</color>
64+
<color name="nav_txt_unselected_color">@color/grey_0</color>
65+
<color name="nav_txt_selected_color">@color/grey_0</color>
66+
<color name="nav_icon_unselected_color">@color/grey_30</color>
67+
<color name="nav_icon_selected_color">#FFFFFF</color>
68+
<color name="nav_divider_color">@color/grey_30</color>
69+
<color name="nav_bg_color">@color/grey_80</color>
70+
<color name="drawer_quota_txt_color">#FFFFFF</color>
71+
72+
<!-- Bottom Sheet Colors -->
73+
<color name="bottom_sheet_bg_color">@color/grey_80</color>
74+
<color name="bottom_sheet_icon_color">@color/grey_30</color>
75+
<color name="bottom_sheet_txt_color">@color/grey_0</color>
76+
77+
<!-- Popup Menu Colors -->
78+
<color name="popup_menu_bg">@color/grey_80</color>
79+
<color name="popup_menu_txt_color">@color/grey_0</color>
80+
<color name="overflow_bg_color">@color/grey_80</color>
81+
82+
<!-- Switch Compat Colors -->
83+
<color name="switch_thumb_disabled">@color/grey_70</color>
84+
<color name="switch_track_disabled">@color/grey_60</color>
85+
86+
<!-- Checkbox Colors -->
87+
<color name="checkbox_checked_disabled">@color/grey_70</color>
88+
<color name="checkbox_unchecked_disabled">@color/grey_70</color>
89+
90+
<!-- Share Colors -->
91+
<color name="share_title_txt_color">#FFFFFF</color>
92+
<color name="share_subtitle_txt_color">@color/grey_30</color>
93+
<color name="share_info_txt_color">@color/grey_0</color>
94+
<color name="share_search_border_color">@color/grey_0</color>
95+
<color name="share_btn_txt_color">@color/grey_0</color>
96+
<color name="share_list_item_txt_color">@color/grey_0</color>
97+
<color name="share_disabled_txt_color">@color/grey_60</color>
98+
<color name="share_txt_color">@color/grey_0</color>
99+
<color name="share_et_divider">#FFFFFF</color>
100+
101+
<!-- Scan Colors -->
102+
<color name="scan_doc_bg_color">#121212</color>
103+
<color name="scan_text_color">@color/grey_0</color>
104+
<color name="scan_edit_bottom_color">@color/grey_80</color>
105+
<color name="scan_count_bg_color">@color/grey_80</color>
42106
</resources>

app/src/main/res/values-night/themes.xml

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,10 @@
1919
<item name="windowActionBar">false</item>
2020
<item name="windowActionModeOverlay">true</item>
2121
<item name="windowNoTitle">true</item>
22+
<!-- SnackBar Styling -->
23+
<item name="snackbarStyle">@style/SnackBarBackgroundStyle</item>
24+
<item name="snackbarButtonStyle">@style/SnackBarActionButtonStyle</item>
25+
<item name="snackbarTextViewStyle">@style/SnackBarTextViewStyle</item>
2226
<item name="textInputStyle">@style/Widget.App.TextInputLayout</item>
2327
<item name="popupMenuStyle">@style/Nextcloud.Widget.PopupMenu</item>
2428
<item name="bottomSheetDialogTheme">@style/ThemeOverlay.App.BottomSheetDialog</item>

app/src/main/res/values/colors.xml

Lines changed: 89 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -78,4 +78,93 @@
7878
<color name="fontSecondaryAppbar">#A5A5A5</color>
7979

8080
<color name="actionbar_color">#F7F9FF</color>
81+
82+
<!-- NMC Colors -->
83+
<color name="icon_color">#191919</color>
84+
<color name="sort_text_color">@color/primary</color>
85+
<color name="list_icon_color">#191919</color>
86+
<color name="warning_icon_color">#191919</color>
87+
<color name="divider_color">@color/grey_30</color>
88+
<color name="spinner_bg_color">@android:color/white</color>
89+
<color name="refresh_layout_bg_color">#FFFFFF</color>
90+
<color name="primary_button_disabled_color">@color/grey_0</color>
91+
<color name="toolbar_divider_color">#CCCCCC</color>
92+
<color name="et_highlight_color">#77c4ff</color>
93+
<color name="white_trans_70">#B3FFFFFF</color>
94+
<color name="progress_bar_background">@color/grey_10</color>
95+
96+
<!-- Grey Colors -->
97+
<color name="dark_grey">#101010</color>
98+
<color name="grey_0">#F2F2F2</color>
99+
<color name="grey_10">#E5E5E5</color>
100+
<color name="grey_30">#B2B2B2</color>
101+
<color name="grey_60">#666666</color>
102+
<color name="grey_70">#4C4C4C</color>
103+
<color name="grey_80">#333333</color>
104+
105+
<!-- Snackbar Colors -->
106+
<color name="snackbar_bg_color">@color/design_snackbar_background_color</color>
107+
<color name="snackbar_txt_color">@color/white</color>
108+
109+
<!-- Alert Dialog Colors -->
110+
<color name="alert_bg_color">#FFFFFF</color>
111+
<color name="alert_txt_color">#191919</color>
112+
113+
<!-- NavigationView colors -->
114+
<color name="nav_selected_bg_color">@color/grey_0</color>
115+
<color name="nav_txt_unselected_color">#191919</color>
116+
<color name="nav_txt_selected_color">@color/primary</color>
117+
<color name="nav_icon_unselected_color">#191919</color>
118+
<color name="nav_icon_selected_color">@color/primary</color>
119+
<color name="nav_divider_color">@color/grey_30</color>
120+
<color name="nav_bg_color">@color/white</color>
121+
<color name="drawer_quota_txt_color">#191919</color>
122+
123+
<!-- Bottom Sheet Colors -->
124+
<color name="bottom_sheet_bg_color">#FFFFFF</color>
125+
<color name="bottom_sheet_icon_color">#191919</color>
126+
<color name="bottom_sheet_txt_color">#191919</color>
127+
128+
<!-- Popup Menu Colors -->
129+
<color name="popup_menu_bg">#FFFFFF</color>
130+
<color name="popup_menu_txt_color">#191919</color>
131+
<color name="overflow_bg_color">#FFFFFF</color>
132+
133+
<!-- Switch Compat Colors -->
134+
<color name="switch_thumb_checked_enabled">@color/primary</color>
135+
<color name="switch_track_checked_enabled">#F399C7</color>
136+
<color name="switch_thumb_unchecked_enabled">#FFFFFF</color>
137+
<color name="switch_track_unchecked_enabled">@color/grey_30</color>
138+
<color name="switch_thumb_disabled">@color/grey_10</color>
139+
<color name="switch_track_disabled">@color/grey_0</color>
140+
141+
<!-- Checkbox Colors -->
142+
<color name="checkbox_checked_enabled">@color/primary</color>
143+
<color name="checkbox_unchecked_enabled">@color/grey_30</color>
144+
<color name="checkbox_checked_disabled">@color/grey_30</color>
145+
<color name="checkbox_unchecked_disabled">#CCCCCC</color>
146+
147+
<!-- Share Colors -->
148+
<color name="share_title_txt_color">#191919</color>
149+
<color name="share_subtitle_txt_color">@color/grey_30</color>
150+
<color name="share_info_txt_color">#191919</color>
151+
<color name="share_search_border_color">#191919</color>
152+
<color name="share_btn_txt_color">#191919</color>
153+
<color name="share_list_item_txt_color">#191919</color>
154+
<color name="share_disabled_txt_color">@color/grey_30</color>
155+
<color name="share_txt_color">#191919</color>
156+
<color name="share_et_divider">#000000</color>
157+
<color name="share_warning_txt_color">#191919</color>
158+
<color name="sharing_warning_bg_color">#F6E5EB</color>
159+
<color name="sharing_warning_border_color">#C16F81</color>
160+
<color name="share_color">#0D39DF</color>
161+
<color name="shared_with_me_color">#0099ff</color>
162+
163+
<!-- Scan Colors -->
164+
<color name="scan_doc_bg_color">@color/grey_0</color>
165+
<color name="scan_text_color">#191919</color>
166+
<color name="scan_edit_bottom_color">@color/grey_0</color>
167+
<color name="scan_count_bg_color">@color/grey_30</color>
168+
<color name="neptune">#77b6bb</color>
169+
<color name="neptune_50">#5077b6bb</color>
81170
</resources>
Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
<?xml version="1.0" encoding="utf-8"?>
2+
<resources>
3+
4+
<style name="SnackBarBackgroundStyle" parent="Widget.Material3.Snackbar">
5+
<item name="android:backgroundTint">@color/snackbar_bg_color</item>
6+
<item name="backgroundTint">@color/snackbar_bg_color</item>
7+
</style>
8+
9+
<style name="SnackBarActionButtonStyle" parent="Widget.Material3.Button.TextButton.Snackbar">
10+
<item name="android:textColor">@color/white</item>
11+
</style>
12+
13+
<style name="SnackBarTextViewStyle" parent="Widget.Material3.Snackbar.TextView">
14+
<item name="android:textColor">@color/snackbar_txt_color</item>
15+
</style>
16+
</resources>

0 commit comments

Comments
 (0)