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