Files
kulakpos_app/lib/Screens/Currency/currency_screen.dart
2026-02-07 15:57:09 +07:00

130 lines
5.0 KiB
Dart

import 'package:flutter/material.dart';
import 'package:flutter_easyloading/flutter_easyloading.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:mobile_pos/Screens/Currency/Provider/currency_provider.dart';
import 'package:mobile_pos/generated/l10n.dart' as lang;
import '../../GlobalComponents/glonal_popup.dart';
import '../../constant.dart';
import '../../currency.dart';
import 'Model/currency_model.dart';
import 'Repo/currency_repo.dart';
class CurrencyScreen extends StatefulWidget {
const CurrencyScreen({super.key});
@override
State<CurrencyScreen> createState() => _CurrencyScreenState();
}
class _CurrencyScreenState extends State<CurrencyScreen> {
CurrencyModel selectedCurrency = CurrencyModel(name: currencyName, symbol: currency);
@override
Widget build(BuildContext context) {
return Consumer(builder: (context, ref, __) {
final currencyData = ref.watch(currencyProvider);
return GlobalPopup(
child: Scaffold(
backgroundColor: kWhite,
resizeToAvoidBottomInset: true,
appBar: AppBar(
backgroundColor: Colors.white,
title: Text(
lang.S.of(context).currency,
//'Currency',
),
centerTitle: true,
iconTheme: const IconThemeData(color: Colors.black),
elevation: 0.0,
),
body: currencyData.when(
data: (currencyList) {
return SingleChildScrollView(
child: Padding(
padding: const EdgeInsets.all(10.0),
child: ListView.builder(
physics: const NeverScrollableScrollPhysics(),
itemCount: currencyList.length,
shrinkWrap: true,
itemBuilder: (BuildContext context, int index) {
return Padding(
padding: const EdgeInsets.only(bottom: 15),
child: Container(
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(6),
color: selectedCurrency.name == currencyList[index].name ? kMainColor : kWhite,
boxShadow: [
BoxShadow(color: const Color(0xff0C1A4B).withValues(alpha: 0.24), blurRadius: 1),
BoxShadow(color: const Color(0xff473232).withValues(alpha: 0.05), offset: const Offset(0, 3), spreadRadius: -1, blurRadius: 8)
],
),
child: ListTile(
selected: selectedCurrency.name == currencyList[index].name,
selectedColor: Colors.white,
onTap: () {
setState(() {
selectedCurrency = currencyList[index];
});
},
title: Text('${currencyList[index].name} - ${currencyList[index].symbol}'),
trailing: const Icon(
(Icons.arrow_forward_ios),
),
),
),
);
},
),
),
);
},
error: (error, stackTrace) {
return null;
},
loading: () => const Center(child: CircularProgressIndicator()),
),
bottomNavigationBar: Padding(
padding: const EdgeInsets.all(10.0),
child: GestureDetector(
onTap: () async {
try {
EasyLoading.show();
final isSet = await CurrencyRepo().setDefaultCurrency(id: selectedCurrency.id!);
if (isSet) {
await CurrencyMethods().saveCurrencyDataInLocalDatabase(
selectedCurrencyName: selectedCurrency.name,
selectedCurrencySymbol: selectedCurrency.symbol,
);
Navigator.pop(context);
} else {
EasyLoading.showError('Something went wrong');
}
} catch (e) {
EasyLoading.showError('An error occurred: $e');
} finally {
EasyLoading.dismiss();
}
},
child: Container(
height: 50,
decoration: const BoxDecoration(
color: kMainColor,
borderRadius: BorderRadius.all(Radius.circular(10)),
),
child: Center(
child: Text(
lang.S.of(context).save,
style: const TextStyle(fontSize: 18, color: Colors.white),
),
),
),
),
),
),
);
});
}
}