bkui-vue 0.0.1-beta.152 → 0.0.1-beta.155
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.cjs.js +55 -55
- package/dist/index.esm.js +1713 -95
- package/dist/index.umd.js +56 -56
- package/dist/style.css +1 -1
- package/dist/style.variable.css +1 -1
- package/lib/components.d.ts +1 -0
- package/lib/components.js +1 -1
- package/lib/select/index.d.ts +25 -1
- package/lib/select/index.js +1 -1
- package/lib/select/option.d.ts +1 -0
- package/lib/select/select.css +4 -4
- package/lib/select/select.d.ts +11 -0
- package/lib/select/select.less +5 -5
- package/lib/select/select.variable.css +4 -4
- package/lib/select/type.d.ts +1 -0
- package/lib/upload/index.js +1 -1
- package/package.json +1 -1
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
|
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 =
|
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$
|
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$
|
8542
|
-
var Component$
|
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$
|
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$
|
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$
|
8745
|
-
var Component$
|
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$
|
8813
|
-
var Component$
|
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$
|
8890
|
-
var Component$
|
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$
|
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$
|
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$
|
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$
|
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$
|
9185
|
+
const BkButton = withInstallProps(Component$y, { ButtonGroup });
|
9186
9186
|
const inputType = {
|
9187
9187
|
type: PropTypes.string.def("text"),
|
9188
9188
|
clearable: PropTypes.bool,
|
@@ -9246,7 +9246,7 @@ const inputEmitEventsType = {
|
|
9246
9246
|
[EVENTS$2.COMPOSITIONUPDATE]: CompositionEventFunction,
|
9247
9247
|
[EVENTS$2.COMPOSITIONEND]: CompositionEventFunction
|
9248
9248
|
};
|
9249
|
-
var Component$
|
9249
|
+
var Component$x = defineComponent({
|
9250
9250
|
name: "Input",
|
9251
9251
|
inheritAttrs: false,
|
9252
9252
|
props: inputType,
|
@@ -9462,8 +9462,8 @@ var Component$w = defineComponent({
|
|
9462
9462
|
};
|
9463
9463
|
}
|
9464
9464
|
});
|
9465
|
-
const BkInput = withInstall(Component$
|
9466
|
-
var Component$
|
9465
|
+
const BkInput = withInstall(Component$x);
|
9466
|
+
var Component$w = defineComponent({
|
9467
9467
|
name: "Card",
|
9468
9468
|
props: {
|
9469
9469
|
title: PropTypes.string,
|
@@ -9556,7 +9556,7 @@ var Component$v = defineComponent({
|
|
9556
9556
|
}, [(_l = (_k = (_j = this.$slots).footer) == null ? void 0 : _k.call(_j)) != null ? _l : "Footer"]) : ""]) : ""]);
|
9557
9557
|
}
|
9558
9558
|
});
|
9559
|
-
const BkCard = withInstall(Component$
|
9559
|
+
const BkCard = withInstall(Component$w);
|
9560
9560
|
const checkboxGroupKey = Symbol("CheckboxGroup");
|
9561
9561
|
function useFocus$1() {
|
9562
9562
|
const isFocus = ref(false);
|
@@ -9657,7 +9657,7 @@ const checkboxProps = {
|
|
9657
9657
|
beforeChange: PropTypes.func,
|
9658
9658
|
size: PropTypes.size().def("large")
|
9659
9659
|
};
|
9660
|
-
var Component$
|
9660
|
+
var Component$v = defineComponent({
|
9661
9661
|
name: "Checkbox",
|
9662
9662
|
props: checkboxProps,
|
9663
9663
|
emits: ["update:modelValue", "change"],
|
@@ -9761,7 +9761,7 @@ var BkCheckboxGroup = defineComponent({
|
|
9761
9761
|
}, [(_a = this.$slots) == null ? void 0 : _a.default()]);
|
9762
9762
|
}
|
9763
9763
|
});
|
9764
|
-
const BkCheckbox = withInstallProps(Component$
|
9764
|
+
const BkCheckbox = withInstallProps(Component$v, { Group: BkCheckboxGroup });
|
9765
9765
|
const propsCollapse = {
|
9766
9766
|
list: PropTypes.arrayOf(PropTypes.any).def([]),
|
9767
9767
|
idFiled: PropTypes.string.def("$index"),
|
@@ -10088,7 +10088,7 @@ const propsMixin$1 = {
|
|
10088
10088
|
dialogType: PropTypes.commonType(["show", "operation", "confirm", "process"], "dialogType").def("operation"),
|
10089
10089
|
multiInstance: PropTypes.bool.def(true)
|
10090
10090
|
};
|
10091
|
-
var Component$
|
10091
|
+
var Component$u = defineComponent({
|
10092
10092
|
name: "Modal",
|
10093
10093
|
props: __spreadValues({}, propsMixin$1),
|
10094
10094
|
emits: ["quick-close", "quickClose", "hidden", "shown", "close"],
|
@@ -10190,7 +10190,7 @@ var Component$t = defineComponent({
|
|
10190
10190
|
})]);
|
10191
10191
|
}
|
10192
10192
|
});
|
10193
|
-
const BkModal = withInstallProps(Component$
|
10193
|
+
const BkModal = withInstallProps(Component$u, { propsMixin: propsMixin$1 }, true);
|
10194
10194
|
const props = __spreadProps(__spreadValues({}, propsMixin$1), {
|
10195
10195
|
width: PropTypes.oneOfType([String, Number]).def(""),
|
10196
10196
|
height: PropTypes.oneOfType([String, Number]).def(""),
|
@@ -10427,7 +10427,7 @@ var Building = "
|
|
10427
10427
|
var empty = "";
|
10428
10428
|
var login = "";
|
10429
10429
|
var searchEmpty = "";
|
10430
|
-
var Component$
|
10430
|
+
var Component$t = defineComponent({
|
10431
10431
|
name: "Exception",
|
10432
10432
|
props: {
|
10433
10433
|
type: PropTypes.commonType(["404", "403", "500", "building", "empty", "search-empty", "login"], "type").def("404"),
|
@@ -10471,8 +10471,8 @@ var Component$s = defineComponent({
|
|
10471
10471
|
};
|
10472
10472
|
}
|
10473
10473
|
});
|
10474
|
-
const BkException = withInstall(Component$
|
10475
|
-
var Component$
|
10474
|
+
const BkException = withInstall(Component$t);
|
10475
|
+
var Component$s = defineComponent({
|
10476
10476
|
name: "FixedNavbar",
|
10477
10477
|
props: {
|
10478
10478
|
navItems: PropTypes.array.def([]),
|
@@ -10513,8 +10513,8 @@ var Component$r = defineComponent({
|
|
10513
10513
|
}, [item.text]) : ""]))]);
|
10514
10514
|
}
|
10515
10515
|
});
|
10516
|
-
const BkFixedNavbar = withInstall(Component$
|
10517
|
-
var Component$
|
10516
|
+
const BkFixedNavbar = withInstall(Component$s);
|
10517
|
+
var Component$r = defineComponent({
|
10518
10518
|
name: "Link",
|
10519
10519
|
props: {
|
10520
10520
|
theme: PropTypes.theme(["danger", "success", "primary", "warning", "default"]).def("default"),
|
@@ -10551,7 +10551,7 @@ var Component$q = defineComponent({
|
|
10551
10551
|
}, [createVNode("span", null, [(_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a)])]);
|
10552
10552
|
}
|
10553
10553
|
});
|
10554
|
-
const BkLink = withInstall(Component$
|
10554
|
+
const BkLink = withInstall(Component$r);
|
10555
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"];
|
10556
10556
|
const EventProps$2 = {
|
10557
10557
|
onAfterHidden: Function,
|
@@ -10594,7 +10594,7 @@ const PopoverProps$1 = __spreadValues({
|
|
10594
10594
|
PropTypes.string
|
10595
10595
|
]).def([])
|
10596
10596
|
}, EventProps$2);
|
10597
|
-
var Component$
|
10597
|
+
var Component$q = defineComponent({
|
10598
10598
|
name: "Popover",
|
10599
10599
|
props: PopoverProps$1,
|
10600
10600
|
emits: ["afterHidden", "afterShow", "update:isShow"],
|
@@ -10744,7 +10744,7 @@ var Component$p = defineComponent({
|
|
10744
10744
|
};
|
10745
10745
|
}
|
10746
10746
|
});
|
10747
|
-
const BkPopover = withInstall(Component$
|
10747
|
+
const BkPopover = withInstall(Component$q);
|
10748
10748
|
var _populated = false;
|
10749
10749
|
var _ie, _firefox, _opera, _webkit, _chrome;
|
10750
10750
|
var _ie_real_version;
|
@@ -12876,7 +12876,7 @@ var usePopperId = (props2, prefix = "#") => {
|
|
12876
12876
|
resetFullscreenElementTag
|
12877
12877
|
};
|
12878
12878
|
};
|
12879
|
-
var Component$
|
12879
|
+
var Component$p = defineComponent({
|
12880
12880
|
name: "Popover2",
|
12881
12881
|
components: {
|
12882
12882
|
Content,
|
@@ -13078,7 +13078,7 @@ var Component$o = defineComponent({
|
|
13078
13078
|
});
|
13079
13079
|
}
|
13080
13080
|
});
|
13081
|
-
const BkPopover2 = withInstall(Component$
|
13081
|
+
const BkPopover2 = withInstall(Component$p);
|
13082
13082
|
const Circle = (_2, {
|
13083
13083
|
attrs,
|
13084
13084
|
slots
|
@@ -13201,7 +13201,7 @@ const Line = (_2, {
|
|
13201
13201
|
function _isSlot$6(s2) {
|
13202
13202
|
return typeof s2 === "function" || Object.prototype.toString.call(s2) === "[object Object]" && !isVNode(s2);
|
13203
13203
|
}
|
13204
|
-
var Component$
|
13204
|
+
var Component$o = defineComponent({
|
13205
13205
|
name: "Progress",
|
13206
13206
|
props: {
|
13207
13207
|
extCls: PropTypes.string,
|
@@ -13279,7 +13279,7 @@ var Component$n = defineComponent({
|
|
13279
13279
|
return createVNode("div", progressProps, [progress2]);
|
13280
13280
|
}
|
13281
13281
|
});
|
13282
|
-
const BkProgress = withInstall(Component$
|
13282
|
+
const BkProgress = withInstall(Component$o);
|
13283
13283
|
const radioGroupKey = Symbol("RadioGroup");
|
13284
13284
|
function useFocus() {
|
13285
13285
|
const isFocused = ref(false);
|
@@ -13376,7 +13376,7 @@ const radioProps = {
|
|
13376
13376
|
checked: PropTypes.bool.def(false),
|
13377
13377
|
disabled: PropTypes.bool.def(false)
|
13378
13378
|
};
|
13379
|
-
var Component$
|
13379
|
+
var Component$n = defineComponent({
|
13380
13380
|
name: "Radio",
|
13381
13381
|
props: radioProps,
|
13382
13382
|
emits: ["change", "update:modelValue"],
|
@@ -13537,7 +13537,7 @@ var RadioGroup = defineComponent({
|
|
13537
13537
|
}, [(_a = this.$slots) == null ? void 0 : _a.default()]);
|
13538
13538
|
}
|
13539
13539
|
});
|
13540
|
-
const BkRadio = withInstallProps(Component$
|
13540
|
+
const BkRadio = withInstallProps(Component$n, { Group: RadioGroup, Button: RadioButton });
|
13541
13541
|
var star = defineComponent({
|
13542
13542
|
name: "Star",
|
13543
13543
|
props: {
|
@@ -13599,7 +13599,7 @@ var star = defineComponent({
|
|
13599
13599
|
}, null)])])])])]))]);
|
13600
13600
|
}
|
13601
13601
|
});
|
13602
|
-
var Component$
|
13602
|
+
var Component$m = defineComponent({
|
13603
13603
|
name: "Rate",
|
13604
13604
|
components: {
|
13605
13605
|
star
|
@@ -13674,8 +13674,8 @@ var Component$l = defineComponent({
|
|
13674
13674
|
}, commonAttrs), null)]]);
|
13675
13675
|
}
|
13676
13676
|
});
|
13677
|
-
const BkRate = withInstall(Component$
|
13678
|
-
var Component$
|
13677
|
+
const BkRate = withInstall(Component$m);
|
13678
|
+
var Component$l = defineComponent({
|
13679
13679
|
name: "Swiper",
|
13680
13680
|
props: {
|
13681
13681
|
isLoop: PropTypes.bool.def(true),
|
@@ -13834,7 +13834,7 @@ var Component$k = defineComponent({
|
|
13834
13834
|
}, null)])]);
|
13835
13835
|
}
|
13836
13836
|
});
|
13837
|
-
const BkSwiper = withInstall(Component$
|
13837
|
+
const BkSwiper = withInstall(Component$l);
|
13838
13838
|
const selectKey = Symbol("BkSelect");
|
13839
13839
|
const optionGroupKey = Symbol("BkOptionGroup");
|
13840
13840
|
function useHover() {
|
@@ -13977,6 +13977,7 @@ var BkOption = defineComponent({
|
|
13977
13977
|
});
|
13978
13978
|
const multiple = computed(() => select2 == null ? void 0 : select2.multiple);
|
13979
13979
|
const isHover = computed(() => (select2 == null ? void 0 : select2.activeOptionValue) === value.value);
|
13980
|
+
const showSelectedIcon = computed(() => select2 == null ? void 0 : select2.showSelectedIcon);
|
13980
13981
|
const handleOptionClick = () => {
|
13981
13982
|
if (disabled.value)
|
13982
13983
|
return;
|
@@ -13997,6 +13998,7 @@ var BkOption = defineComponent({
|
|
13997
13998
|
selected,
|
13998
13999
|
multiple,
|
13999
14000
|
isHover,
|
14001
|
+
showSelectedIcon,
|
14000
14002
|
handleOptionClick,
|
14001
14003
|
handleMouseEnter
|
14002
14004
|
});
|
@@ -14017,11 +14019,11 @@ var BkOption = defineComponent({
|
|
14017
14019
|
}, [(_c = (_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a)) != null ? _c : createVNode("span", {
|
14018
14020
|
"class": "bk-select-option-item",
|
14019
14021
|
"title": this.label
|
14020
|
-
}, [this.label, this.multiple && this.selected && createVNode(done, {
|
14021
|
-
"class": "
|
14022
|
+
}, [this.label]), this.multiple && this.selected && this.showSelectedIcon && createVNode(done, {
|
14023
|
+
"class": "bk-select-selected-icon",
|
14022
14024
|
"width": 22,
|
14023
14025
|
"height": 22
|
14024
|
-
}, null)])
|
14026
|
+
}, null)]), [[vShow, this.visible]]);
|
14025
14027
|
}
|
14026
14028
|
});
|
14027
14029
|
var OptionGroup = defineComponent({
|
@@ -14103,7 +14105,7 @@ var OptionGroup = defineComponent({
|
|
14103
14105
|
}, [(_b = (_a = this.$slots).default) == null ? void 0 : _b.call(_a)]), [[vShow, !this.groupCollapse]])]), [[vShow, this.visible]]);
|
14104
14106
|
}
|
14105
14107
|
});
|
14106
|
-
var Component$
|
14108
|
+
var Component$k = defineComponent({
|
14107
14109
|
name: "Tag",
|
14108
14110
|
props: {
|
14109
14111
|
theme: PropTypes.theme(["success", "info", "warning", "danger"]).def(""),
|
@@ -14165,7 +14167,7 @@ var Component$j = defineComponent({
|
|
14165
14167
|
}, null) : ""]);
|
14166
14168
|
}
|
14167
14169
|
});
|
14168
|
-
const BkTag = withInstall(Component$
|
14170
|
+
const BkTag = withInstall(Component$k);
|
14169
14171
|
function _isSlot$5(s2) {
|
14170
14172
|
return typeof s2 === "function" || Object.prototype.toString.call(s2) === "[object Object]" && !isVNode(s2);
|
14171
14173
|
}
|
@@ -14254,7 +14256,7 @@ var SelectTagInput = defineComponent({
|
|
14254
14256
|
}, null), [[vModelText, this.value]]), (_d = (_c = this.$slots) == null ? void 0 : _c.suffix) == null ? void 0 : _d.call(_c)]);
|
14255
14257
|
}
|
14256
14258
|
});
|
14257
|
-
var Component$
|
14259
|
+
var Component$j = defineComponent({
|
14258
14260
|
name: "Select",
|
14259
14261
|
directives: {
|
14260
14262
|
clickoutside: ClickOutside
|
@@ -14287,7 +14289,8 @@ var Component$i = defineComponent({
|
|
14287
14289
|
customContent: PropTypes.bool.def(false),
|
14288
14290
|
list: PropTypes.array.def([]),
|
14289
14291
|
idKey: PropTypes.string.def("value"),
|
14290
|
-
displayKey: PropTypes.string.def("label")
|
14292
|
+
displayKey: PropTypes.string.def("label"),
|
14293
|
+
showSelectedIcon: PropTypes.bool.def(true)
|
14291
14294
|
},
|
14292
14295
|
emits: ["update:modelValue", "change", "toggle", "clear", "scroll-end", "focus", "blur"],
|
14293
14296
|
setup(props2, {
|
@@ -14307,7 +14310,8 @@ var Component$i = defineComponent({
|
|
14307
14310
|
showOnInit,
|
14308
14311
|
multipleMode,
|
14309
14312
|
allowCreate,
|
14310
|
-
customContent
|
14313
|
+
customContent,
|
14314
|
+
showSelectedIcon
|
14311
14315
|
} = toRefs(props2);
|
14312
14316
|
const formItem = useFormItem();
|
14313
14317
|
const inputRef = ref();
|
@@ -14601,6 +14605,7 @@ var Component$i = defineComponent({
|
|
14601
14605
|
multiple,
|
14602
14606
|
selected,
|
14603
14607
|
activeOptionValue,
|
14608
|
+
showSelectedIcon,
|
14604
14609
|
register,
|
14605
14610
|
unregister,
|
14606
14611
|
registerGroup,
|
@@ -14793,7 +14798,7 @@ var Component$i = defineComponent({
|
|
14793
14798
|
})]);
|
14794
14799
|
}
|
14795
14800
|
});
|
14796
|
-
const BkSelect = withInstallProps(Component$
|
14801
|
+
const BkSelect = withInstallProps(Component$j, { Option: BkOption, Group: OptionGroup });
|
14797
14802
|
function _isSlot$4(s2) {
|
14798
14803
|
return typeof s2 === "function" || Object.prototype.toString.call(s2) === "[object Object]" && !isVNode(s2);
|
14799
14804
|
}
|
@@ -14803,7 +14808,7 @@ const {
|
|
14803
14808
|
const sliderPops = Object.assign({}, propsMixin);
|
14804
14809
|
sliderPops.width.default = "400";
|
14805
14810
|
sliderPops.height.default = "100%";
|
14806
|
-
var Component$
|
14811
|
+
var Component$i = defineComponent({
|
14807
14812
|
name: "Sideslider",
|
14808
14813
|
components: {
|
14809
14814
|
BkModal,
|
@@ -14892,7 +14897,7 @@ var Component$h = defineComponent({
|
|
14892
14897
|
};
|
14893
14898
|
}
|
14894
14899
|
});
|
14895
|
-
const BkSideslider = withInstall(Component$
|
14900
|
+
const BkSideslider = withInstall(Component$i);
|
14896
14901
|
const stepsProps = {
|
14897
14902
|
theme: PropTypes.theme().def("primary"),
|
14898
14903
|
size: PropTypes.size(),
|
@@ -14906,7 +14911,7 @@ const stepsProps = {
|
|
14906
14911
|
steps: PropTypes.array.def([]),
|
14907
14912
|
beforeChange: PropTypes.func
|
14908
14913
|
};
|
14909
|
-
var Component$
|
14914
|
+
var Component$h = defineComponent({
|
14910
14915
|
name: "Steps",
|
14911
14916
|
props: stepsProps,
|
14912
14917
|
emits: ["update:curStep", "click"],
|
@@ -15060,8 +15065,8 @@ var Component$g = defineComponent({
|
|
15060
15065
|
})]);
|
15061
15066
|
}
|
15062
15067
|
});
|
15063
|
-
const BkSteps$2 = withInstall(Component$
|
15064
|
-
var Component$
|
15068
|
+
const BkSteps$2 = withInstall(Component$h);
|
15069
|
+
var Component$g = defineComponent({
|
15065
15070
|
name: "Switcher",
|
15066
15071
|
props: {
|
15067
15072
|
theme: PropTypes.theme().def(""),
|
@@ -15155,7 +15160,7 @@ var Component$f = defineComponent({
|
|
15155
15160
|
}, [isChecked.value ? props2.onText : props2.offText]) : ""]);
|
15156
15161
|
}
|
15157
15162
|
});
|
15158
|
-
const BkSwitcher = withInstall(Component$
|
15163
|
+
const BkSwitcher = withInstall(Component$g);
|
15159
15164
|
const EventProps = {
|
15160
15165
|
onContentScroll: Function
|
15161
15166
|
};
|
@@ -15292,7 +15297,7 @@ var virtualRender = {
|
|
15292
15297
|
}
|
15293
15298
|
}
|
15294
15299
|
};
|
15295
|
-
var Component$
|
15300
|
+
var Component$f = defineComponent({
|
15296
15301
|
name: "VirtualRender",
|
15297
15302
|
directives: {
|
15298
15303
|
bkVirtualRender: virtualRender
|
@@ -15446,7 +15451,7 @@ var Component$e = defineComponent({
|
|
15446
15451
|
};
|
15447
15452
|
}
|
15448
15453
|
});
|
15449
|
-
const BkVirtualRender = withInstall(Component$
|
15454
|
+
const BkVirtualRender = withInstall(Component$f);
|
15450
15455
|
var BORDER_OPTION = /* @__PURE__ */ ((BORDER_OPTION2) => {
|
15451
15456
|
BORDER_OPTION2["NONE"] = "none";
|
15452
15457
|
BORDER_OPTION2["ROW"] = "row";
|
@@ -16067,7 +16072,7 @@ const paginationProps = {
|
|
16067
16072
|
return value.some((item) => layoutNameMap[item]);
|
16068
16073
|
}, "layout \u7684\u503C\u53EA\u652F\u6301 * total\u3001list\u3001limit *").def(["total", "list", "limit"])
|
16069
16074
|
};
|
16070
|
-
var Component$
|
16075
|
+
var Component$e = defineComponent({
|
16071
16076
|
name: "Pagination",
|
16072
16077
|
props: paginationProps,
|
16073
16078
|
emits: ["update:modelValue", "change", "update:limit", "limitChange"],
|
@@ -16134,7 +16139,7 @@ var Component$d = defineComponent({
|
|
16134
16139
|
}))]);
|
16135
16140
|
}
|
16136
16141
|
});
|
16137
|
-
const BkPagination = withInstall(Component$
|
16142
|
+
const BkPagination = withInstall(Component$e);
|
16138
16143
|
var TableRow = defineComponent({
|
16139
16144
|
name: "TableRow",
|
16140
16145
|
render() {
|
@@ -17518,7 +17523,7 @@ const useInit = (props2) => {
|
|
17518
17523
|
updateColGroups
|
17519
17524
|
};
|
17520
17525
|
};
|
17521
|
-
var Component$
|
17526
|
+
var Component$d = defineComponent({
|
17522
17527
|
name: "Table",
|
17523
17528
|
props: tableProps,
|
17524
17529
|
emits: EMIT_EVENT_TYPES,
|
@@ -17760,7 +17765,7 @@ var Component$c = defineComponent({
|
|
17760
17765
|
]);
|
17761
17766
|
}
|
17762
17767
|
});
|
17763
|
-
const BkTable = withInstall(Component$
|
17768
|
+
const BkTable = withInstall(Component$d);
|
17764
17769
|
const INPUT_MIN_WIDTH = 12;
|
17765
17770
|
function usePage(pageSize) {
|
17766
17771
|
const state = reactive({
|
@@ -17935,7 +17940,7 @@ var TagRender = defineComponent({
|
|
17935
17940
|
}, [this.node[this.displayKey]])]);
|
17936
17941
|
}
|
17937
17942
|
});
|
17938
|
-
var Component$
|
17943
|
+
var Component$c = defineComponent({
|
17939
17944
|
name: "TagInput",
|
17940
17945
|
directives: {
|
17941
17946
|
bkTooltips: tooltips
|
@@ -18688,7 +18693,7 @@ var Component$b = defineComponent({
|
|
18688
18693
|
})]);
|
18689
18694
|
}
|
18690
18695
|
});
|
18691
|
-
const TagInput = withInstall(Component$
|
18696
|
+
const TagInput = withInstall(Component$c);
|
18692
18697
|
const dividerProps = {
|
18693
18698
|
direction: PropTypes.commonType(["horizontal", "vertical"], "direction").def("horizontal"),
|
18694
18699
|
align: PropTypes.commonType(["left", "center", "right"], "align").def("center"),
|
@@ -19625,7 +19630,7 @@ const menuProps = {
|
|
19625
19630
|
default: true
|
19626
19631
|
}
|
19627
19632
|
};
|
19628
|
-
var Component$
|
19633
|
+
var Component$b = defineComponent({
|
19629
19634
|
name: "Menu",
|
19630
19635
|
props: menuProps,
|
19631
19636
|
emits: ["update:activeKey", "update:openKeys", "click", "openChange"],
|
@@ -19873,7 +19878,7 @@ var Submenu = defineComponent({
|
|
19873
19878
|
};
|
19874
19879
|
}
|
19875
19880
|
});
|
19876
|
-
const BkMenu = withInstallProps(Component$
|
19881
|
+
const BkMenu = withInstallProps(Component$b, { Item, Submenu, Group });
|
19877
19882
|
const TitleProps = {
|
19878
19883
|
sideTitle: {
|
19879
19884
|
type: String,
|
@@ -19953,7 +19958,7 @@ const NavigationProps = {
|
|
19953
19958
|
default: true
|
19954
19959
|
}
|
19955
19960
|
};
|
19956
|
-
var Component$
|
19961
|
+
var Component$a = defineComponent({
|
19957
19962
|
name: "Navigation",
|
19958
19963
|
props: NavigationProps,
|
19959
19964
|
emits: ["leave", "toggle", "hover", "toggle-click"],
|
@@ -20095,7 +20100,7 @@ var Component$9 = defineComponent({
|
|
20095
20100
|
}, [(_l = (_k = this.$slots).footer) == null ? void 0 : _l.call(_k)])])])])]);
|
20096
20101
|
}
|
20097
20102
|
});
|
20098
|
-
const Navigation = withInstall(Component$
|
20103
|
+
const Navigation = withInstall(Component$a);
|
20099
20104
|
const pickerDropdownProps = {
|
20100
20105
|
placement: {
|
20101
20106
|
type: String,
|
@@ -23450,7 +23455,7 @@ const datePickerProps = {
|
|
23450
23455
|
},
|
23451
23456
|
disableDate: Function
|
23452
23457
|
};
|
23453
|
-
var Component$
|
23458
|
+
var Component$9 = defineComponent({
|
23454
23459
|
name: "DatePicker",
|
23455
23460
|
directives: {
|
23456
23461
|
clickoutside: ClickOutside
|
@@ -23979,7 +23984,7 @@ var Component$8 = defineComponent({
|
|
23979
23984
|
})]), [[resolveDirective("clickoutside"), this.handleClose]]);
|
23980
23985
|
}
|
23981
23986
|
});
|
23982
|
-
const BkDatePicker = withInstall(Component$
|
23987
|
+
const BkDatePicker = withInstall(Component$9);
|
23983
23988
|
var ArrayType = /* @__PURE__ */ ((ArrayType2) => {
|
23984
23989
|
ArrayType2["OBJECT_ARRAY"] = "objectArray";
|
23985
23990
|
ArrayType2["BASE_ARRAY"] = "baseArray";
|
@@ -24035,7 +24040,7 @@ function useSelectListSearch(selectList, displayCode) {
|
|
24035
24040
|
selectListSearch
|
24036
24041
|
};
|
24037
24042
|
}
|
24038
|
-
var Component$
|
24043
|
+
var Component$8 = defineComponent({
|
24039
24044
|
name: "Transfer",
|
24040
24045
|
props: transferProps,
|
24041
24046
|
emits: ["change", "update:targetList"],
|
@@ -24206,7 +24211,7 @@ var Component$7 = defineComponent({
|
|
24206
24211
|
}, [getHeaderHtml("right-header"), getListContentHtml("right")])]);
|
24207
24212
|
}
|
24208
24213
|
});
|
24209
|
-
const Transfer = withInstall(Component$
|
24214
|
+
const Transfer = withInstall(Component$8);
|
24210
24215
|
var EVENTS = /* @__PURE__ */ ((EVENTS2) => {
|
24211
24216
|
EVENTS2["NODE_CLICK"] = "nodeClick";
|
24212
24217
|
EVENTS2["NODE_COLLAPSE"] = "nodeCollapse";
|
@@ -25304,7 +25309,7 @@ var useTreeInit = (props2) => {
|
|
25304
25309
|
onSelected
|
25305
25310
|
};
|
25306
25311
|
};
|
25307
|
-
var Component$
|
25312
|
+
var Component$7 = defineComponent({
|
25308
25313
|
name: "Tree",
|
25309
25314
|
props: treeProps,
|
25310
25315
|
emits: TreeEmitEventsType,
|
@@ -25415,7 +25420,7 @@ var Component$6 = defineComponent({
|
|
25415
25420
|
});
|
25416
25421
|
}
|
25417
25422
|
});
|
25418
|
-
const BkTree = withInstall(Component$
|
25423
|
+
const BkTree = withInstall(Component$7);
|
25419
25424
|
const isCustomComponent = (node) => node.__v_isVNode;
|
25420
25425
|
var ComposeFormItem = defineComponent({
|
25421
25426
|
name: "ComposeFormItem",
|
@@ -26308,7 +26313,7 @@ class Store {
|
|
26308
26313
|
nodeDataList.forEach((node) => this.appendNode(node, parentNode));
|
26309
26314
|
}
|
26310
26315
|
}
|
26311
|
-
var Component$
|
26316
|
+
var Component$6 = defineComponent({
|
26312
26317
|
name: "Cascader",
|
26313
26318
|
directives: {
|
26314
26319
|
clickoutside: ClickOutside
|
@@ -26481,7 +26486,7 @@ var Component$5 = defineComponent({
|
|
26481
26486
|
})]);
|
26482
26487
|
}
|
26483
26488
|
});
|
26484
|
-
const BkCascader = withInstallProps(Component$
|
26489
|
+
const BkCascader = withInstallProps(Component$6, { CascaderPanel });
|
26485
26490
|
var SliderButton = defineComponent({
|
26486
26491
|
name: "SliderButton",
|
26487
26492
|
props: {
|
@@ -26652,7 +26657,7 @@ const off = (element, event, handler) => {
|
|
26652
26657
|
element.removeEventListener(event, handler, false);
|
26653
26658
|
}
|
26654
26659
|
};
|
26655
|
-
var Component$
|
26660
|
+
var Component$5 = defineComponent({
|
26656
26661
|
name: "Slider",
|
26657
26662
|
props: {
|
26658
26663
|
modelValue: PropTypes.oneOfType([PropTypes.array, PropTypes.number]),
|
@@ -27098,8 +27103,8 @@ var Component$4 = defineComponent({
|
|
27098
27103
|
return this.renderDom();
|
27099
27104
|
}
|
27100
27105
|
});
|
27101
|
-
const Slider = withInstall(Component$
|
27102
|
-
var Component$
|
27106
|
+
const Slider = withInstall(Component$5);
|
27107
|
+
var Component$4 = defineComponent({
|
27103
27108
|
name: "ResizeLayout",
|
27104
27109
|
props: {
|
27105
27110
|
placement: PropTypes.placement().def("left"),
|
@@ -27354,13 +27359,13 @@ var Component$3 = defineComponent({
|
|
27354
27359
|
}, null)]);
|
27355
27360
|
}
|
27356
27361
|
});
|
27357
|
-
const BkResizeLayout = withInstall(Component$
|
27362
|
+
const BkResizeLayout = withInstall(Component$4);
|
27358
27363
|
const timelineProps = {
|
27359
27364
|
list: PropTypes.array.def([]),
|
27360
27365
|
titleAble: PropTypes.bool.def(false),
|
27361
27366
|
extCls: PropTypes.string
|
27362
27367
|
};
|
27363
|
-
var Component$
|
27368
|
+
var Component$3 = defineComponent({
|
27364
27369
|
name: "Timeline",
|
27365
27370
|
props: timelineProps,
|
27366
27371
|
emits: ["select"],
|
@@ -27469,7 +27474,7 @@ var Component$2 = defineComponent({
|
|
27469
27474
|
})]);
|
27470
27475
|
}
|
27471
27476
|
});
|
27472
|
-
const BkSteps$1 = withInstall(Component$
|
27477
|
+
const BkSteps$1 = withInstall(Component$3);
|
27473
27478
|
const processProps = {
|
27474
27479
|
list: PropTypes.array.def([]),
|
27475
27480
|
controllable: PropTypes.bool.def(false),
|
@@ -27478,7 +27483,7 @@ const processProps = {
|
|
27478
27483
|
displayKey: PropTypes.string.def("content"),
|
27479
27484
|
extCls: PropTypes.string
|
27480
27485
|
};
|
27481
|
-
var Component$
|
27486
|
+
var Component$2 = defineComponent({
|
27482
27487
|
name: "BKProcess",
|
27483
27488
|
props: processProps,
|
27484
27489
|
emits: ["update:curProcess", "click"],
|
@@ -27574,7 +27579,7 @@ var Component$1 = defineComponent({
|
|
27574
27579
|
}, [item[this.displayKey], renderIcon(index, item)]))])]);
|
27575
27580
|
}
|
27576
27581
|
});
|
27577
|
-
const BkSteps = withInstall(Component$
|
27582
|
+
const BkSteps = withInstall(Component$2);
|
27578
27583
|
const CLASS_PREFIX = "bk-upload";
|
27579
27584
|
var EThemes = /* @__PURE__ */ ((EThemes2) => {
|
27580
27585
|
EThemes2["BUTTON"] = "button";
|
@@ -28292,7 +28297,7 @@ var sparkMd5 = { exports: {} };
|
|
28292
28297
|
;
|
28293
28298
|
if (typeof ArrayBuffer !== "undefined" && !ArrayBuffer.prototype.slice) {
|
28294
28299
|
(function() {
|
28295
|
-
function
|
28300
|
+
function clamp2(val, length) {
|
28296
28301
|
val = val | 0 || 0;
|
28297
28302
|
if (val < 0) {
|
28298
28303
|
return Math.max(val + length, 0);
|
@@ -28300,9 +28305,9 @@ var sparkMd5 = { exports: {} };
|
|
28300
28305
|
return Math.min(val, length);
|
28301
28306
|
}
|
28302
28307
|
ArrayBuffer.prototype.slice = function(from, to) {
|
28303
|
-
var length = this.byteLength, begin =
|
28308
|
+
var length = this.byteLength, begin = clamp2(from, length), end2 = length, num, target, targetArray, sourceArray;
|
28304
28309
|
if (to !== undefined$1) {
|
28305
|
-
end2 =
|
28310
|
+
end2 = clamp2(to, length);
|
28306
28311
|
}
|
28307
28312
|
if (begin > end2) {
|
28308
28313
|
return new ArrayBuffer(0);
|
@@ -28841,8 +28846,8 @@ var useFileHandler = (props2, hooks) => {
|
|
28841
28846
|
handleProgress
|
28842
28847
|
};
|
28843
28848
|
};
|
28844
|
-
var Component = defineComponent({
|
28845
|
-
name: "
|
28849
|
+
var Component$1 = defineComponent({
|
28850
|
+
name: "Upload",
|
28846
28851
|
props: uploadProps,
|
28847
28852
|
emits: ["on-exceed", "on-progress", "on-success", "on-error", "on-delete", "on-done"],
|
28848
28853
|
setup(props2, {
|
@@ -29036,7 +29041,7 @@ var Component = defineComponent({
|
|
29036
29041
|
})]);
|
29037
29042
|
}
|
29038
29043
|
});
|
29039
|
-
const Upload = withInstall(Component);
|
29044
|
+
const Upload = withInstall(Component$1);
|
29040
29045
|
function Diff$1() {
|
29041
29046
|
}
|
29042
29047
|
Diff$1.prototype = {
|
@@ -31960,6 +31965,1618 @@ var CodeDiff = defineComponent({
|
|
31960
31965
|
}
|
31961
31966
|
});
|
31962
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);
|
31963
33580
|
var components = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
31964
33581
|
__proto__: null,
|
31965
33582
|
Alert: BkAlert,
|
@@ -32014,7 +33631,8 @@ var components = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProp
|
|
32014
33631
|
TimeLine: BkSteps$1,
|
32015
33632
|
Process: BkSteps,
|
32016
33633
|
Upload,
|
32017
|
-
CodeDiff: BkCodeDiff
|
33634
|
+
CodeDiff: BkCodeDiff,
|
33635
|
+
ColorPicker: BkColorPicker
|
32018
33636
|
}, Symbol.toStringTag, { value: "Module" }));
|
32019
33637
|
const createInstall = (prefix = "Bk") => (app) => {
|
32020
33638
|
const pre = app.config.globalProperties.bkUIPrefix || prefix;
|
@@ -32032,4 +33650,4 @@ var preset = {
|
|
32032
33650
|
install: createInstall(),
|
32033
33651
|
version: "0.0.1"
|
32034
33652
|
};
|
32035
|
-
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 };
|