ff-ui-plus 2.0.7
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/.nvmrc +1 -0
- package/.prettierrc.cjs +41 -0
- package/.stylelintignore +5 -0
- package/LICENSE +21 -0
- package/README.md +265 -0
- package/commitlint.config.cjs +162 -0
- package/global.d.ts +27 -0
- package/index.html +16 -0
- package/lib.sh +9 -0
- package/lint-staged.config.cjs +8 -0
- package/package.json +149 -0
- package/packages/components/adaptive-page/index.ts +5 -0
- package/packages/components/adaptive-page/src/index.vue +85 -0
- package/packages/components/adaptive-page/src/type.ts +9 -0
- package/packages/components/adaptive-page/style/css.ts +1 -0
- package/packages/components/adaptive-page/style/index.ts +1 -0
- package/packages/components/button/index.ts +5 -0
- package/packages/components/button/src/index.vue +41 -0
- package/packages/components/button/src/type.ts +11 -0
- package/packages/components/button/style/css.ts +1 -0
- package/packages/components/button/style/index.ts +1 -0
- package/packages/components/chart/index.ts +5 -0
- package/packages/components/chart/src/index.vue +121 -0
- package/packages/components/chart/src/type.ts +7 -0
- package/packages/components/chart/style/css.ts +1 -0
- package/packages/components/chart/style/index.ts +1 -0
- package/packages/components/checkbox/index.ts +3 -0
- package/packages/components/checkbox/src/checkbox.d.ts +5 -0
- package/packages/components/checkbox/src/index.vue +67 -0
- package/packages/components/checkbox/style/css.ts +1 -0
- package/packages/components/checkbox/style/index.ts +1 -0
- package/packages/components/date-picker/index.ts +5 -0
- package/packages/components/date-picker/src/index.vue +228 -0
- package/packages/components/date-picker/src/type.ts +22 -0
- package/packages/components/date-picker/style/css.ts +1 -0
- package/packages/components/date-picker/style/index.ts +1 -0
- package/packages/components/detail/index.ts +5 -0
- package/packages/components/detail/src/index.vue +102 -0
- package/packages/components/detail/src/renderLabel.vue +15 -0
- package/packages/components/detail/src/renderTooltip.vue +15 -0
- package/packages/components/detail/src/type.ts +28 -0
- package/packages/components/detail/style/css.ts +1 -0
- package/packages/components/detail/style/index.ts +1 -0
- package/packages/components/form/index.ts +5 -0
- package/packages/components/form/src/index.vue +407 -0
- package/packages/components/form/src/renderBtn.vue +15 -0
- package/packages/components/form/src/renderComp.vue +15 -0
- package/packages/components/form/src/type.ts +26 -0
- package/packages/components/form/style/css.ts +1 -0
- package/packages/components/form/style/index.ts +1 -0
- package/packages/components/index.ts +20 -0
- package/packages/components/input/index.ts +5 -0
- package/packages/components/input/src/index.vue +225 -0
- package/packages/components/input/src/type.ts +14 -0
- package/packages/components/input/style/css.ts +1 -0
- package/packages/components/input/style/index.ts +1 -0
- package/packages/components/layout-page/index.ts +4 -0
- package/packages/components/layout-page/src/index.vue +74 -0
- package/packages/components/layout-page/style/css.ts +1 -0
- package/packages/components/layout-page/style/index.ts +1 -0
- package/packages/components/layout-page-item/index.ts +3 -0
- package/packages/components/layout-page-item/src/index.vue +16 -0
- package/packages/components/layout-page-item/style/css.ts +1 -0
- package/packages/components/layout-page-item/style/index.ts +1 -0
- package/packages/components/module-form/index.ts +4 -0
- package/packages/components/module-form/src/index.vue +243 -0
- package/packages/components/module-form/src/moduleDetail.vue +61 -0
- package/packages/components/module-form/src/moduleForm.vue +88 -0
- package/packages/components/module-form/src/type.ts +16 -0
- package/packages/components/module-form/style/css.ts +1 -0
- package/packages/components/module-form/style/index.ts +1 -0
- package/packages/components/package.json +9 -0
- package/packages/components/query-condition/index.ts +4 -0
- package/packages/components/query-condition/src/index.vue +478 -0
- package/packages/components/query-condition/src/moreChoose.vue +159 -0
- package/packages/components/query-condition/src/renderComp.vue +15 -0
- package/packages/components/query-condition/src/type.ts +22 -0
- package/packages/components/query-condition/src/useComputed.ts +94 -0
- package/packages/components/query-condition/style/css.ts +1 -0
- package/packages/components/query-condition/style/index.ts +1 -0
- package/packages/components/radio/index.ts +3 -0
- package/packages/components/radio/src/index.vue +73 -0
- package/packages/components/radio/src/radio.d.ts +12 -0
- package/packages/components/radio/style/css.ts +1 -0
- package/packages/components/radio/style/index.ts +1 -0
- package/packages/components/select/index.ts +4 -0
- package/packages/components/select/src/index.vue +240 -0
- package/packages/components/select/src/type.ts +43 -0
- package/packages/components/select/style/css.ts +1 -0
- package/packages/components/select/style/index.ts +1 -0
- package/packages/components/select-icon/index.ts +4 -0
- package/packages/components/select-icon/src/index.vue +128 -0
- package/packages/components/select-icon/style/css.ts +1 -0
- package/packages/components/select-icon/style/index.ts +1 -0
- package/packages/components/select-table/index.ts +4 -0
- package/packages/components/select-table/src/ClickOutside.ts +106 -0
- package/packages/components/select-table/src/index.vue +851 -0
- package/packages/components/select-table/src/renderCol.vue +20 -0
- package/packages/components/select-table/src/type.ts +56 -0
- package/packages/components/select-table/src/useVirtualized.ts +86 -0
- package/packages/components/select-table/style/css.ts +1 -0
- package/packages/components/select-table/style/index.ts +1 -0
- package/packages/components/step-wizard/index.ts +4 -0
- package/packages/components/step-wizard/src/index.vue +99 -0
- package/packages/components/step-wizard/src/type.ts +17 -0
- package/packages/components/step-wizard/style/css.ts +1 -0
- package/packages/components/step-wizard/style/index.ts +1 -0
- package/packages/components/table/index.ts +5 -0
- package/packages/components/table/src/ColumnSet.vue +176 -0
- package/packages/components/table/src/TTableColumn.vue +100 -0
- package/packages/components/table/src/densitySet.vue +91 -0
- package/packages/components/table/src/firstColumn.vue +132 -0
- package/packages/components/table/src/index.vue +926 -0
- package/packages/components/table/src/operator.vue +246 -0
- package/packages/components/table/src/renderCol.vue +20 -0
- package/packages/components/table/src/renderHeader.vue +18 -0
- package/packages/components/table/src/singleEdit.vue +354 -0
- package/packages/components/table/src/singleEditCell.vue +303 -0
- package/packages/components/table/src/tableProps.ts +162 -0
- package/packages/components/table/src/useExpose.ts +74 -0
- package/packages/components/table/src/useVirtualized.ts +70 -0
- package/packages/components/table/style/css.ts +1 -0
- package/packages/components/table/style/index.ts +1 -0
- package/packages/components/tabs/index.ts +4 -0
- package/packages/components/tabs/src/index.vue +50 -0
- package/packages/components/tabs/style/css.ts +1 -0
- package/packages/components/tabs/style/index.ts +1 -0
- package/packages/components/timer-btn/index.ts +4 -0
- package/packages/components/timer-btn/src/index.vue +57 -0
- package/packages/components/timer-btn/style/css.ts +1 -0
- package/packages/components/timer-btn/style/index.ts +1 -0
- package/packages/components/utils/index.ts +142 -0
- package/packages/components/utils/install.ts +16 -0
- package/packages/eslint-config/build.config.ts +16 -0
- package/packages/eslint-config/dist/index.cjs +122 -0
- package/packages/eslint-config/dist/index.d.cts +92 -0
- package/packages/eslint-config/dist/index.d.mts +92 -0
- package/packages/eslint-config/dist/index.d.ts +92 -0
- package/packages/eslint-config/dist/index.mjs +120 -0
- package/packages/eslint-config/package.json +34 -0
- package/packages/eslint-config/src/index.ts +121 -0
- package/packages/ff-ui-plus/component.ts +55 -0
- package/packages/ff-ui-plus/defaults.ts +4 -0
- package/packages/ff-ui-plus/index.ts +9 -0
- package/packages/ff-ui-plus/make-installer.ts +10 -0
- package/packages/ff-ui-plus/package.json +117 -0
- package/packages/ff-ui-plus/version.ts +1 -0
- package/packages/hooks/index.ts +1 -0
- package/packages/hooks/package.json +9 -0
- package/packages/hooks/useLocale.ts +53 -0
- package/packages/locale/index.ts +11 -0
- package/packages/locale/lang/en.ts +157 -0
- package/packages/locale/lang/zh-cn.ts +155 -0
- package/packages/locale/package.json +12 -0
- package/packages/resolver/package.json +23 -0
- package/packages/resolver/src/index.ts +99 -0
- package/packages/theme-chalk/build.ts +76 -0
- package/packages/theme-chalk/dist/index.css +1 -0
- package/packages/theme-chalk/dist/src/adaptive-page.scss +48 -0
- package/packages/theme-chalk/dist/src/button.scss +23 -0
- package/packages/theme-chalk/dist/src/chart.scss +10 -0
- package/packages/theme-chalk/dist/src/checkbox.scss +0 -0
- package/packages/theme-chalk/dist/src/date-picker.scss +3 -0
- package/packages/theme-chalk/dist/src/detail.scss +7 -0
- package/packages/theme-chalk/dist/src/form.scss +104 -0
- package/packages/theme-chalk/dist/src/index.scss +19 -0
- package/packages/theme-chalk/dist/src/input.scss +0 -0
- package/packages/theme-chalk/dist/src/layout-page-item.scss +10 -0
- package/packages/theme-chalk/dist/src/layout-page.scss +37 -0
- package/packages/theme-chalk/dist/src/module-form.scss +335 -0
- package/packages/theme-chalk/dist/src/query-condition.scss +132 -0
- package/packages/theme-chalk/dist/src/radio.scss +0 -0
- package/packages/theme-chalk/dist/src/select-icon.scss +61 -0
- package/packages/theme-chalk/dist/src/select-table.scss +71 -0
- package/packages/theme-chalk/dist/src/select.scss +7 -0
- package/packages/theme-chalk/dist/src/step-wizard.scss +51 -0
- package/packages/theme-chalk/dist/src/table.scss +381 -0
- package/packages/theme-chalk/dist/src/tabs.scss +20 -0
- package/packages/theme-chalk/dist/src/timer-btn.scss +21 -0
- package/packages/theme-chalk/dist/t-adaptive-page.css +1 -0
- package/packages/theme-chalk/dist/t-button.css +1 -0
- package/packages/theme-chalk/dist/t-chart.css +1 -0
- package/packages/theme-chalk/dist/t-checkbox.css +0 -0
- package/packages/theme-chalk/dist/t-date-picker.css +1 -0
- package/packages/theme-chalk/dist/t-detail.css +1 -0
- package/packages/theme-chalk/dist/t-form.css +1 -0
- package/packages/theme-chalk/dist/t-input.css +0 -0
- package/packages/theme-chalk/dist/t-layout-page-item.css +1 -0
- package/packages/theme-chalk/dist/t-layout-page.css +1 -0
- package/packages/theme-chalk/dist/t-module-form.css +1 -0
- package/packages/theme-chalk/dist/t-query-condition.css +1 -0
- package/packages/theme-chalk/dist/t-radio.css +0 -0
- package/packages/theme-chalk/dist/t-select-icon.css +1 -0
- package/packages/theme-chalk/dist/t-select-table.css +1 -0
- package/packages/theme-chalk/dist/t-select.css +1 -0
- package/packages/theme-chalk/dist/t-step-wizard.css +1 -0
- package/packages/theme-chalk/dist/t-table.css +1 -0
- package/packages/theme-chalk/dist/t-tabs.css +1 -0
- package/packages/theme-chalk/dist/t-timer-btn.css +1 -0
- package/packages/theme-chalk/mixins/config.scss +8 -0
- package/packages/theme-chalk/mixins/function.scss +71 -0
- package/packages/theme-chalk/mixins/mixins.scss +79 -0
- package/packages/theme-chalk/package.json +21 -0
- package/packages/theme-chalk/src/adaptive-page.scss +48 -0
- package/packages/theme-chalk/src/button.scss +23 -0
- package/packages/theme-chalk/src/chart.scss +10 -0
- package/packages/theme-chalk/src/checkbox.scss +0 -0
- package/packages/theme-chalk/src/date-picker.scss +3 -0
- package/packages/theme-chalk/src/detail.scss +7 -0
- package/packages/theme-chalk/src/form.scss +104 -0
- package/packages/theme-chalk/src/index.scss +19 -0
- package/packages/theme-chalk/src/input.scss +0 -0
- package/packages/theme-chalk/src/layout-page-item.scss +10 -0
- package/packages/theme-chalk/src/layout-page.scss +37 -0
- package/packages/theme-chalk/src/module-form.scss +335 -0
- package/packages/theme-chalk/src/query-condition.scss +132 -0
- package/packages/theme-chalk/src/radio.scss +0 -0
- package/packages/theme-chalk/src/select-icon.scss +61 -0
- package/packages/theme-chalk/src/select-table.scss +71 -0
- package/packages/theme-chalk/src/select.scss +7 -0
- package/packages/theme-chalk/src/step-wizard.scss +51 -0
- package/packages/theme-chalk/src/table.scss +381 -0
- package/packages/theme-chalk/src/tabs.scss +20 -0
- package/packages/theme-chalk/src/timer-btn.scss +21 -0
- package/packages/types/global.ts +34 -0
- package/packages/types/index.ts +1 -0
- package/packages/types/package.json +10 -0
- package/packages/utils/build.config.ts +23 -0
- package/packages/utils/dist/cookie.cjs +1 -0
- package/packages/utils/dist/cookie.d.cts +16 -0
- package/packages/utils/dist/cookie.d.mts +16 -0
- package/packages/utils/dist/cookie.d.ts +16 -0
- package/packages/utils/dist/cookie.mjs +1 -0
- package/packages/utils/dist/day.cjs +1 -0
- package/packages/utils/dist/day.d.cts +37 -0
- package/packages/utils/dist/day.d.mts +37 -0
- package/packages/utils/dist/day.d.ts +37 -0
- package/packages/utils/dist/day.mjs +1 -0
- package/packages/utils/dist/file.cjs +1 -0
- package/packages/utils/dist/file.d.cts +61 -0
- package/packages/utils/dist/file.d.mts +61 -0
- package/packages/utils/dist/file.d.ts +61 -0
- package/packages/utils/dist/file.mjs +1 -0
- package/packages/utils/dist/index.cjs +1 -0
- package/packages/utils/dist/index.d.cts +13 -0
- package/packages/utils/dist/index.d.mts +13 -0
- package/packages/utils/dist/index.d.ts +13 -0
- package/packages/utils/dist/index.mjs +1 -0
- package/packages/utils/dist/is.cjs +1 -0
- package/packages/utils/dist/is.d.cts +117 -0
- package/packages/utils/dist/is.d.mts +117 -0
- package/packages/utils/dist/is.d.ts +117 -0
- package/packages/utils/dist/is.mjs +1 -0
- package/packages/utils/dist/letter.cjs +1 -0
- package/packages/utils/dist/letter.d.cts +12 -0
- package/packages/utils/dist/letter.d.mts +12 -0
- package/packages/utils/dist/letter.d.ts +12 -0
- package/packages/utils/dist/letter.mjs +1 -0
- package/packages/utils/dist/number.cjs +1 -0
- package/packages/utils/dist/number.d.cts +23 -0
- package/packages/utils/dist/number.d.mts +23 -0
- package/packages/utils/dist/number.d.ts +23 -0
- package/packages/utils/dist/number.mjs +1 -0
- package/packages/utils/dist/openExe.cjs +1 -0
- package/packages/utils/dist/openExe.d.cts +9 -0
- package/packages/utils/dist/openExe.d.mts +9 -0
- package/packages/utils/dist/openExe.d.ts +9 -0
- package/packages/utils/dist/openExe.mjs +1 -0
- package/packages/utils/dist/storage.cjs +1 -0
- package/packages/utils/dist/storage.d.cts +46 -0
- package/packages/utils/dist/storage.d.mts +46 -0
- package/packages/utils/dist/storage.d.ts +46 -0
- package/packages/utils/dist/storage.mjs +1 -0
- package/packages/utils/dist/validate.cjs +1 -0
- package/packages/utils/dist/validate.d.cts +32 -0
- package/packages/utils/dist/validate.d.mts +32 -0
- package/packages/utils/dist/validate.d.ts +32 -0
- package/packages/utils/dist/validate.mjs +1 -0
- package/packages/utils/dist/ws.cjs +1 -0
- package/packages/utils/dist/ws.d.cts +86 -0
- package/packages/utils/dist/ws.d.mts +86 -0
- package/packages/utils/dist/ws.d.ts +86 -0
- package/packages/utils/dist/ws.mjs +1 -0
- package/packages/utils/package.json +42 -0
- package/packages/utils/src/cookie.ts +24 -0
- package/packages/utils/src/day.ts +66 -0
- package/packages/utils/src/file.ts +173 -0
- package/packages/utils/src/index.ts +10 -0
- package/packages/utils/src/is.ts +159 -0
- package/packages/utils/src/letter.ts +15 -0
- package/packages/utils/src/number.ts +37 -0
- package/packages/utils/src/openExe.ts +45 -0
- package/packages/utils/src/storage.ts +77 -0
- package/packages/utils/src/validate.ts +55 -0
- package/packages/utils/src/ws.ts +191 -0
- package/pnpm-workspace.yaml +3 -0
- package/publish.sh +37 -0
- package/resolver.sh +9 -0
- package/scripts/build/all.ts +152 -0
- package/scripts/build/build.config.ts +10 -0
- package/scripts/build/dist/index.cjs +7 -0
- package/scripts/build/dist/index.d.ts +2 -0
- package/scripts/build/dist/index.mjs +12 -0
- package/scripts/build/index.ts +63 -0
- package/scripts/build/modules.ts +141 -0
- package/scripts/build/package.json +14 -0
- package/scripts/release/gen-version.ts +12 -0
- package/scripts/release/index.ts +209 -0
- package/scripts/utils/excludeFiles.ts +14 -0
- package/scripts/utils/index.ts +88 -0
- package/scripts/utils/main.ts +14 -0
- package/scripts/utils/paths.ts +40 -0
- package/scripts/utils/plugin.ts +61 -0
- package/tsconfig.base.json +23 -0
- package/tsconfig.vitest.json +11 -0
- package/tsconfig.web.json +18 -0
- package/typings/env.d.ts +22 -0
- package/typings/index.d.ts +161 -0
- package/vitest.config.ts +22 -0
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div class="t-timer-btn">
|
|
3
|
+
<button
|
|
4
|
+
class="sendSmsBtn"
|
|
5
|
+
:class="{ dissendSmsBtn: disabled, className }"
|
|
6
|
+
type="button"
|
|
7
|
+
@click="run"
|
|
8
|
+
:disabled="disabled || time > 0"
|
|
9
|
+
>
|
|
10
|
+
{{ text }}
|
|
11
|
+
</button>
|
|
12
|
+
</div>
|
|
13
|
+
</template>
|
|
14
|
+
|
|
15
|
+
<script setup lang="ts">
|
|
16
|
+
import { computed, ref } from "vue"
|
|
17
|
+
defineOptions({
|
|
18
|
+
name: "TTimerBtn"
|
|
19
|
+
})
|
|
20
|
+
export interface TTimerBtnProps {
|
|
21
|
+
second?: number
|
|
22
|
+
className?: string
|
|
23
|
+
}
|
|
24
|
+
const props = withDefaults(defineProps<TTimerBtnProps>(), {
|
|
25
|
+
second: 60,
|
|
26
|
+
className: ""
|
|
27
|
+
})
|
|
28
|
+
const time = ref(0)
|
|
29
|
+
const disabled = ref(false)
|
|
30
|
+
const text = computed(() => {
|
|
31
|
+
return time.value > 0 ? `${time.value}s 后重获取` : "获取验证码"
|
|
32
|
+
})
|
|
33
|
+
const emits = defineEmits(["click"])
|
|
34
|
+
const run = () => {
|
|
35
|
+
emits("click")
|
|
36
|
+
start()
|
|
37
|
+
}
|
|
38
|
+
// 重置倒计时0
|
|
39
|
+
const reset = () => {
|
|
40
|
+
time.value = 0
|
|
41
|
+
}
|
|
42
|
+
const start = () => {
|
|
43
|
+
time.value = props.second
|
|
44
|
+
disabled.value = true
|
|
45
|
+
timer()
|
|
46
|
+
}
|
|
47
|
+
const timer = () => {
|
|
48
|
+
if (time.value > 0) {
|
|
49
|
+
time.value--
|
|
50
|
+
setTimeout(timer, 1000)
|
|
51
|
+
} else {
|
|
52
|
+
disabled.value = false
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
// 暴露方法出去
|
|
56
|
+
defineExpose({ reset })
|
|
57
|
+
</script>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import "@ff-ui-plus/theme-chalk/t-timer-btn.css"
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import "@ff-ui-plus/theme-chalk/src/timer-btn.scss"
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
type Func = (...args: any[]) => any
|
|
2
|
+
/**
|
|
3
|
+
* 防抖函数
|
|
4
|
+
* @param { Function } func 函数
|
|
5
|
+
* @param { Number } delay 防抖时间
|
|
6
|
+
* @param { Boolean } immediate 是否立即执行
|
|
7
|
+
* @param { Function } resultCallback
|
|
8
|
+
*/
|
|
9
|
+
export function debounce(
|
|
10
|
+
func: Func,
|
|
11
|
+
delay: number = 500,
|
|
12
|
+
immediate?: boolean,
|
|
13
|
+
resultCallback?: Func
|
|
14
|
+
) {
|
|
15
|
+
let timer: null | ReturnType<typeof setTimeout> = null
|
|
16
|
+
let isInvoke = false
|
|
17
|
+
const _debounce = function (this: unknown, ...args: any[]) {
|
|
18
|
+
return new Promise((resolve, reject) => {
|
|
19
|
+
if (timer) clearTimeout(timer)
|
|
20
|
+
if (immediate && !isInvoke) {
|
|
21
|
+
try {
|
|
22
|
+
const result = func.apply(this, args)
|
|
23
|
+
if (resultCallback) resultCallback(result)
|
|
24
|
+
resolve(result)
|
|
25
|
+
} catch (e) {
|
|
26
|
+
reject(e)
|
|
27
|
+
}
|
|
28
|
+
isInvoke = true
|
|
29
|
+
} else {
|
|
30
|
+
timer = setTimeout(() => {
|
|
31
|
+
try {
|
|
32
|
+
const result = func.apply(this, args)
|
|
33
|
+
if (resultCallback) resultCallback(result)
|
|
34
|
+
resolve(result)
|
|
35
|
+
} catch (e) {
|
|
36
|
+
reject(e)
|
|
37
|
+
}
|
|
38
|
+
isInvoke = false
|
|
39
|
+
timer = null
|
|
40
|
+
}, delay)
|
|
41
|
+
}
|
|
42
|
+
})
|
|
43
|
+
}
|
|
44
|
+
_debounce.cancel = function () {
|
|
45
|
+
if (timer) clearTimeout(timer)
|
|
46
|
+
isInvoke = false
|
|
47
|
+
timer = null
|
|
48
|
+
}
|
|
49
|
+
return _debounce
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* 节流函数
|
|
54
|
+
* @param { Function } func
|
|
55
|
+
* @param { Boolean } interval
|
|
56
|
+
* @param { Object } options
|
|
57
|
+
* leading:初始 trailing:结尾
|
|
58
|
+
*/
|
|
59
|
+
export function throttle(
|
|
60
|
+
func: Func,
|
|
61
|
+
interval: number,
|
|
62
|
+
options = { leading: false, trailing: true }
|
|
63
|
+
) {
|
|
64
|
+
let timer: null | ReturnType<typeof setTimeout> = null
|
|
65
|
+
let lastTime = 0
|
|
66
|
+
const { leading, trailing } = options
|
|
67
|
+
const _throttle = function (this: unknown, ...args: any[]) {
|
|
68
|
+
const nowTime = Date.now()
|
|
69
|
+
if (!lastTime && !leading) lastTime = nowTime
|
|
70
|
+
const remainTime = interval - (nowTime - lastTime)
|
|
71
|
+
if (remainTime <= 0) {
|
|
72
|
+
if (timer) {
|
|
73
|
+
clearTimeout(timer)
|
|
74
|
+
timer = null
|
|
75
|
+
}
|
|
76
|
+
lastTime = nowTime
|
|
77
|
+
func.apply(this, args)
|
|
78
|
+
}
|
|
79
|
+
if (trailing && !timer) {
|
|
80
|
+
timer = setTimeout(() => {
|
|
81
|
+
lastTime = !leading ? 0 : Date.now()
|
|
82
|
+
timer = null
|
|
83
|
+
func.apply(this, args)
|
|
84
|
+
}, remainTime)
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
_throttle.cancel = function () {
|
|
88
|
+
if (timer) clearTimeout(timer)
|
|
89
|
+
timer = null
|
|
90
|
+
lastTime = 0
|
|
91
|
+
}
|
|
92
|
+
return _throttle
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* 驼峰转换下划线
|
|
97
|
+
* @param { String } name
|
|
98
|
+
*/
|
|
99
|
+
export function toLine(name: string) {
|
|
100
|
+
return name.replace(/([A-Z])/g, "_$1").toLowerCase()
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
/*
|
|
104
|
+
自定义保留 precision 位小数,并使用 separator 分隔符进行数字格式化
|
|
105
|
+
value:格式化目标数字
|
|
106
|
+
precision:精度,保留小数点后几位,默认2位
|
|
107
|
+
separator:千分位分隔符,默认为','
|
|
108
|
+
decimal:小数点符号,默认'.'
|
|
109
|
+
prefix:前缀字符,默认''
|
|
110
|
+
suffix:后缀字符,默认''
|
|
111
|
+
formatNumber(123456789.87654321, 2, ',') // 123,456,789.88
|
|
112
|
+
*/
|
|
113
|
+
export function formatNumber(
|
|
114
|
+
value: number | string,
|
|
115
|
+
precision = 2,
|
|
116
|
+
separator = ",",
|
|
117
|
+
decimal = ".",
|
|
118
|
+
prefix = "",
|
|
119
|
+
suffix = ""
|
|
120
|
+
): string {
|
|
121
|
+
if (Number(value) === 0) {
|
|
122
|
+
return Number(value).toFixed(precision)
|
|
123
|
+
}
|
|
124
|
+
if (!value) {
|
|
125
|
+
return ""
|
|
126
|
+
}
|
|
127
|
+
value = Number(value).toFixed(precision)
|
|
128
|
+
value += ""
|
|
129
|
+
const nums = value.split(".")
|
|
130
|
+
let integer = nums[0]
|
|
131
|
+
const decimals = nums.length > 1 ? decimal + nums[1] : ""
|
|
132
|
+
const reg = /(\d+)(\d{3})/
|
|
133
|
+
function isNumber(value: any) {
|
|
134
|
+
return Object.prototype.toString.call(value) === "[object Number]"
|
|
135
|
+
}
|
|
136
|
+
if (separator && !isNumber(separator)) {
|
|
137
|
+
while (reg.test(integer)) {
|
|
138
|
+
integer = integer.replace(reg, "$1" + separator + "$2")
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
return prefix + integer + decimals + suffix
|
|
142
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { Plugin, App } from "vue"
|
|
2
|
+
export type SFCWithInstall<T> = T & Plugin
|
|
3
|
+
export const withInstall = <T, E extends Record<string, any>>(main: T, extra?: E) => {
|
|
4
|
+
;(main as SFCWithInstall<T>).install = (app: App): void => {
|
|
5
|
+
for (const comp of [main, ...Object.values(extra ?? {})]) {
|
|
6
|
+
app.component(comp.name, comp)
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
if (extra) {
|
|
11
|
+
for (const [key, comp] of Object.entries(extra)) {
|
|
12
|
+
;(main as any)[key] = comp
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
return main as SFCWithInstall<T> & E
|
|
16
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { defineBuildConfig } from "unbuild"
|
|
2
|
+
|
|
3
|
+
export default defineBuildConfig({
|
|
4
|
+
entries: ["./src/index"],
|
|
5
|
+
clean: true,
|
|
6
|
+
declaration: true,
|
|
7
|
+
rollup: {
|
|
8
|
+
emitCJS: true,
|
|
9
|
+
dts: {
|
|
10
|
+
respectExternal: true
|
|
11
|
+
},
|
|
12
|
+
esbuild: {
|
|
13
|
+
minify: false
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
})
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const index = {
|
|
4
|
+
parser: "vue-eslint-parser",
|
|
5
|
+
env: {
|
|
6
|
+
browser: true,
|
|
7
|
+
es2021: true,
|
|
8
|
+
node: true
|
|
9
|
+
},
|
|
10
|
+
extends: [
|
|
11
|
+
"eslint:recommended",
|
|
12
|
+
"plugin:vue/vue3-recommended",
|
|
13
|
+
"@vue/eslint-config-typescript/recommended",
|
|
14
|
+
"@vue/eslint-config-prettier",
|
|
15
|
+
"plugin:@typescript-eslint/recommended"
|
|
16
|
+
],
|
|
17
|
+
parserOptions: {
|
|
18
|
+
ecmaVersion: "latest",
|
|
19
|
+
parser: "@typescript-eslint/parser"
|
|
20
|
+
},
|
|
21
|
+
plugins: ["vue", "@typescript-eslint", "import"],
|
|
22
|
+
rules: {
|
|
23
|
+
// base
|
|
24
|
+
"no-unused-vars": 0,
|
|
25
|
+
"no-console": process.env.NODE_ENV === "production" ? "warn" : "off",
|
|
26
|
+
"no-debugger": process.env.NODE_ENV === "production" ? "warn" : "off",
|
|
27
|
+
semi: [2, "never"],
|
|
28
|
+
"semi-spacing": [
|
|
29
|
+
2,
|
|
30
|
+
{
|
|
31
|
+
before: false,
|
|
32
|
+
after: true
|
|
33
|
+
}
|
|
34
|
+
],
|
|
35
|
+
quotes: [
|
|
36
|
+
2,
|
|
37
|
+
"single",
|
|
38
|
+
{
|
|
39
|
+
avoidEscape: true,
|
|
40
|
+
allowTemplateLiterals: true
|
|
41
|
+
}
|
|
42
|
+
],
|
|
43
|
+
"comma-dangle": [2, "never"],
|
|
44
|
+
"comma-spacing": [
|
|
45
|
+
2,
|
|
46
|
+
{
|
|
47
|
+
before: false,
|
|
48
|
+
after: true
|
|
49
|
+
}
|
|
50
|
+
],
|
|
51
|
+
"comma-style": [2, "last"],
|
|
52
|
+
"arrow-parens": [2, "as-needed"],
|
|
53
|
+
"arrow-spacing": [
|
|
54
|
+
2,
|
|
55
|
+
{
|
|
56
|
+
before: true,
|
|
57
|
+
after: true
|
|
58
|
+
}
|
|
59
|
+
],
|
|
60
|
+
"jsx-quotes": 2,
|
|
61
|
+
"no-async-promise-executor": 0,
|
|
62
|
+
"space-before-function-paren": 0,
|
|
63
|
+
"no-empty": 0,
|
|
64
|
+
"spaced-comment": ["error", "always"],
|
|
65
|
+
"no-undef": 0,
|
|
66
|
+
eqeqeq: 2,
|
|
67
|
+
// vue
|
|
68
|
+
"vue/no-unused-vars": [
|
|
69
|
+
"error",
|
|
70
|
+
{
|
|
71
|
+
ignorePattern: "^_"
|
|
72
|
+
}
|
|
73
|
+
],
|
|
74
|
+
"vue/valid-attribute-name": 0,
|
|
75
|
+
"vue/singleline-html-element-content-newline": "off",
|
|
76
|
+
"vue/multiline-html-element-content-newline": "off",
|
|
77
|
+
"vue/no-v-html": "off",
|
|
78
|
+
"vue/html-closing-bracket-newline": "off",
|
|
79
|
+
"vue/html-self-closing": [
|
|
80
|
+
"error",
|
|
81
|
+
{
|
|
82
|
+
html: {
|
|
83
|
+
void: "always",
|
|
84
|
+
normal: "always",
|
|
85
|
+
component: "always"
|
|
86
|
+
},
|
|
87
|
+
svg: "always",
|
|
88
|
+
math: "always"
|
|
89
|
+
}
|
|
90
|
+
],
|
|
91
|
+
"vue/html-indent": 0,
|
|
92
|
+
"vue/max-attributes-per-line": 0,
|
|
93
|
+
"vue/custom-event-name-casing": 0,
|
|
94
|
+
"vue/eqeqeq": [2, "always", { null: "ignore" }],
|
|
95
|
+
"vue/multi-word-component-names": 0,
|
|
96
|
+
"vue/v-on-event-hyphenation": 0,
|
|
97
|
+
"vue/first-attribute-linebreak": 0,
|
|
98
|
+
"vue/no-reserved-props": 0,
|
|
99
|
+
// import
|
|
100
|
+
"import/first": "error",
|
|
101
|
+
"import/no-duplicates": "error",
|
|
102
|
+
"import/order": [
|
|
103
|
+
"error",
|
|
104
|
+
{
|
|
105
|
+
pathGroups: [
|
|
106
|
+
{
|
|
107
|
+
pattern: "@/**",
|
|
108
|
+
group: "external",
|
|
109
|
+
position: "after"
|
|
110
|
+
}
|
|
111
|
+
],
|
|
112
|
+
pathGroupsExcludedImportTypes: ["builtin"]
|
|
113
|
+
}
|
|
114
|
+
],
|
|
115
|
+
// typescript
|
|
116
|
+
"@typescript-eslint/no-explicit-any": 0,
|
|
117
|
+
"@typescript-eslint/no-unused-vars": ["error", { argsIgnorePattern: "^_" }],
|
|
118
|
+
"@typescript-eslint/consistent-type-imports": [2, { disallowTypeAnnotations: false }]
|
|
119
|
+
}
|
|
120
|
+
};
|
|
121
|
+
|
|
122
|
+
module.exports = index;
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
declare const _default: {
|
|
2
|
+
parser: string;
|
|
3
|
+
env: {
|
|
4
|
+
browser: boolean;
|
|
5
|
+
es2021: boolean;
|
|
6
|
+
node: boolean;
|
|
7
|
+
};
|
|
8
|
+
extends: string[];
|
|
9
|
+
parserOptions: {
|
|
10
|
+
ecmaVersion: string;
|
|
11
|
+
parser: string;
|
|
12
|
+
};
|
|
13
|
+
plugins: string[];
|
|
14
|
+
rules: {
|
|
15
|
+
"no-unused-vars": number;
|
|
16
|
+
"no-console": string;
|
|
17
|
+
"no-debugger": string;
|
|
18
|
+
semi: (string | number)[];
|
|
19
|
+
"semi-spacing": (number | {
|
|
20
|
+
before: boolean;
|
|
21
|
+
after: boolean;
|
|
22
|
+
})[];
|
|
23
|
+
quotes: (string | number | {
|
|
24
|
+
avoidEscape: boolean;
|
|
25
|
+
allowTemplateLiterals: boolean;
|
|
26
|
+
})[];
|
|
27
|
+
"comma-dangle": (string | number)[];
|
|
28
|
+
"comma-spacing": (number | {
|
|
29
|
+
before: boolean;
|
|
30
|
+
after: boolean;
|
|
31
|
+
})[];
|
|
32
|
+
"comma-style": (string | number)[];
|
|
33
|
+
"arrow-parens": (string | number)[];
|
|
34
|
+
"arrow-spacing": (number | {
|
|
35
|
+
before: boolean;
|
|
36
|
+
after: boolean;
|
|
37
|
+
})[];
|
|
38
|
+
"jsx-quotes": number;
|
|
39
|
+
"no-async-promise-executor": number;
|
|
40
|
+
"space-before-function-paren": number;
|
|
41
|
+
"no-empty": number;
|
|
42
|
+
"spaced-comment": string[];
|
|
43
|
+
"no-undef": number;
|
|
44
|
+
eqeqeq: number;
|
|
45
|
+
"vue/no-unused-vars": (string | {
|
|
46
|
+
ignorePattern: string;
|
|
47
|
+
})[];
|
|
48
|
+
"vue/valid-attribute-name": number;
|
|
49
|
+
"vue/singleline-html-element-content-newline": string;
|
|
50
|
+
"vue/multiline-html-element-content-newline": string;
|
|
51
|
+
"vue/no-v-html": string;
|
|
52
|
+
"vue/html-closing-bracket-newline": string;
|
|
53
|
+
"vue/html-self-closing": (string | {
|
|
54
|
+
html: {
|
|
55
|
+
void: string;
|
|
56
|
+
normal: string;
|
|
57
|
+
component: string;
|
|
58
|
+
};
|
|
59
|
+
svg: string;
|
|
60
|
+
math: string;
|
|
61
|
+
})[];
|
|
62
|
+
"vue/html-indent": number;
|
|
63
|
+
"vue/max-attributes-per-line": number;
|
|
64
|
+
"vue/custom-event-name-casing": number;
|
|
65
|
+
"vue/eqeqeq": (string | number | {
|
|
66
|
+
null: string;
|
|
67
|
+
})[];
|
|
68
|
+
"vue/multi-word-component-names": number;
|
|
69
|
+
"vue/v-on-event-hyphenation": number;
|
|
70
|
+
"vue/first-attribute-linebreak": number;
|
|
71
|
+
"vue/no-reserved-props": number;
|
|
72
|
+
"import/first": string;
|
|
73
|
+
"import/no-duplicates": string;
|
|
74
|
+
"import/order": (string | {
|
|
75
|
+
pathGroups: {
|
|
76
|
+
pattern: string;
|
|
77
|
+
group: string;
|
|
78
|
+
position: string;
|
|
79
|
+
}[];
|
|
80
|
+
pathGroupsExcludedImportTypes: string[];
|
|
81
|
+
})[];
|
|
82
|
+
"@typescript-eslint/no-explicit-any": number;
|
|
83
|
+
"@typescript-eslint/no-unused-vars": (string | {
|
|
84
|
+
argsIgnorePattern: string;
|
|
85
|
+
})[];
|
|
86
|
+
"@typescript-eslint/consistent-type-imports": (number | {
|
|
87
|
+
disallowTypeAnnotations: boolean;
|
|
88
|
+
})[];
|
|
89
|
+
};
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
export { _default as default };
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
declare const _default: {
|
|
2
|
+
parser: string;
|
|
3
|
+
env: {
|
|
4
|
+
browser: boolean;
|
|
5
|
+
es2021: boolean;
|
|
6
|
+
node: boolean;
|
|
7
|
+
};
|
|
8
|
+
extends: string[];
|
|
9
|
+
parserOptions: {
|
|
10
|
+
ecmaVersion: string;
|
|
11
|
+
parser: string;
|
|
12
|
+
};
|
|
13
|
+
plugins: string[];
|
|
14
|
+
rules: {
|
|
15
|
+
"no-unused-vars": number;
|
|
16
|
+
"no-console": string;
|
|
17
|
+
"no-debugger": string;
|
|
18
|
+
semi: (string | number)[];
|
|
19
|
+
"semi-spacing": (number | {
|
|
20
|
+
before: boolean;
|
|
21
|
+
after: boolean;
|
|
22
|
+
})[];
|
|
23
|
+
quotes: (string | number | {
|
|
24
|
+
avoidEscape: boolean;
|
|
25
|
+
allowTemplateLiterals: boolean;
|
|
26
|
+
})[];
|
|
27
|
+
"comma-dangle": (string | number)[];
|
|
28
|
+
"comma-spacing": (number | {
|
|
29
|
+
before: boolean;
|
|
30
|
+
after: boolean;
|
|
31
|
+
})[];
|
|
32
|
+
"comma-style": (string | number)[];
|
|
33
|
+
"arrow-parens": (string | number)[];
|
|
34
|
+
"arrow-spacing": (number | {
|
|
35
|
+
before: boolean;
|
|
36
|
+
after: boolean;
|
|
37
|
+
})[];
|
|
38
|
+
"jsx-quotes": number;
|
|
39
|
+
"no-async-promise-executor": number;
|
|
40
|
+
"space-before-function-paren": number;
|
|
41
|
+
"no-empty": number;
|
|
42
|
+
"spaced-comment": string[];
|
|
43
|
+
"no-undef": number;
|
|
44
|
+
eqeqeq: number;
|
|
45
|
+
"vue/no-unused-vars": (string | {
|
|
46
|
+
ignorePattern: string;
|
|
47
|
+
})[];
|
|
48
|
+
"vue/valid-attribute-name": number;
|
|
49
|
+
"vue/singleline-html-element-content-newline": string;
|
|
50
|
+
"vue/multiline-html-element-content-newline": string;
|
|
51
|
+
"vue/no-v-html": string;
|
|
52
|
+
"vue/html-closing-bracket-newline": string;
|
|
53
|
+
"vue/html-self-closing": (string | {
|
|
54
|
+
html: {
|
|
55
|
+
void: string;
|
|
56
|
+
normal: string;
|
|
57
|
+
component: string;
|
|
58
|
+
};
|
|
59
|
+
svg: string;
|
|
60
|
+
math: string;
|
|
61
|
+
})[];
|
|
62
|
+
"vue/html-indent": number;
|
|
63
|
+
"vue/max-attributes-per-line": number;
|
|
64
|
+
"vue/custom-event-name-casing": number;
|
|
65
|
+
"vue/eqeqeq": (string | number | {
|
|
66
|
+
null: string;
|
|
67
|
+
})[];
|
|
68
|
+
"vue/multi-word-component-names": number;
|
|
69
|
+
"vue/v-on-event-hyphenation": number;
|
|
70
|
+
"vue/first-attribute-linebreak": number;
|
|
71
|
+
"vue/no-reserved-props": number;
|
|
72
|
+
"import/first": string;
|
|
73
|
+
"import/no-duplicates": string;
|
|
74
|
+
"import/order": (string | {
|
|
75
|
+
pathGroups: {
|
|
76
|
+
pattern: string;
|
|
77
|
+
group: string;
|
|
78
|
+
position: string;
|
|
79
|
+
}[];
|
|
80
|
+
pathGroupsExcludedImportTypes: string[];
|
|
81
|
+
})[];
|
|
82
|
+
"@typescript-eslint/no-explicit-any": number;
|
|
83
|
+
"@typescript-eslint/no-unused-vars": (string | {
|
|
84
|
+
argsIgnorePattern: string;
|
|
85
|
+
})[];
|
|
86
|
+
"@typescript-eslint/consistent-type-imports": (number | {
|
|
87
|
+
disallowTypeAnnotations: boolean;
|
|
88
|
+
})[];
|
|
89
|
+
};
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
export { _default as default };
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
declare const _default: {
|
|
2
|
+
parser: string;
|
|
3
|
+
env: {
|
|
4
|
+
browser: boolean;
|
|
5
|
+
es2021: boolean;
|
|
6
|
+
node: boolean;
|
|
7
|
+
};
|
|
8
|
+
extends: string[];
|
|
9
|
+
parserOptions: {
|
|
10
|
+
ecmaVersion: string;
|
|
11
|
+
parser: string;
|
|
12
|
+
};
|
|
13
|
+
plugins: string[];
|
|
14
|
+
rules: {
|
|
15
|
+
"no-unused-vars": number;
|
|
16
|
+
"no-console": string;
|
|
17
|
+
"no-debugger": string;
|
|
18
|
+
semi: (string | number)[];
|
|
19
|
+
"semi-spacing": (number | {
|
|
20
|
+
before: boolean;
|
|
21
|
+
after: boolean;
|
|
22
|
+
})[];
|
|
23
|
+
quotes: (string | number | {
|
|
24
|
+
avoidEscape: boolean;
|
|
25
|
+
allowTemplateLiterals: boolean;
|
|
26
|
+
})[];
|
|
27
|
+
"comma-dangle": (string | number)[];
|
|
28
|
+
"comma-spacing": (number | {
|
|
29
|
+
before: boolean;
|
|
30
|
+
after: boolean;
|
|
31
|
+
})[];
|
|
32
|
+
"comma-style": (string | number)[];
|
|
33
|
+
"arrow-parens": (string | number)[];
|
|
34
|
+
"arrow-spacing": (number | {
|
|
35
|
+
before: boolean;
|
|
36
|
+
after: boolean;
|
|
37
|
+
})[];
|
|
38
|
+
"jsx-quotes": number;
|
|
39
|
+
"no-async-promise-executor": number;
|
|
40
|
+
"space-before-function-paren": number;
|
|
41
|
+
"no-empty": number;
|
|
42
|
+
"spaced-comment": string[];
|
|
43
|
+
"no-undef": number;
|
|
44
|
+
eqeqeq: number;
|
|
45
|
+
"vue/no-unused-vars": (string | {
|
|
46
|
+
ignorePattern: string;
|
|
47
|
+
})[];
|
|
48
|
+
"vue/valid-attribute-name": number;
|
|
49
|
+
"vue/singleline-html-element-content-newline": string;
|
|
50
|
+
"vue/multiline-html-element-content-newline": string;
|
|
51
|
+
"vue/no-v-html": string;
|
|
52
|
+
"vue/html-closing-bracket-newline": string;
|
|
53
|
+
"vue/html-self-closing": (string | {
|
|
54
|
+
html: {
|
|
55
|
+
void: string;
|
|
56
|
+
normal: string;
|
|
57
|
+
component: string;
|
|
58
|
+
};
|
|
59
|
+
svg: string;
|
|
60
|
+
math: string;
|
|
61
|
+
})[];
|
|
62
|
+
"vue/html-indent": number;
|
|
63
|
+
"vue/max-attributes-per-line": number;
|
|
64
|
+
"vue/custom-event-name-casing": number;
|
|
65
|
+
"vue/eqeqeq": (string | number | {
|
|
66
|
+
null: string;
|
|
67
|
+
})[];
|
|
68
|
+
"vue/multi-word-component-names": number;
|
|
69
|
+
"vue/v-on-event-hyphenation": number;
|
|
70
|
+
"vue/first-attribute-linebreak": number;
|
|
71
|
+
"vue/no-reserved-props": number;
|
|
72
|
+
"import/first": string;
|
|
73
|
+
"import/no-duplicates": string;
|
|
74
|
+
"import/order": (string | {
|
|
75
|
+
pathGroups: {
|
|
76
|
+
pattern: string;
|
|
77
|
+
group: string;
|
|
78
|
+
position: string;
|
|
79
|
+
}[];
|
|
80
|
+
pathGroupsExcludedImportTypes: string[];
|
|
81
|
+
})[];
|
|
82
|
+
"@typescript-eslint/no-explicit-any": number;
|
|
83
|
+
"@typescript-eslint/no-unused-vars": (string | {
|
|
84
|
+
argsIgnorePattern: string;
|
|
85
|
+
})[];
|
|
86
|
+
"@typescript-eslint/consistent-type-imports": (number | {
|
|
87
|
+
disallowTypeAnnotations: boolean;
|
|
88
|
+
})[];
|
|
89
|
+
};
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
export { _default as default };
|