@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,95 +0,0 @@
1
- import { BlockContainerElement, Element, ElementFactory, Rect, SerializeProps } from "../../element-define";
2
- import { MouseElementEvent } from "../../element-event-define";
3
- import { ElementUtil } from "../../element-util";
4
- import { RenderContenxtType } from "../../render-context";
5
- import { MuiltBlockLineRenderObject, RenderObject } from "../../render-define";
6
- import { DocumentElement } from "./doc-impl";
7
-
8
-
9
- export class DocumentBodyElement extends BlockContainerElement {
10
- //当前区域内是否留痕
11
- trackChanges: boolean = false;
12
- constructor() {
13
- super('body');
14
- //this.editMode = EditMode.Free;
15
- this.addEvent('ElementDblClick', (evt) => {
16
- if (this.disableClick) {
17
- this.switchEditMode(evt);
18
- }
19
- }, true);
20
- }
21
- createRenderObject(): DocumentBodyRenderObject {
22
- return new DocumentBodyRenderObject(this);
23
- }
24
-
25
- serialize(): SerializeProps {
26
- return {
27
- type: 'body',
28
- props: {}
29
- }
30
- }
31
-
32
- switchEditMode(evt: MouseElementEvent): void {
33
- const docElement = ElementUtil.getParentByType(this, DocumentElement);
34
- if (docElement) {
35
- docElement.switchPageHeaderEditor(evt.selectionState, this);
36
- }
37
- return;
38
- }
39
-
40
- clone(data: boolean): DocumentBodyElement {
41
- const clone = new DocumentBodyElement();
42
- if (data) {
43
- for (let i = 0; i < this.length; i++) {
44
- clone.addChild(this.getChild(i).clone(true));
45
- }
46
- }
47
- return clone;
48
- }
49
-
50
-
51
- }
52
-
53
-
54
- export class DocumentBodyRenderObject extends MuiltBlockLineRenderObject {
55
- beginRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
56
- //console.log('绘制页内容-begin');
57
- if (this.element.disableClick && ctx.drawMode === 'view') {
58
- ctx.contentContext.setGlobalAlpha(0.5);
59
- }
60
- if (ctx.viewOptions.showDebug) {
61
- ctx.overlaysContext.fillRect(position.x, position.y, this.rect.width, this.rect.height, 'rgb(177,177,177,0.4)');
62
- }
63
- }
64
- endRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
65
- //console.log('绘制页内容-end');
66
- if (this.element.disableClick && ctx.drawMode === 'view') {
67
- ctx.contentContext.setGlobalAlpha(1);
68
- }
69
- }
70
-
71
- clone(cloneData = true): RenderObject {
72
- const cloneRender = new DocumentBodyRenderObject(this.element);
73
- cloneRender.rect = ElementUtil.cloneRect(this.rect);
74
- if (cloneData) {
75
- for (let i = 0; i < this.length; i++) {
76
- cloneRender.addChild(this.getChild(i).clone());
77
- }
78
- }
79
- return cloneRender;
80
- }
81
-
82
- }
83
-
84
-
85
- export class DocumentBodyFactory extends ElementFactory<null> {
86
- match(type: string): boolean {
87
- return type === 'body';
88
- }
89
- createElement(data: any, renderCtx: RenderContenxtType): Element {
90
- const element = new DocumentBodyElement();
91
- return element;
92
- }
93
-
94
- }
95
-
@@ -1,104 +0,0 @@
1
- import { BlockContainerElement, SerializeProps, Element, readElementProps, ElementFactory } from "../../element-define";
2
- import { ElementUtil } from "../../element-util";
3
- import { RenderContenxtType } from "../../render-context";
4
- import { MuiltBlockLineRenderObject, RenderObject } from "../../render-define";
5
- import { BodyPartProps } from "../../element-props";
6
-
7
- /**
8
- * 用于合并病程录,每个part包含每份病程录body
9
- * 多个part处于一个body下面
10
- */
11
- export class DocumentBodyPartElement extends BlockContainerElement<BodyPartProps> {
12
- //是否被修改
13
- isModify!: boolean;
14
- constructor() {
15
- super('body-part');
16
- this.addEvent('ElementMousemove', (evt) => {
17
- this.isMouseenter = true;
18
- this.refreshView();
19
- });
20
- this.addEvent('ElementMouseLeave', (evt) => {
21
- this.isMouseenter = false;
22
- this.refreshView();
23
- });
24
- this.addEvent('GotCursor', (evt) => {
25
- this.isFocused = true;
26
- this.refreshView();
27
- });
28
- this.addEvent('LostCursor', (evt) => {
29
- this.isFocused = false;
30
- this.refreshView();
31
- });
32
- this.props = new BodyPartProps();
33
- }
34
- createRenderObject(): DocumentBodyPartRenderObject {
35
- const render = new DocumentBodyPartRenderObject(this);
36
- render.margin.top = 10;
37
- render.margin.bottom = 10;
38
- return render;
39
- }
40
-
41
- serialize(): SerializeProps {
42
- return {
43
- type: this.type,
44
- props: {
45
- partId: this.props.partId,
46
- }
47
- }
48
- }
49
-
50
- clone(data: boolean): DocumentBodyPartElement {
51
- const clone = new DocumentBodyPartElement();
52
- clone.props.partId = this.props.partId;
53
- if (data) {
54
- for (let i = 0; i < this.length; i++) {
55
- clone.addChild(this.getChild(i).clone(true));
56
- }
57
- }
58
- return clone;
59
- }
60
- }
61
-
62
-
63
- export class DocumentBodyPartRenderObject extends MuiltBlockLineRenderObject {
64
- beginRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
65
- //if (ctx.drawMode === 'view' && (this.element.isFocused || this.element.isMouseenter)) {
66
- const borderColor = '#002766';
67
- ctx.overlaysContext.ctx.save();
68
- const bgColor = (this.element.isFocused || this.element.isMouseenter) ? '#d9d9d9' : '#ffffff';
69
- ctx.overlaysContext.fillRect(position.x - 2, position.y - 2, this.rect.width + 4, this.rect.height + 4, bgColor, 5, 'black');
70
- //ctx.overlaysContext.strokeRect(position.x, position.y, this.rect.width, this.rect.height, borderColor)
71
- ctx.overlaysContext.ctx.restore();
72
- //}
73
- }
74
- endRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
75
-
76
- }
77
-
78
- clone(cloneData = true): RenderObject {
79
- const cloneRender = new DocumentBodyPartRenderObject(this.element);
80
- cloneRender.rect = ElementUtil.cloneRect(this.rect);
81
- cloneRender.margin.top = this.margin.top;
82
- cloneRender.margin.bottom = this.margin.bottom;
83
- if (cloneData) {
84
- for (let i = 0; i < this.length; i++) {
85
- cloneRender.addChild(this.getChild(i).clone());
86
- }
87
- }
88
- return cloneRender;
89
- }
90
-
91
- }
92
-
93
- export class DocumentBodyPartFactory extends ElementFactory<BodyPartProps>{
94
- match(type: string): boolean {
95
- return type === 'body-part';
96
- }
97
- createElement(data: readElementProps<BodyPartProps>, renderCtx: RenderContenxtType): Element<any> {
98
- const bodyPart = data.props?.partId || '';
99
- const element = new DocumentBodyPartElement();
100
- element.props.partId = bodyPart;
101
- return element;
102
- }
103
-
104
- }
@@ -1,24 +0,0 @@
1
- import { RenderContenxtType } from "../../render-context";
2
- import { BlockContainerRenderObject, RenderObject } from "../../render-define";
3
- import { DocumentRenderObject } from "./doc-impl";
4
-
5
- export class DocumentContainerRender extends BlockContainerRenderObject {
6
- constructor() {
7
- super(null);
8
- }
9
- beginRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
10
- //throw new Error("Method not implemented.");
11
- }
12
- endRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
13
- //throw new Error("Method not implemented.");
14
- }
15
- clone(): RenderObject {
16
- throw new Error("Method not implemented.");
17
- }
18
-
19
- addPages(pages: Array<DocumentRenderObject>): void {
20
- for (let i = 0; i < pages.length; i++) {
21
- this.addChild(pages[i]);
22
- }
23
- }
24
- }
@@ -1,88 +0,0 @@
1
- import { BlockContainerElement, Element, ElementFactory, Rect, SerializeProps } from "../../element-define";
2
- import { MouseElementEvent } from "../../element-event-define";
3
- import { ElementUtil } from "../../element-util";
4
- import { RenderContenxtType } from "../../render-context";
5
- import { BlockContainerRenderObject, RenderObject } from "../../render-define";
6
- import { DocumentElement } from "./doc-impl";
7
-
8
- export class DocumentFooterElement extends BlockContainerElement {
9
- constructor() {
10
- super('footer');
11
- //this.editMode = EditMode.Disabled;
12
- this.disableClick = true;
13
- this.addEvent('ElementDblClick', (evt) => {
14
- this.switchEditMode(evt);
15
- }, true);
16
- }
17
- clone(data: boolean): Element {
18
- const clone = new DocumentFooterElement();
19
- if (data) {
20
- for (let i = 0; i < this.length; i++) {
21
- clone.addChild(this.getChild(i).clone(true));
22
- }
23
- }
24
- return clone;
25
- }
26
-
27
- switchEditMode(evt: MouseElementEvent): void {
28
- const docElement = this.parent as DocumentElement;
29
- docElement.switchPageHeaderEditor(evt.selectionState, this);
30
- return;
31
- }
32
-
33
- createRenderObject(): DocumentFooterRenderObject {
34
- const renderObject = new DocumentFooterRenderObject(this);
35
- return renderObject;
36
- }
37
-
38
- serialize(): SerializeProps {
39
- return {
40
- type: 'footer',
41
- props: {}
42
- }
43
- }
44
- }
45
-
46
- export class DocumentFooterRenderObject extends BlockContainerRenderObject {
47
- beginRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
48
- //判断页眉是否为输入内容
49
- const isFooterEmpty = ElementUtil.checkEmptyContent(this);
50
- if (this.element.disableClick && ctx.drawMode === 'view') {
51
- if (isFooterEmpty) {
52
- ctx.contentContext.setGlobalAlpha(0);
53
- return;
54
- } else {
55
- ctx.contentContext.setGlobalAlpha(0.5);
56
- }
57
- }
58
- }
59
-
60
- endRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
61
- ctx.contentContext.setGlobalAlpha(1);
62
- if (ctx.viewOptions.showDebug) {
63
- ctx.overlaysContext.fillRect(position.x, position.y, this.rect.width, this.rect.height, 'rgb(122,122,122,0.4)')
64
- }
65
- }
66
-
67
- clone(): RenderObject {
68
- const cloneRender = new DocumentFooterRenderObject(this.element);
69
- cloneRender.rect = ElementUtil.cloneRect(this.rect);
70
- for (let i = 0; i < this.length; i++) {
71
- cloneRender.addChild(this.getChild(i).clone());
72
- }
73
- return cloneRender;
74
- }
75
- }
76
-
77
-
78
- export class DocumentFooterFactory extends ElementFactory<null> {
79
- match(type: string): boolean {
80
- return type === 'footer';
81
- }
82
-
83
- createElement(data: any, renderCtx: RenderContenxtType): Element {
84
- const element = new DocumentFooterElement();
85
- //element.renderCtx = renderCtx;
86
- return element;
87
- }
88
- }
@@ -1,100 +0,0 @@
1
- import { BlockContainerElement, Element, ElementFactory, SerializeProps } from "../../element-define";
2
- import { MouseElementEvent } from "../../element-event-define";
3
- import { ElementUtil } from "../../element-util";
4
- import { RenderContenxtType } from "../../render-context";
5
- import { BlockContainerRenderObject, RenderObject } from "../../render-define";
6
- import { DocumentElement } from "./doc-impl";
7
-
8
- export class DocumentHeaderElement extends BlockContainerElement {
9
- constructor() {
10
- super('header');
11
- this.addEvent('ElementDblClick', (evt) => {
12
- this.switchEditMode(evt);
13
- }, true);
14
- //this.editMode = EditMode.Disabled;
15
- this.disableClick = true;
16
- }
17
-
18
- clone(data: boolean): Element {
19
- const clone = new DocumentHeaderElement();
20
- if (data) {
21
- for (let i = 0; i < this.length; i++) {
22
- clone.addChild(this.getChild(i).clone(true));
23
- }
24
- }
25
- return clone;
26
- }
27
-
28
- switchEditMode(evt: MouseElementEvent): void {
29
- const docElement = this.parent as DocumentElement;
30
- docElement.switchPageHeaderEditor(evt.selectionState, this);
31
- return;
32
- }
33
-
34
-
35
- createRenderObject(): DocumentHeaderRenderObject {
36
- const renderObject = new DocumentHeaderRenderObject(this);
37
- return renderObject;
38
- }
39
-
40
- serialize(): SerializeProps {
41
- return {
42
- type: 'header',
43
- props: {}
44
- }
45
- }
46
-
47
- }
48
-
49
-
50
- export class DocumentHeaderRenderObject extends BlockContainerRenderObject {
51
- beginRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
52
- //判断页眉是否为输入内容
53
- const isHeaderEmpty = ElementUtil.checkEmptyContent(this);
54
- //存在输入内容时,绘制页眉-页体分割线
55
- if (!isHeaderEmpty || !this.element.disableClick) {
56
- const headerLineY = this.rect.height;
57
- ctx.contentContext.drawLine(position.x, position.y + headerLineY, this.rect.width, 'black', 0.5);
58
- }
59
- if (this.element.disableClick && ctx.drawMode === 'view') {
60
- if (isHeaderEmpty) {
61
- ctx.contentContext.setGlobalAlpha(0);
62
- return;
63
- }
64
- ctx.contentContext.setGlobalAlpha(0.7);
65
- }
66
- }
67
-
68
-
69
- endRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
70
- //console.log('绘制页头-end');
71
- if (this.element.disableClick && ctx.drawMode === 'view') {
72
- ctx.contentContext.setGlobalAlpha(1);
73
- }
74
- if (ctx.viewOptions.showDebug) {
75
- ctx.overlaysContext.fillRect(position.x, position.y, this.rect.width, this.rect.height, 'rgb(122,122,122,0.4)')
76
- }
77
- }
78
-
79
- clone(): RenderObject {
80
- const cloneRender = new DocumentHeaderRenderObject(this.element);
81
- cloneRender.rect = ElementUtil.cloneRect(this.rect);
82
- for (let i = 0; i < this.length; i++) {
83
- cloneRender.addChild(this.getChild(i).clone());
84
- }
85
- return cloneRender;
86
- }
87
- }
88
-
89
-
90
- export class DocumentHeaderFactory extends ElementFactory<null> {
91
- match(type: string): boolean {
92
- return type === 'header';
93
- }
94
-
95
- createElement(data: any, renderCtx: RenderContenxtType): Element {
96
- const element = new DocumentHeaderElement();
97
- //element.renderCtx = renderCtx;
98
- return element;
99
- }
100
- }
@@ -1,226 +0,0 @@
1
- import { BlockContainerElement, DocMode, Element, ElementFactory, MarginProps, PaddingProps, readElementProps, Rect, SerializeProps, ViewOptions } from "../../element-define";
2
- import { DocumentProps, TextProps } from '../../element-props';
3
- import { RenderContenxtType } from "../../render-context";
4
- import { DocumentBodyElement } from "./doc-body-impl";
5
- import { DocumentHeaderElement } from "./doc-header-impl";
6
- import { BlockContainerRenderObject, RenderObject } from "../../render-define";
7
- import { ElementUtil } from "../../element-util";
8
- import { DocumentFooterElement } from "./doc-footer-impl";
9
- import { ContextMenuElementEvent } from "../../element-event-define";
10
- import { documentPrint } from "../../document-print";
11
- import { CommsContainerElement } from "../comments/comments-container-impl";
12
- import { CommonUtil } from "../../common-util";
13
- import { SelectionState } from "../../document-selection";
14
-
15
- export class DocumentElement extends BlockContainerElement<DocumentProps> {
16
- //props: DocumentProps;
17
- viewOptions!: ViewOptions;
18
- bodyElement!: DocumentBodyElement;
19
- headerElement!: DocumentHeaderElement;
20
- footerElement!: DocumentFooterElement;
21
- commentsContainerElement!: CommsContainerElement;
22
- headerEditState: boolean = false;
23
- constructor() {
24
- super('doc');
25
- this.props = new DocumentProps();
26
- this.addEvent<ContextMenuElementEvent>('ElementContextMenu', (cevt) => {
27
- cevt.menus.push({ icon: 'Print', caption: '打印所有页', eventObj: { onClick: (evt) => { documentPrint.print(cevt.selectionState, this.viewOptions, cevt.ctx) } } });
28
- cevt.menus.push({ icon: 'Print', caption: '打印当前页', eventObj: { onClick: (evt) => { documentPrint.printCurrPage(cevt.selectionState, this.viewOptions, cevt.ctx) } } });
29
- }, true);
30
- }
31
- createRenderObject(options: ViewOptions): DocumentRenderObject {
32
- const { width: docPixelsWidth, height: docPixelsHeight } = this.viewOptions.docPageSettings;
33
- const docRenderObject = new DocumentRenderObject(this);
34
- docRenderObject.rect.width = docPixelsWidth;
35
- docRenderObject.rect.maxWidth = docPixelsWidth;
36
- docRenderObject.rect.maxHeight = docPixelsHeight;
37
- docRenderObject.rect.height = docPixelsHeight;
38
- docRenderObject.element = this;
39
- const { top, bottom, left, right } = this.props.padding;
40
- let { headerLine: headLine, footerLine: footLine } = this.props;
41
- const { mmToPixelsRatio } = this.viewOptions;
42
- headLine = headLine * mmToPixelsRatio;
43
- footLine = footLine * mmToPixelsRatio;
44
- docRenderObject.padding.top = Math.floor(top * mmToPixelsRatio);
45
- docRenderObject.padding.bottom = Math.floor(bottom * mmToPixelsRatio);
46
- docRenderObject.padding.left = Math.floor(left * mmToPixelsRatio);
47
- docRenderObject.padding.right = Math.floor(right * mmToPixelsRatio);
48
- docRenderObject.headerLine = headLine;
49
- docRenderObject.footerLine = footLine;
50
- docRenderObject.margin.top = options.docSpace;
51
- return docRenderObject;
52
- }
53
-
54
- serialize(): SerializeProps {
55
- return {
56
- type: 'doc',
57
- props: {
58
- ...this.props.getSerializeProps()
59
- }
60
- }
61
- }
62
-
63
- clone(): DocumentElement {
64
- const clone = new DocumentElement();
65
- this.props.clone(clone.props)
66
- for (let i = 0; i < this.length; i++) {
67
- clone.addChild(this.getChild(i).clone(true));
68
- }
69
- return clone;
70
- }
71
-
72
- /**
73
- * 更新页边距
74
- * @param marginProps
75
- */
76
- updateMargin(marginProps: Partial<MarginProps>, unit: 'mm' | 'cm' = 'cm'): void {
77
- const { top, bottom, left, right } = marginProps as MarginProps;
78
- const paddig = this.props.padding;
79
- const ratio = unit === 'cm' ? 10 : 1;
80
- paddig.top = top * ratio;
81
- paddig.bottom = bottom * ratio;
82
- paddig.left = left * ratio;
83
- paddig.right = right * ratio;
84
- }
85
-
86
- /**
87
- * 切换开启页眉页脚编辑功能
88
- */
89
- switchPageHeaderEditor(ss: SelectionState, ele: Element | null): void {
90
- if (this.viewOptions.docMode !== DocMode.Design) {
91
- return;
92
- }
93
- if (!this.headerEditState && (!ele || (ele === this.headerElement || ele === this.footerElement))) {
94
- this.headerElement.disableClick = false;
95
- this.footerElement.disableClick = false;
96
- this.bodyElement.disableClick = true;
97
- this.headerEditState = true;
98
- } else if (this.headerEditState && (!ele || ele === this.bodyElement)) {
99
- this.headerElement.disableClick = true;
100
- this.footerElement.disableClick = true;
101
- this.bodyElement.disableClick = false;
102
- this.headerEditState = false;
103
- }
104
- ss.clear();
105
- this.refreshView();
106
- }
107
- }
108
-
109
-
110
- export class DocumentRenderObject extends BlockContainerRenderObject {
111
- constructor(ele: Element) {
112
- super(ele);
113
- }
114
- headerLine!: number;
115
- footerLine!: number;
116
- beginRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
117
- const { width: docWidth, height: docHeight } = ctx.viewOptions.docPageSettings;
118
- ctx.overlaysContext.fillRect(position.x, position.y, docWidth, this.rect.height, 'white', 5, 'black');
119
- // if (ctx.drawMode === 'view') {
120
- // ctx.contentContext.strokeRect(position.x, position.y, docWidth, this.rect.height, 'black', 0.5);
121
- // }
122
- }
123
- endRender(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
124
- const textP = new TextProps();
125
- textP.color = "rgb(0,0,0)";
126
- textP.fontName = '楷体';
127
- textP.fontSize = 12;
128
- if (ctx.viewOptions.copyRightInfo) {
129
- ctx.contentContext.drawText(ctx.viewOptions.copyRightInfo, textP, position.x + 5, position.y + 5, 100, 12);
130
- }
131
- this.drawDocPageNum(ctx, position);
132
- const padding = this.padding;
133
- let paddingPos = { x: padding.left + position.x, y: padding.top + position.y };
134
- const drawLineWidth = 0.5;
135
- const lineWidth = 20;
136
- const { width: docWidth } = ctx.viewOptions.docPageSettings;
137
- const docHeight = this.rect.height;
138
- ctx.overlaysContext.strokeLines([{ x: paddingPos.x - lineWidth, y: paddingPos.y }, paddingPos, { x: paddingPos.x, y: paddingPos.y - lineWidth }], drawLineWidth);
139
- paddingPos = { x: docWidth - padding.right + position.x, y: padding.top + position.y };
140
- ctx.overlaysContext.strokeLines([{ x: paddingPos.x + lineWidth, y: paddingPos.y }, paddingPos, { x: paddingPos.x, y: paddingPos.y - lineWidth }], drawLineWidth);
141
- paddingPos = { x: padding.left + position.x, y: docHeight - this.padding.bottom + position.y };
142
- ctx.overlaysContext.strokeLines([{ x: paddingPos.x - lineWidth, y: paddingPos.y }, paddingPos, { x: paddingPos.x, y: paddingPos.y + lineWidth }], drawLineWidth);
143
- paddingPos = { x: docWidth - padding.left + position.x, y: docHeight - this.padding.bottom + position.y };
144
- ctx.overlaysContext.strokeLines([{ x: paddingPos.x + lineWidth, y: paddingPos.y }, paddingPos, { x: paddingPos.x, y: paddingPos.y + lineWidth }], drawLineWidth);
145
- this.drawWatermark(ctx, position);
146
- }
147
-
148
- /**
149
- * 绘制水印
150
- * @param ctx
151
- * @param position
152
- */
153
- private drawWatermark(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
154
- if (ctx.viewOptions.watermark) {
155
- const watermark = ctx.viewOptions.watermark;
156
- ctx.contentContext.ctx.save();
157
- ctx.contentContext.ctx.translate(position.x, position.y);
158
- const { width, height } = this.rect;
159
- const degrees = Math.atan(height / width) * 180 / Math.PI
160
- ctx.contentContext.ctx.rotate(degrees * Math.PI / 180);
161
- ctx.contentContext.ctx.globalAlpha = 0.3;
162
- const d = Math.sqrt(width * width + height * height);
163
- const textProps = new TextProps();
164
- textProps.color = "rgb(0,0,0)";
165
- textProps.fontName = '楷体';
166
- textProps.fontSize = 60;
167
- const textWidth = ctx.contentContext.measureText(watermark, textProps).width
168
- const x = d / 2 - textWidth / 2;
169
- ctx.contentContext.ctx.font = textProps.getFont()
170
- ctx.contentContext.ctx.fillText(watermark, x, 30);
171
- ctx.contentContext.ctx.restore();
172
- }
173
- }
174
-
175
- /**
176
- * 绘制文档页码
177
- */
178
- drawDocPageNum(ctx: RenderContenxtType, position: { x: number; y: number; }): void {
179
- const pageWidth = ctx.viewOptions.docPageSettings.width;
180
- const pageIndex = this.getIndex() + 1;
181
- const str = CommonUtil.parseText(ctx.viewOptions.pageNumFormat, { index: pageIndex, count: this.parent.length });
182
- const textProps = new TextProps();
183
- textProps.color = "rgb(0,0,0)";
184
- textProps.fontName = '仿宋';
185
- textProps.fontSize = 14;
186
- textProps.fontStyle = 'italic';
187
- const size = ctx.contentContext.measureText(str, textProps);
188
- const alignCenterX = position.x + Math.ceil(pageWidth / 2) - Math.ceil(size.width / 2)
189
- const paintY = position.y + this.rect.height - size.height - 5;
190
- ctx.contentContext.drawText(str, textProps, alignCenterX, paintY, size.width, size.height);
191
- }
192
-
193
- clone(): RenderObject {
194
- const cloneRender = new DocumentRenderObject(this.element);
195
- cloneRender.rect = ElementUtil.cloneRect(this.rect);
196
- cloneRender.headerLine = this.headerLine;
197
- cloneRender.footerLine = this.footerLine;
198
- for (let i = 0; i < this.length; i++) {
199
- cloneRender.addChild(this.getChild(i).clone());
200
- }
201
- return cloneRender;
202
- }
203
- }
204
-
205
- export class DocumentFactory extends ElementFactory<DocumentProps> {
206
- match(type: string): boolean {
207
- return type === 'doc';
208
- }
209
- createElement(data: readElementProps<DocumentProps>, renderCtx: RenderContenxtType): Element {
210
- const documentElement = new DocumentElement();
211
- const props = data.props as DocumentProps;
212
- const docProps = documentElement.props;
213
- docProps.width = props.width;
214
- docProps.height = props.height;
215
- docProps.padding = new PaddingProps(props.padding.top, props.padding.bottom, props.padding.left, props.padding.right);
216
- docProps.headerLine = props.headerLine ?? 12;
217
- docProps.footerLine = props.footerLine ?? 12;
218
- docProps.scripts = props.scripts;
219
- docProps.createUserId = props.createUserId;
220
- docProps.createUserName = props.createUserName;
221
- docProps.createDate = props.createDate;
222
- docProps.orient = props.orient ?? 'portrait';
223
- return documentElement;
224
- }
225
-
226
- }