@odx/angular 12.7.0 → 12.9.0
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.
- package/CHANGELOG.md +17 -0
- package/cdk/autocomplete-control/index.d.ts +1 -0
- package/cdk/autocomplete-control/lib/directives/highlight-search-result.directive.d.ts +19 -0
- package/cdk/autocomplete-control/lib/directives/index.d.ts +1 -0
- package/components/data-table/README.md +3 -0
- package/components/data-table/index.d.ts +4 -0
- package/components/data-table/lib/data-table.component.d.ts +32 -0
- package/components/data-table/lib/data-table.module.d.ts +14 -0
- package/components/data-table/lib/directives/cell-def.directive.d.ts +7 -0
- package/components/data-table/lib/directives/cell.directive.d.ts +5 -0
- package/components/data-table/lib/directives/column-def.directive.d.ts +11 -0
- package/components/data-table/lib/directives/header-cell-def.directive.d.ts +7 -0
- package/components/data-table/lib/directives/header-cell.directive.d.ts +5 -0
- package/components/data-table/lib/directives/index.d.ts +6 -0
- package/components/data-table/lib/directives/table-empty.directive.d.ts +5 -0
- package/components/data-table/lib/models/index.d.ts +3 -0
- package/components/data-table/lib/models/sort-direction.d.ts +6 -0
- package/components/data-table/lib/models/sort-state.d.ts +5 -0
- package/components/data-table/lib/models/table-variant.d.ts +5 -0
- package/components/main-menu/lib/main-menu.component.d.ts +0 -1
- package/components/modal/lib/modal.component.d.ts +1 -1
- package/components/table/lib/components/header-title/header-title.component.d.ts +2 -2
- package/components/table/lib/models/header-cell.d.ts +1 -2
- package/components/table/lib/models/index.d.ts +1 -2
- package/components/table/lib/table.component.d.ts +3 -3
- package/esm2022/cdk/autocomplete-control/index.mjs +2 -1
- package/esm2022/cdk/autocomplete-control/lib/directives/highlight-search-result.directive.mjs +43 -0
- package/esm2022/cdk/autocomplete-control/lib/directives/index.mjs +2 -0
- package/esm2022/cdk/connected-overlay/lib/connected-overlay.component.mjs +2 -2
- package/esm2022/components/data-table/index.mjs +5 -0
- package/esm2022/components/data-table/lib/data-table.component.mjs +51 -0
- package/esm2022/components/data-table/lib/data-table.module.mjs +19 -0
- package/esm2022/components/data-table/lib/directives/cell-def.directive.mjs +17 -0
- package/esm2022/components/data-table/lib/directives/cell.directive.mjs +18 -0
- package/esm2022/components/data-table/lib/directives/column-def.directive.mjs +27 -0
- package/esm2022/components/data-table/lib/directives/header-cell-def.directive.mjs +17 -0
- package/esm2022/components/data-table/lib/directives/header-cell.directive.mjs +18 -0
- package/esm2022/components/data-table/lib/directives/index.mjs +7 -0
- package/esm2022/components/data-table/lib/directives/table-empty.directive.mjs +11 -0
- package/esm2022/components/data-table/lib/models/index.mjs +4 -0
- package/esm2022/components/data-table/lib/models/sort-direction.mjs +6 -0
- package/esm2022/components/data-table/lib/models/sort-state.mjs +2 -0
- package/esm2022/components/data-table/lib/models/table-variant.mjs +5 -0
- package/esm2022/components/data-table/odx-angular-components-data-table.mjs +5 -0
- package/esm2022/components/main-menu/lib/main-menu.component.mjs +4 -8
- package/esm2022/components/modal/lib/modal.component.mjs +8 -10
- package/esm2022/components/table/lib/components/header-title/header-title.component.mjs +1 -1
- package/esm2022/components/table/lib/models/header-cell.mjs +1 -1
- package/esm2022/components/table/lib/models/index.mjs +2 -3
- package/esm2022/components/table/lib/models/table-body-cell.mjs +2 -0
- package/esm2022/components/table/lib/table.component.mjs +7 -19
- package/esm2022/components/toast/lib/components/toast-container/toast-container.component.mjs +6 -5
- package/fesm2022/odx-angular-cdk-autocomplete-control.mjs +43 -2
- package/fesm2022/odx-angular-cdk-autocomplete-control.mjs.map +1 -1
- package/fesm2022/odx-angular-cdk-connected-overlay.mjs +1 -1
- package/fesm2022/odx-angular-cdk-connected-overlay.mjs.map +1 -1
- package/fesm2022/odx-angular-components-data-table.mjs +176 -0
- package/fesm2022/odx-angular-components-data-table.mjs.map +1 -0
- package/fesm2022/odx-angular-components-main-menu.mjs +3 -7
- package/fesm2022/odx-angular-components-main-menu.mjs.map +1 -1
- package/fesm2022/odx-angular-components-modal.mjs +7 -6
- package/fesm2022/odx-angular-components-modal.mjs.map +1 -1
- package/fesm2022/odx-angular-components-table.mjs +6 -18
- package/fesm2022/odx-angular-components-table.mjs.map +1 -1
- package/fesm2022/odx-angular-components-toast.mjs +5 -4
- package/fesm2022/odx-angular-components-toast.mjs.map +1 -1
- package/package.json +13 -7
- package/components/table/lib/models/column-width.d.ts +0 -5
- package/esm2022/components/table/lib/models/body-cell.mjs +0 -2
- package/esm2022/components/table/lib/models/column-width.mjs +0 -2
- /package/components/table/lib/models/{body-cell.d.ts → table-body-cell.d.ts} +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,22 @@
|
|
|
1
1
|
# @odx/angular
|
|
2
2
|
|
|
3
|
+
## 12.9.0
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- a060753: New Data Table component
|
|
8
|
+
|
|
9
|
+
## 12.8.0
|
|
10
|
+
|
|
11
|
+
### Minor Changes
|
|
12
|
+
|
|
13
|
+
- 1534f03: Fixed product fruits newsfeed alignment. Fixed error for "no method hidePopover()".
|
|
14
|
+
- 0fa3302: added the HighlightSearch directive for highlighting search results
|
|
15
|
+
|
|
16
|
+
### Patch Changes
|
|
17
|
+
|
|
18
|
+
- eaa0e3d: fixed: events propagation for file inputs in modals
|
|
19
|
+
|
|
3
20
|
## 12.7.0
|
|
4
21
|
|
|
5
22
|
### Minor Changes
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class HighlightSearchDirective {
|
|
3
|
+
private readonly sanitizer;
|
|
4
|
+
protected highlightedText: import("@angular/core").Signal<import("@angular/platform-browser").SafeHtml>;
|
|
5
|
+
/**
|
|
6
|
+
* Search string
|
|
7
|
+
* @required
|
|
8
|
+
* @type string
|
|
9
|
+
*/
|
|
10
|
+
odxHighlightSearch: import("@angular/core").InputSignal<string>;
|
|
11
|
+
/**
|
|
12
|
+
* Text to highlight
|
|
13
|
+
* @required
|
|
14
|
+
* @type string
|
|
15
|
+
*/
|
|
16
|
+
text: import("@angular/core").InputSignal<string>;
|
|
17
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<HighlightSearchDirective, never>;
|
|
18
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<HighlightSearchDirective, "odx-highlight", never, { "odxHighlightSearch": { "alias": "odxHighlightSearch"; "required": true; "isSignal": true; }; "text": { "alias": "text"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
|
|
19
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './highlight-search-result.directive';
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Signal } from '@angular/core';
|
|
2
|
+
import { ColumnDef } from './directives';
|
|
3
|
+
import { TableVariant } from './models';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
/**
|
|
6
|
+
* DataTableComponent is a dynamic table structure built for displaying content.
|
|
7
|
+
*/
|
|
8
|
+
export declare class DataTableComponent<T = unknown> {
|
|
9
|
+
protected columnDefs: Signal<readonly ColumnDef[]>;
|
|
10
|
+
protected orderedColumns: Signal<readonly ColumnDef[]>;
|
|
11
|
+
/**
|
|
12
|
+
* The data to be displayed in the table.
|
|
13
|
+
* @required
|
|
14
|
+
* @type {T[]}
|
|
15
|
+
*/
|
|
16
|
+
dataSource: import("@angular/core").InputSignal<T[]>;
|
|
17
|
+
/**
|
|
18
|
+
* The columns to be displayed in the table.
|
|
19
|
+
* @required
|
|
20
|
+
* @type {string[]}
|
|
21
|
+
*/
|
|
22
|
+
displayedColumns: import("@angular/core").InputSignal<string[]>;
|
|
23
|
+
/**
|
|
24
|
+
* The variant of the table.
|
|
25
|
+
* @default TableVariant.DEFAULT
|
|
26
|
+
* @type {TableVariant}
|
|
27
|
+
*/
|
|
28
|
+
variant: import("@angular/core").InputSignal<TableVariant>;
|
|
29
|
+
protected get classList(): Signal<string>;
|
|
30
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DataTableComponent<any>, never>;
|
|
31
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DataTableComponent<any>, "table[odxDataTable]", never, { "dataSource": { "alias": "dataSource"; "required": true; "isSignal": true; }; "displayedColumns": { "alias": "displayedColumns"; "required": true; "isSignal": true; }; "variant": { "alias": "variant"; "required": false; "isSignal": true; }; }, {}, ["columnDefs"], ["odx-table-empty"], true, never>;
|
|
32
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./data-table.component";
|
|
3
|
+
import * as i2 from "./directives/cell-def.directive";
|
|
4
|
+
import * as i3 from "./directives/column-def.directive";
|
|
5
|
+
import * as i4 from "./directives/header-cell-def.directive";
|
|
6
|
+
import * as i5 from "./directives/table-empty.directive";
|
|
7
|
+
import * as i6 from "./directives/cell.directive";
|
|
8
|
+
import * as i7 from "./directives/header-cell.directive";
|
|
9
|
+
import * as i8 from "@odx/angular";
|
|
10
|
+
export declare class DataTableModule {
|
|
11
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DataTableModule, never>;
|
|
12
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<DataTableModule, never, [typeof i1.DataTableComponent, typeof i2.CellDef, typeof i3.ColumnDef, typeof i4.HeaderCellDef, typeof i5.TableEmptyDirective, typeof i6.CellDirective, typeof i7.HeaderCellDirective], [typeof i8.CoreModule, typeof i1.DataTableComponent, typeof i2.CellDef, typeof i3.ColumnDef, typeof i4.HeaderCellDef, typeof i5.TableEmptyDirective, typeof i6.CellDirective, typeof i7.HeaderCellDirective]>;
|
|
13
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<DataTableModule>;
|
|
14
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { TemplateRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class CellDef {
|
|
4
|
+
template: TemplateRef<any>;
|
|
5
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CellDef, never>;
|
|
6
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<CellDef, "[odxCellDef]", never, {}, {}, never, never, true, never>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { TemplateRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class ColumnDef {
|
|
4
|
+
private readonly headerCellDef;
|
|
5
|
+
private readonly cellDef;
|
|
6
|
+
name: import("@angular/core").InputSignal<string>;
|
|
7
|
+
getHeaderTemplate(): TemplateRef<unknown> | null;
|
|
8
|
+
getCellTemplate(): TemplateRef<unknown> | null;
|
|
9
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ColumnDef, never>;
|
|
10
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<ColumnDef, "[odxColumnDef]", never, { "name": { "alias": "odxColumnDef"; "required": true; "isSignal": true; }; }, {}, ["headerCellDef", "cellDef"], never, true, never>;
|
|
11
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { TemplateRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class HeaderCellDef {
|
|
4
|
+
template: TemplateRef<any>;
|
|
5
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<HeaderCellDef, never>;
|
|
6
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<HeaderCellDef, "[odxHeaderCellDef]", never, {}, {}, never, never, true, never>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class HeaderCellDirective {
|
|
3
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<HeaderCellDirective, never>;
|
|
4
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<HeaderCellDirective, "th[odxHeaderCell]", never, {}, {}, never, never, true, never>;
|
|
5
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class TableEmptyDirective {
|
|
3
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TableEmptyDirective, never>;
|
|
4
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TableEmptyDirective, "odx-table-empty", never, {}, {}, never, never, true, never>;
|
|
5
|
+
}
|
|
@@ -60,7 +60,6 @@ export declare class MainMenuComponent implements AfterViewInit {
|
|
|
60
60
|
*/
|
|
61
61
|
close(): void;
|
|
62
62
|
private slideMenuInner;
|
|
63
|
-
private isPopoverElement;
|
|
64
63
|
static ɵfac: i0.ɵɵFactoryDeclaration<MainMenuComponent, never>;
|
|
65
64
|
static ɵcmp: i0.ɵɵComponentDeclaration<MainMenuComponent, "odx-main-menu", never, { "title": { "alias": "title"; "required": true; }; "subtitle": { "alias": "subtitle"; "required": false; }; "copyright": { "alias": "copyright"; "required": false; }; "isOpen": { "alias": "isOpen"; "required": false; }; }, { "menuOpen": "menuOpen"; }, never, ["*", "[odxLink]"], true, never>;
|
|
66
65
|
static ngAcceptInputType_isOpen: unknown;
|
|
@@ -42,7 +42,7 @@ export declare class ModalComponent implements OnChanges {
|
|
|
42
42
|
constructor();
|
|
43
43
|
ngOnChanges(changes: NgChanges<ModalComponent>): void;
|
|
44
44
|
protected preventNativeDismiss(event: KeyboardEvent): void;
|
|
45
|
-
protected handleDialogClose(): void;
|
|
45
|
+
protected handleDialogClose({ target }: KeyboardEvent): void;
|
|
46
46
|
static ɵfac: i0.ɵɵFactoryDeclaration<ModalComponent, never>;
|
|
47
47
|
static ɵcmp: i0.ɵɵComponentDeclaration<ModalComponent, "dialog[odx-dialog-modal]", never, { "content": { "alias": "content"; "required": false; }; }, {}, never, never, true, never>;
|
|
48
48
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { OnInit } from '@angular/core';
|
|
2
2
|
import { FormControl, FormGroup } from '@angular/forms';
|
|
3
|
-
import {
|
|
3
|
+
import { SortStatus, TableHeaderCell } from '../../models';
|
|
4
4
|
import { TableSortVariant } from '../../models/sort-variant';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
/**
|
|
@@ -66,7 +66,7 @@ export declare class HeaderTitleComponent implements OnInit {
|
|
|
66
66
|
ngOnInit(): void;
|
|
67
67
|
private checkBoxListener;
|
|
68
68
|
get indeterminate(): boolean;
|
|
69
|
-
protected get columnWidth():
|
|
69
|
+
protected get columnWidth(): string;
|
|
70
70
|
static ɵfac: i0.ɵɵFactoryDeclaration<HeaderTitleComponent, never>;
|
|
71
71
|
static ɵcmp: i0.ɵɵComponentDeclaration<HeaderTitleComponent, "th[odxHeaderTitle]", never, { "item": { "alias": "item"; "required": false; }; }, {}, never, ["odx-form-field"], true, never>;
|
|
72
72
|
}
|
|
@@ -15,7 +15,6 @@ import * as i0 from "@angular/core";
|
|
|
15
15
|
*/
|
|
16
16
|
export declare class TableComponent<T> implements OnInit {
|
|
17
17
|
private readonly takeUntilDestroyed;
|
|
18
|
-
protected headerColumns: import("@angular/core").Signal<TableHeaderCell[]>;
|
|
19
18
|
readonly element: import("@angular/core").ElementRef<HTMLElement>;
|
|
20
19
|
/**
|
|
21
20
|
* Specifies the table variant for CSS styling.
|
|
@@ -36,7 +35,8 @@ export declare class TableComponent<T> implements OnInit {
|
|
|
36
35
|
*/
|
|
37
36
|
noDataMessage: import("@angular/core").InputSignal<string>;
|
|
38
37
|
/**
|
|
39
|
-
* Configuration for table
|
|
38
|
+
* Configuration for table headers that controls behavior such as sorting, filtering, checkbox display, and width.
|
|
39
|
+
* Should be in the same order as the columns in the template.
|
|
40
40
|
*
|
|
41
41
|
* @type {Signal<TableHeaderCell[]>}
|
|
42
42
|
*/
|
|
@@ -81,5 +81,5 @@ export declare class TableComponent<T> implements OnInit {
|
|
|
81
81
|
clearSort(): void;
|
|
82
82
|
private formListener;
|
|
83
83
|
static ɵfac: i0.ɵɵFactoryDeclaration<TableComponent<any>, never>;
|
|
84
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TableComponent<any>, "table[odxTable]", never, { "variant": { "alias": "variant"; "required": false; }; "data": { "alias": "data"; "required": true; "isSignal": true; }; "noDataMessage": { "alias": "noDataMessage"; "required": false; "isSignal": true; }; "headerData": { "alias": "headerData"; "required":
|
|
84
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TableComponent<any>, "table[odxTable]", never, { "variant": { "alias": "variant"; "required": false; }; "data": { "alias": "data"; "required": true; "isSignal": true; }; "noDataMessage": { "alias": "noDataMessage"; "required": false; "isSignal": true; }; "headerData": { "alias": "headerData"; "required": true; "isSignal": true; }; }, { "sorted": "sorted"; "filtered": "filtered"; "checked": "checked"; }, never, ["tr"], true, never>;
|
|
85
85
|
}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
export * from './lib/autocomplete-control';
|
|
2
|
+
export * from './lib/directives';
|
|
2
3
|
export * from './lib/pipes';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY2RrL2F1dG9jb21wbGV0ZS1jb250cm9sL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9hdXRvY29tcGxldGUtY29udHJvbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BpcGVzJztcbiJdfQ==
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { computed, Directive, inject, input, SecurityContext } from '@angular/core';
|
|
2
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class HighlightSearchDirective {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.sanitizer = inject(DomSanitizer);
|
|
7
|
+
this.highlightedText = computed(() => {
|
|
8
|
+
const search = this.odxHighlightSearch().trim();
|
|
9
|
+
const text = this.sanitizer.sanitize(SecurityContext.HTML, this.text()) ?? '';
|
|
10
|
+
if (!search) {
|
|
11
|
+
return text;
|
|
12
|
+
}
|
|
13
|
+
const regex = new RegExp(search.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'), 'gi');
|
|
14
|
+
const highlightedText = text.replace(regex, '<mark>$&</mark>');
|
|
15
|
+
return this.sanitizer.bypassSecurityTrustHtml(highlightedText);
|
|
16
|
+
});
|
|
17
|
+
/**
|
|
18
|
+
* Search string
|
|
19
|
+
* @required
|
|
20
|
+
* @type string
|
|
21
|
+
*/
|
|
22
|
+
this.odxHighlightSearch = input.required();
|
|
23
|
+
/**
|
|
24
|
+
* Text to highlight
|
|
25
|
+
* @required
|
|
26
|
+
* @type string
|
|
27
|
+
*/
|
|
28
|
+
this.text = input.required();
|
|
29
|
+
}
|
|
30
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: HighlightSearchDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
31
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: HighlightSearchDirective, isStandalone: true, selector: "odx-highlight", inputs: { odxHighlightSearch: { classPropertyName: "odxHighlightSearch", publicName: "odxHighlightSearch", isSignal: true, isRequired: true, transformFunction: null }, text: { classPropertyName: "text", publicName: "text", isSignal: true, isRequired: true, transformFunction: null } }, host: { properties: { "innerHTML": "highlightedText()" } }, ngImport: i0 }); }
|
|
32
|
+
}
|
|
33
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: HighlightSearchDirective, decorators: [{
|
|
34
|
+
type: Directive,
|
|
35
|
+
args: [{
|
|
36
|
+
selector: 'odx-highlight',
|
|
37
|
+
standalone: true,
|
|
38
|
+
host: {
|
|
39
|
+
'[innerHTML]': 'highlightedText()',
|
|
40
|
+
},
|
|
41
|
+
}]
|
|
42
|
+
}] });
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGlnaGxpZ2h0LXNlYXJjaC1yZXN1bHQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2Nkay9hdXRvY29tcGxldGUtY29udHJvbC9zcmMvbGliL2RpcmVjdGl2ZXMvaGlnaGxpZ2h0LXNlYXJjaC1yZXN1bHQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsZUFBZSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQzs7QUFTekQsTUFBTSxPQUFPLHdCQUF3QjtJQVByQztRQVFtQixjQUFTLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBRXhDLG9CQUFlLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUN4QyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNoRCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUU5RSxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7Z0JBQ1osT0FBTyxJQUFJLENBQUM7WUFDZCxDQUFDO1lBRUQsTUFBTSxLQUFLLEdBQUcsSUFBSSxNQUFNLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxxQkFBcUIsRUFBRSxNQUFNLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztZQUM5RSxNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1lBRS9ELE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyx1QkFBdUIsQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUNqRSxDQUFDLENBQUMsQ0FBQztRQUVIOzs7O1dBSUc7UUFDSSx1QkFBa0IsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFVLENBQUM7UUFFckQ7Ozs7V0FJRztRQUNJLFNBQUksR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFVLENBQUM7S0FDeEM7K0dBOUJZLHdCQUF3QjttR0FBeEIsd0JBQXdCOzs0RkFBeEIsd0JBQXdCO2tCQVBwQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxlQUFlO29CQUN6QixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsSUFBSSxFQUFFO3dCQUNKLGFBQWEsRUFBRSxtQkFBbUI7cUJBQ25DO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY29tcHV0ZWQsIERpcmVjdGl2ZSwgaW5qZWN0LCBpbnB1dCwgU2VjdXJpdHlDb250ZXh0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEb21TYW5pdGl6ZXIgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnb2R4LWhpZ2hsaWdodCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGhvc3Q6IHtcbiAgICAnW2lubmVySFRNTF0nOiAnaGlnaGxpZ2h0ZWRUZXh0KCknLFxuICB9LFxufSlcbmV4cG9ydCBjbGFzcyBIaWdobGlnaHRTZWFyY2hEaXJlY3RpdmUge1xuICBwcml2YXRlIHJlYWRvbmx5IHNhbml0aXplciA9IGluamVjdChEb21TYW5pdGl6ZXIpO1xuXG4gIHByb3RlY3RlZCBoaWdobGlnaHRlZFRleHQgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgY29uc3Qgc2VhcmNoID0gdGhpcy5vZHhIaWdobGlnaHRTZWFyY2goKS50cmltKCk7XG4gICAgY29uc3QgdGV4dCA9IHRoaXMuc2FuaXRpemVyLnNhbml0aXplKFNlY3VyaXR5Q29udGV4dC5IVE1MLCB0aGlzLnRleHQoKSkgPz8gJyc7XG5cbiAgICBpZiAoIXNlYXJjaCkge1xuICAgICAgcmV0dXJuIHRleHQ7XG4gICAgfVxuXG4gICAgY29uc3QgcmVnZXggPSBuZXcgUmVnRXhwKHNlYXJjaC5yZXBsYWNlKC9bLiorP14ke30oKXxbXFxdXFxcXF0vZywgJ1xcXFwkJicpLCAnZ2knKTtcbiAgICBjb25zdCBoaWdobGlnaHRlZFRleHQgPSB0ZXh0LnJlcGxhY2UocmVnZXgsICc8bWFyaz4kJjwvbWFyaz4nKTtcblxuICAgIHJldHVybiB0aGlzLnNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0SHRtbChoaWdobGlnaHRlZFRleHQpO1xuICB9KTtcblxuICAvKipcbiAgICogU2VhcmNoIHN0cmluZ1xuICAgKiBAcmVxdWlyZWRcbiAgICogQHR5cGUgc3RyaW5nXG4gICAqL1xuICBwdWJsaWMgb2R4SGlnaGxpZ2h0U2VhcmNoID0gaW5wdXQucmVxdWlyZWQ8c3RyaW5nPigpO1xuXG4gIC8qKlxuICAgKiBUZXh0IHRvIGhpZ2hsaWdodFxuICAgKiBAcmVxdWlyZWRcbiAgICogQHR5cGUgc3RyaW5nXG4gICAqL1xuICBwdWJsaWMgdGV4dCA9IGlucHV0LnJlcXVpcmVkPHN0cmluZz4oKTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './highlight-search-result.directive';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY2RrL2F1dG9jb21wbGV0ZS1jb250cm9sL3NyYy9saWIvZGlyZWN0aXZlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHFDQUFxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9oaWdobGlnaHQtc2VhcmNoLXJlc3VsdC5kaXJlY3RpdmUnO1xuIl19
|
|
@@ -21,7 +21,7 @@ let ConnectedOverlayComponent = class ConnectedOverlayComponent {
|
|
|
21
21
|
ngOnInit() {
|
|
22
22
|
this.options.hooks?.beforeOpen?.();
|
|
23
23
|
deferFn(() => {
|
|
24
|
-
this.element.nativeElement?.showPopover?.();
|
|
24
|
+
this.element.nativeElement?.isConnected && this.element.nativeElement?.showPopover?.();
|
|
25
25
|
this.options.hooks?.afterOpen?.();
|
|
26
26
|
});
|
|
27
27
|
}
|
|
@@ -80,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
80
80
|
}], closed: [{
|
|
81
81
|
type: Output
|
|
82
82
|
}] } });
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connected-overlay.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/cdk/connected-overlay/src/lib/connected-overlay.component.ts","../../../../../../../libs/angular/cdk/connected-overlay/src/lib/connected-overlay.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Injector,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n  inject,\n} from '@angular/core';\nimport { VirtualElement, autoUpdate } from '@floating-ui/dom';\nimport { CoreModule } from '@odx/angular';\nimport { DynamicViewDirective } from '@odx/angular/cdk/dynamic-view';\nimport { CSSComponent } from '@odx/angular/internal';\nimport { NgChanges, Side, deferFn, getSide, hasChanged, injectElement, isPresent } from '@odx/angular/utils';\nimport { Subject } from 'rxjs';\nimport { computeOverlayPosition } from './helpers';\nimport { ConnectedOverlayOptions, DefaultConnectedOverlayOptions } from './models';\n\n@CSSComponent('cdk-connected-overlay')\n@Component({\n  standalone: true,\n  selector: 'odx-connected-overlay[popover=\"manual\"]',\n  imports: [CoreModule, DynamicViewDirective],\n  templateUrl: 'connected-overlay.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class ConnectedOverlayComponent implements OnInit, OnChanges, OnDestroy {\n  private readonly zone = inject(NgZone);\n  private positionUpdater: (() => void) | null = null;\n\n  protected readonly injector = inject(Injector);\n  protected overlaySide?: Side;\n\n  @ViewChild('content', { static: true })\n  protected contentElement!: ElementRef<HTMLElement>;\n\n  @ViewChild('arrow', { static: true })\n  protected arrowElement!: ElementRef<HTMLElement>;\n\n  public readonly element = injectElement();\n\n  @Input()\n  public referenceElement!: VirtualElement;\n\n  @Input()\n  public options: ConnectedOverlayOptions = DefaultConnectedOverlayOptions;\n\n  @Output()\n  public closed = new Subject<void>();\n\n  public ngOnInit(): void {\n    this.options.hooks?.beforeOpen?.();\n    deferFn(() => {\n      this.element.nativeElement?.isConnected && this.element.nativeElement?.showPopover?.();\n      this.options.hooks?.afterOpen?.();\n    });\n  }\n\n  public ngOnChanges(changes: NgChanges<ConnectedOverlayComponent>): void {\n    if (hasChanged(changes, ['options'], false)) {\n      this.overlaySide = getSide(this.options.position);\n      this.element.nativeElement.classList.toggle('odx-cdk-connected-overlay--non-interactive', this.options.nonInteractive ?? false);\n    }\n    if (hasChanged(changes, ['referenceElement', 'options'], false)) {\n      this.stopPositionUpdater();\n      this.startPositionUpdater();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.options.hooks?.beforeClose?.();\n    this.stopPositionUpdater();\n    this.element.nativeElement?.hidePopover?.();\n    this.closed.next();\n    this.options.hooks?.afterClose?.();\n  }\n\n  private startPositionUpdater(): void {\n    this.positionUpdater = this.zone.runOutsideAngular(() =>\n      autoUpdate(this.referenceElement, this.element.nativeElement, () => this.updatePosition(), {\n        elementResize: isPresent(window.ResizeObserver),\n        animationFrame: this.options.updateOnAnimationFrame,\n      }),\n    );\n  }\n\n  private stopPositionUpdater(): void {\n    this.positionUpdater?.();\n    this.positionUpdater = null;\n  }\n\n  private async updatePosition(): Promise<void> {\n    return computeOverlayPosition(\n      this.referenceElement,\n      this.element.nativeElement,\n      this.contentElement.nativeElement,\n      this.arrowElement.nativeElement,\n      this.options,\n    ).then(({ placement }) => {\n      this.overlaySide = getSide(placement);\n    });\n  }\n}\n","<div class=\"odx-cdk-connected-overlay__content {{ options.containerClass }}\" #content>\n  <ng-template [odxDynamicView]=\"options.content\" [odxDynamicViewContext]=\"options.context\" [odxDynamicViewInjector]=\"injector\" />\n  <div class=\"odx-cdk-connected-overlay-arrow\" #arrow></div>\n</div>\n"]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export * from './lib/data-table.component';
|
|
2
|
+
export * from './lib/data-table.module';
|
|
3
|
+
export * from './lib/directives';
|
|
4
|
+
export * from './lib/models';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9kYXRhLXRhYmxlL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGEtdGFibGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGEtdGFibGUubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzJztcbiJdfQ==
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { NgTemplateOutlet } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, computed, contentChildren, input, ViewEncapsulation } from '@angular/core';
|
|
3
|
+
import { ColumnDef } from './directives';
|
|
4
|
+
import { TableVariant } from './models';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
/**
|
|
7
|
+
* DataTableComponent is a dynamic table structure built for displaying content.
|
|
8
|
+
*/
|
|
9
|
+
export class DataTableComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.columnDefs = contentChildren(ColumnDef, { descendants: true });
|
|
12
|
+
this.orderedColumns = computed(() => {
|
|
13
|
+
const cols = this.columnDefs() ?? [];
|
|
14
|
+
const displayedCols = this.displayedColumns() ?? [];
|
|
15
|
+
return displayedCols.length > 0
|
|
16
|
+
? displayedCols.map((colName) => cols.find((colDef) => colDef.name() === colName)).filter((colDef) => !!colDef)
|
|
17
|
+
: cols;
|
|
18
|
+
});
|
|
19
|
+
/**
|
|
20
|
+
* The data to be displayed in the table.
|
|
21
|
+
* @required
|
|
22
|
+
* @type {T[]}
|
|
23
|
+
*/
|
|
24
|
+
this.dataSource = input.required();
|
|
25
|
+
/**
|
|
26
|
+
* The columns to be displayed in the table.
|
|
27
|
+
* @required
|
|
28
|
+
* @type {string[]}
|
|
29
|
+
*/
|
|
30
|
+
this.displayedColumns = input.required();
|
|
31
|
+
/**
|
|
32
|
+
* The variant of the table.
|
|
33
|
+
* @default TableVariant.DEFAULT
|
|
34
|
+
* @type {TableVariant}
|
|
35
|
+
*/
|
|
36
|
+
this.variant = input(TableVariant.DEFAULT);
|
|
37
|
+
}
|
|
38
|
+
get classList() {
|
|
39
|
+
return computed(() => `odx-table odx-data-table odx-table--${this.variant()}`);
|
|
40
|
+
}
|
|
41
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
42
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DataTableComponent, isStandalone: true, selector: "table[odxDataTable]", inputs: { dataSource: { classPropertyName: "dataSource", publicName: "dataSource", isSignal: true, isRequired: true, transformFunction: null }, displayedColumns: { classPropertyName: "displayedColumns", publicName: "displayedColumns", isSignal: true, isRequired: true, transformFunction: null }, variant: { classPropertyName: "variant", publicName: "variant", isSignal: true, isRequired: false, transformFunction: null } }, host: { attributes: { "role": "table" }, properties: { "class": "classList()" } }, queries: [{ propertyName: "columnDefs", predicate: ColumnDef, descendants: true, isSignal: true }], ngImport: i0, template: "<thead role=\"rowgroup\" class=\"odx-table__head\">\n <tr role=\"row\" class=\"odx-table__header-row\">\n @for (col of orderedColumns(); track col.name) {\n <ng-container *ngTemplateOutlet=\"col.getHeaderTemplate()\" />\n }\n </tr>\n</thead>\n<tbody role=\"rowgroup\" class=\"odx-table__body\">\n @for (item of dataSource(); track item) {\n <tr class=\"odx-table__row\" role=\"row\">\n @for (col of orderedColumns(); track col.name) {\n <ng-container *ngTemplateOutlet=\"col.getCellTemplate(); context: { $implicit: item }\" />\n }\n </tr>\n } @empty {\n <tr class=\"odx-table__row\" role=\"row\">\n <td class=\"odx-table__cell\" role=\"cell\" [attr.colspan]=\"orderedColumns().length\">\n <ng-content select=\"odx-table-empty\" />\n </td>\n </tr>\n }\n</tbody>\n", dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
43
|
+
}
|
|
44
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataTableComponent, decorators: [{
|
|
45
|
+
type: Component,
|
|
46
|
+
args: [{ selector: 'table[odxDataTable]', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: {
|
|
47
|
+
role: 'table',
|
|
48
|
+
'[class]': 'classList()',
|
|
49
|
+
}, imports: [NgTemplateOutlet], template: "<thead role=\"rowgroup\" class=\"odx-table__head\">\n <tr role=\"row\" class=\"odx-table__header-row\">\n @for (col of orderedColumns(); track col.name) {\n <ng-container *ngTemplateOutlet=\"col.getHeaderTemplate()\" />\n }\n </tr>\n</thead>\n<tbody role=\"rowgroup\" class=\"odx-table__body\">\n @for (item of dataSource(); track item) {\n <tr class=\"odx-table__row\" role=\"row\">\n @for (col of orderedColumns(); track col.name) {\n <ng-container *ngTemplateOutlet=\"col.getCellTemplate(); context: { $implicit: item }\" />\n }\n </tr>\n } @empty {\n <tr class=\"odx-table__row\" role=\"row\">\n <td class=\"odx-table__cell\" role=\"cell\" [attr.colspan]=\"orderedColumns().length\">\n <ng-content select=\"odx-table-empty\" />\n </td>\n </tr>\n }\n</tbody>\n" }]
|
|
50
|
+
}] });
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10YWJsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9kYXRhLXRhYmxlL3NyYy9saWIvZGF0YS10YWJsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9kYXRhLXRhYmxlL3NyYy9saWIvZGF0YS10YWJsZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxlQUFlLEVBQUUsS0FBSyxFQUFVLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hJLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLFVBQVUsQ0FBQzs7QUFFeEM7O0dBRUc7QUFjSCxNQUFNLE9BQU8sa0JBQWtCO0lBYi9CO1FBY1ksZUFBVSxHQUFHLGVBQWUsQ0FBQyxTQUFTLEVBQUUsRUFBRSxXQUFXLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUUvRCxtQkFBYyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDdkMsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRSxJQUFJLEVBQUUsQ0FBQztZQUNyQyxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsSUFBSSxFQUFFLENBQUM7WUFFcEQsT0FBTyxhQUFhLENBQUMsTUFBTSxHQUFHLENBQUM7Z0JBQzdCLENBQUMsQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLEtBQUssT0FBTyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxNQUFNLEVBQXVCLEVBQUUsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDO2dCQUNwSSxDQUFDLENBQUMsSUFBSSxDQUFDO1FBQ1gsQ0FBQyxDQUFDLENBQUM7UUFFSDs7OztXQUlHO1FBQ0ksZUFBVSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQU8sQ0FBQztRQUUxQzs7OztXQUlHO1FBQ0kscUJBQWdCLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBWSxDQUFDO1FBRXJEOzs7O1dBSUc7UUFDSSxZQUFPLEdBQUcsS0FBSyxDQUFlLFlBQVksQ0FBQyxPQUFPLENBQUMsQ0FBQztLQUs1RDtJQUhDLElBQWMsU0FBUztRQUNyQixPQUFPLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyx1Q0FBdUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNqRixDQUFDOytHQW5DVSxrQkFBa0I7bUdBQWxCLGtCQUFrQixxbUJBQ1UsU0FBUyxnRUN0QmxELDJ6QkFzQkEsNENESFksZ0JBQWdCOzs0RkFFZixrQkFBa0I7a0JBYjlCLFNBQVM7K0JBRUUscUJBQXFCLGNBQ25CLElBQUksbUJBQ0MsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSxRQUMvQjt3QkFDSixJQUFJLEVBQUUsT0FBTzt3QkFDYixTQUFTLEVBQUUsYUFBYTtxQkFDekIsV0FFUSxDQUFDLGdCQUFnQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdUZW1wbGF0ZU91dGxldCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBjb21wdXRlZCwgY29udGVudENoaWxkcmVuLCBpbnB1dCwgU2lnbmFsLCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29sdW1uRGVmIH0gZnJvbSAnLi9kaXJlY3RpdmVzJztcbmltcG9ydCB7IFRhYmxlVmFyaWFudCB9IGZyb20gJy4vbW9kZWxzJztcblxuLyoqXG4gKiBEYXRhVGFibGVDb21wb25lbnQgaXMgYSBkeW5hbWljIHRhYmxlIHN0cnVjdHVyZSBidWlsdCBmb3IgZGlzcGxheWluZyBjb250ZW50LlxuICovXG5AQ29tcG9uZW50KHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBhbmd1bGFyLWVzbGludC9jb21wb25lbnQtc2VsZWN0b3JcbiAgc2VsZWN0b3I6ICd0YWJsZVtvZHhEYXRhVGFibGVdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGhvc3Q6IHtcbiAgICByb2xlOiAndGFibGUnLFxuICAgICdbY2xhc3NdJzogJ2NsYXNzTGlzdCgpJyxcbiAgfSxcbiAgdGVtcGxhdGVVcmw6ICcuL2RhdGEtdGFibGUuY29tcG9uZW50Lmh0bWwnLFxuICBpbXBvcnRzOiBbTmdUZW1wbGF0ZU91dGxldF0sXG59KVxuZXhwb3J0IGNsYXNzIERhdGFUYWJsZUNvbXBvbmVudDxUID0gdW5rbm93bj4ge1xuICBwcm90ZWN0ZWQgY29sdW1uRGVmcyA9IGNvbnRlbnRDaGlsZHJlbihDb2x1bW5EZWYsIHsgZGVzY2VuZGFudHM6IHRydWUgfSk7XG5cbiAgcHJvdGVjdGVkIG9yZGVyZWRDb2x1bW5zID0gY29tcHV0ZWQoKCkgPT4ge1xuICAgIGNvbnN0IGNvbHMgPSB0aGlzLmNvbHVtbkRlZnMoKSA/PyBbXTtcbiAgICBjb25zdCBkaXNwbGF5ZWRDb2xzID0gdGhpcy5kaXNwbGF5ZWRDb2x1bW5zKCkgPz8gW107XG5cbiAgICByZXR1cm4gZGlzcGxheWVkQ29scy5sZW5ndGggPiAwXG4gICAgICA/IGRpc3BsYXllZENvbHMubWFwKChjb2xOYW1lKSA9PiBjb2xzLmZpbmQoKGNvbERlZikgPT4gY29sRGVmLm5hbWUoKSA9PT0gY29sTmFtZSkpLmZpbHRlcigoY29sRGVmKTogY29sRGVmIGlzIENvbHVtbkRlZiA9PiAhIWNvbERlZilcbiAgICAgIDogY29scztcbiAgfSk7XG5cbiAgLyoqXG4gICAqIFRoZSBkYXRhIHRvIGJlIGRpc3BsYXllZCBpbiB0aGUgdGFibGUuXG4gICAqIEByZXF1aXJlZFxuICAgKiBAdHlwZSB7VFtdfVxuICAgKi9cbiAgcHVibGljIGRhdGFTb3VyY2UgPSBpbnB1dC5yZXF1aXJlZDxUW10+KCk7XG5cbiAgLyoqXG4gICAqIFRoZSBjb2x1bW5zIHRvIGJlIGRpc3BsYXllZCBpbiB0aGUgdGFibGUuXG4gICAqIEByZXF1aXJlZFxuICAgKiBAdHlwZSB7c3RyaW5nW119XG4gICAqL1xuICBwdWJsaWMgZGlzcGxheWVkQ29sdW1ucyA9IGlucHV0LnJlcXVpcmVkPHN0cmluZ1tdPigpO1xuXG4gIC8qKlxuICAgKiBUaGUgdmFyaWFudCBvZiB0aGUgdGFibGUuXG4gICAqIEBkZWZhdWx0IFRhYmxlVmFyaWFudC5ERUZBVUxUXG4gICAqIEB0eXBlIHtUYWJsZVZhcmlhbnR9XG4gICAqL1xuICBwdWJsaWMgdmFyaWFudCA9IGlucHV0PFRhYmxlVmFyaWFudD4oVGFibGVWYXJpYW50LkRFRkFVTFQpO1xuXG4gIHByb3RlY3RlZCBnZXQgY2xhc3NMaXN0KCk6IFNpZ25hbDxzdHJpbmc+IHtcbiAgICByZXR1cm4gY29tcHV0ZWQoKCkgPT4gYG9keC10YWJsZSBvZHgtZGF0YS10YWJsZSBvZHgtdGFibGUtLSR7dGhpcy52YXJpYW50KCl9YCk7XG4gIH1cbn1cbiIsIjx0aGVhZCByb2xlPVwicm93Z3JvdXBcIiBjbGFzcz1cIm9keC10YWJsZV9faGVhZFwiPlxuICA8dHIgcm9sZT1cInJvd1wiIGNsYXNzPVwib2R4LXRhYmxlX19oZWFkZXItcm93XCI+XG4gICAgQGZvciAoY29sIG9mIG9yZGVyZWRDb2x1bW5zKCk7IHRyYWNrIGNvbC5uYW1lKSB7XG4gICAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiY29sLmdldEhlYWRlclRlbXBsYXRlKClcIiAvPlxuICAgIH1cbiAgPC90cj5cbjwvdGhlYWQ+XG48dGJvZHkgcm9sZT1cInJvd2dyb3VwXCIgY2xhc3M9XCJvZHgtdGFibGVfX2JvZHlcIj5cbiAgQGZvciAoaXRlbSBvZiBkYXRhU291cmNlKCk7IHRyYWNrIGl0ZW0pIHtcbiAgICA8dHIgY2xhc3M9XCJvZHgtdGFibGVfX3Jvd1wiIHJvbGU9XCJyb3dcIj5cbiAgICAgIEBmb3IgKGNvbCBvZiBvcmRlcmVkQ29sdW1ucygpOyB0cmFjayBjb2wubmFtZSkge1xuICAgICAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiY29sLmdldENlbGxUZW1wbGF0ZSgpOyBjb250ZXh0OiB7ICRpbXBsaWNpdDogaXRlbSB9XCIgLz5cbiAgICAgIH1cbiAgICA8L3RyPlxuICB9IEBlbXB0eSB7XG4gICAgPHRyIGNsYXNzPVwib2R4LXRhYmxlX19yb3dcIiByb2xlPVwicm93XCI+XG4gICAgICA8dGQgY2xhc3M9XCJvZHgtdGFibGVfX2NlbGxcIiByb2xlPVwiY2VsbFwiIFthdHRyLmNvbHNwYW5dPVwib3JkZXJlZENvbHVtbnMoKS5sZW5ndGhcIj5cbiAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwib2R4LXRhYmxlLWVtcHR5XCIgLz5cbiAgICAgIDwvdGQ+XG4gICAgPC90cj5cbiAgfVxuPC90Ym9keT5cbiJdfQ==
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CoreModule } from '@odx/angular';
|
|
3
|
+
import { DataTableComponent } from './data-table.component';
|
|
4
|
+
import { CellDef, CellDirective, ColumnDef, HeaderCellDef, HeaderCellDirective, TableEmptyDirective } from './directives';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
const modules = [DataTableComponent, CellDef, ColumnDef, HeaderCellDef, TableEmptyDirective, CellDirective, HeaderCellDirective];
|
|
7
|
+
export class DataTableModule {
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataTableModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
9
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: DataTableModule, imports: [DataTableComponent, CellDef, ColumnDef, HeaderCellDef, TableEmptyDirective, CellDirective, HeaderCellDirective], exports: [CoreModule, DataTableComponent, CellDef, ColumnDef, HeaderCellDef, TableEmptyDirective, CellDirective, HeaderCellDirective] }); }
|
|
10
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataTableModule, imports: [CoreModule] }); }
|
|
11
|
+
}
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DataTableModule, decorators: [{
|
|
13
|
+
type: NgModule,
|
|
14
|
+
args: [{
|
|
15
|
+
imports: modules,
|
|
16
|
+
exports: [CoreModule, ...modules],
|
|
17
|
+
}]
|
|
18
|
+
}] });
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10YWJsZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9kYXRhLXRhYmxlL3NyYy9saWIvZGF0YS10YWJsZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQzFDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVELE9BQU8sRUFBRSxPQUFPLEVBQUUsYUFBYSxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsbUJBQW1CLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxjQUFjLENBQUM7O0FBRTFILE1BQU0sT0FBTyxHQUFHLENBQUMsa0JBQWtCLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsbUJBQW1CLEVBQUUsYUFBYSxFQUFFLG1CQUFtQixDQUFDLENBQUM7QUFNakksTUFBTSxPQUFPLGVBQWU7K0dBQWYsZUFBZTtnSEFBZixlQUFlLFlBTlgsa0JBQWtCLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsbUJBQW1CLEVBQUUsYUFBYSxFQUFFLG1CQUFtQixhQUluSCxVQUFVLEVBSkwsa0JBQWtCLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsbUJBQW1CLEVBQUUsYUFBYSxFQUFFLG1CQUFtQjtnSEFNbEgsZUFBZSxZQUZoQixVQUFVOzs0RkFFVCxlQUFlO2tCQUozQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxPQUFPO29CQUNoQixPQUFPLEVBQUUsQ0FBQyxVQUFVLEVBQUUsR0FBRyxPQUFPLENBQUM7aUJBQ2xDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvcmVNb2R1bGUgfSBmcm9tICdAb2R4L2FuZ3VsYXInO1xuaW1wb3J0IHsgRGF0YVRhYmxlQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRhLXRhYmxlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDZWxsRGVmLCBDZWxsRGlyZWN0aXZlLCBDb2x1bW5EZWYsIEhlYWRlckNlbGxEZWYsIEhlYWRlckNlbGxEaXJlY3RpdmUsIFRhYmxlRW1wdHlEaXJlY3RpdmUgfSBmcm9tICcuL2RpcmVjdGl2ZXMnO1xuXG5jb25zdCBtb2R1bGVzID0gW0RhdGFUYWJsZUNvbXBvbmVudCwgQ2VsbERlZiwgQ29sdW1uRGVmLCBIZWFkZXJDZWxsRGVmLCBUYWJsZUVtcHR5RGlyZWN0aXZlLCBDZWxsRGlyZWN0aXZlLCBIZWFkZXJDZWxsRGlyZWN0aXZlXTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogbW9kdWxlcyxcbiAgZXhwb3J0czogW0NvcmVNb2R1bGUsIC4uLm1vZHVsZXNdLFxufSlcbmV4cG9ydCBjbGFzcyBEYXRhVGFibGVNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Directive, inject, TemplateRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class CellDef {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.template = inject(TemplateRef);
|
|
6
|
+
}
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CellDef, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
8
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: CellDef, isStandalone: true, selector: "[odxCellDef]", ngImport: i0 }); }
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CellDef, decorators: [{
|
|
11
|
+
type: Directive,
|
|
12
|
+
args: [{
|
|
13
|
+
selector: '[odxCellDef]',
|
|
14
|
+
standalone: true,
|
|
15
|
+
}]
|
|
16
|
+
}] });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbC1kZWYuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2NvbXBvbmVudHMvZGF0YS10YWJsZS9zcmMvbGliL2RpcmVjdGl2ZXMvY2VsbC1kZWYuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFNL0QsTUFBTSxPQUFPLE9BQU87SUFKcEI7UUFLUyxhQUFRLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0tBQ3ZDOytHQUZZLE9BQU87bUdBQVAsT0FBTzs7NEZBQVAsT0FBTztrQkFKbkIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsY0FBYztvQkFDeEIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBpbmplY3QsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tvZHhDZWxsRGVmXScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIENlbGxEZWYge1xuICBwdWJsaWMgdGVtcGxhdGUgPSBpbmplY3QoVGVtcGxhdGVSZWYpO1xufVxuIl19
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Directive } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class CellDirective {
|
|
4
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CellDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
5
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: CellDirective, isStandalone: true, selector: "td[odxCell]", host: { attributes: { "role": "cell" }, classAttribute: "odx-table__cell" }, ngImport: i0 }); }
|
|
6
|
+
}
|
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CellDirective, decorators: [{
|
|
8
|
+
type: Directive,
|
|
9
|
+
args: [{
|
|
10
|
+
selector: 'td[odxCell]',
|
|
11
|
+
standalone: true,
|
|
12
|
+
host: {
|
|
13
|
+
role: 'cell',
|
|
14
|
+
class: 'odx-table__cell',
|
|
15
|
+
},
|
|
16
|
+
}]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9kYXRhLXRhYmxlL3NyYy9saWIvZGlyZWN0aXZlcy9jZWxsLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVUxQyxNQUFNLE9BQU8sYUFBYTsrR0FBYixhQUFhO21HQUFiLGFBQWE7OzRGQUFiLGFBQWE7a0JBUnpCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGFBQWE7b0JBQ3ZCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixJQUFJLEVBQUU7d0JBQ0osSUFBSSxFQUFFLE1BQU07d0JBQ1osS0FBSyxFQUFFLGlCQUFpQjtxQkFDekI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAndGRbb2R4Q2VsbF0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBob3N0OiB7XG4gICAgcm9sZTogJ2NlbGwnLFxuICAgIGNsYXNzOiAnb2R4LXRhYmxlX19jZWxsJyxcbiAgfSxcbn0pXG5leHBvcnQgY2xhc3MgQ2VsbERpcmVjdGl2ZSB7fVxuIl19
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { contentChild, Directive, input } from '@angular/core';
|
|
2
|
+
import { CellDef } from './cell-def.directive';
|
|
3
|
+
import { HeaderCellDef } from './header-cell-def.directive';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class ColumnDef {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.headerCellDef = contentChild.required(HeaderCellDef);
|
|
8
|
+
this.cellDef = contentChild.required(CellDef);
|
|
9
|
+
this.name = input.required({ alias: 'odxColumnDef' });
|
|
10
|
+
}
|
|
11
|
+
getHeaderTemplate() {
|
|
12
|
+
return this.headerCellDef().template ?? null;
|
|
13
|
+
}
|
|
14
|
+
getCellTemplate() {
|
|
15
|
+
return this.cellDef().template ?? null;
|
|
16
|
+
}
|
|
17
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ColumnDef, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
18
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.2.0", version: "18.2.13", type: ColumnDef, isStandalone: true, selector: "[odxColumnDef]", inputs: { name: { classPropertyName: "name", publicName: "odxColumnDef", isSignal: true, isRequired: true, transformFunction: null } }, queries: [{ propertyName: "headerCellDef", first: true, predicate: HeaderCellDef, descendants: true, isSignal: true }, { propertyName: "cellDef", first: true, predicate: CellDef, descendants: true, isSignal: true }], ngImport: i0 }); }
|
|
19
|
+
}
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ColumnDef, decorators: [{
|
|
21
|
+
type: Directive,
|
|
22
|
+
args: [{
|
|
23
|
+
selector: '[odxColumnDef]',
|
|
24
|
+
standalone: true,
|
|
25
|
+
}]
|
|
26
|
+
}] });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sdW1uLWRlZi5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9kYXRhLXRhYmxlL3NyYy9saWIvZGlyZWN0aXZlcy9jb2x1bW4tZGVmLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQWUsTUFBTSxlQUFlLENBQUM7QUFDNUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQzs7QUFNNUQsTUFBTSxPQUFPLFNBQVM7SUFKdEI7UUFLbUIsa0JBQWEsR0FBRyxZQUFZLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ3JELFlBQU8sR0FBRyxZQUFZLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRW5ELFNBQUksR0FBRyxLQUFLLENBQUMsUUFBUSxDQUFTLEVBQUUsS0FBSyxFQUFFLGNBQWMsRUFBRSxDQUFDLENBQUM7S0FTakU7SUFQUSxpQkFBaUI7UUFDdEIsT0FBTyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQztJQUMvQyxDQUFDO0lBRU0sZUFBZTtRQUNwQixPQUFPLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDO0lBQ3pDLENBQUM7K0dBWlUsU0FBUzttR0FBVCxTQUFTLDZQQUNtQyxhQUFhLDBGQUNuQixPQUFPOzs0RkFGN0MsU0FBUztrQkFKckIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsZ0JBQWdCO29CQUMxQixVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjb250ZW50Q2hpbGQsIERpcmVjdGl2ZSwgaW5wdXQsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDZWxsRGVmIH0gZnJvbSAnLi9jZWxsLWRlZi5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgSGVhZGVyQ2VsbERlZiB9IGZyb20gJy4vaGVhZGVyLWNlbGwtZGVmLmRpcmVjdGl2ZSc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tvZHhDb2x1bW5EZWZdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgQ29sdW1uRGVmIHtcbiAgcHJpdmF0ZSByZWFkb25seSBoZWFkZXJDZWxsRGVmID0gY29udGVudENoaWxkLnJlcXVpcmVkKEhlYWRlckNlbGxEZWYpO1xuICBwcml2YXRlIHJlYWRvbmx5IGNlbGxEZWYgPSBjb250ZW50Q2hpbGQucmVxdWlyZWQoQ2VsbERlZik7XG5cbiAgcHVibGljIG5hbWUgPSBpbnB1dC5yZXF1aXJlZDxzdHJpbmc+KHsgYWxpYXM6ICdvZHhDb2x1bW5EZWYnIH0pO1xuXG4gIHB1YmxpYyBnZXRIZWFkZXJUZW1wbGF0ZSgpOiBUZW1wbGF0ZVJlZjx1bmtub3duPiB8IG51bGwge1xuICAgIHJldHVybiB0aGlzLmhlYWRlckNlbGxEZWYoKS50ZW1wbGF0ZSA/PyBudWxsO1xuICB9XG5cbiAgcHVibGljIGdldENlbGxUZW1wbGF0ZSgpOiBUZW1wbGF0ZVJlZjx1bmtub3duPiB8IG51bGwge1xuICAgIHJldHVybiB0aGlzLmNlbGxEZWYoKS50ZW1wbGF0ZSA/PyBudWxsO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Directive, inject, TemplateRef } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class HeaderCellDef {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.template = inject(TemplateRef);
|
|
6
|
+
}
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: HeaderCellDef, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
8
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: HeaderCellDef, isStandalone: true, selector: "[odxHeaderCellDef]", ngImport: i0 }); }
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: HeaderCellDef, decorators: [{
|
|
11
|
+
type: Directive,
|
|
12
|
+
args: [{
|
|
13
|
+
selector: '[odxHeaderCellDef]',
|
|
14
|
+
standalone: true,
|
|
15
|
+
}]
|
|
16
|
+
}] });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLWNlbGwtZGVmLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9jb21wb25lbnRzL2RhdGEtdGFibGUvc3JjL2xpYi9kaXJlY3RpdmVzL2hlYWRlci1jZWxsLWRlZi5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsV0FBVyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU0vRCxNQUFNLE9BQU8sYUFBYTtJQUoxQjtRQUtTLGFBQVEsR0FBRyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7S0FDdkM7K0dBRlksYUFBYTttR0FBYixhQUFhOzs0RkFBYixhQUFhO2tCQUp6QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxvQkFBb0I7b0JBQzlCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgaW5qZWN0LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbb2R4SGVhZGVyQ2VsbERlZl0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBIZWFkZXJDZWxsRGVmIHtcbiAgcHVibGljIHRlbXBsYXRlID0gaW5qZWN0KFRlbXBsYXRlUmVmKTtcbn1cbiJdfQ==
|