ngx-edu-sharing-ui 10.0.20 → 10.0.22

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 (131) hide show
  1. package/assets/scss/material-theme.scss +3 -3
  2. package/assets/scss/mixins.scss +1 -1
  3. package/assets/scss/variables-root.scss +2 -0
  4. package/assets/scss/variables-scss.scss +3 -4
  5. package/assets/scss/variables.scss +1 -1
  6. package/fesm2022/ngx-edu-sharing-ui.mjs +376 -319
  7. package/fesm2022/ngx-edu-sharing-ui.mjs.map +1 -1
  8. package/lib/index.d.ts +1 -0
  9. package/lib/list-items/list-widget.d.ts +1 -1
  10. package/lib/mds-viewer/mds-editor-instance-service.abstract.d.ts +14 -0
  11. package/lib/mds-viewer/widget/mds-widget.component.d.ts +6 -4
  12. package/package.json +8 -9
  13. package/esm2022/lib/actionbar/actionbar.component.mjs +0 -206
  14. package/esm2022/lib/common/edu-sharing-ui-common.module.mjs +0 -170
  15. package/esm2022/lib/directives/border-box-observer.directive.mjs +0 -71
  16. package/esm2022/lib/directives/check-text-overflow.directive.mjs +0 -71
  17. package/esm2022/lib/directives/drag-nodes/drag-nodes.mjs +0 -14
  18. package/esm2022/lib/directives/drag-nodes/nodes-drag-source.directive.mjs +0 -79
  19. package/esm2022/lib/directives/drag-nodes/nodes-drag.directive.mjs +0 -49
  20. package/esm2022/lib/directives/drag-nodes/nodes-drop-target.directive.mjs +0 -105
  21. package/esm2022/lib/directives/focus-state.directive.mjs +0 -44
  22. package/esm2022/lib/directives/icon.directive.mjs +0 -184
  23. package/esm2022/lib/directives/infinite-scroll.directive.mjs +0 -85
  24. package/esm2022/lib/dropdown/dropdown.component.mjs +0 -83
  25. package/esm2022/lib/edu-sharing-ui-configuration.mjs +0 -48
  26. package/esm2022/lib/edu-sharing-ui.module.mjs +0 -82
  27. package/esm2022/lib/index.mjs +0 -96
  28. package/esm2022/lib/list-items/available-widgets.mjs +0 -27
  29. package/esm2022/lib/list-items/format-duration.pipe.mjs +0 -20
  30. package/esm2022/lib/list-items/list-base/list-base.component.mjs +0 -46
  31. package/esm2022/lib/list-items/list-collection-info/list-collection-info.component.mjs +0 -29
  32. package/esm2022/lib/list-items/list-counts/list-counts.component.mjs +0 -56
  33. package/esm2022/lib/list-items/list-items.module.mjs +0 -50
  34. package/esm2022/lib/list-items/list-node-license/list-node-license.component.mjs +0 -41
  35. package/esm2022/lib/list-items/list-node-replication-source/list-node-replication-source.component.mjs +0 -47
  36. package/esm2022/lib/list-items/list-node-workflow/list-node-workflow.component.mjs +0 -24
  37. package/esm2022/lib/list-items/list-text/list-text.component.mjs +0 -106
  38. package/esm2022/lib/list-items/list-widget.mjs +0 -49
  39. package/esm2022/lib/list-items/node-row/node-row.component.mjs +0 -24
  40. package/esm2022/lib/list-items/node-source.pipe.mjs +0 -49
  41. package/esm2022/lib/mds/mds-helper.service.mjs +0 -167
  42. package/esm2022/lib/mds/mds.module.mjs +0 -16
  43. package/esm2022/lib/mds-viewer/mds-viewer.component.mjs +0 -170
  44. package/esm2022/lib/mds-viewer/mds-viewer.service.mjs +0 -18
  45. package/esm2022/lib/mds-viewer/replace-element-with-div.mjs +0 -47
  46. package/esm2022/lib/mds-viewer/view-instance.service.mjs +0 -27
  47. package/esm2022/lib/mds-viewer/widget/mds-widget.component.mjs +0 -379
  48. package/esm2022/lib/node-entries/combined-data-source.mjs +0 -41
  49. package/esm2022/lib/node-entries/custom-templates-data-source.mjs +0 -7
  50. package/esm2022/lib/node-entries/drag-preview/drag-preview.component.mjs +0 -21
  51. package/esm2022/lib/node-entries/entries-model.mjs +0 -24
  52. package/esm2022/lib/node-entries/items-cap.mjs +0 -47
  53. package/esm2022/lib/node-entries/list-item-label.pipe.mjs +0 -37
  54. package/esm2022/lib/node-entries/node-cache.mjs +0 -73
  55. package/esm2022/lib/node-entries/node-data-source-remote.mjs +0 -4
  56. package/esm2022/lib/node-entries/node-data-source.mjs +0 -117
  57. package/esm2022/lib/node-entries/node-entries-card/node-entries-card.component.mjs +0 -117
  58. package/esm2022/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.mjs +0 -329
  59. package/esm2022/lib/node-entries/node-entries-card-small/node-entries-card-small.component.mjs +0 -44
  60. package/esm2022/lib/node-entries/node-entries-global-options/node-entries-global-options.component.mjs +0 -27
  61. package/esm2022/lib/node-entries/node-entries-global.service.mjs +0 -71
  62. package/esm2022/lib/node-entries/node-entries-table/column-chooser/column-chooser.component.mjs +0 -42
  63. package/esm2022/lib/node-entries/node-entries-table/node-entries-table.component.mjs +0 -294
  64. package/esm2022/lib/node-entries/node-entries-templates.service.mjs +0 -11
  65. package/esm2022/lib/node-entries/node-entries-wrapper.component.mjs +0 -369
  66. package/esm2022/lib/node-entries/node-entries.component.mjs +0 -132
  67. package/esm2022/lib/node-entries/node-entries.module.mjs +0 -161
  68. package/esm2022/lib/node-entries/node-rating/node-rating.component.mjs +0 -125
  69. package/esm2022/lib/node-entries/node-stats-badges/node-stats-badges.component.mjs +0 -48
  70. package/esm2022/lib/node-entries/node-type-badge/node-type-badge.component.mjs +0 -36
  71. package/esm2022/lib/node-entries/option-button/option-button.component.mjs +0 -75
  72. package/esm2022/lib/node-entries/preview-image/preview-image.component.mjs +0 -53
  73. package/esm2022/lib/node-entries/sort-select-panel/sort-select-panel.component.mjs +0 -41
  74. package/esm2022/lib/node-url/node-url.component.mjs +0 -132
  75. package/esm2022/lib/pipes/file-size.pipe.mjs +0 -32
  76. package/esm2022/lib/pipes/format-date.pipe.mjs +0 -38
  77. package/esm2022/lib/pipes/mds-duration.pipe.mjs +0 -25
  78. package/esm2022/lib/pipes/node-icon.pipe.mjs +0 -18
  79. package/esm2022/lib/pipes/node-image-size.pipe.mjs +0 -24
  80. package/esm2022/lib/pipes/node-image.pipe.mjs +0 -55
  81. package/esm2022/lib/pipes/node-license.pipe.mjs +0 -24
  82. package/esm2022/lib/pipes/node-person-name.pipe.mjs +0 -50
  83. package/esm2022/lib/pipes/node-title.pipe.mjs +0 -35
  84. package/esm2022/lib/pipes/option-tooltip.pipe.mjs +0 -33
  85. package/esm2022/lib/pipes/property-slug.pipe.mjs +0 -16
  86. package/esm2022/lib/pipes/replace-chars.pipe.mjs +0 -29
  87. package/esm2022/lib/pipes/vcard-name.pipe.mjs +0 -25
  88. package/esm2022/lib/services/abstract/app.service.mjs +0 -3
  89. package/esm2022/lib/services/abstract/keyboard-shortcuts.service.mjs +0 -10
  90. package/esm2022/lib/services/abstract/options-helper.service.mjs +0 -3
  91. package/esm2022/lib/services/abstract/toast.service.mjs +0 -3
  92. package/esm2022/lib/services/accessibility.service.mjs +0 -73
  93. package/esm2022/lib/services/app-container.service.mjs +0 -69
  94. package/esm2022/lib/services/local-events.service.mjs +0 -43
  95. package/esm2022/lib/services/node-entries.service.mjs +0 -201
  96. package/esm2022/lib/services/node-helper.service.mjs +0 -330
  97. package/esm2022/lib/services/nodes-drag-drop.service.mjs +0 -155
  98. package/esm2022/lib/services/options-helper-data.service.mjs +0 -142
  99. package/esm2022/lib/services/render-helper.service.mjs +0 -114
  100. package/esm2022/lib/services/repo-url.service.mjs +0 -50
  101. package/esm2022/lib/services/search-helper.service.mjs +0 -52
  102. package/esm2022/lib/services/temporary-storage.service.mjs +0 -48
  103. package/esm2022/lib/services/ui.service.mjs +0 -327
  104. package/esm2022/lib/sort-dropdown/sort-dropdown.component.mjs +0 -50
  105. package/esm2022/lib/spinner/spinner.component.mjs +0 -19
  106. package/esm2022/lib/spinner-small/spinner-small.component.mjs +0 -18
  107. package/esm2022/lib/translations/fallback-translation-handler.mjs +0 -6
  108. package/esm2022/lib/translations/translation-loader.mjs +0 -219
  109. package/esm2022/lib/translations/translation-source.mjs +0 -11
  110. package/esm2022/lib/translations/translations.module.mjs +0 -82
  111. package/esm2022/lib/translations/translations.service.mjs +0 -238
  112. package/esm2022/lib/types/accessibillity.mjs +0 -19
  113. package/esm2022/lib/types/api-models.mjs +0 -2
  114. package/esm2022/lib/types/drag-drop.mjs +0 -2
  115. package/esm2022/lib/types/injection-tokens.mjs +0 -31
  116. package/esm2022/lib/types/keyboard-shortcuts.mjs +0 -11
  117. package/esm2022/lib/types/list-item.mjs +0 -41
  118. package/esm2022/lib/types/option-item.mjs +0 -192
  119. package/esm2022/lib/types/workflow.mjs +0 -25
  120. package/esm2022/lib/util/DateHelper.mjs +0 -200
  121. package/esm2022/lib/util/VCard.mjs +0 -278
  122. package/esm2022/lib/util/color-helper.mjs +0 -124
  123. package/esm2022/lib/util/duration-helper.mjs +0 -102
  124. package/esm2022/lib/util/functions.mjs +0 -13
  125. package/esm2022/lib/util/helper.mjs +0 -64
  126. package/esm2022/lib/util/isNumeric.mjs +0 -11
  127. package/esm2022/lib/util/rest-helper.mjs +0 -42
  128. package/esm2022/lib/util/ui-animation.mjs +0 -146
  129. package/esm2022/lib/util/ui-constants.mjs +0 -21
  130. package/esm2022/ngx-edu-sharing-ui.mjs +0 -5
  131. package/esm2022/public-api.mjs +0 -2
@@ -1,48 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- /**
4
- * Service to store any data temporary (lost after reloading page).
5
- *
6
- * Note that all components share the same data source. So uses prefixes for your name if
7
- * applicable!
8
- */
9
- export class TemporaryStorageService {
10
- static { this.APPLY_TO_LMS_PARAMETER_NODE = 'apply_to_lms_node'; }
11
- // @Deprecated Use NODE_RENDER_PARAMETER_DATA_SOURCE instead
12
- static { this.NODE_RENDER_PARAMETER_LIST = 'node_render_list'; }
13
- static { this.NODE_RENDER_PARAMETER_DATA_SOURCE = 'node_render_data_source'; }
14
- static { this.COLLECTION_ADD_NODES = 'collection_add_nodes'; }
15
- static { this.WORKSPACE_LAST_LOCATION = 'WORKSPACE_LAST_LOCATION'; }
16
- static { this.CUSTOM_NODE_LIST_COMPONENT = 'custom_node_list_component'; }
17
- static { this.CUSTOM_NODE_ENTRIES_COMPONENT = 'custom_node_entries_component'; }
18
- constructor() {
19
- this.data = {};
20
- }
21
- get(name, defaultValue = null) {
22
- if (this.data[name] != null) {
23
- return this.data[name];
24
- }
25
- return defaultValue;
26
- }
27
- set(name, value) {
28
- this.data[name] = value;
29
- }
30
- /**
31
- * Same as get, but will remove the value after fetching it.
32
- */
33
- pop(name, defaultValue = null) {
34
- const value = this.get(name, defaultValue);
35
- this.remove(name);
36
- return value;
37
- }
38
- remove(name) {
39
- this.data[name] = null;
40
- }
41
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: TemporaryStorageService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
42
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: TemporaryStorageService, providedIn: 'root' }); }
43
- }
44
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: TemporaryStorageService, decorators: [{
45
- type: Injectable,
46
- args: [{ providedIn: 'root' }]
47
- }], ctorParameters: () => [] });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcG9yYXJ5LXN0b3JhZ2Uuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvc2VydmljZXMvdGVtcG9yYXJ5LXN0b3JhZ2Uuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUczQzs7Ozs7R0FLRztBQUVILE1BQU0sT0FBTyx1QkFBdUI7YUFDekIsZ0NBQTJCLEdBQUcsbUJBQW1CLEFBQXRCLENBQXVCO0lBQ3pELDREQUE0RDthQUNyRCwrQkFBMEIsR0FBRyxrQkFBa0IsQUFBckIsQ0FBc0I7YUFDaEQsc0NBQWlDLEdBQUcseUJBQXlCLEFBQTVCLENBQTZCO2FBQzlELHlCQUFvQixHQUFHLHNCQUFzQixBQUF6QixDQUEwQjthQUM5Qyw0QkFBdUIsR0FBRyx5QkFBeUIsQUFBNUIsQ0FBNkI7YUFLcEQsK0JBQTBCLEdBQUcsNEJBQTRCLEFBQS9CLENBQWdDO2FBQzFELGtDQUE2QixHQUFHLCtCQUErQixBQUFsQyxDQUFtQztJQUl2RTtRQUZRLFNBQUksR0FBUSxFQUFFLENBQUM7SUFFUixDQUFDO0lBRWhCLEdBQUcsQ0FBQyxJQUFZLEVBQUUsZUFBb0IsSUFBSTtRQUN0QyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksSUFBSSxFQUFFLENBQUM7WUFDMUIsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzNCLENBQUM7UUFDRCxPQUFPLFlBQVksQ0FBQztJQUN4QixDQUFDO0lBRUQsR0FBRyxDQUFDLElBQVksRUFBRSxLQUFVO1FBQ3hCLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBSyxDQUFDO0lBQzVCLENBQUM7SUFFRDs7T0FFRztJQUNILEdBQUcsQ0FBQyxJQUFZLEVBQUUsZUFBb0IsSUFBSTtRQUN0QyxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxZQUFZLENBQUMsQ0FBQztRQUMzQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2xCLE9BQU8sS0FBSyxDQUFDO0lBQ2pCLENBQUM7SUFFRCxNQUFNLENBQUMsSUFBWTtRQUNmLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFDO0lBQzNCLENBQUM7K0dBeENRLHVCQUF1QjttSEFBdkIsdUJBQXVCLGNBRFYsTUFBTTs7NEZBQ25CLHVCQUF1QjtrQkFEbkMsVUFBVTttQkFBQyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOb2RlIH0gZnJvbSAnbmd4LWVkdS1zaGFyaW5nLWFwaSc7XG5cbi8qKlxuICogU2VydmljZSB0byBzdG9yZSBhbnkgZGF0YSB0ZW1wb3JhcnkgKGxvc3QgYWZ0ZXIgcmVsb2FkaW5nIHBhZ2UpLlxuICpcbiAqIE5vdGUgdGhhdCBhbGwgY29tcG9uZW50cyBzaGFyZSB0aGUgc2FtZSBkYXRhIHNvdXJjZS4gU28gdXNlcyBwcmVmaXhlcyBmb3IgeW91ciBuYW1lIGlmXG4gKiBhcHBsaWNhYmxlIVxuICovXG5ASW5qZWN0YWJsZSh7IHByb3ZpZGVkSW46ICdyb290JyB9KVxuZXhwb3J0IGNsYXNzIFRlbXBvcmFyeVN0b3JhZ2VTZXJ2aWNlIHtcbiAgICBzdGF0aWMgQVBQTFlfVE9fTE1TX1BBUkFNRVRFUl9OT0RFID0gJ2FwcGx5X3RvX2xtc19ub2RlJztcbiAgICAvLyBARGVwcmVjYXRlZCBVc2UgTk9ERV9SRU5ERVJfUEFSQU1FVEVSX0RBVEFfU09VUkNFIGluc3RlYWRcbiAgICBzdGF0aWMgTk9ERV9SRU5ERVJfUEFSQU1FVEVSX0xJU1QgPSAnbm9kZV9yZW5kZXJfbGlzdCc7XG4gICAgc3RhdGljIE5PREVfUkVOREVSX1BBUkFNRVRFUl9EQVRBX1NPVVJDRSA9ICdub2RlX3JlbmRlcl9kYXRhX3NvdXJjZSc7XG4gICAgc3RhdGljIENPTExFQ1RJT05fQUREX05PREVTID0gJ2NvbGxlY3Rpb25fYWRkX25vZGVzJztcbiAgICBzdGF0aWMgV09SS1NQQUNFX0xBU1RfTE9DQVRJT04gPSAnV09SS1NQQUNFX0xBU1RfTE9DQVRJT04nO1xuICAgIC8vIGRlZmF1bHQ6IGZhbHNlXG4gICAgc3RhdGljIE9QVElPTl9ISURFX01BSU5OQVY6ICdvcHRpb25faGlkZV9tYWlubmF2JztcbiAgICAvLyBkZWZhdWx0OiBmYWxzZVxuICAgIHN0YXRpYyBPUFRJT05fRElTQUJMRV9TQ1JPTExfTEFZT1VUOiAnb3B0aW9uX2Rpc2FibGVfc2Nyb2xsX2xheW91dCc7XG4gICAgc3RhdGljIENVU1RPTV9OT0RFX0xJU1RfQ09NUE9ORU5UID0gJ2N1c3RvbV9ub2RlX2xpc3RfY29tcG9uZW50JztcbiAgICBzdGF0aWMgQ1VTVE9NX05PREVfRU5UUklFU19DT01QT05FTlQgPSAnY3VzdG9tX25vZGVfZW50cmllc19jb21wb25lbnQnO1xuXG4gICAgcHJpdmF0ZSBkYXRhOiBhbnkgPSB7fTtcblxuICAgIGNvbnN0cnVjdG9yKCkge31cblxuICAgIGdldChuYW1lOiBzdHJpbmcsIGRlZmF1bHRWYWx1ZTogYW55ID0gbnVsbCkge1xuICAgICAgICBpZiAodGhpcy5kYXRhW25hbWVdICE9IG51bGwpIHtcbiAgICAgICAgICAgIHJldHVybiB0aGlzLmRhdGFbbmFtZV07XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGRlZmF1bHRWYWx1ZTtcbiAgICB9XG5cbiAgICBzZXQobmFtZTogc3RyaW5nLCB2YWx1ZTogYW55KSB7XG4gICAgICAgIHRoaXMuZGF0YVtuYW1lXSA9IHZhbHVlO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFNhbWUgYXMgZ2V0LCBidXQgd2lsbCByZW1vdmUgdGhlIHZhbHVlIGFmdGVyIGZldGNoaW5nIGl0LlxuICAgICAqL1xuICAgIHBvcChuYW1lOiBzdHJpbmcsIGRlZmF1bHRWYWx1ZTogYW55ID0gbnVsbCk6IGFueSB7XG4gICAgICAgIGNvbnN0IHZhbHVlID0gdGhpcy5nZXQobmFtZSwgZGVmYXVsdFZhbHVlKTtcbiAgICAgICAgdGhpcy5yZW1vdmUobmFtZSk7XG4gICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9XG5cbiAgICByZW1vdmUobmFtZTogc3RyaW5nKSB7XG4gICAgICAgIHRoaXMuZGF0YVtuYW1lXSA9IG51bGw7XG4gICAgfVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIENsaXBib2FyZE9iamVjdCB7XG4gICAgbm9kZXM6IE5vZGVbXTtcbiAgICBzb3VyY2VOb2RlOiBOb2RlO1xuICAgIGNvcHk6IGJvb2xlYW47XG59XG4iXX0=
@@ -1,327 +0,0 @@
1
- import { Injectable, } from '@angular/core';
2
- import * as rxjs from 'rxjs';
3
- import { BehaviorSubject } from 'rxjs';
4
- import { UIConstants } from '../util/ui-constants';
5
- import { distinctUntilChanged, map } from 'rxjs/operators';
6
- import * as i0 from "@angular/core";
7
- export class UIService {
8
- get shiftKeyPressed() {
9
- return this.shiftKeyPressedSubject.value;
10
- }
11
- constructor(componentFactoryResolver, injector, ngZone) {
12
- this.componentFactoryResolver = componentFactoryResolver;
13
- this.injector = injector;
14
- this.ngZone = ngZone;
15
- this.isTouchSubject = new BehaviorSubject(false);
16
- this.metaKeyPressedSubject = new BehaviorSubject(false);
17
- this.shiftKeyPressedSubject = new BehaviorSubject(false);
18
- this.ctrlKeyPressedSubject = new BehaviorSubject(false);
19
- // HostListener not working, so use window
20
- this.ngZone.runOutsideAngular(() => {
21
- window.addEventListener('keydown', (event) => {
22
- this.onKeyDownOrKeyUp(event);
23
- });
24
- window.addEventListener('keyup', (event) => {
25
- this.onKeyDownOrKeyUp(event);
26
- });
27
- window.addEventListener('pointerdown', (event) => {
28
- // Usually, properties for modifier keys will be set correctly on keydown and keyup
29
- // events, but there are situations where the operating system intercepts key
30
- // presses, e.g. the Windows key on Linux systems, so we update again on mouse
31
- // clicks to be sure.
32
- this.updateModifierKeys(event);
33
- });
34
- window.addEventListener('pointerdown', (event) => {
35
- // Usually, properties for modifier keys will be set correctly on keydown and keyup
36
- // events, but there are situations where the operating system intercepts key
37
- // presses, e.g. the Windows key on Linux systems, so we update again on mouse
38
- // clicks to be sure.
39
- const isTouch = event.pointerType === 'touch';
40
- if (this.isTouchSubject.value !== isTouch) {
41
- this.ngZone.run(() => this.isTouchSubject.next(isTouch));
42
- }
43
- });
44
- });
45
- }
46
- onKeyDownOrKeyUp(event) {
47
- // `event.metaKey` is not consistent across browsers on the actual keypress of the modifier
48
- // key. So we handle these events separately.
49
- if (event.key === 'Control') {
50
- this.ctrlKeyPressedSubject.next(event.type === 'keydown');
51
- }
52
- else if (event.key === 'Shift') {
53
- this.shiftKeyPressedSubject.next(event.type === 'keydown');
54
- }
55
- else if (event.key === 'Meta') {
56
- this.metaKeyPressedSubject.next(event.type === 'keydown');
57
- }
58
- else {
59
- // In case we miss modifier events because the browser didn't have focus during the
60
- // event, we update modifier keys on unrelated key events as well.
61
- this.updateModifierKeys(event);
62
- }
63
- }
64
- updateModifierKeys(event) {
65
- this.metaKeyPressedSubject.next(event.metaKey);
66
- this.shiftKeyPressedSubject.next(event.shiftKey);
67
- this.ctrlKeyPressedSubject.next(event.ctrlKey);
68
- }
69
- observeCtrlOrCmdKeyPressedOutsideZone() {
70
- return rxjs.combineLatest([this.metaKeyPressedSubject, this.ctrlKeyPressedSubject]).pipe(map(([metaKeyPressed, ctrlKeyPressed]) => metaKeyPressed || ctrlKeyPressed), distinctUntilChanged());
71
- }
72
- /**
73
- * @Deprecated
74
- * Prefer to subscribe to the isTouchSubject directly if viable
75
- *
76
- * Returns true if the current sessions seems to be running on a mobile device
77
- */
78
- isMobile() {
79
- return this.isTouchSubject.value;
80
- }
81
- static evaluateMediaQuery(type, value) {
82
- if (type == UIConstants.MEDIA_QUERY_MAX_WIDTH)
83
- return value > window.innerWidth;
84
- if (type == UIConstants.MEDIA_QUERY_MIN_WIDTH)
85
- return value < window.innerWidth;
86
- if (type == UIConstants.MEDIA_QUERY_MAX_HEIGHT)
87
- return value > window.innerHeight;
88
- if (type == UIConstants.MEDIA_QUERY_MIN_HEIGHT)
89
- return value < window.innerHeight;
90
- console.warn('Unsupported media query ' + type);
91
- return true;
92
- }
93
- filterValidOptions(options) {
94
- if (options == null)
95
- return null;
96
- options = options.filter((value) => value != null);
97
- let optionsFiltered = [];
98
- for (let option of options) {
99
- if ((!option.onlyMobile || (option.onlyMobile && this.isMobile())) &&
100
- (!option.onlyDesktop || (option.onlyDesktop && !this.isMobile())) &&
101
- (!option.mediaQueryType ||
102
- (option.mediaQueryType &&
103
- UIService.evaluateMediaQuery(option.mediaQueryType, option.mediaQueryValue))))
104
- optionsFiltered.push(option);
105
- }
106
- return optionsFiltered;
107
- }
108
- /**
109
- * helper that updates the "isEnabled" flag on all options for the given, selected node
110
- * can be used by dropdown or action menus to update the state for the current element
111
- * @param options
112
- */
113
- async updateOptionEnabledState(options, objects = null) {
114
- options.value?.forEach((o) => {
115
- o.isEnabled = !o.customEnabledCallback;
116
- void o.enabledCallback(objects).then((result) => {
117
- o.isEnabled = result;
118
- options.next(options.value);
119
- });
120
- });
121
- options.next(options.value);
122
- }
123
- filterToggleOptions(options, toggle, togglePosition = 'after') {
124
- let result = [];
125
- for (let option of options) {
126
- if (option.isToggle === toggle && (!toggle || togglePosition === option.togglePosition))
127
- result.push(option);
128
- }
129
- return result;
130
- }
131
- /**
132
- * dynamically inject an angular component into a regular html dom element
133
- * @param componentFactoryResolver The resolver service
134
- * @param viewContainerRef The viewContainerRef service
135
- * @param componentName The name of the angular component (e.g. SpinnerComponent)
136
- * @param targetElement The target element of the dom. If the element is null (not found), nothing is done
137
- * @param bindings Optional bindings (inputs & outputs) to the given component
138
- * @param delay Optional inflating delay in ms(some components may need some time to "init" the layout)
139
- * @param replace Whether to replace to previous `innerHTML` of `targetElement`
140
- * @param injector (to fetch templates for the component)
141
- */
142
- injectAngularComponent(viewContainerRef, componentName, targetElement, bindings = null, { delay = 0, replace = true } = {}, injector) {
143
- if (targetElement == null) {
144
- return null;
145
- }
146
- const factory = this.componentFactoryResolver.resolveComponentFactory(componentName);
147
- const component = viewContainerRef.createComponent(factory, undefined, injector || this.injector);
148
- if (bindings) {
149
- const instance = component.instance;
150
- for (const key in bindings) {
151
- const binding = bindings[key];
152
- if (binding instanceof Function) {
153
- // subscribe so callback can properly invoked
154
- instance[key].subscribe((value) => binding(value));
155
- }
156
- else {
157
- instance[key] = binding;
158
- // `ngOnChanges` won't be called on the component like this. Consider doing
159
- // something like this:
160
- // https://scm.edu-sharing.com/edu-sharing/projects/oeh-redaktion/ng-meta-widgets/-/blob/1603fb2dedadd3952401385bcbd91a4bd8407643/src/app/app.module.ts#L66-79
161
- }
162
- }
163
- }
164
- // 3. Get DOM element from component
165
- const domElem = component.hostView.rootNodes[0];
166
- domElem.style.display = 'none';
167
- if (replace) {
168
- targetElement.innerHTML = null;
169
- }
170
- targetElement.appendChild(domElem);
171
- setTimeout(() => {
172
- domElem.style.display = null;
173
- }, delay);
174
- return component;
175
- }
176
- /**
177
- * dynamically inject an angular component into a regular html dom element
178
- * @param componentFactoryResolver The resolver service
179
- * @param viewContainerRef The viewContainerRef service
180
- * @param componentName The name of the angular component (e.g. SpinnerComponent)
181
- * @param targetElement The target element of the dom. If the element is null (not found), nothing is done
182
- * @param bindings Optional bindings (inputs & outputs) to the given component
183
- * @param delay Optional inflating delay in ms(some components may need some time to "init" the layout)
184
- * @param replace Whether to replace to previous `innerHTML` of `targetElement`
185
- * @param injector (to fetch templates for the component)
186
- */
187
- static injectAngularComponent(componentFactoryResolver, viewContainerRef, componentName, targetElement, bindings = null, { delay = 0, replace = true } = {}, injector) {
188
- if (targetElement == null) {
189
- return null;
190
- }
191
- const factory = componentFactoryResolver.resolveComponentFactory(componentName);
192
- const component = viewContainerRef.createComponent(factory, undefined, injector);
193
- if (bindings) {
194
- const instance = component.instance;
195
- for (const key in bindings) {
196
- const binding = bindings[key];
197
- if (binding instanceof Function) {
198
- // subscribe so callback can properly invoked
199
- instance[key].subscribe((value) => binding(value));
200
- }
201
- else {
202
- instance[key] = binding;
203
- // `ngOnChanges` won't be called on the component like this. Consider doing
204
- // something like this:
205
- // https://scm.edu-sharing.com/edu-sharing/projects/oeh-redaktion/ng-meta-widgets/-/blob/1603fb2dedadd3952401385bcbd91a4bd8407643/src/app/app.module.ts#L66-79
206
- }
207
- }
208
- }
209
- // 3. Get DOM element from component
210
- const domElem = component.hostView.rootNodes[0];
211
- domElem.style.display = 'none';
212
- if (replace) {
213
- targetElement.innerHTML = null;
214
- }
215
- targetElement.appendChild(domElem);
216
- setTimeout(() => {
217
- domElem.style.display = null;
218
- }, delay);
219
- return component;
220
- }
221
- /**
222
- * smoothly scroll to the given child inside an element (The child will be placed around the first 1/3 of the parent's top)
223
- * @param child
224
- * @param element
225
- * @param smoothness
226
- */
227
- scrollSmoothElementToChild(child, element = 'auto', smoothness = 1) {
228
- let target;
229
- if (element === 'auto') {
230
- let parent = child.parentElement;
231
- while (parent) {
232
- if (['scroll', 'auto'].includes(window.getComputedStyle(parent).overflowY)) {
233
- target = parent;
234
- break;
235
- }
236
- parent = parent.parentElement;
237
- }
238
- }
239
- else {
240
- target = element;
241
- }
242
- // y equals to the top of the child + any scrolling of the parent - the top of the parent
243
- let y = child.getBoundingClientRect().top +
244
- target.scrollTop -
245
- target.getBoundingClientRect().top;
246
- // move the focused element to 1/3 at the top of the container
247
- y += child.getBoundingClientRect().height / 2 - target.getBoundingClientRect().height / 3;
248
- return this.scrollSmoothElement(y, target, smoothness);
249
- }
250
- /**
251
- * Smoothly scrolls to the given y offset inside an element (use offsetTop on the child to
252
- * determine this position).
253
- *
254
- * @param smoothness lower numbers indicate less smoothness, higher more smoothness
255
- */
256
- scrollSmoothElement(pos = 0, element, smoothness = 1, axis = 'y') {
257
- return new Promise((resolve) => {
258
- this.ngZone.runOutsideAngular(() => {
259
- const currentPos = axis == 'x' ? element.scrollLeft : element.scrollTop;
260
- if (element.getAttribute('data-is-scrolling') == 'true') {
261
- return;
262
- }
263
- const mode = currentPos > pos;
264
- let lastPos = pos;
265
- const maxPos = axis == 'x'
266
- ? element.scrollWidth - element.clientWidth
267
- : element.scrollHeight - element.clientHeight;
268
- let limitReached = false;
269
- if (mode && pos <= 0) {
270
- pos = 0;
271
- limitReached = true;
272
- }
273
- if (!mode && pos >= maxPos) {
274
- pos = maxPos;
275
- limitReached = true;
276
- }
277
- let speed = 16;
278
- let last = new Date().getTime();
279
- const callback = () => {
280
- let currentPos = axis == 'x' ? element.scrollLeft : element.scrollTop;
281
- const posDiff = currentPos - lastPos;
282
- const speedFactor = speed / 16;
283
- const divider = (3 / speedFactor) * smoothness;
284
- const minSpeed = (5 * speedFactor) / smoothness;
285
- const maxSpeed = (50 * speedFactor) / smoothness;
286
- lastPos = currentPos;
287
- let finished = true;
288
- if (currentPos > pos) {
289
- currentPos -= Math.min(maxSpeed, Math.max((currentPos - pos) / divider, minSpeed));
290
- finished = currentPos <= pos;
291
- }
292
- else if (currentPos < pos && !mode) {
293
- currentPos += Math.min(maxSpeed, Math.max((pos - currentPos) / divider, minSpeed));
294
- finished = currentPos >= pos;
295
- }
296
- if (finished) {
297
- currentPos = pos;
298
- }
299
- if (axis == 'x') {
300
- element.scrollLeft = currentPos;
301
- }
302
- else {
303
- element.scrollTop = currentPos;
304
- }
305
- if (finished) {
306
- element.removeAttribute('data-is-scrolling');
307
- resolve();
308
- }
309
- else {
310
- speed = new Date().getTime() - last;
311
- last = new Date().getTime();
312
- window.requestAnimationFrame(callback);
313
- }
314
- };
315
- window.requestAnimationFrame(callback);
316
- element.setAttribute('data-is-scrolling', 'true');
317
- });
318
- });
319
- }
320
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: UIService, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.Injector }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Injectable }); }
321
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: UIService, providedIn: 'root' }); }
322
- }
323
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: UIService, decorators: [{
324
- type: Injectable,
325
- args: [{ providedIn: 'root' }]
326
- }], ctorParameters: () => [{ type: i0.ComponentFactoryResolver }, { type: i0.Injector }, { type: i0.NgZone }] });
327
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui.service.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/services/ui.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ComponentFactoryResolver,\n    ComponentRef,\n    EmbeddedViewRef,\n    Injectable,\n    Injector,\n    NgZone,\n    Type,\n    ViewContainerRef,\n} from '@angular/core';\nimport * as rxjs from 'rxjs';\nimport { BehaviorSubject, Observable } from 'rxjs';\nimport { UIConstants } from '../util/ui-constants';\nimport { OptionItem } from '../types/option-item';\nimport { distinctUntilChanged, map } from 'rxjs/operators';\nimport { Node } from 'ngx-edu-sharing-api';\n\n@Injectable({ providedIn: 'root' })\nexport class UIService {\n    isTouchSubject = new BehaviorSubject(false);\n    private metaKeyPressedSubject = new BehaviorSubject(false);\n    private shiftKeyPressedSubject = new BehaviorSubject(false);\n    private ctrlKeyPressedSubject = new BehaviorSubject(false);\n\n    get shiftKeyPressed() {\n        return this.shiftKeyPressedSubject.value;\n    }\n\n    constructor(\n        protected componentFactoryResolver: ComponentFactoryResolver,\n        protected injector: Injector,\n        protected ngZone: NgZone,\n    ) {\n        // HostListener not working, so use window\n        this.ngZone.runOutsideAngular(() => {\n            window.addEventListener('keydown', (event) => {\n                this.onKeyDownOrKeyUp(event);\n            });\n            window.addEventListener('keyup', (event) => {\n                this.onKeyDownOrKeyUp(event);\n            });\n            window.addEventListener('pointerdown', (event) => {\n                // Usually, properties for modifier keys will be set correctly on keydown and keyup\n                // events, but there are situations where the operating system intercepts key\n                // presses, e.g. the Windows key on Linux systems, so we update again on mouse\n                // clicks to be sure.\n                this.updateModifierKeys(event);\n            });\n            window.addEventListener('pointerdown', (event) => {\n                // Usually, properties for modifier keys will be set correctly on keydown and keyup\n                // events, but there are situations where the operating system intercepts key\n                // presses, e.g. the Windows key on Linux systems, so we update again on mouse\n                // clicks to be sure.\n                const isTouch = (event as PointerEvent).pointerType === 'touch';\n                if (this.isTouchSubject.value !== isTouch) {\n                    this.ngZone.run(() => this.isTouchSubject.next(isTouch));\n                }\n            });\n        });\n    }\n    private onKeyDownOrKeyUp(event: KeyboardEvent) {\n        // `event.metaKey` is not consistent across browsers on the actual keypress of the modifier\n        // key. So we handle these events separately.\n        if (event.key === 'Control') {\n            this.ctrlKeyPressedSubject.next(event.type === 'keydown');\n        } else if (event.key === 'Shift') {\n            this.shiftKeyPressedSubject.next(event.type === 'keydown');\n        } else if (event.key === 'Meta') {\n            this.metaKeyPressedSubject.next(event.type === 'keydown');\n        } else {\n            // In case we miss modifier events because the browser didn't have focus during the\n            // event, we update modifier keys on unrelated key events as well.\n            this.updateModifierKeys(event);\n        }\n    }\n\n    private updateModifierKeys(event: PointerEvent | KeyboardEvent) {\n        this.metaKeyPressedSubject.next(event.metaKey);\n        this.shiftKeyPressedSubject.next(event.shiftKey);\n        this.ctrlKeyPressedSubject.next(event.ctrlKey);\n    }\n\n    observeCtrlOrCmdKeyPressedOutsideZone(): Observable<boolean> {\n        return rxjs.combineLatest([this.metaKeyPressedSubject, this.ctrlKeyPressedSubject]).pipe(\n            map(([metaKeyPressed, ctrlKeyPressed]) => metaKeyPressed || ctrlKeyPressed),\n            distinctUntilChanged(),\n        );\n    }\n\n    /**\n     * @Deprecated\n     * Prefer to subscribe to the isTouchSubject directly if viable\n     *\n     * Returns true if the current sessions seems to be running on a mobile device\n     */\n    public isMobile() {\n        return this.isTouchSubject.value;\n    }\n    public static evaluateMediaQuery(type: string, value: number) {\n        if (type == UIConstants.MEDIA_QUERY_MAX_WIDTH) return value > window.innerWidth;\n        if (type == UIConstants.MEDIA_QUERY_MIN_WIDTH) return value < window.innerWidth;\n        if (type == UIConstants.MEDIA_QUERY_MAX_HEIGHT) return value > window.innerHeight;\n        if (type == UIConstants.MEDIA_QUERY_MIN_HEIGHT) return value < window.innerHeight;\n        console.warn('Unsupported media query ' + type);\n        return true;\n    }\n    filterValidOptions(options: OptionItem[]) {\n        if (options == null) return null;\n        options = options.filter((value) => value != null);\n        let optionsFiltered: OptionItem[] = [];\n        for (let option of options) {\n            if (\n                (!option.onlyMobile || (option.onlyMobile && this.isMobile())) &&\n                (!option.onlyDesktop || (option.onlyDesktop && !this.isMobile())) &&\n                (!option.mediaQueryType ||\n                    (option.mediaQueryType &&\n                        UIService.evaluateMediaQuery(\n                            option.mediaQueryType,\n                            option.mediaQueryValue,\n                        )))\n            )\n                optionsFiltered.push(option);\n        }\n        return optionsFiltered;\n    }\n\n    /**\n     * helper that updates the \"isEnabled\" flag on all options for the given, selected node\n     * can be used by dropdown or action menus to update the state for the current element\n     * @param options\n     */\n    async updateOptionEnabledState(options: BehaviorSubject<OptionItem[]>, objects: Node[] = null) {\n        options.value?.forEach((o) => {\n            o.isEnabled = !o.customEnabledCallback;\n            void o.enabledCallback(objects).then((result) => {\n                o.isEnabled = result;\n                options.next(options.value);\n            });\n        });\n        options.next(options.value);\n    }\n\n    public filterToggleOptions(\n        options: OptionItem[],\n        toggle: boolean,\n        togglePosition: 'before' | 'after' = 'after',\n    ) {\n        let result: OptionItem[] = [];\n        for (let option of options) {\n            if (option.isToggle === toggle && (!toggle || togglePosition === option.togglePosition))\n                result.push(option);\n        }\n        return result;\n    }\n    /**\n     * dynamically inject an angular component into a regular html dom element\n     * @param componentFactoryResolver The resolver service\n     * @param viewContainerRef The viewContainerRef service\n     * @param componentName The name of the angular component (e.g. SpinnerComponent)\n     * @param targetElement The target element of the dom. If the element is null (not found), nothing is done\n     * @param bindings Optional bindings (inputs & outputs) to the given component\n     * @param delay Optional inflating delay in ms(some components may need some time to \"init\" the layout)\n     * @param replace Whether to replace to previous `innerHTML` of `targetElement`\n     * @param injector (to fetch templates for the component)\n     */\n    public injectAngularComponent<T>(\n        viewContainerRef: ViewContainerRef,\n        componentName: Type<T>,\n        targetElement: Element,\n        bindings: { [key: string]: any } = null,\n        { delay = 0, replace = true } = {},\n        injector?: Injector,\n    ): ComponentRef<T> {\n        if (targetElement == null) {\n            return null;\n        }\n        const factory = this.componentFactoryResolver.resolveComponentFactory(componentName);\n        const component: ComponentRef<T> = viewContainerRef.createComponent(\n            factory,\n            undefined,\n            injector || this.injector,\n        );\n        if (bindings) {\n            const instance: { [key: string]: any } = component.instance;\n            for (const key in bindings) {\n                const binding = bindings[key];\n                if (binding instanceof Function) {\n                    // subscribe so callback can properly invoked\n                    instance[key].subscribe((value: any) => binding(value));\n                } else {\n                    instance[key] = binding;\n                    // `ngOnChanges` won't be called on the component like this. Consider doing\n                    // something like this:\n                    // https://scm.edu-sharing.com/edu-sharing/projects/oeh-redaktion/ng-meta-widgets/-/blob/1603fb2dedadd3952401385bcbd91a4bd8407643/src/app/app.module.ts#L66-79\n                }\n            }\n        }\n\n        // 3. Get DOM element from component\n        const domElem = (component.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n        domElem.style.display = 'none';\n        if (replace) {\n            targetElement.innerHTML = null;\n        }\n        targetElement.appendChild(domElem);\n        setTimeout(() => {\n            domElem.style.display = null;\n        }, delay);\n        return component;\n    }\n\n    /**\n     * dynamically inject an angular component into a regular html dom element\n     * @param componentFactoryResolver The resolver service\n     * @param viewContainerRef The viewContainerRef service\n     * @param componentName The name of the angular component (e.g. SpinnerComponent)\n     * @param targetElement The target element of the dom. If the element is null (not found), nothing is done\n     * @param bindings Optional bindings (inputs & outputs) to the given component\n     * @param delay Optional inflating delay in ms(some components may need some time to \"init\" the layout)\n     * @param replace Whether to replace to previous `innerHTML` of `targetElement`\n     * @param injector (to fetch templates for the component)\n     */\n    public static injectAngularComponent<T>(\n        componentFactoryResolver: ComponentFactoryResolver,\n        viewContainerRef: ViewContainerRef,\n        componentName: Type<T>,\n        targetElement: Element,\n        bindings: { [key: string]: any } = null,\n        { delay = 0, replace = true } = {},\n        injector?: Injector,\n    ): ComponentRef<T> {\n        if (targetElement == null) {\n            return null;\n        }\n        const factory = componentFactoryResolver.resolveComponentFactory(componentName);\n        const component: ComponentRef<T> = viewContainerRef.createComponent(\n            factory,\n            undefined,\n            injector,\n        );\n        if (bindings) {\n            const instance: { [key: string]: any } = component.instance;\n            for (const key in bindings) {\n                const binding = bindings[key];\n                if (binding instanceof Function) {\n                    // subscribe so callback can properly invoked\n                    instance[key].subscribe((value: any) => binding(value));\n                } else {\n                    instance[key] = binding;\n                    // `ngOnChanges` won't be called on the component like this. Consider doing\n                    // something like this:\n                    // https://scm.edu-sharing.com/edu-sharing/projects/oeh-redaktion/ng-meta-widgets/-/blob/1603fb2dedadd3952401385bcbd91a4bd8407643/src/app/app.module.ts#L66-79\n                }\n            }\n        }\n\n        // 3. Get DOM element from component\n        const domElem = (component.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n        domElem.style.display = 'none';\n        if (replace) {\n            targetElement.innerHTML = null;\n        }\n        targetElement.appendChild(domElem);\n        setTimeout(() => {\n            domElem.style.display = null;\n        }, delay);\n        return component;\n    }\n\n    /**\n     * smoothly scroll to the given child inside an element (The child will be placed around the first 1/3 of the parent's top)\n     * @param child\n     * @param element\n     * @param smoothness\n     */\n    scrollSmoothElementToChild(child: Element, element: Element | 'auto' = 'auto', smoothness = 1) {\n        let target: Element;\n        if (element === 'auto') {\n            let parent = child.parentElement;\n            while (parent) {\n                if (['scroll', 'auto'].includes(window.getComputedStyle(parent).overflowY)) {\n                    target = parent;\n                    break;\n                }\n                parent = parent.parentElement;\n            }\n        } else {\n            target = element;\n        }\n        // y equals to the top of the child + any scrolling of the parent - the top of the parent\n        let y =\n            child.getBoundingClientRect().top +\n            target.scrollTop -\n            target.getBoundingClientRect().top;\n        // move the focused element to 1/3 at the top of the container\n        y += child.getBoundingClientRect().height / 2 - target.getBoundingClientRect().height / 3;\n        return this.scrollSmoothElement(y, target, smoothness);\n    }\n    /**\n     * Smoothly scrolls to the given y offset inside an element (use offsetTop on the child to\n     * determine this position).\n     *\n     * @param smoothness lower numbers indicate less smoothness, higher more smoothness\n     */\n    scrollSmoothElement(pos: number = 0, element: Element, smoothness = 1, axis = 'y') {\n        return new Promise<void>((resolve) => {\n            this.ngZone.runOutsideAngular(() => {\n                const currentPos = axis == 'x' ? element.scrollLeft : element.scrollTop;\n                if (element.getAttribute('data-is-scrolling') == 'true') {\n                    return;\n                }\n                const mode = currentPos > pos;\n                let lastPos = pos;\n                const maxPos =\n                    axis == 'x'\n                        ? element.scrollWidth - element.clientWidth\n                        : element.scrollHeight - element.clientHeight;\n                let limitReached = false;\n                if (mode && pos <= 0) {\n                    pos = 0;\n                    limitReached = true;\n                }\n                if (!mode && pos >= maxPos) {\n                    pos = maxPos;\n                    limitReached = true;\n                }\n                let speed = 16;\n                let last = new Date().getTime();\n                const callback = () => {\n                    let currentPos = axis == 'x' ? element.scrollLeft : element.scrollTop;\n                    const posDiff = currentPos - lastPos;\n                    const speedFactor = speed / 16;\n                    const divider = (3 / speedFactor) * smoothness;\n                    const minSpeed = (5 * speedFactor) / smoothness;\n                    const maxSpeed = (50 * speedFactor) / smoothness;\n                    lastPos = currentPos;\n                    let finished = true;\n                    if (currentPos > pos) {\n                        currentPos -= Math.min(\n                            maxSpeed,\n                            Math.max((currentPos - pos) / divider, minSpeed),\n                        );\n                        finished = currentPos <= pos;\n                    } else if (currentPos < pos && !mode) {\n                        currentPos += Math.min(\n                            maxSpeed,\n                            Math.max((pos - currentPos) / divider, minSpeed),\n                        );\n                        finished = currentPos >= pos;\n                    }\n                    if (finished) {\n                        currentPos = pos;\n                    }\n\n                    if (axis == 'x') {\n                        element.scrollLeft = currentPos;\n                    } else {\n                        element.scrollTop = currentPos;\n                    }\n                    if (finished) {\n                        element.removeAttribute('data-is-scrolling');\n                        resolve();\n                    } else {\n                        speed = new Date().getTime() - last;\n                        last = new Date().getTime();\n                        window.requestAnimationFrame(callback);\n                    }\n                };\n                window.requestAnimationFrame(callback);\n\n                element.setAttribute('data-is-scrolling', 'true');\n            });\n        });\n    }\n}\n"]}
@@ -1,50 +0,0 @@
1
- import { trigger } from '@angular/animations';
2
- import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
3
- import { UIAnimation } from '../util/ui-animation';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/common";
6
- import * as i2 from "@angular/material/menu";
7
- import * as i3 from "../directives/icon.directive";
8
- import * as i4 from "@ngx-translate/core";
9
- export class SortDropdownComponent {
10
- constructor() {
11
- this.sort = new EventEmitter();
12
- }
13
- setSort(item) {
14
- let ascending = this.sortAscending;
15
- const itemAscending = item.mode === 'ascending';
16
- if (item.name === this.sortBy) {
17
- if (item.mode != null) {
18
- // element is limited to one mode, ignore the request
19
- if (itemAscending === this.sortAscending) {
20
- return;
21
- }
22
- }
23
- ascending = !ascending;
24
- }
25
- else if (item.mode != null) {
26
- // force mode when switching to item
27
- ascending = itemAscending;
28
- }
29
- item.ascending = ascending;
30
- this.sort.emit(item);
31
- }
32
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SortDropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
33
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: SortDropdownComponent, selector: "es-sort-dropdown", inputs: { columns: "columns", sortBy: "sortBy", sortAscending: "sortAscending" }, outputs: { sort: "sort" }, viewQueries: [{ propertyName: "menu", first: true, predicate: ["menu"], descendants: true, static: true }], ngImport: i0, template: "<mat-menu #menu=\"matMenu\" class=\"sort-dropdown-menu\">\n <div class=\"collection-item-title\">{{ 'SORT_BY' | translate }}</div>\n <button\n *ngFor=\"let item of columns\"\n mat-menu-item\n (click)=\"setSort(item)\"\n class=\"collection-item\"\n [class.active]=\"sortBy === item.name\"\n >\n <span class=\"title\" *ngIf=\"item.label\">{{ item.label }}</span>\n <span class=\"title\" *ngIf=\"!item.label\">{{ item.type + '.' + item.name | translate }}</span>\n <ng-container *ngIf=\"sortBy === item.name && item.name !== 'ccm:collection_ordered_position'\">\n <i class=\"material-icons\" *ngIf=\"sortAscending\" [altText]=\"'ASCENDING' | translate\">\n arrow_upward\n </i>\n <i class=\"material-icons\" *ngIf=\"!sortAscending\" [altText]=\"'DESCENDING' | translate\">\n arrow_downward\n </i>\n <span class=\"cdk-visually-hidden\">{{ 'SELECTED' | translate }}</span>\n </ng-container>\n </button>\n</mat-menu>\n", styles: ["::ng-deep .sort-dropdown-menu{width:240px}.collection-item-title{color:var(--textLight);font-size:80%;font-weight:700;padding:5px 16px}.collection-item{display:flex;color:var(--primary);text-align:left;border:none;width:100%}.collection-item ::ng-deep .mat-mdc-menu-item-text{flex-grow:1;display:flex;align-items:center}.collection-item.cdk-keyboard-focused{outline:none;border:2px solid var(--palette-primary-300)}.collection-item.active{--mat-menu-item-label-text-weight: bold}.collection-item.active:after{content:\"\";position:absolute;left:0;width:100%;height:100%;background:linear-gradient(to right,var(--primary) 0,var(--primary) 5px,transparent 5px,transparent 5%)}.collection-item .title{flex-grow:1}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i2.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i3.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }], animations: [trigger('openOverlay', UIAnimation.openOverlay(UIAnimation.ANIMATION_TIME_FAST))] }); }
34
- }
35
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SortDropdownComponent, decorators: [{
36
- type: Component,
37
- args: [{ selector: 'es-sort-dropdown', animations: [trigger('openOverlay', UIAnimation.openOverlay(UIAnimation.ANIMATION_TIME_FAST))], template: "<mat-menu #menu=\"matMenu\" class=\"sort-dropdown-menu\">\n <div class=\"collection-item-title\">{{ 'SORT_BY' | translate }}</div>\n <button\n *ngFor=\"let item of columns\"\n mat-menu-item\n (click)=\"setSort(item)\"\n class=\"collection-item\"\n [class.active]=\"sortBy === item.name\"\n >\n <span class=\"title\" *ngIf=\"item.label\">{{ item.label }}</span>\n <span class=\"title\" *ngIf=\"!item.label\">{{ item.type + '.' + item.name | translate }}</span>\n <ng-container *ngIf=\"sortBy === item.name && item.name !== 'ccm:collection_ordered_position'\">\n <i class=\"material-icons\" *ngIf=\"sortAscending\" [altText]=\"'ASCENDING' | translate\">\n arrow_upward\n </i>\n <i class=\"material-icons\" *ngIf=\"!sortAscending\" [altText]=\"'DESCENDING' | translate\">\n arrow_downward\n </i>\n <span class=\"cdk-visually-hidden\">{{ 'SELECTED' | translate }}</span>\n </ng-container>\n </button>\n</mat-menu>\n", styles: ["::ng-deep .sort-dropdown-menu{width:240px}.collection-item-title{color:var(--textLight);font-size:80%;font-weight:700;padding:5px 16px}.collection-item{display:flex;color:var(--primary);text-align:left;border:none;width:100%}.collection-item ::ng-deep .mat-mdc-menu-item-text{flex-grow:1;display:flex;align-items:center}.collection-item.cdk-keyboard-focused{outline:none;border:2px solid var(--palette-primary-300)}.collection-item.active{--mat-menu-item-label-text-weight: bold}.collection-item.active:after{content:\"\";position:absolute;left:0;width:100%;height:100%;background:linear-gradient(to right,var(--primary) 0,var(--primary) 5px,transparent 5px,transparent 5%)}.collection-item .title{flex-grow:1}\n"] }]
38
- }], ctorParameters: () => [], propDecorators: { menu: [{
39
- type: ViewChild,
40
- args: ['menu', { static: true }]
41
- }], columns: [{
42
- type: Input
43
- }], sortBy: [{
44
- type: Input
45
- }], sortAscending: [{
46
- type: Input
47
- }], sort: [{
48
- type: Output
49
- }] } });
50
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ydC1kcm9wZG93bi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL3NvcnQtZHJvcGRvd24vc29ydC1kcm9wZG93bi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL3NvcnQtZHJvcGRvd24vc29ydC1kcm9wZG93bi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDOUMsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFbEYsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHNCQUFzQixDQUFDOzs7Ozs7QUFTbkQsTUFBTSxPQUFPLHFCQUFxQjtJQVM5QjtRQUZVLFNBQUksR0FBRyxJQUFJLFlBQVksRUFBYSxDQUFDO0lBRWhDLENBQUM7SUFFaEIsT0FBTyxDQUFDLElBQW9CO1FBQ3hCLElBQUksU0FBUyxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUM7UUFDbkMsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLElBQUksS0FBSyxXQUFXLENBQUM7UUFDaEQsSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUM1QixJQUFJLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxFQUFFLENBQUM7Z0JBQ3BCLHFEQUFxRDtnQkFDckQsSUFBSSxhQUFhLEtBQUssSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO29CQUN2QyxPQUFPO2dCQUNYLENBQUM7WUFDTCxDQUFDO1lBQ0QsU0FBUyxHQUFHLENBQUMsU0FBUyxDQUFDO1FBQzNCLENBQUM7YUFBTSxJQUFJLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxFQUFFLENBQUM7WUFDM0Isb0NBQW9DO1lBQ3BDLFNBQVMsR0FBRyxhQUFhLENBQUM7UUFDOUIsQ0FBQztRQUNBLElBQWtCLENBQUMsU0FBUyxHQUFHLFNBQVMsQ0FBQztRQUMxQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN6QixDQUFDOytHQTVCUSxxQkFBcUI7bUdBQXJCLHFCQUFxQixpUkNabEMsdTlCQXNCQSwwakREWmdCLENBQUMsT0FBTyxDQUFDLGFBQWEsRUFBRSxXQUFXLENBQUMsV0FBVyxDQUFDLFdBQVcsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUM7OzRGQUVyRixxQkFBcUI7a0JBTmpDLFNBQVM7K0JBQ0ksa0JBQWtCLGNBR2hCLENBQUMsT0FBTyxDQUFDLGFBQWEsRUFBRSxXQUFXLENBQUMsV0FBVyxDQUFDLFdBQVcsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUM7d0RBR3pELElBQUk7c0JBQXhDLFNBQVM7dUJBQUMsTUFBTSxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTtnQkFFMUIsT0FBTztzQkFBZixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUVJLElBQUk7c0JBQWIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHRyaWdnZXIgfSBmcm9tICdAYW5ndWxhci9hbmltYXRpb25zJztcbmltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0LCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdE1lbnUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9tZW51JztcbmltcG9ydCB7IFVJQW5pbWF0aW9uIH0gZnJvbSAnLi4vdXRpbC91aS1hbmltYXRpb24nO1xuaW1wb3J0IHsgTGlzdEl0ZW0sIFNvcnRFdmVudCB9IGZyb20gJy4uL3R5cGVzL2xpc3QtaXRlbSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZXMtc29ydC1kcm9wZG93bicsXG4gICAgdGVtcGxhdGVVcmw6ICdzb3J0LWRyb3Bkb3duLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnc29ydC1kcm9wZG93bi5jb21wb25lbnQuc2NzcyddLFxuICAgIGFuaW1hdGlvbnM6IFt0cmlnZ2VyKCdvcGVuT3ZlcmxheScsIFVJQW5pbWF0aW9uLm9wZW5PdmVybGF5KFVJQW5pbWF0aW9uLkFOSU1BVElPTl9USU1FX0ZBU1QpKV0sXG59KVxuZXhwb3J0IGNsYXNzIFNvcnREcm9wZG93bkNvbXBvbmVudCB7XG4gICAgQFZpZXdDaGlsZCgnbWVudScsIHsgc3RhdGljOiB0cnVlIH0pIG1lbnU6IE1hdE1lbnU7XG5cbiAgICBASW5wdXQoKSBjb2x1bW5zOiBMaXN0SXRlbVtdO1xuICAgIEBJbnB1dCgpIHNvcnRCeTogc3RyaW5nO1xuICAgIEBJbnB1dCgpIHNvcnRBc2NlbmRpbmc6IGJvb2xlYW47XG5cbiAgICBAT3V0cHV0KCkgc29ydCA9IG5ldyBFdmVudEVtaXR0ZXI8U29ydEV2ZW50PigpO1xuXG4gICAgY29uc3RydWN0b3IoKSB7fVxuXG4gICAgc2V0U29ydChpdGVtOiBMaXN0SXRlbSB8IGFueSk6IHZvaWQge1xuICAgICAgICBsZXQgYXNjZW5kaW5nID0gdGhpcy5zb3J0QXNjZW5kaW5nO1xuICAgICAgICBjb25zdCBpdGVtQXNjZW5kaW5nID0gaXRlbS5tb2RlID09PSAnYXNjZW5kaW5nJztcbiAgICAgICAgaWYgKGl0ZW0ubmFtZSA9PT0gdGhpcy5zb3J0QnkpIHtcbiAgICAgICAgICAgIGlmIChpdGVtLm1vZGUgIT0gbnVsbCkge1xuICAgICAgICAgICAgICAgIC8vIGVsZW1lbnQgaXMgbGltaXRlZCB0byBvbmUgbW9kZSwgaWdub3JlIHRoZSByZXF1ZXN0XG4gICAgICAgICAgICAgICAgaWYgKGl0ZW1Bc2NlbmRpbmcgPT09IHRoaXMuc29ydEFzY2VuZGluZykge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgYXNjZW5kaW5nID0gIWFzY2VuZGluZztcbiAgICAgICAgfSBlbHNlIGlmIChpdGVtLm1vZGUgIT0gbnVsbCkge1xuICAgICAgICAgICAgLy8gZm9yY2UgbW9kZSB3aGVuIHN3aXRjaGluZyB0byBpdGVtXG4gICAgICAgICAgICBhc2NlbmRpbmcgPSBpdGVtQXNjZW5kaW5nO1xuICAgICAgICB9XG4gICAgICAgIChpdGVtIGFzIFNvcnRFdmVudCkuYXNjZW5kaW5nID0gYXNjZW5kaW5nO1xuICAgICAgICB0aGlzLnNvcnQuZW1pdChpdGVtKTtcbiAgICB9XG59XG4iLCI8bWF0LW1lbnUgI21lbnU9XCJtYXRNZW51XCIgY2xhc3M9XCJzb3J0LWRyb3Bkb3duLW1lbnVcIj5cbiAgPGRpdiBjbGFzcz1cImNvbGxlY3Rpb24taXRlbS10aXRsZVwiPnt7ICdTT1JUX0JZJyB8IHRyYW5zbGF0ZSB9fTwvZGl2PlxuICA8YnV0dG9uXG4gICAgKm5nRm9yPVwibGV0IGl0ZW0gb2YgY29sdW1uc1wiXG4gICAgbWF0LW1lbnUtaXRlbVxuICAgIChjbGljayk9XCJzZXRTb3J0KGl0ZW0pXCJcbiAgICBjbGFzcz1cImNvbGxlY3Rpb24taXRlbVwiXG4gICAgW2NsYXNzLmFjdGl2ZV09XCJzb3J0QnkgPT09IGl0ZW0ubmFtZVwiXG4gID5cbiAgICA8c3BhbiBjbGFzcz1cInRpdGxlXCIgKm5nSWY9XCJpdGVtLmxhYmVsXCI+e3sgaXRlbS5sYWJlbCB9fTwvc3Bhbj5cbiAgICA8c3BhbiBjbGFzcz1cInRpdGxlXCIgKm5nSWY9XCIhaXRlbS5sYWJlbFwiPnt7IGl0ZW0udHlwZSArICcuJyArIGl0ZW0ubmFtZSB8IHRyYW5zbGF0ZSB9fTwvc3Bhbj5cbiAgICA8bmctY29udGFpbmVyICpuZ0lmPVwic29ydEJ5ID09PSBpdGVtLm5hbWUgJiYgaXRlbS5uYW1lICE9PSAnY2NtOmNvbGxlY3Rpb25fb3JkZXJlZF9wb3NpdGlvbidcIj5cbiAgICAgIDxpIGNsYXNzPVwibWF0ZXJpYWwtaWNvbnNcIiAqbmdJZj1cInNvcnRBc2NlbmRpbmdcIiBbYWx0VGV4dF09XCInQVNDRU5ESU5HJyB8IHRyYW5zbGF0ZVwiPlxuICAgICAgICBhcnJvd191cHdhcmRcbiAgICAgIDwvaT5cbiAgICAgIDxpIGNsYXNzPVwibWF0ZXJpYWwtaWNvbnNcIiAqbmdJZj1cIiFzb3J0QXNjZW5kaW5nXCIgW2FsdFRleHRdPVwiJ0RFU0NFTkRJTkcnIHwgdHJhbnNsYXRlXCI+XG4gICAgICAgIGFycm93X2Rvd253YXJkXG4gICAgICA8L2k+XG4gICAgICA8c3BhbiBjbGFzcz1cImNkay12aXN1YWxseS1oaWRkZW5cIj57eyAnU0VMRUNURUQnIHwgdHJhbnNsYXRlIH19PC9zcGFuPlxuICAgIDwvbmctY29udGFpbmVyPlxuICA8L2J1dHRvbj5cbjwvbWF0LW1lbnU+XG4iXX0=
@@ -1,19 +0,0 @@
1
- import { Component, HostBinding } from '@angular/core';
2
- import { TranslateModule } from '@ngx-translate/core';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@ngx-translate/core";
5
- export class SpinnerComponent {
6
- constructor() {
7
- this.dataTest = 'loading-spinner';
8
- }
9
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SpinnerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
10
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: SpinnerComponent, isStandalone: true, selector: "es-spinner", host: { properties: { "attr.data-test": "this.dataTest" } }, ngImport: i0, template: "<div class=\"spinner\">\n <span aria-live=\"polite\" class=\"cdk-visually-hidden\">{{ 'LOADING' | translate }}</span>\n <div class=\"spinnercontainer\">\n <div class=\"inner\">\n <div class=\"spinner1\"></div>\n </div>\n <div class=\"inner\">\n <div class=\"spinner2\"></div>\n </div>\n <div class=\"inner\">\n <div class=\"spinner3\"></div>\n </div>\n </div>\n</div>\n", styles: [".spinner{margin:0 auto}.spinnercontainer{margin:20px auto auto;height:54px;color:#0000;text-align:center;float:left;width:100%}.inner{width:30px;height:50px;display:inline-block}.spinner1{background:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDEyLjAuMCwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgNTE0NDgpICAtLT4KPCFET0NUWVBFIHN2ZyBQVUJMSUMgIi0vL1czQy8vRFREIFNWRyAxLjEvL0VOIiAiaHR0cDovL3d3dy53My5vcmcvR3JhcGhpY3MvU1ZHLzEuMS9EVEQvc3ZnMTEuZHRkIiBbCgk8IUVOVElUWSBuc19zdmcgImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KCTwhRU5USVRZIG5zX3hsaW5rICJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIj4KXT4KPHN2ZyAgdmVyc2lvbj0iMS4xIiBpZD0iTGF5ZXJfMSIgeG1sbnM9IiZuc19zdmc7IiB4bWxuczp4bGluaz0iJm5zX3hsaW5rOyIgd2lkdGg9IjE1LjY1NyIgaGVpZ2h0PSIxMy41NTkiCgkgdmlld0JveD0iMCAwIDE1LjY1NyAxMy41NTkiIG92ZXJmbG93PSJ2aXNpYmxlIiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCAxNS42NTcgMTMuNTU5IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHBvbHlnb24gb3BhY2l0eT0iMC42IiBmaWxsPSIjYzFjNmUzIiBwb2ludHM9IjMuOTE0LDEzLjU1OSAwLDYuNzggMy45MTQsMCAxMS43NDMsMCAxNS42NTcsNi43OCAxMS43NDMsMTMuNTU5ICIvPgo8L3N2Zz4K);background-repeat:no-repeat;background-position:center;background-size:50px;width:50px;height:50px;-webkit-animation:spin 2s infinite ease-in;-moz-animation:spin 2s infinite ease-in;-ms-animation:spin 2s infinite ease-in;-o-animation:spin 2s infinite ease-in;animation:spin 2s infinite ease-in;-webkit-animation-delay:.1s;-moz-animation-delay:.1s;animation-delay:.1s}.spinner2{background:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDEyLjAuMCwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgNTE0NDgpICAtLT4KPCFET0NUWVBFIHN2ZyBQVUJMSUMgIi0vL1czQy8vRFREIFNWRyAxLjEvL0VOIiAiaHR0cDovL3d3dy53My5vcmcvR3JhcGhpY3MvU1ZHLzEuMS9EVEQvc3ZnMTEuZHRkIiBbCgk8IUVOVElUWSBuc19zdmcgImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KCTwhRU5USVRZIG5zX3hsaW5rICJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIj4KXT4KPHN2ZyAgdmVyc2lvbj0iMS4xIiBpZD0iTGF5ZXJfMSIgeG1sbnM9IiZuc19zdmc7IiB4bWxuczp4bGluaz0iJm5zX3hsaW5rOyIgd2lkdGg9IjE1LjY1NyIgaGVpZ2h0PSIxMy41NTkiCgkgdmlld0JveD0iMCAwIDE1LjY1NyAxMy41NTkiIG92ZXJmbG93PSJ2aXNpYmxlIiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCAxNS42NTcgMTMuNTU5IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHBvbHlnb24gb3BhY2l0eT0iMC42IiBmaWxsPSIjN2Y5MWMzIiBwb2ludHM9IjMuOTE0LDEzLjU1OSAwLDYuNzggMy45MTQsMCAxMS43NDMsMCAxNS42NTcsNi43OCAxMS43NDMsMTMuNTU5ICIvPgo8L3N2Zz4K);background-repeat:no-repeat;background-position:center;background-size:50px;width:50px;height:50px;-webkit-animation:spin 2s infinite ease-in;-moz-animation:spin 2s infinite ease-in;-ms-animation:spin 2s infinite ease-in;-o-animation:spin 2s infinite ease-in;animation:spin 2s infinite ease-in;-webkit-animation-delay:.25s;-moz-animation-delay:.25s;animation-delay:.25s}.spinner3{background:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDEyLjAuMCwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgNTE0NDgpICAtLT4KPCFET0NUWVBFIHN2ZyBQVUJMSUMgIi0vL1czQy8vRFREIFNWRyAxLjEvL0VOIiAiaHR0cDovL3d3dy53My5vcmcvR3JhcGhpY3MvU1ZHLzEuMS9EVEQvc3ZnMTEuZHRkIiBbCgk8IUVOVElUWSBuc19zdmcgImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KCTwhRU5USVRZIG5zX3hsaW5rICJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIj4KXT4KPHN2ZyAgdmVyc2lvbj0iMS4xIiBpZD0iTGF5ZXJfMSIgeG1sbnM9IiZuc19zdmc7IiB4bWxuczp4bGluaz0iJm5zX3hsaW5rOyIgd2lkdGg9IjE1LjY1NyIgaGVpZ2h0PSIxMy41NTkiCgkgdmlld0JveD0iMCAwIDE1LjY1NyAxMy41NTkiIG92ZXJmbG93PSJ2aXNpYmxlIiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCAxNS42NTcgMTMuNTU5IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHBvbHlnb24gb3BhY2l0eT0iMC42IiBmaWxsPSIjMzE2MmE3IiBwb2ludHM9IjMuOTE0LDEzLjU1OSAwLDYuNzggMy45MTQsMCAxMS43NDMsMCAxNS42NTcsNi43OCAxMS43NDMsMTMuNTU5ICIvPgo8L3N2Zz4K);background-repeat:no-repeat;background-position:center;background-size:50px;width:50px;height:50px;-webkit-animation:spin 2s infinite ease-in;-moz-animation:spin 2s infinite ease-in;-ms-animation:spin 2s infinite ease-in;-o-animation:spin 2s infinite ease-in;animation:spin 2s infinite ease-in;-webkit-animation-delay:.5s;-moz-animation-delay:.5s;animation-delay:.5s}@-webkit-keyframes spin{0%{transform:scale(1)}50%{transform:scale(.5)}to{transform:scale(1)}}@-moz-keyframes spin{0%{transform:scale(1)}50%{transform:scale(.5)}to{transform:scale(1)}}@-ms-keyframes spin{0%{transform:scale(1)}50%{transform:scale(.5)}to{transform:scale(1)}}@-o-keyframes spin{0%{transform:scale(1)}50%{transform:scale(.5)}to{transform:scale(1)}}@keyframes spin{0%{transform:scale(1)}50%{transform:scale(.5) rotate(90deg)}to{transform:scale(1)}}\n"], dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] }); }
11
- }
12
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SpinnerComponent, decorators: [{
13
- type: Component,
14
- args: [{ selector: 'es-spinner', standalone: true, imports: [TranslateModule], template: "<div class=\"spinner\">\n <span aria-live=\"polite\" class=\"cdk-visually-hidden\">{{ 'LOADING' | translate }}</span>\n <div class=\"spinnercontainer\">\n <div class=\"inner\">\n <div class=\"spinner1\"></div>\n </div>\n <div class=\"inner\">\n <div class=\"spinner2\"></div>\n </div>\n <div class=\"inner\">\n <div class=\"spinner3\"></div>\n </div>\n </div>\n</div>\n", styles: [".spinner{margin:0 auto}.spinnercontainer{margin:20px auto auto;height:54px;color:#0000;text-align:center;float:left;width:100%}.inner{width:30px;height:50px;display:inline-block}.spinner1{background:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDEyLjAuMCwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgNTE0NDgpICAtLT4KPCFET0NUWVBFIHN2ZyBQVUJMSUMgIi0vL1czQy8vRFREIFNWRyAxLjEvL0VOIiAiaHR0cDovL3d3dy53My5vcmcvR3JhcGhpY3MvU1ZHLzEuMS9EVEQvc3ZnMTEuZHRkIiBbCgk8IUVOVElUWSBuc19zdmcgImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KCTwhRU5USVRZIG5zX3hsaW5rICJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIj4KXT4KPHN2ZyAgdmVyc2lvbj0iMS4xIiBpZD0iTGF5ZXJfMSIgeG1sbnM9IiZuc19zdmc7IiB4bWxuczp4bGluaz0iJm5zX3hsaW5rOyIgd2lkdGg9IjE1LjY1NyIgaGVpZ2h0PSIxMy41NTkiCgkgdmlld0JveD0iMCAwIDE1LjY1NyAxMy41NTkiIG92ZXJmbG93PSJ2aXNpYmxlIiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCAxNS42NTcgMTMuNTU5IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHBvbHlnb24gb3BhY2l0eT0iMC42IiBmaWxsPSIjYzFjNmUzIiBwb2ludHM9IjMuOTE0LDEzLjU1OSAwLDYuNzggMy45MTQsMCAxMS43NDMsMCAxNS42NTcsNi43OCAxMS43NDMsMTMuNTU5ICIvPgo8L3N2Zz4K);background-repeat:no-repeat;background-position:center;background-size:50px;width:50px;height:50px;-webkit-animation:spin 2s infinite ease-in;-moz-animation:spin 2s infinite ease-in;-ms-animation:spin 2s infinite ease-in;-o-animation:spin 2s infinite ease-in;animation:spin 2s infinite ease-in;-webkit-animation-delay:.1s;-moz-animation-delay:.1s;animation-delay:.1s}.spinner2{background:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDEyLjAuMCwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgNTE0NDgpICAtLT4KPCFET0NUWVBFIHN2ZyBQVUJMSUMgIi0vL1czQy8vRFREIFNWRyAxLjEvL0VOIiAiaHR0cDovL3d3dy53My5vcmcvR3JhcGhpY3MvU1ZHLzEuMS9EVEQvc3ZnMTEuZHRkIiBbCgk8IUVOVElUWSBuc19zdmcgImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KCTwhRU5USVRZIG5zX3hsaW5rICJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIj4KXT4KPHN2ZyAgdmVyc2lvbj0iMS4xIiBpZD0iTGF5ZXJfMSIgeG1sbnM9IiZuc19zdmc7IiB4bWxuczp4bGluaz0iJm5zX3hsaW5rOyIgd2lkdGg9IjE1LjY1NyIgaGVpZ2h0PSIxMy41NTkiCgkgdmlld0JveD0iMCAwIDE1LjY1NyAxMy41NTkiIG92ZXJmbG93PSJ2aXNpYmxlIiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCAxNS42NTcgMTMuNTU5IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHBvbHlnb24gb3BhY2l0eT0iMC42IiBmaWxsPSIjN2Y5MWMzIiBwb2ludHM9IjMuOTE0LDEzLjU1OSAwLDYuNzggMy45MTQsMCAxMS43NDMsMCAxNS42NTcsNi43OCAxMS43NDMsMTMuNTU5ICIvPgo8L3N2Zz4K);background-repeat:no-repeat;background-position:center;background-size:50px;width:50px;height:50px;-webkit-animation:spin 2s infinite ease-in;-moz-animation:spin 2s infinite ease-in;-ms-animation:spin 2s infinite ease-in;-o-animation:spin 2s infinite ease-in;animation:spin 2s infinite ease-in;-webkit-animation-delay:.25s;-moz-animation-delay:.25s;animation-delay:.25s}.spinner3{background:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDEyLjAuMCwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgNTE0NDgpICAtLT4KPCFET0NUWVBFIHN2ZyBQVUJMSUMgIi0vL1czQy8vRFREIFNWRyAxLjEvL0VOIiAiaHR0cDovL3d3dy53My5vcmcvR3JhcGhpY3MvU1ZHLzEuMS9EVEQvc3ZnMTEuZHRkIiBbCgk8IUVOVElUWSBuc19zdmcgImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KCTwhRU5USVRZIG5zX3hsaW5rICJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIj4KXT4KPHN2ZyAgdmVyc2lvbj0iMS4xIiBpZD0iTGF5ZXJfMSIgeG1sbnM9IiZuc19zdmc7IiB4bWxuczp4bGluaz0iJm5zX3hsaW5rOyIgd2lkdGg9IjE1LjY1NyIgaGVpZ2h0PSIxMy41NTkiCgkgdmlld0JveD0iMCAwIDE1LjY1NyAxMy41NTkiIG92ZXJmbG93PSJ2aXNpYmxlIiBlbmFibGUtYmFja2dyb3VuZD0ibmV3IDAgMCAxNS42NTcgMTMuNTU5IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHBvbHlnb24gb3BhY2l0eT0iMC42IiBmaWxsPSIjMzE2MmE3IiBwb2ludHM9IjMuOTE0LDEzLjU1OSAwLDYuNzggMy45MTQsMCAxMS43NDMsMCAxNS42NTcsNi43OCAxMS43NDMsMTMuNTU5ICIvPgo8L3N2Zz4K);background-repeat:no-repeat;background-position:center;background-size:50px;width:50px;height:50px;-webkit-animation:spin 2s infinite ease-in;-moz-animation:spin 2s infinite ease-in;-ms-animation:spin 2s infinite ease-in;-o-animation:spin 2s infinite ease-in;animation:spin 2s infinite ease-in;-webkit-animation-delay:.5s;-moz-animation-delay:.5s;animation-delay:.5s}@-webkit-keyframes spin{0%{transform:scale(1)}50%{transform:scale(.5)}to{transform:scale(1)}}@-moz-keyframes spin{0%{transform:scale(1)}50%{transform:scale(.5)}to{transform:scale(1)}}@-ms-keyframes spin{0%{transform:scale(1)}50%{transform:scale(.5)}to{transform:scale(1)}}@-o-keyframes spin{0%{transform:scale(1)}50%{transform:scale(.5)}to{transform:scale(1)}}@keyframes spin{0%{transform:scale(1)}50%{transform:scale(.5) rotate(90deg)}to{transform:scale(1)}}\n"] }]
15
- }], ctorParameters: () => [], propDecorators: { dataTest: [{
16
- type: HostBinding,
17
- args: ['attr.data-test']
18
- }] } });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Bpbm5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL3NwaW5uZXIvc3Bpbm5lci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL3NwaW5uZXIvc3Bpbm5lci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUMvRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7OztBQVN0RCxNQUFNLE9BQU8sZ0JBQWdCO0lBR3pCO1FBRndDLGFBQVEsR0FBRyxpQkFBaUIsQ0FBQztJQUV0RCxDQUFDOytHQUhQLGdCQUFnQjttR0FBaEIsZ0JBQWdCLG1JQ1Y3Qix1WkFjQSwrakpETmMsZUFBZTs7NEZBRWhCLGdCQUFnQjtrQkFQNUIsU0FBUzsrQkFDSSxZQUFZLGNBR1YsSUFBSSxXQUNQLENBQUMsZUFBZSxDQUFDO3dEQUdjLFFBQVE7c0JBQS9DLFdBQVc7dUJBQUMsZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBIb3N0QmluZGluZywgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdlcy1zcGlubmVyJyxcbiAgICB0ZW1wbGF0ZVVybDogJ3NwaW5uZXIuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWydzcGlubmVyLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbVHJhbnNsYXRlTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgU3Bpbm5lckNvbXBvbmVudCB7XG4gICAgQEhvc3RCaW5kaW5nKCdhdHRyLmRhdGEtdGVzdCcpIHJlYWRvbmx5IGRhdGFUZXN0ID0gJ2xvYWRpbmctc3Bpbm5lcic7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHt9XG59XG4iLCI8ZGl2IGNsYXNzPVwic3Bpbm5lclwiPlxuICA8c3BhbiBhcmlhLWxpdmU9XCJwb2xpdGVcIiBjbGFzcz1cImNkay12aXN1YWxseS1oaWRkZW5cIj57eyAnTE9BRElORycgfCB0cmFuc2xhdGUgfX08L3NwYW4+XG4gIDxkaXYgY2xhc3M9XCJzcGlubmVyY29udGFpbmVyXCI+XG4gICAgPGRpdiBjbGFzcz1cImlubmVyXCI+XG4gICAgICA8ZGl2IGNsYXNzPVwic3Bpbm5lcjFcIj48L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2IGNsYXNzPVwiaW5uZXJcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJzcGlubmVyMlwiPjwvZGl2PlxuICAgIDwvZGl2PlxuICAgIDxkaXYgY2xhc3M9XCJpbm5lclwiPlxuICAgICAgPGRpdiBjbGFzcz1cInNwaW5uZXIzXCI+PC9kaXY+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
@@ -1,18 +0,0 @@
1
- import { Component, Input } from '@angular/core';
2
- import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/material/progress-spinner";
5
- export class SpinnerSmallComponent {
6
- constructor() {
7
- this.diameter = 20;
8
- }
9
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SpinnerSmallComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
10
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: SpinnerSmallComponent, isStandalone: true, selector: "es-spinner-small", inputs: { diameter: "diameter" }, ngImport: i0, template: "<mat-progress-spinner\n color=\"primary\"\n mode=\"indeterminate\"\n [diameter]=\"diameter\"\n></mat-progress-spinner>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatProgressSpinnerModule }, { kind: "component", type: i1.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }] }); }
11
- }
12
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SpinnerSmallComponent, decorators: [{
13
- type: Component,
14
- args: [{ selector: 'es-spinner-small', standalone: true, imports: [MatProgressSpinnerModule], template: "<mat-progress-spinner\n color=\"primary\"\n mode=\"indeterminate\"\n [diameter]=\"diameter\"\n></mat-progress-spinner>\n" }]
15
- }], ctorParameters: () => [], propDecorators: { diameter: [{
16
- type: Input
17
- }] } });
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Bpbm5lci1zbWFsbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL3NwaW5uZXItc21hbGwvc3Bpbm5lci1zbWFsbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL3NwaW5uZXItc21hbGwvc3Bpbm5lci1zbWFsbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQzs7O0FBUzlFLE1BQU0sT0FBTyxxQkFBcUI7SUFFOUI7UUFEUyxhQUFRLEdBQUcsRUFBRSxDQUFDO0lBQ1IsQ0FBQzsrR0FGUCxxQkFBcUI7bUdBQXJCLHFCQUFxQiw4R0NWbEMsNkhBS0EseURER2Msd0JBQXdCOzs0RkFFekIscUJBQXFCO2tCQVBqQyxTQUFTOytCQUNJLGtCQUFrQixjQUdoQixJQUFJLFdBQ1AsQ0FBQyx3QkFBd0IsQ0FBQzt3REFHMUIsUUFBUTtzQkFBaEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdFByb2dyZXNzU3Bpbm5lck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Byb2dyZXNzLXNwaW5uZXInO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2VzLXNwaW5uZXItc21hbGwnLFxuICAgIHRlbXBsYXRlVXJsOiAnc3Bpbm5lci1zbWFsbC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJ3NwaW5uZXItc21hbGwuY29tcG9uZW50LnNjc3MnXSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtNYXRQcm9ncmVzc1NwaW5uZXJNb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBTcGlubmVyU21hbGxDb21wb25lbnQge1xuICAgIEBJbnB1dCgpIGRpYW1ldGVyID0gMjA7XG4gICAgY29uc3RydWN0b3IoKSB7fVxufVxuIiwiPG1hdC1wcm9ncmVzcy1zcGlubmVyXG4gIGNvbG9yPVwicHJpbWFyeVwiXG4gIG1vZGU9XCJpbmRldGVybWluYXRlXCJcbiAgW2RpYW1ldGVyXT1cImRpYW1ldGVyXCJcbj48L21hdC1wcm9ncmVzcy1zcGlubmVyPlxuIl19
@@ -1,6 +0,0 @@
1
- export class FallbackTranslationHandler {
2
- handle(params) {
3
- return params.interpolateParams?.fallback ?? params.key;
4
- }
5
- }
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFsbGJhY2stdHJhbnNsYXRpb24taGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvdHJhbnNsYXRpb25zL2ZhbGxiYWNrLXRyYW5zbGF0aW9uLWhhbmRsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxPQUFPLDBCQUEwQjtJQUNuQyxNQUFNLENBQUMsTUFBdUM7UUFDMUMsT0FBUSxNQUFNLENBQUMsaUJBQXlCLEVBQUUsUUFBUSxJQUFJLE1BQU0sQ0FBQyxHQUFHLENBQUM7SUFDckUsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWlzc2luZ1RyYW5zbGF0aW9uSGFuZGxlciwgTWlzc2luZ1RyYW5zbGF0aW9uSGFuZGxlclBhcmFtcyB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuXG5leHBvcnQgY2xhc3MgRmFsbGJhY2tUcmFuc2xhdGlvbkhhbmRsZXIgaW1wbGVtZW50cyBNaXNzaW5nVHJhbnNsYXRpb25IYW5kbGVyIHtcbiAgICBoYW5kbGUocGFyYW1zOiBNaXNzaW5nVHJhbnNsYXRpb25IYW5kbGVyUGFyYW1zKSB7XG4gICAgICAgIHJldHVybiAocGFyYW1zLmludGVycG9sYXRlUGFyYW1zIGFzIGFueSk/LmZhbGxiYWNrID8/IHBhcmFtcy5rZXk7XG4gICAgfVxufVxuIl19