Skip to content

Commit

Permalink
Customized dialog theme.
Browse files Browse the repository at this point in the history
  • Loading branch information
surinder-tsys committed Oct 19, 2023
1 parent def5dba commit 0988c97
Show file tree
Hide file tree
Showing 31 changed files with 298 additions and 199 deletions.
30 changes: 30 additions & 0 deletions app/src/main/java/com/nmc/android/utils/DialogThemeUtils.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
package com.nmc.android.utils

import android.content.Context
import android.content.res.ColorStateList
import android.os.Build
import com.google.android.material.dialog.MaterialAlertDialogBuilder
import com.google.android.material.shape.MaterialShapeDrawable
import com.owncloud.android.R

object DialogThemeUtils {
fun colorMaterialAlertDialogBackground(context: Context, dialogBuilder: MaterialAlertDialogBuilder) {
val materialShapeDrawable = MaterialShapeDrawable(
context,
null,
R.attr.alertDialogStyle,
R.style.MaterialAlertDialog_MaterialComponents
)
materialShapeDrawable.initializeElevationOverlay(context)
materialShapeDrawable.fillColor =
ColorStateList.valueOf(context.resources.getColor(R.color.alert_bg_color, null))

// dialogCornerRadius first appeared in Android Pie
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.P) {
val radius: Float =
context.resources.getDimension(com.nextcloud.android.common.ui.R.dimen.dialogBorderRadius)
materialShapeDrawable.setCornerSize(radius)
}
dialogBuilder.background = materialShapeDrawable
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -816,11 +816,8 @@ class SyncedFoldersActivity :
.setNeutralButton(getString(R.string.battery_optimization_close)) { dialog, _ -> dialog.dismiss() }
.setIcon(R.drawable.ic_battery_alert)
if (lifecycle.currentState.isAtLeast(Lifecycle.State.RESUMED)) {
val alertDialog = alertDialogBuilder.show()
viewThemeUtils.platform.colorTextButtons(
alertDialog.getButton(AlertDialog.BUTTON_POSITIVE),
alertDialog.getButton(AlertDialog.BUTTON_NEUTRAL)
)
//NMC Customization
alertDialogBuilder.show()
}
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,19 +25,18 @@
import android.app.Dialog;
import android.os.Bundle;

import com.google.android.material.button.MaterialButton;
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
import com.nextcloud.client.account.User;
import com.nextcloud.client.di.Injectable;
import com.nextcloud.client.jobs.BackgroundJobManager;
import com.nmc.android.utils.DialogThemeUtils;
import com.owncloud.android.R;
import com.owncloud.android.utils.theme.ViewThemeUtils;

import javax.inject.Inject;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.appcompat.app.AlertDialog;
import androidx.fragment.app.DialogFragment;

public class AccountRemovalConfirmationDialog extends DialogFragment implements Injectable {
Expand Down Expand Up @@ -67,25 +66,6 @@ public void onCreate(@Nullable Bundle savedInstanceState) {
}
}

@Override
public void onStart() {
super.onStart();

AlertDialog alertDialog = (AlertDialog) getDialog();
if (alertDialog != null) {

MaterialButton positiveButton = (MaterialButton) alertDialog.getButton(AlertDialog.BUTTON_POSITIVE);
if (positiveButton != null) {
viewThemeUtils.material.colorMaterialButtonPrimaryTonal(positiveButton);
}

MaterialButton negativeButton = (MaterialButton) alertDialog.getButton(AlertDialog.BUTTON_NEGATIVE);
if (negativeButton != null) {
viewThemeUtils.material.colorMaterialButtonPrimaryBorderless(negativeButton);
}
}
}

@NonNull
@Override
public Dialog onCreateDialog(Bundle savedInstanceState) {
Expand All @@ -98,7 +78,8 @@ public Dialog onCreateDialog(Bundle savedInstanceState) {
false))
.setNegativeButton(R.string.common_cancel, null);

viewThemeUtils.dialog.colorMaterialAlertDialogBackground(requireActivity(), builder);
//NMC customization
DialogThemeUtils.INSTANCE.colorMaterialAlertDialogBackground(requireActivity(), builder);

return builder.create();
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@
import com.nextcloud.client.account.User;
import com.nextcloud.client.di.Injectable;
import com.nextcloud.client.network.ClientFactory;
import com.nmc.android.utils.DialogThemeUtils;
import com.owncloud.android.MainApp;
import com.owncloud.android.R;
import com.owncloud.android.databinding.ChooseTemplateBinding;
Expand Down Expand Up @@ -129,17 +130,9 @@ public void onStart() {

if (alertDialog != null) {
positiveButton = (MaterialButton) alertDialog.getButton(AlertDialog.BUTTON_POSITIVE);
viewThemeUtils.material.colorMaterialButtonPrimaryTonal(positiveButton);

MaterialButton negativeButton = (MaterialButton) alertDialog.getButton(AlertDialog.BUTTON_NEGATIVE);
if (negativeButton != null) {
viewThemeUtils.material.colorMaterialButtonPrimaryBorderless(negativeButton);
}

positiveButton.setOnClickListener(this);
positiveButton.setEnabled(false);
}

checkEnablingCreateButton();
}

Expand Down Expand Up @@ -181,8 +174,6 @@ public Dialog onCreateDialog(Bundle savedInstanceState) {
binding = ChooseTemplateBinding.inflate(inflater, null, false);
View view = binding.getRoot();

viewThemeUtils.material.colorTextInputLayout(binding.filenameContainer);

Type type = Type.valueOf(arguments.getString(ARG_TYPE));
new FetchTemplateTask(this, client).execute(type);

Expand Down Expand Up @@ -222,7 +213,8 @@ public void afterTextChanged(Editable s) {
.setNegativeButton(R.string.common_cancel, null)
.setTitle(titleTextId);

viewThemeUtils.dialog.colorMaterialAlertDialogBackground(activity, builder);
//NMC customization
DialogThemeUtils.INSTANCE.colorMaterialAlertDialogBackground(activity, builder);

return builder.create();
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ import com.nextcloud.client.account.User
import com.nextcloud.client.di.Injectable
import com.nextcloud.client.network.ClientFactory
import com.nextcloud.client.network.ClientFactory.CreationException
import com.nmc.android.utils.DialogThemeUtils
import com.owncloud.android.MainApp
import com.owncloud.android.R
import com.owncloud.android.databinding.ChooseTemplateBinding
Expand Down Expand Up @@ -105,10 +106,6 @@ class ChooseTemplateDialogFragment : DialogFragment(), View.OnClickListener, Tem
val alertDialog = dialog as AlertDialog
val button = alertDialog.getButton(AlertDialog.BUTTON_POSITIVE)

viewThemeUtils.platform.colorTextButtons(
button,
alertDialog.getButton(AlertDialog.BUTTON_NEUTRAL)
)
button.setOnClickListener(this)
button.isEnabled = false
button.isClickable = false
Expand Down Expand Up @@ -141,10 +138,6 @@ class ChooseTemplateDialogFragment : DialogFragment(), View.OnClickListener, Tem
_binding = ChooseTemplateBinding.inflate(inflater, null, false)
val view: View = binding.root

viewThemeUtils.material.colorTextInputLayout(
binding.filenameContainer
)

binding.filename.addTextChangedListener(object : TextWatcher {
override fun beforeTextChanged(s: CharSequence, start: Int, count: Int, after: Int) = Unit

Expand Down Expand Up @@ -178,7 +171,8 @@ class ChooseTemplateDialogFragment : DialogFragment(), View.OnClickListener, Tem
.setNeutralButton(R.string.common_cancel, null)
.setTitle(title)

viewThemeUtils.dialog.colorMaterialAlertDialogBackground(binding.list.context, builder)
//NMC customization
DialogThemeUtils.colorMaterialAlertDialogBackground(binding.list.context, builder)

return builder.create()
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,13 +22,13 @@

import com.google.android.material.dialog.MaterialAlertDialogBuilder;
import com.nextcloud.client.di.Injectable;
import com.nmc.android.utils.DialogThemeUtils;
import com.owncloud.android.R;
import com.owncloud.android.utils.theme.ViewThemeUtils;

import javax.inject.Inject;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AlertDialog;
import androidx.fragment.app.DialogFragment;


Expand Down Expand Up @@ -78,19 +78,6 @@ public static ConfirmationDialogFragment newInstance(int messageResId, String[]
return frag;
}

@Override
public void onStart() {
super.onStart();

AlertDialog alertDialog = (AlertDialog) getDialog();

if(alertDialog != null) {
viewThemeUtils.platform.colorTextButtons(alertDialog.getButton(AlertDialog.BUTTON_POSITIVE),
alertDialog.getButton(AlertDialog.BUTTON_NEGATIVE),
alertDialog.getButton(AlertDialog.BUTTON_NEUTRAL));
}
}

public void setOnConfirmationListener(ConfirmationDialogFragmentListener listener) {
mListener = listener;
}
Expand Down Expand Up @@ -157,7 +144,8 @@ public Dialog onCreateDialog(Bundle savedInstanceState) {
});
}

viewThemeUtils.dialog.colorMaterialAlertDialogBackground(activity, builder);
//NMC customization
DialogThemeUtils.INSTANCE.colorMaterialAlertDialogBackground(activity, builder);

return builder.create();
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
import com.google.common.collect.Sets;
import com.nextcloud.client.di.Injectable;
import com.nmc.android.utils.DialogThemeUtils;
import com.owncloud.android.R;
import com.owncloud.android.databinding.EditBoxDialogBinding;
import com.owncloud.android.datamodel.FileDataStorageManager;
Expand Down Expand Up @@ -104,9 +105,6 @@ private void bindButton() {

if (dialog instanceof AlertDialog alertDialog) {
positiveButton = (MaterialButton) alertDialog.getButton(AlertDialog.BUTTON_POSITIVE);
MaterialButton negativeButton = (MaterialButton) alertDialog.getButton(AlertDialog.BUTTON_NEGATIVE);
viewThemeUtils.material.colorMaterialButtonPrimaryTonal(positiveButton);
viewThemeUtils.material.colorMaterialButtonPrimaryBorderless(negativeButton);
}
}

Expand All @@ -130,7 +128,6 @@ public Dialog onCreateDialog(Bundle savedInstanceState) {

// Setup layout
binding.userInput.setText("");
viewThemeUtils.material.colorTextInputLayout(binding.userInputContainer);

OCFile parentFolder = requireArguments().getParcelable(ARG_PARENT_FOLDER);
List<OCFile> folderContent = fileDataStorageManager.getFolderContent(parentFolder, false);
Expand Down Expand Up @@ -187,7 +184,8 @@ public void onTextChanged(CharSequence s, int start, int before, int count) {
// Build the dialog
MaterialAlertDialogBuilder builder = buildMaterialAlertDialog(view);

viewThemeUtils.dialog.colorMaterialAlertDialogBackground(binding.userInputContainer.getContext(), builder);
//NMC customization
DialogThemeUtils.INSTANCE.colorMaterialAlertDialogBackground(binding.userInputContainer.getContext(), builder);

return builder.create();
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -86,20 +86,10 @@ public void onStart() {
if (currentDialog != null) {
final DatePickerDialog dialog = (DatePickerDialog) currentDialog;

MaterialButton positiveButton = (MaterialButton) dialog.getButton(DatePickerDialog.BUTTON_POSITIVE);
if (positiveButton != null) {
viewThemeUtils.material.colorMaterialButtonPrimaryTonal(positiveButton);
}

MaterialButton negativeButton = (MaterialButton) dialog.getButton(DatePickerDialog.BUTTON_NEGATIVE);
if (negativeButton != null) {
viewThemeUtils.material.colorMaterialButtonPrimaryBorderless(negativeButton);
}

MaterialButton neutralButton = (MaterialButton) dialog.getButton(DatePickerDialog.BUTTON_NEUTRAL);
if (neutralButton != null) {
viewThemeUtils.material.colorMaterialButtonPrimaryBorderless(neutralButton);
}
//NMC Customization
dialog.getButton(DatePickerDialog.BUTTON_NEUTRAL).setTextColor(getResources().getColor(R.color.text_color, null));
dialog.getButton(DatePickerDialog.BUTTON_NEGATIVE).setTextColor(getResources().getColor(R.color.text_color, null));
dialog.getButton(DatePickerDialog.BUTTON_POSITIVE).setTextColor(getResources().getColor(R.color.primary, null));
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,9 @@ public Dialog onCreateDialog(Bundle savedInstanceState) {
progressDialog.setIndeterminate(true);
progressDialog.setOnShowListener(dialog -> {
ProgressBar v = progressDialog.findViewById(android.R.id.progress);
viewThemeUtils.platform.tintDrawable(requireContext(), v.getIndeterminateDrawable());
//NMC Customization
viewThemeUtils.platform.colorDrawable(v.getIndeterminateDrawable(),
requireContext().getResources().getColor(R.color.white, null));
});

/// set message
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
package com.owncloud.android.ui.dialog;

import android.app.Dialog;
import android.graphics.PorterDuff;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
Expand Down Expand Up @@ -65,7 +66,8 @@ public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle sa

// set progress wheel color
ProgressBar progressBar = v.findViewById(R.id.loadingBar);
viewThemeUtils.platform.tintDrawable(requireContext(), progressBar.getIndeterminateDrawable());
//NMC Customisation
progressBar.getIndeterminateDrawable().setColorFilter(getResources().getColor(R.color.primary, null), PorterDuff.Mode.SRC_IN);

return v;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@

import com.google.android.material.dialog.MaterialAlertDialogBuilder;
import com.nextcloud.client.di.Injectable;
import com.nmc.android.utils.DialogThemeUtils;
import com.owncloud.android.R;
import com.owncloud.android.databinding.StoragePathDialogBinding;
import com.owncloud.android.ui.adapter.StoragePathAdapter;
Expand Down Expand Up @@ -74,17 +75,6 @@ public static LocalStoragePathPickerDialogFragment newInstance() {
return new LocalStoragePathPickerDialogFragment();
}

@Override
public void onStart() {
super.onStart();

AlertDialog alertDialog = (AlertDialog) getDialog();

if (alertDialog != null) {
viewThemeUtils.platform.colorTextButtons(alertDialog.getButton(AlertDialog.BUTTON_NEGATIVE));
}
}

@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Expand All @@ -111,10 +101,12 @@ public Dialog onCreateDialog(Bundle savedInstanceState) {
// Build the dialog
MaterialAlertDialogBuilder builder = new MaterialAlertDialogBuilder(binding.getRoot().getContext());
builder.setView(view)
.setNegativeButton(R.string.common_cancel, this)
//NMC customisation to show primary color
.setPositiveButton(R.string.common_cancel, this)
.setTitle(R.string.storage_choose_location);

viewThemeUtils.dialog.colorMaterialAlertDialogBackground(binding.getRoot().getContext(), builder);
//NMC customization
DialogThemeUtils.INSTANCE.colorMaterialAlertDialogBackground(binding.getRoot().getContext(), builder);

return builder.create();
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,6 @@
import java.util.Collection;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AlertDialog;

/**
* Dialog requiring confirmation before removing a collection of given OCFiles.
Expand Down Expand Up @@ -130,26 +129,6 @@ public static RemoveFilesDialogFragment newInstance(OCFile file) {
return newInstance(list);
}

@Override
public void onStart() {
super.onStart();

AlertDialog alertDialog = (AlertDialog) getDialog();

if (alertDialog != null) {
MaterialButton positiveButton = (MaterialButton) alertDialog.getButton(AlertDialog.BUTTON_POSITIVE);
viewThemeUtils.material.colorMaterialButtonPrimaryTonal(positiveButton);

MaterialButton negativeButton = (MaterialButton) alertDialog.getButton(AlertDialog.BUTTON_NEGATIVE);
viewThemeUtils.material.colorMaterialButtonPrimaryBorderless(negativeButton);

MaterialButton neutralButton = (MaterialButton) alertDialog.getButton(AlertDialog.BUTTON_NEUTRAL);
if (neutralButton != null) {
viewThemeUtils.material.colorMaterialButtonPrimaryBorderless(neutralButton);
}
}
}

@NonNull
@Override
public Dialog onCreateDialog(Bundle savedInstanceState) {
Expand Down
Loading

0 comments on commit 0988c97

Please sign in to comment.