@abp/ng.components 7.2.2 → 7.3.0-rc.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (72) hide show
  1. package/README.md +129 -2
  2. package/chart.js/chart.component.d.ts +30 -30
  3. package/chart.js/chart.module.d.ts +8 -8
  4. package/chart.js/index.d.ts +5 -5
  5. package/chart.js/public-api.d.ts +3 -3
  6. package/chart.js/widget-utils.d.ts +1 -1
  7. package/{esm2020 → esm2022}/abp-ng.components.mjs +4 -4
  8. package/{esm2020 → esm2022}/chart.js/abp-ng.components-chart.js.mjs +4 -4
  9. package/esm2022/chart.js/chart.component.mjs +141 -0
  10. package/esm2022/chart.js/chart.module.mjs +20 -0
  11. package/{esm2020 → esm2022}/chart.js/public-api.mjs +3 -3
  12. package/{esm2020 → esm2022}/chart.js/widget-utils.mjs +10 -10
  13. package/{esm2020 → esm2022}/page/abp-ng.components-page.mjs +4 -4
  14. package/esm2022/page/page-part.directive.mjs +77 -0
  15. package/esm2022/page/page-parts.component.mjs +48 -0
  16. package/esm2022/page/page.component.mjs +56 -0
  17. package/esm2022/page/page.module.mjs +39 -0
  18. package/{esm2020 → esm2022}/page/public-api.mjs +4 -4
  19. package/{esm2020 → esm2022}/public-api.mjs +4 -4
  20. package/{esm2020 → esm2022}/tree/abp-ng.components-tree.mjs +4 -4
  21. package/esm2022/tree/lib/components/tree.component.mjs +154 -0
  22. package/{esm2020 → esm2022}/tree/lib/disable-tree-style-loading.token.mjs +2 -2
  23. package/esm2022/tree/lib/templates/expanded-icon-template.directive.mjs +17 -0
  24. package/esm2022/tree/lib/templates/tree-node-template.directive.mjs +17 -0
  25. package/esm2022/tree/lib/tree.module.mjs +26 -0
  26. package/{esm2020 → esm2022}/tree/lib/utils/nz-tree-adapter.mjs +91 -91
  27. package/{esm2020 → esm2022}/tree/public-api.mjs +6 -6
  28. package/{fesm2020 → fesm2022}/abp-ng.components-chart.js.mjs +135 -135
  29. package/fesm2022/abp-ng.components-chart.js.mjs.map +1 -0
  30. package/{fesm2020 → fesm2022}/abp-ng.components-page.mjs +187 -187
  31. package/{fesm2020 → fesm2022}/abp-ng.components-page.mjs.map +1 -1
  32. package/{fesm2020 → fesm2022}/abp-ng.components-tree.mjs +269 -269
  33. package/fesm2022/abp-ng.components-tree.mjs.map +1 -0
  34. package/{fesm2020 → fesm2022}/abp-ng.components.mjs +4 -4
  35. package/index.d.ts +5 -5
  36. package/package.json +31 -30
  37. package/page/index.d.ts +5 -5
  38. package/page/page-part.directive.d.ts +31 -31
  39. package/page/page-parts.component.d.ts +18 -18
  40. package/page/page.component.d.ts +21 -21
  41. package/page/page.module.d.ts +13 -13
  42. package/page/public-api.d.ts +4 -4
  43. package/public-api.d.ts +1 -1
  44. package/tree/index.d.ts +5 -5
  45. package/tree/lib/components/tree.component.d.ts +51 -51
  46. package/tree/lib/disable-tree-style-loading.token.d.ts +2 -2
  47. package/tree/lib/templates/expanded-icon-template.directive.d.ts +8 -8
  48. package/tree/lib/templates/tree-node-template.directive.d.ts +8 -8
  49. package/tree/lib/tree.module.d.ts +13 -13
  50. package/tree/lib/utils/nz-tree-adapter.d.ts +38 -38
  51. package/tree/public-api.d.ts +6 -6
  52. package/esm2020/chart.js/chart.component.mjs +0 -140
  53. package/esm2020/chart.js/chart.module.mjs +0 -19
  54. package/esm2020/page/page-part.directive.mjs +0 -76
  55. package/esm2020/page/page-parts.component.mjs +0 -45
  56. package/esm2020/page/page.component.mjs +0 -55
  57. package/esm2020/page/page.module.mjs +0 -38
  58. package/esm2020/tree/lib/components/tree.component.mjs +0 -153
  59. package/esm2020/tree/lib/templates/expanded-icon-template.directive.mjs +0 -16
  60. package/esm2020/tree/lib/templates/tree-node-template.directive.mjs +0 -16
  61. package/esm2020/tree/lib/tree.module.mjs +0 -25
  62. package/fesm2015/abp-ng.components-chart.js.mjs +0 -175
  63. package/fesm2015/abp-ng.components-chart.js.mjs.map +0 -1
  64. package/fesm2015/abp-ng.components-page.mjs +0 -215
  65. package/fesm2015/abp-ng.components-page.mjs.map +0 -1
  66. package/fesm2015/abp-ng.components-tree.mjs +0 -300
  67. package/fesm2015/abp-ng.components-tree.mjs.map +0 -1
  68. package/fesm2015/abp-ng.components.mjs +0 -4
  69. package/fesm2015/abp-ng.components.mjs.map +0 -1
  70. package/fesm2020/abp-ng.components-chart.js.mjs.map +0 -1
  71. package/fesm2020/abp-ng.components-tree.mjs.map +0 -1
  72. /package/{fesm2020 → fesm2022}/abp-ng.components.mjs.map +0 -0
package/README.md CHANGED
@@ -1,3 +1,130 @@
1
- <h1> @abp/ng.components </h1>
1
+ ## ℹ️ Description
2
2
 
3
- [docs.abp.io](https://docs.abp.io)
3
+ ABP Framework is a complete open-source infrastructure to create modern web applications by following the best practices and conventions of software development. This package is a part of the [ABP Framework](https://abp.io) and contains client-side files.
4
+ For more information, check out the below links:
5
+
6
+ 🔗Official Website: https://abp.io
7
+
8
+ 🔗Commercial Website: https://commercial.abp.io
9
+
10
+ 🔗Commercial Demo: https://commercial.abp.io/demo
11
+
12
+ 🔗GitHub Repository: https://github.com/abpframework/abp
13
+
14
+ 🔗Official Theme: https://www.LeptonTheme.com
15
+
16
+ 🔗Documentation: https://docs.abp.io
17
+
18
+ 🔗Community: https://community.abp.io
19
+
20
+ 🔗Blog: https://blog.abp.io
21
+
22
+ 🔗Books: https://abp.io/books
23
+
24
+ 🔗Twitter: https://twitter.com/abpframework
25
+
26
+ 🔗Discord: https://community.abp.io/discord
27
+
28
+ 🔗Stackoverflow: https://stackoverflow.com/questions/tagged/abp
29
+
30
+ 🔗YouTube: https://www.youtube.com/@Volosoft
31
+
32
+
33
+ ## 🤔 Why ABP Platform?
34
+
35
+ Why should you use the ABP.IO Platform instead of creating a new solution from scratch?
36
+
37
+ You can find the answer here 👉🏻 [Why ABP Platform?](https://docs.abp.io/en/commercial/latest/why-abp-io-platform)
38
+
39
+
40
+ ## 🚀 Key Features of the ABP Framework
41
+
42
+ 🟡 Modularity
43
+
44
+ 🟡 Multi-Tenancy
45
+
46
+ 🟡 Bootstrap Tag Helpers
47
+
48
+ 🟡 Dynamic Forms
49
+
50
+ 🟡 Authentication
51
+
52
+ 🟡 Authorization
53
+
54
+ 🟡 Distributed Event Bus
55
+
56
+ 🟡 BLOB Storing
57
+
58
+ 🟡 Text Templating
59
+
60
+ 🟡 Tooling: ABP CLI
61
+
62
+ 🟡 Cross-Cutting Concerns
63
+
64
+ 🟡 Bundling & Minification
65
+
66
+ 🟡 Virtual File System
67
+
68
+ 🟡 Theming
69
+
70
+ 🟡 Background Jobs
71
+
72
+ 🟡 DDD Infrastructure
73
+
74
+ 🟡 Auto REST APIs
75
+
76
+ 🟡 Dynamic Client Proxies
77
+
78
+ 🟡 Multiple Database Providers
79
+
80
+ 🟡 Data filtering
81
+
82
+ 🟡 Test Infrastructure
83
+
84
+ 🟡 Audit Logging
85
+
86
+ 🟡 Object to Object Mapping
87
+
88
+ 🟡 Email & SMS Abstractions
89
+
90
+ 🟡 Localization
91
+
92
+ 🟡 Setting Management
93
+
94
+ 🟡 Extension Methods
95
+
96
+ 🟡 Aspect Oriented Programming
97
+
98
+ 🟡 Dependency Injection
99
+
100
+
101
+ ## 🧐 How It Works?
102
+
103
+ The following page explains how you use the ABP.IO Platform as a .NET developer 👉 [How it works?](https://commercial.abp.io/how-it-works)
104
+
105
+
106
+ ### 📘 Supported Database Providers
107
+
108
+ 🔵 Entity Framework Core
109
+
110
+ 🔵 MongoDB
111
+
112
+ 🔵 Dapper
113
+
114
+
115
+ ### 🎴 Supported UI Frameworks
116
+
117
+ 🔵 Angular
118
+
119
+ 🔵 Razor Pages
120
+
121
+ 🔵 Blazor Web Assembly
122
+
123
+ 🔵 Blazor Server
124
+
125
+ 🔵 MAUI with Blazor Hybrid
126
+
127
+
128
+ ## 📫 Bug & Support
129
+
130
+ Support for open-source ABP Framework client-side packages is available at [GitHub Issues](https://github.com/abpframework/abp/issues), and the commercial support is available at [support.abp.io](https://support.abp.io).
@@ -1,30 +1,30 @@
1
- import { AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, OnChanges, OnDestroy, SimpleChanges } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export declare class ChartComponent implements AfterViewInit, OnDestroy, OnChanges {
4
- el: ElementRef;
5
- private cdr;
6
- type: string;
7
- data: any;
8
- options: any;
9
- plugins: any[];
10
- width?: string;
11
- height?: string;
12
- responsive: boolean;
13
- dataSelect: EventEmitter<any>;
14
- initialized: EventEmitter<boolean>;
15
- canvas: ElementRef<HTMLCanvasElement>;
16
- chart: any;
17
- constructor(el: ElementRef, cdr: ChangeDetectorRef);
18
- ngAfterViewInit(): void;
19
- onCanvasClick(event: MouseEvent): void;
20
- private initChart;
21
- getCanvas: () => HTMLCanvasElement;
22
- getBase64Image: () => any;
23
- generateLegend: () => any;
24
- refresh: () => void;
25
- reinit: () => void;
26
- ngOnDestroy(): void;
27
- ngOnChanges(changes: SimpleChanges): void;
28
- static ɵfac: i0.ɵɵFactoryDeclaration<ChartComponent, never>;
29
- static ɵcmp: i0.ɵɵComponentDeclaration<ChartComponent, "abp-chart", ["abpChart"], { "type": "type"; "data": "data"; "options": "options"; "plugins": "plugins"; "width": "width"; "height": "height"; "responsive": "responsive"; }, { "dataSelect": "dataSelect"; "initialized": "initialized"; }, never, never, false, never>;
30
- }
1
+ import { AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, OnChanges, OnDestroy, SimpleChanges } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class ChartComponent implements AfterViewInit, OnDestroy, OnChanges {
4
+ el: ElementRef;
5
+ private cdr;
6
+ type: string;
7
+ data: any;
8
+ options: any;
9
+ plugins: any[];
10
+ width?: string;
11
+ height?: string;
12
+ responsive: boolean;
13
+ dataSelect: EventEmitter<any>;
14
+ initialized: EventEmitter<boolean>;
15
+ canvas: ElementRef<HTMLCanvasElement>;
16
+ chart: any;
17
+ constructor(el: ElementRef, cdr: ChangeDetectorRef);
18
+ ngAfterViewInit(): void;
19
+ onCanvasClick(event: MouseEvent): void;
20
+ private initChart;
21
+ getCanvas: () => HTMLCanvasElement;
22
+ getBase64Image: () => any;
23
+ generateLegend: () => any;
24
+ refresh: () => void;
25
+ reinit: () => void;
26
+ ngOnDestroy(): void;
27
+ ngOnChanges(changes: SimpleChanges): void;
28
+ static ɵfac: i0.ɵɵFactoryDeclaration<ChartComponent, never>;
29
+ static ɵcmp: i0.ɵɵComponentDeclaration<ChartComponent, "abp-chart", ["abpChart"], { "type": { "alias": "type"; "required": false; }; "data": { "alias": "data"; "required": false; }; "options": { "alias": "options"; "required": false; }; "plugins": { "alias": "plugins"; "required": false; }; "width": { "alias": "width"; "required": false; }; "height": { "alias": "height"; "required": false; }; "responsive": { "alias": "responsive"; "required": false; }; }, { "dataSelect": "dataSelect"; "initialized": "initialized"; }, never, never, false, never>;
30
+ }
@@ -1,8 +1,8 @@
1
- import * as i0 from "@angular/core";
2
- import * as i1 from "./chart.component";
3
- import * as i2 from "@angular/common";
4
- export declare class ChartModule {
5
- static ɵfac: i0.ɵɵFactoryDeclaration<ChartModule, never>;
6
- static ɵmod: i0.ɵɵNgModuleDeclaration<ChartModule, [typeof i1.ChartComponent], [typeof i2.CommonModule], [typeof i1.ChartComponent]>;
7
- static ɵinj: i0.ɵɵInjectorDeclaration<ChartModule>;
8
- }
1
+ import * as i0 from "@angular/core";
2
+ import * as i1 from "./chart.component";
3
+ import * as i2 from "@angular/common";
4
+ export declare class ChartModule {
5
+ static ɵfac: i0.ɵɵFactoryDeclaration<ChartModule, never>;
6
+ static ɵmod: i0.ɵɵNgModuleDeclaration<ChartModule, [typeof i1.ChartComponent], [typeof i2.CommonModule], [typeof i1.ChartComponent]>;
7
+ static ɵinj: i0.ɵɵInjectorDeclaration<ChartModule>;
8
+ }
@@ -1,5 +1,5 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- /// <amd-module name="@abp/ng.components/chart.js" />
5
- export * from './public-api';
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ /// <amd-module name="@abp/ng.components/chart.js" />
5
+ export * from './public-api';
@@ -1,3 +1,3 @@
1
- export * from './chart.component';
2
- export * from './chart.module';
3
- export * from './widget-utils';
1
+ export * from './chart.component';
2
+ export * from './chart.module';
3
+ export * from './widget-utils';
@@ -1 +1 @@
1
- export declare function getRandomBackgroundColor(count: number): any[];
1
+ export declare function getRandomBackgroundColor(count: number): any[];
@@ -1,5 +1,5 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './public-api';
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
5
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJwLW5nLmNvbXBvbmVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21wb25lbnRzL3NyYy9hYnAtbmcuY29tcG9uZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
@@ -1,5 +1,5 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './public-api';
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
5
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJwLW5nLmNvbXBvbmVudHMtY2hhcnQuanMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21wb25lbnRzL2NoYXJ0LmpzL3NyYy9hYnAtbmcuY29tcG9uZW50cy1jaGFydC5qcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
@@ -0,0 +1,141 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ let Chart;
4
+ class ChartComponent {
5
+ constructor(el, cdr) {
6
+ this.el = el;
7
+ this.cdr = cdr;
8
+ this.data = {};
9
+ this.options = {};
10
+ this.plugins = [];
11
+ this.responsive = true;
12
+ this.dataSelect = new EventEmitter();
13
+ this.initialized = new EventEmitter();
14
+ this.initChart = () => {
15
+ const opts = this.options || {};
16
+ opts.responsive = this.responsive;
17
+ // allows chart to resize in responsive mode
18
+ if (opts.responsive && (this.height || this.width)) {
19
+ opts.maintainAspectRatio = false;
20
+ }
21
+ this.chart = new Chart(this.canvas.nativeElement, {
22
+ type: this.type,
23
+ data: this.data,
24
+ options: this.options,
25
+ });
26
+ };
27
+ this.getCanvas = () => {
28
+ return this.canvas.nativeElement;
29
+ };
30
+ this.getBase64Image = () => {
31
+ return this.chart.toBase64Image();
32
+ };
33
+ this.generateLegend = () => {
34
+ if (this.chart) {
35
+ return this.chart.generateLegend();
36
+ }
37
+ };
38
+ this.refresh = () => {
39
+ if (this.chart) {
40
+ this.chart.update();
41
+ this.cdr.detectChanges();
42
+ }
43
+ };
44
+ this.reinit = () => {
45
+ if (!this.chart)
46
+ return;
47
+ this.chart.destroy();
48
+ this.initChart();
49
+ };
50
+ }
51
+ ngAfterViewInit() {
52
+ import('chart.js/auto').then(module => {
53
+ Chart = module.default;
54
+ this.initChart();
55
+ this.initialized.emit(true);
56
+ });
57
+ }
58
+ onCanvasClick(event) {
59
+ if (this.chart) {
60
+ const element = this.chart.getElementsAtEventForMode(event, 'nearest', { intersect: true }, false);
61
+ const dataset = this.chart.getElementsAtEventForMode(event, 'dataset', { intersect: true }, false);
62
+ if (element && element[0] && dataset) {
63
+ this.dataSelect.emit({ originalEvent: event, element: element[0], dataset: dataset });
64
+ }
65
+ }
66
+ }
67
+ ngOnDestroy() {
68
+ if (this.chart) {
69
+ this.chart.destroy();
70
+ this.chart = null;
71
+ }
72
+ }
73
+ ngOnChanges(changes) {
74
+ if (!this.chart)
75
+ return;
76
+ if (changes.data?.currentValue || changes.options?.currentValue) {
77
+ this.chart.destroy();
78
+ this.initChart();
79
+ }
80
+ }
81
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ChartComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
82
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: ChartComponent, selector: "abp-chart", inputs: { type: "type", data: "data", options: "options", plugins: "plugins", width: "width", height: "height", responsive: "responsive" }, outputs: { dataSelect: "dataSelect", initialized: "initialized" }, viewQueries: [{ propertyName: "canvas", first: true, predicate: ["canvas"], descendants: true }], exportAs: ["abpChart"], usesOnChanges: true, ngImport: i0, template: `
83
+ <div
84
+ style="position:relative"
85
+ [style.width]="responsive && !width ? null : width"
86
+ [style.height]="responsive && !height ? null : height"
87
+ >
88
+ <canvas
89
+ #canvas
90
+ [attr.width]="responsive && !width ? null : width"
91
+ [attr.height]="responsive && !height ? null : height"
92
+ (click)="onCanvasClick($event)"
93
+ ></canvas>
94
+ </div>
95
+ `, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
96
+ }
97
+ export { ChartComponent };
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ChartComponent, decorators: [{
99
+ type: Component,
100
+ args: [{
101
+ selector: 'abp-chart',
102
+ template: `
103
+ <div
104
+ style="position:relative"
105
+ [style.width]="responsive && !width ? null : width"
106
+ [style.height]="responsive && !height ? null : height"
107
+ >
108
+ <canvas
109
+ #canvas
110
+ [attr.width]="responsive && !width ? null : width"
111
+ [attr.height]="responsive && !height ? null : height"
112
+ (click)="onCanvasClick($event)"
113
+ ></canvas>
114
+ </div>
115
+ `,
116
+ changeDetection: ChangeDetectionStrategy.OnPush,
117
+ exportAs: 'abpChart',
118
+ }]
119
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { type: [{
120
+ type: Input
121
+ }], data: [{
122
+ type: Input
123
+ }], options: [{
124
+ type: Input
125
+ }], plugins: [{
126
+ type: Input
127
+ }], width: [{
128
+ type: Input
129
+ }], height: [{
130
+ type: Input
131
+ }], responsive: [{
132
+ type: Input
133
+ }], dataSelect: [{
134
+ type: Output
135
+ }], initialized: [{
136
+ type: Output
137
+ }], canvas: [{
138
+ type: ViewChild,
139
+ args: ['canvas']
140
+ }] } });
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.component.js","sourceRoot":"","sources":["../../../../../packages/components/chart.js/src/chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\nlet Chart: any;\r\n\r\n@Component({\r\n  selector: 'abp-chart',\r\n  template: `\r\n    <div\r\n      style=\"position:relative\"\r\n      [style.width]=\"responsive && !width ? null : width\"\r\n      [style.height]=\"responsive && !height ? null : height\"\r\n    >\r\n      <canvas\r\n        #canvas\r\n        [attr.width]=\"responsive && !width ? null : width\"\r\n        [attr.height]=\"responsive && !height ? null : height\"\r\n        (click)=\"onCanvasClick($event)\"\r\n      ></canvas>\r\n    </div>\r\n  `,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  exportAs: 'abpChart',\r\n})\r\nexport class ChartComponent implements AfterViewInit, OnDestroy, OnChanges {\r\n  @Input() type!: string;\r\n\r\n  @Input() data: any = {};\r\n\r\n  @Input() options: any = {};\r\n\r\n  @Input() plugins: any[] = [];\r\n\r\n  @Input() width?: string;\r\n\r\n  @Input() height?: string;\r\n\r\n  @Input() responsive = true;\r\n\r\n  @Output() dataSelect = new EventEmitter();\r\n\r\n  @Output() initialized = new EventEmitter<boolean>();\r\n\r\n  @ViewChild('canvas') canvas!: ElementRef<HTMLCanvasElement>;\r\n\r\n  chart: any;\r\n\r\n  constructor(public el: ElementRef, private cdr: ChangeDetectorRef) {}\r\n\r\n  ngAfterViewInit() {\r\n    import('chart.js/auto').then(module => {\r\n      Chart = module.default;\r\n      this.initChart();\r\n      this.initialized.emit(true);\r\n    });\r\n  }\r\n\r\n  onCanvasClick(event: MouseEvent) {\r\n    if (this.chart) {\r\n      const element = this.chart.getElementsAtEventForMode(\r\n        event,\r\n        'nearest',\r\n        { intersect: true },\r\n        false,\r\n      );\r\n      const dataset = this.chart.getElementsAtEventForMode(\r\n        event,\r\n        'dataset',\r\n        { intersect: true },\r\n        false,\r\n      );\r\n\r\n      if (element && element[0] && dataset) {\r\n        this.dataSelect.emit({ originalEvent: event, element: element[0], dataset: dataset });\r\n      }\r\n    }\r\n  }\r\n\r\n  private initChart = () => {\r\n    const opts = this.options || {};\r\n    opts.responsive = this.responsive;\r\n\r\n    // allows chart to resize in responsive mode\r\n    if (opts.responsive && (this.height || this.width)) {\r\n      opts.maintainAspectRatio = false;\r\n    }\r\n\r\n    this.chart = new Chart(this.canvas.nativeElement, {\r\n      type: this.type as any,\r\n      data: this.data,\r\n      options: this.options,\r\n    });\r\n  };\r\n\r\n  getCanvas = () => {\r\n    return this.canvas.nativeElement;\r\n  };\r\n\r\n  getBase64Image = () => {\r\n    return this.chart.toBase64Image();\r\n  };\r\n\r\n  generateLegend = () => {\r\n    if (this.chart) {\r\n      return this.chart.generateLegend();\r\n    }\r\n  };\r\n\r\n  refresh = () => {\r\n    if (this.chart) {\r\n      this.chart.update();\r\n      this.cdr.detectChanges();\r\n    }\r\n  };\r\n\r\n  reinit = () => {\r\n    if (!this.chart) return;\r\n    this.chart.destroy();\r\n    this.initChart();\r\n  };\r\n\r\n  ngOnDestroy() {\r\n    if (this.chart) {\r\n      this.chart.destroy();\r\n      this.chart = null;\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (!this.chart) return;\r\n\r\n    if (changes.data?.currentValue || changes.options?.currentValue) {\r\n      this.chart.destroy();\r\n      this.initChart();\r\n    }\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,20 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { ChartComponent } from './chart.component';
4
+ import * as i0 from "@angular/core";
5
+ class ChartModule {
6
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ChartModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.1", ngImport: i0, type: ChartModule, declarations: [ChartComponent], imports: [CommonModule], exports: [ChartComponent] }); }
8
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ChartModule, imports: [CommonModule] }); }
9
+ }
10
+ export { ChartModule };
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ChartModule, decorators: [{
12
+ type: NgModule,
13
+ args: [{
14
+ imports: [CommonModule],
15
+ exports: [ChartComponent],
16
+ declarations: [ChartComponent],
17
+ providers: [],
18
+ }]
19
+ }] });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcG9uZW50cy9jaGFydC5qcy9zcmMvY2hhcnQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7QUFFbkQsTUFNYSxXQUFXOzhHQUFYLFdBQVc7K0dBQVgsV0FBVyxpQkFIUCxjQUFjLGFBRm5CLFlBQVksYUFDWixjQUFjOytHQUliLFdBQVcsWUFMWixZQUFZOztTQUtYLFdBQVc7MkZBQVgsV0FBVztrQkFOdkIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7b0JBQ3ZCLE9BQU8sRUFBRSxDQUFDLGNBQWMsQ0FBQztvQkFDekIsWUFBWSxFQUFFLENBQUMsY0FBYyxDQUFDO29CQUM5QixTQUFTLEVBQUUsRUFBRTtpQkFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENoYXJ0Q29tcG9uZW50IH0gZnJvbSAnLi9jaGFydC5jb21wb25lbnQnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcclxuICBleHBvcnRzOiBbQ2hhcnRDb21wb25lbnRdLFxyXG4gIGRlY2xhcmF0aW9uczogW0NoYXJ0Q29tcG9uZW50XSxcclxuICBwcm92aWRlcnM6IFtdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2hhcnRNb2R1bGUge31cclxuIl19
@@ -1,4 +1,4 @@
1
- export * from './chart.component';
2
- export * from './chart.module';
3
- export * from './widget-utils';
1
+ export * from './chart.component';
2
+ export * from './chart.module';
3
+ export * from './widget-utils';
4
4
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBvbmVudHMvY2hhcnQuanMvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsZ0JBQWdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NoYXJ0LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY2hhcnQubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi93aWRnZXQtdXRpbHMnO1xyXG5cclxuIl19
@@ -1,11 +1,11 @@
1
- export function getRandomBackgroundColor(count) {
2
- const colors = [];
3
- for (let i = 0; i < count; i++) {
4
- const r = ((i + 5) * (i + 5) * 474) % 255;
5
- const g = ((i + 5) * (i + 5) * 1600) % 255;
6
- const b = ((i + 5) * (i + 5) * 84065) % 255;
7
- colors.push('rgba(' + r + ', ' + g + ', ' + b + ', 0.7)');
8
- }
9
- return colors;
10
- }
1
+ export function getRandomBackgroundColor(count) {
2
+ const colors = [];
3
+ for (let i = 0; i < count; i++) {
4
+ const r = ((i + 5) * (i + 5) * 474) % 255;
5
+ const g = ((i + 5) * (i + 5) * 1600) % 255;
6
+ const b = ((i + 5) * (i + 5) * 84065) % 255;
7
+ colors.push('rgba(' + r + ', ' + g + ', ' + b + ', 0.7)');
8
+ }
9
+ return colors;
10
+ }
11
11
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LXV0aWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcG9uZW50cy9jaGFydC5qcy9zcmMvd2lkZ2V0LXV0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sVUFBVSx3QkFBd0IsQ0FBQyxLQUFhO0lBQ3BELE1BQU0sTUFBTSxHQUFHLEVBQUUsQ0FBQztJQUVsQixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsS0FBSyxFQUFFLENBQUMsRUFBRSxFQUFFO1FBQzlCLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDLEdBQUcsR0FBRyxDQUFDO1FBQzFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsR0FBRyxDQUFDO1FBQzNDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsS0FBSyxDQUFDLEdBQUcsR0FBRyxDQUFDO1FBQzVDLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxHQUFHLENBQUMsR0FBRyxJQUFJLEdBQUcsQ0FBQyxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsUUFBUSxDQUFDLENBQUM7S0FDM0Q7SUFFRCxPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIGdldFJhbmRvbUJhY2tncm91bmRDb2xvcihjb3VudDogbnVtYmVyKSB7XHJcbiAgY29uc3QgY29sb3JzID0gW107XHJcblxyXG4gIGZvciAobGV0IGkgPSAwOyBpIDwgY291bnQ7IGkrKykge1xyXG4gICAgY29uc3QgciA9ICgoaSArIDUpICogKGkgKyA1KSAqIDQ3NCkgJSAyNTU7XHJcbiAgICBjb25zdCBnID0gKChpICsgNSkgKiAoaSArIDUpICogMTYwMCkgJSAyNTU7XHJcbiAgICBjb25zdCBiID0gKChpICsgNSkgKiAoaSArIDUpICogODQwNjUpICUgMjU1O1xyXG4gICAgY29sb3JzLnB1c2goJ3JnYmEoJyArIHIgKyAnLCAnICsgZyArICcsICcgKyBiICsgJywgMC43KScpO1xyXG4gIH1cclxuXHJcbiAgcmV0dXJuIGNvbG9ycztcclxufVxyXG4iXX0=
@@ -1,5 +1,5 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './public-api';
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
5
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJwLW5nLmNvbXBvbmVudHMtcGFnZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBvbmVudHMvcGFnZS9zcmMvYWJwLW5nLmNvbXBvbmVudHMtcGFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
@@ -0,0 +1,77 @@
1
+ import { Directive, TemplateRef, ViewContainerRef, Input, InjectionToken, Optional, Inject, Injector, } from '@angular/core';
2
+ import { Observable, of } from 'rxjs';
3
+ import * as i0 from "@angular/core";
4
+ export const PAGE_RENDER_STRATEGY = new InjectionToken('PAGE_RENDER_STRATEGY');
5
+ class PagePartDirective {
6
+ set abpPagePart(type) {
7
+ this.type = type;
8
+ this.createRenderStream(type);
9
+ }
10
+ constructor(templateRef, viewContainer, renderLogic, injector) {
11
+ this.templateRef = templateRef;
12
+ this.viewContainer = viewContainer;
13
+ this.renderLogic = renderLogic;
14
+ this.injector = injector;
15
+ this.hasRendered = false;
16
+ this.render = (shouldRender) => {
17
+ if (shouldRender && !this.hasRendered) {
18
+ this.viewContainer.createEmbeddedView(this.templateRef);
19
+ this.hasRendered = true;
20
+ }
21
+ else if (!shouldRender && this.hasRendered) {
22
+ this.viewContainer.clear();
23
+ this.hasRendered = false;
24
+ }
25
+ };
26
+ }
27
+ ngOnChanges({ context }) {
28
+ if (this.renderLogic?.onContextUpdate) {
29
+ this.renderLogic.onContextUpdate(context);
30
+ }
31
+ }
32
+ ngOnInit() {
33
+ if (this.renderLogic?.onInit) {
34
+ this.renderLogic.onInit(this.type, this.injector, this.context);
35
+ }
36
+ }
37
+ ngOnDestroy() {
38
+ this.clearSubscription();
39
+ if (this.renderLogic?.onDestroy) {
40
+ this.renderLogic.onDestroy(this.type, this.injector, this.context);
41
+ }
42
+ }
43
+ shouldRender(type) {
44
+ if (this.renderLogic) {
45
+ const willRender = this.renderLogic.shouldRender(type);
46
+ return willRender instanceof Observable ? willRender : of(willRender);
47
+ }
48
+ return of(true);
49
+ }
50
+ createRenderStream(type) {
51
+ this.clearSubscription();
52
+ this.subscription = this.shouldRender(type).subscribe(this.render);
53
+ }
54
+ clearSubscription() {
55
+ if (this.subscription) {
56
+ this.subscription.unsubscribe();
57
+ }
58
+ }
59
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: PagePartDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }, { token: PAGE_RENDER_STRATEGY, optional: true }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive }); }
60
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.1", type: PagePartDirective, selector: "[abpPagePart]", inputs: { context: ["abpPagePartContext", "context"], abpPagePart: "abpPagePart" }, usesOnChanges: true, ngImport: i0 }); }
61
+ }
62
+ export { PagePartDirective };
63
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: PagePartDirective, decorators: [{
64
+ type: Directive,
65
+ args: [{ selector: '[abpPagePart]' }]
66
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
67
+ type: Optional
68
+ }, {
69
+ type: Inject,
70
+ args: [PAGE_RENDER_STRATEGY]
71
+ }] }, { type: i0.Injector }]; }, propDecorators: { context: [{
72
+ type: Input,
73
+ args: ['abpPagePartContext']
74
+ }], abpPagePart: [{
75
+ type: Input
76
+ }] } });
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS1wYXJ0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBvbmVudHMvcGFnZS9zcmMvcGFnZS1wYXJ0LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULFdBQVcsRUFDWCxnQkFBZ0IsRUFDaEIsS0FBSyxFQUNMLGNBQWMsRUFDZCxRQUFRLEVBQ1IsTUFBTSxFQUdOLFFBQVEsR0FJVCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsVUFBVSxFQUFnQixFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBU3BELE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLElBQUksY0FBYyxDQUFxQixzQkFBc0IsQ0FBQyxDQUFDO0FBRW5HLE1BQ2EsaUJBQWlCO0lBTTVCLElBQWEsV0FBVyxDQUFDLElBQVk7UUFDbkMsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDakIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFZRCxZQUNVLFdBQTZCLEVBQzdCLGFBQStCLEVBQ1csV0FBK0IsRUFDekUsUUFBa0I7UUFIbEIsZ0JBQVcsR0FBWCxXQUFXLENBQWtCO1FBQzdCLGtCQUFhLEdBQWIsYUFBYSxDQUFrQjtRQUNXLGdCQUFXLEdBQVgsV0FBVyxDQUFvQjtRQUN6RSxhQUFRLEdBQVIsUUFBUSxDQUFVO1FBeEI1QixnQkFBVyxHQUFHLEtBQUssQ0FBQztRQVVwQixXQUFNLEdBQUcsQ0FBQyxZQUFxQixFQUFFLEVBQUU7WUFDakMsSUFBSSxZQUFZLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFO2dCQUNyQyxJQUFJLENBQUMsYUFBYSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztnQkFDeEQsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUM7YUFDekI7aUJBQU0sSUFBSSxDQUFDLFlBQVksSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO2dCQUM1QyxJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO2dCQUMzQixJQUFJLENBQUMsV0FBVyxHQUFHLEtBQUssQ0FBQzthQUMxQjtRQUNILENBQUMsQ0FBQztJQU9DLENBQUM7SUFFSixXQUFXLENBQUMsRUFBRSxPQUFPLEVBQWlCO1FBQ3BDLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxlQUFlLEVBQUU7WUFDckMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUM7U0FDM0M7SUFDSCxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxNQUFNLEVBQUU7WUFDNUIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztTQUNqRTtJQUNILENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7UUFFekIsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFLFNBQVMsRUFBRTtZQUMvQixJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1NBQ3BFO0lBQ0gsQ0FBQztJQUVELFlBQVksQ0FBQyxJQUFZO1FBQ3ZCLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNwQixNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUN2RCxPQUFPLFVBQVUsWUFBWSxVQUFVLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1NBQ3ZFO1FBQ0QsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbEIsQ0FBQztJQUVTLGtCQUFrQixDQUFDLElBQVk7UUFDdkMsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7UUFFekIsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDckUsQ0FBQztJQUVTLGlCQUFpQjtRQUN6QixJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDckIsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUNqQztJQUNILENBQUM7OEdBbEVVLGlCQUFpQiw2RUF3Qk4sb0JBQW9CO2tHQXhCL0IsaUJBQWlCOztTQUFqQixpQkFBaUI7MkZBQWpCLGlCQUFpQjtrQkFEN0IsU0FBUzttQkFBQyxFQUFFLFFBQVEsRUFBRSxlQUFlLEVBQUU7OzBCQXlCbkMsUUFBUTs7MEJBQUksTUFBTTsyQkFBQyxvQkFBb0I7bUVBbkJiLE9BQU87c0JBQW5DLEtBQUs7dUJBQUMsb0JBQW9CO2dCQUNkLFdBQVc7c0JBQXZCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIERpcmVjdGl2ZSxcclxuICBUZW1wbGF0ZVJlZixcclxuICBWaWV3Q29udGFpbmVyUmVmLFxyXG4gIElucHV0LFxyXG4gIEluamVjdGlvblRva2VuLFxyXG4gIE9wdGlvbmFsLFxyXG4gIEluamVjdCxcclxuICBPbkluaXQsXHJcbiAgT25EZXN0cm95LFxyXG4gIEluamVjdG9yLFxyXG4gIE9uQ2hhbmdlcyxcclxuICBTaW1wbGVDaGFuZ2VzLFxyXG4gIFNpbXBsZUNoYW5nZSxcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3Vic2NyaXB0aW9uLCBvZiB9IGZyb20gJ3J4anMnO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBQYWdlUmVuZGVyU3RyYXRlZ3kge1xyXG4gIHNob3VsZFJlbmRlcih0eXBlPzogc3RyaW5nKTogYm9vbGVhbiB8IE9ic2VydmFibGU8Ym9vbGVhbj47XHJcbiAgb25Jbml0Pyh0eXBlPzogc3RyaW5nLCBpbmplY3Rvcj86IEluamVjdG9yLCBjb250ZXh0PzogYW55KTogdm9pZDtcclxuICBvbkRlc3Ryb3k/KHR5cGU/OiBzdHJpbmcsIGluamVjdG9yPzogSW5qZWN0b3IsIGNvbnRleHQ/OiBhbnkpOiB2b2lkO1xyXG4gIG9uQ29udGV4dFVwZGF0ZT8oY2hhbmdlPzogU2ltcGxlQ2hhbmdlKTogdm9pZDtcclxufVxyXG5cclxuZXhwb3J0IGNvbnN0IFBBR0VfUkVOREVSX1NUUkFURUdZID0gbmV3IEluamVjdGlvblRva2VuPFBhZ2VSZW5kZXJTdHJhdGVneT4oJ1BBR0VfUkVOREVSX1NUUkFURUdZJyk7XHJcblxyXG5ARGlyZWN0aXZlKHsgc2VsZWN0b3I6ICdbYWJwUGFnZVBhcnRdJyB9KVxyXG5leHBvcnQgY2xhc3MgUGFnZVBhcnREaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSwgT25DaGFuZ2VzIHtcclxuICBoYXNSZW5kZXJlZCA9IGZhbHNlO1xyXG4gIHR5cGUhOiBzdHJpbmc7XHJcbiAgc3Vic2NyaXB0aW9uITogU3Vic2NyaXB0aW9uO1xyXG5cclxuICBASW5wdXQoJ2FicFBhZ2VQYXJ0Q29udGV4dCcpIGNvbnRleHQ6IGFueTtcclxuICBASW5wdXQoKSBzZXQgYWJwUGFnZVBhcnQodHlwZTogc3RyaW5nKSB7XHJcbiAgICB0aGlzLnR5cGUgPSB0eXBlO1xyXG4gICAgdGhpcy5jcmVhdGVSZW5kZXJTdHJlYW0odHlwZSk7XHJcbiAgfVxyXG5cclxuICByZW5kZXIgPSAoc2hvdWxkUmVuZGVyOiBib29sZWFuKSA9PiB7XHJcbiAgICBpZiAoc2hvdWxkUmVuZGVyICYmICF0aGlzLmhhc1JlbmRlcmVkKSB7XHJcbiAgICAgIHRoaXMudmlld0NvbnRhaW5lci5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy50ZW1wbGF0ZVJlZik7XHJcbiAgICAgIHRoaXMuaGFzUmVuZGVyZWQgPSB0cnVlO1xyXG4gICAgfSBlbHNlIGlmICghc2hvdWxkUmVuZGVyICYmIHRoaXMuaGFzUmVuZGVyZWQpIHtcclxuICAgICAgdGhpcy52aWV3Q29udGFpbmVyLmNsZWFyKCk7XHJcbiAgICAgIHRoaXMuaGFzUmVuZGVyZWQgPSBmYWxzZTtcclxuICAgIH1cclxuICB9O1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgdGVtcGxhdGVSZWY6IFRlbXBsYXRlUmVmPGFueT4sXHJcbiAgICBwcml2YXRlIHZpZXdDb250YWluZXI6IFZpZXdDb250YWluZXJSZWYsXHJcbiAgICBAT3B0aW9uYWwoKSBASW5qZWN0KFBBR0VfUkVOREVSX1NUUkFURUdZKSBwcml2YXRlIHJlbmRlckxvZ2ljOiBQYWdlUmVuZGVyU3RyYXRlZ3ksXHJcbiAgICBwcml2YXRlIGluamVjdG9yOiBJbmplY3RvcixcclxuICApIHt9XHJcblxyXG4gIG5nT25DaGFuZ2VzKHsgY29udGV4dCB9OiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XHJcbiAgICBpZiAodGhpcy5yZW5kZXJMb2dpYz8ub25Db250ZXh0VXBkYXRlKSB7XHJcbiAgICAgIHRoaXMucmVuZGVyTG9naWMub25Db250ZXh0VXBkYXRlKGNvbnRleHQpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICBpZiAodGhpcy5yZW5kZXJMb2dpYz8ub25Jbml0KSB7XHJcbiAgICAgIHRoaXMucmVuZGVyTG9naWMub25Jbml0KHRoaXMudHlwZSwgdGhpcy5pbmplY3RvciwgdGhpcy5jb250ZXh0KTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95KCkge1xyXG4gICAgdGhpcy5jbGVhclN1YnNjcmlwdGlvbigpO1xyXG5cclxuICAgIGlmICh0aGlzLnJlbmRlckxvZ2ljPy5vbkRlc3Ryb3kpIHtcclxuICAgICAgdGhpcy5yZW5kZXJMb2dpYy5vbkRlc3Ryb3kodGhpcy50eXBlLCB0aGlzLmluamVjdG9yLCB0aGlzLmNvbnRleHQpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgc2hvdWxkUmVuZGVyKHR5cGU6IHN0cmluZykge1xyXG4gICAgaWYgKHRoaXMucmVuZGVyTG9naWMpIHtcclxuICAgICAgY29uc3Qgd2lsbFJlbmRlciA9IHRoaXMucmVuZGVyTG9naWMuc2hvdWxkUmVuZGVyKHR5cGUpO1xyXG4gICAgICByZXR1cm4gd2lsbFJlbmRlciBpbnN0YW5jZW9mIE9ic2VydmFibGUgPyB3aWxsUmVuZGVyIDogb2Yod2lsbFJlbmRlcik7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gb2YodHJ1ZSk7XHJcbiAgfVxyXG5cclxuICBwcm90ZWN0ZWQgY3JlYXRlUmVuZGVyU3RyZWFtKHR5cGU6IHN0cmluZykge1xyXG4gICAgdGhpcy5jbGVhclN1YnNjcmlwdGlvbigpO1xyXG5cclxuICAgIHRoaXMuc3Vic2NyaXB0aW9uID0gdGhpcy5zaG91bGRSZW5kZXIodHlwZSkuc3Vic2NyaWJlKHRoaXMucmVuZGVyKTtcclxuICB9XHJcblxyXG4gIHByb3RlY3RlZCBjbGVhclN1YnNjcmlwdGlvbigpIHtcclxuICAgIGlmICh0aGlzLnN1YnNjcmlwdGlvbikge1xyXG4gICAgICB0aGlzLnN1YnNjcmlwdGlvbi51bnN1YnNjcmliZSgpO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
@@ -0,0 +1,48 @@
1
+ import { Component, ViewEncapsulation } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export var PageParts;
4
+ (function (PageParts) {
5
+ PageParts["title"] = "PageTitleContainerComponent";
6
+ PageParts["breadcrumb"] = "PageBreadcrumbContainerComponent";
7
+ PageParts["toolbar"] = "PageToolbarContainerComponent";
8
+ })(PageParts || (PageParts = {}));
9
+ class PageTitleContainerComponent {
10
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: PageTitleContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
11
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: PageTitleContainerComponent, selector: "abp-page-title-container", ngImport: i0, template: ` <ng-content></ng-content> `, isInline: true, encapsulation: i0.ViewEncapsulation.None }); }
12
+ }
13
+ export { PageTitleContainerComponent };
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: PageTitleContainerComponent, decorators: [{
15
+ type: Component,
16
+ args: [{
17
+ selector: 'abp-page-title-container',
18
+ template: ` <ng-content></ng-content> `,
19
+ encapsulation: ViewEncapsulation.None,
20
+ }]
21
+ }] });
22
+ class PageBreadcrumbContainerComponent {
23
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: PageBreadcrumbContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
24
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: PageBreadcrumbContainerComponent, selector: "abp-page-breadcrumb-container", ngImport: i0, template: ` <ng-content></ng-content> `, isInline: true, encapsulation: i0.ViewEncapsulation.None }); }
25
+ }
26
+ export { PageBreadcrumbContainerComponent };
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: PageBreadcrumbContainerComponent, decorators: [{
28
+ type: Component,
29
+ args: [{
30
+ selector: 'abp-page-breadcrumb-container',
31
+ template: ` <ng-content></ng-content> `,
32
+ encapsulation: ViewEncapsulation.None,
33
+ }]
34
+ }] });
35
+ class PageToolbarContainerComponent {
36
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: PageToolbarContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
37
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: PageToolbarContainerComponent, selector: "abp-page-toolbar-container", ngImport: i0, template: ` <ng-content></ng-content> `, isInline: true, encapsulation: i0.ViewEncapsulation.None }); }
38
+ }
39
+ export { PageToolbarContainerComponent };
40
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: PageToolbarContainerComponent, decorators: [{
41
+ type: Component,
42
+ args: [{
43
+ selector: 'abp-page-toolbar-container',
44
+ template: ` <ng-content></ng-content> `,
45
+ encapsulation: ViewEncapsulation.None,
46
+ }]
47
+ }] });
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS1wYXJ0cy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21wb25lbnRzL3BhZ2Uvc3JjL3BhZ2UtcGFydHMuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRTdELE1BQU0sQ0FBTixJQUFZLFNBSVg7QUFKRCxXQUFZLFNBQVM7SUFDbkIsa0RBQXFDLENBQUE7SUFDckMsNERBQStDLENBQUE7SUFDL0Msc0RBQXlDLENBQUE7QUFDM0MsQ0FBQyxFQUpXLFNBQVMsS0FBVCxTQUFTLFFBSXBCO0FBRUQsTUFLYSwyQkFBMkI7OEdBQTNCLDJCQUEyQjtrR0FBM0IsMkJBQTJCLGdFQUg1Qiw2QkFBNkI7O1NBRzVCLDJCQUEyQjsyRkFBM0IsMkJBQTJCO2tCQUx2QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSwwQkFBMEI7b0JBQ3BDLFFBQVEsRUFBRSw2QkFBNkI7b0JBQ3ZDLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2lCQUN0Qzs7QUFHRCxNQUthLGdDQUFnQzs4R0FBaEMsZ0NBQWdDO2tHQUFoQyxnQ0FBZ0MscUVBSGpDLDZCQUE2Qjs7U0FHNUIsZ0NBQWdDOzJGQUFoQyxnQ0FBZ0M7a0JBTDVDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLCtCQUErQjtvQkFDekMsUUFBUSxFQUFFLDZCQUE2QjtvQkFDdkMsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7aUJBQ3RDOztBQUdELE1BS2EsNkJBQTZCOzhHQUE3Qiw2QkFBNkI7a0dBQTdCLDZCQUE2QixrRUFIOUIsNkJBQTZCOztTQUc1Qiw2QkFBNkI7MkZBQTdCLDZCQUE2QjtrQkFMekMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsNEJBQTRCO29CQUN0QyxRQUFRLEVBQUUsNkJBQTZCO29CQUN2QyxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTtpQkFDdEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5leHBvcnQgZW51bSBQYWdlUGFydHMge1xyXG4gIHRpdGxlID0gJ1BhZ2VUaXRsZUNvbnRhaW5lckNvbXBvbmVudCcsXHJcbiAgYnJlYWRjcnVtYiA9ICdQYWdlQnJlYWRjcnVtYkNvbnRhaW5lckNvbXBvbmVudCcsXHJcbiAgdG9vbGJhciA9ICdQYWdlVG9vbGJhckNvbnRhaW5lckNvbXBvbmVudCcsXHJcbn1cclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYWJwLXBhZ2UtdGl0bGUtY29udGFpbmVyJyxcclxuICB0ZW1wbGF0ZTogYCA8bmctY29udGVudD48L25nLWNvbnRlbnQ+IGAsXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxufSlcclxuZXhwb3J0IGNsYXNzIFBhZ2VUaXRsZUNvbnRhaW5lckNvbXBvbmVudCB7fVxyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhYnAtcGFnZS1icmVhZGNydW1iLWNvbnRhaW5lcicsXHJcbiAgdGVtcGxhdGU6IGAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PiBgLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBQYWdlQnJlYWRjcnVtYkNvbnRhaW5lckNvbXBvbmVudCB7fVxyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhYnAtcGFnZS10b29sYmFyLWNvbnRhaW5lcicsXHJcbiAgdGVtcGxhdGU6IGAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PiBgLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBQYWdlVG9vbGJhckNvbnRhaW5lckNvbXBvbmVudCB7fVxyXG4iXX0=