bkui-vue 0.0.1-beta.151 → 0.0.1-beta.154

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.esm.js CHANGED
@@ -6321,7 +6321,7 @@ var lodash = { exports: {} };
6321
6321
  function valuesIn(object) {
6322
6322
  return object == null ? [] : baseValues(object, keysIn(object));
6323
6323
  }
6324
- function clamp(number, lower, upper) {
6324
+ function clamp2(number, lower, upper) {
6325
6325
  if (upper === undefined$1) {
6326
6326
  upper = lower;
6327
6327
  lower = undefined$1;
@@ -6995,7 +6995,7 @@ var lodash = { exports: {} };
6995
6995
  lodash2.camelCase = camelCase;
6996
6996
  lodash2.capitalize = capitalize;
6997
6997
  lodash2.ceil = ceil;
6998
- lodash2.clamp = clamp;
6998
+ lodash2.clamp = clamp2;
6999
6999
  lodash2.clone = clone2;
7000
7000
  lodash2.cloneDeep = cloneDeep;
7001
7001
  lodash2.cloneDeepWith = cloneDeepWith;
@@ -8481,7 +8481,7 @@ const warn = (props2, context) => {
8481
8481
  warn.displayName = "warn";
8482
8482
  warn.inheritAttrs = false;
8483
8483
  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"}}]}');
8484
- var Component$E = defineComponent({
8484
+ var Component$F = defineComponent({
8485
8485
  name: "Alert",
8486
8486
  props: {
8487
8487
  theme: PropTypes.theme(["info", "success", "warning", "error"]).def("info"),
@@ -8538,8 +8538,8 @@ var Component$E = defineComponent({
8538
8538
  }, [this.closeText ? this.closeText : createVNode(closeLine, null, null)])])]);
8539
8539
  }
8540
8540
  });
8541
- const BkAlert = withInstall(Component$E);
8542
- var Component$D = defineComponent({
8541
+ const BkAlert = withInstall(Component$F);
8542
+ var Component$E = defineComponent({
8543
8543
  name: "AnimateNumber",
8544
8544
  props: {
8545
8545
  value: PropTypes.number.def(0),
@@ -8587,7 +8587,7 @@ var Component$D = defineComponent({
8587
8587
  return () => createVNode("span", null, [formatValue.value]);
8588
8588
  }
8589
8589
  });
8590
- const BkAnimateNumber = withInstall(Component$D);
8590
+ const BkAnimateNumber = withInstall(Component$E);
8591
8591
  const on$1 = (() => {
8592
8592
  if (document.addEventListener) {
8593
8593
  return (element, event, handler) => {
@@ -8616,7 +8616,7 @@ const off$1 = (() => {
8616
8616
  }
8617
8617
  };
8618
8618
  })();
8619
- var Component$C = defineComponent({
8619
+ var Component$D = defineComponent({
8620
8620
  name: "Affix",
8621
8621
  props: {
8622
8622
  offsetTop: PropTypes.number.def(0),
@@ -8741,8 +8741,8 @@ var Component$C = defineComponent({
8741
8741
  };
8742
8742
  }
8743
8743
  });
8744
- const BkAffix = withInstall(Component$C);
8745
- var Component$B = defineComponent({
8744
+ const BkAffix = withInstall(Component$D);
8745
+ var Component$C = defineComponent({
8746
8746
  name: "Backtop",
8747
8747
  props: {
8748
8748
  visibilityHeight: PropTypes.number.def(200),
@@ -8809,8 +8809,8 @@ var Component$B = defineComponent({
8809
8809
  });
8810
8810
  }
8811
8811
  });
8812
- const BkBacktop = withInstall(Component$B);
8813
- var Component$A = defineComponent({
8812
+ const BkBacktop = withInstall(Component$C);
8813
+ var Component$B = defineComponent({
8814
8814
  name: "Badge",
8815
8815
  props: {
8816
8816
  theme: PropTypes.string.def("primary"),
@@ -8886,8 +8886,8 @@ var Component$A = defineComponent({
8886
8886
  }, [(_f = (_e = (_d = this.$slots).icon) == null ? void 0 : _e.call(_d)) != null ? _f : number]) : ""]);
8887
8887
  }
8888
8888
  });
8889
- const BkBadge = withInstall(Component$A);
8890
- var Component$z = defineComponent({
8889
+ const BkBadge = withInstall(Component$B);
8890
+ var Component$A = defineComponent({
8891
8891
  name: "Breadcrumb",
8892
8892
  props: {
8893
8893
  extCls: PropTypes.string,
@@ -8986,7 +8986,7 @@ var BreadcrumbItem = defineComponent({
8986
8986
  };
8987
8987
  }
8988
8988
  });
8989
- const BkBreadcrumb = withInstallProps(Component$z, { Item: BreadcrumbItem });
8989
+ const BkBreadcrumb = withInstallProps(Component$A, { Item: BreadcrumbItem });
8990
8990
  let BkLoadingMode;
8991
8991
  (function(BkLoadingMode2) {
8992
8992
  BkLoadingMode2["Default"] = "default";
@@ -9017,7 +9017,7 @@ const loadingTypes = {
9017
9017
  color: PropTypes.string.def("white"),
9018
9018
  zIndex: PropTypes.number.def(1)
9019
9019
  };
9020
- var Component$y = defineComponent({
9020
+ var Component$z = defineComponent({
9021
9021
  name: "Loading",
9022
9022
  props: loadingTypes,
9023
9023
  setup(props2, ctx) {
@@ -9073,7 +9073,7 @@ var Component$y = defineComponent({
9073
9073
  };
9074
9074
  }
9075
9075
  });
9076
- const BkLoading = withInstallProps(Component$y, { setDefaultIndicator, BkLoadingMode, BkLoadingSize }, true);
9076
+ const BkLoading = withInstallProps(Component$z, { setDefaultIndicator, BkLoadingMode, BkLoadingSize }, true);
9077
9077
  const btnSizes = ["", "small", "large"];
9078
9078
  const buttonProps = {
9079
9079
  theme: PropTypes.theme().def(""),
@@ -9093,7 +9093,7 @@ const buttonProps = {
9093
9093
  default: "button"
9094
9094
  }
9095
9095
  };
9096
- var Component$x = defineComponent({
9096
+ var Component$y = defineComponent({
9097
9097
  name: "Button",
9098
9098
  props: buttonProps,
9099
9099
  emits: ["click", "mouseover"],
@@ -9182,7 +9182,7 @@ var ButtonGroup = defineComponent({
9182
9182
  };
9183
9183
  }
9184
9184
  });
9185
- const BkButton = withInstallProps(Component$x, { ButtonGroup });
9185
+ const BkButton = withInstallProps(Component$y, { ButtonGroup });
9186
9186
  const inputType = {
9187
9187
  type: PropTypes.string.def("text"),
9188
9188
  clearable: PropTypes.bool,
@@ -9204,7 +9204,8 @@ const inputType = {
9204
9204
  precision: PropTypes.number.def(0).validate((val) => val >= 0 && val < 20),
9205
9205
  modelValue: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
9206
9206
  size: PropTypes.size(),
9207
- rows: PropTypes.number
9207
+ rows: PropTypes.number,
9208
+ selectReadonly: PropTypes.bool.def(false)
9208
9209
  };
9209
9210
  let EVENTS$2;
9210
9211
  (function(EVENTS2) {
@@ -9245,7 +9246,7 @@ const inputEmitEventsType = {
9245
9246
  [EVENTS$2.COMPOSITIONUPDATE]: CompositionEventFunction,
9246
9247
  [EVENTS$2.COMPOSITIONEND]: CompositionEventFunction
9247
9248
  };
9248
- var Component$w = defineComponent({
9249
+ var Component$x = defineComponent({
9249
9250
  name: "Input",
9250
9251
  inheritAttrs: false,
9251
9252
  props: inputType,
@@ -9267,7 +9268,7 @@ var Component$w = defineComponent({
9267
9268
  const inputCls = computed(() => classes({
9268
9269
  [`${inputClsPrefix.value}--${props2.size}`]: !!props2.size,
9269
9270
  "is-focused": isFocused.value,
9270
- "is-readonly": props2.readonly,
9271
+ "is-readonly": props2.readonly && !props2.selectReadonly,
9271
9272
  "is-disabled": props2.disabled,
9272
9273
  "is-simplicity": props2.behavior === "simplicity",
9273
9274
  [`${cls}`]: !!cls
@@ -9461,8 +9462,8 @@ var Component$w = defineComponent({
9461
9462
  };
9462
9463
  }
9463
9464
  });
9464
- const BkInput = withInstall(Component$w);
9465
- var Component$v = defineComponent({
9465
+ const BkInput = withInstall(Component$x);
9466
+ var Component$w = defineComponent({
9466
9467
  name: "Card",
9467
9468
  props: {
9468
9469
  title: PropTypes.string,
@@ -9555,7 +9556,7 @@ var Component$v = defineComponent({
9555
9556
  }, [(_l = (_k = (_j = this.$slots).footer) == null ? void 0 : _k.call(_j)) != null ? _l : "Footer"]) : ""]) : ""]);
9556
9557
  }
9557
9558
  });
9558
- const BkCard = withInstall(Component$v);
9559
+ const BkCard = withInstall(Component$w);
9559
9560
  const checkboxGroupKey = Symbol("CheckboxGroup");
9560
9561
  function useFocus$1() {
9561
9562
  const isFocus = ref(false);
@@ -9656,7 +9657,7 @@ const checkboxProps = {
9656
9657
  beforeChange: PropTypes.func,
9657
9658
  size: PropTypes.size().def("large")
9658
9659
  };
9659
- var Component$u = defineComponent({
9660
+ var Component$v = defineComponent({
9660
9661
  name: "Checkbox",
9661
9662
  props: checkboxProps,
9662
9663
  emits: ["update:modelValue", "change"],
@@ -9760,7 +9761,7 @@ var BkCheckboxGroup = defineComponent({
9760
9761
  }, [(_a = this.$slots) == null ? void 0 : _a.default()]);
9761
9762
  }
9762
9763
  });
9763
- const BkCheckbox = withInstallProps(Component$u, { Group: BkCheckboxGroup });
9764
+ const BkCheckbox = withInstallProps(Component$v, { Group: BkCheckboxGroup });
9764
9765
  const propsCollapse = {
9765
9766
  list: PropTypes.arrayOf(PropTypes.any).def([]),
9766
9767
  idFiled: PropTypes.string.def("$index"),
@@ -10087,7 +10088,7 @@ const propsMixin$1 = {
10087
10088
  dialogType: PropTypes.commonType(["show", "operation", "confirm", "process"], "dialogType").def("operation"),
10088
10089
  multiInstance: PropTypes.bool.def(true)
10089
10090
  };
10090
- var Component$t = defineComponent({
10091
+ var Component$u = defineComponent({
10091
10092
  name: "Modal",
10092
10093
  props: __spreadValues({}, propsMixin$1),
10093
10094
  emits: ["quick-close", "quickClose", "hidden", "shown", "close"],
@@ -10189,7 +10190,7 @@ var Component$t = defineComponent({
10189
10190
  })]);
10190
10191
  }
10191
10192
  });
10192
- const BkModal = withInstallProps(Component$t, { propsMixin: propsMixin$1 }, true);
10193
+ const BkModal = withInstallProps(Component$u, { propsMixin: propsMixin$1 }, true);
10193
10194
  const props = __spreadProps(__spreadValues({}, propsMixin$1), {
10194
10195
  width: PropTypes.oneOfType([String, Number]).def(""),
10195
10196
  height: PropTypes.oneOfType([String, Number]).def(""),
@@ -10426,7 +10427,7 @@ var Building = "
10426
10427
  var empty = "";
10427
10428
  var login = "";
10428
10429
  var searchEmpty = "";
10429
- var Component$s = defineComponent({
10430
+ var Component$t = defineComponent({
10430
10431
  name: "Exception",
10431
10432
  props: {
10432
10433
  type: PropTypes.commonType(["404", "403", "500", "building", "empty", "search-empty", "login"], "type").def("404"),
@@ -10470,8 +10471,8 @@ var Component$s = defineComponent({
10470
10471
  };
10471
10472
  }
10472
10473
  });
10473
- const BkException = withInstall(Component$s);
10474
- var Component$r = defineComponent({
10474
+ const BkException = withInstall(Component$t);
10475
+ var Component$s = defineComponent({
10475
10476
  name: "FixedNavbar",
10476
10477
  props: {
10477
10478
  navItems: PropTypes.array.def([]),
@@ -10512,8 +10513,8 @@ var Component$r = defineComponent({
10512
10513
  }, [item.text]) : ""]))]);
10513
10514
  }
10514
10515
  });
10515
- const BkFixedNavbar = withInstall(Component$r);
10516
- var Component$q = defineComponent({
10516
+ const BkFixedNavbar = withInstall(Component$s);
10517
+ var Component$r = defineComponent({
10517
10518
  name: "Link",
10518
10519
  props: {
10519
10520
  theme: PropTypes.theme(["danger", "success", "primary", "warning", "default"]).def("default"),
@@ -10550,7 +10551,7 @@ var Component$q = defineComponent({
10550
10551
  }, [createVNode("span", null, [(_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a)])]);
10551
10552
  }
10552
10553
  });
10553
- const BkLink = withInstall(Component$q);
10554
+ const BkLink = withInstall(Component$r);
10554
10555
  const placements$1 = ["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"];
10555
10556
  const EventProps$2 = {
10556
10557
  onAfterHidden: Function,
@@ -10593,7 +10594,7 @@ const PopoverProps$1 = __spreadValues({
10593
10594
  PropTypes.string
10594
10595
  ]).def([])
10595
10596
  }, EventProps$2);
10596
- var Component$p = defineComponent({
10597
+ var Component$q = defineComponent({
10597
10598
  name: "Popover",
10598
10599
  props: PopoverProps$1,
10599
10600
  emits: ["afterHidden", "afterShow", "update:isShow"],
@@ -10743,7 +10744,7 @@ var Component$p = defineComponent({
10743
10744
  };
10744
10745
  }
10745
10746
  });
10746
- const BkPopover = withInstall(Component$p);
10747
+ const BkPopover = withInstall(Component$q);
10747
10748
  var _populated = false;
10748
10749
  var _ie, _firefox, _opera, _webkit, _chrome;
10749
10750
  var _ie_real_version;
@@ -12875,7 +12876,7 @@ var usePopperId = (props2, prefix = "#") => {
12875
12876
  resetFullscreenElementTag
12876
12877
  };
12877
12878
  };
12878
- var Component$o = defineComponent({
12879
+ var Component$p = defineComponent({
12879
12880
  name: "Popover2",
12880
12881
  components: {
12881
12882
  Content,
@@ -13077,7 +13078,7 @@ var Component$o = defineComponent({
13077
13078
  });
13078
13079
  }
13079
13080
  });
13080
- const BkPopover2 = withInstall(Component$o);
13081
+ const BkPopover2 = withInstall(Component$p);
13081
13082
  const Circle = (_2, {
13082
13083
  attrs,
13083
13084
  slots
@@ -13200,7 +13201,7 @@ const Line = (_2, {
13200
13201
  function _isSlot$6(s2) {
13201
13202
  return typeof s2 === "function" || Object.prototype.toString.call(s2) === "[object Object]" && !isVNode(s2);
13202
13203
  }
13203
- var Component$n = defineComponent({
13204
+ var Component$o = defineComponent({
13204
13205
  name: "Progress",
13205
13206
  props: {
13206
13207
  extCls: PropTypes.string,
@@ -13278,7 +13279,7 @@ var Component$n = defineComponent({
13278
13279
  return createVNode("div", progressProps, [progress2]);
13279
13280
  }
13280
13281
  });
13281
- const BkProgress = withInstall(Component$n);
13282
+ const BkProgress = withInstall(Component$o);
13282
13283
  const radioGroupKey = Symbol("RadioGroup");
13283
13284
  function useFocus() {
13284
13285
  const isFocused = ref(false);
@@ -13375,7 +13376,7 @@ const radioProps = {
13375
13376
  checked: PropTypes.bool.def(false),
13376
13377
  disabled: PropTypes.bool.def(false)
13377
13378
  };
13378
- var Component$m = defineComponent({
13379
+ var Component$n = defineComponent({
13379
13380
  name: "Radio",
13380
13381
  props: radioProps,
13381
13382
  emits: ["change", "update:modelValue"],
@@ -13536,7 +13537,7 @@ var RadioGroup = defineComponent({
13536
13537
  }, [(_a = this.$slots) == null ? void 0 : _a.default()]);
13537
13538
  }
13538
13539
  });
13539
- const BkRadio = withInstallProps(Component$m, { Group: RadioGroup, Button: RadioButton });
13540
+ const BkRadio = withInstallProps(Component$n, { Group: RadioGroup, Button: RadioButton });
13540
13541
  var star = defineComponent({
13541
13542
  name: "Star",
13542
13543
  props: {
@@ -13598,7 +13599,7 @@ var star = defineComponent({
13598
13599
  }, null)])])])])]))]);
13599
13600
  }
13600
13601
  });
13601
- var Component$l = defineComponent({
13602
+ var Component$m = defineComponent({
13602
13603
  name: "Rate",
13603
13604
  components: {
13604
13605
  star
@@ -13673,8 +13674,8 @@ var Component$l = defineComponent({
13673
13674
  }, commonAttrs), null)]]);
13674
13675
  }
13675
13676
  });
13676
- const BkRate = withInstall(Component$l);
13677
- var Component$k = defineComponent({
13677
+ const BkRate = withInstall(Component$m);
13678
+ var Component$l = defineComponent({
13678
13679
  name: "Swiper",
13679
13680
  props: {
13680
13681
  isLoop: PropTypes.bool.def(true),
@@ -13833,7 +13834,7 @@ var Component$k = defineComponent({
13833
13834
  }, null)])]);
13834
13835
  }
13835
13836
  });
13836
- const BkSwiper = withInstall(Component$k);
13837
+ const BkSwiper = withInstall(Component$l);
13837
13838
  const selectKey = Symbol("BkSelect");
13838
13839
  const optionGroupKey = Symbol("BkOptionGroup");
13839
13840
  function useHover() {
@@ -13976,6 +13977,7 @@ var BkOption = defineComponent({
13976
13977
  });
13977
13978
  const multiple = computed(() => select2 == null ? void 0 : select2.multiple);
13978
13979
  const isHover = computed(() => (select2 == null ? void 0 : select2.activeOptionValue) === value.value);
13980
+ const showSelectedIcon = computed(() => select2 == null ? void 0 : select2.showSelectedIcon);
13979
13981
  const handleOptionClick = () => {
13980
13982
  if (disabled.value)
13981
13983
  return;
@@ -13996,6 +13998,7 @@ var BkOption = defineComponent({
13996
13998
  selected,
13997
13999
  multiple,
13998
14000
  isHover,
14001
+ showSelectedIcon,
13999
14002
  handleOptionClick,
14000
14003
  handleMouseEnter
14001
14004
  });
@@ -14016,11 +14019,11 @@ var BkOption = defineComponent({
14016
14019
  }, [(_c = (_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a)) != null ? _c : createVNode("span", {
14017
14020
  "class": "bk-select-option-item",
14018
14021
  "title": this.label
14019
- }, [this.label, this.multiple && this.selected && createVNode(done, {
14020
- "class": "done-icon",
14022
+ }, [this.label]), this.multiple && this.selected && this.showSelectedIcon && createVNode(done, {
14023
+ "class": "bk-select-selected-icon",
14021
14024
  "width": 22,
14022
14025
  "height": 22
14023
- }, null)])]), [[vShow, this.visible]]);
14026
+ }, null)]), [[vShow, this.visible]]);
14024
14027
  }
14025
14028
  });
14026
14029
  var OptionGroup = defineComponent({
@@ -14102,7 +14105,7 @@ var OptionGroup = defineComponent({
14102
14105
  }, [(_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a)]), [[vShow, !this.groupCollapse]])]), [[vShow, this.visible]]);
14103
14106
  }
14104
14107
  });
14105
- var Component$j = defineComponent({
14108
+ var Component$k = defineComponent({
14106
14109
  name: "Tag",
14107
14110
  props: {
14108
14111
  theme: PropTypes.theme(["success", "info", "warning", "danger"]).def(""),
@@ -14164,7 +14167,7 @@ var Component$j = defineComponent({
14164
14167
  }, null) : ""]);
14165
14168
  }
14166
14169
  });
14167
- const BkTag = withInstall(Component$j);
14170
+ const BkTag = withInstall(Component$k);
14168
14171
  function _isSlot$5(s2) {
14169
14172
  return typeof s2 === "function" || Object.prototype.toString.call(s2) === "[object Object]" && !isVNode(s2);
14170
14173
  }
@@ -14253,7 +14256,7 @@ var SelectTagInput = defineComponent({
14253
14256
  }, null), [[vModelText, this.value]]), (_d = (_c = this.$slots) == null ? void 0 : _c.suffix) == null ? void 0 : _d.call(_c)]);
14254
14257
  }
14255
14258
  });
14256
- var Component$i = defineComponent({
14259
+ var Component$j = defineComponent({
14257
14260
  name: "Select",
14258
14261
  directives: {
14259
14262
  clickoutside: ClickOutside
@@ -14283,7 +14286,11 @@ var Component$i = defineComponent({
14283
14286
  scrollLoading: PropTypes.bool.def(false),
14284
14287
  allowCreate: PropTypes.bool.def(false),
14285
14288
  popoverOptions: PropTypes.object.def({}),
14286
- customContent: PropTypes.bool.def(false)
14289
+ customContent: PropTypes.bool.def(false),
14290
+ list: PropTypes.array.def([]),
14291
+ idKey: PropTypes.string.def("value"),
14292
+ displayKey: PropTypes.string.def("label"),
14293
+ showSelectedIcon: PropTypes.bool.def(true)
14287
14294
  },
14288
14295
  emits: ["update:modelValue", "change", "toggle", "clear", "scroll-end", "focus", "blur"],
14289
14296
  setup(props2, {
@@ -14303,7 +14310,8 @@ var Component$i = defineComponent({
14303
14310
  showOnInit,
14304
14311
  multipleMode,
14305
14312
  allowCreate,
14306
- customContent
14313
+ customContent,
14314
+ showSelectedIcon
14307
14315
  } = toRefs(props2);
14308
14316
  const formItem = useFormItem();
14309
14317
  const inputRef = ref();
@@ -14413,8 +14421,8 @@ var Component$i = defineComponent({
14413
14421
  var _a;
14414
14422
  if (val === modelValue.value)
14415
14423
  return;
14416
- emit("change", val);
14417
- emit("update:modelValue", val);
14424
+ emit("change", val, modelValue.value);
14425
+ emit("update:modelValue", val, modelValue.value);
14418
14426
  (_a = formItem == null ? void 0 : formItem.validate) == null ? void 0 : _a.call(formItem, "change");
14419
14427
  };
14420
14428
  const handleTogglePopover = () => {
@@ -14597,6 +14605,7 @@ var Component$i = defineComponent({
14597
14605
  multiple,
14598
14606
  selected,
14599
14607
  activeOptionValue,
14608
+ showSelectedIcon,
14600
14609
  register,
14601
14610
  unregister,
14602
14611
  registerGroup,
@@ -14714,6 +14723,7 @@ var Component$i = defineComponent({
14714
14723
  "modelValue": this.isInput ? this.searchKey : this.selectedLabel.join(","),
14715
14724
  "placeholder": this.isInput ? this.selectedLabel.join(",") || this.placeholder : this.placeholder,
14716
14725
  "readonly": !this.isInput,
14726
+ "selectReadonly": true,
14717
14727
  "disabled": this.isDisabled,
14718
14728
  "behavior": this.behavior,
14719
14729
  "size": this.size,
@@ -14763,7 +14773,10 @@ var Component$i = defineComponent({
14763
14773
  "class": "bk-select-option",
14764
14774
  "onMouseenter": this.handleSelectedAllOptionMouseEnter,
14765
14775
  "onClick": this.handleToggleAll
14766
- }, [this.selectAllText]), (_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a), this.scrollLoading && createVNode("li", {
14776
+ }, [this.selectAllText]), this.list.map((item) => createVNode(BkOption, {
14777
+ "value": item[this.idKey],
14778
+ "label": item[this.displayKey]
14779
+ }, null)), (_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a), this.scrollLoading && createVNode("li", {
14767
14780
  "class": "bk-select-options-loading"
14768
14781
  }, [createVNode(BkLoading, {
14769
14782
  "class": "spinner mr5",
@@ -14785,7 +14798,7 @@ var Component$i = defineComponent({
14785
14798
  })]);
14786
14799
  }
14787
14800
  });
14788
- const BkSelect = withInstallProps(Component$i, { Option: BkOption, Group: OptionGroup });
14801
+ const BkSelect = withInstallProps(Component$j, { Option: BkOption, Group: OptionGroup });
14789
14802
  function _isSlot$4(s2) {
14790
14803
  return typeof s2 === "function" || Object.prototype.toString.call(s2) === "[object Object]" && !isVNode(s2);
14791
14804
  }
@@ -14795,7 +14808,7 @@ const {
14795
14808
  const sliderPops = Object.assign({}, propsMixin);
14796
14809
  sliderPops.width.default = "400";
14797
14810
  sliderPops.height.default = "100%";
14798
- var Component$h = defineComponent({
14811
+ var Component$i = defineComponent({
14799
14812
  name: "Sideslider",
14800
14813
  components: {
14801
14814
  BkModal,
@@ -14884,7 +14897,7 @@ var Component$h = defineComponent({
14884
14897
  };
14885
14898
  }
14886
14899
  });
14887
- const BkSideslider = withInstall(Component$h);
14900
+ const BkSideslider = withInstall(Component$i);
14888
14901
  const stepsProps = {
14889
14902
  theme: PropTypes.theme().def("primary"),
14890
14903
  size: PropTypes.size(),
@@ -14898,7 +14911,7 @@ const stepsProps = {
14898
14911
  steps: PropTypes.array.def([]),
14899
14912
  beforeChange: PropTypes.func
14900
14913
  };
14901
- var Component$g = defineComponent({
14914
+ var Component$h = defineComponent({
14902
14915
  name: "Steps",
14903
14916
  props: stepsProps,
14904
14917
  emits: ["update:curStep", "click"],
@@ -15052,8 +15065,8 @@ var Component$g = defineComponent({
15052
15065
  })]);
15053
15066
  }
15054
15067
  });
15055
- const BkSteps$2 = withInstall(Component$g);
15056
- var Component$f = defineComponent({
15068
+ const BkSteps$2 = withInstall(Component$h);
15069
+ var Component$g = defineComponent({
15057
15070
  name: "Switcher",
15058
15071
  props: {
15059
15072
  theme: PropTypes.theme().def(""),
@@ -15147,7 +15160,7 @@ var Component$f = defineComponent({
15147
15160
  }, [isChecked.value ? props2.onText : props2.offText]) : ""]);
15148
15161
  }
15149
15162
  });
15150
- const BkSwitcher = withInstall(Component$f);
15163
+ const BkSwitcher = withInstall(Component$g);
15151
15164
  const EventProps = {
15152
15165
  onContentScroll: Function
15153
15166
  };
@@ -15284,7 +15297,7 @@ var virtualRender = {
15284
15297
  }
15285
15298
  }
15286
15299
  };
15287
- var Component$e = defineComponent({
15300
+ var Component$f = defineComponent({
15288
15301
  name: "VirtualRender",
15289
15302
  directives: {
15290
15303
  bkVirtualRender: virtualRender
@@ -15438,7 +15451,7 @@ var Component$e = defineComponent({
15438
15451
  };
15439
15452
  }
15440
15453
  });
15441
- const BkVirtualRender = withInstall(Component$e);
15454
+ const BkVirtualRender = withInstall(Component$f);
15442
15455
  var BORDER_OPTION = /* @__PURE__ */ ((BORDER_OPTION2) => {
15443
15456
  BORDER_OPTION2["NONE"] = "none";
15444
15457
  BORDER_OPTION2["ROW"] = "row";
@@ -16059,7 +16072,7 @@ const paginationProps = {
16059
16072
  return value.some((item) => layoutNameMap[item]);
16060
16073
  }, "layout \u7684\u503C\u53EA\u652F\u6301 * total\u3001list\u3001limit *").def(["total", "list", "limit"])
16061
16074
  };
16062
- var Component$d = defineComponent({
16075
+ var Component$e = defineComponent({
16063
16076
  name: "Pagination",
16064
16077
  props: paginationProps,
16065
16078
  emits: ["update:modelValue", "change", "update:limit", "limitChange"],
@@ -16126,7 +16139,7 @@ var Component$d = defineComponent({
16126
16139
  }))]);
16127
16140
  }
16128
16141
  });
16129
- const BkPagination = withInstall(Component$d);
16142
+ const BkPagination = withInstall(Component$e);
16130
16143
  var TableRow = defineComponent({
16131
16144
  name: "TableRow",
16132
16145
  render() {
@@ -17510,7 +17523,7 @@ const useInit = (props2) => {
17510
17523
  updateColGroups
17511
17524
  };
17512
17525
  };
17513
- var Component$c = defineComponent({
17526
+ var Component$d = defineComponent({
17514
17527
  name: "Table",
17515
17528
  props: tableProps,
17516
17529
  emits: EMIT_EVENT_TYPES,
@@ -17752,7 +17765,7 @@ var Component$c = defineComponent({
17752
17765
  ]);
17753
17766
  }
17754
17767
  });
17755
- const BkTable = withInstall(Component$c);
17768
+ const BkTable = withInstall(Component$d);
17756
17769
  const INPUT_MIN_WIDTH = 12;
17757
17770
  function usePage(pageSize) {
17758
17771
  const state = reactive({
@@ -17927,7 +17940,7 @@ var TagRender = defineComponent({
17927
17940
  }, [this.node[this.displayKey]])]);
17928
17941
  }
17929
17942
  });
17930
- var Component$b = defineComponent({
17943
+ var Component$c = defineComponent({
17931
17944
  name: "TagInput",
17932
17945
  directives: {
17933
17946
  bkTooltips: tooltips
@@ -18680,7 +18693,7 @@ var Component$b = defineComponent({
18680
18693
  })]);
18681
18694
  }
18682
18695
  });
18683
- const TagInput = withInstall(Component$b);
18696
+ const TagInput = withInstall(Component$c);
18684
18697
  const dividerProps = {
18685
18698
  direction: PropTypes.commonType(["horizontal", "vertical"], "direction").def("horizontal"),
18686
18699
  align: PropTypes.commonType(["left", "center", "right"], "align").def("center"),
@@ -19617,7 +19630,7 @@ const menuProps = {
19617
19630
  default: true
19618
19631
  }
19619
19632
  };
19620
- var Component$a = defineComponent({
19633
+ var Component$b = defineComponent({
19621
19634
  name: "Menu",
19622
19635
  props: menuProps,
19623
19636
  emits: ["update:activeKey", "update:openKeys", "click", "openChange"],
@@ -19865,7 +19878,7 @@ var Submenu = defineComponent({
19865
19878
  };
19866
19879
  }
19867
19880
  });
19868
- const BkMenu = withInstallProps(Component$a, { Item, Submenu, Group });
19881
+ const BkMenu = withInstallProps(Component$b, { Item, Submenu, Group });
19869
19882
  const TitleProps = {
19870
19883
  sideTitle: {
19871
19884
  type: String,
@@ -19945,7 +19958,7 @@ const NavigationProps = {
19945
19958
  default: true
19946
19959
  }
19947
19960
  };
19948
- var Component$9 = defineComponent({
19961
+ var Component$a = defineComponent({
19949
19962
  name: "Navigation",
19950
19963
  props: NavigationProps,
19951
19964
  emits: ["leave", "toggle", "hover", "toggle-click"],
@@ -20087,7 +20100,7 @@ var Component$9 = defineComponent({
20087
20100
  }, [(_l = (_k = this.$slots).footer) == null ? void 0 : _l.call(_k)])])])])]);
20088
20101
  }
20089
20102
  });
20090
- const Navigation = withInstall(Component$9);
20103
+ const Navigation = withInstall(Component$a);
20091
20104
  const pickerDropdownProps = {
20092
20105
  placement: {
20093
20106
  type: String,
@@ -23442,7 +23455,7 @@ const datePickerProps = {
23442
23455
  },
23443
23456
  disableDate: Function
23444
23457
  };
23445
- var Component$8 = defineComponent({
23458
+ var Component$9 = defineComponent({
23446
23459
  name: "DatePicker",
23447
23460
  directives: {
23448
23461
  clickoutside: ClickOutside
@@ -23971,7 +23984,7 @@ var Component$8 = defineComponent({
23971
23984
  })]), [[resolveDirective("clickoutside"), this.handleClose]]);
23972
23985
  }
23973
23986
  });
23974
- const BkDatePicker = withInstall(Component$8);
23987
+ const BkDatePicker = withInstall(Component$9);
23975
23988
  var ArrayType = /* @__PURE__ */ ((ArrayType2) => {
23976
23989
  ArrayType2["OBJECT_ARRAY"] = "objectArray";
23977
23990
  ArrayType2["BASE_ARRAY"] = "baseArray";
@@ -24027,7 +24040,7 @@ function useSelectListSearch(selectList, displayCode) {
24027
24040
  selectListSearch
24028
24041
  };
24029
24042
  }
24030
- var Component$7 = defineComponent({
24043
+ var Component$8 = defineComponent({
24031
24044
  name: "Transfer",
24032
24045
  props: transferProps,
24033
24046
  emits: ["change", "update:targetList"],
@@ -24198,7 +24211,7 @@ var Component$7 = defineComponent({
24198
24211
  }, [getHeaderHtml("right-header"), getListContentHtml("right")])]);
24199
24212
  }
24200
24213
  });
24201
- const Transfer = withInstall(Component$7);
24214
+ const Transfer = withInstall(Component$8);
24202
24215
  var EVENTS = /* @__PURE__ */ ((EVENTS2) => {
24203
24216
  EVENTS2["NODE_CLICK"] = "nodeClick";
24204
24217
  EVENTS2["NODE_COLLAPSE"] = "nodeCollapse";
@@ -25296,7 +25309,7 @@ var useTreeInit = (props2) => {
25296
25309
  onSelected
25297
25310
  };
25298
25311
  };
25299
- var Component$6 = defineComponent({
25312
+ var Component$7 = defineComponent({
25300
25313
  name: "Tree",
25301
25314
  props: treeProps,
25302
25315
  emits: TreeEmitEventsType,
@@ -25407,7 +25420,7 @@ var Component$6 = defineComponent({
25407
25420
  });
25408
25421
  }
25409
25422
  });
25410
- const BkTree = withInstall(Component$6);
25423
+ const BkTree = withInstall(Component$7);
25411
25424
  const isCustomComponent = (node) => node.__v_isVNode;
25412
25425
  var ComposeFormItem = defineComponent({
25413
25426
  name: "ComposeFormItem",
@@ -26300,7 +26313,7 @@ class Store {
26300
26313
  nodeDataList.forEach((node) => this.appendNode(node, parentNode));
26301
26314
  }
26302
26315
  }
26303
- var Component$5 = defineComponent({
26316
+ var Component$6 = defineComponent({
26304
26317
  name: "Cascader",
26305
26318
  directives: {
26306
26319
  clickoutside: ClickOutside
@@ -26473,7 +26486,7 @@ var Component$5 = defineComponent({
26473
26486
  })]);
26474
26487
  }
26475
26488
  });
26476
- const BkCascader = withInstallProps(Component$5, { CascaderPanel });
26489
+ const BkCascader = withInstallProps(Component$6, { CascaderPanel });
26477
26490
  var SliderButton = defineComponent({
26478
26491
  name: "SliderButton",
26479
26492
  props: {
@@ -26644,7 +26657,7 @@ const off = (element, event, handler) => {
26644
26657
  element.removeEventListener(event, handler, false);
26645
26658
  }
26646
26659
  };
26647
- var Component$4 = defineComponent({
26660
+ var Component$5 = defineComponent({
26648
26661
  name: "Slider",
26649
26662
  props: {
26650
26663
  modelValue: PropTypes.oneOfType([PropTypes.array, PropTypes.number]),
@@ -27090,8 +27103,8 @@ var Component$4 = defineComponent({
27090
27103
  return this.renderDom();
27091
27104
  }
27092
27105
  });
27093
- const Slider = withInstall(Component$4);
27094
- var Component$3 = defineComponent({
27106
+ const Slider = withInstall(Component$5);
27107
+ var Component$4 = defineComponent({
27095
27108
  name: "ResizeLayout",
27096
27109
  props: {
27097
27110
  placement: PropTypes.placement().def("left"),
@@ -27346,13 +27359,13 @@ var Component$3 = defineComponent({
27346
27359
  }, null)]);
27347
27360
  }
27348
27361
  });
27349
- const BkResizeLayout = withInstall(Component$3);
27362
+ const BkResizeLayout = withInstall(Component$4);
27350
27363
  const timelineProps = {
27351
27364
  list: PropTypes.array.def([]),
27352
27365
  titleAble: PropTypes.bool.def(false),
27353
27366
  extCls: PropTypes.string
27354
27367
  };
27355
- var Component$2 = defineComponent({
27368
+ var Component$3 = defineComponent({
27356
27369
  name: "Timeline",
27357
27370
  props: timelineProps,
27358
27371
  emits: ["select"],
@@ -27461,7 +27474,7 @@ var Component$2 = defineComponent({
27461
27474
  })]);
27462
27475
  }
27463
27476
  });
27464
- const BkSteps$1 = withInstall(Component$2);
27477
+ const BkSteps$1 = withInstall(Component$3);
27465
27478
  const processProps = {
27466
27479
  list: PropTypes.array.def([]),
27467
27480
  controllable: PropTypes.bool.def(false),
@@ -27470,7 +27483,7 @@ const processProps = {
27470
27483
  displayKey: PropTypes.string.def("content"),
27471
27484
  extCls: PropTypes.string
27472
27485
  };
27473
- var Component$1 = defineComponent({
27486
+ var Component$2 = defineComponent({
27474
27487
  name: "BKProcess",
27475
27488
  props: processProps,
27476
27489
  emits: ["update:curProcess", "click"],
@@ -27566,7 +27579,7 @@ var Component$1 = defineComponent({
27566
27579
  }, [item[this.displayKey], renderIcon(index, item)]))])]);
27567
27580
  }
27568
27581
  });
27569
- const BkSteps = withInstall(Component$1);
27582
+ const BkSteps = withInstall(Component$2);
27570
27583
  const CLASS_PREFIX = "bk-upload";
27571
27584
  var EThemes = /* @__PURE__ */ ((EThemes2) => {
27572
27585
  EThemes2["BUTTON"] = "button";
@@ -28284,7 +28297,7 @@ var sparkMd5 = { exports: {} };
28284
28297
  ;
28285
28298
  if (typeof ArrayBuffer !== "undefined" && !ArrayBuffer.prototype.slice) {
28286
28299
  (function() {
28287
- function clamp(val, length) {
28300
+ function clamp2(val, length) {
28288
28301
  val = val | 0 || 0;
28289
28302
  if (val < 0) {
28290
28303
  return Math.max(val + length, 0);
@@ -28292,9 +28305,9 @@ var sparkMd5 = { exports: {} };
28292
28305
  return Math.min(val, length);
28293
28306
  }
28294
28307
  ArrayBuffer.prototype.slice = function(from, to) {
28295
- var length = this.byteLength, begin = clamp(from, length), end2 = length, num, target, targetArray, sourceArray;
28308
+ var length = this.byteLength, begin = clamp2(from, length), end2 = length, num, target, targetArray, sourceArray;
28296
28309
  if (to !== undefined$1) {
28297
- end2 = clamp(to, length);
28310
+ end2 = clamp2(to, length);
28298
28311
  }
28299
28312
  if (begin > end2) {
28300
28313
  return new ArrayBuffer(0);
@@ -28833,7 +28846,7 @@ var useFileHandler = (props2, hooks) => {
28833
28846
  handleProgress
28834
28847
  };
28835
28848
  };
28836
- var Component = defineComponent({
28849
+ var Component$1 = defineComponent({
28837
28850
  name: "BkUpload",
28838
28851
  props: uploadProps,
28839
28852
  emits: ["on-exceed", "on-progress", "on-success", "on-error", "on-delete", "on-done"],
@@ -29028,7 +29041,7 @@ var Component = defineComponent({
29028
29041
  })]);
29029
29042
  }
29030
29043
  });
29031
- const Upload = withInstall(Component);
29044
+ const Upload = withInstall(Component$1);
29032
29045
  function Diff$1() {
29033
29046
  }
29034
29047
  Diff$1.prototype = {
@@ -31952,6 +31965,1618 @@ var CodeDiff = defineComponent({
31952
31965
  }
31953
31966
  });
31954
31967
  const BkCodeDiff = withInstall(CodeDiff);
31968
+ var tinycolor$1 = { exports: {} };
31969
+ (function(module) {
31970
+ (function(Math2) {
31971
+ var trimLeft = /^\s+/, trimRight = /\s+$/, tinyCounter = 0, mathRound = Math2.round, mathMin = Math2.min, mathMax = Math2.max, mathRandom = Math2.random;
31972
+ function tinycolor2(color, opts) {
31973
+ color = color ? color : "";
31974
+ opts = opts || {};
31975
+ if (color instanceof tinycolor2) {
31976
+ return color;
31977
+ }
31978
+ if (!(this instanceof tinycolor2)) {
31979
+ return new tinycolor2(color, opts);
31980
+ }
31981
+ var rgb = inputToRGB(color);
31982
+ this._originalInput = color, this._r = rgb.r, this._g = rgb.g, this._b = rgb.b, this._a = rgb.a, this._roundA = mathRound(100 * this._a) / 100, this._format = opts.format || rgb.format;
31983
+ this._gradientType = opts.gradientType;
31984
+ if (this._r < 1) {
31985
+ this._r = mathRound(this._r);
31986
+ }
31987
+ if (this._g < 1) {
31988
+ this._g = mathRound(this._g);
31989
+ }
31990
+ if (this._b < 1) {
31991
+ this._b = mathRound(this._b);
31992
+ }
31993
+ this._ok = rgb.ok;
31994
+ this._tc_id = tinyCounter++;
31995
+ }
31996
+ tinycolor2.prototype = {
31997
+ isDark: function() {
31998
+ return this.getBrightness() < 128;
31999
+ },
32000
+ isLight: function() {
32001
+ return !this.isDark();
32002
+ },
32003
+ isValid: function() {
32004
+ return this._ok;
32005
+ },
32006
+ getOriginalInput: function() {
32007
+ return this._originalInput;
32008
+ },
32009
+ getFormat: function() {
32010
+ return this._format;
32011
+ },
32012
+ getAlpha: function() {
32013
+ return this._a;
32014
+ },
32015
+ getBrightness: function() {
32016
+ var rgb = this.toRgb();
32017
+ return (rgb.r * 299 + rgb.g * 587 + rgb.b * 114) / 1e3;
32018
+ },
32019
+ getLuminance: function() {
32020
+ var rgb = this.toRgb();
32021
+ var RsRGB, GsRGB, BsRGB, R2, G, B2;
32022
+ RsRGB = rgb.r / 255;
32023
+ GsRGB = rgb.g / 255;
32024
+ BsRGB = rgb.b / 255;
32025
+ if (RsRGB <= 0.03928) {
32026
+ R2 = RsRGB / 12.92;
32027
+ } else {
32028
+ R2 = Math2.pow((RsRGB + 0.055) / 1.055, 2.4);
32029
+ }
32030
+ if (GsRGB <= 0.03928) {
32031
+ G = GsRGB / 12.92;
32032
+ } else {
32033
+ G = Math2.pow((GsRGB + 0.055) / 1.055, 2.4);
32034
+ }
32035
+ if (BsRGB <= 0.03928) {
32036
+ B2 = BsRGB / 12.92;
32037
+ } else {
32038
+ B2 = Math2.pow((BsRGB + 0.055) / 1.055, 2.4);
32039
+ }
32040
+ return 0.2126 * R2 + 0.7152 * G + 0.0722 * B2;
32041
+ },
32042
+ setAlpha: function(value) {
32043
+ this._a = boundAlpha(value);
32044
+ this._roundA = mathRound(100 * this._a) / 100;
32045
+ return this;
32046
+ },
32047
+ toHsv: function() {
32048
+ var hsv = rgbToHsv(this._r, this._g, this._b);
32049
+ return { h: hsv.h * 360, s: hsv.s, v: hsv.v, a: this._a };
32050
+ },
32051
+ toHsvString: function() {
32052
+ var hsv = rgbToHsv(this._r, this._g, this._b);
32053
+ var h2 = mathRound(hsv.h * 360), s2 = mathRound(hsv.s * 100), v2 = mathRound(hsv.v * 100);
32054
+ return this._a == 1 ? "hsv(" + h2 + ", " + s2 + "%, " + v2 + "%)" : "hsva(" + h2 + ", " + s2 + "%, " + v2 + "%, " + this._roundA + ")";
32055
+ },
32056
+ toHsl: function() {
32057
+ var hsl = rgbToHsl(this._r, this._g, this._b);
32058
+ return { h: hsl.h * 360, s: hsl.s, l: hsl.l, a: this._a };
32059
+ },
32060
+ toHslString: function() {
32061
+ var hsl = rgbToHsl(this._r, this._g, this._b);
32062
+ var h2 = mathRound(hsl.h * 360), s2 = mathRound(hsl.s * 100), l2 = mathRound(hsl.l * 100);
32063
+ return this._a == 1 ? "hsl(" + h2 + ", " + s2 + "%, " + l2 + "%)" : "hsla(" + h2 + ", " + s2 + "%, " + l2 + "%, " + this._roundA + ")";
32064
+ },
32065
+ toHex: function(allow3Char) {
32066
+ return rgbToHex(this._r, this._g, this._b, allow3Char);
32067
+ },
32068
+ toHexString: function(allow3Char) {
32069
+ return "#" + this.toHex(allow3Char);
32070
+ },
32071
+ toHex8: function(allow4Char) {
32072
+ return rgbaToHex(this._r, this._g, this._b, this._a, allow4Char);
32073
+ },
32074
+ toHex8String: function(allow4Char) {
32075
+ return "#" + this.toHex8(allow4Char);
32076
+ },
32077
+ toRgb: function() {
32078
+ return { r: mathRound(this._r), g: mathRound(this._g), b: mathRound(this._b), a: this._a };
32079
+ },
32080
+ toRgbString: function() {
32081
+ return this._a == 1 ? "rgb(" + mathRound(this._r) + ", " + mathRound(this._g) + ", " + mathRound(this._b) + ")" : "rgba(" + mathRound(this._r) + ", " + mathRound(this._g) + ", " + mathRound(this._b) + ", " + this._roundA + ")";
32082
+ },
32083
+ toPercentageRgb: function() {
32084
+ return { r: mathRound(bound01(this._r, 255) * 100) + "%", g: mathRound(bound01(this._g, 255) * 100) + "%", b: mathRound(bound01(this._b, 255) * 100) + "%", a: this._a };
32085
+ },
32086
+ toPercentageRgbString: function() {
32087
+ return this._a == 1 ? "rgb(" + mathRound(bound01(this._r, 255) * 100) + "%, " + mathRound(bound01(this._g, 255) * 100) + "%, " + mathRound(bound01(this._b, 255) * 100) + "%)" : "rgba(" + mathRound(bound01(this._r, 255) * 100) + "%, " + mathRound(bound01(this._g, 255) * 100) + "%, " + mathRound(bound01(this._b, 255) * 100) + "%, " + this._roundA + ")";
32088
+ },
32089
+ toName: function() {
32090
+ if (this._a === 0) {
32091
+ return "transparent";
32092
+ }
32093
+ if (this._a < 1) {
32094
+ return false;
32095
+ }
32096
+ return hexNames[rgbToHex(this._r, this._g, this._b, true)] || false;
32097
+ },
32098
+ toFilter: function(secondColor) {
32099
+ var hex8String = "#" + rgbaToArgbHex(this._r, this._g, this._b, this._a);
32100
+ var secondHex8String = hex8String;
32101
+ var gradientType = this._gradientType ? "GradientType = 1, " : "";
32102
+ if (secondColor) {
32103
+ var s2 = tinycolor2(secondColor);
32104
+ secondHex8String = "#" + rgbaToArgbHex(s2._r, s2._g, s2._b, s2._a);
32105
+ }
32106
+ return "progid:DXImageTransform.Microsoft.gradient(" + gradientType + "startColorstr=" + hex8String + ",endColorstr=" + secondHex8String + ")";
32107
+ },
32108
+ toString: function(format2) {
32109
+ var formatSet = !!format2;
32110
+ format2 = format2 || this._format;
32111
+ var formattedString = false;
32112
+ var hasAlpha = this._a < 1 && this._a >= 0;
32113
+ var needsAlphaFormat = !formatSet && hasAlpha && (format2 === "hex" || format2 === "hex6" || format2 === "hex3" || format2 === "hex4" || format2 === "hex8" || format2 === "name");
32114
+ if (needsAlphaFormat) {
32115
+ if (format2 === "name" && this._a === 0) {
32116
+ return this.toName();
32117
+ }
32118
+ return this.toRgbString();
32119
+ }
32120
+ if (format2 === "rgb") {
32121
+ formattedString = this.toRgbString();
32122
+ }
32123
+ if (format2 === "prgb") {
32124
+ formattedString = this.toPercentageRgbString();
32125
+ }
32126
+ if (format2 === "hex" || format2 === "hex6") {
32127
+ formattedString = this.toHexString();
32128
+ }
32129
+ if (format2 === "hex3") {
32130
+ formattedString = this.toHexString(true);
32131
+ }
32132
+ if (format2 === "hex4") {
32133
+ formattedString = this.toHex8String(true);
32134
+ }
32135
+ if (format2 === "hex8") {
32136
+ formattedString = this.toHex8String();
32137
+ }
32138
+ if (format2 === "name") {
32139
+ formattedString = this.toName();
32140
+ }
32141
+ if (format2 === "hsl") {
32142
+ formattedString = this.toHslString();
32143
+ }
32144
+ if (format2 === "hsv") {
32145
+ formattedString = this.toHsvString();
32146
+ }
32147
+ return formattedString || this.toHexString();
32148
+ },
32149
+ clone: function() {
32150
+ return tinycolor2(this.toString());
32151
+ },
32152
+ _applyModification: function(fn2, args) {
32153
+ var color = fn2.apply(null, [this].concat([].slice.call(args)));
32154
+ this._r = color._r;
32155
+ this._g = color._g;
32156
+ this._b = color._b;
32157
+ this.setAlpha(color._a);
32158
+ return this;
32159
+ },
32160
+ lighten: function() {
32161
+ return this._applyModification(lighten, arguments);
32162
+ },
32163
+ brighten: function() {
32164
+ return this._applyModification(brighten, arguments);
32165
+ },
32166
+ darken: function() {
32167
+ return this._applyModification(darken, arguments);
32168
+ },
32169
+ desaturate: function() {
32170
+ return this._applyModification(desaturate, arguments);
32171
+ },
32172
+ saturate: function() {
32173
+ return this._applyModification(saturate, arguments);
32174
+ },
32175
+ greyscale: function() {
32176
+ return this._applyModification(greyscale, arguments);
32177
+ },
32178
+ spin: function() {
32179
+ return this._applyModification(spin, arguments);
32180
+ },
32181
+ _applyCombination: function(fn2, args) {
32182
+ return fn2.apply(null, [this].concat([].slice.call(args)));
32183
+ },
32184
+ analogous: function() {
32185
+ return this._applyCombination(analogous, arguments);
32186
+ },
32187
+ complement: function() {
32188
+ return this._applyCombination(complement, arguments);
32189
+ },
32190
+ monochromatic: function() {
32191
+ return this._applyCombination(monochromatic, arguments);
32192
+ },
32193
+ splitcomplement: function() {
32194
+ return this._applyCombination(splitcomplement, arguments);
32195
+ },
32196
+ triad: function() {
32197
+ return this._applyCombination(triad, arguments);
32198
+ },
32199
+ tetrad: function() {
32200
+ return this._applyCombination(tetrad, arguments);
32201
+ }
32202
+ };
32203
+ tinycolor2.fromRatio = function(color, opts) {
32204
+ if (typeof color == "object") {
32205
+ var newColor = {};
32206
+ for (var i2 in color) {
32207
+ if (color.hasOwnProperty(i2)) {
32208
+ if (i2 === "a") {
32209
+ newColor[i2] = color[i2];
32210
+ } else {
32211
+ newColor[i2] = convertToPercentage(color[i2]);
32212
+ }
32213
+ }
32214
+ }
32215
+ color = newColor;
32216
+ }
32217
+ return tinycolor2(color, opts);
32218
+ };
32219
+ function inputToRGB(color) {
32220
+ var rgb = { r: 0, g: 0, b: 0 };
32221
+ var a2 = 1;
32222
+ var s2 = null;
32223
+ var v2 = null;
32224
+ var l2 = null;
32225
+ var ok = false;
32226
+ var format2 = false;
32227
+ if (typeof color == "string") {
32228
+ color = stringInputToObject(color);
32229
+ }
32230
+ if (typeof color == "object") {
32231
+ if (isValidCSSUnit(color.r) && isValidCSSUnit(color.g) && isValidCSSUnit(color.b)) {
32232
+ rgb = rgbToRgb(color.r, color.g, color.b);
32233
+ ok = true;
32234
+ format2 = String(color.r).substr(-1) === "%" ? "prgb" : "rgb";
32235
+ } else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.v)) {
32236
+ s2 = convertToPercentage(color.s);
32237
+ v2 = convertToPercentage(color.v);
32238
+ rgb = hsvToRgb(color.h, s2, v2);
32239
+ ok = true;
32240
+ format2 = "hsv";
32241
+ } else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.l)) {
32242
+ s2 = convertToPercentage(color.s);
32243
+ l2 = convertToPercentage(color.l);
32244
+ rgb = hslToRgb(color.h, s2, l2);
32245
+ ok = true;
32246
+ format2 = "hsl";
32247
+ }
32248
+ if (color.hasOwnProperty("a")) {
32249
+ a2 = color.a;
32250
+ }
32251
+ }
32252
+ a2 = boundAlpha(a2);
32253
+ return {
32254
+ ok,
32255
+ format: color.format || format2,
32256
+ r: mathMin(255, mathMax(rgb.r, 0)),
32257
+ g: mathMin(255, mathMax(rgb.g, 0)),
32258
+ b: mathMin(255, mathMax(rgb.b, 0)),
32259
+ a: a2
32260
+ };
32261
+ }
32262
+ function rgbToRgb(r2, g2, b2) {
32263
+ return {
32264
+ r: bound01(r2, 255) * 255,
32265
+ g: bound01(g2, 255) * 255,
32266
+ b: bound01(b2, 255) * 255
32267
+ };
32268
+ }
32269
+ function rgbToHsl(r2, g2, b2) {
32270
+ r2 = bound01(r2, 255);
32271
+ g2 = bound01(g2, 255);
32272
+ b2 = bound01(b2, 255);
32273
+ var max2 = mathMax(r2, g2, b2), min2 = mathMin(r2, g2, b2);
32274
+ var h2, s2, l2 = (max2 + min2) / 2;
32275
+ if (max2 == min2) {
32276
+ h2 = s2 = 0;
32277
+ } else {
32278
+ var d2 = max2 - min2;
32279
+ s2 = l2 > 0.5 ? d2 / (2 - max2 - min2) : d2 / (max2 + min2);
32280
+ switch (max2) {
32281
+ case r2:
32282
+ h2 = (g2 - b2) / d2 + (g2 < b2 ? 6 : 0);
32283
+ break;
32284
+ case g2:
32285
+ h2 = (b2 - r2) / d2 + 2;
32286
+ break;
32287
+ case b2:
32288
+ h2 = (r2 - g2) / d2 + 4;
32289
+ break;
32290
+ }
32291
+ h2 /= 6;
32292
+ }
32293
+ return { h: h2, s: s2, l: l2 };
32294
+ }
32295
+ function hslToRgb(h2, s2, l2) {
32296
+ var r2, g2, b2;
32297
+ h2 = bound01(h2, 360);
32298
+ s2 = bound01(s2, 100);
32299
+ l2 = bound01(l2, 100);
32300
+ function hue2rgb(p3, q3, t2) {
32301
+ if (t2 < 0)
32302
+ t2 += 1;
32303
+ if (t2 > 1)
32304
+ t2 -= 1;
32305
+ if (t2 < 1 / 6)
32306
+ return p3 + (q3 - p3) * 6 * t2;
32307
+ if (t2 < 1 / 2)
32308
+ return q3;
32309
+ if (t2 < 2 / 3)
32310
+ return p3 + (q3 - p3) * (2 / 3 - t2) * 6;
32311
+ return p3;
32312
+ }
32313
+ if (s2 === 0) {
32314
+ r2 = g2 = b2 = l2;
32315
+ } else {
32316
+ var q2 = l2 < 0.5 ? l2 * (1 + s2) : l2 + s2 - l2 * s2;
32317
+ var p2 = 2 * l2 - q2;
32318
+ r2 = hue2rgb(p2, q2, h2 + 1 / 3);
32319
+ g2 = hue2rgb(p2, q2, h2);
32320
+ b2 = hue2rgb(p2, q2, h2 - 1 / 3);
32321
+ }
32322
+ return { r: r2 * 255, g: g2 * 255, b: b2 * 255 };
32323
+ }
32324
+ function rgbToHsv(r2, g2, b2) {
32325
+ r2 = bound01(r2, 255);
32326
+ g2 = bound01(g2, 255);
32327
+ b2 = bound01(b2, 255);
32328
+ var max2 = mathMax(r2, g2, b2), min2 = mathMin(r2, g2, b2);
32329
+ var h2, s2, v2 = max2;
32330
+ var d2 = max2 - min2;
32331
+ s2 = max2 === 0 ? 0 : d2 / max2;
32332
+ if (max2 == min2) {
32333
+ h2 = 0;
32334
+ } else {
32335
+ switch (max2) {
32336
+ case r2:
32337
+ h2 = (g2 - b2) / d2 + (g2 < b2 ? 6 : 0);
32338
+ break;
32339
+ case g2:
32340
+ h2 = (b2 - r2) / d2 + 2;
32341
+ break;
32342
+ case b2:
32343
+ h2 = (r2 - g2) / d2 + 4;
32344
+ break;
32345
+ }
32346
+ h2 /= 6;
32347
+ }
32348
+ return { h: h2, s: s2, v: v2 };
32349
+ }
32350
+ function hsvToRgb(h2, s2, v2) {
32351
+ h2 = bound01(h2, 360) * 6;
32352
+ s2 = bound01(s2, 100);
32353
+ v2 = bound01(v2, 100);
32354
+ var i2 = Math2.floor(h2), f2 = h2 - i2, p2 = v2 * (1 - s2), q2 = v2 * (1 - f2 * s2), t2 = v2 * (1 - (1 - f2) * s2), mod = i2 % 6, r2 = [v2, q2, p2, p2, t2, v2][mod], g2 = [t2, v2, v2, q2, p2, p2][mod], b2 = [p2, p2, t2, v2, v2, q2][mod];
32355
+ return { r: r2 * 255, g: g2 * 255, b: b2 * 255 };
32356
+ }
32357
+ function rgbToHex(r2, g2, b2, allow3Char) {
32358
+ var hex = [
32359
+ pad2(mathRound(r2).toString(16)),
32360
+ pad2(mathRound(g2).toString(16)),
32361
+ pad2(mathRound(b2).toString(16))
32362
+ ];
32363
+ if (allow3Char && hex[0].charAt(0) == hex[0].charAt(1) && hex[1].charAt(0) == hex[1].charAt(1) && hex[2].charAt(0) == hex[2].charAt(1)) {
32364
+ return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0);
32365
+ }
32366
+ return hex.join("");
32367
+ }
32368
+ function rgbaToHex(r2, g2, b2, a2, allow4Char) {
32369
+ var hex = [
32370
+ pad2(mathRound(r2).toString(16)),
32371
+ pad2(mathRound(g2).toString(16)),
32372
+ pad2(mathRound(b2).toString(16)),
32373
+ pad2(convertDecimalToHex(a2))
32374
+ ];
32375
+ if (allow4Char && hex[0].charAt(0) == hex[0].charAt(1) && hex[1].charAt(0) == hex[1].charAt(1) && hex[2].charAt(0) == hex[2].charAt(1) && hex[3].charAt(0) == hex[3].charAt(1)) {
32376
+ return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0) + hex[3].charAt(0);
32377
+ }
32378
+ return hex.join("");
32379
+ }
32380
+ function rgbaToArgbHex(r2, g2, b2, a2) {
32381
+ var hex = [
32382
+ pad2(convertDecimalToHex(a2)),
32383
+ pad2(mathRound(r2).toString(16)),
32384
+ pad2(mathRound(g2).toString(16)),
32385
+ pad2(mathRound(b2).toString(16))
32386
+ ];
32387
+ return hex.join("");
32388
+ }
32389
+ tinycolor2.equals = function(color1, color2) {
32390
+ if (!color1 || !color2) {
32391
+ return false;
32392
+ }
32393
+ return tinycolor2(color1).toRgbString() == tinycolor2(color2).toRgbString();
32394
+ };
32395
+ tinycolor2.random = function() {
32396
+ return tinycolor2.fromRatio({
32397
+ r: mathRandom(),
32398
+ g: mathRandom(),
32399
+ b: mathRandom()
32400
+ });
32401
+ };
32402
+ function desaturate(color, amount) {
32403
+ amount = amount === 0 ? 0 : amount || 10;
32404
+ var hsl = tinycolor2(color).toHsl();
32405
+ hsl.s -= amount / 100;
32406
+ hsl.s = clamp01(hsl.s);
32407
+ return tinycolor2(hsl);
32408
+ }
32409
+ function saturate(color, amount) {
32410
+ amount = amount === 0 ? 0 : amount || 10;
32411
+ var hsl = tinycolor2(color).toHsl();
32412
+ hsl.s += amount / 100;
32413
+ hsl.s = clamp01(hsl.s);
32414
+ return tinycolor2(hsl);
32415
+ }
32416
+ function greyscale(color) {
32417
+ return tinycolor2(color).desaturate(100);
32418
+ }
32419
+ function lighten(color, amount) {
32420
+ amount = amount === 0 ? 0 : amount || 10;
32421
+ var hsl = tinycolor2(color).toHsl();
32422
+ hsl.l += amount / 100;
32423
+ hsl.l = clamp01(hsl.l);
32424
+ return tinycolor2(hsl);
32425
+ }
32426
+ function brighten(color, amount) {
32427
+ amount = amount === 0 ? 0 : amount || 10;
32428
+ var rgb = tinycolor2(color).toRgb();
32429
+ rgb.r = mathMax(0, mathMin(255, rgb.r - mathRound(255 * -(amount / 100))));
32430
+ rgb.g = mathMax(0, mathMin(255, rgb.g - mathRound(255 * -(amount / 100))));
32431
+ rgb.b = mathMax(0, mathMin(255, rgb.b - mathRound(255 * -(amount / 100))));
32432
+ return tinycolor2(rgb);
32433
+ }
32434
+ function darken(color, amount) {
32435
+ amount = amount === 0 ? 0 : amount || 10;
32436
+ var hsl = tinycolor2(color).toHsl();
32437
+ hsl.l -= amount / 100;
32438
+ hsl.l = clamp01(hsl.l);
32439
+ return tinycolor2(hsl);
32440
+ }
32441
+ function spin(color, amount) {
32442
+ var hsl = tinycolor2(color).toHsl();
32443
+ var hue = (hsl.h + amount) % 360;
32444
+ hsl.h = hue < 0 ? 360 + hue : hue;
32445
+ return tinycolor2(hsl);
32446
+ }
32447
+ function complement(color) {
32448
+ var hsl = tinycolor2(color).toHsl();
32449
+ hsl.h = (hsl.h + 180) % 360;
32450
+ return tinycolor2(hsl);
32451
+ }
32452
+ function triad(color) {
32453
+ var hsl = tinycolor2(color).toHsl();
32454
+ var h2 = hsl.h;
32455
+ return [
32456
+ tinycolor2(color),
32457
+ tinycolor2({ h: (h2 + 120) % 360, s: hsl.s, l: hsl.l }),
32458
+ tinycolor2({ h: (h2 + 240) % 360, s: hsl.s, l: hsl.l })
32459
+ ];
32460
+ }
32461
+ function tetrad(color) {
32462
+ var hsl = tinycolor2(color).toHsl();
32463
+ var h2 = hsl.h;
32464
+ return [
32465
+ tinycolor2(color),
32466
+ tinycolor2({ h: (h2 + 90) % 360, s: hsl.s, l: hsl.l }),
32467
+ tinycolor2({ h: (h2 + 180) % 360, s: hsl.s, l: hsl.l }),
32468
+ tinycolor2({ h: (h2 + 270) % 360, s: hsl.s, l: hsl.l })
32469
+ ];
32470
+ }
32471
+ function splitcomplement(color) {
32472
+ var hsl = tinycolor2(color).toHsl();
32473
+ var h2 = hsl.h;
32474
+ return [
32475
+ tinycolor2(color),
32476
+ tinycolor2({ h: (h2 + 72) % 360, s: hsl.s, l: hsl.l }),
32477
+ tinycolor2({ h: (h2 + 216) % 360, s: hsl.s, l: hsl.l })
32478
+ ];
32479
+ }
32480
+ function analogous(color, results, slices) {
32481
+ results = results || 6;
32482
+ slices = slices || 30;
32483
+ var hsl = tinycolor2(color).toHsl();
32484
+ var part = 360 / slices;
32485
+ var ret = [tinycolor2(color)];
32486
+ for (hsl.h = (hsl.h - (part * results >> 1) + 720) % 360; --results; ) {
32487
+ hsl.h = (hsl.h + part) % 360;
32488
+ ret.push(tinycolor2(hsl));
32489
+ }
32490
+ return ret;
32491
+ }
32492
+ function monochromatic(color, results) {
32493
+ results = results || 6;
32494
+ var hsv = tinycolor2(color).toHsv();
32495
+ var h2 = hsv.h, s2 = hsv.s, v2 = hsv.v;
32496
+ var ret = [];
32497
+ var modification = 1 / results;
32498
+ while (results--) {
32499
+ ret.push(tinycolor2({ h: h2, s: s2, v: v2 }));
32500
+ v2 = (v2 + modification) % 1;
32501
+ }
32502
+ return ret;
32503
+ }
32504
+ tinycolor2.mix = function(color1, color2, amount) {
32505
+ amount = amount === 0 ? 0 : amount || 50;
32506
+ var rgb1 = tinycolor2(color1).toRgb();
32507
+ var rgb2 = tinycolor2(color2).toRgb();
32508
+ var p2 = amount / 100;
32509
+ var rgba = {
32510
+ r: (rgb2.r - rgb1.r) * p2 + rgb1.r,
32511
+ g: (rgb2.g - rgb1.g) * p2 + rgb1.g,
32512
+ b: (rgb2.b - rgb1.b) * p2 + rgb1.b,
32513
+ a: (rgb2.a - rgb1.a) * p2 + rgb1.a
32514
+ };
32515
+ return tinycolor2(rgba);
32516
+ };
32517
+ tinycolor2.readability = function(color1, color2) {
32518
+ var c1 = tinycolor2(color1);
32519
+ var c2 = tinycolor2(color2);
32520
+ return (Math2.max(c1.getLuminance(), c2.getLuminance()) + 0.05) / (Math2.min(c1.getLuminance(), c2.getLuminance()) + 0.05);
32521
+ };
32522
+ tinycolor2.isReadable = function(color1, color2, wcag2) {
32523
+ var readability = tinycolor2.readability(color1, color2);
32524
+ var wcag2Parms, out;
32525
+ out = false;
32526
+ wcag2Parms = validateWCAG2Parms(wcag2);
32527
+ switch (wcag2Parms.level + wcag2Parms.size) {
32528
+ case "AAsmall":
32529
+ case "AAAlarge":
32530
+ out = readability >= 4.5;
32531
+ break;
32532
+ case "AAlarge":
32533
+ out = readability >= 3;
32534
+ break;
32535
+ case "AAAsmall":
32536
+ out = readability >= 7;
32537
+ break;
32538
+ }
32539
+ return out;
32540
+ };
32541
+ tinycolor2.mostReadable = function(baseColor, colorList, args) {
32542
+ var bestColor = null;
32543
+ var bestScore = 0;
32544
+ var readability;
32545
+ var includeFallbackColors, level, size;
32546
+ args = args || {};
32547
+ includeFallbackColors = args.includeFallbackColors;
32548
+ level = args.level;
32549
+ size = args.size;
32550
+ for (var i2 = 0; i2 < colorList.length; i2++) {
32551
+ readability = tinycolor2.readability(baseColor, colorList[i2]);
32552
+ if (readability > bestScore) {
32553
+ bestScore = readability;
32554
+ bestColor = tinycolor2(colorList[i2]);
32555
+ }
32556
+ }
32557
+ if (tinycolor2.isReadable(baseColor, bestColor, { "level": level, "size": size }) || !includeFallbackColors) {
32558
+ return bestColor;
32559
+ } else {
32560
+ args.includeFallbackColors = false;
32561
+ return tinycolor2.mostReadable(baseColor, ["#fff", "#000"], args);
32562
+ }
32563
+ };
32564
+ var names = tinycolor2.names = {
32565
+ aliceblue: "f0f8ff",
32566
+ antiquewhite: "faebd7",
32567
+ aqua: "0ff",
32568
+ aquamarine: "7fffd4",
32569
+ azure: "f0ffff",
32570
+ beige: "f5f5dc",
32571
+ bisque: "ffe4c4",
32572
+ black: "000",
32573
+ blanchedalmond: "ffebcd",
32574
+ blue: "00f",
32575
+ blueviolet: "8a2be2",
32576
+ brown: "a52a2a",
32577
+ burlywood: "deb887",
32578
+ burntsienna: "ea7e5d",
32579
+ cadetblue: "5f9ea0",
32580
+ chartreuse: "7fff00",
32581
+ chocolate: "d2691e",
32582
+ coral: "ff7f50",
32583
+ cornflowerblue: "6495ed",
32584
+ cornsilk: "fff8dc",
32585
+ crimson: "dc143c",
32586
+ cyan: "0ff",
32587
+ darkblue: "00008b",
32588
+ darkcyan: "008b8b",
32589
+ darkgoldenrod: "b8860b",
32590
+ darkgray: "a9a9a9",
32591
+ darkgreen: "006400",
32592
+ darkgrey: "a9a9a9",
32593
+ darkkhaki: "bdb76b",
32594
+ darkmagenta: "8b008b",
32595
+ darkolivegreen: "556b2f",
32596
+ darkorange: "ff8c00",
32597
+ darkorchid: "9932cc",
32598
+ darkred: "8b0000",
32599
+ darksalmon: "e9967a",
32600
+ darkseagreen: "8fbc8f",
32601
+ darkslateblue: "483d8b",
32602
+ darkslategray: "2f4f4f",
32603
+ darkslategrey: "2f4f4f",
32604
+ darkturquoise: "00ced1",
32605
+ darkviolet: "9400d3",
32606
+ deeppink: "ff1493",
32607
+ deepskyblue: "00bfff",
32608
+ dimgray: "696969",
32609
+ dimgrey: "696969",
32610
+ dodgerblue: "1e90ff",
32611
+ firebrick: "b22222",
32612
+ floralwhite: "fffaf0",
32613
+ forestgreen: "228b22",
32614
+ fuchsia: "f0f",
32615
+ gainsboro: "dcdcdc",
32616
+ ghostwhite: "f8f8ff",
32617
+ gold: "ffd700",
32618
+ goldenrod: "daa520",
32619
+ gray: "808080",
32620
+ green: "008000",
32621
+ greenyellow: "adff2f",
32622
+ grey: "808080",
32623
+ honeydew: "f0fff0",
32624
+ hotpink: "ff69b4",
32625
+ indianred: "cd5c5c",
32626
+ indigo: "4b0082",
32627
+ ivory: "fffff0",
32628
+ khaki: "f0e68c",
32629
+ lavender: "e6e6fa",
32630
+ lavenderblush: "fff0f5",
32631
+ lawngreen: "7cfc00",
32632
+ lemonchiffon: "fffacd",
32633
+ lightblue: "add8e6",
32634
+ lightcoral: "f08080",
32635
+ lightcyan: "e0ffff",
32636
+ lightgoldenrodyellow: "fafad2",
32637
+ lightgray: "d3d3d3",
32638
+ lightgreen: "90ee90",
32639
+ lightgrey: "d3d3d3",
32640
+ lightpink: "ffb6c1",
32641
+ lightsalmon: "ffa07a",
32642
+ lightseagreen: "20b2aa",
32643
+ lightskyblue: "87cefa",
32644
+ lightslategray: "789",
32645
+ lightslategrey: "789",
32646
+ lightsteelblue: "b0c4de",
32647
+ lightyellow: "ffffe0",
32648
+ lime: "0f0",
32649
+ limegreen: "32cd32",
32650
+ linen: "faf0e6",
32651
+ magenta: "f0f",
32652
+ maroon: "800000",
32653
+ mediumaquamarine: "66cdaa",
32654
+ mediumblue: "0000cd",
32655
+ mediumorchid: "ba55d3",
32656
+ mediumpurple: "9370db",
32657
+ mediumseagreen: "3cb371",
32658
+ mediumslateblue: "7b68ee",
32659
+ mediumspringgreen: "00fa9a",
32660
+ mediumturquoise: "48d1cc",
32661
+ mediumvioletred: "c71585",
32662
+ midnightblue: "191970",
32663
+ mintcream: "f5fffa",
32664
+ mistyrose: "ffe4e1",
32665
+ moccasin: "ffe4b5",
32666
+ navajowhite: "ffdead",
32667
+ navy: "000080",
32668
+ oldlace: "fdf5e6",
32669
+ olive: "808000",
32670
+ olivedrab: "6b8e23",
32671
+ orange: "ffa500",
32672
+ orangered: "ff4500",
32673
+ orchid: "da70d6",
32674
+ palegoldenrod: "eee8aa",
32675
+ palegreen: "98fb98",
32676
+ paleturquoise: "afeeee",
32677
+ palevioletred: "db7093",
32678
+ papayawhip: "ffefd5",
32679
+ peachpuff: "ffdab9",
32680
+ peru: "cd853f",
32681
+ pink: "ffc0cb",
32682
+ plum: "dda0dd",
32683
+ powderblue: "b0e0e6",
32684
+ purple: "800080",
32685
+ rebeccapurple: "663399",
32686
+ red: "f00",
32687
+ rosybrown: "bc8f8f",
32688
+ royalblue: "4169e1",
32689
+ saddlebrown: "8b4513",
32690
+ salmon: "fa8072",
32691
+ sandybrown: "f4a460",
32692
+ seagreen: "2e8b57",
32693
+ seashell: "fff5ee",
32694
+ sienna: "a0522d",
32695
+ silver: "c0c0c0",
32696
+ skyblue: "87ceeb",
32697
+ slateblue: "6a5acd",
32698
+ slategray: "708090",
32699
+ slategrey: "708090",
32700
+ snow: "fffafa",
32701
+ springgreen: "00ff7f",
32702
+ steelblue: "4682b4",
32703
+ tan: "d2b48c",
32704
+ teal: "008080",
32705
+ thistle: "d8bfd8",
32706
+ tomato: "ff6347",
32707
+ turquoise: "40e0d0",
32708
+ violet: "ee82ee",
32709
+ wheat: "f5deb3",
32710
+ white: "fff",
32711
+ whitesmoke: "f5f5f5",
32712
+ yellow: "ff0",
32713
+ yellowgreen: "9acd32"
32714
+ };
32715
+ var hexNames = tinycolor2.hexNames = flip2(names);
32716
+ function flip2(o2) {
32717
+ var flipped = {};
32718
+ for (var i2 in o2) {
32719
+ if (o2.hasOwnProperty(i2)) {
32720
+ flipped[o2[i2]] = i2;
32721
+ }
32722
+ }
32723
+ return flipped;
32724
+ }
32725
+ function boundAlpha(a2) {
32726
+ a2 = parseFloat(a2);
32727
+ if (isNaN(a2) || a2 < 0 || a2 > 1) {
32728
+ a2 = 1;
32729
+ }
32730
+ return a2;
32731
+ }
32732
+ function bound01(n2, max2) {
32733
+ if (isOnePointZero(n2)) {
32734
+ n2 = "100%";
32735
+ }
32736
+ var processPercent = isPercentage(n2);
32737
+ n2 = mathMin(max2, mathMax(0, parseFloat(n2)));
32738
+ if (processPercent) {
32739
+ n2 = parseInt(n2 * max2, 10) / 100;
32740
+ }
32741
+ if (Math2.abs(n2 - max2) < 1e-6) {
32742
+ return 1;
32743
+ }
32744
+ return n2 % max2 / parseFloat(max2);
32745
+ }
32746
+ function clamp01(val) {
32747
+ return mathMin(1, mathMax(0, val));
32748
+ }
32749
+ function parseIntFromHex(val) {
32750
+ return parseInt(val, 16);
32751
+ }
32752
+ function isOnePointZero(n2) {
32753
+ return typeof n2 == "string" && n2.indexOf(".") != -1 && parseFloat(n2) === 1;
32754
+ }
32755
+ function isPercentage(n2) {
32756
+ return typeof n2 === "string" && n2.indexOf("%") != -1;
32757
+ }
32758
+ function pad2(c2) {
32759
+ return c2.length == 1 ? "0" + c2 : "" + c2;
32760
+ }
32761
+ function convertToPercentage(n2) {
32762
+ if (n2 <= 1) {
32763
+ n2 = n2 * 100 + "%";
32764
+ }
32765
+ return n2;
32766
+ }
32767
+ function convertDecimalToHex(d2) {
32768
+ return Math2.round(parseFloat(d2) * 255).toString(16);
32769
+ }
32770
+ function convertHexToDecimal(h2) {
32771
+ return parseIntFromHex(h2) / 255;
32772
+ }
32773
+ var matchers = function() {
32774
+ var CSS_INTEGER = "[-\\+]?\\d+%?";
32775
+ var CSS_NUMBER = "[-\\+]?\\d*\\.\\d+%?";
32776
+ var CSS_UNIT = "(?:" + CSS_NUMBER + ")|(?:" + CSS_INTEGER + ")";
32777
+ var PERMISSIVE_MATCH3 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?";
32778
+ var PERMISSIVE_MATCH4 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?";
32779
+ return {
32780
+ CSS_UNIT: new RegExp(CSS_UNIT),
32781
+ rgb: new RegExp("rgb" + PERMISSIVE_MATCH3),
32782
+ rgba: new RegExp("rgba" + PERMISSIVE_MATCH4),
32783
+ hsl: new RegExp("hsl" + PERMISSIVE_MATCH3),
32784
+ hsla: new RegExp("hsla" + PERMISSIVE_MATCH4),
32785
+ hsv: new RegExp("hsv" + PERMISSIVE_MATCH3),
32786
+ hsva: new RegExp("hsva" + PERMISSIVE_MATCH4),
32787
+ hex3: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,
32788
+ hex6: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,
32789
+ hex4: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,
32790
+ hex8: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/
32791
+ };
32792
+ }();
32793
+ function isValidCSSUnit(color) {
32794
+ return !!matchers.CSS_UNIT.exec(color);
32795
+ }
32796
+ function stringInputToObject(color) {
32797
+ color = color.replace(trimLeft, "").replace(trimRight, "").toLowerCase();
32798
+ var named = false;
32799
+ if (names[color]) {
32800
+ color = names[color];
32801
+ named = true;
32802
+ } else if (color == "transparent") {
32803
+ return { r: 0, g: 0, b: 0, a: 0, format: "name" };
32804
+ }
32805
+ var match2;
32806
+ if (match2 = matchers.rgb.exec(color)) {
32807
+ return { r: match2[1], g: match2[2], b: match2[3] };
32808
+ }
32809
+ if (match2 = matchers.rgba.exec(color)) {
32810
+ return { r: match2[1], g: match2[2], b: match2[3], a: match2[4] };
32811
+ }
32812
+ if (match2 = matchers.hsl.exec(color)) {
32813
+ return { h: match2[1], s: match2[2], l: match2[3] };
32814
+ }
32815
+ if (match2 = matchers.hsla.exec(color)) {
32816
+ return { h: match2[1], s: match2[2], l: match2[3], a: match2[4] };
32817
+ }
32818
+ if (match2 = matchers.hsv.exec(color)) {
32819
+ return { h: match2[1], s: match2[2], v: match2[3] };
32820
+ }
32821
+ if (match2 = matchers.hsva.exec(color)) {
32822
+ return { h: match2[1], s: match2[2], v: match2[3], a: match2[4] };
32823
+ }
32824
+ if (match2 = matchers.hex8.exec(color)) {
32825
+ return {
32826
+ r: parseIntFromHex(match2[1]),
32827
+ g: parseIntFromHex(match2[2]),
32828
+ b: parseIntFromHex(match2[3]),
32829
+ a: convertHexToDecimal(match2[4]),
32830
+ format: named ? "name" : "hex8"
32831
+ };
32832
+ }
32833
+ if (match2 = matchers.hex6.exec(color)) {
32834
+ return {
32835
+ r: parseIntFromHex(match2[1]),
32836
+ g: parseIntFromHex(match2[2]),
32837
+ b: parseIntFromHex(match2[3]),
32838
+ format: named ? "name" : "hex"
32839
+ };
32840
+ }
32841
+ if (match2 = matchers.hex4.exec(color)) {
32842
+ return {
32843
+ r: parseIntFromHex(match2[1] + "" + match2[1]),
32844
+ g: parseIntFromHex(match2[2] + "" + match2[2]),
32845
+ b: parseIntFromHex(match2[3] + "" + match2[3]),
32846
+ a: convertHexToDecimal(match2[4] + "" + match2[4]),
32847
+ format: named ? "name" : "hex8"
32848
+ };
32849
+ }
32850
+ if (match2 = matchers.hex3.exec(color)) {
32851
+ return {
32852
+ r: parseIntFromHex(match2[1] + "" + match2[1]),
32853
+ g: parseIntFromHex(match2[2] + "" + match2[2]),
32854
+ b: parseIntFromHex(match2[3] + "" + match2[3]),
32855
+ format: named ? "name" : "hex"
32856
+ };
32857
+ }
32858
+ return false;
32859
+ }
32860
+ function validateWCAG2Parms(parms) {
32861
+ var level, size;
32862
+ parms = parms || { "level": "AA", "size": "small" };
32863
+ level = (parms.level || "AA").toUpperCase();
32864
+ size = (parms.size || "small").toLowerCase();
32865
+ if (level !== "AA" && level !== "AAA") {
32866
+ level = "AA";
32867
+ }
32868
+ if (size !== "small" && size !== "large") {
32869
+ size = "small";
32870
+ }
32871
+ return { "level": level, "size": size };
32872
+ }
32873
+ if (module.exports) {
32874
+ module.exports = tinycolor2;
32875
+ } else {
32876
+ window.tinycolor = tinycolor2;
32877
+ }
32878
+ })(Math);
32879
+ })(tinycolor$1);
32880
+ var tinycolor = tinycolor$1.exports;
32881
+ const inputContainerProps = {
32882
+ info: PropTypes.object.isRequired
32883
+ };
32884
+ var InputContainer = defineComponent({
32885
+ props: inputContainerProps,
32886
+ emits: ["tab", "input"],
32887
+ setup(props2, {
32888
+ emit
32889
+ }) {
32890
+ const handleTab = (e) => {
32891
+ if (props2.info.key === "a") {
32892
+ emit("tab", e);
32893
+ }
32894
+ };
32895
+ const handleInput = (e) => {
32896
+ const {
32897
+ key: key2
32898
+ } = props2.info;
32899
+ const {
32900
+ value
32901
+ } = e.target;
32902
+ emit("input", key2, value);
32903
+ };
32904
+ const colorPickerCls = computed(() => classes({
32905
+ error: props2.info.error
32906
+ }, "bk-color-picker-input-value"));
32907
+ return () => createVNode("div", {
32908
+ "class": "bk-color-picker-input-part"
32909
+ }, [createVNode("input", {
32910
+ "type": props2.info.name === "HEX" ? "text" : "number",
32911
+ "class": colorPickerCls.value,
32912
+ "value": props2.info.value,
32913
+ "onKeydown": handleTab,
32914
+ "onInput": handleInput
32915
+ }, null), createVNode("span", {
32916
+ "class": "bk-color-picker-input-text"
32917
+ }, [props2.info.name])]);
32918
+ }
32919
+ });
32920
+ const colorPickerProps$4 = {
32921
+ colorObj: PropTypes.object.isRequired
32922
+ };
32923
+ var ColorInput = defineComponent({
32924
+ name: "ColorPicker",
32925
+ props: colorPickerProps$4,
32926
+ emits: ["change", "tab"],
32927
+ setup(props2, {
32928
+ emit
32929
+ }) {
32930
+ const hex = reactive({
32931
+ key: "hex",
32932
+ name: "HEX",
32933
+ value: props2.colorObj.hex,
32934
+ error: false
32935
+ });
32936
+ const r2 = reactive({
32937
+ key: "r",
32938
+ name: "R",
32939
+ value: props2.colorObj.rgba.r.toString(),
32940
+ error: false
32941
+ });
32942
+ const g2 = reactive({
32943
+ key: "g",
32944
+ name: "G",
32945
+ value: props2.colorObj.rgba.g.toString(),
32946
+ error: false
32947
+ });
32948
+ const b2 = reactive({
32949
+ key: "b",
32950
+ name: "B",
32951
+ value: props2.colorObj.rgba.b.toString(),
32952
+ error: false
32953
+ });
32954
+ const a2 = reactive({
32955
+ key: "a",
32956
+ name: "Alpha",
32957
+ value: props2.colorObj.rgba.a.toString(),
32958
+ error: false
32959
+ });
32960
+ watch(() => props2.colorObj, (val) => {
32961
+ if (tinycolor(val.hex).toString() !== tinycolor(hex.value).toString()) {
32962
+ hex.value = val.hex;
32963
+ }
32964
+ r2.value = val.rgba.r.toString();
32965
+ g2.value = val.rgba.g.toString();
32966
+ b2.value = val.rgba.b.toString();
32967
+ a2.value = val.rgba.a.toString();
32968
+ validate();
32969
+ }, {
32970
+ deep: true
32971
+ });
32972
+ const handleAlphaTab = (e) => {
32973
+ emit("tab", e);
32974
+ };
32975
+ const handleInput = (key2, value) => {
32976
+ const colorList = {
32977
+ r: r2,
32978
+ g: g2,
32979
+ b: b2,
32980
+ a: a2,
32981
+ hex
32982
+ };
32983
+ colorList[key2].value = value;
32984
+ if (validate()) {
32985
+ const colorStr = key2 === "hex" ? hex.value : `rgba(${r2.value}, ${g2.value}, ${b2.value}, ${a2.value})`;
32986
+ emit("change", colorStr);
32987
+ }
32988
+ };
32989
+ const validate = () => {
32990
+ let result = true;
32991
+ if (hex.value.startsWith("#") && (hex.value.length === 4 || hex.value.length === 7) && !hex.value.slice(1).match(/[^0-9a-fA-F]/)) {
32992
+ hex.error = false;
32993
+ } else {
32994
+ hex.error = true;
32995
+ result = false;
32996
+ }
32997
+ if (a2.value !== "" && a2.value >= 0 && a2.value <= 1) {
32998
+ a2.error = false;
32999
+ } else {
33000
+ a2.error = true;
33001
+ result = false;
33002
+ }
33003
+ for (const colorInfo of [r2, g2, b2]) {
33004
+ const {
33005
+ value
33006
+ } = colorInfo;
33007
+ if (value !== "" && value >= 0 && value <= 255) {
33008
+ colorInfo.error = false;
33009
+ } else {
33010
+ colorInfo.error = true;
33011
+ result = false;
33012
+ }
33013
+ }
33014
+ return result;
33015
+ };
33016
+ return () => createVNode("div", {
33017
+ "class": "bk-color-picker-input"
33018
+ }, [createVNode("div", {
33019
+ "class": "bk-color-picker-input-hex"
33020
+ }, [createVNode(InputContainer, {
33021
+ "info": hex,
33022
+ "onInput": handleInput
33023
+ }, null)]), createVNode("div", {
33024
+ "class": "bk-color-picker-input-rgba"
33025
+ }, [createVNode(InputContainer, {
33026
+ "info": r2,
33027
+ "onInput": handleInput
33028
+ }, null), createVNode(InputContainer, {
33029
+ "info": g2,
33030
+ "onInput": handleInput
33031
+ }, null), createVNode(InputContainer, {
33032
+ "info": b2,
33033
+ "onInput": handleInput
33034
+ }, null), createVNode(InputContainer, {
33035
+ "info": a2,
33036
+ "onInput": handleInput,
33037
+ "onTab": handleAlphaTab
33038
+ }, null)])]);
33039
+ }
33040
+ });
33041
+ const formatColor = (colorParam) => {
33042
+ let colorValue = colorParam;
33043
+ if (colorParam === "") {
33044
+ colorValue = "#FFFFFF";
33045
+ }
33046
+ const tinyColor = tinycolor(colorParam);
33047
+ const hsl = tinyColor.toHsl();
33048
+ const hsv = tinyColor.toHsv();
33049
+ if (hsl.s === 0) {
33050
+ hsl.h = colorValue.h || 0;
33051
+ hsv.h = colorValue.h || 0;
33052
+ }
33053
+ if (hsv.v < 0.0164) {
33054
+ hsv.h = colorValue.h || 0;
33055
+ hsv.s = colorValue.s || 0;
33056
+ }
33057
+ if (hsl.l < 0.01) {
33058
+ hsl.h = colorValue.h || 0;
33059
+ hsl.s = colorValue.s || 0;
33060
+ }
33061
+ return {
33062
+ hsl,
33063
+ hsv,
33064
+ hex: tinyColor.toHexString().toUpperCase(),
33065
+ rgba: tinyColor.toRgb()
33066
+ };
33067
+ };
33068
+ const clamp = (value, min2, max2) => {
33069
+ if (value < min2) {
33070
+ return min2;
33071
+ }
33072
+ if (value > max2) {
33073
+ return max2;
33074
+ }
33075
+ return value;
33076
+ };
33077
+ const getTouches = (e, prop) => e.touches ? e.touches[0][prop] : 0;
33078
+ const toRGBAString = (rgba) => {
33079
+ const { r: r2, g: g2, b: b2, a: a2 } = rgba;
33080
+ return `rgba(${[r2, g2, b2, a2].join(",")})`;
33081
+ };
33082
+ const colorPickerProps$3 = {
33083
+ colorObj: PropTypes.object.isRequired
33084
+ };
33085
+ var HueSlider = defineComponent({
33086
+ name: "ColorPicker",
33087
+ props: colorPickerProps$3,
33088
+ emits: ["change"],
33089
+ setup(props2, {
33090
+ emit
33091
+ }) {
33092
+ const containerRef = ref(null);
33093
+ const pointerStyle = computed(() => ({
33094
+ left: `${props2.colorObj.hsv.h / 360 * 100}%`
33095
+ }));
33096
+ const handleArrowKeydown = (e) => {
33097
+ const {
33098
+ clientWidth
33099
+ } = containerRef.value;
33100
+ let left2 = props2.colorObj.hsv.h / 360 * clientWidth;
33101
+ const step = 2;
33102
+ const hugeStep = 10;
33103
+ switch (e.code) {
33104
+ case "ArrowLeft":
33105
+ e.preventDefault();
33106
+ left2 = clamp(left2 - step, 0, clientWidth);
33107
+ break;
33108
+ case "ArrowRight":
33109
+ e.preventDefault();
33110
+ left2 = clamp(left2 + step, 0, clientWidth);
33111
+ break;
33112
+ case "ArrowUp":
33113
+ e.preventDefault();
33114
+ left2 = clamp(left2 - hugeStep, 0, clientWidth);
33115
+ break;
33116
+ case "ArrowDown":
33117
+ e.preventDefault();
33118
+ left2 = clamp(left2 + hugeStep, 0, clientWidth);
33119
+ break;
33120
+ default:
33121
+ return;
33122
+ }
33123
+ handlePointChange(null, left2);
33124
+ };
33125
+ const handleMouseDown = (e) => {
33126
+ containerRef.value.focus();
33127
+ handlePointChange(e);
33128
+ window.addEventListener("mousemove", handlePointChange, {
33129
+ passive: true
33130
+ });
33131
+ window.addEventListener("mouseup", handleMouseUp);
33132
+ };
33133
+ const handleMouseUp = () => {
33134
+ window.removeEventListener("mousemove", handlePointChange);
33135
+ window.removeEventListener("mouseup", handleMouseUp);
33136
+ };
33137
+ const handlePointChange = (e, appointedLeft) => {
33138
+ const {
33139
+ clientWidth
33140
+ } = containerRef.value;
33141
+ const left2 = appointedLeft !== void 0 ? appointedLeft : getLeft(e);
33142
+ changeColor(left2 / clientWidth);
33143
+ };
33144
+ const getLeft = (e) => {
33145
+ const xOffset = containerRef.value.getBoundingClientRect().left + window.pageXOffset;
33146
+ const pageX = e.pageX || getTouches(e, "PageX");
33147
+ return clamp(pageX - xOffset, 0, containerRef.value.clientWidth);
33148
+ };
33149
+ const changeColor = (ratio) => {
33150
+ const {
33151
+ h: h2,
33152
+ s: s2,
33153
+ l: l2,
33154
+ a: a2
33155
+ } = props2.colorObj.hsl;
33156
+ const newHue = ratio * 360;
33157
+ if (h2 !== newHue) {
33158
+ emit("change", {
33159
+ h: newHue,
33160
+ s: s2,
33161
+ l: l2,
33162
+ a: a2
33163
+ });
33164
+ }
33165
+ };
33166
+ return () => createVNode("div", {
33167
+ "ref": containerRef,
33168
+ "tabindex": "0",
33169
+ "class": "bk-color-picker-hue",
33170
+ "onKeydown": handleArrowKeydown,
33171
+ "onMousedown": (e) => {
33172
+ e.stopPropagation();
33173
+ e.preventDefault();
33174
+ handleMouseDown(e);
33175
+ }
33176
+ }, [createVNode("div", {
33177
+ "class": "bk-color-picker-hue-pointer",
33178
+ "style": pointerStyle.value
33179
+ }, [createVNode("div", {
33180
+ "class": "bk-color-picker-hue-rectangle"
33181
+ }, null)])]);
33182
+ }
33183
+ });
33184
+ const colorPickerProps$2 = {
33185
+ colorObj: PropTypes.object.isRequired,
33186
+ recommend: PropTypes.oneOfType([PropTypes.array.def(() => []), PropTypes.bool.def(true)]).isRequired
33187
+ };
33188
+ var RecommendColors = defineComponent({
33189
+ props: colorPickerProps$2,
33190
+ emits: ["change", "tab"],
33191
+ setup(props2, {
33192
+ emit
33193
+ }) {
33194
+ const isFocused = ref(false);
33195
+ const selectedIndex = ref(-1);
33196
+ const selectedColor = ref(null);
33197
+ watch(() => props2.colorObj, () => {
33198
+ selectedIndex.value = -1;
33199
+ selectedColor.value = null;
33200
+ }, {
33201
+ deep: true
33202
+ });
33203
+ const colors = computed(() => getColorsFromRecommend(props2.recommend));
33204
+ const getColorClass = (color, index) => classes({
33205
+ "bk-color-picker-empty": color === "",
33206
+ "bk-color-picker-recommend-selected-color": isFocused.value && selectedIndex.value === index
33207
+ }, "bk-color-picker-recommend-color");
33208
+ const handleKeydown = (e) => {
33209
+ if (e.code === "Tab") {
33210
+ emit("tab", e);
33211
+ } else {
33212
+ let index = 0;
33213
+ const rowNum = 10;
33214
+ const max2 = colors.value.length - 1;
33215
+ switch (e.code) {
33216
+ case "ArrowLeft":
33217
+ e.preventDefault();
33218
+ index = clamp(selectedIndex.value - 1, 0, max2);
33219
+ break;
33220
+ case "ArrowRight":
33221
+ e.preventDefault();
33222
+ index = clamp(selectedIndex.value + 1, 0, max2);
33223
+ break;
33224
+ case "ArrowUp":
33225
+ e.preventDefault();
33226
+ index = clamp(selectedIndex.value - rowNum, 0, max2);
33227
+ break;
33228
+ case "ArrowDown":
33229
+ e.preventDefault();
33230
+ index = clamp(selectedIndex.value + rowNum, 0, max2);
33231
+ break;
33232
+ default:
33233
+ return;
33234
+ }
33235
+ selectColor(index);
33236
+ }
33237
+ };
33238
+ const selectColor = (index) => {
33239
+ const color = colors.value[index];
33240
+ emit("change", color);
33241
+ nextTick(() => {
33242
+ selectedIndex.value = index;
33243
+ selectedColor.value = color;
33244
+ });
33245
+ };
33246
+ const getColorsFromRecommend = (recommend) => {
33247
+ if (recommend === true) {
33248
+ return ["", "#ff4500", "#ff8c00", "#ffd700", "#90ee90", "#ddffff", "#00ced1", "#3a84ff", "#a933f5", "#db7093", "#000000", "#494949", "#9B9B9B", "#ffffff"];
33249
+ }
33250
+ if (Array.isArray(recommend)) {
33251
+ return recommend.map((color) => tinycolor(color).isValid() ? color : "");
33252
+ }
33253
+ };
33254
+ return () => createVNode("div", {
33255
+ "tabindex": "0",
33256
+ "class": "bk-color-picker-recommend",
33257
+ "onFocus": () => isFocused.value = true,
33258
+ "onBlur": () => isFocused.value = false,
33259
+ "onKeydown": handleKeydown
33260
+ }, [colors.value.map((color, index) => createVNode("div", {
33261
+ "style": `background: ${color || "#fff"}`,
33262
+ "class": getColorClass(color, index),
33263
+ "onClick": () => selectColor(index)
33264
+ }, [selectedIndex.value === index ? createVNode("div", {
33265
+ "class": "bk-color-picker-pointer"
33266
+ }, [createVNode("div", {
33267
+ "class": "bk-color-picker-circle"
33268
+ }, null)]) : void 0]))]);
33269
+ }
33270
+ });
33271
+ const colorPickerProps$1 = {
33272
+ colorObj: PropTypes.object.isRequired
33273
+ };
33274
+ var SaturationPanel = defineComponent({
33275
+ props: colorPickerProps$1,
33276
+ emits: ["change"],
33277
+ setup(props2, {
33278
+ emit
33279
+ }) {
33280
+ const containerRef = ref(null);
33281
+ const backgroundStyle = computed(() => ({
33282
+ background: `hsl(${props2.colorObj.hsv.h}, 100%, 50%)`
33283
+ }));
33284
+ const pointerStyle = computed(() => ({
33285
+ top: `${(1 - props2.colorObj.hsv.v) * 100}%`,
33286
+ left: `${props2.colorObj.hsv.s * 100}%`
33287
+ }));
33288
+ const handleMouseDown = (e) => {
33289
+ containerRef.value.focus();
33290
+ handlePointChange(e);
33291
+ window.addEventListener("mousemove", handlePointChange, {
33292
+ passive: true
33293
+ });
33294
+ window.addEventListener("mouseup", handleMouseUp);
33295
+ };
33296
+ const handleMouseUp = () => {
33297
+ window.removeEventListener("mousemove", handlePointChange);
33298
+ window.removeEventListener("mouseup", handleMouseUp);
33299
+ };
33300
+ const handleArrowKeydown = (e) => {
33301
+ const {
33302
+ clientWidth,
33303
+ clientHeight
33304
+ } = containerRef.value;
33305
+ let left2 = props2.colorObj.hsv.s * clientWidth;
33306
+ let top2 = (1 - props2.colorObj.hsv.v) * clientHeight;
33307
+ const step = 10;
33308
+ switch (e.code) {
33309
+ case "ArrowLeft":
33310
+ e.preventDefault();
33311
+ left2 = clamp(left2 - step, 0, clientWidth);
33312
+ break;
33313
+ case "ArrowRight":
33314
+ e.preventDefault();
33315
+ left2 = clamp(left2 + step, 0, clientWidth);
33316
+ break;
33317
+ case "ArrowUp":
33318
+ e.preventDefault();
33319
+ top2 = clamp(top2 - step, 0, clientHeight);
33320
+ break;
33321
+ case "ArrowDown":
33322
+ e.preventDefault();
33323
+ top2 = clamp(top2 + step, 0, clientHeight);
33324
+ break;
33325
+ default:
33326
+ return;
33327
+ }
33328
+ handlePointChange(null, left2, top2);
33329
+ };
33330
+ const handlePointChange = (e, appointedLeft, appointedTop) => {
33331
+ const {
33332
+ clientWidth,
33333
+ clientHeight
33334
+ } = containerRef.value;
33335
+ const left2 = appointedLeft !== void 0 ? appointedLeft : getLeft(e);
33336
+ const top2 = appointedTop !== void 0 ? appointedTop : getTop(e);
33337
+ const saturation = left2 / clientWidth;
33338
+ const bright = 1 - top2 / clientHeight;
33339
+ changeColor(props2.colorObj.hsv.h, saturation, bright, props2.colorObj.hsv.a);
33340
+ };
33341
+ const getLeft = (e) => {
33342
+ const xOffset = containerRef.value.getBoundingClientRect().left + window.pageXOffset;
33343
+ const pageX = e.pageX || getTouches(e, "PageX");
33344
+ return clamp(pageX - xOffset, 0, containerRef.value.clientWidth);
33345
+ };
33346
+ const getTop = (e) => {
33347
+ const yOffset = containerRef.value.getBoundingClientRect().top + window.pageYOffset;
33348
+ const pageY = e.pageY || getTouches(e, "PageY");
33349
+ return clamp(pageY - yOffset, 0, containerRef.value.clientHeight);
33350
+ };
33351
+ const changeColor = (h2, s2, v2, a2) => {
33352
+ emit("change", {
33353
+ h: h2,
33354
+ s: s2,
33355
+ v: v2,
33356
+ a: a2
33357
+ });
33358
+ };
33359
+ return () => createVNode("div", {
33360
+ "ref": containerRef,
33361
+ "tabindex": "0",
33362
+ "class": "bk-color-picker-saturation",
33363
+ "style": backgroundStyle.value,
33364
+ "onKeydown": handleArrowKeydown,
33365
+ "onMousedown": (e) => {
33366
+ e.stopPropagation();
33367
+ handleMouseDown(e);
33368
+ }
33369
+ }, [createVNode("div", {
33370
+ "class": "bk-color-picker-saturation-white"
33371
+ }, null), createVNode("div", {
33372
+ "class": "bk-color-picker-saturation-black"
33373
+ }, null), createVNode("div", {
33374
+ "class": "bk-color-picker-pointer",
33375
+ "style": pointerStyle.value
33376
+ }, [createVNode("div", {
33377
+ "class": "bk-color-picker-circle"
33378
+ }, null)])]);
33379
+ }
33380
+ });
33381
+ const colorPickerProps = {
33382
+ modelValue: PropTypes.string.def(""),
33383
+ disabled: PropTypes.bool.def(false),
33384
+ readonly: PropTypes.bool.def(false),
33385
+ transfer: PropTypes.bool.def(false),
33386
+ size: PropTypes.size(["", "small", "large"]).def(""),
33387
+ showValue: PropTypes.bool.def(true),
33388
+ recommend: PropTypes.oneOfType([PropTypes.array.def(() => []), PropTypes.bool.def(true)]).def(true),
33389
+ extCls: PropTypes.string.def("")
33390
+ };
33391
+ const whiteColorObj = formatColor("#FFFFFF");
33392
+ var Component = defineComponent({
33393
+ name: "ColorPicker",
33394
+ directives: {
33395
+ clickoutside: ClickOutside
33396
+ },
33397
+ props: colorPickerProps,
33398
+ emits: ["update:modelValue", "change"],
33399
+ setup(props2, {
33400
+ emit
33401
+ }) {
33402
+ const showDropdown = ref(false);
33403
+ const colorStr = ref("");
33404
+ const colorObj = reactive(JSON.parse(JSON.stringify(whiteColorObj)));
33405
+ const dropRef = ref(null);
33406
+ const saturationPanelRef = ref(null);
33407
+ const referenceRef = ref(null);
33408
+ const colorPickerCls = computed(() => classes({
33409
+ [`bk-color-picker-${props2.size}`]: props2.size,
33410
+ "bk-color-picker-show-dropdown": showDropdown.value,
33411
+ "bk-color-picker-show-value": props2.showValue,
33412
+ "bk-color-picker-disabled": props2.disabled || props2.readonly
33413
+ }, `bk-color-picker ${props2.extCls}`));
33414
+ const isRenderRecommend = computed(() => Boolean(props2.recommend === true || Array.isArray(props2.recommend) && props2.recommend.length));
33415
+ onBeforeMount(() => {
33416
+ changeColorFromProps({
33417
+ isCreated: true
33418
+ });
33419
+ });
33420
+ watch(() => props2.modelValue, () => {
33421
+ changeColorFromProps();
33422
+ });
33423
+ const handleTriggerKeydown = (e) => {
33424
+ if (e.code === "Enter" || e.code === "NumpadEnter") {
33425
+ toggleDropdown();
33426
+ } else if (e.code === "Escape") {
33427
+ closeDropdown();
33428
+ }
33429
+ };
33430
+ const handleDropdownKeydown = (e) => {
33431
+ if (props2.transfer) {
33432
+ handleTriggerKeydown(e);
33433
+ }
33434
+ };
33435
+ const toggleDropdown = () => {
33436
+ if (props2.disabled || props2.readonly) {
33437
+ return;
33438
+ }
33439
+ showDropdown.value ? closeDropdown() : openDropdown();
33440
+ };
33441
+ const handleTabInput = (e) => {
33442
+ if (!isRenderRecommend.value) {
33443
+ e.preventDefault();
33444
+ saturationPanelRef.value.$el.focus();
33445
+ }
33446
+ };
33447
+ const handleTabRecommend = (e) => {
33448
+ e.preventDefault();
33449
+ saturationPanelRef.value.$el.focus();
33450
+ };
33451
+ const openDropdown = () => {
33452
+ var _a;
33453
+ showDropdown.value = true;
33454
+ (_a = dropRef.value) == null ? void 0 : _a.updateDropdown();
33455
+ setTimeout(() => {
33456
+ const hexInput = dropRef.value.$el.querySelector(".bk-color-picker-input-hex .bk-color-picker-input-value");
33457
+ hexInput.select();
33458
+ }, 100);
33459
+ };
33460
+ const closeDropdown = () => {
33461
+ var _a;
33462
+ if (showDropdown.value) {
33463
+ nextTick(() => referenceRef.value.focus());
33464
+ showDropdown.value = false;
33465
+ (_a = dropRef.value) == null ? void 0 : _a.destoryDropdown();
33466
+ changeColorFromProps();
33467
+ }
33468
+ };
33469
+ const changeColorFromProps = ({
33470
+ isCreated = false
33471
+ } = {}) => {
33472
+ if (props2.modelValue === "") {
33473
+ if (colorStr.value !== "") {
33474
+ colorStr.value = "";
33475
+ Object.assign(colorObj, whiteColorObj);
33476
+ emit("update:modelValue", colorStr.value);
33477
+ }
33478
+ return;
33479
+ }
33480
+ const propsColorObj = formatColor(props2.modelValue);
33481
+ const propsColorStr = propsColorObj.rgba.a === 1 ? propsColorObj.hex : toRGBAString(propsColorObj.rgba);
33482
+ if (propsColorStr !== colorStr.value) {
33483
+ const isValid2 = tinycolor(props2.modelValue).isValid();
33484
+ if (isCreated) {
33485
+ if (!isValid2) {
33486
+ Object.assign(colorObj, whiteColorObj);
33487
+ emit("change", "");
33488
+ } else {
33489
+ colorStr.value = propsColorStr.toLowerCase() === props2.modelValue.toLowerCase() ? props2.modelValue : propsColorStr;
33490
+ Object.assign(colorObj, propsColorObj);
33491
+ }
33492
+ } else {
33493
+ if (!isValid2) {
33494
+ colorStr.value = "";
33495
+ Object.assign(colorObj, whiteColorObj);
33496
+ } else if (propsColorStr.toLowerCase() !== colorStr.value.toLowerCase()) {
33497
+ Object.assign(colorObj, propsColorObj);
33498
+ colorStr.value = propsColorStr;
33499
+ }
33500
+ }
33501
+ }
33502
+ };
33503
+ const handleColorChange = (val) => {
33504
+ if (val === "") {
33505
+ colorStr.value = "";
33506
+ Object.assign(colorObj, whiteColorObj);
33507
+ emit("update:modelValue", "");
33508
+ emit("change", "");
33509
+ return;
33510
+ }
33511
+ const handleColorObj = formatColor(val);
33512
+ const handleColorStr = handleColorObj.rgba.a === 1 ? handleColorObj.hex : toRGBAString(handleColorObj.rgba);
33513
+ colorStr.value = handleColorStr;
33514
+ Object.assign(colorObj, handleColorObj);
33515
+ emit("change", handleColorStr);
33516
+ emit("update:modelValue", colorStr.value);
33517
+ };
33518
+ const hideDropDown = () => {
33519
+ showDropdown.value = false;
33520
+ };
33521
+ return () => withDirectives(createVNode("div", {
33522
+ "ref": referenceRef,
33523
+ "tabindex": "0",
33524
+ "class": colorPickerCls.value,
33525
+ "onKeydown": handleTriggerKeydown,
33526
+ "onClick": toggleDropdown
33527
+ }, [createVNode("div", {
33528
+ "class": "bk-color-picker-color"
33529
+ }, [createVNode("span", {
33530
+ "class": `bk-color-picker-color-square ${!colorStr.value && "bk-color-picker-empty"}`,
33531
+ "style": `background: ${colorStr.value || "#FFF"}`
33532
+ }, null)]), props2.showValue ? createVNode("div", {
33533
+ "class": "bk-color-picker-text"
33534
+ }, [createVNode("span", null, [colorStr.value])]) : void 0, createVNode("div", {
33535
+ "class": "bk-color-picker-icon"
33536
+ }, [createVNode(angleUp, {
33537
+ "class": "icon-angle-down"
33538
+ }, null)]), createVNode(Transition, {
33539
+ "name": "bk-fade-down-transition"
33540
+ }, {
33541
+ default: () => [withDirectives(createVNode(PickerDropdown, {
33542
+ "ref": dropRef,
33543
+ "triggerRef": referenceRef.value
33544
+ }, {
33545
+ default: () => [createVNode("div", {
33546
+ "class": "bk-color-dropdown-container"
33547
+ }, [createVNode("div", {
33548
+ "class": "bk-color-picker-dropdown",
33549
+ "onClick": (e) => {
33550
+ e.stopPropagation();
33551
+ },
33552
+ "onMousedown": (e) => {
33553
+ e.stopPropagation();
33554
+ },
33555
+ "onKeydown": handleDropdownKeydown
33556
+ }, [createVNode(SaturationPanel, {
33557
+ "ref": saturationPanelRef,
33558
+ "colorObj": colorObj,
33559
+ "onChange": handleColorChange
33560
+ }, null), createVNode(HueSlider, {
33561
+ "colorObj": colorObj,
33562
+ "onChange": handleColorChange
33563
+ }, null), createVNode(ColorInput, {
33564
+ "colorObj": colorObj,
33565
+ "onTab": handleTabInput,
33566
+ "onChange": handleColorChange
33567
+ }, null), isRenderRecommend.value ? createVNode("div", {
33568
+ "class": "bk-color-picker-recommend-container"
33569
+ }, [createVNode(RecommendColors, {
33570
+ "colorObj": colorObj,
33571
+ "recommend": props2.recommend,
33572
+ "onTab": handleTabRecommend,
33573
+ "onChange": handleColorChange
33574
+ }, null)]) : void 0])])]
33575
+ }), [[vShow, showDropdown.value]])]
33576
+ })]), [[resolveDirective("clickoutside"), hideDropDown]]);
33577
+ }
33578
+ });
33579
+ const BkColorPicker = withInstall(Component);
31955
33580
  var components = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
31956
33581
  __proto__: null,
31957
33582
  Alert: BkAlert,
@@ -32006,7 +33631,8 @@ var components = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProp
32006
33631
  TimeLine: BkSteps$1,
32007
33632
  Process: BkSteps,
32008
33633
  Upload,
32009
- CodeDiff: BkCodeDiff
33634
+ CodeDiff: BkCodeDiff,
33635
+ ColorPicker: BkColorPicker
32010
33636
  }, Symbol.toStringTag, { value: "Module" }));
32011
33637
  const createInstall = (prefix = "Bk") => (app) => {
32012
33638
  const pre = app.config.globalProperties.bkUIPrefix || prefix;
@@ -32024,4 +33650,4 @@ var preset = {
32024
33650
  install: createInstall(),
32025
33651
  version: "0.0.1"
32026
33652
  };
32027
- export { BkAffix as Affix, BkAlert as Alert, BkAnimateNumber as AnimateNumber, BkBacktop as Backtop, BkBadge as Badge, BkBreadcrumb as Breadcrumb, BkButton as Button, BkCard as Card, BkCascader as Cascader, BkCheckbox as Checkbox, BkCodeDiff as CodeDiff, BkCollapse as Collapse, BkContainer as Container, BkDatePicker as DatePicker, BkDialog as Dialog, BkDivider as Divider, BkDropdown as Dropdown, BkException as Exception, BkFixedNavbar as FixedNavbar, BkForm as Form, InfoBox, BkInput as Input, BkLink as Link, BkLoading as Loading, BkMenu as Menu, Message, BkModal as Modal, Navigation, Notify, BkPagination as Pagination, BkPopover as Popover, BkPopover2 as Popover2, BkSteps as Process, BkProgress as Progress, BkRadio as Radio, BkRate as Rate, BkResizeLayout as ResizeLayout, BkSelect as Select, BkSideslider as Sideslider, Slider, BkSteps$2 as Steps, BkSwiper as Swiper, BkSwitcher as Switcher, BkTab as Tab, BkTable as Table, BkTag as Tag, TagInput, BkSteps$1 as TimeLine, Transfer, BkTree as Tree, Upload, BkVirtualRender as VirtualRender, tooltips as bkTooltips, ClickOutside as clickoutside, BkContainer as containerProps, preset as default, mousewheel };
33653
+ export { BkAffix as Affix, BkAlert as Alert, BkAnimateNumber as AnimateNumber, BkBacktop as Backtop, BkBadge as Badge, BkBreadcrumb as Breadcrumb, BkButton as Button, BkCard as Card, BkCascader as Cascader, BkCheckbox as Checkbox, BkCodeDiff as CodeDiff, BkCollapse as Collapse, BkColorPicker as ColorPicker, BkContainer as Container, BkDatePicker as DatePicker, BkDialog as Dialog, BkDivider as Divider, BkDropdown as Dropdown, BkException as Exception, BkFixedNavbar as FixedNavbar, BkForm as Form, InfoBox, BkInput as Input, BkLink as Link, BkLoading as Loading, BkMenu as Menu, Message, BkModal as Modal, Navigation, Notify, BkPagination as Pagination, BkPopover as Popover, BkPopover2 as Popover2, BkSteps as Process, BkProgress as Progress, BkRadio as Radio, BkRate as Rate, BkResizeLayout as ResizeLayout, BkSelect as Select, BkSideslider as Sideslider, Slider, BkSteps$2 as Steps, BkSwiper as Swiper, BkSwitcher as Switcher, BkTab as Tab, BkTable as Table, BkTag as Tag, TagInput, BkSteps$1 as TimeLine, Transfer, BkTree as Tree, Upload, BkVirtualRender as VirtualRender, tooltips as bkTooltips, ClickOutside as clickoutside, BkContainer as containerProps, preset as default, mousewheel };