hzzt-plus 0.0.1
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/README.md +45 -0
- package/dist/index.css +1 -0
- package/dist/index.full.js +6928 -0
- package/dist/index.full.min.js +29 -0
- package/dist/index.full.min.js.map +1 -0
- package/dist/index.full.min.mjs +29 -0
- package/dist/index.full.min.mjs.map +1 -0
- package/dist/index.full.mjs +6916 -0
- package/dist/locale/en.js +16 -0
- package/dist/locale/en.min.js +2 -0
- package/dist/locale/en.min.js.map +1 -0
- package/dist/locale/en.min.mjs +2 -0
- package/dist/locale/en.min.mjs.map +1 -0
- package/dist/locale/en.mjs +8 -0
- package/dist/locale/zh-cn.js +16 -0
- package/dist/locale/zh-cn.min.js +2 -0
- package/dist/locale/zh-cn.min.js.map +1 -0
- package/dist/locale/zh-cn.min.mjs +2 -0
- package/dist/locale/zh-cn.min.mjs.map +1 -0
- package/dist/locale/zh-cn.mjs +8 -0
- package/es/_virtual/plugin-vue_export-helper.mjs +10 -0
- package/es/_virtual/plugin-vue_export-helper.mjs.map +1 -0
- package/es/component.d.ts +3 -0
- package/es/component.mjs +8 -0
- package/es/component.mjs.map +1 -0
- package/es/components/base/style/css.d.ts +1 -0
- package/es/components/base/style/index.d.ts +1 -0
- package/es/components/index.d.ts +1 -0
- package/es/components/title/index.d.ts +30 -0
- package/es/components/title/src/index.vue.d.ts +30 -0
- package/es/components/title/style/css.d.ts +2 -0
- package/es/components/title/style/index.d.ts +2 -0
- package/es/constants/aria.d.ts +17 -0
- package/es/constants/date.d.ts +3 -0
- package/es/constants/event.d.ts +3 -0
- package/es/constants/index.d.ts +3 -0
- package/es/constants/key.d.ts +1 -0
- package/es/constants/size.d.ts +7 -0
- package/es/defaults.d.ts +5 -0
- package/es/defaults.mjs +8 -0
- package/es/defaults.mjs.map +1 -0
- package/es/index.d.ts +6 -0
- package/es/index.mjs +11 -0
- package/es/index.mjs.map +1 -0
- package/es/locale/index.d.ts +9 -0
- package/es/locale/lang/en.d.ts +5 -0
- package/es/locale/lang/zh-cn.d.ts +5 -0
- package/es/make-installer.d.ts +5 -0
- package/es/make-installer.mjs +19 -0
- package/es/make-installer.mjs.map +1 -0
- package/es/node_modules/.pnpm/@element-plus_icons-vue@2.3.1_vue@3.2.37/node_modules/@element-plus/icons-vue/dist/index.mjs +5764 -0
- package/es/node_modules/.pnpm/@element-plus_icons-vue@2.3.1_vue@3.2.37/node_modules/@element-plus/icons-vue/dist/index.mjs.map +1 -0
- package/es/packages/components/base/style/css.mjs +2 -0
- package/es/packages/components/base/style/css.mjs.map +1 -0
- package/es/packages/components/base/style/index.mjs +2 -0
- package/es/packages/components/base/style/index.mjs.map +1 -0
- package/es/packages/components/index.mjs +2 -0
- package/es/packages/components/index.mjs.map +1 -0
- package/es/packages/components/title/index.mjs +8 -0
- package/es/packages/components/title/index.mjs.map +1 -0
- package/es/packages/components/title/src/index.mjs +48 -0
- package/es/packages/components/title/src/index.mjs.map +1 -0
- package/es/packages/components/title/style/css.mjs +3 -0
- package/es/packages/components/title/style/css.mjs.map +1 -0
- package/es/packages/components/title/style/index.mjs +3 -0
- package/es/packages/components/title/style/index.mjs.map +1 -0
- package/es/packages/constants/aria.mjs +20 -0
- package/es/packages/constants/aria.mjs.map +1 -0
- package/es/packages/constants/date.mjs +25 -0
- package/es/packages/constants/date.mjs.map +1 -0
- package/es/packages/constants/event.mjs +6 -0
- package/es/packages/constants/event.mjs.map +1 -0
- package/es/packages/constants/index.mjs +4 -0
- package/es/packages/constants/index.mjs.map +1 -0
- package/es/packages/constants/key.mjs +4 -0
- package/es/packages/constants/key.mjs.map +1 -0
- package/es/packages/constants/size.mjs +9 -0
- package/es/packages/constants/size.mjs.map +1 -0
- package/es/packages/locale/index.mjs +3 -0
- package/es/packages/locale/index.mjs.map +1 -0
- package/es/packages/locale/lang/en.mjs +7 -0
- package/es/packages/locale/lang/en.mjs.map +1 -0
- package/es/packages/locale/lang/zh-cn.mjs +7 -0
- package/es/packages/locale/lang/zh-cn.mjs.map +1 -0
- package/es/packages/utils/arrays.mjs +11 -0
- package/es/packages/utils/arrays.mjs.map +1 -0
- package/es/packages/utils/browser.mjs +7 -0
- package/es/packages/utils/browser.mjs.map +1 -0
- package/es/packages/utils/dom/aria.mjs +74 -0
- package/es/packages/utils/dom/aria.mjs.map +1 -0
- package/es/packages/utils/dom/element.mjs +20 -0
- package/es/packages/utils/dom/element.mjs.map +1 -0
- package/es/packages/utils/dom/event.mjs +15 -0
- package/es/packages/utils/dom/event.mjs.map +1 -0
- package/es/packages/utils/dom/index.mjs +7 -0
- package/es/packages/utils/dom/index.mjs.map +1 -0
- package/es/packages/utils/dom/position.mjs +53 -0
- package/es/packages/utils/dom/position.mjs.map +1 -0
- package/es/packages/utils/dom/scroll.mjs +116 -0
- package/es/packages/utils/dom/scroll.mjs.map +1 -0
- package/es/packages/utils/dom/style.mjs +76 -0
- package/es/packages/utils/dom/style.mjs.map +1 -0
- package/es/packages/utils/easings.mjs +11 -0
- package/es/packages/utils/easings.mjs.map +1 -0
- package/es/packages/utils/error.mjs +21 -0
- package/es/packages/utils/error.mjs.map +1 -0
- package/es/packages/utils/functions.mjs +2 -0
- package/es/packages/utils/functions.mjs.map +1 -0
- package/es/packages/utils/i18n.mjs +4 -0
- package/es/packages/utils/i18n.mjs.map +1 -0
- package/es/packages/utils/index.mjs +34 -0
- package/es/packages/utils/index.mjs.map +1 -0
- package/es/packages/utils/objects.mjs +18 -0
- package/es/packages/utils/objects.mjs.map +1 -0
- package/es/packages/utils/raf.mjs +8 -0
- package/es/packages/utils/raf.mjs.map +1 -0
- package/es/packages/utils/rand.mjs +5 -0
- package/es/packages/utils/rand.mjs.map +1 -0
- package/es/packages/utils/strings.mjs +8 -0
- package/es/packages/utils/strings.mjs.map +1 -0
- package/es/packages/utils/throttleByRaf.mjs +22 -0
- package/es/packages/utils/throttleByRaf.mjs.map +1 -0
- package/es/packages/utils/types.mjs +29 -0
- package/es/packages/utils/types.mjs.map +1 -0
- package/es/packages/utils/typescript.mjs +4 -0
- package/es/packages/utils/typescript.mjs.map +1 -0
- package/es/packages/utils/vue/global-node.mjs +33 -0
- package/es/packages/utils/vue/global-node.mjs.map +1 -0
- package/es/packages/utils/vue/icon.mjs +33 -0
- package/es/packages/utils/vue/icon.mjs.map +1 -0
- package/es/packages/utils/vue/index.mjs +11 -0
- package/es/packages/utils/vue/index.mjs.map +1 -0
- package/es/packages/utils/vue/install.mjs +41 -0
- package/es/packages/utils/vue/install.mjs.map +1 -0
- package/es/packages/utils/vue/props/index.mjs +4 -0
- package/es/packages/utils/vue/props/index.mjs.map +1 -0
- package/es/packages/utils/vue/props/runtime.mjs +48 -0
- package/es/packages/utils/vue/props/runtime.mjs.map +1 -0
- package/es/packages/utils/vue/props/types.mjs +2 -0
- package/es/packages/utils/vue/props/types.mjs.map +1 -0
- package/es/packages/utils/vue/props/util.mjs +2 -0
- package/es/packages/utils/vue/props/util.mjs.map +1 -0
- package/es/packages/utils/vue/refs.mjs +17 -0
- package/es/packages/utils/vue/refs.mjs.map +1 -0
- package/es/packages/utils/vue/size.mjs +9 -0
- package/es/packages/utils/vue/size.mjs.map +1 -0
- package/es/packages/utils/vue/typescript.mjs +2 -0
- package/es/packages/utils/vue/typescript.mjs.map +1 -0
- package/es/packages/utils/vue/validator.mjs +9 -0
- package/es/packages/utils/vue/validator.mjs.map +1 -0
- package/es/packages/utils/vue/vnode.mjs +104 -0
- package/es/packages/utils/vue/vnode.mjs.map +1 -0
- package/es/plugin.d.ts +3 -0
- package/es/plugin.mjs +4 -0
- package/es/plugin.mjs.map +1 -0
- package/es/utils/arrays.d.ts +5 -0
- package/es/utils/browser.d.ts +3 -0
- package/es/utils/dom/aria.d.ts +30 -0
- package/es/utils/dom/element.d.ts +3 -0
- package/es/utils/dom/event.d.ts +6 -0
- package/es/utils/dom/index.d.ts +6 -0
- package/es/utils/dom/position.d.ts +7 -0
- package/es/utils/dom/scroll.d.ts +11 -0
- package/es/utils/dom/style.d.ts +9 -0
- package/es/utils/easings.d.ts +1 -0
- package/es/utils/error.d.ts +3 -0
- package/es/utils/functions.d.ts +1 -0
- package/es/utils/i18n.d.ts +1 -0
- package/es/utils/index.d.ts +15 -0
- package/es/utils/objects.d.ts +8 -0
- package/es/utils/raf.d.ts +2 -0
- package/es/utils/rand.d.ts +12 -0
- package/es/utils/strings.d.ts +6 -0
- package/es/utils/throttleByRaf.d.ts +4 -0
- package/es/utils/types.d.ts +10 -0
- package/es/utils/typescript.d.ts +12 -0
- package/es/utils/vue/global-node.d.ts +3 -0
- package/es/utils/vue/icon.d.ts +23 -0
- package/es/utils/vue/index.d.ts +9 -0
- package/es/utils/vue/install.d.ts +6 -0
- package/es/utils/vue/props/index.d.ts +3 -0
- package/es/utils/vue/props/runtime.d.ts +29 -0
- package/es/utils/vue/props/types.d.ts +120 -0
- package/es/utils/vue/props/util.d.ts +8 -0
- package/es/utils/vue/refs.d.ts +3 -0
- package/es/utils/vue/size.d.ts +1 -0
- package/es/utils/vue/typescript.d.ts +5 -0
- package/es/utils/vue/validator.d.ts +2 -0
- package/es/utils/vue/vnode.d.ts +51 -0
- package/es/version.d.ts +1 -0
- package/es/version.mjs +4 -0
- package/es/version.mjs.map +1 -0
- package/global.d.ts +8 -0
- package/lib/_virtual/plugin-vue_export-helper.js +14 -0
- package/lib/_virtual/plugin-vue_export-helper.js.map +1 -0
- package/lib/component.d.ts +3 -0
- package/lib/component.js +12 -0
- package/lib/component.js.map +1 -0
- package/lib/components/base/style/css.d.ts +1 -0
- package/lib/components/base/style/index.d.ts +1 -0
- package/lib/components/index.d.ts +1 -0
- package/lib/components/title/index.d.ts +30 -0
- package/lib/components/title/src/index.vue.d.ts +30 -0
- package/lib/components/title/style/css.d.ts +2 -0
- package/lib/components/title/style/index.d.ts +2 -0
- package/lib/constants/aria.d.ts +17 -0
- package/lib/constants/date.d.ts +3 -0
- package/lib/constants/event.d.ts +3 -0
- package/lib/constants/index.d.ts +3 -0
- package/lib/constants/key.d.ts +1 -0
- package/lib/constants/size.d.ts +7 -0
- package/lib/defaults.d.ts +5 -0
- package/lib/defaults.js +12 -0
- package/lib/defaults.js.map +1 -0
- package/lib/index.d.ts +6 -0
- package/lib/index.js +18 -0
- package/lib/index.js.map +1 -0
- package/lib/locale/index.d.ts +9 -0
- package/lib/locale/lang/en.d.ts +5 -0
- package/lib/locale/lang/zh-cn.d.ts +5 -0
- package/lib/make-installer.d.ts +5 -0
- package/lib/make-installer.js +23 -0
- package/lib/make-installer.js.map +1 -0
- package/lib/node_modules/.pnpm/@element-plus_icons-vue@2.3.1_vue@3.2.37/node_modules/@element-plus/icons-vue/dist/index.js +6060 -0
- package/lib/node_modules/.pnpm/@element-plus_icons-vue@2.3.1_vue@3.2.37/node_modules/@element-plus/icons-vue/dist/index.js.map +1 -0
- package/lib/packages/components/base/style/css.js +5 -0
- package/lib/packages/components/base/style/css.js.map +1 -0
- package/lib/packages/components/base/style/index.js +5 -0
- package/lib/packages/components/base/style/index.js.map +1 -0
- package/lib/packages/components/index.js +10 -0
- package/lib/packages/components/index.js.map +1 -0
- package/lib/packages/components/title/index.js +13 -0
- package/lib/packages/components/title/index.js.map +1 -0
- package/lib/packages/components/title/src/index.js +52 -0
- package/lib/packages/components/title/src/index.js.map +1 -0
- package/lib/packages/components/title/style/css.js +6 -0
- package/lib/packages/components/title/style/css.js.map +1 -0
- package/lib/packages/components/title/style/index.js +6 -0
- package/lib/packages/components/title/style/index.js.map +1 -0
- package/lib/packages/constants/aria.js +24 -0
- package/lib/packages/constants/aria.js.map +1 -0
- package/lib/packages/constants/date.js +30 -0
- package/lib/packages/constants/date.js.map +1 -0
- package/lib/packages/constants/event.js +12 -0
- package/lib/packages/constants/event.js.map +1 -0
- package/lib/packages/constants/index.js +16 -0
- package/lib/packages/constants/index.js.map +1 -0
- package/lib/packages/constants/key.js +8 -0
- package/lib/packages/constants/key.js.map +1 -0
- package/lib/packages/constants/size.js +14 -0
- package/lib/packages/constants/size.js.map +1 -0
- package/lib/packages/locale/index.js +12 -0
- package/lib/packages/locale/index.js.map +1 -0
- package/lib/packages/locale/lang/en.js +11 -0
- package/lib/packages/locale/lang/en.js.map +1 -0
- package/lib/packages/locale/lang/zh-cn.js +11 -0
- package/lib/packages/locale/lang/zh-cn.js.map +1 -0
- package/lib/packages/utils/arrays.js +20 -0
- package/lib/packages/utils/arrays.js.map +1 -0
- package/lib/packages/utils/browser.js +18 -0
- package/lib/packages/utils/browser.js.map +1 -0
- package/lib/packages/utils/dom/aria.js +85 -0
- package/lib/packages/utils/dom/aria.js.map +1 -0
- package/lib/packages/utils/dom/element.js +24 -0
- package/lib/packages/utils/dom/element.js.map +1 -0
- package/lib/packages/utils/dom/event.js +20 -0
- package/lib/packages/utils/dom/event.js.map +1 -0
- package/lib/packages/utils/dom/index.js +44 -0
- package/lib/packages/utils/dom/index.js.map +1 -0
- package/lib/packages/utils/dom/position.js +60 -0
- package/lib/packages/utils/dom/position.js.map +1 -0
- package/lib/packages/utils/dom/scroll.js +126 -0
- package/lib/packages/utils/dom/scroll.js.map +1 -0
- package/lib/packages/utils/dom/style.js +87 -0
- package/lib/packages/utils/dom/style.js.map +1 -0
- package/lib/packages/utils/easings.js +15 -0
- package/lib/packages/utils/easings.js.map +1 -0
- package/lib/packages/utils/error.js +26 -0
- package/lib/packages/utils/error.js.map +1 -0
- package/lib/packages/utils/functions.js +13 -0
- package/lib/packages/utils/functions.js.map +1 -0
- package/lib/packages/utils/i18n.js +8 -0
- package/lib/packages/utils/i18n.js.map +1 -0
- package/lib/packages/utils/index.js +194 -0
- package/lib/packages/utils/index.js.map +1 -0
- package/lib/packages/utils/objects.js +28 -0
- package/lib/packages/utils/objects.js.map +1 -0
- package/lib/packages/utils/raf.js +13 -0
- package/lib/packages/utils/raf.js.map +1 -0
- package/lib/packages/utils/rand.js +10 -0
- package/lib/packages/utils/rand.js.map +1 -0
- package/lib/packages/utils/strings.js +24 -0
- package/lib/packages/utils/strings.js.map +1 -0
- package/lib/packages/utils/throttleByRaf.js +26 -0
- package/lib/packages/utils/throttleByRaf.js.map +1 -0
- package/lib/packages/utils/types.js +71 -0
- package/lib/packages/utils/types.js.map +1 -0
- package/lib/packages/utils/typescript.js +8 -0
- package/lib/packages/utils/typescript.js.map +1 -0
- package/lib/packages/utils/vue/global-node.js +39 -0
- package/lib/packages/utils/vue/global-node.js.map +1 -0
- package/lib/packages/utils/vue/icon.js +41 -0
- package/lib/packages/utils/vue/icon.js.map +1 -0
- package/lib/packages/utils/vue/index.js +51 -0
- package/lib/packages/utils/vue/index.js.map +1 -0
- package/lib/packages/utils/vue/install.js +48 -0
- package/lib/packages/utils/vue/install.js.map +1 -0
- package/lib/packages/utils/vue/props/index.js +16 -0
- package/lib/packages/utils/vue/props/index.js.map +1 -0
- package/lib/packages/utils/vue/props/runtime.js +56 -0
- package/lib/packages/utils/vue/props/runtime.js.map +1 -0
- package/lib/packages/utils/vue/props/types.js +3 -0
- package/lib/packages/utils/vue/props/types.js.map +1 -0
- package/lib/packages/utils/vue/props/util.js +3 -0
- package/lib/packages/utils/vue/props/util.js.map +1 -0
- package/lib/packages/utils/vue/refs.js +21 -0
- package/lib/packages/utils/vue/refs.js.map +1 -0
- package/lib/packages/utils/vue/size.js +13 -0
- package/lib/packages/utils/vue/size.js.map +1 -0
- package/lib/packages/utils/vue/typescript.js +3 -0
- package/lib/packages/utils/vue/typescript.js.map +1 -0
- package/lib/packages/utils/vue/validator.js +14 -0
- package/lib/packages/utils/vue/validator.js.map +1 -0
- package/lib/packages/utils/vue/vnode.js +119 -0
- package/lib/packages/utils/vue/vnode.js.map +1 -0
- package/lib/plugin.d.ts +3 -0
- package/lib/plugin.js +8 -0
- package/lib/plugin.js.map +1 -0
- package/lib/utils/arrays.d.ts +5 -0
- package/lib/utils/browser.d.ts +3 -0
- package/lib/utils/dom/aria.d.ts +30 -0
- package/lib/utils/dom/element.d.ts +3 -0
- package/lib/utils/dom/event.d.ts +6 -0
- package/lib/utils/dom/index.d.ts +6 -0
- package/lib/utils/dom/position.d.ts +7 -0
- package/lib/utils/dom/scroll.d.ts +11 -0
- package/lib/utils/dom/style.d.ts +9 -0
- package/lib/utils/easings.d.ts +1 -0
- package/lib/utils/error.d.ts +3 -0
- package/lib/utils/functions.d.ts +1 -0
- package/lib/utils/i18n.d.ts +1 -0
- package/lib/utils/index.d.ts +15 -0
- package/lib/utils/objects.d.ts +8 -0
- package/lib/utils/raf.d.ts +2 -0
- package/lib/utils/rand.d.ts +12 -0
- package/lib/utils/strings.d.ts +6 -0
- package/lib/utils/throttleByRaf.d.ts +4 -0
- package/lib/utils/types.d.ts +10 -0
- package/lib/utils/typescript.d.ts +12 -0
- package/lib/utils/vue/global-node.d.ts +3 -0
- package/lib/utils/vue/icon.d.ts +23 -0
- package/lib/utils/vue/index.d.ts +9 -0
- package/lib/utils/vue/install.d.ts +6 -0
- package/lib/utils/vue/props/index.d.ts +3 -0
- package/lib/utils/vue/props/runtime.d.ts +29 -0
- package/lib/utils/vue/props/types.d.ts +120 -0
- package/lib/utils/vue/props/util.d.ts +8 -0
- package/lib/utils/vue/refs.d.ts +3 -0
- package/lib/utils/vue/size.d.ts +1 -0
- package/lib/utils/vue/typescript.d.ts +5 -0
- package/lib/utils/vue/validator.d.ts +2 -0
- package/lib/utils/vue/vnode.d.ts +51 -0
- package/lib/version.d.ts +1 -0
- package/lib/version.js +8 -0
- package/lib/version.js.map +1 -0
- package/package.json +106 -0
- package/theme/base.css +1 -0
- package/theme/hzzt-title.css +1 -0
- package/theme/hzzt-var.css +1 -0
- package/theme/index.css +1 -0
- package/theme/src/base.scss +5 -0
- package/theme/src/common/box.scss +93 -0
- package/theme/src/common/flex.scss +119 -0
- package/theme/src/common/font.scss +39 -0
- package/theme/src/common/position.scss +41 -0
- package/theme/src/common/var.scss +1540 -0
- package/theme/src/index.scss +3 -0
- package/theme/src/mixins/_button.scss +165 -0
- package/theme/src/mixins/_col.scss +33 -0
- package/theme/src/mixins/_var.scss +66 -0
- package/theme/src/mixins/config.scss +5 -0
- package/theme/src/mixins/function.scss +86 -0
- package/theme/src/mixins/mixins.scss +235 -0
- package/theme/src/mixins/utils.scss +39 -0
- package/theme/src/title.scss +22 -0
- package/theme/src/var.scss +87 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"css.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../../../../packages/components/title/index.ts"],"sourcesContent":["import { withInstall } from '@hzzt-plus/utils'\n\nimport Title from './src/index.vue';\n\nexport const HzztTitle = withInstall(Title);\nexport default HzztTitle\n"],"names":[],"mappings":";;;;AAEY,MAAC,SAAS,GAAG,WAAW,CAAC,KAAK;;;;"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { defineComponent, useSlots, computed, unref, openBlock, createElementBlock, createCommentVNode, renderSlot, createElementVNode, createTextVNode, toDisplayString } from 'vue';
|
|
2
|
+
import _export_sfc from '../../../../_virtual/plugin-vue_export-helper.mjs';
|
|
3
|
+
|
|
4
|
+
const _hoisted_1 = {
|
|
5
|
+
key: 0,
|
|
6
|
+
class: "hzzt-title flex align-items-center"
|
|
7
|
+
};
|
|
8
|
+
const _hoisted_2 = {
|
|
9
|
+
key: 0,
|
|
10
|
+
class: "decorative-line"
|
|
11
|
+
};
|
|
12
|
+
const _hoisted_3 = { class: "label-name" };
|
|
13
|
+
const __default__ = defineComponent({
|
|
14
|
+
name: "HzztTitle"
|
|
15
|
+
});
|
|
16
|
+
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
17
|
+
...__default__,
|
|
18
|
+
props: {
|
|
19
|
+
label: String,
|
|
20
|
+
sideline: {
|
|
21
|
+
type: Boolean,
|
|
22
|
+
default: true
|
|
23
|
+
}
|
|
24
|
+
},
|
|
25
|
+
setup(__props) {
|
|
26
|
+
const props = __props;
|
|
27
|
+
const slots = useSlots();
|
|
28
|
+
const showLabel = computed(() => {
|
|
29
|
+
var _a, _b, _c;
|
|
30
|
+
return props.label || ((_c = (_b = (_a = slots == null ? void 0 : slots.default) == null ? void 0 : _a.call(slots)) == null ? void 0 : _b[0]) == null ? void 0 : _c.children);
|
|
31
|
+
});
|
|
32
|
+
return (_ctx, _cache) => {
|
|
33
|
+
return unref(showLabel) ? (openBlock(), createElementBlock("div", _hoisted_1, [
|
|
34
|
+
__props.sideline ? (openBlock(), createElementBlock("span", _hoisted_2)) : createCommentVNode("v-if", true),
|
|
35
|
+
renderSlot(_ctx.$slots, "before"),
|
|
36
|
+
createElementVNode("label", _hoisted_3, [
|
|
37
|
+
renderSlot(_ctx.$slots, "default", {}, () => [
|
|
38
|
+
createTextVNode(toDisplayString(__props.label), 1)
|
|
39
|
+
])
|
|
40
|
+
])
|
|
41
|
+
])) : createCommentVNode("v-if", true);
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
var Title = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "index.vue"]]);
|
|
46
|
+
|
|
47
|
+
export { Title as default };
|
|
48
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../../../../../packages/components/title/src/index.vue"],"sourcesContent":["<template>\n <div v-if=\"showLabel\" class=\"hzzt-title flex align-items-center\">\n <span v-if=\"sideline\" class=\"decorative-line\" />\n <slot name=\"before\" />\n <label class=\"label-name\">\n <slot>{{ label }}</slot>\n </label>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\n\n import {computed, useSlots} from 'vue';\n\n defineOptions({\n name: 'HzztTitle',\n });\n\n const props = defineProps({\n label: String,\n sideline: {\n type: Boolean,\n default: true,\n },\n });\n\n const slots = useSlots();\n\n const showLabel = computed(() => props.label || slots?.default?.()?.[0]?.children);\n\n</script>\n"],"names":[],"mappings":";;;;;;;;;;;;mCAcgB,CAAA;AAAA,EACZ,IAAM,EAAA,WAAA;AACR,CAAA,CAAA,CAAA;;;;;;;;;;;;AAUA,IAAA,MAAM,QAAQ,QAAS,EAAA,CAAA;AAEvB,IAAM,MAAA,SAAA,GAAY,SAAS,MAAM;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"css.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
const EVENT_CODE = {
|
|
2
|
+
tab: "Tab",
|
|
3
|
+
enter: "Enter",
|
|
4
|
+
space: "Space",
|
|
5
|
+
left: "ArrowLeft",
|
|
6
|
+
up: "ArrowUp",
|
|
7
|
+
right: "ArrowRight",
|
|
8
|
+
down: "ArrowDown",
|
|
9
|
+
esc: "Escape",
|
|
10
|
+
delete: "Delete",
|
|
11
|
+
backspace: "Backspace",
|
|
12
|
+
numpadEnter: "NumpadEnter",
|
|
13
|
+
pageUp: "PageUp",
|
|
14
|
+
pageDown: "PageDown",
|
|
15
|
+
home: "Home",
|
|
16
|
+
end: "End"
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
export { EVENT_CODE };
|
|
20
|
+
//# sourceMappingURL=aria.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aria.mjs","sources":["../../../../../packages/constants/aria.ts"],"sourcesContent":["export const EVENT_CODE = {\n tab: 'Tab',\n enter: 'Enter',\n space: 'Space',\n left: 'ArrowLeft', // 37\n up: 'ArrowUp', // 38\n right: 'ArrowRight', // 39\n down: 'ArrowDown', // 40\n esc: 'Escape',\n delete: 'Delete',\n backspace: 'Backspace',\n numpadEnter: 'NumpadEnter',\n pageUp: 'PageUp',\n pageDown: 'PageDown',\n home: 'Home',\n end: 'End',\n}\n"],"names":[],"mappings":"AAAY,MAAC,UAAU,GAAG;AAC1B,EAAE,GAAG,EAAE,KAAK;AACZ,EAAE,KAAK,EAAE,OAAO;AAChB,EAAE,KAAK,EAAE,OAAO;AAChB,EAAE,IAAI,EAAE,WAAW;AACnB,EAAE,EAAE,EAAE,SAAS;AACf,EAAE,KAAK,EAAE,YAAY;AACrB,EAAE,IAAI,EAAE,WAAW;AACnB,EAAE,GAAG,EAAE,QAAQ;AACf,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,SAAS,EAAE,WAAW;AACxB,EAAE,WAAW,EAAE,aAAa;AAC5B,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,QAAQ,EAAE,UAAU;AACtB,EAAE,IAAI,EAAE,MAAM;AACd,EAAE,GAAG,EAAE,KAAK;AACZ;;;;"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
const datePickTypes = [
|
|
2
|
+
"year",
|
|
3
|
+
"years",
|
|
4
|
+
"month",
|
|
5
|
+
"months",
|
|
6
|
+
"date",
|
|
7
|
+
"dates",
|
|
8
|
+
"week",
|
|
9
|
+
"datetime",
|
|
10
|
+
"datetimerange",
|
|
11
|
+
"daterange",
|
|
12
|
+
"monthrange"
|
|
13
|
+
];
|
|
14
|
+
const WEEK_DAYS = [
|
|
15
|
+
"sun",
|
|
16
|
+
"mon",
|
|
17
|
+
"tue",
|
|
18
|
+
"wed",
|
|
19
|
+
"thu",
|
|
20
|
+
"fri",
|
|
21
|
+
"sat"
|
|
22
|
+
];
|
|
23
|
+
|
|
24
|
+
export { WEEK_DAYS, datePickTypes };
|
|
25
|
+
//# sourceMappingURL=date.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"date.mjs","sources":["../../../../../packages/constants/date.ts"],"sourcesContent":["export const datePickTypes = [\n 'year',\n 'years',\n 'month',\n 'months',\n 'date',\n 'dates',\n 'week',\n 'datetime',\n 'datetimerange',\n 'daterange',\n 'monthrange',\n] as const\n\nexport const WEEK_DAYS = [\n 'sun',\n 'mon',\n 'tue',\n 'wed',\n 'thu',\n 'fri',\n 'sat',\n] as const\n\nexport type DatePickType = typeof datePickTypes[number]\n"],"names":[],"mappings":"AAAY,MAAC,aAAa,GAAG;AAC7B,EAAE,MAAM;AACR,EAAE,OAAO;AACT,EAAE,OAAO;AACT,EAAE,QAAQ;AACV,EAAE,MAAM;AACR,EAAE,OAAO;AACT,EAAE,MAAM;AACR,EAAE,UAAU;AACZ,EAAE,eAAe;AACjB,EAAE,WAAW;AACb,EAAE,YAAY;AACd,EAAE;AACU,MAAC,SAAS,GAAG;AACzB,EAAE,KAAK;AACP,EAAE,KAAK;AACP,EAAE,KAAK;AACP,EAAE,KAAK;AACP,EAAE,KAAK;AACP,EAAE,KAAK;AACP,EAAE,KAAK;AACP;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event.mjs","sources":["../../../../../packages/constants/event.ts"],"sourcesContent":["export const UPDATE_MODEL_EVENT = 'update:modelValue'\nexport const CHANGE_EVENT = 'change'\nexport const INPUT_EVENT = 'input'\n"],"names":[],"mappings":"AAAY,MAAC,kBAAkB,GAAG,oBAAoB;AAC1C,MAAC,YAAY,GAAG,SAAS;AACzB,MAAC,WAAW,GAAG;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"key.mjs","sources":["../../../../../packages/constants/key.ts"],"sourcesContent":["export const INSTALLED_KEY = Symbol('INSTALLED_KEY')\n"],"names":[],"mappings":"AAAY,MAAC,aAAa,GAAG,MAAM,CAAC,eAAe;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"size.mjs","sources":["../../../../../packages/constants/size.ts"],"sourcesContent":["export const componentSizes = ['', 'default', 'small', 'large'] as const\n\nexport type ComponentSize = typeof componentSizes[number]\n\nexport const componentSizeMap = {\n large: 40,\n default: 32,\n small: 24,\n} as const\n"],"names":[],"mappings":"AAAY,MAAC,cAAc,GAAG,CAAC,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE;AACpD,MAAC,gBAAgB,GAAG;AAChC,EAAE,KAAK,EAAE,EAAE;AACX,EAAE,OAAO,EAAE,EAAE;AACb,EAAE,KAAK,EAAE,EAAE;AACX;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"en.mjs","sources":["../../../../../../packages/locale/lang/en.ts"],"sourcesContent":["export default {\n name: 'en',\n hzzt: {\n },\n}\n"],"names":[],"mappings":"AAAA,SAAe;AACf,EAAE,IAAI,EAAE,IAAI;AACZ,EAAE,IAAI,EAAE,EAAE;AACV,CAAC;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"zh-cn.mjs","sources":["../../../../../../packages/locale/lang/zh-cn.ts"],"sourcesContent":["export default {\n name: 'zh-cn',\n hzzt: {\n },\n}\n"],"names":[],"mappings":"AAAA,WAAe;AACf,EAAE,IAAI,EAAE,OAAO;AACf,EAAE,IAAI,EAAE,EAAE;AACV,CAAC;;;;"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export { castArray as ensureArray } from 'lodash-unified';
|
|
2
|
+
|
|
3
|
+
const unique = (arr) => [...new Set(arr)];
|
|
4
|
+
const castArray = (arr) => {
|
|
5
|
+
if (!arr && arr !== 0)
|
|
6
|
+
return [];
|
|
7
|
+
return Array.isArray(arr) ? arr : [arr];
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
export { castArray, unique };
|
|
11
|
+
//# sourceMappingURL=arrays.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"arrays.mjs","sources":["../../../../../packages/utils/arrays.ts"],"sourcesContent":["export const unique = <T>(arr: T[]) => [...new Set(arr)]\n\ntype Many<T> = T | ReadonlyArray<T>\n// TODO: rename to `ensureArray`\n/** like `_.castArray`, except falsy value returns empty array. */\nexport const castArray = <T>(arr: Many<T>): T[] => {\n if (!arr && (arr as any) !== 0) return []\n return Array.isArray(arr) ? arr : [arr]\n}\n\n// TODO: remove import alias\n// avoid naming conflicts\nexport { castArray as ensureArray } from 'lodash-unified'\n"],"names":[],"mappings":";;AAAY,MAAC,MAAM,GAAG,CAAC,GAAG,KAAK,CAAC,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,EAAE;AACrC,MAAC,SAAS,GAAG,CAAC,GAAG,KAAK;AAClC,EAAE,IAAI,CAAC,GAAG,IAAI,GAAG,KAAK,CAAC;AACvB,IAAI,OAAO,EAAE,CAAC;AACd,EAAE,OAAO,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;AAC1C;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"browser.mjs","sources":["../../../../../packages/utils/browser.ts"],"sourcesContent":["import { isClient, isIOS } from '@vueuse/core'\n\nexport const isFirefox = (): boolean =>\n isClient && /firefox/i.test(window.navigator.userAgent)\n\nexport { isClient, isIOS }\n"],"names":[],"mappings":";;;AACY,MAAC,SAAS,GAAG,MAAM,QAAQ,IAAI,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS;;;;"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
const FOCUSABLE_ELEMENT_SELECTORS = `a[href],button:not([disabled]),button:not([hidden]),:not([tabindex="-1"]),input:not([disabled]),input:not([type="hidden"]),select:not([disabled]),textarea:not([disabled])`;
|
|
2
|
+
const isVisible = (element) => {
|
|
3
|
+
if (process.env.NODE_ENV === "test")
|
|
4
|
+
return true;
|
|
5
|
+
const computed = getComputedStyle(element);
|
|
6
|
+
return computed.position === "fixed" ? false : element.offsetParent !== null;
|
|
7
|
+
};
|
|
8
|
+
const obtainAllFocusableElements = (element) => {
|
|
9
|
+
return Array.from(element.querySelectorAll(FOCUSABLE_ELEMENT_SELECTORS)).filter((item) => isFocusable(item) && isVisible(item));
|
|
10
|
+
};
|
|
11
|
+
const isFocusable = (element) => {
|
|
12
|
+
if (element.tabIndex > 0 || element.tabIndex === 0 && element.getAttribute("tabIndex") !== null) {
|
|
13
|
+
return true;
|
|
14
|
+
}
|
|
15
|
+
if (element.disabled) {
|
|
16
|
+
return false;
|
|
17
|
+
}
|
|
18
|
+
switch (element.nodeName) {
|
|
19
|
+
case "A": {
|
|
20
|
+
return !!element.href && element.rel !== "ignore";
|
|
21
|
+
}
|
|
22
|
+
case "INPUT": {
|
|
23
|
+
return !(element.type === "hidden" || element.type === "file");
|
|
24
|
+
}
|
|
25
|
+
case "BUTTON":
|
|
26
|
+
case "SELECT":
|
|
27
|
+
case "TEXTAREA": {
|
|
28
|
+
return true;
|
|
29
|
+
}
|
|
30
|
+
default: {
|
|
31
|
+
return false;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
const attemptFocus = (element) => {
|
|
36
|
+
var _a;
|
|
37
|
+
if (!isFocusable(element)) {
|
|
38
|
+
return false;
|
|
39
|
+
}
|
|
40
|
+
(_a = element.focus) == null ? void 0 : _a.call(element);
|
|
41
|
+
return document.activeElement === element;
|
|
42
|
+
};
|
|
43
|
+
const triggerEvent = function(elm, name, ...opts) {
|
|
44
|
+
let eventName;
|
|
45
|
+
if (name.includes("mouse") || name.includes("click")) {
|
|
46
|
+
eventName = "MouseEvents";
|
|
47
|
+
} else if (name.includes("key")) {
|
|
48
|
+
eventName = "KeyboardEvent";
|
|
49
|
+
} else {
|
|
50
|
+
eventName = "HTMLEvents";
|
|
51
|
+
}
|
|
52
|
+
const evt = document.createEvent(eventName);
|
|
53
|
+
evt.initEvent(name, ...opts);
|
|
54
|
+
elm.dispatchEvent(evt);
|
|
55
|
+
return elm;
|
|
56
|
+
};
|
|
57
|
+
const isLeaf = (el) => !el.getAttribute("aria-owns");
|
|
58
|
+
const getSibling = (el, distance, elClass) => {
|
|
59
|
+
const { parentNode } = el;
|
|
60
|
+
if (!parentNode)
|
|
61
|
+
return null;
|
|
62
|
+
const siblings = parentNode.querySelectorAll(elClass);
|
|
63
|
+
const index = Array.prototype.indexOf.call(siblings, el);
|
|
64
|
+
return siblings[index + distance] || null;
|
|
65
|
+
};
|
|
66
|
+
const focusNode = (el) => {
|
|
67
|
+
if (!el)
|
|
68
|
+
return;
|
|
69
|
+
el.focus();
|
|
70
|
+
!isLeaf(el) && el.click();
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
export { attemptFocus, focusNode, getSibling, isFocusable, isLeaf, isVisible, obtainAllFocusableElements, triggerEvent };
|
|
74
|
+
//# sourceMappingURL=aria.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aria.mjs","sources":["../../../../../../packages/utils/dom/aria.ts"],"sourcesContent":["const FOCUSABLE_ELEMENT_SELECTORS = `a[href],button:not([disabled]),button:not([hidden]),:not([tabindex=\"-1\"]),input:not([disabled]),input:not([type=\"hidden\"]),select:not([disabled]),textarea:not([disabled])`\n\n/**\n * Determine if the testing element is visible on screen no matter if its on the viewport or not\n */\nexport const isVisible = (element: HTMLElement) => {\n if (process.env.NODE_ENV === 'test') return true\n const computed = getComputedStyle(element)\n // element.offsetParent won't work on fix positioned\n // WARNING: potential issue here, going to need some expert advices on this issue\n return computed.position === 'fixed' ? false : element.offsetParent !== null\n}\n\nexport const obtainAllFocusableElements = (\n element: HTMLElement\n): HTMLElement[] => {\n return Array.from(\n element.querySelectorAll<HTMLElement>(FOCUSABLE_ELEMENT_SELECTORS)\n ).filter((item: HTMLElement) => isFocusable(item) && isVisible(item))\n}\n\n/**\n * @desc Determine if target element is focusable\n * @param element {HTMLElement}\n * @returns {Boolean} true if it is focusable\n */\nexport const isFocusable = (element: HTMLElement): boolean => {\n if (\n element.tabIndex > 0 ||\n (element.tabIndex === 0 && element.getAttribute('tabIndex') !== null)\n ) {\n return true\n }\n // HTMLButtonElement has disabled\n if ((element as HTMLButtonElement).disabled) {\n return false\n }\n\n switch (element.nodeName) {\n case 'A': {\n // casting current element to Specific HTMLElement in order to be more type precise\n return (\n !!(element as HTMLAnchorElement).href &&\n (element as HTMLAnchorElement).rel !== 'ignore'\n )\n }\n case 'INPUT': {\n return !(\n (element as HTMLInputElement).type === 'hidden' ||\n (element as HTMLInputElement).type === 'file'\n )\n }\n case 'BUTTON':\n case 'SELECT':\n case 'TEXTAREA': {\n return true\n }\n default: {\n return false\n }\n }\n}\n\n/**\n * @desc Set Attempt to set focus on the current node.\n * @param element\n * The node to attempt to focus on.\n * @returns\n * true if element is focused.\n */\nexport const attemptFocus = (element: HTMLElement): boolean => {\n if (!isFocusable(element)) {\n return false\n }\n // Remove the old try catch block since there will be no error to be thrown\n element.focus?.()\n return document.activeElement === element\n}\n\n/**\n * Trigger an event\n * mouseenter, mouseleave, mouseover, keyup, change, click, etc.\n * @param {HTMLElement} elm\n * @param {String} name\n * @param {*} opts\n */\nexport const triggerEvent = function (\n elm: HTMLElement,\n name: string,\n ...opts: Array<boolean>\n): HTMLElement {\n let eventName: string\n\n if (name.includes('mouse') || name.includes('click')) {\n eventName = 'MouseEvents'\n } else if (name.includes('key')) {\n eventName = 'KeyboardEvent'\n } else {\n eventName = 'HTMLEvents'\n }\n const evt = document.createEvent(eventName)\n\n evt.initEvent(name, ...opts)\n elm.dispatchEvent(evt)\n return elm\n}\n\nexport const isLeaf = (el: HTMLElement) => !el.getAttribute('aria-owns')\n\nexport const getSibling = (\n el: HTMLElement,\n distance: number,\n elClass: string\n) => {\n const { parentNode } = el\n if (!parentNode) return null\n const siblings = parentNode.querySelectorAll(elClass)\n const index = Array.prototype.indexOf.call(siblings, el)\n return siblings[index + distance] || null\n}\n\nexport const focusNode = (el: HTMLElement) => {\n if (!el) return\n el.focus()\n !isLeaf(el) && el.click()\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import '../types.mjs';
|
|
2
|
+
import '../browser.mjs';
|
|
3
|
+
import { isClient } from '@vueuse/core';
|
|
4
|
+
import { isString } from '@vue/shared';
|
|
5
|
+
|
|
6
|
+
const getElement = (target) => {
|
|
7
|
+
if (!isClient || target === "")
|
|
8
|
+
return null;
|
|
9
|
+
if (isString(target)) {
|
|
10
|
+
try {
|
|
11
|
+
return document.querySelector(target);
|
|
12
|
+
} catch (e) {
|
|
13
|
+
return null;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
return target;
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
export { getElement };
|
|
20
|
+
//# sourceMappingURL=element.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"element.mjs","sources":["../../../../../../packages/utils/dom/element.ts"],"sourcesContent":["import { isString } from '../types'\nimport { isClient } from '../browser'\n\ntype GetElement = <T extends string | HTMLElement | Window | null | undefined>(\n target: T\n) => T extends string ? HTMLElement | null : T\n\nexport const getElement = ((\n target: string | HTMLElement | Window | null | undefined\n) => {\n if (!isClient || target === '') return null\n if (isString(target)) {\n try {\n return document.querySelector<HTMLElement>(target)\n } catch {\n return null\n }\n }\n return target\n}) as GetElement\n"],"names":[],"mappings":";;;;;AAEY,MAAC,UAAU,GAAG,CAAC,MAAM,KAAK;AACtC,EAAE,IAAI,CAAC,QAAQ,IAAI,MAAM,KAAK,EAAE;AAChC,IAAI,OAAO,IAAI,CAAC;AAChB,EAAE,IAAI,QAAQ,CAAC,MAAM,CAAC,EAAE;AACxB,IAAI,IAAI;AACR,MAAM,OAAO,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;AAC5C,KAAK,CAAC,OAAO,CAAC,EAAE;AAChB,MAAM,OAAO,IAAI,CAAC;AAClB,KAAK;AACL,GAAG;AACH,EAAE,OAAO,MAAM,CAAC;AAChB;;;;"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
const composeEventHandlers = (theirsHandler, oursHandler, { checkForDefaultPrevented = true } = {}) => {
|
|
2
|
+
const handleEvent = (event) => {
|
|
3
|
+
const shouldPrevent = theirsHandler == null ? void 0 : theirsHandler(event);
|
|
4
|
+
if (checkForDefaultPrevented === false || !shouldPrevent) {
|
|
5
|
+
return oursHandler == null ? void 0 : oursHandler(event);
|
|
6
|
+
}
|
|
7
|
+
};
|
|
8
|
+
return handleEvent;
|
|
9
|
+
};
|
|
10
|
+
const whenMouse = (handler) => {
|
|
11
|
+
return (e) => e.pointerType === "mouse" ? handler(e) : void 0;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
export { composeEventHandlers, whenMouse };
|
|
15
|
+
//# sourceMappingURL=event.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event.mjs","sources":["../../../../../../packages/utils/dom/event.ts"],"sourcesContent":["export const composeEventHandlers = <E>(\n theirsHandler?: (event: E) => boolean | void,\n oursHandler?: (event: E) => void,\n { checkForDefaultPrevented = true } = {}\n) => {\n const handleEvent = (event: E) => {\n const shouldPrevent = theirsHandler?.(event)\n\n if (checkForDefaultPrevented === false || !shouldPrevent) {\n return oursHandler?.(event)\n }\n }\n return handleEvent\n}\n\ntype WhenMouseHandler = (e: PointerEvent) => any\nexport const whenMouse = (handler: WhenMouseHandler): WhenMouseHandler => {\n return (e: PointerEvent) =>\n e.pointerType === 'mouse' ? handler(e) : undefined\n}\n"],"names":[],"mappings":"AAAY,MAAC,oBAAoB,GAAG,CAAC,aAAa,EAAE,WAAW,EAAE,EAAE,wBAAwB,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK;AAC9G,EAAE,MAAM,WAAW,GAAG,CAAC,KAAK,KAAK;AACjC,IAAI,MAAM,aAAa,GAAG,aAAa,IAAI,IAAI,GAAG,KAAK,CAAC,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;AAChF,IAAI,IAAI,wBAAwB,KAAK,KAAK,IAAI,CAAC,aAAa,EAAE;AAC9D,MAAM,OAAO,WAAW,IAAI,IAAI,GAAG,KAAK,CAAC,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC;AAC/D,KAAK;AACL,GAAG,CAAC;AACJ,EAAE,OAAO,WAAW,CAAC;AACrB,EAAE;AACU,MAAC,SAAS,GAAG,CAAC,OAAO,KAAK;AACtC,EAAE,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,WAAW,KAAK,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC;AAChE;;;;"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { attemptFocus, focusNode, getSibling, isFocusable, isLeaf, isVisible, obtainAllFocusableElements, triggerEvent } from './aria.mjs';
|
|
2
|
+
export { composeEventHandlers, whenMouse } from './event.mjs';
|
|
3
|
+
export { getClientXY, getOffsetTop, getOffsetTopDistance, isInContainer } from './position.mjs';
|
|
4
|
+
export { animateScrollTo, getScrollBarWidth, getScrollContainer, getScrollElement, getScrollTop, isScroll, scrollIntoView } from './scroll.mjs';
|
|
5
|
+
export { addClass, addUnit, classNameToArray, getStyle, hasClass, removeClass, removeStyle, setStyle } from './style.mjs';
|
|
6
|
+
export { getElement } from './element.mjs';
|
|
7
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import '../browser.mjs';
|
|
2
|
+
import { isClient } from '@vueuse/core';
|
|
3
|
+
|
|
4
|
+
const isInContainer = (el, container) => {
|
|
5
|
+
if (!isClient || !el || !container)
|
|
6
|
+
return false;
|
|
7
|
+
const elRect = el.getBoundingClientRect();
|
|
8
|
+
let containerRect;
|
|
9
|
+
if (container instanceof Element) {
|
|
10
|
+
containerRect = container.getBoundingClientRect();
|
|
11
|
+
} else {
|
|
12
|
+
containerRect = {
|
|
13
|
+
top: 0,
|
|
14
|
+
right: window.innerWidth,
|
|
15
|
+
bottom: window.innerHeight,
|
|
16
|
+
left: 0
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
return elRect.top < containerRect.bottom && elRect.bottom > containerRect.top && elRect.right > containerRect.left && elRect.left < containerRect.right;
|
|
20
|
+
};
|
|
21
|
+
const getOffsetTop = (el) => {
|
|
22
|
+
let offset = 0;
|
|
23
|
+
let parent = el;
|
|
24
|
+
while (parent) {
|
|
25
|
+
offset += parent.offsetTop;
|
|
26
|
+
parent = parent.offsetParent;
|
|
27
|
+
}
|
|
28
|
+
return offset;
|
|
29
|
+
};
|
|
30
|
+
const getOffsetTopDistance = (el, containerEl) => {
|
|
31
|
+
return Math.abs(getOffsetTop(el) - getOffsetTop(containerEl));
|
|
32
|
+
};
|
|
33
|
+
const getClientXY = (event) => {
|
|
34
|
+
let clientX;
|
|
35
|
+
let clientY;
|
|
36
|
+
if (event.type === "touchend") {
|
|
37
|
+
clientY = event.changedTouches[0].clientY;
|
|
38
|
+
clientX = event.changedTouches[0].clientX;
|
|
39
|
+
} else if (event.type.startsWith("touch")) {
|
|
40
|
+
clientY = event.touches[0].clientY;
|
|
41
|
+
clientX = event.touches[0].clientX;
|
|
42
|
+
} else {
|
|
43
|
+
clientY = event.clientY;
|
|
44
|
+
clientX = event.clientX;
|
|
45
|
+
}
|
|
46
|
+
return {
|
|
47
|
+
clientX,
|
|
48
|
+
clientY
|
|
49
|
+
};
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
export { getClientXY, getOffsetTop, getOffsetTopDistance, isInContainer };
|
|
53
|
+
//# sourceMappingURL=position.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"position.mjs","sources":["../../../../../../packages/utils/dom/position.ts"],"sourcesContent":["import { isClient } from '../browser'\n\nexport const isInContainer = (\n el?: Element,\n container?: Element | Window\n): boolean => {\n if (!isClient || !el || !container) return false\n\n const elRect = el.getBoundingClientRect()\n\n let containerRect: Pick<DOMRect, 'top' | 'bottom' | 'left' | 'right'>\n if (container instanceof Element) {\n containerRect = container.getBoundingClientRect()\n } else {\n containerRect = {\n top: 0,\n right: window.innerWidth,\n bottom: window.innerHeight,\n left: 0,\n }\n }\n return (\n elRect.top < containerRect.bottom &&\n elRect.bottom > containerRect.top &&\n elRect.right > containerRect.left &&\n elRect.left < containerRect.right\n )\n}\n\nexport const getOffsetTop = (el: HTMLElement) => {\n let offset = 0\n let parent = el\n\n while (parent) {\n offset += parent.offsetTop\n parent = parent.offsetParent as HTMLElement\n }\n\n return offset\n}\n\nexport const getOffsetTopDistance = (\n el: HTMLElement,\n containerEl: HTMLElement\n) => {\n return Math.abs(getOffsetTop(el) - getOffsetTop(containerEl))\n}\n\nexport const getClientXY = (event: MouseEvent | TouchEvent) => {\n let clientX: number\n let clientY: number\n if (event.type === 'touchend') {\n clientY = (event as TouchEvent).changedTouches[0].clientY\n clientX = (event as TouchEvent).changedTouches[0].clientX\n } else if (event.type.startsWith('touch')) {\n clientY = (event as TouchEvent).touches[0].clientY\n clientX = (event as TouchEvent).touches[0].clientX\n } else {\n clientY = (event as MouseEvent).clientY\n clientX = (event as MouseEvent).clientX\n }\n return {\n clientX,\n clientY,\n }\n}\n"],"names":[],"mappings":";;;AACY,MAAC,aAAa,GAAG,CAAC,EAAE,EAAE,SAAS,KAAK;AAChD,EAAE,IAAI,CAAC,QAAQ,IAAI,CAAC,EAAE,IAAI,CAAC,SAAS;AACpC,IAAI,OAAO,KAAK,CAAC;AACjB,EAAE,MAAM,MAAM,GAAG,EAAE,CAAC,qBAAqB,EAAE,CAAC;AAC5C,EAAE,IAAI,aAAa,CAAC;AACpB,EAAE,IAAI,SAAS,YAAY,OAAO,EAAE;AACpC,IAAI,aAAa,GAAG,SAAS,CAAC,qBAAqB,EAAE,CAAC;AACtD,GAAG,MAAM;AACT,IAAI,aAAa,GAAG;AACpB,MAAM,GAAG,EAAE,CAAC;AACZ,MAAM,KAAK,EAAE,MAAM,CAAC,UAAU;AAC9B,MAAM,MAAM,EAAE,MAAM,CAAC,WAAW;AAChC,MAAM,IAAI,EAAE,CAAC;AACb,KAAK,CAAC;AACN,GAAG;AACH,EAAE,OAAO,MAAM,CAAC,GAAG,GAAG,aAAa,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,GAAG,aAAa,CAAC,GAAG,IAAI,MAAM,CAAC,KAAK,GAAG,aAAa,CAAC,IAAI,IAAI,MAAM,CAAC,IAAI,GAAG,aAAa,CAAC,KAAK,CAAC;AAC1J,EAAE;AACU,MAAC,YAAY,GAAG,CAAC,EAAE,KAAK;AACpC,EAAE,IAAI,MAAM,GAAG,CAAC,CAAC;AACjB,EAAE,IAAI,MAAM,GAAG,EAAE,CAAC;AAClB,EAAE,OAAO,MAAM,EAAE;AACjB,IAAI,MAAM,IAAI,MAAM,CAAC,SAAS,CAAC;AAC/B,IAAI,MAAM,GAAG,MAAM,CAAC,YAAY,CAAC;AACjC,GAAG;AACH,EAAE,OAAO,MAAM,CAAC;AAChB,EAAE;AACU,MAAC,oBAAoB,GAAG,CAAC,EAAE,EAAE,WAAW,KAAK;AACzD,EAAE,OAAO,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,WAAW,CAAC,CAAC,CAAC;AAChE,EAAE;AACU,MAAC,WAAW,GAAG,CAAC,KAAK,KAAK;AACtC,EAAE,IAAI,OAAO,CAAC;AACd,EAAE,IAAI,OAAO,CAAC;AACd,EAAE,IAAI,KAAK,CAAC,IAAI,KAAK,UAAU,EAAE;AACjC,IAAI,OAAO,GAAG,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;AAC9C,IAAI,OAAO,GAAG,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;AAC9C,GAAG,MAAM,IAAI,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE;AAC7C,IAAI,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;AACvC,IAAI,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;AACvC,GAAG,MAAM;AACT,IAAI,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;AAC5B,IAAI,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;AAC5B,GAAG;AACH,EAAE,OAAO;AACT,IAAI,OAAO;AACX,IAAI,OAAO;AACX,GAAG,CAAC;AACJ;;;;"}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import '../browser.mjs';
|
|
2
|
+
import { easeInOutCubic } from '../easings.mjs';
|
|
3
|
+
import { isWindow } from '../types.mjs';
|
|
4
|
+
import { rAF, cAF } from '../raf.mjs';
|
|
5
|
+
import { getStyle } from './style.mjs';
|
|
6
|
+
import { isClient } from '@vueuse/core';
|
|
7
|
+
|
|
8
|
+
const isScroll = (el, isVertical) => {
|
|
9
|
+
if (!isClient)
|
|
10
|
+
return false;
|
|
11
|
+
const key = {
|
|
12
|
+
undefined: "overflow",
|
|
13
|
+
true: "overflow-y",
|
|
14
|
+
false: "overflow-x"
|
|
15
|
+
}[String(isVertical)];
|
|
16
|
+
const overflow = getStyle(el, key);
|
|
17
|
+
return ["scroll", "auto", "overlay"].some((s) => overflow.includes(s));
|
|
18
|
+
};
|
|
19
|
+
const getScrollContainer = (el, isVertical) => {
|
|
20
|
+
if (!isClient)
|
|
21
|
+
return;
|
|
22
|
+
let parent = el;
|
|
23
|
+
while (parent) {
|
|
24
|
+
if ([window, document, document.documentElement].includes(parent))
|
|
25
|
+
return window;
|
|
26
|
+
if (isScroll(parent, isVertical))
|
|
27
|
+
return parent;
|
|
28
|
+
parent = parent.parentNode;
|
|
29
|
+
}
|
|
30
|
+
return parent;
|
|
31
|
+
};
|
|
32
|
+
let scrollBarWidth;
|
|
33
|
+
const getScrollBarWidth = (namespace) => {
|
|
34
|
+
var _a;
|
|
35
|
+
if (!isClient)
|
|
36
|
+
return 0;
|
|
37
|
+
if (scrollBarWidth !== void 0)
|
|
38
|
+
return scrollBarWidth;
|
|
39
|
+
const outer = document.createElement("div");
|
|
40
|
+
outer.className = `${namespace}-scrollbar__wrap`;
|
|
41
|
+
outer.style.visibility = "hidden";
|
|
42
|
+
outer.style.width = "100px";
|
|
43
|
+
outer.style.position = "absolute";
|
|
44
|
+
outer.style.top = "-9999px";
|
|
45
|
+
document.body.appendChild(outer);
|
|
46
|
+
const widthNoScroll = outer.offsetWidth;
|
|
47
|
+
outer.style.overflow = "scroll";
|
|
48
|
+
const inner = document.createElement("div");
|
|
49
|
+
inner.style.width = "100%";
|
|
50
|
+
outer.appendChild(inner);
|
|
51
|
+
const widthWithScroll = inner.offsetWidth;
|
|
52
|
+
(_a = outer.parentNode) == null ? void 0 : _a.removeChild(outer);
|
|
53
|
+
scrollBarWidth = widthNoScroll - widthWithScroll;
|
|
54
|
+
return scrollBarWidth;
|
|
55
|
+
};
|
|
56
|
+
function scrollIntoView(container, selected) {
|
|
57
|
+
if (!isClient)
|
|
58
|
+
return;
|
|
59
|
+
if (!selected) {
|
|
60
|
+
container.scrollTop = 0;
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
const offsetParents = [];
|
|
64
|
+
let pointer = selected.offsetParent;
|
|
65
|
+
while (pointer !== null && container !== pointer && container.contains(pointer)) {
|
|
66
|
+
offsetParents.push(pointer);
|
|
67
|
+
pointer = pointer.offsetParent;
|
|
68
|
+
}
|
|
69
|
+
const top = selected.offsetTop + offsetParents.reduce((prev, curr) => prev + curr.offsetTop, 0);
|
|
70
|
+
const bottom = top + selected.offsetHeight;
|
|
71
|
+
const viewRectTop = container.scrollTop;
|
|
72
|
+
const viewRectBottom = viewRectTop + container.clientHeight;
|
|
73
|
+
if (top < viewRectTop) {
|
|
74
|
+
container.scrollTop = top;
|
|
75
|
+
} else if (bottom > viewRectBottom) {
|
|
76
|
+
container.scrollTop = bottom - container.clientHeight;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
function animateScrollTo(container, from, to, duration, callback) {
|
|
80
|
+
const startTime = Date.now();
|
|
81
|
+
let handle;
|
|
82
|
+
const scroll = () => {
|
|
83
|
+
const timestamp = Date.now();
|
|
84
|
+
const time = timestamp - startTime;
|
|
85
|
+
const nextScrollTop = easeInOutCubic(time > duration ? duration : time, from, to, duration);
|
|
86
|
+
if (isWindow(container)) {
|
|
87
|
+
container.scrollTo(window.pageXOffset, nextScrollTop);
|
|
88
|
+
} else {
|
|
89
|
+
container.scrollTop = nextScrollTop;
|
|
90
|
+
}
|
|
91
|
+
if (time < duration) {
|
|
92
|
+
handle = rAF(scroll);
|
|
93
|
+
} else if (typeof callback === "function") {
|
|
94
|
+
callback();
|
|
95
|
+
}
|
|
96
|
+
};
|
|
97
|
+
scroll();
|
|
98
|
+
return () => {
|
|
99
|
+
handle && cAF(handle);
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
const getScrollElement = (target, container) => {
|
|
103
|
+
if (isWindow(container)) {
|
|
104
|
+
return target.ownerDocument.documentElement;
|
|
105
|
+
}
|
|
106
|
+
return container;
|
|
107
|
+
};
|
|
108
|
+
const getScrollTop = (container) => {
|
|
109
|
+
if (isWindow(container)) {
|
|
110
|
+
return window.scrollY;
|
|
111
|
+
}
|
|
112
|
+
return container.scrollTop;
|
|
113
|
+
};
|
|
114
|
+
|
|
115
|
+
export { animateScrollTo, getScrollBarWidth, getScrollContainer, getScrollElement, getScrollTop, isScroll, scrollIntoView };
|
|
116
|
+
//# sourceMappingURL=scroll.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scroll.mjs","sources":["../../../../../../packages/utils/dom/scroll.ts"],"sourcesContent":["import { isClient } from '../browser'\nimport { easeInOutCubic } from '../easings'\nimport { isWindow } from '../types'\nimport { cAF, rAF } from '../raf'\nimport { getStyle } from './style'\n\nexport const isScroll = (el: HTMLElement, isVertical?: boolean): boolean => {\n if (!isClient) return false\n\n const key = (\n {\n undefined: 'overflow',\n true: 'overflow-y',\n false: 'overflow-x',\n } as const\n )[String(isVertical)]!\n const overflow = getStyle(el, key)\n return ['scroll', 'auto', 'overlay'].some((s) => overflow.includes(s))\n}\n\nexport const getScrollContainer = (\n el: HTMLElement,\n isVertical?: boolean\n): Window | HTMLElement | undefined => {\n if (!isClient) return\n\n let parent: HTMLElement = el\n while (parent) {\n if ([window, document, document.documentElement].includes(parent))\n return window\n\n if (isScroll(parent, isVertical)) return parent\n\n parent = parent.parentNode as HTMLElement\n }\n\n return parent\n}\n\nlet scrollBarWidth: number\nexport const getScrollBarWidth = (namespace: string): number => {\n if (!isClient) return 0\n if (scrollBarWidth !== undefined) return scrollBarWidth\n\n const outer = document.createElement('div')\n outer.className = `${namespace}-scrollbar__wrap`\n outer.style.visibility = 'hidden'\n outer.style.width = '100px'\n outer.style.position = 'absolute'\n outer.style.top = '-9999px'\n document.body.appendChild(outer)\n\n const widthNoScroll = outer.offsetWidth\n outer.style.overflow = 'scroll'\n\n const inner = document.createElement('div')\n inner.style.width = '100%'\n outer.appendChild(inner)\n\n const widthWithScroll = inner.offsetWidth\n outer.parentNode?.removeChild(outer)\n scrollBarWidth = widthNoScroll - widthWithScroll\n\n return scrollBarWidth\n}\n\n/**\n * Scroll with in the container element, positioning the **selected** element at the top\n * of the container\n */\nexport function scrollIntoView(\n container: HTMLElement,\n selected: HTMLElement\n): void {\n if (!isClient) return\n\n if (!selected) {\n container.scrollTop = 0\n return\n }\n\n const offsetParents: HTMLElement[] = []\n let pointer = selected.offsetParent\n while (\n pointer !== null &&\n container !== pointer &&\n container.contains(pointer)\n ) {\n offsetParents.push(pointer as HTMLElement)\n pointer = (pointer as HTMLElement).offsetParent\n }\n const top =\n selected.offsetTop +\n offsetParents.reduce((prev, curr) => prev + curr.offsetTop, 0)\n const bottom = top + selected.offsetHeight\n const viewRectTop = container.scrollTop\n const viewRectBottom = viewRectTop + container.clientHeight\n\n if (top < viewRectTop) {\n container.scrollTop = top\n } else if (bottom > viewRectBottom) {\n container.scrollTop = bottom - container.clientHeight\n }\n}\n\nexport function animateScrollTo(\n container: HTMLElement | Window,\n from: number,\n to: number,\n duration: number,\n callback?: unknown\n) {\n const startTime = Date.now()\n\n let handle: number | undefined\n const scroll = () => {\n const timestamp = Date.now()\n const time = timestamp - startTime\n const nextScrollTop = easeInOutCubic(\n time > duration ? duration : time,\n from,\n to,\n duration\n )\n\n if (isWindow(container)) {\n container.scrollTo(window.pageXOffset, nextScrollTop)\n } else {\n container.scrollTop = nextScrollTop\n }\n if (time < duration) {\n handle = rAF(scroll)\n } else if (typeof callback === 'function') {\n callback()\n }\n }\n\n scroll()\n\n return () => {\n handle && cAF(handle)\n }\n}\n\nexport const getScrollElement = (\n target: HTMLElement,\n container: HTMLElement | Window\n) => {\n if (isWindow(container)) {\n return target.ownerDocument.documentElement\n }\n return container\n}\n\nexport const getScrollTop = (container: HTMLElement | Window) => {\n if (isWindow(container)) {\n return window.scrollY\n }\n return container.scrollTop\n}\n"],"names":[],"mappings":"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"}
|