goods_add_menu.dart
3.53 KB
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
112
import 'package:flutter/material.dart';
import 'package:one_poem/res/resources.dart';
import 'package:one_poem/routers/fluro_navigator.dart';
import 'package:one_poem/util/theme_utils.dart';
import 'package:one_poem/widgets/load_image.dart';
import '../goods_router.dart';
class GoodsAddMenu extends StatefulWidget {
const GoodsAddMenu({
Key? key,
}): super(key: key);
@override
_GoodsAddMenuState createState() => _GoodsAddMenuState();
}
class _GoodsAddMenuState extends State<GoodsAddMenu> with SingleTickerProviderStateMixin {
late AnimationController _controller;
late Animation<double> _scaleAnimation;
@override
void initState() {
super.initState();
_controller = AnimationController(
duration: const Duration(milliseconds: 200),
vsync: this,
);
_scaleAnimation = Tween<double>(begin: 0.0, end: 1.0).animate(_controller);
_controller.forward();
}
@override
void dispose() {
_controller.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
final Color backgroundColor = context.backgroundColor;
final Color? iconColor = ThemeUtils.getIconColor(context);
final Widget body = Column(
crossAxisAlignment: CrossAxisAlignment.end,
children: <Widget>[
Padding(
padding: const EdgeInsets.only(right: 12.0),
child: LoadAssetImage('goods/jt', width: 8.0, height: 4.0,
color: ThemeUtils.getDarkColor(context, Colours.dark_bg_color),
),
),
SizedBox(
width: 120.0,
height: 40.0,
child: TextButton.icon(
onPressed: () {
NavigatorUtils.push(context, '${GoodsRouter.goodsEditPage}?isAdd=true&isScan=true', replace: true);
},
icon: LoadAssetImage('goods/scanning', width: 16.0, height: 16.0, color: iconColor,),
label: const Text('扫码添加'),
style: TextButton.styleFrom(
primary: Theme.of(context).textTheme.bodyText2?.color,
onSurface: Theme.of(context).textTheme.bodyText2?.color?.withOpacity(0.12),
backgroundColor: backgroundColor,
shape: const RoundedRectangleBorder(
borderRadius: BorderRadius.only(topLeft: Radius.circular(8.0), topRight: Radius.circular(8.0)),
),
),
),
),
Container(width: 120.0, height: 0.6, color: Colours.line),
SizedBox(
width: 120.0,
height: 40.0,
child: TextButton.icon(
onPressed: () {
NavigatorUtils.push(context, '${GoodsRouter.goodsEditPage}?isAdd=true', replace: true);
},
icon: LoadAssetImage('goods/add2', width: 16.0, height: 16.0, color: iconColor,),
label: const Text('添加商品'),
style: TextButton.styleFrom(
primary: Theme.of(context).textTheme.bodyText2?.color,
onSurface: Theme.of(context).textTheme.bodyText2?.color?.withOpacity(0.12),
backgroundColor: backgroundColor,
shape: const RoundedRectangleBorder(
borderRadius: BorderRadius.only(bottomLeft: Radius.circular(8.0), bottomRight: Radius.circular(8.0)),
),
),
),
),
],
);
return AnimatedBuilder(
animation: _scaleAnimation,
builder: (_, child) {
return Transform.scale(
scale: _scaleAnimation.value,
alignment: Alignment.topRight,
child: child,
);
},
child: body,
);
}
}