@smartbit4all/ng-client 4.2.114 → 4.2.116

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 (161) hide show
  1. package/esm2022/lib/smart-client/smart-component-api-client.mjs +34 -2
  2. package/esm2022/lib/smart-component-layout/api/api/api.mjs +1 -1
  3. package/esm2022/lib/smart-component-layout/api/api/default.service.mjs +1 -1
  4. package/esm2022/lib/smart-component-layout/api/api.module.mjs +1 -1
  5. package/esm2022/lib/smart-component-layout/api/configuration.mjs +1 -1
  6. package/esm2022/lib/smart-component-layout/api/encoder.mjs +1 -1
  7. package/esm2022/lib/smart-component-layout/api/index.mjs +1 -1
  8. package/esm2022/lib/smart-component-layout/api/model/componentType.mjs +1 -1
  9. package/esm2022/lib/smart-component-layout/api/model/layoutDirection.mjs +1 -1
  10. package/esm2022/lib/smart-component-layout/api/model/smartComponentWidgetDefinition.mjs +1 -1
  11. package/esm2022/lib/smart-component-layout/api/param.mjs +1 -1
  12. package/esm2022/lib/smart-component-layout/api/variables.mjs +1 -1
  13. package/esm2022/lib/smart-form/api/api/api.mjs +1 -1
  14. package/esm2022/lib/smart-form/api/api/default.service.mjs +1 -1
  15. package/esm2022/lib/smart-form/api/api.module.mjs +1 -1
  16. package/esm2022/lib/smart-form/api/configuration.mjs +1 -1
  17. package/esm2022/lib/smart-form/api/encoder.mjs +1 -1
  18. package/esm2022/lib/smart-form/api/index.mjs +1 -1
  19. package/esm2022/lib/smart-form/api/model/fileUploaderProperties.mjs +2 -0
  20. package/esm2022/lib/smart-form/api/model/imageProperties.mjs +1 -1
  21. package/esm2022/lib/smart-form/api/model/models.mjs +2 -1
  22. package/esm2022/lib/smart-form/api/model/propertyMapping.mjs +1 -1
  23. package/esm2022/lib/smart-form/api/model/selectionDefinition.mjs +1 -1
  24. package/esm2022/lib/smart-form/api/model/smartFormInputMode.mjs +1 -1
  25. package/esm2022/lib/smart-form/api/model/smartFormWidgetDirection.mjs +1 -1
  26. package/esm2022/lib/smart-form/api/model/smartFormWidgetType.mjs +1 -1
  27. package/esm2022/lib/smart-form/api/model/smartLayoutDefinition.mjs +1 -1
  28. package/esm2022/lib/smart-form/api/model/smartMatrixModel.mjs +1 -1
  29. package/esm2022/lib/smart-form/api/model/smartWidgetDefinition.mjs +1 -1
  30. package/esm2022/lib/smart-form/api/model/smartWidgetHint.mjs +1 -1
  31. package/esm2022/lib/smart-form/api/model/sortDefinition.mjs +1 -1
  32. package/esm2022/lib/smart-form/api/model/textFieldProperties.mjs +1 -1
  33. package/esm2022/lib/smart-form/api/model/valueChangeMode.mjs +1 -1
  34. package/esm2022/lib/smart-form/api/param.mjs +1 -1
  35. package/esm2022/lib/smart-form/api/variables.mjs +1 -1
  36. package/esm2022/lib/smart-form/services/smartform.layout-definition.service.mjs +2 -5
  37. package/esm2022/lib/smart-form/smartfileuploader/smartfileuploader.component.mjs +129 -29
  38. package/esm2022/lib/smart-form/smartform.form-model.mjs +1 -1
  39. package/esm2022/lib/smart-form/widgets/smartformwidget/smartformwidget.component.mjs +18 -13
  40. package/esm2022/lib/smart-map/api/api/api.mjs +1 -1
  41. package/esm2022/lib/smart-map/api/api/geoMap.service.mjs +1 -1
  42. package/esm2022/lib/smart-map/api/api.module.mjs +1 -1
  43. package/esm2022/lib/smart-map/api/configuration.mjs +1 -1
  44. package/esm2022/lib/smart-map/api/encoder.mjs +1 -1
  45. package/esm2022/lib/smart-map/api/index.mjs +1 -1
  46. package/esm2022/lib/smart-map/api/model/gPSPosition.mjs +1 -1
  47. package/esm2022/lib/smart-map/api/model/gPSRoute.mjs +1 -1
  48. package/esm2022/lib/smart-map/api/model/geoMapChange.mjs +1 -1
  49. package/esm2022/lib/smart-map/api/model/geoMapDataLoadingMode.mjs +1 -1
  50. package/esm2022/lib/smart-map/api/model/geoMapDataSourceDescriptor.mjs +1 -1
  51. package/esm2022/lib/smart-map/api/model/geoMapDataSourceType.mjs +1 -1
  52. package/esm2022/lib/smart-map/api/model/geoMapEditingSession.mjs +1 -1
  53. package/esm2022/lib/smart-map/api/model/geoMapInteraction.mjs +1 -1
  54. package/esm2022/lib/smart-map/api/model/geoMapItem.mjs +1 -1
  55. package/esm2022/lib/smart-map/api/model/geoMapItemKind.mjs +1 -1
  56. package/esm2022/lib/smart-map/api/model/geoMapLayer.mjs +1 -1
  57. package/esm2022/lib/smart-map/api/model/geoMapLayerChange.mjs +1 -1
  58. package/esm2022/lib/smart-map/api/model/geoMapLayerDescriptor.mjs +1 -1
  59. package/esm2022/lib/smart-map/api/model/geoMapModel.mjs +1 -1
  60. package/esm2022/lib/smart-map/api/model/geoMapOperationMode.mjs +1 -1
  61. package/esm2022/lib/smart-map/api/model/geoMapSelectionMode.mjs +1 -1
  62. package/esm2022/lib/smart-map/api/model/geoMapServerModel.mjs +1 -1
  63. package/esm2022/lib/smart-map/api/model/geoMapTextType.mjs +1 -1
  64. package/esm2022/lib/smart-map/api/model/geoMapViewState.mjs +1 -1
  65. package/esm2022/lib/smart-map/api/model/geoMapViewport.mjs +1 -1
  66. package/esm2022/lib/smart-map/api/model/models.mjs +1 -1
  67. package/esm2022/lib/smart-map/api/param.mjs +1 -1
  68. package/esm2022/lib/smart-map/api/variables.mjs +1 -1
  69. package/esm2022/lib/view-context/api/api/api.mjs +1 -1
  70. package/esm2022/lib/view-context/api/api/view.service.mjs +1 -1
  71. package/esm2022/lib/view-context/api/api.module.mjs +1 -1
  72. package/esm2022/lib/view-context/api/configuration.mjs +1 -1
  73. package/esm2022/lib/view-context/api/encoder.mjs +1 -1
  74. package/esm2022/lib/view-context/api/index.mjs +1 -1
  75. package/esm2022/lib/view-context/api/model/backgroundProcessInfo.mjs +1 -1
  76. package/esm2022/lib/view-context/api/model/badgeDescriptor.mjs +1 -1
  77. package/esm2022/lib/view-context/api/model/clipboardData.mjs +1 -1
  78. package/esm2022/lib/view-context/api/model/closeResult.mjs +1 -1
  79. package/esm2022/lib/view-context/api/model/componentConstraint.mjs +1 -1
  80. package/esm2022/lib/view-context/api/model/componentModel.mjs +1 -1
  81. package/esm2022/lib/view-context/api/model/componentModelChange.mjs +1 -1
  82. package/esm2022/lib/view-context/api/model/dataChange.mjs +1 -1
  83. package/esm2022/lib/view-context/api/model/dataChangeEvent.mjs +1 -1
  84. package/esm2022/lib/view-context/api/model/dataChangeKind.mjs +1 -1
  85. package/esm2022/lib/view-context/api/model/deviceInfo.mjs +1 -1
  86. package/esm2022/lib/view-context/api/model/downloadedFile.mjs +1 -1
  87. package/esm2022/lib/view-context/api/model/iconPosition.mjs +1 -1
  88. package/esm2022/lib/view-context/api/model/imageResource.mjs +1 -1
  89. package/esm2022/lib/view-context/api/model/link.mjs +1 -1
  90. package/esm2022/lib/view-context/api/model/messageData.mjs +1 -1
  91. package/esm2022/lib/view-context/api/model/messageOption.mjs +1 -1
  92. package/esm2022/lib/view-context/api/model/messageOptionType.mjs +1 -1
  93. package/esm2022/lib/view-context/api/model/messageResult.mjs +1 -1
  94. package/esm2022/lib/view-context/api/model/messageTextType.mjs +1 -1
  95. package/esm2022/lib/view-context/api/model/messageType.mjs +1 -1
  96. package/esm2022/lib/view-context/api/model/models.mjs +1 -1
  97. package/esm2022/lib/view-context/api/model/multiComboBoxElement.mjs +1 -1
  98. package/esm2022/lib/view-context/api/model/multiComboBoxModel.mjs +1 -1
  99. package/esm2022/lib/view-context/api/model/namedValidator.mjs +1 -1
  100. package/esm2022/lib/view-context/api/model/openPendingData.mjs +1 -1
  101. package/esm2022/lib/view-context/api/model/serverRequestExecutionStat.mjs +1 -1
  102. package/esm2022/lib/view-context/api/model/serverRequestTrack.mjs +1 -1
  103. package/esm2022/lib/view-context/api/model/serverRequestType.mjs +1 -1
  104. package/esm2022/lib/view-context/api/model/smartLinkData.mjs +1 -1
  105. package/esm2022/lib/view-context/api/model/smartLinkMigrationStatus.mjs +1 -1
  106. package/esm2022/lib/view-context/api/model/statisticRecord.mjs +1 -1
  107. package/esm2022/lib/view-context/api/model/style.mjs +1 -1
  108. package/esm2022/lib/view-context/api/model/uiAction.mjs +1 -1
  109. package/esm2022/lib/view-context/api/model/uiActionButtonDescriptor.mjs +1 -1
  110. package/esm2022/lib/view-context/api/model/uiActionButtonType.mjs +1 -1
  111. package/esm2022/lib/view-context/api/model/uiActionConstraint.mjs +1 -1
  112. package/esm2022/lib/view-context/api/model/uiActionDescriptor.mjs +1 -1
  113. package/esm2022/lib/view-context/api/model/uiActionDialogDescriptor.mjs +1 -1
  114. package/esm2022/lib/view-context/api/model/uiActionFeedbackType.mjs +1 -1
  115. package/esm2022/lib/view-context/api/model/uiActionInputType.mjs +1 -1
  116. package/esm2022/lib/view-context/api/model/uiActionRequest.mjs +1 -1
  117. package/esm2022/lib/view-context/api/model/uiActionTooltip.mjs +1 -1
  118. package/esm2022/lib/view-context/api/model/uiActionUploadDescriptor.mjs +1 -1
  119. package/esm2022/lib/view-context/api/model/uploadWidgetType.mjs +1 -1
  120. package/esm2022/lib/view-context/api/model/uploadedFile.mjs +1 -1
  121. package/esm2022/lib/view-context/api/model/valueSet.mjs +1 -1
  122. package/esm2022/lib/view-context/api/model/view.mjs +1 -1
  123. package/esm2022/lib/view-context/api/model/viewApiError.mjs +1 -1
  124. package/esm2022/lib/view-context/api/model/viewConstraint.mjs +1 -1
  125. package/esm2022/lib/view-context/api/model/viewContext.mjs +1 -1
  126. package/esm2022/lib/view-context/api/model/viewContextChange.mjs +1 -1
  127. package/esm2022/lib/view-context/api/model/viewContextData.mjs +1 -1
  128. package/esm2022/lib/view-context/api/model/viewContextUpdate.mjs +1 -1
  129. package/esm2022/lib/view-context/api/model/viewData.mjs +1 -1
  130. package/esm2022/lib/view-context/api/model/viewEventHandler.mjs +1 -1
  131. package/esm2022/lib/view-context/api/model/viewPlaceholder.mjs +1 -1
  132. package/esm2022/lib/view-context/api/model/viewState.mjs +1 -1
  133. package/esm2022/lib/view-context/api/model/viewStateUpdate.mjs +1 -1
  134. package/esm2022/lib/view-context/api/model/viewType.mjs +1 -1
  135. package/esm2022/lib/view-context/api/param.mjs +1 -1
  136. package/esm2022/lib/view-context/api/variables.mjs +1 -1
  137. package/esm2022/lib/view-context/projects.mjs +4 -3
  138. package/esm2022/lib/view-context/smart-ui-action/components/upload-widget/photo-capture-widget/photo-capture-widget.component.mjs +198 -0
  139. package/esm2022/lib/view-context/smart-ui-action/components/upload-widget/upload-widget.component.mjs +118 -0
  140. package/esm2022/lib/view-context/smart-ui-action/components/upload-widget/voice-record-widget/voice-record-widget.component.mjs +186 -0
  141. package/esm2022/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.component.mjs +15 -104
  142. package/esm2022/lib/view-context/smart-view-context.module.mjs +18 -13
  143. package/fesm2022/smartbit4all-ng-client.mjs +1180 -1023
  144. package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
  145. package/lib/smart-client/smart-component-api-client.d.ts +2 -0
  146. package/lib/smart-form/api/model/fileUploaderProperties.d.ts +17 -0
  147. package/lib/smart-form/api/model/models.d.ts +1 -0
  148. package/lib/smart-form/smartfileuploader/smartfileuploader.component.d.ts +15 -2
  149. package/lib/smart-form/smartform.form-model.d.ts +2 -2
  150. package/lib/smart-form/widgets/smartformwidget/smartformwidget.component.d.ts +10 -2
  151. package/lib/view-context/projects.d.ts +3 -2
  152. package/lib/view-context/smart-ui-action/components/upload-widget/upload-widget.component.d.ts +38 -0
  153. package/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.component.d.ts +2 -19
  154. package/lib/view-context/smart-view-context.module.d.ts +50 -49
  155. package/package.json +1 -1
  156. package/smartbit4all-ng-client-4.2.116.tgz +0 -0
  157. package/esm2022/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/photo-capture-widget/photo-capture-widget.component.mjs +0 -198
  158. package/esm2022/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/voice-record-widget/voice-record-widget.component.mjs +0 -186
  159. package/smartbit4all-ng-client-4.2.114.tgz +0 -0
  160. /package/lib/view-context/smart-ui-action/{dialogs/ui-action-file-upload-dialog → components/upload-widget}/photo-capture-widget/photo-capture-widget.component.d.ts +0 -0
  161. /package/lib/view-context/smart-ui-action/{dialogs/ui-action-file-upload-dialog → components/upload-widget}/voice-record-widget/voice-record-widget.component.d.ts +0 -0
@@ -1,11 +1,13 @@
1
1
  import { Component, Input, ViewChild } from '@angular/core';
2
- import { LargeFileSnackBarComponent } from './large-file-snack-bar/large-file-snack-bar.component';
2
+ import { IconPosition, UiActionButtonType, } from '../../view-context/api/model/models';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/material/snack-bar";
5
5
  import * as i2 from "@angular/common";
6
6
  import * as i3 from "@angular/material/button";
7
7
  import * as i4 from "@angular/material/icon";
8
- import * as i5 from "@angular/material/form-field";
8
+ import * as i5 from "../../smart-icon/smart-icon/smart-icon.component";
9
+ import * as i6 from "@angular/material/form-field";
10
+ import * as i7 from "../../view-context/smart-ui-action/ui-action-button/ui-action-button.component";
9
11
  export class SmartfileuploaderComponent {
10
12
  constructor(_snackBar) {
11
13
  this._snackBar = _snackBar;
@@ -14,51 +16,149 @@ export class SmartfileuploaderComponent {
14
16
  this.maxSizeMb = 25;
15
17
  this.useIconButton = true;
16
18
  this.isMultiple = true;
19
+ this.isDragOver = false;
20
+ this.errors = [];
17
21
  }
18
22
  ngOnInit() {
19
- if (!this.i18n || this.i18n === undefined) {
20
- this.i18n = {
21
- addFile: 'dokumentum hozzáadása',
22
- browseOrDrag: 'tallózás vagy behúzás',
23
- maxSize: 'max. 25 MB',
24
- formats: 'PDF, docx, xls formátum',
25
- upload: 'Feltöltés',
26
- };
23
+ const defaultI18n = {
24
+ addFile: 'dokumentum hozzáadása',
25
+ browseOrDrag: 'tallózás vagy behúzás',
26
+ maxSize: `max. ${this.maxSizeMb} MB`,
27
+ formats: 'PDF, docx, xls formátum',
28
+ upload: 'Feltöltés',
29
+ };
30
+ this.i18n = { ...defaultI18n, ...this.i18n };
31
+ }
32
+ processFiles(fileList) {
33
+ this.errors = [];
34
+ var validFiles = [];
35
+ fileList.forEach((file) => {
36
+ let hasError = false;
37
+ if (this.fileFormats?.length) {
38
+ var ext = file.name.split('.').pop()?.toLowerCase();
39
+ var trimmedFormats = (this.fileFormats || [])
40
+ .flatMap((f) => f.split(','))
41
+ .map((f) => f.replace('.', '').trim().toLowerCase());
42
+ var isAllowed = trimmedFormats.includes(ext);
43
+ if (!isAllowed) {
44
+ this.errors.push(`"${file.name}" - nem támogatott formátum`);
45
+ hasError = true;
46
+ }
47
+ }
48
+ if (file.size > this.maxSizeMb * 1000000) {
49
+ this.errors.push(`"${file.name}" - túl nagy fájl (max ${this.maxSizeMb} MB)`);
50
+ hasError = true;
51
+ }
52
+ if (!hasError) {
53
+ validFiles.push(file);
54
+ }
55
+ });
56
+ if (this.isMultiple) {
57
+ this.files = [...this.files, ...validFiles];
58
+ }
59
+ else if (validFiles.length) {
60
+ this.files = [validFiles[0]];
27
61
  }
28
62
  }
29
63
  getFile(event) {
30
64
  if (event.target.files && event.target.files.length) {
31
- let fileList = [...event.target.files];
32
- fileList.forEach((file) => {
33
- if (file.size > this.maxSizeMb * 1000000) {
34
- this._snackBar.openFromComponent(LargeFileSnackBarComponent, {
35
- duration: 5 * 1000,
36
- });
37
- }
38
- else {
39
- if (this.isMultiple) {
40
- this.files = [...this.files, file];
41
- }
42
- else {
43
- this.files = [file];
44
- }
45
- }
46
- });
65
+ var fileList = Array.from(event.target.files);
66
+ this.processFiles(fileList);
47
67
  this.fileInput.nativeElement.value = '';
48
68
  }
49
69
  }
70
+ onDrop(event) {
71
+ event.preventDefault();
72
+ this.isDragOver = false;
73
+ if (!event.dataTransfer?.files)
74
+ return;
75
+ const fileList = Array.from(event.dataTransfer.files);
76
+ this.processFiles(fileList);
77
+ }
78
+ onDragOver(event) {
79
+ event.preventDefault();
80
+ this.isDragOver = true;
81
+ }
82
+ onDragLeave(event) {
83
+ event.preventDefault();
84
+ const related = event.relatedTarget;
85
+ let stopDrag = false;
86
+ if (!related) {
87
+ stopDrag = true;
88
+ }
89
+ else {
90
+ const parentDrop = related.closest('.container');
91
+ if (related !== event.currentTarget && !parentDrop) {
92
+ stopDrag = true;
93
+ }
94
+ }
95
+ if (stopDrag) {
96
+ this.isDragOver = false;
97
+ }
98
+ }
50
99
  remove(index) {
51
100
  this.files.splice(index, 1);
52
101
  }
53
102
  uploadFile() {
54
103
  this.uploadCallback(this.files);
55
104
  }
105
+ formatSize(bytes) {
106
+ if (bytes === 0)
107
+ return '0 B';
108
+ const k = 1024;
109
+ const sizes = ['B', 'KB', 'MB', 'GB', 'TB'];
110
+ const i = Math.floor(Math.log(bytes) / Math.log(k));
111
+ const value = parseFloat((bytes / Math.pow(k, i)).toFixed(1));
112
+ return `${value} ${sizes[i]}`;
113
+ }
114
+ filePreviewUrl(file) {
115
+ if (file.type.startsWith('image/')) {
116
+ return URL.createObjectURL(file);
117
+ }
118
+ return null;
119
+ }
120
+ downloadFile(file) {
121
+ const url = URL.createObjectURL(file);
122
+ const a = document.createElement('a');
123
+ a.href = url;
124
+ a.download = file.name;
125
+ a.click();
126
+ URL.revokeObjectURL(url);
127
+ }
128
+ get uploadButton() {
129
+ return {
130
+ title: this.i18n.upload ?? '',
131
+ color: 'primary',
132
+ type: UiActionButtonType.RAISED,
133
+ icon: 'upload',
134
+ iconPosition: IconPosition.PRE,
135
+ };
136
+ }
137
+ get downloadButton() {
138
+ return {
139
+ title: '',
140
+ color: 'primary',
141
+ type: UiActionButtonType.ICON,
142
+ icon: 'download',
143
+ iconPosition: IconPosition.PRE,
144
+ };
145
+ }
146
+ get removeButton() {
147
+ return {
148
+ title: '',
149
+ color: 'primary',
150
+ type: UiActionButtonType.ICON,
151
+ icon: 'close',
152
+ iconColor: 'red',
153
+ iconPosition: IconPosition.PRE,
154
+ };
155
+ }
56
156
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartfileuploaderComponent, deps: [{ token: i1.MatSnackBar }], target: i0.ɵɵFactoryTarget.Component }); }
57
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SmartfileuploaderComponent, selector: "smartfileuploader", inputs: { uploadCallback: "uploadCallback", fileFormats: "fileFormats", maxSizeMb: "maxSizeMb", i18n: "i18n", useIconButton: "useIconButton", isMultiple: "isMultiple" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], ngImport: i0, template: "<div class=\"container\">\r\n <div class=\"fileContainer\">\r\n <div class=\"fileInnerContainer\">\r\n <input\r\n #fileInput\r\n id=\"addFile\"\r\n placeholder=\"fileInput\"\r\n type=\"file\"\r\n (change)=\"getFile($event)\"\r\n class=\"file\"\r\n accept=\"{{ fileFormats?.join(', ') }}\"\r\n [size]=\"maxSizeMb\"\r\n [multiple]=\"isMultiple\"\r\n />\r\n <div class=\"fileUploadContentContainer\">\r\n <mat-label *ngIf=\"useIconButton\" class=\"addFileButton\">\r\n <mat-icon color=\"primary\" class=\"addCircle\">add_circle</mat-icon>\r\n </mat-label>\r\n <button *ngIf=\"!useIconButton\" mat-raised-button color=\"primary\" class=\"addFileButton\">\r\n {{ i18n!.addFile }}\r\n </button>\r\n <mat-label *ngIf=\"useIconButton\" class=\"label primary\"> {{ i18n!.addFile }} </mat-label>\r\n <mat-label class=\"label secondary\"> {{ i18n!.browseOrDrag }} </mat-label>\r\n <mat-label class=\"subLabel primary\"> {{ i18n!.maxSize }} </mat-label>\r\n <mat-label class=\"subLabel primary\"> {{ i18n!.formats }} </mat-label>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"files.length\" class=\"uploadedFilesContainer\">\r\n <div *ngFor=\"let file of files; let i = index\" class=\"uploadedFile\">\r\n <mat-label class=\"fileNameLabel\"> {{ file.name }} </mat-label>\r\n <button mat-icon-button (click)=\"remove(i)\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n </div>\r\n <button class=\"uploadButton\" mat-raised-button color=\"primary\" (click)=\"uploadFile()\">\r\n {{ i18n!.upload ?? 'Felt\u00F6lt\u00E9s' }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".container{width:calc(100% - 2em);height:max-content;margin:1em;border-radius:5px;border:2px dashed var(--light-gray-60)}.fileContainer,.uploadedFilesContainer{background-color:var(--primary-lighter-color)}.fileInnerContainer{min-height:250px}.uploadedFilesContainer{border-top:1px solid var(--light-gray-60);display:flex;flex-direction:column}.fileContainer{position:relative;height:250px}.uploadedFile{padding:1em;display:flex;flex-direction:row;color:var(--primary-color)}.fileNameLabel{flex:1;margin-top:auto;margin-bottom:auto}.label{font-size:small}.subLabel{font-size:smaller}.file{position:absolute;left:0;top:0;opacity:0;width:100%;height:100%;z-index:120;cursor:pointer}.addFileButton{z-index:150;cursor:pointer}.addCircle{font-size:50px;width:50px;height:50px;margin:0 auto}.fileUploadContentContainer{position:absolute;top:50%;left:0;transform:translateY(-50%);width:100%;display:flex;flex-direction:column;text-align:center}.fileUploadContentContainer .secondary{margin-bottom:1em}.inputLabel{flex:1}.uploadButton{margin-left:auto;margin-right:auto;margin-bottom:.5em}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }] }); }
157
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SmartfileuploaderComponent, selector: "smartfileuploader", inputs: { uploadCallback: "uploadCallback", fileFormats: "fileFormats", maxSizeMb: "maxSizeMb", i18n: "i18n", useIconButton: "useIconButton", isMultiple: "isMultiple" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], ngImport: i0, template: "<div\r\n class=\"container\"\r\n (dragover)=\"onDragOver($event)\"\r\n (dragleave)=\"onDragLeave($event)\"\r\n (drop)=\"onDrop($event)\"\r\n [class.dragover]=\"isDragOver\"\r\n>\r\n <div class=\"fileContainer\" (click)=\"fileInput.click()\">\r\n <input\r\n #fileInput\r\n id=\"addFile\"\r\n placeholder=\"fileInput\"\r\n type=\"file\"\r\n (change)=\"getFile($event)\"\r\n class=\"file\"\r\n accept=\"{{ fileFormats?.join(', ') }}\"\r\n [size]=\"maxSizeMb\"\r\n [multiple]=\"isMultiple\"\r\n style=\"display: none\"\r\n />\r\n <div class=\"fileUploadContentContainer\">\r\n <div class=\"icon\">\r\n <mat-label *ngIf=\"useIconButton\" class=\"addFileButton\">\r\n <mat-icon color=\"primary\" class=\"addCircle\">add_circle</mat-icon>\r\n </mat-label>\r\n <button *ngIf=\"!useIconButton\" mat-raised-button color=\"primary\" class=\"addFileButton\">\r\n {{ i18n!.addFile }}\r\n </button>\r\n </div>\r\n <div class=\"labels\">\r\n <mat-label *ngIf=\"useIconButton\" class=\"label primary title\">\r\n {{ i18n!.addFile }}\r\n </mat-label>\r\n <mat-label class=\"label secondary\"> {{ i18n!.browseOrDrag }} </mat-label>\r\n <mat-label class=\"subLabel primary\"> {{ i18n!.maxSize }} </mat-label>\r\n <mat-label class=\"subLabel primary\"> {{ i18n!.formats }} </mat-label>\r\n </div>\r\n <div class=\"uploadButton\" *ngIf=\"files.length\">\r\n <ui-action-button (actionClick)=\"uploadFile()\" [descriptor]=\"uploadButton\">\r\n </ui-action-button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"errors.length\" class=\"errorMessage\">\r\n <smart-icon [icon]=\"'error'\" [color]=\"'warn'\"></smart-icon>\r\n <div class=\"errors\">\r\n <span *ngFor=\"let error of errors\">{{ error }}</span>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"files.length\" class=\"uploadedFilesContainer\">\r\n <div *ngFor=\"let file of files; let i = index\" class=\"uploadedFile\">\r\n <ng-container *ngIf=\"filePreviewUrl(file); else fileIcon\">\r\n <img [src]=\"filePreviewUrl(file)\" [alt]=\"file.name\" width=\"50\" height=\"50\" />\r\n </ng-container>\r\n <ng-template #fileIcon>\r\n <smart-icon [icon]=\"'insert_drive_file'\"></smart-icon>\r\n </ng-template>\r\n\r\n <div class=\"fileData\">\r\n <div class=\"fileDataContainer\">\r\n <span class=\"fileName\">{{ file.name }}</span>\r\n <span class=\"fileSize\">{{ formatSize(file.size) }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"fileActions\">\r\n <ui-action-button (actionClick)=\"downloadFile(file)\" [descriptor]=\"downloadButton\">\r\n </ui-action-button>\r\n\r\n <ui-action-button class=\"removeIcon\" (actionClick)=\"remove(i)\" [descriptor]=\"removeButton\">\r\n </ui-action-button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [":host{--border-color: #a6aabd60;--warninig-color: #be2d2e;--def-border-radius: .5rem}.container{display:flex;flex-direction:column;border:2px dashed var(--border-color);border-radius:var(--def-border-radius)}.fileContainer{cursor:pointer;padding:1rem;display:flex;flex-direction:column}.fileContainer:hover,.dragover{background-color:rgb(from var(--border-color) r g b / .1)}.fileUploadContentContainer{display:flex;flex-direction:row;gap:1rem}.icon mat-icon{font-size:3rem;width:unset;height:unset}.icon{align-content:center}.labels{flex:1;display:flex;flex-direction:column;justify-content:center;width:fit-content}.uploadButton{align-content:center}.primary{color:var(--primary-color)}.secondary{color:var(--gray)}.label{margin:unset}.subLabel{font-size:smaller}.title{padding-bottom:.3rem}.errorMessage,.uploadedFilesContainer{border-top:2px solid var(--border-color)}.errorMessage{display:flex;flex-direction:row;align-items:center;color:var(--warninig-color);padding:.5rem 1rem;gap:1rem}.errorMessage ::ng-deep mat-icon{color:var(--warninig-color)}.errors{display:flex;flex-direction:column}.uploadedFile{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;padding:1rem;border-bottom:1px solid #e0e0e0;gap:1rem}.uploadedFile:last-child{border-bottom:none}.fileSize{display:flex;flex-direction:row;font-size:smaller}.fileData{flex:1;display:flex;flex-direction:column}.fileDataContainer{display:flex;flex-direction:column;justify-content:flex-end;width:fit-content}.fileActions{display:flex;flex-direction:row;justify-content:flex-end}.fileActions ::ng-deep button{border:unset}.fileActions ::ng-deep button:hover{border:unset}.removeIcon ::ng-deep mat-icon{color:var(--warninig-color)}smart-icon ::ng-deep mat-icon{font-size:3rem;width:unset;height:unset}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color", "imageResource"] }, { kind: "directive", type: i6.MatLabel, selector: "mat-label" }, { kind: "component", type: i7.UiActionButtonComponent, selector: "ui-action-button", inputs: ["disabled", "descriptor", "code", "addedCssClass"], outputs: ["actionClick", "actionDoubleClick"] }] }); }
58
158
  }
59
159
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartfileuploaderComponent, decorators: [{
60
160
  type: Component,
61
- args: [{ selector: 'smartfileuploader', template: "<div class=\"container\">\r\n <div class=\"fileContainer\">\r\n <div class=\"fileInnerContainer\">\r\n <input\r\n #fileInput\r\n id=\"addFile\"\r\n placeholder=\"fileInput\"\r\n type=\"file\"\r\n (change)=\"getFile($event)\"\r\n class=\"file\"\r\n accept=\"{{ fileFormats?.join(', ') }}\"\r\n [size]=\"maxSizeMb\"\r\n [multiple]=\"isMultiple\"\r\n />\r\n <div class=\"fileUploadContentContainer\">\r\n <mat-label *ngIf=\"useIconButton\" class=\"addFileButton\">\r\n <mat-icon color=\"primary\" class=\"addCircle\">add_circle</mat-icon>\r\n </mat-label>\r\n <button *ngIf=\"!useIconButton\" mat-raised-button color=\"primary\" class=\"addFileButton\">\r\n {{ i18n!.addFile }}\r\n </button>\r\n <mat-label *ngIf=\"useIconButton\" class=\"label primary\"> {{ i18n!.addFile }} </mat-label>\r\n <mat-label class=\"label secondary\"> {{ i18n!.browseOrDrag }} </mat-label>\r\n <mat-label class=\"subLabel primary\"> {{ i18n!.maxSize }} </mat-label>\r\n <mat-label class=\"subLabel primary\"> {{ i18n!.formats }} </mat-label>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"files.length\" class=\"uploadedFilesContainer\">\r\n <div *ngFor=\"let file of files; let i = index\" class=\"uploadedFile\">\r\n <mat-label class=\"fileNameLabel\"> {{ file.name }} </mat-label>\r\n <button mat-icon-button (click)=\"remove(i)\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n </div>\r\n <button class=\"uploadButton\" mat-raised-button color=\"primary\" (click)=\"uploadFile()\">\r\n {{ i18n!.upload ?? 'Felt\u00F6lt\u00E9s' }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".container{width:calc(100% - 2em);height:max-content;margin:1em;border-radius:5px;border:2px dashed var(--light-gray-60)}.fileContainer,.uploadedFilesContainer{background-color:var(--primary-lighter-color)}.fileInnerContainer{min-height:250px}.uploadedFilesContainer{border-top:1px solid var(--light-gray-60);display:flex;flex-direction:column}.fileContainer{position:relative;height:250px}.uploadedFile{padding:1em;display:flex;flex-direction:row;color:var(--primary-color)}.fileNameLabel{flex:1;margin-top:auto;margin-bottom:auto}.label{font-size:small}.subLabel{font-size:smaller}.file{position:absolute;left:0;top:0;opacity:0;width:100%;height:100%;z-index:120;cursor:pointer}.addFileButton{z-index:150;cursor:pointer}.addCircle{font-size:50px;width:50px;height:50px;margin:0 auto}.fileUploadContentContainer{position:absolute;top:50%;left:0;transform:translateY(-50%);width:100%;display:flex;flex-direction:column;text-align:center}.fileUploadContentContainer .secondary{margin-bottom:1em}.inputLabel{flex:1}.uploadButton{margin-left:auto;margin-right:auto;margin-bottom:.5em}\n"] }]
161
+ args: [{ selector: 'smartfileuploader', template: "<div\r\n class=\"container\"\r\n (dragover)=\"onDragOver($event)\"\r\n (dragleave)=\"onDragLeave($event)\"\r\n (drop)=\"onDrop($event)\"\r\n [class.dragover]=\"isDragOver\"\r\n>\r\n <div class=\"fileContainer\" (click)=\"fileInput.click()\">\r\n <input\r\n #fileInput\r\n id=\"addFile\"\r\n placeholder=\"fileInput\"\r\n type=\"file\"\r\n (change)=\"getFile($event)\"\r\n class=\"file\"\r\n accept=\"{{ fileFormats?.join(', ') }}\"\r\n [size]=\"maxSizeMb\"\r\n [multiple]=\"isMultiple\"\r\n style=\"display: none\"\r\n />\r\n <div class=\"fileUploadContentContainer\">\r\n <div class=\"icon\">\r\n <mat-label *ngIf=\"useIconButton\" class=\"addFileButton\">\r\n <mat-icon color=\"primary\" class=\"addCircle\">add_circle</mat-icon>\r\n </mat-label>\r\n <button *ngIf=\"!useIconButton\" mat-raised-button color=\"primary\" class=\"addFileButton\">\r\n {{ i18n!.addFile }}\r\n </button>\r\n </div>\r\n <div class=\"labels\">\r\n <mat-label *ngIf=\"useIconButton\" class=\"label primary title\">\r\n {{ i18n!.addFile }}\r\n </mat-label>\r\n <mat-label class=\"label secondary\"> {{ i18n!.browseOrDrag }} </mat-label>\r\n <mat-label class=\"subLabel primary\"> {{ i18n!.maxSize }} </mat-label>\r\n <mat-label class=\"subLabel primary\"> {{ i18n!.formats }} </mat-label>\r\n </div>\r\n <div class=\"uploadButton\" *ngIf=\"files.length\">\r\n <ui-action-button (actionClick)=\"uploadFile()\" [descriptor]=\"uploadButton\">\r\n </ui-action-button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"errors.length\" class=\"errorMessage\">\r\n <smart-icon [icon]=\"'error'\" [color]=\"'warn'\"></smart-icon>\r\n <div class=\"errors\">\r\n <span *ngFor=\"let error of errors\">{{ error }}</span>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"files.length\" class=\"uploadedFilesContainer\">\r\n <div *ngFor=\"let file of files; let i = index\" class=\"uploadedFile\">\r\n <ng-container *ngIf=\"filePreviewUrl(file); else fileIcon\">\r\n <img [src]=\"filePreviewUrl(file)\" [alt]=\"file.name\" width=\"50\" height=\"50\" />\r\n </ng-container>\r\n <ng-template #fileIcon>\r\n <smart-icon [icon]=\"'insert_drive_file'\"></smart-icon>\r\n </ng-template>\r\n\r\n <div class=\"fileData\">\r\n <div class=\"fileDataContainer\">\r\n <span class=\"fileName\">{{ file.name }}</span>\r\n <span class=\"fileSize\">{{ formatSize(file.size) }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"fileActions\">\r\n <ui-action-button (actionClick)=\"downloadFile(file)\" [descriptor]=\"downloadButton\">\r\n </ui-action-button>\r\n\r\n <ui-action-button class=\"removeIcon\" (actionClick)=\"remove(i)\" [descriptor]=\"removeButton\">\r\n </ui-action-button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [":host{--border-color: #a6aabd60;--warninig-color: #be2d2e;--def-border-radius: .5rem}.container{display:flex;flex-direction:column;border:2px dashed var(--border-color);border-radius:var(--def-border-radius)}.fileContainer{cursor:pointer;padding:1rem;display:flex;flex-direction:column}.fileContainer:hover,.dragover{background-color:rgb(from var(--border-color) r g b / .1)}.fileUploadContentContainer{display:flex;flex-direction:row;gap:1rem}.icon mat-icon{font-size:3rem;width:unset;height:unset}.icon{align-content:center}.labels{flex:1;display:flex;flex-direction:column;justify-content:center;width:fit-content}.uploadButton{align-content:center}.primary{color:var(--primary-color)}.secondary{color:var(--gray)}.label{margin:unset}.subLabel{font-size:smaller}.title{padding-bottom:.3rem}.errorMessage,.uploadedFilesContainer{border-top:2px solid var(--border-color)}.errorMessage{display:flex;flex-direction:row;align-items:center;color:var(--warninig-color);padding:.5rem 1rem;gap:1rem}.errorMessage ::ng-deep mat-icon{color:var(--warninig-color)}.errors{display:flex;flex-direction:column}.uploadedFile{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;padding:1rem;border-bottom:1px solid #e0e0e0;gap:1rem}.uploadedFile:last-child{border-bottom:none}.fileSize{display:flex;flex-direction:row;font-size:smaller}.fileData{flex:1;display:flex;flex-direction:column}.fileDataContainer{display:flex;flex-direction:column;justify-content:flex-end;width:fit-content}.fileActions{display:flex;flex-direction:row;justify-content:flex-end}.fileActions ::ng-deep button{border:unset}.fileActions ::ng-deep button:hover{border:unset}.removeIcon ::ng-deep mat-icon{color:var(--warninig-color)}smart-icon ::ng-deep mat-icon{font-size:3rem;width:unset;height:unset}\n"] }]
62
162
  }], ctorParameters: () => [{ type: i1.MatSnackBar }], propDecorators: { fileInput: [{
63
163
  type: ViewChild,
64
164
  args: ['fileInput']
@@ -75,4 +175,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
75
175
  }], isMultiple: [{
76
176
  type: Input
77
177
  }] } });
78
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRmaWxldXBsb2FkZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvc21hcnQtZm9ybS9zbWFydGZpbGV1cGxvYWRlci9zbWFydGZpbGV1cGxvYWRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi9zbWFydC1mb3JtL3NtYXJ0ZmlsZXVwbG9hZGVyL3NtYXJ0ZmlsZXVwbG9hZGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFVLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVoRixPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSx1REFBdUQsQ0FBQzs7Ozs7OztBQVFuRyxNQUFNLE9BQU8sMEJBQTBCO0lBV3JDLFlBQW9CLFNBQXNCO1FBQXRCLGNBQVMsR0FBVCxTQUFTLENBQWE7UUFSMUMsVUFBSyxHQUFVLEVBQUUsQ0FBQztRQUVULGdCQUFXLEdBQWMsRUFBRSxDQUFDO1FBQzVCLGNBQVMsR0FBWSxFQUFFLENBQUM7UUFFeEIsa0JBQWEsR0FBWSxJQUFJLENBQUM7UUFDOUIsZUFBVSxHQUFhLElBQUksQ0FBQztJQUVRLENBQUM7SUFFOUMsUUFBUTtRQUNOLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxJQUFJLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDMUMsSUFBSSxDQUFDLElBQUksR0FBRztnQkFDVixPQUFPLEVBQUUsdUJBQXVCO2dCQUNoQyxZQUFZLEVBQUUsdUJBQXVCO2dCQUNyQyxPQUFPLEVBQUUsWUFBWTtnQkFDckIsT0FBTyxFQUFFLHlCQUF5QjtnQkFDbEMsTUFBTSxFQUFFLFdBQVc7YUFDcEIsQ0FBQztRQUNKLENBQUM7SUFDSCxDQUFDO0lBRUQsT0FBTyxDQUFDLEtBQVU7UUFDaEIsSUFBSSxLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssSUFBSSxLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNwRCxJQUFJLFFBQVEsR0FBVyxDQUFDLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUMvQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBVSxFQUFFLEVBQUU7Z0JBQzlCLElBQUksSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsU0FBVSxHQUFHLE9BQU8sRUFBRSxDQUFDO29CQUMxQyxJQUFJLENBQUMsU0FBUyxDQUFDLGlCQUFpQixDQUFDLDBCQUEwQixFQUFFO3dCQUMzRCxRQUFRLEVBQUUsQ0FBQyxHQUFHLElBQUk7cUJBQ25CLENBQUMsQ0FBQztnQkFDTCxDQUFDO3FCQUFNLENBQUM7b0JBQ04sSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7d0JBQ3BCLElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUM7b0JBQ3JDLENBQUM7eUJBQU0sQ0FBQzt3QkFDTixJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7b0JBQ3RCLENBQUM7Z0JBQ0gsQ0FBQztZQUNILENBQUMsQ0FBQyxDQUFDO1lBQ0gsSUFBSSxDQUFDLFNBQVMsQ0FBQyxhQUFhLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQztRQUMxQyxDQUFDO0lBQ0gsQ0FBQztJQUVELE1BQU0sQ0FBQyxLQUFhO1FBQ2xCLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBRUQsVUFBVTtRQUNSLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2xDLENBQUM7K0dBbkRVLDBCQUEwQjttR0FBMUIsMEJBQTBCLDJVQ1Z2QyxpdURBd0NBOzs0RkQ5QmEsMEJBQTBCO2tCQUx0QyxTQUFTOytCQUNFLG1CQUFtQjtnRkFLTCxTQUFTO3NCQUFoQyxTQUFTO3VCQUFDLFdBQVc7Z0JBR2IsY0FBYztzQkFBdEIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5wdXQsIE9uSW5pdCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdFNuYWNrQmFyIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc25hY2stYmFyJztcclxuaW1wb3J0IHsgTGFyZ2VGaWxlU25hY2tCYXJDb21wb25lbnQgfSBmcm9tICcuL2xhcmdlLWZpbGUtc25hY2stYmFyL2xhcmdlLWZpbGUtc25hY2stYmFyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IFNtYXJ0RmlsZVVwbG9hZGVySTE4biB9IGZyb20gJy4vc21hcnRmaWxldXBsb2FkZXIubW9kZWwnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdzbWFydGZpbGV1cGxvYWRlcicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3NtYXJ0ZmlsZXVwbG9hZGVyLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9zbWFydGZpbGV1cGxvYWRlci5jb21wb25lbnQuY3NzJ10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTbWFydGZpbGV1cGxvYWRlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgQFZpZXdDaGlsZCgnZmlsZUlucHV0JykgZmlsZUlucHV0ITogRWxlbWVudFJlZjxIVE1MSW5wdXRFbGVtZW50PjtcclxuXHJcbiAgZmlsZXM6IGFueVtdID0gW107XHJcbiAgQElucHV0KCkgdXBsb2FkQ2FsbGJhY2shOiAoZmlsZXM6IGFueVtdKSA9PiB2b2lkO1xyXG4gIEBJbnB1dCgpIGZpbGVGb3JtYXRzPzogc3RyaW5nW10gPSBbXTtcclxuICBASW5wdXQoKSBtYXhTaXplTWI/OiBudW1iZXIgPSAyNTtcclxuICBASW5wdXQoKSBpMThuPzogU21hcnRGaWxlVXBsb2FkZXJJMThuO1xyXG4gIEBJbnB1dCgpIHVzZUljb25CdXR0b246IGJvb2xlYW4gPSB0cnVlO1xyXG4gIEBJbnB1dCgpIGlzTXVsdGlwbGU/OiBib29sZWFuID0gdHJ1ZTtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBfc25hY2tCYXI6IE1hdFNuYWNrQmFyKSB7fVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIGlmICghdGhpcy5pMThuIHx8IHRoaXMuaTE4biA9PT0gdW5kZWZpbmVkKSB7XHJcbiAgICAgIHRoaXMuaTE4biA9IHtcclxuICAgICAgICBhZGRGaWxlOiAnZG9rdW1lbnR1bSBob3p6w6FhZMOhc2EnLFxyXG4gICAgICAgIGJyb3dzZU9yRHJhZzogJ3RhbGzDs3rDoXMgdmFneSBiZWjDunrDoXMnLFxyXG4gICAgICAgIG1heFNpemU6ICdtYXguIDI1IE1CJyxcclxuICAgICAgICBmb3JtYXRzOiAnUERGLCBkb2N4LCB4bHMgZm9ybcOhdHVtJyxcclxuICAgICAgICB1cGxvYWQ6ICdGZWx0w7ZsdMOpcycsXHJcbiAgICAgIH07XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBnZXRGaWxlKGV2ZW50OiBhbnkpOiB2b2lkIHtcclxuICAgIGlmIChldmVudC50YXJnZXQuZmlsZXMgJiYgZXZlbnQudGFyZ2V0LmZpbGVzLmxlbmd0aCkge1xyXG4gICAgICBsZXQgZmlsZUxpc3Q6IEZpbGVbXSA9IFsuLi5ldmVudC50YXJnZXQuZmlsZXNdO1xyXG4gICAgICBmaWxlTGlzdC5mb3JFYWNoKChmaWxlOiBGaWxlKSA9PiB7XHJcbiAgICAgICAgaWYgKGZpbGUuc2l6ZSA+IHRoaXMubWF4U2l6ZU1iISAqIDEwMDAwMDApIHtcclxuICAgICAgICAgIHRoaXMuX3NuYWNrQmFyLm9wZW5Gcm9tQ29tcG9uZW50KExhcmdlRmlsZVNuYWNrQmFyQ29tcG9uZW50LCB7XHJcbiAgICAgICAgICAgIGR1cmF0aW9uOiA1ICogMTAwMCxcclxuICAgICAgICAgIH0pO1xyXG4gICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICBpZiAodGhpcy5pc011bHRpcGxlKSB7XHJcbiAgICAgICAgICAgIHRoaXMuZmlsZXMgPSBbLi4udGhpcy5maWxlcywgZmlsZV07XHJcbiAgICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICB0aGlzLmZpbGVzID0gW2ZpbGVdO1xyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuICAgICAgfSk7XHJcbiAgICAgIHRoaXMuZmlsZUlucHV0Lm5hdGl2ZUVsZW1lbnQudmFsdWUgPSAnJztcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHJlbW92ZShpbmRleDogbnVtYmVyKTogdm9pZCB7XHJcbiAgICB0aGlzLmZpbGVzLnNwbGljZShpbmRleCwgMSk7XHJcbiAgfVxyXG5cclxuICB1cGxvYWRGaWxlKCk6IHZvaWQge1xyXG4gICAgdGhpcy51cGxvYWRDYWxsYmFjayh0aGlzLmZpbGVzKTtcclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImNvbnRhaW5lclwiPlxyXG4gIDxkaXYgY2xhc3M9XCJmaWxlQ29udGFpbmVyXCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwiZmlsZUlubmVyQ29udGFpbmVyXCI+XHJcbiAgICAgIDxpbnB1dFxyXG4gICAgICAgICNmaWxlSW5wdXRcclxuICAgICAgICBpZD1cImFkZEZpbGVcIlxyXG4gICAgICAgIHBsYWNlaG9sZGVyPVwiZmlsZUlucHV0XCJcclxuICAgICAgICB0eXBlPVwiZmlsZVwiXHJcbiAgICAgICAgKGNoYW5nZSk9XCJnZXRGaWxlKCRldmVudClcIlxyXG4gICAgICAgIGNsYXNzPVwiZmlsZVwiXHJcbiAgICAgICAgYWNjZXB0PVwie3sgZmlsZUZvcm1hdHM/LmpvaW4oJywgJykgfX1cIlxyXG4gICAgICAgIFtzaXplXT1cIm1heFNpemVNYlwiXHJcbiAgICAgICAgW211bHRpcGxlXT1cImlzTXVsdGlwbGVcIlxyXG4gICAgICAvPlxyXG4gICAgICA8ZGl2IGNsYXNzPVwiZmlsZVVwbG9hZENvbnRlbnRDb250YWluZXJcIj5cclxuICAgICAgICA8bWF0LWxhYmVsICpuZ0lmPVwidXNlSWNvbkJ1dHRvblwiIGNsYXNzPVwiYWRkRmlsZUJ1dHRvblwiPlxyXG4gICAgICAgICAgPG1hdC1pY29uIGNvbG9yPVwicHJpbWFyeVwiIGNsYXNzPVwiYWRkQ2lyY2xlXCI+YWRkX2NpcmNsZTwvbWF0LWljb24+XHJcbiAgICAgICAgPC9tYXQtbGFiZWw+XHJcbiAgICAgICAgPGJ1dHRvbiAqbmdJZj1cIiF1c2VJY29uQnV0dG9uXCIgbWF0LXJhaXNlZC1idXR0b24gY29sb3I9XCJwcmltYXJ5XCIgY2xhc3M9XCJhZGRGaWxlQnV0dG9uXCI+XHJcbiAgICAgICAgICB7eyBpMThuIS5hZGRGaWxlIH19XHJcbiAgICAgICAgPC9idXR0b24+XHJcbiAgICAgICAgPG1hdC1sYWJlbCAqbmdJZj1cInVzZUljb25CdXR0b25cIiBjbGFzcz1cImxhYmVsIHByaW1hcnlcIj4ge3sgaTE4biEuYWRkRmlsZSB9fSA8L21hdC1sYWJlbD5cclxuICAgICAgICA8bWF0LWxhYmVsIGNsYXNzPVwibGFiZWwgc2Vjb25kYXJ5XCI+IHt7IGkxOG4hLmJyb3dzZU9yRHJhZyB9fSA8L21hdC1sYWJlbD5cclxuICAgICAgICA8bWF0LWxhYmVsIGNsYXNzPVwic3ViTGFiZWwgcHJpbWFyeVwiPiB7eyBpMThuIS5tYXhTaXplIH19IDwvbWF0LWxhYmVsPlxyXG4gICAgICAgIDxtYXQtbGFiZWwgY2xhc3M9XCJzdWJMYWJlbCBwcmltYXJ5XCI+IHt7IGkxOG4hLmZvcm1hdHMgfX0gPC9tYXQtbGFiZWw+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgPC9kaXY+XHJcbiAgPGRpdiAqbmdJZj1cImZpbGVzLmxlbmd0aFwiIGNsYXNzPVwidXBsb2FkZWRGaWxlc0NvbnRhaW5lclwiPlxyXG4gICAgPGRpdiAqbmdGb3I9XCJsZXQgZmlsZSBvZiBmaWxlczsgbGV0IGkgPSBpbmRleFwiIGNsYXNzPVwidXBsb2FkZWRGaWxlXCI+XHJcbiAgICAgIDxtYXQtbGFiZWwgY2xhc3M9XCJmaWxlTmFtZUxhYmVsXCI+IHt7IGZpbGUubmFtZSB9fSA8L21hdC1sYWJlbD5cclxuICAgICAgPGJ1dHRvbiBtYXQtaWNvbi1idXR0b24gKGNsaWNrKT1cInJlbW92ZShpKVwiPlxyXG4gICAgICAgIDxtYXQtaWNvbj5jbG9zZTwvbWF0LWljb24+XHJcbiAgICAgIDwvYnV0dG9uPlxyXG4gICAgPC9kaXY+XHJcbiAgICA8YnV0dG9uIGNsYXNzPVwidXBsb2FkQnV0dG9uXCIgbWF0LXJhaXNlZC1idXR0b24gY29sb3I9XCJwcmltYXJ5XCIgKGNsaWNrKT1cInVwbG9hZEZpbGUoKVwiPlxyXG4gICAgICB7eyBpMThuIS51cGxvYWQgPz8gJ0ZlbHTDtmx0w6lzJyB9fVxyXG4gICAgPC9idXR0b24+XHJcbiAgPC9kaXY+XHJcbjwvZGl2PlxyXG4iXX0=
178
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartfileuploader.component.js","sourceRoot":"","sources":["../../../../../../projects/smart-ng-client/src/lib/smart-form/smartfileuploader/smartfileuploader.component.ts","../../../../../../projects/smart-ng-client/src/lib/smart-form/smartfileuploader/smartfileuploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, OnInit, ViewChild } from '@angular/core';\r\nimport { MatSnackBar } from '@angular/material/snack-bar';\r\nimport { SmartFileUploaderI18n } from './smartfileuploader.model';\r\nimport {\r\n  IconPosition,\r\n  UiActionButtonType,\r\n  UiActionDescriptor,\r\n} from '../../view-context/api/model/models';\r\n\r\n@Component({\r\n  selector: 'smartfileuploader',\r\n  templateUrl: './smartfileuploader.component.html',\r\n  styleUrls: ['./smartfileuploader.component.css'],\r\n})\r\nexport class SmartfileuploaderComponent implements OnInit {\r\n  @ViewChild('fileInput') fileInput!: ElementRef<HTMLInputElement>;\r\n\r\n  files: File[] = [];\r\n  @Input() uploadCallback!: (files: File[]) => void;\r\n  @Input() fileFormats?: string[] = [];\r\n  @Input() maxSizeMb?: number = 25;\r\n  @Input() i18n?: SmartFileUploaderI18n;\r\n  @Input() useIconButton: boolean = true;\r\n  @Input() isMultiple?: boolean = true;\r\n\r\n  isDragOver = false;\r\n  errors: string[] = [];\r\n\r\n  constructor(private _snackBar: MatSnackBar) {}\r\n\r\n  ngOnInit(): void {\r\n    const defaultI18n = {\r\n      addFile: 'dokumentum hozzáadása',\r\n      browseOrDrag: 'tallózás vagy behúzás',\r\n      maxSize: `max. ${this.maxSizeMb} MB`,\r\n      formats: 'PDF, docx, xls formátum',\r\n      upload: 'Feltöltés',\r\n    };\r\n\r\n    this.i18n = { ...defaultI18n, ...this.i18n };\r\n  }\r\n\r\n  private processFiles(fileList: File[]): void {\r\n    this.errors = [];\r\n    var validFiles: File[] = [];\r\n\r\n    fileList.forEach((file: File) => {\r\n      let hasError = false;\r\n\r\n      if (this.fileFormats?.length) {\r\n        var ext = file.name.split('.').pop()?.toLowerCase();\r\n\r\n        var trimmedFormats = (this.fileFormats || [])\r\n          .flatMap((f) => f.split(','))\r\n          .map((f) => f.replace('.', '').trim().toLowerCase());\r\n        var isAllowed = trimmedFormats.includes(ext!);\r\n\r\n        if (!isAllowed) {\r\n          this.errors.push(`\"${file.name}\" - nem támogatott formátum`);\r\n          hasError = true;\r\n        }\r\n      }\r\n\r\n      if (file.size > this.maxSizeMb! * 1_000_000) {\r\n        this.errors.push(`\"${file.name}\" - túl nagy fájl (max ${this.maxSizeMb} MB)`);\r\n        hasError = true;\r\n      }\r\n\r\n      if (!hasError) {\r\n        validFiles.push(file);\r\n      }\r\n    });\r\n\r\n    if (this.isMultiple) {\r\n      this.files = [...this.files, ...validFiles];\r\n    } else if (validFiles.length) {\r\n      this.files = [validFiles[0]];\r\n    }\r\n  }\r\n\r\n  getFile(event: any): void {\r\n    if (event.target.files && event.target.files.length) {\r\n      var fileList = Array.from(event.target.files) as File[];\r\n      this.processFiles(fileList);\r\n      this.fileInput.nativeElement.value = '';\r\n    }\r\n  }\r\n\r\n  onDrop(event: DragEvent): void {\r\n    event.preventDefault();\r\n    this.isDragOver = false;\r\n\r\n    if (!event.dataTransfer?.files) return;\r\n    const fileList = Array.from(event.dataTransfer.files);\r\n    this.processFiles(fileList);\r\n  }\r\n\r\n  onDragOver(event: DragEvent): void {\r\n    event.preventDefault();\r\n    this.isDragOver = true;\r\n  }\r\n\r\n  onDragLeave(event: DragEvent): void {\r\n    event.preventDefault();\r\n\r\n    const related = event.relatedTarget as HTMLElement | null;\r\n    let stopDrag = false;\r\n\r\n    if (!related) {\r\n      stopDrag = true;\r\n    } else {\r\n      const parentDrop = related.closest('.container');\r\n      if (related !== event.currentTarget && !parentDrop) {\r\n        stopDrag = true;\r\n      }\r\n    }\r\n\r\n    if (stopDrag) {\r\n      this.isDragOver = false;\r\n    }\r\n  }\r\n\r\n  remove(index: number): void {\r\n    this.files.splice(index, 1);\r\n  }\r\n\r\n  uploadFile(): void {\r\n    this.uploadCallback(this.files);\r\n  }\r\n\r\n  formatSize(bytes: number): string {\r\n    if (bytes === 0) return '0 B';\r\n    const k = 1024;\r\n    const sizes = ['B', 'KB', 'MB', 'GB', 'TB'];\r\n    const i = Math.floor(Math.log(bytes) / Math.log(k));\r\n    const value = parseFloat((bytes / Math.pow(k, i)).toFixed(1));\r\n    return `${value} ${sizes[i]}`;\r\n  }\r\n\r\n  filePreviewUrl(file: File): string | null {\r\n    if (file.type.startsWith('image/')) {\r\n      return URL.createObjectURL(file);\r\n    }\r\n    return null;\r\n  }\r\n\r\n  downloadFile(file: File): void {\r\n    const url = URL.createObjectURL(file);\r\n    const a = document.createElement('a');\r\n    a.href = url;\r\n    a.download = file.name;\r\n    a.click();\r\n    URL.revokeObjectURL(url);\r\n  }\r\n\r\n  get uploadButton(): UiActionDescriptor {\r\n    return {\r\n      title: this.i18n!.upload ?? '',\r\n      color: 'primary',\r\n      type: UiActionButtonType.RAISED,\r\n      icon: 'upload',\r\n      iconPosition: IconPosition.PRE,\r\n    };\r\n  }\r\n\r\n  get downloadButton(): UiActionDescriptor {\r\n    return {\r\n      title: '',\r\n      color: 'primary',\r\n      type: UiActionButtonType.ICON,\r\n      icon: 'download',\r\n      iconPosition: IconPosition.PRE,\r\n    };\r\n  }\r\n\r\n  get removeButton(): UiActionDescriptor {\r\n    return {\r\n      title: '',\r\n      color: 'primary',\r\n      type: UiActionButtonType.ICON,\r\n      icon: 'close',\r\n      iconColor: 'red',\r\n      iconPosition: IconPosition.PRE,\r\n    };\r\n  }\r\n}\r\n","<div\r\n  class=\"container\"\r\n  (dragover)=\"onDragOver($event)\"\r\n  (dragleave)=\"onDragLeave($event)\"\r\n  (drop)=\"onDrop($event)\"\r\n  [class.dragover]=\"isDragOver\"\r\n>\r\n  <div class=\"fileContainer\" (click)=\"fileInput.click()\">\r\n    <input\r\n      #fileInput\r\n      id=\"addFile\"\r\n      placeholder=\"fileInput\"\r\n      type=\"file\"\r\n      (change)=\"getFile($event)\"\r\n      class=\"file\"\r\n      accept=\"{{ fileFormats?.join(', ') }}\"\r\n      [size]=\"maxSizeMb\"\r\n      [multiple]=\"isMultiple\"\r\n      style=\"display: none\"\r\n    />\r\n    <div class=\"fileUploadContentContainer\">\r\n      <div class=\"icon\">\r\n        <mat-label *ngIf=\"useIconButton\" class=\"addFileButton\">\r\n          <mat-icon color=\"primary\" class=\"addCircle\">add_circle</mat-icon>\r\n        </mat-label>\r\n        <button *ngIf=\"!useIconButton\" mat-raised-button color=\"primary\" class=\"addFileButton\">\r\n          {{ i18n!.addFile }}\r\n        </button>\r\n      </div>\r\n      <div class=\"labels\">\r\n        <mat-label *ngIf=\"useIconButton\" class=\"label primary title\">\r\n          {{ i18n!.addFile }}\r\n        </mat-label>\r\n        <mat-label class=\"label secondary\"> {{ i18n!.browseOrDrag }} </mat-label>\r\n        <mat-label class=\"subLabel primary\"> {{ i18n!.maxSize }} </mat-label>\r\n        <mat-label class=\"subLabel primary\"> {{ i18n!.formats }} </mat-label>\r\n      </div>\r\n      <div class=\"uploadButton\" *ngIf=\"files.length\">\r\n        <ui-action-button (actionClick)=\"uploadFile()\" [descriptor]=\"uploadButton\">\r\n        </ui-action-button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <div *ngIf=\"errors.length\" class=\"errorMessage\">\r\n    <smart-icon [icon]=\"'error'\" [color]=\"'warn'\"></smart-icon>\r\n    <div class=\"errors\">\r\n      <span *ngFor=\"let error of errors\">{{ error }}</span>\r\n    </div>\r\n  </div>\r\n\r\n  <div *ngIf=\"files.length\" class=\"uploadedFilesContainer\">\r\n    <div *ngFor=\"let file of files; let i = index\" class=\"uploadedFile\">\r\n      <ng-container *ngIf=\"filePreviewUrl(file); else fileIcon\">\r\n        <img [src]=\"filePreviewUrl(file)\" [alt]=\"file.name\" width=\"50\" height=\"50\" />\r\n      </ng-container>\r\n      <ng-template #fileIcon>\r\n        <smart-icon [icon]=\"'insert_drive_file'\"></smart-icon>\r\n      </ng-template>\r\n\r\n      <div class=\"fileData\">\r\n        <div class=\"fileDataContainer\">\r\n          <span class=\"fileName\">{{ file.name }}</span>\r\n          <span class=\"fileSize\">{{ formatSize(file.size) }}</span>\r\n        </div>\r\n      </div>\r\n\r\n      <div class=\"fileActions\">\r\n        <ui-action-button (actionClick)=\"downloadFile(file)\" [descriptor]=\"downloadButton\">\r\n        </ui-action-button>\r\n\r\n        <ui-action-button class=\"removeIcon\" (actionClick)=\"remove(i)\" [descriptor]=\"removeButton\">\r\n        </ui-action-button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartform.form-model.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.form-model.ts"],"names":[],"mappings":"","sourcesContent":["import { QuillModules } from 'ngx-quill';\r\nimport {\r\n  ImageProperties,\r\n  SelectionDefinition,\r\n  SmartFormInputMode,\r\n  SmartFormWidgetDirection,\r\n  SmartFormWidgetType,\r\n  SmartWidgetHint,\r\n  SortDefinition,\r\n  TextFieldProperties,\r\n  ValueChangeMode,\r\n} from './api';\r\nimport {\r\n  SmartFormTextFieldButton,\r\n  SmartFormWidgetWidth,\r\n  SmartIndicator,\r\n  SmartValidator,\r\n  ToggleLabelPosition,\r\n} from './smartform.model';\r\nimport { ImageResource, Style } from '../view-context/api';\r\n\r\nexport declare type SmartFormWidget<T> =\r\n  | SmartTextField<T>\r\n  | SmartTextFieldNumber<T>\r\n  | SmartTextFieldChips<T>\r\n  | SmartTextFieldLookup<T>\r\n  | SmartTextBox<T>\r\n  | SmartSelect<T>\r\n  | SmartSelectMultiple<T>\r\n  | SmartCheckBox<T>\r\n  | SmartCheckBox2<T>\r\n  | SmartRadioButton<T>\r\n  | SmartDatePicker<T>\r\n  | SmartDateTimePicker<T>\r\n  | SmartContainer<T>\r\n  | SmartLabel\r\n  | SmartTime<T>\r\n  | SmartToggle<T>\r\n  | SmartIndicatorItem\r\n  | SmartFileUploader\r\n  | SmartImage\r\n  | SmartDivider\r\n  | SmartButton\r\n  | SmartFormInlineComponent\r\n  | SmartRichText\r\n  | SmartSortable<T>\r\n  | SmartMatrix\r\n  | SmartYoutubePlayer\r\n  | SmartMonthPicker\r\n  | SmartSvg;\r\n\r\nexport interface SmartTextField<T> {\r\n  type: SmartFormWidgetType.TEXT_FIELD;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  prefix?: string;\r\n  suffix?: string;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isPassword?: boolean;\r\n  textFieldButton?: SmartFormTextFieldButton;\r\n  capsLockWarning?: string;\r\n  capsLockWarningIcon?: string;\r\n  isVisible?: boolean;\r\n  mask?: string;\r\n  error?: string;\r\n  icon?: string;\r\n  iconColor?: string;\r\n  iconPosition?: 'PRE' | 'POST';\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList?: SmartItem<T>[];\r\n  selection?: SelectionDefinition;\r\n  filterErrorMessage?: string;\r\n  hint?: SmartWidgetHint;\r\n  maxLength?: number;\r\n  showCharacterLimitSuffix?: boolean;\r\n  toolbarId?: string;\r\n  inputMode?: SmartFormInputMode;\r\n  textFieldProperties?: TextFieldProperties;\r\n}\r\n\r\nexport interface SmartTextFieldNumber<T> {\r\n  type: SmartFormWidgetType.TEXT_FIELD_NUMBER;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  prefix?: string;\r\n  suffix?: string;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  textFieldButton?: SmartFormTextFieldButton;\r\n  isVisible?: boolean;\r\n  minValues?: number;\r\n  maxValues?: number;\r\n  error?: string;\r\n  icon?: string;\r\n  iconColor?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n}\r\n\r\nexport interface SmartTextFieldChips<T> {\r\n  type: SmartFormWidgetType.TEXT_FIELD_CHIPS;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItem<T>[];\r\n  minValues?: number;\r\n  maxValues?: number;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartTextFieldLookup<T> {\r\n  type: SmartFormWidgetType.TEXT_FIELD_LOOKUP;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  minValues?: number;\r\n  maxValues?: number;\r\n  hint?: SmartWidgetHint;\r\n  toolbarId?: string;\r\n}\r\nexport interface SmartTextBox<T> {\r\n  type: SmartFormWidgetType.TEXT_BOX;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n  maxLength?: number;\r\n  showCharacterLimitSuffix?: boolean;\r\n}\r\nexport interface SmartSelect<T> {\r\n  type: SmartFormWidgetType.SELECT;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  placeholder?: string;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItems<T>[];\r\n  selection?: SelectionDefinition;\r\n  hint?: SmartWidgetHint;\r\n  compareWith?: (o1: any, o2: any) => boolean;\r\n}\r\nexport interface SmartSelectMultiple<T> {\r\n  type: SmartFormWidgetType.SELECT_MULTIPLE;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  placeholder?: string;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItems<T>[];\r\n  selection?: SelectionDefinition;\r\n  hint?: SmartWidgetHint;\r\n  compareWith?: (o1: any, o2: any) => boolean;\r\n}\r\nexport interface SmartCheckBox<T> {\r\n  type: SmartFormWidgetType.CHECK_BOX;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItem<T>[];\r\n  selection?: SelectionDefinition;\r\n  direction?: SmartFormWidgetDirection;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartCheckBox2<T> {\r\n  type: SmartFormWidgetType.CHECK_BOX_2;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItem<T>[];\r\n  selection?: SelectionDefinition;\r\n  direction?: SmartFormWidgetDirection;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartRadioButton<T> {\r\n  type: SmartFormWidgetType.RADIO_BUTTON;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItem<T>[];\r\n  selection?: SelectionDefinition;\r\n  direction?: SmartFormWidgetDirection;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartDatePicker<T> {\r\n  type: SmartFormWidgetType.DATE_PICKER;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  dateFormatHint?: string;\r\n  minDate?: Date;\r\n  maxDate?: Date;\r\n  filter?: (d: Date | null) => boolean;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartDateTimePicker<T> {\r\n  type: SmartFormWidgetType.DATE_TIME_PICKER;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  dateFormatHint?: string;\r\n  filter?: (d: Date | null) => boolean;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartContainer<T> {\r\n  key?: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  type: SmartFormWidgetType.CONTAINER;\r\n  isVisible?: boolean;\r\n  valueList: SmartFormWidget<T>[];\r\n  direction?: SmartFormWidgetDirection;\r\n  cssClass?: string;\r\n  style?: Style;\r\n}\r\nexport interface SmartLabel {\r\n  key?: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  type: SmartFormWidgetType.LABEL;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  label: string;\r\n  originalLabel?: string;\r\n  widgetDescription?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  markAsRequired?: boolean;\r\n}\r\nexport interface SmartTime<T> {\r\n  type: SmartFormWidgetType.TIME;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  value?: T;\r\n  placeholder?: string;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartToggle<T> {\r\n  type: SmartFormWidgetType.TOGGLE;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  value?: T;\r\n  placeholder?: string;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  toggleLabelPosition?: ToggleLabelPosition;\r\n  validators?: SmartValidator[];\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartIndicatorItem {\r\n  type: SmartFormWidgetType.INDICATOR;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  indicator: SmartIndicator;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n}\r\n\r\nexport declare type SmartItems<T> = SmartItem<T> | SmartItemGroup<T>;\r\n\r\nexport interface SmartItem<T> {\r\n  type: SmartFormWidgetType.ITEM;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  originalLabel?: string;\r\n  value?: T;\r\n  isDisabled?: boolean;\r\n  icon?: string;\r\n  iconColor?: string;\r\n  imageUrl?: string;\r\n}\r\nexport interface SmartItemGroup<T> {\r\n  type: SmartFormWidgetType.ITEM_GROUP;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  originalLabel?: string;\r\n  isDisabled?: boolean;\r\n  valueList: SmartItem<T>[];\r\n}\r\n\r\nexport interface SmartFileUploader {\r\n  type: SmartFormWidgetType.FILE_UPLOADER;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  uploadCallback: (key: string, files: any[]) => void;\r\n  fileFormats?: string[];\r\n  maxSizeMb?: number;\r\n  i18n?: any;\r\n}\r\n\r\nexport interface SmartImage {\r\n  type: SmartFormWidgetType.IMAGE;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  value?: ImageResource;\r\n  imageCss?: string;\r\n  imageProperties?: ImageProperties;\r\n}\r\n\r\nexport interface SmartDivider {\r\n  type: SmartFormWidgetType.DIVIDER;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  value?: string;\r\n}\r\n\r\nexport interface SmartButton {\r\n  type: SmartFormWidgetType.BUTTON;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  value?: string;\r\n  uiAction?: any;\r\n  uiActionDescriptor: any;\r\n  callback: ((uiAction: any) => void) | ((key: string) => void);\r\n}\r\nexport interface SmartFormInlineComponent {\r\n  type: SmartFormWidgetType.COMPONENT;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  component: any;\r\n  input: Map<string, any>;\r\n}\r\n\r\nexport interface SmartRichText {\r\n  type: SmartFormWidgetType.RICH_TEXT;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  value?: string;\r\n  originalLabel?: string;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  quillModules: QuillModules;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n  maxLength?: number;\r\n  showCharacterLimitSuffix?: boolean;\r\n}\r\n\r\nexport interface SmartSortable<T> {\r\n  type: SmartFormWidgetType.SORTABLE;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  value?: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  validators?: SmartValidator[];\r\n  valueList?: SmartItem<T>[];\r\n  isMultiple?: boolean;\r\n  hint?: SmartWidgetHint;\r\n  icon?: string;\r\n  sortDefinition: SortDefinition;\r\n}\r\n\r\nexport interface SmartMatrix {\r\n  type: SmartFormWidgetType.MATRIX;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  value?: any;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  validators?: SmartValidator[];\r\n  isMultiple?: boolean;\r\n  hint?: SmartWidgetHint;\r\n  button?: SmartMatrixButton;\r\n}\r\n\r\nexport interface SmartMatrixButton {\r\n  iconCode?: string;\r\n  callback: (widget: SmartFormWidget<any>, row: any) => any;\r\n  color?: string;\r\n}\r\n\r\nexport interface SmartYoutubePlayer {\r\n  key?: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  type: SmartFormWidgetType.YOUTUBE_PLAYER;\r\n  link?: string;\r\n  videoId?: string;\r\n  height?: number;\r\n  width?: number;\r\n  startSeconds?: number | 0;\r\n  endSeconds?: number;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  label?: string;\r\n  validators?: SmartValidator[];\r\n  hint?: SmartWidgetHint;\r\n  showLabel?: boolean;\r\n}\r\n\r\nexport interface SmartMonthPicker {\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  type: SmartFormWidgetType.MONTH_PICKER;\r\n  value?: string;\r\n  validators?: SmartValidator[];\r\n  label: string;\r\n  showLabel?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  isDisabled?: boolean;\r\n  originalLabel?: string;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartSvg {\r\n  type: SmartFormWidgetType.SVG;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  value?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n}\r\n"]}
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartform.form-model.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.form-model.ts"],"names":[],"mappings":"","sourcesContent":["import { QuillModules } from 'ngx-quill';\r\nimport {\r\n  FileUploaderProperties,\r\n  ImageProperties,\r\n  SelectionDefinition,\r\n  SmartFormInputMode,\r\n  SmartFormWidgetDirection,\r\n  SmartFormWidgetType,\r\n  SmartWidgetHint,\r\n  SortDefinition,\r\n  TextFieldProperties,\r\n  ValueChangeMode,\r\n} from './api';\r\nimport {\r\n  SmartFormTextFieldButton,\r\n  SmartFormWidgetWidth,\r\n  SmartIndicator,\r\n  SmartValidator,\r\n  ToggleLabelPosition,\r\n} from './smartform.model';\r\nimport { ImageResource, Style } from '../view-context/api';\r\n\r\nexport declare type SmartFormWidget<T> =\r\n  | SmartTextField<T>\r\n  | SmartTextFieldNumber<T>\r\n  | SmartTextFieldChips<T>\r\n  | SmartTextFieldLookup<T>\r\n  | SmartTextBox<T>\r\n  | SmartSelect<T>\r\n  | SmartSelectMultiple<T>\r\n  | SmartCheckBox<T>\r\n  | SmartCheckBox2<T>\r\n  | SmartRadioButton<T>\r\n  | SmartDatePicker<T>\r\n  | SmartDateTimePicker<T>\r\n  | SmartContainer<T>\r\n  | SmartLabel\r\n  | SmartTime<T>\r\n  | SmartToggle<T>\r\n  | SmartIndicatorItem\r\n  | SmartFileUploader\r\n  | SmartImage\r\n  | SmartDivider\r\n  | SmartButton\r\n  | SmartFormInlineComponent\r\n  | SmartRichText\r\n  | SmartSortable<T>\r\n  | SmartMatrix\r\n  | SmartYoutubePlayer\r\n  | SmartMonthPicker\r\n  | SmartSvg;\r\n\r\nexport interface SmartTextField<T> {\r\n  type: SmartFormWidgetType.TEXT_FIELD;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  prefix?: string;\r\n  suffix?: string;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isPassword?: boolean;\r\n  textFieldButton?: SmartFormTextFieldButton;\r\n  capsLockWarning?: string;\r\n  capsLockWarningIcon?: string;\r\n  isVisible?: boolean;\r\n  mask?: string;\r\n  error?: string;\r\n  icon?: string;\r\n  iconColor?: string;\r\n  iconPosition?: 'PRE' | 'POST';\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList?: SmartItem<T>[];\r\n  selection?: SelectionDefinition;\r\n  filterErrorMessage?: string;\r\n  hint?: SmartWidgetHint;\r\n  maxLength?: number;\r\n  showCharacterLimitSuffix?: boolean;\r\n  toolbarId?: string;\r\n  inputMode?: SmartFormInputMode;\r\n  textFieldProperties?: TextFieldProperties;\r\n}\r\n\r\nexport interface SmartTextFieldNumber<T> {\r\n  type: SmartFormWidgetType.TEXT_FIELD_NUMBER;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  prefix?: string;\r\n  suffix?: string;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  textFieldButton?: SmartFormTextFieldButton;\r\n  isVisible?: boolean;\r\n  minValues?: number;\r\n  maxValues?: number;\r\n  error?: string;\r\n  icon?: string;\r\n  iconColor?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n}\r\n\r\nexport interface SmartTextFieldChips<T> {\r\n  type: SmartFormWidgetType.TEXT_FIELD_CHIPS;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItem<T>[];\r\n  minValues?: number;\r\n  maxValues?: number;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartTextFieldLookup<T> {\r\n  type: SmartFormWidgetType.TEXT_FIELD_LOOKUP;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  minValues?: number;\r\n  maxValues?: number;\r\n  hint?: SmartWidgetHint;\r\n  toolbarId?: string;\r\n}\r\nexport interface SmartTextBox<T> {\r\n  type: SmartFormWidgetType.TEXT_BOX;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n  maxLength?: number;\r\n  showCharacterLimitSuffix?: boolean;\r\n}\r\nexport interface SmartSelect<T> {\r\n  type: SmartFormWidgetType.SELECT;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  placeholder?: string;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItems<T>[];\r\n  selection?: SelectionDefinition;\r\n  hint?: SmartWidgetHint;\r\n  compareWith?: (o1: any, o2: any) => boolean;\r\n}\r\nexport interface SmartSelectMultiple<T> {\r\n  type: SmartFormWidgetType.SELECT_MULTIPLE;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  placeholder?: string;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItems<T>[];\r\n  selection?: SelectionDefinition;\r\n  hint?: SmartWidgetHint;\r\n  compareWith?: (o1: any, o2: any) => boolean;\r\n}\r\nexport interface SmartCheckBox<T> {\r\n  type: SmartFormWidgetType.CHECK_BOX;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItem<T>[];\r\n  selection?: SelectionDefinition;\r\n  direction?: SmartFormWidgetDirection;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartCheckBox2<T> {\r\n  type: SmartFormWidgetType.CHECK_BOX_2;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItem<T>[];\r\n  selection?: SelectionDefinition;\r\n  direction?: SmartFormWidgetDirection;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartRadioButton<T> {\r\n  type: SmartFormWidgetType.RADIO_BUTTON;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  valueList: SmartItem<T>[];\r\n  selection?: SelectionDefinition;\r\n  direction?: SmartFormWidgetDirection;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartDatePicker<T> {\r\n  type: SmartFormWidgetType.DATE_PICKER;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  dateFormatHint?: string;\r\n  minDate?: Date;\r\n  maxDate?: Date;\r\n  filter?: (d: Date | null) => boolean;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartDateTimePicker<T> {\r\n  type: SmartFormWidgetType.DATE_TIME_PICKER;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  value?: T;\r\n  placeholder?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  dateFormatHint?: string;\r\n  filter?: (d: Date | null) => boolean;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartContainer<T> {\r\n  key?: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  type: SmartFormWidgetType.CONTAINER;\r\n  isVisible?: boolean;\r\n  valueList: SmartFormWidget<T>[];\r\n  direction?: SmartFormWidgetDirection;\r\n  cssClass?: string;\r\n  style?: Style;\r\n}\r\nexport interface SmartLabel {\r\n  key?: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  type: SmartFormWidgetType.LABEL;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  label: string;\r\n  originalLabel?: string;\r\n  widgetDescription?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  markAsRequired?: boolean;\r\n}\r\nexport interface SmartTime<T> {\r\n  type: SmartFormWidgetType.TIME;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  value?: T;\r\n  placeholder?: string;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartToggle<T> {\r\n  type: SmartFormWidgetType.TOGGLE;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  value?: T;\r\n  placeholder?: string;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  toggleLabelPosition?: ToggleLabelPosition;\r\n  validators?: SmartValidator[];\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartIndicatorItem {\r\n  type: SmartFormWidgetType.INDICATOR;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  indicator: SmartIndicator;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n}\r\n\r\nexport declare type SmartItems<T> = SmartItem<T> | SmartItemGroup<T>;\r\n\r\nexport interface SmartItem<T> {\r\n  type: SmartFormWidgetType.ITEM;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  originalLabel?: string;\r\n  value?: T;\r\n  isDisabled?: boolean;\r\n  icon?: string;\r\n  iconColor?: string;\r\n  imageUrl?: string;\r\n}\r\nexport interface SmartItemGroup<T> {\r\n  type: SmartFormWidgetType.ITEM_GROUP;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  originalLabel?: string;\r\n  isDisabled?: boolean;\r\n  valueList: SmartItem<T>[];\r\n}\r\n\r\nexport interface SmartFileUploader {\r\n  type: SmartFormWidgetType.FILE_UPLOADER;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  fileFormats?: string[];\r\n  maxSizeMb?: number;\r\n  i18n?: any;\r\n  fileUploaderProperties?: FileUploaderProperties;\r\n}\r\n\r\nexport interface SmartImage {\r\n  type: SmartFormWidgetType.IMAGE;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  value?: ImageResource;\r\n  imageCss?: string;\r\n  imageProperties?: ImageProperties;\r\n}\r\n\r\nexport interface SmartDivider {\r\n  type: SmartFormWidgetType.DIVIDER;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  value?: string;\r\n}\r\n\r\nexport interface SmartButton {\r\n  type: SmartFormWidgetType.BUTTON;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  value?: string;\r\n  uiAction?: any;\r\n  uiActionDescriptor: any;\r\n  callback: ((uiAction: any) => void) | ((key: string) => void);\r\n}\r\nexport interface SmartFormInlineComponent {\r\n  type: SmartFormWidgetType.COMPONENT;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  component: any;\r\n  input: Map<string, any>;\r\n}\r\n\r\nexport interface SmartRichText {\r\n  type: SmartFormWidgetType.RICH_TEXT;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  value?: string;\r\n  originalLabel?: string;\r\n  placeholder?: string;\r\n  originalPlaceholder?: string;\r\n  quillModules: QuillModules;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  validators?: SmartValidator[];\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  hint?: SmartWidgetHint;\r\n  maxLength?: number;\r\n  showCharacterLimitSuffix?: boolean;\r\n}\r\n\r\nexport interface SmartSortable<T> {\r\n  type: SmartFormWidgetType.SORTABLE;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  value?: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  validators?: SmartValidator[];\r\n  valueList?: SmartItem<T>[];\r\n  isMultiple?: boolean;\r\n  hint?: SmartWidgetHint;\r\n  icon?: string;\r\n  sortDefinition: SortDefinition;\r\n}\r\n\r\nexport interface SmartMatrix {\r\n  type: SmartFormWidgetType.MATRIX;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  value?: any;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isDisabled?: boolean;\r\n  isReadonly?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  validators?: SmartValidator[];\r\n  isMultiple?: boolean;\r\n  hint?: SmartWidgetHint;\r\n  button?: SmartMatrixButton;\r\n}\r\n\r\nexport interface SmartMatrixButton {\r\n  iconCode?: string;\r\n  callback: (widget: SmartFormWidget<any>, row: any) => any;\r\n  color?: string;\r\n}\r\n\r\nexport interface SmartYoutubePlayer {\r\n  key?: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  type: SmartFormWidgetType.YOUTUBE_PLAYER;\r\n  link?: string;\r\n  videoId?: string;\r\n  height?: number;\r\n  width?: number;\r\n  startSeconds?: number | 0;\r\n  endSeconds?: number;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  label?: string;\r\n  validators?: SmartValidator[];\r\n  hint?: SmartWidgetHint;\r\n  showLabel?: boolean;\r\n}\r\n\r\nexport interface SmartMonthPicker {\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  type: SmartFormWidgetType.MONTH_PICKER;\r\n  value?: string;\r\n  validators?: SmartValidator[];\r\n  label: string;\r\n  showLabel?: boolean;\r\n  error?: string;\r\n  errorIcon?: string;\r\n  errorIconColor?: string;\r\n  serverErrorMessage?: string;\r\n  serverErrorIcon?: string;\r\n  serverErrorColor?: string;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  isVisible?: boolean;\r\n  isDisabled?: boolean;\r\n  originalLabel?: string;\r\n  hint?: SmartWidgetHint;\r\n}\r\nexport interface SmartSvg {\r\n  type: SmartFormWidgetType.SVG;\r\n  key: string;\r\n  valueChangeMode?: ValueChangeMode;\r\n  label: string;\r\n  originalLabel?: string;\r\n  showLabel?: boolean;\r\n  isVisible?: boolean;\r\n  cssClass?: string;\r\n  cssLabelClass?: string;\r\n  style?: Style;\r\n  labelStyle?: Style;\r\n  value?: string;\r\n  minWidth?: SmartFormWidgetWidth | number;\r\n}\r\n"]}