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
7682af35
Commit
7682af35
authored
Sep 16, 2025
by
Ooh-Ao
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ww
parent
5cca44a4
Show whitespace changes
Inline
Side-by-side
Showing
19 changed files
with
167 additions
and
52 deletions
+167
-52
app.component.html
src/app/app.component.html
+7
-7
app.component.ts
src/app/app.component.ts
+14
-11
dashboard-management.component.html
.../dashboard-management/dashboard-management.component.html
+2
-1
dashboard-management.component.ts
...ge/dashboard-management/dashboard-management.component.ts
+2
-1
dataset-widget-linker.component.ts
...ment/widget-management/dataset-widget-linker.component.ts
+2
-2
area-chart-widget.component.ts
.../widgets/area-chart-widget/area-chart-widget.component.ts
+12
-1
bar-chart-widget.component.ts
...nt/widgets/bar-chart-widget/bar-chart-widget.component.ts
+12
-1
combo-chart-widget.component.html
...gets/combo-chart-widget/combo-chart-widget.component.html
+2
-2
combo-chart-widget.component.ts
...idgets/combo-chart-widget/combo-chart-widget.component.ts
+22
-1
doughnut-chart-widget.component.ts
.../doughnut-chart-widget/doughnut-chart-widget.component.ts
+12
-2
data-table-widget.component.ts
...nt/widgets/dynamic-widgets/data-table-widget.component.ts
+2
-2
funnel-chart-widget.component.ts
...gets/funnel-chart-widget/funnel-chart-widget.component.ts
+12
-1
gauge-chart-widget.component.ts
...idgets/gauge-chart-widget/gauge-chart-widget.component.ts
+5
-4
pie-chart-widget.component.ts
...nt/widgets/pie-chart-widget/pie-chart-widget.component.ts
+12
-2
scatter-bubble-chart-widget.component.ts
...ble-chart-widget/scatter-bubble-chart-widget.component.ts
+18
-2
syncfusion-chart-widget.component.html
...usion-chart-widget/syncfusion-chart-widget.component.html
+1
-1
syncfusion-chart-widget.component.ts
...cfusion-chart-widget/syncfusion-chart-widget.component.ts
+16
-8
syncfusion-datagrid-widget.component.ts
...n-datagrid-widget/syncfusion-datagrid-widget.component.ts
+2
-2
waterfall-chart-widget.component.ts
...aterfall-chart-widget/waterfall-chart-widget.component.ts
+12
-1
No files found.
src/app/app.component.html
View file @
7682af35
<router-outlet></router-outlet>
<router-outlet></router-outlet>
<ejs-dialog
#
notificationDialog
<
!-- <
ejs-dialog #notificationDialog
[
header
]="
notification
?.
title
"
[header]="notification?.title
|| ''
"
[
content
]="
notification
?.
content
"
[content]="notification?.content
|| ''
"
[
visible
]="
isNotificationVisible
"
[visible]="isNotificationVisible
&& notification !== null
"
(close)="onDialogClose()"
(close)="onDialogClose()"
[isModal]="true"
[isModal]="true"
width="400px"
width="400px"
...
@@ -12,16 +12,16 @@
...
@@ -12,16 +12,16 @@
[animationSettings]="{ effect: 'Zoom' }">
[animationSettings]="{ effect: 'Zoom' }">
<ng-template #header>
<ng-template #header>
<div [ngClass]="getHeaderClass()">
<div [ngClass]="getHeaderClass()">
<span
class=
"e-dlg-title"
>
{{ notification?.title }}
</span>
<span class="e-dlg-title">{{ notification?.title
|| ''
}}</span>
</div>
</div>
</ng-template>
</ng-template>
<ng-template #content>
<ng-template #content>
<div class="dialog-content">
<div class="dialog-content">
<p>
{{ notification?.content }}
</p>
<p>{{ notification?.content
|| ''
}}</p>
</div>
</div>
</ng-template>
</ng-template>
<ng-template #footerTemplate>
<ng-template #footerTemplate>
<button ejs-button (click)="onDialogClose()" cssClass="e-primary">OK</button>
<button ejs-button (click)="onDialogClose()" cssClass="e-primary">OK</button>
</ng-template>
</ng-template>
</ejs-dialog>
</ejs-dialog>
-->
src/app/app.component.ts
View file @
7682af35
...
@@ -32,15 +32,18 @@ export class AppComponent implements OnDestroy, OnInit {
...
@@ -32,15 +32,18 @@ export class AppComponent implements OnDestroy, OnInit {
public
isNotificationVisible
=
false
;
public
isNotificationVisible
=
false
;
constructor
(
private
notificationService
:
NotificationService
)
{
constructor
(
private
notificationService
:
NotificationService
)
{
this
.
notificationSubscription
=
this
.
notificationService
.
notification$
.
subscribe
(
// this.notificationSubscription = this.notificationService.notification$.subscribe(
(
notification
)
=>
{
// (notification) => {
this
.
notification
=
notification
;
// this.notification = notification;
this
.
isNotificationVisible
=
true
;
// this.isNotificationVisible = true;
if
(
this
.
notificationDialog
)
{
// // Add a small delay to ensure the view is updated before showing the dialog
this
.
notificationDialog
.
show
();
// setTimeout(() => {
}
// if (this.notificationDialog && this.notification) {
}
// this.notificationDialog.show();
);
// }
// }, 0);
// }
// );
}
}
ngOnInit
()
{
ngOnInit
()
{
...
@@ -49,8 +52,8 @@ export class AppComponent implements OnDestroy, OnInit {
...
@@ -49,8 +52,8 @@ export class AppComponent implements OnDestroy, OnInit {
}
}
getHeaderClass
():
string
{
getHeaderClass
():
string
{
if
(
!
this
.
notification
)
{
if
(
!
this
.
notification
||
!
this
.
notification
.
type
)
{
return
''
;
return
'
e-dlg-header-content
'
;
}
}
return
`e-dlg-header-content e-dlg-
${
this
.
notification
.
type
}
`
;
return
`e-dlg-header-content e-dlg-
${
this
.
notification
.
type
}
`
;
}
}
...
...
src/app/portal-manage/dashboard-management/dashboard-management.component.html
View file @
7682af35
...
@@ -106,9 +106,10 @@
...
@@ -106,9 +106,10 @@
#
editLayout
#
editLayout
[
allowResizing
]="
true
"
[
allowResizing
]="
true
"
[
allowDragging
]="
true
"
[
allowDragging
]="
true
"
[
allowFloating
]="
false
"
[
allowFloating
]="
allowFloating
"
[
enableRtl
]="
false
"
[
enableRtl
]="
false
"
[
enablePersistence
]="
false
"
[
enablePersistence
]="
false
"
[
cellAspectRatio
]="
cellAspectRatio
"
class=
"dashboard-layout"
class=
"dashboard-layout"
>
>
<e-panels>
<e-panels>
...
...
src/app/portal-manage/dashboard-management/dashboard-management.component.ts
View file @
7682af35
...
@@ -89,7 +89,8 @@ export class DashboardManagementComponent implements OnInit, OnDestroy {
...
@@ -89,7 +89,8 @@ export class DashboardManagementComponent implements OnInit, OnDestroy {
public
dashboardData
:
DashboardModel
|
null
=
null
;
public
dashboardData
:
DashboardModel
|
null
=
null
;
public
userDashboards
:
DashboardModel
[]
=
[];
public
userDashboards
:
DashboardModel
[]
=
[];
public
selectedDashboardId
:
DashboardModel
|
null
=
null
;
public
selectedDashboardId
:
DashboardModel
|
null
=
null
;
public
allowFloating
:
boolean
=
false
;
public
cellAspectRatio
:
number
=
100
/
75
;
constructor
(
constructor
(
private
dashboardDataService
:
DashboardDataService
,
private
dashboardDataService
:
DashboardDataService
,
private
mMenuitemsWidgetService
:
MMenuitemsWidgetService
,
private
mMenuitemsWidgetService
:
MMenuitemsWidgetService
,
...
...
src/app/portal-manage/dashboard-management/widget-management/dataset-widget-linker.component.ts
View file @
7682af35
...
@@ -6,7 +6,7 @@ import { MatDialog } from '@angular/material/dialog';
...
@@ -6,7 +6,7 @@ import { MatDialog } from '@angular/material/dialog';
// Syncfusion Modules
// Syncfusion Modules
import
{
DropDownListModule
}
from
'@syncfusion/ej2-angular-dropdowns'
;
import
{
DropDownListModule
}
from
'@syncfusion/ej2-angular-dropdowns'
;
import
{
DialogComponent
,
DialogModule
}
from
'@syncfusion/ej2-angular-popups'
;
import
{
DialogComponent
,
DialogModule
}
from
'@syncfusion/ej2-angular-popups'
;
import
{
GridComponent
,
GridModule
,
PageService
,
SelectionService
}
from
'@syncfusion/ej2-angular-grids'
;
import
{
GridComponent
,
GridModule
,
PageService
,
SelectionService
,
ResizeService
}
from
'@syncfusion/ej2-angular-grids'
;
import
{
ButtonModule
}
from
'@syncfusion/ej2-angular-buttons'
;
import
{
ButtonModule
}
from
'@syncfusion/ej2-angular-buttons'
;
import
{
NotificationService
}
from
'../../../shared/services/notification.service'
;
import
{
NotificationService
}
from
'../../../shared/services/notification.service'
;
...
@@ -68,7 +68,7 @@ export interface DashboardPanel extends PanelModel {
...
@@ -68,7 +68,7 @@ export interface DashboardPanel extends PanelModel {
// Add all widget components here to make them available for NgComponentOutlet
// Add all widget components here to make them available for NgComponentOutlet
CompanyInfoWidgetComponent
,
HeadcountWidgetComponent
,
AttendanceOverviewWidgetComponent
,
PayrollSummaryWidgetComponent
,
EmployeeDirectoryWidgetComponent
,
KpiWidgetComponent
,
WelcomeWidgetComponent
,
ChartWidgetComponent
,
QuickLinksWidgetComponent
,
SyncfusionDatagridWidgetComponent
,
SyncfusionPivotWidgetComponent
,
SyncfusionChartWidgetComponent
,
DataTableWidgetComponent
,
AreaChartWidgetComponent
,
BarChartWidgetComponent
,
PieChartWidgetComponent
,
ScatterBubbleChartWidgetComponent
,
MultiRowCardWidgetComponent
,
ComboChartWidgetComponent
,
DoughnutChartWidgetComponent
,
FunnelChartWidgetComponent
,
GaugeChartWidgetComponent
,
SimpleKpiWidgetComponent
,
FilledMapWidgetComponent
,
MatrixWidgetComponent
,
SlicerWidgetComponent
,
SimpleTableWidgetComponent
,
WaterfallChartWidgetComponent
,
TreemapWidgetComponent
CompanyInfoWidgetComponent
,
HeadcountWidgetComponent
,
AttendanceOverviewWidgetComponent
,
PayrollSummaryWidgetComponent
,
EmployeeDirectoryWidgetComponent
,
KpiWidgetComponent
,
WelcomeWidgetComponent
,
ChartWidgetComponent
,
QuickLinksWidgetComponent
,
SyncfusionDatagridWidgetComponent
,
SyncfusionPivotWidgetComponent
,
SyncfusionChartWidgetComponent
,
DataTableWidgetComponent
,
AreaChartWidgetComponent
,
BarChartWidgetComponent
,
PieChartWidgetComponent
,
ScatterBubbleChartWidgetComponent
,
MultiRowCardWidgetComponent
,
ComboChartWidgetComponent
,
DoughnutChartWidgetComponent
,
FunnelChartWidgetComponent
,
GaugeChartWidgetComponent
,
SimpleKpiWidgetComponent
,
FilledMapWidgetComponent
,
MatrixWidgetComponent
,
SlicerWidgetComponent
,
SimpleTableWidgetComponent
,
WaterfallChartWidgetComponent
,
TreemapWidgetComponent
],
],
providers
:
[
PageService
,
SelectionService
],
providers
:
[
PageService
,
SelectionService
,
ResizeService
],
templateUrl
:
'./dataset-widget-linker.component.html'
,
templateUrl
:
'./dataset-widget-linker.component.html'
,
styleUrls
:
[
'./dataset-widget-linker.component.scss'
]
styleUrls
:
[
'./dataset-widget-linker.component.scss'
]
})
})
...
...
src/app/portal-manage/dashboard-management/widgets/area-chart-widget/area-chart-widget.component.ts
View file @
7682af35
...
@@ -28,7 +28,18 @@ export class AreaChartWidgetComponent extends BaseWidgetComponent {
...
@@ -28,7 +28,18 @@ export class AreaChartWidgetComponent extends BaseWidgetComponent {
}
}
onDataUpdate
(
data
:
any
[]):
void
{
onDataUpdate
(
data
:
any
[]):
void
{
this
.
chartData
=
data
.
map
(
item
=>
({
x
:
item
[
this
.
configObj
.
xField
],
y
:
item
[
this
.
configObj
.
yField
]
}));
if
(
!
data
||
data
.
length
===
0
)
{
this
.
chartData
=
[];
return
;
}
const
xField
=
this
.
configObj
.
xField
||
'x'
;
const
yField
=
this
.
configObj
.
yField
||
'y'
;
this
.
chartData
=
data
.
map
(
item
=>
({
x
:
item
[
xField
]
||
''
,
y
:
item
[
yField
]
||
0
}));
}
}
onReset
():
void
{
onReset
():
void
{
...
...
src/app/portal-manage/dashboard-management/widgets/bar-chart-widget/bar-chart-widget.component.ts
View file @
7682af35
...
@@ -31,7 +31,18 @@ export class BarChartWidgetComponent extends BaseWidgetComponent {
...
@@ -31,7 +31,18 @@ export class BarChartWidgetComponent extends BaseWidgetComponent {
}
}
onDataUpdate
(
data
:
any
[]):
void
{
onDataUpdate
(
data
:
any
[]):
void
{
this
.
chartData
=
data
.
map
(
item
=>
({
x
:
item
[
this
.
configObj
.
xField
],
y
:
item
[
this
.
configObj
.
yField
]
}));
if
(
!
data
||
data
.
length
===
0
)
{
this
.
chartData
=
[];
return
;
}
const
xField
=
this
.
configObj
.
xField
||
'x'
;
const
yField
=
this
.
configObj
.
yField
||
'y'
;
this
.
chartData
=
data
.
map
(
item
=>
({
x
:
item
[
xField
]
||
''
,
y
:
item
[
yField
]
||
0
}));
}
}
onReset
():
void
{
onReset
():
void
{
...
...
src/app/portal-manage/dashboard-management/widgets/combo-chart-widget/combo-chart-widget.component.html
View file @
7682af35
...
@@ -10,9 +10,9 @@
...
@@ -10,9 +10,9 @@
</div>
</div>
<!-- Chart -->
<!-- Chart -->
<ejs-chart
*
ngIf=
"!isLoading && !hasError
&& configObj?.series
"
[
title
]="
title
"
[
primaryXAxis
]="
primaryXAxis
"
[
primaryYAxis
]="
primaryYAxis
"
>
<ejs-chart
*
ngIf=
"!isLoading && !hasError"
[
title
]="
title
"
[
primaryXAxis
]="
primaryXAxis
"
[
primaryYAxis
]="
primaryYAxis
"
>
<e-series-collection>
<e-series-collection>
<e-series
*
ngFor=
"let series of
configObj.series
"
<e-series
*
ngFor=
"let series of
(configObj?.series || [])
"
[
dataSource
]="
chartData
"
[
dataSource
]="
chartData
"
[
type
]="
series
.
type
||
'
Column
'"
[
type
]="
series
.
type
||
'
Column
'"
[
xName
]="
series
.
xName
"
[
xName
]="
series
.
xName
"
...
...
src/app/portal-manage/dashboard-management/widgets/combo-chart-widget/combo-chart-widget.component.ts
View file @
7682af35
...
@@ -25,10 +25,31 @@ export class ComboChartWidgetComponent extends BaseWidgetComponent {
...
@@ -25,10 +25,31 @@ export class ComboChartWidgetComponent extends BaseWidgetComponent {
this
.
primaryXAxis
=
{
valueType
:
'Category'
,
title
:
this
.
configObj
.
xAxisTitle
||
''
};
this
.
primaryXAxis
=
{
valueType
:
'Category'
,
title
:
this
.
configObj
.
xAxisTitle
||
''
};
this
.
primaryYAxis
=
{
title
:
this
.
configObj
.
yAxisTitle
||
''
};
this
.
primaryYAxis
=
{
title
:
this
.
configObj
.
yAxisTitle
||
''
};
this
.
chartData
=
[];
this
.
chartData
=
[];
// Ensure series configuration exists
if
(
!
this
.
configObj
.
series
)
{
this
.
configObj
.
series
=
[
{
type
:
'Column'
,
xName
:
'x'
,
yName
:
'y1'
,
name
:
'Series 1'
},
{
type
:
'Line'
,
xName
:
'x'
,
yName
:
'y2'
,
name
:
'Series 2'
}
];
}
}
}
onDataUpdate
(
data
:
any
[]):
void
{
onDataUpdate
(
data
:
any
[]):
void
{
this
.
chartData
=
data
;
if
(
!
data
||
data
.
length
===
0
)
{
this
.
chartData
=
[];
return
;
}
const
xField
=
this
.
configObj
.
xField
||
'x'
;
const
yField
=
this
.
configObj
.
yField
||
'y'
;
const
y2Field
=
this
.
configObj
.
y2Field
||
'y2'
;
this
.
chartData
=
data
.
map
(
item
=>
({
x
:
item
[
xField
]
||
''
,
y1
:
item
[
yField
]
||
0
,
y2
:
item
[
y2Field
]
||
0
}));
}
}
onReset
():
void
{
onReset
():
void
{
...
...
src/app/portal-manage/dashboard-management/widgets/doughnut-chart-widget/doughnut-chart-widget.component.ts
View file @
7682af35
...
@@ -26,17 +26,27 @@ export class DoughnutChartWidgetComponent extends BaseWidgetComponent {
...
@@ -26,17 +26,27 @@ export class DoughnutChartWidgetComponent extends BaseWidgetComponent {
}
}
onDataUpdate
(
data
:
any
[]):
void
{
onDataUpdate
(
data
:
any
[]):
void
{
if
(
!
data
||
data
.
length
===
0
)
{
this
.
chartData
=
[];
return
;
}
const
xField
=
this
.
configObj
.
xField
||
'x'
;
const
yField
=
this
.
configObj
.
yField
||
'y'
;
let
transformedData
=
data
;
let
transformedData
=
data
;
if
(
this
.
configObj
.
aggregation
===
'count'
)
{
if
(
this
.
configObj
.
aggregation
===
'count'
)
{
const
counts
=
transformedData
.
reduce
((
acc
,
item
)
=>
{
const
counts
=
transformedData
.
reduce
((
acc
,
item
)
=>
{
const
key
=
item
[
this
.
configObj
.
xField
]
;
const
key
=
item
[
xField
]
||
''
;
acc
[
key
]
=
(
acc
[
key
]
||
0
)
+
1
;
acc
[
key
]
=
(
acc
[
key
]
||
0
)
+
1
;
return
acc
;
return
acc
;
},
{});
},
{});
transformedData
=
Object
.
keys
(
counts
).
map
(
key
=>
({
x
:
key
,
y
:
counts
[
key
]
}));
transformedData
=
Object
.
keys
(
counts
).
map
(
key
=>
({
x
:
key
,
y
:
counts
[
key
]
}));
}
else
{
}
else
{
transformedData
=
transformedData
.
map
(
item
=>
({
x
:
item
[
this
.
configObj
.
xField
],
y
:
item
[
this
.
configObj
.
yField
]
}));
transformedData
=
transformedData
.
map
(
item
=>
({
x
:
item
[
xField
]
||
''
,
y
:
item
[
yField
]
||
0
}));
}
}
this
.
chartData
=
transformedData
;
this
.
chartData
=
transformedData
;
}
}
...
...
src/app/portal-manage/dashboard-management/widgets/dynamic-widgets/data-table-widget.component.ts
View file @
7682af35
import
{
Component
,
Input
,
OnInit
,
OnChanges
,
SimpleChanges
}
from
'@angular/core'
;
import
{
Component
,
Input
,
OnInit
,
OnChanges
,
SimpleChanges
}
from
'@angular/core'
;
import
{
CommonModule
}
from
'@angular/common'
;
import
{
CommonModule
}
from
'@angular/common'
;
import
{
GridModule
,
PageService
,
SortService
,
FilterService
,
GroupService
}
from
'@syncfusion/ej2-angular-grids'
;
import
{
GridModule
,
PageService
,
SortService
,
FilterService
,
GroupService
,
ResizeService
}
from
'@syncfusion/ej2-angular-grids'
;
@
Component
({
@
Component
({
selector
:
'app-data-table-widget'
,
selector
:
'app-data-table-widget'
,
standalone
:
true
,
standalone
:
true
,
imports
:
[
CommonModule
,
GridModule
],
imports
:
[
CommonModule
,
GridModule
],
providers
:
[
PageService
,
SortService
,
FilterService
,
GroupService
],
providers
:
[
PageService
,
SortService
,
FilterService
,
GroupService
,
ResizeService
],
templateUrl
:
'./data-table-widget.component.html'
,
templateUrl
:
'./data-table-widget.component.html'
,
styleUrls
:
[
'./data-table-widget.component.scss'
]
styleUrls
:
[
'./data-table-widget.component.scss'
]
})
})
...
...
src/app/portal-manage/dashboard-management/widgets/funnel-chart-widget/funnel-chart-widget.component.ts
View file @
7682af35
...
@@ -26,7 +26,18 @@ export class FunnelChartWidgetComponent extends BaseWidgetComponent {
...
@@ -26,7 +26,18 @@ export class FunnelChartWidgetComponent extends BaseWidgetComponent {
}
}
onDataUpdate
(
data
:
any
[]):
void
{
onDataUpdate
(
data
:
any
[]):
void
{
this
.
chartData
=
data
.
map
(
item
=>
({
x
:
item
[
this
.
configObj
.
xField
],
y
:
item
[
this
.
configObj
.
yField
]
}));
if
(
!
data
||
data
.
length
===
0
)
{
this
.
chartData
=
[];
return
;
}
const
xField
=
this
.
configObj
.
xField
||
'x'
;
const
yField
=
this
.
configObj
.
yField
||
'y'
;
this
.
chartData
=
data
.
map
(
item
=>
({
x
:
item
[
xField
]
||
''
,
y
:
item
[
yField
]
||
0
}));
}
}
onReset
():
void
{
onReset
():
void
{
...
...
src/app/portal-manage/dashboard-management/widgets/gauge-chart-widget/gauge-chart-widget.component.ts
View file @
7682af35
...
@@ -25,14 +25,15 @@ export class GaugeChartWidgetComponent extends BaseWidgetComponent {
...
@@ -25,14 +25,15 @@ export class GaugeChartWidgetComponent extends BaseWidgetComponent {
onDataUpdate
(
data
:
any
[]):
void
{
onDataUpdate
(
data
:
any
[]):
void
{
let
value
=
0
;
let
value
=
0
;
if
(
data
.
length
>
0
)
{
if
(
data
&&
data
.
length
>
0
)
{
const
valueField
=
this
.
configObj
.
valueField
||
'value'
;
if
(
this
.
configObj
.
aggregation
===
'sum'
)
{
if
(
this
.
configObj
.
aggregation
===
'sum'
)
{
value
=
data
.
reduce
((
sum
,
item
)
=>
sum
+
(
item
[
this
.
configObj
.
valueField
]
||
0
),
0
);
value
=
data
.
reduce
((
sum
,
item
)
=>
sum
+
(
item
[
valueField
]
||
0
),
0
);
}
else
if
(
this
.
configObj
.
aggregation
===
'avg'
)
{
}
else
if
(
this
.
configObj
.
aggregation
===
'avg'
)
{
const
sum
=
data
.
reduce
((
sum
,
item
)
=>
sum
+
(
item
[
this
.
configObj
.
valueField
]
||
0
),
0
);
const
sum
=
data
.
reduce
((
sum
,
item
)
=>
sum
+
(
item
[
valueField
]
||
0
),
0
);
value
=
sum
/
data
.
length
;
value
=
sum
/
data
.
length
;
}
else
{
}
else
{
value
=
data
[
0
][
this
.
configObj
.
valueField
]
;
value
=
data
[
0
][
valueField
]
||
0
;
}
}
}
}
this
.
setAxes
(
value
);
this
.
setAxes
(
value
);
...
...
src/app/portal-manage/dashboard-management/widgets/pie-chart-widget/pie-chart-widget.component.ts
View file @
7682af35
...
@@ -26,17 +26,27 @@ export class PieChartWidgetComponent extends BaseWidgetComponent {
...
@@ -26,17 +26,27 @@ export class PieChartWidgetComponent extends BaseWidgetComponent {
}
}
onDataUpdate
(
data
:
any
[]):
void
{
onDataUpdate
(
data
:
any
[]):
void
{
if
(
!
data
||
data
.
length
===
0
)
{
this
.
chartData
=
[];
return
;
}
const
xField
=
this
.
configObj
.
xField
||
'x'
;
const
yField
=
this
.
configObj
.
yField
||
'y'
;
let
transformedData
=
data
;
let
transformedData
=
data
;
if
(
this
.
configObj
.
aggregation
===
'count'
)
{
if
(
this
.
configObj
.
aggregation
===
'count'
)
{
const
counts
=
transformedData
.
reduce
((
acc
,
item
)
=>
{
const
counts
=
transformedData
.
reduce
((
acc
,
item
)
=>
{
const
key
=
item
[
this
.
configObj
.
xField
]
;
const
key
=
item
[
xField
]
||
''
;
acc
[
key
]
=
(
acc
[
key
]
||
0
)
+
1
;
acc
[
key
]
=
(
acc
[
key
]
||
0
)
+
1
;
return
acc
;
return
acc
;
},
{});
},
{});
transformedData
=
Object
.
keys
(
counts
).
map
(
key
=>
({
x
:
key
,
y
:
counts
[
key
]
}));
transformedData
=
Object
.
keys
(
counts
).
map
(
key
=>
({
x
:
key
,
y
:
counts
[
key
]
}));
}
else
{
}
else
{
transformedData
=
transformedData
.
map
(
item
=>
({
x
:
item
[
this
.
configObj
.
xField
],
y
:
item
[
this
.
configObj
.
yField
]
}));
transformedData
=
transformedData
.
map
(
item
=>
({
x
:
item
[
xField
]
||
''
,
y
:
item
[
yField
]
||
0
}));
}
}
this
.
chartData
=
transformedData
;
this
.
chartData
=
transformedData
;
}
}
...
...
src/app/portal-manage/dashboard-management/widgets/scatter-bubble-chart-widget/scatter-bubble-chart-widget.component.ts
View file @
7682af35
...
@@ -31,10 +31,26 @@ export class ScatterBubbleChartWidgetComponent extends BaseWidgetComponent {
...
@@ -31,10 +31,26 @@ export class ScatterBubbleChartWidgetComponent extends BaseWidgetComponent {
}
}
onDataUpdate
(
data
:
any
[]):
void
{
onDataUpdate
(
data
:
any
[]):
void
{
if
(
!
data
||
data
.
length
===
0
)
{
this
.
chartData
=
[];
return
;
}
const
xField
=
this
.
configObj
.
xField
||
'x'
;
const
yField
=
this
.
configObj
.
yField
||
'y'
;
const
sizeField
=
this
.
configObj
.
sizeField
||
'size'
;
if
(
this
.
type
===
'Bubble'
)
{
if
(
this
.
type
===
'Bubble'
)
{
this
.
chartData
=
data
.
map
(
item
=>
({
x
:
item
[
this
.
configObj
.
xField
],
y
:
item
[
this
.
configObj
.
yField
],
size
:
item
[
this
.
configObj
.
sizeField
]
}));
this
.
chartData
=
data
.
map
(
item
=>
({
x
:
item
[
xField
]
||
0
,
y
:
item
[
yField
]
||
0
,
size
:
item
[
sizeField
]
||
0
}));
}
else
{
}
else
{
this
.
chartData
=
data
.
map
(
item
=>
({
x
:
item
[
this
.
configObj
.
xField
],
y
:
item
[
this
.
configObj
.
yField
]
}));
this
.
chartData
=
data
.
map
(
item
=>
({
x
:
item
[
xField
]
||
0
,
y
:
item
[
yField
]
||
0
}));
}
}
}
}
...
...
src/app/portal-manage/dashboard-management/widgets/syncfusion-chart-widget/syncfusion-chart-widget.component.html
View file @
7682af35
...
@@ -22,7 +22,7 @@
...
@@ -22,7 +22,7 @@
<!-- Chart -->
<!-- Chart -->
<ejs-chart
*
ngIf=
"!isLoading && !hasError"
style=
"height: 100%; width: 100%"
[
primaryXAxis
]="
primaryXAxis
"
[
primaryYAxis
]="
primaryYAxis
"
>
<ejs-chart
*
ngIf=
"!isLoading && !hasError"
style=
"height: 100%; width: 100%"
[
primaryXAxis
]="
primaryXAxis
"
[
primaryYAxis
]="
primaryYAxis
"
>
<e-series-collection>
<e-series-collection>
<e-series
[
dataSource
]="
chartData
.
executeLocal
(
query
)
"
type=
"Column"
xName=
"x"
yName=
"y"
name=
"Data"
></e-series>
<e-series
[
dataSource
]="
chartData
"
type=
"Column"
xName=
"x"
yName=
"y"
name=
"Data"
></e-series>
</e-series-collection>
</e-series-collection>
</ejs-chart>
</ejs-chart>
...
...
src/app/portal-manage/dashboard-management/widgets/syncfusion-chart-widget/syncfusion-chart-widget.component.ts
View file @
7682af35
import
{
Component
}
from
'@angular/core'
;
import
{
Component
}
from
'@angular/core'
;
import
{
CommonModule
}
from
'@angular/common'
;
import
{
CommonModule
}
from
'@angular/common'
;
import
{
ChartModule
,
ColumnSeriesService
,
CategoryService
,
LegendService
,
TooltipService
,
DataLabelService
}
from
'@syncfusion/ej2-angular-charts'
;
import
{
ChartModule
,
ColumnSeriesService
,
CategoryService
,
LegendService
,
TooltipService
,
DataLabelService
}
from
'@syncfusion/ej2-angular-charts'
;
import
{
DataManager
,
Query
}
from
'@syncfusion/ej2-data'
;
// Added DataManager and Query import
import
{
DashboardStateService
}
from
'../../services/dashboard-state.service'
;
import
{
DashboardStateService
}
from
'../../services/dashboard-state.service'
;
import
{
BaseWidgetComponent
}
from
'../base-widget.component'
;
import
{
BaseWidgetComponent
}
from
'../base-widget.component'
;
...
@@ -13,10 +12,9 @@ import { BaseWidgetComponent } from '../base-widget.component';
...
@@ -13,10 +12,9 @@ import { BaseWidgetComponent } from '../base-widget.component';
templateUrl
:
'./syncfusion-chart-widget.component.html'
,
templateUrl
:
'./syncfusion-chart-widget.component.html'
,
})
})
export
class
SyncfusionChartWidgetComponent
extends
BaseWidgetComponent
{
export
class
SyncfusionChartWidgetComponent
extends
BaseWidgetComponent
{
public
chartData
:
DataManager
=
new
DataManager
([]);
// Changed type and initialized
public
chartData
:
Object
[]
=
[];
// Changed to simple array
public
primaryXAxis
:
Object
;
public
primaryXAxis
:
Object
;
public
primaryYAxis
:
Object
;
public
primaryYAxis
:
Object
;
public
query
:
Query
=
new
Query
();
// Added Query instance
constructor
(
protected
override
dashboardStateService
:
DashboardStateService
)
{
constructor
(
protected
override
dashboardStateService
:
DashboardStateService
)
{
super
(
dashboardStateService
);
super
(
dashboardStateService
);
...
@@ -26,21 +24,31 @@ export class SyncfusionChartWidgetComponent extends BaseWidgetComponent {
...
@@ -26,21 +24,31 @@ export class SyncfusionChartWidgetComponent extends BaseWidgetComponent {
this
.
title
=
this
.
configObj
.
title
||
'Syncfusion Chart'
;
this
.
title
=
this
.
configObj
.
title
||
'Syncfusion Chart'
;
this
.
primaryXAxis
=
{
valueType
:
'Category'
,
title
:
this
.
configObj
.
xAxisTitle
||
''
};
this
.
primaryXAxis
=
{
valueType
:
'Category'
,
title
:
this
.
configObj
.
xAxisTitle
||
''
};
this
.
primaryYAxis
=
{
title
:
this
.
configObj
.
yAxisTitle
||
''
};
this
.
primaryYAxis
=
{
title
:
this
.
configObj
.
yAxisTitle
||
''
};
this
.
chartData
=
new
DataManager
([])
;
this
.
chartData
=
[]
;
}
}
onDataUpdate
(
data
:
any
[]):
void
{
onDataUpdate
(
data
:
any
[]):
void
{
const
dm
=
new
DataManager
(
data
);
if
(
!
data
||
data
.
length
===
0
)
{
this
.
chartData
=
new
DataManager
(
dm
.
executeLocal
(
new
Query
()).
map
((
item
:
any
)
=>
({
x
:
item
[
this
.
configObj
.
xField
],
y
:
item
[
this
.
configObj
.
yField
]
})));
this
.
chartData
=
[];
return
;
}
const
xField
=
this
.
configObj
.
xField
||
'x'
;
const
yField
=
this
.
configObj
.
yField
||
'y'
;
this
.
chartData
=
data
.
map
((
item
:
any
)
=>
({
x
:
item
[
xField
]
||
''
,
y
:
item
[
yField
]
||
0
}));
}
}
onReset
():
void
{
onReset
():
void
{
this
.
title
=
'Syncfusion Chart (Default)'
;
this
.
title
=
'Syncfusion Chart (Default)'
;
this
.
chartData
=
new
DataManager
(
[
this
.
chartData
=
[
{
x
:
'Jan'
,
y
:
35
},
{
x
:
'Feb'
,
y
:
28
},
{
x
:
'Jan'
,
y
:
35
},
{
x
:
'Feb'
,
y
:
28
},
{
x
:
'Mar'
,
y
:
34
},
{
x
:
'Apr'
,
y
:
32
},
{
x
:
'Mar'
,
y
:
34
},
{
x
:
'Apr'
,
y
:
32
},
{
x
:
'May'
,
y
:
40
},
{
x
:
'Jun'
,
y
:
30
},
{
x
:
'May'
,
y
:
40
},
{
x
:
'Jun'
,
y
:
30
},
]
)
;
];
this
.
primaryXAxis
=
{
valueType
:
'Category'
,
title
:
'Month'
};
this
.
primaryXAxis
=
{
valueType
:
'Category'
,
title
:
'Month'
};
this
.
primaryYAxis
=
{
title
:
'Sales'
};
this
.
primaryYAxis
=
{
title
:
'Sales'
};
}
}
...
...
src/app/portal-manage/dashboard-management/widgets/syncfusion-datagrid-widget/syncfusion-datagrid-widget.component.ts
View file @
7682af35
import
{
Component
,
ViewChild
,
OnInit
,
OnDestroy
,
AfterViewInit
,
Input
}
from
'@angular/core'
;
import
{
Component
,
ViewChild
,
OnInit
,
OnDestroy
,
AfterViewInit
,
Input
}
from
'@angular/core'
;
import
{
CommonModule
}
from
'@angular/common'
;
import
{
CommonModule
}
from
'@angular/common'
;
import
{
GridModule
,
PageService
,
SortService
,
FilterService
,
GroupService
,
ToolbarService
,
ExcelExportService
,
PdfExportService
,
GridComponent
,
ToolbarItems
,
SearchSettingsModel
,
GroupSettingsModel
,
FilterSettingsModel
,
SelectionSettingsModel
,
AggregateService
,
ColumnMenuService
,
DetailRowService
,
ReorderService
,
EditService
,
PdfExportProperties
,
ExcelExportProperties
,
LoadingIndicatorModel
,
Column
,
Search
Service
}
from
'@syncfusion/ej2-angular-grids'
;
import
{
GridModule
,
PageService
,
SortService
,
FilterService
,
GroupService
,
ToolbarService
,
ExcelExportService
,
PdfExportService
,
GridComponent
,
ToolbarItems
,
SearchSettingsModel
,
GroupSettingsModel
,
FilterSettingsModel
,
SelectionSettingsModel
,
AggregateService
,
ColumnMenuService
,
DetailRowService
,
ReorderService
,
EditService
,
PdfExportProperties
,
ExcelExportProperties
,
LoadingIndicatorModel
,
Column
,
SearchService
,
Resize
Service
}
from
'@syncfusion/ej2-angular-grids'
;
import
{
MenuEventArgs
}
from
'@syncfusion/ej2-navigations'
;
import
{
MenuEventArgs
}
from
'@syncfusion/ej2-navigations'
;
import
{
ClickEventArgs
}
from
'@syncfusion/ej2-navigations'
;
import
{
ClickEventArgs
}
from
'@syncfusion/ej2-navigations'
;
import
{
DataManager
,
Query
}
from
'@syncfusion/ej2-data'
;
import
{
DataManager
,
Query
}
from
'@syncfusion/ej2-data'
;
...
@@ -53,7 +53,7 @@ L10n.load({
...
@@ -53,7 +53,7 @@ L10n.load({
selector
:
'app-syncfusion-datagrid-widget'
,
selector
:
'app-syncfusion-datagrid-widget'
,
standalone
:
true
,
standalone
:
true
,
imports
:
[
CommonModule
,
GridModule
],
imports
:
[
CommonModule
,
GridModule
],
providers
:
[
PageService
,
SortService
,
FilterService
,
GroupService
,
ToolbarService
,
ExcelExportService
,
PdfExportService
,
AggregateService
,
ColumnMenuService
,
DetailRowService
,
ReorderService
,
EditService
,
SearchService
],
providers
:
[
PageService
,
SortService
,
FilterService
,
GroupService
,
ToolbarService
,
ExcelExportService
,
PdfExportService
,
AggregateService
,
ColumnMenuService
,
DetailRowService
,
ReorderService
,
EditService
,
SearchService
,
ResizeService
],
templateUrl
:
'./syncfusion-datagrid-widget.component.html'
,
templateUrl
:
'./syncfusion-datagrid-widget.component.html'
,
styleUrls
:
[
'./syncfusion-datagrid-widget.component.scss'
]
styleUrls
:
[
'./syncfusion-datagrid-widget.component.scss'
]
})
})
...
...
src/app/portal-manage/dashboard-management/widgets/waterfall-chart-widget/waterfall-chart-widget.component.ts
View file @
7682af35
...
@@ -28,7 +28,18 @@ export class WaterfallChartWidgetComponent extends BaseWidgetComponent {
...
@@ -28,7 +28,18 @@ export class WaterfallChartWidgetComponent extends BaseWidgetComponent {
}
}
onDataUpdate
(
data
:
any
[]):
void
{
onDataUpdate
(
data
:
any
[]):
void
{
this
.
chartData
=
data
.
map
(
item
=>
({
x
:
item
[
this
.
configObj
.
xField
],
y
:
item
[
this
.
configObj
.
yField
]
}));
if
(
!
data
||
data
.
length
===
0
)
{
this
.
chartData
=
[];
return
;
}
const
xField
=
this
.
configObj
.
xField
||
'x'
;
const
yField
=
this
.
configObj
.
yField
||
'y'
;
this
.
chartData
=
data
.
map
(
item
=>
({
x
:
item
[
xField
]
||
''
,
y
:
item
[
yField
]
||
0
}));
}
}
onReset
():
void
{
onReset
():
void
{
...
...
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