@theseam/ui-common 0.2.15 → 0.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (73) hide show
  1. package/bundles/theseam-ui-common-datatable.umd.js +1 -7
  2. package/bundles/theseam-ui-common-datatable.umd.js.map +1 -1
  3. package/bundles/theseam-ui-common-framework.umd.js +1 -1
  4. package/bundles/theseam-ui-common-framework.umd.js.map +1 -1
  5. package/bundles/theseam-ui-common-scrollbar.umd.js +1 -1
  6. package/bundles/theseam-ui-common-scrollbar.umd.js.map +1 -1
  7. package/bundles/theseam-ui-common-table-cell-types.umd.js +89 -4
  8. package/bundles/theseam-ui-common-table-cell-types.umd.js.map +1 -1
  9. package/bundles/theseam-ui-common-tel-input.umd.js +59 -7
  10. package/bundles/theseam-ui-common-tel-input.umd.js.map +1 -1
  11. package/bundles/theseam-ui-common-testing.umd.js.map +1 -1
  12. package/bundles/theseam-ui-common-utils.umd.js.map +1 -1
  13. package/bundles/theseam-ui-common-viewers.umd.js +269 -4
  14. package/bundles/theseam-ui-common-viewers.umd.js.map +1 -1
  15. package/datatable/datatable-column-preferences/datatable-column-preferences.component.d.ts +0 -1
  16. package/datatable/theseam-ui-common-datatable.metadata.json +1 -1
  17. package/esm2015/datatable/datatable-column-preferences/datatable-column-preferences.component.js +4 -10
  18. package/esm2015/datatable/models/columns-alteration.js +1 -1
  19. package/esm2015/datatable/models/columns-alterations/hide-column.columns-alteration.js +1 -1
  20. package/esm2015/datatable/models/columns-alterations/sort.columns-alteration.js +1 -1
  21. package/esm2015/datatable/models/columns-alterations/width.columns-alteration.js +1 -1
  22. package/esm2015/datatable/models/internal-column-props.js +1 -1
  23. package/esm2015/datatable/services/columns-alterations-manager.service.js +1 -1
  24. package/esm2015/datatable/utils/map-columns-alterations-states.js +1 -1
  25. package/esm2015/framework/top-bar/top-bar.component.js +2 -2
  26. package/esm2015/graphql/models/gql-datatable-accessor.js +1 -1
  27. package/esm2015/scrollbar/overlay-scrollbar.directive.js +2 -2
  28. package/esm2015/table-cell-types/table-cell-type-currency/table-cell-type-currency-config.js +1 -1
  29. package/esm2015/table-cell-types/table-cell-type-currency/table-cell-type-currency.component.js +17 -2
  30. package/esm2015/table-cell-types/table-cell-type-decimal/table-cell-type-decimal-config.js +1 -1
  31. package/esm2015/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.component.js +16 -2
  32. package/esm2015/table-cell-types/table-cell-type-integer/table-cell-type-integer-config.js +1 -1
  33. package/esm2015/table-cell-types/table-cell-type-integer/table-cell-type-integer.component.js +16 -2
  34. package/esm2015/table-cell-types/table-cell-type-string/table-cell-type-string-config.js +1 -1
  35. package/esm2015/table-cell-types/table-cell-type-string/table-cell-type-string.component.js +32 -4
  36. package/esm2015/tel-input/tel-input/tel-input.component.js +10 -2
  37. package/esm2015/tel-input/tel-input.directive.js +50 -5
  38. package/esm2015/testing/current-tick-time.js +1 -1
  39. package/esm2015/utils/array-move.js +1 -1
  40. package/esm2015/utils/router/is-empty-url-route.js +1 -1
  41. package/esm2015/viewers/html-template-viewer/html-template-viewer.component.js +219 -0
  42. package/esm2015/viewers/html-template-viewer/html-template-viewer.module.js +23 -0
  43. package/esm2015/viewers/html-template-viewer/index.js +3 -0
  44. package/esm2015/viewers/public-api.js +2 -1
  45. package/fesm2015/theseam-ui-common-datatable.js +1 -7
  46. package/fesm2015/theseam-ui-common-datatable.js.map +1 -1
  47. package/fesm2015/theseam-ui-common-framework.js +1 -1
  48. package/fesm2015/theseam-ui-common-framework.js.map +1 -1
  49. package/fesm2015/theseam-ui-common-scrollbar.js +1 -1
  50. package/fesm2015/theseam-ui-common-scrollbar.js.map +1 -1
  51. package/fesm2015/theseam-ui-common-table-cell-types.js +74 -5
  52. package/fesm2015/theseam-ui-common-table-cell-types.js.map +1 -1
  53. package/fesm2015/theseam-ui-common-tel-input.js +58 -6
  54. package/fesm2015/theseam-ui-common-tel-input.js.map +1 -1
  55. package/fesm2015/theseam-ui-common-testing.js.map +1 -1
  56. package/fesm2015/theseam-ui-common-utils.js.map +1 -1
  57. package/fesm2015/theseam-ui-common-viewers.js +237 -2
  58. package/fesm2015/theseam-ui-common-viewers.js.map +1 -1
  59. package/framework/theseam-ui-common-framework.metadata.json +1 -1
  60. package/package.json +1 -1
  61. package/table-cell-types/table-cell-type-currency/table-cell-type-currency-config.d.ts +5 -0
  62. package/table-cell-types/table-cell-type-decimal/table-cell-type-decimal-config.d.ts +5 -0
  63. package/table-cell-types/table-cell-type-integer/table-cell-type-integer-config.d.ts +5 -0
  64. package/table-cell-types/table-cell-type-string/table-cell-type-string-config.d.ts +8 -0
  65. package/table-cell-types/table-cell-type-string/table-cell-type-string.component.d.ts +9 -0
  66. package/table-cell-types/theseam-ui-common-table-cell-types.metadata.json +1 -1
  67. package/tel-input/tel-input.directive.d.ts +7 -3
  68. package/tel-input/theseam-ui-common-tel-input.metadata.json +1 -1
  69. package/viewers/html-template-viewer/html-template-viewer.component.d.ts +67 -0
  70. package/viewers/html-template-viewer/html-template-viewer.module.d.ts +2 -0
  71. package/viewers/html-template-viewer/index.d.ts +2 -0
  72. package/viewers/public-api.d.ts +1 -0
  73. package/viewers/theseam-ui-common-viewers.metadata.json +1 -1
@@ -0,0 +1,219 @@
1
+ import { __decorate } from "tslib";
2
+ import { ChangeDetectorRef, Component, ElementRef, Input, NgZone, ViewChild } from '@angular/core';
3
+ import { InputBoolean } from '@theseam/ui-common/core';
4
+ var TemplateMessageType;
5
+ (function (TemplateMessageType) {
6
+ TemplateMessageType["TplData"] = "theseam_tpl_data";
7
+ TemplateMessageType["TplResize"] = "theseam_tpl_resize";
8
+ })(TemplateMessageType || (TemplateMessageType = {}));
9
+ export class TheSeamHtmlTemplateViewerComponent {
10
+ constructor(_ngZone, _cdr, _elementRef) {
11
+ this._ngZone = _ngZone;
12
+ this._cdr = _cdr;
13
+ this._elementRef = _elementRef;
14
+ this._dataVersion = 0;
15
+ this._scrollHandleObserver = null;
16
+ this._scrollable = false;
17
+ this._scrollbarOptions = {
18
+ callbacks: {
19
+ onInitialized: () => this._initScrollHandleObserver(),
20
+ // Only scrollbar handles from OverlayScrollbars are currently observed,
21
+ // so we can just disable the observer for native scrollbars.
22
+ onInitializationWithdrawn: () => this._destroyScrollHandleObserver(),
23
+ onDestroyed: () => this._destroyScrollHandleObserver(),
24
+ }
25
+ };
26
+ this._mouseBlockActive = false;
27
+ this._mouseBlockWidth = '100%';
28
+ this._mouseBlockHeight = '100%';
29
+ this._onMessageFromTemplate = (e) => {
30
+ const type = e.data.type;
31
+ if (this._templateMessageHandlers[type]) {
32
+ this._ngZone.run(() => this._templateMessageHandlers[type](e.data.payload));
33
+ }
34
+ };
35
+ this._onResizeMessageFromTemplate = (payload) => {
36
+ const iframeNativeElement = this._getIFrameNativeElement();
37
+ if (iframeNativeElement) {
38
+ iframeNativeElement.style.height = `${payload.height}px`;
39
+ }
40
+ };
41
+ this._templateMessageHandlers = {
42
+ [TemplateMessageType.TplData]: () => { },
43
+ [TemplateMessageType.TplResize]: this._onResizeMessageFromTemplate
44
+ };
45
+ }
46
+ get src() { return this._src; }
47
+ set src(val) {
48
+ this._src = val;
49
+ this._updateSrc();
50
+ }
51
+ set dataVersion(value) {
52
+ const dv = value || 0;
53
+ const sendData = this._dataVersion !== dv;
54
+ this._dataVersion = dv;
55
+ if (sendData) {
56
+ this.postMessage(this._message);
57
+ }
58
+ }
59
+ set data(value) {
60
+ this.postMessage((value !== null && value !== undefined) ? JSON.stringify(value) : value);
61
+ }
62
+ set scrollable(value) {
63
+ this._scrollable = value;
64
+ if (this._scrollable) {
65
+ this._initScrollHandleObserver();
66
+ }
67
+ else {
68
+ this._destroyScrollHandleObserver();
69
+ }
70
+ }
71
+ set iframeElementRef(val) {
72
+ this._iframeElementRef = val;
73
+ const iframeNativeElement = this._getIFrameNativeElement();
74
+ if (iframeNativeElement) {
75
+ this._updateSrc();
76
+ iframeNativeElement.onload = () => this.postMessage(this._message);
77
+ }
78
+ }
79
+ ngOnInit() {
80
+ this._ngZone.runOutsideAngular(() => window.addEventListener('message', this._onMessageFromTemplate));
81
+ }
82
+ ngOnDestroy() {
83
+ window.removeEventListener('message', this._onMessageFromTemplate);
84
+ this._destroyScrollHandleObserver();
85
+ }
86
+ _updateSrc() {
87
+ const iframeNativeElement = this._getIFrameNativeElement();
88
+ if (iframeNativeElement) {
89
+ iframeNativeElement.src = this._src || '';
90
+ }
91
+ }
92
+ postMessage(msg) {
93
+ this._message = msg;
94
+ let _msg = msg;
95
+ const contentWindow = this._getIFrameContentWindow();
96
+ if (contentWindow && _msg) {
97
+ if (this._dataVersion === 2) {
98
+ const wrapper = { type: TemplateMessageType.TplData, payload: undefined };
99
+ try {
100
+ wrapper.payload = JSON.parse(_msg);
101
+ }
102
+ catch (_a) {
103
+ wrapper.payload = _msg;
104
+ }
105
+ _msg = JSON.stringify(wrapper);
106
+ }
107
+ contentWindow.postMessage(_msg, '*');
108
+ }
109
+ }
110
+ reload() {
111
+ this._updateSrc();
112
+ }
113
+ _onResized(event) {
114
+ // This ensures the iframe scales itself if it isn't listening to or misses
115
+ // the resize event.
116
+ this.reload();
117
+ }
118
+ _getIFrameNativeElement() {
119
+ var _a;
120
+ return ((_a = this._iframeElementRef) === null || _a === void 0 ? void 0 : _a.nativeElement) || null;
121
+ }
122
+ _getIFrameContentWindow() {
123
+ var _a, _b;
124
+ return ((_b = (_a = this._iframeElementRef) === null || _a === void 0 ? void 0 : _a.nativeElement) === null || _b === void 0 ? void 0 : _b.contentWindow) || null;
125
+ }
126
+ /**
127
+ * Initializes a MutationObserver to detect the 'active' class added to a
128
+ * scroll handle, because OverlayScrollbars does not seem to provide an event
129
+ * for scrollbar handle activation/deactivation.
130
+ *
131
+ * TODO: Do we need this to work for native scrollbars also?
132
+ */
133
+ _initScrollHandleObserver() {
134
+ if (this._scrollHandleObserver !== null) {
135
+ return;
136
+ }
137
+ this._ngZone.runOutsideAngular(() => {
138
+ const observer = new MutationObserver(() => {
139
+ this._ngZone.run(() => {
140
+ if (this._isScrollbarHandleActive()) {
141
+ this._enableMouseBlock();
142
+ }
143
+ else {
144
+ this._disableMouseBlock();
145
+ }
146
+ });
147
+ });
148
+ observer.observe(this._elementRef.nativeElement, {
149
+ attributes: true,
150
+ attributeFilter: ['class'],
151
+ childList: true,
152
+ subtree: true,
153
+ characterData: false,
154
+ });
155
+ this._scrollHandleObserver = observer;
156
+ });
157
+ }
158
+ _destroyScrollHandleObserver() {
159
+ if (this._scrollHandleObserver === null) {
160
+ return;
161
+ }
162
+ this._scrollHandleObserver.disconnect();
163
+ this._scrollHandleObserver = null;
164
+ }
165
+ /**
166
+ * Enables a transparent div to cover the iframe.
167
+ *
168
+ * When the mouse is over an iframe the browser stops letting the parent
169
+ * document receive mouse events. Anything actively tracking mouse movement or
170
+ * button pressed will think the mouse has left the page. So the scrollbar
171
+ * handle would deactivate, when the mouse hovers the iframe. This adds an
172
+ * element to cover the iframe, which prevents mouse events getting sent to
173
+ * the iframe.
174
+ */
175
+ _enableMouseBlock() {
176
+ this._mouseBlockActive = true;
177
+ const iframeElement = this._getIFrameNativeElement();
178
+ if (iframeElement) {
179
+ const rect = iframeElement.getBoundingClientRect();
180
+ this._mouseBlockWidth = `${rect.width}px`;
181
+ this._mouseBlockHeight = `${rect.height}px`;
182
+ }
183
+ else {
184
+ this._mouseBlockWidth = '100%';
185
+ this._mouseBlockHeight = '100%';
186
+ }
187
+ this._cdr.detectChanges();
188
+ }
189
+ _disableMouseBlock() {
190
+ this._mouseBlockActive = false;
191
+ this._cdr.detectChanges();
192
+ }
193
+ _isScrollbarHandleActive() {
194
+ return this._elementRef.nativeElement.querySelector('.os-scrollbar-handle.active') !== null;
195
+ }
196
+ }
197
+ TheSeamHtmlTemplateViewerComponent.decorators = [
198
+ { type: Component, args: [{
199
+ selector: 'seam-html-template-viewer',
200
+ template: "<div (seamElemResized)=\"_onResized($any($event))\">\n <div class=\"embed-responsive embed-responsive-4by3\"\n [seamOverlayScrollbar]=\"_scrollbarOptions\"\n [overlayScrollbarEnabled]=\"_scrollable\">\n <iframe #iframeElement class=\"embed-responsive-item\" allowfullscreen></iframe>\n <div *ngIf=\"_mouseBlockActive\"\n class=\"iframe-mouse-block\"\n [style.width]=\"_mouseBlockWidth\"\n [style.height]=\"_mouseBlockHeight\">\n </div>\n </div>\n</div>\n",
201
+ styles: [":host{display:block}.iframe-mouse-block{position:absolute;top:0;right:0;height:100%;width:100%}\n"]
202
+ },] }
203
+ ];
204
+ TheSeamHtmlTemplateViewerComponent.ctorParameters = () => [
205
+ { type: NgZone },
206
+ { type: ChangeDetectorRef },
207
+ { type: ElementRef }
208
+ ];
209
+ TheSeamHtmlTemplateViewerComponent.propDecorators = {
210
+ src: [{ type: Input }],
211
+ dataVersion: [{ type: Input }],
212
+ data: [{ type: Input }],
213
+ scrollable: [{ type: Input }],
214
+ iframeElementRef: [{ type: ViewChild, args: ['iframeElement', { static: true },] }]
215
+ };
216
+ __decorate([
217
+ InputBoolean()
218
+ ], TheSeamHtmlTemplateViewerComponent.prototype, "scrollable", null);
219
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"html-template-viewer.component.js","sourceRoot":"","sources":["../../../../../projects/ui-common/viewers/html-template-viewer/html-template-viewer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput } from '@angular/cdk/coercion'\nimport { ChangeDetectorRef, Component, ElementRef, Input, NgZone, OnDestroy, OnInit, ViewChild } from '@angular/core'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\n\ninterface TemplateResizeMessagePayload {\n  width: number\n  height: number\n}\n\nenum TemplateMessageType {\n  TplData = 'theseam_tpl_data',\n  TplResize = 'theseam_tpl_resize',\n}\n\ninterface TemplateMessage<TType, TPayload> {\n  type: TType\n  payload: TPayload\n}\n\n@Component({\n  selector: 'seam-html-template-viewer',\n  templateUrl: './html-template-viewer.component.html',\n  styleUrls: ['./html-template-viewer.component.scss']\n})\nexport class TheSeamHtmlTemplateViewerComponent implements OnInit, OnDestroy {\n  static ngAcceptInputType_scrollable: BooleanInput\n\n  private readonly _templateMessageHandlers: { [key in TemplateMessageType]: (payload: any) => void }\n\n  private _message: string | undefined | null\n  private _dataVersion: number = 0\n  private _scrollHandleObserver: MutationObserver | null = null\n\n  @Input()\n  get src(): string | null | undefined { return this._src }\n  set src(val: string | null | undefined) {\n    this._src = val\n    this._updateSrc()\n  }\n  private _src: string | null | undefined\n\n  @Input()\n  set dataVersion(value: number | undefined | null) {\n    const dv = value || 0\n    const sendData = this._dataVersion !== dv\n    this._dataVersion = dv\n    if (sendData) {\n      this.postMessage(this._message)\n    }\n  }\n\n  @Input()\n  set data(value: any) {\n    this.postMessage((value !== null && value !== undefined) ? JSON.stringify(value) : value)\n  }\n\n  @Input() @InputBoolean()\n  set scrollable(value: boolean) {\n    this._scrollable = value\n    if (this._scrollable) {\n      this._initScrollHandleObserver()\n    } else {\n      this._destroyScrollHandleObserver()\n    }\n  }\n\n  _scrollable: boolean = false\n\n  @ViewChild('iframeElement', { static: true })\n  set iframeElementRef(val: ElementRef<HTMLIFrameElement>) {\n    this._iframeElementRef = val\n    const iframeNativeElement = this._getIFrameNativeElement()\n    if (iframeNativeElement) {\n      this._updateSrc()\n      iframeNativeElement.onload = () => this.postMessage(this._message)\n    }\n  }\n  private _iframeElementRef!: ElementRef<HTMLIFrameElement>\n\n  _scrollbarOptions = {\n    callbacks: {\n      onInitialized: () => this._initScrollHandleObserver(),\n      // Only scrollbar handles from OverlayScrollbars are currently observed,\n      // so we can just disable the observer for native scrollbars.\n      onInitializationWithdrawn: () => this._destroyScrollHandleObserver(),\n      onDestroyed: () => this._destroyScrollHandleObserver(),\n    }\n  }\n\n  _mouseBlockActive: boolean = false\n  _mouseBlockWidth: string = '100%'\n  _mouseBlockHeight: string = '100%'\n\n  constructor(\n    private readonly _ngZone: NgZone,\n    private readonly _cdr: ChangeDetectorRef,\n    private readonly _elementRef: ElementRef\n  ) {\n    this._templateMessageHandlers = {\n      [TemplateMessageType.TplData]: () => { }, // Not listening for message from template\n      [TemplateMessageType.TplResize]: this._onResizeMessageFromTemplate\n    }\n  }\n\n  ngOnInit(): void {\n    this._ngZone.runOutsideAngular(() => window.addEventListener('message', this._onMessageFromTemplate))\n  }\n\n  ngOnDestroy(): void {\n    window.removeEventListener('message', this._onMessageFromTemplate)\n    this._destroyScrollHandleObserver()\n  }\n\n  private _onMessageFromTemplate = (e: any) => {\n    const type = e.data.type as TemplateMessageType\n    if (this._templateMessageHandlers[type]) {\n      this._ngZone.run(() => this._templateMessageHandlers[type](e.data.payload))\n    }\n  }\n\n  private _onResizeMessageFromTemplate = (payload: TemplateResizeMessagePayload): void => {\n    const iframeNativeElement = this._getIFrameNativeElement()\n    if (iframeNativeElement) {\n      iframeNativeElement.style.height = `${payload.height}px`\n    }\n  }\n\n  private _updateSrc(): void {\n    const iframeNativeElement = this._getIFrameNativeElement()\n    if (iframeNativeElement) {\n      iframeNativeElement.src = this._src || ''\n    }\n  }\n\n  public postMessage(msg: string | undefined | null): void {\n    this._message = msg\n\n    let _msg = msg\n    const contentWindow = this._getIFrameContentWindow()\n    if (contentWindow && _msg) {\n      if (this._dataVersion === 2) {\n        const wrapper: TemplateMessage<TemplateMessageType, any> = { type: TemplateMessageType.TplData, payload: undefined }\n        try { wrapper.payload = JSON.parse(_msg) } catch { wrapper.payload = _msg }\n        _msg = JSON.stringify(wrapper)\n      }\n\n      contentWindow.postMessage(_msg, '*')\n    }\n  }\n\n  public reload(): void {\n    this._updateSrc()\n  }\n\n  _onResized(event: { width: number, height: number }) {\n    // This ensures the iframe scales itself if it isn't listening to or misses\n    // the resize event.\n    this.reload()\n  }\n\n  private _getIFrameNativeElement(): HTMLIFrameElement | null {\n    return (this._iframeElementRef?.nativeElement) || null\n  }\n\n  private _getIFrameContentWindow(): Window | null {\n    return (this._iframeElementRef?.nativeElement?.contentWindow) || null\n  }\n\n  /**\n   * Initializes a MutationObserver to detect the 'active' class added to a\n   * scroll handle, because OverlayScrollbars does not seem to provide an event\n   * for scrollbar handle activation/deactivation.\n   *\n   * TODO: Do we need this to work for native scrollbars also?\n   */\n  private _initScrollHandleObserver(): void {\n    if (this._scrollHandleObserver !== null) {\n      return\n    }\n\n    this._ngZone.runOutsideAngular(() => {\n      const observer = new MutationObserver(() => {\n        this._ngZone.run(() => {\n          if (this._isScrollbarHandleActive()) {\n            this._enableMouseBlock()\n          } else {\n            this._disableMouseBlock()\n          }\n        })\n      })\n\n      observer.observe(this._elementRef.nativeElement, {\n        attributes: true,\n        attributeFilter: [ 'class' ],\n        childList: true,\n        subtree: true,\n        characterData: false,\n      })\n\n      this._scrollHandleObserver = observer\n    })\n  }\n\n  private _destroyScrollHandleObserver(): void {\n    if (this._scrollHandleObserver === null) {\n      return\n    }\n\n    this._scrollHandleObserver.disconnect()\n    this._scrollHandleObserver = null\n  }\n\n  /**\n   * Enables a transparent div to cover the iframe.\n   *\n   * When the mouse is over an iframe the browser stops letting the parent\n   * document receive mouse events. Anything actively tracking mouse movement or\n   * button pressed will think the mouse has left the page. So the scrollbar\n   * handle would deactivate, when the mouse hovers the iframe. This adds an\n   * element to cover the iframe, which prevents mouse events getting sent to\n   * the iframe.\n   */\n  private _enableMouseBlock(): void {\n    this._mouseBlockActive = true\n\n    const iframeElement = this._getIFrameNativeElement()\n    if (iframeElement) {\n      const rect = iframeElement.getBoundingClientRect()\n      this._mouseBlockWidth = `${rect.width}px`\n      this._mouseBlockHeight = `${rect.height}px`\n    } else {\n      this._mouseBlockWidth = '100%'\n      this._mouseBlockHeight = '100%'\n    }\n\n    this._cdr.detectChanges()\n  }\n\n  private _disableMouseBlock(): void {\n    this._mouseBlockActive = false\n    this._cdr.detectChanges()\n  }\n\n  private _isScrollbarHandleActive(): boolean {\n    return this._elementRef.nativeElement.querySelector('.os-scrollbar-handle.active') !== null\n  }\n\n}\n"]}
@@ -0,0 +1,23 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { TheSeamScrollbarModule } from '@theseam/ui-common/scrollbar';
4
+ import { TheSeamSharedModule } from '@theseam/ui-common/shared';
5
+ import { TheSeamHtmlTemplateViewerComponent } from './html-template-viewer.component';
6
+ export class TheSeamHtmlTemplateViewerModule {
7
+ }
8
+ TheSeamHtmlTemplateViewerModule.decorators = [
9
+ { type: NgModule, args: [{
10
+ imports: [
11
+ CommonModule,
12
+ TheSeamScrollbarModule,
13
+ TheSeamSharedModule,
14
+ ],
15
+ declarations: [
16
+ TheSeamHtmlTemplateViewerComponent,
17
+ ],
18
+ exports: [
19
+ TheSeamHtmlTemplateViewerComponent,
20
+ ]
21
+ },] }
22
+ ];
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHRtbC10ZW1wbGF0ZS12aWV3ZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3ZpZXdlcnMvaHRtbC10ZW1wbGF0ZS12aWV3ZXIvaHRtbC10ZW1wbGF0ZS12aWV3ZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUM5QyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBRXhDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDhCQUE4QixDQUFBO0FBQ3JFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDJCQUEyQixDQUFBO0FBRS9ELE9BQU8sRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLGtDQUFrQyxDQUFBO0FBZXJGLE1BQU0sT0FBTywrQkFBK0I7OztZQWIzQyxRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osc0JBQXNCO29CQUN0QixtQkFBbUI7aUJBQ3BCO2dCQUNELFlBQVksRUFBRTtvQkFDWixrQ0FBa0M7aUJBQ25DO2dCQUNELE9BQU8sRUFBRTtvQkFDUCxrQ0FBa0M7aUJBQ25DO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5cbmltcG9ydCB7IFRoZVNlYW1TY3JvbGxiYXJNb2R1bGUgfSBmcm9tICdAdGhlc2VhbS91aS1jb21tb24vc2Nyb2xsYmFyJ1xuaW1wb3J0IHsgVGhlU2VhbVNoYXJlZE1vZHVsZSB9IGZyb20gJ0B0aGVzZWFtL3VpLWNvbW1vbi9zaGFyZWQnXG5cbmltcG9ydCB7IFRoZVNlYW1IdG1sVGVtcGxhdGVWaWV3ZXJDb21wb25lbnQgfSBmcm9tICcuL2h0bWwtdGVtcGxhdGUtdmlld2VyLmNvbXBvbmVudCdcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBUaGVTZWFtU2Nyb2xsYmFyTW9kdWxlLFxuICAgIFRoZVNlYW1TaGFyZWRNb2R1bGUsXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIFRoZVNlYW1IdG1sVGVtcGxhdGVWaWV3ZXJDb21wb25lbnQsXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBUaGVTZWFtSHRtbFRlbXBsYXRlVmlld2VyQ29tcG9uZW50LFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFRoZVNlYW1IdG1sVGVtcGxhdGVWaWV3ZXJNb2R1bGUgeyB9XG4iXX0=
@@ -0,0 +1,3 @@
1
+ export * from './html-template-viewer.component';
2
+ export * from './html-template-viewer.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1jb21tb24vdmlld2Vycy9odG1sLXRlbXBsYXRlLXZpZXdlci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGtDQUFrQyxDQUFBO0FBQ2hELGNBQWMsK0JBQStCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2h0bWwtdGVtcGxhdGUtdmlld2VyLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vaHRtbC10ZW1wbGF0ZS12aWV3ZXIubW9kdWxlJ1xuIl19
@@ -1,2 +1,3 @@
1
1
  export * from './pdf-viewer';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi92aWV3ZXJzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3BkZi12aWV3ZXInXG4iXX0=
2
+ export * from './html-template-viewer';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi92aWV3ZXJzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUE7QUFDNUIsY0FBYyx3QkFBd0IsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcGRmLXZpZXdlcidcbmV4cG9ydCAqIGZyb20gJy4vaHRtbC10ZW1wbGF0ZS12aWV3ZXInXG4iXX0=
@@ -1915,19 +1915,13 @@ class DatatableColumnPreferencesComponent {
1915
1915
  this._datatable = _datatable;
1916
1916
  this._columnsAlterationsManager = _columnsAlterationsManager;
1917
1917
  this._filterControl = new FormControl();
1918
- this._alphabeticalColumnCompareFn = (a, b) => {
1919
- const aProp = getColumnProp(a);
1920
- const bProp = getColumnProp(b);
1921
- return aProp === bProp ? 0 : aProp > bProp ? 1 : -1;
1922
- };
1923
1918
  this._columns$ = combineLatest([
1924
1919
  (_a = this._datatable.columns$) !== null && _a !== void 0 ? _a : of([]),
1925
1920
  observeControlValue(this._filterControl)
1926
1921
  ]).pipe(map(([columns, filter]) => {
1927
1922
  const _filter = (filter || '').trim().toLowerCase();
1928
1923
  return columns
1929
- .filter(c => this._canToggleColumn(c, _filter))
1930
- .sort(this._alphabeticalColumnCompareFn);
1924
+ .filter(c => this._canToggleColumn(c, _filter));
1931
1925
  }));
1932
1926
  }
1933
1927
  _canToggleColumn(column, filter, omitInternalColumns = true) {