From f21a528ea0e88ec8592a04084d5334e3525505a5 Mon Sep 17 00:00:00 2001 From: catouse Date: Fri, 2 Aug 2024 05:41:48 +0000 Subject: [PATCH] deploy: 72c2169fcca047715e16bcf0a87f10dc0a398dea --- dev/404.html | 6 ++-- ...kD.js => guide_start_index.md.9ipcmLFp.js} | 26 +++++++++--------- ... => guide_start_index.md.9ipcmLFp.lean.js} | 26 +++++++++--------- dev/guide/config/base/color.html | 6 ++-- dev/guide/config/base/font.html | 6 ++-- dev/guide/config/base/rounded.html | 6 ++-- dev/guide/config/base/screens.html | 6 ++-- dev/guide/config/base/shadow.html | 6 ++-- dev/guide/config/base/spacing.html | 6 ++-- dev/guide/customize/build.html | 6 ++-- dev/guide/customize/dev.html | 6 ++-- dev/guide/customize/exts-lib.html | 6 ++-- dev/guide/index.html | 6 ++-- dev/guide/start/compatibility.html | 6 ++-- dev/guide/start/index.html | 10 +++---- dev/guide/start/intro.html | 6 ++-- dev/guide/start/tutorial.html | 6 ++-- dev/hashmap.json | 2 +- dev/index.html | 6 ++-- dev/lib/basic/core/cash.html | 6 ++-- dev/lib/basic/core/component.html | 10 +++---- dev/lib/basic/core/css-component.html | 8 +++--- dev/lib/basic/core/react.html | 6 ++-- dev/lib/basic/core/zui-create.html | 6 ++-- dev/lib/basic/core/zui-on.html | 6 ++-- dev/lib/basic/core/zui-toggle.html | 6 ++-- dev/lib/components/alert/index.html | 6 ++-- dev/lib/components/avatar-group/index.html | 8 +++--- dev/lib/components/avatar/index.html | 8 +++--- dev/lib/components/breadcrumb/index.html | 6 ++-- dev/lib/components/btn-group/index.html | 8 +++--- dev/lib/components/button/index.html | 8 +++--- dev/lib/components/color-picker/index.html | 8 +++--- dev/lib/components/contextmenu/index.html | 6 ++-- dev/lib/components/dashboard/index.html | 6 ++-- dev/lib/components/dropdown/index.html | 6 ++-- dev/lib/components/dtable/index.html | 6 ++-- dev/lib/components/dtable/plugins.html | 6 ++-- dev/lib/components/file-selector/index.html | 8 +++--- dev/lib/components/kanban/index.html | 6 ++-- dev/lib/components/label/index.html | 8 +++--- dev/lib/components/menu/index.html | 8 +++--- dev/lib/components/menu/js.html | 6 ++-- dev/lib/components/messager/index.html | 8 +++--- dev/lib/components/modal/index.html | 8 +++--- dev/lib/components/modal/trigger.html | 6 ++-- dev/lib/components/nav/index.html | 10 +++---- dev/lib/components/nav/js.html | 6 ++-- dev/lib/components/pager/index.html | 8 +++--- dev/lib/components/pager/js.html | 6 ++-- dev/lib/components/panel/index.html | 8 +++--- dev/lib/components/progress-circle/index.html | 8 +++--- dev/lib/components/progress/index.html | 8 +++--- dev/lib/components/scrollbar/index.html | 8 +++--- dev/lib/components/search-box/index.html | 8 +++--- dev/lib/components/table/index.html | 10 +++---- dev/lib/components/tabs/index.html | 8 +++--- dev/lib/components/toolbar/index.html | 8 +++--- dev/lib/components/toolbar/js.html | 6 ++-- dev/lib/components/tooltip/index.html | 8 +++--- dev/lib/components/tree/index.html | 6 ++-- dev/lib/components/upload-imgs/index.html | 6 ++-- dev/lib/components/upload/index.html | 6 ++-- dev/lib/forms/checkbox/index.html | 8 +++--- dev/lib/forms/checkbox/switch.html | 8 +++--- dev/lib/forms/datetime-picker/date.html | 8 +++--- dev/lib/forms/datetime-picker/datetime.html | 8 +++--- dev/lib/forms/datetime-picker/time.html | 8 +++--- dev/lib/forms/form-control/index.html | 8 +++--- dev/lib/forms/form/index.html | 6 ++-- dev/lib/forms/input-control/index.html | 8 +++--- dev/lib/forms/input-group/index.html | 8 +++--- dev/lib/forms/picker/index.html | 8 +++--- dev/lib/helpers/helpers/date-helper.html | 6 ++-- dev/lib/helpers/helpers/string-helper.html | 6 ++-- dev/lib/helpers/store/index.html | 6 ++-- dev/lib/index.html | 6 ++-- dev/public/zui/icons/fontawesome-license.html | 6 ++-- dev/themes/index.html | 6 ++-- .../backgrounds/utilities/index.html | 6 ++-- .../borders/utilities/border-color.html | 6 ++-- .../borders/utilities/border-radius.html | 6 ++-- .../borders/utilities/border-width.html | 6 ++-- dev/utilities/borders/utilities/divider.html | 6 ++-- .../borders/utilities/ring-color.html | 6 ++-- .../borders/utilities/ring-offset.html | 6 ++-- .../borders/utilities/ring-width.html | 6 ++-- .../effects/utilities/animation.html | 6 ++-- dev/utilities/effects/utilities/filter.html | 6 ++-- dev/utilities/effects/utilities/opacity.html | 6 ++-- dev/utilities/effects/utilities/shadow.html | 6 ++-- .../effects/utilities/transform.html | 6 ++-- .../effects/utilities/transition.html | 6 ++-- .../flex/utilities/align-content.html | 6 ++-- dev/utilities/flex/utilities/align-items.html | 6 ++-- dev/utilities/flex/utilities/align-self.html | 6 ++-- dev/utilities/flex/utilities/basis.html | 6 ++-- dev/utilities/flex/utilities/direction.html | 6 ++-- dev/utilities/flex/utilities/flex.html | 6 ++-- dev/utilities/flex/utilities/gap.html | 6 ++-- dev/utilities/flex/utilities/grow.html | 6 ++-- .../flex/utilities/justify-content.html | 6 ++-- dev/utilities/flex/utilities/order.html | 6 ++-- dev/utilities/flex/utilities/shrink.html | 6 ++-- dev/utilities/flex/utilities/wrap.html | 6 ++-- dev/utilities/index.html | 6 ++-- .../interactivity/utilities/cursor.html | 8 +++--- .../interactivity/utilities/disabled.html | 8 +++--- .../interactivity/utilities/loading.html | 8 +++--- .../utilities/pointer-events.html | 8 +++--- .../interactivity/utilities/scroll.html | 6 ++-- .../interactivity/utilities/state.html | 8 +++--- .../interactivity/utilities/user-select.html | 8 +++--- .../layout/utilities/aspect-ratio.html | 8 +++--- dev/utilities/layout/utilities/container.html | 8 +++--- dev/utilities/layout/utilities/display.html | 6 ++-- dev/utilities/layout/utilities/floats.html | 8 +++--- .../layout/utilities/object-fit.html | 8 +++--- dev/utilities/layout/utilities/overflow.html | 8 +++--- dev/utilities/layout/utilities/position.html | 8 +++--- .../utilities/top-right-bottom-left.html | 8 +++--- .../layout/utilities/visibility.html | 8 +++--- dev/utilities/layout/utilities/z-index.html | 8 +++--- dev/utilities/sizing/utilities/height.html | 6 ++-- dev/utilities/sizing/utilities/width.html | 6 ++-- dev/utilities/skin/utilities/ghost.html | 8 +++--- dev/utilities/skin/utilities/outline.html | 8 +++--- dev/utilities/skin/utilities/pale.html | 8 +++--- dev/utilities/skin/utilities/solid.html | 8 +++--- dev/utilities/skin/utilities/surface.html | 8 +++--- dev/utilities/spacing/utilities/margin.html | 8 +++--- dev/utilities/spacing/utilities/padding.html | 8 +++--- dev/utilities/spacing/utilities/space.html | 8 +++--- .../typography/utilities/font-family.html | 8 +++--- .../typography/utilities/font-size.html | 8 +++--- .../typography/utilities/font-weight.html | 8 +++--- .../typography/utilities/leading.html | 8 +++--- .../typography/utilities/line-clamp.html | 8 +++--- .../typography/utilities/list-style.html | 8 +++--- .../typography/utilities/text-align.html | 8 +++--- .../typography/utilities/text-color.html | 6 ++-- .../typography/utilities/text-decoration.html | 8 +++--- .../typography/utilities/text-overflow.html | 8 +++--- .../typography/utilities/text-transform.html | 8 +++--- .../typography/utilities/vertical-align.html | 8 +++--- .../typography/utilities/whitespace.html | 14 +++++----- .../typography/utilities/word-break.html | 12 ++++---- dev/zui-3.0.0.zip | Bin 983785 -> 983804 bytes dev/zui/zui.esm.js | 4 +-- dev/zui/zui.esm.js.map | 2 +- dev/zui/zui.js | 2 +- dev/zui/zui.js.map | 2 +- 152 files changed, 542 insertions(+), 542 deletions(-) rename dev/assets/{guide_start_index.md.CCziB0kD.js => guide_start_index.md.9ipcmLFp.js} (95%) rename dev/assets/{guide_start_index.md.CCziB0kD.lean.js => guide_start_index.md.9ipcmLFp.lean.js} (89%) diff --git a/dev/404.html b/dev/404.html index 4493599c25..e8e600db02 100644 --- a/dev/404.html +++ b/dev/404.html @@ -11,14 +11,14 @@ - - + +
Skip to content

404

PAGE NOT FOUND

But if you don't change your direction, and if you keep looking, you may end up where you are heading.

MIT License (MIT)

- + \ No newline at end of file diff --git a/dev/assets/guide_start_index.md.CCziB0kD.js b/dev/assets/guide_start_index.md.9ipcmLFp.js similarity index 95% rename from dev/assets/guide_start_index.md.CCziB0kD.js rename to dev/assets/guide_start_index.md.9ipcmLFp.js index c05385f4b1..583daaadbf 100644 --- a/dev/assets/guide_start_index.md.CCziB0kD.js +++ b/dev/assets/guide_start_index.md.9ipcmLFp.js @@ -14,7 +14,7 @@ import{c as d,k as s,m as r,a as i,t as l,I as h,w as n,R as a,D as p,o as g,f a <a class="btn" href="/">访问 ZUI 网站</a> <script src="./zui/zui.js"></script> </body> -</html>

使用 CDN

使用 CDN 可以快速使用 ZUI,与下载使用基本一样,只需要将相关资源文件替换为 CDN 上的地址即可:

`,6),m={class:"vp-code-group vp-adaptive-theme"},B=a('
',1),b={class:"blocks"},v={class:"language-html vp-adaptive-theme active"},S=s("button",{title:"Copy Code",class:"copy"},null,-1),I=s("span",{class:"lang"},"html",-1),q={class:"shiki shiki-themes github-light github-dark vp-code"},P=a('<!doctype html>',1),z=a('<html lang="zh-CN">',1),V=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"head"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),f=a(' <meta charset="utf-8">',1),N=a(' <meta name="viewport" content="width=device-width, initial-scale=1">',1),w=a(' <title>ZUI</title>',1),R={class:"line highlighted"},x=a(' <link rel="stylesheet" href=',7),U={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},j=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">",-1),Z=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," ")],-1),M=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"body"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),J=a(' <h1>ZUI is awesome!</h1>',1),H=a(' <a class="btn" href="/">访问 ZUI 网站</a>',1),Y={class:"line highlighted"},$=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <",-1),W=s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"script",-1),L=s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," src",-1),O=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"=",-1),Q={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},G=a(' crossorigin="anonymous"></script>',6),K=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," ")],-1),X=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"")],-1),ss={class:"language-html vp-adaptive-theme"},is=s("button",{title:"Copy Code",class:"copy"},null,-1),as=s("span",{class:"lang"},"html",-1),ts={class:"shiki shiki-themes github-light github-dark vp-code"},hs=a('<!doctype html>',1),ns=a('<html lang="zh-CN">',1),ls=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"head"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),ks=a(' <meta charset="utf-8">',1),ps=a(' <meta name="viewport" content="width=device-width, initial-scale=1">',1),es=a(' <title>ZUI</title>',1),Es={class:"line highlighted"},ds=a(' <link rel="stylesheet" href=',7),rs={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},gs=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">",-1),_s=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," ")],-1),os=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"body"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),ys=a(' <h1>ZUI is awesome!</h1>',1),cs=a(' <a class="btn" href="/">访问 ZUI 网站</a>',1),Fs={class:"line highlighted"},us=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <",-1),Cs=s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"script",-1),As=s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," src",-1),Ts=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"=",-1),Ds={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},ms=a(' crossorigin="anonymous"></script>',6),Bs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," ")],-1),bs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"")],-1),vs={class:"language-html vp-adaptive-theme"},Ss=s("button",{title:"Copy Code",class:"copy"},null,-1),Is=s("span",{class:"lang"},"html",-1),qs={class:"shiki shiki-themes github-light github-dark vp-code"},Ps=a('<!doctype html>',1),zs=a('<html lang="zh-CN">',1),Vs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"head"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),fs=a(' <meta charset="utf-8">',1),Ns=a(' <meta name="viewport" content="width=device-width, initial-scale=1">',1),ws=a(' <title>ZUI</title>',1),Rs={class:"line highlighted"},xs=a(' <link rel="stylesheet" href=',7),Us={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},js=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">",-1),Zs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," ")],-1),Ms=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"body"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),Js=a(' <h1>ZUI is awesome!</h1>',1),Hs=a(' <a class="btn" href="/">访问 ZUI 网站</a>',1),Ys={class:"line highlighted"},$s=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <",-1),Ws=s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"script",-1),Ls=s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," src",-1),Os=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"=",-1),Qs={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},Gs=a(' crossorigin="anonymous"></script>',6),Ks=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," ")],-1),Xs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"")],-1),si=a(`

使用 JS 组件

无论是下载还是使用 CDN,导入 zui.js 之后,你就可以使用 ZUI 中的 JS 组件了,ZUI 提供的所有 JS 辅助方法和组件类都在全局对象 zui 上进行访问,例如:

html
<nav id="myNav"></nav>
+</html>

使用 CDN

使用 CDN 可以快速使用 ZUI,与下载使用基本一样,只需要将相关资源文件替换为 CDN 上的地址即可:

`,6),m={class:"vp-code-group vp-adaptive-theme"},B=a('
',1),b={class:"blocks"},v={class:"language-html vp-adaptive-theme active"},S=s("button",{title:"Copy Code",class:"copy"},null,-1),I=s("span",{class:"lang"},"html",-1),q={class:"shiki shiki-themes github-light github-dark vp-code"},P=a('<!doctype html>',1),z=a('<html lang="zh-CN">',1),V=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"head"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),f=a(' <meta charset="utf-8">',1),N=a(' <meta name="viewport" content="width=device-width, initial-scale=1">',1),R=a(' <title>ZUI</title>',1),w={class:"line highlighted"},j=a(' <link rel="stylesheet" href=',7),Z={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},U=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">",-1),x=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," ")],-1),M=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"body"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),H=a(' <h1>ZUI is awesome!</h1>',1),J=a(' <a class="btn" href="/">访问 ZUI 网站</a>',1),Y={class:"line highlighted"},$=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <",-1),K=s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"script",-1),L=s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," src",-1),O=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"=",-1),Q={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},W=a(' crossorigin="anonymous"></script>',6),G=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," ")],-1),X=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"")],-1),ss={class:"language-html vp-adaptive-theme"},is=s("button",{title:"Copy Code",class:"copy"},null,-1),as=s("span",{class:"lang"},"html",-1),ts={class:"shiki shiki-themes github-light github-dark vp-code"},hs=a('<!doctype html>',1),ns=a('<html lang="zh-CN">',1),ls=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"head"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),ks=a(' <meta charset="utf-8">',1),ps=a(' <meta name="viewport" content="width=device-width, initial-scale=1">',1),es=a(' <title>ZUI</title>',1),Es={class:"line highlighted"},ds=a(' <link rel="stylesheet" href=',7),rs={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},gs=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">",-1),_s=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," ")],-1),os=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"body"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),ys=a(' <h1>ZUI is awesome!</h1>',1),cs=a(' <a class="btn" href="/">访问 ZUI 网站</a>',1),Fs={class:"line highlighted"},us=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <",-1),Cs=s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"script",-1),As=s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," src",-1),Ts=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"=",-1),Ds={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},ms=a(' crossorigin="anonymous"></script>',6),Bs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," ")],-1),bs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"")],-1),vs={class:"language-html vp-adaptive-theme"},Ss=s("button",{title:"Copy Code",class:"copy"},null,-1),Is=s("span",{class:"lang"},"html",-1),qs={class:"shiki shiki-themes github-light github-dark vp-code"},Ps=a('<!doctype html>',1),zs=a('<html lang="zh-CN">',1),Vs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"head"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),fs=a(' <meta charset="utf-8">',1),Ns=a(' <meta name="viewport" content="width=device-width, initial-scale=1">',1),Rs=a(' <title>ZUI</title>',1),ws={class:"line highlighted"},js=a(' <link rel="stylesheet" href=',7),Zs={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},Us=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">",-1),xs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," ")],-1),Ms=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"body"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),Hs=a(' <h1>ZUI is awesome!</h1>',1),Js=a(' <a class="btn" href="/">访问 ZUI 网站</a>',1),Ys={class:"line highlighted"},$s=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," <",-1),Ks=s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"script",-1),Ls=s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," src",-1),Os=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"=",-1),Qs={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},Ws=a(' crossorigin="anonymous"></script>',6),Gs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}}," ")],-1),Xs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"")],-1),si=a(`

使用 JS 组件

无论是下载还是使用 CDN,导入 zui.js 之后,你就可以使用 ZUI 中的 JS 组件了,ZUI 提供的所有 JS 辅助方法和组件类都在全局对象 zui 上进行访问,例如:

html
<nav id="myNav"></nav>
 
 <script>
 const {Nav, Messager} = zui;
@@ -56,14 +56,14 @@ import{c as d,k as s,m as r,a as i,t as l,I as h,w as n,R as a,D as p,o as g,f a
 `),V,i(`
 `),f,i(`
 `),N,i(`
-`),w,i(`
-`),s("span",R,[x,s("span",U,'"///cdn.jsdelivr.net/npm/zui/dist/'+l(t.zui.version)+'/zui.css"',1),j]),i(`
-`),Z,i(`
+`),R,i(`
+`),s("span",w,[j,s("span",Z,'"///cdn.jsdelivr.net/npm/zui/dist/'+l(t.zui.version)+'/zui.css"',1),U]),i(`
+`),x,i(`
 `),M,i(`
-`),J,i(`
 `),H,i(`
-`),s("span",Y,[$,W,L,O,s("span",Q,'"///cdn.jsdelivr.net/npm/zui/dist/'+l(t.zui.version)+'/zui.js"',1),G]),i(`
-`),K,i(`
+`),J,i(`
+`),s("span",Y,[$,K,L,O,s("span",Q,'"///cdn.jsdelivr.net/npm/zui/dist/'+l(t.zui.version)+'/zui.js"',1),W]),i(`
+`),G,i(`
 `),X])])]),s("div",ss,[is,as,s("pre",ts,[s("code",null,[hs,i(`
 `),ns,i(`
 `),ls,i(`
@@ -82,12 +82,12 @@ import{c as d,k as s,m as r,a as i,t as l,I as h,w as n,R as a,D as p,o as g,f a
 `),Vs,i(`
 `),fs,i(`
 `),Ns,i(`
-`),ws,i(`
-`),s("span",Rs,[xs,s("span",Us,'"///unpkg.com/zui@'+l(t.zui.version)+'/zui.css"',1),js]),i(`
-`),Zs,i(`
+`),Rs,i(`
+`),s("span",ws,[js,s("span",Zs,'"///unpkg.com/zui@'+l(t.zui.version)+'/zui.css"',1),Us]),i(`
+`),xs,i(`
 `),Ms,i(`
-`),Js,i(`
 `),Hs,i(`
-`),s("span",Ys,[$s,Ws,Ls,Os,s("span",Qs,'"///unpkg.com/zui@'+l(t.zui.version)+'/zui.js"',1),Gs]),i(`
-`),Ks,i(`
+`),Js,i(`
+`),s("span",Ys,[$s,Ks,Ls,Os,s("span",Qs,'"///unpkg.com/zui@'+l(t.zui.version)+'/zui.js"',1),Ws]),i(`
+`),Gs,i(`
 `),Xs])])])])]),si,h(E,null,{default:n(()=>[h(k,{label:"示例"},{default:n(()=>[h(e,null,{default:n(()=>[ii]),_:1})]),_:1}),h(k,{label:"HTML"},{default:n(()=>[ai]),_:1})]),_:1}),ti,h(E,null,{default:n(()=>[h(k,{label:"示例"},{default:n(()=>[h(e,null,{default:n(()=>[hi]),_:1})]),_:1}),h(k,{label:"HTML"},{default:n(()=>[ni]),_:1})]),_:1}),li])}}});export{di as __pageData,ri as default};
diff --git a/dev/assets/guide_start_index.md.CCziB0kD.lean.js b/dev/assets/guide_start_index.md.9ipcmLFp.lean.js
similarity index 89%
rename from dev/assets/guide_start_index.md.CCziB0kD.lean.js
rename to dev/assets/guide_start_index.md.9ipcmLFp.lean.js
index 142a08e326..ed865518a4 100644
--- a/dev/assets/guide_start_index.md.CCziB0kD.lean.js
+++ b/dev/assets/guide_start_index.md.9ipcmLFp.lean.js
@@ -1,4 +1,4 @@
-import{c as d,k as s,m as r,a as i,t as l,I as h,w as n,R as a,D as p,o as g,f as _}from"./chunks/framework.DeE3OwZJ.js";const o=s("h1",{id:"快速上手",tabindex:"-1"},[i("快速上手 "),s("a",{class:"header-anchor",href:"#快速上手","aria-label":'Permalink to "快速上手"'},"​")],-1),y=s("h2",{id:"下载使用",tabindex:"-1"},[i("下载使用 "),s("a",{class:"header-anchor",href:"#下载使用","aria-label":'Permalink to "下载使用"'},"​")],-1),c=s("p",null,"你可以从如下地址下载 ZUI 的最新版本:",-1),F={class:"gap-4 vp-raw row"},u=["href"],C=s("i",{class:"icon icon-download-alt icon-lg"},null,-1),A=["href"],T=s("i",{class:"icon icon-github icon-lg"},null,-1),D=a("",6),m={class:"vp-code-group vp-adaptive-theme"},B=a("",1),b={class:"blocks"},v={class:"language-html vp-adaptive-theme active"},S=s("button",{title:"Copy Code",class:"copy"},null,-1),I=s("span",{class:"lang"},"html",-1),q={class:"shiki shiki-themes github-light github-dark vp-code"},P=a("",1),z=a("",1),V=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"head"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),f=a("",1),N=a("",1),w=a("",1),R={class:"line highlighted"},x=a("",7),U={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},j=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">",-1),Z=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  ")],-1),M=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"body"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),J=a("",1),H=a("",1),Y={class:"line highlighted"},$=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"    <",-1),W=s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"script",-1),L=s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," src",-1),O=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"=",-1),Q={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},G=a("",6),K=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  ")],-1),X=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"")],-1),ss={class:"language-html vp-adaptive-theme"},is=s("button",{title:"Copy Code",class:"copy"},null,-1),as=s("span",{class:"lang"},"html",-1),ts={class:"shiki shiki-themes github-light github-dark vp-code"},hs=a("",1),ns=a("",1),ls=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"head"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),ks=a("",1),ps=a("",1),es=a("",1),Es={class:"line highlighted"},ds=a("",7),rs={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},gs=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">",-1),_s=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  ")],-1),os=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"body"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),ys=a("",1),cs=a("",1),Fs={class:"line highlighted"},us=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"    <",-1),Cs=s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"script",-1),As=s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," src",-1),Ts=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"=",-1),Ds={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},ms=a("",6),Bs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  ")],-1),bs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"")],-1),vs={class:"language-html vp-adaptive-theme"},Ss=s("button",{title:"Copy Code",class:"copy"},null,-1),Is=s("span",{class:"lang"},"html",-1),qs={class:"shiki shiki-themes github-light github-dark vp-code"},Ps=a("",1),zs=a("",1),Vs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"head"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),fs=a("",1),Ns=a("",1),ws=a("",1),Rs={class:"line highlighted"},xs=a("",7),Us={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},js=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">",-1),Zs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  ")],-1),Ms=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"body"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),Js=a("",1),Hs=a("",1),Ys={class:"line highlighted"},$s=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"    <",-1),Ws=s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"script",-1),Ls=s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," src",-1),Os=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"=",-1),Qs={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},Gs=a("",6),Ks=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  ")],-1),Xs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"")],-1),si=a("",8),ii=s("div",{"zui-create":"datePicker"},null,-1),ai=s("div",{class:"language-html vp-adaptive-theme"},[s("button",{title:"Copy Code",class:"copy"}),s("span",{class:"lang"},"html"),s("pre",{class:"shiki shiki-themes github-light github-dark vp-code"},[s("code",null,[s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"<"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"div"),s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," zui-create"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"="),s("span",{style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},'"datePicker"'),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")])])])],-1),ti=s("p",null,[i("使用 "),s("code",null,"zui-create-"),i(" 来定义组件选项,例如:")],-1),hi=s("div",{"zui-create":"","zui-create-list":"{items: [{text: 'item1'}, {text: 'item2'}], onClickItem: (e) => console.log('You clicked', e)}"},null,-1),ni=s("div",{class:"language-html vp-adaptive-theme"},[s("button",{title:"Copy Code",class:"copy"}),s("span",{class:"lang"},"html"),s("pre",{class:"shiki shiki-themes github-light github-dark vp-code"},[s("code",null,[s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"<"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"div"),s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," zui-create"),s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," zui-create-list"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"="),s("span",{style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},'"')]),i(`
+import{c as d,k as s,m as r,a as i,t as l,I as h,w as n,R as a,D as p,o as g,f as _}from"./chunks/framework.DeE3OwZJ.js";const o=s("h1",{id:"快速上手",tabindex:"-1"},[i("快速上手 "),s("a",{class:"header-anchor",href:"#快速上手","aria-label":'Permalink to "快速上手"'},"​")],-1),y=s("h2",{id:"下载使用",tabindex:"-1"},[i("下载使用 "),s("a",{class:"header-anchor",href:"#下载使用","aria-label":'Permalink to "下载使用"'},"​")],-1),c=s("p",null,"你可以从如下地址下载 ZUI 的最新版本:",-1),F={class:"gap-4 vp-raw row"},u=["href"],C=s("i",{class:"icon icon-download-alt icon-lg"},null,-1),A=["href"],T=s("i",{class:"icon icon-github icon-lg"},null,-1),D=a("",6),m={class:"vp-code-group vp-adaptive-theme"},B=a("",1),b={class:"blocks"},v={class:"language-html vp-adaptive-theme active"},S=s("button",{title:"Copy Code",class:"copy"},null,-1),I=s("span",{class:"lang"},"html",-1),q={class:"shiki shiki-themes github-light github-dark vp-code"},P=a("",1),z=a("",1),V=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"head"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),f=a("",1),N=a("",1),R=a("",1),w={class:"line highlighted"},j=a("",7),Z={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},U=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">",-1),x=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  ")],-1),M=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"body"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),H=a("",1),J=a("",1),Y={class:"line highlighted"},$=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"    <",-1),K=s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"script",-1),L=s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," src",-1),O=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"=",-1),Q={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},W=a("",6),G=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  ")],-1),X=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"")],-1),ss={class:"language-html vp-adaptive-theme"},is=s("button",{title:"Copy Code",class:"copy"},null,-1),as=s("span",{class:"lang"},"html",-1),ts={class:"shiki shiki-themes github-light github-dark vp-code"},hs=a("",1),ns=a("",1),ls=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"head"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),ks=a("",1),ps=a("",1),es=a("",1),Es={class:"line highlighted"},ds=a("",7),rs={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},gs=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">",-1),_s=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  ")],-1),os=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"body"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),ys=a("",1),cs=a("",1),Fs={class:"line highlighted"},us=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"    <",-1),Cs=s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"script",-1),As=s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," src",-1),Ts=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"=",-1),Ds={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},ms=a("",6),Bs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  ")],-1),bs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"")],-1),vs={class:"language-html vp-adaptive-theme"},Ss=s("button",{title:"Copy Code",class:"copy"},null,-1),Is=s("span",{class:"lang"},"html",-1),qs={class:"shiki shiki-themes github-light github-dark vp-code"},Ps=a("",1),zs=a("",1),Vs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"head"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),fs=a("",1),Ns=a("",1),Rs=a("",1),ws={class:"line highlighted"},js=a("",7),Zs={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},Us=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">",-1),xs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  ")],-1),Ms=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  <"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"body"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")],-1),Hs=a("",1),Js=a("",1),Ys={class:"line highlighted"},$s=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"    <",-1),Ks=s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"script",-1),Ls=s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," src",-1),Os=s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"=",-1),Qs={style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},Ws=a("",6),Gs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"  ")],-1),Xs=s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"")],-1),si=a("",8),ii=s("div",{"zui-create":"datePicker"},null,-1),ai=s("div",{class:"language-html vp-adaptive-theme"},[s("button",{title:"Copy Code",class:"copy"}),s("span",{class:"lang"},"html"),s("pre",{class:"shiki shiki-themes github-light github-dark vp-code"},[s("code",null,[s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"<"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"div"),s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," zui-create"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"="),s("span",{style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},'"datePicker"'),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},">")])])])],-1),ti=s("p",null,[i("使用 "),s("code",null,"zui-create-"),i(" 来定义组件选项,例如:")],-1),hi=s("div",{"zui-create":"","zui-create-list":"{items: [{text: 'item1'}, {text: 'item2'}], onClickItem: (e) => console.log('You clicked', e)}"},null,-1),ni=s("div",{class:"language-html vp-adaptive-theme"},[s("button",{title:"Copy Code",class:"copy"}),s("span",{class:"lang"},"html"),s("pre",{class:"shiki shiki-themes github-light github-dark vp-code"},[s("code",null,[s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"<"),s("span",{style:{"--shiki-light":"#22863A","--shiki-dark":"#85E89D"}},"div"),s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," zui-create"),s("span",{style:{"--shiki-light":"#6F42C1","--shiki-dark":"#B392F0"}}," zui-create-list"),s("span",{style:{"--shiki-light":"#24292E","--shiki-dark":"#E1E4E8"}},"="),s("span",{style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},'"')]),i(`
 `),s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},"  {")]),i(`
 `),s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},"    items: [{text: 'item1'}, {text: 'item2'}],")]),i(`
 `),s("span",{class:"line"},[s("span",{style:{"--shiki-light":"#032F62","--shiki-dark":"#9ECBFF"}},"    onClickItem: (e) => console.log('You clicked', e)")]),i(`
@@ -8,14 +8,14 @@ import{c as d,k as s,m as r,a as i,t as l,I as h,w as n,R as a,D as p,o as g,f a
 `),V,i(`
 `),f,i(`
 `),N,i(`
-`),w,i(`
-`),s("span",R,[x,s("span",U,'"///cdn.jsdelivr.net/npm/zui/dist/'+l(t.zui.version)+'/zui.css"',1),j]),i(`
-`),Z,i(`
+`),R,i(`
+`),s("span",w,[j,s("span",Z,'"///cdn.jsdelivr.net/npm/zui/dist/'+l(t.zui.version)+'/zui.css"',1),U]),i(`
+`),x,i(`
 `),M,i(`
-`),J,i(`
 `),H,i(`
-`),s("span",Y,[$,W,L,O,s("span",Q,'"///cdn.jsdelivr.net/npm/zui/dist/'+l(t.zui.version)+'/zui.js"',1),G]),i(`
-`),K,i(`
+`),J,i(`
+`),s("span",Y,[$,K,L,O,s("span",Q,'"///cdn.jsdelivr.net/npm/zui/dist/'+l(t.zui.version)+'/zui.js"',1),W]),i(`
+`),G,i(`
 `),X])])]),s("div",ss,[is,as,s("pre",ts,[s("code",null,[hs,i(`
 `),ns,i(`
 `),ls,i(`
@@ -34,12 +34,12 @@ import{c as d,k as s,m as r,a as i,t as l,I as h,w as n,R as a,D as p,o as g,f a
 `),Vs,i(`
 `),fs,i(`
 `),Ns,i(`
-`),ws,i(`
-`),s("span",Rs,[xs,s("span",Us,'"///unpkg.com/zui@'+l(t.zui.version)+'/zui.css"',1),js]),i(`
-`),Zs,i(`
+`),Rs,i(`
+`),s("span",ws,[js,s("span",Zs,'"///unpkg.com/zui@'+l(t.zui.version)+'/zui.css"',1),Us]),i(`
+`),xs,i(`
 `),Ms,i(`
-`),Js,i(`
 `),Hs,i(`
-`),s("span",Ys,[$s,Ws,Ls,Os,s("span",Qs,'"///unpkg.com/zui@'+l(t.zui.version)+'/zui.js"',1),Gs]),i(`
-`),Ks,i(`
+`),Js,i(`
+`),s("span",Ys,[$s,Ks,Ls,Os,s("span",Qs,'"///unpkg.com/zui@'+l(t.zui.version)+'/zui.js"',1),Ws]),i(`
+`),Gs,i(`
 `),Xs])])])])]),si,h(E,null,{default:n(()=>[h(k,{label:"示例"},{default:n(()=>[h(e,null,{default:n(()=>[ii]),_:1})]),_:1}),h(k,{label:"HTML"},{default:n(()=>[ai]),_:1})]),_:1}),ti,h(E,null,{default:n(()=>[h(k,{label:"示例"},{default:n(()=>[h(e,null,{default:n(()=>[hi]),_:1})]),_:1}),h(k,{label:"HTML"},{default:n(()=>[ni]),_:1})]),_:1}),li])}}});export{di as __pageData,ri as default};
diff --git a/dev/guide/config/base/color.html b/dev/guide/config/base/color.html
index 9494cd4412..ddbdefd88c 100644
--- a/dev/guide/config/base/color.html
+++ b/dev/guide/config/base/color.html
@@ -14,8 +14,8 @@
     
     
     
-    
-    
+    
+    
     
     
   
@@ -49,7 +49,7 @@
   --color-primary-900-rgb: 88, 34, 133;
   --color-primary-950-rgb: 59, 14, 99;
 }

提示

在定义 CSS 变量覆盖调色板时,除了定义 50~950 的十六进制颜色外,还需要定义对应的 RGB 颜色,这是为了在一些特殊场景下通过改变透明度来实现颜色的变化。

注意

如果你需要自定义配色,建议只通过修改调色板来实现,不建议修改界面颜色,除非主题需要实现对比度更明显的风格,任何时候都不应该修改特殊颜色的定义。

更多关于主题的内容参考 主题 文档。

- + \ No newline at end of file diff --git a/dev/guide/config/base/font.html b/dev/guide/config/base/font.html index f7eba9209c..9b1c992c76 100644 --- a/dev/guide/config/base/font.html +++ b/dev/guide/config/base/font.html @@ -14,8 +14,8 @@ - - + + @@ -44,7 +44,7 @@ 月光如流水一般,静静地泻在这一片叶子和花上。薄薄的青雾浮起在荷塘里。叶子和花仿佛在牛乳中洗过一样;又像笼着轻纱的梦。
leading-relaxed
.leading-relaxed
宽松
line-height: line-height
So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the kinship of all living things but I tell you Jerry at that moment, I was a marine biologist.
 月光如流水一般,静静地泻在这一片叶子和花上。薄薄的青雾浮起在荷塘里。叶子和花仿佛在牛乳中洗过一样;又像笼着轻纱的梦。
leading-loose
.leading-loose
松散
line-height: line-height
So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the kinship of all living things but I tell you Jerry at that moment, I was a marine biologist.
 月光如流水一般,静静地泻在这一片叶子和花上。薄薄的青雾浮起在荷塘里。叶子和花仿佛在牛乳中洗过一样;又像笼着轻纱的梦。

在 ZUI 中可以通过 CSS 工具类来设置行高,详细用法参加 CSS 工具类 / 排版 / 行高 文档。

- + \ No newline at end of file diff --git a/dev/guide/config/base/rounded.html b/dev/guide/config/base/rounded.html index 67d19ece9f..d34cd56fe7 100644 --- a/dev/guide/config/base/rounded.html +++ b/dev/guide/config/base/rounded.html @@ -14,8 +14,8 @@ - - + + @@ -31,7 +31,7 @@ --radius-3xl: 1.5rem; --radius-full: 9999px; }

自定义主题

可以通过定制主题来修改圆角设置,具体参见 主题 文档。

- + \ No newline at end of file diff --git a/dev/guide/config/base/screens.html b/dev/guide/config/base/screens.html index 3a9b8600dc..9726d61537 100644 --- a/dev/guide/config/base/screens.html +++ b/dev/guide/config/base/screens.html @@ -14,8 +14,8 @@ - - + + @@ -54,7 +54,7 @@ --screen-xl: 1280px; --screen-2xl: 1536px; }

自定义主题

可以通过定制主题来修改屏幕断点设置,具体参见 主题 文档。

- + \ No newline at end of file diff --git a/dev/guide/config/base/shadow.html b/dev/guide/config/base/shadow.html index 19180896ea..48b7d91ddf 100644 --- a/dev/guide/config/base/shadow.html +++ b/dev/guide/config/base/shadow.html @@ -14,8 +14,8 @@ - - + + @@ -30,7 +30,7 @@ --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / 0.05); --shadow-none: none; }

自定义主题

可以通过定制主题来修改阴影设置,具体参见 主题 文档。

- + \ No newline at end of file diff --git a/dev/guide/config/base/spacing.html b/dev/guide/config/base/spacing.html index 989fd1affa..0ac4a15b5d 100644 --- a/dev/guide/config/base/spacing.html +++ b/dev/guide/config/base/spacing.html @@ -14,14 +14,14 @@ - - + +
Skip to content

间距

间距配置

为了方便实现风格一致的交互界面,ZUI 预置了间距设置。下面为默认的间距配置:

名称
实际值
预览
0
width
px
width
0.5
width
1
width
1.5
width
2
width
2.5
width
3
width
3.5
width
4
width
5
width
6
width
7
width
8
width
9
width
10
width
11
width
12
width
14
width
16
width
20
width
24
width
28
width
32
width
36
width
40
width
44
width
48
width
52
width
56
width
60
width
64
width
72
width
80
width
96
width

4px 约定

通过上表可以看到,除了 0px 比较特殊的设置,其他间距实际值都是 4px 的倍数,这是有意设计,无论是设计还是开发都应该将间距为 4px 的倍数作为约定,这样更有利于实现风格一致的交互界面。

当以上间距无法满足要求时,如果需要引入新的间距值也应当遵从 4px 约定。

间距会影响所有相关 CSS 属性配置,包括 paddingmarginwidthheightmaxHeightgapinset 等。

使用间距

在 ZUI 中提供了大量 CSS 工具类,可以非常方便的来应用间距配置,包括:

如需了解,请参考对应的文档。

自定义间距

可以通过定制主题来修改间距设置,具体参见 主题 文档。

MIT License (MIT)

- + \ No newline at end of file diff --git a/dev/guide/customize/build.html b/dev/guide/customize/build.html index 7a99b50326..eb47d28a66 100644 --- a/dev/guide/customize/build.html +++ b/dev/guide/customize/build.html @@ -14,14 +14,14 @@ - - + +
Skip to content

打包

打包组件库

执行如下命令进行打包操作:

sh
pnpm build

该命令提供了一些参数用户个性化打包,例如打包命令后可以直接指定需要打包的组件库,通过 --name 来指定打包生成的文件名:

sh
pnpm build -- utilities dtable --name=zui-table

打包文档

执行如下命令进行打包文档网站:

sh
pnpm docs:build

MIT License (MIT)

- + \ No newline at end of file diff --git a/dev/guide/customize/dev.html b/dev/guide/customize/dev.html index ee0443d3d1..c457518cab 100644 --- a/dev/guide/customize/dev.html +++ b/dev/guide/customize/dev.html @@ -14,14 +14,14 @@ - - + +
Skip to content

开发

开发服务

执行如下命令启动开发服务:

shell
$ pnpm dev

开发服务器启动后,默认情况下可以通过网址:http://localhost:5173/ 来访问开发服务页面。通过页面上的组件导航,可以访问对应的组件开发页面。也可以将组件名附加到网址后面,直接访问对应的组件页面,例如 http://localhost:5173/button/

在开发服务页面上支持热更新,当开发文件变更后会自动反馈到开发服务页面上。

对组件进行开发调试

组件开发目录

ZUI3 每个组件在一个独立的目录内,拥有自己的 package.json 文件,使得组件可以独立作为 npm 包来使用,也可以单独作为子项目进行开发维护。

提示

通常组件通过在 package.json 文件中设置属性 private: true 来让包仅在 zui3 工作空间内可用,但组件仍然拥有作为公开的包发布到 npm 上进行独立使用。

文档开发服务

启动 ZUI 文档网站开发服务执行如下命令:

shell
$ pnpm docs:dev

此命令会先打包 ZUI 并启动文档开发服务器,默认情况下可以通过网址:http://localhost:5174/ 来访问文档开发服务页面。在文档开发服务启动时,修改文档源文件,会自动更新文档页面。

MIT License (MIT)

- + \ No newline at end of file diff --git a/dev/guide/customize/exts-lib.html b/dev/guide/customize/exts-lib.html index 1e18fb482b..70f0b3e5c0 100644 --- a/dev/guide/customize/exts-lib.html +++ b/dev/guide/customize/exts-lib.html @@ -14,8 +14,8 @@ - - + + @@ -23,7 +23,7 @@
Skip to content

组件库扩展

ZUI3 组件库内置了大量组件,并支持集中开发、调试和打包,其中打包还支持只选择指定的组件进行个性化定制,同步输出组件库文档。但当需求扩展到组件库之外时,就需要用到扩展组件库了。ZUI3 支持扩展组件库模式,可以从其他位置引入一个或多个组件库目录,享受集中开发、调试和打包。下面介绍扩展组件库的使用方法。

定义扩展库

扩展组件库可以来自本地系统的任意位置,只需要提供一个路径,例如:

txt
/Users/TaiJi/Projects/zui3_exts/lib/

扩展组件库的目录结构与 ZUI3 /lib/ 下的目录结构一致,下面的每个子目录为一个独立的组件,详细定义参考 开发文档

添加扩展库

zui3 项目根目录执行:

shell
$ pnpm extend-lib -- <ext_lib_path> <lib_name>

其中参数 ext_lib_path 为扩展组件库路径,<lib_name> 为扩展组件库名称。例如:

shell
$ pnpm extend-lib -- /Users/TaiJi/Projects/zui3_exts/lib/ zentao

执行上述命令之后,会将组件库目录文件拷贝到 zui3/lib_name 目录下,同时会在 zui3/exts/libs.json 文件中记录此扩展库的名称和路径。

json
{
     "zentao": "/Users/TaiJi/Projects/zui3_exts/lib/*"
 }

实际上,你也可以通过自己编辑这个文件来添加扩展库。

启动开发服务

要在开发模式中包含对扩展组件库的开发调试,只需要执行如下命令代替 pnpm dev 命令即可:

shell
$ pnpm dev:exts

当添加了多个扩展库时,上述命令会包含所有扩展库,有时只需要包含特定的扩展库,只需要自定义 --lib 参数即可:

shell
$ pnpm dev:exts --lib=zui,zentao

启动文档服务器

要在文档网站服务模式中包含对扩展组件库的文档支持,只需要如下命令代替 pnpm docs:dev 命令即可:

shell
$ pnpm docs:dev:exts

打包

打包时如果需要将扩展库中的组件也进行打包,则需要添加 --exts 参数,然后就可以在需要打包的组件清单中指定扩展库中的组件名称:

shell
$ pnpm build -- label @zentao/status-label --exts

如果不指定名称,则默认打包仍然只打包内置组件库的组件,例如下面的命令仍然相当于 pnpm build

shell
$ pnpm build -- --exts

如果需要将所有内置组件库和扩展库中的所有组件一并打包,可以使用如下命令:

shell
$ pnpm build -- zui+exts --exts --name=zentao

当添加了多个扩展库时,上述命令会包含所有扩展库,有时只需要包含特定的扩展库,只需要自定义 --exts 参数即可:

shell
$ pnpm build -- zui+exts --exts=zui,zentao

MIT License (MIT)

- + \ No newline at end of file diff --git a/dev/guide/index.html b/dev/guide/index.html index 2ea68b914c..e6d1525fea 100644 --- a/dev/guide/index.html +++ b/dev/guide/index.html @@ -14,14 +14,14 @@ - - + +
Skip to content

MIT License (MIT)

- + \ No newline at end of file diff --git a/dev/guide/start/compatibility.html b/dev/guide/start/compatibility.html index a6a57f9d21..3d2b730ce3 100644 --- a/dev/guide/start/compatibility.html +++ b/dev/guide/start/compatibility.html @@ -14,14 +14,14 @@ - - + +
Skip to content

兼容性

支持的浏览器

  • Chrome:84+
  • Firefox:63+
  • Safari:14.1+
  • Edge:84+
  • Chrome for Android:126+
  • iOS Safari:14.5+

用到的第三方库

在 ZUI 3 中使用了一些精心挑选的第三方库,这些库通常足够小巧但实用:

  • preact - 基于 Preact 实现了大部分 JS 组件,通过封装支持原生调用
  • cash-dom - 提供了大量辅助方法方便操作 DOM,同时提供了对 jQuery 的兼容实用方式
  • floating UI - 实现浮动交互定位,例如下拉菜单、工具提示等
  • tinykeys - 实现快捷键功能

技术栈

MIT License (MIT)

- + \ No newline at end of file diff --git a/dev/guide/start/index.html b/dev/guide/start/index.html index 1efaa475c1..8ad8b25554 100644 --- a/dev/guide/start/index.html +++ b/dev/guide/start/index.html @@ -12,10 +12,10 @@ - + - - + + @@ -36,7 +36,7 @@ <a class="btn" href="/">访问 ZUI 网站</a> <script src="./zui/zui.js"></script> </body> -</html>

使用 CDN

使用 CDN 可以快速使用 ZUI,与下载使用基本一样,只需要将相关资源文件替换为 CDN 上的地址即可:

html
<!doctype html>
+</html>

使用 CDN

使用 CDN 可以快速使用 ZUI,与下载使用基本一样,只需要将相关资源文件替换为 CDN 上的地址即可:

html
<!doctype html>
 <html lang="zh-CN">
   <head>
     <meta charset="utf-8">
@@ -108,7 +108,7 @@
 import 'zui/lib/dtable/css';
 
 const myTable = new DTable('#myTable', {...});
- + \ No newline at end of file diff --git a/dev/guide/start/intro.html b/dev/guide/start/intro.html index 99014013e3..fb80b31373 100644 --- a/dev/guide/start/intro.html +++ b/dev/guide/start/intro.html @@ -14,14 +14,14 @@ - - + +
Skip to content

介绍

ZUI 3 是一个的开源 UI 组件库,提供了大量实用组件,支持最大限度的定制,不依赖任何其他 JS 框架,可以在任何 Web 应用中通过原生的方式使用。

功能特性

  • 📡 统一的 UI 配置:基于 CSS 变量实现的全局 UI 配置,为组件提供了统一的风格基础,支持深色模式,方便定制主题;
  • 👔 丰富的 CSS 工具类:基于 Tailwind CSS 提供了丰富的 CSS 工具类,包括特别的语义化外观工具类,轻松实现常见布局、文字排版、动画、外观定义;
  • ⭐️ 实用的 CSS 组件:提供了大量实用的 CSS 组件,无需借助 JS 即可实现界面基本功能,例如按钮、表单、导航、卡片、表格等;
  • 💎 强大的 JS 组件:通过 JS 实现很多功能强大的组件,包括下拉菜单、工具提示、对话框、数据表格、文件上传等;
  • 📦 使用灵活:不依赖具体的框架,所有 CSS 工具类开箱即用,所有 JS 组件支持原生调用,丰富的引入方式,支持通过 ESM 导入,或者直接在浏览器中引用整个 JS 和 CSS,支持打包定制自己的组合版本。

与 ZUI1 的区别

相比较 ZUI 1,ZUI 3 是一个全新的更加现代的 UI 组件库,主要有如下区别:

区别ZUI 1ZUI 3
外部依赖jQuery
内部依赖Bootstrap 3
网格布局实现floatFlex
工具类部分样式、布局、排版工具类丰富的样式、布局、排版、交互效果工具类
主题定制CSS 覆盖CSS 变量
CSS 组件大部分由 Bootstrap 提供全新的 CSS 组件,更方便定制外观
JS 组件基于 jQuery 实现基于 Preact 实现,功能更强大

MIT License (MIT)

- + \ No newline at end of file diff --git a/dev/guide/start/tutorial.html b/dev/guide/start/tutorial.html index 4763d899e6..6ef8c46b5d 100644 --- a/dev/guide/start/tutorial.html +++ b/dev/guide/start/tutorial.html @@ -14,8 +14,8 @@ - - + + @@ -238,7 +238,7 @@ /* Extend StepsEditor to zui object. */ $.extend(zui, {StepsEditor});

开发定制入门

参考打包开发扩展文档。

- + \ No newline at end of file diff --git a/dev/hashmap.json b/dev/hashmap.json index c8152a00af..b91ff97d37 100644 --- a/dev/hashmap.json +++ b/dev/hashmap.json @@ -1 +1 @@ -{"lib_basic_core_cash.md":"Bzo_CH3I","guide_customize_dev.md":"BHKWgm2m","guide_customize_build.md":"BnMDMPqz","guide_customize_exts-lib.md":"BKuxQGR7","guide_start_tutorial.md":"CmfMgriO","index.md":"0I4m7CHi","lib_basic_core_zui-on.md":"IjDbHIdO","guide_index.md":"t3LZT4QY","guide_start_compatibility.md":"CltyrLny","guide_config_base_shadow.md":"BNzZgBvC","lib_basic_core_zui-toggle.md":"D_sPxQQs","guide_config_base_spacing.md":"B653NiFv","lib_basic_core_zui-create.md":"DLe7A4Hj","guide_start_index.md":"CCziB0kD","lib_basic_core_css-component.md":"BwdGvlia","lib_components_progress-circle_index.md":"B0UUIqGM","lib_components_progress_index.md":"CEtektTK","lib_components_scrollbar_index.md":"BjI3vUqu","lib_components_search-box_index.md":"C6d4tMjv","lib_components_toolbar_js.md":"ih1Bb-Rr","lib_components_tooltip_index.md":"Co1ECN3g","lib_components_tree_index.md":"Dn03SufJ","lib_components_upload-imgs_index.md":"erXa6IN9","lib_components_upload_index.md":"CzVklHlh","lib_components_btn-group_index.md":"5V7X7r4P","lib_components_tabs_index.md":"D-2YSS_0","utilities_typography_utilities_text-color.md":"D1fjRsa-","utilities_layout_utilities_visibility.md":"CKuADuoh","utilities_layout_utilities_z-index.md":"DKY1uWyd","lib_basic_core_component.md":"uPNn0zXQ","utilities_sizing_utilities_width.md":"DNXQWQFd","utilities_sizing_utilities_height.md":"CdF7aUuw","lib_basic_core_react.md":"BTwYD_hf","lib_forms_form-control_index.md":"BiHmr69s","utilities_flex_utilities_gap.md":"DArM8pom","lib_components_menu_index.md":"GncmWrZR","utilities_flex_utilities_order.md":"CfeTP7tL","lib_forms_form_index.md":"sRq2u4jF","utilities_interactivity_utilities_user-select.md":"BrNPbIfK","utilities_layout_utilities_aspect-ratio.md":"_oWsoIYV","utilities_effects_utilities_filter.md":"BECjG4KT","guide_config_base_screens.md":"CXV8MRfe","utilities_layout_utilities_floats.md":"pUvtfQiw","utilities_layout_utilities_object-fit.md":"D4YmLxEC","lib_forms_input-group_index.md":"BMbSYMAL","lib_forms_picker_index.md":"DRGaAh8C","lib_helpers_helpers_date-helper.md":"8AhG85Op","utilities_layout_utilities_overflow.md":"DVHk2FQA","lib_forms_checkbox_index.md":"D_VspyHI","lib_components_nav_js.md":"OePgMXXa","utilities_flex_utilities_align-items.md":"CoFxBC8U","utilities_typography_utilities_text-overflow.md":"CCaD8PoB","lib_components_pager_js.md":"DDMQ9lXw","utilities_layout_utilities_container.md":"Bb3Lxa_7","utilities_flex_utilities_wrap.md":"DZ1moX26","utilities_interactivity_utilities_pointer-events.md":"EHN_kBvp","utilities_interactivity_utilities_scroll.md":"-0JODEPX","lib_forms_datetime-picker_time.md":"BTTIPCd8","guide_config_base_font.md":"Ba4TxUmX","lib_components_pager_index.md":"D-bROEeS","lib_components_color-picker_index.md":"TddEDwtA","utilities_interactivity_utilities_loading.md":"Da_3FM-1","lib_components_breadcrumb_index.md":"9pymY2C8","guide_config_base_rounded.md":"-jZtXV-b","lib_components_dashboard_index.md":"DRaM25zK","utilities_interactivity_utilities_state.md":"0ZTXUBo7","lib_components_alert_index.md":"Bep50ZBz","lib_components_table_index.md":"Ck9c8Ek4","utilities_skin_utilities_pale.md":"D1L1NRKs","utilities_spacing_utilities_space.md":"xgZHI4vS","utilities_spacing_utilities_padding.md":"DuVwhAAe","utilities_typography_utilities_font-size.md":"B3W8gyR3","utilities_typography_utilities_font-weight.md":"CV3nf15_","lib_forms_datetime-picker_date.md":"D59eL2rp","utilities_typography_utilities_leading.md":"DOlxRw-6","utilities_skin_utilities_solid.md":"Cst9ctTO","utilities_typography_utilities_line-clamp.md":"CvO9OG4z","utilities_interactivity_utilities_cursor.md":"DvV2lotG","utilities_skin_utilities_surface.md":"CN20jMqq","utilities_typography_utilities_list-style.md":"LuK8VgZf","utilities_layout_utilities_position.md":"rEqgc51a","utilities_typography_utilities_text-align.md":"CtJ4rtrI","public_zui_icons_fontawesome-license.md":"gfk3cURr","themes_index.md":"BufleTaf","utilities_effects_utilities_opacity.md":"BcIL05hy","utilities_backgrounds_utilities_index.md":"83vrBdjK","lib_components_file-selector_index.md":"DvywDJ4t","utilities_borders_utilities_border-color.md":"YFsIdVzo","utilities_borders_utilities_border-radius.md":"Dh1Nfe3A","utilities_borders_utilities_border-width.md":"DVKauZHZ","utilities_borders_utilities_divider.md":"khTQtOjv","utilities_borders_utilities_ring-color.md":"s0nb0vey","utilities_borders_utilities_ring-offset.md":"DVb4azgP","utilities_layout_utilities_top-right-bottom-left.md":"C3lYdIa5","utilities_effects_utilities_shadow.md":"CaSFSOMl","guide_config_base_color.md":"B_i0YNBV","utilities_effects_utilities_animation.md":"B91izYvM","utilities_typography_utilities_text-decoration.md":"BvY6hqYi","lib_helpers_store_index.md":"Bb0Q5VMq","lib_components_dropdown_index.md":"DbbvFq7u","lib_components_avatar_index.md":"7j-ew9BZ","lib_components_toolbar_index.md":"DvojQFd3","utilities_typography_utilities_word-break.md":"BxSlEVBy","lib_index.md":"Ci-MFpvh","utilities_typography_utilities_text-transform.md":"CM7k043G","utilities_flex_utilities_flex.md":"BlvjgLjv","utilities_skin_utilities_ghost.md":"DIt2ElJv","utilities_flex_utilities_align-self.md":"FvSQ-0Fm","lib_components_panel_index.md":"CoS14bNk","lib_components_button_index.md":"B_1XMQuI","utilities_effects_utilities_transform.md":"DOI7WnD2","guide_start_intro.md":"DEIJsFre","utilities_flex_utilities_justify-content.md":"D4BVZfVC","utilities_typography_utilities_vertical-align.md":"DiLQT3Ni","lib_components_contextmenu_index.md":"DmEkUwKC","utilities_borders_utilities_ring-width.md":"DzwqJDAb","lib_components_modal_trigger.md":"BMBZZybJ","utilities_typography_utilities_whitespace.md":"BFKZWjDW","utilities_layout_utilities_display.md":"DcXW9WtS","lib_helpers_helpers_string-helper.md":"me2jtoF5","lib_forms_datetime-picker_datetime.md":"CPkUUpoa","utilities_effects_utilities_transition.md":"SqXrre1m","lib_forms_input-control_index.md":"Cv0HAFHI","lib_components_label_index.md":"q76w0qb_","lib_components_dtable_plugins.md":"CrBZnIMk","lib_components_nav_index.md":"LeXRijcV","lib_components_dtable_index.md":"BffsFMb4","lib_components_kanban_index.md":"BFBze8B1","utilities_flex_utilities_basis.md":"CD8bfBkC","lib_components_messager_index.md":"BW-SbOyW","utilities_interactivity_utilities_disabled.md":"CEB7Waub","utilities_flex_utilities_grow.md":"Cn0nOehN","utilities_flex_utilities_shrink.md":"CangfHwT","utilities_skin_utilities_outline.md":"bsC71Qhi","utilities_index.md":"CTpyUmIw","utilities_flex_utilities_align-content.md":"BXGtlw9g","utilities_flex_utilities_direction.md":"ByjEgbMo","lib_forms_checkbox_switch.md":"QH8sYaT3","utilities_typography_utilities_font-family.md":"BHWBVXg4","lib_components_modal_index.md":"CgbVseyc","lib_components_avatar-group_index.md":"BqwB9RZP","utilities_spacing_utilities_margin.md":"C9jBOzP9","lib_components_menu_js.md":"CtCBsfaZ"} +{"lib_basic_core_react.md":"BTwYD_hf","guide_config_base_font.md":"Ba4TxUmX","index.md":"0I4m7CHi","guide_config_base_screens.md":"CXV8MRfe","guide_customize_build.md":"BnMDMPqz","guide_start_intro.md":"DEIJsFre","guide_start_compatibility.md":"CltyrLny","guide_customize_dev.md":"BHKWgm2m","lib_components_contextmenu_index.md":"DmEkUwKC","lib_basic_core_zui-create.md":"DLe7A4Hj","guide_start_index.md":"9ipcmLFp","lib_basic_core_css-component.md":"BwdGvlia","lib_components_color-picker_index.md":"TddEDwtA","lib_components_messager_index.md":"BW-SbOyW","lib_components_menu_js.md":"CtCBsfaZ","guide_config_base_color.md":"B_i0YNBV","lib_basic_core_cash.md":"Bzo_CH3I","guide_start_tutorial.md":"CmfMgriO","lib_components_dashboard_index.md":"DRaM25zK","lib_components_avatar-group_index.md":"BqwB9RZP","lib_components_alert_index.md":"Bep50ZBz","guide_config_base_spacing.md":"B653NiFv","lib_components_kanban_index.md":"BFBze8B1","lib_components_tabs_index.md":"D-2YSS_0","lib_components_upload-imgs_index.md":"erXa6IN9","lib_components_dtable_index.md":"BffsFMb4","lib_components_btn-group_index.md":"5V7X7r4P","lib_components_nav_js.md":"OePgMXXa","lib_components_nav_index.md":"LeXRijcV","lib_components_progress-circle_index.md":"B0UUIqGM","lib_components_pager_js.md":"DDMQ9lXw","lib_components_panel_index.md":"CoS14bNk","lib_components_scrollbar_index.md":"BjI3vUqu","lib_components_progress_index.md":"CEtektTK","guide_config_base_rounded.md":"-jZtXV-b","lib_components_pager_index.md":"D-bROEeS","lib_components_search-box_index.md":"C6d4tMjv","guide_customize_exts-lib.md":"BKuxQGR7","guide_index.md":"t3LZT4QY","lib_components_table_index.md":"Ck9c8Ek4","guide_config_base_shadow.md":"BNzZgBvC","lib_basic_core_zui-on.md":"IjDbHIdO","lib_components_label_index.md":"q76w0qb_","lib_forms_checkbox_switch.md":"QH8sYaT3","lib_forms_datetime-picker_date.md":"D59eL2rp","lib_forms_datetime-picker_datetime.md":"CPkUUpoa","lib_forms_form-control_index.md":"BiHmr69s","lib_forms_input-group_index.md":"BMbSYMAL","lib_helpers_helpers_date-helper.md":"8AhG85Op","lib_forms_picker_index.md":"DRGaAh8C","lib_helpers_helpers_string-helper.md":"me2jtoF5","lib_helpers_store_index.md":"Bb0Q5VMq","lib_index.md":"Ci-MFpvh","lib_forms_input-control_index.md":"Cv0HAFHI","public_zui_icons_fontawesome-license.md":"gfk3cURr","themes_index.md":"BufleTaf","lib_forms_datetime-picker_time.md":"BTTIPCd8","utilities_backgrounds_utilities_index.md":"83vrBdjK","utilities_borders_utilities_border-radius.md":"Dh1Nfe3A","utilities_borders_utilities_border-color.md":"YFsIdVzo","utilities_borders_utilities_border-width.md":"DVKauZHZ","utilities_borders_utilities_ring-color.md":"s0nb0vey","utilities_borders_utilities_divider.md":"khTQtOjv","utilities_borders_utilities_ring-width.md":"DzwqJDAb","utilities_effects_utilities_animation.md":"B91izYvM","utilities_effects_utilities_filter.md":"BECjG4KT","utilities_effects_utilities_shadow.md":"CaSFSOMl","utilities_effects_utilities_transform.md":"DOI7WnD2","utilities_effects_utilities_opacity.md":"BcIL05hy","utilities_effects_utilities_transition.md":"SqXrre1m","utilities_flex_utilities_align-content.md":"BXGtlw9g","utilities_flex_utilities_align-items.md":"CoFxBC8U","utilities_flex_utilities_align-self.md":"FvSQ-0Fm","utilities_flex_utilities_basis.md":"CD8bfBkC","utilities_flex_utilities_direction.md":"ByjEgbMo","utilities_flex_utilities_flex.md":"BlvjgLjv","utilities_flex_utilities_gap.md":"DArM8pom","utilities_flex_utilities_justify-content.md":"D4BVZfVC","utilities_flex_utilities_order.md":"CfeTP7tL","utilities_flex_utilities_grow.md":"Cn0nOehN","utilities_flex_utilities_shrink.md":"CangfHwT","utilities_flex_utilities_wrap.md":"DZ1moX26","utilities_index.md":"CTpyUmIw","utilities_interactivity_utilities_disabled.md":"CEB7Waub","utilities_interactivity_utilities_cursor.md":"DvV2lotG","lib_forms_form_index.md":"sRq2u4jF","utilities_interactivity_utilities_pointer-events.md":"EHN_kBvp","utilities_interactivity_utilities_scroll.md":"-0JODEPX","utilities_interactivity_utilities_state.md":"0ZTXUBo7","utilities_interactivity_utilities_user-select.md":"BrNPbIfK","utilities_interactivity_utilities_loading.md":"Da_3FM-1","utilities_layout_utilities_container.md":"Bb3Lxa_7","utilities_layout_utilities_aspect-ratio.md":"_oWsoIYV","utilities_layout_utilities_floats.md":"pUvtfQiw","utilities_layout_utilities_object-fit.md":"D4YmLxEC","utilities_layout_utilities_position.md":"rEqgc51a","utilities_layout_utilities_top-right-bottom-left.md":"C3lYdIa5","utilities_layout_utilities_display.md":"DcXW9WtS","lib_components_dtable_plugins.md":"CrBZnIMk","utilities_layout_utilities_z-index.md":"DKY1uWyd","utilities_sizing_utilities_height.md":"CdF7aUuw","utilities_layout_utilities_overflow.md":"DVHk2FQA","utilities_sizing_utilities_width.md":"DNXQWQFd","utilities_layout_utilities_visibility.md":"CKuADuoh","utilities_typography_utilities_text-decoration.md":"BvY6hqYi","utilities_typography_utilities_text-overflow.md":"CCaD8PoB","utilities_typography_utilities_text-color.md":"D1fjRsa-","utilities_typography_utilities_vertical-align.md":"DiLQT3Ni","utilities_typography_utilities_whitespace.md":"BFKZWjDW","utilities_typography_utilities_word-break.md":"BxSlEVBy","lib_components_tooltip_index.md":"Co1ECN3g","lib_components_tree_index.md":"Dn03SufJ","utilities_typography_utilities_text-align.md":"CtJ4rtrI","utilities_skin_utilities_ghost.md":"DIt2ElJv","utilities_skin_utilities_outline.md":"bsC71Qhi","utilities_skin_utilities_surface.md":"CN20jMqq","utilities_spacing_utilities_margin.md":"C9jBOzP9","utilities_spacing_utilities_space.md":"xgZHI4vS","utilities_typography_utilities_line-clamp.md":"CvO9OG4z","utilities_typography_utilities_leading.md":"DOlxRw-6","lib_components_upload_index.md":"CzVklHlh","utilities_typography_utilities_list-style.md":"LuK8VgZf","lib_components_button_index.md":"B_1XMQuI","lib_basic_core_zui-toggle.md":"D_sPxQQs","lib_components_breadcrumb_index.md":"9pymY2C8","lib_components_avatar_index.md":"7j-ew9BZ","utilities_typography_utilities_text-transform.md":"CM7k043G","utilities_typography_utilities_font-family.md":"BHWBVXg4","utilities_borders_utilities_ring-offset.md":"DVb4azgP","utilities_typography_utilities_font-size.md":"B3W8gyR3","utilities_skin_utilities_pale.md":"D1L1NRKs","utilities_typography_utilities_font-weight.md":"CV3nf15_","utilities_spacing_utilities_padding.md":"DuVwhAAe","utilities_skin_utilities_solid.md":"Cst9ctTO","lib_basic_core_component.md":"uPNn0zXQ","lib_components_toolbar_index.md":"DvojQFd3","lib_forms_checkbox_index.md":"D_VspyHI","lib_components_toolbar_js.md":"ih1Bb-Rr","lib_components_dropdown_index.md":"DbbvFq7u","lib_components_menu_index.md":"GncmWrZR","lib_components_file-selector_index.md":"DvywDJ4t","lib_components_modal_trigger.md":"BMBZZybJ","lib_components_modal_index.md":"CgbVseyc"} diff --git a/dev/index.html b/dev/index.html index 809274f281..c60e33d3d0 100644 --- a/dev/index.html +++ b/dev/index.html @@ -14,14 +14,14 @@ - - + +
Skip to content

ZUI 3

开箱即用的组合式前端 UI 框架

MIT License (MIT)

- + \ No newline at end of file diff --git a/dev/lib/basic/core/cash.html b/dev/lib/basic/core/cash.html index 90c6a2c7d9..5c68b33152 100644 --- a/dev/lib/basic/core/cash.html +++ b/dev/lib/basic/core/cash.html @@ -14,8 +14,8 @@ - - + + @@ -82,7 +82,7 @@ /* 销毁。 */ datePicker.destroy();

辅助方法

$.fn.resize() 监听元素尺寸变化

定义:

ts
$.fn.resize(callback: ResizeObserverCallback): ResizeObserver;

参数

返回值ResizeObserverResizeObserver 对象。

- + \ No newline at end of file diff --git a/dev/lib/basic/core/component.html b/dev/lib/basic/core/component.html index dee88e7046..164b59b3ad 100644 --- a/dev/lib/basic/core/component.html +++ b/dev/lib/basic/core/component.html @@ -14,8 +14,8 @@ - - + + @@ -76,7 +76,7 @@ * @param key 组件的唯一标识。 */ static query(element: HTMLElement | string, key?: string): Component; -}

创建组件实例

每个组件通常对应一个元素,只有使用对应元素创建了组件实例,组件才会生效,例如:

html
<nav id="myNav"></nav>
+}

创建组件实例

每个组件通常对应一个元素,只有使用对应元素创建了组件实例,组件才会生效,例如:

html
<nav id="myNav"></nav>
 
 <script>
 const nav = new zui.Nav('#myNav', {
@@ -85,7 +85,7 @@
         {text: 'Blog'},
     ]
 });
-</script>

另一种方式是通过 zui-create 属性来声明组件,例如:

html
<div zui-create="datePicker"></div>

调用组件方法

当创建了组件实例后,就可以调用组件实例上的方法,例如:

html
<nav id="myNav"></nav>
+</script>

另一种方式是通过 zui-create 属性来声明组件,例如:

html
<div zui-create="datePicker"></div>

调用组件方法

当创建了组件实例后,就可以调用组件实例上的方法,例如:

html
<nav id="myNav"></nav>
 <button id="myNavRenderBtn">重新渲染</button>
 
 <script>
@@ -117,7 +117,7 @@
 
 const nav = zui.Nav.get('#myNav');
 </script>
- + \ No newline at end of file diff --git a/dev/lib/basic/core/css-component.html b/dev/lib/basic/core/css-component.html index 5001596661..d874f037dd 100644 --- a/dev/lib/basic/core/css-component.html +++ b/dev/lib/basic/core/css-component.html @@ -14,14 +14,14 @@ - - + + -
Skip to content

CSS 组件

基本使用

CSS 组件通常提供了界面所需的基本功能,例如按钮、表单、导航、卡片、表格等,这些组件通常不需要 JS 的支持,只需要在 HTML 中使用对应的组件类名即可,例如按钮:

提示

一些 JS 组件也提供了纯 CSS 使用的方式,也就是说 CSS 组件也可能是一个 JS 组件。

组件样式

通用样式修饰

CSS 组件通常提供了多种样式修饰,例如按钮的颜色、大小、形状、状态等,大部分通用样式的修饰都可以通过 CSS 工具类来实现,例如:

专用样式修饰

部分组件提供了专用样式修饰类,这些类名通常为组件类加后缀实现,例如按钮组件的 btn-link

CSS 变量

CSS 组件通常提供了一些 CSS 变量用于自定义组件的样式,例如按钮组件提供了 --btn-bg 用于自定义按钮的颜色:

MIT License (MIT)

- +
Skip to content

CSS 组件

基本使用

CSS 组件通常提供了界面所需的基本功能,例如按钮、表单、导航、卡片、表格等,这些组件通常不需要 JS 的支持,只需要在 HTML 中使用对应的组件类名即可,例如按钮:

提示

一些 JS 组件也提供了纯 CSS 使用的方式,也就是说 CSS 组件也可能是一个 JS 组件。

组件样式

通用样式修饰

CSS 组件通常提供了多种样式修饰,例如按钮的颜色、大小、形状、状态等,大部分通用样式的修饰都可以通过 CSS 工具类来实现,例如:

专用样式修饰

部分组件提供了专用样式修饰类,这些类名通常为组件类加后缀实现,例如按钮组件的 btn-link

CSS 变量

CSS 组件通常提供了一些 CSS 变量用于自定义组件的样式,例如按钮组件提供了 --btn-bg 用于自定义按钮的颜色:

MIT License (MIT)

+ \ No newline at end of file diff --git a/dev/lib/basic/core/react.html b/dev/lib/basic/core/react.html index 6a7f3b7026..f865ee9439 100644 --- a/dev/lib/basic/core/react.html +++ b/dev/lib/basic/core/react.html @@ -14,8 +14,8 @@ - - + + @@ -33,7 +33,7 @@ */ static renderHTML(options: object): string; }

React 组件相比较普通的组件有如下特点:

React 组件实例上的 $ 属性是组件的 React 实例,可以通过这个属性来访问组件的属性和方法。

- + \ No newline at end of file diff --git a/dev/lib/basic/core/zui-create.html b/dev/lib/basic/core/zui-create.html index 7ee0c89aa7..96b177ce6f 100644 --- a/dev/lib/basic/core/zui-create.html +++ b/dev/lib/basic/core/zui-create.html @@ -14,14 +14,14 @@ - - + +
Skip to content

便捷组件声明

在 ZUI 中,所有 JS 组件支持通过声明 zui-create 属性来自动创建,例如:

使用 zui-create-<component> 来定义组件选项,例如:

注意

通过 zui-create 创建的组件,只会在页面加载完成后自动扫描一次,如果需要在动态添加的元素上利用 zui-create 创建组件,需要手动执行 $(element).zuiInit() 初始化。

MIT License (MIT)

- + \ No newline at end of file diff --git a/dev/lib/basic/core/zui-on.html b/dev/lib/basic/core/zui-on.html index dc86fea249..27699512c4 100644 --- a/dev/lib/basic/core/zui-on.html +++ b/dev/lib/basic/core/zui-on.html @@ -14,14 +14,14 @@ - - + +
Skip to content

便捷事件绑定

介绍

便捷事件机制允许通过 HTML 元素属性 [zui-on-*] 来绑定事件。下面为一个例子:

上例中,通过 [zui-on-click] 属性绑定点击事件,通过属性指定需要执行的 JS 代码,从而实现当点击按钮时,将会弹出一个对话框。

提示

编辑事件机制实际原理为在 document 元素上绑定了一个事件监听器,当事件触发时,会检查事件源元素是否存在 [data-on-*] 属性,如果存在,则会根据 [data-on-*] 属性的值来执行 JS 代码。根据此原理,需要被监听的元素上的事件能够被冒泡到 document 上。

事件类型

在 ZUI3 中默认支持的便捷绑定事件类型包括:

  • click:点击事件;
  • inited:组件初始化事件;
  • change:变更事件。

自定义选项

除了可以直接指定要执行的 JS 代码,还可以通过一个对象来指定事件绑定选项,例如:

所有可用的选项包括:

选项说明
on事件类型,必须,目前支持点击('click')和变更('change')事件
selector事件是否仅能触发在符合指定选择器的内部元素上,相当于事件委托
do要执行的 JS 代码,可选
call要执行的回调函数,可选
params需要传递给 JS 代码的参数,多个参数使用 , 分隔,也可以通过 JSON 数组的形式指定
if在执行 JS 代码和回调函数之前进行判断,如果结果为 false 则不会执行
once是否只执行一次,默认 false
stop是否阻止事件冒泡,相当于调用 stopPropagation,默认 false
prevent是否阻止默认行为,相当于调用 preventDefault,默认 false
self是否尽在点击自身时触发。

内置参数

在指定执行代码和回调函数参数时有一些内置参数可以直接通过约定名称引用,包括:

  • event:事件对象;
  • options:事件绑定选项;
  • $element:事件源元素(Cash 类型)。

例如:

内置参数还可以直接用于 do 代码中和 call 回调函数定义中,例如:

MIT License (MIT)

- + \ No newline at end of file diff --git a/dev/lib/basic/core/zui-toggle.html b/dev/lib/basic/core/zui-toggle.html index 81cbaee284..37c8c6afb1 100644 --- a/dev/lib/basic/core/zui-toggle.html +++ b/dev/lib/basic/core/zui-toggle.html @@ -14,14 +14,14 @@ - - + +
Skip to content

全局触发调用

使用

全局触发调用允许在元素上通过 zui-toggle 属性来声明组件调用,在某个事件(通常为点击)触发时,自动使用选项进行初始化,并执行操作。例如下拉菜单按钮,在点击时声明下拉菜单组件,并打开下拉菜单。下面为一个下拉菜单的例子:

兼容模式

在兼容模式下,可以通过 data-toggle 属性生命组件,使用其他 data-* 属性声明组件初始化选项。

支持的组件

支持全局触发调用的组件包括:

MIT License (MIT)

- + \ No newline at end of file diff --git a/dev/lib/components/alert/index.html b/dev/lib/components/alert/index.html index 9ae3f961d5..6fb6371cc8 100644 --- a/dev/lib/components/alert/index.html +++ b/dev/lib/components/alert/index.html @@ -14,14 +14,14 @@ - - + +
Skip to content

消息框

消息框能够轻松展示一些需要引起用户注意的内容。

基本使用

为元素添加 alert 类来获得消息框的外观。

嘿!这是一则提示。

包含链接

使用 .alert-link 类来为消息框内的链接添加样式。

Hi! 这条消息可能需要你注意。了解更多

包含关闭按钮

使用 .alert-close 类来为消息框内的关闭按钮添加样式。絮语注意到是当需要在消息框中包含更多内容时,需要将消息文本放置在 .alert-text 中。

嘿!这是一则提示。了解更多

包含操作按钮

像添加关闭按钮一样,还可以添加其他操作按钮:

嘿!这是一则提示。了解更多

可以将多个按钮放在工具栏中:

嘿!这是一则提示。了解更多

外观类型

配合丰富的 CSS 工具类 来实现不同消息框的外观。

嘿!这是一则提示。
嘿!这是一则提示。
嘿!这是一则提示。
嘿!这是一则提示。
嘿!这是一则提示。
嘿!这是一则提示。
嘿!这是一则提示。

CSS 类

消息框提供了如下 CSS 类:

类型作用
alert实体类元素作为消息框组件
alert-icon实体类元素作为消息框内左侧图标
alert-close实体类元素作为消息框关闭按钮
alert-text实体类元素作为消息框文本内容

CSS 变量

消息框提供了如下 CSS 变量:

变量名称变量含义
--alert-bg消息框默认背景色

MIT License (MIT)

- + \ No newline at end of file diff --git a/dev/lib/components/avatar-group/index.html b/dev/lib/components/avatar-group/index.html index 778dc0036f..8f10f081bd 100644 --- a/dev/lib/components/avatar-group/index.html +++ b/dev/lib/components/avatar-group/index.html @@ -14,14 +14,14 @@ - - + + -
Skip to content

头像组

头像组用于将多个头像堆叠显示。

基本使用

将多个头像放置在 <div class="avatar-group"> 内即可创建一个头像组。

+10

尺寸

当使用不同大小的头像时,可以通过为 .avatar-group 添加同样等级的 size-* 辅助类已获得统一的堆叠间距。

堆叠间距

使用工具类 gap-* 来调整堆叠间距。默认间距等同于 gap-2.5,小于 2.5 将使得间距比默认间距更小,反之则更大。

0
1
2
2.5
3
3.5

CSS 类

头像组提供了如下 CSS 类:

类型作用
avatar-group实体类元素作为头像组组件
size-xs工具类头像组使用超小号尺寸
size-sm工具类头像组使用小号尺寸
size-lg工具类头像组使用大号尺寸
size-xl工具类头像组使用超大号尺寸

参考

MIT License (MIT)

- +
Skip to content

头像组

头像组用于将多个头像堆叠显示。

基本使用

将多个头像放置在 <div class="avatar-group"> 内即可创建一个头像组。

+10

尺寸

当使用不同大小的头像时,可以通过为 .avatar-group 添加同样等级的 size-* 辅助类已获得统一的堆叠间距。

堆叠间距

使用工具类 gap-* 来调整堆叠间距。默认间距等同于 gap-2.5,小于 2.5 将使得间距比默认间距更小,反之则更大。

0
1
2
2.5
3
3.5

CSS 类

头像组提供了如下 CSS 类:

类型作用
avatar-group实体类元素作为头像组组件
size-xs工具类头像组使用超小号尺寸
size-sm工具类头像组使用小号尺寸
size-lg工具类头像组使用大号尺寸
size-xl工具类头像组使用超大号尺寸

参考

MIT License (MIT)

+ \ No newline at end of file diff --git a/dev/lib/components/avatar/index.html b/dev/lib/components/avatar/index.html index 8b6671ff62..4a1c5d2bd5 100644 --- a/dev/lib/components/avatar/index.html +++ b/dev/lib/components/avatar/index.html @@ -14,14 +14,14 @@ - - + + -
Skip to content

头像

头像是用图片、图标或者文字的形式展示用户及具有特殊标识的其他对象。

基本使用

为元素并添加类 .avatar,然后将作为图像的图片、文字或图标放置在此元素内。

Z

提示

当使用文字作为头像时,建议文字数目不要超过 2 个,如果需要显示更多文字进行个性化排版,推荐使用 JavaScript 增强的头像插件。

头像形状

搭配 CSS 工具类 rounded-* 为头像应用不同的圆角样式。

外观类型

当使用文字或图标作为头像时,配合使用CSS 工具类来实现不同头像的外观。下面展示各种工具类的外观效果。

Z
Z
Z
Z

尺寸

除了默认大小,还提供了额外的 4 种预设尺寸,通过 size-* 来为头像设置尺寸。

X
S
Z
LG
XL

CSS 类

头像提供了如下 CSS 类:

类型作用
avatar实体类元素作为头像组件
size-xs工具类头像使用超小号尺寸
size-sm工具类头像使用小号尺寸
size-lg工具类头像使用大号尺寸
size-xl工具类头像使用超大号尺寸

CSS 变量

头像提供了如下 CSS 变量,可进行全局修改:

CSS 变量名作用
--avatar-radius头像默认圆角大小
--avatar-bg头像默认背景颜色

参考

MIT License (MIT)

- +
Skip to content

头像

头像是用图片、图标或者文字的形式展示用户及具有特殊标识的其他对象。

基本使用

为元素并添加类 .avatar,然后将作为图像的图片、文字或图标放置在此元素内。

Z

提示

当使用文字作为头像时,建议文字数目不要超过 2 个,如果需要显示更多文字进行个性化排版,推荐使用 JavaScript 增强的头像插件。

头像形状

搭配 CSS 工具类 rounded-* 为头像应用不同的圆角样式。

外观类型

当使用文字或图标作为头像时,配合使用CSS 工具类来实现不同头像的外观。下面展示各种工具类的外观效果。

Z
Z
Z
Z

尺寸

除了默认大小,还提供了额外的 4 种预设尺寸,通过 size-* 来为头像设置尺寸。

X
S
Z
LG
XL

CSS 类

头像提供了如下 CSS 类:

类型作用
avatar实体类元素作为头像组件
size-xs工具类头像使用超小号尺寸
size-sm工具类头像使用小号尺寸
size-lg工具类头像使用大号尺寸
size-xl工具类头像使用超大号尺寸

CSS 变量

头像提供了如下 CSS 变量,可进行全局修改:

CSS 变量名作用
--avatar-radius头像默认圆角大小
--avatar-bg头像默认背景颜色

参考

MIT License (MIT)

+ \ No newline at end of file diff --git a/dev/lib/components/breadcrumb/index.html b/dev/lib/components/breadcrumb/index.html index dd22eaef93..5b11cfdcaa 100644 --- a/dev/lib/components/breadcrumb/index.html +++ b/dev/lib/components/breadcrumb/index.html @@ -14,14 +14,14 @@ - - + +
Skip to content

面包屑

基本使用

使用类 .breadcrumb 来实现面包屑,通常搭配 <ol><li> 元素使用。

CSS 类

面包屑提供了如下 CSS 类

类型作用
breadcrumb实体类元素作为面包屑组件

CSS 变量

变量名称变量含义
--breadcrumb-divider面包屑分割元素标签类型
--breadcrumb-divider-color面包屑分割元素颜色
--breadcrumb-color-active面包屑选中态元素颜色

MIT License (MIT)

- + \ No newline at end of file diff --git a/dev/lib/components/btn-group/index.html b/dev/lib/components/btn-group/index.html index 6a76777434..048d33a355 100644 --- a/dev/lib/components/btn-group/index.html +++ b/dev/lib/components/btn-group/index.html @@ -14,14 +14,14 @@ - - + + -
Skip to content

按钮组

按钮组可以将多个按钮成组展示。

使用方法

将多个 按钮 放置在 <div class="btn-group"> 内即可创建一个按钮组。

多组按钮

使用 CSS 工具类 .row 搭配 .gap-* 实现多组按钮效果。

尺寸

.btn-group 上配合使用工具类 size-* 来获得不同大小的按钮组。

外观

在按钮上加 CSS 工具类,以获得不同的按钮外观显示。

使用下拉菜单

可以在按钮组中使用下拉菜单,只需要将启用下拉菜单的按钮放置于按钮组中即可。

CSS 类

按钮提供了如下 CSS 类:

类型作用
btn-group实体类元素作为按钮组组件
size-xs工具类按钮组使用超小号尺寸
size-sm工具类按钮组使用小号尺寸
size-lg工具类按钮组使用大号尺寸
size-xl工具类按钮组使用超大号尺寸

参考

MIT License (MIT)

- +
Skip to content

按钮组

按钮组可以将多个按钮成组展示。

使用方法

将多个 按钮 放置在 <div class="btn-group"> 内即可创建一个按钮组。

多组按钮

使用 CSS 工具类 .row 搭配 .gap-* 实现多组按钮效果。

尺寸

.btn-group 上配合使用工具类 size-* 来获得不同大小的按钮组。

外观

在按钮上加 CSS 工具类,以获得不同的按钮外观显示。

使用下拉菜单

可以在按钮组中使用下拉菜单,只需要将启用下拉菜单的按钮放置于按钮组中即可。

CSS 类

按钮提供了如下 CSS 类:

类型作用
btn-group实体类元素作为按钮组组件
size-xs工具类按钮组使用超小号尺寸
size-sm工具类按钮组使用小号尺寸
size-lg工具类按钮组使用大号尺寸
size-xl工具类按钮组使用超大号尺寸

参考

MIT License (MIT)

+ \ No newline at end of file diff --git a/dev/lib/components/button/index.html b/dev/lib/components/button/index.html index 4174e70c68..2ee555645a 100644 --- a/dev/lib/components/button/index.html +++ b/dev/lib/components/button/index.html @@ -14,14 +14,14 @@ - - + + -
Skip to content

按钮

按钮是用来触发一些动作。通常用在表单、对话框、菜单上面。好的按钮设计能够引导用户高效的达到目的。

使用方法

使用 .btn 类来获得按钮的外观和交互体验,通常用在元素 <button><a> 上。

配合丰富的CSS 工具类来实现不同按钮的外观。

图标按钮

按钮配合图标组件一起使用时,自动呈现为图标按钮。

外观

外观类型

配合使用CSS 工具类来实现不同按钮的外观。下面展示各种工具类的外观效果。

链接按钮

使用 .btn-link 类来获得链接按钮的外观。

按钮圆角

搭配 CSS 工具类 rounded-* 为按钮应用不同的圆角样式。

按钮阴影效果

搭配 CSS 工具类 shadow-* 为按钮应用不同的阴影样式。

尺寸

除了默认大小,按钮还提供了额外的 4 种预设尺寸。

形状

正方形按钮

通过工具类 square 可以让按钮获得正方形外观,通常作为图标按钮使用。

圆形按钮

当与工具类 circlesquare 一起使用时则获得圆形按钮。

状态

禁用状态

为按钮提供 disabled="disabled" 属性或 disabled 工具类来禁用按钮。被禁用的按钮将无法响应点击事件。

激活状态

为按钮添加 active 类启用激活状态。

加载中状态

为按钮提供动画图标实现加载中状态。

CSS 类

按钮提供了如下 CSS 类:

类型作用
btn实体类元素作为按钮组件
btn-link修饰类使用链接按钮外观
square工具类按钮使用正方形外观
size-xs工具类按钮使用超小号尺寸
size-sm工具类按钮使用小号尺寸
size-lg工具类按钮使用大号尺寸
size-xl工具类按钮使用超大号尺寸

CSS 变量

变量名称变量含义
--btn-radius按钮圆角
--btn-bg按钮背景颜色
--btn-border-color按钮边框颜色
--btn-height按钮高度

MIT License (MIT)

- +
Skip to content

按钮

按钮是用来触发一些动作。通常用在表单、对话框、菜单上面。好的按钮设计能够引导用户高效的达到目的。

使用方法

使用 .btn 类来获得按钮的外观和交互体验,通常用在元素 <button><a> 上。

配合丰富的CSS 工具类来实现不同按钮的外观。

图标按钮

按钮配合图标组件一起使用时,自动呈现为图标按钮。

外观

外观类型

配合使用CSS 工具类来实现不同按钮的外观。下面展示各种工具类的外观效果。

链接按钮

使用 .btn-link 类来获得链接按钮的外观。

按钮圆角

搭配 CSS 工具类 rounded-* 为按钮应用不同的圆角样式。

按钮阴影效果

搭配 CSS 工具类 shadow-* 为按钮应用不同的阴影样式。

尺寸

除了默认大小,按钮还提供了额外的 4 种预设尺寸。

形状

正方形按钮

通过工具类 square 可以让按钮获得正方形外观,通常作为图标按钮使用。

圆形按钮

当与工具类 circlesquare 一起使用时则获得圆形按钮。

状态

禁用状态

为按钮提供 disabled="disabled" 属性或 disabled 工具类来禁用按钮。被禁用的按钮将无法响应点击事件。

激活状态

为按钮添加 active 类启用激活状态。

加载中状态

为按钮提供动画图标实现加载中状态。

CSS 类

按钮提供了如下 CSS 类:

类型作用
btn实体类元素作为按钮组件
btn-link修饰类使用链接按钮外观
square工具类按钮使用正方形外观
size-xs工具类按钮使用超小号尺寸
size-sm工具类按钮使用小号尺寸
size-lg工具类按钮使用大号尺寸
size-xl工具类按钮使用超大号尺寸

CSS 变量

变量名称变量含义
--btn-radius按钮圆角
--btn-bg按钮背景颜色
--btn-border-color按钮边框颜色
--btn-height按钮高度

MIT License (MIT)

+ \ No newline at end of file diff --git a/dev/lib/components/color-picker/index.html b/dev/lib/components/color-picker/index.html index 9d575cead4..bc7f0a3990 100644 --- a/dev/lib/components/color-picker/index.html +++ b/dev/lib/components/color-picker/index.html @@ -14,14 +14,14 @@ - - + + -
Skip to content

颜色选择器

基于下拉选择器实现的颜色选择器。

基本使用

在选定元素上调用初始化函数即可使用颜色选择器。

自定义颜色

通过设置 colors 属性自定义颜色列表,可以指定一个表示颜色的字符串数组,也可以通过英文逗号拼接多个颜色一起指定。

自定义图标

通过设置 icon 属性自定义颜色显示图标。

同步颜色

通过为 syncValuesyncColorsyncBackgroundsyncBorder 设置选择器可实现将当前选中的颜色信息同步到相应元素。

颜色值:
文字颜色
背景色
边框色

配合使用

作为按钮

在输入组中使用

在输入框中使用

选项

名称类型默认值说明
headingstringnull颜色面板标题。 colors?: string | string[]; // 颜色选项列表。 icon?: string; // 显示为图标的名称。 closeBtn?: boolean = true; // 颜色面板是否使用关闭按钮。 syncValue?: string; // 颜色值容器选择器。 syncColor?: string; // 文本色同步容器选择器。 syncBackground?: string; // 背景色同步容器选择器。 syncBorder?: string; // 边框色同步容器选择器。

MIT License (MIT)

- +
Skip to content

颜色选择器

基于下拉选择器实现的颜色选择器。

基本使用

在选定元素上调用初始化函数即可使用颜色选择器。

自定义颜色

通过设置 colors 属性自定义颜色列表,可以指定一个表示颜色的字符串数组,也可以通过英文逗号拼接多个颜色一起指定。

自定义图标

通过设置 icon 属性自定义颜色显示图标。

同步颜色

通过为 syncValuesyncColorsyncBackgroundsyncBorder 设置选择器可实现将当前选中的颜色信息同步到相应元素。

颜色值:
文字颜色
背景色
边框色

配合使用

作为按钮

在输入组中使用

在输入框中使用

选项

名称类型默认值说明
headingstringnull颜色面板标题。 colors?: string | string[]; // 颜色选项列表。 icon?: string; // 显示为图标的名称。 closeBtn?: boolean = true; // 颜色面板是否使用关闭按钮。 syncValue?: string; // 颜色值容器选择器。 syncColor?: string; // 文本色同步容器选择器。 syncBackground?: string; // 背景色同步容器选择器。 syncBorder?: string; // 边框色同步容器选择器。

MIT License (MIT)

+ \ No newline at end of file diff --git a/dev/lib/components/contextmenu/index.html b/dev/lib/components/contextmenu/index.html index 93c33aac7a..76dfad269d 100644 --- a/dev/lib/components/contextmenu/index.html +++ b/dev/lib/components/contextmenu/index.html @@ -14,8 +14,8 @@ - - + + @@ -115,7 +115,7 @@ }); }); </script>

API

items 的单个对象属性

text

名称。

icon

左侧图标。

trailingIcon

右侧图标。

className

类名。

style

样式。

url

跳转链接地址。

target

在何处打开链接地址。

disabled

是否禁用。

active

是否是激活状态。

type

单项类型。

rootClass

menu-item 同级类名。

items

子级操作数据。

onClick

点击操作菜单项的回调事件。

- + \ No newline at end of file diff --git a/dev/lib/components/dashboard/index.html b/dev/lib/components/dashboard/index.html index 88ed6fa652..50e8e1be70 100644 --- a/dev/lib/components/dashboard/index.html +++ b/dev/lib/components/dashboard/index.html @@ -14,8 +14,8 @@ - - + + @@ -82,7 +82,7 @@ blockMenu?: ContextMenuOptions; onLayoutChange?: (blocks: BlockSetting[]) => void; }; - + \ No newline at end of file diff --git a/dev/lib/components/dropdown/index.html b/dev/lib/components/dropdown/index.html index 8b6867c25d..49a9c12ee2 100644 --- a/dev/lib/components/dropdown/index.html +++ b/dev/lib/components/dropdown/index.html @@ -14,14 +14,14 @@ - - + +
Skip to content

下拉菜单

将动作或菜单折叠到下拉菜单中。

使用方法

为触发按钮添加属性 data-toggle="dropdown",然后在触发按钮之后添加一个 .dropdown-menu 用于定义菜单列表。

关联菜单元素

你还可以在触发按钮上通过 data-target 属性来指定要打开的菜单列表元素,这样不用要求触发按钮和菜单列表元素之间必须按顺序紧邻。

手动初始化

你可以通过 new zui.Dropdown() 方法在触发按钮上动态初始化下拉菜单组件,这样无需为触发按钮添加属性 data-toggle="dropdown",以及预先创建下拉菜单列表元素 .dropdown-menu

显示箭头

通过给下拉菜单菜单按钮添加 data-arrow="true" 来使下拉菜单展示箭头。

改变箭头大小

通过给下拉菜单按钮添加 data-arrow={size} 来控制下拉菜单的箭头的大小。

data-arrow = 4
data-arrow = 8
data-arrow = 12

鼠标悬停展开菜单

为触发按钮添加属性 data-trigger="hover" 实现鼠标悬停展开菜单。

浮动方向

通过 data-placement=* 属性控制弹出方向。

data-placement = top-start
data-placement = top
data-placement = top-end
data-placement = bottom-start
data-placement = bottom
data-placement = bottom-end
data-placement = left-start
data-placement = left
data-placement = left-end
data-placement = right-start
data-placement = right
data-placement = right-end

多级子菜单

多级子菜单仅支持通过手动初始化的方式创建。

自定义菜单

通常情况下下拉菜单列表使用 <menu> 元素,你也可以替换为其他元素或内容

51015202530354045505560

禁用的菜单项

为菜单项 <li> 添加 .disabled 类即可获得禁用外观。

标题和分割线

.dropdown-menuli 标签使用 .dropdown-header类 来显示标题,使用 .divider 来创建分割线。

  • CSS 类

    按钮提供了如下 CSS 类:

    类型作用
    dropdown实体类元素作为下拉菜单组件
    dropdown-menu实体类元素作为下拉菜单列表
    dropdown-header实体类元素作为下拉菜单中的标题
    caret实体类元素作为下拉菜单icon图标
    divider实体类元素作为下拉菜单分割线
    dropup工具类下拉框浮动方向为上方

    CSS 变量

    变量名称变量含义
    --dropmenu-radius下拉菜单圆角
    --dropmenu-border-color下拉菜单边框颜色
    --dropmenu-bg下拉菜单背景颜色
    --dropmenu-active-color下拉菜单条目激活状态文字颜色
    --dropmenu-active-bg下拉菜单条目激活状态背景颜色

    API

    操作菜单定义对象。

    trigger

    触发方式

    • 类型:click | hover | manual
    • 必选:否。

    arrow

    箭头大小 为 true 则为默认12

    • 类型:boolean | number
    • 必选:否。

    offset

    偏移量

    • 类型:number
    • 必选:否。

    菜单对象 详细配置可参考 菜单

    • 类型:object
    • 必选:否。

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/lib/components/dtable/index.html b/dev/lib/components/dtable/index.html index c1394845d8..6253253849 100644 --- a/dev/lib/components/dtable/index.html +++ b/dev/lib/components/dtable/index.html @@ -14,8 +14,8 @@ - - + + @@ -360,7 +360,7 @@ render(): void; } - + \ No newline at end of file diff --git a/dev/lib/components/dtable/plugins.html b/dev/lib/components/dtable/plugins.html index 74b3227aea..c790451d1a 100644 --- a/dev/lib/components/dtable/plugins.html +++ b/dev/lib/components/dtable/plugins.html @@ -14,8 +14,8 @@ - - + + @@ -750,7 +750,7 @@ /* 表头分组名称。 */ headerGroup?: string; }

    更多插件开发中

    - + \ No newline at end of file diff --git a/dev/lib/components/file-selector/index.html b/dev/lib/components/file-selector/index.html index 56c5f26bd8..bc16c4352d 100644 --- a/dev/lib/components/file-selector/index.html +++ b/dev/lib/components/file-selector/index.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    文件选择

    界面模式

    文件选择器支持多种界面模式,包括按钮模式、方框模式和网格模式,另外还提供了单独的图片选择器用于选择图片文件。

    按钮模式

    默认模式为按钮模式,点击按钮选择文件,所选择的文件会显示在按钮上方。

    方框模式

    通过设置 mode 属性为 'box' 可以切换为方框模式,所选择的文件会显示在方框下方。方框模式提供了更大的拖放文件放置区域。

    网格模式

    通过设置 mode 属性为 'grid' 可以切换为网格模式,所选择的文件会显示在网格中。网格模式提供了更大的文件预览区域。

    图片选择

    图片选择是基于网格模式的一种预设模式,通过 ImageSelector 可以快速创建一个图片选择器。

    文件限制

    限制文件类型

    通过 accept 来限制文件类型,可以使用 MIME 类型、文件扩展名或通配符,定义与 HTML 的 accept 属性相同。

    限制文件大小

    通过 maxFileSize 来限制单个文件大小,通过 totalFileSize 来限制总文件大小。

    限制文件数目

    通过 maxFileCount 来限制文件数目,如果设置为非大于 0 的数则不限制。

    预设文件

    通过设置 defaultFiles 属性可以预设文件列表,预设文件不会触发 onAdd 回调函数和 onSelect 回调函数。

    禁用

    通过设置 disabled 属性为 true 可以禁用文件选择器。

    个性化配置

    提示信息

    通过 tip 属性可以设置提示信息,在提示信息中可以使用如下占位文本:

    • {size}:文件总大小;
    • {count}:文件数目;
    • {maxFileSize}:最大文件大小;
    • {maxFileCount}:最大文件数目。

    文件图标

    通过设置 fileIcons 属性可以为不同类型的文件(根据扩展名)显示不同的图标。

    显示缩略图

    默认会为图片文件显示缩略图,通过设置 thumbnail 属性为 false 可以关闭缩略图显示。

    文件拖放

    默认情况下用户可以拖放文件到文件选择器中,通过设置 draggable 属性为 false 可以禁用拖放。

    一次选择一个文件

    默认情况下用户可以在操作系统文件选择对话框中一次选择多个文件,通过设置 multiple 属性为 false 可以限制一次只能选择一个文件。

    网格模式配置

    网格模式下可以通过设置 gridWidthgridHeightgridGap 来调整网格的宽度、高度和间距。

    自定义文件上传按钮

    通过设置 uploadBtn 属性可以自定义文件上传按钮。

    文件操作

    文件重命名

    默认情况下支持对文件进行重命名,通过设置 renameBtn 属性为 false 可以禁用重命名按钮,通过为 renameBtn 属性设置字符串可以自定义重命名按钮的文字,通过为 renameBtn 属性设置对象可以自定义重命名按钮。

    文件移除

    默认情况下支持对文件进行移除,通过设置 removeBtn 属性为 false 可以禁用移除按钮,通过为 removeBtn 属性设置字符串可以自定义移除按钮的文字,通过为 removeBtn 属性设置对象可以自定义移除按钮。

    自定义操作提示信息

    通过设置 removeConfirmduplicatedTipexceededSizeTipexceededTotalSizeTipexceededCountTip 属性可以自定义操作提示信息。

    在提示信息中可以使用如下占位文本:

    • {name}:当前文件名;
    • {size}:当前文件大小;
    • {count}:当前已选择文件数目;
    • {maxFileSize}:最大文件大小;
    • {maxFileCount}:最大文件数目;
    • {totalFileSize}:最大文件数目,仅适用于 exceededTotalSizeTip 提示;
    • {exceededCount}:超出数量,仅适用于 exceededCountTip 提示。

    操作拦截

    通过设置 onRenameonRemoveonAddonRemove 选项设置回调函数可以拦截文件操作,通常在回调函数中返回 false 可以阻止继续操作,相关回调函数定义参加选项和 API。

    文件限制拦截

    通过设置 onDuplicatedonExceededSizeonExceededTotalSizeonExceededCount 选项可以在触发文件限制时拦截文件操作,通过在回调函数中返回 true 来忽略文件限制,相关回调函数定义参加选项和 API。

    选项

    FileSelectorProps

    名称类型默认值说明
    namestringnull作为表单字段的名称。 accept?: string; // 限制文件类型。 disabled?: boolean; // 是否禁用。 mode?: 'button' | 'box' | 'grid' = "button"; // 界面模式。 tip?: string; // 提示信息。 thumbnail?: boolean=true; // 是否显示缩略图。 gridWidth?: string | number; // 网格模式的宽度。 gridHeight?: string | number; // 网格模式的高度。 gridGap?: string | number; // 网格模式的间距。 defaultFiles?: DefaltFileInfo[]; // 默认显示的文件列表。 multiple?: boolean = true; // 是否允许在文件选择对话框中一次性选择多个文件(需要操作系统支持)。 itemProps?: ButtonProps | FileButtonGenerator; // 文件项的属性。 draggable?: boolean = true; // 是否允许拖拽。 fileIcons?: IconType | Record = "file"; // 文件图标。 uploadBtn?: string | ButtonProps; // 上传按钮。 renameBtn?: boolean | string | ButtonProps | FileButtonGenerator = true; // 重命名按钮。 removeBtn?: boolean | string | ButtonProps | FileButtonGenerator = true; // 删除按钮。 removeConfirm?: string | ModalConfirmOptions; // 删除确认提示。 maxFileSize?: FileSize = "100MB"; // 限制文件大小。 maxFileCount?: number = 0; // 限制文件数目,如果设置为非大于 0 的数则不限制。 totalFileSize?: FileSize; // 限制总文件大小,如果设置为非大于 0 的数则不限制。 allowSameName?: boolean; // 是否允许同名文件。 duplicatedTip?: string | ModalAlertOptions; // 重名提示。 exceededSizeTip?: string | ModalAlertOptions; // 超出大小提示。 exceededTotalSizeTip?: string | ModalAlertOptions; // 超出总大小提示。 exceededCountTip?: string | ModalAlertOptions; // 超出数量提示。 onSelect?: FileSelectCallback; // 选择文件时的回调。 onAdd?: FileAddCallback; // 添加文件时的回调。 onRemove?: RemoveFileCallback; // 删除文件时的回调。 onRename?: RenameFileCallback; // 重命名文件时的回调,返回 false 取消重命名。 onDuplicated?: DuplicatedCallback; // 重名时的回调,返回 true 保留重复文件。 onExceededSize?: ExceededLimitCallback; // 超出大小时的回调,返回 true 保留超出大小文件。 onExceededTotalSize?: ExceededLimitCallback; // 超出总大小时的回调,返回 true 保留超出总大小文件。 onExceededCount?: ExceededLimitCallback; // 超出数量时的回调,返回 true 保留超出数量文件。

    API

    FileInfo

    文件信息对象。

    名称类型默认值说明
    namestring文件名。 size: number; // 文件大小。 id: string; // 文件唯一标识。 type: string; // 文件类型。 ext: string; // 文件扩展名。 url?: string; // 文件地址。 file?: File; // 文件对象。

    StaticFileInfo

    预设文件信息对象。

    名称类型默认值说明
    namestring文件名。 size: FileSize; // 文件大小。 type?: string; // 文件类型。 id?: string; // 文件唯一标识。 url?: string; // 文件地址。

    FileSize

    文件大小,字节数或带单位的大小,例如 1024'1KB'

    ts
    type FileSize = number | `${number}${'B' | 'KB' | 'MB' | 'GB' | 'TB'}`;

    DefaltFileInfo

    默认文件信息对象。

    ts
    type DefaltFileInfo = File | FileInfo | StaticFileInfo;

    FileButtonGenerator

    文件操作按钮属性生成器,返回 false 不显示按钮,返回 true 使用默认按钮,返回字符串使用默认按钮并设置文字,返回对象使用自定义按钮。

    ts
    type FileButtonGenerator = ((file: FileInfo) => (boolean | string | ButtonProps));

    FileAddCallback

    添加文件时的回调函数,返回 false 取消添加文件。

    ts
    type FileAddCallback = (file: FileInfo) => void | false;

    FileSelectCallback

    选择文件时的回调函数。

    ts
    type FileSelectCallback = (files: File[] | FileList) => void | false;

    RemoveFileCallback

    删除文件时的回调函数。

    ts
    (file: FileInfo) => void | false | Promise<void | false>;

    RenameFileCallback

    重命名文件时的回调函数,返回 false 取消重命名。

    ts
    type RenameFileCallback = (newName: string, oldName: string, file: FileInfo) => void | false | Promise<void | false>;

    DuplicatedCallback

    重名时的回调,返回 true 保留重复文件。

    ts
    type DuplicatedCallback = (name: string, currentFile: FileInfo, existFile: FileInfo) => void | true;

    ExceededLimitCallback

    超出限制时的回调函数,返回 true 忽略限制,否则取消添加文件。

    ts
    type ExceededLimitCallback = (limit: number, file: FileInfo) => void | true;

    MIT License (MIT)

    - +
    Skip to content

    文件选择

    界面模式

    文件选择器支持多种界面模式,包括按钮模式、方框模式和网格模式,另外还提供了单独的图片选择器用于选择图片文件。

    按钮模式

    默认模式为按钮模式,点击按钮选择文件,所选择的文件会显示在按钮上方。

    方框模式

    通过设置 mode 属性为 'box' 可以切换为方框模式,所选择的文件会显示在方框下方。方框模式提供了更大的拖放文件放置区域。

    网格模式

    通过设置 mode 属性为 'grid' 可以切换为网格模式,所选择的文件会显示在网格中。网格模式提供了更大的文件预览区域。

    图片选择

    图片选择是基于网格模式的一种预设模式,通过 ImageSelector 可以快速创建一个图片选择器。

    文件限制

    限制文件类型

    通过 accept 来限制文件类型,可以使用 MIME 类型、文件扩展名或通配符,定义与 HTML 的 accept 属性相同。

    限制文件大小

    通过 maxFileSize 来限制单个文件大小,通过 totalFileSize 来限制总文件大小。

    限制文件数目

    通过 maxFileCount 来限制文件数目,如果设置为非大于 0 的数则不限制。

    预设文件

    通过设置 defaultFiles 属性可以预设文件列表,预设文件不会触发 onAdd 回调函数和 onSelect 回调函数。

    禁用

    通过设置 disabled 属性为 true 可以禁用文件选择器。

    个性化配置

    提示信息

    通过 tip 属性可以设置提示信息,在提示信息中可以使用如下占位文本:

    • {size}:文件总大小;
    • {count}:文件数目;
    • {maxFileSize}:最大文件大小;
    • {maxFileCount}:最大文件数目。

    文件图标

    通过设置 fileIcons 属性可以为不同类型的文件(根据扩展名)显示不同的图标。

    显示缩略图

    默认会为图片文件显示缩略图,通过设置 thumbnail 属性为 false 可以关闭缩略图显示。

    文件拖放

    默认情况下用户可以拖放文件到文件选择器中,通过设置 draggable 属性为 false 可以禁用拖放。

    一次选择一个文件

    默认情况下用户可以在操作系统文件选择对话框中一次选择多个文件,通过设置 multiple 属性为 false 可以限制一次只能选择一个文件。

    网格模式配置

    网格模式下可以通过设置 gridWidthgridHeightgridGap 来调整网格的宽度、高度和间距。

    自定义文件上传按钮

    通过设置 uploadBtn 属性可以自定义文件上传按钮。

    文件操作

    文件重命名

    默认情况下支持对文件进行重命名,通过设置 renameBtn 属性为 false 可以禁用重命名按钮,通过为 renameBtn 属性设置字符串可以自定义重命名按钮的文字,通过为 renameBtn 属性设置对象可以自定义重命名按钮。

    文件移除

    默认情况下支持对文件进行移除,通过设置 removeBtn 属性为 false 可以禁用移除按钮,通过为 removeBtn 属性设置字符串可以自定义移除按钮的文字,通过为 removeBtn 属性设置对象可以自定义移除按钮。

    自定义操作提示信息

    通过设置 removeConfirmduplicatedTipexceededSizeTipexceededTotalSizeTipexceededCountTip 属性可以自定义操作提示信息。

    在提示信息中可以使用如下占位文本:

    • {name}:当前文件名;
    • {size}:当前文件大小;
    • {count}:当前已选择文件数目;
    • {maxFileSize}:最大文件大小;
    • {maxFileCount}:最大文件数目;
    • {totalFileSize}:最大文件数目,仅适用于 exceededTotalSizeTip 提示;
    • {exceededCount}:超出数量,仅适用于 exceededCountTip 提示。

    操作拦截

    通过设置 onRenameonRemoveonAddonRemove 选项设置回调函数可以拦截文件操作,通常在回调函数中返回 false 可以阻止继续操作,相关回调函数定义参加选项和 API。

    文件限制拦截

    通过设置 onDuplicatedonExceededSizeonExceededTotalSizeonExceededCount 选项可以在触发文件限制时拦截文件操作,通过在回调函数中返回 true 来忽略文件限制,相关回调函数定义参加选项和 API。

    选项

    FileSelectorProps

    名称类型默认值说明
    namestringnull作为表单字段的名称。 accept?: string; // 限制文件类型。 disabled?: boolean; // 是否禁用。 mode?: 'button' | 'box' | 'grid' = "button"; // 界面模式。 tip?: string; // 提示信息。 thumbnail?: boolean=true; // 是否显示缩略图。 gridWidth?: string | number; // 网格模式的宽度。 gridHeight?: string | number; // 网格模式的高度。 gridGap?: string | number; // 网格模式的间距。 defaultFiles?: DefaltFileInfo[]; // 默认显示的文件列表。 multiple?: boolean = true; // 是否允许在文件选择对话框中一次性选择多个文件(需要操作系统支持)。 itemProps?: ButtonProps | FileButtonGenerator; // 文件项的属性。 draggable?: boolean = true; // 是否允许拖拽。 fileIcons?: IconType | Record = "file"; // 文件图标。 uploadBtn?: string | ButtonProps; // 上传按钮。 renameBtn?: boolean | string | ButtonProps | FileButtonGenerator = true; // 重命名按钮。 removeBtn?: boolean | string | ButtonProps | FileButtonGenerator = true; // 删除按钮。 removeConfirm?: string | ModalConfirmOptions; // 删除确认提示。 maxFileSize?: FileSize = "100MB"; // 限制文件大小。 maxFileCount?: number = 0; // 限制文件数目,如果设置为非大于 0 的数则不限制。 totalFileSize?: FileSize; // 限制总文件大小,如果设置为非大于 0 的数则不限制。 allowSameName?: boolean; // 是否允许同名文件。 duplicatedTip?: string | ModalAlertOptions; // 重名提示。 exceededSizeTip?: string | ModalAlertOptions; // 超出大小提示。 exceededTotalSizeTip?: string | ModalAlertOptions; // 超出总大小提示。 exceededCountTip?: string | ModalAlertOptions; // 超出数量提示。 onSelect?: FileSelectCallback; // 选择文件时的回调。 onAdd?: FileAddCallback; // 添加文件时的回调。 onRemove?: RemoveFileCallback; // 删除文件时的回调。 onRename?: RenameFileCallback; // 重命名文件时的回调,返回 false 取消重命名。 onDuplicated?: DuplicatedCallback; // 重名时的回调,返回 true 保留重复文件。 onExceededSize?: ExceededLimitCallback; // 超出大小时的回调,返回 true 保留超出大小文件。 onExceededTotalSize?: ExceededLimitCallback; // 超出总大小时的回调,返回 true 保留超出总大小文件。 onExceededCount?: ExceededLimitCallback; // 超出数量时的回调,返回 true 保留超出数量文件。

    API

    FileInfo

    文件信息对象。

    名称类型默认值说明
    namestring文件名。 size: number; // 文件大小。 id: string; // 文件唯一标识。 type: string; // 文件类型。 ext: string; // 文件扩展名。 url?: string; // 文件地址。 file?: File; // 文件对象。

    StaticFileInfo

    预设文件信息对象。

    名称类型默认值说明
    namestring文件名。 size: FileSize; // 文件大小。 type?: string; // 文件类型。 id?: string; // 文件唯一标识。 url?: string; // 文件地址。

    FileSize

    文件大小,字节数或带单位的大小,例如 1024'1KB'

    ts
    type FileSize = number | `${number}${'B' | 'KB' | 'MB' | 'GB' | 'TB'}`;

    DefaltFileInfo

    默认文件信息对象。

    ts
    type DefaltFileInfo = File | FileInfo | StaticFileInfo;

    FileButtonGenerator

    文件操作按钮属性生成器,返回 false 不显示按钮,返回 true 使用默认按钮,返回字符串使用默认按钮并设置文字,返回对象使用自定义按钮。

    ts
    type FileButtonGenerator = ((file: FileInfo) => (boolean | string | ButtonProps));

    FileAddCallback

    添加文件时的回调函数,返回 false 取消添加文件。

    ts
    type FileAddCallback = (file: FileInfo) => void | false;

    FileSelectCallback

    选择文件时的回调函数。

    ts
    type FileSelectCallback = (files: File[] | FileList) => void | false;

    RemoveFileCallback

    删除文件时的回调函数。

    ts
    (file: FileInfo) => void | false | Promise<void | false>;

    RenameFileCallback

    重命名文件时的回调函数,返回 false 取消重命名。

    ts
    type RenameFileCallback = (newName: string, oldName: string, file: FileInfo) => void | false | Promise<void | false>;

    DuplicatedCallback

    重名时的回调,返回 true 保留重复文件。

    ts
    type DuplicatedCallback = (name: string, currentFile: FileInfo, existFile: FileInfo) => void | true;

    ExceededLimitCallback

    超出限制时的回调函数,返回 true 忽略限制,否则取消添加文件。

    ts
    type ExceededLimitCallback = (limit: number, file: FileInfo) => void | true;

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/components/kanban/index.html b/dev/lib/components/kanban/index.html index dc545d7020..5139acb87b 100644 --- a/dev/lib/components/kanban/index.html +++ b/dev/lib/components/kanban/index.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/lib/components/label/index.html b/dev/lib/components/label/index.html index e5eb18c284..e4fe71a3dc 100644 --- a/dev/lib/components/label/index.html +++ b/dev/lib/components/label/index.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    标签

    标签通常用于对内容进行标记。

    使用方法

    使用 .label 类来获得标签的外观和交互体验,通常用在元素 <span> 上。

    标签

    外观类型

    配合丰富的CSS 工具类来实现不同标签的外观。

    主要标签黑色标签描边浅色

    尺寸

    除了默认大小,标签还提供了额外的 2 种预设尺寸。

    小标签普通大小大标签

    圆角

    通过工具类 rounded-* 来应用不同的圆角样式。

    无圆角小圆角普通圆角中等圆角大圆角超大圆角完整圆角

    圆点标签

    当与工具类 label-dot 一起使用时则获得圆点标签。

    与按钮组合使用

    CSS 类

    标签提供了如下 CSS 类:

    类型作用
    label实体类元素作为标签组件
    label-dot工具类标签使用圆形外观
    size-sm工具类标签使用小号尺寸
    size-lg工具类标签使用大号尺寸

    CSS 变量

    变量名称变量含义
    --label-bg标签背景色
    --label-color标签文字颜色
    --label-border-color标签边框颜色
    --label-radius标签圆角

    MIT License (MIT)

    - +
    Skip to content

    标签

    标签通常用于对内容进行标记。

    使用方法

    使用 .label 类来获得标签的外观和交互体验,通常用在元素 <span> 上。

    标签

    外观类型

    配合丰富的CSS 工具类来实现不同标签的外观。

    主要标签黑色标签描边浅色

    尺寸

    除了默认大小,标签还提供了额外的 2 种预设尺寸。

    小标签普通大小大标签

    圆角

    通过工具类 rounded-* 来应用不同的圆角样式。

    无圆角小圆角普通圆角中等圆角大圆角超大圆角完整圆角

    圆点标签

    当与工具类 label-dot 一起使用时则获得圆点标签。

    与按钮组合使用

    CSS 类

    标签提供了如下 CSS 类:

    类型作用
    label实体类元素作为标签组件
    label-dot工具类标签使用圆形外观
    size-sm工具类标签使用小号尺寸
    size-lg工具类标签使用大号尺寸

    CSS 变量

    变量名称变量含义
    --label-bg标签背景色
    --label-color标签文字颜色
    --label-border-color标签边框颜色
    --label-radius标签圆角

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/components/menu/index.html b/dev/lib/components/menu/index.html index cd0c7d5fec..cf1b7172c7 100644 --- a/dev/lib/components/menu/index.html +++ b/dev/lib/components/menu/index.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    菜单

    菜单用于展示一个操作列表,也可以用于构建更复杂的组件,例如右键菜单、下拉菜单等。如果需要通过 JS 动态创建菜单,可以使用菜单生成器

    使用方法

    使用类 .menu.menu-item 按照如下结构来构建一个静态菜单:

    标题

    使用类 .menu-heading 来创建一个标题:

    分割线

    使用类 .divider 来添加一个分割线:

    包含图标

    可以在菜单项内添加图标,但如果是部分菜单项拥有图标,可以通过为 .menu 添加工具类 .has-icons 来让图标以及文本进行对齐:

    禁用的菜单项

    .menu-item 添加工具类 .disabled 来将菜单项禁用:

    标记激活项

    .menu-item 内的 <a> 元素添加工具类 .active 来将菜单项标记为激活状态:

    标记选中项

    .menu-item 内的 <a> 元素添加工具类 .active 来将菜单项标记为选中项状态:

    尾部图标

    直接将图标 .icon 元素添加到菜单项 .menu-item 内尾部,图标将自动靠右侧对齐:

    自定义菜单项

    .menu 内可以放置其他内容来自定义菜单项:

    CSS 类

    头像提供了如下 CSS 类:

    类型作用
    menu实体类元素作为菜单
    menu-item实体类元素作为菜单项
    menu-heading实体类元素作为菜单标题
    divider实体类元素作为分割线
    has-icons工具类menu 一起使用,标记菜单内包含图标
    active工具类标记菜单项为激活状态
    selected工具类标记菜单项为选中状态
    disabled工具类标记菜单项为禁用状态

    CSS 变量

    头像提供了如下 CSS 变量,可进行全局修改:

    CSS 变量名作用默认值
    --menu-radius菜单圆角var(--radius)
    --menu-bg菜单背景颜色var(--color-canvas)
    --menu-border菜单边框1px solid var(--color-border)
    --menu-shadow菜单阴影var(--shadow-lg)
    --menu-hover-bg菜单项鼠标悬停背景色var(--color-primary-500)
    --menu-hover-color菜单项鼠标悬停文字颜色var(--color-canvas)
    --menu-active-bg菜单项激活状态背景色var(--color-primary-50)
    --menu-active-color菜单项激活状态文字颜色var(--color-primary-500)
    --menu-icon-opacity菜单项图标透明度.5
    --menu-heading-color菜单标题文字颜色var(--color-gray-500)

    MIT License (MIT)

    - +
    Skip to content

    菜单

    菜单用于展示一个操作列表,也可以用于构建更复杂的组件,例如右键菜单、下拉菜单等。如果需要通过 JS 动态创建菜单,可以使用菜单生成器

    使用方法

    使用类 .menu.menu-item 按照如下结构来构建一个静态菜单:

    标题

    使用类 .menu-heading 来创建一个标题:

    分割线

    使用类 .divider 来添加一个分割线:

    包含图标

    可以在菜单项内添加图标,但如果是部分菜单项拥有图标,可以通过为 .menu 添加工具类 .has-icons 来让图标以及文本进行对齐:

    禁用的菜单项

    .menu-item 添加工具类 .disabled 来将菜单项禁用:

    标记激活项

    .menu-item 内的 <a> 元素添加工具类 .active 来将菜单项标记为激活状态:

    标记选中项

    .menu-item 内的 <a> 元素添加工具类 .active 来将菜单项标记为选中项状态:

    尾部图标

    直接将图标 .icon 元素添加到菜单项 .menu-item 内尾部,图标将自动靠右侧对齐:

    自定义菜单项

    .menu 内可以放置其他内容来自定义菜单项:

    CSS 类

    头像提供了如下 CSS 类:

    类型作用
    menu实体类元素作为菜单
    menu-item实体类元素作为菜单项
    menu-heading实体类元素作为菜单标题
    divider实体类元素作为分割线
    has-icons工具类menu 一起使用,标记菜单内包含图标
    active工具类标记菜单项为激活状态
    selected工具类标记菜单项为选中状态
    disabled工具类标记菜单项为禁用状态

    CSS 变量

    头像提供了如下 CSS 变量,可进行全局修改:

    CSS 变量名作用默认值
    --menu-radius菜单圆角var(--radius)
    --menu-bg菜单背景颜色var(--color-canvas)
    --menu-border菜单边框1px solid var(--color-border)
    --menu-shadow菜单阴影var(--shadow-lg)
    --menu-hover-bg菜单项鼠标悬停背景色var(--color-primary-500)
    --menu-hover-color菜单项鼠标悬停文字颜色var(--color-canvas)
    --menu-active-bg菜单项激活状态背景色var(--color-primary-50)
    --menu-active-color菜单项激活状态文字颜色var(--color-primary-500)
    --menu-icon-opacity菜单项图标透明度.5
    --menu-heading-color菜单标题文字颜色var(--color-gray-500)

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/components/menu/js.html b/dev/lib/components/menu/js.html index c0c381d3b1..bd2054c2ce 100644 --- a/dev/lib/components/menu/js.html +++ b/dev/lib/components/menu/js.html @@ -14,8 +14,8 @@ - - + + @@ -150,7 +150,7 @@ key?: string | number, items?: MenuListItem[], }; - + \ No newline at end of file diff --git a/dev/lib/components/messager/index.html b/dev/lib/components/messager/index.html index 67912af24b..44a7dab1d9 100644 --- a/dev/lib/components/messager/index.html +++ b/dev/lib/components/messager/index.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    浮动消息

    通过 JS 动态创建一个浮动消息。

    基本用法

    通过构造一个 messager 实例,页面上创建一个浮动消息。

    显示位置

    提供 9 个预设的显示位置,通过 placement 选项进行指定。

    颜色主题

    提供多种预设颜色主题,通过 type 选项指定外观工具类即可。

    禁用关闭按钮

    默认会在右侧显示关闭按钮,如果需要禁用关闭按钮,将 close 选项设置为 false

    自定义操作按钮

    通过 actions 数组来自定义一组操作。详细配置可参考 工具栏

    禁用自动隐藏

    默认超过 5000ms 自动隐藏,通过设置 time0 取消自动隐藏。

    禁用动画效果

    设置 animationfalse 禁用动画效果。

    选项

    名称类型默认值说明
    typestringnull消息类型 placement?: string; // 浮动消息定位方式,支持 'top' | 'center' | 'bottom' | 'left-top' | 'left' | 'left-bottom' | 'right' | 'right-top' | 'right-bottom' time?: number; // 浮动消息持续时间 content?: string; // 浮动消息内容 icon?: string; // 图标名称 actions?: object[]; // 操作按钮定义列表 margin?: number; // 外边距

    MIT License (MIT)

    - +
    Skip to content

    浮动消息

    通过 JS 动态创建一个浮动消息。

    基本用法

    通过构造一个 messager 实例,页面上创建一个浮动消息。

    显示位置

    提供 9 个预设的显示位置,通过 placement 选项进行指定。

    颜色主题

    提供多种预设颜色主题,通过 type 选项指定外观工具类即可。

    禁用关闭按钮

    默认会在右侧显示关闭按钮,如果需要禁用关闭按钮,将 close 选项设置为 false

    自定义操作按钮

    通过 actions 数组来自定义一组操作。详细配置可参考 工具栏

    禁用自动隐藏

    默认超过 5000ms 自动隐藏,通过设置 time0 取消自动隐藏。

    禁用动画效果

    设置 animationfalse 禁用动画效果。

    选项

    名称类型默认值说明
    typestringnull消息类型 placement?: string; // 浮动消息定位方式,支持 'top' | 'center' | 'bottom' | 'left-top' | 'left' | 'left-bottom' | 'right' | 'right-top' | 'right-bottom' time?: number; // 浮动消息持续时间 content?: string; // 浮动消息内容 icon?: string; // 图标名称 actions?: object[]; // 操作按钮定义列表 margin?: number; // 外边距

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/components/modal/index.html b/dev/lib/components/modal/index.html index a1b2e4faba..c5af7b898d 100644 --- a/dev/lib/components/modal/index.html +++ b/dev/lib/components/modal/index.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    对话框

    在保留当前页面状态的情况下,直接使用触发按钮即可展现对话框,告知用户展示相关操作。

    使用方法

    使用 .modal.modal-dialog 类获得对话框的外观展示,通常用在元素 <div> 上。使用 [data-toggle="modal"] 指定对话框触发按钮,在触发按钮上通过 data-target 属性指定要打开的对话框。

    点击 a 标签按钮打开

    自定义位置

    使用 data-position 自定义设置对话框位置。可设置 fitcenter 或其具体像素值。

    尺寸

    除了默认大小,还提供了额外的 3 种预设尺寸。

    信息提示

    展示各种类型的信息提示,只提供一个按钮用于关闭。

    控制遮罩层

    通过 data-backdrop="false" 移除遮罩层,设置后可以操作模态框之外的交互。

    CSS 类

    对话框提供了如下 CSS 类:

    类型作用
    modal实体类元素作为对话框遮罩组件
    modal-dialog实体类元素作为对话框组件
    size-sm工具类对话框使用小号尺寸
    size-lg工具类对话框使用大号尺寸
    size-xl工具类对话框使用超大号尺寸

    CSS 变量

    对话框提供了如下 CSS 变量,可进行全局修改。

    CSS 变量名作用
    --modal-radius对话框默认圆角大小
    --modal-bg对话框遮挡层颜色
    --modal-sm对话框小号尺寸宽度
    --modal-base对话框默认宽度
    --modal-lg对话框大号尺寸宽度
    --modal-xl对话框超大号尺寸宽度

    MIT License (MIT)

    - +
    Skip to content

    对话框

    在保留当前页面状态的情况下,直接使用触发按钮即可展现对话框,告知用户展示相关操作。

    使用方法

    使用 .modal.modal-dialog 类获得对话框的外观展示,通常用在元素 <div> 上。使用 [data-toggle="modal"] 指定对话框触发按钮,在触发按钮上通过 data-target 属性指定要打开的对话框。

    点击 a 标签按钮打开

    自定义位置

    使用 data-position 自定义设置对话框位置。可设置 fitcenter 或其具体像素值。

    尺寸

    除了默认大小,还提供了额外的 3 种预设尺寸。

    信息提示

    展示各种类型的信息提示,只提供一个按钮用于关闭。

    控制遮罩层

    通过 data-backdrop="false" 移除遮罩层,设置后可以操作模态框之外的交互。

    CSS 类

    对话框提供了如下 CSS 类:

    类型作用
    modal实体类元素作为对话框遮罩组件
    modal-dialog实体类元素作为对话框组件
    size-sm工具类对话框使用小号尺寸
    size-lg工具类对话框使用大号尺寸
    size-xl工具类对话框使用超大号尺寸

    CSS 变量

    对话框提供了如下 CSS 变量,可进行全局修改。

    CSS 变量名作用
    --modal-radius对话框默认圆角大小
    --modal-bg对话框遮挡层颜色
    --modal-sm对话框小号尺寸宽度
    --modal-base对话框默认宽度
    --modal-lg对话框大号尺寸宽度
    --modal-xl对话框超大号尺寸宽度

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/components/modal/trigger.html b/dev/lib/components/modal/trigger.html index c29a64c389..0b60957fa1 100644 --- a/dev/lib/components/modal/trigger.html +++ b/dev/lib/components/modal/trigger.html @@ -14,8 +14,8 @@ - - + + @@ -55,7 +55,7 @@ /* 当用户点击确认或取消时的回调函数 */ onResult?: (confirmed: boolean, modal: Modal) => void; }

    该方法会通过 Promise 异步返回用户点击的按钮名称。

    下面为一个示例:

    - + \ No newline at end of file diff --git a/dev/lib/components/nav/index.html b/dev/lib/components/nav/index.html index fb6bfbcfef..fd88b76182 100644 --- a/dev/lib/components/nav/index.html +++ b/dev/lib/components/nav/index.html @@ -14,17 +14,17 @@ - - + + -
    Skip to content

    导航

    基础用法

    使用组件类 .nav 来获得导航外观 通常搭配 <ul><menu><li> 标签来使用。

    带标题的导航

    可以通过 CSS 类 nav-heading 给导航项设置标题样式。

    html
    <menu class="nav">
    +    
    Skip to content

    导航

    基础用法

    使用组件类 .nav 来获得导航外观 通常搭配 <ul><menu><li> 标签来使用。

    带标题的导航

    可以通过 CSS 类 nav-heading 给导航项设置标题样式。

    html
    <menu class="nav">
       <li class="nav-heading">导航标题</li>
       ...
    -</menu>

    导航样式

    除了默认样式,还可以通过修饰类为导航应用不同的样式。

    主要导航 .nav-primary

    次要导航 .nav-secondary

    圆点导航 .nav-pills

    标签导航 .nav-tabs

    步骤条 .nav-steps

    垂直排列

    使用修饰类 nav-stacked 使导航获得垂直排列样式,可搭配其他各种样式的导航使用。

    .nav-primary
    .nav-secondary
    .nav-pills
    .nav-tabs

    自适应宽度的导航

    使用修饰类 nav-justified 使导航获得自适应宽度样式,可搭配其他各种样式的导航使用。

    提示

    自适应宽度修饰类不能和垂直排列修饰类混用。

    CSS 类

    导航提供了如下 CSS 类

    类型作用
    nav实体类元素导航组件
    nav-item实体类元素导航条目组件
    nav-heading实体类导航标题组件
    nav-divider实体类导航分割线组件
    active修饰类为导航元素启用选中态样式
    nav-simple修饰类为导航元素启用简单样式
    nav-primary修饰类为导航元素启用主要导航样式
    nav-secondary修饰类为导航元素启用次要导航样式
    nav-tabs修饰类为导航元素启用标签风格导航样式
    nav-pills修饰类为导航元素启用标签风格导航样式
    nav-stacked修饰类为导航元素启用垂直排列导航样式
    nav-justified修饰类为导航元素启用自适应宽度导航样式

    CSS 变量

    变量名称变量含义
    --nav-heading-color导航标题字体颜色

    MIT License (MIT)

    - +</menu>

    导航样式

    除了默认样式,还可以通过修饰类为导航应用不同的样式。

    主要导航 .nav-primary

    次要导航 .nav-secondary

    圆点导航 .nav-pills

    标签导航 .nav-tabs

    步骤条 .nav-steps

    垂直排列

    使用修饰类 nav-stacked 使导航获得垂直排列样式,可搭配其他各种样式的导航使用。

    .nav-primary
    .nav-secondary
    .nav-pills
    .nav-tabs

    自适应宽度的导航

    使用修饰类 nav-justified 使导航获得自适应宽度样式,可搭配其他各种样式的导航使用。

    提示

    自适应宽度修饰类不能和垂直排列修饰类混用。

    CSS 类

    导航提供了如下 CSS 类

    类型作用
    nav实体类元素导航组件
    nav-item实体类元素导航条目组件
    nav-heading实体类导航标题组件
    nav-divider实体类导航分割线组件
    active修饰类为导航元素启用选中态样式
    nav-simple修饰类为导航元素启用简单样式
    nav-primary修饰类为导航元素启用主要导航样式
    nav-secondary修饰类为导航元素启用次要导航样式
    nav-tabs修饰类为导航元素启用标签风格导航样式
    nav-pills修饰类为导航元素启用标签风格导航样式
    nav-stacked修饰类为导航元素启用垂直排列导航样式
    nav-justified修饰类为导航元素启用自适应宽度导航样式

    CSS 变量

    变量名称变量含义
    --nav-heading-color导航标题字体颜色

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/components/nav/js.html b/dev/lib/components/nav/js.html index 445fa33a15..0e4e93231f 100644 --- a/dev/lib/components/nav/js.html +++ b/dev/lib/components/nav/js.html @@ -14,8 +14,8 @@ - - + + @@ -62,7 +62,7 @@ afterRender?: (info: {nav: nav, firstRender: boolean}) => void; beforeDestroy?: (info: {nav: nav}) => void; } - + \ No newline at end of file diff --git a/dev/lib/components/pager/index.html b/dev/lib/components/pager/index.html index 3421d8fd0f..3bf69da52a 100644 --- a/dev/lib/components/pager/index.html +++ b/dev/lib/components/pager/index.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    分页

    使用方法

    将多个按钮放置在 <div class="pager"> 内即可创建一个分页组件。

    简洁样式

    简单的翻页。

    状态

    为分页按钮添加 active 类标记选中,添加 disabled 类来禁用页码,被禁用的页码将无法响应点击事件。

    外观

    分页按钮间距

    使用 gap-* CSS 工具类 可获得宽松的分页组件。

    两边对齐

    结合使用 justify-between CSS 工具类 可获得页面两端对齐的分页组件。

    尺寸

    除了默认大小,还提供了额外的 2 种预设尺寸。可以通过为 pager 添加 size-* 类来获取其他尺寸外观。

    调整每页显示数

    结合使用 dropdown 下拉菜单组件 可展示调整每页显示数的分页组件。

    前往页码

    结合使用 input-group 输入组组件 可展示快速跳转到某一页的分页组件。

    CSS 类

    分页提供了如下 CSS 类:

    类型作用
    pager实体类元素作为分页组件
    pager-goto实体类元素作为分页的跳转组件
    pager-size-menu实体类元素作为分页的每页条数的下拉组件

    MIT License (MIT)

    - +
    Skip to content

    分页

    使用方法

    将多个按钮放置在 <div class="pager"> 内即可创建一个分页组件。

    简洁样式

    简单的翻页。

    状态

    为分页按钮添加 active 类标记选中,添加 disabled 类来禁用页码,被禁用的页码将无法响应点击事件。

    外观

    分页按钮间距

    使用 gap-* CSS 工具类 可获得宽松的分页组件。

    两边对齐

    结合使用 justify-between CSS 工具类 可获得页面两端对齐的分页组件。

    尺寸

    除了默认大小,还提供了额外的 2 种预设尺寸。可以通过为 pager 添加 size-* 类来获取其他尺寸外观。

    调整每页显示数

    结合使用 dropdown 下拉菜单组件 可展示调整每页显示数的分页组件。

    前往页码

    结合使用 input-group 输入组组件 可展示快速跳转到某一页的分页组件。

    CSS 类

    分页提供了如下 CSS 类:

    类型作用
    pager实体类元素作为分页组件
    pager-goto实体类元素作为分页的跳转组件
    pager-size-menu实体类元素作为分页的每页条数的下拉组件

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/components/pager/js.html b/dev/lib/components/pager/js.html index 5e71d1faf2..94dfef7df2 100644 --- a/dev/lib/components/pager/js.html +++ b/dev/lib/components/pager/js.html @@ -14,8 +14,8 @@ - - + + @@ -167,7 +167,7 @@ render(element, <Pager {...options} />);

    使用Jquery 扩展

    js
    $(element).pager(options);
     
     const pager = $(element).data('zui.pager');

    选项

    linkCreator

    导航链接生成器,点击页码时进行页面地址更换。

    page

    初始状态的当前页码。

    recTotal

    总记录数目。

    recPerPage

    每页记录数。

    pageTotal

    总页数。

    items

    定义分页项的列表,可以通过一个函数动态返回分页组件。

    基于 工具栏 选项 和 自定义 PagerItemOptions 选项。

    onClickItem

    指定分页按钮的点击回调事件。

    API

    PagerInfo

    参数:

    page

    recTotal

    recPerPage

    pageTotal

    PagerItemOptions

    参数:

    type

    page

    text

    count

    format

    items

    - + \ No newline at end of file diff --git a/dev/lib/components/panel/index.html b/dev/lib/components/panel/index.html index 58607e3e7a..5d81d2ffcd 100644 --- a/dev/lib/components/panel/index.html +++ b/dev/lib/components/panel/index.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    面板

    基本使用

    一个面板通常包含标题,内容,底部三部分。标题,底部可按需选择使用。

    面板标题

    面板内容

    不同主题

    除默认主题外,另外提供6种主题样式。

    面板标题
    面板内容
    面板标题
    面板内容
    面板标题
    面板内容
    面板标题
    面板内容
    面板标题
    面板内容
    面板标题
    面板内容

    面板组

    搭配CSS工具类 space-* 可实现面板组效果。

    面板标题
    面板内容
    面板标题
    面板内容
    面板标题
    面板内容

    与表格组合使用

    包含表格
    项目名称负责人计划开始计划完成
    ZUI1研发今天今天
    ZUI2研发明天明天
    ZUI3研发后天后天

    CSS 类

    面板提供了如下 CSS 类:

    类型作用
    panel实体类元素作为面板组件
    panel-heading实体类元素作为面板头部组件
    panel-title实体类元素作为面板头部标题组件
    panel-body实体类元素作为面板主体组件
    panel-footer实体类元素作为面板尾部组件

    CSS 变量

    面板提供了如下 CSS 变量:

    变量名称变量含义
    --panel-heading-bg标题背景色
    --panel-footer-bg底部背景色

    MIT License (MIT)

    - +
    Skip to content

    面板

    基本使用

    一个面板通常包含标题,内容,底部三部分。标题,底部可按需选择使用。

    面板标题

    面板内容

    不同主题

    除默认主题外,另外提供6种主题样式。

    面板标题
    面板内容
    面板标题
    面板内容
    面板标题
    面板内容
    面板标题
    面板内容
    面板标题
    面板内容
    面板标题
    面板内容

    面板组

    搭配CSS工具类 space-* 可实现面板组效果。

    面板标题
    面板内容
    面板标题
    面板内容
    面板标题
    面板内容

    与表格组合使用

    包含表格
    项目名称负责人计划开始计划完成
    ZUI1研发今天今天
    ZUI2研发明天明天
    ZUI3研发后天后天

    CSS 类

    面板提供了如下 CSS 类:

    类型作用
    panel实体类元素作为面板组件
    panel-heading实体类元素作为面板头部组件
    panel-title实体类元素作为面板头部标题组件
    panel-body实体类元素作为面板主体组件
    panel-footer实体类元素作为面板尾部组件

    CSS 变量

    面板提供了如下 CSS 变量:

    变量名称变量含义
    --panel-heading-bg标题背景色
    --panel-footer-bg底部背景色

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/components/progress-circle/index.html b/dev/lib/components/progress-circle/index.html index 0b06003a34..c2ff0217a6 100644 --- a/dev/lib/components/progress-circle/index.html +++ b/dev/lib/components/progress-circle/index.html @@ -14,14 +14,14 @@ - - + + -
    - +
    + \ No newline at end of file diff --git a/dev/lib/components/progress/index.html b/dev/lib/components/progress/index.html index c8503a2681..c918137a26 100644 --- a/dev/lib/components/progress/index.html +++ b/dev/lib/components/progress/index.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    进度条

    使用方法

    使用 CSS 类 .progress.progress-bar 来创建进度条,通过为 .progress-bar 设置 CSS width 来展示进度。

    颜色主题

    .progress-bar 元素添加 .* 等颜色CSS工具类,得到各种颜色的进度条。

    圆角大小

    .progress 元素添加 .rounded-* CSS工具类,给进度条添加不同大小的圆角。

    特殊效果

    条纹效果

    .progress 元素添加 .progress-striped 工具类,给进度条添加条纹效果。

    动画效果

    给使用了 progress-striped 工具类的元素添加 .active 工具类,给条纹进度条添加向左滑动的动画。

    堆叠效果

    .progress 元素添加多个 progress-bar 元素,使多个进度条堆叠展示。

    CSS 类

    进度条提供了如下 CSS 类:

    类型作用
    progress实体类元素作为进度条容器组件
    progress-bar实体类元素作为进度条组件
    progress-striped工具类为进度条组件启用条纹样式
    active工具类为条纹样式进度条组件启用动画效果

    CSS 变量

    变量名称变量含义
    --progress-bg进度条组件背景颜色
    --progress-bar-color进度条组件颜色
    --progress-radius进度条组件圆角大小
    --progress-striped-size进度条组件条纹大小

    MIT License (MIT)

    - +
    Skip to content

    进度条

    使用方法

    使用 CSS 类 .progress.progress-bar 来创建进度条,通过为 .progress-bar 设置 CSS width 来展示进度。

    颜色主题

    .progress-bar 元素添加 .* 等颜色CSS工具类,得到各种颜色的进度条。

    圆角大小

    .progress 元素添加 .rounded-* CSS工具类,给进度条添加不同大小的圆角。

    特殊效果

    条纹效果

    .progress 元素添加 .progress-striped 工具类,给进度条添加条纹效果。

    动画效果

    给使用了 progress-striped 工具类的元素添加 .active 工具类,给条纹进度条添加向左滑动的动画。

    堆叠效果

    .progress 元素添加多个 progress-bar 元素,使多个进度条堆叠展示。

    CSS 类

    进度条提供了如下 CSS 类:

    类型作用
    progress实体类元素作为进度条容器组件
    progress-bar实体类元素作为进度条组件
    progress-striped工具类为进度条组件启用条纹样式
    active工具类为条纹样式进度条组件启用动画效果

    CSS 变量

    变量名称变量含义
    --progress-bg进度条组件背景颜色
    --progress-bar-color进度条组件颜色
    --progress-radius进度条组件圆角大小
    --progress-striped-size进度条组件条纹大小

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/components/scrollbar/index.html b/dev/lib/components/scrollbar/index.html index 4e4c1e9e74..4645d10b7d 100644 --- a/dev/lib/components/scrollbar/index.html +++ b/dev/lib/components/scrollbar/index.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    滚动条

    滚动条样式

    Lorem ipsum dolor sit amet consectetur adipisicing elit. Veniam, accusamus.Molestiae saepe deleniti voluptas excepturi nostrum. Consequatur eius non voluptates!Commodi omnis minus quo totam, ab aspernatur sequi vero cum?

    Explicabo asperiores recusandae qui? Aliquam similique eaque animi nemo? Fugiat.Cupiditate eaque, doloribus magnam velit ipsum maiores voluptatum eveniet rem!

    Pariatur sapiente laboriosam cumque itaque, id saepe commodi accusantium neque?

    Cupiditate eaque, doloribus magnam velit ipsum maiores voluptatum eveniet rem!

    Quidem eum, reiciendis iusto rem perspiciatis neque optio! Quae, sint!

    Maxime animi iure enim sint aperiam tempora non voluptatibus dolore.

    Suscipit cumque minus veritatis labore dolor corporis molestias. Rem, pariatur.

    Commodi omnis minus quo totam, ab aspernatur sequi vero cum?

    Repellendus rerum tempora eos praesentium at placeat, quas quibusdam sunt?

    Molestiae saepe deleniti voluptas excepturi nostrum. Consequatur eius non voluptates!

    窄滚动条样式

    Lorem ipsum dolor sit amet consectetur adipisicing elit. Veniam, accusamus.Molestiae saepe deleniti voluptas excepturi nostrum. Consequatur eius non voluptates!Commodi omnis minus quo totam, ab aspernatur sequi vero cum?

    Explicabo asperiores recusandae qui? Aliquam similique eaque animi nemo? Fugiat.Cupiditate eaque, doloribus magnam velit ipsum maiores voluptatum eveniet rem!

    Pariatur sapiente laboriosam cumque itaque, id saepe commodi accusantium neque?

    Cupiditate eaque, doloribus magnam velit ipsum maiores voluptatum eveniet rem!

    Quidem eum, reiciendis iusto rem perspiciatis neque optio! Quae, sint!

    Maxime animi iure enim sint aperiam tempora non voluptatibus dolore.

    Suscipit cumque minus veritatis labore dolor corporis molestias. Rem, pariatur.

    Commodi omnis minus quo totam, ab aspernatur sequi vero cum?

    Repellendus rerum tempora eos praesentium at placeat, quas quibusdam sunt?

    Molestiae saepe deleniti voluptas excepturi nostrum. Consequatur eius non voluptates!

    仅鼠标悬停时显示

    Lorem ipsum dolor sit amet consectetur adipisicing elit. Veniam, accusamus.Molestiae saepe deleniti voluptas excepturi nostrum. Consequatur eius non voluptates!Commodi omnis minus quo totam, ab aspernatur sequi vero cum?

    Explicabo asperiores recusandae qui? Aliquam similique eaque animi nemo? Fugiat.Cupiditate eaque, doloribus magnam velit ipsum maiores voluptatum eveniet rem!

    Pariatur sapiente laboriosam cumque itaque, id saepe commodi accusantium neque?

    Cupiditate eaque, doloribus magnam velit ipsum maiores voluptatum eveniet rem!

    Quidem eum, reiciendis iusto rem perspiciatis neque optio! Quae, sint!

    Maxime animi iure enim sint aperiam tempora non voluptatibus dolore.

    Suscipit cumque minus veritatis labore dolor corporis molestias. Rem, pariatur.

    Commodi omnis minus quo totam, ab aspernatur sequi vero cum?

    Repellendus rerum tempora eos praesentium at placeat, quas quibusdam sunt?

    Molestiae saepe deleniti voluptas excepturi nostrum. Consequatur eius non voluptates!

    MIT License (MIT)

    - +
    Skip to content

    滚动条

    滚动条样式

    Lorem ipsum dolor sit amet consectetur adipisicing elit. Veniam, accusamus.Molestiae saepe deleniti voluptas excepturi nostrum. Consequatur eius non voluptates!Commodi omnis minus quo totam, ab aspernatur sequi vero cum?

    Explicabo asperiores recusandae qui? Aliquam similique eaque animi nemo? Fugiat.Cupiditate eaque, doloribus magnam velit ipsum maiores voluptatum eveniet rem!

    Pariatur sapiente laboriosam cumque itaque, id saepe commodi accusantium neque?

    Cupiditate eaque, doloribus magnam velit ipsum maiores voluptatum eveniet rem!

    Quidem eum, reiciendis iusto rem perspiciatis neque optio! Quae, sint!

    Maxime animi iure enim sint aperiam tempora non voluptatibus dolore.

    Suscipit cumque minus veritatis labore dolor corporis molestias. Rem, pariatur.

    Commodi omnis minus quo totam, ab aspernatur sequi vero cum?

    Repellendus rerum tempora eos praesentium at placeat, quas quibusdam sunt?

    Molestiae saepe deleniti voluptas excepturi nostrum. Consequatur eius non voluptates!

    窄滚动条样式

    Lorem ipsum dolor sit amet consectetur adipisicing elit. Veniam, accusamus.Molestiae saepe deleniti voluptas excepturi nostrum. Consequatur eius non voluptates!Commodi omnis minus quo totam, ab aspernatur sequi vero cum?

    Explicabo asperiores recusandae qui? Aliquam similique eaque animi nemo? Fugiat.Cupiditate eaque, doloribus magnam velit ipsum maiores voluptatum eveniet rem!

    Pariatur sapiente laboriosam cumque itaque, id saepe commodi accusantium neque?

    Cupiditate eaque, doloribus magnam velit ipsum maiores voluptatum eveniet rem!

    Quidem eum, reiciendis iusto rem perspiciatis neque optio! Quae, sint!

    Maxime animi iure enim sint aperiam tempora non voluptatibus dolore.

    Suscipit cumque minus veritatis labore dolor corporis molestias. Rem, pariatur.

    Commodi omnis minus quo totam, ab aspernatur sequi vero cum?

    Repellendus rerum tempora eos praesentium at placeat, quas quibusdam sunt?

    Molestiae saepe deleniti voluptas excepturi nostrum. Consequatur eius non voluptates!

    仅鼠标悬停时显示

    Lorem ipsum dolor sit amet consectetur adipisicing elit. Veniam, accusamus.Molestiae saepe deleniti voluptas excepturi nostrum. Consequatur eius non voluptates!Commodi omnis minus quo totam, ab aspernatur sequi vero cum?

    Explicabo asperiores recusandae qui? Aliquam similique eaque animi nemo? Fugiat.Cupiditate eaque, doloribus magnam velit ipsum maiores voluptatum eveniet rem!

    Pariatur sapiente laboriosam cumque itaque, id saepe commodi accusantium neque?

    Cupiditate eaque, doloribus magnam velit ipsum maiores voluptatum eveniet rem!

    Quidem eum, reiciendis iusto rem perspiciatis neque optio! Quae, sint!

    Maxime animi iure enim sint aperiam tempora non voluptatibus dolore.

    Suscipit cumque minus veritatis labore dolor corporis molestias. Rem, pariatur.

    Commodi omnis minus quo totam, ab aspernatur sequi vero cum?

    Repellendus rerum tempora eos praesentium at placeat, quas quibusdam sunt?

    Molestiae saepe deleniti voluptas excepturi nostrum. Consequatur eius non voluptates!

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/components/search-box/index.html b/dev/lib/components/search-box/index.html index 0862742a41..b27ec21054 100644 --- a/dev/lib/components/search-box/index.html +++ b/dev/lib/components/search-box/index.html @@ -14,14 +14,14 @@ - - + + -
    - +
    + \ No newline at end of file diff --git a/dev/lib/components/table/index.html b/dev/lib/components/table/index.html index 0df41ffa79..39134d0048 100644 --- a/dev/lib/components/table/index.html +++ b/dev/lib/components/table/index.html @@ -14,16 +14,16 @@ - - + + -
    Skip to content

    表格

    表格用于展示二维数据。

    使用方法

    <table> 元素添加 CSS 类 .table 来使用表格。

    组成部分元素标签说明
    表头<thead>表头通常作为表格第一行,用于展示所有数据的各个属性名称。
    主体<tbody>一个或多个行组成表格的主体,每行用于展示一个数据。
    表尾<tfoot>表尾通常用于展示一些数据的汇总信息。
    总计3 个部分

    斑马纹表格

    <table class="table"> 上使用工具类 .table-striped 斑马纹表格外观(隔行变色)效果。

    :: tabs

    == 示例

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观
    2.12021-07-31新的预览功能,更方便的提前查看最终效果!

    == HTML

    html
    <table class="table table-striped">
    +    
    Skip to content

    表格

    表格用于展示二维数据。

    使用方法

    <table> 元素添加 CSS 类 .table 来使用表格。

    组成部分元素标签说明
    表头<thead>表头通常作为表格第一行,用于展示所有数据的各个属性名称。
    主体<tbody>一个或多个行组成表格的主体,每行用于展示一个数据。
    表尾<tfoot>表尾通常用于展示一些数据的汇总信息。
    总计3 个部分

    斑马纹表格

    <table class="table"> 上使用工具类 .table-striped 斑马纹表格外观(隔行变色)效果。

    :: tabs

    == 示例

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观
    2.12021-07-31新的预览功能,更方便的提前查看最终效果!

    == HTML

    html
    <table class="table table-striped">
       ...
    -</table>

    :::

    鼠标悬停变色

    <table class="table"> 上使用工具类 .table-hover,当鼠标悬停在行上时显示不一样的背景。

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观
    2.12021-07-31新的预览功能,更方便的提前查看最终效果!

    完整边框

    <table class="table"> 上使用工具类 .bordered,为表格添加所有边框。

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观
    2.12021-07-31新的预览功能,更方便的提前查看最终效果!

    无边框

    <table class="table"> 上使用工具类 .borderless,为表格移除所有边框。

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观
    2.12021-07-31新的预览功能,更方便的提前查看最终效果!

    紧凑的表格

    <table class="table"> 上使用工具类 .condensed 来获得更紧凑的表格。表格中的单元格拥有更小的间距,整体行高减少。

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观
    2.12021-07-31新的预览功能,更方便的提前查看最终效果!

    固定布局的表格

    <table class="table"> 上使用工具类 .table-fixed 来将表格布局方式设置为 fixed

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观。
    3.02021-07-31这一次说说关于表格的固定布局,当启用固定布局时,后续行中的单元格内容将不会对表格布局产生影响,当单元格内的文本过长时会被截断隐藏。

    关于表格的固定布局

    表格和列的宽度通过表格的宽度来设置,某一列的宽度仅由该列首行的单元格决定。在当前列中,该单元格所在行之后的行并不会影响整个列宽。

    使用“fixed”布局方式时,整个表格可以在其首行被下载后就被解析和渲染。这样对于“automatic”自动布局方式来说可以加速渲染,但是其后的单元格内容并不会自适应当前列宽。任何一个包含溢出内容的单元格可以使用 overflow 属性控制是否允许内容溢出。

    参考:https://developer.mozilla.org/zh-CN/docs/Web/CSS/table-layout

    自动宽度

    通常表格宽度为 100%,与表格所属的父级元素宽度保持一致,但有时希望表格的宽度能够按照实际内容宽度展示。此时可以通过配合使用 CSS 工具类 w-auto 来设置表格宽度为自动,同时推荐使用工具类 max-w-full 来限制表格最大宽度不超过父级元素宽度(100%)。

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观
    2.12021-07-31新的预览功能,更方便的提前查看最终效果!

    特殊外观

    为行元素 <tr> 或单元格 <td><th> 应用 CSS 工具类 来获得特殊外观。

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观
    2.12021-07-31新的预览功能,更方便的提前查看最终效果!

    CSS 类

    按钮提供了如下 CSS 类:

    类型作用
    table实体类元素作为表格组件
    table-striped工具类为表格启用斑马纹效果
    table-hover工具类为表格启用行悬停变色效果
    table-fixed工具类为表格启用固定布局
    borderless工具类移除表格所有边框
    bordered工具类为表格添加完整边框
    condensed工具类为表格启用紧凑布局

    CSS 变量

    变量名称变量含义
    --table-head-bg表头背景色
    --table-striped-color表格斑马纹行背景色
    --table-hover-color表格行响应鼠标悬停变化背景颜色
    --table-border-color表格边框颜色

    MIT License (MIT)

    - +</table>

    :::

    鼠标悬停变色

    <table class="table"> 上使用工具类 .table-hover,当鼠标悬停在行上时显示不一样的背景。

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观
    2.12021-07-31新的预览功能,更方便的提前查看最终效果!

    完整边框

    <table class="table"> 上使用工具类 .bordered,为表格添加所有边框。

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观
    2.12021-07-31新的预览功能,更方便的提前查看最终效果!

    无边框

    <table class="table"> 上使用工具类 .borderless,为表格移除所有边框。

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观
    2.12021-07-31新的预览功能,更方便的提前查看最终效果!

    紧凑的表格

    <table class="table"> 上使用工具类 .condensed 来获得更紧凑的表格。表格中的单元格拥有更小的间距,整体行高减少。

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观
    2.12021-07-31新的预览功能,更方便的提前查看最终效果!

    固定布局的表格

    <table class="table"> 上使用工具类 .table-fixed 来将表格布局方式设置为 fixed

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观。
    3.02021-07-31这一次说说关于表格的固定布局,当启用固定布局时,后续行中的单元格内容将不会对表格布局产生影响,当单元格内的文本过长时会被截断隐藏。

    关于表格的固定布局

    表格和列的宽度通过表格的宽度来设置,某一列的宽度仅由该列首行的单元格决定。在当前列中,该单元格所在行之后的行并不会影响整个列宽。

    使用“fixed”布局方式时,整个表格可以在其首行被下载后就被解析和渲染。这样对于“automatic”自动布局方式来说可以加速渲染,但是其后的单元格内容并不会自适应当前列宽。任何一个包含溢出内容的单元格可以使用 overflow 属性控制是否允许内容溢出。

    参考:https://developer.mozilla.org/zh-CN/docs/Web/CSS/table-layout

    自动宽度

    通常表格宽度为 100%,与表格所属的父级元素宽度保持一致,但有时希望表格的宽度能够按照实际内容宽度展示。此时可以通过配合使用 CSS 工具类 w-auto 来设置表格宽度为自动,同时推荐使用工具类 max-w-full 来限制表格最大宽度不超过父级元素宽度(100%)。

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观
    2.12021-07-31新的预览功能,更方便的提前查看最终效果!

    特殊外观

    为行元素 <tr> 或单元格 <td><th> 应用 CSS 工具类 来获得特殊外观。

    版本发布时间主要特性
    1.02021-03-01第一个版本发布!
    1.12021-04-12修复了大量已知问题。
    1.22021-05-18新的编辑器,让创意更容易展现。
    2.02021-06-05这次版本带来全新的界面外观
    2.12021-07-31新的预览功能,更方便的提前查看最终效果!

    CSS 类

    按钮提供了如下 CSS 类:

    类型作用
    table实体类元素作为表格组件
    table-striped工具类为表格启用斑马纹效果
    table-hover工具类为表格启用行悬停变色效果
    table-fixed工具类为表格启用固定布局
    borderless工具类移除表格所有边框
    bordered工具类为表格添加完整边框
    condensed工具类为表格启用紧凑布局

    CSS 变量

    变量名称变量含义
    --table-head-bg表头背景色
    --table-striped-color表格斑马纹行背景色
    --table-hover-color表格行响应鼠标悬停变化背景颜色
    --table-border-color表格边框颜色

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/components/tabs/index.html b/dev/lib/components/tabs/index.html index 6a6a9cbfd9..b70963f9b3 100644 --- a/dev/lib/components/tabs/index.html +++ b/dev/lib/components/tabs/index.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    标签页

    使用方法

    标签页一般配合导航使用,通过 .nav 来定义切换的触发器,通过 .tab-content 来定义切换的内容。标签页内容使用 .tab-pane 作为容器元素,所有供切换显示的 .tab-pane 放置在 .tab-content 容器元素内。

    提示

    为确保在页面显示的时候标签页能够指示正确的标签和显示正确的内容,在初始状态需要为当前选中的导航项目 li.nav-item > a 元素添加 .active 类,并且为当前显示的标签页内容元素 .tab-pane 添加 .active 类。

    为导航上每个用于切换标签内容的链接添加 hrefdata-target 属性指向当前标签页内容 .tab-paneid ,并添加 data-toggle="tab" 属性。

    我是标签1。

    我是标签2。

    我是标签3。

    动画效果

    为每个 .tab-pane 添加 .fade,可以使得标签内容在显示时获得渐变动画效果。在初始状态要显示的标签页内容 .tab-pane 不仅需要添加 .active 类,还需要添加 .in 类。

    我是标签1。

    我是标签2。

    我是标签3。

    垂直标签页

    使用 .nav-tabs.nav-stacked 获得垂直排列的标签导航,使用 flex 布局来使得导航和标签页内容水平排列。

    我是标签1。

    我是标签2。

    我是标签3。

    事件

    当显示一个新的标签页时,这些事件会被触发:

    • show: 当前标签页在显示时触发;
    • shown: 当前标签页在显示后(动画执行完毕)触发。

    通过为 [data-toggle="tab"] 链接添加 data-name 属性,这样事件触发时会传递该属性值作为参数,如果不指定则使用 [data-target] 的值作为参数。

    我是标签1。

    我是标签2。

    我是标签3。

    MIT License (MIT)

    - +
    Skip to content

    标签页

    使用方法

    标签页一般配合导航使用,通过 .nav 来定义切换的触发器,通过 .tab-content 来定义切换的内容。标签页内容使用 .tab-pane 作为容器元素,所有供切换显示的 .tab-pane 放置在 .tab-content 容器元素内。

    提示

    为确保在页面显示的时候标签页能够指示正确的标签和显示正确的内容,在初始状态需要为当前选中的导航项目 li.nav-item > a 元素添加 .active 类,并且为当前显示的标签页内容元素 .tab-pane 添加 .active 类。

    为导航上每个用于切换标签内容的链接添加 hrefdata-target 属性指向当前标签页内容 .tab-paneid ,并添加 data-toggle="tab" 属性。

    我是标签1。

    我是标签2。

    我是标签3。

    动画效果

    为每个 .tab-pane 添加 .fade,可以使得标签内容在显示时获得渐变动画效果。在初始状态要显示的标签页内容 .tab-pane 不仅需要添加 .active 类,还需要添加 .in 类。

    我是标签1。

    我是标签2。

    我是标签3。

    垂直标签页

    使用 .nav-tabs.nav-stacked 获得垂直排列的标签导航,使用 flex 布局来使得导航和标签页内容水平排列。

    我是标签1。

    我是标签2。

    我是标签3。

    事件

    当显示一个新的标签页时,这些事件会被触发:

    • show: 当前标签页在显示时触发;
    • shown: 当前标签页在显示后(动画执行完毕)触发。

    通过为 [data-toggle="tab"] 链接添加 data-name 属性,这样事件触发时会传递该属性值作为参数,如果不指定则使用 [data-target] 的值作为参数。

    我是标签1。

    我是标签2。

    我是标签3。

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/components/toolbar/index.html b/dev/lib/components/toolbar/index.html index 8b3c4c4482..82088c7d3e 100644 --- a/dev/lib/components/toolbar/index.html +++ b/dev/lib/components/toolbar/index.html @@ -14,14 +14,14 @@ - - + + -
    - +
    + \ No newline at end of file diff --git a/dev/lib/components/toolbar/js.html b/dev/lib/components/toolbar/js.html index 726dd0e73c..bcc5efb576 100644 --- a/dev/lib/components/toolbar/js.html +++ b/dev/lib/components/toolbar/js.html @@ -14,8 +14,8 @@ - - + + @@ -152,7 +152,7 @@ render(element, <Toolbar {...options} />);

    使用 jQuery 扩展

    js
    $(element).toolbar(options);
     
     const toolbar = $(element).data('zui.toolbar');

    选项

    操作菜单 选项基础上添加新的参数选项。

    wrap

    限制工具栏按钮过多超出时是否换行。

    gap

    自定义工具栏按钮的间距,与 .toolbar 同级生成 .gap-* 的工具类控制按钮间距。

    items

    继承了 操作菜单 选项和按钮选项,同时添加了其他选项。

    btnProps

    继承按钮组件的属性, 统一处理工具栏按钮属性外观等。

    itemRender

    指定一个回调函数用于对组件渲染进行自定义。

    参数items 选项的单个配置;

    返回值items 选项的单个配置。

    beforeRender

    指定一个回调函数在渲染之前调用,可重新配置组件选项。

    参数:用户为按钮组组件件设置的 options

    返回值:组件选项数据。

    afterRender

    指定一个回调函数在渲染之后调用。

    参数:

    beforeDestroy

    指定一个回调函数在组件销毁之前调用,无参数。

    API

    ToolbarItemOptions

    ts
    type ToolbarItemOptions = ToolbarItemProps | ToolbarDropdownProps | ToolbarBtnGroupProps | ToolbarDividerProps | ToolbarSpaceProps;

    ToolbarItemProps

    选项:

    继承了操作菜单的 ActionItemProps 选项和按钮的 ButtonProps ,同时添加了其他选项 btnType,用来设置按钮外观类型。

    btnType

    设置工具栏单个按钮的外观类型。

    ToolbarDropdownProps

    选项:

    在原有属性基础上固定 type 属性,并继承了下拉菜单的 DropdownButtonOptions 选项,同时添加了其他选项。

    type
    children

    ToolbarBtnGroupProps

    选项:

    在原有属性基础上固定 type 属性,并继承了操作菜单的 ActionBasicProps 选项和按钮组的 BtnGroupOptions选项,同时添加了其他选项。

    type

    ToolbarDividerProps

    选项:

    继承了工具栏的 ActionDividerProps 选项。

    ToolbarSpaceProps

    选项:

    继承了工具栏的 ActionSpaceProps 选项。

    type
    space
    flex
    - + \ No newline at end of file diff --git a/dev/lib/components/tooltip/index.html b/dev/lib/components/tooltip/index.html index 5ecc2564dd..ca0f633367 100644 --- a/dev/lib/components/tooltip/index.html +++ b/dev/lib/components/tooltip/index.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    提示消息

    提示消息又称“工具提示”,在鼠标悬停在元素上时及时显示额外的内容。

    使用方法

    组件提供多种不同方向的展示方式,可以根据需求选择你要的效果。

    触发方式

    除了默认的鼠标悬浮展示信息外,组件也提供了点击触发的方式。

    外观

    指定 type 选项来更改外观类型。

    选项

    名称类型默认值说明
    titlestringnull提示消息内容 placement?: string; // 弹出方向,可选值包括:'top-start' | 'top' | 'top-end' | 'bottom-start' | 'bottom' | 'bottom-end' | 'left-start' | 'left' | 'left-end' | 'right-start' | 'right' | 'right-end' trigger?: string; // 触发方式,可选值包括:'click' | 'hover' className?: string; // 类名 type?: string; // 外观类型,可选值包括:'primary' | 'secondary' | 'warning' | 'success' | 'danger' | 'important' | 'gray' animation?: boolean; // 是否应用淡入淡出动画 arrow?: number | number; // 箭头大小 delay?: boolean | number; // 延迟显示,可选值包括:true | false | number hideOthers?: boolean; // 显示时隐藏其他已经显示的提示消息

    MIT License (MIT)

    - +
    Skip to content

    提示消息

    提示消息又称“工具提示”,在鼠标悬停在元素上时及时显示额外的内容。

    使用方法

    组件提供多种不同方向的展示方式,可以根据需求选择你要的效果。

    触发方式

    除了默认的鼠标悬浮展示信息外,组件也提供了点击触发的方式。

    外观

    指定 type 选项来更改外观类型。

    选项

    名称类型默认值说明
    titlestringnull提示消息内容 placement?: string; // 弹出方向,可选值包括:'top-start' | 'top' | 'top-end' | 'bottom-start' | 'bottom' | 'bottom-end' | 'left-start' | 'left' | 'left-end' | 'right-start' | 'right' | 'right-end' trigger?: string; // 触发方式,可选值包括:'click' | 'hover' className?: string; // 类名 type?: string; // 外观类型,可选值包括:'primary' | 'secondary' | 'warning' | 'success' | 'danger' | 'important' | 'gray' animation?: boolean; // 是否应用淡入淡出动画 arrow?: number | number; // 箭头大小 delay?: boolean | number; // 延迟显示,可选值包括:true | false | number hideOthers?: boolean; // 显示时隐藏其他已经显示的提示消息

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/components/tree/index.html b/dev/lib/components/tree/index.html index 48b3ffe755..a7dc2b0aed 100644 --- a/dev/lib/components/tree/index.html +++ b/dev/lib/components/tree/index.html @@ -14,8 +14,8 @@ - - + + @@ -181,7 +181,7 @@ /** 工具栏定义。 */ actions?: ToolbarOptions | ToolbarItemOptions[]; }; - + \ No newline at end of file diff --git a/dev/lib/components/upload-imgs/index.html b/dev/lib/components/upload-imgs/index.html index 715fd55eb7..b413f683e7 100644 --- a/dev/lib/components/upload-imgs/index.html +++ b/dev/lib/components/upload-imgs/index.html @@ -14,8 +14,8 @@ - - + + @@ -40,7 +40,7 @@ tip: '可点击添加或拖拽上传,图片格式支持jpg、jpeg', accept: 'image/jpg, image/jpeg' });

    选项

    name

    表单字段名。

    showSize

    是否显示文件大小。

    multiple

    是否开启多文件上传。

    uploadText

    上传按钮文本。

    uploadIcon

    上传按钮图标。

    renameBtn

    是否启用重命名按钮。

    renameIcon

    重命名按钮图标。

    renameText

    重命名按钮文本。

    renameClass

    重命名按钮类。

    deleteBtn

    是否启用删除按钮。

    deleteIcon

    删除按钮图标。

    deleteText

    删除按钮文本。

    deleteClass

    删除按钮类。

    tip

    文件上传提示。

    btnClass

    上传按钮类。

    onAdd

    文件变更回调。

    onDelete

    删除文件回调。

    onRename

    重命名文件回调。

    onSizeChange

    文件大小变更回调。

    limitCount

    上传文件最大数量限制。

    accept

    上传文件类型。

    defaultFileList

    默认文件列表。

    limitSize

    上传文件最大大小限制。

    duplicatedHint

    重复文件提示。

    onDuplicated

    文件重复回调。

    exceededSizeHint

    超出大小限制提示。

    onExceededSize

    超出大小限制回调。

    exceededCountHint

    超过数量限制提示。

    onExceededCount

    超过数量限制回调

    totalCountText

    文件数量提示。

    - + \ No newline at end of file diff --git a/dev/lib/components/upload/index.html b/dev/lib/components/upload/index.html index ab34febf75..95ffc65226 100644 --- a/dev/lib/components/upload/index.html +++ b/dev/lib/components/upload/index.html @@ -14,8 +14,8 @@ - - + + @@ -56,7 +56,7 @@ name: 'files8', defaultFileList: [file1, file2] });

    选项

    name

    表单字段名。

    icon

    文件图标。

    showIcon

    是否显示文件图标。

    showSize

    是否显示文件大小。

    multiple

    是否开启多文件上传。

    listPosition

    文件列表位置。

    uploadText

    上传按钮文本。

    uploadIcon

    上传按钮图标。

    renameBtn

    是否启用重命名按钮。

    renameIcon

    重命名按钮图标。

    renameText

    重命名按钮文本。

    renameClass

    重命名按钮类。

    deleteBtn

    是否启用删除按钮。

    deleteIcon

    删除按钮图标。

    deleteText

    删除按钮文本。

    deleteClass

    删除按钮类。

    confirmText

    确认重命名按钮文本。

    cancelText

    取消重命名按钮文本。

    useIconBtn

    是否使用图标按钮。

    tip

    文件上传提示。

    btnClass

    上传按钮类。

    onAdd

    文件变更回调。

    onDelete

    删除文件回调。

    onRename

    重命名文件回调。

    onSizeChange

    文件大小变更回调。

    draggable

    是否启用拖拽功能。

    limitCount

    上传文件最大数量限制。

    accept

    上传文件类型。

    defaultFileList

    默认文件列表。

    limitSize

    上传文件最大大小限制。

    duplicatedHint

    重复文件提示。

    onDuplicated

    文件重复回调。

    exceededSizeHint

    超出大小限制提示。

    onExceededSize

    超出大小限制回调。

    exceededCountHint

    超过数量限制提示。

    onExceededCount

    超过数量限制回调

    - + \ No newline at end of file diff --git a/dev/lib/forms/checkbox/index.html b/dev/lib/forms/checkbox/index.html index 2f92cf8a18..62e2c646e1 100644 --- a/dev/lib/forms/checkbox/index.html +++ b/dev/lib/forms/checkbox/index.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    复选框和单选框

    复选框(checkbox)允许用户选择多个选项,不同于 <select>,这些选项是直接展示的。为 <input type="checkbox"> 设置 disabled 属性来应用禁用样式,如果为 .checkbox 添加 disabled 类,则整个复选框包括文字部分都会应用禁用样式。将多个复选框堆叠形成一个复选框组。

    基本使用

    复选框

    单选框列表

    单选框通常多个一起使用组成列表,将多个单选框放在 .check-list 中即可。

    复选框列表

    复选框也支持多个一起使用组成列表,将多个复选框放在 .check-list 中即可。

    不包含文字样式

    复选框

    单选框

    内联形式

    为让多个复选框或单选框内联显示,可以将他们放置在一个 .check-list-inline 中。

    内联多选框

    内联单选框

    内联间距

    可以通过工具类 gap-* 来设置内联的复选框和单选框间的间距。

    高级外观

    高级外观的多选框和单选框使用自定义的外观代替原生外观,在所有浏览器都具有一致的体验。

    高级外观的复选框

    高级外观的单选框

    <input> 选择框

    高级外观还可以不使用 <input> 元素,在此种情况下,为 .checkbox-primary.radio-primary 添加 .checked 类标记为选中状态,通过 focus 类来标记激活状态,用户无法通过点击来切换选中状态,但可以通过程序手动添加或移除 .checked 来更改选中状态。

    设置高级外观颜色

    通过设置 CSS 变量 --checkbox-color 可以设置高级外观颜色。

    CSS 类

    单选框和复选框提供了如下 CSS 类:

    类型作用
    checkbox实体类复选框组件
    radio实体类单选框组件
    check-list实体类复选框或单选框列表组件
    check-list-inline实体类复选框或单选框内联列表组件
    checkbox-primary实体类高级外观的复选框组件
    radio-primary实体类高级外观的单选框组件
    checked修饰类强制使用选中外观
    focus修饰类强制使用激活外观
    disabled修饰类强制使用禁用外观
    indeterminate修饰类强制使用 Indeterminate 外观

    CSS 变量

    单选框和复选框提供了如下 CSS 变量:

    CSS 变量名作用
    --checkbox-size复选框或单选框大小,仅当使用高级外观时有效
    --checkbox-color复选框或单选框颜色,仅当使用高级外观时有效

    MIT License (MIT)

    - +
    Skip to content

    复选框和单选框

    复选框(checkbox)允许用户选择多个选项,不同于 <select>,这些选项是直接展示的。为 <input type="checkbox"> 设置 disabled 属性来应用禁用样式,如果为 .checkbox 添加 disabled 类,则整个复选框包括文字部分都会应用禁用样式。将多个复选框堆叠形成一个复选框组。

    基本使用

    复选框

    单选框列表

    单选框通常多个一起使用组成列表,将多个单选框放在 .check-list 中即可。

    复选框列表

    复选框也支持多个一起使用组成列表,将多个复选框放在 .check-list 中即可。

    不包含文字样式

    复选框

    单选框

    内联形式

    为让多个复选框或单选框内联显示,可以将他们放置在一个 .check-list-inline 中。

    内联多选框

    内联单选框

    内联间距

    可以通过工具类 gap-* 来设置内联的复选框和单选框间的间距。

    高级外观

    高级外观的多选框和单选框使用自定义的外观代替原生外观,在所有浏览器都具有一致的体验。

    高级外观的复选框

    高级外观的单选框

    <input> 选择框

    高级外观还可以不使用 <input> 元素,在此种情况下,为 .checkbox-primary.radio-primary 添加 .checked 类标记为选中状态,通过 focus 类来标记激活状态,用户无法通过点击来切换选中状态,但可以通过程序手动添加或移除 .checked 来更改选中状态。

    设置高级外观颜色

    通过设置 CSS 变量 --checkbox-color 可以设置高级外观颜色。

    CSS 类

    单选框和复选框提供了如下 CSS 类:

    类型作用
    checkbox实体类复选框组件
    radio实体类单选框组件
    check-list实体类复选框或单选框列表组件
    check-list-inline实体类复选框或单选框内联列表组件
    checkbox-primary实体类高级外观的复选框组件
    radio-primary实体类高级外观的单选框组件
    checked修饰类强制使用选中外观
    focus修饰类强制使用激活外观
    disabled修饰类强制使用禁用外观
    indeterminate修饰类强制使用 Indeterminate 外观

    CSS 变量

    单选框和复选框提供了如下 CSS 变量:

    CSS 变量名作用
    --checkbox-size复选框或单选框大小,仅当使用高级外观时有效
    --checkbox-color复选框或单选框颜色,仅当使用高级外观时有效

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/forms/checkbox/switch.html b/dev/lib/forms/checkbox/switch.html index 05056a86fa..3ceec6c112 100644 --- a/dev/lib/forms/checkbox/switch.html +++ b/dev/lib/forms/checkbox/switch.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    开关

    基本使用

    与单选框和复选框的高级外观一样,通过 .switch 类来启用开关外观。

    开关颜色

    通过设置 CSS 变量 --checkbox-color 可以设置高级外观颜色。

    开关列表

    垂直列表

    通过将多个开关放置在 .check-list 中,可以实现一个开关列表:

    内联列表

    通过将多个开关放置在 .check-list 中,可以实现一个开关内联列表:

    列表联动

    通过开关内部使用的 input[type="checkbox"] 更换为 input[type="radio"],并指定为相同的 name 属性,即可实现多个开关单选联动:

    CSS 类

    开关提供了如下 CSS 类:

    类型作用
    switch实体类开关组件
    check-list实体类开关列表组件
    check-list-inline实体类开关内联列表组件
    checked修饰类强制使用选中外观
    focus修饰类强制使用激活外观
    disabled修饰类强制使用禁用外观

    CSS 变量

    单选框和复选框提供了如下 CSS 变量:

    CSS 变量名作用
    --checkbox-color开关颜色,仅当使用高级外观时有效

    MIT License (MIT)

    - +
    Skip to content

    开关

    基本使用

    与单选框和复选框的高级外观一样,通过 .switch 类来启用开关外观。

    开关颜色

    通过设置 CSS 变量 --checkbox-color 可以设置高级外观颜色。

    开关列表

    垂直列表

    通过将多个开关放置在 .check-list 中,可以实现一个开关列表:

    内联列表

    通过将多个开关放置在 .check-list 中,可以实现一个开关内联列表:

    列表联动

    通过开关内部使用的 input[type="checkbox"] 更换为 input[type="radio"],并指定为相同的 name 属性,即可实现多个开关单选联动:

    CSS 类

    开关提供了如下 CSS 类:

    类型作用
    switch实体类开关组件
    check-list实体类开关列表组件
    check-list-inline实体类开关内联列表组件
    checked修饰类强制使用选中外观
    focus修饰类强制使用激活外观
    disabled修饰类强制使用禁用外观

    CSS 变量

    单选框和复选框提供了如下 CSS 变量:

    CSS 变量名作用
    --checkbox-color开关颜色,仅当使用高级外观时有效

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/forms/datetime-picker/date.html b/dev/lib/forms/datetime-picker/date.html index 5268b8f3f3..9b334e73eb 100644 --- a/dev/lib/forms/datetime-picker/date.html +++ b/dev/lib/forms/datetime-picker/date.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    日期选择器

    用法

    设置默认值

    通过 defaultValue 选项设置默认值,设置为 'today' 可以将默认值设置为当天。

    格式化

    通过 format 选项设置日期格式化形式,支持日期辅助方法 formatDate 中的所有格式。

    限制日期范围

    通过 minDatemaxDate 来限制可选的日期范围。

    自定义菜单

    通过 menu 选项可以在弹出面板侧面显示一个自定义菜单,通过 actions 可以自定义底部工具栏上的按钮。在菜单项和按钮上通过 [data-set-date] 属性指定点击按钮时要设定的日期。

    自定义侧边菜单

    通过 menu 选项可以在弹出面板左侧显示一个自定义菜单,在菜单项配置上通过 [data-set-date] 属性指定点击菜单项时要设定的日期。

    自定义底部按钮

    通过 actions 可以自定义底部工具栏上的按钮,在菜单项和按钮上通过 [data-set-date] 属性指定点击按钮时要设定的日期。

    选项

    名称类型默认值说明
    classNameanynull组件根元素的类名。 style?: object; // 组件根元素的样式。 tagName?: string; // 组件根元素的标签名。 attrs?: object; // 附加到组件根元素上的属性。 clickType?: 'toggle' | 'open'; // 点击类型,toggle 表示点击按钮时切换显示隐藏,open 表示点击按钮时只打开。 name?: string; // 作为表单项的名称。 defaultValue?: 'today' | string; // 默认值。 onChange?: function; // 值变更时的回调函数。 disabled?: boolean; // 是否禁用。 readonly?: boolean; // 是否只读,不允许手动修改。 required?: boolean; // 是否必须提供值(不能清除和选择空值)。 placeholder?: string; // 输入框上占位文本。 format?: string; // 日期格式,默认 yyyy-MM-dd。 icon?: string | object; // 在输入框右侧显示的图标。 weekNames?: string[]; // 星期名称,索引为 0 表示周日。 monthNames?: string[]; // 月份名称,索引为 0 表示一月份。 yearText?: string; // 用于显示年份的格式化文本。 todayText?: string; // 用于显示“今天”的文本。 clearText?: string; // 用于显示“清除”的文本。 weekStart?: number; // 一周从星期几开始,默认 1。 minDate?: DateLike; // 最小可选的日期。 maxDate?: DateLike; // 最大可选的日期。 menu?: object[] | object; // 左侧显示的菜单设置。 actions?: object[] | object; // 底部工具栏设置。 onInvalid?: function; // 日期值无效时的回调函数。

    MIT License (MIT)

    - +
    Skip to content

    日期选择器

    用法

    设置默认值

    通过 defaultValue 选项设置默认值,设置为 'today' 可以将默认值设置为当天。

    格式化

    通过 format 选项设置日期格式化形式,支持日期辅助方法 formatDate 中的所有格式。

    限制日期范围

    通过 minDatemaxDate 来限制可选的日期范围。

    自定义菜单

    通过 menu 选项可以在弹出面板侧面显示一个自定义菜单,通过 actions 可以自定义底部工具栏上的按钮。在菜单项和按钮上通过 [data-set-date] 属性指定点击按钮时要设定的日期。

    自定义侧边菜单

    通过 menu 选项可以在弹出面板左侧显示一个自定义菜单,在菜单项配置上通过 [data-set-date] 属性指定点击菜单项时要设定的日期。

    自定义底部按钮

    通过 actions 可以自定义底部工具栏上的按钮,在菜单项和按钮上通过 [data-set-date] 属性指定点击按钮时要设定的日期。

    选项

    名称类型默认值说明
    classNameanynull组件根元素的类名。 style?: object; // 组件根元素的样式。 tagName?: string; // 组件根元素的标签名。 attrs?: object; // 附加到组件根元素上的属性。 clickType?: 'toggle' | 'open'; // 点击类型,toggle 表示点击按钮时切换显示隐藏,open 表示点击按钮时只打开。 name?: string; // 作为表单项的名称。 defaultValue?: 'today' | string; // 默认值。 onChange?: function; // 值变更时的回调函数。 disabled?: boolean; // 是否禁用。 readonly?: boolean; // 是否只读,不允许手动修改。 required?: boolean; // 是否必须提供值(不能清除和选择空值)。 placeholder?: string; // 输入框上占位文本。 format?: string; // 日期格式,默认 yyyy-MM-dd。 icon?: string | object; // 在输入框右侧显示的图标。 weekNames?: string[]; // 星期名称,索引为 0 表示周日。 monthNames?: string[]; // 月份名称,索引为 0 表示一月份。 yearText?: string; // 用于显示年份的格式化文本。 todayText?: string; // 用于显示“今天”的文本。 clearText?: string; // 用于显示“清除”的文本。 weekStart?: number; // 一周从星期几开始,默认 1。 minDate?: DateLike; // 最小可选的日期。 maxDate?: DateLike; // 最大可选的日期。 menu?: object[] | object; // 左侧显示的菜单设置。 actions?: object[] | object; // 底部工具栏设置。 onInvalid?: function; // 日期值无效时的回调函数。

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/forms/datetime-picker/datetime.html b/dev/lib/forms/datetime-picker/datetime.html index 0c7eb3824c..9916e2696e 100644 --- a/dev/lib/forms/datetime-picker/datetime.html +++ b/dev/lib/forms/datetime-picker/datetime.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    日期时间选择器

    日期时间选择器允许用户通过下拉面板同时选择日期和时间。

    用法

    设置默认值

    通过 defaultValue 选项设置默认值,设置为 'today' 可以将默认值设置为现在时间。

    格式化

    通过 format 选项设置日期和时间的格式化形式。

    限制日期范围

    通过 minDatemaxDate 来限制可选的日期范围。

    自定义菜单

    通过 menu 选项可以在弹出面板左侧显示一个自定义菜单,通过 actions 可以自定义底部工具栏上的按钮。在菜单项和按钮上通过 [data-set-date] 属性指定点击按钮时要设定的日期。

    自定义左侧菜单

    通过 menu 选项可以在弹出面板左侧显示一个自定义菜单,在菜单项配置上通过 [data-set-date] 属性指定点击菜单项时要设定的日期。

    自定义底部按钮

    通过 actions 可以自定义底部工具栏上的按钮,在菜单项和按钮上通过 [data-set-date] 属性指定点击按钮时要设定的日期。

    选项

    名称类型默认值说明
    classNameanynull组件根元素的类名。 style?: object; // 组件根元素的样式。 tagName?: string; // 组件根元素的标签名。 attrs?: object; // 附加到组件根元素上的属性。 clickType?: 'toggle' | 'open'; // 点击类型,toggle 表示点击按钮时切换显示隐藏,open 表示点击按钮时只打开。 name?: string; // 作为表单项的名称。 defaultValue?: 'today' | string; // 默认值。 onChange?: function; // 值变更时的回调函数。 disabled?: boolean; // 是否禁用。 readonly?: boolean; // 是否只读,不允许手动修改。 required?: boolean; // 是否必须提供值(不能清除和选择空值)。 placeholder?: string; // 输入框上占位文本。 format?: string; // 日期格式,默认 yyyy-MM-dd。 icon?: string | object; // 在输入框右侧显示的图标。 weekNames?: string[]; // 星期名称,索引为 0 表示周日。 monthNames?: string[]; // 月份名称,索引为 0 表示一月份。 yearText?: string; // 用于显示年份的格式化文本。 todayText?: string; // 用于显示“今天”的文本。 clearText?: string; // 用于显示“清除”的文本。 weekStart?: number; // 一周从星期几开始,默认 1。 minDate?: DateLike; // 最小可选的日期。 maxDate?: DateLike; // 最大可选的日期。 menu?: object[] | object; // 左侧显示的菜单设置。 actions?: object[] | object; // 底部工具栏设置。 onInvalid?: function; // 日期值无效时的回调函数。 minuteStep?: number; // 分钟选择间隔,默认 5(分钟)。

    MIT License (MIT)

    - +
    Skip to content

    日期时间选择器

    日期时间选择器允许用户通过下拉面板同时选择日期和时间。

    用法

    设置默认值

    通过 defaultValue 选项设置默认值,设置为 'today' 可以将默认值设置为现在时间。

    格式化

    通过 format 选项设置日期和时间的格式化形式。

    限制日期范围

    通过 minDatemaxDate 来限制可选的日期范围。

    自定义菜单

    通过 menu 选项可以在弹出面板左侧显示一个自定义菜单,通过 actions 可以自定义底部工具栏上的按钮。在菜单项和按钮上通过 [data-set-date] 属性指定点击按钮时要设定的日期。

    自定义左侧菜单

    通过 menu 选项可以在弹出面板左侧显示一个自定义菜单,在菜单项配置上通过 [data-set-date] 属性指定点击菜单项时要设定的日期。

    自定义底部按钮

    通过 actions 可以自定义底部工具栏上的按钮,在菜单项和按钮上通过 [data-set-date] 属性指定点击按钮时要设定的日期。

    选项

    名称类型默认值说明
    classNameanynull组件根元素的类名。 style?: object; // 组件根元素的样式。 tagName?: string; // 组件根元素的标签名。 attrs?: object; // 附加到组件根元素上的属性。 clickType?: 'toggle' | 'open'; // 点击类型,toggle 表示点击按钮时切换显示隐藏,open 表示点击按钮时只打开。 name?: string; // 作为表单项的名称。 defaultValue?: 'today' | string; // 默认值。 onChange?: function; // 值变更时的回调函数。 disabled?: boolean; // 是否禁用。 readonly?: boolean; // 是否只读,不允许手动修改。 required?: boolean; // 是否必须提供值(不能清除和选择空值)。 placeholder?: string; // 输入框上占位文本。 format?: string; // 日期格式,默认 yyyy-MM-dd。 icon?: string | object; // 在输入框右侧显示的图标。 weekNames?: string[]; // 星期名称,索引为 0 表示周日。 monthNames?: string[]; // 月份名称,索引为 0 表示一月份。 yearText?: string; // 用于显示年份的格式化文本。 todayText?: string; // 用于显示“今天”的文本。 clearText?: string; // 用于显示“清除”的文本。 weekStart?: number; // 一周从星期几开始,默认 1。 minDate?: DateLike; // 最小可选的日期。 maxDate?: DateLike; // 最大可选的日期。 menu?: object[] | object; // 左侧显示的菜单设置。 actions?: object[] | object; // 底部工具栏设置。 onInvalid?: function; // 日期值无效时的回调函数。 minuteStep?: number; // 分钟选择间隔,默认 5(分钟)。

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/forms/datetime-picker/time.html b/dev/lib/forms/datetime-picker/time.html index dd254dc553..03818aaf0a 100644 --- a/dev/lib/forms/datetime-picker/time.html +++ b/dev/lib/forms/datetime-picker/time.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    时间选择器

    用法

    设置默认值

    通过 defaultValue 选项设置默认值,设置为 'now' 可以将默认值设置为页面显示的时刻。

    格式化

    通过 format 选项设置日期格式化形式,支持日期辅助方法 formatDate 中的所有格式。

    选项

    名称类型默认值说明

    MIT License (MIT)

    - +
    Skip to content

    时间选择器

    用法

    设置默认值

    通过 defaultValue 选项设置默认值,设置为 'now' 可以将默认值设置为页面显示的时刻。

    格式化

    通过 format 选项设置日期格式化形式,支持日期辅助方法 formatDate 中的所有格式。

    选项

    名称类型默认值说明

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/forms/form-control/index.html b/dev/lib/forms/form-control/index.html index 478e660e21..510fe31018 100644 --- a/dev/lib/forms/form-control/index.html +++ b/dev/lib/forms/form-control/index.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    表单控件

    输入框

    输入框通过为 <input> 元素添加类 form-control 实现,支持通过 type 属性设置输入框类型。

    选择框

    通过为 <select> 元素添加 form-control 类来使用选择框,包括单选和多选模式。

    单选框

    多选框

    TIP

    使用多选框时通常需要指定多选框高度。

    多行文本框

    通过为 <textarea> 元素添加 form-control 类来使用多行文本框。

    特殊表单控件

    在浏览器支持的情况下,还可以为 type 设置一些特殊类型。

    日期

    设置 <input type="date">

    时间

    设置 <input type="time">

    日期时间

    设置 <input type="datetime-local">

    月份

    设置 <input type="month">

    周数

    设置 <input type="week">

    范围

    设置 <input type="range">

    颜色

    设置 <input type="color">

    文件

    设置 <input type="file">

    尺寸

    通过为表单控件添加 size-* 工具类来设置尺寸。

    禁用

    通过为表单控件添加 disabled 属性来禁用表单控件。

    只读

    通过为表单控件添加 readonly 属性来表单控件只读。

    特殊状态

    通过为表单控件或者其直接父级元素添加工具类 has-errorhas-warninghas-error 来让其拥有特殊语义的状态。

    CSS 类

    表单控件提供了如下 CSS 类:

    类型作用
    form-control实体类元素作为表单控件组件
    size-sm工具类表单控件使用小号尺寸
    size-lg工具类表单控件使用大号尺寸

    CSS 变量

    表单控件提供了如下 CSS 变量,可进行全局修改。

    CSS 变量名作用
    --form-control-radius圆角
    --form-control-border边框颜色
    --form-control-focus激活颜色
    --form-control-disabled禁用颜色
    --form-control-readonly只读颜色

    MIT License (MIT)

    - +
    Skip to content

    表单控件

    输入框

    输入框通过为 <input> 元素添加类 form-control 实现,支持通过 type 属性设置输入框类型。

    选择框

    通过为 <select> 元素添加 form-control 类来使用选择框,包括单选和多选模式。

    单选框

    多选框

    TIP

    使用多选框时通常需要指定多选框高度。

    多行文本框

    通过为 <textarea> 元素添加 form-control 类来使用多行文本框。

    特殊表单控件

    在浏览器支持的情况下,还可以为 type 设置一些特殊类型。

    日期

    设置 <input type="date">

    时间

    设置 <input type="time">

    日期时间

    设置 <input type="datetime-local">

    月份

    设置 <input type="month">

    周数

    设置 <input type="week">

    范围

    设置 <input type="range">

    颜色

    设置 <input type="color">

    文件

    设置 <input type="file">

    尺寸

    通过为表单控件添加 size-* 工具类来设置尺寸。

    禁用

    通过为表单控件添加 disabled 属性来禁用表单控件。

    只读

    通过为表单控件添加 readonly 属性来表单控件只读。

    特殊状态

    通过为表单控件或者其直接父级元素添加工具类 has-errorhas-warninghas-error 来让其拥有特殊语义的状态。

    CSS 类

    表单控件提供了如下 CSS 类:

    类型作用
    form-control实体类元素作为表单控件组件
    size-sm工具类表单控件使用小号尺寸
    size-lg工具类表单控件使用大号尺寸

    CSS 变量

    表单控件提供了如下 CSS 变量,可进行全局修改。

    CSS 变量名作用
    --form-control-radius圆角
    --form-control-border边框颜色
    --form-control-focus激活颜色
    --form-control-disabled禁用颜色
    --form-control-readonly只读颜色

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/forms/form/index.html b/dev/lib/forms/form/index.html index 824f6f4e48..dd4ac7c4e8 100644 --- a/dev/lib/forms/form/index.html +++ b/dev/lib/forms/form/index.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    表单

    基本用法

    <form> 元素使用类 .form 类来获得表单外观,将表单控件放置在表单控件组 .form-group 内,将表单操作按钮放置在表单操作栏 .form-actions 中。

    水平布局的表单

    <form> 元素使用类 .form-horz 类来让表单实现水平布局。

    在水平布局表单中,如果需要在一行包含多个表单控件,可以使用 .form-row 类,下面是一个更复杂的例子:

    可以放在同一行的字段满足:可连着填写,字段意义上有相似性
    此表单项为必填
    强关联字段,有灰色底色进行连接,3个以上框的自适应宽度

    网格布局

    <form> 元素使用类 .form-grid 类来让表单实现网格布局。

    .form-group 添加 w-* 辅助类来设置宽度
    项目类型
    -

    帮助性文本

    使用 form-tip 来显示帮助性的文本并添加到表单控件组中。

    校验状态

    通过为表单控件组添加 has-warninghas-errorhas-success 类即可应用相应的效验状态样式。这些样式会影响到表单控件组内的 label.form-control.form-tip 元素。

    表单分组

    使用fieldset 将多个表单控件放置在一起进行分组。在<fieldset> 内使用 <legend> 来定义分组标题。

    账号信息
    额外内容

    标记必填项

    标记必填项的一种通用方法是在标签上添加星标 * , 在表单控件组中只需要为表单组标签 .form-label 添加 required 类。

    水平布局的表单中也可以使用:

    CSS 类

    表单提供了如下 CSS 类

    类型作用
    form-group实体类元素作为表单组件
    form-label实体类元素作为表单组标签
    form-control实体类元素作为表单控件组件
    form-tip实体类元素作为表单控件的提示性文本
    form-actions实体类元素作为表单按钮容器
    form-grid修饰类为表单启用水平排列样式
    required修饰类为表单控件启用必填标记样式
    has-error修饰类为表单控件启用报错样式
    has-warning修饰类为表单控件启用警告样式
    has-success修饰类为表单控件启用成功样式

    CSS 变量

    变量名称变量含义
    --form-label-color表单组标签颜色
    --form-tip-color帮助性文本默认颜色
    --form-grid-label-width水平布局时表单表单组标签宽度

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/lib/forms/input-control/index.html b/dev/lib/forms/input-control/index.html index ce73ef1cbf..0c88f00b5d 100644 --- a/dev/lib/forms/input-control/index.html +++ b/dev/lib/forms/input-control/index.html @@ -14,19 +14,19 @@ - - + + -
    Skip to content

    输入框

    通过鼠标或键盘输入内容,可以在输入框前后位置包含额外的文本或图标,通常用在表单、对话框上面。

    基本使用

    使用 input-control 类来获得输入框的外观和交互体验。

    用户名
    用户名验证失败

    包含图标和按钮

    前缀和后缀

    通过结合类 has-prefix has-suffix 在输入框上添加前缀或后缀图标或字符。

    除了预设的前 / 后缀宽度,还预设了其他两种尺寸,结合 has-prefix-*has-suffix-* 类进行不同宽度展示。

    用户名
    有效身份证号码

    尺寸

    除了默认大小,输入框还提供了额外的 2 种预设尺寸。

    小号尺寸

    用户名
    有效身份证号码

    默认尺寸

    用户名
    有效身份证号码

    大号尺寸

    用户名
    有效身份证号码

    外观类型

    配合使用CSS 工具类来实现不同输入框的外观。下面展示各种工具类的外观效果。

    html
    <div class="input-control">
    +    
    Skip to content

    输入框

    通过鼠标或键盘输入内容,可以在输入框前后位置包含额外的文本或图标,通常用在表单、对话框上面。

    基本使用

    使用 input-control 类来获得输入框的外观和交互体验。

    用户名
    用户名验证失败

    包含图标和按钮

    前缀和后缀

    通过结合类 has-prefix has-suffix 在输入框上添加前缀或后缀图标或字符。

    除了预设的前 / 后缀宽度,还预设了其他两种尺寸,结合 has-prefix-*has-suffix-* 类进行不同宽度展示。

    用户名
    有效身份证号码

    尺寸

    除了默认大小,输入框还提供了额外的 2 种预设尺寸。

    小号尺寸

    用户名
    有效身份证号码

    默认尺寸

    用户名
    有效身份证号码

    大号尺寸

    用户名
    有效身份证号码

    外观类型

    配合使用CSS 工具类来实现不同输入框的外观。下面展示各种工具类的外观效果。

    html
    <div class="input-control">
       <input type="text" class="form-control circle" placeholder="请填写" />
     </div>
     <div class="input-control">
       <input type="text" class="form-control shadow" placeholder="请填写" />
     </div>

    CSS 类

    输入框提供了如下 CSS 类:

    类型作用
    input-control实体类元素作为输入框组件
    input-control-prefix工具类输入框前缀元素样式
    input-control-suffix工具类输入框后缀元素样式
    has-prefix工具类标记输入框拥有前缀元素
    has-suffix工具类标记输入框拥有后缀元素
    has-prefix-icon工具类标记输入框拥有前缀图标
    has-suffix-icon工具类标记输入框拥有后缀图标
    size-sm工具类输入框使用小号尺寸
    size-lg工具类输入框使用大号尺寸

    CSS 变量

    输入框提供了如下 CSS 变量,可进行全局修改。

    CSS 变量名作用
    --input-fix-width输入框前/后缀的默认宽度
    --input-fix-width-sm输入框前/后缀的小号宽度
    --input-fix-width-lg输入框前/后缀的大号宽度

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/lib/forms/input-group/index.html b/dev/lib/forms/input-group/index.html index 9afb75ac6a..1e30143bd6 100644 --- a/dev/lib/forms/input-group/index.html +++ b/dev/lib/forms/input-group/index.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    输入组

    通过在文本输入框 <input> 前面、后面或是两边加上文字、图标或按钮,可以实现对表单控件的扩展。

    使用方法

    在元素使用工具类 .input-group 作为输入组容器,然后在内部添加表单控件、按钮或附加文本(.input-group-addon)。

    账号
    密码

    组合方式

    在输入组内部可以将不同的内容按需组合使用,包括附加文本(.input-group-addon)、表单控件(.form-control)、按钮(.btn)。

    登录

    尺寸

    除了默认大小,输入组还提供了额外的 2 种预设尺寸,通过修饰类 .size-* 来应用尺寸。

    登录
    登录
    登录

    CSS 类

    输入组提供了如下 CSS 类:

    类型作用
    input-group实体类元素作为输入组组件
    input-group-addon实体类元素作为输入组内部额外元素
    size-sm工具类输入组使用小号尺寸
    size-lg工具类输入组使用大号尺寸

    CSS 变量

    变量名称变量含义
    --input-group-addon-bg输入组附加部分背景颜色

    MIT License (MIT)

    - +
    Skip to content

    输入组

    通过在文本输入框 <input> 前面、后面或是两边加上文字、图标或按钮,可以实现对表单控件的扩展。

    使用方法

    在元素使用工具类 .input-group 作为输入组容器,然后在内部添加表单控件、按钮或附加文本(.input-group-addon)。

    账号
    密码

    组合方式

    在输入组内部可以将不同的内容按需组合使用,包括附加文本(.input-group-addon)、表单控件(.form-control)、按钮(.btn)。

    登录

    尺寸

    除了默认大小,输入组还提供了额外的 2 种预设尺寸,通过修饰类 .size-* 来应用尺寸。

    登录
    登录
    登录

    CSS 类

    输入组提供了如下 CSS 类:

    类型作用
    input-group实体类元素作为输入组组件
    input-group-addon实体类元素作为输入组内部额外元素
    size-sm工具类输入组使用小号尺寸
    size-lg工具类输入组使用大号尺寸

    CSS 变量

    变量名称变量含义
    --input-group-addon-bg输入组附加部分背景颜色

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/lib/forms/picker/index.html b/dev/lib/forms/picker/index.html index acaafce81a..ccbf4ea775 100644 --- a/dev/lib/forms/picker/index.html +++ b/dev/lib/forms/picker/index.html @@ -14,14 +14,14 @@ - - + + - - + + \ No newline at end of file diff --git a/dev/lib/helpers/helpers/date-helper.html b/dev/lib/helpers/helpers/date-helper.html index 65382ddf3b..5b2751f92a 100644 --- a/dev/lib/helpers/helpers/date-helper.html +++ b/dev/lib/helpers/helpers/date-helper.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    日期辅助方法

    createDate

    创建日期时间对象。

    定义:

    ts
    function createDate(dateLike: string | number | Date): Date;

    参数

    • dateLike:日期时间对象或者日期时间字符串或者时间戳。

    返回值Date:日期时间对象。

    addDate

    在一个日期时间对象上增加指定的时间。

    定义:

    ts
    function addDate(dateLike: string | number | Date, value: number, unit: string): Date;

    参数:

    • dateLike:日期时间对象或者日期时间字符串或者时间戳;
    • value:增加的时间值;
    • unit:增加的时间单位,可选值为:yearmonthdayhourminutesecond

    返回值: Date:日期时间对象。

    formatDate

    格式化日期时间对象。

    定义:

    ts
    function formatDate(dateLike: string | number | Date, format = 'yyyy-MM-dd hh:mm', invalidDateValue = ''): string;

    参数:

    • dateLike:日期时间对象或者日期时间字符串或者时间戳;
    • format:格式化字符串,可选值为:yyyyMMddhhmmssSSS
    • invalidDateValue:无效日期时间对象时的返回值。

    返回值: string:格式化后的日期时间字符串。

    所有支持的格式化占位符包括:

      • yyyy,例如:2018,表示四位数字表示的年份
      • yy,例如:18,表示两位数字表示的年份
      • MM,例如:07,表示两位数字表示的月份,不足两位在起始用 0 填充
      • M,例如:10,表示一位或两位数字表示的月份
      • dd,例如:05,表示两位数字表示的日期,不足两位在起始用 0 填充
      • d,例如:5,表示一位或两位数字表示的日期
      • hh,例如:08,表示两位数字表示的小时,不足两位在起始用 0 填充
      • h,例如:8,表示一位或两位数字表示的小时
      • mm,例如:03,表示两位数字表示的分钟,不足两位在起始用 0 填充
      • m,例如:3,表示一位或两位数字表示的分钟
      • ss,例如:05,表示两位数字表示的秒数,不足两位在起始用 0 填充
      • s,例如:5,表示一位或两位数字表示的秒数
      • S,例如:236,表示毫秒数
      • SSS,例如:036,表示毫秒数,不足3位在起始用 0 填充

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/lib/helpers/helpers/string-helper.html b/dev/lib/helpers/helpers/string-helper.html index 4d2f45f907..71c9a7bcfa 100644 --- a/dev/lib/helpers/helpers/string-helper.html +++ b/dev/lib/helpers/helpers/string-helper.html @@ -14,8 +14,8 @@ - - + + @@ -25,7 +25,7 @@ /** 通过映射对象的形式格式化字符串。 */ function formatString(str: string, map: Record<string, unknown>): string;

    参数

    • str:字符串;
    • args:格式化参数;
    • map:格式化参数映射对象。

    返回值string:格式化后的字符串。

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/lib/helpers/store/index.html b/dev/lib/helpers/store/index.html index f34d2a1166..5251dc5155 100644 --- a/dev/lib/helpers/store/index.html +++ b/dev/lib/helpers/store/index.html @@ -14,8 +14,8 @@ - - + + @@ -41,7 +41,7 @@ store.get('mySecretCode'); // 返回 1 myStore.get('mySecretCode'); // 返回 2 mySessionStore.get('mySecretCode'); // 返回 3 - + \ No newline at end of file diff --git a/dev/lib/index.html b/dev/lib/index.html index b2fa672c0c..f9cfee9095 100644 --- a/dev/lib/index.html +++ b/dev/lib/index.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/public/zui/icons/fontawesome-license.html b/dev/public/zui/icons/fontawesome-license.html index 8eed4e357e..493538e1a4 100644 --- a/dev/public/zui/icons/fontawesome-license.html +++ b/dev/public/zui/icons/fontawesome-license.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    License

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/themes/index.html b/dev/themes/index.html index 4f08d01c44..d1b8a92b0f 100644 --- a/dev/themes/index.html +++ b/dev/themes/index.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/backgrounds/utilities/index.html b/dev/utilities/backgrounds/utilities/index.html index 46ef904b53..2b0d8e8975 100644 --- a/dev/utilities/backgrounds/utilities/index.html +++ b/dev/utilities/backgrounds/utilities/index.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    背景色

    效果

    使用工具类 bg-* 给元素添加背景色。

    语义化
    bg-primary
    bg-secondary
    bg-success
    bg-warning
    bg-danger
    bg-important
    bg-special
    主色系列
    bg-primary-50
    bg-primary-100
    bg-primary-200
    bg-primary-300
    bg-primary-400
    bg-primary-500
    bg-primary-600
    bg-primary-700
    bg-primary-800
    bg-primary-900
    bg-primary-950
    次要系列
    bg-secondary-50
    bg-secondary-100
    bg-secondary-200
    bg-secondary-300
    bg-secondary-400
    bg-secondary-500
    bg-secondary-600
    bg-secondary-700
    bg-secondary-800
    bg-secondary-900
    bg-secondary-950
    灰度
    bg-gray-50
    bg-gray-100
    bg-gray-200
    bg-gray-300
    bg-gray-400
    gray
    bg-gray-500 别名: bg-gray
    bg-gray-600
    bg-gray-700
    bg-gray-800
    bg-gray-900
    bg-gray-950
    界面
    bg-white
    纯白
    bg-black
    纯黑
    bg-transparent
    透明
    bg-canvas
    画布
    bg-inverse
    反色
    bg-surface-light
    加重的控件
    bg-surface
    控件
    bg-surface-strong
    轻量的控件
    bg-fore
    前景色作为背景
    bg-focus
    焦点色作为背景
    特殊
    bg-current
    CSS 值 currentColor
    bg-inherit
    CSS 值 inherit
    bg-none
    无背景

    背景色透明度

    使用工具类 bg-opacity-* 给元素设置背景色透明度。

    bg-opacity-0
    透明度:0%
    bg-opacity-5
    透明度:5%
    bg-opacity-10
    透明度:10%
    bg-opacity-20
    透明度:20%
    bg-opacity-25
    透明度:25%
    bg-opacity-30
    透明度:30%
    bg-opacity-40
    透明度:40%
    bg-opacity-50
    透明度:60%
    bg-opacity-60
    透明度:60%
    bg-opacity-70
    透明度:70%
    bg-opacity-75
    透明度:75%
    bg-opacity-80
    透明度:80%
    bg-opacity-90
    透明度:90%
    bg-opacity-95
    透明度:95%
    bg-opacity-100
    透明度:0%

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/borders/utilities/border-color.html b/dev/utilities/borders/utilities/border-color.html index de725d2c2a..5898928ff3 100644 --- a/dev/utilities/borders/utilities/border-color.html +++ b/dev/utilities/borders/utilities/border-color.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    边框颜色

    效果

    使用工具类 border-* 给元素添加边框颜色。

    默认
    border-light
    border
    border-strong
    语义化
    border-primary
    border-secondary
    border-success
    border-warning
    border-danger
    border-important
    border-special
    灰度
    border-gray-50
    border-gray-100
    border-gray-200
    border-gray-300
    border-gray-400
    gray
    border-gray-500 别名: border-gray
    border-gray-600
    border-gray-700
    border-gray-800
    border-gray-900
    border-gray-950
    界面
    border-white
    纯白
    border-black
    纯黑
    border-transparent
    透明
    border-canvas
    画布
    border-inverse
    反色
    border-surface-light
    加重的控件
    border-surface
    控件
    border-surface-strong
    轻量的控件
    border-fore
    前景色作为边框颜
    border-focus
    焦点色作为边框颜
    特殊
    border-current
    CSS 值 currentColor
    border-inherit
    CSS 值 inherit

    提示

    border 外,其他工具类只设置边框颜色,如果需要启用边框,需要将 border-*border 类一起使用,例如 border border-primary

    边框颜色透明度

    使用工具类 border-opacity-* 给元素添加边框颜色透明度。

    border-opacity-0
    透明度:0%
    border-opacity-5
    透明度:5%
    border-opacity-10
    透明度:10%
    border-opacity-20
    透明度:20%
    border-opacity-25
    透明度:25%
    border-opacity-30
    透明度:30%
    border-opacity-40
    透明度:40%
    border-opacity-50
    透明度:60%
    border-opacity-60
    透明度:60%
    border-opacity-70
    透明度:70%
    border-opacity-75
    透明度:75%
    border-opacity-80
    透明度:80%
    border-opacity-90
    透明度:90%
    border-opacity-95
    透明度:95%
    border-opacity-100
    透明度:0%

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/borders/utilities/border-radius.html b/dev/utilities/borders/utilities/border-radius.html index d8795d4176..34f53467ad 100644 --- a/dev/utilities/borders/utilities/border-radius.html +++ b/dev/utilities/borders/utilities/border-radius.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    边框圆角

    效果

    使用 'rounded-* 设置元素边框圆角大小。

    所有边
    rounded-none
    rounded-sm
    rounded
    rounded-lg
    rounded-xl
    rounded-2xl
    rounded-3xl
    rounded-full
    禁用特定边
    rounded-t-none
    rounded-r-none
    rounded-b-none
    rounded-l-none
    rounded-br-none
    rounded-bl-none
    rounded-tr-none
    rounded-tl-none

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/borders/utilities/border-width.html b/dev/utilities/borders/utilities/border-width.html index 8205a6aec8..a862adc81a 100644 --- a/dev/utilities/borders/utilities/border-width.html +++ b/dev/utilities/borders/utilities/border-width.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    边框大小

    效果

    使用 'rounded-* 设置元素边框大小。

    所有边
    border-0
    border
    border-2
    border-4
    上边框
    border-t-0
    border-t
    border-t-2
    border-t-4
    右边框
    border-r-0
    border-r
    border-r-2
    border-r-4
    下边框
    border-b-0
    border-b
    border-b-2
    border-b-4
    左边框
    border-l-0
    border-l
    border-l-2
    border-l-4

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/borders/utilities/divider.html b/dev/utilities/borders/utilities/divider.html index 0d9f2977c4..2ac4e9e19e 100644 --- a/dev/utilities/borders/utilities/divider.html +++ b/dev/utilities/borders/utilities/divider.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/utilities/borders/utilities/ring-color.html b/dev/utilities/borders/utilities/ring-color.html index 92ed12e54e..9b9e59b8b1 100644 --- a/dev/utilities/borders/utilities/ring-color.html +++ b/dev/utilities/borders/utilities/ring-color.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    环颜色

    效果

    通过 ring-* 来为元素添加通过 box-shadow 实现的环边框颜色。

    作为边框
    ring-border-light
    ring-border
    ring-border-strong
    透明度反色
    ring-light
    ring-gray
    ring-dark
    ring-darker
    ring-darkest
    语义化
    ring-primary
    ring-secondary
    ring-success
    ring-warning
    ring-danger
    ring-important
    ring-special
    灰度
    ring-gray-50
    ring-gray-100
    ring-gray-200
    ring-gray-300
    ring-gray-400
    ring-gray-500
    ring-gray-600
    ring-gray-700
    ring-gray-800
    ring-gray-900
    ring-gray-950
    界面
    ring-white
    纯白
    ring-black
    纯黑
    ring-canvas
    画布
    ring-inverse
    反色
    ring-surface
    控件
    ring-fore
    前景色
    ring-focus
    焦点色
    特殊
    ring-current
    CSS 值 currentColor
    ring-inherit
    CSS 值 inherit

    环颜色透明度

    使用工具类 ring-opacity-* 给元素添加背景色透明度。

    ring-opacity-0
    透明度:0%
    ring-opacity-5
    透明度:5%
    ring-opacity-10
    透明度:10%
    ring-opacity-20
    透明度:20%
    ring-opacity-25
    透明度:25%
    ring-opacity-30
    透明度:30%
    ring-opacity-40
    透明度:40%
    ring-opacity-50
    透明度:60%
    ring-opacity-60
    透明度:60%
    ring-opacity-70
    透明度:70%
    ring-opacity-75
    透明度:75%
    ring-opacity-80
    透明度:80%
    ring-opacity-90
    透明度:90%
    ring-opacity-95
    透明度:95%
    ring-opacity-100
    透明度:0%

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/borders/utilities/ring-offset.html b/dev/utilities/borders/utilities/ring-offset.html index e8e48e7553..e06ac9119a 100644 --- a/dev/utilities/borders/utilities/ring-offset.html +++ b/dev/utilities/borders/utilities/ring-offset.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/utilities/borders/utilities/ring-width.html b/dev/utilities/borders/utilities/ring-width.html index d0eec40f63..5a3ec0f1ce 100644 --- a/dev/utilities/borders/utilities/ring-width.html +++ b/dev/utilities/borders/utilities/ring-width.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/utilities/effects/utilities/animation.html b/dev/utilities/effects/utilities/animation.html index 880a4d63e5..9dc7cfc9da 100644 --- a/dev/utilities/effects/utilities/animation.html +++ b/dev/utilities/effects/utilities/animation.html @@ -14,8 +14,8 @@ - - + + @@ -35,7 +35,7 @@ </div>

    弹跳

    使用 animate-bounce 给元素添加弹跳动画。

    html
    <button type="button" class="btn primary">
       <i class="bounce icon icon-arrow-down"></i> 下载
     </button>
    - + \ No newline at end of file diff --git a/dev/utilities/effects/utilities/filter.html b/dev/utilities/effects/utilities/filter.html index d401b4c7b8..fa6e081bb5 100644 --- a/dev/utilities/effects/utilities/filter.html +++ b/dev/utilities/effects/utilities/filter.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    CSS 滤镜

    高斯模糊

    通过 blur-* 给图片添加高斯模糊样式。

    原始
    blur-none
    blur-sm
    blur
    blur-md
    blur-lg
    blur-xl

    灰度和反色

    通过 grayscale 将图像转为灰度图像;通过 invert 将图像设置为反色。

    原始
    grayscale
    invert

    形状阴影

    通过 drop-shadow-* 给元素设置形状阴影效果,通常用在图片上。

    原始
    drop-shadow-none
    drop-shadow-sm
    drop-shadow
    drop-shadow-md
    drop-shadow-lg
    drop-shadow-xl
    drop-shadow-2xl

    背景模糊

    通过 backdrop-blur-* 添加覆盖区域模糊样式。

    原始
    backdrop-blur-none
    backdrop-blur-sm
    backdrop-blur
    backdrop-blur-md
    backdrop-blur-lg
    backdrop-blur-xl
    backdrop-blur-2xl
    backdrop-blur-3xl

    禁用滤镜

    通过 filter-none 来禁用之前添加的滤镜效果。

    filter-none

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/effects/utilities/opacity.html b/dev/utilities/effects/utilities/opacity.html index 642d7e0d4a..83598a01ff 100644 --- a/dev/utilities/effects/utilities/opacity.html +++ b/dev/utilities/effects/utilities/opacity.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/utilities/effects/utilities/shadow.html b/dev/utilities/effects/utilities/shadow.html index bf65dfdb39..8324fba8ac 100644 --- a/dev/utilities/effects/utilities/shadow.html +++ b/dev/utilities/effects/utilities/shadow.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/utilities/effects/utilities/transform.html b/dev/utilities/effects/utilities/transform.html index 9c88c228e1..83e9fc2a30 100644 --- a/dev/utilities/effects/utilities/transform.html +++ b/dev/utilities/effects/utilities/transform.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    变换

    使用 CSS transform 对元素应用变换效果。

    缩放

    通过 scale-* 为元素应用缩放效果。

    原始
    scale-0
    scale-50
    scale-75
    scale-90
    scale-95
    scale-100
    scale-105
    scale-110
    scale-125
    scale-150

    旋转

    通过 rotate-* 为元素应用旋转效果。

    原始
    rotate-0
    rotate-1
    rotate-2
    rotate-3
    rotate-6
    rotate-12
    rotate-45
    rotate-90
    rotate-135
    rotate-180
    rotate-270

    翻转

    添加 flip-* 给元素添加翻转效果。

    原始
    flip-x
    flip-y

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/effects/utilities/transition.html b/dev/utilities/effects/utilities/transition.html index e14b2ef4c4..42ff1e921b 100644 --- a/dev/utilities/effects/utilities/transition.html +++ b/dev/utilities/effects/utilities/transition.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    过渡动画

    过渡属性

    通过 transition-* 为元素应用过渡动画,并制定过渡目标属性。

    transition
    transition
    all
    transition-all
    colors
    transition-colors
    opacity
    transition-opacity
    shadow
    transition-shadow
    transform
    transition-transform

    过渡时间

    通过 duration-* 为元素应用过渡动画时间。

    75ms
    duration-75
    100ms
    duration-100
    200ms
    duration-200
    300ms
    duration-300
    500ms
    duration-500
    1000ms
    duration-1000

    渐隐渐显

    通过 fade-* 来为元素设置渐隐渐显动画效果,默认元素不显示,通过控制添加 in 类让元素渐显。

    默认
    默认
    fade
    从中心显示
    从中心显示
    fade-from-center
    从下方显示
    从下方显示
    fade-from-bottom
    从上方显示
    从上方显示
    fade-from-top
    从左侧显示
    从左侧显示
    fade-from-left
    从右侧显示
    从右侧显示
    fade-from-right

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/flex/utilities/align-content.html b/dev/utilities/flex/utilities/align-content.html index 37405e16f6..ed3c51afb4 100644 --- a/dev/utilities/flex/utilities/align-content.html +++ b/dev/utilities/flex/utilities/align-content.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    align-content

    使用 content-* 应用CSS align-content 属性设置 Flex 容器中多行子元素沿交叉轴的对齐方式。

    效果展示

    content-center

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10

    content-start

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10

    content-end

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10

    content-between

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10

    content-around

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10

    content-evenly

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/flex/utilities/align-items.html b/dev/utilities/flex/utilities/align-items.html index df94e0cf48..c75571b06c 100644 --- a/dev/utilities/flex/utilities/align-items.html +++ b/dev/utilities/flex/utilities/align-items.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/utilities/flex/utilities/align-self.html b/dev/utilities/flex/utilities/align-self.html index fe1780ff89..ec03afeb63 100644 --- a/dev/utilities/flex/utilities/align-self.html +++ b/dev/utilities/flex/utilities/align-self.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    align-self

    使用 self-* 应用 CSS align-self 属性设置当前元素在 Grid 或 Flex 容器中的交叉轴方向上的对齐方式。

    self-auto

    self-auto
    default
    default
    default
    default

    self-start

    self-start
    default
    default
    default
    default

    self-end

    self-end
    default
    default
    default
    default

    self-center

    self-center
    default
    default
    default
    default

    self-stretch

    self-stretch
    default
    default
    default
    default

    self-baseline

    self-baseline
    default
    default
    default
    default

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/flex/utilities/basis.html b/dev/utilities/flex/utilities/basis.html index 6395db948c..79d42fa665 100644 --- a/dev/utilities/flex/utilities/basis.html +++ b/dev/utilities/flex/utilities/basis.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/utilities/flex/utilities/direction.html b/dev/utilities/flex/utilities/direction.html index e35d0d3423..408d861695 100644 --- a/dev/utilities/flex/utilities/direction.html +++ b/dev/utilities/flex/utilities/direction.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/utilities/flex/utilities/flex.html b/dev/utilities/flex/utilities/flex.html index 9d13efee82..4b67279ae3 100644 --- a/dev/utilities/flex/utilities/flex.html +++ b/dev/utilities/flex/utilities/flex.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    flex

    效果

    使用 flex-* 应用CSS flex 属性设置当前元素在 Grid 或 Flex 容器中的伸缩方式。

    flex-auto

    24 × 8
    24 × 8
    24 × 8

    flex-1

    24 × 8
    24 × 8
    24 × 8

    flex-initial

    24 × 8
    24 × 8
    24 × 8

    flex-none

    24 × 8
    24 × 8
    24 × 8

    混合使用

    flex-auto
    flex-1
    flex-initial
    flex-none

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/flex/utilities/gap.html b/dev/utilities/flex/utilities/gap.html index dbad53aa0b..72450fd3b4 100644 --- a/dev/utilities/flex/utilities/gap.html +++ b/dev/utilities/flex/utilities/gap.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    gap

    效果

    使用 gap-* 应用CSS属性 gap 设置 Flex 容器中元素间距。

    gap-0

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-x-0

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-y-0

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-1

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-x-1

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-y-1

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-2

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-x-2

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-y-2

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-3

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-x-3

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-y-3

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-4

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-x-4

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-y-4

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-5

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-x-5

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-y-5

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-6

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-x-6

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-y-6

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-7

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-x-7

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-y-7

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-8

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-x-8

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    gap-y-8

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/flex/utilities/grow.html b/dev/utilities/flex/utilities/grow.html index ba090af0c9..d50e5c618e 100644 --- a/dev/utilities/flex/utilities/grow.html +++ b/dev/utilities/flex/utilities/grow.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/utilities/flex/utilities/justify-content.html b/dev/utilities/flex/utilities/justify-content.html index ec60b54210..cdb4a1fabf 100644 --- a/dev/utilities/flex/utilities/justify-content.html +++ b/dev/utilities/flex/utilities/justify-content.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/utilities/flex/utilities/order.html b/dev/utilities/flex/utilities/order.html index 3d98e08b06..422941a89a 100644 --- a/dev/utilities/flex/utilities/order.html +++ b/dev/utilities/flex/utilities/order.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    order

    效果

    使用 order-* 应用CSS属性 order 设置当前元素在 Flex 容器中的排列顺序。

    1
    order-12
    2
    order-11
    3
    order-10
    4
    order-9
    5
    order-8
    6
    order-7
    7
    order-6
    8
    order-5
    9
    order-4
    10
    order-3
    11
    order-2
    12
    order-1

    使用 order-firstorder-lastorder-none 也可以改变 Flex 子元素排列顺序。

    0
    order-last
    1
    order-first
    2
    order-none

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/flex/utilities/shrink.html b/dev/utilities/flex/utilities/shrink.html index 3da7e3c180..8226f59e2f 100644 --- a/dev/utilities/flex/utilities/shrink.html +++ b/dev/utilities/flex/utilities/shrink.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/utilities/flex/utilities/wrap.html b/dev/utilities/flex/utilities/wrap.html index 857f1e4923..6778325185 100644 --- a/dev/utilities/flex/utilities/wrap.html +++ b/dev/utilities/flex/utilities/wrap.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/utilities/index.html b/dev/utilities/index.html index b722751896..2239fafe8f 100644 --- a/dev/utilities/index.html +++ b/dev/utilities/index.html @@ -14,14 +14,14 @@ - - + +
    - + \ No newline at end of file diff --git a/dev/utilities/interactivity/utilities/cursor.html b/dev/utilities/interactivity/utilities/cursor.html index 4c883c3013..d0d6343a29 100644 --- a/dev/utilities/interactivity/utilities/cursor.html +++ b/dev/utilities/interactivity/utilities/cursor.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    光标

    效果

    通过 cursor-* 类可以改变光标的样式。

    cursor-auto
    cursor-auto
    cursor-default
    cursor-default
    cursor-pointer
    cursor-pointer
    cursor-wait
    cursor-wait
    cursor-text
    cursor-text
    cursor-move
    cursor-move
    cursor-help
    cursor-help
    cursor-not-allowed
    cursor-not-allowed

    MIT License (MIT)

    - +
    Skip to content

    光标

    效果

    通过 cursor-* 类可以改变光标的样式。

    cursor-auto
    cursor-auto
    cursor-default
    cursor-default
    cursor-pointer
    cursor-pointer
    cursor-wait
    cursor-wait
    cursor-text
    cursor-text
    cursor-move
    cursor-move
    cursor-help
    cursor-help
    cursor-not-allowed
    cursor-not-allowed

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/interactivity/utilities/disabled.html b/dev/utilities/interactivity/utilities/disabled.html index ecd10da7d7..4347309480 100644 --- a/dev/utilities/interactivity/utilities/disabled.html +++ b/dev/utilities/interactivity/utilities/disabled.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    禁用

    效果

    使用 disabled 类设置元素为禁用,禁用的元素会以半透明的形式显示,并强制使用灰度显示。

    注意

    禁用元素仍然响应鼠标事件,如果需要完全禁用鼠标事件,需要添加 pointer-events-none,如果是表单元素或按钮则可以添加 disabled="disabled" 属性实现完全禁用。

    MIT License (MIT)

    - +
    Skip to content

    禁用

    效果

    使用 disabled 类设置元素为禁用,禁用的元素会以半透明的形式显示,并强制使用灰度显示。

    注意

    禁用元素仍然响应鼠标事件,如果需要完全禁用鼠标事件,需要添加 pointer-events-none,如果是表单元素或按钮则可以添加 disabled="disabled" 属性实现完全禁用。

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/interactivity/utilities/loading.html b/dev/utilities/interactivity/utilities/loading.html index 49e82891db..c3d5db3180 100644 --- a/dev/utilities/interactivity/utilities/loading.html +++ b/dev/utilities/interactivity/utilities/loading.html @@ -14,14 +14,14 @@ - - + + -
    - +
    + \ No newline at end of file diff --git a/dev/utilities/interactivity/utilities/pointer-events.html b/dev/utilities/interactivity/utilities/pointer-events.html index 05fdb5a028..7a99004029 100644 --- a/dev/utilities/interactivity/utilities/pointer-events.html +++ b/dev/utilities/interactivity/utilities/pointer-events.html @@ -14,14 +14,14 @@ - - + + -
    - +
    + \ No newline at end of file diff --git a/dev/utilities/interactivity/utilities/scroll.html b/dev/utilities/interactivity/utilities/scroll.html index 2ef391d4bc..ba41228b90 100644 --- a/dev/utilities/interactivity/utilities/scroll.html +++ b/dev/utilities/interactivity/utilities/scroll.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    滚动

    平滑滚动

    使用 scroll-smooth 工具类来为元素应用 scroll-behavior: smooth 属性,指定其进行平滑滚动。

    1
    2
    3
    4
    滚动到:

    立即滚动

    使用 scroll-auto 工具类来为元素应用 scroll-behavior: auto 属性,指定其进行立即滚动。

    1
    2
    3
    4
    滚动到:

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/interactivity/utilities/state.html b/dev/utilities/interactivity/utilities/state.html index fabcbaa36a..20a5d9f152 100644 --- a/dev/utilities/interactivity/utilities/state.html +++ b/dev/utilities/interactivity/utilities/state.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    状态响应

    效果

    通过为元素添加工具类 state 让按钮响应用户的鼠标交互,包括鼠标悬停、鼠标按下、获得焦点时拥有不同的样式。

    提示

    在按钮(.btn)和导航中的链接(.item > a )已经默认应用了 state 工具类,无需再次添加。

    MIT License (MIT)

    - +
    Skip to content

    状态响应

    效果

    通过为元素添加工具类 state 让按钮响应用户的鼠标交互,包括鼠标悬停、鼠标按下、获得焦点时拥有不同的样式。

    提示

    在按钮(.btn)和导航中的链接(.item > a )已经默认应用了 state 工具类,无需再次添加。

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/interactivity/utilities/user-select.html b/dev/utilities/interactivity/utilities/user-select.html index f8f9ac02d6..c6586aca11 100644 --- a/dev/utilities/interactivity/utilities/user-select.html +++ b/dev/utilities/interactivity/utilities/user-select.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    文本选择

    用于控制用户能否选中文本的工具类。

    效果

    通过工具类 select-* 来控制用户能否选中元素中的文本。

    禁止选择文本
    select-none
    允许选择文本
    select-text
    点击自动选择所有文本
    select-all
    浏览器默认行为
    select-auto

    MIT License (MIT)

    - +
    Skip to content

    文本选择

    用于控制用户能否选中文本的工具类。

    效果

    通过工具类 select-* 来控制用户能否选中元素中的文本。

    禁止选择文本
    select-none
    允许选择文本
    select-text
    点击自动选择所有文本
    select-all
    浏览器默认行为
    select-auto

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/layout/utilities/aspect-ratio.html b/dev/utilities/layout/utilities/aspect-ratio.html index 75b0e0aea4..11a45b10cb 100644 --- a/dev/utilities/layout/utilities/aspect-ratio.html +++ b/dev/utilities/layout/utilities/aspect-ratio.html @@ -14,14 +14,14 @@ - - + + -
    - +
    + \ No newline at end of file diff --git a/dev/utilities/layout/utilities/container.html b/dev/utilities/layout/utilities/container.html index fda239345c..5dd4f5dbd9 100644 --- a/dev/utilities/layout/utilities/container.html +++ b/dev/utilities/layout/utilities/container.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    容器

    定义

    使用 container 类将元素宽度限制为当前屏幕断点,具体规则如下:

    屏幕断点CSS 属性
    默认width: 100%;
    @media (min-width: --screen-sm)max-width: --screen-sm;
    @media (min-width: --screen-md)max-width: --screen-md;
    @media (min-width: --screen-lg)max-width: --screen-lg;
    @media (min-width: --screen-xl)max-width: --screen-xl;
    @media (min-width: --screen-2xl)max-width: --screen-2xl;

    提示

    .container 还会为元素添加 margin-left: auto; margin-right: auto;,使得元素默认居中显示。

    用法

    .container

    MIT License (MIT)

    - +
    Skip to content

    容器

    定义

    使用 container 类将元素宽度限制为当前屏幕断点,具体规则如下:

    屏幕断点CSS 属性
    默认width: 100%;
    @media (min-width: --screen-sm)max-width: --screen-sm;
    @media (min-width: --screen-md)max-width: --screen-md;
    @media (min-width: --screen-lg)max-width: --screen-lg;
    @media (min-width: --screen-xl)max-width: --screen-xl;
    @media (min-width: --screen-2xl)max-width: --screen-2xl;

    提示

    .container 还会为元素添加 margin-left: auto; margin-right: auto;,使得元素默认居中显示。

    用法

    .container

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/layout/utilities/display.html b/dev/utilities/layout/utilities/display.html index 12da873e5f..8ce12a1210 100644 --- a/dev/utilities/layout/utilities/display.html +++ b/dev/utilities/layout/utilities/display.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    显示类型

    定义

    在 ZUI 中提供了各种工具类来设置 CSS display 属性,主要包括:

    工具类属性
    blockdisplay: block;
    inline-blockdisplay: inline-block;
    inlinedisplay: inline;
    flexdisplay: flex;
    inline-flexdisplay: inline-flex;
    tabledisplay: table;
    table-celldisplay: table-cell;
    table-rowdisplay: table-row;
    list-itemdisplay: list-item;
    hiddendisplay: hidden;

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/layout/utilities/floats.html b/dev/utilities/layout/utilities/floats.html index f796b960f2..1519577250 100644 --- a/dev/utilities/layout/utilities/floats.html +++ b/dev/utilities/layout/utilities/floats.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    浮动

    定义

    用于设置元素浮动或清除浮动影响的工具类。

    工具类属性
    pull-rightfloat: right;
    pull-leftfloat: left;
    clearfix.clearfix::after {content: ""; display: block; clear: both;}

    提示

    浮动应当仅适用于实现文字环绕效果,布局请使用 Flex 工具类

    效果展示

    向右浮动

    使用工具类 pull-right 将一个元素浮动到其容器的右边。

    So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the kinship of all living things but I tell you Jerry at that moment, I was a marine biologist.

    月光如流水一般,静静地泻在这一片叶子和花上。薄薄的青雾浮起在荷塘里。叶子和花仿佛在牛乳中洗过一样;又像笼着轻纱的梦。

    向左浮动

    使用工具类 pull-left 将一个元素浮动到其容器的左边。

    So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the kinship of all living things but I tell you Jerry at that moment, I was a marine biologist.

    月光如流水一般,静静地泻在这一片叶子和花上。薄薄的青雾浮起在荷塘里。叶子和花仿佛在牛乳中洗过一样;又像笼着轻纱的梦。

    MIT License (MIT)

    - +
    Skip to content

    浮动

    定义

    用于设置元素浮动或清除浮动影响的工具类。

    工具类属性
    pull-rightfloat: right;
    pull-leftfloat: left;
    clearfix.clearfix::after {content: ""; display: block; clear: both;}

    提示

    浮动应当仅适用于实现文字环绕效果,布局请使用 Flex 工具类

    效果展示

    向右浮动

    使用工具类 pull-right 将一个元素浮动到其容器的右边。

    So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the kinship of all living things but I tell you Jerry at that moment, I was a marine biologist.

    月光如流水一般,静静地泻在这一片叶子和花上。薄薄的青雾浮起在荷塘里。叶子和花仿佛在牛乳中洗过一样;又像笼着轻纱的梦。

    向左浮动

    使用工具类 pull-left 将一个元素浮动到其容器的左边。

    So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the kinship of all living things but I tell you Jerry at that moment, I was a marine biologist.

    月光如流水一般,静静地泻在这一片叶子和花上。薄薄的青雾浮起在荷塘里。叶子和花仿佛在牛乳中洗过一样;又像笼着轻纱的梦。

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/layout/utilities/object-fit.html b/dev/utilities/layout/utilities/object-fit.html index bfae466aab..2af58d67dc 100644 --- a/dev/utilities/layout/utilities/object-fit.html +++ b/dev/utilities/layout/utilities/object-fit.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    内容适配

    定义

    元素的内容应该如何去适应指定容器的高度与宽度。

    工具类属性
    object-containobject-fit: contain;
    object-coverobject-fit: cover;
    object-fillobject-fit: fill;
    object-noneobject-fit: none;
    object-scale-downobject-fit: scale-down;

    效果展示

    包含

    使用工具类 object-contain 调整元素内容的大小,使其保持在容器内。

    覆盖

    使用工具类 object-cover 调整元素内容的大小以覆盖其容器。

    充满

    使用工具类 object-fill 拉伸元素的内容以适应其容器。

    使用工具类 object-none 以原始大小显示元素的内容,忽略容器大小。

    缩小

    以原始大小显示元素的内容,但必要时使用 object-scale-down 将其缩小以适应其容器。

    MIT License (MIT)

    - +
    Skip to content

    内容适配

    定义

    元素的内容应该如何去适应指定容器的高度与宽度。

    工具类属性
    object-containobject-fit: contain;
    object-coverobject-fit: cover;
    object-fillobject-fit: fill;
    object-noneobject-fit: none;
    object-scale-downobject-fit: scale-down;

    效果展示

    包含

    使用工具类 object-contain 调整元素内容的大小,使其保持在容器内。

    覆盖

    使用工具类 object-cover 调整元素内容的大小以覆盖其容器。

    充满

    使用工具类 object-fill 拉伸元素的内容以适应其容器。

    使用工具类 object-none 以原始大小显示元素的内容,忽略容器大小。

    缩小

    以原始大小显示元素的内容,但必要时使用 object-scale-down 将其缩小以适应其容器。

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/layout/utilities/overflow.html b/dev/utilities/layout/utilities/overflow.html index 66a50f1112..e1be355c68 100644 --- a/dev/utilities/layout/utilities/overflow.html +++ b/dev/utilities/layout/utilities/overflow.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    溢出

    定义

    用于控制元素如何处理超出容器的内容的工具类。

    工具类属性
    overflow-autooverflow: auto;
    overflow-hiddenoverflow: hidden;
    overflow-cliptext-overflow: clip;
    overflow-visibleoverflow: visible;
    overflow-scrolloverflow: scroll;
    overflow-x-autooverflow-x: auto;
    overflow-y-autooverflow-y: auto;
    overflow-x-hiddenoverflow-x: hidden;
    overflow-y-hiddenoverflow-y: hidden;
    overflow-x-visibleoverflow-x: visible;
    overflow-y-visibleoverflow-y: visible;
    overflow-x-scrolloverflow-x: scroll;
    overflow-y-scrolloverflow-y: scroll;

    效果展示

    自动

    使用工具类 overflow-auto 在一个元素的内容溢出该元素的边界时为其添加滚动条。不像 overflow-scroll 总是显示滚动条,这个工具类只在需要滚动时才会显示。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。
    小楼昨夜又东风,故国不堪回首月明中。
    雕栏玉砌应犹在,只是朱颜改。
    问君能有几多愁?恰似一江春水向东流

    隐藏

    使用工具类 overflow-hidden 来剪切元素中任何溢出该元素边界的内容。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。
    小楼昨夜又东风,故国不堪回首月明中。
    雕栏玉砌应犹在,只是朱颜改。
    问君能有几多愁?恰似一江春水向东流

    可见

    使用工具类 overflow-visible 来防止元素内的内容被剪切。请注意,任何溢出元素边界的内容都将是可见的。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。
    小楼昨夜又东风,故国不堪回首月明中。
    雕栏玉砌应犹在,只是朱颜改。
    问君能有几多愁?恰似一江春水向东流

    需要时水平滚动

    如果需要,使用工具类 overflow-x-auto 来允许水平滚动。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。小楼昨夜又东风,故国不堪回首月明中。雕栏玉砌应犹在,只是朱颜改。问君能有几多愁?恰似一江春水向东流

    需要时垂直滚动

    如果需要,使用工具类 overflow-y-auto 来允许垂直滚动。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。小楼昨夜又东风,故国不堪回首月明中。雕栏玉砌应犹在,只是朱颜改。问君能有几多愁?恰似一江春水向东流

    始终水平滚动

    如果需要,使用工具类 overflow-x-scroll 来允许水平滚动。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。小楼昨夜又东风,故国不堪回首月明中。雕栏玉砌应犹在,只是朱颜改。问君能有几多愁?恰似一江春水向东流

    始终垂直滚动

    如果需要,使用工具类 overflow-y-scroll 来允许水平滚动。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。小楼昨夜又东风,故国不堪回首月明中。雕栏玉砌应犹在,只是朱颜改。问君能有几多愁?恰似一江春水向东流

    在所有方向上滚动

    如果需要,使用工具类 overflow-scroll 来允许水平滚动。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。小楼昨夜又东风,故国不堪回首月明中。雕栏玉砌应犹在,只是朱颜改。问君能有几多愁?恰似一江春水向东流

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。小楼昨夜又东风,故国不堪回首月明中。雕栏玉砌应犹在,只是朱颜改。问君能有几多愁?恰似一江春水向东流

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。小楼昨夜又东风,故国不堪回首月明中。雕栏玉砌应犹在,只是朱颜改。问君能有几多愁?恰似一江春水向东流

    MIT License (MIT)

    - +
    Skip to content

    溢出

    定义

    用于控制元素如何处理超出容器的内容的工具类。

    工具类属性
    overflow-autooverflow: auto;
    overflow-hiddenoverflow: hidden;
    overflow-cliptext-overflow: clip;
    overflow-visibleoverflow: visible;
    overflow-scrolloverflow: scroll;
    overflow-x-autooverflow-x: auto;
    overflow-y-autooverflow-y: auto;
    overflow-x-hiddenoverflow-x: hidden;
    overflow-y-hiddenoverflow-y: hidden;
    overflow-x-visibleoverflow-x: visible;
    overflow-y-visibleoverflow-y: visible;
    overflow-x-scrolloverflow-x: scroll;
    overflow-y-scrolloverflow-y: scroll;

    效果展示

    自动

    使用工具类 overflow-auto 在一个元素的内容溢出该元素的边界时为其添加滚动条。不像 overflow-scroll 总是显示滚动条,这个工具类只在需要滚动时才会显示。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。
    小楼昨夜又东风,故国不堪回首月明中。
    雕栏玉砌应犹在,只是朱颜改。
    问君能有几多愁?恰似一江春水向东流

    隐藏

    使用工具类 overflow-hidden 来剪切元素中任何溢出该元素边界的内容。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。
    小楼昨夜又东风,故国不堪回首月明中。
    雕栏玉砌应犹在,只是朱颜改。
    问君能有几多愁?恰似一江春水向东流

    可见

    使用工具类 overflow-visible 来防止元素内的内容被剪切。请注意,任何溢出元素边界的内容都将是可见的。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。
    小楼昨夜又东风,故国不堪回首月明中。
    雕栏玉砌应犹在,只是朱颜改。
    问君能有几多愁?恰似一江春水向东流

    需要时水平滚动

    如果需要,使用工具类 overflow-x-auto 来允许水平滚动。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。小楼昨夜又东风,故国不堪回首月明中。雕栏玉砌应犹在,只是朱颜改。问君能有几多愁?恰似一江春水向东流

    需要时垂直滚动

    如果需要,使用工具类 overflow-y-auto 来允许垂直滚动。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。小楼昨夜又东风,故国不堪回首月明中。雕栏玉砌应犹在,只是朱颜改。问君能有几多愁?恰似一江春水向东流

    始终水平滚动

    如果需要,使用工具类 overflow-x-scroll 来允许水平滚动。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。小楼昨夜又东风,故国不堪回首月明中。雕栏玉砌应犹在,只是朱颜改。问君能有几多愁?恰似一江春水向东流

    始终垂直滚动

    如果需要,使用工具类 overflow-y-scroll 来允许水平滚动。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。小楼昨夜又东风,故国不堪回首月明中。雕栏玉砌应犹在,只是朱颜改。问君能有几多愁?恰似一江春水向东流

    在所有方向上滚动

    如果需要,使用工具类 overflow-scroll 来允许水平滚动。

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。小楼昨夜又东风,故国不堪回首月明中。雕栏玉砌应犹在,只是朱颜改。问君能有几多愁?恰似一江春水向东流

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。小楼昨夜又东风,故国不堪回首月明中。雕栏玉砌应犹在,只是朱颜改。问君能有几多愁?恰似一江春水向东流

    虞美人·春花秋月何时了

    五代·李煜

    春花秋月何时了?往事知多少。小楼昨夜又东风,故国不堪回首月明中。雕栏玉砌应犹在,只是朱颜改。问君能有几多愁?恰似一江春水向东流

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/layout/utilities/position.html b/dev/utilities/layout/utilities/position.html index 13fab71ecf..0554e9627f 100644 --- a/dev/utilities/layout/utilities/position.html +++ b/dev/utilities/layout/utilities/position.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    定位

    定义

    用于控制元素在DOM中的位置的工具类。

    工具类属性
    staticposition: static;
    fixedposition: fixed;
    absoluteposition: absolute;
    relativeposition: relative;
    stickyposition: sticky;

    使用方法

    staticabsolute

    使用 static 根据常规的文档流来定位元素,浏览器默认 position 取值就是 static。任何偏移都将被忽略,而且该元素不会作为绝对定位的子元素的位置参考。

    Static 父元素

    Absolute 子元素

    relativeabsolute

    使用 relative 根据常规的文档流来定位元素。偏移量是相对于元素的正常位置计算的,并且该元素将作为绝对定位的子元素的位置参考。

    使用 absolute 将一个元素定位在文档常规流之外,使相邻元素的行为就像该元素不存在一样。偏移量是相对于最近的位置不是 static 的父元素计算的,而且该元素将作为其他绝对定位的子元素的位置参考。

    Relative 父元素

    Absolute 子元素

    sticky

    sticky 元素根据正常文档流进行定位,然后相对它的最近滚动祖先和 containing block,包括 table-related 元素,基于 top、right、bottom 和 left 的值进行偏移。偏移值不会影响任何其他元素的位置。

    黄鹤楼送孟浩然之广陵

    故人西辞黄鹤楼,

    烟花三月下扬州。

    孤帆远影碧空尽,

    唯见长江天际流。

    闻王昌龄左迁龙标遥有此寄

    杨花落尽子规啼,

    闻道龙标过五溪。

    我寄愁心与明月,

    随君直到夜郎西。

    宣州谢朓楼饯别校书叔云

    弃我去者,昨日之日不可留;

    乱我心者,今日之日多烦忧。

    长风万里送秋雁,对此可以酣高楼。

    蓬莱文章建安骨,中间小谢又清发。

    俱怀逸兴壮思飞,欲上青天揽明月。

    抽刀断水水更流,举杯消愁愁更愁。

    人生在世不称意,明朝散发弄扁舟。

    fixed

    使用 fixed 来定位一个元素相对于浏览器窗视口的位置。偏移量是相对于视口计算的,且该元素将作为绝对定位的子元素的位置参考。

    MIT License (MIT)

    - +
    Skip to content

    定位

    定义

    用于控制元素在DOM中的位置的工具类。

    工具类属性
    staticposition: static;
    fixedposition: fixed;
    absoluteposition: absolute;
    relativeposition: relative;
    stickyposition: sticky;

    使用方法

    staticabsolute

    使用 static 根据常规的文档流来定位元素,浏览器默认 position 取值就是 static。任何偏移都将被忽略,而且该元素不会作为绝对定位的子元素的位置参考。

    Static 父元素

    Absolute 子元素

    relativeabsolute

    使用 relative 根据常规的文档流来定位元素。偏移量是相对于元素的正常位置计算的,并且该元素将作为绝对定位的子元素的位置参考。

    使用 absolute 将一个元素定位在文档常规流之外,使相邻元素的行为就像该元素不存在一样。偏移量是相对于最近的位置不是 static 的父元素计算的,而且该元素将作为其他绝对定位的子元素的位置参考。

    Relative 父元素

    Absolute 子元素

    sticky

    sticky 元素根据正常文档流进行定位,然后相对它的最近滚动祖先和 containing block,包括 table-related 元素,基于 top、right、bottom 和 left 的值进行偏移。偏移值不会影响任何其他元素的位置。

    黄鹤楼送孟浩然之广陵

    故人西辞黄鹤楼,

    烟花三月下扬州。

    孤帆远影碧空尽,

    唯见长江天际流。

    闻王昌龄左迁龙标遥有此寄

    杨花落尽子规啼,

    闻道龙标过五溪。

    我寄愁心与明月,

    随君直到夜郎西。

    宣州谢朓楼饯别校书叔云

    弃我去者,昨日之日不可留;

    乱我心者,今日之日多烦忧。

    长风万里送秋雁,对此可以酣高楼。

    蓬莱文章建安骨,中间小谢又清发。

    俱怀逸兴壮思飞,欲上青天揽明月。

    抽刀断水水更流,举杯消愁愁更愁。

    人生在世不称意,明朝散发弄扁舟。

    fixed

    使用 fixed 来定位一个元素相对于浏览器窗视口的位置。偏移量是相对于视口计算的,且该元素将作为绝对定位的子元素的位置参考。

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/layout/utilities/top-right-bottom-left.html b/dev/utilities/layout/utilities/top-right-bottom-left.html index a269d19cd8..c7757b7060 100644 --- a/dev/utilities/layout/utilities/top-right-bottom-left.html +++ b/dev/utilities/layout/utilities/top-right-bottom-left.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    上下左右

    定义

    用于控制定位元素的位置的工具类。

    工具类属性
    inset-0top: 0px; right: 0px; bottom: 0px; left: 0px;
    inset-autotop: auto; right: auto; bottom: auto; left: auto;
    inset-x-0left: 0px; right: 0px;
    inset-y-0top: 0px; bottom: 0px;
    top-0top: 0px;
    right-0right: 0px;
    bottom-0bottom: 0px;
    left-0left: 0px;
    top-pxtop: 1px;
    right-pxright: 1px;
    bottom-pxbottom: 1px;
    left-pxleft: 1px;
    top-0.5top: 2px;
    right-0.5right: 2px;
    bottom-0.5bottom: 2px;
    left-0.5left: 2px;
    top-1top: 4px;
    right-1right: 4px;
    bottom-1bottom: 4px;
    left-1left: 4px;
    top-1.5top: 6px;
    right-1.5right: 6px;
    bottom-1.5bottom: 6px;
    left-1.5left: 6px;
    top-2top: 8px;
    right-2right: 8px;
    bottom-2bottom: 8px;
    left-2left: 8px;
    top-fulltop: 100%;
    right-fullright: 100%;
    bottom-fullbottom: 100%;
    left-fullleft: 100%;
    top-autotop: auto;
    right-autoright: auto;
    bottom-autobottom: auto;
    left-autoleft: auto;

    效果展示

    1
    2
    3
    4
    5
    6
    7
    8

    MIT License (MIT)

    - +
    Skip to content

    上下左右

    定义

    用于控制定位元素的位置的工具类。

    工具类属性
    inset-0top: 0px; right: 0px; bottom: 0px; left: 0px;
    inset-autotop: auto; right: auto; bottom: auto; left: auto;
    inset-x-0left: 0px; right: 0px;
    inset-y-0top: 0px; bottom: 0px;
    top-0top: 0px;
    right-0right: 0px;
    bottom-0bottom: 0px;
    left-0left: 0px;
    top-pxtop: 1px;
    right-pxright: 1px;
    bottom-pxbottom: 1px;
    left-pxleft: 1px;
    top-0.5top: 2px;
    right-0.5right: 2px;
    bottom-0.5bottom: 2px;
    left-0.5left: 2px;
    top-1top: 4px;
    right-1right: 4px;
    bottom-1bottom: 4px;
    left-1left: 4px;
    top-1.5top: 6px;
    right-1.5right: 6px;
    bottom-1.5bottom: 6px;
    left-1.5left: 6px;
    top-2top: 8px;
    right-2right: 8px;
    bottom-2bottom: 8px;
    left-2left: 8px;
    top-fulltop: 100%;
    right-fullright: 100%;
    bottom-fullbottom: 100%;
    left-fullleft: 100%;
    top-autotop: auto;
    right-autoright: auto;
    bottom-autobottom: auto;
    left-autoleft: auto;

    效果展示

    1
    2
    3
    4
    5
    6
    7
    8

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/layout/utilities/visibility.html b/dev/utilities/layout/utilities/visibility.html index bf16aa180e..1528ad63b8 100644 --- a/dev/utilities/layout/utilities/visibility.html +++ b/dev/utilities/layout/utilities/visibility.html @@ -14,14 +14,14 @@ - - + + -
    - +
    + \ No newline at end of file diff --git a/dev/utilities/layout/utilities/z-index.html b/dev/utilities/layout/utilities/z-index.html index 3db3c21d80..ab4aa1c5a6 100644 --- a/dev/utilities/layout/utilities/z-index.html +++ b/dev/utilities/layout/utilities/z-index.html @@ -14,14 +14,14 @@ - - + + -
    - +
    + \ No newline at end of file diff --git a/dev/utilities/sizing/utilities/height.html b/dev/utilities/sizing/utilities/height.html index 424984215c..d7a3f2cff7 100644 --- a/dev/utilities/sizing/utilities/height.html +++ b/dev/utilities/sizing/utilities/height.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    高度

    固定值

    通过工具类 h-* 设置高度为固定值,包含如下工具类:

    工具类CSS 属性
    h-0height: 0px;
    h-pxheight: 1px;
    h-0.5height: 2px;
    h-1height: 4px;
    h-1.5height: 6px;
    h-2height: 8px;
    h-2.5height: 10px;
    h-3height: 12px;
    h-3.5height: 14px;
    h-4height: 16px;
    h-5height: 20px;
    h-6height: 24px;
    h-7height: 28px;
    h-8height: 32px;
    h-9height: 36px;
    h-10height: 40px;
    h-11height: 44px;
    h-12height: 48px;
    h-14height: 56px;
    h-16height: 64px;
    h-20height: 80px;
    h-24height: 96px;
    h-28height: 112px;
    h-32height: 128px;
    h-36height: 144px;
    h-40height: 160px;
    h-44height: 176px;
    h-48height: 192px;
    h-52height: 208px;
    h-56height: 224px;
    h-60height: 240px;
    h-64height: 256px;
    h-72height: 288px;
    h-80height: 320px;
    h-96height: 384px;

    百分比

    通过工具类 h-* 设置高度为百分比,包含如下工具类:

    工具类CSS 属性
    h-1/2height: 50%;
    h-1/3height: 33.3333333%;
    h-2/3height: 66.6666667%;
    h-1/4height: 25%;
    h-2/4height: 50%;
    h-3/4height: 75%;
    h-1/5height: 20%;
    h-2/5height: 40%;
    h-3/5height: 60%;
    h-4/5height: 80%;
    h-1/6height: 16.6666667%;
    h-2/6height: 33.3333333%;
    h-3/6height: 50%;
    h-4/6height: 66.6666667%;
    h-5/6height: 83.3333333%;
    h-fullheight: 100%;

    特殊值

    通过工具类 h-* 设置高度为特殊值,包含如下工具类:

    工具类CSS 属性
    h-autoheight: auto;
    h-screenheight: 100vh;
    h-fitheight: fit-content;
    h-minheight: min-content;
    h-maxheight: max-content;

    限制最大高度

    通过工具类 max-h-* 设置限制元素最大高度,包含如下工具类:

    工具类CSS 属性
    max-h-0max-height: 0px;
    max-h-fullmax-height: 100%;
    max-h-screenmax-height: 100vh;
    max-h-nonemax-height: none;
    max-h-minmax-height: min-content;
    max-h-maxmax-height: max-content;
    max-h-fitmax-height: fit-content;

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/sizing/utilities/width.html b/dev/utilities/sizing/utilities/width.html index 27645a91b5..7022e05e16 100644 --- a/dev/utilities/sizing/utilities/width.html +++ b/dev/utilities/sizing/utilities/width.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    宽度

    固定值

    通过工具类 w-* 设置宽度为固定值,包含如下工具类:

    工具类CSS 属性
    w-0width: 0px;
    w-pxwidth: 1px;
    w-0.5width: 2px;
    w-1width: 4px;
    w-1.5width: 6px;
    w-2width: 8px;
    w-2.5width: 10px;
    w-3width: 12px;
    w-3.5width: 14px;
    w-4width: 16px;
    w-5width: 20px;
    w-6width: 24px;
    w-7width: 28px;
    w-8width: 32px;
    w-9width: 36px;
    w-10width: 40px;
    w-11width: 44px;
    w-12width: 48px;
    w-14width: 56px;
    w-16width: 64px;
    w-20width: 80px;
    w-24width: 96px;
    w-28width: 112px;
    w-32width: 128px;
    w-36width: 144px;
    w-40width: 160px;
    w-44width: 176px;
    w-48width: 192px;
    w-52width: 208px;
    w-56width: 224px;
    w-60width: 240px;
    w-64width: 256px;
    w-72width: 288px;
    w-80width: 320px;
    w-96width: 384px;

    百分比

    通过工具类 w-* 设置宽度为百分比,包含如下工具类:

    工具类CSS 属性
    w-1/2width: 50%;
    w-1/3width: 33.3333333%;
    w-2/3width: 66.6666667%;
    w-1/4width: 25%;
    w-2/4width: 50%;
    w-3/4width: 75%;
    w-1/5width: 20%;
    w-2/5width: 40%;
    w-3/5width: 60%;
    w-4/5width: 80%;
    w-1/6width: 16.6666667%;
    w-2/6width: 33.3333333%;
    w-3/6width: 50%;
    w-4/6width: 66.6666667%;
    w-5/6width: 83.3333333%;
    w-fullwidth: 100%;

    特殊值

    通过工具类 w-* 设置宽度为特殊值,包含如下工具类:

    工具类CSS 属性
    w-autowidth: auto;
    w-screenwidth: 100vw;
    w-fitwidth: fit-content;
    w-minwidth: min-content;
    w-maxwidth: max-content;

    限制最大宽度

    通过工具类 max-w-* 设置限制元素最大宽度,包含如下工具类:

    工具类CSS 属性
    max-w-0max-width: 0px;
    max-w-fullmax-width: 100%;
    max-w-screenmax-width: 100vw;
    max-w-nonemax-width: none;
    max-w-minmax-width: min-content;
    max-w-maxmax-width: max-content;
    max-w-fitmax-width: fit-content;

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/skin/utilities/ghost.html b/dev/utilities/skin/utilities/ghost.html index fa31add9c6..d9467f4a2a 100644 --- a/dev/utilities/skin/utilities/ghost.html +++ b/dev/utilities/skin/utilities/ghost.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    透明

    用于快速为元素或组件实现特定文字颜色带透明背景外观。

    效果

    默认
    ghost
    语义化
    primary-ghost
    secondary-ghost
    success-ghost
    warning-ghost
    danger-ghost
    important-ghost
    special-ghost

    示例

    Ghost Element

    MIT License (MIT)

    - +
    Skip to content

    透明

    用于快速为元素或组件实现特定文字颜色带透明背景外观。

    效果

    默认
    ghost
    语义化
    primary-ghost
    secondary-ghost
    success-ghost
    warning-ghost
    danger-ghost
    important-ghost
    special-ghost

    示例

    Ghost Element

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/skin/utilities/outline.html b/dev/utilities/skin/utilities/outline.html index 3832fede93..d88a7f4e6b 100644 --- a/dev/utilities/skin/utilities/outline.html +++ b/dev/utilities/skin/utilities/outline.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    轮廓

    用于快速为元素或组件实现特定颜色的轮廓描边外观。

    效果

    默认
    outline
    语义化
    primary-outline
    secondary-outline
    success-outline
    warning-outline
    danger-outline
    important-outline
    special-outline
    灰度
    gray-outline

    提示

    轮廓的描边效果使用 box-shadow 实现。

    示例

    Success Label
    Gray Element

    MIT License (MIT)

    - +
    Skip to content

    轮廓

    用于快速为元素或组件实现特定颜色的轮廓描边外观。

    效果

    默认
    outline
    语义化
    primary-outline
    secondary-outline
    success-outline
    warning-outline
    danger-outline
    important-outline
    special-outline
    灰度
    gray-outline

    提示

    轮廓的描边效果使用 box-shadow 实现。

    示例

    Success Label
    Gray Element

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/skin/utilities/pale.html b/dev/utilities/skin/utilities/pale.html index 5878670f14..74cfb1ec36 100644 --- a/dev/utilities/skin/utilities/pale.html +++ b/dev/utilities/skin/utilities/pale.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    浅色

    用于快速为元素或组件实现特定颜色的浅色填充外观,包含语义化和灰度工具类。

    效果

    语义化
    primary-pale
    secondary-pale
    success-pale
    warning-pale
    danger-pale
    important-pale
    special-pale
    灰度
    gray-50-pale
    gray-100-pale
    gray-200-pale
    gray-300-pale
    gray-400-pale
    gray-pale
    gray-500-pale 别名: gray-pale
    gray-600-pale
    gray-700-pale
    gray-800-pale
    gray-900-pale
    gray-950-pale

    示例

    Success Label
    Gray Element

    MIT License (MIT)

    - +
    Skip to content

    浅色

    用于快速为元素或组件实现特定颜色的浅色填充外观,包含语义化和灰度工具类。

    效果

    语义化
    primary-pale
    secondary-pale
    success-pale
    warning-pale
    danger-pale
    important-pale
    special-pale
    灰度
    gray-50-pale
    gray-100-pale
    gray-200-pale
    gray-300-pale
    gray-400-pale
    gray-pale
    gray-500-pale 别名: gray-pale
    gray-600-pale
    gray-700-pale
    gray-800-pale
    gray-900-pale
    gray-950-pale

    示例

    Success Label
    Gray Element

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/skin/utilities/solid.html b/dev/utilities/skin/utilities/solid.html index 16ef41f07b..4c77c193df 100644 --- a/dev/utilities/skin/utilities/solid.html +++ b/dev/utilities/skin/utilities/solid.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    实心

    用于快速为元素或组件实现特定颜色的实心填充外观,包含语义化和灰度工具类。

    效果

    语义化
    primary
    secondary
    success
    warning
    danger
    important
    special
    灰度
    gray-50
    gray-100
    gray-200
    gray-300
    gray-400
    gray
    gray-500 别名: gray
    gray-600
    gray-700
    gray-800
    gray-900
    gray-950

    示例

    Success Label
    Gray Element

    MIT License (MIT)

    - +
    Skip to content

    实心

    用于快速为元素或组件实现特定颜色的实心填充外观,包含语义化和灰度工具类。

    效果

    语义化
    primary
    secondary
    success
    warning
    danger
    important
    special
    灰度
    gray-50
    gray-100
    gray-200
    gray-300
    gray-400
    gray
    gray-500 别名: gray
    gray-600
    gray-700
    gray-800
    gray-900
    gray-950

    示例

    Success Label
    Gray Element

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/skin/utilities/surface.html b/dev/utilities/skin/utilities/surface.html index 7d5cdce709..d02916ad9b 100644 --- a/dev/utilities/skin/utilities/surface.html +++ b/dev/utilities/skin/utilities/surface.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    界面

    用于快速为元素或组件实现特定功能界面颜色外观。

    效果

    white
    纯白
    black
    纯黑
    transparent
    透明
    canvas
    画布
    inverse
    反色
    surface-light
    加重的控件
    surface
    控件
    surface-strong
    轻量的控件

    示例

    Surface Element

    MIT License (MIT)

    - +
    Skip to content

    界面

    用于快速为元素或组件实现特定功能界面颜色外观。

    效果

    white
    纯白
    black
    纯黑
    transparent
    透明
    canvas
    画布
    inverse
    反色
    surface-light
    加重的控件
    surface
    控件
    surface-strong
    轻量的控件

    示例

    Surface Element

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/spacing/utilities/margin.html b/dev/utilities/spacing/utilities/margin.html index 3ad0666267..8884760601 100644 --- a/dev/utilities/spacing/utilities/margin.html +++ b/dev/utilities/spacing/utilities/margin.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    外边距

    定义

    通过 m-* 工具类设置外边距,可用的工具类包括:

    工具类CSS 属性
    m-automargin: auto;
    mx-automargin-left: auto; margin-right: auto;
    my-automargin-top: auto; margin-bottom: auto;
    mt-automargin-top: auto;
    mr-automargin-right: auto;
    mb-automargin-bottom: auto;
    ml-automargin-left: auto;
    m-0margin: 0px;
    m-pxmargin: 1px;
    m-0.5margin: 2px;
    m-1margin: 4px;
    m-1.5margin: 6px;
    m-2margin: 8px;
    m-2.5margin: 10px;
    m-3margin: 12px;
    m-3.5margin: 14px;
    m-4margin: 16px;
    m-5margin: 20px;
    m-6margin: 24px;
    m-7margin: 28px;
    m-8margin: 32px;
    m-9margin: 36px;
    m-10margin: 40px;
    mx-0margin-left: 0px; margin-right: 0px;
    my-0margin-top: 0px; margin-bottom: 0px;
    mt-0margin-top: 0px;
    mr-0margin-right: 0px;
    mb-0margin-bottom: 0px;
    ml-0margin-left: 0px;
    mx-pxmargin-left: 1px; margin-right: 1px;
    my-pxmargin-top: 1px; margin-bottom: 1px;
    mt-pxmargin-top: 1px;
    mr-pxmargin-right: 1px;
    mb-pxmargin-bottom: 1px;
    ml-pxmargin-left: 1px;
    mx-0.5margin-left: 2px; margin-right: 2px;
    my-0.5margin-top: 2px; margin-bottom: 2px;
    mt-0.5margin-top: 2px;
    mr-0.5margin-right: 2px;
    mb-0.5margin-bottom: 2px;
    ml-0.5margin-left: 2px;
    mx-1margin-left: 4px; margin-right: 4px;
    my-1margin-top: 4px; margin-bottom: 4px;
    mt-1margin-top: 4px;
    mr-1margin-right: 4px;
    mb-1margin-bottom: 4px;
    ml-1margin-left: 4px;
    mx-1.5margin-left: 6px; margin-right: 6px;
    my-1.5margin-top: 6px; margin-bottom: 6px;
    mt-1.5margin-top: 6px;
    mr-1.5margin-right: 6px;
    mb-1.5margin-bottom: 6px;
    ml-1.5margin-left: 6px;
    mx-2margin-left: 8px; margin-right: 8px;
    my-2margin-top: 8px; margin-bottom: 8px;
    mt-2margin-top: 8px;
    mr-2margin-right: 8px;
    mb-2margin-bottom: 8px;
    ml-2margin-left: 8px;
    mx-2.5margin-left: 10px; margin-right: 10px;
    my-2.5margin-top: 10px; margin-bottom: 10px;
    mt-2.5margin-top: 10px;
    mr-2.5margin-right: 10px;
    mb-2.5margin-bottom: 10px;
    ml-2.5margin-left: 10px;
    mx-3margin-left: 12px; margin-right: 12px;
    my-3margin-top: 12px; margin-bottom: 12px;
    mt-3margin-top: 12px;
    mr-3margin-right: 12px;
    mb-3margin-bottom: 12px;
    ml-3margin-left: 12px;
    mx-3.5margin-left: 14px; margin-right: 14px;
    my-3.5margin-top: 14px; margin-bottom: 14px;
    mt-3.5margin-top: 14px;
    mr-3.5margin-right: 14px;
    mb-3.5margin-bottom: 14px;
    ml-3.5margin-left: 14px;
    mx-4margin-left: 16px; margin-right: 16px;
    my-4margin-top: 16px; margin-bottom: 16px;
    mt-4margin-top: 16px;
    mr-4margin-right: 16px;
    mb-4margin-bottom: 16px;
    ml-4margin-left: 16px;
    mx-5margin-left: 20px; margin-right: 20px;
    my-5margin-top: 20px; margin-bottom: 20px;
    mt-5margin-top: 20px;
    mr-5margin-right: 20px;
    mb-5margin-bottom: 20px;
    ml-5margin-left: 20px;
    mx-6margin-left: 24px; margin-right: 24px;
    my-6margin-top: 24px; margin-bottom: 24px;
    mt-6margin-top: 24px;
    mr-6margin-right: 24px;
    mb-6margin-bottom: 24px;
    ml-6margin-left: 24px;
    mx-7margin-left: 28px; margin-right: 28px;
    my-7margin-top: 28px; margin-bottom: 28px;
    mt-7margin-top: 28px;
    mr-7margin-right: 28px;
    mb-7margin-bottom: 28px;
    ml-7margin-left: 28px;
    mx-8margin-left: 32px; margin-right: 32px;
    my-8margin-top: 32px; margin-bottom: 32px;
    mt-8margin-top: 32px;
    mr-8margin-right: 32px;
    mb-8margin-bottom: 32px;
    ml-8margin-left: 32px;
    mx-9margin-left: 36px; margin-right: 36px;
    my-9margin-top: 36px; margin-bottom: 36px;
    mt-9margin-top: 36px;
    mr-9margin-right: 36px;
    mb-9margin-bottom: 36px;
    ml-9margin-left: 36px;
    mx-10margin-left: 40px; margin-right: 40px;
    my-10margin-top: 40px; margin-bottom: 40px;
    mt-10margin-top: 40px;
    mr-10margin-right: 40px;
    mb-10margin-bottom: 40px;
    ml-10margin-left: 40px;

    示例

    MIT License (MIT)

    - +
    Skip to content

    外边距

    定义

    通过 m-* 工具类设置外边距,可用的工具类包括:

    工具类CSS 属性
    m-automargin: auto;
    mx-automargin-left: auto; margin-right: auto;
    my-automargin-top: auto; margin-bottom: auto;
    mt-automargin-top: auto;
    mr-automargin-right: auto;
    mb-automargin-bottom: auto;
    ml-automargin-left: auto;
    m-0margin: 0px;
    m-pxmargin: 1px;
    m-0.5margin: 2px;
    m-1margin: 4px;
    m-1.5margin: 6px;
    m-2margin: 8px;
    m-2.5margin: 10px;
    m-3margin: 12px;
    m-3.5margin: 14px;
    m-4margin: 16px;
    m-5margin: 20px;
    m-6margin: 24px;
    m-7margin: 28px;
    m-8margin: 32px;
    m-9margin: 36px;
    m-10margin: 40px;
    mx-0margin-left: 0px; margin-right: 0px;
    my-0margin-top: 0px; margin-bottom: 0px;
    mt-0margin-top: 0px;
    mr-0margin-right: 0px;
    mb-0margin-bottom: 0px;
    ml-0margin-left: 0px;
    mx-pxmargin-left: 1px; margin-right: 1px;
    my-pxmargin-top: 1px; margin-bottom: 1px;
    mt-pxmargin-top: 1px;
    mr-pxmargin-right: 1px;
    mb-pxmargin-bottom: 1px;
    ml-pxmargin-left: 1px;
    mx-0.5margin-left: 2px; margin-right: 2px;
    my-0.5margin-top: 2px; margin-bottom: 2px;
    mt-0.5margin-top: 2px;
    mr-0.5margin-right: 2px;
    mb-0.5margin-bottom: 2px;
    ml-0.5margin-left: 2px;
    mx-1margin-left: 4px; margin-right: 4px;
    my-1margin-top: 4px; margin-bottom: 4px;
    mt-1margin-top: 4px;
    mr-1margin-right: 4px;
    mb-1margin-bottom: 4px;
    ml-1margin-left: 4px;
    mx-1.5margin-left: 6px; margin-right: 6px;
    my-1.5margin-top: 6px; margin-bottom: 6px;
    mt-1.5margin-top: 6px;
    mr-1.5margin-right: 6px;
    mb-1.5margin-bottom: 6px;
    ml-1.5margin-left: 6px;
    mx-2margin-left: 8px; margin-right: 8px;
    my-2margin-top: 8px; margin-bottom: 8px;
    mt-2margin-top: 8px;
    mr-2margin-right: 8px;
    mb-2margin-bottom: 8px;
    ml-2margin-left: 8px;
    mx-2.5margin-left: 10px; margin-right: 10px;
    my-2.5margin-top: 10px; margin-bottom: 10px;
    mt-2.5margin-top: 10px;
    mr-2.5margin-right: 10px;
    mb-2.5margin-bottom: 10px;
    ml-2.5margin-left: 10px;
    mx-3margin-left: 12px; margin-right: 12px;
    my-3margin-top: 12px; margin-bottom: 12px;
    mt-3margin-top: 12px;
    mr-3margin-right: 12px;
    mb-3margin-bottom: 12px;
    ml-3margin-left: 12px;
    mx-3.5margin-left: 14px; margin-right: 14px;
    my-3.5margin-top: 14px; margin-bottom: 14px;
    mt-3.5margin-top: 14px;
    mr-3.5margin-right: 14px;
    mb-3.5margin-bottom: 14px;
    ml-3.5margin-left: 14px;
    mx-4margin-left: 16px; margin-right: 16px;
    my-4margin-top: 16px; margin-bottom: 16px;
    mt-4margin-top: 16px;
    mr-4margin-right: 16px;
    mb-4margin-bottom: 16px;
    ml-4margin-left: 16px;
    mx-5margin-left: 20px; margin-right: 20px;
    my-5margin-top: 20px; margin-bottom: 20px;
    mt-5margin-top: 20px;
    mr-5margin-right: 20px;
    mb-5margin-bottom: 20px;
    ml-5margin-left: 20px;
    mx-6margin-left: 24px; margin-right: 24px;
    my-6margin-top: 24px; margin-bottom: 24px;
    mt-6margin-top: 24px;
    mr-6margin-right: 24px;
    mb-6margin-bottom: 24px;
    ml-6margin-left: 24px;
    mx-7margin-left: 28px; margin-right: 28px;
    my-7margin-top: 28px; margin-bottom: 28px;
    mt-7margin-top: 28px;
    mr-7margin-right: 28px;
    mb-7margin-bottom: 28px;
    ml-7margin-left: 28px;
    mx-8margin-left: 32px; margin-right: 32px;
    my-8margin-top: 32px; margin-bottom: 32px;
    mt-8margin-top: 32px;
    mr-8margin-right: 32px;
    mb-8margin-bottom: 32px;
    ml-8margin-left: 32px;
    mx-9margin-left: 36px; margin-right: 36px;
    my-9margin-top: 36px; margin-bottom: 36px;
    mt-9margin-top: 36px;
    mr-9margin-right: 36px;
    mb-9margin-bottom: 36px;
    ml-9margin-left: 36px;
    mx-10margin-left: 40px; margin-right: 40px;
    my-10margin-top: 40px; margin-bottom: 40px;
    mt-10margin-top: 40px;
    mr-10margin-right: 40px;
    mb-10margin-bottom: 40px;
    ml-10margin-left: 40px;

    示例

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/spacing/utilities/padding.html b/dev/utilities/spacing/utilities/padding.html index 8295f22d95..b74119ca43 100644 --- a/dev/utilities/spacing/utilities/padding.html +++ b/dev/utilities/spacing/utilities/padding.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    内边距

    定义

    通过 p-* 工具类设置内边距,可用的工具类包括:

    工具类CSS 属性
    p-autopadding: auto;
    px-autopadding-left: auto; padding-right: auto;
    py-autopadding-top: auto; padding-bottom: auto;
    pt-autopadding-top: auto;
    pr-autopadding-right: auto;
    pb-autopadding-bottom: auto;
    pl-autopadding-left: auto;
    p-0padding: 0px;
    p-pxpadding: 1px;
    p-0.5padding: 2px;
    p-1padding: 4px;
    p-1.5padding: 6px;
    p-2padding: 8px;
    p-2.5padding: 10px;
    p-3padding: 12px;
    p-3.5padding: 14px;
    p-4padding: 16px;
    p-5padding: 20px;
    p-6padding: 24px;
    p-7padding: 28px;
    p-8padding: 32px;
    p-9padding: 36px;
    p-10padding: 40px;
    px-0padding-left: 0px; padding-right: 0px;
    py-0padding-top: 0px; padding-bottom: 0px;
    pt-0padding-top: 0px;
    pr-0padding-right: 0px;
    pb-0padding-bottom: 0px;
    pl-0padding-left: 0px;
    px-pxpadding-left: 1px; padding-right: 1px;
    py-pxpadding-top: 1px; padding-bottom: 1px;
    pt-pxpadding-top: 1px;
    pr-pxpadding-right: 1px;
    pb-pxpadding-bottom: 1px;
    pl-pxpadding-left: 1px;
    px-0.5padding-left: 2px; padding-right: 2px;
    py-0.5padding-top: 2px; padding-bottom: 2px;
    pt-0.5padding-top: 2px;
    pr-0.5padding-right: 2px;
    pb-0.5padding-bottom: 2px;
    pl-0.5padding-left: 2px;
    px-1padding-left: 4px; padding-right: 4px;
    py-1padding-top: 4px; padding-bottom: 4px;
    pt-1padding-top: 4px;
    pr-1padding-right: 4px;
    pb-1padding-bottom: 4px;
    pl-1padding-left: 4px;
    px-1.5padding-left: 6px; padding-right: 6px;
    py-1.5padding-top: 6px; padding-bottom: 6px;
    pt-1.5padding-top: 6px;
    pr-1.5padding-right: 6px;
    pb-1.5padding-bottom: 6px;
    pl-1.5padding-left: 6px;
    px-2padding-left: 8px; padding-right: 8px;
    py-2padding-top: 8px; padding-bottom: 8px;
    pt-2padding-top: 8px;
    pr-2padding-right: 8px;
    pb-2padding-bottom: 8px;
    pl-2padding-left: 8px;
    px-2.5padding-left: 10px; padding-right: 10px;
    py-2.5padding-top: 10px; padding-bottom: 10px;
    pt-2.5padding-top: 10px;
    pr-2.5padding-right: 10px;
    pb-2.5padding-bottom: 10px;
    pl-2.5padding-left: 10px;
    px-3padding-left: 12px; padding-right: 12px;
    py-3padding-top: 12px; padding-bottom: 12px;
    pt-3padding-top: 12px;
    pr-3padding-right: 12px;
    pb-3padding-bottom: 12px;
    pl-3padding-left: 12px;
    px-3.5padding-left: 14px; padding-right: 14px;
    py-3.5padding-top: 14px; padding-bottom: 14px;
    pt-3.5padding-top: 14px;
    pr-3.5padding-right: 14px;
    pb-3.5padding-bottom: 14px;
    pl-3.5padding-left: 14px;
    px-4padding-left: 16px; padding-right: 16px;
    py-4padding-top: 16px; padding-bottom: 16px;
    pt-4padding-top: 16px;
    pr-4padding-right: 16px;
    pb-4padding-bottom: 16px;
    pl-4padding-left: 16px;
    px-5padding-left: 20px; padding-right: 20px;
    py-5padding-top: 20px; padding-bottom: 20px;
    pt-5padding-top: 20px;
    pr-5padding-right: 20px;
    pb-5padding-bottom: 20px;
    pl-5padding-left: 20px;
    px-6padding-left: 24px; padding-right: 24px;
    py-6padding-top: 24px; padding-bottom: 24px;
    pt-6padding-top: 24px;
    pr-6padding-right: 24px;
    pb-6padding-bottom: 24px;
    pl-6padding-left: 24px;
    px-7padding-left: 28px; padding-right: 28px;
    py-7padding-top: 28px; padding-bottom: 28px;
    pt-7padding-top: 28px;
    pr-7padding-right: 28px;
    pb-7padding-bottom: 28px;
    pl-7padding-left: 28px;
    px-8padding-left: 32px; padding-right: 32px;
    py-8padding-top: 32px; padding-bottom: 32px;
    pt-8padding-top: 32px;
    pr-8padding-right: 32px;
    pb-8padding-bottom: 32px;
    pl-8padding-left: 32px;
    px-9padding-left: 36px; padding-right: 36px;
    py-9padding-top: 36px; padding-bottom: 36px;
    pt-9padding-top: 36px;
    pr-9padding-right: 36px;
    pb-9padding-bottom: 36px;
    pl-9padding-left: 36px;
    px-10padding-left: 40px; padding-right: 40px;
    py-10padding-top: 40px; padding-bottom: 40px;
    pt-10padding-top: 40px;
    pr-10padding-right: 40px;
    pb-10padding-bottom: 40px;
    pl-10padding-left: 40px;

    示例

    MIT License (MIT)

    - +
    Skip to content

    内边距

    定义

    通过 p-* 工具类设置内边距,可用的工具类包括:

    工具类CSS 属性
    p-autopadding: auto;
    px-autopadding-left: auto; padding-right: auto;
    py-autopadding-top: auto; padding-bottom: auto;
    pt-autopadding-top: auto;
    pr-autopadding-right: auto;
    pb-autopadding-bottom: auto;
    pl-autopadding-left: auto;
    p-0padding: 0px;
    p-pxpadding: 1px;
    p-0.5padding: 2px;
    p-1padding: 4px;
    p-1.5padding: 6px;
    p-2padding: 8px;
    p-2.5padding: 10px;
    p-3padding: 12px;
    p-3.5padding: 14px;
    p-4padding: 16px;
    p-5padding: 20px;
    p-6padding: 24px;
    p-7padding: 28px;
    p-8padding: 32px;
    p-9padding: 36px;
    p-10padding: 40px;
    px-0padding-left: 0px; padding-right: 0px;
    py-0padding-top: 0px; padding-bottom: 0px;
    pt-0padding-top: 0px;
    pr-0padding-right: 0px;
    pb-0padding-bottom: 0px;
    pl-0padding-left: 0px;
    px-pxpadding-left: 1px; padding-right: 1px;
    py-pxpadding-top: 1px; padding-bottom: 1px;
    pt-pxpadding-top: 1px;
    pr-pxpadding-right: 1px;
    pb-pxpadding-bottom: 1px;
    pl-pxpadding-left: 1px;
    px-0.5padding-left: 2px; padding-right: 2px;
    py-0.5padding-top: 2px; padding-bottom: 2px;
    pt-0.5padding-top: 2px;
    pr-0.5padding-right: 2px;
    pb-0.5padding-bottom: 2px;
    pl-0.5padding-left: 2px;
    px-1padding-left: 4px; padding-right: 4px;
    py-1padding-top: 4px; padding-bottom: 4px;
    pt-1padding-top: 4px;
    pr-1padding-right: 4px;
    pb-1padding-bottom: 4px;
    pl-1padding-left: 4px;
    px-1.5padding-left: 6px; padding-right: 6px;
    py-1.5padding-top: 6px; padding-bottom: 6px;
    pt-1.5padding-top: 6px;
    pr-1.5padding-right: 6px;
    pb-1.5padding-bottom: 6px;
    pl-1.5padding-left: 6px;
    px-2padding-left: 8px; padding-right: 8px;
    py-2padding-top: 8px; padding-bottom: 8px;
    pt-2padding-top: 8px;
    pr-2padding-right: 8px;
    pb-2padding-bottom: 8px;
    pl-2padding-left: 8px;
    px-2.5padding-left: 10px; padding-right: 10px;
    py-2.5padding-top: 10px; padding-bottom: 10px;
    pt-2.5padding-top: 10px;
    pr-2.5padding-right: 10px;
    pb-2.5padding-bottom: 10px;
    pl-2.5padding-left: 10px;
    px-3padding-left: 12px; padding-right: 12px;
    py-3padding-top: 12px; padding-bottom: 12px;
    pt-3padding-top: 12px;
    pr-3padding-right: 12px;
    pb-3padding-bottom: 12px;
    pl-3padding-left: 12px;
    px-3.5padding-left: 14px; padding-right: 14px;
    py-3.5padding-top: 14px; padding-bottom: 14px;
    pt-3.5padding-top: 14px;
    pr-3.5padding-right: 14px;
    pb-3.5padding-bottom: 14px;
    pl-3.5padding-left: 14px;
    px-4padding-left: 16px; padding-right: 16px;
    py-4padding-top: 16px; padding-bottom: 16px;
    pt-4padding-top: 16px;
    pr-4padding-right: 16px;
    pb-4padding-bottom: 16px;
    pl-4padding-left: 16px;
    px-5padding-left: 20px; padding-right: 20px;
    py-5padding-top: 20px; padding-bottom: 20px;
    pt-5padding-top: 20px;
    pr-5padding-right: 20px;
    pb-5padding-bottom: 20px;
    pl-5padding-left: 20px;
    px-6padding-left: 24px; padding-right: 24px;
    py-6padding-top: 24px; padding-bottom: 24px;
    pt-6padding-top: 24px;
    pr-6padding-right: 24px;
    pb-6padding-bottom: 24px;
    pl-6padding-left: 24px;
    px-7padding-left: 28px; padding-right: 28px;
    py-7padding-top: 28px; padding-bottom: 28px;
    pt-7padding-top: 28px;
    pr-7padding-right: 28px;
    pb-7padding-bottom: 28px;
    pl-7padding-left: 28px;
    px-8padding-left: 32px; padding-right: 32px;
    py-8padding-top: 32px; padding-bottom: 32px;
    pt-8padding-top: 32px;
    pr-8padding-right: 32px;
    pb-8padding-bottom: 32px;
    pl-8padding-left: 32px;
    px-9padding-left: 36px; padding-right: 36px;
    py-9padding-top: 36px; padding-bottom: 36px;
    pt-9padding-top: 36px;
    pr-9padding-right: 36px;
    pb-9padding-bottom: 36px;
    pl-9padding-left: 36px;
    px-10padding-left: 40px; padding-right: 40px;
    py-10padding-top: 40px; padding-bottom: 40px;
    pt-10padding-top: 40px;
    pr-10padding-right: 40px;
    pb-10padding-bottom: 40px;
    pl-10padding-left: 40px;

    示例

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/spacing/utilities/space.html b/dev/utilities/spacing/utilities/space.html index 3fcf113ddf..5465bb1b6c 100644 --- a/dev/utilities/spacing/utilities/space.html +++ b/dev/utilities/spacing/utilities/space.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    子元素间距

    定义

    通过工具类 space-x-* 来为元素内的所有子元素之间设置水平间距;通过工具类 space-y-* 来为元素内的所有子元素之间设置水平间距,所有可用的工具类定义如下:

    工具类CSS 属性
    space-x-0 > * + *margin-left: 0px;
    space-y-0 > * + *margin-top: 0px;
    space-x-0.5 > * + *margin-left: 2px;
    space-y-0.5 > * + *margin-top: 2px;
    space-x-1 > * + *margin-left: 4px;
    space-y-1 > * + *margin-top: 4px;
    space-x-1.5 > * + *margin-left: 6px;
    space-y-1.5 > * + *margin-top: 6px;
    space-x-2 > * + *margin-left: 8px;
    space-y-2 > * + *margin-top: 8px;
    space-x-2.5 > * + *margin-left: 10px;
    space-y-2.5 > * + *margin-top: 10px;
    space-x-3 > * + *margin-left: 12px;
    space-y-3 > * + *margin-top: 12px;
    space-x-3.5 > * + *margin-left: 14px;
    space-y-3.5 > * + *margin-top: 14px;
    space-x-4 > * + *margin-left: 16px;
    space-y-4 > * + *margin-top: 16px;
    space-x-5 > * + *margin-left: 20px;
    space-y-5 > * + *margin-top: 20px;
    space-x-6 > * + *margin-left: 24px;
    space-y-6 > * + *margin-top: 24px;
    space-x-7 > * + *margin-left: 28px;
    space-y-7 > * + *margin-top: 28px;
    space-x-8 > * + *margin-left: 32px;
    space-y-8 > * + *margin-top: 32px;
    space-x-9 > * + *margin-left: 36px;
    space-y-9 > * + *margin-top: 36px;
    space-x-10 > * + *margin-left: 40px;
    space-y-10 > * + *margin-top: 40px;
    space-x-px > * + *margin-left: 1px;
    space-y-px > * + *margin-top: 1px;

    示例

    水平间距

    1
    2
    3

    垂直间距

    1
    2
    3

    MIT License (MIT)

    - +
    Skip to content

    子元素间距

    定义

    通过工具类 space-x-* 来为元素内的所有子元素之间设置水平间距;通过工具类 space-y-* 来为元素内的所有子元素之间设置水平间距,所有可用的工具类定义如下:

    工具类CSS 属性
    space-x-0 > * + *margin-left: 0px;
    space-y-0 > * + *margin-top: 0px;
    space-x-0.5 > * + *margin-left: 2px;
    space-y-0.5 > * + *margin-top: 2px;
    space-x-1 > * + *margin-left: 4px;
    space-y-1 > * + *margin-top: 4px;
    space-x-1.5 > * + *margin-left: 6px;
    space-y-1.5 > * + *margin-top: 6px;
    space-x-2 > * + *margin-left: 8px;
    space-y-2 > * + *margin-top: 8px;
    space-x-2.5 > * + *margin-left: 10px;
    space-y-2.5 > * + *margin-top: 10px;
    space-x-3 > * + *margin-left: 12px;
    space-y-3 > * + *margin-top: 12px;
    space-x-3.5 > * + *margin-left: 14px;
    space-y-3.5 > * + *margin-top: 14px;
    space-x-4 > * + *margin-left: 16px;
    space-y-4 > * + *margin-top: 16px;
    space-x-5 > * + *margin-left: 20px;
    space-y-5 > * + *margin-top: 20px;
    space-x-6 > * + *margin-left: 24px;
    space-y-6 > * + *margin-top: 24px;
    space-x-7 > * + *margin-left: 28px;
    space-y-7 > * + *margin-top: 28px;
    space-x-8 > * + *margin-left: 32px;
    space-y-8 > * + *margin-top: 32px;
    space-x-9 > * + *margin-left: 36px;
    space-y-9 > * + *margin-top: 36px;
    space-x-10 > * + *margin-left: 40px;
    space-y-10 > * + *margin-top: 40px;
    space-x-px > * + *margin-left: 1px;
    space-y-px > * + *margin-top: 1px;

    示例

    水平间距

    1
    2
    3

    垂直间距

    1
    2
    3

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/typography/utilities/font-family.html b/dev/utilities/typography/utilities/font-family.html index 062d67a29e..30c8785d8d 100644 --- a/dev/utilities/typography/utilities/font-family.html +++ b/dev/utilities/typography/utilities/font-family.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    字体风格

    定义

    在 ZUI 中提供了一些 CSS 工具类方便为元素设置不同风格的字体,包括:

    工具类CSS 属性
    font-sansfont-family
    font-seriffont-family
    font-monofont-family

    无衬线字体 font-sans

    The quick brown fox jumps over the lazy dog.

    白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    衬线字体 font-serif

    The quick brown fox jumps over the lazy dog.

    白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    等宽字体 font-mono

    The quick brown fox jumps over the lazy dog.

    白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    参考

    MIT License (MIT)

    - +
    Skip to content

    字体风格

    定义

    在 ZUI 中提供了一些 CSS 工具类方便为元素设置不同风格的字体,包括:

    工具类CSS 属性
    font-sansfont-family
    font-seriffont-family
    font-monofont-family

    无衬线字体 font-sans

    The quick brown fox jumps over the lazy dog.

    白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    衬线字体 font-serif

    The quick brown fox jumps over the lazy dog.

    白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    等宽字体 font-mono

    The quick brown fox jumps over the lazy dog.

    白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    参考

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/typography/utilities/font-size.html b/dev/utilities/typography/utilities/font-size.html index 981cece6d2..1cf992c3bf 100644 --- a/dev/utilities/typography/utilities/font-size.html +++ b/dev/utilities/typography/utilities/font-size.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    字体大小

    定义

    使用 text-* 工具类控制元素的字体大小。

    工具类CSS 属性
    text-rootfont-size
    text-smfont-size
    text-basefont-size
    text-mdfont-size
    text-lgfont-size
    text-xlfont-size
    text-2xlfont-size
    text-3xlfont-size
    text-4xlfont-size

    示例

    text-root 字体大小
    text-xs 字体大小
    text-sm 字体大小
    text-base 字体大小
    text-md 字体大小
    text-lg 字体大小
    text-xl 字体大小
    text-2xl 字体大小
    text-3xl 字体大小
    text-4xl 字体大小

    MIT License (MIT)

    - +
    Skip to content

    字体大小

    定义

    使用 text-* 工具类控制元素的字体大小。

    工具类CSS 属性
    text-rootfont-size
    text-smfont-size
    text-basefont-size
    text-mdfont-size
    text-lgfont-size
    text-xlfont-size
    text-2xlfont-size
    text-3xlfont-size
    text-4xlfont-size

    示例

    text-root 字体大小
    text-xs 字体大小
    text-sm 字体大小
    text-base 字体大小
    text-md 字体大小
    text-lg 字体大小
    text-xl 字体大小
    text-2xl 字体大小
    text-3xl 字体大小
    text-4xl 字体大小

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/typography/utilities/font-weight.html b/dev/utilities/typography/utilities/font-weight.html index 68f48b9449..a7c33fe36b 100644 --- a/dev/utilities/typography/utilities/font-weight.html +++ b/dev/utilities/typography/utilities/font-weight.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    字体粗细

    定义

    使用 font-* 工具类来控制元素字体粗细。

    工具类CSS 属性
    font-thinfont-weight
    font-lightfont-weight
    font-mediumfont-weight
    font-semiboldfont-weight
    font-boldfont-weight
    font-blackfont-weight

    示例

    font-thin 字体粗细
    font-light 字体粗细
    font-medium 字体粗细
    font-semibold 字体粗细
    font-bold 字体粗细
    font-black 字体粗细

    MIT License (MIT)

    - +
    Skip to content

    字体粗细

    定义

    使用 font-* 工具类来控制元素字体粗细。

    工具类CSS 属性
    font-thinfont-weight
    font-lightfont-weight
    font-mediumfont-weight
    font-semiboldfont-weight
    font-boldfont-weight
    font-blackfont-weight

    示例

    font-thin 字体粗细
    font-light 字体粗细
    font-medium 字体粗细
    font-semibold 字体粗细
    font-bold 字体粗细
    font-black 字体粗细

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/typography/utilities/leading.html b/dev/utilities/typography/utilities/leading.html index 205055beb9..04b21e2adb 100644 --- a/dev/utilities/typography/utilities/leading.html +++ b/dev/utilities/typography/utilities/leading.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    行高

    定义

    使用 leading-* 工具类来控制元素文字行高。

    工具类CSS 属性
    leading-3line-height: .75rem;
    leading-4line-height: 1rem;
    leading-5line-height: 1.25rem;
    leading-6line-height: 1.5rem;
    leading-7line-height: 1.75rem;
    leading-8line-height: 2rem;
    leading-9line-height: 2.25rem;
    leading-10line-height: 2.5rem;
    leading-noneline-height: 1;
    leading-tightline-height: 1.25;
    leading-snugline-height: 1.375;
    leading-normalline-height: 1.5;
    leading-relaxedline-height: 1.625;
    leading-looseline-height: 2;

    固定行高

    使用 leading-* 工具类给一个元素一个固定的行高。

    leading-3 行高展示
    leading-4 行高展示
    leading-5 行高展示
    leading-6 行高展示
    leading-7 行高展示
    leading-8 行高展示
    leading-9 行高展示
    leading-10 行高展示

    相对行高

    使用 leading-noneleading-tightleading-snugleading-normalleading-relaxedleading-loose 等工具类,根据元素当前的字体大小,给它一个相对的行高。

    leading-none 行高展示
    leading-none 行高展示
    leading-none 行高展示
    leading-tight 行高展示
    leading-tight 行高展示
    leading-tight 行高展示
    leading-snug 行高展示
    leading-snug 行高展示
    leading-snug 行高展示
    leading-normal 行高展示
    leading-normal 行高展示
    leading-normal 行高展示
    leading-relaxed 行高展示
    leading-relaxed 行高展示
    leading-relaxed 行高展示
    leading-loose 行高展示
    leading-loose 行高展示
    leading-loose 行高展示

    MIT License (MIT)

    - +
    Skip to content

    行高

    定义

    使用 leading-* 工具类来控制元素文字行高。

    工具类CSS 属性
    leading-3line-height: .75rem;
    leading-4line-height: 1rem;
    leading-5line-height: 1.25rem;
    leading-6line-height: 1.5rem;
    leading-7line-height: 1.75rem;
    leading-8line-height: 2rem;
    leading-9line-height: 2.25rem;
    leading-10line-height: 2.5rem;
    leading-noneline-height: 1;
    leading-tightline-height: 1.25;
    leading-snugline-height: 1.375;
    leading-normalline-height: 1.5;
    leading-relaxedline-height: 1.625;
    leading-looseline-height: 2;

    固定行高

    使用 leading-* 工具类给一个元素一个固定的行高。

    leading-3 行高展示
    leading-4 行高展示
    leading-5 行高展示
    leading-6 行高展示
    leading-7 行高展示
    leading-8 行高展示
    leading-9 行高展示
    leading-10 行高展示

    相对行高

    使用 leading-noneleading-tightleading-snugleading-normalleading-relaxedleading-loose 等工具类,根据元素当前的字体大小,给它一个相对的行高。

    leading-none 行高展示
    leading-none 行高展示
    leading-none 行高展示
    leading-tight 行高展示
    leading-tight 行高展示
    leading-tight 行高展示
    leading-snug 行高展示
    leading-snug 行高展示
    leading-snug 行高展示
    leading-normal 行高展示
    leading-normal 行高展示
    leading-normal 行高展示
    leading-relaxed 行高展示
    leading-relaxed 行高展示
    leading-relaxed 行高展示
    leading-loose 行高展示
    leading-loose 行高展示
    leading-loose 行高展示

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/typography/utilities/line-clamp.html b/dev/utilities/typography/utilities/line-clamp.html index 75dded2240..b73c20fad1 100644 --- a/dev/utilities/typography/utilities/line-clamp.html +++ b/dev/utilities/typography/utilities/line-clamp.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    行数限制

    定义

    使用 line-clamp-* 工具类限制显示多少行文本,在文本超出时进行截断:

    工具类属性
    line-clamp-1overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 1;
    line-clamp-2overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2;
    line-clamp-3overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3;
    line-clamp-4overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 4;
    line-clamp-5overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 5;
    line-clamp-6overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 6;

    示例

    至多显示 clamp-1 行

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    至多显示 clamp-2 行

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    至多显示 clamp-3 行

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    至多显示 clamp-4 行

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    至多显示 clamp-5 行

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    至多显示 clamp-6 行

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    MIT License (MIT)

    - +
    Skip to content

    行数限制

    定义

    使用 line-clamp-* 工具类限制显示多少行文本,在文本超出时进行截断:

    工具类属性
    line-clamp-1overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 1;
    line-clamp-2overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2;
    line-clamp-3overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3;
    line-clamp-4overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 4;
    line-clamp-5overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 5;
    line-clamp-6overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 6;

    示例

    至多显示 clamp-1 行

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    至多显示 clamp-2 行

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    至多显示 clamp-3 行

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    至多显示 clamp-4 行

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    至多显示 clamp-5 行

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    至多显示 clamp-6 行

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/typography/utilities/list-style.html b/dev/utilities/typography/utilities/list-style.html index 2c5af1fa9b..6ee41649d8 100644 --- a/dev/utilities/typography/utilities/list-style.html +++ b/dev/utilities/typography/utilities/list-style.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    列表样式

    定义

    使用工具类 list-* 为元素(通常是 <ul><ol>)设置 CSS 属性 list-style

    工具类属性
    list-unstyledlist-style-type: none; padding-left: 0;
    list-nonelist-style-type: none;
    list-disclist-style-type: disc;
    list-decimallist-style-type: decimal;

    示例

    无样式 list-unstyled

    • 这是一个列表
    • 含四个列表项
    • 作为示例
    • 最后一个列表有嵌套的子列表
      • 子列表项 1
      • 子列表项 2
      • 子列表项 3

    空白样式 list-none

    • 这是一个列表
    • 含四个列表项
    • 作为示例
    • 最后一个列表有嵌套的子列表
      • 子列表项 1
      • 子列表项 2
      • 子列表项 3

    圆点样式 list-disc

    • 这是一个列表
    • 含四个列表项
    • 作为示例
    • 最后一个列表有嵌套的子列表
      • 子列表项 1
      • 子列表项 2
      • 子列表项 3

    序号样式 list-decimal

    • 这是一个列表
    • 含四个列表项
    • 作为示例
    • 最后一个列表有嵌套的子列表
      • 子列表项 1
      • 子列表项 2
      • 子列表项 3

    MIT License (MIT)

    - +
    Skip to content

    列表样式

    定义

    使用工具类 list-* 为元素(通常是 <ul><ol>)设置 CSS 属性 list-style

    工具类属性
    list-unstyledlist-style-type: none; padding-left: 0;
    list-nonelist-style-type: none;
    list-disclist-style-type: disc;
    list-decimallist-style-type: decimal;

    示例

    无样式 list-unstyled

    • 这是一个列表
    • 含四个列表项
    • 作为示例
    • 最后一个列表有嵌套的子列表
      • 子列表项 1
      • 子列表项 2
      • 子列表项 3

    空白样式 list-none

    • 这是一个列表
    • 含四个列表项
    • 作为示例
    • 最后一个列表有嵌套的子列表
      • 子列表项 1
      • 子列表项 2
      • 子列表项 3

    圆点样式 list-disc

    • 这是一个列表
    • 含四个列表项
    • 作为示例
    • 最后一个列表有嵌套的子列表
      • 子列表项 1
      • 子列表项 2
      • 子列表项 3

    序号样式 list-decimal

    • 这是一个列表
    • 含四个列表项
    • 作为示例
    • 最后一个列表有嵌套的子列表
      • 子列表项 1
      • 子列表项 2
      • 子列表项 3

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/typography/utilities/text-align.html b/dev/utilities/typography/utilities/text-align.html index 5f84073b53..2863ef785d 100644 --- a/dev/utilities/typography/utilities/text-align.html +++ b/dev/utilities/typography/utilities/text-align.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    文本对齐

    定义

    使用 text-* 工具类来控制元素的文本对齐方式。

    工具类属性
    text-lefttext-align: left;
    text-centertext-align: center;
    text-righttext-align: right;
    text-justifytext-align: justify;

    示例

    文本左对齐

    文本居中对齐

    文本右对齐

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    MIT License (MIT)

    - +
    Skip to content

    文本对齐

    定义

    使用 text-* 工具类来控制元素的文本对齐方式。

    工具类属性
    text-lefttext-align: left;
    text-centertext-align: center;
    text-righttext-align: right;
    text-justifytext-align: justify;

    示例

    文本左对齐

    文本居中对齐

    文本右对齐

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/typography/utilities/text-color.html b/dev/utilities/typography/utilities/text-color.html index b744bb234d..57c03b470d 100644 --- a/dev/utilities/typography/utilities/text-color.html +++ b/dev/utilities/typography/utilities/text-color.html @@ -14,14 +14,14 @@ - - + +
    Skip to content

    文本颜色

    效果

    使用工具类 text-* 给元素添加文本颜色。

    语义化
    Text 文本
    text-primary
    Text 文本
    text-secondary
    Text 文本
    text-success
    Text 文本
    text-warning
    Text 文本
    text-danger
    Text 文本
    text-important
    Text 文本
    text-special
    主色系列
    Text 文本
    text-primary-50
    Text 文本
    text-primary-100
    Text 文本
    text-primary-200
    Text 文本
    text-primary-300
    Text 文本
    text-primary-400
    Text 文本
    text-primary-500
    Text 文本
    text-primary-600
    Text 文本
    text-primary-700
    Text 文本
    text-primary-800
    Text 文本
    text-primary-900
    Text 文本
    text-primary-950
    次要系列
    Text 文本
    text-secondary-50
    Text 文本
    text-secondary-100
    Text 文本
    text-secondary-200
    Text 文本
    text-secondary-300
    Text 文本
    text-secondary-400
    Text 文本
    text-secondary-500
    Text 文本
    text-secondary-600
    Text 文本
    text-secondary-700
    Text 文本
    text-secondary-800
    Text 文本
    text-secondary-900
    Text 文本
    text-secondary-950
    灰度
    Text 文本
    text-gray-50
    Text 文本
    text-gray-100
    Text 文本
    text-gray-200
    Text 文本
    text-gray-300
    Text 文本
    text-gray-400
    Text 文本
    gray
    text-gray-500 别名: text-gray
    Text 文本
    text-gray-600
    Text 文本
    text-gray-700
    Text 文本
    text-gray-800
    Text 文本
    text-gray-900
    Text 文本
    text-gray-950
    界面
    Text 文本
    text-white
    纯白
    Text 文本
    text-black
    纯黑
    Text 文本
    text-transparent
    透明
    Text 文本
    text-canvas
    画布
    Text 文本
    text-inverse
    反色
    Text 文本
    text-surface-light
    加重的控件
    Text 文本
    text-surface
    控件
    Text 文本
    text-surface-strong
    轻量的控件
    Text 文本
    text-fore
    前景色作为背景
    Text 文本
    text-focus
    焦点色作为背景
    特殊
    Text 文本
    text-current
    CSS 值 currentColor
    Text 文本
    text-inherit
    CSS 值 inherit

    文本颜色透明度

    使用工具类 text-opacity-* 给元素设置文本颜色透明度。

    Text 文本
    text-opacity-0
    透明度:0%
    Text 文本
    text-opacity-5
    透明度:5%
    Text 文本
    text-opacity-10
    透明度:10%
    Text 文本
    text-opacity-20
    透明度:20%
    Text 文本
    text-opacity-25
    透明度:25%
    Text 文本
    text-opacity-30
    透明度:30%
    Text 文本
    text-opacity-40
    透明度:40%
    Text 文本
    text-opacity-50
    透明度:60%
    Text 文本
    text-opacity-60
    透明度:60%
    Text 文本
    text-opacity-70
    透明度:70%
    Text 文本
    text-opacity-75
    透明度:75%
    Text 文本
    text-opacity-80
    透明度:80%
    Text 文本
    text-opacity-90
    透明度:90%
    Text 文本
    text-opacity-95
    透明度:95%
    Text 文本
    text-opacity-100
    透明度:0%

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/typography/utilities/text-decoration.html b/dev/utilities/typography/utilities/text-decoration.html index f7affe1ab8..0bfeb266ea 100644 --- a/dev/utilities/typography/utilities/text-decoration.html +++ b/dev/utilities/typography/utilities/text-decoration.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    文本装饰

    定义

    在 ZUI 中,你可以通过如下工具类来设置文本装饰样式:

    工具类属性
    underlinetext-decoration-line: underline;
    overlinetext-decoration-line: overline;
    line-throughtext-decoration-line: line-through;
    no-underlinetext-decoration-line: none;

    示例

    下划线 underline

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。

    上划线 overline

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。

    中间划线 line-through

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。

    无划线 no-underline

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。

    MIT License (MIT)

    - +
    Skip to content

    文本装饰

    定义

    在 ZUI 中,你可以通过如下工具类来设置文本装饰样式:

    工具类属性
    underlinetext-decoration-line: underline;
    overlinetext-decoration-line: overline;
    line-throughtext-decoration-line: line-through;
    no-underlinetext-decoration-line: none;

    示例

    下划线 underline

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。

    上划线 overline

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。

    中间划线 line-through

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。

    无划线 no-underline

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/typography/utilities/text-overflow.html b/dev/utilities/typography/utilities/text-overflow.html index 91e263ed7c..f7ba0c9abb 100644 --- a/dev/utilities/typography/utilities/text-overflow.html +++ b/dev/utilities/typography/utilities/text-overflow.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    文本溢出

    定义

    文字溢出包括两种方式,分布为省略和裁剪,在 ZUI 中可以通过如下工具类实现:

    工具类属性
    text-ellipsisoverflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    text-clipoverflow: hidden; text-overflow: clip; white-space: nowrap;

    文字省略 text-ellipsis

    使用 text-ellipsis 用省略号(…)来截断溢出的文本。

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    文字裁剪 text-clip

    使用 text-clip 在内容区域的极限处截断文本。

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    MIT License (MIT)

    - +
    Skip to content

    文本溢出

    定义

    文字溢出包括两种方式,分布为省略和裁剪,在 ZUI 中可以通过如下工具类实现:

    工具类属性
    text-ellipsisoverflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    text-clipoverflow: hidden; text-overflow: clip; white-space: nowrap;

    文字省略 text-ellipsis

    使用 text-ellipsis 用省略号(…)来截断溢出的文本。

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    文字裁剪 text-clip

    使用 text-clip 在内容区域的极限处截断文本。

    The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。The quick brown fox jumps over the lazy dog.白日依山尽,黄河入海流。欲穷千里目,更上一层楼。

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/typography/utilities/text-transform.html b/dev/utilities/typography/utilities/text-transform.html index f658fad0a8..e56859f18d 100644 --- a/dev/utilities/typography/utilities/text-transform.html +++ b/dev/utilities/typography/utilities/text-transform.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    文本大小写

    定义

    在 ZUI 中,你可以通过如下工具类来设置文本大小写显示规则:

    工具类属性
    uppercasetext-transform: uppercase;
    lowercasetext-transform: lowercase;
    capitalizetext-transform: capitalize;
    normal-casetext-transform: none;

    示例

    显示为大写 uppercase

    The quick brown fox jumps over the lazy dog.

    显示为小写 lowercase

    The quick brown fox jumps over the lazy dog.

    显示为单词首字母大写 capitalize

    The quick brown fox jumps over the lazy dog.

    默认大小写 normal-case

    The quick brown fox jumps over the lazy dog.

    MIT License (MIT)

    - +
    Skip to content

    文本大小写

    定义

    在 ZUI 中,你可以通过如下工具类来设置文本大小写显示规则:

    工具类属性
    uppercasetext-transform: uppercase;
    lowercasetext-transform: lowercase;
    capitalizetext-transform: capitalize;
    normal-casetext-transform: none;

    示例

    显示为大写 uppercase

    The quick brown fox jumps over the lazy dog.

    显示为小写 lowercase

    The quick brown fox jumps over the lazy dog.

    显示为单词首字母大写 capitalize

    The quick brown fox jumps over the lazy dog.

    默认大小写 normal-case

    The quick brown fox jumps over the lazy dog.

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/typography/utilities/vertical-align.html b/dev/utilities/typography/utilities/vertical-align.html index dc4c27b6d7..50615aa7a5 100644 --- a/dev/utilities/typography/utilities/vertical-align.html +++ b/dev/utilities/typography/utilities/vertical-align.html @@ -14,14 +14,14 @@ - - + + -
    Skip to content

    垂直对齐

    定义

    用于控制内联或表格单元格的垂直对齐的工具类。

    工具类属性
    align-middlevertical-align: middle;
    align-topvertical-align: top;
    align-bottomvertical-align: bottom;
    align-subvertical-align: sub;
    align-supervertical-align: super;

    示例

    参照文本中部对齐

    参照文本顶端对齐

    参照文本底部对齐

    参照文本文本下标对齐

    参照文本文本上标对齐

    MIT License (MIT)

    - +
    Skip to content

    垂直对齐

    定义

    用于控制内联或表格单元格的垂直对齐的工具类。

    工具类属性
    align-middlevertical-align: middle;
    align-topvertical-align: top;
    align-bottomvertical-align: bottom;
    align-subvertical-align: sub;
    align-supervertical-align: super;

    示例

    参照文本中部对齐

    参照文本顶端对齐

    参照文本底部对齐

    参照文本文本下标对齐

    参照文本文本上标对齐

    MIT License (MIT)

    + \ No newline at end of file diff --git a/dev/utilities/typography/utilities/whitespace.html b/dev/utilities/typography/utilities/whitespace.html index 0b24063d77..4434ebce6c 100644 --- a/dev/utilities/typography/utilities/whitespace.html +++ b/dev/utilities/typography/utilities/whitespace.html @@ -14,22 +14,22 @@ - - + + -
    Skip to content

    空白处理

    定义

    用于控制元素的空格属性的工具类。

    工具类属性
    whitespace-nowrapwhite-space: nowrap;
    whitespace-prewhite-space: pre;
    whitespace-pre-linewhite-space: pre-line;
    whitespace-pre-wrapwhite-space: pre-wrap;

    示例

    不保留空格不自动换行

    使用 whitespace-nowrap 来防止文本在元素中被包裹。换行和空格将被折叠。

    The quick brown fox jumps over the lazy dog. +
    Skip to content

    空白处理

    定义

    用于控制元素的空格属性的工具类。

    工具类属性
    whitespace-nowrapwhite-space: nowrap;
    whitespace-prewhite-space: pre;
    whitespace-pre-linewhite-space: pre-line;
    whitespace-pre-wrapwhite-space: pre-wrap;

    示例

    不保留空格不自动换行

    使用 whitespace-nowrap 来防止文本在元素中被包裹。换行和空格将被折叠。

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。 - 欲穷千里目,更上一层楼。

    保留空格不自动换行

    使用 pre 来保留元素中的换行和空格。文本不会被包装。

    The quick brown fox jumps over the lazy dog. + 欲穷千里目,更上一层楼。

    保留空格不自动换行

    使用 pre 来保留元素中的换行和空格。文本不会被包装。

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。 - 欲穷千里目,更上一层楼。

    不保留空格自动换行

    使用 whitespace-pre-line 保留换行,但不保留元素中的空格。文本将被正常包装。

    The quick brown fox jumps over the lazy dog. + 欲穷千里目,更上一层楼。

    不保留空格自动换行

    使用 whitespace-pre-line 保留换行,但不保留元素中的空格。文本将被正常包装。

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。 - 欲穷千里目,更上一层楼。

    保留空格自动换行

    使用 whitespace-pre-wrap 来保留元素中的换行和空格。文本将被正常包装。

    The quick brown fox jumps over the lazy dog. + 欲穷千里目,更上一层楼。

    保留空格自动换行

    使用 whitespace-pre-wrap 来保留元素中的换行和空格。文本将被正常包装。

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。 欲穷千里目,更上一层楼。

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/utilities/typography/utilities/word-break.html b/dev/utilities/typography/utilities/word-break.html index 8e1fed7e12..5a9f646dec 100644 --- a/dev/utilities/typography/utilities/word-break.html +++ b/dev/utilities/typography/utilities/word-break.html @@ -14,20 +14,20 @@ - - + + -
    Skip to content

    文本换行

    定义

    用于控制元素中的换行符的工具类。

    工具类属性
    break-normaloverflow-wrap: normal;word-break: normal;
    break-wordsoverflow-wrap: break-word;
    break-allword-break: break-all;

    示例

    字内换行

    使用 break-normal 只在正常的换行点添加换行符。

    The quick brown fox jumps over the lazy dog. +
    Skip to content

    文本换行

    定义

    用于控制元素中的换行符的工具类。

    工具类属性
    break-normaloverflow-wrap: normal;word-break: normal;
    break-wordsoverflow-wrap: break-word;
    break-allword-break: break-all;

    示例

    字内换行

    使用 break-normal 只在正常的换行点添加换行符。

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。 - 欲穷千里目,更上一层楼。

    单词内换行

    使用 break-words 在词中间添加换行符。

    The quick brown fox jumps over the lazy dog. + 欲穷千里目,更上一层楼。

    单词内换行

    使用 break-words 在词中间添加换行符。

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。 - 欲穷千里目,更上一层楼。

    任意字内断开

    使用 break-all 在必要的时候添加换行符,而不是试图保留整个单词。

    The quick brown fox jumps over the lazy dog. + 欲穷千里目,更上一层楼。

    任意字内断开

    使用 break-all 在必要的时候添加换行符,而不是试图保留整个单词。

    The quick brown fox jumps over the lazy dog. 白日依山尽,黄河入海流。 欲穷千里目,更上一层楼。

    MIT License (MIT)

    - + \ No newline at end of file diff --git a/dev/zui-3.0.0.zip b/dev/zui-3.0.0.zip index 8fd2d056f085f86aed773fa91869a012e515142e..bbbb7f249c74cf950b6b3c91300f037adaa4a779 100644 GIT binary patch delta 305421 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�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�JlDj;i@-UyoZSIbsWf;fBc0ZX3jt5)kjR2 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

    REXb^|xW48V8Qf6!zDWPBK4qf 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 }2nAw7R5O2QzGvvYqghBQ+o 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 (bn(s, t, "read from private field"), e ? e.call(s) : t.ge t instanceof WeakSet ? t.add(s) : t.set(s, e); }, mt = (s, t, e, n) => (bn(s, t, "write to private field"), n ? n.call(s, e) : t.set(s, e), e); var wn = (s, t, e) => (bn(s, t, "access private method"), e); -const Pu = "3.0.0", Ru = 1722568029152, Ht = document, Es = window, Hr = Ht.documentElement, de = Ht.createElement.bind(Ht), Wr = de("div"), Cn = de("table"), Ja = de("tbody"), ar = de("tr"), { isArray: Xs, prototype: jr } = Array, { concat: Za, filter: oi, indexOf: Br, map: Vr, push: Xa, slice: Ur, some: ai, splice: Qa } = jr, tl = /^#(?:[\w-]|\\.|[^\x00-\xa0])*$/, el = /^\.(?:[\w-]|\\.|[^\x00-\xa0])*$/, sl = /<.+>/, nl = /^\w+$/; +const Pu = "3.0.0", Ru = 1722577250753, Ht = document, Es = window, Hr = Ht.documentElement, de = Ht.createElement.bind(Ht), Wr = de("div"), Cn = de("table"), Ja = de("tbody"), ar = de("tr"), { isArray: Xs, prototype: jr } = Array, { concat: Za, filter: oi, indexOf: Br, map: Vr, push: Xa, slice: Ur, some: ai, splice: Qa } = jr, tl = /^#(?:[\w-]|\\.|[^\x00-\xa0])*$/, el = /^\.(?:[\w-]|\\.|[^\x00-\xa0])*$/, sl = /<.+>/, nl = /^\w+$/; function li(s, t) { const e = il(t); return !s || !e && !le(t) && !X(t) ? [] : !e && el.test(s) ? t.getElementsByClassName(s.slice(1).replace(/\\/g, "")) : !e && nl.test(s) ? t.getElementsByTagName(s) : t.querySelectorAll(s); @@ -10904,7 +10904,7 @@ const vu = { }, methods: { ignoreNextClick(s = 10) { - window.setTimeout(() => { + this.data.ignoreNextClick = window.setTimeout(() => { this.data.ignoreNextClick = void 0; }, s); } diff --git a/dev/zui/zui.esm.js.map b/dev/zui/zui.esm.js.map index 3f701c5a72..a16968e70e 100644 --- a/dev/zui/zui.esm.js.map +++ b/dev/zui/zui.esm.js.map @@ -1 +1 @@ -{"version":3,"file":"zui.esm.js","sources":["../../../../lib/core/src/config/index.ts","../../../../node_modules/cash-dom/dist/cash.esm.js","../../../../lib/core/src/cash/cash.ts","../../../../lib/helpers/src/object/deep-get.ts","../../../../lib/helpers/src/format-string.ts","../../../../lib/core/src/i18n/i18n.ts","../../../../lib/core/src/i18n/common.ts","../../../../lib/core/src/ajax/ajax.ts","../../../../lib/core/src/ajax/helper.ts","../../../../lib/core/src/ajax/fetcher.ts","../../../../lib/core/src/helpers/gid.ts","../../../../lib/core/src/helpers/is-diff.ts","../../../../lib/core/src/helpers/computed.ts","../../../../lib/core/src/helpers/classes.ts","../../../../lib/core/src/helpers/data.ts","../../../../lib/core/src/helpers/raw-data.ts","../../../../lib/core/src/helpers/z.ts","../../../../lib/core/src/helpers/attr.ts","../../../../lib/core/src/helpers/event.ts","../../../../lib/core/src/helpers/delay.ts","../../../../lib/core/src/helpers/share-data.ts","../../../../node_modules/preact/dist/preact.module.js","../../../../lib/core/src/helpers/merge-props.ts","../../../../lib/core/src/helpers/scroll.ts","../../../../lib/core/src/helpers/global-event.ts","../../../../lib/core/src/helpers/size.ts","../../../../lib/core/src/helpers/download-file.ts","../../../../lib/core/src/helpers/bus.ts","../../../../node_modules/tinykeys/dist/tinykeys.module.js","../../../../lib/core/src/helpers/hotkeys.ts","../../../../lib/core/src/helpers/fullscreen.ts","../../../../lib/core/src/dom/is-detached.ts","../../../../lib/core/src/component/component.ts","../../../../lib/core/src/component/creator.ts","../../../../lib/core/src/helpers/sticky.ts","../../../../lib/core/src/dom/is-visible.ts","../../../../lib/core/src/dom/run-js.ts","../../../../lib/core/src/dom/scroll-into-view.ts","../../../../lib/core/src/dom/get-lib.ts","../../../../lib/core/src/dom/resize.ts","../../../../lib/core/src/react/components/components.ts","../../../../lib/core/src/react/components/h-element.ts","../../../../node_modules/preact/jsx-runtime/dist/jsxRuntime.module.js","../../../../lib/core/src/react/components/html-content.tsx","../../../../lib/core/src/react/components/custom-render.tsx","../../../../lib/core/src/react/components/custom-content.tsx","../../../../lib/core/src/react/components/icon.tsx","../../../../lib/core/src/react/components/portals.ts","../../../../lib/core/src/react/components/share.ts","../../../../lib/core/src/react/component-from-react.ts","../../../../lib/button/src/component/button.tsx","../../../../lib/button/src/component/share.ts","../../../../lib/common-list/src/component/common-list.tsx","../../../../lib/common-list/src/vanilla/common-list.ts","../../../../lib/common-list/src/component/share.ts","../../../../lib/helpers/src/color-helper.ts","../../../../lib/helpers/src/string-code.ts","../../../../lib/avatar/src/component/avatar.tsx","../../../../lib/btn-group/src/component/btn-group.tsx","../../../../lib/toolbar/src/component/toolbar.tsx","../../../../lib/checkbox/src/component/checkbox.tsx","../../../../lib/checkbox/src/component/radio.tsx","../../../../lib/checkbox/src/component/switch.tsx","../../../../lib/list/src/component/listitem.tsx","../../../../lib/list/src/component/list.tsx","../../../../lib/store/src/store.ts","../../../../lib/store/src/main.ts","../../../../lib/list/src/component/nested-list.tsx","../../../../lib/menu/src/component/menu.tsx","../../../../lib/search-box/src/components/search-box.tsx","../../../../lib/menu/src/component/search-menu.tsx","../../../../lib/menu/src/vanilla/menu.ts","../../../../lib/menu/src/vanilla/search-menu.ts","../../../../lib/menu/src/component/share.ts","../../../../lib/alert/src/component/alert.tsx","../../../../lib/messager/src/component/messager-item.tsx","../../../../lib/messager/src/vanilla/messager-item.ts","../../../../lib/messager/src/vanilla/messager.ts","../../../../lib/progress/src/components/progress-bar.tsx","../../../../lib/progress/src/components/share.ts","../../../../lib/progress/src/vanilla/index.ts","../../../../lib/progress-circle/src/component/progress-circle.tsx","../../../../lib/progress-circle/src/vanilla/index.ts","../../../../lib/progress-circle/src/component/share.ts","../../../../lib/avatar/src/vanilla/index.ts","../../../../lib/avatar/src/component/share.ts","../../../../lib/btn-group/src/vanilla/index.ts","../../../../lib/btn-group/src/component/share.ts","../../../../lib/pick/src/components/pick-trigger.tsx","../../../../node_modules/@floating-ui/utils/dist/floating-ui.utils.mjs","../../../../node_modules/@floating-ui/core/dist/floating-ui.core.mjs","../../../../node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.mjs","../../../../node_modules/@floating-ui/dom/dist/floating-ui.dom.mjs","../../../../lib/pick/src/components/pick-pop.tsx","../../../../lib/pick/src/components/pick.tsx","../../../../lib/color-picker/src/components/color-picker.tsx","../../../../lib/color-picker/src/vanilla/color-picker.ts","../../../../lib/helpers/src/date-helper.ts","../../../../lib/datetime-picker/src/component/time-picker-menu.tsx","../../../../lib/datetime-picker/src/component/time-picker.tsx","../../../../lib/datetime-picker/src/helpers/date-helper.ts","../../../../lib/datetime-picker/src/i18n/index.ts","../../../../lib/datetime-picker/src/component/mini-calendar.tsx","../../../../lib/datetime-picker/src/component/value-selector.tsx","../../../../lib/datetime-picker/src/component/date-picker-menu.tsx","../../../../lib/datetime-picker/src/component/date-picker.tsx","../../../../lib/datetime-picker/src/component/datetime-picker.tsx","../../../../lib/datetime-picker/src/vanilla/time-picker.ts","../../../../lib/datetime-picker/src/vanilla/date-picker.ts","../../../../lib/datetime-picker/src/vanilla/datetime-picker.ts","../../../../lib/modal/src/vanilla/modal-base.ts","../../../../lib/modal/src/component/modal-dialog.tsx","../../../../lib/modal/src/component/modal-iframe-content.tsx","../../../../lib/modal/src/vanilla/modal.tsx","../../../../lib/modal/src/vanilla/modal-trigger.ts","../../../../lib/file-selector/src/i18n/index.ts","../../../../lib/file-selector/src/components/file-selector.tsx","../../../../lib/file-selector/src/components/image-selector.tsx","../../../../lib/file-selector/src/vanilla/file-selector.ts","../../../../lib/file-selector/src/vanilla/image-selector.ts","../../../../lib/file-selector/src/components/share.ts","../../../../lib/nav/src/component/nav.tsx","../../../../lib/nav/src/vanilla/nav.ts","../../../../lib/nav/src/component/share.ts","../../../../lib/pager/src/helpers/update-pager-info.ts","../../../../lib/pager/src/component/pager-link.tsx","../../../../lib/pager/src/component/pager-info.tsx","../../../../lib/pager/src/component/pager-nav.tsx","../../../../lib/popover/src/component/popover-panel.tsx","../../../../lib/popover/src/vanilla/popover-panel.ts","../../../../lib/popover/src/vanilla/popover.ts","../../../../lib/dropdown/src/vanilla/dropdown.ts","../../../../lib/dropdown/src/component/dropdown-button.tsx","../../../../lib/dropdown/src/component/dropdown-menu.tsx","../../../../lib/pager/src/component/pager-size-menu.tsx","../../../../lib/pager/src/component/pager-goto.tsx","../../../../lib/pager/src/component/pager.tsx","../../../../lib/pager/src/vanilla/index.ts","../../../../lib/pager/src/component/share.ts","../../../../lib/pick/src/vanilla/pick.ts","../../../../lib/picker/src/component/picker-search.tsx","../../../../lib/picker/src/component/picker-multi-select.tsx","../../../../lib/picker/src/component/picker-single-select.tsx","../../../../lib/tree/src/components/tree.tsx","../../../../lib/tree/src/components/search-tree.tsx","../../../../lib/picker/src/component/picker-menu.tsx","../../../../lib/picker/src/component/picker.tsx","../../../../lib/picker/src/vanilla/picker.ts","../../../../lib/picker/src/i18n/index.ts","../../../../lib/search-box/src/vanilla/search-box.ts","../../../../lib/search-box/src/components/share.ts","../../../../lib/toolbar/src/vanilla/index.ts","../../../../lib/toolbar/src/component/share.ts","../../../../lib/tooltip/src/vanilla/tooltip.ts","../../../../lib/scrollbar/src/component/scrollbar.tsx","../../../../lib/dtable/src/helpers/shared-plugins.ts","../../../../lib/dtable/src/helpers/default-options.ts","../../../../lib/dtable/src/helpers/number.ts","../../../../lib/dtable/src/helpers/layout.ts","../../../../lib/dtable/src/components/cell.tsx","../../../../lib/dtable/src/components/cells.tsx","../../../../lib/dtable/src/components/block.tsx","../../../../lib/dtable/src/components/dtable.tsx","../../../../lib/dtable/src/plugins/rich/index.tsx","../../../../lib/dtable/src/plugins/sort/index.tsx","../../../../lib/dtable/src/plugins/custom/index.tsx","../../../../lib/dtable/src/plugins/checkable/index.tsx","../../../../lib/dtable/src/plugins/store/index.ts","../../../../lib/dtable/src/plugins/nested/index.tsx","../../../../lib/dtable/src/plugins/avatar/index.tsx","../../../../lib/dtable/src/plugins/sort-type/index.tsx","../../../../lib/dtable/src/plugins/group/index.tsx","../../../../lib/dtable/src/plugins/header-group/index.tsx","../../../../lib/dtable/src/plugins/cellspan/index.ts","../../../../lib/dtable/src/plugins/mousemove/index.ts","../../../../lib/dtable/src/plugins/autoscroll/index.ts","../../../../lib/dtable/src/plugins/sortable/index.tsx","../../../../lib/dtable/src/vanilla/index.ts","../../../../lib/tabs/src/vanilla/tabs.ts"],"sourcesContent":["\n// eslint-disable-next-line @typescript-eslint/naming-convention\ndeclare const __APP_VERSION__: string;\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\ndeclare const __BUILD_TIME__: number;\n\nexport const VERSION = __APP_VERSION__;\nexport const BUILD = __BUILD_TIME__;\n","const doc = document;\nconst win = window;\nconst docEle = doc.documentElement;\nconst createElement = doc.createElement.bind(doc);\nconst div = createElement('div');\nconst table = createElement('table');\nconst tbody = createElement('tbody');\nconst tr = createElement('tr');\nconst { isArray, prototype: ArrayPrototype } = Array;\nconst { concat, filter, indexOf, map, push, slice, some, splice } = ArrayPrototype;\nconst idRe = /^#(?:[\\w-]|\\\\.|[^\\x00-\\xa0])*$/;\nconst classRe = /^\\.(?:[\\w-]|\\\\.|[^\\x00-\\xa0])*$/;\nconst htmlRe = /<.+>/;\nconst tagRe = /^\\w+$/;\n// @require ./variables.ts\nfunction find(selector, context) {\n const isFragment = isDocumentFragment(context);\n return !selector || (!isFragment && !isDocument(context) && !isElement(context))\n ? []\n : !isFragment && classRe.test(selector)\n ? context.getElementsByClassName(selector.slice(1).replace(/\\\\/g, ''))\n : !isFragment && tagRe.test(selector)\n ? context.getElementsByTagName(selector)\n : context.querySelectorAll(selector);\n}\n// @require ./find.ts\n// @require ./variables.ts\nclass Cash {\n constructor(selector, context) {\n if (!selector)\n return;\n if (isCash(selector))\n return selector;\n let eles = selector;\n if (isString(selector)) {\n const ctx = context || doc;\n eles = idRe.test(selector) && isDocument(ctx)\n ? ctx.getElementById(selector.slice(1).replace(/\\\\/g, ''))\n : htmlRe.test(selector)\n ? parseHTML(selector)\n : isCash(ctx)\n ? ctx.find(selector)\n : isString(ctx)\n ? cash(ctx).find(selector)\n : find(selector, ctx);\n if (!eles)\n return;\n }\n else if (isFunction(selector)) {\n return this.ready(selector); //FIXME: `fn.ready` is not included in `core`, but it's actually a core functionality\n }\n if (eles.nodeType || eles === win)\n eles = [eles];\n this.length = eles.length;\n for (let i = 0, l = this.length; i < l; i++) {\n this[i] = eles[i];\n }\n }\n init(selector, context) {\n return new Cash(selector, context);\n }\n}\nconst fn = Cash.prototype;\nconst cash = fn.init;\ncash.fn = cash.prototype = fn; // Ensuring that `cash () instanceof cash`\nfn.length = 0;\nfn.splice = splice; // Ensuring a cash collection gets printed as array-like in Chrome's devtools\nif (typeof Symbol === 'function') { // Ensuring a cash collection is iterable\n fn[Symbol['iterator']] = ArrayPrototype[Symbol['iterator']];\n}\nfunction isCash(value) {\n return value instanceof Cash;\n}\nfunction isWindow(value) {\n return !!value && value === value.window;\n}\nfunction isDocument(value) {\n return !!value && value.nodeType === 9;\n}\nfunction isDocumentFragment(value) {\n return !!value && value.nodeType === 11;\n}\nfunction isElement(value) {\n return !!value && value.nodeType === 1;\n}\nfunction isText(value) {\n return !!value && value.nodeType === 3;\n}\nfunction isBoolean(value) {\n return typeof value === 'boolean';\n}\nfunction isFunction(value) {\n return typeof value === 'function';\n}\nfunction isString(value) {\n return typeof value === 'string';\n}\nfunction isUndefined(value) {\n return value === undefined;\n}\nfunction isNull(value) {\n return value === null;\n}\nfunction isNumeric(value) {\n return !isNaN(parseFloat(value)) && isFinite(value);\n}\nfunction isPlainObject(value) {\n if (typeof value !== 'object' || value === null)\n return false;\n const proto = Object.getPrototypeOf(value);\n return proto === null || proto === Object.prototype;\n}\ncash.isWindow = isWindow;\ncash.isFunction = isFunction;\ncash.isArray = isArray;\ncash.isNumeric = isNumeric;\ncash.isPlainObject = isPlainObject;\nfunction each(arr, callback, _reverse) {\n if (_reverse) {\n let i = arr.length;\n while (i--) {\n if (callback.call(arr[i], i, arr[i]) === false)\n return arr;\n }\n }\n else if (isPlainObject(arr)) {\n const keys = Object.keys(arr);\n for (let i = 0, l = keys.length; i < l; i++) {\n const key = keys[i];\n if (callback.call(arr[key], key, arr[key]) === false)\n return arr;\n }\n }\n else {\n for (let i = 0, l = arr.length; i < l; i++) {\n if (callback.call(arr[i], i, arr[i]) === false)\n return arr;\n }\n }\n return arr;\n}\ncash.each = each;\nfn.each = function (callback) {\n return each(this, callback);\n};\nfn.empty = function () {\n return this.each((i, ele) => {\n while (ele.firstChild) {\n ele.removeChild(ele.firstChild);\n }\n });\n};\nfunction extend(...sources) {\n const deep = isBoolean(sources[0]) ? sources.shift() : false;\n const target = sources.shift();\n const length = sources.length;\n if (!target)\n return {};\n if (!length)\n return extend(deep, cash, target);\n for (let i = 0; i < length; i++) {\n const source = sources[i];\n for (const key in source) {\n if (deep && (isArray(source[key]) || isPlainObject(source[key]))) {\n if (!target[key] || target[key].constructor !== source[key].constructor)\n target[key] = new source[key].constructor();\n extend(deep, target[key], source[key]);\n }\n else {\n target[key] = source[key];\n }\n }\n }\n return target;\n}\ncash.extend = extend;\nfn.extend = function (plugins) {\n return extend(fn, plugins);\n};\n// @require ./type_checking.ts\nconst splitValuesRe = /\\S+/g;\nfunction getSplitValues(str) {\n return isString(str) ? str.match(splitValuesRe) || [] : [];\n}\nfn.toggleClass = function (cls, force) {\n const classes = getSplitValues(cls);\n const isForce = !isUndefined(force);\n return this.each((i, ele) => {\n if (!isElement(ele))\n return;\n each(classes, (i, c) => {\n if (isForce) {\n force ? ele.classList.add(c) : ele.classList.remove(c);\n }\n else {\n ele.classList.toggle(c);\n }\n });\n });\n};\nfn.addClass = function (cls) {\n return this.toggleClass(cls, true);\n};\nfn.removeAttr = function (attr) {\n const attrs = getSplitValues(attr);\n return this.each((i, ele) => {\n if (!isElement(ele))\n return;\n each(attrs, (i, a) => {\n ele.removeAttribute(a);\n });\n });\n};\nfunction attr(attr, value) {\n if (!attr)\n return;\n if (isString(attr)) {\n if (arguments.length < 2) {\n if (!this[0] || !isElement(this[0]))\n return;\n const value = this[0].getAttribute(attr);\n return isNull(value) ? undefined : value;\n }\n if (isUndefined(value))\n return this;\n if (isNull(value))\n return this.removeAttr(attr);\n return this.each((i, ele) => {\n if (!isElement(ele))\n return;\n ele.setAttribute(attr, value);\n });\n }\n for (const key in attr) {\n this.attr(key, attr[key]);\n }\n return this;\n}\nfn.attr = attr;\nfn.removeClass = function (cls) {\n if (arguments.length)\n return this.toggleClass(cls, false);\n return this.attr('class', '');\n};\nfn.hasClass = function (cls) {\n return !!cls && some.call(this, (ele) => isElement(ele) && ele.classList.contains(cls));\n};\nfn.get = function (index) {\n if (isUndefined(index))\n return slice.call(this);\n index = Number(index);\n return this[index < 0 ? index + this.length : index];\n};\nfn.eq = function (index) {\n return cash(this.get(index));\n};\nfn.first = function () {\n return this.eq(0);\n};\nfn.last = function () {\n return this.eq(-1);\n};\nfunction text(text) {\n if (isUndefined(text)) {\n return this.get().map(ele => isElement(ele) || isText(ele) ? ele.textContent : '').join('');\n }\n return this.each((i, ele) => {\n if (!isElement(ele))\n return;\n ele.textContent = text;\n });\n}\nfn.text = text;\n// @require core/type_checking.ts\n// @require core/variables.ts\nfunction computeStyle(ele, prop, isVariable) {\n if (!isElement(ele))\n return;\n const style = win.getComputedStyle(ele, null);\n return isVariable ? style.getPropertyValue(prop) || undefined : style[prop] || ele.style[prop];\n}\n// @require ./compute_style.ts\nfunction computeStyleInt(ele, prop) {\n return parseInt(computeStyle(ele, prop), 10) || 0;\n}\n// @require css/helpers/compute_style_int.ts\nfunction getExtraSpace(ele, xAxis) {\n return computeStyleInt(ele, `border${xAxis ? 'Left' : 'Top'}Width`) + computeStyleInt(ele, `padding${xAxis ? 'Left' : 'Top'}`) + computeStyleInt(ele, `padding${xAxis ? 'Right' : 'Bottom'}`) + computeStyleInt(ele, `border${xAxis ? 'Right' : 'Bottom'}Width`);\n}\n// @require css/helpers/compute_style.ts\nconst defaultDisplay = {};\nfunction getDefaultDisplay(tagName) {\n if (defaultDisplay[tagName])\n return defaultDisplay[tagName];\n const ele = createElement(tagName);\n doc.body.insertBefore(ele, null);\n const display = computeStyle(ele, 'display');\n doc.body.removeChild(ele);\n return defaultDisplay[tagName] = display !== 'none' ? display : 'block';\n}\n// @require css/helpers/compute_style.ts\nfunction isHidden(ele) {\n return computeStyle(ele, 'display') === 'none';\n}\n// @require ./cash.ts\nfunction matches(ele, selector) {\n const matches = ele && (ele['matches'] || ele['webkitMatchesSelector'] || ele['msMatchesSelector']);\n return !!matches && !!selector && matches.call(ele, selector);\n}\n// @require ./matches.ts\n// @require ./type_checking.ts\nfunction getCompareFunction(comparator) {\n return isString(comparator)\n ? (i, ele) => matches(ele, comparator)\n : isFunction(comparator)\n ? comparator\n : isCash(comparator)\n ? (i, ele) => comparator.is(ele)\n : !comparator\n ? () => false\n : (i, ele) => ele === comparator;\n}\nfn.filter = function (comparator) {\n const compare = getCompareFunction(comparator);\n return cash(filter.call(this, (ele, i) => compare.call(ele, i, ele)));\n};\n// @require collection/filter.ts\nfunction filtered(collection, comparator) {\n return !comparator ? collection : collection.filter(comparator);\n}\nfn.detach = function (comparator) {\n filtered(this, comparator).each((i, ele) => {\n if (ele.parentNode) {\n ele.parentNode.removeChild(ele);\n }\n });\n return this;\n};\nconst fragmentRe = /^\\s*<(\\w+)[^>]*>/;\nconst singleTagRe = /^<(\\w+)\\s*\\/?>(?:<\\/\\1>)?$/;\nconst containers = {\n '*': div,\n tr: tbody,\n td: tr,\n th: tr,\n thead: table,\n tbody: table,\n tfoot: table\n};\n//TODO: Create elements inside a document fragment, in order to prevent inline event handlers from firing\n//TODO: Ensure the created elements have the fragment as their parent instead of null, this also ensures we can deal with detatched nodes more reliably\nfunction parseHTML(html) {\n if (!isString(html))\n return [];\n if (singleTagRe.test(html))\n return [createElement(RegExp.$1)];\n const fragment = fragmentRe.test(html) && RegExp.$1;\n const container = containers[fragment] || containers['*'];\n container.innerHTML = html;\n return cash(container.childNodes).detach().get();\n}\ncash.parseHTML = parseHTML;\nfn.has = function (selector) {\n const comparator = isString(selector)\n ? (i, ele) => find(selector, ele).length\n : (i, ele) => ele.contains(selector);\n return this.filter(comparator);\n};\nfn.not = function (comparator) {\n const compare = getCompareFunction(comparator);\n return this.filter((i, ele) => (!isString(comparator) || isElement(ele)) && !compare.call(ele, i, ele));\n};\nfunction pluck(arr, prop, deep, until) {\n const plucked = [];\n const isCallback = isFunction(prop);\n const compare = until && getCompareFunction(until);\n for (let i = 0, l = arr.length; i < l; i++) {\n if (isCallback) {\n const val = prop(arr[i]);\n if (val.length)\n push.apply(plucked, val);\n }\n else {\n let val = arr[i][prop];\n while (val != null) {\n if (until && compare(-1, val))\n break;\n plucked.push(val);\n val = deep ? val[prop] : null;\n }\n }\n }\n return plucked;\n}\n// @require core/pluck.ts\n// @require core/variables.ts\nfunction getValue(ele) {\n if (ele.multiple && ele.options)\n return pluck(filter.call(ele.options, option => option.selected && !option.disabled && !option.parentNode.disabled), 'value');\n return ele.value || '';\n}\nfunction val(value) {\n if (!arguments.length)\n return this[0] && getValue(this[0]);\n return this.each((i, ele) => {\n const isSelect = ele.multiple && ele.options;\n if (isSelect || checkableRe.test(ele.type)) {\n const eleValue = isArray(value) ? map.call(value, String) : (isNull(value) ? [] : [String(value)]);\n if (isSelect) {\n each(ele.options, (i, option) => {\n option.selected = eleValue.indexOf(option.value) >= 0;\n }, true);\n }\n else {\n ele.checked = eleValue.indexOf(ele.value) >= 0;\n }\n }\n else {\n ele.value = isUndefined(value) || isNull(value) ? '' : value;\n }\n });\n}\nfn.val = val;\nfn.is = function (comparator) {\n const compare = getCompareFunction(comparator);\n return some.call(this, (ele, i) => compare.call(ele, i, ele));\n};\ncash.guid = 1;\nfunction unique(arr) {\n return arr.length > 1 ? filter.call(arr, (item, index, self) => indexOf.call(self, item) === index) : arr;\n}\ncash.unique = unique;\nfn.add = function (selector, context) {\n return cash(unique(this.get().concat(cash(selector, context).get())));\n};\nfn.children = function (comparator) {\n return filtered(cash(unique(pluck(this, ele => ele.children))), comparator);\n};\nfn.parent = function (comparator) {\n return filtered(cash(unique(pluck(this, 'parentNode'))), comparator);\n};\nfn.index = function (selector) {\n const child = selector ? cash(selector)[0] : this[0];\n const collection = selector ? this : cash(child).parent().children();\n return indexOf.call(collection, child);\n};\nfn.closest = function (comparator) {\n const filtered = this.filter(comparator);\n if (filtered.length)\n return filtered;\n const $parent = this.parent();\n if (!$parent.length)\n return filtered;\n return $parent.closest(comparator);\n};\nfn.siblings = function (comparator) {\n return filtered(cash(unique(pluck(this, ele => cash(ele).parent().children().not(ele)))), comparator);\n};\nfn.find = function (selector) {\n return cash(unique(pluck(this, ele => find(selector, ele))));\n};\n// @require core/variables.ts\n// @require collection/filter.ts\n// @require traversal/find.ts\nconst HTMLCDATARe = /^\\s*\\s*$/g;\nconst scriptTypeRe = /^$|^module$|\\/(java|ecma)script/i;\nconst scriptAttributes = ['type', 'src', 'nonce', 'noModule'];\nfunction evalScripts(node, doc) {\n const collection = cash(node);\n collection.filter('script').add(collection.find('script')).each((i, ele) => {\n if (scriptTypeRe.test(ele.type) && docEle.contains(ele)) { // The script type is supported // The element is attached to the DOM // Using `documentElement` for broader browser support\n const script = createElement('script');\n script.text = ele.textContent.replace(HTMLCDATARe, '');\n each(scriptAttributes, (i, attr) => {\n if (ele[attr])\n script[attr] = ele[attr];\n });\n doc.head.insertBefore(script, null);\n doc.head.removeChild(script);\n }\n });\n}\n// @require ./eval_scripts.ts\nfunction insertElement(anchor, target, left, inside, evaluate) {\n if (inside) { // prepend/append\n anchor.insertBefore(target, left ? anchor.firstChild : null);\n }\n else { // before/after\n if (anchor.nodeName === 'HTML') {\n anchor.parentNode.replaceChild(target, anchor);\n }\n else {\n anchor.parentNode.insertBefore(target, left ? anchor : anchor.nextSibling);\n }\n }\n if (evaluate) {\n evalScripts(target, anchor.ownerDocument);\n }\n}\n// @require ./insert_element.ts\nfunction insertSelectors(selectors, anchors, inverse, left, inside, reverseLoop1, reverseLoop2, reverseLoop3) {\n each(selectors, (si, selector) => {\n each(cash(selector), (ti, target) => {\n each(cash(anchors), (ai, anchor) => {\n const anchorFinal = inverse ? target : anchor;\n const targetFinal = inverse ? anchor : target;\n const indexFinal = inverse ? ti : ai;\n insertElement(anchorFinal, !indexFinal ? targetFinal : targetFinal.cloneNode(true), left, inside, !indexFinal);\n }, reverseLoop3);\n }, reverseLoop2);\n }, reverseLoop1);\n return anchors;\n}\nfn.after = function () {\n return insertSelectors(arguments, this, false, false, false, true, true);\n};\nfn.append = function () {\n return insertSelectors(arguments, this, false, false, true);\n};\nfunction html(html) {\n if (!arguments.length)\n return this[0] && this[0].innerHTML;\n if (isUndefined(html))\n return this;\n const hasScript = /]/.test(html);\n return this.each((i, ele) => {\n if (!isElement(ele))\n return;\n if (hasScript) {\n cash(ele).empty().append(html);\n }\n else {\n ele.innerHTML = html;\n }\n });\n}\nfn.html = html;\nfn.appendTo = function (selector) {\n return insertSelectors(arguments, this, true, false, true);\n};\nfn.wrapInner = function (selector) {\n return this.each((i, ele) => {\n const $ele = cash(ele);\n const contents = $ele.contents();\n contents.length ? contents.wrapAll(selector) : $ele.append(selector);\n });\n};\nfn.before = function () {\n return insertSelectors(arguments, this, false, true);\n};\nfn.wrapAll = function (selector) {\n let structure = cash(selector);\n let wrapper = structure[0];\n while (wrapper.children.length)\n wrapper = wrapper.firstElementChild;\n this.first().before(structure);\n return this.appendTo(wrapper);\n};\nfn.wrap = function (selector) {\n return this.each((i, ele) => {\n const wrapper = cash(selector)[0];\n cash(ele).wrapAll(!i ? wrapper : wrapper.cloneNode(true));\n });\n};\nfn.insertAfter = function (selector) {\n return insertSelectors(arguments, this, true, false, false, false, false, true);\n};\nfn.insertBefore = function (selector) {\n return insertSelectors(arguments, this, true, true);\n};\nfn.prepend = function () {\n return insertSelectors(arguments, this, false, true, true, true, true);\n};\nfn.prependTo = function (selector) {\n return insertSelectors(arguments, this, true, true, true, false, false, true);\n};\nfn.contents = function () {\n return cash(unique(pluck(this, ele => ele.tagName === 'IFRAME' ? [ele.contentDocument] : (ele.tagName === 'TEMPLATE' ? ele.content.childNodes : ele.childNodes))));\n};\nfn.next = function (comparator, _all, _until) {\n return filtered(cash(unique(pluck(this, 'nextElementSibling', _all, _until))), comparator);\n};\nfn.nextAll = function (comparator) {\n return this.next(comparator, true);\n};\nfn.nextUntil = function (until, comparator) {\n return this.next(comparator, true, until);\n};\nfn.parents = function (comparator, _until) {\n return filtered(cash(unique(pluck(this, 'parentElement', true, _until))), comparator);\n};\nfn.parentsUntil = function (until, comparator) {\n return this.parents(comparator, until);\n};\nfn.prev = function (comparator, _all, _until) {\n return filtered(cash(unique(pluck(this, 'previousElementSibling', _all, _until))), comparator);\n};\nfn.prevAll = function (comparator) {\n return this.prev(comparator, true);\n};\nfn.prevUntil = function (until, comparator) {\n return this.prev(comparator, true, until);\n};\nfn.map = function (callback) {\n return cash(concat.apply([], map.call(this, (ele, i) => callback.call(ele, i, ele))));\n};\nfn.clone = function () {\n return this.map((i, ele) => ele.cloneNode(true));\n};\nfn.offsetParent = function () {\n return this.map((i, ele) => {\n let offsetParent = ele.offsetParent;\n while (offsetParent && computeStyle(offsetParent, 'position') === 'static') {\n offsetParent = offsetParent.offsetParent;\n }\n return offsetParent || docEle;\n });\n};\nfn.slice = function (start, end) {\n return cash(slice.call(this, start, end));\n};\n// @require ./cash.ts\nconst dashAlphaRe = /-([a-z])/g;\nfunction camelCase(str) {\n return str.replace(dashAlphaRe, (match, letter) => letter.toUpperCase());\n}\nfn.ready = function (callback) {\n const cb = () => setTimeout(callback, 0, cash);\n if (doc.readyState !== 'loading') {\n cb();\n }\n else {\n doc.addEventListener('DOMContentLoaded', cb);\n }\n return this;\n};\nfn.unwrap = function () {\n this.parent().each((i, ele) => {\n if (ele.tagName === 'BODY')\n return;\n const $ele = cash(ele);\n $ele.replaceWith($ele.children());\n });\n return this;\n};\nfn.offset = function () {\n const ele = this[0];\n if (!ele)\n return;\n const rect = ele.getBoundingClientRect();\n return {\n top: rect.top + win.pageYOffset,\n left: rect.left + win.pageXOffset\n };\n};\nfn.position = function () {\n const ele = this[0];\n if (!ele)\n return;\n const isFixed = (computeStyle(ele, 'position') === 'fixed');\n const offset = isFixed ? ele.getBoundingClientRect() : this.offset();\n if (!isFixed) {\n const doc = ele.ownerDocument;\n let offsetParent = ele.offsetParent || doc.documentElement;\n while ((offsetParent === doc.body || offsetParent === doc.documentElement) && computeStyle(offsetParent, 'position') === 'static') {\n offsetParent = offsetParent.parentNode;\n }\n if (offsetParent !== ele && isElement(offsetParent)) {\n const parentOffset = cash(offsetParent).offset();\n offset.top -= parentOffset.top + computeStyleInt(offsetParent, 'borderTopWidth');\n offset.left -= parentOffset.left + computeStyleInt(offsetParent, 'borderLeftWidth');\n }\n }\n return {\n top: offset.top - computeStyleInt(ele, 'marginTop'),\n left: offset.left - computeStyleInt(ele, 'marginLeft')\n };\n};\nconst propMap = {\n /* GENERAL */\n class: 'className',\n contenteditable: 'contentEditable',\n /* LABEL */\n for: 'htmlFor',\n /* INPUT */\n readonly: 'readOnly',\n maxlength: 'maxLength',\n tabindex: 'tabIndex',\n /* TABLE */\n colspan: 'colSpan',\n rowspan: 'rowSpan',\n /* IMAGE */\n usemap: 'useMap'\n};\nfn.prop = function (prop, value) {\n if (!prop)\n return;\n if (isString(prop)) {\n prop = propMap[prop] || prop;\n if (arguments.length < 2)\n return this[0] && this[0][prop];\n return this.each((i, ele) => { ele[prop] = value; });\n }\n for (const key in prop) {\n this.prop(key, prop[key]);\n }\n return this;\n};\nfn.removeProp = function (prop) {\n return this.each((i, ele) => { delete ele[propMap[prop] || prop]; });\n};\nconst cssVariableRe = /^--/;\n// @require ./variables.ts\nfunction isCSSVariable(prop) {\n return cssVariableRe.test(prop);\n}\n// @require core/camel_case.ts\n// @require core/cash.ts\n// @require core/each.ts\n// @require core/variables.ts\n// @require ./is_css_variable.ts\nconst prefixedProps = {};\nconst { style } = div;\nconst vendorsPrefixes = ['webkit', 'moz', 'ms'];\nfunction getPrefixedProp(prop, isVariable = isCSSVariable(prop)) {\n if (isVariable)\n return prop;\n if (!prefixedProps[prop]) {\n const propCC = camelCase(prop);\n const propUC = `${propCC[0].toUpperCase()}${propCC.slice(1)}`;\n const props = (`${propCC} ${vendorsPrefixes.join(`${propUC} `)}${propUC}`).split(' ');\n each(props, (i, p) => {\n if (p in style) {\n prefixedProps[prop] = p;\n return false;\n }\n });\n }\n return prefixedProps[prop];\n}\n// @require core/type_checking.ts\n// @require ./is_css_variable.ts\nconst numericProps = {\n animationIterationCount: true,\n columnCount: true,\n flexGrow: true,\n flexShrink: true,\n fontWeight: true,\n gridArea: true,\n gridColumn: true,\n gridColumnEnd: true,\n gridColumnStart: true,\n gridRow: true,\n gridRowEnd: true,\n gridRowStart: true,\n lineHeight: true,\n opacity: true,\n order: true,\n orphans: true,\n widows: true,\n zIndex: true\n};\nfunction getSuffixedValue(prop, value, isVariable = isCSSVariable(prop)) {\n return !isVariable && !numericProps[prop] && isNumeric(value) ? `${value}px` : value;\n}\nfunction css(prop, value) {\n if (isString(prop)) {\n const isVariable = isCSSVariable(prop);\n prop = getPrefixedProp(prop, isVariable);\n if (arguments.length < 2)\n return this[0] && computeStyle(this[0], prop, isVariable);\n if (!prop)\n return this;\n value = getSuffixedValue(prop, value, isVariable);\n return this.each((i, ele) => {\n if (!isElement(ele))\n return;\n if (isVariable) {\n ele.style.setProperty(prop, value);\n }\n else {\n ele.style[prop] = value;\n }\n });\n }\n for (const key in prop) {\n this.css(key, prop[key]);\n }\n return this;\n}\n;\nfn.css = css;\nfunction attempt(fn, arg) {\n try {\n return fn(arg);\n }\n catch (_a) {\n return arg;\n }\n}\n// @require core/attempt.ts\n// @require core/camel_case.ts\nconst JSONStringRe = /^\\s+|\\s+$/;\nfunction getData(ele, key) {\n const value = ele.dataset[key] || ele.dataset[camelCase(key)];\n if (JSONStringRe.test(value))\n return value;\n return attempt(JSON.parse, value);\n}\n// @require core/attempt.ts\n// @require core/camel_case.ts\nfunction setData(ele, key, value) {\n value = attempt(JSON.stringify, value);\n ele.dataset[camelCase(key)] = value;\n}\nfunction data(name, value) {\n if (!name) {\n if (!this[0])\n return;\n const datas = {};\n for (const key in this[0].dataset) {\n datas[key] = getData(this[0], key);\n }\n return datas;\n }\n if (isString(name)) {\n if (arguments.length < 2)\n return this[0] && getData(this[0], name);\n if (isUndefined(value))\n return this;\n return this.each((i, ele) => { setData(ele, name, value); });\n }\n for (const key in name) {\n this.data(key, name[key]);\n }\n return this;\n}\nfn.data = data;\nfunction getDocumentDimension(doc, dimension) {\n const docEle = doc.documentElement;\n return Math.max(doc.body[`scroll${dimension}`], docEle[`scroll${dimension}`], doc.body[`offset${dimension}`], docEle[`offset${dimension}`], docEle[`client${dimension}`]);\n}\neach([true, false], (i, outer) => {\n each(['Width', 'Height'], (i, prop) => {\n const name = `${outer ? 'outer' : 'inner'}${prop}`;\n fn[name] = function (includeMargins) {\n if (!this[0])\n return;\n if (isWindow(this[0]))\n return outer ? this[0][`inner${prop}`] : this[0].document.documentElement[`client${prop}`];\n if (isDocument(this[0]))\n return getDocumentDimension(this[0], prop);\n return this[0][`${outer ? 'offset' : 'client'}${prop}`] + (includeMargins && outer ? computeStyleInt(this[0], `margin${i ? 'Top' : 'Left'}`) + computeStyleInt(this[0], `margin${i ? 'Bottom' : 'Right'}`) : 0);\n };\n });\n});\neach(['Width', 'Height'], (index, prop) => {\n const propLC = prop.toLowerCase();\n fn[propLC] = function (value) {\n if (!this[0])\n return isUndefined(value) ? undefined : this;\n if (!arguments.length) {\n if (isWindow(this[0]))\n return this[0].document.documentElement[`client${prop}`];\n if (isDocument(this[0]))\n return getDocumentDimension(this[0], prop);\n return this[0].getBoundingClientRect()[propLC] - getExtraSpace(this[0], !index);\n }\n const valueNumber = parseInt(value, 10);\n return this.each((i, ele) => {\n if (!isElement(ele))\n return;\n const boxSizing = computeStyle(ele, 'boxSizing');\n ele.style[propLC] = getSuffixedValue(propLC, valueNumber + (boxSizing === 'border-box' ? getExtraSpace(ele, !index) : 0));\n });\n };\n});\nconst displayProperty = '___cd';\nfn.toggle = function (force) {\n return this.each((i, ele) => {\n if (!isElement(ele))\n return;\n const hidden = isHidden(ele);\n const show = isUndefined(force) ? hidden : force;\n if (show) {\n ele.style.display = ele[displayProperty] || '';\n if (isHidden(ele)) {\n ele.style.display = getDefaultDisplay(ele.tagName);\n }\n }\n else if (!hidden) {\n ele[displayProperty] = computeStyle(ele, 'display');\n ele.style.display = 'none';\n }\n });\n};\nfn.hide = function () {\n return this.toggle(false);\n};\nfn.show = function () {\n return this.toggle(true);\n};\nconst eventsNamespace = '___ce';\nconst eventsNamespacesSeparator = '.';\nconst eventsFocus = { focus: 'focusin', blur: 'focusout' };\nconst eventsHover = { mouseenter: 'mouseover', mouseleave: 'mouseout' };\nconst eventsMouseRe = /^(mouse|pointer|contextmenu|drag|drop|click|dblclick)/i;\n// @require ./variables.ts\nfunction getEventNameBubbling(name) {\n return eventsHover[name] || eventsFocus[name] || name;\n}\n// @require ./variables.ts\nfunction parseEventName(eventName) {\n const parts = eventName.split(eventsNamespacesSeparator);\n return [parts[0], parts.slice(1).sort()]; // [name, namespace[]]\n}\nfn.trigger = function (event, data) {\n if (isString(event)) {\n const [nameOriginal, namespaces] = parseEventName(event);\n const name = getEventNameBubbling(nameOriginal);\n if (!name)\n return this;\n const type = eventsMouseRe.test(name) ? 'MouseEvents' : 'HTMLEvents';\n event = doc.createEvent(type);\n event.initEvent(name, true, true);\n event.namespace = namespaces.join(eventsNamespacesSeparator);\n event.___ot = nameOriginal;\n }\n event.___td = data;\n const isEventFocus = (event.___ot in eventsFocus);\n return this.each((i, ele) => {\n if (isEventFocus && isFunction(ele[event.___ot])) {\n ele[`___i${event.type}`] = true; // Ensuring the native event is ignored\n ele[event.___ot]();\n ele[`___i${event.type}`] = false; // Ensuring the custom event is not ignored\n }\n ele.dispatchEvent(event);\n });\n};\n// @require ./variables.ts\nfunction getEventsCache(ele) {\n return ele[eventsNamespace] = (ele[eventsNamespace] || {});\n}\n// @require core/guid.ts\n// @require events/helpers/get_events_cache.ts\nfunction addEvent(ele, name, namespaces, selector, callback) {\n const eventCache = getEventsCache(ele);\n eventCache[name] = (eventCache[name] || []);\n eventCache[name].push([namespaces, selector, callback]);\n ele.addEventListener(name, callback);\n}\nfunction hasNamespaces(ns1, ns2) {\n return !ns2 || !some.call(ns2, (ns) => ns1.indexOf(ns) < 0);\n}\n// @require ./get_events_cache.ts\n// @require ./has_namespaces.ts\n// @require ./parse_event_name.ts\nfunction removeEvent(ele, name, namespaces, selector, callback) {\n const cache = getEventsCache(ele);\n if (!name) {\n for (name in cache) {\n removeEvent(ele, name, namespaces, selector, callback);\n }\n }\n else if (cache[name]) {\n cache[name] = cache[name].filter(([ns, sel, cb]) => {\n if ((callback && cb.guid !== callback.guid) || !hasNamespaces(ns, namespaces) || (selector && selector !== sel))\n return true;\n ele.removeEventListener(name, cb);\n });\n }\n}\nfn.off = function (eventFullName, selector, callback) {\n if (isUndefined(eventFullName)) {\n this.each((i, ele) => {\n if (!isElement(ele) && !isDocument(ele) && !isWindow(ele))\n return;\n removeEvent(ele);\n });\n }\n else if (!isString(eventFullName)) {\n for (const key in eventFullName) {\n this.off(key, eventFullName[key]);\n }\n }\n else {\n if (isFunction(selector)) {\n callback = selector;\n selector = '';\n }\n each(getSplitValues(eventFullName), (i, eventFullName) => {\n const [nameOriginal, namespaces] = parseEventName(eventFullName);\n const name = getEventNameBubbling(nameOriginal);\n this.each((i, ele) => {\n if (!isElement(ele) && !isDocument(ele) && !isWindow(ele))\n return;\n removeEvent(ele, name, namespaces, selector, callback);\n });\n });\n }\n return this;\n};\nfn.remove = function (comparator) {\n filtered(this, comparator).detach().off();\n return this;\n};\nfn.replaceWith = function (selector) {\n return this.before(selector).remove();\n};\nfn.replaceAll = function (selector) {\n cash(selector).replaceWith(this);\n return this;\n};\nfunction on(eventFullName, selector, data, callback, _one) {\n if (!isString(eventFullName)) {\n for (const key in eventFullName) {\n this.on(key, selector, data, eventFullName[key], _one);\n }\n return this;\n }\n if (!isString(selector)) {\n if (isUndefined(selector) || isNull(selector)) {\n selector = '';\n }\n else if (isUndefined(data)) {\n data = selector;\n selector = '';\n }\n else {\n callback = data;\n data = selector;\n selector = '';\n }\n }\n if (!isFunction(callback)) {\n callback = data;\n data = undefined;\n }\n if (!callback)\n return this;\n each(getSplitValues(eventFullName), (i, eventFullName) => {\n const [nameOriginal, namespaces] = parseEventName(eventFullName);\n const name = getEventNameBubbling(nameOriginal);\n const isEventHover = (nameOriginal in eventsHover);\n const isEventFocus = (nameOriginal in eventsFocus);\n if (!name)\n return;\n this.each((i, ele) => {\n if (!isElement(ele) && !isDocument(ele) && !isWindow(ele))\n return;\n const finalCallback = function (event) {\n if (event.target[`___i${event.type}`])\n return event.stopImmediatePropagation(); // Ignoring native event in favor of the upcoming custom one\n if (event.namespace && !hasNamespaces(namespaces, event.namespace.split(eventsNamespacesSeparator)))\n return;\n if (!selector && ((isEventFocus && (event.target !== ele || event.___ot === name)) || (isEventHover && event.relatedTarget && ele.contains(event.relatedTarget))))\n return;\n let thisArg = ele;\n if (selector) {\n let target = event.target;\n while (!matches(target, selector)) {\n if (target === ele)\n return;\n target = target.parentNode;\n if (!target)\n return;\n }\n thisArg = target;\n }\n Object.defineProperty(event, 'currentTarget', {\n configurable: true,\n get() {\n return thisArg;\n }\n });\n Object.defineProperty(event, 'delegateTarget', {\n configurable: true,\n get() {\n return ele;\n }\n });\n Object.defineProperty(event, 'data', {\n configurable: true,\n get() {\n return data;\n }\n });\n const returnValue = callback.call(thisArg, event, event.___td);\n if (_one) {\n removeEvent(ele, name, namespaces, selector, finalCallback);\n }\n if (returnValue === false) {\n event.preventDefault();\n event.stopPropagation();\n }\n };\n finalCallback.guid = callback.guid = (callback.guid || cash.guid++);\n addEvent(ele, name, namespaces, selector, finalCallback);\n });\n });\n return this;\n}\nfn.on = on;\nfunction one(eventFullName, selector, data, callback) {\n return this.on(eventFullName, selector, data, callback, true);\n}\n;\nfn.one = one;\nconst queryEncodeCRLFRe = /\\r?\\n/g;\nfunction queryEncode(prop, value) {\n return `&${encodeURIComponent(prop)}=${encodeURIComponent(value.replace(queryEncodeCRLFRe, '\\r\\n'))}`;\n}\nconst skippableRe = /file|reset|submit|button|image/i;\nconst checkableRe = /radio|checkbox/i;\nfn.serialize = function () {\n let query = '';\n this.each((i, ele) => {\n each(ele.elements || [ele], (i, ele) => {\n if (ele.disabled || !ele.name || ele.tagName === 'FIELDSET' || skippableRe.test(ele.type) || (checkableRe.test(ele.type) && !ele.checked))\n return;\n const value = getValue(ele);\n if (!isUndefined(value)) {\n const values = isArray(value) ? value : [value];\n each(values, (i, value) => {\n query += queryEncode(ele.name, value);\n });\n }\n });\n });\n return query.slice(1);\n};\n// @require core/types.ts\n// @require core/cash.ts\n// @require core/type_checking.ts\n// @require core/variables.ts\n// @require core/each.ts\n// @require core/extend.ts\n// @require core/find.ts\n// @require core/get_compare_function.ts\n// @require core/get_split_values.ts\n// @require core/guid.ts\n// @require core/parse_html.ts\n// @require core/unique.ts\n// @require attributes/add_class.ts\n// @require attributes/attr.ts\n// @require attributes/has_class.ts\n// @require attributes/prop.ts\n// @require attributes/remove_attr.ts\n// @require attributes/remove_class.ts\n// @require attributes/remove_prop.ts\n// @require attributes/toggle_class.ts\n// @require collection/add.ts\n// @require collection/each.ts\n// @require collection/eq.ts\n// @require collection/filter.ts\n// @require collection/first.ts\n// @require collection/get.ts\n// @require collection/index.ts\n// @require collection/last.ts\n// @require collection/map.ts\n// @require collection/slice.ts\n// @require css/css.ts\n// @require data/data.ts\n// @require dimensions/inner_outer.ts\n// @require dimensions/normal.ts\n// @require effects/hide.ts\n// @require effects/show.ts\n// @require effects/toggle.ts\n// @require events/off.ts\n// @require events/on.ts\n// @require events/one.ts\n// @require events/ready.ts\n// @require events/trigger.ts\n// @require forms/serialize.ts\n// @require forms/val.ts\n// @require manipulation/after.ts\n// @require manipulation/append.ts\n// @require manipulation/append_to.ts\n// @require manipulation/before.ts\n// @require manipulation/clone.ts\n// @require manipulation/detach.ts\n// @require manipulation/empty.ts\n// @require manipulation/html.ts\n// @require manipulation/insert_after.ts\n// @require manipulation/insert_before.ts\n// @require manipulation/prepend.ts\n// @require manipulation/prepend_to.ts\n// @require manipulation/remove.ts\n// @require manipulation/replace_all.ts\n// @require manipulation/replace_with.ts\n// @require manipulation/text.ts\n// @require manipulation/unwrap.ts\n// @require manipulation/wrap.ts\n// @require manipulation/wrap_all.ts\n// @require manipulation/wrap_inner.ts\n// @require offset/offset.ts\n// @require offset/offset_parent.ts\n// @require offset/position.ts\n// @require traversal/children.ts\n// @require traversal/closest.ts\n// @require traversal/contents.ts\n// @require traversal/find.ts\n// @require traversal/has.ts\n// @require traversal/is.ts\n// @require traversal/next.ts\n// @require traversal/next_all.ts\n// @require traversal/next_until.ts\n// @require traversal/not.ts\n// @require traversal/parent.ts\n// @require traversal/parents.ts\n// @require traversal/parents_until.ts\n// @require traversal/prev.ts\n// @require traversal/prev_all.ts\n// @require traversal/prev_until.ts\n// @require traversal/siblings.ts\n// @no-require extras/get_script.ts\n// @no-require extras/shorthands.ts\n// @require methods.ts\nexport default cash;\nexport { Cash };\n","import $ from 'cash-dom';\nexport type * from 'cash-dom';\n\ndeclare global {\n interface Window {\n $: typeof $\n }\n}\n\nwindow.$ = $;\n\nexport {$, $ as cash};\n","/**\n * Get all values in path from an object\n * @param object The object to access\n * @param pathName Access path\n * @returns All values in path\n * @example\n * const object = {\n * a: [{b: {c: 1}, d: 2}]\n * };\n *\n * deepGetPath(object, 'a[0].b.c'); // Output [[{b: {c: 1}, d: 2}], {b: {c: 1}, {c: 1}, 1]\n */\nexport function deepGetPath(object: object, pathName: string | string[]): (object | undefined)[] {\n if (object === null || object === undefined) {\n return [object, undefined];\n }\n\n if (typeof pathName === 'string') {\n pathName = pathName.split('.');\n }\n\n const fullPath = pathName.join('.');\n let context = object;\n const way = [context];\n while (typeof context === 'object' && context !== null && pathName.length) {\n let name = pathName.shift()!;\n let subName: string | undefined;\n const bracketIndex = name.indexOf('[');\n if (bracketIndex > 0 && bracketIndex < (name.length - 1) && name.endsWith(']')) {\n subName = name.substring(bracketIndex + 1, name.length - 1);\n name = name.substring(0, bracketIndex);\n }\n\n context = (context as Record)[name];\n way.push(context);\n if (subName !== undefined) {\n if (typeof context === 'object' && context !== null) {\n if (context instanceof Map) {\n context = context.get(subName);\n } else {\n context = (context as Record)[subName];\n }\n way.push(context);\n } else {\n throw new Error(`Cannot access property \"${name}[${subName}]\", the full path is \"${fullPath}\".`);\n }\n }\n }\n\n if (pathName.length) {\n throw new Error(`Cannot access property with rest path \"${pathName.join('.')}\", the full path is \"${fullPath}\".`);\n }\n\n return way;\n}\n\n/**\n * Get object inner value with dot-strings\n * @param object The object to access\n * @param pathName Access path\n * @param defaultValue Default value\n * @returns Final value\n * @example\n * const object = {\n * a: [{b: {c: 1}, d: 2}]\n * };\n *\n * deepGetPath(object, 'a[0].b.c'); // Output 1\n * deepGetPath(object, 'a[0].d'); // Output 2\n * deepGetPath(object, 'a'); // Output [{b: {c: 1}, d: 2}]\n */\nexport function deepGet(object: object, pathName: string | string[], defaultValue?: T): T | undefined {\n try {\n const way = deepGetPath(object, pathName);\n const lastValue = way[way.length - 1] as T | undefined;\n return lastValue === undefined ? defaultValue : lastValue;\n } catch (_) {\n return defaultValue;\n }\n}\n","\n/**\n * 格式化字符串\n * @param str 要格式化的字符串\n * @param args 格式化参数\n * @returns 格式化后的字符串\n * @example 通过参数序号格式化\n * const hello = formatString('{0} {1}!', 'Hello', 'world');\n * // hello 值为 'Hello world!'\n */\nexport function formatString(str: string, ...args: unknown[]): string;\n\n/**\n * 格式化字符串\n * @param str 要格式化的字符串\n * @param obj 格式化参数\n * @returns 格式化后的字符串\n * @example 通过对象名称格式化\n * const say = formatString('Say {what} to {who}', {what: 'hello', who: 'you'});\n * // say 值为 'Say hello to you'\n */\nexport function formatString(str: string, obj: Record): string;\n\nexport function formatString(str: string, ...args: [Record] | unknown[]): string {\n if (args.length === 0) {\n return str;\n }\n if (args.length === 1 && typeof args[0] === 'object' && args[0]) {\n const obj = args[0];\n Object.keys(obj).forEach(key => {\n const value = (obj as Record)[key] ?? '';\n str = str.replace(new RegExp(`\\\\{${key}\\\\}`, 'g'), `${value}`);\n });\n return str;\n }\n\n for (let i = 0; i < args.length; i++) {\n const arg = args[i] ?? '';\n str = str.replace(new RegExp(`\\\\{${i}\\\\}`, 'g'), `${arg}`);\n }\n return str;\n}\n\n/**\n * 字节单位表\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nenum BYTE_UNITS {\n B = 1,\n KB = 1024,\n MB = 1024 * 1024,\n GB = 1024 * 1024 * 1024,\n TB = 1024 * 1024 * 1024 * 1024,\n}\n\n/**\n * 格式化字节值为包含单位的字符串\n * @param size 字节大小\n * @param fixed 保留的小数点位数\n * @param unit 单位,如果留空,则自动使用最合适的单位\n * @returns 格式化后的字符串\n */\nexport function formatBytes(size: number, fixed = 2, unit?: keyof typeof BYTE_UNITS) {\n if (Number.isNaN(size)) {\n return '?KB';\n }\n if (!unit) {\n if (size < BYTE_UNITS.KB) {\n unit = 'B';\n } else if (size < BYTE_UNITS.MB) {\n unit = 'KB';\n } else if (size < BYTE_UNITS.GB) {\n unit = 'MB';\n } else if (size < BYTE_UNITS.TB) {\n unit = 'GB';\n } else {\n unit = 'TB';\n }\n }\n\n return (size / BYTE_UNITS[unit]).toFixed(fixed) + unit;\n}\n\n/**\n * 转换带单位的字节字符串为字节数\n * @param str 带单位的字节字符串\n * @returns 字节数\n */\nexport const convertBytes = (str: string) => {\n const pattern = /^[0-9]*(B|KB|MB|GB|TB)$/;\n str = str.toUpperCase();\n const matchRes = str.match(pattern);\n if (!matchRes) {\n return 0;\n }\n const unit = matchRes[1] as keyof typeof BYTE_UNITS;\n str = str.replace(unit, '');\n return Number.parseInt(str, 10) * BYTE_UNITS[unit];\n};\n","import {$} from '../cash';\nimport {deepGet} from '@zui/helpers/src/object/deep-get';\nimport {formatString} from '@zui/helpers/src/format-string';\nimport {I18nLangMap, I18nLangCode, I18nValuesMap} from './types';\n\nlet globalLangCode = (document.documentElement.getAttribute('lang') || 'zh_cn').toLowerCase().replace('-', '_');\n\nlet globalLangMap: I18nLangMap | undefined;\n\nexport function getLangCode() {\n return globalLangCode;\n}\n\nexport function setLangCode(langCode: I18nLangCode) {\n globalLangCode = langCode.toLowerCase().replace('-', '_');\n}\n\nexport function addI18nMap(map: I18nLangMap): void;\nexport function addI18nMap(code: I18nLangCode, values: I18nValuesMap): void;\nexport function addI18nMap(codeOrMap: I18nLangCode | I18nLangMap, values?: I18nValuesMap): void {\n if (!globalLangMap) {\n globalLangMap = {};\n }\n if (typeof codeOrMap === 'string') {\n codeOrMap = {[codeOrMap]: values ?? {}};\n }\n $.extend(true, globalLangMap, codeOrMap);\n}\n\nexport function i18n(maps: I18nLangMap | (I18nLangMap | undefined)[] | undefined, key: string, defaultValue?: T, langCode?: I18nLangCode, globalPrefix?: string): T | undefined;\nexport function i18n(maps: I18nLangMap | (I18nLangMap | undefined)[] | undefined, key: string, args?: string | (string | number)[] | Record, defaultValue?: T, langCode?: I18nLangCode, globalPrefix?: string): T | undefined;\nexport function i18n(maps: I18nLangMap | (I18nLangMap | undefined)[] | undefined, key: string, args?: string | (string | number)[] | Record, defaultValue?: T | I18nLangCode, langCode?: I18nLangCode, globalPrefix?: string): T | undefined {\n if (!Array.isArray(maps)) {\n maps = globalLangMap ? [globalLangMap, maps] : [maps];\n } else if (globalLangMap) {\n maps.unshift(globalLangMap);\n }\n if (typeof args === 'string') {\n globalPrefix = langCode;\n langCode = defaultValue as I18nLangCode;\n defaultValue = args;\n args = undefined;\n }\n const lang = langCode || globalLangCode;\n let value: T | undefined;\n for (const map of maps) {\n if (!map) {\n continue;\n }\n const mapValues = map[lang] || map.default;\n if (!mapValues) {\n continue;\n }\n const mapKey = (globalPrefix && map === globalLangMap) ? `${globalPrefix}.${key}` : key;\n value = deepGet(mapValues, mapKey);\n if (value !== undefined) {\n break;\n }\n }\n if (value === undefined) {\n return defaultValue as T;\n }\n if (args) {\n return formatString(value as string, ...(Array.isArray(args) ? args : [args])) as T;\n }\n return value;\n}\n\nexport function getLang(key: string, args?: string | (string | number)[] | Record, defaultValue?: T, langCode?: I18nLangCode): T | undefined {\n return i18n(undefined, key, args, defaultValue, langCode);\n}\n\ni18n.addLang = addI18nMap;\ni18n.getLang = getLang;\ni18n.getCode = getLangCode;\ni18n.setCode = setLangCode;\ni18n.map = globalLangMap;\n","import {addI18nMap} from './i18n';\n\naddI18nMap({\n 'zh_cn': {\n confirm: '确定',\n save: '保存',\n cancel: '取消',\n delete: '删除',\n reset: '重置',\n add: '添加',\n copy: '复制',\n close: '关闭',\n },\n 'zh_tw': {\n confirm: '確定',\n save: '儲存',\n cancel: '取消',\n delete: '刪除',\n reset: '重置',\n add: '添加',\n Copy: '複製',\n close: '關閉',\n },\n en: {\n confirm: 'Confirm',\n save: 'Save',\n cancel: 'Cancel',\n delete: 'Delete',\n reset: 'Reset',\n add: 'Add',\n copy: 'Copy',\n close: 'Close',\n },\n});\n","import {$} from '@zui/core';\n\nimport type {AjaxCallbackMap, AjaxCompleteCallback, AjaxErrorCallback, AjaxFormItemValue, AjaxSetting, AjaxSuccessCallback} from './types';\n\nfunction setHeader(headers: HeadersInit, name: string, value: string) {\n if (headers instanceof Headers) {\n headers.set(name, value);\n } else if (Array.isArray(headers)) {\n headers.push([name, value]);\n } else {\n headers[name] = value;\n }\n}\n\nfunction setFormItem(formData: FormData, name: string, value: AjaxFormItemValue | AjaxFormItemValue[] | Record) {\n if (value === undefined || value === null) {\n return;\n }\n if (Array.isArray(value)) {\n value.forEach((v) => setFormItem(formData, name, v));\n } else if (!(value instanceof Blob) && $.isPlainObject(value)) {\n Object.entries(value).forEach(([key, v]) => {\n setFormItem(formData, `${name}[${key}]`, v);\n });\n } else {\n formData.append(name, value instanceof Blob ? value : String(value));\n }\n}\n\nfunction getDataType(contentType: string | undefined | null, accepts: Record | undefined) {\n if (contentType) {\n const map = {\n text: 'text/plain',\n html: 'text/html',\n json: 'application/json',\n ...accepts,\n };\n for (const [key, value] of Object.entries(map)) {\n if (value.split(',').map(x => x.trim()).includes(contentType)) {\n return key;\n }\n }\n }\n\n return 'text';\n}\n\nexport function createFormData(data: string | FormData | URLSearchParams | Record | [name: string, value: AjaxFormItemValue][], existingFormData?: FormData): FormData {\n const formData = existingFormData || new FormData();\n if (data) {\n if (typeof data === 'string') {\n data = new URLSearchParams(data);\n }\n if (data instanceof URLSearchParams) {\n data.forEach((value, name) => {\n setFormItem(formData, name, value);\n });\n } else if (Array.isArray(data)) {\n data.forEach(([name, value]) => {\n setFormItem(formData, name, value);\n });\n } else if (data instanceof FormData) {\n data.forEach((value, name) => {\n setFormItem(formData, name, value);\n });\n } else if ($.isPlainObject(data)) {\n Object.entries(data).forEach(([name, value]) => {\n setFormItem(formData, name, value);\n });\n }\n }\n return formData;\n}\n\nexport class Ajax {\n private declare _timeoutID: number;\n\n private _controller: AbortController;\n\n private _callbacks: {[P in keyof AjaxCallbackMap]: AjaxCallbackMap[P][];};\n\n private declare _abortError?: Error;\n\n setting: AjaxSetting;\n\n declare data: T;\n\n declare error: Error;\n\n declare response: Response;\n\n declare url: string;\n\n declare request: RequestInit;\n\n get completed() {\n return this.data !== undefined || this.error !== undefined;\n }\n\n get [Symbol.toStringTag]() {\n return 'Ajax';\n }\n\n constructor(setting: AjaxSetting) {\n this.setting = setting;\n this._controller = new AbortController();\n this._callbacks = {success: [], error: [], complete: []};\n }\n\n on(name: N, callback: AjaxCallbackMap[N]) {\n (this._callbacks[name]).push(callback);\n return this;\n }\n\n success(calback: AjaxSuccessCallback) {\n return this.on('success', calback);\n }\n\n done(calback: AjaxSuccessCallback) {\n return this.success(calback);\n }\n\n fail(calback: AjaxErrorCallback) {\n return this.on('error', calback);\n }\n\n complete(calback: AjaxCompleteCallback) {\n return this.on('complete', calback);\n }\n\n always(calback: AjaxCompleteCallback) {\n return this.complete(calback);\n }\n\n then(resolve: (data: T) => void, reject?: (error: Error) => void) {\n if (this.completed) {\n if (reject && this.error) {\n reject(this.error);\n } else {\n resolve(this.data);\n }\n } else {\n this.success((data) => resolve(data as T));\n if (reject) {\n this.fail(reject);\n }\n }\n return this;\n }\n\n catch(calback: (error: Error) => void) {\n if (this.error) {\n calback(this.error);\n return this;\n }\n return this.on('error', (error) => calback(error));\n }\n\n finally(onFinally: () => void) {\n if (this.completed) {\n onFinally();\n return this;\n }\n return this.complete(() => onFinally());\n }\n\n abort(abortError?: Error) {\n if (this.completed) {\n return false;\n }\n this._abortError = abortError;\n this._controller.abort();\n return true;\n }\n\n getResponseHeader(name: string) {\n return this.response?.headers.get(name);\n }\n\n private _init() {\n if (this.completed) {\n return;\n }\n const {\n url,\n type,\n data,\n processData = true,\n contentType,\n crossDomain,\n accepts,\n dataType,\n timeout,\n dataFilter,\n beforeSend,\n success,\n error,\n complete,\n ...initOptions\n } = this.setting;\n\n if (beforeSend?.(initOptions) === false) {\n return;\n }\n if (type) {\n initOptions.method = type;\n }\n let dataSetting = data;\n if (dataSetting) {\n if (processData) {\n dataSetting = createFormData(dataSetting);\n }\n initOptions.body = dataSetting as BodyInit;\n }\n if (crossDomain) {\n initOptions.mode = 'cors';\n }\n const headers = initOptions.headers || {};\n setHeader(headers, 'X-Requested-With', 'XMLHttpRequest');\n if (contentType) {\n setHeader(headers, 'Content-Type', contentType);\n }\n initOptions.headers = headers;\n\n if (initOptions.signal) {\n initOptions.signal.addEventListener('abort', () => {\n this.abort();\n });\n }\n if (success) {\n this.success(success);\n }\n if (error) {\n this.fail(error);\n }\n if (complete) {\n this.complete(complete);\n }\n initOptions.signal = this._controller.signal;\n this.url = url;\n this.request = initOptions;\n }\n\n private _emit(name: N, ...args: Parameters) {\n this._callbacks[name].forEach((callback) => {\n callback.call(this, ...(args as [arg0: Error & Response, statusText: string, arg2: string & Response]));\n });\n }\n\n async send(): Promise<[data?: D | undefined, error?: Error | undefined, response?: Response | undefined]> {\n if (this.completed) {\n return [];\n }\n this._init();\n\n const {timeout, dataType: dataTypeSetting, accepts, dataFilter, throws, jsonParser} = this.setting;\n if (timeout) {\n this._timeoutID = window.setTimeout(() => {\n this.abort(new Error('timeout'));\n }, timeout);\n }\n\n let response: Response | undefined;\n let error: Error | undefined;\n let data: unknown | undefined;\n try {\n response = await fetch(this.url, this.request);\n this.response = response;\n const {statusText} = response;\n if (response.ok) {\n const isAttachment = response.headers.get('Content-Disposition')?.startsWith('attachment');\n const dataType = isAttachment ? 'blob' : (dataTypeSetting || getDataType(response.headers.get('Content-Type'), accepts));\n if (isAttachment || dataType === 'blob' || dataType === 'file') {\n data = await response.blob();\n } else if (dataType === 'json') {\n if (typeof jsonParser === 'function') {\n data = await response.text();\n data = jsonParser(data as string);\n } else {\n data = await response.json();\n }\n } else {\n data = await response.text();\n }\n this.data = data as T;\n const filteredData = dataFilter?.(data, dataType) ?? data;\n this._emit('success', filteredData, statusText, response);\n } else {\n this.data = await response.text() as T;\n throw new Error(statusText);\n }\n } catch (err) {\n error = err as Error;\n let skipTriggerError = false;\n if (error.name === 'AbortError') {\n if (this._abortError) {\n error = this._abortError;\n } else {\n skipTriggerError = true;\n }\n }\n this.error = error;\n if (!skipTriggerError) {\n this._emit('error', error, response?.statusText, error.message);\n }\n }\n\n if (this._timeoutID) {\n clearTimeout(this._timeoutID);\n }\n\n this._emit('complete', response, response?.statusText);\n if (error && throws) {\n throw error;\n }\n return [data as D, error, response];\n }\n}\n","import {$, Cash} from '@zui/core';\nimport {Ajax} from './ajax';\nimport type {AjaxFormData, AjaxSetting, AjaxSuccessCallback} from './types';\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface CashStatic {\n ajax(urlOrSetting: string | AjaxSetting, setting?: Partial): Ajax;\n\n getJSON(url: string, dataOrSuccess?: AjaxFormData | AjaxSuccessCallback, success?: AjaxSuccessCallback): Ajax;\n\n get(url: string, dataOrSuccess?: AjaxFormData | AjaxSuccessCallback, successOrDataType?: AjaxSuccessCallback | string, dataType?: string, method?: string): Ajax;\n\n post(url: string, dataOrSuccess?: AjaxFormData | AjaxSuccessCallback, successOrDataType?: AjaxSuccessCallback | string, dataType?: string): Ajax;\n }\n\n interface Cash {\n load(this: Cash, url: string, dataOrSuccess?: AjaxFormData | AjaxSuccessCallback, success?: AjaxSuccessCallback): Cash;\n }\n}\n\n/* Extend as $.ajax() to create ajax for cash. */\n$.ajax = (urlOrSetting: string | AjaxSetting, setting?: Partial) => {\n setting = setting || {};\n if (typeof urlOrSetting === 'string') {\n setting.url = urlOrSetting;\n } else {\n $.extend(setting, urlOrSetting);\n }\n const ajax = new Ajax(setting as AjaxSetting);\n ajax.send();\n return ajax;\n};\n\n/* Extend as $.getJSON() to create getJSON for cash. */\n$.getJSON = (url: string, dataOrSuccess?: AjaxFormData | AjaxSuccessCallback, success?: AjaxSuccessCallback) => {\n if (typeof dataOrSuccess === 'function') {\n success = dataOrSuccess;\n dataOrSuccess = undefined;\n }\n return $.ajax({\n url,\n data: dataOrSuccess,\n success,\n dataType: 'json',\n });\n};\n\n/* Extend as $.get() to create get for cash. */\n$.get = (url: string, dataOrSuccess?: AjaxFormData | AjaxSuccessCallback, successOrDataType?: AjaxSuccessCallback | string, dataType?: string, method = 'GET') => {\n let success: AjaxSuccessCallback | undefined;\n let data: AjaxFormData | undefined;\n if (typeof dataOrSuccess === 'function') {\n success = dataOrSuccess;\n data = undefined;\n } else {\n data = dataOrSuccess;\n }\n if (typeof successOrDataType === 'function') {\n success = successOrDataType;\n dataType = undefined;\n } else {\n dataType = successOrDataType;\n }\n return $.ajax({\n method,\n url,\n data,\n success,\n dataType,\n });\n};\n\n/* Extend as $.post() to create post for cash. */\n$.post = (url: string, dataOrSuccess?: AjaxFormData | AjaxSuccessCallback, successOrDataType?: AjaxSuccessCallback | string, dataType?: string) => {\n return $.get(url, dataOrSuccess, successOrDataType, dataType, 'POST');\n};\n\n/* Extend as $.load() to create load for cash. */\n$.fn.load = function (this: Cash, url: string, dataOrSuccess?: AjaxFormData | AjaxSuccessCallback, success?: AjaxSuccessCallback): Cash {\n if (typeof dataOrSuccess === 'function') {\n success = dataOrSuccess;\n dataOrSuccess = undefined;\n }\n const [realUrl, selector] = url.split(' ');\n $.get(realUrl, dataOrSuccess, (data, statusText, response) => {\n if (selector) {\n data = $(data as string).find(selector).html();\n }\n $(this).html(data as string).zuiInit();\n success?.call(this, data, statusText, response);\n }, 'html');\n return this;\n};\n","import {$} from '../cash';\nimport {Ajax} from './ajax';\nimport type {AjaxSetting, FetcherSetting} from './types';\n\nexport async function fetchData(setting: FetcherSetting, args: A = ([] as unknown as A), extraAjaxSetting?: Partial | ((ajaxSetting: AjaxSetting) => Partial)): Promise {\n const ajaxSetting = {throws: true, dataType: 'json'} as AjaxSetting;\n if (typeof setting === 'string') {\n ajaxSetting.url = setting;\n } else if (typeof setting === 'object') {\n $.extend(ajaxSetting, setting);\n } else if (typeof setting === 'function') {\n const result = setting(...args);\n if (result instanceof Promise) {\n const data = await result;\n return data;\n }\n return result;\n }\n if (extraAjaxSetting) {\n $.extend(ajaxSetting, typeof extraAjaxSetting === 'function' ? extraAjaxSetting(ajaxSetting) : extraAjaxSetting);\n }\n const ajax = new Ajax(ajaxSetting);\n const [data] = await ajax.send();\n return data as T;\n}\n\nexport function isFetchSetting(setting: FetcherSetting | unknown): setting is FetcherSetting {\n return !!(setting && (typeof setting === 'string' || (typeof setting === 'object' && (setting as AjaxSetting).url) || typeof setting === 'function'));\n}\n\ndeclare module 'cash-dom' {\n interface CashStatic {\n fetch(setting: FetcherSetting, args?: A, extraAjaxSetting?: Partial | ((ajaxSetting: AjaxSetting) => Partial)): Promise\n }\n}\n\n$.fetch = fetchData;\n","import {$} from '../cash';\n\nexport function nextGid() {\n return $.guid++;\n}\n","export function isDiff(value1: unknown, value2: unknown) {\n if (value1 === value2) {\n return false;\n }\n if (value1 && value2) {\n const typeOfValue1 = typeof value1;\n const typeOfValue2 = typeof value2;\n if (typeOfValue1 !== typeOfValue2) {\n return true;\n }\n if (typeOfValue1 === 'object' && typeOfValue2 === 'object') {\n const isArray1 = Array.isArray(value1);\n const isArray2 = Array.isArray(value2);\n if (isArray1 !== isArray2) {\n return true;\n }\n if (isArray1 && isArray2) {\n if (value1.length !== value2.length) {\n return true;\n }\n for (let i = 0; i < value1.length; i++) {\n if (isDiff(value1[i], value2[i])) {\n return true;\n }\n }\n return true;\n }\n\n const keys1 = Object.keys(value1);\n const keys2 = Object.keys(value2);\n if (keys1.length !== keys2.length) {\n return true;\n }\n for (const key of keys1) {\n if (isDiff((value1 as Record)[key], (value2 as Record)[key])) {\n return true;\n }\n }\n return true;\n }\n if (typeOfValue1 === 'function' && typeOfValue2 === 'function') {\n return value1.toString() !== value2.toString();\n }\n }\n return true;\n}\n","import {isDiff} from './is-diff';\n\n/**\n * A class representing a computed value that can be cached and recomputed when its dependencies change.\n * @template T The type of the computed value.\n * @template D The type of the dependencies array.\n */\nexport class Computed {\n /**\n * The dependencies of the computed value.\n */\n protected _dependencies: D | (() => D);\n\n /**\n * The function that computes the value.\n */\n protected _compute: () => T;\n\n /**\n * The cached value of the computed value.\n */\n protected _value?: T;\n\n /**\n * The last dependencies array used to compute the value.\n */\n protected _lastDependencies: D | undefined;\n\n /**\n * Creates a new Computed instance.\n * @param compute The function that computes the value.\n * @param dependencies The dependencies of the computed value.\n */\n constructor(compute: () => T, dependencies: D | (() => D)) {\n this._compute = compute;\n this._dependencies = dependencies;\n }\n\n /**\n * Gets the computed value.\n */\n get value(): T {\n return this.compute();\n }\n\n /**\n * Gets the cached value of the computed value.\n */\n get cache(): T {\n return this._lastDependencies ? this._value as T : this.compute();\n }\n\n /**\n * Forces the computed value to be recomputed.\n * @param dependencies The new dependencies to use for recomputing the value.\n * @returns The recomputed value.\n */\n forceCompute(dependencies?: D | (() => D)) {\n this._lastDependencies = undefined;\n return this.compute(dependencies);\n }\n\n /**\n * Computes the value of the computed value.\n * @param dependencies The dependencies to use for computing the value.\n * @returns The computed value.\n */\n compute(dependencies?: D | (() => D)): T {\n if (dependencies !== undefined) {\n this._dependencies = dependencies;\n }\n\n dependencies = this._dependencies;\n if (typeof dependencies === 'function') {\n dependencies = dependencies();\n }\n\n // Check if dependencies changed.\n const lastDependencies = this._lastDependencies;\n if (!lastDependencies || dependencies.some((dept, index) => {\n return isDiff(dept instanceof Computed ? dept.value : dept, lastDependencies[index]);\n })) {\n this._value = this._compute();\n this._lastDependencies = dependencies.map(x => x instanceof Computed ? x.cache : x) as D;\n }\n\n return this._value as T;\n }\n}\n","import {$, Cash} from '../cash';\n\n/**\n * Classname like.\n */\nexport type ClassNameLike = string | null | undefined | boolean | {[key: string]: unknown} | (() => ClassNameLike) | ClassNameLike[];\n\n/**\n * Classname setting.\n */\nexport type ClassNameSetting = [name: string, toggle: boolean];\n\n/**\n * Get class name setting list from arguments.\n *\n * @param args Classname like arguments.\n * @returns Classname setting list.\n */\nexport function getClassList(...args: ClassNameLike[]): ClassNameSetting[] {\n const settings: ClassNameSetting[] = [];\n\n /* Indexes map to keep classname's order. */\n const indexes = new Map();\n\n const setSetting = (name: string | [name: string, toggle?: unknown], toggle?: unknown) => {\n if (Array.isArray(name)) {\n toggle = name[1];\n name = name[0];\n }\n if (!name.length) {\n return;\n }\n const index = indexes.get(name);\n if (typeof index === 'number') {\n settings[index][1] = !!toggle;\n } else {\n indexes.set(name, settings.length);\n settings.push([name, !!toggle]);\n }\n };\n\n args.forEach((arg) => {\n if (typeof arg === 'function') {\n arg = arg();\n }\n\n if (Array.isArray(arg)) {\n getClassList(...arg).forEach(setSetting);\n } else if (arg && typeof arg === 'object') {\n Object.entries(arg).forEach(setSetting);\n } else if (typeof arg === 'string') {\n arg.split(' ').forEach(name => setSetting(name, true));\n }\n });\n\n return settings.sort((a, b) => (indexes.get(a[0]) || 0) - (indexes.get(b[0]) || 0));\n}\n\n/**\n * Get classname string from arguments.\n *\n * @param args Classname like arguments.\n * @returns Classname string.\n */\nexport const classes = (...args: ClassNameLike[]): string => {\n return getClassList(...args).reduce((classList, [name, toggle]) => {\n if (toggle) {\n classList.push(name);\n }\n return classList;\n }, []).join(' ');\n};\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface CashStatic {\n classes(...args: ClassNameLike[]): string;\n }\n\n interface Cash {\n setClass(merge: ClassNameLike | boolean, ...args: ClassNameLike[]): Cash;\n }\n}\n\n/* Extend as $.classes() */\n$.classes = classes;\n\n/* Extend as $.fn.setClass() */\n$.fn.setClass = function (this: Cash, merge: ClassNameLike | boolean, ...args: ClassNameLike[]): Cash {\n return this.each((_, ele) => {\n const $ele = $(ele);\n if (merge === true) {\n $ele.attr('class', classes($ele.attr('class'), ...args));\n } else {\n $ele.addClass(classes(merge, ...args));\n }\n });\n};\n","import {$, Cash} from '../cash';\n\n/**\n * Cache for data associated with the target object.\n */\nconst cache = new WeakMap>();\n\n/**\n * Store data associated with the target object with key value in the cache.\n *\n * @param target Target object to store data.\n * @param key Key to store.\n * @param value Value to store.\n */\nexport function storeData(target: object, key: string | null, value?: unknown): void;\n\n/**\n * Store data associated with the target object in the cache.\n *\n * @param target Target object to store data.\n * @param data Data to store.\n */\nexport function storeData(target: object, data: Record): void;\n\n/**\n * Store data associated with the target object in the cache.\n *\n * @param target Target object to store data.\n * @param keyOrData Key or data to store.\n * @param value Value to store.\n */\nexport function storeData(target: object, keyOrData: string | Record | null, value?: unknown): void {\n const hasCache = cache.has(target);\n const data = hasCache ? cache.get(target)! : {};\n if (typeof keyOrData === 'string') {\n data[keyOrData] = value;\n } else if (keyOrData === null) {\n Object.keys(data).forEach((key) => {\n delete data[key];\n });\n } else {\n Object.assign(data, keyOrData);\n }\n\n Object.keys(data).forEach((key) => {\n if (data[key] === undefined) {\n delete data[key];\n }\n });\n\n if (Object.keys(data).length) {\n if (!hasCache && target instanceof Element) {\n Object.assign(data, $(target).dataset(), data);\n }\n cache.set(target, data);\n } else {\n cache.delete(target);\n }\n}\n\n/**\n * Take data associated with the target object from the cache.\n *\n * @param target Target object to take data.\n */\nexport function takeData(target: object): Record;\n\n/**\n * Take data associated by key with the target object from the cache.\n *\n * @param target Target object to take data.\n * @param key Key to take.\n */\nexport function takeData(target: object, key: string): unknown;\n\n/**\n * Take data associated by key with the target object from the cache.\n *\n * @param target Target object to take data.\n * @param key Key to take.\n * @param mergeElementData Whether to merge element dataset.\n */\nexport function takeData(target: object, key: string | undefined, mergeElementData: boolean): unknown;\n\n/**\n * Take data associated with the target object from the cache.\n *\n * @param target Target object to take data.\n * @param key Key to take.\n * @param mergeElementData Whether to merge element dataset.\n * @returns Data associated with the target object.\n */\nexport function takeData(target: object, key?: string, mergeElementData?: boolean): unknown {\n let data = cache.get(target) || {};\n if (mergeElementData && target instanceof Element) {\n data = Object.assign({}, $(target).dataset(), data);\n }\n if (key === undefined) {\n return data;\n }\n return data[key];\n}\n\n/**\n * Clear data associated with the target object from the cache.\n */\nexport function clearData(target: object): void {\n cache.delete(target);\n}\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface Cash {\n dataset(): Record | undefined;\n dataset(name: string): unknown | undefined;\n dataset(name: string, value: unknown): Cash;\n dataset(dataset: Record): Cash;\n\n removeData(name?: string): Cash;\n }\n}\n\n/* Backup the origin $.fn.data method. */\n$.fn.dataset = $.fn.data;\n\n/* Extend as $.fn.data() */\n$.fn.data = function (this: Cash, ...args: (string | Record | unknown)[]) {\n const [data, value] = args;\n if (!args.length || (args.length === 1 && typeof data === 'string')) {\n if (!this.length) {\n return;\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return takeData(this[0]!, data as string, true) as any;\n }\n return this.each((_, ele) => {\n return storeData(ele, data as string, value);\n });\n};\n\n/* Extend as $.fn.removeData() */\n$.fn.removeData = function (this: Cash, name: string | null = null) {\n return this.each((_, ele) => {\n return storeData(ele, name);\n });\n};\n","export function evalValue(value: string, ...args: unknown[]): T {\n if (value.includes('RAWJS')) {\n value = value.split('\"RAWJS<').join('').split('>RAWJS\"').join('').split('').join('\"').split('').join('\\n');\n }\n // eslint-disable-next-line @typescript-eslint/no-implied-eval\n const func = new Function(`return ${value}`);\n return func(...args);\n}\n\nexport function parseRawData(data: string, ...args: unknown[]): T {\n if (data.includes('RAWJS')) {\n return evalValue(data, ...args);\n }\n\n return JSON.parse(data);\n}\n","import {$, Cash, Selector} from '../cash';\nimport {evalValue} from './raw-data';\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface Cash {\n z(): Record | undefined;\n z(name: string): unknown | undefined;\n z(name: string, value: unknown): Cash;\n z(data: Record): Cash;\n }\n}\n\ntype ZDataGetterOptions = {\n prefix?: string;\n evalValue?: boolean | string[];\n evalArgs?: unknown[];\n json?: boolean;\n getter?: (name: string, value: unknown) => unknown;\n};\n\nexport function getZData(selector: Selector, prefixOrOptions?: ZDataGetterOptions | string): Record | undefined {\n const element = $(selector)[0];\n if (!element) {\n return;\n }\n const {prefix, getter, evalValue: evalValueSetting, json = true, evalArgs = []} = {\n prefix: 'z-',\n ...(typeof prefixOrOptions === 'string' ? {prefix: prefixOrOptions} : prefixOrOptions),\n };\n const evalValueSet = Array.isArray(evalValueSetting) ? new Set(evalValueSetting) : undefined;\n return Array.from(element.attributes).reduce>((data, attribute) => {\n let {name} = attribute;\n const {value} = attribute;\n let finalValue: unknown = value;\n if (name.startsWith(prefix)) {\n name = name.slice(prefix.length).replace(/-([a-z])/g, (g) => g[1].toUpperCase());\n if (getter) {\n finalValue = getter(name, value);\n } else {\n try {\n if ((evalValueSetting && (!evalValueSet || evalValueSet.has(name))) || (evalValueSetting === undefined && value.includes('RAWJS'))) {\n finalValue = evalValue(value, ...evalArgs);\n } else if (json) {\n finalValue = JSON.parse(value);\n }\n } catch (error) {\n // Ignore.\n }\n }\n data[name] = finalValue;\n }\n return data;\n }, {});\n}\n\nexport function setZData(selector: Selector, data: Record, prefix = 'z-') {\n const $element = $(selector);\n Object.keys(data).forEach((name) => {\n let value = data[name];\n if (typeof value === 'function') {\n value = `RAWJS<${value}>RAWJS`;\n }\n if (typeof value !== 'string') {\n value = JSON.stringify(value);\n }\n name = name.replace(/[A-Z]/g, (g) => `-${g.toLowerCase()}`);\n $element.attr(`${prefix}${name}`, value as string);\n });\n}\n\nfunction z(): Record | undefined;\nfunction z(name: string): unknown | undefined;\nfunction z(name: string, value: unknown): Cash;\nfunction z(data: Record): Cash;\nfunction z(this: Cash, ...args: unknown[]): Record | unknown | Cash | undefined {\n const argsLength = args.length;\n if (!argsLength) {\n return getZData(this);\n }\n if (argsLength === 1) {\n const [nameOrData] = args;\n if (typeof nameOrData === 'string') {\n return getZData(this)?.[nameOrData];\n }\n if ($.isPlainObject(nameOrData)) {\n setZData(this, nameOrData);\n }\n return this;\n }\n setZData(this, {[args[0] as string]: args[1]});\n return this;\n}\n\n/* Extend as $.fn.z() */\n$.fn.z = z;\n","import {$, Cash} from '../cash';\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface Cash {\n _attr(): undefined;\n _attr(attrs: string): string | null;\n _attr(attrs: string, value: string): this;\n _attr(attrs: Record): this;\n\n attr(attrs: string, value: string | null): Cash;\n attr(attrs: Record): Cash;\n }\n}\n\n/* Backup the origin $.fn.attr() method. */\n$.fn._attr = $.fn.attr;\n\n/* Extend the attr method. */\n$.fn.extend({\n attr(this: Cash, ...args: (string | Record | null)[]): Cash | string | null | undefined {\n const [attrs, value] = args;\n if (!args.length || (args.length === 1 && typeof attrs === 'string')) {\n // eslint-disable-next-line prefer-spread\n return this._attr.apply(this, args as [attrs: Record]);\n }\n if (typeof attrs === 'object') {\n if (attrs) {\n Object.keys(attrs).forEach((key) => {\n const val = attrs[key];\n if (val === null) {\n this.removeAttr(key);\n } else {\n this._attr(key, val);\n }\n });\n }\n return this;\n }\n if (value === null) {\n return this.removeAttr(attrs as string);\n }\n return this._attr(attrs as string, value as string);\n },\n});\n","import {$} from '../cash';\n\n/**\n * Cash event.\n */\ntype CashEvent = Exclude[0], string>;\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface CashStatic {\n Event(event: string, data?: unknown): CashEvent;\n }\n}\n\n/* Extend as $.Event() to create custom event for cash. */\nif (!$.Event) {\n $.Event = (event: string, data?: unknown): CashEvent => {\n const [name, ...namespaces] = event.split('.');\n const eventObject = new Event(name, {\n bubbles: true,\n cancelable: true,\n });\n (eventObject as Event & {namespace: string}).namespace = namespaces.join('.');\n (eventObject as Event & {___ot: string}).___ot = name;\n (eventObject as Event & {___td: unknown}).___td = data;\n return eventObject as unknown as CashEvent;\n };\n}\n","export const delay = (ms: number, setTimerID?: (timerID: number) => void) => new Promise(resolve => {\n const id = window.setTimeout(resolve, ms);\n if (setTimerID) {\n setTimerID(id);\n }\n});\n","import {$} from '../cash';\n\nexport const shareData: Record = {};\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface CashStatic {\n share: Record;\n }\n}\n\n/** Define $.share helper. */\n$.share = shareData;\n","var n,l,u,t,i,o,r,f,e,c,s,a,h={},p=[],v=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i,y=Array.isArray;function d(n,l){for(var u in l)n[u]=l[u];return n}function w(n){var l=n.parentNode;l&&l.removeChild(n)}function _(l,u,t){var i,o,r,f={};for(r in u)\"key\"==r?i=u[r]:\"ref\"==r?o=u[r]:f[r]=u[r];if(arguments.length>2&&(f.children=arguments.length>3?n.call(arguments,2):t),\"function\"==typeof l&&null!=l.defaultProps)for(r in l.defaultProps)void 0===f[r]&&(f[r]=l.defaultProps[r]);return g(l,f,i,o,null)}function g(n,t,i,o,r){var f={type:n,props:t,key:i,ref:o,__k:null,__:null,__b:0,__e:null,__d:void 0,__c:null,constructor:void 0,__v:null==r?++u:r,__i:-1,__u:0};return null==r&&null!=l.vnode&&l.vnode(f),f}function m(){return{current:null}}function k(n){return n.children}function b(n,l){this.props=n,this.context=l}function x(n,l){if(null==l)return n.__?x(n.__,n.__i+1):null;for(var u;lu&&i.sort(f));P.__r=0}function S(n,l,u,t,i,o,r,f,e,c,s){var a,v,y,d,w,_=t&&t.__k||p,g=l.length;for(u.__d=e,$(u,l,_),e=u.__d,a=0;a0?g(i.type,i.props,i.key,i.ref?i.ref:null,i.__v):i)?(i.__=n,i.__b=n.__b+1,f=L(i,u,r,s),i.__i=f,o=null,-1!==f&&(s--,(o=u[f])&&(o.__u|=131072)),null==o||null===o.__v?(-1==f&&a--,\"function\"!=typeof i.type&&(i.__u|=65536)):f!==r&&(f==r-1?a=f-r:f==r+1?a++:f>r?s>e-r?a+=f-r:a--:f(null!=e&&0==(131072&e.__u)?1:0))for(;r>=0||f=0){if((e=l[r])&&0==(131072&e.__u)&&i==e.key&&o===e.type)return r;r--}if(f2&&(e.children=arguments.length>3?n.call(arguments,2):t),g(l.type,e,i||l.key,o||l.ref,null)}function G(n,l){var u={__c:l=\"__cC\"+a++,__:n,Consumer:function(n,l){return n.children(l)},Provider:function(n){var u,t;return this.getChildContext||(u=[],(t={})[l]=this,this.getChildContext=function(){return t},this.componentWillUnmount=function(){u=null},this.shouldComponentUpdate=function(n){this.props.value!==n.value&&u.some(function(n){n.__e=!0,M(n)})},this.sub=function(n){u.push(n);var l=n.componentWillUnmount;n.componentWillUnmount=function(){u&&u.splice(u.indexOf(n),1),l&&l.call(n)}}),n.children}};return u.Provider.__=u.Consumer.contextType=u}n=p.slice,l={__e:function(n,l,u,t){for(var i,o,r;l=l.__;)if((i=l.__c)&&!i.__)try{if((o=i.constructor)&&null!=o.getDerivedStateFromError&&(i.setState(o.getDerivedStateFromError(n)),r=i.__d),null!=i.componentDidCatch&&(i.componentDidCatch(n,t||{}),r=i.__d),r)return i.__E=i}catch(l){n=l}throw n}},u=0,t=function(n){return null!=n&&null==n.constructor},b.prototype.setState=function(n,l){var u;u=null!=this.__s&&this.__s!==this.state?this.__s:this.__s=d({},this.state),\"function\"==typeof n&&(n=n(d({},u),this.props)),n&&d(u,n),null!=n&&this.__v&&(l&&this._sb.push(l),M(this))},b.prototype.forceUpdate=function(n){this.__v&&(this.__e=!0,n&&this.__h.push(n),M(this))},b.prototype.render=k,i=[],r=\"function\"==typeof Promise?Promise.prototype.then.bind(Promise.resolve()):setTimeout,f=function(n,l){return n.__v.__b-l.__v.__b},P.__r=0,e=0,c=F(!1),s=F(!0),a=0;export{b as Component,k as Fragment,E as cloneElement,G as createContext,_ as createElement,m as createRef,_ as h,D as hydrate,t as isValidElement,l as options,B as render,H as toChildArray};\n//# sourceMappingURL=preact.module.js.map\n","import {ComponentChildren, toChildArray} from 'preact';\nimport {$} from '../cash';\n\nexport function mergeProps = Record>(props: Record, ...args: unknown[]) {\n args.forEach(arg => {\n if (!arg || typeof arg !== 'object') {\n return;\n }\n Object.keys(arg as Partial).forEach(key => {\n let value = (arg as Record)[key];\n const oldValue = props[key];\n if (value === oldValue) {\n return;\n }\n if (oldValue !== undefined) {\n if (key === 'className' || key.endsWith('Class')) {\n value = [oldValue, value];\n } else if (key === 'children') {\n value = [...toChildArray(oldValue), ...toChildArray(value as ComponentChildren)];\n } else if (typeof oldValue == 'object' && (key === 'style' || key.endsWith('Style') || key === 'attrs' || key.endsWith('Attrs') || key === 'props')) {\n value = $.extend(oldValue, value);\n }\n }\n props[key] = value;\n });\n });\n return props;\n}\n\nexport function removeUndefinedProps(props: Record) {\n Object.keys(props).forEach(key => {\n if (props[key] === undefined) {\n delete props[key];\n }\n });\n return props;\n}\n","import {$, Cash, Selector} from '../cash';\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface Cash {\n disableScroll(disable?: boolean): Cash;\n enableScroll(enable?: boolean): Cash;\n }\n}\n\nexport function disableScroll(selector: Selector, disable = true): void {\n const $element = $(selector);\n const element = $element[0] as HTMLElement;\n const dataName = 'zui-disable-scroll';\n if (disable) {\n if ($element.data(dataName)) {\n return;\n }\n if (($element.css('scrollbar-gutter') || '').includes('stable')) {\n $element.data(dataName, {overflow: $element.css('overflow')}).css('overflow', 'hidden');\n return;\n }\n const scrollbarWidth = (element === document.body || $element.is('html')) ? (window.innerWidth - document.body.clientWidth) : (element.offsetWidth - element.clientWidth);\n if (!scrollbarWidth) {\n return;\n }\n const paddingRight = $element.css('paddingRight') || '0';\n $element.data(dataName, {\n paddingRight: paddingRight,\n overflow: $element.css('overflow'),\n }).css({\n paddingRight: `${scrollbarWidth + Number.parseInt(paddingRight, 10)}px`,\n overflow: 'hidden',\n });\n } else {\n const oldStyle = $element.data(dataName);\n if (!oldStyle) {\n return;\n }\n $element.css(oldStyle).removeData(dataName);\n }\n}\n\n/* Extend as $.fn.disableScroll() */\n$.fn.disableScroll = function (this: Cash, disable = true): Cash {\n return this.each((_, ele) => {\n disableScroll(ele, disable);\n });\n};\n\n$.fn.enableScroll = function (this: Cash, enable = true): Cash {\n return this.disableScroll(!enable);\n};\n","import {$, Cash} from '../cash';\nimport {evalValue} from './raw-data';\nimport {deepGet} from '@zui/helpers/src/object/deep-get';\nimport {getZData} from './z';\n\nexport type GlobalEventOptions = {\n on: string;\n selector?: string;\n prevent?: boolean;\n stop?: boolean;\n call?: string | ((...args: unknown[]) => void);\n self?: boolean;\n params?: unknown[] | string;\n once?: boolean;\n if?: string | ((...args: unknown[]) => boolean);\n do?: string | ((...args: unknown[]) => void);\n [option: string]: unknown;\n};\n\nfunction processGlobalEvent($element: Cash, event: Event, options: GlobalEventOptions) {\n if (!(options.on as string || 'click').split(' ').includes(event.type)) {\n return;\n }\n const $target = options.selector ? $(event.target as HTMLElement).closest(options.selector as string) : $element;\n if (!$target.length) {\n return;\n }\n const parseBool = (value: unknown) => {\n return value === '' ? true : value;\n };\n const parseVal = (value: unknown) => {\n if (typeof value === 'string') {\n try {\n value = JSON.parse(value);\n // eslint-disable-next-line no-empty\n } catch (_) {}\n }\n return value;\n };\n if (parseBool(options.once)) {\n if (options.onceCalled) {\n return;\n }\n $element.dataset('once-called', true);\n }\n if (parseBool(options.prevent)) {\n event.preventDefault();\n }\n if (parseBool(options.stop)) {\n event.stopPropagation();\n }\n if (parseBool(options.self) && event.currentTarget !== event.target) {\n return;\n }\n\n const runParams: [string, unknown][] = [['$element', $element], ['event', event], ['options', options], ['$target', $target]];\n const runCode = (code: string | ((...args: unknown[]) => boolean)) => {\n if (typeof code === 'function') {\n return code(...runParams);\n }\n return $.runJS(code as string, ...runParams);\n };\n if (options.if !== undefined && !runCode(options.if)) {\n return;\n }\n\n const call = options.call;\n if (call) {\n let callback: unknown;\n if (typeof call === 'string') {\n const isFuncName = /^[$A-Z_][0-9A-Z_$.]*$/i.test(call);\n callback = isFuncName ? deepGet(window, call) : runCode(call);\n } else {\n callback = call;\n }\n if (typeof callback === 'function') {\n const params: unknown[] = [];\n const paramsOption = options.params;\n options.params = params;\n if (typeof paramsOption === 'string' && paramsOption.length) {\n if (paramsOption[0] === '[') {\n params.push(...(parseVal(paramsOption) as unknown[]));\n } else {\n params.push(...paramsOption.split(', ').map(x => {\n x = x.trim();\n if (x === '$element') return $element;\n if (x === 'event') return event;\n if (x === 'options') return options;\n if (x.startsWith('$element.') || x.startsWith('event.') || x.startsWith('options.')) return runCode(x);\n return parseVal(x);\n }));\n }\n } else if (Array.isArray(paramsOption)) {\n params.push(...paramsOption);\n } else {\n params.push(paramsOption);\n }\n callback(...params);\n }\n }\n\n if (options.do) {\n runCode(options.do as string);\n }\n}\n\n/**\n * Handle global event.\n * @param event The event object\n * @example\n * ```html\n * Click or changed\n * console.log('clicked or changed'), if: () => confirm('continue?')}\">Click or changed\n * Click\n * Click or changed\n * console.log('clicked')}\">Click or changed\n *\n * [data-on] is deprecated\n * ```\n */\nfunction handleGlobalEvent(this: Cash, event: Event) {\n const $element = $(this);\n const type = event.type;\n const zuiOn = $element.attr('zui-on');\n if (zuiOn) {\n const [events, code] = zuiOn.split('~').map(x => x.trim());\n if (events) {\n processGlobalEvent($element, event, $.extend({\n on: events,\n }, code ? (code.startsWith('{') ? evalValue(code) : {do: code}) : getZData($element, {prefix: 'data-', evalValue: ['call', 'if', 'do']})));\n }\n }\n const zuiOnEvent = $element.attr(`zui-on-${type}`);\n if (zuiOnEvent) {\n processGlobalEvent($element, event, $.extend({\n on: type,\n }, zuiOnEvent.startsWith('{') ? evalValue(zuiOnEvent) : {do: zuiOnEvent}));\n }\n\n const dataOn = $element.attr('data-on');\n if (dataOn) {\n processGlobalEvent($element, event, getZData($element, {prefix: 'data-', evalValue: ['call', 'if', 'do']}) as GlobalEventOptions);\n }\n}\n\nexport function registerGlobalListener(events: string[]) {\n $(document).off('.zui.global').on(events.map(event => `${event}.zui.global`).join(' '), `[zui-on],${events.map(x => `[zui-on-${x}]`)},[data-on]`, handleGlobalEvent);\n}\n\nregisterGlobalListener(['click', 'change', 'inited']);\n","export type SizeSetting = number | `${number}%` | `${number}px` | `${number}/${number}` | (string & {}) | (() => SizeSetting);\n\nexport function parseSize(size: SizeSetting): [value: number, type?: 'px' | '%'] {\n if (typeof size === 'function') {\n return parseSize(size());\n }\n if (typeof size === 'number') {\n return [size];\n }\n let match = size.match(/(\\d+)(%|px)?/);\n if (match) {\n return [parseInt(match[1]), match[2] as 'px' | '%'];\n }\n match = size.match(/(\\d+)\\/(\\d+)/);\n if (match) {\n return [100 * parseInt(match[1]) / parseInt(match[2]), '%'];\n }\n return [NaN];\n}\n\nexport function toCssSize(size: SizeSetting | undefined | null): string | null {\n if (size === undefined || size === null) {\n return null;\n }\n const [val, unit = 'px'] = parseSize(size);\n if (Number.isNaN(val)) {\n return typeof size === 'string' ? size : null;\n }\n return `${val}${unit}`;\n}\n","export async function downloadFile(file: Blob | Response | string, fileName?: string): Promise {\n if (file instanceof Blob) {\n const link = document.createElement('a');\n link.href = window.URL.createObjectURL(file);\n if (fileName) {\n link.download = decodeURIComponent(fileName);\n }\n link.click();\n link.remove();\n return file;\n }\n if (file instanceof Response) {\n const blob = await file.blob();\n fileName = fileName || file.headers.get('Content-Disposition')?.split(';')[1]?.split('=')[1]?.replace(/\"/g, '');\n return downloadFile(blob, fileName);\n }\n const response = await fetch(file);\n return downloadFile(response);\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {$, type Cash, type Selector} from '../cash';\n\ntype EventCallback = {\n (event: any, data?: any): any;\n guid?: number;\n};\n\nexport class Bus {\n protected _$target: Cash;\n\n constructor(target: Selector) {\n this._$target = $(target);\n }\n\n on(events: Record): this;\n on(events: Record, selector: string): this;\n on(events: Record, data: any): this;\n on(events: Record, selector: string | null | undefined, data: any): this;\n on(events: string, callback: EventCallback): this;\n on(events: string, selector: string, callback: EventCallback): this;\n on(events: string, data: any, callback: EventCallback): this;\n on(events: string, selector: string | null | undefined, data: any, callback: EventCallback, _one?: boolean): this;\n on(...args: any[]): this {\n this._$target.on(...(args as Parameters));\n return this;\n }\n\n one(events: Record): this;\n one(events: Record, selector: string): this;\n one(events: Record, data: any): this;\n one(events: Record, selector: string | null | undefined, data: any): this;\n one(events: string, callback: EventCallback): this;\n one(events: string, selector: string, callback: EventCallback): this;\n one(events: string, data: any, callback: EventCallback): this;\n one(events: string, selector: string | null | undefined, data: any, callback: EventCallback): this;\n one(...args: any[]): this {\n this._$target.one(...(args as Parameters));\n return this;\n }\n\n off(): this;\n off(events: string): this;\n off(events: Record): this;\n off(events: string, callback: EventCallback): this;\n off(events: string, selector: string, callback: EventCallback): this;\n off(...args: any[]): this {\n this._$target.off(...(args as Parameters));\n return this;\n }\n\n trigger(event: Event | string, data?: any): this;\n trigger(...args: any[]): this {\n this._$target.trigger(...(args as Parameters));\n return this;\n }\n}\n\nexport const bus = new Bus(document);\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface CashStatic {\n bus: Bus;\n\n on(events: Record): Bus;\n on(events: Record, selector: string): Bus;\n on(events: Record, data: any): Bus;\n on(events: Record, selector: string | null | undefined, data: any): Bus;\n on(events: string, callback: EventCallback): Bus;\n on(events: string, selector: string, callback: EventCallback): Bus;\n on(events: string, data: any, callback: EventCallback): Bus;\n on(events: string, selector: string | null | undefined, data: any, callback: EventCallback, _one?: boolean): Bus;\n\n one(events: Record): Bus;\n one(events: Record, selector: string): Bus;\n one(events: Record, data: any): Bus;\n one(events: Record, selector: string | null | undefined, data: any): Bus;\n one(events: string, callback: EventCallback): Bus;\n one(events: string, selector: string, callback: EventCallback): Bus;\n one(events: string, data: any, callback: EventCallback): Bus;\n one(events: string, selector: string | null | undefined, data: any, callback: EventCallback): Bus;\n\n off(): Bus;\n off(events: string): Bus;\n off(events: Record): Bus;\n off(events: string, callback: EventCallback): Bus;\n off(events: string, selector: string, callback: EventCallback): Bus;\n\n trigger(event: Event | string, data?: any): Bus;\n }\n}\n\n$.bus = bus;\n$.on = bus.on.bind(bus);\n$.one = bus.one.bind(bus);\n$.off = bus.off.bind(bus);\n$.trigger = bus.trigger.bind(bus);\n","var t=[\"Shift\",\"Meta\",\"Alt\",\"Control\"],e=\"object\"==typeof navigator?navigator.platform:\"\",n=/Mac|iPod|iPhone|iPad/.test(e),r=n?\"Meta\":\"Control\",o=\"Win32\"===e?[\"Control\",\"Alt\"]:n?[\"Alt\"]:[];function i(t,e){return\"function\"==typeof t.getModifierState&&(t.getModifierState(e)||o.includes(e)&&t.getModifierState(\"AltGraph\"))}function a(t){return t.trim().split(\" \").map(function(t){var e=t.split(/\\b\\+/),n=e.pop();return[e=e.map(function(t){return\"$mod\"===t?r:t}),n]})}function u(e,n){var r;void 0===n&&(n={});var o=null!=(r=n.timeout)?r:1e3,u=Object.keys(e).map(function(t){return[a(t),e[t]]}),c=new Map,f=null;return function(e){e instanceof KeyboardEvent&&(u.forEach(function(n){var r=n[0],o=n[1],a=c.get(r)||r;!function(e,n){return!(n[1].toUpperCase()!==e.key.toUpperCase()&&n[1]!==e.code||n[0].find(function(t){return!i(e,t)})||t.find(function(t){return!n[0].includes(t)&&n[1]!==t&&i(e,t)}))}(e,a[0])?i(e,e.key)||c.delete(r):a.length>1?c.set(r,a.slice(1)):(c.delete(r),o(e))}),f&&clearTimeout(f),f=setTimeout(c.clear.bind(c),o))}}function c(t,e,n){var r;void 0===n&&(n={});var o=null!=(r=n.event)?r:\"keydown\",i=u(e,n);return t.addEventListener(o,i),function(){t.removeEventListener(o,i)}}export{u as createKeybindingsHandler,a as parseKeybinding,c as tinykeys};\n//# sourceMappingURL=tinykeys.module.js.map\n","import {tinykeys, createKeybindingsHandler, type KeyBindingMap, type KeyBindingHandlerOptions} from 'tinykeys';\nimport {$, type Selector, Cash} from '../cash';\n\nexport type HotkeysBindingOptions = KeyBindingHandlerOptions & {\n scope?: string;\n event?: 'keydown' | 'keyup' | 'keypress';\n when?: (event: KeyboardEvent) => boolean;\n};\n\nexport type HotkeysBindingMap = KeyBindingMap;\n\nexport type HotkeyBindingCallback = (event: KeyboardEvent) => void;\n\nexport type HotkeySetting = {\n keys: string | string[];\n handler: HotkeyBindingCallback;\n optional?: boolean;\n};\n\nexport type HotkeyName = string;\n\nexport type HotkeysMap = Record;\n\nexport type HotkeysSettings = boolean | Record;\n\nexport function getHotkeysMap(settings: HotkeysSettings, defaultMap: HotkeysMap = {}): HotkeysBindingMap | undefined {\n if (!settings) {\n return;\n }\n\n const map = Object.keys(defaultMap).reduce((currentMap, name) => {\n if (!defaultMap[name].optional) {\n currentMap[name] = {\n ...defaultMap[name],\n };\n }\n return currentMap;\n }, {});\n Object.keys(settings).forEach((name) => {\n const setting = (settings as Record)[name];\n if (!setting) {\n delete map[name];\n } else if (setting === true) {\n if (defaultMap[name]) {\n map[name] = {\n ...defaultMap[name],\n };\n }\n } else {\n map[name] = setting;\n }\n });\n\n return Object.keys(map).reduce((bindingMap, name) => {\n const {keys, handler} = map[name];\n if (typeof keys === 'string') {\n bindingMap[keys] = handler;\n } else {\n keys.forEach((key) => {\n bindingMap[key] = handler;\n });\n }\n return bindingMap;\n }, {});\n}\n\nexport function bindHotkeys(selector: Selector, bindingMap: HotkeysBindingMap, options?: HotkeysBindingOptions) {\n const {timeout, event = 'keydown', scope, when} = options || {};\n const handler = createKeybindingsHandler(bindingMap, {timeout});\n const namespace = `.zui.hotkeys${scope ? `.${scope}` : ''}`;\n const composingDataKey = 'zui-hotkeys-composing';\n return $(selector).on(`${event}${namespace}`, function (e: KeyboardEvent) {\n if (when && when(e) === false) {\n return;\n }\n if ($(e.target as HTMLElement).data(composingDataKey)) {\n return;\n }\n handler(e);\n }).on(`compositionstart${namespace}`, (e: Event) => {\n $(e.target as HTMLElement).data(composingDataKey, true);\n }).on(`compositionend${namespace}`, (e: Event) => {\n $(e.target as HTMLElement).removeData(composingDataKey);\n });\n}\n\nexport function unbindHotkeys(selector: Selector, scope?: string) {\n return $(selector).off(`.zui.hotkeys${scope ? `.${scope}` : ''}`);\n}\n\nexport const hotkeys = tinykeys;\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface CashStatic {\n hotkeys(bindingMap: HotkeysBindingMap, options?: HotkeysBindingOptions): void;\n\n unbindHotkeys(scope?: string): void;\n }\n\n interface Cash {\n hotkeys(bindingMap: HotkeysBindingMap, options?: HotkeysBindingOptions): Cash;\n\n unbindHotkeys(scope?: string): Cash;\n }\n}\n\n/* Extend $.fn.hotkeys(). */\n$.fn.hotkeys = function (this: Cash, bindingMap: HotkeysBindingMap, options?: HotkeysBindingOptions): Cash {\n return bindHotkeys(this, bindingMap, options);\n};\n\n/* Extend $.fn.unbindHotkeys. */\n$.fn.unbindHotkeys = function (this: Cash, scope?: string): Cash {\n return unbindHotkeys(this, scope);\n};\n\n/* Extend $.hotkeys(). */\n$.hotkeys = function (bindingMap: HotkeysBindingMap, options?: HotkeysBindingOptions): void {\n bindHotkeys(window, bindingMap, options);\n};\n\n/* Extend $.unbindHotkeys. */\n$.unbindHotkeys = function (scope?: string): void {\n unbindHotkeys(window, scope);\n};\n","import {$, Cash, type Selector} from '../cash';\n\nexport type EnterFullscreenOptions = {\n target: Selector;\n onError?: (error: Error) => void;\n onSuccess?: () => void;\n afterEnter?: (event: Event) => void;\n afterExit?: (event: Event) => void;\n};\n\nexport function getFullscreenElement() {\n return document.fullscreenElement || (document as {webkitFullscreenElement?: typeof document.fullscreenElement}).webkitFullscreenElement || (document as {mozFullScreenElement?: typeof document.fullscreenElement}).mozFullScreenElement;\n}\n\nexport async function enterFullscreen(options: Selector | EnterFullscreenOptions) {\n if (typeof options === 'string' || options instanceof Element || options instanceof $) {\n options = {target: options as Selector};\n }\n const {target, onError, onSuccess, afterExit, afterEnter} = options as EnterFullscreenOptions;\n const $target = $(target);\n const element = $target[0] as Element;\n if (!element) {\n return;\n }\n const requestMethod = element.requestFullscreen || (element as {webkitRequestFullscreen?: typeof element.requestFullscreen}).webkitRequestFullscreen || (element as {mozRequestFullScreen?: typeof element.requestFullscreen}).mozRequestFullScreen;\n if (!requestMethod) {\n onError?.call(element, new Error('[ZUI] The browser does not support full screen feature.'));\n return;\n }\n\n try {\n await requestMethod.call(element);\n onSuccess?.call(element);\n $(element).off('.zui.fullscreen');\n if (afterExit) {\n $target.on('exitFullscreen.zui.fullscreen', afterExit);\n }\n if (afterEnter) {\n $target.on('enterFullscreen.zui.fullscreen', afterEnter);\n }\n } catch (error) {\n onError?.call(element, error as Error);\n }\n\n if (!(document as {zuiBindFullscreenChange?: boolean}).zuiBindFullscreenChange) {\n (document as {zuiBindFullscreenChange?: boolean}).zuiBindFullscreenChange = true;\n $(document).on('fullscreenchange.zui webkitfullscreenchange.zui mozfullscreenchange.zui', (event) => {\n const fullscreenElement = getFullscreenElement();\n let triggerElement: Element | Document | null | undefined = fullscreenElement;\n if (fullscreenElement) {\n $(fullscreenElement).addClass('is-in-fullscreen');\n } else {\n triggerElement = $(document).find('.is-in-fullscreen')[0] || document;\n $(triggerElement).removeClass('is-in-fullscreen');\n }\n $('body').toggleClass('has-in-fullscreen', !!fullscreenElement);\n const data = {event, target: triggerElement, fullscreenElement};\n $(triggerElement).trigger(fullscreenElement ? 'enterFullscreen' : 'exitFullscreen', data).trigger('toggleFullscreen', data);\n });\n }\n}\n\nexport async function toggleFullscreen(options?: Selector | EnterFullscreenOptions | false) {\n const fullscreenElement = getFullscreenElement();\n if (options === false) {\n if (!!fullscreenElement === options) {\n return options;\n }\n }\n\n if (fullscreenElement) {\n document.exitFullscreen();\n return false;\n }\n await enterFullscreen(options);\n return true;\n}\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface Cash {\n fullscreen(this: Cash, options?: EnterFullscreenOptions | false): Promise;\n }\n\n interface CashStatic {\n getFullscreenElement: typeof getFullscreenElement;\n toggleFullscreen: typeof toggleFullscreen;\n }\n}\n\n/** Extend the $.fn.fullscreen. */\n$.fn.fullscreen = function (this: Cash, options?: EnterFullscreenOptions | false) {\n return toggleFullscreen({\n target: this,\n ...options,\n });\n};\n\n/** Extend the $.getFullscreenElement. */\n$.getFullscreenElement = getFullscreenElement;\n\n/** Extend the $.toggleFullscreen. */\n$.toggleFullscreen = toggleFullscreen;\n","import {$, Cash} from '../cash';\n\n/**\n * Check whether the element is detached from document.\n * @param element The element to check.\n * @returns Whether the element is detached from document.\n */\nexport function isElementDetached(element: Node): boolean {\n if (element.parentNode === document) {\n return false;\n }\n if (!element.parentNode) {\n return true;\n }\n return isElementDetached(element.parentNode);\n}\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface CashStatic {\n isDetached(element: Node): boolean;\n }\n\n interface Cash {\n isDetached(): boolean;\n }\n}\n\n/* Extend $.isDetached. */\n$.isDetached = isElementDetached;\n\n/* Extend as $.fn.isDisabled(). */\n$.fn.isDetached = function (this: Cash) {\n const element = this[0];\n return !element || isElementDetached(element);\n};\n","import {I18nLangMap, i18n} from '../i18n';\nimport {$} from '../cash';\nimport {nextGid} from '../helpers';\nimport {isElementDetached} from '../dom/is-detached';\n\nimport type {Cash, Element, Selector} from '../cash';\nimport type {ComponentEventArgs, ComponentEventName, ComponentOptions, ComponentEvents, ComponentEventsDefnition, ComponentToggleConfig} from './types';\n\n/**\n * The event callback for component.\n */\nexport type ComponentEventCallback> = (event: N extends keyof HTMLElementEventMap ? HTMLElementEventMap[N] : Event, args: [Component, ComponentEventArgs]) => void | false;\n\n/**\n * The component base class.\n */\nexport class Component {\n /**\n * The default options.\n */\n static DEFAULT = {};\n\n /**\n * The component name.\n * It usually equals to the class name.\n * The name must be provided in subclass.\n */\n static NAME: string;\n\n /**\n * Whether the component supports multiple instances.\n */\n static MULTI_INSTANCE = false;\n\n /**\n * The component i18n data.\n * It will be merged with global i18n data.\n */\n static i18n: I18nLangMap | undefined;\n\n /**\n * The component toggle config.\n */\n static toggle: ComponentToggleConfig | undefined;\n\n /**\n * ZUI name\n */\n static get ZUI() {\n return this.NAME.replace(/(^[A-Z]+)/, (match) => match.toLowerCase());\n }\n\n /**\n * Component data key, like \"zui.menu\"\n */\n static get KEY(): `zui.${string}` {\n return `zui.${this.NAME}`;\n }\n\n /**\n * Component namespace, like \".zui.menu\"\n */\n static get NAMESPACE(): `.zui.${string}` {\n return `.zui.${this.ZUI}`;\n }\n\n /**\n * @deprecated Use ATTR_KEY instead.\n */\n static get DATA_KEY(): `data-zui-${string}` {\n return `data-zui-${this.NAME}`;\n }\n\n /**\n * Component attribute key, like \"z-use-menu\"\n */\n static get ATTR_KEY(): `z-use-${string}` {\n return `z-use-${this.NAME}`;\n }\n\n /**\n * The component default selector.\n */\n static get SELECTOR() {\n return `[${this.DATA_KEY}]`;\n }\n\n /**\n * Access to static properties via this.constructor.\n *\n * @see https://github.com/Microsoft/TypeScript/issues/3841#issuecomment-337560146\n */\n declare ['constructor']: typeof Component;\n\n /**\n * Store the component options.\n */\n private _options?: ComponentOptions;\n\n /**\n * Store the component element.\n */\n private _element?: U;\n\n /**\n * The component global ID.\n */\n private _gid: number;\n\n /**\n * The component key.\n */\n protected _key: string | number;\n\n /**\n * The component initialized flag.\n */\n private _inited = false;\n\n /**\n * Auto destroy flag.\n */\n private _autoDestory = 0;\n\n /**\n * The component destroyed flag.\n */\n protected _destroyed = false;\n\n /**\n * The component constructor.\n *\n * @param options The component initial options.\n */\n constructor(selector: Selector, options?: Partial>) {\n const {KEY, DATA_KEY, DEFAULT, MULTI_INSTANCE, NAME, ATTR_KEY, ALL, TYPED_ALL} = this.constructor;\n\n if (!NAME) {\n throw new Error('[ZUI] The component must have a \"NAME\" static property.');\n }\n\n const $element = $(selector);\n if ($element.data(KEY) && !MULTI_INSTANCE) {\n throw new Error(`[ZUI] The component \"${NAME}\" has been initialized on element.`);\n }\n\n const element = $element[0] as U;\n const gid = nextGid();\n this._gid = gid;\n this._element = element;\n\n this._options = {...DEFAULT, ...(options?.$optionsFromDataset !== false ? $element.dataset() : {})} as ComponentOptions;\n this.setOptions(options);\n this._key = this.options.key ?? `__${gid}`;\n\n if (ALL.has(element)) {\n ALL.get(element)!.add(this);\n } else {\n ALL.set(element, new Set([this]));\n }\n\n if (TYPED_ALL.has(NAME)) {\n TYPED_ALL.get(NAME)!.add(this);\n } else {\n TYPED_ALL.set(NAME, new Set([this]));\n }\n\n $element.data(KEY, this).attr(ATTR_KEY, '').attr(DATA_KEY, `${gid}`);\n if (MULTI_INSTANCE) {\n const dataName = `${KEY}:ALL`;\n let instanceMap: Map | undefined = $element.data(dataName);\n if (!instanceMap) {\n instanceMap = new Map();\n $element.data(dataName, instanceMap);\n }\n instanceMap.set(this._key, this);\n }\n\n this.init();\n requestAnimationFrame(async () => {\n this._inited = true;\n await this.afterInit();\n this.emit('inited', this.options);\n });\n }\n\n /**\n * Get the component initialized flag.\n */\n get inited() {\n return this._inited;\n }\n\n /**\n * Get the component destroyed flag.\n */\n get destroyed() {\n return this._destroyed;\n }\n\n /**\n * Get the component element.\n */\n get element() {\n return this._element!;\n }\n\n get key() {\n return this._key;\n }\n\n /**\n * Get the component options.\n */\n get options() {\n return this._options!;\n }\n\n /**\n * Get the component global id.\n */\n get gid() {\n return this._gid;\n }\n\n /**\n * Get the component element as a jQuery like object.\n */\n get $element() {\n return $(this.element);\n }\n\n /**\n * Get the component event emitter.\n */\n get $emitter() {\n return this.$element;\n }\n\n /**\n * Get the component i18n data.\n */\n get i18nData(): (I18nLangMap | undefined)[] {\n return [this.options.i18n, this.constructor.i18n];\n }\n\n /**\n * Initialize the component.\n */\n init() {}\n\n /**\n * Do something after the component initialized.\n */\n afterInit(): void | Promise {}\n\n /**\n * Render the component.\n *\n * @param options The component options to override before render.\n */\n render(options?: Partial>, reset?: boolean) {\n this.setOptions(options, reset);\n }\n\n /**\n * Destroy the component.\n */\n destroy() {\n const {KEY, DATA_KEY, ALL, TYPED_ALL, NAME, MULTI_INSTANCE, ATTR_KEY} = this.constructor;\n const {$element, element} = this;\n\n (this.emit as ((event: string, ...args: unknown[]) => void))('destroyed');\n\n this._destroyed = true;\n\n $element\n .off(this.namespace)\n .removeData(KEY)\n .removeAttr(ATTR_KEY)\n .removeAttr(DATA_KEY);\n\n if (MULTI_INSTANCE) {\n const map = this.$element.data(`${KEY}:ALL`) as Map>;\n if (map) {\n map.delete(this._key);\n if (map.size === 0) {\n this.$element.removeData(`${KEY}:ALL`);\n } else {\n const nextInstance = map.values().next().value;\n $element.data(KEY, nextInstance).attr(DATA_KEY, nextInstance.gid);\n }\n }\n }\n\n const map = ALL.get(element);\n if (map) {\n map.delete(this);\n if (map.size === 0) {\n ALL.delete(element);\n }\n }\n\n const typedMap = TYPED_ALL.get(NAME);\n if (typedMap) {\n typedMap.delete(this);\n if (typedMap.size === 0) {\n TYPED_ALL.delete(NAME);\n }\n }\n }\n\n /**\n * Auto destroy the component when detached.\n */\n autoDestroy(delay = 100) {\n if (this._autoDestory) {\n clearTimeout(this._autoDestory);\n }\n this._autoDestory = window.setTimeout(() => {\n this._autoDestory = 0;\n if (isElementDetached(this.element)) {\n this.destroy();\n }\n }, delay);\n }\n\n /**\n * Set the component options.\n *\n * @param options The component options to set.\n * @returns The component options.\n */\n setOptions(options?: Partial>, reset?: boolean): ComponentOptions {\n if (reset) {\n this._options = {\n ...this.constructor.DEFAULT,\n ...(options?.$optionsFromDataset !== false ? this.$element.dataset() : {}),\n ...options,\n } as ComponentOptions;\n } else if (options) {\n $.extend(this._options, options);\n }\n return this._options!;\n }\n\n /**\n * Emit a component event.\n * @param event The event name.\n * @param args The event arguments.\n */\n emit>(event: N, ...args: ComponentEventArgs): Event {\n const eventObject = $.Event(event);\n (eventObject as unknown as {__src?: unknown}).__src = this;\n this.$emitter.trigger(eventObject, [this, ...args]);\n return eventObject as unknown as Event;\n }\n\n /**\n * Listen to a component event.\n *\n * @param event The event name.\n * @param callback The event callback.\n */\n on>(event: N | (string & {}), callback: ComponentEventCallback, options?: {once?: boolean}) {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const component = this;\n this.$element[options?.once ? 'one' : 'on'](this._wrapEvent(event), function (this: Component, e: N extends keyof HTMLElementEventMap ? HTMLElementEventMap[N] : Event, info: [Component, ComponentEventArgs]) {\n if (!(e as {__src?: unknown}).__src || (e as {__src?: unknown}).__src === component) {\n callback.call(this, e, info);\n }\n });\n }\n\n /**\n * Listen to a component event.\n *\n * @param event The event name.\n * @param callback The event callback.\n */\n one>(event: N, callback: ComponentEventCallback) {\n this.on(event, callback, {once: true});\n }\n\n /**\n * Stop listening to a component event.\n * @param event The event name.\n * @param callback The event callback.\n */\n off>(event: N | (string & {})) {\n this.$element.off(this._wrapEvent(event));\n }\n\n /**\n * Get the i18n text.\n *\n * @param key The i18n key.\n * @param defaultValue The default value if the key is not found.\n */\n i18n(key: string, defaultValue?: string): string;\n\n /**\n * Get the i18n text.\n *\n * @param key The i18n key.\n * @param args The i18n arguments.\n * @param defaultValue The default value if the key is not found.\n */\n i18n(key: string, args?: (string | number)[], defaultValue?: string): string;\n\n /**\n * Get the i18n text.\n *\n * @param key The i18n key.\n * @param args The i18n arguments.\n * @param defaultValue The default value if the key is not found.\n */\n i18n(key: string, args?: Record, defaultValue?: string): string;\n\n /**\n * Get the i18n text.\n *\n * @param key The i18n key.\n * @param args The i18n arguments or the default value.\n * @param defaultValue The default value if the key is not found.\n * @returns The i18n text.\n */\n i18n(key: string, args?: string | (string | number)[] | Record, defaultValue?: string): string {\n const {i18nData} = this;\n return i18n(i18nData, key, args, defaultValue, this.options.lang, this.constructor.NAME)\n ?? i18n(i18nData, key, args, defaultValue, this.options.lang)\n ?? `{i18n:${key}}`;\n }\n\n /**\n * Get event namespace.\n * @returns Event namespace.\n */\n get namespace(): `.zui.${string}` {\n return `${this.constructor.NAMESPACE}.${this._key}`;\n }\n\n /**\n * Wrap event names with component namespace.\n *\n * @param names The event names.\n * @returns The wrapped event names.\n */\n protected _wrapEvent(names: string) {\n return names.split(' ').map(name => name.includes('.') ? name : `${name}${this.namespace}`).join(' ');\n }\n\n static ALL = new Map>();\n\n static TYPED_ALL = new Map>();\n\n /**\n * Get the component instance of the given element.\n *\n * @param this Current component constructor.\n * @param selector The component element selector.\n * @returns The component instance.\n */\n static get>(this: T, selector: Selector, key?: string | number): InstanceType | undefined {\n const $element = $(selector);\n if (this.MULTI_INSTANCE && key !== undefined) {\n const instanceMap = $element.data(`${this.KEY}:ALL`);\n if (instanceMap) {\n return instanceMap.get(key);\n }\n return;\n }\n return $element.data(this.KEY);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n static isValid>(this: T, _instance: InstanceType): boolean {\n return true;\n }\n\n /**\n * Ensure the component instance of the given element.\n *\n * @param this Current component constructor.\n * @param selector The component element selector.\n * @param options The component options.\n * @returns The component instance.\n */\n static ensure>(this: T, selector: Selector, options?: Partial>): InstanceType {\n const instance = this.get(selector, options?.key);\n if (instance) {\n if (this.isValid(instance)) {\n if (options) {\n instance.setOptions(options);\n }\n return instance;\n } else {\n instance.destroy();\n }\n }\n return new this(selector, options) as InstanceType;\n }\n\n /**\n * Get all component instances.\n *\n * @param this Current component constructor.\n * @param selector The component element selector.\n * @returns All component instances.\n */\n static getAll>(this: T, selector?: Selector, filter?: (instance: InstanceType) => boolean): InstanceType[] {\n const {SELECTOR, ALL, TYPED_ALL} = this;\n const list: InstanceType[] = [];\n const checkInstance = (instance: Component) => {\n if (instance instanceof this && (!filter || filter(instance as InstanceType) !== false)) {\n list.push(instance as InstanceType);\n }\n };\n if (selector) {\n $(selector)\n .find(SELECTOR)\n .each((_, element) => {\n ALL.get(element)?.forEach(checkInstance);\n });\n } else if (this !== Component) {\n TYPED_ALL.get(this.NAME)?.forEach(checkInstance);\n } else {\n ALL.forEach((components) => {\n components.forEach(checkInstance);\n });\n }\n return list.sort((a, b) => a.gid - b.gid);\n }\n\n /**\n * Query the component instance.\n *\n * @param this Current component constructor.\n * @param selector The component element selector.\n * @returns The component instance.\n */\n static query>(this: T, selector?: Selector, key?: string | number, filter?: (instance: InstanceType) => boolean): InstanceType | undefined {\n if (selector === undefined) {\n return this.getAll(undefined, filter).pop();\n }\n return this.get($(selector).closest(this.SELECTOR), key);\n }\n\n /**\n * Create cash fn.method for current component.\n *\n * @param name The method name.\n */\n static defineFn(name?: string) {\n let fnName = (name || this.ZUI) as keyof Cash;\n if ($.fn[fnName]) {\n fnName = `zui${this.NAME}` as keyof Cash;\n }\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const ZUIComponent = this;\n $.fn.extend({\n [fnName](options: Partial> | string, ...args: unknown[]) {\n const initOptions = typeof options === 'object' ? options : undefined;\n const callMethod = typeof options === 'string' ? options : undefined;\n let callResult: unknown;\n this.each((_: number, element: Element) => {\n let instance = ZUIComponent.get(element);\n if (instance) {\n if (initOptions) {\n instance.render(initOptions);\n }\n } else {\n instance = new ZUIComponent(element, initOptions);\n }\n if (callMethod) {\n let method: ((...args: unknown[]) => void) = (instance as unknown as Record void>)[callMethod];\n let callThis: unknown = instance;\n if (method === undefined) {\n callThis = (instance as unknown as {$: Record void>}).$;\n method = (callThis as Record void>)[callMethod as string];\n }\n if (typeof method === 'function') {\n callResult = method.call(callThis, ...args);\n } else {\n callResult = method;\n }\n }\n });\n return callResult !== undefined ? callResult : this;\n },\n });\n }\n\n static map = new Map();\n\n static toggleMap = new Map();\n\n static register(ComponentClass?: typeof Component, name?: string) {\n ComponentClass = ComponentClass || this;\n name = (name ?? ComponentClass.NAME).toLowerCase();\n this.map.set(name, ComponentClass);\n\n const toggleName = ComponentClass.toggle?.name?.toLowerCase();\n if (toggleName && toggleName !== name) {\n this.toggleMap.set(toggleName, ComponentClass);\n }\n }\n}\n","import {$, Cash} from '../cash';\nimport {type GetLibOptions} from '../dom';\nimport {evalValue} from '../helpers';\nimport {storeData, takeData} from '../helpers/data';\nimport {getZData} from '../helpers/z';\nimport {Component} from './component';\n\nimport type {ComponentOptions} from './types';\n\nexport type ComponentClass = typeof Component;\n\nexport type ComponentCreateOptions = ComponentOptions & {\n $update?: boolean | 'reset';\n $reset?: boolean;\n};\n\nexport type ZUIInitOptions = {\n update?: boolean | 'reset';\n beforeCreate?: BeforeCreateCallback;\n onCreate?: OnCreateCallback;\n};\n\nexport function getComponent(name: string): ComponentClass | undefined {\n return Component.map.get(name.toLowerCase());\n}\n\nexport function create(name: string, element: HTMLElement, options: ComponentCreateOptions = {}) {\n let TheComponentClass = getComponent(name);\n if (!TheComponentClass) {\n TheComponentClass = initGlobalComponents(name);\n }\n if (!TheComponentClass) {\n return null;\n }\n const {$update, ...componentOptions} = options;\n if (!TheComponentClass.MULTI_INSTANCE) {\n const component = TheComponentClass.get(element);\n if (component) {\n if ($update) {\n component.render(componentOptions, $update === 'reset');\n }\n return component;\n }\n }\n return new TheComponentClass(element, componentOptions);\n}\n\nfunction createInAnimationFrame(name: string, element: HTMLElement, options: ComponentCreateOptions = {}) {\n requestAnimationFrame(() => create(name, element, options));\n}\n\nexport function registerComponent(component: ComponentClass, name?: string) {\n Component.register(component, name);\n}\n\nexport function initGlobalComponents(name?: string): ComponentClass | undefined {\n const {zui} = window as unknown as {zui: Record};\n if (!zui) {\n return;\n }\n name = name?.toLowerCase();\n for (const n in zui) {\n const isMatch = n.toLowerCase() === name;\n if (name && !isMatch) {\n continue;\n }\n const TheComponentClass = zui[n];\n if (typeof TheComponentClass !== 'function' || !TheComponentClass.NAME || !TheComponentClass.ZUI) {\n continue;\n }\n if (!Component.map.has(n.toLowerCase())) {\n registerComponent(TheComponentClass);\n }\n if (isMatch) {\n return TheComponentClass;\n }\n }\n}\n\nexport function defineFn(name?: string) {\n if (name) {\n getComponent(name)?.defineFn();\n } else if (!(window as unknown as {_zuiDefined: Record})._zuiDefined) {\n initGlobalComponents();\n Component.map.forEach((TheComponentClass) => {\n TheComponentClass.defineFn();\n });\n Object.assign(window, {_zuiDefined: true});\n }\n}\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface Cash {\n zuiInit(this: Cash, options?: ZUIInitOptions): Cash;\n zui(this: Cash, name?: string, key?: string | number | true): ComponentClass | ComponentClass[] | Record | undefined;\n zuiCall(this: Cash, method: string, args?: unknown[]): Cash;\n }\n}\n\nexport type BeforeCreateCallback = (element: HTMLElement) => boolean | void;\n\nexport type OnCreateCallback = (name: string, options: Record) => false | Record | void;\n\n/**\n * Create zui component instance from elements which match [zui-create], [data-zui], [data-zui] is deprecated, use [zui-create] instead.\n * 为匹配 [zui-create], [data-zui] 的元素创建 zui 组件实例,[data-zui] 被弃用,优先使用 [zui-create]。\n *\n * @param element - The element to create zui components. 要创建 zui 组件的元素。\n * @param options - The options. 选项。\n *\n * @example\n * ```html\n *

    \n * \n * Create multiple components\n *\n *
    Deprecated usage
    \n * ```\n */\nfunction initCreators(element: HTMLElement, options: ZUIInitOptions = {}): void {\n const $element = $(element);\n let createNames = $element.attr('zui-create');\n const {update: $update, onCreate} = options;\n const createInstance = (name: string, createOptions?: Record) => {\n createOptions = {\n $update,\n $optionsFromDataset: false,\n ...createOptions,\n };\n if (onCreate) {\n const newCreateOptions = onCreate(name, createOptions);\n if (newCreateOptions === false) {\n return;\n }\n if (newCreateOptions) {\n createOptions = newCreateOptions;\n }\n }\n const $lib = createOptions.$lib as (GetLibOptions | undefined);\n if ($lib) {\n delete createOptions.$lib;\n $.getLib($lib).then(() => create(name, element, createOptions));\n return;\n }\n createInAnimationFrame(name, element, createOptions);\n };\n if (typeof createNames === 'string') {\n createNames = createNames.trim();\n const names = createNames.length ? createNames.split(',').map((name) => name.trim()) : [];\n const createOptionsMap = getZData(element, {prefix: 'zui-create-', evalValue: true})!;\n const createOptionsNames = Object.keys(createOptionsMap);\n if (!createOptionsNames.length && names.length === 1) {\n createInstance(names[0], $element.dataset());\n } else {\n const initedNames = new Set();\n [...names, ...createOptionsNames].forEach(name => {\n if (initedNames.has(name)) {\n return;\n }\n const createOptions = createOptionsMap[name] as ComponentCreateOptions | undefined;\n createInstance(name, createOptions);\n delete createOptionsMap[name];\n initedNames.add(name);\n });\n }\n } else {\n const initOptions = $element.dataset();\n const name = initOptions?.zui as string;\n if (!name) {\n return;\n }\n console.warn('[ZUI] create component instance with [data-zui] is deprecated, use [zui-create] instead.', {element, options});\n delete initOptions!.zui;\n createInstance(name, initOptions);\n }\n}\n\n/**\n * Bind toggle events.\n */\nfunction bindToggleEvents() {\n $(document).on('click.zui.toggle mouseenter.zui.toggle', '[data-toggle],[zui-toggle]', function (this: HTMLElement, event) {\n const $this = $(this);\n const toggleName = ($this.dataset('toggle') || $this.attr('zui-toggle')) as string;\n if (!toggleName) {\n return;\n }\n const TheComponentClass = Component.toggleMap.get(toggleName) || getComponent(toggleName);\n const toggleConfig = TheComponentClass?.toggle;\n if (!toggleConfig) {\n return;\n }\n\n const {trigger = 'click', skip = '[disabled],.disabled', check} = toggleConfig;\n const eventTriggerType = event.type === 'mouseover' ? 'hover' : 'click';\n if (!trigger.includes(eventTriggerType) || (check && !check.call(TheComponentClass, this, eventTriggerType, event)) || (skip && $this.is(skip))) {\n return;\n }\n\n const {onGet, onCreate, setOptions = true, getOptions, prevent = true, handler, onToggle, convertHref} = toggleConfig;\n let options = $this.dataset() as Record;\n const toggleOptions = $this.attr(`zui-toggle-${toggleName}`);\n if (toggleOptions) {\n options = $.extend(options, evalValue(toggleOptions));\n }\n if (convertHref && $this.is('a')) {\n const href = $this.attr('href');\n if (href) {\n const hrefMap = convertHref === true ? {selector: 'target', url: 'url'} : convertHref;\n if ('#.'.includes(href[0])) {\n if (hrefMap.selector && options[hrefMap.selector] === undefined) {\n options[hrefMap.selector] = href;\n }\n } else if (hrefMap.url && options[hrefMap.url] === undefined) {\n options[hrefMap.url] = href;\n }\n }\n }\n if (getOptions) {\n options = getOptions.call(TheComponentClass, this, options, event);\n }\n\n if (handler) {\n handler.call(TheComponentClass, this, options, eventTriggerType, event);\n if (prevent) {\n event.preventDefault();\n }\n return;\n }\n\n let component = onGet ? onGet.call(TheComponentClass, this) : TheComponentClass.get(this);\n if (!component) {\n const newComponent = onCreate ? onCreate.call(TheComponentClass, this, event, options) : (new TheComponentClass(this, options));\n if (!newComponent) {\n return;\n }\n component = newComponent;\n } else if (setOptions) {\n component.setOptions(options);\n }\n\n if (onToggle) {\n if (onToggle.call(TheComponentClass, component, this, event) === false) {\n return;\n }\n } else {\n const {shown, show, hide, toggle: toggleFunc} = component as unknown as {\n shown?: boolean,\n show?: () => void,\n hide?: () => void,\n toggle?: () => void,\n };\n\n let func: (() => void) | undefined;\n if (toggleFunc) {\n func = toggleFunc;\n } else if (show && hide) {\n if (shown) {\n func = hide;\n } else {\n func = show;\n }\n } else if (show) {\n func = show;\n }\n if (func) {\n func.call(component);\n } else {\n return;\n }\n }\n\n if (prevent) {\n event.preventDefault();\n }\n });\n}\n\nfunction getComponentsOnElement(element: HTMLElement, forEach?: (component: Component, dataKey: string) => void | boolean): Component[] {\n const data = takeData(element) as Record;\n const components: Component[] = [];\n Object.keys(data).forEach((dataKey) => {\n if (!dataKey.startsWith('zui.')) {\n return;\n }\n const component = data[dataKey] as Component;\n if (forEach?.(component, dataKey) === false) {\n return;\n }\n components.push(data[dataKey] as Component);\n });\n return components;\n}\n\nlet checkComponentsTimer = 0;\n\nfunction checkComponents(delay = 100) {\n if (checkComponentsTimer) {\n clearTimeout(checkComponentsTimer);\n }\n if (delay) {\n checkComponentsTimer = window.setTimeout(() => checkComponents(0), delay);\n return;\n }\n checkComponentsTimer = 0;\n Component.ALL.forEach((components) => {\n components.forEach((component) => component.autoDestroy());\n });\n}\n\nfunction autoDestroyComponents() {\n if (takeData(document.body, '_autoDestoryMob')) {\n return;\n }\n const mob = new MutationObserver((mutations) => {\n let hasRemovedNodes = false;\n for (const mutation of mutations) {\n if (mutation.removedNodes.length) {\n hasRemovedNodes = true;\n break;\n }\n }\n\n if (hasRemovedNodes) {\n checkComponents();\n }\n });\n mob.observe(document.body, {childList: true, subtree: true});\n storeData(document.body, '_autoDestoryMob', mob);\n}\n\n/** Define the $.fn.zuiInit method. */\n$.fn.zuiInit = function (this: Cash, options?: ZUIInitOptions) {\n this.find('[zui-create],[data-zui]').each(function () {\n if (options?.beforeCreate?.(this) === false) {\n return;\n }\n initCreators(this, options);\n });\n this.find('[zui-init]').each(function () {\n if (this.hasAttribute('z-zui-inited')) {\n return;\n }\n this.setAttribute('z-zui-inited', '');\n $.runJS(this.getAttribute('zui-init')!, ['$element', $(this)]);\n });\n this.find('.hide-before-init').removeClass('invisible hidden opacity-0');\n this.find('.scroll-into-view').scrollIntoView();\n this.find('[data-on=\"inited\"],[zui-on-inited]').each((_, ele) => {\n const $ele = $(ele);\n if (!$ele.zui()) {\n $ele.trigger('inited');\n }\n });\n return this;\n};\n\n/** Define the $.fn.zui method. */\n$.fn.zui = function (this: Cash, name?: string | true, key?: string | number | true) {\n const element = this[0];\n if (!element) {\n return;\n }\n if (typeof name !== 'string') {\n const result: Record = {};\n let lastComponent: Component | undefined;\n getComponentsOnElement(element, (component, dataKey) => {\n result[dataKey] = component;\n if (!lastComponent || lastComponent.gid < component.gid) {\n lastComponent = result[dataKey];\n }\n });\n return name === true ? result : lastComponent;\n }\n const TheComponentClass = getComponent(name);\n if (!TheComponentClass) {\n return $(element).data(`zui.${name}`);\n }\n if (key === true) {\n return TheComponentClass.getAll(element);\n }\n return TheComponentClass.query(element, key);\n};\n\n$.fn.zuiCall = function (this: Cash, componentMethod: string, args: unknown[] = []) {\n this.each(function () {\n const parts = componentMethod.split('.');\n const name = parts.length > 1 ? parts[0] : undefined;\n const method = parts[parts.length > 1 ? 1 : 0];\n const component = $(this).zui(name) as (Component | undefined);\n const methodFunc = component?.[method as keyof Component];\n if (typeof methodFunc === 'function') {\n (methodFunc as ((...args: unknown[]) => void)).apply(component, args);\n }\n });\n return this;\n};\n\n$(() => {\n // Init zui creators and call [zui-init] code.\n $('body').zuiInit({update: true});\n\n // Bind toggle events.\n bindToggleEvents();\n\n // Auto destroy components when detached.\n autoDestroyComponents();\n});\n","import {Component} from '../component';\n\nexport type StickyOptions = {\n side?: 'top' | 'bottom';\n offset?: number;\n zIndex?: number;\n pinnedClass?: string;\n targets?: string;\n scrollContainer?: string;\n};\n\nexport class Sticky extends Component {\n static NAME = 'Sticky';\n\n protected declare _ob: IntersectionObserver;\n\n protected declare _container: HTMLElement;\n\n protected declare _scrollListener: () => void;\n\n protected declare _raf: number;\n\n init() {\n const {offset = 1, side, zIndex, pinnedClass = 'is-pinned', targets, scrollContainer} = this.options;\n const {$element} = this;\n const $targets = targets ? $element.find(targets) : $element;\n $targets.css({position: 'sticky', zIndex});\n if (side) $targets.css(side, -offset);\n\n if (scrollContainer) {\n const container = $element.closest(scrollContainer)[0] as HTMLElement;\n if (container) {\n const listener = () => {\n if (this._raf) {\n cancelAnimationFrame(this._raf);\n }\n this._raf = requestAnimationFrame(() => {\n this._raf = 0;\n if (container.scrollTop === 0 && (!side || side === 'top')) {\n $targets.toggleClass(pinnedClass, false);\n return;\n }\n const containerRect = container.getBoundingClientRect();\n $targets.each((_, target) => {\n const rect = target.getBoundingClientRect();\n const pinned = rect[side || 'top'] === containerRect[side || 'top'];\n target.classList.toggle(pinnedClass, pinned);\n });\n });\n };\n this._scrollListener = listener;\n container.addEventListener('scroll', listener);\n }\n this._container = container;\n } else {\n this._ob = new IntersectionObserver(\n (entries) => {\n entries.forEach(e => {\n e.target.classList.toggle(pinnedClass, e.intersectionRatio < offset);\n });\n },\n {threshold: [1]},\n );\n\n $targets.each((_, e) => this._ob.observe(e));\n }\n }\n\n destroy() {\n this._ob?.disconnect();\n if (this._container) {\n this._container.removeEventListener('scroll', this._scrollListener);\n if (this._raf) {\n cancelAnimationFrame(this._raf);\n }\n }\n }\n}\n","import {$, Cash, Selector, Comparator} from '../cash';\n\n/**\n * Options for {@link isVisible}.\n */\ntype ISVisibleOptions = {\n /** Whether to check if the element is fully visible. */\n fullyCheck?: boolean;\n viewport?: {left: number, top: number, width: number, height: number} | DOMRectReadOnly;\n container?: Comparator;\n checkZeroSize?: boolean;\n};\n\n/**\n * Check an element whethear is visible in the current viewport.\n *\n * @param selector Element selector to check.\n * @param options Options.\n * @returns True if the element is visible.\n * @see https://stackoverflow.com/a/26039199\n */\nexport function isVisible(selector: Selector, options: ISVisibleOptions = {}): boolean {\n const element = $(selector)[0];\n if (!element) {\n return false;\n }\n\n let {viewport} = options;\n const {left, top, width, height} = element.getBoundingClientRect();\n if (options.checkZeroSize && !(width * height)) {\n return false;\n }\n if (!viewport) {\n if (options.container) {\n viewport = $(element).closest(options.container)[0]!.getBoundingClientRect();\n } else {\n const {innerHeight, innerWidth} = window;\n const {clientHeight, clientWidth} = document.documentElement;\n viewport = {left: 0, top: 0, width: innerWidth || clientWidth, height: innerHeight || clientHeight};\n }\n }\n const {left: viewportLeft, top: viewportTop, width: viewportWidth, height: viewportHeight} = viewport;\n if (options.fullyCheck) {\n return (\n (left >= viewportLeft)\n && (top >= viewportTop)\n && ((left + width) <= (viewportWidth + viewportLeft))\n && ((top + height) <= (viewportHeight + viewportTop))\n );\n }\n // http://stackoverflow.com/questions/325933/determine-whether-two-date-ranges-overlap\n const horInView = (left <= (viewportLeft + viewportWidth)) && ((left + width) >= viewportLeft);\n const vertInView = (top <= (viewportTop + viewportHeight)) && ((top + height) >= viewportTop);\n\n return vertInView && horInView;\n}\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface Cash {\n isVisible(options?: ISVisibleOptions): boolean;\n }\n}\n\n/* Extend as $.fn.isVisible() */\n$.fn.isVisible = function (this: Cash, options?: ISVisibleOptions) {\n return isVisible(this, options);\n};\n","import {$, Cash} from '../cash';\nimport {nextGid} from '../helpers';\n\nimport type {Selector} from '../cash';\n\n/**\n * Run javascript in an element.\n *\n * @param selector Element selector to run.\n * @param jsCode If not set, run all scripts in the element.\n */\nexport function runJS(selector: Selector, jsCode?: string | null, removeAfterRun = false) {\n const $element = $(selector);\n if (jsCode !== undefined) {\n if (typeof jsCode === 'string' && jsCode.length) {\n const id = `zui-runjs-${nextGid()}`;\n $element.append(``);\n if (removeAfterRun) {\n $element.find(`#${id}`).remove();\n }\n }\n return;\n }\n if ($element.is('script')) {\n const code = $element[0]?.textContent;\n if (code) {\n runJS($element.parent(), code);\n }\n return;\n }\n $element.find('script').each((_, script) => {\n runJS($element, (script as HTMLScriptElement).textContent);\n script.remove();\n });\n}\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface Cash {\n runJS(jsCode?: string): this;\n }\n\n interface CashStatic {\n runJS(jsCode: string, ...args: [name: string, value: unknown][]): T;\n }\n}\n\n/* Extend as $.runJS() */\n$.runJS = (jsCode: string, ...args: [name: string, value: unknown][]): T => {\n jsCode = jsCode.trim();\n if (!jsCode.startsWith('return ') && !jsCode.endsWith(';')) {\n jsCode = `return ${jsCode}`;\n }\n // eslint-disable-next-line @typescript-eslint/no-implied-eval\n const func = new Function(...args.map(([name]) => name), jsCode);\n return func(...args.map(([, value]) => value));\n};\n\n/* Extend as $.fn.runJS() */\n$.fn.runJS = function (this: Cash, jsCode?: string) {\n return this.each((_, ele) => {\n runJS(ele, jsCode);\n });\n};\n","import {$, Cash, Selector, Comparator} from '../cash';\nimport {isVisible} from './is-visible';\n\n/**\n * Options for {@link scrollIntoView}.\n */\ntype CashScrollIntoViewOptions = ScrollIntoViewOptions & {\n ifNeeded?: boolean;\n container?: Comparator;\n};\n\nfunction hasScrollbar(element: HTMLElement, direction: 'vert' | 'horz' | 'both' = 'both') {\n if (direction === 'vert' || direction === 'both') {\n if (element.clientHeight < element.scrollHeight) {\n return true;\n }\n }\n\n if (direction === 'horz' || direction === 'both') {\n if (element.clientWidth < element.scrollWidth) {\n return true;\n }\n }\n\n return false;\n}\n\n/**\n * Scroll into view.\n *\n * @param selector Element selector to scroll into view.\n * @param options Options.\n * @returns True if the element is visible.\n * @see https://stackoverflow.com/a/26039199\n */\nexport function scrollIntoView(selector: Selector, options?: CashScrollIntoViewOptions): Cash {\n const $element = $(selector);\n const {ifNeeded = true, container, ...other} = options || {};\n $element.each((_, ele) => {\n if (container) {\n const $container = $(ele).closest(container);\n if (!$container.length || !hasScrollbar($container[0] as HTMLElement)) {\n return;\n }\n }\n if (ifNeeded) {\n if ((ele as unknown as {scrollIntoViewIfNeeded?: (options: ScrollIntoViewOptions) => void}).scrollIntoViewIfNeeded) {\n return (ele as unknown as {scrollIntoViewIfNeeded: (options: ScrollIntoViewOptions) => void}).scrollIntoViewIfNeeded(other);\n }\n if (isVisible(ele, {viewport: ele.getBoundingClientRect()})) {\n return;\n }\n }\n ele.scrollIntoView(other);\n });\n return $element;\n}\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface Cash {\n scrollIntoView(options?: CashScrollIntoViewOptions): this;\n }\n}\n\n/* Extend as $.fn.scrollIntoView() */\n$.fn.scrollIntoView = function (this: Cash, options?: CashScrollIntoViewOptions) {\n return this.each((_, ele) => {\n scrollIntoView(ele, options);\n });\n};\n","import {$} from '../cash';\n\nexport type GetLibCallback = () => void;\n\nexport interface LoadJSOptions {\n src: string;\n id?: string;\n async?: boolean;\n defer?: boolean;\n noModule?: boolean;\n type?: string;\n integrity?: string;\n}\n\nexport interface LoadCSSOptions {\n src: string;\n id?: string;\n type?: 'css';\n}\n\nexport type GetLibOptions = {\n src: string | (string | LoadJSOptions | LoadCSSOptions)[];\n id?: string;\n async?: boolean;\n defer?: boolean;\n noModule?: boolean;\n type?: string;\n integrity?: string;\n name?: string;\n root?: string;\n css?: string;\n check?: string | boolean | (() => boolean | Promise);\n success?: GetLibCallback;\n};\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface CashStatic {\n libRoot?: string;\n\n libMap?: Record;\n\n setLibRoot(root: string): void;\n\n registerLib(name: string, options: GetLibOptions): void;\n\n getLib(options: GetLibOptions): Promise;\n getLib(src: string | string[]): Promise;\n getLib(src: string | string[], options: Omit): Promise;\n getLib(src: string | string[], callback: GetLibCallback): Promise;\n getLib(src: string | string[], options: GetLibCallback, callback?: GetLibCallback): Promise;\n getLib(optionsOrSrc: string | string[] | GetLibOptions, optionsOrCallback?: Omit | GetLibCallback, callback?: GetLibCallback): Promise;\n\n /**\n * @deprecated Use $.getLib instead.\n */\n getScript(optionsOrSrc: string | (GetLibOptions & {src: string}), optionsOrCallback?: Omit | GetLibCallback, callback?: GetLibCallback): Promise;\n }\n}\n\n/** Define the $.libRoot property. */\n$.setLibRoot = function (root: string): void {\n $.libRoot = root;\n};\n\n/** Define the $.libMap property. */\n$.registerLib = function (name: string, options: GetLibOptions): void {\n if (!$.libMap) {\n $.libMap = {};\n }\n if (!options.name && options.id) {\n options.id = `zui-lib-${name}`;\n }\n $.libMap[name] = options;\n};\n\n/**\n * Load a CSS file by append a link tag to the head.\n */\nfunction loadCSS(options: string | LoadCSSOptions): Promise {\n return new Promise((resolve, reject) => {\n if (typeof options === 'string') {\n options = {src: options};\n }\n const {src, id} = options;\n const $oldLinks = $(id ? `#${id}` : `link[href=\"${src}\"]`);\n if ($oldLinks.length) {\n resolve();\n return;\n }\n const link = document.createElement('link');\n link.onload = () => {\n resolve();\n };\n link.onerror = () => {\n reject(new Error(`[ZUI] Failed to load CSS from: ${src}`));\n };\n link.rel = 'stylesheet';\n link.href = src;\n if (id) {\n link.id = id;\n }\n $('head').append(link);\n });\n}\n\nfunction loadJS(options: string | LoadJSOptions): Promise {\n return new Promise((resolve, reject) => {\n if (typeof options === 'string') {\n options = {src: options};\n }\n const {src, id} = options;\n const $oldScripts = $(id ? `#${id}` : `script[src=\"${src}\"]`);\n if ($oldScripts.length) {\n if ($oldScripts.dataset('loaded')) {\n resolve();\n } else {\n const callbacks = $oldScripts.data('loadCalls') || [];\n callbacks.push(resolve);\n $oldScripts.data('loadCalls', callbacks);\n }\n return;\n }\n const {async = true, defer = false, noModule = false, type, integrity} = options;\n const script = document.createElement('script');\n script.async = async;\n script.defer = defer;\n script.noModule = noModule;\n if (type) {\n script.type = type;\n }\n if (integrity) {\n script.integrity = integrity;\n }\n\n script.onload = () => {\n resolve();\n const callbacks: GetLibCallback[] = $(script).dataset('loaded', true).data('loadCalls') || [];\n callbacks.forEach(x => x());\n $(script).removeData('loadCalls');\n };\n script.onerror = () => {\n reject(new Error(`[ZUI] Failed to load JS from: ${src}`));\n };\n $('head').append(script);\n script.src = src;\n });\n}\n\n/** Define the $.getLib method. */\n$.getLib = async function (optionsOrSrc: string | string[] | GetLibOptions, optionsOrCallback?: Omit | GetLibCallback, callback?: GetLibCallback): Promise {\n if (typeof optionsOrSrc === 'string') {\n optionsOrSrc = ($.libMap?.[optionsOrSrc] || {src: optionsOrSrc}) as GetLibOptions;\n }\n let options: GetLibOptions = Array.isArray(optionsOrSrc) ? {src: optionsOrSrc} : $.extend({}, optionsOrSrc);\n if (typeof optionsOrCallback === 'function') {\n options.success = optionsOrCallback;\n } else if (optionsOrCallback) {\n $.extend(options, optionsOrCallback);\n }\n if (callback) {\n options.success = callback;\n }\n\n let {src: srcList} = options;\n const {name, success} = options;\n const lib = ($.libMap && name) ? $.libMap[name] : null;\n if (lib) {\n options = $.extend({}, lib, options);\n srcList = lib.src || options.src;\n }\n if (typeof srcList === 'string') {\n srcList = [srcList];\n }\n if (!srcList || !srcList.length) {\n throw new Error('[ZUI] No src provided for $.getLib.');\n }\n\n let {check = true} = options;\n if (check === true && name) {\n check = name;\n }\n const libVarName = typeof check === 'string' ? check : name;\n const getLibVar = (): T | undefined => {\n return libVarName ? ((window as unknown as Record)[libVarName] as T) : undefined;\n };\n if (typeof check === 'string') {\n check = () => !!getLibVar();\n }\n const onSuccess = () => {\n success?.();\n return getLibVar();\n };\n if (typeof check === 'function') {\n const checkResult = await check();\n if (checkResult) {\n return onSuccess();\n }\n }\n\n const {root = $.libRoot} = options;\n for (let srcOptions of srcList) {\n if (typeof srcOptions === 'string') {\n srcOptions = {src: srcOptions};\n }\n let {src} = srcOptions;\n if (root) {\n src = `${root}${(root.endsWith('/') || src.startsWith('/')) ? '' : '/'}${src}`;\n }\n const loadOptions = {\n ...options,\n ...srcOptions,\n src,\n };\n if (srcOptions.type === 'css' || (!srcOptions.type && src.endsWith('.css'))) {\n await loadCSS(loadOptions as LoadCSSOptions);\n continue;\n }\n await loadJS(loadOptions as LoadJSOptions);\n }\n return onSuccess();\n};\n\n/** Define the $.getScript method. */\n$.getScript = $.getLib;\n","import {$, Cash, Selector} from '../cash';\n\n/**\n * Listen element resize with ResizeObserver.\n *\n * @param selector Element selector to check.\n * @returns True if the element is disabled.\n */\nexport function listenResize(selector: Selector, callback: ResizeObserverCallback): ResizeObserver {\n const $elements = $(selector);\n const observer = new ResizeObserver(callback);\n\n $elements.each((_, ele) => {\n observer.observe(ele);\n });\n\n return observer;\n}\n\n/* Declare types. */\ndeclare module 'cash-dom' {\n interface Cash {\n resize(callback: ResizeObserverCallback): ResizeObserver;\n }\n}\n\n/* Extend as $.fn.resize() */\n$.fn.resize = function (this: Cash, callback: ResizeObserverCallback) {\n return listenResize(this, callback);\n};\n","import type {ComponentType} from 'preact';\n\nexport const reactComponents: Record = {};\n\nexport function registerReactComponent

    (name: string, component?: ComponentType

    ): void;\n\nexport function registerReactComponent(componentMap: Record): void;\n\nexport function registerReactComponent(nameOrMap: string | Record, component?: ComponentType): void {\n if (typeof nameOrMap === 'object') {\n Object.keys(nameOrMap).forEach(name => {\n registerReactComponent(name, nameOrMap[name] as ComponentType);\n });\n } else if (component) {\n reactComponents[nameOrMap.toLowerCase()] = component;\n }\n}\n\nexport function getReactComponent

    (name: string): ComponentType

    | undefined {\n return reactComponents[name.toLowerCase()] as (ComponentType

    | undefined);\n}\n","import {h, Component} from 'preact';\nimport {nextGid} from '../../helpers/gid';\nimport {classes} from '../../helpers/classes';\nimport {getReactComponent} from './components';\nimport {i18n} from '../../i18n';\n\nimport type {JSX, ComponentType, RenderableProps, ComponentChildren} from 'preact';\nimport type {ClassNameLike} from '../../helpers/classes';\nimport type {HElementProps} from '../types';\nimport type {I18nLangMap} from '../../i18n';\n\n/**\n * The base HTML element.\n */\nexport class HElement

    extends Component {\n static HElement = true;\n\n static customProps: string[] = [];\n\n /**\n * The component name.\n * It usually equals to the class name.\n * The name must be provided in subclass.\n */\n static NAME: string;\n\n /**\n * The component i18n data.\n * It will be merged with global i18n data.\n */\n static i18n: I18nLangMap | undefined;\n\n /**\n * Access to static properties via this.constructor.\n *\n * @see https://github.com/Microsoft/TypeScript/issues/3841#issuecomment-337560146\n */\n declare ['constructor']: typeof HElement;\n\n protected _gid = nextGid();\n\n constructor(props: P) {\n super(props);\n\n this.state = this.getDefaultState(props);\n }\n\n get gid() {\n return this._gid;\n }\n\n get element() {\n return document.querySelector(`[z-gid-${this._gid}]`);\n }\n\n /**\n * Get the component i18n data.\n */\n get i18nData(): (I18nLangMap | undefined)[] {\n return [this.props.i18n, this.constructor.i18n];\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n getDefaultState(_props?: RenderableProps

    ): S {\n return {} as S;\n }\n\n resetState(props?: RenderableProps

    , init?: boolean) {\n const defaultState = this.getDefaultState(props);\n if (init) {\n this.state = defaultState;\n } else {\n this.changeState(defaultState);\n }\n }\n\n /**\n * Get the i18n text.\n *\n * @param key The i18n key.\n * @param defaultValue The default value if the key is not found.\n */\n i18n(key: string, defaultValue?: string): string;\n\n /**\n * Get the i18n text.\n *\n * @param key The i18n key.\n * @param args The i18n arguments.\n * @param defaultValue The default value if the key is not found.\n */\n i18n(key: string, args?: (string | number)[], defaultValue?: string): string;\n\n /**\n * Get the i18n text.\n *\n * @param key The i18n key.\n * @param args The i18n arguments.\n * @param defaultValue The default value if the key is not found.\n */\n i18n(key: string, args?: Record, defaultValue?: string): string;\n\n /**\n * Get the i18n text.\n *\n * @param key The i18n key.\n * @param args The i18n arguments or the default value.\n * @param defaultValue The default value if the key is not found.\n * @returns The i18n text.\n */\n i18n(key: string, args?: string | (string | number)[] | Record, defaultValue?: string): string {\n const {i18nData} = this;\n return i18n(i18nData, key, args, defaultValue, this.props.lang, this.constructor.NAME)\n ?? i18n(i18nData, key, args, defaultValue, this.props.lang)\n ?? `{i18n:${key}}`;\n }\n\n changeState(state: Partial | ((prevState: Readonly) => Partial), callback?: () => void): Promise {\n return new Promise(resolve => {\n this.setState(state, () => {\n callback?.();\n resolve(this.state);\n });\n });\n }\n\n protected _getClassName(props: RenderableProps

    ): ClassNameLike {\n return props.className;\n }\n\n protected _getProps(props: RenderableProps

    ): Record {\n const {className, attrs, props: componentProps, data, forwardRef, children, component, style, class: classNameAlt, ...others} = props;\n const customProps = new Set((this.constructor as typeof HElement).customProps);\n const strDangerouslySetInnerHTML = 'dangerouslySetInnerHTML';\n const other = Object.keys(others).reduce>((map, key) => {\n if (!customProps.has(key) && (key === strDangerouslySetInnerHTML || /^(on[A-Z]|data-|zui-|z-)[a-zA-Z-]+/.test(key))) {\n const val = others[key as keyof typeof others];\n map[key] = (key !== strDangerouslySetInnerHTML && val && typeof val === 'object') ? JSON.stringify(val) : val;\n }\n return map;\n }, {});\n return {ref: forwardRef, className: classes(this._getClassName(props), classNameAlt) || undefined, style, [`z-gid-${this._gid}`]: '', ...other, ...attrs, ...componentProps};\n }\n\n protected _getComponent(props: RenderableProps

    ): ComponentType | keyof JSX.IntrinsicElements {\n const {component = 'div'} = props;\n return (typeof component === 'string' ? getReactComponent(component as string) : component) || component;\n }\n\n protected _getChildren(props: RenderableProps

    ): ComponentChildren {\n return props.children;\n }\n\n protected _beforeRender(props: RenderableProps

    ): RenderableProps

    | undefined | void {\n return props;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n protected _onRender(component: ComponentType | keyof JSX.IntrinsicElements, componentProps: Record, children: ComponentChildren, _props: RenderableProps

    ): [component: ComponentType | keyof JSX.IntrinsicElements, componentProps: Record, children: ComponentChildren] | void {\n return [component, componentProps, children];\n }\n\n render(props: RenderableProps

    ) {\n props = this._beforeRender(props) || props;\n let component = this._getComponent(props);\n let children = this._getChildren(props);\n let componentProps = this._getProps(props);\n const renderResult = this._onRender(component, componentProps, children, props);\n if (renderResult) {\n [component, componentProps, children] = renderResult;\n }\n return h(component as ComponentType, componentProps, children);\n }\n}\n","import{options as r,Fragment as e}from\"preact\";export{Fragment}from\"preact\";var t=/[\"&<]/;function n(r){if(0===r.length||!1===t.test(r))return r;for(var e=0,n=0,o=\"\",f=\"\";n

    Hello world

    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 z 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

    \n * Hello world\" />\n *\n * // Render and execute script\n * alert('Hello world')\" executeScript />\n */\nexport class HtmlContent extends Component {\n protected _ref = createRef();\n\n protected _runJS() {\n if (!this.props.executeScript) {\n return;\n }\n $(this._ref.current).runJS().zuiInit();\n }\n\n componentDidMount(): void {\n this._runJS();\n }\n\n componentDidUpdate(previousProps: Readonly): void {\n if (this.props.html !== previousProps.html) {\n this._runJS();\n }\n }\n\n render(props: HtmlContentProps) {\n const {executeScript, html, ...others} = props;\n return ;\n }\n}\n","import {h as _h, isValidElement, ComponentChildren, JSX, Attributes} from 'preact';\nimport {classes, ClassNameLike} from '../../helpers';\n\n/**\n * @deprecated Use `CustomContent` instead.\n */\nexport type CustomRenderResultItem = Partial<{\n html: string;\n __html: string;\n style: JSX.CSSProperties;\n className: ClassNameLike;\n children: ComponentChildren;\n attrs: JSX.HTMLAttributes;\n [prop: string]: unknown;\n}>;\n\n/**\n * @deprecated Use `CustomContent` instead.\n */\nexport type CustomRenderResultGenerator = unknown[], THIS = unknown> = (this: THIS, result: ComponentChildren[], ...args: T) => (ComponentChildren | CustomRenderResultItem)[] | undefined | void;\n\n/**\n * @deprecated Use `CustomContent` instead.\n */\nexport type CustomRenderResult = unknown[], THIS = unknown> = CustomRenderResultGenerator | CustomRenderResultItem | ComponentChildren;\n\n/**\n * @deprecated Use `CustomContent` instead.\n */\nexport type CustomRenderResultList = unknown[], THIS = unknown> = CustomRenderResult[];\n\n/**\n * @deprecated Use `CustomContent` instead.\n */\nexport type CustomRenderProps = unknown[], THIS = unknown> = {\n tag?: string;\n className?: ClassNameLike;\n style?: JSX.CSSProperties;\n renders: CustomRenderResultList;\n generateArgs?: T;\n generators?: Record>;\n generatorThis?: THIS;\n onGenerate?: (this: THIS, generator: CustomRenderResultGenerator, result: ComponentChildren[], ...args: T) => (ComponentChildren | CustomRenderResultItem)[];\n onRenderItem?: (item: CustomRenderResultItem) => ComponentChildren;\n children?: ComponentChildren;\n};\n\n/**\n * @deprecated Use `renderCustomContent` instead.\n */\nexport function renderCustomResult(props: CustomRenderProps): [JSX.HTMLAttributes, ComponentChildren[]] {\n const {\n tag,\n className,\n style,\n renders,\n generateArgs = [],\n generatorThis,\n generators,\n onGenerate,\n onRenderItem,\n ...others\n } = props;\n const classList: ClassNameLike = [className];\n const rootStyle: JSX.CSSProperties = {...style};\n const result: ComponentChildren[] = [];\n const rawHtml: string[] = [];\n renders.forEach(render => {\n const items: (CustomRenderResultItem | ComponentChildren)[] = [];\n if (typeof render === 'string' && generators && generators[render]) {\n render = generators[render];\n }\n if (typeof render === 'function') {\n if (onGenerate) {\n items.push(...onGenerate.call(generatorThis, render as CustomRenderResultGenerator, result, ...generateArgs));\n } else {\n const renderResult = (render as CustomRenderResultGenerator).call(generatorThis, result, ...generateArgs);\n if (renderResult) {\n if (Array.isArray(renderResult)) {\n items.push(...renderResult);\n } else {\n items.push(renderResult);\n }\n }\n }\n } else {\n items.push(render);\n }\n items.forEach(item => {\n if (item === undefined || item === null) {\n return;\n }\n if (typeof item === 'object' && !isValidElement(item) && ('html' in item || '__html' in item || 'className' in item || 'style' in item || 'attrs' in item || 'children' in item)) {\n if (item.html) {\n result.push(\n
    )}>
    ,\n );\n } else if (item.__html) {\n rawHtml.push(item.__html);\n } else {\n if (item.style) {\n Object.assign(rootStyle, item.style);\n }\n if (item.className) {\n classList.push(item.className);\n }\n if (item.children) {\n result.push(item.children);\n }\n if (item.attrs) {\n Object.assign(others, item.attrs);\n }\n }\n } else {\n result.push(item);\n }\n });\n });\n\n if (rawHtml.length) {\n Object.assign(others, {dangerouslySetInnerHTML: {__html: rawHtml}});\n }\n\n return [{\n className: classes(classList),\n style: rootStyle,\n ...others,\n }, result];\n}\n\n/**\n * @deprecated Use `CustomContent` instead.\n */\nexport function CustomRender({\n tag = 'div',\n ...props\n}: CustomRenderProps) {\n const [attrs, children] = renderCustomResult(props);\n return _h(tag, attrs as Attributes, ...children);\n}\n","import {isValidElement} from 'preact';\nimport {HtmlContent} from './html-content';\nimport {HElement} from './h-element';\nimport {mergeProps} from '../../helpers';\n\nimport type {ComponentChildren, VNode} from 'preact';\nimport type {HtmlContentProps, HElementProps, CustomContentType, CustomContentGenerator, CustomContentProps} from '../types';\n\n/**\n * Render custom content.\n *\n * @param content The content to render.\n * @param generatorThis The `this` value to use when calling the generator.\n * @param generatorArgs The arguments to pass to the generator.\n * @returns The rendered content.\n */\nexport function renderCustomContent(props: CustomContentProps): ComponentChildren {\n const {content: contentSetting, generatorArgs, generatorThis, ...others} = props;\n let content = contentSetting;\n if (typeof content === 'function') {\n content = (content as CustomContentGenerator).call(generatorThis, ...(generatorArgs || []));\n }\n if (Array.isArray(content)) {\n return content.map((x) => renderCustomContent({...others, content: x, generatorThis, generatorArgs}));\n }\n if ((typeof content === 'string' || typeof content === 'number')) {\n if (Object.keys(others).length) {\n return
    {content}
    ;\n }\n return content;\n }\n if (content && typeof content === 'object' && (typeof (content as HtmlContentProps).html === 'string' || (content as HtmlContentProps).component)) {\n if ((content as HtmlContentProps).html) {\n return ;\n }\n const {children, ...contentOthers} = content as HElementProps;\n if (children) {\n content = mergeProps({children: ((Array.isArray(children) ? children : [children]) as CustomContentType[]).map((x) => renderCustomContent({...others, content: x, generatorThis, generatorArgs}))}, contentOthers);\n }\n return ;\n }\n if (isValidElement(content)) {\n return content;\n }\n if (content) {\n console.groupCollapsed('[ZUI] CustomContent format error');\n console.trace('content:', content);\n console.log('props:', props);\n console.groupEnd();\n }\n return null;\n}\n\n/**\n * Component for rendering custom content.\n *\n * @param props Custom content props.\n * @returns Custom content.\n */\nexport function CustomContent(props: CustomContentProps): VNode | null {\n const result = renderCustomContent(props);\n if (result === undefined || result === null || typeof result === 'boolean') {\n return null;\n }\n if (isValidElement(result)) {\n return result;\n }\n return <>{result};\n}\n","import {isValidElement} from 'preact';\nimport {classes} from '../../helpers/classes';\n\nimport type {ClassNameLike} from '../../helpers/classes';\nimport type {IconProps} from '../types';\n\nconst createIconClass = (icon: string) => icon.startsWith('icon-') ? icon : `icon-${icon}`;\n\n/**\n * Component for rendering icons.\n *\n * @param props Icon properties.\n * @returns Icon element.\n */\nexport function Icon(props: IconProps) {\n const {icon, className, ...others} = props;\n if (!icon) {\n return null;\n }\n if (isValidElement(icon)) {\n return icon;\n }\n const classList: ClassNameLike[] = ['icon', className as string];\n if (typeof icon === 'string') {\n classList.push(createIconClass(icon));\n } else if (typeof icon === 'object') {\n const {className: iconClass, icon: finalIcon, ...iconOthers} = icon;\n classList.push(iconClass as string, finalIcon ? createIconClass(finalIcon as string) : '');\n Object.assign(others, iconOthers);\n }\n return ;\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {createElement, render} from 'preact';\n\nimport type {VNode, RenderableProps, ContainerNode} from 'preact';\n\n/**\n * @param {import('../../src/index').RenderableProps<{ context: any }>} props\n */\nfunction ContextProvider(this: any, props: RenderableProps<{context: any}>) {\n this.getChildContext = () => props.context;\n return props.children;\n}\n\n/**\n * Portal component\n * @this {import('preact').Component}\n * @param {object | null | undefined} props\n *\n * TODO: use createRoot() instead of fake root\n */\nexport function Portal(this: any, props: any) {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const that = this;\n const container = props._container;\n\n that.componentWillUnmount = function () {\n render(null, that._temp);\n that._temp = null;\n that._container = null;\n };\n\n // When we change container we should clear our old container and\n // indicate a new mount.\n if (that._container && that._container !== container) {\n that.componentWillUnmount();\n }\n\n // When props.vnode is undefined/false/null we are dealing with some kind of\n // conditional vnode. This should not trigger a render.\n if (props._vnode) {\n if (!that._temp) {\n that._container = container;\n\n // Create a fake DOM parent node that manages a subset of `container`'s children:\n that._temp = {\n nodeType: 1,\n parentNode: container,\n childNodes: [],\n appendChild(child: VNode) {\n this.childNodes.push(child);\n that._container.appendChild(child);\n },\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n insertBefore(child: VNode, _before: VNode) {\n this.childNodes.push(child);\n that._container.appendChild(child);\n },\n removeChild(child: VNode) {\n this.childNodes.splice(this.childNodes.indexOf(child) >>> 1, 1);\n that._container.removeChild(child);\n },\n };\n }\n\n // Render our wrapping element into temp.\n render(\n createElement(ContextProvider as any, {context: that.context}, props._vnode),\n that._temp,\n );\n } else if (that._temp) {\n // When we come from a conditional render, on a mounted\n // portal we should clear the DOM.\n that.componentWillUnmount();\n }\n}\n\n/**\n * Create a `Portal` to continue rendering the vnode tree at a different DOM node\n *\n * @param {import('preact').VNode} vnode The vnode to render\n * @param {import('preact').PreactElement} container The DOM node to continue rendering in to.\n * @see https://github.com/developit/preact-portal/blob/master/src/preact-portal.js\n */\nexport function createPortal(vnode: VNode, container: ContainerNode): VNode {\n const el = createElement(Portal as any, {_vnode: vnode, _container: container}) as any;\n el.containerInfo = container;\n return el;\n}\n","import {HElement} from './h-element';\nimport {HtmlContent} from './html-content';\nimport {CustomContent} from './custom-content';\nimport {Icon} from './icon';\nimport {Portal} from './portals';\nimport {registerReactComponent} from './components';\n\nregisterReactComponent({\n HElement,\n element: HElement,\n HtmlContent,\n html: HtmlContent,\n CustomContent,\n custom: CustomContent,\n Icon,\n Portal,\n});\n","import {createRef, render, h} from 'preact';\nimport {Component as ComponentBase} from '../component';\nimport {mergeProps} from '../helpers';\n\nimport type {Component as ComponentReact, ComponentClass} from 'preact';\nimport {type I18nLangMap} from '../i18n';\nimport type {ComponentEventsDefnition} from '../component';\n\nexport class ComponentFromReact = ComponentReact, E extends ComponentEventsDefnition = {}, U extends HTMLElement = HTMLElement> extends ComponentBase {\n /**\n * The React component class.\n */\n static Component: unknown;\n\n /**\n * Whether replace the element.\n */\n static replace: boolean | keyof HTMLElementTagNameMap | (string & {}) = false;\n\n /**\n * Access to static properties via this.constructor.\n *\n * @see https://github.com/Microsoft/TypeScript/issues/3841#issuecomment-337560146\n */\n declare ['constructor']: typeof ComponentFromReact;\n\n /**\n * The React ref for component instance.\n */\n protected _ref = createRef();\n\n /**\n * The React component instance.\n */\n get $(): C | null {\n return this._ref.current;\n }\n\n /**\n * The i18n data.\n */\n get i18nData() {\n const {i18n, i18nData} = this.constructor.Component as {i18n?: I18nLangMap, i18nData?: (I18nLangMap | undefined)[]};\n if (i18nData) {\n return [...i18nData, this.constructor.i18n];\n }\n return [i18n, ...super.i18nData];\n }\n\n /**\n * Render after component init.\n */\n afterInit() {\n this.render();\n }\n\n /**\n * Destroy component.\n */\n destroy() {\n this.$?.componentWillUnmount?.();\n if (this.element) {\n this.element.innerHTML = '';\n }\n super.destroy();\n }\n\n /**\n * Render component.\n *\n * @param options new options.\n */\n render(options?: Partial, reset?: boolean) {\n const {element, $: instance} = this;\n const {Component, replace} = this.constructor;\n const {$replace = replace, $optionsFromDataset, ...userOptions} = this.setOptions(options, reset);\n const props = {\n ref: this._ref,\n ...userOptions,\n };\n if (reset) {\n (instance as {resetState?: (props?: Record, init?: boolean) => void})?.resetState?.(userOptions);\n }\n\n if ($replace && (Component as {HElement?: boolean}).HElement && (element.tagName.toLowerCase() === $replace || $replace === true)) {\n const attrs = Array.from(element.attributes).reduce>((data, attribute) => {\n const {name, value} = attribute;\n data[name === 'class' ? 'className' : name] = value;\n return data;\n }, {});\n render(\n h(Component as ComponentClass, mergeProps({component: element.tagName.toLowerCase(), attrs}, props)),\n element.parentElement!,\n element,\n );\n } else {\n render(\n h(Component as ComponentClass, props),\n element,\n );\n }\n }\n\n static renderHTML(options: Record): string {\n const tmpNode = document.createElement('div');\n render(h(this.Component as ComponentClass, options), tmpNode);\n return tmpNode.innerHTML;\n }\n}\n","import {HElement, Icon, classes} from '@zui/core';\n\nimport type {ClassNameLike} from '@zui/core';\nimport type {ButtonProps} from '../types/button-props';\nimport type {RenderableProps} from 'preact';\n\nexport class Button

    extends HElement

    {\n protected declare _isEmptyText?: boolean;\n\n protected declare _onlyCaret?: boolean;\n\n protected _beforeRender(props: RenderableProps

    ) {\n const {text, loading, loadingText, caret, icon, trailingIcon, children} = props;\n this._isEmptyText = text === undefined || text === null || (typeof text === 'string' && !text.length) || loading && !loadingText;\n this._onlyCaret = caret && this._isEmptyText && !icon && !trailingIcon && !children && !loading;\n }\n\n protected _getChildren(props: RenderableProps

    ) {\n const {loading, loadingIcon, loadingText, icon, text, children, trailingIcon, caret} = props;\n return [\n loading ? : ,\n this._isEmptyText ? null : {loading ? loadingText : text},\n loading ? null : children,\n loading ? null : ,\n loading ? null : caret ? : null,\n ];\n }\n\n protected _getClassName(props: RenderableProps

    ) {\n const {type, className, disabled, loading, active, children, square, size, rounded} = props;\n return ['btn', type, className, {\n 'btn-caret': this._onlyCaret,\n disabled: disabled || loading,\n active,\n loading,\n square: square === undefined ? (!this._onlyCaret && !children && this._isEmptyText) : square,\n }, size ? `size-${size}` : '', typeof rounded === 'string' ? `rounded-${rounded}` : {rounded}];\n }\n\n protected _getComponent(props: RenderableProps

    ) {\n return props.component || (props.url ? 'a' : 'button');\n }\n\n protected _getProps(props: RenderableProps

    ) {\n const component = this._getComponent(props);\n const {url, target, disabled, btnType = 'button', hint} = props;\n const asLink = component === 'a';\n const componentProps: Record = {\n ...super._getProps(props),\n type: asLink ? undefined : 'button',\n disabled: (!asLink && disabled) ? '' : undefined,\n title: hint,\n };\n if (btnType) {\n if (['button', 'reset', 'submit'].includes(btnType)) {\n if (component === 'button') {\n componentProps.type = btnType;\n }\n } else {\n componentProps.className = classes([componentProps.className as ClassNameLike, btnType]);\n }\n }\n if (!disabled) {\n if (url !== undefined) {\n componentProps[asLink ? 'href' : 'data-url'] = url;\n }\n if (target !== undefined) {\n componentProps[asLink ? 'target' : 'data-target'] = target;\n }\n }\n return componentProps;\n }\n}\n","import {registerReactComponent} from '@zui/core';\nimport * as components from './index';\n\nregisterReactComponent(components);\n","import {CustomContent, HElement, mergeProps} from '@zui/core';\n\nimport type {ComponentChild, ComponentChildren, ComponentType, JSX, RenderableProps} from 'preact';\nimport type {ClassNameLike} from '../../../core/src/helpers';\nimport type {CommonListProps, Item, ItemKey, ItemType} from '../types';\n\n/**\n * Generic list component.\n */\nexport class CommonList

    extends HElement {\n /**\n * Root element default name, used for class name.\n */\n static NAME = '';\n\n /**\n * Item default name, used for class name.\n */\n static ITEM_NAME = 'item';\n\n /**\n * Root element default tag name, used for DOM rendering.\n */\n static TAG = 'ul';\n\n /**\n * Item components, used for rendering for different item types.\n */\n static ItemComponents: Partial | ((this: CommonList, item: Item, props: CommonListProps) => Partial)]>> = {\n default: HElement,\n divider: [HElement, {className: 'divider'}],\n space: [HElement, (item) => {\n const {space, flex, style} = item as {space: JSX.CSSProperties['width'], flex: JSX.CSSProperties['flex'], style: JSX.CSSProperties};\n return {\n style: {width: space, height: space, flex, ...style},\n };\n }],\n };\n\n /**\n * Item default common props, used for rendering for all item types.\n */\n static defaultItemProps: Partial = {\n component: 'li',\n };\n\n /**\n * Item default props, used for rendering for different item types.\n */\n static defaultItemPropsMap: Partial>> = {};\n\n /**\n * Item default type, used for rendering for item without type.\n */\n static defaultItemType = 'item';\n\n static defaultProps: Partial = {\n itemKey: 'id',\n };\n\n /**\n * Access to static properties via this.constructor.\n *\n * @see https://github.com/Microsoft/TypeScript/issues/3841#issuecomment-337560146\n */\n declare ['constructor']: typeof CommonList;\n\n /**\n * Store the raw items.\n */\n protected declare _items: Item[];\n\n /**\n * Store the rendered items.\n */\n protected declare _renderedItems: Item[];\n\n constructor(props: P) {\n super(props);\n this._handleClick = this._handleClick.bind(this);\n }\n\n /**\n * Get the root element name, used for class name.\n */\n get name() {\n return this.props.name || this.constructor.NAME;\n }\n\n /**\n * Get the item element name, used for class name.\n */\n get itemName() {\n return this.props.itemName || this.constructor.ITEM_NAME;\n }\n\n getItems() {\n return this._items;\n }\n\n getRenderedItem(key: ItemKey) {\n return this._renderedItems.find((item) => item.key === key);\n }\n\n getItem(key: ItemKey): Item | undefined {\n return this._items[this.getItemIndex(key)];\n }\n\n getItemIndex(key: ItemKey) {\n return this._renderedItems.findIndex((item) => item.key === key);\n }\n\n getItemByIndex(index: number) {\n return this._items[index];\n }\n\n /**\n * Get the item key by index.\n *\n * @param index The rendered item index.\n * @returns The item key, if the item is not rendered, return undefined.\n */\n getKey(index: number): ItemKey | undefined {\n return this._renderedItems?.[index]?.key;\n }\n\n protected _getItemFromEvent(event: MouseEvent, target?: HTMLElement): {\n index: number;\n item: Item;\n renderedItem: Item;\n element: HTMLElement;\n event: MouseEvent;\n key: ItemKey;\n relativeTarget?: unknown;\n } | undefined {\n const element = (target || event.target as HTMLElement).closest('[z-item]') as HTMLElement;\n if (!element || !element.parentElement?.hasAttribute(`z-gid-${this._gid}`)) {\n return;\n }\n const index = +element.getAttribute('z-item')!;\n const item = this._items[index];\n if (!item) {\n return;\n }\n const key = this.getKey(index);\n if (key === undefined) {\n return;\n }\n const renderedItem = this._renderedItems[index];\n return {index, item, element, event, key, renderedItem, relativeTarget: this.props.relativeTarget};\n }\n\n protected _handleClick(event: MouseEvent) {\n const info = this._getItemFromEvent(event);\n if (!info) {\n return;\n }\n this.props.onClickItem?.call(this, info);\n info.item.onClick?.call(this, event, info);\n return info;\n }\n\n /**\n * Render the item content.\n *\n * @param props Current list properties.\n * @param item The item to render.\n * @param index The item index.\n * @returns The item rendered content.\n */\n protected _renderItem(props: RenderableProps

    , item: Item, index: number): ComponentChildren {\n const {beforeRenderItem} = props;\n if (beforeRenderItem) {\n const result = beforeRenderItem.call(this, item, index);\n if (result !== undefined) {\n item = result;\n }\n }\n\n const {type} = item;\n let {itemRender} = props;\n if (itemRender && typeof itemRender === 'object') {\n itemRender = itemRender[type!];\n }\n if (itemRender) {\n const customResult = itemRender.call(this, item, index);\n if (customResult !== undefined) {\n return ;\n }\n }\n\n const {ItemComponents} = this.constructor;\n let ItemComponent = ItemComponents[type!];\n if (!ItemComponent && item.component) {\n return ;\n }\n ItemComponent = ItemComponent || ItemComponents.default || HElement;\n if (Array.isArray(ItemComponent)) {\n let defaultItemProps = ItemComponent[1];\n if (typeof defaultItemProps === 'function') {\n defaultItemProps = defaultItemProps.call(this as CommonList, item, props);\n }\n item = mergeProps({}, defaultItemProps, item);\n ItemComponent = ItemComponent[0];\n }\n return ;\n }\n\n /**\n * Get the rendered item final properties.\n *\n * @param props Current list properties.\n * @param item The item to render.\n * @param index The item index.\n * @returns The item to rendered, if return false, the item will not be rendered.\n */\n protected _getItem(props: RenderableProps

    , item: Item, index: number): Item | false {\n if (!item) {\n return false;\n }\n const {itemProps, itemPropsMap = {}, getItem, itemKey} = props;\n const {type = this.constructor.defaultItemType} = item;\n const {name, itemName} = this;\n const {defaultItemProps = {}, defaultItemPropsMap = {}} = this.constructor;\n\n item = mergeProps(\n {type},\n defaultItemProps,\n defaultItemPropsMap[type],\n itemProps,\n itemPropsMap[type],\n {className: [name ? `${name}-${type}` : '', itemName]},\n item,\n {\n _item: item,\n _index: index,\n key: String((itemKey ? item[itemKey] : item.key) ?? (item.key ?? index)),\n onClick: undefined,\n },\n );\n\n if (getItem) {\n const result = getItem.call(this, item, index);\n if (result !== undefined) {\n return result;\n }\n }\n return item;\n }\n\n protected _getProps(props: RenderableProps

    ): Record {\n const finalProps = super._getProps(props);\n return {onClick: this._handleClick, ...finalProps};\n }\n\n /**\n * Get the list root element classname list.\n *\n * @param props Current list properties.\n * @returns The list root element classname list.\n */\n protected _getClassName(props: RenderableProps

    ): ClassNameLike {\n return [this.name, props.className];\n }\n\n /**\n * Get final rendered item list.\n *\n * @param props Current list properties.\n * @returns Item list.\n */\n protected _getItems(props: RenderableProps

    ): Item[] {\n let {items = []} = props;\n if (typeof items === 'function') {\n items = items.call(this);\n } else if (!Array.isArray(items)) {\n items = [];\n }\n return items as Item[];\n }\n\n /**\n * Render items.\n *\n * @param props props Current list properties.\n * @param items Render items.\n * @returns React render children.\n */\n protected _renderItems(props: RenderableProps

    , items: Item[]): ComponentChild[] {\n this._renderedItems = items.map((item, index) => {\n const finalItem = this._getItem(props, item, index);\n return finalItem ? finalItem : undefined;\n }) as Item[];\n return this._renderedItems.reduce((children, item, index) => {\n if (item) {\n children.push(this._renderItem(props, item, index));\n }\n return children;\n }, []);\n }\n\n /**\n * Get root element rendered children.\n *\n * @param props Current list properties.\n * @returns React render children.\n */\n protected _getChildren(props: RenderableProps

    ): ComponentChildren {\n const items = this._getItems(props);\n this._items = items;\n const children = this._renderItems(props, items);\n if (props.children) {\n children.push(props.children);\n }\n return children;\n }\n\n /**\n * Get root element rendered component type.\n *\n * @param props Current list properties.\n * @returns React component type.\n */\n protected _getComponent(props: RenderableProps

    ): ComponentType | keyof JSX.IntrinsicElements {\n return props.component || (this.constructor.TAG as keyof JSX.IntrinsicElements);\n }\n}\n","import {ComponentFromReact} from '@zui/core';\nimport {CommonList as CommonListReact} from '../component';\n\nimport type {CommonListProps} from '../types';\n\nexport class CommonList extends ComponentFromReact {\n static NAME = 'CommonList';\n\n static Component = CommonListReact;\n\n static replace = CommonListReact.TAG;\n}\n\nCommonList.register();\n","import {registerReactComponent} from '@zui/core';\nimport * as components from './index';\n\nregisterReactComponent(components);\n","export type RGBColor = [r: number, g: number, b: number];\n\nexport function hex2Rgb(hex: string): RGBColor {\n if (hex.indexOf('#') === 0) {\n hex = hex.slice(1);\n }\n // convert 3-digit hex to 6-digits.\n if (hex.length === 3) {\n hex = hex[0] + hex[0] + hex[1] + hex[1] + hex[2] + hex[2];\n }\n if (hex.length !== 6) {\n throw new Error(`Invalid HEX color \"${hex}\".`);\n }\n return [\n parseInt(hex.slice(0, 2), 16), // r\n parseInt(hex.slice(2, 4), 16), // g\n parseInt(hex.slice(4, 6), 16), // b\n ];\n}\n\nexport function isLightColor(color: string | RGBColor): boolean {\n const [r, g, b] = typeof color === 'string' ? hex2Rgb(color) : color;\n return (r * 0.299 + g * 0.587 + b * 0.114) > 186;\n}\n\nexport function contrastColor(color: string | RGBColor, options?: {dark: string, light: string}) {\n return isLightColor(color) ? (options?.dark ?? '#333333') : (options?.light ?? '#ffffff');\n}\n\nfunction clamp(value: number, max = 255): number {\n return Math.min(Math.max(value, 0), max);\n}\n\nexport function hslToRgb(h: number, s: number, l: number): RGBColor {\n h = (h % 360) / 360;\n s = clamp(s);\n l = clamp(l);\n\n const m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n const m1 = l * 2 - m2;\n\n const hue = (value: number): number => {\n value = value < 0 ? value + 1 : (value > 1 ? value - 1 : value);\n if (value * 6 < 1) {\n return m1 + (m2 - m1) * value * 6;\n } else if (value * 2 < 1) {\n return m2;\n } else if (value * 3 < 2) {\n return m1 + (m2 - m1) * (2 / 3 - value) * 6;\n } else {\n return m1;\n }\n };\n\n return [\n hue(h + 1 / 3) * 255,\n hue(h) * 255,\n hue(h - 1 / 3) * 255,\n ];\n}\n","export function getUniqueCode(str: string): number {\n let code = 0;\n if (typeof str !== 'string') str = String(str);\n if (str && str.length) {\n for (let i = 0; i < str.length; ++i) {\n code += (i + 1) * str.charCodeAt(i);\n }\n }\n return code;\n}\n","import {Component, ComponentChildren, JSX} from 'preact';\nimport {classes, Icon} from '@zui/core';\nimport {contrastColor, hslToRgb} from '@zui/helpers/src/color-helper';\nimport {getUniqueCode} from '@zui/helpers/src/string-code';\nimport {AvatarOptions} from '../types/';\n\nfunction getAvatarText(text: string, maxTextLength: number) {\n if (/^[\\u4e00-\\u9fa5\\s]+$/.test(text)) {\n return text.length <= maxTextLength ? text : text.substring(text.length - maxTextLength);\n }\n if (/^[A-Za-z\\d\\s]+$/.test(text)) {\n return text[0].toUpperCase();\n }\n return text.length <= maxTextLength ? text : text.substring(0, maxTextLength);\n}\n\nexport class Avatar extends Component {\n render() {\n const {\n className,\n style,\n size = '',\n circle,\n rounded,\n background,\n foreColor,\n icon,\n text,\n code,\n maxTextLength = 2,\n src,\n hueDistance = 43,\n saturation = 0.4,\n lightness = 0.6,\n children,\n ...others\n } = this.props;\n\n const finalClass = ['avatar', className];\n const finalStyle = {...style, background, color: foreColor};\n\n let actualSize = 32;\n if (size) {\n if (typeof size === 'number') {\n finalStyle.width = `${size}px`;\n finalStyle.height = `${size}px`;\n finalStyle.fontSize = `${Math.max(12, Math.round(size / 2))}px`;\n actualSize = size;\n } else {\n finalClass.push(`size-${size}`);\n actualSize = ({xs: 20, sm: 24, lg: 48, xl: 80})[size];\n }\n }\n if (circle) {\n finalClass.push('circle');\n } else if (rounded) {\n if (typeof rounded === 'number') {\n finalStyle.borderRadius = `${rounded}px`;\n } else {\n finalClass.push(`rounded-${rounded}`);\n }\n }\n\n let content: ComponentChildren | undefined;\n if (src) {\n finalClass.push('has-img');\n content = {text};\n } else if (icon) {\n finalClass.push('has-icon');\n content = ;\n } else if (text?.length) {\n const displayText = getAvatarText(text, maxTextLength);\n const displayTextLength = displayText.length;\n finalClass.push('has-text', `has-text-${displayTextLength}`);\n\n if (background === undefined) {\n const avatarCode = code ?? text;\n const hue = (typeof avatarCode === 'number' ? avatarCode : getUniqueCode(avatarCode)) * hueDistance % 360;\n finalStyle.background = `hsl(${hue},${saturation * 100}%,${lightness * 100}%)`;\n if (!foreColor) {\n const rgb = hslToRgb(hue, saturation, lightness);\n finalStyle.color = contrastColor(rgb);\n }\n } else if (!foreColor && background) {\n finalStyle.color = contrastColor(background);\n }\n let textStyle: JSX.CSSProperties | undefined;\n if (actualSize && actualSize < (16 * displayTextLength)) {\n textStyle = {transform: `scale(${actualSize / (16 * displayTextLength)})`, whiteSpace: 'nowrap'};\n }\n\n content =

    {displayText}
    ;\n }\n\n return (\n \n {content}\n {children}\n
    \n );\n }\n}\n","import {$, mergeProps, removeUndefinedProps} from '@zui/core';\nimport {Button} from '@zui/button/src/component';\nimport {CommonList} from '@zui/common-list/src/component';\n\nimport type {RenderableProps} from 'preact';\nimport type {ButtonProps} from '@zui/button';\nimport type {Item} from '@zui/common-list';\nimport type {BtnGroupOptions} from '../types';\n\nexport class BtnGroup extends CommonList {\n static NAME = 'btn-group';\n\n /**\n * Root element default tag name, used for DOM rendering.\n */\n static TAG = 'nav';\n\n static ItemComponents = {\n ...CommonList.ItemComponents,\n default: Button,\n };\n\n /**\n * Item default common props, used for rendering for all item types.\n */\n static defaultItemProps: Partial = {\n component: undefined,\n };\n\n protected _shareBtnProps?: Partial;\n\n protected _isBtnType({type}: Item): boolean {\n return type === 'item' || type === 'dropdown';\n }\n\n protected _getItem(props: RenderableProps, item: Item, index: number): false | Item {\n if (!item) {\n return false;\n }\n if (!item.type) {\n item = $.extend({type: (item.dropdown || item.items) ? 'dropdown' : 'item'}, item);\n }\n let itemProps = super._getItem(props, item, index);\n if (!itemProps) {\n return itemProps;\n }\n if (this._isBtnType(itemProps)) {\n itemProps = mergeProps({}, this._shareBtnProps, itemProps);\n }\n return itemProps;\n }\n\n protected _beforeRender(props: RenderableProps): void | RenderableProps | undefined {\n const {btnProps, btnType, size} = props;\n\n this._shareBtnProps = mergeProps({}, btnProps, removeUndefinedProps({btnType, size}));\n }\n}\n","import {classes, $, mergeProps} from '@zui/core';\nimport {BtnGroup} from '@zui/btn-group/src/component/btn-group';\n\nimport type {Item} from '@zui/common-list';\nimport type {ToolbarOptions, ToolbarSetting} from '../types';\nimport type {ClassNameLike} from '@zui/core/src/helpers';\nimport type {Attributes, RenderableProps} from 'preact';\n\nexport class Toolbar extends BtnGroup {\n static NAME = 'toolbar';\n\n static defaultProps: Partial = {\n btnProps: {\n btnType: 'ghost',\n },\n };\n\n static ItemComponents = {\n ...BtnGroup.ItemComponents,\n btnGroup: BtnGroup,\n 'btn-group': BtnGroup,\n };\n\n protected _getProps(props: RenderableProps): Record {\n const {gap} = props;\n const propsMap = super._getProps(props);\n if (gap) {\n if (typeof gap === 'number') {\n propsMap.className = classes(propsMap.className as ClassNameLike, `gap-${gap}`);\n } else {\n propsMap.style = $.extend(propsMap.style || {}, {gap: gap});\n }\n }\n return propsMap;\n }\n\n protected _getItem(props: RenderableProps, item: Item, index: number): false | Item {\n const itemProps = super._getItem(props, item, index);\n if (!itemProps) {\n return itemProps;\n }\n const {type} = itemProps;\n const isBtnGroup = type === 'btn-group' || type === 'btnGroup';\n if (isBtnGroup) {\n itemProps.btnProps = mergeProps({}, this._shareBtnProps, itemProps.btnProps);\n }\n if ((isBtnGroup || type === 'dropdown') && !itemProps.relativeTarget) {\n itemProps.relativeTarget = props.relativeTarget;\n }\n return itemProps;\n }\n\n static render(this: unknown, setting: ToolbarSetting | undefined, args: T, defaultProps?: Partial & Attributes, thisObject?: unknown) {\n let toolbarOptions = typeof setting === 'function' ? setting.call(thisObject ?? this, ...args) : setting;\n if (!toolbarOptions) {\n return;\n }\n if (Array.isArray(toolbarOptions)) {\n toolbarOptions = {\n items: toolbarOptions,\n };\n }\n if (defaultProps) {\n toolbarOptions = mergeProps(defaultProps as Record, toolbarOptions);\n }\n return ;\n }\n}\n","import {CustomContent, HElement} from '@zui/core';\n\nimport type {ClassNameLike} from '@zui/core';\nimport type {ComponentChildren, RenderableProps} from 'preact';\nimport type {CheckboxProps, CheckboxState} from '../types';\n\nexport class Checkbox

    extends HElement {\n protected _controlled: boolean;\n\n constructor(props: P) {\n super(props);\n this.state = {\n checked: props.checked ?? props.defaultChecked ?? false,\n };\n this._controlled = props.checked !== undefined;\n }\n\n get checked() {\n return this._controlled ? this.props.checked : this.state.checked;\n }\n\n protected _getClassName(props: RenderableProps

    ): ClassNameLike {\n const {disabled, type = 'checkbox'} = props;\n const {checked} = this;\n return [props.className, type === 'switch' ? type : `${type}-primary`, {\n disabled,\n checked: checked === true,\n indeterminate: checked === 'indeterminate',\n }];\n }\n\n protected _handleChange = (event: Event) => {\n const {onChange} = this.props;\n const checked = (event.target as HTMLInputElement).indeterminate ? 'indeterminate' : (event.target as HTMLInputElement).checked;\n if (onChange) {\n onChange.call(this, event, checked);\n }\n if (!this._controlled) {\n this.setState({checked});\n }\n };\n\n protected _getChildren(props: RenderableProps

    ): ComponentChildren {\n const {name, type, value, id, label} = props;\n const {checked} = this;\n return [\n name ? (\n \n ) : null,\n (),\n ];\n }\n}\n","import {RadioProps} from '../types';\nimport {Checkbox} from './checkbox';\n\nexport class Radio

    extends Checkbox

    {\n static defaultProps: Partial = {\n type: 'radio',\n };\n}\n","import {SwitchProps} from '../types';\nimport {Checkbox} from './checkbox';\n\nexport class Switch

    extends Checkbox

    {\n static defaultProps: Partial = {\n type: 'switch',\n };\n}\n","import {toChildArray} from 'preact';\nimport {CustomContent, HElement, Icon, classes, mergeProps} from '@zui/core';\nimport {Avatar} from '@zui/avatar/src/component';\nimport {Toolbar} from '@zui/toolbar/src/component';\nimport {Checkbox} from '@zui/checkbox/src/component';\n\nimport type {ComponentChild, ComponentChildren, ComponentType, JSX, RenderableProps} from 'preact';\nimport type {ListitemProps} from '../types';\n\nexport class Listitem

    extends HElement {\n protected _renderLeading(props: RenderableProps

    ): ComponentChild[] {\n const {\n icon,\n avatar,\n toggleIcon,\n leading,\n leadingClass,\n checked,\n checkbox,\n multiline,\n } = props;\n const contents: ComponentChild[] = [];\n if (toggleIcon) {\n contents.push();\n }\n if (checked !== undefined) {\n contents.push();\n }\n if (icon) {\n contents.push();\n }\n if (avatar) {\n const avatarProps = typeof avatar === 'function' ? avatar.call(this, props) : avatar;\n if (avatarProps) {\n avatarProps.className = classes('item-avatar', avatarProps.className);\n contents.push();\n }\n }\n const customLeading = leading ? : null;\n if (customLeading) {\n contents.push(customLeading);\n }\n if (multiline) {\n return contents.length ? [\n

    {contents}
    ,\n ] : [];\n }\n return contents;\n }\n\n protected _renderContent(props: RenderableProps

    , linkRendered?: boolean): ComponentChild[] {\n const {\n textClass,\n titleClass,\n titleAttrs,\n subtitle,\n subtitleClass,\n url,\n target,\n content,\n contentClass,\n contentAttrs,\n } = props;\n const titleAsLink = url && !linkRendered;\n const TitleComponent = titleAsLink ? 'a' : 'div';\n let {title, text} = props;\n if (title === undefined) {\n title = text;\n text = null;\n }\n return [\n

    \n {title ? : null}\n {subtitle ?
    : null}\n {text ?
    {text}
    : null}\n {content ? : null}\n
    ,\n ];\n }\n\n protected _renderTrailing(props: RenderableProps

    ): ComponentChild[] {\n const {\n multiline,\n trailing,\n trailingClass,\n trailingIcon,\n actions,\n } = props;\n const contents: ComponentChild[] = [];\n if (trailingIcon) {\n contents.push();\n }\n if (actions) {\n contents.push(Toolbar.render(actions, [props], {key: 'actions', relativeTarget: props, size: 'sm'}, this));\n }\n const customTrailing = trailing ? : null;\n if (customTrailing) {\n contents.push(customTrailing);\n }\n if (multiline) {\n return contents.length ? [\n

    {contents}{customTrailing}
    ,\n ] : [];\n }\n return contents;\n }\n\n protected _render(props: RenderableProps

    , extraAttrs?: Record): ComponentChild {\n const {\n innerComponent,\n innerClass,\n innerAttrs,\n url,\n actions,\n target,\n active,\n disabled,\n divider,\n checked,\n multiline,\n title,\n subtitle,\n hint,\n selected,\n } = props;\n const ComponentName = innerComponent || ((url && !actions) ? 'a' : 'div');\n const asLink = ComponentName === 'a';\n const attrs = mergeProps({\n key: 'item',\n title: hint,\n className: classes('listitem', innerClass, {\n active,\n disabled,\n 'has-divider': divider,\n selected,\n checked,\n multiline: multiline ?? !!(title && subtitle),\n state: asLink && !disabled,\n }),\n }, asLink ? {href: url || 'javascript:;', target} : null, extraAttrs, innerAttrs);\n return (\n \n {this._renderLeading(props)}\n {this._renderContent(props, asLink)}\n {this._renderTrailing(props)}\n \n );\n }\n\n protected _onRender(component: ComponentType | keyof JSX.IntrinsicElements, componentProps: Record, children: ComponentChildren, _props: RenderableProps

    ): void | [component: ComponentType | keyof JSX.IntrinsicElements, componentProps: Record, children: ComponentChildren] {\n const innerAttrs = Object.keys(componentProps).reduce>((attrs, key) => {\n if (key.startsWith('data-')) {\n attrs[key] = componentProps[key];\n delete componentProps[key];\n }\n return attrs;\n }, {});\n return [component, componentProps, [this._render(_props, innerAttrs), ...toChildArray(children)]];\n }\n}\n","import {$, Computed, HElement, classes, fetchData, mergeProps, removeUndefinedProps} from '@zui/core';\nimport {CommonList} from '@zui/common-list/src/component';\nimport {Listitem} from './listitem';\n\nimport type {ComponentChild, ComponentChildren, RenderableProps} from 'preact';\nimport type {ClassNameLike, CustomContentType} from '@zui/core';\nimport type {Item, ItemKey} from '@zui/common-list';\nimport type {CheckedType} from '@zui/checkbox';\nimport type {ListProps, ListState, ListItemsSetting, ListItemsFetcher} from '../types';\n\nexport class List

    extends CommonList {\n static ItemComponents: typeof CommonList.ItemComponents = {\n ...CommonList.ItemComponents,\n default: HElement,\n item: Listitem,\n heading: Listitem,\n };\n\n static NAME = 'list';\n\n protected _loadedSetting?: ListItemsSetting;\n\n protected declare _hasIcons: boolean;\n\n protected declare _hasCheckbox: boolean;\n\n protected _activeSet = new Computed>(() => {\n const map = new Set();\n const {active} = this.props;\n if (Array.isArray(active)) {\n active.forEach(x => map.add(x));\n } else if (typeof active === 'string') {\n map.add(active);\n } else if (active) {\n Object.keys(active).forEach(x => active[x] && map.add(x));\n }\n const {activeMap} = this.state;\n Object.keys(activeMap).forEach(x => activeMap[x] ? map.add(x) : map.delete(x));\n return map;\n }, () => [this.state.activeMap, this.props.active]);\n\n constructor(props: P) {\n super(props);\n this.state = {\n checked: {},\n activeMap: {},\n } as S;\n }\n\n get namespace() {\n return `.zui.${this.constructor.NAME}.list_${this.gid}`;\n }\n\n get isLazyItems() {\n const {items} = this.props;\n return items && !Array.isArray(items);\n }\n\n componentDidMount() {\n this._afterRender(true);\n this.tryLoad();\n\n if (this.props.activeOnHover && !this.props.multipleActive) {\n $(this.element).on(`mouseenter${this.namespace}`, '[z-item]', (event) => {\n const info = this._getItemFromEvent(event);\n if (info && info.renderedItem.type === 'item' && !info.renderedItem.disabled && !this.isActive(info.key)) {\n this.toggleActive(info.key, true);\n }\n });\n }\n }\n\n componentDidUpdate(): void {\n this._afterRender(false);\n this.tryLoad();\n }\n\n componentWillUnmount(): void {\n $(this.element).off(this.namespace);\n this.props.beforeDestroy?.call(this);\n }\n\n setItems(items?: Item[], error?: Error) {\n const {onLoadFail} = this.props;\n return this.changeState({\n loading: false,\n items: items || [],\n loadFailed: error ? (typeof onLoadFail === 'function' ? (onLoadFail as (error: Error) => CustomContentType | undefined).call(this, error as Error) : onLoadFail) || String(error) : undefined,\n } as S);\n }\n\n load(): void {\n const {items, onLoad} = this.props;\n this._loadedSetting = items;\n this.setState({loading: true, items: []}, async () => {\n try {\n const newItems = await fetchData(items as ListItemsFetcher, [this], {throws: true});\n this.setItems(onLoad?.call(this, newItems) || newItems);\n } catch (error) {\n this.setItems(undefined, error as Error);\n }\n });\n }\n\n tryLoad() {\n const {loading} = this.state;\n const {items} = this.props;\n if (loading || !items || Array.isArray(items) || items === this._loadedSetting) {\n return false;\n }\n this.load();\n return true;\n }\n\n isChecked(key: ItemKey, index?: number, defaultChecked: CheckedType = false): CheckedType {\n const item = (typeof index === 'number' ? this._items[index] : this.getItem(key)) || {};\n return this.state.checked[key] ?? item.checked ?? defaultChecked;\n }\n\n isAllChecked(): boolean {\n return this._renderedItems.every(({key}, index) => this.isChecked(key!, index) === true);\n }\n\n toggleAllChecked(checked?: boolean) {\n if (checked === undefined) {\n checked = !this.isAllChecked();\n }\n return this.toggleChecked(this._renderedItems.map(x => x.key!), checked);\n }\n\n async toggleChecked(keyOrChange: ItemKey | ItemKey[] | Record, checked?: boolean) {\n let change: Record;\n if (Array.isArray(keyOrChange)) {\n if (!keyOrChange.length) {\n return;\n }\n if (checked === undefined) {\n checked = !this.isChecked(keyOrChange[0]);\n }\n change = keyOrChange.reduce>((map, key) => {\n map[key] = checked!;\n return map;\n }, {});\n } else if (typeof keyOrChange === 'object') {\n change = keyOrChange;\n } else {\n const isChecked = this.isChecked(keyOrChange);\n if (checked === undefined) {\n checked = !isChecked;\n }\n change = {[keyOrChange]: checked!};\n }\n if (!Object.keys(change).length) {\n return;\n }\n\n await this.changeState(prevState => ({\n checked: {\n ...prevState.checked,\n ...change,\n },\n } as Partial), () => {\n const checkState = this.state.checked;\n this.props.onCheck?.call(this, change, Object.keys(checkState).filter(x => checkState[x] === true));\n });\n }\n\n getChecks() {\n return this._renderedItems.reduce((checks, {key}, index) => {\n if (key !== undefined && this.isChecked(key, index) === true) {\n checks.push(key);\n }\n return checks;\n }, []);\n }\n\n isActive(key: string | Item) {\n if (typeof key === 'object') {\n key = key.key!;\n }\n return this._activeSet.cache.has(key);\n }\n\n getActiveKeys() {\n return [...this._activeSet.value];\n }\n\n getActiveKey() {\n return this.getActiveKeys()[0];\n }\n\n async toggleActive(keys: string | string[], active?: boolean) {\n if (typeof keys === 'string') {\n keys = [keys];\n }\n if (!keys.length) {\n return;\n }\n active = active ?? !this.isActive(keys[0]);\n await this.changeState(prevState => {\n const activeMap = this.props.multipleActive ? (keys as string[]).reduce>((map, key) => {\n map[key] = active!;\n return map;\n }, {...prevState.activeMap}) : {[keys[0]]: active!};\n return {activeMap} as Partial;\n }, () => {\n this.props.onActive?.call(this, keys as string[], active!);\n });\n }\n\n getNextItem(key: string | undefined, condition?: (item: Item, index: number) => boolean, step = 1, items: Item[] | undefined = undefined): Item | undefined {\n items = items || this._renderedItems;\n const count = items.length;\n if (key === undefined) {\n return items[step ? 0 : count - 1];\n }\n let index = items.findIndex(x => x.key === key);\n if (index < 0 || count < 2) {\n return items[step ? 0 : count - 1];\n }\n let checkCount = 0;\n condition = condition || ((x) => x.type === 'item' && !x.disabled);\n while (checkCount < count) {\n index = (index + step + count) % count;\n const nextItem = items[index];\n if (nextItem && !nextItem.disabled && !nextItem.hidden && condition.call(this, nextItem, index)) {\n return nextItem;\n }\n checkCount++;\n }\n }\n\n getPrevItem(key: string | undefined, condition?: (item: Item, index: number) => boolean): Item | undefined {\n return this.getNextItem(key, condition, -1);\n }\n\n activeNext(condition?: (item: Item, index: number) => boolean, step = 1) {\n const nextItem = this.getNextItem(this.getActiveKey(), condition, step);\n if (nextItem) {\n this.toggleActive(nextItem.key!);\n }\n }\n\n activePrev(condition?: (item: Item, index: number) => boolean) {\n this.activeNext(condition, -1);\n }\n\n protected _afterRender(firstRender: boolean) {\n this.props.afterRender?.call(this, firstRender);\n }\n\n protected _getItems(props: RenderableProps

    ): Item[] {\n const {items} = props;\n const {items: stateItems} = this.state;\n return stateItems || (Array.isArray(items) ? items : []);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n protected _getRenderedItem(props: RenderableProps

    , renderedItem: Item, index: number): Item {\n const {divider, multiline} = props;\n renderedItem = mergeProps({}, removeUndefinedProps({\n divider,\n multiline,\n }), renderedItem);\n\n const {itemName, name} = this;\n renderedItem.innerClass = [itemName ? `${itemName}-inner${name ? ` ${name}-${renderedItem.type}-inner` : ''}` : '', renderedItem.innerClass];\n\n if (renderedItem.type === 'item') {\n const {checkbox} = props;\n if (checkbox) {\n renderedItem.checked = this.isChecked(renderedItem.key!, index, renderedItem.checked as CheckedType);\n if (typeof checkbox === 'object') {\n renderedItem.checkbox = renderedItem.checkbox ? $.extend({}, checkbox, renderedItem.checkbox) : checkbox;\n }\n if (props.selectOnChecked && renderedItem.checked === true) {\n renderedItem.selected = true;\n }\n }\n if (renderedItem.active === undefined && this.isActive(renderedItem)) {\n renderedItem.active = true;\n }\n }\n\n if (renderedItem.icon) {\n this._hasIcons = true;\n }\n if (renderedItem.checked !== undefined) {\n this._hasCheckbox = true;\n }\n\n return renderedItem;\n }\n\n protected _getItem(props: RenderableProps

    , item: Item, index: number): Item | false {\n const renderedItem = super._getItem(props, item, index);\n if (!renderedItem) {\n return renderedItem;\n }\n return this._getRenderedItem(props, renderedItem, index);\n }\n\n protected _renderItem(props: RenderableProps

    , item: Item, index: number): ComponentChildren {\n if (item.type === 'item' && this._hasIcons && item.icon === undefined) {\n item.icon = 'EMPTY';\n }\n return super._renderItem(props, item, index);\n }\n\n protected _handleClick(event: MouseEvent) {\n const info = super._handleClick(event);\n let {checkOnClick} = this.props;\n if (checkOnClick === 'any') {\n checkOnClick = '.item-checkbox,.item-content,.item-icon';\n } else if (checkOnClick === true) {\n checkOnClick = '.item-checkbox';\n }\n if (checkOnClick && !info?.renderedItem.disabled && info && (event.target as HTMLElement).closest(checkOnClick)) {\n this.toggleChecked(info.key);\n event.stopPropagation();\n return;\n }\n return info;\n }\n\n protected _getClassName(props: RenderableProps

    ): ClassNameLike {\n const {loading, loadFailed} = this.state;\n return [super._getClassName(props), loading ? 'loading' : (loadFailed ? 'is-load-failed' : '')];\n }\n\n protected _getProps(props: RenderableProps

    ): Record {\n const {className, ...others} = super._getProps(props);\n return {\n ...others,\n className: classes(className as ClassNameLike, this._hasIcons ? 'has-icons' : '', this._hasCheckbox ? 'has-checkbox' : ''),\n };\n }\n\n protected _getChildren(props: RenderableProps

    ): ComponentChildren {\n this._hasIcons = false;\n this._hasCheckbox = false;\n this._activeSet.compute();\n const children = super._getChildren(props) as ComponentChild[];\n const {loadFailed} = this.state;\n if (loadFailed) {\n children.push(loadFailed);\n }\n return children;\n }\n}\n","/** Store type. */\nexport type StoreType = 'local' | 'session';\n\nconst STR_PREFIX = '```ZUI_STR\\n';\n\n/**\n * Store for using localStorage and sessionStorage.\n */\nexport class Store {\n protected _type: StoreType;\n\n protected _name: string;\n\n protected _id: string;\n\n protected _storage: Storage;\n\n protected _altStorage?: Store;\n\n /**\n * Create new store instance.\n * @param id Store profile ID.\n * @param type Store type.\n */\n constructor(id: string = '', type: StoreType = 'local') {\n this._type = type;\n this._id = id;\n this._name = `ZUI_STORE:${this._id}`;\n this._storage = type === 'local' ? localStorage : sessionStorage;\n }\n\n /**\n * Get store type.\n */\n get type(): StoreType {\n return this._type;\n }\n\n /**\n * Get session type store instance.\n */\n get session(): Store {\n if (this.type === 'session') {\n return this;\n }\n if (!this._altStorage) {\n this._altStorage = new Store(this._id, 'session');\n }\n return this._altStorage;\n }\n\n protected _getKey(key: string): string {\n return `${this._name}:${key}`;\n }\n\n /**\n * Switch store profile.\n *\n * @param id Store profile ID.\n */\n switch(id: string) {\n this._id = id;\n this._name = `ZUI_STORE:${this._id}`;\n }\n\n /**\n * Get value from store.\n *\n * @param key Key to get\n * @returns Value of key or undefined if key is not found\n */\n get(key: string): T | undefined;\n\n /**\n * Get value from store, if key is not found, return defaultValue.\n *\n * @param key Key to get.\n * @param defaultValue Default value to return if key is not found.\n */\n get(key: string, defaultValue: T): T;\n\n /**\n * Get value from store.\n *\n * @param key Key to get.\n * @param defaultValue Default value to return if key is not found.\n * @returns Value of key or defaultValue if key is not found.\n */\n get(key: string, defaultValue?: T): T | undefined {\n const value = this._storage.getItem(this._getKey(key));\n if (typeof value === 'string') {\n if (value.startsWith(STR_PREFIX)) {\n return value.substring(STR_PREFIX.length) as T;\n }\n try {\n return JSON.parse(value);\n // eslint-disable-next-line no-empty\n } catch (_error) {}\n }\n return (value as T) ?? defaultValue;\n }\n\n /**\n * Set key-value pair in store.\n *\n * @param key Key to set.\n * @param value Value to set.\n */\n set(key: string, value: unknown): void {\n if (value === undefined || value === null) {\n return this.remove(key);\n }\n this._storage.setItem(this._getKey(key), typeof value === 'string' ? `${STR_PREFIX}${value}` : JSON.stringify(value));\n }\n\n /**\n * Remove key-value pair from store.\n *\n * @param key Key to remove.\n */\n remove(key: string): void {\n this._storage.removeItem(this._getKey(key));\n }\n\n /**\n * Iterate all key-value pairs in store.\n *\n * @param callback Callback function to call for each key-value pair in the store.\n */\n each(callback: (name: string, value: unknown) => void): void {\n for (let i = 0; i < this._storage.length; i++) {\n const key = this._storage.key(i);\n if (key?.startsWith(this._name)) {\n const value = this._storage.getItem(key);\n if (typeof value === 'string') {\n callback(key.substring(this._name.length + 1), JSON.parse(value));\n }\n }\n }\n }\n\n /**\n * Get all key values in store.\n *\n * @returns All key-value pairs in the store.\n */\n getAll(): Record {\n const result: Record = {};\n this.each((key, value) => {\n result[key] = value;\n });\n return result;\n }\n}\n","import {Store, StoreType} from './store';\n\nexport type {Store} from './store';\n\nexport const store = new Store('DEFAULT');\n\nfunction createStore(name?: string, type: StoreType = 'local') {\n return new Store(name, type);\n}\n\nObject.assign(store, {create: createStore});\n","import {Icon, classes, mergeProps, $} from '@zui/core';\nimport {store} from '@zui/store';\nimport {List} from './list';\nimport '@zui/css-icons/src/icons/caret.css';\n\nimport type {ComponentChild, ComponentChildren, RenderableProps} from 'preact';\nimport type {ClassNameLike} from '@zui/core';\nimport type {Item, ItemKey} from '@zui/common-list';\nimport type {CheckedType} from '@zui/checkbox';\nimport type {ListItemsSetting, NestedItem, NestedListProps, NestedListState} from '../types';\n\nexport type MouseEventInfo = {\n index: number;\n item: NestedItem;\n renderedItem: NestedItem;\n element: HTMLElement;\n target: HTMLElement;\n event: MouseEvent;\n key: ItemKey;\n parentKey?: ItemKey;\n hover?: boolean;\n keyPath: string;\n};\n\nexport type ItemInfo = {\n key: string;\n level: number;\n keyPath: string;\n parentKey?: string;\n parent?: ItemInfo;\n children: ItemInfo[];\n data: Item;\n};\n\nfunction forEachChild(item: ItemInfo, callback: (child: ItemInfo) => void) {\n const {children} = item;\n if (!children.length) {\n return;\n }\n children.forEach(child => {\n callback(child);\n forEachChild(child, callback);\n });\n}\n\nfunction forEachParent(item: ItemInfo, callback: (parent: ItemInfo) => void) {\n let parent = item.parent;\n while (parent) {\n callback(parent);\n parent = parent.parent;\n }\n}\n\nfunction parentKeys(keyPath: string) {\n return keyPath.split(':').reduce((keys, item, index) => {\n keys.push(index ? keys[index - 1] + ':' + item : item);\n return keys;\n }, []);\n}\n\n\nfunction reduceNestedItems(items: Item[], itemKey: string | undefined, reducer: (previousValue: T, info: ItemInfo) => T, initialValue: T, level = 0, parent?: ItemInfo): T {\n return items.reduce((currentValue, item, index) => {\n if (!item) {\n return currentValue;\n }\n const key = String((itemKey ? item[itemKey] : item.key) ?? (item.key ?? index));\n const keyPath = parent ? `${parent.keyPath}:${key}` : key;\n const itemInfo = {\n key,\n level,\n keyPath,\n parentKey: parent?.keyPath,\n parent: parent,\n data: item,\n children: [],\n };\n if (parent) {\n parent.children.push(itemInfo);\n }\n currentValue = reducer(currentValue, itemInfo);\n if (Array.isArray(item.items)) {\n return reduceNestedItems(item.items as Item[], itemKey, reducer, currentValue, level + 1, itemInfo);\n }\n return currentValue;\n }, initialValue);\n}\n\nexport class NestedList

    extends List {\n static defaultProps: Partial = {\n ...List.defaultProps,\n defaultNestedShow: false,\n level: 0,\n indent: 20,\n } as Partial;\n\n static inheritNestedProps = ['component', 'name', 'itemName', 'itemKey', 'indent', 'hover', 'divider', 'multiline', 'toggleIcons', 'nestedToggle', 'accordion', 'itemRender', 'itemProps', 'beforeRenderItem', 'onToggle', 'checkbox', 'getItem', 'checkOnClick', 'selectOnChecked', 'checkedState', 'onClickItem', 'activeOnHover', 'multipleActive', 'onActive'];\n\n protected declare _hasNestedItems: boolean;\n\n protected declare _needHandleHover: boolean;\n\n protected declare _storeID: string;\n\n protected declare _renderedItemMap: Map;\n\n protected declare _itemMap?: Map;\n\n protected declare _needInitChecks?: boolean;\n\n protected declare _hoverInfo?: {timer: number, info: MouseEventInfo};\n\n constructor(props: P) {\n super(props);\n const {defaultNestedShow, preserve, nestedShow} = props;\n $.extend(\n this.state,\n typeof defaultNestedShow === 'boolean' ? {defaultShow: defaultNestedShow, nestedShow: {}} : {nestedShow: defaultNestedShow || {}},\n nestedShow !== undefined ? {nestedShow} : null,\n );\n if (preserve && nestedShow === undefined) {\n this._storeID = `${this.constructor.NAME}:${preserve}:state`;\n const storeState = store.get(this._storeID) as NestedListState;\n if (storeState) {\n (this.state as NestedListState).nestedShow = storeState.nestedShow;\n }\n }\n\n if (!props.level) {\n const nestedState = this.state.nestedShow;\n if (nestedState) {\n Object.keys(nestedState).forEach(key => {\n if (!nestedState[key]) {\n return;\n }\n parentKeys(key).forEach(parentKey => {\n nestedState[parentKey] = true;\n });\n });\n }\n this._needInitChecks = true;\n }\n\n this._renderedItemMap = new Map();\n this._handleHover = this._handleHover.bind(this);\n this._handleClick = this._handleClick.bind(this);\n this._beforeRenderNestedItem = this._beforeRenderNestedItem.bind(this);\n this._handleNestedToggle = this._handleNestedToggle.bind(this);\n this._handleNestedCheck = this._handleNestedCheck.bind(this);\n this._preserveState = this._preserveState.bind(this);\n }\n\n get isRoot() {\n return !this.props.level;\n }\n\n get nestedShow() {\n return this.props.nestedShow ?? this.state.nestedShow ?? false;\n }\n\n get isHoverTrigger() {\n return this.props.nestedTrigger === 'hover';\n }\n\n async setItems(items?: Item[] | undefined, error?: Error | undefined) {\n if (this.isRoot) {\n this._needInitChecks = true;\n }\n const state = await super.setItems(items, error);\n if (items && this.props.parent?.checked === true) {\n this.toggleChecked(this._renderedItems.map(x => x.key!), true);\n } else if (items?.some((x) => x.checked)) {\n this._needInitChecks = true;\n this.forceUpdate();\n }\n return state;\n }\n\n getItemMap() {\n if (!this._itemMap) {\n let needCheckRenderItems = false;\n const map: Map = reduceNestedItems(this._items, this.props.itemKey, (currentMap, info) => {\n currentMap.set(info.keyPath, info);\n if (info.data.items && !Array.isArray(info.data.items)) {\n needCheckRenderItems = true;\n }\n return currentMap;\n }, new Map());\n if (needCheckRenderItems) {\n this._renderedItemMap.forEach((item, keyPath) => {\n if (map.has(keyPath)) {\n return;\n }\n map.set(keyPath, {\n key: item.key,\n level: item._level,\n keyPath,\n parentKey: `${keyPath.split(':').slice(0, -1).join(':')}`,\n children: [],\n data: item,\n } as ItemInfo);\n });\n map.forEach((info) => {\n const {parentKey} = info;\n if (!parentKey) {\n return;\n }\n const parent = map.get(parentKey);\n if (parent) {\n parent.children.push(info);\n info.parent = parent;\n }\n });\n return map;\n }\n this._itemMap = map;\n }\n return this._itemMap;\n }\n\n getRenderedItem(keyPath: string): Item | undefined {\n return this._renderedItemMap.get(keyPath);\n }\n\n getItem(keyPath: string) {\n if (this._itemMap) {\n return this._itemMap.get(keyPath)?.data;\n }\n const renderedItem = this.getRenderedItem(keyPath);\n return renderedItem ? (renderedItem._item as Item) : super.getItem(keyPath);\n }\n\n isExpanded(keyPath: string) {\n const {nestedShow} = this;\n if (typeof nestedShow === 'boolean') {\n return nestedShow;\n }\n return !!(nestedShow[keyPath] ?? this.state.defaultShow);\n }\n\n async toggle(keyPath: string, toggle?: boolean) {\n const isExpanded = this.isExpanded(keyPath);\n if (toggle === isExpanded) {\n return;\n }\n if (toggle === undefined) {\n toggle = !isExpanded;\n }\n const {nestedShow, onToggle, accordion} = this.props;\n if (onToggle && onToggle.call(this, keyPath, toggle) === false) {\n return;\n }\n if (nestedShow !== undefined) {\n return;\n }\n await this.changeState(prevState => {\n let newNestedShow: Record = {\n ...prevState.nestedShow,\n [keyPath]: toggle!,\n };\n if (toggle && accordion) {\n let parentKey = `${keyPath.split(':').slice(0, -1).join(':')}`;\n if (parentKey.length) {\n parentKey += ':';\n }\n Object.keys(newNestedShow).forEach(key => {\n if (key !== keyPath && key.startsWith(parentKey)) {\n newNestedShow[key] = false;\n }\n });\n }\n newNestedShow = toggle ? parentKeys(keyPath).reduce>((map, key) => {\n map[key] = toggle!;\n return map;\n }, newNestedShow) : newNestedShow;\n if (this.isHoverTrigger && !toggle) {\n Object.keys(newNestedShow).forEach(key => {\n if (!newNestedShow[key] || !key.startsWith(`${keyPath}:`)) {\n return;\n }\n parentKeys(keyPath).forEach(k => {\n newNestedShow[k] = true;\n });\n });\n }\n return {\n nestedShow: newNestedShow,\n } as Partial;\n }, this._preserveState);\n }\n\n toggleAll(show: boolean) {\n if (this.props.nestedShow !== undefined) {\n return;\n }\n return this.setState({nestedShow: {}, defaultShow: show}, this._preserveState);\n }\n\n getChecks() {\n return Array.from(this.getItemMap().values()).reduce((checks, {keyPath, data}) => {\n const checkState = this.state.checked[keyPath];\n if ((checkState === true || (data.checked && checkState !== false)) === true) {\n checks.push(keyPath);\n }\n return checks;\n }, []);\n }\n\n isChecked(key: ItemKey, index?: number, defaultChecked: CheckedType = false): CheckedType {\n const item = (typeof index === 'number' ? this._items[index] : this.getItem(key)) || {};\n if (this.isRoot) {\n return this.state.checked[key] ?? (item.checked as CheckedType) ?? defaultChecked;\n }\n return this.props.checkedState![`${this.props.parentKey}:${key}`] ?? (item.checked as CheckedType) ?? defaultChecked;\n }\n\n async toggleChecked(keyOrChange: ItemKey | ItemKey[] | Record, checked?: CheckedType) {\n let change: Record;\n if (Array.isArray(keyOrChange)) {\n if (!keyOrChange.length) {\n return;\n }\n if (checked === undefined) {\n checked = !this.isChecked(keyOrChange[0]);\n }\n change = keyOrChange.reduce>((map, key) => {\n map[key] = checked!;\n return map;\n }, {});\n } else if (typeof keyOrChange === 'object') {\n change = keyOrChange;\n } else {\n if (checked === undefined) {\n checked = !this.isChecked(keyOrChange);\n }\n change = {[keyOrChange]: checked!};\n }\n if (!Object.keys(change).length) {\n return;\n }\n if (this.isRoot) {\n const map = this.getItemMap();\n await this.changeState(({checked: prevChecked}) => {\n const isChecked = (item: ItemInfo) => {\n return change[item.keyPath] ?? prevChecked[item.keyPath] ?? item.data.checked ?? false;\n };\n Object.keys(change).forEach(key => {\n checked = change[key];\n const item = map.get(key);\n if (!item) {\n return;\n }\n forEachChild(item, child => {\n if (isChecked(child) !== checked) {\n change[child.keyPath] = checked!;\n }\n });\n forEachParent(item, parent => {\n const {children} = parent;\n const checkedCount = children.reduce((count, child) => {\n if (isChecked(child)) {\n count++;\n }\n return count;\n }, 0);\n\n change[parent.keyPath] = checkedCount === children.length ? true : (checkedCount ? 'indeterminate' : false);\n });\n });\n return {\n checked: {\n ...prevChecked,\n ...change,\n },\n } as Partial;\n }, () => {\n const checkState = this.state.checked;\n this.props.onCheck?.call(this, change, Object.keys(checkState).filter(x => checkState[x] === true));\n });\n return;\n }\n\n const {parentKey, onCheck} = this.props;\n const nestedChange = Object.keys(change).reduce>((map, key) => {\n map[`${parentKey !== undefined ? `${parentKey}:` : ''}${key}`] = change[key];\n return map;\n }, {});\n onCheck!.call(this, nestedChange, []);\n }\n\n getKeyPath(key: string) {\n if (this.isRoot) {\n return key;\n }\n const parentKey = this.props.parentKey!;\n if (!key.startsWith(parentKey + ':')) {\n return `${parentKey}:${key}`;\n }\n return key;\n }\n\n isActive(keyPath: string | Item) {\n if (typeof keyPath === 'object') {\n const keyOrKeyPath = (keyPath._keyPath ?? keyPath.key) as (string | undefined);\n if (keyOrKeyPath === undefined) {\n return false;\n }\n keyPath = keyOrKeyPath;\n }\n return this._activeSet.cache.has(this.getKeyPath(keyPath));\n }\n\n async toggleActive(keys: string | string[], active?: boolean) {\n if (typeof keys === 'string') {\n keys = [keys];\n }\n keys = keys.map(key => this.getKeyPath(key));\n if (this.isRoot) {\n await super.toggleActive(keys, active);\n if (this.props.toggleOnActive) {\n (keys as string[]).forEach(key => {\n if (this.isActive(key) && !this.isExpanded(key)) {\n this.toggle(key, true);\n }\n });\n }\n return;\n }\n\n this.props.onActive!.call(this, keys, active ?? !this.isActive(keys[0]));\n }\n\n activeNext(condition?: (item: Item, index: number) => boolean, step = 1) {\n const nextItem = this.getNextItem(this.getActiveKey(), condition, step);\n if (nextItem) {\n this.toggleActive(nextItem._keyPath as string);\n }\n }\n\n getNextItem(key: string | undefined, condition?: (item: Item, index: number) => boolean, step = 1, items: Item[] | undefined = undefined): Item | undefined {\n items = items || reduceNestedItems(this._items, this.props.itemKey, (list, info) => {\n if (info.data.disabled) {\n return list;\n }\n list.push({\n _keyPath: info.keyPath,\n type: 'item',\n ...info.data,\n ...this._renderedItemMap.get(info.keyPath),\n key: info.keyPath,\n });\n return list;\n }, []);\n return super.getNextItem(key, condition, step, items);\n }\n\n protected _afterRender(firstRender: boolean): void {\n super._afterRender(firstRender);\n if (this._needInitChecks) {\n const initChecks: Record = {};\n const itemMap = this.getItemMap();\n itemMap.forEach(item => {\n if (item.data.checked !== undefined) {\n initChecks[item.keyPath] = item.data.checked as CheckedType;\n }\n });\n this.toggleChecked(initChecks);\n this._needInitChecks = false;\n }\n }\n\n protected _preserveState() {\n if (this._storeID) {\n store.set(this._storeID, {nestedShow: this.state.nestedShow});\n }\n }\n\n protected _getClassName(props: RenderableProps

    ): ClassNameLike {\n return [super._getClassName(props), 'is-nested', props.level ? 'is-nested-sub' : 'is-nested-root'];\n }\n\n protected _getNestedProps(props: RenderableProps

    , items: ListItemsSetting, item: NestedItem, expanded: boolean): NestedListProps {\n const {\n parentKey,\n level = 0,\n } = props;\n const {isRoot} = this;\n return mergeProps(((this.constructor as typeof NestedList).inheritNestedProps.reduce>((propMap, key) => {\n propMap[key] = props[key as keyof P];\n return propMap;\n }, {})), {\n key: item.key,\n level: level + 1,\n className: `is-nested-${expanded ? 'expanded' : 'collapsed'}`,\n items,\n parent: item,\n parentKey: parentKey ? `${parentKey}:${item.key}` : item.key,\n nestedShow: this.nestedShow,\n defaultNestedShow: this.state.defaultShow,\n checkedState: props.checkedState || this.state.checked,\n onCheck: isRoot ? this._handleNestedCheck : props.onCheck,\n onToggle: isRoot ? this._handleNestedToggle : props.onToggle,\n beforeRenderItem: isRoot ? this._beforeRenderNestedItem : props.beforeRenderItem,\n active: isRoot ? this.getActiveKeys() : props.active,\n onActive: isRoot ? this.toggleActive.bind(this) : props.onActive,\n }, item.listProps);\n }\n\n protected _renderNestedList(props: RenderableProps

    , items: ListItemsSetting, item: NestedItem, expanded: boolean): ComponentChildren {\n if (!expanded && !props.renderCollapsedList) {\n return;\n }\n const nestedListProps = this._getNestedProps(props, items, item, expanded);\n const NestedListComponent = this.constructor as typeof NestedList;\n return ;\n }\n\n protected _renderNestedToggle(props: RenderableProps

    , isExpanded: boolean | undefined): ComponentChild {\n let toggleIcon: ComponentChild;\n let toggleClass = '';\n const {toggleIcons = {}} = props;\n if (typeof isExpanded === 'boolean') {\n toggleIcon = isExpanded ? (toggleIcons.expanded || ) : (toggleIcons.collapsed || );\n toggleClass = `state is-${isExpanded ? 'expanded' : 'collapsed'}`;\n } else {\n toggleIcon = ;\n toggleClass = 'is-empty';\n }\n return {toggleIcon};\n }\n\n protected _getItems(props: RenderableProps

    ): Item[] {\n const items = super._getItems(props);\n if (this.isRoot && items !== this._items) {\n this._itemMap = undefined;\n }\n return items;\n }\n\n protected _getItem(props: RenderableProps

    , item: NestedItem, index: number): NestedItem | false {\n const nestedItem = super._getItem(props, item, index) ?? item;\n if (!nestedItem) {\n return nestedItem;\n }\n const {parentKey} = props;\n const key = nestedItem.key!;\n const keyPath = `${parentKey !== undefined ? `${parentKey}:` : ''}${key}`;\n if (nestedItem.items) {\n const expanded = nestedItem.expanded ?? this.isExpanded(keyPath);\n mergeProps(nestedItem, {\n expanded: expanded,\n className: ['is-nested', `is-nested-${expanded ? 'show' : 'hide'}`],\n });\n this._hasNestedItems = true;\n }\n return mergeProps(nestedItem, {\n _level: props.level,\n _keyPath: keyPath,\n parentKey,\n });\n }\n\n protected _beforeRenderNestedItem(item: NestedItem): NestedItem | false {\n this._renderedItemMap.set(item._keyPath as string, item);\n return item;\n }\n\n protected _renderItem(props: RenderableProps

    , renderedItem: NestedItem, index: number): ComponentChildren {\n if (this._hasNestedItems && renderedItem.type === 'item' && renderedItem.toggleIcon === undefined) {\n renderedItem.toggleIcon = this._renderNestedToggle(props, renderedItem.expanded as boolean | undefined);\n }\n const nestedListContent = renderedItem.items ? this._renderNestedList(props, renderedItem.items, renderedItem, renderedItem.expanded as boolean) : null;\n renderedItem = mergeProps(renderedItem, {\n 'z-parent': renderedItem.parentKey,\n 'z-key-path': renderedItem._keyPath,\n }, this._needHandleHover ? {\n onMouseEnter: this._handleHover,\n onMouseLeave: this._handleHover,\n } : null, nestedListContent ? {children: nestedListContent} : null);\n this._renderedItemMap.set(renderedItem._keyPath as string, renderedItem);\n return super._renderItem(props, renderedItem, index);\n }\n\n protected _getItemFromEvent(event: MouseEvent, target?: HTMLElement): MouseEventInfo | undefined {\n const info = super._getItemFromEvent(event, target) as MouseEventInfo;\n if (!info) {\n return;\n }\n if (event.type === 'mouseenter' || event.type === 'mouseleave') {\n info.hover = event.type === 'mouseenter';\n }\n const {parentKey} = this.props;\n return {...info, parentKey, keyPath: `${parentKey !== undefined ? `${parentKey}:` : ''}${info.key}`, target: target || event.target as HTMLElement};\n }\n\n protected _toggleFromEvent(info: MouseEventInfo) {\n const {item, hover, event, keyPath, target} = info;\n const {nestedToggle} = this.props;\n const {isHoverTrigger} = this;\n if (!item.items || event.defaultPrevented || (isHoverTrigger && hover === undefined) || (!isHoverTrigger && event.type !== 'click') || target.closest('.not-nested-toggle') || (nestedToggle && !item.disabled && !target.closest(nestedToggle)) || (!nestedToggle && !item.disabled && target.closest('a,.btn,.item-checkbox,.open-url') && !target.closest('.nested-toggle-icon,.item-icon'))) {\n return info;\n }\n const toggle = typeof hover === 'boolean' ? hover : undefined;\n this.toggle(keyPath, toggle);\n event.preventDefault();\n }\n\n protected _handleNestedToggle(key: ItemKey, toggle: boolean) {\n this.toggle(key, toggle);\n }\n\n protected _handleClick(event: MouseEvent) {\n const info = super._handleClick(event);\n if (info) {\n return this._toggleFromEvent(info as MouseEventInfo);\n }\n return info;\n }\n\n protected _handleHover(event: MouseEvent) {\n const info = this._getItemFromEvent(event);\n if (!info) {\n return;\n }\n this.props.onHoverItem?.call(this, info as {hover: boolean, item: NestedItem, index: number, event: MouseEvent});\n if (!this.isHoverTrigger) {\n return;\n }\n const lastHover = this._hoverInfo;\n if (lastHover) {\n if (lastHover.info.keyPath === info.keyPath) {\n clearTimeout(lastHover.timer);\n } else {\n this._toggleFromEvent(lastHover.info);\n }\n }\n this._hoverInfo = {\n info,\n timer: window.setTimeout(() => {\n this._hoverInfo = undefined;\n this._toggleFromEvent(info);\n }, info.hover ? 0 : 200),\n };\n }\n\n protected _handleNestedCheck(change: Record) {\n this.toggleChecked(change);\n }\n\n protected _getProps(props: RenderableProps

    ): Record {\n const {level = 0, indent = 20, parentKey} = props;\n const finalProps = mergeProps(super._getProps(props), {\n 'z-level': level,\n 'z-parent-key': parentKey,\n style: {'--list-nested-indent': `${level * indent}px`, '--list-indent': `${indent}px`},\n className: this._hasNestedItems ? 'has-nested-items' : 'no-nested-items',\n });\n finalProps.className = classes(finalProps.className as ClassNameLike);\n return finalProps;\n }\n\n protected _beforeRender(props: RenderableProps

    ): void | RenderableProps

    | undefined {\n this._renderedItemMap.clear();\n this._hasIcons = false;\n this._hasNestedItems = !this.isRoot;\n this._needHandleHover = !!(props.onHoverItem || this.isHoverTrigger);\n return super._beforeRender(props);\n }\n}\n","import {CustomContent, classes, mergeProps} from '@zui/core';\nimport {NestedList, Listitem} from '@zui/list/src/component';\n\nimport type {Attributes, ComponentChildren, RenderableProps} from 'preact';\nimport type {ClassNameLike} from '@zui/core';\nimport type {NestedListState} from '@zui/list';\nimport type {MenuOptions, MenuSetting} from '../types';\n\nexport class Menu extends NestedList {\n static NAME = 'menu';\n\n static TAG = 'menu';\n\n static inheritNestedProps = [...NestedList.inheritNestedProps, 'compact'];\n\n static ItemComponents: typeof NestedList.ItemComponents = {\n ...NestedList.ItemComponents,\n item: [Listitem, {innerComponent: 'a'}],\n };\n\n static defaultProps: Partial = {\n ...NestedList.defaultProps,\n scrollbarHover: true,\n };\n\n protected _getClassName(props: RenderableProps): ClassNameLike {\n return [super._getClassName(props), this._hasNestedItems ? 'menu-nested' : '', props.className, props.wrap ? {'scrollbar-thin': props.scrollbarThin, 'scrollbar-hover': props.scrollbarHover} : {popup: props.popup, compact: props.compact}];\n }\n\n protected _getWrapClass(props: RenderableProps): ClassNameLike {\n return ['menu-wrapper', props.wrapClass, {popup: props.popup, compact: props.compact}];\n }\n\n protected _getWrapperProps(props: RenderableProps): Record {\n const {wrapAttrs, height, maxHeight} = props;\n const wrapProps = mergeProps({}, wrapAttrs, (height || maxHeight) ? {style: {height, maxHeight}} : null);\n wrapProps.className = classes(this._getWrapClass(props), wrapProps.className as ClassNameLike);\n return wrapProps;\n }\n\n protected _renderWrapperHeader(props: RenderableProps): ComponentChildren {\n return ;\n }\n\n protected _renderWrapperFooter(props: RenderableProps): ComponentChildren {\n return ;\n }\n\n render(props: RenderableProps) {\n const menuView = super.render(props);\n if (props.wrap) {\n return (\n

    \n {this._renderWrapperHeader(props)}\n {menuView}\n {this._renderWrapperFooter(props)}\n \n );\n }\n return super.render(props);\n }\n\n static render(this: unknown, setting: MenuSetting | undefined, args: T, defaultProps?: Partial & Attributes, thisObject?: unknown) {\n let menuOptions = typeof setting === 'function' ? setting.call(thisObject ?? this, ...args) : setting;\n if (!menuOptions) {\n return;\n }\n if (Array.isArray(menuOptions)) {\n menuOptions = {\n items: menuOptions,\n };\n }\n if (defaultProps) {\n menuOptions = mergeProps(defaultProps as Record, menuOptions);\n }\n return ;\n }\n}\n","import {Component, createRef} from 'preact';\nimport {$, classes, getHotkeysMap, Icon, nextGid} from '@zui/core';\nimport '../style';\n\nimport type {ComponentChildren, RenderableProps} from 'preact';\nimport type {SearchBoxOptions, SearchBoxState} from '../types';\n\nexport class SearchBox extends Component {\n static defaultProps: Partial = {\n clearIcon: true,\n searchIcon: true,\n delay: 500,\n hotkeys: true,\n };\n\n protected _gid: string;\n\n protected _input = createRef();\n\n protected _timer = 0;\n\n protected _hotkeysScope?: string;\n\n constructor(props: SearchBoxOptions) {\n super(props);\n this.state = {focus: false, value: props.defaultValue || ''};\n this._gid = props.id || `search-box-${nextGid()}`;\n }\n\n componentDidMount(): void {\n const {hotkeys} = this.props;\n if (hotkeys) {\n const hotkeysMap = getHotkeysMap(hotkeys, {\n clear: {\n keys: 'Escape',\n handler: (event) => {\n this.clear(event);\n },\n },\n enter: {\n keys: 'Enter',\n handler: (event) => {\n this.props.onEnter?.(this.state.value, event);\n },\n },\n });\n if (hotkeysMap) {\n this._hotkeysScope = `SearchBox_${this._gid}`;\n $(this.input).hotkeys(hotkeysMap, {\n scope: this._hotkeysScope,\n event: 'keydown',\n });\n }\n }\n }\n\n componentWillUnmount(): void {\n if (this._hotkeysScope) {\n $(this.input).unbindHotkeys(this._hotkeysScope);\n }\n }\n\n get id() {\n return this._gid;\n }\n\n get input() {\n return this._input.current;\n }\n\n focus() {\n this.input?.focus();\n }\n\n blur() {\n this.input?.blur();\n }\n\n clear(event?: Event) {\n const oldValue = this.state.value;\n this.setState({value: ''}, () => {\n const {onChange, onClear} = this.props;\n onClear?.(event);\n this.focus();\n if (oldValue.trim() !== '') {\n onChange?.('', event);\n }\n });\n }\n\n _handleClearBtnClick = (event: MouseEvent) => {\n event.stopPropagation();\n this.clear(event);\n };\n\n _handleChange = (event: Event) => {\n const oldValue = this.state.value;\n const value = (event.target as HTMLInputElement).value;\n const {onChange, delay} = this.props;\n this.setState({value}, () => {\n if (!onChange || oldValue === value) {\n return;\n }\n if (delay) {\n this._clearTimer();\n this._timer = window.setTimeout(() => {\n onChange(value, event);\n this._timer = 0;\n }, delay);\n } else {\n onChange(value, event);\n }\n });\n };\n\n _handleFocus = (event: FocusEvent) => {\n const focus = event.type === 'focus';\n this.setState({focus}, () => {\n const callback = focus ? this.props.onFocus : this.props.onBlur;\n callback?.(event);\n });\n };\n\n _clearTimer() {\n if (this._timer) {\n clearTimeout(this._timer);\n }\n this._timer = 0;\n }\n\n render(props: RenderableProps, state: Readonly) {\n const {style, className, rootClass, rootStyle, readonly, disabled, circle, placeholder, mergeIcon, searchIcon, clearIcon, value: controlledValue, compact, prefixClass, suffixClass} = props;\n const {focus, value} = state;\n const {id} = this;\n const finalValue = controlledValue ?? value;\n const empty = typeof finalValue !== 'string' || !finalValue.trim().length;\n let prefixView: ComponentChildren;\n let suffixView: ComponentChildren;\n let searchIconView: ComponentChildren;\n if (searchIcon) {\n searchIconView = searchIcon === true ? : ;\n }\n if (!mergeIcon && searchIcon) {\n prefixView = ;\n }\n if (clearIcon && !empty) {\n suffixView = (\n \n {clearIcon === true ? : }\n \n );\n } else if (mergeIcon && searchIcon) {\n suffixView = searchIconView;\n }\n if (suffixView) {\n suffixView = (\n \n );\n }\n\n return (\n
    \n {prefixView}\n \n {suffixView}\n
    \n );\n }\n}\n","import {$, classes} from '@zui/core';\nimport {SearchBox} from '@zui/search-box/src/components';\nimport {Menu} from './menu';\n\nimport {type ComponentChild, type ComponentChildren, type RenderableProps} from 'preact';\nimport type {ClassNameLike} from '@zui/core';\nimport type {Item, ItemKey} from '@zui/common-list';\nimport type {ListItemsSetting, NestedItem, NestedListItem, NestedListProps} from '@zui/list';\nimport type {SearchBoxOptions} from '@zui/search-box';\nimport type {SearchMenuOptions, SearchMenuState} from '../types';\n\nexport class SearchMenu extends Menu {\n static inheritNestedProps = [...Menu.inheritNestedProps, 'isItemMatch', 'search', 'underlineKeys'];\n\n static defaultProps: Partial = {\n ...Menu.defaultProps,\n defaultNestedShow: true,\n wrap: true,\n };\n\n protected declare _searchKeys: string[];\n\n protected declare _matchedParents: Set;\n\n protected declare _showCount: number;\n\n constructor(props: T) {\n super(props);\n (this.state as SearchMenuState).search = props.search ?? props.defaultSearch;\n this._searchKeys = (this.constructor as typeof SearchMenu).getSearchKeys(this.state.search);\n this._isNestedItemMatch = this._isNestedItemMatch.bind(this);\n }\n\n componentWillUpdate(nextProps: Readonly): void {\n if (this.isRoot) {\n if (nextProps.search !== undefined && nextProps.search !== this.props.search) {\n this._searchKeys = (this.constructor as typeof SearchMenu).getSearchKeys(nextProps.search);\n }\n }\n }\n\n componentDidMount(): void {\n super.componentDidMount();\n this._updateMatchedParents();\n }\n\n componentDidUpdate(): void {\n super.componentDidUpdate();\n this._updateMatchedParents();\n }\n\n isExpanded(keyPath: string): boolean {\n if (this.props.expandOnSearch && this._searchKeys.length) {\n return true;\n }\n return super.isExpanded(keyPath);\n }\n\n protected _updateMatchedParents(): void {\n if (!this.isRoot) {\n return;\n }\n const $element = $(this.element);\n const $matchedChildren = $element.find('.item.is-nested.is-not-match').filter((_, element) => this._matchedParents.has(element.getAttribute('z-key-path') || '')).addClass('has-match-child');\n $element.parent().toggleClass('no-match-child', !!this._searchKeys?.length && !$matchedChildren.length && !$element.children('.item').not('.is-not-match').length);\n }\n\n protected _handleSearchChange = (search: string) => {\n const searchKeys = (this.constructor as typeof SearchMenu).getSearchKeys(search);\n this._searchKeys = searchKeys;\n this.setState({search: searchKeys.join(' ')});\n };\n\n protected _isItemMatch(props: RenderableProps, item: NestedItem, index: number, parentKey: ItemKey | undefined) {\n const {isItemMatch} = props;\n const isMatch = isItemMatch ? isItemMatch.call(this, item, this._searchKeys, index, parentKey) : (this.constructor as typeof SearchMenu).isItemMatch(item, this._searchKeys, props.searchProps);\n if (this.isRoot && isMatch && parentKey !== undefined) {\n let key = '';\n String(parentKey).split(':').forEach(x => {\n key += `${key.length ? ':' : ''}${x}`;\n this._matchedParents.add(key);\n });\n }\n return isMatch;\n }\n\n protected _isNestedItemMatch(item: NestedItem, _searchKeys: string[], index: number, parentKey: ItemKey | undefined): boolean {\n return this._isItemMatch(this.props, item, index, parentKey);\n }\n\n protected _getNestedProps(props: RenderableProps, items: ListItemsSetting, item: NestedItem, expanded: boolean): NestedListProps {\n const nestedProps = super._getNestedProps(props, items, item, expanded) as SearchMenuOptions;\n if (this.isRoot) {\n nestedProps.isItemMatch = this._isNestedItemMatch;\n nestedProps.search = this._searchKeys.join(' ');\n }\n return nestedProps;\n }\n\n protected _getItem(props: RenderableProps, item: NestedItem, index: number): NestedItem | false {\n const finalItem = super._getItem(props, item, index);\n if (!finalItem) {\n return finalItem;\n }\n if (this.isRoot && this.props.limit && this._showCount >= this.props.limit) {\n return false;\n }\n finalItem.hidden = !this._isItemMatch(props, item, index, props.parentKey);\n if (!finalItem.hidden) {\n this._showCount++;\n }\n return finalItem;\n }\n\n protected _renderItem(props: RenderableProps, item: Item, index: number): ComponentChildren {\n item.className = [item.className, item.hidden ? 'is-not-match' : ''];\n if (props.underlineKeys && this._searchKeys.length) {\n ['text', 'title', 'subtitle', 'content'].forEach(key => {\n if (typeof item[key] === 'string') {\n item[key] = (this.constructor as typeof SearchMenu).underlineKeys(this._searchKeys, [item[key] as string]);\n }\n });\n }\n return super._renderItem(props, item, index);\n }\n\n protected _getWrapClass(props: RenderableProps): ClassNameLike {\n const isSearchMode = this.isRoot && this._searchKeys.length;\n return classes(super._getWrapClass(props), 'search-menu', props.searchBox ? `search-menu-on-${props.searchPlacement || 'top'}` : '', isSearchMode ? 'is-search-mode' : '', isSearchMode && props.expandOnSearch ? 'no-toggle-on-search' : '');\n }\n\n protected _renderSearchBox(props: RenderableProps): ComponentChildren {\n const {searchBox} = props;\n if (!searchBox || !this.isRoot) {\n return null;\n }\n const searchOptions: SearchBoxOptions = {\n compact: true,\n onChange: this._handleSearchChange,\n };\n if (typeof searchBox === 'object') {\n $.extend(searchOptions, searchBox);\n }\n if (props.search !== undefined) {\n searchOptions.value = this._searchKeys.join(' ');\n searchOptions.disabled = true;\n }\n return ;\n }\n\n protected _renderWrapperHeader(props: RenderableProps): ComponentChildren {\n const hasHeader = props.header;\n const hasTopSearchBox = this.isRoot && props.searchBox && props.searchPlacement !== 'bottom';\n const {noMatchHint} = props;\n if (!hasHeader && !hasTopSearchBox && !noMatchHint) {\n return null;\n }\n return [\n noMatchHint ?
    {noMatchHint}
    : null,\n (hasHeader || hasTopSearchBox) ? (
    \n {hasHeader ? super._renderWrapperHeader(props) : null}\n {hasTopSearchBox ? this._renderSearchBox(props) : null}\n
    ) : null,\n ];\n }\n\n protected _renderWrapperFooter(props: RenderableProps): ComponentChildren {\n const hasFooter = props.footer;\n const hasBottomSearchBox = this.isRoot && props.searchBox && props.searchPlacement === 'bottom';\n if (!hasFooter && !hasBottomSearchBox) {\n return null;\n }\n return (\n
    \n {hasFooter ? super._renderWrapperFooter(props) : null}\n {this._renderSearchBox(props)}\n
    \n );\n }\n\n protected _beforeRender(props: RenderableProps): void | RenderableProps | undefined {\n if (this.isRoot) {\n this._matchedParents = new Set();\n this._showCount = 0;\n }\n return super._beforeRender(props);\n }\n\n /**\n * Check whether item is matched.\n *\n * @param item Item to match.\n * @param searchKeys Search keys.\n * @returns Whether item is matched.\n */\n static isItemMatch(item: Item, searchKeys: string[], searchProps = ['keys', 'text', 'title', 'subtitle']) {\n if (!searchKeys.length) {\n return true;\n }\n return searchKeys.every(searchKey => searchProps.some(propName => {\n const propValue = item[propName];\n return typeof propValue === 'string' && propValue.length && propValue.toLowerCase().includes(searchKey);\n }));\n }\n\n /**\n * Convert search string to search keys.\n *\n * @param search Search string.\n * @returns Search keys array.\n */\n static getSearchKeys(search: string = ''): string[] {\n return $.unique((search).toLowerCase().split(' ').filter(x => x.length)) as string[];\n }\n\n static underlineKeys(searchKeys: string[], text: string[], className = 'is-match-keys'): ComponentChild[] {\n return searchKeys.reduce((result, key) => {\n return [...result].reduce((list, span) => {\n if (typeof span !== 'string') {\n list.push(span);\n return list;\n }\n const parts = span.toLowerCase().split(key);\n if (parts.length === 1) {\n list.push(span);\n return list;\n }\n let start = 0;\n parts.forEach((part, index) => {\n if (index) {\n list.push({span.substring(start, start + key.length)});\n start += key.length;\n }\n list.push(span.substring(start, start + part.length));\n start += part.length;\n });\n return list;\n }, []);\n }, text);\n }\n}\n","import {ComponentFromReact} from '@zui/core';\nimport {Menu as MenuReact} from '../component';\n\nimport type {MenuOptions} from '../types';\n\nexport class Menu extends ComponentFromReact> {\n static NAME = 'Menu';\n\n static Component = MenuReact;\n\n static replace = MenuReact.TAG;\n}\n","import {ComponentFromReact} from '@zui/core';\nimport {SearchMenu as MenuReact} from '../component';\n\nimport type {SearchMenuOptions} from '../types';\n\nexport class SearchMenu extends ComponentFromReact {\n static NAME = 'SearchMenu';\n\n static Component = MenuReact;\n\n static replace = MenuReact.TAG;\n}\n","import {registerReactComponent} from '@zui/core';\nimport * as components from './index';\n\nregisterReactComponent(components);\n","import {isValidElement, ComponentChildren} from 'preact';\nimport {classes, CustomContent, Icon} from '@zui/core';\nimport {Button} from '@zui/button/src/component/button';\nimport type {ButtonProps} from '@zui/button';\nimport '@zui/css-icons/src/icons/close.css';\nimport {AlertOptions} from '../types';\nimport {Toolbar} from '@zui/toolbar/src/component';\n\nexport function Alert({\n className,\n style,\n actions,\n heading,\n content,\n contentClass,\n children,\n close,\n onClose,\n icon,\n iconClass,\n ...others\n}: AlertOptions) {\n let closeButton: ComponentChildren;\n if (close === true) {\n closeButton = ;\n } else if (isValidElement(close)) {\n closeButton = close;\n } else if (typeof close === 'object') {\n closeButton =