mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2024-08-30 18:12:39 +00:00
chore: mobile grid dark mode improvements (#4821)
* chore: field type grid * chore: don't allow hiding primary field * chore: bottom sheets * chore: checklist bottom sheet
This commit is contained in:
parent
c8e86f4f26
commit
ff8eb0d479
@ -20,6 +20,7 @@ class OptionColorList extends StatelessWidget {
|
|||||||
crossAxisCount: 6,
|
crossAxisCount: 6,
|
||||||
shrinkWrap: true,
|
shrinkWrap: true,
|
||||||
physics: const NeverScrollableScrollPhysics(),
|
physics: const NeverScrollableScrollPhysics(),
|
||||||
|
padding: EdgeInsets.zero,
|
||||||
children: SelectOptionColorPB.values.map(
|
children: SelectOptionColorPB.values.map(
|
||||||
(colorPB) {
|
(colorPB) {
|
||||||
final color = colorPB.toColor(context);
|
final color = colorPB.toColor(context);
|
||||||
|
@ -65,7 +65,7 @@ Future<T?> showMobileBottomSheet<T>(
|
|||||||
|
|
||||||
backgroundColor ??= Theme.of(context).brightness == Brightness.light
|
backgroundColor ??= Theme.of(context).brightness == Brightness.light
|
||||||
? const Color(0xFFF7F8FB)
|
? const Color(0xFFF7F8FB)
|
||||||
: const Color(0xFF626364);
|
: const Color(0xFF23262B);
|
||||||
|
|
||||||
return showModalBottomSheet<T>(
|
return showModalBottomSheet<T>(
|
||||||
context: context,
|
context: context,
|
||||||
|
@ -39,7 +39,7 @@ Future<T?> showTransitionMobileBottomSheet<T>(
|
|||||||
|
|
||||||
backgroundColor ??= Theme.of(context).brightness == Brightness.light
|
backgroundColor ??= Theme.of(context).brightness == Brightness.light
|
||||||
? const Color(0xFFF7F8FB)
|
? const Color(0xFFF7F8FB)
|
||||||
: const Color(0xFF626364);
|
: const Color(0xFF23262B);
|
||||||
|
|
||||||
return Navigator.of(
|
return Navigator.of(
|
||||||
context,
|
context,
|
||||||
|
@ -55,7 +55,7 @@ class _MobileDateCellEditScreenState extends State<MobileDateCellEditScreen> {
|
|||||||
minChildSize: 0.4,
|
minChildSize: 0.4,
|
||||||
snapSizes: const [0.4, 0.7, 1.0],
|
snapSizes: const [0.4, 0.7, 1.0],
|
||||||
builder: (_, controller) => Material(
|
builder: (_, controller) => Material(
|
||||||
color: Theme.of(context).colorScheme.secondaryContainer,
|
color: Colors.transparent,
|
||||||
child: ListView(
|
child: ListView(
|
||||||
controller: controller,
|
controller: controller,
|
||||||
children: [
|
children: [
|
||||||
|
@ -47,7 +47,9 @@ Future<FieldType?> showFieldTypeGridBottomSheet(
|
|||||||
.map(
|
.map(
|
||||||
(fieldType) => TypeOptionMenuItemValue(
|
(fieldType) => TypeOptionMenuItemValue(
|
||||||
value: fieldType,
|
value: fieldType,
|
||||||
backgroundColor: fieldType.mobileIconBackgroundColor,
|
backgroundColor: Theme.of(context).brightness == Brightness.light
|
||||||
|
? fieldType.mobileIconBackgroundColor
|
||||||
|
: fieldType.mobileIconBackgroundColorDark,
|
||||||
text: fieldType.i18n,
|
text: fieldType.i18n,
|
||||||
icon: fieldType.svgData,
|
icon: fieldType.svgData,
|
||||||
onTap: (context, fieldType) =>
|
onTap: (context, fieldType) =>
|
||||||
@ -121,7 +123,6 @@ void showQuickEditField(
|
|||||||
) {
|
) {
|
||||||
showMobileBottomSheet(
|
showMobileBottomSheet(
|
||||||
context,
|
context,
|
||||||
backgroundColor: Theme.of(context).colorScheme.secondaryContainer,
|
|
||||||
showDragHandle: true,
|
showDragHandle: true,
|
||||||
builder: (context) {
|
builder: (context) {
|
||||||
return SingleChildScrollView(
|
return SingleChildScrollView(
|
||||||
|
@ -208,7 +208,9 @@ class _MobileFieldEditorState extends State<MobileFieldEditor> {
|
|||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final option = _buildOption();
|
final option = _buildOption();
|
||||||
return Container(
|
return Container(
|
||||||
color: Theme.of(context).colorScheme.secondaryContainer,
|
color: Theme.of(context).brightness == Brightness.light
|
||||||
|
? const Color(0xFFF7F8FB)
|
||||||
|
: const Color(0xFF23262B),
|
||||||
height: MediaQuery.of(context).size.height,
|
height: MediaQuery.of(context).size.height,
|
||||||
child: SingleChildScrollView(
|
child: SingleChildScrollView(
|
||||||
child: Column(
|
child: Column(
|
||||||
@ -259,6 +261,7 @@ class _MobileFieldEditorState extends State<MobileFieldEditor> {
|
|||||||
],
|
],
|
||||||
..._buildOptionActions(),
|
..._buildOptionActions(),
|
||||||
const _Divider(),
|
const _Divider(),
|
||||||
|
VSpace(MediaQuery.viewPaddingOf(context).bottom == 0 ? 28.0 : 16.0),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
@ -351,7 +354,7 @@ class _MobileFieldEditorState extends State<MobileFieldEditor> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return [
|
return [
|
||||||
if (widget.actions.contains(FieldOptionAction.hide))
|
if (widget.actions.contains(FieldOptionAction.hide) && !widget.isPrimary)
|
||||||
FlowyOptionTile.text(
|
FlowyOptionTile.text(
|
||||||
text: LocaleKeys.grid_field_hide.tr(),
|
text: LocaleKeys.grid_field_hide.tr(),
|
||||||
leftIcon: const FlowySvg(FlowySvgs.m_field_hide_s),
|
leftIcon: const FlowySvg(FlowySvgs.m_field_hide_s),
|
||||||
|
@ -87,7 +87,11 @@ class _DatabaseViewSelectorButton extends StatelessWidget {
|
|||||||
borderRadius: BorderRadius.all(Radius.circular(12)),
|
borderRadius: BorderRadius.all(Radius.circular(12)),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
backgroundColor: const MaterialStatePropertyAll(Color(0x0F212729)),
|
backgroundColor: MaterialStatePropertyAll(
|
||||||
|
Theme.of(context).brightness == Brightness.light
|
||||||
|
? const Color(0x0F212729)
|
||||||
|
: const Color(0x0FFFFFFF),
|
||||||
|
),
|
||||||
overlayColor: MaterialStatePropertyAll(
|
overlayColor: MaterialStatePropertyAll(
|
||||||
Theme.of(context).colorScheme.secondary,
|
Theme.of(context).colorScheme.secondary,
|
||||||
),
|
),
|
||||||
|
@ -39,7 +39,6 @@ class MobileGridChecklistCellSkin extends IEditableChecklistCellSkin {
|
|||||||
),
|
),
|
||||||
onTap: () => showMobileBottomSheet(
|
onTap: () => showMobileBottomSheet(
|
||||||
context,
|
context,
|
||||||
backgroundColor: Theme.of(context).colorScheme.background,
|
|
||||||
builder: (context) {
|
builder: (context) {
|
||||||
return BlocProvider.value(
|
return BlocProvider.value(
|
||||||
value: bloc,
|
value: bloc,
|
||||||
|
@ -44,7 +44,6 @@ class MobileGridDateCellSkin extends IEditableDateCellSkin {
|
|||||||
onTap: () {
|
onTap: () {
|
||||||
showMobileBottomSheet(
|
showMobileBottomSheet(
|
||||||
context,
|
context,
|
||||||
backgroundColor: Theme.of(context).colorScheme.secondaryContainer,
|
|
||||||
builder: (context) {
|
builder: (context) {
|
||||||
return MobileDateCellEditScreen(
|
return MobileDateCellEditScreen(
|
||||||
controller: bloc.cellController,
|
controller: bloc.cellController,
|
||||||
|
@ -230,7 +230,7 @@ class _ChecklistItemState extends State<_ChecklistItem> {
|
|||||||
void _showDeleteTaskBottomSheet() {
|
void _showDeleteTaskBottomSheet() {
|
||||||
showMobileBottomSheet(
|
showMobileBottomSheet(
|
||||||
context,
|
context,
|
||||||
padding: const EdgeInsets.only(top: 8, bottom: 32),
|
showDragHandle: true,
|
||||||
builder: (_) => Column(
|
builder: (_) => Column(
|
||||||
mainAxisSize: MainAxisSize.min,
|
mainAxisSize: MainAxisSize.min,
|
||||||
children: [
|
children: [
|
||||||
|
@ -421,7 +421,6 @@ class _MoreOptionsState extends State<_MoreOptions> {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final color = Theme.of(context).colorScheme.secondaryContainer;
|
|
||||||
return SingleChildScrollView(
|
return SingleChildScrollView(
|
||||||
child: Column(
|
child: Column(
|
||||||
crossAxisAlignment: CrossAxisAlignment.start,
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
@ -432,22 +431,18 @@ class _MoreOptionsState extends State<_MoreOptions> {
|
|||||||
const VSpace(16.0),
|
const VSpace(16.0),
|
||||||
Padding(
|
Padding(
|
||||||
padding: const EdgeInsets.only(left: 12.0),
|
padding: const EdgeInsets.only(left: 12.0),
|
||||||
child: ColoredBox(
|
|
||||||
color: color,
|
|
||||||
child: FlowyText(
|
child: FlowyText(
|
||||||
LocaleKeys.grid_selectOption_colorPanelTitle.tr().toUpperCase(),
|
LocaleKeys.grid_selectOption_colorPanelTitle.tr().toUpperCase(),
|
||||||
color: Theme.of(context).hintColor,
|
color: Theme.of(context).hintColor,
|
||||||
fontSize: 13,
|
fontSize: 13,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
|
||||||
const VSpace(4.0),
|
const VSpace(4.0),
|
||||||
FlowyOptionDecorateBox(
|
FlowyOptionDecorateBox(
|
||||||
child: Padding(
|
child: Padding(
|
||||||
padding: const EdgeInsets.only(
|
padding: const EdgeInsets.symmetric(
|
||||||
top: 12.0,
|
vertical: 12.0,
|
||||||
left: 6.0,
|
horizontal: 6.0,
|
||||||
right: 6.0,
|
|
||||||
),
|
),
|
||||||
child: OptionColorList(
|
child: OptionColorList(
|
||||||
selectedColor: option.color,
|
selectedColor: option.color,
|
||||||
|
@ -147,7 +147,6 @@ void _showEditSortPanelFromToolbar(
|
|||||||
) {
|
) {
|
||||||
showMobileBottomSheet(
|
showMobileBottomSheet(
|
||||||
context,
|
context,
|
||||||
backgroundColor: Theme.of(context).colorScheme.surface,
|
|
||||||
showDragHandle: true,
|
showDragHandle: true,
|
||||||
showDivider: false,
|
showDivider: false,
|
||||||
useSafeArea: false,
|
useSafeArea: false,
|
||||||
|
@ -42,14 +42,30 @@ extension FieldTypeExtension on FieldType {
|
|||||||
Color get mobileIconBackgroundColor => switch (this) {
|
Color get mobileIconBackgroundColor => switch (this) {
|
||||||
FieldType.RichText => const Color(0xFFBECCFF),
|
FieldType.RichText => const Color(0xFFBECCFF),
|
||||||
FieldType.Number => const Color(0xFFCABDFF),
|
FieldType.Number => const Color(0xFFCABDFF),
|
||||||
FieldType.DateTime => const Color(0xFFFDEDA7),
|
FieldType.URL => const Color(0xFFFFB9EF),
|
||||||
FieldType.SingleSelect => const Color(0xFFBECCFF),
|
FieldType.SingleSelect => const Color(0xFFBECCFF),
|
||||||
FieldType.MultiSelect => const Color(0xFFBECCFF),
|
FieldType.MultiSelect => const Color(0xFFBECCFF),
|
||||||
FieldType.URL => const Color(0xFFFFB9EF),
|
FieldType.DateTime => const Color(0xFFFDEDA7),
|
||||||
FieldType.Checkbox => const Color(0xFF98F4CD),
|
|
||||||
FieldType.Checklist => const Color(0xFF98F4CD),
|
|
||||||
FieldType.LastEditedTime => const Color(0xFFFDEDA7),
|
FieldType.LastEditedTime => const Color(0xFFFDEDA7),
|
||||||
FieldType.CreatedTime => const Color(0xFFFDEDA7),
|
FieldType.CreatedTime => const Color(0xFFFDEDA7),
|
||||||
|
FieldType.Checkbox => const Color(0xFF98F4CD),
|
||||||
|
FieldType.Checklist => const Color(0xFF98F4CD),
|
||||||
|
FieldType.Relation => const Color(0xFFFDEDA7),
|
||||||
|
_ => throw UnimplementedError(),
|
||||||
|
};
|
||||||
|
|
||||||
|
// TODO(RS): inner icon color isn't always white
|
||||||
|
Color get mobileIconBackgroundColorDark => switch (this) {
|
||||||
|
FieldType.RichText => const Color(0xFF6859A7),
|
||||||
|
FieldType.Number => const Color(0xFF6859A7),
|
||||||
|
FieldType.URL => const Color(0xFFA75C96),
|
||||||
|
FieldType.SingleSelect => const Color(0xFF5366AB),
|
||||||
|
FieldType.MultiSelect => const Color(0xFF5366AB),
|
||||||
|
FieldType.DateTime => const Color(0xFFB0A26D),
|
||||||
|
FieldType.LastEditedTime => const Color(0xFFB0A26D),
|
||||||
|
FieldType.CreatedTime => const Color(0xFFB0A26D),
|
||||||
|
FieldType.Checkbox => const Color(0xFF42AD93),
|
||||||
|
FieldType.Checklist => const Color(0xFF42AD93),
|
||||||
FieldType.Relation => const Color(0xFFFDEDA7),
|
FieldType.Relation => const Color(0xFFFDEDA7),
|
||||||
_ => throw UnimplementedError(),
|
_ => throw UnimplementedError(),
|
||||||
};
|
};
|
||||||
|
@ -74,10 +74,9 @@ class MobileAppearance extends BaseAppearance {
|
|||||||
outline: _hintColorInDarkMode,
|
outline: _hintColorInDarkMode,
|
||||||
outlineVariant: Colors.black,
|
outlineVariant: Colors.black,
|
||||||
//Snack bar
|
//Snack bar
|
||||||
surface: const Color(0xff2F3030),
|
surface: const Color(0xFF171A1F),
|
||||||
onSurface: const Color(0xffC5C6C7), // text/body color
|
onSurface: const Color(0xffC5C6C7), // text/body color
|
||||||
);
|
);
|
||||||
|
|
||||||
final hintColor = brightness == Brightness.light
|
final hintColor = brightness == Brightness.light
|
||||||
? const Color(0x991F2329)
|
? const Color(0x991F2329)
|
||||||
: _hintColorInDarkMode;
|
: _hintColorInDarkMode;
|
||||||
|
Loading…
Reference in New Issue
Block a user