2025-08-01 15:41:02 +07:00
|
|
|
import 'package:enaklo_pos/core/components/custom_modal_dialog.dart';
|
2025-07-30 22:38:44 +07:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
|
|
|
|
import 'package:enaklo_pos/core/components/custom_text_field.dart';
|
|
|
|
|
import 'package:enaklo_pos/core/extensions/build_context_ext.dart';
|
|
|
|
|
import 'package:enaklo_pos/presentation/setting/bloc/add_discount/add_discount_bloc.dart';
|
|
|
|
|
import 'package:enaklo_pos/presentation/setting/bloc/discount/discount_bloc.dart';
|
|
|
|
|
|
|
|
|
|
import '../../../core/components/buttons.dart';
|
|
|
|
|
import '../../../core/components/spaces.dart';
|
|
|
|
|
import '../models/discount_model.dart';
|
|
|
|
|
|
|
|
|
|
class FormDiscountDialog extends StatefulWidget {
|
|
|
|
|
final DiscountModel? data;
|
|
|
|
|
const FormDiscountDialog({super.key, this.data});
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
State<FormDiscountDialog> createState() => _FormDiscountDialogState();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class _FormDiscountDialogState extends State<FormDiscountDialog> {
|
|
|
|
|
final nameController = TextEditingController();
|
|
|
|
|
final descriptionController = TextEditingController();
|
|
|
|
|
final discountController = TextEditingController();
|
|
|
|
|
@override
|
|
|
|
|
Widget build(BuildContext context) {
|
2025-08-01 15:41:02 +07:00
|
|
|
return CustomModalDialog(
|
|
|
|
|
title: widget.data == null ? 'Tambah Diskon' : 'Edit Diskon',
|
|
|
|
|
contentPadding: const EdgeInsets.all(16.0),
|
|
|
|
|
child: SingleChildScrollView(
|
2025-07-30 22:38:44 +07:00
|
|
|
child: SizedBox(
|
|
|
|
|
width: context.deviceWidth / 3,
|
|
|
|
|
child: Column(
|
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
|
children: [
|
|
|
|
|
CustomTextField(
|
|
|
|
|
controller: nameController,
|
|
|
|
|
label: 'Nama Diskon',
|
|
|
|
|
onChanged: (value) {},
|
|
|
|
|
),
|
|
|
|
|
const SpaceHeight(24.0),
|
|
|
|
|
CustomTextField(
|
|
|
|
|
controller: descriptionController,
|
|
|
|
|
label: 'Deskripsi (Opsional)',
|
|
|
|
|
onChanged: (value) {},
|
|
|
|
|
),
|
|
|
|
|
const SpaceHeight(24.0),
|
|
|
|
|
Row(
|
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.end,
|
|
|
|
|
children: [
|
|
|
|
|
Flexible(
|
|
|
|
|
child: CustomTextField(
|
|
|
|
|
controller: TextEditingController(text: 'Presentase'),
|
|
|
|
|
label: 'Nilai',
|
|
|
|
|
suffixIcon: const Icon(Icons.chevron_right),
|
|
|
|
|
onChanged: (value) {},
|
|
|
|
|
readOnly: true,
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
const SpaceWidth(14.0),
|
|
|
|
|
Flexible(
|
|
|
|
|
child: CustomTextField(
|
|
|
|
|
showLabel: false,
|
|
|
|
|
controller: discountController,
|
|
|
|
|
label: 'Percent',
|
|
|
|
|
prefixIcon: const Icon(Icons.percent),
|
|
|
|
|
onChanged: (value) {},
|
|
|
|
|
keyboardType: TextInputType.number,
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
const SpaceHeight(24.0),
|
|
|
|
|
BlocConsumer<AddDiscountBloc, AddDiscountState>(
|
|
|
|
|
listener: (context, state) {
|
|
|
|
|
state.maybeWhen(
|
|
|
|
|
orElse: () {},
|
|
|
|
|
success: () {
|
|
|
|
|
context
|
|
|
|
|
.read<DiscountBloc>()
|
|
|
|
|
.add(const DiscountEvent.getDiscounts());
|
|
|
|
|
context.pop();
|
|
|
|
|
},
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
builder: (context, state) {
|
|
|
|
|
return state.maybeWhen(orElse: () {
|
|
|
|
|
return Button.filled(
|
|
|
|
|
onPressed: () {
|
|
|
|
|
context.read<AddDiscountBloc>().add(
|
|
|
|
|
AddDiscountEvent.addDiscount(
|
|
|
|
|
name: nameController.text,
|
|
|
|
|
description: descriptionController.text,
|
|
|
|
|
value: int.parse(discountController.text),
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
label: 'Simpan Diskon',
|
|
|
|
|
);
|
|
|
|
|
}, loading: () {
|
|
|
|
|
return const Center(
|
|
|
|
|
child: CircularProgressIndicator(),
|
|
|
|
|
);
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
)
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|