piao_wait.dart 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469
  1. import 'package:flutter/material.dart';
  2. import 'package:liftmanager/res/gaps.dart';
  3. import 'package:liftmanager/net/api_service.dart';
  4. import 'package:liftmanager/utils/toast.dart';
  5. import 'package:liftmanager/widgets/app_bar.dart';
  6. import 'package:liftmanager/internal/search/search_router.dart';
  7. import 'package:liftmanager/widgets/app_search_bar.dart';
  8. import 'package:liftmanager/res/resources.dart';
  9. import 'package:liftmanager/routers/fluro_navigator.dart';
  10. import 'package:liftmanager/widgets/load_image.dart';
  11. import 'package:liftmanager/internal/bbs/bbs_router.dart';
  12. import 'package:liftmanager/widgets/my_card.dart';
  13. import 'package:liftmanager/internal/wode/wode_router.dart';
  14. import 'package:flutter_screenutil/flutter_screenutil.dart';
  15. import 'package:liftmanager/mvp/base_page_state.dart';
  16. import 'package:liftmanager/internal/wode/presenter/order_list_presenter.dart';
  17. import 'package:liftmanager/internal/search/presenter/base_list_provider.dart';
  18. import 'package:liftmanager/internal/bbs/model/liftcase_model.dart';
  19. import 'package:liftmanager/widgets/state_layout.dart';
  20. import 'package:provider/provider.dart';
  21. import 'package:liftmanager/utils/time_format.dart';
  22. import 'package:liftmanager/utils/log_util.dart';
  23. import 'package:liftmanager/widgets/my_refresh_list.dart';
  24. import 'dart:convert';
  25. import 'package:liftmanager/utils/fast_notification.dart';
  26. class PiaoWait extends StatefulWidget {
  27. // QuestionList(this.index);
  28. // final String index;
  29. bool checkAll = false;
  30. @override
  31. PiaoWaitState createState() => PiaoWaitState();
  32. }
  33. class PiaoWaitState extends State<PiaoWait> {
  34. int _page = 1;
  35. List<int>idList = [];
  36. List<int>commentListWidget=[];
  37. List<dynamic>listCase;
  38. bool _hasData = false;
  39. @override
  40. void initState() {
  41. super.initState();
  42. getLiftCasesListNoPage();
  43. print(66666);
  44. FastNotification.addListener("initThisPiao",(initThisStringPiao){
  45. if(mounted){
  46. getLiftCasesListNoPage();
  47. }
  48. });
  49. }
  50. Future getLiftCasesListNoPage() async {
  51. await NewApiService().getLiftCasesListNoPage(
  52. onSuccess: (res) {
  53. if (res != null) {
  54. _hasData = true;
  55. listCase = res;
  56. res.forEach((item){
  57. // print(JsonEncoder().convert(item));
  58. // print(item.id);
  59. commentListWidget.add(item.id);
  60. });
  61. // LogUtil.d(JsonEncoder().convert(listCase));
  62. print(123);
  63. setState(() {});
  64. }
  65. }, onError: (code, msg) {
  66. toasts(msg);
  67. });
  68. }
  69. @override
  70. void dispose() {
  71. super.dispose();
  72. }
  73. @override
  74. Widget build(BuildContext context) {
  75. double width = MediaQuery.of(context).size.width;
  76. String checkFalse = "tab_first/check_false";
  77. String checkTrue = "tab_first/check_true";
  78. return Scaffold(
  79. // resizeToAvoidBottomPadding: true,
  80. appBar: MyAppBar(
  81. centerTitle: "待开发票",
  82. // actions:<Widget>[
  83. // FlatButton(
  84. // child: Text("发票抬头"),
  85. // textColor: Colours.dark_text,
  86. // highlightColor: Colors.transparent,
  87. // onPressed: () {
  88. // NavigatorUtils.push(context, WodeRouter.piaotou);
  89. // },
  90. // )
  91. // ],
  92. ),
  93. body: _hasData?Stack(
  94. children: <Widget>[
  95. listCase.length>0?Container(
  96. // color: Color(0xFFF1F4FC),
  97. child: ListView(
  98. children: <Widget>[
  99. OrderListItemWidget(idList:idList,lists:listCase,
  100. changeState:(id){
  101. setState(() {
  102. print(557);
  103. if(idList.contains(id)){
  104. idList.remove(id);
  105. }else {
  106. idList.add(id);
  107. }
  108. print(idList);
  109. print(commentListWidget);
  110. if(commentListWidget.length==idList.length){
  111. widget.checkAll = true;
  112. print(widget.checkAll);
  113. print(555);
  114. }else {
  115. widget.checkAll = false;
  116. print(widget.checkAll);
  117. print(556);
  118. }
  119. print(idList);
  120. print(557);
  121. });
  122. }
  123. )
  124. ],
  125. ),
  126. ):Center(child:Text("暂无数据")),
  127. listCase.length>0?Positioned(
  128. bottom:0,
  129. left:0,
  130. child:Container(
  131. width: width,
  132. child: Row(
  133. children:<Widget>[
  134. Container(
  135. height:ScreenUtil().setWidth(70),
  136. width:width/2,
  137. color:Colors.white,
  138. child: GestureDetector(
  139. onTap: (){
  140. print(commentListWidget);
  141. setState(() {
  142. widget.checkAll = !widget.checkAll;
  143. if(widget.checkAll == false){
  144. idList = [];
  145. }else {
  146. idList = [];
  147. commentListWidget.forEach((item){
  148. idList.add(item);
  149. });
  150. }
  151. });
  152. print(idList);
  153. print(89888);
  154. print(commentListWidget);
  155. },
  156. child:Row(
  157. mainAxisAlignment: MainAxisAlignment.center,
  158. children: <Widget>[
  159. LoadAssetImage(
  160. // image: AssetImage(i['img']),
  161. widget.checkAll == true?checkTrue:checkFalse,
  162. width: ScreenUtil().setWidth(20),
  163. height:ScreenUtil().setWidth(20),
  164. // alignment: Alignment.centerLeft,
  165. ),
  166. SizedBox(
  167. width:5
  168. ),
  169. Text("全选",style: TextStyle(fontSize:ScreenUtil().setSp(16)),)
  170. ],
  171. )
  172. )
  173. ),
  174. Container(
  175. height:70,
  176. width:width/2,
  177. color: Color(0xff0388FD),
  178. child: FlatButton(
  179. // padding: EdgeInsets.all(15.0),
  180. child: Text("下一步",style: TextStyle(fontSize:ScreenUtil().setSp(16)),),
  181. textColor: Colors.white,
  182. onPressed: () {
  183. if(idList.length>0){
  184. String str = "";
  185. idList.forEach((item){
  186. str += (item.toString() + ",");
  187. });
  188. print(str.substring(0, str.length));
  189. print(456);
  190. double price = 0.0;
  191. listCase.forEach((subitem){
  192. idList.forEach((i){
  193. if(subitem.id == i){
  194. price += subitem.payCost;
  195. }
  196. });
  197. });
  198. NavigatorUtils.push(context, "${WodeRouter.kaipiao}?ids=${str.substring(0, str.length)}&price=${price.toString()}");
  199. idList = [];
  200. print(idList);
  201. }else {
  202. toasts("请选择一项");
  203. }
  204. },
  205. ),
  206. ),
  207. ]
  208. )
  209. )
  210. ):Container(child:null)
  211. ],
  212. ):Center(
  213. child: Text("正在加载..."),
  214. )
  215. );
  216. }
  217. }
  218. class OrderListItemWidget extends StatelessWidget {
  219. OrderListItemWidget({Key key, this.data,this.changeState,this.idList,this.lists}) : super(key: key);
  220. LiftCasesDetailModel data;
  221. Function changeState;
  222. List<int>idList;
  223. List<dynamic>lists;
  224. String checkFalse = "tab_first/check_false";
  225. String checkTrue = "tab_first/check_true";
  226. List<Widget> getListWdiget(context) => lists.asMap().keys.map((i){
  227. double width = MediaQuery.of(context).size.width;
  228. return Container(
  229. padding: EdgeInsets.all(ScreenUtil().setWidth(10)),
  230. width: width,
  231. decoration: BoxDecoration(
  232. border: Border(
  233. bottom: BorderSide(width: 0.5, color: Colours.line),
  234. ),
  235. ),
  236. // height: 100,
  237. child: Row(
  238. children: <Widget>[
  239. GestureDetector(
  240. child: Container(
  241. padding: EdgeInsets.only(top:ScreenUtil().setWidth(10),left:ScreenUtil().setWidth(5),right:ScreenUtil().setWidth(5),bottom:ScreenUtil().setWidth(10)),
  242. child: LoadAssetImage(
  243. // image: AssetImage(i['img']),
  244. idList.contains(lists[i].id)?checkTrue:checkFalse,
  245. width: ScreenUtil().setWidth(20),
  246. height:ScreenUtil().setWidth(20),
  247. // alignment: Alignment.centerLeft,
  248. ),
  249. ),
  250. onTap: (){
  251. changeState(lists[i].id);
  252. },
  253. ),
  254. Expanded(
  255. child: GestureDetector(
  256. behavior: HitTestBehavior.opaque,
  257. onTap: () {
  258. NavigatorUtils.push(
  259. context, "${WodeRouter.orderDetail}?id=${lists[i].id}");
  260. },
  261. child: Row(
  262. crossAxisAlignment: CrossAxisAlignment.start,
  263. // mainAxisSize: MainAxisSize.min,
  264. children: <Widget>[
  265. Container(
  266. margin: EdgeInsets.only(
  267. left: ScreenUtil().setWidth(10),
  268. right: ScreenUtil().setWidth(10),
  269. top: ScreenUtil().setWidth(5)),
  270. decoration: BoxDecoration(
  271. borderRadius: BorderRadius.circular(ScreenUtil().setWidth(22)),
  272. ),
  273. child: ClipRRect(
  274. borderRadius: BorderRadius.circular(ScreenUtil().setWidth(22)),
  275. child: LoadNetworkImage(
  276. lists[i].avatarUrl,
  277. width: ScreenUtil().setWidth(43),
  278. height: ScreenUtil().setWidth(43),
  279. // alignment: Alignment.centerLeft,
  280. ),
  281. ),
  282. ),
  283. Expanded(
  284. // flex: 1,
  285. // fit: FlexFit.loose,
  286. child: Container(
  287. padding: EdgeInsets.only(right: ScreenUtil().setWidth(15)),
  288. child: Column(
  289. children: <Widget>[
  290. Container(
  291. child: Row(
  292. mainAxisAlignment: MainAxisAlignment.spaceBetween,
  293. children: <Widget>[
  294. Row(
  295. crossAxisAlignment: CrossAxisAlignment.center,
  296. children: <Widget>[
  297. Text(
  298. lists[i].name,
  299. style: TextStyle(
  300. color: Color(0xff333333),
  301. fontSize: ScreenUtil().setSp(17)),
  302. textAlign: TextAlign.start,
  303. ),
  304. Container(
  305. padding: EdgeInsets.only(left: 5),
  306. child: Text(
  307. lists[i].dataTable == 1 ? '问诊服务' : '出诊服务',
  308. style: TextStyle(
  309. color: Color(0xff0288FF),
  310. fontSize: ScreenUtil().setSp(14),
  311. ),
  312. textAlign: TextAlign.start,
  313. ),
  314. )
  315. ],
  316. ),
  317. // Container(
  318. // child: Text(
  319. // OrderConstant.getStatusName(data.statuz, data.dataTable, arrivedFlag: data.arrivedFlag, userType: 'USER'),
  320. // style: TextStyle(
  321. // color: [].indexOf(data.statuz) == -1
  322. // ? Color(0xff0288FF)
  323. // : Color(0xffF84203),
  324. // fontSize: ScreenUtil().setSp(14),
  325. // ),
  326. // textAlign: TextAlign.end,
  327. // ),
  328. // )
  329. ],
  330. ),
  331. ),
  332. Container(
  333. child: Row(
  334. mainAxisAlignment: MainAxisAlignment.spaceBetween,
  335. children: <Widget>[
  336. Row(
  337. crossAxisAlignment: CrossAxisAlignment.center,
  338. children: <Widget>[
  339. Text(
  340. lists[i].createTime != null
  341. ? DateUtils.instance.getFormartData(
  342. timeSamp: lists[i].createTime,
  343. format: "yyyy-MM-dd")
  344. : '',
  345. style: TextStyle(
  346. color: Color(0xff999999),
  347. fontSize: ScreenUtil().setSp(13),
  348. ),
  349. textAlign: TextAlign.start,
  350. ),
  351. Container(
  352. padding: EdgeInsets.only(left: 5),
  353. child: Text(
  354. lists[i].brandName ?? '',
  355. style: TextStyle(
  356. color: Color(0xff999999),
  357. fontSize: ScreenUtil().setSp(13),
  358. ),
  359. textAlign: TextAlign.start,
  360. ),
  361. )
  362. ],
  363. ),
  364. ],
  365. ),
  366. ),
  367. Container(
  368. // margin: EdgeInsets.only(top: 6),
  369. child: Row(
  370. children: <Widget>[
  371. Container(
  372. width: width*0.6,
  373. padding: EdgeInsets.only(right: 5),
  374. child: Text(
  375. lists[i].expression ?? '',
  376. style: TextStyle(
  377. color: Color(0xff666666),
  378. fontSize: ScreenUtil().setSp(15),
  379. ),
  380. textAlign: TextAlign.start,
  381. maxLines: 1,
  382. overflow: TextOverflow.ellipsis,
  383. ),
  384. ),
  385. ],
  386. ),
  387. ),
  388. Container(
  389. margin: EdgeInsets.only(top: 6),
  390. child: Row(
  391. children: <Widget>[
  392. Container(
  393. padding: EdgeInsets.only(right: 5),
  394. child: Text(
  395. lists[i].payCost != null
  396. ? "¥${lists[i].payCost.toString()}"
  397. : '',
  398. style: TextStyle(
  399. color: Color(0xffFD0808),
  400. fontSize: ScreenUtil().setSp(15),
  401. ),
  402. textAlign: TextAlign.start,
  403. ),
  404. ),
  405. ],
  406. ),
  407. )
  408. ],
  409. ),
  410. ),
  411. )
  412. ],
  413. ),
  414. ),
  415. )
  416. ],
  417. ),
  418. );
  419. }).toList();
  420. @override
  421. @override
  422. Widget build(BuildContext context) {
  423. return Container(
  424. child: Column(
  425. crossAxisAlignment: CrossAxisAlignment.start,
  426. children: getListWdiget(context),
  427. ),
  428. );
  429. }
  430. }