mirror of
https://github.com/vodemn/m3_lightmeter.git
synced 2025-01-18 19:30:43 +00:00
added some mock tiles to settings
This commit is contained in:
parent
6b3be40254
commit
6dd0a9b192
8 changed files with 122 additions and 7 deletions
|
@ -22,7 +22,11 @@ class MessageLookup extends MessageLookupByLibrary {
|
|||
|
||||
final messages = _notInlinedMessages(_notInlinedMessages);
|
||||
static Map<String, Function> _notInlinedMessages(_) => <String, Function>{
|
||||
"caffeine": MessageLookupByLibrary.simpleMessage("Caffeine"),
|
||||
"fastestExposurePair": MessageLookupByLibrary.simpleMessage("Fastest"),
|
||||
"haptics": MessageLookupByLibrary.simpleMessage("Haptics"),
|
||||
"keepsScreenOn":
|
||||
MessageLookupByLibrary.simpleMessage("Keeps screen on"),
|
||||
"settings": MessageLookupByLibrary.simpleMessage("Settings"),
|
||||
"slowestExposurePair": MessageLookupByLibrary.simpleMessage("Slowest")
|
||||
};
|
||||
|
|
|
@ -79,6 +79,36 @@ class S {
|
|||
args: [],
|
||||
);
|
||||
}
|
||||
|
||||
/// `Caffeine`
|
||||
String get caffeine {
|
||||
return Intl.message(
|
||||
'Caffeine',
|
||||
name: 'caffeine',
|
||||
desc: '',
|
||||
args: [],
|
||||
);
|
||||
}
|
||||
|
||||
/// `Keeps screen on`
|
||||
String get keepsScreenOn {
|
||||
return Intl.message(
|
||||
'Keeps screen on',
|
||||
name: 'keepsScreenOn',
|
||||
desc: '',
|
||||
args: [],
|
||||
);
|
||||
}
|
||||
|
||||
/// `Haptics`
|
||||
String get haptics {
|
||||
return Intl.message(
|
||||
'Haptics',
|
||||
name: 'haptics',
|
||||
desc: '',
|
||||
args: [],
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
class AppLocalizationDelegate extends LocalizationsDelegate<S> {
|
||||
|
|
|
@ -2,5 +2,8 @@
|
|||
"@@locale": "en",
|
||||
"fastestExposurePair": "Fastest",
|
||||
"slowestExposurePair": "Slowest",
|
||||
"settings": "Settings"
|
||||
"settings": "Settings",
|
||||
"caffeine": "Caffeine",
|
||||
"keepsScreenOn": "Keeps screen on",
|
||||
"haptics": "Haptics"
|
||||
}
|
|
@ -7,6 +7,7 @@ import 'models/photography_value.dart';
|
|||
import 'res/theme.dart';
|
||||
import 'screens/metering/metering_bloc.dart';
|
||||
import 'screens/metering/metering_screen.dart';
|
||||
import 'screens/settings/settings_screen.dart';
|
||||
import 'utils/stop_type_provider.dart';
|
||||
|
||||
void main() {
|
||||
|
@ -34,7 +35,7 @@ class MyApp extends StatelessWidget {
|
|||
GlobalCupertinoLocalizations.delegate,
|
||||
],
|
||||
supportedLocales: S.delegate.supportedLocales,
|
||||
home: const MeteringScreen(),
|
||||
home: const SettingsScreen(),
|
||||
),
|
||||
),
|
||||
);
|
||||
|
|
28
lib/screens/settings/components/caffeine_tile.dart
Normal file
28
lib/screens/settings/components/caffeine_tile.dart
Normal file
|
@ -0,0 +1,28 @@
|
|||
import 'package:flutter/material.dart';
|
||||
import 'package:lightmeter/generated/l10n.dart';
|
||||
|
||||
class CaffeineListTile extends StatefulWidget {
|
||||
const CaffeineListTile({super.key});
|
||||
|
||||
@override
|
||||
State<CaffeineListTile> createState() => _CaffeineListTileState();
|
||||
}
|
||||
|
||||
class _CaffeineListTileState extends State<CaffeineListTile> {
|
||||
bool _isCaffeineOn = false;
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return SwitchListTile(
|
||||
secondary: const Icon(Icons.coffee),
|
||||
title: Text(S.of(context).caffeine),
|
||||
subtitle: Text(S.of(context).keepsScreenOn),
|
||||
value: _isCaffeineOn,
|
||||
onChanged: (value) {
|
||||
setState(() {
|
||||
_isCaffeineOn = value;
|
||||
});
|
||||
},
|
||||
);
|
||||
}
|
||||
}
|
27
lib/screens/settings/components/haptics_tile.dart
Normal file
27
lib/screens/settings/components/haptics_tile.dart
Normal file
|
@ -0,0 +1,27 @@
|
|||
import 'package:flutter/material.dart';
|
||||
import 'package:lightmeter/generated/l10n.dart';
|
||||
|
||||
class HapticsListTile extends StatefulWidget {
|
||||
const HapticsListTile({super.key});
|
||||
|
||||
@override
|
||||
State<HapticsListTile> createState() => _HapticsListTileState();
|
||||
}
|
||||
|
||||
class _HapticsListTileState extends State<HapticsListTile> {
|
||||
bool _value = false;
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return SwitchListTile(
|
||||
secondary: const Icon(Icons.vibration),
|
||||
title: Text(S.of(context).haptics),
|
||||
value: _value,
|
||||
onChanged: (value) {
|
||||
setState(() {
|
||||
_value = value;
|
||||
});
|
||||
},
|
||||
);
|
||||
}
|
||||
}
|
12
lib/screens/settings/components/stop_type_tile.dart
Normal file
12
lib/screens/settings/components/stop_type_tile.dart
Normal file
|
@ -0,0 +1,12 @@
|
|||
import 'package:flutter/material.dart';
|
||||
|
||||
class StopTypeTile extends StatelessWidget {
|
||||
const StopTypeTile({super.key});
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return ListTile(
|
||||
leading: const Icon(Icons.rule),
|
||||
);
|
||||
}
|
||||
}
|
|
@ -1,4 +1,9 @@
|
|||
import 'package:flutter/material.dart';
|
||||
import 'package:lightmeter/generated/l10n.dart';
|
||||
import 'package:lightmeter/res/dimens.dart';
|
||||
|
||||
import 'components/caffeine_tile.dart';
|
||||
import 'components/haptics_tile.dart';
|
||||
|
||||
class SettingsScreen extends StatelessWidget {
|
||||
const SettingsScreen({super.key});
|
||||
|
@ -11,7 +16,16 @@ class SettingsScreen extends StatelessWidget {
|
|||
slivers: <Widget>[
|
||||
SliverAppBar(
|
||||
pinned: true,
|
||||
leading: null,
|
||||
expandedHeight: 160.0,
|
||||
flexibleSpace: FlexibleSpaceBar(
|
||||
centerTitle: false,
|
||||
titlePadding: const EdgeInsets.all(Dimens.paddingM),
|
||||
title: Text(
|
||||
S.of(context).settings,
|
||||
style: TextStyle(color: Theme.of(context).colorScheme.onSurface, fontSize: 24),
|
||||
),
|
||||
),
|
||||
actions: [
|
||||
IconButton(
|
||||
onPressed: () {},
|
||||
|
@ -19,11 +33,7 @@ class SettingsScreen extends StatelessWidget {
|
|||
),
|
||||
],
|
||||
),
|
||||
SliverList(
|
||||
delegate: SliverChildListDelegate(
|
||||
[],
|
||||
),
|
||||
),
|
||||
SliverList(delegate: SliverChildListDelegate([CaffeineListTile(), HapticsListTile()])),
|
||||
],
|
||||
),
|
||||
);
|
||||
|
|
Loading…
Reference in a new issue