You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
173 lines
6.9 KiB
Dart
173 lines
6.9 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:provider/provider.dart';
|
|
import 'package:test_sa/controllers/providers/api/ppm_provider.dart';
|
|
import 'package:test_sa/controllers/providers/api/user_provider.dart';
|
|
import 'package:test_sa/extensions/context_extension.dart';
|
|
import 'package:test_sa/extensions/int_extensions.dart';
|
|
import 'package:test_sa/extensions/string_extensions.dart';
|
|
import 'package:test_sa/extensions/widget_extensions.dart';
|
|
import 'package:test_sa/models/all_requests_and_count_model.dart';
|
|
import 'package:test_sa/models/plan_preventive_visit/plan_preventive_visit_model.dart';
|
|
import 'package:test_sa/models/ppm/ppm.dart';
|
|
import 'package:test_sa/new_views/app_style/app_color.dart';
|
|
import 'package:test_sa/new_views/common_widgets/app_filled_button.dart';
|
|
import 'package:test_sa/new_views/common_widgets/default_app_bar.dart';
|
|
import 'package:test_sa/views/pages/user/ppm/update_ppm/ppm_external_details_form.dart';
|
|
|
|
import '../../../../../extensions/text_extensions.dart';
|
|
import 'ppm_calibration_tools_form.dart';
|
|
import 'ppm_pm_check_list_form.dart';
|
|
import 'ppm_pm_kits_form.dart';
|
|
import 'wo_info_form.dart';
|
|
|
|
class UpdatePpm extends StatefulWidget {
|
|
final Ppm? ppm;
|
|
final PlanPreventiveVisit planPreventiveVisit;
|
|
final RequestsDetails? details;
|
|
|
|
const UpdatePpm({Key? key, this.ppm, required this.planPreventiveVisit, this.details}) : super(key: key);
|
|
|
|
@override
|
|
State<UpdatePpm> createState() => _UpdatePpmState();
|
|
}
|
|
|
|
class _UpdatePpmState extends State<UpdatePpm> with SingleTickerProviderStateMixin {
|
|
late UserProvider _userProvider;
|
|
late PpmProvider _regularVisitsProvider;
|
|
Ppm? _ppm;
|
|
|
|
late PlanPreventiveVisit _planPreventiveVisit;
|
|
|
|
final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();
|
|
|
|
late TabController _tabController;
|
|
|
|
_onSubmit() async {
|
|
// if (!(await _ppm.validate(context))) {
|
|
// setState(() {});
|
|
// return;
|
|
// }
|
|
// _ppm.removeEmptyObjects();
|
|
// await _regularVisitsProvider.updatePentry(context, user: _userProvider.user!, ppm: widget.ppm);
|
|
}
|
|
|
|
@override
|
|
void initState() {
|
|
_ppm = widget.ppm;
|
|
_planPreventiveVisit = widget.planPreventiveVisit;
|
|
_tabController = TabController(length: 3, vsync: this);
|
|
super.initState();
|
|
}
|
|
|
|
int tabIndex = 0;
|
|
|
|
@override
|
|
void dispose() {
|
|
_tabController.dispose();
|
|
super.dispose();
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
_userProvider = Provider.of<UserProvider>(context, listen: false);
|
|
_regularVisitsProvider = Provider.of<PpmProvider>(context, listen: false);
|
|
return Scaffold(
|
|
backgroundColor: AppColor.neutral110,
|
|
appBar: DefaultAppBar(title: context.translation.preventiveMaintenance),
|
|
key: _scaffoldKey,
|
|
body: SafeArea(
|
|
child: Column(
|
|
children: [
|
|
DefaultTabController(
|
|
length: 2,
|
|
child: Column(
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: <Widget>[
|
|
Container(
|
|
margin: EdgeInsets.only(left: 16.toScreenWidth, right: 16.toScreenWidth, top: 16.toScreenHeight, bottom: 8),
|
|
decoration: BoxDecoration(
|
|
color: context.isDark ? AppColor.neutral50 : AppColor.white10,
|
|
borderRadius: BorderRadius.circular(10),
|
|
),
|
|
child: TabBar(
|
|
padding: EdgeInsets.symmetric(vertical: 4.toScreenHeight, horizontal: 4.toScreenWidth),
|
|
labelColor: context.isDark ? AppColor.neutral30 : AppColor.black20,
|
|
unselectedLabelColor: context.isDark ? AppColor.neutral30 : AppColor.black20,
|
|
unselectedLabelStyle: AppTextStyles.bodyText,
|
|
labelStyle: AppTextStyles.bodyText,
|
|
indicatorPadding: EdgeInsets.zero,
|
|
indicatorSize: TabBarIndicatorSize.tab,
|
|
dividerColor: Colors.transparent,
|
|
indicator: BoxDecoration(
|
|
color: context.isDark ? AppColor.neutral60 : AppColor.neutral110,
|
|
borderRadius: BorderRadius.circular(7),
|
|
),
|
|
onTap: (index) {
|
|
tabIndex = index;
|
|
if (tabIndex == 0) {
|
|
_tabController.animateTo(0);
|
|
}
|
|
setState(() {});
|
|
},
|
|
tabs: [
|
|
Tab(text: "WO Info".addTranslation, height: 57.toScreenHeight),
|
|
Tab(text: "WO Inspection".addTranslation, height: 57.toScreenHeight),
|
|
],
|
|
),
|
|
),
|
|
TabBarView(
|
|
children: [
|
|
WoInfoForm(planPreventiveVisit: _planPreventiveVisit),
|
|
TabBarView(
|
|
physics: const NeverScrollableScrollPhysics(),
|
|
controller: _tabController,
|
|
children: [
|
|
// PpmExternalDetailsForm(models: []),
|
|
PpmCalibrationToolsForm(models: _planPreventiveVisit.preventiveVisitCalibrations),
|
|
PpmPMKitsForm(models: _planPreventiveVisit.preventiveVisitKits,assetId: _planPreventiveVisit.asset?.id),
|
|
|
|
// PpmExternalDetailsForm(models: _ppm.vCalibrationTools),
|
|
// PpmCalibrationToolsForm(models: _ppm.vCalibrationTools),
|
|
// PpmPMKitsForm(models: _ppm.vKits, assetId: widget.ppm.assetId),
|
|
PpmPmChecklistForm(checkList: _planPreventiveVisit.preventiveVisitChecklists),
|
|
],
|
|
)
|
|
],
|
|
).expanded,
|
|
],
|
|
),
|
|
).expanded,
|
|
Row(
|
|
children: [
|
|
AppFilledButton(
|
|
buttonColor: AppColor.white60,
|
|
textColor: AppColor.neutral50,
|
|
onPressed: () {
|
|
_onSubmit();
|
|
},
|
|
label: context.translation.save,
|
|
).expanded,
|
|
16.width,
|
|
AppFilledButton(
|
|
onPressed: () {
|
|
if (tabIndex == 0) {
|
|
return;
|
|
}
|
|
if (_tabController.index == 3) {
|
|
_onSubmit();
|
|
} else {
|
|
_tabController.animateTo(_tabController.index + 1);
|
|
setState(() {});
|
|
}
|
|
},
|
|
label: tabIndex == 0 ? "Complete".addTranslation : (_tabController.index == 3 ? "Complete".addTranslation : context.translation.next),
|
|
).expanded,
|
|
],
|
|
).toShadowContainer(context, showShadow: false, borderRadius: 0),
|
|
],
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|