added Home and Produk Page
This commit is contained in:
85
boss_app/lib/controller/boss_controller.dart
Normal file
85
boss_app/lib/controller/boss_controller.dart
Normal file
@ -0,0 +1,85 @@
|
||||
// ignore_for_file: non_constant_identifier_names
|
||||
|
||||
import 'dart:convert';
|
||||
|
||||
import 'package:flutter/cupertino.dart';
|
||||
// ignore: unused_import
|
||||
import 'package:http/http.dart' as http;
|
||||
|
||||
//create class LoginController extends ChangeNotifier
|
||||
class BossController extends ChangeNotifier {
|
||||
//create future string login , parameter is String username and password
|
||||
Future<Map> ambilLaporan(
|
||||
String tanggal, String bulan, String tahun, String filter) async {
|
||||
//create string result
|
||||
Map<String, dynamic> result;
|
||||
|
||||
try {
|
||||
final response = await http.get(
|
||||
Uri.parse(
|
||||
"http://192.168.43.125/ilham/server2/api/ambil_laporan?tanggal=$tanggal&bulan=$bulan&tahun=$tahun&filter=$filter"),
|
||||
headers: {
|
||||
"Accept": "application/json",
|
||||
"authorization":
|
||||
"Basic ${base64Encode(utf8.encode("Kicap_karan:bb10c6d9f01ec0cb16726b59e36c2f73"))}",
|
||||
"crossDomain": "true"
|
||||
});
|
||||
final data = jsonDecode(response.body);
|
||||
result = data;
|
||||
// print(result);
|
||||
} catch (e) {
|
||||
result = {"status": "error", "message": e.toString()};
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
Future<Map> ambilLaporanDetail(String no_log) async {
|
||||
//create string result
|
||||
Map<String, dynamic> result;
|
||||
|
||||
try {
|
||||
final response = await http.get(
|
||||
Uri.parse(
|
||||
"http://192.168.43.125/ilham/server2/api/ambil_laporan_detail?no_log=$no_log"),
|
||||
headers: {
|
||||
"Accept": "application/json",
|
||||
"authorization":
|
||||
"Basic ${base64Encode(utf8.encode("Kicap_karan:bb10c6d9f01ec0cb16726b59e36c2f73"))}",
|
||||
"crossDomain": "true"
|
||||
});
|
||||
|
||||
final data = jsonDecode(response.body);
|
||||
// print(data);
|
||||
result = data;
|
||||
} catch (e) {
|
||||
result = {"status": "error", "message": e.toString()};
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
Future<Map> ambilProdukAll(int pageNumber, String filter) async {
|
||||
Map<String, dynamic> result;
|
||||
|
||||
try {
|
||||
final response = await http.get(
|
||||
Uri.parse(
|
||||
"http://192.168.43.125/ilham/server2/api/ambil_produk_all?page=$pageNumber&filter=$filter"),
|
||||
headers: {
|
||||
"Accept": "application/json",
|
||||
"authorization":
|
||||
"Basic ${base64Encode(utf8.encode("Kicap_karan:bb10c6d9f01ec0cb16726b59e36c2f73"))}",
|
||||
"crossDomain": "true"
|
||||
});
|
||||
|
||||
final data = jsonDecode(response.body);
|
||||
// print(data['data2']);
|
||||
result = data;
|
||||
} catch (e) {
|
||||
result = {"status": "error", "message": e.toString()};
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
}
|
||||
30
boss_app/lib/controller/datatables_laporan.dart
Normal file
30
boss_app/lib/controller/datatables_laporan.dart
Normal file
@ -0,0 +1,30 @@
|
||||
import 'dart:math';
|
||||
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class MyData extends DataTableSource {
|
||||
// Generate some made-up data
|
||||
final List<Map<String, dynamic>> _data = List.generate(
|
||||
200,
|
||||
(index) => {
|
||||
"id": index,
|
||||
"title": "Item $index",
|
||||
"price": Random().nextInt(10000),
|
||||
},
|
||||
);
|
||||
|
||||
@override
|
||||
bool get isRowCountApproximate => false;
|
||||
@override
|
||||
int get rowCount => _data.length;
|
||||
@override
|
||||
int get selectedRowCount => 0;
|
||||
@override
|
||||
DataRow getRow(int index) {
|
||||
return DataRow(cells: [
|
||||
DataCell(Text(_data[index]['id'].toString())),
|
||||
DataCell(Text(_data[index]["title"])),
|
||||
DataCell(Text(_data[index]["price"].toString())),
|
||||
]);
|
||||
}
|
||||
}
|
||||
82
boss_app/lib/controller/login_controller.dart
Normal file
82
boss_app/lib/controller/login_controller.dart
Normal file
@ -0,0 +1,82 @@
|
||||
import 'dart:convert';
|
||||
|
||||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:http/http.dart' as http;
|
||||
import 'package:shared_preferences/shared_preferences.dart';
|
||||
|
||||
//create class LoginController extends ChangeNotifier
|
||||
class LoginController extends ChangeNotifier {
|
||||
//create future string login , parameter is String username and password
|
||||
Future<String> login(String username, String password) async {
|
||||
late String _returnString;
|
||||
// print("sini dia");
|
||||
|
||||
try {
|
||||
//create final sharedPreferences
|
||||
final sharedPreferences = await SharedPreferences.getInstance();
|
||||
|
||||
//create http get wih basic auth
|
||||
final response = await http.get(
|
||||
Uri.parse(
|
||||
"http://192.168.43.125/ilham/server2/api/login_user?username=$username&password=$password"),
|
||||
headers: {
|
||||
"Accept": "application/json",
|
||||
"authorization":
|
||||
"Basic ${base64Encode(utf8.encode("Kicap_karan:bb10c6d9f01ec0cb16726b59e36c2f73"))}",
|
||||
"crossDomain": "true"
|
||||
});
|
||||
final data = jsonDecode(response.body);
|
||||
// print(response.statusCode);
|
||||
if (response.statusCode == 200) {
|
||||
if (data['data']['level'] == '0') {
|
||||
sharedPreferences.setString('level', 'Superadmin');
|
||||
} else if (data['data']['level'] == '1') {
|
||||
sharedPreferences.setString('level', 'Boss');
|
||||
}
|
||||
_returnString = "1";
|
||||
sharedPreferences.setString('data', jsonEncode(data['data']));
|
||||
} else if (response.statusCode == 401) {
|
||||
_returnString = "2";
|
||||
}
|
||||
} catch (e) {
|
||||
// print(e);
|
||||
_returnString = "3";
|
||||
}
|
||||
|
||||
//return result
|
||||
return _returnString;
|
||||
}
|
||||
|
||||
// Future<Map> login(String username, String password) async {
|
||||
// //create string result
|
||||
// // String result = "try";
|
||||
// //create map data
|
||||
// Map datanya;
|
||||
// //create http get wih basic auth
|
||||
// var response = await http.get(
|
||||
// Uri.parse(
|
||||
// "http://192.168.43.125/ilham/server2/api/login_user?username=$username&password=$password"),
|
||||
// headers: {
|
||||
// "Accept": "application/json",
|
||||
// "authorization": "Basic " +
|
||||
// base64Encode(
|
||||
// utf8.encode("Kicap_karan:bb10c6d9f01ec0cb16726b59e36c2f73")),
|
||||
// "crossDomain": "true"
|
||||
// });
|
||||
// final data = jsonDecode(response.body);
|
||||
// // print(data["message"][0]['username']);
|
||||
// datanya = data;
|
||||
// print(response.statusCode);
|
||||
// // switch (response.statusCode) {
|
||||
// // case 200:
|
||||
// // final data = response.body;
|
||||
// // print(data);
|
||||
// // break;
|
||||
// // default:
|
||||
// // }
|
||||
|
||||
//return result
|
||||
// return datanya;
|
||||
// }
|
||||
|
||||
}
|
||||
3
boss_app/lib/global.dart
Normal file
3
boss_app/lib/global.dart
Normal file
@ -0,0 +1,3 @@
|
||||
int inidia = 1;
|
||||
// ignore: non_constant_identifier_names
|
||||
String http_to_server = "http://192.168.43.125/ilham/server/";
|
||||
34
boss_app/lib/main.dart
Normal file
34
boss_app/lib/main.dart
Normal file
@ -0,0 +1,34 @@
|
||||
import 'package:boss_app/controller/login_controller.dart';
|
||||
import 'package:boss_app/page/login.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'controller/boss_controller.dart';
|
||||
|
||||
void main() {
|
||||
runApp(const MyApp());
|
||||
}
|
||||
|
||||
class MyApp extends StatelessWidget {
|
||||
const MyApp({Key? key}) : super(key: key);
|
||||
|
||||
// This widget is the root of your application.
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return MultiProvider(
|
||||
providers: [
|
||||
ChangeNotifierProvider<LoginController>(
|
||||
create: (BuildContext context) => LoginController()),
|
||||
ChangeNotifierProvider<BossController>(
|
||||
create: (BuildContext context) => BossController()),
|
||||
],
|
||||
child: MaterialApp(
|
||||
title: 'Flutter Demo',
|
||||
debugShowCheckedModeBanner: false,
|
||||
theme: ThemeData(
|
||||
primarySwatch: Colors.blue,
|
||||
),
|
||||
home: const Login(),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
72
boss_app/lib/page/before_login.dart
Normal file
72
boss_app/lib/page/before_login.dart
Normal file
@ -0,0 +1,72 @@
|
||||
// ignore_for_file: avoid_void_async
|
||||
|
||||
import 'package:boss_app/page/boss/index.dart';
|
||||
import 'package:boss_app/page/login.dart';
|
||||
import 'package:boss_app/page/superadmin/index.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:shared_preferences/shared_preferences.dart';
|
||||
|
||||
class BeforeLogin extends StatefulWidget {
|
||||
const BeforeLogin({Key? key}) : super(key: key);
|
||||
|
||||
@override
|
||||
_BeforeLoginState createState() => _BeforeLoginState();
|
||||
}
|
||||
|
||||
class _BeforeLoginState extends State<BeforeLogin> {
|
||||
//shared prefs
|
||||
late SharedPreferences sharedPreferences;
|
||||
int _loading = 0;
|
||||
|
||||
@override
|
||||
void didChangeDependencies() async {
|
||||
super.didChangeDependencies();
|
||||
sharedPreferences = await SharedPreferences.getInstance();
|
||||
final level = sharedPreferences.getString('level');
|
||||
print(level);
|
||||
|
||||
if (level == null) {
|
||||
sharedPreferences.remove('level');
|
||||
sharedPreferences.remove('data');
|
||||
setState(() {
|
||||
_loading = 3;
|
||||
});
|
||||
}
|
||||
if (level == 'Superadmin') {
|
||||
setState(() {
|
||||
_loading = 1;
|
||||
});
|
||||
}
|
||||
if (level == 'Boss') {
|
||||
setState(() {
|
||||
_loading = 2;
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
late Widget retVal;
|
||||
switch (_loading) {
|
||||
case 0:
|
||||
retVal = Scaffold(
|
||||
appBar: AppBar(
|
||||
title: const Text("Loading"),
|
||||
),
|
||||
body: const Center(child: CircularProgressIndicator()),
|
||||
);
|
||||
break;
|
||||
case 1:
|
||||
retVal = const SuperadminIndex();
|
||||
break;
|
||||
case 2:
|
||||
retVal = BossIndex();
|
||||
break;
|
||||
case 3:
|
||||
retVal = const Login();
|
||||
break;
|
||||
}
|
||||
|
||||
return retVal;
|
||||
}
|
||||
}
|
||||
721
boss_app/lib/page/boss/homeAdmin.dart
Normal file
721
boss_app/lib/page/boss/homeAdmin.dart
Normal file
@ -0,0 +1,721 @@
|
||||
// ignore_for_file: unused_element, non_constant_identifier_names
|
||||
import 'dart:convert';
|
||||
import 'package:boss_app/controller/boss_controller.dart';
|
||||
import 'package:boss_app/widgets/ourContainer.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:intl/intl.dart';
|
||||
import 'package:month_picker_dialog/month_picker_dialog.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
// import '../../controller/datatables_laporan.dart';
|
||||
|
||||
class HomeAdmin extends StatefulWidget {
|
||||
// const HomeAdmin({Key? key}) : super(key: key);
|
||||
@override
|
||||
_HomeAdminState createState() => _HomeAdminState();
|
||||
}
|
||||
|
||||
class _HomeAdminState extends State<HomeAdmin> {
|
||||
int _year = DateTime.now().year.toInt();
|
||||
int _bulan = 0;
|
||||
String _hintTextBulanTahun = '-Pilih Bulan / Tahun Terlebih Dahulu';
|
||||
|
||||
//create string tanggal from today
|
||||
// ignore: prefer_final_fields
|
||||
String _tanggal =
|
||||
'${DateTime.now().year}-${DateTime.now().month}-${DateTime.now().day}';
|
||||
// ignore: prefer_final_fields, prefer_interpolation_to_compose_strings
|
||||
String _headerLaporan = "Laporan Tanggal " +
|
||||
DateTime.now().year.toString() +
|
||||
'-' +
|
||||
DateTime.now().month.toString() +
|
||||
'-' +
|
||||
DateTime.now().day.toString();
|
||||
|
||||
//create list map with field waktu, status, dan ket and push 10 random data
|
||||
// List<Map<String, String>> _listLaporan = [];
|
||||
|
||||
late List<Map<String, String>> _laporan;
|
||||
// late List<Map<String, dynamic>> _laporanDetail;
|
||||
int _loadingLaporan = 0;
|
||||
|
||||
// ignore: avoid_void_async
|
||||
void _ambilLaporan(String tanggal, String bulan, String tahun, String filter,
|
||||
BuildContext context) async {
|
||||
// print(context);
|
||||
// print('hehe');
|
||||
final BossController _ambilLaporan =
|
||||
Provider.of<BossController>(context, listen: false);
|
||||
|
||||
setState(() {
|
||||
_loadingLaporan = 0;
|
||||
});
|
||||
// print(_login);
|
||||
try {
|
||||
final Map _data =
|
||||
await _ambilLaporan.ambilLaporan(tanggal, bulan, tahun, filter);
|
||||
// Navigator.pop(context);
|
||||
|
||||
// print(_data);
|
||||
if (_data['status'] == 'success') {
|
||||
//loop the _data['data'] and push to _laporan by field waktu, status, dan ket
|
||||
if (_data['data'].length > 0) {
|
||||
_laporan = <Map<String, String>>[];
|
||||
for (int i = 0; i < _data['data'].length; i++) {
|
||||
_laporan.add({
|
||||
'waktu': _data['data'][i]['waktu'].toString(),
|
||||
'status': _data['data'][i]['status'],
|
||||
'ket': _data['data'][i]['ket'].toString(),
|
||||
'no_log': _data['data'][i]['no_log'].toString(),
|
||||
});
|
||||
}
|
||||
_laporan = _laporan;
|
||||
setState(() {
|
||||
_loadingLaporan = 1;
|
||||
});
|
||||
} else {
|
||||
setState(() {
|
||||
_loadingLaporan = 2;
|
||||
});
|
||||
}
|
||||
} else if (_data['status'] == 'error') {
|
||||
setState(() {
|
||||
_loadingLaporan = 3;
|
||||
});
|
||||
}
|
||||
} catch (e) {
|
||||
setState(() {
|
||||
_loadingLaporan = 3;
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
int _loadingBottomSheet = 0;
|
||||
// ignore: avoid_void_async
|
||||
void _ambilLaporanDetail(String no_log, BuildContext context) async {
|
||||
// print('sini no_log' + no_log);
|
||||
final BossController _ambilLaporan =
|
||||
Provider.of<BossController>(context, listen: false);
|
||||
|
||||
// ignore: prefer_final_locals
|
||||
Map<String, dynamic> _result = {'data': 0};
|
||||
|
||||
setState(() {
|
||||
_loadingBottomSheet = 0;
|
||||
|
||||
_bottomSheetModal(context, _result);
|
||||
});
|
||||
|
||||
try {
|
||||
final Map _data = await _ambilLaporan.ambilLaporanDetail(no_log);
|
||||
print(_data['status']);
|
||||
Navigator.pop(context);
|
||||
if (_data['status'] == 'success') {
|
||||
// print(_data);
|
||||
|
||||
setState(() {
|
||||
_loadingBottomSheet = 1;
|
||||
// _laporanDetail = _data['data'][0];
|
||||
_bottomSheetModal(context, _data['data'][0]);
|
||||
});
|
||||
} else if (_data['status'] == 'error') {
|
||||
setState(() {
|
||||
_loadingBottomSheet = 2;
|
||||
|
||||
_bottomSheetModal(context, _result);
|
||||
});
|
||||
}
|
||||
} catch (e) {
|
||||
setState(() {
|
||||
_loadingBottomSheet = 2;
|
||||
_bottomSheetModal(context, _result);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
Future<dynamic> _bottomSheetModal(
|
||||
BuildContext context, Map<String, dynamic> _result) async {
|
||||
return showModalBottomSheet(
|
||||
isScrollControlled: true,
|
||||
context: context,
|
||||
shape: RoundedRectangleBorder(
|
||||
borderRadius: BorderRadius.circular(20),
|
||||
),
|
||||
builder: (context) => SingleChildScrollView(
|
||||
child: Column(
|
||||
mainAxisSize: MainAxisSize.min,
|
||||
children: [
|
||||
SizedBox(
|
||||
height: (_loadingBottomSheet == 0 || _loadingBottomSheet == 2)
|
||||
? 50
|
||||
: 20,
|
||||
),
|
||||
if (_loadingBottomSheet == 0)
|
||||
const Center(
|
||||
child: CircularProgressIndicator(),
|
||||
)
|
||||
else if (_loadingBottomSheet == 1)
|
||||
Column(
|
||||
children: [
|
||||
Align(
|
||||
alignment: Alignment.topLeft,
|
||||
child: Row(
|
||||
children: [
|
||||
SizedBox(
|
||||
width: (MediaQuery.of(context).size.width -
|
||||
(MediaQuery.of(context).size.width * 0.8)) /
|
||||
2,
|
||||
),
|
||||
const Text(
|
||||
'Detail Laporan',
|
||||
style: TextStyle(fontWeight: FontWeight.bold),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
const SizedBox(
|
||||
height: 10,
|
||||
),
|
||||
_detailLaporan(_result),
|
||||
],
|
||||
)
|
||||
else if (_loadingBottomSheet == 2)
|
||||
const Text(
|
||||
'Koneksi Ke Server Bermasalah, Sila Periksa Jaringan Anda'),
|
||||
if (_loadingBottomSheet == 0 || _loadingBottomSheet == 2)
|
||||
const SizedBox(
|
||||
height: 50,
|
||||
)
|
||||
else if (_loadingBottomSheet == 1)
|
||||
const SizedBox(
|
||||
height: 30,
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
Widget _detailLaporan(Map<String, dynamic> _result) {
|
||||
// print(_result);
|
||||
FocusManager.instance.primaryFocus?.unfocus();
|
||||
final Map<String, dynamic> _ket = jsonDecode(_result['ket']);
|
||||
// print(_ket);
|
||||
// ignore: prefer_typing_uninitialized_variables
|
||||
var _detail;
|
||||
final formatter = NumberFormat('#,000');
|
||||
|
||||
if (_result['status'] == 'Penjualan Produk') {
|
||||
//create var list map
|
||||
final List<Map<String, dynamic>> _arrayPenjualan = (_ket['ket'] as List)
|
||||
.map((dynamic item) => item as Map<String, dynamic>)
|
||||
.toList();
|
||||
|
||||
final _widgetTabel = DataTable(
|
||||
columns: const [
|
||||
DataColumn(
|
||||
label: Text('Kode Barang'),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text('Jumlah'),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text('Harga Jual'),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text('Total'),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text('Stok Sebelumnya'),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text('Stok Terkini'),
|
||||
),
|
||||
],
|
||||
rows: _arrayPenjualan
|
||||
.map((Map<String, dynamic> laporan) => DataRow(
|
||||
cells: [
|
||||
DataCell(Text(laporan['kode_barang']!)),
|
||||
DataCell(Text(laporan['jumlah']!.toString())),
|
||||
DataCell(Text("Rp. ${laporan['harga_jual']!}")),
|
||||
DataCell(Text("Rp. ${formatter.format(laporan['total'])}")),
|
||||
DataCell(
|
||||
Text(laporan['jumlah_stok_sebelumnya']!.toString())),
|
||||
DataCell(Text(laporan['jumlah_stok_sekarang']!.toString())),
|
||||
],
|
||||
))
|
||||
.toList(),
|
||||
);
|
||||
|
||||
_detail = Column(
|
||||
children: [
|
||||
Text("Total Belanja : Rp. ${_ket['total_belanja']}"),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
Text("Pembayaran : Rp. ${_ket['pembayaran']}"),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
Text("Kembalian : Rp. ${_ket['baki']}"),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
const SizedBox(
|
||||
height: 10,
|
||||
),
|
||||
SingleChildScrollView(
|
||||
child: SingleChildScrollView(
|
||||
scrollDirection: Axis.horizontal, child: _widgetTabel),
|
||||
),
|
||||
],
|
||||
);
|
||||
} else if (_result['status'] == 'Edit Detail Produk') {
|
||||
// ignore: prefer_typing_uninitialized_variables
|
||||
var _namanya, _harganya, _fotonya;
|
||||
if (_ket['nama_lama'] != _ket['nama_baru']) {
|
||||
_namanya = Column(
|
||||
children: [
|
||||
Text('Nama : ${_ket['nama_lama']} => ${_ket['nama_baru']}'),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
],
|
||||
);
|
||||
} else {
|
||||
_namanya = const SizedBox();
|
||||
}
|
||||
|
||||
if (_ket['harga_lama'] != _ket['harga_baru']) {
|
||||
_harganya = Column(
|
||||
children: [
|
||||
Text(
|
||||
'Harga : Rp. ${_ket['harga_lama']} => Rp. ${_ket['harga_baru']}'),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
],
|
||||
);
|
||||
} else {
|
||||
_harganya = const SizedBox();
|
||||
}
|
||||
|
||||
if (_ket['foto_lama'] != _ket['foto_baru']) {
|
||||
_fotonya = Text('Foto : ${_ket['foto_lama']} => ${_ket['foto_baru']}');
|
||||
} else {
|
||||
_fotonya = const SizedBox();
|
||||
}
|
||||
|
||||
_detail = Column(
|
||||
children: [
|
||||
_namanya,
|
||||
_harganya,
|
||||
_fotonya,
|
||||
],
|
||||
);
|
||||
} else if (_result['status'] == 'Penambahan Stok') {
|
||||
_detail = Column(
|
||||
children: [
|
||||
Text("Penambahan Stok : ${_ket['penambahan_stok']}"),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
Text("Harga Pembelian : Rp. ${_ket['harga_pembelian_stok']}"),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
Text("Stok Sebelumnya : ${_ket['jumlah_stok_sebelumnya']}"),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
Text("Stok Baru : ${_ket['total_stok']}"),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
],
|
||||
);
|
||||
} else if (_result['status'] == 'Penambahan Produk Baru') {
|
||||
_detail = Column(
|
||||
children: [
|
||||
Text("Kode Barang : ${_ket['kode_barang']}"),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
Text("Nama Barang : ${_ket['nama']}"),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
Text("Harga Jual : Rp. ${_ket['harga_jual']}"),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
Text("Harga Pembelian Stok : Rp. ${_ket['pembelian_stok']}"),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
Text("Jumlah : ${_ket['jumlah']}"),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
],
|
||||
);
|
||||
} else {
|
||||
_detail = Container();
|
||||
}
|
||||
|
||||
return Container(
|
||||
width: MediaQuery.of(context).size.width * 0.85,
|
||||
padding: const EdgeInsets.only(left: 20, right: 20, bottom: 20, top: 10),
|
||||
decoration: BoxDecoration(
|
||||
color: Colors.white,
|
||||
borderRadius: BorderRadius.circular(20),
|
||||
boxShadow: const [
|
||||
BoxShadow(
|
||||
color: Colors.grey,
|
||||
blurRadius: 10,
|
||||
spreadRadius: 1,
|
||||
offset: Offset(
|
||||
4,
|
||||
4,
|
||||
),
|
||||
),
|
||||
]),
|
||||
child: Column(
|
||||
children: [
|
||||
Text("Waktu : ${_result['waktu']}"),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
Text("Status : ${_result['status']}"),
|
||||
const Divider(
|
||||
color: Colors.black,
|
||||
),
|
||||
_detail,
|
||||
],
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
// _pushYears();
|
||||
// _pushMonths();
|
||||
_ambilLaporan(_tanggal, '', '', '', context);
|
||||
}
|
||||
|
||||
// final DataTableSource _data = MyData();
|
||||
// ignore: prefer_final_fields
|
||||
int _currentSortColumn = 0;
|
||||
bool _isAscending = true;
|
||||
|
||||
// bool _buttonFilter = false;
|
||||
|
||||
final _formKey = GlobalKey<FormState>();
|
||||
final TextEditingController _filterLaporan = TextEditingController();
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
// return Scaffold
|
||||
return Scaffold(
|
||||
body: SingleChildScrollView(
|
||||
child: Column(
|
||||
children: [
|
||||
const SizedBox(
|
||||
height: 10,
|
||||
),
|
||||
OurContainer(
|
||||
child: Column(
|
||||
children: [
|
||||
const Align(
|
||||
alignment: Alignment.topLeft,
|
||||
child: Text(
|
||||
"Form Pilih Bulan / Tahun Laporan",
|
||||
style: TextStyle(fontWeight: FontWeight.bold),
|
||||
),
|
||||
),
|
||||
const SizedBox(
|
||||
height: 10,
|
||||
),
|
||||
TextField(
|
||||
enabled: false,
|
||||
decoration: InputDecoration(
|
||||
border: OutlineInputBorder(
|
||||
borderRadius: BorderRadius.circular(10),
|
||||
),
|
||||
isDense: true,
|
||||
hintText: _hintTextBulanTahun,
|
||||
filled: true,
|
||||
fillColor: const Color.fromARGB(255, 247, 247, 247),
|
||||
),
|
||||
),
|
||||
|
||||
const SizedBox(
|
||||
height: 10,
|
||||
),
|
||||
const SizedBox(
|
||||
height: 10,
|
||||
),
|
||||
|
||||
//create elevated button
|
||||
ElevatedButton(
|
||||
child: const Text('Klik Untuk Pilih Bulan / Tanggal'),
|
||||
onPressed: () {
|
||||
showMonthPicker(
|
||||
context: context,
|
||||
firstDate: DateTime(DateTime.now().year - 1),
|
||||
lastDate: DateTime.now(),
|
||||
initialDate: DateTime.now(),
|
||||
locale: const Locale("id"),
|
||||
).then((date) {
|
||||
// print(date);
|
||||
// get only month and year on date
|
||||
|
||||
setState(() {
|
||||
_tanggal = '';
|
||||
_bulan = date!.month;
|
||||
_year = date.year;
|
||||
_hintTextBulanTahun =
|
||||
'Bulan ${_bulan.toString()} / Tahun ${_year.toString()}';
|
||||
_headerLaporan =
|
||||
"Laporan Bulan ${_bulan.toString()} / Tahun ${_year.toString()}";
|
||||
});
|
||||
_ambilLaporan('', _bulan.toString(), _year.toString(),
|
||||
'', context);
|
||||
// _tanggal = date.day.toString();
|
||||
});
|
||||
},
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
const SizedBox(
|
||||
height: 30,
|
||||
),
|
||||
OurContainer(
|
||||
child: Column(
|
||||
children: [
|
||||
Align(
|
||||
alignment: Alignment.topLeft,
|
||||
child: Text(
|
||||
_headerLaporan,
|
||||
style: const TextStyle(fontWeight: FontWeight.bold),
|
||||
),
|
||||
),
|
||||
//create data table with column "Waktu", "Status", "Aksi" and 10 rows
|
||||
const SizedBox(
|
||||
height: 10,
|
||||
),
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
|
||||
children: [
|
||||
Flexible(
|
||||
child: Form(
|
||||
key: _formKey,
|
||||
child: TextFormField(
|
||||
controller: _filterLaporan,
|
||||
decoration: InputDecoration(
|
||||
border: OutlineInputBorder(
|
||||
borderRadius: BorderRadius.circular(10),
|
||||
),
|
||||
isDense: true,
|
||||
hintText: 'Berdasarkan Waktu / Status',
|
||||
filled: true,
|
||||
fillColor:
|
||||
const Color.fromARGB(255, 247, 247, 247),
|
||||
),
|
||||
// onChanged: (value) {
|
||||
// // print(value);
|
||||
// if (value.isEmpty) {
|
||||
// setState(() {
|
||||
// _buttonFilter = false;
|
||||
// });
|
||||
// } else {
|
||||
// setState(() {
|
||||
// _buttonFilter = true;
|
||||
// });
|
||||
// }
|
||||
// },
|
||||
),
|
||||
),
|
||||
),
|
||||
const SizedBox(width: 20),
|
||||
ElevatedButton(
|
||||
//disabed the button
|
||||
style:
|
||||
// _buttonFilter
|
||||
// ?
|
||||
ElevatedButton.styleFrom(
|
||||
primary: Colors.blue,
|
||||
)
|
||||
// : ElevatedButton.styleFrom(
|
||||
// primary: Colors.grey,
|
||||
// )
|
||||
,
|
||||
onPressed: () {
|
||||
// if (_buttonFilter) {
|
||||
// print(_filterLaporan.text);
|
||||
// print(_tanggal + "heheh");
|
||||
// print(_bulan);
|
||||
// print(_year);
|
||||
if (_tanggal == '') {
|
||||
_ambilLaporan('', _bulan.toString(),
|
||||
_year.toString(), _filterLaporan.text, context);
|
||||
} else {
|
||||
_ambilLaporan(
|
||||
_tanggal, '', '', _filterLaporan.text, context);
|
||||
}
|
||||
FocusManager.instance.primaryFocus?.unfocus();
|
||||
// }
|
||||
},
|
||||
child: const Text('Filter'),
|
||||
),
|
||||
],
|
||||
),
|
||||
|
||||
_tampilkanLaporan()
|
||||
|
||||
// PaginatedDataTable(
|
||||
// columns: [
|
||||
// DataColumn(label: const Text('Waktu')),
|
||||
// DataColumn(label: const Text('Status')),
|
||||
// DataColumn(label: const Text('Aksi')),
|
||||
// ],
|
||||
|
||||
// //source from _listLaporan
|
||||
// source: _data,
|
||||
// )
|
||||
],
|
||||
),
|
||||
),
|
||||
const SizedBox(
|
||||
height: 30,
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
Widget _tampilkanLaporan() {
|
||||
//create switch case
|
||||
switch (_loadingLaporan) {
|
||||
case 0:
|
||||
return Column(
|
||||
children: const [
|
||||
SizedBox(
|
||||
height: 30,
|
||||
),
|
||||
Center(
|
||||
child: CircularProgressIndicator(),
|
||||
),
|
||||
],
|
||||
);
|
||||
case 1:
|
||||
// ignore: sized_box_for_whitespace
|
||||
return Container(
|
||||
height: 400,
|
||||
child: SingleChildScrollView(
|
||||
child: SingleChildScrollView(
|
||||
scrollDirection: Axis.horizontal,
|
||||
child: DataTable(
|
||||
columns: [
|
||||
DataColumn(
|
||||
label: const Text('Waktu'),
|
||||
onSort: (columnIndex, _) {
|
||||
setState(() {
|
||||
if (_isAscending == false) {
|
||||
_laporan.sort((a, b) {
|
||||
return b['waktu']!.compareTo(a['waktu']!);
|
||||
});
|
||||
_isAscending = true;
|
||||
} else {
|
||||
_isAscending = false;
|
||||
_laporan.sort((a, b) {
|
||||
return a['waktu']!.compareTo(b['waktu']!);
|
||||
});
|
||||
}
|
||||
});
|
||||
},
|
||||
),
|
||||
DataColumn(
|
||||
label: const Text('Status'),
|
||||
onSort: (columnIndex, _) {
|
||||
setState(() {
|
||||
if (_isAscending == false) {
|
||||
_laporan.sort((a, b) {
|
||||
return b['status']!.compareTo(a['status']!);
|
||||
});
|
||||
_isAscending = true;
|
||||
} else {
|
||||
_isAscending = false;
|
||||
_laporan.sort((a, b) {
|
||||
return a['status']!.compareTo(b['status']!);
|
||||
});
|
||||
}
|
||||
});
|
||||
},
|
||||
),
|
||||
const DataColumn(label: Text('Aksi')),
|
||||
],
|
||||
//rows = _laporan
|
||||
rows: _laporan
|
||||
.map((Map<String, dynamic> laporan) => DataRow(
|
||||
cells: [
|
||||
DataCell(Text(laporan['waktu']!)),
|
||||
DataCell(Text(laporan['status']!)),
|
||||
DataCell(
|
||||
Row(
|
||||
children: [
|
||||
IconButton(
|
||||
icon: const Icon(Icons.article),
|
||||
color: Colors.blue,
|
||||
onPressed: () {
|
||||
_ambilLaporanDetail(
|
||||
laporan['no_log']!.toString(),
|
||||
context);
|
||||
},
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
],
|
||||
))
|
||||
.toList(),
|
||||
sortColumnIndex: _currentSortColumn,
|
||||
sortAscending: _isAscending,
|
||||
),
|
||||
),
|
||||
),
|
||||
);
|
||||
|
||||
case 2:
|
||||
return Column(
|
||||
children: const [
|
||||
SizedBox(
|
||||
height: 20,
|
||||
),
|
||||
Align(
|
||||
child: Text('Tidak ada laporan untuk filter ini'),
|
||||
),
|
||||
],
|
||||
);
|
||||
|
||||
case 3:
|
||||
return Column(
|
||||
children: const [
|
||||
SizedBox(
|
||||
height: 20,
|
||||
),
|
||||
Align(
|
||||
child: Text(
|
||||
'Koneksi ke server gagal, Sila Cek Koneksi Internet Anda'),
|
||||
),
|
||||
],
|
||||
);
|
||||
|
||||
default:
|
||||
return Container();
|
||||
}
|
||||
}
|
||||
}
|
||||
77
boss_app/lib/page/boss/index.dart
Normal file
77
boss_app/lib/page/boss/index.dart
Normal file
@ -0,0 +1,77 @@
|
||||
import 'package:boss_app/page/boss/homeAdmin.dart';
|
||||
import 'package:boss_app/page/boss/produk.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class BossIndex extends StatefulWidget {
|
||||
@override
|
||||
_BossIndexState createState() => _BossIndexState();
|
||||
}
|
||||
|
||||
class _BossIndexState extends State<BossIndex> {
|
||||
Future<bool> _onWillPop() async {
|
||||
return (await showDialog(
|
||||
context: context,
|
||||
builder: (context) => AlertDialog(
|
||||
title: const Text('Yakin?'),
|
||||
content: const Text('Anda Akan Keluar Dari Aplikasi'),
|
||||
actions: <Widget>[
|
||||
ElevatedButton(
|
||||
onPressed: () => Navigator.of(context).pop(false),
|
||||
child: const Text('Tidak'),
|
||||
),
|
||||
ElevatedButton(
|
||||
onPressed: () => Navigator.of(context).pop(true),
|
||||
style: ElevatedButton.styleFrom(
|
||||
primary: Colors.red,
|
||||
),
|
||||
child: const Text('Ya'),
|
||||
),
|
||||
],
|
||||
),
|
||||
)) ??
|
||||
false;
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
// return Scaffold
|
||||
return WillPopScope(
|
||||
onWillPop: _onWillPop,
|
||||
child: DefaultTabController(
|
||||
length: 3,
|
||||
child: Scaffold(
|
||||
appBar: AppBar(
|
||||
toolbarHeight: AppBar().preferredSize.height + 8,
|
||||
flexibleSpace: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.end,
|
||||
children: const [
|
||||
TabBar(tabs: [
|
||||
Tab(
|
||||
text: 'Home',
|
||||
icon: Icon(Icons.home),
|
||||
),
|
||||
Tab(
|
||||
text: 'Log Produk',
|
||||
icon: Icon(Icons.home),
|
||||
),
|
||||
Tab(
|
||||
text: 'Laporan Penuh',
|
||||
icon: Icon(Icons.home),
|
||||
),
|
||||
])
|
||||
],
|
||||
),
|
||||
),
|
||||
body: TabBarView(
|
||||
children: [
|
||||
HomeAdmin(),
|
||||
ProdukAdmin(),
|
||||
Center(
|
||||
child: Text('ini Ketiga'),
|
||||
),
|
||||
],
|
||||
)),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
356
boss_app/lib/page/boss/produk.dart
Normal file
356
boss_app/lib/page/boss/produk.dart
Normal file
@ -0,0 +1,356 @@
|
||||
import 'package:boss_app/controller/boss_controller.dart';
|
||||
import 'package:boss_app/global.dart' as globals;
|
||||
import 'package:boss_app/widgets/ourContainer.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
|
||||
class ProdukAdmin extends StatefulWidget {
|
||||
// const ProdukAdmin({Key? key}) : super(key: key);
|
||||
@override
|
||||
_ProdukAdminState createState() => _ProdukAdminState();
|
||||
}
|
||||
|
||||
class _ProdukAdminState extends State<ProdukAdmin> {
|
||||
late List<Map<String, dynamic>> _produkAll;
|
||||
int _loadingProdukAll = 0;
|
||||
int _pageNumber = 5;
|
||||
int _pageNumberIndex = 3;
|
||||
|
||||
// ignore: avoid_void_async
|
||||
void _ambilProdukAll(
|
||||
BuildContext context, int pageNumber, String filter) async {
|
||||
// print(context);
|
||||
// print('hehe');
|
||||
_produkAll = [];
|
||||
final BossController _toController =
|
||||
Provider.of<BossController>(context, listen: false);
|
||||
|
||||
// print(_login);
|
||||
try {
|
||||
final Map _data = await _toController.ambilProdukAll(pageNumber, filter);
|
||||
|
||||
if (_data['status'] == 'success') {
|
||||
//loop the _data['data'] and push to _laporan by field waktu, status, dan ket
|
||||
if (_data['data'].length > 0) {
|
||||
// print(_data['ceil'].toString());
|
||||
_produkAll = (_data['data'] as List)
|
||||
.map((dynamic item) => item as Map<String, dynamic>)
|
||||
.toList();
|
||||
// print(_produkAll);
|
||||
setState(() {
|
||||
_loadingProdukAll = 1;
|
||||
// _pageNumber = (_data['ceil'] / 10).ceil();
|
||||
// print(_pageNumber.toString() + " sini lagi try");
|
||||
});
|
||||
} else {
|
||||
setState(() {
|
||||
_loadingProdukAll = 2;
|
||||
});
|
||||
}
|
||||
} else if (_data['status'] == 'error') {
|
||||
setState(() {
|
||||
_loadingProdukAll = 3;
|
||||
});
|
||||
}
|
||||
} catch (e) {
|
||||
print(e);
|
||||
setState(() {
|
||||
_loadingProdukAll = 3;
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
void didChangeDependencies() {
|
||||
_ambilProdukAll(context, 1, '');
|
||||
// print('hehehe');
|
||||
// print(_pageNumber.toString() + "sini ceil");
|
||||
super.didChangeDependencies();
|
||||
|
||||
// super.initState();
|
||||
}
|
||||
|
||||
final TextEditingController _filterProduk = TextEditingController();
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Scaffold(
|
||||
body: SingleChildScrollView(
|
||||
child: Column(
|
||||
children: [
|
||||
const SizedBox(height: 20),
|
||||
OurContainer(
|
||||
child: Column(
|
||||
children: [
|
||||
const Align(
|
||||
alignment: Alignment.topLeft,
|
||||
child: Text(
|
||||
"Filter Produk",
|
||||
style: TextStyle(fontWeight: FontWeight.bold),
|
||||
),
|
||||
),
|
||||
const SizedBox(
|
||||
height: 10,
|
||||
),
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
|
||||
children: [
|
||||
Flexible(
|
||||
child: TextFormField(
|
||||
controller: _filterProduk,
|
||||
decoration: InputDecoration(
|
||||
border: OutlineInputBorder(
|
||||
borderRadius: BorderRadius.circular(10),
|
||||
),
|
||||
isDense: true,
|
||||
hintText: 'Kode / Nama Produk',
|
||||
filled: true,
|
||||
fillColor: const Color.fromARGB(255, 247, 247, 247),
|
||||
),
|
||||
),
|
||||
),
|
||||
const SizedBox(width: 20),
|
||||
ElevatedButton(
|
||||
onPressed: () {},
|
||||
child: Text('Cari'),
|
||||
),
|
||||
],
|
||||
),
|
||||
const SizedBox(height: 20),
|
||||
if (_loadingProdukAll == 0)
|
||||
Center(child: CircularProgressIndicator())
|
||||
else if (_loadingProdukAll == 1)
|
||||
Container(
|
||||
height: 400,
|
||||
child: SingleChildScrollView(
|
||||
child: SingleChildScrollView(
|
||||
scrollDirection: Axis.horizontal,
|
||||
child: Column(
|
||||
children: [
|
||||
DataTable(
|
||||
columns: const [
|
||||
DataColumn(
|
||||
label: Text('Kode'),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text('Nama'),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text('Harga'),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text('Stok'),
|
||||
),
|
||||
DataColumn(
|
||||
label: Text('Laporan'),
|
||||
),
|
||||
],
|
||||
rows: _produkAll
|
||||
.where((Map<String, dynamic> item) =>
|
||||
item['nama']
|
||||
.toString()
|
||||
.toLowerCase()
|
||||
.contains(_filterProduk.text
|
||||
.toLowerCase()))
|
||||
.map((Map<String, dynamic> item) => DataRow(
|
||||
cells: [
|
||||
DataCell(
|
||||
Row(
|
||||
children: [
|
||||
Text(item['kode_barang']
|
||||
.toString()),
|
||||
const SizedBox(width: 10),
|
||||
GestureDetector(
|
||||
onTap: () => _tampilkanFoto(
|
||||
context,
|
||||
item['no_barang'],
|
||||
item['foto']),
|
||||
child: Hero(
|
||||
tag: 'image' +
|
||||
item['no_barang'],
|
||||
child: CircleAvatar(
|
||||
radius: 15,
|
||||
backgroundImage:
|
||||
NetworkImage(
|
||||
globals.http_to_server +
|
||||
"img/" +
|
||||
item[
|
||||
'no_barang'] +
|
||||
"/" +
|
||||
item['foto'],
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
DataCell(
|
||||
Text(item['nama'].toString()),
|
||||
),
|
||||
DataCell(
|
||||
Text("Rp. ${item['harga_jual']}"),
|
||||
),
|
||||
DataCell(
|
||||
Text(item['jumlah'].toString()),
|
||||
),
|
||||
DataCell(IconButton(
|
||||
icon: const Icon(Icons.article),
|
||||
color: Colors.blue,
|
||||
onPressed: () {
|
||||
print('sini ambil laporan');
|
||||
},
|
||||
)),
|
||||
],
|
||||
))
|
||||
.toList(),
|
||||
),
|
||||
_pageButton(),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
)
|
||||
else if (_loadingProdukAll == 2)
|
||||
const Text(
|
||||
'Tidak ada data',
|
||||
textAlign: TextAlign.center,
|
||||
)
|
||||
else if (_loadingProdukAll == 3)
|
||||
const Text(
|
||||
'Koneksi Ke Server Bermasalah, Sila Periksa Jaringan Anda',
|
||||
textAlign: TextAlign.center,
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
const SizedBox(height: 20),
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
Future<dynamic> _tampilkanFoto(
|
||||
BuildContext context, String item, String foto) {
|
||||
return showModalBottomSheet(
|
||||
isScrollControlled: true,
|
||||
context: context,
|
||||
shape: RoundedRectangleBorder(
|
||||
borderRadius: BorderRadius.circular(20),
|
||||
),
|
||||
builder: (context) => SingleChildScrollView(
|
||||
child: Column(
|
||||
children: [
|
||||
Hero(
|
||||
tag: 'image' + item,
|
||||
child: ClipRRect(
|
||||
borderRadius: BorderRadius.circular(20),
|
||||
child: Image.network(
|
||||
globals.http_to_server + "img/" + item + "/" + foto,
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
Row _pageButton() {
|
||||
print(_pageNumber.toString() + "sini page");
|
||||
List<Widget> _pageButton = <Widget>[];
|
||||
if (_pageNumber >= 1 && _pageNumber <= 3) {
|
||||
for (int i = 1; i <= _pageNumber; i++) {
|
||||
_pageButton.add(
|
||||
ElevatedButton(
|
||||
style: ElevatedButton.styleFrom(
|
||||
shape: CircleBorder(),
|
||||
),
|
||||
onPressed: () {
|
||||
print('sini page button' + i.toString());
|
||||
},
|
||||
child: Text(i.toString()),
|
||||
),
|
||||
);
|
||||
}
|
||||
} else if (_pageNumber > 3) {
|
||||
_pageButton.add(
|
||||
ElevatedButton(
|
||||
style: ElevatedButton.styleFrom(
|
||||
shape: CircleBorder(),
|
||||
primary: (_pageNumberIndex != 1) ? Colors.blue : Colors.grey,
|
||||
),
|
||||
onPressed: () {
|
||||
print('<');
|
||||
},
|
||||
child: Text('<'),
|
||||
),
|
||||
);
|
||||
_pageButton.add(
|
||||
ElevatedButton(
|
||||
style: ElevatedButton.styleFrom(
|
||||
shape: CircleBorder(),
|
||||
primary: (_pageNumberIndex != 1) ? Colors.blue : Colors.grey,
|
||||
),
|
||||
onPressed: () {
|
||||
print('1');
|
||||
},
|
||||
child: Text('1'),
|
||||
),
|
||||
);
|
||||
_pageButton.add(
|
||||
Text('...'),
|
||||
);
|
||||
|
||||
if (_pageNumberIndex != 1 && _pageNumberIndex != _pageNumber) {
|
||||
_pageButton.add(
|
||||
ElevatedButton(
|
||||
style: ElevatedButton.styleFrom(
|
||||
shape: CircleBorder(),
|
||||
primary: Colors.grey,
|
||||
),
|
||||
onPressed: () {
|
||||
print('sini page button' + _pageNumberIndex.toString());
|
||||
},
|
||||
child: Text(_pageNumberIndex.toString()),
|
||||
),
|
||||
);
|
||||
_pageButton.add(
|
||||
Text('...'),
|
||||
);
|
||||
}
|
||||
|
||||
_pageButton.add(
|
||||
ElevatedButton(
|
||||
style: ElevatedButton.styleFrom(
|
||||
shape: CircleBorder(),
|
||||
primary:
|
||||
(_pageNumberIndex != _pageNumber) ? Colors.blue : Colors.grey,
|
||||
),
|
||||
onPressed: () {
|
||||
print(_pageNumber.toString());
|
||||
},
|
||||
child: Text(_pageNumber.toString()),
|
||||
),
|
||||
);
|
||||
_pageButton.add(
|
||||
ElevatedButton(
|
||||
style: ElevatedButton.styleFrom(
|
||||
shape: CircleBorder(),
|
||||
primary:
|
||||
(_pageNumberIndex != _pageNumber) ? Colors.blue : Colors.grey,
|
||||
),
|
||||
onPressed: () {
|
||||
print('>');
|
||||
},
|
||||
child: Text('>'),
|
||||
),
|
||||
);
|
||||
}
|
||||
return Row(
|
||||
mainAxisAlignment: MainAxisAlignment.center,
|
||||
children: _pageButton,
|
||||
);
|
||||
}
|
||||
}
|
||||
208
boss_app/lib/page/login.dart
Normal file
208
boss_app/lib/page/login.dart
Normal file
@ -0,0 +1,208 @@
|
||||
// ignore_for_file: sized_box_for_whitespace, prefer_const_constructors
|
||||
|
||||
import 'package:boss_app/controller/login_controller.dart';
|
||||
import 'package:boss_app/page/before_login.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:shared_preferences/shared_preferences.dart';
|
||||
|
||||
class Login extends StatefulWidget {
|
||||
const Login({Key? key}) : super(key: key);
|
||||
|
||||
@override
|
||||
_LoginState createState() => _LoginState();
|
||||
}
|
||||
|
||||
class _LoginState extends State<Login> {
|
||||
final _formKey = GlobalKey<FormState>();
|
||||
//create shared prefs
|
||||
late SharedPreferences sharedPreferences;
|
||||
//create 2 final variables , one for the username and one for the password = TextEditingController
|
||||
final TextEditingController _usernameController = TextEditingController();
|
||||
final TextEditingController _passwordController = TextEditingController();
|
||||
|
||||
bool _isLoading = false;
|
||||
late FocusNode myFocusNode;
|
||||
|
||||
//create void _login with 3 parameters, username, password and context
|
||||
// ignore: avoid_void_async
|
||||
void _login(String username, String password, BuildContext context) async {
|
||||
// create final LoginController loginController = provider.of<LoginController>(context, listen: false);
|
||||
final LoginController _login =
|
||||
Provider.of<LoginController>(context, listen: false);
|
||||
|
||||
//create try catch
|
||||
try {
|
||||
// final Map _returnString = await _login.login(username, password);
|
||||
final String _returnString = await _login.login(username, password);
|
||||
print(_returnString);
|
||||
|
||||
//create switch case
|
||||
switch (_returnString) {
|
||||
case "1":
|
||||
showDialog(
|
||||
context: context,
|
||||
builder: (BuildContext context) {
|
||||
Future.delayed(const Duration(milliseconds: 2500), () {
|
||||
// Navigator.of(context).pop(true);
|
||||
// Navigator.pushAndRemoveUntil(
|
||||
// context,
|
||||
// MaterialPageRoute(
|
||||
// builder: (context) => ScanQRCode(),
|
||||
// ),
|
||||
// (route) => false);
|
||||
});
|
||||
return const AlertDialog(
|
||||
title: Text(
|
||||
"Sukses",
|
||||
textAlign: TextAlign.center,
|
||||
),
|
||||
content: Text(
|
||||
"Selamat Login Kembali",
|
||||
textAlign: TextAlign.center,
|
||||
),
|
||||
);
|
||||
},
|
||||
);
|
||||
|
||||
Future.delayed(const Duration(seconds: 3), () {
|
||||
// Navigator.of(context).pop(true);
|
||||
Navigator.pushAndRemoveUntil(
|
||||
context,
|
||||
MaterialPageRoute(
|
||||
builder: (context) => BeforeLogin(),
|
||||
),
|
||||
(route) => false);
|
||||
});
|
||||
|
||||
break;
|
||||
|
||||
case "2":
|
||||
ScaffoldMessenger.of(context).showSnackBar(SnackBar(
|
||||
content: const Text("Username Dan Password Salah"),
|
||||
));
|
||||
//focus node
|
||||
myFocusNode.requestFocus();
|
||||
break;
|
||||
|
||||
case "3":
|
||||
ScaffoldMessenger.of(context).showSnackBar(SnackBar(
|
||||
content: const Text(
|
||||
"Error Koneksi Ke Server, Sila Periksa Jaringan Anda"),
|
||||
));
|
||||
|
||||
break;
|
||||
}
|
||||
|
||||
setState(() {
|
||||
_isLoading = false;
|
||||
});
|
||||
} catch (e) {
|
||||
print(e);
|
||||
}
|
||||
|
||||
// print(_login);
|
||||
}
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
myFocusNode = FocusNode();
|
||||
}
|
||||
|
||||
@override
|
||||
void dispose() {
|
||||
super.dispose();
|
||||
myFocusNode.dispose();
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Scaffold(
|
||||
//create appbar
|
||||
appBar: AppBar(
|
||||
title: const Text('Halaman Login'),
|
||||
),
|
||||
//create body
|
||||
body: Center(
|
||||
child: SingleChildScrollView(
|
||||
reverse: true,
|
||||
child: _isLoading
|
||||
? const Center(child: CircularProgressIndicator())
|
||||
: Form(
|
||||
key: _formKey,
|
||||
child: Center(
|
||||
child: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.center,
|
||||
// ignore: avoid_redundant_argument_values
|
||||
crossAxisAlignment: CrossAxisAlignment.center,
|
||||
children: <Widget>[
|
||||
Container(
|
||||
width: MediaQuery.of(context).size.width * 0.8,
|
||||
child: TextFormField(
|
||||
focusNode: myFocusNode,
|
||||
controller: _usernameController,
|
||||
keyboardType: TextInputType.text,
|
||||
decoration: const InputDecoration(
|
||||
border: OutlineInputBorder(),
|
||||
hintText: "Masukkan Username",
|
||||
labelText: 'Username',
|
||||
),
|
||||
validator: (value) {
|
||||
if (value!.isEmpty) {
|
||||
return 'Masukkan Username';
|
||||
}
|
||||
return null;
|
||||
},
|
||||
),
|
||||
),
|
||||
const SizedBox(
|
||||
height: 20,
|
||||
),
|
||||
Container(
|
||||
width: MediaQuery.of(context).size.width * 0.8,
|
||||
child: TextFormField(
|
||||
controller: _passwordController,
|
||||
keyboardType: TextInputType.text,
|
||||
obscureText: true,
|
||||
decoration: const InputDecoration(
|
||||
border: OutlineInputBorder(),
|
||||
hintText: "Masukkan Password",
|
||||
labelText: 'Password',
|
||||
),
|
||||
validator: (value) {
|
||||
if (value!.isEmpty) {
|
||||
return 'Masukkan Pasword';
|
||||
}
|
||||
return null;
|
||||
},
|
||||
),
|
||||
),
|
||||
const SizedBox(
|
||||
height: 20,
|
||||
),
|
||||
Container(
|
||||
width: MediaQuery.of(context).size.width * 0.8,
|
||||
height: 50,
|
||||
child: ElevatedButton(
|
||||
child: const Text('Login'),
|
||||
onPressed: () {
|
||||
if (_formKey.currentState!.validate()) {
|
||||
setState(() {
|
||||
_isLoading = true;
|
||||
});
|
||||
_login(_usernameController.text,
|
||||
_passwordController.text, context);
|
||||
}
|
||||
},
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
23
boss_app/lib/page/superadmin/index.dart
Normal file
23
boss_app/lib/page/superadmin/index.dart
Normal file
@ -0,0 +1,23 @@
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class SuperadminIndex extends StatefulWidget {
|
||||
const SuperadminIndex({Key? key}) : super(key: key);
|
||||
|
||||
@override
|
||||
_SuperadminIndexState createState() => _SuperadminIndexState();
|
||||
}
|
||||
|
||||
class _SuperadminIndexState extends State<SuperadminIndex> {
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
// return Scaffold
|
||||
return Scaffold(
|
||||
appBar: AppBar(
|
||||
title: const Text('Superadmin'),
|
||||
),
|
||||
body: const Center(
|
||||
child: Text('Superadmin'),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
33
boss_app/lib/widgets/ourContainer.dart
Normal file
33
boss_app/lib/widgets/ourContainer.dart
Normal file
@ -0,0 +1,33 @@
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class OurContainer extends StatelessWidget {
|
||||
final Widget? child;
|
||||
|
||||
const OurContainer({Key? key, this.child}) : super(key: key);
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
final double left = (MediaQuery.of(context).size.width -
|
||||
(MediaQuery.of(context).size.width * 0.9)) /
|
||||
2;
|
||||
return Container(
|
||||
width: MediaQuery.of(context).size.width * 0.9,
|
||||
margin: EdgeInsets.only(left: left),
|
||||
padding: const EdgeInsets.only(left: 20, right: 20, bottom: 20, top: 10),
|
||||
decoration: BoxDecoration(
|
||||
color: Colors.white,
|
||||
borderRadius: BorderRadius.circular(20),
|
||||
boxShadow: const [
|
||||
BoxShadow(
|
||||
color: Colors.grey,
|
||||
blurRadius: 10,
|
||||
spreadRadius: 1,
|
||||
offset: Offset(
|
||||
4,
|
||||
4,
|
||||
),
|
||||
),
|
||||
]),
|
||||
child: child,
|
||||
);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user