mirror of
https://github.com/vodemn/m3_lightmeter.git
synced 2024-10-19 14:50:40 +00:00
9cfffc3377
* wip * hide `DynamicColorListTile` if unavailable * added color animation for `AnimatedDialog` * adjusted some colors * sync `AnimatedDialog` insets with material * scroll to selected color
40 lines
1.2 KiB
Dart
40 lines
1.2 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
|
import 'package:lightmeter/data/models/dynamic_colors_state.dart';
|
|
import 'package:lightmeter/generated/l10n.dart';
|
|
import 'package:lightmeter/providers/theme_provider.dart';
|
|
|
|
import 'components/primary_color_picker_dialog/widget_dialog_picker_primary_color.dart';
|
|
|
|
class PrimaryColorListTile extends StatelessWidget {
|
|
const PrimaryColorListTile({super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
if (context.watch<DynamicColorState>() == DynamicColorState.enabled) {
|
|
return Opacity(
|
|
opacity: 0.5,
|
|
child: IgnorePointer(
|
|
child: ListTile(
|
|
leading: const Icon(Icons.palette),
|
|
title: Text(S.of(context).primaryColor),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
return ListTile(
|
|
leading: const Icon(Icons.palette),
|
|
title: Text(S.of(context).primaryColor),
|
|
onTap: () {
|
|
showDialog<Color>(
|
|
context: context,
|
|
builder: (_) => const PrimaryColorDialogPicker(),
|
|
).then((value) {
|
|
if (value != null) {
|
|
ThemeProvider.of(context).setPrimaryColor(value);
|
|
}
|
|
});
|
|
},
|
|
);
|
|
}
|
|
}
|