first commit

This commit is contained in:
kicap
2023-11-09 02:42:23 +08:00
commit ba5d6fa38b
54 changed files with 4841 additions and 0 deletions

View File

@ -0,0 +1,141 @@
import 'package:flutter/material.dart';
import 'package:stacked/stacked.dart';
import 'package:stacked_services/stacked_services.dart';
import '../../../app/themes/app_colors.dart';
import '../../../app/themes/app_text.dart';
import './detail_suara_bottom_sheet_view_model.dart';
class DetailSuaraBottomSheetView extends StatelessWidget {
final SheetRequest? request;
final Function(SheetResponse)? completer;
const DetailSuaraBottomSheetView({
Key? key,
this.request,
this.completer,
}) : super(key: key);
@override
Widget build(BuildContext context) {
return ViewModelBuilder<DetailSuaraBottomSheetViewModel>.reactive(
viewModelBuilder: () => DetailSuaraBottomSheetViewModel(),
onViewModelReady: (DetailSuaraBottomSheetViewModel model) async {
await model.init(request!);
},
builder: (
BuildContext context,
DetailSuaraBottomSheetViewModel model,
Widget? child,
) {
return SafeArea(
child: Container(
width: MediaQuery.of(context).size.width,
padding: const EdgeInsets.all(20),
alignment: Alignment.topCenter,
decoration: const BoxDecoration(
color: Colors.white,
borderRadius: BorderRadius.only(
topLeft: Radius.circular(20),
topRight: Radius.circular(20),
),
),
child: Column(
children: [
Text(
request!.title!,
style: italicTextStyle.copyWith(
fontSize: 15,
fontWeight: FontWeight.bold,
),
),
const SizedBox(height: 20),
Expanded(
child: Container(
padding: const EdgeInsets.all(15),
decoration: BoxDecoration(
color: warningColor,
borderRadius: BorderRadius.circular(10),
),
child: SingleChildScrollView(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
// mainAxisSize: MainAxisSize.min,
children: [
Text(
'Jumlah Suara: ${model.counter}',
style: boldTextStyle,
),
const SizedBox(height: 10),
if (model.isBusy)
const Center(child: CircularProgressIndicator()),
if (!model.isBusy &&
model.status == true &&
model.counter > 0)
for (var i = 0; i < model.counter; i++)
Card(
child: ListTile(
// leading is datetime dummy
leading: Text(model.myFunction
.convertDateTime2(
model.listPemilih[i].createdAt!)),
title: Text(
model.listPemilih[i].namaPemilih!,
style: boldTextStyle,
),
subtitle: Column(
crossAxisAlignment:
CrossAxisAlignment.start,
children: [
if (request!.description == 'Caleg')
Text(
model.listPemilih[i].namaTimSurvei!,
style: italicTextStyle,
),
Text(
model.listPemilih[i].namaArea!,
),
],
),
trailing: IconButton(
icon: const Icon(
Icons.info_outline,
color: mainColor,
),
onPressed: () {
model.showDetailPemilih(
model.listPemilih[i],
);
},
),
),
),
if (!model.isBusy &&
model.status == true &&
model.counter == 0)
const Center(
child: Text(
'Belum ada data',
style: boldTextStyle,
),
),
if (!model.isBusy && model.status == false)
const Center(
child: Text(
'Error: Gagal mengambil data dari server',
style: boldTextStyle,
),
),
],
),
),
),
),
],
),
),
);
},
);
}
}

View File

@ -0,0 +1,54 @@
import '../../../app/app.bottomsheets.dart';
import '../../../app/app.logger.dart';
import '../../../app/core/custom_base_view_model.dart';
import '../../../model/my_response.model.dart';
import '../../../model/pemilih_model.dart';
class DetailSuaraBottomSheetViewModel extends CustomBaseViewModel {
final log = getLogger('DetailSuaraBottomSheetViewModel');
bool status = false;
List<PemilihModel> listPemilih = [];
int counter = 0;
Future<void> init(sheetRequest) async {
String id = sheetRequest.data.toString();
String status = sheetRequest.description;
String? idCaleg = await mySharedPrefs.getString('id');
await getData(id, status, idCaleg!);
}
getData(String id, String status, String idCaleg) async {
setBusy(true);
try {
// var response = await httpService.get('caleg/suara/$id');
String url = status == 'Tim Survei'
? 'survei/suara/$id'
: 'area/suara/$id/$idCaleg';
var response = await httpService.get(url);
MyResponseModel myResponseModel = MyResponseModel.fromJson(response.data);
PemilihDetailModel pemilihDetailModel =
PemilihDetailModel.fromJson(myResponseModel.data);
listPemilih = pemilihDetailModel.pemilihModel!;
counter = pemilihDetailModel.jumlah!;
this.status = true;
} catch (e) {
this.status = false;
} finally {
setBusy(false);
}
}
showDetailPemilih(PemilihModel listPemilih) async {
await bottomSheetService.showCustomSheet(
variant: BottomSheetType.detailSuaraPemilihBottomSheetView,
title: 'Detail Suara Pemilih',
description: 'Detail Suara Pemilih',
// isScrollControlled: true,
data: listPemilih,
);
}
}