bitboss-ui 2.0.137 → 2.0.141

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 (245) hide show
  1. package/dist/index100.js +9 -9
  2. package/dist/index109.js +2 -2
  3. package/dist/index11.js +11 -11
  4. package/dist/index111.js +12 -12
  5. package/dist/index119.js +2 -2
  6. package/dist/index12.js +5 -5
  7. package/dist/index121.js +6 -6
  8. package/dist/index125.js +1 -1
  9. package/dist/index127.js +1 -1
  10. package/dist/index128.js +1 -1
  11. package/dist/index129.js +1 -1
  12. package/dist/index13.js +2 -2
  13. package/dist/index131.js +1 -1
  14. package/dist/index132.js +2 -2
  15. package/dist/index133.js +9 -25
  16. package/dist/index134.js +25 -2
  17. package/dist/index135.js +2 -5
  18. package/dist/index136.js +5 -9
  19. package/dist/index137.js +8 -5
  20. package/dist/index138.js +6 -3
  21. package/dist/index139.js +1 -1
  22. package/dist/index140.js +1 -1
  23. package/dist/index141.js +1 -1
  24. package/dist/index142.js +1 -1
  25. package/dist/index143.js +1 -1
  26. package/dist/index144.js +1 -1
  27. package/dist/index145.js +1 -1
  28. package/dist/index146.js +1 -1
  29. package/dist/index147.js +1 -1
  30. package/dist/index148.js +1 -1
  31. package/dist/index149.js +1 -1
  32. package/dist/index15.js +36 -35
  33. package/dist/index150.js +1 -1
  34. package/dist/index151.js +1 -1
  35. package/dist/index152.js +1 -1
  36. package/dist/index153.js +1 -1
  37. package/dist/index154.js +1 -1
  38. package/dist/index155.js +1 -1
  39. package/dist/index156.js +1 -1
  40. package/dist/index157.js +1 -1
  41. package/dist/index158.js +1 -1
  42. package/dist/index159.js +1 -1
  43. package/dist/index160.js +1 -1
  44. package/dist/index161.js +1 -1
  45. package/dist/index162.js +1 -1
  46. package/dist/index163.js +1 -1
  47. package/dist/index164.js +1 -1
  48. package/dist/index165.js +2 -2
  49. package/dist/{index195.js → index166.js} +1 -1
  50. package/dist/index17.js +3 -3
  51. package/dist/index170.js +1 -1
  52. package/dist/index171.js +1 -1
  53. package/dist/index172.js +1 -1
  54. package/dist/index173.js +1 -1
  55. package/dist/index174.js +1 -1
  56. package/dist/index175.js +1 -1
  57. package/dist/index176.js +2 -2
  58. package/dist/index177.js +5 -0
  59. package/dist/index179.js +2 -3
  60. package/dist/index180.js +1 -1
  61. package/dist/index181.js +1 -1
  62. package/dist/index182.js +1 -1
  63. package/dist/index183.js +1 -1
  64. package/dist/index184.js +1 -1
  65. package/dist/index185.js +1 -1
  66. package/dist/index186.js +1 -1
  67. package/dist/index187.js +1 -1
  68. package/dist/index188.js +3 -2
  69. package/dist/index189.js +2 -3
  70. package/dist/index19.js +8 -8
  71. package/dist/index190.js +1 -1
  72. package/dist/index191.js +1 -1
  73. package/dist/index192.js +5 -0
  74. package/dist/index196.js +1 -1
  75. package/dist/index197.js +1 -1
  76. package/dist/index198.js +1 -1
  77. package/dist/index199.js +1 -1
  78. package/dist/index200.js +1 -1
  79. package/dist/index201.js +1 -1
  80. package/dist/index202.js +1 -1
  81. package/dist/index203.js +1 -1
  82. package/dist/index204.js +1 -1
  83. package/dist/index205.js +3 -2
  84. package/dist/index206.js +115 -5
  85. package/dist/index207.js +2 -16
  86. package/dist/index208.js +2 -16
  87. package/dist/index209.js +8 -19
  88. package/dist/index21.js +16 -16
  89. package/dist/index210.js +3 -15
  90. package/dist/index211.js +2 -19
  91. package/dist/index212.js +4 -27
  92. package/dist/index213.js +2 -3
  93. package/dist/index214.js +3 -2
  94. package/dist/index215.js +41 -8
  95. package/dist/index216.js +5 -249
  96. package/dist/index217.js +7 -52
  97. package/dist/index218.js +11 -40
  98. package/dist/index219.js +13 -5
  99. package/dist/index220.js +3 -60
  100. package/dist/index221.js +85 -12
  101. package/dist/index223.js +29 -65
  102. package/dist/index224.js +19 -0
  103. package/dist/index225.js +51 -13
  104. package/dist/index226.js +15 -125
  105. package/dist/index227.js +12 -2
  106. package/dist/index228.js +15 -40
  107. package/dist/index229.js +5 -20
  108. package/dist/index23.js +16 -16
  109. package/dist/index230.js +16 -6
  110. package/dist/index231.js +16 -94
  111. package/dist/index232.js +21 -0
  112. package/dist/index233.js +15 -2
  113. package/dist/index234.js +19 -2
  114. package/dist/index235.js +27 -4
  115. package/dist/index236.js +2 -2
  116. package/dist/index237.js +243 -79
  117. package/dist/index238.js +54 -0
  118. package/dist/index239.js +44 -29
  119. package/dist/index240.js +5 -17
  120. package/dist/index241.js +59 -50
  121. package/dist/index242.js +65 -15
  122. package/dist/index244.js +13 -16
  123. package/dist/index245.js +3 -114
  124. package/dist/index246.js +20 -4
  125. package/dist/index247.js +86 -192
  126. package/dist/index249.js +200 -3
  127. package/dist/index25.js +83 -82
  128. package/dist/index251.js +125 -15
  129. package/dist/index252.js +2 -2
  130. package/dist/index253.js +2 -2
  131. package/dist/index254.js +2 -18
  132. package/dist/index255.js +2 -126
  133. package/dist/index256.js +2 -2
  134. package/dist/index258.js +2 -2
  135. package/dist/index260.js +17 -11
  136. package/dist/index261.js +124 -226
  137. package/dist/index262.js +11 -368
  138. package/dist/index263.js +228 -10
  139. package/dist/index264.js +368 -2
  140. package/dist/index265.js +10 -281
  141. package/dist/index266.js +3 -6
  142. package/dist/index267.js +9 -2
  143. package/dist/index268.js +23 -2
  144. package/dist/index269.js +9 -2
  145. package/dist/index27.js +1 -1
  146. package/dist/index270.js +6 -2
  147. package/dist/index271.js +16 -2
  148. package/dist/index272.js +28 -2
  149. package/dist/index273.js +9 -2
  150. package/dist/index274.js +8 -2
  151. package/dist/index275.js +4 -2
  152. package/dist/index276.js +431 -2
  153. package/dist/index277.js +1 -1
  154. package/dist/index278.js +85 -24
  155. package/dist/index279.js +7 -22
  156. package/dist/index280.js +13 -0
  157. package/dist/index281.js +224 -7
  158. package/dist/index282.js +3 -7
  159. package/dist/index283.js +17 -11
  160. package/dist/index284.js +200 -224
  161. package/dist/index285.js +281 -3
  162. package/dist/index286.js +8 -0
  163. package/dist/index287.js +2 -3
  164. package/dist/index288.js +2 -17
  165. package/dist/index289.js +2 -9
  166. package/dist/index29.js +4 -4
  167. package/dist/index290.js +2 -4
  168. package/dist/index291.js +2 -2
  169. package/dist/index292.js +2 -431
  170. package/dist/index293.js +2 -176
  171. package/dist/index294.js +2 -3
  172. package/dist/index295.js +2 -9
  173. package/dist/index296.js +2 -23
  174. package/dist/index297.js +1 -5
  175. package/dist/index298.js +21 -15
  176. package/dist/index300.js +7 -3
  177. package/dist/index301.js +3 -8
  178. package/dist/index303.js +176 -2
  179. package/dist/index304.js +3 -89
  180. package/dist/index305.js +3 -126
  181. package/dist/index306.js +2 -3
  182. package/dist/index307.js +1 -1
  183. package/dist/index308.js +3 -2
  184. package/dist/index309.js +117 -427
  185. package/dist/index31.js +2 -2
  186. package/dist/index310.js +2 -127
  187. package/dist/index311.js +435 -6
  188. package/dist/index312.js +125 -17
  189. package/dist/index313.js +2 -7
  190. package/dist/index314.js +67 -2
  191. package/dist/index316.js +2 -32
  192. package/dist/index317.js +3 -26
  193. package/dist/index318.js +56 -65
  194. package/dist/index319.js +1 -1
  195. package/dist/index320.js +1 -1
  196. package/dist/index321.js +4 -57
  197. package/dist/index322.js +32 -32
  198. package/dist/index323.js +57 -4
  199. package/dist/index324.js +32 -2
  200. package/dist/index325.js +26 -3
  201. package/dist/index326.js +6 -57
  202. package/dist/index327.js +19 -480
  203. package/dist/index328.js +480 -8
  204. package/dist/index329.js +46 -5
  205. package/dist/index33.js +8 -8
  206. package/dist/index330.js +7 -8
  207. package/dist/index331.js +7 -46
  208. package/dist/index332.js +8 -0
  209. package/dist/index333.js +10 -0
  210. package/dist/index334.js +1 -1
  211. package/dist/index337.js +420 -43
  212. package/dist/index338.js +49 -0
  213. package/dist/index35.js +5 -5
  214. package/dist/index37.js +20 -20
  215. package/dist/index39.js +6 -6
  216. package/dist/index41.js +2 -2
  217. package/dist/index43.js +8 -8
  218. package/dist/index45.js +6 -6
  219. package/dist/index47.js +3 -3
  220. package/dist/index49.js +3 -3
  221. package/dist/index53.js +1 -1
  222. package/dist/index55.js +1 -1
  223. package/dist/index57.js +2 -2
  224. package/dist/index61.js +3 -3
  225. package/dist/index75.js +3 -3
  226. package/dist/index77.js +1 -1
  227. package/dist/index79.js +2 -2
  228. package/dist/index81.js +1 -1
  229. package/dist/index84.js +67 -67
  230. package/dist/index86.js +2 -2
  231. package/dist/index88.js +5 -5
  232. package/dist/index90.js +1 -1
  233. package/dist/style.css +1 -1
  234. package/package.json +2 -1
  235. package/dist/index169.js +0 -5
  236. package/dist/index178.js +0 -4
  237. package/dist/index222.js +0 -5
  238. package/dist/index243.js +0 -14
  239. package/dist/index250.js +0 -9
  240. package/dist/index299.js +0 -11
  241. package/dist/index302.js +0 -202
  242. package/dist/index335.js +0 -426
  243. /package/dist/{index167.js → index168.js} +0 -0
  244. /package/dist/{index193.js → index194.js} +0 -0
  245. /package/dist/{index336.js → index339.js} +0 -0
package/dist/index247.js CHANGED
@@ -1,202 +1,96 @@
1
- import { defineComponent as j, ref as c, onMounted as J, watch as Q, openBlock as _, createElementBlock as R, createElementVNode as w, createTextVNode as B, toDisplayString as C, unref as x, createCommentVNode as K } from "vue";
2
- import { useResizeObserver as Z } from "./index132.js";
3
- import { hexToRgb as O } from "./index328.js";
4
- import { getHueFromRGB as F } from "./index329.js";
5
- import { hslToHex as y } from "./index330.js";
6
- import { useLocale as ee } from "./index221.js";
7
- const te = {
8
- id: "mainCanvasDesc",
9
- "aria-live": "polite",
10
- class: "sr-only"
11
- }, ae = { key: 0 }, ne = {
12
- id: "hueCanvasDesc",
13
- "aria-live": "polite",
14
- class: "sr-only"
15
- }, oe = { key: 0 }, de = /* @__PURE__ */ j({
16
- __name: "ColorPallette",
1
+ import { defineComponent as h, toRef as y, ref as o, computed as n, watch as x, openBlock as b, createBlock as $, withCtx as A, createElementBlock as k, mergeProps as l, createElementVNode as f, renderSlot as B } from "vue";
2
+ import C from "./index218.js";
3
+ import c from "./index328.js";
4
+ import { useFloating as D, arrow as E } from "./index261.js";
5
+ import { autoUpdate as P, flip as F, offset as M, shift as S } from "./index264.js";
6
+ const W = /* @__PURE__ */ h({
7
+ __name: "CommonFloating",
17
8
  props: {
18
- modelValue: {}
9
+ arrowPadding: {},
10
+ eager: { type: Boolean },
11
+ offset: {},
12
+ padding: {},
13
+ placement: {},
14
+ theme: { default: "default" },
15
+ transitionDuration: {},
16
+ containerAttributes: { default: () => ({}) },
17
+ bubbleAttributes: {},
18
+ wrapper: {},
19
+ baseClass: {},
20
+ open: { type: Boolean },
21
+ teleportTarget: {}
19
22
  },
20
- emits: ["update:modelValue"],
21
- setup(N, { emit: T }) {
22
- const D = N, f = T, { t: h } = ee(), o = c(D.modelValue), d = c(
23
- y(F(...O(o.value ?? "#ff0000")), 100, 50)
24
- ), P = c(null), s = c(null), r = c(null), l = c({ x: 0, y: 0 }), u = c({ x: 0 }), b = c(!1), k = c(!1), H = () => {
25
- const e = s.value, t = r.value;
26
- !e || !t || (e.width = e.offsetWidth, e.height = e.offsetHeight, t.width = t.offsetWidth, t.height = t.offsetHeight, v(), m());
27
- }, I = () => {
28
- const e = s.value;
29
- return e ? e.getContext("2d", { willReadFrequently: !0 }) : null;
30
- }, v = () => {
31
- const e = s.value;
32
- if (!e) return;
33
- const t = I();
34
- if (!t) return;
35
- t.clearRect(0, 0, e.width, e.height);
36
- const a = t.createLinearGradient(0, 0, e.width, 0);
37
- a.addColorStop(0, d.value), a.addColorStop(1, "#ffffff");
38
- const n = t.createLinearGradient(0, 0, 0, e.height);
39
- n.addColorStop(0, "transparent"), n.addColorStop(1, "#000000"), t.fillStyle = a, t.fillRect(0, 0, e.width, e.height), t.fillStyle = n, t.globalCompositeOperation = "multiply", t.fillRect(0, 0, e.width, e.height), t.globalCompositeOperation = "source-over", t.fillStyle = "#000000", t.strokeStyle = "#000000", t.lineWidth = 1;
40
- }, p = () => {
41
- const e = I();
42
- e && (e.beginPath(), e.arc(
43
- l.value.x,
44
- l.value.y,
45
- 8,
46
- 0,
47
- 2 * Math.PI
48
- ), e.strokeStyle = "#ffffff", e.lineWidth = 2, e.stroke(), e.beginPath(), e.arc(
49
- l.value.x,
50
- l.value.y,
51
- 7,
52
- 0,
53
- 2 * Math.PI
54
- ), e.strokeStyle = "#000000", e.lineWidth = 1, e.stroke(), e.globalCompositeOperation = "source-over");
55
- }, V = () => {
56
- const e = r.value;
57
- return e ? e.getContext("2d", { willReadFrequently: !0 }) : null;
58
- }, m = () => {
59
- const e = r.value;
60
- if (!e) return;
61
- const t = V();
62
- if (!t) return;
63
- const a = t.createLinearGradient(0, 0, e.width, 0);
64
- for (let n = 0; n <= 360; n += 60)
65
- a.addColorStop(n / 360, `hsl(${n}, 100%, 50%)`);
66
- a.addColorStop(1, "hsl(360, 100%, 50%)"), t.fillStyle = a, t.fillRect(0, 0, e.width, e.height), L(), t.fillStyle = "#000000", t.strokeStyle = "#000000", t.lineWidth = 1;
67
- }, L = () => {
68
- const e = r.value;
69
- if (!e) return;
70
- const t = V();
71
- if (!t) return;
72
- const a = 10, n = 16, i = u.value.x - a / 2, S = e.height / 2 - n / 2;
73
- t.beginPath(), t.roundRect(i, S, a, n, 2), t.strokeStyle = "lightgray", t.stroke(), t.fillStyle = "#ffffff", t.fill();
74
- }, q = (e) => {
75
- s.value && (window.addEventListener("pointermove", A), window.addEventListener("pointerup", E), b.value = !0, G(e));
76
- }, z = (e) => {
77
- r.value && (window.addEventListener("pointermove", A), window.addEventListener("pointerup", E), k.value = !0, W(e));
78
- }, G = (e) => {
79
- const t = s.value;
80
- if (!t) return;
81
- const a = t.getBoundingClientRect(), n = Math.max(0, Math.min(t.width, e.clientX - a.left)), i = Math.max(0, Math.min(t.height, e.clientY - a.top));
82
- l.value = { x: n, y: i }, v(), p(), o.value = g(), f("update:modelValue", o.value);
83
- }, W = (e) => {
84
- const t = r.value;
85
- if (!t) return;
86
- const a = t.getBoundingClientRect(), n = Math.max(0, Math.min(t.width, e.clientX - a.left));
87
- u.value = { x: n };
88
- const i = n / t.width * 360;
89
- d.value = y(i, 100, 50), m(), v(), p(), o.value = g(), f("update:modelValue", o.value);
90
- }, A = (e) => {
91
- b.value ? G(e) : k.value && W(e);
92
- }, E = () => {
93
- b.value = !1, k.value = !1;
94
- }, U = (e) => {
95
- var a, n;
96
- switch (e.key) {
97
- case "ArrowUp":
98
- l.value.y = Math.max(0, l.value.y - 5);
99
- break;
100
- case "ArrowDown":
101
- l.value.y = Math.min(
102
- ((a = s.value) == null ? void 0 : a.height) ?? 0,
103
- l.value.y + 5
104
- );
105
- break;
106
- case "ArrowLeft":
107
- l.value.x = Math.max(0, l.value.x - 5);
108
- break;
109
- case "ArrowRight":
110
- l.value.x = Math.min(
111
- ((n = s.value) == null ? void 0 : n.width) ?? 0,
112
- l.value.x + 5
113
- );
114
- break;
115
- default:
116
- return;
23
+ setup(d) {
24
+ const e = d, m = y(e, "wrapper"), i = o(), s = o(), p = o(), { floatingStyles: g, placement: w, middlewareData: a } = D(
25
+ i,
26
+ s,
27
+ {
28
+ placement: e.placement,
29
+ whileElementsMounted: P,
30
+ middleware: [
31
+ F(),
32
+ M(e.offset),
33
+ S({ padding: e.padding }),
34
+ E({
35
+ element: p,
36
+ padding: e.arrowPadding
37
+ })
38
+ ]
117
39
  }
118
- v(), p(), o.value = g(), f("update:modelValue", o.value), e.preventDefault();
119
- }, X = (e) => {
120
- var n, i;
121
- switch (e.key) {
122
- case "ArrowLeft":
123
- u.value.x = Math.max(0, u.value.x - 5);
124
- break;
125
- case "ArrowRight":
126
- u.value.x = Math.min(
127
- ((n = r.value) == null ? void 0 : n.width) ?? 0,
128
- u.value.x + 5
129
- );
130
- break;
131
- default:
132
- return;
40
+ ), _ = n(() => {
41
+ if (a.value.arrow) {
42
+ const { x: t, y: r } = a.value.arrow;
43
+ return {
44
+ style: {
45
+ left: `${t}px`,
46
+ top: `${r}px`
47
+ }
48
+ };
133
49
  }
134
- const a = u.value.x / (((i = r.value) == null ? void 0 : i.width) ?? 1) * 360;
135
- d.value = y(a, 100, 50), m(), L(), v(), p(), o.value = g(), f("update:modelValue", o.value), e.preventDefault();
136
- };
137
- J(() => {
138
- H(), M(o.value ?? "#ff0000");
139
- }), Z(P, () => {
140
- H(), M(o.value ?? "#ff0000");
141
- }), Q(
142
- () => D.modelValue,
143
- (e) => {
144
- !e || e === o.value || (o.value = e, M(e), m(), v());
50
+ }), u = n(() => {
51
+ var t, r;
52
+ return c({}, e.containerAttributes, {
53
+ class: {
54
+ "bb-floating": !0,
55
+ [`bb-floating--${w.value}`]: !0,
56
+ [`${e.baseClass}__bubble-container--${e.theme}`]: e.theme,
57
+ "bb-floating--hidden": !e.open,
58
+ "bb-floating--open": e.open
59
+ },
60
+ style: {
61
+ ...g.value,
62
+ "--transition-duration": `${e.transitionDuration}ms`,
63
+ "--arrow-offset-x": Math.round(((r = (t = a.value) == null ? void 0 : t.arrow) == null ? void 0 : r.x) ?? 0) + "px"
64
+ },
65
+ tabindex: e.open ? void 0 : -1
66
+ });
67
+ }), v = n(() => c({}, e.bubbleAttributes, {}));
68
+ return x(
69
+ () => e.open,
70
+ (t) => {
71
+ t && (i.value = m.value);
145
72
  }
146
- );
147
- const g = () => {
148
- const e = s.value;
149
- if (!e) return "#ffffff";
150
- const t = e.getContext("2d");
151
- if (!t) return "#ffffff";
152
- const { x: a, y: n } = l.value, i = t.getImageData(a, n, 1, 1).data, [S, $, Y] = i;
153
- return `#${((1 << 24) + (S << 16) + ($ << 8) + Y).toString(16).slice(1)}`;
154
- };
155
- function M(e) {
156
- var a;
157
- const t = F(...O(e));
158
- d.value = y(t, 100, 50), u.value.x = t / 360 * (((a = r.value) == null ? void 0 : a.width) ?? 0);
159
- }
160
- return (e, t) => (_(), R("div", {
161
- ref_key: "paletteRef",
162
- ref: P,
163
- "aria-label": "Color Picker",
164
- class: "bb-color-palette",
165
- role: "application"
166
- }, [
167
- w("canvas", {
168
- ref_key: "mainCanvasRef",
169
- ref: s,
170
- "aria-describedby": "mainCanvasDesc",
171
- "aria-label": "Main Color Selection",
172
- class: "bb-color-palette__canvas",
173
- role: "application",
174
- tabindex: "0",
175
- onKeydown: U,
176
- onPointerdown: q
177
- }, null, 544),
178
- w("p", te, [
179
- B(C(x(h)("colorInput.mainCanvasDesc")) + " ", 1),
180
- o.value ? (_(), R("span", ae, C(x(h)("colorInput.mainCanvasSelectedColor", o.value)), 1)) : K("", !0)
73
+ ), (t, r) => (b(), $(C, { target: t.teleportTarget }, {
74
+ default: A(() => [
75
+ (b(), k("span", l(u.value, {
76
+ key: u.value.id,
77
+ ref_key: "content",
78
+ ref: s
79
+ }), [
80
+ f("span", l({
81
+ ref_key: "bubblearrow",
82
+ ref: p,
83
+ class: "bb-floating__arrow"
84
+ }, _.value), null, 16),
85
+ f("span", l({ class: "bb-floating__bubble" }, v.value), [
86
+ B(t.$slots, "default")
87
+ ], 16)
88
+ ], 16))
181
89
  ]),
182
- w("canvas", {
183
- ref_key: "hueCanvasRef",
184
- ref: r,
185
- "aria-describedby": "hueCanvasDesc",
186
- "aria-label": "Hue Selection",
187
- class: "bb-color-palette__hue-canvas",
188
- role: "application",
189
- tabindex: "0",
190
- onKeydown: X,
191
- onPointerdown: z
192
- }, null, 544),
193
- w("p", ne, [
194
- B(C(x(h)("colorInput.hueCanvasDesc")) + " ", 1),
195
- d.value ? (_(), R("span", oe, C(x(h)("colorInput.hueCanvasSelectedHue", d.value)), 1)) : K("", !0)
196
- ])
197
- ], 512));
90
+ _: 3
91
+ }, 8, ["target"]));
198
92
  }
199
93
  });
200
94
  export {
201
- de as default
95
+ W as default
202
96
  };
package/dist/index249.js CHANGED
@@ -1,5 +1,202 @@
1
- import t from "./index304.js";
2
- const r = t;
1
+ import { defineComponent as j, ref as c, onMounted as J, watch as Q, openBlock as _, createElementBlock as R, createElementVNode as w, createTextVNode as B, toDisplayString as C, unref as x, createCommentVNode as K } from "vue";
2
+ import { useResizeObserver as Z } from "./index132.js";
3
+ import { hexToRgb as O } from "./index331.js";
4
+ import { getHueFromRGB as F } from "./index332.js";
5
+ import { hslToHex as y } from "./index333.js";
6
+ import { useLocale as ee } from "./index219.js";
7
+ const te = {
8
+ id: "mainCanvasDesc",
9
+ "aria-live": "polite",
10
+ class: "sr-only"
11
+ }, ae = { key: 0 }, ne = {
12
+ id: "hueCanvasDesc",
13
+ "aria-live": "polite",
14
+ class: "sr-only"
15
+ }, oe = { key: 0 }, de = /* @__PURE__ */ j({
16
+ __name: "ColorPallette",
17
+ props: {
18
+ modelValue: {}
19
+ },
20
+ emits: ["update:modelValue"],
21
+ setup(N, { emit: T }) {
22
+ const D = N, f = T, { t: h } = ee(), o = c(D.modelValue), d = c(
23
+ y(F(...O(o.value ?? "#ff0000")), 100, 50)
24
+ ), P = c(null), s = c(null), r = c(null), l = c({ x: 0, y: 0 }), u = c({ x: 0 }), b = c(!1), k = c(!1), H = () => {
25
+ const e = s.value, t = r.value;
26
+ !e || !t || (e.width = e.offsetWidth, e.height = e.offsetHeight, t.width = t.offsetWidth, t.height = t.offsetHeight, v(), m());
27
+ }, I = () => {
28
+ const e = s.value;
29
+ return e ? e.getContext("2d", { willReadFrequently: !0 }) : null;
30
+ }, v = () => {
31
+ const e = s.value;
32
+ if (!e) return;
33
+ const t = I();
34
+ if (!t) return;
35
+ t.clearRect(0, 0, e.width, e.height);
36
+ const a = t.createLinearGradient(0, 0, e.width, 0);
37
+ a.addColorStop(0, d.value), a.addColorStop(1, "#ffffff");
38
+ const n = t.createLinearGradient(0, 0, 0, e.height);
39
+ n.addColorStop(0, "transparent"), n.addColorStop(1, "#000000"), t.fillStyle = a, t.fillRect(0, 0, e.width, e.height), t.fillStyle = n, t.globalCompositeOperation = "multiply", t.fillRect(0, 0, e.width, e.height), t.globalCompositeOperation = "source-over", t.fillStyle = "#000000", t.strokeStyle = "#000000", t.lineWidth = 1;
40
+ }, p = () => {
41
+ const e = I();
42
+ e && (e.beginPath(), e.arc(
43
+ l.value.x,
44
+ l.value.y,
45
+ 8,
46
+ 0,
47
+ 2 * Math.PI
48
+ ), e.strokeStyle = "#ffffff", e.lineWidth = 2, e.stroke(), e.beginPath(), e.arc(
49
+ l.value.x,
50
+ l.value.y,
51
+ 7,
52
+ 0,
53
+ 2 * Math.PI
54
+ ), e.strokeStyle = "#000000", e.lineWidth = 1, e.stroke(), e.globalCompositeOperation = "source-over");
55
+ }, V = () => {
56
+ const e = r.value;
57
+ return e ? e.getContext("2d", { willReadFrequently: !0 }) : null;
58
+ }, m = () => {
59
+ const e = r.value;
60
+ if (!e) return;
61
+ const t = V();
62
+ if (!t) return;
63
+ const a = t.createLinearGradient(0, 0, e.width, 0);
64
+ for (let n = 0; n <= 360; n += 60)
65
+ a.addColorStop(n / 360, `hsl(${n}, 100%, 50%)`);
66
+ a.addColorStop(1, "hsl(360, 100%, 50%)"), t.fillStyle = a, t.fillRect(0, 0, e.width, e.height), L(), t.fillStyle = "#000000", t.strokeStyle = "#000000", t.lineWidth = 1;
67
+ }, L = () => {
68
+ const e = r.value;
69
+ if (!e) return;
70
+ const t = V();
71
+ if (!t) return;
72
+ const a = 10, n = 16, i = u.value.x - a / 2, S = e.height / 2 - n / 2;
73
+ t.beginPath(), t.roundRect(i, S, a, n, 2), t.strokeStyle = "lightgray", t.stroke(), t.fillStyle = "#ffffff", t.fill();
74
+ }, q = (e) => {
75
+ s.value && (window.addEventListener("pointermove", A), window.addEventListener("pointerup", E), b.value = !0, G(e));
76
+ }, z = (e) => {
77
+ r.value && (window.addEventListener("pointermove", A), window.addEventListener("pointerup", E), k.value = !0, W(e));
78
+ }, G = (e) => {
79
+ const t = s.value;
80
+ if (!t) return;
81
+ const a = t.getBoundingClientRect(), n = Math.max(0, Math.min(t.width, e.clientX - a.left)), i = Math.max(0, Math.min(t.height, e.clientY - a.top));
82
+ l.value = { x: n, y: i }, v(), p(), o.value = g(), f("update:modelValue", o.value);
83
+ }, W = (e) => {
84
+ const t = r.value;
85
+ if (!t) return;
86
+ const a = t.getBoundingClientRect(), n = Math.max(0, Math.min(t.width, e.clientX - a.left));
87
+ u.value = { x: n };
88
+ const i = n / t.width * 360;
89
+ d.value = y(i, 100, 50), m(), v(), p(), o.value = g(), f("update:modelValue", o.value);
90
+ }, A = (e) => {
91
+ b.value ? G(e) : k.value && W(e);
92
+ }, E = () => {
93
+ b.value = !1, k.value = !1;
94
+ }, U = (e) => {
95
+ var a, n;
96
+ switch (e.key) {
97
+ case "ArrowUp":
98
+ l.value.y = Math.max(0, l.value.y - 5);
99
+ break;
100
+ case "ArrowDown":
101
+ l.value.y = Math.min(
102
+ ((a = s.value) == null ? void 0 : a.height) ?? 0,
103
+ l.value.y + 5
104
+ );
105
+ break;
106
+ case "ArrowLeft":
107
+ l.value.x = Math.max(0, l.value.x - 5);
108
+ break;
109
+ case "ArrowRight":
110
+ l.value.x = Math.min(
111
+ ((n = s.value) == null ? void 0 : n.width) ?? 0,
112
+ l.value.x + 5
113
+ );
114
+ break;
115
+ default:
116
+ return;
117
+ }
118
+ v(), p(), o.value = g(), f("update:modelValue", o.value), e.preventDefault();
119
+ }, X = (e) => {
120
+ var n, i;
121
+ switch (e.key) {
122
+ case "ArrowLeft":
123
+ u.value.x = Math.max(0, u.value.x - 5);
124
+ break;
125
+ case "ArrowRight":
126
+ u.value.x = Math.min(
127
+ ((n = r.value) == null ? void 0 : n.width) ?? 0,
128
+ u.value.x + 5
129
+ );
130
+ break;
131
+ default:
132
+ return;
133
+ }
134
+ const a = u.value.x / (((i = r.value) == null ? void 0 : i.width) ?? 1) * 360;
135
+ d.value = y(a, 100, 50), m(), L(), v(), p(), o.value = g(), f("update:modelValue", o.value), e.preventDefault();
136
+ };
137
+ J(() => {
138
+ H(), M(o.value ?? "#ff0000");
139
+ }), Z(P, () => {
140
+ H(), M(o.value ?? "#ff0000");
141
+ }), Q(
142
+ () => D.modelValue,
143
+ (e) => {
144
+ !e || e === o.value || (o.value = e, M(e), m(), v());
145
+ }
146
+ );
147
+ const g = () => {
148
+ const e = s.value;
149
+ if (!e) return "#ffffff";
150
+ const t = e.getContext("2d");
151
+ if (!t) return "#ffffff";
152
+ const { x: a, y: n } = l.value, i = t.getImageData(a, n, 1, 1).data, [S, $, Y] = i;
153
+ return `#${((1 << 24) + (S << 16) + ($ << 8) + Y).toString(16).slice(1)}`;
154
+ };
155
+ function M(e) {
156
+ var a;
157
+ const t = F(...O(e));
158
+ d.value = y(t, 100, 50), u.value.x = t / 360 * (((a = r.value) == null ? void 0 : a.width) ?? 0);
159
+ }
160
+ return (e, t) => (_(), R("div", {
161
+ ref_key: "paletteRef",
162
+ ref: P,
163
+ "aria-label": "Color Picker",
164
+ class: "bb-color-palette",
165
+ role: "application"
166
+ }, [
167
+ w("canvas", {
168
+ ref_key: "mainCanvasRef",
169
+ ref: s,
170
+ "aria-describedby": "mainCanvasDesc",
171
+ "aria-label": "Main Color Selection",
172
+ class: "bb-color-palette__canvas",
173
+ role: "application",
174
+ tabindex: "0",
175
+ onKeydown: U,
176
+ onPointerdown: q
177
+ }, null, 544),
178
+ w("p", te, [
179
+ B(C(x(h)("colorInput.mainCanvasDesc")) + " ", 1),
180
+ o.value ? (_(), R("span", ae, C(x(h)("colorInput.mainCanvasSelectedColor", o.value)), 1)) : K("", !0)
181
+ ]),
182
+ w("canvas", {
183
+ ref_key: "hueCanvasRef",
184
+ ref: r,
185
+ "aria-describedby": "hueCanvasDesc",
186
+ "aria-label": "Hue Selection",
187
+ class: "bb-color-palette__hue-canvas",
188
+ role: "application",
189
+ tabindex: "0",
190
+ onKeydown: X,
191
+ onPointerdown: z
192
+ }, null, 544),
193
+ w("p", ne, [
194
+ B(C(x(h)("colorInput.hueCanvasDesc")) + " ", 1),
195
+ d.value ? (_(), R("span", oe, C(x(h)("colorInput.hueCanvasSelectedHue", d.value)), 1)) : K("", !0)
196
+ ])
197
+ ], 512));
198
+ }
199
+ });
3
200
  export {
4
- r as throttle
201
+ de as default
5
202
  };