GSI - Employe Self Service Mobile
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

307 lines
12 KiB

import 'dart:convert';
import 'package:flutter/material.dart';
import 'package:fluttertoast/fluttertoast.dart';
import 'package:google_fonts/google_fonts.dart';
import 'package:employee_selfservice_mobile/Screens/Menu/AjukanCuti/RequestHttp/historyCuti_post.dart';
import 'package:progress_dialog_null_safe/progress_dialog_null_safe.dart';
import 'dart:developer' as logDev;
import '../AjukanCuti/backgroundHistory.dart';
class HistoryCuti extends StatefulWidget {
const HistoryCuti({Key? key}) : super(key: key);
@override
State<HistoryCuti> createState() => _HistoryCutiState();
}
class _HistoryCutiState extends State<HistoryCuti> {
late List <String> id_List;
late List <String> name_List;
late List <String> type_cuti_List;
late List <String> detail_List;
late List <String> created_on_List;
late List <String> created_by_List;
late List <String> start_date_List;
late List <String> end_date_List;
late List <String> duration_List;
late List <String> status_List;
late List <Color> statusColor;
late List <bool> visible;
int HistoryLength = 0;
@override
initState() {
super.initState();
id_List = [""];
name_List = [""];
type_cuti_List = [""];
detail_List = [""];
created_on_List = [""];
created_by_List = [""];
start_date_List = [""];
end_date_List = [""];
duration_List = [""];
status_List = [""];
statusColor = [Colors.black54];
visible = [false];
WidgetsBinding.instance.addPostFrameCallback((_) async {
getHistoryData();
});
logDev.log(HistoryLength.toString(), name: "Banyak History");
}
getHistoryData() async {
ProgressDialog loading = ProgressDialog(context);
loading = ProgressDialog(context,
type: ProgressDialogType.normal, isDismissible: false, showLogs: true);
loading.style(
message: 'Please Wait .....',
borderRadius: 3,
backgroundColor: Colors.white,
progressWidget: CircularProgressIndicator(),
elevation: 10.0,
padding: EdgeInsets.all(10),
insetAnimCurve: Curves.easeInOut,
progress: 0.0,
maxProgress: 100.0,
progressTextStyle: TextStyle(
color: Colors.black, fontSize: 10.0, fontWeight: FontWeight.w400),
messageTextStyle: TextStyle(
color: Colors.black, fontSize: 15.0, fontWeight: FontWeight.w600));
await loading.show();
HistoryCuti_Post.connectToAPI().then((valueResult) async {
Map<String, dynamic> object = jsonDecode(valueResult);
if (object.containsKey("result").toString() == "true") {
String result = object['result'].toString();
if (result.contains("Failed")) {
await loading.hide();
alertDialogFailedRetrievedData(context);
} else {
List <dynamic> historyCuti = object['result'];
/* logDev.log(historyCuti.toString(), name: "History Cuti");
logDev.log(historyCuti.length.toString(), name: "Banyaknya History Cuti");*/
setState(() {
for (int i = 0; i < historyCuti.length; i++){
String id = historyCuti[i]['id'].toString();
String name = historyCuti[i]['name'].toString();
String type_cuti = historyCuti[i]['type_cuti'].toString();
String detail = historyCuti[i]['detail'].toString();
String created_on = historyCuti[i]['created_on'].toString();
String created_by = historyCuti[i]['created_by'].toString();
String start_date = historyCuti[i]['start_date'].toString();
String end_date = historyCuti[i]['end_date'].toString();
String duration = historyCuti[i]['duration'].toString();
String status = historyCuti[i]['status'].toString();
if (detail == "false"){
detail = "-";
}
id_List.add(id);
name_List.add(name);
type_cuti_List.add(type_cuti);
detail_List.add(detail);
created_on_List.add(created_on);
created_by_List.add(created_by);
start_date_List.add(start_date.substring(0,10));
end_date_List.add(end_date.substring(0,10));
duration_List.add(duration);
status_List.add(status);
visible.add(false);
var statColor;
if (status == "To Approve"){
statColor = Colors.red;
} else if (status == "Second Approval"){
statColor = Colors.green;
} else if (status == "Approved"){
statColor = Colors.blueAccent;
}
statusColor.add(statColor);
}
id_List.removeAt(0);
name_List.removeAt(0);
type_cuti_List.removeAt(0);
detail_List.removeAt(0);
created_on_List.removeAt(0);
created_by_List.removeAt(0);
start_date_List.removeAt(0);
end_date_List.removeAt(0);
duration_List.removeAt(0);
status_List.removeAt(0);
statusColor.removeAt(0);
visible.removeAt(0);
HistoryLength = historyCuti.length;
});
}
} else {
Fluttertoast.showToast(
msg: "Server Response Error",
toastLength: Toast.LENGTH_SHORT,
gravity: ToastGravity.CENTER,
timeInSecForIosWeb: 1,
textColor: Colors.white,
fontSize: 16.0);
}
await loading.hide();
});
}
@override
Widget build(BuildContext context) {
var size = MediaQuery.of(context).size;
return Scaffold(
body: Stack(
children: [
Column(
children: <Widget>[
Stack(
children: [
WavyHeader(),
Container(
margin: EdgeInsets.only(top: (size.height / 6) - 20),
padding: EdgeInsets.fromLTRB(0, 5, 25, 5),
child: Row(
mainAxisAlignment: MainAxisAlignment.end,
crossAxisAlignment: CrossAxisAlignment.end,
children: [
Text(
'Leaves History\t\t',
maxLines: 1,
style: GoogleFonts.luckiestGuy(
fontSize: 28,
color: Color(0xFF4858A7),
fontStyle: FontStyle.italic,
),
),
Image.asset(
'assets/images/ic_history.png',
width: 40,
height: 40,
),
],
)
),
],
),
],
),
Container(
margin: EdgeInsets.only(top: (MediaQuery.of(context).size.height / 6) + 40, left: 5, right: 5, bottom: 10),
child: ListView.builder(
scrollDirection: Axis.vertical,
shrinkWrap: true,
itemCount: HistoryLength,
itemBuilder: (context, int i) {
return Container(
child: InkWell(
child: Card(
elevation: 10,
child: Column(
children: [
Row(
children: [
Expanded(
flex: 8,
child: Padding(
padding: EdgeInsets.fromLTRB(10, 5, 5, 5),
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(type_cuti_List[i], style: GoogleFonts.rubikBubbles(fontSize: 16)),
Text(start_date_List[i] + " - " + end_date_List[i] + " (" + duration_List[i] + ") ", style: GoogleFonts.nunito(fontSize: 15)),
Text("\nDescription : " + detail_List[i], style: GoogleFonts.nunito(fontSize: 15)),
Text("\nCreated : " + created_on_List[i], style: GoogleFonts.yeonSung(fontSize: 14, fontStyle: FontStyle.italic)),
],
),
)
),
Expanded(
flex: 2,
child: Padding(
padding: EdgeInsets.fromLTRB(5, 5, 5, 5),
child: Text(status_List[i], textAlign: TextAlign.center, style: GoogleFonts.lilitaOne(color: statusColor[i], fontSize: 17),
),
)
),
],
),
Align(
alignment: Alignment.centerLeft,
child: Visibility(
visible: visible[i],
child: Padding(
padding: EdgeInsets.fromLTRB(10, 5, 5, 5),
child: Column(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text("\nAttachment : ", style: GoogleFonts.josefinSans(fontSize: 15, fontWeight: FontWeight.bold)),
Text("Created : " + created_on_List[i], style: GoogleFonts.nunito(fontSize: 15, fontStyle: FontStyle.italic)),
],
),
)
),
)
],
),
),
onTap: (){
setState(() {
visible[i] = !visible[i];
});
},
),
);
},
),
)
]),
);
}
}
alertDialogFailedRetrievedData(BuildContext context) {
Widget okButton = TextButton(
child: Text("Refresh"),
onPressed: () {
Navigator.of(context, rootNavigator: true).pop();
Navigator.pushReplacement(
context, MaterialPageRoute(builder: (context) => HistoryCuti()));
},
);
Widget noButton = TextButton(
child: Text("Back"),
onPressed: () {
Navigator.of(context, rootNavigator: true).pop();
Navigator.pop(context);
},
);
// set up the AlertDialog
AlertDialog alert = AlertDialog(
title: Text("Employee Self Service"),
content: Text("Failed to Retrieve Data"),
actions: [
noButton,
okButton,
],
);
// show the dialog
showDialog(
context: context,
builder: (BuildContext context) {
return alert;
},
);
}