@ai-table/grid 0.0.12 → 0.0.14

Sign up to get free protection for your applications and to get access to all the features.
Files changed (324) hide show
  1. package/angular-konva/components/container.component.d.ts +7 -0
  2. package/angular-konva/components/container.component.d.ts.map +1 -0
  3. package/angular-konva/components/container.token.d.ts +3 -0
  4. package/angular-konva/components/container.token.d.ts.map +1 -0
  5. package/angular-konva/components/index.d.ts +4 -0
  6. package/angular-konva/components/index.d.ts.map +1 -0
  7. package/angular-konva/components/shape.component.d.ts +61 -0
  8. package/angular-konva/components/shape.component.d.ts.map +1 -0
  9. package/angular-konva/components/stage.component.d.ts +40 -0
  10. package/angular-konva/components/stage.component.d.ts.map +1 -0
  11. package/angular-konva/index.d.ts +5 -0
  12. package/angular-konva/index.d.ts.map +1 -0
  13. package/angular-konva/interfaces/component.d.ts +49 -0
  14. package/angular-konva/interfaces/component.d.ts.map +1 -0
  15. package/angular-konva/interfaces/config.d.ts +26 -0
  16. package/angular-konva/interfaces/config.d.ts.map +1 -0
  17. package/angular-konva/interfaces/event-object.d.ts +7 -0
  18. package/angular-konva/interfaces/event-object.d.ts.map +1 -0
  19. package/angular-konva/interfaces/index.d.ts +5 -0
  20. package/angular-konva/interfaces/index.d.ts.map +1 -0
  21. package/angular-konva/interfaces/shape.d.ts +42 -0
  22. package/angular-konva/interfaces/shape.d.ts.map +1 -0
  23. package/angular-konva/utils/apply-node-props.d.ts +4 -0
  24. package/angular-konva/utils/apply-node-props.d.ts.map +1 -0
  25. package/angular-konva/utils/common.d.ts +8 -0
  26. package/angular-konva/utils/common.d.ts.map +1 -0
  27. package/angular-konva/utils/index.d.ts +5 -0
  28. package/angular-konva/utils/index.d.ts.map +1 -0
  29. package/angular-konva/utils/types.d.ts +4 -0
  30. package/angular-konva/utils/types.d.ts.map +1 -0
  31. package/angular-konva/utils/update-picture.d.ts +4 -0
  32. package/angular-konva/utils/update-picture.d.ts.map +1 -0
  33. package/components/cell-editors/abstract-cell-editor.component.d.ts +7 -5
  34. package/components/cell-editors/abstract-cell-editor.component.d.ts.map +1 -1
  35. package/components/cell-editors/cell-editor.scss +38 -25
  36. package/components/cell-editors/cell-editor.variables.scss +5 -0
  37. package/components/cell-editors/date/date-editor.component.d.ts.map +1 -1
  38. package/components/cell-editors/link/edit-link/edit-link.component.d.ts +33 -0
  39. package/components/cell-editors/link/edit-link/edit-link.component.d.ts.map +1 -0
  40. package/components/cell-editors/link/link-editor.component.d.ts +36 -0
  41. package/components/cell-editors/link/link-editor.component.d.ts.map +1 -0
  42. package/components/cell-editors/link/link-editor.component.scss +21 -0
  43. package/components/cell-editors/progress/progress-editor.component.d.ts +0 -1
  44. package/components/cell-editors/progress/progress-editor.component.d.ts.map +1 -1
  45. package/components/cell-editors/progress/progress-editor.component.scss +12 -4
  46. package/components/cell-editors/rating/rating-editor.component.d.ts +0 -1
  47. package/components/cell-editors/rating/rating-editor.component.d.ts.map +1 -1
  48. package/components/cell-editors/rating/rating-editor.component.scss +10 -0
  49. package/components/cell-editors/select/select-editor.component.d.ts +3 -4
  50. package/components/cell-editors/select/select-editor.component.d.ts.map +1 -1
  51. package/components/cell-editors/text/text-editor.component.d.ts +0 -1
  52. package/components/cell-editors/text/text-editor.component.d.ts.map +1 -1
  53. package/components/cell-views/select/option.component.d.ts.map +1 -1
  54. package/components/cell-views/select/option.scss +10 -0
  55. package/components/field-menu/field-menu.component.d.ts +8 -3
  56. package/components/field-menu/field-menu.component.d.ts.map +1 -1
  57. package/components/field-property-editor/field-property-editor.component.d.ts +4 -2
  58. package/components/field-property-editor/field-property-editor.component.d.ts.map +1 -1
  59. package/components/index.d.ts +3 -1
  60. package/components/index.d.ts.map +1 -1
  61. package/constants/colors.d.ts +18 -0
  62. package/constants/colors.d.ts.map +1 -0
  63. package/constants/grid.d.ts +17 -1
  64. package/constants/grid.d.ts.map +1 -1
  65. package/constants/icon.d.ts +19 -0
  66. package/constants/icon.d.ts.map +1 -0
  67. package/constants/index.d.ts +5 -1
  68. package/constants/index.d.ts.map +1 -1
  69. package/constants/table.d.ts +60 -0
  70. package/constants/table.d.ts.map +1 -0
  71. package/constants/text.d.ts +22 -0
  72. package/constants/text.d.ts.map +1 -0
  73. package/core/context.d.ts +14 -0
  74. package/core/context.d.ts.map +1 -0
  75. package/core/coordinate.d.ts +96 -0
  76. package/core/coordinate.d.ts.map +1 -0
  77. package/core/index.d.ts +3 -2
  78. package/core/index.d.ts.map +1 -1
  79. package/core/types/ai-table.d.ts +56 -0
  80. package/core/types/ai-table.d.ts.map +1 -0
  81. package/core/types/core.d.ts +29 -23
  82. package/core/types/core.d.ts.map +1 -1
  83. package/core/types/index.d.ts +1 -1
  84. package/core/types/index.d.ts.map +1 -1
  85. package/core/utils/common.d.ts +1 -2
  86. package/core/utils/common.d.ts.map +1 -1
  87. package/core/utils/field.d.ts +3 -1
  88. package/core/utils/field.d.ts.map +1 -1
  89. package/core/utils/index.d.ts +0 -1
  90. package/core/utils/index.d.ts.map +1 -1
  91. package/core/utils/queries.d.ts +5 -5
  92. package/core/utils/queries.d.ts.map +1 -1
  93. package/dom-grid.component.d.ts +11 -0
  94. package/dom-grid.component.d.ts.map +1 -0
  95. package/esm2022/angular-konva/components/container.component.mjs +29 -0
  96. package/esm2022/angular-konva/components/container.token.mjs +3 -0
  97. package/esm2022/angular-konva/components/index.mjs +4 -0
  98. package/esm2022/angular-konva/components/shape.component.mjs +142 -0
  99. package/esm2022/angular-konva/components/stage.component.mjs +123 -0
  100. package/esm2022/angular-konva/index.mjs +5 -0
  101. package/esm2022/angular-konva/interfaces/component.mjs +4 -0
  102. package/esm2022/angular-konva/interfaces/config.mjs +2 -0
  103. package/esm2022/angular-konva/interfaces/event-object.mjs +2 -0
  104. package/esm2022/angular-konva/interfaces/index.mjs +5 -0
  105. package/esm2022/angular-konva/interfaces/shape.mjs +42 -0
  106. package/esm2022/angular-konva/utils/apply-node-props.mjs +67 -0
  107. package/esm2022/angular-konva/utils/common.mjs +48 -0
  108. package/esm2022/angular-konva/utils/index.mjs +5 -0
  109. package/esm2022/angular-konva/utils/types.mjs +2 -0
  110. package/esm2022/angular-konva/utils/update-picture.mjs +7 -0
  111. package/esm2022/components/cell-editors/abstract-cell-editor.component.mjs +15 -7
  112. package/esm2022/components/cell-editors/date/date-editor.component.mjs +6 -3
  113. package/esm2022/components/cell-editors/link/edit-link/edit-link.component.mjs +66 -0
  114. package/esm2022/components/cell-editors/link/link-editor.component.mjs +117 -0
  115. package/esm2022/components/cell-editors/number/number-editor.component.mjs +2 -2
  116. package/esm2022/components/cell-editors/progress/progress-editor.component.mjs +3 -6
  117. package/esm2022/components/cell-editors/rating/rating-editor.component.mjs +4 -7
  118. package/esm2022/components/cell-editors/select/select-editor.component.mjs +19 -17
  119. package/esm2022/components/cell-editors/text/text-editor.component.mjs +10 -11
  120. package/esm2022/components/cell-views/select/option.component.mjs +6 -5
  121. package/esm2022/components/field-menu/field-menu.component.mjs +11 -8
  122. package/esm2022/components/field-property-editor/field-property-editor.component.mjs +17 -12
  123. package/esm2022/components/index.mjs +4 -2
  124. package/esm2022/constants/colors.mjs +18 -0
  125. package/esm2022/constants/editor.mjs +2 -3
  126. package/esm2022/constants/grid.mjs +22 -4
  127. package/esm2022/constants/icon.mjs +26 -0
  128. package/esm2022/constants/index.mjs +6 -2
  129. package/esm2022/constants/table.mjs +62 -0
  130. package/esm2022/constants/text.mjs +23 -0
  131. package/esm2022/core/context.mjs +25 -0
  132. package/esm2022/core/coordinate.mjs +222 -0
  133. package/esm2022/core/index.mjs +4 -3
  134. package/esm2022/core/types/ai-table.mjs +44 -0
  135. package/esm2022/core/types/core.mjs +6 -1
  136. package/esm2022/core/types/index.mjs +2 -2
  137. package/esm2022/core/utils/common.mjs +3 -20
  138. package/esm2022/core/utils/field.mjs +18 -5
  139. package/esm2022/core/utils/index.mjs +1 -2
  140. package/esm2022/core/utils/queries.mjs +4 -4
  141. package/esm2022/dom-grid.component.mjs +82 -0
  142. package/esm2022/grid-base.component.mjs +154 -0
  143. package/esm2022/grid.component.mjs +337 -160
  144. package/esm2022/public-api.mjs +9 -5
  145. package/esm2022/renderer/components/add-field-column.component.mjs +68 -0
  146. package/esm2022/renderer/components/cells.component.mjs +35 -0
  147. package/esm2022/renderer/components/field-head.component.mjs +130 -0
  148. package/esm2022/renderer/components/field-icon.component.mjs +66 -0
  149. package/esm2022/renderer/components/frozen-cells.component.mjs +36 -0
  150. package/esm2022/renderer/components/frozen-heads.component.mjs +117 -0
  151. package/esm2022/renderer/components/frozen-placeholder-cells.component.mjs +38 -0
  152. package/esm2022/renderer/components/heads.component.mjs +38 -0
  153. package/esm2022/renderer/components/hover-row-heads.component.mjs +107 -0
  154. package/esm2022/renderer/components/icon.component.mjs +80 -0
  155. package/esm2022/renderer/components/index.mjs +14 -0
  156. package/esm2022/renderer/components/other-rows.component.mjs +68 -0
  157. package/esm2022/renderer/components/placeholder-cells.component.mjs +33 -0
  158. package/esm2022/renderer/components/text.component.mjs +45 -0
  159. package/esm2022/renderer/creations/create-active-cell-border.mjs +68 -0
  160. package/esm2022/renderer/creations/create-cells.mjs +135 -0
  161. package/esm2022/renderer/creations/create-heads.mjs +45 -0
  162. package/esm2022/renderer/drawers/add-row-layout-drawer.mjs +97 -0
  163. package/esm2022/renderer/drawers/cell-drawer.mjs +587 -0
  164. package/esm2022/renderer/drawers/drawer.mjs +936 -0
  165. package/esm2022/renderer/drawers/layout-drawer.mjs +58 -0
  166. package/esm2022/renderer/drawers/record-row-layout-drawer.mjs +101 -0
  167. package/esm2022/renderer/index.mjs +4 -0
  168. package/esm2022/renderer/renderer.component.mjs +174 -0
  169. package/esm2022/services/event.service.mjs +120 -11
  170. package/esm2022/services/field.service.mjs +28 -5
  171. package/esm2022/services/index.mjs +4 -0
  172. package/esm2022/services/selection.service.mjs +8 -1
  173. package/esm2022/types/avatar.mjs +27 -0
  174. package/esm2022/types/canvas.mjs +2 -0
  175. package/esm2022/types/cell.mjs +2 -0
  176. package/esm2022/types/component-config.mjs +7 -0
  177. package/esm2022/types/field.mjs +1 -1
  178. package/esm2022/types/grid.mjs +16 -2
  179. package/esm2022/types/index.mjs +8 -2
  180. package/esm2022/types/layout.mjs +2 -0
  181. package/esm2022/types/row.mjs +6 -0
  182. package/esm2022/utils/build.mjs +39 -0
  183. package/esm2022/utils/cell.mjs +71 -0
  184. package/esm2022/utils/common.mjs +49 -0
  185. package/esm2022/utils/get-placeholder-cells.mjs +66 -0
  186. package/esm2022/utils/get-text-width.mjs +30 -0
  187. package/esm2022/utils/image-cache.mjs +57 -0
  188. package/esm2022/utils/index.mjs +12 -0
  189. package/esm2022/utils/os.mjs +16 -0
  190. package/esm2022/utils/position.mjs +48 -0
  191. package/esm2022/utils/style.mjs +25 -0
  192. package/esm2022/utils/text-measure.mjs +122 -0
  193. package/esm2022/utils/visible-range.mjs +38 -0
  194. package/fesm2022/ai-table-grid.mjs +5549 -690
  195. package/fesm2022/ai-table-grid.mjs.map +1 -1
  196. package/grid-base.component.d.ts +52 -0
  197. package/grid-base.component.d.ts.map +1 -0
  198. package/grid.component.d.ts +43 -40
  199. package/grid.component.d.ts.map +1 -1
  200. package/package.json +5 -2
  201. package/public-api.d.ts +8 -4
  202. package/public-api.d.ts.map +1 -1
  203. package/renderer/components/add-field-column.component.d.ts +16 -0
  204. package/renderer/components/add-field-column.component.d.ts.map +1 -0
  205. package/renderer/components/cells.component.d.ts +14 -0
  206. package/renderer/components/cells.component.d.ts.map +1 -0
  207. package/renderer/components/field-head.component.d.ts +73 -0
  208. package/renderer/components/field-head.component.d.ts.map +1 -0
  209. package/renderer/components/field-icon.component.d.ts +17 -0
  210. package/renderer/components/field-icon.component.d.ts.map +1 -0
  211. package/renderer/components/frozen-cells.component.d.ts +14 -0
  212. package/renderer/components/frozen-cells.component.d.ts.map +1 -0
  213. package/renderer/components/frozen-heads.component.d.ts +47 -0
  214. package/renderer/components/frozen-heads.component.d.ts.map +1 -0
  215. package/renderer/components/frozen-placeholder-cells.component.d.ts +22 -0
  216. package/renderer/components/frozen-placeholder-cells.component.d.ts.map +1 -0
  217. package/renderer/components/heads.component.d.ts +9 -0
  218. package/renderer/components/heads.component.d.ts.map +1 -0
  219. package/renderer/components/hover-row-heads.component.d.ts +11 -0
  220. package/renderer/components/hover-row-heads.component.d.ts.map +1 -0
  221. package/renderer/components/icon.component.d.ts +37 -0
  222. package/renderer/components/icon.component.d.ts.map +1 -0
  223. package/renderer/components/index.d.ts +14 -0
  224. package/renderer/components/index.d.ts.map +1 -0
  225. package/renderer/components/other-rows.component.d.ts +31 -0
  226. package/renderer/components/other-rows.component.d.ts.map +1 -0
  227. package/renderer/components/placeholder-cells.component.d.ts +22 -0
  228. package/renderer/components/placeholder-cells.component.d.ts.map +1 -0
  229. package/renderer/components/text.component.d.ts +99 -0
  230. package/renderer/components/text.component.d.ts.map +1 -0
  231. package/renderer/creations/create-active-cell-border.d.ts +7 -0
  232. package/renderer/creations/create-active-cell-border.d.ts.map +1 -0
  233. package/renderer/creations/create-cells.d.ts +8 -0
  234. package/renderer/creations/create-cells.d.ts.map +1 -0
  235. package/renderer/creations/create-heads.d.ts +3 -0
  236. package/renderer/creations/create-heads.d.ts.map +1 -0
  237. package/renderer/drawers/add-row-layout-drawer.d.ts +12 -0
  238. package/renderer/drawers/add-row-layout-drawer.d.ts.map +1 -0
  239. package/renderer/drawers/cell-drawer.d.ts +22 -0
  240. package/renderer/drawers/cell-drawer.d.ts.map +1 -0
  241. package/renderer/drawers/drawer.d.ts +136 -0
  242. package/renderer/drawers/drawer.d.ts.map +1 -0
  243. package/renderer/drawers/layout-drawer.d.ts +22 -0
  244. package/renderer/drawers/layout-drawer.d.ts.map +1 -0
  245. package/renderer/drawers/record-row-layout-drawer.d.ts +14 -0
  246. package/renderer/drawers/record-row-layout-drawer.d.ts.map +1 -0
  247. package/renderer/index.d.ts +4 -0
  248. package/renderer/index.d.ts.map +1 -0
  249. package/renderer/renderer.component.d.ts +64 -0
  250. package/renderer/renderer.component.d.ts.map +1 -0
  251. package/services/event.service.d.ts +17 -3
  252. package/services/event.service.d.ts.map +1 -1
  253. package/services/field.service.d.ts +5 -4
  254. package/services/field.service.d.ts.map +1 -1
  255. package/services/index.d.ts +4 -0
  256. package/services/index.d.ts.map +1 -0
  257. package/services/selection.service.d.ts.map +1 -1
  258. package/styles/styles.scss +71 -11
  259. package/types/avatar.d.ts +24 -0
  260. package/types/avatar.d.ts.map +1 -0
  261. package/types/canvas.d.ts +83 -0
  262. package/types/canvas.d.ts.map +1 -0
  263. package/types/cell.d.ts +43 -0
  264. package/types/cell.d.ts.map +1 -0
  265. package/types/component-config.d.ts +50 -0
  266. package/types/component-config.d.ts.map +1 -0
  267. package/types/field.d.ts +27 -1
  268. package/types/field.d.ts.map +1 -1
  269. package/types/grid.d.ts +81 -2
  270. package/types/grid.d.ts.map +1 -1
  271. package/types/index.d.ts +7 -1
  272. package/types/index.d.ts.map +1 -1
  273. package/types/layout.d.ts +11 -0
  274. package/types/layout.d.ts.map +1 -0
  275. package/types/row.d.ts +27 -0
  276. package/types/row.d.ts.map +1 -0
  277. package/utils/build.d.ts +5 -0
  278. package/utils/build.d.ts.map +1 -0
  279. package/utils/cell.d.ts +19 -0
  280. package/utils/cell.d.ts.map +1 -0
  281. package/utils/common.d.ts +20 -0
  282. package/utils/common.d.ts.map +1 -0
  283. package/utils/get-placeholder-cells.d.ts +16 -0
  284. package/utils/get-placeholder-cells.d.ts.map +1 -0
  285. package/utils/get-text-width.d.ts +9 -0
  286. package/utils/get-text-width.d.ts.map +1 -0
  287. package/utils/image-cache.d.ts +16 -0
  288. package/utils/image-cache.d.ts.map +1 -0
  289. package/utils/index.d.ts +12 -0
  290. package/utils/index.d.ts.map +1 -0
  291. package/utils/os.d.ts +4 -0
  292. package/utils/os.d.ts.map +1 -0
  293. package/utils/position.d.ts +20 -0
  294. package/utils/position.d.ts.map +1 -0
  295. package/utils/style.d.ts +4 -0
  296. package/utils/style.d.ts.map +1 -0
  297. package/utils/text-measure.d.ts +32 -0
  298. package/utils/text-measure.d.ts.map +1 -0
  299. package/utils/visible-range.d.ts +13 -0
  300. package/utils/visible-range.d.ts.map +1 -0
  301. package/components/cell-editors/link/number-editor.component.d.ts +0 -8
  302. package/components/cell-editors/link/number-editor.component.d.ts.map +0 -1
  303. package/constants/field.d.ts +0 -20
  304. package/constants/field.d.ts.map +0 -1
  305. package/core/action/field.d.ts +0 -12
  306. package/core/action/field.d.ts.map +0 -1
  307. package/core/action/general.d.ts +0 -5
  308. package/core/action/general.d.ts.map +0 -1
  309. package/core/action/index.d.ts +0 -12
  310. package/core/action/index.d.ts.map +0 -1
  311. package/core/action/record.d.ts +0 -12
  312. package/core/action/record.d.ts.map +0 -1
  313. package/core/types/action.d.ts +0 -64
  314. package/core/types/action.d.ts.map +0 -1
  315. package/core/utils/weak-map.d.ts +0 -3
  316. package/core/utils/weak-map.d.ts.map +0 -1
  317. package/esm2022/components/cell-editors/link/number-editor.component.mjs +0 -25
  318. package/esm2022/constants/field.mjs +0 -25
  319. package/esm2022/core/action/field.mjs +0 -57
  320. package/esm2022/core/action/general.mjs +0 -116
  321. package/esm2022/core/action/index.mjs +0 -9
  322. package/esm2022/core/action/record.mjs +0 -44
  323. package/esm2022/core/types/action.mjs +0 -18
  324. package/esm2022/core/utils/weak-map.mjs +0 -2
@@ -0,0 +1,52 @@
1
+ import { DestroyRef, ElementRef, NgZone, OnInit } from '@angular/core';
2
+ import { ThyPopoverRef } from 'ngx-tethys/popover';
3
+ import { AddFieldOptions, AddRecordOptions, AIPlugin, AITable, AITableFields, AITableFieldType, AITableRecords, AITableSelectOptionStyle, AITableValue, UpdateFieldValueOptions } from './core';
4
+ import { AITableGridEventService } from './services/event.service';
5
+ import { AITableGridFieldService } from './services/field.service';
6
+ import { AITableGridSelectionService } from './services/selection.service';
7
+ import { AIFieldConfig, AITableFieldMenuItem, AITableReferences } from './types';
8
+ import * as i0 from "@angular/core";
9
+ export declare class AITableGridBase implements OnInit {
10
+ aiRecords: import("@angular/core").ModelSignal<AITableRecords>;
11
+ aiFields: import("@angular/core").ModelSignal<AITableFields>;
12
+ aiFieldConfig: import("@angular/core").InputSignal<AIFieldConfig | undefined>;
13
+ aiReadonly: import("@angular/core").InputSignal<boolean | undefined>;
14
+ aiPlugins: import("@angular/core").InputSignal<AIPlugin[] | undefined>;
15
+ aiReferences: import("@angular/core").InputSignal<AITableReferences>;
16
+ aiBuildRenderDataFn: import("@angular/core").InputSignal<((aiTable: AITable) => AITableValue) | undefined>;
17
+ AITableFieldType: typeof AITableFieldType;
18
+ AITableSelectOptionStyle: typeof AITableSelectOptionStyle;
19
+ aiTable: AITable;
20
+ isSelectedAll: import("@angular/core").Signal<boolean>;
21
+ aiTableInitialized: import("@angular/core").OutputEmitterRef<AITable>;
22
+ aiAddRecord: import("@angular/core").OutputEmitterRef<AddRecordOptions>;
23
+ aiAddField: import("@angular/core").OutputEmitterRef<AddFieldOptions>;
24
+ aiUpdateFieldValue: import("@angular/core").OutputEmitterRef<UpdateFieldValueOptions<unknown>>;
25
+ fieldMenus: AITableFieldMenuItem[];
26
+ mouseoverRef: ThyPopoverRef<any>;
27
+ gridData: import("@angular/core").Signal<AITableValue>;
28
+ protected ngZone: NgZone;
29
+ protected elementRef: ElementRef<any>;
30
+ protected destroyRef: DestroyRef;
31
+ protected aiTableGridFieldService: AITableGridFieldService;
32
+ protected aiTableGridEventService: AITableGridEventService;
33
+ protected aiTableGridSelectionService: AITableGridSelectionService;
34
+ ngOnInit(): void;
35
+ initAITable(): void;
36
+ initService(): void;
37
+ buildFieldMenus(): void;
38
+ addRecord(): void;
39
+ selectRecord(recordId: string): void;
40
+ toggleSelectAll(checked: boolean): void;
41
+ addField(gridColumnBlank?: HTMLElement, position?: {
42
+ x: number;
43
+ y: number;
44
+ }): void;
45
+ subscribeEvents(): void;
46
+ private dblClick;
47
+ private mouseoverHandle;
48
+ private closeHoverCellEditor;
49
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITableGridBase, never>;
50
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableGridBase, "ai-table-grid-base", never, { "aiRecords": { "alias": "aiRecords"; "required": true; "isSignal": true; }; "aiFields": { "alias": "aiFields"; "required": true; "isSignal": true; }; "aiFieldConfig": { "alias": "aiFieldConfig"; "required": false; "isSignal": true; }; "aiReadonly": { "alias": "aiReadonly"; "required": false; "isSignal": true; }; "aiPlugins": { "alias": "aiPlugins"; "required": false; "isSignal": true; }; "aiReferences": { "alias": "aiReferences"; "required": true; "isSignal": true; }; "aiBuildRenderDataFn": { "alias": "aiBuildRenderDataFn"; "required": false; "isSignal": true; }; }, { "aiRecords": "aiRecordsChange"; "aiFields": "aiFieldsChange"; "aiTableInitialized": "aiTableInitialized"; "aiAddRecord": "aiAddRecord"; "aiAddField": "aiAddField"; "aiUpdateFieldValue": "aiUpdateFieldValue"; }, never, never, true, never>;
51
+ }
52
+ //# sourceMappingURL=grid-base.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"grid-base.component.d.ts","sourceRoot":"","sources":["../../packages/grid/src/grid-base.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAIH,UAAU,EACV,UAAU,EAIV,MAAM,EACN,MAAM,EAET,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAGnD,OAAO,EACH,eAAe,EACf,gBAAgB,EAChB,QAAQ,EACR,OAAO,EACP,aAAa,EACb,gBAAgB,EAChB,cAAc,EACd,wBAAwB,EACxB,YAAY,EAGZ,uBAAuB,EAC1B,MAAM,QAAQ,CAAC;AAChB,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAmC,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACpG,OAAO,EAAE,2BAA2B,EAAE,MAAM,8BAA8B,CAAC;AAC3E,OAAO,EAAE,aAAa,EAAE,oBAAoB,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;;AAGjF,qBAMa,eAAgB,YAAW,MAAM;IAC1C,SAAS,sDAAoC;IAE7C,QAAQ,qDAAmC;IAE3C,aAAa,iEAA0B;IAEvC,UAAU,2DAAoB;IAE9B,SAAS,8DAAuB;IAEhC,YAAY,yDAAuC;IAEnD,mBAAmB,iDAAmB,OAAO,KAAK,YAAY,eAAI;IAElE,gBAAgB,0BAAoB;IAEpC,wBAAwB,kCAA4B;IAEpD,OAAO,EAAG,OAAO,CAAC;IAElB,aAAa,0CAEV;IAEH,kBAAkB,oDAAqB;IAEvC,WAAW,6DAA8B;IAEzC,UAAU,4DAA6B;IAEvC,kBAAkB,6EAAqC;IAEvD,UAAU,EAAG,oBAAoB,EAAE,CAAC;IAEpC,YAAY,EAAG,aAAa,CAAC,GAAG,CAAC,CAAC;IAElC,QAAQ,+CAQL;IAEH,SAAS,CAAC,MAAM,SAAkB;IAClC,SAAS,CAAC,UAAU,kBAAsB;IAC1C,SAAS,CAAC,UAAU,aAAsB;IAC1C,SAAS,CAAC,uBAAuB,0BAAmC;IACpE,SAAS,CAAC,uBAAuB,0BAAmC;IACpE,SAAS,CAAC,2BAA2B,8BAAuC;IAE5E,QAAQ,IAAI,IAAI;IAMhB,WAAW;IAQX,WAAW;IAQX,eAAe;IAIf,SAAS;IAQT,YAAY,CAAC,QAAQ,EAAE,MAAM;IAI7B,eAAe,CAAC,OAAO,EAAE,OAAO;IAIhC,QAAQ,CAAC,eAAe,CAAC,EAAE,WAAW,EAAE,QAAQ,CAAC,EAAE;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAA;KAAE;IAoBpE,eAAe;IAoBtB,OAAO,CAAC,QAAQ;IAQhB,OAAO,CAAC,eAAe;IAWvB,OAAO,CAAC,oBAAoB;yCA3JnB,eAAe;2CAAf,eAAe;CAoK3B"}
@@ -1,45 +1,48 @@
1
- import { OnInit } from '@angular/core';
2
- import { ThyPopoverRef } from 'ngx-tethys/popover';
3
- import { AIPlugin, AITable, AITableChangeOptions, AITableFields, AITableFieldType, AITableRecords, AITableSelectOptionStyle, AITableValue } from './core';
4
- import { AITableGridSelectionService } from './services/selection.service';
5
- import { AIFieldConfig, AITableFieldMenuItem, AITableReferences } from './types';
1
+ import { ElementRef, OnDestroy, OnInit, Signal } from '@angular/core';
2
+ import { KoEventObject } from './angular-konva';
3
+ import { Coordinate } from './core';
4
+ import { AITableGridBase } from './grid-base.component';
5
+ import { AITableRendererConfig, ScrollActionOptions } from './types';
6
6
  import * as i0 from "@angular/core";
7
- export declare class AITableGrid implements OnInit {
8
- aiRecords: import("@angular/core").ModelSignal<AITableRecords>;
9
- aiFields: import("@angular/core").ModelSignal<AITableFields>;
10
- aiFieldConfig: import("@angular/core").InputSignal<AIFieldConfig | undefined>;
11
- aiReadonly: import("@angular/core").InputSignal<boolean | undefined>;
12
- aiPlugins: import("@angular/core").InputSignal<AIPlugin[] | undefined>;
13
- aiReferences: import("@angular/core").InputSignal<AITableReferences | undefined>;
14
- aiBuildRenderDataFn: import("@angular/core").InputSignal<((aiTable: AITable) => AITableValue) | undefined>;
15
- AITableFieldType: typeof AITableFieldType;
16
- AITableSelectOptionStyle: typeof AITableSelectOptionStyle;
17
- aiTable: AITable;
18
- gridData: import("@angular/core").Signal<AITableValue>;
19
- isSelectedAll: import("@angular/core").Signal<boolean>;
20
- onChange: import("@angular/core").OutputEmitterRef<AITableChangeOptions>;
21
- aiTableInitialized: import("@angular/core").OutputEmitterRef<AITable>;
22
- fieldMenus: AITableFieldMenuItem[];
23
- mouseoverRef: ThyPopoverRef<any>;
24
- private ngZone;
25
- private elementRef;
26
- private destroyRef;
27
- private aiTableGridFieldService;
28
- private aiTableGridEventService;
29
- aiTableGridSelectionService: AITableGridSelectionService;
7
+ export declare class AITableGrid extends AITableGridBase implements OnInit, OnDestroy {
8
+ timer: number | null;
9
+ resizeObserver: ResizeObserver;
10
+ fieldHeadHeight: number;
11
+ ADD_BUTTON_WIDTH: number;
12
+ containerRect: import("@angular/core").WritableSignal<{
13
+ width: number;
14
+ height: number;
15
+ }>;
16
+ hasContainerRect: Signal<boolean>;
17
+ container: Signal<ElementRef<any> | undefined>;
18
+ verticalBarRef: Signal<ElementRef<any> | undefined>;
19
+ horizontalBarRef: Signal<ElementRef<any> | undefined>;
20
+ linearRows: Signal<import("./types").AITableLinearRow[]>;
21
+ visibleColumnsMap: Signal<Map<string, number>>;
22
+ visibleRowsIndexMap: Signal<Map<string, number>>;
23
+ containerElement: Signal<any>;
24
+ rendererConfig: Signal<AITableRendererConfig>;
25
+ coordinate: Signal<Coordinate>;
26
+ scrollTotalHeight: Signal<number>;
27
+ constructor();
30
28
  ngOnInit(): void;
31
- initAITable(): void;
32
- initService(): void;
33
- buildFieldMenus(): void;
34
- addRecord(): void;
35
- selectRecord(recordId: string): void;
36
- toggleSelectAll(checked: boolean): void;
37
- addField(gridColumnBlank: HTMLElement): void;
38
- private subscribeEvents;
39
- private dblClick;
40
- private mouseoverHandle;
41
- private closeHoverCellEditor;
29
+ ngOnDestroy(): void;
30
+ private initContext;
31
+ stageMousemove(e: KoEventObject<MouseEvent>): void;
32
+ stageMousedown(e: KoEventObject<MouseEvent>): void;
33
+ stageClick(e: KoEventObject<MouseEvent>): void;
34
+ stageDblclick(e: KoEventObject<MouseEvent>): void;
35
+ private bindWheel;
36
+ scrollAction: (options: ScrollActionOptions) => void;
37
+ private bindScrollBarScroll;
38
+ private bindGlobalMousedown;
39
+ private resetScrolling;
40
+ private horizontalScroll;
41
+ private verticalScroll;
42
+ private setContainerRect;
43
+ private containerResizeListener;
44
+ private toggleHoverCellEditor;
42
45
  static ɵfac: i0.ɵɵFactoryDeclaration<AITableGrid, never>;
43
- static ɵcmp: i0.ɵɵComponentDeclaration<AITableGrid, "ai-table-grid", never, { "aiRecords": { "alias": "aiRecords"; "required": true; "isSignal": true; }; "aiFields": { "alias": "aiFields"; "required": true; "isSignal": true; }; "aiFieldConfig": { "alias": "aiFieldConfig"; "required": false; "isSignal": true; }; "aiReadonly": { "alias": "aiReadonly"; "required": false; "isSignal": true; }; "aiPlugins": { "alias": "aiPlugins"; "required": false; "isSignal": true; }; "aiReferences": { "alias": "aiReferences"; "required": false; "isSignal": true; }; "aiBuildRenderDataFn": { "alias": "aiBuildRenderDataFn"; "required": false; "isSignal": true; }; }, { "aiRecords": "aiRecordsChange"; "aiFields": "aiFieldsChange"; "onChange": "onChange"; "aiTableInitialized": "aiTableInitialized"; }, never, never, true, never>;
46
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableGrid, "ai-table-grid", never, {}, {}, never, never, true, never>;
44
47
  }
45
48
  //# sourceMappingURL=grid.component.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"grid.component.d.ts","sourceRoot":"","sources":["../../packages/grid/src/grid.component.ts"],"names":[],"mappings":"AACA,OAAO,EAUH,MAAM,EAGT,MAAM,eAAe,CAAC;AAUvB,OAAO,EAAoB,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAUrE,OAAO,EAEH,QAAQ,EACR,OAAO,EACP,oBAAoB,EACpB,aAAa,EACb,gBAAgB,EAChB,cAAc,EACd,wBAAwB,EACxB,YAAY,EAIf,MAAM,QAAQ,CAAC;AAIhB,OAAO,EAAE,2BAA2B,EAAE,MAAM,8BAA8B,CAAC;AAC3E,OAAO,EAAE,aAAa,EAAE,oBAAoB,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;;AAEjF,qBA0Ca,WAAY,YAAW,MAAM;IACtC,SAAS,sDAAoC;IAE7C,QAAQ,qDAAmC;IAE3C,aAAa,iEAA0B;IAEvC,UAAU,2DAAoB;IAE9B,SAAS,8DAAuB;IAEhC,YAAY,qEAA8B;IAE1C,mBAAmB,iDAAmB,OAAO,KAAK,YAAY,eAAI;IAElE,gBAAgB,0BAAoB;IAEpC,wBAAwB,kCAA4B;IAEpD,OAAO,EAAG,OAAO,CAAC;IAElB,QAAQ,+CAQL;IAEH,aAAa,0CAEV;IAEH,QAAQ,iEAAkC;IAE1C,kBAAkB,oDAAqB;IAEvC,UAAU,EAAG,oBAAoB,EAAE,CAAC;IAEpC,YAAY,EAAG,aAAa,CAAC,GAAG,CAAC,CAAC;IAElC,OAAO,CAAC,MAAM,CAAkB;IAEhC,OAAO,CAAC,UAAU,CAAsB;IAExC,OAAO,CAAC,UAAU,CAAsB;IAExC,OAAO,CAAC,uBAAuB,CAAmC;IAElE,OAAO,CAAC,uBAAuB,CAAmC;IAE3D,2BAA2B,8BAAuC;IAEzE,QAAQ,IAAI,IAAI;IAOhB,WAAW;IAeX,WAAW;IAQX,eAAe;IAIf,SAAS;IAIT,YAAY,CAAC,QAAQ,EAAE,MAAM;IAI7B,eAAe,CAAC,OAAO,EAAE,OAAO;IAIhC,QAAQ,CAAC,eAAe,EAAE,WAAW;IAKrC,OAAO,CAAC,eAAe;IAoBvB,OAAO,CAAC,QAAQ;IAQhB,OAAO,CAAC,eAAe;IAWvB,OAAO,CAAC,oBAAoB;yCAjJnB,WAAW;2CAAX,WAAW;CA0JvB"}
1
+ {"version":3,"file":"grid.component.d.ts","sourceRoot":"","sources":["../../packages/grid/src/grid.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAMH,UAAU,EACV,SAAS,EACT,MAAM,EACN,MAAM,EAGT,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAmBhD,OAAO,EAAW,UAAU,EAA4C,MAAM,QAAQ,CAAC;AACvF,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAKxD,OAAO,EAAwB,qBAAqB,EAAE,mBAAmB,EAAE,MAAM,SAAS,CAAC;;AAI3F,qBAWa,WAAY,SAAQ,eAAgB,YAAW,MAAM,EAAE,SAAS;IACzE,KAAK,EAAG,MAAM,GAAG,IAAI,CAAC;IAEtB,cAAc,EAAG,cAAc,CAAC;IAEhC,eAAe,SAA8B;IAE7C,gBAAgB,SAAmC;IAEnD,aAAa;;;OAAmC;IAEhD,gBAAgB,kBAEb;IAEH,SAAS,sCAAsC;IAE/C,cAAc,sCAAwC;IAEtD,gBAAgB,sCAA0C;IAE1D,UAAU,+CAEP;IAEH,iBAAiB,8BAGd;IAEH,mBAAmB,8BAEhB;IAEH,gBAAgB,cAEb;IAEH,cAAc,EAAE,MAAM,CAAC,qBAAqB,CAAC,CAqB1C;IAEH,UAAU,qBAEP;IAEH,iBAAiB,iBAEd;;IAsBM,QAAQ,IAAI,IAAI;IAKzB,WAAW,IAAI,IAAI;IAInB,OAAO,CAAC,WAAW;IAWnB,cAAc,CAAC,CAAC,EAAE,aAAa,CAAC,UAAU,CAAC;IAyB3C,cAAc,CAAC,CAAC,EAAE,aAAa,CAAC,UAAU,CAAC;IA0B3C,UAAU,CAAC,CAAC,EAAE,aAAa,CAAC,UAAU,CAAC;IAgEvC,aAAa,CAAC,CAAC,EAAE,aAAa,CAAC,UAAU,CAAC;IAsB1C,OAAO,CAAC,SAAS;IAUjB,YAAY,YAAa,mBAAmB,UAmB1C;IAEF,OAAO,CAAC,mBAAmB;IAc3B,OAAO,CAAC,mBAAmB;IAW3B,OAAO,CAAC,cAAc,CAIpB;IAEF,OAAO,CAAC,gBAAgB,CAOtB;IAEF,OAAO,CAAC,cAAc;IAStB,OAAO,CAAC,gBAAgB;IAOxB,OAAO,CAAC,uBAAuB;IAa/B,OAAO,CAAC,qBAAqB;yCA1VpB,WAAW;2CAAX,WAAW;CA2YvB"}
package/package.json CHANGED
@@ -1,10 +1,13 @@
1
1
  {
2
2
  "name": "@ai-table/grid",
3
- "version": "0.0.12",
3
+ "version": "0.0.14",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "^18.1.4",
6
6
  "@angular/core": "^18.1.4",
7
- "bson-objectid": "^2.0.4"
7
+ "bson-objectid": "^2.0.4",
8
+ "lru-cache": "^11.0.0",
9
+ "konva": "^9.3.14",
10
+ "grapheme-splitter": "^1.0.4"
8
11
  },
9
12
  "dependencies": {
10
13
  "tslib": "^2.3.0"
package/public-api.d.ts CHANGED
@@ -1,7 +1,11 @@
1
+ export * from './components';
2
+ export * from './constants';
3
+ export * from './core/index';
4
+ export * from './dom-grid.component';
1
5
  export * from './grid.component';
2
- export * from './types';
3
6
  export * from './pipes';
4
- export * from './constants';
5
- export * from './core';
6
- export * from './components';
7
+ export * from './renderer';
8
+ export * from './services';
9
+ export * from './types';
10
+ export * from './utils';
7
11
  //# sourceMappingURL=public-api.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"public-api.d.ts","sourceRoot":"","sources":["../../packages/grid/src/public-api.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC;AACxB,cAAc,aAAa,CAAC;AAC5B,cAAc,QAAQ,CAAC;AACvB,cAAc,cAAc,CAAC"}
1
+ {"version":3,"file":"public-api.d.ts","sourceRoot":"","sources":["../../packages/grid/src/public-api.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,sBAAsB,CAAC;AACrC,cAAc,kBAAkB,CAAC;AACjC,cAAc,SAAS,CAAC;AACxB,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC"}
@@ -0,0 +1,16 @@
1
+ import { StageConfig } from 'konva/lib/Stage';
2
+ import { AITableField, Coordinate } from '../../core';
3
+ import { AITableIconConfig } from '../../types';
4
+ import * as i0 from "@angular/core";
5
+ export declare class AITableAddField {
6
+ coordinate: import("@angular/core").InputSignal<Coordinate>;
7
+ fields: import("@angular/core").InputSignal<AITableField[]>;
8
+ columnStopIndex: import("@angular/core").InputSignal<number>;
9
+ btnWidth: number;
10
+ x: import("@angular/core").Signal<number>;
11
+ rectConfig: import("@angular/core").Signal<Partial<StageConfig>>;
12
+ addIconConfig: import("@angular/core").Signal<AITableIconConfig>;
13
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITableAddField, never>;
14
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableAddField, "ai-table-add-field", never, { "coordinate": { "alias": "coordinate"; "required": true; "isSignal": true; }; "fields": { "alias": "fields"; "required": true; "isSignal": true; }; "columnStopIndex": { "alias": "columnStopIndex"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
15
+ }
16
+ //# sourceMappingURL=add-field-column.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"add-field-column.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/components/add-field-column.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAW9C,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AACtD,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;;AAIhD,qBAYa,eAAe;IACxB,UAAU,kDAAgC;IAE1C,MAAM,sDAAoC;IAE1C,eAAe,8CAA4B;IAE3C,QAAQ,SAAmC;IAE3C,CAAC,yCAIE;IAEH,UAAU,uDAgBP;IAEH,aAAa,oDASV;yCA1CM,eAAe;2CAAf,eAAe;CA2C3B"}
@@ -0,0 +1,14 @@
1
+ import Konva from 'konva';
2
+ import { AITableCellsConfig } from '../../types';
3
+ import * as i0 from "@angular/core";
4
+ export declare class AITableCells {
5
+ config: import("@angular/core").InputSignal<AITableCellsConfig>;
6
+ cellsShapeConfig: import("@angular/core").Signal<{
7
+ listening: boolean;
8
+ perfectDrawEnabled: boolean;
9
+ sceneFunc: (ctx: Konva.Context) => void;
10
+ }>;
11
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITableCells, never>;
12
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableCells, "ai-table-cells", never, { "config": { "alias": "config"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
13
+ }
14
+ //# sourceMappingURL=cells.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cells.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/components/cells.component.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;;AAGjD,qBAOa,YAAY;IACrB,MAAM,0DAAwC;IAE9C,gBAAgB;;;yBAMS,MAAM,OAAO;OAOnC;yCAhBM,YAAY;2CAAZ,YAAY;CAiBxB"}
@@ -0,0 +1,73 @@
1
+ import { StageConfig } from 'konva/lib/Stage';
2
+ import { AITableFieldHeadConfig } from '../../types';
3
+ import * as i0 from "@angular/core";
4
+ export declare class AITableFieldHead {
5
+ config: import("@angular/core").InputSignal<AITableFieldHeadConfig>;
6
+ textOffset: number;
7
+ textMeasure: {
8
+ context: CanvasRenderingContext2D | null;
9
+ measureText: (text: string, maxWidth?: number | undefined, maxLineCount?: number | undefined) => {
10
+ width: number;
11
+ height: number;
12
+ lastLineWidth: number;
13
+ text?: undefined;
14
+ isOverflow?: undefined;
15
+ } | {
16
+ width: number;
17
+ height: number;
18
+ text: string;
19
+ isOverflow: boolean;
20
+ lastLineWidth: number;
21
+ };
22
+ setFont: (options?: import("../../utils").AITableTextMeasureOptions) => void;
23
+ reset: () => void;
24
+ };
25
+ availableTextWidth: import("@angular/core").Signal<number>;
26
+ textData: import("@angular/core").Signal<{
27
+ width: number;
28
+ height: number;
29
+ isOverflow: boolean | undefined;
30
+ }>;
31
+ groupConfig: import("@angular/core").Signal<Partial<StageConfig>>;
32
+ bgConfig: import("@angular/core").Signal<{
33
+ x: number;
34
+ y: number;
35
+ name: string;
36
+ width: number;
37
+ height: number;
38
+ fill: string;
39
+ stroke: string;
40
+ strokeWidth: number;
41
+ opacity: number;
42
+ }>;
43
+ fieldIconConfig: import("@angular/core").Signal<{
44
+ field: import("@ai-table/grid").AITableField;
45
+ x: number;
46
+ y: number;
47
+ width: number;
48
+ height: number;
49
+ fill: string;
50
+ }>;
51
+ textConfig: import("@angular/core").Signal<{
52
+ x: number;
53
+ y: undefined;
54
+ width: number;
55
+ height: number;
56
+ text: string;
57
+ lineHeight: number;
58
+ }>;
59
+ moreIconConfig: import("@angular/core").Signal<{
60
+ name: string;
61
+ x: number;
62
+ y: number;
63
+ data: string;
64
+ fill: string;
65
+ background: string;
66
+ backgroundWidth: number;
67
+ backgroundHeight: number;
68
+ cornerRadius: number;
69
+ }>;
70
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITableFieldHead, never>;
71
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableFieldHead, "ai-table-field-head", never, { "config": { "alias": "config"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
72
+ }
73
+ //# sourceMappingURL=field-head.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"field-head.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/components/field-head.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAe9C,OAAO,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAC;;AAMrD,qBAkBa,gBAAgB;IACzB,MAAM,8DAA4C;IAElD,UAAU,SAAyF;IAEnG,WAAW;;;;;;;;;;;;;;;;;MAAiB;IAE5B,kBAAkB,yCAQf;IAEH,QAAQ;;;;OASL;IAEH,WAAW,uDAKR;IAEH,QAAQ;;;;;;;;;;OAgBL;IAEH,eAAe;;;;;;;OAUZ;IAEH,UAAU;;;;;;;OAUP;IAEH,cAAc;;;;;;;;;;OAiBX;yCA9FM,gBAAgB;2CAAhB,gBAAgB;CA+F5B"}
@@ -0,0 +1,17 @@
1
+ import { AITableFieldTypeIconConfig } from '../../types';
2
+ import * as i0 from "@angular/core";
3
+ export declare class AITableFieldIcon {
4
+ config: import("@angular/core").InputSignal<AITableFieldTypeIconConfig>;
5
+ iconConfig: import("@angular/core").Signal<{
6
+ x: number | undefined;
7
+ y: number | undefined;
8
+ size: number | undefined;
9
+ backgroundHeight: number | undefined;
10
+ listening: boolean;
11
+ data: string | null;
12
+ fill: string | undefined;
13
+ }>;
14
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITableFieldIcon, never>;
15
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableFieldIcon, "ai-table-field-icon", never, { "config": { "alias": "config"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
16
+ }
17
+ //# sourceMappingURL=field-icon.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"field-icon.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/components/field-icon.component.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAC;;AAGzD,qBAOa,gBAAgB;IACzB,MAAM,kEAAgD;IAEtD,UAAU;;;;;;;;OA0CP;yCA7CM,gBAAgB;2CAAhB,gBAAgB;CA8C5B"}
@@ -0,0 +1,14 @@
1
+ import Konva from 'konva';
2
+ import { AITableCellsConfig } from '../../types';
3
+ import * as i0 from "@angular/core";
4
+ export declare class AITableFrozenCells {
5
+ config: import("@angular/core").InputSignal<AITableCellsConfig>;
6
+ frozenCellsConfig: import("@angular/core").Signal<{
7
+ listening: boolean;
8
+ perfectDrawEnabled: boolean;
9
+ sceneFunc: (ctx: Konva.Context) => void;
10
+ }>;
11
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITableFrozenCells, never>;
12
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableFrozenCells, "ai-table-frozen-cells", never, { "config": { "alias": "config"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
13
+ }
14
+ //# sourceMappingURL=frozen-cells.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"frozen-cells.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/components/frozen-cells.component.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;;AAGjD,qBAOa,kBAAkB;IAC3B,MAAM,0DAAwC;IAE9C,iBAAiB;;;yBAMQ,MAAM,OAAO;OAQnC;yCAjBM,kBAAkB;2CAAlB,kBAAkB;CAkB9B"}
@@ -0,0 +1,47 @@
1
+ import { StageConfig } from 'konva/lib/Stage';
2
+ import { AITableCheckType, AITableCreateHeadsConfig } from '../../types';
3
+ import * as i0 from "@angular/core";
4
+ export declare class AITableFrozenColumnHeads {
5
+ config: import("@angular/core").InputSignal<AITableCreateHeadsConfig>;
6
+ coordinate: import("@angular/core").Signal<import("@ai-table/grid").Coordinate>;
7
+ isChecked: import("@angular/core").Signal<boolean>;
8
+ fieldHeadHeight: import("@angular/core").Signal<number>;
9
+ headConfigs: import("@angular/core").Signal<import("../../types").AITableFieldHeadConfig[]>;
10
+ numberHeadBgConfig: import("@angular/core").Signal<Partial<StageConfig>>;
11
+ topLineConfig: {
12
+ x: number;
13
+ y: number;
14
+ points: number[];
15
+ stroke: string;
16
+ strokeWidth: number;
17
+ listening: boolean;
18
+ };
19
+ bottomLineConfig: import("@angular/core").Signal<{
20
+ x: number;
21
+ y: number;
22
+ points: number[];
23
+ stroke: string;
24
+ strokeWidth: number;
25
+ listening: boolean;
26
+ }>;
27
+ iconConfig: import("@angular/core").Signal<{
28
+ name: string;
29
+ x: number;
30
+ y: number;
31
+ type: AITableCheckType;
32
+ fill: string;
33
+ }>;
34
+ headBgConfig: import("@angular/core").Signal<{
35
+ x: number;
36
+ y: number;
37
+ width: number;
38
+ height: number;
39
+ stroke: string;
40
+ strokeWidth: number;
41
+ fill: string;
42
+ listening: boolean;
43
+ }>;
44
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITableFrozenColumnHeads, never>;
45
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableFrozenColumnHeads, "ai-table-frozen-column-heads", never, { "config": { "alias": "config"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
46
+ }
47
+ //# sourceMappingURL=frozen-heads.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"frozen-heads.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/components/frozen-heads.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAU9C,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,aAAa,CAAC;;AAKzE,qBAkBa,wBAAwB;IACjC,MAAM,gEAA8C;IAEpD,UAAU,sEAEP;IAEH,SAAS,0CAGN;IAEH,eAAe,yCAEZ;IAEH,WAAW,iFAMR;IAEH,kBAAkB,uDASf;IAEH,aAAa;;;;;;;MAOX;IAEF,gBAAgB;;;;;;;OASb;IAEH,UAAU;;;;;;OAWP;IAEH,YAAY;;;;;;;;;OAYT;yCAhFM,wBAAwB;2CAAxB,wBAAwB;CAiFpC"}
@@ -0,0 +1,22 @@
1
+ import { AITableCellsConfig } from '../../types';
2
+ import * as i0 from "@angular/core";
3
+ export declare class AITableFrozenPlaceholderCells {
4
+ config: import("@angular/core").InputSignal<AITableCellsConfig>;
5
+ frozenPlaceHolderCellsConfig: import("@angular/core").Signal<{
6
+ key: string;
7
+ name: string;
8
+ x: number;
9
+ y: number;
10
+ width: number;
11
+ height: number;
12
+ fill: string;
13
+ strokeEnabled: boolean;
14
+ hitStrokeWidth: number;
15
+ transformsEnabled: string;
16
+ perfectDrawEnabled: boolean;
17
+ shadowEnabled: boolean;
18
+ }[]>;
19
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITableFrozenPlaceholderCells, never>;
20
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableFrozenPlaceholderCells, "ai-table-frozen-placeholder-cells", never, { "config": { "alias": "config"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
21
+ }
22
+ //# sourceMappingURL=frozen-placeholder-cells.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"frozen-placeholder-cells.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/components/frozen-placeholder-cells.component.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;;AAGjD,qBAWa,6BAA6B;IACtC,MAAM,0DAAwC;IAE9C,4BAA4B;;;;;;;;;;;;;SAOzB;yCAVM,6BAA6B;2CAA7B,6BAA6B;CAWzC"}
@@ -0,0 +1,9 @@
1
+ import { AITableCreateHeadsConfig } from '../../types';
2
+ import * as i0 from "@angular/core";
3
+ export declare class AITableColumnHeads {
4
+ config: import("@angular/core").InputSignal<AITableCreateHeadsConfig>;
5
+ headConfigs: import("@angular/core").Signal<import("../../types").AITableFieldHeadConfig[]>;
6
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITableColumnHeads, never>;
7
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableColumnHeads, "ai-table-column-heads", never, { "config": { "alias": "config"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
8
+ }
9
+ //# sourceMappingURL=heads.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"heads.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/components/heads.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,wBAAwB,EAAE,MAAM,aAAa,CAAC;;AAIvD,qBAWa,kBAAkB;IAC3B,MAAM,gEAA8C;IAEpD,WAAW,iFAOR;yCAVM,kBAAkB;2CAAlB,kBAAkB;CAW9B"}
@@ -0,0 +1,11 @@
1
+ import { AITablePointPosition, AITableRowHeadsConfig } from '../../types';
2
+ import * as i0 from "@angular/core";
3
+ export declare class AITableHoverRowHeads {
4
+ config: import("@angular/core").InputSignal<AITableRowHeadsConfig>;
5
+ pointPosition: import("@angular/core").Signal<AITablePointPosition>;
6
+ headConfigs: import("@angular/core").Signal<any[]>;
7
+ createHoverRowHeads: (pointPosition: AITablePointPosition) => any[];
8
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITableHoverRowHeads, never>;
9
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableHoverRowHeads, "ai-table-hover-row-heads", never, { "config": { "alias": "config"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
10
+ }
11
+ //# sourceMappingURL=hover-row-heads.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hover-row-heads.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/components/hover-row-heads.component.ts"],"names":[],"mappings":"AAYA,OAAO,EAAqC,oBAAoB,EAAE,qBAAqB,EAAkB,MAAM,aAAa,CAAC;;AAI7H,qBAkBa,oBAAoB;IAC7B,MAAM,6DAA2C;IAEjD,aAAa,uDAEV;IAEH,WAAW,wCAER;IAEH,mBAAmB,kBAAmB,oBAAoB,WA+DxD;yCA1EO,oBAAoB;2CAApB,oBAAoB;CA2EhC"}
@@ -0,0 +1,37 @@
1
+ import { StageConfig } from 'konva/lib/Stage';
2
+ import { AITableIconConfig } from '../../types';
3
+ import * as i0 from "@angular/core";
4
+ export declare class AITableIcon {
5
+ config: import("@angular/core").InputSignal<AITableIconConfig>;
6
+ groupConfig: import("@angular/core").Signal<Partial<StageConfig>>;
7
+ squareShapeConfig: import("@angular/core").Signal<{
8
+ name: string | undefined;
9
+ width: any;
10
+ height: any;
11
+ strokeWidth: number;
12
+ fill: any;
13
+ cornerRadius: any;
14
+ opacity: number | undefined;
15
+ }>;
16
+ iconConfig: import("@angular/core").Signal<{
17
+ x: any;
18
+ y: any;
19
+ data: any;
20
+ width: number;
21
+ height: number;
22
+ fill: string | CanvasGradient;
23
+ offsetX: number | undefined;
24
+ offsetY: number | undefined;
25
+ scaleX: number | undefined;
26
+ scaleY: number | undefined;
27
+ rotation: number | undefined;
28
+ stroke: string | CanvasGradient | undefined;
29
+ strokeWidth: number;
30
+ transformsEnabled: any;
31
+ perfectDrawEnabled: boolean;
32
+ listening: boolean;
33
+ }>;
34
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITableIcon, never>;
35
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableIcon, "ai-table-icon", never, { "config": { "alias": "config"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
36
+ }
37
+ //# sourceMappingURL=icon.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"icon.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/components/icon.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAI9C,OAAO,EAAoB,iBAAiB,EAAE,MAAM,aAAa,CAAC;;AAElE,qBAYa,WAAW;IACpB,MAAM,yDAAuC;IAE7C,WAAW,uDAGR;IAEH,iBAAiB;;;;;;;;OAoBd;IAEH,UAAU;;;;;;;;;;;;;;;;;OA+CP;yCA7EM,WAAW;2CAAX,WAAW;CA8EvB"}
@@ -0,0 +1,14 @@
1
+ export * from './add-field-column.component';
2
+ export * from './cells.component';
3
+ export * from './field-head.component';
4
+ export * from './field-icon.component';
5
+ export * from './frozen-cells.component';
6
+ export * from './frozen-heads.component';
7
+ export * from './frozen-placeholder-cells.component';
8
+ export * from './heads.component';
9
+ export * from './hover-row-heads.component';
10
+ export * from './icon.component';
11
+ export * from './other-rows.component';
12
+ export * from './placeholder-cells.component';
13
+ export * from './text.component';
14
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC;AAC7C,cAAc,mBAAmB,CAAC;AAClC,cAAc,wBAAwB,CAAC;AACvC,cAAc,wBAAwB,CAAC;AACvC,cAAc,0BAA0B,CAAC;AACzC,cAAc,0BAA0B,CAAC;AACzC,cAAc,sCAAsC,CAAC;AACrD,cAAc,mBAAmB,CAAC;AAClC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,kBAAkB,CAAC;AACjC,cAAc,wBAAwB,CAAC;AACvC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,kBAAkB,CAAC"}
@@ -0,0 +1,31 @@
1
+ import { AITableRowHeadsConfig, AITableRowType } from '../../types';
2
+ import * as i0 from "@angular/core";
3
+ export declare class AITableOtherRows {
4
+ config: import("@angular/core").InputSignal<AITableRowHeadsConfig>;
5
+ AITableRowType: typeof AITableRowType;
6
+ otherConfigs: import("@angular/core").Signal<{
7
+ type: AITableRowType.add;
8
+ addBtnConfig: {
9
+ key: string;
10
+ y: number;
11
+ name: string;
12
+ width: number;
13
+ height: number;
14
+ fill: string;
15
+ };
16
+ }[]>;
17
+ createOtherRows: (config: AITableRowHeadsConfig) => {
18
+ type: AITableRowType.add;
19
+ addBtnConfig: {
20
+ key: string;
21
+ y: number;
22
+ name: string;
23
+ width: number;
24
+ height: number;
25
+ fill: string;
26
+ };
27
+ }[];
28
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITableOtherRows, never>;
29
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableOtherRows, "ai-table-other-rows", never, { "config": { "alias": "config"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
30
+ }
31
+ //# sourceMappingURL=other-rows.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"other-rows.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/components/other-rows.component.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,qBAAqB,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;;AAEpE,qBAea,gBAAgB;IACzB,MAAM,6DAA2C;IAEjD,cAAc,wBAAkB;IAEhC,YAAY;;;;;;;;;;SAET;IAEH,eAAe,WAAY,qBAAqB;;;;;;;;;;QAuB9C;yCAhCO,gBAAgB;2CAAhB,gBAAgB;CAiC5B"}
@@ -0,0 +1,22 @@
1
+ import { AITableCellsConfig } from '../../types';
2
+ import * as i0 from "@angular/core";
3
+ export declare class AITablePlaceholderCells {
4
+ config: import("@angular/core").InputSignal<AITableCellsConfig>;
5
+ frozenPlaceHolderCellsConfig: import("@angular/core").Signal<{
6
+ key: string;
7
+ name: string;
8
+ x: number;
9
+ y: number;
10
+ width: number;
11
+ height: number;
12
+ fill: string;
13
+ strokeEnabled: boolean;
14
+ hitStrokeWidth: number;
15
+ transformsEnabled: string;
16
+ perfectDrawEnabled: boolean;
17
+ shadowEnabled: boolean;
18
+ }[]>;
19
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITablePlaceholderCells, never>;
20
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITablePlaceholderCells, "ai-table-placeholder-cells", never, { "config": { "alias": "config"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
21
+ }
22
+ //# sourceMappingURL=placeholder-cells.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"placeholder-cells.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/components/placeholder-cells.component.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;;AAGjD,qBAWa,uBAAuB;IAChC,MAAM,0DAAwC;IAE9C,4BAA4B;;;;;;;;;;;;;SAEzB;yCALM,uBAAuB;2CAAvB,uBAAuB;CAMnC"}