snag issues resolve
parent
b6c08450fe
commit
60639620c6
@ -0,0 +1,109 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:test_sa/extensions/context_extension.dart';
|
||||||
|
import 'package:test_sa/extensions/int_extensions.dart';
|
||||||
|
import 'package:test_sa/extensions/text_extensions.dart';
|
||||||
|
import 'package:test_sa/extensions/widget_extensions.dart';
|
||||||
|
import 'package:test_sa/new_views/app_style/app_color.dart';
|
||||||
|
import 'package:test_sa/new_views/common_widgets/app_filled_button.dart';
|
||||||
|
|
||||||
|
typedef SelectionBuilderString = String Function(dynamic);
|
||||||
|
|
||||||
|
class SelectionBottomSheet<T> extends StatefulWidget {
|
||||||
|
List<T> items;
|
||||||
|
T selectedItem;
|
||||||
|
String title;
|
||||||
|
|
||||||
|
final SelectionBuilderString builderString;
|
||||||
|
|
||||||
|
SelectionBottomSheet({Key key, this.items = const [], this.selectedItem, this.title = "", @required this.builderString}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_SelectionBottomSheetState createState() {
|
||||||
|
return _SelectionBottomSheetState();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class _SelectionBottomSheetState<T> extends State<SelectionBottomSheet> {
|
||||||
|
T _selectedValue;
|
||||||
|
|
||||||
|
String query = "";
|
||||||
|
|
||||||
|
List<T> get filteredList => widget.items.where((element) => element.name.toString().toLowerCase().contains(query.toLowerCase())).toList();
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
_selectedValue = widget.selectedItem;
|
||||||
|
super.initState();
|
||||||
|
}
|
||||||
|
|
||||||
|
FocusNode searchFocusNode = FocusNode();
|
||||||
|
|
||||||
|
@override
|
||||||
|
void dispose() {
|
||||||
|
super.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return Container(
|
||||||
|
height: MediaQuery.of(context).size.height * .7,
|
||||||
|
padding: const EdgeInsets.all(21),
|
||||||
|
child: Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
widget.title.heading5(context),
|
||||||
|
16.height,
|
||||||
|
TextField(
|
||||||
|
onChanged: (queryString) {
|
||||||
|
query = queryString;
|
||||||
|
setState(() {});
|
||||||
|
},
|
||||||
|
style: TextStyle(fontSize: 14),
|
||||||
|
focusNode: searchFocusNode,
|
||||||
|
decoration: InputDecoration(
|
||||||
|
hintText: 'Search by name',
|
||||||
|
labelText: 'Search',
|
||||||
|
hintStyle: TextStyle(fontSize: 14),
|
||||||
|
focusedBorder: OutlineInputBorder(
|
||||||
|
borderSide: BorderSide(color: AppColor.blueStatus(context), width: 2.0),
|
||||||
|
borderRadius: BorderRadius.all(Radius.circular(12.0)),
|
||||||
|
),
|
||||||
|
enabledBorder: OutlineInputBorder(
|
||||||
|
borderSide: BorderSide(color: AppColor.blueStatus(context), width: 1.0),
|
||||||
|
borderRadius: BorderRadius.all(Radius.circular(12.0)),
|
||||||
|
),
|
||||||
|
contentPadding: EdgeInsets.symmetric(vertical: 8.0, horizontal: 16.0),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
8.height,
|
||||||
|
ListView.builder(
|
||||||
|
itemCount: filteredList.length,
|
||||||
|
padding: EdgeInsets.only(top: 8),
|
||||||
|
itemBuilder: (cxt, index) => RadioListTile(
|
||||||
|
value: filteredList[index],
|
||||||
|
dense: true,
|
||||||
|
contentPadding: EdgeInsets.zero,
|
||||||
|
groupValue: _selectedValue,
|
||||||
|
activeColor: Colors.black87,
|
||||||
|
onChanged: (value) {
|
||||||
|
_selectedValue = value;
|
||||||
|
searchFocusNode.unfocus();
|
||||||
|
setState(() {});
|
||||||
|
},
|
||||||
|
title: Text(
|
||||||
|
widget.builderString(filteredList[index]).cleanupWhitespace?.capitalizeFirstOfEach ?? "",
|
||||||
|
style: Theme.of(context).textTheme.bodyLarge,
|
||||||
|
))).expanded,
|
||||||
|
8.height,
|
||||||
|
if (_selectedValue != null)
|
||||||
|
AppFilledButton(
|
||||||
|
label: context.translation.select,
|
||||||
|
maxWidth: true,
|
||||||
|
onPressed: () {
|
||||||
|
Navigator.pop(context, _selectedValue);
|
||||||
|
}),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,88 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:flutter_typeahead/flutter_typeahead.dart';
|
||||||
|
import 'package:provider/provider.dart';
|
||||||
|
import 'package:test_sa/controllers/providers/api/devices_provider.dart';
|
||||||
|
import 'package:test_sa/controllers/providers/api/user_provider.dart';
|
||||||
|
import 'package:test_sa/controllers/providers/settings/setting_provider.dart';
|
||||||
|
import 'package:test_sa/extensions/context_extension.dart';
|
||||||
|
import 'package:test_sa/extensions/int_extensions.dart';
|
||||||
|
import 'package:test_sa/extensions/widget_extensions.dart';
|
||||||
|
import 'package:test_sa/models/lookup.dart';
|
||||||
|
import 'package:test_sa/views/app_style/sizing.dart';
|
||||||
|
import 'package:test_sa/views/widgets/equipment/pick_asset.dart';
|
||||||
|
|
||||||
|
import '../../../../extensions/text_extensions.dart';
|
||||||
|
import '../../../../models/device/asset.dart';
|
||||||
|
import '../../../../models/device/asset_search.dart';
|
||||||
|
import '../../../../new_views/app_style/app_color.dart';
|
||||||
|
import '../../../../new_views/app_style/app_text_style.dart';
|
||||||
|
|
||||||
|
class CalibrationToolAssetPicker extends StatefulWidget {
|
||||||
|
final Lookup initialValue;
|
||||||
|
final int hospitalId;
|
||||||
|
final Function(Lookup) onPick;
|
||||||
|
|
||||||
|
const CalibrationToolAssetPicker({Key key, this.initialValue, this.onPick, this.hospitalId}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<CalibrationToolAssetPicker> createState() => _CalibrationToolAssetPickerState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _CalibrationToolAssetPickerState extends State<CalibrationToolAssetPicker> {
|
||||||
|
SettingProvider _settingProvider;
|
||||||
|
AssetProvider _devicesProvider;
|
||||||
|
UserProvider _userProvider;
|
||||||
|
TextEditingController _controller;
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
_controller = TextEditingController(text: widget.initialValue?.name);
|
||||||
|
super.initState();
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void didUpdateWidget(covariant CalibrationToolAssetPicker oldWidget) {
|
||||||
|
if (widget.initialValue != oldWidget.initialValue) {
|
||||||
|
_controller = TextEditingController(text: widget.initialValue?.name);
|
||||||
|
}
|
||||||
|
super.didUpdateWidget(oldWidget);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void dispose() {
|
||||||
|
_controller.dispose();
|
||||||
|
super.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
_settingProvider = Provider.of<SettingProvider>(context);
|
||||||
|
_userProvider = Provider.of<UserProvider>(context);
|
||||||
|
_devicesProvider = Provider.of<AssetProvider>(context);
|
||||||
|
final border = UnderlineInputBorder(borderSide: BorderSide.none, borderRadius: BorderRadius.circular(10));
|
||||||
|
return Container(
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
color: AppColor.background(context),
|
||||||
|
borderRadius: BorderRadius.circular(AppStyle.borderRadius * AppStyle.getScaleFactor(context)),
|
||||||
|
boxShadow: [BoxShadow(color: Colors.black.withOpacity(0.05), blurRadius: 10)],
|
||||||
|
),
|
||||||
|
child: Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
PickAsset(
|
||||||
|
showAssetInfo: false,
|
||||||
|
forPPM: true,
|
||||||
|
device: widget.initialValue == null
|
||||||
|
? null
|
||||||
|
: Asset(
|
||||||
|
id: widget.initialValue.id,
|
||||||
|
assetNumber: widget.initialValue.name,
|
||||||
|
),
|
||||||
|
onPickAsset: (device) {
|
||||||
|
widget.onPick(Lookup(id: device.id, name: device.assetNumber));
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue