@theseam/ui-common 0.2.16 → 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (97) hide show
  1. package/breadcrumbs/_breadcrumbs-theme.scss +3 -0
  2. package/breadcrumbs/breadcrumbs/breadcrumbs.component.scss +10 -0
  3. package/breadcrumbs/styles/_utilities.scss +3 -0
  4. package/breadcrumbs/styles/_variables.scss +1 -0
  5. package/breadcrumbs/theseam-ui-common-breadcrumbs.metadata.json +1 -1
  6. package/bundles/theseam-ui-common-breadcrumbs.umd.js +2 -1
  7. package/bundles/theseam-ui-common-breadcrumbs.umd.js.map +1 -1
  8. package/bundles/theseam-ui-common-datatable.umd.js.map +1 -1
  9. package/bundles/theseam-ui-common-framework.umd.js +18 -15
  10. package/bundles/theseam-ui-common-framework.umd.js.map +1 -1
  11. package/bundles/theseam-ui-common-scrollbar.umd.js +1 -1
  12. package/bundles/theseam-ui-common-scrollbar.umd.js.map +1 -1
  13. package/bundles/theseam-ui-common-table-cell-types.umd.js +89 -4
  14. package/bundles/theseam-ui-common-table-cell-types.umd.js.map +1 -1
  15. package/bundles/theseam-ui-common-tel-input.umd.js +59 -7
  16. package/bundles/theseam-ui-common-tel-input.umd.js.map +1 -1
  17. package/bundles/theseam-ui-common-testing.umd.js.map +1 -1
  18. package/bundles/theseam-ui-common-utils.umd.js.map +1 -1
  19. package/bundles/theseam-ui-common-viewers.umd.js +269 -4
  20. package/bundles/theseam-ui-common-viewers.umd.js.map +1 -1
  21. package/bundles/theseam-ui-common-widget.umd.js +1 -1
  22. package/esm2015/breadcrumbs/breadcrumbs/breadcrumbs.component.js +4 -3
  23. package/esm2015/datatable/models/columns-alteration.js +1 -1
  24. package/esm2015/datatable/models/columns-alterations/hide-column.columns-alteration.js +1 -1
  25. package/esm2015/datatable/models/columns-alterations/sort.columns-alteration.js +1 -1
  26. package/esm2015/datatable/models/columns-alterations/width.columns-alteration.js +1 -1
  27. package/esm2015/datatable/models/internal-column-props.js +1 -1
  28. package/esm2015/datatable/services/columns-alterations-manager.service.js +1 -1
  29. package/esm2015/datatable/utils/map-columns-alterations-states.js +1 -1
  30. package/esm2015/framework/base-layout/base-layout.component.js +3 -3
  31. package/esm2015/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.js +5 -5
  32. package/esm2015/framework/top-bar/top-bar-title/top-bar-title.component.js +4 -3
  33. package/esm2015/framework/top-bar/top-bar.component.js +10 -8
  34. package/esm2015/graphql/models/gql-datatable-accessor.js +1 -1
  35. package/esm2015/scrollbar/overlay-scrollbar.directive.js +2 -2
  36. package/esm2015/table-cell-types/table-cell-type-currency/table-cell-type-currency-config.js +1 -1
  37. package/esm2015/table-cell-types/table-cell-type-currency/table-cell-type-currency.component.js +17 -2
  38. package/esm2015/table-cell-types/table-cell-type-decimal/table-cell-type-decimal-config.js +1 -1
  39. package/esm2015/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.component.js +16 -2
  40. package/esm2015/table-cell-types/table-cell-type-integer/table-cell-type-integer-config.js +1 -1
  41. package/esm2015/table-cell-types/table-cell-type-integer/table-cell-type-integer.component.js +16 -2
  42. package/esm2015/table-cell-types/table-cell-type-string/table-cell-type-string-config.js +1 -1
  43. package/esm2015/table-cell-types/table-cell-type-string/table-cell-type-string.component.js +32 -4
  44. package/esm2015/tel-input/tel-input/tel-input.component.js +10 -2
  45. package/esm2015/tel-input/tel-input.directive.js +50 -5
  46. package/esm2015/testing/current-tick-time.js +1 -1
  47. package/esm2015/utils/array-move.js +1 -1
  48. package/esm2015/utils/router/is-empty-url-route.js +1 -1
  49. package/esm2015/viewers/html-template-viewer/html-template-viewer.component.js +219 -0
  50. package/esm2015/viewers/html-template-viewer/html-template-viewer.module.js +23 -0
  51. package/esm2015/viewers/html-template-viewer/index.js +3 -0
  52. package/esm2015/viewers/public-api.js +2 -1
  53. package/esm2015/widget/widget/widget.component.js +1 -1
  54. package/fesm2015/theseam-ui-common-breadcrumbs.js +3 -2
  55. package/fesm2015/theseam-ui-common-breadcrumbs.js.map +1 -1
  56. package/fesm2015/theseam-ui-common-datatable.js.map +1 -1
  57. package/fesm2015/theseam-ui-common-framework.js +15 -12
  58. package/fesm2015/theseam-ui-common-framework.js.map +1 -1
  59. package/fesm2015/theseam-ui-common-scrollbar.js +1 -1
  60. package/fesm2015/theseam-ui-common-scrollbar.js.map +1 -1
  61. package/fesm2015/theseam-ui-common-table-cell-types.js +74 -5
  62. package/fesm2015/theseam-ui-common-table-cell-types.js.map +1 -1
  63. package/fesm2015/theseam-ui-common-tel-input.js +58 -6
  64. package/fesm2015/theseam-ui-common-tel-input.js.map +1 -1
  65. package/fesm2015/theseam-ui-common-testing.js.map +1 -1
  66. package/fesm2015/theseam-ui-common-utils.js.map +1 -1
  67. package/fesm2015/theseam-ui-common-viewers.js +237 -2
  68. package/fesm2015/theseam-ui-common-viewers.js.map +1 -1
  69. package/fesm2015/theseam-ui-common-widget.js +1 -1
  70. package/framework/base-layout/base-layout.component.scss +14 -0
  71. package/framework/base-layout/styles/_variables.scss +14 -0
  72. package/framework/theseam-ui-common-framework.metadata.json +1 -1
  73. package/framework/top-bar/_top-bar-theme.scss +5 -0
  74. package/framework/top-bar/styles/_utilities.scss +3 -0
  75. package/framework/top-bar/styles/_variables.scss +18 -0
  76. package/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.d.ts +3 -1
  77. package/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.scss +15 -0
  78. package/framework/top-bar/top-bar-title/top-bar-title.component.scss +6 -0
  79. package/framework/top-bar/top-bar.component.d.ts +3 -0
  80. package/framework/top-bar/top-bar.component.scss +39 -0
  81. package/package.json +1 -1
  82. package/table-cell-types/table-cell-type-currency/table-cell-type-currency-config.d.ts +5 -0
  83. package/table-cell-types/table-cell-type-decimal/table-cell-type-decimal-config.d.ts +5 -0
  84. package/table-cell-types/table-cell-type-integer/table-cell-type-integer-config.d.ts +5 -0
  85. package/table-cell-types/table-cell-type-string/table-cell-type-string-config.d.ts +8 -0
  86. package/table-cell-types/table-cell-type-string/table-cell-type-string.component.d.ts +9 -0
  87. package/table-cell-types/theseam-ui-common-table-cell-types.metadata.json +1 -1
  88. package/tel-input/tel-input.directive.d.ts +7 -3
  89. package/tel-input/theseam-ui-common-tel-input.metadata.json +1 -1
  90. package/viewers/html-template-viewer/html-template-viewer.component.d.ts +67 -0
  91. package/viewers/html-template-viewer/html-template-viewer.module.d.ts +2 -0
  92. package/viewers/html-template-viewer/index.d.ts +2 -0
  93. package/viewers/public-api.d.ts +1 -0
  94. package/viewers/theseam-ui-common-viewers.metadata.json +1 -1
  95. package/widget/styles/_variables.scss +2 -0
  96. package/widget/theseam-ui-common-widget.metadata.json +1 -1
  97. package/widget/widget/widget.component.scss +2 -0
@@ -3,6 +3,8 @@ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, O
3
3
  import { Subject } from 'rxjs';
4
4
  import { takeUntil } from 'rxjs/operators';
5
5
  import { TableCellTypesHelpersService, TABLE_CELL_DATA } from '@theseam/ui-common/table-cell-type';
6
+ import { isNumeric, notNullOrUndefined } from '@theseam/ui-common/utils';
7
+ import { coerceBooleanProperty } from '@angular/cdk/coercion';
6
8
  export class TableCellTypeCurrencyComponent {
7
9
  // TODO: implement
8
10
  // titleAttr?: string
@@ -41,11 +43,24 @@ export class TableCellTypeCurrencyComponent {
41
43
  _formatCurrency(currentValue, tableData) {
42
44
  var _a;
43
45
  const config = (_a = tableData === null || tableData === void 0 ? void 0 : tableData.colData) === null || _a === void 0 ? void 0 : _a.cellTypeConfig;
46
+ const defaultToEmpty = notNullOrUndefined(config === null || config === void 0 ? void 0 : config.defaultToEmpty) ?
47
+ this._parseConfigValue(coerceBooleanProperty(config === null || config === void 0 ? void 0 : config.defaultToEmpty), tableData) : true;
48
+ const valueIsNumeric = isNumeric(currentValue);
49
+ if (!valueIsNumeric) {
50
+ if (defaultToEmpty) {
51
+ // return empty string instead of $0 when currentValue is empty or unparseable
52
+ return '';
53
+ }
54
+ else {
55
+ // set non-numeric value to 0 so it can be formatted the same as other numbers
56
+ currentValue = 0;
57
+ }
58
+ }
44
59
  const locale = this._parseConfigValue(config === null || config === void 0 ? void 0 : config.locale, tableData) || 'en-US';
45
60
  const currency = this._parseConfigValue(config === null || config === void 0 ? void 0 : config.currency, tableData) || '$';
46
61
  const currencyCode = this._parseConfigValue(config === null || config === void 0 ? void 0 : config.currencyCode, tableData) || 'USD';
47
62
  const minIntegerDigits = this._parseConfigValue(config === null || config === void 0 ? void 0 : config.minIntegerDigits, tableData) || 1;
48
- const minFractionDigits = this._parseConfigValue(config === null || config === void 0 ? void 0 : config.minFractionDigits, tableData) || 0;
63
+ const minFractionDigits = this._parseConfigValue(config === null || config === void 0 ? void 0 : config.minFractionDigits, tableData) || 2;
49
64
  const maxFractionDigits = this._parseConfigValue(config === null || config === void 0 ? void 0 : config.maxFractionDigits, tableData) || 2;
50
65
  const format = `${minIntegerDigits}.${minFractionDigits}-${maxFractionDigits}`;
51
66
  return formatCurrency(currentValue, locale, currency, currencyCode, format);
@@ -71,4 +86,4 @@ TableCellTypeCurrencyComponent.ctorParameters = () => [
71
86
  TableCellTypeCurrencyComponent.propDecorators = {
72
87
  value: [{ type: Input }]
73
88
  };
74
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-cell-type-currency.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/table-cell-types/table-cell-type-currency/table-cell-type-currency.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { formatCurrency } from '@angular/common'\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, OnDestroy, OnInit, Optional } from '@angular/core'\nimport { Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\nimport { TableCellTypesHelpersService, TABLE_CELL_DATA, TheSeamTableColumn } from '@theseam/ui-common/table-cell-type'\nimport type { TableCellData } from '@theseam/ui-common/table-cell-type'\n\nimport { TableCellTypeConfigCurrency } from './table-cell-type-currency-config'\n\n@Component({\n  selector: 'seam-table-cell-type-currency',\n  templateUrl: './table-cell-type-currency.component.html',\n  styleUrls: ['./table-cell-type-currency.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TableCellTypeCurrencyComponent implements OnInit, OnDestroy {\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  @Input() value: string | null | undefined\n\n  row?: any\n  rowIndex?: number\n  colData?: TheSeamTableColumn<'currency', TableCellTypeConfigCurrency>\n  textAlign?: 'left' | 'center' | 'right'\n  // TODO: implement\n  // titleAttr?: string\n\n  constructor(\n    private _cdf: ChangeDetectorRef,\n    private _tableCellTypeHelpers: TableCellTypesHelpersService,\n    @Optional() @Inject(TABLE_CELL_DATA) _tableData?: TableCellData<'currency', TableCellTypeConfigCurrency>\n  ) {\n    const tableData = _tableData\n    this.value = tableData && this._formatCurrency(tableData.value, tableData)\n    this.row = tableData && tableData.row\n    this.rowIndex = tableData && tableData.rowIndex\n    this.colData = tableData && tableData.colData\n    this.textAlign = this._parseConfigValue(tableData?.colData?.cellTypeConfig?.textAlign, tableData) || 'right'\n    // this.titleAttr = this._parseConfigValue(tableData?.colData?.cellTypeConfig?.titleAttr, tableData) || this.value\n\n    if (tableData) {\n      tableData.changed\n        .pipe(takeUntil(this._ngUnsubscribe))\n        .subscribe(v => {\n          if (v.changes.hasOwnProperty('value')) {\n            this.value = this._formatCurrency(v.changes.value.currentValue, tableData)\n            this._cdf.markForCheck()\n          }\n\n          if (v.changes.hasOwnProperty('colData')) {\n            this.colData = v.changes.colData.currentValue\n            this._cdf.markForCheck()\n          }\n        })\n    }\n  }\n\n  ngOnInit() {}\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  private _formatCurrency(currentValue?: any, tableData?: TableCellData<'currency', TableCellTypeConfigCurrency>): string {\n      const config = tableData?.colData?.cellTypeConfig\n      const locale = this._parseConfigValue(config?.locale, tableData) || 'en-US'\n      const currency = this._parseConfigValue(config?.currency, tableData) || '$'\n      const currencyCode = this._parseConfigValue(config?.currencyCode, tableData) || 'USD'\n      const minIntegerDigits = this._parseConfigValue(config?.minIntegerDigits, tableData) || 1\n      const minFractionDigits = this._parseConfigValue(config?.minFractionDigits, tableData) || 0\n      const maxFractionDigits = this._parseConfigValue(config?.maxFractionDigits, tableData) || 2\n      const format = `${ minIntegerDigits }.${ minFractionDigits }-${ maxFractionDigits }`\n\n      return formatCurrency(currentValue, locale, currency, currencyCode, format )\n  }\n\n  private _parseConfigValue(val?: any, tableData?: TableCellData<'currency', TableCellTypeConfigCurrency>) {\n    const contextFn = () => this._tableCellTypeHelpers.getValueContext(val, tableData)\n    return this._tableCellTypeHelpers.parseValueProp(val, contextFn)\n  }\n\n}\n"]}
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-cell-type-currency.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/table-cell-types/table-cell-type-currency/table-cell-type-currency.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { formatCurrency } from '@angular/common'\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, OnDestroy, OnInit, Optional } from '@angular/core'\nimport { Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\nimport { TableCellTypesHelpersService, TABLE_CELL_DATA, TheSeamTableColumn } from '@theseam/ui-common/table-cell-type'\nimport type { TableCellData } from '@theseam/ui-common/table-cell-type'\nimport { isNumeric, notNullOrUndefined } from '@theseam/ui-common/utils'\n\nimport { coerceBooleanProperty } from '@angular/cdk/coercion'\n\nimport { TableCellTypeConfigCurrency } from './table-cell-type-currency-config'\n\n@Component({\n  selector: 'seam-table-cell-type-currency',\n  templateUrl: './table-cell-type-currency.component.html',\n  styleUrls: ['./table-cell-type-currency.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TableCellTypeCurrencyComponent implements OnInit, OnDestroy {\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  @Input() value: string | null | undefined\n\n  row?: any\n  rowIndex?: number\n  colData?: TheSeamTableColumn<'currency', TableCellTypeConfigCurrency>\n  textAlign?: 'left' | 'center' | 'right'\n  // TODO: implement\n  // titleAttr?: string\n\n  constructor(\n    private _cdf: ChangeDetectorRef,\n    private _tableCellTypeHelpers: TableCellTypesHelpersService,\n    @Optional() @Inject(TABLE_CELL_DATA) _tableData?: TableCellData<'currency', TableCellTypeConfigCurrency>\n  ) {\n    const tableData = _tableData\n    this.value = tableData && this._formatCurrency(tableData.value, tableData)\n    this.row = tableData && tableData.row\n    this.rowIndex = tableData && tableData.rowIndex\n    this.colData = tableData && tableData.colData\n    this.textAlign = this._parseConfigValue(tableData?.colData?.cellTypeConfig?.textAlign, tableData) || 'right'\n    // this.titleAttr = this._parseConfigValue(tableData?.colData?.cellTypeConfig?.titleAttr, tableData) || this.value\n\n    if (tableData) {\n      tableData.changed\n        .pipe(takeUntil(this._ngUnsubscribe))\n        .subscribe(v => {\n          if (v.changes.hasOwnProperty('value')) {\n            this.value = this._formatCurrency(v.changes.value.currentValue, tableData)\n            this._cdf.markForCheck()\n          }\n\n          if (v.changes.hasOwnProperty('colData')) {\n            this.colData = v.changes.colData.currentValue\n            this._cdf.markForCheck()\n          }\n        })\n    }\n  }\n\n  ngOnInit() {}\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  private _formatCurrency(currentValue?: any, tableData?: TableCellData<'currency', TableCellTypeConfigCurrency>): string {\n      const config = tableData?.colData?.cellTypeConfig\n      const defaultToEmpty = notNullOrUndefined(config?.defaultToEmpty) ?\n        this._parseConfigValue(coerceBooleanProperty(config?.defaultToEmpty), tableData) : true\n      const valueIsNumeric = isNumeric(currentValue)\n\n      if (!valueIsNumeric) {\n        if (defaultToEmpty) {\n          // return empty string instead of $0 when currentValue is empty or unparseable\n          return ''\n        } else {\n          // set non-numeric value to 0 so it can be formatted the same as other numbers\n          currentValue = 0\n        }\n      }\n\n      const locale = this._parseConfigValue(config?.locale, tableData) || 'en-US'\n      const currency = this._parseConfigValue(config?.currency, tableData) || '$'\n      const currencyCode = this._parseConfigValue(config?.currencyCode, tableData) || 'USD'\n\n      const minIntegerDigits = this._parseConfigValue(config?.minIntegerDigits, tableData) || 1\n      const minFractionDigits = this._parseConfigValue(config?.minFractionDigits, tableData) || 2\n      const maxFractionDigits = this._parseConfigValue(config?.maxFractionDigits, tableData) || 2\n      const format = `${ minIntegerDigits }.${ minFractionDigits }-${ maxFractionDigits }`\n\n      return formatCurrency(currentValue, locale, currency, currencyCode, format )\n  }\n\n  private _parseConfigValue(val?: any, tableData?: TableCellData<'currency', TableCellTypeConfigCurrency>) {\n    const contextFn = () => this._tableCellTypeHelpers.getValueContext(val, tableData)\n    return this._tableCellTypeHelpers.parseValueProp(val, contextFn)\n  }\n\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY2VsbC10eXBlLWRlY2ltYWwtY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3RhYmxlLWNlbGwtdHlwZXMvdGFibGUtY2VsbC10eXBlLWRlY2ltYWwvdGFibGUtY2VsbC10eXBlLWRlY2ltYWwtY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEeW5hbWljQWN0aW9uTGlua0RlZiwgRHluYW1pY0FjdGlvbk1vZGFsRGVmLCBEeW5hbWljVmFsdWUgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vZHluYW1pYydcbmltcG9ydCB7IFRhYmxlQ2VsbFR5cGVDb25maWcgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vdGFibGUtY2VsbC10eXBlJ1xuXG5leHBvcnQgdHlwZSBUYWJsZUNlbGxUeXBlRGVjaW1hbENvbmZpZ0FjdGlvbiA9XG4gIER5bmFtaWNBY3Rpb25MaW5rRGVmIHxcbiAgRHluYW1pY0FjdGlvbk1vZGFsRGVmXG5cbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVDZWxsVHlwZUNvbmZpZ0RlY2ltYWwgZXh0ZW5kcyBUYWJsZUNlbGxUeXBlQ29uZmlnPCdkZWNpbWFsJz4ge1xuICBhY3Rpb24/OiBUYWJsZUNlbGxUeXBlRGVjaW1hbENvbmZpZ0FjdGlvblxuXG4gIC8qKlxuICAgKiBFbGVtZW50IHRpdGxlIGF0dHJpYnV0ZS5cbiAgICovXG4gIC8vIHRpdGxlQXR0cj86IER5bmFtaWNWYWx1ZTxzdHJpbmc+XG5cbiAgLyoqXG4gICAqIEEgbG9jYWxlIGNvZGUgZm9yIHRoZSBsb2NhbGUgZm9ybWF0IHJ1bGVzIHRvIHVzZS4gRGVmYXVsdHMgdG8gYGVuLVVTYC5cbiAgICovXG4gIGxvY2FsZT86IER5bmFtaWNWYWx1ZTxzdHJpbmc+XG5cbiAgLyoqXG4gICAqIFdoZW4gdHJ1ZSwgcGlwZSBpbnB1dCB0aHJvdWdoIEFuZ3VsYXIgYG51bWJlcmAgcGlwZS4gRGVmYXVsdCBpcyBgdHJ1ZWAuXG4gICAqL1xuICAgZm9ybWF0TnVtYmVyPzogRHluYW1pY1ZhbHVlPGJvb2xlYW4+XG5cbiAgLyoqXG4gICAqIFRoZSBtaW5pbXVtIG51bWJlciBvZiBpbnRlZ2VyIGRpZ2l0cyBiZWZvcmUgdGhlIGRlY2ltYWwgcG9pbnQuIERlZmF1bHQgaXMgMS5cbiAgICovXG4gIG1pbkludGVnZXJEaWdpdHM/OiBEeW5hbWljVmFsdWU8bnVtYmVyPlxuXG4gIC8qKlxuICAgKiBUaGUgbWluaW11bSBudW1iZXIgb2YgZGlnaXRzIGFmdGVyIHRoZSBkZWNpbWFsIHBvaW50LiBEZWZhdWx0IGlzIDAuXG4gICAqL1xuICBtaW5GcmFjdGlvbkRpZ2l0cz86IER5bmFtaWNWYWx1ZTxudW1iZXI+XG5cbiAgLyoqXG4gICAqIFRoZSBtYXhpbXVtIG51bWJlciBvZiBkaWdpdHMgYWZ0ZXIgdGhlIGRlY2ltYWwgcG9pbnQuIERlZmF1bHQgaXMgMy5cbiAgICovXG4gIG1heEZyYWN0aW9uRGlnaXRzPzogRHluYW1pY1ZhbHVlPG51bWJlcj5cblxuICAvKipcbiAgICogRGVmYXVsdCBpcyAncmlnaHQnLlxuICAgKi9cbiAgdGV4dEFsaWduPzogRHluYW1pY1ZhbHVlPCdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0Jz5cbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY2VsbC10eXBlLWRlY2ltYWwtY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3RhYmxlLWNlbGwtdHlwZXMvdGFibGUtY2VsbC10eXBlLWRlY2ltYWwvdGFibGUtY2VsbC10eXBlLWRlY2ltYWwtY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEeW5hbWljQWN0aW9uTGlua0RlZiwgRHluYW1pY0FjdGlvbk1vZGFsRGVmLCBEeW5hbWljVmFsdWUgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vZHluYW1pYydcbmltcG9ydCB7IFRhYmxlQ2VsbFR5cGVDb25maWcgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vdGFibGUtY2VsbC10eXBlJ1xuXG5leHBvcnQgdHlwZSBUYWJsZUNlbGxUeXBlRGVjaW1hbENvbmZpZ0FjdGlvbiA9XG4gIER5bmFtaWNBY3Rpb25MaW5rRGVmIHxcbiAgRHluYW1pY0FjdGlvbk1vZGFsRGVmXG5cbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVDZWxsVHlwZUNvbmZpZ0RlY2ltYWwgZXh0ZW5kcyBUYWJsZUNlbGxUeXBlQ29uZmlnPCdkZWNpbWFsJz4ge1xuICBhY3Rpb24/OiBUYWJsZUNlbGxUeXBlRGVjaW1hbENvbmZpZ0FjdGlvblxuXG4gIC8qKlxuICAgKiBFbGVtZW50IHRpdGxlIGF0dHJpYnV0ZS5cbiAgICovXG4gIHRpdGxlQXR0cj86IER5bmFtaWNWYWx1ZTxzdHJpbmc+XG5cbiAgLyoqXG4gICAqIEEgbG9jYWxlIGNvZGUgZm9yIHRoZSBsb2NhbGUgZm9ybWF0IHJ1bGVzIHRvIHVzZS4gRGVmYXVsdHMgdG8gYGVuLVVTYC5cbiAgICovXG4gIGxvY2FsZT86IER5bmFtaWNWYWx1ZTxzdHJpbmc+XG5cbiAgLyoqXG4gICAqIFdoZW4gdHJ1ZSwgcGlwZSBpbnB1dCB0aHJvdWdoIEFuZ3VsYXIgYG51bWJlcmAgcGlwZS4gRGVmYXVsdCBpcyBgdHJ1ZWAuXG4gICAqL1xuICBmb3JtYXROdW1iZXI/OiBEeW5hbWljVmFsdWU8Ym9vbGVhbj5cblxuICAvKipcbiAgICogV2hlbiB0cnVlLCBhbiBlbXB0eSBvciB1bnBhcnNlYWJsZSB2YWx1ZSBkZWZhdWx0cyB0byBhbiBlbXB0eSBzdHJpbmcsIG90aGVyd2lzZSBkZWZhdWx0cyB0byAwLiBEZWZhdWx0IGlzIGB0cnVlYC5cbiAgICovXG4gIGRlZmF1bHRUb0VtcHR5PzogRHluYW1pY1ZhbHVlPGJvb2xlYW4+XG5cbiAgLyoqXG4gICAqIFRoZSBtaW5pbXVtIG51bWJlciBvZiBpbnRlZ2VyIGRpZ2l0cyBiZWZvcmUgdGhlIGRlY2ltYWwgcG9pbnQuIERlZmF1bHQgaXMgMS5cbiAgICovXG4gIG1pbkludGVnZXJEaWdpdHM/OiBEeW5hbWljVmFsdWU8bnVtYmVyPlxuXG4gIC8qKlxuICAgKiBUaGUgbWluaW11bSBudW1iZXIgb2YgZGlnaXRzIGFmdGVyIHRoZSBkZWNpbWFsIHBvaW50LiBEZWZhdWx0IGlzIDAuXG4gICAqL1xuICBtaW5GcmFjdGlvbkRpZ2l0cz86IER5bmFtaWNWYWx1ZTxudW1iZXI+XG5cbiAgLyoqXG4gICAqIFRoZSBtYXhpbXVtIG51bWJlciBvZiBkaWdpdHMgYWZ0ZXIgdGhlIGRlY2ltYWwgcG9pbnQuIERlZmF1bHQgaXMgMy5cbiAgICovXG4gIG1heEZyYWN0aW9uRGlnaXRzPzogRHluYW1pY1ZhbHVlPG51bWJlcj5cblxuICAvKipcbiAgICogRGVmYXVsdCBpcyAncmlnaHQnLlxuICAgKi9cbiAgdGV4dEFsaWduPzogRHluYW1pY1ZhbHVlPCdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0Jz5cbn1cbiJdfQ==
@@ -3,7 +3,7 @@ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, O
3
3
  import { Subject } from 'rxjs';
4
4
  import { takeUntil } from 'rxjs/operators';
5
5
  import { TableCellTypesHelpersService, TABLE_CELL_DATA } from '@theseam/ui-common/table-cell-type';
6
- import { notNullOrUndefined } from '@theseam/ui-common/utils';
6
+ import { isNumeric, notNullOrUndefined } from '@theseam/ui-common/utils';
7
7
  import { coerceBooleanProperty } from '@angular/cdk/coercion';
8
8
  export class TableCellTypeDecimalComponent {
9
9
  constructor(_cdf, _tableCellTypeHelpers, _tableData) {
@@ -40,8 +40,22 @@ export class TableCellTypeDecimalComponent {
40
40
  _formatDecimal(currentValue, tableData) {
41
41
  var _a;
42
42
  const config = (_a = tableData === null || tableData === void 0 ? void 0 : tableData.colData) === null || _a === void 0 ? void 0 : _a.cellTypeConfig;
43
+ const defaultToEmpty = notNullOrUndefined(config === null || config === void 0 ? void 0 : config.defaultToEmpty) ?
44
+ this._parseConfigValue(coerceBooleanProperty(config === null || config === void 0 ? void 0 : config.defaultToEmpty), tableData) : true;
43
45
  const formatDecimal = notNullOrUndefined(config === null || config === void 0 ? void 0 : config.formatNumber) ?
44
46
  this._parseConfigValue(coerceBooleanProperty(config === null || config === void 0 ? void 0 : config.formatNumber), tableData) : true;
47
+ const valueIsNumeric = isNumeric(currentValue);
48
+ // unparseable values are OK to return as long as we're not trying to format them
49
+ if (!valueIsNumeric && formatDecimal) {
50
+ if (defaultToEmpty) {
51
+ // return empty string instead of 0 when currentValue is empty or unparseable
52
+ return '';
53
+ }
54
+ else {
55
+ // set non-numeric value to 0 so it can be formatted the same as other numbers
56
+ currentValue = 0;
57
+ }
58
+ }
45
59
  const locale = this._parseConfigValue(config === null || config === void 0 ? void 0 : config.locale, tableData) || 'en-US';
46
60
  const minIntegerDigits = this._parseConfigValue(config === null || config === void 0 ? void 0 : config.minIntegerDigits, tableData) || 1;
47
61
  const minFractionDigits = this._parseConfigValue(config === null || config === void 0 ? void 0 : config.minFractionDigits, tableData) || 0;
@@ -70,4 +84,4 @@ TableCellTypeDecimalComponent.ctorParameters = () => [
70
84
  TableCellTypeDecimalComponent.propDecorators = {
71
85
  value: [{ type: Input }]
72
86
  };
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-cell-type-decimal.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { formatNumber } from '@angular/common'\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, OnDestroy, OnInit, Optional } from '@angular/core'\nimport { Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\nimport { TableCellTypesHelpersService, TABLE_CELL_DATA, TheSeamTableColumn } from '@theseam/ui-common/table-cell-type'\nimport type { TableCellData } from '@theseam/ui-common/table-cell-type'\nimport { notNullOrUndefined } from '@theseam/ui-common/utils'\n\nimport { coerceBooleanProperty } from '@angular/cdk/coercion'\nimport { TableCellTypeConfigDecimal } from './table-cell-type-decimal-config'\n\n@Component({\n  selector: 'seam-table-cell-type-decimal',\n  templateUrl: './table-cell-type-decimal.component.html',\n  styleUrls: ['./table-cell-type-decimal.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TableCellTypeDecimalComponent implements OnInit, OnDestroy {\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  @Input() value: string | undefined | null\n\n  row?: any\n  rowIndex?: number\n  colData?: TheSeamTableColumn<'decimal', TableCellTypeConfigDecimal>\n  textAlign?: 'left' | 'center' | 'right'\n\n  constructor(\n    private _cdf: ChangeDetectorRef,\n    private _tableCellTypeHelpers: TableCellTypesHelpersService,\n    @Optional() @Inject(TABLE_CELL_DATA) _tableData?: TableCellData<'decimal', TableCellTypeConfigDecimal>\n  ) {\n    const tableData = _tableData\n    this.value = tableData && this._formatDecimal(tableData.value, tableData)\n    this.row = tableData && tableData.row\n    this.rowIndex = tableData && tableData.rowIndex\n    this.colData = tableData && tableData.colData\n    this.textAlign = this._parseConfigValue(tableData?.colData?.cellTypeConfig?.textAlign, tableData) || 'right'\n\n    if (tableData) {\n      tableData.changed\n        .pipe(takeUntil(this._ngUnsubscribe))\n        .subscribe(v => {\n          if (v.changes.hasOwnProperty('value')) {\n            this.value = this._formatDecimal(v.changes.value.currentValue, tableData)\n            this._cdf.markForCheck()\n          }\n\n          if (v.changes.hasOwnProperty('colData')) {\n            this.colData = v.changes.colData.currentValue\n            this._cdf.markForCheck()\n          }\n        })\n    }\n  }\n\n  ngOnInit() {}\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  private _formatDecimal(currentValue?: any, tableData?: TableCellData<'decimal', TableCellTypeConfigDecimal> | undefined): string {\n    const config = tableData?.colData?.cellTypeConfig\n    const formatDecimal = notNullOrUndefined(config?.formatNumber) ?\n      this._parseConfigValue(coerceBooleanProperty(config?.formatNumber), tableData) : true\n    const locale = this._parseConfigValue(config?.locale, tableData) || 'en-US'\n    const minIntegerDigits = this._parseConfigValue(config?.minIntegerDigits, tableData) || 1\n    const minFractionDigits = this._parseConfigValue(config?.minFractionDigits, tableData) || 0\n    const maxFractionDigits = this._parseConfigValue(config?.maxFractionDigits, tableData) || 3\n    const format = `${ minIntegerDigits }.${ minFractionDigits }-${ maxFractionDigits }`\n\n    return formatDecimal ? formatNumber(currentValue, locale, format) : currentValue\n  }\n\n  private _parseConfigValue(val?: any, tableData?: TableCellData<'decimal', TableCellTypeConfigDecimal>) {\n    const contextFn = () => this._tableCellTypeHelpers.getValueContext(val, tableData)\n    return this._tableCellTypeHelpers.parseValueProp(val, contextFn)\n  }\n\n}\n"]}
87
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-cell-type-decimal.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAqB,QAAQ,EAAE,MAAM,eAAe,CAAA;AACjI,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAA;AAC9B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAE1C,OAAO,EAAE,4BAA4B,EAAE,eAAe,EAAsB,MAAM,oCAAoC,CAAA;AAEtH,OAAO,EAAE,SAAS,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAA;AAExE,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAA;AAS7D,MAAM,OAAO,6BAA6B;IAWxC,YACU,IAAuB,EACvB,qBAAmD,EACtB,UAAiE;;QAF9F,SAAI,GAAJ,IAAI,CAAmB;QACvB,0BAAqB,GAArB,qBAAqB,CAA8B;QAX5C,mBAAc,GAAG,IAAI,OAAO,EAAE,CAAA;QAc7C,MAAM,SAAS,GAAG,UAAU,CAAA;QAC5B,IAAI,CAAC,KAAK,GAAG,SAAS,IAAI,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;QACzE,IAAI,CAAC,GAAG,GAAG,SAAS,IAAI,SAAS,CAAC,GAAG,CAAA;QACrC,IAAI,CAAC,QAAQ,GAAG,SAAS,IAAI,SAAS,CAAC,QAAQ,CAAA;QAC/C,IAAI,CAAC,OAAO,GAAG,SAAS,IAAI,SAAS,CAAC,OAAO,CAAA;QAC7C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAA,MAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,OAAO,0CAAE,cAAc,0CAAE,SAAS,EAAE,SAAS,CAAC,IAAI,OAAO,CAAA;QAE5G,IAAI,SAAS,EAAE;YACb,SAAS,CAAC,OAAO;iBACd,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;iBACpC,SAAS,CAAC,CAAC,CAAC,EAAE;gBACb,IAAI,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE;oBACrC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,YAAY,EAAE,SAAS,CAAC,CAAA;oBACzE,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAA;iBACzB;gBAED,IAAI,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,SAAS,CAAC,EAAE;oBACvC,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,YAAY,CAAA;oBAC7C,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAA;iBACzB;YACH,CAAC,CAAC,CAAA;SACL;IACH,CAAC;IAED,QAAQ,KAAI,CAAC;IAEb,WAAW;QACT,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAA;QAC1B,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAA;IAChC,CAAC;IAEO,cAAc,CAAC,YAAkB,EAAE,SAA4E;;QACrH,MAAM,MAAM,GAAG,MAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,OAAO,0CAAE,cAAc,CAAA;QACjD,MAAM,cAAc,GAAG,kBAAkB,CAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,cAAc,CAAC,CAAC,CAAC;YACjE,IAAI,CAAC,iBAAiB,CAAC,qBAAqB,CAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,cAAc,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;QACzF,MAAM,aAAa,GAAG,kBAAkB,CAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,YAAY,CAAC,CAAC,CAAC;YAC9D,IAAI,CAAC,iBAAiB,CAAC,qBAAqB,CAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,YAAY,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;QACvF,MAAM,cAAc,GAAG,SAAS,CAAC,YAAY,CAAC,CAAA;QAE9C,iFAAiF;QACjF,IAAI,CAAC,cAAc,IAAI,aAAa,EAAE;YACpC,IAAI,cAAc,EAAE;gBAClB,6EAA6E;gBAC7E,OAAO,EAAE,CAAA;aACV;iBAAM;gBACL,8EAA8E;gBAC9E,YAAY,GAAG,CAAC,CAAA;aACjB;SACF;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,EAAE,SAAS,CAAC,IAAI,OAAO,CAAA;QAC3E,MAAM,gBAAgB,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,gBAAgB,EAAE,SAAS,CAAC,IAAI,CAAC,CAAA;QACzF,MAAM,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,iBAAiB,EAAE,SAAS,CAAC,IAAI,CAAC,CAAA;QAC3F,MAAM,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,iBAAiB,EAAE,SAAS,CAAC,IAAI,CAAC,CAAA;QAC3F,MAAM,MAAM,GAAG,GAAI,gBAAiB,IAAK,iBAAkB,IAAK,iBAAkB,EAAE,CAAA;QAEpF,OAAO,aAAa,CAAC,CAAC,CAAC,YAAY,CAAC,YAAY,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,YAAY,CAAA;IAClF,CAAC;IAEO,iBAAiB,CAAC,GAAS,EAAE,SAAgE;QACnG,MAAM,SAAS,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,eAAe,CAAC,GAAG,EAAE,SAAS,CAAC,CAAA;QAClF,OAAO,IAAI,CAAC,qBAAqB,CAAC,cAAc,CAAC,GAAG,EAAE,SAAS,CAAC,CAAA;IAClE,CAAC;;;YApFF,SAAS,SAAC;gBACT,QAAQ,EAAE,8BAA8B;gBACxC,qPAAuD;gBAEvD,eAAe,EAAE,uBAAuB,CAAC,MAAM;;aAChD;;;YAhBiC,iBAAiB;YAI1C,4BAA4B;4CA2BhC,QAAQ,YAAI,MAAM,SAAC,eAAe;;;oBAVpC,KAAK","sourcesContent":["import { formatNumber } from '@angular/common'\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, OnDestroy, OnInit, Optional } from '@angular/core'\nimport { Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\nimport { TableCellTypesHelpersService, TABLE_CELL_DATA, TheSeamTableColumn } from '@theseam/ui-common/table-cell-type'\nimport type { TableCellData } from '@theseam/ui-common/table-cell-type'\nimport { isNumeric, notNullOrUndefined } from '@theseam/ui-common/utils'\n\nimport { coerceBooleanProperty } from '@angular/cdk/coercion'\nimport { TableCellTypeConfigDecimal } from './table-cell-type-decimal-config'\n\n@Component({\n  selector: 'seam-table-cell-type-decimal',\n  templateUrl: './table-cell-type-decimal.component.html',\n  styleUrls: ['./table-cell-type-decimal.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TableCellTypeDecimalComponent implements OnInit, OnDestroy {\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  @Input() value: string | undefined | null\n\n  row?: any\n  rowIndex?: number\n  colData?: TheSeamTableColumn<'decimal', TableCellTypeConfigDecimal>\n  textAlign?: 'left' | 'center' | 'right'\n\n  constructor(\n    private _cdf: ChangeDetectorRef,\n    private _tableCellTypeHelpers: TableCellTypesHelpersService,\n    @Optional() @Inject(TABLE_CELL_DATA) _tableData?: TableCellData<'decimal', TableCellTypeConfigDecimal>\n  ) {\n    const tableData = _tableData\n    this.value = tableData && this._formatDecimal(tableData.value, tableData)\n    this.row = tableData && tableData.row\n    this.rowIndex = tableData && tableData.rowIndex\n    this.colData = tableData && tableData.colData\n    this.textAlign = this._parseConfigValue(tableData?.colData?.cellTypeConfig?.textAlign, tableData) || 'right'\n\n    if (tableData) {\n      tableData.changed\n        .pipe(takeUntil(this._ngUnsubscribe))\n        .subscribe(v => {\n          if (v.changes.hasOwnProperty('value')) {\n            this.value = this._formatDecimal(v.changes.value.currentValue, tableData)\n            this._cdf.markForCheck()\n          }\n\n          if (v.changes.hasOwnProperty('colData')) {\n            this.colData = v.changes.colData.currentValue\n            this._cdf.markForCheck()\n          }\n        })\n    }\n  }\n\n  ngOnInit() {}\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  private _formatDecimal(currentValue?: any, tableData?: TableCellData<'decimal', TableCellTypeConfigDecimal> | undefined): string {\n    const config = tableData?.colData?.cellTypeConfig\n    const defaultToEmpty = notNullOrUndefined(config?.defaultToEmpty) ?\n      this._parseConfigValue(coerceBooleanProperty(config?.defaultToEmpty), tableData) : true\n    const formatDecimal = notNullOrUndefined(config?.formatNumber) ?\n      this._parseConfigValue(coerceBooleanProperty(config?.formatNumber), tableData) : true\n    const valueIsNumeric = isNumeric(currentValue)\n\n    // unparseable values are OK to return as long as we're not trying to format them\n    if (!valueIsNumeric && formatDecimal) {\n      if (defaultToEmpty) {\n        // return empty string instead of 0 when currentValue is empty or unparseable\n        return ''\n      } else {\n        // set non-numeric value to 0 so it can be formatted the same as other numbers\n        currentValue = 0\n      }\n    }\n\n    const locale = this._parseConfigValue(config?.locale, tableData) || 'en-US'\n    const minIntegerDigits = this._parseConfigValue(config?.minIntegerDigits, tableData) || 1\n    const minFractionDigits = this._parseConfigValue(config?.minFractionDigits, tableData) || 0\n    const maxFractionDigits = this._parseConfigValue(config?.maxFractionDigits, tableData) || 3\n    const format = `${ minIntegerDigits }.${ minFractionDigits }-${ maxFractionDigits }`\n\n    return formatDecimal ? formatNumber(currentValue, locale, format) : currentValue\n  }\n\n  private _parseConfigValue(val?: any, tableData?: TableCellData<'decimal', TableCellTypeConfigDecimal>) {\n    const contextFn = () => this._tableCellTypeHelpers.getValueContext(val, tableData)\n    return this._tableCellTypeHelpers.parseValueProp(val, contextFn)\n  }\n\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY2VsbC10eXBlLWludGVnZXItY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3RhYmxlLWNlbGwtdHlwZXMvdGFibGUtY2VsbC10eXBlLWludGVnZXIvdGFibGUtY2VsbC10eXBlLWludGVnZXItY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEeW5hbWljQWN0aW9uTGlua0RlZiwgRHluYW1pY0FjdGlvbk1vZGFsRGVmLCBEeW5hbWljVmFsdWUgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vZHluYW1pYydcbmltcG9ydCB7IFRhYmxlQ2VsbFR5cGVDb25maWcgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vdGFibGUtY2VsbC10eXBlJ1xuXG5leHBvcnQgdHlwZSBUYWJsZUNlbGxUeXBlSW50ZWdlckNvbmZpZ0FjdGlvbiA9XG4gIER5bmFtaWNBY3Rpb25MaW5rRGVmIHxcbiAgRHluYW1pY0FjdGlvbk1vZGFsRGVmXG5cbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVDZWxsVHlwZUNvbmZpZ0ludGVnZXIgZXh0ZW5kcyBUYWJsZUNlbGxUeXBlQ29uZmlnPCdpbnRlZ2VyJz4ge1xuICBhY3Rpb24/OiBUYWJsZUNlbGxUeXBlSW50ZWdlckNvbmZpZ0FjdGlvblxuXG4gIC8qKlxuICAgKiBFbGVtZW50IHRpdGxlIGF0dHJpYnV0ZS5cbiAgICovXG4gIC8vIHRpdGxlQXR0cj86IER5bmFtaWNWYWx1ZTxzdHJpbmc+XG5cbiAgLyoqXG4gICAqIEEgbG9jYWxlIGNvZGUgZm9yIHRoZSBsb2NhbGUgZm9ybWF0IHJ1bGVzIHRvIHVzZS4gRGVmYXVsdHMgdG8gYGVuLVVTYC5cbiAgICovXG4gIGxvY2FsZT86IER5bmFtaWNWYWx1ZTxzdHJpbmc+XG5cbiAgLyoqXG4gICAqIFdoZW4gdHJ1ZSwgcGlwZSBpbnB1dCB0aHJvdWdoIEFuZ3VsYXIgYG51bWJlcmAgcGlwZS4gRGVmYXVsdCBpcyBgdHJ1ZWAuXG4gICAqL1xuICBmb3JtYXROdW1iZXI/OiBEeW5hbWljVmFsdWU8Ym9vbGVhbj5cblxuICAvKipcbiAgICogSWYgYGZvcm1hdE51bWJlciA9PT0gdHJ1ZWAsIHRoZSBtaW5pbXVtIG51bWJlciBvZiBpbnRlZ2VyIGRpZ2l0cyBiZWZvcmUgdGhlIGRlY2ltYWwgcG9pbnQuIERlZmF1bHQgaXMgMS5cbiAgICovXG4gICBtaW5JbnRlZ2VyRGlnaXRzPzogRHluYW1pY1ZhbHVlPG51bWJlcj5cblxuICAgLyoqXG4gICAgKiBEZWZhdWx0IGlzIGByaWdodGAuXG4gICAgKi9cbiAgIHRleHRBbGlnbj86IER5bmFtaWNWYWx1ZTwnbGVmdCcgfCAnY2VudGVyJyB8ICdyaWdodCc+XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY2VsbC10eXBlLWludGVnZXItY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3RhYmxlLWNlbGwtdHlwZXMvdGFibGUtY2VsbC10eXBlLWludGVnZXIvdGFibGUtY2VsbC10eXBlLWludGVnZXItY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEeW5hbWljQWN0aW9uTGlua0RlZiwgRHluYW1pY0FjdGlvbk1vZGFsRGVmLCBEeW5hbWljVmFsdWUgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vZHluYW1pYydcbmltcG9ydCB7IFRhYmxlQ2VsbFR5cGVDb25maWcgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vdGFibGUtY2VsbC10eXBlJ1xuXG5leHBvcnQgdHlwZSBUYWJsZUNlbGxUeXBlSW50ZWdlckNvbmZpZ0FjdGlvbiA9XG4gIER5bmFtaWNBY3Rpb25MaW5rRGVmIHxcbiAgRHluYW1pY0FjdGlvbk1vZGFsRGVmXG5cbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVDZWxsVHlwZUNvbmZpZ0ludGVnZXIgZXh0ZW5kcyBUYWJsZUNlbGxUeXBlQ29uZmlnPCdpbnRlZ2VyJz4ge1xuICBhY3Rpb24/OiBUYWJsZUNlbGxUeXBlSW50ZWdlckNvbmZpZ0FjdGlvblxuXG4gIC8qKlxuICAgKiBFbGVtZW50IHRpdGxlIGF0dHJpYnV0ZS5cbiAgICovXG4gIHRpdGxlQXR0cj86IER5bmFtaWNWYWx1ZTxzdHJpbmc+XG5cbiAgLyoqXG4gICAqIEEgbG9jYWxlIGNvZGUgZm9yIHRoZSBsb2NhbGUgZm9ybWF0IHJ1bGVzIHRvIHVzZS4gRGVmYXVsdHMgdG8gYGVuLVVTYC5cbiAgICovXG4gIGxvY2FsZT86IER5bmFtaWNWYWx1ZTxzdHJpbmc+XG5cbiAgLyoqXG4gICAqIFdoZW4gdHJ1ZSwgcGlwZSBpbnB1dCB0aHJvdWdoIEFuZ3VsYXIgYG51bWJlcmAgcGlwZS4gRGVmYXVsdCBpcyBgdHJ1ZWAuXG4gICAqL1xuICBmb3JtYXROdW1iZXI/OiBEeW5hbWljVmFsdWU8Ym9vbGVhbj5cblxuICAvKipcbiAgICogV2hlbiB0cnVlLCBhbiBlbXB0eSBvciB1bnBhcnNlYWJsZSB2YWx1ZSBkZWZhdWx0cyB0byBhbiBlbXB0eSBzdHJpbmcsIG90aGVyd2lzZSBkZWZhdWx0cyB0byAwLiBEZWZhdWx0IGlzIGB0cnVlYC5cbiAgICovXG4gIGRlZmF1bHRUb0VtcHR5PzogRHluYW1pY1ZhbHVlPGJvb2xlYW4+XG5cbiAgLyoqXG4gICAqIElmIGBmb3JtYXROdW1iZXIgPT09IHRydWVgLCB0aGUgbWluaW11bSBudW1iZXIgb2YgaW50ZWdlciBkaWdpdHMgYmVmb3JlIHRoZSBkZWNpbWFsIHBvaW50LiBEZWZhdWx0IGlzIDEuXG4gICAqL1xuICAgbWluSW50ZWdlckRpZ2l0cz86IER5bmFtaWNWYWx1ZTxudW1iZXI+XG5cbiAgIC8qKlxuICAgICogRGVmYXVsdCBpcyBgcmlnaHRgLlxuICAgICovXG4gICB0ZXh0QWxpZ24/OiBEeW5hbWljVmFsdWU8J2xlZnQnIHwgJ2NlbnRlcicgfCAncmlnaHQnPlxufVxuIl19
@@ -3,7 +3,7 @@ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, O
3
3
  import { Subject } from 'rxjs';
4
4
  import { takeUntil } from 'rxjs/operators';
5
5
  import { TableCellTypesHelpersService, TABLE_CELL_DATA } from '@theseam/ui-common/table-cell-type';
6
- import { notNullOrUndefined } from '@theseam/ui-common/utils';
6
+ import { isNumeric, notNullOrUndefined } from '@theseam/ui-common/utils';
7
7
  import { coerceBooleanProperty } from '@angular/cdk/coercion';
8
8
  export class TableCellTypeIntegerComponent {
9
9
  constructor(_cdf, _tableCellTypeHelpers, _tableData) {
@@ -40,8 +40,22 @@ export class TableCellTypeIntegerComponent {
40
40
  _formatInteger(currentValue, tableData) {
41
41
  var _a;
42
42
  const config = (_a = tableData === null || tableData === void 0 ? void 0 : tableData.colData) === null || _a === void 0 ? void 0 : _a.cellTypeConfig;
43
+ const defaultToEmpty = notNullOrUndefined(config === null || config === void 0 ? void 0 : config.defaultToEmpty) ?
44
+ this._parseConfigValue(coerceBooleanProperty(config === null || config === void 0 ? void 0 : config.defaultToEmpty), tableData) : true;
43
45
  const formatInteger = notNullOrUndefined(config === null || config === void 0 ? void 0 : config.formatNumber) ?
44
46
  this._parseConfigValue(coerceBooleanProperty(config === null || config === void 0 ? void 0 : config.formatNumber), tableData) : true;
47
+ const valueIsNumeric = isNumeric(currentValue);
48
+ // unparseable values are OK to return as long as we're not trying to format them
49
+ if (!valueIsNumeric && formatInteger) {
50
+ if (defaultToEmpty) {
51
+ // return empty string instead of 0 when currentValue is empty or unparseable
52
+ return '';
53
+ }
54
+ else {
55
+ // set non-numeric value to 0 so it can be formatted the same as other numbers
56
+ currentValue = 0;
57
+ }
58
+ }
45
59
  const locale = this._parseConfigValue(config === null || config === void 0 ? void 0 : config.locale, tableData) || 'en-US';
46
60
  const minIntegerDigits = this._parseConfigValue(config === null || config === void 0 ? void 0 : config.minIntegerDigits, tableData) || 1;
47
61
  const format = `${minIntegerDigits}.0-0`;
@@ -68,4 +82,4 @@ TableCellTypeIntegerComponent.ctorParameters = () => [
68
82
  TableCellTypeIntegerComponent.propDecorators = {
69
83
  value: [{ type: Input }]
70
84
  };
71
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-cell-type-integer.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/table-cell-types/table-cell-type-integer/table-cell-type-integer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { formatNumber } from '@angular/common'\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, OnDestroy, OnInit, Optional } from '@angular/core'\nimport { Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\nimport { TableCellTypesHelpersService, TABLE_CELL_DATA, TheSeamTableColumn } from '@theseam/ui-common/table-cell-type'\nimport type { TableCellData } from '@theseam/ui-common/table-cell-type'\nimport { notNullOrUndefined } from '@theseam/ui-common/utils'\n\nimport { coerceBooleanProperty } from '@angular/cdk/coercion'\nimport { TableCellTypeConfigInteger } from './table-cell-type-integer-config'\n\n@Component({\n  selector: 'seam-table-cell-type-integer',\n  templateUrl: './table-cell-type-integer.component.html',\n  styleUrls: ['./table-cell-type-integer.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TableCellTypeIntegerComponent implements OnInit, OnDestroy {\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  @Input() value: string | null | undefined\n\n  row?: any\n  rowIndex?: number\n  colData?: TheSeamTableColumn<'integer', TableCellTypeConfigInteger>\n  textAlign?: 'left' | 'center' | 'right'\n\n  constructor(\n    private _cdf: ChangeDetectorRef,\n    private _tableCellTypeHelpers: TableCellTypesHelpersService,\n    @Optional() @Inject(TABLE_CELL_DATA) _tableData?: TableCellData<'integer', TableCellTypeConfigInteger>\n  ) {\n    const tableData = _tableData\n    this.value = tableData && this._formatInteger(tableData.value, tableData)\n    this.row = tableData && tableData.row\n    this.rowIndex = tableData && tableData.rowIndex\n    this.colData = tableData && tableData.colData\n    this.textAlign = this._parseConfigValue(tableData?.colData?.cellTypeConfig?.textAlign, tableData) || 'right'\n\n    if (tableData) {\n      tableData.changed\n        .pipe(takeUntil(this._ngUnsubscribe))\n        .subscribe(v => {\n          if (v.changes.hasOwnProperty('value')) {\n            this.value = this._formatInteger(v.changes.value.currentValue, tableData)\n            this._cdf.markForCheck()\n          }\n\n          if (v.changes.hasOwnProperty('colData')) {\n            this.colData = v.changes.colData.currentValue\n            this._cdf.markForCheck()\n          }\n        })\n    }\n  }\n\n  ngOnInit() {}\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  private _formatInteger(currentValue?: any, tableData?: TableCellData<'integer', TableCellTypeConfigInteger> | undefined): string {\n    const config = tableData?.colData?.cellTypeConfig\n    const formatInteger = notNullOrUndefined(config?.formatNumber) ?\n      this._parseConfigValue(coerceBooleanProperty(config?.formatNumber), tableData) : true\n    const locale = this._parseConfigValue(config?.locale, tableData) || 'en-US'\n    const minIntegerDigits = this._parseConfigValue(config?.minIntegerDigits, tableData) || 1\n    const format = `${ minIntegerDigits }.0-0`\n\n    return formatInteger ? formatNumber(currentValue, locale, format ) : currentValue\n  }\n\n  private _parseConfigValue(val?: any, tableData?: TableCellData<'integer', TableCellTypeConfigInteger>) {\n    const contextFn = () => this._tableCellTypeHelpers.getValueContext(val, tableData)\n    return this._tableCellTypeHelpers.parseValueProp(val, contextFn)\n  }\n\n}\n"]}
85
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-cell-type-integer.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/table-cell-types/table-cell-type-integer/table-cell-type-integer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { formatNumber } from '@angular/common'\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, OnDestroy, OnInit, Optional } from '@angular/core'\nimport { Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\nimport { TableCellTypesHelpersService, TABLE_CELL_DATA, TheSeamTableColumn } from '@theseam/ui-common/table-cell-type'\nimport type { TableCellData } from '@theseam/ui-common/table-cell-type'\nimport { isNumeric, notNullOrUndefined } from '@theseam/ui-common/utils'\n\nimport { coerceBooleanProperty } from '@angular/cdk/coercion'\nimport { TableCellTypeConfigInteger } from './table-cell-type-integer-config'\n\n@Component({\n  selector: 'seam-table-cell-type-integer',\n  templateUrl: './table-cell-type-integer.component.html',\n  styleUrls: ['./table-cell-type-integer.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TableCellTypeIntegerComponent implements OnInit, OnDestroy {\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  @Input() value: string | null | undefined\n\n  row?: any\n  rowIndex?: number\n  colData?: TheSeamTableColumn<'integer', TableCellTypeConfigInteger>\n  textAlign?: 'left' | 'center' | 'right'\n\n  constructor(\n    private _cdf: ChangeDetectorRef,\n    private _tableCellTypeHelpers: TableCellTypesHelpersService,\n    @Optional() @Inject(TABLE_CELL_DATA) _tableData?: TableCellData<'integer', TableCellTypeConfigInteger>\n  ) {\n    const tableData = _tableData\n    this.value = tableData && this._formatInteger(tableData.value, tableData)\n    this.row = tableData && tableData.row\n    this.rowIndex = tableData && tableData.rowIndex\n    this.colData = tableData && tableData.colData\n    this.textAlign = this._parseConfigValue(tableData?.colData?.cellTypeConfig?.textAlign, tableData) || 'right'\n\n    if (tableData) {\n      tableData.changed\n        .pipe(takeUntil(this._ngUnsubscribe))\n        .subscribe(v => {\n          if (v.changes.hasOwnProperty('value')) {\n            this.value = this._formatInteger(v.changes.value.currentValue, tableData)\n            this._cdf.markForCheck()\n          }\n\n          if (v.changes.hasOwnProperty('colData')) {\n            this.colData = v.changes.colData.currentValue\n            this._cdf.markForCheck()\n          }\n        })\n    }\n  }\n\n  ngOnInit() {}\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  private _formatInteger(currentValue?: any, tableData?: TableCellData<'integer', TableCellTypeConfigInteger> | undefined): string {\n    const config = tableData?.colData?.cellTypeConfig\n    const defaultToEmpty = notNullOrUndefined(config?.defaultToEmpty) ?\n      this._parseConfigValue(coerceBooleanProperty(config?.defaultToEmpty), tableData) : true\n    const formatInteger = notNullOrUndefined(config?.formatNumber) ?\n      this._parseConfigValue(coerceBooleanProperty(config?.formatNumber), tableData) : true\n    const valueIsNumeric = isNumeric(currentValue)\n\n    // unparseable values are OK to return as long as we're not trying to format them\n    if (!valueIsNumeric && formatInteger) {\n      if (defaultToEmpty) {\n        // return empty string instead of 0 when currentValue is empty or unparseable\n        return ''\n      } else {\n        // set non-numeric value to 0 so it can be formatted the same as other numbers\n        currentValue = 0\n      }\n    }\n\n    const locale = this._parseConfigValue(config?.locale, tableData) || 'en-US'\n    const minIntegerDigits = this._parseConfigValue(config?.minIntegerDigits, tableData) || 1\n    const format = `${ minIntegerDigits }.0-0`\n\n    return formatInteger ? formatNumber(currentValue, locale, format ) : currentValue\n  }\n\n  private _parseConfigValue(val?: any, tableData?: TableCellData<'integer', TableCellTypeConfigInteger>) {\n    const contextFn = () => this._tableCellTypeHelpers.getValueContext(val, tableData)\n    return this._tableCellTypeHelpers.parseValueProp(val, contextFn)\n  }\n\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY2VsbC10eXBlLXN0cmluZy1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1jb21tb24vdGFibGUtY2VsbC10eXBlcy90YWJsZS1jZWxsLXR5cGUtc3RyaW5nL3RhYmxlLWNlbGwtdHlwZS1zdHJpbmctY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEeW5hbWljQWN0aW9uTGlua0RlZiwgRHluYW1pY0FjdGlvbk1vZGFsRGVmLCBEeW5hbWljVmFsdWUgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vZHluYW1pYydcbmltcG9ydCB7IFRhYmxlQ2VsbFR5cGVDb25maWcgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vdGFibGUtY2VsbC10eXBlJ1xuXG5leHBvcnQgdHlwZSBUYWJsZUNlbGxUeXBlU3RyaW5nQ29uZmlnQWN0aW9uID1cbiAgRHluYW1pY0FjdGlvbkxpbmtEZWYgfFxuICBEeW5hbWljQWN0aW9uTW9kYWxEZWZcblxuZXhwb3J0IGludGVyZmFjZSBUYWJsZUNlbGxUeXBlQ29uZmlnU3RyaW5nIGV4dGVuZHMgVGFibGVDZWxsVHlwZUNvbmZpZzwnc3RyaW5nJz4ge1xuICBhY3Rpb24/OiBUYWJsZUNlbGxUeXBlU3RyaW5nQ29uZmlnQWN0aW9uXG5cbiAgLyoqXG4gICAqIEVsZW1lbnQgdGl0bGUgYXR0cmlidXRlLlxuICAgKi9cbiAgdGl0bGVBdHRyPzogRHluYW1pY1ZhbHVlPHN0cmluZz5cbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY2VsbC10eXBlLXN0cmluZy1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1jb21tb24vdGFibGUtY2VsbC10eXBlcy90YWJsZS1jZWxsLXR5cGUtc3RyaW5nL3RhYmxlLWNlbGwtdHlwZS1zdHJpbmctY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEeW5hbWljQWN0aW9uTGlua0RlZiwgRHluYW1pY0FjdGlvbk1vZGFsRGVmLCBEeW5hbWljVmFsdWUgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vZHluYW1pYydcbmltcG9ydCB7IFRhYmxlQ2VsbFR5cGVDb25maWcgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vdGFibGUtY2VsbC10eXBlJ1xuXG5leHBvcnQgdHlwZSBUYWJsZUNlbGxUeXBlU3RyaW5nQ29uZmlnQWN0aW9uID1cbiAgRHluYW1pY0FjdGlvbkxpbmtEZWYgfFxuICBEeW5hbWljQWN0aW9uTW9kYWxEZWZcblxuZXhwb3J0IGludGVyZmFjZSBUYWJsZUNlbGxUeXBlQ29uZmlnU3RyaW5nIGV4dGVuZHMgVGFibGVDZWxsVHlwZUNvbmZpZzwnc3RyaW5nJz4ge1xuICBhY3Rpb24/OiBUYWJsZUNlbGxUeXBlU3RyaW5nQ29uZmlnQWN0aW9uXG5cbiAgLyoqXG4gICAqIEVsZW1lbnQgdGl0bGUgYXR0cmlidXRlLlxuICAgKi9cbiAgdGl0bGVBdHRyPzogRHluYW1pY1ZhbHVlPHN0cmluZz5cblxuICAvKipcbiAgICogU3R5bGVzIGFkZGVkIHRvIHRoZSByb290IGNlbGwgZWxlbWVudHMgYHN0eWxlYCBhdHRyaWJ1dGUuXG4gICAqL1xuICAvLyBUT0RPOiByZWZhY3RvciBUYWJsZUNlbGxUeXBlQ29uZmlnIHN0eWxlcyBvYmogdG8gYmUgZHluYW1pYz9cbiAgc3R5bGVBdHRyPzogRHluYW1pY1ZhbHVlPHN0cmluZyB8IHN0cmluZ1tdPlxuXG4gIC8qKlxuICAgKiBDbGFzc2VzIGFkZGVkIHRvIHRoZSByb290IGNlbGwgZWxlbWVudHMgYGNsYXNzYCBhdHRyaWJ1dGUuXG4gICAqL1xuICAvLyBUT0RPOiByZWZhY3RvciBUYWJsZUNlbGxUeXBlQ29uZmlnIGNzc0NsYXNzIG9iaiB0byBiZSBkeW5hbWljP1xuICBjbGFzc0F0dHI/OiBEeW5hbWljVmFsdWU8c3RyaW5nIHwgc3RyaW5nW10+XG5cbn1cbiJdfQ==
@@ -39,12 +39,18 @@ export class TableCellTypeStringComponent {
39
39
  set config(value) {
40
40
  this._config = value;
41
41
  if (value) {
42
- this.setAction(value.action);
42
+ this.setConfig(value);
43
43
  }
44
44
  }
45
- set title(value) { this.title = value; }
45
+ set title(value) { this._title = value; }
46
46
  get title() { return this._title; }
47
47
  get _titleAttr() { return this.title || this.value; }
48
+ set style(value) { this._style = value; }
49
+ get style() { return this._style; }
50
+ get _styleAttr() { return this.style; }
51
+ set classAttr(value) { this._class = value; }
52
+ get classAttr() { return this._class; }
53
+ get _classAttr() { return this.classAttr; }
48
54
  ngOnInit() {
49
55
  const _data = this._tableData;
50
56
  if (_data) {
@@ -105,6 +111,24 @@ export class TableCellTypeStringComponent {
105
111
  this._detectMimeContent = detectMimeContent;
106
112
  this._queryParams = queryParams;
107
113
  }
114
+ setConfig(config) {
115
+ if (!config) {
116
+ return;
117
+ }
118
+ const title = this._parseConfigValue(config.titleAttr);
119
+ if (title) {
120
+ this.title = title;
121
+ }
122
+ const style = this._parseConfigValue(config.styleAttr);
123
+ if (style) {
124
+ this.style = style;
125
+ }
126
+ const classAttr = this._parseConfigValue(config.classAttr);
127
+ if (classAttr) {
128
+ this.classAttr = classAttr;
129
+ }
130
+ this.setAction(config.action);
131
+ }
108
132
  _parseConfigValue(val) {
109
133
  const contextFn = () => this._tableCellTypeHelpers.getValueContext(val, this._tableCellData);
110
134
  return this._tableCellTypeHelpers.parseValueProp(val, contextFn);
@@ -145,6 +169,10 @@ TableCellTypeStringComponent.propDecorators = {
145
169
  value: [{ type: Input }],
146
170
  config: [{ type: Input }],
147
171
  title: [{ type: Input }],
148
- _titleAttr: [{ type: HostBinding, args: ['attr.title',] }]
172
+ _titleAttr: [{ type: HostBinding, args: ['attr.title',] }],
173
+ style: [{ type: Input }],
174
+ _styleAttr: [{ type: HostBinding, args: ['attr.style',] }],
175
+ classAttr: [{ type: Input }],
176
+ _classAttr: [{ type: HostBinding, args: ['class',] }]
149
177
  };
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-cell-type-string.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/table-cell-types/table-cell-type-string/table-cell-type-string.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  HostBinding,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional\n} from '@angular/core'\nimport { Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\nimport { DatatableComponent } from '@theseam/ui-common/datatable'\nimport { TableComponent } from '@theseam/ui-common/table'\nimport { TableCellTypesHelpersService, TABLE_CELL_DATA } from '@theseam/ui-common/table-cell-type'\nimport type { TableCellData, TheSeamTableColumn } from '@theseam/ui-common/table-cell-type'\n\n\nimport { TableCellTypeConfigString, TableCellTypeStringConfigAction } from './table-cell-type-string-config'\n\nexport type StringTemplateType = 'default' | 'link' | 'link-external' | 'link-encrypted' | 'button'\n\n@Component({\n  selector: 'seam-table-cell-type-string',\n  templateUrl: './table-cell-type-string.component.html',\n  styleUrls: ['./table-cell-type-string.component.scss'],\n  host: { },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TableCellTypeStringComponent implements OnInit, OnDestroy {\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  @Input()\n  get value() { return this._value }\n  set value(val: string | null | undefined) {\n    this._value = val\n    // TODO: This is temporary to test the feature and will be fixed when the\n    // dynamic column data is fixed. The plan is to add a config toggle to\n    // always enable and depending on performance it could try to decide on its\n    // own based on content size.\n    if (this.value && this.value.length > 30) {\n      this.canPopover = true\n    }\n  }\n  _value: string | null | undefined\n\n  @Input()\n  get config() { return this._config }\n  set config(value: TableCellTypeConfigString | undefined | null) {\n    this._config = value\n    if (value) {\n      this.setAction(value.action)\n    }\n  }\n  private _config: TableCellTypeConfigString | undefined | null\n\n  _tplType: StringTemplateType = 'default'\n  _link?: string\n  _title?: string\n  _queryParams?: { [k: string]: any }\n\n  _buttonAction?: TableCellTypeStringConfigAction\n\n  _tableCellData?: TableCellData<'string', TableCellTypeConfigString>\n  _row?: any\n  _rowIndex?: number\n  _colData?: TheSeamTableColumn<'string', TableCellTypeConfigString>\n\n  _download?: boolean\n  _detectMimeContent?: boolean\n\n  @Input()\n  set title(value: string | undefined) { this.title = value }\n  get title(): string | undefined { return this._title }\n\n  @HostBinding('attr.title') get _titleAttr() { return this.title || this.value }\n\n  canPopover = false\n\n  constructor(\n    private readonly _cdf: ChangeDetectorRef,\n    private readonly _tableCellTypeHelpers: TableCellTypesHelpersService,\n    @Optional() private _datatable?: DatatableComponent,\n    @Optional() private _table?: TableComponent,\n    @Optional() @Inject(TABLE_CELL_DATA) readonly _tableData?: TableCellData<'string', TableCellTypeConfigString>\n  ) {\n    const _data = _tableData\n    this._tableCellData = _tableData\n\n    this._row = _data && _data.row\n    this._rowIndex = _data && _data.rowIndex\n\n    this.value = _data && _data.value\n    this._colData = _data && _data.colData\n    if (_data && _data.colData && (<any>_data.colData).cellTypeConfig) {\n      this.config = (<any>_data.colData).cellTypeConfig\n    }\n  }\n\n  ngOnInit() {\n    const _data = this._tableData\n    if (_data) {\n      _data.changed\n        .pipe(takeUntil(this._ngUnsubscribe))\n        .subscribe(v => {\n          if (v.changes.hasOwnProperty('value')) {\n            this.value = v.changes.value.currentValue\n            this._cdf.markForCheck()\n          }\n\n          if (v.changes.hasOwnProperty('colData')) {\n            const colData = v.changes.colData.currentValue\n            if (colData && colData.cellTypeConfig !== this.config) {\n              this.config = colData.cellTypeConfig\n            } else {\n              this.config = undefined\n            }\n            this._cdf.markForCheck()\n          } else {\n            if (v.changes.hasOwnProperty('row')) {\n              this.config = this.config\n              this._cdf.markForCheck()\n            }\n          }\n        })\n    }\n  }\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  public setAction(configAction?: TableCellTypeStringConfigAction) {\n    let newTplType: StringTemplateType = 'default'\n    let link: string | undefined\n    let download: boolean = false\n    let detectMimeContent = false\n    let queryParams: { [k: string]: any } | undefined\n\n    if (configAction) {\n      if (configAction.type === 'link') {\n        link = this._parseConfigValue(configAction.link)\n        if (link !== undefined && link !== null) {\n          newTplType = this._parseConfigValue(configAction.asset) ? 'link-encrypted' : 'link'\n          download = !!this._parseConfigValue(configAction.download)\n          detectMimeContent = !!this._parseConfigValue(configAction.detectMimeContent)\n          queryParams = this._parseConfigValue(configAction.queryParams)\n        }\n      } else if (configAction.type === 'modal') {\n        newTplType = 'button'\n        this._buttonAction = configAction\n      }\n    }\n\n    this._tplType = newTplType\n    this._link = link\n    this._download = download\n    this._detectMimeContent = detectMimeContent\n    this._queryParams = queryParams\n  }\n\n  private _parseConfigValue(val: any) {\n    const contextFn = () => this._tableCellTypeHelpers.getValueContext(val, this._tableCellData)\n    return this._tableCellTypeHelpers.parseValueProp(val, contextFn)\n  }\n\n  _doButtonAction() {\n    if (this._buttonAction && this._buttonAction.type === 'modal') {\n      const contextFn = () => this._tableCellTypeHelpers.getValueContext(this.value, this._tableCellData)\n      this._tableCellTypeHelpers.handleModalAction(this._buttonAction, contextFn)\n        .subscribe(\n          r => {},\n          err => console.error(err),\n          () => this._actionRefreshRequest()\n        )\n    }\n  }\n\n  private _actionRefreshRequest() {\n    if (this._datatable) {\n      this._datatable.triggerActionRefreshRequest()\n    } else if (this._table) {\n      this._table.triggerActionRefreshRequest()\n    }\n  }\n\n}\n"]}
178
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-cell-type-string.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/table-cell-types/table-cell-type-string/table-cell-type-string.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  HostBinding,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional\n} from '@angular/core'\nimport { Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\nimport { DatatableComponent } from '@theseam/ui-common/datatable'\nimport { TableComponent } from '@theseam/ui-common/table'\nimport { TableCellTypesHelpersService, TABLE_CELL_DATA } from '@theseam/ui-common/table-cell-type'\nimport type { TableCellData, TheSeamTableColumn } from '@theseam/ui-common/table-cell-type'\n\n\nimport { TableCellTypeConfigString, TableCellTypeStringConfigAction } from './table-cell-type-string-config'\n\nexport type StringTemplateType = 'default' | 'link' | 'link-external' | 'link-encrypted' | 'button'\n\n@Component({\n  selector: 'seam-table-cell-type-string',\n  templateUrl: './table-cell-type-string.component.html',\n  styleUrls: ['./table-cell-type-string.component.scss'],\n  host: { },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TableCellTypeStringComponent implements OnInit, OnDestroy {\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  @Input()\n  get value() { return this._value }\n  set value(val: string | null | undefined) {\n    this._value = val\n    // TODO: This is temporary to test the feature and will be fixed when the\n    // dynamic column data is fixed. The plan is to add a config toggle to\n    // always enable and depending on performance it could try to decide on its\n    // own based on content size.\n    if (this.value && this.value.length > 30) {\n      this.canPopover = true\n    }\n  }\n  _value: string | null | undefined\n\n  @Input()\n  get config() { return this._config }\n  set config(value: TableCellTypeConfigString | undefined | null) {\n    this._config = value\n    if (value) {\n      this.setConfig(value)\n    }\n  }\n  private _config: TableCellTypeConfigString | undefined | null\n\n  _tplType: StringTemplateType = 'default'\n  _link?: string\n  _title?: string\n  _queryParams?: { [k: string]: any }\n\n  _style?: string\n  _class?: string\n\n  _buttonAction?: TableCellTypeStringConfigAction\n\n  _tableCellData?: TableCellData<'string', TableCellTypeConfigString>\n  _row?: any\n  _rowIndex?: number\n  _colData?: TheSeamTableColumn<'string', TableCellTypeConfigString>\n\n  _download?: boolean\n  _detectMimeContent?: boolean\n\n  @Input()\n  set title(value: string | undefined) { this._title = value }\n  get title(): string | undefined { return this._title }\n\n  @HostBinding('attr.title') get _titleAttr() { return this.title || this.value }\n\n  @Input()\n  set style(value: string | undefined) { this._style = value }\n  get style(): string | undefined { return this._style }\n\n  @HostBinding('attr.style') get _styleAttr() { return this.style }\n\n  @Input()\n  set classAttr(value: string | undefined) { this._class = value }\n  get classAttr(): string | undefined { return this._class }\n\n  @HostBinding('class') get _classAttr() { return this.classAttr }\n\n  canPopover = false\n\n  constructor(\n    private readonly _cdf: ChangeDetectorRef,\n    private readonly _tableCellTypeHelpers: TableCellTypesHelpersService,\n    @Optional() private _datatable?: DatatableComponent,\n    @Optional() private _table?: TableComponent,\n    @Optional() @Inject(TABLE_CELL_DATA) readonly _tableData?: TableCellData<'string', TableCellTypeConfigString>\n  ) {\n    const _data = _tableData\n    this._tableCellData = _tableData\n\n    this._row = _data && _data.row\n    this._rowIndex = _data && _data.rowIndex\n\n    this.value = _data && _data.value\n    this._colData = _data && _data.colData\n    if (_data && _data.colData && (<any>_data.colData).cellTypeConfig) {\n      this.config = (<any>_data.colData).cellTypeConfig\n    }\n  }\n\n  ngOnInit() {\n    const _data = this._tableData\n    if (_data) {\n      _data.changed\n        .pipe(takeUntil(this._ngUnsubscribe))\n        .subscribe(v => {\n          if (v.changes.hasOwnProperty('value')) {\n            this.value = v.changes.value.currentValue\n            this._cdf.markForCheck()\n          }\n\n          if (v.changes.hasOwnProperty('colData')) {\n            const colData = v.changes.colData.currentValue\n            if (colData && colData.cellTypeConfig !== this.config) {\n              this.config = colData.cellTypeConfig\n            } else {\n              this.config = undefined\n            }\n            this._cdf.markForCheck()\n          } else {\n            if (v.changes.hasOwnProperty('row')) {\n              this.config = this.config\n              this._cdf.markForCheck()\n            }\n          }\n        })\n    }\n  }\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  public setAction(configAction?: TableCellTypeStringConfigAction) {\n    let newTplType: StringTemplateType = 'default'\n    let link: string | undefined\n    let download: boolean = false\n    let detectMimeContent = false\n    let queryParams: { [k: string]: any } | undefined\n\n    if (configAction) {\n      if (configAction.type === 'link') {\n        link = this._parseConfigValue(configAction.link)\n        if (link !== undefined && link !== null) {\n          newTplType = this._parseConfigValue(configAction.asset) ? 'link-encrypted' : 'link'\n          download = !!this._parseConfigValue(configAction.download)\n          detectMimeContent = !!this._parseConfigValue(configAction.detectMimeContent)\n          queryParams = this._parseConfigValue(configAction.queryParams)\n        }\n      } else if (configAction.type === 'modal') {\n        newTplType = 'button'\n        this._buttonAction = configAction\n      }\n    }\n\n    this._tplType = newTplType\n    this._link = link\n    this._download = download\n    this._detectMimeContent = detectMimeContent\n    this._queryParams = queryParams\n  }\n\n  public setConfig(config?: TableCellTypeConfigString): void {\n    if (!config) { return }\n\n    const title = this._parseConfigValue(config.titleAttr)\n    if (title) {\n      this.title = title\n    }\n\n    const style = this._parseConfigValue(config.styleAttr)\n    if (style) {\n      this.style = style\n    }\n\n    const classAttr = this._parseConfigValue(config.classAttr)\n    if (classAttr) {\n      this.classAttr = classAttr\n    }\n\n    this.setAction(config.action)\n  }\n\n  private _parseConfigValue(val: any) {\n    const contextFn = () => this._tableCellTypeHelpers.getValueContext(val, this._tableCellData)\n    return this._tableCellTypeHelpers.parseValueProp(val, contextFn)\n  }\n\n  _doButtonAction() {\n    if (this._buttonAction && this._buttonAction.type === 'modal') {\n      const contextFn = () => this._tableCellTypeHelpers.getValueContext(this.value, this._tableCellData)\n      this._tableCellTypeHelpers.handleModalAction(this._buttonAction, contextFn)\n        .subscribe(\n          r => {},\n          err => console.error(err),\n          () => this._actionRefreshRequest()\n        )\n    }\n  }\n\n  private _actionRefreshRequest() {\n    if (this._datatable) {\n      this._datatable.triggerActionRefreshRequest()\n    } else if (this._table) {\n      this._table.triggerActionRefreshRequest()\n    }\n  }\n\n}\n"]}
@@ -53,6 +53,14 @@ export class TheSeamTelInputComponent {
53
53
  get disabled() { return this._disabled; }
54
54
  set disabled(value) {
55
55
  const newValue = coerceBooleanProperty(value);
56
+ if (this._control.disabled !== newValue) {
57
+ if (newValue) {
58
+ this._control.disable();
59
+ }
60
+ else {
61
+ this._control.enable();
62
+ }
63
+ }
56
64
  if (newValue !== this.disabled) {
57
65
  this._disabled = newValue;
58
66
  this._changeDetectorRef.markForCheck();
@@ -138,7 +146,7 @@ TheSeamTelInputComponent.decorators = [
138
146
  multi: true
139
147
  }],
140
148
  changeDetection: ChangeDetectionStrategy.OnPush,
141
- styles: [":host{display:block}\n"]
149
+ styles: [":host{display:block}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__flag-container:hover,:host[disabled] ::ng-deep .iti--allow-dropdown .iti__flag-container:hover{cursor:default}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__flag-container:hover .iti__selected-flag,:host[disabled] ::ng-deep .iti--allow-dropdown .iti__flag-container:hover .iti__selected-flag{background-color:transparent}:host[disabled] ::ng-deep .iti--allow-dropdown .iti__arrow{display:none}\n"]
142
150
  },] }
143
151
  ];
144
152
  TheSeamTelInputComponent.ctorParameters = () => [
@@ -164,4 +172,4 @@ TheSeamTelInputComponent.propDecorators = {
164
172
  __decorate([
165
173
  InputBoolean()
166
174
  ], TheSeamTelInputComponent.prototype, "required", void 0);
167
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tel-input.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/tel-input/tel-input/tel-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor, FocusOrigin } from '@angular/cdk/a11y'\nimport { BooleanInput, coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion'\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  HostListener,\n  InjectFlags,\n  Injector,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core'\nimport { ControlValueAccessor, FormControl, NgControl, NG_VALUE_ACCESSOR } from '@angular/forms'\nimport { defer, fromEvent, merge, Observable, of, Subject } from 'rxjs'\nimport { auditTime, map, switchMap, takeUntil } from 'rxjs/operators'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport { InputDirective } from '@theseam/ui-common/form-field'\n\nimport { TheSeamTelInputDirective } from '../tel-input.directive'\n\n// TODO: Fix focus\n// TODO: Fix disabled\n\n@Component({\n  selector: 'seam-tel-input',\n  templateUrl: './tel-input.component.html',\n  styleUrls: ['./tel-input.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    // tslint:disable-next-line: no-use-before-declare\n    useExisting: forwardRef(() => TheSeamTelInputComponent),\n    multi: true\n  }],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TheSeamTelInputComponent implements OnInit, OnDestroy, ControlValueAccessor {\n  static ngAcceptInputType_required: BooleanInput\n  static ngAcceptInputType_disabled: BooleanInput\n\n  /** @ignore */\n  private readonly _ngUnsubscribe = new Subject()\n\n  /** @ignore */\n  readonly _control = new FormControl()\n\n  private _focusOrigin: FocusOrigin = null\n\n  _hasInvalidCss$: Observable<boolean>\n\n  @Input() @InputBoolean() required: boolean = false\n\n  @Input()\n  get disabled(): boolean { return this._disabled }\n  set disabled(value: boolean) {\n    const newValue = coerceBooleanProperty(value)\n\n    if (newValue !== this.disabled) {\n      this._disabled = newValue\n      this._changeDetectorRef.markForCheck()\n    }\n  }\n  /** @ignore */\n  private _disabled = false\n\n  /**\n   * Set the tab index to `-1` to allow the root element of the\n   * component to receive `focus` event from javascript, but not get focused by\n   * keyboard navigation.\n   */\n  @Input()\n  set tabIndex(value: number) { this._tabIndex = coerceNumberProperty(value) }\n  get tabIndex(): number { return this._tabIndex }\n  private _tabIndex = -1\n\n  @HostBinding('attr.disabled')\n  get _attrDisabled() { return this.disabled || null }\n\n  @HostBinding('attr.tabindex')\n  get _attrTabIndex() { return this.disabled ? -1 : (this.tabIndex || 0) }\n\n  /** Name value will be applied to the input element if present */\n  @Input() name: string | undefined | null = null\n\n  /** The value attribute of the native input element */\n  @Input() value: string | undefined | null\n\n  /** Event emitted when the \"tel\" input value changes. */\n  @Output() readonly change = new EventEmitter<string>()\n\n  /**\n   * The telInput directive\n   * @ignore\n   */\n  @ViewChild(TheSeamTelInputDirective, { static: true }) _telInputDirective?: TheSeamTelInputDirective\n\n  /**\n   * The telInput directive\n   * @ignore\n   */\n  @ViewChild(InputDirective, { static: true }) _inputDirective?: InputDirective\n\n  /**\n   * The native `<input type=\"tel\">` element\n   * @ignore\n   */\n  @ViewChild('input', { static: true }) _inputElementRef?: ElementRef<HTMLInputElement>\n\n  @HostListener('focus', [ '$event' ])\n  _onFocus() {\n    this._telInputDirective?.focus()\n  }\n\n  /**\n   * Called when the checkbox is blurred. Needed to properly implement ControlValueAccessor.\n   * @ignore\n   */\n  _onTouched: () => any = () => {}\n\n  /** @ignore */\n  private _controlValueAccessorChangeFn: (value: any) => void = () => {}\n\n  constructor(\n    private readonly _changeDetectorRef: ChangeDetectorRef,\n    private readonly _injector: Injector,\n    private readonly _elementRef: ElementRef,\n    private readonly _focusMonitor: FocusMonitor\n  ) {\n    const telInputBlurEvent$ = this._telInputDirective\n      ? fromEvent(this._telInputDirective.getHostElement(), 'blur')\n      : of<Event>()\n\n    this._hasInvalidCss$ = defer(() => of((this._injector.get(NgControl, null, InjectFlags.Self)?.control) || undefined)).pipe(\n      switchMap(control => {\n        if (control) {\n          return merge(\n            control.valueChanges,\n            control.statusChanges,\n            telInputBlurEvent$\n          ).pipe(\n            auditTime(0),\n            map(() => {\n              const inputControl = this._inputDirective?.ngControl\n              return control.invalid && (inputControl?.dirty as boolean || inputControl?.touched as boolean)\n            })\n          )\n        }\n        return of(false)\n      })\n    )\n  }\n\n  /** @ignore */\n  ngOnInit(): void {\n    this._focusMonitor.monitor(this._elementRef, true).pipe(\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe(origin => this._focusOrigin = origin)\n\n    this._control.valueChanges.pipe(\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe(v => {\n      const value = this._telInputDirective?.getFullNumber()\n      this.value = value\n      if (this._controlValueAccessorChangeFn) {\n        this._controlValueAccessorChangeFn(value)\n      }\n    })\n  }\n\n  /** @ignore */\n  ngOnDestroy(): void {\n    this._focusMonitor.stopMonitoring(this._elementRef)\n\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  writeValue(value: any) {\n    this.value = value\n    if (this._telInputDirective) {\n      this._telInputDirective.value = value\n      this._telInputDirective.updateValue()\n    }\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  registerOnChange(fn: (value: any) => void) {\n    this._controlValueAccessorChangeFn = fn\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  registerOnTouched(fn: any) {\n    this._onTouched = fn\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled\n  }\n\n  /** Focuses the input. */\n  public focus(): void {\n    this._telInputDirective?.focus()\n  }\n\n  /** Unfocuses the input. */\n  public blur(): void {\n    this._telInputDirective?.blur()\n  }\n\n  public hasFocus(): boolean {\n    return this._focusOrigin !== null && this._focusOrigin !== undefined\n  }\n\n}\n"]}
175
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tel-input.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/tel-input/tel-input/tel-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor, FocusOrigin } from '@angular/cdk/a11y'\nimport { BooleanInput, coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion'\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  HostListener,\n  InjectFlags,\n  Injector,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core'\nimport { ControlValueAccessor, FormControl, NgControl, NG_VALUE_ACCESSOR } from '@angular/forms'\nimport { defer, fromEvent, merge, Observable, of, Subject } from 'rxjs'\nimport { auditTime, map, switchMap, takeUntil } from 'rxjs/operators'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\nimport { InputDirective } from '@theseam/ui-common/form-field'\n\nimport { TheSeamTelInputDirective } from '../tel-input.directive'\n\n// TODO: Fix focus\n// TODO: Fix disabled\n\n@Component({\n  selector: 'seam-tel-input',\n  templateUrl: './tel-input.component.html',\n  styleUrls: ['./tel-input.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    // tslint:disable-next-line: no-use-before-declare\n    useExisting: forwardRef(() => TheSeamTelInputComponent),\n    multi: true\n  }],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TheSeamTelInputComponent implements OnInit, OnDestroy, ControlValueAccessor {\n  static ngAcceptInputType_required: BooleanInput\n  static ngAcceptInputType_disabled: BooleanInput\n\n  /** @ignore */\n  private readonly _ngUnsubscribe = new Subject()\n\n  /** @ignore */\n  readonly _control = new FormControl()\n\n  private _focusOrigin: FocusOrigin = null\n\n  _hasInvalidCss$: Observable<boolean>\n\n  @Input() @InputBoolean() required: boolean = false\n\n  @Input()\n  get disabled(): boolean { return this._disabled }\n  set disabled(value: boolean) {\n    const newValue = coerceBooleanProperty(value)\n\n    if (this._control.disabled !== newValue) {\n      if (newValue) {\n        this._control.disable()\n      } else {\n        this._control.enable()\n      }\n    }\n\n    if (newValue !== this.disabled) {\n      this._disabled = newValue\n      this._changeDetectorRef.markForCheck()\n    }\n  }\n  /** @ignore */\n  private _disabled = false\n\n  /**\n   * Set the tab index to `-1` to allow the root element of the\n   * component to receive `focus` event from javascript, but not get focused by\n   * keyboard navigation.\n   */\n  @Input()\n  set tabIndex(value: number) { this._tabIndex = coerceNumberProperty(value) }\n  get tabIndex(): number { return this._tabIndex }\n  private _tabIndex = -1\n\n  @HostBinding('attr.disabled')\n  get _attrDisabled() { return this.disabled || null }\n\n  @HostBinding('attr.tabindex')\n  get _attrTabIndex() { return this.disabled ? -1 : (this.tabIndex || 0) }\n\n  /** Name value will be applied to the input element if present */\n  @Input() name: string | undefined | null = null\n\n  /** The value attribute of the native input element */\n  @Input() value: string | undefined | null\n\n  /** Event emitted when the \"tel\" input value changes. */\n  @Output() readonly change = new EventEmitter<string>()\n\n  /**\n   * The telInput directive\n   * @ignore\n   */\n  @ViewChild(TheSeamTelInputDirective, { static: true }) _telInputDirective?: TheSeamTelInputDirective\n\n  /**\n   * The telInput directive\n   * @ignore\n   */\n  @ViewChild(InputDirective, { static: true }) _inputDirective?: InputDirective\n\n  /**\n   * The native `<input type=\"tel\">` element\n   * @ignore\n   */\n  @ViewChild('input', { static: true }) _inputElementRef?: ElementRef<HTMLInputElement>\n\n  @HostListener('focus', [ '$event' ])\n  _onFocus() {\n    this._telInputDirective?.focus()\n  }\n\n  /**\n   * Called when the checkbox is blurred. Needed to properly implement ControlValueAccessor.\n   * @ignore\n   */\n  _onTouched: () => any = () => {}\n\n  /** @ignore */\n  private _controlValueAccessorChangeFn: (value: any) => void = () => {}\n\n  constructor(\n    private readonly _changeDetectorRef: ChangeDetectorRef,\n    private readonly _injector: Injector,\n    private readonly _elementRef: ElementRef,\n    private readonly _focusMonitor: FocusMonitor\n  ) {\n    const telInputBlurEvent$ = this._telInputDirective\n      ? fromEvent(this._telInputDirective.getHostElement(), 'blur')\n      : of<Event>()\n\n    this._hasInvalidCss$ = defer(() => of((this._injector.get(NgControl, null, InjectFlags.Self)?.control) || undefined)).pipe(\n      switchMap(control => {\n        if (control) {\n          return merge(\n            control.valueChanges,\n            control.statusChanges,\n            telInputBlurEvent$\n          ).pipe(\n            auditTime(0),\n            map(() => {\n              const inputControl = this._inputDirective?.ngControl\n              return control.invalid && (inputControl?.dirty as boolean || inputControl?.touched as boolean)\n            })\n          )\n        }\n        return of(false)\n      })\n    )\n  }\n\n  /** @ignore */\n  ngOnInit(): void {\n    this._focusMonitor.monitor(this._elementRef, true).pipe(\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe(origin => this._focusOrigin = origin)\n\n    this._control.valueChanges.pipe(\n      takeUntil(this._ngUnsubscribe)\n    ).subscribe(v => {\n      const value = this._telInputDirective?.getFullNumber()\n      this.value = value\n      if (this._controlValueAccessorChangeFn) {\n        this._controlValueAccessorChangeFn(value)\n      }\n    })\n  }\n\n  /** @ignore */\n  ngOnDestroy(): void {\n    this._focusMonitor.stopMonitoring(this._elementRef)\n\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  writeValue(value: any) {\n    this.value = value\n    if (this._telInputDirective) {\n      this._telInputDirective.value = value\n      this._telInputDirective.updateValue()\n    }\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  registerOnChange(fn: (value: any) => void) {\n    this._controlValueAccessorChangeFn = fn\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  registerOnTouched(fn: any) {\n    this._onTouched = fn\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  /** @ignore */\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled\n  }\n\n  /** Focuses the input. */\n  public focus(): void {\n    this._telInputDirective?.focus()\n  }\n\n  /** Unfocuses the input. */\n  public blur(): void {\n    this._telInputDirective?.blur()\n  }\n\n  public hasFocus(): boolean {\n    return this._focusOrigin !== null && this._focusOrigin !== undefined\n  }\n\n}\n"]}