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/cupertino.dart';
|
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
|
|
|
|
|
import 'input_text.dart';
|
|
|
|
|
|
|
|
|
|
class LengthPicker extends StatefulWidget {
|
|
|
|
|
final TextEditingController controller;
|
|
|
|
|
final String lableKey;
|
2020-10-14 16:53:16 +06:30
|
|
|
final bool isReadOnly;
|
2020-12-03 08:26:58 +06:30
|
|
|
final bool displayFeet;
|
2020-10-14 01:51:53 +06:30
|
|
|
|
2020-10-21 02:59:10 +06:30
|
|
|
const LengthPicker(
|
2020-12-03 08:26:58 +06:30
|
|
|
{Key key,
|
|
|
|
|
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();
|
|
|
|
|
widget.controller.addListener(() {
|
|
|
|
|
_setText();
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_setText() {
|
2020-10-16 10:58:31 +06:30
|
|
|
double v = double.parse(widget.controller.text, (s) => 0);
|
2020-12-03 08:26:58 +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-03 08:26:58 +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-03 08:26:58 +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(
|
|
|
|
|
controller: widget.controller,
|
2020-10-15 17:33:43 +06:30
|
|
|
labelKey: widget.lableKey,
|
2020-12-03 08:26:58 +06:30
|
|
|
displayFeet: widget.displayFeet,
|
2020-10-14 01:51:53 +06:30
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class LengthPickerDialog extends StatefulWidget {
|
|
|
|
|
final TextEditingController controller;
|
2020-10-15 17:33:43 +06:30
|
|
|
final String labelKey;
|
2020-12-03 08:26:58 +06:30
|
|
|
final bool displayFeet;
|
2020-10-14 01:51:53 +06:30
|
|
|
|
2020-12-03 08:26:58 +06:30
|
|
|
const LengthPickerDialog(
|
|
|
|
|
{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> {
|
2020-10-16 10:58:31 +06:30
|
|
|
int _valueFeet;
|
|
|
|
|
int _valueInc;
|
2020-10-14 01:51:53 +06:30
|
|
|
@override
|
|
|
|
|
void initState() {
|
|
|
|
|
super.initState();
|
|
|
|
|
_valueFeet = 0;
|
|
|
|
|
_valueInc = 0;
|
|
|
|
|
if (widget.controller != null) {
|
|
|
|
|
double v = double.parse(widget.controller.text, (s) => 0);
|
2020-10-16 10:58:31 +06:30
|
|
|
_valueFeet = (v / 12).floor();
|
2020-12-03 08:26:58 +06:30
|
|
|
_valueInc = widget.displayFeet ? (v % 12).toInt() : v.toInt();
|
2020-10-14 01:51:53 +06:30
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
|
return SimpleDialog(
|
|
|
|
|
title: Center(
|
|
|
|
|
child: LocalText(
|
|
|
|
|
context,
|
2020-10-15 17:33:43 +06:30
|
|
|
widget.labelKey,
|
2020-10-14 01:51:53 +06:30
|
|
|
color: primaryColor,
|
|
|
|
|
fontSize: 16,
|
|
|
|
|
)),
|
|
|
|
|
children: [
|
2020-10-16 10:58:31 +06:30
|
|
|
Center(child: Text(_getText())),
|
2020-12-03 08:26:58 +06:30
|
|
|
widget.displayFeet
|
|
|
|
|
? Column(
|
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
|
children: [
|
|
|
|
|
Padding(
|
|
|
|
|
padding: const EdgeInsets.only(top: 8.0, left: 8),
|
|
|
|
|
child: LocalText(
|
|
|
|
|
context,
|
|
|
|
|
"feet",
|
|
|
|
|
color: primaryColor,
|
|
|
|
|
fontSize: 12,
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
Slider(
|
|
|
|
|
activeColor: primaryColor,
|
|
|
|
|
value: _valueFeet.toDouble(),
|
|
|
|
|
min: 0,
|
|
|
|
|
max: 15,
|
|
|
|
|
divisions: 100,
|
|
|
|
|
label: (_valueFeet ?? 0).round().toString(),
|
|
|
|
|
onChanged: (double v) {
|
|
|
|
|
_updateFeet(v);
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
)
|
|
|
|
|
: Container(),
|
2020-10-14 01:51:53 +06:30
|
|
|
Column(
|
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
|
children: [
|
|
|
|
|
Padding(
|
|
|
|
|
padding: const EdgeInsets.only(top: 8.0, left: 8),
|
|
|
|
|
child: LocalText(
|
|
|
|
|
context,
|
|
|
|
|
"inch",
|
|
|
|
|
color: primaryColor,
|
|
|
|
|
fontSize: 12,
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
Slider(
|
|
|
|
|
activeColor: primaryColor,
|
2020-10-16 10:58:31 +06:30
|
|
|
value: _valueInc.toDouble(),
|
2020-10-14 01:51:53 +06:30
|
|
|
min: 0,
|
2020-12-03 08:26:58 +06:30
|
|
|
max: widget.displayFeet ? 11 : 50,
|
2020-10-14 01:51:53 +06:30
|
|
|
divisions: 100,
|
|
|
|
|
label: (_valueInc ?? 0).round().toString(),
|
|
|
|
|
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
|
|
|
});
|
|
|
|
|
if (widget.controller != null) {
|
|
|
|
|
int _v = _valueInc.round() + _valueFeet.round() * 12;
|
|
|
|
|
widget.controller.text = _v.toString();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_updateInc(double v) {
|
|
|
|
|
setState(() {
|
2020-10-16 10:58:31 +06:30
|
|
|
_valueInc = v.toInt();
|
2020-10-14 01:51:53 +06:30
|
|
|
});
|
|
|
|
|
if (widget.controller != null) {
|
|
|
|
|
int _v = _valueInc.round() + _valueFeet.round() * 12;
|
2020-12-03 08:26:58 +06:30
|
|
|
widget.controller.text =
|
|
|
|
|
widget.displayFeet ? _v.toString() : _valueInc.toString();
|
2020-10-14 01:51:53 +06:30
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-10-16 10:58:31 +06:30
|
|
|
String _getText() {
|
2020-10-14 01:51:53 +06:30
|
|
|
int ft = _valueFeet.round();
|
|
|
|
|
int ins = _valueInc.round();
|
2020-12-03 08:26:58 +06:30
|
|
|
|
|
|
|
|
return widget.displayFeet ? "$ft\' $ins\"" : "$ins\"";
|
2020-10-14 01:51:53 +06:30
|
|
|
}
|
|
|
|
|
}
|