@ni/nimble-angular 30.11.8 → 30.12.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.
@@ -1,6 +1,7 @@
1
1
  import { Directive, ElementRef, Input, Renderer2 } from '@angular/core';
2
2
  import { tableTag } from '@ni/nimble-components/dist/esm/table';
3
3
  import { TableRowSelectionMode, TableRecordDelayedHierarchyState } from '@ni/nimble-components/dist/esm/table/types';
4
+ import { toBooleanProperty } from '@ni/nimble-angular/internal-utilities';
4
5
  import * as i0 from "@angular/core";
5
6
  export { tableTag };
6
7
  export { TableRowSelectionMode, TableRecordDelayedHierarchyState };
@@ -47,6 +48,12 @@ export class NimbleTableDirective {
47
48
  set selectionMode(value) {
48
49
  this.renderer.setProperty(this.elementRef.nativeElement, 'selectionMode', value);
49
50
  }
51
+ get actionMenusPreserveSelection() {
52
+ return this.elementRef.nativeElement.actionMenusPreserveSelection;
53
+ }
54
+ set actionMenusPreserveSelection(value) {
55
+ this.renderer.setProperty(this.elementRef.nativeElement, 'actionMenusPreserveSelection', toBooleanProperty(value));
56
+ }
50
57
  get validity() {
51
58
  return this.elementRef.nativeElement.validity;
52
59
  }
@@ -73,7 +80,7 @@ export class NimbleTableDirective {
73
80
  await this.elementRef.nativeElement.setRecordHierarchyOptions(hierarchyOptions);
74
81
  }
75
82
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: NimbleTableDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
76
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: NimbleTableDirective, selector: "nimble-table", inputs: { data$: "data$", idFieldName: ["id-field-name", "idFieldName"], parentIdFieldName: ["parent-id-field-name", "parentIdFieldName"], selectionMode: ["selection-mode", "selectionMode"] }, ngImport: i0 }); }
83
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: NimbleTableDirective, selector: "nimble-table", inputs: { data$: "data$", idFieldName: ["id-field-name", "idFieldName"], parentIdFieldName: ["parent-id-field-name", "parentIdFieldName"], selectionMode: ["selection-mode", "selectionMode"], actionMenusPreserveSelection: ["action-menus-preserve-selection", "actionMenusPreserveSelection"] }, ngImport: i0 }); }
77
84
  }
78
85
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: NimbleTableDirective, decorators: [{
79
86
  type: Directive,
@@ -92,5 +99,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
92
99
  }], selectionMode: [{
93
100
  type: Input,
94
101
  args: ['selection-mode']
102
+ }], actionMenusPreserveSelection: [{
103
+ type: Input,
104
+ args: ['action-menus-preserve-selection']
95
105
  }] } });
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nimble-table.directive.js","sourceRoot":"","sources":["../../../../nimble-angular/table/nimble-table.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, type OnDestroy, Renderer2 } from '@angular/core';\nimport { type Table, tableTag } from '@ni/nimble-components/dist/esm/table';\nimport type { TableRecord, TableFieldName, TableFieldValue, TableValidity, TableActionMenuToggleEventDetail, TableRowSelectionEventDetail, TableColumnConfigurationChangeEventDetail, TableColumnConfiguration, TableRowExpansionToggleEventDetail, TableSetRecordHierarchyOptions, TableRecordHierarchyOptions } from '@ni/nimble-components/dist/esm/table/types';\nimport { TableRowSelectionMode, TableRecordDelayedHierarchyState } from '@ni/nimble-components/dist/esm/table/types';\nimport type { Observable, Subscription } from 'rxjs';\n\nexport type { Table };\nexport { tableTag };\nexport type { TableActionMenuToggleEventDetail, TableRowSelectionEventDetail, TableColumnConfigurationChangeEventDetail, TableColumnConfiguration, TableRowExpansionToggleEventDetail };\nexport { type TableRecord, type TableFieldName, type TableFieldValue, type TableValidity, TableRowSelectionMode, TableRecordDelayedHierarchyState, type TableSetRecordHierarchyOptions, type TableRecordHierarchyOptions };\n\n/**\n * Directive to provide Angular integration for the table element.\n */\n@Directive({\n    selector: 'nimble-table',\n    standalone: false\n})\nexport class NimbleTableDirective<TData extends TableRecord = TableRecord> implements OnDestroy {\n    public get data$(): Observable<TData[]> | undefined {\n        return this.dataObservable;\n    }\n\n    /**\n     * An `Observable<TData[]>` that emits data that should be set on the table.\n     *\n     * When using `data$`, the timing of when the table has been updated with a new collection of data\n     * cannot be observed or await by an application. If an application needs to know when the data has\n     * been applied, explicitly call `setData()` rather than using the `data$` property. For example,\n     * calling `getSelectedRecordIds()` immediately after emitting a new value to the `data$` `Observable`\n     * may not take the new data into account when determining the selected records.\n     */\n    @Input() public set data$(value: Observable<TData[]> | undefined) {\n        this.dataSubscription?.unsubscribe();\n\n        this.dataObservable = value;\n        if (value) {\n            this.dataSubscription = value.subscribe(\n                next => {\n                    void this.setData(next);\n                }\n            );\n        }\n    }\n\n    public get idFieldName(): string | null | undefined {\n        return this.elementRef.nativeElement.idFieldName;\n    }\n\n    @Input('id-field-name') public set idFieldName(value: string | null | undefined) {\n        this.renderer.setProperty(this.elementRef.nativeElement, 'idFieldName', value);\n    }\n\n    public get parentIdFieldName(): string | null | undefined {\n        return this.elementRef.nativeElement.parentIdFieldName;\n    }\n\n    @Input('parent-id-field-name') public set parentIdFieldName(value: string | null | undefined) {\n        this.renderer.setProperty(this.elementRef.nativeElement, 'parentIdFieldName', value);\n    }\n\n    public get selectionMode(): TableRowSelectionMode {\n        return this.elementRef.nativeElement.selectionMode;\n    }\n\n    @Input('selection-mode') public set selectionMode(value: TableRowSelectionMode) {\n        this.renderer.setProperty(this.elementRef.nativeElement, 'selectionMode', value);\n    }\n\n    public get validity(): TableValidity {\n        return this.elementRef.nativeElement.validity;\n    }\n\n    private dataObservable?: Observable<TData[]>;\n    private dataSubscription?: Subscription;\n\n    public constructor(private readonly renderer: Renderer2, private readonly elementRef: ElementRef<Table<TData>>) {}\n\n    public ngOnDestroy(): void {\n        this.dataSubscription?.unsubscribe();\n    }\n\n    public checkValidity(): boolean {\n        return this.elementRef.nativeElement.checkValidity();\n    }\n\n    public async setData(data: readonly TData[]): Promise<void> {\n        await this.elementRef.nativeElement.setData(data);\n    }\n\n    public async getSelectedRecordIds(): Promise<string[]> {\n        return await this.elementRef.nativeElement.getSelectedRecordIds();\n    }\n\n    public async setSelectedRecordIds(recordIds: string[]): Promise<void> {\n        await this.elementRef.nativeElement.setSelectedRecordIds(recordIds);\n    }\n\n    public async setRecordHierarchyOptions(hierarchyOptions: TableSetRecordHierarchyOptions[]): Promise<void> {\n        await this.elementRef.nativeElement.setRecordHierarchyOptions(hierarchyOptions);\n    }\n}\n"]}
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nimble-table.directive.js","sourceRoot":"","sources":["../../../../nimble-angular/table/nimble-table.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, type OnDestroy, Renderer2 } from '@angular/core';\nimport { type Table, tableTag } from '@ni/nimble-components/dist/esm/table';\nimport type { TableRecord, TableFieldName, TableFieldValue, TableValidity, TableActionMenuToggleEventDetail, TableRowSelectionEventDetail, TableColumnConfigurationChangeEventDetail, TableColumnConfiguration, TableRowExpansionToggleEventDetail, TableSetRecordHierarchyOptions, TableRecordHierarchyOptions } from '@ni/nimble-components/dist/esm/table/types';\nimport { TableRowSelectionMode, TableRecordDelayedHierarchyState } from '@ni/nimble-components/dist/esm/table/types';\nimport type { Observable, Subscription } from 'rxjs';\nimport { type BooleanValueOrAttribute, toBooleanProperty } from '@ni/nimble-angular/internal-utilities';\n\nexport type { Table };\nexport { tableTag };\nexport type { TableActionMenuToggleEventDetail, TableRowSelectionEventDetail, TableColumnConfigurationChangeEventDetail, TableColumnConfiguration, TableRowExpansionToggleEventDetail };\nexport { type TableRecord, type TableFieldName, type TableFieldValue, type TableValidity, TableRowSelectionMode, TableRecordDelayedHierarchyState, type TableSetRecordHierarchyOptions, type TableRecordHierarchyOptions };\n\n/**\n * Directive to provide Angular integration for the table element.\n */\n@Directive({\n    selector: 'nimble-table',\n    standalone: false\n})\nexport class NimbleTableDirective<TData extends TableRecord = TableRecord> implements OnDestroy {\n    public get data$(): Observable<TData[]> | undefined {\n        return this.dataObservable;\n    }\n\n    /**\n     * An `Observable<TData[]>` that emits data that should be set on the table.\n     *\n     * When using `data$`, the timing of when the table has been updated with a new collection of data\n     * cannot be observed or await by an application. If an application needs to know when the data has\n     * been applied, explicitly call `setData()` rather than using the `data$` property. For example,\n     * calling `getSelectedRecordIds()` immediately after emitting a new value to the `data$` `Observable`\n     * may not take the new data into account when determining the selected records.\n     */\n    @Input() public set data$(value: Observable<TData[]> | undefined) {\n        this.dataSubscription?.unsubscribe();\n\n        this.dataObservable = value;\n        if (value) {\n            this.dataSubscription = value.subscribe(\n                next => {\n                    void this.setData(next);\n                }\n            );\n        }\n    }\n\n    public get idFieldName(): string | null | undefined {\n        return this.elementRef.nativeElement.idFieldName;\n    }\n\n    @Input('id-field-name') public set idFieldName(value: string | null | undefined) {\n        this.renderer.setProperty(this.elementRef.nativeElement, 'idFieldName', value);\n    }\n\n    public get parentIdFieldName(): string | null | undefined {\n        return this.elementRef.nativeElement.parentIdFieldName;\n    }\n\n    @Input('parent-id-field-name') public set parentIdFieldName(value: string | null | undefined) {\n        this.renderer.setProperty(this.elementRef.nativeElement, 'parentIdFieldName', value);\n    }\n\n    public get selectionMode(): TableRowSelectionMode {\n        return this.elementRef.nativeElement.selectionMode;\n    }\n\n    @Input('selection-mode') public set selectionMode(value: TableRowSelectionMode) {\n        this.renderer.setProperty(this.elementRef.nativeElement, 'selectionMode', value);\n    }\n\n    public get actionMenusPreserveSelection(): BooleanValueOrAttribute {\n        return this.elementRef.nativeElement.actionMenusPreserveSelection;\n    }\n\n    @Input('action-menus-preserve-selection') public set actionMenusPreserveSelection(value: BooleanValueOrAttribute) {\n        this.renderer.setProperty(this.elementRef.nativeElement, 'actionMenusPreserveSelection', toBooleanProperty(value));\n    }\n\n    public get validity(): TableValidity {\n        return this.elementRef.nativeElement.validity;\n    }\n\n    private dataObservable?: Observable<TData[]>;\n    private dataSubscription?: Subscription;\n\n    public constructor(private readonly renderer: Renderer2, private readonly elementRef: ElementRef<Table<TData>>) {}\n\n    public ngOnDestroy(): void {\n        this.dataSubscription?.unsubscribe();\n    }\n\n    public checkValidity(): boolean {\n        return this.elementRef.nativeElement.checkValidity();\n    }\n\n    public async setData(data: readonly TData[]): Promise<void> {\n        await this.elementRef.nativeElement.setData(data);\n    }\n\n    public async getSelectedRecordIds(): Promise<string[]> {\n        return await this.elementRef.nativeElement.getSelectedRecordIds();\n    }\n\n    public async setSelectedRecordIds(recordIds: string[]): Promise<void> {\n        await this.elementRef.nativeElement.setSelectedRecordIds(recordIds);\n    }\n\n    public async setRecordHierarchyOptions(hierarchyOptions: TableSetRecordHierarchyOptions[]): Promise<void> {\n        await this.elementRef.nativeElement.setRecordHierarchyOptions(hierarchyOptions);\n    }\n}\n"]}
@@ -2,6 +2,7 @@ import * as i0 from '@angular/core';
2
2
  import { Input, Directive, NgModule } from '@angular/core';
3
3
  export { tableTag } from '@ni/nimble-components/dist/esm/table';
4
4
  export { TableRecordDelayedHierarchyState, TableRowSelectionMode } from '@ni/nimble-components/dist/esm/table/types';
5
+ import { toBooleanProperty } from '@ni/nimble-angular/internal-utilities';
5
6
  import { CommonModule } from '@angular/common';
6
7
 
7
8
  /**
@@ -47,6 +48,12 @@ class NimbleTableDirective {
47
48
  set selectionMode(value) {
48
49
  this.renderer.setProperty(this.elementRef.nativeElement, 'selectionMode', value);
49
50
  }
51
+ get actionMenusPreserveSelection() {
52
+ return this.elementRef.nativeElement.actionMenusPreserveSelection;
53
+ }
54
+ set actionMenusPreserveSelection(value) {
55
+ this.renderer.setProperty(this.elementRef.nativeElement, 'actionMenusPreserveSelection', toBooleanProperty(value));
56
+ }
50
57
  get validity() {
51
58
  return this.elementRef.nativeElement.validity;
52
59
  }
@@ -73,7 +80,7 @@ class NimbleTableDirective {
73
80
  await this.elementRef.nativeElement.setRecordHierarchyOptions(hierarchyOptions);
74
81
  }
75
82
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: NimbleTableDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
76
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: NimbleTableDirective, selector: "nimble-table", inputs: { data$: "data$", idFieldName: ["id-field-name", "idFieldName"], parentIdFieldName: ["parent-id-field-name", "parentIdFieldName"], selectionMode: ["selection-mode", "selectionMode"] }, ngImport: i0 }); }
83
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: NimbleTableDirective, selector: "nimble-table", inputs: { data$: "data$", idFieldName: ["id-field-name", "idFieldName"], parentIdFieldName: ["parent-id-field-name", "parentIdFieldName"], selectionMode: ["selection-mode", "selectionMode"], actionMenusPreserveSelection: ["action-menus-preserve-selection", "actionMenusPreserveSelection"] }, ngImport: i0 }); }
77
84
  }
78
85
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: NimbleTableDirective, decorators: [{
79
86
  type: Directive,
@@ -92,6 +99,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
92
99
  }], selectionMode: [{
93
100
  type: Input,
94
101
  args: ['selection-mode']
102
+ }], actionMenusPreserveSelection: [{
103
+ type: Input,
104
+ args: ['action-menus-preserve-selection']
95
105
  }] } });
96
106
 
97
107
  class NimbleTableModule {
@@ -1 +1 @@
1
- {"version":3,"file":"ni-nimble-angular-table.mjs","sources":["../../../nimble-angular/table/nimble-table.directive.ts","../../../nimble-angular/table/nimble-table.module.ts","../../../nimble-angular/table/ni-nimble-angular-table.ts"],"sourcesContent":["import { Directive, ElementRef, Input, type OnDestroy, Renderer2 } from '@angular/core';\nimport { type Table, tableTag } from '@ni/nimble-components/dist/esm/table';\nimport type { TableRecord, TableFieldName, TableFieldValue, TableValidity, TableActionMenuToggleEventDetail, TableRowSelectionEventDetail, TableColumnConfigurationChangeEventDetail, TableColumnConfiguration, TableRowExpansionToggleEventDetail, TableSetRecordHierarchyOptions, TableRecordHierarchyOptions } from '@ni/nimble-components/dist/esm/table/types';\nimport { TableRowSelectionMode, TableRecordDelayedHierarchyState } from '@ni/nimble-components/dist/esm/table/types';\nimport type { Observable, Subscription } from 'rxjs';\n\nexport type { Table };\nexport { tableTag };\nexport type { TableActionMenuToggleEventDetail, TableRowSelectionEventDetail, TableColumnConfigurationChangeEventDetail, TableColumnConfiguration, TableRowExpansionToggleEventDetail };\nexport { type TableRecord, type TableFieldName, type TableFieldValue, type TableValidity, TableRowSelectionMode, TableRecordDelayedHierarchyState, type TableSetRecordHierarchyOptions, type TableRecordHierarchyOptions };\n\n/**\n * Directive to provide Angular integration for the table element.\n */\n@Directive({\n selector: 'nimble-table',\n standalone: false\n})\nexport class NimbleTableDirective<TData extends TableRecord = TableRecord> implements OnDestroy {\n public get data$(): Observable<TData[]> | undefined {\n return this.dataObservable;\n }\n\n /**\n * An `Observable<TData[]>` that emits data that should be set on the table.\n *\n * When using `data$`, the timing of when the table has been updated with a new collection of data\n * cannot be observed or await by an application. If an application needs to know when the data has\n * been applied, explicitly call `setData()` rather than using the `data$` property. For example,\n * calling `getSelectedRecordIds()` immediately after emitting a new value to the `data$` `Observable`\n * may not take the new data into account when determining the selected records.\n */\n @Input() public set data$(value: Observable<TData[]> | undefined) {\n this.dataSubscription?.unsubscribe();\n\n this.dataObservable = value;\n if (value) {\n this.dataSubscription = value.subscribe(\n next => {\n void this.setData(next);\n }\n );\n }\n }\n\n public get idFieldName(): string | null | undefined {\n return this.elementRef.nativeElement.idFieldName;\n }\n\n @Input('id-field-name') public set idFieldName(value: string | null | undefined) {\n this.renderer.setProperty(this.elementRef.nativeElement, 'idFieldName', value);\n }\n\n public get parentIdFieldName(): string | null | undefined {\n return this.elementRef.nativeElement.parentIdFieldName;\n }\n\n @Input('parent-id-field-name') public set parentIdFieldName(value: string | null | undefined) {\n this.renderer.setProperty(this.elementRef.nativeElement, 'parentIdFieldName', value);\n }\n\n public get selectionMode(): TableRowSelectionMode {\n return this.elementRef.nativeElement.selectionMode;\n }\n\n @Input('selection-mode') public set selectionMode(value: TableRowSelectionMode) {\n this.renderer.setProperty(this.elementRef.nativeElement, 'selectionMode', value);\n }\n\n public get validity(): TableValidity {\n return this.elementRef.nativeElement.validity;\n }\n\n private dataObservable?: Observable<TData[]>;\n private dataSubscription?: Subscription;\n\n public constructor(private readonly renderer: Renderer2, private readonly elementRef: ElementRef<Table<TData>>) {}\n\n public ngOnDestroy(): void {\n this.dataSubscription?.unsubscribe();\n }\n\n public checkValidity(): boolean {\n return this.elementRef.nativeElement.checkValidity();\n }\n\n public async setData(data: readonly TData[]): Promise<void> {\n await this.elementRef.nativeElement.setData(data);\n }\n\n public async getSelectedRecordIds(): Promise<string[]> {\n return await this.elementRef.nativeElement.getSelectedRecordIds();\n }\n\n public async setSelectedRecordIds(recordIds: string[]): Promise<void> {\n await this.elementRef.nativeElement.setSelectedRecordIds(recordIds);\n }\n\n public async setRecordHierarchyOptions(hierarchyOptions: TableSetRecordHierarchyOptions[]): Promise<void> {\n await this.elementRef.nativeElement.setRecordHierarchyOptions(hierarchyOptions);\n }\n}\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { NimbleTableDirective } from './nimble-table.directive';\n\nimport '@ni/nimble-components/dist/esm/table';\n\n@NgModule({\n declarations: [NimbleTableDirective],\n imports: [CommonModule],\n exports: [NimbleTableDirective]\n})\nexport class NimbleTableModule { }\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"ni-nimble-angular-table.mjs","sources":["../../../nimble-angular/table/nimble-table.directive.ts","../../../nimble-angular/table/nimble-table.module.ts","../../../nimble-angular/table/ni-nimble-angular-table.ts"],"sourcesContent":["import { Directive, ElementRef, Input, type OnDestroy, Renderer2 } from '@angular/core';\nimport { type Table, tableTag } from '@ni/nimble-components/dist/esm/table';\nimport type { TableRecord, TableFieldName, TableFieldValue, TableValidity, TableActionMenuToggleEventDetail, TableRowSelectionEventDetail, TableColumnConfigurationChangeEventDetail, TableColumnConfiguration, TableRowExpansionToggleEventDetail, TableSetRecordHierarchyOptions, TableRecordHierarchyOptions } from '@ni/nimble-components/dist/esm/table/types';\nimport { TableRowSelectionMode, TableRecordDelayedHierarchyState } from '@ni/nimble-components/dist/esm/table/types';\nimport type { Observable, Subscription } from 'rxjs';\nimport { type BooleanValueOrAttribute, toBooleanProperty } from '@ni/nimble-angular/internal-utilities';\n\nexport type { Table };\nexport { tableTag };\nexport type { TableActionMenuToggleEventDetail, TableRowSelectionEventDetail, TableColumnConfigurationChangeEventDetail, TableColumnConfiguration, TableRowExpansionToggleEventDetail };\nexport { type TableRecord, type TableFieldName, type TableFieldValue, type TableValidity, TableRowSelectionMode, TableRecordDelayedHierarchyState, type TableSetRecordHierarchyOptions, type TableRecordHierarchyOptions };\n\n/**\n * Directive to provide Angular integration for the table element.\n */\n@Directive({\n selector: 'nimble-table',\n standalone: false\n})\nexport class NimbleTableDirective<TData extends TableRecord = TableRecord> implements OnDestroy {\n public get data$(): Observable<TData[]> | undefined {\n return this.dataObservable;\n }\n\n /**\n * An `Observable<TData[]>` that emits data that should be set on the table.\n *\n * When using `data$`, the timing of when the table has been updated with a new collection of data\n * cannot be observed or await by an application. If an application needs to know when the data has\n * been applied, explicitly call `setData()` rather than using the `data$` property. For example,\n * calling `getSelectedRecordIds()` immediately after emitting a new value to the `data$` `Observable`\n * may not take the new data into account when determining the selected records.\n */\n @Input() public set data$(value: Observable<TData[]> | undefined) {\n this.dataSubscription?.unsubscribe();\n\n this.dataObservable = value;\n if (value) {\n this.dataSubscription = value.subscribe(\n next => {\n void this.setData(next);\n }\n );\n }\n }\n\n public get idFieldName(): string | null | undefined {\n return this.elementRef.nativeElement.idFieldName;\n }\n\n @Input('id-field-name') public set idFieldName(value: string | null | undefined) {\n this.renderer.setProperty(this.elementRef.nativeElement, 'idFieldName', value);\n }\n\n public get parentIdFieldName(): string | null | undefined {\n return this.elementRef.nativeElement.parentIdFieldName;\n }\n\n @Input('parent-id-field-name') public set parentIdFieldName(value: string | null | undefined) {\n this.renderer.setProperty(this.elementRef.nativeElement, 'parentIdFieldName', value);\n }\n\n public get selectionMode(): TableRowSelectionMode {\n return this.elementRef.nativeElement.selectionMode;\n }\n\n @Input('selection-mode') public set selectionMode(value: TableRowSelectionMode) {\n this.renderer.setProperty(this.elementRef.nativeElement, 'selectionMode', value);\n }\n\n public get actionMenusPreserveSelection(): BooleanValueOrAttribute {\n return this.elementRef.nativeElement.actionMenusPreserveSelection;\n }\n\n @Input('action-menus-preserve-selection') public set actionMenusPreserveSelection(value: BooleanValueOrAttribute) {\n this.renderer.setProperty(this.elementRef.nativeElement, 'actionMenusPreserveSelection', toBooleanProperty(value));\n }\n\n public get validity(): TableValidity {\n return this.elementRef.nativeElement.validity;\n }\n\n private dataObservable?: Observable<TData[]>;\n private dataSubscription?: Subscription;\n\n public constructor(private readonly renderer: Renderer2, private readonly elementRef: ElementRef<Table<TData>>) {}\n\n public ngOnDestroy(): void {\n this.dataSubscription?.unsubscribe();\n }\n\n public checkValidity(): boolean {\n return this.elementRef.nativeElement.checkValidity();\n }\n\n public async setData(data: readonly TData[]): Promise<void> {\n await this.elementRef.nativeElement.setData(data);\n }\n\n public async getSelectedRecordIds(): Promise<string[]> {\n return await this.elementRef.nativeElement.getSelectedRecordIds();\n }\n\n public async setSelectedRecordIds(recordIds: string[]): Promise<void> {\n await this.elementRef.nativeElement.setSelectedRecordIds(recordIds);\n }\n\n public async setRecordHierarchyOptions(hierarchyOptions: TableSetRecordHierarchyOptions[]): Promise<void> {\n await this.elementRef.nativeElement.setRecordHierarchyOptions(hierarchyOptions);\n }\n}\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { NimbleTableDirective } from './nimble-table.directive';\n\nimport '@ni/nimble-components/dist/esm/table';\n\n@NgModule({\n declarations: [NimbleTableDirective],\n imports: [CommonModule],\n exports: [NimbleTableDirective]\n})\nexport class NimbleTableModule { }\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ni/nimble-angular",
3
- "version": "30.11.8",
3
+ "version": "30.12.0",
4
4
  "description": "Angular components for the NI Nimble Design System",
5
5
  "repository": {
6
6
  "type": "git",
@@ -271,7 +271,7 @@
271
271
  "@angular/forms": "^18.2.13",
272
272
  "@angular/localize": "^18.2.13",
273
273
  "@angular/router": "^18.2.13",
274
- "@ni/nimble-components": "^34.9.0"
274
+ "@ni/nimble-components": "^34.10.0"
275
275
  },
276
276
  "dependencies": {
277
277
  "tslib": "^2.2.0"
@@ -3,6 +3,7 @@ import { type Table, tableTag } from '@ni/nimble-components/dist/esm/table';
3
3
  import type { TableRecord, TableFieldName, TableFieldValue, TableValidity, TableActionMenuToggleEventDetail, TableRowSelectionEventDetail, TableColumnConfigurationChangeEventDetail, TableColumnConfiguration, TableRowExpansionToggleEventDetail, TableSetRecordHierarchyOptions, TableRecordHierarchyOptions } from '@ni/nimble-components/dist/esm/table/types';
4
4
  import { TableRowSelectionMode, TableRecordDelayedHierarchyState } from '@ni/nimble-components/dist/esm/table/types';
5
5
  import type { Observable } from 'rxjs';
6
+ import { type BooleanValueOrAttribute } from '@ni/nimble-angular/internal-utilities';
6
7
  import * as i0 from "@angular/core";
7
8
  export type { Table };
8
9
  export { tableTag };
@@ -31,6 +32,8 @@ export declare class NimbleTableDirective<TData extends TableRecord = TableRecor
31
32
  set parentIdFieldName(value: string | null | undefined);
32
33
  get selectionMode(): TableRowSelectionMode;
33
34
  set selectionMode(value: TableRowSelectionMode);
35
+ get actionMenusPreserveSelection(): BooleanValueOrAttribute;
36
+ set actionMenusPreserveSelection(value: BooleanValueOrAttribute);
34
37
  get validity(): TableValidity;
35
38
  private dataObservable?;
36
39
  private dataSubscription?;
@@ -42,5 +45,5 @@ export declare class NimbleTableDirective<TData extends TableRecord = TableRecor
42
45
  setSelectedRecordIds(recordIds: string[]): Promise<void>;
43
46
  setRecordHierarchyOptions(hierarchyOptions: TableSetRecordHierarchyOptions[]): Promise<void>;
44
47
  static ɵfac: i0.ɵɵFactoryDeclaration<NimbleTableDirective<any>, never>;
45
- static ɵdir: i0.ɵɵDirectiveDeclaration<NimbleTableDirective<any>, "nimble-table", never, { "data$": { "alias": "data$"; "required": false; }; "idFieldName": { "alias": "id-field-name"; "required": false; }; "parentIdFieldName": { "alias": "parent-id-field-name"; "required": false; }; "selectionMode": { "alias": "selection-mode"; "required": false; }; }, {}, never, never, false, never>;
48
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NimbleTableDirective<any>, "nimble-table", never, { "data$": { "alias": "data$"; "required": false; }; "idFieldName": { "alias": "id-field-name"; "required": false; }; "parentIdFieldName": { "alias": "parent-id-field-name"; "required": false; }; "selectionMode": { "alias": "selection-mode"; "required": false; }; "actionMenusPreserveSelection": { "alias": "action-menus-preserve-selection"; "required": false; }; }, {}, never, never, false, never>;
46
49
  }