st-comp 0.0.148 → 0.0.150

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 (150) hide show
  1. package/components.d.ts +3 -0
  2. package/es/ChartLayout.cjs +1 -1
  3. package/es/ChartLayout.js +5 -4
  4. package/es/Dialog.cjs +1 -1
  5. package/es/Dialog.js +28 -24
  6. package/es/FactorWarning.cjs +1 -1
  7. package/es/FactorWarning.js +577 -631
  8. package/es/Kline.cjs +1 -0
  9. package/es/Kline.js +1903 -0
  10. package/es/KlineBasic.cjs +1 -1
  11. package/es/KlineBasic.js +677 -1428
  12. package/es/KlineNew.cjs +1 -3
  13. package/es/KlineNew.js +316 -2740
  14. package/es/Pagination.cjs +1 -1
  15. package/es/Pagination.js +60 -58
  16. package/es/PasswordPrompt.cjs +1 -0
  17. package/es/PasswordPrompt.js +13 -0
  18. package/es/Table.cjs +1 -1
  19. package/es/Table.js +102 -98
  20. package/es/User.cjs +1 -1
  21. package/es/User.js +397 -373
  22. package/es/VarietySearch.cjs +1 -1
  23. package/es/VarietySearch.js +2395 -1
  24. package/es/VirtualTable.cjs +5 -5
  25. package/es/VirtualTable.js +154 -151
  26. package/es/_initCloneObject-47814efa.cjs +1 -0
  27. package/es/{_initCloneObject-ec5c9523.js → _initCloneObject-e3d8a9ab.js} +13 -13
  28. package/es/base-0ca7c43a.cjs +5 -0
  29. package/es/base-19787dfb.js +303 -0
  30. package/es/{castArray-c770910d.js → castArray-8405000b.js} +1 -1
  31. package/es/castArray-a78ae889.cjs +1 -0
  32. package/es/{config-provider-feed0e8a.js → config-provider-0f6672af.js} +3 -3
  33. package/es/{config-provider-c87e277f.cjs → config-provider-cfbb9cd8.cjs} +1 -1
  34. package/es/{debounce-c64fb3b5.js → debounce-6cb0781f.js} +29 -29
  35. package/es/debounce-cf26af24.cjs +1 -0
  36. package/es/{dropdown-c9272ca3.js → dropdown-17b3ef6a.js} +4 -4
  37. package/es/{dropdown-6bdb3cf4.cjs → dropdown-790d31ea.cjs} +1 -1
  38. package/es/el-button-0bf1d532.js +236 -0
  39. package/es/el-button-62966947.cjs +1 -0
  40. package/es/el-checkbox-group-45247bbf.cjs +1 -0
  41. package/es/el-checkbox-group-d53bc316.js +67 -0
  42. package/es/el-empty-2ece1134.cjs +1 -0
  43. package/es/{el-empty-89a523ed.js → el-empty-bd5343a7.js} +10 -9
  44. package/es/{el-form-item-55d36086.js → el-form-item-05c0e335.js} +82 -81
  45. package/es/el-form-item-47e255d4.cjs +12 -0
  46. package/es/{el-input-cb528574.js → el-input-1e309239.js} +46 -45
  47. package/es/el-input-6a3805c5.cjs +1 -0
  48. package/es/{el-input-number-ce30bfa8.js → el-input-number-60ebc58f.js} +50 -48
  49. package/es/el-input-number-96ff2e47.cjs +1 -0
  50. package/es/el-menu-item-4c9eb7ad.cjs +1 -0
  51. package/es/el-menu-item-6c6236a1.js +772 -0
  52. package/es/{el-message-d51d032b.js → el-message-7d927756.js} +56 -55
  53. package/es/el-message-d5ed7a4f.cjs +1 -0
  54. package/es/el-overlay-26bf0945.js +521 -0
  55. package/es/el-overlay-41994f67.cjs +1 -0
  56. package/es/el-popover-17e2e66c.js +140 -0
  57. package/es/el-popover-7bd8a7c3.cjs +1 -0
  58. package/es/el-popper-7adbf1c6.cjs +1 -0
  59. package/es/{el-popper-f4b01f85.js → el-popper-b6527ae2.js} +217 -216
  60. package/es/{el-scrollbar-e8e93751.js → el-scrollbar-29bcab5f.js} +22 -22
  61. package/es/el-scrollbar-ac525239.cjs +1 -0
  62. package/es/el-select-31f8ac8a.cjs +1 -0
  63. package/es/{el-select-e71af2e6.js → el-select-7395562b.js} +42 -40
  64. package/es/el-table-column-47d80736.js +3804 -0
  65. package/es/el-table-column-bdc46568.cjs +14 -0
  66. package/es/{el-tag-d65768f4.js → el-tag-7414e0c7.js} +59 -58
  67. package/es/el-tag-9732314f.cjs +1 -0
  68. package/es/{index-da646183.cjs → index-1d85ba4b.cjs} +1 -1
  69. package/es/{index-92ba4292.js → index-273822d1.js} +26 -25
  70. package/es/index-2f958e56.cjs +3 -0
  71. package/es/index-375e8de4.cjs +5 -0
  72. package/es/{index-121e2861.js → index-621b092b.js} +3 -3
  73. package/es/index-657047bb.js +513 -0
  74. package/es/{index-18416440.cjs → index-65b4113e.cjs} +1 -1
  75. package/es/index-70372cdb.js +519 -0
  76. package/es/{use-form-common-props-4d37077d.js → index-72151b24.js} +151 -312
  77. package/es/index-9e6e8d03.cjs +1 -0
  78. package/es/index-ab96bbf4.js +156 -0
  79. package/es/index-afc88a4b.cjs +1 -0
  80. package/es/index-c066fe0d.js +82 -0
  81. package/es/index-ce3223db.cjs +1 -0
  82. package/es/{index-709675d5.js → index-dc22ffe4.js} +18 -18
  83. package/es/index-eea0bcb3.cjs +1 -0
  84. package/es/index.esm-8d9a2abe.js +2432 -0
  85. package/es/index.esm-94a95a2a.cjs +3 -0
  86. package/es/{raf-f55e0daa.js → raf-a532c514.js} +1 -1
  87. package/es/{raf-2d77cbbe.cjs → raf-f46caea0.cjs} +1 -1
  88. package/es/{scroll-c8ac196e.cjs → scroll-339681d4.cjs} +1 -1
  89. package/es/{scroll-ca84f80a.js → scroll-d787d648.js} +1 -1
  90. package/es/style.css +1 -1
  91. package/es/use-form-common-props-5ff2f51b.js +171 -0
  92. package/es/use-form-common-props-74a96df2.cjs +2 -0
  93. package/es/vnode-6a0c7411.js +14 -0
  94. package/es/vnode-b15eb11b.cjs +1 -0
  95. package/es/{zh-cn-414d7f0c.cjs → zh-cn-36f34912.cjs} +1 -1
  96. package/es/{zh-cn-23c8e0d1.js → zh-cn-f37255ae.js} +2 -2
  97. package/lib/bundle.js +1 -1
  98. package/lib/bundle.umd.cjs +206 -206
  99. package/lib/{index-ffeb163e.js → index-d0cb2fa2.js} +33754 -31705
  100. package/lib/{python-0ec8f68c.js → python-050ba5a4.js} +1 -1
  101. package/lib/style.css +1 -1
  102. package/package.json +1 -1
  103. package/packages/Kline/components/Contextmenu/index.vue +110 -0
  104. package/packages/Kline/components/Tips/index.vue +40 -0
  105. package/packages/Kline/componentsNew/KlineSlide/index.vue +155 -0
  106. package/packages/Kline/componentsNew/KlineSub/index.vue +297 -0
  107. package/packages/Kline/componentsNew/KlineTips/index.vue +66 -0
  108. package/packages/Kline/componentsNew/KlineUtils/index.vue +84 -0
  109. package/packages/Kline/componentsNew/Tips/index.vue +33 -0
  110. package/packages/Kline/formatKlineData.ts +109 -0
  111. package/packages/Kline/images/buy.svg +1 -0
  112. package/packages/Kline/images/pen.png +0 -0
  113. package/packages/Kline/images/sell.svg +1 -0
  114. package/packages/Kline/images/t.svg +1 -0
  115. package/packages/Kline/index.ts +16 -0
  116. package/packages/Kline/index.vue +891 -0
  117. package/packages/Kline/option.ts +539 -0
  118. package/packages/Kline/type.d.ts +219 -0
  119. package/packages/Kline/utils.ts +682 -0
  120. package/packages/PasswordPrompt/index.ts +8 -0
  121. package/packages/PasswordPrompt/index.vue +266 -0
  122. package/packages/User/index.vue +97 -58
  123. package/packages/index.ts +4 -0
  124. package/src/pages/Kline/index.vue +12 -0
  125. package/src/pages/PasswordPrompt/index.vue +12 -0
  126. package/src/router/routes.ts +10 -0
  127. package/es/_initCloneObject-476b02ce.cjs +0 -1
  128. package/es/base-6ccc8fc2.cjs +0 -9
  129. package/es/base-950bac7e.js +0 -816
  130. package/es/castArray-374558a5.cjs +0 -1
  131. package/es/debounce-a6b4f91b.cjs +0 -1
  132. package/es/el-button-b8f71c7d.cjs +0 -1
  133. package/es/el-button-d7b6eebd.js +0 -745
  134. package/es/el-empty-12eece57.cjs +0 -1
  135. package/es/el-form-item-ebbf096d.cjs +0 -12
  136. package/es/el-input-2c7e70a3.cjs +0 -1
  137. package/es/el-input-number-8e168e83.cjs +0 -1
  138. package/es/el-message-612c2346.cjs +0 -1
  139. package/es/el-overlay-07414277.js +0 -526
  140. package/es/el-overlay-fb255b83.cjs +0 -1
  141. package/es/el-popper-8360bd91.cjs +0 -1
  142. package/es/el-scrollbar-271142ad.cjs +0 -1
  143. package/es/el-select-2e71d4af.cjs +0 -1
  144. package/es/el-table-column-9fe79f05.cjs +0 -14
  145. package/es/el-table-column-dc562f14.js +0 -3933
  146. package/es/el-tag-930e7b32.cjs +0 -1
  147. package/es/index-0ed86daf.cjs +0 -3
  148. package/es/index-674d2fd7.cjs +0 -1
  149. package/es/index-aece600c.js +0 -81
  150. package/es/use-form-common-props-c1960844.cjs +0 -2
package/es/Kline.js ADDED
@@ -0,0 +1,1903 @@
1
+ import "./base-19787dfb.js";
2
+ import { E as he, a as Ce } from "./el-menu-item-6c6236a1.js";
3
+ import "./el-tooltip-4ed993c7.js";
4
+ import "./el-popper-b6527ae2.js";
5
+ import { defineComponent as Me, openBlock as C, createElementBlock as v, createElementVNode as K, Fragment as ae, renderList as le, normalizeStyle as ye, toDisplayString as q, ref as S, renderSlot as De, createCommentVNode as xe, nextTick as Ye, computed as W, watch as H, onMounted as de, onUnmounted as ge, createVNode as V, withCtx as X, createBlock as Ae, createTextVNode as Oe, normalizeClass as ke } from "vue";
6
+ import * as oe from "echarts";
7
+ import { _ as $ } from "./_plugin-vue_export-helper-dad06003.js";
8
+ import { x as re } from "./index-8542fe24.js";
9
+ import { i as ve, t as be } from "./index.esm-8d9a2abe.js";
10
+ import "./el-tag-7414e0c7.js";
11
+ import { E as Ee, a as Se } from "./el-select-7395562b.js";
12
+ import "./el-scrollbar-29bcab5f.js";
13
+ import "./index-72151b24.js";
14
+ import "./index-621b092b.js";
15
+ import "./index-657047bb.js";
16
+ import "./use-form-common-props-5ff2f51b.js";
17
+ import "./index-70372cdb.js";
18
+ import "./typescript-7ae59c4c.js";
19
+ import "./vnode-6a0c7411.js";
20
+ import "./index-273822d1.js";
21
+ import "./castArray-8405000b.js";
22
+ import "./index-dc22ffe4.js";
23
+ import "./scroll-d787d648.js";
24
+ import "./debounce-6cb0781f.js";
25
+ const Fe = { class: "st-kline-tips" }, Qe = { class: "st-kline-tips-row" }, _e = /* @__PURE__ */ Me({
26
+ __name: "index",
27
+ props: {
28
+ // 提示数据
29
+ data: {
30
+ type: Array,
31
+ default: () => []
32
+ }
33
+ },
34
+ setup(a) {
35
+ return (t, i) => (C(), v("div", Fe, [
36
+ K("div", Qe, [
37
+ (C(!0), v(ae, null, le(a.data, (e) => (C(), v("div", {
38
+ class: "st-kline-tips-row-item",
39
+ style: ye({ color: e.color })
40
+ }, q(e.label) + " " + q(e.value), 5))), 256))
41
+ ])
42
+ ]));
43
+ }
44
+ });
45
+ const se = /* @__PURE__ */ $(_e, [["__scopeId", "data-v-78aed210"]]), Ue = /* @__PURE__ */ Me({
46
+ __name: "index",
47
+ emits: ["closeContextMenuCallBack"],
48
+ setup(a, { emit: t }) {
49
+ const i = t, e = S(), n = S(), o = S({
50
+ display: "none",
51
+ top: "0px",
52
+ left: "0px"
53
+ }), z = () => {
54
+ o.value.display = "none", i("closeContextMenuCallBack"), document.removeEventListener("click", z);
55
+ }, s = (l) => {
56
+ if (l.preventDefault(), l.stopPropagation(), o.value.display === "block") {
57
+ const { offsetX: r, offsetY: j } = l, { offsetWidth: D, offsetHeight: c } = n.value;
58
+ if (r <= D && j <= c)
59
+ return;
60
+ }
61
+ e.value.click(), o.value = {
62
+ display: "block",
63
+ top: `${l.offsetY}px`,
64
+ left: `${l.offsetX}px`
65
+ }, Ye(() => {
66
+ const { bottom: r, height: j, right: D, width: c } = n.value.getBoundingClientRect();
67
+ r > window.innerHeight ? o.value = {
68
+ display: "block",
69
+ top: `${l.offsetY - j}px`,
70
+ left: `${l.offsetX}px`
71
+ } : D > window.innerWidth && (o.value = {
72
+ display: "block",
73
+ top: `${l.offsetY}px`,
74
+ left: `${l.offsetX - c}px`
75
+ });
76
+ }), document.addEventListener("click", z);
77
+ };
78
+ return (l, r) => (C(), v("div", {
79
+ ref_key: "contextmenuRef",
80
+ ref: e,
81
+ class: "contextmenu",
82
+ onContextmenu: s,
83
+ onMouseleave: z
84
+ }, [
85
+ De(l.$slots, "default", {}, void 0, !0),
86
+ o.value.display !== "none" ? (C(), v("div", {
87
+ key: 0,
88
+ ref_key: "contextmenuContentRef",
89
+ ref: n,
90
+ class: "contextmenu-popover",
91
+ style: ye(o.value)
92
+ }, [
93
+ De(l.$slots, "popover", {}, void 0, !0)
94
+ ], 4)) : xe("", !0)
95
+ ], 544));
96
+ }
97
+ });
98
+ const Re = /* @__PURE__ */ $(Ue, [["__scopeId", "data-v-249fd104"]]);
99
+ let Ie = !1, Le = !0, pe = [];
100
+ const fe = (a) => {
101
+ const t = [], i = [], e = [], n = [], o = [], z = [];
102
+ return a.forEach((s, l) => {
103
+ t.push(s[0]), i.push(s[1]), e.push(s[4]), n.push(s[2]), o.push(s[3]), z.push([s[1], s[4], s[3], s[2], Number(s[6]), l === 0 ? s[4] : a[l - 1][4]]);
104
+ }), { time: t, open: i, close: e, high: n, low: o, kLineData: z };
105
+ }, Be = async () => {
106
+ if (!Ie)
107
+ Ie = !0, await ve("./talib.wasm"), Le = !1, pe.forEach((a) => {
108
+ a();
109
+ });
110
+ else if (Le)
111
+ return new Promise((a) => {
112
+ pe.push(a);
113
+ });
114
+ }, ne = (a, t) => a.length > t ? a.slice(a.length - t) : a, Ve = (a, t, i) => a.calculationFn ? a.calculationFn(be, t, i) : new Array(t.time.length).fill(null), Pe = async (a, t, i) => {
115
+ const e = fe(a);
116
+ let n = [];
117
+ return n = fe(n), await Be(), {
118
+ originData: ne(a, i),
119
+ kLine: ne(e.kLineData, i),
120
+ time: ne(e.time, i),
121
+ indicator: t.config.reduce((o, z) => (o.push({
122
+ key: z.key,
123
+ color: z.color,
124
+ data: ne(Ve(z, e, n), i)
125
+ }), o), [])
126
+ };
127
+ }, ce = "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/PjwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+PHN2ZyB0PSIxNjgzNzAzMjM4NzI1IiBjbGFzcz0iaWNvbiIgdmlld0JveD0iMCAwIDEwMjQgMTAyNCIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHAtaWQ9IjI2MjUiIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB3aWR0aD0iMjAwIiBoZWlnaHQ9IjIwMCI+PHBhdGggZD0iTTE5OC4wMTYgMTA5LjczODY2N0E3Ny44NjY2NjcgNzcuODY2NjY3IDAgMCAwIDE3MC42NjY2NjcgMTY3LjY4bDAuNTEyIDQxOC45NDRjMCAyMi44NjkzMzMgNi40IDQ4IDE5LjAyOTMzMyA3NS4zMDY2NjcgMTIuNjcyIDI3LjIyMTMzMyAyNy45ODkzMzMgNDguOTM4NjY3IDQ1Ljk1MiA2NC45Mzg2NjZsMjExLjE1NzMzMyAxODguMjAyNjY3YzE3LjA2NjY2NyAxNS40ODggNDAuNTc2IDIzLjk3ODY2NyA2NC45Mzg2NjcgMjMuNTk0NjY3IDI1LjY4NTMzMy0wLjA4NTMzMyA0Ny4zNi03LjkzNiA2NC45ODEzMzMtMjMuNTk0NjY3bDIxMS4yLTE4OC4yMDI2NjdjMTcuOTItMTYgMzMuMTk0NjY3LTM3LjYzMiA0NS44NjY2NjctNjQuOTM4NjY2IDEyLjY3Mi0yNy4zMDY2NjcgMTguNzczMzMzLTUyLjIyNCAxOC41MTczMzMtNzQuOTIyNjY3TDg1My4zMzMzMzMgMTY3LjI1MzMzM2MwLTIyLjI3Mi04Ljk2LTQxLjQ3Mi0yNi44MzczMzMtNTcuNDcyLTE3LjU3ODY2Ny0xNS42MTYtMzkuMzM4NjY3LTIzLjg5MzMzMy02NC45Mzg2NjctMjQuNDA1MzMzbC00OTkuMDI5MzMzIDAuNDY5MzMzYTkzLjMxMiA5My4zMTIgMCAwIDAtNjQuNTEyIDIzLjg5MzMzNHoiIGZpbGw9IiNGRjAwMDAiIHAtaWQ9IjI2MjYiPjwvcGF0aD48cGF0aCBkPSJNMTcwLjcwOTMzMyAxNjcuNzIyNjY3YzAuMTI4LTIxLjc2IDkuOTg0LTQyLjY2NjY2NyAyNy4zOTItNTcuOTQxMzM0YTkzLjMxMiA5My4zMTIgMCAwIDEgNjQuNDY5MzM0LTIzLjg5MzMzM0w3NjEuNiA4NS4zMzMzMzNjMjUuNiAwLjU1NDY2NyA0Ny4zNiA4Ljc4OTMzMyA2NC45Mzg2NjcgMjQuNDA1MzM0IDE3LjkyIDE2IDI2Ljg4IDM1LjIgMjYuODggNTcuNDcybC0wLjU1NDY2NyA0MTkuODRjMC4yOTg2NjcgMjIuNjk4NjY3LTUuODQ1MzMzIDQ3LjYxNi0xOC41MTczMzMgNzQuOTIyNjY2LTEyLjYyOTMzMyAyNy4zMDY2NjctMjcuOTQ2NjY3IDQ4Ljg5Ni00NS44MjQgNjQuODk2bC0yMTEuMjQyNjY3IDE4OC4yMDI2NjdjLTE3LjU3ODY2NyAxNS43MDEzMzMtMzkuMjUzMzMzIDIzLjUwOTMzMy02NC45Mzg2NjcgMjMuNTk0NjY3YTk0LjcyIDk0LjcyIDAgMCAxLTY0Ljk4MTMzMy0yMy41OTQ2NjdsLTIxMS4xNTczMzMtMTg4LjE2Yy0xNy45Mi0xNi4wNDI2NjctMzMuMjgtMzcuNzE3MzMzLTQ1LjkwOTMzNC02NC45ODEzMzMtMTIuNjcyLTI3LjMwNjY2Ny0xOS4wMjkzMzMtNTIuMzk0NjY3LTE5LjAyOTMzMy03NS4zMDY2NjdMMTcwLjY2NjY2NyAxNjcuNzIyNjY3eiBtNDIuNjY2NjY3IDAuMjU2bDAuNTU0NjY3IDQxOC42ODhjMCAxNi4yMTMzMzMgNC44MjEzMzMgMzUuMzI4IDE1LjAxODY2NiA1Ny4zNDQgMTAuMzY4IDIyLjI3MiAyMi4zNTczMzMgMzkuMjEwNjY3IDM1LjYyNjY2NyA1MS4wNzJsMjExLjQxMzMzMyAxODguNDE2YzguOTYgOC4xMDY2NjcgMjEuODg4IDEyLjggMzYuMjI0IDEyLjU0NCAxNS41MzA2NjctMC4wNDI2NjcgMjcuMDkzMzMzLTQuMjY2NjY3IDM2LjY5MzMzNC0xMi44bDIxMS4xNTczMzMtMTg4LjExNzMzNGMxMy4zMTItMTEuOTQ2NjY3IDI1LjMwMTMzMy0yOC44NDI2NjcgMzUuNTg0LTUxLjA3MiAxMC4xMTItMjEuODQ1MzMzIDE0Ljc2MjY2Ny00MC41NzYgMTQuNTA2NjY3LTU3LjA0NTMzM2wwLjU1NDY2Ni00MTkuNzU0NjY3YzAtOS44OTg2NjctMy41ODQtMTcuNjIxMzMzLTEyLjQ1ODY2Ni0yNS42YTU0LjY5ODY2NyA1NC42OTg2NjcgMCAwIDAtMzYuNjA4LTEzLjYxMDY2NmwtNDk5LjYyNjY2NyAwLjQ2OTMzM2E1MS4zMjggNTEuMzI4IDAgMCAwLTM1Ljc1NDY2NyAxMy4zMTIgMzYuNTY1MzMzIDM2LjU2NTMzMyAwIDAgMC0xMi41MDEzMzMgMjEuNDYxMzMzbC0wLjQyNjY2NyA0LjY5MzMzNHoiIGZpbGw9IiNBRTAwMDAiIHAtaWQ9IjI2MjciPjwvcGF0aD48cGF0aCBkPSJNMzg0IDY1NC4xMjI2NjdoMTUzLjUxNDY2N2M5Ni43NjggMCAxNDIuNzYyNjY3LTQ4Ljk4MTMzMyAxNDIuNzYyNjY2LTExNy4wNzczMzQgMC01OS43MzMzMzMtMzMuNDUwNjY3LTg4LjQwNTMzMy04NC44MjEzMzMtOTcuOTYyNjY2di0xLjc5MmM0OC45ODEzMzMtMTUuNTMwNjY3IDY2LjkwMTMzMy00Ni41OTIgNjYuOTAxMzMzLTg5LjYgMC02NS4xMDkzMzMtNDAuNjE4NjY3LTEwMy4zMzg2NjctMTM0Ljk5NzMzMy0xMDMuMzM4NjY3SDM4NHY0MDkuNzcwNjY3eiBtNzIuODc0NjY3LTU0Ljk1NDY2N3YtMTMxLjQxMzMzM2g2Ni4zMDRjNTEuOTY4IDAgODAuMDQyNjY3IDE3LjkyIDgwLjA0MjY2NiA2NS4xMDkzMzMgMCA0NC44LTI2LjI4MjY2NyA2Ni4zMDQtNzUuODYxMzMzIDY2LjMwNGgtNzAuNDg1MzMzeiBtMC0xODAuMzk0NjY3VjI5OC43MDkzMzNoNjAuMzMwNjY2YzQ3LjE4OTMzMyAwIDcyLjI3NzMzMyAxNC45MzMzMzMgNzIuMjc3MzM0IDU5LjEzNiAwIDQ2LjU5Mi0zMi4yNTYgNjAuOTI4LTc1LjI2NCA2MC45MjhoLTU3LjM0NHoiIGZpbGw9IiNGRkZGRkYiIHAtaWQ9IjI2MjgiPjwvcGF0aD48L3N2Zz4=", ue = "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/PjwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+PHN2ZyB0PSIxNjgzNzAzMjQxNjY0IiBjbGFzcz0iaWNvbiIgdmlld0JveD0iMCAwIDEwMjQgMTAyNCIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHAtaWQ9IjI3NzciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB3aWR0aD0iMjAwIiBoZWlnaHQ9IjIwMCI+PHBhdGggZD0iTTE5OC4wMTYgMTA5LjczODY2N0E3Ny44NjY2NjcgNzcuODY2NjY3IDAgMCAwIDE3MC42NjY2NjcgMTY3LjY4bDAuNTEyIDQxOC45NDRjMCAyMi44NjkzMzMgNi40IDQ4IDE5LjAyOTMzMyA3NS4zMDY2NjcgMTIuNjcyIDI3LjIyMTMzMyAyNy45ODkzMzMgNDguOTM4NjY3IDQ1Ljk1MiA2NC45Mzg2NjZsMjExLjE1NzMzMyAxODguMjAyNjY3YzE3LjA2NjY2NyAxNS40ODggNDAuNTc2IDIzLjk3ODY2NyA2NC45Mzg2NjcgMjMuNTk0NjY3IDI1LjY4NTMzMy0wLjA4NTMzMyA0Ny4zNi03LjkzNiA2NC45ODEzMzMtMjMuNTk0NjY3bDIxMS4yLTE4OC4yMDI2NjdjMTcuOTItMTYgMzMuMTk0NjY3LTM3LjYzMiA0NS44NjY2NjctNjQuOTM4NjY2IDEyLjY3Mi0yNy4zMDY2NjcgMTguNzczMzMzLTUyLjIyNCAxOC41MTczMzMtNzQuOTIyNjY3TDg1My4zMzMzMzMgMTY3LjI1MzMzM2MwLTIyLjI3Mi04Ljk2LTQxLjQ3Mi0yNi44MzczMzMtNTcuNDcyLTE3LjU3ODY2Ny0xNS42MTYtMzkuMzM4NjY3LTIzLjg5MzMzMy02NC45Mzg2NjctMjQuNDA1MzMzbC00OTkuMDI5MzMzIDAuNDY5MzMzYTkzLjMxMiA5My4zMTIgMCAwIDAtNjQuNTEyIDIzLjg5MzMzNHoiIGZpbGw9IiM1NEFCMzAiIHAtaWQ9IjI3NzgiPjwvcGF0aD48cGF0aCBkPSJNMTcwLjY2NjY2NyAxNjcuNjhjMC4xMjgtMjEuNzYgOS45NDEzMzMtNDIuNjY2NjY3IDI3LjM0OTMzMy01Ny45NDEzMzNhOTMuMzEyIDkzLjMxMiAwIDAgMSA2NC41MTItMjMuODkzMzM0TDc2MS41NTczMzMgODUuMzMzMzMzYzI1LjYgMC41NTQ2NjcgNDcuMzYgOC43ODkzMzMgNjQuOTM4NjY3IDI0LjQwNTMzNCAxNy45MiAxNiAyNi44MzczMzMgMzUuMiAyNi44MzczMzMgNTcuNDcybC0wLjUxMiA0MTkuODRjMC4yOTg2NjcgMjIuNjU2LTUuODQ1MzMzIDQ3LjYxNi0xOC41MTczMzMgNzQuODgtMTIuNjcyIDI3LjMwNjY2Ny0yNy45NDY2NjcgNDguOTM4NjY3LTQ1Ljg2NjY2NyA2NC45Mzg2NjZsLTIxMS4yIDE4OC4yMDI2NjdjLTE3LjYyMTMzMyAxNS42NTg2NjctMzkuMjUzMzMzIDIzLjUwOTMzMy02NC45ODEzMzMgMjMuNTk0NjY3YTk0LjcyIDk0LjcyIDAgMCAxLTY0LjkzODY2Ny0yMy41OTQ2NjdsLTIxMS4yLTE4OC4yMDI2NjdjLTE3LjkyLTE2LTMzLjIzNzMzMy0zNy43MTczMzMtNDUuOTA5MzMzLTY0LjkzODY2Ni0xMi42MjkzMzMtMjcuMzA2NjY3LTE5LjAyOTMzMy01Mi40MzczMzMtMTkuMDI5MzMzLTc1LjMwNjY2N0wxNzAuNjY2NjY3IDE2Ny42OHogbTQyLjYyNCAwLjI1NmwwLjU1NDY2NiA0MTguNjg4YzAgMTYuMTcwNjY3IDQuODY0IDM1LjMyOCAxNS4wNjEzMzQgNTcuMzQ0IDEwLjM2OCAyMi4yNzIgMjIuMzE0NjY3IDM5LjE2OCAzNS42MjY2NjYgNTEuMDI5MzMzbDIxMS40MTMzMzQgMTg4LjQxNmM4Ljk2IDguMTA2NjY3IDIxLjg4OCAxMi44IDM2LjIyNCAxMi41ODY2NjcgMTUuNTMwNjY3LTAuMDQyNjY3IDI3LjA5MzMzMy00LjI2NjY2NyAzNi42OTMzMzMtMTIuOGwyMTEuMTE0NjY3LTE4OC4xNmMxMy4zNTQ2NjctMTEuOTQ2NjY3IDI1LjMwMTMzMy0yOC44NDI2NjcgMzUuNjI2NjY2LTUxLjA3MiAxMC4xMTItMjEuNzYgMTQuNzYyNjY3LTQwLjUzMzMzMyAxNC41MDY2NjctNTcuMDAyNjY3TDgxMC42NjY2NjcgMTY3LjIxMDY2N2MwLTkuODk4NjY3LTMuNTg0LTE3LjYyMTMzMy0xMi41MDEzMzQtMjUuNkE1NC42OTg2NjcgNTQuNjk4NjY3IDAgMCAwIDc2MS42IDEyOGwtNDk5LjYyNjY2NyAwLjQ2OTMzM2E1MS4zMjggNTEuMzI4IDAgMCAwLTM1Ljc1NDY2NiAxMy4yNjkzMzQgMzYuNTY1MzMzIDM2LjU2NTMzMyAwIDAgMC0xMi41MDEzMzQgMjEuNTA0bC0wLjQyNjY2NiA0LjY5MzMzM3oiIGZpbGw9IiMzODhEMTQiIHAtaWQ9IjI3NzkiPjwvcGF0aD48cGF0aCBkPSJNNTA2LjQ1MzMzMyA2NzQuNzMwNjY3Yzk5LjE1NzMzMyAwIDE0Ni4zNDY2NjctNDguMzg0IDE0Ni4zNDY2NjctMTI2LjAzNzMzNCAwLTcyLjg3NDY2Ny0zOC44MjY2NjctOTkuNzU0NjY3LTEwMy4zMzg2NjctMTE4LjI3MmwtMzguMjI5MzMzLTExLjk0NjY2NmMtNDAuNjE4NjY3LTExLjM0OTMzMy01Mi41NjUzMzMtMjUuMDg4LTUyLjU2NTMzMy01Ny4zNDQgMC0zMi44NTMzMzMgMjMuODkzMzMzLTUwLjc3MzMzMyA2Ni45MDEzMzMtNTAuNzczMzM0IDQ1LjM5NzMzMyAwIDc4Ljg0OCA5LjU1NzMzMyAxMDQuNTMzMzMzIDIwLjMwOTMzNFYyNzMuMzIyNjY3Yy0yMi42OTg2NjctMTEuOTQ2NjY3LTUxLjk2OC0yMi4xMDEzMzMtMTA1LjcyOC0yMi4xMDEzMzQtOTIuNTg2NjY3IDAtMTM3LjM4NjY2NyA0Ny4xODkzMzMtMTM3LjM4NjY2NiAxMTYuNDggMCA2OS4yOTA2NjcgMzUuMjQyNjY3IDEwMC4zNTIgOTMuMTg0IDExNi40OGwzOC44MjY2NjYgMTAuNzUyYzQ0LjggMTMuNzM4NjY3IDU5LjczMzMzMyAyNi44OCA1OS43MzMzMzQgNjAuOTI4IDAgMzcuMDM0NjY3LTIzLjI5NiA1OS43MzMzMzMtNzguMjUwNjY3IDU5LjczMzMzNC00NC44IDAtODMuNjI2NjY3LTEwLjc1Mi0xMTYuNDgtMjUuMDg4djU3Ljk0MTMzM2MyOC4wNzQ2NjcgMTQuOTMzMzMzIDY4LjY5MzMzMyAyNi4yODI2NjcgMTIyLjQ1MzMzMyAyNi4yODI2Njd6IiBmaWxsPSIjRkZGRkZGIiBwLWlkPSIyNzgwIj48L3BhdGg+PC9zdmc+", Ne = "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/PjwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+PHN2ZyB0PSIxNjgzNzAzMjI4MjAyIiBjbGFzcz0iaWNvbiIgdmlld0JveD0iMCAwIDEwMjQgMTAyNCIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHAtaWQ9IjMwNzgiIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB3aWR0aD0iMjAwIiBoZWlnaHQ9IjIwMCI+PHBhdGggZD0iTTE5OC4wMTYgMTA5LjczODY2N0E3Ny44NjY2NjcgNzcuODY2NjY3IDAgMCAwIDE3MC42NjY2NjcgMTY3LjY4bDAuNTEyIDQxOC45NDRjMCAyMi44NjkzMzMgNi40IDQ4IDE5LjAyOTMzMyA3NS4zMDY2NjcgMTIuNjcyIDI3LjIyMTMzMyAyNy45ODkzMzMgNDguOTM4NjY3IDQ1Ljk1MiA2NC45Mzg2NjZsMjExLjE1NzMzMyAxODguMjAyNjY3YzE3LjA2NjY2NyAxNS40ODggNDAuNTc2IDIzLjk3ODY2NyA2NC45Mzg2NjcgMjMuNTk0NjY3IDI1LjY4NTMzMy0wLjA4NTMzMyA0Ny4zNi03LjkzNiA2NC45ODEzMzMtMjMuNTk0NjY3bDIxMS4yLTE4OC4yMDI2NjdjMTcuOTItMTYgMzMuMTk0NjY3LTM3LjYzMiA0NS44NjY2NjctNjQuOTM4NjY2IDEyLjY3Mi0yNy4zMDY2NjcgMTguNzczMzMzLTUyLjIyNCAxOC41MTczMzMtNzQuOTIyNjY3TDg1My4zMzMzMzMgMTY3LjI1MzMzM2MwLTIyLjI3Mi04Ljk2LTQxLjQ3Mi0yNi44MzczMzMtNTcuNDcyLTE3LjU3ODY2Ny0xNS42MTYtMzkuMzM4NjY3LTIzLjg5MzMzMy02NC45Mzg2NjctMjQuNDA1MzMzbC00OTkuMDI5MzMzIDAuNDY5MzMzYTkzLjMxMiA5My4zMTIgMCAwIDAtNjQuNTEyIDIzLjg5MzMzNHoiIGZpbGw9IiNDODgwRkYiIHAtaWQ9IjMwNzkiPjwvcGF0aD48cGF0aCBkPSJNMTcwLjY2NjY2NyAxNjcuNjhjMC4xMjgtMjEuNzYgOS45NDEzMzMtNDIuNjY2NjY3IDI3LjM0OTMzMy01Ny45NDEzMzNhOTMuMzEyIDkzLjMxMiAwIDAgMSA2NC41MTItMjMuODkzMzM0TDc2MS41NTczMzMgODUuMzMzMzMzYzI1LjYgMC41NTQ2NjcgNDcuMzYgOC43ODkzMzMgNjQuOTM4NjY3IDI0LjQwNTMzNCAxNy45MiAxNiAyNi44MzczMzMgMzUuMiAyNi44MzczMzMgNTcuNDcybC0wLjUxMiA0MTkuODRjMC4yOTg2NjcgMjIuNjU2LTUuODQ1MzMzIDQ3LjYxNi0xOC41MTczMzMgNzQuODgtMTIuNjcyIDI3LjMwNjY2Ny0yNy45NDY2NjcgNDguOTM4NjY3LTQ1Ljg2NjY2NyA2NC45Mzg2NjZsLTIxMS4yIDE4OC4yMDI2NjdjLTE3LjYyMTMzMyAxNS42NTg2NjctMzkuMjUzMzMzIDIzLjUwOTMzMy02NC45ODEzMzMgMjMuNTk0NjY3YTk0LjcyIDk0LjcyIDAgMCAxLTY0LjkzODY2Ny0yMy41OTQ2NjdsLTIxMS4yLTE4OC4yMDI2NjdjLTE3LjkyLTE2LTMzLjIzNzMzMy0zNy43MTczMzMtNDUuOTA5MzMzLTY0LjkzODY2Ni0xMi42MjkzMzMtMjcuMzA2NjY3LTE5LjAyOTMzMy01Mi40MzczMzMtMTkuMDI5MzMzLTc1LjMwNjY2N0wxNzAuNjY2NjY3IDE2Ny42OHogbTQyLjYyNCAwLjI1NmwwLjU1NDY2NiA0MTguNjg4YzAgMTYuMTcwNjY3IDQuODY0IDM1LjMyOCAxNS4wNjEzMzQgNTcuMzQ0IDEwLjM2OCAyMi4yNzIgMjIuMzE0NjY3IDM5LjE2OCAzNS42MjY2NjYgNTEuMDI5MzMzbDIxMS40MTMzMzQgMTg4LjQxNmM4Ljk2IDguMTA2NjY3IDIxLjg4OCAxMi44IDM2LjIyNCAxMi41ODY2NjcgMTUuNTMwNjY3LTAuMDQyNjY3IDI3LjA5MzMzMy00LjI2NjY2NyAzNi42OTMzMzMtMTIuOGwyMTEuMTE0NjY3LTE4OC4xNmMxMy4zNTQ2NjctMTEuOTQ2NjY3IDI1LjMwMTMzMy0yOC44NDI2NjcgMzUuNjI2NjY2LTUxLjA3MiAxMC4xMTItMjEuNzYgMTQuNzYyNjY3LTQwLjUzMzMzMyAxNC41MDY2NjctNTcuMDAyNjY3TDgxMC42NjY2NjcgMTY3LjIxMDY2N2MwLTkuODk4NjY3LTMuNTg0LTE3LjYyMTMzMy0xMi41MDEzMzQtMjUuNkE1NC42OTg2NjcgNTQuNjk4NjY3IDAgMCAwIDc2MS42IDEyOGwtNDk5LjYyNjY2NyAwLjQ2OTMzM2E1MS4zMjggNTEuMzI4IDAgMCAwLTM1Ljc1NDY2NiAxMy4yNjkzMzQgMzYuNTY1MzMzIDM2LjU2NTMzMyAwIDAgMC0xMi41MDEzMzQgMjEuNTA0bC0wLjQyNjY2NiA0LjY5MzMzM3oiIGZpbGw9IiNBRTQ0RkYiIHAtaWQ9IjMwODAiPjwvcGF0aD48cGF0aCBkPSJNNDc1LjMwNjY2NyA2NTguMjE4NjY3aDczLjQ3MlYzMDYuMzg5MzMzaDExNi40OFYyNDguNDQ4aC0zMDcuNjI2NjY3djU3Ljk0MTMzM2gxMTcuNjc0NjY3eiIgZmlsbD0iI0ZGRkZGRiIgcC1pZD0iMzA4MSI+PC9wYXRoPjwvc3ZnPg==", J = (a, t) => {
128
+ const { type: i = "log", color: e = "black" } = t ?? {};
129
+ localStorage.getItem("st-kline-console-show") === "true" && console[i](`%c${a}`, `color:${e}`);
130
+ }, h = (a) => a || a === 0 ? Math.round(a * 1e3) / 1e3 : null, We = (a) => a >= 1e12 ? `${(a / 1e12).toFixed(2)}万亿` : a >= 1e8 ? `${(a / 1e8).toFixed(2)}亿` : a >= 1e4 ? `${(a / 1e4).toFixed(2)}万` : a.toFixed(2), Ze = (a) => {
131
+ const { y: t, text: i, info: e, gridLeft: n, gridRight: o, echartsWidth: z, echartsInstance: s } = a, { config: l, event: r } = e;
132
+ let j = 0;
133
+ return {
134
+ type: "group",
135
+ draggable: l.draggable ? "vertical" : !1,
136
+ children: [
137
+ {
138
+ type: "line",
139
+ info: e,
140
+ shape: {
141
+ x1: n,
142
+ y1: t,
143
+ x2: z - o,
144
+ y2: t
145
+ },
146
+ style: {
147
+ stroke: l.lineColor,
148
+ lineWidth: 1,
149
+ lineDash: [8, 4]
150
+ },
151
+ z: 10
152
+ },
153
+ {
154
+ type: "group",
155
+ x: z,
156
+ y: t - 5,
157
+ children: [
158
+ {
159
+ type: "text",
160
+ left: -1 * o,
161
+ info: e,
162
+ style: {
163
+ fill: l.textColor,
164
+ text: i,
165
+ stroke: "#000",
166
+ lineWidth: 1,
167
+ opacity: 1
168
+ },
169
+ z: 10
170
+ }
171
+ ]
172
+ }
173
+ ],
174
+ // 事件:鼠标滑入
175
+ onmouseover: (D) => {
176
+ r.onmouseover instanceof Function && r.onmouseover(D, e);
177
+ },
178
+ // 事件:鼠标滑出
179
+ onmouseout: (D) => {
180
+ r.onmouseout instanceof Function && r.onmouseout(D, e);
181
+ },
182
+ // 事件:开始拖拽
183
+ ondragstart: (D) => {
184
+ r.ondragstart instanceof Function && l.draggable && (j = D.offsetY, r.ondragstart(D, e));
185
+ },
186
+ // 事件:结束拖拽
187
+ ondragend: (D) => {
188
+ if (r.ondragend instanceof Function && l.draggable) {
189
+ const u = D.offsetY - j;
190
+ if (u === 0)
191
+ return;
192
+ const I = s.convertFromPixel({ yAxisIndex: 0 }, t + u);
193
+ r.ondragend(D, e, I);
194
+ }
195
+ }
196
+ };
197
+ }, Ge = (a) => {
198
+ const { y: t, text: i, info: e, gridLeft: n, gridRight: o, echartsWidth: z, echartsInstance: s } = a, { config: l, event: r } = e;
199
+ let j = 0;
200
+ const D = (u) => {
201
+ let I = null;
202
+ u.target.type === "line" ? I = u.target.parent : u.target.type === "tspan" && (I = u.target.parent.parent.parent), I.children()[1].children()[0].animate("style", !1).when(200, { opacity: 1 }).start();
203
+ }, c = (u) => {
204
+ let I = null;
205
+ u.target.type === "line" ? I = u.target.parent : u.target.type === "tspan" && (I = u.target.parent.parent.parent), I.children()[1].children()[0].animate("style", !1).when(200, { opacity: 0 }).start();
206
+ };
207
+ return {
208
+ type: "group",
209
+ draggable: l.draggable ? "vertical" : !1,
210
+ // 是否支持拖拽
211
+ children: [
212
+ {
213
+ type: "line",
214
+ info: e,
215
+ shape: {
216
+ x1: n,
217
+ y1: t,
218
+ x2: z - o,
219
+ y2: t
220
+ },
221
+ style: {
222
+ stroke: l.lineColor,
223
+ lineWidth: 1
224
+ },
225
+ z: 10
226
+ },
227
+ {
228
+ type: "group",
229
+ x: z / 2,
230
+ y: t - 5,
231
+ children: [
232
+ {
233
+ type: "text",
234
+ left: "center",
235
+ info: e,
236
+ style: {
237
+ fill: l.textColor,
238
+ text: i,
239
+ stroke: "#000",
240
+ lineWidth: 1,
241
+ opacity: 0
242
+ //隐藏文本
243
+ },
244
+ z: 10
245
+ }
246
+ ]
247
+ }
248
+ ],
249
+ // 事件:鼠标滑入
250
+ onmouseover: (u) => {
251
+ r.onmouseover instanceof Function ? r.onmouseover(u, e) : D(u);
252
+ },
253
+ // 事件:鼠标滑出
254
+ onmouseout: (u) => {
255
+ r.onmouseout instanceof Function ? r.onmouseout(u, e) : c(u);
256
+ },
257
+ // 事件:开始拖拽
258
+ ondragstart: (u) => {
259
+ r.ondragstart instanceof Function && l.draggable && (j = u.offsetY, r.ondragstart(u, e));
260
+ },
261
+ // 事件:结束拖拽
262
+ ondragend: (u) => {
263
+ if (r.ondragend instanceof Function && l.draggable) {
264
+ const M = u.offsetY - j;
265
+ if (M === 0)
266
+ return;
267
+ const p = s.convertFromPixel({ yAxisIndex: 0 }, t + M);
268
+ r.ondragend(u, e, p);
269
+ }
270
+ }
271
+ };
272
+ }, $e = (a) => {
273
+ const { y: t, text: i, profitY: e, profitText: n, lossY: o, lossText: z, info: s, gridLeft: l, gridRight: r, echartsWidth: j, echartsInstance: D } = a, { config: c, event: u } = s;
274
+ let I = 0, M = null, p = null;
275
+ const m = (N, d) => {
276
+ var T, x, A, k;
277
+ (T = N.children()[2]) == null || T.animate("style", !1).when(200, { opacity: ~~d }).start(), (x = N.children()[3].children()[0]) == null || x.animate("style", !1).when(200, { opacity: ~~d }).start(), (A = N.children()[4]) == null || A.animate("style", !1).when(200, { opacity: ~~d }).start(), (k = N.children()[5].children()[0]) == null || k.animate("style", !1).when(200, { opacity: ~~d }).start();
278
+ }, w = (N) => {
279
+ let d = null;
280
+ N.target.type === "line" ? d = N.target.parent : N.target.type === "tspan" && (d = N.target.parent.parent.parent), M = (T) => {
281
+ T.preventDefault(), (T.code === "AltLeft" || T.code === "AltRight") && m(d, !0);
282
+ }, p = (T) => {
283
+ (T.code === "AltLeft" || T.code === "AltRight") && m(d, !1);
284
+ }, window.addEventListener("keydown", M), window.addEventListener("keyup", p);
285
+ }, b = (N) => {
286
+ let d = null;
287
+ N.target.type === "line" ? d = N.target.parent : N.target.type === "tspan" && (d = N.target.parent.parent.parent), m(d, !1), window.removeEventListener("keydown", M), window.removeEventListener("keyup", p);
288
+ };
289
+ return {
290
+ type: "group",
291
+ draggable: c.draggable ? "vertical" : !1,
292
+ // 是否支持拖拽
293
+ children: [
294
+ // 条件单-主线
295
+ {
296
+ type: "line",
297
+ info: s,
298
+ shape: {
299
+ x1: l,
300
+ y1: t,
301
+ x2: j - r,
302
+ y2: t
303
+ },
304
+ style: {
305
+ stroke: c.lineColor,
306
+ lineWidth: 1
307
+ },
308
+ z: 10
309
+ },
310
+ // 条件单-文本内容
311
+ {
312
+ type: "group",
313
+ x: j / 2,
314
+ y: t - 5,
315
+ children: [
316
+ {
317
+ type: "text",
318
+ left: "center",
319
+ info: s,
320
+ style: {
321
+ fill: c.textColor,
322
+ // 填充色
323
+ text: i,
324
+ stroke: "#000",
325
+ // 线条颜色
326
+ lineWidth: 1,
327
+ opacity: 1
328
+ //直接展示文本
329
+ },
330
+ z: 10
331
+ }
332
+ ]
333
+ },
334
+ // 条件单-止盈线
335
+ {
336
+ type: "line",
337
+ info: s,
338
+ shape: {
339
+ x1: l,
340
+ y1: e,
341
+ x2: j - r,
342
+ y2: e
343
+ },
344
+ style: {
345
+ stroke: c.profitLineColor,
346
+ lineWidth: 1,
347
+ lineDash: [8, 4],
348
+ opacity: 0
349
+ },
350
+ z: 10
351
+ },
352
+ // 条件单-止盈线文本内容
353
+ {
354
+ type: "group",
355
+ x: j / 2,
356
+ y: e - 5,
357
+ children: [
358
+ {
359
+ type: "text",
360
+ left: "center",
361
+ info: s,
362
+ style: {
363
+ fill: c.profitTextColor,
364
+ text: n,
365
+ stroke: "#000",
366
+ lineWidth: 1,
367
+ opacity: 0
368
+ },
369
+ z: 10
370
+ }
371
+ ]
372
+ },
373
+ // 条件单-止损线
374
+ {
375
+ type: "line",
376
+ info: s,
377
+ shape: {
378
+ x1: l,
379
+ y1: o,
380
+ x2: j - r,
381
+ y2: o
382
+ },
383
+ style: {
384
+ stroke: c.lossLineColor,
385
+ lineWidth: 1,
386
+ lineDash: [8, 4],
387
+ opacity: 0
388
+ },
389
+ z: 10
390
+ },
391
+ // 条件单-止损线文本内容
392
+ {
393
+ type: "group",
394
+ x: j / 2,
395
+ y: o - 5,
396
+ children: [
397
+ {
398
+ type: "text",
399
+ left: "center",
400
+ info: s,
401
+ style: {
402
+ fill: c.lossTextColor,
403
+ text: z,
404
+ stroke: "#000",
405
+ lineWidth: 1,
406
+ opacity: 0
407
+ },
408
+ z: 10
409
+ }
410
+ ]
411
+ }
412
+ ],
413
+ // 事件:鼠标滑入
414
+ onmouseover: (N) => {
415
+ u.onmouseover instanceof Function ? u.onmouseover(N, s) : w(N);
416
+ },
417
+ // 事件:鼠标滑出
418
+ onmouseout: (N) => {
419
+ u.onmouseout instanceof Function ? u.onmouseout(N, s) : b(N);
420
+ },
421
+ // 事件:开始拖拽
422
+ ondragstart: (N) => {
423
+ u.ondragstart instanceof Function && c.draggable && (I = N.offsetY, u.ondragstart(N, s));
424
+ },
425
+ // 事件:结束拖拽
426
+ ondragend: (N) => {
427
+ if (u.ondragend instanceof Function && c.draggable) {
428
+ const T = N.offsetY - I;
429
+ if (T === 0)
430
+ return;
431
+ const x = D.convertFromPixel({ yAxisIndex: 0 }, t + T);
432
+ u.ondragend(N, s, x);
433
+ }
434
+ }
435
+ };
436
+ }, ie = (a, t) => {
437
+ const { direction: i = "", tradeAction: e = "", tradeType: n = "" } = a;
438
+ if (t === "sellBuy") {
439
+ const o = n ?? i + e;
440
+ return (/* @__PURE__ */ new Map([
441
+ ["开多", "买"],
442
+ ["平多", "卖"],
443
+ ["开空", "卖"],
444
+ ["平空", "买"]
445
+ ])).get(o);
446
+ } else if (t === "openClose")
447
+ return n ?? i + e;
448
+ }, He = (a, t) => a.reduce((i, e) => {
449
+ var j;
450
+ const n = ie(e, "sellBuy"), o = a.filter((D) => D.time === e.time);
451
+ let z = "image://" + new URL((/* @__PURE__ */ Object.assign({ "./images/buy.svg": ce, "./images/sell.svg": ue, "./images/t.svg": Ne }))[`./images/${n === "买" ? "buy" : "sell"}.svg`], self.location).href;
452
+ o.length > 1 ? [...new Set(o.map((c) => ie(c, "sellBuy")))].length > 1 ? z = "image://" + new URL("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/PjwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+PHN2ZyB0PSIxNjgzNzAzMjI4MjAyIiBjbGFzcz0iaWNvbiIgdmlld0JveD0iMCAwIDEwMjQgMTAyNCIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHAtaWQ9IjMwNzgiIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB3aWR0aD0iMjAwIiBoZWlnaHQ9IjIwMCI+PHBhdGggZD0iTTE5OC4wMTYgMTA5LjczODY2N0E3Ny44NjY2NjcgNzcuODY2NjY3IDAgMCAwIDE3MC42NjY2NjcgMTY3LjY4bDAuNTEyIDQxOC45NDRjMCAyMi44NjkzMzMgNi40IDQ4IDE5LjAyOTMzMyA3NS4zMDY2NjcgMTIuNjcyIDI3LjIyMTMzMyAyNy45ODkzMzMgNDguOTM4NjY3IDQ1Ljk1MiA2NC45Mzg2NjZsMjExLjE1NzMzMyAxODguMjAyNjY3YzE3LjA2NjY2NyAxNS40ODggNDAuNTc2IDIzLjk3ODY2NyA2NC45Mzg2NjcgMjMuNTk0NjY3IDI1LjY4NTMzMy0wLjA4NTMzMyA0Ny4zNi03LjkzNiA2NC45ODEzMzMtMjMuNTk0NjY3bDIxMS4yLTE4OC4yMDI2NjdjMTcuOTItMTYgMzMuMTk0NjY3LTM3LjYzMiA0NS44NjY2NjctNjQuOTM4NjY2IDEyLjY3Mi0yNy4zMDY2NjcgMTguNzczMzMzLTUyLjIyNCAxOC41MTczMzMtNzQuOTIyNjY3TDg1My4zMzMzMzMgMTY3LjI1MzMzM2MwLTIyLjI3Mi04Ljk2LTQxLjQ3Mi0yNi44MzczMzMtNTcuNDcyLTE3LjU3ODY2Ny0xNS42MTYtMzkuMzM4NjY3LTIzLjg5MzMzMy02NC45Mzg2NjctMjQuNDA1MzMzbC00OTkuMDI5MzMzIDAuNDY5MzMzYTkzLjMxMiA5My4zMTIgMCAwIDAtNjQuNTEyIDIzLjg5MzMzNHoiIGZpbGw9IiNDODgwRkYiIHAtaWQ9IjMwNzkiPjwvcGF0aD48cGF0aCBkPSJNMTcwLjY2NjY2NyAxNjcuNjhjMC4xMjgtMjEuNzYgOS45NDEzMzMtNDIuNjY2NjY3IDI3LjM0OTMzMy01Ny45NDEzMzNhOTMuMzEyIDkzLjMxMiAwIDAgMSA2NC41MTItMjMuODkzMzM0TDc2MS41NTczMzMgODUuMzMzMzMzYzI1LjYgMC41NTQ2NjcgNDcuMzYgOC43ODkzMzMgNjQuOTM4NjY3IDI0LjQwNTMzNCAxNy45MiAxNiAyNi44MzczMzMgMzUuMiAyNi44MzczMzMgNTcuNDcybC0wLjUxMiA0MTkuODRjMC4yOTg2NjcgMjIuNjU2LTUuODQ1MzMzIDQ3LjYxNi0xOC41MTczMzMgNzQuODgtMTIuNjcyIDI3LjMwNjY2Ny0yNy45NDY2NjcgNDguOTM4NjY3LTQ1Ljg2NjY2NyA2NC45Mzg2NjZsLTIxMS4yIDE4OC4yMDI2NjdjLTE3LjYyMTMzMyAxNS42NTg2NjctMzkuMjUzMzMzIDIzLjUwOTMzMy02NC45ODEzMzMgMjMuNTk0NjY3YTk0LjcyIDk0LjcyIDAgMCAxLTY0LjkzODY2Ny0yMy41OTQ2NjdsLTIxMS4yLTE4OC4yMDI2NjdjLTE3LjkyLTE2LTMzLjIzNzMzMy0zNy43MTczMzMtNDUuOTA5MzMzLTY0LjkzODY2Ni0xMi42MjkzMzMtMjcuMzA2NjY3LTE5LjAyOTMzMy01Mi40MzczMzMtMTkuMDI5MzMzLTc1LjMwNjY2N0wxNzAuNjY2NjY3IDE2Ny42OHogbTQyLjYyNCAwLjI1NmwwLjU1NDY2NiA0MTguNjg4YzAgMTYuMTcwNjY3IDQuODY0IDM1LjMyOCAxNS4wNjEzMzQgNTcuMzQ0IDEwLjM2OCAyMi4yNzIgMjIuMzE0NjY3IDM5LjE2OCAzNS42MjY2NjYgNTEuMDI5MzMzbDIxMS40MTMzMzQgMTg4LjQxNmM4Ljk2IDguMTA2NjY3IDIxLjg4OCAxMi44IDM2LjIyNCAxMi41ODY2NjcgMTUuNTMwNjY3LTAuMDQyNjY3IDI3LjA5MzMzMy00LjI2NjY2NyAzNi42OTMzMzMtMTIuOGwyMTEuMTE0NjY3LTE4OC4xNmMxMy4zNTQ2NjctMTEuOTQ2NjY3IDI1LjMwMTMzMy0yOC44NDI2NjcgMzUuNjI2NjY2LTUxLjA3MiAxMC4xMTItMjEuNzYgMTQuNzYyNjY3LTQwLjUzMzMzMyAxNC41MDY2NjctNTcuMDAyNjY3TDgxMC42NjY2NjcgMTY3LjIxMDY2N2MwLTkuODk4NjY3LTMuNTg0LTE3LjYyMTMzMy0xMi41MDEzMzQtMjUuNkE1NC42OTg2NjcgNTQuNjk4NjY3IDAgMCAwIDc2MS42IDEyOGwtNDk5LjYyNjY2NyAwLjQ2OTMzM2E1MS4zMjggNTEuMzI4IDAgMCAwLTM1Ljc1NDY2NiAxMy4yNjkzMzQgMzYuNTY1MzMzIDM2LjU2NTMzMyAwIDAgMC0xMi41MDEzMzQgMjEuNTA0bC0wLjQyNjY2NiA0LjY5MzMzM3oiIGZpbGw9IiNBRTQ0RkYiIHAtaWQ9IjMwODAiPjwvcGF0aD48cGF0aCBkPSJNNDc1LjMwNjY2NyA2NTguMjE4NjY3aDczLjQ3MlYzMDYuMzg5MzMzaDExNi40OFYyNDguNDQ4aC0zMDcuNjI2NjY3djU3Ljk0MTMzM2gxMTcuNjc0NjY3eiIgZmlsbD0iI0ZGRkZGRiIgcC1pZD0iMzA4MSI+PC9wYXRoPjwvc3ZnPg==", self.location).href : z = "image://" + new URL((/* @__PURE__ */ Object.assign({ "./images/buy.svg": ce, "./images/sell.svg": ue, "./images/t.svg": Ne }))[`./images/${n === "买" ? "buy" : "sell"}.svg`], self.location).href : z = "image://" + new URL((/* @__PURE__ */ Object.assign({ "./images/buy.svg": ce, "./images/sell.svg": ue, "./images/t.svg": Ne }))[`./images/${n === "买" ? "buy" : "sell"}.svg`], self.location).href;
453
+ const l = (t.find((D) => D[0] === e.time) ?? [])[2], r = ((j = e == null ? void 0 : e.markLineTarget) == null ? void 0 : j.map((D) => {
454
+ const c = e.time, u = l + "", I = D.time, M = t.find((m) => m[0] === D.time), p = M ? M[3] : null;
455
+ return [
456
+ {
457
+ coord: [c, u],
458
+ lineStyle: D.lineStyle
459
+ },
460
+ {
461
+ coord: [I, p]
462
+ }
463
+ ];
464
+ })) ?? null;
465
+ return i.push({
466
+ symbol: z,
467
+ // 图标
468
+ symbolSize: 25,
469
+ // 图标大小
470
+ animation: !1,
471
+ // 是否展示动画
472
+ coord: [e.time + "", l],
473
+ // X轴[时间],Y轴[最高价]
474
+ symbolRotate: 0,
475
+ // 旋转角度
476
+ symbolOffset: [0, "-7"],
477
+ // 偏移距离
478
+ markLineTarget: r
479
+ }), i;
480
+ }, []), Je = (a, t) => a.reduce((i, e, n) => {
481
+ var D;
482
+ const o = ie(e, "openClose"), z = o === "开多" || o === "开空" ? "top" : "bottom", s = t.find((c) => c[0] === e.time) ?? [], l = z === "top" ? s[2] : s[3];
483
+ let r = 7;
484
+ r += a.slice(0, n).filter((c) => {
485
+ const u = ie(c, "openClose");
486
+ return (u === "开多" || u === "开空" ? "top" : "bottom") === z && c.time === e.time;
487
+ }).length * 7;
488
+ const j = ((D = e == null ? void 0 : e.markLineTarget) == null ? void 0 : D.map((c) => {
489
+ const u = e.time, I = l + "", M = c.time, p = t.find((m) => m[0] === c.time)[3];
490
+ return [
491
+ {
492
+ coord: [u, I],
493
+ lineStyle: c.lineStyle
494
+ },
495
+ {
496
+ coord: [M, p]
497
+ }
498
+ ];
499
+ })) ?? null;
500
+ return i.push({
501
+ symbol: "triangle",
502
+ // 图标
503
+ symbolSize: [10, 12],
504
+ // 图标大小
505
+ animation: !1,
506
+ // 是否展示动画
507
+ coord: [e.time + "", l],
508
+ // X轴[时间],Y轴[最高价||最低价]
509
+ symbolRotate: z === "top" ? 180 : 0,
510
+ //标注旋转角度
511
+ symbolOffset: [0, `${z === "top" ? r * -1 : r}`],
512
+ //标注偏移距离
513
+ itemStyle: { color: z === "top" ? "#FF0000" : "#389e0d" },
514
+ // 图标颜色
515
+ // 文本
516
+ label: {
517
+ show: !0,
518
+ // 是否展示
519
+ position: z,
520
+ color: "#fff",
521
+ formatter: `${o} ${z === "top" ? "+" : "-"} ${e.amount}手 ${e.part ? `(${e.part}份)` : ""}`
522
+ },
523
+ markLineTarget: j
524
+ }), i;
525
+ }, []), Xe = (a, t) => a.reduce((i, e) => {
526
+ const { key: n, data: o } = e;
527
+ if (o === null || o.length === 0)
528
+ return i;
529
+ const s = (/* @__PURE__ */ new Map([
530
+ // 买卖点
531
+ [
532
+ "sellBuy",
533
+ () => He(o, t)
534
+ ],
535
+ // 开平点
536
+ [
537
+ "openClose",
538
+ () => Je(o, t)
539
+ ],
540
+ // 信号点
541
+ ["signal", () => {
542
+ }]
543
+ ])).get(n);
544
+ return s instanceof Function && i.push(...s()), i;
545
+ }, []), ze = async (a, t, i, e, n, o) => {
546
+ const { totalBarCount: z, defaultShowBarCount: s, maxValueSpan: l, gridLeft: r, gridTop: j, gridRight: D, gridBottom: c, zoomLock: u } = e, { time: I, kLine: M, originData: p, indicator: m } = await Pe(a, i, z), w = m.map((d) => {
547
+ const { key: T, data: x, color: A } = d;
548
+ return {
549
+ name: T,
550
+ type: "line",
551
+ silent: !0,
552
+ symbol: "none",
553
+ data: x,
554
+ lineStyle: {
555
+ width: 1
556
+ },
557
+ itemStyle: {
558
+ color: A
559
+ }
560
+ };
561
+ }), b = Xe(t, p);
562
+ let N = [];
563
+ return b.forEach((d) => {
564
+ d.markLineTarget && (N = [...N, ...d.markLineTarget]);
565
+ }), {
566
+ animation: !1,
567
+ dataset: {
568
+ id: "data",
569
+ source: {
570
+ klineData: M,
571
+ indicatorData: m
572
+ }
573
+ },
574
+ grid: {
575
+ left: `${r}px`,
576
+ top: `${j}px`,
577
+ right: `${D}px`,
578
+ bottom: `${c}px`
579
+ },
580
+ tooltip: {
581
+ trigger: "axis",
582
+ axisPointer: {
583
+ type: "cross",
584
+ label: {
585
+ formatter: (d) => {
586
+ const { axisDimension: T, value: x } = d;
587
+ return T === "x" ? x : String(h(x));
588
+ }
589
+ }
590
+ },
591
+ formatter: (d) => {
592
+ let T = null, x = "";
593
+ return d.forEach((A) => {
594
+ A.seriesName === "资产持仓净值" && A.data !== null && (x += `<div>资产持仓净值: ${A.data}</div>`), A.componentSubType === "candlestick" && t.forEach((k) => {
595
+ const { key: E, data: U } = k;
596
+ if (E === "sellBuy") {
597
+ const F = U.filter((f) => f.time === A.axisValue);
598
+ let B = 0, g = 0;
599
+ F.forEach((f) => {
600
+ f.tradeType === "开多" || f.tradeType === "平空" ? B += f.amount : g += f.amount;
601
+ }), B && (x += `<div>买: ${B}</div>`), g && (x += `<div>卖: ${g}</div>`);
602
+ }
603
+ E === "openClose" && U.forEach((F) => {
604
+ F.time === A.axisValue && (x += F.tooltip);
605
+ });
606
+ }), x && (T = `<div><span style="font-weight: bold;">${A.axisValue}</span>${x}</div>`);
607
+ }), T;
608
+ }
609
+ },
610
+ xAxis: {
611
+ type: "category",
612
+ data: I,
613
+ axisLine: {
614
+ show: !0
615
+ },
616
+ splitLine: {
617
+ show: !0,
618
+ lineStyle: {
619
+ type: "dotted",
620
+ color: "#333"
621
+ }
622
+ },
623
+ axisLabel: {
624
+ show: !0,
625
+ formatter: (d) => d
626
+ }
627
+ },
628
+ yAxis: [
629
+ {
630
+ index: 0,
631
+ splitLine: {
632
+ show: !0,
633
+ lineStyle: {
634
+ type: "dotted",
635
+ color: "#333"
636
+ }
637
+ },
638
+ min: (d) => {
639
+ const { min: T, max: x } = d, A = Math.abs((x - T) / 10);
640
+ return T - A;
641
+ },
642
+ max: (d) => {
643
+ const { min: T, max: x } = d, A = Math.abs((x - T) / 10);
644
+ return x + A;
645
+ },
646
+ axisLine: {
647
+ show: !0
648
+ },
649
+ axisLabel: {
650
+ formatter: (d) => h(d),
651
+ showMaxLabel: !1
652
+ }
653
+ },
654
+ {
655
+ show: !1,
656
+ min: "dataMin"
657
+ }
658
+ ],
659
+ dataZoom: [
660
+ {
661
+ type: "inside",
662
+ xAxisIndex: [0, 0],
663
+ zoomLock: u,
664
+ maxValueSpan: l,
665
+ start: M.length >= s ? (M.length - s) / M.length * 100 : 0,
666
+ end: 99.99
667
+ // startValue: kLine.length >= defaultShowBarCount ? kLine.length - defaultShowBarCount : 0,
668
+ // endValue: kLine.length - 1,
669
+ }
670
+ ],
671
+ series: [
672
+ {
673
+ name: "k线",
674
+ type: "candlestick",
675
+ data: M,
676
+ markPoint: {
677
+ data: b
678
+ },
679
+ markLine: {
680
+ position: "middle",
681
+ textStyle: { color: "blue", fontSize: 15 },
682
+ animation: !1,
683
+ data: N,
684
+ lineStyle: {
685
+ width: 3,
686
+ type: "solid"
687
+ },
688
+ symbol: ["none", "none"]
689
+ },
690
+ itemStyle: {
691
+ color: "transparent",
692
+ color0: "#00FFFF",
693
+ borderColor: "#FF0000",
694
+ borderColor0: "#00FFFF",
695
+ borderWidth: 1
696
+ },
697
+ z: 1
698
+ },
699
+ ...w,
700
+ {
701
+ name: "资产持仓净值",
702
+ type: "line",
703
+ data: n ?? [],
704
+ symbol: "none",
705
+ yAxisIndex: 1,
706
+ connectNulls: !0,
707
+ itemStyle: {
708
+ color: "#666"
709
+ }
710
+ },
711
+ {
712
+ name: "二腿相关度",
713
+ type: "line",
714
+ data: o ?? [],
715
+ symbol: "none",
716
+ yAxisIndex: 1,
717
+ connectNulls: !0,
718
+ itemStyle: {
719
+ color: "#FFF"
720
+ },
721
+ lineStyle: {
722
+ // type: "dashed", // 虚线
723
+ width: 2
724
+ },
725
+ label: {
726
+ show: !0,
727
+ // 显示文字
728
+ position: "top",
729
+ // 文字位置
730
+ formatter: (d) => `相关度: ${d.data[1]}`,
731
+ textStyle: {
732
+ color: "#FFF",
733
+ // 文字颜色
734
+ fontSize: 14
735
+ // 文字字体大小
736
+ }
737
+ }
738
+ }
739
+ ],
740
+ toolbox: {
741
+ show: !1
742
+ },
743
+ brush: {
744
+ xAxisIndex: "all",
745
+ brushLink: "all",
746
+ transformable: !1,
747
+ outOfBrush: {
748
+ colorAlpha: 1
749
+ },
750
+ brushStyle: {
751
+ color: "rgba(120,140,180,0)",
752
+ borderColor: "rgba(255,255,255,0.4)"
753
+ }
754
+ }
755
+ };
756
+ }, Ke = (a, t, i) => {
757
+ var D;
758
+ const { gridLeft: e, gridRight: n, gridBottom: o, warningConfig: z, positionConfig: s, conditionConfig: l, isOpenDS: r } = t;
759
+ let j = [];
760
+ if ((D = i == null ? void 0 : i.getModel()) != null && D.getComponent) {
761
+ const [c, u] = i.getModel().getComponent("yAxis").axis.scale._extent;
762
+ let I = [], M = {}, p = [], m = {}, w = [], b = {};
763
+ if (a.forEach(({ key: N, data: d, ...T }) => {
764
+ N === "warning" ? (I = d, M = T) : N === "position" ? (p = d, m = T) : N === "condition" && (w = d, b = T);
765
+ }), I.length > 0 && (j = I.reduce((N, d) => {
766
+ const { value: T, text: x, info: A, config: k } = d;
767
+ if (T > u || T < c)
768
+ return N;
769
+ const E = {
770
+ y: i.convertToPixel({ yAxisIndex: 0 }, T),
771
+ text: x,
772
+ info: { info: A, config: { ...z, ...k }, event: { ...M } },
773
+ gridLeft: e,
774
+ gridRight: n,
775
+ echartsWidth: i.getWidth(),
776
+ echartsInstance: i
777
+ };
778
+ return [...N, Ze(E)];
779
+ }, j)), p.length > 0 && (j = p.reduce((N, d) => {
780
+ const { value: T, text: x, info: A, config: k } = d;
781
+ if (T > u || T < c)
782
+ return N;
783
+ const E = {
784
+ y: i.convertToPixel({ yAxisIndex: 0 }, T),
785
+ text: x,
786
+ info: { info: A, config: { ...s, ...k }, event: { ...m } },
787
+ gridLeft: e,
788
+ gridRight: n,
789
+ echartsWidth: i.getWidth(),
790
+ echartsInstance: i
791
+ };
792
+ return [...N, Ge(E)];
793
+ }, j)), w.length > 0 && (j = w.reduce((N, d) => {
794
+ const { value: T, text: x, profitValue: A, profitText: k, lossValue: E, lossText: U, info: F, config: B } = d;
795
+ if (T > u || T < c)
796
+ return N;
797
+ const g = {
798
+ y: i.convertToPixel({ yAxisIndex: 0 }, T),
799
+ text: x,
800
+ profitY: i.convertToPixel({ yAxisIndex: 0 }, A),
801
+ profitText: k,
802
+ lossY: i.convertToPixel({ yAxisIndex: 0 }, E),
803
+ lossText: U,
804
+ info: { info: F, config: { ...l, ...B }, event: { ...b } },
805
+ gridLeft: e,
806
+ gridRight: n,
807
+ echartsWidth: i.getWidth(),
808
+ echartsInstance: i
809
+ };
810
+ return [...N, $e(g)];
811
+ }, j)), r) {
812
+ const N = i.getOption(), d = N.dataset[0].source.klineData.slice(
813
+ N.dataZoom[0].startValue,
814
+ N.dataZoom[0].endValue + 1
815
+ ), T = {};
816
+ d.forEach((g) => {
817
+ T[g[1]] ? T[g[1]] += 1 : T[g[1]] = 1;
818
+ });
819
+ const x = d[d.length - 1][1], A = d.reduce((g, f) => g + f[1], 0) / d.length, k = x - A, E = et(d, 1, 50), U = tt(d), F = U ? k / U : 0, B = qe(d, 1, x);
820
+ j = [
821
+ ...j,
822
+ {
823
+ type: "group",
824
+ draggable: !1,
825
+ children: Object.keys(T).map((g) => ({
826
+ type: "line",
827
+ shape: {
828
+ x1: i.getWidth() - n - 100 * T[g],
829
+ y1: i.convertToPixel({ yAxisIndex: 0 }, g),
830
+ x2: i.getWidth() - n,
831
+ y2: i.convertToPixel({ yAxisIndex: 0 }, g)
832
+ },
833
+ style: {
834
+ stroke: "rgb(124,124,124)",
835
+ lineWidth: 1
836
+ },
837
+ z: 10
838
+ }))
839
+ },
840
+ {
841
+ type: "text",
842
+ x: e + 6,
843
+ y: i.getHeight() - o - 20,
844
+ style: {
845
+ fill: "#FFF",
846
+ text: `均值: ${h(A)}    距均值: ${h(
847
+ k
848
+ )}    中值: ${h(E)}    标准差: ${h(
849
+ U
850
+ )}    距均值/标准差: ${h(F)}    百分位: ${h(
851
+ B
852
+ )}%`,
853
+ lineWidth: 1,
854
+ opacity: 1
855
+ },
856
+ z: 10
857
+ }
858
+ ];
859
+ }
860
+ }
861
+ return { elements: j };
862
+ }, qe = (a, t, i) => {
863
+ const { round: e, add: n, subtract: o, multiply: z, divide: s } = re, l = a.map((j) => j[t]).sort((j, D) => j - D);
864
+ let r = 0;
865
+ for (let j = 0; j < l.length; j++)
866
+ if (l[j] === i) {
867
+ r = j;
868
+ break;
869
+ } else if (l[j] >= i) {
870
+ r = n(j, s(o(l[j + 1], l[j]), l[j]));
871
+ break;
872
+ }
873
+ return e(s(z(r, 100), a.length + 1));
874
+ }, et = (a, t, i) => {
875
+ const { round: e, add: n, subtract: o, multiply: z, divide: s } = re, l = a.map((c) => c[t]).sort((c, u) => c - u), r = z(a.length + 1, s(i, 100)), j = Math.floor(r), D = o(r, j);
876
+ return e(D === 0 ? l[r] : n(
877
+ l[j],
878
+ z(
879
+ o(
880
+ l[j >= a.length - 1 ? j : j + 1],
881
+ l[j]
882
+ ),
883
+ D
884
+ )
885
+ ));
886
+ };
887
+ function tt(a) {
888
+ const t = a.map((z) => z[1]), i = t.length;
889
+ let e = 0, n = 0;
890
+ for (const z of t)
891
+ e += z;
892
+ const o = e / i;
893
+ for (const z of t)
894
+ n += Math.pow(z - o, 2);
895
+ return Math.sqrt(n / i);
896
+ }
897
+ const nt = { class: "st-kline" }, ot = { class: "st-kline-header" }, it = 300, Mt = /* @__PURE__ */ Me({
898
+ __name: "index",
899
+ props: {
900
+ indicator: {
901
+ type: Object,
902
+ default: () => ({})
903
+ },
904
+ klineData: {
905
+ type: Array,
906
+ default: () => []
907
+ },
908
+ markData: {
909
+ type: Array,
910
+ default: () => []
911
+ },
912
+ lineData: {
913
+ type: Array,
914
+ default: () => []
915
+ },
916
+ netPositionData: {
917
+ type: Array,
918
+ default: () => []
919
+ },
920
+ relevanceData: {
921
+ type: Array,
922
+ default: () => []
923
+ },
924
+ priceTrendData: {
925
+ type: Array,
926
+ default: () => []
927
+ },
928
+ priceTrendPercentData: {
929
+ type: Array,
930
+ default: () => []
931
+ },
932
+ brushRange: {
933
+ type: Array,
934
+ default: () => []
935
+ },
936
+ defaultMenuData: {
937
+ type: Array,
938
+ default: () => []
939
+ },
940
+ isSelect: {
941
+ type: Boolean,
942
+ default: () => !1
943
+ },
944
+ config: {
945
+ type: Object,
946
+ default: () => ({})
947
+ }
948
+ },
949
+ setup(a) {
950
+ const t = a, i = {
951
+ totalBarCount: 2e3,
952
+ defaultShowBarCount: 200,
953
+ preBarCount: 800,
954
+ maxValueSpan: 1e4,
955
+ gridLeft: 60,
956
+ gridTop: 0,
957
+ gridRight: 60,
958
+ gridBottom: 30,
959
+ // 预警线配置
960
+ warningConfig: {
961
+ draggable: !1,
962
+ lineColor: "#fff",
963
+ textColor: "#fff"
964
+ },
965
+ // 持仓线配置
966
+ positionConfig: {
967
+ draggable: !1,
968
+ lineColor: "#e45d07",
969
+ textColor: "#fff"
970
+ },
971
+ // 条件单配置
972
+ conditionConfig: {
973
+ draggable: !1,
974
+ lineColor: "#fff",
975
+ textColor: "#fff",
976
+ profitLineColor: "#b71e44",
977
+ profitTextColor: "#fff",
978
+ lossLineColor: "#749b66",
979
+ lossTextColor: "#fff"
980
+ },
981
+ // Tips配置
982
+ tipsConfig: {
983
+ open: !0,
984
+ heigh: !0,
985
+ low: !0,
986
+ close: !0,
987
+ business: !0,
988
+ riseAndFall: !0
989
+ },
990
+ // 动态加载配置
991
+ dynamicLoadConfig: {
992
+ historyVisible: !1,
993
+ historyLoadCallBack: () => {
994
+ },
995
+ futureVisible: !1,
996
+ futureLoadCallBack: () => {
997
+ }
998
+ },
999
+ // 是否禁用鼠标滚轮缩放K线,在开启动态后续数据加载时,建议开启,否则会引起datazoom内部缩放拖拽触发后续加载冲突
1000
+ zoomLock: !1,
1001
+ // 是否启用计算收盘价分布统计功能
1002
+ isOpenDS: !1
1003
+ }, e = W(() => ({ ...i, ...t.config })), n = S(null), o = S(-1), z = W(() => {
1004
+ var g, f;
1005
+ if (n.value && ((f = (g = n.value.dataset[0]) == null ? void 0 : g.source) != null && f.klineData[o.value])) {
1006
+ const L = n.value.dataset[0].source.klineData[o.value], y = [], { open: Y, heigh: O, low: Q, close: R, business: Z, riseAndFall: G } = e.value.tipsConfig;
1007
+ if (Y && y.push({ label: "开", value: h(L[0]), color: "rgb(153, 153, 153)" }), O && y.push({ label: "高", value: h(L[3]), color: "rgb(153, 153, 153)" }), Q && y.push({ label: "低", value: h(L[2]), color: "rgb(153, 153, 153)" }), R && y.push({ label: "收", value: h(L[1]), color: "rgb(153, 153, 153)" }), Z && y.push({ label: "额", value: We(L[4]), color: "rgb(153, 153, 153)" }), G) {
1008
+ let P = ((L[1] - L[5]) / L[1] * 100).toFixed(2), _ = +P == 0 ? "white" : +P > 0 ? "red" : "#00ff00";
1009
+ y.push({ label: "涨跌", value: `${P}%`, color: _ });
1010
+ }
1011
+ return y;
1012
+ }
1013
+ return [];
1014
+ }), s = W(() => {
1015
+ var g, f;
1016
+ return n.value && ((f = (g = n.value.dataset[0]) == null ? void 0 : g.source) != null && f.indicatorData) ? n.value.dataset[0].source.indicatorData.reduce((L, y) => (y.data[o.value] && L.push({
1017
+ label: y.key,
1018
+ value: h(y.data[o.value]),
1019
+ color: y.color
1020
+ }), L), []) : [];
1021
+ }), l = W(() => {
1022
+ const g = [
1023
+ "#FFFFFF",
1024
+ "#FFDD00",
1025
+ "#FF00FF",
1026
+ "#00FF00",
1027
+ "#FF6000",
1028
+ "#1677FF",
1029
+ "#7C3CC9",
1030
+ "#FF0000",
1031
+ "#FB9A0E",
1032
+ "#00B7FF"
1033
+ ];
1034
+ if (t.priceTrendData.length > 0) {
1035
+ const f = [];
1036
+ return t.priceTrendData.forEach((L, y) => {
1037
+ var O;
1038
+ (L.data[o.value] ? h(L.data[o.value][1]) : null) !== null && f.push({
1039
+ label: L.name,
1040
+ value: h((O = L.data[o.value]) == null ? void 0 : O[1]),
1041
+ color: g[y]
1042
+ });
1043
+ }), f;
1044
+ }
1045
+ if (t.priceTrendPercentData.length > 0) {
1046
+ const f = [];
1047
+ return M.getOption().series.filter((y) => y.name.includes("二腿价格走势百分比图")).forEach((y, Y) => {
1048
+ var Q;
1049
+ (y.data[o.value] ? h(y.data[o.value][1]) : null) !== null && f.push({
1050
+ label: y.name.split("-")[1],
1051
+ value: `${h((Q = y.data[o.value]) == null ? void 0 : Q[1])}%`,
1052
+ color: g[Y]
1053
+ });
1054
+ }), f;
1055
+ }
1056
+ return [];
1057
+ });
1058
+ H(
1059
+ () => [t.klineData, t.indicator, t.markData, t.netPositionData, t.relevanceData],
1060
+ () => {
1061
+ r();
1062
+ },
1063
+ {
1064
+ deep: !0
1065
+ }
1066
+ ), H(
1067
+ () => t.lineData,
1068
+ async () => {
1069
+ J("st-kline组件消息:props.lineData监控,额外画线数据发生改变,重绘->line", {
1070
+ color: "red"
1071
+ }), r("line");
1072
+ },
1073
+ {
1074
+ deep: !0
1075
+ }
1076
+ ), H(
1077
+ () => t.brushRange,
1078
+ async () => {
1079
+ J("st-kline组件消息:props.brushRange监控,区域刷选数据发生改变,重绘->brush", {
1080
+ color: "red"
1081
+ }), r("brush");
1082
+ },
1083
+ {
1084
+ deep: !0
1085
+ }
1086
+ ), H(
1087
+ () => t.priceTrendData,
1088
+ async () => {
1089
+ r("priceTrend");
1090
+ },
1091
+ {
1092
+ deep: !0
1093
+ }
1094
+ ), H(
1095
+ () => t.priceTrendPercentData,
1096
+ async () => {
1097
+ r("priceTrendPercent");
1098
+ },
1099
+ {
1100
+ deep: !0
1101
+ }
1102
+ );
1103
+ const r = async (g) => {
1104
+ const L = (/* @__PURE__ */ new Map([
1105
+ // kline-K线绘制
1106
+ [
1107
+ "kline",
1108
+ async () => {
1109
+ const y = await ze(
1110
+ t.klineData,
1111
+ t.markData,
1112
+ t.indicator,
1113
+ e.value,
1114
+ t.netPositionData,
1115
+ t.relevanceData
1116
+ ), { graphic: Y } = M.getOption() ?? { graphic: [] };
1117
+ n.value = { ...y, graphic: Y }, M.setOption(n.value, !0), J("st-kline组件消息:K线绘制完毕-draw", { color: "green" });
1118
+ }
1119
+ ],
1120
+ // line-额外线条绘制
1121
+ [
1122
+ "line",
1123
+ () => {
1124
+ const y = M.getOption(), Y = Ke(t.lineData, e.value, M);
1125
+ n.value = { ...y, graphic: Y }, M.setOption(n.value, {
1126
+ replaceMerge: ["graphic"]
1127
+ }), J("st-kline组件消息:额外画线绘制完毕-draw", { color: "green" });
1128
+ }
1129
+ ],
1130
+ // brush-区域刷选
1131
+ [
1132
+ "brush",
1133
+ () => {
1134
+ const { brushRange: y } = t;
1135
+ y instanceof Array && y.length > 0 && (M.dispatchAction({
1136
+ type: "brush",
1137
+ areas: [
1138
+ {
1139
+ brushType: "lineX",
1140
+ coordRange: [y[0] + "", y[1] + ""],
1141
+ xAxisIndex: 0
1142
+ }
1143
+ ]
1144
+ }), J("st-kline组件消息:区域刷选绘制完毕-draw", { color: "green" }));
1145
+ }
1146
+ ],
1147
+ // 全部绘制
1148
+ [
1149
+ void 0,
1150
+ async () => {
1151
+ await r("kline"), await r("line"), await r("priceTrend"), await r("priceTrendPercent"), await r("brush");
1152
+ }
1153
+ ],
1154
+ // history-K线历史数据绘制
1155
+ [
1156
+ "history",
1157
+ async () => {
1158
+ const y = M.getOption(), Y = await ze(
1159
+ t.klineData,
1160
+ t.markData,
1161
+ t.indicator,
1162
+ e.value,
1163
+ t.netPositionData,
1164
+ t.relevanceData
1165
+ ), O = Y.dataset.source.klineData.length - y.dataset[0].source.klineData.length;
1166
+ M.setOption(
1167
+ {
1168
+ ...Y,
1169
+ dataZoom: [
1170
+ {
1171
+ type: "inside",
1172
+ xAxisIndex: [0, 0],
1173
+ zoomLock: e.value.zoomLock,
1174
+ maxValueSpan: e.value.maxValueSpan,
1175
+ startValue: y.dataZoom[0].startValue + O,
1176
+ endValue: y.dataZoom[0].endValue + O
1177
+ }
1178
+ ]
1179
+ },
1180
+ !0
1181
+ ), await r("priceTrend");
1182
+ }
1183
+ ],
1184
+ // future-K线后续数据绘制
1185
+ [
1186
+ "future",
1187
+ async () => {
1188
+ const y = M.getOption(), Y = await ze(
1189
+ t.klineData,
1190
+ t.markData,
1191
+ t.indicator,
1192
+ e.value,
1193
+ t.netPositionData,
1194
+ t.relevanceData
1195
+ );
1196
+ Y.dataZoom[0].start = (t.klineData.length - y.dataZoom[0].endValue + y.dataZoom[0].startValue) / t.klineData.length * 100, M.setOption(Y, !0), await r("priceTrend");
1197
+ }
1198
+ ],
1199
+ // priceTrend-二腿价格趋势绘制
1200
+ [
1201
+ "priceTrend",
1202
+ () => {
1203
+ if (t.priceTrendData.length === 0)
1204
+ return;
1205
+ const y = M.getOption(), Y = [
1206
+ "#FFFFFF",
1207
+ "#FFDD00",
1208
+ "#FF00FF",
1209
+ "#00FF00",
1210
+ "#FF6000",
1211
+ "#1677FF",
1212
+ "#7C3CC9",
1213
+ "#FF0000",
1214
+ "#FB9A0E",
1215
+ "#00B7FF"
1216
+ ], O = t.priceTrendData.reduce((Q, R, Z) => {
1217
+ const { name: G, data: P } = R, _ = {
1218
+ name: `二腿价格走势图-${G}`,
1219
+ type: "line",
1220
+ data: P,
1221
+ symbol: "none",
1222
+ yAxisIndex: 1,
1223
+ connectNulls: !0,
1224
+ itemStyle: {
1225
+ color: Y[Z]
1226
+ },
1227
+ lineStyle: {
1228
+ type: "dashed",
1229
+ // 虚线
1230
+ width: 1
1231
+ }
1232
+ };
1233
+ return Q.push(_), Q;
1234
+ }, []);
1235
+ n.value = { ...y, series: [...y.series, ...O] }, M.setOption(n.value, {
1236
+ replaceMerge: ["series"]
1237
+ });
1238
+ }
1239
+ ],
1240
+ // priceTrendPercent-二腿价格趋势百分比绘制-初始绘制
1241
+ [
1242
+ "priceTrendPercent",
1243
+ async () => {
1244
+ if (t.priceTrendPercentData.length === 0)
1245
+ return;
1246
+ const y = M.getOption(), Y = [
1247
+ "#FFFFFF",
1248
+ "#FFDD00",
1249
+ "#FF00FF",
1250
+ "#00FF00",
1251
+ "#FF6000",
1252
+ "#1677FF",
1253
+ "#7C3CC9",
1254
+ "#FF0000",
1255
+ "#FB9A0E",
1256
+ "#00B7FF"
1257
+ ], O = y.dataZoom[0].startValue, Q = t.priceTrendPercentData.reduce((R, Z, G) => {
1258
+ const { name: P, data: _ } = Z, ee = _.length > e.value.totalBarCount ? _.slice(_.length - e.value.totalBarCount) : _, te = ee[O][1], me = ee.map((Te) => [Te[0], (Te[1] - te) / te * 100]), we = {
1259
+ name: `二腿价格走势百分比图-${P}`,
1260
+ type: "line",
1261
+ data: me,
1262
+ symbol: "none",
1263
+ yAxisIndex: 1,
1264
+ connectNulls: !0,
1265
+ itemStyle: {
1266
+ color: Y[G]
1267
+ },
1268
+ lineStyle: {
1269
+ type: "dashed",
1270
+ // 虚线
1271
+ width: 1
1272
+ }
1273
+ };
1274
+ return R.push(we), R;
1275
+ }, []);
1276
+ y.series = [...y.series.filter((R) => !R.name.includes("二腿价格走势百分比图")), ...Q], M.setOption(y, !0);
1277
+ }
1278
+ ]
1279
+ ])).get(g);
1280
+ L instanceof Function && await L();
1281
+ }, j = S(!1), D = S([]), c = (g) => {
1282
+ const { callBack: f } = g;
1283
+ f instanceof Function && f(M, j);
1284
+ }, u = () => {
1285
+ D.value = t.defaultMenuData;
1286
+ }, I = S();
1287
+ let M, p;
1288
+ const m = (g, f) => {
1289
+ var L, y;
1290
+ if (g)
1291
+ o.value = typeof ((L = g == null ? void 0 : g.batch[0]) == null ? void 0 : L.dataIndex) == "number" ? (y = g == null ? void 0 : g.batch[0]) == null ? void 0 : y.dataIndex : -1;
1292
+ else {
1293
+ const Y = f.getOption();
1294
+ Y.dataZoom instanceof Array && (o.value = Y.dataZoom[0].endValue);
1295
+ }
1296
+ };
1297
+ let w = null, b = !1, N = S(!1), d = !1, T = S(!1);
1298
+ const x = async (g) => {
1299
+ const f = g.batch ? g.batch[0].start * e.value.totalBarCount : g.startValue;
1300
+ e.value.dynamicLoadConfig.historyVisible && f <= 100 && !b && !N.value && (b = !0, await e.value.dynamicLoadConfig.historyLoadCallBack(N), await r("history"), b = !1);
1301
+ const L = g.batch ? g.batch[0].end === 100 : g.endValue >= t.klineData.length - e.value.preBarCount - 1, y = g.actionIsWheel;
1302
+ e.value.dynamicLoadConfig.futureVisible && L && !d && !T.value && !y && (d = !0, await e.value.dynamicLoadConfig.futureLoadCallBack(T), await r("future"), d = !1), clearTimeout(w), w = setTimeout(() => {
1303
+ r("line"), r("priceTrendPercent"), clearTimeout(w), w = null;
1304
+ }, it);
1305
+ };
1306
+ let A = null;
1307
+ const k = (g) => {
1308
+ A = setTimeout(() => {
1309
+ var f;
1310
+ if (g.componentType === "graphic") {
1311
+ const { oncontextmenu: L } = ((f = g.info) == null ? void 0 : f.event) ?? {};
1312
+ L instanceof Function && L(g, g.info, D);
1313
+ }
1314
+ clearTimeout(A), A = null;
1315
+ });
1316
+ }, E = () => {
1317
+ M.on("highlight", (g) => {
1318
+ m(g, M);
1319
+ }), M.on("globalout", () => {
1320
+ m(null, M);
1321
+ }), M.on("contextmenu", (g) => {
1322
+ k(g);
1323
+ }), M.on("datazoom", (g) => {
1324
+ x(g);
1325
+ });
1326
+ }, U = () => {
1327
+ M.off("highlight"), M.off("globalout"), M.off("contextmenu"), M.off("datazoom");
1328
+ }, F = (g) => {
1329
+ if (!M || !(g.ctrlKey || t.isSelect))
1330
+ return;
1331
+ const f = M.getOption();
1332
+ let { startValue: L, endValue: y, start: Y, end: O } = f.dataZoom[0];
1333
+ const Q = () => {
1334
+ L !== 0 && (L = L - 1, y = y - 1, M.dispatchAction({
1335
+ type: "dataZoom",
1336
+ startValue: L,
1337
+ endValue: y,
1338
+ maxValueSpan: e.value.maxValueSpan
1339
+ }));
1340
+ }, R = () => {
1341
+ if (e.value.dynamicLoadConfig.futureVisible && !d && !T.value)
1342
+ L = L + 1, y = y + 1, M.dispatchAction({
1343
+ type: "dataZoom",
1344
+ startValue: L,
1345
+ endValue: y,
1346
+ maxValueSpan: e.value.maxValueSpan
1347
+ });
1348
+ else {
1349
+ if (y === f.xAxis[0].data.length - 1)
1350
+ return;
1351
+ L = L + 1, y = y + 1, M.dispatchAction({
1352
+ type: "dataZoom",
1353
+ startValue: L,
1354
+ endValue: y,
1355
+ maxValueSpan: e.value.maxValueSpan
1356
+ });
1357
+ }
1358
+ }, Z = () => {
1359
+ if (y - L < 5)
1360
+ return;
1361
+ const ee = Math.floor((o.value - L) / 2) + 1, te = Math.floor((y - o.value) / 2) + 1;
1362
+ L = L + ee, y = y - te, M.dispatchAction({
1363
+ type: "dataZoom",
1364
+ startValue: L,
1365
+ endValue: y,
1366
+ actionIsWheel: !0,
1367
+ // 标记为缩放
1368
+ maxValueSpan: e.value.maxValueSpan
1369
+ });
1370
+ }, G = () => {
1371
+ Y = Y - (O - Y) / 4, M.dispatchAction({
1372
+ type: "dataZoom",
1373
+ start: Y,
1374
+ end: O,
1375
+ actionIsWheel: !0,
1376
+ // 标记为缩放
1377
+ maxValueSpan: e.value.maxValueSpan
1378
+ });
1379
+ }, _ = (/* @__PURE__ */ new Map([
1380
+ ["ArrowLeft", Q],
1381
+ ["ArrowRight", R],
1382
+ ["ArrowUp", Z],
1383
+ ["ArrowDown", G]
1384
+ ])).get(g.code);
1385
+ _ instanceof Function && _();
1386
+ }, B = async () => {
1387
+ let g = !0;
1388
+ M = oe.init(I.value), await r(), D.value = t.defaultMenuData, o.value = M.getOption().dataZoom[0].endValue ?? -1, E(), p = new ResizeObserver(() => {
1389
+ if (g) {
1390
+ g = null;
1391
+ return;
1392
+ }
1393
+ M.resize(), r("line");
1394
+ }), p.observe(I.value), window.addEventListener("keydown", F);
1395
+ };
1396
+ return de(() => {
1397
+ B();
1398
+ }), ge(() => {
1399
+ U(), window.removeEventListener("keydown", F), M.dispose(), p.disconnect(), p = null;
1400
+ }), (g, f) => {
1401
+ const L = he, y = Ce;
1402
+ return C(), v("div", nt, [
1403
+ K("div", ot, [
1404
+ V(se, { data: z.value }, null, 8, ["data"]),
1405
+ V(se, { data: s.value }, null, 8, ["data"]),
1406
+ V(se, { data: l.value }, null, 8, ["data"])
1407
+ ]),
1408
+ V(Re, {
1409
+ class: "st-kline-body",
1410
+ onCloseContextMenuCallBack: u
1411
+ }, {
1412
+ popover: X(() => [
1413
+ V(y, { class: "menu" }, {
1414
+ default: X(() => [
1415
+ (C(!0), v(ae, null, le(D.value, (Y) => (C(), Ae(L, {
1416
+ key: Y.label,
1417
+ index: Y.label,
1418
+ class: "menuItem",
1419
+ onClick: (O) => c(Y)
1420
+ }, {
1421
+ default: X(() => [
1422
+ Oe(q(Y.label), 1)
1423
+ ]),
1424
+ _: 2
1425
+ }, 1032, ["index", "onClick"]))), 128))
1426
+ ]),
1427
+ _: 1
1428
+ })
1429
+ ]),
1430
+ default: X(() => [
1431
+ K("div", {
1432
+ ref_key: "echartsRef",
1433
+ ref: I,
1434
+ class: ke(j.value ? "st-kline-chart cursorPen" : "st-kline-chart")
1435
+ }, null, 2)
1436
+ ]),
1437
+ _: 1
1438
+ })
1439
+ ]);
1440
+ };
1441
+ }
1442
+ });
1443
+ const at = /* @__PURE__ */ $(Mt, [["__scopeId", "data-v-7f014d0e"]]), lt = { class: "kline-tips" }, rt = /* @__PURE__ */ Me({
1444
+ __name: "index",
1445
+ props: {
1446
+ // 提示数据
1447
+ data: {
1448
+ type: Array,
1449
+ require: !0
1450
+ }
1451
+ },
1452
+ setup(a) {
1453
+ return (t, i) => (C(), v("div", lt, [
1454
+ (C(!0), v(ae, null, le(a.data, (e, n) => (C(), v("div", {
1455
+ key: n,
1456
+ class: "kline-tips-item",
1457
+ style: ye({ color: e.color })
1458
+ }, q(e.label) + " " + q(e.value), 5))), 128))
1459
+ ]));
1460
+ }
1461
+ });
1462
+ const je = /* @__PURE__ */ $(rt, [["__scopeId", "data-v-dc7d381b"]]);
1463
+ const st = { class: "klineSub" }, ct = { class: "klineSub-tips" }, ut = {
1464
+ key: 0,
1465
+ class: "klineSub-tips-select"
1466
+ }, Nt = {
1467
+ __name: "index",
1468
+ props: {
1469
+ data: { type: Object, require: !0 },
1470
+ activeIndex: { type: [Number, String], require: !0 },
1471
+ modelValue: { type: String, required: !0 },
1472
+ // 副图指标
1473
+ subIndicatorList: { type: Array, required: !0 }
1474
+ // 副图指标列表
1475
+ },
1476
+ emits: ["update:modelValue"],
1477
+ setup(a, { expose: t, emit: i }) {
1478
+ const { round: e } = re;
1479
+ let n, o;
1480
+ const z = i, s = a, l = S(), r = W({
1481
+ get() {
1482
+ return s.modelValue;
1483
+ },
1484
+ set(c) {
1485
+ z("update:modelValue", c);
1486
+ }
1487
+ }), j = W(() => {
1488
+ var I;
1489
+ const { data: c, activeIndex: u } = s;
1490
+ return ((I = c == null ? void 0 : c.subIndicator) == null ? void 0 : I.map((M) => ({ label: M.key, color: M.color, value: M.data[u] || "-" }))) || [];
1491
+ });
1492
+ de(() => {
1493
+ n = oe.init(l.value);
1494
+ let c = !0;
1495
+ o = new ResizeObserver(() => {
1496
+ if (c) {
1497
+ c = null;
1498
+ return;
1499
+ }
1500
+ n.resize();
1501
+ }), o.observe(l.value);
1502
+ }), ge(() => {
1503
+ n.dispose(), o.disconnect(), o = null;
1504
+ });
1505
+ const D = (c, u) => {
1506
+ const I = c[u], M = u === 0 ? c[u] : c[u - 1];
1507
+ return I[0] === I[1] ? I[0] >= M[1] ? {
1508
+ color: "transparent",
1509
+ borderColor: "#FF0000"
1510
+ } : {
1511
+ color: "#00FFFF"
1512
+ } : I[1] > I[0] ? {
1513
+ color: "transparent",
1514
+ borderColor: "#FF0000"
1515
+ } : {
1516
+ color: "#00FFFF"
1517
+ };
1518
+ };
1519
+ return t({
1520
+ connect: (c) => {
1521
+ oe.connect([c, n]);
1522
+ },
1523
+ // 联动
1524
+ draw: (c, u) => {
1525
+ Ye(() => {
1526
+ const { startValue: I, endValue: M, maxValueSpan: p } = c, { leftYAxisRange: m, rightYAxisRange: w } = s.data.subIndicator[0], b = s.data.subIndicator.map((N) => {
1527
+ if (N.series === "bar")
1528
+ return {
1529
+ name: "subMain",
1530
+ xAxisIndex: 0,
1531
+ yAxisIndex: 1,
1532
+ type: "bar",
1533
+ silent: !0,
1534
+ symbol: "none",
1535
+ data: N.data.map((d, T) => N.seriesColor === "kline" ? {
1536
+ value: d,
1537
+ itemStyle: D(s.data.data, T)
1538
+ } : N.seriesColor === "value" ? {
1539
+ value: d,
1540
+ itemStyle: {
1541
+ color: d >= 0 ? "#FF0000" : "#00FFFF"
1542
+ }
1543
+ } : {
1544
+ value: d,
1545
+ itemStyle: {
1546
+ color: N.seriesColor
1547
+ }
1548
+ })
1549
+ };
1550
+ if (N.series === "line")
1551
+ return {
1552
+ xAxisIndex: 0,
1553
+ yAxisIndex: N.yAxis === "right" ? 2 : 1,
1554
+ name: N.key,
1555
+ type: "line",
1556
+ silent: !0,
1557
+ symbol: "none",
1558
+ data: N.data,
1559
+ lineStyle: {
1560
+ width: 1
1561
+ },
1562
+ itemStyle: {
1563
+ color: N.color
1564
+ }
1565
+ };
1566
+ });
1567
+ n.setOption(
1568
+ {
1569
+ animation: !1,
1570
+ grid: {
1571
+ left: `${u.gridLeft}px`,
1572
+ top: "10px",
1573
+ right: `${u.gridRight}px`,
1574
+ bottom: "20px"
1575
+ },
1576
+ dataZoom: [
1577
+ {
1578
+ type: "inside",
1579
+ startValue: I,
1580
+ endValue: M,
1581
+ maxValueSpan: p
1582
+ }
1583
+ ],
1584
+ tooltip: {
1585
+ trigger: "axis",
1586
+ appendToBody: !0,
1587
+ confine: !0,
1588
+ axisPointer: {
1589
+ type: "cross",
1590
+ label: {
1591
+ rich: {},
1592
+ formatter: (N) => {
1593
+ const { axisDimension: d, value: T } = N;
1594
+ if (d === "x")
1595
+ return T;
1596
+ if (N.axisIndex === 1)
1597
+ return String(e(T));
1598
+ }
1599
+ }
1600
+ },
1601
+ formatter: () => ""
1602
+ },
1603
+ xAxis: {
1604
+ type: "category",
1605
+ data: s.data.time,
1606
+ axisLine: {
1607
+ show: !0
1608
+ },
1609
+ splitLine: {
1610
+ show: !1
1611
+ },
1612
+ axisLabel: {
1613
+ show: !0,
1614
+ formatter: (N) => N
1615
+ }
1616
+ },
1617
+ yAxis: [
1618
+ {
1619
+ position: "right"
1620
+ },
1621
+ {
1622
+ position: "left",
1623
+ min: m === "cover" ? (N) => N.min : null,
1624
+ max: m === "cover" ? (N) => N.max : null,
1625
+ splitNumber: 1,
1626
+ axisLine: {
1627
+ show: !0
1628
+ },
1629
+ splitLine: {
1630
+ show: !0,
1631
+ lineStyle: {
1632
+ type: "dotted",
1633
+ color: "#333"
1634
+ }
1635
+ }
1636
+ },
1637
+ {
1638
+ position: "right",
1639
+ min: w === "cover" ? (N) => N.min : null,
1640
+ max: w === "cover" ? (N) => N.max : null,
1641
+ splitNumber: 1,
1642
+ axisLine: {
1643
+ show: !1
1644
+ },
1645
+ splitLine: {
1646
+ show: !1
1647
+ },
1648
+ axisLabel: {
1649
+ show: !1
1650
+ }
1651
+ }
1652
+ ],
1653
+ series: b
1654
+ },
1655
+ !0
1656
+ );
1657
+ });
1658
+ }
1659
+ // 重置
1660
+ }), (c, u) => {
1661
+ const I = Ee, M = Se;
1662
+ return C(), v("div", st, [
1663
+ K("div", ct, [
1664
+ j.value.length ? (C(), v("div", ut, [
1665
+ V(M, {
1666
+ modelValue: r.value,
1667
+ "onUpdate:modelValue": u[0] || (u[0] = (p) => r.value = p),
1668
+ size: "small",
1669
+ "popper-class": "element-dark",
1670
+ class: "element-dark subIndicator"
1671
+ }, {
1672
+ default: X(() => [
1673
+ (C(!0), v(ae, null, le(a.subIndicatorList, (p) => (C(), Ae(I, {
1674
+ key: p.value,
1675
+ label: p.label,
1676
+ value: p.value
1677
+ }, null, 8, ["label", "value"]))), 128))
1678
+ ]),
1679
+ _: 1
1680
+ }, 8, ["modelValue"])
1681
+ ])) : xe("", !0),
1682
+ V(je, { data: j.value }, null, 8, ["data"])
1683
+ ]),
1684
+ K("div", {
1685
+ class: "klineSub-chart",
1686
+ ref_key: "subChartRef",
1687
+ ref: l
1688
+ }, null, 512)
1689
+ ]);
1690
+ };
1691
+ }
1692
+ }, zt = /* @__PURE__ */ $(Nt, [["__scopeId", "data-v-aba58678"]]);
1693
+ const jt = { class: "kline-tips" }, yt = {
1694
+ __name: "index",
1695
+ props: {
1696
+ // 提示数据
1697
+ data: {
1698
+ type: Object,
1699
+ require: !0
1700
+ },
1701
+ activeIndex: {
1702
+ type: [Number, String],
1703
+ require: !0
1704
+ }
1705
+ },
1706
+ setup(a) {
1707
+ const { round: t, formatValue: i } = re, e = a, n = W(() => {
1708
+ const { data: z, activeIndex: s } = e;
1709
+ if (z.data && z.data[s]) {
1710
+ const l = z.data[s], r = [
1711
+ { label: "开", value: t(l[0]) },
1712
+ { label: "高", value: t(l[3]) },
1713
+ { label: "低", value: t(l[2]) },
1714
+ { label: "收", value: t(l[1]) }
1715
+ ];
1716
+ l[4] !== null && r.push({ label: "额", value: i(l[4]) });
1717
+ let j;
1718
+ return l[6] > 0 ? j = "red" : l[6] < 0 && (j = "green"), r.push({ label: "涨跌", value: `${t(l[6])}%`, color: j }), r;
1719
+ }
1720
+ return [];
1721
+ }), o = W(() => {
1722
+ var l;
1723
+ const { data: z, activeIndex: s } = e;
1724
+ return ((l = z == null ? void 0 : z.mainIndicator) == null ? void 0 : l.map((r) => ({ label: r.key, value: t(r.data[s]), color: r.color }))) || [];
1725
+ });
1726
+ return (z, s) => (C(), v("div", jt, [
1727
+ V(je, { data: n.value }, null, 8, ["data"]),
1728
+ V(je, { data: o.value }, null, 8, ["data"])
1729
+ ]));
1730
+ }
1731
+ }, dt = /* @__PURE__ */ $(yt, [["__scopeId", "data-v-a12855fe"]]), gt = {
1732
+ __name: "index",
1733
+ setup(a, { expose: t }) {
1734
+ return t({
1735
+ // 键盘事件处理
1736
+ handleKeyDown: (i, e) => {
1737
+ let { startValue: n, endValue: o, maxIndex: z } = e;
1738
+ if (i.code === "ArrowLeft") {
1739
+ if (n === 0)
1740
+ return;
1741
+ n = n - 1, o = o - 1;
1742
+ } else if (i.code === "ArrowRight") {
1743
+ if (o === z)
1744
+ return;
1745
+ n = n + 1, o = o + 1;
1746
+ } else if (i.code === "ArrowUp") {
1747
+ if (o - n < 5)
1748
+ return;
1749
+ const s = Math.floor((o - n) / 2) + 1;
1750
+ n = n + s, o - n < 5 && (n = o - 4);
1751
+ } else if (i.code === "ArrowDown") {
1752
+ const s = Math.min(500, o - n);
1753
+ n = n - s - 1;
1754
+ }
1755
+ return {
1756
+ startValue: n,
1757
+ endValue: o
1758
+ };
1759
+ },
1760
+ // 合并数据
1761
+ mergeData: (i, e) => ({
1762
+ time: [...i.time, ...e.time.slice(1)],
1763
+ data: [...i.data, ...e.data.slice(1)],
1764
+ mainIndicator: i.mainIndicator.map((n, o) => ({
1765
+ ...n,
1766
+ data: [...n.data, ...e.mainIndicator[o].data.slice(1)]
1767
+ })),
1768
+ subIndicator: i.subIndicator.map((n, o) => ({
1769
+ ...n,
1770
+ data: [...n.data, ...e.subIndicator[o].data.slice(1)]
1771
+ }))
1772
+ }),
1773
+ // 根据时间解析dataZoom
1774
+ getDataZoomInfoByTime: (i) => {
1775
+ const { showStartTime: e, showEndTime: n, maxShowDays: o } = i;
1776
+ let z = -1, s = -1, l = {};
1777
+ return i.time.forEach((r, j) => {
1778
+ const D = r.split(" ")[0];
1779
+ l[D] = l[D] || 0, l[D] += 1, z === -1 && new Date(r) >= new Date(e) && (z = j), s === -1 && new Date(r) >= new Date(n) && (s = j);
1780
+ }), s = s === -1 ? i.time.length - 1 : s, {
1781
+ startValue: z,
1782
+ endValue: s,
1783
+ maxValueSpan: Math.max(...Object.values(l)) * o
1784
+ };
1785
+ }
1786
+ }), (i, e) => null;
1787
+ }
1788
+ };
1789
+ const Tt = {
1790
+ __name: "index",
1791
+ props: {
1792
+ data: { type: Array, default: () => [] }
1793
+ // 时间数据
1794
+ },
1795
+ emits: ["change"],
1796
+ setup(a, { expose: t, emit: i }) {
1797
+ let e, n, o = null;
1798
+ const z = i, s = a, l = S();
1799
+ H(
1800
+ () => s.data,
1801
+ () => {
1802
+ D();
1803
+ },
1804
+ { deep: !0 }
1805
+ ), de(() => {
1806
+ e = oe.init(l.value), r(), D();
1807
+ let c = !0;
1808
+ n = new ResizeObserver(() => {
1809
+ if (c) {
1810
+ c = null;
1811
+ return;
1812
+ }
1813
+ e.resize();
1814
+ }), n.observe(l.value);
1815
+ }), ge(() => {
1816
+ e.off("datazoom"), e.dispose(), n.disconnect(), n = null;
1817
+ });
1818
+ const r = () => {
1819
+ e.on("datazoom", (c) => {
1820
+ c.dataZoomId && (clearTimeout(o), o = setTimeout(() => {
1821
+ const { data: u } = s, { start: I, end: M } = c, p = Math.floor(I * u.length / 100), m = M === 100 ? u.length - 1 : Math.floor(M * u.length / 100);
1822
+ j(p, m), clearTimeout(o);
1823
+ }, 100));
1824
+ });
1825
+ }, j = (c, u) => {
1826
+ const I = s.data;
1827
+ if (I.length === 0)
1828
+ return;
1829
+ const M = I[c][0].split(" ")[0], p = I[u][0].split(" ")[0];
1830
+ z("change", {
1831
+ startTime: `${M} 00:00:00`,
1832
+ endTime: `${p} 24:00:00`
1833
+ });
1834
+ }, D = () => {
1835
+ const { data: c } = s;
1836
+ if (c.length === 0)
1837
+ return;
1838
+ const u = c.map((M) => M[0].split(" ")[0]), I = c.map((M) => M[1]);
1839
+ e.setOption({
1840
+ grid: {
1841
+ height: 0,
1842
+ left: "80px",
1843
+ right: "80px"
1844
+ },
1845
+ xAxis: {
1846
+ type: "category",
1847
+ data: u,
1848
+ show: !1
1849
+ },
1850
+ yAxis: {
1851
+ type: "value"
1852
+ },
1853
+ series: [
1854
+ {
1855
+ data: I,
1856
+ type: "line"
1857
+ }
1858
+ ]
1859
+ }, !0);
1860
+ };
1861
+ return t({
1862
+ resetSlide: (c, u, I) => {
1863
+ let M = -1, p = -1;
1864
+ s.data.forEach((m, w) => {
1865
+ M === -1 && m[0] === c ? M = w : M === -1 && new Date(m[0]) > new Date(c) && (M = w - 1), (p === -1 && m[0] === u || p === -1 && new Date(m[0]) > new Date(u)) && (p = w);
1866
+ }), p = p === -1 ? s.data.length - 1 : p, e.setOption({
1867
+ dataZoom: [
1868
+ {
1869
+ show: !0,
1870
+ startValue: M,
1871
+ endValue: p,
1872
+ maxValueSpan: I,
1873
+ textStyle: {
1874
+ color: "#ccc"
1875
+ }
1876
+ },
1877
+ {
1878
+ type: "inside",
1879
+ startValue: M,
1880
+ endValue: p,
1881
+ maxValueSpan: I
1882
+ }
1883
+ ]
1884
+ });
1885
+ },
1886
+ // 重置
1887
+ resize: () => {
1888
+ e == null || e.resize();
1889
+ }
1890
+ }), (c, u) => (C(), v("div", {
1891
+ class: "klineSlide",
1892
+ ref_key: "slideChartRef",
1893
+ ref: l
1894
+ }, null, 512));
1895
+ }
1896
+ }, Dt = /* @__PURE__ */ $(Tt, [["__scopeId", "data-v-7a2f3dd0"]]), Vt = {
1897
+ install(a) {
1898
+ a.component("st-kline", at), a.component("st-kline-sub-new", zt), a.component("st-kline-tips-new", dt), a.component("st-kline-slide-new", Dt), a.component("st-kline-utils-new", gt);
1899
+ }
1900
+ };
1901
+ export {
1902
+ Vt as default
1903
+ };