208 lines
14 KiB
JavaScript
208 lines
14 KiB
JavaScript
import { w as withInstall } from "../badge/index2.js";
|
|
import { defineComponent, ref, watch, computed, openBlock, createElementBlock, createVNode, unref, withCtx, createElementVNode, isRef } from "vue";
|
|
import { _ as _sfc_main$2 } from "../input/index2.js";
|
|
import { _ as _sfc_main$2W } from "../_chunks/@layui/index.js";
|
|
import { _ as _sfc_main$1 } from "../button/index2.js";
|
|
import "../dropdownMenu/index2.js";
|
|
var index = /* @__PURE__ */ (() => ":root{--button-primary-text-color: #fff;--button-primary-background-color: var(--global-primary-color);--button-primary-border-color: var(--global-primary-color);--button-normal-text-color: #fff;--button-normal-background-color: var(--global-normal-color);--button-normal-border-color: var(--global-normal-color);--button-warm-text-color: #fff;--button-warm-background-color: var(--global-warm-color);--button-warm-border-color: var(--global-warm-color);--button-danger-text-color: #fff;--button-danger-background-color: var(--global-danger-color);--button-danger-border-color: var(--global-danger-color);--button-border-radius: var(--global-border-radius);--button-border-color: var(--global-neutral-color-6);--button-background-color: 0 0;--button-text-color: #666}.layui-btn{height:38px;line-height:36px;padding:0 18px;font-size:14px;text-align:center;white-space:nowrap;color:var(--button-text-color);background:var(--button-background-color);border-radius:var(--button-border-radius);border-color:var(--button-border-color);border-width:1px;border-style:solid;cursor:pointer}.layui-btn-primary{color:var(--button-primary-text-color);background-color:var(--button-primary-background-color);border-color:var(--button-primary-border-color)}.layui-btn-normal{color:var(--button-normal-text-color);background-color:var(--button-normal-background-color);border-color:var(--button-normal-border-color)}.layui-btn-warm{color:var(--button-warm-text-color);background-color:var(--button-warm-background-color);border-color:var(--button-warm-border-color)}.layui-btn-danger{color:var(--button-danger-text-color);background-color:var(--button-danger-background-color);border-color:var(--button-danger-border-color)}.layui-btn:hover{opacity:.8;filter:alpha(opacity=80)}.layui-btn:active{opacity:1;filter:alpha(opacity=100)}.layui-btn-lg{height:44px;line-height:44px;padding:0 25px;font-size:16px}.layui-btn-sm{height:30px;line-height:30px;padding:0 10px;font-size:12px}.layui-btn-xs{height:22px;line-height:22px;padding:0 5px;font-size:12px}.layui-btn-xs i{font-size:12px!important}.layui-btn-fluid{width:100%}.layui-btn-radius{border-radius:100px}.layui-btn-disabled,.layui-btn-disabled:active,.layui-btn-disabled:hover{border-color:#eee!important;background-color:#fbfbfb!important;color:#d2d2d2!important;cursor:not-allowed!important;opacity:1}.layui-btn+.layui-btn{margin-left:10px}.layui-btn .layui-icon{padding:0 2px;vertical-align:middle\\ ;vertical-align:bottom}:root{--input-border-radius: var(--global-border-radius);--input-border-color: var(--global-neutral-color-3)}.layui-input{width:100%;height:38px;line-height:38px;border-width:1px;border-style:solid;border-color:var(--input-border-color);border-radius:var(--input-border-radius);display:inline-flex}.layui-input input{height:38px;line-height:38px;background-color:#fff;color:#000000d9;padding-left:10px;display:inline-block;border:none;height:100%;width:100%}.layui-input-append{background-color:#fafafa;border-left:1px solid var(--input-border-color);display:flex;padding:0 15px;flex:none;align-items:center}.layui-input-prepend{background-color:#fafafa;border-right:1px solid var(--input-border-color);display:flex;padding:0 15px;flex:none;align-items:center}.layui-input-wrapper{width:100%;display:inline-flex;border:none}.layui-input:hover,.layui-input:focus-within{border-color:#d2d2d2}.layui-input-clear,.layui-input-prefix,.layui-input-suffix,.layui-input-password{background-color:#fff}.layui-input-clear,.layui-input-password,.layui-input-prefix,.layui-input-suffix{display:flex;flex:none;align-items:center;padding:0 10px}.layui-input-has-prefix input{padding:0}.layui-input-clear,.layui-input-password{color:#00000073}.layui-input-clear:hover{opacity:.6}.layui-input input::-webkit-input-placeholder{line-height:1.3}.layui-input input::-ms-reveal{display:none}.layui-input-disabled{border-color:var(--input-border-color)!important}.layui-input-disabled{opacity:.6}.layui-input-disabled,.layui-input-disabled *{cursor:not-allowed!important}.layui-input[size=lg]{height:44px}.layui-input[size=lg] .layui-input{height:44px;line-height:44px}.layui-input[size=md]{height:38px}.layui-input[size=md] .layui-input{height:38px;line-height:38px}.layui-input[size=sm]{height:32px}.layui-input[size=sm] .layui-input{height:32px;line-height:32px}.layui-input[size=xs]{height:26px}.layui-input[size=xs] .layui-input{height:26px;line-height:26px}.layui-input-number+.layui-input-number{margin-left:10px}.layui-input-number{position:relative;display:inline-block;box-sizing:border-box;border:1px solid #eee;border-color:#eee;border-radius:var(--global-border-radius);overflow:hidden}.layui-input-number .layui-input{border:0}.layui-input-number .layui-input input{text-align:center;padding-left:0}.layui-input-number .layui-control-btn{position:absolute;box-sizing:border-box;border:0;border-color:#eee;border-style:solid;border-radius:0;padding:0;text-align:center;top:0}.layui-input-number .layui-control-btn:hover{color:var(--global-primary-color)}.layui-input-number .layui-control-btn.layui-subtraction-btn{border-right-width:1px}.layui-input-number .layui-control-btn.layui-addition-btn{border-left-width:1px;right:0}.layui-input-number .layui-control-btn .layui-icon{padding:0}.layui-input-number .layui-input input::-webkit-outer-spin-button,.layui-input-number .layui-input input::-webkit-inner-spin-button{-webkit-appearance:none}.layui-input-number .layui-input input[type=number]{-moz-appearance:textfield}.layui-input-number[position=right] .layui-subtraction-btn{right:0;border-right-width:0px;border-left-width:1px}.layui-input-number[position=right] .layui-addition-btn{border-bottom-width:1px}.layui-input-number[size=lg]{height:44px;width:200px}.layui-input-number[size=lg] .layui-input{height:44px;line-height:44px;padding:0 44px}.layui-input-number[size=lg] .layui-control-btn{width:44px;height:44px;line-height:44px;z-index:1}.layui-input-number[size=lg][position=right] .layui-input{padding:0 44px 0 0}.layui-input-number[size=lg][position=right] .layui-control-btn{height:22px;line-height:22px}.layui-input-number[size=lg][position=right] .layui-subtraction-btn{top:21px}.layui-input-number[size=md]{height:38px;width:160px}.layui-input-number[size=md] .layui-input{height:38px;line-height:38px;padding:0 38px}.layui-input-number[size=md] .layui-control-btn{width:38px;height:38px;line-height:38px;z-index:1}.layui-input-number[size=md][position=right] .layui-input{padding:0 38px 0 0}.layui-input-number[size=md][position=right] .layui-control-btn{height:19px;line-height:19px}.layui-input-number[size=md][position=right] .layui-subtraction-btn{top:18px}.layui-input-number[size=sm]{height:32px;width:140px}.layui-input-number[size=sm] .layui-input{height:32px;line-height:32px;padding:0 32px}.layui-input-number[size=sm] .layui-control-btn{width:32px;height:32px;line-height:32px;z-index:1}.layui-input-number[size=sm][position=right] .layui-input{padding:0 32px 0 0}.layui-input-number[size=sm][position=right] .layui-control-btn{height:16px;line-height:16px}.layui-input-number[size=sm][position=right] .layui-subtraction-btn{top:15px}.layui-input-number[size=xs]{height:26px;width:120px}.layui-input-number[size=xs] .layui-input{height:26px;line-height:26px;padding:0 26px}.layui-input-number[size=xs] .layui-control-btn{width:26px;height:26px;line-height:26px;z-index:1}.layui-input-number[size=xs][position=right] .layui-input{padding:0 26px 0 0}.layui-input-number[size=xs][position=right] .layui-control-btn{height:13px;line-height:13px}.layui-input-number[size=xs][position=right] .layui-subtraction-btn{top:12px}\n")();
|
|
function add(arg1, arg2) {
|
|
var r1, r2, m, c;
|
|
try {
|
|
r1 = arg1.toString().split(".")[1].length;
|
|
} catch (e) {
|
|
r1 = 0;
|
|
}
|
|
try {
|
|
r2 = arg2.toString().split(".")[1].length;
|
|
} catch (e) {
|
|
r2 = 0;
|
|
}
|
|
c = Math.abs(r1 - r2);
|
|
m = Math.pow(10, Math.max(r1, r2));
|
|
if (c > 0) {
|
|
var cm = Math.pow(10, c);
|
|
if (r1 > r2) {
|
|
arg1 = Number(arg1.toString().replace(".", ""));
|
|
arg2 = Number(arg2.toString().replace(".", "")) * cm;
|
|
} else {
|
|
arg1 = Number(arg1.toString().replace(".", "")) * cm;
|
|
arg2 = Number(arg2.toString().replace(".", ""));
|
|
}
|
|
} else {
|
|
arg1 = Number(arg1.toString().replace(".", ""));
|
|
arg2 = Number(arg2.toString().replace(".", ""));
|
|
}
|
|
return (arg1 + arg2) / m;
|
|
}
|
|
function sub(arg1, arg2) {
|
|
var r1, r2, m, c;
|
|
try {
|
|
r1 = arg1.toString().split(".")[1].length;
|
|
} catch (e) {
|
|
r1 = 0;
|
|
}
|
|
try {
|
|
r2 = arg2.toString().split(".")[1].length;
|
|
} catch (e) {
|
|
r2 = 0;
|
|
}
|
|
c = Math.abs(r1 - r2);
|
|
m = Math.pow(10, Math.max(r1, r2));
|
|
if (c > 0) {
|
|
var cm = Math.pow(10, c);
|
|
if (r1 > r2) {
|
|
arg1 = Number(arg1.toString().replace(".", ""));
|
|
arg2 = Number(arg2.toString().replace(".", "")) * cm;
|
|
} else {
|
|
arg1 = Number(arg1.toString().replace(".", "")) * cm;
|
|
arg2 = Number(arg2.toString().replace(".", ""));
|
|
}
|
|
} else {
|
|
arg1 = Number(arg1.toString().replace(".", ""));
|
|
arg2 = Number(arg2.toString().replace(".", ""));
|
|
}
|
|
return (arg1 - arg2) / m;
|
|
}
|
|
const _hoisted_1 = ["position", "size"];
|
|
const _hoisted_2 = { class: "layui-input-number-input" };
|
|
const __default__ = {
|
|
name: "LayInputNumber"
|
|
};
|
|
const _sfc_main = defineComponent({
|
|
...__default__,
|
|
props: {
|
|
modelValue: { default: 0 },
|
|
name: null,
|
|
disabled: { type: Boolean, default: false },
|
|
disabledInput: { type: Boolean, default: false },
|
|
size: { default: "md" },
|
|
step: { default: 1 },
|
|
position: null,
|
|
min: { default: -Infinity },
|
|
max: { default: Infinity }
|
|
},
|
|
emits: ["update:modelValue", "change"],
|
|
setup(__props, { emit }) {
|
|
const props = __props;
|
|
let num = ref(props.modelValue);
|
|
watch(num, (val) => {
|
|
if (props.max !== Infinity && val > props.max) {
|
|
num.value = props.max;
|
|
return;
|
|
}
|
|
if (props.min !== -Infinity && val < props.min) {
|
|
num.value = props.min;
|
|
return;
|
|
}
|
|
if (isNumber(num.value)) {
|
|
tempValue.value = Number(num.value);
|
|
emit("update:modelValue", tempValue.value);
|
|
emit("change", tempValue.value);
|
|
}
|
|
});
|
|
watch(() => props.modelValue, (val) => {
|
|
if (val !== num.value) {
|
|
num.value = props.modelValue;
|
|
}
|
|
});
|
|
let timer = 0;
|
|
const tempValue = ref(0);
|
|
const minControl = computed(() => {
|
|
if (props.disabled) {
|
|
return true;
|
|
}
|
|
if (props.min !== -Infinity) {
|
|
return Number(props.min) >= num.value;
|
|
}
|
|
});
|
|
const maxControl = computed(() => {
|
|
if (props.disabled) {
|
|
return true;
|
|
}
|
|
if (props.max !== Infinity) {
|
|
return Number(props.max) <= num.value;
|
|
}
|
|
});
|
|
const addition = function() {
|
|
num.value = add(num.value, props.step);
|
|
};
|
|
const subtraction = function() {
|
|
num.value = sub(num.value, props.step);
|
|
};
|
|
const longDown = function(fn) {
|
|
cancelLongDown();
|
|
if (props.disabled) {
|
|
return;
|
|
}
|
|
timer = setInterval(() => fn.call(timer), 150);
|
|
fn.call(timer);
|
|
};
|
|
const cancelLongDown = function() {
|
|
clearInterval(timer);
|
|
};
|
|
const inputChange = function() {
|
|
if (isNumber(num.value)) {
|
|
tempValue.value = Number(num.value);
|
|
return;
|
|
}
|
|
num.value = tempValue.value;
|
|
};
|
|
const isNumber = function(num2) {
|
|
return !isNaN(num2);
|
|
};
|
|
return (_ctx, _cache) => {
|
|
return openBlock(), createElementBlock("div", {
|
|
class: "layui-input-number",
|
|
position: __props.position,
|
|
size: __props.size
|
|
}, [
|
|
createVNode(_sfc_main$1, {
|
|
size: "lg",
|
|
onMouseup: cancelLongDown,
|
|
onMousedown: _cache[0] || (_cache[0] = ($event) => longDown(subtraction)),
|
|
onBlur: cancelLongDown,
|
|
disabled: unref(minControl),
|
|
class: "layui-control-btn layui-subtraction-btn"
|
|
}, {
|
|
default: withCtx(() => [
|
|
createVNode(unref(_sfc_main$2W), {
|
|
type: __props.position === "right" ? "layui-icon-down" : "layui-icon-subtraction"
|
|
}, null, 8, ["type"])
|
|
]),
|
|
_: 1
|
|
}, 8, ["disabled"]),
|
|
createElementVNode("div", _hoisted_2, [
|
|
createVNode(_sfc_main$2, {
|
|
max: __props.max,
|
|
min: __props.min,
|
|
name: __props.name,
|
|
modelValue: unref(num),
|
|
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => isRef(num) ? num.value = $event : num = $event),
|
|
readonly: __props.disabledInput || __props.disabled,
|
|
disabled: __props.disabledInput || __props.disabled,
|
|
onInput: inputChange,
|
|
type: "number"
|
|
}, null, 8, ["max", "min", "name", "modelValue", "readonly", "disabled"])
|
|
]),
|
|
createVNode(_sfc_main$1, {
|
|
size: "lg",
|
|
onMouseup: cancelLongDown,
|
|
onMousedown: _cache[2] || (_cache[2] = ($event) => longDown(addition)),
|
|
onBlur: cancelLongDown,
|
|
disabled: unref(maxControl),
|
|
class: "layui-control-btn layui-addition-btn"
|
|
}, {
|
|
default: withCtx(() => [
|
|
createVNode(unref(_sfc_main$2W), {
|
|
type: __props.position === "right" ? "layui-icon-up" : "layui-icon-addition"
|
|
}, null, 8, ["type"])
|
|
]),
|
|
_: 1
|
|
}, 8, ["disabled"])
|
|
], 8, _hoisted_1);
|
|
};
|
|
}
|
|
});
|
|
const component = withInstall(_sfc_main);
|
|
export { component as default };
|