@topvisor/ui 0.0.43 → 0.9.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (99) hide show
  1. package/.chunks/datepicker-32bc8bd9.es.js +275 -0
  2. package/.chunks/datepicker-32bc8bd9.es.js.map +1 -0
  3. package/.chunks/datepicker-8a42d8a6.amd.js +234 -0
  4. package/.chunks/datepicker-8a42d8a6.amd.js.map +1 -0
  5. package/.chunks/forms-30d68077.amd.js +3 -0
  6. package/.chunks/forms-30d68077.amd.js.map +1 -0
  7. package/.chunks/forms-64632f73.es.js +1091 -0
  8. package/.chunks/forms-64632f73.es.js.map +1 -0
  9. package/.chunks/{popup-de28e508.amd.js → popup-14ca85cf.amd.js} +378 -377
  10. package/.chunks/popup-14ca85cf.amd.js.map +1 -0
  11. package/.chunks/{popup-a622fe31.es.js → popup-b2fe3094.es.js} +439 -429
  12. package/.chunks/popup-b2fe3094.es.js.map +1 -0
  13. package/README.md +80 -80
  14. package/assets/core.css +1 -1
  15. package/assets/forms.css +1 -1
  16. package/assets/tabsView.css +1 -0
  17. package/core/core.amd.js +1 -1
  18. package/core/core.d.ts +2 -2
  19. package/core/core.js +1 -1
  20. package/forms/forms.amd.js +1 -1
  21. package/forms/forms.js +8 -8
  22. package/forms/helpers.amd.js.map +1 -1
  23. package/forms/helpers.js.map +1 -1
  24. package/formsExt/formsExt.amd.js +1 -1
  25. package/formsExt/formsExt.amd.js.map +1 -1
  26. package/formsExt/formsExt.js +1 -1
  27. package/formsExt/formsExt.js.map +1 -1
  28. package/icomoon/demo-files/demo.css +161 -161
  29. package/icomoon/demo-files/demo.js +30 -30
  30. package/icomoon/demo.html +2945 -2945
  31. package/icomoon/fonts/Topvisor-2.svg +232 -232
  32. package/icomoon/style.css +647 -647
  33. package/package.json +19 -19
  34. package/popup/popup.amd.js +1 -1
  35. package/popup/popup.amd.js.map +1 -1
  36. package/popup/popup.js +1 -1
  37. package/popup/popup.js.map +1 -1
  38. package/popup/worker.amd.js +1 -1
  39. package/popup/worker.amd.js.map +1 -1
  40. package/popup/worker.js +13 -10
  41. package/popup/worker.js.map +1 -1
  42. package/src/components/tabsView/tabsView/_MenuItem.stories.d.ts +361 -0
  43. package/src/components/tabsView/tabsView/_MenuTitle.stories.d.ts +280 -0
  44. package/src/components/tabsView/tabsView/content.vue.d.ts +19 -0
  45. package/src/components/tabsView/tabsView/menu.vue.d.ts +19 -0
  46. package/src/components/tabsView/tabsView/menuDelimeter.vue.d.ts +2 -0
  47. package/src/components/tabsView/tabsView/menuItem.vue.d.ts +19 -0
  48. package/src/components/tabsView/tabsView/menuTitle.vue.d.ts +19 -0
  49. package/src/components/tabsView/tabsView/state.d.ts +14 -0
  50. package/src/components/tabsView/tabsView/tabsView.d.ts +69 -0
  51. package/src/components/tabsView/tabsView/tabsView.stories.d.ts +529 -0
  52. package/src/components/tabsView/tabsView/tabsView.vue.d.ts +38 -0
  53. package/src/components/tabsView/tabsView.d.ts +4 -0
  54. package/src/core/utils/date.d.ts +25 -27
  55. package/src/core/utils/device.d.ts +10 -13
  56. package/tabs/tabs.amd.js +1 -1
  57. package/tabs/tabs.js +1 -1
  58. package/tabsView/tabsView.amd.js +2 -0
  59. package/tabsView/tabsView.amd.js.map +1 -0
  60. package/tabsView/tabsView.d.ts +1 -0
  61. package/tabsView/tabsView.js +271 -0
  62. package/tabsView/tabsView.js.map +1 -0
  63. package/utils/date.amd.js +1 -1
  64. package/utils/date.d.ts +0 -2
  65. package/utils/date.js +5 -2
  66. package/utils/device.amd.js +1 -1
  67. package/utils/device.d.ts +0 -2
  68. package/utils/device.js +7 -2
  69. package/utils/dom.amd.js +1 -1
  70. package/utils/dom.d.ts +2 -2
  71. package/utils/dom.js +1 -1
  72. package/.chunks/datepicker-92744062.es.js +0 -275
  73. package/.chunks/datepicker-92744062.es.js.map +0 -1
  74. package/.chunks/datepicker-a9226b0f.amd.js +0 -234
  75. package/.chunks/datepicker-a9226b0f.amd.js.map +0 -1
  76. package/.chunks/forms-727cc6aa.es.js +0 -1112
  77. package/.chunks/forms-727cc6aa.es.js.map +0 -1
  78. package/.chunks/forms-771091d4.amd.js +0 -3
  79. package/.chunks/forms-771091d4.amd.js.map +0 -1
  80. package/.chunks/popup-a622fe31.es.js.map +0 -1
  81. package/.chunks/popup-de28e508.amd.js.map +0 -1
  82. package/build/cssModules.d.ts +0 -13
  83. package/build/plugin/amdFix.d.ts +0 -8
  84. package/build/plugin/autoloadCSS.d.ts +0 -19
  85. package/build/rollup.config.d.ts +0 -15
  86. package/src/components/component.d.ts +0 -25
  87. package/src/components/helpersStories.d.ts +0 -28
  88. package/src/core/base/Colors.stories.d.ts +0 -19
  89. package/src/core/base/Layout.stories.d.ts +0 -19
  90. package/src/core/base/Properties.stories.d.ts +0 -19
  91. package/src/core/directives/tooltip.d.ts +0 -7
  92. package/src/core/theme/Colors.stories.d.ts +0 -19
  93. package/src/core/theme/Properties.stories.d.ts +0 -19
  94. package/src/core//320/235/320/260/320/261/320/276/321/200 /320/270/320/272/320/276/320/275/320/276/320/272//320/235/320/260/320/261/320/276/321/200 /320/270/320/272/320/276/320/275/320/276/320/272.stories.d.ts" +0 -6
  95. package/src/d.d.ts +0 -4
  96. package/src/resources/styles/core/core.d.ts +0 -0
  97. package/src/resources/styles/themes/dark.d.ts +0 -0
  98. package/src/resources/styles/themes/light.d.ts +0 -0
  99. package/src/storybook/components/icomoon.d.ts +0 -2
@@ -1,13 +1,10 @@
1
- declare class Device {
2
- static isRetina(): boolean;
3
- static isMobile(): boolean;
4
- static isApp(): boolean;
5
- static isMacOS(): boolean;
6
- static isSafari(): boolean;
7
- /**
8
- * Вернуть текст для обозначения клавиши Ctrl / Command в зависимости от OS
9
- * @returns {'Ctrl'|'⌘'}
10
- */
11
- static getCommandKeyLabel(): 'Ctrl' | '⌘';
12
- }
13
- export default Device;
1
+ export declare function isRetina(): boolean;
2
+ export declare function isMobile(): boolean;
3
+ export declare function isApp(): boolean;
4
+ export declare function isMacOS(): boolean;
5
+ export declare function isSafari(): boolean;
6
+ /**
7
+ * Вернуть текст для обозначения клавиши Ctrl / Command в зависимости от OS
8
+ * @returns {'Ctrl'|'⌘'}
9
+ */
10
+ export declare function getCommandKeyLabel(): 'Ctrl' | '⌘';
package/tabs/tabs.amd.js CHANGED
@@ -1,2 +1,2 @@
1
- define(["require","exports","vue","../.chunks/forms-771091d4.amd"],function(l,s,t,n){"use strict";l(["../core/core.amd"],o=>{const e=["../assets/tabs.css"].map(a=>l.toUrl(a));o.Page.addCss(e)});const c={class:t.normalizeClass({"top-tabs":!0})},d={key:0,class:"top-tabs_header"},b={class:"top-tabs_contents"},p=t.defineComponent({__name:"tabs",props:{id:{}},setup(o){return(e,a)=>(t.openBlock(),t.createElementBlock("div",c,[t.renderSlot(e.$slots,"buttons"),e.$slots.header?(t.openBlock(),t.createElementBlock("div",d,[t.renderSlot(e.$slots,"header")])):t.createCommentVNode("",!0),t.createElementVNode("div",b,[t.renderSlot(e.$slots,"contents")])]))}}),r={$style:{"top-tabs":"top-tabs","top-tabs_header":"top-tabs_header","top-tabs_contents":"top-tabs_contents","top-tabs_tabInput":"top-tabs_tabInput","top-tabs_content":"top-tabs_content"}},_=n._export_sfc(p,[["__cssModules",r]]),i=["id","name","value","checked","disabled"],m=["for"],$=t.defineComponent({__name:"tab",props:{tabsId:{},name:{},title:{},active:{type:Boolean},disabled:{type:Boolean}},setup(o){return(e,a)=>(t.openBlock(),t.createElementBlock(t.Fragment,null,[t.createElementVNode("input",{type:"radio",class:"top-tabs_tabInput top-unvisible",id:e.tabsId+e.name,name:e.tabsId,value:e.name,checked:e.active,disabled:e.disabled},null,8,i),t.createElementVNode("label",{class:t.normalizeClass({"top-tabs_tabLabel":!0,"top-forms-focusable":!0,"top-disabled":e.disabled}),for:e.tabsId+e.name},[t.renderSlot(e.$slots,"default")],10,m)],64))}}),f={$style:{"top-tabs_tabLabel":"top-tabs_tabLabel","top-tabs_tabInput":"top-tabs_tabInput","top-disabled":"top-disabled"}},u=n._export_sfc($,[["__cssModules",f]]),h=["data-tabs-name"],y=t.defineComponent({__name:"content",props:{name:{}},setup(o){return(e,a)=>(t.openBlock(),t.createElementBlock("div",{class:t.normalizeClass({"top-tabs_content":!0}),"data-tabs-name":e.name},[t.renderSlot(e.$slots,"default")],8,h))}}),k={$style:{"top-tabs_content":"top-tabs_content"}},B=n._export_sfc(y,[["__cssModules",k]]);s.Tabs=_,s.TabsContent=B,s.TabsTab=u,Object.defineProperty(s,Symbol.toStringTag,{value:"Module"})});
1
+ define(["require","exports","vue","../.chunks/forms-30d68077.amd"],function(l,s,t,n){"use strict";l(["../core/core.amd"],o=>{const e=["../assets/tabs.css"].map(a=>l.toUrl(a));o.Page.addCss(e)});const c={class:t.normalizeClass({"top-tabs":!0})},d={key:0,class:"top-tabs_header"},b={class:"top-tabs_contents"},p=t.defineComponent({__name:"tabs",props:{id:{}},setup(o){return(e,a)=>(t.openBlock(),t.createElementBlock("div",c,[t.renderSlot(e.$slots,"buttons"),e.$slots.header?(t.openBlock(),t.createElementBlock("div",d,[t.renderSlot(e.$slots,"header")])):t.createCommentVNode("",!0),t.createElementVNode("div",b,[t.renderSlot(e.$slots,"contents")])]))}}),r={$style:{"top-tabs":"top-tabs","top-tabs_header":"top-tabs_header","top-tabs_contents":"top-tabs_contents","top-tabs_tabInput":"top-tabs_tabInput","top-tabs_content":"top-tabs_content"}},_=n._export_sfc(p,[["__cssModules",r]]),i=["id","name","value","checked","disabled"],m=["for"],$=t.defineComponent({__name:"tab",props:{tabsId:{},name:{},title:{},active:{type:Boolean},disabled:{type:Boolean}},setup(o){return(e,a)=>(t.openBlock(),t.createElementBlock(t.Fragment,null,[t.createElementVNode("input",{type:"radio",class:"top-tabs_tabInput top-unvisible",id:e.tabsId+e.name,name:e.tabsId,value:e.name,checked:e.active,disabled:e.disabled},null,8,i),t.createElementVNode("label",{class:t.normalizeClass({"top-tabs_tabLabel":!0,"top-forms-focusable":!0,"top-disabled":e.disabled}),for:e.tabsId+e.name},[t.renderSlot(e.$slots,"default")],10,m)],64))}}),f={$style:{"top-tabs_tabLabel":"top-tabs_tabLabel","top-tabs_tabInput":"top-tabs_tabInput","top-disabled":"top-disabled"}},u=n._export_sfc($,[["__cssModules",f]]),h=["data-tabs-name"],y=t.defineComponent({__name:"content",props:{name:{}},setup(o){return(e,a)=>(t.openBlock(),t.createElementBlock("div",{class:t.normalizeClass({"top-tabs_content":!0}),"data-tabs-name":e.name},[t.renderSlot(e.$slots,"default")],8,h))}}),k={$style:{"top-tabs_content":"top-tabs_content"}},B=n._export_sfc(y,[["__cssModules",k]]);s.Tabs=_,s.TabsContent=B,s.TabsTab=u,Object.defineProperty(s,Symbol.toStringTag,{value:"Module"})});
2
2
  //# sourceMappingURL=tabs.amd.js.map
package/tabs/tabs.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { defineComponent as l, openBlock as o, createElementBlock as n, renderSlot as s, createCommentVNode as c, createElementVNode as b, normalizeClass as p, Fragment as r } from "vue";
2
- import { _ as d } from "../.chunks/forms-727cc6aa.es.js";
2
+ import { _ as d } from "../.chunks/forms-64632f73.es.js";
3
3
  import("../core/core.js").then((e) => {
4
4
  const t = ["../assets/tabs.css"].map((a) => import.meta.resolve(a));
5
5
  e.default.Page.addCss(t);
@@ -0,0 +1,2 @@
1
+ define(["require","exports","vue","../popup/popup.amd","../.chunks/forms-30d68077.amd","../popup/worker.amd"],function(w,p,e,u,c,Z){"use strict";w(["../core/core.amd"],o=>{const t=["../assets/tabsView.css"].map(n=>w.toUrl(n));o.Page.addCss(t)});const y=(o,t)=>(e.provide(o,t),t),k=o=>{const t=e.inject(o);if(!t)throw Error("Попытка использовать tabsView state до его инициализации");return t},f=(o,t)=>`top:tabsView:${String(o)}:${t}`,m={init:y,use:k,loadLocalStorge:(o,t)=>{if(!t.key)return;const n=f(o,t.key);try{const s=JSON.parse(localStorage.getItem(n));typeof s==typeof t[o]&&(t[o]=s)}catch{console.warn(new Error(`В localStorage[${n}] не корректный json`))}},addSaverLocalStorge:(o,t)=>{if(!t.key)return;const n=f(o,t.key);e.watch(e.toRef(t,o),()=>{localStorage.setItem(n,JSON.stringify(t[o]))},{immediate:!0})}},b=Symbol(),I=(o,t)=>{const n=e.reactive({key:o.keyForSaveState,showMenuInPopup:o.showMenuInPopup,isShort:!1,activeItemName:e.computed({get(){return o.modelValue},set(s){t("update:modelValue",s)}})});return $(o,n),m.init(b,n)},d=()=>m.use(b),$=(o,t)=>{if(o.isShortable){const n="isShort";m.loadLocalStorge(n,t),m.addSaverLocalStorge(n,t)}},M={key:1,class:"top-ellipsis"},B=e.defineComponent({__name:"menuItem",props:{name:{},href:{},icon:{},disabled:{type:Boolean}},setup(o){const t=o,n=e.computed(()=>s.showMenuInPopup?u.PopupListItem:t.href?"a":"button"),s=d();return(a,l)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(n.value),{class:e.normalizeClass({"top-tabsView_menuItem":!e.unref(s).showMenuInPopup,"top-active":a.name&&e.unref(s).activeItemName===a.name,"top-disabled":a.disabled}),href:a.href,"data-top-icon":a.icon||void 0,disabled:a.disabled||void 0,onClick:l[0]||(l[0]=i=>a.name?e.unref(s).activeItemName=a.name:null)},{default:e.withCtx(()=>[e.unref(s).showMenuInPopup?e.renderSlot(a.$slots,"default",{key:0}):a.$slots.default&&!e.unref(s).isShort?(e.openBlock(),e.createElementBlock("span",M,[e.renderSlot(a.$slots,"default")])):e.createCommentVNode("",!0)]),_:3},8,["class","href","data-top-icon","disabled"]))}}),g={$style:{"top-tabsView_menuItem":"top-tabsView_menuItem","top-active":"top-active","top-forms-option":"top-forms-option","top-formsCaption":"top-formsCaption","top-disabled":"top-disabled"}},_=c._export_sfc(B,[["__cssModules",g]]),P={class:"top-tabsView_menuOpener"},C=["data-top-icon"],N={class:"top-ellipsis"},T=e.createElementVNode("div",{class:"top-tabsView_menuOpenerIcon","data-top-icon":""},null,-1),E={class:"top-tabsView_menuList"},L=e.defineComponent({__name:"menu",props:{isShortable:{type:Boolean}},setup(o){const t=d(),n=e.useSlots(),s=new Map,a=e.computed(()=>{let i=s.get(t.activeItemName);return i||(l(),s.get(t.activeItemName)||null)}),l=()=>{if(!n.default)return;const i=n.default().find(r=>r.key==="_menu");i&&i.children.forEach(r=>{var h,S;if(r.type.__name!==_.__name||!r.props.name)return;const V={title:((S=(h=r.children).default)==null?void 0:S.call(h)[0].children).trim(),icon:r.props.icon};s.set(r.props.name,V)})};return(i,r)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass({"top-tabsView_menu":!0,"top-tabsView_menu-inPopup_0":!e.unref(t).showMenuInPopup,"top-tabsView_menu-inPopup_1":e.unref(t).showMenuInPopup,"top-tabsView_menu-short":e.unref(t).isShort&&!e.unref(t).showMenuInPopup})},[e.unref(t).showMenuInPopup?(e.openBlock(),e.createBlock(e.unref(u.Popup),{key:0},{opener:e.withCtx(()=>[e.createElementVNode("div",P,[a.value?(e.openBlock(),e.createElementBlock("div",{key:0,class:"top-tabsView_menuOpenerActiveItem","data-top-icon":a.value.icon},[e.createElementVNode("span",N,e.toDisplayString(a.value.title),1)],8,C)):e.createCommentVNode("",!0),T])]),contentList:e.withCtx(()=>[e.renderSlot(i.$slots,"default")]),_:3})):(e.openBlock(),e.createElementBlock(e.Fragment,{key:1},[e.createElementVNode("div",E,[e.renderSlot(i.$slots,"default")]),i.isShortable?(e.openBlock(),e.createBlock(_,{key:0,icon:e.unref(t).isShort?"":"",onClick:r[0]||(r[0]=V=>e.unref(t).isShort=!e.unref(t).isShort)},{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(e.unref(t).isShort?"":"Свернуть")+" ",1)]),_:1},8,["icon"])):e.createCommentVNode("",!0)],64))],2))}}),O={$style:{"top-tabsView_menu-inPopup_0":"top-tabsView_menu-inPopup_0","top-tabsView_menu-inPopup_1":"top-tabsView_menu-inPopup_1","top-tabsView_menu-short":"top-tabsView_menu-short","top-tabsView_menu":"top-tabsView_menu","top-tabsView_menuOpener":"top-tabsView_menuOpener","top-tabsView_menuOpenerIcon":"top-tabsView_menuOpenerIcon","top-tabsView_menuOpenerActiveItem":"top-tabsView_menuOpenerActiveItem","top-tabsView_menuList":"top-tabsView_menuList"}},D=c._export_sfc(L,[["__cssModules",O]]),j={class:"top-tabsView_contents"},z=e.defineComponent({__name:"tabsView",props:{modelValue:{},showMenuInPopup:{type:Boolean},isShortable:{type:Boolean,default:!1},keyForSaveState:{}},emits:["update:modelValue"],setup(o,{emit:t}){const n=o,a=I(n,t);return e.watchEffect(()=>{a.showMenuInPopup=n.showMenuInPopup??c.Core.state.isMobile}),(l,i)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass({"top-tabsView":!0,"top-tabsView-inPopup":e.unref(a).showMenuInPopup})},[e.createVNode(D,{isShortable:l.isShortable},{default:e.withCtx(()=>[e.renderSlot(l.$slots,"menu")]),_:3},8,["isShortable"]),e.createElementVNode("div",j,[e.renderSlot(l.$slots,"contents")])],2))}}),K={$style:{"top-tabsView":"top-tabsView","top-tabsView-inPopup":"top-tabsView-inPopup","top-tabsView_contents":"top-tabsView_contents"}},A=c._export_sfc(z,[["__cssModules",K]]),F={"top-tabsView_menuDelimeter":"top-tabsView_menuDelimeter"},J={},R={class:"top-tabsView_menuDelimeter"};function U(o,t){return e.openBlock(),e.createElementBlock("div",R)}const q={$style:F},G=c._export_sfc(J,[["render",U],["__cssModules",q]]),H=e.defineComponent({__name:"menuTitle",props:{isSubtitle:{type:Boolean}},setup(o){const t=d();return(n,s)=>e.unref(t).showMenuInPopup?(e.openBlock(),e.createBlock(e.unref(u.PopupListItem),{key:0,type:"title"},{default:e.withCtx(()=>[e.renderSlot(n.$slots,"default")]),_:3})):e.unref(t).isShort?(e.openBlock(),e.createBlock(G,{key:1})):(e.openBlock(),e.createElementBlock("div",{key:2,class:e.normalizeClass({"top-tabsView_menuTitle":!0,"top-tabsView_menuTitle-subtitle":n.isSubtitle})},[e.renderSlot(n.$slots,"default")],2))}}),Q={$style:{"top-tabsView_menuTitle":"top-tabsView_menuTitle","top-tabsView_menuTitle-subtitle":"top-tabsView_menuTitle-subtitle"}},W=c._export_sfc(H,[["__cssModules",Q]]),X={key:0,class:"top-tabsView_content"},Y=e.defineComponent({__name:"content",props:{name:{}},setup(o){const t=d();return(n,s)=>e.unref(t).activeItemName===n.name?(e.openBlock(),e.createElementBlock("div",X,[e.renderSlot(n.$slots,"default")])):e.createCommentVNode("",!0)}});p.TabsView=A,p.TabsViewContent=Y,p.TabsViewMenuItem=_,p.TabsViewMenuTitle=W,Object.defineProperty(p,Symbol.toStringTag,{value:"Module"})});
2
+ //# sourceMappingURL=tabsView.amd.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabsView.amd.js","sources":["../../src/components/stateManager.ts","../../src/components/tabsView/tabsView/state.ts","../../src/components/tabsView/tabsView/menuItem.vue","../../src/components/tabsView/tabsView/menu.vue","../../src/components/tabsView/tabsView/tabsView.vue","../../src/components/tabsView/tabsView/menuDelimeter.vue","../../src/components/tabsView/tabsView/menuTitle.vue","../../src/components/tabsView/tabsView/content.vue"],"sourcesContent":["import { provide, inject, toRef, watch } from 'vue';\nimport type { InjectionKey } from 'vue';\nimport { injectionKey } from '@/components/tabsView/tabsView/state';\n\n/**\n * State - интерфейс с общими параметрами для состояния компоента\n */\nexport interface State {\n\t/**\n\t * Ключ для сохранения состояния\n\t *\n\t * Может быть одинаковый для разных компонентов\n\t *\n\t * Не может быть реактивным\n\t *\n\t * Состояния сохраняются в localStorage с префиксом top\n\t */\n\tkey?: string;\n}\n\n/**\n * Инициировать State компонента\n * @param key - InjectionKey для provide / inject в области компонента\n * @param state\n * @return - State компонента\n */\nconst init = <T>(injectionKey: InjectionKey<T>, state: T): T => {\n\tprovide(injectionKey, state);\n\n\treturn state;\n};\n\n/**\n * Получить State компонента\n * @param key - InjectionKey для provide / inject в области компонента\n * @return - State компонента\n */\nconst use = <T>(injectionKey: InjectionKey<T>): T => {\n\tconst state = inject(injectionKey);\n\n\tif (!state) {\n\t\tthrow Error('Попытка использовать tabsView state до его инициализации');\n\t}\n\n\treturn state;\n};\n\n/**\n * Сгенерировать имя для сохранения данных в localStorage\n * @param stateName - имя свойства состояния\n * @param stateKey - ключ состояния, разные компоненты могут использовать одинаковый ключ\n */\nconst genStorageKey = <T extends State>(stateName: keyof T, stateKey: string): string => {\n\tconst stateNameString = String(stateName);\n\n\treturn `top:tabsView:${stateNameString}:${stateKey}`;\n};\n\n/**\n * Загрузить состояние\n * @param stateName - имя свойства состояния\n * @param state\n */\nconst loadLocalStorge = <T extends State>(stateName: keyof T, state: T) => {\n\t// если state.key не знадан, значит сохранение состояния в компоненте отключено\n\tif (!state.key) return;\n\n\tconst localStorageKey = genStorageKey(stateName, state.key);\n\n\ttry {\n\t\tconst localStorageValue: typeof state[keyof typeof state] = JSON.parse(localStorage.getItem(localStorageKey) as string);\n\n\t\tif (typeof localStorageValue === typeof state[stateName]) {\n\t\t\tstate[stateName] = localStorageValue;\n\t\t}\n\t} catch (e) {\n\t\tconsole.warn(new Error(`В localStorage[${localStorageKey}] не корректный json`));\n\t}\n};\n\n/**\n * Добавить автосохранение состояние при его изменении\n * @param stateName - имя свойства состояния\n * @param state\n */\nconst addSaverLocalStorge = <T extends State>(stateName: keyof T, state: T) => {\n\t// если state.key не знадан, значит сохранение состояния в компоненте отключено\n\tif (!state.key) return;\n\n\tconst localStorageKey = genStorageKey(stateName, state.key);\n\n\twatch(toRef(state, stateName), () => {\n\t\tlocalStorage.setItem(localStorageKey, JSON.stringify(state[stateName]));\n\t}, { immediate: true });\n};\n\nexport default {\n\tinit,\n\tuse,\n\tloadLocalStorge,\n\taddSaverLocalStorge,\n};","import { reactive, computed } from 'vue';\nimport type { InjectionKey } from 'vue';\nimport type { State } from './tabsView';\nimport type { Emits, Props } from './tabsView';\nimport stateManager from '@/components/stateManager';\n\nexport const injectionKey = Symbol() as InjectionKey<State>;\n\n/**\n * Инициировать State компонента\n * @param props\n * @param emit\n */\nexport const initState = (props: Props, emit: Emits): State => {\n\tconst state: State = reactive({\n\t\tkey: props.keyForSaveState,\n\t\tshowMenuInPopup: props.showMenuInPopup,\n\t\tisShort: false,\n\t\tactiveItemName: computed({\n\t\t\tget() {\n\t\t\t\treturn props.modelValue;\n\t\t\t},\n\t\t\tset(value) {\n\t\t\t\temit('update:modelValue', value);\n\t\t\t},\n\t\t}),\n\t});\n\n\tinitLocalStorge(props, state);\n\n\treturn stateManager.init(injectionKey, state);\n};\n\n/**\n * Получить State компонента\n */\nexport const useState = () => {\n\treturn stateManager.use(injectionKey);\n};\n\n/**\n * Инициировать работу LocalStorge\n * @param props\n * @param state\n */\nconst initLocalStorge = (props: Props, state: State): void => {\n\tif (props.isShortable) {\n\t\tconst stateName = 'isShort';\n\n\t\tstateManager.loadLocalStorge(stateName, state);\n\t\tstateManager.addSaverLocalStorge(stateName, state);\n\t}\n};","<script setup lang=\"ts\">\nimport { computed } from 'vue';\nimport { useState } from './state';\nimport type { PropsMenuItem, State } from './tabsView';\nimport { PopupListItem } from '../../popup/popup';\n\nconst props = defineProps<PropsMenuItem>();\n\nconst componentName = computed(() => {\n\tif (state.showMenuInPopup) {\n\t\treturn PopupListItem;\n\t}\n\n\treturn props.href ? 'a' : 'button';\n});\n\nconst state = useState();\n</script>\n\n<template>\n\t<component\n\t\t:is=\"componentName\"\n\t\t:class=\"{\n\t\t\t['top-tabsView_menuItem']: !state.showMenuInPopup,\n\t\t\t['top-active']: name && state.activeItemName === name,\n\t\t\t['top-disabled']: disabled,\n\t\t}\"\n\t\t:href=\"href\"\n\t\t:data-top-icon=\"icon || undefined\"\n\t\t:disabled=\"disabled || undefined\"\n\t\t@click=\"name ? state.activeItemName = name : null\"\n\t>\n\t\t<slot v-if=\"state.showMenuInPopup\"></slot>\n\n\t\t<span\n\t\t\tv-else-if=\"$slots.default && !state.isShort\"\n\t\t\tclass=\"top-ellipsis\"\n\t\t>\n\t\t\t<slot></slot>\n\t\t</span>\n\t</component>\n</template>\n\n<style module>\n.top-tabsView_menuItem {\n\t--top-icon-color: var(--color-text-1);\n\t--top-icon-width: calc(var(--top-icon-size));\n\n\tcursor: pointer;\n\tbox-sizing: border-box;\n\n\tborder: none;\n\tborder-radius: var(--top-radius-2);\n\tpadding: var(--top-padding-2);\n\tbackground: transparent;\n\theight: 40px;\n\n\tcolor: var(--color-text-1);\n\ttext-align: left;\n\ttext-decoration: none;\n\twhite-space: nowrap;\n\n\tdisplay: flex;\n\tgap: var(--top-gap-2);\n\talign-items: center;\n\tjustify-content: flex-start;\n\ttransition: background var(--transition);\n}\n\n.top-tabsView_menuItem:hover {\n\tbackground: var(--color-secondary-2-opacity);\n}\n\n.top-tabsView_menuItem.top-active {\n\t--top-icon-color: var(--color-primary);\n\n\tcursor: unset;\n\tbackground: var(--color-bg-3);\n\tcolor: var(--color-primary);\n}\n\n.top-tabsView_menuItem:disabled:not(option):not(optgroup):not(.top-forms-option),\n.top-tabsView_menuItem:disabled ~ .top-formsCaption,\n.top-tabsView_menuItem.top-disabled[data-top-icon]:before,\n.top-tabsView_menuItem.top-disabled[data-top-icon2]:after {\n\topacity: unset;\n\tfilter: unset;\n}\n\n.top-tabsView_menuItem.top-disabled {\n\t--top-icon-color: var(--color-text-4);\n\n\tcolor: var(--color-text-4);\n}\n</style>","<script setup lang=\"ts\">\nimport { computed, useSlots } from 'vue';\nimport type { ComputedRef } from '@vue/reactivity';\nimport { Popup } from '../../popup/popup';\n\nimport type { PropsMenu, PropsMenuItem, MenuItem } from './tabsView';\nimport { useState } from './state';\nimport TabsViewMenuItem from './menuItem.vue';\n\ndefineProps<PropsMenu>();\n\nconst state = useState();\n\nconst slots = useSlots();\n\n// словарь испоьзуется для оптимизации получения нужного menuItem\nconst menuItemByName: Map<PropsMenuItem['name'], MenuItem> = new Map();\n\n// activeMenuItem нужен для вывода текста активной вкладки в меню с popup\n// смена slot, например смена языка, требует повторного выполнения genMenuItemByName()\nconst activeMenuItem: ComputedRef<MenuItem | null> = computed(() => {\n\tlet menuItem = menuItemByName.get(state.activeItemName);\n\tif (menuItem) return menuItem;\n\n\tgenMenuItemByName();\n\n\treturn menuItemByName.get(state.activeItemName) || null;\n});\n\n// сгенерировать словарь с menuItem, по элементам в slot\nconst genMenuItemByName = () => {\n\tif (!slots.default) return;\n\n\tconst component: any = slots.default().find(item => item.key === '_menu');\n\tif (!component) return;\n\n\tcomponent.children.forEach((subComponent: any) => {\n\t\tif (subComponent.type.__name !== TabsViewMenuItem.__name) return;\n\t\tif (!subComponent.props.name) return;\n\n\t\tconst menuItem = {\n\t\t\ttitle: (subComponent.children.default?.()[0].children as string).trim(),\n\t\t\ticon: subComponent.props.icon,\n\t\t};\n\n\t\tmenuItemByName.set(subComponent.props.name, menuItem);\n\t});\n};\n</script>\n\n<template>\n\t<div\n\t\t:class=\"{\n\t\t\t'top-tabsView_menu': true,\n\t\t\t'top-tabsView_menu-inPopup_0': !state.showMenuInPopup,\n\t\t\t'top-tabsView_menu-inPopup_1': state.showMenuInPopup,\n\t\t\t'top-tabsView_menu-short': state.isShort && !state.showMenuInPopup,\n\t\t}\"\n\t>\n\t\t<!-- Спрятать меню под кнопку в popup -->\n\t\t<Popup v-if=\"state.showMenuInPopup\">\n\t\t\t<template #opener>\n\t\t\t\t<div class=\"top-tabsView_menuOpener\">\n\t\t\t\t\t<div\n\t\t\t\t\t\tv-if=\"activeMenuItem\"\n\t\t\t\t\t\tclass=\"top-tabsView_menuOpenerActiveItem\"\n\t\t\t\t\t\t:data-top-icon=\"activeMenuItem.icon\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<span class=\"top-ellipsis\">\n\t\t\t\t\t\t\t{{ activeMenuItem.title }}\n\t\t\t\t\t\t</span>\n\t\t\t\t\t</div>\n\n\t\t\t\t\t<div class=\"top-tabsView_menuOpenerIcon\" data-top-icon=\"\"></div>\n\t\t\t\t</div>\n\t\t\t</template>\n\n\t\t\t<template #contentList>\n\t\t\t\t<slot></slot>\n\t\t\t</template>\n\t\t</Popup>\n\n\t\t<!-- Отобразить меню на старнице -->\n\t\t<template v-else>\n\t\t\t<div class=\"top-tabsView_menuList\">\n\t\t\t\t<slot></slot>\n\t\t\t</div>\n\n\t\t\t<TabsViewMenuItem\n\t\t\t\tv-if=\"isShortable\"\n\t\t\t\t:icon=\"state.isShort ? '' : ''\"\n\t\t\t\t@click=\"state.isShort = !state.isShort\"\n\t\t\t>\n\t\t\t\t{{ state.isShort ? '' : 'Свернуть' }} <!--TODO: translate-->\n\t\t\t</TabsViewMenuItem>\n\t\t</template>\n\t</div>\n</template>\n\n<style module>\n.top-tabsView_menu-inPopup_0 {\n\tbox-sizing: border-box;\n\tbackground: var(--color-bg-2);\n\twidth: var(--top-tabsView-menu-width);\n\tpadding: var(--top-padding-2);\n\tdisplay: flex;\n\tflex-direction: column;\n\tjustify-content: space-between;\n}\n\n.top-tabsView_menu-inPopup_1 {\n\tborder-bottom: 1px solid var(--color-line-2-opacity);\n}\n\n.top-tabsView_menu-short {\n\twidth: auto;\n}\n\n.top-tabsView_menu .top-tabsView_menuOpener {\n\tdisplay: flex;\n\tjustify-content: flex-end;\n}\n\n.top-tabsView_menu .top-tabsView_menuOpener:hover {\n\tbackground: var(--color-secondary-opacity);\n}\n\n.top-tabsView_menuOpenerIcon { display: flex; }\n\n.top-tabsView_menuOpenerActiveItem {\n\t--top-forms-padding: 0px;\n\n\tbox-sizing: border-box;\n\tpadding: var(--top-padding-2);\n\tmax-width: calc(100% - var(--top-forms-base-height));\n\twhite-space: nowrap;\n\tflex-grow: 1;\n\tdisplay: flex;\n\talign-items: center;\n\tgap: var(--top-padding-2);\n}\n\n.top-tabsView_menuList {\n\tdisplay: flex;\n\tflex-direction: column;\n\tgap: var(--top-gap-2);\n}\n</style>","<script setup lang=\"ts\">\nimport { watchEffect } from 'vue';\nimport type { Props, Emits } from './tabsView';\nimport { initState } from './state';\nimport TabsViewMenu from './menu.vue';\nimport Core from '@/core/core/core';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tisShortable: false,\n});\n\nconst emit = defineEmits<Emits>();\n\nconst state = initState(props, emit);\n\nwatchEffect(() => {\n\tstate.showMenuInPopup = props.showMenuInPopup ?? Core.state.isMobile;\n});\n</script>\n\n<template>\n\t<div\n\t\t:class=\"{\n\t\t\t'top-tabsView': true,\n\t\t\t'top-tabsView-inPopup': state.showMenuInPopup,\n\t\t}\"\n\t>\n\t\t<TabsViewMenu :isShortable=\"isShortable\">\n\t\t\t<!-- @slot Меню, ожидает передачу компонентов TabsViewMenuItem и TabsViewMenuTitle -->\n\t\t\t<slot name=\"menu\"></slot>\n\t\t</TabsViewMenu>\n\n\t\t<div class=\"top-tabsView_contents\">\n\t\t\t<!-- @slot Контент вкладок, ожидает передачу компонентов TabsViewContent, в слоте необходимо предусмотреть вывод неободимого компонента в зависимости от активной вкладки -->\n\t\t\t<slot name=\"contents\"></slot>\n\t\t</div>\n\t</div>\n</template>\n\n<style module>\n:root {\n\t--top-tabsView-menu-width: 190px;\n}\n\n.top-tabsView {\n\twidth: 100%;\n\theight: 100%;\n\tdisplay: flex;\n\tflex-direction: row;\n}\n\n.top-tabsView-inPopup {\n\tflex-direction: column;\n}\n\n.top-tabsView_contents {\n\tpadding: var(--top-padding-4);\n\tflex-grow: 1;\n}\n</style>","<script setup lang=\"ts\">\n\n</script>\n\n<template>\n\t<div class=\"top-tabsView_menuDelimeter\"></div>\n</template>\n\n<style module>\n.top-tabsView_menuDelimeter {\n\tpadding: var(--top-padding-1) 0;\n\tdisplay: flex;\n}\n\n.top-tabsView_menuDelimeter:before {\n\tcontent: \"\";\n\theight: 2px;\n\tbackground: var(--color-line-2-opacity);\n\tflex-grow: 1;\n}\n\n.top-tabsView_menuDelimeter + .top-tabsView_menuDelimeter {\n\tdisplay: none;\n}\n</style>","<script setup lang=\"ts\">\nimport { useState } from './state';\nimport type { PropsMenuTitle, State } from './tabsView';\nimport TabsViewMenuDelimeter from './menuDelimeter.vue';\nimport { PopupListItem } from '../../popup/popup';\n\ndefineProps<PropsMenuTitle>();\n\nconst state = useState();\n</script>\n\n<template>\n\t<PopupListItem\n\t\tv-if=\"state.showMenuInPopup\"\n\t\ttype=\"title\"\n\t>\n\t\t<slot></slot>\n\t</PopupListItem>\n\n\t<TabsViewMenuDelimeter v-else-if=\"state.isShort\"/>\n\n\t<div\n\t\tv-else\n\t\t:class=\"{\n\t\t\t'top-tabsView_menuTitle': true,\n\t\t\t'top-tabsView_menuTitle-subtitle': isSubtitle,\n\t\t}\"\n\t>\n\t\t<slot></slot>\n\t</div>\n</template>\n\n<style module>\n.top-tabsView_menuTitle {\n\tpadding: var(--top-padding-4) var(--top-padding-2) var(--top-padding-1);\n\tfont-weight: 600;\n}\n\n.top-tabsView_menuTitle-subtitle {\n\tpadding-top: var(--top-padding-1);\n\tfont-size: 12px;\n\tfont-weight: 400;\n\tcolor: var(--color-text-2);\n}\n</style>","<script setup lang=\"ts\">\nimport { useState } from './state';\nimport type { PropsContent } from './tabsView';\n\ndefineProps<PropsContent>();\n\nconst state = useState();\n</script>\n\n<template>\n\t<div\n\t\tv-if=\"state.activeItemName === name\"\n\t\tclass=\"top-tabsView_content\"\n\t>\n\t\t<slot></slot>\n\t</div>\n</template>\n\n<style module>\n\n</style>"],"names":["init","injectionKey2","state","vue","use","genStorageKey","stateName","stateKey","stateManager","localStorageValue","localStorageKey","injectionKey","initState","props","emit","value","initLocalStorge","__props","componentName","useState","slots","menuItemByName","activeMenuItem","menuItem","component","item","subComponent","_b","_a","__emit","forms","_sfc_render","_ctx","_cache"],"mappings":"qPA0BA,MAAAA,EAAA,CAAAC,EAAAC,KACCC,EAAA,QAAAF,EAAAC,CAAA,KAUDE,EAAAH,GAAA,CACC,MAAAC,EAAAC,EAAA,OAAAF,CAAA,QAGC,MAAA,MAAA,0DAAA,UAIF,EAOAI,EAAA,CAAAC,EAAAC,oBACC,OAAAD,CAAA,SA2CDE,EAAA,CAAe,KAAAR,EACd,IAAAI,EACA,gBAnCD,CAAAE,EAAAJ,IAAA,CAEC,GAAA,CAAAA,EAAA,IAAgB,0BAIhB,GAAA,CACC,MAAAO,EAAA,KAAA,MAAA,aAAA,QAAAC,CAAA,CAAA,0BAGCR,EAAAI,CAAA,EAAAG,SAGD,QAAA,KAAA,IAAA,MAAA,kBAAAC,CAAA,sBAAA,CAAA,EAEF,EAqBC,oBAdD,CAAAJ,EAAAJ,IAAA,CAEC,GAAA,CAAAA,EAAA,IAAgB,oDAKf,aAAA,QAAAQ,EAAA,KAAA,UAAAR,EAAAI,CAAA,CAAA,CAAA,CAAsE,EAAA,CAAA,UAAA,EAAA,CAAA,CAExE,GCxFOK,EAAA,OAAA,EAOMC,EAAA,CAAAC,EAAAC,IAAA,CACZ,MAAAZ,EAAAC,EAAA,SAAA,CAA8B,IAAAU,EAAA,gBAClB,gBAAAA,EAAA,sDAGc,KAAA,CAEvB,OAAAA,EAAA,mBAGAC,EAAA,oBAAAC,CAAA,EACD,CAAA,CACA,CAAA,EAGF,OAAAC,EAAAH,EAAAX,CAAA,aAGD,QAMCM,EAAA,IAAAG,CAAA,EAQDK,EAAA,CAAAH,EAAAX,IAAA,CACC,GAAAW,EAAA,YAAA,CACC,MAAAP,EAAA,qMCzCF,MAAAO,EAAAI,EAEAC,EAAAf,EAAA,SAAA,IACCD,EAAA,mDAI0B,EAG3BA,EAAAiB,EAAA,krCCLA,MAAAjB,EAAAiB,EAAA,EAEAC,EAAAjB,EAAA,SAAA,EAGAkB,EAAA,IAAA,IAIAC,EAAAnB,EAAA,SAAA,IAAA,+BAEC,OAAAoB,sCAImD,CAAA,SAKnD,GAAA,CAAAH,EAAA,QAAoB,OAEpB,MAAAI,EAAAJ,EAAA,QAAA,EAAA,KAAAK,GAAAA,EAAA,MAAA,OAAA,oCAKC,6BAAA,CAAAC,EAAA,MAAA,KAA8B,gBAEb,QAAAC,GAAAC,EAAAF,EAAA,UAAA,UAAA,YAAAC,EAAA,KAAAC,GAAA,GAAA,UAAA,KAAA,EACsD,KAAAF,EAAA,MAAA,IAC7C,EAG1BL,EAAA,IAAAK,EAAA,MAAA,KAAAH,CAAA,CAAoD,CAAA,CACpD,w2DCvCF,MAAAV,EAAAI,QAIAY,6BAKC3B,EAAA,gBAAAW,EAAA,iBAAAiB,EAAA,KAAA,MAAA,QAA4D,CAAA,qnBCX5D,SAAAC,EAAAC,EAAAC,EAAA,+MCGD,MAAA/B,EAAAiB,EAAA,qsBCFA,MAAAjB,EAAAiB,EAAA"}
@@ -0,0 +1 @@
1
+ export * from '../src/components/tabsView/tabsView'
@@ -0,0 +1,271 @@
1
+ import { provide as N, inject as O, watch as B, toRef as L, reactive as C, computed as S, defineComponent as w, openBlock as i, createBlock as d, resolveDynamicComponent as D, normalizeClass as h, unref as s, withCtx as m, renderSlot as u, createElementBlock as c, createCommentVNode as V, useSlots as E, createElementVNode as _, toDisplayString as M, Fragment as K, createTextVNode as j, watchEffect as A, createVNode as F } from "vue";
2
+ import { PopupListItem as P, Popup as J } from "../popup/popup.js";
3
+ import { _ as b, C as z } from "../.chunks/forms-64632f73.es.js";
4
+ import "../popup/worker.js";
5
+ import("../core/core.js").then((t) => {
6
+ const e = ["../assets/tabsView.css"].map((o) => import.meta.resolve(o));
7
+ t.default.Page.addCss(e);
8
+ });
9
+ const R = (t, e) => (N(t, e), e), q = (t) => {
10
+ const e = O(t);
11
+ if (!e)
12
+ throw Error("Попытка использовать tabsView state до его инициализации");
13
+ return e;
14
+ }, k = (t, e) => `top:tabsView:${String(t)}:${e}`, G = (t, e) => {
15
+ if (!e.key)
16
+ return;
17
+ const o = k(t, e.key);
18
+ try {
19
+ const n = JSON.parse(localStorage.getItem(o));
20
+ typeof n == typeof e[t] && (e[t] = n);
21
+ } catch {
22
+ console.warn(new Error(`В localStorage[${o}] не корректный json`));
23
+ }
24
+ }, H = (t, e) => {
25
+ if (!e.key)
26
+ return;
27
+ const o = k(t, e.key);
28
+ B(L(e, t), () => {
29
+ localStorage.setItem(o, JSON.stringify(e[t]));
30
+ }, { immediate: !0 });
31
+ }, f = {
32
+ init: R,
33
+ use: q,
34
+ loadLocalStorge: G,
35
+ addSaverLocalStorge: H
36
+ }, T = Symbol(), Q = (t, e) => {
37
+ const o = C({
38
+ key: t.keyForSaveState,
39
+ showMenuInPopup: t.showMenuInPopup,
40
+ isShort: !1,
41
+ activeItemName: S({
42
+ get() {
43
+ return t.modelValue;
44
+ },
45
+ set(n) {
46
+ e("update:modelValue", n);
47
+ }
48
+ })
49
+ });
50
+ return U(t, o), f.init(T, o);
51
+ }, y = () => f.use(T), U = (t, e) => {
52
+ if (t.isShortable) {
53
+ const o = "isShort";
54
+ f.loadLocalStorge(o, e), f.addSaverLocalStorge(o, e);
55
+ }
56
+ }, W = {
57
+ key: 1,
58
+ class: "top-ellipsis"
59
+ }, X = /* @__PURE__ */ w({
60
+ __name: "menuItem",
61
+ props: {
62
+ name: {},
63
+ href: {},
64
+ icon: {},
65
+ disabled: { type: Boolean }
66
+ },
67
+ setup(t) {
68
+ const e = t, o = S(() => n.showMenuInPopup ? P : e.href ? "a" : "button"), n = y();
69
+ return (a, l) => (i(), d(D(o.value), {
70
+ class: h({
71
+ "top-tabsView_menuItem": !s(n).showMenuInPopup,
72
+ "top-active": a.name && s(n).activeItemName === a.name,
73
+ "top-disabled": a.disabled
74
+ }),
75
+ href: a.href,
76
+ "data-top-icon": a.icon || void 0,
77
+ disabled: a.disabled || void 0,
78
+ onClick: l[0] || (l[0] = (p) => a.name ? s(n).activeItemName = a.name : null)
79
+ }, {
80
+ default: m(() => [
81
+ s(n).showMenuInPopup ? u(a.$slots, "default", { key: 0 }) : a.$slots.default && !s(n).isShort ? (i(), c("span", W, [
82
+ u(a.$slots, "default")
83
+ ])) : V("", !0)
84
+ ]),
85
+ _: 3
86
+ }, 8, ["class", "href", "data-top-icon", "disabled"]));
87
+ }
88
+ }), Y = {
89
+ "top-tabsView_menuItem": "top-tabsView_menuItem",
90
+ "top-active": "top-active",
91
+ "top-forms-option": "top-forms-option",
92
+ "top-formsCaption": "top-formsCaption",
93
+ "top-disabled": "top-disabled"
94
+ }, Z = {
95
+ $style: Y
96
+ }, g = /* @__PURE__ */ b(X, [["__cssModules", Z]]), x = { class: "top-tabsView_menuOpener" }, ee = ["data-top-icon"], te = { class: "top-ellipsis" }, oe = /* @__PURE__ */ _("div", {
97
+ class: "top-tabsView_menuOpenerIcon",
98
+ "data-top-icon": ""
99
+ }, null, -1), se = { class: "top-tabsView_menuList" }, ne = /* @__PURE__ */ w({
100
+ __name: "menu",
101
+ props: {
102
+ isShortable: { type: Boolean }
103
+ },
104
+ setup(t) {
105
+ const e = y(), o = E(), n = /* @__PURE__ */ new Map(), a = S(() => {
106
+ let p = n.get(e.activeItemName);
107
+ return p || (l(), n.get(e.activeItemName) || null);
108
+ }), l = () => {
109
+ if (!o.default)
110
+ return;
111
+ const p = o.default().find((r) => r.key === "_menu");
112
+ p && p.children.forEach((r) => {
113
+ var I, $;
114
+ if (r.type.__name !== g.__name || !r.props.name)
115
+ return;
116
+ const v = {
117
+ title: (($ = (I = r.children).default) == null ? void 0 : $.call(I)[0].children).trim(),
118
+ icon: r.props.icon
119
+ };
120
+ n.set(r.props.name, v);
121
+ });
122
+ };
123
+ return (p, r) => (i(), c("div", {
124
+ class: h({
125
+ "top-tabsView_menu": !0,
126
+ "top-tabsView_menu-inPopup_0": !s(e).showMenuInPopup,
127
+ "top-tabsView_menu-inPopup_1": s(e).showMenuInPopup,
128
+ "top-tabsView_menu-short": s(e).isShort && !s(e).showMenuInPopup
129
+ })
130
+ }, [
131
+ s(e).showMenuInPopup ? (i(), d(s(J), { key: 0 }, {
132
+ opener: m(() => [
133
+ _("div", x, [
134
+ a.value ? (i(), c("div", {
135
+ key: 0,
136
+ class: "top-tabsView_menuOpenerActiveItem",
137
+ "data-top-icon": a.value.icon
138
+ }, [
139
+ _("span", te, M(a.value.title), 1)
140
+ ], 8, ee)) : V("", !0),
141
+ oe
142
+ ])
143
+ ]),
144
+ contentList: m(() => [
145
+ u(p.$slots, "default")
146
+ ]),
147
+ _: 3
148
+ })) : (i(), c(K, { key: 1 }, [
149
+ _("div", se, [
150
+ u(p.$slots, "default")
151
+ ]),
152
+ p.isShortable ? (i(), d(g, {
153
+ key: 0,
154
+ icon: s(e).isShort ? "" : "",
155
+ onClick: r[0] || (r[0] = (v) => s(e).isShort = !s(e).isShort)
156
+ }, {
157
+ default: m(() => [
158
+ j(M(s(e).isShort ? "" : "Свернуть") + " ", 1)
159
+ ]),
160
+ _: 1
161
+ }, 8, ["icon"])) : V("", !0)
162
+ ], 64))
163
+ ], 2));
164
+ }
165
+ }), ae = {
166
+ "top-tabsView_menu-inPopup_0": "top-tabsView_menu-inPopup_0",
167
+ "top-tabsView_menu-inPopup_1": "top-tabsView_menu-inPopup_1",
168
+ "top-tabsView_menu-short": "top-tabsView_menu-short",
169
+ "top-tabsView_menu": "top-tabsView_menu",
170
+ "top-tabsView_menuOpener": "top-tabsView_menuOpener",
171
+ "top-tabsView_menuOpenerIcon": "top-tabsView_menuOpenerIcon",
172
+ "top-tabsView_menuOpenerActiveItem": "top-tabsView_menuOpenerActiveItem",
173
+ "top-tabsView_menuList": "top-tabsView_menuList"
174
+ }, ie = {
175
+ $style: ae
176
+ }, pe = /* @__PURE__ */ b(ne, [["__cssModules", ie]]), re = { class: "top-tabsView_contents" }, ue = /* @__PURE__ */ w({
177
+ __name: "tabsView",
178
+ props: {
179
+ modelValue: {},
180
+ showMenuInPopup: { type: Boolean },
181
+ isShortable: { type: Boolean, default: !1 },
182
+ keyForSaveState: {}
183
+ },
184
+ emits: ["update:modelValue"],
185
+ setup(t, { emit: e }) {
186
+ const o = t, a = Q(o, e);
187
+ return A(() => {
188
+ a.showMenuInPopup = o.showMenuInPopup ?? z.state.isMobile;
189
+ }), (l, p) => (i(), c("div", {
190
+ class: h({
191
+ "top-tabsView": !0,
192
+ "top-tabsView-inPopup": s(a).showMenuInPopup
193
+ })
194
+ }, [
195
+ F(pe, { isShortable: l.isShortable }, {
196
+ default: m(() => [
197
+ u(l.$slots, "menu")
198
+ ]),
199
+ _: 3
200
+ }, 8, ["isShortable"]),
201
+ _("div", re, [
202
+ u(l.$slots, "contents")
203
+ ])
204
+ ], 2));
205
+ }
206
+ }), le = {
207
+ "top-tabsView": "top-tabsView",
208
+ "top-tabsView-inPopup": "top-tabsView-inPopup",
209
+ "top-tabsView_contents": "top-tabsView_contents"
210
+ }, ce = {
211
+ $style: le
212
+ }, ge = /* @__PURE__ */ b(ue, [["__cssModules", ce]]), me = {
213
+ "top-tabsView_menuDelimeter": "top-tabsView_menuDelimeter"
214
+ }, _e = {}, de = { class: "top-tabsView_menuDelimeter" };
215
+ function we(t, e) {
216
+ return i(), c("div", de);
217
+ }
218
+ const be = {
219
+ $style: me
220
+ }, Ve = /* @__PURE__ */ b(_e, [["render", we], ["__cssModules", be]]), fe = /* @__PURE__ */ w({
221
+ __name: "menuTitle",
222
+ props: {
223
+ isSubtitle: { type: Boolean }
224
+ },
225
+ setup(t) {
226
+ const e = y();
227
+ return (o, n) => s(e).showMenuInPopup ? (i(), d(s(P), {
228
+ key: 0,
229
+ type: "title"
230
+ }, {
231
+ default: m(() => [
232
+ u(o.$slots, "default")
233
+ ]),
234
+ _: 3
235
+ })) : s(e).isShort ? (i(), d(Ve, { key: 1 })) : (i(), c("div", {
236
+ key: 2,
237
+ class: h({
238
+ "top-tabsView_menuTitle": !0,
239
+ "top-tabsView_menuTitle-subtitle": o.isSubtitle
240
+ })
241
+ }, [
242
+ u(o.$slots, "default")
243
+ ], 2));
244
+ }
245
+ }), he = {
246
+ "top-tabsView_menuTitle": "top-tabsView_menuTitle",
247
+ "top-tabsView_menuTitle-subtitle": "top-tabsView_menuTitle-subtitle"
248
+ }, ye = {
249
+ $style: he
250
+ }, Pe = /* @__PURE__ */ b(fe, [["__cssModules", ye]]), Se = {
251
+ key: 0,
252
+ class: "top-tabsView_content"
253
+ }, ke = /* @__PURE__ */ w({
254
+ __name: "content",
255
+ props: {
256
+ name: {}
257
+ },
258
+ setup(t) {
259
+ const e = y();
260
+ return (o, n) => s(e).activeItemName === o.name ? (i(), c("div", Se, [
261
+ u(o.$slots, "default")
262
+ ])) : V("", !0);
263
+ }
264
+ });
265
+ export {
266
+ ge as TabsView,
267
+ ke as TabsViewContent,
268
+ g as TabsViewMenuItem,
269
+ Pe as TabsViewMenuTitle
270
+ };
271
+ //# sourceMappingURL=tabsView.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabsView.js","sources":["../../src/components/stateManager.ts","../../src/components/tabsView/tabsView/state.ts","../../src/components/tabsView/tabsView/menuItem.vue","../../src/components/tabsView/tabsView/menu.vue","../../src/components/tabsView/tabsView/tabsView.vue","../../src/components/tabsView/tabsView/menuDelimeter.vue","../../src/components/tabsView/tabsView/menuTitle.vue","../../src/components/tabsView/tabsView/content.vue"],"sourcesContent":["import { provide, inject, toRef, watch } from 'vue';\nimport type { InjectionKey } from 'vue';\nimport { injectionKey } from '@/components/tabsView/tabsView/state';\n\n/**\n * State - интерфейс с общими параметрами для состояния компоента\n */\nexport interface State {\n\t/**\n\t * Ключ для сохранения состояния\n\t *\n\t * Может быть одинаковый для разных компонентов\n\t *\n\t * Не может быть реактивным\n\t *\n\t * Состояния сохраняются в localStorage с префиксом top\n\t */\n\tkey?: string;\n}\n\n/**\n * Инициировать State компонента\n * @param key - InjectionKey для provide / inject в области компонента\n * @param state\n * @return - State компонента\n */\nconst init = <T>(injectionKey: InjectionKey<T>, state: T): T => {\n\tprovide(injectionKey, state);\n\n\treturn state;\n};\n\n/**\n * Получить State компонента\n * @param key - InjectionKey для provide / inject в области компонента\n * @return - State компонента\n */\nconst use = <T>(injectionKey: InjectionKey<T>): T => {\n\tconst state = inject(injectionKey);\n\n\tif (!state) {\n\t\tthrow Error('Попытка использовать tabsView state до его инициализации');\n\t}\n\n\treturn state;\n};\n\n/**\n * Сгенерировать имя для сохранения данных в localStorage\n * @param stateName - имя свойства состояния\n * @param stateKey - ключ состояния, разные компоненты могут использовать одинаковый ключ\n */\nconst genStorageKey = <T extends State>(stateName: keyof T, stateKey: string): string => {\n\tconst stateNameString = String(stateName);\n\n\treturn `top:tabsView:${stateNameString}:${stateKey}`;\n};\n\n/**\n * Загрузить состояние\n * @param stateName - имя свойства состояния\n * @param state\n */\nconst loadLocalStorge = <T extends State>(stateName: keyof T, state: T) => {\n\t// если state.key не знадан, значит сохранение состояния в компоненте отключено\n\tif (!state.key) return;\n\n\tconst localStorageKey = genStorageKey(stateName, state.key);\n\n\ttry {\n\t\tconst localStorageValue: typeof state[keyof typeof state] = JSON.parse(localStorage.getItem(localStorageKey) as string);\n\n\t\tif (typeof localStorageValue === typeof state[stateName]) {\n\t\t\tstate[stateName] = localStorageValue;\n\t\t}\n\t} catch (e) {\n\t\tconsole.warn(new Error(`В localStorage[${localStorageKey}] не корректный json`));\n\t}\n};\n\n/**\n * Добавить автосохранение состояние при его изменении\n * @param stateName - имя свойства состояния\n * @param state\n */\nconst addSaverLocalStorge = <T extends State>(stateName: keyof T, state: T) => {\n\t// если state.key не знадан, значит сохранение состояния в компоненте отключено\n\tif (!state.key) return;\n\n\tconst localStorageKey = genStorageKey(stateName, state.key);\n\n\twatch(toRef(state, stateName), () => {\n\t\tlocalStorage.setItem(localStorageKey, JSON.stringify(state[stateName]));\n\t}, { immediate: true });\n};\n\nexport default {\n\tinit,\n\tuse,\n\tloadLocalStorge,\n\taddSaverLocalStorge,\n};","import { reactive, computed } from 'vue';\nimport type { InjectionKey } from 'vue';\nimport type { State } from './tabsView';\nimport type { Emits, Props } from './tabsView';\nimport stateManager from '@/components/stateManager';\n\nexport const injectionKey = Symbol() as InjectionKey<State>;\n\n/**\n * Инициировать State компонента\n * @param props\n * @param emit\n */\nexport const initState = (props: Props, emit: Emits): State => {\n\tconst state: State = reactive({\n\t\tkey: props.keyForSaveState,\n\t\tshowMenuInPopup: props.showMenuInPopup,\n\t\tisShort: false,\n\t\tactiveItemName: computed({\n\t\t\tget() {\n\t\t\t\treturn props.modelValue;\n\t\t\t},\n\t\t\tset(value) {\n\t\t\t\temit('update:modelValue', value);\n\t\t\t},\n\t\t}),\n\t});\n\n\tinitLocalStorge(props, state);\n\n\treturn stateManager.init(injectionKey, state);\n};\n\n/**\n * Получить State компонента\n */\nexport const useState = () => {\n\treturn stateManager.use(injectionKey);\n};\n\n/**\n * Инициировать работу LocalStorge\n * @param props\n * @param state\n */\nconst initLocalStorge = (props: Props, state: State): void => {\n\tif (props.isShortable) {\n\t\tconst stateName = 'isShort';\n\n\t\tstateManager.loadLocalStorge(stateName, state);\n\t\tstateManager.addSaverLocalStorge(stateName, state);\n\t}\n};","<script setup lang=\"ts\">\nimport { computed } from 'vue';\nimport { useState } from './state';\nimport type { PropsMenuItem, State } from './tabsView';\nimport { PopupListItem } from '../../popup/popup';\n\nconst props = defineProps<PropsMenuItem>();\n\nconst componentName = computed(() => {\n\tif (state.showMenuInPopup) {\n\t\treturn PopupListItem;\n\t}\n\n\treturn props.href ? 'a' : 'button';\n});\n\nconst state = useState();\n</script>\n\n<template>\n\t<component\n\t\t:is=\"componentName\"\n\t\t:class=\"{\n\t\t\t['top-tabsView_menuItem']: !state.showMenuInPopup,\n\t\t\t['top-active']: name && state.activeItemName === name,\n\t\t\t['top-disabled']: disabled,\n\t\t}\"\n\t\t:href=\"href\"\n\t\t:data-top-icon=\"icon || undefined\"\n\t\t:disabled=\"disabled || undefined\"\n\t\t@click=\"name ? state.activeItemName = name : null\"\n\t>\n\t\t<slot v-if=\"state.showMenuInPopup\"></slot>\n\n\t\t<span\n\t\t\tv-else-if=\"$slots.default && !state.isShort\"\n\t\t\tclass=\"top-ellipsis\"\n\t\t>\n\t\t\t<slot></slot>\n\t\t</span>\n\t</component>\n</template>\n\n<style module>\n.top-tabsView_menuItem {\n\t--top-icon-color: var(--color-text-1);\n\t--top-icon-width: calc(var(--top-icon-size));\n\n\tcursor: pointer;\n\tbox-sizing: border-box;\n\n\tborder: none;\n\tborder-radius: var(--top-radius-2);\n\tpadding: var(--top-padding-2);\n\tbackground: transparent;\n\theight: 40px;\n\n\tcolor: var(--color-text-1);\n\ttext-align: left;\n\ttext-decoration: none;\n\twhite-space: nowrap;\n\n\tdisplay: flex;\n\tgap: var(--top-gap-2);\n\talign-items: center;\n\tjustify-content: flex-start;\n\ttransition: background var(--transition);\n}\n\n.top-tabsView_menuItem:hover {\n\tbackground: var(--color-secondary-2-opacity);\n}\n\n.top-tabsView_menuItem.top-active {\n\t--top-icon-color: var(--color-primary);\n\n\tcursor: unset;\n\tbackground: var(--color-bg-3);\n\tcolor: var(--color-primary);\n}\n\n.top-tabsView_menuItem:disabled:not(option):not(optgroup):not(.top-forms-option),\n.top-tabsView_menuItem:disabled ~ .top-formsCaption,\n.top-tabsView_menuItem.top-disabled[data-top-icon]:before,\n.top-tabsView_menuItem.top-disabled[data-top-icon2]:after {\n\topacity: unset;\n\tfilter: unset;\n}\n\n.top-tabsView_menuItem.top-disabled {\n\t--top-icon-color: var(--color-text-4);\n\n\tcolor: var(--color-text-4);\n}\n</style>","<script setup lang=\"ts\">\nimport { computed, useSlots } from 'vue';\nimport type { ComputedRef } from '@vue/reactivity';\nimport { Popup } from '../../popup/popup';\n\nimport type { PropsMenu, PropsMenuItem, MenuItem } from './tabsView';\nimport { useState } from './state';\nimport TabsViewMenuItem from './menuItem.vue';\n\ndefineProps<PropsMenu>();\n\nconst state = useState();\n\nconst slots = useSlots();\n\n// словарь испоьзуется для оптимизации получения нужного menuItem\nconst menuItemByName: Map<PropsMenuItem['name'], MenuItem> = new Map();\n\n// activeMenuItem нужен для вывода текста активной вкладки в меню с popup\n// смена slot, например смена языка, требует повторного выполнения genMenuItemByName()\nconst activeMenuItem: ComputedRef<MenuItem | null> = computed(() => {\n\tlet menuItem = menuItemByName.get(state.activeItemName);\n\tif (menuItem) return menuItem;\n\n\tgenMenuItemByName();\n\n\treturn menuItemByName.get(state.activeItemName) || null;\n});\n\n// сгенерировать словарь с menuItem, по элементам в slot\nconst genMenuItemByName = () => {\n\tif (!slots.default) return;\n\n\tconst component: any = slots.default().find(item => item.key === '_menu');\n\tif (!component) return;\n\n\tcomponent.children.forEach((subComponent: any) => {\n\t\tif (subComponent.type.__name !== TabsViewMenuItem.__name) return;\n\t\tif (!subComponent.props.name) return;\n\n\t\tconst menuItem = {\n\t\t\ttitle: (subComponent.children.default?.()[0].children as string).trim(),\n\t\t\ticon: subComponent.props.icon,\n\t\t};\n\n\t\tmenuItemByName.set(subComponent.props.name, menuItem);\n\t});\n};\n</script>\n\n<template>\n\t<div\n\t\t:class=\"{\n\t\t\t'top-tabsView_menu': true,\n\t\t\t'top-tabsView_menu-inPopup_0': !state.showMenuInPopup,\n\t\t\t'top-tabsView_menu-inPopup_1': state.showMenuInPopup,\n\t\t\t'top-tabsView_menu-short': state.isShort && !state.showMenuInPopup,\n\t\t}\"\n\t>\n\t\t<!-- Спрятать меню под кнопку в popup -->\n\t\t<Popup v-if=\"state.showMenuInPopup\">\n\t\t\t<template #opener>\n\t\t\t\t<div class=\"top-tabsView_menuOpener\">\n\t\t\t\t\t<div\n\t\t\t\t\t\tv-if=\"activeMenuItem\"\n\t\t\t\t\t\tclass=\"top-tabsView_menuOpenerActiveItem\"\n\t\t\t\t\t\t:data-top-icon=\"activeMenuItem.icon\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<span class=\"top-ellipsis\">\n\t\t\t\t\t\t\t{{ activeMenuItem.title }}\n\t\t\t\t\t\t</span>\n\t\t\t\t\t</div>\n\n\t\t\t\t\t<div class=\"top-tabsView_menuOpenerIcon\" data-top-icon=\"\"></div>\n\t\t\t\t</div>\n\t\t\t</template>\n\n\t\t\t<template #contentList>\n\t\t\t\t<slot></slot>\n\t\t\t</template>\n\t\t</Popup>\n\n\t\t<!-- Отобразить меню на старнице -->\n\t\t<template v-else>\n\t\t\t<div class=\"top-tabsView_menuList\">\n\t\t\t\t<slot></slot>\n\t\t\t</div>\n\n\t\t\t<TabsViewMenuItem\n\t\t\t\tv-if=\"isShortable\"\n\t\t\t\t:icon=\"state.isShort ? '' : ''\"\n\t\t\t\t@click=\"state.isShort = !state.isShort\"\n\t\t\t>\n\t\t\t\t{{ state.isShort ? '' : 'Свернуть' }} <!--TODO: translate-->\n\t\t\t</TabsViewMenuItem>\n\t\t</template>\n\t</div>\n</template>\n\n<style module>\n.top-tabsView_menu-inPopup_0 {\n\tbox-sizing: border-box;\n\tbackground: var(--color-bg-2);\n\twidth: var(--top-tabsView-menu-width);\n\tpadding: var(--top-padding-2);\n\tdisplay: flex;\n\tflex-direction: column;\n\tjustify-content: space-between;\n}\n\n.top-tabsView_menu-inPopup_1 {\n\tborder-bottom: 1px solid var(--color-line-2-opacity);\n}\n\n.top-tabsView_menu-short {\n\twidth: auto;\n}\n\n.top-tabsView_menu .top-tabsView_menuOpener {\n\tdisplay: flex;\n\tjustify-content: flex-end;\n}\n\n.top-tabsView_menu .top-tabsView_menuOpener:hover {\n\tbackground: var(--color-secondary-opacity);\n}\n\n.top-tabsView_menuOpenerIcon { display: flex; }\n\n.top-tabsView_menuOpenerActiveItem {\n\t--top-forms-padding: 0px;\n\n\tbox-sizing: border-box;\n\tpadding: var(--top-padding-2);\n\tmax-width: calc(100% - var(--top-forms-base-height));\n\twhite-space: nowrap;\n\tflex-grow: 1;\n\tdisplay: flex;\n\talign-items: center;\n\tgap: var(--top-padding-2);\n}\n\n.top-tabsView_menuList {\n\tdisplay: flex;\n\tflex-direction: column;\n\tgap: var(--top-gap-2);\n}\n</style>","<script setup lang=\"ts\">\nimport { watchEffect } from 'vue';\nimport type { Props, Emits } from './tabsView';\nimport { initState } from './state';\nimport TabsViewMenu from './menu.vue';\nimport Core from '@/core/core/core';\n\nconst props = withDefaults(defineProps<Props>(), {\n\tisShortable: false,\n});\n\nconst emit = defineEmits<Emits>();\n\nconst state = initState(props, emit);\n\nwatchEffect(() => {\n\tstate.showMenuInPopup = props.showMenuInPopup ?? Core.state.isMobile;\n});\n</script>\n\n<template>\n\t<div\n\t\t:class=\"{\n\t\t\t'top-tabsView': true,\n\t\t\t'top-tabsView-inPopup': state.showMenuInPopup,\n\t\t}\"\n\t>\n\t\t<TabsViewMenu :isShortable=\"isShortable\">\n\t\t\t<!-- @slot Меню, ожидает передачу компонентов TabsViewMenuItem и TabsViewMenuTitle -->\n\t\t\t<slot name=\"menu\"></slot>\n\t\t</TabsViewMenu>\n\n\t\t<div class=\"top-tabsView_contents\">\n\t\t\t<!-- @slot Контент вкладок, ожидает передачу компонентов TabsViewContent, в слоте необходимо предусмотреть вывод неободимого компонента в зависимости от активной вкладки -->\n\t\t\t<slot name=\"contents\"></slot>\n\t\t</div>\n\t</div>\n</template>\n\n<style module>\n:root {\n\t--top-tabsView-menu-width: 190px;\n}\n\n.top-tabsView {\n\twidth: 100%;\n\theight: 100%;\n\tdisplay: flex;\n\tflex-direction: row;\n}\n\n.top-tabsView-inPopup {\n\tflex-direction: column;\n}\n\n.top-tabsView_contents {\n\tpadding: var(--top-padding-4);\n\tflex-grow: 1;\n}\n</style>","<script setup lang=\"ts\">\n\n</script>\n\n<template>\n\t<div class=\"top-tabsView_menuDelimeter\"></div>\n</template>\n\n<style module>\n.top-tabsView_menuDelimeter {\n\tpadding: var(--top-padding-1) 0;\n\tdisplay: flex;\n}\n\n.top-tabsView_menuDelimeter:before {\n\tcontent: \"\";\n\theight: 2px;\n\tbackground: var(--color-line-2-opacity);\n\tflex-grow: 1;\n}\n\n.top-tabsView_menuDelimeter + .top-tabsView_menuDelimeter {\n\tdisplay: none;\n}\n</style>","<script setup lang=\"ts\">\nimport { useState } from './state';\nimport type { PropsMenuTitle, State } from './tabsView';\nimport TabsViewMenuDelimeter from './menuDelimeter.vue';\nimport { PopupListItem } from '../../popup/popup';\n\ndefineProps<PropsMenuTitle>();\n\nconst state = useState();\n</script>\n\n<template>\n\t<PopupListItem\n\t\tv-if=\"state.showMenuInPopup\"\n\t\ttype=\"title\"\n\t>\n\t\t<slot></slot>\n\t</PopupListItem>\n\n\t<TabsViewMenuDelimeter v-else-if=\"state.isShort\"/>\n\n\t<div\n\t\tv-else\n\t\t:class=\"{\n\t\t\t'top-tabsView_menuTitle': true,\n\t\t\t'top-tabsView_menuTitle-subtitle': isSubtitle,\n\t\t}\"\n\t>\n\t\t<slot></slot>\n\t</div>\n</template>\n\n<style module>\n.top-tabsView_menuTitle {\n\tpadding: var(--top-padding-4) var(--top-padding-2) var(--top-padding-1);\n\tfont-weight: 600;\n}\n\n.top-tabsView_menuTitle-subtitle {\n\tpadding-top: var(--top-padding-1);\n\tfont-size: 12px;\n\tfont-weight: 400;\n\tcolor: var(--color-text-2);\n}\n</style>","<script setup lang=\"ts\">\nimport { useState } from './state';\nimport type { PropsContent } from './tabsView';\n\ndefineProps<PropsContent>();\n\nconst state = useState();\n</script>\n\n<template>\n\t<div\n\t\tv-if=\"state.activeItemName === name\"\n\t\tclass=\"top-tabsView_content\"\n\t>\n\t\t<slot></slot>\n\t</div>\n</template>\n\n<style module>\n\n</style>"],"names":["init","injectionKey2","state","provide","use","inject","genStorageKey","stateName","stateKey","loadLocalStorge","localStorageKey","localStorageValue","addSaverLocalStorge","watch","toRef","stateManager","injectionKey","initState","props","emit","reactive","computed","value","initLocalStorge","useState","__props","componentName","_sfc_main$6","slots","useSlots","menuItemByName","activeMenuItem","menuItem","genMenuItemByName","component","item","subComponent","TabsViewMenuItem","_b","_a","__emit","watchEffect","Core","_sfc_render","_ctx","_cache"],"mappings":";;;;;;;;AA0BA,MAAAA,IAAA,CAAAC,GAAAC,OACCC,EAAAF,GAAAC,CAAA,GAEAA,IAQDE,IAAA,CAAAH,MAAA;AACC,QAAAC,IAAAG,EAAAJ,CAAA;AAEA,MAAA,CAAAC;AACC,UAAA,MAAA,0DAAA;AAGD,SAAAA;AACD,GAOAI,IAAA,CAAAC,GAAAC,MAGC,gBAFA,OAAAD,CAAA,CAEA,IAAAC,CAAA,IAQDC,IAAA,CAAAF,GAAAL,MAAA;AAEC,MAAA,CAAAA,EAAA;AAAgB;AAEhB,QAAAQ,IAAAJ,EAAAC,GAAAL,EAAA,GAAA;AAEA,MAAA;AACC,UAAAS,IAAA,KAAA,MAAA,aAAA,QAAAD,CAAA,CAAA;AAEA,IAAA,OAAAC,KAAA,OAAAT,EAAAK,CAAA,MACCL,EAAAK,CAAA,IAAAI;AAAA,EACD,QAAA;AAEA,YAAA,KAAA,IAAA,MAAA,kBAAAD,CAAA,sBAAA,CAAA;AAAA,EAA+E;AAEjF,GAOAE,IAAA,CAAAL,GAAAL,MAAA;AAEC,MAAA,CAAAA,EAAA;AAAgB;AAEhB,QAAAQ,IAAAJ,EAAAC,GAAAL,EAAA,GAAA;AAEA,EAAAW,EAAAC,EAAAZ,GAAAK,CAAA,GAAA,MAAA;AACC,iBAAA,QAAAG,GAAA,KAAA,UAAAR,EAAAK,CAAA,CAAA,CAAA;AAAA,EAAsE,GAAA,EAAA,WAAA,GAAA,CAAA;AAExE,GAEAQ,IAAA;AAAA,EAAe,MAAAf;AAAA,EACd,KAAAI;AAAA,EACA,iBAAAK;AAAA,EACA,qBAAAG;AAED,GC/FOI,IAAA,OAAA,GAOMC,IAAA,CAAAC,GAAAC,MAAA;AACZ,QAAAjB,IAAAkB,EAAA;AAAA,IAA8B,KAAAF,EAAA;AAAA,IAClB,iBAAAA,EAAA;AAAA,IACY,SAAA;AAAA,IACd,gBAAAG,EAAA;AAAA,MACgB,MAAA;AAEvB,eAAAH,EAAA;AAAA,MAAa;AAAA,MACd,IAAAI,GAAA;AAEC,QAAAH,EAAA,qBAAAG,CAAA;AAAA,MAA+B;AAAA,IAChC,CAAA;AAAA,EACA,CAAA;AAGF,SAAAC,EAAAL,GAAAhB,CAAA,GAEAa,EAAA,KAAAC,GAAAd,CAAA;AACD,GAKOsB,IAAA,MACNT,EAAA,IAAAC,CAAA,GAQDO,IAAA,CAAAL,GAAAhB,MAAA;AACC,MAAAgB,EAAA,aAAA;AACC,UAAAX,IAAA;AAEA,IAAAQ,EAAA,gBAAAR,GAAAL,CAAA,GACAa,EAAA,oBAAAR,GAAAL,CAAA;AAAA,EAAiD;AAEnD;;;;;;;;;;;;AC9CA,UAAAgB,IAAAO,GAEAC,IAAAL,EAAA,MACCnB,EAAA,kBACCyB,IAGDT,EAAA,OAAA,MAAA,QAA0B,GAG3BhB,IAAAsB,EAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACLA,UAAAtB,IAAAsB,EAAA,GAEAI,IAAAC,EAAA,GAGAC,IAAA,oBAAA,IAAA,GAIAC,IAAAV,EAAA,MAAA;AACC,UAAAW,IAAAF,EAAA,IAAA5B,EAAA,cAAA;AACA,aAAA8B,MAEAC,EAAA,GAEAH,EAAA,IAAA5B,EAAA,cAAA,KAAA;AAAA,IAAmD,CAAA,GAIpD+B,IAAA,MAAA;AACC,UAAA,CAAAL,EAAA;AAAoB;AAEpB,YAAAM,IAAAN,EAAA,QAAA,EAAA,KAAA,CAAAO,MAAAA,EAAA,QAAA,OAAA;AACA,MAAAD,KAEAA,EAAA,SAAA,QAAA,CAAAE,MAAA;;AAEC,YADAA,EAAA,KAAA,WAAAC,EAAA,UACA,CAAAD,EAAA,MAAA;AAA8B;AAE9B,cAAAJ,IAAA;AAAA,UAAiB,SAAAM,KAAAC,IAAAH,EAAA,UAAA,YAAA,gBAAAE,EAAA,KAAAC,GAAA,GAAA,UAAA,KAAA;AAAA,UACsD,MAAAH,EAAA,MAAA;AAAA,QAC7C;AAG1B,QAAAN,EAAA,IAAAM,EAAA,MAAA,MAAAJ,CAAA;AAAA,MAAoD,CAAA;AAAA,IACpD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACvCF,UAAAd,IAAAO,GAMAvB,IAAAe,EAAAC,GAFAsB,CAEA;AAEA,WAAAC,EAAA,MAAA;AACC,MAAAvC,EAAA,kBAAAgB,EAAA,mBAAAwB,EAAA,MAAA;AAAA,IAA4D,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;ACX5D,SAAAC,GAAAC,GAAAC,GAAA;;;;;;;;;;;ACGD,UAAA3C,IAAAsB,EAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACFA,UAAAtB,IAAAsB,EAAA;;;;;;"}
package/utils/date.amd.js CHANGED
@@ -1,2 +1,2 @@
1
- define(["require","../.chunks/forms-771091d4.amd","vue"],function(i,u,e){"use strict";if(typeof e>"u")var e=window.Vue;return u.UtilsDate});
1
+ define(["require","exports","../.chunks/forms-30d68077.amd","vue"],function(n,e,t,a){"use strict";if(typeof a>"u")var a=window.Vue;e.dateFormat=t.dateFormat,e.dateUnformat=t.dateUnformat,e.genDate=t.genDate,e.stringToDate=t.stringToDate,Object.defineProperty(e,Symbol.toStringTag,{value:"Module"})});
2
2
  //# sourceMappingURL=date.amd.js.map
package/utils/date.d.ts CHANGED
@@ -1,3 +1 @@
1
1
  export * from '../src/core/utils/date'
2
- import Lib from '../src/core/utils/date'
3
- export default Lib
package/utils/date.js CHANGED
@@ -1,6 +1,9 @@
1
- import { U as a } from "../.chunks/forms-727cc6aa.es.js";
1
+ import { d as o, h as r, f as s, s as m } from "../.chunks/forms-64632f73.es.js";
2
2
  import "vue";
3
3
  export {
4
- a as default
4
+ o as dateFormat,
5
+ r as dateUnformat,
6
+ s as genDate,
7
+ m as stringToDate
5
8
  };
6
9
  //# sourceMappingURL=date.js.map
@@ -1,2 +1,2 @@
1
- define(["require","../.chunks/forms-771091d4.amd","vue"],function(i,u,e){"use strict";if(typeof e>"u")var e=window.Vue;return u.Device});
1
+ define(["require","exports","../.chunks/forms-30d68077.amd","vue"],function(n,i,e,a){"use strict";if(typeof a>"u")var a=window.Vue;i.getCommandKeyLabel=e.getCommandKeyLabel,i.isApp=e.isApp,i.isMacOS=e.isMacOS,i.isMobile=e.isMobile,i.isRetina=e.isRetina,i.isSafari=e.isSafari,Object.defineProperty(i,Symbol.toStringTag,{value:"Module"})});
2
2
  //# sourceMappingURL=device.amd.js.map
package/utils/device.d.ts CHANGED
@@ -1,3 +1 @@
1
1
  export * from '../src/core/utils/device'
2
- import Lib from '../src/core/utils/device'
3
- export default Lib
package/utils/device.js CHANGED
@@ -1,6 +1,11 @@
1
- import { a as t } from "../.chunks/forms-727cc6aa.es.js";
1
+ import { g as e, b as o, c as m, a as p, i as r, e as t } from "../.chunks/forms-64632f73.es.js";
2
2
  import "vue";
3
3
  export {
4
- t as default
4
+ e as getCommandKeyLabel,
5
+ o as isApp,
6
+ m as isMacOS,
7
+ p as isMobile,
8
+ r as isRetina,
9
+ t as isSafari
5
10
  };
6
11
  //# sourceMappingURL=device.js.map
package/utils/dom.amd.js CHANGED
@@ -1,2 +1,2 @@
1
- define(["require","../.chunks/forms-771091d4.amd","vue"],function(r,u,e){"use strict";if(typeof e>"u")var e=window.Vue;return u.DOM});
1
+ define(["require","../.chunks/forms-30d68077.amd","vue"],function(r,u,e){"use strict";if(typeof e>"u")var e=window.Vue;return u.DOM});
2
2
  //# sourceMappingURL=dom.amd.js.map
package/utils/dom.d.ts CHANGED
@@ -1,3 +1,3 @@
1
1
  export * from '../src/core/utils/dom'
2
- import Lib from '../src/core/utils/dom'
3
- export default Lib
2
+ import topvisorui from '../src/core/utils/dom'
3
+ export default topvisorui
package/utils/dom.js CHANGED
@@ -1,4 +1,4 @@
1
- import { D as a } from "../.chunks/forms-727cc6aa.es.js";
1
+ import { D as a } from "../.chunks/forms-64632f73.es.js";
2
2
  import "vue";
3
3
  export {
4
4
  a as default