|
|
@ -2,6 +2,11 @@
|
|
|
|
import 'dart:math';
|
|
|
|
import 'dart:math';
|
|
|
|
|
|
|
|
|
|
|
|
// Flutter imports:
|
|
|
|
// Flutter imports:
|
|
|
|
|
|
|
|
import 'package:aku_community_manager/const/api.dart';
|
|
|
|
|
|
|
|
import 'package:aku_community_manager/models/manager/decoration/decoration_detail_model.dart';
|
|
|
|
|
|
|
|
import 'package:aku_community_manager/utils/network/base_model.dart';
|
|
|
|
|
|
|
|
import 'package:aku_community_manager/utils/network/net_util.dart';
|
|
|
|
|
|
|
|
import 'package:bot_toast/bot_toast.dart';
|
|
|
|
import 'package:flutter/cupertino.dart';
|
|
|
|
import 'package:flutter/cupertino.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
|
|
|
|
|
|
@ -9,12 +14,12 @@ import 'package:flutter/material.dart';
|
|
|
|
import 'package:aku_ui/common_widgets/aku_material_button.dart';
|
|
|
|
import 'package:aku_ui/common_widgets/aku_material_button.dart';
|
|
|
|
import 'package:common_utils/common_utils.dart';
|
|
|
|
import 'package:common_utils/common_utils.dart';
|
|
|
|
import 'package:expandable/expandable.dart';
|
|
|
|
import 'package:expandable/expandable.dart';
|
|
|
|
|
|
|
|
import 'package:flutter_easyrefresh/easy_refresh.dart';
|
|
|
|
import 'package:get/get.dart';
|
|
|
|
import 'package:get/get.dart';
|
|
|
|
|
|
|
|
|
|
|
|
// Project imports:
|
|
|
|
// Project imports:
|
|
|
|
import 'package:aku_community_manager/const/resource.dart';
|
|
|
|
import 'package:aku_community_manager/const/resource.dart';
|
|
|
|
import 'package:aku_community_manager/mock_models/decoration/decoration_model.dart';
|
|
|
|
import 'package:aku_community_manager/mock_models/decoration/decoration_model.dart';
|
|
|
|
import 'package:aku_community_manager/models/manager/decoration/decoration_list_model.dart';
|
|
|
|
|
|
|
|
import 'package:aku_community_manager/style/app_style.dart';
|
|
|
|
import 'package:aku_community_manager/style/app_style.dart';
|
|
|
|
import 'package:aku_community_manager/tools/screen_tool.dart';
|
|
|
|
import 'package:aku_community_manager/tools/screen_tool.dart';
|
|
|
|
import 'package:aku_community_manager/tools/user_tool.dart';
|
|
|
|
import 'package:aku_community_manager/tools/user_tool.dart';
|
|
|
@ -29,9 +34,14 @@ import 'package:aku_community_manager/ui/widgets/inner/aku_title_box.dart';
|
|
|
|
import 'package:aku_community_manager/ui/widgets/inner/show_bottom_sheet.dart';
|
|
|
|
import 'package:aku_community_manager/ui/widgets/inner/show_bottom_sheet.dart';
|
|
|
|
|
|
|
|
|
|
|
|
class DecorationManagerDetailPage extends StatefulWidget {
|
|
|
|
class DecorationManagerDetailPage extends StatefulWidget {
|
|
|
|
final DecorationListModel decorationModel;
|
|
|
|
final int id;
|
|
|
|
DecorationManagerDetailPage({Key key, this.decorationModel})
|
|
|
|
final int status;
|
|
|
|
: super(key: key);
|
|
|
|
final int operationStatus;
|
|
|
|
|
|
|
|
DecorationManagerDetailPage({
|
|
|
|
|
|
|
|
Key key,
|
|
|
|
|
|
|
|
this.id,
|
|
|
|
|
|
|
|
this.status, this.operationStatus,
|
|
|
|
|
|
|
|
}) : super(key: key);
|
|
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
@override
|
|
|
|
_DecorationManagerDetailStatePage createState() =>
|
|
|
|
_DecorationManagerDetailStatePage createState() =>
|
|
|
@ -40,26 +50,57 @@ class DecorationManagerDetailPage extends StatefulWidget {
|
|
|
|
|
|
|
|
|
|
|
|
class _DecorationManagerDetailStatePage
|
|
|
|
class _DecorationManagerDetailStatePage
|
|
|
|
extends State<DecorationManagerDetailPage> {
|
|
|
|
extends State<DecorationManagerDetailPage> {
|
|
|
|
|
|
|
|
EasyRefreshController _refreshController;
|
|
|
|
|
|
|
|
DecorationDetailModel _model;
|
|
|
|
|
|
|
|
bool _onload = true;
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
|
|
|
void initState() {
|
|
|
|
|
|
|
|
super.initState();
|
|
|
|
|
|
|
|
_refreshController = EasyRefreshController();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
|
|
|
void dispose() {
|
|
|
|
|
|
|
|
_refreshController.dispose();
|
|
|
|
|
|
|
|
super.dispose();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return AkuScaffold(
|
|
|
|
return AkuScaffold(
|
|
|
|
title: '装修详情',
|
|
|
|
title: '装修详情',
|
|
|
|
body: ListView(
|
|
|
|
body: EasyRefresh(
|
|
|
|
padding: EdgeInsets.symmetric(vertical: 16.w),
|
|
|
|
firstRefresh: true,
|
|
|
|
children: [
|
|
|
|
header: MaterialHeader(),
|
|
|
|
_buildInfo(),
|
|
|
|
onRefresh: () async {
|
|
|
|
widget.decorationModel.status > 3
|
|
|
|
BaseModel baseModel =
|
|
|
|
? SizedBox()
|
|
|
|
await NetUtil().get(API.manage.decorationFindByld, params: {
|
|
|
|
: _buildFinishWorkCheck(),
|
|
|
|
"decorationId ": widget.id,
|
|
|
|
_buildCycleCheck(),
|
|
|
|
});
|
|
|
|
UserTool.userProvider.infoModel.manager
|
|
|
|
if (baseModel.status) {
|
|
|
|
? SizedBox()
|
|
|
|
_model = DecorationDetailModel.fromJson(baseModel.data);
|
|
|
|
: _buildCheckDetail(),
|
|
|
|
_onload = false;
|
|
|
|
],
|
|
|
|
} else {
|
|
|
|
|
|
|
|
BotToast.showText(text: baseModel.message);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
child: _onload
|
|
|
|
|
|
|
|
? Container()
|
|
|
|
|
|
|
|
: ListView(
|
|
|
|
|
|
|
|
padding: EdgeInsets.symmetric(vertical: 16.w),
|
|
|
|
|
|
|
|
children: [
|
|
|
|
|
|
|
|
_buildInfo(),
|
|
|
|
|
|
|
|
widget.status > 3 ? SizedBox() : _buildFinishWorkCheck(),
|
|
|
|
|
|
|
|
_buildCycleCheck(),
|
|
|
|
|
|
|
|
UserTool.userProvider.infoModel.canDecorationTrack
|
|
|
|
|
|
|
|
? SizedBox()
|
|
|
|
|
|
|
|
: _buildCheckDetail(),
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
bottom: Builder(builder: (context) {
|
|
|
|
bottom: Builder(builder: (context) {
|
|
|
|
if (UserTool.userProvider.infoModel.canOperation) {
|
|
|
|
if (UserTool.userProvider.infoModel.canDecorationDispatch) {
|
|
|
|
switch (widget.decorationModel.operationStatus) {
|
|
|
|
switch (widget.status) {
|
|
|
|
case 1:
|
|
|
|
case 1:
|
|
|
|
return AkuBottomButton(title: '立即安排', onTap: () {});
|
|
|
|
return AkuBottomButton(title: '立即安排', onTap: () {});
|
|
|
|
break;
|
|
|
|
break;
|
|
|
@ -67,8 +108,8 @@ class _DecorationManagerDetailStatePage
|
|
|
|
return SizedBox();
|
|
|
|
return SizedBox();
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if (UserTool.userProvider.infoModel.canOperation) {
|
|
|
|
} else if (UserTool.userProvider.infoModel.canDecorationTrack) {
|
|
|
|
switch (widget.decorationModel.operationStatus) {
|
|
|
|
switch (widget.status) {
|
|
|
|
case 2:
|
|
|
|
case 2:
|
|
|
|
return AkuBottomButton(
|
|
|
|
return AkuBottomButton(
|
|
|
|
title: '立即执行',
|
|
|
|
title: '立即执行',
|
|
|
@ -102,12 +143,12 @@ class _DecorationManagerDetailStatePage
|
|
|
|
_buildInfoCard(
|
|
|
|
_buildInfoCard(
|
|
|
|
tag: '家',
|
|
|
|
tag: '家',
|
|
|
|
midTop: '人才公寓',
|
|
|
|
midTop: '人才公寓',
|
|
|
|
midBottom: widget.decorationModel.roomName,
|
|
|
|
midBottom: _model.decorationFBIVo.roomName,
|
|
|
|
name: '业主:' + UserTool.userProvider.infoModel.nickName,
|
|
|
|
name: '业主:' + UserTool.userProvider.infoModel.nickName,
|
|
|
|
phone: UserTool.userProvider.profileModel.tel,
|
|
|
|
phone: UserTool.userProvider.profileModel.tel,
|
|
|
|
rightTopWidget: Transform.rotate(
|
|
|
|
rightTopWidget: Transform.rotate(
|
|
|
|
angle: pi / 4,
|
|
|
|
angle: pi / 4,
|
|
|
|
child: widget.decorationModel.operationStatus == 3
|
|
|
|
child: widget.status == 3
|
|
|
|
? Image.asset(R.ASSETS_MANAGE_IC_WANCHENG_PNG)
|
|
|
|
? Image.asset(R.ASSETS_MANAGE_IC_WANCHENG_PNG)
|
|
|
|
: Image.asset(R.ASSETS_MANAGE_IC_ZHUANGXIU_PNG),
|
|
|
|
: Image.asset(R.ASSETS_MANAGE_IC_ZHUANGXIU_PNG),
|
|
|
|
),
|
|
|
|
),
|
|
|
@ -115,9 +156,9 @@ class _DecorationManagerDetailStatePage
|
|
|
|
AkuBox.h(16),
|
|
|
|
AkuBox.h(16),
|
|
|
|
_buildInfoCard(
|
|
|
|
_buildInfoCard(
|
|
|
|
tag: '装',
|
|
|
|
tag: '装',
|
|
|
|
midTop: widget.decorationModel.constructionUnit,
|
|
|
|
midTop: _model.decorationFBIVo.constructionUnit,
|
|
|
|
name: '负责人:' + '马泽鹏',
|
|
|
|
name: '负责人:${_model.decorationFBIVo.director}',
|
|
|
|
phone: '13831971345',
|
|
|
|
phone: '${_model.decorationFBIVo.directorTel}',
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
],
|
|
|
|
);
|
|
|
|
);
|
|
|
@ -250,19 +291,19 @@ class _DecorationManagerDetailStatePage
|
|
|
|
_buildRow(
|
|
|
|
_buildRow(
|
|
|
|
title: '开始装修时间',
|
|
|
|
title: '开始装修时间',
|
|
|
|
subTitle: DateUtil.formatDateStr(
|
|
|
|
subTitle: DateUtil.formatDateStr(
|
|
|
|
'2021-5-20 13:14',
|
|
|
|
_model.decorationFBIVo.actualBegin,
|
|
|
|
format: 'yyyy-MM-dd',
|
|
|
|
format: 'yyyy-MM-dd',
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
_buildRow(
|
|
|
|
_buildRow(
|
|
|
|
title: '接受人',
|
|
|
|
title: '接受人',
|
|
|
|
subTitle: '金礼伟',
|
|
|
|
subTitle: _model.decorationFBIVo.director,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
_buildRow(title: '所属项目', subTitle: '装修管理'),
|
|
|
|
_buildRow(title: '所属项目', subTitle: '装修管理'),
|
|
|
|
_buildRow(
|
|
|
|
_buildRow(
|
|
|
|
title: '开始日期',
|
|
|
|
title: '开始日期',
|
|
|
|
subTitle: DateUtil.formatDateStr(
|
|
|
|
subTitle: DateUtil.formatDateStr(
|
|
|
|
'2021-5-20 13:14',
|
|
|
|
_model.trackInspectionFBIVo.startDate,
|
|
|
|
format: 'yyyy-MM-dd',
|
|
|
|
format: 'yyyy-MM-dd',
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
@ -284,6 +325,7 @@ class _DecorationManagerDetailStatePage
|
|
|
|
CHECK_TYPE.WATER,
|
|
|
|
CHECK_TYPE.WATER,
|
|
|
|
CHECK_TYPE.WALL,
|
|
|
|
CHECK_TYPE.WALL,
|
|
|
|
CHECK_TYPE.DOOR_AND_WINDOWS,
|
|
|
|
CHECK_TYPE.DOOR_AND_WINDOWS,
|
|
|
|
|
|
|
|
CHECK_TYPE.SECURITY,
|
|
|
|
],
|
|
|
|
],
|
|
|
|
onChange: (details) {},
|
|
|
|
onChange: (details) {},
|
|
|
|
),
|
|
|
|
),
|
|
|
@ -300,14 +342,14 @@ class _DecorationManagerDetailStatePage
|
|
|
|
_buildRow(
|
|
|
|
_buildRow(
|
|
|
|
title: '开始装修时间',
|
|
|
|
title: '开始装修时间',
|
|
|
|
subTitle: DateUtil.formatDateStr(
|
|
|
|
subTitle: DateUtil.formatDateStr(
|
|
|
|
'2021-05-20 13:14:00',
|
|
|
|
_model.decorationFBIVo.actualBegin,
|
|
|
|
format: 'yyyy-MM-dd',
|
|
|
|
format: 'yyyy-MM-dd',
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
_buildRow(
|
|
|
|
_buildRow(
|
|
|
|
title: '接受人',
|
|
|
|
title: '接受人',
|
|
|
|
subTitle: '黄鑫',
|
|
|
|
subTitle: '黄鑫',
|
|
|
|
onTap: UserTool.userProvider.infoModel.canOperation
|
|
|
|
onTap: UserTool.userProvider.infoModel.canDecorationTrack
|
|
|
|
? () {
|
|
|
|
? () {
|
|
|
|
// Get.to(DecorationDepartmentPage(
|
|
|
|
// Get.to(DecorationDepartmentPage(
|
|
|
|
// model: widget.model,
|
|
|
|
// model: widget.model,
|
|
|
@ -322,7 +364,7 @@ class _DecorationManagerDetailStatePage
|
|
|
|
'2021-05-20 13:14:00',
|
|
|
|
'2021-05-20 13:14:00',
|
|
|
|
format: 'yyyy-MM-dd',
|
|
|
|
format: 'yyyy-MM-dd',
|
|
|
|
),
|
|
|
|
),
|
|
|
|
onTap: UserTool.userProvider.infoModel.canOperation
|
|
|
|
onTap: UserTool.userProvider.infoModel.canDecorationTrack
|
|
|
|
? () {
|
|
|
|
? () {
|
|
|
|
showAkuSheet(
|
|
|
|
showAkuSheet(
|
|
|
|
child: Column(
|
|
|
|
child: Column(
|
|
|
@ -373,8 +415,8 @@ class _DecorationManagerDetailStatePage
|
|
|
|
),
|
|
|
|
),
|
|
|
|
_buildRow(
|
|
|
|
_buildRow(
|
|
|
|
title: '检查周期',
|
|
|
|
title: '检查周期',
|
|
|
|
subTitle: '${15}天',
|
|
|
|
subTitle: '${_model.trackInspectionFBIVo.inspectionCycle}天',
|
|
|
|
onTap: UserTool.userProvider.infoModel.canOperation
|
|
|
|
onTap: UserTool.userProvider.infoModel.canDecorationTrack
|
|
|
|
? () {
|
|
|
|
? () {
|
|
|
|
showAkuSheet(
|
|
|
|
showAkuSheet(
|
|
|
|
child: Column(
|
|
|
|
child: Column(
|
|
|
@ -481,7 +523,7 @@ class _DecorationManagerDetailStatePage
|
|
|
|
CHECK_TYPE.SECURITY,
|
|
|
|
CHECK_TYPE.SECURITY,
|
|
|
|
],
|
|
|
|
],
|
|
|
|
onChange: (details) {},
|
|
|
|
onChange: (details) {},
|
|
|
|
canTap: UserTool.userProvider.infoModel.canOperation,
|
|
|
|
canTap: UserTool.userProvider.infoModel.canDecorationTrack,
|
|
|
|
)
|
|
|
|
)
|
|
|
|
],
|
|
|
|
],
|
|
|
|
);
|
|
|
|
);
|
|
|
@ -492,7 +534,7 @@ class _DecorationManagerDetailStatePage
|
|
|
|
return AkuTitleBox(
|
|
|
|
return AkuTitleBox(
|
|
|
|
title: '执行信息',
|
|
|
|
title: '执行信息',
|
|
|
|
spacing: 24,
|
|
|
|
spacing: 24,
|
|
|
|
children: [].map((e) {
|
|
|
|
children: _model.trackRecordVos.map((e) {
|
|
|
|
return Container(
|
|
|
|
return Container(
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
border: Border(
|
|
|
|
border: Border(
|
|
|
@ -515,7 +557,7 @@ class _DecorationManagerDetailStatePage
|
|
|
|
AkuBox.h(96),
|
|
|
|
AkuBox.h(96),
|
|
|
|
Text(
|
|
|
|
Text(
|
|
|
|
'${DateUtil.formatDateStr('2021-5-20 13:14', format: 'yyyy-MM-dd')} ' +
|
|
|
|
'${DateUtil.formatDateStr('2021-5-20 13:14', format: 'yyyy-MM-dd')} ' +
|
|
|
|
e.checkType,
|
|
|
|
e.typeString,
|
|
|
|
style: TextStyle(
|
|
|
|
style: TextStyle(
|
|
|
|
color: AppStyle.primaryTextColor,
|
|
|
|
color: AppStyle.primaryTextColor,
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
@ -526,7 +568,7 @@ class _DecorationManagerDetailStatePage
|
|
|
|
Text(
|
|
|
|
Text(
|
|
|
|
3 > 2 ? '正常' : '异常',
|
|
|
|
3 > 2 ? '正常' : '异常',
|
|
|
|
style: TextStyle(
|
|
|
|
style: TextStyle(
|
|
|
|
color: e.checkAllResult
|
|
|
|
color: e.result==1
|
|
|
|
? Color(0xFF32B814)
|
|
|
|
? Color(0xFF32B814)
|
|
|
|
: Color(0xFFFF4501),
|
|
|
|
: Color(0xFFFF4501),
|
|
|
|
fontSize: 28.sp,
|
|
|
|
fontSize: 28.sp,
|
|
|
@ -537,7 +579,7 @@ class _DecorationManagerDetailStatePage
|
|
|
|
expanded: Column(
|
|
|
|
expanded: Column(
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
children: [
|
|
|
|
children: [
|
|
|
|
...[].map((e) {
|
|
|
|
...e.recordDetailVoList.map((e) {
|
|
|
|
return Container(
|
|
|
|
return Container(
|
|
|
|
height: 96.w,
|
|
|
|
height: 96.w,
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
decoration: BoxDecoration(
|
|
|
@ -556,7 +598,7 @@ class _DecorationManagerDetailStatePage
|
|
|
|
height: 40.w,
|
|
|
|
height: 40.w,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
Text(
|
|
|
|
Text(
|
|
|
|
'233',
|
|
|
|
e.qualifiedString,
|
|
|
|
style: TextStyle(
|
|
|
|
style: TextStyle(
|
|
|
|
fontSize: 28.sp,
|
|
|
|
fontSize: 28.sp,
|
|
|
|
color: AppStyle.primaryTextColor,
|
|
|
|
color: AppStyle.primaryTextColor,
|
|
|
@ -594,7 +636,7 @@ class _DecorationManagerDetailStatePage
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
TextSpan(
|
|
|
|
TextSpan(
|
|
|
|
text: 'e.info',
|
|
|
|
text: e.description,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
],
|
|
|
|
style: TextStyle(
|
|
|
|
style: TextStyle(
|
|
|
|