order_page.dart 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538
  1. import 'package:flutter/material.dart';
  2. import 'package:liftmanager/widgets/app_bar.dart';
  3. import 'package:liftmanager/routers/fluro_navigator.dart';
  4. import 'package:liftmanager/widgets/load_image.dart';
  5. import 'package:liftmanager/mvp/base_page_state.dart';
  6. import 'dart:async';
  7. import 'package:liftmanager/internal/wode/wode_router.dart';
  8. import 'package:liftmanager/utils/toast.dart';
  9. import 'package:flutter_screenutil/flutter_screenutil.dart';
  10. import 'package:provider/provider.dart';
  11. // import 'package:liftmanager/internal/wode/model/order_model.dart';
  12. import 'package:liftmanager/internal/bbs/model/liftcase_model.dart';
  13. import 'package:liftmanager/internal/search/presenter/base_list_provider.dart';
  14. import 'package:liftmanager/internal/wode/presenter/order_master_list_presenter.dart';
  15. import 'package:liftmanager/widgets/state_layout.dart';
  16. import 'package:liftmanager/mvp/base_page_state.dart';
  17. import 'package:liftmanager/utils/time_format.dart';
  18. import 'package:liftmanager/widgets/my_refresh_list.dart';
  19. import 'package:liftmanager/internal/wode/order_const.dart';
  20. class OrderPageMaster extends StatefulWidget {
  21. OrderPageMaster(this.checkType);
  22. String checkType;
  23. int tabCheckIndex = 0;
  24. @override
  25. // State<StatefulWidget> createState() {
  26. // return OrderPageMasterState();
  27. // }
  28. OrderPageMasterState createState() => OrderPageMasterState();
  29. }
  30. class OrderPageMasterState
  31. extends BasePageState<OrderPageMaster, OrderListPresenterSeconds> {
  32. BaseListProvider<LiftCasesDetailModel> provider =
  33. BaseListProvider<LiftCasesDetailModel>();
  34. int _page = 1;
  35. ScrollController _scrollController = new ScrollController();
  36. @override
  37. void dispose() {
  38. _scrollController.dispose();
  39. super.dispose();
  40. }
  41. @override
  42. void initState() {
  43. if (widget.checkType.isNotEmpty && widget.checkType != null) {
  44. widget.tabCheckIndex = int.parse(widget.checkType);
  45. }
  46. provider.setStateTypeNotNotify(StateType.loading);
  47. super.initState();
  48. _onRefresh();
  49. }
  50. @override
  51. Widget build(BuildContext context) {
  52. double width = MediaQuery.of(context).size.width;
  53. return ChangeNotifierProvider<BaseListProvider<LiftCasesDetailModel>>(
  54. create: (_) => provider,
  55. child: Scaffold(
  56. appBar: MyAppBar(
  57. centerTitle: "专家订单",
  58. isFun: true,
  59. fun: () {
  60. Navigator.popUntil(context, ModalRoute.withName('/home'));
  61. },
  62. actions: <Widget>[],
  63. ),
  64. body: Container(
  65. child: Stack(
  66. children: <Widget>[
  67. Container(
  68. padding: EdgeInsets.only(top: ScreenUtil().setWidth(44)),
  69. child: Column(
  70. children: <Widget>[
  71. Expanded(
  72. flex: 1,
  73. child: Consumer<BaseListProvider<LiftCasesDetailModel>>(
  74. builder: (_, provider, __) {
  75. return MyListView(
  76. key: Key('order_list'),
  77. itemCount: provider.list.length,
  78. stateType: provider.stateType,
  79. onRefresh: _onRefresh,
  80. loadMore: _loadMore,
  81. hasMore: provider.hasMore,
  82. itemBuilder: (_, index) {
  83. return OrderListItemWidget(
  84. data: provider.list[index],
  85. );
  86. },
  87. );
  88. },
  89. ),
  90. )
  91. ],
  92. ),
  93. ),
  94. Positioned(
  95. child: Container(
  96. padding: EdgeInsets.only(bottom: 5),
  97. // color:Color(0xffFAF7FA),
  98. decoration: BoxDecoration(
  99. border: Border(
  100. bottom: BorderSide(width: 0.5, color: Color(0xffeeeeee)),
  101. ),
  102. // color: Color(0xff9FD1FE),
  103. ),
  104. child: Row(
  105. mainAxisAlignment: MainAxisAlignment.spaceAround,
  106. children:
  107. OrderConstant.expertOrderType.asMap().keys.map((i) {
  108. return TabThis(
  109. item: OrderConstant.expertOrderType[i]['name'],
  110. tabIndex: i,
  111. checkIndex: widget.tabCheckIndex,
  112. fun: (index) {
  113. setState(() {
  114. widget.tabCheckIndex = index;
  115. provider.list.clear();
  116. _onRefresh();
  117. });
  118. });
  119. }).toList(),
  120. ),
  121. ),
  122. ),
  123. ],
  124. ),
  125. ),
  126. ),
  127. );
  128. }
  129. Future _onRefresh() async {
  130. _page = 1;
  131. await presenter.getOrderList(
  132. _page, OrderConstant.expertOrderType[widget.tabCheckIndex]['value']);
  133. }
  134. Future _loadMore() async {
  135. _page++;
  136. await presenter.getOrderList(
  137. _page, OrderConstant.expertOrderType[widget.tabCheckIndex]['value']);
  138. }
  139. @override
  140. OrderListPresenterSeconds createPresenter() {
  141. // TODO: implement createPresenter
  142. // throw UnimplementedError();
  143. return OrderListPresenterSeconds();
  144. }
  145. }
  146. class TabThis extends StatelessWidget {
  147. TabThis({Key key, this.item, this.tabIndex, this.fun, this.checkIndex})
  148. : super(key: key);
  149. String item;
  150. int tabIndex;
  151. int checkIndex;
  152. Function fun;
  153. @override
  154. Widget build(BuildContext context) {
  155. return Container(
  156. padding: EdgeInsets.only(top: ScreenUtil().setWidth(10)),
  157. child: Container(
  158. child: Row(
  159. mainAxisAlignment: MainAxisAlignment.center,
  160. children: <Widget>[
  161. GestureDetector(
  162. onTap: () {
  163. fun(tabIndex);
  164. },
  165. child: Container(
  166. padding: EdgeInsets.only(bottom: 6),
  167. decoration: BoxDecoration(
  168. border: Border(
  169. bottom: BorderSide(
  170. width: 2,
  171. color: checkIndex == tabIndex
  172. ? Color(0xff02A0FD)
  173. : Colors.transparent),
  174. ),
  175. // color: Color(0xff9FD1FE),
  176. ),
  177. child: Text(
  178. item,
  179. style: TextStyle(
  180. color: checkIndex == tabIndex
  181. ? Color(0xff02A0FD)
  182. : Color(0xff666666),
  183. fontSize: ScreenUtil().setSp(14),
  184. ),
  185. textAlign: TextAlign.center,
  186. ),
  187. ),
  188. )
  189. ],
  190. ),
  191. ),
  192. );
  193. }
  194. }
  195. class OrderListItemWidget extends StatelessWidget {
  196. OrderListItemWidget({Key key, this.data}) : super(key: key);
  197. LiftCasesDetailModel data;
  198. @override
  199. Widget build(BuildContext context) {
  200. double width = MediaQuery.of(context).size.width;
  201. return IntrinsicWidth(
  202. child: Container(
  203. padding: EdgeInsets.only(top: ScreenUtil().setWidth(10)),
  204. width: width,
  205. // height: 100,
  206. child: GestureDetector(
  207. onTap: () {
  208. NavigatorUtils.push(
  209. context, "${WodeRouter.orderDetailMaster}?id=${data.id}");
  210. },
  211. child: Row(
  212. crossAxisAlignment: CrossAxisAlignment.start,
  213. // mainAxisSize: MainAxisSize.min,
  214. children: <Widget>[
  215. Container(
  216. margin: EdgeInsets.only(
  217. left: ScreenUtil().setWidth(10),
  218. right: ScreenUtil().setWidth(10),
  219. top: ScreenUtil().setWidth(5),
  220. ),
  221. decoration: BoxDecoration(
  222. borderRadius: BorderRadius.circular(
  223. ScreenUtil().setWidth(22),
  224. ),
  225. ),
  226. child: LoadNetworkImage(
  227. data.avatarUrl,
  228. width: ScreenUtil().setWidth(43),
  229. height: ScreenUtil().setWidth(43),
  230. // alignment: Alignment.centerLeft,
  231. ),
  232. ),
  233. Expanded(
  234. child: Container(
  235. padding: EdgeInsets.only(
  236. right: ScreenUtil().setWidth(15),
  237. ),
  238. child: Column(
  239. children: <Widget>[
  240. Container(
  241. child: Row(
  242. mainAxisAlignment: MainAxisAlignment.spaceBetween,
  243. children: <Widget>[
  244. Row(
  245. crossAxisAlignment: CrossAxisAlignment.center,
  246. children: <Widget>[
  247. Text(
  248. data.name ?? '',
  249. style: TextStyle(
  250. fontSize: ScreenUtil().setSp(17),
  251. ),
  252. textAlign: TextAlign.start,
  253. ),
  254. Container(
  255. padding: EdgeInsets.only(left: 5),
  256. child: Text(
  257. data.dataTable == 1 ? '问诊服务' : '出诊服务',
  258. style: TextStyle(
  259. color: Color(0xff0288FF),
  260. fontSize: ScreenUtil().setSp(14),
  261. ),
  262. textAlign: TextAlign.start,
  263. ),
  264. )
  265. ],
  266. ),
  267. Container(
  268. child: Text(
  269. OrderConstant.getStatusName(
  270. data.statuz, data.dataTable,
  271. arrivedFlag: data.arrivedFlag,
  272. userType: 'EXPERT'),
  273. style: TextStyle(
  274. color: [].indexOf(data.statuz) == -1
  275. ? Color(0xff0288FF)
  276. : Color(0xffF84203),
  277. fontSize: ScreenUtil().setSp(14),
  278. ),
  279. textAlign: TextAlign.end,
  280. ),
  281. )
  282. ]),
  283. ),
  284. Container(
  285. child: Row(
  286. mainAxisAlignment: MainAxisAlignment.spaceBetween,
  287. children: <Widget>[
  288. Row(
  289. crossAxisAlignment: CrossAxisAlignment.center,
  290. children: <Widget>[
  291. Text(
  292. data.createTime != null
  293. ? DateUtils.instance.getFormartData(
  294. timeSamp: data.createTime,
  295. format: "MM-dd")
  296. : '',
  297. style: TextStyle(
  298. color: Color(0xff999999),
  299. fontSize: ScreenUtil().setSp(13),
  300. ),
  301. textAlign: TextAlign.start,
  302. ),
  303. Container(
  304. padding: EdgeInsets.only(left: 5),
  305. child: Text(
  306. data.brandName ?? '',
  307. style: TextStyle(
  308. color: Color(0xff999999),
  309. fontSize: ScreenUtil().setSp(13),
  310. ),
  311. textAlign: TextAlign.start,
  312. ),
  313. )
  314. ],
  315. ),
  316. ]),
  317. ),
  318. data.dataTable == 1
  319. ? Container(
  320. child: Row(
  321. mainAxisAlignment: MainAxisAlignment.spaceBetween,
  322. children: <Widget>[
  323. Row(
  324. crossAxisAlignment: CrossAxisAlignment.center,
  325. children: <Widget>[
  326. Text(
  327. '问题描述:',
  328. style: TextStyle(
  329. color: Color(0xff666666),
  330. fontSize: ScreenUtil().setSp(14),
  331. ),
  332. textAlign: TextAlign.start,
  333. ),
  334. Container(
  335. width: 200,
  336. padding: EdgeInsets.only(left: 5),
  337. child: Text(
  338. data.expression ?? '',
  339. style: TextStyle(
  340. color: Color(0xff666666),
  341. fontSize: ScreenUtil().setSp(14),
  342. ),
  343. textAlign: TextAlign.start,
  344. maxLines: 1,
  345. overflow: TextOverflow.ellipsis,
  346. ),
  347. )
  348. ],
  349. ),
  350. ],
  351. ),
  352. )
  353. : Container(
  354. child: Row(
  355. mainAxisAlignment: MainAxisAlignment.spaceBetween,
  356. children: <Widget>[
  357. Row(
  358. crossAxisAlignment: CrossAxisAlignment.center,
  359. children: <Widget>[
  360. Text(
  361. '出诊时间:',
  362. style: TextStyle(
  363. color: Color(0xff666666),
  364. fontSize: ScreenUtil().setSp(14),
  365. ),
  366. textAlign: TextAlign.start,
  367. ),
  368. Container(
  369. padding: EdgeInsets.only(left: 5),
  370. child: Text(
  371. data.arrivedTime != null
  372. ? DateUtils.instance.getFormartData(
  373. timeSamp: data.arrivedTime,
  374. format: "MM-dd HH:mm")
  375. : '',
  376. style: TextStyle(
  377. color: Color(0xff666666),
  378. fontSize: ScreenUtil().setSp(14),
  379. ),
  380. textAlign: TextAlign.start,
  381. ),
  382. )
  383. ],
  384. ),
  385. ],
  386. ),
  387. ),
  388. data.dataTable == 1
  389. ? Container(
  390. child: Row(
  391. mainAxisAlignment: MainAxisAlignment.spaceBetween,
  392. children: <Widget>[
  393. Row(
  394. crossAxisAlignment: CrossAxisAlignment.center,
  395. children: <Widget>[
  396. Text(
  397. '已尝试方法:',
  398. style: TextStyle(
  399. color: Color(0xff666666),
  400. fontSize: ScreenUtil().setSp(14),
  401. ),
  402. textAlign: TextAlign.start,
  403. ),
  404. Container(
  405. width: 200,
  406. padding: EdgeInsets.only(left: 5),
  407. child: Text(
  408. data.usedMethods ?? '',
  409. style: TextStyle(
  410. color: Color(0xff666666),
  411. fontSize: ScreenUtil().setSp(14),
  412. ),
  413. textAlign: TextAlign.start,
  414. maxLines: 1,
  415. overflow: TextOverflow.ellipsis,
  416. ),
  417. )
  418. ],
  419. ),
  420. ],
  421. ),
  422. )
  423. : Container(
  424. child: Row(
  425. mainAxisAlignment: MainAxisAlignment.spaceBetween,
  426. children: <Widget>[
  427. Row(
  428. crossAxisAlignment: CrossAxisAlignment.center,
  429. children: <Widget>[
  430. Text(
  431. '出诊地点:',
  432. style: TextStyle(
  433. color: Color(0xff666666),
  434. fontSize: ScreenUtil().setSp(14),
  435. ),
  436. textAlign: TextAlign.start,
  437. ),
  438. Container(
  439. width: 200,
  440. padding: EdgeInsets.only(left: 5),
  441. child: Text(
  442. data.address ?? '',
  443. style: TextStyle(
  444. color: Color(0xff666666),
  445. fontSize: ScreenUtil().setSp(14),
  446. ),
  447. textAlign: TextAlign.start,
  448. maxLines: 1,
  449. overflow: TextOverflow.ellipsis,
  450. ),
  451. )
  452. ],
  453. ),
  454. ],
  455. ),
  456. ),
  457. data.dataTable == 2
  458. ? Container(
  459. child: Row(
  460. mainAxisAlignment: MainAxisAlignment.spaceBetween,
  461. children: <Widget>[
  462. Row(
  463. crossAxisAlignment: CrossAxisAlignment.center,
  464. children: <Widget>[
  465. Text(
  466. '问题描述:',
  467. style: TextStyle(
  468. color: Color(0xff666666),
  469. fontSize: ScreenUtil().setSp(14),
  470. ),
  471. textAlign: TextAlign.start,
  472. ),
  473. Container(
  474. width: 200,
  475. padding: EdgeInsets.only(left: 5),
  476. child: Text(
  477. data.expression ?? '',
  478. style: TextStyle(
  479. color: Color(0xff666666),
  480. fontSize: ScreenUtil().setSp(14),
  481. ),
  482. textAlign: TextAlign.start,
  483. maxLines: 1,
  484. overflow: TextOverflow.ellipsis,
  485. ),
  486. )
  487. ],
  488. ),
  489. ],
  490. ),
  491. )
  492. : Container(),
  493. Container(
  494. margin: EdgeInsets.only(top: 6),
  495. child: Row(
  496. children: <Widget>[
  497. Container(
  498. padding: EdgeInsets.only(right: 5),
  499. child: Text(
  500. data.totalCost != null
  501. ? "¥${data.totalCost.toString()}"
  502. : '',
  503. style: TextStyle(
  504. color: Color(0xffFD0808),
  505. fontSize: ScreenUtil().setSp(15),
  506. ),
  507. textAlign: TextAlign.start,
  508. ),
  509. ),
  510. ],
  511. ),
  512. )
  513. ],
  514. ),
  515. ),
  516. ),
  517. ],
  518. ),
  519. ),
  520. ));
  521. }
  522. }