@aquera/ngx-smart-table 0.0.2-alpha

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 (169) hide show
  1. package/README.md +152 -0
  2. package/aquera-ngx-smart-table.d.ts +5 -0
  3. package/esm2020/aquera-ngx-smart-table.mjs +5 -0
  4. package/esm2020/lib/builder/components/builder-preview/builder-preview.component.mjs +63 -0
  5. package/esm2020/lib/builder/components/builder-toolbar/builder-toolbar.component.mjs +115 -0
  6. package/esm2020/lib/builder/components/column-editor/column-editor.component.mjs +206 -0
  7. package/esm2020/lib/builder/components/column-list/column-list.component.mjs +125 -0
  8. package/esm2020/lib/builder/components/definition-builder/definition-builder.component.mjs +105 -0
  9. package/esm2020/lib/builder/components/table-config-editor/table-config-editor.component.mjs +132 -0
  10. package/esm2020/lib/builder/definition-builder.module.mjs +70 -0
  11. package/esm2020/lib/builder/models/builder-state.interface.mjs +5 -0
  12. package/esm2020/lib/builder/services/definition-builder.service.mjs +251 -0
  13. package/esm2020/lib/builder/services/definition-export.service.mjs +167 -0
  14. package/esm2020/lib/builder/services/definition-import.service.mjs +193 -0
  15. package/esm2020/lib/builder/services/sample-data-generator.service.mjs +126 -0
  16. package/esm2020/lib/builder/utils/config-validator.util.mjs +165 -0
  17. package/esm2020/lib/builder/utils/typescript-generator.util.mjs +206 -0
  18. package/esm2020/lib/editors/index.mjs +9 -0
  19. package/esm2020/lib/editors/nile-autocomplete-editor.mjs +228 -0
  20. package/esm2020/lib/editors/nile-calendar-editor.mjs +214 -0
  21. package/esm2020/lib/editors/nile-date-picker-editor.mjs +227 -0
  22. package/esm2020/lib/editors/nile-input-editor.mjs +235 -0
  23. package/esm2020/lib/editors/nile-select-editor.mjs +317 -0
  24. package/esm2020/lib/factories/column-config.factory.mjs +231 -0
  25. package/esm2020/lib/models/autosave-config.interface.mjs +8 -0
  26. package/esm2020/lib/models/base-column-config.class.mjs +253 -0
  27. package/esm2020/lib/models/cell-strategies.interface.mjs +6 -0
  28. package/esm2020/lib/models/cell-types.mjs +147 -0
  29. package/esm2020/lib/models/column-action.interface.mjs +6 -0
  30. package/esm2020/lib/models/column-config.interface.mjs +43 -0
  31. package/esm2020/lib/models/column-config.utils.mjs +101 -0
  32. package/esm2020/lib/models/row-action.interface.mjs +5 -0
  33. package/esm2020/lib/models/row-validator.interface.mjs +2 -0
  34. package/esm2020/lib/models/schema-validation.interface.mjs +2 -0
  35. package/esm2020/lib/models/sheet-action.interface.mjs +5 -0
  36. package/esm2020/lib/models/sheet-config.interface.mjs +5 -0
  37. package/esm2020/lib/models/table-config.interface.mjs +106 -0
  38. package/esm2020/lib/models/table-validator.interface.mjs +2 -0
  39. package/esm2020/lib/models/workbook-action.interface.mjs +5 -0
  40. package/esm2020/lib/models/workbook-config.interface.mjs +5 -0
  41. package/esm2020/lib/renderer/components/st-add-column-button/st-add-column-button.component.mjs +24 -0
  42. package/esm2020/lib/renderer/components/st-cell/st-cell.component.mjs +391 -0
  43. package/esm2020/lib/renderer/components/st-column-editor-modal/st-column-editor-modal.component.mjs +103 -0
  44. package/esm2020/lib/renderer/components/st-column-filter/st-column-filter.component.mjs +383 -0
  45. package/esm2020/lib/renderer/components/st-column-menu/st-column-menu.component.mjs +232 -0
  46. package/esm2020/lib/renderer/components/st-column-visibility/st-column-visibility.component.mjs +97 -0
  47. package/esm2020/lib/renderer/components/st-header/st-header.component.mjs +157 -0
  48. package/esm2020/lib/renderer/components/st-pagination/st-pagination.component.mjs +87 -0
  49. package/esm2020/lib/renderer/components/st-row-actions-dropdown/st-row-actions-dropdown.component.mjs +167 -0
  50. package/esm2020/lib/renderer/components/st-sheet/st-sheet.component.mjs +165 -0
  51. package/esm2020/lib/renderer/components/st-sheet-actions/st-sheet-actions.component.mjs +112 -0
  52. package/esm2020/lib/renderer/components/st-table/st-table.component.mjs +1246 -0
  53. package/esm2020/lib/renderer/components/st-table-actions/st-table-actions.component.mjs +171 -0
  54. package/esm2020/lib/renderer/components/st-workbook/st-workbook.component.mjs +489 -0
  55. package/esm2020/lib/renderer/directives/click-outside.directive.mjs +28 -0
  56. package/esm2020/lib/renderer/directives/st-column-resize.directive.mjs +108 -0
  57. package/esm2020/lib/renderer/directives/st-keyboard-navigation.directive.mjs +73 -0
  58. package/esm2020/lib/renderer/models/cell-state.interface.mjs +66 -0
  59. package/esm2020/lib/renderer/models/cell.class.mjs +389 -0
  60. package/esm2020/lib/renderer/models/row-validation-state.interface.mjs +7 -0
  61. package/esm2020/lib/renderer/models/sheet-state.class.mjs +90 -0
  62. package/esm2020/lib/renderer/models/sheet-state.interface.mjs +5 -0
  63. package/esm2020/lib/renderer/models/table-state.class.mjs +841 -0
  64. package/esm2020/lib/renderer/models/table-state.interface.mjs +5 -0
  65. package/esm2020/lib/renderer/models/table-types.mjs +29 -0
  66. package/esm2020/lib/renderer/models/table-validation-state.interface.mjs +7 -0
  67. package/esm2020/lib/renderer/models/workbook-state.class.mjs +174 -0
  68. package/esm2020/lib/renderer/models/workbook-state.interface.mjs +5 -0
  69. package/esm2020/lib/renderer/models/z-index.enum.mjs +55 -0
  70. package/esm2020/lib/schemas/table-config.schema.mjs +472 -0
  71. package/esm2020/lib/services/autosave.service.mjs +92 -0
  72. package/esm2020/lib/services/custom-validation-rules.util.mjs +124 -0
  73. package/esm2020/lib/services/json-schema-validator.service.mjs +216 -0
  74. package/esm2020/lib/services/row-validation.service.mjs +42 -0
  75. package/esm2020/lib/services/validation-logger.service.mjs +177 -0
  76. package/esm2020/lib/services/virtual-scroll.service.mjs +52 -0
  77. package/esm2020/lib/shared/shared-table-components.module.mjs +35 -0
  78. package/esm2020/lib/smart-table.module.mjs +124 -0
  79. package/esm2020/lib/strategies/default-editors.mjs +433 -0
  80. package/esm2020/lib/strategies/default-formatters.mjs +238 -0
  81. package/esm2020/lib/strategies/default-validators.mjs +327 -0
  82. package/esm2020/public-api.mjs +146 -0
  83. package/fesm2015/aquera-ngx-smart-table.mjs +11860 -0
  84. package/fesm2015/aquera-ngx-smart-table.mjs.map +1 -0
  85. package/fesm2020/aquera-ngx-smart-table.mjs +11897 -0
  86. package/fesm2020/aquera-ngx-smart-table.mjs.map +1 -0
  87. package/lib/builder/components/builder-preview/builder-preview.component.d.ts +31 -0
  88. package/lib/builder/components/builder-toolbar/builder-toolbar.component.d.ts +53 -0
  89. package/lib/builder/components/column-editor/column-editor.component.d.ts +69 -0
  90. package/lib/builder/components/column-list/column-list.component.d.ts +65 -0
  91. package/lib/builder/components/definition-builder/definition-builder.component.d.ts +58 -0
  92. package/lib/builder/components/table-config-editor/table-config-editor.component.d.ts +32 -0
  93. package/lib/builder/definition-builder.module.d.ts +15 -0
  94. package/lib/builder/models/builder-state.interface.d.ts +93 -0
  95. package/lib/builder/services/definition-builder.service.d.ts +80 -0
  96. package/lib/builder/services/definition-export.service.d.ts +59 -0
  97. package/lib/builder/services/definition-import.service.d.ts +31 -0
  98. package/lib/builder/services/sample-data-generator.service.d.ts +41 -0
  99. package/lib/builder/utils/config-validator.util.d.ts +32 -0
  100. package/lib/builder/utils/typescript-generator.util.d.ts +29 -0
  101. package/lib/editors/index.d.ts +8 -0
  102. package/lib/editors/nile-autocomplete-editor.d.ts +102 -0
  103. package/lib/editors/nile-calendar-editor.d.ts +89 -0
  104. package/lib/editors/nile-date-picker-editor.d.ts +95 -0
  105. package/lib/editors/nile-input-editor.d.ts +67 -0
  106. package/lib/editors/nile-select-editor.d.ts +109 -0
  107. package/lib/factories/column-config.factory.d.ts +73 -0
  108. package/lib/models/autosave-config.interface.d.ts +23 -0
  109. package/lib/models/base-column-config.class.d.ts +115 -0
  110. package/lib/models/cell-strategies.interface.d.ts +181 -0
  111. package/lib/models/cell-types.d.ts +337 -0
  112. package/lib/models/column-action.interface.d.ts +86 -0
  113. package/lib/models/column-config.interface.d.ts +272 -0
  114. package/lib/models/column-config.utils.d.ts +37 -0
  115. package/lib/models/row-action.interface.d.ts +86 -0
  116. package/lib/models/row-validator.interface.d.ts +37 -0
  117. package/lib/models/schema-validation.interface.d.ts +42 -0
  118. package/lib/models/sheet-action.interface.d.ts +59 -0
  119. package/lib/models/sheet-config.interface.d.ts +41 -0
  120. package/lib/models/table-config.interface.d.ts +245 -0
  121. package/lib/models/table-validator.interface.d.ts +40 -0
  122. package/lib/models/workbook-action.interface.d.ts +90 -0
  123. package/lib/models/workbook-config.interface.d.ts +107 -0
  124. package/lib/renderer/components/st-add-column-button/st-add-column-button.component.d.ts +9 -0
  125. package/lib/renderer/components/st-cell/st-cell.component.d.ts +69 -0
  126. package/lib/renderer/components/st-column-editor-modal/st-column-editor-modal.component.d.ts +39 -0
  127. package/lib/renderer/components/st-column-filter/st-column-filter.component.d.ts +139 -0
  128. package/lib/renderer/components/st-column-menu/st-column-menu.component.d.ts +81 -0
  129. package/lib/renderer/components/st-column-visibility/st-column-visibility.component.d.ts +44 -0
  130. package/lib/renderer/components/st-header/st-header.component.d.ts +93 -0
  131. package/lib/renderer/components/st-pagination/st-pagination.component.d.ts +42 -0
  132. package/lib/renderer/components/st-row-actions-dropdown/st-row-actions-dropdown.component.d.ts +67 -0
  133. package/lib/renderer/components/st-sheet/st-sheet.component.d.ts +98 -0
  134. package/lib/renderer/components/st-sheet-actions/st-sheet-actions.component.d.ts +58 -0
  135. package/lib/renderer/components/st-table/st-table.component.d.ts +349 -0
  136. package/lib/renderer/components/st-table-actions/st-table-actions.component.d.ts +77 -0
  137. package/lib/renderer/components/st-workbook/st-workbook.component.d.ts +235 -0
  138. package/lib/renderer/directives/click-outside.directive.d.ts +10 -0
  139. package/lib/renderer/directives/st-column-resize.directive.d.ts +44 -0
  140. package/lib/renderer/directives/st-keyboard-navigation.directive.d.ts +15 -0
  141. package/lib/renderer/models/cell-state.interface.d.ts +118 -0
  142. package/lib/renderer/models/cell.class.d.ts +174 -0
  143. package/lib/renderer/models/row-validation-state.interface.d.ts +27 -0
  144. package/lib/renderer/models/sheet-state.class.d.ts +67 -0
  145. package/lib/renderer/models/sheet-state.interface.d.ts +55 -0
  146. package/lib/renderer/models/table-state.class.d.ts +313 -0
  147. package/lib/renderer/models/table-state.interface.d.ts +18 -0
  148. package/lib/renderer/models/table-types.d.ts +228 -0
  149. package/lib/renderer/models/table-validation-state.interface.d.ts +34 -0
  150. package/lib/renderer/models/workbook-state.class.d.ts +117 -0
  151. package/lib/renderer/models/workbook-state.interface.d.ts +71 -0
  152. package/lib/renderer/models/z-index.enum.d.ts +44 -0
  153. package/lib/schemas/table-config.schema.d.ts +455 -0
  154. package/lib/services/autosave.service.d.ts +73 -0
  155. package/lib/services/custom-validation-rules.util.d.ts +12 -0
  156. package/lib/services/json-schema-validator.service.d.ts +49 -0
  157. package/lib/services/row-validation.service.d.ts +17 -0
  158. package/lib/services/validation-logger.service.d.ts +87 -0
  159. package/lib/services/virtual-scroll.service.d.ts +44 -0
  160. package/lib/shared/shared-table-components.module.d.ts +9 -0
  161. package/lib/smart-table.module.d.ts +26 -0
  162. package/lib/strategies/default-editors.d.ts +109 -0
  163. package/lib/strategies/default-formatters.d.ts +116 -0
  164. package/lib/strategies/default-validators.d.ts +113 -0
  165. package/package.json +42 -0
  166. package/public-api.d.ts +70 -0
  167. package/src/lib/builder/README.md +30 -0
  168. package/src/lib/editors/README.md +303 -0
  169. package/src/lib/renderer/components/st-column-filter/README.md +286 -0
@@ -0,0 +1,167 @@
1
+ /**
2
+ * Definition export service
3
+ * Handles exporting TableConfig to JSON or TypeScript
4
+ */
5
+ import { Injectable } from '@angular/core';
6
+ import { generateTypeScriptCode } from '../utils/typescript-generator.util';
7
+ import * as i0 from "@angular/core";
8
+ export class DefinitionExportService {
9
+ /**
10
+ * Export TableConfig to JSON string
11
+ * @param config Table configuration
12
+ * @param pretty Whether to format JSON with indentation
13
+ * @returns JSON string
14
+ */
15
+ exportToJSON(config, pretty = true) {
16
+ // Create a serializable version (remove functions, circular refs)
17
+ const serializable = this.sanitizeForJSON(config);
18
+ if (pretty) {
19
+ return JSON.stringify(serializable, null, 2);
20
+ }
21
+ else {
22
+ return JSON.stringify(serializable);
23
+ }
24
+ }
25
+ /**
26
+ * Export TableConfig to TypeScript code
27
+ * @param config Table configuration
28
+ * @param options Generation options
29
+ * @returns TypeScript code string
30
+ */
31
+ exportToTypeScript(config, options = {}) {
32
+ return generateTypeScriptCode(config, options);
33
+ }
34
+ /**
35
+ * Download configuration as JSON file
36
+ * @param config Table configuration
37
+ * @param fileName File name (without extension)
38
+ */
39
+ downloadAsJSON(config, fileName = 'table-config') {
40
+ const json = this.exportToJSON(config);
41
+ this.downloadFile(json, `${fileName}.json`, 'application/json');
42
+ }
43
+ /**
44
+ * Download configuration as TypeScript file
45
+ * @param config Table configuration
46
+ * @param fileName File name (without extension)
47
+ * @param options Generation options
48
+ */
49
+ downloadAsTypeScript(config, fileName = 'table-config', options = {}) {
50
+ const code = this.exportToTypeScript(config, options);
51
+ this.downloadFile(code, `${fileName}.ts`, 'text/typescript');
52
+ }
53
+ /**
54
+ * Save configuration to localStorage
55
+ * @param config Table configuration
56
+ * @param key Storage key
57
+ */
58
+ saveToLocalStorage(config, key = 'smart-table-definition') {
59
+ try {
60
+ const json = this.exportToJSON(config, false);
61
+ localStorage.setItem(key, json);
62
+ }
63
+ catch (error) {
64
+ console.error('Failed to save to localStorage:', error);
65
+ throw error;
66
+ }
67
+ }
68
+ /**
69
+ * Load configuration from localStorage
70
+ * @param key Storage key
71
+ * @returns TableConfig or null if not found
72
+ */
73
+ loadFromLocalStorage(key = 'smart-table-definition') {
74
+ try {
75
+ const stored = localStorage.getItem(key);
76
+ if (!stored) {
77
+ return null;
78
+ }
79
+ return JSON.parse(stored);
80
+ }
81
+ catch (error) {
82
+ console.error('Failed to load from localStorage:', error);
83
+ return null;
84
+ }
85
+ }
86
+ /**
87
+ * Sanitize config for JSON serialization
88
+ * Removes functions, circular references, and other non-serializable values
89
+ */
90
+ sanitizeForJSON(config) {
91
+ const sanitized = {
92
+ columns: config.columns.map(col => this.sanitizeColumn(col)),
93
+ pagination: config.pagination,
94
+ sorting: config.sorting,
95
+ filtering: config.filtering,
96
+ display: config.display,
97
+ initialState: config.initialState
98
+ };
99
+ // Remove undefined values
100
+ Object.keys(sanitized).forEach(key => {
101
+ if (sanitized[key] === undefined) {
102
+ delete sanitized[key];
103
+ }
104
+ });
105
+ return sanitized;
106
+ }
107
+ /**
108
+ * Sanitize column config for JSON serialization
109
+ */
110
+ sanitizeColumn(column) {
111
+ const sanitized = {
112
+ key: column.key,
113
+ header: column.header,
114
+ dataType: column.dataType,
115
+ editable: column.editable,
116
+ sortable: column.sortable,
117
+ filterable: column.filterable,
118
+ resizable: column.resizable,
119
+ width: column.width,
120
+ minWidth: column.minWidth,
121
+ maxWidth: column.maxWidth,
122
+ sticky: column.sticky,
123
+ alignment: column.alignment,
124
+ verticalAlignment: column.verticalAlignment,
125
+ className: column.className,
126
+ style: column.style,
127
+ tooltip: column.tooltip,
128
+ visible: column.visible,
129
+ pinned: column.pinned,
130
+ sortPriority: column.sortPriority,
131
+ metadata: column.metadata
132
+ };
133
+ // Remove undefined values
134
+ Object.keys(sanitized).forEach(key => {
135
+ if (sanitized[key] === undefined) {
136
+ delete sanitized[key];
137
+ }
138
+ });
139
+ // Note: formatter, validator, editor, parser, hooks are functions
140
+ // and cannot be serialized to JSON. They will need to be recreated
141
+ // when importing, or stored separately as metadata.
142
+ return sanitized;
143
+ }
144
+ /**
145
+ * Download file helper
146
+ */
147
+ downloadFile(content, fileName, mimeType) {
148
+ const blob = new Blob([content], { type: mimeType });
149
+ const url = URL.createObjectURL(blob);
150
+ const link = document.createElement('a');
151
+ link.href = url;
152
+ link.download = fileName;
153
+ document.body.appendChild(link);
154
+ link.click();
155
+ document.body.removeChild(link);
156
+ URL.revokeObjectURL(url);
157
+ }
158
+ }
159
+ DefinitionExportService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: DefinitionExportService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
160
+ DefinitionExportService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: DefinitionExportService, providedIn: 'root' });
161
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: DefinitionExportService, decorators: [{
162
+ type: Injectable,
163
+ args: [{
164
+ providedIn: 'root'
165
+ }]
166
+ }] });
167
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmaW5pdGlvbi1leHBvcnQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NtYXJ0LXRhYmxlL3NyYy9saWIvYnVpbGRlci9zZXJ2aWNlcy9kZWZpbml0aW9uLWV4cG9ydC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUVILE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHM0MsT0FBTyxFQUFFLHNCQUFzQixFQUE4QixNQUFNLG9DQUFvQyxDQUFDOztBQUt4RyxNQUFNLE9BQU8sdUJBQXVCO0lBQ2xDOzs7OztPQUtHO0lBQ0gsWUFBWSxDQUFDLE1BQW1CLEVBQUUsU0FBa0IsSUFBSTtRQUN0RCxrRUFBa0U7UUFDbEUsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUVsRCxJQUFJLE1BQU0sRUFBRTtZQUNWLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO1NBQzlDO2FBQU07WUFDTCxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWSxDQUFDLENBQUM7U0FDckM7SUFDSCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxrQkFBa0IsQ0FBQyxNQUFtQixFQUFFLFVBQXNDLEVBQUU7UUFDOUUsT0FBTyxzQkFBc0IsQ0FBQyxNQUFNLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDakQsQ0FBQztJQUVEOzs7O09BSUc7SUFDSCxjQUFjLENBQUMsTUFBbUIsRUFBRSxXQUFtQixjQUFjO1FBQ25FLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDdkMsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLEVBQUUsR0FBRyxRQUFRLE9BQU8sRUFBRSxrQkFBa0IsQ0FBQyxDQUFDO0lBQ2xFLENBQUM7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QUNoQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDYixRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNoQyxHQUFHLENBQUMsZUFBZSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzNCLENBQUM7O29IQXJLVSx1QkFBdUI7d0hBQXZCLHVCQUF1QixjQUZ0QixNQUFNOzJGQUVQLHVCQUF1QjtrQkFIbkMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIERlZmluaXRpb24gZXhwb3J0IHNlcnZpY2VcbiAqIEhhbmRsZXMgZXhwb3J0aW5nIFRhYmxlQ29uZmlnIHRvIEpTT04gb3IgVHlwZVNjcmlwdFxuICovXG5cbmltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRhYmxlQ29uZmlnIH0gZnJvbSAnLi4vLi4vbW9kZWxzL3RhYmxlLWNvbmZpZy5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgRXhwb3J0T3B0aW9ucyB9IGZyb20gJy4uL21vZGVscy9idWlsZGVyLXN0YXRlLmludGVyZmFjZSc7XG5pbXBvcnQgeyBnZW5lcmF0ZVR5cGVTY3JpcHRDb2RlLCBUeXBlU2NyaXB0R2VuZXJhdG9yT3B0aW9ucyB9IGZyb20gJy4uL3V0aWxzL3R5cGVzY3JpcHQtZ2VuZXJhdG9yLnV0aWwnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBEZWZpbml0aW9uRXhwb3J0U2VydmljZSB7XG4gIC8qKlxuICAgKiBFeHBvcnQgVGFibGVDb25maWcgdG8gSlNPTiBzdHJpbmdcbiAgICogQHBhcmFtIGNvbmZpZyBUYWJsZSBjb25maWd1cmF0aW9uXG4gICAqIEBwYXJhbSBwcmV0dHkgV2hldGhlciB0byBmb3JtYXQgSlNPTiB3aXRoIGluZGVudGF0aW9uXG4gICAqIEByZXR1cm5zIEpTT04gc3RyaW5nXG4gICAqL1xuICBleHBvcnRUb0pTT04oY29uZmlnOiBUYWJsZUNvbmZpZywgcHJldHR5OiBib29sZWFuID0gdHJ1ZSk6IHN0cmluZyB7XG4gICAgLy8gQ3JlYXRlIGEgc2VyaWFsaXphYmxlIHZlcnNpb24gKHJlbW92ZSBmdW5jdGlvbnMsIGNpcmN1bGFyIHJlZnMpXG4gICAgY29uc3Qgc2VyaWFsaXphYmxlID0gdGhpcy5zYW5pdGl6ZUZvckpTT04oY29uZmlnKTtcblxuICAgIGlmIChwcmV0dHkpIHtcbiAgICAgIHJldHVybiBKU09OLnN0cmluZ2lmeShzZXJpYWxpemFibGUsIG51bGwsIDIpO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gSlNPTi5zdHJpbmdpZnkoc2VyaWFsaXphYmxlKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogRXhwb3J0IFRhYmxlQ29uZmlnIHRvIFR5cGVTY3JpcHQgY29kZVxuICAgKiBAcGFyYW0gY29uZmlnIFRhYmxlIGNvbmZpZ3VyYXRpb25cbiAgICogQHBhcmFtIG9wdGlvbnMgR2VuZXJhdGlvbiBvcHRpb25zXG4gICAqIEByZXR1cm5zIFR5cGVTY3JpcHQgY29kZSBzdHJpbmdcbiAgICovXG4gIGV4cG9ydFRvVHlwZVNjcmlwdChjb25maWc6IFRhYmxlQ29uZmlnLCBvcHRpb25zOiBUeXBlU2NyaXB0R2VuZXJhdG9yT3B0aW9ucyA9IHt9KTogc3RyaW5nIHtcbiAgICByZXR1cm4gZ2VuZXJhdGVUeXBlU2NyaXB0Q29kZShjb25maWcsIG9wdGlvbnMpO1xuICB9XG5cbiAgLyoqXG4gICAqIERvd25sb2FkIGNvbmZpZ3VyYXRpb24gYXMgSlNPTiBmaWxlXG4gICAqIEBwYXJhbSBjb25maWcgVGFibGUgY29uZmlndXJhdGlvblxuICAgKiBAcGFyYW0gZmlsZU5hbWUgRmlsZSBuYW1lICh3aXRob3V0IGV4dGVuc2lvbilcbiAgICovXG4gIGRvd25sb2FkQXNKU09OKGNvbmZpZzogVGFibGVDb25maWcsIGZpbGVOYW1lOiBzdHJpbmcgPSAndGFibGUtY29uZmlnJyk6IHZvaWQge1xuICAgIGNvbnN0IGpzb24gPSB0aGlzLmV4cG9ydFRvSlNPTihjb25maWcpO1xuICAgIHRoaXMuZG93bmxvYWRGaWxlKGpzb24sIGAke2ZpbGVOYW1lfS5qc29uYCwgJ2FwcGxpY2F0aW9uL2pzb24nKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBEb3dubG9hZCBjb25maWd1cmF0aW9uIGFzIFR5cGVTY3JpcHQgZmlsZVxuICAgKiBAcGFyYW0gY29uZmlnIFRhYmxlIGNvbmZpZ3VyYXRpb25cbiAgICogQHBhcmFtIGZpbGVOYW1lIEZpbGUgbmFtZSAod2l0aG91dCBleHRlbnNpb24pXG4gICAqIEBwYXJhbSBvcHRpb25zIEdlbmVyYXRpb24gb3B0aW9uc1xuICAgKi9cbiAgZG93bmxvYWRBc1R5cGVTY3JpcHQoXG4gICAgY29uZmlnOiBUYWJsZUNvbmZpZyxcbiAgICBmaWxlTmFtZTogc3RyaW5nID0gJ3RhYmxlLWNvbmZpZycsXG4gICAgb3B0aW9uczogVHlwZVNjcmlwdEdlbmVyYXRvck9wdGlvbnMgPSB7fVxuICApOiB2b2lkIHtcbiAgICBjb25zdCBjb2RlID0gdGhpcy5leHBvcnRUb1R5cGVTY3JpcHQoY29uZmlnLCBvcHRpb25zKTtcbiAgICB0aGlzLmRvd25sb2FkRmlsZShjb2RlLCBgJHtmaWxlTmFtZX0udHNgLCAndGV4dC90eXBlc2NyaXB0Jyk7XG4gIH1cblxuICAvKipcbiAgICogU2F2ZSBjb25maWd1cmF0aW9uIHRvIGxvY2FsU3RvcmFnZVxuICAgKiBAcGFyYW0gY29uZmlnIFRhYmxlIGNvbmZpZ3VyYXRpb25cbiAgICogQHBhcmFtIGtleSBTdG9yYWdlIGtleVxuICAgKi9cbiAgc2F2ZVRvTG9jYWxTdG9yYWdlKGNvbmZpZzogVGFibGVDb25maWcsIGtleTogc3RyaW5nID0gJ3NtYXJ0LXRhYmxlLWRlZmluaXRpb24nKTogdm9pZCB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IGpzb24gPSB0aGlzLmV4cG9ydFRvSlNPTihjb25maWcsIGZhbHNlKTtcbiAgICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGtleSwganNvbik7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGNvbnNvbGUuZXJyb3IoJ0ZhaWxlZCB0byBzYXZlIHRvIGxvY2FsU3RvcmFnZTonLCBlcnJvcik7XG4gICAgICB0aHJvdyBlcnJvcjtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogTG9hZCBjb25maWd1cmF0aW9uIGZyb20gbG9jYWxTdG9yYWdlXG4gICAqIEBwYXJhbSBrZXkgU3RvcmFnZSBrZXlcbiAgICogQHJldHVybnMgVGFibGVDb25maWcgb3IgbnVsbCBpZiBub3QgZm91bmRcbiAgICovXG4gIGxvYWRGcm9tTG9jYWxTdG9yYWdlKGtleTogc3RyaW5nID0gJ3NtYXJ0LXRhYmxlLWRlZmluaXRpb24nKTogVGFibGVDb25maWcgfCBudWxsIHtcbiAgICB0cnkge1xuICAgICAgY29uc3Qgc3RvcmVkID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0oa2V5KTtcbiAgICAgIGlmICghc3RvcmVkKSB7XG4gICAgICAgIHJldHVybiBudWxsO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gSlNPTi5wYXJzZShzdG9yZWQpIGFzIFRhYmxlQ29uZmlnO1xuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBjb25zb2xlLmVycm9yKCdGYWlsZWQgdG8gbG9hZCBmcm9tIGxvY2FsU3RvcmFnZTonLCBlcnJvcik7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogU2FuaXRpemUgY29uZmlnIGZvciBKU09OIHNlcmlhbGl6YXRpb25cbiAgICogUmVtb3ZlcyBmdW5jdGlvbnMsIGNpcmN1bGFyIHJlZmVyZW5jZXMsIGFuZCBvdGhlciBub24tc2VyaWFsaXphYmxlIHZhbHVlc1xuICAgKi9cbiAgcHJpdmF0ZSBzYW5pdGl6ZUZvckpTT04oY29uZmlnOiBUYWJsZUNvbmZpZyk6IGFueSB7XG4gICAgY29uc3Qgc2FuaXRpemVkOiBhbnkgPSB7XG4gICAgICBjb2x1bW5zOiBjb25maWcuY29sdW1ucy5tYXAoY29sID0+IHRoaXMuc2FuaXRpemVDb2x1bW4oY29sKSksXG4gICAgICBwYWdpbmF0aW9uOiBjb25maWcucGFnaW5hdGlvbixcbiAgICAgIHNvcnRpbmc6IGNvbmZpZy5zb3J0aW5nLFxuICAgICAgZmlsdGVyaW5nOiBjb25maWcuZmlsdGVyaW5nLFxuICAgICAgZGlzcGxheTogY29uZmlnLmRpc3BsYXksXG4gICAgICBpbml0aWFsU3RhdGU6IGNvbmZpZy5pbml0aWFsU3RhdGVcbiAgICB9O1xuXG4gICAgLy8gUmVtb3ZlIHVuZGVmaW5lZCB2YWx1ZXNcbiAgICBPYmplY3Qua2V5cyhzYW5pdGl6ZWQpLmZvckVhY2goa2V5ID0+IHtcbiAgICAgIGlmIChzYW5pdGl6ZWRba2V5XSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgIGRlbGV0ZSBzYW5pdGl6ZWRba2V5XTtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIHJldHVybiBzYW5pdGl6ZWQ7XG4gIH1cblxuICAvKipcbiAgICogU2FuaXRpemUgY29sdW1uIGNvbmZpZyBmb3IgSlNPTiBzZXJpYWxpemF0aW9uXG4gICAqL1xuICBwcml2YXRlIHNhbml0aXplQ29sdW1uKGNvbHVtbjogYW55KTogYW55IHtcbiAgICBjb25zdCBzYW5pdGl6ZWQ6IGFueSA9IHtcbiAgICAgIGtleTogY29sdW1uLmtleSxcbiAgICAgIGhlYWRlcjogY29sdW1uLmhlYWRlcixcbiAgICAgIGRhdGFUeXBlOiBjb2x1bW4uZGF0YVR5cGUsXG4gICAgICBlZGl0YWJsZTogY29sdW1uLmVkaXRhYmxlLFxuICAgICAgc29ydGFibGU6IGNvbHVtbi5zb3J0YWJsZSxcbiAgICAgIGZpbHRlcmFibGU6IGNvbHVtbi5maWx0ZXJhYmxlLFxuICAgICAgcmVzaXphYmxlOiBjb2x1bW4ucmVzaXphYmxlLFxuICAgICAgd2lkdGg6IGNvbHVtbi53aWR0aCxcbiAgICAgIG1pbldpZHRoOiBjb2x1bW4ubWluV2lkdGgsXG4gICAgICBtYXhXaWR0aDogY29sdW1uLm1heFdpZHRoLFxuICAgICAgc3RpY2t5OiBjb2x1bW4uc3RpY2t5LFxuICAgICAgYWxpZ25tZW50OiBjb2x1bW4uYWxpZ25tZW50LFxuICAgICAgdmVydGljYWxBbGlnbm1lbnQ6IGNvbHVtbi52ZXJ0aWNhbEFsaWdubWVudCxcbiAgICAgIGNsYXNzTmFtZTogY29sdW1uLmNsYXNzTmFtZSxcbiAgICAgIHN0eWxlOiBjb2x1bW4uc3R5bGUsXG4gICAgICB0b29sdGlwOiBjb2x1bW4udG9vbHRpcCxcbiAgICAgIHZpc2libGU6IGNvbHVtbi52aXNpYmxlLFxuICAgICAgcGlubmVkOiBjb2x1bW4ucGlubmVkLFxuICAgICAgc29ydFByaW9yaXR5OiBjb2x1bW4uc29ydFByaW9yaXR5LFxuICAgICAgbWV0YWRhdGE6IGNvbHVtbi5tZXRhZGF0YVxuICAgIH07XG5cbiAgICAvLyBSZW1vdmUgdW5kZWZpbmVkIHZhbHVlc1xuICAgIE9iamVjdC5rZXlzKHNhbml0aXplZCkuZm9yRWFjaChrZXkgPT4ge1xuICAgICAgaWYgKHNhbml0aXplZFtrZXldID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgZGVsZXRlIHNhbml0aXplZFtrZXldO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgLy8gTm90ZTogZm9ybWF0dGVyLCB2YWxpZGF0b3IsIGVkaXRvciwgcGFyc2VyLCBob29rcyBhcmUgZnVuY3Rpb25zXG4gICAgLy8gYW5kIGNhbm5vdCBiZSBzZXJpYWxpemVkIHRvIEpTT04uIFRoZXkgd2lsbCBuZWVkIHRvIGJlIHJlY3JlYXRlZFxuICAgIC8vIHdoZW4gaW1wb3J0aW5nLCBvciBzdG9yZWQgc2VwYXJhdGVseSBhcyBtZXRhZGF0YS5cblxuICAgIHJldHVybiBzYW5pdGl6ZWQ7XG4gIH1cblxuICAvKipcbiAgICogRG93bmxvYWQgZmlsZSBoZWxwZXJcbiAgICovXG4gIHByaXZhdGUgZG93bmxvYWRGaWxlKGNvbnRlbnQ6IHN0cmluZywgZmlsZU5hbWU6IHN0cmluZywgbWltZVR5cGU6IHN0cmluZyk6IHZvaWQge1xuICAgIGNvbnN0IGJsb2IgPSBuZXcgQmxvYihbY29udGVudF0sIHsgdHlwZTogbWltZVR5cGUgfSk7XG4gICAgY29uc3QgdXJsID0gVVJMLmNyZWF0ZU9iamVjdFVSTChibG9iKTtcbiAgICBjb25zdCBsaW5rID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnYScpO1xuICAgIGxpbmsuaHJlZiA9IHVybDtcbiAgICBsaW5rLmRvd25sb2FkID0gZmlsZU5hbWU7XG4gICAgZG9jdW1lbnQuYm9keS5hcHBlbmRDaGlsZChsaW5rKTtcbiAgICBsaW5rLmNsaWNrKCk7XG4gICAgZG9jdW1lbnQuYm9keS5yZW1vdmVDaGlsZChsaW5rKTtcbiAgICBVUkwucmV2b2tlT2JqZWN0VVJMKHVybCk7XG4gIH1cbn1cblxuIl19
@@ -0,0 +1,193 @@
1
+ /**
2
+ * Definition import service
3
+ * Handles importing TableConfig from JSON with validation
4
+ */
5
+ import { Injectable } from '@angular/core';
6
+ import { mergeTableConfig } from '../../models/table-config.interface';
7
+ import { validateTableConfig } from '../utils/config-validator.util';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "../../services/json-schema-validator.service";
10
+ import * as i2 from "../../services/validation-logger.service";
11
+ export class DefinitionImportService {
12
+ constructor(schemaValidator, logger) {
13
+ this.schemaValidator = schemaValidator;
14
+ this.logger = logger;
15
+ }
16
+ /**
17
+ * Import TableConfig from JSON string
18
+ * @param jsonString JSON string to parse
19
+ * @param skipSchemaValidation Skip JSON schema validation (use custom validation only)
20
+ * @param fileName Optional filename for logging context
21
+ * @returns Import result with success status and config or errors
22
+ */
23
+ importFromJSON(jsonString, skipSchemaValidation = false, fileName) {
24
+ try {
25
+ // Parse JSON
26
+ const parsed = JSON.parse(jsonString);
27
+ // Validate structure
28
+ if (!parsed || typeof parsed !== 'object') {
29
+ return {
30
+ success: false,
31
+ error: 'Invalid JSON: root must be an object',
32
+ validationErrors: ['Root must be an object']
33
+ };
34
+ }
35
+ // JSON Schema validation (if enabled and available)
36
+ let schemaErrors = [];
37
+ if (!skipSchemaValidation && this.schemaValidator.isAvailable()) {
38
+ const schemaResult = this.schemaValidator.validateJSONString(jsonString, true);
39
+ if (!schemaResult.valid) {
40
+ schemaErrors = schemaResult.errors;
41
+ }
42
+ }
43
+ // Check for columns array (basic validation)
44
+ if (!parsed.columns || !Array.isArray(parsed.columns)) {
45
+ return {
46
+ success: false,
47
+ error: 'Invalid configuration: columns array is required',
48
+ validationErrors: [
49
+ 'Columns array is required',
50
+ ...schemaErrors.map(err => `${err.field || err.path}: ${err.message}`)
51
+ ]
52
+ };
53
+ }
54
+ // Create TableConfig object
55
+ const tableConfig = {
56
+ columns: parsed.columns,
57
+ pagination: parsed.pagination,
58
+ sorting: parsed.sorting,
59
+ filtering: parsed.filtering,
60
+ display: parsed.display,
61
+ initialState: parsed.initialState
62
+ };
63
+ // Merge with defaults
64
+ const mergedConfig = mergeTableConfig(tableConfig);
65
+ // Custom validation (for additional business rules)
66
+ const customValidationErrors = validateTableConfig(mergedConfig);
67
+ // Combine all validation errors
68
+ const allErrors = [
69
+ ...schemaErrors.map(err => `${err.field || err.path}: ${err.message}`),
70
+ ...customValidationErrors.map(err => `${err.field}: ${err.message}`)
71
+ ];
72
+ if (allErrors.length > 0) {
73
+ // Log validation errors
74
+ const allSchemaErrors = [
75
+ ...schemaErrors,
76
+ ...customValidationErrors.map(err => ({
77
+ path: err.field || '',
78
+ message: err.message,
79
+ code: err.code || 'VALIDATION_ERROR',
80
+ field: err.field
81
+ }))
82
+ ];
83
+ this.logger.logValidationErrors(allSchemaErrors, 'import', {
84
+ fileName: fileName,
85
+ configSnippet: jsonString.substring(0, 500) // Include first 500 chars as context
86
+ });
87
+ return {
88
+ success: false,
89
+ error: 'Configuration validation failed',
90
+ validationErrors: allErrors
91
+ };
92
+ }
93
+ return {
94
+ success: true,
95
+ tableConfig: mergedConfig
96
+ };
97
+ }
98
+ catch (error) {
99
+ return {
100
+ success: false,
101
+ error: `Failed to parse JSON: ${error.message}`,
102
+ validationErrors: [error.message]
103
+ };
104
+ }
105
+ }
106
+ /**
107
+ * Import TableConfig from File object
108
+ * @param file File to read
109
+ * @returns Promise with import result
110
+ */
111
+ async importFromFile(file) {
112
+ return new Promise((resolve) => {
113
+ const reader = new FileReader();
114
+ reader.onload = (event) => {
115
+ const content = event.target?.result;
116
+ const result = this.importFromJSON(content, true, file.name);
117
+ resolve(result);
118
+ };
119
+ reader.onerror = () => {
120
+ const errorResult = {
121
+ success: false,
122
+ error: 'Failed to read file',
123
+ validationErrors: ['File read error']
124
+ };
125
+ // Log file read error
126
+ this.logger.logValidationErrors([{
127
+ path: '',
128
+ message: 'Failed to read file',
129
+ code: 'FILE_READ_ERROR',
130
+ field: 'root'
131
+ }], 'import', {
132
+ fileName: file.name
133
+ });
134
+ resolve(errorResult);
135
+ };
136
+ reader.readAsText(file);
137
+ });
138
+ }
139
+ /**
140
+ * Import TableConfig from localStorage
141
+ * @param key Storage key
142
+ * @returns Import result
143
+ */
144
+ importFromLocalStorage(key = 'smart-table-definition') {
145
+ try {
146
+ const stored = localStorage.getItem(key);
147
+ if (!stored) {
148
+ const errorResult = {
149
+ success: false,
150
+ error: 'No data found in localStorage',
151
+ validationErrors: ['No data found']
152
+ };
153
+ // Log localStorage read error
154
+ this.logger.logValidationErrors([{
155
+ path: '',
156
+ message: 'No data found in localStorage',
157
+ code: 'STORAGE_NOT_FOUND',
158
+ field: 'root'
159
+ }], 'import', {
160
+ storageKey: key
161
+ });
162
+ return errorResult;
163
+ }
164
+ return this.importFromJSON(stored, true, undefined);
165
+ }
166
+ catch (error) {
167
+ const errorResult = {
168
+ success: false,
169
+ error: `Failed to read from localStorage: ${error.message}`,
170
+ validationErrors: [error.message]
171
+ };
172
+ // Log localStorage error
173
+ this.logger.logValidationErrors([{
174
+ path: '',
175
+ message: `Failed to read from localStorage: ${error.message}`,
176
+ code: 'STORAGE_READ_ERROR',
177
+ field: 'root'
178
+ }], 'import', {
179
+ storageKey: key
180
+ });
181
+ return errorResult;
182
+ }
183
+ }
184
+ }
185
+ DefinitionImportService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: DefinitionImportService, deps: [{ token: i1.JsonSchemaValidatorService }, { token: i2.ValidationLoggerService }], target: i0.ɵɵFactoryTarget.Injectable });
186
+ DefinitionImportService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: DefinitionImportService, providedIn: 'root' });
187
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: DefinitionImportService, decorators: [{
188
+ type: Injectable,
189
+ args: [{
190
+ providedIn: 'root'
191
+ }]
192
+ }], ctorParameters: function () { return [{ type: i1.JsonSchemaValidatorService }, { type: i2.ValidationLoggerService }]; } });
193
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmaW5pdGlvbi1pbXBvcnQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NtYXJ0LXRhYmxlL3NyYy9saWIvYnVpbGRlci9zZXJ2aWNlcy9kZWZpbml0aW9uLWltcG9ydC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUVILE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFlLGdCQUFnQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFFcEYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7Ozs7QUFRckUsTUFBTSxPQUFPLHVCQUF1QjtJQUNsQyxZQUNVLGVBQTJDLEVBQzNDLE1BQStCO1FBRC9CLG9CQUFlLEdBQWYsZUFBZSxDQUE0QjtRQUMzQyxXQUFNLEdBQU4sTUFBTSxDQUF5QjtJQUN0QyxDQUFDO0lBQ0o7Ozs7OztPQU1HO0lBQ0gsY0FBYyxDQUFDLFVBQWtCLEVBQUUsdUJBQWdDLEtBQUssRUFBRSxRQUFpQjtRQUN6RixJQUFJO1lBQ0YsYUFBYTtZQUNiLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUM7WUFFdEMscUJBQXFCO1lBQ3JCLElBQUksQ0FBQyxNQUFNLElBQUksT0FBTyxNQUFNLEtBQUssUUFBUSxFQUFFO2dCQUN6QyxPQUFPO29CQUNMLE9BQU8sRUFBRSxLQUFLO29CQUNkLEtBQUssRUFBRSxzQ0FBc0M7b0JBQzdDLGdCQUFnQixFQUFFLENBQUMsd0JBQXdCLENBQUM7aUJBQzdDLENBQUM7YUFDSDtZQUVELG9EQUFvRDtZQUNwRCxJQUFJLFlBQVksR0FBNEIsRUFBRSxDQUFDO1lBQy9DLElBQUksQ0FBQyxvQkFBb0IsSUFBSSxJQUFJLENBQUMsZUFBZSxDQUFDLFdBQVcsRUFBRSxFQUFFO2dCQUMvRCxNQUFNLFlBQVksR0FB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QXFDLEtBQUssQ0FBQyxPQUFPLEVBQUU7b0JBQzdELElBQUksRUFBRSxvQkFBb0I7b0JBQzFCLEtBQUssRUFBRSxNQUFNO2lCQUNkLENBQUMsRUFBRSxRQUFRLEVBQUU7Z0JBQ1osVUFBVSxFQUFFLEdBQUc7YUFDaEIsQ0FBQyxDQUFDO1lBRUgsT0FBTyxXQUFXLENBQUM7U0FDcEI7SUFDSCxDQUFDOztvSEFqTVUsdUJBQXVCO3dIQUF2Qix1QkFBdUIsY0FGdEIsTUFBTTsyRkFFUCx1QkFBdUI7a0JBSG5DLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBEZWZpbml0aW9uIGltcG9ydCBzZXJ2aWNlXG4gKiBIYW5kbGVzIGltcG9ydGluZyBUYWJsZUNvbmZpZyBmcm9tIEpTT04gd2l0aCB2YWxpZGF0aW9uXG4gKi9cblxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGFibGVDb25maWcsIG1lcmdlVGFibGVDb25maWcgfSBmcm9tICcuLi8uLi9tb2RlbHMvdGFibGUtY29uZmlnLmludGVyZmFjZSc7XG5pbXBvcnQgeyBJbXBvcnRSZXN1bHQsIFZhbGlkYXRpb25FcnJvciB9IGZyb20gJy4uL21vZGVscy9idWlsZGVyLXN0YXRlLmludGVyZmFjZSc7XG5pbXBvcnQgeyB2YWxpZGF0ZVRhYmxlQ29uZmlnIH0gZnJvbSAnLi4vdXRpbHMvY29uZmlnLXZhbGlkYXRvci51dGlsJztcbmltcG9ydCB7IEpzb25TY2hlbWFWYWxpZGF0b3JTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvanNvbi1zY2hlbWEtdmFsaWRhdG9yLnNlcnZpY2UnO1xuaW1wb3J0IHsgU2NoZW1hVmFsaWRhdGlvbkVycm9yIH0gZnJvbSAnLi4vLi4vbW9kZWxzL3NjaGVtYS12YWxpZGF0aW9uLmludGVyZmFjZSc7XG5pbXBvcnQgeyBWYWxpZGF0aW9uTG9nZ2VyU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL3ZhbGlkYXRpb24tbG9nZ2VyLnNlcnZpY2UnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBEZWZpbml0aW9uSW1wb3J0U2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgc2NoZW1hVmFsaWRhdG9yOiBKc29uU2NoZW1hVmFsaWRhdG9yU2VydmljZSxcbiAgICBwcml2YXRlIGxvZ2dlcjogVmFsaWRhdGlvbkxvZ2dlclNlcnZpY2VcbiAgKSB7fVxuICAvKipcbiAgICogSW1wb3J0IFRhYmxlQ29uZmlnIGZyb20gSlNPTiBzdHJpbmdcbiAgICogQHBhcmFtIGpzb25TdHJpbmcgSlNPTiBzdHJpbmcgdG8gcGFyc2VcbiAgICogQHBhcmFtIHNraXBTY2hlbWFWYWxpZGF0aW9uIFNraXAgSlNPTiBzY2hlbWEgdmFsaWRhdGlvbiAodXNlIGN1c3RvbSB2YWxpZGF0aW9uIG9ubHkpXG4gICAqIEBwYXJhbSBmaWxlTmFtZSBPcHRpb25hbCBmaWxlbmFtZSBmb3IgbG9nZ2luZyBjb250ZXh0XG4gICAqIEByZXR1cm5zIEltcG9ydCByZXN1bHQgd2l0aCBzdWNjZXNzIHN0YXR1cyBhbmQgY29uZmlnIG9yIGVycm9yc1xuICAgKi9cbiAgaW1wb3J0RnJvbUpTT04oanNvblN0cmluZzogc3RyaW5nLCBza2lwU2NoZW1hVmFsaWRhdGlvbjogYm9vbGVhbiA9IGZhbHNlLCBmaWxlTmFtZT86IHN0cmluZyk6IEltcG9ydFJlc3VsdCB7XG4gICAgdHJ5IHtcbiAgICAgIC8vIFBhcnNlIEpTT05cbiAgICAgIGNvbnN0IHBhcnNlZCA9IEpTT04ucGFyc2UoanNvblN0cmluZyk7XG5cbiAgICAgIC8vIFZhbGlkYXRlIHN0cnVjdHVyZVxuICAgICAgaWYgKCFwYXJzZWQgfHwgdHlwZW9mIHBhcnNlZCAhPT0gJ29iamVjdCcpIHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICBzdWNjZXNzOiBmYWxzZSxcbiAgICAgICAgICBlcnJvcjogJ0ludmFsaWQgSlNPTjogcm9vdCBtdXN0IGJlIGFuIG9iamVjdCcsXG4gICAgICAgICAgdmFsaWRhdGlvbkVycm9yczogWydSb290IG11c3QgYmUgYW4gb2JqZWN0J11cbiAgICAgICAgfTtcbiAgICAgIH1cblxuICAgICAgLy8gSlNPTiBTY2hlbWEgdmFsaWRhdGlvbiAoaWYgZW5hYmxlZCBhbmQgYXZhaWxhYmxlKVxuICAgICAgbGV0IHNjaGVtYUVycm9yczogU2NoZW1hVmFsaWRhdGlvbkVycm9yW10gPSBbXTtcbiAgICAgIGlmICghc2tpcFNjaGVtYVZhbGlkYXRpb24gJiYgdGhpcy5zY2hlbWFWYWxpZGF0b3IuaXNBdmFpbGFibGUoKSkge1xuICAgICAgICBjb25zdCBzY2hlbWFSZXN1bHQgPSB0aGlzLnNjaGVtYVZhbGlkYXRvci52YWxpZGF0ZUpTT05TdHJpbmcoanNvblN0cmluZywgdHJ1ZSk7XG4gICAgICAgIGlmICghc2NoZW1hUmVzdWx0LnZhbGlkKSB7XG4gICAgICAgICAgc2NoZW1hRXJyb3JzID0gc2NoZW1hUmVzdWx0LmVycm9ycztcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICAvLyBDaGVjayBmb3IgY29sdW1ucyBhcnJheSAoYmFzaWMgdmFsaWRhdGlvbilcbiAgICAgIGlmICghcGFyc2VkLmNvbHVtbnMgfHwgIUFycmF5LmlzQXJyYXkocGFyc2VkLmNvbHVtbnMpKSB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgc3VjY2VzczogZmFsc2UsXG4gICAgICAgICAgZXJyb3I6ICdJbnZhbGlkIGNvbmZpZ3VyYXRpb246IGNvbHVtbnMgYXJyYXkgaXMgcmVxdWlyZWQnLFxuICAgICAgICAgIHZhbGlkYXRpb25FcnJvcnM6IFtcbiAgICAgICAgICAgICdDb2x1bW5zIGFycmF5IGlzIHJlcXVpcmVkJyxcbiAgICAgICAgICAgIC4uLnNjaGVtYUVycm9ycy5tYXAoZXJyID0+IGAke2Vyci5maWVsZCB8fCBlcnIucGF0aH06ICR7ZXJyLm1lc3NhZ2V9YClcbiAgICAgICAgICBdXG4gICAgICAgIH07XG4gICAgICB9XG5cbiAgICAgIC8vIENyZWF0ZSBUYWJsZUNvbmZpZyBvYmplY3RcbiAgICAgIGNvbnN0IHRhYmxlQ29uZmlnOiBUYWJsZUNvbmZpZyA9IHtcbiAgICAgICAgY29sdW1uczogcGFyc2VkLmNvbHVtbnMsXG4gICAgICAgIHBhZ2luYXRpb246IHBhcnNlZC5wYWdpbmF0aW9uLFxuICAgICAgICBzb3J0aW5nOiBwYXJzZWQuc29ydGluZyxcbiAgICAgICAgZmlsdGVyaW5nOiBwYXJzZWQuZmlsdGVyaW5nLFxuICAgICAgICBkaXNwbGF5OiBwYXJzZWQuZGlzcGxheSxcbiAgICAgICAgaW5pdGlhbFN0YXRlOiBwYXJzZWQuaW5pdGlhbFN0YXRlXG4gICAgICB9O1xuXG4gICAgICAvLyBNZXJnZSB3aXRoIGRlZmF1bHRzXG4gICAgICBjb25zdCBtZXJnZWRDb25maWcgPSBtZXJnZVRhYmxlQ29uZmlnKHRhYmxlQ29uZmlnKTtcblxuICAgICAgLy8gQ3VzdG9tIHZhbGlkYXRpb24gKGZvciBhZGRpdGlvbmFsIGJ1c2luZXNzIHJ1bGVzKVxuICAgICAgY29uc3QgY3VzdG9tVmFsaWRhdGlvbkVycm9ycyA9IHZhbGlkYXRlVGFibGVDb25maWcobWVyZ2VkQ29uZmlnKTtcbiAgICAgIFxuICAgICAgLy8gQ29tYmluZSBhbGwgdmFsaWRhdGlvbiBlcnJvcnNcbiAgICAgIGNvbnN0IGFsbEVycm9ycyA9IFtcbiAgICAgICAgLi4uc2NoZW1hRXJyb3JzLm1hcChlcnIgPT4gYCR7ZXJyLmZpZWxkIHx8IGVyci5wYXRofTogJHtlcnIubWVzc2FnZX1gKSxcbiAgICAgICAgLi4uY3VzdG9tVmFsaWRhdGlvbkVycm9ycy5tYXAoZXJyID0+IGAke2Vyci5maWVsZH06ICR7ZXJyLm1lc3NhZ2V9YClcbiAgICAgIF07XG5cbiAgICAgIGlmIChhbGxFcnJvcnMubGVuZ3RoID4gMCkge1xuICAgICAgICAvLyBMb2cgdmFsaWRhdGlvbiBlcnJvcnNcbiAgICAgICAgY29uc3QgYWxsU2NoZW1hRXJyb3JzOiBTY2hlbWFWYWxpZGF0aW9uRXJyb3JbXSA9IFtcbiAgICAgICAgICAuLi5zY2hlbWFFcnJvcnMsXG4gICAgICAgICAgLi4uY3VzdG9tVmFsaWRhdGlvbkVycm9ycy5tYXAoZXJyID0+ICh7XG4gICAgICAgICAgICBwYXRoOiBlcnIuZmllbGQgfHwgJycsXG4gICAgICAgICAgICBtZXNzYWdlOiBlcnIubWVzc2FnZSxcbiAgICAgICAgICAgIGNvZGU6IGVyci5jb2RlIHx8ICdWQUxJREFUSU9OX0VSUk9SJyxcbiAgICAgICAgICAgIGZpZWxkOiBlcnIuZmllbGRcbiAgICAgICAgICB9KSlcbiAgICAgICAgXTtcbiAgICAgICAgXG4gICAgICAgIHRoaXMubG9nZ2VyLmxvZ1ZhbGlkYXRpb25FcnJvcnMoYWxsU2NoZW1hRXJyb3JzLCAnaW1wb3J0Jywge1xuICAgICAgICAgIGZpbGVOYW1lOiBmaWxlTmFtZSxcbiAgICAgICAgICBjb25maWdTbmlwcGV0OiBqc29uU3RyaW5nLnN1YnN0cmluZygwLCA1MDApIC8vIEluY2x1ZGUgZmlyc3QgNTAwIGNoYXJzIGFzIGNvbnRleHRcbiAgICAgICAgfSk7XG5cbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICBzdWNjZXNzOiBmYWxzZSxcbiAgICAgICAgICBlcnJvcjogJ0NvbmZpZ3VyYXRpb24gdmFsaWRhdGlvbiBmYWlsZWQnLFxuICAgICAgICAgIHZhbGlkYXRpb25FcnJvcnM6IGFsbEVycm9yc1xuICAgICAgICB9O1xuICAgICAgfVxuXG4gICAgICByZXR1cm4ge1xuICAgICAgICBzdWNjZXNzOiB0cnVlLFxuICAgICAgICB0YWJsZUNvbmZpZzogbWVyZ2VkQ29uZmlnXG4gICAgICB9O1xuICAgIH0gY2F0Y2ggKGVycm9yOiBhbnkpIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIHN1Y2Nlc3M6IGZhbHNlLFxuICAgICAgICBlcnJvcjogYEZhaWxlZCB0byBwYXJzZSBKU09OOiAke2Vycm9yLm1lc3NhZ2V9YCxcbiAgICAgICAgdmFsaWRhdGlvbkVycm9yczogW2Vycm9yLm1lc3NhZ2VdXG4gICAgICB9O1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBJbXBvcnQgVGFibGVDb25maWcgZnJvbSBGaWxlIG9iamVjdFxuICAgKiBAcGFyYW0gZmlsZSBGaWxlIHRvIHJlYWRcbiAgICogQHJldHVybnMgUHJvbWlzZSB3aXRoIGltcG9ydCByZXN1bHRcbiAgICovXG4gIGFzeW5jIGltcG9ydEZyb21GaWxlKGZpbGU6IEZpbGUpOiBQcm9taXNlPEltcG9ydFJlc3VsdD4ge1xuICAgIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSkgPT4ge1xuICAgICAgY29uc3QgcmVhZGVyID0gbmV3IEZpbGVSZWFkZXIoKTtcblxuICAgICAgcmVhZGVyLm9ubG9hZCA9IChldmVudCkgPT4ge1xuICAgICAgICBjb25zdCBjb250ZW50ID0gZXZlbnQudGFyZ2V0Py5yZXN1bHQgYXMgc3RyaW5nO1xuICAgICAgICBjb25zdCByZXN1bHQgPSB0aGlzLmltcG9ydEZyb21KU09OKGNvbnRlbnQsIHRydWUsIGZpbGUubmFtZSk7XG4gICAgICAgIHJlc29sdmUocmVzdWx0KTtcbiAgICAgIH07XG5cbiAgICAgIHJlYWRlci5vbmVycm9yID0gKCkgPT4ge1xuICAgICAgICBjb25zdCBlcnJvclJlc3VsdCA9IHtcbiAgICAgICAgICBzdWNjZXNzOiBmYWxzZSxcbiAgICAgICAgICBlcnJvcjogJ0ZhaWxlZCB0byByZWFkIGZpbGUnLFxuICAgICAgICAgIHZhbGlkYXRpb25FcnJvcnM6IFsnRmlsZSByZWFkIGVycm9yJ11cbiAgICAgICAgfTtcbiAgICAgICAgXG4gICAgICAgIC8vIExvZyBmaWxlIHJlYWQgZXJyb3JcbiAgICAgICAgdGhpcy5sb2dnZXIubG9nVmFsaWRhdGlvbkVycm9ycyhbe1xuICAgICAgICAgIHBhdGg6ICcnLFxuICAgICAgICAgIG1lc3NhZ2U6ICdGYWlsZWQgdG8gcmVhZCBmaWxlJyxcbiAgICAgICAgICBjb2RlOiAnRklMRV9SRUFEX0VSUk9SJyxcbiAgICAgICAgICBmaWVsZDogJ3Jvb3QnXG4gICAgICAgIH1dLCAnaW1wb3J0Jywge1xuICAgICAgICAgIGZpbGVOYW1lOiBmaWxlLm5hbWVcbiAgICAgICAgfSk7XG4gICAgICAgIFxuICAgICAgICByZXNvbHZlKGVycm9yUmVzdWx0KTtcbiAgICAgIH07XG5cbiAgICAgIHJlYWRlci5yZWFkQXNUZXh0KGZpbGUpO1xuICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIEltcG9ydCBUYWJsZUNvbmZpZyBmcm9tIGxvY2FsU3RvcmFnZVxuICAgKiBAcGFyYW0ga2V5IFN0b3JhZ2Uga2V5XG4gICAqIEByZXR1cm5zIEltcG9ydCByZXN1bHRcbiAgICovXG4gIGltcG9ydEZyb21Mb2NhbFN0b3JhZ2Uoa2V5OiBzdHJpbmcgPSAnc21hcnQtdGFibGUtZGVmaW5pdGlvbicpOiBJbXBvcnRSZXN1bHQge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCBzdG9yZWQgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbShrZXkpO1xuICAgICAgaWYgKCFzdG9yZWQpIHtcbiAgICAgICAgY29uc3QgZXJyb3JSZXN1bHQgPSB7XG4gICAgICAgICAgc3VjY2VzczogZmFsc2UsXG4gICAgICAgICAgZXJyb3I6ICdObyBkYXRhIGZvdW5kIGluIGxvY2FsU3RvcmFnZScsXG4gICAgICAgICAgdmFsaWRhdGlvbkVycm9yczogWydObyBkYXRhIGZvdW5kJ11cbiAgICAgICAgfTtcbiAgICAgICAgXG4gICAgICAgIC8vIExvZyBsb2NhbFN0b3JhZ2UgcmVhZCBlcnJvclxuICAgICAgICB0aGlzLmxvZ2dlci5sb2dWYWxpZGF0aW9uRXJyb3JzKFt7XG4gICAgICAgICAgcGF0aDogJycsXG4gICAgICAgICAgbWVzc2FnZTogJ05vIGRhdGEgZm91bmQgaW4gbG9jYWxTdG9yYWdlJyxcbiAgICAgICAgICBjb2RlOiAnU1RPUkFHRV9OT1RfRk9VTkQnLFxuICAgICAgICAgIGZpZWxkOiAncm9vdCdcbiAgICAgICAgfV0sICdpbXBvcnQnLCB7XG4gICAgICAgICAgc3RvcmFnZUtleToga2V5XG4gICAgICAgIH0pO1xuICAgICAgICBcbiAgICAgICAgcmV0dXJuIGVycm9yUmVzdWx0O1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gdGhpcy5pbXBvcnRGcm9tSlNPTihzdG9yZWQsIHRydWUsIHVuZGVmaW5lZCk7XG4gICAgfSBjYXRjaCAoZXJyb3I6IGFueSkge1xuICAgICAgY29uc3QgZXJyb3JSZXN1bHQgPSB7XG4gICAgICAgIHN1Y2Nlc3M6IGZhbHNlLFxuICAgICAgICBlcnJvcjogYEZhaWxlZCB0byByZWFkIGZyb20gbG9jYWxTdG9yYWdlOiAke2Vycm9yLm1lc3NhZ2V9YCxcbiAgICAgICAgdmFsaWRhdGlvbkVycm9yczogW2Vycm9yLm1lc3NhZ2VdXG4gICAgICB9O1xuICAgICAgXG4gICAgICAvLyBMb2cgbG9jYWxTdG9yYWdlIGVycm9yXG4gICAgICB0aGlzLmxvZ2dlci5sb2dWYWxpZGF0aW9uRXJyb3JzKFt7XG4gICAgICAgIHBhdGg6ICcnLFxuICAgICAgICBtZXNzYWdlOiBgRmFpbGVkIHRvIHJlYWQgZnJvbSBsb2NhbFN0b3JhZ2U6ICR7ZXJyb3IubWVzc2FnZX1gLFxuICAgICAgICBjb2RlOiAnU1RPUkFHRV9SRUFEX0VSUk9SJyxcbiAgICAgICAgZmllbGQ6ICdyb290J1xuICAgICAgfV0sICdpbXBvcnQnLCB7XG4gICAgICAgIHN0b3JhZ2VLZXk6IGtleVxuICAgICAgfSk7XG4gICAgICBcbiAgICAgIHJldHVybiBlcnJvclJlc3VsdDtcbiAgICB9XG4gIH1cbn1cblxuIl19
@@ -0,0 +1,126 @@
1
+ /**
2
+ * Sample data generator service
3
+ * Generates sample data for preview based on column configurations
4
+ */
5
+ import { Injectable } from '@angular/core';
6
+ import { CellDataType } from '../../models/cell-types';
7
+ import * as i0 from "@angular/core";
8
+ export class SampleDataGeneratorService {
9
+ /**
10
+ * Generate sample data based on column configurations
11
+ * @param columns Column configurations
12
+ * @param rowCount Number of rows to generate
13
+ * @returns Array of sample data objects
14
+ */
15
+ generateSampleData(columns, rowCount = 5) {
16
+ return Array.from({ length: rowCount }, (_, index) => {
17
+ const row = {};
18
+ columns.forEach(column => {
19
+ row[column.key] = this.generateValueForColumn(column, index, columns);
20
+ });
21
+ return row;
22
+ });
23
+ }
24
+ /**
25
+ * Generate a sample value for a specific column
26
+ * @param column Column configuration
27
+ * @param rowIndex Row index (for variation)
28
+ * @param allColumns All columns (for valueGetter context)
29
+ * @returns Sample value
30
+ */
31
+ generateValueForColumn(column, rowIndex, allColumns) {
32
+ // Use valueGetter if provided
33
+ if (column.valueGetter && allColumns) {
34
+ // For preview, we'll generate a simple object
35
+ const sampleRow = this.generateBasicSampleRow(allColumns);
36
+ return column.valueGetter(sampleRow);
37
+ }
38
+ // Generate based on dataType
39
+ switch (column.dataType) {
40
+ case CellDataType.STRING:
41
+ return this.generateStringValue(column, rowIndex);
42
+ case CellDataType.NUMBER:
43
+ return this.generateNumberValue(column, rowIndex);
44
+ case CellDataType.DATE:
45
+ return this.generateDateValue(rowIndex);
46
+ case CellDataType.BOOLEAN:
47
+ return this.generateBooleanValue(rowIndex);
48
+ default:
49
+ return this.generateStringValue(column, rowIndex);
50
+ }
51
+ }
52
+ /**
53
+ * Generate a basic sample row for valueGetter
54
+ */
55
+ generateBasicSampleRow(columns) {
56
+ const row = {};
57
+ columns.forEach(col => {
58
+ row[col.key] = `Sample ${col.key}`;
59
+ });
60
+ return row;
61
+ }
62
+ /**
63
+ * Generate string value
64
+ */
65
+ generateStringValue(column, rowIndex) {
66
+ const key = column.key;
67
+ const samples = {
68
+ name: ['John Doe', 'Jane Smith', 'Bob Johnson', 'Alice Williams', 'Charlie Brown'],
69
+ email: ['john@example.com', 'jane@example.com', 'bob@example.com', 'alice@example.com', 'charlie@example.com'],
70
+ title: ['Manager', 'Developer', 'Designer', 'Analyst', 'Director'],
71
+ status: ['Active', 'Inactive', 'Pending', 'Approved', 'Rejected'],
72
+ city: ['New York', 'London', 'Tokyo', 'Paris', 'Sydney'],
73
+ country: ['USA', 'UK', 'Japan', 'France', 'Australia']
74
+ };
75
+ // Check if we have predefined samples for this key
76
+ if (samples[key]) {
77
+ return samples[key][rowIndex % samples[key].length];
78
+ }
79
+ // Generate generic string
80
+ return `${key.charAt(0).toUpperCase() + key.slice(1)} ${rowIndex + 1}`;
81
+ }
82
+ /**
83
+ * Generate number value
84
+ */
85
+ generateNumberValue(column, rowIndex) {
86
+ const key = column.key.toLowerCase();
87
+ // Special handling for common numeric fields
88
+ if (key.includes('age')) {
89
+ return 20 + (rowIndex * 5) + Math.floor(Math.random() * 10);
90
+ }
91
+ if (key.includes('price') || key.includes('cost') || key.includes('amount') || key.includes('salary')) {
92
+ return (rowIndex + 1) * 1000 + Math.floor(Math.random() * 500);
93
+ }
94
+ if (key.includes('quantity') || key.includes('count')) {
95
+ return (rowIndex + 1) * 10;
96
+ }
97
+ if (key.includes('id')) {
98
+ return rowIndex + 1;
99
+ }
100
+ // Generic number
101
+ return (rowIndex + 1) * 100;
102
+ }
103
+ /**
104
+ * Generate date value
105
+ */
106
+ generateDateValue(rowIndex) {
107
+ const baseDate = new Date(2024, 0, 1);
108
+ baseDate.setDate(baseDate.getDate() + rowIndex * 7); // Increment by weeks
109
+ return baseDate;
110
+ }
111
+ /**
112
+ * Generate boolean value
113
+ */
114
+ generateBooleanValue(rowIndex) {
115
+ return rowIndex % 2 === 0;
116
+ }
117
+ }
118
+ SampleDataGeneratorService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SampleDataGeneratorService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
119
+ SampleDataGeneratorService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SampleDataGeneratorService, providedIn: 'root' });
120
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SampleDataGeneratorService, decorators: [{
121
+ type: Injectable,
122
+ args: [{
123
+ providedIn: 'root'
124
+ }]
125
+ }] });
126
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FtcGxlLWRhdGEtZ2VuZXJhdG9yLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC10YWJsZS9zcmMvbGliL2J1aWxkZXIvc2VydmljZXMvc2FtcGxlLWRhdGEtZ2VuZXJhdG9yLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7OztHQUdHO0FBRUgsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBS3ZELE1BQU0sT0FBTywwQkFBMEI7SUFDckM7Ozs7O09BS0c7SUFDSCxrQkFBa0IsQ0FBQyxPQUF1QixFQUFFLFdBQW1CLENBQUM7UUFDOUQsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxFQUFFO1lBQ25ELE1BQU0sR0FBRyxHQUFRLEVBQUUsQ0FBQztZQUNwQixPQUFPLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxFQUFFO2dCQUN2QixHQUFHLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxNQUFNLEVBQUUsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1lBQ3hFLENBQUMsQ0FBQyxDQUFDO1lBQ0gsT0FBTyxHQUFHLENBQUM7UUFDYixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRDs7Ozs7O09BTUc7SUFDSyxzQkFBc0IsQ0FBQyxNQUFvQixFQUFFLFFBQWdCLEVBQUUsVUFBMkI7UUFDaEcsOEJBQThCO1FBQzlCLElBQUksTUFBTSxDQUFDLFdBQVcsSUFBSSxVQUFVLEVBQUU7WUFDcEMsOENBQThDO1lBQzlDLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxVQUFVLENBQUMsQ0FBQztZQUMx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QztJQUM1QixDQUFDOzt1SEF2SFUsMEJBQTBCOzJIQUExQiwwQkFBMEIsY0FGekIsTUFBTTsyRkFFUCwwQkFBMEI7a0JBSHRDLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBTYW1wbGUgZGF0YSBnZW5lcmF0b3Igc2VydmljZVxuICogR2VuZXJhdGVzIHNhbXBsZSBkYXRhIGZvciBwcmV2aWV3IGJhc2VkIG9uIGNvbHVtbiBjb25maWd1cmF0aW9uc1xuICovXG5cbmltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbHVtbkNvbmZpZyB9IGZyb20gJy4uLy4uL21vZGVscy9jb2x1bW4tY29uZmlnLmludGVyZmFjZSc7XG5pbXBvcnQgeyBDZWxsRGF0YVR5cGUgfSBmcm9tICcuLi8uLi9tb2RlbHMvY2VsbC10eXBlcyc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIFNhbXBsZURhdGFHZW5lcmF0b3JTZXJ2aWNlIHtcbiAgLyoqXG4gICAqIEdlbmVyYXRlIHNhbXBsZSBkYXRhIGJhc2VkIG9uIGNvbHVtbiBjb25maWd1cmF0aW9uc1xuICAgKiBAcGFyYW0gY29sdW1ucyBDb2x1bW4gY29uZmlndXJhdGlvbnNcbiAgICogQHBhcmFtIHJvd0NvdW50IE51bWJlciBvZiByb3dzIHRvIGdlbmVyYXRlXG4gICAqIEByZXR1cm5zIEFycmF5IG9mIHNhbXBsZSBkYXRhIG9iamVjdHNcbiAgICovXG4gIGdlbmVyYXRlU2FtcGxlRGF0YShjb2x1bW5zOiBDb2x1bW5Db25maWdbXSwgcm93Q291bnQ6IG51bWJlciA9IDUpOiBhbnlbXSB7XG4gICAgcmV0dXJuIEFycmF5LmZyb20oeyBsZW5ndGg6IHJvd0NvdW50IH0sIChfLCBpbmRleCkgPT4ge1xuICAgICAgY29uc3Qgcm93OiBhbnkgPSB7fTtcbiAgICAgIGNvbHVtbnMuZm9yRWFjaChjb2x1bW4gPT4ge1xuICAgICAgICByb3dbY29sdW1uLmtleV0gPSB0aGlzLmdlbmVyYXRlVmFsdWVGb3JDb2x1bW4oY29sdW1uLCBpbmRleCwgY29sdW1ucyk7XG4gICAgICB9KTtcbiAgICAgIHJldHVybiByb3c7XG4gICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogR2VuZXJhdGUgYSBzYW1wbGUgdmFsdWUgZm9yIGEgc3BlY2lmaWMgY29sdW1uXG4gICAqIEBwYXJhbSBjb2x1bW4gQ29sdW1uIGNvbmZpZ3VyYXRpb25cbiAgICogQHBhcmFtIHJvd0luZGV4IFJvdyBpbmRleCAoZm9yIHZhcmlhdGlvbilcbiAgICogQHBhcmFtIGFsbENvbHVtbnMgQWxsIGNvbHVtbnMgKGZvciB2YWx1ZUdldHRlciBjb250ZXh0KVxuICAgKiBAcmV0dXJucyBTYW1wbGUgdmFsdWVcbiAgICovXG4gIHByaXZhdGUgZ2VuZXJhdGVWYWx1ZUZvckNvbHVtbihjb2x1bW46IENvbHVtbkNvbmZpZywgcm93SW5kZXg6IG51bWJlciwgYWxsQ29sdW1ucz86IENvbHVtbkNvbmZpZ1tdKTogYW55IHtcbiAgICAvLyBVc2UgdmFsdWVHZXR0ZXIgaWYgcHJvdmlkZWRcbiAgICBpZiAoY29sdW1uLnZhbHVlR2V0dGVyICYmIGFsbENvbHVtbnMpIHtcbiAgICAgIC8vIEZvciBwcmV2aWV3LCB3ZSdsbCBnZW5lcmF0ZSBhIHNpbXBsZSBvYmplY3RcbiAgICAgIGNvbnN0IHNhbXBsZVJvdyA9IHRoaXMuZ2VuZXJhdGVCYXNpY1NhbXBsZVJvdyhhbGxDb2x1bW5zKTtcbiAgICAgIHJldHVybiBjb2x1bW4udmFsdWVHZXR0ZXIoc2FtcGxlUm93KTtcbiAgICB9XG5cbiAgICAvLyBHZW5lcmF0ZSBiYXNlZCBvbiBkYXRhVHlwZVxuICAgIHN3aXRjaCAoY29sdW1uLmRhdGFUeXBlKSB7XG4gICAgICBjYXNlIENlbGxEYXRhVHlwZS5TVFJJTkc6XG4gICAgICAgIHJldHVybiB0aGlzLmdlbmVyYXRlU3RyaW5nVmFsdWUoY29sdW1uLCByb3dJbmRleCk7XG4gICAgICBjYXNlIENlbGxEYXRhVHlwZS5OVU1CRVI6XG4gICAgICAgIHJldHVybiB0aGlzLmdlbmVyYXRlTnVtYmVyVmFsdWUoY29sdW1uLCByb3dJbmRleCk7XG4gICAgICBjYXNlIENlbGxEYXRhVHlwZS5EQVRFOlxuICAgICAgICByZXR1cm4gdGhpcy5nZW5lcmF0ZURhdGVWYWx1ZShyb3dJbmRleCk7XG4gICAgICBjYXNlIENlbGxEYXRhVHlwZS5CT09MRUFOOlxuICAgICAgICByZXR1cm4gdGhpcy5nZW5lcmF0ZUJvb2xlYW5WYWx1ZShyb3dJbmRleCk7XG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4gdGhpcy5nZW5lcmF0ZVN0cmluZ1ZhbHVlKGNvbHVtbiwgcm93SW5kZXgpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBHZW5lcmF0ZSBhIGJhc2ljIHNhbXBsZSByb3cgZm9yIHZhbHVlR2V0dGVyXG4gICAqL1xuICBwcml2YXRlIGdlbmVyYXRlQmFzaWNTYW1wbGVSb3coY29sdW1uczogQ29sdW1uQ29uZmlnW10pOiBhbnkge1xuICAgIGNvbnN0IHJvdzogYW55ID0ge307XG4gICAgY29sdW1ucy5mb3JFYWNoKGNvbCA9PiB7XG4gICAgICByb3dbY29sLmtleV0gPSBgU2FtcGxlICR7Y29sLmtleX1gO1xuICAgIH0pO1xuICAgIHJldHVybiByb3c7XG4gIH1cblxuICAvKipcbiAgICogR2VuZXJhdGUgc3RyaW5nIHZhbHVlXG4gICAqL1xuICBwcml2YXRlIGdlbmVyYXRlU3RyaW5nVmFsdWUoY29sdW1uOiBDb2x1bW5Db25maWcsIHJvd0luZGV4OiBudW1iZXIpOiBzdHJpbmcge1xuICAgIGNvbnN0IGtleSA9IGNvbHVtbi5rZXk7XG4gICAgY29uc3Qgc2FtcGxlczogUmVjb3JkPHN0cmluZywgc3RyaW5nW10+ID0ge1xuICAgICAgbmFtZTogWydKb2huIERvZScsICdKYW5lIFNtaXRoJywgJ0JvYiBKb2huc29uJywgJ0FsaWNlIFdpbGxpYW1zJywgJ0NoYXJsaWUgQnJvd24nXSxcbiAgICAgIGVtYWlsOiBbJ2pvaG5AZXhhbXBsZS5jb20nLCAnamFuZUBleGFtcGxlLmNvbScsICdib2JAZXhhbXBsZS5jb20nLCAnYWxpY2VAZXhhbXBsZS5jb20nLCAnY2hhcmxpZUBleGFtcGxlLmNvbSddLFxuICAgICAgdGl0bGU6IFsnTWFuYWdlcicsICdEZXZlbG9wZXInLCAnRGVzaWduZXInLCAnQW5hbHlzdCcsICdEaXJlY3RvciddLFxuICAgICAgc3RhdHVzOiBbJ0FjdGl2ZScsICdJbmFjdGl2ZScsICdQZW5kaW5nJywgJ0FwcHJvdmVkJywgJ1JlamVjdGVkJ10sXG4gICAgICBjaXR5OiBbJ05ldyBZb3JrJywgJ0xvbmRvbicsICdUb2t5bycsICdQYXJpcycsICdTeWRuZXknXSxcbiAgICAgIGNvdW50cnk6IFsnVVNBJywgJ1VLJywgJ0phcGFuJywgJ0ZyYW5jZScsICdBdXN0cmFsaWEnXVxuICAgIH07XG5cbiAgICAvLyBDaGVjayBpZiB3ZSBoYXZlIHByZWRlZmluZWQgc2FtcGxlcyBmb3IgdGhpcyBrZXlcbiAgICBpZiAoc2FtcGxlc1trZXldKSB7XG4gICAgICByZXR1cm4gc2FtcGxlc1trZXldW3Jvd0luZGV4ICUgc2FtcGxlc1trZXldLmxlbmd0aF07XG4gICAgfVxuXG4gICAgLy8gR2VuZXJhdGUgZ2VuZXJpYyBzdHJpbmdcbiAgICByZXR1cm4gYCR7a2V5LmNoYXJBdCgwKS50b1VwcGVyQ2FzZSgpICsga2V5LnNsaWNlKDEpfSAke3Jvd0luZGV4ICsgMX1gO1xuICB9XG5cbiAgLyoqXG4gICAqIEdlbmVyYXRlIG51bWJlciB2YWx1ZVxuICAgKi9cbiAgcHJpdmF0ZSBnZW5lcmF0ZU51bWJlclZhbHVlKGNvbHVtbjogQ29sdW1uQ29uZmlnLCByb3dJbmRleDogbnVtYmVyKTogbnVtYmVyIHtcbiAgICBjb25zdCBrZXkgPSBjb2x1bW4ua2V5LnRvTG93ZXJDYXNlKCk7XG4gICAgXG4gICAgLy8gU3BlY2lhbCBoYW5kbGluZyBmb3IgY29tbW9uIG51bWVyaWMgZmllbGRzXG4gICAgaWYgKGtleS5pbmNsdWRlcygnYWdlJykpIHtcbiAgICAgIHJldHVybiAyMCArIChyb3dJbmRleCAqIDUpICsgTWF0aC5mbG9vcihNYXRoLnJhbmRvbSgpICogMTApO1xuICAgIH1cbiAgICBpZiAoa2V5LmluY2x1ZGVzKCdwcmljZScpIHx8IGtleS5pbmNsdWRlcygnY29zdCcpIHx8IGtleS5pbmNsdWRlcygnYW1vdW50JykgfHwga2V5LmluY2x1ZGVzKCdzYWxhcnknKSkge1xuICAgICAgcmV0dXJuIChyb3dJbmRleCArIDEpICogMTAwMCArIE1hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIDUwMCk7XG4gICAgfVxuICAgIGlmIChrZXkuaW5jbHVkZXMoJ3F1YW50aXR5JykgfHwga2V5LmluY2x1ZGVzKCdjb3VudCcpKSB7XG4gICAgICByZXR1cm4gKHJvd0luZGV4ICsgMSkgKiAxMDtcbiAgICB9XG4gICAgaWYgKGtleS5pbmNsdWRlcygnaWQnKSkge1xuICAgICAgcmV0dXJuIHJvd0luZGV4ICsgMTtcbiAgICB9XG5cbiAgICAvLyBHZW5lcmljIG51bWJlclxuICAgIHJldHVybiAocm93SW5kZXggKyAxKSAqIDEwMDtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZW5lcmF0ZSBkYXRlIHZhbHVlXG4gICAqL1xuICBwcml2YXRlIGdlbmVyYXRlRGF0ZVZhbHVlKHJvd0luZGV4OiBudW1iZXIpOiBEYXRlIHtcbiAgICBjb25zdCBiYXNlRGF0ZSA9IG5ldyBEYXRlKDIwMjQsIDAsIDEpO1xuICAgIGJhc2VEYXRlLnNldERhdGUoYmFzZURhdGUuZ2V0RGF0ZSgpICsgcm93SW5kZXggKiA3KTsgLy8gSW5jcmVtZW50IGJ5IHdlZWtzXG4gICAgcmV0dXJuIGJhc2VEYXRlO1xuICB9XG5cbiAgLyoqXG4gICAqIEdlbmVyYXRlIGJvb2xlYW4gdmFsdWVcbiAgICovXG4gIHByaXZhdGUgZ2VuZXJhdGVCb29sZWFuVmFsdWUocm93SW5kZXg6IG51bWJlcik6IGJvb2xlYW4ge1xuICAgIHJldHVybiByb3dJbmRleCAlIDIgPT09IDA7XG4gIH1cbn1cblxuIl19