-
Notifications
You must be signed in to change notification settings - Fork 50
/
Copy pathmain.dart
111 lines (103 loc) · 3.63 KB
/
main.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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
import 'package:flutter/material.dart';
import 'package:flutter_localizations/flutter_localizations.dart';
import 'package:insta_assets_picker_demo/pages/stateless_pickers.dart';
import 'package:insta_assets_picker_demo/pages/camera/camera_picker.dart';
import 'package:insta_assets_picker_demo/pages/camera/wechat_camera_picker.dart';
import 'package:insta_assets_picker_demo/pages/restorable_picker.dart';
import 'package:insta_assets_picker_demo/post_provider.dart';
import 'package:insta_assets_picker_demo/widgets/insta_picker_interface.dart';
import 'package:insta_assets_picker_demo/widgets/post.dart';
import 'package:provider/provider.dart';
const kDefaultColor = Colors.deepPurple;
void main() => runApp(
ChangeNotifierProvider(
create: (context) => PostProvider(),
child: const MyApp(),
),
);
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Insta Assets Picker Demo',
// update to change the main theme of app + picker
theme: ThemeData(
useMaterial3: true,
colorScheme: ColorScheme.fromSeed(
seedColor: kDefaultColor,
brightness: Brightness.dark,
),
cardTheme: const CardTheme(
elevation: 2,
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.all(Radius.circular(8)),
),
),
listTileTheme: const ListTileThemeData(
enableFeedback: true,
contentPadding: EdgeInsets.all(16),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.all(Radius.circular(8)),
),
titleTextStyle: TextStyle(fontWeight: FontWeight.w600),
leadingAndTrailingTextStyle: TextStyle(fontSize: 24),
),
),
home: const PickersScreen(),
localizationsDelegates: const <LocalizationsDelegate<dynamic>>[
GlobalWidgetsLocalizations.delegate,
GlobalMaterialLocalizations.delegate,
GlobalCupertinoLocalizations.delegate,
],
supportedLocales: const [Locale('en')],
);
}
}
class PickersScreen extends StatelessWidget {
const PickersScreen({super.key});
@override
Widget build(BuildContext context) {
final List<InstaPickerInterface> pickers = [
const SinglePicker(),
const MultiplePicker(),
const RestorablePicker(),
const CameraPicker(),
const WeChatCameraPicker(),
];
return Scaffold(
appBar: AppBar(
title: const Text('Insta pickers'),
actions: [
IconButton(
onPressed: () => Navigator.of(context).push(
MaterialPageRoute(builder: (context) => const PostsPage()),
),
icon: Icon(Icons.feed, semanticLabel: 'Feed'),
)
],
),
body: ListView.separated(
padding: const EdgeInsets.all(16),
itemBuilder: (BuildContext context, int index) {
final PickerDescription description = pickers[index].description;
return Card(
child: ListTile(
leading: Text(description.icon),
title: Text(description.label),
subtitle: description.description != null
? Text(description.description!)
: null,
trailing: const Icon(Icons.chevron_right_rounded),
onTap: () => Navigator.of(context).push(
MaterialPageRoute(builder: (context) => pickers[index]),
),
),
);
},
separatorBuilder: (_, __) => const SizedBox(height: 4),
itemCount: pickers.length,
),
);
}
}