@hailin-zheng/editor-core 1.0.10 → 1.0.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (300) hide show
  1. package/lib/doc-ruler.d.ts +51 -0
  2. package/lib/doc-ruler.js +313 -0
  3. package/lib/doc-ruler.js.map +1 -0
  4. package/lib/framework/common-util.d.ts +63 -0
  5. package/lib/framework/common-util.js +178 -0
  6. package/lib/framework/common-util.js.map +1 -0
  7. package/lib/framework/document-change.d.ts +265 -0
  8. package/lib/framework/document-change.js +1342 -0
  9. package/lib/framework/document-change.js.map +1 -0
  10. package/lib/framework/document-combine.d.ts +24 -0
  11. package/lib/framework/document-combine.js +40 -0
  12. package/lib/framework/document-combine.js.map +1 -0
  13. package/lib/framework/document-comment.d.ts +46 -0
  14. package/lib/framework/document-comment.js +148 -0
  15. package/lib/framework/document-comment.js.map +1 -0
  16. package/lib/framework/document-context.d.ts +149 -0
  17. package/lib/framework/document-context.js +330 -0
  18. package/lib/framework/document-context.js.map +1 -0
  19. package/lib/framework/document-eval-func.d.ts +18 -0
  20. package/lib/framework/document-eval-func.js +48 -0
  21. package/lib/framework/document-eval-func.js.map +1 -0
  22. package/lib/framework/document-event.d.ts +213 -0
  23. package/lib/framework/document-event.js +1054 -0
  24. package/lib/framework/document-event.js.map +1 -0
  25. package/lib/framework/document-history.d.ts +26 -0
  26. package/lib/framework/document-history.js +65 -0
  27. package/lib/framework/document-history.js.map +1 -0
  28. package/lib/framework/document-images-loader.d.ts +16 -0
  29. package/lib/framework/document-images-loader.js +66 -0
  30. package/lib/framework/document-images-loader.js.map +1 -0
  31. package/lib/framework/document-input-cursor.d.ts +78 -0
  32. package/lib/framework/document-input-cursor.js +239 -0
  33. package/lib/framework/document-input-cursor.js.map +1 -0
  34. package/lib/framework/document-paint.d.ts +34 -0
  35. package/lib/framework/document-paint.js +103 -0
  36. package/lib/framework/document-paint.js.map +1 -0
  37. package/lib/framework/document-print-offscreen.d.ts +38 -0
  38. package/lib/framework/document-print-offscreen.js +128 -0
  39. package/lib/framework/document-print-offscreen.js.map +1 -0
  40. package/lib/framework/document-print.d.ts +60 -0
  41. package/lib/framework/document-print.js +203 -0
  42. package/lib/framework/document-print.js.map +1 -0
  43. package/lib/framework/document-segmenter.d.ts +2 -0
  44. package/lib/framework/document-segmenter.js +106 -0
  45. package/lib/framework/document-segmenter.js.map +1 -0
  46. package/lib/framework/document-selection.d.ts +89 -0
  47. package/lib/framework/document-selection.js +358 -0
  48. package/lib/framework/document-selection.js.map +1 -0
  49. package/lib/framework/document-template.d.ts +4 -0
  50. package/lib/framework/document-template.js +20 -0
  51. package/lib/framework/document-template.js.map +1 -0
  52. package/lib/framework/document-textline-mode.d.ts +7 -0
  53. package/lib/framework/document-textline-mode.js +30 -0
  54. package/lib/framework/document-textline-mode.js.map +1 -0
  55. package/lib/framework/element-define.d.ts +319 -0
  56. package/lib/framework/element-define.js +579 -0
  57. package/lib/framework/element-define.js.map +1 -0
  58. package/lib/framework/element-event-define.d.ts +98 -0
  59. package/lib/framework/element-event-define.js +108 -0
  60. package/lib/framework/element-event-define.js.map +1 -0
  61. package/lib/framework/element-measure.d.ts +97 -0
  62. package/lib/framework/element-measure.js +551 -0
  63. package/lib/framework/element-measure.js.map +1 -0
  64. package/lib/framework/element-paint.d.ts +42 -0
  65. package/lib/framework/element-paint.js +170 -0
  66. package/lib/framework/element-paint.js.map +1 -0
  67. package/lib/framework/element-props.d.ts +301 -0
  68. package/lib/framework/element-props.js +809 -0
  69. package/lib/framework/element-props.js.map +1 -0
  70. package/lib/framework/element-reader.d.ts +19 -0
  71. package/lib/framework/element-reader.js +151 -0
  72. package/lib/framework/element-reader.js.map +1 -0
  73. package/lib/framework/element-render-cut.d.ts +55 -0
  74. package/lib/framework/element-render-cut.js +449 -0
  75. package/lib/framework/element-render-cut.js.map +1 -0
  76. package/lib/framework/element-serialize.d.ts +30 -0
  77. package/lib/framework/element-serialize.js +113 -0
  78. package/lib/framework/element-serialize.js.map +1 -0
  79. package/lib/framework/element-util.d.ts +369 -0
  80. package/lib/framework/element-util.js +1463 -0
  81. package/lib/framework/element-util.js.map +1 -0
  82. package/lib/framework/impl/checkbox/checkbox-impl.d.ts +24 -0
  83. package/lib/framework/impl/checkbox/checkbox-impl.js +64 -0
  84. package/lib/framework/impl/checkbox/checkbox-impl.js.map +1 -0
  85. package/lib/framework/impl/comments/comment-content-impl.d.ts +40 -0
  86. package/lib/framework/impl/comments/comment-content-impl.js +105 -0
  87. package/lib/framework/impl/comments/comment-content-impl.js.map +1 -0
  88. package/lib/framework/impl/comments/comment-element-impl.d.ts +21 -0
  89. package/lib/framework/impl/comments/comment-element-impl.js +62 -0
  90. package/lib/framework/impl/comments/comment-element-impl.js.map +1 -0
  91. package/lib/framework/impl/comments/comments-container-impl.d.ts +22 -0
  92. package/lib/framework/impl/comments/comments-container-impl.js +62 -0
  93. package/lib/framework/impl/comments/comments-container-impl.js.map +1 -0
  94. package/lib/framework/impl/comments/comments-util.d.ts +12 -0
  95. package/lib/framework/impl/comments/comments-util.js +67 -0
  96. package/lib/framework/impl/comments/comments-util.js.map +1 -0
  97. package/lib/framework/impl/comments/validate-msg-impl.d.ts +21 -0
  98. package/lib/framework/impl/comments/validate-msg-impl.js +83 -0
  99. package/lib/framework/impl/comments/validate-msg-impl.js.map +1 -0
  100. package/lib/framework/impl/data-element/data-decorate-impl.d.ts +30 -0
  101. package/lib/framework/impl/data-element/data-decorate-impl.js +91 -0
  102. package/lib/framework/impl/data-element/data-decorate-impl.js.map +1 -0
  103. package/lib/framework/impl/data-element/data-element-barcode.d.ts +31 -0
  104. package/lib/framework/impl/data-element/data-element-barcode.js +115 -0
  105. package/lib/framework/impl/data-element/data-element-barcode.js.map +1 -0
  106. package/lib/framework/impl/data-element/data-element-base-impl.d.ts +68 -0
  107. package/lib/framework/impl/data-element/data-element-base-impl.js +205 -0
  108. package/lib/framework/impl/data-element/data-element-base-impl.js.map +1 -0
  109. package/lib/framework/impl/data-element/data-element-check-impl.d.ts +35 -0
  110. package/lib/framework/impl/data-element/data-element-check-impl.js +133 -0
  111. package/lib/framework/impl/data-element/data-element-check-impl.js.map +1 -0
  112. package/lib/framework/impl/data-element/data-element-date-impl.d.ts +23 -0
  113. package/lib/framework/impl/data-element/data-element-date-impl.js +111 -0
  114. package/lib/framework/impl/data-element/data-element-date-impl.js.map +1 -0
  115. package/lib/framework/impl/data-element/data-element-group-impl.d.ts +23 -0
  116. package/lib/framework/impl/data-element/data-element-group-impl.js +130 -0
  117. package/lib/framework/impl/data-element/data-element-group-impl.js.map +1 -0
  118. package/lib/framework/impl/data-element/data-element-image-impl.d.ts +30 -0
  119. package/lib/framework/impl/data-element/data-element-image-impl.js +137 -0
  120. package/lib/framework/impl/data-element/data-element-image-impl.js.map +1 -0
  121. package/lib/framework/impl/data-element/data-element-list-impl.d.ts +22 -0
  122. package/lib/framework/impl/data-element/data-element-list-impl.js +131 -0
  123. package/lib/framework/impl/data-element/data-element-list-impl.js.map +1 -0
  124. package/lib/framework/impl/data-element/data-element-text-impl.d.ts +23 -0
  125. package/lib/framework/impl/data-element/data-element-text-impl.js +103 -0
  126. package/lib/framework/impl/data-element/data-element-text-impl.js.map +1 -0
  127. package/lib/framework/impl/decorate/fill-null-space-imple.d.ts +21 -0
  128. package/lib/framework/impl/decorate/fill-null-space-imple.js +43 -0
  129. package/lib/framework/impl/decorate/fill-null-space-imple.js.map +1 -0
  130. package/lib/framework/impl/document/doc-body-impl.d.ts +27 -0
  131. package/lib/framework/impl/document/doc-body-impl.js +79 -0
  132. package/lib/framework/impl/document/doc-body-impl.js.map +1 -0
  133. package/lib/framework/impl/document/doc-body-part-impl.d.ts +30 -0
  134. package/lib/framework/impl/document/doc-body-part-impl.js +94 -0
  135. package/lib/framework/impl/document/doc-body-part-impl.js.map +1 -0
  136. package/lib/framework/impl/document/doc-container-impl.d.ts +16 -0
  137. package/lib/framework/impl/document/doc-container-impl.js +21 -0
  138. package/lib/framework/impl/document/doc-container-impl.js.map +1 -0
  139. package/lib/framework/impl/document/doc-footer-impl.d.ts +26 -0
  140. package/lib/framework/impl/document/doc-footer-impl.js +77 -0
  141. package/lib/framework/impl/document/doc-footer-impl.js.map +1 -0
  142. package/lib/framework/impl/document/doc-header-impl.d.ts +26 -0
  143. package/lib/framework/impl/document/doc-header-impl.js +83 -0
  144. package/lib/framework/impl/document/doc-header-impl.js.map +1 -0
  145. package/lib/framework/impl/document/doc-impl.d.ts +61 -0
  146. package/lib/framework/impl/document/doc-impl.js +209 -0
  147. package/lib/framework/impl/document/doc-impl.js.map +1 -0
  148. package/lib/framework/impl/media-formula/menstrual-history.d.ts +35 -0
  149. package/lib/framework/impl/media-formula/menstrual-history.js +153 -0
  150. package/lib/framework/impl/media-formula/menstrual-history.js.map +1 -0
  151. package/lib/framework/impl/paragraph/p-impl.d.ts +45 -0
  152. package/lib/framework/impl/paragraph/p-impl.js +156 -0
  153. package/lib/framework/impl/paragraph/p-impl.js.map +1 -0
  154. package/lib/framework/impl/picture/image-impl.d.ts +31 -0
  155. package/lib/framework/impl/picture/image-impl.js +124 -0
  156. package/lib/framework/impl/picture/image-impl.js.map +1 -0
  157. package/lib/framework/impl/radio/radio-impl.d.ts +22 -0
  158. package/lib/framework/impl/radio/radio-impl.js +72 -0
  159. package/lib/framework/impl/radio/radio-impl.js.map +1 -0
  160. package/lib/framework/impl/symbol/br-symbol-impl.d.ts +22 -0
  161. package/lib/framework/impl/symbol/br-symbol-impl.js +54 -0
  162. package/lib/framework/impl/symbol/br-symbol-impl.js.map +1 -0
  163. package/lib/framework/impl/symbol/p-symbol-impl.d.ts +19 -0
  164. package/lib/framework/impl/symbol/p-symbol-impl.js +54 -0
  165. package/lib/framework/impl/symbol/p-symbol-impl.js.map +1 -0
  166. package/lib/framework/impl/table/table-cell-impl.d.ts +37 -0
  167. package/lib/framework/impl/table/table-cell-impl.js +145 -0
  168. package/lib/framework/impl/table/table-cell-impl.js.map +1 -0
  169. package/lib/framework/impl/table/table-impl.d.ts +55 -0
  170. package/lib/framework/impl/table/table-impl.js +363 -0
  171. package/lib/framework/impl/table/table-impl.js.map +1 -0
  172. package/lib/framework/impl/table/table-row-impl.d.ts +26 -0
  173. package/lib/framework/impl/table/table-row-impl.js +75 -0
  174. package/lib/framework/impl/table/table-row-impl.js.map +1 -0
  175. package/lib/framework/impl/table/table-split-cell-patch.d.ts +20 -0
  176. package/lib/framework/impl/table/table-split-cell-patch.js +89 -0
  177. package/lib/framework/impl/table/table-split-cell-patch.js.map +1 -0
  178. package/lib/framework/impl/table/table-split-cell.d.ts +90 -0
  179. package/lib/framework/impl/table/table-split-cell.js +464 -0
  180. package/lib/framework/impl/table/table-split-cell.js.map +1 -0
  181. package/lib/framework/impl/table/table-util.d.ts +150 -0
  182. package/lib/framework/impl/table/table-util.js +678 -0
  183. package/lib/framework/impl/table/table-util.js.map +1 -0
  184. package/lib/framework/impl/text/text-impl.d.ts +32 -0
  185. package/lib/framework/impl/text/text-impl.js +149 -0
  186. package/lib/framework/impl/text/text-impl.js.map +1 -0
  187. package/lib/framework/impl/text/track-run-impl.d.ts +27 -0
  188. package/lib/framework/impl/text/track-run-impl.js +112 -0
  189. package/lib/framework/impl/text/track-run-impl.js.map +1 -0
  190. package/lib/framework/notify.d.ts +13 -0
  191. package/lib/framework/notify.js +116 -0
  192. package/lib/framework/notify.js.map +1 -0
  193. package/lib/framework/range-util.d.ts +40 -0
  194. package/lib/framework/range-util.js +312 -0
  195. package/lib/framework/range-util.js.map +1 -0
  196. package/lib/framework/render-context.d.ts +91 -0
  197. package/lib/framework/render-context.js +384 -0
  198. package/lib/framework/render-context.js.map +1 -0
  199. package/lib/framework/render-define.d.ts +109 -0
  200. package/lib/framework/render-define.js +195 -0
  201. package/lib/framework/render-define.js.map +1 -0
  202. package/lib/framework/selection-overlays.d.ts +30 -0
  203. package/lib/framework/selection-overlays.js +124 -0
  204. package/lib/framework/selection-overlays.js.map +1 -0
  205. package/lib/texteditor.d.ts +318 -0
  206. package/lib/texteditor.js +913 -0
  207. package/lib/texteditor.js.map +1 -0
  208. package/lib/util/subject.d.ts +34 -0
  209. package/lib/util/subject.js +88 -0
  210. package/lib/util/subject.js.map +1 -0
  211. package/{src/med_editor/util/table-bind.ts → lib/util/table-bind.d.ts} +2 -3
  212. package/lib/util/table-bind.js +6 -0
  213. package/lib/util/table-bind.js.map +1 -0
  214. package/package.json +2 -2
  215. package/src/med_editor/doc-ruler.ts +0 -340
  216. package/src/med_editor/framework/common-util.ts +0 -200
  217. package/src/med_editor/framework/document-change.ts +0 -1391
  218. package/src/med_editor/framework/document-combine.ts +0 -44
  219. package/src/med_editor/framework/document-comment.ts +0 -163
  220. package/src/med_editor/framework/document-context.ts +0 -410
  221. package/src/med_editor/framework/document-eval-func.ts +0 -53
  222. package/src/med_editor/framework/document-event.ts +0 -1082
  223. package/src/med_editor/framework/document-history.ts +0 -76
  224. package/src/med_editor/framework/document-images-loader.ts +0 -74
  225. package/src/med_editor/framework/document-input-cursor.ts +0 -244
  226. package/src/med_editor/framework/document-paint.ts +0 -110
  227. package/src/med_editor/framework/document-print-offscreen.ts +0 -134
  228. package/src/med_editor/framework/document-print.ts +0 -219
  229. package/src/med_editor/framework/document-segmenter.ts +0 -211
  230. package/src/med_editor/framework/document-selection.ts +0 -389
  231. package/src/med_editor/framework/document-template.ts +0 -20
  232. package/src/med_editor/framework/document-textline-mode.ts +0 -34
  233. package/src/med_editor/framework/element-define.ts +0 -674
  234. package/src/med_editor/framework/element-event-define.ts +0 -141
  235. package/src/med_editor/framework/element-measure.ts +0 -573
  236. package/src/med_editor/framework/element-paint.ts +0 -176
  237. package/src/med_editor/framework/element-props.ts +0 -938
  238. package/src/med_editor/framework/element-reader.ts +0 -159
  239. package/src/med_editor/framework/element-render-cut.ts +0 -456
  240. package/src/med_editor/framework/element-serialize.ts +0 -126
  241. package/src/med_editor/framework/element-util.ts +0 -1564
  242. package/src/med_editor/framework/impl/checkbox/checkbox-impl.ts +0 -71
  243. package/src/med_editor/framework/impl/comments/comment-content-impl.ts +0 -119
  244. package/src/med_editor/framework/impl/comments/comment-element-impl.ts +0 -65
  245. package/src/med_editor/framework/impl/comments/comments-container-impl.ts +0 -68
  246. package/src/med_editor/framework/impl/comments/comments-util.ts +0 -84
  247. package/src/med_editor/framework/impl/comments/validate-msg-impl.ts +0 -94
  248. package/src/med_editor/framework/impl/data-element/data-decorate-impl.ts +0 -95
  249. package/src/med_editor/framework/impl/data-element/data-element-barcode.ts +0 -127
  250. package/src/med_editor/framework/impl/data-element/data-element-base-impl.ts +0 -234
  251. package/src/med_editor/framework/impl/data-element/data-element-check-impl.ts +0 -146
  252. package/src/med_editor/framework/impl/data-element/data-element-date-impl.ts +0 -128
  253. package/src/med_editor/framework/impl/data-element/data-element-group-impl.ts +0 -150
  254. package/src/med_editor/framework/impl/data-element/data-element-image-impl.ts +0 -147
  255. package/src/med_editor/framework/impl/data-element/data-element-list-impl.ts +0 -142
  256. package/src/med_editor/framework/impl/data-element/data-element-text-impl.ts +0 -117
  257. package/src/med_editor/framework/impl/decorate/fill-null-space-imple.ts +0 -48
  258. package/src/med_editor/framework/impl/document/doc-body-impl.ts +0 -95
  259. package/src/med_editor/framework/impl/document/doc-body-part-impl.ts +0 -104
  260. package/src/med_editor/framework/impl/document/doc-container-impl.ts +0 -24
  261. package/src/med_editor/framework/impl/document/doc-footer-impl.ts +0 -88
  262. package/src/med_editor/framework/impl/document/doc-header-impl.ts +0 -100
  263. package/src/med_editor/framework/impl/document/doc-impl.ts +0 -226
  264. package/src/med_editor/framework/impl/media-formula/menstrual-history.ts +0 -175
  265. package/src/med_editor/framework/impl/paragraph/p-impl.ts +0 -190
  266. package/src/med_editor/framework/impl/picture/image-impl.ts +0 -136
  267. package/src/med_editor/framework/impl/radio/radio-impl.ts +0 -79
  268. package/src/med_editor/framework/impl/symbol/br-symbol-impl.ts +0 -60
  269. package/src/med_editor/framework/impl/symbol/p-symbol-impl.ts +0 -57
  270. package/src/med_editor/framework/impl/table/table-cell-impl.ts +0 -156
  271. package/src/med_editor/framework/impl/table/table-impl.ts +0 -401
  272. package/src/med_editor/framework/impl/table/table-row-impl.ts +0 -83
  273. package/src/med_editor/framework/impl/table/table-split-cell-patch.ts +0 -98
  274. package/src/med_editor/framework/impl/table/table-split-cell.ts +0 -475
  275. package/src/med_editor/framework/impl/table/table-util.ts +0 -716
  276. package/src/med_editor/framework/impl/text/text-impl.ts +0 -163
  277. package/src/med_editor/framework/impl/text/track-run-impl.ts +0 -135
  278. package/src/med_editor/framework/notify.ts +0 -130
  279. package/src/med_editor/framework/range-util.ts +0 -321
  280. package/src/med_editor/framework/render-context.ts +0 -431
  281. package/src/med_editor/framework/render-define.ts +0 -224
  282. package/src/med_editor/framework/selection-overlays.ts +0 -133
  283. package/src/med_editor/texteditor.ts +0 -1010
  284. package/src/med_editor/util/subject.ts +0 -118
  285. package/src/med_editor//345/205/245/351/231/242/350/256/260/345/275/225.json +0 -3573
  286. package/src/med_editor//345/205/245/351/231/242/350/256/260/345/275/225/346/265/213/350/257/225.json +0 -3573
  287. package/src/med_editor//345/205/245/351/231/242/350/256/260/345/275/225/346/265/213/350/257/225bug.json +0 -315
  288. package/src/med_editor//345/205/245/351/231/242/350/256/260/345/275/225/346/265/213/350/257/225/346/211/271/346/263/250.json +0 -122
  289. package/src/med_editor//345/205/245/351/231/242/350/256/260/345/275/225/346/265/213/350/257/225/346/226/207/346/241/243/351/252/214/350/257/201.json +0 -3599
  290. package/src/med_editor//345/205/245/351/231/242/350/256/260/345/275/225/346/265/213/350/257/225/351/225/277/346/226/207/346/234/254.json +0 -24586
  291. package/src/med_editor//345/220/210/345/271/266/347/227/205/347/250/213/345/275/225.json +0 -2874
  292. package/src/med_editor//346/211/213/346/234/257/350/256/260/345/275/225.json +0 -341
  293. package/src/med_editor//346/231/256/351/200/232doc/347/261/273/346/226/207/346/241/243.json +0 -2201
  294. package/src/med_editor//346/243/200/351/252/214/347/224/263/350/257/267/345/215/225.json +0 -1069
  295. package/src/med_editor//347/227/205/347/250/213/345/275/225//345/206/205/351/225/234/344/270/213/346/262/273/347/226/227/350/256/260/345/275/225.json +0 -125
  296. package/src/med_editor//347/227/205/347/250/213/345/275/225//345/220/210/345/271/266/347/227/205/347/250/213/345/275/225/346/250/241/346/235/277.json +0 -86
  297. package/src/med_editor//347/227/205/347/250/213/345/275/225//346/227/245/345/270/270/347/227/205/347/250/213/350/256/260/345/275/225.json +0 -115
  298. package/src/med_editor//347/227/205/347/250/213/345/275/225//346/237/245/346/210/277/350/256/260/345/275/2251.json +0 -108
  299. package/src/med_editor//347/227/205/347/250/213/345/275/225//351/246/226/346/254/241/344/270/212/347/272/247/345/214/273/345/270/210/346/237/245/346/210/277/350/256/260/345/275/225.json +0 -272
  300. package/src/med_editor//351/225/277/346/234/237/345/214/273/345/230/261/345/215/225.json +0 -1070
@@ -1,150 +0,0 @@
1
- import { InlineGroupInputElement } from "./data-element-base-impl";
2
- import { InlineGroupRenderObject, RenderObject } from "../../render-define";
3
- import { RenderContenxtType } from "../../render-context";
4
- import { SerializeProps, ViewOptions, Element, ElementFactory, Position } from "../../element-define";
5
- import { DataElementGroupProps } from "../../element-props";
6
- import { ElementUtil } from "../../element-util";
7
- import { ContextMenuElementEvent } from "../../element-event-define";
8
- import { ElementSerialize } from "../../element-serialize";
9
- import { ParagraphRenderObject } from "../paragraph/p-impl";
10
- import { CommonUtil } from "../../common-util";
11
-
12
- export class DataElementGroupElement extends InlineGroupInputElement<DataElementGroupProps>{
13
- constructor() {
14
- super('data-group');
15
- this.props = new DataElementGroupProps();
16
- this.addEvent<ContextMenuElementEvent>('ElementContextMenu', (evt) => {
17
- if (evt.ctx.viewOptions.devMode) {
18
- evt.menus.push({
19
- icon: '获取数据组值', caption: '获取数据组值', eventObj: {
20
- onClick: () => {
21
- const str = ElementSerialize.serializeString(this, { all: false })
22
- alert(str)
23
- }
24
- }
25
- });
26
- }
27
- }, true);
28
- this.addEvent('ElementMousemove', (evt) => {
29
- this.isMouseenter = true;
30
- this.refreshView();
31
- });
32
- this.addEvent('ElementMouseLeave', (evt) => {
33
- this.isMouseenter = false;
34
- this.refreshView();
35
- });
36
- }
37
- clone(data: boolean): Element {
38
- const clone = new DataElementGroupElement();
39
- this.props.clone(clone.props);
40
- if (data) {
41
- const length = this.length;
42
- for (let i = 0; i < length; i++) {
43
- const child = this.getChild(i);
44
- if (child !== this.startDecorate && child !== this.endDecorate) {
45
- clone.addChild(child.clone(true));
46
- }
47
- }
48
- }
49
- return clone;
50
- }
51
-
52
- createRenderObject(options: ViewOptions, renderCtx: RenderContenxtType): RenderObject | null {
53
- return new DataElementGroupRenderObject(this);
54
- }
55
-
56
- serialize(viewOptions: ViewOptions): SerializeProps | null {
57
- return {
58
- type: this.type,
59
- props: {
60
- ...this.props.getSerializeProps()
61
- }
62
- }
63
- }
64
-
65
- }
66
-
67
-
68
- export class DataElementGroupRenderObject extends InlineGroupRenderObject<DataElementGroupElement> {
69
- paintPos!: Position;
70
- beginRender(ctx: RenderContenxtType, position: Position): void {
71
- //ctx.contentContext.fillRect(position.x, position.y, this.rect.width, this.rect.height, 'yellow');
72
- this.paintPos = position;
73
-
74
- }
75
-
76
- private getCurrentParaGroupRenders(): DataElementGroupRenderObject[] {
77
- const renders: DataElementGroupRenderObject[] = [];
78
- const currParaRender = ElementUtil.getParentRender(this, ParagraphRenderObject) as ParagraphRenderObject;
79
- for (let i = 0; i < this.element.paintRenders.length; i++) {
80
- const paraRender = ElementUtil.getParentRender(this.element.paintRenders[i], ParagraphRenderObject) as ParagraphRenderObject;
81
- if (paraRender === currParaRender) {
82
- renders.push(this.element.paintRenders[i] as DataElementGroupRenderObject);
83
- }
84
- }
85
- return renders;
86
- }
87
-
88
-
89
- pagePaintCompleted(ctx: RenderContenxtType, position: Position): void {
90
- const canPaint = this.element.isMouseenter || this.element.isFocused;
91
- if (canPaint && this.element.paintRenders.indexOf(this) === 0) {
92
- const currParaRenders = this.getCurrentParaGroupRenders();
93
- const verOffset = 3;
94
- if (currParaRenders.length > 1) {
95
- const secondGroupRenderPos = currParaRenders[1].paintPos;
96
- if (secondGroupRenderPos.x + currParaRenders[1].rect.width > this.paintPos.x) {
97
- const leftPoints: Array<Position> = [];
98
- const rightPoints: Array<Position> = [];
99
- for (let i = 0; i < currParaRenders.length; i++) {
100
- const groupRender = currParaRenders[i];
101
- const groupRenderPos = groupRender.paintPos;
102
-
103
- leftPoints.push({ x: groupRenderPos.x, y: groupRenderPos.y - verOffset });
104
- rightPoints.push({ x: groupRenderPos.x + groupRender.rect.width, y: groupRenderPos.y - verOffset });
105
- leftPoints.push({ x: groupRenderPos.x, y: groupRenderPos.y + groupRender.rect.height + verOffset * 2 });
106
- rightPoints.push({ x: groupRenderPos.x + groupRender.rect.width, y: groupRenderPos.y + groupRender.rect.height + verOffset * 2 });
107
- }
108
- const sharpPoints1 = CommonUtil.resharpPoints(rightPoints);
109
- const sharpPoints = CommonUtil.resharpPoints([...leftPoints.reverse()]);
110
- ctx.overlaysContext.strokeLines([...sharpPoints, ...sharpPoints1, sharpPoints[0]], 1, ctx.viewOptions.dataGroupColor);
111
- return;
112
- }
113
- }
114
- for (let i = 0; i < currParaRenders.length; i++) {
115
- const render = currParaRenders[i];
116
- ctx.overlaysContext.strokeRect(render.paintPos.x, render.paintPos.y - verOffset, render.rect.width, render.rect.height + verOffset * 2, ctx.viewOptions.dataGroupColor);
117
- }
118
- }
119
-
120
- }
121
-
122
-
123
-
124
- endRender(ctx: RenderContenxtType, position: Position): void {
125
-
126
- }
127
-
128
- clone(): RenderObject {
129
- const cloneRender = new DataElementGroupRenderObject(this.element);
130
- cloneRender.rect = ElementUtil.cloneRect(this.rect);
131
- for (let i = 0; i < this.length; i++) {
132
- cloneRender.addChild(this.getChild(i).clone());
133
- }
134
- return cloneRender;
135
- }
136
- }
137
-
138
- export class DataElementGroupFactory extends ElementFactory<DataElementGroupProps> {
139
- match(type: string): boolean {
140
- return type === "data-group"
141
- }
142
- createElement(data: any, renderCtx: RenderContenxtType): Element {
143
- const props = data.props as DataElementGroupProps;
144
- const ele = new DataElementGroupElement();
145
- ele.props.id = props.id;
146
- ele.props.name = props.name;
147
- return ele;
148
- }
149
-
150
- }
@@ -1,147 +0,0 @@
1
- import { Element, ElementFactory, ImgLoadStatus, LeafElement, Position, readElementProps, ResizeLeafRenderObject, SerializeProps, ViewOptions } from "../../element-define";
2
- import { DataEleImageProps } from "../../element-props";
3
- import { ElementUtil } from "../../element-util";
4
- import { RenderContenxtType } from "../../render-context";
5
- import { LeafRenderObject, RenderObject } from "../../render-define";
6
- import { DataElementLeaf } from "./data-element-base-impl";
7
-
8
- export class DataElementImage extends DataElementLeaf<DataEleImageProps> {
9
- //props: DataEleImageProps;
10
- status: ImgLoadStatus = 'no';
11
- resizeable: boolean = true;
12
- constructor() {
13
- super('data-ele-img');
14
- this.props = new DataEleImageProps();
15
- //this.addPropValueChangedSub(this.props);
16
- this.cursorType = 'move'
17
- this.focusable = true;
18
- }
19
- createRenderObject(): LeafRenderObject {
20
- const render = new DataImageRenderObject(this);
21
- render.rect.width = this.props.width + 2;
22
- render.rect.height = this.props.height + 2;
23
- return render;
24
- }
25
- serialize(options: ViewOptions): SerializeProps {
26
- return {
27
- type: 'data-ele-img',
28
- props: {
29
- ...this.props.getSerializeProps(options)
30
- }
31
- }
32
- }
33
- clone(data: boolean): Element {
34
- const clone = new DataElementImage();
35
- this.props.clone(clone.props);
36
- return clone;
37
- }
38
-
39
- loadImage(ctx: RenderContenxtType): void {
40
- if (this.status === 'no') {
41
- this.status = 'loading';
42
- const onCallback = (status: ImgLoadStatus) => {
43
- this.status = status;
44
- if (status === 'completed') {
45
- this.refreshView();
46
- }
47
- }
48
- ctx.docCtx.imageLoader.loadImage(this.props.src, onCallback);
49
- }
50
- }
51
- destroy(): void {
52
- super.destroy();
53
- }
54
-
55
- setValue(val: any): void {
56
- if (this.getValue() === val) {
57
- return;
58
- }
59
- this.props.src = val as string;
60
- }
61
-
62
- getValue(): string {
63
- return this.props.src;
64
- }
65
- }
66
-
67
- export class DataImageRenderObject extends ResizeLeafRenderObject {
68
- render(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
69
- const dataImgElement = this.element as DataElementImage;
70
- const picProps = dataImgElement.props;
71
- if (dataImgElement.status === 'no') {
72
- dataImgElement.loadImage(ctx);
73
- return;
74
- }
75
- if (dataImgElement.status === 'completed') {
76
- const imageSource = ctx.docCtx.imageLoader.getImage(picProps.src);
77
- if (!imageSource) {
78
- return;
79
- }
80
- if (picProps.border === 'all') {
81
- ctx.contentContext.strokeRect(position.x, position.y, this.rect.width, this.rect.height, 'black');
82
- }
83
- ctx.contentContext.drawImage(imageSource, 0, 0, imageSource.naturalWidth, imageSource.naturalHeight, position.x + 2, position.y + 2, picProps.width, picProps.height);
84
- }
85
- if (ctx.drawMode === 'view') {
86
- let { x, y } = position;
87
- const { width, height } = this.rect;
88
- const lineWidth = 5;
89
- const paintColor = '#0050b3';
90
- ctx.contentContext.strokeLines([{ x: x + lineWidth, y }, { x, y }, { x, y: y + height }, { x: x + lineWidth, y: y + height }], 1, paintColor);
91
- x = x + width;
92
- ctx.contentContext.strokeLines([{ x: x - lineWidth, y }, { x, y }, { x, y: y + height }, { x: x - lineWidth, y: y + height }], 1, paintColor);
93
- }
94
- }
95
- clone(): RenderObject {
96
- const clone = new DataImageRenderObject(this.element);
97
- clone.rect = ElementUtil.cloneRect(this.rect);
98
- return clone;
99
- }
100
-
101
- pagePaintCompleted(ctx: RenderContenxtType, pos: Position): void {
102
- if (this.element.isFocused) {
103
- const { width, height } = this.rect;
104
- ctx.contentContext.strokeRect(pos.x, pos.y, this.rect.width, this.rect.height, '#1890ff', 0.5);
105
- this.drawResizeCircle(ctx, pos.x, pos.y);
106
- this.drawResizeCircle(ctx, pos.x + width, pos.y);
107
- this.drawResizeCircle(ctx, pos.x, pos.y + height);
108
- this.drawResizeCircle(ctx, pos.x + width, pos.y + height);
109
- this.drawResizeCircle(ctx, pos.x + (Math.floor(width / 2)), pos.y);
110
- this.drawResizeCircle(ctx, pos.x + (Math.floor(width / 2)), pos.y + height);
111
- this.drawResizeCircle(ctx, pos.x, pos.y + (Math.floor(height / 2)));
112
- this.drawResizeCircle(ctx, pos.x + width, pos.y + (Math.floor(height / 2)));
113
- }
114
- }
115
-
116
- private drawResizeCircle(ctx: RenderContenxtType, x: number, y: number): void {
117
- const ctxNative = ctx.contentContext.ctx;
118
- ctxNative.save();
119
- ctxNative.fillStyle = '#69c0ff';
120
- ctxNative.beginPath();
121
- ctxNative.arc(x, y, Math.floor(4 / 5 * 4), 0, 2 * Math.PI);
122
- ctxNative.closePath();
123
- ctxNative.fill();
124
- ctxNative.restore();
125
- }
126
- }
127
-
128
-
129
- export class DataElementImgFactory extends ElementFactory<DataEleImageProps> {
130
- match(type: string): boolean {
131
- return type === 'data-ele-img';
132
- }
133
- createElement(data: readElementProps<DataEleImageProps>, renderCtx: RenderContenxtType): Element {
134
- const props = data.props as DataEleImageProps;
135
- const pic = new DataElementImage();
136
- ElementUtil.readEleBaseProps(pic.props, props);
137
- //pic.props.id = props.id ?? nanoid(5);
138
- //pic.props.name = props.name;
139
- //pic.props.caption = props.caption;
140
- //pic.props.type = props.type;
141
- pic.props.width = props.width;
142
- pic.props.height = props.height;
143
- pic.props.src = props.src;
144
- pic.props.border = props.border || 'all';
145
- return pic;
146
- }
147
- }
@@ -1,142 +0,0 @@
1
- import { Element, ElementFactory, readElementProps, SerializeProps, ViewOptions } from "../../element-define";
2
- import { DataEleListProps, DataEleBaseTextProps } from "../../element-props";
3
- import { ElementUtil } from "../../element-util";
4
- import { RenderContenxtType } from "../../render-context";
5
- import { RenderObject } from "../../render-define";
6
- import { ElementSerialize } from "../../element-serialize";
7
- import { TextGroupElement } from "../text/text-impl";
8
- import { DataElementInlineGroup, DataElementRenderObject } from "./data-element-base-impl";
9
-
10
- export class DataElementList extends DataElementInlineGroup<DataEleListProps> {
11
- //props: DataEleListProps;
12
- constructor() {
13
- super('data-ele-list');
14
- this.props = new DataEleListProps();
15
- }
16
-
17
- createRenderObject(): RenderObject {
18
- return new DataElementListRenderObject(this);
19
- }
20
-
21
- serialize(viewOptions: ViewOptions): SerializeProps & any {
22
- return {
23
- type: this.type,
24
- props: {
25
- ...this.props.getSerializeProps(viewOptions)
26
- }
27
- }
28
- }
29
-
30
- clone(data: boolean): DataElementList {
31
- const clone = new DataElementList();
32
- this.props.clone(clone.props);
33
- if (data) {
34
- const length = this.length;
35
- for (let i = 0; i < length; i++) {
36
- const child = this.getChild(i);
37
- if (child !== this.startDecorate && child !== this.endDecorate) {
38
- clone.addChild(child.clone(true));
39
- }
40
- }
41
- }
42
- return clone;
43
- }
44
-
45
- setValue(vals: string[]): void {
46
- if (this.getValue() === vals.join(';')) {
47
- return;
48
- }
49
- this.pubOnChange('self');
50
- this.clearInnerItems();
51
- if (this.props.multiSelect) {
52
- for (let i = 0; i < vals.length; i++) {
53
- const val = vals[i];
54
- const option = this.props.options.find(item => item.code === val);
55
- if (option) {
56
- const valueText = new TextGroupElement();
57
- this.props.valueTextProps.clone(valueText.props);
58
- const splitSymbol = i < vals.length - 1 ? ';' : ''
59
- valueText.text = option.value + splitSymbol;
60
- this.addChild(valueText, this.length - 1);
61
- }
62
- }
63
- } else {
64
- if (vals.length > 1) {
65
- console.warn('当前下拉框是单选模式,不能传入多个值')
66
- }
67
- const val = vals[0];
68
- const option = this.props.options.find(item => item.code === val);
69
- if (option) {
70
- const valueText = new TextGroupElement();
71
- this.props.valueTextProps.clone(valueText.props);
72
- valueText.text = option.value;
73
- this.addChild(valueText, this.length - 1);
74
- }
75
- }
76
- this.beginMeasure();
77
- }
78
-
79
- getValue(): string {
80
- const values = ElementSerialize.serializeString(this);
81
- if (!values) {
82
- return '';
83
- }
84
- const valueItems = values.split(';');
85
- const valueCode: Array<string> = [];
86
- for (const valueItem of valueItems) {
87
- const option = this.props.options.find(item => item.value === valueItem);
88
- if (option) {
89
- valueCode.push(option.code)
90
- } else {
91
- valueCode.push(option + '')
92
- }
93
- }
94
- return valueCode.join(';')
95
- }
96
- }
97
-
98
-
99
- export class DataElementListRenderObject extends DataElementRenderObject<DataElementList> {
100
- constructor(element: DataElementList) {
101
- super(element);
102
- }
103
- clone(): RenderObject {
104
- const cloneRender = new DataElementListRenderObject(this.element);
105
- cloneRender.rect = ElementUtil.cloneRect(this.rect);
106
- for (let i = 0; i < this.length; i++) {
107
- cloneRender.addChild(this.getChild(i).clone());
108
- }
109
- return cloneRender;
110
- }
111
-
112
- }
113
-
114
- export class DataElementListFactory extends ElementFactory<DataEleListProps> {
115
- match(type: string): boolean {
116
- return type === "data-ele-list"
117
- }
118
- createElement(data: readElementProps<DataEleListProps>, renderCtx: RenderContenxtType): Element {
119
- const props = data.props as DataEleListProps;
120
- const ele = new DataElementList();
121
- this.createDataEleProps(ele.props, props);
122
- return ele;
123
- }
124
-
125
- createDataEleProps(dest: DataEleListProps, props: DataEleListProps): DataEleBaseTextProps {
126
- const dataEleProps: DataEleListProps = dest;
127
- ElementUtil.readEleBaseProps(dataEleProps, props);
128
- //dataEleProps.id = props.id ?? nanoid(5);
129
- //dataEleProps.name = props.name;
130
- //dataEleProps.caption = props.caption;
131
- //dataEleProps.type = props.type;
132
- dataEleProps.nullText = props.nullText;
133
- dataEleProps.nullTextProps = ElementUtil.readTextProps(null, props.nullTextProps, this.options);
134
- dataEleProps.valueTextProps = ElementUtil.readTextProps(null, props.valueTextProps, this.options);
135
- const options = props.options || [];
136
- dataEleProps.multiSelect = props.multiSelect;
137
- dataEleProps.options = [...options];
138
- dataEleProps.dropDownStyle = props.dropDownStyle;
139
- return dataEleProps;
140
- }
141
-
142
- }
@@ -1,117 +0,0 @@
1
- import { Element, ElementFactory, SerializeProps, ViewOptions } from "../../element-define";
2
- import { DataEleBaseTextProps } from "../../element-props";
3
- import { ElementUtil } from "../../element-util";
4
- import { RenderContenxtType } from "../../render-context";
5
- import { RenderObject } from "../../render-define";
6
- import { ElementSerialize } from "../../element-serialize";
7
- import { TextGroupElement } from "../text/text-impl";
8
- import { DataElementInlineGroup, DataElementRenderObject } from "./data-element-base-impl";
9
-
10
- export class DataElementText extends DataElementInlineGroup<DataEleBaseTextProps> {
11
- //props: DataEleBaseTextProps;
12
- constructor() {
13
- super('data-ele-text');
14
- this.props = new DataEleBaseTextProps();
15
- }
16
-
17
- createRenderObject(): RenderObject {
18
- return new DataElementTextRenderObject(this);
19
- }
20
-
21
- serialize(viewOptions: ViewOptions): SerializeProps & any {
22
- return {
23
- type: this.type,
24
- props: {
25
- ...this.props.getSerializeProps(viewOptions)
26
- }
27
- }
28
- }
29
-
30
- clone(data: boolean): DataElementText {
31
- const clone = new DataElementText();
32
- this.props.clone(clone.props);
33
- if (data) {
34
- const length = this.length;
35
- for (let i = 0; i < length; i++) {
36
- const child = this.getChild(i);
37
- if (child !== this.startDecorate && child !== this.endDecorate) {
38
- clone.addChild(child.clone(true));
39
- }
40
- }
41
- }
42
- return clone;
43
- }
44
-
45
- setValue(val: string): void {
46
- if (!this.startDecorate) {
47
- return;
48
- }
49
- if (this.getValue() === val) {
50
- return;
51
- }
52
- this.pubOnChange('self');
53
- this.clearInnerItems();
54
- if (val) {
55
- const valueText = new TextGroupElement();
56
- this.props.valueTextProps.clone(valueText.props);
57
- valueText.text = val;
58
- this.addChild(valueText, this.length - 1);
59
- }
60
- this.beginMeasure();
61
- }
62
-
63
- getValue(): string {
64
- return ElementSerialize.serializeString(this, { all: false });
65
- }
66
-
67
- validate(): string {
68
- let error = super.validate();
69
- if (error) {
70
- return error;
71
- }
72
- return '';
73
-
74
- }
75
- }
76
-
77
- export class DataElementTextRenderObject extends DataElementRenderObject<DataElementText> {
78
- constructor(element: DataElementText) {
79
- super(element);
80
- }
81
- clone(): RenderObject {
82
- const cloneRender = new DataElementTextRenderObject(this.element);
83
- cloneRender.rect = ElementUtil.cloneRect(this.rect);
84
- for (let i = 0; i < this.length; i++) {
85
- cloneRender.addChild(this.getChild(i).clone());
86
- }
87
- return cloneRender;
88
- }
89
-
90
- }
91
-
92
- export class DataElementTextFactory extends ElementFactory<DataEleBaseTextProps> {
93
- match(type: string): boolean {
94
- return type === "data-ele-text"
95
- }
96
- createElement(data: any, renderCtx: RenderContenxtType): Element {
97
- const props = data.props as DataEleBaseTextProps;
98
- const ele = new DataElementText();
99
- this.createDataEleProps(ele.props, props);
100
- return ele;
101
- }
102
-
103
- createDataEleProps(dest: DataEleBaseTextProps, props: DataEleBaseTextProps): DataEleBaseTextProps {
104
- const dataEleProps: DataEleBaseTextProps = dest;
105
- ElementUtil.readEleBaseProps(dataEleProps, props);
106
- //dataEleProps.id = props.id ?? nanoid(5);
107
- //dataEleProps.name = props.name;
108
- //dataEleProps.caption = props.caption;
109
- //dataEleProps.type = props.type;
110
- dataEleProps.nullText = props.nullText;
111
- dataEleProps.nullTextProps = ElementUtil.readTextProps(null, props.nullTextProps, this.options);
112
- dataEleProps.valueTextProps = ElementUtil.readTextProps(null, props.valueTextProps, this.options);
113
- dataEleProps.dataType = props.dataType;
114
- return dataEleProps;
115
- }
116
-
117
- }
@@ -1,48 +0,0 @@
1
- import { Element, LeafElement, SerializeProps, ViewOptions } from "../../element-define";
2
- import { ElementUtil } from "../../element-util";
3
- import { RenderContenxtType } from "../../render-context";
4
- import { LeafRenderObject, RenderObject } from "../../render-define";
5
-
6
- /**
7
- * 当前数据元内容长度小于最小长度时,需要当前元素撑开以达到最小长度
8
- */
9
- export class FillNullSpaceElement extends LeafElement {
10
- //需要填充的长度
11
- length!: number;
12
- constructor() {
13
- super('fill-null');
14
- this.isDecorate = true;
15
- this.disableClick = true;
16
- }
17
- createRenderObject(options: ViewOptions, renderCtx: RenderContenxtType): RenderObject {
18
- return new FillNullSpaceRenderObject();
19
- }
20
- serialize(viewOptions: ViewOptions): SerializeProps {
21
- throw new Error("Method not implemented.");
22
- }
23
- clone(data: boolean): Element {
24
- //throw new Error("Method not implemented.");
25
- return new FillNullSpaceElement();
26
- }
27
-
28
- }
29
-
30
-
31
- export class FillNullSpaceRenderObject extends LeafRenderObject {
32
- constructor() {
33
- super(null);
34
- this.disableClick = true;
35
- }
36
- render(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
37
- //throw new Error("Method not implemented.");
38
- if (ctx.viewOptions.showDebug) {
39
- ctx.contentContext.fillRect(position.x, position.y, this.rect.width, this.rect.height, 'red');
40
- }
41
- }
42
- clone(): RenderObject {
43
- const clone = new FillNullSpaceRenderObject();
44
- clone.rect = ElementUtil.cloneRect(this.rect);
45
- return clone;
46
- }
47
-
48
- }