@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.
- package/bundles/theseam-ui-common-datatable.umd.js +1 -7
- package/bundles/theseam-ui-common-datatable.umd.js.map +1 -1
- package/bundles/theseam-ui-common-framework.umd.js +1 -1
- package/bundles/theseam-ui-common-framework.umd.js.map +1 -1
- package/bundles/theseam-ui-common-scrollbar.umd.js +1 -1
- package/bundles/theseam-ui-common-scrollbar.umd.js.map +1 -1
- package/bundles/theseam-ui-common-table-cell-types.umd.js +89 -4
- package/bundles/theseam-ui-common-table-cell-types.umd.js.map +1 -1
- package/bundles/theseam-ui-common-tel-input.umd.js +59 -7
- package/bundles/theseam-ui-common-tel-input.umd.js.map +1 -1
- package/bundles/theseam-ui-common-testing.umd.js.map +1 -1
- package/bundles/theseam-ui-common-utils.umd.js.map +1 -1
- package/bundles/theseam-ui-common-viewers.umd.js +269 -4
- package/bundles/theseam-ui-common-viewers.umd.js.map +1 -1
- package/datatable/datatable-column-preferences/datatable-column-preferences.component.d.ts +0 -1
- package/datatable/theseam-ui-common-datatable.metadata.json +1 -1
- package/esm2015/datatable/datatable-column-preferences/datatable-column-preferences.component.js +4 -10
- package/esm2015/datatable/models/columns-alteration.js +1 -1
- package/esm2015/datatable/models/columns-alterations/hide-column.columns-alteration.js +1 -1
- package/esm2015/datatable/models/columns-alterations/sort.columns-alteration.js +1 -1
- package/esm2015/datatable/models/columns-alterations/width.columns-alteration.js +1 -1
- package/esm2015/datatable/models/internal-column-props.js +1 -1
- package/esm2015/datatable/services/columns-alterations-manager.service.js +1 -1
- package/esm2015/datatable/utils/map-columns-alterations-states.js +1 -1
- package/esm2015/framework/top-bar/top-bar.component.js +2 -2
- package/esm2015/graphql/models/gql-datatable-accessor.js +1 -1
- package/esm2015/scrollbar/overlay-scrollbar.directive.js +2 -2
- package/esm2015/table-cell-types/table-cell-type-currency/table-cell-type-currency-config.js +1 -1
- package/esm2015/table-cell-types/table-cell-type-currency/table-cell-type-currency.component.js +17 -2
- package/esm2015/table-cell-types/table-cell-type-decimal/table-cell-type-decimal-config.js +1 -1
- package/esm2015/table-cell-types/table-cell-type-decimal/table-cell-type-decimal.component.js +16 -2
- package/esm2015/table-cell-types/table-cell-type-integer/table-cell-type-integer-config.js +1 -1
- package/esm2015/table-cell-types/table-cell-type-integer/table-cell-type-integer.component.js +16 -2
- package/esm2015/table-cell-types/table-cell-type-string/table-cell-type-string-config.js +1 -1
- package/esm2015/table-cell-types/table-cell-type-string/table-cell-type-string.component.js +32 -4
- package/esm2015/tel-input/tel-input/tel-input.component.js +10 -2
- package/esm2015/tel-input/tel-input.directive.js +50 -5
- package/esm2015/testing/current-tick-time.js +1 -1
- package/esm2015/utils/array-move.js +1 -1
- package/esm2015/utils/router/is-empty-url-route.js +1 -1
- package/esm2015/viewers/html-template-viewer/html-template-viewer.component.js +219 -0
- package/esm2015/viewers/html-template-viewer/html-template-viewer.module.js +23 -0
- package/esm2015/viewers/html-template-viewer/index.js +3 -0
- package/esm2015/viewers/public-api.js +2 -1
- package/fesm2015/theseam-ui-common-datatable.js +1 -7
- package/fesm2015/theseam-ui-common-datatable.js.map +1 -1
- package/fesm2015/theseam-ui-common-framework.js +1 -1
- package/fesm2015/theseam-ui-common-framework.js.map +1 -1
- package/fesm2015/theseam-ui-common-scrollbar.js +1 -1
- package/fesm2015/theseam-ui-common-scrollbar.js.map +1 -1
- package/fesm2015/theseam-ui-common-table-cell-types.js +74 -5
- package/fesm2015/theseam-ui-common-table-cell-types.js.map +1 -1
- package/fesm2015/theseam-ui-common-tel-input.js +58 -6
- package/fesm2015/theseam-ui-common-tel-input.js.map +1 -1
- package/fesm2015/theseam-ui-common-testing.js.map +1 -1
- package/fesm2015/theseam-ui-common-utils.js.map +1 -1
- package/fesm2015/theseam-ui-common-viewers.js +237 -2
- package/fesm2015/theseam-ui-common-viewers.js.map +1 -1
- package/framework/theseam-ui-common-framework.metadata.json +1 -1
- package/package.json +1 -1
- package/table-cell-types/table-cell-type-currency/table-cell-type-currency-config.d.ts +5 -0
- package/table-cell-types/table-cell-type-decimal/table-cell-type-decimal-config.d.ts +5 -0
- package/table-cell-types/table-cell-type-integer/table-cell-type-integer-config.d.ts +5 -0
- package/table-cell-types/table-cell-type-string/table-cell-type-string-config.d.ts +8 -0
- package/table-cell-types/table-cell-type-string/table-cell-type-string.component.d.ts +9 -0
- package/table-cell-types/theseam-ui-common-table-cell-types.metadata.json +1 -1
- package/tel-input/tel-input.directive.d.ts +7 -3
- package/tel-input/theseam-ui-common-tel-input.metadata.json +1 -1
- package/viewers/html-template-viewer/html-template-viewer.component.d.ts +67 -0
- package/viewers/html-template-viewer/html-template-viewer.module.d.ts +2 -0
- package/viewers/html-template-viewer/index.d.ts +2 -0
- package/viewers/public-api.d.ts +1 -0
- 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":";AACA,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAqB,SAAS,EAAE,MAAM,eAAe,CAAA;AAErH,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAA;AAOtD,IAAK,mBAGJ;AAHD,WAAK,mBAAmB;IACtB,mDAA4B,CAAA;IAC5B,uDAAgC,CAAA;AAClC,CAAC,EAHI,mBAAmB,KAAnB,mBAAmB,QAGvB;AAYD,MAAM,OAAO,kCAAkC;IAqE7C,YACmB,OAAe,EACf,IAAuB,EACvB,WAAuB;QAFvB,YAAO,GAAP,OAAO,CAAQ;QACf,SAAI,GAAJ,IAAI,CAAmB;QACvB,gBAAW,GAAX,WAAW,CAAY;QAlElC,iBAAY,GAAW,CAAC,CAAA;QACxB,0BAAqB,GAA4B,IAAI,CAAA;QAmC7D,gBAAW,GAAY,KAAK,CAAA;QAa5B,sBAAiB,GAAG;YAClB,SAAS,EAAE;gBACT,aAAa,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,yBAAyB,EAAE;gBACrD,wEAAwE;gBACxE,6DAA6D;gBAC7D,yBAAyB,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,4BAA4B,EAAE;gBACpE,WAAW,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,4BAA4B,EAAE;aACvD;SACF,CAAA;QAED,sBAAiB,GAAY,KAAK,CAAA;QAClC,qBAAgB,GAAW,MAAM,CAAA;QACjC,sBAAiB,GAAW,MAAM,CAAA;QAsB1B,2BAAsB,GAAG,CAAC,CAAM,EAAE,EAAE;YAC1C,MAAM,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,IAA2B,CAAA;YAC/C,IAAI,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,EAAE;gBACvC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAA;aAC5E;QACH,CAAC,CAAA;QAEO,iCAA4B,GAAG,CAAC,OAAqC,EAAQ,EAAE;YACrF,MAAM,mBAAmB,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAA;YAC1D,IAAI,mBAAmB,EAAE;gBACvB,mBAAmB,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,OAAO,CAAC,MAAM,IAAI,CAAA;aACzD;QACH,CAAC,CAAA;QA3BC,IAAI,CAAC,wBAAwB,GAAG;YAC9B,CAAC,mBAAmB,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC;YACxC,CAAC,mBAAmB,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,4BAA4B;SACnE,CAAA;IACH,CAAC;IArED,IACI,GAAG,KAAgC,OAAO,IAAI,CAAC,IAAI,CAAA,CAAC,CAAC;IACzD,IAAI,GAAG,CAAC,GAA8B;QACpC,IAAI,CAAC,IAAI,GAAG,GAAG,CAAA;QACf,IAAI,CAAC,UAAU,EAAE,CAAA;IACnB,CAAC;IAGD,IACI,WAAW,CAAC,KAAgC;QAC9C,MAAM,EAAE,GAAG,KAAK,IAAI,CAAC,CAAA;QACrB,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,KAAK,EAAE,CAAA;QACzC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAA;QACtB,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;SAChC;IACH,CAAC;IAED,IACI,IAAI,CAAC,KAAU;QACjB,IAAI,CAAC,WAAW,CAAC,CAAC,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;IAC3F,CAAC;IAGD,IAAI,UAAU,CAAC,KAAc;QAC3B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAA;QACxB,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,yBAAyB,EAAE,CAAA;SACjC;aAAM;YACL,IAAI,CAAC,4BAA4B,EAAE,CAAA;SACpC;IACH,CAAC;IAID,IACI,gBAAgB,CAAC,GAAkC;QACrD,IAAI,CAAC,iBAAiB,GAAG,GAAG,CAAA;QAC5B,MAAM,mBAAmB,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAA;QAC1D,IAAI,mBAAmB,EAAE;YACvB,IAAI,CAAC,UAAU,EAAE,CAAA;YACjB,mBAAmB,CAAC,MAAM,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;SACnE;IACH,CAAC;IA4BD,QAAQ;QACN,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAA;IACvG,CAAC;IAED,WAAW;QACT,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,sBAAsB,CAAC,CAAA;QAClE,IAAI,CAAC,4BAA4B,EAAE,CAAA;IACrC,CAAC;IAgBO,UAAU;QAChB,MAAM,mBAAmB,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAA;QAC1D,IAAI,mBAAmB,EAAE;YACvB,mBAAmB,CAAC,GAAG,GAAG,IAAI,CAAC,IAAI,IAAI,EAAE,CAAA;SAC1C;IACH,CAAC;IAEM,WAAW,CAAC,GAA8B;QAC/C,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAA;QAEnB,IAAI,IAAI,GAAG,GAAG,CAAA;QACd,MAAM,aAAa,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAA;QACpD,IAAI,aAAa,IAAI,IAAI,EAAE;YACzB,IAAI,IAAI,CAAC,YAAY,KAAK,CAAC,EAAE;gBAC3B,MAAM,OAAO,GAA8C,EAAE,IAAI,EAAE,mBAAmB,CAAC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,CAAA;gBACpH,IAAI;oBAAE,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;iBAAE;gBAAC,WAAM;oBAAE,OAAO,CAAC,OAAO,GAAG,IAAI,CAAA;iBAAE;gBAC3E,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAA;aAC/B;YAED,aAAa,CAAC,WAAW,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;SACrC;IACH,CAAC;IAEM,MAAM;QACX,IAAI,CAAC,UAAU,EAAE,CAAA;IACnB,CAAC;IAED,UAAU,CAAC,KAAwC;QACjD,2EAA2E;QAC3E,oBAAoB;QACpB,IAAI,CAAC,MAAM,EAAE,CAAA;IACf,CAAC;IAEO,uBAAuB;;QAC7B,OAAO,CAAC,MAAA,IAAI,CAAC,iBAAiB,0CAAE,aAAa,CAAC,IAAI,IAAI,CAAA;IACxD,CAAC;IAEO,uBAAuB;;QAC7B,OAAO,CAAC,MAAA,MAAA,IAAI,CAAC,iBAAiB,0CAAE,aAAa,0CAAE,aAAa,CAAC,IAAI,IAAI,CAAA;IACvE,CAAC;IAED;;;;;;OAMG;IACK,yBAAyB;QAC/B,IAAI,IAAI,CAAC,qBAAqB,KAAK,IAAI,EAAE;YACvC,OAAM;SACP;QAED,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAClC,MAAM,QAAQ,GAAG,IAAI,gBAAgB,CAAC,GAAG,EAAE;gBACzC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE;oBACpB,IAAI,IAAI,CAAC,wBAAwB,EAAE,EAAE;wBACnC,IAAI,CAAC,iBAAiB,EAAE,CAAA;qBACzB;yBAAM;wBACL,IAAI,CAAC,kBAAkB,EAAE,CAAA;qBAC1B;gBACH,CAAC,CAAC,CAAA;YACJ,CAAC,CAAC,CAAA;YAEF,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE;gBAC/C,UAAU,EAAE,IAAI;gBAChB,eAAe,EAAE,CAAE,OAAO,CAAE;gBAC5B,SAAS,EAAE,IAAI;gBACf,OAAO,EAAE,IAAI;gBACb,aAAa,EAAE,KAAK;aACrB,CAAC,CAAA;YAEF,IAAI,CAAC,qBAAqB,GAAG,QAAQ,CAAA;QACvC,CAAC,CAAC,CAAA;IACJ,CAAC;IAEO,4BAA4B;QAClC,IAAI,IAAI,CAAC,qBAAqB,KAAK,IAAI,EAAE;YACvC,OAAM;SACP;QAED,IAAI,CAAC,qBAAqB,CAAC,UAAU,EAAE,CAAA;QACvC,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAA;IACnC,CAAC;IAED;;;;;;;;;OASG;IACK,iBAAiB;QACvB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAA;QAE7B,MAAM,aAAa,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAA;QACpD,IAAI,aAAa,EAAE;YACjB,MAAM,IAAI,GAAG,aAAa,CAAC,qBAAqB,EAAE,CAAA;YAClD,IAAI,CAAC,gBAAgB,GAAG,GAAG,IAAI,CAAC,KAAK,IAAI,CAAA;YACzC,IAAI,CAAC,iBAAiB,GAAG,GAAG,IAAI,CAAC,MAAM,IAAI,CAAA;SAC5C;aAAM;YACL,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAA;YAC9B,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAA;SAChC;QAED,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAA;IAC3B,CAAC;IAEO,kBAAkB;QACxB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAA;QAC9B,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAA;IAC3B,CAAC;IAEO,wBAAwB;QAC9B,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,CAAC,6BAA6B,CAAC,KAAK,IAAI,CAAA;IAC7F,CAAC;;;YAlOF,SAAS,SAAC;gBACT,QAAQ,EAAE,2BAA2B;gBACrC,kfAAoD;;aAErD;;;YAvByD,MAAM;YAAvD,iBAAiB;YAAa,UAAU;;;kBAiC9C,KAAK;0BAQL,KAAK;mBAUL,KAAK;yBAKL,KAAK;+BAYL,SAAS,SAAC,eAAe,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;;AAX5C;IADU,YAAY,EAAE;oEAQvB","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
|
-
|
|
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) {
|