Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
P
portal-apps-manage
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Registry
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
angular
portal-apps-manage
Commits
03c321cb
Commit
03c321cb
authored
Sep 18, 2025
by
sawit
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
api widget by module
parent
a6a50aed
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
58 additions
and
16 deletions
+58
-16
api.service.ts
src/app/core/services/api.service.ts
+6
-2
dashboard-management.component.ts
...ge/dashboard-management/dashboard-management.component.ts
+26
-4
dashboard-data.service.ts
...e/dashboard-management/services/dashboard-data.service.ts
+12
-6
home.component.ts
src/app/portal-manage/home/home.component.ts
+1
-0
header.component.html
src/app/shared/components/header/header.component.html
+8
-4
header.component.ts
src/app/shared/components/header/header.component.ts
+5
-0
No files found.
src/app/core/services/api.service.ts
View file @
03c321cb
...
@@ -48,8 +48,12 @@ export class ApiService {
...
@@ -48,8 +48,12 @@ export class ApiService {
.
pipe
(
catchError
(
this
.
formatErrors
));
.
pipe
(
catchError
(
this
.
formatErrors
));
}
}
delete
<
T
>
(
path
:
string
):
Observable
<
T
>
{
delete
<
T
>
(
path
:
string
,
options
?:
{
body
?:
any
}):
Observable
<
T
>
{
return
this
.
http
.
delete
<
T
>
(
`
${
this
.
apiUrl
}${
path
}
`
,
{
headers
:
this
.
getHeaders
()
})
const
requestOptions
=
{
headers
:
this
.
getHeaders
(),
body
:
options
?.
body
};
return
this
.
http
.
delete
<
T
>
(
`
${
this
.
apiUrl
}${
path
}
`
,
requestOptions
)
.
pipe
(
catchError
(
this
.
formatErrors
));
.
pipe
(
catchError
(
this
.
formatErrors
));
}
}
}
}
src/app/portal-manage/dashboard-management/dashboard-management.component.ts
View file @
03c321cb
...
@@ -3,7 +3,7 @@ import { ActivatedRoute, RouterModule } from '@angular/router';
...
@@ -3,7 +3,7 @@ import { ActivatedRoute, RouterModule } from '@angular/router';
import
{
CommonModule
,
TitleCasePipe
}
from
'@angular/common'
;
import
{
CommonModule
,
TitleCasePipe
}
from
'@angular/common'
;
import
{
NgComponentOutlet
}
from
'@angular/common'
;
import
{
NgComponentOutlet
}
from
'@angular/common'
;
import
{
FormsModule
}
from
'@angular/forms'
;
import
{
FormsModule
}
from
'@angular/forms'
;
import
{
throwError
}
from
'rxjs'
;
import
{
throwError
,
Observable
}
from
'rxjs'
;
import
{
map
,
switchMap
,
catchError
,
take
}
from
'rxjs/operators'
;
import
{
map
,
switchMap
,
catchError
,
take
}
from
'rxjs/operators'
;
import
{
DashboardLayoutComponent
,
DashboardLayoutModule
,
PanelModel
}
from
'@syncfusion/ej2-angular-layouts'
;
import
{
DashboardLayoutComponent
,
DashboardLayoutModule
,
PanelModel
}
from
'@syncfusion/ej2-angular-layouts'
;
import
{
MatDialog
,
MatDialogModule
}
from
'@angular/material/dialog'
;
import
{
MatDialog
,
MatDialogModule
}
from
'@angular/material/dialog'
;
...
@@ -110,7 +110,7 @@ export class DashboardManagementComponent implements OnInit, OnDestroy {
...
@@ -110,7 +110,7 @@ export class DashboardManagementComponent implements OnInit, OnDestroy {
this
.
setResponsiveColumns
();
this
.
setResponsiveColumns
();
});
});
this
.
dashboardDataService
.
get
Dashboards
().
pipe
(
this
.
getFiltered
Dashboards
().
pipe
(
catchError
(
error
=>
{
catchError
(
error
=>
{
this
.
notificationService
.
error
(
'Error'
,
'Failed to load user dashboards.'
);
this
.
notificationService
.
error
(
'Error'
,
'Failed to load user dashboards.'
);
return
throwError
(()
=>
error
);
return
throwError
(()
=>
error
);
...
@@ -127,6 +127,28 @@ export class DashboardManagementComponent implements OnInit, OnDestroy {
...
@@ -127,6 +127,28 @@ export class DashboardManagementComponent implements OnInit, OnDestroy {
});
});
}
}
private
getDashboardQueryParams
():
any
{
const
module
=
sessionStorage
.
getItem
(
'module'
);
let
queryParams
=
{};
if
(
module
)
{
queryParams
=
{
application
:
module
};
}
return
queryParams
;
}
private
getFilteredDashboards
():
Observable
<
DashboardModel
[]
>
{
const
queryParams
=
this
.
getDashboardQueryParams
();
return
this
.
dashboardDataService
.
getDashboards
().
pipe
(
map
(
dashboards
=>
{
// Show all dashboards if the module is 'dashboard-management', otherwise filter by application.
if
(
queryParams
.
application
&&
queryParams
.
application
!==
'dashboard-management'
)
{
return
dashboards
.
filter
(
dashboard
=>
dashboard
.
application
===
queryParams
.
application
);
}
return
dashboards
;
})
);
}
private
setResponsiveColumns
():
void
{
private
setResponsiveColumns
():
void
{
const
width
=
window
.
innerWidth
;
const
width
=
window
.
innerWidth
;
if
(
width
<=
480
)
{
if
(
width
<=
480
)
{
...
@@ -219,7 +241,7 @@ export class DashboardManagementComponent implements OnInit, OnDestroy {
...
@@ -219,7 +241,7 @@ export class DashboardManagementComponent implements OnInit, OnDestroy {
});
});
this
.
dashboardDataService
.
saveDashboard
(
newDashboard
).
pipe
(
this
.
dashboardDataService
.
saveDashboard
(
newDashboard
).
pipe
(
switchMap
(
addedDashboard
=>
{
switchMap
(
addedDashboard
=>
{
return
this
.
dashboardDataService
.
get
Dashboards
().
pipe
(
return
this
.
getFiltered
Dashboards
().
pipe
(
map
(
dashboards
=>
({
addedDashboard
,
dashboards
}))
map
(
dashboards
=>
({
addedDashboard
,
dashboards
}))
);
);
}),
}),
...
@@ -258,7 +280,7 @@ export class DashboardManagementComponent implements OnInit, OnDestroy {
...
@@ -258,7 +280,7 @@ export class DashboardManagementComponent implements OnInit, OnDestroy {
this
.
dashboardDataService
.
deleteDashboard
(
this
.
selectedDashboardId
).
pipe
(
this
.
dashboardDataService
.
deleteDashboard
(
this
.
selectedDashboardId
).
pipe
(
switchMap
(()
=>
{
switchMap
(()
=>
{
// Refresh the list of dashboards after deletion
// Refresh the list of dashboards after deletion
return
this
.
dashboardDataService
.
get
Dashboards
();
return
this
.
getFiltered
Dashboards
();
}),
}),
catchError
(
error
=>
{
catchError
(
error
=>
{
this
.
notificationService
.
error
(
'Error'
,
'Failed to delete dashboard.'
);
this
.
notificationService
.
error
(
'Error'
,
'Failed to delete dashboard.'
);
...
...
src/app/portal-manage/dashboard-management/services/dashboard-data.service.ts
View file @
03c321cb
import
{
Injectable
}
from
'@angular/core'
;
import
{
Injectable
}
from
'@angular/core'
;
import
{
Observable
,
of
}
from
'rxjs'
;
import
{
Observable
,
of
}
from
'rxjs'
;
import
{
DashboardModel
,
WidgetModel
}
from
'../models/widgets.model'
;
import
{
DashboardModel
,
WidgetModel
}
from
'../models/widgets.model'
;
import
{
HttpParams
}
from
'@angular/common/http'
;
// Keep HttpParams if still used
import
{
HttpParams
,
HttpHeaders
}
from
'@angular/common/http'
;
// Keep HttpParams if still used
import
{
ApiService
}
from
'../../../core/services/api.service'
;
import
{
ApiService
}
from
'../../../core/services/api.service'
;
@
Injectable
({
@
Injectable
({
...
@@ -28,10 +28,16 @@ export class DashboardDataService {
...
@@ -28,10 +28,16 @@ export class DashboardDataService {
return
this
.
apiService
.
post
<
DashboardModel
>
(
'dashboard'
,
dashboard
);
return
this
.
apiService
.
post
<
DashboardModel
>
(
'dashboard'
,
dashboard
);
}
}
deleteDashboard
(
dashboard
:
DashboardModel
):
Observable
<
void
>
{
deleteDashboard
(
dashboard
:
DashboardModel
):
Observable
<
any
>
{
// Assuming the backend expects the ID in the URL for DELETE
const
body
=
{
// If the backend expects the full object in the body for DELETE,
dashboardId
:
dashboard
.
dashboardId
// you might need to adjust ApiService.delete or use apiService.post to a specific delete endpoint.
};
return
this
.
apiService
.
delete
<
void
>
(
`dashboard/
${
dashboard
.
dashboardId
}
`
);
const
options
=
{
headers
:
new
HttpHeaders
({
'Content-Type'
:
'application/json'
,
}),
body
:
body
};
return
this
.
apiService
.
delete
<
any
>
(
'dashboard'
,
options
);
}
}
}
}
src/app/portal-manage/home/home.component.ts
View file @
03c321cb
...
@@ -362,6 +362,7 @@ export class HomeComponent implements OnInit {
...
@@ -362,6 +362,7 @@ export class HomeComponent implements OnInit {
navigateToApp
(
app
:
AppModule
)
{
navigateToApp
(
app
:
AppModule
)
{
// เนื่องจากทุก path ตอนนี้เริ่มด้วย /portal-manage แล้ว
// เนื่องจากทุก path ตอนนี้เริ่มด้วย /portal-manage แล้ว
this
.
router
.
navigate
([
app
.
path
]);
this
.
router
.
navigate
([
app
.
path
]);
window
.
sessionStorage
.
setItem
(
"module"
,
app
.
name
);
}
}
getAppCardClass
(
app
:
AppModule
):
string
{
getAppCardClass
(
app
:
AppModule
):
string
{
...
...
src/app/shared/components/header/header.component.html
View file @
03c321cb
...
@@ -385,7 +385,8 @@
...
@@ -385,7 +385,8 @@
<!-- Meeting Booking -->
<!-- Meeting Booking -->
<div
class=
""
>
<div
class=
""
>
<a
routerLink=
"/portal-manage/meeting-booking"
<!-- <a routerLink="/portal-manage/meeting-booking" -->
<a
(
click
)="
routerApp
('
meeting-booking
')"
class=
"p-3 items-center related-app block text-center rounded-sm hover:bg-gray-50 dark:hover:bg-black/20"
>
class=
"p-3 items-center related-app block text-center rounded-sm hover:bg-gray-50 dark:hover:bg-black/20"
>
<img
src=
"./assets/images/logoallHR/booking.png"
alt=
"Meeting Booking"
<img
src=
"./assets/images/logoallHR/booking.png"
alt=
"Meeting Booking"
class=
"leading-[1.5] text-2xl !h-[1.5rem] align-middle flex justify-center mx-auto"
>
class=
"leading-[1.5] text-2xl !h-[1.5rem] align-middle flex justify-center mx-auto"
>
...
@@ -395,7 +396,8 @@
...
@@ -395,7 +396,8 @@
<!-- my-Portal -->
<!-- my-Portal -->
<div
class=
""
>
<div
class=
""
>
<a
routerLink=
"/portal-manage/my-portal"
<!-- <a routerLink="/portal-manage/my-portal" -->
<a
(
click
)="
routerApp
('
my-portal
')"
class=
"p-3 items-center related-app block text-center rounded-sm hover:bg-gray-50 dark:hover:bg-black/20"
>
class=
"p-3 items-center related-app block text-center rounded-sm hover:bg-gray-50 dark:hover:bg-black/20"
>
<img
src=
"./assets/images/logoallHR/portal.webp"
alt=
"my-Portal"
<img
src=
"./assets/images/logoallHR/portal.webp"
alt=
"my-Portal"
class=
"leading-[1.5] text-2xl !h-[1.5rem] align-middle flex justify-center mx-auto"
>
class=
"leading-[1.5] text-2xl !h-[1.5rem] align-middle flex justify-center mx-auto"
>
...
@@ -405,7 +407,8 @@
...
@@ -405,7 +407,8 @@
<!-- Permission Management -->
<!-- Permission Management -->
<div
class=
""
>
<div
class=
""
>
<a
routerLink=
"/portal-manage/permission-management"
<!-- <a routerLink="/portal-manage/permission-management" -->
<a
(
click
)="
routerApp
('
permission-management
')"
class=
"p-3 items-center related-app block text-center rounded-sm hover:bg-gray-50 dark:hover:bg-black/20"
>
class=
"p-3 items-center related-app block text-center rounded-sm hover:bg-gray-50 dark:hover:bg-black/20"
>
<img
src=
"./assets/images/logoallHR/permission.png"
alt=
"Permission Management"
<img
src=
"./assets/images/logoallHR/permission.png"
alt=
"Permission Management"
class=
"leading-[1.5] text-2xl !h-[1.5rem] align-middle flex justify-center mx-auto"
>
class=
"leading-[1.5] text-2xl !h-[1.5rem] align-middle flex justify-center mx-auto"
>
...
@@ -415,7 +418,8 @@
...
@@ -415,7 +418,8 @@
<!-- Dashboard Management -->
<!-- Dashboard Management -->
<div
class=
""
>
<div
class=
""
>
<a
routerLink=
"/portal-manage/dashboard-management"
<!-- <a routerLink="/portal-manage/dashboard-management" -->
<a
(
click
)="
routerApp
('
dashboard-management
')"
class=
"p-3 items-center related-app block text-center rounded-sm hover:bg-gray-50 dark:hover:bg-black/20"
>
class=
"p-3 items-center related-app block text-center rounded-sm hover:bg-gray-50 dark:hover:bg-black/20"
>
<img
src=
"./assets/images/logoallHR/widget.webp"
alt=
"Dashboard Management"
<img
src=
"./assets/images/logoallHR/widget.webp"
alt=
"Dashboard Management"
class=
"leading-[1.5] text-2xl !h-[1.5rem] align-middle flex justify-center mx-auto"
>
class=
"leading-[1.5] text-2xl !h-[1.5rem] align-middle flex justify-center mx-auto"
>
...
...
src/app/shared/components/header/header.component.ts
View file @
03c321cb
...
@@ -260,6 +260,11 @@ export class HeaderComponent {
...
@@ -260,6 +260,11 @@ export class HeaderComponent {
this
.
router
.
navigate
([
'/portal-manage/'
+
appmodule
])
this
.
router
.
navigate
([
'/portal-manage/'
+
appmodule
])
}
}
routerApp
(
appmodule
:
string
){
this
.
router
.
navigate
([
'/portal-manage/'
+
appmodule
])
window
.
sessionStorage
.
setItem
(
"module"
,
appmodule
);
}
goToHome
()
{
goToHome
()
{
this
.
router
.
navigate
([
'/home'
])
this
.
router
.
navigate
([
'/home'
])
}
}
...
...
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