@quadrel-enterprise-ui/framework 18.29.0 → 18.29.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.
- package/esm2022/lib/table/services/resolver.service.mjs +3 -5
- package/esm2022/lib/table/store/table-store.service.mjs +1 -1
- package/esm2022/lib/table/table.component.mjs +2 -2
- package/esm2022/lib/tree/row/actions/secondary/menu/tree-row-actions-secondary-menu.component.mjs +10 -13
- package/fesm2022/quadrel-enterprise-ui-framework.mjs +12 -17
- package/fesm2022/quadrel-enterprise-ui-framework.mjs.map +1 -1
- package/lib/table/store/table-store.service.d.ts +1 -1
- package/lib/tree/row/actions/secondary/menu/tree-row-actions-secondary-menu.component.d.ts +1 -1
- package/package.json +1 -1
|
@@ -39,9 +39,7 @@ export class QdTableResolverService {
|
|
|
39
39
|
// TODO: Add Error handling
|
|
40
40
|
this.tableStoreService
|
|
41
41
|
.selectDataResolutionCriteria$()
|
|
42
|
-
.pipe(takeUntil(this._destroyed$), distinctUntilChanged(isEqual), filter((resolutionCriteria) => {
|
|
43
|
-
return !!resolutionCriteria && this.shouldDataBeResolved(resolutionCriteria);
|
|
44
|
-
}), map(({ tableParams, connectorParams }) => {
|
|
42
|
+
.pipe(takeUntil(this._destroyed$), distinctUntilChanged(isEqual), filter((resolutionCriteria) => !!resolutionCriteria && this.shouldDataBeResolved(resolutionCriteria)), map(({ tableParams, connectorParams }) => {
|
|
45
43
|
return {
|
|
46
44
|
...(this._hasPagination ? tableParams : {}),
|
|
47
45
|
...connectorParams
|
|
@@ -59,7 +57,7 @@ export class QdTableResolverService {
|
|
|
59
57
|
this._refreshSubscription.unsubscribe();
|
|
60
58
|
this._refreshSubscription = this.tableStoreService
|
|
61
59
|
.selectDataResolutionCriteria$()
|
|
62
|
-
.pipe(first(), tap(() => this.tableStoreService.setRequestState(QdTableRequestState.PENDING)), switchMap(resolutionCriteria => this.tableDataResolver.resolve({
|
|
60
|
+
.pipe(filter((criteria) => !!criteria), first(), tap(() => this.tableStoreService.setRequestState(QdTableRequestState.PENDING)), switchMap(resolutionCriteria => this.tableDataResolver.resolve({
|
|
63
61
|
...resolutionCriteria.tableParams,
|
|
64
62
|
...resolutionCriteria.connectorParams,
|
|
65
63
|
...(this._hasPagination && pageIndex !== undefined ? { page: pageIndex } : {})
|
|
@@ -92,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
92
90
|
type: Inject,
|
|
93
91
|
args: [QD_TABLE_DATA_RESOLVER_TOKEN]
|
|
94
92
|
}] }, { type: i1.QdTableStoreService }, { type: i2.TranslateService }, { type: i3.QdTableExternalActionResultService }] });
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resolver.service.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/table/services/resolver.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, OnDestroy, Optional } from '@angular/core';\nimport isEqual from 'lodash/isEqual';\nimport { first, Subject, Subscription, switchMap } from 'rxjs';\nimport { distinctUntilChanged, filter, map, takeUntil, tap } from 'rxjs/operators';\nimport { TranslateService } from '@ngx-translate/core';\n\nimport { QdTableConnectorState } from '../model/connectors-state.enum';\nimport { QdTableDataResolver, QdTableDataResolverProps, QdTableRequestState } from '../model/table-data-resolver';\nimport { QD_TABLE_DATA_RESOLVER_TOKEN } from '../model/table-data-resolver.token';\nimport { QdTableDataResolutionCriteria } from '../model/table-store.interface';\nimport { QdTableStoreService } from '../store/table-store.service';\nimport { QdTableExternalActionResultService } from './external-action-result.service';\n\n@Injectable()\nexport class QdTableResolverService<T extends string> implements OnDestroy {\n  private _destroyed$: Subject<null> = new Subject();\n  private _refreshSubscription!: Subscription;\n  private _hasPagination = true;\n\n  constructor(\n    @Optional() @Inject(QD_TABLE_DATA_RESOLVER_TOKEN) private readonly tableDataResolver: QdTableDataResolver<T>,\n    private readonly tableStoreService: QdTableStoreService<T>,\n    private readonly translateService: TranslateService,\n    private readonly actionResultService: QdTableExternalActionResultService\n  ) {\n    this.subscribeToExternalRefresh();\n  }\n\n  ngOnDestroy(): void {\n    this._destroyed$.complete();\n  }\n\n  init(refreshOnLanguageChange?: boolean, hasPagination = true): void {\n    if (!this.tableDataResolver) return;\n    this._hasPagination = hasPagination;\n    if (refreshOnLanguageChange) this.subscribeToLangChanges();\n\n    // TODO: Add Error handling\n    this.tableStoreService\n      .selectDataResolutionCriteria$()\n      .pipe(\n        takeUntil(this._destroyed$),\n        distinctUntilChanged(isEqual),\n        filter((resolutionCriteria): resolutionCriteria is QdTableDataResolutionCriteria<T> => {\n          return !!resolutionCriteria && this.shouldDataBeResolved(resolutionCriteria);\n        }),\n        map(({ tableParams, connectorParams }) => {\n          return {\n            ...(this._hasPagination ? tableParams : {}),\n            ...connectorParams\n          } as QdTableDataResolverProps<T>;\n        }),\n        tap(() => this.tableStoreService.setRequestState(QdTableRequestState.PENDING)),\n        switchMap(resolutionParams => this.tableDataResolver.resolve(resolutionParams)),\n        tap(({ data, size, page, totalElements }) => {\n          this.tableStoreService.setPage(page ?? 0, size, totalElements, data);\n        }),\n        tap(() => this.tableStoreService.setRequestState(QdTableRequestState.SUCCESS))\n      )\n      .subscribe();\n  }\n\n  refresh(resolverOptions: { pageIndex?: number } = {}): void {\n    if (!this.tableDataResolver) return console.warn('QD-UI | QdTable - Refresh skipped: resolver not provided.');\n\n    const { pageIndex } = resolverOptions;\n\n    if (this._refreshSubscription) this._refreshSubscription.unsubscribe();\n\n    this._refreshSubscription = this.tableStoreService\n      .selectDataResolutionCriteria$()\n      .pipe(\n        first(),\n        tap(() => this.tableStoreService.setRequestState(QdTableRequestState.PENDING)),\n        switchMap(resolutionCriteria =>\n          this.tableDataResolver.resolve({\n            ...resolutionCriteria.tableParams,\n            ...resolutionCriteria.connectorParams,\n            ...(this._hasPagination && pageIndex !== undefined ? { page: pageIndex } : {})\n          })\n        ),\n        tap(({ page, data, size, totalElements }) => this.tableStoreService.setPage(page, size, totalElements, data)),\n        tap(() => this.tableStoreService.setRequestState(QdTableRequestState.SUCCESS))\n      )\n      .subscribe();\n  }\n\n  private subscribeToLangChanges(): void {\n    this.translateService.onLangChange.pipe(takeUntil(this._destroyed$)).subscribe(() => this.refresh());\n  }\n\n  private shouldDataBeResolved({\n    hasConnectors,\n    connectorsState,\n    tableParams\n  }: QdTableDataResolutionCriteria<T>): boolean {\n    if (hasConnectors && connectorsState === QdTableConnectorState.AWAITING) return false;\n\n    if (!this._hasPagination) return true;\n\n    return tableParams?.size !== undefined && tableParams?.page !== undefined;\n  }\n\n  private subscribeToExternalRefresh(): void {\n    this.actionResultService.actionSuccess$\n      .pipe(takeUntil(this._destroyed$))\n      .subscribe(pageIndex => this.refresh({ pageIndex }));\n  }\n}\n"]}
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resolver.service.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/table/services/resolver.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, OnDestroy, Optional } from '@angular/core';\nimport isEqual from 'lodash/isEqual';\nimport { first, Subject, Subscription, switchMap } from 'rxjs';\nimport { distinctUntilChanged, filter, map, takeUntil, tap } from 'rxjs/operators';\nimport { TranslateService } from '@ngx-translate/core';\n\nimport { QdTableConnectorState } from '../model/connectors-state.enum';\nimport { QdTableDataResolver, QdTableDataResolverProps, QdTableRequestState } from '../model/table-data-resolver';\nimport { QD_TABLE_DATA_RESOLVER_TOKEN } from '../model/table-data-resolver.token';\nimport { QdTableDataResolutionCriteria } from '../model/table-store.interface';\nimport { QdTableStoreService } from '../store/table-store.service';\nimport { QdTableExternalActionResultService } from './external-action-result.service';\n\n@Injectable()\nexport class QdTableResolverService<T extends string> implements OnDestroy {\n  private _destroyed$: Subject<null> = new Subject();\n  private _refreshSubscription!: Subscription;\n  private _hasPagination = true;\n\n  constructor(\n    @Optional() @Inject(QD_TABLE_DATA_RESOLVER_TOKEN) private readonly tableDataResolver: QdTableDataResolver<T>,\n    private readonly tableStoreService: QdTableStoreService<T>,\n    private readonly translateService: TranslateService,\n    private readonly actionResultService: QdTableExternalActionResultService\n  ) {\n    this.subscribeToExternalRefresh();\n  }\n\n  ngOnDestroy(): void {\n    this._destroyed$.complete();\n  }\n\n  init(refreshOnLanguageChange?: boolean, hasPagination = true): void {\n    if (!this.tableDataResolver) return;\n    this._hasPagination = hasPagination;\n    if (refreshOnLanguageChange) this.subscribeToLangChanges();\n\n    // TODO: Add Error handling\n    this.tableStoreService\n      .selectDataResolutionCriteria$()\n      .pipe(\n        takeUntil(this._destroyed$),\n        distinctUntilChanged(isEqual),\n        filter(\n          (resolutionCriteria): resolutionCriteria is QdTableDataResolutionCriteria<T> =>\n            !!resolutionCriteria && this.shouldDataBeResolved(resolutionCriteria)\n        ),\n        map(({ tableParams, connectorParams }) => {\n          return {\n            ...(this._hasPagination ? tableParams : {}),\n            ...connectorParams\n          } as QdTableDataResolverProps<T>;\n        }),\n        tap(() => this.tableStoreService.setRequestState(QdTableRequestState.PENDING)),\n        switchMap(resolutionParams => this.tableDataResolver.resolve(resolutionParams)),\n        tap(({ data, size, page, totalElements }) => {\n          this.tableStoreService.setPage(page ?? 0, size, totalElements, data);\n        }),\n        tap(() => this.tableStoreService.setRequestState(QdTableRequestState.SUCCESS))\n      )\n      .subscribe();\n  }\n\n  refresh(resolverOptions: { pageIndex?: number } = {}): void {\n    if (!this.tableDataResolver) return console.warn('QD-UI | QdTable - Refresh skipped: resolver not provided.');\n\n    const { pageIndex } = resolverOptions;\n\n    if (this._refreshSubscription) this._refreshSubscription.unsubscribe();\n\n    this._refreshSubscription = this.tableStoreService\n      .selectDataResolutionCriteria$()\n      .pipe(\n        filter((criteria: any): criteria is QdTableDataResolutionCriteria<T> => !!criteria),\n        first(),\n        tap(() => this.tableStoreService.setRequestState(QdTableRequestState.PENDING)),\n        switchMap(resolutionCriteria =>\n          this.tableDataResolver.resolve({\n            ...resolutionCriteria.tableParams,\n            ...resolutionCriteria.connectorParams,\n            ...(this._hasPagination && pageIndex !== undefined ? { page: pageIndex } : {})\n          })\n        ),\n        tap(({ page, data, size, totalElements }) => this.tableStoreService.setPage(page, size, totalElements, data)),\n        tap(() => this.tableStoreService.setRequestState(QdTableRequestState.SUCCESS))\n      )\n      .subscribe();\n  }\n\n  private subscribeToLangChanges(): void {\n    this.translateService.onLangChange.pipe(takeUntil(this._destroyed$)).subscribe(() => this.refresh());\n  }\n\n  private shouldDataBeResolved({\n    hasConnectors,\n    connectorsState,\n    tableParams\n  }: QdTableDataResolutionCriteria<T>): boolean {\n    if (hasConnectors && connectorsState === QdTableConnectorState.AWAITING) return false;\n\n    if (!this._hasPagination) return true;\n\n    return tableParams?.size !== undefined && tableParams?.page !== undefined;\n  }\n\n  private subscribeToExternalRefresh(): void {\n    this.actionResultService.actionSuccess$\n      .pipe(takeUntil(this._destroyed$))\n      .subscribe(pageIndex => this.refresh({ pageIndex }));\n  }\n}\n"]}
|
|
@@ -141,4 +141,4 @@ export class QdTableStoreService {
|
|
|
141
141
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdTableStoreService, decorators: [{
|
|
142
142
|
type: Injectable
|
|
143
143
|
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.QdTableStoreSelectorService }] });
|
|
144
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-store.service.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/table/store/table-store.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\n\nimport { Store } from '@ngrx/store';\nimport { Observable } from 'rxjs';\nimport { filter } from 'rxjs/operators';\nimport {\n  QdTableConnector,\n  QdTableConnectorCriteria,\n  QdTableDataResolutionCriteria,\n  QdTablePaginatorCurrentPage,\n  QdTableState,\n  QdTableStore\n} from '../model/table-store.interface';\nimport { QdTableActions } from './table.actions';\n\nimport { QdTableConnectorState } from '../model/connectors-state.enum';\nimport { QdSortDirection } from '../model/sort-direction.enum';\nimport { QdTableConfigColumn } from '../model/table-config.interface';\nimport { QdTableRequestState } from '../model/table-data-resolver';\nimport {\n  QdTableData,\n  QdTableDataRow,\n  QdTableRecentSecondaryAction,\n  QdTableRowIdentifier\n} from '../model/table-data.interface';\nimport { QdTableStoreSelectorService } from './table-store-selector.service';\nimport { QdTreeData } from '../../tree/model/tree-data.interface';\n\n@Injectable()\nexport class QdTableStoreService<T extends string> {\n  tableId = '';\n\n  constructor(\n    private readonly store: Store<QdTableStore<T>>,\n    private readonly tableStoreSelectorService: QdTableStoreSelectorService\n  ) {}\n\n  init(): void {\n    this.tableStoreSelectorService.tableId = this.tableId;\n  }\n\n  /**\n   * Actions\n   */\n  initTableState(\n    data: QdTableData<T> | QdTreeData<T>,\n    hasResolver: boolean,\n    connectors: QdTableConnector[],\n    hasPagination = false\n  ): void {\n    this.store.dispatch(\n      QdTableActions.initTableState({\n        tableId: this.tableId,\n        data,\n        hasResolver,\n        connectors,\n        hasPagination\n      })\n    );\n  }\n\n  initTableStateSelectedRows(selectedRows: QdTableRowIdentifier[]): void {\n    this.store.dispatch(\n      QdTableActions.initTableStateSelectedRows({ tableId: this.tableId, selectedRows: [...selectedRows] })\n    );\n  }\n\n  updateTableStateData(data: QdTableData<T> | QdTreeData<T>): void {\n    this.store.dispatch(QdTableActions.updateTableStateData({ tableId: this.tableId, data }));\n  }\n\n  updateTableStateRowToSelected(rowIndex: number): void {\n    this.store.dispatch(QdTableActions.updateTableStateRowToSelected({ tableId: this.tableId, rowIndex }));\n  }\n\n  updateTableStateSingleRowToSelected(rowIndex: number): void {\n    this.store.dispatch(QdTableActions.updateTableStateSingleRowToSelected({ tableId: this.tableId, rowIndex }));\n  }\n\n  updateTableStateRowToUnselected(rowIndex: number): void {\n    this.store.dispatch(QdTableActions.updateTableStateRowToUnselected({ tableId: this.tableId, rowIndex }));\n  }\n\n  updateTableStateRecentSecondaryAction(action: QdTableRecentSecondaryAction<any> | undefined): void {\n    this.store.dispatch(\n      QdTableActions.updateTableStateRecentSecondaryAction({ tableId: this.tableId, recentSecondaryAction: action })\n    );\n  }\n\n  setupPagination(pageSize: number): void {\n    this.store.dispatch(QdTableActions.setupPagination({ tableId: this.tableId, pageSize }));\n  }\n\n  setPage(pageIndex: number, pageSize: number, totalCount: number, data: QdTableData<string>): void {\n    this.store.dispatch(QdTableActions.setPage({ tableId: this.tableId, pageIndex, pageSize, totalCount, data }));\n  }\n\n  setPageSize(pageSize: number): void {\n    this.store.dispatch(QdTableActions.setPageSize({ tableId: this.tableId, pageSize }));\n  }\n\n  setPageParams(pageIndex: number, pageSize: number, totalCount: number): void {\n    this.store.dispatch(QdTableActions.setPageParams({ tableId: this.tableId, pageIndex, pageSize, totalCount }));\n  }\n\n  setupSort(columns: QdTableConfigColumn<T>[]): void {\n    this.store.dispatch(QdTableActions.setupSort({ tableId: this.tableId, columns }));\n  }\n\n  setSort(column: string, direction: QdSortDirection): void {\n    this.store.dispatch(QdTableActions.setSort({ tableId: this.tableId, column, direction }));\n  }\n\n  updateSort(column: string, direction: QdSortDirection): void {\n    this.store.dispatch(QdTableActions.updateSort({ tableId: this.tableId, column, direction }));\n  }\n\n  setRequestState(requestState: QdTableRequestState): void {\n    this.store.dispatch(QdTableActions.setRequestState({ tableId: this.tableId, requestState }));\n  }\n\n  connect(\n    connectorName: string,\n    connectorState: QdTableConnectorState,\n    connectorCriteria: QdTableConnectorCriteria\n  ): void {\n    this.store.dispatch(\n      QdTableActions.connect({ tableId: this.tableId, connectorCriteria, connectorName, connectorState })\n    );\n  }\n\n  resetConnectorStates(): void {\n    this.store.dispatch(QdTableActions.resetConnectorStates({ tableId: this.tableId }));\n  }\n\n  deleteTableState(): void {\n    this.store.dispatch(QdTableActions.deleteTableState({ tableId: this.tableId }));\n  }\n\n  /**\n   * Selects\n   */\n  table$(): Observable<QdTableState<string> | undefined> {\n    return this.store.select(this.tableStoreSelectorService.table());\n  }\n\n  tableDataEntries$(): Observable<QdTableData<any> | QdTreeData<any>> {\n    return this.store.select(this.tableStoreSelectorService.tableDataEntries());\n  }\n\n  selectedRows$(): Observable<QdTableRowIdentifier[]> {\n    return this.store\n      .select(this.tableStoreSelectorService.selectedRows())\n      .pipe(filter(selectedRows => selectedRows !== undefined));\n  }\n\n  isTableRowSelected$(rowIndex: number): Observable<boolean> {\n    return this.store.select(this.tableStoreSelectorService.isTableRowSelected(rowIndex));\n  }\n\n  recentSecondaryAction$(): Observable<QdTableRecentSecondaryAction<T> | undefined> {\n    return this.store\n      .select(this.tableStoreSelectorService.recentSecondaryAction())\n      .pipe(filter(action => action?.rowData !== undefined));\n  }\n\n  tableRow$(rowIndex: number): Observable<QdTableDataRow<T> | undefined> {\n    return this.store.select(this.tableStoreSelectorService.tableRow(rowIndex));\n  }\n\n  canPageBackward$(): Observable<boolean> {\n    return this.store.select(this.tableStoreSelectorService.canPageBackward());\n  }\n\n  canPageForward$(): Observable<boolean> {\n    return this.store.select(this.tableStoreSelectorService.canPageForward());\n  }\n\n  pageInfo$(): Observable<QdTablePaginatorCurrentPage | undefined> {\n    return this.store.select(this.tableStoreSelectorService.pageInfo());\n  }\n\n  pageSize$(): Observable<number> {\n    return this.store.select(this.tableStoreSelectorService.pageSize());\n  }\n\n  totalCount$(): Observable<number> {\n    return this.store.select(this.tableStoreSelectorService.totalCount());\n  }\n\n  pageChangeInfo$(): Observable<\n    { pageIndex: number; pageSize: number; requestState: QdTableRequestState } | undefined\n  > {\n    return this.store.select(this.tableStoreSelectorService.pageChangeInfo());\n  }\n\n  columnSortDirection$(column: string): Observable<QdSortDirection> {\n    return this.store.select(this.tableStoreSelectorService.columnSortDirection(column));\n  }\n\n  selectIsLoading$(): Observable<boolean> {\n    return this.store.select(this.tableStoreSelectorService.selectIsLoading());\n  }\n\n  selectDataResolutionCriteria$(): Observable<QdTableDataResolutionCriteria<T>> {\n    return this.store.select(this.tableStoreSelectorService.selectDataResolutionCriteria());\n  }\n\n  selectConnectorState$(connectorName: string): Observable<QdTableConnectorState> {\n    return this.store.select(this.tableStoreSelectorService.selectConnectorState(connectorName));\n  }\n}\n"]}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-store.service.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/table/store/table-store.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAEpC,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AASxC,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAYjD,OAAO,EAAE,2BAA2B,EAAE,MAAM,gCAAgC,CAAC;;;;AAI7E,MAAM,OAAO,mBAAmB;IAIX;IACA;IAJnB,OAAO,GAAG,EAAE,CAAC;IAEb,YACmB,KAA6B,EAC7B,yBAAsD;QADtD,UAAK,GAAL,KAAK,CAAwB;QAC7B,8BAAyB,GAAzB,yBAAyB,CAA6B;IACtE,CAAC;IAEJ,IAAI;QACF,IAAI,CAAC,yBAAyB,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;IACxD,CAAC;IAED;;OAEG;IACH,cAAc,CACZ,IAAoC,EACpC,WAAoB,EACpB,UAA8B,EAC9B,aAAa,GAAG,KAAK;QAErB,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,cAAc,CAAC,cAAc,CAAC;YAC5B,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,IAAI;YACJ,WAAW;YACX,UAAU;YACV,aAAa;SACd,CAAC,CACH,CAAC;IACJ,CAAC;IAED,0BAA0B,CAAC,YAAoC;QAC7D,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,cAAc,CAAC,0BAA0B,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,YAAY,EAAE,CAAC,GAAG,YAAY,CAAC,EAAE,CAAC,CACtG,CAAC;IACJ,CAAC;IAED,oBAAoB,CAAC,IAAoC;QACvD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,oBAAoB,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;IAC5F,CAAC;IAED,6BAA6B,CAAC,QAAgB;QAC5C,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,6BAA6B,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;IACzG,CAAC;IAED,mCAAmC,CAAC,QAAgB;QAClD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,mCAAmC,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;IAC/G,CAAC;IAED,+BAA+B,CAAC,QAAgB;QAC9C,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,+BAA+B,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;IAC3G,CAAC;IAED,qCAAqC,CAAC,MAAqD;QACzF,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,cAAc,CAAC,qCAAqC,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,qBAAqB,EAAE,MAAM,EAAE,CAAC,CAC/G,CAAC;IACJ,CAAC;IAED,eAAe,CAAC,QAAgB;QAC9B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,eAAe,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;IAC3F,CAAC;IAED,OAAO,CAAC,SAAiB,EAAE,QAAgB,EAAE,UAAkB,EAAE,IAAyB;QACxF,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;IAChH,CAAC;IAED,WAAW,CAAC,QAAgB;QAC1B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,WAAW,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;IACvF,CAAC;IAED,aAAa,CAAC,SAAiB,EAAE,QAAgB,EAAE,UAAkB;QACnE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,aAAa,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;IAChH,CAAC;IAED,SAAS,CAAC,OAAiC;QACzC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC;IACpF,CAAC;IAED,OAAO,CAAC,MAAc,EAAE,SAA0B;QAChD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;IAC5F,CAAC;IAED,UAAU,CAAC,MAAc,EAAE,SAA0B;QACnD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;IAC/F,CAAC;IAED,eAAe,CAAC,YAAiC;QAC/C,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,eAAe,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;IAC/F,CAAC;IAED,OAAO,CACL,aAAqB,EACrB,cAAqC,EACrC,iBAA2C;QAE3C,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,cAAc,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,iBAAiB,EAAE,aAAa,EAAE,cAAc,EAAE,CAAC,CACpG,CAAC;IACJ,CAAC;IAED,oBAAoB;QAClB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,oBAAoB,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;IACtF,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,CAAC,gBAAgB,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;IAClF,CAAC;IAED;;OAEG;IACH,MAAM;QACJ,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,KAAK,EAAE,CAAC,CAAC;IACnE,CAAC;IAED,iBAAiB;QACf,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,gBAAgB,EAAE,CAAC,CAAC;IAC9E,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,KAAK;aACd,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,YAAY,EAAE,CAAC;aACrD,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC,YAAY,KAAK,SAAS,CAAC,CAAC,CAAC;IAC9D,CAAC;IAED,mBAAmB,CAAC,QAAgB;QAClC,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC,CAAC;IACxF,CAAC;IAED,sBAAsB;QACpB,OAAO,IAAI,CAAC,KAAK;aACd,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,qBAAqB,EAAE,CAAC;aAC9D,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC;IAC3D,CAAC;IAED,SAAS,CAAC,QAAgB;QACxB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC9E,CAAC;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,eAAe,EAAE,CAAC,CAAC;IAC7E,CAAC;IAED,eAAe;QACb,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,cAAc,EAAE,CAAC,CAAC;IAC5E,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,QAAQ,EAAE,CAAC,CAAC;IACtE,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,QAAQ,EAAE,CAAC,CAAC;IACtE,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,UAAU,EAAE,CAAC,CAAC;IACxE,CAAC;IAED,eAAe;QAGb,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,cAAc,EAAE,CAAC,CAAC;IAC5E,CAAC;IAED,oBAAoB,CAAC,MAAc;QACjC,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC;IACvF,CAAC;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,eAAe,EAAE,CAAC,CAAC;IAC7E,CAAC;IAED,6BAA6B;QAC3B,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,4BAA4B,EAAE,CAAC,CAAC;IAC1F,CAAC;IAED,qBAAqB,CAAC,aAAqB;QACzC,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,oBAAoB,CAAC,aAAa,CAAC,CAAC,CAAC;IAC/F,CAAC;uGArLU,mBAAmB;2GAAnB,mBAAmB;;2FAAnB,mBAAmB;kBAD/B,UAAU","sourcesContent":["import { Injectable } from '@angular/core';\n\nimport { Store } from '@ngrx/store';\nimport { Observable } from 'rxjs';\nimport { filter } from 'rxjs/operators';\nimport {\n  QdTableConnector,\n  QdTableConnectorCriteria,\n  QdTableDataResolutionCriteria,\n  QdTablePaginatorCurrentPage,\n  QdTableState,\n  QdTableStore\n} from '../model/table-store.interface';\nimport { QdTableActions } from './table.actions';\n\nimport { QdTableConnectorState } from '../model/connectors-state.enum';\nimport { QdSortDirection } from '../model/sort-direction.enum';\nimport { QdTableConfigColumn } from '../model/table-config.interface';\nimport { QdTableRequestState } from '../model/table-data-resolver';\nimport {\n  QdTableData,\n  QdTableDataRow,\n  QdTableRecentSecondaryAction,\n  QdTableRowIdentifier\n} from '../model/table-data.interface';\nimport { QdTableStoreSelectorService } from './table-store-selector.service';\nimport { QdTreeData } from '../../tree/model/tree-data.interface';\n\n@Injectable()\nexport class QdTableStoreService<T extends string> {\n  tableId = '';\n\n  constructor(\n    private readonly store: Store<QdTableStore<T>>,\n    private readonly tableStoreSelectorService: QdTableStoreSelectorService\n  ) {}\n\n  init(): void {\n    this.tableStoreSelectorService.tableId = this.tableId;\n  }\n\n  /**\n   * Actions\n   */\n  initTableState(\n    data: QdTableData<T> | QdTreeData<T>,\n    hasResolver: boolean,\n    connectors: QdTableConnector[],\n    hasPagination = false\n  ): void {\n    this.store.dispatch(\n      QdTableActions.initTableState({\n        tableId: this.tableId,\n        data,\n        hasResolver,\n        connectors,\n        hasPagination\n      })\n    );\n  }\n\n  initTableStateSelectedRows(selectedRows: QdTableRowIdentifier[]): void {\n    this.store.dispatch(\n      QdTableActions.initTableStateSelectedRows({ tableId: this.tableId, selectedRows: [...selectedRows] })\n    );\n  }\n\n  updateTableStateData(data: QdTableData<T> | QdTreeData<T>): void {\n    this.store.dispatch(QdTableActions.updateTableStateData({ tableId: this.tableId, data }));\n  }\n\n  updateTableStateRowToSelected(rowIndex: number): void {\n    this.store.dispatch(QdTableActions.updateTableStateRowToSelected({ tableId: this.tableId, rowIndex }));\n  }\n\n  updateTableStateSingleRowToSelected(rowIndex: number): void {\n    this.store.dispatch(QdTableActions.updateTableStateSingleRowToSelected({ tableId: this.tableId, rowIndex }));\n  }\n\n  updateTableStateRowToUnselected(rowIndex: number): void {\n    this.store.dispatch(QdTableActions.updateTableStateRowToUnselected({ tableId: this.tableId, rowIndex }));\n  }\n\n  updateTableStateRecentSecondaryAction(action: QdTableRecentSecondaryAction<any> | undefined): void {\n    this.store.dispatch(\n      QdTableActions.updateTableStateRecentSecondaryAction({ tableId: this.tableId, recentSecondaryAction: action })\n    );\n  }\n\n  setupPagination(pageSize: number): void {\n    this.store.dispatch(QdTableActions.setupPagination({ tableId: this.tableId, pageSize }));\n  }\n\n  setPage(pageIndex: number, pageSize: number, totalCount: number, data: QdTableData<string>): void {\n    this.store.dispatch(QdTableActions.setPage({ tableId: this.tableId, pageIndex, pageSize, totalCount, data }));\n  }\n\n  setPageSize(pageSize: number): void {\n    this.store.dispatch(QdTableActions.setPageSize({ tableId: this.tableId, pageSize }));\n  }\n\n  setPageParams(pageIndex: number, pageSize: number, totalCount: number): void {\n    this.store.dispatch(QdTableActions.setPageParams({ tableId: this.tableId, pageIndex, pageSize, totalCount }));\n  }\n\n  setupSort(columns: QdTableConfigColumn<T>[]): void {\n    this.store.dispatch(QdTableActions.setupSort({ tableId: this.tableId, columns }));\n  }\n\n  setSort(column: string, direction: QdSortDirection): void {\n    this.store.dispatch(QdTableActions.setSort({ tableId: this.tableId, column, direction }));\n  }\n\n  updateSort(column: string, direction: QdSortDirection): void {\n    this.store.dispatch(QdTableActions.updateSort({ tableId: this.tableId, column, direction }));\n  }\n\n  setRequestState(requestState: QdTableRequestState): void {\n    this.store.dispatch(QdTableActions.setRequestState({ tableId: this.tableId, requestState }));\n  }\n\n  connect(\n    connectorName: string,\n    connectorState: QdTableConnectorState,\n    connectorCriteria: QdTableConnectorCriteria\n  ): void {\n    this.store.dispatch(\n      QdTableActions.connect({ tableId: this.tableId, connectorCriteria, connectorName, connectorState })\n    );\n  }\n\n  resetConnectorStates(): void {\n    this.store.dispatch(QdTableActions.resetConnectorStates({ tableId: this.tableId }));\n  }\n\n  deleteTableState(): void {\n    this.store.dispatch(QdTableActions.deleteTableState({ tableId: this.tableId }));\n  }\n\n  /**\n   * Selects\n   */\n  table$(): Observable<QdTableState<string> | undefined> {\n    return this.store.select(this.tableStoreSelectorService.table());\n  }\n\n  tableDataEntries$(): Observable<QdTableData<any> | QdTreeData<any>> {\n    return this.store.select(this.tableStoreSelectorService.tableDataEntries());\n  }\n\n  selectedRows$(): Observable<QdTableRowIdentifier[]> {\n    return this.store\n      .select(this.tableStoreSelectorService.selectedRows())\n      .pipe(filter(selectedRows => selectedRows !== undefined));\n  }\n\n  isTableRowSelected$(rowIndex: number): Observable<boolean> {\n    return this.store.select(this.tableStoreSelectorService.isTableRowSelected(rowIndex));\n  }\n\n  recentSecondaryAction$(): Observable<QdTableRecentSecondaryAction<T> | undefined> {\n    return this.store\n      .select(this.tableStoreSelectorService.recentSecondaryAction())\n      .pipe(filter(action => action?.rowData !== undefined));\n  }\n\n  tableRow$(rowIndex: number): Observable<QdTableDataRow<T> | undefined> {\n    return this.store.select(this.tableStoreSelectorService.tableRow(rowIndex));\n  }\n\n  canPageBackward$(): Observable<boolean> {\n    return this.store.select(this.tableStoreSelectorService.canPageBackward());\n  }\n\n  canPageForward$(): Observable<boolean> {\n    return this.store.select(this.tableStoreSelectorService.canPageForward());\n  }\n\n  pageInfo$(): Observable<QdTablePaginatorCurrentPage | undefined> {\n    return this.store.select(this.tableStoreSelectorService.pageInfo());\n  }\n\n  pageSize$(): Observable<number> {\n    return this.store.select(this.tableStoreSelectorService.pageSize());\n  }\n\n  totalCount$(): Observable<number> {\n    return this.store.select(this.tableStoreSelectorService.totalCount());\n  }\n\n  pageChangeInfo$(): Observable<\n    { pageIndex: number; pageSize: number; requestState: QdTableRequestState } | undefined\n  > {\n    return this.store.select(this.tableStoreSelectorService.pageChangeInfo());\n  }\n\n  columnSortDirection$(column: string): Observable<QdSortDirection> {\n    return this.store.select(this.tableStoreSelectorService.columnSortDirection(column));\n  }\n\n  selectIsLoading$(): Observable<boolean> {\n    return this.store.select(this.tableStoreSelectorService.selectIsLoading());\n  }\n\n  selectDataResolutionCriteria$(): Observable<QdTableDataResolutionCriteria<T> | undefined> {\n    return this.store.select(this.tableStoreSelectorService.selectDataResolutionCriteria());\n  }\n\n  selectConnectorState$(connectorName: string): Observable<QdTableConnectorState> {\n    return this.store.select(this.tableStoreSelectorService.selectConnectorState(connectorName));\n  }\n}\n"]}
|
|
@@ -263,11 +263,11 @@ export class QdTableComponent {
|
|
|
263
263
|
}
|
|
264
264
|
ngOnInit() {
|
|
265
265
|
this.tableStoreService.tableId = this.config.uid || uuid();
|
|
266
|
-
this.resolverService.init(this.config.refreshOnLanguageChange, this.hasPagination);
|
|
267
266
|
this.tableStoreService.init();
|
|
268
267
|
this.tableStoreService.initTableState(this._data, this.hasResolver, this._connectors, this.hasPagination);
|
|
269
268
|
this.tableStoreService.updateTableStateRecentSecondaryAction(undefined);
|
|
270
269
|
this.tableStoreService.setupSort(this.config.columns);
|
|
270
|
+
this.resolverService.init(this.config.refreshOnLanguageChange, this.hasPagination);
|
|
271
271
|
this.data$ = this.tableStoreService.tableDataEntries$();
|
|
272
272
|
this.mapColumnFillsWidth();
|
|
273
273
|
this.validateConfig();
|
|
@@ -488,4 +488,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
488
488
|
type: HostBinding,
|
|
489
489
|
args: ['attr.data-test-id']
|
|
490
490
|
}] } });
|
|
491
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../libs/qd-ui/src/lib/table/table.component.ts","../../../../../libs/qd-ui/src/lib/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { firstValueFrom, merge, NEVER, Observable, of, Subscription } from 'rxjs';\nimport { catchError, filter, map, take } from 'rxjs/operators';\nimport { v4 as uuid } from 'uuid';\n\nimport { QdBreakpointService } from '../core/services/breakpoint.service';\nimport { QdTableEmptyStateService } from './services/empty-state.service';\nimport { QdTableFillingWidthService } from './services/filling-width.service';\nimport { QdTableResolverService } from './services/resolver.service';\nimport { QdTableResponsiveRowService } from './services/responsive-row.service';\nimport { QdTableRowSelectionService } from './services/row-selection.service';\nimport { QdTableSecondaryActionsService } from './services/secondary-actions.service';\nimport { QdTableStoreSelectorService } from './store/table-store-selector.service';\nimport { QdTableStoreService } from './store/table-store.service';\n\nimport { QdTableDataResolver } from './model/table-data-resolver';\nimport { QD_TABLE_DATA_RESOLVER_TOKEN } from './model/table-data-resolver.token';\n\nimport { QdTableConfig, QdTableFillingColumn } from './model/table-config.interface';\nimport { QdTableData, QdTableRecentSecondaryAction } from './model/table-data.interface';\nimport { QdTableSelectedRows } from './model/table-row-selection.interface';\nimport { QdTableActionResult, QdTableRefreshConfig } from './model/table-config-actions.interface';\nimport { QdTableConnector, QdTableConnectorCriteria, QdTableState } from './model/table-store.interface';\nimport { QdTableConnectorState } from './model/connectors-state.enum';\nimport { QdPaginatorDirection } from './model/paginator-direction.enum';\nimport { QdTablePaginatorComponent } from './paginator/table-paginator.component';\nimport { EventName, QdPushEventsService } from '../core/services/push-events.service';\nimport { QdTableExternalActionResultService } from './services/external-action-result.service';\n\n/**\n * QdTableComponent is a responsive and highly configurable table component designed for effective data display and user interaction.\n * It supports pagination, sorting, actions, selections, and customizable columns.\n *\n * #### **Features**\n * - **RWD Ready**: Automatically adapts to various screen sizes.\n * - **Custom Columns**: Define content types like text, date, chip, or icon.\n * - **Pagination & Sorting**: Supports data pagination and column sorting. Pagination is optional.\n * - **Row Selections**: Single or multiple row selection.\n * - **Actions**: Primary and secondary row actions with refresh support.\n * - **Internationalization (i18ns)**: Localize column headers and specific content types (e.g., text, chip).\n * - **Section Toolbar Communication**: Communicate with the QLS for search and filtering.\n *\n * #### **Basic Usage**\n *\n * ```typescript\n * type ColumnDefinition = 'name' | 'age' | 'active';\n *\n * config: QdTableConfig<ColumnDefinition> = {\n *   columns: [\n *     { column: 'name', type: 'text' },\n *     { column: 'age', type: 'integer' },\n *     { column: 'active', type: 'boolean' }\n *   ]\n * };\n *\n * data: QdTableData<ColumnDefinition> = [\n *   { name: 'Alice', age: 30, active: true },\n *   { name: 'Bob', age: 25, active: false }\n * ];\n * ```\n *\n * ```html\n * <qd-table [config]=\"config\" [data]=\"data\"></qd-table>\n * ```\n *\n * #### **Resolver, Pagination, and Sorting**\n *\n * Load data dynamically, manage pagination, and enable column sorting using Quadrel's interface and injection token.\n *\n * Pagination is optional. If not configured, the full dataset is handled client-side.\n *\n * ```typescript\n * @Injectable()\n * export class MyTableResolver implements QdTableDataResolver<ColumnDefinition> {\n *   resolve(criteria: QdTableDataResolverProps<ColumnDefinition>): Observable<QdTableResolvedData<ColumnDefinition>> {\n *     // custom implementation here\n *   }\n * }\n * ```\n *\n * ```typescript\n * @Component({\n *   selector: 'my-table',\n *   template: '<qd-table [config]=\"config\"></qd-table>',\n *   providers: [\n *     {\n *       provide: QD_TABLE_DATA_RESOLVER_TOKEN,\n *       useClass: MyTableResolver\n *     }\n *   ]\n * })\n * class MyTableComponent {\n *   config: QdTableConfig<ColumnDefinition> = {\n *     columns: [\n *       { column: 'name', type: 'text', sort: { direction: 'asc' } },\n *       { column: 'age', type: 'integer', sort: {} },\n *       { column: 'active', type: 'boolean' }\n *     ],\n *     pagination: {\n *       pageSizes: [10, 20, 50],\n *       pageSizeDefault: 10\n *     } // ← omit this section to disable pagination\n *   };\n * }\n * ```\n *\n * #### **Selections and Actions**\n *\n * Configure row selections and trigger primary or secondary actions.\n *\n * ```typescript\n * config: QdTableConfig<ColumnDefinition> = {\n *   columns: [\n *     { column: 'name', type: 'text' },\n *     { column: 'age', type: 'integer' },\n *     { column: 'active', type: 'boolean' }\n *   ],\n *   selection: {\n *     type: 'multiSelect',\n *     handler: (selectedRows) => select(selectedRows)\n *   },\n *   secondaryActions: [\n *     {\n *       type: 'edit',\n *       handler: ({ rowData }) => edit(rowData)\n *     },\n *     {\n *       type: 'delete',\n *       isDisabled: (row) => !row.active,\n *       handler: ({ rowData }) => delete(rowData)\n *     }\n *   ]\n * };\n * ```\n */\n@Component({\n  selector: 'qd-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table-common.scss'],\n  providers: [\n    QdTableStoreService,\n    QdTableStoreSelectorService,\n    QdTableEmptyStateService,\n    QdTableSecondaryActionsService,\n    QdTableResponsiveRowService,\n    QdTableRowSelectionService,\n    QdTableFillingWidthService,\n    QdTableResolverService,\n    QdTableExternalActionResultService\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    '[class.qd-table]': 'true',\n    '[class.main-column-fills-width]': 'whichColumnFillsWidth === \"main\"',\n    '[class.last-column-fills-width]': 'whichColumnFillsWidth === \"last\"',\n    '[class.harmonized]': 'whichColumnFillsWidth === \"harmonized\"',\n    '[attr.data-qd-no-horizontal-padding-small]': 'true'\n  }\n})\nexport class QdTableComponent<T extends string> implements OnInit, OnChanges, OnDestroy {\n  /**\n   * Configuration of the table. The generic type specifies the column definition. <br />\n   *\n   * **Usage:**\n   *\n   * @example\n   * type ColumnDefinition = 'article' | 'mass' | 'documents';\n   * const tableConfig: QdTableConfig<ColumnDefinition> = {\n   *   columns: [\n   *     {\n   *       column: 'article',\n   *       type: 'text'\n   *     },\n   *     {\n   *       column: 'mass',\n   *       type: 'integer'\n   *     },\n   *     {\n   *       column: 'documents',\n   *       type: 'boolean'\n   *     }\n   *   ]\n   * }\n   */\n  @Input() config!: QdTableConfig<T>;\n\n  /**\n   * One way to fill the table with data. Another option is to use a resolver, which is needed for pagination, for instance. <br />\n   * The generic type is used for the column definition. <br />\n   *\n   * **Usage:**\n   *\n   * @example\n   * type ColumnDefinition = 'article' | 'mass' | 'documents';\n   * const tableData: QdTableData<ColumnDefinition> = [\n   *   {\n   *     article: 'article one',\n   *     mass: 10,\n   *     documents: true\n   *   },\n   *   {\n   *     article: 'article two',\n   *     mass: 20,\n   *     documents: false\n   *   }\n   * ]\n   */\n  @Input()\n  set data(data: QdTableData<T>) {\n    this._data = data;\n  }\n\n  /**\n   * A static test ID for integration tests can be set. <br />\n   * The value for the HTML attribute [data-test-id].\n   */\n  @Input('data-test-id') testId = 'table';\n\n  /**\n   * Emits an event when an secondary action is triggered. The return value contains the row-specific data. <br />\n   * `secondaryActions` must be defined in the table configuration.\n   *\n   * * @returns EventEmitter with generic type: QdTableRecentSecondaryAction\n   */\n  @Output() secondaryActionOutput = new EventEmitter<QdTableRecentSecondaryAction<T>>();\n\n  /**\n   * Outputs an event when one or more lines are selected. The return value contains the row-specific data. <br />\n   * `multiSelect` or `singleSelect` must be activated in the table configuration.\n   *\n   * * @returns EventEmitter with generic type: QdTableSelectedRows\n   */\n  @Output() selectedRowsOutput = new EventEmitter<QdTableSelectedRows<T>>();\n\n  /**\n   * The event is triggered when the no contents are present. <br />\n   * The `emptyStateView` must be enabled in the table configuration.\n   */\n  @Output() emptyStateActionOutput = new EventEmitter();\n\n  @ViewChild(QdTablePaginatorComponent) paginator?: QdTablePaginatorComponent<T>;\n\n  @HostBinding('attr.data-test-id') get dataTestId(): string {\n    return this.testId + '-' + this.tableStoreService.tableId;\n  }\n\n  data$!: Observable<QdTableData<T> | undefined>;\n  hasData$!: Observable<boolean>;\n  hasEmptyStateView$!: Observable<boolean>;\n\n  private table$!: Observable<QdTableState<string> | undefined>;\n  private _data: QdTableData<T> = [];\n  private _recentSecondaryActionsSubscription?: Subscription;\n  private _rowSelectionServiceSubscription?: Subscription;\n  private _emptyStateActionServiceSubscription?: Subscription;\n  private _breakpointSubscription?: Subscription;\n  private _pushEventsSubscription?: Subscription;\n  private _refreshSubscription?: Subscription;\n  private _connectors: QdTableConnector[] = [];\n\n  get whichColumnFillsWidth(): QdTableFillingColumn {\n    return this.fillingWidthService.whichColumnFillsWidth;\n  }\n\n  get hasResolver(): boolean {\n    return !!this.tableDataResolver;\n  }\n\n  get hasPagination(): boolean {\n    return this.config.hasPagination || !!this.config.pagination;\n  }\n\n  constructor(\n    private element: ElementRef,\n    @Optional() @Inject(QD_TABLE_DATA_RESOLVER_TOKEN) private readonly tableDataResolver: QdTableDataResolver<T>,\n    @Optional() private readonly pushEventsService: QdPushEventsService,\n    private readonly tableStoreService: QdTableStoreService<T>,\n    private readonly secondaryActionsService: QdTableSecondaryActionsService<T>,\n    private readonly rowSelectionService: QdTableRowSelectionService<T>,\n    private readonly emptyStateService: QdTableEmptyStateService,\n    private readonly responsiveRowService: QdTableResponsiveRowService<T>,\n    private readonly fillingWidthService: QdTableFillingWidthService<T>,\n    private readonly breakpointService: QdBreakpointService,\n    private readonly resolverService: QdTableResolverService<T>\n  ) {}\n\n  ngOnInit(): void {\n    this.tableStoreService.tableId = this.config.uid || uuid();\n\n    this.resolverService.init(this.config.refreshOnLanguageChange, this.hasPagination);\n    this.tableStoreService.init();\n    this.tableStoreService.initTableState(this._data, this.hasResolver, this._connectors, this.hasPagination);\n    this.tableStoreService.updateTableStateRecentSecondaryAction(undefined);\n    this.tableStoreService.setupSort(this.config.columns);\n\n    this.data$ = this.tableStoreService.tableDataEntries$() as Observable<QdTableData<T>>;\n\n    this.mapColumnFillsWidth();\n    this.validateConfig();\n\n    this.initializeResponsiveRowService();\n    this.initializeFillingWidthService();\n    this.initializeEmptyStateService();\n    this.initializeRowSelectionService();\n    this.initializeSecondaryActionsService();\n    this.initializePushEventsService();\n    this.initRefresh();\n\n    this.table$ = this.tableStoreService.table$();\n    this.hasData$ = this.data$.pipe(map(state => (state ?? []).length > 0));\n    this.hasEmptyStateView$ = this.hasData$.pipe(\n      map(hasData => !hasData && !!this.config.emptyStateView && !this.config.emptyStateView.disabled)\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (\n      changes['data'] &&\n      !changes['data'].firstChange &&\n      JSON.stringify(changes['data'].previousValue) !== JSON.stringify(changes['data'].currentValue)\n    ) {\n      this.tableStoreService.updateTableStateData(this._data);\n      if (!this.hasPagination) {\n        this.data$ = of(this._data);\n      }\n    }\n\n    if (\n      changes['config'] &&\n      !changes['config'].firstChange &&\n      JSON.stringify(changes['config'].previousValue) !== JSON.stringify(changes['config'].currentValue)\n    ) {\n      this.updateResponsiveRowServiceTableConfig();\n      this.updateFillingWidthServiceTableConfig();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.tableStoreService.updateTableStateRecentSecondaryAction(undefined);\n    this.tableStoreService.resetConnectorStates();\n    this.fillingWidthService.destroy();\n\n    this._recentSecondaryActionsSubscription?.unsubscribe();\n    this._rowSelectionServiceSubscription?.unsubscribe();\n    this._emptyStateActionServiceSubscription?.unsubscribe();\n    this._breakpointSubscription?.unsubscribe();\n    this._pushEventsSubscription?.unsubscribe();\n    this._refreshSubscription?.unsubscribe();\n\n    if (!this.config.uid || this.config.refreshOnPushEvent) this.tableStoreService.deleteTableState();\n  }\n\n  registerConnector(connectorName: string): void {\n    if (!this.tableDataResolver) {\n      console.warn(\n        'QD-UI | QdTable - qdConnectToFilter only works with a resolver. Please inject the resolver using QD_TABLE_DATA_RESOLVER_TOKEN.'\n      );\n\n      return;\n    }\n\n    this._connectors.push({ connectorName, connectorState: QdTableConnectorState.AWAITING });\n  }\n\n  async updateFromConnector(connectorName: string, ConnectorCriteria: QdTableConnectorCriteria): Promise<void> {\n    const connectorState = await firstValueFrom(this.tableStoreService.selectConnectorState$(connectorName));\n    if (connectorState === QdTableConnectorState.ESTABLISHED) {\n      this.paginator?.navigateToPage(QdPaginatorDirection.FirstPage);\n    }\n\n    this.tableStoreService.connect(connectorName, QdTableConnectorState.ESTABLISHED, ConnectorCriteria);\n  }\n\n  private initializeResponsiveRowService(): void {\n    this.responsiveRowService.config = this.config;\n\n    this._breakpointSubscription = this.breakpointService.getMatchingBreakpoint().subscribe(breakpoint => {\n      this.responsiveRowService.currentBreakpoint = breakpoint;\n    });\n  }\n\n  private updateResponsiveRowServiceTableConfig(): void {\n    this.responsiveRowService.config = this.config;\n  }\n\n  private initializeFillingWidthService(): void {\n    this.fillingWidthService.initialize(this.element.nativeElement, this.config);\n  }\n\n  private updateFillingWidthServiceTableConfig(): void {\n    this.fillingWidthService.updateTableConfig(this.config);\n  }\n\n  private initializeEmptyStateService(): void {\n    this.emptyStateService.i18ns = this.config.i18ns;\n\n    this._emptyStateActionServiceSubscription = this.emptyStateService.emptyStateAction$.subscribe(() =>\n      this.emptyStateActionOutput.emit()\n    );\n  }\n\n  private initializeRowSelectionService(): void {\n    this.rowSelectionService.config = this.config;\n\n    this._rowSelectionServiceSubscription = this.rowSelectionService.selectedRows$.subscribe(selectedRows => {\n      this.selectedRowsOutput.emit(selectedRows);\n      this.config.selection?.handler?.(selectedRows);\n    });\n  }\n\n  private initializeSecondaryActionsService(): void {\n    this.secondaryActionsService.configs = this.config.secondaryActions ?? [];\n\n    this._recentSecondaryActionsSubscription = this.tableStoreService\n      .recentSecondaryAction$()\n      .subscribe(recentAction => {\n        if (!recentAction) return;\n\n        this.secondaryActionOutput.emit(recentAction);\n\n        const action = this.config.secondaryActions?.find(a => a.type === recentAction.type);\n        if (!action?.handler)\n          return console.warn('QD-UI | QdTable - No handler defined for secondary action:', recentAction.type);\n\n        const result = action.handler(recentAction);\n        if (action.refresh?.isEnabled) this.processSecondaryActionRefresh(result, action.refresh);\n      });\n  }\n\n  private initializePushEventsService(): void {\n    if (!this.config.refreshOnPushEvent) return;\n\n    if (!this.config.uid) {\n      console.error(\n        'QD-UI | QdTable - A uid has to be defined when refreshOnPushEvent is enabled. ' +\n          'The table uid has to match the path of the server side event.'\n      );\n\n      return;\n    }\n\n    if (!this.pushEventsService.isConnectedOrConnecting()) {\n      console.error(\n        'QD-UI | QdTable - You have to connect the QdPushEventsService on your own ' +\n          'if you enable the refreshOnPushEvent flag in the table.'\n      );\n\n      return;\n    }\n\n    const events = [...(this.config?.refreshingEvents || []), 'RESOURCE_UPDATED'] as EventName[];\n    const combinedEvents$ = merge(...events.map(eventName => this.pushEventsService.observe(eventName)));\n\n    this._pushEventsSubscription = combinedEvents$\n      .pipe(\n        filter(messageEvent => {\n          try {\n            const data = JSON.parse(messageEvent.data);\n            return data.path.includes(this.config.uid);\n          } catch (error) {\n            console.warn('Failed to process messageEvent:', error);\n            return false;\n          }\n        }),\n        catchError(error => {\n          console.error('Error in event stream:', error);\n          return NEVER;\n        })\n      )\n      .subscribe(() => this.triggerRefresh());\n  }\n\n  private processSecondaryActionRefresh(result: QdTableActionResult, refreshConfig: QdTableRefreshConfig): void {\n    if (result instanceof Observable) {\n      result.pipe(take(1)).subscribe(success => success && this.triggerRefresh(refreshConfig.page));\n\n      return;\n    }\n\n    this.triggerRefresh(refreshConfig.page);\n  }\n\n  private initRefresh(): void {\n    this._refreshSubscription = this.config.refresh?.subscribe(value => this.triggerRefresh(value));\n  }\n\n  private triggerRefresh(pageIndex?: number): void {\n    this.resolverService.refresh(pageIndex !== undefined ? { pageIndex } : {});\n  }\n\n  private validateConfig(): void {\n    if (!this.config.i18ns) {\n      console.warn('QD-UI | QdTable - No translations available for the secondaryActions.');\n    }\n  }\n\n  /**\n   * @description Can be deleted when the property \"mainColumnNotFillingWidth\" is dropped.\n   *\n   * * @deprecated\n   */\n  private mapColumnFillsWidth(): void {\n    if (!this.config.mainColumnNotFillingWidth) return;\n\n    console.warn(\n      'QD-UI | QdTable - The config key \"mainColumnNotFillingWidth\" is deprecated. Please use \"whichColumnFillsWidth\" instead.'\n    );\n\n    if (this.config.whichColumnFillsWidth) return;\n\n    this.config.whichColumnFillsWidth = 'none';\n  }\n}\n","<table [class]=\"'qd-table__table'\">\n  <tr qd-table-head [config]=\"config\" [data-test-id]=\"testId\"></tr>\n  <tbody qd-table-body [config]=\"config\" [data]=\"(data$ | async) ?? []\" [data-test-id]=\"testId\"></tbody>\n</table>\n\n<qd-table-paginator [config]=\"config\" [data-test-id]=\"testId\" *ngIf=\"hasPagination\"></qd-table-paginator>\n<qd-table-empty-state *ngIf=\"hasEmptyStateView$ | async\" [config]=\"config.emptyStateView\"></qd-table-empty-state>\n"]}
|
|
491
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../libs/qd-ui/src/lib/table/table.component.ts","../../../../../libs/qd-ui/src/lib/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { firstValueFrom, merge, NEVER, Observable, of, Subscription } from 'rxjs';\nimport { catchError, filter, map, take } from 'rxjs/operators';\nimport { v4 as uuid } from 'uuid';\n\nimport { QdBreakpointService } from '../core/services/breakpoint.service';\nimport { QdTableEmptyStateService } from './services/empty-state.service';\nimport { QdTableFillingWidthService } from './services/filling-width.service';\nimport { QdTableResolverService } from './services/resolver.service';\nimport { QdTableResponsiveRowService } from './services/responsive-row.service';\nimport { QdTableRowSelectionService } from './services/row-selection.service';\nimport { QdTableSecondaryActionsService } from './services/secondary-actions.service';\nimport { QdTableStoreSelectorService } from './store/table-store-selector.service';\nimport { QdTableStoreService } from './store/table-store.service';\n\nimport { QdTableDataResolver } from './model/table-data-resolver';\nimport { QD_TABLE_DATA_RESOLVER_TOKEN } from './model/table-data-resolver.token';\n\nimport { QdTableConfig, QdTableFillingColumn } from './model/table-config.interface';\nimport { QdTableData, QdTableRecentSecondaryAction } from './model/table-data.interface';\nimport { QdTableSelectedRows } from './model/table-row-selection.interface';\nimport { QdTableActionResult, QdTableRefreshConfig } from './model/table-config-actions.interface';\nimport { QdTableConnector, QdTableConnectorCriteria, QdTableState } from './model/table-store.interface';\nimport { QdTableConnectorState } from './model/connectors-state.enum';\nimport { QdPaginatorDirection } from './model/paginator-direction.enum';\nimport { QdTablePaginatorComponent } from './paginator/table-paginator.component';\nimport { EventName, QdPushEventsService } from '../core/services/push-events.service';\nimport { QdTableExternalActionResultService } from './services/external-action-result.service';\n\n/**\n * QdTableComponent is a responsive and highly configurable table component designed for effective data display and user interaction.\n * It supports pagination, sorting, actions, selections, and customizable columns.\n *\n * #### **Features**\n * - **RWD Ready**: Automatically adapts to various screen sizes.\n * - **Custom Columns**: Define content types like text, date, chip, or icon.\n * - **Pagination & Sorting**: Supports data pagination and column sorting. Pagination is optional.\n * - **Row Selections**: Single or multiple row selection.\n * - **Actions**: Primary and secondary row actions with refresh support.\n * - **Internationalization (i18ns)**: Localize column headers and specific content types (e.g., text, chip).\n * - **Section Toolbar Communication**: Communicate with the QLS for search and filtering.\n *\n * #### **Basic Usage**\n *\n * ```typescript\n * type ColumnDefinition = 'name' | 'age' | 'active';\n *\n * config: QdTableConfig<ColumnDefinition> = {\n *   columns: [\n *     { column: 'name', type: 'text' },\n *     { column: 'age', type: 'integer' },\n *     { column: 'active', type: 'boolean' }\n *   ]\n * };\n *\n * data: QdTableData<ColumnDefinition> = [\n *   { name: 'Alice', age: 30, active: true },\n *   { name: 'Bob', age: 25, active: false }\n * ];\n * ```\n *\n * ```html\n * <qd-table [config]=\"config\" [data]=\"data\"></qd-table>\n * ```\n *\n * #### **Resolver, Pagination, and Sorting**\n *\n * Load data dynamically, manage pagination, and enable column sorting using Quadrel's interface and injection token.\n *\n * Pagination is optional. If not configured, the full dataset is handled client-side.\n *\n * ```typescript\n * @Injectable()\n * export class MyTableResolver implements QdTableDataResolver<ColumnDefinition> {\n *   resolve(criteria: QdTableDataResolverProps<ColumnDefinition>): Observable<QdTableResolvedData<ColumnDefinition>> {\n *     // custom implementation here\n *   }\n * }\n * ```\n *\n * ```typescript\n * @Component({\n *   selector: 'my-table',\n *   template: '<qd-table [config]=\"config\"></qd-table>',\n *   providers: [\n *     {\n *       provide: QD_TABLE_DATA_RESOLVER_TOKEN,\n *       useClass: MyTableResolver\n *     }\n *   ]\n * })\n * class MyTableComponent {\n *   config: QdTableConfig<ColumnDefinition> = {\n *     columns: [\n *       { column: 'name', type: 'text', sort: { direction: 'asc' } },\n *       { column: 'age', type: 'integer', sort: {} },\n *       { column: 'active', type: 'boolean' }\n *     ],\n *     pagination: {\n *       pageSizes: [10, 20, 50],\n *       pageSizeDefault: 10\n *     } // ← omit this section to disable pagination\n *   };\n * }\n * ```\n *\n * #### **Selections and Actions**\n *\n * Configure row selections and trigger primary or secondary actions.\n *\n * ```typescript\n * config: QdTableConfig<ColumnDefinition> = {\n *   columns: [\n *     { column: 'name', type: 'text' },\n *     { column: 'age', type: 'integer' },\n *     { column: 'active', type: 'boolean' }\n *   ],\n *   selection: {\n *     type: 'multiSelect',\n *     handler: (selectedRows) => select(selectedRows)\n *   },\n *   secondaryActions: [\n *     {\n *       type: 'edit',\n *       handler: ({ rowData }) => edit(rowData)\n *     },\n *     {\n *       type: 'delete',\n *       isDisabled: (row) => !row.active,\n *       handler: ({ rowData }) => delete(rowData)\n *     }\n *   ]\n * };\n * ```\n */\n@Component({\n  selector: 'qd-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table-common.scss'],\n  providers: [\n    QdTableStoreService,\n    QdTableStoreSelectorService,\n    QdTableEmptyStateService,\n    QdTableSecondaryActionsService,\n    QdTableResponsiveRowService,\n    QdTableRowSelectionService,\n    QdTableFillingWidthService,\n    QdTableResolverService,\n    QdTableExternalActionResultService\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    '[class.qd-table]': 'true',\n    '[class.main-column-fills-width]': 'whichColumnFillsWidth === \"main\"',\n    '[class.last-column-fills-width]': 'whichColumnFillsWidth === \"last\"',\n    '[class.harmonized]': 'whichColumnFillsWidth === \"harmonized\"',\n    '[attr.data-qd-no-horizontal-padding-small]': 'true'\n  }\n})\nexport class QdTableComponent<T extends string> implements OnInit, OnChanges, OnDestroy {\n  /**\n   * Configuration of the table. The generic type specifies the column definition. <br />\n   *\n   * **Usage:**\n   *\n   * @example\n   * type ColumnDefinition = 'article' | 'mass' | 'documents';\n   * const tableConfig: QdTableConfig<ColumnDefinition> = {\n   *   columns: [\n   *     {\n   *       column: 'article',\n   *       type: 'text'\n   *     },\n   *     {\n   *       column: 'mass',\n   *       type: 'integer'\n   *     },\n   *     {\n   *       column: 'documents',\n   *       type: 'boolean'\n   *     }\n   *   ]\n   * }\n   */\n  @Input() config!: QdTableConfig<T>;\n\n  /**\n   * One way to fill the table with data. Another option is to use a resolver, which is needed for pagination, for instance. <br />\n   * The generic type is used for the column definition. <br />\n   *\n   * **Usage:**\n   *\n   * @example\n   * type ColumnDefinition = 'article' | 'mass' | 'documents';\n   * const tableData: QdTableData<ColumnDefinition> = [\n   *   {\n   *     article: 'article one',\n   *     mass: 10,\n   *     documents: true\n   *   },\n   *   {\n   *     article: 'article two',\n   *     mass: 20,\n   *     documents: false\n   *   }\n   * ]\n   */\n  @Input()\n  set data(data: QdTableData<T>) {\n    this._data = data;\n  }\n\n  /**\n   * A static test ID for integration tests can be set. <br />\n   * The value for the HTML attribute [data-test-id].\n   */\n  @Input('data-test-id') testId = 'table';\n\n  /**\n   * Emits an event when an secondary action is triggered. The return value contains the row-specific data. <br />\n   * `secondaryActions` must be defined in the table configuration.\n   *\n   * * @returns EventEmitter with generic type: QdTableRecentSecondaryAction\n   */\n  @Output() secondaryActionOutput = new EventEmitter<QdTableRecentSecondaryAction<T>>();\n\n  /**\n   * Outputs an event when one or more lines are selected. The return value contains the row-specific data. <br />\n   * `multiSelect` or `singleSelect` must be activated in the table configuration.\n   *\n   * * @returns EventEmitter with generic type: QdTableSelectedRows\n   */\n  @Output() selectedRowsOutput = new EventEmitter<QdTableSelectedRows<T>>();\n\n  /**\n   * The event is triggered when the no contents are present. <br />\n   * The `emptyStateView` must be enabled in the table configuration.\n   */\n  @Output() emptyStateActionOutput = new EventEmitter();\n\n  @ViewChild(QdTablePaginatorComponent) paginator?: QdTablePaginatorComponent<T>;\n\n  @HostBinding('attr.data-test-id') get dataTestId(): string {\n    return this.testId + '-' + this.tableStoreService.tableId;\n  }\n\n  data$!: Observable<QdTableData<T> | undefined>;\n  hasData$!: Observable<boolean>;\n  hasEmptyStateView$!: Observable<boolean>;\n\n  private table$!: Observable<QdTableState<string> | undefined>;\n  private _data: QdTableData<T> = [];\n  private _recentSecondaryActionsSubscription?: Subscription;\n  private _rowSelectionServiceSubscription?: Subscription;\n  private _emptyStateActionServiceSubscription?: Subscription;\n  private _breakpointSubscription?: Subscription;\n  private _pushEventsSubscription?: Subscription;\n  private _refreshSubscription?: Subscription;\n  private _connectors: QdTableConnector[] = [];\n\n  get whichColumnFillsWidth(): QdTableFillingColumn {\n    return this.fillingWidthService.whichColumnFillsWidth;\n  }\n\n  get hasResolver(): boolean {\n    return !!this.tableDataResolver;\n  }\n\n  get hasPagination(): boolean {\n    return this.config.hasPagination || !!this.config.pagination;\n  }\n\n  constructor(\n    private element: ElementRef,\n    @Optional() @Inject(QD_TABLE_DATA_RESOLVER_TOKEN) private readonly tableDataResolver: QdTableDataResolver<T>,\n    @Optional() private readonly pushEventsService: QdPushEventsService,\n    private readonly tableStoreService: QdTableStoreService<T>,\n    private readonly secondaryActionsService: QdTableSecondaryActionsService<T>,\n    private readonly rowSelectionService: QdTableRowSelectionService<T>,\n    private readonly emptyStateService: QdTableEmptyStateService,\n    private readonly responsiveRowService: QdTableResponsiveRowService<T>,\n    private readonly fillingWidthService: QdTableFillingWidthService<T>,\n    private readonly breakpointService: QdBreakpointService,\n    private readonly resolverService: QdTableResolverService<T>\n  ) {}\n\n  ngOnInit(): void {\n    this.tableStoreService.tableId = this.config.uid || uuid();\n    this.tableStoreService.init();\n    this.tableStoreService.initTableState(this._data, this.hasResolver, this._connectors, this.hasPagination);\n    this.tableStoreService.updateTableStateRecentSecondaryAction(undefined);\n    this.tableStoreService.setupSort(this.config.columns);\n\n    this.resolverService.init(this.config.refreshOnLanguageChange, this.hasPagination);\n\n    this.data$ = this.tableStoreService.tableDataEntries$() as Observable<QdTableData<T>>;\n\n    this.mapColumnFillsWidth();\n    this.validateConfig();\n\n    this.initializeResponsiveRowService();\n    this.initializeFillingWidthService();\n    this.initializeEmptyStateService();\n    this.initializeRowSelectionService();\n    this.initializeSecondaryActionsService();\n    this.initializePushEventsService();\n    this.initRefresh();\n\n    this.table$ = this.tableStoreService.table$();\n    this.hasData$ = this.data$.pipe(map(state => (state ?? []).length > 0));\n    this.hasEmptyStateView$ = this.hasData$.pipe(\n      map(hasData => !hasData && !!this.config.emptyStateView && !this.config.emptyStateView.disabled)\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (\n      changes['data'] &&\n      !changes['data'].firstChange &&\n      JSON.stringify(changes['data'].previousValue) !== JSON.stringify(changes['data'].currentValue)\n    ) {\n      this.tableStoreService.updateTableStateData(this._data);\n      if (!this.hasPagination) {\n        this.data$ = of(this._data);\n      }\n    }\n\n    if (\n      changes['config'] &&\n      !changes['config'].firstChange &&\n      JSON.stringify(changes['config'].previousValue) !== JSON.stringify(changes['config'].currentValue)\n    ) {\n      this.updateResponsiveRowServiceTableConfig();\n      this.updateFillingWidthServiceTableConfig();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.tableStoreService.updateTableStateRecentSecondaryAction(undefined);\n    this.tableStoreService.resetConnectorStates();\n    this.fillingWidthService.destroy();\n\n    this._recentSecondaryActionsSubscription?.unsubscribe();\n    this._rowSelectionServiceSubscription?.unsubscribe();\n    this._emptyStateActionServiceSubscription?.unsubscribe();\n    this._breakpointSubscription?.unsubscribe();\n    this._pushEventsSubscription?.unsubscribe();\n    this._refreshSubscription?.unsubscribe();\n\n    if (!this.config.uid || this.config.refreshOnPushEvent) this.tableStoreService.deleteTableState();\n  }\n\n  registerConnector(connectorName: string): void {\n    if (!this.tableDataResolver) {\n      console.warn(\n        'QD-UI | QdTable - qdConnectToFilter only works with a resolver. Please inject the resolver using QD_TABLE_DATA_RESOLVER_TOKEN.'\n      );\n\n      return;\n    }\n\n    this._connectors.push({ connectorName, connectorState: QdTableConnectorState.AWAITING });\n  }\n\n  async updateFromConnector(connectorName: string, ConnectorCriteria: QdTableConnectorCriteria): Promise<void> {\n    const connectorState = await firstValueFrom(this.tableStoreService.selectConnectorState$(connectorName));\n    if (connectorState === QdTableConnectorState.ESTABLISHED) {\n      this.paginator?.navigateToPage(QdPaginatorDirection.FirstPage);\n    }\n\n    this.tableStoreService.connect(connectorName, QdTableConnectorState.ESTABLISHED, ConnectorCriteria);\n  }\n\n  private initializeResponsiveRowService(): void {\n    this.responsiveRowService.config = this.config;\n\n    this._breakpointSubscription = this.breakpointService.getMatchingBreakpoint().subscribe(breakpoint => {\n      this.responsiveRowService.currentBreakpoint = breakpoint;\n    });\n  }\n\n  private updateResponsiveRowServiceTableConfig(): void {\n    this.responsiveRowService.config = this.config;\n  }\n\n  private initializeFillingWidthService(): void {\n    this.fillingWidthService.initialize(this.element.nativeElement, this.config);\n  }\n\n  private updateFillingWidthServiceTableConfig(): void {\n    this.fillingWidthService.updateTableConfig(this.config);\n  }\n\n  private initializeEmptyStateService(): void {\n    this.emptyStateService.i18ns = this.config.i18ns;\n\n    this._emptyStateActionServiceSubscription = this.emptyStateService.emptyStateAction$.subscribe(() =>\n      this.emptyStateActionOutput.emit()\n    );\n  }\n\n  private initializeRowSelectionService(): void {\n    this.rowSelectionService.config = this.config;\n\n    this._rowSelectionServiceSubscription = this.rowSelectionService.selectedRows$.subscribe(selectedRows => {\n      this.selectedRowsOutput.emit(selectedRows);\n      this.config.selection?.handler?.(selectedRows);\n    });\n  }\n\n  private initializeSecondaryActionsService(): void {\n    this.secondaryActionsService.configs = this.config.secondaryActions ?? [];\n\n    this._recentSecondaryActionsSubscription = this.tableStoreService\n      .recentSecondaryAction$()\n      .subscribe(recentAction => {\n        if (!recentAction) return;\n\n        this.secondaryActionOutput.emit(recentAction);\n\n        const action = this.config.secondaryActions?.find(a => a.type === recentAction.type);\n        if (!action?.handler)\n          return console.warn('QD-UI | QdTable - No handler defined for secondary action:', recentAction.type);\n\n        const result = action.handler(recentAction);\n        if (action.refresh?.isEnabled) this.processSecondaryActionRefresh(result, action.refresh);\n      });\n  }\n\n  private initializePushEventsService(): void {\n    if (!this.config.refreshOnPushEvent) return;\n\n    if (!this.config.uid) {\n      console.error(\n        'QD-UI | QdTable - A uid has to be defined when refreshOnPushEvent is enabled. ' +\n          'The table uid has to match the path of the server side event.'\n      );\n\n      return;\n    }\n\n    if (!this.pushEventsService.isConnectedOrConnecting()) {\n      console.error(\n        'QD-UI | QdTable - You have to connect the QdPushEventsService on your own ' +\n          'if you enable the refreshOnPushEvent flag in the table.'\n      );\n\n      return;\n    }\n\n    const events = [...(this.config?.refreshingEvents || []), 'RESOURCE_UPDATED'] as EventName[];\n    const combinedEvents$ = merge(...events.map(eventName => this.pushEventsService.observe(eventName)));\n\n    this._pushEventsSubscription = combinedEvents$\n      .pipe(\n        filter(messageEvent => {\n          try {\n            const data = JSON.parse(messageEvent.data);\n            return data.path.includes(this.config.uid);\n          } catch (error) {\n            console.warn('Failed to process messageEvent:', error);\n            return false;\n          }\n        }),\n        catchError(error => {\n          console.error('Error in event stream:', error);\n          return NEVER;\n        })\n      )\n      .subscribe(() => this.triggerRefresh());\n  }\n\n  private processSecondaryActionRefresh(result: QdTableActionResult, refreshConfig: QdTableRefreshConfig): void {\n    if (result instanceof Observable) {\n      result.pipe(take(1)).subscribe(success => success && this.triggerRefresh(refreshConfig.page));\n\n      return;\n    }\n\n    this.triggerRefresh(refreshConfig.page);\n  }\n\n  private initRefresh(): void {\n    this._refreshSubscription = this.config.refresh?.subscribe(value => this.triggerRefresh(value));\n  }\n\n  private triggerRefresh(pageIndex?: number): void {\n    this.resolverService.refresh(pageIndex !== undefined ? { pageIndex } : {});\n  }\n\n  private validateConfig(): void {\n    if (!this.config.i18ns) {\n      console.warn('QD-UI | QdTable - No translations available for the secondaryActions.');\n    }\n  }\n\n  /**\n   * @description Can be deleted when the property \"mainColumnNotFillingWidth\" is dropped.\n   *\n   * * @deprecated\n   */\n  private mapColumnFillsWidth(): void {\n    if (!this.config.mainColumnNotFillingWidth) return;\n\n    console.warn(\n      'QD-UI | QdTable - The config key \"mainColumnNotFillingWidth\" is deprecated. Please use \"whichColumnFillsWidth\" instead.'\n    );\n\n    if (this.config.whichColumnFillsWidth) return;\n\n    this.config.whichColumnFillsWidth = 'none';\n  }\n}\n","<table [class]=\"'qd-table__table'\">\n  <tr qd-table-head [config]=\"config\" [data-test-id]=\"testId\"></tr>\n  <tbody qd-table-body [config]=\"config\" [data]=\"(data$ | async) ?? []\" [data-test-id]=\"testId\"></tbody>\n</table>\n\n<qd-table-paginator [config]=\"config\" [data-test-id]=\"testId\" *ngIf=\"hasPagination\"></qd-table-paginator>\n<qd-table-empty-state *ngIf=\"hasEmptyStateView$ | async\" [config]=\"config.emptyStateView\"></qd-table-empty-state>\n"]}
|
package/esm2022/lib/tree/row/actions/secondary/menu/tree-row-actions-secondary-menu.component.mjs
CHANGED
|
@@ -52,16 +52,13 @@ export class QdTreeRowActionsSecondaryMenuComponent {
|
|
|
52
52
|
this._destroy$.next();
|
|
53
53
|
this._destroy$.complete();
|
|
54
54
|
}
|
|
55
|
-
handleSecondaryAction(type, index,
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
index,
|
|
63
|
-
rowData: this.rowData
|
|
64
|
-
});
|
|
55
|
+
handleSecondaryAction(type, index, isHidden) {
|
|
56
|
+
if (isHidden)
|
|
57
|
+
return;
|
|
58
|
+
this.tableStoreService.updateTableStateRecentSecondaryAction({
|
|
59
|
+
type,
|
|
60
|
+
index,
|
|
61
|
+
rowData: this.rowData
|
|
65
62
|
});
|
|
66
63
|
}
|
|
67
64
|
initViewMode() {
|
|
@@ -75,11 +72,11 @@ export class QdTreeRowActionsSecondaryMenuComponent {
|
|
|
75
72
|
.subscribe(({ payload }) => this._viewonly$.next(payload.isViewonly));
|
|
76
73
|
}
|
|
77
74
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdTreeRowActionsSecondaryMenuComponent, deps: [{ token: i1.QdTableStoreService }, { token: i2.QdEventBrokerService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
78
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdTreeRowActionsSecondaryMenuComponent, selector: "[qd-tree-row-actions-secondary-menu]", inputs: { rowIndex: "rowIndex", rowData: "rowData", config: "config", testId: "testId" }, ngImport: i0, template: "<ng-container *ngIf=\"hasVisibleActions$ | async\">\n <button\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n [qdPopoverMinWidth]=\"200\"\n class=\"menu-button\"\n [attr.data-test-id]=\"testId + '-toggler'\"\n >\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n\n <ng-template #menu>\n <ng-container *ngFor=\"let action of actions$ | async; let i = index\">\n <button\n *ngIf=\"!action.isHidden\"\n class=\"action-button\"\n (click)=\"handleSecondaryAction(action.type, rowIndex,
|
|
75
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdTreeRowActionsSecondaryMenuComponent, selector: "[qd-tree-row-actions-secondary-menu]", inputs: { rowIndex: "rowIndex", rowData: "rowData", config: "config", testId: "testId" }, ngImport: i0, template: "<ng-container *ngIf=\"hasVisibleActions$ | async\">\n <button\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n [qdPopoverMinWidth]=\"200\"\n class=\"menu-button\"\n [attr.data-test-id]=\"testId + '-toggler'\"\n >\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n\n <ng-template #menu>\n <ng-container *ngFor=\"let action of actions$ | async; let i = index\">\n <button\n *ngIf=\"!action.isHidden\"\n class=\"action-button\"\n (click)=\"handleSecondaryAction(action.type, rowIndex, action.isHidden)\"\n [attr.data-test-id]=\"testId + '-' + i\"\n >\n {{ action.i18n | translate }}\n </button>\n </ng-container>\n </ng-template>\n</ng-container>\n", styles: [".menu-button{display:flex;padding:0 .625rem 0 .375rem;background:unset;color:#454545;font-size:2rem;vertical-align:middle}.menu-button:hover,.menu-button:focus{color:#000}.action-button{display:block;width:100%;min-height:2rem;padding:0 1rem;background:#fff0;font-size:.75rem;text-align:left}.action-button:hover{background-color:#f2f7fa}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.QdIconComponent, selector: "qd-icon", inputs: ["icon"] }, { kind: "directive", type: i5.QdPopoverOnClickDirective, selector: "[qdPopoverOnClick]", inputs: ["qdPopoverOnClick", "positionStrategy", "qdPopoverCloseStrategy", "qdPopoverDisabled", "qdPopoverStopPropagation", "qdPopoverBackgroundColor", "qdPopoverMaxHeight", "qdPopoverMinWidth", "qdPopoverMaxWidth", "qdPopoverAutoSize", "qdPopoverEnableKeyControl"], outputs: ["opened", "closed"], exportAs: ["qdPopoverOnClick"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
79
76
|
}
|
|
80
77
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdTreeRowActionsSecondaryMenuComponent, decorators: [{
|
|
81
78
|
type: Component,
|
|
82
|
-
args: [{ selector: '[qd-tree-row-actions-secondary-menu]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"hasVisibleActions$ | async\">\n <button\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n [qdPopoverMinWidth]=\"200\"\n class=\"menu-button\"\n [attr.data-test-id]=\"testId + '-toggler'\"\n >\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n\n <ng-template #menu>\n <ng-container *ngFor=\"let action of actions$ | async; let i = index\">\n <button\n *ngIf=\"!action.isHidden\"\n class=\"action-button\"\n (click)=\"handleSecondaryAction(action.type, rowIndex,
|
|
79
|
+
args: [{ selector: '[qd-tree-row-actions-secondary-menu]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"hasVisibleActions$ | async\">\n <button\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n [qdPopoverMinWidth]=\"200\"\n class=\"menu-button\"\n [attr.data-test-id]=\"testId + '-toggler'\"\n >\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n\n <ng-template #menu>\n <ng-container *ngFor=\"let action of actions$ | async; let i = index\">\n <button\n *ngIf=\"!action.isHidden\"\n class=\"action-button\"\n (click)=\"handleSecondaryAction(action.type, rowIndex, action.isHidden)\"\n [attr.data-test-id]=\"testId + '-' + i\"\n >\n {{ action.i18n | translate }}\n </button>\n </ng-container>\n </ng-template>\n</ng-container>\n", styles: [".menu-button{display:flex;padding:0 .625rem 0 .375rem;background:unset;color:#454545;font-size:2rem;vertical-align:middle}.menu-button:hover,.menu-button:focus{color:#000}.action-button{display:block;width:100%;min-height:2rem;padding:0 1rem;background:#fff0;font-size:.75rem;text-align:left}.action-button:hover{background-color:#f2f7fa}\n"] }]
|
|
83
80
|
}], ctorParameters: () => [{ type: i1.QdTableStoreService }, { type: i2.QdEventBrokerService, decorators: [{
|
|
84
81
|
type: Optional
|
|
85
82
|
}] }], propDecorators: { rowIndex: [{
|
|
@@ -95,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
95
92
|
type: Input,
|
|
96
93
|
args: [{ required: true }]
|
|
97
94
|
}] } });
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-row-actions-secondary-menu.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/qd-ui/src/lib/tree/row/actions/secondary/menu/tree-row-actions-secondary-menu.component.ts","../../../../../../../../../libs/qd-ui/src/lib/tree/row/actions/secondary/menu/tree-row-actions-secondary-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { BehaviorSubject, combineLatest, Observable, Subject } from 'rxjs';\nimport { map, takeUntil } from 'rxjs/operators';\n\nimport { QdTableStoreService } from '../../../../../table/store/table-store.service';\nimport { QdEventBrokerService } from '../../../../../core/services/event-broker.service';\nimport { QdTreeDataRow } from '../../../../model/tree-data.interface';\nimport { QdTreeConfig } from '../../../../model/tree-config.interface';\nimport {\n  QdTreeConfigSecondaryActionType,\n  QdTreeSecondaryAction\n} from '../../../../model/tree-config-actions.interface';\n\nexport interface ResolvedAction extends Pick<QdTreeSecondaryAction<any>, 'type' | 'isHidden' | 'operationMode'> {\n  i18n: string;\n}\n\n@Component({\n  selector: '[qd-tree-row-actions-secondary-menu]',\n  templateUrl: './tree-row-actions-secondary-menu.component.html',\n  styleUrls: ['./tree-row-actions-secondary-menu.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class QdTreeRowActionsSecondaryMenuComponent<T extends string> implements OnInit, OnDestroy {\n  @Input({ required: true }) rowIndex!: number;\n  @Input({ required: true }) rowData!: QdTreeDataRow<T>;\n  @Input({ required: true }) config!: QdTreeConfig<T>;\n  @Input({ required: true }) testId!: string;\n\n  private readonly _i18ns$ = new BehaviorSubject<string | undefined>(undefined);\n  private readonly _secondaryActionsConfig$ = new BehaviorSubject<QdTreeSecondaryAction<T>[]>([]);\n  private readonly _viewonly$ = new BehaviorSubject<boolean>(false);\n  private readonly _destroy$ = new Subject<void>();\n\n  get hasVisibleActions$(): Observable<boolean> {\n    return this.actions$.pipe(map(actions => actions.some(action => !action.isHidden)));\n  }\n\n  get actions$(): Observable<ResolvedAction[]> {\n    return combineLatest([this._i18ns$, this._secondaryActionsConfig$, this._viewonly$]).pipe(\n      map(([i18ns, actions, isViewonly]) => {\n        const currentMode = isViewonly ? 'view' : 'edit';\n\n        return actions.map(action => {\n          const hiddenByMode = !!action.operationMode && action.operationMode !== currentMode;\n          const hiddenByCustom =\n            typeof action.isHidden === 'function' ? action.isHidden(this.rowData) : !!action.isHidden;\n\n          return {\n            type: action.type,\n            operationMode: action.operationMode,\n            isHidden: hiddenByMode || hiddenByCustom,\n            i18n: `${i18ns}.secondaryActions.${action.type}`\n          };\n        });\n      })\n    );\n  }\n\n  constructor(\n    private readonly tableStoreService: QdTableStoreService<T>,\n    @Optional() private readonly eventBroker?: QdEventBrokerService\n  ) {}\n\n  ngOnInit(): void {\n    this._i18ns$.next(this.config.i18ns);\n    this._secondaryActionsConfig$.next(this.config.secondaryActions ?? []);\n    this.initViewMode();\n  }\n\n  ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  handleSecondaryAction(type: QdTreeConfigSecondaryActionType, index: number, actionIndex: number): void {\n    this.actions$.pipe(takeUntil(this._destroy$)).subscribe(actions => {\n      const action = actions[actionIndex];\n      if (!action || action.isHidden) return;\n\n      this.tableStoreService.updateTableStateRecentSecondaryAction({\n        type,\n        index,\n        rowData: this.rowData\n      });\n    });\n  }\n\n  private initViewMode(): void {\n    if (typeof this.config.viewonly === 'boolean') {\n      this._viewonly$.next(this.config.viewonly);\n\n      return;\n    }\n\n    this.eventBroker\n      ?.consume<{ isViewonly: boolean }>('operation_mode_changed')\n      .pipe(takeUntil(this._destroy$))\n      .subscribe(({ payload }) => this._viewonly$.next(payload.isViewonly));\n  }\n}\n","<ng-container *ngIf=\"hasVisibleActions$ | async\">\n  <button\n    type=\"button\"\n    [qdPopoverOnClick]=\"menu\"\n    [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n    [qdPopoverStopPropagation]=\"true\"\n    [qdPopoverMinWidth]=\"200\"\n    class=\"menu-button\"\n    [attr.data-test-id]=\"testId + '-toggler'\"\n  >\n    <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n  </button>\n\n  <ng-template #menu>\n    <ng-container *ngFor=\"let action of actions$ | async; let i = index\">\n      <button\n        *ngIf=\"!action.isHidden\"\n        class=\"action-button\"\n        (click)=\"handleSecondaryAction(action.type, rowIndex, i)\"\n        [attr.data-test-id]=\"testId + '-' + i\"\n      >\n        {{ action.i18n | translate }}\n      </button>\n    </ng-container>\n  </ng-template>\n</ng-container>\n"]}
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-row-actions-secondary-menu.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/qd-ui/src/lib/tree/row/actions/secondary/menu/tree-row-actions-secondary-menu.component.ts","../../../../../../../../../libs/qd-ui/src/lib/tree/row/actions/secondary/menu/tree-row-actions-secondary-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { BehaviorSubject, combineLatest, Observable, Subject } from 'rxjs';\nimport { map, takeUntil } from 'rxjs/operators';\n\nimport { QdTableStoreService } from '../../../../../table/store/table-store.service';\nimport { QdEventBrokerService } from '../../../../../core/services/event-broker.service';\nimport { QdTreeDataRow } from '../../../../model/tree-data.interface';\nimport { QdTreeConfig } from '../../../../model/tree-config.interface';\nimport {\n  QdTreeConfigSecondaryActionType,\n  QdTreeSecondaryAction\n} from '../../../../model/tree-config-actions.interface';\n\nexport interface ResolvedAction extends Pick<QdTreeSecondaryAction<any>, 'type' | 'isHidden' | 'operationMode'> {\n  i18n: string;\n}\n\n@Component({\n  selector: '[qd-tree-row-actions-secondary-menu]',\n  templateUrl: './tree-row-actions-secondary-menu.component.html',\n  styleUrls: ['./tree-row-actions-secondary-menu.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class QdTreeRowActionsSecondaryMenuComponent<T extends string> implements OnInit, OnDestroy {\n  @Input({ required: true }) rowIndex!: number;\n  @Input({ required: true }) rowData!: QdTreeDataRow<T>;\n  @Input({ required: true }) config!: QdTreeConfig<T>;\n  @Input({ required: true }) testId!: string;\n\n  private readonly _i18ns$ = new BehaviorSubject<string | undefined>(undefined);\n  private readonly _secondaryActionsConfig$ = new BehaviorSubject<QdTreeSecondaryAction<T>[]>([]);\n  private readonly _viewonly$ = new BehaviorSubject<boolean>(false);\n  private readonly _destroy$ = new Subject<void>();\n\n  get hasVisibleActions$(): Observable<boolean> {\n    return this.actions$.pipe(map(actions => actions.some(action => !action.isHidden)));\n  }\n\n  get actions$(): Observable<ResolvedAction[]> {\n    return combineLatest([this._i18ns$, this._secondaryActionsConfig$, this._viewonly$]).pipe(\n      map(([i18ns, actions, isViewonly]) => {\n        const currentMode = isViewonly ? 'view' : 'edit';\n\n        return actions.map(action => {\n          const hiddenByMode = !!action.operationMode && action.operationMode !== currentMode;\n          const hiddenByCustom =\n            typeof action.isHidden === 'function' ? action.isHidden(this.rowData) : !!action.isHidden;\n\n          return {\n            type: action.type,\n            operationMode: action.operationMode,\n            isHidden: hiddenByMode || hiddenByCustom,\n            i18n: `${i18ns}.secondaryActions.${action.type}`\n          };\n        });\n      })\n    );\n  }\n\n  constructor(\n    private readonly tableStoreService: QdTableStoreService<T>,\n    @Optional() private readonly eventBroker?: QdEventBrokerService\n  ) {}\n\n  ngOnInit(): void {\n    this._i18ns$.next(this.config.i18ns);\n    this._secondaryActionsConfig$.next(this.config.secondaryActions ?? []);\n    this.initViewMode();\n  }\n\n  ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  handleSecondaryAction(\n    type: QdTreeConfigSecondaryActionType,\n    index: number,\n    isHidden: boolean | ((row: QdTreeDataRow<T>) => boolean)\n  ): void {\n    if (isHidden) return;\n    this.tableStoreService.updateTableStateRecentSecondaryAction({\n      type,\n      index,\n      rowData: this.rowData\n    });\n  }\n\n  private initViewMode(): void {\n    if (typeof this.config.viewonly === 'boolean') {\n      this._viewonly$.next(this.config.viewonly);\n\n      return;\n    }\n\n    this.eventBroker\n      ?.consume<{ isViewonly: boolean }>('operation_mode_changed')\n      .pipe(takeUntil(this._destroy$))\n      .subscribe(({ payload }) => this._viewonly$.next(payload.isViewonly));\n  }\n}\n","<ng-container *ngIf=\"hasVisibleActions$ | async\">\n  <button\n    type=\"button\"\n    [qdPopoverOnClick]=\"menu\"\n    [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n    [qdPopoverStopPropagation]=\"true\"\n    [qdPopoverMinWidth]=\"200\"\n    class=\"menu-button\"\n    [attr.data-test-id]=\"testId + '-toggler'\"\n  >\n    <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n  </button>\n\n  <ng-template #menu>\n    <ng-container *ngFor=\"let action of actions$ | async; let i = index\">\n      <button\n        *ngIf=\"!action.isHidden\"\n        class=\"action-button\"\n        (click)=\"handleSecondaryAction(action.type, rowIndex, action.isHidden)\"\n        [attr.data-test-id]=\"testId + '-' + i\"\n      >\n        {{ action.i18n | translate }}\n      </button>\n    </ng-container>\n  </ng-template>\n</ng-container>\n"]}
|
|
@@ -20763,9 +20763,7 @@ class QdTableResolverService {
|
|
|
20763
20763
|
// TODO: Add Error handling
|
|
20764
20764
|
this.tableStoreService
|
|
20765
20765
|
.selectDataResolutionCriteria$()
|
|
20766
|
-
.pipe(takeUntil(this._destroyed$), distinctUntilChanged(isEqual$1), filter((resolutionCriteria) => {
|
|
20767
|
-
return !!resolutionCriteria && this.shouldDataBeResolved(resolutionCriteria);
|
|
20768
|
-
}), map(({ tableParams, connectorParams }) => {
|
|
20766
|
+
.pipe(takeUntil(this._destroyed$), distinctUntilChanged(isEqual$1), filter((resolutionCriteria) => !!resolutionCriteria && this.shouldDataBeResolved(resolutionCriteria)), map(({ tableParams, connectorParams }) => {
|
|
20769
20767
|
return {
|
|
20770
20768
|
...(this._hasPagination ? tableParams : {}),
|
|
20771
20769
|
...connectorParams
|
|
@@ -20783,7 +20781,7 @@ class QdTableResolverService {
|
|
|
20783
20781
|
this._refreshSubscription.unsubscribe();
|
|
20784
20782
|
this._refreshSubscription = this.tableStoreService
|
|
20785
20783
|
.selectDataResolutionCriteria$()
|
|
20786
|
-
.pipe(first(), tap(() => this.tableStoreService.setRequestState(QdTableRequestState.PENDING)), switchMap(resolutionCriteria => this.tableDataResolver.resolve({
|
|
20784
|
+
.pipe(filter((criteria) => !!criteria), first(), tap(() => this.tableStoreService.setRequestState(QdTableRequestState.PENDING)), switchMap(resolutionCriteria => this.tableDataResolver.resolve({
|
|
20787
20785
|
...resolutionCriteria.tableParams,
|
|
20788
20786
|
...resolutionCriteria.connectorParams,
|
|
20789
20787
|
...(this._hasPagination && pageIndex !== undefined ? { page: pageIndex } : {})
|
|
@@ -22074,11 +22072,11 @@ class QdTableComponent {
|
|
|
22074
22072
|
}
|
|
22075
22073
|
ngOnInit() {
|
|
22076
22074
|
this.tableStoreService.tableId = this.config.uid || v4();
|
|
22077
|
-
this.resolverService.init(this.config.refreshOnLanguageChange, this.hasPagination);
|
|
22078
22075
|
this.tableStoreService.init();
|
|
22079
22076
|
this.tableStoreService.initTableState(this._data, this.hasResolver, this._connectors, this.hasPagination);
|
|
22080
22077
|
this.tableStoreService.updateTableStateRecentSecondaryAction(undefined);
|
|
22081
22078
|
this.tableStoreService.setupSort(this.config.columns);
|
|
22079
|
+
this.resolverService.init(this.config.refreshOnLanguageChange, this.hasPagination);
|
|
22082
22080
|
this.data$ = this.tableStoreService.tableDataEntries$();
|
|
22083
22081
|
this.mapColumnFillsWidth();
|
|
22084
22082
|
this.validateConfig();
|
|
@@ -22745,16 +22743,13 @@ class QdTreeRowActionsSecondaryMenuComponent {
|
|
|
22745
22743
|
this._destroy$.next();
|
|
22746
22744
|
this._destroy$.complete();
|
|
22747
22745
|
}
|
|
22748
|
-
handleSecondaryAction(type, index,
|
|
22749
|
-
|
|
22750
|
-
|
|
22751
|
-
|
|
22752
|
-
|
|
22753
|
-
|
|
22754
|
-
|
|
22755
|
-
index,
|
|
22756
|
-
rowData: this.rowData
|
|
22757
|
-
});
|
|
22746
|
+
handleSecondaryAction(type, index, isHidden) {
|
|
22747
|
+
if (isHidden)
|
|
22748
|
+
return;
|
|
22749
|
+
this.tableStoreService.updateTableStateRecentSecondaryAction({
|
|
22750
|
+
type,
|
|
22751
|
+
index,
|
|
22752
|
+
rowData: this.rowData
|
|
22758
22753
|
});
|
|
22759
22754
|
}
|
|
22760
22755
|
initViewMode() {
|
|
@@ -22768,11 +22763,11 @@ class QdTreeRowActionsSecondaryMenuComponent {
|
|
|
22768
22763
|
.subscribe(({ payload }) => this._viewonly$.next(payload.isViewonly));
|
|
22769
22764
|
}
|
|
22770
22765
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdTreeRowActionsSecondaryMenuComponent, deps: [{ token: QdTableStoreService }, { token: QdEventBrokerService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
22771
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdTreeRowActionsSecondaryMenuComponent, selector: "[qd-tree-row-actions-secondary-menu]", inputs: { rowIndex: "rowIndex", rowData: "rowData", config: "config", testId: "testId" }, ngImport: i0, template: "<ng-container *ngIf=\"hasVisibleActions$ | async\">\n <button\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n [qdPopoverMinWidth]=\"200\"\n class=\"menu-button\"\n [attr.data-test-id]=\"testId + '-toggler'\"\n >\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n\n <ng-template #menu>\n <ng-container *ngFor=\"let action of actions$ | async; let i = index\">\n <button\n *ngIf=\"!action.isHidden\"\n class=\"action-button\"\n (click)=\"handleSecondaryAction(action.type, rowIndex,
|
|
22766
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdTreeRowActionsSecondaryMenuComponent, selector: "[qd-tree-row-actions-secondary-menu]", inputs: { rowIndex: "rowIndex", rowData: "rowData", config: "config", testId: "testId" }, ngImport: i0, template: "<ng-container *ngIf=\"hasVisibleActions$ | async\">\n <button\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n [qdPopoverMinWidth]=\"200\"\n class=\"menu-button\"\n [attr.data-test-id]=\"testId + '-toggler'\"\n >\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n\n <ng-template #menu>\n <ng-container *ngFor=\"let action of actions$ | async; let i = index\">\n <button\n *ngIf=\"!action.isHidden\"\n class=\"action-button\"\n (click)=\"handleSecondaryAction(action.type, rowIndex, action.isHidden)\"\n [attr.data-test-id]=\"testId + '-' + i\"\n >\n {{ action.i18n | translate }}\n </button>\n </ng-container>\n </ng-template>\n</ng-container>\n", styles: [".menu-button{display:flex;padding:0 .625rem 0 .375rem;background:unset;color:#454545;font-size:2rem;vertical-align:middle}.menu-button:hover,.menu-button:focus{color:#000}.action-button{display:block;width:100%;min-height:2rem;padding:0 1rem;background:#fff0;font-size:.75rem;text-align:left}.action-button:hover{background-color:#f2f7fa}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: QdIconComponent, selector: "qd-icon", inputs: ["icon"] }, { kind: "directive", type: QdPopoverOnClickDirective, selector: "[qdPopoverOnClick]", inputs: ["qdPopoverOnClick", "positionStrategy", "qdPopoverCloseStrategy", "qdPopoverDisabled", "qdPopoverStopPropagation", "qdPopoverBackgroundColor", "qdPopoverMaxHeight", "qdPopoverMinWidth", "qdPopoverMaxWidth", "qdPopoverAutoSize", "qdPopoverEnableKeyControl"], outputs: ["opened", "closed"], exportAs: ["qdPopoverOnClick"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1$2.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
22772
22767
|
}
|
|
22773
22768
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdTreeRowActionsSecondaryMenuComponent, decorators: [{
|
|
22774
22769
|
type: Component,
|
|
22775
|
-
args: [{ selector: '[qd-tree-row-actions-secondary-menu]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"hasVisibleActions$ | async\">\n <button\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n [qdPopoverMinWidth]=\"200\"\n class=\"menu-button\"\n [attr.data-test-id]=\"testId + '-toggler'\"\n >\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n\n <ng-template #menu>\n <ng-container *ngFor=\"let action of actions$ | async; let i = index\">\n <button\n *ngIf=\"!action.isHidden\"\n class=\"action-button\"\n (click)=\"handleSecondaryAction(action.type, rowIndex,
|
|
22770
|
+
args: [{ selector: '[qd-tree-row-actions-secondary-menu]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"hasVisibleActions$ | async\">\n <button\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n [qdPopoverMinWidth]=\"200\"\n class=\"menu-button\"\n [attr.data-test-id]=\"testId + '-toggler'\"\n >\n <qd-icon icon=\"overflowMenuHorizontal\"></qd-icon>\n </button>\n\n <ng-template #menu>\n <ng-container *ngFor=\"let action of actions$ | async; let i = index\">\n <button\n *ngIf=\"!action.isHidden\"\n class=\"action-button\"\n (click)=\"handleSecondaryAction(action.type, rowIndex, action.isHidden)\"\n [attr.data-test-id]=\"testId + '-' + i\"\n >\n {{ action.i18n | translate }}\n </button>\n </ng-container>\n </ng-template>\n</ng-container>\n", styles: [".menu-button{display:flex;padding:0 .625rem 0 .375rem;background:unset;color:#454545;font-size:2rem;vertical-align:middle}.menu-button:hover,.menu-button:focus{color:#000}.action-button{display:block;width:100%;min-height:2rem;padding:0 1rem;background:#fff0;font-size:.75rem;text-align:left}.action-button:hover{background-color:#f2f7fa}\n"] }]
|
|
22776
22771
|
}], ctorParameters: () => [{ type: QdTableStoreService }, { type: QdEventBrokerService, decorators: [{
|
|
22777
22772
|
type: Optional
|
|
22778
22773
|
}] }], propDecorators: { rowIndex: [{
|