Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in
Toggle navigation
L
library-app-flutter
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Ilham Maulana
library-app-flutter
Commits
a7aeb206
Commit
a7aeb206
authored
Aug 01, 2024
by
Ilham Maulana
💻
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix: shifting near outstanding and overdue loans (admin access) to one reusable widget
parent
68feb6a9
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
26 additions
and
101 deletions
+26
-101
admin_list_screen.dart
lib/src/screens/admin_list_screen.dart
+4
-4
admin_loan_list.dart
lib/src/widgets/loans/admin_loan_list.dart
+22
-9
upcoming_loan_list.dart
lib/src/widgets/loans/upcoming_loan_list.dart
+0
-88
No files found.
lib/src/screens/admin_list_screen.dart
View file @
a7aeb206
import
'package:flutter/material.dart'
;
import
'package:flutter/material.dart'
;
import
'package:library_app/src/widgets/loans/admin_loan_list.dart'
;
import
'package:provider/provider.dart'
;
import
'package:provider/provider.dart'
;
import
'package:library_app/src/providers/auth_provider.dart'
;
import
'package:library_app/src/providers/auth_provider.dart'
;
...
@@ -7,8 +8,6 @@ import 'package:library_app/src/providers/navigations_provider.dart';
...
@@ -7,8 +8,6 @@ import 'package:library_app/src/providers/navigations_provider.dart';
import
'package:library_app/src/widgets/home.dart'
;
import
'package:library_app/src/widgets/home.dart'
;
import
'package:library_app/src/widgets/profile.dart'
;
import
'package:library_app/src/widgets/profile.dart'
;
import
'package:library_app/src/widgets/loans/overdued_loan_list.dart'
;
import
'package:library_app/src/widgets/loans/upcoming_loan_list.dart'
;
class
AdminListScreen
extends
StatefulWidget
{
class
AdminListScreen
extends
StatefulWidget
{
const
AdminListScreen
({
super
.
key
});
const
AdminListScreen
({
super
.
key
});
...
@@ -61,9 +60,10 @@ class _AdminListScreen extends State<AdminListScreen> {
...
@@ -61,9 +60,10 @@ class _AdminListScreen extends State<AdminListScreen> {
// Home
// Home
const
HomePage
(),
const
HomePage
(),
// Near Outstanding Loans
// Near Outstanding Loans
const
UpcomingLoanList
(),
const
AdminLoanList
(
title:
"Near Outstanding Loans"
,
type:
"upcoming"
),
// Overdued Loans
// Overdued Loans
const
OverduedLoanList
(
),
const
AdminLoanList
(
title:
"Overdued Loans"
,
type:
"overdue"
),
// Profile
// Profile
const
Profile
(),
const
Profile
(),
][
navProvider
.
currentPageIndex
],
][
navProvider
.
currentPageIndex
],
...
...
lib/src/widgets/loans/
overdued
_loan_list.dart
→
lib/src/widgets/loans/
admin
_loan_list.dart
View file @
a7aeb206
...
@@ -6,25 +6,38 @@ import 'package:provider/provider.dart';
...
@@ -6,25 +6,38 @@ import 'package:provider/provider.dart';
import
'package:library_app/src/models/loan.dart'
;
import
'package:library_app/src/models/loan.dart'
;
import
'package:library_app/src/widgets/loans/loan_item.dart'
;
import
'package:library_app/src/widgets/loans/loan_item.dart'
;
class
OverduedLoanList
extends
StatefulWidget
{
class
AdminLoanList
extends
StatefulWidget
{
const
OverduedLoanList
({
super
.
key
});
final
String
title
;
final
String
type
;
const
AdminLoanList
({
super
.
key
,
required
this
.
title
,
required
this
.
type
,
});
@override
@override
State
<
OverduedLoanList
>
createState
()
=>
_Overdued
LoanList
();
State
<
AdminLoanList
>
createState
()
=>
_Admin
LoanList
();
}
}
class
_OverduedLoanList
extends
State
<
OverduedLoanList
>
{
class
_AdminLoanList
extends
State
<
AdminLoanList
>
{
String
get
title
=>
widget
.
title
;
String
get
type
=>
widget
.
type
;
@override
@override
void
initState
()
{
void
initState
()
{
super
.
initState
();
super
.
initState
();
Provider
.
of
<
AuthProvider
>(
context
,
listen:
false
).
getLoans
(
"overdue"
);
Provider
.
of
<
AuthProvider
>(
context
,
listen:
false
).
getLoans
(
type
);
}
}
@override
@override
Widget
build
(
BuildContext
context
)
{
Widget
build
(
BuildContext
context
)
{
return
Consumer
<
AuthProvider
>(
builder:
(
context
,
loanProvider
,
child
)
{
return
Consumer
<
AuthProvider
>(
builder:
(
context
,
loanProvider
,
child
)
{
if
(
loanProvider
.
overduedLoans
!=
null
)
{
final
getLoans
=
type
==
"upcoming"
var
loans
=
loanProvider
.
overduedLoans
!.
map
(
?
loanProvider
.
nearOutstandingLoans
:
loanProvider
.
overduedLoans
;
if
(
getLoans
!=
null
)
{
var
loans
=
getLoans
.
map
(
(
loan
)
{
(
loan
)
{
var
book
=
Book
.
fromJson
(
loan
[
"book_detail"
]);
var
book
=
Book
.
fromJson
(
loan
[
"book_detail"
]);
return
Loan
(
return
Loan
(
...
@@ -39,7 +52,7 @@ class _OverduedLoanList extends State<OverduedLoanList> {
...
@@ -39,7 +52,7 @@ class _OverduedLoanList extends State<OverduedLoanList> {
return
NestedScrollView
(
return
NestedScrollView
(
headerSliverBuilder:
(
BuildContext
context
,
bool
innerBoxIsScrolled
)
{
headerSliverBuilder:
(
BuildContext
context
,
bool
innerBoxIsScrolled
)
{
return
[
const
TopAppBar
(
title:
"Overdued Loans"
)];
return
[
TopAppBar
(
title:
title
)];
},
},
body:
ListView
(
body:
ListView
(
children:
List
.
generate
(
loans
.
length
,
(
index
)
{
children:
List
.
generate
(
loans
.
length
,
(
index
)
{
...
@@ -50,7 +63,7 @@ class _OverduedLoanList extends State<OverduedLoanList> {
...
@@ -50,7 +63,7 @@ class _OverduedLoanList extends State<OverduedLoanList> {
}
else
{
}
else
{
return
NestedScrollView
(
return
NestedScrollView
(
headerSliverBuilder:
(
BuildContext
context
,
bool
innerBoxIsScrolled
)
{
headerSliverBuilder:
(
BuildContext
context
,
bool
innerBoxIsScrolled
)
{
return
[
const
TopAppBar
(
title:
"Book Loans"
)];
return
[
TopAppBar
(
title:
title
)];
},
},
body:
const
Center
(
body:
const
Center
(
child:
Text
(
"the loan is currently empty"
),
child:
Text
(
"the loan is currently empty"
),
...
...
lib/src/widgets/loans/upcoming_loan_list.dart
deleted
100644 → 0
View file @
68feb6a9
import
'package:flutter/material.dart'
;
import
'package:library_app/src/models/book.dart'
;
import
'package:library_app/src/providers/auth_provider.dart'
;
import
'package:provider/provider.dart'
;
import
'package:library_app/src/models/loan.dart'
;
import
'package:library_app/src/widgets/loans/loan_item.dart'
;
class
UpcomingLoanList
extends
StatefulWidget
{
const
UpcomingLoanList
({
super
.
key
});
@override
State
<
UpcomingLoanList
>
createState
()
=>
_UpcomingLoanList
();
}
class
_UpcomingLoanList
extends
State
<
UpcomingLoanList
>
{
@override
void
initState
()
{
super
.
initState
();
Provider
.
of
<
AuthProvider
>(
context
,
listen:
false
).
getLoans
(
"upcoming"
);
}
@override
Widget
build
(
BuildContext
context
)
{
return
Consumer
<
AuthProvider
>(
builder:
(
context
,
loanProvider
,
child
)
{
if
(
loanProvider
.
nearOutstandingLoans
!=
null
)
{
var
loans
=
loanProvider
.
nearOutstandingLoans
!.
map
(
(
loan
)
{
var
book
=
Book
.
fromJson
(
loan
[
"book_detail"
]);
return
Loan
(
book
,
loan
[
"loan_date"
],
loan
[
"due_date"
],
loan
[
"remaining_loan_time"
],
loan
[
"is_overdue"
],
);
},
);
return
NestedScrollView
(
headerSliverBuilder:
(
BuildContext
context
,
bool
innerBoxIsScrolled
)
{
return
[
const
TopAppBar
(
title:
"Near Outstanding Loans"
)];
},
body:
ListView
(
children:
List
.
generate
(
loans
.
length
,
(
index
)
{
return
LoanItem
(
loans
.
elementAt
(
index
));
}),
),
);
}
else
{
return
NestedScrollView
(
headerSliverBuilder:
(
BuildContext
context
,
bool
innerBoxIsScrolled
)
{
return
[
const
TopAppBar
(
title:
"Book Loans"
)];
},
body:
const
Center
(
child:
Text
(
"the loan is currently empty"
),
),
);
}
});
}
}
class
TopAppBar
extends
StatefulWidget
{
final
String
title
;
const
TopAppBar
({
super
.
key
,
required
this
.
title
});
@override
_TopAppBar
createState
()
=>
_TopAppBar
();
}
class
_TopAppBar
extends
State
<
TopAppBar
>
{
String
get
title
=>
widget
.
title
;
bool
showWidget
=
false
;
@override
Widget
build
(
BuildContext
context
)
{
return
SliverAppBar
(
title:
Text
(
title
),
elevation:
10.0
,
automaticallyImplyLeading:
false
,
expandedHeight:
50
,
floating:
true
,
snap:
true
,
);
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment