@ng-nest/ui 14.0.6 → 14.0.7

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 (109) hide show
  1. package/calendar/calendar.component.d.ts +1 -0
  2. package/calendar/calendar.property.d.ts +18 -4
  3. package/calendar/examples/en_US/default/card/README.md +6 -0
  4. package/calendar/examples/en_US/default/header/README.md +6 -0
  5. package/calendar/examples/zh_CN/default/card/README.md +6 -0
  6. package/calendar/examples/zh_CN/default/header/README.md +6 -0
  7. package/collapse/collapse.property.d.ts +6 -1
  8. package/collapse/examples/en_US/default/disabled/README.md +6 -0
  9. package/collapse/examples/zh_CN/default/disabled/README.md +6 -0
  10. package/core/config/config.d.ts +4 -0
  11. package/esm2020/badge/badge.component.mjs +3 -3
  12. package/esm2020/calendar/calendar.component.mjs +8 -4
  13. package/esm2020/calendar/calendar.property.mjs +11 -2
  14. package/esm2020/collapse/collapse-panel.component.mjs +3 -3
  15. package/esm2020/collapse/collapse.property.mjs +7 -2
  16. package/esm2020/core/config/config.mjs +1 -1
  17. package/esm2020/date-picker/date-picker.component.mjs +5 -1
  18. package/esm2020/i18n/i18n.property.mjs +1 -1
  19. package/esm2020/i18n/languages/en_US.mjs +4 -1
  20. package/esm2020/i18n/languages/zh_CN.mjs +4 -1
  21. package/esm2020/i18n/languages/zh_TW.mjs +4 -1
  22. package/esm2020/image/image-group.component.mjs +18 -0
  23. package/esm2020/image/image-preview.component.mjs +136 -0
  24. package/esm2020/image/image.component.mjs +81 -0
  25. package/esm2020/image/image.module.mjs +26 -0
  26. package/esm2020/image/image.property.mjs +63 -0
  27. package/esm2020/image/ng-nest-ui-image.mjs +5 -0
  28. package/esm2020/image/public-api.mjs +6 -0
  29. package/esm2020/index.mjs +2 -1
  30. package/esm2020/list/list.component.mjs +70 -9
  31. package/esm2020/list/list.module.mjs +8 -4
  32. package/esm2020/list/list.property.mjs +37 -2
  33. package/esm2020/table/table-head.component.mjs +2 -2
  34. package/esm2020/textarea/textarea.component.mjs +2 -2
  35. package/esm2020/timeline/timeline.component.mjs +6 -4
  36. package/fesm2015/ng-nest-ui-badge.mjs +2 -2
  37. package/fesm2015/ng-nest-ui-badge.mjs.map +1 -1
  38. package/fesm2015/ng-nest-ui-calendar.mjs +17 -4
  39. package/fesm2015/ng-nest-ui-calendar.mjs.map +1 -1
  40. package/fesm2015/ng-nest-ui-collapse.mjs +8 -3
  41. package/fesm2015/ng-nest-ui-collapse.mjs.map +1 -1
  42. package/fesm2015/ng-nest-ui-core.mjs.map +1 -1
  43. package/fesm2015/ng-nest-ui-date-picker.mjs +4 -0
  44. package/fesm2015/ng-nest-ui-date-picker.mjs.map +1 -1
  45. package/fesm2015/ng-nest-ui-i18n.mjs +9 -0
  46. package/fesm2015/ng-nest-ui-i18n.mjs.map +1 -1
  47. package/fesm2015/ng-nest-ui-image.mjs +312 -0
  48. package/fesm2015/ng-nest-ui-image.mjs.map +1 -0
  49. package/fesm2015/ng-nest-ui-list.mjs +112 -11
  50. package/fesm2015/ng-nest-ui-list.mjs.map +1 -1
  51. package/fesm2015/ng-nest-ui-table.mjs +1 -1
  52. package/fesm2015/ng-nest-ui-table.mjs.map +1 -1
  53. package/fesm2015/ng-nest-ui-textarea.mjs +2 -2
  54. package/fesm2015/ng-nest-ui-textarea.mjs.map +1 -1
  55. package/fesm2015/ng-nest-ui-timeline.mjs +5 -3
  56. package/fesm2015/ng-nest-ui-timeline.mjs.map +1 -1
  57. package/fesm2015/ng-nest-ui.mjs +1 -0
  58. package/fesm2015/ng-nest-ui.mjs.map +1 -1
  59. package/fesm2020/ng-nest-ui-badge.mjs +2 -2
  60. package/fesm2020/ng-nest-ui-badge.mjs.map +1 -1
  61. package/fesm2020/ng-nest-ui-calendar.mjs +17 -4
  62. package/fesm2020/ng-nest-ui-calendar.mjs.map +1 -1
  63. package/fesm2020/ng-nest-ui-collapse.mjs +8 -3
  64. package/fesm2020/ng-nest-ui-collapse.mjs.map +1 -1
  65. package/fesm2020/ng-nest-ui-core.mjs.map +1 -1
  66. package/fesm2020/ng-nest-ui-date-picker.mjs +4 -0
  67. package/fesm2020/ng-nest-ui-date-picker.mjs.map +1 -1
  68. package/fesm2020/ng-nest-ui-i18n.mjs +9 -0
  69. package/fesm2020/ng-nest-ui-i18n.mjs.map +1 -1
  70. package/fesm2020/ng-nest-ui-image.mjs +308 -0
  71. package/fesm2020/ng-nest-ui-image.mjs.map +1 -0
  72. package/fesm2020/ng-nest-ui-list.mjs +111 -11
  73. package/fesm2020/ng-nest-ui-list.mjs.map +1 -1
  74. package/fesm2020/ng-nest-ui-table.mjs +1 -1
  75. package/fesm2020/ng-nest-ui-table.mjs.map +1 -1
  76. package/fesm2020/ng-nest-ui-textarea.mjs +2 -2
  77. package/fesm2020/ng-nest-ui-textarea.mjs.map +1 -1
  78. package/fesm2020/ng-nest-ui-timeline.mjs +5 -3
  79. package/fesm2020/ng-nest-ui-timeline.mjs.map +1 -1
  80. package/fesm2020/ng-nest-ui.mjs +1 -0
  81. package/fesm2020/ng-nest-ui.mjs.map +1 -1
  82. package/i18n/i18n.property.d.ts +4 -0
  83. package/i18n/languages/en_US.d.ts +3 -0
  84. package/i18n/languages/zh_CN.d.ts +3 -0
  85. package/i18n/languages/zh_TW.d.ts +3 -0
  86. package/image/examples/en_US/default/README.md +4 -0
  87. package/image/examples/en_US/default/default/README.md +6 -0
  88. package/image/examples/en_US/default/fallback/README.md +6 -0
  89. package/image/examples/en_US/default/group/README.md +6 -0
  90. package/image/examples/en_US/default/placeholder/README.md +6 -0
  91. package/image/examples/zh_CN/default/README.md +4 -0
  92. package/image/examples/zh_CN/default/default/README.md +6 -0
  93. package/image/examples/zh_CN/default/fallback/README.md +6 -0
  94. package/image/examples/zh_CN/default/group/README.md +6 -0
  95. package/image/examples/zh_CN/default/placeholder/README.md +6 -0
  96. package/image/image-group.component.d.ts +8 -0
  97. package/image/image-preview.component.d.ts +39 -0
  98. package/image/image.component.d.ts +29 -0
  99. package/image/image.module.d.ts +16 -0
  100. package/image/image.property.d.ts +96 -0
  101. package/image/index.d.ts +5 -0
  102. package/image/public-api.d.ts +5 -0
  103. package/index.d.ts +1 -0
  104. package/list/examples/en_US/default/scroll/README.md +8 -0
  105. package/list/examples/zh_CN/default/scroll/README.md +8 -0
  106. package/list/list.component.d.ts +13 -1
  107. package/list/list.module.d.ts +2 -1
  108. package/list/list.property.d.ts +41 -2
  109. package/package.json +9 -1
@@ -0,0 +1,136 @@
1
+ import { Component, ViewEncapsulation, ChangeDetectionStrategy, Inject, ViewChild } from '@angular/core';
2
+ import { XImagePreviewPrefix, XImagePreviewProperty } from './image.property';
3
+ import { X_DIALOG_DATA } from '@ng-nest/ui/dialog';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@ng-nest/ui/core";
6
+ import * as i2 from "@angular/common";
7
+ import * as i3 from "@ng-nest/ui/icon";
8
+ import * as i4 from "@ng-nest/ui/dialog";
9
+ import * as i5 from "@angular/cdk/drag-drop";
10
+ export class XImagePreviewComponent extends XImagePreviewProperty {
11
+ constructor(renderer, elementRef, cdr, configService, data) {
12
+ super();
13
+ this.renderer = renderer;
14
+ this.elementRef = elementRef;
15
+ this.cdr = cdr;
16
+ this.configService = configService;
17
+ this.data = data;
18
+ this.imgScale3d = {
19
+ x: 1,
20
+ y: 1,
21
+ z: 1
22
+ };
23
+ this.rotate = 0;
24
+ this.position = {
25
+ x: 0,
26
+ y: 0
27
+ };
28
+ this.total = 1;
29
+ this.current = 1;
30
+ }
31
+ get getWrapperTransform() {
32
+ return `translate3d(${this.position.x}px, ${this.position.y}px, 0)`;
33
+ }
34
+ get getImgTransform() {
35
+ return `scale3d(${this.imgScale3d.x}, ${this.imgScale3d.y}, ${this.imgScale3d.z}) rotate(${this.rotate}deg)`;
36
+ }
37
+ ngOnInit() {
38
+ this.setActivated();
39
+ }
40
+ ngOnChanges() { }
41
+ initialization() {
42
+ this.imgScale3d = {
43
+ x: 1,
44
+ y: 1,
45
+ z: 1
46
+ };
47
+ this.rotate = 0;
48
+ this.position = {
49
+ x: 0,
50
+ y: 0
51
+ };
52
+ }
53
+ setActivated() {
54
+ if (!this.data)
55
+ return;
56
+ if (this.data.length === 1) {
57
+ this.activated = this.data[0];
58
+ this.total = this.current = 1;
59
+ }
60
+ else {
61
+ this.total = this.data.length;
62
+ this.activated = this.data.find((x, index) => {
63
+ if (x.activated) {
64
+ this.current = index + 1;
65
+ return true;
66
+ }
67
+ return false;
68
+ });
69
+ }
70
+ }
71
+ onCurrentChange(num) {
72
+ this.current += num;
73
+ this.activated = this.data[this.current - 1];
74
+ this.initialization();
75
+ }
76
+ onRotate(deg) {
77
+ this.rotate += deg;
78
+ }
79
+ onScale(zoom) {
80
+ this.imgScale3d.x += zoom;
81
+ this.imgScale3d.y += zoom;
82
+ }
83
+ onDragReleased() {
84
+ let width = this.imageRef.nativeElement.offsetWidth * this.imgScale3d.x;
85
+ let height = this.imageRef.nativeElement.offsetHeight * this.imgScale3d.x;
86
+ const clientWidth = document.documentElement.clientWidth;
87
+ const clientHeight = window.innerHeight || document.documentElement.clientHeight;
88
+ const isRotate = this.rotate % 180 !== 0;
89
+ const box = this.imageRef.nativeElement.getBoundingClientRect();
90
+ const docElem = document.documentElement;
91
+ const left = box.left + (window.pageXOffset || docElem.scrollLeft) - (docElem.clientLeft || document.body.clientLeft || 0);
92
+ const top = box.top + (window.pageYOffset || docElem.scrollTop) - (docElem.clientTop || document.body.clientTop || 0);
93
+ width = isRotate ? height : width;
94
+ height = isRotate ? width : height;
95
+ let position = { x: 0, y: 0 };
96
+ if (width > clientWidth || height > clientHeight) {
97
+ const x = this.fitPoint(left, width, clientWidth);
98
+ const y = this.fitPoint(top, height, clientHeight);
99
+ position.x = x ? x : 0;
100
+ position.y = y ? y : 0;
101
+ }
102
+ this.position = { ...this.position, ...position };
103
+ }
104
+ fitPoint(start, size, clientSize) {
105
+ const startAddSize = start + size;
106
+ const offsetStart = (size - clientSize) / 2;
107
+ let distance = null;
108
+ if (size > clientSize) {
109
+ if (start > 0) {
110
+ distance = offsetStart;
111
+ }
112
+ if (start < 0 && startAddSize < clientSize) {
113
+ distance = -offsetStart;
114
+ }
115
+ }
116
+ else {
117
+ if (start < 0 || startAddSize > clientSize) {
118
+ distance = start < 0 ? offsetStart : -offsetStart;
119
+ }
120
+ }
121
+ return distance;
122
+ }
123
+ }
124
+ /** @nocollapse */ XImagePreviewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XImagePreviewComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.XConfigService }, { token: X_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
125
+ /** @nocollapse */ XImagePreviewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: XImagePreviewComponent, selector: "x-image-preview", viewQueries: [{ propertyName: "imageRef", first: true, predicate: ["imageRef"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"x-image-preview\" [ngClass]=\"classMap\">\r\n <div class=\"x-image-preview-header\">\r\n <div class=\"x-image-preview-header-left\">\r\n <span class=\"x-image-preview-current\" *ngIf=\"total != 1\">{{ current }} / {{ total }}</span>\r\n </div>\r\n <div class=\"x-image-preview-header-center\">\r\n <x-icon type=\"fto-corner-up-left\" (click)=\"onRotate(-90)\"></x-icon>\r\n <x-icon type=\"fto-corner-up-right\" (click)=\"onRotate(90)\"></x-icon>\r\n <x-icon type=\"fto-zoom-out\" [class.x-image-preview-disabled]=\"imgScale3d.x === 1\" (click)=\"imgScale3d.x > 1 && onScale(-1)\"></x-icon>\r\n <x-icon type=\"fto-zoom-in\" (click)=\"onScale(1)\"></x-icon>\r\n </div>\r\n <div class=\"x-image-preview-header-right\">\r\n <x-icon type=\"fto-x\" x-dialog-close></x-icon>\r\n </div>\r\n </div>\r\n <div\r\n class=\"x-image-preview-wrapper\"\r\n cdkDrag\r\n [style.transform]=\"getWrapperTransform\"\r\n [cdkDragFreeDragPosition]=\"position\"\r\n (cdkDragReleased)=\"onDragReleased()\"\r\n >\r\n <img #imageRef [src]=\"activated?.src\" [attr.alt]=\"activated?.alt\" cdkDragHandle [style.transform]=\"getImgTransform\" />\r\n </div>\r\n <div\r\n *ngIf=\"data && data.length > 1\"\r\n [class.x-image-preview-disabled]=\"current === 1\"\r\n class=\"x-image-preview-left\"\r\n (click)=\"current > 1 && onCurrentChange(-1)\"\r\n >\r\n <x-icon type=\"fto-chevron-left\"></x-icon>\r\n </div>\r\n <div\r\n *ngIf=\"data && data.length > 1\"\r\n [class.x-image-preview-disabled]=\"current === total\"\r\n class=\"x-image-preview-right\"\r\n (click)=\"current != total && onCurrentChange(1)\"\r\n >\r\n <x-icon type=\"fto-chevron-right\"></x-icon>\r\n </div>\r\n</div>\r\n", styles: ["x-image-preview{display:block;width:100%;height:100%}.x-image-preview{margin:0;padding:0;width:100%;height:100%}.x-image-preview-header{display:flex;align-items:center;justify-content:center;background-color:#0003;color:#fff;position:absolute;width:100%;z-index:1;height:2.75rem}.x-image-preview-header x-icon{font-size:1.25rem;padding:.75rem;cursor:pointer;transition:background-color var(--x-animation-duration-base)}.x-image-preview-header x-icon:hover:not(.x-image-preview-disabled){background-color:#0000001a}.x-image-preview-header x-icon.x-image-preview-disabled{color:#ffffff80;cursor:default}.x-image-preview-header-center{position:absolute}.x-image-preview-header-right{position:absolute;right:0}.x-image-preview-header-left{position:absolute;left:0}.x-image-preview-current{padding:.75rem}.x-image-preview-wrapper{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;transition:transform var(--x-animation-duration-base) ease-out 0s}.x-image-preview-wrapper>img{max-width:100%;max-height:100%;vertical-align:middle;cursor:grab;transition:transform var(--x-animation-duration-base) ease-out 0s}.x-image-preview-left,.x-image-preview-right{position:absolute;top:50%;z-index:1;display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;margin-top:-1.375rem;color:#fff;background-color:#0003;border-radius:50%;transition:background-color var(--x-animation-duration-base);cursor:pointer;font-size:1.25rem}.x-image-preview-left:hover:not(.x-image-preview-disabled),.x-image-preview-right:hover:not(.x-image-preview-disabled){background-color:#0000001a}.x-image-preview-left.x-image-preview-disabled,.x-image-preview-right.x-image-preview-disabled{color:#ffffff80;cursor:default}.x-image-preview-left{left:1rem}.x-image-preview-right{right:1rem}.x-image-preview-portal .x-dialog-portal{background:transparent;box-shadow:none;padding:0}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.XIconComponent, selector: "x-icon" }, { kind: "directive", type: i4.XDialogCloseDirective, selector: "[x-dialog-close]" }, { kind: "directive", type: i5.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i5.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
126
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XImagePreviewComponent, decorators: [{
127
+ type: Component,
128
+ args: [{ selector: `${XImagePreviewPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"x-image-preview\" [ngClass]=\"classMap\">\r\n <div class=\"x-image-preview-header\">\r\n <div class=\"x-image-preview-header-left\">\r\n <span class=\"x-image-preview-current\" *ngIf=\"total != 1\">{{ current }} / {{ total }}</span>\r\n </div>\r\n <div class=\"x-image-preview-header-center\">\r\n <x-icon type=\"fto-corner-up-left\" (click)=\"onRotate(-90)\"></x-icon>\r\n <x-icon type=\"fto-corner-up-right\" (click)=\"onRotate(90)\"></x-icon>\r\n <x-icon type=\"fto-zoom-out\" [class.x-image-preview-disabled]=\"imgScale3d.x === 1\" (click)=\"imgScale3d.x > 1 && onScale(-1)\"></x-icon>\r\n <x-icon type=\"fto-zoom-in\" (click)=\"onScale(1)\"></x-icon>\r\n </div>\r\n <div class=\"x-image-preview-header-right\">\r\n <x-icon type=\"fto-x\" x-dialog-close></x-icon>\r\n </div>\r\n </div>\r\n <div\r\n class=\"x-image-preview-wrapper\"\r\n cdkDrag\r\n [style.transform]=\"getWrapperTransform\"\r\n [cdkDragFreeDragPosition]=\"position\"\r\n (cdkDragReleased)=\"onDragReleased()\"\r\n >\r\n <img #imageRef [src]=\"activated?.src\" [attr.alt]=\"activated?.alt\" cdkDragHandle [style.transform]=\"getImgTransform\" />\r\n </div>\r\n <div\r\n *ngIf=\"data && data.length > 1\"\r\n [class.x-image-preview-disabled]=\"current === 1\"\r\n class=\"x-image-preview-left\"\r\n (click)=\"current > 1 && onCurrentChange(-1)\"\r\n >\r\n <x-icon type=\"fto-chevron-left\"></x-icon>\r\n </div>\r\n <div\r\n *ngIf=\"data && data.length > 1\"\r\n [class.x-image-preview-disabled]=\"current === total\"\r\n class=\"x-image-preview-right\"\r\n (click)=\"current != total && onCurrentChange(1)\"\r\n >\r\n <x-icon type=\"fto-chevron-right\"></x-icon>\r\n </div>\r\n</div>\r\n", styles: ["x-image-preview{display:block;width:100%;height:100%}.x-image-preview{margin:0;padding:0;width:100%;height:100%}.x-image-preview-header{display:flex;align-items:center;justify-content:center;background-color:#0003;color:#fff;position:absolute;width:100%;z-index:1;height:2.75rem}.x-image-preview-header x-icon{font-size:1.25rem;padding:.75rem;cursor:pointer;transition:background-color var(--x-animation-duration-base)}.x-image-preview-header x-icon:hover:not(.x-image-preview-disabled){background-color:#0000001a}.x-image-preview-header x-icon.x-image-preview-disabled{color:#ffffff80;cursor:default}.x-image-preview-header-center{position:absolute}.x-image-preview-header-right{position:absolute;right:0}.x-image-preview-header-left{position:absolute;left:0}.x-image-preview-current{padding:.75rem}.x-image-preview-wrapper{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;transition:transform var(--x-animation-duration-base) ease-out 0s}.x-image-preview-wrapper>img{max-width:100%;max-height:100%;vertical-align:middle;cursor:grab;transition:transform var(--x-animation-duration-base) ease-out 0s}.x-image-preview-left,.x-image-preview-right{position:absolute;top:50%;z-index:1;display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;margin-top:-1.375rem;color:#fff;background-color:#0003;border-radius:50%;transition:background-color var(--x-animation-duration-base);cursor:pointer;font-size:1.25rem}.x-image-preview-left:hover:not(.x-image-preview-disabled),.x-image-preview-right:hover:not(.x-image-preview-disabled){background-color:#0000001a}.x-image-preview-left.x-image-preview-disabled,.x-image-preview-right.x-image-preview-disabled{color:#ffffff80;cursor:default}.x-image-preview-left{left:1rem}.x-image-preview-right{right:1rem}.x-image-preview-portal .x-dialog-portal{background:transparent;box-shadow:none;padding:0}\n"] }]
129
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.XConfigService }, { type: undefined, decorators: [{
130
+ type: Inject,
131
+ args: [X_DIALOG_DATA]
132
+ }] }]; }, propDecorators: { imageRef: [{
133
+ type: ViewChild,
134
+ args: ['imageRef']
135
+ }] } });
136
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-preview.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/image/image-preview.component.ts","../../../../../lib/ng-nest/ui/image/image-preview.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  OnChanges,\r\n  Inject,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { XImageNode, XImagePreviewPrefix, XImagePreviewProperty } from './image.property';\r\nimport { XConfigService } from '@ng-nest/ui/core';\r\nimport { X_DIALOG_DATA } from '@ng-nest/ui/dialog';\r\n\r\n@Component({\r\n  selector: `${XImagePreviewPrefix}`,\r\n  templateUrl: './image-preview.component.html',\r\n  styleUrls: ['./image-preview.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XImagePreviewComponent extends XImagePreviewProperty implements OnChanges {\r\n  imgScale3d = {\r\n    x: 1,\r\n    y: 1,\r\n    z: 1\r\n  };\r\n  rotate = 0;\r\n\r\n  position = {\r\n    x: 0,\r\n    y: 0\r\n  };\r\n\r\n  activated?: XImageNode;\r\n  total = 1;\r\n  current = 1;\r\n\r\n  get getWrapperTransform() {\r\n    return `translate3d(${this.position.x}px, ${this.position.y}px, 0)`;\r\n  }\r\n  get getImgTransform() {\r\n    return `scale3d(${this.imgScale3d.x}, ${this.imgScale3d.y}, ${this.imgScale3d.z}) rotate(${this.rotate}deg)`;\r\n  }\r\n\r\n  @ViewChild('imageRef') imageRef!: ElementRef<HTMLImageElement>;\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public cdr: ChangeDetectorRef,\r\n    public configService: XConfigService,\r\n    @Inject(X_DIALOG_DATA) public data: XImageNode[]\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setActivated();\r\n  }\r\n\r\n  ngOnChanges() {}\r\n\r\n  initialization() {\r\n    this.imgScale3d = {\r\n      x: 1,\r\n      y: 1,\r\n      z: 1\r\n    };\r\n    this.rotate = 0;\r\n    this.position = {\r\n      x: 0,\r\n      y: 0\r\n    };\r\n  }\r\n\r\n  setActivated() {\r\n    if (!this.data) return;\r\n    if (this.data.length === 1) {\r\n      this.activated = this.data[0];\r\n      this.total = this.current = 1;\r\n    } else {\r\n      this.total = this.data.length;\r\n      this.activated = this.data.find((x, index) => {\r\n        if (x.activated) {\r\n          this.current = index + 1;\r\n          return true;\r\n        }\r\n        return false;\r\n      });\r\n    }\r\n  }\r\n\r\n  onCurrentChange(num: number) {\r\n    this.current += num;\r\n    this.activated = this.data[this.current - 1];\r\n    this.initialization();\r\n  }\r\n\r\n  onRotate(deg: number) {\r\n    this.rotate += deg;\r\n  }\r\n\r\n  onScale(zoom: number) {\r\n    this.imgScale3d.x += zoom;\r\n    this.imgScale3d.y += zoom;\r\n  }\r\n\r\n  onDragReleased() {\r\n    let width = this.imageRef.nativeElement.offsetWidth * this.imgScale3d.x;\r\n    let height = this.imageRef.nativeElement.offsetHeight * this.imgScale3d.x;\r\n    const clientWidth = document.documentElement.clientWidth;\r\n    const clientHeight = window.innerHeight || document.documentElement.clientHeight;\r\n    const isRotate = this.rotate % 180 !== 0;\r\n    const box = this.imageRef.nativeElement.getBoundingClientRect();\r\n    const docElem = document.documentElement;\r\n    const left = box.left + (window.pageXOffset || docElem.scrollLeft) - (docElem.clientLeft || document.body.clientLeft || 0);\r\n    const top = box.top + (window.pageYOffset || docElem.scrollTop) - (docElem.clientTop || document.body.clientTop || 0);\r\n    width = isRotate ? height : width;\r\n    height = isRotate ? width : height;\r\n\r\n    let position = { x: 0, y: 0 };\r\n    if (width > clientWidth || height > clientHeight) {\r\n      const x = this.fitPoint(left, width, clientWidth);\r\n      const y = this.fitPoint(top, height, clientHeight);\r\n      position.x = x ? x : 0;\r\n      position.y = y ? y : 0;\r\n    }\r\n\r\n    this.position = { ...this.position, ...position };\r\n  }\r\n\r\n  fitPoint(start: number, size: number, clientSize: number): number | null {\r\n    const startAddSize = start + size;\r\n    const offsetStart = (size - clientSize) / 2;\r\n    let distance: number | null = null;\r\n\r\n    if (size > clientSize) {\r\n      if (start > 0) {\r\n        distance = offsetStart;\r\n      }\r\n      if (start < 0 && startAddSize < clientSize) {\r\n        distance = -offsetStart;\r\n      }\r\n    } else {\r\n      if (start < 0 || startAddSize > clientSize) {\r\n        distance = start < 0 ? offsetStart : -offsetStart;\r\n      }\r\n    }\r\n\r\n    return distance;\r\n  }\r\n}\r\n","<div class=\"x-image-preview\" [ngClass]=\"classMap\">\r\n  <div class=\"x-image-preview-header\">\r\n    <div class=\"x-image-preview-header-left\">\r\n      <span class=\"x-image-preview-current\" *ngIf=\"total != 1\">{{ current }} / {{ total }}</span>\r\n    </div>\r\n    <div class=\"x-image-preview-header-center\">\r\n      <x-icon type=\"fto-corner-up-left\" (click)=\"onRotate(-90)\"></x-icon>\r\n      <x-icon type=\"fto-corner-up-right\" (click)=\"onRotate(90)\"></x-icon>\r\n      <x-icon type=\"fto-zoom-out\" [class.x-image-preview-disabled]=\"imgScale3d.x === 1\" (click)=\"imgScale3d.x > 1 && onScale(-1)\"></x-icon>\r\n      <x-icon type=\"fto-zoom-in\" (click)=\"onScale(1)\"></x-icon>\r\n    </div>\r\n    <div class=\"x-image-preview-header-right\">\r\n      <x-icon type=\"fto-x\" x-dialog-close></x-icon>\r\n    </div>\r\n  </div>\r\n  <div\r\n    class=\"x-image-preview-wrapper\"\r\n    cdkDrag\r\n    [style.transform]=\"getWrapperTransform\"\r\n    [cdkDragFreeDragPosition]=\"position\"\r\n    (cdkDragReleased)=\"onDragReleased()\"\r\n  >\r\n    <img #imageRef [src]=\"activated?.src\" [attr.alt]=\"activated?.alt\" cdkDragHandle [style.transform]=\"getImgTransform\" />\r\n  </div>\r\n  <div\r\n    *ngIf=\"data && data.length > 1\"\r\n    [class.x-image-preview-disabled]=\"current === 1\"\r\n    class=\"x-image-preview-left\"\r\n    (click)=\"current > 1 && onCurrentChange(-1)\"\r\n  >\r\n    <x-icon type=\"fto-chevron-left\"></x-icon>\r\n  </div>\r\n  <div\r\n    *ngIf=\"data && data.length > 1\"\r\n    [class.x-image-preview-disabled]=\"current === total\"\r\n    class=\"x-image-preview-right\"\r\n    (click)=\"current != total && onCurrentChange(1)\"\r\n  >\r\n    <x-icon type=\"fto-chevron-right\"></x-icon>\r\n  </div>\r\n</div>\r\n"]}
@@ -0,0 +1,81 @@
1
+ import { Component, ViewEncapsulation, ChangeDetectionStrategy, Optional } from '@angular/core';
2
+ import { XImagePrefix, XImageProperty } from './image.property';
3
+ import { XIsChange } from '@ng-nest/ui/core';
4
+ import { XImagePreviewComponent } from './image-preview.component';
5
+ import { map, Subject } from 'rxjs';
6
+ import { takeUntil } from 'rxjs/operators';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@ng-nest/ui/core";
9
+ import * as i2 from "@ng-nest/ui/dialog";
10
+ import * as i3 from "@ng-nest/ui/i18n";
11
+ import * as i4 from "./image-group.component";
12
+ import * as i5 from "@angular/common";
13
+ import * as i6 from "@ng-nest/ui/icon";
14
+ export class XImageComponent extends XImageProperty {
15
+ constructor(renderer, elementRef, cdr, configService, dialog, i18n, group) {
16
+ super();
17
+ this.renderer = renderer;
18
+ this.elementRef = elementRef;
19
+ this.cdr = cdr;
20
+ this.configService = configService;
21
+ this.dialog = dialog;
22
+ this.i18n = i18n;
23
+ this.group = group;
24
+ this.locale = {};
25
+ this.isError = false;
26
+ this.isLoaded = false;
27
+ this._unSubject = new Subject();
28
+ }
29
+ get getPreviewText() {
30
+ return this.previewText || this.locale.previewText;
31
+ }
32
+ ngOnInit() {
33
+ if (this.group) {
34
+ this.group.addImage(this);
35
+ }
36
+ this.i18n.localeChange
37
+ .pipe(map((x) => x.image), takeUntil(this._unSubject))
38
+ .subscribe((x) => {
39
+ this.locale = x;
40
+ this.cdr.markForCheck();
41
+ });
42
+ }
43
+ ngOnChanges(changes) {
44
+ let { src } = changes;
45
+ if (XIsChange(src)) {
46
+ this.isLoaded = false;
47
+ }
48
+ }
49
+ onPreview() {
50
+ let data = [];
51
+ if (this.group) {
52
+ const activatedIndex = this.group.images.indexOf(this);
53
+ data = this.group.images.map((x, index) => ({ src: x.src, alt: x.alt, fallback: x.fallback, activated: index === activatedIndex }));
54
+ }
55
+ else {
56
+ data = [{ src: this.src, alt: this.alt, fallback: this.fallback }];
57
+ }
58
+ this.dialog.create(XImagePreviewComponent, {
59
+ width: '100%',
60
+ height: '100%',
61
+ className: 'x-image-preview-portal',
62
+ data: data
63
+ });
64
+ }
65
+ onError() {
66
+ this.src = this.fallback;
67
+ this.isError = true;
68
+ }
69
+ onLoad() {
70
+ this.isLoaded = true;
71
+ }
72
+ }
73
+ /** @nocollapse */ XImageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XImageComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.XConfigService }, { token: i2.XDialogService }, { token: i3.XI18nService }, { token: i4.XImageGroupComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component });
74
+ /** @nocollapse */ XImageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: XImageComponent, selector: "x-image", usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"x-image\" [ngClass]=\"classMap\">\r\n <img\r\n [hidden]=\"placeholder && !isLoaded\"\r\n class=\"x-image-img\"\r\n [src]=\"src\"\r\n [style.width]=\"width\"\r\n [style.height]=\"height\"\r\n (error)=\"onError()\"\r\n (load)=\"onLoad()\"\r\n />\r\n <img *ngIf=\"placeholder && !isLoaded\" class=\"x-image-img\" [src]=\"placeholder\" [style.width]=\"width\" [style.height]=\"height\" />\r\n <div class=\"x-image-overlay\" *ngIf=\"!isError\" (click)=\"onPreview()\">\r\n <div class=\"x-image-text\">\r\n <x-icon type=\"fto-eye\"></x-icon>\r\n <span>{{ getPreviewText }}</span>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["x-image{display:inline-block}.x-image{margin:0;padding:0;position:relative;display:inline-block}.x-image-img{width:100%;height:auto;vertical-align:middle}.x-image-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;background:rgba(0,0,0,.5);cursor:pointer;opacity:0;transition:opacity var(--x-animation-duration-base)}.x-image-overlay:hover{opacity:1}.x-image-text>span{margin-left:.25rem}\n"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.XIconComponent, selector: "x-icon" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
75
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XImageComponent, decorators: [{
76
+ type: Component,
77
+ args: [{ selector: `${XImagePrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"x-image\" [ngClass]=\"classMap\">\r\n <img\r\n [hidden]=\"placeholder && !isLoaded\"\r\n class=\"x-image-img\"\r\n [src]=\"src\"\r\n [style.width]=\"width\"\r\n [style.height]=\"height\"\r\n (error)=\"onError()\"\r\n (load)=\"onLoad()\"\r\n />\r\n <img *ngIf=\"placeholder && !isLoaded\" class=\"x-image-img\" [src]=\"placeholder\" [style.width]=\"width\" [style.height]=\"height\" />\r\n <div class=\"x-image-overlay\" *ngIf=\"!isError\" (click)=\"onPreview()\">\r\n <div class=\"x-image-text\">\r\n <x-icon type=\"fto-eye\"></x-icon>\r\n <span>{{ getPreviewText }}</span>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["x-image{display:inline-block}.x-image{margin:0;padding:0;position:relative;display:inline-block}.x-image-img{width:100%;height:auto;vertical-align:middle}.x-image-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;background:rgba(0,0,0,.5);cursor:pointer;opacity:0;transition:opacity var(--x-animation-duration-base)}.x-image-overlay:hover{opacity:1}.x-image-text>span{margin-left:.25rem}\n"] }]
78
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.XConfigService }, { type: i2.XDialogService }, { type: i3.XI18nService }, { type: i4.XImageGroupComponent, decorators: [{
79
+ type: Optional
80
+ }] }]; } });
81
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/image/image.component.ts","../../../../../lib/ng-nest/ui/image/image.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  OnInit,\r\n  Optional,\r\n  OnChanges,\r\n  SimpleChanges\r\n} from '@angular/core';\r\nimport { XImageNode, XImagePrefix, XImageProperty } from './image.property';\r\nimport { XConfigService, XIsChange } from '@ng-nest/ui/core';\r\nimport { XDialogService } from '@ng-nest/ui/dialog';\r\nimport { XImagePreviewComponent } from './image-preview.component';\r\nimport { XI18nImage, XI18nService } from '@ng-nest/ui/i18n';\r\nimport { map, Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { XImageGroupComponent } from './image-group.component';\r\n\r\n@Component({\r\n  selector: `${XImagePrefix}`,\r\n  templateUrl: './image.component.html',\r\n  styleUrls: ['./image.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XImageComponent extends XImageProperty implements OnInit, OnChanges {\r\n  locale: XI18nImage = {};\r\n  isError = false;\r\n  isLoaded = false;\r\n  private _unSubject = new Subject<void>();\r\n\r\n  get getPreviewText() {\r\n    return this.previewText || this.locale.previewText;\r\n  }\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public cdr: ChangeDetectorRef,\r\n    public configService: XConfigService,\r\n    public dialog: XDialogService,\r\n    public i18n: XI18nService,\r\n    @Optional() public group: XImageGroupComponent\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.group) {\r\n      this.group.addImage(this);\r\n    }\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.image as XI18nImage),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        this.cdr.markForCheck();\r\n      });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    let { src } = changes;\r\n    if (XIsChange(src)) {\r\n      this.isLoaded = false;\r\n    }\r\n  }\r\n\r\n  onPreview() {\r\n    let data: XImageNode[] = [];\r\n    if (this.group) {\r\n      const activatedIndex = this.group.images.indexOf(this);\r\n      data = this.group.images.map((x, index) => ({ src: x.src, alt: x.alt, fallback: x.fallback, activated: index === activatedIndex }));\r\n    } else {\r\n      data = [{ src: this.src, alt: this.alt, fallback: this.fallback }];\r\n    }\r\n    this.dialog.create(XImagePreviewComponent, {\r\n      width: '100%',\r\n      height: '100%',\r\n      className: 'x-image-preview-portal',\r\n      data: data\r\n    });\r\n  }\r\n\r\n  onError() {\r\n    this.src = this.fallback;\r\n    this.isError = true;\r\n  }\r\n\r\n  onLoad() {\r\n    this.isLoaded = true;\r\n  }\r\n}\r\n","<div class=\"x-image\" [ngClass]=\"classMap\">\r\n  <img\r\n    [hidden]=\"placeholder && !isLoaded\"\r\n    class=\"x-image-img\"\r\n    [src]=\"src\"\r\n    [style.width]=\"width\"\r\n    [style.height]=\"height\"\r\n    (error)=\"onError()\"\r\n    (load)=\"onLoad()\"\r\n  />\r\n  <img *ngIf=\"placeholder && !isLoaded\" class=\"x-image-img\" [src]=\"placeholder\" [style.width]=\"width\" [style.height]=\"height\" />\r\n  <div class=\"x-image-overlay\" *ngIf=\"!isError\" (click)=\"onPreview()\">\r\n    <div class=\"x-image-text\">\r\n      <x-icon type=\"fto-eye\"></x-icon>\r\n      <span>{{ getPreviewText }}</span>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
@@ -0,0 +1,26 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { XImageComponent } from './image.component';
4
+ import { XIconModule } from '@ng-nest/ui/icon';
5
+ import { XImagePreviewProperty, XImageProperty } from './image.property';
6
+ import { XDialogModule } from '@ng-nest/ui/dialog';
7
+ import { XImagePreviewComponent } from './image-preview.component';
8
+ import { XButtonModule } from '@ng-nest/ui/button';
9
+ import { DragDropModule } from '@angular/cdk/drag-drop';
10
+ import { XI18nModule } from '@ng-nest/ui/i18n';
11
+ import { XImageGroupComponent } from './image-group.component';
12
+ import * as i0 from "@angular/core";
13
+ export class XImageModule {
14
+ }
15
+ /** @nocollapse */ XImageModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XImageModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
16
+ /** @nocollapse */ XImageModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: XImageModule, declarations: [XImageComponent, XImageProperty, XImagePreviewComponent, XImagePreviewProperty, XImageGroupComponent], imports: [CommonModule, XIconModule, XDialogModule, XButtonModule, XI18nModule, DragDropModule], exports: [XImageComponent, XImagePreviewComponent, XImageGroupComponent] });
17
+ /** @nocollapse */ XImageModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XImageModule, imports: [CommonModule, XIconModule, XDialogModule, XButtonModule, XI18nModule, DragDropModule] });
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XImageModule, decorators: [{
19
+ type: NgModule,
20
+ args: [{
21
+ declarations: [XImageComponent, XImageProperty, XImagePreviewComponent, XImagePreviewProperty, XImageGroupComponent],
22
+ exports: [XImageComponent, XImagePreviewComponent, XImageGroupComponent],
23
+ imports: [CommonModule, XIconModule, XDialogModule, XButtonModule, XI18nModule, DragDropModule]
24
+ }]
25
+ }] });
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGliL25nLW5lc3QvdWkvaW1hZ2UvaW1hZ2UubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHFCQUFxQixFQUFFLGNBQWMsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ3pFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNuRCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbkQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3hELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7QUFPL0QsTUFBTSxPQUFPLFlBQVk7OzRIQUFaLFlBQVk7NkhBQVosWUFBWSxpQkFKUixlQUFlLEVBQUUsY0FBYyxFQUFFLHNCQUFzQixFQUFFLHFCQUFxQixFQUFFLG9CQUFvQixhQUV6RyxZQUFZLEVBQUUsV0FBVyxFQUFFLGFBQWEsRUFBRSxhQUFhLEVBQUUsV0FBVyxFQUFFLGNBQWMsYUFEcEYsZUFBZSxFQUFFLHNCQUFzQixFQUFFLG9CQUFvQjs2SEFHNUQsWUFBWSxZQUZiLFlBQVksRUFBRSxXQUFXLEVBQUUsYUFBYSxFQUFFLGFBQWEsRUFBRSxXQUFXLEVBQUUsY0FBYzsyRkFFbkYsWUFBWTtrQkFMeEIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxlQUFlLEVBQUUsY0FBYyxFQUFFLHNCQUFzQixFQUFFLHFCQUFxQixFQUFFLG9CQUFvQixDQUFDO29CQUNwSCxPQUFPLEVBQUUsQ0FBQyxlQUFlLEVBQUUsc0JBQXNCLEVBQUUsb0JBQW9CLENBQUM7b0JBQ3hFLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxXQUFXLEVBQUUsYUFBYSxFQUFFLGFBQWEsRUFBRSxXQUFXLEVBQUUsY0FBYyxDQUFDO2lCQUNoRyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IFhJbWFnZUNvbXBvbmVudCB9IGZyb20gJy4vaW1hZ2UuY29tcG9uZW50JztcclxuaW1wb3J0IHsgWEljb25Nb2R1bGUgfSBmcm9tICdAbmctbmVzdC91aS9pY29uJztcclxuaW1wb3J0IHsgWEltYWdlUHJldmlld1Byb3BlcnR5LCBYSW1hZ2VQcm9wZXJ0eSB9IGZyb20gJy4vaW1hZ2UucHJvcGVydHknO1xyXG5pbXBvcnQgeyBYRGlhbG9nTW9kdWxlIH0gZnJvbSAnQG5nLW5lc3QvdWkvZGlhbG9nJztcclxuaW1wb3J0IHsgWEltYWdlUHJldmlld0NvbXBvbmVudCB9IGZyb20gJy4vaW1hZ2UtcHJldmlldy5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBYQnV0dG9uTW9kdWxlIH0gZnJvbSAnQG5nLW5lc3QvdWkvYnV0dG9uJztcclxuaW1wb3J0IHsgRHJhZ0Ryb3BNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvZHJhZy1kcm9wJztcclxuaW1wb3J0IHsgWEkxOG5Nb2R1bGUgfSBmcm9tICdAbmctbmVzdC91aS9pMThuJztcclxuaW1wb3J0IHsgWEltYWdlR3JvdXBDb21wb25lbnQgfSBmcm9tICcuL2ltYWdlLWdyb3VwLmNvbXBvbmVudCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1hJbWFnZUNvbXBvbmVudCwgWEltYWdlUHJvcGVydHksIFhJbWFnZVByZXZpZXdDb21wb25lbnQsIFhJbWFnZVByZXZpZXdQcm9wZXJ0eSwgWEltYWdlR3JvdXBDb21wb25lbnRdLFxyXG4gIGV4cG9ydHM6IFtYSW1hZ2VDb21wb25lbnQsIFhJbWFnZVByZXZpZXdDb21wb25lbnQsIFhJbWFnZUdyb3VwQ29tcG9uZW50XSxcclxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBYSWNvbk1vZHVsZSwgWERpYWxvZ01vZHVsZSwgWEJ1dHRvbk1vZHVsZSwgWEkxOG5Nb2R1bGUsIERyYWdEcm9wTW9kdWxlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgWEltYWdlTW9kdWxlIHt9XHJcbiJdfQ==
@@ -0,0 +1,63 @@
1
+ import { __decorate } from "tslib";
2
+ import { Input, Component } from '@angular/core';
3
+ import { XProperty, XWithConfig } from '@ng-nest/ui/core';
4
+ import * as i0 from "@angular/core";
5
+ /**
6
+ * Image
7
+ * @selector x-image
8
+ * @decorator component
9
+ */
10
+ export const XImagePrefix = 'x-image';
11
+ const X_CONFIG_NAME = 'image';
12
+ /**
13
+ * Image Property
14
+ */
15
+ export class XImageProperty extends XProperty {
16
+ }
17
+ /** @nocollapse */ XImageProperty.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XImageProperty, deps: null, target: i0.ɵɵFactoryTarget.Component });
18
+ /** @nocollapse */ XImageProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: XImageProperty, selector: "ng-component", inputs: { src: "src", width: "width", height: "height", alt: "alt", fallback: "fallback", previewText: "previewText", placeholder: "placeholder" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
19
+ __decorate([
20
+ XWithConfig(X_CONFIG_NAME)
21
+ ], XImageProperty.prototype, "previewText", void 0);
22
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XImageProperty, decorators: [{
23
+ type: Component,
24
+ args: [{ template: '' }]
25
+ }], propDecorators: { src: [{
26
+ type: Input
27
+ }], width: [{
28
+ type: Input
29
+ }], height: [{
30
+ type: Input
31
+ }], alt: [{
32
+ type: Input
33
+ }], fallback: [{
34
+ type: Input
35
+ }], previewText: [{
36
+ type: Input
37
+ }], placeholder: [{
38
+ type: Input
39
+ }] } });
40
+ /**
41
+ * Image Preview
42
+ * @selector x-image-preview
43
+ * @decorator component
44
+ */
45
+ export const XImagePreviewPrefix = 'x-image-preview';
46
+ /**
47
+ * Image Preview Property
48
+ */
49
+ export class XImagePreviewProperty extends XProperty {
50
+ }
51
+ /** @nocollapse */ XImagePreviewProperty.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XImagePreviewProperty, deps: null, target: i0.ɵɵFactoryTarget.Component });
52
+ /** @nocollapse */ XImagePreviewProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: XImagePreviewProperty, selector: "ng-component", usesInheritance: true, ngImport: i0, template: '', isInline: true });
53
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: XImagePreviewProperty, decorators: [{
54
+ type: Component,
55
+ args: [{ template: '' }]
56
+ }] });
57
+ /**
58
+ * Image Group
59
+ * @selector x-image-group
60
+ * @decorator component
61
+ */
62
+ export const XImageGroupPrefix = 'x-image-group';
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UucHJvcGVydHkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWIvbmctbmVzdC91aS9pbWFnZS9pbWFnZS5wcm9wZXJ0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFFMUQ7Ozs7R0FJRztBQUNILE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxTQUFTLENBQUM7QUFDdEMsTUFBTSxhQUFhLEdBQUcsT0FBTyxDQUFDO0FBRTlCOztHQUVHO0FBRUgsTUFBTSxPQUFPLGNBQWUsU0FBUSxTQUFTOzs4SEFBaEMsY0FBYztrSEFBZCxjQUFjLCtOQURKLEVBQUU7QUFnQ3NCO0lBQW5DLFdBQVcsQ0FBUyxhQUFhLENBQUM7bURBQXNCOzJGQS9CdkQsY0FBYztrQkFEMUIsU0FBUzttQkFBQyxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUU7OEJBTWhCLEdBQUc7c0JBQVgsS0FBSztnQkFLRyxLQUFLO3NCQUFiLEtBQUs7Z0JBS0csTUFBTTtzQkFBZCxLQUFLO2dCQUtHLEdBQUc7c0JBQVgsS0FBSztnQkFLRyxRQUFRO3NCQUFoQixLQUFLO2dCQU11QyxXQUFXO3NCQUF2RCxLQUFLO2dCQUtHLFdBQVc7c0JBQW5CLEtBQUs7O0FBOEJSOzs7O0dBSUc7QUFDSCxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxpQkFBaUIsQ0FBQztBQUVyRDs7R0FFRztBQUVILE1BQU0sT0FBTyxxQkFBc0IsU0FBUSxTQUFTOztxSUFBdkMscUJBQXFCO3lIQUFyQixxQkFBcUIsMkVBRFgsRUFBRTsyRkFDWixxQkFBcUI7a0JBRGpDLFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFOztBQUczQjs7OztHQUlHO0FBQ0gsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5wdXQsIENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBYUHJvcGVydHksIFhXaXRoQ29uZmlnIH0gZnJvbSAnQG5nLW5lc3QvdWkvY29yZSc7XHJcblxyXG4vKipcclxuICogSW1hZ2VcclxuICogQHNlbGVjdG9yIHgtaW1hZ2VcclxuICogQGRlY29yYXRvciBjb21wb25lbnRcclxuICovXHJcbmV4cG9ydCBjb25zdCBYSW1hZ2VQcmVmaXggPSAneC1pbWFnZSc7XHJcbmNvbnN0IFhfQ09ORklHX05BTUUgPSAnaW1hZ2UnO1xyXG5cclxuLyoqXHJcbiAqIEltYWdlIFByb3BlcnR5XHJcbiAqL1xyXG5AQ29tcG9uZW50KHsgdGVtcGxhdGU6ICcnIH0pXHJcbmV4cG9ydCBjbGFzcyBYSW1hZ2VQcm9wZXJ0eSBleHRlbmRzIFhQcm9wZXJ0eSB7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOWbvueJh+aYvuekuuWcsOWdgFxyXG4gICAqIEBlbl9VUyBQaWN0dXJlIGRpc3BsYXkgYWRkcmVzc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHNyYyE6IHN0cmluZztcclxuICAvKipcclxuICAgKiBAemhfQ04g5Zu+54mH5a695bqmXHJcbiAgICogQGVuX1VTIFBpY3R1cmUgd2lkdGhcclxuICAgKi9cclxuICBASW5wdXQoKSB3aWR0aCE6IHN0cmluZztcclxuICAvKipcclxuICAgKiBAemhfQ04g5Zu+54mH6auY5bqmXHJcbiAgICogQGVuX1VTIFBpY3R1cmUgaGVpZ2h0XHJcbiAgICovXHJcbiAgQElucHV0KCkgaGVpZ2h0ITogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDlm77lg4/mj4/ov7BcclxuICAgKiBAZW5fVVMgSW1hZ2UgZGVzY3JpcHRpb25cclxuICAgKi9cclxuICBASW5wdXQoKSBhbHQhOiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOWKoOi9veWksei0peaYvuekuueahOWcsOWdgFxyXG4gICAqIEBlbl9VUyBMb2FkIGZhdWx0IHRvbGVyYW5jZSBhZGRyZXNzXHJcbiAgICovXHJcbiAgQElucHV0KCkgZmFsbGJhY2shOiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOmihOiniOaWh+Wtl1xyXG4gICAqIEBlbl9VUyBQcmV2aWV3IHRleHRcclxuICAgKiBAZGVmYXVsdCAn6aKE6KeIJ1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpIEBYV2l0aENvbmZpZzxzdHJpbmc+KFhfQ09ORklHX05BTUUpIHByZXZpZXdUZXh0Pzogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDmuJDov5vliqDovb3mmL7npLrnmoTlm77niYdcclxuICAgKiBAZW5fVVMgR3JhZHVhbGx5IGxvYWRlZCB0aGUgZGlzcGxheSBvZiB0aGUgZGlzcGxheVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHBsYWNlaG9sZGVyPzogc3RyaW5nO1xyXG59XHJcblxyXG4vKipcclxuICogQHpoX0NOIOWbvueJh+iKgueCueaVsOaNrlxyXG4gKiBAZW5fVVMgSW1hZ2Ugbm9kZSBkYXRhXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFhJbWFnZU5vZGUge1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDlm77niYfmmL7npLrlnLDlnYBcclxuICAgKiBAZW5fVVMgUGljdHVyZSBkaXNwbGF5IGFkZHJlc3NcclxuICAgKi9cclxuICBzcmM/OiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOWbvuWDj+aPj+i/sFxyXG4gICAqIEBlbl9VUyBJbWFnZSBkZXNjcmlwdGlvblxyXG4gICAqL1xyXG4gIGFsdD86IHN0cmluZztcclxuICAvKipcclxuICAgKiBAemhfQ04g5Yqg6L295aSx6LSl5pi+56S655qE5Zyw5Z2AXHJcbiAgICogQGVuX1VTIExvYWQgZmF1bHQgdG9sZXJhbmNlIGFkZHJlc3NcclxuICAgKi9cclxuICBmYWxsYmFjaz86IHN0cmluZztcclxuICAvKipcclxuICAgKiBAemhfQ04g5b2T5YmN5r+A5rS755qE5Zu+54mHXHJcbiAgICogQGVuX1VTIEN1cnJlbnQgYWN0aXZhdGVkIHBpY3R1cmVzXHJcbiAgICovXHJcbiAgYWN0aXZhdGVkPzogYm9vbGVhbjtcclxufVxyXG5cclxuLyoqXHJcbiAqIEltYWdlIFByZXZpZXdcclxuICogQHNlbGVjdG9yIHgtaW1hZ2UtcHJldmlld1xyXG4gKiBAZGVjb3JhdG9yIGNvbXBvbmVudFxyXG4gKi9cclxuZXhwb3J0IGNvbnN0IFhJbWFnZVByZXZpZXdQcmVmaXggPSAneC1pbWFnZS1wcmV2aWV3JztcclxuXHJcbi8qKlxyXG4gKiBJbWFnZSBQcmV2aWV3IFByb3BlcnR5XHJcbiAqL1xyXG5AQ29tcG9uZW50KHsgdGVtcGxhdGU6ICcnIH0pXHJcbmV4cG9ydCBjbGFzcyBYSW1hZ2VQcmV2aWV3UHJvcGVydHkgZXh0ZW5kcyBYUHJvcGVydHkge31cclxuXHJcbi8qKlxyXG4gKiBJbWFnZSBHcm91cFxyXG4gKiBAc2VsZWN0b3IgeC1pbWFnZS1ncm91cFxyXG4gKiBAZGVjb3JhdG9yIGNvbXBvbmVudFxyXG4gKi9cclxuZXhwb3J0IGNvbnN0IFhJbWFnZUdyb3VwUHJlZml4ID0gJ3gtaW1hZ2UtZ3JvdXAnO1xyXG4iXX0=
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctbmVzdC11aS1pbWFnZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL2ltYWdlL25nLW5lc3QtdWktaW1hZ2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
@@ -0,0 +1,6 @@
1
+ export * from './image.component';
2
+ export * from './image-preview.component';
3
+ export * from './image-group.component';
4
+ export * from './image.module';
5
+ export * from './image.property';
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL2ltYWdlL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGtCQUFrQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9pbWFnZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2ltYWdlLXByZXZpZXcuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9pbWFnZS1ncm91cC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2ltYWdlLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vaW1hZ2UucHJvcGVydHknO1xyXG4iXX0=
package/esm2020/index.mjs CHANGED
@@ -27,6 +27,7 @@ export * from '@ng-nest/ui/calendar';
27
27
  export * from '@ng-nest/ui/comment';
28
28
  export * from '@ng-nest/ui/description';
29
29
  export * from '@ng-nest/ui/empty';
30
+ export * from '@ng-nest/ui/image';
30
31
  export * from '@ng-nest/ui/outlet';
31
32
  export * from '@ng-nest/ui/pagination';
32
33
  export * from '@ng-nest/ui/progress';
@@ -101,4 +102,4 @@ export * from '@ng-nest/ui/pattern';
101
102
  export * from '@ng-nest/ui/slider';
102
103
  export * from '@ng-nest/ui/highlight';
103
104
  export * from '@ng-nest/ui/inner';
104
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWIvbmctbmVzdC91aS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILGNBQWMsa0JBQWtCLENBQUM7QUFFakM7O0dBRUc7QUFDSCxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHdCQUF3QixDQUFDO0FBRXZDOztHQUVHO0FBQ0gsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLHVCQUF1QixDQUFDO0FBRXRDOztHQUVHO0FBQ0gsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMscUJBQXFCLENBQUM7QUFFcEM7O0dBRUc7QUFDSCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsb0JBQW9CLENBQUM7QUFFbkM7O0dBRUc7QUFDSCxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxrQkFBa0IsQ0FBQztBQUVqQzs7R0FFRztBQUNILGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsbUJBQW1CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogQ29yZVxyXG4gKi9cclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvY29yZSc7XHJcblxyXG4vKipcclxuICogQmFzaWNcclxuICovXHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2JvcmRlcic7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2J1dHRvbic7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2NvbG9yJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvY29udGFpbmVyJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvbGF5b3V0JztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvaWNvbic7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2kxOG4nO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9saW5rJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvdGhlbWUnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS90eXBvZ3JhcGh5JztcclxuXHJcbi8qKlxyXG4gKiBEYXRhXHJcbiAqL1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9hdmF0YXInO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9iYWRnZSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2NhcmQnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9jYXJvdXNlbCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2NvbGxhcHNlJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvY2FsZW5kYXInO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9jb21tZW50JztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvZGVzY3JpcHRpb24nO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9lbXB0eSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL291dGxldCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3BhZ2luYXRpb24nO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9wcm9ncmVzcyc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3JpcHBsZSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3Jlc2l6YWJsZSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3N0YXRpc3RpYyc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3RhYmxlJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvdGFnJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvdGV4dC1yZXRyYWN0JztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvdGltZS1hZ28nO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS90aW1lLXJhbmdlJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvdGltZWxpbmUnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS90cmVlJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvdHJlZS1maWxlJztcclxuXHJcbi8qKlxyXG4gKiBGZWVkYmFja1xyXG4gKi9cclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvYWxlcnQnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9kaWFsb2cnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9kcmF3ZXInO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9sb2FkaW5nJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvbWVzc2FnZSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL21lc3NhZ2UtYm94JztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvbm90aWZpY2F0aW9uJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvcG9wY29uZmlybSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3BvcG92ZXInO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9yZXN1bHQnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9za2VsZXRvbic7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3Rvb2x0aXAnO1xyXG5cclxuLyoqXHJcbiAqIEZvcm1cclxuICovXHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2F1dG8tY29tcGxldGUnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9iYXNlLWZvcm0nO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9jYXNjYWRlJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvY2hlY2tib3gnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9jb2xvci1waWNrZXInO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9kYXRlLXBpY2tlcic7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2Zvcm0nO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9maW5kJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvaW5wdXQnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9pbnB1dC1udW1iZXInO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9saXN0JztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvcmFkaW8nO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9yYXRlJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvc2VsZWN0JztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvc2xpZGVyLXNlbGVjdCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3N3aXRjaCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3RpbWUtcGlja2VyJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvdHJhbnNmZXInO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS90ZXh0YXJlYSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3VwbG9hZCc7XHJcblxyXG4vKipcclxuICogTmF2aWdhdGlvblxyXG4gKi9cclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvYWZmaXgnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9hbmNob3InO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9iYWNrLXRvcCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2NydW1iJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvZHJvcGRvd24nO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9tZW51JztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvcGFnZS1oZWFkZXInO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9zdGVwcyc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3RhYnMnO1xyXG5cclxuLyoqXHJcbiAqIE90aGVyc1xyXG4gKi9cclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvZG9jJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvZXhhbXBsZXMnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9hcGknO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9wYXR0ZXJuJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvc2xpZGVyJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvaGlnaGxpZ2h0JztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvaW5uZXInO1xyXG4iXX0=
105
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWIvbmctbmVzdC91aS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILGNBQWMsa0JBQWtCLENBQUM7QUFFakM7O0dBRUc7QUFDSCxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHdCQUF3QixDQUFDO0FBRXZDOztHQUVHO0FBQ0gsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsdUJBQXVCLENBQUM7QUFFdEM7O0dBRUc7QUFDSCxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxxQkFBcUIsQ0FBQztBQUVwQzs7R0FFRztBQUNILGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxvQkFBb0IsQ0FBQztBQUVuQzs7R0FFRztBQUNILGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGtCQUFrQixDQUFDO0FBRWpDOztHQUVHO0FBQ0gsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxtQkFBbUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBDb3JlXHJcbiAqL1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9jb3JlJztcclxuXHJcbi8qKlxyXG4gKiBCYXNpY1xyXG4gKi9cclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvYm9yZGVyJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvYnV0dG9uJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvY29sb3InO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9jb250YWluZXInO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9sYXlvdXQnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9pY29uJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvaTE4bic7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2xpbmsnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS90aGVtZSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3R5cG9ncmFwaHknO1xyXG5cclxuLyoqXHJcbiAqIERhdGFcclxuICovXHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2F2YXRhcic7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2JhZGdlJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvY2FyZCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2Nhcm91c2VsJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvY29sbGFwc2UnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9jYWxlbmRhcic7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2NvbW1lbnQnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9kZXNjcmlwdGlvbic7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2VtcHR5JztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvaW1hZ2UnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9vdXRsZXQnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9wYWdpbmF0aW9uJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvcHJvZ3Jlc3MnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9yaXBwbGUnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9yZXNpemFibGUnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9zdGF0aXN0aWMnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS90YWJsZSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3RhZyc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3RleHQtcmV0cmFjdCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3RpbWUtYWdvJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvdGltZS1yYW5nZSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3RpbWVsaW5lJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvdHJlZSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3RyZWUtZmlsZSc7XHJcblxyXG4vKipcclxuICogRmVlZGJhY2tcclxuICovXHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2FsZXJ0JztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvZGlhbG9nJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvZHJhd2VyJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvbG9hZGluZyc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL21lc3NhZ2UnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9tZXNzYWdlLWJveCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL25vdGlmaWNhdGlvbic7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3BvcGNvbmZpcm0nO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9wb3BvdmVyJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvcmVzdWx0JztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvc2tlbGV0b24nO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS90b29sdGlwJztcclxuXHJcbi8qKlxyXG4gKiBGb3JtXHJcbiAqL1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9hdXRvLWNvbXBsZXRlJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvYmFzZS1mb3JtJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvY2FzY2FkZSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2NoZWNrYm94JztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvY29sb3ItcGlja2VyJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvZGF0ZS1waWNrZXInO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9mb3JtJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvZmluZCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2lucHV0JztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvaW5wdXQtbnVtYmVyJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvbGlzdCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3JhZGlvJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvcmF0ZSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3NlbGVjdCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3NsaWRlci1zZWxlY3QnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9zd2l0Y2gnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS90aW1lLXBpY2tlcic7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3RyYW5zZmVyJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvdGV4dGFyZWEnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS91cGxvYWQnO1xyXG5cclxuLyoqXHJcbiAqIE5hdmlnYXRpb25cclxuICovXHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2FmZml4JztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvYW5jaG9yJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvYmFjay10b3AnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS9jcnVtYic7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2Ryb3Bkb3duJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvbWVudSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3BhZ2UtaGVhZGVyJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvc3RlcHMnO1xyXG5leHBvcnQgKiBmcm9tICdAbmctbmVzdC91aS90YWJzJztcclxuXHJcbi8qKlxyXG4gKiBPdGhlcnNcclxuICovXHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2RvYyc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2V4YW1wbGVzJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvYXBpJztcclxuZXhwb3J0ICogZnJvbSAnQG5nLW5lc3QvdWkvcGF0dGVybic7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL3NsaWRlcic7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2hpZ2hsaWdodCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BuZy1uZXN0L3VpL2lubmVyJztcclxuIl19