create asset transfer, on internal & external destination values reset.

design_3.0_TM_Module
Sikander Saleem 2 months ago
parent 79fa949ba2
commit c1a7562e3b

@ -3,14 +3,14 @@ class URLs {
static const String appReleaseBuildNumber = "24"; static const String appReleaseBuildNumber = "24";
static const host1 = "https://atomsm.hmg.com"; // production url // static const host1 = "https://atomsm.hmg.com"; // production url
// static const host1 = "https://atomsmdev.hmg.com"; // local DEV url // static const host1 = "https://atomsmdev.hmg.com"; // local DEV url
// static const host1 = "https://atomsmuat.hmg.com"; // local UAT url static const host1 = "https://atomsmuat.hmg.com"; // local UAT url
// static String _baseUrl = "$_host/mobile"; static String _baseUrl = "$_host/mobile";
// static final String _baseUrl = "$_host/v2/mobile"; // new V2 apis // static final String _baseUrl = "$_host/v2/mobile"; // new V2 apis
// static final String _baseUrl = "$_host/mobile"; // host local UAT // static final String _baseUrl = "$_host/mobile"; // host local UAT
static final String _baseUrl = "$_host/v3/mobile"; // v3 for production CM,PM,TM // static final String _baseUrl = "$_host/v3/mobile"; // v3 for production CM,PM,TM
static String _host = host1; static String _host = host1;

@ -252,6 +252,7 @@ class ServiceRequestDetailProvider extends ChangeNotifier {
} catch (e) { } catch (e) {
log("getWorkOrder [error] : $e"); log("getWorkOrder [error] : $e");
isLoading = false; isLoading = false;
currentWorkOrder = null;
notifyListeners(); notifyListeners();
return null; return null;
} }

@ -137,43 +137,49 @@ class _ServiceRequestDetailViewState extends State<ServiceRequestDetailView> {
children: [ children: [
Row( Row(
mainAxisSize: MainAxisSize.min, mainAxisSize: MainAxisSize.min,
crossAxisAlignment: CrossAxisAlignment.start,
children: [ children: [
if (Provider.of<SettingProvider>(context, listen: false).showPriority) ...[ Wrap(
StatusLabel( // spacing: 8,
label: workOrder.priority?.name, runSpacing: 8,
id: workOrder.priority!.id!, children: [
radius: 4, if (Provider.of<SettingProvider>(context, listen: false).showPriority) ...[
textColor: AppColor.getPriorityStatusTextColor(context, workOrder.priority!.id!), StatusLabel(
backgroundColor: AppColor.getPriorityStatusColor(context, workOrder.priority!.id!), label: workOrder.priority?.name,
), id: workOrder.priority!.id!,
8.width, radius: 4,
], textColor: AppColor.getPriorityStatusTextColor(context, workOrder.priority!.id!),
if (workOrder.itgFormWorkOrderStatus != null) ...[ backgroundColor: AppColor.getPriorityStatusColor(context, workOrder.priority!.id!),
StatusLabel( ),
label: workOrder.itgFormWorkOrderStatus, 8.width,
id: 0, ],
radius: 4, if (workOrder.itgFormWorkOrderStatus != null) ...[
textColor: AppColor.getPriorityStatusTextColor(context, 82), StatusLabel(
backgroundColor: AppColor.getPriorityStatusColor(context, 0), label: workOrder.itgFormWorkOrderStatus,
), id: 0,
8.width, radius: 4,
], textColor: AppColor.getPriorityStatusTextColor(context, 82),
StatusLabel( backgroundColor: AppColor.getPriorityStatusColor(context, 0),
radius: 4, ),
label: workOrder.status!.name, 8.width,
textColor: AppColor.getHistoryLogStatusTextColorByName(workOrder.status!.name!), ],
backgroundColor: AppColor.getHistoryLogStatusColorByName(workOrder.status!.name!), StatusLabel(
), radius: 4,
if (workOrder.since != null) ...[ label: workOrder.status!.name,
8.width, textColor: AppColor.getHistoryLogStatusTextColorByName(workOrder.status!.name!),
StatusLabel( backgroundColor: AppColor.getHistoryLogStatusColorByName(workOrder.status!.name!),
radius: 4, ),
label: '${workOrder.since} days', if (workOrder.since != null) ...[
textColor: AppColor.neutral50, 8.width,
backgroundColor: AppColor.orange30, StatusLabel(
), radius: 4,
], label: '${workOrder.since} days',
1.width.expanded, textColor: AppColor.neutral50,
backgroundColor: AppColor.orange30,
),
],
],
).expanded,
Column( Column(
crossAxisAlignment: CrossAxisAlignment.end, crossAxisAlignment: CrossAxisAlignment.end,
children: [ children: [
@ -181,7 +187,7 @@ class _ServiceRequestDetailViewState extends State<ServiceRequestDetailView> {
// context.translation.code.toSvgAsset(width: 48).onPress(() { // context.translation.code.toSvgAsset(width: 48).onPress(() {
// // Navigator.push(context, MaterialPageRoute(builder: (context) => UpdateServiceRequestPage(serviceRequest: serviceRequest))); // // Navigator.push(context, MaterialPageRoute(builder: (context) => UpdateServiceRequestPage(serviceRequest: serviceRequest)));
// }), // }),
if (userProvider.user!.type == UsersTypes.engineer) 16.height, // if (userProvider.user!.type == UsersTypes.engineer) 16.height,
Text( Text(
workOrder.requestedDate!.toString().toServiceRequestCardFormat, workOrder.requestedDate!.toString().toServiceRequestCardFormat,
textAlign: TextAlign.end, textAlign: TextAlign.end,
@ -191,6 +197,7 @@ class _ServiceRequestDetailViewState extends State<ServiceRequestDetailView> {
) )
], ],
), ),
8.height,
Text( Text(
context.translation.assetInformation, context.translation.assetInformation,
style: AppTextStyles.heading4.copyWith(color: context.isDark ? AppColor.neutral30 : AppColor.neutral50), style: AppTextStyles.heading4.copyWith(color: context.isDark ? AppColor.neutral30 : AppColor.neutral50),
@ -507,9 +514,7 @@ class _ServiceRequestDetailViewState extends State<ServiceRequestDetailView> {
style: AppTextStyles.heading4.copyWith(color: context.isDark ? AppColor.neutral30 : AppColor.neutral50), style: AppTextStyles.heading4.copyWith(color: context.isDark ? AppColor.neutral30 : AppColor.neutral50),
).expanded, ).expanded,
if (!provider.isReadOnlyRequest) if (!provider.isReadOnlyRequest)
"edit_icon".toSvgAsset(height: 21, width: 21, "edit_icon".toSvgAsset(height: 21, width: 21, color: context.isDark ? AppColor.primary10 : null).onPress(() async {
color: context.isDark?AppColor.primary10:null
).onPress(() async {
provider.refreshTimer = false; provider.refreshTimer = false;
await Navigator.push(context, MaterialPageRoute(builder: (context) => CostDetailFormScreen(isEdit: true))); await Navigator.push(context, MaterialPageRoute(builder: (context) => CostDetailFormScreen(isEdit: true)));
provider.refreshTimer = true; provider.refreshTimer = true;

@ -16,6 +16,7 @@ class SingleItemDropDownMenu<T extends Base, X extends LoadingListNotifier> exte
final BuildContext context; final BuildContext context;
final Function(T?)? onSelect; // Now accepts nullable values final Function(T?)? onSelect; // Now accepts nullable values
final T? initialValue; final T? initialValue;
final T? disableValue;
final bool enabled; final bool enabled;
final bool showAsBottomSheet; final bool showAsBottomSheet;
final bool showAsFullScreenDialog; final bool showAsFullScreenDialog;
@ -35,6 +36,7 @@ class SingleItemDropDownMenu<T extends Base, X extends LoadingListNotifier> exte
required this.context, required this.context,
this.onSelect, this.onSelect,
this.initialValue, this.initialValue,
this.disableValue,
this.enabled = true, this.enabled = true,
this.height, this.height,
this.showAsBottomSheet = false, this.showAsBottomSheet = false,
@ -160,11 +162,13 @@ class _SingleItemDropDownMenuState<T extends Base, X extends LoadingListNotifier
value: value, value: value,
child: Text( child: Text(
value.name ?? "", // Null-aware operator for value.name value.name ?? "", // Null-aware operator for value.name
style: Theme.of(context).textTheme.bodyMedium?.copyWith(fontWeight: FontWeight.w500, color: context.isDark?AppColor.white10: AppColor.black10), maxLines: 1,
overflow: TextOverflow.ellipsis,
style: Theme.of(context).textTheme.bodyMedium?.copyWith(fontWeight: FontWeight.w500, color: context.isDark ? AppColor.white10 : AppColor.black10),
), ),
); );
}).toList(), }).toList(),
).onPress(widget.showAsFullScreenDialog ).onPress(widget.enabled && widget.showAsFullScreenDialog
? () { ? () {
openDialog(); openDialog();
} }
@ -220,6 +224,7 @@ class _SingleItemDropDownMenuState<T extends Base, X extends LoadingListNotifier
items: ((X == NullableLoadingProvider) ? widget.staticData : provider?.items as List<T>) ?? [], items: ((X == NullableLoadingProvider) ? widget.staticData : provider?.items as List<T>) ?? [],
// Provide default empty list if null // Provide default empty list if null
selectedItem: _selectedItem, selectedItem: _selectedItem,
disableItem: widget.disableValue,
title: widget.title, title: widget.title,
showCancel: widget.showCancel, showCancel: widget.showCancel,
onSelect: (selectedT) { onSelect: (selectedT) {

@ -80,7 +80,7 @@ class _CreateDeviceTransferRequestState extends State<CreateDeviceTransferReques
_formKey.currentState!.save(); _formKey.currentState!.save();
List<AssetTransferAttachment> attachement = []; List<AssetTransferAttachment> attachement = [];
for (var item in attachments) { for (var item in attachments) {
String fileName = ServiceRequestUtils.isLocalUrl(item.name??'') ? ("${item.name??''.split("/").last}|${base64Encode(File(item.name??'').readAsBytesSync())}") :item.name??''; String fileName = ServiceRequestUtils.isLocalUrl(item.name ?? '') ? ("${item.name ?? ''.split("/").last}|${base64Encode(File(item.name ?? '').readAsBytesSync())}") : item.name ?? '';
attachement.add(AssetTransferAttachment(id: item.id, attachmentName: fileName)); attachement.add(AssetTransferAttachment(id: item.id, attachmentName: fileName));
} }
_transferModel.attachments = attachement; _transferModel.attachments = attachement;
@ -135,19 +135,26 @@ class _CreateDeviceTransferRequestState extends State<CreateDeviceTransferReques
backgroundColor: AppColor.white936, backgroundColor: AppColor.white936,
onPick: (asset) async { onPick: (asset) async {
_pickedAsset = asset; _pickedAsset = asset;
if (_pickedAsset?.site != null && _transferModel.transferType?.value == 1) { if (_pickedAsset?.site != null && _transferModel.transferType?.value == 1) {
await _deviceTransferProvider.getSiteData(siteId: int.tryParse(_pickedAsset!.site!.id.toString())); await _deviceTransferProvider.getSiteData(siteId: int.tryParse(_pickedAsset!.site!.id.toString()));
_assetDestination.site = _deviceTransferProvider.internalAssetDestination?.site; _assetDestination.site = _deviceTransferProvider.internalAssetDestination?.site;
_assetDestination.building = null; _assetDestination.building = null;
_assetDestination.floor = null; _assetDestination.floor = null;
_assetDestination.department = null; _assetDestination.department = null;
} else if (_pickedAsset?.site != null && _transferModel.transferType?.value == 2) {
_assetDestination.site = null;
_assetDestination.building = null;
_assetDestination.floor = null;
_assetDestination.department = null;
} }
setState(() {}); setState(() {});
}), }),
21.height, 21.height,
requestTypeWidget(context), requestTypeWidget(context),
12.height, 12.height,
"Destination".bodyText(context).custom(color:context.isDark?Colors.white: AppColor.white936), "Destination".bodyText(context).custom(color: context.isDark ? Colors.white : AppColor.white936),
12.height, 12.height,
Row( Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween, mainAxisAlignment: MainAxisAlignment.spaceBetween,
@ -156,6 +163,7 @@ class _CreateDeviceTransferRequestState extends State<CreateDeviceTransferReques
context: context, context: context,
title: context.translation.site, title: context.translation.site,
initialValue: _assetDestination.site, initialValue: _assetDestination.site,
disableValue: isInternal ? null : _pickedAsset?.site,
showShadow: false, showShadow: false,
loading: _deviceTransferProvider.isSiteLoading, loading: _deviceTransferProvider.isSiteLoading,
enabled: !isInternal, enabled: !isInternal,
@ -273,7 +281,7 @@ class _CreateDeviceTransferRequestState extends State<CreateDeviceTransferReques
crossAxisAlignment: CrossAxisAlignment.start, crossAxisAlignment: CrossAxisAlignment.start,
mainAxisSize: MainAxisSize.min, mainAxisSize: MainAxisSize.min,
children: [ children: [
context.translation.requestType.bodyText(context).custom(color:context.isDark?Colors.white: AppColor.white936), context.translation.requestType.bodyText(context).custom(color: context.isDark ? Colors.white : AppColor.white936),
8.height, 8.height,
Wrap( Wrap(
runSpacing: 8, runSpacing: 8,
@ -299,7 +307,17 @@ class _CreateDeviceTransferRequestState extends State<CreateDeviceTransferReques
onChanged: (state) { onChanged: (state) {
_transferModel.transferType = element; _transferModel.transferType = element;
isInternal = !isInternal; isInternal = !isInternal;
// _assetDestination = Asset(); if (isInternal) {
_assetDestination.site = _deviceTransferProvider.internalAssetDestination?.site;
_assetDestination.building = null;
_assetDestination.floor = null;
_assetDestination.department = null;
} else {
_assetDestination.site = null;
_assetDestination.building = null;
_assetDestination.floor = null;
_assetDestination.department = null;
}
setState(() {}); setState(() {});
// }); // });
@ -310,7 +328,7 @@ class _CreateDeviceTransferRequestState extends State<CreateDeviceTransferReques
], ],
) )
], ],
).toShimmer(isShow: snapshot.loading,context: context), ).toShimmer(isShow: snapshot.loading, context: context),
], ],
); );
}); });

@ -3,26 +3,29 @@ import 'package:test_sa/extensions/context_extension.dart';
import 'package:test_sa/extensions/int_extensions.dart'; import 'package:test_sa/extensions/int_extensions.dart';
import 'package:test_sa/extensions/text_extensions.dart'; import 'package:test_sa/extensions/text_extensions.dart';
import 'package:test_sa/extensions/widget_extensions.dart'; import 'package:test_sa/extensions/widget_extensions.dart';
import 'package:test_sa/models/base.dart';
import 'package:test_sa/new_views/app_style/app_color.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/app_filled_button.dart';
typedef SelectionBuilderString = String Function(dynamic); typedef SelectionBuilderString = String Function(dynamic);
class SelectionFullScreenDialog<T> extends StatefulWidget { class SelectionFullScreenDialog<T extends Base> extends StatefulWidget {
final List<T>? items; final List<T>? items;
final T? selectedItem; // Now nullable final T? selectedItem; // Now nullable
final T? disableItem; // Now nullable
final String title; final String title;
final bool showCancel; final bool showCancel;
final SelectionBuilderString builderString; final SelectionBuilderString builderString;
final Function(T?) onSelect; final Function(T?) onSelect;
const SelectionFullScreenDialog({Key? key, this.items, this.selectedItem, this.title = "", required this.builderString, this.showCancel = false, required this.onSelect}) : super(key: key); const SelectionFullScreenDialog({Key? key, this.items, this.selectedItem, this.disableItem, this.title = "", required this.builderString, this.showCancel = false, required this.onSelect})
: super(key: key);
@override @override
_SelectionBottomSheetState createState() => _SelectionBottomSheetState<T>(); _SelectionBottomSheetState createState() => _SelectionBottomSheetState<T>();
} }
class _SelectionBottomSheetState<T> extends State<SelectionFullScreenDialog<T>> { class _SelectionBottomSheetState<T extends Base> extends State<SelectionFullScreenDialog<T>> {
T? _selectedValue; // Now nullable T? _selectedValue; // Now nullable
String query = ""; String query = "";
@ -86,12 +89,12 @@ class _SelectionBottomSheetState<T> extends State<SelectionFullScreenDialog<T>>
backgroundColor: WidgetStateProperty.all<Color>( backgroundColor: WidgetStateProperty.all<Color>(
AppColor.fieldBgColor(context), // Your custom background color AppColor.fieldBgColor(context), // Your custom background color
), ),
leading: Icon(Icons.search, color: AppColor.iconColor(context)), leading: Icon(Icons.search, color: AppColor.iconColor(context)),
textStyle: WidgetStateProperty.all<TextStyle>( textStyle: WidgetStateProperty.all<TextStyle>(
TextStyle(color: AppColor.textColor(context), fontSize: 16.0), TextStyle(color: AppColor.textColor(context), fontSize: 16.0),
), ),
hintStyle: WidgetStateProperty.all<TextStyle>( hintStyle: WidgetStateProperty.all<TextStyle>(
TextStyle(color: AppColor.textColor(context), fontSize: 14.0), TextStyle(color: AppColor.textColor(context), fontSize: 14.0),
), ),
hintText: 'Search by name', hintText: 'Search by name',
onChanged: (queryString) { onChanged: (queryString) {
@ -124,39 +127,43 @@ class _SelectionBottomSheetState<T> extends State<SelectionFullScreenDialog<T>>
8.height, 8.height,
Expanded( Expanded(
child: ListView.builder( child: ListView.builder(
itemCount: filteredList?.length, itemCount: filteredList?.length,
padding: EdgeInsets.zero, padding: EdgeInsets.zero,
itemBuilder: (cxt, index) =>Theme( itemBuilder: (cxt, index) {
data: Theme.of(context).copyWith( bool isDisabledItem = widget.disableItem != null && widget.disableItem?.identifier == filteredList![index].identifier;
radioTheme: RadioThemeData( return Theme(
fillColor: MaterialStateColor.resolveWith((states) { data: Theme.of(context).copyWith(
if (states.contains(MaterialState.selected)) { radioTheme: RadioThemeData(
return AppColor.iconColor(context); // Active color fillColor: MaterialStateColor.resolveWith((states) {
} if (states.contains(MaterialState.selected)) {
return Colors.grey; // Inactive color return AppColor.iconColor(context); // Active color
}), }
), return Colors.grey; // Inactive color
), }),
child: RadioListTile<T>( ),
// Specify type for RadioListTile ),
value: filteredList![index], child: RadioListTile<T>(
dense: true, // Specify type for RadioListTile
contentPadding: const EdgeInsets.only(left: 16, right: 16), value: filteredList![index],
groupValue: _selectedValue, dense: true,
activeColor: AppColor.iconColor(context), contentPadding: const EdgeInsets.only(left: 16, right: 16),
hoverColor: Colors.transparent, groupValue: _selectedValue,
onChanged: (value) { activeColor: AppColor.iconColor(context),
_selectedValue = value; hoverColor: Colors.transparent,
searchFocusNode.unfocus(); onChanged: isDisabledItem
setState(() {}); ? null
}, : (value) {
title: Text( _selectedValue = value;
widget.builderString(filteredList![index]).cleanupWhitespace.capitalizeFirstOfEach ?? "", searchFocusNode.unfocus();
style: Theme.of(context).textTheme.bodyLarge, setState(() {});
), },
), title: Text(
), widget.builderString(filteredList![index]).cleanupWhitespace.capitalizeFirstOfEach ?? "",
), style: Theme.of(context).textTheme.bodyLarge?.copyWith(color: isDisabledItem ? AppColor.neutral20:null),
),
),
);
}),
), ),
8.height, 8.height,
if (_selectedValue != null) if (_selectedValue != null)

Loading…
Cancel
Save