@stenajs-webui/select 22.7.0 → 22.7.2

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.
package/dist/index.es.js CHANGED
@@ -1,12 +1,12 @@
1
1
  import { jsx as i, jsxs as C } from "react/jsx-runtime";
2
2
  import * as F from "react";
3
- import { useMemo as g, memo as P, createElement as j } from "react";
4
- import R, { mergeStyles as w, components as b } from "react-select";
5
- import H from "react-select/async";
3
+ import { useMemo as p, memo as _, createElement as j } from "react";
4
+ import V, { mergeStyles as w, components as v } from "react-select";
5
+ import R from "react-select/async";
6
6
  import { cssColor as u } from "@stenajs-webui/theme";
7
- import { TextInputButton as N, stenaTimes as U, Chip as O, CloseButton as V, Icon as q, stenaCheck as D, FlatButton as E } from "@stenajs-webui/elements";
7
+ import { Chip as O, TextInputButton as N, stenaTimes as U, CloseButton as H, Icon as q, stenaCheck as D, FlatButton as E } from "@stenajs-webui/elements";
8
8
  import { Row as k, Space as y, Text as X, Column as Y, Spacing as I } from "@stenajs-webui/core";
9
- import { uniqWith as J, isEqual as S, intersectionWith as L, differenceWith as K } from "lodash-es";
9
+ import { intersectionWith as L, isEqual as S, differenceWith as J, uniqWith as K } from "lodash-es";
10
10
  import Q from "react-select/creatable";
11
11
  const W = {
12
12
  arrowColor: {
@@ -97,26 +97,26 @@ const W = {
97
97
  arrowColor: c,
98
98
  groupHeading: a,
99
99
  loadingIndicator: f
100
- }, m) => ({
101
- option: (l, { isDisabled: d, isFocused: s, isSelected: h }) => ({
100
+ }, h) => ({
101
+ option: (l, { isDisabled: s, isFocused: d, isSelected: m }) => ({
102
102
  ...l,
103
103
  fontFamily: o.fontFamily,
104
104
  fontSize: o.fontSize,
105
105
  backgroundColor: Z(
106
106
  e,
107
- d,
108
- h,
109
- s
107
+ s,
108
+ m,
109
+ d
110
110
  ),
111
- color: $(e, d, h, s),
112
- cursor: d ? "not-allowed" : "default",
111
+ color: $(e, s, m, d),
112
+ cursor: s ? "not-allowed" : "default",
113
113
  whiteSpace: e.whiteSpace || l.whiteSpace,
114
114
  ":active": {
115
- backgroundColor: d ? void 0 : h ? e.selectedItemActiveBackgroundColor : e.activeBackgroundColor,
116
- color: d ? void 0 : h ? e.selectedItemActiveTextColor : e.activeTextColor
115
+ backgroundColor: s ? void 0 : m ? e.selectedItemActiveBackgroundColor : e.activeBackgroundColor,
116
+ color: s ? void 0 : m ? e.selectedItemActiveTextColor : e.activeTextColor
117
117
  }
118
118
  }),
119
- control: (l, { isFocused: d, isDisabled: s, menuIsOpen: h }) => ({
119
+ control: (l, { isFocused: s, isDisabled: d, menuIsOpen: m }) => ({
120
120
  ...l,
121
121
  // none of react-selects styles are passed to <View />
122
122
  fontFamily: o.fontFamily,
@@ -124,30 +124,30 @@ const W = {
124
124
  minHeight: "var(--swui-field-height)",
125
125
  backgroundColor: ee(
126
126
  o,
127
- s,
128
127
  d,
129
- m
128
+ s,
129
+ h
130
130
  ),
131
131
  borderRadius: o.borderRadius,
132
132
  border: o.border,
133
133
  "--swui-select-border-color": T(
134
134
  o,
135
- s,
136
- d || h,
135
+ d,
136
+ s || m,
137
137
  !1,
138
- m
138
+ h
139
139
  ),
140
- outline: d ? "var(--swui-focus-outline)" : void 0,
141
- outlineOffset: d ? "-1px" : void 0,
140
+ outline: s ? "var(--swui-focus-outline)" : void 0,
141
+ outlineOffset: s ? "-1px" : void 0,
142
142
  transition: "none",
143
- boxShadow: d ? o.boxShadowFocused : void 0,
143
+ boxShadow: s ? o.boxShadowFocused : void 0,
144
144
  "&:hover": {
145
145
  "--swui-select-border-color": T(
146
146
  o,
147
147
  !1,
148
- d || h,
148
+ s || m,
149
149
  !0,
150
- m
150
+ h
151
151
  )
152
152
  }
153
153
  }),
@@ -214,12 +214,12 @@ const W = {
214
214
  padding: "var(--swui-metrics-space-half) var(--swui-metrics-space)",
215
215
  gap: "var(--swui-metrics-space-half)"
216
216
  }),
217
- dropdownIndicator: (l, { isFocused: d, isDisabled: s }) => ({
217
+ dropdownIndicator: (l, { isFocused: s, isDisabled: d }) => ({
218
218
  ...l,
219
219
  padding: "5px",
220
- color: s ? c.disabled : d ? c.focused.standard : c.closed.standard,
220
+ color: d ? c.disabled : s ? c.focused.standard : c.closed.standard,
221
221
  "&:hover": {
222
- color: s ? c.disabled : d ? c.focused.hover : c.closed.hover
222
+ color: d ? c.disabled : s ? c.focused.hover : c.closed.hover
223
223
  },
224
224
  svg: {
225
225
  width: 14,
@@ -282,22 +282,22 @@ function ye({
282
282
  styles: r,
283
283
  ...o
284
284
  }) {
285
- const t = g(() => {
285
+ const t = p(() => {
286
286
  const n = x(e);
287
287
  return r ? w(n, r) : n;
288
288
  }, [e, r]);
289
- return /* @__PURE__ */ i(H, { styles: t, ...o, isMulti: !0 });
289
+ return /* @__PURE__ */ i(R, { styles: t, ...o, isMulti: !0 });
290
290
  }
291
291
  function Be({
292
292
  variant: e = "standard",
293
293
  styles: r,
294
294
  ...o
295
295
  }) {
296
- const t = g(() => {
296
+ const t = p(() => {
297
297
  const n = x(e);
298
298
  return r ? w(n, r) : n;
299
299
  }, [e, r]);
300
- return /* @__PURE__ */ i(H, { styles: t, ...o, isMulti: !1 });
300
+ return /* @__PURE__ */ i(R, { styles: t, ...o, isMulti: !1 });
301
301
  }
302
302
  const re = function({
303
303
  clearValue: e
@@ -323,13 +323,9 @@ const re = function({
323
323
  /* @__PURE__ */ i("div", { onMouseDown: (o) => o.stopPropagation(), children: /* @__PURE__ */ i(
324
324
  O,
325
325
  {
326
- onClickRemove: (o) => {
327
- var t;
328
- return (t = e.onClick) == null ? void 0 : t.call(
329
- e,
330
- o
331
- );
332
- },
326
+ onClickRemove: (o) => e.onClick?.(
327
+ o
328
+ ),
333
329
  label: r.label
334
330
  }
335
331
  ) })
@@ -341,12 +337,12 @@ function B({
341
337
  components: o,
342
338
  ...t
343
339
  }) {
344
- const n = g(() => {
340
+ const n = p(() => {
345
341
  const c = x(e);
346
342
  return r ? w(c, r) : c;
347
343
  }, [e, r]);
348
344
  return /* @__PURE__ */ i(
349
- R,
345
+ V,
350
346
  {
351
347
  styles: n,
352
348
  components: { ...o, ClearIndicator: re, MultiValue: te },
@@ -368,10 +364,10 @@ function ze(e) {
368
364
  }
369
365
  );
370
366
  }
371
- const le = P(
367
+ const le = _(
372
368
  (e) => {
373
369
  const [r, ...o] = e.children, t = ne(r, e);
374
- return /* @__PURE__ */ C(b.ValueContainer, { ...e, children: [
370
+ return /* @__PURE__ */ C(v.ValueContainer, { ...e, children: [
375
371
  t,
376
372
  o
377
373
  ] });
@@ -385,7 +381,7 @@ const le = P(
385
381
  }) => e ? e.length > 1 ? [
386
382
  e[0],
387
383
  /* @__PURE__ */ j(
388
- b.MultiValue,
384
+ v.MultiValue,
389
385
  {
390
386
  ...n,
391
387
  key: "DUMMY_VALUE_FOR_PLUS_X",
@@ -395,8 +391,8 @@ const le = P(
395
391
  removeProps: {},
396
392
  index: 1,
397
393
  components: {
398
- Container: b.MultiValueContainer,
399
- Label: b.MultiValueLabel,
394
+ Container: v.MultiValueContainer,
395
+ Label: v.MultiValueLabel,
400
396
  Remove: () => /* @__PURE__ */ i("div", { style: { height: 16, margin: 3, marginTop: 4 } })
401
397
  }
402
398
  },
@@ -409,34 +405,34 @@ function Te({
409
405
  components: o,
410
406
  ...t
411
407
  }) {
412
- const n = g(() => {
408
+ const n = p(() => {
413
409
  const a = x(e);
414
410
  return r ? w(a, r) : a;
415
411
  }, [e, r]);
416
412
  return /* @__PURE__ */ i(
417
- R,
413
+ V,
418
414
  {
419
415
  styles: n,
420
- components: { ...o, ClearIndicator: (a) => /* @__PURE__ */ i(V, { "aria-label": "Clear", onClick: a.clearValue }) },
416
+ components: { ...o, ClearIndicator: (a) => /* @__PURE__ */ i(H, { "aria-label": "Clear", onClick: a.clearValue }) },
421
417
  ...t,
422
418
  isMulti: !1
423
419
  }
424
420
  );
425
421
  }
426
- const M = (e, r) => K(
422
+ const M = (e, r) => J(
427
423
  r,
428
424
  [...e.internalOptions, e],
429
425
  S
430
- ).map(p), ie = (e) => !("internalOptions" in e), v = (e) => e.filter(ie).map(p), ae = (e) => (r, o) => {
426
+ ).map(g), ie = (e) => !("internalOptions" in e), b = (e) => e.filter(ie).map(g), ae = (e) => (r, o) => {
431
427
  const t = r ?? [];
432
428
  switch (o.action) {
433
429
  case "select-option":
434
430
  if (o.option && "internalOptions" in o.option) {
435
- const n = J(
431
+ const n = K(
436
432
  t.reduce(
437
433
  (c, a) => "internalOptions" in a ? [...c, ...a.internalOptions] : [
438
434
  ...c,
439
- p(a)
435
+ g(a)
440
436
  ],
441
437
  []
442
438
  ),
@@ -444,36 +440,36 @@ const M = (e, r) => K(
444
440
  );
445
441
  e(n, o);
446
442
  } else
447
- e(v(t), o);
443
+ e(b(t), o);
448
444
  break;
449
445
  case "deselect-option":
450
446
  o.option && "internalOptions" in o.option ? e(
451
447
  M(
452
448
  o.option,
453
- v(t)
449
+ b(t)
454
450
  ),
455
451
  o
456
- ) : e(v(t), o);
452
+ ) : e(b(t), o);
457
453
  break;
458
454
  case "remove-value":
459
455
  case "pop-value":
460
456
  o.removedValue && "internalOptions" in o.removedValue ? e(
461
457
  M(
462
458
  o.removedValue,
463
- v(t)
459
+ b(t)
464
460
  ),
465
461
  o
466
- ) : e(v(t), o);
462
+ ) : e(b(t), o);
467
463
  break;
468
464
  case "clear":
469
465
  e(
470
- t.map(p),
466
+ t.map(g),
471
467
  o
472
468
  );
473
469
  break;
474
470
  case "create-option":
475
471
  e(
476
- t.map(p),
472
+ t.map(g),
477
473
  o
478
474
  );
479
475
  break;
@@ -481,33 +477,33 @@ const M = (e, r) => K(
481
477
  }, ce = (e) => e.reduce(
482
478
  (r, o) => [
483
479
  ...r,
484
- A(o),
480
+ P(o),
485
481
  ...o.options.map(G)
486
482
  ],
487
483
  []
488
- ), de = (e, r) => {
484
+ ), se = (e, r) => {
489
485
  if (!r)
490
486
  return [];
491
487
  const o = [];
492
488
  return e.forEach((t) => {
493
- se(t.options, r) && o.push(
494
- A(t)
489
+ de(t.options, r) && o.push(
490
+ P(t)
495
491
  ), o.push(
496
492
  ...L(t.options, r, S).map(
497
493
  (n) => G(n)
498
494
  )
499
495
  );
500
496
  }), o;
501
- }, se = (e, r) => r ? L(e, r, S).length === e.length : !1, G = (e) => ({
497
+ }, de = (e, r) => r ? L(e, r, S).length === e.length : !1, G = (e) => ({
502
498
  data: e.data,
503
499
  label: e.label,
504
500
  value: e.value
505
- }), A = (e) => ({
501
+ }), P = (e) => ({
506
502
  data: e.label,
507
503
  label: e.label,
508
504
  value: e.label,
509
505
  internalOptions: e.options
510
- }), p = (e) => ({
506
+ }), g = (e) => ({
511
507
  data: e.data,
512
508
  label: e.label,
513
509
  value: e.value
@@ -523,7 +519,7 @@ function fe(e) {
523
519
  selectValue: e.getValue()
524
520
  }) : e.label;
525
521
  }
526
- function me({
522
+ function he({
527
523
  onChange: e,
528
524
  options: r,
529
525
  value: o,
@@ -533,22 +529,22 @@ function me({
533
529
  formatOptionLabel: c,
534
530
  ...a
535
531
  }) {
536
- const f = (s) => {
537
- const h = fe(s), z = "internalOptions" in s.data;
538
- return /* @__PURE__ */ i(b.Option, { ...s, children: /* @__PURE__ */ C(k, { children: [
532
+ const f = (d) => {
533
+ const m = fe(d), z = "internalOptions" in d.data;
534
+ return /* @__PURE__ */ i(v.Option, { ...d, children: /* @__PURE__ */ C(k, { children: [
539
535
  !z && /* @__PURE__ */ i(y, {}),
540
536
  /* @__PURE__ */ i(
541
- he,
537
+ me,
542
538
  {
543
539
  theme: W,
544
540
  size: z ? void 0 : "small",
545
- label: h,
546
- selected: s.isSelected,
547
- focused: s.isFocused
541
+ label: m,
542
+ selected: d.isSelected,
543
+ focused: d.isFocused
548
544
  }
549
545
  )
550
546
  ] }) });
551
- }, m = (s) => "internalOptions" in s.data ? null : /* @__PURE__ */ i(b.MultiValue, { ...s }), l = r ? de(r, o) : void 0, d = r ? ce(r) : void 0;
547
+ }, h = (d) => "internalOptions" in d.data ? null : /* @__PURE__ */ i(v.MultiValue, { ...d }), l = r ? se(r, o) : void 0, s = r ? ce(r) : void 0;
552
548
  return /* @__PURE__ */ i(
553
549
  B,
554
550
  {
@@ -557,17 +553,17 @@ function me({
557
553
  hideSelectedOptions: !1,
558
554
  components: {
559
555
  ...a.components,
560
- MultiValue: m,
556
+ MultiValue: h,
561
557
  Option: f
562
558
  },
563
559
  isMulti: !0,
564
- options: d,
560
+ options: s,
565
561
  value: l,
566
562
  variant: t
567
563
  }
568
564
  );
569
565
  }
570
- const he = ({
566
+ const me = ({
571
567
  focused: e,
572
568
  label: r,
573
569
  selected: o,
@@ -591,7 +587,7 @@ function Me({
591
587
  ariaLabelClear: t = "Clear",
592
588
  ...n
593
589
  }) {
594
- const c = g(() => {
590
+ const c = p(() => {
595
591
  const f = x(e);
596
592
  return r ? w(f, r) : f;
597
593
  }, [e, r]);
@@ -599,13 +595,13 @@ function Me({
599
595
  Q,
600
596
  {
601
597
  styles: c,
602
- components: { ...o, ClearIndicator: (f) => /* @__PURE__ */ i(V, { "aria-label": t, onClick: f.clearValue }) },
598
+ components: { ...o, ClearIndicator: (f) => /* @__PURE__ */ i(H, { "aria-label": t, onClick: f.clearValue }) },
603
599
  ...n,
604
600
  isMulti: !1
605
601
  }
606
602
  );
607
603
  }
608
- function _({
604
+ function A({
609
605
  value: e,
610
606
  onValueChange: r,
611
607
  noneSelectedLabel: o = "None",
@@ -613,24 +609,24 @@ function _({
613
609
  }) {
614
610
  return /* @__PURE__ */ C(Y, { flex: 1, children: [
615
611
  /* @__PURE__ */ C(k, { flexWrap: "wrap", children: [
616
- e == null ? void 0 : e.map((n) => /* @__PURE__ */ C(k, { children: [
612
+ e?.map((n) => /* @__PURE__ */ C(k, { children: [
617
613
  /* @__PURE__ */ i(I, { num: 0.5, children: /* @__PURE__ */ i(
618
614
  O,
619
615
  {
620
616
  label: n.label,
621
- onClickRemove: () => r == null ? void 0 : r(
622
- (e == null ? void 0 : e.filter((c) => c.value !== n.value)) ?? []
617
+ onClickRemove: () => r?.(
618
+ e?.filter((c) => c.value !== n.value) ?? []
623
619
  )
624
620
  }
625
621
  ) }),
626
622
  /* @__PURE__ */ i(y, {})
627
623
  ] }, n.value)),
628
- e != null && e.length ? /* @__PURE__ */ i(I, { num: 0.5, children: /* @__PURE__ */ i(
624
+ e?.length ? /* @__PURE__ */ i(I, { num: 0.5, children: /* @__PURE__ */ i(
629
625
  E,
630
626
  {
631
627
  size: "small",
632
628
  label: "Clear",
633
- onClick: () => r == null ? void 0 : r([])
629
+ onClick: () => r?.([])
634
630
  }
635
631
  ) }) : /* @__PURE__ */ i(I, { num: 0.5, children: /* @__PURE__ */ i(O, { variant: "secondary", label: o }) })
636
632
  ] }),
@@ -649,7 +645,7 @@ function Ce({
649
645
  ...f
650
646
  }) {
651
647
  return /* @__PURE__ */ i(
652
- _,
648
+ A,
653
649
  {
654
650
  noneSelectedLabel: a,
655
651
  onValueChange: r,
@@ -660,7 +656,7 @@ function Ce({
660
656
  ...f,
661
657
  isClearable: !1,
662
658
  value: e,
663
- onChange: r ? (m) => r([...m]) : void 0,
659
+ onChange: r ? (h) => r([...h]) : void 0,
664
660
  backspaceRemovesValue: !1,
665
661
  hideSelectedOptions: !0,
666
662
  controlShouldRenderValue: !1,
@@ -676,7 +672,7 @@ function Ce({
676
672
  const Fe = F.memo(
677
673
  Ce
678
674
  );
679
- function be({
675
+ function ve({
680
676
  value: e,
681
677
  onValueChange: r,
682
678
  placeholder: o = "Type to search",
@@ -687,18 +683,18 @@ function be({
687
683
  ...f
688
684
  }) {
689
685
  return /* @__PURE__ */ i(
690
- _,
686
+ A,
691
687
  {
692
688
  noneSelectedLabel: a,
693
689
  onValueChange: r,
694
690
  value: e,
695
691
  children: /* @__PURE__ */ i(
696
- me,
692
+ he,
697
693
  {
698
694
  ...f,
699
695
  isClearable: !1,
700
696
  value: e,
701
- onChange: r ? (m) => r([...m]) : void 0,
697
+ onChange: r ? (h) => r([...h]) : void 0,
702
698
  backspaceRemovesValue: !1,
703
699
  hideSelectedOptions: !0,
704
700
  controlShouldRenderValue: !1,
@@ -711,16 +707,16 @@ function be({
711
707
  }
712
708
  );
713
709
  }
714
- const Re = F.memo(
715
- be
710
+ const Ve = F.memo(
711
+ ve
716
712
  );
717
713
  export {
718
714
  ye as AsyncMultiSelect,
719
715
  Be as AsyncSelect,
720
716
  Fe as ChipMultiSelect,
721
717
  Me as CreatableSelect,
722
- Re as GroupedChipMultiSelect,
723
- me as GroupedMultiSelect,
718
+ Ve as GroupedChipMultiSelect,
719
+ he as GroupedMultiSelect,
724
720
  B as MultiSelect,
725
721
  ze as OverflowingMultiSelect,
726
722
  Te as Select,
@@ -1 +1 @@
1
- {"version":3,"file":"index.es.js","sources":["../src/SelectTheme.ts","../src/util/StylesBuilder.ts","../src/components/ui/AsyncMultiSelect.tsx","../src/components/ui/AsyncSelect.tsx","../src/components/ui/MultiSelect.tsx","../src/components/ui/OverflowingMultiSelect.tsx","../src/components/ui/Select.tsx","../src/util/multiDropdownUtils.ts","../src/components/ui/GroupedMultiSelect.tsx","../src/components/ui/CreatableSelect.tsx","../src/components/ui/ChipMultiSelect/ChipRow.tsx","../src/components/ui/ChipMultiSelect/ChipMultiSelect.tsx","../src/components/ui/ChipMultiSelect/GroupedChipMultiSelect.tsx"],"sourcesContent":["import { Property } from \"csstype\";\nimport { cssColor } from \"@stenajs-webui/theme\";\n\nexport interface SelectTheme {\n arrowColor: {\n disabled: string;\n focused: {\n standard: string;\n hover: string;\n };\n closed: {\n standard: string;\n hover: string;\n };\n };\n clearButtonColor: {\n standard: string;\n hover: string;\n };\n input: {\n backgroundColor: string;\n border: string;\n borderColor: string;\n disabledBorderColor: string;\n borderColorFocused: string;\n borderRadius: string;\n disabledBackgroundColor: string;\n warningBackgroundColor: string;\n errorBackgroundColor: string;\n successBackgroundColor: string;\n warningBorderColor: string;\n errorBorderColor: string;\n successBorderColor: string;\n boxShadowFocused: string;\n fontFamily: string;\n fontSize: string;\n height?: string;\n minHeight?: string;\n placeholderColor: string;\n textColor: string;\n };\n loadingIndicator: {\n textColor: string;\n };\n menu: {\n disabledTextColor: string;\n disabledBackgroundColor: string;\n textColor: string;\n backgroundColor: string;\n hoverTextColor: string;\n hoverBackgroundColor: string;\n activeTextColor: string;\n activeBackgroundColor: string;\n minWidth?: string;\n selectedItemTextColor: string;\n selectedItemBackgroundColor: string;\n selectedItemHoverTextColor: string;\n selectedItemIconColor: string;\n selectedItemHoverIconColor: string;\n selectedItemHoverBackgroundColor: string;\n selectedItemActiveTextColor: string;\n selectedItemActiveBackgroundColor: string;\n zIndex: number;\n width?: string;\n whiteSpace?: Property.WhiteSpace;\n };\n groupHeading: {\n fontSize: string;\n lineHeight: string;\n fontWeight: string;\n color: string;\n letterSpacing: string;\n };\n menuPortal: {\n zIndex: number;\n };\n multiSelect: {\n backgroundColor: string;\n textColor: string;\n removeButtonBackgroundColor: string;\n removeButtonTextColor: string;\n removeButtonHoverBackgroundColor: string;\n removeButtonHoverTextColor: string;\n };\n}\n\nexport const defaultSelectTheme: SelectTheme = {\n arrowColor: {\n disabled: cssColor(\"--silver-light\"),\n focused: {\n hover: cssColor(\"--lhds-color-blue-600\"),\n standard: cssColor(\"--lhds-color-blue-600\"),\n },\n closed: {\n hover: cssColor(\"--lhds-color-blue-600\"),\n standard: cssColor(\"--lhds-color-blue-600\"),\n },\n },\n clearButtonColor: {\n hover: cssColor(\"--lhds-color-red-600\"),\n standard: cssColor(\"--lhds-color-red-500\"),\n },\n input: {\n backgroundColor: \"var(--swui-field-bg-enabled)\",\n border: `1px solid var(--swui-select-border-color)`,\n borderColor: \"var(--swui-field-border-color)\",\n borderColorFocused: \"var(--swui-field-border-color-hover)\",\n disabledBackgroundColor: \"var(--swui-field-bg-disabled)\",\n disabledBorderColor: \"var(--swui-field-bg-disabled)\",\n warningBackgroundColor: \"var(--swui-state-alert-light-color)\",\n warningBorderColor: \"var(--swui-state-alert-light-color)\",\n errorBackgroundColor: \"var(--swui-state-error-light-color)\",\n errorBorderColor: \"var(--swui-state-error-light-color)\",\n successBackgroundColor: \"var(--swui-state-success-light-color)\",\n successBorderColor: \"var(--swui-state-success-light-color)\",\n boxShadowFocused: \"none\",\n fontFamily: \"var(--swui-font-primary)\",\n fontSize: \"var(--swui-font-size-inputs)\",\n minHeight: \"24px\",\n placeholderColor: \"var(--swui-field-text-color)\",\n textColor: \"var(--swui-field-text-color)\",\n borderRadius: \"var(--swui-field-border-radius)\",\n },\n loadingIndicator: {\n textColor: \"var(--swui-field-text-color)\",\n },\n groupHeading: {\n fontSize: \"var(--swui-font-size-small)\",\n lineHeight: \"var(--swui-line-height-smaller)\",\n fontWeight: \"var(--swui-font-weight-text-bold)\",\n color: cssColor(\"--lhds-color-ui-600\"),\n letterSpacing: \"0.1rem\",\n },\n menu: {\n activeBackgroundColor: cssColor(\"--lhds-color-blue-100\"),\n activeTextColor: \"var(--swui-field-text-color)\",\n selectedItemActiveBackgroundColor: cssColor(\"--lhds-color-blue-500\"),\n selectedItemActiveTextColor: cssColor(\"--lhds-color-blue-50\"),\n disabledTextColor: \"var(--swui-field-text-color-disabled)\",\n disabledBackgroundColor: \"var(--swui-field-bg-disabled)\",\n textColor: \"var(--swui-field-text-color)\",\n backgroundColor: \"var(--swui-field-bg-enabled)\",\n hoverTextColor: \"var(--swui-field-text-color)\",\n hoverBackgroundColor: cssColor(\"--lhds-color-blue-200\"),\n selectedItemTextColor: cssColor(\"--lhds-color-blue-500\"),\n selectedItemIconColor: cssColor(\"--lhds-color-blue-500\"),\n selectedItemHoverTextColor: \"var(--swui-field-text-color)\",\n selectedItemHoverIconColor: \"var(--swui-field-text-color)\",\n selectedItemBackgroundColor: cssColor(\"--lhds-color-blue-50\"),\n selectedItemHoverBackgroundColor: cssColor(\"--lhds-color-blue-50\"),\n zIndex: 1,\n width: \"auto\",\n minWidth: \"100%\",\n whiteSpace: \"nowrap\",\n },\n menuPortal: {\n zIndex: 1,\n },\n multiSelect: {\n backgroundColor: \"var(--swui-primary-action-color)\",\n textColor: cssColor(\"--lhds-color-blue-50\"),\n removeButtonBackgroundColor: \"transparent\",\n removeButtonTextColor: \"var(--swui-white)\",\n removeButtonHoverBackgroundColor: \"var(--swui-primary-action-color-hover)\",\n removeButtonHoverTextColor: \"var(--swui-white)\",\n },\n};\n","import { StylesConfig } from \"react-select\";\nimport { defaultSelectTheme, SelectTheme } from \"../SelectTheme\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\nimport { Property } from \"csstype\";\n\nexport type SelectVariant = \"standard\" | \"warning\" | \"error\" | \"success\";\n\nconst resolveOptionBackgroundColor = (\n colors: SelectTheme[\"menu\"],\n isDisabled: boolean,\n isSelected: boolean,\n isFocused: boolean,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledBackgroundColor;\n } else if (isSelected && isFocused) {\n return colors.selectedItemHoverBackgroundColor;\n } else if (isSelected) {\n return colors.selectedItemBackgroundColor;\n } else if (isFocused) {\n return colors.hoverBackgroundColor;\n } else {\n return undefined;\n }\n};\n\nconst resolveOptionColor = (\n colors: SelectTheme[\"menu\"],\n isDisabled: boolean,\n isSelected: boolean,\n isFocused: boolean,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledTextColor;\n } else if (isSelected && isFocused) {\n return colors.selectedItemHoverTextColor;\n } else if (isSelected) {\n return colors.selectedItemTextColor;\n } else if (isFocused) {\n return colors.hoverTextColor;\n } else {\n return undefined;\n }\n};\n\nconst resolveInputBackgroundColor = (\n colors: SelectTheme[\"input\"],\n isDisabled: boolean,\n isFocused: boolean,\n variant: SelectVariant | undefined,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledBackgroundColor;\n } else if (isFocused) {\n return colors.backgroundColor;\n } else if (variant === \"warning\") {\n return colors.warningBackgroundColor;\n } else if (variant === \"success\") {\n return colors.successBackgroundColor;\n } else if (variant === \"error\") {\n return colors.errorBackgroundColor;\n } else {\n return colors.backgroundColor;\n }\n};\n\nconst resolveInputBorderColor = (\n colors: SelectTheme[\"input\"],\n isDisabled: boolean,\n isFocused: boolean,\n isHovered: boolean,\n variant: SelectVariant | undefined,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledBorderColor;\n } else if (isFocused) {\n return colors.borderColorFocused;\n } else if (variant === \"warning\") {\n return colors.warningBorderColor;\n } else if (variant === \"success\") {\n return colors.successBorderColor;\n } else if (variant === \"error\") {\n return colors.errorBorderColor;\n } else if (isHovered) {\n return colors.borderColorFocused;\n } else {\n return colors.borderColor;\n }\n};\n\n/**\n * @deprecated\n */\nexport const createStylesFromTheme = <\n OptionType,\n IsMulti extends boolean,\n TGroup extends GroupBase<OptionType> = GroupBase<OptionType>,\n>(\n {\n menu,\n menuPortal,\n input,\n multiSelect,\n clearButtonColor,\n arrowColor,\n groupHeading,\n loadingIndicator,\n }: SelectTheme,\n variant: SelectVariant | undefined,\n): StylesConfig<OptionType, IsMulti, TGroup> => ({\n option: (base, { isDisabled, isFocused, isSelected }) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n backgroundColor: resolveOptionBackgroundColor(\n menu,\n isDisabled,\n isSelected,\n isFocused,\n ),\n color: resolveOptionColor(menu, isDisabled, isSelected, isFocused),\n cursor: isDisabled ? \"not-allowed\" : \"default\",\n whiteSpace: menu.whiteSpace || base.whiteSpace,\n \":active\": {\n backgroundColor: isDisabled\n ? undefined\n : isSelected\n ? menu.selectedItemActiveBackgroundColor\n : menu.activeBackgroundColor,\n color: isDisabled\n ? undefined\n : isSelected\n ? menu.selectedItemActiveTextColor\n : menu.activeTextColor,\n },\n }),\n control: (base, { isFocused, isDisabled, menuIsOpen }) => ({\n ...base,\n // none of react-selects styles are passed to <View />\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n minHeight: \"var(--swui-field-height)\",\n backgroundColor: resolveInputBackgroundColor(\n input,\n isDisabled,\n isFocused,\n variant,\n ),\n borderRadius: input.borderRadius,\n border: input.border,\n \"--swui-select-border-color\": resolveInputBorderColor(\n input,\n isDisabled,\n isFocused || menuIsOpen,\n false,\n variant,\n ),\n outline: isFocused ? \"var(--swui-focus-outline)\" : undefined,\n outlineOffset: isFocused ? \"-1px\" : undefined,\n transition: \"none\",\n boxShadow: isFocused ? input.boxShadowFocused : undefined,\n \"&:hover\": {\n \"--swui-select-border-color\": resolveInputBorderColor(\n input,\n false,\n isFocused || menuIsOpen,\n true,\n variant,\n ),\n },\n }),\n singleValue: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n color: input.textColor,\n }),\n noOptionsMessage: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n }),\n input: (base) => ({\n ...base,\n padding: 0,\n margin: 0,\n minHeight: input.minHeight,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n color: input.textColor,\n }),\n groupHeading: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: groupHeading.fontSize,\n lineHeight: groupHeading.lineHeight,\n fontWeight: groupHeading.fontWeight as Property.FontWeight,\n color: groupHeading.color,\n letterSpacing: groupHeading.letterSpacing,\n }),\n multiValueLabel: (base) => ({\n ...base,\n backgroundColor: multiSelect.backgroundColor,\n color: multiSelect.textColor,\n fontFamily: input.fontFamily,\n fontSize: groupHeading.fontSize,\n }),\n indicatorSeparator: (base) => ({\n ...base,\n display: \"none\",\n }),\n clearIndicator: (base) => ({\n ...base,\n padding: \"5px\",\n color: clearButtonColor.standard,\n \"&:hover\": {\n color: clearButtonColor.hover,\n },\n cursor: \"pointer\",\n }),\n placeholder: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n color: input.placeholderColor,\n }),\n container: (base) => ({\n ...base,\n }),\n valueContainer: (base) => ({\n ...base,\n padding: \"var(--swui-metrics-space-half) var(--swui-metrics-space)\",\n gap: \"var(--swui-metrics-space-half)\",\n }),\n dropdownIndicator: (base, { isFocused, isDisabled }) => ({\n ...base,\n padding: \"5px\",\n color: isDisabled\n ? arrowColor.disabled\n : isFocused\n ? arrowColor.focused.standard\n : arrowColor.closed.standard,\n \"&:hover\": {\n color: isDisabled\n ? arrowColor.disabled\n : isFocused\n ? arrowColor.focused.hover\n : arrowColor.closed.hover,\n },\n svg: {\n width: 14,\n height: 14,\n },\n }),\n menu: (base) => ({\n ...base,\n backgroundColor: menu.backgroundColor,\n color: menu.textColor,\n minWidth: menu.minWidth || base.minWidth,\n zIndex: menu.zIndex,\n width: menu.width || base.width,\n border: input.border,\n borderColor: input.borderColorFocused,\n }),\n menuPortal: (base) => ({\n ...base,\n zIndex: menuPortal.zIndex,\n }),\n multiValueRemove: (styles) => ({\n ...styles,\n backgroundColor: multiSelect.removeButtonBackgroundColor,\n \":hover\": {\n color: multiSelect.removeButtonHoverTextColor,\n backgroundColor: multiSelect.removeButtonHoverBackgroundColor,\n },\n color: multiSelect.removeButtonTextColor,\n borderRadius: \"50%\",\n width: 16,\n height: 16,\n padding: 0,\n margin: 3,\n marginTop: 4,\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n cursor: \"pointer\",\n }),\n multiValue: (base) => ({\n ...base,\n backgroundColor: multiSelect.backgroundColor,\n color: multiSelect.textColor,\n fontFamily: input.fontFamily,\n fontSize: groupHeading.fontSize,\n alignItems: \"center\",\n margin: 0,\n borderRadius: \"var(--swui-border-radius-small)\",\n overflow: \"hidden\",\n }),\n loadingMessage: (base) => ({\n ...base,\n color: loadingIndicator.textColor,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n }),\n});\n\nexport const createStylesFromVariant = <\n OptionType,\n IsMulti extends boolean,\n TGroup extends GroupBase<OptionType> = GroupBase<OptionType>,\n>(\n variant: SelectVariant,\n): StylesConfig<OptionType, IsMulti, TGroup> =>\n createStylesFromTheme(defaultSelectTheme, variant);\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport { mergeStyles } from \"react-select\";\nimport AsyncComponent, { AsyncProps } from \"react-select/async\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\n\nexport interface AsyncMultiSelectProps<T = { label: string; value: string }>\n extends AsyncProps<T, true, GroupBase<T>> {\n variant?: SelectVariant;\n isMulti?: true;\n}\n\nexport function AsyncMultiSelect<T>({\n variant = \"standard\",\n styles,\n ...selectProps\n}: AsyncMultiSelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, true>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n return (\n <AsyncComponent styles={selectStyles} {...selectProps} isMulti={true} />\n );\n}\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport AsyncComponent, { AsyncProps } from \"react-select/async\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { mergeStyles } from \"react-select\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\n\nexport interface AsyncSelectProps<T = { label: string; value: string }>\n extends AsyncProps<T, false, GroupBase<T>> {\n variant?: SelectVariant;\n isMulti?: false;\n}\n\nexport function AsyncSelect<T>({\n variant = \"standard\",\n styles,\n ...selectProps\n}: AsyncSelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, false>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n return (\n <AsyncComponent styles={selectStyles} {...selectProps} isMulti={false} />\n );\n}\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport SelectComponent, {\n ClearIndicatorProps,\n GroupBase,\n mergeStyles,\n MultiValueProps,\n Props,\n SelectComponentsConfig,\n} from \"react-select\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { Chip, stenaTimes, TextInputButton } from \"@stenajs-webui/elements\";\n\nexport interface MultiSelectOption {\n label: string;\n value: string;\n}\n\nexport interface MultiSelectProps<\n TOption extends MultiSelectOption = MultiSelectOption,\n> extends Props<TOption, true> {\n variant?: SelectVariant;\n isMulti?: true;\n}\n\nexport type MultiSelectComponentsConfig<TOption> = SelectComponentsConfig<\n TOption,\n true,\n GroupBase<TOption>\n>;\n\nconst ClearIndicator = function <TOption>({\n clearValue,\n}: ClearIndicatorProps<TOption, true, GroupBase<TOption>>) {\n return (\n // stopPropagation is needed to prevent react-select from opening its menu when clicking on the button.\n <div onMouseDown={(ev) => ev.stopPropagation()}>\n <TextInputButton\n aria-label={\"Clear\"}\n onClick={clearValue}\n icon={stenaTimes}\n variant={\"error\"}\n />\n </div>\n );\n};\n\nconst MultiValue = function <TOption extends MultiSelectOption>({\n removeProps,\n data,\n}: MultiValueProps<TOption, true, GroupBase<TOption>>) {\n return (\n // stopPropagation is needed to prevent react-select from opening its menu when clicking on the button.\n <div onMouseDown={(ev) => ev.stopPropagation()}>\n <Chip\n onClickRemove={(ev) =>\n removeProps.onClick?.(\n ev as unknown as React.MouseEvent<HTMLDivElement>,\n )\n }\n label={data.label}\n />\n </div>\n );\n};\n\nexport function MultiSelect<TOption extends MultiSelectOption>({\n variant = \"standard\",\n styles,\n components,\n ...selectProps\n}: MultiSelectProps<TOption>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<TOption, true>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n return (\n <SelectComponent\n styles={selectStyles}\n components={{ ...components, ClearIndicator, MultiValue }}\n {...selectProps}\n isMulti={true}\n />\n );\n}\n","import * as React from \"react\";\nimport { memo, ReactElement } from \"react\";\nimport {\n MultiSelect,\n MultiSelectOption,\n MultiSelectProps,\n} from \"./MultiSelect\";\nimport { components, ValueContainerProps } from \"react-select\";\n\nexport function OverflowingMultiSelect<T extends MultiSelectOption>(\n props: MultiSelectProps<T>,\n) {\n return (\n <MultiSelect\n hideSelectedOptions={false}\n {...props}\n components={{\n ...props.components,\n ValueContainer: FirstValueOnlyValueContainer,\n }}\n />\n );\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nconst FirstValueOnlyValueContainer = memo(\n (props: ValueContainerProps<any, true>) => {\n const [prevOptions, ...restChildren] = props.children as [\n ReactElement[] | null | undefined,\n ReactElement[] | null | undefined,\n ];\n\n const options = getOptionsToRender(prevOptions, props);\n\n return (\n <components.ValueContainer {...props}>\n {options}\n {restChildren}\n </components.ValueContainer>\n );\n },\n);\n\nconst getOptionsToRender = (\n optionElements: ReactElement[] | null | undefined,\n {\n /* eslint-disable @typescript-eslint/no-unused-vars */\n children,\n innerProps,\n className,\n ...spreadProps\n }: ValueContainerProps<any, true>,\n) => {\n if (!optionElements) {\n return null;\n }\n\n if (optionElements.length > 1) {\n return [\n optionElements[0],\n <components.MultiValue\n {...spreadProps}\n key={\"DUMMY_VALUE_FOR_PLUS_X\"}\n innerProps={{}}\n data={null}\n isFocused={false}\n removeProps={{}}\n index={1}\n components={{\n Container: components.MultiValueContainer,\n Label: components.MultiValueLabel,\n Remove: () => <div style={{ height: 16, margin: 3, marginTop: 4 }} />,\n }}\n >\n {\"+\" + (optionElements.length - 1)}\n </components.MultiValue>,\n ];\n } else {\n return optionElements;\n }\n};\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport SelectComponent, {\n ClearIndicatorProps,\n GroupBase,\n mergeStyles,\n Props,\n} from \"react-select\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { CloseButton } from \"@stenajs-webui/elements\";\n\nexport interface SelectProps<T = { label: string; value: string }>\n extends Props<T, false> {\n variant?: SelectVariant;\n isMulti?: false;\n}\n\nexport function Select<T>({\n variant = \"standard\",\n styles,\n components,\n ...selectProps\n}: SelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, false>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n const ClearIndicator = (\n props: ClearIndicatorProps<T, false, GroupBase<T>>,\n ) => <CloseButton aria-label={\"Clear\"} onClick={props.clearValue} />;\n\n return (\n <SelectComponent\n styles={selectStyles}\n components={{ ...components, ClearIndicator }}\n {...selectProps}\n isMulti={false}\n />\n );\n}\n","import { differenceWith, intersectionWith, isEqual, uniqWith } from \"lodash-es\";\nimport { ActionMeta, GroupBase, OnChangeValue, Options } from \"react-select\";\nimport { OnChange } from \"../components/ui/GroupedMultiSelect\";\nimport { DropdownOption } from \"../components/ui/GroupedMultiSelectTypes\";\n\nexport type GroupedOptionsType<TOption> = ReadonlyArray<GroupBase<TOption>>;\n\nexport type InternalDropdownOption<TData> =\n | InternalChildOption<TData>\n | InternalParentDropdownOption<TData>;\n\ninterface InternalChildOption<TData> {\n data: TData;\n label: string;\n value: string;\n}\n\ninterface InternalParentDropdownOption<TData> {\n data: TData;\n label: string;\n value: string;\n internalOptions: Options<DropdownOption<TData>>;\n}\n\nconst removeGroupedOptionsType = <TData>(\n removedValue: InternalParentDropdownOption<TData>,\n selectedInternalOptions: Options<InternalDropdownOption<TData>>,\n): Options<InternalDropdownOption<TData>> =>\n differenceWith(\n selectedInternalOptions,\n [...removedValue.internalOptions, removedValue],\n isEqual,\n ).map(convertInternalOptionToDropdownOption);\n\nconst removeInternalOptions = <TData>(\n selectedInternalOption: InternalDropdownOption<TData>,\n): boolean => !(\"internalOptions\" in selectedInternalOption);\n\nconst removeOptionHeaders = <TData>(\n selectedInternalOptions: Options<InternalDropdownOption<TData>>,\n): Options<InternalDropdownOption<TData>> =>\n selectedInternalOptions\n .filter(removeInternalOptions)\n .map(convertInternalOptionToDropdownOption);\n\nexport const createOnChange =\n <TData>(onChange: OnChange<TData>) =>\n (\n incomingSelectedInternalOptions: OnChangeValue<\n InternalDropdownOption<TData>,\n true\n >,\n meta: ActionMeta<InternalDropdownOption<TData>>,\n ) => {\n const selectedInternalOptions = incomingSelectedInternalOptions ?? [];\n switch (meta.action) {\n case \"select-option\":\n if (meta.option && \"internalOptions\" in meta.option) {\n const selectedOptions: OnChangeValue<\n InternalDropdownOption<TData>,\n true\n > = uniqWith(\n selectedInternalOptions.reduce<Options<DropdownOption<TData>>>(\n (previousValue, currentValue) => {\n if (\"internalOptions\" in currentValue) {\n return [...previousValue, ...currentValue.internalOptions];\n } else {\n return [\n ...previousValue,\n convertInternalOptionToDropdownOption(currentValue),\n ];\n }\n },\n [],\n ),\n isEqual,\n );\n\n onChange(selectedOptions, meta);\n } else {\n onChange(removeOptionHeaders(selectedInternalOptions), meta);\n }\n break;\n case \"deselect-option\":\n if (meta.option && \"internalOptions\" in meta.option) {\n onChange(\n removeGroupedOptionsType(\n meta.option,\n removeOptionHeaders(selectedInternalOptions),\n ),\n meta,\n );\n } else {\n onChange(removeOptionHeaders(selectedInternalOptions), meta);\n }\n break;\n case \"remove-value\":\n case \"pop-value\":\n if (meta.removedValue && \"internalOptions\" in meta.removedValue) {\n onChange(\n removeGroupedOptionsType(\n meta.removedValue,\n removeOptionHeaders(selectedInternalOptions),\n ),\n meta,\n );\n } else {\n onChange(removeOptionHeaders(selectedInternalOptions), meta);\n }\n break;\n case \"clear\":\n onChange(\n selectedInternalOptions.map(convertInternalOptionToDropdownOption),\n meta,\n );\n break;\n case \"create-option\":\n onChange(\n selectedInternalOptions.map(convertInternalOptionToDropdownOption),\n meta,\n );\n break;\n default:\n break;\n }\n };\n\nexport const convertGroupedDropdownOptionsToInternalOptions = <TData>(\n options: GroupedOptionsType<DropdownOption<TData>>,\n): InternalDropdownOption<TData>[] => {\n return options.reduce<InternalDropdownOption<TData>[]>(\n (previousValue, currentValue) => {\n return [\n ...previousValue,\n convertGroupedDropdownOptionToInternalOption(currentValue),\n ...currentValue.options.map(convertDropdownOptionToInternalOption),\n ];\n },\n [],\n );\n};\n\nexport const convertValueToInternalValue = <TData>(\n options: GroupedOptionsType<DropdownOption<TData>>,\n values: Options<DropdownOption<TData>> | undefined,\n): InternalDropdownOption<TData>[] => {\n if (!values) {\n return [];\n }\n const selectedOptions: InternalDropdownOption<TData>[] = [];\n options.forEach((option) => {\n if (allOptionsExists(option.options, values)) {\n selectedOptions.push(\n convertGroupedDropdownOptionToInternalOption(option),\n );\n }\n selectedOptions.push(\n ...intersectionWith(option.options, values, isEqual).map((option) =>\n convertDropdownOptionToInternalOption(option),\n ),\n );\n });\n return selectedOptions;\n};\n\nexport const allOptionsExists = <TData>(\n options: Options<DropdownOption<TData>>,\n selectedValues: Options<DropdownOption<TData>> | undefined,\n): boolean => {\n if (!selectedValues) {\n return false;\n }\n\n return (\n intersectionWith(options, selectedValues, isEqual).length === options.length\n );\n};\n\nexport const convertDropdownOptionToInternalOption = <TData>(\n option: DropdownOption<TData>,\n): InternalDropdownOption<TData> => ({\n data: option.data,\n label: option.label,\n value: option.value,\n});\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nexport const convertGroupedDropdownOptionToInternalOption = <TData>(\n option: GroupBase<DropdownOption<TData>>,\n): InternalDropdownOption<TData> => ({\n data: option.label as any,\n label: option.label as any,\n value: option.label as any,\n internalOptions: option.options,\n});\n\nexport const convertInternalOptionToDropdownOption = <TData>(\n option: InternalDropdownOption<TData>,\n): DropdownOption<TData> => ({\n data: option.data,\n label: option.label,\n value: option.value,\n});\n","import { Row, Space, Text, TextSize } from \"@stenajs-webui/core\";\nimport { Icon, stenaCheck } from \"@stenajs-webui/elements\";\nimport * as React from \"react\";\nimport { ReactNode } from \"react\";\nimport {\n ActionMeta,\n components,\n GroupBase,\n MultiValueProps,\n OnChangeValue,\n OptionProps,\n Options,\n} from \"react-select\";\nimport { defaultSelectTheme, SelectTheme } from \"../../SelectTheme\";\nimport {\n convertGroupedDropdownOptionsToInternalOptions,\n convertValueToInternalValue,\n createOnChange,\n GroupedOptionsType,\n InternalDropdownOption,\n} from \"../../util/multiDropdownUtils\";\nimport { DropdownOption } from \"./GroupedMultiSelectTypes\";\nimport {\n MultiSelect,\n MultiSelectComponentsConfig,\n MultiSelectProps,\n} from \"./MultiSelect\";\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nexport type OnChange<TData> = (\n value: OnChangeValue<DropdownOption<TData>, true>,\n action: ActionMeta<any>,\n) => void;\n\nexport interface GroupedMultiSelectProps<TData>\n extends Omit<\n MultiSelectProps<InternalDropdownOption<TData>>,\n \"options\" | \"onChange\" | \"value\" | \"components\"\n > {\n /**\n * Same as Select prop `component` but without MultiValue and Option since they can not be modified\n */\n components?: Omit<\n MultiSelectComponentsConfig<InternalDropdownOption<TData>>,\n \"MultiValue\" | \"Option\"\n >;\n /**\n * Same as Select prop `options` but only with GroupOptionsType\n */\n options?: GroupedOptionsType<DropdownOption<TData>>;\n /**\n * Same as Select prop `onChange` but only with GroupOptionsType\n */\n onChange?: OnChange<TData>;\n /**\n * Same as Select prop `value` but only with GroupOptionsType\n */\n value?: Options<DropdownOption<TData>> | undefined;\n}\n\nconst resolveIconColor = (\n theme: SelectTheme,\n isFocused: boolean,\n): string | undefined =>\n isFocused\n ? theme.menu.selectedItemHoverIconColor\n : theme.menu.selectedItemIconColor;\n\nfunction formatInnerOptionLabel<TData>(\n props: OptionProps<\n InternalDropdownOption<TData>,\n true,\n GroupBase<InternalDropdownOption<TData>>\n >,\n) {\n const { formatGroupLabel, formatOptionLabel } = props.selectProps;\n\n if (\"internalOptions\" in props.data) {\n return formatGroupLabel\n ? formatGroupLabel({\n label: props.data.label,\n options: props.data.internalOptions,\n })\n : props.label;\n }\n\n return formatOptionLabel\n ? formatOptionLabel(props.data, {\n context: \"menu\",\n inputValue: props.selectProps.inputValue ?? \"\",\n selectValue: props.getValue(),\n })\n : props.label;\n}\n\nexport function GroupedMultiSelect<TData>({\n onChange,\n options,\n value,\n variant = \"standard\",\n /* eslint-disable @typescript-eslint/no-unused-vars */\n formatGroupLabel,\n formatOptionLabel,\n ...selectProps\n}: GroupedMultiSelectProps<TData>): React.ReactElement<\n GroupedMultiSelectProps<TData>\n> {\n const Option = (\n props: OptionProps<\n InternalDropdownOption<TData>,\n true,\n GroupBase<InternalDropdownOption<TData>>\n >,\n ) => {\n const label = formatInnerOptionLabel(props);\n const isGroupOption = \"internalOptions\" in props.data;\n\n return (\n <components.Option {...props}>\n <Row>\n {!isGroupOption && <Space />}\n <InnerOption\n theme={defaultSelectTheme}\n size={!isGroupOption ? \"small\" : undefined}\n label={label}\n selected={props.isSelected}\n focused={props.isFocused}\n />\n </Row>\n </components.Option>\n );\n };\n\n const MultiValue = (\n props: MultiValueProps<\n InternalDropdownOption<TData>,\n true,\n GroupBase<InternalDropdownOption<TData>>\n >,\n ) => {\n return !(\"internalOptions\" in props.data) ? (\n <components.MultiValue {...props} />\n ) : null;\n };\n\n const internalValue = options\n ? convertValueToInternalValue(options, value)\n : undefined;\n const internalOptions = options\n ? convertGroupedDropdownOptionsToInternalOptions(options)\n : undefined;\n\n return (\n <MultiSelect<InternalDropdownOption<TData>>\n {...selectProps}\n onChange={onChange ? createOnChange<TData>(onChange) : undefined}\n hideSelectedOptions={false}\n components={{\n ...selectProps.components,\n MultiValue,\n Option,\n }}\n isMulti={true}\n options={internalOptions}\n value={internalValue}\n variant={variant}\n />\n );\n}\n\ninterface InnerOptionProps {\n size?: TextSize;\n selected: boolean;\n theme: SelectTheme;\n label: ReactNode;\n focused: boolean;\n}\n\nconst InnerOption: React.FC<InnerOptionProps> = ({\n focused,\n label,\n selected,\n size,\n theme,\n}) => (\n <Row alignItems={\"center\"} justifyContent={\"space-between\"} flexGrow={1}>\n <Text tabIndex={-1} size={size} color={\"currentColor\"}>\n {label}\n </Text>\n {selected && (\n <Icon\n color={resolveIconColor(theme, focused)}\n icon={stenaCheck}\n size={12}\n />\n )}\n </Row>\n);\n","import { CloseButton } from \"@stenajs-webui/elements\";\nimport * as React from \"react\";\nimport { useMemo } from \"react\";\nimport { ClearIndicatorProps, mergeStyles } from \"react-select\";\nimport CreatableComponent, { CreatableProps } from \"react-select/creatable\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\n\nexport interface CreatableSelectProps<T = { label: string; value: string }>\n extends CreatableProps<T, false, GroupBase<T>> {\n variant?: SelectVariant;\n isMulti?: false;\n ariaLabelClear?: string;\n}\n\nexport function CreatableSelect<T>({\n variant = \"standard\",\n styles,\n components,\n ariaLabelClear = \"Clear\",\n ...selectProps\n}: CreatableSelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, false>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n const ClearIndicator = (\n props: ClearIndicatorProps<T, false, GroupBase<T>>,\n ) => <CloseButton aria-label={ariaLabelClear} onClick={props.clearValue} />;\n\n return (\n <CreatableComponent\n styles={selectStyles}\n components={{ ...components, ClearIndicator }}\n {...selectProps}\n isMulti={false}\n />\n );\n}\n","import { Column, Row, Space, Spacing } from \"@stenajs-webui/core\";\nimport { Chip, FlatButton } from \"@stenajs-webui/elements\";\nimport { ValueAndOnValueChangeProps } from \"@stenajs-webui/forms\";\nimport * as React from \"react\";\nimport { PropsWithChildren } from \"react\";\nimport { MultiSelectOption } from \"../MultiSelect\";\n\nexport interface ChipRowItem extends MultiSelectOption {}\n\nexport interface ChipRowProps<TValue>\n extends ValueAndOnValueChangeProps<TValue> {\n noneSelectedLabel?: string;\n}\n\nexport function ChipRow<TValue extends ChipRowItem>({\n value,\n onValueChange,\n noneSelectedLabel = \"None\",\n children,\n}: PropsWithChildren<ChipRowProps<Array<TValue>>>) {\n return (\n <Column flex={1}>\n <Row flexWrap={\"wrap\"}>\n {value?.map((v) => (\n <Row key={v.value}>\n <Spacing num={0.5}>\n <Chip\n label={v.label}\n onClickRemove={() =>\n onValueChange?.(\n value?.filter((f) => f.value !== v.value) ?? [],\n )\n }\n />\n </Spacing>\n <Space />\n </Row>\n ))}\n {value?.length ? (\n <Spacing num={0.5}>\n <FlatButton\n size={\"small\"}\n label={\"Clear\"}\n onClick={() => onValueChange?.([])}\n />\n </Spacing>\n ) : (\n <Spacing num={0.5}>\n <Chip variant={\"secondary\"} label={noneSelectedLabel} />\n </Spacing>\n )}\n </Row>\n <Space num={0.5} />\n {children}\n </Column>\n );\n}\n","import { ValueAndOnValueChangeProps } from \"@stenajs-webui/forms\";\nimport * as React from \"react\";\nimport {\n MultiSelect,\n MultiSelectOption,\n MultiSelectProps,\n} from \"../MultiSelect\";\nimport { ChipRow, ChipRowItem } from \"./ChipRow\";\n\nexport interface ChipMultiSelectOption extends ChipRowItem {}\n\n/**\n * @deprecated renamed to ChipMultiSelectOption\n */\nexport type ChipMultiSelectValue = ChipMultiSelectOption;\n\nexport interface ChipMultiSelectProps<\n TOption extends MultiSelectOption = MultiSelectOption,\n> extends Omit<MultiSelectProps<TOption>, \"value\" | \"onChange\" | \"isLoading\">,\n ValueAndOnValueChangeProps<Array<TOption>> {\n loading?: boolean;\n inputValue?: string;\n onInputChange?: (inputValue: string) => void;\n noneSelectedLabel?: string;\n}\n\nfunction _ChipMultiSelect<TOption extends ChipMultiSelectOption>({\n value,\n onValueChange,\n placeholder = \"Type to search\",\n loading,\n inputValue,\n onInputChange,\n noneSelectedLabel = \"None\",\n ...selectProps\n}: ChipMultiSelectProps<TOption>) {\n return (\n <ChipRow\n noneSelectedLabel={noneSelectedLabel}\n onValueChange={onValueChange}\n value={value}\n >\n <MultiSelect<TOption>\n {...selectProps}\n isClearable={false}\n value={value}\n onChange={\n onValueChange ? (value) => onValueChange([...value]) : undefined\n }\n backspaceRemovesValue={false}\n hideSelectedOptions\n controlShouldRenderValue={false}\n placeholder={placeholder}\n isLoading={loading}\n inputValue={inputValue}\n onInputChange={onInputChange}\n />\n </ChipRow>\n );\n}\n\nexport const ChipMultiSelect = React.memo(\n _ChipMultiSelect,\n) as typeof _ChipMultiSelect;\n","import * as React from \"react\";\nimport { ValueAndOnValueChangeProps } from \"@stenajs-webui/forms\";\nimport {\n GroupedMultiSelect,\n GroupedMultiSelectProps,\n} from \"../GroupedMultiSelect\";\nimport { DropdownOption } from \"../GroupedMultiSelectTypes\";\nimport { ChipRow } from \"./ChipRow\";\n\nexport interface GroupedChipMultiSelectValue<TData>\n extends DropdownOption<TData> {}\n\nexport interface GroupedChipMultiSelectProps<TData>\n extends Omit<GroupedMultiSelectProps<TData>, \"onChange\" | \"value\">,\n ValueAndOnValueChangeProps<Array<DropdownOption<TData>>> {\n loading?: boolean;\n inputValue?: string;\n onInputChange?: (inputValue: string) => void;\n noneSelectedLabel?: string;\n}\n\nfunction _GroupedChipMultiSelect<TData>({\n value,\n onValueChange,\n placeholder = \"Type to search\",\n loading,\n inputValue,\n onInputChange,\n noneSelectedLabel = \"None\",\n ...selectProps\n}: GroupedChipMultiSelectProps<TData>) {\n return (\n <ChipRow\n noneSelectedLabel={noneSelectedLabel}\n onValueChange={onValueChange}\n value={value}\n >\n <GroupedMultiSelect<TData>\n {...selectProps}\n isClearable={false}\n value={value}\n onChange={\n onValueChange ? (value) => onValueChange([...value]) : undefined\n }\n backspaceRemovesValue={false}\n hideSelectedOptions\n controlShouldRenderValue={false}\n placeholder={placeholder}\n isLoading={loading}\n inputValue={inputValue}\n onInputChange={onInputChange}\n />\n </ChipRow>\n );\n}\n\nexport const GroupedChipMultiSelect = React.memo(\n _GroupedChipMultiSelect,\n) as typeof _GroupedChipMultiSelect;\n"],"names":["defaultSelectTheme","cssColor","resolveOptionBackgroundColor","colors","isDisabled","isSelected","isFocused","resolveOptionColor","resolveInputBackgroundColor","variant","resolveInputBorderColor","isHovered","createStylesFromTheme","menu","menuPortal","input","multiSelect","clearButtonColor","arrowColor","groupHeading","loadingIndicator","base","menuIsOpen","styles","createStylesFromVariant","AsyncMultiSelect","selectProps","selectStyles","useMemo","sourceStyles","mergeStyles","AsyncComponent","AsyncSelect","ClearIndicator","clearValue","ev","jsx","TextInputButton","stenaTimes","MultiValue","removeProps","data","Chip","_a","MultiSelect","components","SelectComponent","OverflowingMultiSelect","props","FirstValueOnlyValueContainer","memo","prevOptions","restChildren","options","getOptionsToRender","jsxs","optionElements","children","innerProps","className","spreadProps","createElement","Select","CloseButton","removeGroupedOptionsType","removedValue","selectedInternalOptions","differenceWith","isEqual","convertInternalOptionToDropdownOption","removeInternalOptions","selectedInternalOption","removeOptionHeaders","createOnChange","onChange","incomingSelectedInternalOptions","meta","selectedOptions","uniqWith","previousValue","currentValue","convertGroupedDropdownOptionsToInternalOptions","convertGroupedDropdownOptionToInternalOption","convertDropdownOptionToInternalOption","convertValueToInternalValue","values","option","allOptionsExists","intersectionWith","selectedValues","resolveIconColor","theme","formatInnerOptionLabel","formatGroupLabel","formatOptionLabel","GroupedMultiSelect","value","Option","label","isGroupOption","Row","Space","InnerOption","internalValue","internalOptions","focused","selected","size","Text","Icon","stenaCheck","CreatableSelect","ariaLabelClear","CreatableComponent","ChipRow","onValueChange","noneSelectedLabel","Column","v","Spacing","f","FlatButton","_ChipMultiSelect","placeholder","loading","inputValue","onInputChange","ChipMultiSelect","React","_GroupedChipMultiSelect","GroupedChipMultiSelect"],"mappings":"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"}
1
+ {"version":3,"file":"index.es.js","sources":["../src/SelectTheme.ts","../src/util/StylesBuilder.ts","../src/components/ui/AsyncMultiSelect.tsx","../src/components/ui/AsyncSelect.tsx","../src/components/ui/MultiSelect.tsx","../src/components/ui/OverflowingMultiSelect.tsx","../src/components/ui/Select.tsx","../src/util/multiDropdownUtils.ts","../src/components/ui/GroupedMultiSelect.tsx","../src/components/ui/CreatableSelect.tsx","../src/components/ui/ChipMultiSelect/ChipRow.tsx","../src/components/ui/ChipMultiSelect/ChipMultiSelect.tsx","../src/components/ui/ChipMultiSelect/GroupedChipMultiSelect.tsx"],"sourcesContent":["import { Property } from \"csstype\";\nimport { cssColor } from \"@stenajs-webui/theme\";\n\nexport interface SelectTheme {\n arrowColor: {\n disabled: string;\n focused: {\n standard: string;\n hover: string;\n };\n closed: {\n standard: string;\n hover: string;\n };\n };\n clearButtonColor: {\n standard: string;\n hover: string;\n };\n input: {\n backgroundColor: string;\n border: string;\n borderColor: string;\n disabledBorderColor: string;\n borderColorFocused: string;\n borderRadius: string;\n disabledBackgroundColor: string;\n warningBackgroundColor: string;\n errorBackgroundColor: string;\n successBackgroundColor: string;\n warningBorderColor: string;\n errorBorderColor: string;\n successBorderColor: string;\n boxShadowFocused: string;\n fontFamily: string;\n fontSize: string;\n height?: string;\n minHeight?: string;\n placeholderColor: string;\n textColor: string;\n };\n loadingIndicator: {\n textColor: string;\n };\n menu: {\n disabledTextColor: string;\n disabledBackgroundColor: string;\n textColor: string;\n backgroundColor: string;\n hoverTextColor: string;\n hoverBackgroundColor: string;\n activeTextColor: string;\n activeBackgroundColor: string;\n minWidth?: string;\n selectedItemTextColor: string;\n selectedItemBackgroundColor: string;\n selectedItemHoverTextColor: string;\n selectedItemIconColor: string;\n selectedItemHoverIconColor: string;\n selectedItemHoverBackgroundColor: string;\n selectedItemActiveTextColor: string;\n selectedItemActiveBackgroundColor: string;\n zIndex: number;\n width?: string;\n whiteSpace?: Property.WhiteSpace;\n };\n groupHeading: {\n fontSize: string;\n lineHeight: string;\n fontWeight: string;\n color: string;\n letterSpacing: string;\n };\n menuPortal: {\n zIndex: number;\n };\n multiSelect: {\n backgroundColor: string;\n textColor: string;\n removeButtonBackgroundColor: string;\n removeButtonTextColor: string;\n removeButtonHoverBackgroundColor: string;\n removeButtonHoverTextColor: string;\n };\n}\n\nexport const defaultSelectTheme: SelectTheme = {\n arrowColor: {\n disabled: cssColor(\"--silver-light\"),\n focused: {\n hover: cssColor(\"--lhds-color-blue-600\"),\n standard: cssColor(\"--lhds-color-blue-600\"),\n },\n closed: {\n hover: cssColor(\"--lhds-color-blue-600\"),\n standard: cssColor(\"--lhds-color-blue-600\"),\n },\n },\n clearButtonColor: {\n hover: cssColor(\"--lhds-color-red-600\"),\n standard: cssColor(\"--lhds-color-red-500\"),\n },\n input: {\n backgroundColor: \"var(--swui-field-bg-enabled)\",\n border: `1px solid var(--swui-select-border-color)`,\n borderColor: \"var(--swui-field-border-color)\",\n borderColorFocused: \"var(--swui-field-border-color-hover)\",\n disabledBackgroundColor: \"var(--swui-field-bg-disabled)\",\n disabledBorderColor: \"var(--swui-field-bg-disabled)\",\n warningBackgroundColor: \"var(--swui-state-alert-light-color)\",\n warningBorderColor: \"var(--swui-state-alert-light-color)\",\n errorBackgroundColor: \"var(--swui-state-error-light-color)\",\n errorBorderColor: \"var(--swui-state-error-light-color)\",\n successBackgroundColor: \"var(--swui-state-success-light-color)\",\n successBorderColor: \"var(--swui-state-success-light-color)\",\n boxShadowFocused: \"none\",\n fontFamily: \"var(--swui-font-primary)\",\n fontSize: \"var(--swui-font-size-inputs)\",\n minHeight: \"24px\",\n placeholderColor: \"var(--swui-field-text-color)\",\n textColor: \"var(--swui-field-text-color)\",\n borderRadius: \"var(--swui-field-border-radius)\",\n },\n loadingIndicator: {\n textColor: \"var(--swui-field-text-color)\",\n },\n groupHeading: {\n fontSize: \"var(--swui-font-size-small)\",\n lineHeight: \"var(--swui-line-height-smaller)\",\n fontWeight: \"var(--swui-font-weight-text-bold)\",\n color: cssColor(\"--lhds-color-ui-600\"),\n letterSpacing: \"0.1rem\",\n },\n menu: {\n activeBackgroundColor: cssColor(\"--lhds-color-blue-100\"),\n activeTextColor: \"var(--swui-field-text-color)\",\n selectedItemActiveBackgroundColor: cssColor(\"--lhds-color-blue-500\"),\n selectedItemActiveTextColor: cssColor(\"--lhds-color-blue-50\"),\n disabledTextColor: \"var(--swui-field-text-color-disabled)\",\n disabledBackgroundColor: \"var(--swui-field-bg-disabled)\",\n textColor: \"var(--swui-field-text-color)\",\n backgroundColor: \"var(--swui-field-bg-enabled)\",\n hoverTextColor: \"var(--swui-field-text-color)\",\n hoverBackgroundColor: cssColor(\"--lhds-color-blue-200\"),\n selectedItemTextColor: cssColor(\"--lhds-color-blue-500\"),\n selectedItemIconColor: cssColor(\"--lhds-color-blue-500\"),\n selectedItemHoverTextColor: \"var(--swui-field-text-color)\",\n selectedItemHoverIconColor: \"var(--swui-field-text-color)\",\n selectedItemBackgroundColor: cssColor(\"--lhds-color-blue-50\"),\n selectedItemHoverBackgroundColor: cssColor(\"--lhds-color-blue-50\"),\n zIndex: 1,\n width: \"auto\",\n minWidth: \"100%\",\n whiteSpace: \"nowrap\",\n },\n menuPortal: {\n zIndex: 1,\n },\n multiSelect: {\n backgroundColor: \"var(--swui-primary-action-color)\",\n textColor: cssColor(\"--lhds-color-blue-50\"),\n removeButtonBackgroundColor: \"transparent\",\n removeButtonTextColor: \"var(--swui-white)\",\n removeButtonHoverBackgroundColor: \"var(--swui-primary-action-color-hover)\",\n removeButtonHoverTextColor: \"var(--swui-white)\",\n },\n};\n","import { StylesConfig } from \"react-select\";\nimport { defaultSelectTheme, SelectTheme } from \"../SelectTheme\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\nimport { Property } from \"csstype\";\n\nexport type SelectVariant = \"standard\" | \"warning\" | \"error\" | \"success\";\n\nconst resolveOptionBackgroundColor = (\n colors: SelectTheme[\"menu\"],\n isDisabled: boolean,\n isSelected: boolean,\n isFocused: boolean,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledBackgroundColor;\n } else if (isSelected && isFocused) {\n return colors.selectedItemHoverBackgroundColor;\n } else if (isSelected) {\n return colors.selectedItemBackgroundColor;\n } else if (isFocused) {\n return colors.hoverBackgroundColor;\n } else {\n return undefined;\n }\n};\n\nconst resolveOptionColor = (\n colors: SelectTheme[\"menu\"],\n isDisabled: boolean,\n isSelected: boolean,\n isFocused: boolean,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledTextColor;\n } else if (isSelected && isFocused) {\n return colors.selectedItemHoverTextColor;\n } else if (isSelected) {\n return colors.selectedItemTextColor;\n } else if (isFocused) {\n return colors.hoverTextColor;\n } else {\n return undefined;\n }\n};\n\nconst resolveInputBackgroundColor = (\n colors: SelectTheme[\"input\"],\n isDisabled: boolean,\n isFocused: boolean,\n variant: SelectVariant | undefined,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledBackgroundColor;\n } else if (isFocused) {\n return colors.backgroundColor;\n } else if (variant === \"warning\") {\n return colors.warningBackgroundColor;\n } else if (variant === \"success\") {\n return colors.successBackgroundColor;\n } else if (variant === \"error\") {\n return colors.errorBackgroundColor;\n } else {\n return colors.backgroundColor;\n }\n};\n\nconst resolveInputBorderColor = (\n colors: SelectTheme[\"input\"],\n isDisabled: boolean,\n isFocused: boolean,\n isHovered: boolean,\n variant: SelectVariant | undefined,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledBorderColor;\n } else if (isFocused) {\n return colors.borderColorFocused;\n } else if (variant === \"warning\") {\n return colors.warningBorderColor;\n } else if (variant === \"success\") {\n return colors.successBorderColor;\n } else if (variant === \"error\") {\n return colors.errorBorderColor;\n } else if (isHovered) {\n return colors.borderColorFocused;\n } else {\n return colors.borderColor;\n }\n};\n\n/**\n * @deprecated\n */\nexport const createStylesFromTheme = <\n OptionType,\n IsMulti extends boolean,\n TGroup extends GroupBase<OptionType> = GroupBase<OptionType>,\n>(\n {\n menu,\n menuPortal,\n input,\n multiSelect,\n clearButtonColor,\n arrowColor,\n groupHeading,\n loadingIndicator,\n }: SelectTheme,\n variant: SelectVariant | undefined,\n): StylesConfig<OptionType, IsMulti, TGroup> => ({\n option: (base, { isDisabled, isFocused, isSelected }) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n backgroundColor: resolveOptionBackgroundColor(\n menu,\n isDisabled,\n isSelected,\n isFocused,\n ),\n color: resolveOptionColor(menu, isDisabled, isSelected, isFocused),\n cursor: isDisabled ? \"not-allowed\" : \"default\",\n whiteSpace: menu.whiteSpace || base.whiteSpace,\n \":active\": {\n backgroundColor: isDisabled\n ? undefined\n : isSelected\n ? menu.selectedItemActiveBackgroundColor\n : menu.activeBackgroundColor,\n color: isDisabled\n ? undefined\n : isSelected\n ? menu.selectedItemActiveTextColor\n : menu.activeTextColor,\n },\n }),\n control: (base, { isFocused, isDisabled, menuIsOpen }) => ({\n ...base,\n // none of react-selects styles are passed to <View />\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n minHeight: \"var(--swui-field-height)\",\n backgroundColor: resolveInputBackgroundColor(\n input,\n isDisabled,\n isFocused,\n variant,\n ),\n borderRadius: input.borderRadius,\n border: input.border,\n \"--swui-select-border-color\": resolveInputBorderColor(\n input,\n isDisabled,\n isFocused || menuIsOpen,\n false,\n variant,\n ),\n outline: isFocused ? \"var(--swui-focus-outline)\" : undefined,\n outlineOffset: isFocused ? \"-1px\" : undefined,\n transition: \"none\",\n boxShadow: isFocused ? input.boxShadowFocused : undefined,\n \"&:hover\": {\n \"--swui-select-border-color\": resolveInputBorderColor(\n input,\n false,\n isFocused || menuIsOpen,\n true,\n variant,\n ),\n },\n }),\n singleValue: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n color: input.textColor,\n }),\n noOptionsMessage: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n }),\n input: (base) => ({\n ...base,\n padding: 0,\n margin: 0,\n minHeight: input.minHeight,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n color: input.textColor,\n }),\n groupHeading: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: groupHeading.fontSize,\n lineHeight: groupHeading.lineHeight,\n fontWeight: groupHeading.fontWeight as Property.FontWeight,\n color: groupHeading.color,\n letterSpacing: groupHeading.letterSpacing,\n }),\n multiValueLabel: (base) => ({\n ...base,\n backgroundColor: multiSelect.backgroundColor,\n color: multiSelect.textColor,\n fontFamily: input.fontFamily,\n fontSize: groupHeading.fontSize,\n }),\n indicatorSeparator: (base) => ({\n ...base,\n display: \"none\",\n }),\n clearIndicator: (base) => ({\n ...base,\n padding: \"5px\",\n color: clearButtonColor.standard,\n \"&:hover\": {\n color: clearButtonColor.hover,\n },\n cursor: \"pointer\",\n }),\n placeholder: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n color: input.placeholderColor,\n }),\n container: (base) => ({\n ...base,\n }),\n valueContainer: (base) => ({\n ...base,\n padding: \"var(--swui-metrics-space-half) var(--swui-metrics-space)\",\n gap: \"var(--swui-metrics-space-half)\",\n }),\n dropdownIndicator: (base, { isFocused, isDisabled }) => ({\n ...base,\n padding: \"5px\",\n color: isDisabled\n ? arrowColor.disabled\n : isFocused\n ? arrowColor.focused.standard\n : arrowColor.closed.standard,\n \"&:hover\": {\n color: isDisabled\n ? arrowColor.disabled\n : isFocused\n ? arrowColor.focused.hover\n : arrowColor.closed.hover,\n },\n svg: {\n width: 14,\n height: 14,\n },\n }),\n menu: (base) => ({\n ...base,\n backgroundColor: menu.backgroundColor,\n color: menu.textColor,\n minWidth: menu.minWidth || base.minWidth,\n zIndex: menu.zIndex,\n width: menu.width || base.width,\n border: input.border,\n borderColor: input.borderColorFocused,\n }),\n menuPortal: (base) => ({\n ...base,\n zIndex: menuPortal.zIndex,\n }),\n multiValueRemove: (styles) => ({\n ...styles,\n backgroundColor: multiSelect.removeButtonBackgroundColor,\n \":hover\": {\n color: multiSelect.removeButtonHoverTextColor,\n backgroundColor: multiSelect.removeButtonHoverBackgroundColor,\n },\n color: multiSelect.removeButtonTextColor,\n borderRadius: \"50%\",\n width: 16,\n height: 16,\n padding: 0,\n margin: 3,\n marginTop: 4,\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n cursor: \"pointer\",\n }),\n multiValue: (base) => ({\n ...base,\n backgroundColor: multiSelect.backgroundColor,\n color: multiSelect.textColor,\n fontFamily: input.fontFamily,\n fontSize: groupHeading.fontSize,\n alignItems: \"center\",\n margin: 0,\n borderRadius: \"var(--swui-border-radius-small)\",\n overflow: \"hidden\",\n }),\n loadingMessage: (base) => ({\n ...base,\n color: loadingIndicator.textColor,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n }),\n});\n\nexport const createStylesFromVariant = <\n OptionType,\n IsMulti extends boolean,\n TGroup extends GroupBase<OptionType> = GroupBase<OptionType>,\n>(\n variant: SelectVariant,\n): StylesConfig<OptionType, IsMulti, TGroup> =>\n createStylesFromTheme(defaultSelectTheme, variant);\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport { mergeStyles } from \"react-select\";\nimport AsyncComponent, { AsyncProps } from \"react-select/async\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\n\nexport interface AsyncMultiSelectProps<T = { label: string; value: string }>\n extends AsyncProps<T, true, GroupBase<T>> {\n variant?: SelectVariant;\n isMulti?: true;\n}\n\nexport function AsyncMultiSelect<T>({\n variant = \"standard\",\n styles,\n ...selectProps\n}: AsyncMultiSelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, true>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n return (\n <AsyncComponent styles={selectStyles} {...selectProps} isMulti={true} />\n );\n}\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport AsyncComponent, { AsyncProps } from \"react-select/async\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { mergeStyles } from \"react-select\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\n\nexport interface AsyncSelectProps<T = { label: string; value: string }>\n extends AsyncProps<T, false, GroupBase<T>> {\n variant?: SelectVariant;\n isMulti?: false;\n}\n\nexport function AsyncSelect<T>({\n variant = \"standard\",\n styles,\n ...selectProps\n}: AsyncSelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, false>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n return (\n <AsyncComponent styles={selectStyles} {...selectProps} isMulti={false} />\n );\n}\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport SelectComponent, {\n ClearIndicatorProps,\n GroupBase,\n mergeStyles,\n MultiValueProps,\n Props,\n SelectComponentsConfig,\n} from \"react-select\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { Chip, stenaTimes, TextInputButton } from \"@stenajs-webui/elements\";\n\nexport interface MultiSelectOption {\n label: string;\n value: string;\n}\n\nexport interface MultiSelectProps<\n TOption extends MultiSelectOption = MultiSelectOption,\n> extends Props<TOption, true> {\n variant?: SelectVariant;\n isMulti?: true;\n}\n\nexport type MultiSelectComponentsConfig<TOption> = SelectComponentsConfig<\n TOption,\n true,\n GroupBase<TOption>\n>;\n\nconst ClearIndicator = function <TOption>({\n clearValue,\n}: ClearIndicatorProps<TOption, true, GroupBase<TOption>>) {\n return (\n // stopPropagation is needed to prevent react-select from opening its menu when clicking on the button.\n <div onMouseDown={(ev) => ev.stopPropagation()}>\n <TextInputButton\n aria-label={\"Clear\"}\n onClick={clearValue}\n icon={stenaTimes}\n variant={\"error\"}\n />\n </div>\n );\n};\n\nconst MultiValue = function <TOption extends MultiSelectOption>({\n removeProps,\n data,\n}: MultiValueProps<TOption, true, GroupBase<TOption>>) {\n return (\n // stopPropagation is needed to prevent react-select from opening its menu when clicking on the button.\n <div onMouseDown={(ev) => ev.stopPropagation()}>\n <Chip\n onClickRemove={(ev) =>\n removeProps.onClick?.(\n ev as unknown as React.MouseEvent<HTMLDivElement>,\n )\n }\n label={data.label}\n />\n </div>\n );\n};\n\nexport function MultiSelect<TOption extends MultiSelectOption>({\n variant = \"standard\",\n styles,\n components,\n ...selectProps\n}: MultiSelectProps<TOption>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<TOption, true>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n return (\n <SelectComponent\n styles={selectStyles}\n components={{ ...components, ClearIndicator, MultiValue }}\n {...selectProps}\n isMulti={true}\n />\n );\n}\n","import * as React from \"react\";\nimport { memo, ReactElement } from \"react\";\nimport {\n MultiSelect,\n MultiSelectOption,\n MultiSelectProps,\n} from \"./MultiSelect\";\nimport { components, ValueContainerProps } from \"react-select\";\n\nexport function OverflowingMultiSelect<T extends MultiSelectOption>(\n props: MultiSelectProps<T>,\n) {\n return (\n <MultiSelect\n hideSelectedOptions={false}\n {...props}\n components={{\n ...props.components,\n ValueContainer: FirstValueOnlyValueContainer,\n }}\n />\n );\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nconst FirstValueOnlyValueContainer = memo(\n (props: ValueContainerProps<any, true>) => {\n const [prevOptions, ...restChildren] = props.children as [\n ReactElement[] | null | undefined,\n ReactElement[] | null | undefined,\n ];\n\n const options = getOptionsToRender(prevOptions, props);\n\n return (\n <components.ValueContainer {...props}>\n {options}\n {restChildren}\n </components.ValueContainer>\n );\n },\n);\n\nconst getOptionsToRender = (\n optionElements: ReactElement[] | null | undefined,\n {\n /* eslint-disable @typescript-eslint/no-unused-vars */\n children,\n innerProps,\n className,\n ...spreadProps\n }: ValueContainerProps<any, true>,\n) => {\n if (!optionElements) {\n return null;\n }\n\n if (optionElements.length > 1) {\n return [\n optionElements[0],\n <components.MultiValue\n {...spreadProps}\n key={\"DUMMY_VALUE_FOR_PLUS_X\"}\n innerProps={{}}\n data={null}\n isFocused={false}\n removeProps={{}}\n index={1}\n components={{\n Container: components.MultiValueContainer,\n Label: components.MultiValueLabel,\n Remove: () => <div style={{ height: 16, margin: 3, marginTop: 4 }} />,\n }}\n >\n {\"+\" + (optionElements.length - 1)}\n </components.MultiValue>,\n ];\n } else {\n return optionElements;\n }\n};\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport SelectComponent, {\n ClearIndicatorProps,\n GroupBase,\n mergeStyles,\n Props,\n} from \"react-select\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { CloseButton } from \"@stenajs-webui/elements\";\n\nexport interface SelectProps<T = { label: string; value: string }>\n extends Props<T, false> {\n variant?: SelectVariant;\n isMulti?: false;\n}\n\nexport function Select<T>({\n variant = \"standard\",\n styles,\n components,\n ...selectProps\n}: SelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, false>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n const ClearIndicator = (\n props: ClearIndicatorProps<T, false, GroupBase<T>>,\n ) => <CloseButton aria-label={\"Clear\"} onClick={props.clearValue} />;\n\n return (\n <SelectComponent\n styles={selectStyles}\n components={{ ...components, ClearIndicator }}\n {...selectProps}\n isMulti={false}\n />\n );\n}\n","import { differenceWith, intersectionWith, isEqual, uniqWith } from \"lodash-es\";\nimport { ActionMeta, GroupBase, OnChangeValue, Options } from \"react-select\";\nimport { OnChange } from \"../components/ui/GroupedMultiSelect\";\nimport { DropdownOption } from \"../components/ui/GroupedMultiSelectTypes\";\n\nexport type GroupedOptionsType<TOption> = ReadonlyArray<GroupBase<TOption>>;\n\nexport type InternalDropdownOption<TData> =\n | InternalChildOption<TData>\n | InternalParentDropdownOption<TData>;\n\ninterface InternalChildOption<TData> {\n data: TData;\n label: string;\n value: string;\n}\n\ninterface InternalParentDropdownOption<TData> {\n data: TData;\n label: string;\n value: string;\n internalOptions: Options<DropdownOption<TData>>;\n}\n\nconst removeGroupedOptionsType = <TData>(\n removedValue: InternalParentDropdownOption<TData>,\n selectedInternalOptions: Options<InternalDropdownOption<TData>>,\n): Options<InternalDropdownOption<TData>> =>\n differenceWith(\n selectedInternalOptions,\n [...removedValue.internalOptions, removedValue],\n isEqual,\n ).map(convertInternalOptionToDropdownOption);\n\nconst removeInternalOptions = <TData>(\n selectedInternalOption: InternalDropdownOption<TData>,\n): boolean => !(\"internalOptions\" in selectedInternalOption);\n\nconst removeOptionHeaders = <TData>(\n selectedInternalOptions: Options<InternalDropdownOption<TData>>,\n): Options<InternalDropdownOption<TData>> =>\n selectedInternalOptions\n .filter(removeInternalOptions)\n .map(convertInternalOptionToDropdownOption);\n\nexport const createOnChange =\n <TData>(onChange: OnChange<TData>) =>\n (\n incomingSelectedInternalOptions: OnChangeValue<\n InternalDropdownOption<TData>,\n true\n >,\n meta: ActionMeta<InternalDropdownOption<TData>>,\n ) => {\n const selectedInternalOptions = incomingSelectedInternalOptions ?? [];\n switch (meta.action) {\n case \"select-option\":\n if (meta.option && \"internalOptions\" in meta.option) {\n const selectedOptions: OnChangeValue<\n InternalDropdownOption<TData>,\n true\n > = uniqWith(\n selectedInternalOptions.reduce<Options<DropdownOption<TData>>>(\n (previousValue, currentValue) => {\n if (\"internalOptions\" in currentValue) {\n return [...previousValue, ...currentValue.internalOptions];\n } else {\n return [\n ...previousValue,\n convertInternalOptionToDropdownOption(currentValue),\n ];\n }\n },\n [],\n ),\n isEqual,\n );\n\n onChange(selectedOptions, meta);\n } else {\n onChange(removeOptionHeaders(selectedInternalOptions), meta);\n }\n break;\n case \"deselect-option\":\n if (meta.option && \"internalOptions\" in meta.option) {\n onChange(\n removeGroupedOptionsType(\n meta.option,\n removeOptionHeaders(selectedInternalOptions),\n ),\n meta,\n );\n } else {\n onChange(removeOptionHeaders(selectedInternalOptions), meta);\n }\n break;\n case \"remove-value\":\n case \"pop-value\":\n if (meta.removedValue && \"internalOptions\" in meta.removedValue) {\n onChange(\n removeGroupedOptionsType(\n meta.removedValue,\n removeOptionHeaders(selectedInternalOptions),\n ),\n meta,\n );\n } else {\n onChange(removeOptionHeaders(selectedInternalOptions), meta);\n }\n break;\n case \"clear\":\n onChange(\n selectedInternalOptions.map(convertInternalOptionToDropdownOption),\n meta,\n );\n break;\n case \"create-option\":\n onChange(\n selectedInternalOptions.map(convertInternalOptionToDropdownOption),\n meta,\n );\n break;\n default:\n break;\n }\n };\n\nexport const convertGroupedDropdownOptionsToInternalOptions = <TData>(\n options: GroupedOptionsType<DropdownOption<TData>>,\n): InternalDropdownOption<TData>[] => {\n return options.reduce<InternalDropdownOption<TData>[]>(\n (previousValue, currentValue) => {\n return [\n ...previousValue,\n convertGroupedDropdownOptionToInternalOption(currentValue),\n ...currentValue.options.map(convertDropdownOptionToInternalOption),\n ];\n },\n [],\n );\n};\n\nexport const convertValueToInternalValue = <TData>(\n options: GroupedOptionsType<DropdownOption<TData>>,\n values: Options<DropdownOption<TData>> | undefined,\n): InternalDropdownOption<TData>[] => {\n if (!values) {\n return [];\n }\n const selectedOptions: InternalDropdownOption<TData>[] = [];\n options.forEach((option) => {\n if (allOptionsExists(option.options, values)) {\n selectedOptions.push(\n convertGroupedDropdownOptionToInternalOption(option),\n );\n }\n selectedOptions.push(\n ...intersectionWith(option.options, values, isEqual).map((option) =>\n convertDropdownOptionToInternalOption(option),\n ),\n );\n });\n return selectedOptions;\n};\n\nexport const allOptionsExists = <TData>(\n options: Options<DropdownOption<TData>>,\n selectedValues: Options<DropdownOption<TData>> | undefined,\n): boolean => {\n if (!selectedValues) {\n return false;\n }\n\n return (\n intersectionWith(options, selectedValues, isEqual).length === options.length\n );\n};\n\nexport const convertDropdownOptionToInternalOption = <TData>(\n option: DropdownOption<TData>,\n): InternalDropdownOption<TData> => ({\n data: option.data,\n label: option.label,\n value: option.value,\n});\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nexport const convertGroupedDropdownOptionToInternalOption = <TData>(\n option: GroupBase<DropdownOption<TData>>,\n): InternalDropdownOption<TData> => ({\n data: option.label as any,\n label: option.label as any,\n value: option.label as any,\n internalOptions: option.options,\n});\n\nexport const convertInternalOptionToDropdownOption = <TData>(\n option: InternalDropdownOption<TData>,\n): DropdownOption<TData> => ({\n data: option.data,\n label: option.label,\n value: option.value,\n});\n","import { Row, Space, Text, TextSize } from \"@stenajs-webui/core\";\nimport { Icon, stenaCheck } from \"@stenajs-webui/elements\";\nimport * as React from \"react\";\nimport { ReactNode } from \"react\";\nimport {\n ActionMeta,\n components,\n GroupBase,\n MultiValueProps,\n OnChangeValue,\n OptionProps,\n Options,\n} from \"react-select\";\nimport { defaultSelectTheme, SelectTheme } from \"../../SelectTheme\";\nimport {\n convertGroupedDropdownOptionsToInternalOptions,\n convertValueToInternalValue,\n createOnChange,\n GroupedOptionsType,\n InternalDropdownOption,\n} from \"../../util/multiDropdownUtils\";\nimport { DropdownOption } from \"./GroupedMultiSelectTypes\";\nimport {\n MultiSelect,\n MultiSelectComponentsConfig,\n MultiSelectProps,\n} from \"./MultiSelect\";\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nexport type OnChange<TData> = (\n value: OnChangeValue<DropdownOption<TData>, true>,\n action: ActionMeta<any>,\n) => void;\n\nexport interface GroupedMultiSelectProps<TData>\n extends Omit<\n MultiSelectProps<InternalDropdownOption<TData>>,\n \"options\" | \"onChange\" | \"value\" | \"components\"\n > {\n /**\n * Same as Select prop `component` but without MultiValue and Option since they can not be modified\n */\n components?: Omit<\n MultiSelectComponentsConfig<InternalDropdownOption<TData>>,\n \"MultiValue\" | \"Option\"\n >;\n /**\n * Same as Select prop `options` but only with GroupOptionsType\n */\n options?: GroupedOptionsType<DropdownOption<TData>>;\n /**\n * Same as Select prop `onChange` but only with GroupOptionsType\n */\n onChange?: OnChange<TData>;\n /**\n * Same as Select prop `value` but only with GroupOptionsType\n */\n value?: Options<DropdownOption<TData>> | undefined;\n}\n\nconst resolveIconColor = (\n theme: SelectTheme,\n isFocused: boolean,\n): string | undefined =>\n isFocused\n ? theme.menu.selectedItemHoverIconColor\n : theme.menu.selectedItemIconColor;\n\nfunction formatInnerOptionLabel<TData>(\n props: OptionProps<\n InternalDropdownOption<TData>,\n true,\n GroupBase<InternalDropdownOption<TData>>\n >,\n) {\n const { formatGroupLabel, formatOptionLabel } = props.selectProps;\n\n if (\"internalOptions\" in props.data) {\n return formatGroupLabel\n ? formatGroupLabel({\n label: props.data.label,\n options: props.data.internalOptions,\n })\n : props.label;\n }\n\n return formatOptionLabel\n ? formatOptionLabel(props.data, {\n context: \"menu\",\n inputValue: props.selectProps.inputValue ?? \"\",\n selectValue: props.getValue(),\n })\n : props.label;\n}\n\nexport function GroupedMultiSelect<TData>({\n onChange,\n options,\n value,\n variant = \"standard\",\n /* eslint-disable @typescript-eslint/no-unused-vars */\n formatGroupLabel,\n formatOptionLabel,\n ...selectProps\n}: GroupedMultiSelectProps<TData>): React.ReactElement<\n GroupedMultiSelectProps<TData>\n> {\n const Option = (\n props: OptionProps<\n InternalDropdownOption<TData>,\n true,\n GroupBase<InternalDropdownOption<TData>>\n >,\n ) => {\n const label = formatInnerOptionLabel(props);\n const isGroupOption = \"internalOptions\" in props.data;\n\n return (\n <components.Option {...props}>\n <Row>\n {!isGroupOption && <Space />}\n <InnerOption\n theme={defaultSelectTheme}\n size={!isGroupOption ? \"small\" : undefined}\n label={label}\n selected={props.isSelected}\n focused={props.isFocused}\n />\n </Row>\n </components.Option>\n );\n };\n\n const MultiValue = (\n props: MultiValueProps<\n InternalDropdownOption<TData>,\n true,\n GroupBase<InternalDropdownOption<TData>>\n >,\n ) => {\n return !(\"internalOptions\" in props.data) ? (\n <components.MultiValue {...props} />\n ) : null;\n };\n\n const internalValue = options\n ? convertValueToInternalValue(options, value)\n : undefined;\n const internalOptions = options\n ? convertGroupedDropdownOptionsToInternalOptions(options)\n : undefined;\n\n return (\n <MultiSelect<InternalDropdownOption<TData>>\n {...selectProps}\n onChange={onChange ? createOnChange<TData>(onChange) : undefined}\n hideSelectedOptions={false}\n components={{\n ...selectProps.components,\n MultiValue,\n Option,\n }}\n isMulti={true}\n options={internalOptions}\n value={internalValue}\n variant={variant}\n />\n );\n}\n\ninterface InnerOptionProps {\n size?: TextSize;\n selected: boolean;\n theme: SelectTheme;\n label: ReactNode;\n focused: boolean;\n}\n\nconst InnerOption: React.FC<InnerOptionProps> = ({\n focused,\n label,\n selected,\n size,\n theme,\n}) => (\n <Row alignItems={\"center\"} justifyContent={\"space-between\"} flexGrow={1}>\n <Text tabIndex={-1} size={size} color={\"currentColor\"}>\n {label}\n </Text>\n {selected && (\n <Icon\n color={resolveIconColor(theme, focused)}\n icon={stenaCheck}\n size={12}\n />\n )}\n </Row>\n);\n","import { CloseButton } from \"@stenajs-webui/elements\";\nimport * as React from \"react\";\nimport { useMemo } from \"react\";\nimport { ClearIndicatorProps, mergeStyles } from \"react-select\";\nimport CreatableComponent, { CreatableProps } from \"react-select/creatable\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\n\nexport interface CreatableSelectProps<T = { label: string; value: string }>\n extends CreatableProps<T, false, GroupBase<T>> {\n variant?: SelectVariant;\n isMulti?: false;\n ariaLabelClear?: string;\n}\n\nexport function CreatableSelect<T>({\n variant = \"standard\",\n styles,\n components,\n ariaLabelClear = \"Clear\",\n ...selectProps\n}: CreatableSelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, false>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n const ClearIndicator = (\n props: ClearIndicatorProps<T, false, GroupBase<T>>,\n ) => <CloseButton aria-label={ariaLabelClear} onClick={props.clearValue} />;\n\n return (\n <CreatableComponent\n styles={selectStyles}\n components={{ ...components, ClearIndicator }}\n {...selectProps}\n isMulti={false}\n />\n );\n}\n","import { Column, Row, Space, Spacing } from \"@stenajs-webui/core\";\nimport { Chip, FlatButton } from \"@stenajs-webui/elements\";\nimport { ValueAndOnValueChangeProps } from \"@stenajs-webui/forms\";\nimport * as React from \"react\";\nimport { PropsWithChildren } from \"react\";\nimport { MultiSelectOption } from \"../MultiSelect\";\n\nexport interface ChipRowItem extends MultiSelectOption {}\n\nexport interface ChipRowProps<TValue>\n extends ValueAndOnValueChangeProps<TValue> {\n noneSelectedLabel?: string;\n}\n\nexport function ChipRow<TValue extends ChipRowItem>({\n value,\n onValueChange,\n noneSelectedLabel = \"None\",\n children,\n}: PropsWithChildren<ChipRowProps<Array<TValue>>>) {\n return (\n <Column flex={1}>\n <Row flexWrap={\"wrap\"}>\n {value?.map((v) => (\n <Row key={v.value}>\n <Spacing num={0.5}>\n <Chip\n label={v.label}\n onClickRemove={() =>\n onValueChange?.(\n value?.filter((f) => f.value !== v.value) ?? [],\n )\n }\n />\n </Spacing>\n <Space />\n </Row>\n ))}\n {value?.length ? (\n <Spacing num={0.5}>\n <FlatButton\n size={\"small\"}\n label={\"Clear\"}\n onClick={() => onValueChange?.([])}\n />\n </Spacing>\n ) : (\n <Spacing num={0.5}>\n <Chip variant={\"secondary\"} label={noneSelectedLabel} />\n </Spacing>\n )}\n </Row>\n <Space num={0.5} />\n {children}\n </Column>\n );\n}\n","import { ValueAndOnValueChangeProps } from \"@stenajs-webui/forms\";\nimport * as React from \"react\";\nimport {\n MultiSelect,\n MultiSelectOption,\n MultiSelectProps,\n} from \"../MultiSelect\";\nimport { ChipRow, ChipRowItem } from \"./ChipRow\";\n\nexport interface ChipMultiSelectOption extends ChipRowItem {}\n\n/**\n * @deprecated renamed to ChipMultiSelectOption\n */\nexport type ChipMultiSelectValue = ChipMultiSelectOption;\n\nexport interface ChipMultiSelectProps<\n TOption extends MultiSelectOption = MultiSelectOption,\n> extends Omit<MultiSelectProps<TOption>, \"value\" | \"onChange\" | \"isLoading\">,\n ValueAndOnValueChangeProps<Array<TOption>> {\n loading?: boolean;\n inputValue?: string;\n onInputChange?: (inputValue: string) => void;\n noneSelectedLabel?: string;\n}\n\nfunction _ChipMultiSelect<TOption extends ChipMultiSelectOption>({\n value,\n onValueChange,\n placeholder = \"Type to search\",\n loading,\n inputValue,\n onInputChange,\n noneSelectedLabel = \"None\",\n ...selectProps\n}: ChipMultiSelectProps<TOption>) {\n return (\n <ChipRow\n noneSelectedLabel={noneSelectedLabel}\n onValueChange={onValueChange}\n value={value}\n >\n <MultiSelect<TOption>\n {...selectProps}\n isClearable={false}\n value={value}\n onChange={\n onValueChange ? (value) => onValueChange([...value]) : undefined\n }\n backspaceRemovesValue={false}\n hideSelectedOptions\n controlShouldRenderValue={false}\n placeholder={placeholder}\n isLoading={loading}\n inputValue={inputValue}\n onInputChange={onInputChange}\n />\n </ChipRow>\n );\n}\n\nexport const ChipMultiSelect = React.memo(\n _ChipMultiSelect,\n) as typeof _ChipMultiSelect;\n","import * as React from \"react\";\nimport { ValueAndOnValueChangeProps } from \"@stenajs-webui/forms\";\nimport {\n GroupedMultiSelect,\n GroupedMultiSelectProps,\n} from \"../GroupedMultiSelect\";\nimport { DropdownOption } from \"../GroupedMultiSelectTypes\";\nimport { ChipRow } from \"./ChipRow\";\n\nexport interface GroupedChipMultiSelectValue<TData>\n extends DropdownOption<TData> {}\n\nexport interface GroupedChipMultiSelectProps<TData>\n extends Omit<GroupedMultiSelectProps<TData>, \"onChange\" | \"value\">,\n ValueAndOnValueChangeProps<Array<DropdownOption<TData>>> {\n loading?: boolean;\n inputValue?: string;\n onInputChange?: (inputValue: string) => void;\n noneSelectedLabel?: string;\n}\n\nfunction _GroupedChipMultiSelect<TData>({\n value,\n onValueChange,\n placeholder = \"Type to search\",\n loading,\n inputValue,\n onInputChange,\n noneSelectedLabel = \"None\",\n ...selectProps\n}: GroupedChipMultiSelectProps<TData>) {\n return (\n <ChipRow\n noneSelectedLabel={noneSelectedLabel}\n onValueChange={onValueChange}\n value={value}\n >\n <GroupedMultiSelect<TData>\n {...selectProps}\n isClearable={false}\n value={value}\n onChange={\n onValueChange ? (value) => onValueChange([...value]) : undefined\n }\n backspaceRemovesValue={false}\n hideSelectedOptions\n controlShouldRenderValue={false}\n placeholder={placeholder}\n isLoading={loading}\n inputValue={inputValue}\n onInputChange={onInputChange}\n />\n </ChipRow>\n );\n}\n\nexport const GroupedChipMultiSelect = React.memo(\n _GroupedChipMultiSelect,\n) as typeof _GroupedChipMultiSelect;\n"],"names":["defaultSelectTheme","cssColor","resolveOptionBackgroundColor","colors","isDisabled","isSelected","isFocused","resolveOptionColor","resolveInputBackgroundColor","variant","resolveInputBorderColor","isHovered","createStylesFromTheme","menu","menuPortal","input","multiSelect","clearButtonColor","arrowColor","groupHeading","loadingIndicator","base","menuIsOpen","styles","createStylesFromVariant","AsyncMultiSelect","selectProps","selectStyles","useMemo","sourceStyles","mergeStyles","AsyncComponent","AsyncSelect","ClearIndicator","clearValue","ev","jsx","TextInputButton","stenaTimes","MultiValue","removeProps","data","Chip","MultiSelect","components","SelectComponent","OverflowingMultiSelect","props","FirstValueOnlyValueContainer","memo","prevOptions","restChildren","options","getOptionsToRender","jsxs","optionElements","children","innerProps","className","spreadProps","createElement","Select","CloseButton","removeGroupedOptionsType","removedValue","selectedInternalOptions","differenceWith","isEqual","convertInternalOptionToDropdownOption","removeInternalOptions","selectedInternalOption","removeOptionHeaders","createOnChange","onChange","incomingSelectedInternalOptions","meta","selectedOptions","uniqWith","previousValue","currentValue","convertGroupedDropdownOptionsToInternalOptions","convertGroupedDropdownOptionToInternalOption","convertDropdownOptionToInternalOption","convertValueToInternalValue","values","option","allOptionsExists","intersectionWith","selectedValues","resolveIconColor","theme","formatInnerOptionLabel","formatGroupLabel","formatOptionLabel","GroupedMultiSelect","value","Option","label","isGroupOption","Row","Space","InnerOption","internalValue","internalOptions","focused","selected","size","Text","Icon","stenaCheck","CreatableSelect","ariaLabelClear","CreatableComponent","ChipRow","onValueChange","noneSelectedLabel","Column","v","Spacing","f","FlatButton","_ChipMultiSelect","placeholder","loading","inputValue","onInputChange","ChipMultiSelect","React","_GroupedChipMultiSelect","GroupedChipMultiSelect"],"mappings":"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"}
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("react/jsx-runtime"),x=require("react"),f=require("react-select"),j=require("react-select/async"),u=require("@stenajs-webui/theme"),m=require("@stenajs-webui/elements"),h=require("@stenajs-webui/core"),p=require("lodash-es"),H=require("react-select/creatable");function V(e){const r=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const o in e)if(o!=="default"){const t=Object.getOwnPropertyDescriptor(e,o);Object.defineProperty(r,o,t.get?t:{enumerable:!0,get:()=>e[o]})}}return r.default=e,Object.freeze(r)}const M=V(x),y={arrowColor:{disabled:u.cssColor("--silver-light"),focused:{hover:u.cssColor("--lhds-color-blue-600"),standard:u.cssColor("--lhds-color-blue-600")},closed:{hover:u.cssColor("--lhds-color-blue-600"),standard:u.cssColor("--lhds-color-blue-600")}},clearButtonColor:{hover:u.cssColor("--lhds-color-red-600"),standard:u.cssColor("--lhds-color-red-500")},input:{backgroundColor:"var(--swui-field-bg-enabled)",border:"1px solid var(--swui-select-border-color)",borderColor:"var(--swui-field-border-color)",borderColorFocused:"var(--swui-field-border-color-hover)",disabledBackgroundColor:"var(--swui-field-bg-disabled)",disabledBorderColor:"var(--swui-field-bg-disabled)",warningBackgroundColor:"var(--swui-state-alert-light-color)",warningBorderColor:"var(--swui-state-alert-light-color)",errorBackgroundColor:"var(--swui-state-error-light-color)",errorBorderColor:"var(--swui-state-error-light-color)",successBackgroundColor:"var(--swui-state-success-light-color)",successBorderColor:"var(--swui-state-success-light-color)",boxShadowFocused:"none",fontFamily:"var(--swui-font-primary)",fontSize:"var(--swui-font-size-inputs)",minHeight:"24px",placeholderColor:"var(--swui-field-text-color)",textColor:"var(--swui-field-text-color)",borderRadius:"var(--swui-field-border-radius)"},loadingIndicator:{textColor:"var(--swui-field-text-color)"},groupHeading:{fontSize:"var(--swui-font-size-small)",lineHeight:"var(--swui-line-height-smaller)",fontWeight:"var(--swui-font-weight-text-bold)",color:u.cssColor("--lhds-color-ui-600"),letterSpacing:"0.1rem"},menu:{activeBackgroundColor:u.cssColor("--lhds-color-blue-100"),activeTextColor:"var(--swui-field-text-color)",selectedItemActiveBackgroundColor:u.cssColor("--lhds-color-blue-500"),selectedItemActiveTextColor:u.cssColor("--lhds-color-blue-50"),disabledTextColor:"var(--swui-field-text-color-disabled)",disabledBackgroundColor:"var(--swui-field-bg-disabled)",textColor:"var(--swui-field-text-color)",backgroundColor:"var(--swui-field-bg-enabled)",hoverTextColor:"var(--swui-field-text-color)",hoverBackgroundColor:u.cssColor("--lhds-color-blue-200"),selectedItemTextColor:u.cssColor("--lhds-color-blue-500"),selectedItemIconColor:u.cssColor("--lhds-color-blue-500"),selectedItemHoverTextColor:"var(--swui-field-text-color)",selectedItemHoverIconColor:"var(--swui-field-text-color)",selectedItemBackgroundColor:u.cssColor("--lhds-color-blue-50"),selectedItemHoverBackgroundColor:u.cssColor("--lhds-color-blue-50"),zIndex:1,width:"auto",minWidth:"100%",whiteSpace:"nowrap"},menuPortal:{zIndex:1},multiSelect:{backgroundColor:"var(--swui-primary-action-color)",textColor:u.cssColor("--lhds-color-blue-50"),removeButtonBackgroundColor:"transparent",removeButtonTextColor:"var(--swui-white)",removeButtonHoverBackgroundColor:"var(--swui-primary-action-color-hover)",removeButtonHoverTextColor:"var(--swui-white)"}},G=(e,r,o,t)=>r?e.disabledBackgroundColor:o&&t?e.selectedItemHoverBackgroundColor:o?e.selectedItemBackgroundColor:t?e.hoverBackgroundColor:void 0,L=(e,r,o,t)=>r?e.disabledTextColor:o&&t?e.selectedItemHoverTextColor:o?e.selectedItemTextColor:t?e.hoverTextColor:void 0,W=(e,r,o,t)=>r?e.disabledBackgroundColor:o?e.backgroundColor:t==="warning"?e.warningBackgroundColor:t==="success"?e.successBackgroundColor:t==="error"?e.errorBackgroundColor:e.backgroundColor,I=(e,r,o,t,i)=>r?e.disabledBorderColor:o?e.borderColorFocused:i==="warning"?e.warningBorderColor:i==="success"?e.successBorderColor:i==="error"?e.errorBorderColor:t?e.borderColorFocused:e.borderColor,T=({menu:e,menuPortal:r,input:o,multiSelect:t,clearButtonColor:i,arrowColor:c,groupHeading:s,loadingIndicator:C},b)=>({option:(l,{isDisabled:a,isFocused:d,isSelected:g})=>({...l,fontFamily:o.fontFamily,fontSize:o.fontSize,backgroundColor:G(e,a,g,d),color:L(e,a,g,d),cursor:a?"not-allowed":"default",whiteSpace:e.whiteSpace||l.whiteSpace,":active":{backgroundColor:a?void 0:g?e.selectedItemActiveBackgroundColor:e.activeBackgroundColor,color:a?void 0:g?e.selectedItemActiveTextColor:e.activeTextColor}}),control:(l,{isFocused:a,isDisabled:d,menuIsOpen:g})=>({...l,fontFamily:o.fontFamily,fontSize:o.fontSize,minHeight:"var(--swui-field-height)",backgroundColor:W(o,d,a,b),borderRadius:o.borderRadius,border:o.border,"--swui-select-border-color":I(o,d,a||g,!1,b),outline:a?"var(--swui-focus-outline)":void 0,outlineOffset:a?"-1px":void 0,transition:"none",boxShadow:a?o.boxShadowFocused:void 0,"&:hover":{"--swui-select-border-color":I(o,!1,a||g,!0,b)}}),singleValue:l=>({...l,fontFamily:o.fontFamily,fontSize:o.fontSize,color:o.textColor}),noOptionsMessage:l=>({...l,fontFamily:o.fontFamily,fontSize:o.fontSize}),input:l=>({...l,padding:0,margin:0,minHeight:o.minHeight,fontFamily:o.fontFamily,fontSize:o.fontSize,color:o.textColor}),groupHeading:l=>({...l,fontFamily:o.fontFamily,fontSize:s.fontSize,lineHeight:s.lineHeight,fontWeight:s.fontWeight,color:s.color,letterSpacing:s.letterSpacing}),multiValueLabel:l=>({...l,backgroundColor:t.backgroundColor,color:t.textColor,fontFamily:o.fontFamily,fontSize:s.fontSize}),indicatorSeparator:l=>({...l,display:"none"}),clearIndicator:l=>({...l,padding:"5px",color:i.standard,"&:hover":{color:i.hover},cursor:"pointer"}),placeholder:l=>({...l,fontFamily:o.fontFamily,fontSize:o.fontSize,color:o.placeholderColor}),container:l=>({...l}),valueContainer:l=>({...l,padding:"var(--swui-metrics-space-half) var(--swui-metrics-space)",gap:"var(--swui-metrics-space-half)"}),dropdownIndicator:(l,{isFocused:a,isDisabled:d})=>({...l,padding:"5px",color:d?c.disabled:a?c.focused.standard:c.closed.standard,"&:hover":{color:d?c.disabled:a?c.focused.hover:c.closed.hover},svg:{width:14,height:14}}),menu:l=>({...l,backgroundColor:e.backgroundColor,color:e.textColor,minWidth:e.minWidth||l.minWidth,zIndex:e.zIndex,width:e.width||l.width,border:o.border,borderColor:o.borderColorFocused}),menuPortal:l=>({...l,zIndex:r.zIndex}),multiValueRemove:l=>({...l,backgroundColor:t.removeButtonBackgroundColor,":hover":{color:t.removeButtonHoverTextColor,backgroundColor:t.removeButtonHoverBackgroundColor},color:t.removeButtonTextColor,borderRadius:"50%",width:16,height:16,padding:0,margin:3,marginTop:4,display:"flex",justifyContent:"center",alignItems:"center",cursor:"pointer"}),multiValue:l=>({...l,backgroundColor:t.backgroundColor,color:t.textColor,fontFamily:o.fontFamily,fontSize:s.fontSize,alignItems:"center",margin:0,borderRadius:"var(--swui-border-radius-small)",overflow:"hidden"}),loadingMessage:l=>({...l,color:C.textColor,fontFamily:o.fontFamily,fontSize:o.fontSize})}),v=e=>T(y,e);function A({variant:e="standard",styles:r,...o}){const t=x.useMemo(()=>{const i=v(e);return r?f.mergeStyles(i,r):i},[e,r]);return n.jsx(j,{styles:t,...o,isMulti:!0})}function _({variant:e="standard",styles:r,...o}){const t=x.useMemo(()=>{const i=v(e);return r?f.mergeStyles(i,r):i},[e,r]);return n.jsx(j,{styles:t,...o,isMulti:!1})}const P=function({clearValue:e}){return n.jsx("div",{onMouseDown:r=>r.stopPropagation(),children:n.jsx(m.TextInputButton,{"aria-label":"Clear",onClick:e,icon:m.stenaTimes,variant:"error"})})},E=function({removeProps:e,data:r}){return n.jsx("div",{onMouseDown:o=>o.stopPropagation(),children:n.jsx(m.Chip,{onClickRemove:o=>{var t;return(t=e.onClick)==null?void 0:t.call(e,o)},label:r.label})})};function k({variant:e="standard",styles:r,components:o,...t}){const i=x.useMemo(()=>{const c=v(e);return r?f.mergeStyles(c,r):c},[e,r]);return n.jsx(f,{styles:i,components:{...o,ClearIndicator:P,MultiValue:E},...t,isMulti:!0})}function N(e){return n.jsx(k,{hideSelectedOptions:!1,...e,components:{...e.components,ValueContainer:D}})}const D=x.memo(e=>{const[r,...o]=e.children,t=U(r,e);return n.jsxs(f.components.ValueContainer,{...e,children:[t,o]})}),U=(e,{children:r,innerProps:o,className:t,...i})=>e?e.length>1?[e[0],x.createElement(f.components.MultiValue,{...i,key:"DUMMY_VALUE_FOR_PLUS_X",innerProps:{},data:null,isFocused:!1,removeProps:{},index:1,components:{Container:f.components.MultiValueContainer,Label:f.components.MultiValueLabel,Remove:()=>n.jsx("div",{style:{height:16,margin:3,marginTop:4}})}},"+"+(e.length-1))]:e:null;function X({variant:e="standard",styles:r,components:o,...t}){const i=x.useMemo(()=>{const s=v(e);return r?f.mergeStyles(s,r):s},[e,r]),c=s=>n.jsx(m.CloseButton,{"aria-label":"Clear",onClick:s.clearValue});return n.jsx(f,{styles:i,components:{...o,ClearIndicator:c},...t,isMulti:!1})}const B=(e,r)=>p.differenceWith(r,[...e.internalOptions,e],p.isEqual).map(w),Y=e=>!("internalOptions"in e),S=e=>e.filter(Y).map(w),J=e=>(r,o)=>{const t=r??[];switch(o.action){case"select-option":if(o.option&&"internalOptions"in o.option){const i=p.uniqWith(t.reduce((c,s)=>"internalOptions"in s?[...c,...s.internalOptions]:[...c,w(s)],[]),p.isEqual);e(i,o)}else e(S(t),o);break;case"deselect-option":o.option&&"internalOptions"in o.option?e(B(o.option,S(t)),o):e(S(t),o);break;case"remove-value":case"pop-value":o.removedValue&&"internalOptions"in o.removedValue?e(B(o.removedValue,S(t)),o):e(S(t),o);break;case"clear":e(t.map(w),o);break;case"create-option":e(t.map(w),o);break}},K=e=>e.reduce((r,o)=>[...r,F(o),...o.options.map(z)],[]),Q=(e,r)=>{if(!r)return[];const o=[];return e.forEach(t=>{Z(t.options,r)&&o.push(F(t)),o.push(...p.intersectionWith(t.options,r,p.isEqual).map(i=>z(i)))}),o},Z=(e,r)=>r?p.intersectionWith(e,r,p.isEqual).length===e.length:!1,z=e=>({data:e.data,label:e.label,value:e.value}),F=e=>({data:e.label,label:e.label,value:e.label,internalOptions:e.options}),w=e=>({data:e.data,label:e.label,value:e.value}),$=(e,r)=>r?e.menu.selectedItemHoverIconColor:e.menu.selectedItemIconColor;function ee(e){const{formatGroupLabel:r,formatOptionLabel:o}=e.selectProps;return"internalOptions"in e.data?r?r({label:e.data.label,options:e.data.internalOptions}):e.label:o?o(e.data,{context:"menu",inputValue:e.selectProps.inputValue??"",selectValue:e.getValue()}):e.label}function R({onChange:e,options:r,value:o,variant:t="standard",formatGroupLabel:i,formatOptionLabel:c,...s}){const C=d=>{const g=ee(d),O="internalOptions"in d.data;return n.jsx(f.components.Option,{...d,children:n.jsxs(h.Row,{children:[!O&&n.jsx(h.Space,{}),n.jsx(oe,{theme:y,size:O?void 0:"small",label:g,selected:d.isSelected,focused:d.isFocused})]})})},b=d=>"internalOptions"in d.data?null:n.jsx(f.components.MultiValue,{...d}),l=r?Q(r,o):void 0,a=r?K(r):void 0;return n.jsx(k,{...s,onChange:e?J(e):void 0,hideSelectedOptions:!1,components:{...s.components,MultiValue:b,Option:C},isMulti:!0,options:a,value:l,variant:t})}const oe=({focused:e,label:r,selected:o,size:t,theme:i})=>n.jsxs(h.Row,{alignItems:"center",justifyContent:"space-between",flexGrow:1,children:[n.jsx(h.Text,{tabIndex:-1,size:t,color:"currentColor",children:r}),o&&n.jsx(m.Icon,{color:$(i,e),icon:m.stenaCheck,size:12})]});function re({variant:e="standard",styles:r,components:o,ariaLabelClear:t="Clear",...i}){const c=x.useMemo(()=>{const C=v(e);return r?f.mergeStyles(C,r):C},[e,r]),s=C=>n.jsx(m.CloseButton,{"aria-label":t,onClick:C.clearValue});return n.jsx(H,{styles:c,components:{...o,ClearIndicator:s},...i,isMulti:!1})}function q({value:e,onValueChange:r,noneSelectedLabel:o="None",children:t}){return n.jsxs(h.Column,{flex:1,children:[n.jsxs(h.Row,{flexWrap:"wrap",children:[e==null?void 0:e.map(i=>n.jsxs(h.Row,{children:[n.jsx(h.Spacing,{num:.5,children:n.jsx(m.Chip,{label:i.label,onClickRemove:()=>r==null?void 0:r((e==null?void 0:e.filter(c=>c.value!==i.value))??[])})}),n.jsx(h.Space,{})]},i.value)),e!=null&&e.length?n.jsx(h.Spacing,{num:.5,children:n.jsx(m.FlatButton,{size:"small",label:"Clear",onClick:()=>r==null?void 0:r([])})}):n.jsx(h.Spacing,{num:.5,children:n.jsx(m.Chip,{variant:"secondary",label:o})})]}),n.jsx(h.Space,{num:.5}),t]})}function te({value:e,onValueChange:r,placeholder:o="Type to search",loading:t,inputValue:i,onInputChange:c,noneSelectedLabel:s="None",...C}){return n.jsx(q,{noneSelectedLabel:s,onValueChange:r,value:e,children:n.jsx(k,{...C,isClearable:!1,value:e,onChange:r?b=>r([...b]):void 0,backspaceRemovesValue:!1,hideSelectedOptions:!0,controlShouldRenderValue:!1,placeholder:o,isLoading:t,inputValue:i,onInputChange:c})})}const le=M.memo(te);function ne({value:e,onValueChange:r,placeholder:o="Type to search",loading:t,inputValue:i,onInputChange:c,noneSelectedLabel:s="None",...C}){return n.jsx(q,{noneSelectedLabel:s,onValueChange:r,value:e,children:n.jsx(R,{...C,isClearable:!1,value:e,onChange:r?b=>r([...b]):void 0,backspaceRemovesValue:!1,hideSelectedOptions:!0,controlShouldRenderValue:!1,placeholder:o,isLoading:t,inputValue:i,onInputChange:c})})}const ie=M.memo(ne);exports.AsyncMultiSelect=A;exports.AsyncSelect=_;exports.ChipMultiSelect=le;exports.CreatableSelect=re;exports.GroupedChipMultiSelect=ie;exports.GroupedMultiSelect=R;exports.MultiSelect=k;exports.OverflowingMultiSelect=N;exports.Select=X;exports.createStylesFromTheme=T;exports.createStylesFromVariant=v;exports.defaultSelectTheme=y;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("react/jsx-runtime"),p=require("react"),f=require("react-select"),j=require("react-select/async"),u=require("@stenajs-webui/theme"),m=require("@stenajs-webui/elements"),h=require("@stenajs-webui/core"),g=require("lodash-es"),q=require("react-select/creatable");function H(e){const r=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const o in e)if(o!=="default"){const t=Object.getOwnPropertyDescriptor(e,o);Object.defineProperty(r,o,t.get?t:{enumerable:!0,get:()=>e[o]})}}return r.default=e,Object.freeze(r)}const M=H(p),y={arrowColor:{disabled:u.cssColor("--silver-light"),focused:{hover:u.cssColor("--lhds-color-blue-600"),standard:u.cssColor("--lhds-color-blue-600")},closed:{hover:u.cssColor("--lhds-color-blue-600"),standard:u.cssColor("--lhds-color-blue-600")}},clearButtonColor:{hover:u.cssColor("--lhds-color-red-600"),standard:u.cssColor("--lhds-color-red-500")},input:{backgroundColor:"var(--swui-field-bg-enabled)",border:"1px solid var(--swui-select-border-color)",borderColor:"var(--swui-field-border-color)",borderColorFocused:"var(--swui-field-border-color-hover)",disabledBackgroundColor:"var(--swui-field-bg-disabled)",disabledBorderColor:"var(--swui-field-bg-disabled)",warningBackgroundColor:"var(--swui-state-alert-light-color)",warningBorderColor:"var(--swui-state-alert-light-color)",errorBackgroundColor:"var(--swui-state-error-light-color)",errorBorderColor:"var(--swui-state-error-light-color)",successBackgroundColor:"var(--swui-state-success-light-color)",successBorderColor:"var(--swui-state-success-light-color)",boxShadowFocused:"none",fontFamily:"var(--swui-font-primary)",fontSize:"var(--swui-font-size-inputs)",minHeight:"24px",placeholderColor:"var(--swui-field-text-color)",textColor:"var(--swui-field-text-color)",borderRadius:"var(--swui-field-border-radius)"},loadingIndicator:{textColor:"var(--swui-field-text-color)"},groupHeading:{fontSize:"var(--swui-font-size-small)",lineHeight:"var(--swui-line-height-smaller)",fontWeight:"var(--swui-font-weight-text-bold)",color:u.cssColor("--lhds-color-ui-600"),letterSpacing:"0.1rem"},menu:{activeBackgroundColor:u.cssColor("--lhds-color-blue-100"),activeTextColor:"var(--swui-field-text-color)",selectedItemActiveBackgroundColor:u.cssColor("--lhds-color-blue-500"),selectedItemActiveTextColor:u.cssColor("--lhds-color-blue-50"),disabledTextColor:"var(--swui-field-text-color-disabled)",disabledBackgroundColor:"var(--swui-field-bg-disabled)",textColor:"var(--swui-field-text-color)",backgroundColor:"var(--swui-field-bg-enabled)",hoverTextColor:"var(--swui-field-text-color)",hoverBackgroundColor:u.cssColor("--lhds-color-blue-200"),selectedItemTextColor:u.cssColor("--lhds-color-blue-500"),selectedItemIconColor:u.cssColor("--lhds-color-blue-500"),selectedItemHoverTextColor:"var(--swui-field-text-color)",selectedItemHoverIconColor:"var(--swui-field-text-color)",selectedItemBackgroundColor:u.cssColor("--lhds-color-blue-50"),selectedItemHoverBackgroundColor:u.cssColor("--lhds-color-blue-50"),zIndex:1,width:"auto",minWidth:"100%",whiteSpace:"nowrap"},menuPortal:{zIndex:1},multiSelect:{backgroundColor:"var(--swui-primary-action-color)",textColor:u.cssColor("--lhds-color-blue-50"),removeButtonBackgroundColor:"transparent",removeButtonTextColor:"var(--swui-white)",removeButtonHoverBackgroundColor:"var(--swui-primary-action-color-hover)",removeButtonHoverTextColor:"var(--swui-white)"}},G=(e,r,o,t)=>r?e.disabledBackgroundColor:o&&t?e.selectedItemHoverBackgroundColor:o?e.selectedItemBackgroundColor:t?e.hoverBackgroundColor:void 0,L=(e,r,o,t)=>r?e.disabledTextColor:o&&t?e.selectedItemHoverTextColor:o?e.selectedItemTextColor:t?e.hoverTextColor:void 0,P=(e,r,o,t)=>r?e.disabledBackgroundColor:o?e.backgroundColor:t==="warning"?e.warningBackgroundColor:t==="success"?e.successBackgroundColor:t==="error"?e.errorBackgroundColor:e.backgroundColor,I=(e,r,o,t,i)=>r?e.disabledBorderColor:o?e.borderColorFocused:i==="warning"?e.warningBorderColor:i==="success"?e.successBorderColor:i==="error"?e.errorBorderColor:t?e.borderColorFocused:e.borderColor,T=({menu:e,menuPortal:r,input:o,multiSelect:t,clearButtonColor:i,arrowColor:a,groupHeading:s,loadingIndicator:C},v)=>({option:(l,{isDisabled:c,isFocused:d,isSelected:b})=>({...l,fontFamily:o.fontFamily,fontSize:o.fontSize,backgroundColor:G(e,c,b,d),color:L(e,c,b,d),cursor:c?"not-allowed":"default",whiteSpace:e.whiteSpace||l.whiteSpace,":active":{backgroundColor:c?void 0:b?e.selectedItemActiveBackgroundColor:e.activeBackgroundColor,color:c?void 0:b?e.selectedItemActiveTextColor:e.activeTextColor}}),control:(l,{isFocused:c,isDisabled:d,menuIsOpen:b})=>({...l,fontFamily:o.fontFamily,fontSize:o.fontSize,minHeight:"var(--swui-field-height)",backgroundColor:P(o,d,c,v),borderRadius:o.borderRadius,border:o.border,"--swui-select-border-color":I(o,d,c||b,!1,v),outline:c?"var(--swui-focus-outline)":void 0,outlineOffset:c?"-1px":void 0,transition:"none",boxShadow:c?o.boxShadowFocused:void 0,"&:hover":{"--swui-select-border-color":I(o,!1,c||b,!0,v)}}),singleValue:l=>({...l,fontFamily:o.fontFamily,fontSize:o.fontSize,color:o.textColor}),noOptionsMessage:l=>({...l,fontFamily:o.fontFamily,fontSize:o.fontSize}),input:l=>({...l,padding:0,margin:0,minHeight:o.minHeight,fontFamily:o.fontFamily,fontSize:o.fontSize,color:o.textColor}),groupHeading:l=>({...l,fontFamily:o.fontFamily,fontSize:s.fontSize,lineHeight:s.lineHeight,fontWeight:s.fontWeight,color:s.color,letterSpacing:s.letterSpacing}),multiValueLabel:l=>({...l,backgroundColor:t.backgroundColor,color:t.textColor,fontFamily:o.fontFamily,fontSize:s.fontSize}),indicatorSeparator:l=>({...l,display:"none"}),clearIndicator:l=>({...l,padding:"5px",color:i.standard,"&:hover":{color:i.hover},cursor:"pointer"}),placeholder:l=>({...l,fontFamily:o.fontFamily,fontSize:o.fontSize,color:o.placeholderColor}),container:l=>({...l}),valueContainer:l=>({...l,padding:"var(--swui-metrics-space-half) var(--swui-metrics-space)",gap:"var(--swui-metrics-space-half)"}),dropdownIndicator:(l,{isFocused:c,isDisabled:d})=>({...l,padding:"5px",color:d?a.disabled:c?a.focused.standard:a.closed.standard,"&:hover":{color:d?a.disabled:c?a.focused.hover:a.closed.hover},svg:{width:14,height:14}}),menu:l=>({...l,backgroundColor:e.backgroundColor,color:e.textColor,minWidth:e.minWidth||l.minWidth,zIndex:e.zIndex,width:e.width||l.width,border:o.border,borderColor:o.borderColorFocused}),menuPortal:l=>({...l,zIndex:r.zIndex}),multiValueRemove:l=>({...l,backgroundColor:t.removeButtonBackgroundColor,":hover":{color:t.removeButtonHoverTextColor,backgroundColor:t.removeButtonHoverBackgroundColor},color:t.removeButtonTextColor,borderRadius:"50%",width:16,height:16,padding:0,margin:3,marginTop:4,display:"flex",justifyContent:"center",alignItems:"center",cursor:"pointer"}),multiValue:l=>({...l,backgroundColor:t.backgroundColor,color:t.textColor,fontFamily:o.fontFamily,fontSize:s.fontSize,alignItems:"center",margin:0,borderRadius:"var(--swui-border-radius-small)",overflow:"hidden"}),loadingMessage:l=>({...l,color:C.textColor,fontFamily:o.fontFamily,fontSize:o.fontSize})}),x=e=>T(y,e);function W({variant:e="standard",styles:r,...o}){const t=p.useMemo(()=>{const i=x(e);return r?f.mergeStyles(i,r):i},[e,r]);return n.jsx(j,{styles:t,...o,isMulti:!0})}function A({variant:e="standard",styles:r,...o}){const t=p.useMemo(()=>{const i=x(e);return r?f.mergeStyles(i,r):i},[e,r]);return n.jsx(j,{styles:t,...o,isMulti:!1})}const _=function({clearValue:e}){return n.jsx("div",{onMouseDown:r=>r.stopPropagation(),children:n.jsx(m.TextInputButton,{"aria-label":"Clear",onClick:e,icon:m.stenaTimes,variant:"error"})})},E=function({removeProps:e,data:r}){return n.jsx("div",{onMouseDown:o=>o.stopPropagation(),children:n.jsx(m.Chip,{onClickRemove:o=>e.onClick?.(o),label:r.label})})};function k({variant:e="standard",styles:r,components:o,...t}){const i=p.useMemo(()=>{const a=x(e);return r?f.mergeStyles(a,r):a},[e,r]);return n.jsx(f,{styles:i,components:{...o,ClearIndicator:_,MultiValue:E},...t,isMulti:!0})}function N(e){return n.jsx(k,{hideSelectedOptions:!1,...e,components:{...e.components,ValueContainer:D}})}const D=p.memo(e=>{const[r,...o]=e.children,t=U(r,e);return n.jsxs(f.components.ValueContainer,{...e,children:[t,o]})}),U=(e,{children:r,innerProps:o,className:t,...i})=>e?e.length>1?[e[0],p.createElement(f.components.MultiValue,{...i,key:"DUMMY_VALUE_FOR_PLUS_X",innerProps:{},data:null,isFocused:!1,removeProps:{},index:1,components:{Container:f.components.MultiValueContainer,Label:f.components.MultiValueLabel,Remove:()=>n.jsx("div",{style:{height:16,margin:3,marginTop:4}})}},"+"+(e.length-1))]:e:null;function X({variant:e="standard",styles:r,components:o,...t}){const i=p.useMemo(()=>{const s=x(e);return r?f.mergeStyles(s,r):s},[e,r]),a=s=>n.jsx(m.CloseButton,{"aria-label":"Clear",onClick:s.clearValue});return n.jsx(f,{styles:i,components:{...o,ClearIndicator:a},...t,isMulti:!1})}const B=(e,r)=>g.differenceWith(r,[...e.internalOptions,e],g.isEqual).map(w),Y=e=>!("internalOptions"in e),S=e=>e.filter(Y).map(w),J=e=>(r,o)=>{const t=r??[];switch(o.action){case"select-option":if(o.option&&"internalOptions"in o.option){const i=g.uniqWith(t.reduce((a,s)=>"internalOptions"in s?[...a,...s.internalOptions]:[...a,w(s)],[]),g.isEqual);e(i,o)}else e(S(t),o);break;case"deselect-option":o.option&&"internalOptions"in o.option?e(B(o.option,S(t)),o):e(S(t),o);break;case"remove-value":case"pop-value":o.removedValue&&"internalOptions"in o.removedValue?e(B(o.removedValue,S(t)),o):e(S(t),o);break;case"clear":e(t.map(w),o);break;case"create-option":e(t.map(w),o);break}},K=e=>e.reduce((r,o)=>[...r,F(o),...o.options.map(z)],[]),Q=(e,r)=>{if(!r)return[];const o=[];return e.forEach(t=>{Z(t.options,r)&&o.push(F(t)),o.push(...g.intersectionWith(t.options,r,g.isEqual).map(i=>z(i)))}),o},Z=(e,r)=>r?g.intersectionWith(e,r,g.isEqual).length===e.length:!1,z=e=>({data:e.data,label:e.label,value:e.value}),F=e=>({data:e.label,label:e.label,value:e.label,internalOptions:e.options}),w=e=>({data:e.data,label:e.label,value:e.value}),$=(e,r)=>r?e.menu.selectedItemHoverIconColor:e.menu.selectedItemIconColor;function ee(e){const{formatGroupLabel:r,formatOptionLabel:o}=e.selectProps;return"internalOptions"in e.data?r?r({label:e.data.label,options:e.data.internalOptions}):e.label:o?o(e.data,{context:"menu",inputValue:e.selectProps.inputValue??"",selectValue:e.getValue()}):e.label}function R({onChange:e,options:r,value:o,variant:t="standard",formatGroupLabel:i,formatOptionLabel:a,...s}){const C=d=>{const b=ee(d),O="internalOptions"in d.data;return n.jsx(f.components.Option,{...d,children:n.jsxs(h.Row,{children:[!O&&n.jsx(h.Space,{}),n.jsx(oe,{theme:y,size:O?void 0:"small",label:b,selected:d.isSelected,focused:d.isFocused})]})})},v=d=>"internalOptions"in d.data?null:n.jsx(f.components.MultiValue,{...d}),l=r?Q(r,o):void 0,c=r?K(r):void 0;return n.jsx(k,{...s,onChange:e?J(e):void 0,hideSelectedOptions:!1,components:{...s.components,MultiValue:v,Option:C},isMulti:!0,options:c,value:l,variant:t})}const oe=({focused:e,label:r,selected:o,size:t,theme:i})=>n.jsxs(h.Row,{alignItems:"center",justifyContent:"space-between",flexGrow:1,children:[n.jsx(h.Text,{tabIndex:-1,size:t,color:"currentColor",children:r}),o&&n.jsx(m.Icon,{color:$(i,e),icon:m.stenaCheck,size:12})]});function re({variant:e="standard",styles:r,components:o,ariaLabelClear:t="Clear",...i}){const a=p.useMemo(()=>{const C=x(e);return r?f.mergeStyles(C,r):C},[e,r]),s=C=>n.jsx(m.CloseButton,{"aria-label":t,onClick:C.clearValue});return n.jsx(q,{styles:a,components:{...o,ClearIndicator:s},...i,isMulti:!1})}function V({value:e,onValueChange:r,noneSelectedLabel:o="None",children:t}){return n.jsxs(h.Column,{flex:1,children:[n.jsxs(h.Row,{flexWrap:"wrap",children:[e?.map(i=>n.jsxs(h.Row,{children:[n.jsx(h.Spacing,{num:.5,children:n.jsx(m.Chip,{label:i.label,onClickRemove:()=>r?.(e?.filter(a=>a.value!==i.value)??[])})}),n.jsx(h.Space,{})]},i.value)),e?.length?n.jsx(h.Spacing,{num:.5,children:n.jsx(m.FlatButton,{size:"small",label:"Clear",onClick:()=>r?.([])})}):n.jsx(h.Spacing,{num:.5,children:n.jsx(m.Chip,{variant:"secondary",label:o})})]}),n.jsx(h.Space,{num:.5}),t]})}function te({value:e,onValueChange:r,placeholder:o="Type to search",loading:t,inputValue:i,onInputChange:a,noneSelectedLabel:s="None",...C}){return n.jsx(V,{noneSelectedLabel:s,onValueChange:r,value:e,children:n.jsx(k,{...C,isClearable:!1,value:e,onChange:r?v=>r([...v]):void 0,backspaceRemovesValue:!1,hideSelectedOptions:!0,controlShouldRenderValue:!1,placeholder:o,isLoading:t,inputValue:i,onInputChange:a})})}const le=M.memo(te);function ne({value:e,onValueChange:r,placeholder:o="Type to search",loading:t,inputValue:i,onInputChange:a,noneSelectedLabel:s="None",...C}){return n.jsx(V,{noneSelectedLabel:s,onValueChange:r,value:e,children:n.jsx(R,{...C,isClearable:!1,value:e,onChange:r?v=>r([...v]):void 0,backspaceRemovesValue:!1,hideSelectedOptions:!0,controlShouldRenderValue:!1,placeholder:o,isLoading:t,inputValue:i,onInputChange:a})})}const ie=M.memo(ne);exports.AsyncMultiSelect=W;exports.AsyncSelect=A;exports.ChipMultiSelect=le;exports.CreatableSelect=re;exports.GroupedChipMultiSelect=ie;exports.GroupedMultiSelect=R;exports.MultiSelect=k;exports.OverflowingMultiSelect=N;exports.Select=X;exports.createStylesFromTheme=T;exports.createStylesFromVariant=x;exports.defaultSelectTheme=y;
2
2
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../src/SelectTheme.ts","../src/util/StylesBuilder.ts","../src/components/ui/AsyncMultiSelect.tsx","../src/components/ui/AsyncSelect.tsx","../src/components/ui/MultiSelect.tsx","../src/components/ui/OverflowingMultiSelect.tsx","../src/components/ui/Select.tsx","../src/util/multiDropdownUtils.ts","../src/components/ui/GroupedMultiSelect.tsx","../src/components/ui/CreatableSelect.tsx","../src/components/ui/ChipMultiSelect/ChipRow.tsx","../src/components/ui/ChipMultiSelect/ChipMultiSelect.tsx","../src/components/ui/ChipMultiSelect/GroupedChipMultiSelect.tsx"],"sourcesContent":["import { Property } from \"csstype\";\nimport { cssColor } from \"@stenajs-webui/theme\";\n\nexport interface SelectTheme {\n arrowColor: {\n disabled: string;\n focused: {\n standard: string;\n hover: string;\n };\n closed: {\n standard: string;\n hover: string;\n };\n };\n clearButtonColor: {\n standard: string;\n hover: string;\n };\n input: {\n backgroundColor: string;\n border: string;\n borderColor: string;\n disabledBorderColor: string;\n borderColorFocused: string;\n borderRadius: string;\n disabledBackgroundColor: string;\n warningBackgroundColor: string;\n errorBackgroundColor: string;\n successBackgroundColor: string;\n warningBorderColor: string;\n errorBorderColor: string;\n successBorderColor: string;\n boxShadowFocused: string;\n fontFamily: string;\n fontSize: string;\n height?: string;\n minHeight?: string;\n placeholderColor: string;\n textColor: string;\n };\n loadingIndicator: {\n textColor: string;\n };\n menu: {\n disabledTextColor: string;\n disabledBackgroundColor: string;\n textColor: string;\n backgroundColor: string;\n hoverTextColor: string;\n hoverBackgroundColor: string;\n activeTextColor: string;\n activeBackgroundColor: string;\n minWidth?: string;\n selectedItemTextColor: string;\n selectedItemBackgroundColor: string;\n selectedItemHoverTextColor: string;\n selectedItemIconColor: string;\n selectedItemHoverIconColor: string;\n selectedItemHoverBackgroundColor: string;\n selectedItemActiveTextColor: string;\n selectedItemActiveBackgroundColor: string;\n zIndex: number;\n width?: string;\n whiteSpace?: Property.WhiteSpace;\n };\n groupHeading: {\n fontSize: string;\n lineHeight: string;\n fontWeight: string;\n color: string;\n letterSpacing: string;\n };\n menuPortal: {\n zIndex: number;\n };\n multiSelect: {\n backgroundColor: string;\n textColor: string;\n removeButtonBackgroundColor: string;\n removeButtonTextColor: string;\n removeButtonHoverBackgroundColor: string;\n removeButtonHoverTextColor: string;\n };\n}\n\nexport const defaultSelectTheme: SelectTheme = {\n arrowColor: {\n disabled: cssColor(\"--silver-light\"),\n focused: {\n hover: cssColor(\"--lhds-color-blue-600\"),\n standard: cssColor(\"--lhds-color-blue-600\"),\n },\n closed: {\n hover: cssColor(\"--lhds-color-blue-600\"),\n standard: cssColor(\"--lhds-color-blue-600\"),\n },\n },\n clearButtonColor: {\n hover: cssColor(\"--lhds-color-red-600\"),\n standard: cssColor(\"--lhds-color-red-500\"),\n },\n input: {\n backgroundColor: \"var(--swui-field-bg-enabled)\",\n border: `1px solid var(--swui-select-border-color)`,\n borderColor: \"var(--swui-field-border-color)\",\n borderColorFocused: \"var(--swui-field-border-color-hover)\",\n disabledBackgroundColor: \"var(--swui-field-bg-disabled)\",\n disabledBorderColor: \"var(--swui-field-bg-disabled)\",\n warningBackgroundColor: \"var(--swui-state-alert-light-color)\",\n warningBorderColor: \"var(--swui-state-alert-light-color)\",\n errorBackgroundColor: \"var(--swui-state-error-light-color)\",\n errorBorderColor: \"var(--swui-state-error-light-color)\",\n successBackgroundColor: \"var(--swui-state-success-light-color)\",\n successBorderColor: \"var(--swui-state-success-light-color)\",\n boxShadowFocused: \"none\",\n fontFamily: \"var(--swui-font-primary)\",\n fontSize: \"var(--swui-font-size-inputs)\",\n minHeight: \"24px\",\n placeholderColor: \"var(--swui-field-text-color)\",\n textColor: \"var(--swui-field-text-color)\",\n borderRadius: \"var(--swui-field-border-radius)\",\n },\n loadingIndicator: {\n textColor: \"var(--swui-field-text-color)\",\n },\n groupHeading: {\n fontSize: \"var(--swui-font-size-small)\",\n lineHeight: \"var(--swui-line-height-smaller)\",\n fontWeight: \"var(--swui-font-weight-text-bold)\",\n color: cssColor(\"--lhds-color-ui-600\"),\n letterSpacing: \"0.1rem\",\n },\n menu: {\n activeBackgroundColor: cssColor(\"--lhds-color-blue-100\"),\n activeTextColor: \"var(--swui-field-text-color)\",\n selectedItemActiveBackgroundColor: cssColor(\"--lhds-color-blue-500\"),\n selectedItemActiveTextColor: cssColor(\"--lhds-color-blue-50\"),\n disabledTextColor: \"var(--swui-field-text-color-disabled)\",\n disabledBackgroundColor: \"var(--swui-field-bg-disabled)\",\n textColor: \"var(--swui-field-text-color)\",\n backgroundColor: \"var(--swui-field-bg-enabled)\",\n hoverTextColor: \"var(--swui-field-text-color)\",\n hoverBackgroundColor: cssColor(\"--lhds-color-blue-200\"),\n selectedItemTextColor: cssColor(\"--lhds-color-blue-500\"),\n selectedItemIconColor: cssColor(\"--lhds-color-blue-500\"),\n selectedItemHoverTextColor: \"var(--swui-field-text-color)\",\n selectedItemHoverIconColor: \"var(--swui-field-text-color)\",\n selectedItemBackgroundColor: cssColor(\"--lhds-color-blue-50\"),\n selectedItemHoverBackgroundColor: cssColor(\"--lhds-color-blue-50\"),\n zIndex: 1,\n width: \"auto\",\n minWidth: \"100%\",\n whiteSpace: \"nowrap\",\n },\n menuPortal: {\n zIndex: 1,\n },\n multiSelect: {\n backgroundColor: \"var(--swui-primary-action-color)\",\n textColor: cssColor(\"--lhds-color-blue-50\"),\n removeButtonBackgroundColor: \"transparent\",\n removeButtonTextColor: \"var(--swui-white)\",\n removeButtonHoverBackgroundColor: \"var(--swui-primary-action-color-hover)\",\n removeButtonHoverTextColor: \"var(--swui-white)\",\n },\n};\n","import { StylesConfig } from \"react-select\";\nimport { defaultSelectTheme, SelectTheme } from \"../SelectTheme\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\nimport { Property } from \"csstype\";\n\nexport type SelectVariant = \"standard\" | \"warning\" | \"error\" | \"success\";\n\nconst resolveOptionBackgroundColor = (\n colors: SelectTheme[\"menu\"],\n isDisabled: boolean,\n isSelected: boolean,\n isFocused: boolean,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledBackgroundColor;\n } else if (isSelected && isFocused) {\n return colors.selectedItemHoverBackgroundColor;\n } else if (isSelected) {\n return colors.selectedItemBackgroundColor;\n } else if (isFocused) {\n return colors.hoverBackgroundColor;\n } else {\n return undefined;\n }\n};\n\nconst resolveOptionColor = (\n colors: SelectTheme[\"menu\"],\n isDisabled: boolean,\n isSelected: boolean,\n isFocused: boolean,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledTextColor;\n } else if (isSelected && isFocused) {\n return colors.selectedItemHoverTextColor;\n } else if (isSelected) {\n return colors.selectedItemTextColor;\n } else if (isFocused) {\n return colors.hoverTextColor;\n } else {\n return undefined;\n }\n};\n\nconst resolveInputBackgroundColor = (\n colors: SelectTheme[\"input\"],\n isDisabled: boolean,\n isFocused: boolean,\n variant: SelectVariant | undefined,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledBackgroundColor;\n } else if (isFocused) {\n return colors.backgroundColor;\n } else if (variant === \"warning\") {\n return colors.warningBackgroundColor;\n } else if (variant === \"success\") {\n return colors.successBackgroundColor;\n } else if (variant === \"error\") {\n return colors.errorBackgroundColor;\n } else {\n return colors.backgroundColor;\n }\n};\n\nconst resolveInputBorderColor = (\n colors: SelectTheme[\"input\"],\n isDisabled: boolean,\n isFocused: boolean,\n isHovered: boolean,\n variant: SelectVariant | undefined,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledBorderColor;\n } else if (isFocused) {\n return colors.borderColorFocused;\n } else if (variant === \"warning\") {\n return colors.warningBorderColor;\n } else if (variant === \"success\") {\n return colors.successBorderColor;\n } else if (variant === \"error\") {\n return colors.errorBorderColor;\n } else if (isHovered) {\n return colors.borderColorFocused;\n } else {\n return colors.borderColor;\n }\n};\n\n/**\n * @deprecated\n */\nexport const createStylesFromTheme = <\n OptionType,\n IsMulti extends boolean,\n TGroup extends GroupBase<OptionType> = GroupBase<OptionType>,\n>(\n {\n menu,\n menuPortal,\n input,\n multiSelect,\n clearButtonColor,\n arrowColor,\n groupHeading,\n loadingIndicator,\n }: SelectTheme,\n variant: SelectVariant | undefined,\n): StylesConfig<OptionType, IsMulti, TGroup> => ({\n option: (base, { isDisabled, isFocused, isSelected }) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n backgroundColor: resolveOptionBackgroundColor(\n menu,\n isDisabled,\n isSelected,\n isFocused,\n ),\n color: resolveOptionColor(menu, isDisabled, isSelected, isFocused),\n cursor: isDisabled ? \"not-allowed\" : \"default\",\n whiteSpace: menu.whiteSpace || base.whiteSpace,\n \":active\": {\n backgroundColor: isDisabled\n ? undefined\n : isSelected\n ? menu.selectedItemActiveBackgroundColor\n : menu.activeBackgroundColor,\n color: isDisabled\n ? undefined\n : isSelected\n ? menu.selectedItemActiveTextColor\n : menu.activeTextColor,\n },\n }),\n control: (base, { isFocused, isDisabled, menuIsOpen }) => ({\n ...base,\n // none of react-selects styles are passed to <View />\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n minHeight: \"var(--swui-field-height)\",\n backgroundColor: resolveInputBackgroundColor(\n input,\n isDisabled,\n isFocused,\n variant,\n ),\n borderRadius: input.borderRadius,\n border: input.border,\n \"--swui-select-border-color\": resolveInputBorderColor(\n input,\n isDisabled,\n isFocused || menuIsOpen,\n false,\n variant,\n ),\n outline: isFocused ? \"var(--swui-focus-outline)\" : undefined,\n outlineOffset: isFocused ? \"-1px\" : undefined,\n transition: \"none\",\n boxShadow: isFocused ? input.boxShadowFocused : undefined,\n \"&:hover\": {\n \"--swui-select-border-color\": resolveInputBorderColor(\n input,\n false,\n isFocused || menuIsOpen,\n true,\n variant,\n ),\n },\n }),\n singleValue: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n color: input.textColor,\n }),\n noOptionsMessage: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n }),\n input: (base) => ({\n ...base,\n padding: 0,\n margin: 0,\n minHeight: input.minHeight,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n color: input.textColor,\n }),\n groupHeading: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: groupHeading.fontSize,\n lineHeight: groupHeading.lineHeight,\n fontWeight: groupHeading.fontWeight as Property.FontWeight,\n color: groupHeading.color,\n letterSpacing: groupHeading.letterSpacing,\n }),\n multiValueLabel: (base) => ({\n ...base,\n backgroundColor: multiSelect.backgroundColor,\n color: multiSelect.textColor,\n fontFamily: input.fontFamily,\n fontSize: groupHeading.fontSize,\n }),\n indicatorSeparator: (base) => ({\n ...base,\n display: \"none\",\n }),\n clearIndicator: (base) => ({\n ...base,\n padding: \"5px\",\n color: clearButtonColor.standard,\n \"&:hover\": {\n color: clearButtonColor.hover,\n },\n cursor: \"pointer\",\n }),\n placeholder: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n color: input.placeholderColor,\n }),\n container: (base) => ({\n ...base,\n }),\n valueContainer: (base) => ({\n ...base,\n padding: \"var(--swui-metrics-space-half) var(--swui-metrics-space)\",\n gap: \"var(--swui-metrics-space-half)\",\n }),\n dropdownIndicator: (base, { isFocused, isDisabled }) => ({\n ...base,\n padding: \"5px\",\n color: isDisabled\n ? arrowColor.disabled\n : isFocused\n ? arrowColor.focused.standard\n : arrowColor.closed.standard,\n \"&:hover\": {\n color: isDisabled\n ? arrowColor.disabled\n : isFocused\n ? arrowColor.focused.hover\n : arrowColor.closed.hover,\n },\n svg: {\n width: 14,\n height: 14,\n },\n }),\n menu: (base) => ({\n ...base,\n backgroundColor: menu.backgroundColor,\n color: menu.textColor,\n minWidth: menu.minWidth || base.minWidth,\n zIndex: menu.zIndex,\n width: menu.width || base.width,\n border: input.border,\n borderColor: input.borderColorFocused,\n }),\n menuPortal: (base) => ({\n ...base,\n zIndex: menuPortal.zIndex,\n }),\n multiValueRemove: (styles) => ({\n ...styles,\n backgroundColor: multiSelect.removeButtonBackgroundColor,\n \":hover\": {\n color: multiSelect.removeButtonHoverTextColor,\n backgroundColor: multiSelect.removeButtonHoverBackgroundColor,\n },\n color: multiSelect.removeButtonTextColor,\n borderRadius: \"50%\",\n width: 16,\n height: 16,\n padding: 0,\n margin: 3,\n marginTop: 4,\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n cursor: \"pointer\",\n }),\n multiValue: (base) => ({\n ...base,\n backgroundColor: multiSelect.backgroundColor,\n color: multiSelect.textColor,\n fontFamily: input.fontFamily,\n fontSize: groupHeading.fontSize,\n alignItems: \"center\",\n margin: 0,\n borderRadius: \"var(--swui-border-radius-small)\",\n overflow: \"hidden\",\n }),\n loadingMessage: (base) => ({\n ...base,\n color: loadingIndicator.textColor,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n }),\n});\n\nexport const createStylesFromVariant = <\n OptionType,\n IsMulti extends boolean,\n TGroup extends GroupBase<OptionType> = GroupBase<OptionType>,\n>(\n variant: SelectVariant,\n): StylesConfig<OptionType, IsMulti, TGroup> =>\n createStylesFromTheme(defaultSelectTheme, variant);\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport { mergeStyles } from \"react-select\";\nimport AsyncComponent, { AsyncProps } from \"react-select/async\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\n\nexport interface AsyncMultiSelectProps<T = { label: string; value: string }>\n extends AsyncProps<T, true, GroupBase<T>> {\n variant?: SelectVariant;\n isMulti?: true;\n}\n\nexport function AsyncMultiSelect<T>({\n variant = \"standard\",\n styles,\n ...selectProps\n}: AsyncMultiSelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, true>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n return (\n <AsyncComponent styles={selectStyles} {...selectProps} isMulti={true} />\n );\n}\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport AsyncComponent, { AsyncProps } from \"react-select/async\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { mergeStyles } from \"react-select\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\n\nexport interface AsyncSelectProps<T = { label: string; value: string }>\n extends AsyncProps<T, false, GroupBase<T>> {\n variant?: SelectVariant;\n isMulti?: false;\n}\n\nexport function AsyncSelect<T>({\n variant = \"standard\",\n styles,\n ...selectProps\n}: AsyncSelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, false>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n return (\n <AsyncComponent styles={selectStyles} {...selectProps} isMulti={false} />\n );\n}\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport SelectComponent, {\n ClearIndicatorProps,\n GroupBase,\n mergeStyles,\n MultiValueProps,\n Props,\n SelectComponentsConfig,\n} from \"react-select\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { Chip, stenaTimes, TextInputButton } from \"@stenajs-webui/elements\";\n\nexport interface MultiSelectOption {\n label: string;\n value: string;\n}\n\nexport interface MultiSelectProps<\n TOption extends MultiSelectOption = MultiSelectOption,\n> extends Props<TOption, true> {\n variant?: SelectVariant;\n isMulti?: true;\n}\n\nexport type MultiSelectComponentsConfig<TOption> = SelectComponentsConfig<\n TOption,\n true,\n GroupBase<TOption>\n>;\n\nconst ClearIndicator = function <TOption>({\n clearValue,\n}: ClearIndicatorProps<TOption, true, GroupBase<TOption>>) {\n return (\n // stopPropagation is needed to prevent react-select from opening its menu when clicking on the button.\n <div onMouseDown={(ev) => ev.stopPropagation()}>\n <TextInputButton\n aria-label={\"Clear\"}\n onClick={clearValue}\n icon={stenaTimes}\n variant={\"error\"}\n />\n </div>\n );\n};\n\nconst MultiValue = function <TOption extends MultiSelectOption>({\n removeProps,\n data,\n}: MultiValueProps<TOption, true, GroupBase<TOption>>) {\n return (\n // stopPropagation is needed to prevent react-select from opening its menu when clicking on the button.\n <div onMouseDown={(ev) => ev.stopPropagation()}>\n <Chip\n onClickRemove={(ev) =>\n removeProps.onClick?.(\n ev as unknown as React.MouseEvent<HTMLDivElement>,\n )\n }\n label={data.label}\n />\n </div>\n );\n};\n\nexport function MultiSelect<TOption extends MultiSelectOption>({\n variant = \"standard\",\n styles,\n components,\n ...selectProps\n}: MultiSelectProps<TOption>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<TOption, true>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n return (\n <SelectComponent\n styles={selectStyles}\n components={{ ...components, ClearIndicator, MultiValue }}\n {...selectProps}\n isMulti={true}\n />\n );\n}\n","import * as React from \"react\";\nimport { memo, ReactElement } from \"react\";\nimport {\n MultiSelect,\n MultiSelectOption,\n MultiSelectProps,\n} from \"./MultiSelect\";\nimport { components, ValueContainerProps } from \"react-select\";\n\nexport function OverflowingMultiSelect<T extends MultiSelectOption>(\n props: MultiSelectProps<T>,\n) {\n return (\n <MultiSelect\n hideSelectedOptions={false}\n {...props}\n components={{\n ...props.components,\n ValueContainer: FirstValueOnlyValueContainer,\n }}\n />\n );\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nconst FirstValueOnlyValueContainer = memo(\n (props: ValueContainerProps<any, true>) => {\n const [prevOptions, ...restChildren] = props.children as [\n ReactElement[] | null | undefined,\n ReactElement[] | null | undefined,\n ];\n\n const options = getOptionsToRender(prevOptions, props);\n\n return (\n <components.ValueContainer {...props}>\n {options}\n {restChildren}\n </components.ValueContainer>\n );\n },\n);\n\nconst getOptionsToRender = (\n optionElements: ReactElement[] | null | undefined,\n {\n /* eslint-disable @typescript-eslint/no-unused-vars */\n children,\n innerProps,\n className,\n ...spreadProps\n }: ValueContainerProps<any, true>,\n) => {\n if (!optionElements) {\n return null;\n }\n\n if (optionElements.length > 1) {\n return [\n optionElements[0],\n <components.MultiValue\n {...spreadProps}\n key={\"DUMMY_VALUE_FOR_PLUS_X\"}\n innerProps={{}}\n data={null}\n isFocused={false}\n removeProps={{}}\n index={1}\n components={{\n Container: components.MultiValueContainer,\n Label: components.MultiValueLabel,\n Remove: () => <div style={{ height: 16, margin: 3, marginTop: 4 }} />,\n }}\n >\n {\"+\" + (optionElements.length - 1)}\n </components.MultiValue>,\n ];\n } else {\n return optionElements;\n }\n};\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport SelectComponent, {\n ClearIndicatorProps,\n GroupBase,\n mergeStyles,\n Props,\n} from \"react-select\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { CloseButton } from \"@stenajs-webui/elements\";\n\nexport interface SelectProps<T = { label: string; value: string }>\n extends Props<T, false> {\n variant?: SelectVariant;\n isMulti?: false;\n}\n\nexport function Select<T>({\n variant = \"standard\",\n styles,\n components,\n ...selectProps\n}: SelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, false>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n const ClearIndicator = (\n props: ClearIndicatorProps<T, false, GroupBase<T>>,\n ) => <CloseButton aria-label={\"Clear\"} onClick={props.clearValue} />;\n\n return (\n <SelectComponent\n styles={selectStyles}\n components={{ ...components, ClearIndicator }}\n {...selectProps}\n isMulti={false}\n />\n );\n}\n","import { differenceWith, intersectionWith, isEqual, uniqWith } from \"lodash-es\";\nimport { ActionMeta, GroupBase, OnChangeValue, Options } from \"react-select\";\nimport { OnChange } from \"../components/ui/GroupedMultiSelect\";\nimport { DropdownOption } from \"../components/ui/GroupedMultiSelectTypes\";\n\nexport type GroupedOptionsType<TOption> = ReadonlyArray<GroupBase<TOption>>;\n\nexport type InternalDropdownOption<TData> =\n | InternalChildOption<TData>\n | InternalParentDropdownOption<TData>;\n\ninterface InternalChildOption<TData> {\n data: TData;\n label: string;\n value: string;\n}\n\ninterface InternalParentDropdownOption<TData> {\n data: TData;\n label: string;\n value: string;\n internalOptions: Options<DropdownOption<TData>>;\n}\n\nconst removeGroupedOptionsType = <TData>(\n removedValue: InternalParentDropdownOption<TData>,\n selectedInternalOptions: Options<InternalDropdownOption<TData>>,\n): Options<InternalDropdownOption<TData>> =>\n differenceWith(\n selectedInternalOptions,\n [...removedValue.internalOptions, removedValue],\n isEqual,\n ).map(convertInternalOptionToDropdownOption);\n\nconst removeInternalOptions = <TData>(\n selectedInternalOption: InternalDropdownOption<TData>,\n): boolean => !(\"internalOptions\" in selectedInternalOption);\n\nconst removeOptionHeaders = <TData>(\n selectedInternalOptions: Options<InternalDropdownOption<TData>>,\n): Options<InternalDropdownOption<TData>> =>\n selectedInternalOptions\n .filter(removeInternalOptions)\n .map(convertInternalOptionToDropdownOption);\n\nexport const createOnChange =\n <TData>(onChange: OnChange<TData>) =>\n (\n incomingSelectedInternalOptions: OnChangeValue<\n InternalDropdownOption<TData>,\n true\n >,\n meta: ActionMeta<InternalDropdownOption<TData>>,\n ) => {\n const selectedInternalOptions = incomingSelectedInternalOptions ?? [];\n switch (meta.action) {\n case \"select-option\":\n if (meta.option && \"internalOptions\" in meta.option) {\n const selectedOptions: OnChangeValue<\n InternalDropdownOption<TData>,\n true\n > = uniqWith(\n selectedInternalOptions.reduce<Options<DropdownOption<TData>>>(\n (previousValue, currentValue) => {\n if (\"internalOptions\" in currentValue) {\n return [...previousValue, ...currentValue.internalOptions];\n } else {\n return [\n ...previousValue,\n convertInternalOptionToDropdownOption(currentValue),\n ];\n }\n },\n [],\n ),\n isEqual,\n );\n\n onChange(selectedOptions, meta);\n } else {\n onChange(removeOptionHeaders(selectedInternalOptions), meta);\n }\n break;\n case \"deselect-option\":\n if (meta.option && \"internalOptions\" in meta.option) {\n onChange(\n removeGroupedOptionsType(\n meta.option,\n removeOptionHeaders(selectedInternalOptions),\n ),\n meta,\n );\n } else {\n onChange(removeOptionHeaders(selectedInternalOptions), meta);\n }\n break;\n case \"remove-value\":\n case \"pop-value\":\n if (meta.removedValue && \"internalOptions\" in meta.removedValue) {\n onChange(\n removeGroupedOptionsType(\n meta.removedValue,\n removeOptionHeaders(selectedInternalOptions),\n ),\n meta,\n );\n } else {\n onChange(removeOptionHeaders(selectedInternalOptions), meta);\n }\n break;\n case \"clear\":\n onChange(\n selectedInternalOptions.map(convertInternalOptionToDropdownOption),\n meta,\n );\n break;\n case \"create-option\":\n onChange(\n selectedInternalOptions.map(convertInternalOptionToDropdownOption),\n meta,\n );\n break;\n default:\n break;\n }\n };\n\nexport const convertGroupedDropdownOptionsToInternalOptions = <TData>(\n options: GroupedOptionsType<DropdownOption<TData>>,\n): InternalDropdownOption<TData>[] => {\n return options.reduce<InternalDropdownOption<TData>[]>(\n (previousValue, currentValue) => {\n return [\n ...previousValue,\n convertGroupedDropdownOptionToInternalOption(currentValue),\n ...currentValue.options.map(convertDropdownOptionToInternalOption),\n ];\n },\n [],\n );\n};\n\nexport const convertValueToInternalValue = <TData>(\n options: GroupedOptionsType<DropdownOption<TData>>,\n values: Options<DropdownOption<TData>> | undefined,\n): InternalDropdownOption<TData>[] => {\n if (!values) {\n return [];\n }\n const selectedOptions: InternalDropdownOption<TData>[] = [];\n options.forEach((option) => {\n if (allOptionsExists(option.options, values)) {\n selectedOptions.push(\n convertGroupedDropdownOptionToInternalOption(option),\n );\n }\n selectedOptions.push(\n ...intersectionWith(option.options, values, isEqual).map((option) =>\n convertDropdownOptionToInternalOption(option),\n ),\n );\n });\n return selectedOptions;\n};\n\nexport const allOptionsExists = <TData>(\n options: Options<DropdownOption<TData>>,\n selectedValues: Options<DropdownOption<TData>> | undefined,\n): boolean => {\n if (!selectedValues) {\n return false;\n }\n\n return (\n intersectionWith(options, selectedValues, isEqual).length === options.length\n );\n};\n\nexport const convertDropdownOptionToInternalOption = <TData>(\n option: DropdownOption<TData>,\n): InternalDropdownOption<TData> => ({\n data: option.data,\n label: option.label,\n value: option.value,\n});\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nexport const convertGroupedDropdownOptionToInternalOption = <TData>(\n option: GroupBase<DropdownOption<TData>>,\n): InternalDropdownOption<TData> => ({\n data: option.label as any,\n label: option.label as any,\n value: option.label as any,\n internalOptions: option.options,\n});\n\nexport const convertInternalOptionToDropdownOption = <TData>(\n option: InternalDropdownOption<TData>,\n): DropdownOption<TData> => ({\n data: option.data,\n label: option.label,\n value: option.value,\n});\n","import { Row, Space, Text, TextSize } from \"@stenajs-webui/core\";\nimport { Icon, stenaCheck } from \"@stenajs-webui/elements\";\nimport * as React from \"react\";\nimport { ReactNode } from \"react\";\nimport {\n ActionMeta,\n components,\n GroupBase,\n MultiValueProps,\n OnChangeValue,\n OptionProps,\n Options,\n} from \"react-select\";\nimport { defaultSelectTheme, SelectTheme } from \"../../SelectTheme\";\nimport {\n convertGroupedDropdownOptionsToInternalOptions,\n convertValueToInternalValue,\n createOnChange,\n GroupedOptionsType,\n InternalDropdownOption,\n} from \"../../util/multiDropdownUtils\";\nimport { DropdownOption } from \"./GroupedMultiSelectTypes\";\nimport {\n MultiSelect,\n MultiSelectComponentsConfig,\n MultiSelectProps,\n} from \"./MultiSelect\";\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nexport type OnChange<TData> = (\n value: OnChangeValue<DropdownOption<TData>, true>,\n action: ActionMeta<any>,\n) => void;\n\nexport interface GroupedMultiSelectProps<TData>\n extends Omit<\n MultiSelectProps<InternalDropdownOption<TData>>,\n \"options\" | \"onChange\" | \"value\" | \"components\"\n > {\n /**\n * Same as Select prop `component` but without MultiValue and Option since they can not be modified\n */\n components?: Omit<\n MultiSelectComponentsConfig<InternalDropdownOption<TData>>,\n \"MultiValue\" | \"Option\"\n >;\n /**\n * Same as Select prop `options` but only with GroupOptionsType\n */\n options?: GroupedOptionsType<DropdownOption<TData>>;\n /**\n * Same as Select prop `onChange` but only with GroupOptionsType\n */\n onChange?: OnChange<TData>;\n /**\n * Same as Select prop `value` but only with GroupOptionsType\n */\n value?: Options<DropdownOption<TData>> | undefined;\n}\n\nconst resolveIconColor = (\n theme: SelectTheme,\n isFocused: boolean,\n): string | undefined =>\n isFocused\n ? theme.menu.selectedItemHoverIconColor\n : theme.menu.selectedItemIconColor;\n\nfunction formatInnerOptionLabel<TData>(\n props: OptionProps<\n InternalDropdownOption<TData>,\n true,\n GroupBase<InternalDropdownOption<TData>>\n >,\n) {\n const { formatGroupLabel, formatOptionLabel } = props.selectProps;\n\n if (\"internalOptions\" in props.data) {\n return formatGroupLabel\n ? formatGroupLabel({\n label: props.data.label,\n options: props.data.internalOptions,\n })\n : props.label;\n }\n\n return formatOptionLabel\n ? formatOptionLabel(props.data, {\n context: \"menu\",\n inputValue: props.selectProps.inputValue ?? \"\",\n selectValue: props.getValue(),\n })\n : props.label;\n}\n\nexport function GroupedMultiSelect<TData>({\n onChange,\n options,\n value,\n variant = \"standard\",\n /* eslint-disable @typescript-eslint/no-unused-vars */\n formatGroupLabel,\n formatOptionLabel,\n ...selectProps\n}: GroupedMultiSelectProps<TData>): React.ReactElement<\n GroupedMultiSelectProps<TData>\n> {\n const Option = (\n props: OptionProps<\n InternalDropdownOption<TData>,\n true,\n GroupBase<InternalDropdownOption<TData>>\n >,\n ) => {\n const label = formatInnerOptionLabel(props);\n const isGroupOption = \"internalOptions\" in props.data;\n\n return (\n <components.Option {...props}>\n <Row>\n {!isGroupOption && <Space />}\n <InnerOption\n theme={defaultSelectTheme}\n size={!isGroupOption ? \"small\" : undefined}\n label={label}\n selected={props.isSelected}\n focused={props.isFocused}\n />\n </Row>\n </components.Option>\n );\n };\n\n const MultiValue = (\n props: MultiValueProps<\n InternalDropdownOption<TData>,\n true,\n GroupBase<InternalDropdownOption<TData>>\n >,\n ) => {\n return !(\"internalOptions\" in props.data) ? (\n <components.MultiValue {...props} />\n ) : null;\n };\n\n const internalValue = options\n ? convertValueToInternalValue(options, value)\n : undefined;\n const internalOptions = options\n ? convertGroupedDropdownOptionsToInternalOptions(options)\n : undefined;\n\n return (\n <MultiSelect<InternalDropdownOption<TData>>\n {...selectProps}\n onChange={onChange ? createOnChange<TData>(onChange) : undefined}\n hideSelectedOptions={false}\n components={{\n ...selectProps.components,\n MultiValue,\n Option,\n }}\n isMulti={true}\n options={internalOptions}\n value={internalValue}\n variant={variant}\n />\n );\n}\n\ninterface InnerOptionProps {\n size?: TextSize;\n selected: boolean;\n theme: SelectTheme;\n label: ReactNode;\n focused: boolean;\n}\n\nconst InnerOption: React.FC<InnerOptionProps> = ({\n focused,\n label,\n selected,\n size,\n theme,\n}) => (\n <Row alignItems={\"center\"} justifyContent={\"space-between\"} flexGrow={1}>\n <Text tabIndex={-1} size={size} color={\"currentColor\"}>\n {label}\n </Text>\n {selected && (\n <Icon\n color={resolveIconColor(theme, focused)}\n icon={stenaCheck}\n size={12}\n />\n )}\n </Row>\n);\n","import { CloseButton } from \"@stenajs-webui/elements\";\nimport * as React from \"react\";\nimport { useMemo } from \"react\";\nimport { ClearIndicatorProps, mergeStyles } from \"react-select\";\nimport CreatableComponent, { CreatableProps } from \"react-select/creatable\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\n\nexport interface CreatableSelectProps<T = { label: string; value: string }>\n extends CreatableProps<T, false, GroupBase<T>> {\n variant?: SelectVariant;\n isMulti?: false;\n ariaLabelClear?: string;\n}\n\nexport function CreatableSelect<T>({\n variant = \"standard\",\n styles,\n components,\n ariaLabelClear = \"Clear\",\n ...selectProps\n}: CreatableSelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, false>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n const ClearIndicator = (\n props: ClearIndicatorProps<T, false, GroupBase<T>>,\n ) => <CloseButton aria-label={ariaLabelClear} onClick={props.clearValue} />;\n\n return (\n <CreatableComponent\n styles={selectStyles}\n components={{ ...components, ClearIndicator }}\n {...selectProps}\n isMulti={false}\n />\n );\n}\n","import { Column, Row, Space, Spacing } from \"@stenajs-webui/core\";\nimport { Chip, FlatButton } from \"@stenajs-webui/elements\";\nimport { ValueAndOnValueChangeProps } from \"@stenajs-webui/forms\";\nimport * as React from \"react\";\nimport { PropsWithChildren } from \"react\";\nimport { MultiSelectOption } from \"../MultiSelect\";\n\nexport interface ChipRowItem extends MultiSelectOption {}\n\nexport interface ChipRowProps<TValue>\n extends ValueAndOnValueChangeProps<TValue> {\n noneSelectedLabel?: string;\n}\n\nexport function ChipRow<TValue extends ChipRowItem>({\n value,\n onValueChange,\n noneSelectedLabel = \"None\",\n children,\n}: PropsWithChildren<ChipRowProps<Array<TValue>>>) {\n return (\n <Column flex={1}>\n <Row flexWrap={\"wrap\"}>\n {value?.map((v) => (\n <Row key={v.value}>\n <Spacing num={0.5}>\n <Chip\n label={v.label}\n onClickRemove={() =>\n onValueChange?.(\n value?.filter((f) => f.value !== v.value) ?? [],\n )\n }\n />\n </Spacing>\n <Space />\n </Row>\n ))}\n {value?.length ? (\n <Spacing num={0.5}>\n <FlatButton\n size={\"small\"}\n label={\"Clear\"}\n onClick={() => onValueChange?.([])}\n />\n </Spacing>\n ) : (\n <Spacing num={0.5}>\n <Chip variant={\"secondary\"} label={noneSelectedLabel} />\n </Spacing>\n )}\n </Row>\n <Space num={0.5} />\n {children}\n </Column>\n );\n}\n","import { ValueAndOnValueChangeProps } from \"@stenajs-webui/forms\";\nimport * as React from \"react\";\nimport {\n MultiSelect,\n MultiSelectOption,\n MultiSelectProps,\n} from \"../MultiSelect\";\nimport { ChipRow, ChipRowItem } from \"./ChipRow\";\n\nexport interface ChipMultiSelectOption extends ChipRowItem {}\n\n/**\n * @deprecated renamed to ChipMultiSelectOption\n */\nexport type ChipMultiSelectValue = ChipMultiSelectOption;\n\nexport interface ChipMultiSelectProps<\n TOption extends MultiSelectOption = MultiSelectOption,\n> extends Omit<MultiSelectProps<TOption>, \"value\" | \"onChange\" | \"isLoading\">,\n ValueAndOnValueChangeProps<Array<TOption>> {\n loading?: boolean;\n inputValue?: string;\n onInputChange?: (inputValue: string) => void;\n noneSelectedLabel?: string;\n}\n\nfunction _ChipMultiSelect<TOption extends ChipMultiSelectOption>({\n value,\n onValueChange,\n placeholder = \"Type to search\",\n loading,\n inputValue,\n onInputChange,\n noneSelectedLabel = \"None\",\n ...selectProps\n}: ChipMultiSelectProps<TOption>) {\n return (\n <ChipRow\n noneSelectedLabel={noneSelectedLabel}\n onValueChange={onValueChange}\n value={value}\n >\n <MultiSelect<TOption>\n {...selectProps}\n isClearable={false}\n value={value}\n onChange={\n onValueChange ? (value) => onValueChange([...value]) : undefined\n }\n backspaceRemovesValue={false}\n hideSelectedOptions\n controlShouldRenderValue={false}\n placeholder={placeholder}\n isLoading={loading}\n inputValue={inputValue}\n onInputChange={onInputChange}\n />\n </ChipRow>\n );\n}\n\nexport const ChipMultiSelect = React.memo(\n _ChipMultiSelect,\n) as typeof _ChipMultiSelect;\n","import * as React from \"react\";\nimport { ValueAndOnValueChangeProps } from \"@stenajs-webui/forms\";\nimport {\n GroupedMultiSelect,\n GroupedMultiSelectProps,\n} from \"../GroupedMultiSelect\";\nimport { DropdownOption } from \"../GroupedMultiSelectTypes\";\nimport { ChipRow } from \"./ChipRow\";\n\nexport interface GroupedChipMultiSelectValue<TData>\n extends DropdownOption<TData> {}\n\nexport interface GroupedChipMultiSelectProps<TData>\n extends Omit<GroupedMultiSelectProps<TData>, \"onChange\" | \"value\">,\n ValueAndOnValueChangeProps<Array<DropdownOption<TData>>> {\n loading?: boolean;\n inputValue?: string;\n onInputChange?: (inputValue: string) => void;\n noneSelectedLabel?: string;\n}\n\nfunction _GroupedChipMultiSelect<TData>({\n value,\n onValueChange,\n placeholder = \"Type to search\",\n loading,\n inputValue,\n onInputChange,\n noneSelectedLabel = \"None\",\n ...selectProps\n}: GroupedChipMultiSelectProps<TData>) {\n return (\n <ChipRow\n noneSelectedLabel={noneSelectedLabel}\n onValueChange={onValueChange}\n value={value}\n >\n <GroupedMultiSelect<TData>\n {...selectProps}\n isClearable={false}\n value={value}\n onChange={\n onValueChange ? (value) => onValueChange([...value]) : undefined\n }\n backspaceRemovesValue={false}\n hideSelectedOptions\n controlShouldRenderValue={false}\n placeholder={placeholder}\n isLoading={loading}\n inputValue={inputValue}\n onInputChange={onInputChange}\n />\n </ChipRow>\n );\n}\n\nexport const GroupedChipMultiSelect = React.memo(\n _GroupedChipMultiSelect,\n) as typeof _GroupedChipMultiSelect;\n"],"names":["defaultSelectTheme","cssColor","resolveOptionBackgroundColor","colors","isDisabled","isSelected","isFocused","resolveOptionColor","resolveInputBackgroundColor","variant","resolveInputBorderColor","isHovered","createStylesFromTheme","menu","menuPortal","input","multiSelect","clearButtonColor","arrowColor","groupHeading","loadingIndicator","base","menuIsOpen","styles","createStylesFromVariant","AsyncMultiSelect","selectProps","selectStyles","useMemo","sourceStyles","mergeStyles","AsyncComponent","AsyncSelect","ClearIndicator","clearValue","ev","jsx","TextInputButton","stenaTimes","MultiValue","removeProps","data","Chip","_a","MultiSelect","components","SelectComponent","OverflowingMultiSelect","props","FirstValueOnlyValueContainer","memo","prevOptions","restChildren","options","getOptionsToRender","jsxs","optionElements","children","innerProps","className","spreadProps","createElement","Select","CloseButton","removeGroupedOptionsType","removedValue","selectedInternalOptions","differenceWith","isEqual","convertInternalOptionToDropdownOption","removeInternalOptions","selectedInternalOption","removeOptionHeaders","createOnChange","onChange","incomingSelectedInternalOptions","meta","selectedOptions","uniqWith","previousValue","currentValue","convertGroupedDropdownOptionsToInternalOptions","convertGroupedDropdownOptionToInternalOption","convertDropdownOptionToInternalOption","convertValueToInternalValue","values","option","allOptionsExists","intersectionWith","selectedValues","resolveIconColor","theme","formatInnerOptionLabel","formatGroupLabel","formatOptionLabel","GroupedMultiSelect","value","Option","label","isGroupOption","Row","Space","InnerOption","internalValue","internalOptions","focused","selected","size","Text","Icon","stenaCheck","CreatableSelect","ariaLabelClear","CreatableComponent","ChipRow","onValueChange","noneSelectedLabel","Column","v","Spacing","f","FlatButton","_ChipMultiSelect","placeholder","loading","inputValue","onInputChange","ChipMultiSelect","React","_GroupedChipMultiSelect","GroupedChipMultiSelect"],"mappings":"+nBAsFaA,EAAkC,CAC7C,WAAY,CACV,SAAUC,WAAS,gBAAgB,EACnC,QAAS,CACP,MAAOA,WAAS,uBAAuB,EACvC,SAAUA,WAAS,uBAAuB,CAC5C,EACA,OAAQ,CACN,MAAOA,WAAS,uBAAuB,EACvC,SAAUA,WAAS,uBAAuB,CAAA,CAE9C,EACA,iBAAkB,CAChB,MAAOA,WAAS,sBAAsB,EACtC,SAAUA,WAAS,sBAAsB,CAC3C,EACA,MAAO,CACL,gBAAiB,+BACjB,OAAQ,4CACR,YAAa,iCACb,mBAAoB,uCACpB,wBAAyB,gCACzB,oBAAqB,gCACrB,uBAAwB,sCACxB,mBAAoB,sCACpB,qBAAsB,sCACtB,iBAAkB,sCAClB,uBAAwB,wCACxB,mBAAoB,wCACpB,iBAAkB,OAClB,WAAY,2BACZ,SAAU,+BACV,UAAW,OACX,iBAAkB,+BAClB,UAAW,+BACX,aAAc,iCAChB,EACA,iBAAkB,CAChB,UAAW,8BACb,EACA,aAAc,CACZ,SAAU,8BACV,WAAY,kCACZ,WAAY,oCACZ,MAAOA,WAAS,qBAAqB,EACrC,cAAe,QACjB,EACA,KAAM,CACJ,sBAAuBA,WAAS,uBAAuB,EACvD,gBAAiB,+BACjB,kCAAmCA,WAAS,uBAAuB,EACnE,4BAA6BA,WAAS,sBAAsB,EAC5D,kBAAmB,wCACnB,wBAAyB,gCACzB,UAAW,+BACX,gBAAiB,+BACjB,eAAgB,+BAChB,qBAAsBA,WAAS,uBAAuB,EACtD,sBAAuBA,WAAS,uBAAuB,EACvD,sBAAuBA,WAAS,uBAAuB,EACvD,2BAA4B,+BAC5B,2BAA4B,+BAC5B,4BAA6BA,WAAS,sBAAsB,EAC5D,iCAAkCA,WAAS,sBAAsB,EACjE,OAAQ,EACR,MAAO,OACP,SAAU,OACV,WAAY,QACd,EACA,WAAY,CACV,OAAQ,CACV,EACA,YAAa,CACX,gBAAiB,mCACjB,UAAWA,WAAS,sBAAsB,EAC1C,4BAA6B,cAC7B,sBAAuB,oBACvB,iCAAkC,yCAClC,2BAA4B,mBAAA,CAEhC,EC/JMC,EAA+B,CACnCC,EACAC,EACAC,EACAC,IAEIF,EACKD,EAAO,wBACLE,GAAcC,EAChBH,EAAO,iCACLE,EACFF,EAAO,4BACLG,EACFH,EAAO,qBAEP,OAILI,EAAqB,CACzBJ,EACAC,EACAC,EACAC,IAEIF,EACKD,EAAO,kBACLE,GAAcC,EAChBH,EAAO,2BACLE,EACFF,EAAO,sBACLG,EACFH,EAAO,eAEP,OAILK,EAA8B,CAClCL,EACAC,EACAE,EACAG,IAEIL,EACKD,EAAO,wBACLG,EACFH,EAAO,gBACLM,IAAY,UACdN,EAAO,uBACLM,IAAY,UACdN,EAAO,uBACLM,IAAY,QACdN,EAAO,qBAEPA,EAAO,gBAIZO,EAA0B,CAC9BP,EACAC,EACAE,EACAK,EACAF,IAEIL,EACKD,EAAO,oBACLG,EACFH,EAAO,mBACLM,IAAY,UACdN,EAAO,mBACLM,IAAY,UACdN,EAAO,mBACLM,IAAY,QACdN,EAAO,iBACLQ,EACFR,EAAO,mBAEPA,EAAO,YAOLS,EAAwB,CAKnC,CACE,KAAAC,EACA,WAAAC,EACA,MAAAC,EACA,YAAAC,EACA,iBAAAC,EACA,WAAAC,EACA,aAAAC,EACA,iBAAAC,CACF,EACAX,KAC+C,CAC/C,OAAQ,CAACY,EAAM,CAAE,WAAAjB,EAAY,UAAAE,EAAW,WAAAD,MAAkB,CACxD,GAAGgB,EACH,WAAYN,EAAM,WAClB,SAAUA,EAAM,SAChB,gBAAiBb,EACfW,EACAT,EACAC,EACAC,CACF,EACA,MAAOC,EAAmBM,EAAMT,EAAYC,EAAYC,CAAS,EACjE,OAAQF,EAAa,cAAgB,UACrC,WAAYS,EAAK,YAAcQ,EAAK,WACpC,UAAW,CACT,gBAAiBjB,EACb,OACAC,EACEQ,EAAK,kCACLA,EAAK,sBACX,MAAOT,EACH,OACAC,EACEQ,EAAK,4BACLA,EAAK,eAAA,CACb,GAEF,QAAS,CAACQ,EAAM,CAAE,UAAAf,EAAW,WAAAF,EAAY,WAAAkB,MAAkB,CACzD,GAAGD,EAEH,WAAYN,EAAM,WAClB,SAAUA,EAAM,SAChB,UAAW,2BACX,gBAAiBP,EACfO,EACAX,EACAE,EACAG,CACF,EACA,aAAcM,EAAM,aACpB,OAAQA,EAAM,OACd,6BAA8BL,EAC5BK,EACAX,EACAE,GAAagB,EACb,GACAb,CACF,EACA,QAASH,EAAY,4BAA8B,OACnD,cAAeA,EAAY,OAAS,OACpC,WAAY,OACZ,UAAWA,EAAYS,EAAM,iBAAmB,OAChD,UAAW,CACT,6BAA8BL,EAC5BK,EACA,GACAT,GAAagB,EACb,GACAb,CAAA,CACF,CACF,GAEF,YAAcY,IAAU,CACtB,GAAGA,EACH,WAAYN,EAAM,WAClB,SAAUA,EAAM,SAChB,MAAOA,EAAM,SAAA,GAEf,iBAAmBM,IAAU,CAC3B,GAAGA,EACH,WAAYN,EAAM,WAClB,SAAUA,EAAM,QAAA,GAElB,MAAQM,IAAU,CAChB,GAAGA,EACH,QAAS,EACT,OAAQ,EACR,UAAWN,EAAM,UACjB,WAAYA,EAAM,WAClB,SAAUA,EAAM,SAChB,MAAOA,EAAM,SAAA,GAEf,aAAeM,IAAU,CACvB,GAAGA,EACH,WAAYN,EAAM,WAClB,SAAUI,EAAa,SACvB,WAAYA,EAAa,WACzB,WAAYA,EAAa,WACzB,MAAOA,EAAa,MACpB,cAAeA,EAAa,aAAA,GAE9B,gBAAkBE,IAAU,CAC1B,GAAGA,EACH,gBAAiBL,EAAY,gBAC7B,MAAOA,EAAY,UACnB,WAAYD,EAAM,WAClB,SAAUI,EAAa,QAAA,GAEzB,mBAAqBE,IAAU,CAC7B,GAAGA,EACH,QAAS,MAAA,GAEX,eAAiBA,IAAU,CACzB,GAAGA,EACH,QAAS,MACT,MAAOJ,EAAiB,SACxB,UAAW,CACT,MAAOA,EAAiB,KAC1B,EACA,OAAQ,SAAA,GAEV,YAAcI,IAAU,CACtB,GAAGA,EACH,WAAYN,EAAM,WAClB,SAAUA,EAAM,SAChB,MAAOA,EAAM,gBAAA,GAEf,UAAYM,IAAU,CACpB,GAAGA,CAAA,GAEL,eAAiBA,IAAU,CACzB,GAAGA,EACH,QAAS,2DACT,IAAK,gCAAA,GAEP,kBAAmB,CAACA,EAAM,CAAE,UAAAf,EAAW,WAAAF,MAAkB,CACvD,GAAGiB,EACH,QAAS,MACT,MAAOjB,EACHc,EAAW,SACXZ,EACEY,EAAW,QAAQ,SACnBA,EAAW,OAAO,SACxB,UAAW,CACT,MAAOd,EACHc,EAAW,SACXZ,EACEY,EAAW,QAAQ,MACnBA,EAAW,OAAO,KAC1B,EACA,IAAK,CACH,MAAO,GACP,OAAQ,EAAA,CACV,GAEF,KAAOG,IAAU,CACf,GAAGA,EACH,gBAAiBR,EAAK,gBACtB,MAAOA,EAAK,UACZ,SAAUA,EAAK,UAAYQ,EAAK,SAChC,OAAQR,EAAK,OACb,MAAOA,EAAK,OAASQ,EAAK,MAC1B,OAAQN,EAAM,OACd,YAAaA,EAAM,kBAAA,GAErB,WAAaM,IAAU,CACrB,GAAGA,EACH,OAAQP,EAAW,MAAA,GAErB,iBAAmBS,IAAY,CAC7B,GAAGA,EACH,gBAAiBP,EAAY,4BAC7B,SAAU,CACR,MAAOA,EAAY,2BACnB,gBAAiBA,EAAY,gCAC/B,EACA,MAAOA,EAAY,sBACnB,aAAc,MACd,MAAO,GACP,OAAQ,GACR,QAAS,EACT,OAAQ,EACR,UAAW,EACX,QAAS,OACT,eAAgB,SAChB,WAAY,SACZ,OAAQ,SAAA,GAEV,WAAaK,IAAU,CACrB,GAAGA,EACH,gBAAiBL,EAAY,gBAC7B,MAAOA,EAAY,UACnB,WAAYD,EAAM,WAClB,SAAUI,EAAa,SACvB,WAAY,SACZ,OAAQ,EACR,aAAc,kCACd,SAAU,QAAA,GAEZ,eAAiBE,IAAU,CACzB,GAAGA,EACH,MAAOD,EAAiB,UACxB,WAAYL,EAAM,WAClB,SAAUA,EAAM,QAClB,EACF,GAEaS,EAKXf,GAEAG,EAAsBZ,EAAoBS,CAAO,ECzS5C,SAASgB,EAAoB,CAClC,QAAAhB,EAAU,WACV,OAAAc,EACA,GAAGG,CACL,EAA6B,CACrB,MAAAC,EAAeC,EAAAA,QAAQ,IAAM,CAC3B,MAAAC,EAAeL,EAAiCf,CAAO,EAE7D,OAAOc,EAASO,EAAA,YAAYD,EAAcN,CAAM,EAAIM,CAAA,EACnD,CAACpB,EAASc,CAAM,CAAC,EAEpB,aACGQ,EAAe,CAAA,OAAQJ,EAAe,GAAGD,EAAa,QAAS,GAAM,CAE1E,CCdO,SAASM,EAAe,CAC7B,QAAAvB,EAAU,WACV,OAAAc,EACA,GAAGG,CACL,EAAwB,CAChB,MAAAC,EAAeC,EAAAA,QAAQ,IAAM,CAC3B,MAAAC,EAAeL,EAAkCf,CAAO,EAE9D,OAAOc,EAASO,EAAA,YAAYD,EAAcN,CAAM,EAAIM,CAAA,EACnD,CAACpB,EAASc,CAAM,CAAC,EAEpB,aACGQ,EAAe,CAAA,OAAQJ,EAAe,GAAGD,EAAa,QAAS,GAAO,CAE3E,CCIA,MAAMO,EAAiB,SAAmB,CACxC,WAAAC,CACF,EAA2D,CACzD,aAEG,MAAI,CAAA,YAAcC,GAAOA,EAAG,kBAC3B,SAAAC,EAAA,IAACC,EAAA,gBAAA,CACC,aAAY,QACZ,QAASH,EACT,KAAMI,EAAA,WACN,QAAS,OAAA,CAAA,CAEb,CAAA,CAEJ,EAEMC,EAAa,SAA6C,CAC9D,YAAAC,EACA,KAAAC,CACF,EAAuD,CACrD,aAEG,MAAI,CAAA,YAAcN,GAAOA,EAAG,kBAC3B,SAAAC,EAAA,IAACM,EAAA,KAAA,CACC,cAAgBP,GACd,OAAA,OAAAQ,EAAAH,EAAY,UAAZ,YAAAG,EAAA,KAAAH,EACEL,IAGJ,MAAOM,EAAK,KAAA,CAAA,CAEhB,CAAA,CAEJ,EAEO,SAASG,EAA+C,CAC7D,QAAAnC,EAAU,WACV,OAAAc,EACA,WAAAsB,EACA,GAAGnB,CACL,EAA8B,CACtB,MAAAC,EAAeC,EAAAA,QAAQ,IAAM,CAC3B,MAAAC,EAAeL,EAAuCf,CAAO,EAEnE,OAAOc,EAASO,EAAA,YAAYD,EAAcN,CAAM,EAAIM,CAAA,EACnD,CAACpB,EAASc,CAAM,CAAC,EAGlB,OAAAa,EAAA,IAACU,EAAA,CACC,OAAQnB,EACR,WAAY,CAAE,GAAGkB,EAAY,eAAAZ,EAAgB,WAAAM,CAAW,EACvD,GAAGb,EACJ,QAAS,EAAA,CACX,CAEJ,CChFO,SAASqB,EACdC,EACA,CAEE,OAAAZ,EAAA,IAACQ,EAAA,CACC,oBAAqB,GACpB,GAAGI,EACJ,WAAY,CACV,GAAGA,EAAM,WACT,eAAgBC,CAAA,CAClB,CACF,CAEJ,CAIA,MAAMA,EAA+BC,EAAA,KAClCF,GAA0C,CACzC,KAAM,CAACG,EAAa,GAAGC,CAAY,EAAIJ,EAAM,SAKvCK,EAAUC,EAAmBH,EAAaH,CAAK,EAErD,OACGO,EAAAA,KAAAV,EAAAA,WAAW,eAAX,CAA2B,GAAGG,EAC5B,SAAA,CAAAK,EACAD,CAAA,EACH,CAAA,CAGN,EAEME,EAAqB,CACzBE,EACA,CAEE,SAAAC,EACA,WAAAC,EACA,UAAAC,EACA,GAAGC,CACL,IAEKJ,EAIDA,EAAe,OAAS,EACnB,CACLA,EAAe,CAAC,EAChBK,EAAA,cAAChB,EAAAA,WAAW,WAAX,CACE,GAAGe,EACJ,IAAK,yBACL,WAAY,CAAC,EACb,KAAM,KACN,UAAW,GACX,YAAa,CAAC,EACd,MAAO,EACP,WAAY,CACV,UAAWf,EAAW,WAAA,oBACtB,MAAOA,EAAW,WAAA,gBAClB,OAAQ,IAAOT,EAAAA,IAAA,MAAA,CAAI,MAAO,CAAE,OAAQ,GAAI,OAAQ,EAAG,UAAW,CAAA,CAAK,CAAA,CAAA,CACrE,EAEC,KAAOoB,EAAe,OAAS,EAAA,CAEpC,EAEOA,EAxBA,KCnCJ,SAASM,EAAU,CACxB,QAAArD,EAAU,WACV,OAAAc,EACA,WAAAsB,EACA,GAAGnB,CACL,EAAmB,CACX,MAAAC,EAAeC,EAAAA,QAAQ,IAAM,CAC3B,MAAAC,EAAeL,EAAkCf,CAAO,EAE9D,OAAOc,EAASO,EAAA,YAAYD,EAAcN,CAAM,EAAIM,CAAA,EACnD,CAACpB,EAASc,CAAM,CAAC,EAEdU,EACJe,GACGZ,EAAAA,IAAC2B,eAAY,aAAY,QAAS,QAASf,EAAM,UAAY,CAAA,EAGhE,OAAAZ,EAAA,IAACU,EAAA,CACC,OAAQnB,EACR,WAAY,CAAE,GAAGkB,EAAY,eAAAZ,CAAe,EAC3C,GAAGP,EACJ,QAAS,EAAA,CACX,CAEJ,CCpBA,MAAMsC,EAA2B,CAC/BC,EACAC,IAEAC,EAAA,eACED,EACA,CAAC,GAAGD,EAAa,gBAAiBA,CAAY,EAC9CG,EAAAA,OACF,EAAE,IAAIC,CAAqC,EAEvCC,EACJC,GACY,EAAE,oBAAqBA,GAE/BC,EACJN,GAEAA,EACG,OAAOI,CAAqB,EAC5B,IAAID,CAAqC,EAEjCI,EACHC,GACR,CACEC,EAIAC,IACG,CACG,MAAAV,EAA0BS,GAAmC,CAAC,EACpE,OAAQC,EAAK,OAAQ,CACnB,IAAK,gBACH,GAAIA,EAAK,QAAU,oBAAqBA,EAAK,OAAQ,CACnD,MAAMC,EAGFC,EAAA,SACFZ,EAAwB,OACtB,CAACa,EAAeC,IACV,oBAAqBA,EAChB,CAAC,GAAGD,EAAe,GAAGC,EAAa,eAAe,EAElD,CACL,GAAGD,EACHV,EAAsCW,CAAY,CACpD,EAGJ,CAAA,CACF,EACAZ,EAAAA,OACF,EAEAM,EAASG,EAAiBD,CAAI,CAAA,MAErBF,EAAAF,EAAoBN,CAAuB,EAAGU,CAAI,EAE7D,MACF,IAAK,kBACCA,EAAK,QAAU,oBAAqBA,EAAK,OAC3CF,EACEV,EACEY,EAAK,OACLJ,EAAoBN,CAAuB,CAC7C,EACAU,CACF,EAESF,EAAAF,EAAoBN,CAAuB,EAAGU,CAAI,EAE7D,MACF,IAAK,eACL,IAAK,YACCA,EAAK,cAAgB,oBAAqBA,EAAK,aACjDF,EACEV,EACEY,EAAK,aACLJ,EAAoBN,CAAuB,CAC7C,EACAU,CACF,EAESF,EAAAF,EAAoBN,CAAuB,EAAGU,CAAI,EAE7D,MACF,IAAK,QACHF,EACER,EAAwB,IAAIG,CAAqC,EACjEO,CACF,EACA,MACF,IAAK,gBACHF,EACER,EAAwB,IAAIG,CAAqC,EACjEO,CACF,EACA,KAEA,CAEN,EAEWK,EACX5B,GAEOA,EAAQ,OACb,CAAC0B,EAAeC,IACP,CACL,GAAGD,EACHG,EAA6CF,CAAY,EACzD,GAAGA,EAAa,QAAQ,IAAIG,CAAqC,CACnE,EAEF,CAAA,CACF,EAGWC,EAA8B,CACzC/B,EACAgC,IACoC,CACpC,GAAI,CAACA,EACH,MAAO,CAAC,EAEV,MAAMR,EAAmD,CAAC,EAClD,OAAAxB,EAAA,QAASiC,GAAW,CACtBC,EAAiBD,EAAO,QAASD,CAAM,GACzBR,EAAA,KACdK,EAA6CI,CAAM,CACrD,EAEcT,EAAA,KACd,GAAGW,EAAAA,iBAAiBF,EAAO,QAASD,EAAQjB,EAAAA,OAAO,EAAE,IAAKkB,GACxDH,EAAsCG,CAAM,CAAA,CAEhD,CAAA,CACD,EACMT,CACT,EAEaU,EAAmB,CAC9BlC,EACAoC,IAEKA,EAKHD,EAAAA,iBAAiBnC,EAASoC,EAAgBrB,EAAO,OAAA,EAAE,SAAWf,EAAQ,OAJ/D,GAQE8B,EACXG,IACmC,CACnC,KAAMA,EAAO,KACb,MAAOA,EAAO,MACd,MAAOA,EAAO,KAChB,GAGaJ,EACXI,IACmC,CACnC,KAAMA,EAAO,MACb,MAAOA,EAAO,MACd,MAAOA,EAAO,MACd,gBAAiBA,EAAO,OAC1B,GAEajB,EACXiB,IAC2B,CAC3B,KAAMA,EAAO,KACb,MAAOA,EAAO,MACd,MAAOA,EAAO,KAChB,GC7IMI,EAAmB,CACvBC,EACArF,IAEAA,EACIqF,EAAM,KAAK,2BACXA,EAAM,KAAK,sBAEjB,SAASC,GACP5C,EAKA,CACA,KAAM,CAAE,iBAAA6C,EAAkB,kBAAAC,CAAkB,EAAI9C,EAAM,YAElD,MAAA,oBAAqBA,EAAM,KACtB6C,EACHA,EAAiB,CACf,MAAO7C,EAAM,KAAK,MAClB,QAASA,EAAM,KAAK,eAAA,CACrB,EACDA,EAAM,MAGL8C,EACHA,EAAkB9C,EAAM,KAAM,CAC5B,QAAS,OACT,WAAYA,EAAM,YAAY,YAAc,GAC5C,YAAaA,EAAM,SAAS,CAAA,CAC7B,EACDA,EAAM,KACZ,CAEO,SAAS+C,EAA0B,CACxC,SAAArB,EACA,QAAArB,EACA,MAAA2C,EACA,QAAAvF,EAAU,WAEV,iBAAAoF,EACA,kBAAAC,EACA,GAAGpE,CACL,EAEE,CACM,MAAAuE,EACJjD,GAKG,CACG,MAAAkD,EAAQN,GAAuB5C,CAAK,EACpCmD,EAAgB,oBAAqBnD,EAAM,KAEjD,aACGH,aAAW,OAAX,CAAmB,GAAGG,EACrB,gBAACoD,MACE,CAAA,SAAA,CAAC,CAAAD,SAAkBE,EAAM,MAAA,EAAA,EAC1BjE,EAAA,IAACkE,GAAA,CACC,MAAOtG,EACP,KAAOmG,EAA0B,OAAV,QACvB,MAAAD,EACA,SAAUlD,EAAM,WAChB,QAASA,EAAM,SAAA,CAAA,CACjB,CAAA,CACF,CACF,CAAA,CAEJ,EAEMT,EACJS,GAMS,oBAAqBA,EAAM,KAEhC,KADFZ,EAAAA,IAACS,aAAW,WAAX,CAAuB,GAAGG,CAAA,CAAO,EAIhCuD,EAAgBlD,EAClB+B,EAA4B/B,EAAS2C,CAAK,EAC1C,OACEQ,EAAkBnD,EACpB4B,EAA+C5B,CAAO,EACtD,OAGF,OAAAjB,EAAA,IAACQ,EAAA,CACE,GAAGlB,EACJ,SAAUgD,EAAWD,EAAsBC,CAAQ,EAAI,OACvD,oBAAqB,GACrB,WAAY,CACV,GAAGhD,EAAY,WACf,WAAAa,EACA,OAAA0D,CACF,EACA,QAAS,GACT,QAASO,EACT,MAAOD,EACP,QAAA9F,CAAA,CACF,CAEJ,CAUA,MAAM6F,GAA0C,CAAC,CAC/C,QAAAG,EACA,MAAAP,EACA,SAAAQ,EACA,KAAAC,EACA,MAAAhB,CACF,WACGS,MAAI,CAAA,WAAY,SAAU,eAAgB,gBAAiB,SAAU,EACpE,SAAA,CAAAhE,MAACwE,EAAAA,MAAK,SAAU,GAAI,KAAAD,EAAY,MAAO,eACpC,SACHT,EAAA,EACCQ,GACCtE,EAAA,IAACyE,EAAA,KAAA,CACC,MAAOnB,EAAiBC,EAAOc,CAAO,EACtC,KAAMK,EAAA,WACN,KAAM,EAAA,CAAA,CACR,EAEJ,ECnLK,SAASC,GAAmB,CACjC,QAAAtG,EAAU,WACV,OAAAc,EACA,WAAAsB,EACA,eAAAmE,EAAiB,QACjB,GAAGtF,CACL,EAA4B,CACpB,MAAAC,EAAeC,EAAAA,QAAQ,IAAM,CAC3B,MAAAC,EAAeL,EAAkCf,CAAO,EAE9D,OAAOc,EAASO,EAAA,YAAYD,EAAcN,CAAM,EAAIM,CAAA,EACnD,CAACpB,EAASc,CAAM,CAAC,EAEdU,EACJe,GACGZ,EAAAA,IAAC2B,eAAY,aAAYiD,EAAgB,QAAShE,EAAM,UAAY,CAAA,EAGvE,OAAAZ,EAAA,IAAC6E,EAAA,CACC,OAAQtF,EACR,WAAY,CAAE,GAAGkB,EAAY,eAAAZ,CAAe,EAC3C,GAAGP,EACJ,QAAS,EAAA,CACX,CAEJ,CC7BO,SAASwF,EAAoC,CAClD,MAAAlB,EACA,cAAAmB,EACA,kBAAAC,EAAoB,OACpB,SAAA3D,CACF,EAAmD,CAE/C,OAAAF,EAAA,KAAC8D,EAAO,OAAA,CAAA,KAAM,EACZ,SAAA,CAAC9D,EAAAA,KAAA6C,EAAAA,IAAA,CAAI,SAAU,OACZ,SAAA,CAAAJ,GAAA,YAAAA,EAAO,IAAKsB,GACX/D,EAAAA,KAAC6C,EAAAA,IACC,CAAA,SAAA,CAAChE,EAAAA,IAAAmF,EAAAA,QAAA,CAAQ,IAAK,GACZ,SAAAnF,EAAA,IAACM,EAAA,KAAA,CACC,MAAO4E,EAAE,MACT,cAAe,IACbH,GAAA,YAAAA,GACEnB,GAAA,YAAAA,EAAO,OAAQwB,GAAMA,EAAE,QAAUF,EAAE,SAAU,CAAA,EAC/C,CAAA,EAGN,QACCjB,EAAM,MAAA,CAAA,CAAA,CAAA,GAXCiB,EAAE,KAYZ,GAEDtB,GAAA,MAAAA,EAAO,OACL5D,MAAAmF,EAAAA,QAAA,CAAQ,IAAK,GACZ,SAAAnF,EAAA,IAACqF,EAAA,WAAA,CACC,KAAM,QACN,MAAO,QACP,QAAS,IAAMN,GAAA,YAAAA,EAAgB,CAAE,EAAA,CAAA,CAErC,CAAA,EAEC/E,EAAAA,IAAAmF,EAAAA,QAAA,CAAQ,IAAK,GACZ,SAACnF,EAAA,IAAAM,EAAA,KAAA,CAAK,QAAS,YAAa,MAAO0E,CAAmB,CAAA,CACxD,CAAA,CAAA,EAEJ,EACAhF,EAAAA,IAACiE,EAAM,MAAA,CAAA,IAAK,EAAK,CAAA,EAChB5C,CAAA,EACH,CAEJ,CC9BA,SAASiE,GAAwD,CAC/D,MAAA1B,EACA,cAAAmB,EACA,YAAAQ,EAAc,iBACd,QAAAC,EACA,WAAAC,EACA,cAAAC,EACA,kBAAAV,EAAoB,OACpB,GAAG1F,CACL,EAAkC,CAE9B,OAAAU,EAAA,IAAC8E,EAAA,CACC,kBAAAE,EACA,cAAAD,EACA,MAAAnB,EAEA,SAAA5D,EAAA,IAACQ,EAAA,CACE,GAAGlB,EACJ,YAAa,GACb,MAAAsE,EACA,SACEmB,EAAiBnB,GAAUmB,EAAc,CAAC,GAAGnB,CAAK,CAAC,EAAI,OAEzD,sBAAuB,GACvB,oBAAmB,GACnB,yBAA0B,GAC1B,YAAA2B,EACA,UAAWC,EACX,WAAAC,EACA,cAAAC,CAAA,CAAA,CACF,CACF,CAEJ,CAEO,MAAMC,GAAkBC,EAAM,KACnCN,EACF,EC1CA,SAASO,GAA+B,CACtC,MAAAjC,EACA,cAAAmB,EACA,YAAAQ,EAAc,iBACd,QAAAC,EACA,WAAAC,EACA,cAAAC,EACA,kBAAAV,EAAoB,OACpB,GAAG1F,CACL,EAAuC,CAEnC,OAAAU,EAAA,IAAC8E,EAAA,CACC,kBAAAE,EACA,cAAAD,EACA,MAAAnB,EAEA,SAAA5D,EAAA,IAAC2D,EAAA,CACE,GAAGrE,EACJ,YAAa,GACb,MAAAsE,EACA,SACEmB,EAAiBnB,GAAUmB,EAAc,CAAC,GAAGnB,CAAK,CAAC,EAAI,OAEzD,sBAAuB,GACvB,oBAAmB,GACnB,yBAA0B,GAC1B,YAAA2B,EACA,UAAWC,EACX,WAAAC,EACA,cAAAC,CAAA,CAAA,CACF,CACF,CAEJ,CAEO,MAAMI,GAAyBF,EAAM,KAC1CC,EACF"}
1
+ {"version":3,"file":"index.js","sources":["../src/SelectTheme.ts","../src/util/StylesBuilder.ts","../src/components/ui/AsyncMultiSelect.tsx","../src/components/ui/AsyncSelect.tsx","../src/components/ui/MultiSelect.tsx","../src/components/ui/OverflowingMultiSelect.tsx","../src/components/ui/Select.tsx","../src/util/multiDropdownUtils.ts","../src/components/ui/GroupedMultiSelect.tsx","../src/components/ui/CreatableSelect.tsx","../src/components/ui/ChipMultiSelect/ChipRow.tsx","../src/components/ui/ChipMultiSelect/ChipMultiSelect.tsx","../src/components/ui/ChipMultiSelect/GroupedChipMultiSelect.tsx"],"sourcesContent":["import { Property } from \"csstype\";\nimport { cssColor } from \"@stenajs-webui/theme\";\n\nexport interface SelectTheme {\n arrowColor: {\n disabled: string;\n focused: {\n standard: string;\n hover: string;\n };\n closed: {\n standard: string;\n hover: string;\n };\n };\n clearButtonColor: {\n standard: string;\n hover: string;\n };\n input: {\n backgroundColor: string;\n border: string;\n borderColor: string;\n disabledBorderColor: string;\n borderColorFocused: string;\n borderRadius: string;\n disabledBackgroundColor: string;\n warningBackgroundColor: string;\n errorBackgroundColor: string;\n successBackgroundColor: string;\n warningBorderColor: string;\n errorBorderColor: string;\n successBorderColor: string;\n boxShadowFocused: string;\n fontFamily: string;\n fontSize: string;\n height?: string;\n minHeight?: string;\n placeholderColor: string;\n textColor: string;\n };\n loadingIndicator: {\n textColor: string;\n };\n menu: {\n disabledTextColor: string;\n disabledBackgroundColor: string;\n textColor: string;\n backgroundColor: string;\n hoverTextColor: string;\n hoverBackgroundColor: string;\n activeTextColor: string;\n activeBackgroundColor: string;\n minWidth?: string;\n selectedItemTextColor: string;\n selectedItemBackgroundColor: string;\n selectedItemHoverTextColor: string;\n selectedItemIconColor: string;\n selectedItemHoverIconColor: string;\n selectedItemHoverBackgroundColor: string;\n selectedItemActiveTextColor: string;\n selectedItemActiveBackgroundColor: string;\n zIndex: number;\n width?: string;\n whiteSpace?: Property.WhiteSpace;\n };\n groupHeading: {\n fontSize: string;\n lineHeight: string;\n fontWeight: string;\n color: string;\n letterSpacing: string;\n };\n menuPortal: {\n zIndex: number;\n };\n multiSelect: {\n backgroundColor: string;\n textColor: string;\n removeButtonBackgroundColor: string;\n removeButtonTextColor: string;\n removeButtonHoverBackgroundColor: string;\n removeButtonHoverTextColor: string;\n };\n}\n\nexport const defaultSelectTheme: SelectTheme = {\n arrowColor: {\n disabled: cssColor(\"--silver-light\"),\n focused: {\n hover: cssColor(\"--lhds-color-blue-600\"),\n standard: cssColor(\"--lhds-color-blue-600\"),\n },\n closed: {\n hover: cssColor(\"--lhds-color-blue-600\"),\n standard: cssColor(\"--lhds-color-blue-600\"),\n },\n },\n clearButtonColor: {\n hover: cssColor(\"--lhds-color-red-600\"),\n standard: cssColor(\"--lhds-color-red-500\"),\n },\n input: {\n backgroundColor: \"var(--swui-field-bg-enabled)\",\n border: `1px solid var(--swui-select-border-color)`,\n borderColor: \"var(--swui-field-border-color)\",\n borderColorFocused: \"var(--swui-field-border-color-hover)\",\n disabledBackgroundColor: \"var(--swui-field-bg-disabled)\",\n disabledBorderColor: \"var(--swui-field-bg-disabled)\",\n warningBackgroundColor: \"var(--swui-state-alert-light-color)\",\n warningBorderColor: \"var(--swui-state-alert-light-color)\",\n errorBackgroundColor: \"var(--swui-state-error-light-color)\",\n errorBorderColor: \"var(--swui-state-error-light-color)\",\n successBackgroundColor: \"var(--swui-state-success-light-color)\",\n successBorderColor: \"var(--swui-state-success-light-color)\",\n boxShadowFocused: \"none\",\n fontFamily: \"var(--swui-font-primary)\",\n fontSize: \"var(--swui-font-size-inputs)\",\n minHeight: \"24px\",\n placeholderColor: \"var(--swui-field-text-color)\",\n textColor: \"var(--swui-field-text-color)\",\n borderRadius: \"var(--swui-field-border-radius)\",\n },\n loadingIndicator: {\n textColor: \"var(--swui-field-text-color)\",\n },\n groupHeading: {\n fontSize: \"var(--swui-font-size-small)\",\n lineHeight: \"var(--swui-line-height-smaller)\",\n fontWeight: \"var(--swui-font-weight-text-bold)\",\n color: cssColor(\"--lhds-color-ui-600\"),\n letterSpacing: \"0.1rem\",\n },\n menu: {\n activeBackgroundColor: cssColor(\"--lhds-color-blue-100\"),\n activeTextColor: \"var(--swui-field-text-color)\",\n selectedItemActiveBackgroundColor: cssColor(\"--lhds-color-blue-500\"),\n selectedItemActiveTextColor: cssColor(\"--lhds-color-blue-50\"),\n disabledTextColor: \"var(--swui-field-text-color-disabled)\",\n disabledBackgroundColor: \"var(--swui-field-bg-disabled)\",\n textColor: \"var(--swui-field-text-color)\",\n backgroundColor: \"var(--swui-field-bg-enabled)\",\n hoverTextColor: \"var(--swui-field-text-color)\",\n hoverBackgroundColor: cssColor(\"--lhds-color-blue-200\"),\n selectedItemTextColor: cssColor(\"--lhds-color-blue-500\"),\n selectedItemIconColor: cssColor(\"--lhds-color-blue-500\"),\n selectedItemHoverTextColor: \"var(--swui-field-text-color)\",\n selectedItemHoverIconColor: \"var(--swui-field-text-color)\",\n selectedItemBackgroundColor: cssColor(\"--lhds-color-blue-50\"),\n selectedItemHoverBackgroundColor: cssColor(\"--lhds-color-blue-50\"),\n zIndex: 1,\n width: \"auto\",\n minWidth: \"100%\",\n whiteSpace: \"nowrap\",\n },\n menuPortal: {\n zIndex: 1,\n },\n multiSelect: {\n backgroundColor: \"var(--swui-primary-action-color)\",\n textColor: cssColor(\"--lhds-color-blue-50\"),\n removeButtonBackgroundColor: \"transparent\",\n removeButtonTextColor: \"var(--swui-white)\",\n removeButtonHoverBackgroundColor: \"var(--swui-primary-action-color-hover)\",\n removeButtonHoverTextColor: \"var(--swui-white)\",\n },\n};\n","import { StylesConfig } from \"react-select\";\nimport { defaultSelectTheme, SelectTheme } from \"../SelectTheme\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\nimport { Property } from \"csstype\";\n\nexport type SelectVariant = \"standard\" | \"warning\" | \"error\" | \"success\";\n\nconst resolveOptionBackgroundColor = (\n colors: SelectTheme[\"menu\"],\n isDisabled: boolean,\n isSelected: boolean,\n isFocused: boolean,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledBackgroundColor;\n } else if (isSelected && isFocused) {\n return colors.selectedItemHoverBackgroundColor;\n } else if (isSelected) {\n return colors.selectedItemBackgroundColor;\n } else if (isFocused) {\n return colors.hoverBackgroundColor;\n } else {\n return undefined;\n }\n};\n\nconst resolveOptionColor = (\n colors: SelectTheme[\"menu\"],\n isDisabled: boolean,\n isSelected: boolean,\n isFocused: boolean,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledTextColor;\n } else if (isSelected && isFocused) {\n return colors.selectedItemHoverTextColor;\n } else if (isSelected) {\n return colors.selectedItemTextColor;\n } else if (isFocused) {\n return colors.hoverTextColor;\n } else {\n return undefined;\n }\n};\n\nconst resolveInputBackgroundColor = (\n colors: SelectTheme[\"input\"],\n isDisabled: boolean,\n isFocused: boolean,\n variant: SelectVariant | undefined,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledBackgroundColor;\n } else if (isFocused) {\n return colors.backgroundColor;\n } else if (variant === \"warning\") {\n return colors.warningBackgroundColor;\n } else if (variant === \"success\") {\n return colors.successBackgroundColor;\n } else if (variant === \"error\") {\n return colors.errorBackgroundColor;\n } else {\n return colors.backgroundColor;\n }\n};\n\nconst resolveInputBorderColor = (\n colors: SelectTheme[\"input\"],\n isDisabled: boolean,\n isFocused: boolean,\n isHovered: boolean,\n variant: SelectVariant | undefined,\n): string | undefined => {\n if (isDisabled) {\n return colors.disabledBorderColor;\n } else if (isFocused) {\n return colors.borderColorFocused;\n } else if (variant === \"warning\") {\n return colors.warningBorderColor;\n } else if (variant === \"success\") {\n return colors.successBorderColor;\n } else if (variant === \"error\") {\n return colors.errorBorderColor;\n } else if (isHovered) {\n return colors.borderColorFocused;\n } else {\n return colors.borderColor;\n }\n};\n\n/**\n * @deprecated\n */\nexport const createStylesFromTheme = <\n OptionType,\n IsMulti extends boolean,\n TGroup extends GroupBase<OptionType> = GroupBase<OptionType>,\n>(\n {\n menu,\n menuPortal,\n input,\n multiSelect,\n clearButtonColor,\n arrowColor,\n groupHeading,\n loadingIndicator,\n }: SelectTheme,\n variant: SelectVariant | undefined,\n): StylesConfig<OptionType, IsMulti, TGroup> => ({\n option: (base, { isDisabled, isFocused, isSelected }) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n backgroundColor: resolveOptionBackgroundColor(\n menu,\n isDisabled,\n isSelected,\n isFocused,\n ),\n color: resolveOptionColor(menu, isDisabled, isSelected, isFocused),\n cursor: isDisabled ? \"not-allowed\" : \"default\",\n whiteSpace: menu.whiteSpace || base.whiteSpace,\n \":active\": {\n backgroundColor: isDisabled\n ? undefined\n : isSelected\n ? menu.selectedItemActiveBackgroundColor\n : menu.activeBackgroundColor,\n color: isDisabled\n ? undefined\n : isSelected\n ? menu.selectedItemActiveTextColor\n : menu.activeTextColor,\n },\n }),\n control: (base, { isFocused, isDisabled, menuIsOpen }) => ({\n ...base,\n // none of react-selects styles are passed to <View />\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n minHeight: \"var(--swui-field-height)\",\n backgroundColor: resolveInputBackgroundColor(\n input,\n isDisabled,\n isFocused,\n variant,\n ),\n borderRadius: input.borderRadius,\n border: input.border,\n \"--swui-select-border-color\": resolveInputBorderColor(\n input,\n isDisabled,\n isFocused || menuIsOpen,\n false,\n variant,\n ),\n outline: isFocused ? \"var(--swui-focus-outline)\" : undefined,\n outlineOffset: isFocused ? \"-1px\" : undefined,\n transition: \"none\",\n boxShadow: isFocused ? input.boxShadowFocused : undefined,\n \"&:hover\": {\n \"--swui-select-border-color\": resolveInputBorderColor(\n input,\n false,\n isFocused || menuIsOpen,\n true,\n variant,\n ),\n },\n }),\n singleValue: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n color: input.textColor,\n }),\n noOptionsMessage: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n }),\n input: (base) => ({\n ...base,\n padding: 0,\n margin: 0,\n minHeight: input.minHeight,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n color: input.textColor,\n }),\n groupHeading: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: groupHeading.fontSize,\n lineHeight: groupHeading.lineHeight,\n fontWeight: groupHeading.fontWeight as Property.FontWeight,\n color: groupHeading.color,\n letterSpacing: groupHeading.letterSpacing,\n }),\n multiValueLabel: (base) => ({\n ...base,\n backgroundColor: multiSelect.backgroundColor,\n color: multiSelect.textColor,\n fontFamily: input.fontFamily,\n fontSize: groupHeading.fontSize,\n }),\n indicatorSeparator: (base) => ({\n ...base,\n display: \"none\",\n }),\n clearIndicator: (base) => ({\n ...base,\n padding: \"5px\",\n color: clearButtonColor.standard,\n \"&:hover\": {\n color: clearButtonColor.hover,\n },\n cursor: \"pointer\",\n }),\n placeholder: (base) => ({\n ...base,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n color: input.placeholderColor,\n }),\n container: (base) => ({\n ...base,\n }),\n valueContainer: (base) => ({\n ...base,\n padding: \"var(--swui-metrics-space-half) var(--swui-metrics-space)\",\n gap: \"var(--swui-metrics-space-half)\",\n }),\n dropdownIndicator: (base, { isFocused, isDisabled }) => ({\n ...base,\n padding: \"5px\",\n color: isDisabled\n ? arrowColor.disabled\n : isFocused\n ? arrowColor.focused.standard\n : arrowColor.closed.standard,\n \"&:hover\": {\n color: isDisabled\n ? arrowColor.disabled\n : isFocused\n ? arrowColor.focused.hover\n : arrowColor.closed.hover,\n },\n svg: {\n width: 14,\n height: 14,\n },\n }),\n menu: (base) => ({\n ...base,\n backgroundColor: menu.backgroundColor,\n color: menu.textColor,\n minWidth: menu.minWidth || base.minWidth,\n zIndex: menu.zIndex,\n width: menu.width || base.width,\n border: input.border,\n borderColor: input.borderColorFocused,\n }),\n menuPortal: (base) => ({\n ...base,\n zIndex: menuPortal.zIndex,\n }),\n multiValueRemove: (styles) => ({\n ...styles,\n backgroundColor: multiSelect.removeButtonBackgroundColor,\n \":hover\": {\n color: multiSelect.removeButtonHoverTextColor,\n backgroundColor: multiSelect.removeButtonHoverBackgroundColor,\n },\n color: multiSelect.removeButtonTextColor,\n borderRadius: \"50%\",\n width: 16,\n height: 16,\n padding: 0,\n margin: 3,\n marginTop: 4,\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n cursor: \"pointer\",\n }),\n multiValue: (base) => ({\n ...base,\n backgroundColor: multiSelect.backgroundColor,\n color: multiSelect.textColor,\n fontFamily: input.fontFamily,\n fontSize: groupHeading.fontSize,\n alignItems: \"center\",\n margin: 0,\n borderRadius: \"var(--swui-border-radius-small)\",\n overflow: \"hidden\",\n }),\n loadingMessage: (base) => ({\n ...base,\n color: loadingIndicator.textColor,\n fontFamily: input.fontFamily,\n fontSize: input.fontSize,\n }),\n});\n\nexport const createStylesFromVariant = <\n OptionType,\n IsMulti extends boolean,\n TGroup extends GroupBase<OptionType> = GroupBase<OptionType>,\n>(\n variant: SelectVariant,\n): StylesConfig<OptionType, IsMulti, TGroup> =>\n createStylesFromTheme(defaultSelectTheme, variant);\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport { mergeStyles } from \"react-select\";\nimport AsyncComponent, { AsyncProps } from \"react-select/async\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\n\nexport interface AsyncMultiSelectProps<T = { label: string; value: string }>\n extends AsyncProps<T, true, GroupBase<T>> {\n variant?: SelectVariant;\n isMulti?: true;\n}\n\nexport function AsyncMultiSelect<T>({\n variant = \"standard\",\n styles,\n ...selectProps\n}: AsyncMultiSelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, true>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n return (\n <AsyncComponent styles={selectStyles} {...selectProps} isMulti={true} />\n );\n}\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport AsyncComponent, { AsyncProps } from \"react-select/async\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { mergeStyles } from \"react-select\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\n\nexport interface AsyncSelectProps<T = { label: string; value: string }>\n extends AsyncProps<T, false, GroupBase<T>> {\n variant?: SelectVariant;\n isMulti?: false;\n}\n\nexport function AsyncSelect<T>({\n variant = \"standard\",\n styles,\n ...selectProps\n}: AsyncSelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, false>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n return (\n <AsyncComponent styles={selectStyles} {...selectProps} isMulti={false} />\n );\n}\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport SelectComponent, {\n ClearIndicatorProps,\n GroupBase,\n mergeStyles,\n MultiValueProps,\n Props,\n SelectComponentsConfig,\n} from \"react-select\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { Chip, stenaTimes, TextInputButton } from \"@stenajs-webui/elements\";\n\nexport interface MultiSelectOption {\n label: string;\n value: string;\n}\n\nexport interface MultiSelectProps<\n TOption extends MultiSelectOption = MultiSelectOption,\n> extends Props<TOption, true> {\n variant?: SelectVariant;\n isMulti?: true;\n}\n\nexport type MultiSelectComponentsConfig<TOption> = SelectComponentsConfig<\n TOption,\n true,\n GroupBase<TOption>\n>;\n\nconst ClearIndicator = function <TOption>({\n clearValue,\n}: ClearIndicatorProps<TOption, true, GroupBase<TOption>>) {\n return (\n // stopPropagation is needed to prevent react-select from opening its menu when clicking on the button.\n <div onMouseDown={(ev) => ev.stopPropagation()}>\n <TextInputButton\n aria-label={\"Clear\"}\n onClick={clearValue}\n icon={stenaTimes}\n variant={\"error\"}\n />\n </div>\n );\n};\n\nconst MultiValue = function <TOption extends MultiSelectOption>({\n removeProps,\n data,\n}: MultiValueProps<TOption, true, GroupBase<TOption>>) {\n return (\n // stopPropagation is needed to prevent react-select from opening its menu when clicking on the button.\n <div onMouseDown={(ev) => ev.stopPropagation()}>\n <Chip\n onClickRemove={(ev) =>\n removeProps.onClick?.(\n ev as unknown as React.MouseEvent<HTMLDivElement>,\n )\n }\n label={data.label}\n />\n </div>\n );\n};\n\nexport function MultiSelect<TOption extends MultiSelectOption>({\n variant = \"standard\",\n styles,\n components,\n ...selectProps\n}: MultiSelectProps<TOption>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<TOption, true>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n return (\n <SelectComponent\n styles={selectStyles}\n components={{ ...components, ClearIndicator, MultiValue }}\n {...selectProps}\n isMulti={true}\n />\n );\n}\n","import * as React from \"react\";\nimport { memo, ReactElement } from \"react\";\nimport {\n MultiSelect,\n MultiSelectOption,\n MultiSelectProps,\n} from \"./MultiSelect\";\nimport { components, ValueContainerProps } from \"react-select\";\n\nexport function OverflowingMultiSelect<T extends MultiSelectOption>(\n props: MultiSelectProps<T>,\n) {\n return (\n <MultiSelect\n hideSelectedOptions={false}\n {...props}\n components={{\n ...props.components,\n ValueContainer: FirstValueOnlyValueContainer,\n }}\n />\n );\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nconst FirstValueOnlyValueContainer = memo(\n (props: ValueContainerProps<any, true>) => {\n const [prevOptions, ...restChildren] = props.children as [\n ReactElement[] | null | undefined,\n ReactElement[] | null | undefined,\n ];\n\n const options = getOptionsToRender(prevOptions, props);\n\n return (\n <components.ValueContainer {...props}>\n {options}\n {restChildren}\n </components.ValueContainer>\n );\n },\n);\n\nconst getOptionsToRender = (\n optionElements: ReactElement[] | null | undefined,\n {\n /* eslint-disable @typescript-eslint/no-unused-vars */\n children,\n innerProps,\n className,\n ...spreadProps\n }: ValueContainerProps<any, true>,\n) => {\n if (!optionElements) {\n return null;\n }\n\n if (optionElements.length > 1) {\n return [\n optionElements[0],\n <components.MultiValue\n {...spreadProps}\n key={\"DUMMY_VALUE_FOR_PLUS_X\"}\n innerProps={{}}\n data={null}\n isFocused={false}\n removeProps={{}}\n index={1}\n components={{\n Container: components.MultiValueContainer,\n Label: components.MultiValueLabel,\n Remove: () => <div style={{ height: 16, margin: 3, marginTop: 4 }} />,\n }}\n >\n {\"+\" + (optionElements.length - 1)}\n </components.MultiValue>,\n ];\n } else {\n return optionElements;\n }\n};\n","import * as React from \"react\";\nimport { useMemo } from \"react\";\nimport SelectComponent, {\n ClearIndicatorProps,\n GroupBase,\n mergeStyles,\n Props,\n} from \"react-select\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\nimport { CloseButton } from \"@stenajs-webui/elements\";\n\nexport interface SelectProps<T = { label: string; value: string }>\n extends Props<T, false> {\n variant?: SelectVariant;\n isMulti?: false;\n}\n\nexport function Select<T>({\n variant = \"standard\",\n styles,\n components,\n ...selectProps\n}: SelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, false>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n const ClearIndicator = (\n props: ClearIndicatorProps<T, false, GroupBase<T>>,\n ) => <CloseButton aria-label={\"Clear\"} onClick={props.clearValue} />;\n\n return (\n <SelectComponent\n styles={selectStyles}\n components={{ ...components, ClearIndicator }}\n {...selectProps}\n isMulti={false}\n />\n );\n}\n","import { differenceWith, intersectionWith, isEqual, uniqWith } from \"lodash-es\";\nimport { ActionMeta, GroupBase, OnChangeValue, Options } from \"react-select\";\nimport { OnChange } from \"../components/ui/GroupedMultiSelect\";\nimport { DropdownOption } from \"../components/ui/GroupedMultiSelectTypes\";\n\nexport type GroupedOptionsType<TOption> = ReadonlyArray<GroupBase<TOption>>;\n\nexport type InternalDropdownOption<TData> =\n | InternalChildOption<TData>\n | InternalParentDropdownOption<TData>;\n\ninterface InternalChildOption<TData> {\n data: TData;\n label: string;\n value: string;\n}\n\ninterface InternalParentDropdownOption<TData> {\n data: TData;\n label: string;\n value: string;\n internalOptions: Options<DropdownOption<TData>>;\n}\n\nconst removeGroupedOptionsType = <TData>(\n removedValue: InternalParentDropdownOption<TData>,\n selectedInternalOptions: Options<InternalDropdownOption<TData>>,\n): Options<InternalDropdownOption<TData>> =>\n differenceWith(\n selectedInternalOptions,\n [...removedValue.internalOptions, removedValue],\n isEqual,\n ).map(convertInternalOptionToDropdownOption);\n\nconst removeInternalOptions = <TData>(\n selectedInternalOption: InternalDropdownOption<TData>,\n): boolean => !(\"internalOptions\" in selectedInternalOption);\n\nconst removeOptionHeaders = <TData>(\n selectedInternalOptions: Options<InternalDropdownOption<TData>>,\n): Options<InternalDropdownOption<TData>> =>\n selectedInternalOptions\n .filter(removeInternalOptions)\n .map(convertInternalOptionToDropdownOption);\n\nexport const createOnChange =\n <TData>(onChange: OnChange<TData>) =>\n (\n incomingSelectedInternalOptions: OnChangeValue<\n InternalDropdownOption<TData>,\n true\n >,\n meta: ActionMeta<InternalDropdownOption<TData>>,\n ) => {\n const selectedInternalOptions = incomingSelectedInternalOptions ?? [];\n switch (meta.action) {\n case \"select-option\":\n if (meta.option && \"internalOptions\" in meta.option) {\n const selectedOptions: OnChangeValue<\n InternalDropdownOption<TData>,\n true\n > = uniqWith(\n selectedInternalOptions.reduce<Options<DropdownOption<TData>>>(\n (previousValue, currentValue) => {\n if (\"internalOptions\" in currentValue) {\n return [...previousValue, ...currentValue.internalOptions];\n } else {\n return [\n ...previousValue,\n convertInternalOptionToDropdownOption(currentValue),\n ];\n }\n },\n [],\n ),\n isEqual,\n );\n\n onChange(selectedOptions, meta);\n } else {\n onChange(removeOptionHeaders(selectedInternalOptions), meta);\n }\n break;\n case \"deselect-option\":\n if (meta.option && \"internalOptions\" in meta.option) {\n onChange(\n removeGroupedOptionsType(\n meta.option,\n removeOptionHeaders(selectedInternalOptions),\n ),\n meta,\n );\n } else {\n onChange(removeOptionHeaders(selectedInternalOptions), meta);\n }\n break;\n case \"remove-value\":\n case \"pop-value\":\n if (meta.removedValue && \"internalOptions\" in meta.removedValue) {\n onChange(\n removeGroupedOptionsType(\n meta.removedValue,\n removeOptionHeaders(selectedInternalOptions),\n ),\n meta,\n );\n } else {\n onChange(removeOptionHeaders(selectedInternalOptions), meta);\n }\n break;\n case \"clear\":\n onChange(\n selectedInternalOptions.map(convertInternalOptionToDropdownOption),\n meta,\n );\n break;\n case \"create-option\":\n onChange(\n selectedInternalOptions.map(convertInternalOptionToDropdownOption),\n meta,\n );\n break;\n default:\n break;\n }\n };\n\nexport const convertGroupedDropdownOptionsToInternalOptions = <TData>(\n options: GroupedOptionsType<DropdownOption<TData>>,\n): InternalDropdownOption<TData>[] => {\n return options.reduce<InternalDropdownOption<TData>[]>(\n (previousValue, currentValue) => {\n return [\n ...previousValue,\n convertGroupedDropdownOptionToInternalOption(currentValue),\n ...currentValue.options.map(convertDropdownOptionToInternalOption),\n ];\n },\n [],\n );\n};\n\nexport const convertValueToInternalValue = <TData>(\n options: GroupedOptionsType<DropdownOption<TData>>,\n values: Options<DropdownOption<TData>> | undefined,\n): InternalDropdownOption<TData>[] => {\n if (!values) {\n return [];\n }\n const selectedOptions: InternalDropdownOption<TData>[] = [];\n options.forEach((option) => {\n if (allOptionsExists(option.options, values)) {\n selectedOptions.push(\n convertGroupedDropdownOptionToInternalOption(option),\n );\n }\n selectedOptions.push(\n ...intersectionWith(option.options, values, isEqual).map((option) =>\n convertDropdownOptionToInternalOption(option),\n ),\n );\n });\n return selectedOptions;\n};\n\nexport const allOptionsExists = <TData>(\n options: Options<DropdownOption<TData>>,\n selectedValues: Options<DropdownOption<TData>> | undefined,\n): boolean => {\n if (!selectedValues) {\n return false;\n }\n\n return (\n intersectionWith(options, selectedValues, isEqual).length === options.length\n );\n};\n\nexport const convertDropdownOptionToInternalOption = <TData>(\n option: DropdownOption<TData>,\n): InternalDropdownOption<TData> => ({\n data: option.data,\n label: option.label,\n value: option.value,\n});\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nexport const convertGroupedDropdownOptionToInternalOption = <TData>(\n option: GroupBase<DropdownOption<TData>>,\n): InternalDropdownOption<TData> => ({\n data: option.label as any,\n label: option.label as any,\n value: option.label as any,\n internalOptions: option.options,\n});\n\nexport const convertInternalOptionToDropdownOption = <TData>(\n option: InternalDropdownOption<TData>,\n): DropdownOption<TData> => ({\n data: option.data,\n label: option.label,\n value: option.value,\n});\n","import { Row, Space, Text, TextSize } from \"@stenajs-webui/core\";\nimport { Icon, stenaCheck } from \"@stenajs-webui/elements\";\nimport * as React from \"react\";\nimport { ReactNode } from \"react\";\nimport {\n ActionMeta,\n components,\n GroupBase,\n MultiValueProps,\n OnChangeValue,\n OptionProps,\n Options,\n} from \"react-select\";\nimport { defaultSelectTheme, SelectTheme } from \"../../SelectTheme\";\nimport {\n convertGroupedDropdownOptionsToInternalOptions,\n convertValueToInternalValue,\n createOnChange,\n GroupedOptionsType,\n InternalDropdownOption,\n} from \"../../util/multiDropdownUtils\";\nimport { DropdownOption } from \"./GroupedMultiSelectTypes\";\nimport {\n MultiSelect,\n MultiSelectComponentsConfig,\n MultiSelectProps,\n} from \"./MultiSelect\";\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nexport type OnChange<TData> = (\n value: OnChangeValue<DropdownOption<TData>, true>,\n action: ActionMeta<any>,\n) => void;\n\nexport interface GroupedMultiSelectProps<TData>\n extends Omit<\n MultiSelectProps<InternalDropdownOption<TData>>,\n \"options\" | \"onChange\" | \"value\" | \"components\"\n > {\n /**\n * Same as Select prop `component` but without MultiValue and Option since they can not be modified\n */\n components?: Omit<\n MultiSelectComponentsConfig<InternalDropdownOption<TData>>,\n \"MultiValue\" | \"Option\"\n >;\n /**\n * Same as Select prop `options` but only with GroupOptionsType\n */\n options?: GroupedOptionsType<DropdownOption<TData>>;\n /**\n * Same as Select prop `onChange` but only with GroupOptionsType\n */\n onChange?: OnChange<TData>;\n /**\n * Same as Select prop `value` but only with GroupOptionsType\n */\n value?: Options<DropdownOption<TData>> | undefined;\n}\n\nconst resolveIconColor = (\n theme: SelectTheme,\n isFocused: boolean,\n): string | undefined =>\n isFocused\n ? theme.menu.selectedItemHoverIconColor\n : theme.menu.selectedItemIconColor;\n\nfunction formatInnerOptionLabel<TData>(\n props: OptionProps<\n InternalDropdownOption<TData>,\n true,\n GroupBase<InternalDropdownOption<TData>>\n >,\n) {\n const { formatGroupLabel, formatOptionLabel } = props.selectProps;\n\n if (\"internalOptions\" in props.data) {\n return formatGroupLabel\n ? formatGroupLabel({\n label: props.data.label,\n options: props.data.internalOptions,\n })\n : props.label;\n }\n\n return formatOptionLabel\n ? formatOptionLabel(props.data, {\n context: \"menu\",\n inputValue: props.selectProps.inputValue ?? \"\",\n selectValue: props.getValue(),\n })\n : props.label;\n}\n\nexport function GroupedMultiSelect<TData>({\n onChange,\n options,\n value,\n variant = \"standard\",\n /* eslint-disable @typescript-eslint/no-unused-vars */\n formatGroupLabel,\n formatOptionLabel,\n ...selectProps\n}: GroupedMultiSelectProps<TData>): React.ReactElement<\n GroupedMultiSelectProps<TData>\n> {\n const Option = (\n props: OptionProps<\n InternalDropdownOption<TData>,\n true,\n GroupBase<InternalDropdownOption<TData>>\n >,\n ) => {\n const label = formatInnerOptionLabel(props);\n const isGroupOption = \"internalOptions\" in props.data;\n\n return (\n <components.Option {...props}>\n <Row>\n {!isGroupOption && <Space />}\n <InnerOption\n theme={defaultSelectTheme}\n size={!isGroupOption ? \"small\" : undefined}\n label={label}\n selected={props.isSelected}\n focused={props.isFocused}\n />\n </Row>\n </components.Option>\n );\n };\n\n const MultiValue = (\n props: MultiValueProps<\n InternalDropdownOption<TData>,\n true,\n GroupBase<InternalDropdownOption<TData>>\n >,\n ) => {\n return !(\"internalOptions\" in props.data) ? (\n <components.MultiValue {...props} />\n ) : null;\n };\n\n const internalValue = options\n ? convertValueToInternalValue(options, value)\n : undefined;\n const internalOptions = options\n ? convertGroupedDropdownOptionsToInternalOptions(options)\n : undefined;\n\n return (\n <MultiSelect<InternalDropdownOption<TData>>\n {...selectProps}\n onChange={onChange ? createOnChange<TData>(onChange) : undefined}\n hideSelectedOptions={false}\n components={{\n ...selectProps.components,\n MultiValue,\n Option,\n }}\n isMulti={true}\n options={internalOptions}\n value={internalValue}\n variant={variant}\n />\n );\n}\n\ninterface InnerOptionProps {\n size?: TextSize;\n selected: boolean;\n theme: SelectTheme;\n label: ReactNode;\n focused: boolean;\n}\n\nconst InnerOption: React.FC<InnerOptionProps> = ({\n focused,\n label,\n selected,\n size,\n theme,\n}) => (\n <Row alignItems={\"center\"} justifyContent={\"space-between\"} flexGrow={1}>\n <Text tabIndex={-1} size={size} color={\"currentColor\"}>\n {label}\n </Text>\n {selected && (\n <Icon\n color={resolveIconColor(theme, focused)}\n icon={stenaCheck}\n size={12}\n />\n )}\n </Row>\n);\n","import { CloseButton } from \"@stenajs-webui/elements\";\nimport * as React from \"react\";\nimport { useMemo } from \"react\";\nimport { ClearIndicatorProps, mergeStyles } from \"react-select\";\nimport CreatableComponent, { CreatableProps } from \"react-select/creatable\";\nimport { GroupBase } from \"react-select/dist/declarations/src/types\";\nimport {\n createStylesFromVariant,\n SelectVariant,\n} from \"../../util/StylesBuilder\";\n\nexport interface CreatableSelectProps<T = { label: string; value: string }>\n extends CreatableProps<T, false, GroupBase<T>> {\n variant?: SelectVariant;\n isMulti?: false;\n ariaLabelClear?: string;\n}\n\nexport function CreatableSelect<T>({\n variant = \"standard\",\n styles,\n components,\n ariaLabelClear = \"Clear\",\n ...selectProps\n}: CreatableSelectProps<T>) {\n const selectStyles = useMemo(() => {\n const sourceStyles = createStylesFromVariant<T, false>(variant);\n\n return styles ? mergeStyles(sourceStyles, styles) : sourceStyles;\n }, [variant, styles]);\n\n const ClearIndicator = (\n props: ClearIndicatorProps<T, false, GroupBase<T>>,\n ) => <CloseButton aria-label={ariaLabelClear} onClick={props.clearValue} />;\n\n return (\n <CreatableComponent\n styles={selectStyles}\n components={{ ...components, ClearIndicator }}\n {...selectProps}\n isMulti={false}\n />\n );\n}\n","import { Column, Row, Space, Spacing } from \"@stenajs-webui/core\";\nimport { Chip, FlatButton } from \"@stenajs-webui/elements\";\nimport { ValueAndOnValueChangeProps } from \"@stenajs-webui/forms\";\nimport * as React from \"react\";\nimport { PropsWithChildren } from \"react\";\nimport { MultiSelectOption } from \"../MultiSelect\";\n\nexport interface ChipRowItem extends MultiSelectOption {}\n\nexport interface ChipRowProps<TValue>\n extends ValueAndOnValueChangeProps<TValue> {\n noneSelectedLabel?: string;\n}\n\nexport function ChipRow<TValue extends ChipRowItem>({\n value,\n onValueChange,\n noneSelectedLabel = \"None\",\n children,\n}: PropsWithChildren<ChipRowProps<Array<TValue>>>) {\n return (\n <Column flex={1}>\n <Row flexWrap={\"wrap\"}>\n {value?.map((v) => (\n <Row key={v.value}>\n <Spacing num={0.5}>\n <Chip\n label={v.label}\n onClickRemove={() =>\n onValueChange?.(\n value?.filter((f) => f.value !== v.value) ?? [],\n )\n }\n />\n </Spacing>\n <Space />\n </Row>\n ))}\n {value?.length ? (\n <Spacing num={0.5}>\n <FlatButton\n size={\"small\"}\n label={\"Clear\"}\n onClick={() => onValueChange?.([])}\n />\n </Spacing>\n ) : (\n <Spacing num={0.5}>\n <Chip variant={\"secondary\"} label={noneSelectedLabel} />\n </Spacing>\n )}\n </Row>\n <Space num={0.5} />\n {children}\n </Column>\n );\n}\n","import { ValueAndOnValueChangeProps } from \"@stenajs-webui/forms\";\nimport * as React from \"react\";\nimport {\n MultiSelect,\n MultiSelectOption,\n MultiSelectProps,\n} from \"../MultiSelect\";\nimport { ChipRow, ChipRowItem } from \"./ChipRow\";\n\nexport interface ChipMultiSelectOption extends ChipRowItem {}\n\n/**\n * @deprecated renamed to ChipMultiSelectOption\n */\nexport type ChipMultiSelectValue = ChipMultiSelectOption;\n\nexport interface ChipMultiSelectProps<\n TOption extends MultiSelectOption = MultiSelectOption,\n> extends Omit<MultiSelectProps<TOption>, \"value\" | \"onChange\" | \"isLoading\">,\n ValueAndOnValueChangeProps<Array<TOption>> {\n loading?: boolean;\n inputValue?: string;\n onInputChange?: (inputValue: string) => void;\n noneSelectedLabel?: string;\n}\n\nfunction _ChipMultiSelect<TOption extends ChipMultiSelectOption>({\n value,\n onValueChange,\n placeholder = \"Type to search\",\n loading,\n inputValue,\n onInputChange,\n noneSelectedLabel = \"None\",\n ...selectProps\n}: ChipMultiSelectProps<TOption>) {\n return (\n <ChipRow\n noneSelectedLabel={noneSelectedLabel}\n onValueChange={onValueChange}\n value={value}\n >\n <MultiSelect<TOption>\n {...selectProps}\n isClearable={false}\n value={value}\n onChange={\n onValueChange ? (value) => onValueChange([...value]) : undefined\n }\n backspaceRemovesValue={false}\n hideSelectedOptions\n controlShouldRenderValue={false}\n placeholder={placeholder}\n isLoading={loading}\n inputValue={inputValue}\n onInputChange={onInputChange}\n />\n </ChipRow>\n );\n}\n\nexport const ChipMultiSelect = React.memo(\n _ChipMultiSelect,\n) as typeof _ChipMultiSelect;\n","import * as React from \"react\";\nimport { ValueAndOnValueChangeProps } from \"@stenajs-webui/forms\";\nimport {\n GroupedMultiSelect,\n GroupedMultiSelectProps,\n} from \"../GroupedMultiSelect\";\nimport { DropdownOption } from \"../GroupedMultiSelectTypes\";\nimport { ChipRow } from \"./ChipRow\";\n\nexport interface GroupedChipMultiSelectValue<TData>\n extends DropdownOption<TData> {}\n\nexport interface GroupedChipMultiSelectProps<TData>\n extends Omit<GroupedMultiSelectProps<TData>, \"onChange\" | \"value\">,\n ValueAndOnValueChangeProps<Array<DropdownOption<TData>>> {\n loading?: boolean;\n inputValue?: string;\n onInputChange?: (inputValue: string) => void;\n noneSelectedLabel?: string;\n}\n\nfunction _GroupedChipMultiSelect<TData>({\n value,\n onValueChange,\n placeholder = \"Type to search\",\n loading,\n inputValue,\n onInputChange,\n noneSelectedLabel = \"None\",\n ...selectProps\n}: GroupedChipMultiSelectProps<TData>) {\n return (\n <ChipRow\n noneSelectedLabel={noneSelectedLabel}\n onValueChange={onValueChange}\n value={value}\n >\n <GroupedMultiSelect<TData>\n {...selectProps}\n isClearable={false}\n value={value}\n onChange={\n onValueChange ? (value) => onValueChange([...value]) : undefined\n }\n backspaceRemovesValue={false}\n hideSelectedOptions\n controlShouldRenderValue={false}\n placeholder={placeholder}\n isLoading={loading}\n inputValue={inputValue}\n onInputChange={onInputChange}\n />\n </ChipRow>\n );\n}\n\nexport const GroupedChipMultiSelect = React.memo(\n _GroupedChipMultiSelect,\n) as typeof _GroupedChipMultiSelect;\n"],"names":["defaultSelectTheme","cssColor","resolveOptionBackgroundColor","colors","isDisabled","isSelected","isFocused","resolveOptionColor","resolveInputBackgroundColor","variant","resolveInputBorderColor","isHovered","createStylesFromTheme","menu","menuPortal","input","multiSelect","clearButtonColor","arrowColor","groupHeading","loadingIndicator","base","menuIsOpen","styles","createStylesFromVariant","AsyncMultiSelect","selectProps","selectStyles","useMemo","sourceStyles","mergeStyles","AsyncComponent","AsyncSelect","ClearIndicator","clearValue","ev","jsx","TextInputButton","stenaTimes","MultiValue","removeProps","data","Chip","MultiSelect","components","SelectComponent","OverflowingMultiSelect","props","FirstValueOnlyValueContainer","memo","prevOptions","restChildren","options","getOptionsToRender","jsxs","optionElements","children","innerProps","className","spreadProps","createElement","Select","CloseButton","removeGroupedOptionsType","removedValue","selectedInternalOptions","differenceWith","isEqual","convertInternalOptionToDropdownOption","removeInternalOptions","selectedInternalOption","removeOptionHeaders","createOnChange","onChange","incomingSelectedInternalOptions","meta","selectedOptions","uniqWith","previousValue","currentValue","convertGroupedDropdownOptionsToInternalOptions","convertGroupedDropdownOptionToInternalOption","convertDropdownOptionToInternalOption","convertValueToInternalValue","values","option","allOptionsExists","intersectionWith","selectedValues","resolveIconColor","theme","formatInnerOptionLabel","formatGroupLabel","formatOptionLabel","GroupedMultiSelect","value","Option","label","isGroupOption","Row","Space","InnerOption","internalValue","internalOptions","focused","selected","size","Text","Icon","stenaCheck","CreatableSelect","ariaLabelClear","CreatableComponent","ChipRow","onValueChange","noneSelectedLabel","Column","v","Spacing","f","FlatButton","_ChipMultiSelect","placeholder","loading","inputValue","onInputChange","ChipMultiSelect","React","_GroupedChipMultiSelect","GroupedChipMultiSelect"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@stenajs-webui/select",
3
- "version": "22.7.0",
3
+ "version": "22.7.2",
4
4
  "type": "module",
5
5
  "description": "",
6
6
  "author": "mattias800",
@@ -35,10 +35,10 @@
35
35
  "deploy": "gh-pages -d example/build"
36
36
  },
37
37
  "dependencies": {
38
- "@stenajs-webui/core": "22.7.0",
39
- "@stenajs-webui/elements": "22.7.0",
40
- "@stenajs-webui/forms": "22.7.0",
41
- "@stenajs-webui/theme": "22.7.0",
38
+ "@stenajs-webui/core": "22.7.2",
39
+ "@stenajs-webui/elements": "22.7.2",
40
+ "@stenajs-webui/forms": "22.7.2",
41
+ "@stenajs-webui/theme": "22.7.2",
42
42
  "lodash-es": "^4.17.21",
43
43
  "react-select": "^5.9.0"
44
44
  },
@@ -67,5 +67,5 @@
67
67
  "files": [
68
68
  "dist"
69
69
  ],
70
- "gitHead": "f57a915d7da4ae06aa9af7b5996a1c668fcd2382"
70
+ "gitHead": "dadd882a85509a9a7fb8ab3a4b7c39d88b91cd97"
71
71
  }