update
This commit is contained in:
parent
f87e1511bc
commit
e48e400e43
13 changed files with 333 additions and 33 deletions
|
|
@ -22,9 +22,10 @@ class AddGenericsPageState extends State<AddGenericsPage> {
|
|||
final _refCategories = RefCategories();
|
||||
final _refGenericNames = RefGenericNames();
|
||||
final _nameController = TextEditingController();
|
||||
late List _categoryList;
|
||||
late String _selectedCategory;
|
||||
late String _categoryUUID;
|
||||
|
||||
late List _categoryList = [];
|
||||
late String _selectedCategory = '';
|
||||
late String _categoryUUID = '';
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
|
|
@ -43,7 +44,6 @@ class AddGenericsPageState extends State<AddGenericsPage> {
|
|||
void saveGeneric() async {
|
||||
_categoryUUID = await _refCategories.getUUID(_selectedCategory);
|
||||
|
||||
log(_categoryUUID);
|
||||
await _refGenericNames.postGeneric(_nameController.text, _categoryUUID);
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -3,11 +3,11 @@ import 'package:gap/gap.dart';
|
|||
import 'package:pharmacy_mobile/tables/ref_categories.dart';
|
||||
import 'package:pharmacy_mobile/tables/ref_generic_names.dart';
|
||||
import 'package:pharmacy_mobile/tables/ref_manufactorers.dart';
|
||||
import 'package:pharmacy_mobile/tables/ref_medicines.dart';
|
||||
import 'package:pharmacy_mobile/tables/ref_types.dart';
|
||||
import 'package:pharmacy_mobile/widgets/button_widget.dart';
|
||||
import 'package:pharmacy_mobile/widgets/dropdown_widget.dart';
|
||||
import 'package:pharmacy_mobile/widgets/input_widget.dart';
|
||||
// import 'package:google_fonts/google_fonts.dart';
|
||||
import 'package:pharmacy_mobile/widgets/text_widget.dart';
|
||||
import 'package:pharmacy_mobile/widgets/title_widget.dart';
|
||||
|
||||
|
|
@ -22,22 +22,20 @@ class AddMedicinePageState extends State<AddMedicinePage> {
|
|||
final _formKey = GlobalKey<FormState>();
|
||||
// final _authService = AuthService();
|
||||
final _refGenericNames = RefGenericNames();
|
||||
// final _refCategories = RefCategories();
|
||||
final _refCategories = RefCategories();
|
||||
final _refTypes = RefTypes();
|
||||
final _refManufactorer = RefManufactorers();
|
||||
final _refMedicines = RefMedicines();
|
||||
final _nameController = TextEditingController();
|
||||
final _genericNameController = TextEditingController();
|
||||
final _typeController = TextEditingController();
|
||||
final _manufactorerController = TextEditingController();
|
||||
final _categoryController = TextEditingController();
|
||||
final FocusNode _focusNode = FocusNode();
|
||||
|
||||
late List _genericNameList = [];
|
||||
late String _selectedGeneric;
|
||||
late String _selectedGeneric = '';
|
||||
late String _selectedCategory = '';
|
||||
late List _typeList = [];
|
||||
late String _selectedType;
|
||||
late String _selectedType = '';
|
||||
late List _manufactorerList = [];
|
||||
late String _selectedManufactorer;
|
||||
late String _selectedManufactorer = '';
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
|
|
@ -51,8 +49,14 @@ class AddMedicinePageState extends State<AddMedicinePage> {
|
|||
_manufactorerList = await _refManufactorer.getList();
|
||||
}
|
||||
|
||||
void _updateGeneric(dynamic generic) {
|
||||
void _updateGeneric(dynamic generic) async {
|
||||
_selectedGeneric = generic;
|
||||
final catuuid = await _refGenericNames.getCategoryUUID(_selectedGeneric);
|
||||
final catname = await _refCategories.getName(catuuid);
|
||||
|
||||
setState(() {
|
||||
_selectedCategory = catname;
|
||||
});
|
||||
}
|
||||
|
||||
void _updateType(dynamic type) {
|
||||
|
|
@ -63,22 +67,27 @@ class AddMedicinePageState extends State<AddMedicinePage> {
|
|||
_selectedManufactorer = manufactorer;
|
||||
}
|
||||
|
||||
// @override
|
||||
// void initState() {
|
||||
// super.initState();
|
||||
// }
|
||||
void _saveMedicine() async {
|
||||
final medName = _nameController.text;
|
||||
final medGenericUUID = await _refGenericNames.getUUID(_selectedGeneric);
|
||||
final medTypeUUID = await _refTypes.getUUID(_selectedType);
|
||||
final medManufactorerUUID = await _refManufactorer.getUUID(_selectedManufactorer);
|
||||
|
||||
await _refMedicines.postMedicine(medName, medGenericUUID, medManufactorerUUID, medTypeUUID);
|
||||
}
|
||||
|
||||
@override
|
||||
void dispose() {
|
||||
_nameController.dispose();
|
||||
_genericNameController.dispose();
|
||||
_typeController.dispose();
|
||||
_manufactorerController.dispose();
|
||||
_categoryController.dispose();
|
||||
_focusNode.dispose();
|
||||
|
||||
_genericNameList = [];
|
||||
_selectedGeneric = '';
|
||||
_selectedCategory = '';
|
||||
_typeList = [];
|
||||
_selectedType = '';
|
||||
_manufactorerList = [];
|
||||
_selectedManufactorer = '';
|
||||
super.dispose();
|
||||
}
|
||||
|
||||
|
|
@ -113,13 +122,18 @@ class AddMedicinePageState extends State<AddMedicinePage> {
|
|||
children: [
|
||||
InputWidget(label: 'Name', controller: _nameController),
|
||||
const Gap(16),
|
||||
DropDownWidget(
|
||||
label: 'Generic Name',
|
||||
list: _genericNameList,
|
||||
listTitle: 'generic_name',
|
||||
onChanged: _updateGeneric),
|
||||
const Gap(8),
|
||||
TextWidget(text: _categoryController.text),
|
||||
Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: [
|
||||
DropDownWidget(
|
||||
label: 'Generic Name',
|
||||
list: _genericNameList,
|
||||
listTitle: 'generic_name',
|
||||
onChanged: _updateGeneric),
|
||||
const Gap(8),
|
||||
TextWidget(text: _selectedCategory, size: 18),
|
||||
],
|
||||
),
|
||||
const Gap(16),
|
||||
DropDownWidget(label: 'Type', list: _typeList, listTitle: 'type_name', onChanged: _updateType),
|
||||
const Gap(16),
|
||||
|
|
@ -129,7 +143,7 @@ class AddMedicinePageState extends State<AddMedicinePage> {
|
|||
listTitle: 'manufactorer_name',
|
||||
onChanged: _updateManufactorer),
|
||||
const Gap(16),
|
||||
ButtonWidget(text: 'Save Medicine', onPressed: onPressed)
|
||||
ButtonWidget(text: 'Save Medicine', onPressed: _saveMedicine)
|
||||
],
|
||||
),
|
||||
))
|
||||
|
|
|
|||
125
lib/pages/add_stock.dart
Normal file
125
lib/pages/add_stock.dart
Normal file
|
|
@ -0,0 +1,125 @@
|
|||
import 'dart:developer';
|
||||
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:gap/gap.dart';
|
||||
import 'package:google_fonts/google_fonts.dart';
|
||||
import 'package:pharmacy_mobile/tables/ref_medicines.dart';
|
||||
import 'package:pharmacy_mobile/widgets/button_widget.dart';
|
||||
import 'package:pharmacy_mobile/widgets/datepicker_widget.dart';
|
||||
import 'package:pharmacy_mobile/widgets/dropdown_widget.dart';
|
||||
import 'package:pharmacy_mobile/widgets/input_widget.dart';
|
||||
import 'package:pharmacy_mobile/widgets/text_widget.dart';
|
||||
import 'package:pharmacy_mobile/widgets/title_widget.dart';
|
||||
import 'package:intl/intl.dart';
|
||||
|
||||
class AddStockPage extends StatefulWidget {
|
||||
const AddStockPage({super.key});
|
||||
|
||||
@override
|
||||
_AddStockPageState createState() => _AddStockPageState();
|
||||
}
|
||||
|
||||
class _AddStockPageState extends State<AddStockPage> {
|
||||
final _formKey = GlobalKey<FormState>();
|
||||
final FocusNode _focusNode = FocusNode();
|
||||
final _refMedicines = RefMedicines();
|
||||
final _quantityController = TextEditingController();
|
||||
final _dateController = TextEditingController();
|
||||
|
||||
late List _medicineList = [];
|
||||
late String _selectedMedicine = '';
|
||||
late DateTime selectedDate = DateTime.now();
|
||||
|
||||
void autoRun() async {
|
||||
_medicineList = await _refMedicines.getList();
|
||||
}
|
||||
|
||||
void _updateMedicine(dynamic medicine) {
|
||||
_selectedMedicine = medicine;
|
||||
}
|
||||
|
||||
// Future<void> _selectDate(BuildContext context) async {
|
||||
// final DateTime? picked = await showDatePicker(
|
||||
// context: context, initialDate: selectedDate, firstDate: DateTime(2015, 8), lastDate: DateTime(2101));
|
||||
// if (picked != null && picked != selectedDate) {
|
||||
// setState(() {
|
||||
// selectedDate = picked;
|
||||
// final DateFormat formatter = DateFormat('MMMM dd, yyyy');
|
||||
// _dateController.text = formatter.format(selectedDate);
|
||||
// });
|
||||
// }
|
||||
// }
|
||||
|
||||
void saveStock() async {}
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
autoRun();
|
||||
super.initState();
|
||||
}
|
||||
|
||||
@override
|
||||
void dispose() {
|
||||
_focusNode.dispose();
|
||||
_medicineList = [];
|
||||
_selectedMedicine = '';
|
||||
_quantityController.dispose();
|
||||
_dateController.dispose();
|
||||
super.dispose();
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Scaffold(
|
||||
body: Container(
|
||||
alignment: Alignment.center,
|
||||
height: MediaQuery.of(context).size.height * 8,
|
||||
decoration: const BoxDecoration(
|
||||
gradient: LinearGradient(
|
||||
colors: [
|
||||
Color.fromRGBO(34, 51, 69, 1),
|
||||
Color.fromRGBO(22, 32, 44, 1),
|
||||
],
|
||||
begin: Alignment.topCenter,
|
||||
end: Alignment.bottomCenter,
|
||||
),
|
||||
),
|
||||
child: Center(
|
||||
child: Column(
|
||||
children: [
|
||||
const Gap(120),
|
||||
const TitleWidget(firstTextSize: 16, secondTextSize: 32),
|
||||
const Gap(32),
|
||||
const TextWidget(text: 'Add Stock'),
|
||||
const Gap(16),
|
||||
Form(
|
||||
key: _formKey,
|
||||
child: Center(
|
||||
child: Column(
|
||||
children: [
|
||||
DropDownWidget(
|
||||
label: 'Medicine Name',
|
||||
list: _medicineList,
|
||||
listTitle: 'medicine_name',
|
||||
onChanged: _updateMedicine),
|
||||
const Gap(16),
|
||||
InputWidget(label: 'Quantity', controller: _quantityController),
|
||||
const Gap(16),
|
||||
DatePickerWidget(
|
||||
label: 'Date Expiration',
|
||||
controller: _dateController,
|
||||
value: selectedDate,
|
||||
),
|
||||
const Gap(16),
|
||||
ButtonWidget(text: 'Add Stock', onPressed: saveStock)
|
||||
],
|
||||
),
|
||||
),
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
@ -63,9 +63,7 @@ class MainPage extends StatelessWidget {
|
|||
),
|
||||
const Gap(16),
|
||||
MenuWidget(
|
||||
icon: FontAwesomeIcons.squarePlus,
|
||||
text: 'Add Stock',
|
||||
),
|
||||
icon: FontAwesomeIcons.squarePlus, text: 'Add Stock', onPressed: () => {context.push('/addstock')}),
|
||||
const Gap(16),
|
||||
MenuWidget(
|
||||
icon: FontAwesomeIcons.squarePlus,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue