@farris/ui-vue 1.2.9 → 1.3.1

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 (287) hide show
  1. package/components/accordion/index.esm.js +64 -64
  2. package/components/accordion/index.umd.cjs +1 -1
  3. package/components/avatar/index.esm.js +521 -336
  4. package/components/avatar/index.umd.cjs +1 -1
  5. package/components/button-edit/index.css +1 -1
  6. package/components/button-edit/index.esm.js +99 -97
  7. package/components/button-edit/index.umd.cjs +1 -1
  8. package/components/calendar/index.esm.js +496 -504
  9. package/components/calendar/index.umd.cjs +1 -1
  10. package/components/capsule/index.esm.js +251 -259
  11. package/components/capsule/index.umd.cjs +1 -1
  12. package/components/checkbox/index.esm.js +696 -519
  13. package/components/checkbox/index.umd.cjs +1 -1
  14. package/components/color-picker/index.esm.js +368 -376
  15. package/components/color-picker/index.umd.cjs +2 -2
  16. package/components/combo-list/index.css +1 -0
  17. package/components/combo-list/index.esm.js +1141 -340
  18. package/components/combo-list/index.umd.cjs +1 -1
  19. package/components/combo-tree/index.esm.js +116 -116
  20. package/components/combo-tree/index.umd.cjs +1 -1
  21. package/components/common/index.esm.js +986 -798
  22. package/components/common/index.umd.cjs +1 -1
  23. package/components/component/index.esm.js +463 -998
  24. package/components/component/index.umd.cjs +1 -1
  25. package/components/condition/index.css +1 -0
  26. package/components/condition/index.esm.js +2233 -1057
  27. package/components/condition/index.umd.cjs +1 -1
  28. package/components/content-container/index.esm.js +335 -1002
  29. package/components/content-container/index.umd.cjs +1 -1
  30. package/components/data-grid/index.css +1 -1
  31. package/components/data-grid/index.esm.js +6193 -4702
  32. package/components/data-grid/index.umd.cjs +1 -1
  33. package/components/data-view/index.css +1 -0
  34. package/components/data-view/index.esm.js +4562 -3294
  35. package/components/data-view/index.umd.cjs +1 -1
  36. package/components/date-picker/index.css +1 -1
  37. package/components/date-picker/index.esm.js +3420 -2623
  38. package/components/date-picker/index.umd.cjs +1 -1
  39. package/components/designer-canvas/index.css +1 -1
  40. package/components/designer-canvas/index.esm.js +914 -883
  41. package/components/designer-canvas/index.umd.cjs +1 -1
  42. package/components/designer-outline/index.esm.js +14 -13
  43. package/components/designer-outline/index.umd.cjs +1 -1
  44. package/components/dropdown/index.esm.js +204 -212
  45. package/components/dropdown/index.umd.cjs +2 -2
  46. package/components/dynamic-form/index.css +1 -0
  47. package/components/dynamic-form/index.esm.js +2795 -1835
  48. package/components/dynamic-form/index.umd.cjs +1 -1
  49. package/components/dynamic-resolver/index.esm.js +180 -130
  50. package/components/dynamic-resolver/index.umd.cjs +1 -1
  51. package/components/dynamic-view/index.esm.js +303 -290
  52. package/components/dynamic-view/index.umd.cjs +1 -1
  53. package/components/events-editor/index.esm.js +328 -336
  54. package/components/events-editor/index.umd.cjs +1 -1
  55. package/components/expression-editor/index.esm.js +65 -65
  56. package/components/expression-editor/index.umd.cjs +1 -1
  57. package/components/external-container/index.css +1 -1
  58. package/components/external-container/index.esm.js +3349 -3626
  59. package/components/external-container/index.umd.cjs +1 -1
  60. package/components/field-selector/index.css +1 -1
  61. package/components/field-selector/index.esm.js +5344 -8588
  62. package/components/field-selector/index.umd.cjs +1 -1
  63. package/components/filter-bar/index.css +1 -1
  64. package/components/filter-bar/index.esm.js +2179 -2227
  65. package/components/filter-bar/index.umd.cjs +1 -1
  66. package/components/flow-canvas/index.css +1 -1
  67. package/components/flow-canvas/index.esm.js +684 -675
  68. package/components/flow-canvas/index.umd.cjs +1 -1
  69. package/components/image-cropper/index.esm.js +482 -490
  70. package/components/image-cropper/index.umd.cjs +1 -1
  71. package/components/input-group/index.esm.js +746 -569
  72. package/components/input-group/index.umd.cjs +1 -1
  73. package/components/layout/index.esm.js +409 -385
  74. package/components/layout/index.umd.cjs +1 -1
  75. package/components/list-nav/index.esm.js +348 -1019
  76. package/components/list-nav/index.umd.cjs +1 -1
  77. package/components/list-view/index.css +1 -1
  78. package/components/list-view/index.esm.js +3606 -2388
  79. package/components/list-view/index.umd.cjs +1 -1
  80. package/components/lookup/index.css +1 -1
  81. package/components/lookup/index.esm.js +10871 -8970
  82. package/components/lookup/index.umd.cjs +1 -1
  83. package/components/mapping-editor/index.css +1 -1
  84. package/components/mapping-editor/index.esm.js +6019 -5631
  85. package/components/mapping-editor/index.umd.cjs +1 -1
  86. package/components/message-box/index.css +1 -1
  87. package/components/message-box/index.esm.js +511 -471
  88. package/components/message-box/index.umd.cjs +1 -1
  89. package/components/modal/index.css +1 -1
  90. package/components/modal/index.esm.js +438 -398
  91. package/components/modal/index.umd.cjs +1 -1
  92. package/components/nav/index.esm.js +912 -1281
  93. package/components/nav/index.umd.cjs +3 -3
  94. package/components/notify/index.esm.js +59 -53
  95. package/components/notify/index.umd.cjs +1 -1
  96. package/components/number-range/index.esm.js +660 -484
  97. package/components/number-range/index.umd.cjs +1 -1
  98. package/components/number-spinner/index.esm.js +682 -506
  99. package/components/number-spinner/index.umd.cjs +1 -1
  100. package/components/order/index.css +1 -1
  101. package/components/order/index.esm.js +1848 -1658
  102. package/components/order/index.umd.cjs +1 -1
  103. package/components/page-footer/index.esm.js +100 -100
  104. package/components/page-footer/index.umd.cjs +1 -1
  105. package/components/page-header/index.esm.js +1120 -1923
  106. package/components/page-header/index.umd.cjs +1 -1
  107. package/components/pagination/index.esm.js +875 -1214
  108. package/components/pagination/index.umd.cjs +1 -1
  109. package/components/popover/index.esm.js +71 -70
  110. package/components/popover/index.umd.cjs +1 -1
  111. package/components/progress/index.esm.js +229 -237
  112. package/components/progress/index.umd.cjs +3 -3
  113. package/components/property-editor/index.css +1 -1
  114. package/components/property-editor/index.esm.js +2314 -1521
  115. package/components/property-editor/index.umd.cjs +3 -3
  116. package/components/property-panel/index.esm.js +867 -868
  117. package/components/property-panel/index.umd.cjs +1 -1
  118. package/components/query-solution/index.css +1 -1
  119. package/components/query-solution/index.esm.js +4332 -3623
  120. package/components/query-solution/index.umd.cjs +1 -1
  121. package/components/radio-button/index.esm.js +72 -72
  122. package/components/radio-button/index.umd.cjs +1 -1
  123. package/components/radio-group/index.esm.js +613 -437
  124. package/components/radio-group/index.umd.cjs +1 -1
  125. package/components/rate/index.esm.js +255 -263
  126. package/components/rate/index.umd.cjs +1 -1
  127. package/components/response-layout/index.esm.js +144 -152
  128. package/components/response-layout/index.umd.cjs +1 -1
  129. package/components/response-layout-editor/index.css +1 -1
  130. package/components/response-layout-editor/index.esm.js +1101 -1038
  131. package/components/response-layout-editor/index.umd.cjs +1 -1
  132. package/components/response-toolbar/index.esm.js +935 -1750
  133. package/components/response-toolbar/index.umd.cjs +1 -1
  134. package/components/schema-selector/index.css +1 -1
  135. package/components/schema-selector/index.esm.js +5264 -5677
  136. package/components/schema-selector/index.umd.cjs +2 -2
  137. package/components/search-box/index.esm.js +151 -154
  138. package/components/search-box/index.umd.cjs +1 -1
  139. package/components/section/index.esm.js +438 -1125
  140. package/components/section/index.umd.cjs +1 -1
  141. package/components/smoke-detector/index.esm.js +93 -101
  142. package/components/smoke-detector/index.umd.cjs +1 -1
  143. package/components/splitter/index.esm.js +563 -1202
  144. package/components/splitter/index.umd.cjs +1 -1
  145. package/components/splitter/style.js +2 -0
  146. package/components/step/index.esm.js +248 -256
  147. package/components/step/index.umd.cjs +1 -1
  148. package/components/switch/index.esm.js +549 -373
  149. package/components/switch/index.umd.cjs +1 -1
  150. package/components/tabs/index.css +1 -1
  151. package/components/tabs/index.esm.js +2436 -3110
  152. package/components/tabs/index.umd.cjs +1 -1
  153. package/components/tags/index.esm.js +328 -336
  154. package/components/tags/index.umd.cjs +1 -1
  155. package/components/text/index.esm.js +339 -347
  156. package/components/text/index.umd.cjs +1 -1
  157. package/components/textarea/index.esm.js +554 -378
  158. package/components/textarea/index.umd.cjs +1 -1
  159. package/components/time-picker/index.css +1 -1
  160. package/components/time-picker/index.esm.js +1322 -1144
  161. package/components/time-picker/index.umd.cjs +1 -1
  162. package/components/transfer/index.css +1 -1
  163. package/components/transfer/index.esm.js +537 -543
  164. package/components/transfer/index.umd.cjs +1 -1
  165. package/components/tree-grid/index.css +1 -1
  166. package/components/tree-grid/index.esm.js +5113 -9426
  167. package/components/tree-grid/index.umd.cjs +1 -1
  168. package/components/tree-view/index.css +1 -0
  169. package/components/tree-view/index.esm.js +3900 -2677
  170. package/components/tree-view/index.umd.cjs +1 -1
  171. package/components/uploader/index.esm.js +568 -570
  172. package/components/uploader/index.umd.cjs +2 -2
  173. package/components/verify-detail/index.esm.js +266 -274
  174. package/components/verify-detail/index.umd.cjs +1 -1
  175. package/components/video/index.esm.js +553 -1052
  176. package/components/video/index.umd.cjs +1 -1
  177. package/components/weather/index.esm.js +558 -566
  178. package/components/weather/index.umd.cjs +5 -5
  179. package/farris.all.esm.js +22009 -22688
  180. package/farris.all.umd.cjs +9 -9
  181. package/index.css +1 -1
  182. package/package.json +1 -1
  183. package/types/capsule/src/capsule.props.d.ts +2 -2
  184. package/types/combo-list/src/components/list-container.component.d.ts +0 -3
  185. package/types/combo-list/src/components/list-container.props.d.ts +0 -4
  186. package/types/common/directive/area-response.d.ts +10 -0
  187. package/types/common/index.d.ts +9 -0
  188. package/types/common/radio-checkbox/radio-checkbox.props.d.ts +1 -0
  189. package/types/common/types.d.ts +1 -1
  190. package/types/common/utils/encrypt.d.ts +2 -0
  191. package/types/common/utils/resolve-field.d.ts +2 -0
  192. package/types/common/utils/use-class.d.ts +7 -0
  193. package/types/component/src/component.props.d.ts +7 -0
  194. package/types/component/src/designer/use-designer-rules.d.ts +2 -2
  195. package/types/component/src/property-config/component.property-config.d.ts +9 -0
  196. package/types/components.d.ts +1 -0
  197. package/types/condition/src/types.d.ts +2 -1
  198. package/types/content-container/src/designer/use-designer-rules.d.ts +3 -3
  199. package/types/data-grid/index.d.ts +11 -5
  200. package/types/data-grid/src/data-grid.component.d.ts +4 -2
  201. package/types/data-grid/src/data-grid.props.d.ts +1 -0
  202. package/types/data-grid/src/designer/data-grid.design.component.d.ts +2 -2
  203. package/types/data-grid/src/designer/use-designer-rules.d.ts +2 -2
  204. package/types/data-view/components/row/hierarchy-row.component.d.ts +2 -2
  205. package/types/data-view/composition/data/use-tree-data.d.ts +1 -1
  206. package/types/data-view/composition/types.d.ts +19 -4
  207. package/types/data-view/composition/visualization/use-virtual-scroll.d.ts +0 -15
  208. package/types/designer-canvas/index.d.ts +2 -1
  209. package/types/designer-canvas/src/composition/dg-control.d.ts +5 -0
  210. package/types/designer-canvas/src/composition/rule/use-dragula-common-rule.d.ts +4 -0
  211. package/types/designer-canvas/src/composition/rule/use-template-rule.d.ts +30 -0
  212. package/types/designer-canvas/src/composition/types.d.ts +2 -3
  213. package/types/designer-canvas/src/types.d.ts +2 -1
  214. package/types/dynamic-form/src/composition/use-response-form-layout-setting.d.ts +2 -0
  215. package/types/dynamic-form/src/designer/response-form-layout-setting.component.d.ts +8 -0
  216. package/types/dynamic-form/src/designer/response-form-layout-setting.props.d.ts +4 -0
  217. package/types/dynamic-form/src/designer/response-form.design.component.d.ts +7 -1
  218. package/types/dynamic-form/src/designer/use-designer-rules.d.ts +1 -1
  219. package/types/dynamic-form/src/property-config/form.property-config.d.ts +9 -0
  220. package/types/dynamic-form/src/schema/schema-mapper.d.ts +1 -0
  221. package/types/dynamic-form/src/schema/schema-resolver.d.ts +1 -0
  222. package/types/dynamic-form/src/types.d.ts +12 -1
  223. package/types/dynamic-resolver/index.d.ts +1 -0
  224. package/types/dynamic-resolver/src/common/toolbar-resolver.d.ts +1 -1
  225. package/types/dynamic-resolver/src/event-handler-resolver.d.ts +4 -0
  226. package/types/dynamic-resolver/src/types.d.ts +9 -0
  227. package/types/dynamic-view/index.d.ts +1 -0
  228. package/types/dynamic-view/src/event-dispatcher.d.ts +1 -1
  229. package/types/external-container/src/designer/use-designer-rules.d.ts +3 -3
  230. package/types/index.d.ts +2 -0
  231. package/types/layout/src/designer/layout-pane-use-designer-rules.d.ts +3 -3
  232. package/types/list-nav/src/designer/use-designer-rules.d.ts +3 -0
  233. package/types/lookup/src/components/favorite/lookup-favorite.component.d.ts +29 -0
  234. package/types/lookup/src/components/favorite/lookup-favorite.props.d.ts +15 -0
  235. package/types/lookup/src/components/modal-container.component.d.ts +25 -0
  236. package/types/lookup/src/components/modal-container.props.d.ts +29 -0
  237. package/types/lookup/src/composition/types.d.ts +8 -0
  238. package/types/lookup/src/composition/use-check-props.d.ts +9 -2
  239. package/types/lookup/src/composition/use-dialog.d.ts +5 -1
  240. package/types/lookup/src/composition/use-favorite.d.ts +12 -0
  241. package/types/lookup/src/composition/use-http.d.ts +9 -5
  242. package/types/lookup/src/composition/use-input-change.d.ts +3 -0
  243. package/types/lookup/src/composition/use-user-data.d.ts +24 -0
  244. package/types/lookup/src/property-config/lookup.property-config.d.ts +6 -4
  245. package/types/mapping-editor/src/mapping-editor.component.d.ts +3 -0
  246. package/types/mapping-editor/src/mapping-editor.props.d.ts +0 -1
  247. package/types/modal/src/composition/use-draggable.d.ts +2 -1
  248. package/types/modal/src/composition/use-shortcut.d.ts +6 -0
  249. package/types/modal/src/modal.component.d.ts +3 -0
  250. package/types/modal/src/modal.props.d.ts +4 -0
  251. package/types/page-header/src/page-header.props.d.ts +1 -0
  252. package/types/pagination/src/components/buttons/goto-buttons.component.d.ts +2 -2
  253. package/types/pagination/src/components/buttons/next-buttons.component.d.ts +2 -2
  254. package/types/pagination/src/components/buttons/previous-buttons.component.d.ts +2 -2
  255. package/types/pagination/src/components/pages/page-list.component.d.ts +2 -2
  256. package/types/pagination/src/components/pages/page-number.component.d.ts +2 -2
  257. package/types/property-panel/index.d.ts +2 -1
  258. package/types/property-panel/src/composition/entity/base-property.d.ts +8 -0
  259. package/types/property-panel/src/composition/entity/input-base-property.d.ts +20 -1
  260. package/types/query-solution/src/designer/query-solution-config/composition/types.d.ts +34 -27
  261. package/types/query-solution/src/designer/query-solution-config/composition/use-panel.d.ts +2 -16
  262. package/types/{data-grid/src/designer/use-group-column.d.ts → query-solution/src/designer/query-solution-config/composition/use-property.d.ts} +4 -5
  263. package/types/query-solution/src/designer/query-solution-config/composition/use-querysolution-rules.d.ts +3 -0
  264. package/types/query-solution/src/designer/query-solution-config/composition/use-transfer.d.ts +1 -1
  265. package/types/query-solution/src/property-config/query-solution.property-config.d.ts +60 -0
  266. package/types/query-solution/src/solutions.d.ts +108 -509
  267. package/types/response-layout-editor/index.d.ts +3 -1
  268. package/types/response-layout-editor/src/composition/converter/use-response-layout-editor-setting.d.ts +2 -0
  269. package/types/response-layout-editor/src/type.d.ts +21 -0
  270. package/types/response-toolbar/src/designer/use-designer-rules.d.ts +3 -3
  271. package/types/response-toolbar/src/property-config/response-toolbar-item.property-config.d.ts +1 -0
  272. package/types/section/src/designer/use-designer-rules.d.ts +3 -3
  273. package/types/splitter/src/components/splitter-pane.component.d.ts +1 -1
  274. package/types/splitter/src/designer/splitter-pane-use-designer-rules.d.ts +3 -3
  275. package/types/splitter/src/designer/splitter-use-designer-rules.d.ts +3 -3
  276. package/types/tabs/src/designer/tab-page-use-designer-rules.d.ts +3 -3
  277. package/types/tabs/src/designer/tab-use-designer-rules.d.ts +3 -3
  278. package/types/tabs/src/tabs.props.d.ts +1 -0
  279. package/types/tree-grid/index.d.ts +8 -2
  280. package/types/tree-grid/src/tree-grid.component.d.ts +3 -1
  281. package/types/designer-canvas/src/composition/rule/use-drag-drop-rules.d.ts +0 -19
  282. package/types/designer-canvas/src/composition/use-dragula-common-rule.d.ts +0 -4
  283. package/types/list-nav/src/composition/use-designer-rules.d.ts +0 -3
  284. package/types/modal/src/composition/use-esc.d.ts +0 -1
  285. package/types/query-solution/src/designer/query-solution-config/composition/mock-data.d.ts +0 -6
  286. package/types/response-layout-editor/src/composition/converter/response-layout-editor.converter.d.ts +0 -3
  287. package/types/response-layout-editor/src/composition/converter/use-convert-property-value.d.ts +0 -20
@@ -1 +1 @@
1
- (function(H,a){typeof exports=="object"&&typeof module<"u"?a(exports,require("vue"),require("lodash-es"),require("bignumber.js")):typeof define=="function"&&define.amd?define(["exports","vue","lodash-es","bignumber.js"],a):(H=typeof globalThis<"u"?globalThis:H||self,a(H.layout={},H.Vue,H.LodashES))})(this,function(H,a,G){"use strict";const k={},L={};function R(t){const{properties:e,title:n,ignore:o}=t,l=o&&Array.isArray(o),s=Object.keys(e).reduce((c,m)=>((!l||!o.find(P=>P==m))&&(c[m]=e[m].type==="object"&&e[m].properties?R(e[m]):G.cloneDeep(e[m].default)),c),{});return(!l||!o.find(c=>c=="id"))&&(s.id=`${n}-${Date.now()}`),s}function E(t,e={},n){const o=k[t];if(o){let l=R(o);const s=L[t];return l=s?s({getSchemaByType:E},l,e,n):l,l}return null}function Q(t,e){const n=R(e);return Object.keys(t).reduce((o,l)=>(o[l]&&typeof o[l]=="object"?Object.assign(o[l],t[l]):o[l]=t[l],o),n),n}function U(t,e){return Object.keys(t).filter(o=>t[o]!=null).reduce((o,l)=>{if(e.has(l)){const s=e.get(l);if(typeof s=="string")o[s]=t[l];else{const c=s(l,t[l],t);Object.assign(o,c)}}else o[l]=t[l];return o},{})}function Z(t,e,n=new Map){const o=Q(t,e);return U(o,n)}function K(t={}){function e(r,d,u,v){if(typeof u=="number")return v[r].length===u;if(typeof u=="object"){const $=Object.keys(u)[0],O=u[$];if($==="not")return Number(v[r].length)!==Number(O);if($==="moreThan")return Number(v[r].length)>=Number(O);if($==="lessThan")return Number(v[r].length)<=Number(O)}return!1}function n(r,d,u,v){return v[r]&&v[r].propertyValue&&String(v[r].propertyValue.value)===String(u)}const o=new Map([["length",e],["getProperty",n]]);Object.keys(t).reduce((r,d)=>(r.set(d,t[d]),r),o);function l(r,d){const u=r;return typeof d=="number"?[{target:u,operator:"length",param:null,value:Number(d)}]:typeof d=="boolean"?[{target:u,operator:"getProperty",param:r,value:!!d}]:typeof d=="object"?Object.keys(d).map(v=>{if(v==="length")return{target:u,operator:"length",param:null,value:d[v]};const $=v,O=d[v];return{target:u,operator:"getProperty",param:$,value:O}}):[]}function s(r){return Object.keys(r).reduce((u,v)=>{const $=l(v,r[v]);return u.push(...$),u},[])}function c(r,d){if(o.has(r.operator)){const u=o.get(r.operator);return u&&u(r.target,r.param,r.value,d)||!1}return!1}function m(r,d){return s(r).reduce(($,O)=>$&&c(O,d),!0)}function P(r,d){const u=Object.keys(r),v=u.includes("allOf"),$=u.includes("anyOf"),O=v||$,f=(O?r[O?v?"allOf":"anyOf":"allOf"]:[r]).map(g=>m(g,d));return v?!f.includes(!1):f.includes(!0)}return{parseValueSchema:P}}const x={},I={};K();function F(t,e,n=new Map,o=(c,m,P)=>m,l={},s=c=>c){return k[e.title]=e,L[e.title]=o,x[e.title]=l,I[e.title]=s,(c={})=>{const m=Z(c,e,n),P=Object.keys(t).reduce((r,d)=>(r[d]=t[d].default,r),{});return Object.assign(P,m)}}function ee(t,e){return{customClass:e.class,customStyle:e.style}}const q=new Map([["appearance",ee]]);function W(t,e,n){return e}const te={$schema:"https://json-schema.org/draft/2020-12/schema",$id:"https://farris-design.gitee.io/layout.schema.json",title:"layout",description:"A Farris Container Component",type:"object",properties:{id:{description:"The unique identifier for layout component",type:"string"},type:{description:"The type string of layout component",type:"string",default:"layout"},appearance:{description:"",type:"object",properties:{class:{type:"string"},style:{type:"string"}},default:{}},contents:{description:"",type:"array",default:[]},collapsable:{description:"",type:"boolean",default:!1},resizable:{description:"",type:"boolean",default:!0},visible:{description:"",type:"boolean",default:!0}},required:["id","type","contents"]},ne={title:"layout",description:"A Farris Component",type:"object",categories:{basic:{description:"Basic Infomation",title:"基本信息",properties:{id:{description:"组件标识",title:"标识",type:"string",readonly:!0},type:{description:"类型",title:"类型",type:"string",readonly:!0}}},behavior:{description:"Basic Infomation",title:"行为",properties:{collapsable:{description:"",title:"可收折",type:"boolean"},resizable:{description:"",title:"可调整尺寸",type:"boolean"}}}}},D={customStyle:{type:String,defaut:""},customClass:{type:String,defaut:""}},T=F(D,te,q,W,ne);function _(t){const e=a.ref(-1),n=a.ref(-1),o=a.ref(0),l=a.ref(0),s=a.ref(!1),c=a.ref(!1),m=a.computed(()=>({display:s.value?"block":"none",left:`${o.value}px`,cursor:"e-resize"})),P=a.computed(()=>({display:c.value?"block":"none",top:`${l.value}px`,cursor:"n-resize"})),r=a.computed(()=>({display:c.value||s.value?"block":"none"}));function d(z,f,h,g){const S=t.value;if(S){const{left:b,right:i,width:y}=S.getBoundingClientRect();let p=z.clientX-b;g==="right"&&(p=i-z.clientX),p>f&&(p=f),p<h&&(p=h),g==="right"&&(p=y-p),o.value=p}}function u(z,f,h,g){const S=t.value;if(S){const{top:b,bottom:i,height:y}=S.getBoundingClientRect();let p=z.clientY-b;g==="bottom"&&(p=i-z.clientY),p>f&&(p=f),p<h&&(p=h),g==="bottom"&&(p=y-p),l.value=p}}function v(){const z=t.value;if(z){const{width:f,height:h}=z.getBoundingClientRect();return{width:f,height:h}}return null}function $(){const z=t.value;return z?Array.from(z.querySelectorAll("[data-position]")).reduce((f,h)=>{const g=h.getAttribute("data-position");return f=Object.assign(f,{[g]:h}),f},{}):null}function O(z,f){const h=v(),g=$();if(h&&g){const S=g==null?void 0:g.right,b=g==null?void 0:g.left;if(z==="left"&&b)return S?h.width-S.clientWidth-f:h.width-f;if(z==="right"&&S)return b?h.width-b.clientWidth-f:h.width-f}}function w(z,f){const h=v(),g=$();if(h&&g){const S=g==null?void 0:g.bottom,b=g==null?void 0:g.top;if(z==="top"&&b)return S?h.height-S.clientHeight-f:h.height-f;if(z==="bottom"&&S)return b?h.height-b.clientHeight-f:h.height-f}}return{horizontalResizeHandleStyle:m,verticalResizeHandleStyle:P,resizeOverlayStyle:r,showHorizontalResizeHandle:s,showVerticalResizeHandle:c,horizontalResizeBarPosition:e,verticalResizeBarPosition:n,verticalResizeHandleOffset:l,horizontalResizeHandleOffset:o,draggingHorizontalResizeHandle:d,draggingVerticalResizeHandle:u,getPanelMaxHeight:w,getPanelMaxWidth:O}}const oe=["moz","ms","webkit"];function ae(){let t=0;return e=>{const n=new Date().getTime(),o=Math.max(0,16-(n-t)),l=setTimeout(()=>{e(n+o)},o);return t=n+o,l}}function re(){if(typeof window>"u")return()=>0;if(window.requestAnimationFrame)return window.requestAnimationFrame.bind(window);const t=oe.filter(e=>`${e}RequestAnimationFrame`in window)[0];return t?window[`${t}RequestAnimationFrame`]:ae()}re();function ie(t,e){return((e==null?void 0:e.split(" "))||[]).reduce((o,l)=>(l&&(o[l]=!0),o),t),t}function le(t,e){return((e==null?void 0:e.split(";"))||[]).reduce((o,l)=>{if(l){const s=l.split(":");o[s[0]]=s[1]}return o},t),t}const N=a.defineComponent({name:"FLayout",props:D,emits:[],setup(t,e){const n=a.ref(),o=_(n),{horizontalResizeHandleStyle:l,verticalResizeHandleStyle:s,resizeOverlayStyle:c}=o;a.provide("layout",{useResizeHandleComposition:o});const m=a.computed(()=>ie({"f-layout":!0},t==null?void 0:t.customClass)),P=a.computed(()=>le({},t==null?void 0:t.customStyle));return()=>a.createVNode("div",{class:m.value,style:P.value,ref:n},[e.slots.default&&e.slots.default(),a.createVNode("div",{class:"f-layout-resize-overlay",style:c.value},null),a.createVNode("div",{class:"f-layout-horizontal-resize-proxy",style:l.value},null),a.createVNode("div",{class:"f-layout-vertical-resize-proxy",style:s.value},null)])}}),se={$schema:"https://json-schema.org/draft/2020-12/schema",$id:"https://farris-design.gitee.io/layout-pane.schema.json",title:"layout-pane",description:"A Farris Container Component",type:"object",properties:{id:{description:"The unique identifier for a layout pane",type:"string"},type:{description:"The type string of layout paney",type:"string",default:"layout-pane"},appearance:{description:"",type:"object",properties:{class:{type:"string"},style:{type:"string"}},default:{}},collapsable:{description:"",type:"boolean",default:!1},contents:{description:"",type:"array",default:[]},height:{description:"",type:"number"},position:{description:"",type:"string",default:"left",enum:["left","center","right","top","bottom"]},resizeable:{description:"",type:"boolean",default:!0},width:{description:"",type:"number"},visible:{description:"",type:"number",default:!0}}},ce={title:"layout-pane",description:"A Farris Container Component",type:"object",categories:{basic:{description:"Basic Infomation",title:"基本信息",properties:{id:{description:"组件标识",title:"标识",type:"string",readonly:!0},type:{description:"组件类型",title:"控件类型",type:"enum"},width:{description:"",type:"number",title:"宽度"},height:{description:"",type:"number",title:"高度"}}},appearance:{title:"样式",description:"Appearance",properties:{class:{title:"class",type:"string",description:""},style:{title:"style",type:"string",description:""}}},behavior:{description:"",title:"行为",properties:{collapsable:{description:"",type:"boolean",title:"允许收折"},position:{description:"",type:"enum",title:"位置",editor:{type:"combo-list",data:[{id:"left",name:"左侧"},{id:"center",name:"居中"},{id:"right",name:"右侧"},{id:"top",name:"顶部"},{id:"bottom",name:"底部"}]}},resizeable:{description:"",type:"boolean",title:"允许调整尺寸"},visible:{description:"运行时组件是否可见",type:"boolean",title:"是否可见"}}}}},V={customClass:{type:String,defaut:""},customStyle:{type:String,defaut:""},width:{type:Number,default:-1},height:{type:Number,default:-1},position:{type:String,default:"left"},visible:{type:Boolean,default:!0},resizable:{type:Boolean,default:!0},collapsable:{type:Boolean,default:!1},minWidth:{type:Number,default:100},minHeight:{type:Number,default:100}},Y=F(V,se,q,W,ce);function X(t,e,n,o,l){const{horizontalResizeBarPosition:s,horizontalResizeHandleOffset:c,showHorizontalResizeHandle:m,showVerticalResizeHandle:P,verticalResizeBarPosition:r,verticalResizeHandleOffset:d,draggingHorizontalResizeHandle:u,draggingVerticalResizeHandle:v,getPanelMaxHeight:$,getPanelMaxWidth:O}=l;let w="",z,f,h;function g(i){if((w==="left"||w==="right")&&f){const{left:y}=f.getBoundingClientRect(),{width:p}=z.getBoundingClientRect(),M=i.clientX-y;let C=w==="left"?(p||0)+(M-s.value):(p||0)-(M-s.value);C=n.value>0?Math.max(n.value,C):C;const j=O(w,n.value);j!=null&&(C=j>C?C:j),t.value=C}if((w==="top"||w==="bottom")&&f){const{top:y}=f.getBoundingClientRect(),{height:p}=z.getBoundingClientRect(),M=i.clientY-y;let C=w==="top"?(p||0)+(M-r.value):(p||0)-(M-r.value);C=o.value>0?Math.max(o.value,C):C;const j=$(w,o.value);j!=null&&(C=j>C?C:j),e.value=C}c.value=0,d.value=0,s.value=-1,r.value=-1,m.value=!1,P.value=!1,document.removeEventListener("mousemove",h),document.removeEventListener("mouseup",g),document.body.style.userSelect="",w="",z=null,f=null}function S(i,y,p){if(w=y,z=p,m.value=!0,f=i.composedPath().find(C=>(C.className||"").split(" ")[0]==="f-layout"),f){const{left:C}=f.getBoundingClientRect(),j=i.clientX-C;c.value=j,s.value=j;const B=O(w,n.value)||0;h=me=>u(me,B,n.value,w),document.addEventListener("mousemove",h),document.addEventListener("mouseup",g),document.body.style.userSelect="none"}}function b(i,y,p){if(w=y,z=p,P.value=!0,f=i.composedPath().find(C=>(C.className||"").split(" ")[0]==="f-layout"),f){const{top:C}=f.getBoundingClientRect();d.value=i.clientY-C,r.value=i.clientY-C;const j=$(w,o.value)||0;h=B=>v(B,j,o.value,w),document.addEventListener("mousemove",h),document.addEventListener("mouseup",g),document.body.style.userSelect="none"}}return{onClickHorizontalResizeBar:S,onClickVerticalResizeBar:b}}const A=a.defineComponent({name:"FLayoutPane",props:V,emits:[],setup(t,e){const n=a.ref(t.minHeight<=0?100:t.minHeight),o=a.ref(t.minWidth<=0?100:t.minWidth),l=a.ref(t.width<=0?100:t.width),s=a.ref(t.height<=100?100:t.height),c=a.ref(Math.max(n.value,s.value)),m=a.ref(Math.max(o.value,l.value)),P=a.ref(),r=a.ref(t.position),d=a.ref(t.resizable);a.watch(()=>t.resizable,b=>{d.value=b});const u=a.inject("layout"),{useResizeHandleComposition:v}=u,$=X(m,c,o,n,v),{onClickHorizontalResizeBar:O,onClickVerticalResizeBar:w}=$,z=a.computed(()=>({"f-layout-resize-bar":!0,"f-layout-resize-bar-e":r.value==="left","f-layout-resize-bar-n":r.value==="bottom","f-layout-resize-bar-s":r.value==="top","f-layout-resize-bar-w":r.value==="right"})),f=a.computed(()=>r.value!=="center"&&d.value);function h(b,i){(i==="left"||i==="right")&&O(b,i,P.value),(i==="top"||i==="bottom")&&w(b,i,P.value)}const g=a.computed(()=>{const b={"f-layout-pane":!0,"f-page-content-nav":r.value==="left"||r.value==="right","f-page-content-main":r.value==="center"};return t.customClass&&String(t.customClass).split(" ").reduce((i,y)=>(i[y]=!0,i),b),b}),S=a.computed(()=>{const b={};return(m.value&&r.value==="left"||r.value==="right")&&(b.width=`${m.value}px`),(c.value&&r.value==="bottom"||r.value==="top")&&(b.height=`${c.value}px`),t.visible||(b.display="none"),b});return()=>a.createVNode("div",{ref:P,class:g.value,style:S.value,"data-position":r.value},[e.slots.default&&e.slots.default(),f.value&&a.createVNode("span",{class:z.value,onMousedown:b=>h(b,r.value)},null)])}});function ue(t,e){function n(){return!1}return{canAccepts:n}}function J(t,e,n){var b;function o(){n!=null&&n.resolveComponentContext&&n.resolveComponentContext()}o();const l=n&&n.getStyles&&n.getStyles()||"",s=n&&n.getDesignerClass&&n.getDesignerClass()||"",c=a.ref();function m(){return(e==null?void 0:e.schema.componentType)==="frame"?!1:n&&n.checkCanMoveComponent?n.checkCanMoveComponent():!0}function P(){return!1}function r(){return(e==null?void 0:e.schema.componentType)==="frame"?!1:n&&n.checkCanDeleteComponent?n.checkCanDeleteComponent():!0}function d(){return(e==null?void 0:e.schema.componentType)==="frame"?!0:n&&n.hideNestedPaddingInDesginerView?n.hideNestedPaddingInDesginerView():!1}function u(i){if(!i||!i.value)return null;if(i.value.schema&&i.value.schema.type==="component")return i.value;const y=a.ref(i==null?void 0:i.value.parent),p=u(y);return p||null}function v(i=e){const{componentInstance:y,designerItemElementRef:p}=i;return!y||!y.value?null:y.value.canMove?p:v(i.parent)}function $(i){return!!n&&n.canAccepts(i)}function O(){return(e==null?void 0:e.schema.label)||(e==null?void 0:e.schema.title)||(e==null?void 0:e.schema.name)}function w(){}function z(i,y){y&&n!=null&&n.onAcceptMovedChildElement&&n.onAcceptMovedChildElement(y)}function f(i,y){const{componentType:p}=i;let M=E(p,i,y);n&&n.onResolveNewComponentSchema&&(M=n.onResolveNewComponentSchema(i,M));const C=p.toLowerCase().replace("-","_");return M&&!M.id&&M.type===p&&(M.id=`${C}_${Math.random().toString().slice(2,6)}`),M}function h(i,y){const p=String(i.getAttribute("data-controltype")),M=i.getAttribute("data-feature"),C=M?JSON.parse(M):{};C.parentComponentInstance=c.value;let j=E(p,C);n&&n.onAcceptNewChildElement&&(j=n.onAcceptNewChildElement(i,y,j));const B=p.toLowerCase().replace("-","_");return j&&!j.id&&j.type===p&&(j.id=`${B}_${Math.random().toString().slice(2,6)}`),j}function g(i){}function S(...i){if(n&&n.getPropsConfig)return n.getPropsConfig(...i)}return c.value={canMove:m(),canSelectParent:P(),canDelete:r(),canNested:!d(),contents:e==null?void 0:e.schema.contents,elementRef:t,parent:(b=e==null?void 0:e.parent)==null?void 0:b.componentInstance,schema:e==null?void 0:e.schema,styles:l,designerClass:s,canAccepts:$,getBelongedComponentInstance:u,getDraggableDesignItemElement:v,getDraggingDisplayText:O,getPropConfig:S,getDragScopeElement:w,onAcceptMovedChildElement:z,onAcceptNewChildElement:h,onChildElementMovedOut:g,addNewChildComponentSchema:f,updateDragAndDropRules:o,triggerBelongedComponentToMoveWhenMoved:!!n&&n.triggerBelongedComponentToMoveWhenMoved||a.ref(!1),triggerBelongedComponentToDeleteWhenDeleted:!!n&&n.triggerBelongedComponentToDeleteWhenDeleted||a.ref(!1)},c}const fe=a.defineComponent({name:"FLayoutDesign",props:D,emits:[],setup(t,e){var d;const n=a.ref(),o=a.inject("design-item-context"),l=ue(o.schema,(d=o.parent)==null?void 0:d.schema),s=J(n,o,l);s.value.canNested=!1;const c=_(n),{horizontalResizeHandleStyle:m,verticalResizeHandleStyle:P,resizeOverlayStyle:r}=c;return a.provide("layout",{useResizeHandleComposition:c}),a.onMounted(()=>{n.value.componentInstance=s}),e.expose(s.value),()=>a.createVNode("div",{class:"f-layout f-page-content",ref:n},[e.slots.default&&e.slots.default(),a.createVNode("div",{class:"f-layout-resize-overlay",style:r.value},null),a.createVNode("div",{class:"f-layout-horizontal-resize-proxy",style:m.value},null),a.createVNode("div",{class:"f-layout-vertical-resize-proxy",style:P.value},null)])}});function pe(){function t(e){var l,s;if(!e)return!1;const n=((l=e.targetContainer)==null?void 0:l.componentInstance)&&e.targetContainer.componentInstance.value;if(!n)return!1;const o=(s=n.schema.appearance)==null?void 0:s.class;if(e.controlCategory==="input"||e.controlType==="form-group"){const c=n.schema.type,m=(c==="response-form"||c==="content-container")&&o&&o.includes("farris-form");if(n.schema.type!=="response-layout-item"&&!m)return!1}return e.controlType!=="field-set"}return{basalDragulaRuleForContainer:t}}function de(t,e){function n(s){return!!pe().basalDragulaRuleForContainer(s)}function o(s,c,m){return m}function l(){const s=["f-layout-pane"];return(t.position==="left"||t.position==="right")&&s.push("f-page-content-nav"),t.position==="center"&&s.push("f-page-content-main"),s.join(" ")}return{canAccepts:n,getDesignerClass:l,onAcceptNewChildElement:o}}const ye=a.defineComponent({name:"FLayoutPaneDesign",props:V,emits:[],setup(t,e){var b;const n=a.ref(),o=a.ref(),l=a.inject("design-item-context"),s=de(l.schema,(b=l.parent)==null?void 0:b.schema),c=J(o,l,s);c.value.canNested=!1,c.value.canMove=!1,c.value.canDelete=!1,a.onMounted(()=>{o.value.componentInstance=c}),e.expose(c.value);const m=a.ref(Math.max(t.minHeight,t.height)),P=a.ref(Math.max(t.minWidth,t.width)),r=a.ref(t.minHeight),d=a.ref(t.minWidth),u=a.ref(t.position),v=a.inject("layout"),{useResizeHandleComposition:$}=v,O=X(P,m,d,r,$),{onClickHorizontalResizeBar:w,onClickVerticalResizeBar:z}=O,f=a.computed(()=>({"f-layout-resize-bar":!0,"f-layout-resize-bar-e":u.value==="left","f-layout-resize-bar-n":u.value==="bottom","f-layout-resize-bar-s":u.value==="top","f-layout-resize-bar-w":u.value==="right"}));function h(i,y){(y==="left"||y==="right")&&w(i,y,n.value),(y==="top"||y==="bottom")&&z(i,y,n.value)}const g=a.computed(()=>{const i={"f-layout-pane":!0,"f-page-content-nav":u.value==="left"||u.value==="right","f-page-content-main":u.value==="center"};return t.customClass&&String(t.customClass).split(" ").reduce((y,p)=>(y[p]=!0,y),i),i}),S=a.computed(()=>{const i={flex:"1"};return(P.value&&u.value==="left"||u.value==="right")&&(i.width=`${P.value}px`),(m.value&&u.value==="bottom"||u.value==="top")&&(i.height=`${m.value}px`),i});return()=>a.createVNode("div",{ref:n,class:g.value,style:S.value},[a.createVNode("div",{ref:o,class:"drag-container","data-dragref":`${l.schema.id}-container`},[e.slots.default&&e.slots.default()]),a.createVNode("span",{class:f.value,onMousedown:i=>h(i,u.value)},null)])}});N.install=t=>{t.component(N.name,N),t.component(A.name,A)},N.register=(t,e,n,o)=>{t.layout=N,e.layout=T,t["layout-pane"]=A,e["layout-pane"]=Y},N.registerDesigner=(t,e,n)=>{t.layout=fe,e.layout=T,t["layout-pane"]=ye,e["layout-pane"]=Y},H.FLayout=N,H.FLayoutPane=A,H.default=N,H.layoutProps=D,H.layoutPropsResolver=T,Object.defineProperties(H,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})});
1
+ (function($,a){typeof exports=="object"&&typeof module<"u"?a(exports,require("vue"),require("lodash-es"),require("bignumber.js")):typeof define=="function"&&define.amd?define(["exports","vue","lodash-es","bignumber.js"],a):($=typeof globalThis<"u"?globalThis:$||self,a($.layout={},$.Vue,$.LodashES))})(this,function($,a,H){"use strict";const V={},F={};function N(t){const{properties:e,title:n,ignore:o}=t,l=o&&Array.isArray(o),s=Object.keys(e).reduce((p,v)=>((!l||!o.find(z=>z==v))&&(p[v]=e[v].type==="object"&&e[v].properties?N(e[v]):H.cloneDeep(e[v].default)),p),{});return n&&(!l||!o.find(p=>p=="id"))&&(s.id=`${n}-${Date.now()}`),s}function q(t,e={},n){const o=V[t];if(o){let l=N(o);const s=F[t];return l=s?s({getSchemaByType:q},l,e,n):l,l}return null}function Q(t,e){const n=N(e);return Object.keys(t).reduce((o,l)=>(o[l]&&H.isPlainObject(o[l])&&H.isPlainObject(t[l])?Object.assign(o[l],t[l]):o[l]=t[l],o),n),n}function Z(t,e){return Object.keys(t).filter(o=>t[o]!=null).reduce((o,l)=>{if(e.has(l)){const s=e.get(l);if(typeof s=="string")o[s]=t[l];else{const p=s(l,t[l],t);Object.assign(o,p)}}else o[l]=t[l];return o},{})}function x(t,e,n=new Map){const o=Q(t,e);return Z(o,n)}function K(t={}){function e(r,y,c,b){if(typeof c=="number")return b[r].length===c;if(typeof c=="object"){const P=Object.keys(c)[0],j=c[P];if(P==="not")return Number(b[r].length)!==Number(j);if(P==="moreThan")return Number(b[r].length)>=Number(j);if(P==="lessThan")return Number(b[r].length)<=Number(j)}return!1}function n(r,y,c,b){return b[r]&&b[r].propertyValue&&String(b[r].propertyValue.value)===String(c)}const o=new Map([["length",e],["getProperty",n]]);Object.keys(t).reduce((r,y)=>(r.set(y,t[y]),r),o);function l(r,y){const c=r;return typeof y=="number"?[{target:c,operator:"length",param:null,value:Number(y)}]:typeof y=="boolean"?[{target:c,operator:"getProperty",param:r,value:!!y}]:typeof y=="object"?Object.keys(y).map(b=>{if(b==="length")return{target:c,operator:"length",param:null,value:y[b]};const P=b,j=y[b];return{target:c,operator:"getProperty",param:P,value:j}}):[]}function s(r){return Object.keys(r).reduce((c,b)=>{const P=l(b,r[b]);return c.push(...P),c},[])}function p(r,y){if(o.has(r.operator)){const c=o.get(r.operator);return c&&c(r.target,r.param,r.value,y)||!1}return!1}function v(r,y){return s(r).reduce((P,j)=>P&&p(j,y),!0)}function z(r,y){const c=Object.keys(r),b=c.includes("allOf"),P=c.includes("anyOf"),j=b||P,f=(j?r[j?b?"allOf":"anyOf":"allOf"]:[r]).map(d=>v(d,y));return b?!f.includes(!1):f.includes(!0)}return{parseValueSchema:z}}const R={button:{type:"button",name:"按钮",icon:"Button"},"response-toolbar":{type:"response-toolbar",name:"工具栏",icon:"ButtonGroup"},"response-toolbar-item":{type:"response-toolbar-item",name:"按钮",icon:"Button"},"content-container":{type:"content-container",name:"容器",icon:"ContentContainer"},"input-group":{type:"input-group",name:"文本",icon:"TextBox"},textarea:{type:"textarea",name:"多行文本",icon:"MultiTextBox"},lookup:{type:"lookup",name:"帮助",icon:"LookupEdit"},"number-spinner":{type:"number-spinner",name:"数值",icon:"NumericBox"},"date-picker":{type:"date-picker",name:"日期",icon:"DateBox"},switch:{type:"switch",name:"开关",icon:"SwitchField"},"radio-group":{type:"radio-group",name:"单选组",icon:"RadioGroup"},"check-box":{type:"check-box",name:"复选框",icon:"CheckBox"},"check-group":{type:"check-group",name:"复选框组",icon:"CheckGroup"},"combo-list":{type:"combo-list",name:"下拉列表",icon:"EnumField"},"response-form":{type:"response-form",name:"卡片面板",icon:"Form"},"response-layout":{type:"response-layout",name:"布局容器",icon:"ResponseLayout3"},"response-layout-item":{type:"response-layout-item",name:"布局",icon:"ResponseLayout1"},"tree-grid":{type:"tree-grid",name:"树表格",icon:"TreeGrid"},"tree-grid-column":{type:"tree-grid-column",name:"树表格列"},"data-grid":{type:"data-grid",name:"表格",icon:"DataGrid"},"data-grid-column":{type:"data-grid-column",name:"表格列"},module:{type:"Module",name:"模块",icon:"Module"},component:{type:"component",name:"组件",icon:"Component"},tabs:{type:"tabs",name:"标签页",icon:"Tab"},"tab-page":{type:"tab-page",name:"标签页项",dependentParentControl:"Tab"},"tab-toolbar-item":{type:"tab-toolbar-item",name:"标签页工具栏按钮",icon:"Button"},"time-picker":{type:"time-picker",name:"时间选择",icon:"TimePicker"},section:{type:"section",name:"分组面板",icon:"Section"},"section-toolbar":{type:"section-toolbar",name:"分组面板工具栏"},"section-toolbar-item":{type:"section-toolbar-item",name:"分组面板按钮"},splitter:{type:"splitter",name:"分栏面板",icon:"Splitter"},"splitter-pane":{type:"splitter-pane",name:"分栏面板项",dependentParentControl:"Splitter"},"component-ref":{type:"component-ref",name:"组件引用节点"},uploader:{type:"uploader",name:"附件上传",icon:"FileUpload"},"page-header":{type:"page-header",name:"页头",icon:"Header"},"page-footer":{type:"page-footer",name:"页脚",icon:"ModalFooter"},"tab-toolbar":{type:"tab-toolbar",name:"标签页工具栏",icon:"TabToolbar"},fieldset:{type:"fieldset",name:"分组",icon:"fieldset"}},I={},ee={};K();function W(t,e,n=new Map,o=(p,v,z)=>v,l={},s=p=>p){return V[e.title]=e,F[e.title]=o,I[e.title]=l,ee[e.title]=s,(p={})=>{const v=x(p,e,n),z=Object.keys(t).reduce((r,y)=>(r[y]=t[y].default,r),{});return Object.assign(z,v)}}function te(t,e){return{customClass:e.class,customStyle:e.style}}const G=new Map([["appearance",te]]);function Y(t,e,n){return e}const ne={$schema:"https://json-schema.org/draft/2020-12/schema",$id:"https://farris-design.gitee.io/layout.schema.json",title:"layout",description:"A Farris Container Component",type:"object",properties:{id:{description:"The unique identifier for layout component",type:"string"},type:{description:"The type string of layout component",type:"string",default:"layout"},appearance:{description:"",type:"object",properties:{class:{type:"string"},style:{type:"string"}},default:{}},contents:{description:"",type:"array",default:[]},collapsable:{description:"",type:"boolean",default:!1},resizable:{description:"",type:"boolean",default:!0},visible:{description:"",type:"boolean",default:!0}},required:["id","type","contents"]},oe={title:"layout",description:"A Farris Component",type:"object",categories:{basic:{description:"Basic Infomation",title:"基本信息",properties:{id:{description:"组件标识",title:"标识",type:"string",readonly:!0},type:{description:"类型",title:"类型",type:"string",readonly:!0}}},behavior:{description:"Basic Infomation",title:"行为",properties:{collapsable:{description:"",title:"可收折",type:"boolean"},resizable:{description:"",title:"可调整尺寸",type:"boolean"}}}}},S={customStyle:{type:String,defaut:""},customClass:{type:String,defaut:""}},E=W(S,ne,G,Y,oe);function X(t){const e=a.ref(-1),n=a.ref(-1),o=a.ref(0),l=a.ref(0),s=a.ref(!1),p=a.ref(!1),v=a.computed(()=>({display:s.value?"block":"none",left:`${o.value}px`,cursor:"e-resize"})),z=a.computed(()=>({display:p.value?"block":"none",top:`${l.value}px`,cursor:"n-resize"})),r=a.computed(()=>({display:p.value||s.value?"block":"none"}));function y(g,f,m,d){const O=t.value;if(O){const{left:i,right:u,width:w}=O.getBoundingClientRect();let h=g.clientX-i;d==="right"&&(h=u-g.clientX),h>f&&(h=f),h<m&&(h=m),d==="right"&&(h=w-h),o.value=h}}function c(g,f,m,d){const O=t.value;if(O){const{top:i,bottom:u,height:w}=O.getBoundingClientRect();let h=g.clientY-i;d==="bottom"&&(h=u-g.clientY),h>f&&(h=f),h<m&&(h=m),d==="bottom"&&(h=w-h),l.value=h}}function b(){const g=t.value;if(g){const{width:f,height:m}=g.getBoundingClientRect();return{width:f,height:m}}return null}function P(){const g=t.value;return g?Array.from(g.querySelectorAll("[data-position]")).reduce((f,m)=>{const d=m.getAttribute("data-position");return f=Object.assign(f,{[d]:m}),f},{}):null}function j(g,f){const m=b(),d=P();if(m&&d){const O=d==null?void 0:d.right,i=d==null?void 0:d.left;if(g==="left"&&i)return O?m.width-O.clientWidth-f:m.width-f;if(g==="right"&&O)return i?m.width-i.clientWidth-f:m.width-f}}function C(g,f){const m=b(),d=P();if(m&&d){const O=d==null?void 0:d.bottom,i=d==null?void 0:d.top;if(g==="top"&&i)return O?m.height-O.clientHeight-f:m.height-f;if(g==="bottom"&&O)return i?m.height-i.clientHeight-f:m.height-f}}return{horizontalResizeHandleStyle:v,verticalResizeHandleStyle:z,resizeOverlayStyle:r,showHorizontalResizeHandle:s,showVerticalResizeHandle:p,horizontalResizeBarPosition:e,verticalResizeBarPosition:n,verticalResizeHandleOffset:l,horizontalResizeHandleOffset:o,draggingHorizontalResizeHandle:y,draggingVerticalResizeHandle:c,getPanelMaxHeight:C,getPanelMaxWidth:j}}const ae=["moz","ms","webkit"];function ie(){let t=0;return e=>{const n=new Date().getTime(),o=Math.max(0,16-(n-t)),l=setTimeout(()=>{e(n+o)},o);return t=n+o,l}}function re(){if(typeof window>"u")return()=>0;if(window.requestAnimationFrame)return window.requestAnimationFrame.bind(window);const t=ae.filter(e=>`${e}RequestAnimationFrame`in window)[0];return t?window[`${t}RequestAnimationFrame`]:ie()}re();function le(t,e){return((e==null?void 0:e.split(" "))||[]).reduce((o,l)=>(l&&(o[l]=!0),o),t),t}function se(t,e){return((e==null?void 0:e.split(";"))||[]).reduce((o,l)=>{if(l){const s=l.split(":");o[s[0]]=s[1]}return o},t),t}const k=a.defineComponent({name:"FLayout",props:S,emits:[],setup(t,e){const n=a.ref(),o=X(n),{horizontalResizeHandleStyle:l,verticalResizeHandleStyle:s,resizeOverlayStyle:p}=o;a.provide("layout",{useResizeHandleComposition:o});const v=a.computed(()=>le({"f-layout":!0},t==null?void 0:t.customClass)),z=a.computed(()=>se({},t==null?void 0:t.customStyle));return()=>a.createVNode("div",{class:v.value,style:z.value,ref:n},[e.slots.default&&e.slots.default(),a.createVNode("div",{class:"f-layout-resize-overlay",style:p.value},null),a.createVNode("div",{class:"f-layout-horizontal-resize-proxy",style:l.value},null),a.createVNode("div",{class:"f-layout-vertical-resize-proxy",style:s.value},null)])}}),ce={$schema:"https://json-schema.org/draft/2020-12/schema",$id:"https://farris-design.gitee.io/layout-pane.schema.json",title:"layout-pane",description:"A Farris Container Component",type:"object",properties:{id:{description:"The unique identifier for a layout pane",type:"string"},type:{description:"The type string of layout paney",type:"string",default:"layout-pane"},appearance:{description:"",type:"object",properties:{class:{type:"string"},style:{type:"string"}},default:{}},collapsable:{description:"",type:"boolean",default:!1},contents:{description:"",type:"array",default:[]},height:{description:"",type:"number"},position:{description:"",type:"string",default:"left",enum:["left","center","right","top","bottom"]},resizeable:{description:"",type:"boolean",default:!0},width:{description:"",type:"number"},visible:{description:"",type:"number",default:!0}}},ue={title:"layout-pane",description:"A Farris Container Component",type:"object",categories:{basic:{description:"Basic Infomation",title:"基本信息",properties:{id:{description:"组件标识",title:"标识",type:"string",readonly:!0},type:{description:"组件类型",title:"控件类型",type:"enum"},width:{description:"",type:"number",title:"宽度"},height:{description:"",type:"number",title:"高度"}}},appearance:{title:"样式",description:"Appearance",properties:{class:{title:"class",type:"string",description:""},style:{title:"style",type:"string",description:""}}},behavior:{description:"",title:"行为",properties:{collapsable:{description:"",type:"boolean",title:"允许收折"},position:{description:"",type:"enum",title:"位置",editor:{type:"combo-list",data:[{id:"left",name:"左侧"},{id:"center",name:"居中"},{id:"right",name:"右侧"},{id:"top",name:"顶部"},{id:"bottom",name:"底部"}]}},resizeable:{description:"",type:"boolean",title:"允许调整尺寸"},visible:{description:"运行时组件是否可见",type:"boolean",title:"是否可见"}}}}},A={customClass:{type:String,defaut:""},customStyle:{type:String,defaut:""},width:{type:Number,default:-1},height:{type:Number,default:-1},position:{type:String,default:"left"},visible:{type:Boolean,default:!0},resizable:{type:Boolean,default:!0},collapsable:{type:Boolean,default:!1},minWidth:{type:Number,default:100},minHeight:{type:Number,default:100}},_=W(A,ce,G,Y,ue);function U(t,e,n,o,l){const{horizontalResizeBarPosition:s,horizontalResizeHandleOffset:p,showHorizontalResizeHandle:v,showVerticalResizeHandle:z,verticalResizeBarPosition:r,verticalResizeHandleOffset:y,draggingHorizontalResizeHandle:c,draggingVerticalResizeHandle:b,getPanelMaxHeight:P,getPanelMaxWidth:j}=l;let C="",g,f,m;function d(u){if((C==="left"||C==="right")&&f){const{left:w}=f.getBoundingClientRect(),{width:h}=g.getBoundingClientRect(),T=u.clientX-w;let B=C==="left"?(h||0)+(T-s.value):(h||0)-(T-s.value);B=n.value>0?Math.max(n.value,B):B;const M=j(C,n.value);M!=null&&(B=M>B?B:M),t.value=B}if((C==="top"||C==="bottom")&&f){const{top:w}=f.getBoundingClientRect(),{height:h}=g.getBoundingClientRect(),T=u.clientY-w;let B=C==="top"?(h||0)+(T-r.value):(h||0)-(T-r.value);B=o.value>0?Math.max(o.value,B):B;const M=P(C,o.value);M!=null&&(B=M>B?B:M),e.value=B}p.value=0,y.value=0,s.value=-1,r.value=-1,v.value=!1,z.value=!1,document.removeEventListener("mousemove",m),document.removeEventListener("mouseup",d),document.body.style.userSelect="",C="",g=null,f=null}function O(u,w,h){if(C=w,g=h,v.value=!0,f=u.composedPath().find(B=>(B.className||"").split(" ")[0]==="f-layout"),f){const{left:B}=f.getBoundingClientRect(),M=u.clientX-B;p.value=M,s.value=M;const L=j(C,n.value)||0;m=he=>c(he,L,n.value,C),document.addEventListener("mousemove",m),document.addEventListener("mouseup",d),document.body.style.userSelect="none"}}function i(u,w,h){if(C=w,g=h,z.value=!0,f=u.composedPath().find(B=>(B.className||"").split(" ")[0]==="f-layout"),f){const{top:B}=f.getBoundingClientRect();y.value=u.clientY-B,r.value=u.clientY-B;const M=P(C,o.value)||0;m=L=>b(L,M,o.value,C),document.addEventListener("mousemove",m),document.addEventListener("mouseup",d),document.body.style.userSelect="none"}}return{onClickHorizontalResizeBar:O,onClickVerticalResizeBar:i}}const D=a.defineComponent({name:"FLayoutPane",props:A,emits:[],setup(t,e){const n=a.ref(t.minHeight<=0?100:t.minHeight),o=a.ref(t.minWidth<=0?100:t.minWidth),l=a.ref(t.width<=0?100:t.width),s=a.ref(t.height<=100?100:t.height),p=a.ref(Math.max(n.value,s.value)),v=a.ref(Math.max(o.value,l.value)),z=a.ref(),r=a.ref(t.position),y=a.ref(t.resizable);a.watch(()=>t.resizable,i=>{y.value=i});const c=a.inject("layout"),{useResizeHandleComposition:b}=c,P=U(v,p,o,n,b),{onClickHorizontalResizeBar:j,onClickVerticalResizeBar:C}=P,g=a.computed(()=>({"f-layout-resize-bar":!0,"f-layout-resize-bar-e":r.value==="left","f-layout-resize-bar-n":r.value==="bottom","f-layout-resize-bar-s":r.value==="top","f-layout-resize-bar-w":r.value==="right"})),f=a.computed(()=>r.value!=="center"&&y.value);function m(i,u){(u==="left"||u==="right")&&j(i,u,z.value),(u==="top"||u==="bottom")&&C(i,u,z.value)}const d=a.computed(()=>{const i={"f-layout-pane":!0,"f-page-content-nav":r.value==="left"||r.value==="right","f-page-content-main":r.value==="center"};return t.customClass&&String(t.customClass).split(" ").reduce((u,w)=>(u[w]=!0,u),i),i}),O=a.computed(()=>{const i={};return(v.value&&r.value==="left"||r.value==="right")&&(i.width=`${v.value}px`),(p.value&&r.value==="bottom"||r.value==="top")&&(i.height=`${p.value}px`),t.visible||(i.display="none"),i});return()=>a.createVNode("div",{ref:z,class:d.value,style:O.value,"data-position":r.value},[e.slots.default&&e.slots.default(),f.value&&a.createVNode("span",{class:g.value,onMousedown:i=>m(i,r.value)},null)])}});function pe(t,e){function n(){return!1}return{canAccepts:n}}function J(t,e,n){var O;function o(){n!=null&&n.resolveComponentContext&&n.resolveComponentContext()}o();const l=n&&n.getStyles&&n.getStyles()||"",s=n&&n.getDesignerClass&&n.getDesignerClass()||"",p=a.ref();function v(){return(e==null?void 0:e.schema.componentType)==="frame"?!1:n&&n.checkCanMoveComponent?n.checkCanMoveComponent():!0}function z(){return!1}function r(){return(e==null?void 0:e.schema.componentType)==="frame"?!1:n&&n.checkCanDeleteComponent?n.checkCanDeleteComponent():!0}function y(){return(e==null?void 0:e.schema.componentType)==="frame"?!0:n&&n.hideNestedPaddingInDesginerView?n.hideNestedPaddingInDesginerView():!1}function c(i){if(!i||!i.value)return null;if(i.value.schema&&i.value.schema.type==="component")return i.value;const u=a.ref(i==null?void 0:i.value.parent),w=c(u);return w||null}function b(i=e){const{componentInstance:u,designerItemElementRef:w}=i;return!u||!u.value?null:u.value.canMove?w:b(i.parent)}function P(i){return!!n&&n.canAccepts(i)}function j(){return(e==null?void 0:e.schema.label)||(e==null?void 0:e.schema.title)||(e==null?void 0:e.schema.name)}function C(){}function g(i,u){u&&n!=null&&n.onAcceptMovedChildElement&&n.onAcceptMovedChildElement(u)}function f(i,u){const{componentType:w}=i;let h=q(w,i,u);n&&n.onResolveNewComponentSchema&&(h=n.onResolveNewComponentSchema(i,h));const T=w.toLowerCase().replace("-","_");return h&&!h.id&&h.type===w&&(h.id=`${T}_${Math.random().toString().slice(2,6)}`),h}function m(i){}function d(...i){if(n&&n.getPropsConfig)return n.getPropsConfig(...i)}return p.value={canMove:v(),canSelectParent:z(),canDelete:r(),canNested:!y(),contents:e==null?void 0:e.schema.contents,elementRef:t,parent:(O=e==null?void 0:e.parent)==null?void 0:O.componentInstance,schema:e==null?void 0:e.schema,styles:l,designerClass:s,canAccepts:P,getBelongedComponentInstance:c,getDraggableDesignItemElement:b,getDraggingDisplayText:j,getPropConfig:d,getDragScopeElement:C,onAcceptMovedChildElement:g,onChildElementMovedOut:m,addNewChildComponentSchema:f,updateDragAndDropRules:o,triggerBelongedComponentToMoveWhenMoved:!!n&&n.triggerBelongedComponentToMoveWhenMoved||a.ref(!1),triggerBelongedComponentToDeleteWhenDeleted:!!n&&n.triggerBelongedComponentToDeleteWhenDeleted||a.ref(!1)},p}const fe=a.defineComponent({name:"FLayoutDesign",props:S,emits:[],setup(t,e){var y;const n=a.ref(),o=a.inject("design-item-context"),l=pe(o.schema,(y=o.parent)==null?void 0:y.schema),s=J(n,o,l);s.value.canNested=!1;const p=X(n),{horizontalResizeHandleStyle:v,verticalResizeHandleStyle:z,resizeOverlayStyle:r}=p;return a.provide("layout",{useResizeHandleComposition:p}),a.onMounted(()=>{n.value.componentInstance=s}),e.expose(s.value),()=>a.createVNode("div",{class:"f-layout f-page-content",ref:n},[e.slots.default&&e.slots.default(),a.createVNode("div",{class:"f-layout-resize-overlay",style:r.value},null),a.createVNode("div",{class:"f-layout-horizontal-resize-proxy",style:v.value},null),a.createVNode("div",{class:"f-layout-vertical-resize-proxy",style:z.value},null)])}});function ye(){function t(e,n){var p;if(!e)return!1;const o=((p=e.targetContainer)==null?void 0:p.componentInstance)&&e.targetContainer.componentInstance.value;if(!o)return!1;const l=o.schema.type,s=n==null?void 0:n.formSchemaUtils.getComponentById(o.belongedComponentId);return!((e.controlCategory==="input"||e.controlType==="form-group")&&![R["response-layout-item"].type,R["response-form"].type].includes(l)||(e.controlType===R.tabs.type||e.controlType===R.section.type)&&((s==null?void 0:s.componentType)!=="frame"||![R["content-container"].type,R["splitter-pane"].type,R["response-layout-item"].type].includes(l)))}return{basalDragulaRuleForContainer:t}}function me(t,e){const n=t.schema;function o(s){return!!ye().basalDragulaRuleForContainer(s)}function l(){const s=["f-layout-pane"];return(n.position==="left"||n.position==="right")&&s.push("f-page-content-nav"),n.position==="center"&&s.push("f-page-content-main"),s.join(" ")}return{canAccepts:o,getDesignerClass:l}}const de=a.defineComponent({name:"FLayoutPaneDesign",props:A,emits:[],setup(t,e){const n=a.ref(),o=a.ref();a.inject("designer-host-service");const l=a.inject("design-item-context"),s=me(l),p=J(o,l,s);p.value.canNested=!1,p.value.canMove=!1,p.value.canDelete=!1,a.onMounted(()=>{o.value.componentInstance=p}),e.expose(p.value);const v=a.ref(Math.max(t.minHeight,t.height)),z=a.ref(Math.max(t.minWidth,t.width)),r=a.ref(t.minHeight),y=a.ref(t.minWidth),c=a.ref(t.position),b=a.inject("layout"),{useResizeHandleComposition:P}=b,j=U(z,v,y,r,P),{onClickHorizontalResizeBar:C,onClickVerticalResizeBar:g}=j,f=a.computed(()=>({"f-layout-resize-bar":!0,"f-layout-resize-bar-e":c.value==="left","f-layout-resize-bar-n":c.value==="bottom","f-layout-resize-bar-s":c.value==="top","f-layout-resize-bar-w":c.value==="right"}));function m(i,u){(u==="left"||u==="right")&&C(i,u,n.value),(u==="top"||u==="bottom")&&g(i,u,n.value)}const d=a.computed(()=>{const i={"f-layout-pane":!0,"f-page-content-nav":c.value==="left"||c.value==="right","f-page-content-main":c.value==="center"};return t.customClass&&String(t.customClass).split(" ").reduce((u,w)=>(u[w]=!0,u),i),i}),O=a.computed(()=>{const i={flex:"1"};return(z.value&&c.value==="left"||c.value==="right")&&(i.width=`${z.value}px`),(v.value&&c.value==="bottom"||c.value==="top")&&(i.height=`${v.value}px`),i});return()=>a.createVNode("div",{ref:n,class:d.value,style:O.value},[a.createVNode("div",{ref:o,class:"drag-container","data-dragref":`${l.schema.id}-container`},[e.slots.default&&e.slots.default()]),a.createVNode("span",{class:f.value,onMousedown:i=>m(i,c.value)},null)])}});k.install=t=>{t.component(k.name,k),t.component(D.name,D)},k.register=(t,e,n,o)=>{t.layout=k,e.layout=E,t["layout-pane"]=D,e["layout-pane"]=_},k.registerDesigner=(t,e,n)=>{t.layout=fe,e.layout=E,t["layout-pane"]=de,e["layout-pane"]=_},$.FLayout=k,$.FLayoutPane=D,$.default=k,$.layoutProps=S,$.layoutPropsResolver=E,Object.defineProperties($,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})});