128 lines
3.7 KiB
Dart
128 lines
3.7 KiB
Dart
import 'dart:developer';
|
|
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
|
import 'package:enaklo_pos/core/constants/colors.dart';
|
|
import 'package:enaklo_pos/core/extensions/date_time_ext.dart';
|
|
import 'package:enaklo_pos/presentation/sales/blocs/day_sales/day_sales_bloc.dart';
|
|
|
|
import '../widgets/sales_widget.dart';
|
|
|
|
class SalesPage extends StatefulWidget {
|
|
const SalesPage({super.key});
|
|
|
|
@override
|
|
State<SalesPage> createState() => _SalesPageState();
|
|
}
|
|
|
|
class _SalesPageState extends State<SalesPage> {
|
|
@override
|
|
void initState() {
|
|
context.read<DaySalesBloc>().add(DaySalesEvent.getDaySales(DateTime.now()));
|
|
super.initState();
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Padding(
|
|
padding: const EdgeInsets.all(32),
|
|
child: Column(
|
|
children: [
|
|
Row(
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
children: [
|
|
const Text(
|
|
'Apskel POS ',
|
|
style: TextStyle(
|
|
color: AppColors.primary,
|
|
fontSize: 22,
|
|
fontWeight: FontWeight.w600,
|
|
),
|
|
),
|
|
Text(
|
|
"${DateTime.now().toFormattedDate()}",
|
|
style: const TextStyle(
|
|
color: AppColors.subtitle,
|
|
fontSize: 16,
|
|
),
|
|
),
|
|
],
|
|
),
|
|
const SizedBox(
|
|
height: 12.0,
|
|
),
|
|
Expanded(
|
|
child: BlocBuilder<DaySalesBloc, DaySalesState>(
|
|
builder: (context, state) {
|
|
return state.maybeWhen(
|
|
orElse: () => const Center(
|
|
child: CircularProgressIndicator(),
|
|
),
|
|
loaded: (orders) {
|
|
log("message: ${orders.length}");
|
|
if (orders.isEmpty) {
|
|
return Center(
|
|
child: Text(
|
|
"Belum ada transaksi saat ini. ",
|
|
style: TextStyle(
|
|
fontSize: 16.0,
|
|
fontWeight: FontWeight.bold,
|
|
),
|
|
),
|
|
);
|
|
} else {
|
|
return SalesWidget(
|
|
headerWidgets: _getTitleHeaderWidget(),
|
|
orders: orders,
|
|
);
|
|
}
|
|
},
|
|
);
|
|
},
|
|
),
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
|
|
List<Widget> _getTitleHeaderWidget() {
|
|
return [
|
|
_getTitleItemWidget('ID', 40),
|
|
_getTitleItemWidget('Customer', 120),
|
|
_getTitleItemWidget('Status', 120),
|
|
_getTitleItemWidget('Sync', 60),
|
|
_getTitleItemWidget('Payment Status', 120),
|
|
_getTitleItemWidget('Payment Method', 120),
|
|
_getTitleItemWidget('Payment Amount', 120),
|
|
_getTitleItemWidget('Sub Total', 120),
|
|
_getTitleItemWidget('Tax', 120),
|
|
_getTitleItemWidget('Discount', 60),
|
|
_getTitleItemWidget('Service Charge', 120),
|
|
_getTitleItemWidget('Total', 120),
|
|
_getTitleItemWidget('Payment', 60),
|
|
_getTitleItemWidget('Item', 60),
|
|
_getTitleItemWidget('Cashier', 150),
|
|
_getTitleItemWidget('Time', 230),
|
|
_getTitleItemWidget('Action', 230),
|
|
];
|
|
}
|
|
|
|
Widget _getTitleItemWidget(String label, double width) {
|
|
return Container(
|
|
width: width,
|
|
height: 56,
|
|
color: AppColors.primary,
|
|
alignment: Alignment.centerLeft,
|
|
child: Center(
|
|
child: Text(
|
|
label,
|
|
style: const TextStyle(
|
|
color: Colors.white,
|
|
),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|