Files
fcs/lib/pages/widgets/length_picker.dart

376 lines
11 KiB
Dart
Raw Normal View History

2020-10-14 01:51:53 +06:30
import 'package:fcs/helpers/theme.dart';
import 'package:fcs/pages/widgets/local_text.dart';
import 'package:flutter/material.dart';
import 'input_text.dart';
2021-01-23 23:55:53 +06:30
const MAX_INC = 50.0;
const MAX_FEET = 25.0;
2020-10-14 01:51:53 +06:30
class LengthPicker extends StatefulWidget {
2021-09-10 14:25:37 +06:30
final TextEditingController? controller;
final String? lableKey;
2020-10-14 16:53:16 +06:30
final bool isReadOnly;
2020-12-01 19:02:21 +06:30
final bool displayFeet;
2020-10-14 01:51:53 +06:30
2020-10-21 02:59:10 +06:30
const LengthPicker(
2021-09-10 14:25:37 +06:30
{Key? key,
2020-12-01 19:02:21 +06:30
this.controller,
this.lableKey,
this.isReadOnly = false,
this.displayFeet = false})
2020-10-14 01:51:53 +06:30
: super(key: key);
@override
_LengthPickerState createState() => _LengthPickerState();
}
class _LengthPickerState extends State<LengthPicker> {
TextEditingController _controller = TextEditingController();
@override
void initState() {
super.initState();
if (widget.controller != null) {
_setText();
2021-09-10 14:25:37 +06:30
widget.controller!.addListener(() {
2020-10-14 01:51:53 +06:30
_setText();
});
}
}
_setText() {
2024-01-09 13:11:22 +06:30
double v = double.parse(widget.controller!.text);
2020-12-01 19:02:21 +06:30
int _v = v.toInt();
2020-10-16 10:58:31 +06:30
int f = (v / 12).floor();
2020-10-14 01:51:53 +06:30
int ins = (v % 12).round();
2020-10-16 10:58:31 +06:30
2020-12-01 19:02:21 +06:30
_controller.text = widget.displayFeet ? "$f' $ins\"" : "$_v\"";
2020-10-14 01:51:53 +06:30
}
@override
Widget build(BuildContext context) {
return InkWell(
2020-10-21 02:59:10 +06:30
onTap: widget.isReadOnly ? null : () => _showDialog(context),
2020-10-14 01:51:53 +06:30
child: Padding(
padding: EdgeInsets.only(left: 8, right: 8),
child: InputText(
enabled: false,
labelTextKey: widget.lableKey,
controller: _controller,
textInputType: TextInputType.number,
2020-12-01 19:02:21 +06:30
textAlign: widget.displayFeet ? TextAlign.end : TextAlign.center,
2020-10-14 01:51:53 +06:30
)),
);
}
void _showDialog(BuildContext context) {
showDialog(
context: context,
builder: (BuildContext context) {
return LengthPickerDialog(
2021-09-10 14:25:37 +06:30
controller: widget.controller!,
labelKey: widget.lableKey!,
2020-12-01 19:02:21 +06:30
displayFeet: widget.displayFeet,
2020-10-14 01:51:53 +06:30
);
},
);
}
}
class LengthPickerDialog extends StatefulWidget {
2021-09-10 14:25:37 +06:30
final TextEditingController? controller;
final String? labelKey;
final bool? displayFeet;
2020-10-14 01:51:53 +06:30
2020-12-01 19:02:21 +06:30
const LengthPickerDialog(
2021-09-10 14:25:37 +06:30
{Key? key, this.controller, this.labelKey, this.displayFeet})
2020-10-15 17:33:43 +06:30
: super(key: key);
2020-10-14 01:51:53 +06:30
@override
_LengthPickerDialogState createState() => _LengthPickerDialogState();
}
class _LengthPickerDialogState extends State<LengthPickerDialog> {
2021-09-10 14:25:37 +06:30
late int _valueFeet;
late int _valueInc;
2021-01-23 23:55:53 +06:30
TextEditingController inchInputController = TextEditingController();
TextEditingController feetInputController = TextEditingController();
final _focusNode = FocusNode();
2020-10-14 01:51:53 +06:30
@override
void initState() {
super.initState();
_valueFeet = 0;
_valueInc = 0;
if (widget.controller != null) {
2024-01-09 13:11:22 +06:30
double v = double.parse(widget.controller!.text);
2020-10-16 10:58:31 +06:30
_valueFeet = (v / 12).floor();
2021-09-10 14:25:37 +06:30
_valueInc = widget.displayFeet! ? (v % 12).toInt() : v.toInt();
2021-01-23 23:55:53 +06:30
inchInputController.text = _valueInc.toString();
feetInputController.text = _valueFeet.toString();
2020-10-14 01:51:53 +06:30
}
2021-01-23 23:55:53 +06:30
_focusNode.addListener(() {
if (_focusNode.hasFocus) {
inchInputController.selection = TextSelection(
baseOffset: 0, extentOffset: inchInputController.text.length);
}
});
2020-10-14 01:51:53 +06:30
}
@override
Widget build(BuildContext context) {
2021-01-23 23:55:53 +06:30
final inchBox = Column(
children: [
Text("Inch"),
Row(
children: [
Expanded(
child: TextFormField(
focusNode: _focusNode,
autofocus: true,
onChanged: _updateInputInch,
textAlign: TextAlign.center,
controller: inchInputController,
2024-01-29 17:18:23 +06:30
cursorColor: primaryColor,
2021-01-23 23:55:53 +06:30
keyboardType: TextInputType.numberWithOptions(
signed: false, decimal: true),
decoration: new InputDecoration(
contentPadding: EdgeInsets.all(10),
isDense: true,
focusedBorder: OutlineInputBorder(
borderSide: BorderSide(color: primaryColor, width: 1.0),
),
enabledBorder: OutlineInputBorder(
2021-09-10 16:48:24 +06:30
borderSide:
BorderSide(color: Colors.grey.shade400, width: 1.0),
2021-01-23 23:55:53 +06:30
),
),
),
),
Column(
children: [
InkWell(
onTap: () => _addInc(1),
2021-01-24 22:51:00 +06:30
child: Padding(
padding: const EdgeInsets.all(3.0),
child: Icon(
Icons.add,
color: primaryColor,
),
2021-01-23 23:55:53 +06:30
),
),
InkWell(
onTap: () => _addInc(-1),
2021-01-24 22:51:00 +06:30
child: Padding(
padding: const EdgeInsets.all(3.0),
child: Icon(
Icons.remove,
color: primaryColor,
),
2021-01-23 23:55:53 +06:30
),
)
],
)
],
)
],
);
2024-01-29 17:18:23 +06:30
final feetBox = Column(
2021-01-23 23:55:53 +06:30
children: [
Text("Feet"),
Row(
children: [
Expanded(
child: TextFormField(
onChanged: _updateInputFeet,
textAlign: TextAlign.center,
controller: feetInputController,
keyboardType: TextInputType.numberWithOptions(
signed: false, decimal: true),
2024-01-29 17:18:23 +06:30
cursorColor: primaryColor,
2021-01-23 23:55:53 +06:30
decoration: new InputDecoration(
contentPadding: EdgeInsets.all(10),
isDense: true,
focusedBorder: OutlineInputBorder(
borderSide: BorderSide(color: primaryColor, width: 1.0),
),
enabledBorder: OutlineInputBorder(
2021-09-10 16:48:24 +06:30
borderSide:
BorderSide(color: Colors.grey.shade400, width: 1.0),
2021-01-23 23:55:53 +06:30
),
),
),
),
Column(
children: [
InkWell(
onTap: () => _addFeet(1),
2021-01-24 22:51:00 +06:30
child: Padding(
padding: const EdgeInsets.all(3.0),
child: Icon(
Icons.add,
color: primaryColor,
),
2021-01-23 23:55:53 +06:30
),
),
InkWell(
onTap: () => _addFeet(-1),
2021-01-24 22:51:00 +06:30
child: Padding(
padding: const EdgeInsets.all(3.0),
child: Icon(
Icons.remove,
color: primaryColor,
),
2021-01-23 23:55:53 +06:30
),
)
],
)
],
)
],
);
2020-10-14 01:51:53 +06:30
return SimpleDialog(
title: Center(
child: LocalText(
context,
2021-09-10 14:25:37 +06:30
widget.labelKey!,
2020-10-14 01:51:53 +06:30
color: primaryColor,
fontSize: 16,
)),
children: [
2021-01-23 23:55:53 +06:30
Row(
mainAxisAlignment: MainAxisAlignment.spaceAround,
2021-09-10 14:25:37 +06:30
children: widget.displayFeet!
2021-01-23 23:55:53 +06:30
? [
Container(width: 100, child: feetBox),
Container(width: 100, child: inchBox),
]
: [
Container(width: 100, child: inchBox),
],
),
SizedBox(
height: 10,
),
2021-09-10 14:25:37 +06:30
widget.displayFeet!
2020-12-01 19:02:21 +06:30
? Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Padding(
padding: const EdgeInsets.only(top: 8.0, left: 8),
child: LocalText(
context,
"feet",
color: primaryColor,
fontSize: 12,
),
),
Slider(
2024-01-25 17:40:35 +06:30
inactiveColor: Colors.grey.shade200,
2020-12-01 19:02:21 +06:30
activeColor: primaryColor,
2021-01-23 23:55:53 +06:30
value: _valueFeet.toDouble() > MAX_FEET
? 0
: _valueFeet.toDouble(),
2020-12-01 19:02:21 +06:30
min: 0,
2021-01-23 23:55:53 +06:30
max: MAX_FEET,
2020-12-01 19:02:21 +06:30
divisions: 100,
2021-09-10 16:48:24 +06:30
label: _valueFeet.round().toString(),
2020-12-01 19:02:21 +06:30
onChanged: (double v) {
_updateFeet(v);
},
),
],
)
: Container(),
2020-10-14 01:51:53 +06:30
Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Padding(
2024-01-29 17:18:23 +06:30
padding: const EdgeInsets.only(top: 8.0, left: 15),
2020-10-14 01:51:53 +06:30
child: LocalText(
context,
"inch",
color: primaryColor,
fontSize: 12,
),
),
Slider(
2024-01-25 17:40:35 +06:30
inactiveColor: Colors.grey.shade200,
2020-10-14 01:51:53 +06:30
activeColor: primaryColor,
2021-09-10 14:25:37 +06:30
value: _valueInc.toDouble() > (widget.displayFeet! ? 11 : MAX_INC)
2021-01-23 23:55:53 +06:30
? 0
: _valueInc.toDouble(),
2020-10-14 01:51:53 +06:30
min: 0,
2021-09-10 14:25:37 +06:30
max: widget.displayFeet! ? 11 : MAX_INC,
2020-10-14 01:51:53 +06:30
divisions: 100,
2021-09-10 16:48:24 +06:30
label: _valueInc.round().toString(),
2020-10-14 01:51:53 +06:30
onChanged: (double v) {
_updateInc(v);
},
),
],
)
],
);
}
_updateFeet(double v) {
setState(() {
2020-10-16 10:58:31 +06:30
_valueFeet = v.toInt();
2020-10-14 01:51:53 +06:30
});
2021-01-23 23:55:53 +06:30
int _v = _valueInc.round() + _valueFeet.round() * 12;
2020-10-14 01:51:53 +06:30
if (widget.controller != null) {
2021-09-10 14:25:37 +06:30
widget.controller!.text = _v.toString();
2020-10-14 01:51:53 +06:30
}
2021-01-23 23:55:53 +06:30
feetInputController.text =
2021-09-10 14:25:37 +06:30
widget.displayFeet! ? _valueFeet.round().toString() : _v.toString();
2020-10-14 01:51:53 +06:30
}
_updateInc(double v) {
setState(() {
2020-10-16 10:58:31 +06:30
_valueInc = v.toInt();
2020-10-14 01:51:53 +06:30
});
2021-01-23 23:55:53 +06:30
int _v = _valueInc.round() + _valueFeet.round() * 12;
if (widget.controller != null) {
2021-09-10 14:25:37 +06:30
widget.controller!.text =
widget.displayFeet! ? _v.toString() : _valueInc.toString();
2021-01-23 23:55:53 +06:30
}
inchInputController.text = _valueInc.toString();
}
_updateInputInch(String value) {
int val = int.tryParse(value) ?? _valueInc;
setState(() {
_valueInc = val.toInt();
});
int _v = _valueInc.round() + _valueFeet.round() * 12;
2020-10-14 01:51:53 +06:30
if (widget.controller != null) {
2021-09-10 14:25:37 +06:30
widget.controller!.text =
widget.displayFeet! ? _v.toString() : _valueInc.toString();
2020-10-14 01:51:53 +06:30
}
}
2021-01-23 23:55:53 +06:30
_updateInputFeet(String value) {
int val = int.tryParse(value) ?? _valueInc;
setState(() {
_valueFeet = val.toInt();
});
int _v = _valueInc.round() + _valueFeet.round() * 12;
if (widget.controller != null) {
2021-09-10 14:25:37 +06:30
widget.controller!.text = _v.toString();
2021-01-23 23:55:53 +06:30
}
}
_addInc(int v) {
int value = int.tryParse(inchInputController.text) ?? 0;
_updateInc((value + v).toDouble());
}
2020-12-01 19:02:21 +06:30
2021-01-23 23:55:53 +06:30
_addFeet(int v) {
int value = int.tryParse(feetInputController.text) ?? 0;
_updateFeet((value + v).toDouble());
2020-10-14 01:51:53 +06:30
}
}