-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathside_bar.dart
91 lines (83 loc) · 2.8 KB
/
side_bar.dart
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
import 'package:flutter/material.dart';
import 'package:watch_it/watch_it.dart';
import 'package:yaru/yaru.dart';
import '../constants.dart';
import '../extensions/build_context_x.dart';
import '../weather/view/city_search_field.dart';
import '../weather/weather_model.dart';
class SideBar extends StatelessWidget with WatchItMixin {
const SideBar({super.key, this.onSelected});
final VoidCallback? onSelected;
@override
Widget build(BuildContext context) {
final theme = context.theme;
final model = di<WeatherModel>();
final favLocationsLength =
watchPropertyValue((WeatherModel m) => m.favLocations.length);
final favLocations = watchPropertyValue((WeatherModel m) => m.favLocations);
final lastLocation = watchPropertyValue((WeatherModel m) => m.lastLocation);
final listView = ListView.builder(
itemCount: favLocationsLength,
itemBuilder: (context, index) {
final location = favLocations.elementAt(index);
return Stack(
alignment: Alignment.centerRight,
children: [
YaruMasterTile(
onTap: () {
model.loadWeather(cityName: location);
onSelected?.call();
},
selected: lastLocation == location,
title: Text(
favLocations.elementAt(index),
),
),
if (favLocationsLength > 1 && lastLocation == location)
Positioned(
right: 20,
child: SizedBox.square(
dimension: 30,
child: IconButton(
padding: EdgeInsets.zero,
onPressed: () {
model.removeFavLocation(location).then(
(value) => model.loadWeather(
cityName: favLocations.lastOrNull,
),
);
},
icon: const Icon(
YaruIcons.window_close,
),
),
),
),
],
);
},
);
return Material(
color: theme.colorScheme.surface.withValues(alpha: 0.4),
child: SizedBox(
width: kPaneWidth,
child: Column(
children: [
const YaruDialogTitleBar(
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.only(
topLeft: Radius.circular(kYaruContainerRadius),
),
),
backgroundColor: Colors.transparent,
border: BorderSide.none,
style: YaruTitleBarStyle.undecorated,
title: CitySearchField(),
),
Expanded(child: listView),
],
),
),
);
}
}