bkui-vue 0.0.1-beta.23 → 0.0.1-beta.26

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. package/dist/bkui-vue.cjs.js +659 -335
  2. package/dist/bkui-vue.esm.js +660 -337
  3. package/dist/bkui-vue.umd.js +659 -335
  4. package/dist/style.css +450 -50
  5. package/lib/components.d.ts +1 -0
  6. package/lib/loading/index.js +1 -1
  7. package/lib/loading/loading.css +2 -0
  8. package/lib/loading/loading.d.ts +1 -0
  9. package/lib/loading/loading.less +2 -0
  10. package/lib/loading/loading.variable.css +2 -0
  11. package/lib/popover/index.js +1 -1
  12. package/lib/resize-layout/index.d.ts +336 -0
  13. package/lib/resize-layout/index.js +1 -0
  14. package/lib/resize-layout/resize-layout.css +189 -0
  15. package/lib/resize-layout/resize-layout.d.ts +127 -0
  16. package/lib/resize-layout/resize-layout.less +233 -0
  17. package/lib/resize-layout/resize-layout.variable.css +282 -0
  18. package/lib/select/common.d.ts +23 -27
  19. package/lib/select/index.d.ts +530 -145
  20. package/lib/select/index.js +12 -12
  21. package/lib/select/optionGroup.d.ts +0 -76
  22. package/lib/select/select.css +154 -44
  23. package/lib/select/select.d.ts +150 -39
  24. package/lib/select/select.less +131 -75
  25. package/lib/select/select.variable.css +154 -44
  26. package/lib/select/type.d.ts +31 -0
  27. package/lib/shared/{bk-helper-core.d.ts → helper.d.ts} +0 -0
  28. package/lib/shared/index.d.ts +4 -4
  29. package/lib/shared/{bk-mask-manager.d.ts → mask-manager.d.ts} +0 -0
  30. package/lib/shared/{bk-pop-manager.d.ts → pop-manager.d.ts} +0 -0
  31. package/lib/shared/{bk-popover.d.ts → popover.d.ts} +0 -0
  32. package/lib/styles/index.d.ts +2 -0
  33. package/lib/styles/index.js +1 -1
  34. package/lib/swiper/index.d.ts +181 -0
  35. package/lib/swiper/index.js +1 -0
  36. package/lib/swiper/swiper.css +91 -0
  37. package/lib/swiper/swiper.d.ts +65 -0
  38. package/lib/swiper/swiper.less +107 -0
  39. package/lib/swiper/swiper.variable.css +91 -0
  40. package/lib/table/index.d.ts +1 -1
  41. package/lib/table/index.js +2 -2
  42. package/lib/table/table.css +1 -1
  43. package/lib/table/table.d.ts +1 -1
  44. package/lib/table/table.less +1 -1
  45. package/lib/table/table.variable.css +1 -1
  46. package/lib/tag/tag.css +1 -1
  47. package/lib/tag/tag.less +1 -1
  48. package/lib/tag/tag.variable.css +1 -1
  49. package/lib/transfer/index.d.ts +325 -1
  50. package/lib/transfer/index.js +1 -1
  51. package/lib/tree/index.d.ts +4 -1
  52. package/lib/tree/index.js +1 -1
  53. package/lib/tree/tree.css +13 -5
  54. package/lib/tree/tree.d.ts +18 -9
  55. package/lib/tree/tree.less +20 -9
  56. package/lib/tree/tree.variable.css +106 -5
  57. package/lib/tree/util.d.ts +1 -1
  58. package/lib/virtual-render/index.js +1 -1
  59. package/lib/virtual-render/virtual-render.d.ts +2 -2
  60. package/package.json +3 -3
@@ -59,6 +59,7 @@ var __publicField = (obj, key, value) => {
59
59
  var radio = "";
60
60
  var rate = "";
61
61
  var star$1 = "";
62
+ var swiper = "";
62
63
  var select = "";
63
64
  var sideslider = "";
64
65
  var switcher = "";
@@ -80,6 +81,7 @@ var __publicField = (obj, key, value) => {
80
81
  var transfer = "";
81
82
  var pagination = "";
82
83
  var timeline = "";
84
+ var resizeLayout = "";
83
85
  const BKLAYERD_INDEX_EFAULT_VALUE = {
84
86
  ["bottom"]: 0,
85
87
  ["content"]: 1,
@@ -333,7 +335,7 @@ var __publicField = (obj, key, value) => {
333
335
  }
334
336
  return false;
335
337
  }
336
- function getComputedStyle(element) {
338
+ function getComputedStyle$1(element) {
337
339
  return getWindow(element).getComputedStyle(element);
338
340
  }
339
341
  function isTableElement(element) {
@@ -349,7 +351,7 @@ var __publicField = (obj, key, value) => {
349
351
  return element.assignedSlot || element.parentNode || (isShadowRoot(element) ? element.host : null) || getDocumentElement(element);
350
352
  }
351
353
  function getTrueOffsetParent(element) {
352
- if (!isHTMLElement(element) || getComputedStyle(element).position === "fixed") {
354
+ if (!isHTMLElement(element) || getComputedStyle$1(element).position === "fixed") {
353
355
  return null;
354
356
  }
355
357
  return element.offsetParent;
@@ -358,7 +360,7 @@ var __publicField = (obj, key, value) => {
358
360
  var isFirefox2 = navigator.userAgent.toLowerCase().indexOf("firefox") !== -1;
359
361
  var isIE = navigator.userAgent.indexOf("Trident") !== -1;
360
362
  if (isIE && isHTMLElement(element)) {
361
- var elementCss = getComputedStyle(element);
363
+ var elementCss = getComputedStyle$1(element);
362
364
  if (elementCss.position === "fixed") {
363
365
  return null;
364
366
  }
@@ -368,7 +370,7 @@ var __publicField = (obj, key, value) => {
368
370
  currentNode = currentNode.host;
369
371
  }
370
372
  while (isHTMLElement(currentNode) && ["html", "body"].indexOf(getNodeName(currentNode)) < 0) {
371
- var css = getComputedStyle(currentNode);
373
+ var css = getComputedStyle$1(currentNode);
372
374
  if (css.transform !== "none" || css.perspective !== "none" || css.contain === "paint" || ["transform", "perspective"].indexOf(css.willChange) !== -1 || isFirefox2 && css.willChange === "filter" || isFirefox2 && css.filter && css.filter !== "none") {
373
375
  return currentNode;
374
376
  } else {
@@ -380,10 +382,10 @@ var __publicField = (obj, key, value) => {
380
382
  function getOffsetParent(element) {
381
383
  var window2 = getWindow(element);
382
384
  var offsetParent = getTrueOffsetParent(element);
383
- while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === "static") {
385
+ while (offsetParent && isTableElement(offsetParent) && getComputedStyle$1(offsetParent).position === "static") {
384
386
  offsetParent = getTrueOffsetParent(offsetParent);
385
387
  }
386
- if (offsetParent && (getNodeName(offsetParent) === "html" || getNodeName(offsetParent) === "body" && getComputedStyle(offsetParent).position === "static")) {
388
+ if (offsetParent && (getNodeName(offsetParent) === "html" || getNodeName(offsetParent) === "body" && getComputedStyle$1(offsetParent).position === "static")) {
387
389
  return window2;
388
390
  }
389
391
  return offsetParent || getContainingBlock(element) || window2;
@@ -517,7 +519,7 @@ var __publicField = (obj, key, value) => {
517
519
  var widthProp = "clientWidth";
518
520
  if (offsetParent === getWindow(popper2)) {
519
521
  offsetParent = getDocumentElement(popper2);
520
- if (getComputedStyle(offsetParent).position !== "static" && position === "absolute") {
522
+ if (getComputedStyle$1(offsetParent).position !== "static" && position === "absolute") {
521
523
  heightProp = "scrollHeight";
522
524
  widthProp = "scrollWidth";
523
525
  }
@@ -692,7 +694,7 @@ var __publicField = (obj, key, value) => {
692
694
  var height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0);
693
695
  var x2 = -winScroll.scrollLeft + getWindowScrollBarX(element);
694
696
  var y2 = -winScroll.scrollTop;
695
- if (getComputedStyle(body || html).direction === "rtl") {
697
+ if (getComputedStyle$1(body || html).direction === "rtl") {
696
698
  x2 += max(html.clientWidth, body ? body.clientWidth : 0) - width;
697
699
  }
698
700
  return {
@@ -703,7 +705,7 @@ var __publicField = (obj, key, value) => {
703
705
  };
704
706
  }
705
707
  function isScrollParent(element) {
706
- var _getComputedStyle = getComputedStyle(element), overflow = _getComputedStyle.overflow, overflowX = _getComputedStyle.overflowX, overflowY = _getComputedStyle.overflowY;
708
+ var _getComputedStyle = getComputedStyle$1(element), overflow = _getComputedStyle.overflow, overflowX = _getComputedStyle.overflowX, overflowY = _getComputedStyle.overflowY;
707
709
  return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX);
708
710
  }
709
711
  function getScrollParent(node) {
@@ -752,7 +754,7 @@ var __publicField = (obj, key, value) => {
752
754
  }
753
755
  function getClippingParents(element) {
754
756
  var clippingParents2 = listScrollParents(getParentNode(element));
755
- var canEscapeClipping = ["absolute", "fixed"].indexOf(getComputedStyle(element).position) >= 0;
757
+ var canEscapeClipping = ["absolute", "fixed"].indexOf(getComputedStyle$1(element).position) >= 0;
756
758
  var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element;
757
759
  if (!isElement$2(clipperElement)) {
758
760
  return [];
@@ -2717,7 +2719,7 @@ ${$(r2)}`), n2;
2717
2719
  warn.displayName = "warn";
2718
2720
  warn.inheritAttrs = false;
2719
2721
  JSON.parse('{"type":"element","name":"svg","attributes":{"xmlns":"http://www.w3.org/2000/svg","viewBox":"0 0 1024 1024","style":"width: 1em; height: 1em; vertical-align: middle;fill: currentColor;overflow: hidden;"},"elements":[{"type":"element","name":"path","attributes":{"d":"M603.52 348.8c0 26.496-22.357333333333333 48-49.919999999999995 48s-49.919999999999995-21.503999999999998-49.919999999999995-48c0-26.496 22.357333333333333-48 49.919999999999995-48s49.919999999999995 21.503999999999998 49.919999999999995 48z"}},{"type":"element","name":"path","attributes":{"d":"M357.11999999999995 348.8c0 26.496-22.357333333333333 48-49.919999999999995 48s-49.919999999999995-21.503999999999998-49.919999999999995-48c0-26.496 22.357333333333333-48 49.919999999999995-48s49.919999999999995 21.503999999999998 49.919999999999995 48z"}},{"type":"element","name":"path","attributes":{"d":"M693.12 604.16c0 15.914666666666665-13.184 28.8-29.439999999999998 28.8s-29.439999999999998-12.885333333333332-29.439999999999998-28.8c0-15.914666666666665 13.184-28.8 29.439999999999998-28.8s29.439999999999998 12.885333333333332 29.439999999999998 28.8z"}},{"type":"element","name":"path","attributes":{"d":"M951.68 832c43.775999999999996-42.410666666666664 71.29599999999999-101.41866666666665 72.32-166.86933333333332-4.608-109.696-77.35466666666666-201.0453333333333-176.72533333333334-233.30133333333333 5.674666666666667-12.117333333333331 10.154666666666666-26.282666666666664 10.154666666666666-41.471999999999994 0-4.522666666666666-0.38399999999999995-8.959999999999999-1.152-13.226666666666667-33.834666666666664-181.29066666666665-212.39466666666664-313.1306666666667-425.5146666666667-313.1306666666667-238.71999999999997 0-430.72 167.04-430.72 372.48 1.2799999999999998 107.56266666666666 50.56 203.30666666666664 127.40266666666668 267.05066666666664l-16.682666666666666 55.50933333333333c-2.1759999999999997 6.784-3.456 14.634666666666668-3.456 22.741333333333333 0 42.410666666666664 34.38933333333333 76.8 76.8 76.8 12.458666666666666 0 24.191999999999997-2.944 34.602666666666664-8.234666666666666l101.33333333333333-52.906666666666666c32.81066666666666 7.722666666666666 70.52799999999999 12.159999999999998 109.22666666666666 12.159999999999998 0.08533333333333333 0 0.17066666666666666 0 0.21333333333333332 0h28.16c13.098666666666666-0.7679999999999999 25.130666666666663-4.693333333333333 35.54133333333333-11.050666666666666 54.22933333333333 73.55733333333333 140.672 120.53333333333333 238.07999999999998 120.53333333333333 1.664 0 3.3706666666666667 0 5.034666666666666-0.042666666666666665 21.077333333333332-0.08533333333333333 41.855999999999995-2.1759999999999997 61.99466666666667-6.101333333333333l49.10933333333333 26.581333333333333c9.941333333333333 5.034666666666666 21.717333333333332 8.021333333333333 34.176 8.021333333333333 42.410666666666664 0 76.8-34.38933333333333 76.8-76.8 0-8.106666666666666-1.2799999999999998-15.957333333333333-3.584-23.296zM430.72 752.64c-0.17066666666666666 0-0.38399999999999995 0-0.5973333333333333 0-40.831999999999994 0-80.29866666666666-5.8453333333333335-117.58933333333331-16.72533333333333l-3.456 0.7253333333333334-131.2 67.19999999999999 35.199999999999996-113.27999999999999h-3.1999999999999997c-86.10133333333332-52.05333333333333-143.40266666666668-144.17066666666665-145.92-249.89866666666666 0-172.50133333333332 165.76-312.66133333333335 366.72-312.66133333333335 5.717333333333333-0.3413333333333333 12.415999999999999-0.512 19.157333333333334-0.512 163.32799999999997 0 300.58666666666664 111.40266666666668 340.0106666666667 262.4l-14.805333333333332 2.432c-183.04 0-327.03999999999996 112-327.03999999999996 285.44 0.512 26.709333333333333 5.1626666666666665 52.181333333333335 13.312 75.98933333333332zM872.96 812.8v0l21.759999999999998 67.84-81.28-40.959999999999994h-3.84c-21.119999999999997 6.101333333333333-45.397333333333336 9.6-70.48533333333333 9.6-0.17066666666666666 0-0.38399999999999995 0-0.5546666666666666 0-5.888 0.5973333333333333-12.757333333333332 0.9386666666666665-19.712 0.9386666666666665-107.09333333333332 0-195.2853333333333-80.93866666666666-206.71999999999997-184.95999999999998 10.367999999999999-106.96533333333333 99.072-189.1413333333333 206.976-189.1413333333333 5.973333333333334 0 11.861333333333334 0.256 17.706666666666663 0.7253333333333334 4.309333333333333-0.512 10.197333333333333-0.7253333333333334 16.170666666666666-0.7253333333333334 107.904 0 196.60799999999998 82.17599999999999 206.976 187.34933333333333-1.7066666666666666 63.82933333333333-35.79733333333333 118.44266666666665-86.18666666666667 148.90666666666667z"}},{"type":"element","name":"path","attributes":{"d":"M839.68 604.16c0 15.914666666666665-13.184 28.8-29.439999999999998 28.8s-29.439999999999998-12.885333333333332-29.439999999999998-28.8c0-15.914666666666665 13.184-28.8 29.439999999999998-28.8s29.439999999999998 12.885333333333332 29.439999999999998 28.8z"}}]}');
2720
- var Component$u = vue.defineComponent({
2722
+ var Component$w = vue.defineComponent({
2721
2723
  name: "Alert",
2722
2724
  props: {
2723
2725
  theme: PropTypes.theme(["info", "success", "warning", "error"]).def("info"),
@@ -2773,8 +2775,8 @@ ${$(r2)}`), n2;
2773
2775
  }, [this.closeText])])]);
2774
2776
  }
2775
2777
  });
2776
- const BkAlert = withInstall(Component$u);
2777
- var Component$t = vue.defineComponent({
2778
+ const BkAlert = withInstall(Component$w);
2779
+ var Component$v = vue.defineComponent({
2778
2780
  name: "AnimateNumber",
2779
2781
  props: {
2780
2782
  value: PropTypes.number.def(0),
@@ -2822,7 +2824,7 @@ ${$(r2)}`), n2;
2822
2824
  return () => vue.createVNode("span", null, [formatValue.value]);
2823
2825
  }
2824
2826
  });
2825
- const BkAnimateNumber = withInstall(Component$t);
2827
+ const BkAnimateNumber = withInstall(Component$v);
2826
2828
  var commonjsGlobal = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {};
2827
2829
  var lodash = { exports: {} };
2828
2830
  /**
@@ -8235,7 +8237,7 @@ ${$(r2)}`), n2;
8235
8237
  }
8236
8238
  }).call(commonjsGlobal);
8237
8239
  })(lodash, lodash.exports);
8238
- var Component$s = vue.defineComponent({
8240
+ var Component$u = vue.defineComponent({
8239
8241
  name: "Backtop",
8240
8242
  props: {
8241
8243
  visibilityHeight: PropTypes.number.def(200),
@@ -8302,8 +8304,8 @@ ${$(r2)}`), n2;
8302
8304
  });
8303
8305
  }
8304
8306
  });
8305
- const BkBacktop = withInstall(Component$s);
8306
- var Component$r = vue.defineComponent({
8307
+ const BkBacktop = withInstall(Component$u);
8308
+ var Component$t = vue.defineComponent({
8307
8309
  name: "Badge",
8308
8310
  props: {
8309
8311
  theme: PropTypes.string.def("primary"),
@@ -8337,8 +8339,8 @@ ${$(r2)}`), n2;
8337
8339
  }, [(_f = (_e = (_d = this.$slots).icon) == null ? void 0 : _e.call(_d)) != null ? _f : number]) : ""]);
8338
8340
  }
8339
8341
  });
8340
- const BkBadge = withInstall(Component$r);
8341
- var Component$q = vue.defineComponent({
8342
+ const BkBadge = withInstall(Component$t);
8343
+ var Component$s = vue.defineComponent({
8342
8344
  name: "Breadcrumb",
8343
8345
  props: {
8344
8346
  extCls: PropTypes.string,
@@ -8437,7 +8439,7 @@ ${$(r2)}`), n2;
8437
8439
  };
8438
8440
  }
8439
8441
  });
8440
- const BkBreadcrumb = withInstallProps(Component$q, { Item: BreadcrumbItem });
8442
+ const BkBreadcrumb = withInstallProps(Component$s, { Item: BreadcrumbItem });
8441
8443
  let BkLoadingMode;
8442
8444
  (function(BkLoadingMode2) {
8443
8445
  BkLoadingMode2["Default"] = "default";
@@ -8445,6 +8447,7 @@ ${$(r2)}`), n2;
8445
8447
  })(BkLoadingMode || (BkLoadingMode = {}));
8446
8448
  let BkLoadingSize;
8447
8449
  (function(BkLoadingSize2) {
8450
+ BkLoadingSize2["Normal"] = "";
8448
8451
  BkLoadingSize2["Mini"] = "mini";
8449
8452
  BkLoadingSize2["Small"] = "small";
8450
8453
  BkLoadingSize2["Large"] = "large";
@@ -8460,10 +8463,10 @@ ${$(r2)}`), n2;
8460
8463
  loading: PropTypes.bool,
8461
8464
  theme: PropTypes.theme(["white", "primary", "warning", "success", "danger"]),
8462
8465
  title: PropTypes.string.def(""),
8463
- size: PropTypes.commonType(Object.values(BkLoadingSize)).def("small"),
8466
+ size: PropTypes.commonType(Object.values(BkLoadingSize)).def(BkLoadingSize.Normal),
8464
8467
  mode: PropTypes.commonType(Object.values(BkLoadingMode)).def("default")
8465
8468
  };
8466
- var Component$p = vue.defineComponent({
8469
+ var Component$r = vue.defineComponent({
8467
8470
  name: "Loading",
8468
8471
  props: loadingTypes,
8469
8472
  setup(props, ctx) {
@@ -8508,7 +8511,7 @@ ${$(r2)}`), n2;
8508
8511
  };
8509
8512
  }
8510
8513
  });
8511
- const BkLoading = withInstallProps(Component$p, { setDefaultIndicator, BkLoadingMode, BkLoadingSize }, true);
8514
+ const BkLoading = withInstallProps(Component$r, { setDefaultIndicator, BkLoadingMode, BkLoadingSize }, true);
8512
8515
  const buttonProps = {
8513
8516
  theme: PropTypes.theme().def(""),
8514
8517
  hoverTheme: PropTypes.theme(["primary", "warning", "success", "danger"]).def(""),
@@ -8525,7 +8528,7 @@ ${$(r2)}`), n2;
8525
8528
  type: String
8526
8529
  }
8527
8530
  };
8528
- var Component$o = vue.defineComponent({
8531
+ var Component$q = vue.defineComponent({
8529
8532
  name: "Button",
8530
8533
  props: buttonProps,
8531
8534
  emits: ["click", "mouseover"],
@@ -8608,8 +8611,8 @@ ${$(r2)}`), n2;
8608
8611
  };
8609
8612
  }
8610
8613
  });
8611
- const BkButton = withInstallProps(Component$o, { ButtonGroup });
8612
- var Component$n = vue.defineComponent({
8614
+ const BkButton = withInstallProps(Component$q, { ButtonGroup });
8615
+ var Component$p = vue.defineComponent({
8613
8616
  name: "Card",
8614
8617
  props: {
8615
8618
  title: PropTypes.string,
@@ -8648,7 +8651,7 @@ ${$(r2)}`), n2;
8648
8651
  }, [(_i = (_h = (_g = this.$slots).footer) == null ? void 0 : _h.call(_g)) != null ? _i : "Footer"]) : ""]) : ""]);
8649
8652
  }
8650
8653
  });
8651
- const BkCard = withInstall(Component$n);
8654
+ const BkCard = withInstall(Component$p);
8652
8655
  const checkboxGroupKey = Symbol("CheckboxGroup");
8653
8656
  function useFocus$2() {
8654
8657
  const isFocus = vue.ref(false);
@@ -8750,7 +8753,7 @@ ${$(r2)}`), n2;
8750
8753
  beforeChange: PropTypes.func,
8751
8754
  size: PropTypes.size()
8752
8755
  };
8753
- var Component$m = vue.defineComponent({
8756
+ var Component$o = vue.defineComponent({
8754
8757
  name: "Checkbox",
8755
8758
  props: checkboxProps,
8756
8759
  emits: ["update:modelValue", "change"],
@@ -8866,8 +8869,8 @@ ${$(r2)}`), n2;
8866
8869
  }, [this.$slots.default()]);
8867
8870
  }
8868
8871
  });
8869
- const BkCheckbox = withInstallProps(Component$m, { Group: CheckboxGroup });
8870
- var Component$l = vue.defineComponent({
8872
+ const BkCheckbox = withInstallProps(Component$o, { Group: CheckboxGroup });
8873
+ var Component$n = vue.defineComponent({
8871
8874
  name: "Collapse",
8872
8875
  props: {
8873
8876
  list: PropTypes.arrayOf(PropTypes.any).def([]),
@@ -8956,7 +8959,7 @@ ${$(r2)}`), n2;
8956
8959
  }, [renderItems()]);
8957
8960
  }
8958
8961
  });
8959
- const BkCollaspe = withInstall(Component$l);
8962
+ const BkCollaspe = withInstall(Component$n);
8960
8963
  const propsMixin$1 = {
8961
8964
  isShow: {
8962
8965
  type: Boolean,
@@ -8983,7 +8986,7 @@ ${$(r2)}`), n2;
8983
8986
  default: true
8984
8987
  }
8985
8988
  };
8986
- var Component$k = vue.defineComponent({
8989
+ var Component$m = vue.defineComponent({
8987
8990
  name: "Modal",
8988
8991
  props: __spreadValues({}, propsMixin$1),
8989
8992
  data() {
@@ -9045,11 +9048,11 @@ ${$(r2)}`), n2;
9045
9048
  }, [(_i = (_h = (_g = this.$slots).footer) == null ? void 0 : _h.call(_g)) != null ? _i : ""])]) : ""]);
9046
9049
  }
9047
9050
  });
9048
- const BkModal = withInstallProps(Component$k, { propsMixin: propsMixin$1 }, true);
9051
+ const BkModal = withInstallProps(Component$m, { propsMixin: propsMixin$1 }, true);
9049
9052
  function _isSlot$3(s2) {
9050
9053
  return typeof s2 === "function" || Object.prototype.toString.call(s2) === "[object Object]" && !vue.isVNode(s2);
9051
9054
  }
9052
- var Component$j = vue.defineComponent({
9055
+ var Component$l = vue.defineComponent({
9053
9056
  name: "Dialog",
9054
9057
  components: {
9055
9058
  BkModal,
@@ -9145,7 +9148,7 @@ ${$(r2)}`), n2;
9145
9148
  });
9146
9149
  }
9147
9150
  });
9148
- const BkDialog = withInstall(Component$j);
9151
+ const BkDialog = withInstall(Component$l);
9149
9152
  var permissions = "";
9150
9153
  var notFound = "";
9151
9154
  var maintain = "";
@@ -9153,7 +9156,7 @@ ${$(r2)}`), n2;
9153
9156
  var empty = "";
9154
9157
  var login = "";
9155
9158
  var searchEmpty = "";
9156
- var Component$i = vue.defineComponent({
9159
+ var Component$k = vue.defineComponent({
9157
9160
  name: "Exception",
9158
9161
  props: {
9159
9162
  type: PropTypes.commonType(["404", "403", "500", "building", "empty", "search-empty", "login"], "type").def("404"),
@@ -9197,8 +9200,8 @@ ${$(r2)}`), n2;
9197
9200
  };
9198
9201
  }
9199
9202
  });
9200
- const BkException = withInstall(Component$i);
9201
- var Component$h = vue.defineComponent({
9203
+ const BkException = withInstall(Component$k);
9204
+ var Component$j = vue.defineComponent({
9202
9205
  name: "FixedNavbar",
9203
9206
  props: {
9204
9207
  navItems: PropTypes.array.def([]),
@@ -9237,7 +9240,7 @@ ${$(r2)}`), n2;
9237
9240
  }, [item.text]) : ""]))]);
9238
9241
  }
9239
9242
  });
9240
- const BkFixedNavbar = withInstall(Component$h);
9243
+ const BkFixedNavbar = withInstall(Component$j);
9241
9244
  const inputType = {
9242
9245
  type: PropTypes.string.def("text"),
9243
9246
  clearable: PropTypes.bool,
@@ -9262,7 +9265,7 @@ ${$(r2)}`), n2;
9262
9265
  };
9263
9266
  const inputEvents = ["update:modelValue", "focus", "blur", "change", "clear", "input", "keypress", "keydown", "keyup", "enter", "paste"];
9264
9267
  const EventEnum = stringEnum([...inputEvents]);
9265
- var Component$g = vue.defineComponent({
9268
+ var Component$i = vue.defineComponent({
9266
9269
  name: "Input",
9267
9270
  inheritAttrs: false,
9268
9271
  props: inputType,
@@ -9425,8 +9428,8 @@ ${$(r2)}`), n2;
9425
9428
  };
9426
9429
  }
9427
9430
  });
9428
- const BkInput = withInstall(Component$g);
9429
- var Component$f = vue.defineComponent({
9431
+ const BkInput = withInstall(Component$i);
9432
+ var Component$h = vue.defineComponent({
9430
9433
  name: "Link",
9431
9434
  props: {
9432
9435
  theme: PropTypes.theme(["danger", "success", "primary", "warning", "default"]).def("default"),
@@ -9463,7 +9466,7 @@ ${$(r2)}`), n2;
9463
9466
  }, [vue.createVNode("span", null, [(_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a)])]);
9464
9467
  }
9465
9468
  });
9466
- const BkLink = withInstall(Component$f);
9469
+ const BkLink = withInstall(Component$h);
9467
9470
  const placements = ["auto", "auto-start", "auto-end", "top", "top-start", "top-end", "bottom", "bottom-start", "bottom-end", "right", "right-start", "right-end", "left", "left-start", "left-end"];
9468
9471
  const PopoverProps = {
9469
9472
  isShow: PropTypes.bool,
@@ -9491,7 +9494,7 @@ ${$(r2)}`), n2;
9491
9494
  boundary: PropTypes.oneOfType([PropTypes.string.def("parent"), PropTypes.instanceOf(HTMLElement)]),
9492
9495
  fixOnBoundary: PropTypes.bool.def(false)
9493
9496
  };
9494
- var Component$e = vue.defineComponent({
9497
+ var Component$g = vue.defineComponent({
9495
9498
  name: "Popover",
9496
9499
  props: PopoverProps,
9497
9500
  setup(props, ctx) {
@@ -9527,8 +9530,9 @@ ${$(r2)}`), n2;
9527
9530
  };
9528
9531
  });
9529
9532
  const handleManualShow = (val) => {
9533
+ var _a, _b;
9530
9534
  if (trigger.value === "manual" && isPopInstance) {
9531
- val ? popoverInstance.show() : popoverInstance.hide();
9535
+ val ? (_a = popoverInstance.show) == null ? void 0 : _a.call(popoverInstance) : (_b = popoverInstance.hide) == null ? void 0 : _b.call(popoverInstance);
9532
9536
  }
9533
9537
  };
9534
9538
  vue.watch(() => props.isShow, (val) => {
@@ -9605,7 +9609,7 @@ ${$(r2)}`), n2;
9605
9609
  "ref": refContent,
9606
9610
  "class": contentClass,
9607
9611
  "style": compStyle.value
9608
- }, customTheme), [(_c = (_b2 = (_a2 = ctx.slots).content) == null ? void 0 : _b2.call(_a2)) != null ? _c : content.value, arrow2 && vue.createVNode("div", {
9612
+ }, customTheme), [(_c = (_b2 = (_a2 = ctx.slots).content) == null ? void 0 : _b2.call(_a2)) != null ? _c : content.value, arrow2.value && vue.createVNode("div", {
9609
9613
  "class": "arrow",
9610
9614
  "data-popper-arrow": true
9611
9615
  }, null)])];
@@ -9614,7 +9618,7 @@ ${$(r2)}`), n2;
9614
9618
  };
9615
9619
  }
9616
9620
  });
9617
- const BkPopover = withInstall(Component$e);
9621
+ const BkPopover = withInstall(Component$g);
9618
9622
  const Circle = (_2, {
9619
9623
  attrs,
9620
9624
  slots
@@ -9737,7 +9741,7 @@ ${$(r2)}`), n2;
9737
9741
  function _isSlot$2(s2) {
9738
9742
  return typeof s2 === "function" || Object.prototype.toString.call(s2) === "[object Object]" && !vue.isVNode(s2);
9739
9743
  }
9740
- var Component$d = vue.defineComponent({
9744
+ var Component$f = vue.defineComponent({
9741
9745
  name: "Progress",
9742
9746
  props: {
9743
9747
  extCls: PropTypes.string,
@@ -9815,7 +9819,7 @@ ${$(r2)}`), n2;
9815
9819
  return vue.createVNode("div", progressProps, [progress2]);
9816
9820
  }
9817
9821
  });
9818
- const BkProgress = withInstall(Component$d);
9822
+ const BkProgress = withInstall(Component$f);
9819
9823
  const radioGroupKey = Symbol("RadioGroup");
9820
9824
  function useFocus$1() {
9821
9825
  const isFocus = vue.ref(false);
@@ -9889,7 +9893,7 @@ ${$(r2)}`), n2;
9889
9893
  checked: PropTypes.bool.def(false),
9890
9894
  disabled: PropTypes.bool.def(false)
9891
9895
  };
9892
- var Component$c = vue.defineComponent({
9896
+ var Component$e = vue.defineComponent({
9893
9897
  name: "Radio",
9894
9898
  props: radioProps,
9895
9899
  emits: ["change", "update:modelValue"],
@@ -10032,7 +10036,7 @@ ${$(r2)}`), n2;
10032
10036
  }, [this.$slots.default()]);
10033
10037
  }
10034
10038
  });
10035
- const BkRadio = withInstallProps(Component$c, { Group: RadioGroup, Button: RadioButton });
10039
+ const BkRadio = withInstallProps(Component$e, { Group: RadioGroup, Button: RadioButton });
10036
10040
  var star = vue.defineComponent({
10037
10041
  name: "Star",
10038
10042
  props: {
@@ -10094,7 +10098,7 @@ ${$(r2)}`), n2;
10094
10098
  }, null)])])])])]))]);
10095
10099
  }
10096
10100
  });
10097
- var Component$b = vue.defineComponent({
10101
+ var Component$d = vue.defineComponent({
10098
10102
  name: "Rate",
10099
10103
  components: {
10100
10104
  star
@@ -10166,7 +10170,167 @@ ${$(r2)}`), n2;
10166
10170
  }, commonAttrs), null)])]);
10167
10171
  }
10168
10172
  });
10169
- const BkRate = withInstall(Component$b);
10173
+ const BkRate = withInstall(Component$d);
10174
+ var Component$c = vue.defineComponent({
10175
+ name: "Swiper",
10176
+ props: {
10177
+ isLoop: PropTypes.bool.def(true),
10178
+ loopTime: PropTypes.number.def(8e3),
10179
+ pics: PropTypes.array.def([]),
10180
+ list: PropTypes.array.def([]),
10181
+ height: PropTypes.number,
10182
+ width: PropTypes.number
10183
+ },
10184
+ emits: ["index-change"],
10185
+ setup(props, {
10186
+ emit,
10187
+ slots
10188
+ }) {
10189
+ const {
10190
+ isLoop,
10191
+ loopTime,
10192
+ pics,
10193
+ list,
10194
+ height,
10195
+ width
10196
+ } = vue.toRefs(props);
10197
+ const swiperRef = vue.ref();
10198
+ const swiperIndex = vue.ref(0);
10199
+ const renderWidth = vue.ref(0);
10200
+ const renderHeight = vue.ref(0);
10201
+ const loopId = vue.ref(0);
10202
+ let resizeObserver;
10203
+ const computedRenderDataList = vue.computed(() => {
10204
+ var _a;
10205
+ return ((_a = list.value) == null ? void 0 : _a.length) > 0 ? list.value : pics.value;
10206
+ });
10207
+ const computedSwiperTranslateStyle = vue.computed(() => ({
10208
+ width: `${renderWidth.value * computedRenderDataList.value.length}px`,
10209
+ transform: `translateX(-${renderWidth.value * swiperIndex.value}px)`
10210
+ }));
10211
+ const computedSwiperRenderStyle = vue.computed(() => ({
10212
+ width: `${renderWidth.value}px`,
10213
+ height: `${renderHeight.value}px`
10214
+ }));
10215
+ const changeIndex = (index) => {
10216
+ let showIndex = index;
10217
+ if (index >= computedRenderDataList.value.length) {
10218
+ showIndex = 0;
10219
+ }
10220
+ if (index < 0) {
10221
+ showIndex = computedRenderDataList.value.length - 1;
10222
+ }
10223
+ swiperIndex.value = showIndex;
10224
+ emit("index-change", showIndex);
10225
+ };
10226
+ const goToLink = (link2) => {
10227
+ if (!link2)
10228
+ return;
10229
+ window.open(link2, "_blank");
10230
+ };
10231
+ const getRenderItemClass = (renderData) => ["bk-swiper-img", {
10232
+ "bk-swiper-link": renderData.link
10233
+ }, renderData.class];
10234
+ const getRenderItemStyle = (renderData) => ({
10235
+ "background-image": `url(${renderData.url})`,
10236
+ "background-color": renderData.color
10237
+ });
10238
+ const getRenderIndexStyle = (index) => ({
10239
+ "bk-current-index": swiperIndex.value === index
10240
+ });
10241
+ const startLoop = () => {
10242
+ if (isLoop.value) {
10243
+ loopId.value = window.setTimeout(() => {
10244
+ changeIndex(swiperIndex.value + 1);
10245
+ startLoop();
10246
+ }, loopTime.value);
10247
+ }
10248
+ };
10249
+ const endLoop = () => {
10250
+ window.clearTimeout(loopId.value);
10251
+ };
10252
+ const watchParentSizeChange = () => {
10253
+ var _a;
10254
+ const parentEle = (_a = swiperRef.value) == null ? void 0 : _a.parentElement;
10255
+ if (!parentEle || !window.ResizeObserver) {
10256
+ return;
10257
+ }
10258
+ resizeObserver = new ResizeObserver(() => {
10259
+ calcSize();
10260
+ });
10261
+ resizeObserver.observe(parentEle);
10262
+ };
10263
+ const endWatchParentSizeChange = () => {
10264
+ var _a;
10265
+ (_a = resizeObserver.disconnect) == null ? void 0 : _a.call(resizeObserver);
10266
+ };
10267
+ const getElementSize = (node) => {
10268
+ if (node === void 0) {
10269
+ return {
10270
+ height: 0,
10271
+ width: 0
10272
+ };
10273
+ }
10274
+ const computedStyle = getComputedStyle(node);
10275
+ const width2 = node.clientWidth - parseFloat(computedStyle.paddingTop) - parseFloat(computedStyle.paddingBottom);
10276
+ const height2 = node.clientHeight - parseFloat(computedStyle.paddingLeft) - parseFloat(computedStyle.paddingRight);
10277
+ return {
10278
+ height: height2,
10279
+ width: width2
10280
+ };
10281
+ };
10282
+ const calcSize = () => {
10283
+ var _a;
10284
+ const swiperParentSize = getElementSize((_a = swiperRef.value) == null ? void 0 : _a.parentElement);
10285
+ renderWidth.value = +width.value > 0 ? width.value : swiperParentSize.width;
10286
+ renderHeight.value = +height.value > 0 ? height.value : swiperParentSize.height;
10287
+ };
10288
+ vue.watch([height, width], calcSize);
10289
+ vue.onMounted(() => {
10290
+ calcSize();
10291
+ startLoop();
10292
+ watchParentSizeChange();
10293
+ });
10294
+ vue.onBeforeUnmount(() => {
10295
+ endLoop();
10296
+ endWatchParentSizeChange();
10297
+ });
10298
+ return () => vue.createVNode("section", {
10299
+ "class": "bk-swiper-home",
10300
+ "ref": swiperRef,
10301
+ "style": computedSwiperRenderStyle.value
10302
+ }, [vue.createVNode("hgroup", {
10303
+ "style": computedSwiperTranslateStyle.value,
10304
+ "class": "bk-transition bk-swiper-main"
10305
+ }, [computedRenderDataList.value.map((renderData) => {
10306
+ var _a, _b;
10307
+ return vue.createVNode("h3", {
10308
+ "class": "bk-swiper-card",
10309
+ "style": computedSwiperRenderStyle.value
10310
+ }, [(_b = (_a = slots.default) == null ? void 0 : _a.call(slots, renderData)) != null ? _b : vue.createVNode("span", {
10311
+ "class": getRenderItemClass(renderData),
10312
+ "style": getRenderItemStyle(renderData),
10313
+ "onClick": () => goToLink(renderData.link)
10314
+ }, null)]);
10315
+ })]), vue.createVNode("ul", {
10316
+ "class": "bk-swiper-index"
10317
+ }, [computedRenderDataList.value.map((_2, index) => vue.createVNode("li", {
10318
+ "class": getRenderIndexStyle(index),
10319
+ "onMouseover": () => changeIndex(index)
10320
+ }, null))]), vue.createVNode("span", {
10321
+ "class": "bk-swiper-nav bk-nav-prev",
10322
+ "onClick": () => changeIndex(swiperIndex.value - 1)
10323
+ }, [vue.createVNode("i", {
10324
+ "class": "bk-swiper-nav-icon"
10325
+ }, null)]), vue.createVNode("span", {
10326
+ "class": "bk-swiper-nav bk-nav-next",
10327
+ "onClick": () => changeIndex(swiperIndex.value + 1)
10328
+ }, [vue.createVNode("i", {
10329
+ "class": "bk-swiper-nav-icon"
10330
+ }, null)])]);
10331
+ }
10332
+ });
10333
+ const BkSwiper = withInstall(Component$c);
10170
10334
  const selectKey = Symbol("BkSelect");
10171
10335
  const optionGroupKey = Symbol("BkOptionGroup");
10172
10336
  function useFocus() {
@@ -10197,22 +10361,79 @@ ${$(r2)}`), n2;
10197
10361
  cancelHover
10198
10362
  };
10199
10363
  }
10364
+ function useRegistry(data2) {
10365
+ const register = (item) => {
10366
+ if (!item)
10367
+ return;
10368
+ return data2.value.add(item);
10369
+ };
10370
+ const unregister = (item) => data2.value.delete(item);
10371
+ return {
10372
+ register,
10373
+ unregister
10374
+ };
10375
+ }
10200
10376
  function useDebouncedRef(value, delay = 200) {
10201
10377
  let timeout;
10378
+ let innerValue = value;
10202
10379
  return vue.customRef((track, trigger) => ({
10203
10380
  get() {
10204
10381
  track();
10205
- return value;
10382
+ return innerValue;
10206
10383
  },
10207
10384
  set(newValue) {
10208
10385
  clearTimeout(timeout);
10209
10386
  timeout = setTimeout(() => {
10210
- value = newValue;
10387
+ innerValue = newValue;
10211
10388
  trigger();
10212
10389
  }, delay);
10213
10390
  }
10214
10391
  }));
10215
10392
  }
10393
+ function usePopover(config) {
10394
+ const { popoverMinWidth } = config;
10395
+ const popperWidth = vue.ref("auto");
10396
+ const isPopoverShow = vue.ref(false);
10397
+ const onPopoverFirstUpdate = (instance) => {
10398
+ const { reference: reference2 } = instance.elements;
10399
+ popperWidth.value = Math.max(reference2.offsetWidth, popoverMinWidth);
10400
+ };
10401
+ const togglePopover = () => {
10402
+ isPopoverShow.value = !isPopoverShow.value;
10403
+ };
10404
+ const hidePopover = () => {
10405
+ isPopoverShow.value = false;
10406
+ };
10407
+ const showPopover = () => {
10408
+ isPopoverShow.value = true;
10409
+ };
10410
+ return {
10411
+ isPopoverShow,
10412
+ popperWidth,
10413
+ togglePopover,
10414
+ onPopoverFirstUpdate,
10415
+ hidePopover,
10416
+ showPopover
10417
+ };
10418
+ }
10419
+ function useRemoteSearch(method) {
10420
+ const searchKey = useDebouncedRef("");
10421
+ const searchLoading = vue.ref(false);
10422
+ vue.watch(searchKey, async () => {
10423
+ searchLoading.value = true;
10424
+ await method(searchKey.value);
10425
+ searchLoading.value = false;
10426
+ });
10427
+ return {
10428
+ searchKey,
10429
+ searchLoading
10430
+ };
10431
+ }
10432
+ function toLowerCase(value = "") {
10433
+ if (!value)
10434
+ return value;
10435
+ return String(value).trim().toLowerCase();
10436
+ }
10216
10437
  var BkOption = vue.defineComponent({
10217
10438
  name: "Option",
10218
10439
  props: {
@@ -10228,28 +10449,12 @@ ${$(r2)}`), n2;
10228
10449
  visible: true
10229
10450
  });
10230
10451
  const {
10231
- disabled,
10232
- label
10452
+ disabled
10233
10453
  } = vue.toRefs(props);
10234
10454
  const select2 = vue.inject(selectKey, null);
10235
10455
  const group = vue.inject(optionGroupKey, null);
10236
10456
  const selected = vue.computed(() => select2.selectedOptions.has(proxy));
10237
10457
  const multiple = vue.computed(() => select2 == null ? void 0 : select2.props.multiple);
10238
- vue.watchEffect(() => {
10239
- var _a;
10240
- if (group == null ? void 0 : group.groupCollapse) {
10241
- states.visible = false;
10242
- } else if (!(select2 == null ? void 0 : select2.isRemoteSearch) && (select2 == null ? void 0 : select2.searchKey)) {
10243
- states.visible = (_a = toLowerCase(String(label.value))) == null ? void 0 : _a.includes(toLowerCase(select2 == null ? void 0 : select2.searchKey));
10244
- } else {
10245
- states.visible = true;
10246
- }
10247
- });
10248
- const toLowerCase = (value = "") => {
10249
- if (!value)
10250
- return value;
10251
- return String(value).trim().toLowerCase();
10252
- };
10253
10458
  const handleOptionClick = () => {
10254
10459
  if (disabled.value)
10255
10460
  return;
@@ -10257,9 +10462,11 @@ ${$(r2)}`), n2;
10257
10462
  };
10258
10463
  vue.onBeforeMount(() => {
10259
10464
  select2 == null ? void 0 : select2.register(proxy);
10465
+ group == null ? void 0 : group.register(proxy);
10260
10466
  });
10261
10467
  vue.onBeforeUnmount(() => {
10262
10468
  select2 == null ? void 0 : select2.unregister(proxy);
10469
+ group == null ? void 0 : group.unregister(proxy);
10263
10470
  });
10264
10471
  return __spreadProps(__spreadValues({}, vue.toRefs(states)), {
10265
10472
  selected,
@@ -10293,41 +10500,38 @@ ${$(r2)}`), n2;
10293
10500
  setup(props, {
10294
10501
  emit
10295
10502
  }) {
10296
- const children = vue.ref([]);
10297
- const instance = vue.getCurrentInstance();
10503
+ const {
10504
+ proxy
10505
+ } = vue.getCurrentInstance();
10506
+ const select2 = vue.inject(selectKey, null);
10298
10507
  const states = vue.reactive({
10299
10508
  groupCollapse: props.collapse,
10300
10509
  visible: true
10301
10510
  });
10302
- const groupLabel = vue.computed(() => `${props.label} (${children.value.filter((option) => option.visible).length})`);
10303
- vue.provide(optionGroupKey, vue.reactive(__spreadProps(__spreadValues({}, vue.toRefs(props)), {
10304
- groupCollapse: vue.toRef(states, "groupCollapse")
10305
- })));
10306
- const flattedChildren = (node) => {
10307
- const children2 = [];
10308
- if (Array.isArray(node.children)) {
10309
- node.children.forEach((child) => {
10310
- var _a;
10311
- if (child.type && child.type.name === "Option" && child.component && child.component.proxy) {
10312
- children2.push(child.component.proxy);
10313
- } else if ((_a = child.children) == null ? void 0 : _a.length) {
10314
- children2.push(...flattedChildren(child));
10315
- }
10316
- });
10317
- }
10318
- return children2;
10319
- };
10511
+ const options = vue.ref(/* @__PURE__ */ new Set());
10512
+ const {
10513
+ register,
10514
+ unregister
10515
+ } = useRegistry(options);
10516
+ const groupLabel = vue.computed(() => `${props.label} (${[...options.value.values()].filter((option) => option.visible).length})`);
10320
10517
  const handleToggleCollapse = () => {
10321
- if (!props.collapsible)
10518
+ if (!props.collapsible || props.disabled)
10322
10519
  return;
10323
10520
  states.groupCollapse = !states.groupCollapse;
10324
10521
  emit("update:collapse", states.groupCollapse);
10325
10522
  };
10326
- vue.onMounted(() => {
10327
- children.value = flattedChildren(instance.subTree);
10523
+ vue.provide(optionGroupKey, vue.reactive(__spreadProps(__spreadValues({}, vue.toRefs(props)), {
10524
+ register,
10525
+ unregister,
10526
+ groupCollapse: vue.toRef(states, "groupCollapse")
10527
+ })));
10528
+ vue.onBeforeMount(() => {
10529
+ select2 == null ? void 0 : select2.registerGroup(proxy);
10530
+ });
10531
+ vue.onBeforeUnmount(() => {
10532
+ select2 == null ? void 0 : select2.unregisterGroup(proxy);
10328
10533
  });
10329
10534
  return __spreadProps(__spreadValues({}, vue.toRefs(states)), {
10330
- children,
10331
10535
  groupLabel,
10332
10536
  handleToggleCollapse
10333
10537
  });
@@ -10336,7 +10540,8 @@ ${$(r2)}`), n2;
10336
10540
  var _a, _b;
10337
10541
  const groupClass = classes({
10338
10542
  "bk-option-group": true,
10339
- collapsible: this.collapsible
10543
+ collapsible: this.collapsible,
10544
+ disabled: this.disabled
10340
10545
  });
10341
10546
  const groupLabelClass = classes({
10342
10547
  "bk-option-group-label": true,
@@ -10353,13 +10558,13 @@ ${$(r2)}`), n2;
10353
10558
  "onClick": this.handleToggleCollapse
10354
10559
  }, [this.$slots.label ? this.$slots.label() : vue.createVNode("span", {
10355
10560
  "class": "default-group-label"
10356
- }, [this.collapsible ? vue.createVNode(angleUpFill, {
10561
+ }, [this.collapsible && vue.createVNode(angleUpFill, {
10357
10562
  "class": groupLabelIconClass
10358
- }, null) : null, vue.createVNode("span", {
10563
+ }, null), vue.createVNode("span", {
10359
10564
  "class": "default-group-label-title"
10360
- }, [this.groupLabel])])]), vue.createVNode("ul", {
10565
+ }, [this.groupLabel])])]), vue.withDirectives(vue.createVNode("ul", {
10361
10566
  "class": "bk-option-group-content"
10362
- }, [(_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a)])]), [[vue.vShow, this.visible]]);
10567
+ }, [(_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a)]), [[vue.vShow, !this.groupCollapse]])]), [[vue.vShow, this.visible]]);
10363
10568
  }
10364
10569
  });
10365
10570
  var _populated = false;
@@ -10760,6 +10965,67 @@ ${$(r2)}`), n2;
10760
10965
  }));
10761
10966
  }
10762
10967
  }
10968
+ var Component$b = vue.defineComponent({
10969
+ name: "Tag",
10970
+ props: {
10971
+ theme: PropTypes.theme(["success", "info", "warning", "danger"]).def(""),
10972
+ closable: PropTypes.bool.def(false),
10973
+ type: PropTypes.commonType(["", "filled", "stroke"]).def(""),
10974
+ checkable: PropTypes.bool.def(false),
10975
+ checked: PropTypes.bool.def(false),
10976
+ radius: PropTypes.string.def("2px"),
10977
+ extCls: PropTypes.string.def("")
10978
+ },
10979
+ emits: ["change", "close"],
10980
+ slots: ["icon"],
10981
+ setup(props, {
10982
+ emit
10983
+ }) {
10984
+ const wrapperCls = vue.computed(() => classes({
10985
+ "bk-tag-closable": props.closable,
10986
+ "bk-tag-checkable": props.checkable,
10987
+ "bk-tag-check": props.checked,
10988
+ [`bk-tag-${props.type}`]: props.type,
10989
+ [`bk-tag-${props.theme}`]: props.theme,
10990
+ [props.extCls]: !!props.extCls
10991
+ }, "bk-tag"));
10992
+ const wrapperStyle = vue.computed(() => ({
10993
+ borderRadius: props.radius
10994
+ }));
10995
+ const handleClose = (e) => {
10996
+ e.preventDefault();
10997
+ e.stopPropagation();
10998
+ emit("close", e);
10999
+ };
11000
+ const handleClick = (e) => {
11001
+ e.preventDefault();
11002
+ e.stopPropagation();
11003
+ if (props.checkable) {
11004
+ emit("change", !props.checked);
11005
+ }
11006
+ };
11007
+ return {
11008
+ wrapperCls,
11009
+ wrapperStyle,
11010
+ handleClose,
11011
+ handleClick
11012
+ };
11013
+ },
11014
+ render() {
11015
+ var _a, _b;
11016
+ return vue.createVNode("div", {
11017
+ "class": this.wrapperCls,
11018
+ "style": this.wrapperStyle,
11019
+ "onClick": this.handleClick
11020
+ }, [this.$slots.icon ? vue.createVNode("span", {
11021
+ "class": "bk-tag-icon"
11022
+ }, [this.$slots.icon()]) : "", vue.createVNode("span", null, [(_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a)]), this.closable ? vue.createVNode(error, {
11023
+ "class": "bk-tag-close",
11024
+ "onClick": this.handleClose
11025
+ }, null) : ""]);
11026
+ }
11027
+ });
11028
+ const BkTag = withInstall(Component$b);
10763
11029
  var Component$a = vue.defineComponent({
10764
11030
  name: "Select",
10765
11031
  directives: {
@@ -10768,43 +11034,84 @@ ${$(r2)}`), n2;
10768
11034
  props: {
10769
11035
  modelValue: PropTypes.any,
10770
11036
  multiple: PropTypes.bool.def(false),
10771
- placeholder: PropTypes.string.def("\u8BF7\u9009\u62E9"),
10772
11037
  disabled: PropTypes.bool.def(false),
10773
- size: PropTypes.size().def("small"),
11038
+ size: PropTypes.size().def("default"),
10774
11039
  clearable: PropTypes.bool.def(true),
10775
11040
  loading: PropTypes.bool.def(false),
10776
11041
  filterable: PropTypes.bool.def(false),
10777
11042
  remoteMethod: PropTypes.func,
10778
- scrollHeight: PropTypes.number.def(216)
11043
+ scrollHeight: PropTypes.number.def(216),
11044
+ showSelectAll: PropTypes.bool.def(false),
11045
+ popoverMinWidth: PropTypes.number.def(0),
11046
+ showOnInit: PropTypes.bool.def(false),
11047
+ multipleMode: PropTypes.oneOf(["default", "tag"]).def("default"),
11048
+ tagTheme: PropTypes.theme(["success", "info", "warning", "danger"]).def(""),
11049
+ behavior: PropTypes.oneOf(["normal", "simplicity"]).def("normal"),
11050
+ collapseTags: PropTypes.bool.def(false),
11051
+ noDataText: PropTypes.string.def("\u65E0\u6570\u636E"),
11052
+ noMatchText: PropTypes.string.def("\u65E0\u5339\u914D\u6570\u636E"),
11053
+ loadingText: PropTypes.string.def("\u52A0\u8F7D\u4E2D..."),
11054
+ placeholder: PropTypes.string.def("\u8BF7\u9009\u62E9"),
11055
+ selectAllText: PropTypes.string.def("\u5168\u90E8")
10779
11056
  },
10780
- emits: ["update:modelValue", "change", "toggle"],
11057
+ emits: ["update:modelValue", "change", "toggle", "clear"],
10781
11058
  setup(props, {
10782
11059
  emit
10783
11060
  }) {
10784
11061
  const {
10785
11062
  modelValue,
10786
11063
  disabled,
10787
- size,
10788
11064
  filterable,
10789
11065
  placeholder,
10790
11066
  multiple,
10791
11067
  remoteMethod,
10792
- loading: loading2
11068
+ loading: loading2,
11069
+ loadingText,
11070
+ noDataText,
11071
+ noMatchText,
11072
+ popoverMinWidth,
11073
+ showOnInit
10793
11074
  } = vue.toRefs(props);
10794
11075
  const states = vue.reactive({
10795
11076
  currentPlaceholder: placeholder.value,
10796
- options: /* @__PURE__ */ new Set(),
10797
11077
  selectedOptions: /* @__PURE__ */ new Set(),
10798
11078
  currentSelectedLabel: ""
10799
11079
  });
10800
- const selectTriggerRef = vue.ref();
10801
11080
  const inputRef = vue.ref();
10802
- const register = (option) => {
10803
- if (!option)
10804
- return;
10805
- return states.options.add(option);
10806
- };
10807
- const unregister = (option) => states.options.delete(option);
11081
+ const popoverRef = vue.ref();
11082
+ const options = vue.ref(/* @__PURE__ */ new Set());
11083
+ const groups = vue.ref(/* @__PURE__ */ new Set());
11084
+ const isDisabled = vue.computed(() => disabled.value || loading2.value);
11085
+ const selectedLabel = vue.computed(() => [...states.selectedOptions.values()].map((option) => option.label));
11086
+ const isAllSelected = vue.computed(() => [...options.value.values()].filter((option) => !option.disabled).every((option) => states.selectedOptions.has(option)));
11087
+ const isGroup = vue.computed(() => !!groups.value.size);
11088
+ const isOptionsEmpty = vue.computed(() => !options.value.size);
11089
+ const isSearchEmpty = vue.computed(() => {
11090
+ const data2 = [...options.value.values()];
11091
+ return data2.length && data2.every((option) => !option.visible);
11092
+ });
11093
+ const isRemoteSearch = vue.computed(() => typeof remoteMethod.value === "function");
11094
+ const isShowSelectContent = vue.computed(() => !(searchLoading.value || isOptionsEmpty.value || isSearchEmpty.value));
11095
+ const curContentText = vue.computed(() => {
11096
+ if (searchLoading.value) {
11097
+ return loadingText.value;
11098
+ }
11099
+ if (isOptionsEmpty.value) {
11100
+ return noDataText.value;
11101
+ }
11102
+ if (isSearchEmpty.value) {
11103
+ return noMatchText.value;
11104
+ }
11105
+ return "";
11106
+ });
11107
+ const {
11108
+ register,
11109
+ unregister
11110
+ } = useRegistry(options);
11111
+ const {
11112
+ register: registerGroup,
11113
+ unregister: unregisterGroup
11114
+ } = useRegistry(groups);
10808
11115
  const {
10809
11116
  isHover,
10810
11117
  setHover,
@@ -10815,63 +11122,63 @@ ${$(r2)}`), n2;
10815
11122
  handleFocus,
10816
11123
  handleBlur
10817
11124
  } = useFocus();
10818
- const handleInput = (e) => {
10819
- searchKey.value = e.target.value;
10820
- };
10821
- const isDisabled = vue.computed(() => disabled.value || loading2.value);
10822
- const selectClass = vue.computed(() => ({
10823
- "bk-select": true,
10824
- "popover-show": isPopoverShow.value,
10825
- "is-disabled": isDisabled.value,
10826
- "is-focus": isFocus.value,
10827
- [size.value]: true
10828
- }));
10829
- const selectedLabel = vue.computed(() => [...states.selectedOptions.values()].map((option) => option.label).join(","));
10830
- const popperWidth = vue.ref("auto");
10831
- const onPopoverFirstUpdate = (instance) => {
10832
- const {
10833
- reference: reference2
10834
- } = instance.elements;
10835
- popperWidth.value = reference2.offsetWidth;
10836
- };
10837
- const isPopoverShow = vue.ref(false);
10838
- const toggleMenu = () => {
10839
- if (isDisabled.value)
10840
- return;
10841
- isPopoverShow.value = !isPopoverShow.value;
10842
- emit("toggle", isPopoverShow.value);
10843
- };
10844
- const hidePopover = () => {
10845
- isPopoverShow.value = false;
10846
- handleBlur();
10847
- };
10848
- const showPopover = () => {
10849
- isPopoverShow.value = true;
10850
- };
10851
- vue.watch(isPopoverShow, () => {
10852
- handleResetState();
11125
+ const {
11126
+ popperWidth,
11127
+ isPopoverShow,
11128
+ onPopoverFirstUpdate,
11129
+ hidePopover,
11130
+ showPopover,
11131
+ togglePopover
11132
+ } = usePopover({
11133
+ popoverMinWidth: popoverMinWidth.value
10853
11134
  });
10854
- const handleResetState = () => {
10855
- if (!isRemoteSearch.value || isRemoteSearch.value && !isPopoverShow.value) {
10856
- searchKey.value = "";
10857
- }
11135
+ const defaultSearchMethod = (value) => {
11136
+ options.value.forEach((option) => {
11137
+ var _a;
11138
+ option.visible = (_a = toLowerCase(String(option.label))) == null ? void 0 : _a.includes(toLowerCase(value));
11139
+ });
11140
+ };
11141
+ const {
11142
+ searchKey,
11143
+ searchLoading
11144
+ } = useRemoteSearch(isRemoteSearch.value ? remoteMethod.value : defaultSearchMethod);
11145
+ const handleResetInputValue = () => {
11146
+ const label = selectedLabel.value.join(",");
10858
11147
  if (filterable.value && isPopoverShow.value) {
10859
- states.currentPlaceholder = selectedLabel.value || placeholder.value;
11148
+ states.currentPlaceholder = label || placeholder.value;
10860
11149
  states.currentSelectedLabel = "";
10861
11150
  } else {
10862
11151
  states.currentPlaceholder = placeholder.value;
10863
- states.currentSelectedLabel = selectedLabel.value;
11152
+ states.currentSelectedLabel = label;
11153
+ searchKey.value = "";
10864
11154
  }
10865
11155
  };
11156
+ vue.watch(isPopoverShow, () => {
11157
+ handleResetInputValue();
11158
+ });
10866
11159
  const emitChange = (val) => {
10867
11160
  if (val === modelValue.value)
10868
11161
  return;
10869
11162
  emit("change", val);
10870
11163
  emit("update:modelValue", val);
10871
11164
  };
10872
- const handleOptionSelected = (option) => {
11165
+ const handleTogglePopover = () => {
10873
11166
  if (isDisabled.value)
10874
11167
  return;
11168
+ togglePopover();
11169
+ emit("toggle", isPopoverShow.value);
11170
+ };
11171
+ const handleInput = (e) => {
11172
+ searchKey.value = e.target.value;
11173
+ };
11174
+ const selectedCallback = () => {
11175
+ inputRef.value.focus();
11176
+ popoverRef.value.update();
11177
+ !searchKey.value && handleResetInputValue();
11178
+ };
11179
+ const handleOptionSelected = (option) => {
11180
+ if (isDisabled.value || !option)
11181
+ return;
10875
11182
  if (multiple.value) {
10876
11183
  if (states.selectedOptions.has(option)) {
10877
11184
  states.selectedOptions.delete(option);
@@ -10885,129 +11192,195 @@ ${$(r2)}`), n2;
10885
11192
  emitChange(option.value);
10886
11193
  hidePopover();
10887
11194
  }
10888
- inputRef.value.focus();
10889
- handleResetState();
11195
+ selectedCallback();
10890
11196
  };
10891
11197
  const handleClear = (e) => {
10892
11198
  e.stopPropagation();
10893
11199
  states.selectedOptions.clear();
10894
- emitChange(multiple.value ? [] : "");
10895
11200
  hidePopover();
10896
- handleResetState();
11201
+ handleResetInputValue();
11202
+ emitChange(multiple.value ? [] : "");
11203
+ emit("clear", multiple.value ? [] : "");
10897
11204
  };
10898
- const searchKey = useDebouncedRef("");
10899
- const isRemoteSearch = vue.computed(() => typeof remoteMethod.value === "function");
10900
- const searchLoading = vue.ref(false);
10901
- vue.watchEffect(async () => {
10902
- if (!isRemoteSearch.value || !isPopoverShow.value || !searchKey.value)
10903
- return;
10904
- try {
10905
- searchLoading.value = true;
10906
- await remoteMethod.value(searchKey.value);
10907
- } catch (e) {
10908
- console.error(e);
10909
- } finally {
10910
- searchLoading.value = false;
11205
+ const handleToggleAll = () => {
11206
+ if (isAllSelected.value) {
11207
+ states.selectedOptions.clear();
11208
+ } else {
11209
+ options.value.forEach((option) => {
11210
+ if (option.disabled || states.selectedOptions.has(option))
11211
+ return;
11212
+ states.selectedOptions.add(option);
11213
+ });
10911
11214
  }
10912
- });
10913
- const isEmpty2 = vue.computed(() => [...states.options.values()].every((option) => !option.visible));
11215
+ selectedCallback();
11216
+ emitChange([...states.selectedOptions.values()].map((option) => option.value));
11217
+ };
11218
+ const handleClickOutside = () => {
11219
+ hidePopover();
11220
+ handleBlur();
11221
+ };
10914
11222
  vue.provide(selectKey, vue.reactive({
10915
11223
  props,
10916
- searchKey,
10917
11224
  selectedOptions: vue.unref(states.selectedOptions),
10918
- isRemoteSearch,
10919
11225
  register,
10920
11226
  unregister,
11227
+ registerGroup,
11228
+ unregisterGroup,
10921
11229
  handleOptionSelected
10922
11230
  }));
10923
11231
  vue.onMounted(() => {
10924
11232
  const initializeValue = Array.isArray(modelValue.value) ? modelValue.value : [modelValue.value];
10925
- states.options.forEach((option) => {
11233
+ options.value.forEach((option) => {
10926
11234
  if (initializeValue.includes(option.value)) {
10927
11235
  states.selectedOptions.add(option);
10928
11236
  }
10929
11237
  });
10930
- handleResetState();
11238
+ handleResetInputValue();
11239
+ setTimeout(() => {
11240
+ showOnInit.value && showPopover();
11241
+ });
10931
11242
  });
10932
11243
  return __spreadProps(__spreadValues({}, vue.toRefs(states)), {
11244
+ options,
11245
+ isDisabled,
10933
11246
  selectedLabel,
10934
- selectClass,
10935
11247
  isPopoverShow,
10936
11248
  isHover,
10937
11249
  popperWidth,
10938
- selectTriggerRef,
11250
+ popoverRef,
10939
11251
  inputRef,
10940
- searchKey,
10941
11252
  searchLoading,
10942
- isEmpty: isEmpty2,
11253
+ isOptionsEmpty,
11254
+ isSearchEmpty,
10943
11255
  isFocus,
11256
+ isShowSelectContent,
11257
+ curContentText,
11258
+ isGroup,
11259
+ searchKey,
10944
11260
  setHover,
10945
11261
  cancelHover,
10946
11262
  handleFocus,
10947
11263
  handleInput,
10948
- toggleMenu,
11264
+ handleTogglePopover,
10949
11265
  handleClear,
10950
11266
  onPopoverFirstUpdate,
10951
11267
  hidePopover,
10952
- showPopover
11268
+ showPopover,
11269
+ handleToggleAll,
11270
+ handleOptionSelected,
11271
+ handleClickOutside
10953
11272
  });
10954
11273
  },
10955
11274
  render() {
11275
+ const selectClass = classes({
11276
+ "bk-select": true,
11277
+ "popover-show": this.isPopoverShow,
11278
+ "is-disabled": this.isDisabled,
11279
+ "is-focus": this.isFocus,
11280
+ "is-filterable": this.filterable,
11281
+ [this.size]: true,
11282
+ [this.behavior]: true
11283
+ });
10956
11284
  const modifiers = [{
10957
11285
  name: "offset",
10958
11286
  options: {
10959
11287
  offset: [0, 4]
10960
11288
  }
10961
11289
  }];
10962
- const renderSelectRightIcon = () => {
10963
- if (this.loading) {
10964
- return vue.createVNode(spinner, {
10965
- "class": "spinner"
10966
- }, null);
10967
- }
10968
- if (this.clearable && this.isHover) {
10969
- return vue.createVNode(close$1, {
10970
- "class": "clear-icon",
10971
- "onClick": this.handleClear
11290
+ const renderSelectTrigger = () => {
11291
+ var _a, _b;
11292
+ const suffixIcon = () => {
11293
+ if (this.loading) {
11294
+ return vue.createVNode(BkLoading, {
11295
+ "class": "spinner",
11296
+ "mode": "spin",
11297
+ "size": "mini"
11298
+ }, null);
11299
+ }
11300
+ if (this.clearable && this.isHover) {
11301
+ return vue.createVNode(close$1, {
11302
+ "class": "clear-icon",
11303
+ "onClick": this.handleClear
11304
+ }, null);
11305
+ }
11306
+ return vue.createVNode(angleUp, {
11307
+ "class": "angle-up"
10972
11308
  }, null);
10973
- }
10974
- return vue.createVNode(angleUp, {
10975
- "class": "angle-up"
10976
- }, null);
10977
- };
10978
- const renderEmptySelect = () => {
10979
- if (this.searchLoading) {
10980
- return vue.withDirectives(vue.createVNode("div", {
10981
- "class": "bk-select-empty"
10982
- }, [vue.createVNode(spinner, {
10983
- "class": "spinner"
10984
- }, null), vue.createTextVNode("\u52A0\u8F7D\u4E2D...")]), [[vue.vShow, this.searchLoading]]);
10985
- }
10986
- if (this.isEmpty) {
10987
- return vue.withDirectives(vue.createVNode("div", {
10988
- "class": "bk-select-empty"
10989
- }, [vue.createTextVNode("\u65E0\u5339\u914D\u6570\u636E")]), [[vue.vShow, this.isEmpty]]);
10990
- }
10991
- return null;
11309
+ };
11310
+ const renderTriggerInput = () => {
11311
+ if (this.multipleMode === "tag") {
11312
+ return vue.createVNode("div", {
11313
+ "class": "bk-select-tag"
11314
+ }, [[...this.selectedOptions.values()].map((option) => vue.createVNode(BkTag, {
11315
+ "closable": true,
11316
+ "style": {
11317
+ marginTop: "3px"
11318
+ },
11319
+ "theme": this.tagTheme,
11320
+ "onClose": () => this.handleOptionSelected(option)
11321
+ }, {
11322
+ default: () => [option.label]
11323
+ })), vue.withDirectives(vue.createVNode("input", {
11324
+ "class": "bk-select-tag-input",
11325
+ "ref": "inputRef",
11326
+ "type": "text",
11327
+ "placeholder": !this.selectedOptions.size ? this.placeholder : "",
11328
+ "readonly": !this.filterable || !this.isPopoverShow,
11329
+ "onUpdate:modelValue": ($event) => this.searchKey = $event,
11330
+ "onFocus": this.handleFocus
11331
+ }, null), [[vue.vModelText, this.searchKey]])]);
11332
+ }
11333
+ return vue.withDirectives(vue.createVNode("input", {
11334
+ "ref": "inputRef",
11335
+ "type": "text",
11336
+ "class": "bk-select-input",
11337
+ "style": {
11338
+ paddingLeft: this.$slots.prefixIcon ? "20px" : "10px"
11339
+ },
11340
+ "onUpdate:modelValue": ($event) => this.currentSelectedLabel = $event,
11341
+ "placeholder": this.currentPlaceholder,
11342
+ "readonly": !this.filterable || !this.isPopoverShow,
11343
+ "onFocus": this.handleFocus,
11344
+ "onInput": this.handleInput
11345
+ }, null), [[vue.vModelText, this.currentSelectedLabel]]);
11346
+ };
11347
+ return vue.createVNode("div", {
11348
+ "class": "bk-select-trigger",
11349
+ "onClick": this.handleTogglePopover,
11350
+ "onMouseenter": this.setHover,
11351
+ "onMouseleave": this.cancelHover
11352
+ }, [this.$slots.prefixIcon ? vue.createVNode("span", {
11353
+ "class": "bk-select-prefix"
11354
+ }, [(_b = (_a = this.$slots).prefixIcon) == null ? void 0 : _b.call(_a)]) : null, renderTriggerInput(), suffixIcon()]);
10992
11355
  };
10993
11356
  const renderSelectContent = () => {
10994
11357
  var _a, _b;
10995
- return vue.createVNode("div", null, [renderEmptySelect(), vue.withDirectives(vue.createVNode("div", {
11358
+ return vue.createVNode("div", null, [!this.isShowSelectContent && vue.createVNode("div", {
11359
+ "class": "bk-select-empty"
11360
+ }, [this.searchLoading && vue.createVNode(BkLoading, {
11361
+ "class": "mr5",
11362
+ "mode": "spin",
11363
+ "size": "mini"
11364
+ }, null), this.curContentText]), vue.createVNode("div", {
10996
11365
  "class": "bk-select-content"
10997
11366
  }, [vue.createVNode("div", {
10998
11367
  "class": "bk-select-dropdown",
10999
11368
  "style": {
11000
11369
  maxHeight: `${this.scrollHeight}px`
11001
11370
  }
11002
- }, [vue.createVNode("ul", {
11371
+ }, [vue.withDirectives(vue.createVNode("ul", {
11003
11372
  "class": "bk-select-options"
11004
- }, [(_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a)])]), this.$slots.extension ? vue.createVNode("div", {
11373
+ }, [this.multiple && this.showSelectAll && !this.searchKey && vue.createVNode("li", {
11374
+ "class": "bk-select-option",
11375
+ "onClick": this.handleToggleAll
11376
+ }, [this.selectAllText]), (_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a)]), [[vue.vShow, this.isShowSelectContent]])]), this.$slots.extension && vue.createVNode("div", {
11005
11377
  "class": "bk-select-extension"
11006
- }, [this.$slots.extension()]) : null]), [[vue.vShow, !this.searchLoading && !this.isEmpty]])]);
11378
+ }, [this.$slots.extension()])])]);
11007
11379
  };
11008
11380
  return vue.withDirectives(vue.createVNode("div", {
11009
- "class": this.selectClass
11381
+ "class": selectClass
11010
11382
  }, [vue.createVNode(BkPopover, {
11383
+ "ref": "popoverRef",
11011
11384
  "theme": "light",
11012
11385
  "trigger": "manual",
11013
11386
  "width": this.popperWidth,
@@ -11017,32 +11390,9 @@ ${$(r2)}`), n2;
11017
11390
  "modifiers": modifiers,
11018
11391
  "handleFirstUpdate": this.onPopoverFirstUpdate
11019
11392
  }, {
11020
- default: () => {
11021
- var _a, _b;
11022
- return vue.createVNode("div", {
11023
- "class": "bk-select-trigger",
11024
- "ref": "selectTriggerRef",
11025
- "onClick": this.toggleMenu,
11026
- "onMouseenter": this.setHover,
11027
- "onMouseleave": this.cancelHover
11028
- }, [this.$slots.prefixIcon ? vue.createVNode("span", {
11029
- "class": "bk-select-prefix"
11030
- }, [(_b = (_a = this.$slots).prefixIcon) == null ? void 0 : _b.call(_a)]) : null, vue.withDirectives(vue.createVNode("input", {
11031
- "ref": "inputRef",
11032
- "type": "text",
11033
- "class": "bk-select-input",
11034
- "style": {
11035
- paddingLeft: this.$slots.prefixIcon ? "20px" : "10px"
11036
- },
11037
- "onUpdate:modelValue": ($event) => this.currentSelectedLabel = $event,
11038
- "placeholder": this.currentPlaceholder,
11039
- "readonly": !this.filterable || !this.isPopoverShow,
11040
- "onFocus": this.handleFocus,
11041
- "onInput": this.handleInput
11042
- }, null), [[vue.vModelText, this.currentSelectedLabel]]), renderSelectRightIcon()]);
11043
- },
11393
+ default: () => renderSelectTrigger(),
11044
11394
  content: () => renderSelectContent()
11045
- })]), [[vue.resolveDirective("clickoutside"), this.hidePopover]]);
11395
+ })]), [[vue.resolveDirective("clickoutside"), this.handleClickOutside]]);
11046
11396
  }
11047
11397
  });
11048
11398
  const BkSelect = withInstallProps(Component$a, { Option: BkOption, Group: OptionGroup });
@@ -11462,7 +11812,7 @@ ${$(r2)}`), n2;
11462
11812
  }
11463
11813
  };
11464
11814
  var Component$6 = vue.defineComponent({
11465
- name: "BkVirtualRender",
11815
+ name: "VirtualRender",
11466
11816
  directives: {
11467
11817
  bkVirtualRender: virtualRender
11468
11818
  },
@@ -11530,8 +11880,8 @@ ${$(r2)}`), n2;
11530
11880
  const handleChangeListConfig = () => {
11531
11881
  handleListChanged(props.list);
11532
11882
  };
11533
- const listLength = vue.reactive(vue.ref(0));
11534
- const innerHeight = vue.reactive(vue.ref(0));
11883
+ const listLength = vue.ref(0);
11884
+ const innerHeight = vue.ref(0);
11535
11885
  const handleListChanged = (list) => {
11536
11886
  listLength.value = Math.ceil((list || []).length / props.groupItemCount);
11537
11887
  pagination2.count = listLength.value;
@@ -11561,7 +11911,7 @@ ${$(r2)}`), n2;
11561
11911
  const el = (_a = refRoot.value) == null ? void 0 : _a.parentNode;
11562
11912
  computedVirtualIndex(props.lineHeight, handleScrollCallback, pagination2, el, null);
11563
11913
  };
11564
- const localList = vue.computed(() => (props.list || []).map((item, index) => Object.assign(item, {
11914
+ const localList = vue.computed(() => (props.list || []).map((item, index) => __spreadProps(__spreadValues({}, item), {
11565
11915
  $index: index
11566
11916
  })));
11567
11917
  const calcList = vue.computed(() => localList.value.slice(pagination2.startIndex * props.groupItemCount, (pagination2.endIndex + props.preloadItemCount) * props.groupItemCount));
@@ -12342,6 +12692,7 @@ ${$(r2)}`), n2;
12342
12692
  var Component$4 = vue.defineComponent({
12343
12693
  name: "Table",
12344
12694
  props: tableProps,
12695
+ emits: ["column-pick", "row-click", "page-limit-change", "page-value-change"],
12345
12696
  setup(props, ctx) {
12346
12697
  const activeCols = vue.reactive(resolveActiveColumns(props));
12347
12698
  const colgroups = vue.reactive(props.columns.map((col) => __spreadProps(__spreadValues({}, col), {
@@ -12376,7 +12727,7 @@ ${$(r2)}`), n2;
12376
12727
  activeColumns: getActiveColumns(),
12377
12728
  scrollTranslateY: 0
12378
12729
  });
12379
- vue.watch(() => [props.activeColumn, props.columns, props.pagination], () => {
12730
+ vue.watch(() => [props.activeColumn, props.columns], () => {
12380
12731
  vue.nextTick(() => {
12381
12732
  reactiveProp.activeColumns = getActiveColumns();
12382
12733
  const cols = resolveActiveColumns(props);
@@ -12385,8 +12736,6 @@ ${$(r2)}`), n2;
12385
12736
  active: cols.some((colIndex) => colIndex === index)
12386
12737
  });
12387
12738
  });
12388
- pagination2 = resolvePaginationOption(props.pagination, pagination2);
12389
- resetStartEndIndex();
12390
12739
  });
12391
12740
  }, {
12392
12741
  deep: true
@@ -12395,6 +12744,10 @@ ${$(r2)}`), n2;
12395
12744
  const wrapperStyle = vue.computed(() => ({
12396
12745
  minHeight: resolveNumberOrStringToPix(props.minHeight, "auto")
12397
12746
  }));
12747
+ vue.watchEffect(() => {
12748
+ pagination2 = resolvePaginationOption(props.pagination, pagination2);
12749
+ resetStartEndIndex();
12750
+ });
12398
12751
  const pageData = vue.computed(() => props.data.slice(startIndex.value, endIndex.value));
12399
12752
  const localPagination = vue.computed(() => {
12400
12753
  if (!props.pagination) {
@@ -12472,67 +12825,6 @@ ${$(r2)}`), n2;
12472
12825
  }
12473
12826
  });
12474
12827
  const BkTable = withInstall(Component$4);
12475
- var Component$3 = vue.defineComponent({
12476
- name: "Tag",
12477
- props: {
12478
- theme: PropTypes.theme(["success", "info", "warning", "danger"]).def(""),
12479
- closable: PropTypes.bool.def(false),
12480
- type: PropTypes.commonType(["", "filled", "stroke"]).def(""),
12481
- checkable: PropTypes.bool.def(false),
12482
- checked: PropTypes.bool.def(false),
12483
- radius: PropTypes.string.def("2px"),
12484
- extCls: PropTypes.string.def("")
12485
- },
12486
- emits: ["change", "close"],
12487
- slots: ["icon"],
12488
- setup(props, {
12489
- emit
12490
- }) {
12491
- const wrapperCls = vue.computed(() => classes({
12492
- "bk-tag-closable": props.closable,
12493
- "bk-tag-checkable": props.checkable,
12494
- "bk-tag-check": props.checked,
12495
- [`bk-tag-${props.type}`]: props.type,
12496
- [`bk-tag-${props.theme}`]: props.theme,
12497
- [props.extCls]: !!props.extCls
12498
- }, "bk-tag"));
12499
- const wrapperStyle = vue.computed(() => ({
12500
- borderRadius: props.radius
12501
- }));
12502
- const handleClose = (e) => {
12503
- e.preventDefault();
12504
- e.stopPropagation();
12505
- emit("close", e);
12506
- };
12507
- const handleClick = (e) => {
12508
- e.preventDefault();
12509
- e.stopPropagation();
12510
- if (props.checkable) {
12511
- emit("change", !props.checked);
12512
- }
12513
- };
12514
- return {
12515
- wrapperCls,
12516
- wrapperStyle,
12517
- handleClose,
12518
- handleClick
12519
- };
12520
- },
12521
- render() {
12522
- var _a, _b;
12523
- return vue.createVNode("div", {
12524
- "class": this.wrapperCls,
12525
- "style": this.wrapperStyle,
12526
- "onClick": this.handleClick
12527
- }, [this.$slots.icon ? vue.createVNode("span", {
12528
- "class": "bk-tag-icon"
12529
- }, [this.$slots.icon()]) : "", vue.createVNode("span", null, [(_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a)]), this.closable ? vue.createVNode(error, {
12530
- "class": "bk-tag-close",
12531
- "onClick": this.handleClose
12532
- }, null) : ""]);
12533
- }
12534
- });
12535
- const BkTag = withInstall(Component$3);
12536
12828
  var bkDivider = vue.defineComponent({
12537
12829
  name: "Divider",
12538
12830
  props: {
@@ -13382,7 +13674,7 @@ ${$(r2)}`), n2;
13382
13674
  default: true
13383
13675
  }
13384
13676
  };
13385
- var Component$2 = vue.defineComponent({
13677
+ var Component$3 = vue.defineComponent({
13386
13678
  name: "Menu",
13387
13679
  props: menuProps,
13388
13680
  emits: ["update:activeKey", "update:openKeys", "click", "openChange"],
@@ -13623,7 +13915,7 @@ ${$(r2)}`), n2;
13623
13915
  };
13624
13916
  }
13625
13917
  });
13626
- const BkMenu = withInstallProps(Component$2, { Item, Submenu, Group });
13918
+ const BkMenu = withInstallProps(Component$3, { Item, Submenu, Group });
13627
13919
  const TitleProps = {
13628
13920
  sideTitle: {
13629
13921
  type: String,
@@ -17072,7 +17364,7 @@ ${$(r2)}`), n2;
17072
17364
  },
17073
17365
  disableDate: Function
17074
17366
  };
17075
- var Component$1 = vue.defineComponent({
17367
+ var Component$2 = vue.defineComponent({
17076
17368
  name: "DatePicker",
17077
17369
  directives: {
17078
17370
  clickoutside: ClickOutside
@@ -17583,7 +17875,7 @@ ${$(r2)}`), n2;
17583
17875
  })]), [[vue.resolveDirective("clickoutside"), this.handleClose]]);
17584
17876
  }
17585
17877
  });
17586
- const BkDatePicker = withInstall(Component$1);
17878
+ const BkDatePicker = withInstall(Component$2);
17587
17879
  ({
17588
17880
  title: Array,
17589
17881
  extCls: PropTypes.string,
@@ -17598,7 +17890,7 @@ ${$(r2)}`), n2;
17598
17890
  targetList: Array,
17599
17891
  emptyContent: Array
17600
17892
  });
17601
- var Transfer = vue.defineComponent({
17893
+ var Component$1 = vue.defineComponent({
17602
17894
  name: "Transfer",
17603
17895
  props: {
17604
17896
  title: {
@@ -18006,9 +18298,7 @@ ${$(r2)}`), n2;
18006
18298
  }, [getHeaderHtml("right-header"), getListContentHtml("right")])]);
18007
18299
  }
18008
18300
  });
18009
- Transfer.install = (Vue) => {
18010
- Vue.component(Transfer.name, Transfer);
18011
- };
18301
+ const Transfer = withInstall(Component$1);
18012
18302
  const treeProps = {
18013
18303
  data: PropTypes.arrayOf(PropTypes.any).def([]),
18014
18304
  label: PropTypes.oneOfType([PropTypes.func.def(void 0), PropTypes.string.def("label")]),
@@ -18030,7 +18320,7 @@ ${$(r2)}`), n2;
18030
18320
  callback: PropTypes.func.def(null),
18031
18321
  cache: PropTypes.bool.def(true)
18032
18322
  }),
18033
- offsetLeft: PropTypes.number.def(15)
18323
+ offsetLeft: PropTypes.number.def(5)
18034
18324
  };
18035
18325
  var rngBrowser = { exports: {} };
18036
18326
  var getRandomValues = typeof crypto != "undefined" && crypto.getRandomValues && crypto.getRandomValues.bind(crypto) || typeof msCrypto != "undefined" && typeof window.msCrypto.getRandomValues == "function" && msCrypto.getRandomValues.bind(msCrypto);
@@ -18176,8 +18466,12 @@ ${$(r2)}`), n2;
18176
18466
  const outputData = [];
18177
18467
  let order2 = 0;
18178
18468
  const schema = /* @__PURE__ */ new Map();
18179
- function isCachedTreeNodeOpened(uuid2) {
18180
- return (cachedSchema || []).some((item) => item.__uuid === uuid2 && item.__isOpen);
18469
+ function isCachedTreeNodeOpened(uuid2, node) {
18470
+ const cached = (cachedSchema || []).find((item) => item.__uuid === uuid2);
18471
+ if (cached) {
18472
+ return cached.__isOpen;
18473
+ }
18474
+ return node.isOpen;
18181
18475
  }
18182
18476
  function flatten(array, depth = 0, parent = null, path = null) {
18183
18477
  for (let i2 = 0; i2 < array.length; i2++) {
@@ -18187,7 +18481,7 @@ ${$(r2)}`), n2;
18187
18481
  } else {
18188
18482
  if (typeof item === "object" && item !== null) {
18189
18483
  const uuid2 = item.__uuid || uuid_1.v4();
18190
- const isOpen = isCachedTreeNodeOpened(uuid2);
18484
+ const isOpen = isCachedTreeNodeOpened(uuid2, item);
18191
18485
  const currentPath = path !== null ? `${path}-${i2}` : `${i2}`;
18192
18486
  const attrs = {
18193
18487
  __depth: depth,
@@ -18200,7 +18494,7 @@ ${$(r2)}`), n2;
18200
18494
  __isRoot: parent === null,
18201
18495
  __order: order2,
18202
18496
  __isOpen: isOpen,
18203
- __checked: false,
18497
+ __checked: !!item.checked,
18204
18498
  [children]: null
18205
18499
  };
18206
18500
  Object.assign(item, { __uuid: uuid2 });
@@ -18287,7 +18581,7 @@ ${$(r2)}`), n2;
18287
18581
  const { __checked } = getSchemaVal(schema, item.__uuid) || {};
18288
18582
  return {
18289
18583
  "is-checked": __checked,
18290
- "bk-node-row": true
18584
+ [resolveClassName("node-row")]: true
18291
18585
  };
18292
18586
  };
18293
18587
  const updateTreeNode = (path, treeData, childKey, nodekey, nodeValue) => {
@@ -18304,6 +18598,7 @@ ${$(r2)}`), n2;
18304
18598
  var Component = vue.defineComponent({
18305
18599
  name: "Tree",
18306
18600
  props: treeProps,
18601
+ emits: ["check"],
18307
18602
  setup(props, ctx) {
18308
18603
  const formatData = getFlatdata(props);
18309
18604
  const checkedNodes = [];
@@ -18344,9 +18639,9 @@ ${$(r2)}`), n2;
18344
18639
  return false;
18345
18640
  };
18346
18641
  const getRootIcon = (item) => isItemOpen(item) ? vue.createVNode(folderShapeOpen, {
18347
- "class": "bk-tree-icon"
18642
+ "class": resolveClassName("tree-icon")
18348
18643
  }, null) : vue.createVNode(folder, {
18349
- "class": "bk-tree-icon"
18644
+ "class": resolveClassName("tree-icon")
18350
18645
  }, null);
18351
18646
  const renderPrefixVal = (val) => {
18352
18647
  if (typeof val === "string") {
@@ -18394,7 +18689,7 @@ ${$(r2)}`), n2;
18394
18689
  }
18395
18690
  if (prefixFnVal === "default" || typeof props.prefixIcon === "boolean" && props.prefixIcon) {
18396
18691
  return isRootNode(item) || hasChildNode(item) ? getRootIcon(item) : vue.createVNode(textFile, {
18397
- "class": "bk-tree-icon"
18692
+ "class": resolveClassName("tree-icon")
18398
18693
  }, null);
18399
18694
  }
18400
18695
  return null;
@@ -18487,9 +18782,32 @@ ${$(r2)}`), n2;
18487
18782
  "style": getNodeLineStyle(maxDeep - index)
18488
18783
  }, null));
18489
18784
  };
18785
+ const root = vue.ref();
18786
+ const setNodeTextStyle = () => {
18787
+ var _a;
18788
+ if ((_a = root.value) == null ? void 0 : _a.$el) {
18789
+ const selector = `.${resolveClassName("tree-node")}`;
18790
+ const ctxSelector = `.${resolveClassName("node-content")}`;
18791
+ Array.prototype.forEach.call(root.value.$el.querySelectorAll(selector), (nodeEl) => {
18792
+ const txtSpans = nodeEl.querySelectorAll(`${ctxSelector} span`);
18793
+ const lastSpan = Array.prototype.slice.call(txtSpans, -1)[0];
18794
+ if (lastSpan) {
18795
+ const maxWidth = nodeEl.offsetWidth - lastSpan.offsetLeft;
18796
+ lastSpan.style.setProperty("max-width", `${maxWidth}px`);
18797
+ }
18798
+ });
18799
+ }
18800
+ };
18801
+ vue.onMounted(() => {
18802
+ setNodeTextStyle();
18803
+ });
18804
+ vue.onUpdated(() => {
18805
+ setNodeTextStyle();
18806
+ });
18490
18807
  return {
18491
18808
  renderData,
18492
18809
  flatData,
18810
+ root,
18493
18811
  hanldeTreeNodeClick,
18494
18812
  handleNodeContentClick,
18495
18813
  handleNodeActionClick,
@@ -18508,19 +18826,23 @@ ${$(r2)}`), n2;
18508
18826
  "class": getNodeItemClass(item, this.flatData.schema, props),
18509
18827
  "style": getNodeItemStyle(item, props, this.flatData)
18510
18828
  }, [vue.createVNode("span", {
18511
- "class": "node-action",
18829
+ "class": resolveClassName("node-action"),
18512
18830
  "onClick": () => this.handleNodeActionClick(item)
18513
18831
  }, [this.getActionIcon(item)]), vue.createVNode("span", {
18514
- "class": "node-content",
18832
+ "class": resolveClassName("node-content"),
18515
18833
  "onClick": () => this.handleNodeContentClick(item)
18516
- }, [[this.getNodePrefixIcon(item), this.getLoadingIcon(item)], vue.createVNode("span", null, [getLabel(item, props)])]), this.getVirtualLines(item)])]);
18834
+ }, [[this.getNodePrefixIcon(item), this.getLoadingIcon(item)], vue.createVNode("span", {
18835
+ "class": resolveClassName("node-text")
18836
+ }, [getLabel(item, props)])]), this.getVirtualLines(item)])]);
18517
18837
  return vue.createVNode(BkVirtualRender, {
18518
- "class": "bk-tree",
18838
+ "class": resolveClassName("tree"),
18519
18839
  "style": getTreeStyle(null, props),
18520
18840
  "list": this.renderData,
18521
18841
  "lineHeight": props.lineHeight,
18522
18842
  "enabled": props.virtualRender,
18523
- "throttleDelay": 0
18843
+ "contentClassName": resolveClassName("container"),
18844
+ "throttleDelay": 0,
18845
+ "ref": "root"
18524
18846
  }, {
18525
18847
  default: (scoped) => (scoped.data || []).map(renderTreeNode)
18526
18848
  });
@@ -18849,6 +19171,7 @@ ${$(r2)}`), n2;
18849
19171
  RadioButton,
18850
19172
  RadioGroup,
18851
19173
  Rate: BkRate,
19174
+ Swiper: BkSwiper,
18852
19175
  Select: BkSelect,
18853
19176
  BkOption,
18854
19177
  BkOptionGroup: OptionGroup,
@@ -18925,6 +19248,7 @@ ${$(r2)}`), n2;
18925
19248
  exports2.Select = BkSelect;
18926
19249
  exports2.Sideslider = BkSideslider;
18927
19250
  exports2.Steps = BkSteps;
19251
+ exports2.Swiper = BkSwiper;
18928
19252
  exports2.Switcher = BkSwitcher;
18929
19253
  exports2.Tab = BKTab;
18930
19254
  exports2.TabPanel = BKTabPanel;