super-page-designer 2.0.9 → 2.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 (205) hide show
  1. package/dist/es/assets/design-attr.css +579 -0
  2. package/dist/es/components/design/utils/assemblys-config.js +85 -55
  3. package/dist/es/components/design/utils/chart-design-util.js +203 -160
  4. package/dist/es/components/design/utils/form-design-util.d.ts +5 -4
  5. package/dist/es/components/design/utils/form-design-util.js +55 -153
  6. package/dist/es/components/design/utils/interfaces/page-design-types.d.ts +0 -1
  7. package/dist/es/components/design/utils/page-design-util.d.ts +2 -1
  8. package/dist/es/components/design/utils/page-design-util.js +8 -2
  9. package/dist/es/components/design/utils/page-service-util.d.ts +15 -0
  10. package/dist/es/components/design/utils/page-service-util.js +5 -0
  11. package/dist/es/components/design/views/assemblys/button/button/button-attr-base.vue.js +20 -3
  12. package/dist/es/components/design/views/assemblys/button/button/button-attr-event.vue.js +6 -3
  13. package/dist/es/components/design/views/assemblys/button/button/button-attr.vue.js +1 -1
  14. package/dist/es/components/design/views/assemblys/button/button-group/buttongroup-attr.vue.js +1 -1
  15. package/dist/es/components/design/views/assemblys/button/component/journal-set-dialog.css +4 -0
  16. package/dist/es/components/design/views/assemblys/button/component/journal-set-dialog.vue.js +1 -1
  17. package/dist/es/components/design/views/assemblys/button/dropdown/dropdown-attr.vue.js +1 -1
  18. package/dist/es/components/design/views/assemblys/chart/column-line/column-line-attr-base.vue.js +6 -3
  19. package/dist/es/components/design/views/assemblys/chart/column-line/column-line-attr-style.vue.js +1 -1
  20. package/dist/es/components/design/views/assemblys/chart/column-line/column-line-design.vue2.js +7 -3
  21. package/dist/es/components/design/views/assemblys/chart/column-line/series/column-line-series-attr-base.vue.js +3 -1
  22. package/dist/es/components/design/views/assemblys/chart/column-line/series/column-line-series-attr-style.vue.js +4 -1
  23. package/dist/es/components/design/views/assemblys/chart/common/common-attr-data.vue.js +68 -3
  24. package/dist/es/components/design/views/assemblys/chart/common/common-attr-groupby.vue.js +94 -16
  25. package/dist/es/components/design/views/assemblys/chart/common/common-attr-serieslist.vue.js +12 -6
  26. package/dist/es/components/design/views/assemblys/chart/common/common-attr-sortby.vue.js +30 -13
  27. package/dist/es/components/design/views/assemblys/chart/common-series/common-attr-dataset-columnline.vue.js +21 -3
  28. package/dist/es/components/design/views/assemblys/chart/common-series/common-attr-dynamic.vue.js +12 -66
  29. package/dist/es/components/design/views/assemblys/chart/gauge/gauge-attr-base.vue.js +20 -12
  30. package/dist/es/components/design/views/assemblys/chart/gauge/gauge-attr-data.vue.js +318 -0
  31. package/dist/es/components/design/views/assemblys/chart/gauge/gauge-attr-data.vue2.js +4 -0
  32. package/dist/es/components/design/views/assemblys/chart/gauge/gauge-attr-style.vue.js +5 -2
  33. package/dist/es/components/design/views/assemblys/chart/gauge/gauge-design.vue2.js +34 -15
  34. package/dist/es/components/design/views/assemblys/chart/gauge/series/gauge-series-attr-base.vue.js +4 -19
  35. package/dist/es/components/design/views/assemblys/chart/gauge/series/gauge-series-attr-style.vue.js +5 -2
  36. package/dist/es/components/design/views/assemblys/chart/pie/pie-attr-base.vue.js +18 -5
  37. package/dist/es/components/design/views/assemblys/chart/pie/pie-attr-style.vue.js +5 -2
  38. package/dist/es/components/design/views/assemblys/chart/pie/pie-design.vue2.js +34 -16
  39. package/dist/es/components/design/views/assemblys/chart/pie/series/pie-series-attr-base.vue.js +4 -22
  40. package/dist/es/components/design/views/assemblys/chart/pie/series/pie-series-attr-style.vue.js +4 -1
  41. package/dist/es/components/design/views/assemblys/chart/radar/radar-attr-base.vue.js +23 -9
  42. package/dist/es/components/design/views/assemblys/chart/radar/radar-attr-data.vue.js +318 -0
  43. package/dist/es/components/design/views/assemblys/chart/radar/radar-attr-data.vue2.js +4 -0
  44. package/dist/es/components/design/views/assemblys/chart/radar/radar-attr-style.vue.js +25 -12
  45. package/dist/es/components/design/views/assemblys/chart/radar/radar-design.vue2.js +37 -13
  46. package/dist/es/components/design/views/assemblys/chart/radar/series/series-attr-base.vue.js +4 -17
  47. package/dist/es/components/design/views/assemblys/chart/radar/series/series-attr-dataset.vue.js +82 -256
  48. package/dist/es/components/design/views/assemblys/chart/radar/series/series-attr-style.vue.js +12 -17
  49. package/dist/es/components/design/views/assemblys/chart/scatter/scatter-attr-base.vue.js +23 -13
  50. package/dist/es/components/design/views/assemblys/chart/scatter/scatter-attr-data.vue.js +205 -0
  51. package/dist/es/components/design/views/assemblys/chart/scatter/scatter-attr-data.vue2.js +4 -0
  52. package/dist/es/components/design/views/assemblys/chart/scatter/scatter-attr-style.vue.js +5 -7
  53. package/dist/es/components/design/views/assemblys/chart/scatter/scatter-design.vue2.js +35 -12
  54. package/dist/es/components/design/views/assemblys/chart/scatter/series/scatter-series-attr-base.vue.js +6 -77
  55. package/dist/es/components/design/views/assemblys/chart/scatter/series/scatter-series-attr-style.vue.js +4 -1
  56. package/dist/es/components/design/views/assemblys/chart/scatter/series/scatter-series-data.vue.js +191 -0
  57. package/dist/es/components/design/views/assemblys/chart/scatter/series/scatter-series-data.vue2.js +4 -0
  58. package/dist/es/components/design/views/assemblys/common/common-variable-bind.css +4 -0
  59. package/dist/es/components/design/views/assemblys/common/common-variable-bind.vue.js +1 -1
  60. package/dist/es/components/design/views/assemblys/common/state-button.css +8 -0
  61. package/dist/es/components/design/views/assemblys/common/state-button.vue.js +1 -1
  62. package/dist/es/components/design/views/assemblys/container/tabs/tabs-attr-event.vue.js +30 -0
  63. package/dist/es/components/design/views/assemblys/container/tabs/tabs-attr-event.vue2.js +4 -0
  64. package/dist/es/components/design/views/assemblys/container/tabs/tabs-attr.vue2.js +2 -1
  65. package/dist/es/components/design/views/assemblys/data/bar-code/barcode-attr-base.vue.js +1 -1
  66. package/dist/es/components/design/views/assemblys/data/bar-code/barcode-attr.vue.js +1 -1
  67. package/dist/es/components/design/views/assemblys/data/component/attr-header.css +38 -0
  68. package/dist/es/components/design/views/assemblys/data/component/attr-header.vue.js +1 -1
  69. package/dist/es/components/design/views/assemblys/data/component/attr-style.vue.js +1 -1
  70. package/dist/es/components/design/views/assemblys/data/component/composite-header.css +37 -0
  71. package/dist/es/components/design/views/assemblys/data/component/composite-header.vue.js +1 -1
  72. package/dist/es/components/design/views/assemblys/data/component/data-origin-tree.css +4 -0
  73. package/dist/es/components/design/views/assemblys/data/component/data-origin-tree.vue.js +1 -1
  74. package/dist/es/components/design/views/assemblys/data/component/data-origin-tree.vue2.js +1 -1
  75. package/dist/es/components/design/views/assemblys/data/component/data-origin.css +5 -0
  76. package/dist/es/components/design/views/assemblys/data/component/data-origin.vue.js +1 -1
  77. package/dist/es/components/design/views/assemblys/data/component/querySetting.vue.js +2 -2
  78. package/dist/es/components/design/views/assemblys/data/component/row-backgroud-color.css +9 -0
  79. package/dist/es/components/design/views/assemblys/data/component/row-backgroud-color.vue.js +1 -1
  80. package/dist/es/components/design/views/assemblys/data/table/table-attr.vue.js +1 -1
  81. package/dist/es/components/design/views/assemblys/data/table/table-design.css +18 -0
  82. package/dist/es/components/design/views/assemblys/data/table/table-design.vue.js +2 -2
  83. package/dist/es/components/design/views/assemblys/data/table/table-design2.css +32 -0
  84. package/dist/es/components/design/views/assemblys/data/table/tablecolumn-attr-base.vue.js +1 -1
  85. package/dist/es/components/design/views/assemblys/data/table/tablecolumn-attr-style.vue.js +1 -1
  86. package/dist/es/components/design/views/assemblys/data/tree/tree-attr-base.vue.js +2 -2
  87. package/dist/es/components/design/views/assemblys/data/tree/tree-attr-style.vue.js +2 -2
  88. package/dist/es/components/design/views/assemblys/data/tree/tree-attr.vue.js +1 -1
  89. package/dist/es/components/design/views/assemblys/form/checkbox/checkbox-attr.vue.js +1 -1
  90. package/dist/es/components/design/views/assemblys/form/common/attr-event.css +7 -0
  91. package/dist/es/components/design/views/assemblys/form/common/attr-event.vue.js +1 -1
  92. package/dist/es/components/design/views/assemblys/form/common/attr-header.css +26 -0
  93. package/dist/es/components/design/views/assemblys/form/common/attr-header.vue.js +1 -1
  94. package/dist/es/components/design/views/assemblys/form/common/data-format.vue.js +1 -1
  95. package/dist/es/components/design/views/assemblys/form/common/data-origin.css +5 -0
  96. package/dist/es/components/design/views/assemblys/form/common/data-origin.vue.js +1 -1
  97. package/dist/es/components/design/views/assemblys/form/common/dimension-input.css +4 -0
  98. package/dist/es/components/design/views/assemblys/form/common/dimension-input.vue.js +75 -1
  99. package/dist/es/components/design/views/assemblys/form/common/dimension-input.vue3.js +2 -2
  100. package/dist/es/components/design/views/assemblys/form/common/icon-set-dialog.css +37 -0
  101. package/dist/es/components/design/views/assemblys/form/common/icon-set-dialog.vue.js +1 -1
  102. package/dist/es/components/design/views/assemblys/form/common/parameter-table.vue.js +186 -0
  103. package/dist/es/components/design/views/assemblys/form/common/parameter-table.vue2.js +4 -0
  104. package/dist/es/components/design/views/assemblys/form/common/suffixmodule.vue.js +28 -4
  105. package/dist/es/components/design/views/assemblys/form/custom/custom-attr-base.vue.js +11 -169
  106. package/dist/es/components/design/views/assemblys/form/custom/custom-attr.vue.js +1 -1
  107. package/dist/es/components/design/views/assemblys/form/custom/custom-design.css +4 -0
  108. package/dist/es/components/design/views/assemblys/form/custom/custom-design.vue.js +2 -2
  109. package/dist/es/components/design/views/assemblys/form/custom/custom-design.vue2.js +3 -12
  110. package/dist/es/components/design/views/assemblys/form/date-picker/datepicker-attr.vue.js +1 -1
  111. package/dist/es/components/design/views/assemblys/form/dept-tree/depttree-attr.vue.js +1 -1
  112. package/dist/es/components/design/views/assemblys/form/divider/divider-attr.vue.js +1 -1
  113. package/dist/es/components/design/views/assemblys/form/file-upload/fileupload-attr.vue.js +1 -1
  114. package/dist/es/components/design/views/assemblys/form/input-number/input-number-attr.vue.js +1 -1
  115. package/dist/es/components/design/views/assemblys/form/input-text/inputtext-attr-base.vue.js +33 -10
  116. package/dist/es/components/design/views/assemblys/form/input-text/inputtext-attr.css +565 -0
  117. package/dist/es/components/design/views/assemblys/form/input-text/inputtext-attr.vue.js +1 -1
  118. package/dist/es/components/design/views/assemblys/form/input-text/inputtext-attr.vue2.js +10 -1
  119. package/dist/es/components/design/views/assemblys/form/label/label-attr.vue.js +1 -1
  120. package/dist/es/components/design/views/assemblys/form/link/link-attr-base.vue.js +15 -3
  121. package/dist/es/components/design/views/assemblys/form/placeholder/placeholder-attr.vue.js +1 -1
  122. package/dist/es/components/design/views/assemblys/form/radio/radio-attr.vue.js +1 -1
  123. package/dist/es/components/design/views/assemblys/form/select/select-attr.vue.js +1 -1
  124. package/dist/es/components/design/views/assemblys/form/switch/switch-attr.vue.js +1 -1
  125. package/dist/es/components/design/views/assemblys/form/tag/tag-attr.vue.js +1 -1
  126. package/dist/es/components/design/views/assemblys/form/textarea/textarea-attr.vue.js +1 -1
  127. package/dist/es/components/design/views/assemblys/object-design.vue.js +52 -77
  128. package/dist/es/components/design/views/assemblys/page/component/setting-form-rule-base-input.vue.d.ts +2 -2
  129. package/dist/es/components/design/views/assemblys/workflow/picture-flow/pictureflow-attr-base.vue.js +1 -1
  130. package/dist/es/components/design/views/assemblys/workflow/picture-flow/pictureflow-attr.vue.js +1 -1
  131. package/dist/es/components/design/views/assemblys/workflow/text-history/texthistory-attr-base.vue.js +1 -1
  132. package/dist/es/components/design/views/assemblys/workflow/text-history/texthistory-attr.vue.js +1 -1
  133. package/dist/es/components/design/views/assemblys/workflow/workflow-button/workflowbutton-attr.vue.js +1 -1
  134. package/dist/es/components/design/views/design/page-design.vue.d.ts +13 -1
  135. package/dist/es/components/design/views/design/page-design.vue.js +218 -100
  136. package/dist/es/components/design/views/design/page-event/config.css +13 -0
  137. package/dist/es/components/design/views/design/page-event/config.vue.js +1 -1
  138. package/dist/es/components/design/views/design/page-event/page-event-content.css +4 -0
  139. package/dist/es/components/design/views/design/page-event/page-event-content.vue.js +2 -2
  140. package/dist/es/components/design/views/design/page-event/page-event-content.vue2.js +19 -9
  141. package/dist/es/components/design/views/design/view/page-switch.css +17 -0
  142. package/dist/es/components/design/views/design/view/page-switch.vue.d.ts +18 -0
  143. package/dist/es/components/design/views/design/view/page-switch.vue.js +7 -0
  144. package/dist/es/components/design/views/design/view/page-switch.vue2.js +185 -0
  145. package/dist/es/components/design/views/design/view/view-design-display.vue.js +1 -1
  146. package/dist/es/components/design/views/design/view/view-design-preview.vue.js +2 -2
  147. package/dist/es/components/design/views/design/view/view-design.vue.js +7 -9
  148. package/dist/es/index.js +1 -1
  149. package/package.json +7 -6
  150. package/dist/es/assets/design-attr.css.js +0 -1
  151. package/dist/es/components/design/views/assemblys/button/button/button-attr.vue3.js +0 -1
  152. package/dist/es/components/design/views/assemblys/button/button-group/buttongroup-attr.vue3.js +0 -1
  153. package/dist/es/components/design/views/assemblys/button/component/journal-set-dialog.vue3.js +0 -1
  154. package/dist/es/components/design/views/assemblys/button/dropdown/dropdown-attr.vue3.js +0 -1
  155. package/dist/es/components/design/views/assemblys/chart/common/common-attr-drill.vue.js +0 -108
  156. package/dist/es/components/design/views/assemblys/chart/common/common-attr-drill.vue2.js +0 -4
  157. package/dist/es/components/design/views/assemblys/chart/common-series/common-attr-dataset.vue.js +0 -166
  158. package/dist/es/components/design/views/assemblys/chart/common-series/common-attr-dataset.vue2.js +0 -4
  159. package/dist/es/components/design/views/assemblys/chart/gauge/series/gauge-series-attr-dataset.vue.js +0 -153
  160. package/dist/es/components/design/views/assemblys/chart/gauge/series/gauge-series-attr-dataset.vue2.js +0 -4
  161. package/dist/es/components/design/views/assemblys/chart/radar/series/attrs/attr-testdatas.vue.js +0 -58
  162. package/dist/es/components/design/views/assemblys/chart/radar/series/attrs/attr-testdatas.vue2.js +0 -4
  163. package/dist/es/components/design/views/assemblys/common/common-variable-bind.vue3.js +0 -1
  164. package/dist/es/components/design/views/assemblys/common/state-button.vue3.js +0 -1
  165. package/dist/es/components/design/views/assemblys/data/bar-code/barcode-attr.vue3.js +0 -1
  166. package/dist/es/components/design/views/assemblys/data/component/attr-header.vue3.js +0 -1
  167. package/dist/es/components/design/views/assemblys/data/component/composite-header.vue3.js +0 -1
  168. package/dist/es/components/design/views/assemblys/data/component/data-origin-tree.vue3.js +0 -1
  169. package/dist/es/components/design/views/assemblys/data/component/data-origin.vue3.js +0 -1
  170. package/dist/es/components/design/views/assemblys/data/component/row-backgroud-color.vue3.js +0 -1
  171. package/dist/es/components/design/views/assemblys/data/table/table-attr.vue3.js +0 -1
  172. package/dist/es/components/design/views/assemblys/data/table/table-design.vue3.js +0 -1
  173. package/dist/es/components/design/views/assemblys/data/table/table-design.vue4.js +0 -1
  174. package/dist/es/components/design/views/assemblys/data/tree/tree-attr.vue3.js +0 -1
  175. package/dist/es/components/design/views/assemblys/form/checkbox/checkbox-attr.vue3.js +0 -1
  176. package/dist/es/components/design/views/assemblys/form/common/attr-event.vue3.js +0 -1
  177. package/dist/es/components/design/views/assemblys/form/common/attr-header.vue3.js +0 -1
  178. package/dist/es/components/design/views/assemblys/form/common/data-origin.vue3.js +0 -1
  179. package/dist/es/components/design/views/assemblys/form/common/dimension-input.vue2.js +0 -75
  180. package/dist/es/components/design/views/assemblys/form/common/icon-set-dialog.vue3.js +0 -1
  181. package/dist/es/components/design/views/assemblys/form/common/linkpage-params-in.vue.js +0 -154
  182. package/dist/es/components/design/views/assemblys/form/common/linkpage-params-in.vue2.js +0 -4
  183. package/dist/es/components/design/views/assemblys/form/common/title.vue.js +0 -45
  184. package/dist/es/components/design/views/assemblys/form/common/title.vue2.js +0 -4
  185. package/dist/es/components/design/views/assemblys/form/custom/custom-attr.vue3.js +0 -1
  186. package/dist/es/components/design/views/assemblys/form/custom/custom-design.vue3.js +0 -1
  187. package/dist/es/components/design/views/assemblys/form/date-picker/datepicker-attr.vue3.js +0 -1
  188. package/dist/es/components/design/views/assemblys/form/dept-tree/depttree-attr.vue3.js +0 -1
  189. package/dist/es/components/design/views/assemblys/form/divider/divider-attr.vue3.js +0 -1
  190. package/dist/es/components/design/views/assemblys/form/file-upload/fileupload-attr.vue3.js +0 -1
  191. package/dist/es/components/design/views/assemblys/form/input-number/input-number-attr.vue3.js +0 -1
  192. package/dist/es/components/design/views/assemblys/form/input-text/inputtext-attr.vue3.js +0 -1
  193. package/dist/es/components/design/views/assemblys/form/label/label-attr.vue3.js +0 -1
  194. package/dist/es/components/design/views/assemblys/form/placeholder/placeholder-attr.vue3.js +0 -1
  195. package/dist/es/components/design/views/assemblys/form/radio/radio-attr.vue3.js +0 -1
  196. package/dist/es/components/design/views/assemblys/form/select/select-attr.vue3.js +0 -1
  197. package/dist/es/components/design/views/assemblys/form/switch/switch-attr.vue3.js +0 -1
  198. package/dist/es/components/design/views/assemblys/form/tag/tag-attr.vue3.js +0 -1
  199. package/dist/es/components/design/views/assemblys/form/textarea/textarea-attr.vue3.js +0 -1
  200. package/dist/es/components/design/views/assemblys/workflow/picture-flow/pictureflow-attr.vue3.js +0 -1
  201. package/dist/es/components/design/views/assemblys/workflow/text-history/texthistory-attr.vue3.js +0 -1
  202. package/dist/es/components/design/views/assemblys/workflow/workflow-button/workflowbutton-attr.vue3.js +0 -1
  203. package/dist/es/components/design/views/design/page-event/config.vue3.js +0 -1
  204. package/dist/es/components/design/views/design/page-event/page-event-content.vue3.js +0 -1
  205. package/dist/es/style.css +0 -14198
@@ -1,8 +1,10 @@
1
- import { defineComponent, ref, watch, openBlock, createElementBlock, normalizeStyle, normalizeClass, withModifiers, createVNode, unref, withDirectives, createElementVNode, Fragment, renderList, toDisplayString, vShow } from "vue";
1
+ import { defineComponent, ref, watch, onUnmounted, openBlock, createElementBlock, normalizeStyle, normalizeClass, withModifiers, withDirectives, createVNode, vShow, unref, createElementVNode, Fragment, renderList, toDisplayString } from "vue";
2
2
  import { caculateComponentStyle } from "../../../../utils/container-design-util.js";
3
- import { generateChartOption } from "../../../../utils/chart-design-util.js";
3
+ import { removComponentDataConfig, generateChartHeader, generateChartOption, initComponentDataConfig } from "../../../../utils/chart-design-util.js";
4
+ import { getUuidv4 } from "../../../../utils/common-util.js";
4
5
  import { getCustomTheme } from "super-page-runtime";
5
- import _sfc_main$1 from "./series/series-attr.vue.js";
6
+ import _sfc_main$2 from "./series/series-attr.vue.js";
7
+ import _sfc_main$1 from "../common/common-chart-header.vue.js";
6
8
  import { use } from "echarts/core";
7
9
  import { CanvasRenderer } from "echarts/renderers";
8
10
  import { RadarChart } from "echarts/charts";
@@ -13,12 +15,10 @@ const _hoisted_2 = ["onClick"];
13
15
  const _sfc_main = /* @__PURE__ */ defineComponent({
14
16
  __name: "radar-design",
15
17
  props: {
16
- configure: {
17
- type: Object,
18
- required: true
19
- },
20
- indexObj: Object,
21
- selectWidget: Object
18
+ pageDesign: {},
19
+ configure: {},
20
+ indexObj: {},
21
+ selectWidget: {}
22
22
  },
23
23
  emits: ["onSelectWidget", "onCustomAttrWidget"],
24
24
  setup(__props, { emit: __emit }) {
@@ -32,10 +32,13 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
32
32
  }
33
33
  if (props.configure.items.length == 0) {
34
34
  props.configure.items.push({
35
+ uuid: getUuidv4(),
36
+ name: "",
35
37
  index: 1,
36
38
  type: "radar",
39
+ label: "数据1",
37
40
  props: {
38
- title: "系列1"
41
+ title: "数据1"
39
42
  },
40
43
  style: {}
41
44
  });
@@ -47,6 +50,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
47
50
  const designClass = ref("");
48
51
  const customTheme = ref(null);
49
52
  const chartOption = ref({});
53
+ const headerInfo = ref({});
50
54
  watch(
51
55
  props.configure.style,
52
56
  () => {
@@ -55,21 +59,36 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
55
59
  },
56
60
  { immediate: true }
57
61
  );
62
+ function updateDataConfig() {
63
+ const dataConfig = initComponentDataConfig(props.configure, headerInfo.value);
64
+ props.configure.runtime.dataConfig = dataConfig;
65
+ }
58
66
  watch(props.configure.props, () => {
59
67
  customChartOption();
68
+ updateDataConfig();
60
69
  });
61
70
  watch(props.configure.items, () => {
62
71
  customChartOption();
63
72
  });
73
+ setTimeout(() => {
74
+ updateDataConfig();
75
+ }, 100);
76
+ onUnmounted(() => {
77
+ removComponentDataConfig(props.configure);
78
+ });
64
79
  function customCaculateStyle() {
65
80
  caculateComponentStyle(props.configure, designStyle, designClass, null);
66
81
  props.configure.runtime.style = designStyle.value;
67
82
  props.configure.runtime.class = designClass.value;
83
+ headerInfo.value = generateChartHeader(props.configure);
84
+ props.configure.runtime.headerInfo = headerInfo.value;
68
85
  }
69
86
  function customChartOption() {
70
87
  generateChartOption(props.configure, chartOption);
88
+ headerInfo.value = generateChartHeader(props.configure);
71
89
  customTheme.value = getCustomTheme(props.configure.props.customTheme);
72
90
  props.configure.runtime.chartOption = chartOption.value;
91
+ props.configure.runtime.headerInfo = headerInfo.value;
73
92
  }
74
93
  if (props.selectWidget) {
75
94
  watch(props.selectWidget, () => {
@@ -102,8 +121,10 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
102
121
  break;
103
122
  }
104
123
  }
124
+ selItem.serviceFields = props.configure.serviceFields;
125
+ selItem.serviceDataField = props.configure.serviceDataField;
105
126
  selItem.selected = true;
106
- $emits("onCustomAttrWidget", selItem, _sfc_main$1);
127
+ $emits("onCustomAttrWidget", selItem, _sfc_main$2);
107
128
  }
108
129
  const $emits = __emit;
109
130
  return (_ctx, _cache) => {
@@ -113,6 +134,9 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
113
134
  onClick: withModifiers(selectParent, ["stop"]),
114
135
  ref: "thisRef"
115
136
  }, [
137
+ withDirectives(createVNode(_sfc_main$1, { headerInfo: headerInfo.value }, null, 8, ["headerInfo"]), [
138
+ [vShow, headerInfo.value.showHeader]
139
+ ]),
116
140
  createVNode(unref(VChart), {
117
141
  ref: "chartRef",
118
142
  theme: customTheme.value,
@@ -120,14 +144,14 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
120
144
  autoresize: ""
121
145
  }, null, 8, ["theme", "option"]),
122
146
  withDirectives(createElementVNode("div", _hoisted_1, [
123
- (openBlock(true), createElementBlock(Fragment, null, renderList(__props.configure.items, (item, itemIndex) => {
147
+ (openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.configure.items, (item, itemIndex) => {
124
148
  return openBlock(), createElementBlock("label", {
125
149
  class: normalizeClass([[item.selected ? "amb-design-chart-series-selected" : ""], "amb-design-chart-series"]),
126
150
  onClick: withModifiers(($event) => selectSeries($event, itemIndex), ["stop"])
127
151
  }, toDisplayString(item.props.title), 11, _hoisted_2);
128
152
  }), 256))
129
153
  ], 512), [
130
- [vShow, __props.configure.componentIndex == __props.selectWidget.value]
154
+ [vShow, _ctx.configure.componentIndex == _ctx.selectWidget.value]
131
155
  ])
132
156
  ], 6);
133
157
  };
@@ -1,6 +1,6 @@
1
1
  import { defineComponent, ref, resolveComponent, openBlock, createBlock, withCtx, createVNode, createElementVNode } from "vue";
2
2
  import _sfc_main$1 from "./series-attr-dataset.vue.js";
3
- import _sfc_main$2 from "./attrs/attr-testdatas.vue.js";
3
+ import _sfc_main$2 from "../../common-series/common-attr-testdatas.vue.js";
4
4
  const _hoisted_1 = { style: { "padding": "8px 0px 0px 0px" } };
5
5
  const _sfc_main = /* @__PURE__ */ defineComponent({
6
6
  __name: "series-attr-base",
@@ -25,7 +25,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
25
25
  default: withCtx(() => [
26
26
  createVNode(_component_el_collapse, {
27
27
  modelValue: openCollapseItems.value,
28
- "onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => openCollapseItems.value = $event),
28
+ "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => openCollapseItems.value = $event),
29
29
  style: { "margin-top": "6px" }
30
30
  }, {
31
31
  default: withCtx(() => [
@@ -37,8 +37,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
37
37
  default: withCtx(() => [
38
38
  createElementVNode("div", _hoisted_1, [
39
39
  createVNode(_component_el_form_item, {
40
- label: "系列名称",
41
- style: { "margin-top": "4px" }
40
+ label: "数据名称",
41
+ style: { "margin-top": "4px", "margin-bottom": "-15px" }
42
42
  }, {
43
43
  default: withCtx(() => [
44
44
  createVNode(_component_el_input, {
@@ -48,19 +48,6 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
48
48
  }, null, 8, ["modelValue"])
49
49
  ]),
50
50
  _: 1
51
- }),
52
- createVNode(_component_el_form_item, {
53
- label: "副标题",
54
- style: { "margin-top": "-10px", "margin-bottom": "-15px" }
55
- }, {
56
- default: withCtx(() => [
57
- createVNode(_component_el_input, {
58
- modelValue: __props.configure.props.subTitle,
59
- "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => __props.configure.props.subTitle = $event),
60
- placeholder: "请输入"
61
- }, null, 8, ["modelValue"])
62
- ]),
63
- _: 1
64
51
  })
65
52
  ])
66
53
  ]),
@@ -1,7 +1,7 @@
1
- import { defineComponent, resolveComponent, openBlock, createBlock, withCtx, createElementVNode, createVNode, unref, createTextVNode } from "vue";
2
- import { Search, Plus } from "@element-plus/icons-vue";
1
+ import { defineComponent, ref, resolveComponent, openBlock, createBlock, withCtx, createElementVNode, createVNode, createTextVNode, createElementBlock, Fragment, renderList, toDisplayString } from "vue";
3
2
  const _hoisted_1 = { style: { "padding": "8px 0px 0px 0px" } };
4
- const _hoisted_2 = { style: { "text-align": "center", "margin": "0px -8px", "padding-top": "4px", "padding-left": "2px" } };
3
+ const _hoisted_2 = { style: { "float": "left" } };
4
+ const _hoisted_3 = { style: { "float": "right", "color": "var(--el-text-color-secondary)", "font-size": "13px" } };
5
5
  const _sfc_main = /* @__PURE__ */ defineComponent({
6
6
  __name: "series-attr-dataset",
7
7
  props: {
@@ -11,21 +11,45 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
11
11
  }
12
12
  },
13
13
  setup(__props) {
14
+ const props = __props;
15
+ const sourceFields = ref([]);
16
+ let hisServiceFields = null;
17
+ let hisServiceDataField = null;
18
+ function updateBindFields() {
19
+ if (props.configure.serviceFields == hisServiceFields && props.configure.serviceDataField == hisServiceDataField) {
20
+ return;
21
+ }
22
+ hisServiceFields = props.configure.serviceFields;
23
+ hisServiceDataField = props.configure.serviceDataField;
24
+ const newFields = [];
25
+ if (hisServiceFields) {
26
+ const prevField = hisServiceDataField ? hisServiceDataField : "";
27
+ for (let f of hisServiceFields) {
28
+ if (!(!f.type || f.type == "any" || f.type == "number")) {
29
+ continue;
30
+ }
31
+ if (!prevField || f.value.startsWith(prevField + ".")) {
32
+ const tempField = {};
33
+ Object.assign(tempField, f);
34
+ if (prevField) {
35
+ const newValue = f.value.substring(prevField.length + 1);
36
+ tempField.value = newValue;
37
+ if (f.label) {
38
+ tempField.label = f.label.replace(prevField + ".", "");
39
+ }
40
+ }
41
+ newFields.push(tempField);
42
+ }
43
+ }
44
+ }
45
+ sourceFields.value = newFields;
46
+ }
47
+ updateBindFields();
14
48
  return (_ctx, _cache) => {
15
- const _component_el_button = resolveComponent("el-button");
16
- const _component_el_input = resolveComponent("el-input");
17
- const _component_el_form_item = resolveComponent("el-form-item");
49
+ const _component_el_radio = resolveComponent("el-radio");
18
50
  const _component_el_option = resolveComponent("el-option");
19
51
  const _component_el_select = resolveComponent("el-select");
20
- const _component_el_text = resolveComponent("el-text");
21
- const _component_el_divider = resolveComponent("el-divider");
22
- const _component_Top = resolveComponent("Top");
23
- const _component_el_icon = resolveComponent("el-icon");
24
- const _component_Bottom = resolveComponent("Bottom");
25
- const _component_el_table_column = resolveComponent("el-table-column");
26
- const _component_Delete = resolveComponent("Delete");
27
- const _component_el_table = resolveComponent("el-table");
28
- const _component_el_radio = resolveComponent("el-radio");
52
+ const _component_el_form_item = resolveComponent("el-form-item");
29
53
  const _component_el_input_number = resolveComponent("el-input-number");
30
54
  const _component_el_radio_group = resolveComponent("el-radio-group");
31
55
  const _component_el_collapse_item = resolveComponent("el-collapse-item");
@@ -36,269 +60,71 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
36
60
  }, {
37
61
  default: withCtx(() => [
38
62
  createElementVNode("div", _hoisted_1, [
39
- createVNode(_component_el_form_item, {
40
- label: "数据源",
41
- style: { "margin-top": "4px" }
42
- }, {
43
- default: withCtx(() => [
44
- createVNode(_component_el_input, {
45
- modelValue: __props.configure.props.serviceName,
46
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => __props.configure.props.serviceName = $event),
47
- readonly: ""
48
- }, {
49
- append: withCtx(() => [
50
- createVNode(_component_el_button, { icon: unref(Search) }, null, 8, ["icon"]),
51
- createVNode(_component_el_button, { icon: unref(Plus) }, null, 8, ["icon"])
52
- ]),
53
- _: 1
54
- }, 8, ["modelValue"])
55
- ]),
56
- _: 1
57
- }),
58
- createVNode(_component_el_form_item, {
59
- label: "数据集",
60
- style: { "margin-top": "-5px" }
61
- }, {
62
- default: withCtx(() => [
63
- createVNode(_component_el_select, {
64
- modelValue: __props.configure.props.datasField,
65
- "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => __props.configure.props.datasField = $event),
66
- placeholder: "根目录",
67
- clearable: ""
68
- }, {
69
- default: withCtx(() => [
70
- createVNode(_component_el_option, {
71
- label: "data",
72
- value: "root"
73
- })
74
- ]),
75
- _: 1
76
- }, 8, ["modelValue"]),
77
- createVNode(_component_el_text, {
78
- type: "success",
79
- size: "small"
80
- }, {
81
- default: withCtx(() => [
82
- createTextVNode("默认为根目录")
83
- ]),
84
- _: 1
85
- })
86
- ]),
87
- _: 1
88
- }),
89
- createVNode(_component_el_form_item, {
90
- label: "配置项字段",
91
- style: { "margin-top": "-10px" }
63
+ createVNode(_component_el_radio_group, {
64
+ modelValue: __props.configure.props.yaxisSource,
65
+ "onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => __props.configure.props.yaxisSource = $event)
92
66
  }, {
93
67
  default: withCtx(() => [
94
- createVNode(_component_el_select, {
95
- modelValue: __props.configure.props.xaxisField,
96
- "onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => __props.configure.props.xaxisField = $event),
97
- placeholder: "请选择",
98
- multiple: "",
99
- "collapse-tags": "",
100
- clearable: ""
101
- }, {
102
- default: withCtx(() => [
103
- createVNode(_component_el_option, {
104
- label: "field1",
105
- value: "root"
68
+ createVNode(_component_el_form_item, { style: { "margin-top": "4px" } }, {
69
+ label: withCtx(() => [
70
+ createVNode(_component_el_radio, { value: "variable" }, {
71
+ default: withCtx(() => [
72
+ createTextVNode("数据字段")
73
+ ]),
74
+ _: 1
106
75
  })
107
76
  ]),
108
- _: 1
109
- }, 8, ["modelValue"]),
110
- createVNode(_component_el_text, {
111
- type: "success",
112
- size: "small"
113
- }, {
114
77
  default: withCtx(() => [
115
- createTextVNode("默认为选择的维度字段,可为空")
116
- ]),
117
- _: 1
118
- })
119
- ]),
120
- _: 1
121
- }),
122
- createVNode(_component_el_divider, null, {
123
- default: withCtx(() => [
124
- createTextVNode(" 数据项 ")
125
- ]),
126
- _: 1
127
- }),
128
- createVNode(_component_el_table, {
129
- data: __props.configure.props.yaxisFields,
130
- style: { "width": "100%" }
131
- }, {
132
- default: withCtx(() => [
133
- createVNode(_component_el_table_column, {
134
- label: "",
135
- width: "32"
136
- }, {
137
- default: withCtx((scope) => [
138
- createElementVNode("div", _hoisted_2, [
139
- createVNode(_component_el_icon, {
140
- size: "14",
141
- style: { "cursor": "pointer" },
142
- onClick: ($event) => _ctx.moveTop(scope.row)
143
- }, {
144
- default: withCtx(() => [
145
- createVNode(_component_Top)
146
- ]),
147
- _: 2
148
- }, 1032, ["onClick"]),
149
- createVNode(_component_el_icon, {
150
- size: "14",
151
- style: { "margin-left": "2px", "cursor": "pointer" },
152
- onClick: ($event) => _ctx.moveToBottom(scope.row)
153
- }, {
154
- default: withCtx(() => [
155
- createVNode(_component_Bottom)
156
- ]),
157
- _: 2
158
- }, 1032, ["onClick"])
159
- ])
160
- ]),
161
- _: 1
162
- }),
163
- createVNode(_component_el_table_column, {
164
- prop: "label",
165
- label: "名称",
166
- width: "100"
167
- }, {
168
- default: withCtx((scope) => [
169
- createVNode(_component_el_input, {
170
- modelValue: scope.row.name,
171
- "onUpdate:modelValue": ($event) => scope.row.name = $event,
172
- size: "small"
173
- }, null, 8, ["modelValue", "onUpdate:modelValue"])
174
- ]),
175
- _: 1
176
- }),
177
- createVNode(_component_el_table_column, {
178
- prop: "label",
179
- label: "字段",
180
- width: "58"
181
- }, {
182
- default: withCtx((scope) => [
183
78
  createVNode(_component_el_select, {
79
+ size: "small",
80
+ disabled: __props.configure.props.yaxisSource == "fix",
184
81
  modelValue: __props.configure.props.yaxisField,
185
- "onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => __props.configure.props.yaxisField = $event),
186
- placeholder: "请选择",
187
- multiple: "",
188
- "collapse-tags": "",
189
- clearable: ""
82
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => __props.configure.props.yaxisField = $event),
83
+ title: __props.configure.props.yaxisField,
84
+ style: { "width": "160px" },
85
+ filterable: "",
86
+ "allow-create": "",
87
+ clearable: "",
88
+ placeholder: "请选择"
190
89
  }, {
191
90
  default: withCtx(() => [
192
- createVNode(_component_el_option, {
193
- label: "field1",
194
- value: "root"
195
- })
91
+ (openBlock(true), createElementBlock(Fragment, null, renderList(sourceFields.value, (item) => {
92
+ return openBlock(), createBlock(_component_el_option, {
93
+ key: item.value,
94
+ label: item.label,
95
+ value: item.value
96
+ }, {
97
+ default: withCtx(() => [
98
+ createElementVNode("span", _hoisted_2, toDisplayString(item.label), 1),
99
+ createElementVNode("span", _hoisted_3, toDisplayString(item.type), 1)
100
+ ]),
101
+ _: 2
102
+ }, 1032, ["label", "value"]);
103
+ }), 128))
196
104
  ]),
197
105
  _: 1
198
- }, 8, ["modelValue"])
106
+ }, 8, ["disabled", "modelValue", "title"])
199
107
  ]),
200
108
  _: 1
201
109
  }),
202
- createVNode(_component_el_table_column, {
203
- label: "操作",
204
- width: "60"
205
- }, {
206
- default: withCtx((scope) => [
207
- createVNode(_component_el_icon, {
208
- size: "14",
209
- style: { "color": "#5893EF", "cursor": "pointer", "font-weight": "bold", "margin-right": "8px" },
210
- onClick: ($event) => _ctx.addColor(scope.row)
211
- }, {
212
- default: withCtx(() => [
213
- createVNode(unref(Plus))
214
- ]),
215
- _: 2
216
- }, 1032, ["onClick"]),
217
- createVNode(_component_el_icon, {
218
- size: "14",
219
- style: { "color": "#5893EF", "cursor": "pointer" },
220
- onClick: ($event) => _ctx.deleteColor(scope.row)
221
- }, {
222
- default: withCtx(() => [
223
- createVNode(_component_Delete)
224
- ]),
225
- _: 2
226
- }, 1032, ["onClick"])
227
- ]),
228
- _: 1
229
- })
230
- ]),
231
- _: 1
232
- }, 8, ["data"]),
233
- createVNode(_component_el_text, {
234
- style: { "line-height": "15px" },
235
- type: "success",
236
- size: "small"
237
- }, {
238
- default: withCtx(() => [
239
- createTextVNode("选择比较的数值字段,为空时为默认字段")
240
- ]),
241
- _: 1
242
- }),
243
- createVNode(_component_el_radio_group, {
244
- modelValue: __props.configure.props.maxValueSource,
245
- "onUpdate:modelValue": _cache[6] || (_cache[6] = ($event) => __props.configure.props.maxValueSource = $event)
246
- }, {
247
- default: withCtx(() => [
248
- createVNode(_component_el_form_item, { style: { "margin-top": "-10px" } }, {
110
+ createVNode(_component_el_form_item, { style: { "margin-top": "-10px", "margin-bottom": "-15px" } }, {
249
111
  label: withCtx(() => [
250
- createVNode(_component_el_radio, { value: "fix" }, {
112
+ createVNode(_component_el_radio, { value: "fixed" }, {
251
113
  default: withCtx(() => [
252
- createTextVNode("最大值")
114
+ createTextVNode("固定值   ")
253
115
  ]),
254
116
  _: 1
255
117
  })
256
118
  ]),
257
119
  default: withCtx(() => [
258
120
  createVNode(_component_el_input_number, {
259
- modelValue: __props.configure.style.maxValueFixed,
260
- "onUpdate:modelValue": _cache[4] || (_cache[4] = ($event) => __props.configure.style.maxValueFixed = $event),
261
- disabled: __props.configure.props.maxValueSource != "fix"
262
- }, null, 8, ["modelValue", "disabled"])
263
- ]),
264
- _: 1
265
- }),
266
- createVNode(_component_el_form_item, { style: { "margin-top": "-10px" } }, {
267
- label: withCtx(() => [
268
- createVNode(_component_el_radio, { value: "field" }, {
269
- default: withCtx(() => [
270
- createTextVNode("最大值字段")
271
- ]),
272
- _: 1
273
- })
274
- ]),
275
- default: withCtx(() => [
276
- createVNode(_component_el_select, {
277
- modelValue: __props.configure.props.maxValueField,
278
- "onUpdate:modelValue": _cache[5] || (_cache[5] = ($event) => __props.configure.props.maxValueField = $event),
279
- disabled: __props.configure.props.maxValueSource != "field",
280
- placeholder: "请选择",
281
- multiple: "",
282
- "collapse-tags": "",
283
- clearable: ""
284
- }, {
285
- default: withCtx(() => [
286
- createVNode(_component_el_option, {
287
- label: "field1",
288
- value: "root"
289
- })
290
- ]),
291
- _: 1
292
- }, 8, ["modelValue", "disabled"]),
293
- createVNode(_component_el_text, {
294
- type: "success",
295
- size: "small"
296
- }, {
297
- default: withCtx(() => [
298
- createTextVNode("指示器的最大值字段,可为空")
299
- ]),
300
- _: 1
301
- })
121
+ disabled: __props.configure.props.yaxisSource != "fixed",
122
+ placeholder: "请输入",
123
+ modelValue: __props.configure.props.yaxisFix,
124
+ "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => __props.configure.props.yaxisFix = $event),
125
+ min: 1,
126
+ preision: "2"
127
+ }, null, 8, ["disabled", "modelValue"])
302
128
  ]),
303
129
  _: 1
304
130
  })
@@ -1,14 +1,9 @@
1
1
  import { defineComponent, ref, resolveComponent, openBlock, createBlock, withCtx, createVNode, withDirectives, vShow } from "vue";
2
2
  import _sfc_main$1 from "../../common/common-style-font-subtitle.vue.js";
3
- import _sfc_main$3 from "./styles/style-axisname.vue.js";
4
- import _sfc_main$2 from "./styles/style-radar.vue.js";
5
- import _sfc_main$4 from "./styles/style-datalabel.vue.js";
6
- import _sfc_main$5 from "./styles/style-dataline.vue.js";
7
- import _sfc_main$7 from "./styles/style-axis.vue.js";
8
- import _sfc_main$8 from "./styles/style-split.vue.js";
9
- import _sfc_main$9 from "./styles/style-splitarea.vue.js";
10
- import _sfc_main$6 from "./styles/style-dataarea.vue.js";
11
- import _sfc_main$a from "../../common/common-style-custom.vue.js";
3
+ import _sfc_main$2 from "./styles/style-datalabel.vue.js";
4
+ import _sfc_main$3 from "./styles/style-dataline.vue.js";
5
+ import _sfc_main$4 from "./styles/style-dataarea.vue.js";
6
+ import _sfc_main$5 from "../../common/common-style-custom.vue.js";
12
7
  const _sfc_main = /* @__PURE__ */ defineComponent({
13
8
  __name: "series-attr-style",
14
9
  props: {
@@ -18,11 +13,15 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
18
13
  }
19
14
  },
20
15
  setup(__props) {
21
- const openCollapseItems = ref([]);
16
+ const openCollapseItems = ref(["styleDataLabel"]);
22
17
  return (_ctx, _cache) => {
18
+ const _component_commonStyleAxis = resolveComponent("commonStyleAxis");
23
19
  const _component_el_collapse = resolveComponent("el-collapse");
24
20
  const _component_el_form = resolveComponent("el-form");
25
- return openBlock(), createBlock(_component_el_form, { "label-width": "80px" }, {
21
+ return openBlock(), createBlock(_component_el_form, {
22
+ "label-width": "80px",
23
+ size: "small"
24
+ }, {
26
25
  default: withCtx(() => [
27
26
  createVNode(_component_el_collapse, {
28
27
  modelValue: openCollapseItems.value,
@@ -39,12 +38,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
39
38
  createVNode(_sfc_main$2, { configure: __props.configure }, null, 8, ["configure"]),
40
39
  createVNode(_sfc_main$3, { configure: __props.configure }, null, 8, ["configure"]),
41
40
  createVNode(_sfc_main$4, { configure: __props.configure }, null, 8, ["configure"]),
42
- createVNode(_sfc_main$5, { configure: __props.configure }, null, 8, ["configure"]),
43
- createVNode(_sfc_main$6, { configure: __props.configure }, null, 8, ["configure"]),
44
- createVNode(_sfc_main$7, { configure: __props.configure }, null, 8, ["configure"]),
45
- createVNode(_sfc_main$8, { configure: __props.configure }, null, 8, ["configure"]),
46
- createVNode(_sfc_main$9, { configure: __props.configure }, null, 8, ["configure"]),
47
- createVNode(_sfc_main$a, { configure: __props.configure }, null, 8, ["configure"])
41
+ createVNode(_component_commonStyleAxis, { configure: __props.configure }, null, 8, ["configure"]),
42
+ createVNode(_sfc_main$5, { configure: __props.configure }, null, 8, ["configure"])
48
43
  ]),
49
44
  _: 1
50
45
  }, 8, ["modelValue"])