@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,99 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class AITableText {
3
+ config: import("@angular/core").InputSignal<import("konva/lib/Shape").ShapeConfig>;
4
+ textConfig: import("@angular/core").Signal<{
5
+ fillPatternImage?: HTMLImageElement | undefined;
6
+ fillPatternX?: number | undefined;
7
+ fillPatternY?: number | undefined;
8
+ fillPatternOffset?: import("konva/lib/types").Vector2d | undefined;
9
+ fillPatternOffsetX?: number | undefined;
10
+ fillPatternOffsetY?: number | undefined;
11
+ fillPatternScale?: import("konva/lib/types").Vector2d | undefined;
12
+ fillPatternScaleX?: number | undefined;
13
+ fillPatternScaleY?: number | undefined;
14
+ fillPatternRotation?: number | undefined;
15
+ fillPatternRepeat?: string | undefined;
16
+ fillLinearGradientStartPoint?: import("konva/lib/types").Vector2d | undefined;
17
+ fillLinearGradientStartPointX?: number | undefined;
18
+ fillLinearGradientStartPointY?: number | undefined;
19
+ fillLinearGradientEndPoint?: import("konva/lib/types").Vector2d | undefined;
20
+ fillLinearGradientEndPointX?: number | undefined;
21
+ fillLinearGradientEndPointY?: number | undefined;
22
+ fillLinearGradientColorStops?: (string | number)[] | undefined;
23
+ fillRadialGradientStartPoint?: import("konva/lib/types").Vector2d | undefined;
24
+ fillRadialGradientStartPointX?: number | undefined;
25
+ fillRadialGradientStartPointY?: number | undefined;
26
+ fillRadialGradientEndPoint?: import("konva/lib/types").Vector2d | undefined;
27
+ fillRadialGradientEndPointX?: number | undefined;
28
+ fillRadialGradientEndPointY?: number | undefined;
29
+ fillRadialGradientStartRadius?: number | undefined;
30
+ fillRadialGradientEndRadius?: number | undefined;
31
+ fillRadialGradientColorStops?: (string | number)[] | undefined;
32
+ fillEnabled?: boolean | undefined;
33
+ fillPriority?: string | undefined;
34
+ fillRule?: CanvasFillRule | undefined;
35
+ stroke?: string | CanvasGradient | undefined;
36
+ strokeWidth?: number | undefined;
37
+ fillAfterStrokeEnabled?: boolean | undefined;
38
+ hitStrokeWidth?: string | number | undefined;
39
+ strokeScaleEnabled?: boolean | undefined;
40
+ strokeHitEnabled?: boolean | undefined;
41
+ strokeEnabled?: boolean | undefined;
42
+ lineJoin?: import("konva/lib/Shape").LineJoin | undefined;
43
+ lineCap?: import("konva/lib/Shape").LineCap | undefined;
44
+ sceneFunc?: ((con: import("konva/lib/Context").Context, shape: import("konva/lib/Shape").Shape<import("konva/lib/Shape").ShapeConfig>) => void) | undefined;
45
+ hitFunc?: ((con: import("konva/lib/Context").Context, shape: import("konva/lib/Shape").Shape<import("konva/lib/Shape").ShapeConfig>) => void) | undefined;
46
+ shadowColor?: string | undefined;
47
+ shadowBlur?: number | undefined;
48
+ shadowOffset?: import("konva/lib/types").Vector2d | undefined;
49
+ shadowOffsetX?: number | undefined;
50
+ shadowOffsetY?: number | undefined;
51
+ shadowOpacity?: number | undefined;
52
+ shadowEnabled?: boolean | undefined;
53
+ shadowForStrokeEnabled?: boolean | undefined;
54
+ dash?: number[] | undefined;
55
+ dashOffset?: number | undefined;
56
+ dashEnabled?: boolean | undefined;
57
+ perfectDrawEnabled?: boolean | undefined;
58
+ visible?: boolean | undefined;
59
+ id?: string | undefined;
60
+ name?: string | undefined;
61
+ opacity?: number | undefined;
62
+ scale?: import("konva/lib/types").Vector2d | undefined;
63
+ scaleX?: number | undefined;
64
+ skewX?: number | undefined;
65
+ skewY?: number | undefined;
66
+ scaleY?: number | undefined;
67
+ rotation?: number | undefined;
68
+ rotationDeg?: number | undefined;
69
+ offset?: import("konva/lib/types").Vector2d | undefined;
70
+ offsetX?: number | undefined;
71
+ offsetY?: number | undefined;
72
+ draggable?: boolean | undefined;
73
+ dragDistance?: number | undefined;
74
+ dragBoundFunc?: ((this: import("konva/lib/Node").Node<import("konva/lib/Node").NodeConfig>, pos: import("konva/lib/types").Vector2d) => import("konva/lib/types").Vector2d) | undefined;
75
+ preventDefault?: boolean | undefined;
76
+ globalCompositeOperation?: ("" | "lighter" | "source-over" | "source-in" | "source-out" | "source-atop" | "destination-over" | "destination-in" | "destination-out" | "destination-atop" | "copy" | "xor" | "multiply" | "screen" | "overlay" | "darken" | "lighten" | "color-dodge" | "color-burn" | "hard-light" | "soft-light" | "difference" | "exclusion" | "hue" | "saturation" | "color" | "luminosity") | undefined;
77
+ filters?: import("konva/lib/Node").Filter[] | undefined;
78
+ x: number | undefined;
79
+ y: number | undefined;
80
+ width: number | undefined;
81
+ height: number | undefined;
82
+ text: any;
83
+ padding: any;
84
+ align: any;
85
+ verticalAlign: any;
86
+ fill: string | CanvasGradient;
87
+ textDecoration: any;
88
+ fontSize: any;
89
+ fontStyle: any;
90
+ ellipsis: any;
91
+ wrap: any;
92
+ transformsEnabled: any;
93
+ listening: boolean;
94
+ fontFamily: any;
95
+ }>;
96
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITableText, never>;
97
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableText, "ai-table-text", never, { "config": { "alias": "config"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
98
+ }
99
+ //# sourceMappingURL=text.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"text.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/components/text.component.ts"],"names":[],"mappings":";AAgBA,qBAOa,WAAW;IACpB,MAAM,6EAAuC;IAE7C,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAyCP;yCA5CM,WAAW;2CAAX,WAAW;CA6CvB"}
@@ -0,0 +1,7 @@
1
+ import { RectConfig } from 'konva/lib/shapes/Rect';
2
+ import { AITableCellsConfig } from '../../types';
3
+ export declare const createActiveCellBorder: (config: AITableCellsConfig) => {
4
+ activeCellBorder: RectConfig | null;
5
+ frozenActiveCellBorder: RectConfig | null;
6
+ };
7
+ //# sourceMappingURL=create-active-cell-border.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create-active-cell-border.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/creations/create-active-cell-border.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAGnD,OAAO,EAAE,kBAAkB,EAAkB,MAAM,aAAa,CAAC;AAGjE,eAAO,MAAM,sBAAsB,WAAY,kBAAkB;;;CAuEhE,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { AITableCellsDrawerConfig } from '../../types';
2
+ /**
3
+ * 绘制单元格内容的函数
4
+ * 利用 Canvas API 绘制每个单元格的背景颜色、文本以及其他可能的样式。这个函数通常用于自定义表格渲染,尤其是在处理大量数据时,通过直接操作 Canvas 来提高渲染性能
5
+ * @param config
6
+ */
7
+ export declare const createCells: (config: AITableCellsDrawerConfig) => void;
8
+ //# sourceMappingURL=create-cells.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create-cells.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/creations/create-cells.ts"],"names":[],"mappings":"AAQA,OAAO,EAAmB,wBAAwB,EAAiC,MAAM,aAAa,CAAC;AAMvG;;;;GAIG;AACH,eAAO,MAAM,WAAW,WAAY,wBAAwB,SA4H3D,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { AITableCreateHeadsConfig, AITableFieldHeadConfig } from '../../types';
2
+ export declare const createColumnHeads: (config: AITableCreateHeadsConfig) => AITableFieldHeadConfig[];
3
+ //# sourceMappingURL=create-heads.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create-heads.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/creations/create-heads.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,wBAAwB,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAC;AAE/E,eAAO,MAAM,iBAAiB,WAAY,wBAAwB,6BA2CjE,CAAC"}
@@ -0,0 +1,12 @@
1
+ import { AITableCell } from '../../types';
2
+ import { Layout } from './layout-drawer';
3
+ export declare class AddRowLayout extends Layout {
4
+ renderAddFieldBlank(): void;
5
+ private renderCell;
6
+ private renderFirstCell;
7
+ private renderLastCell;
8
+ private renderCommonCell;
9
+ render({ isHoverRow }: Pick<AITableCell, 'isHoverRow'>): void;
10
+ }
11
+ export declare const addRowLayout: AddRowLayout;
12
+ //# sourceMappingURL=add-row-layout-drawer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"add-row-layout-drawer.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/drawers/add-row-layout-drawer.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAEzC,qBAAa,YAAa,SAAQ,MAAM;IAC3B,mBAAmB;IAe5B,OAAO,CAAC,UAAU;IAqBlB,OAAO,CAAC,eAAe;IA+BvB,OAAO,CAAC,cAAc;IAYtB,OAAO,CAAC,gBAAgB;IAQxB,MAAM,CAAC,EAAE,UAAU,EAAE,EAAE,IAAI,CAAC,WAAW,EAAE,YAAY,CAAC;CAWzD;AAED,eAAO,MAAM,YAAY,cAAqB,CAAC"}
@@ -0,0 +1,22 @@
1
+ import { AITableField } from '../../core';
2
+ import { AITableRender } from '../../types';
3
+ import { Drawer } from './drawer';
4
+ /**
5
+ * 处理和渲染表格单元格的内容
6
+ */
7
+ export declare class CellDrawer extends Drawer {
8
+ initStyle(field: AITableField, styleProps: {
9
+ fontWeight: any;
10
+ }): void | null;
11
+ renderCell(render: AITableRender, ctx?: CanvasRenderingContext2D | undefined): void | void[] | null;
12
+ private renderCellText;
13
+ private renderCellSelect;
14
+ private renderCellMultiSelect;
15
+ private renderSingleSelectCell;
16
+ private renderCellDate;
17
+ private renderCellRate;
18
+ private renderCellProgress;
19
+ private renderCellMember;
20
+ }
21
+ export declare const cellDrawer: CellDrawer;
22
+ //# sourceMappingURL=cell-drawer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cell-drawer.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/drawers/cell-drawer.ts"],"names":[],"mappings":"AAgDA,OAAO,EAAW,YAAY,EAA8E,MAAM,YAAY,CAAC;AAC/H,OAAO,EAA2D,aAAa,EAAsB,MAAM,aAAa,CAAC;AAEzH,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC;;GAEG;AACH,qBAAa,UAAW,SAAQ,MAAM;IAE3B,SAAS,CAAC,KAAK,EAAE,YAAY,EAAE,UAAU,EAAE;QAAE,UAAU,EAAE,GAAG,CAAA;KAAE,GAAG,IAAI,GAAG,IAAI;IAqB5E,UAAU,CAAC,MAAM,EAAE,aAAa,EAAE,GAAG,CAAC,EAAE,wBAAwB,GAAG,SAAS;IA4BnF,OAAO,CAAC,cAAc;IA8DtB,OAAO,CAAC,gBAAgB;IASxB,OAAO,CAAC,qBAAqB;IA0M7B,OAAO,CAAC,sBAAsB;IA2F9B,OAAO,CAAC,cAAc;IAwBtB,OAAO,CAAC,cAAc;IA0BtB,OAAO,CAAC,kBAAkB;IA6C1B,OAAO,CAAC,gBAAgB;CAqG3B;AAED,eAAO,MAAM,UAAU,YAAmB,CAAC"}
@@ -0,0 +1,136 @@
1
+ import GraphemeSplitter from 'grapheme-splitter';
2
+ import { AITableArc, AITableAvatarSize, AITableAvatarType, AITableCtxStyle, AITableImage, AITableLabel, AITableLine, AITableRect, AITableText, AITableTextEllipsis, AITableWrapText } from '../../types';
3
+ export declare const graphemeSplitter: GraphemeSplitter;
4
+ /**
5
+ * 用于在 Canvas 上进行的各种绘图操作,包含了文本绘制、矩形绘制、路径绘制以及一些几何计算等功能
6
+ */
7
+ export declare class Drawer {
8
+ ctx: CanvasRenderingContext2D;
9
+ needDraw: boolean;
10
+ colors: {
11
+ primary: string;
12
+ gray100: string;
13
+ gray200: string;
14
+ gray300: string;
15
+ gray800: string;
16
+ gray600: string;
17
+ gray700: string;
18
+ white: string;
19
+ black: string;
20
+ transparent: string;
21
+ gray80: string;
22
+ headSelectedBgColor: string;
23
+ itemActiveBgColor: string;
24
+ waring: string;
25
+ success: string;
26
+ };
27
+ initCtx(ctx: CanvasRenderingContext2D): void;
28
+ setStyle(options: AITableCtxStyle): void;
29
+ textEllipsis(options: AITableTextEllipsis): {
30
+ text: string;
31
+ textWidth: number;
32
+ isEllipsis: boolean;
33
+ };
34
+ line(options: AITableLine): void;
35
+ arc(options: AITableArc): void;
36
+ rect(options: AITableRect): void;
37
+ customRect(options: AITableRect): void;
38
+ wrapText(options: AITableWrapText): import("../../types").AITableWrapTextResult;
39
+ text(options: AITableText): void;
40
+ tag(options: AITableLabel): {
41
+ width: number;
42
+ height: number;
43
+ };
44
+ image(options: AITableImage, crossOrigin?: boolean, allowDefault?: boolean): void;
45
+ avatar(options: {
46
+ x: number;
47
+ y: number;
48
+ url: string;
49
+ id: string;
50
+ title: string;
51
+ type?: AITableAvatarType;
52
+ size?: AITableAvatarSize;
53
+ opacity?: number;
54
+ bgColor?: string;
55
+ }): void | null;
56
+ /**
57
+ * 方法将椭圆弧的端点参数化形式转换为中心参数化形式
58
+ * 接受弧线的端点参数,并计算出弧线的中心点坐标、起始角度、终止角度等参数
59
+ * 返回值:一个包含中心点坐标、半径、旋转角度、起始角度以及角度差的对象,这些参数可以直接用于绘制椭圆弧
60
+ * @returns [cx, cy, rx, ry, theta, dTheta, psi, fs]
61
+ */
62
+ private convertEndpointToCenterParameterization;
63
+ /**
64
+ * 计算两个点 (x1, y1) 和 (x2, y2) 之间的直线距离
65
+ * @returns 两个点 (x1, y1) 和 (x2, y2) 之间的直线距离,单位与输入的坐标值相同
66
+ */
67
+ private getLineLength;
68
+ /**
69
+ * 计算三次贝塞尔曲线上给定参数 t 对应的点的坐标.
70
+ * 可以在指定的 t 参数下计算出曲线上精确的一个点,这个点可以用于绘制平滑曲线的一部分
71
+ * @param pct - 0 到 1 之间的参数,用于指定曲线上的点的位置
72
+ * @param P1x - 曲线的起点 x 坐标
73
+ * @param P1y - 曲线的起点 y 坐标
74
+ * @param P2x - 曲线的第一个控制点 x 坐标
75
+ * @param P2y - 曲线的第一个控制点 y 坐标
76
+ * @param P3x - 曲线的第二个控制点 x 坐标
77
+ * @param P3y - 曲线的第二个控制点 y 坐标
78
+ * @param P4x - 曲线的终点 x 坐标
79
+ * @param P4y - 曲线的终点 y 坐标
80
+ * @returns
81
+ */
82
+ private getPointOnCubicBezier;
83
+ /**
84
+ * 计算二次贝塞尔曲线上给定参数 t 对应的点的坐标
85
+ * @param pct - 0 到 1 之间的参数,用于指定曲线上的点的位置
86
+ * @param P1x - 曲线的起点 x 坐标
87
+ * @param P1y - 曲线的起点 y 坐标
88
+ * @param P2x - 曲线的控制点 x 坐标
89
+ * @param P2y - 曲线的控制点 y 坐标
90
+ * @param P3x - 曲线的终点 x 坐标
91
+ * @param P3y - 曲线的终点 y 坐标
92
+ * @returns
93
+ */
94
+ private getPointOnQuadraticBezier;
95
+ /**
96
+ * 计算椭圆弧上给定角度 θ 对应的点的坐标
97
+ * @param cx - 椭圆的中心点 x 坐标
98
+ * @param cy - 椭圆的中心点 y 坐标
99
+ * @param rx - 椭圆的 x 轴半径
100
+ * @param ry - 椭圆的 y 轴半径
101
+ * @param theta - 椭圆弧的起始角度
102
+ * @param psi - 椭圆弧的旋转角度
103
+ * @returns
104
+ */
105
+ private getPointOnEllipticalArc;
106
+ /**
107
+ * 计算基于不同路径命令的长度
108
+ * @param x - 起点 x 坐标
109
+ * @param y - 起点 y 坐标
110
+ * @param cmd - 路径命令
111
+ * @param points - 与路径命令相关的点的坐标或控制参数
112
+ * @returns
113
+ */
114
+ private calcLength;
115
+ /**
116
+ * 解析 SVG 路径数据字符串,将其转换为一个包含路径命令和坐标点的数组对象
117
+ * @param data - SVG 路径数据字符串
118
+ * @returns
119
+ */
120
+ private parsePathData;
121
+ /**
122
+ * 根据传入的路径数据 data 在画布上绘制路径
123
+ * @param options
124
+ */
125
+ path(options: {
126
+ x: number;
127
+ y: number;
128
+ data: string;
129
+ size?: number;
130
+ scaleX?: number;
131
+ scaleY?: number;
132
+ fill: string;
133
+ }): void;
134
+ }
135
+ export declare const drawer: Drawer;
136
+ //# sourceMappingURL=drawer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"drawer.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/drawers/drawer.ts"],"names":[],"mappings":"AAAA,OAAO,gBAAgB,MAAM,mBAAmB,CAAC;AAkBjD,OAAO,EACH,UAAU,EACV,iBAAiB,EACjB,iBAAiB,EACjB,eAAe,EACf,YAAY,EACZ,YAAY,EACZ,WAAW,EACX,WAAW,EACX,WAAW,EACX,mBAAmB,EACnB,eAAe,EAElB,MAAM,aAAa,CAAC;AAIrB,eAAO,MAAM,gBAAgB,kBAAyB,CAAC;AAEvD;;GAEG;AACH,qBAAa,MAAM;IACf,GAAG,EAAE,wBAAwB,CAA0B;IACvD,QAAQ,UAAS;IACjB,MAAM;;;;;;;;;;;;;;;;MAAuB;IAEtB,OAAO,CAAC,GAAG,EAAE,wBAAwB;IAUrC,QAAQ,CAAC,OAAO,EAAE,eAAe;IAejC,YAAY,CAAC,OAAO,EAAE,mBAAmB;;;;;IAsDzC,IAAI,CAAC,OAAO,EAAE,WAAW;IAuBzB,GAAG,CAAC,OAAO,EAAE,UAAU;IAevB,IAAI,CAAC,OAAO,EAAE,WAAW;IA6CzB,UAAU,CAAC,OAAO,EAAE,WAAW;IAkC/B,QAAQ,CAAC,OAAO,EAAE,eAAe;IA0HjC,IAAI,CAAC,OAAO,EAAE,WAAW;IAiCzB,GAAG,CAAC,OAAO,EAAE,YAAY,GAAG;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE;IAyC7D,KAAK,CAAC,OAAO,EAAE,YAAY,EAAE,WAAW,CAAC,EAAE,OAAO,EAAE,YAAY,CAAC,EAAE,OAAO;IAiD1E,MAAM,CAAC,OAAO,EAAE;QACnB,CAAC,EAAE,MAAM,CAAC;QACV,CAAC,EAAE,MAAM,CAAC;QACV,GAAG,EAAE,MAAM,CAAC;QACZ,EAAE,EAAE,MAAM,CAAC;QACX,KAAK,EAAE,MAAM,CAAC;QACd,IAAI,CAAC,EAAE,iBAAiB,CAAC;QACzB,IAAI,CAAC,EAAE,iBAAiB,CAAC;QACzB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,OAAO,CAAC,EAAE,MAAM,CAAC;KACpB;IAwDD;;;;;OAKG;IACH,OAAO,CAAC,uCAAuC;IAkE/C;;;OAGG;IACH,OAAO,CAAC,aAAa;IAIrB;;;;;;;;;;;;;OAaG;IACH,OAAO,CAAC,qBAAqB;IAoC7B;;;;;;;;;;OAUG;IACH,OAAO,CAAC,yBAAyB;IAsBjC;;;;;;;;;OASG;IACH,OAAO,CAAC,uBAAuB;IAa/B;;;;;;;OAOG;IACH,OAAO,CAAC,UAAU;IAsDlB;;;;OAIG;IACH,OAAO,CAAC,aAAa;IAuPrB;;;OAGG;IACI,IAAI,CAAC,OAAO,EAAE;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE;CA8D7H;AAED,eAAO,MAAM,MAAM,QAAe,CAAC"}
@@ -0,0 +1,22 @@
1
+ import { AITableLayout } from '../../types';
2
+ import { Drawer } from './drawer';
3
+ /**
4
+ * 用于处理表格行或单元格的布局和绘制。
5
+ * 它提供了基本的布局信息(如位置、大小等),并定义了常用的绘图方法(如渲染缩进区域、添加新字段的空白区域等)。
6
+ * 该类继承自 Drawer,并被其他更具体的布局类(如 RecordRowLayout)扩展和使用
7
+ */
8
+ export declare class Layout extends Drawer {
9
+ protected x: number;
10
+ protected y: number;
11
+ protected rowHeight: number;
12
+ protected columnWidth: number;
13
+ protected rowIndex: number;
14
+ protected columnIndex: number;
15
+ protected columnCount: number;
16
+ protected containerWidth: number;
17
+ init({ x, y, rowIndex, columnIndex, rowHeight, columnWidth, columnCount, containerWidth }: AITableLayout): void;
18
+ protected get isFirst(): boolean;
19
+ protected get isLast(): boolean;
20
+ protected renderAddFieldBlank(): void;
21
+ }
22
+ //# sourceMappingURL=layout-drawer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"layout-drawer.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/drawers/layout-drawer.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC;;;;GAIG;AACH,qBAAa,MAAO,SAAQ,MAAM;IAE9B,SAAS,CAAC,CAAC,SAAK;IAChB,SAAS,CAAC,CAAC,SAAK;IAEhB,SAAS,CAAC,SAAS,SAAK;IAExB,SAAS,CAAC,WAAW,SAAK;IAE1B,SAAS,CAAC,QAAQ,SAAK;IAEvB,SAAS,CAAC,WAAW,SAAK;IAE1B,SAAS,CAAC,WAAW,SAAK;IAE1B,SAAS,CAAC,cAAc,SAAK;IAG7B,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,WAAW,EAAE,WAAW,EAAE,cAAc,EAAE,EAAE,aAAa;IAYxG,SAAS,KAAK,OAAO,YAEpB;IAGD,SAAS,KAAK,MAAM,YAEnB;IAED,SAAS,CAAC,mBAAmB;CAYhC"}
@@ -0,0 +1,14 @@
1
+ import { AITableCell } from '../../types';
2
+ import { Layout } from './layout-drawer';
3
+ /**
4
+ * 绘制行的布局,通过直接操作 Canvas 提供高效的渲染方法。
5
+ * 它继承自 Layout 类,包含了用于绘制行中单元格(尤其是首列和尾列)的几个方法
6
+ */
7
+ export declare class RecordRowLayout extends Layout {
8
+ private renderFirstCell;
9
+ private renderLastCell;
10
+ private renderCommonCell;
11
+ render(config: AITableCell): void;
12
+ }
13
+ export declare const recordRowLayout: RecordRowLayout;
14
+ //# sourceMappingURL=record-row-layout-drawer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"record-row-layout-drawer.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/drawers/record-row-layout-drawer.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAEzC;;;GAGG;AACH,qBAAa,eAAgB,SAAQ,MAAM;IAEvC,OAAO,CAAC,eAAe;IAkDvB,OAAO,CAAC,cAAc;IAoBtB,OAAO,CAAC,gBAAgB;IAiBxB,MAAM,CAAC,MAAM,EAAE,WAAW;CAM7B;AAED,eAAO,MAAM,eAAe,iBAAwB,CAAC"}
@@ -0,0 +1,4 @@
1
+ export * from './creations/create-active-cell-border';
2
+ export * from './creations/create-cells';
3
+ export * from './renderer.component';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/renderer/index.ts"],"names":[],"mappings":"AAAA,cAAc,uCAAuC,CAAC;AACtD,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC"}
@@ -0,0 +1,64 @@
1
+ import { StageConfig } from 'konva/lib/Stage';
2
+ import { KoEventObject } from '../angular-konva';
3
+ import { AITable } from '../core';
4
+ import { AITableRendererConfig } from '../types';
5
+ import * as i0 from "@angular/core";
6
+ export declare class AITableRenderer {
7
+ config: import("@angular/core").InputSignal<AITableRendererConfig>;
8
+ koMousemove: import("@angular/core").OutputEmitterRef<KoEventObject<MouseEvent>>;
9
+ koMousedown: import("@angular/core").OutputEmitterRef<KoEventObject<MouseEvent>>;
10
+ koWheel: import("@angular/core").OutputEmitterRef<KoEventObject<WheelEvent>>;
11
+ koClick: import("@angular/core").OutputEmitterRef<KoEventObject<MouseEvent>>;
12
+ koDblclick: import("@angular/core").OutputEmitterRef<KoEventObject<MouseEvent>>;
13
+ fields: import("@angular/core").Signal<import("../core").AITableField[]>;
14
+ coordinate: import("@angular/core").Signal<import("../core").Coordinate>;
15
+ containerWidth: import("@angular/core").Signal<number>;
16
+ containerHeight: import("@angular/core").Signal<number>;
17
+ scrollState: import("@angular/core").Signal<import("../types").AITableScrollState>;
18
+ visibleRangeInfo: import("@angular/core").Signal<{
19
+ rowStartIndex: number;
20
+ rowStopIndex: number;
21
+ columnStartIndex: number;
22
+ columnStopIndex: number;
23
+ }>;
24
+ frozenAreaWidth: import("@angular/core").Signal<number>;
25
+ lastColumnWidth: import("@angular/core").Signal<number>;
26
+ lastColumnOffset: import("@angular/core").Signal<number>;
27
+ cellGroupClipWidth: import("@angular/core").Signal<number>;
28
+ stageConfig: import("@angular/core").Signal<Partial<StageConfig>>;
29
+ gridGroupConfig: import("@angular/core").Signal<Partial<StageConfig>>;
30
+ commonGroupConfig: import("@angular/core").Signal<Partial<StageConfig>>;
31
+ attachGroupConfig: import("@angular/core").Signal<Partial<StageConfig>>;
32
+ frozenAttachGroupConfig: import("@angular/core").Signal<Partial<StageConfig>>;
33
+ offsetYConfig: import("@angular/core").Signal<Partial<StageConfig>>;
34
+ offsetXConfig: import("@angular/core").Signal<Partial<StageConfig>>;
35
+ offsetConfig: import("@angular/core").Signal<Partial<StageConfig>>;
36
+ columnHeadConfig: import("@angular/core").Signal<{
37
+ aiTable: AITable;
38
+ coordinate: import("../core").Coordinate;
39
+ fields: import("../core").AITableField[];
40
+ columnStartIndex: number;
41
+ columnStopIndex: number;
42
+ pointPosition: import("../types").AITablePointPosition;
43
+ }>;
44
+ cellsConfig: import("@angular/core").Signal<{
45
+ aiTable: AITable;
46
+ coordinate: import("../core").Coordinate;
47
+ references: import("../types").AITableReferences;
48
+ rowStartIndex: number;
49
+ rowStopIndex: number;
50
+ columnStartIndex: number;
51
+ columnStopIndex: number;
52
+ }>;
53
+ activeCellBorderConfig: import("@angular/core").Signal<{
54
+ activeCellBorder: import("konva/lib/shapes/Rect").RectConfig | null;
55
+ frozenActiveCellBorder: import("konva/lib/shapes/Rect").RectConfig | null;
56
+ }>;
57
+ stageMousemove(e: KoEventObject<MouseEvent>): void;
58
+ stageMousedown(e: KoEventObject<MouseEvent>): void;
59
+ stageClick(e: KoEventObject<MouseEvent>): void;
60
+ stageDblclick(e: KoEventObject<MouseEvent>): void;
61
+ static ɵfac: i0.ɵɵFactoryDeclaration<AITableRenderer, never>;
62
+ static ɵcmp: i0.ɵɵComponentDeclaration<AITableRenderer, "ai-table-renderer", never, { "config": { "alias": "config"; "required": true; "isSignal": true; }; }, { "koMousemove": "koMousemove"; "koMousedown": "koMousedown"; "koWheel": "koWheel"; "koClick": "koClick"; "koDblclick": "koDblclick"; }, never, ["*"], true, never>;
63
+ }
64
+ //# sourceMappingURL=renderer.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"renderer.component.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/renderer/renderer.component.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAe,aAAa,EAAoB,MAAM,kBAAkB,CAAC;AAEhF,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;;AAmBjD,qBAsBa,eAAe;IACxB,MAAM,6DAA2C;IAEjD,WAAW,sEAAuC;IAElD,WAAW,sEAAuC;IAElD,OAAO,sEAAuC;IAE9C,OAAO,sEAAuC;IAE9C,UAAU,sEAAuC;IAEjD,MAAM,mEAEH;IAEH,UAAU,+DAEP;IAEH,cAAc,yCAEX;IAEH,eAAe,yCAEZ;IAEH,WAAW,wEAER;IAEH,gBAAgB;;;;;OAEb;IAEH,eAAe,yCAEZ;IAEH,eAAe,yCAEZ;IAEH,gBAAgB,yCAEb;IAEH,kBAAkB,yCAMf;IAEH,WAAW,uDAOR;IAEH,eAAe,uDAOZ;IAEH,iBAAiB,uDAOd;IAEH,iBAAiB,uDAOd;IAEH,uBAAuB,uDAOpB;IAEH,aAAa,uDAKV;IAEH,aAAa,uDAKV;IAEH,YAAY,uDAMT;IAEH,gBAAgB;;;;;;;OAab;IAEH,WAAW;;;;;;;;OAYR;IAEH,sBAAsB;;;OAEnB;IAEH,cAAc,CAAC,CAAC,EAAE,aAAa,CAAC,UAAU,CAAC;IAI3C,cAAc,CAAC,CAAC,EAAE,aAAa,CAAC,UAAU,CAAC;IAI3C,UAAU,CAAC,CAAC,EAAE,aAAa,CAAC,UAAU,CAAC;IAIvC,aAAa,CAAC,CAAC,EAAE,aAAa,CAAC,UAAU,CAAC;yCAzKjC,eAAe;2CAAf,eAAe;CA4K3B"}
@@ -1,6 +1,8 @@
1
+ import { ThyPopoverRef } from 'ngx-tethys/popover';
1
2
  import { Subject } from 'rxjs';
3
+ import { AbstractEditCellEditor } from '../components';
2
4
  import { AITable, AITableFieldType } from '../core';
3
- import { AITableGridCellRenderSchema } from '../types';
5
+ import { AITableGridCellRenderSchema, AITableOpenEditOptions } from '../types';
4
6
  import * as i0 from "@angular/core";
5
7
  export declare class AITableGridEventService {
6
8
  aiTable: AITable;
@@ -10,13 +12,25 @@ export declare class AITableGridEventService {
10
12
  mouseoverEvent$: Subject<MouseEvent>;
11
13
  globalMouseoverEvent$: Subject<MouseEvent>;
12
14
  globalMousedownEvent$: Subject<MouseEvent>;
15
+ private cellEditorPopoverRef;
13
16
  private destroyRef;
14
- private overlay;
15
17
  private thyPopover;
16
18
  initialize(aiTable: AITable, aiFieldRenderers?: Partial<Record<AITableFieldType, AITableGridCellRenderSchema>>): void;
17
19
  registerEvents(element: HTMLElement): void;
18
20
  private getEditorComponent;
19
- openEdit(cellDom: HTMLElement): import("ngx-tethys/popover").ThyPopoverRef<unknown, unknown, unknown>;
21
+ openEdit(cellDom: HTMLElement): ThyPopoverRef<unknown, unknown, unknown>;
22
+ getOriginPosition(aiTable: AITable, options: AITableOpenEditOptions): {
23
+ x: number;
24
+ y: number;
25
+ width: number;
26
+ height: number;
27
+ };
28
+ openCellEditor(aiTable: AITable, options: AITableOpenEditOptions): ThyPopoverRef<AbstractEditCellEditor<any, import("../core").AITableField>, unknown, unknown>;
29
+ closeCellEditor(): void;
30
+ getCurrentEditCell(): {
31
+ recordId: string;
32
+ fieldId: string;
33
+ } | null;
20
34
  static ɵfac: i0.ɵɵFactoryDeclaration<AITableGridEventService, never>;
21
35
  static ɵprov: i0.ɵɵInjectableDeclaration<AITableGridEventService>;
22
36
  }
@@ -1 +1 @@
1
- {"version":3,"file":"event.service.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/services/event.service.ts"],"names":[],"mappings":"AAGA,OAAO,EAA2B,OAAO,EAAE,MAAM,MAAM,CAAC;AAExD,OAAO,EAAE,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACpD,OAAO,EAAE,2BAA2B,EAAE,MAAM,UAAU,CAAC;;AAGvD,qBACa,uBAAuB;IAChC,OAAO,EAAG,OAAO,CAAC;IAElB,gBAAgB,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,gBAAgB,EAAE,2BAA2B,CAAC,CAAC,CAAC;IAElF,cAAc,sBAA6B;IAE3C,eAAe,sBAA6B;IAE5C,eAAe,sBAA6B;IAE5C,qBAAqB,sBAA6B;IAElD,qBAAqB,sBAA6B;IAElD,OAAO,CAAC,UAAU,CAAsB;IAExC,OAAO,CAAC,OAAO,CAAmB;IAElC,OAAO,CAAC,UAAU,CAAsB;IAExC,UAAU,CAAC,OAAO,EAAE,OAAO,EAAE,gBAAgB,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,gBAAgB,EAAE,2BAA2B,CAAC,CAAC;IAK9G,cAAc,CAAC,OAAO,EAAE,WAAW;IAgCnC,OAAO,CAAC,kBAAkB;IAO1B,QAAQ,CAAC,OAAO,EAAE,WAAW;yCAjEpB,uBAAuB;6CAAvB,uBAAuB;CAkGnC"}
1
+ {"version":3,"file":"event.service.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/services/event.service.ts"],"names":[],"mappings":"AAIA,OAAO,EAAc,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAC/D,OAAO,EAA2B,OAAO,EAAE,MAAM,MAAM,CAAC;AACxD,OAAO,EAAE,sBAAsB,EAAE,MAAM,eAAe,CAAC;AAEvD,OAAO,EAAE,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACpD,OAAO,EAAE,2BAA2B,EAAE,sBAAsB,EAAE,MAAM,UAAU,CAAC;;AAG/E,qBACa,uBAAuB;IAChC,OAAO,EAAG,OAAO,CAAC;IAElB,gBAAgB,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,gBAAgB,EAAE,2BAA2B,CAAC,CAAC,CAAC;IAElF,cAAc,sBAA6B;IAE3C,eAAe,sBAA6B;IAE5C,eAAe,sBAA6B;IAE5C,qBAAqB,sBAA6B;IAElD,qBAAqB,sBAA6B;IAElD,OAAO,CAAC,oBAAoB,CAAqD;IAEjF,OAAO,CAAC,UAAU,CAAsB;IAExC,OAAO,CAAC,UAAU,CAAsB;IAExC,UAAU,CAAC,OAAO,EAAE,OAAO,EAAE,gBAAgB,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,gBAAgB,EAAE,2BAA2B,CAAC,CAAC;IAK9G,cAAc,CAAC,OAAO,EAAE,WAAW;IAgCnC,OAAO,CAAC,kBAAkB;IAO1B,QAAQ,CAAC,OAAO,EAAE,WAAW;IAiC7B,iBAAiB,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,sBAAsB;;;;;;IAwCnE,cAAc,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,sBAAsB;IAwDhE,eAAe;IAOf,kBAAkB;;;;yCAzMT,uBAAuB;6CAAvB,uBAAuB;CAwNnC"}
@@ -1,7 +1,7 @@
1
- import { ElementRef } from '@angular/core';
2
1
  import { ThyPopover } from 'ngx-tethys/popover';
3
- import { AITable, AITableField } from '../core';
4
- import { AIFieldConfig } from '../types';
2
+ import { FieldMenu } from '../components/field-menu/field-menu.component';
3
+ import { AITable } from '../core';
4
+ import { AIFieldConfig, AITableEditFieldOptions, AITableFieldMenuOptions } from '../types';
5
5
  import * as i0 from "@angular/core";
6
6
  export declare const AI_TABLE_GRID_FIELD_SERVICE_MAP: WeakMap<AITable, AITableGridFieldService>;
7
7
  export declare class AITableGridFieldService {
@@ -9,7 +9,8 @@ export declare class AITableGridFieldService {
9
9
  aiFieldConfig: AIFieldConfig | undefined;
10
10
  constructor(thyPopover: ThyPopover);
11
11
  initAIFieldConfig(aiFieldConfig: AIFieldConfig | undefined): void;
12
- editFieldProperty(origin: HTMLElement | ElementRef<any>, aiTable: AITable, aiEditField: AITableField, isUpdate: boolean): void;
12
+ editFieldProperty(aiTable: AITable, options: AITableEditFieldOptions): import("ngx-tethys/popover").ThyPopoverRef<unknown, unknown, unknown>;
13
+ openFieldMenu(aiTable: AITable, options: AITableFieldMenuOptions): import("ngx-tethys/popover").ThyPopoverRef<FieldMenu, unknown, unknown>;
13
14
  static ɵfac: i0.ɵɵFactoryDeclaration<AITableGridFieldService, never>;
14
15
  static ɵprov: i0.ɵɵInjectableDeclaration<AITableGridFieldService>;
15
16
  }
@@ -1 +1 @@
1
- {"version":3,"file":"field.service.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/services/field.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAc,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAEhD,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;;AAEzC,eAAO,MAAM,+BAA+B,2CAAkD,CAAC;AAE/F,qBACa,uBAAuB;IAGpB,OAAO,CAAC,UAAU;IAF9B,aAAa,EAAE,aAAa,GAAG,SAAS,CAAC;gBAErB,UAAU,EAAE,UAAU;IAE1C,iBAAiB,CAAC,aAAa,EAAE,aAAa,GAAG,SAAS;IAI1D,iBAAiB,CAAC,MAAM,EAAE,WAAW,GAAG,UAAU,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,EAAE,OAAO;yCAT9G,uBAAuB;6CAAvB,uBAAuB;CAsBnC"}
1
+ {"version":3,"file":"field.service.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/services/field.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAEhD,OAAO,EAAE,SAAS,EAAE,MAAM,+CAA+C,CAAC;AAC1E,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,aAAa,EAAE,uBAAuB,EAAE,uBAAuB,EAAE,MAAM,UAAU,CAAC;;AAE3F,eAAO,MAAM,+BAA+B,2CAAkD,CAAC;AAE/F,qBACa,uBAAuB;IAGpB,OAAO,CAAC,UAAU;IAF9B,aAAa,EAAE,aAAa,GAAG,SAAS,CAAC;gBAErB,UAAU,EAAE,UAAU;IAE1C,iBAAiB,CAAC,aAAa,EAAE,aAAa,GAAG,SAAS;IAI1D,iBAAiB,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,uBAAuB;IAgBpE,aAAa,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,uBAAuB;yCAzBvD,uBAAuB;6CAAvB,uBAAuB;CA6CnC"}
@@ -0,0 +1,4 @@
1
+ export * from './event.service';
2
+ export * from './field.service';
3
+ export * from './selection.service';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/services/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC;AAChC,cAAc,iBAAiB,CAAC;AAChC,cAAc,qBAAqB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"selection.service.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/services/selection.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;;AAElC,qBACa,2BAA2B;IACpC,OAAO,EAAG,OAAO,CAAC;;IAIlB,UAAU,CAAC,OAAO,EAAE,OAAO;IAI3B,cAAc;IAQd,UAAU,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM;IAK5C,WAAW,CAAC,OAAO,EAAE,MAAM;IAK3B,YAAY,CAAC,QAAQ,EAAE,MAAM;IAa7B,eAAe,CAAC,OAAO,EAAE,OAAO;IAShC,YAAY,CAAC,KAAK,EAAE,UAAU;yCAjDrB,2BAA2B;6CAA3B,2BAA2B;CAuEvC"}
1
+ {"version":3,"file":"selection.service.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/services/selection.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;;AAElC,qBACa,2BAA2B;IACpC,OAAO,EAAG,OAAO,CAAC;;IAIlB,UAAU,CAAC,OAAO,EAAE,OAAO;IAI3B,cAAc;IAQd,UAAU,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM;IAS5C,WAAW,CAAC,OAAO,EAAE,MAAM;IAQ3B,YAAY,CAAC,QAAQ,EAAE,MAAM;IAa7B,eAAe,CAAC,OAAO,EAAE,OAAO;IAShC,YAAY,CAAC,KAAK,EAAE,UAAU;yCAxDrB,2BAA2B;6CAA3B,2BAA2B;CA8EvC"}
@@ -2,8 +2,8 @@
2
2
  @use 'ngx-tethys/styles/index.scss';
3
3
  @use 'ngx-tethys/styles/variables.scss';
4
4
  @use '../components/cell-editors/cell-editor.scss';
5
-
6
- .ai-table-grid {
5
+ @use '../components/cell-views/select/option.scss';
6
+ .ai-table-dom-grid {
7
7
  display: table;
8
8
  width: 100%;
9
9
 
@@ -145,15 +145,75 @@
145
145
  }
146
146
  }
147
147
 
148
- .grid-cell-editor {
149
- .thy-popover-container {
150
- box-shadow: none;
151
- border-radius: inherit;
152
- }
153
- .form-control,
154
- .thy-select-custom,
155
- .select-control-rendered {
148
+ .ai-table-grid {
149
+ display: block;
150
+ width: 100%;
151
+ height: 100%;
152
+ position: relative;
153
+
154
+ .ai-table-grid-view {
155
+ display: block;
156
+ width: 100%;
156
157
  height: 100%;
157
- border-radius: 0;
158
+ }
159
+ .ai-table-horizontal-scroll-bar-wrapper,
160
+ .ai-table-vertical-scroll-bar-wrapper {
161
+ position: absolute;
162
+ will-change: transform;
163
+ cursor: pointer;
164
+
165
+ .ai-table-scroll-bar-inner {
166
+ position: absolute;
167
+ }
168
+
169
+ &::scrollbar {
170
+ width: 18px;
171
+ height: 18px;
172
+ position: absolute;
173
+ top: 0;
174
+ left: 0;
175
+ right: 0;
176
+ bottom: 0;
177
+ }
178
+ &::scrollbar-button {
179
+ display: none;
180
+ height: 0;
181
+ width: 0;
182
+ }
183
+ &::scrollbar-thumb {
184
+ background-color: variables.$gray-500;
185
+ background-clip: padding-box;
186
+ border: calc(18px / 4) solid variables.$black;
187
+ border-radius: calc(18px / 2);
188
+ min-height: 36px;
189
+ }
190
+ &:hover {
191
+ &::scrollbar-thumb {
192
+ background-color: variables.$gray-500;
193
+ }
194
+ }
195
+ }
196
+
197
+ .ai-table-vertical-scroll-bar-wrapper {
198
+ overflow-x: hidden;
199
+ overflow-y: scroll;
200
+ width: 18px;
201
+ right: 0;
202
+
203
+ .ai-table-scroll-bar-inner {
204
+ width: 1px;
205
+ }
206
+ }
207
+
208
+ .ai-table-horizontal-scroll-bar-wrapper {
209
+ overflow-x: scroll;
210
+ overflow-y: hidden;
211
+ height: 18px;
212
+ bottom: 0;
213
+ left: 0;
214
+
215
+ .ai-table-scroll-bar-inner {
216
+ height: 1px;
217
+ }
158
218
  }
159
219
  }