@theseam/ui-common 0.2.13 → 0.2.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,5 @@
1
1
  import { ChangeDetectionStrategy, Component, Inject, Input, isDevMode, Optional } from '@angular/core';
2
- import { of } from 'rxjs';
2
+ import { combineLatest, of } from 'rxjs';
3
3
  import { catchError, concatMap, map, take, tap } from 'rxjs/operators';
4
4
  import { faFileDownload } from '@fortawesome/free-solid-svg-icons';
5
5
  import { ToastrService } from 'ngx-toastr';
@@ -30,12 +30,13 @@ export class DatatableExportButtonComponent {
30
30
  : `${exporter.label} export is not available.`;
31
31
  this._toastr.error(msg, 'Data Export');
32
32
  }
33
- const export$ = this._datatable.rows$
34
- .pipe(take(1), map(rows => {
33
+ const export$ = combineLatest([
34
+ this._datatable.rows$, this._datatable.columns$
35
+ ]).pipe(take(1), map(([rows, columns]) => {
35
36
  if (exporter.skipDataMapping) {
36
37
  return rows;
37
38
  }
38
- return this._mapExportData(this._datatable.columns || [], rows);
39
+ return this._mapExportData(columns || [], rows);
39
40
  }), concatMap(data => exporter.export(data)), catchError(err => {
40
41
  console.error(err);
41
42
  return of(false);
@@ -95,4 +96,4 @@ DatatableExportButtonComponent.ctorParameters = () => [
95
96
  DatatableExportButtonComponent.propDecorators = {
96
97
  exporters: [{ type: Input }]
97
98
  };
98
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datatable-export-button.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/datatable/datatable-export-button/datatable-export-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Inject, Input, isDevMode, OnInit, Optional } from '@angular/core'\nimport { of } from 'rxjs'\nimport { catchError, concatMap, map, take, tap } from 'rxjs/operators'\n\nimport { faFileDownload } from '@fortawesome/free-solid-svg-icons'\nimport { ToastrService } from 'ngx-toastr'\n\nimport { IDataExporter } from '@theseam/ui-common/data-exporter'\nimport { DynamicValueHelperService, THESEAM_DYNAMIC_DATA } from '@theseam/ui-common/dynamic'\nimport { TheSeamLoadingOverlayService } from '@theseam/ui-common/loading'\nimport { hasProperty } from '@theseam/ui-common/utils'\n\nimport { DatatableComponent, THESEAM_DATATABLE } from '../datatable/datatable.component'\nimport { TheSeamDatatableColumn } from '../models/table-column'\n\nexport interface IDatatableExportButtonData {\n  exporters: IDataExporter[]\n}\n\n@Component({\n  selector: 'seam-datatable-export-button',\n  templateUrl: './datatable-export-button.component.html',\n  styleUrls: ['./datatable-export-button.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DatatableExportButtonComponent implements OnInit {\n\n  icon = faFileDownload\n\n  @Input() exporters: IDataExporter[] | undefined | null\n\n  get disabled() {\n    return !(this.exporters && this.exporters.length > 0)\n  }\n\n  constructor(\n    @Inject(THESEAM_DATATABLE) private readonly _datatable: DatatableComponent,\n    private readonly _toastr: ToastrService,\n    private readonly _loading: TheSeamLoadingOverlayService,\n    private readonly _valueHelper: DynamicValueHelperService,\n    @Optional() @Inject(THESEAM_DYNAMIC_DATA) private readonly _data?: IDatatableExportButtonData\n  ) {\n    if (this._data && this._data.exporters) {\n      this.exporters = this._data.exporters\n    }\n  }\n\n  ngOnInit() { }\n\n  _onExporterClicked(exporter: IDataExporter) {\n    if (!exporter.export) {\n      const msg = isDevMode()\n        ? `Exporter '${exporter.name}' is missing an export method.`\n        : `${exporter.label} export is not available.`\n      this._toastr.error(msg, 'Data Export')\n    }\n\n    const export$ = this._datatable.rows$\n      .pipe(\n        take(1),\n        map(rows => {\n          if (exporter.skipDataMapping) {\n            return rows\n          }\n          return this._mapExportData(this._datatable.columns || [], rows)\n        }),\n        concatMap(data => exporter.export(data)),\n        catchError(err => {\n          console.error(err)\n          return of(false)\n        }),\n        tap(success => {\n          if (success) {\n            this._toastr.success(`${exporter.label} export complete.`, 'Data Export')\n          } else {\n            this._toastr.error(`${exporter.label} export failed.`, 'Data Export')\n          }\n        })\n      )\n\n    this._loading.while(export$).subscribe()\n  }\n\n  private _mapExportData(columns: TheSeamDatatableColumn[], rows: any[]) {\n    const data: any[] = []\n\n    for (const row of rows) {\n      const newRow: any = {}\n\n      for (const col of columns) {\n        if (!col.exportIgnore) {\n          const colName = col.exportHeader || col.name || col.prop\n          if (colName) {\n            newRow[colName] = this._rowValue(col, row)\n          }\n        }\n      }\n\n      data.push(newRow)\n    }\n\n    return data\n  }\n\n  private _rowValue(column: TheSeamDatatableColumn, row: any) {\n    if (hasProperty(column as any, 'exportValue')) {\n      const context = { value: column.prop ? row[column.prop] : undefined, row }\n      return this._valueHelper.evalSync((column as any).exportValue, context)\n    }\n\n    const colProp = column.prop\n    if (colProp) {\n      return row[colProp]\n    }\n    return undefined\n  }\n\n}\n"]}
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datatable-export-button.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/datatable/datatable-export-button/datatable-export-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Inject, Input, isDevMode, OnInit, Optional } from '@angular/core'\nimport { combineLatest, of } from 'rxjs'\nimport { catchError, concatMap, map, take, tap } from 'rxjs/operators'\n\nimport { faFileDownload } from '@fortawesome/free-solid-svg-icons'\nimport { ToastrService } from 'ngx-toastr'\n\nimport { IDataExporter } from '@theseam/ui-common/data-exporter'\nimport { DynamicValueHelperService, THESEAM_DYNAMIC_DATA } from '@theseam/ui-common/dynamic'\nimport { TheSeamLoadingOverlayService } from '@theseam/ui-common/loading'\nimport { hasProperty } from '@theseam/ui-common/utils'\n\nimport { DatatableComponent, THESEAM_DATATABLE } from '../datatable/datatable.component'\nimport { TheSeamDatatableColumn } from '../models/table-column'\n\nexport interface IDatatableExportButtonData {\n  exporters: IDataExporter[]\n}\n\n@Component({\n  selector: 'seam-datatable-export-button',\n  templateUrl: './datatable-export-button.component.html',\n  styleUrls: ['./datatable-export-button.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DatatableExportButtonComponent implements OnInit {\n\n  icon = faFileDownload\n\n  @Input() exporters: IDataExporter[] | undefined | null\n\n  get disabled() {\n    return !(this.exporters && this.exporters.length > 0)\n  }\n\n  constructor(\n    @Inject(THESEAM_DATATABLE) private readonly _datatable: DatatableComponent,\n    private readonly _toastr: ToastrService,\n    private readonly _loading: TheSeamLoadingOverlayService,\n    private readonly _valueHelper: DynamicValueHelperService,\n    @Optional() @Inject(THESEAM_DYNAMIC_DATA) private readonly _data?: IDatatableExportButtonData\n  ) {\n    if (this._data && this._data.exporters) {\n      this.exporters = this._data.exporters\n    }\n  }\n\n  ngOnInit() { }\n\n  _onExporterClicked(exporter: IDataExporter) {\n    if (!exporter.export) {\n      const msg = isDevMode()\n        ? `Exporter '${exporter.name}' is missing an export method.`\n        : `${exporter.label} export is not available.`\n      this._toastr.error(msg, 'Data Export')\n    }\n\n    const export$ = combineLatest([\n      this._datatable.rows$, this._datatable.columns$\n    ]).pipe(\n      take(1),\n      map(([ rows, columns ]) => {\n        if (exporter.skipDataMapping) {\n          return rows\n        }\n        return this._mapExportData(columns || [], rows)\n      }),\n      concatMap(data => exporter.export(data)),\n      catchError(err => {\n        console.error(err)\n        return of(false)\n      }),\n      tap(success => {\n        if (success) {\n          this._toastr.success(`${exporter.label} export complete.`, 'Data Export')\n        } else {\n          this._toastr.error(`${exporter.label} export failed.`, 'Data Export')\n        }\n      })\n    )\n\n    this._loading.while(export$).subscribe()\n  }\n\n  private _mapExportData(columns: TheSeamDatatableColumn[], rows: any[]) {\n    const data: any[] = []\n\n    for (const row of rows) {\n      const newRow: any = {}\n\n      for (const col of columns) {\n        if (!col.exportIgnore) {\n          const colName = col.exportHeader || col.name || col.prop\n          if (colName) {\n            newRow[colName] = this._rowValue(col, row)\n          }\n        }\n      }\n\n      data.push(newRow)\n    }\n\n    return data\n  }\n\n  private _rowValue(column: TheSeamDatatableColumn, row: any) {\n    if (hasProperty(column as any, 'exportValue')) {\n      const context = { value: column.prop ? row[column.prop] : undefined, row }\n      return this._valueHelper.evalSync((column as any).exportValue, context)\n    }\n\n    const colProp = column.prop\n    if (colProp) {\n      return row[colProp]\n    }\n    return undefined\n  }\n\n}\n"]}
@@ -25,8 +25,8 @@ export class OrderColumnsAlteration extends ColumnsAlteration {
25
25
  // NOTE: If we add an internal column that can be moved then this will need
26
26
  // to be changed.
27
27
  const internalColumns = columns
28
- .filter(c => isInternalColumn(c))
29
- .map((column, index) => ({ column, index }));
28
+ .map((column, index) => ({ column, index }))
29
+ .filter(x => isInternalColumn(x.column));
30
30
  for (const c of stateColumns) {
31
31
  const currentIndex = columns.findIndex(x => getColumnProp(x) === c.columnProp);
32
32
  if (currentIndex === c.index || currentIndex === -1) {
@@ -78,4 +78,4 @@ export class OrderColumnsAlteration extends ColumnsAlteration {
78
78
  }).sort((a, b) => a.index === b.index ? 0 : a.index > b.index ? 1 : -1);
79
79
  }
80
80
  }
81
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"order.columns-alteration.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/datatable/models/columns-alterations/order.columns-alteration.ts"],"names":[],"mappings":"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","sourcesContent":["import { isDevMode } from '@angular/core'\r\n\r\nimport { TableColumnProp } from '@marklb/ngx-datatable'\r\nimport { arrayMoveMutable, notNullOrUndefined } from '@theseam/ui-common/utils'\r\nimport { CHECKBOX_COLUMN_PROP } from '../../utils/create-checkbox-column'\r\n\r\nimport { getColumnProp } from '../../utils/get-column-prop'\r\nimport { ColumnsAlteration } from '../columns-alteration'\r\nimport { TheSeamDatatableAccessor } from '../datatable-accessor'\r\nimport { INTERNAL_COLUMN_PROPS, isInternalColumn } from '../internal-column-props'\r\nimport { TheSeamDatatableColumn } from '../table-column'\r\n\r\nexport interface ColumnOrderRecord {\r\n  columnProp: TableColumnProp\r\n  index: number\r\n}\r\n\r\nexport interface OrderColumnsAlterationState {\r\n  // NOTE: This stores the column index of reordered columns only, to avoid any\r\n  // new columns from always being placed at the end. The moved columns should\r\n  // always be accurate relative to each other, but if this becomes an issue\r\n  // then we can just store all the columns positions.\r\n  columns: ColumnOrderRecord[]\r\n}\r\n\r\nexport class OrderColumnsAlteration extends ColumnsAlteration<OrderColumnsAlterationState> {\r\n  public readonly id: string\r\n\r\n  public readonly type: string = 'order'\r\n\r\n  constructor(\r\n    state: OrderColumnsAlterationState,\r\n    persistent: boolean\r\n  ) {\r\n    super(state, persistent)\r\n\r\n    if (!this._isValidState(state)) {\r\n      throw Error(`Invalid state: ${JSON.stringify(state)}`)\r\n    }\r\n\r\n    this.id = `${this.type}`\r\n  }\r\n\r\n  public apply(columns: TheSeamDatatableColumn<any, any>[], datatable: TheSeamDatatableAccessor): void {\r\n    if (this.state.columns.length === 0) {\r\n      return\r\n    }\r\n\r\n    const stateColumns = this._stateColumns()\r\n\r\n    // The internal columns are not intended for a user to be able to move them.\r\n    // Store the internal columns current index, so it can be moved back ofter\r\n    // sorting. This may not be the best way to do this, but it is easier than\r\n    // making a sort that avoids them.\r\n    //\r\n    // NOTE: If we add an internal column that can be moved then this will need\r\n    // to be changed.\r\n    const internalColumns = columns\r\n      .filter(c => isInternalColumn(c))\r\n      .map((column, index) => ({ column, index }))\r\n\r\n    for (const c of stateColumns) {\r\n      const currentIndex = columns.findIndex(x => getColumnProp(x) === c.columnProp)\r\n      if (currentIndex === c.index || currentIndex === -1) {\r\n        // Skip if already at correct index.\r\n        // Skip columns not found. It may be a column that was removed from the\r\n        // table, but we still want to handle the other columns.\r\n        continue\r\n      }\r\n\r\n      arrayMoveMutable(columns, currentIndex, c.index)\r\n    }\r\n\r\n    for (const c of internalColumns) {\r\n      const currentIndex = columns.findIndex(col => col === c.column)\r\n      if (currentIndex !== -1) {\r\n        arrayMoveMutable(columns, currentIndex, c.index)\r\n      } else {\r\n        if (isDevMode()) {\r\n          console.warn(`Internal column could not be found after sorting. Was it lost during the sorting?`)\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private _isValidState(state: OrderColumnsAlterationState): boolean {\r\n    // NOTE: Checking null or undefined, even though the type doesn't allow,\r\n    // because the state may have been loaded from an invalid persistant\r\n    // storage.\r\n\r\n    // TODO: Remove when state validation/migration is implemented to happen\r\n    // when retrieved from storage.\r\n    if (!notNullOrUndefined(state.columns)) {\r\n      return false\r\n    }\r\n\r\n    // NOTE: Didn't iterate each column record, because it is probably better to\r\n    // just skip to invalid column records. It does prevent being able to\r\n    // validate the whole state though.\r\n\r\n    return true\r\n  }\r\n\r\n  private _isColumnOrderRecordValid(columnOrder: ColumnOrderRecord): boolean {\r\n    return notNullOrUndefined(columnOrder.columnProp) && notNullOrUndefined(columnOrder.index)\r\n  }\r\n\r\n  private _stateColumns(): ColumnOrderRecord[] {\r\n    return this.state.columns.filter(c => {\r\n      if (!this._isColumnOrderRecordValid(c)) {\r\n        if (isDevMode()) {\r\n          console.warn('Invalid column order record', c)\r\n        }\r\n        return false\r\n      }\r\n      return true\r\n    }).sort((a, b) => a.index === b.index ? 0 : a.index > b.index ? 1 : -1)\r\n  }\r\n}\r\n"]}
81
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"order.columns-alteration.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/datatable/models/columns-alterations/order.columns-alteration.ts"],"names":[],"mappings":"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","sourcesContent":["import { isDevMode } from '@angular/core'\n\nimport { TableColumnProp } from '@marklb/ngx-datatable'\nimport { arrayMoveMutable, notNullOrUndefined } from '@theseam/ui-common/utils'\n\nimport { getColumnProp } from '../../utils/get-column-prop'\nimport { ColumnsAlteration } from '../columns-alteration'\nimport { TheSeamDatatableAccessor } from '../datatable-accessor'\nimport { isInternalColumn } from '../internal-column-props'\nimport { TheSeamDatatableColumn } from '../table-column'\n\nexport interface ColumnOrderRecord {\n  columnProp: TableColumnProp\n  index: number\n}\n\nexport interface OrderColumnsAlterationState {\n  // NOTE: This stores the column index of reordered columns only, to avoid any\n  // new columns from always being placed at the end. The moved columns should\n  // always be accurate relative to each other, but if this becomes an issue\n  // then we can just store all the columns positions.\n  columns: ColumnOrderRecord[]\n}\n\nexport class OrderColumnsAlteration extends ColumnsAlteration<OrderColumnsAlterationState> {\n  public readonly id: string\n\n  public readonly type: string = 'order'\n\n  constructor(\n    state: OrderColumnsAlterationState,\n    persistent: boolean\n  ) {\n    super(state, persistent)\n\n    if (!this._isValidState(state)) {\n      throw Error(`Invalid state: ${JSON.stringify(state)}`)\n    }\n\n    this.id = `${this.type}`\n  }\n\n  public apply(columns: TheSeamDatatableColumn<any, any>[], datatable: TheSeamDatatableAccessor): void {\n    if (this.state.columns.length === 0) {\n      return\n    }\n\n    const stateColumns = this._stateColumns()\n\n    // The internal columns are not intended for a user to be able to move them.\n    // Store the internal columns current index, so it can be moved back ofter\n    // sorting. This may not be the best way to do this, but it is easier than\n    // making a sort that avoids them.\n    //\n    // NOTE: If we add an internal column that can be moved then this will need\n    // to be changed.\n    const internalColumns = columns\n      .map((column, index) => ({ column, index }))\n      .filter(x => isInternalColumn(x.column))\n\n    for (const c of stateColumns) {\n      const currentIndex = columns.findIndex(x => getColumnProp(x) === c.columnProp)\n      if (currentIndex === c.index || currentIndex === -1) {\n        // Skip if already at correct index.\n        // Skip columns not found. It may be a column that was removed from the\n        // table, but we still want to handle the other columns.\n        continue\n      }\n\n      arrayMoveMutable(columns, currentIndex, c.index)\n    }\n\n    for (const c of internalColumns) {\n      const currentIndex = columns.findIndex(col => col === c.column)\n      if (currentIndex !== -1) {\n        arrayMoveMutable(columns, currentIndex, c.index)\n      } else {\n        if (isDevMode()) {\n          console.warn(`Internal column could not be found after sorting. Was it lost during the sorting?`)\n        }\n      }\n    }\n  }\n\n  private _isValidState(state: OrderColumnsAlterationState): boolean {\n    // NOTE: Checking null or undefined, even though the type doesn't allow,\n    // because the state may have been loaded from an invalid persistant\n    // storage.\n\n    // TODO: Remove when state validation/migration is implemented to happen\n    // when retrieved from storage.\n    if (!notNullOrUndefined(state.columns)) {\n      return false\n    }\n\n    // NOTE: Didn't iterate each column record, because it is probably better to\n    // just skip to invalid column records. It does prevent being able to\n    // validate the whole state though.\n\n    return true\n  }\n\n  private _isColumnOrderRecordValid(columnOrder: ColumnOrderRecord): boolean {\n    return notNullOrUndefined(columnOrder.columnProp) && notNullOrUndefined(columnOrder.index)\n  }\n\n  private _stateColumns(): ColumnOrderRecord[] {\n    return this.state.columns.filter(c => {\n      if (!this._isColumnOrderRecordValid(c)) {\n        if (isDevMode()) {\n          console.warn('Invalid column order record', c)\n        }\n        return false\n      }\n      return true\n    }).sort((a, b) => a.index === b.index ? 0 : a.index > b.index ? 1 : -1)\n  }\n}\n"]}
@@ -1282,8 +1282,8 @@ class OrderColumnsAlteration extends ColumnsAlteration {
1282
1282
  // NOTE: If we add an internal column that can be moved then this will need
1283
1283
  // to be changed.
1284
1284
  const internalColumns = columns
1285
- .filter(c => isInternalColumn(c))
1286
- .map((column, index) => ({ column, index }));
1285
+ .map((column, index) => ({ column, index }))
1286
+ .filter(x => isInternalColumn(x.column));
1287
1287
  for (const c of stateColumns) {
1288
1288
  const currentIndex = columns.findIndex(x => getColumnProp(x) === c.columnProp);
1289
1289
  if (currentIndex === c.index || currentIndex === -1) {
@@ -2040,12 +2040,13 @@ class DatatableExportButtonComponent {
2040
2040
  : `${exporter.label} export is not available.`;
2041
2041
  this._toastr.error(msg, 'Data Export');
2042
2042
  }
2043
- const export$ = this._datatable.rows$
2044
- .pipe(take(1), map(rows => {
2043
+ const export$ = combineLatest([
2044
+ this._datatable.rows$, this._datatable.columns$
2045
+ ]).pipe(take(1), map(([rows, columns]) => {
2045
2046
  if (exporter.skipDataMapping) {
2046
2047
  return rows;
2047
2048
  }
2048
- return this._mapExportData(this._datatable.columns || [], rows);
2049
+ return this._mapExportData(columns || [], rows);
2049
2050
  }), concatMap(data => exporter.export(data)), catchError(err => {
2050
2051
  console.error(err);
2051
2052
  return of(false);