@sugarat/easypicker2-client 2.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +86 -0
- package/dist/assets/aria-bc8e8b0f.js +2 -0
- package/dist/assets/aria-bc8e8b0f.js.map +1 -0
- package/dist/assets/aria-legacy.af0825d3.js +2 -0
- package/dist/assets/data-analysis-13490516.js +2 -0
- package/dist/assets/data-analysis-13490516.js.map +1 -0
- package/dist/assets/data-analysis-legacy.f8612e65.js +2 -0
- package/dist/assets/data-board-229a3bf5.js +2 -0
- package/dist/assets/data-board-229a3bf5.js.map +1 -0
- package/dist/assets/data-board-legacy.a60c4519.js +2 -0
- package/dist/assets/el-date-picker-5a3e3d86.js +2 -0
- package/dist/assets/el-date-picker-5a3e3d86.js.map +1 -0
- package/dist/assets/el-date-picker-cf2e83b6.css +1 -0
- package/dist/assets/el-date-picker-legacy.6d67764b.js +2 -0
- package/dist/assets/el-dialog-25bd2fb8.css +1 -0
- package/dist/assets/el-dialog-463960e0.js +2 -0
- package/dist/assets/el-dialog-463960e0.js.map +1 -0
- package/dist/assets/el-dialog-legacy.0bcf48a4.js +2 -0
- package/dist/assets/el-dropdown-item-0c6ddabc.css +1 -0
- package/dist/assets/el-dropdown-item-7c33f4fa.js +2 -0
- package/dist/assets/el-dropdown-item-7c33f4fa.js.map +1 -0
- package/dist/assets/el-dropdown-item-legacy.8625546e.js +2 -0
- package/dist/assets/el-form-item-3aad794a.css +1 -0
- package/dist/assets/el-form-item-f40006bf.js +2 -0
- package/dist/assets/el-form-item-f40006bf.js.map +1 -0
- package/dist/assets/el-form-item-legacy.d28db5d0.js +2 -0
- package/dist/assets/el-loading-5d91bb6c.js +2 -0
- package/dist/assets/el-loading-5d91bb6c.js.map +1 -0
- package/dist/assets/el-loading-d0f2d079.css +1 -0
- package/dist/assets/el-loading-legacy.0f35210f.js +2 -0
- package/dist/assets/el-pagination-bf7c736d.css +1 -0
- package/dist/assets/el-pagination-ffb99240.js +2 -0
- package/dist/assets/el-pagination-ffb99240.js.map +1 -0
- package/dist/assets/el-pagination-legacy.25b54e8d.js +2 -0
- package/dist/assets/el-progress-2fff98be.js +2 -0
- package/dist/assets/el-progress-2fff98be.js.map +1 -0
- package/dist/assets/el-progress-63aabe3a.css +1 -0
- package/dist/assets/el-progress-legacy.db8b5855.js +2 -0
- package/dist/assets/el-select-6be23320.css +1 -0
- package/dist/assets/el-select-7d894fd0.js +2 -0
- package/dist/assets/el-select-7d894fd0.js.map +1 -0
- package/dist/assets/el-select-legacy.ad6ded5a.js +2 -0
- package/dist/assets/el-switch-2eda0412.js +2 -0
- package/dist/assets/el-switch-2eda0412.js.map +1 -0
- package/dist/assets/el-switch-aeab2c6b.css +1 -0
- package/dist/assets/el-switch-legacy.e17e7919.js +2 -0
- package/dist/assets/el-tab-pane-4a1bb4c7.css +1 -0
- package/dist/assets/el-tab-pane-b3156067.js +2 -0
- package/dist/assets/el-tab-pane-b3156067.js.map +1 -0
- package/dist/assets/el-tab-pane-legacy.2cf21031.js +2 -0
- package/dist/assets/el-table-column-22352e92.js +21 -0
- package/dist/assets/el-table-column-22352e92.js.map +1 -0
- package/dist/assets/el-table-column-6c2089f9.css +1 -0
- package/dist/assets/el-table-column-legacy.fd665e2a.js +24 -0
- package/dist/assets/index-01e33329.css +1 -0
- package/dist/assets/index-17fa8fb7.js +2 -0
- package/dist/assets/index-17fa8fb7.js.map +1 -0
- package/dist/assets/index-3091894a.css +1 -0
- package/dist/assets/index-34bd5929.js +2 -0
- package/dist/assets/index-34bd5929.js.map +1 -0
- package/dist/assets/index-34fd4f9f.css +1 -0
- package/dist/assets/index-37e15bc6.css +1 -0
- package/dist/assets/index-3f82ab7a.css +1 -0
- package/dist/assets/index-4c81cf78.css +1 -0
- package/dist/assets/index-5f3a9ae0.css +1 -0
- package/dist/assets/index-62c7029f.js +15 -0
- package/dist/assets/index-62c7029f.js.map +1 -0
- package/dist/assets/index-6d7ac779.js +2 -0
- package/dist/assets/index-6d7ac779.js.map +1 -0
- package/dist/assets/index-6f4c911e.js +2 -0
- package/dist/assets/index-6f4c911e.js.map +1 -0
- package/dist/assets/index-75b8c91c.js +2 -0
- package/dist/assets/index-75b8c91c.js.map +1 -0
- package/dist/assets/index-76f31e30.css +1 -0
- package/dist/assets/index-76ff9b9b.css +1 -0
- package/dist/assets/index-82a6b493.css +1 -0
- package/dist/assets/index-8eff6b5a.js +2 -0
- package/dist/assets/index-8eff6b5a.js.map +1 -0
- package/dist/assets/index-93c733b3.css +1 -0
- package/dist/assets/index-98964915.js +2 -0
- package/dist/assets/index-98964915.js.map +1 -0
- package/dist/assets/index-98b55468.css +1 -0
- package/dist/assets/index-9e6bd406.js +2 -0
- package/dist/assets/index-9e6bd406.js.map +1 -0
- package/dist/assets/index-afb7d164.js +2 -0
- package/dist/assets/index-afb7d164.js.map +1 -0
- package/dist/assets/index-b0a4c236.js +2 -0
- package/dist/assets/index-b0a4c236.js.map +1 -0
- package/dist/assets/index-b3774417.js +2 -0
- package/dist/assets/index-b3774417.js.map +1 -0
- package/dist/assets/index-bc1a6d96.js +2 -0
- package/dist/assets/index-bc1a6d96.js.map +1 -0
- package/dist/assets/index-c3a1cd43.js +2 -0
- package/dist/assets/index-c3a1cd43.js.map +1 -0
- package/dist/assets/index-c61deab7.js +2 -0
- package/dist/assets/index-c61deab7.js.map +1 -0
- package/dist/assets/index-c840d3aa.js +2 -0
- package/dist/assets/index-c840d3aa.js.map +1 -0
- package/dist/assets/index-ca90e8da.js +2 -0
- package/dist/assets/index-ca90e8da.js.map +1 -0
- package/dist/assets/index-d32645f3.js +2 -0
- package/dist/assets/index-d32645f3.js.map +1 -0
- package/dist/assets/index-d3ae2239.css +1 -0
- package/dist/assets/index-da51da36.css +1 -0
- package/dist/assets/index-e7d8a83e.css +1 -0
- package/dist/assets/index-eb08e7b7.css +1 -0
- package/dist/assets/index-f298d979.js +2 -0
- package/dist/assets/index-f298d979.js.map +1 -0
- package/dist/assets/index-f31c9ba4.css +1 -0
- package/dist/assets/index-f47a54b0.js +2 -0
- package/dist/assets/index-f47a54b0.js.map +1 -0
- package/dist/assets/index-f6ffb548.js +2 -0
- package/dist/assets/index-f6ffb548.js.map +1 -0
- package/dist/assets/index-legacy.01d9320a.js +2 -0
- package/dist/assets/index-legacy.08663170.js +2 -0
- package/dist/assets/index-legacy.1540c5bc.js +2 -0
- package/dist/assets/index-legacy.189f20a8.js +2 -0
- package/dist/assets/index-legacy.1f2405e5.js +2 -0
- package/dist/assets/index-legacy.45ec3501.js +2 -0
- package/dist/assets/index-legacy.4f956884.js +2 -0
- package/dist/assets/index-legacy.51740a44.js +2 -0
- package/dist/assets/index-legacy.5d174bde.js +2 -0
- package/dist/assets/index-legacy.6c7021b3.js +2 -0
- package/dist/assets/index-legacy.7dae3131.js +2 -0
- package/dist/assets/index-legacy.978f90e1.js +18 -0
- package/dist/assets/index-legacy.9c4986d3.js +2 -0
- package/dist/assets/index-legacy.9dc57803.js +2 -0
- package/dist/assets/index-legacy.9f65dcb9.js +2 -0
- package/dist/assets/index-legacy.bd5a4368.js +2 -0
- package/dist/assets/index-legacy.d32480a5.js +2 -0
- package/dist/assets/index-legacy.d9854cf5.js +2 -0
- package/dist/assets/index-legacy.e6994f0a.js +2 -0
- package/dist/assets/index-legacy.e7464d3c.js +2 -0
- package/dist/assets/index-legacy.f84efe08.js +2 -0
- package/dist/assets/isEqual-9c466456.js +2 -0
- package/dist/assets/isEqual-9c466456.js.map +1 -0
- package/dist/assets/isEqual-legacy.985bb619.js +2 -0
- package/dist/assets/other-8d7ba6a0.js +2 -0
- package/dist/assets/other-8d7ba6a0.js.map +1 -0
- package/dist/assets/other-legacy.39078796.js +2 -0
- package/dist/assets/polyfills-legacy.99e38685.js +4 -0
- package/dist/assets/refresh-6ae903c0.js +2 -0
- package/dist/assets/refresh-6ae903c0.js.map +1 -0
- package/dist/assets/refresh-legacy.8092415a.js +2 -0
- package/dist/assets/tip-00ddf749.js +2 -0
- package/dist/assets/tip-00ddf749.js.map +1 -0
- package/dist/assets/tip-9cb18ee8.css +1 -0
- package/dist/assets/tip-legacy.6e921091.js +2 -0
- package/dist/assets/validator-853854a1.js +2 -0
- package/dist/assets/validator-853854a1.js.map +1 -0
- package/dist/assets/validator-legacy.b34dfdfa.js +2 -0
- package/dist/favicon.ico +0 -0
- package/dist/index.html +134 -0
- package/dist/logo.png +0 -0
- package/package.json +57 -0
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{bM as s,bQ as p,cK as f,O as c,k as d,bL as g,r as w,bJ as y}from"./index-62c7029f.js";const b=(t,o)=>{if(!s)return!1;const e={undefined:"overflow",true:"overflow-y",false:"overflow-x"}[String(o)],r=p(t,e);return["scroll","auto","overlay"].some(a=>r.includes(a))},N=(t,o)=>{if(!s)return;let e=t;for(;e;){if([window,document,document.documentElement].includes(e))return window;if(b(e,o))return e;e=e.parentNode}return e};let l;const D=t=>{var o;if(!s)return 0;if(l!==void 0)return l;const e=document.createElement("div");e.className="".concat(t,"-scrollbar__wrap"),e.style.visibility="hidden",e.style.width="100px",e.style.position="absolute",e.style.top="-9999px",document.body.appendChild(e);const r=e.offsetWidth;e.style.overflow="scroll";const a=document.createElement("div");a.style.width="100%",e.appendChild(a);const n=a.offsetWidth;return(o=e.parentNode)==null||o.removeChild(e),l=r-n,l};function x(t,o){if(!s)return;if(!o){t.scrollTop=0;return}const e=[];let r=o.offsetParent;for(;r!==null&&t!==r&&t.contains(r);)e.push(r),r=r.offsetParent;const a=o.offsetTop+e.reduce((m,h)=>m+h.offsetTop,0),n=a+o.offsetHeight,i=t.scrollTop,u=i+t.clientHeight;a<i?t.scrollTop=a:n>u&&(t.scrollTop=n-t.clientHeight)}var v={name:"en",el:{colorpicker:{confirm:"OK",clear:"Clear",defaultLabel:"color picker",description:"current color is {color}. press enter to select a new color."},datepicker:{now:"Now",today:"Today",cancel:"Cancel",clear:"Clear",confirm:"OK",dateTablePrompt:"Use the arrow keys and enter to select the day of the month",monthTablePrompt:"Use the arrow keys and enter to select the month",yearTablePrompt:"Use the arrow keys and enter to select the year",selectedDate:"Selected date",selectDate:"Select date",selectTime:"Select time",startDate:"Start Date",startTime:"Start Time",endDate:"End Date",endTime:"End Time",prevYear:"Previous Year",nextYear:"Next Year",prevMonth:"Previous Month",nextMonth:"Next Month",year:"",month1:"January",month2:"February",month3:"March",month4:"April",month5:"May",month6:"June",month7:"July",month8:"August",month9:"September",month10:"October",month11:"November",month12:"December",week:"week",weeks:{sun:"Sun",mon:"Mon",tue:"Tue",wed:"Wed",thu:"Thu",fri:"Fri",sat:"Sat"},weeksFull:{sun:"Sunday",mon:"Monday",tue:"Tuesday",wed:"Wednesday",thu:"Thursday",fri:"Friday",sat:"Saturday"},months:{jan:"Jan",feb:"Feb",mar:"Mar",apr:"Apr",may:"May",jun:"Jun",jul:"Jul",aug:"Aug",sep:"Sep",oct:"Oct",nov:"Nov",dec:"Dec"}},inputNumber:{decrease:"decrease number",increase:"increase number"},select:{loading:"Loading",noMatch:"No matching data",noData:"No data",placeholder:"Select"},dropdown:{toggleDropdown:"Toggle Dropdown"},cascader:{noMatch:"No matching data",loading:"Loading",placeholder:"Select",noData:"No data"},pagination:{goto:"Go to",pagesize:"/page",total:"Total {total}",pageClassifier:"",deprecationWarning:"Deprecated usages detected, please refer to the el-pagination documentation for more details"},dialog:{close:"Close this dialog"},drawer:{close:"Close this dialog"},messagebox:{title:"Message",confirm:"OK",cancel:"Cancel",error:"Illegal input",close:"Close this dialog"},upload:{deleteTip:"press delete to remove",delete:"Delete",preview:"Preview",continue:"Continue"},slider:{defaultLabel:"slider between {min} and {max}",defaultRangeStartLabel:"pick start value",defaultRangeEndLabel:"pick end value"},table:{emptyText:"No Data",confirmFilter:"Confirm",resetFilter:"Reset",clearFilter:"All",sumText:"Sum"},tree:{emptyText:"No Data"},transfer:{noMatch:"No matching data",noData:"No data",titles:["List 1","List 2"],filterPlaceholder:"Enter keyword",noCheckedFormat:"{total} items",hasCheckedFormat:"{checked}/{total} checked"},image:{error:"FAILED"},pageHeader:{title:"Back"},popconfirm:{confirmButtonText:"Yes",cancelButtonText:"No"}}};const T=t=>(o,e)=>S(o,e,d(t)),S=(t,o,e)=>y(e,t,t).replace(/\{(\w+)\}/g,(r,a)=>{var n;return"".concat((n=o==null?void 0:o[a])!=null?n:"{".concat(a,"}"))}),k=t=>{const o=c(()=>d(t).name),e=g(t)?t:w(t);return{lang:o,locale:e,t:T(t)}},M=()=>{const t=f("locale");return k(c(()=>t.value||v))};export{D as a,N as g,x as s,M as u};
|
|
2
|
+
//# sourceMappingURL=index-6d7ac779.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-6d7ac779.js","sources":["../../node_modules/.pnpm/element-plus@2.2.13_vue@3.3.4/node_modules/element-plus/es/utils/dom/scroll.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.3.4/node_modules/element-plus/es/locale/lang/en.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.3.4/node_modules/element-plus/es/hooks/use-locale/index.mjs"],"sourcesContent":["import { isClient } from '@vueuse/core';\nimport { getStyle } from './style.mjs';\n\nconst isScroll = (el, isVertical) => {\n if (!isClient)\n return false;\n const key = {\n undefined: \"overflow\",\n true: \"overflow-y\",\n false: \"overflow-x\"\n }[String(isVertical)];\n const overflow = getStyle(el, key);\n return [\"scroll\", \"auto\", \"overlay\"].some((s) => overflow.includes(s));\n};\nconst getScrollContainer = (el, isVertical) => {\n if (!isClient)\n return;\n let parent = el;\n while (parent) {\n if ([window, document, document.documentElement].includes(parent))\n return window;\n if (isScroll(parent, isVertical))\n return parent;\n parent = parent.parentNode;\n }\n return parent;\n};\nlet scrollBarWidth;\nconst getScrollBarWidth = (namespace) => {\n var _a;\n if (!isClient)\n return 0;\n if (scrollBarWidth !== void 0)\n return scrollBarWidth;\n const outer = document.createElement(\"div\");\n outer.className = `${namespace}-scrollbar__wrap`;\n outer.style.visibility = \"hidden\";\n outer.style.width = \"100px\";\n outer.style.position = \"absolute\";\n outer.style.top = \"-9999px\";\n document.body.appendChild(outer);\n const widthNoScroll = outer.offsetWidth;\n outer.style.overflow = \"scroll\";\n const inner = document.createElement(\"div\");\n inner.style.width = \"100%\";\n outer.appendChild(inner);\n const widthWithScroll = inner.offsetWidth;\n (_a = outer.parentNode) == null ? void 0 : _a.removeChild(outer);\n scrollBarWidth = widthNoScroll - widthWithScroll;\n return scrollBarWidth;\n};\nfunction scrollIntoView(container, selected) {\n if (!isClient)\n return;\n if (!selected) {\n container.scrollTop = 0;\n return;\n }\n const offsetParents = [];\n let pointer = selected.offsetParent;\n while (pointer !== null && container !== pointer && container.contains(pointer)) {\n offsetParents.push(pointer);\n pointer = pointer.offsetParent;\n }\n const top = selected.offsetTop + offsetParents.reduce((prev, curr) => prev + curr.offsetTop, 0);\n const bottom = top + selected.offsetHeight;\n const viewRectTop = container.scrollTop;\n const viewRectBottom = viewRectTop + container.clientHeight;\n if (top < viewRectTop) {\n container.scrollTop = top;\n } else if (bottom > viewRectBottom) {\n container.scrollTop = bottom - container.clientHeight;\n }\n}\n\nexport { getScrollBarWidth, getScrollContainer, isScroll, scrollIntoView };\n//# sourceMappingURL=scroll.mjs.map\n","var English = {\n name: \"en\",\n el: {\n colorpicker: {\n confirm: \"OK\",\n clear: \"Clear\",\n defaultLabel: \"color picker\",\n description: \"current color is {color}. press enter to select a new color.\"\n },\n datepicker: {\n now: \"Now\",\n today: \"Today\",\n cancel: \"Cancel\",\n clear: \"Clear\",\n confirm: \"OK\",\n dateTablePrompt: \"Use the arrow keys and enter to select the day of the month\",\n monthTablePrompt: \"Use the arrow keys and enter to select the month\",\n yearTablePrompt: \"Use the arrow keys and enter to select the year\",\n selectedDate: \"Selected date\",\n selectDate: \"Select date\",\n selectTime: \"Select time\",\n startDate: \"Start Date\",\n startTime: \"Start Time\",\n endDate: \"End Date\",\n endTime: \"End Time\",\n prevYear: \"Previous Year\",\n nextYear: \"Next Year\",\n prevMonth: \"Previous Month\",\n nextMonth: \"Next Month\",\n year: \"\",\n month1: \"January\",\n month2: \"February\",\n month3: \"March\",\n month4: \"April\",\n month5: \"May\",\n month6: \"June\",\n month7: \"July\",\n month8: \"August\",\n month9: \"September\",\n month10: \"October\",\n month11: \"November\",\n month12: \"December\",\n week: \"week\",\n weeks: {\n sun: \"Sun\",\n mon: \"Mon\",\n tue: \"Tue\",\n wed: \"Wed\",\n thu: \"Thu\",\n fri: \"Fri\",\n sat: \"Sat\"\n },\n weeksFull: {\n sun: \"Sunday\",\n mon: \"Monday\",\n tue: \"Tuesday\",\n wed: \"Wednesday\",\n thu: \"Thursday\",\n fri: \"Friday\",\n sat: \"Saturday\"\n },\n months: {\n jan: \"Jan\",\n feb: \"Feb\",\n mar: \"Mar\",\n apr: \"Apr\",\n may: \"May\",\n jun: \"Jun\",\n jul: \"Jul\",\n aug: \"Aug\",\n sep: \"Sep\",\n oct: \"Oct\",\n nov: \"Nov\",\n dec: \"Dec\"\n }\n },\n inputNumber: {\n decrease: \"decrease number\",\n increase: \"increase number\"\n },\n select: {\n loading: \"Loading\",\n noMatch: \"No matching data\",\n noData: \"No data\",\n placeholder: \"Select\"\n },\n dropdown: {\n toggleDropdown: \"Toggle Dropdown\"\n },\n cascader: {\n noMatch: \"No matching data\",\n loading: \"Loading\",\n placeholder: \"Select\",\n noData: \"No data\"\n },\n pagination: {\n goto: \"Go to\",\n pagesize: \"/page\",\n total: \"Total {total}\",\n pageClassifier: \"\",\n deprecationWarning: \"Deprecated usages detected, please refer to the el-pagination documentation for more details\"\n },\n dialog: {\n close: \"Close this dialog\"\n },\n drawer: {\n close: \"Close this dialog\"\n },\n messagebox: {\n title: \"Message\",\n confirm: \"OK\",\n cancel: \"Cancel\",\n error: \"Illegal input\",\n close: \"Close this dialog\"\n },\n upload: {\n deleteTip: \"press delete to remove\",\n delete: \"Delete\",\n preview: \"Preview\",\n continue: \"Continue\"\n },\n slider: {\n defaultLabel: \"slider between {min} and {max}\",\n defaultRangeStartLabel: \"pick start value\",\n defaultRangeEndLabel: \"pick end value\"\n },\n table: {\n emptyText: \"No Data\",\n confirmFilter: \"Confirm\",\n resetFilter: \"Reset\",\n clearFilter: \"All\",\n sumText: \"Sum\"\n },\n tree: {\n emptyText: \"No Data\"\n },\n transfer: {\n noMatch: \"No matching data\",\n noData: \"No data\",\n titles: [\"List 1\", \"List 2\"],\n filterPlaceholder: \"Enter keyword\",\n noCheckedFormat: \"{total} items\",\n hasCheckedFormat: \"{checked}/{total} checked\"\n },\n image: {\n error: \"FAILED\"\n },\n pageHeader: {\n title: \"Back\"\n },\n popconfirm: {\n confirmButtonText: \"Yes\",\n cancelButtonText: \"No\"\n }\n }\n};\n\nexport { English as default };\n//# sourceMappingURL=en.mjs.map\n","import { unref, computed, isRef, ref } from 'vue';\nimport { get } from 'lodash-unified';\nimport English from '../../locale/lang/en.mjs';\nimport { useGlobalConfig } from '../use-global-config/index.mjs';\n\nconst buildTranslator = (locale) => (path, option) => translate(path, option, unref(locale));\nconst translate = (path, option, locale) => get(locale, path, path).replace(/\\{(\\w+)\\}/g, (_, key) => {\n var _a;\n return `${(_a = option == null ? void 0 : option[key]) != null ? _a : `{${key}}`}`;\n});\nconst buildLocaleContext = (locale) => {\n const lang = computed(() => unref(locale).name);\n const localeRef = isRef(locale) ? locale : ref(locale);\n return {\n lang,\n locale: localeRef,\n t: buildTranslator(locale)\n };\n};\nconst useLocale = () => {\n const locale = useGlobalConfig(\"locale\");\n return buildLocaleContext(computed(() => locale.value || English));\n};\n\nexport { buildLocaleContext, buildTranslator, translate, useLocale };\n//# sourceMappingURL=index.mjs.map\n"],"names":["isScroll","el","isVertical","isClient","key","overflow","getStyle","s","getScrollContainer","parent","scrollBarWidth","getScrollBarWidth","namespace","_a","outer","widthNoScroll","inner","widthWithScroll","scrollIntoView","container","selected","offsetParents","pointer","top","prev","curr","bottom","viewRectTop","viewRectBottom","English","buildTranslator","locale","path","option","translate","unref","get","_","buildLocaleContext","lang","computed","localeRef","isRef","ref","useLocale","useGlobalConfig"],"mappings":"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","x_google_ignoreList":[0,1,2]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{d as _,r as n,u as r,o as d,c as u,a as t,b as p,t as i,p as v,e as f,f as h,_ as m}from"./index-62c7029f.js";const c=e=>(v("data-v-7bc5f813"),e=e(),f(),e),x={class:"not-found"},I=c(()=>t("h1",null,"404 Not Found",-1)),b=c(()=>t("h2",null,"糟糕页面走丢了",-1)),S=_({__name:"index",setup(e){const o=n(3),a=n(null),s=r(),l=()=>{clearInterval(a.value),s.replace("/")};return d(()=>{a.value=setInterval(()=>{o.value===1&&(clearInterval(a.value),s.replace("/")),o.value-=1},1e3)}),(k,y)=>(h(),u("div",x,[I,b,t("h3",null,[p(i(o.value)+"s后",1),t("a",{onClick:l},"回到首页")])]))}});const N=m(S,[["__scopeId","data-v-7bc5f813"]]);export{N as default};
|
|
2
|
+
//# sourceMappingURL=index-6f4c911e.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-6f4c911e.js","sources":["../../src/pages/404/index.vue"],"sourcesContent":["<template>\n <div class=\"not-found\">\n <h1>404 Not Found</h1>\n <h2>糟糕页面走丢了</h2>\n <h3>{{ time }}s后<a @click=\"handleToHome\">回到首页</a></h3>\n </div>\n</template>\n<script lang=\"ts\" setup>\nimport { onMounted, ref } from 'vue'\nimport { useRouter } from 'vue-router'\n\nconst time = ref(3)\nconst timer = ref(null)\nconst router = useRouter()\nconst handleToHome = () => {\n clearInterval(timer.value)\n router.replace('/')\n}\nonMounted(() => {\n timer.value = setInterval(() => {\n if (time.value === 1) {\n clearInterval(timer.value)\n router.replace('/')\n }\n time.value -= 1\n }, 1000)\n})\n</script>\n<style lang=\"scss\" scoped>\n.not-found {\n font-family: 'Avenir', Helvetica, Arial, sans-serif;\n background-image: linear-gradient(to top, #30cfd0 0%, #330867 100%);\n min-height: 100vh;\n}\nh1,\nh2,\nh3,\na {\n color: aliceblue;\n text-align: center;\n font-weight: lighter;\n}\na {\n margin-left: 10px;\n border-bottom: 2px solid aliceblue;\n}\nh1 {\n font-size: 48px;\n padding-top: 10%;\n}\nh2 {\n font-size: 30px;\n padding-top: 2vh;\n}\nh3 {\n font-size: 28px;\n padding-top: 1vh;\n}\n</style>\n"],"names":["time","ref","timer","router","useRouter","handleToHome","onMounted"],"mappings":"kSAWA,MAAAA,EAAAC,EAAA,CAAA,EACAC,EAAAD,EAAA,IAAA,EACAE,EAAAC,IACAC,EAAA,IAAA,CACE,cAAAH,EAAA,KAAA,EACAC,EAAA,QAAA,GAAA,CAAkB,EAEpB,OAAAG,EAAA,IAAA,CACEJ,EAAA,MAAA,YAAA,IAAA,CACEF,EAAA,QAAA,IACE,cAAAE,EAAA,KAAA,EACAC,EAAA,QAAA,GAAA,GAEFH,EAAA,OAAA,CAAc,EAAA,GAAA,CACT,CAAA"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{a4 as k,d as oe,h as ne,Z as $,r as i,O as D,o as ue,c as T,a as u,j as l,w as s,k as U,v as ie,p as de,e as re,f as E,F,C as N,D as R,b as d,t as O,s as j,E as P,x as pe,_ as ce}from"./index-62c7029f.js";import{E as fe,a as _e}from"./el-form-item-f40006bf.js";import{E as me}from"./el-dialog-463960e0.js";import{E as ve,s as he}from"./el-pagination-ffb99240.js";import{E as ge,a as be}from"./el-select-7d894fd0.js";import{E as we,a as ye}from"./el-table-column-22352e92.js";import{W as m}from"./index-9e6bd406.js";import"./isEqual-9c466456.js";import"./index-6d7ac779.js";import"./validator-853854a1.js";function Ve(n){return k.post("/wish/add",n)}function Ee(){return k.get("/wish/all")}function Ce(n,v){return k.put("/wish/update",{id:n,status:v})}function We(n,v,r){return k.put("/wish/update/".concat(n),{title:v,des:r})}const L={addWish:Ve,findAllWish:Ee,updateWishStatus:Ce,updateWishDes:We},xe=n=>(de("data-v-8f592632"),n=n(),re(),n),Se={class:"user"},De={class:"panel"},ke={class:"p10 log-filter"},ze={class:"item"},Ie=xe(()=>u("span",{class:"label"},"状态",-1)),$e={class:"item"},Te={class:"text-btn-list"},Ue={class:"flex fc p10"},Le={class:"tc"},Ae={class:"dialog-footer"},Be={class:"dialog-footer"},Z="80px",Me=oe({__name:"index",setup(n){const v=ne(),r=$([]),q=()=>{L.findAllWish().then(a=>{r.splice(0,r.length,...a.data)})},C=i(-1),W=i(""),z=$([{label:"待审核",type:m.REVIEW},{label:"待开始",type:m.WAIT},{label:"关闭",type:m.CLOSE},{label:"已上线",type:m.END},{label:"开发中",type:m.START}]),I=D(()=>r.filter(a=>a.status===C.value||C.value===-1).filter(a=>{const{createDate:t,title:p,des:S,contact:y}=a;return W.value.length===0?!0:"".concat(j(new Date(t))," ").concat(p," ").concat(S," ").concat(y).includes(W.value)})),h=i(10),G=a=>{h.value=a},H=D(()=>Math.ceil(I.value.length/h.value)),x=i(1),J=D(()=>{const a=(x.value-1)*h.value,t=x.value*h.value;return I.value.slice(a,t)}),K=a=>{x.value=a},g=i(!1),c=i(""),b=i(m.REVIEW),Q=z,X=(a,t)=>{c.value=a,b.value=t,g.value=!0},Y=()=>{const a=r.find(t=>t.id===c.value);a.status=b.value,g.value=!1,L.updateWishStatus(c.value,b.value).then(()=>{P.success("修改成功")})},w=i(!1),o=$({title:"",des:""}),ee=(a,t,p)=>{c.value=a,o.title=t,o.des=p,w.value=!0},te=()=>{const a=r.find(t=>t.id===c.value);L.updateWishDes(c.value,o.title,o.des).then(()=>{w.value=!1,a.title=o.title,a.des=o.des,P.success("修改成功")})};ue(()=>{q()});const A=D(()=>v.getters["public/isMobile"]);return(a,t)=>{const p=be,S=ge,y=ie,f=ye,_=pe,le=we,ae=ve,B=me,M=fe,se=_e;return E(),T("div",Se,[u("div",De,[u("div",ke,[u("span",ze,[Ie,l(S,{modelValue:C.value,"onUpdate:modelValue":t[0]||(t[0]=e=>C.value=e),size:"default",placeholder:"请选择筛选状态"},{default:s(()=>[l(p,{label:"全部",value:-1}),(E(!0),T(F,null,N(z,(e,V)=>(E(),R(p,{key:V,label:e.label,value:e.type},null,8,["label","value"]))),128))]),_:1},8,["modelValue"])]),u("span",$e,[l(y,{size:"default",clearable:"",placeholder:"请输入要检索的内容","prefix-icon":U(he),modelValue:W.value,"onUpdate:modelValue":t[1]||(t[1]=e=>W.value=e)},null,8,["prefix-icon","modelValue"])])]),l(le,{height:"550",stripe:"",border:"","default-sort":{prop:"date",order:"descending"},data:J.value,style:{width:"100%"}},{default:s(()=>[l(f,{sortable:"",prop:"createDate",label:"提交时间",width:"190"},{default:s(e=>[d(O(e.row.createDate&&U(j)(new Date(e.row.createDate))),1)]),_:1}),l(f,{prop:"title",label:"标题",width:"120"}),l(f,{prop:"des",label:"详细描述"}),l(f,{prop:"contact",label:"联系方式"}),l(f,{prop:"status",label:"状态"},{default:s(e=>[d(O(z.find(V=>V.type===e.row.status).label),1)]),_:1}),l(f,{fixed:"right",label:"操作",width:"100"},{default:s(e=>[u("div",Te,[l(_,{onClick:V=>X(e.row.id,e.row.status),type:"primary",text:"",size:"small"},{default:s(()=>[d("修改状态 ")]),_:2},1032,["onClick"]),l(_,{onClick:V=>ee(e.row.id,e.row.title,e.row.des),type:"primary",text:"",size:"small"},{default:s(()=>[d(" 修改描述 ")]),_:2},1032,["onClick"])])]),_:1})]),_:1},8,["data"]),u("div",Ue,[l(ae,{"current-page":x.value,onCurrentChange:K,background:"","page-count":H.value,"page-sizes":[10,50,100,200],"page-size":h.value,onSizeChange:G,total:I.value.length,layout:"total, sizes, prev, pager, next, jumper"},null,8,["current-page","page-count","page-size","total"])])]),l(B,{fullscreen:A.value,center:"",title:"状态修改",modelValue:g.value,"onUpdate:modelValue":t[4]||(t[4]=e=>g.value=e)},{footer:s(()=>[u("span",Ae,[l(_,{onClick:t[3]||(t[3]=e=>g.value=!1)},{default:s(()=>[d("取 消")]),_:1}),l(_,{type:"primary",onClick:Y},{default:s(()=>[d("确 定")]),_:1})])]),default:s(()=>[u("div",Le,[l(S,{modelValue:b.value,"onUpdate:modelValue":t[2]||(t[2]=e=>b.value=e),placeholder:"请选择新状态"},{default:s(()=>[(E(!0),T(F,null,N(U(Q),e=>(E(),R(p,{key:e.type,label:e.label,value:e.type},null,8,["label","value"]))),128))]),_:1},8,["modelValue"])])]),_:1},8,["fullscreen","modelValue"]),l(B,{title:"需求信息",modelValue:w.value,"onUpdate:modelValue":t[8]||(t[8]=e=>w.value=e),fullscreen:A.value},{footer:s(()=>[u("span",Be,[l(_,{onClick:t[7]||(t[7]=e=>w.value=!1)},{default:s(()=>[d("取 消")]),_:1}),l(_,{type:"primary",onClick:te},{default:s(()=>[d("确 定")]),_:1})])]),default:s(()=>[l(se,{model:o},{default:s(()=>[l(M,{label:"需求","label-width":Z},{default:s(()=>[l(y,{placeholder:"一句简单明了的话概括一下",modelValue:o.title,"onUpdate:modelValue":t[5]||(t[5]=e=>o.title=e)},null,8,["modelValue"])]),_:1}),l(M,{label:"详细描述","label-width":Z},{default:s(()=>[l(y,{placeholder:"用朴素的话语进一步描述你的需求",type:"textarea",modelValue:o.des,"onUpdate:modelValue":t[6]||(t[6]=e=>o.des=e)},null,8,["modelValue"])]),_:1})]),_:1},8,["model"])]),_:1},8,["modelValue","fullscreen"])])}}});const Je=ce(Me,[["__scopeId","data-v-8f592632"]]);export{Je as default};
|
|
2
|
+
//# sourceMappingURL=index-75b8c91c.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-75b8c91c.js","sources":["../../src/apis/modules/wish.ts","../../src/pages/dashboard/manage/wish/index.vue"],"sourcesContent":["import { WishStatus } from '@/constants'\nimport ajax from '../ajax'\n\nfunction addWish(wish: Partial<WishApiTypes.Wish>): WishApiTypes.addWish {\n return ajax.post('/wish/add', wish)\n}\n\nfunction findAllWish(): WishApiTypes.allWishData {\n return ajax.get('/wish/all')\n}\n\nfunction updateWishStatus(\n id: string,\n status: WishStatus\n): WishApiTypes.updateWish {\n return ajax.put('/wish/update', { id, status })\n}\n\nfunction updateWishDes(\n id: string,\n title: string,\n des: string\n): WishApiTypes.updateWish {\n return ajax.put(`/wish/update/${id}`, { title, des })\n}\nexport default {\n addWish,\n findAllWish,\n updateWishStatus,\n updateWishDes\n}\n","<template>\n <div class=\"user\">\n <div class=\"panel\">\n <div class=\"p10 log-filter\">\n <span class=\"item\">\n <span class=\"label\">状态</span>\n <el-select v-model=\"filterLogType\" size=\"default\" placeholder=\"请选择筛选状态\">\n <el-option label=\"全部\" :value=\"-1\"></el-option>\n <el-option v-for=\"(item, idx) in logTypeList\" :key=\"idx\" :label=\"item.label\" :value=\"item.type\"></el-option>\n </el-select>\n </span>\n <span class=\"item\">\n <el-input size=\"default\" clearable placeholder=\"请输入要检索的内容\" :prefix-icon=\"Search\" v-model=\"searchWord\">\n </el-input>\n </span>\n </div>\n <el-table height=\"550\" stripe border :default-sort=\"{ prop: 'date', order: 'descending' }\" :data=\"pageWishes\"\n style=\"width: 100%\">\n <el-table-column sortable prop=\"createDate\" label=\"提交时间\" width=\"190\">\n <template #default=\"scope\">{{ scope.row.createDate && formatDate(new Date(scope.row.createDate)) }}</template>\n </el-table-column>\n <el-table-column prop=\"title\" label=\"标题\" width=\"120\"></el-table-column>\n <el-table-column prop=\"des\" label=\"详细描述\"></el-table-column>\n <el-table-column prop=\"contact\" label=\"联系方式\"></el-table-column>\n <el-table-column prop=\"status\" label=\"状态\">\n <template #default=\"scope\">\n {{ logTypeList.find(v => v.type === scope.row.status).label }}\n </template>\n </el-table-column>\n <el-table-column fixed=\"right\" label=\"操作\" width=\"100\">\n <template #default=\"scope\">\n <div class=\"text-btn-list\">\n <el-button @click=\"handleChangeStatus(scope.row.id, scope.row.status)\" type=\"primary\" text size=\"small\">修改状态\n </el-button>\n <el-button @click=\"handleRewriteDes(scope.row.id, scope.row.title, scope.row.des)\" type=\"primary\" text\n size=\"small\">\n 修改描述\n </el-button>\n </div>\n </template>\n </el-table-column>\n </el-table>\n <div class=\"flex fc p10\">\n <el-pagination :current-page=\"pageCurrent\" @current-change=\"handlePageChange\" background :page-count=\"pageCount\"\n :page-sizes=\"[10, 50, 100, 200]\" :page-size=\"pageSize\" @size-change=\"handleSizeChange\"\n :total=\"filterWishes.length\" layout=\"total, sizes, prev, pager, next, jumper\"></el-pagination>\n </div>\n </div>\n <!-- 状态修改弹窗 -->\n <el-dialog :fullscreen=\"isMobile\" center title=\"状态修改\" v-model=\"showWishStatusDialog\">\n <div class=\"tc\">\n <el-select v-model=\"selectStatus\" placeholder=\"请选择新状态\">\n <el-option v-for=\"s in wishStatusList\" :key=\"s.type\" :label=\"s.label\" :value=\"s.type\"></el-option>\n </el-select>\n </div>\n <template #footer>\n <span class=\"dialog-footer\">\n <el-button @click=\"showWishStatusDialog = false\">取 消</el-button>\n <el-button type=\"primary\" @click=\"handleSaveStatus\">确 定</el-button>\n </span>\n </template>\n </el-dialog>\n\n <!-- 需求描述更新弹窗 -->\n <el-dialog title=\"需求信息\" v-model=\"desVisible\" :fullscreen=\"isMobile\">\n <el-form :model=\"formData\">\n <el-form-item label=\"需求\" :label-width=\"formLabelWidth\">\n <el-input placeholder=\"一句简单明了的话概括一下\" v-model=\"formData.title\"></el-input>\n </el-form-item>\n <el-form-item label=\"详细描述\" :label-width=\"formLabelWidth\">\n <el-input placeholder=\"用朴素的话语进一步描述你的需求\" type=\"textarea\" v-model=\"formData.des\"></el-input>\n </el-form-item>\n </el-form>\n <template #footer>\n <span class=\"dialog-footer\">\n <el-button @click=\"desVisible = false\">取 消</el-button>\n <el-button type=\"primary\" @click=\"handleUpdateWish\">确 定</el-button>\n </span>\n </template>\n </el-dialog>\n </div>\n</template>\n<script lang=\"ts\" setup>\nimport { ElMessage } from 'element-plus'\nimport {\n computed, onMounted, reactive, ref,\n} from 'vue'\nimport { useStore } from 'vuex'\nimport { Search } from '@element-plus/icons-vue'\nimport { WishApi } from '@/apis'\nimport { formatDate } from '@/utils/stringUtil'\nimport { WishStatus } from '@/constants'\n\nconst $store = useStore()\nconst wishes = reactive<WishApiTypes.WishItem[]>([])\nconst refreshWishes = () => {\n WishApi.findAllWish().then((v) => {\n wishes.splice(0, wishes.length, ...v.data)\n })\n}\n\n// 筛选状态\nconst filterLogType = ref(-1)\nconst searchWord = ref('')\nconst logTypeList = reactive([\n {\n label: '待审核',\n type: WishStatus.REVIEW,\n },\n {\n label: '待开始',\n type: WishStatus.WAIT,\n },\n {\n label: '关闭',\n type: WishStatus.CLOSE,\n },\n {\n label: '已上线',\n type: WishStatus.END,\n },\n {\n label: '开发中',\n type: WishStatus.START,\n },\n])\n\nconst filterWishes = computed(() => wishes\n .filter((v) => v.status === filterLogType.value || filterLogType.value === -1)\n .filter((v) => {\n const {\n createDate, title, des, contact,\n } = v\n if (searchWord.value.length === 0) return true\n return `${formatDate(new Date(createDate))} ${title} ${des} ${contact}`.includes(searchWord.value)\n }))\n\n// 分页\nconst pageSize = ref(10)\nconst handleSizeChange = (v: number) => {\n pageSize.value = v\n}\nconst pageCount = computed(() => {\n const t = Math.ceil(filterWishes.value.length / pageSize.value)\n return t\n})\nconst pageCurrent = ref(1)\nconst pageWishes = computed(() => {\n const start = (pageCurrent.value - 1) * pageSize.value\n const end = (pageCurrent.value) * pageSize.value\n return filterWishes.value.slice(start, end)\n})\nconst handlePageChange = (idx: number) => {\n pageCurrent.value = idx\n}\n\n// 状态修改\nconst showWishStatusDialog = ref(false)\nconst selectWishId = ref('')\nconst selectStatus = ref(WishStatus.REVIEW)\nconst wishStatusList = logTypeList\nconst handleChangeStatus = (wishId: string, status: WishStatus) => {\n selectWishId.value = wishId\n selectStatus.value = status\n showWishStatusDialog.value = true\n}\nconst handleSaveStatus = () => {\n const wish = wishes.find((v) => v.id === selectWishId.value)\n wish.status = selectStatus.value\n showWishStatusDialog.value = false\n WishApi\n .updateWishStatus(selectWishId.value, selectStatus.value)\n .then(() => {\n ElMessage.success('修改成功')\n })\n}\n\n// 描述信息修改\nconst formLabelWidth = '80px'\nconst desVisible = ref(false)\nconst formData = reactive({\n title: '',\n des: '',\n})\nconst handleRewriteDes = (id: string, title: string, des: string) => {\n selectWishId.value = id\n formData.title = title\n formData.des = des\n desVisible.value = true\n}\nconst handleUpdateWish = () => {\n const wish = wishes.find((v) => v.id === selectWishId.value)\n WishApi\n .updateWishDes(selectWishId.value, formData.title, formData.des)\n .then(() => {\n desVisible.value = false\n wish.title = formData.title\n wish.des = formData.des\n ElMessage.success('修改成功')\n })\n}\nonMounted(() => {\n refreshWishes()\n})\nconst isMobile = computed(() => $store.getters['public/isMobile'])\n\n</script>\n\n<style scoped lang=\"scss\">\n@media screen and (max-width: 700px) {\n .user {\n margin-top: 40px !important;\n }\n\n .log-filter {\n justify-content: center;\n }\n}\n\n.user {\n margin: 0 auto;\n}\n\n.panel {\n max-width: 1256px;\n padding: 1em;\n background-color: #fff;\n margin: 10px auto;\n box-sizing: border-box;\n box-shadow: 0 2px 12px 0 rgb(0 0 0 / 10%);\n border-radius: 4px;\n}\n\n.log-filter {\n display: flex;\n flex-wrap: wrap;\n\n .item {\n margin-right: 10px;\n margin-bottom: 10px;\n\n .label {\n margin-right: 10px;\n font-size: 12px;\n }\n }\n}\n\n.text-btn-list {\n display: flex;\n flex-wrap: wrap;\n\n button {\n margin-left: 0;\n }\n}\n</style>\n"],"names":["addWish","wish","ajax","findAllWish","updateWishStatus","id","status","updateWishDes","title","des","WishApi","formLabelWidth","$store","useStore","wishes","reactive","refreshWishes","v","filterLogType","ref","searchWord","logTypeList","WishStatus","filterWishes","computed","createDate","contact","formatDate","pageSize","handleSizeChange","pageCount","pageCurrent","pageWishes","start","end","handlePageChange","idx","showWishStatusDialog","selectWishId","selectStatus","wishStatusList","handleChangeStatus","wishId","handleSaveStatus","ElMessage","desVisible","formData","handleRewriteDes","handleUpdateWish","onMounted","isMobile"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.login[data-v-4e645608]{background-image:linear-gradient(120deg,#a1c4fd 0%,#c2e9fb 100%);min-height:100vh}.inputArea[data-v-4e645608]{margin:0 auto;max-width:320px}.inputArea div[data-v-4e645608]{margin-top:10px}.links[data-v-4e645608]{display:flex;justify-content:center}.links a[data-v-4e645608]{color:#409eff;margin-left:10px}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
h1[data-v-57f0136c],h2[data-v-57f0136c],h3[data-v-57f0136c],h4[data-v-57f0136c]{font-weight:500}.about[data-v-57f0136c]{background-image:linear-gradient(120deg,#a1c4fd 0%,#c2e9fb 100%);min-height:100vh}main[data-v-57f0136c]{max-width:860px;margin:0 auto;padding:20px}main .panel[data-v-57f0136c]{position:relative;margin:0 auto 10px;padding:16px 20px;width:100%;overflow:hidden;border-radius:.25rem;box-shadow:#eee;box-sizing:border-box;transition:all .3s;background-color:#fff}main .logo[data-v-57f0136c]{width:100%;max-width:520px;margin:0 auto;display:block}main h1[data-v-57f0136c]{font-size:1.6rem;margin-bottom:10px}main h2[data-v-57f0136c]{font-size:1.3rem;margin-bottom:12px}main ul[data-v-57f0136c],main ol[data-v-57f0136c]{margin-left:20px;font-size:15px;margin-bottom:1em}main p[data-v-57f0136c]{font-size:15px;margin-bottom:1em}main a[data-v-57f0136c]{color:#409eff}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.el-tag[data-v-89760030]{margin-left:10px;margin-bottom:10px;cursor:pointer}.new-tag-wrap[data-v-89760030]{display:flex;align-items:center}.button-new-tag[data-v-89760030]{margin-left:10px;height:32px;line-height:30px;padding-top:0;padding-bottom:0}.input-new-tag[data-v-89760030]{width:120px;padding:0;margin-left:10px;margin-bottom:10px;vertical-align:bottom}.panel[data-v-89760030]{padding:1em;background-color:#fff;margin:10px auto;box-sizing:border-box;box-shadow:0 2px 12px rgba(0,0,0,.1);border-radius:4px}.btn-area[data-v-89760030]{display:flex;justify-content:center}.list-tip[data-v-89760030]{margin-right:10px;flex:1;text-align:right}.tag-wrap[data-v-89760030]{width:100%;height:150px}.tag-list[data-v-89760030]{height:150px;overflow-x:hidden;overflow-y:scroll;display:flex;flex-wrap:wrap}.tag-list[data-v-89760030] .el-tag{width:140px}.tag-list[data-v-89760030] .el-tag__content{width:100px;text-align:center;text-overflow:ellipsis;word-break:keep-all;overflow:hidden}.btn-area[data-v-74937fc2]{display:flex;justify-content:center}.input-container[data-v-74937fc2]{margin:15px auto;max-width:600px;background-color:#fff;display:flex;justify-content:space-around}.el-card{--el-card-border-color:var(--el-border-color-light);--el-card-border-radius:4px;--el-card-padding:20px;--el-card-bg-color:var(--el-fill-color-blank)}.el-card{border-radius:var(--el-card-border-radius);border:1px solid var(--el-card-border-color);background-color:var(--el-card-bg-color);overflow:hidden;color:var(--el-text-color-primary);transition:var(--el-transition-duration)}.el-card.is-always-shadow{box-shadow:var(--el-box-shadow-light)}.el-card.is-hover-shadow:focus,.el-card.is-hover-shadow:hover{box-shadow:var(--el-box-shadow-light)}.el-card__header{padding:calc(var(--el-card-padding) - 2px) var(--el-card-padding);border-bottom:1px solid var(--el-card-border-color);box-sizing:border-box}.el-card__body{padding:var(--el-card-padding)}.task-item[data-v-15cc9632]{min-width:400px;margin-top:1em}.task-item .header[data-v-15cc9632]{overflow:hidden;display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap}.task-item .header .actions[data-v-15cc9632]{min-width:200px;padding:3px 0;margin-left:20px}.task-item .body[data-v-15cc9632]{min-height:30px}.task-item .body .empty[data-v-15cc9632]{text-align:center;font-size:12px;color:gray}.task-item .body ul[data-v-15cc9632]{font-size:12px;color:gray;list-style:none}.task-item .body ul .time[data-v-15cc9632]{margin-right:10px}@media screen and (max-width: 700px){.task-item[data-v-15cc9632]{min-width:100%}}.check-files[data-v-15cc9632]{display:flex;justify-content:space-between;align-items:center}.check-files a[data-v-15cc9632]{color:#409eff}.el-radio-button{--el-radio-button-checked-bg-color:var(--el-color-primary);--el-radio-button-checked-text-color:var(--el-color-white);--el-radio-button-checked-border-color:var(--el-color-primary);--el-radio-button-disabled-checked-fill:var(--el-border-color-extra-light)}.el-radio-button{position:relative;display:inline-block;outline:0}.el-radio-button__inner{display:inline-block;line-height:1;white-space:nowrap;vertical-align:middle;background:var(--el-button-bg-color,var(--el-fill-color-blank));border:var(--el-border);font-weight:var(--el-button-font-weight,var(--el-font-weight-primary));border-left:0;color:var(--el-button-text-color,var(--el-text-color-regular));-webkit-appearance:none;text-align:center;box-sizing:border-box;outline:0;margin:0;position:relative;cursor:pointer;transition:var(--el-transition-all);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;padding:8px 15px;font-size:var(--el-font-size-base);border-radius:0}.el-radio-button__inner.is-round{padding:8px 15px}.el-radio-button__inner:hover{color:var(--el-color-primary)}.el-radio-button__inner [class*=el-icon-]{line-height:.9}.el-radio-button__inner [class*=el-icon-]+span{margin-left:5px}.el-radio-button:first-child .el-radio-button__inner{border-left:var(--el-border);border-radius:var(--el-border-radius-base) 0 0 var(--el-border-radius-base);box-shadow:none!important}.el-radio-button__original-radio{opacity:0;outline:0;position:absolute;z-index:-1}.el-radio-button__original-radio:checked+.el-radio-button__inner{color:var(--el-radio-button-checked-text-color,var(--el-color-white));background-color:var(--el-radio-button-checked-bg-color,var(--el-color-primary));border-color:var(--el-radio-button-checked-border-color,var(--el-color-primary));box-shadow:-1px 0 0 0 var(--el-radio-button-checked-border-color,var(--el-color-primary))}.el-radio-button__original-radio:focus-visible+.el-radio-button__inner{border-left:var(--el-border);border-left-color:var(--el-radio-button-checked-border-color,var(--el-color-primary));outline:2px solid var(--el-radio-button-checked-border-color);outline-offset:1px;z-index:2;border-radius:var(--el-border-radius-base);box-shadow:none}.el-radio-button__original-radio:disabled+.el-radio-button__inner{color:var(--el-disabled-text-color);cursor:not-allowed;background-image:none;background-color:var(--el-button-disabled-bg-color,var(--el-fill-color-blank));border-color:var(--el-button-disabled-border-color,var(--el-border-color-light));box-shadow:none}.el-radio-button__original-radio:disabled:checked+.el-radio-button__inner{background-color:var(--el-radio-button-disabled-checked-fill)}.el-radio-button:last-child .el-radio-button__inner{border-radius:0 var(--el-border-radius-base) var(--el-border-radius-base) 0}.el-radio-button:first-child:last-child .el-radio-button__inner{border-radius:var(--el-border-radius-base)}.el-radio-button--large .el-radio-button__inner{padding:12px 19px;font-size:var(--el-font-size-base);border-radius:0}.el-radio-button--large .el-radio-button__inner.is-round{padding:12px 19px}.el-radio-button--small .el-radio-button__inner{padding:5px 11px;font-size:12px;border-radius:0}.el-radio-button--small .el-radio-button__inner.is-round{padding:5px 11px}.upload-people[data-v-325c5841]{padding:10px}.import-people-wrapper[data-v-325c5841]{padding:10px 0}.submit-ok[data-v-325c5841]{color:#67c23a}.submit-fail[data-v-325c5841]{color:#f56c6c}.nav[data-v-325c5841]{display:flex;flex-wrap:wrap;justify-content:center;padding-bottom:5px}.nav .item[data-v-325c5841]{margin-left:10px;margin-top:5px}.info-panel[data-v-325c5841] .el-form-item__label{flex:var(--1fa0305c)}.info-panel[data-v-325c5841] .el-upload-list__item-name,.info-panel[data-v-77b4c9c1] .el-upload-list__item-name{justify-content:center}.auto-format[data-v-3fba454a]{display:flex;justify-content:center}[data-v-3fba454a] .el-form-item__label{display:flex;justify-content:center;align-items:flex-start}.num-wrapper[data-v-3fba454a]{display:flex;justify-content:center;align-items:center;width:20px;height:20px;border-radius:50%;border:2px solid #000;text-align:center;font-size:14px}.info-panel[data-v-3fba454a] .el-form-item__label{flex:var(--ddfb70e2);justify-content:flex-end}.form-wrapper[data-v-3fba454a]{max-width:380px;margin:0 auto}.form-wrapper[data-v-3fba454a] .el-input-group__append{background-color:transparent;border:none;box-shadow:none;padding:0}.form-item-wrapper[data-v-3fba454a]{width:50px;display:flex;justify-content:center;align-items:center}.form-item-type[data-v-3fba454a]{margin-left:10px;font-size:12px;width:48px;text-align:left}.radio-list[data-v-3fba454a]{padding-top:10px}.radio-list[data-v-3fba454a] .el-input{width:80%}.el-input-number{position:relative;display:inline-block;width:150px;line-height:30px}.el-input-number .el-input__wrapper{padding-left:42px;padding-right:42px}.el-input-number .el-input__inner{-webkit-appearance:none;-moz-appearance:textfield;text-align:center;line-height:1}.el-input-number .el-input__inner::-webkit-inner-spin-button,.el-input-number .el-input__inner::-webkit-outer-spin-button{margin:0;-webkit-appearance:none}.el-input-number__decrease,.el-input-number__increase{display:flex;justify-content:center;align-items:center;height:auto;position:absolute;z-index:1;top:1px;bottom:1px;width:32px;background:var(--el-fill-color-light);color:var(--el-text-color-regular);cursor:pointer;font-size:13px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.el-input-number__decrease:hover,.el-input-number__increase:hover{color:var(--el-color-primary)}.el-input-number__decrease:hover~.el-input:not(.is-disabled) .el-input_wrapper,.el-input-number__increase:hover~.el-input:not(.is-disabled) .el-input_wrapper{box-shadow:0 0 0 1px var(--el-input-focus-border-color,var(--el-color-primary)) inset}.el-input-number__decrease.is-disabled,.el-input-number__increase.is-disabled{color:var(--el-disabled-text-color);cursor:not-allowed}.el-input-number__increase{right:1px;border-radius:0 var(--el-border-radius-base) var(--el-border-radius-base) 0;border-left:var(--el-border)}.el-input-number__decrease{left:1px;border-radius:var(--el-border-radius-base) 0 0 var(--el-border-radius-base);border-right:var(--el-border)}.el-input-number.is-disabled .el-input-number__decrease,.el-input-number.is-disabled .el-input-number__increase{border-color:var(--el-disabled-border-color);color:var(--el-disabled-border-color)}.el-input-number.is-disabled .el-input-number__decrease:hover,.el-input-number.is-disabled .el-input-number__increase:hover{color:var(--el-disabled-border-color);cursor:not-allowed}.el-input-number--large{width:180px;line-height:38px}.el-input-number--large .el-input-number__decrease,.el-input-number--large .el-input-number__increase{width:40px;font-size:14px}.el-input-number--large .el-input__wrapper{padding-left:47px;padding-right:47px}.el-input-number--small{width:120px;line-height:22px}.el-input-number--small .el-input-number__decrease,.el-input-number--small .el-input-number__increase{width:24px;font-size:12px}.el-input-number--small .el-input__wrapper{padding-left:31px;padding-right:31px}.el-input-number--small .el-input-number__decrease [class*=el-icon],.el-input-number--small .el-input-number__increase [class*=el-icon]{transform:scale(.9)}.el-input-number.is-without-controls .el-input__wrapper{padding-left:15px;padding-right:15px}.el-input-number.is-controls-right .el-input__wrapper{padding-left:15px;padding-right:42px}.el-input-number.is-controls-right .el-input-number__decrease,.el-input-number.is-controls-right .el-input-number__increase{--el-input-number-controls-height:15px;height:var(--el-input-number-controls-height);line-height:var(--el-input-number-controls-height)}.el-input-number.is-controls-right .el-input-number__decrease [class*=el-icon],.el-input-number.is-controls-right .el-input-number__increase [class*=el-icon]{transform:scale(.8)}.el-input-number.is-controls-right .el-input-number__increase{bottom:auto;left:auto;border-radius:0 var(--el-border-radius-base) 0 0;border-bottom:var(--el-border)}.el-input-number.is-controls-right .el-input-number__decrease{right:1px;top:auto;left:auto;border-right:none;border-left:var(--el-border);border-radius:0 0 var(--el-border-radius-base) 0}.el-input-number.is-controls-right[class*=large] [class*=decrease],.el-input-number.is-controls-right[class*=large] [class*=increase]{--el-input-number-controls-height:19px}.el-input-number.is-controls-right[class*=small] [class*=decrease],.el-input-number.is-controls-right[class*=small] [class*=increase]{--el-input-number-controls-height:11px}.type[data-v-28b884c6]{margin:10px}.split-line[data-v-28b884c6]{margin-top:10px}.title[data-v-28b884c6]{color:#000;font-weight:700}.tasks[data-v-a447a8ef]{max-width:1024px;margin:0 auto;padding-bottom:2em}.tasks[data-v-a447a8ef] .el-dialog__body{padding-top:10px}.panel[data-v-a447a8ef]{padding:1em;background-color:#fff;margin:10px auto;box-sizing:border-box;box-shadow:0 2px 12px rgba(0,0,0,.1);border-radius:4px}.task-list[data-v-a447a8ef]{display:flex;flex-wrap:wrap;justify-content:space-around}@media screen and (max-width: 700px){.categorys-area[data-v-a447a8ef]{margin-top:20px}[data-v-a447a8ef] .el-tabs__nav-scroll{overflow-x:scroll}[data-v-a447a8ef] .el-tabs__nav-scroll::-webkit-scrollbar{display:none}}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{J as se,K as R,L as $,M as ae,N as ne,d as E,O as y,Q as le,r as A,k as m,R as re,f as c,D as K,w as p,c as _,H as I,t as k,S as C,T as U,b as B,V as ie,W as pe,X as ce,Y as de,g as L,a as o,Z as N,$ as J,h as Q,F as D,C as X,s as F,j as n,a0 as Y,x as G,_ as z,a1 as ee,o as te,a2 as ue,u as _e,U as O,i as W,E as fe,I as ve,p as he,e as me,a3 as ge}from"./index-62c7029f.js";import{E as be}from"./el-dialog-463960e0.js";import{d as H,E as we,a as $e,b as ye,c as Ce}from"./el-dropdown-item-7c33f4fa.js";import{E as ke,a as xe}from"./el-tab-pane-b3156067.js";import{E as Ee}from"./index-17fa8fb7.js";import"./index-6d7ac779.js";import"./aria-bc8e8b0f.js";import"./validator-853854a1.js";const Me=se({trigger:R.trigger,placement:H.placement,disabled:R.disabled,visible:$.visible,transition:$.transition,popperOptions:H.popperOptions,tabindex:H.tabindex,content:$.content,popperStyle:$.popperStyle,popperClass:$.popperClass,enterable:{...$.enterable,default:!0},effect:{...$.effect,default:"light"},teleported:$.teleported,title:String,width:{type:[String,Number],default:150},offset:{type:Number,default:void 0},showAfter:{type:Number,default:0},hideAfter:{type:Number,default:200},autoClose:{type:Number,default:0},showArrow:{type:Boolean,default:!0},persistent:{type:Boolean,default:!0},"onUpdate:visible":{type:Function}}),Ve={"update:visible":r=>ae(r),"before-enter":()=>!0,"before-leave":()=>!0,"after-enter":()=>!0,"after-leave":()=>!0},Se={name:"ElPopover"},Ae=E({...Se,props:Me,emits:Ve,setup(r,{expose:l,emit:t}){const s=r,f="onUpdate:visible",i=y(()=>s[f]),h=le("popover"),g=A(),u=y(()=>{var e;return(e=m(g))==null?void 0:e.popperRef}),v=y(()=>[{width:re(s.width)},s.popperStyle]),b=y(()=>[h.b(),s.popperClass,{[h.m("plain")]:!!s.content}]),d=y(()=>s.transition==="el-fade-in-linear"),a=()=>{var e;(e=g.value)==null||e.hide()},x=()=>{t("before-enter")},w=()=>{t("before-leave")},M=()=>{t("after-enter")},V=()=>{t("update:visible",!1),t("after-leave")};return l({popperRef:u,hide:a}),(e,T)=>(c(),K(m(pe),ie({ref_key:"tooltipRef",ref:g},e.$attrs,{trigger:e.trigger,placement:e.placement,disabled:e.disabled,visible:e.visible,transition:e.transition,"popper-options":e.popperOptions,tabindex:e.tabindex,content:e.content,offset:e.offset,"show-after":e.showAfter,"hide-after":e.hideAfter,"auto-close":e.autoClose,"show-arrow":e.showArrow,"aria-label":e.title,effect:e.effect,enterable:e.enterable,"popper-class":m(b),"popper-style":m(v),teleported:e.teleported,persistent:e.persistent,"gpu-acceleration":m(d),"onUpdate:visible":m(i),onBeforeShow:x,onBeforeHide:w,onShow:M,onHide:V}),{content:p(()=>[e.title?(c(),_("div",{key:0,class:I(m(h).e("title")),role:"title"},k(e.title),3)):C("v-if",!0),U(e.$slots,"default",{},()=>[B(k(e.content),1)])]),default:p(()=>[e.$slots.reference?U(e.$slots,"reference",{key:0}):C("v-if",!0)]),_:3},16,["trigger","placement","disabled","visible","transition","popper-options","tabindex","content","offset","show-after","hide-after","auto-close","show-arrow","aria-label","effect","enterable","popper-class","popper-style","teleported","persistent","gpu-acceleration","onUpdate:visible"]))}});var Be=ne(Ae,[["__file","/home/runner/work/element-plus/element-plus/packages/components/popover/src/popover.vue"]]);const Z=(r,l)=>{const t=l.arg||l.value,s=t==null?void 0:t.popperRef;s&&(s.triggerRef=r)};var Pe={mounted(r,l){Z(r,l)},updated(r,l){Z(r,l)}};const He="popover",De=ce(Pe,He),Ie=de(Be,{directive:De}),Le=E({name:"Bell"}),Ne={viewBox:"0 0 1024 1024",xmlns:"http://www.w3.org/2000/svg"},ze=o("path",{fill:"currentColor",d:"M512 64a64 64 0 0 1 64 64v64H448v-64a64 64 0 0 1 64-64z"},null,-1),Te=o("path",{fill:"currentColor",d:"M256 768h512V448a256 256 0 1 0-512 0v320zm256-640a320 320 0 0 1 320 320v384H192V448a320 320 0 0 1 320-320z"},null,-1),Re=o("path",{fill:"currentColor",d:"M96 768h832q32 0 32 32t-32 32H96q-32 0-32-32t32-32zm352 128h128a64 64 0 0 1-128 0z"},null,-1),Ue=[ze,Te,Re];function Fe(r,l,t,s,f,i){return c(),_("svg",Ne,Ue)}var Oe=L(Le,[["render",Fe]]);const We=E({name:"Close"}),Ze={viewBox:"0 0 1024 1024",xmlns:"http://www.w3.org/2000/svg"},je=o("path",{fill:"currentColor",d:"M764.288 214.592 512 466.88 259.712 214.592a31.936 31.936 0 0 0-45.12 45.12L466.752 512 214.528 764.224a31.936 31.936 0 1 0 45.12 45.184L512 557.184l252.288 252.288a31.936 31.936 0 0 0 45.12-45.12L557.12 512.064l252.288-252.352a31.936 31.936 0 1 0-45.12-45.184z"},null,-1),qe=[je];function Ke(r,l,t,s,f,i){return c(),_("svg",Ze,qe)}var Je=L(We,[["render",Ke]]);const Qe=E({name:"Expand"}),Xe={viewBox:"0 0 1024 1024",xmlns:"http://www.w3.org/2000/svg"},Ye=o("path",{fill:"currentColor",d:"M128 192h768v128H128V192zm0 256h512v128H128V448zm0 256h768v128H128V704zm576-352 192 160-192 128V352z"},null,-1),Ge=[Ye];function et(r,l,t,s,f,i){return c(),_("svg",Xe,Ge)}var tt=L(Qe,[["render",et]]);const ot={key:0,class:"empty"},st={class:"message-list"},at=["onClick"],nt={class:"text"},lt={class:"date"},rt=["innerHTML"],it={class:"dialog-date"},pt=E({__name:"index",props:{data:{},autoShow:{type:Boolean}},setup(r){const l=r,t=N({show:!1,title:"系统消息",text:"内容"}),s=A(null),f=u=>{s.value=u,t.text=u.text,t.title=u.type===0?"【系统消息】":"【私信】",t.show=!0},i=()=>{if(s.value.read){t.show=!1;return}Y.readMessage(s.value.id).then(()=>{s.value.read=!0,t.show=!1})};J(()=>l.data.length,()=>{if(!l.autoShow)return;const u=l.data.find(v=>!v.read);u&&f(u)});const h=Q(),g=y(()=>h.getters["public/isMobile"]);return(u,v)=>{const b=G,d=be;return c(),_(D,null,[u.data.length?C("",!0):(c(),_("div",ot,"暂无更多消息 ღ( ´・ᴗ・` )比心")),o("ul",st,[(c(!0),_(D,null,X(u.data,a=>(c(),_("li",{key:a.id,class:I({read:a.read}),onClick:x=>f(a)},[o("p",nt,k(a.text),1),o("p",lt,k(m(F)(new Date(a.date))),1)],10,at))),128))]),n(d,{center:"","show-close":"","append-to-body":"",modelValue:t.show,"onUpdate:modelValue":v[1]||(v[1]=a=>t.show=a),"close-on-click-modal":!1,title:t.title,width:"30%",fullscreen:g.value},{footer:p(()=>[o("p",it," 时间:"+k(m(F)(new Date(s.value.date))),1),o("span",null,[n(b,{type:"default",onClick:v[0]||(v[0]=()=>{t.show=!1})},{default:p(()=>[B(" 下次提醒 ")]),_:1}),n(b,{type:"primary",onClick:i},{default:p(()=>[B(" 确定 ")]),_:1})])]),default:p(()=>[o("div",{class:"message-text",innerHTML:t.text},null,8,rt)]),_:1},8,["modelValue","title","fullscreen"])],64)}}});const j=z(pt,[["__scopeId","data-v-46eebd19"]]),ct={class:"message-panel"},dt=E({__name:"index",setup(r){const l=A("all"),t=N([]),s=y(()=>t.filter(i=>!i.read)),f=ee();return te(()=>{f.name!=="config"&&Y.getMessageList().then(i=>{t.push(...i.data)})}),(i,h)=>{const g=G,u=ue,v=ke,b=xe,d=Ie;return c(),_("div",ct,[n(d,{placement:"bottom-end",width:375,trigger:"hover"},{reference:p(()=>[n(u,{value:s.value.length||"",max:99},{default:p(()=>[n(g,{icon:m(Oe),circle:""},null,8,["icon"])]),_:1},8,["value"])]),default:p(()=>[o("div",null,[n(b,{modelValue:l.value,"onUpdate:modelValue":h[0]||(h[0]=a=>l.value=a)},{default:p(()=>[n(v,{label:"未读 ".concat(s.value.length||""),name:"no"},{default:p(()=>[n(j,{"auto-show":"",data:s.value},null,8,["data"])]),_:1},8,["label"]),n(v,{label:"全部 ".concat(t.length||""),name:"all"},{default:p(()=>[n(j,{data:t},null,8,["data"])]),_:1},8,["label"])]),_:1},8,["modelValue"])])]),_:1})])}}});const q=z(dt,[["__scopeId","data-v-9de070a6"]]),S=r=>(he("data-v-2108dc2b"),r=r(),me(),r),ut={class:"dashboard"},_t={class:"pc-nav"},ft={class:"nav"},vt={class:"logo"},ht=S(()=>o("img",{src:"https://img.cdn.sugarat.top/easypicker/EasyPicker.png",alt:"logo"},null,-1)),mt={key:0,type:"checkbox",id:"navActive"},gt={key:0,for:"navActive",class:"nav-item"},bt=S(()=>o("span",null,"Hello💐,",-1)),wt=["onClick"],$t=S(()=>o("span",{style:{"margin-right":"6px"}},"退出",-1)),yt=S(()=>o("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",xmlns:"http://www.w3.org/2000/svg","data-v-53d86618":""},[o("path",{"fill-rule":"evenodd","clip-rule":"evenodd",d:"M10.6667 2.55473C13.0212 3.58347 14.6667 5.93291 14.6667 8.66667C14.6667 12.3486 11.6819 15.3333 8 15.3333C4.3181 15.3333 1.33333 12.3486 1.33333 8.66667C1.33333 5.93291 2.97879 3.58347 5.33333 2.55473V4.04684C3.7392 4.969 2.66667 6.69259 2.66667 8.66667C2.66667 11.6122 5.05448 14 8 14C10.9455 14 13.3333 11.6122 13.3333 8.66667C13.3333 6.69259 12.2608 4.969 10.6667 4.04684V2.55473ZM7.33333 8.66667V1.33333C7.33333 1.14924 7.48257 1 7.66667 1H8.33333C8.51743 1 8.66667 1.14924 8.66667 1.33333V8.66667C8.66667 8.85076 8.51743 9 8.33333 9H7.66667C7.48257 9 7.33333 8.85076 7.33333 8.66667Z",fill:"#86909C","data-v-53d86618":""})],-1)),Ct=S(()=>o("div",{class:"mask"},null,-1)),kt={id:"navMenu"},xt={for:"navActive"},Et={key:0,class:"flex fac"},Mt=S(()=>o("span",null,"Hello 💐,",-1)),Vt={class:"exit-info"},St={class:"ellipsis"},At=E({__name:"index",setup(r){const l=_e(),t=Q(),s=ee(),f=y(()=>t.getters["public/isMobile"]),i=N([{title:"文件管理",path:"/dashboard/files"},{title:"任务管理",path:"/dashboard/tasks"}]),h=A(0),g=d=>{const a=i[d];!a.isExternal&&d!==h.value&&l.push({path:a.path}),a.isExternal&&window.open(a.path,"_blank")};J(()=>s.path,d=>{const a=i.findIndex(x=>d.startsWith(x.path));a!==-1&&(h.value=a)});const u=()=>{Ee.confirm("确认退出登录?","登出提示",{draggable:!0}).then(()=>{O.logout().finally(()=>{t.commit("user/setToken",null),l.replace({name:"home"})})}).catch(()=>{fe.info("取消")})},v=A("World"),b=()=>{h.value=i.findIndex(d=>s.path.startsWith(d.path))};return te(()=>{O.checkPower().then(d=>{var w,M,V;const a=(w=d.data)==null?void 0:w.power;if(v.value=(M=d.data)==null?void 0:M.name,t.commit("user/setSuperAdmin",a),a){const e=[{title:"应用管理",path:"/dashboard/manage"},{title:"网站监控",path:"https://www.frontjs.com/app/87c1ef7667a513f313b4abb22a88dc78",isExternal:!0}];i.push(...e)}((V=d.data)==null?void 0:V.system)&&(i.splice(0,i.length),i.push({title:"系统管理",path:"/dashboard/config"})),b()})}),(d,a)=>{const x=W("router-link"),w=ve,M=ye,V=Ce,e=we,T=W("router-view");return c(),_("div",ut,[o("div",_t,[o("div",ft,[o("div",vt,[n(x,{to:"/"},{default:p(()=>[ht]),_:1})]),f.value?(c(),_("input",mt)):C("",!0),o("nav",null,[f.value?(c(),_("label",gt,[bt,B(" "+k(v.value),1)])):C("",!0),(c(!0),_(D,null,X(i,(oe,P)=>(c(),_("label",{for:"navActive",class:I(["nav-item",{active:h.value===P}]),key:P,onClick:Bt=>g(P)},k(oe.title),11,wt))),128)),f.value?(c(),_("label",{key:1,onClick:u,for:"navActive",class:"nav-item"},[$t,n(w,{size:"16"},{default:p(()=>[yt]),_:1})])):C("",!0)]),Ct]),o("span",kt,[f.value?(c(),K(q,{key:0,class:"mobile-message-bell"})):C("",!0),o("label",xt,[n(w,{size:"32"},{default:p(()=>[n(m(tt))]),_:1})])]),f.value?C("",!0):(c(),_("div",Et,[n(q),Mt,n(e,{class:"exit"},{dropdown:p(()=>[n(V,null,{default:p(()=>[n(M,{onClick:u,icon:m(Je)},{default:p(()=>[B("退出")]),_:1},8,["icon"])]),_:1})]),default:p(()=>[o("span",Vt,[o("span",St,k(v.value),1),n(w,null,{default:p(()=>[n(m($e))]),_:1})])]),_:1})]))]),n(T),o("div",null,[n(ge,{type:"dashboard"})])])}}});const Rt=z(At,[["__scopeId","data-v-2108dc2b"]]);export{Rt as default};
|
|
2
|
+
//# sourceMappingURL=index-8eff6b5a.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-8eff6b5a.js","sources":["../../node_modules/.pnpm/element-plus@2.2.13_vue@3.3.4/node_modules/element-plus/es/components/popover/src/popover.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.3.4/node_modules/element-plus/es/components/popover/src/popover2.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.3.4/node_modules/element-plus/es/components/popover/src/directive.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.3.4/node_modules/element-plus/es/components/popover/index.mjs","../../node_modules/.pnpm/@element-plus+icons-vue@1.1.4_vue@3.3.4/node_modules/@element-plus/icons-vue/dist/es/bell.mjs","../../node_modules/.pnpm/@element-plus+icons-vue@1.1.4_vue@3.3.4/node_modules/@element-plus/icons-vue/dist/es/close.mjs","../../node_modules/.pnpm/@element-plus+icons-vue@1.1.4_vue@3.3.4/node_modules/@element-plus/icons-vue/dist/es/expand.mjs","../../src/components/MessageList/index.vue","../../src/components/MessagePanel/index.vue","../../src/pages/dashboard/index.vue"],"sourcesContent":["import '../../../utils/index.mjs';\nimport '../../tooltip/index.mjs';\nimport '../../dropdown/index.mjs';\nimport { buildProps } from '../../../utils/vue/props/runtime.mjs';\nimport { useTooltipTriggerProps, useTooltipContentProps } from '../../tooltip/src/tooltip.mjs';\nimport { dropdownProps } from '../../dropdown/src/dropdown.mjs';\nimport { isBoolean } from '@vueuse/core';\n\nconst popoverProps = buildProps({\n trigger: useTooltipTriggerProps.trigger,\n placement: dropdownProps.placement,\n disabled: useTooltipTriggerProps.disabled,\n visible: useTooltipContentProps.visible,\n transition: useTooltipContentProps.transition,\n popperOptions: dropdownProps.popperOptions,\n tabindex: dropdownProps.tabindex,\n content: useTooltipContentProps.content,\n popperStyle: useTooltipContentProps.popperStyle,\n popperClass: useTooltipContentProps.popperClass,\n enterable: {\n ...useTooltipContentProps.enterable,\n default: true\n },\n effect: {\n ...useTooltipContentProps.effect,\n default: \"light\"\n },\n teleported: useTooltipContentProps.teleported,\n title: String,\n width: {\n type: [String, Number],\n default: 150\n },\n offset: {\n type: Number,\n default: void 0\n },\n showAfter: {\n type: Number,\n default: 0\n },\n hideAfter: {\n type: Number,\n default: 200\n },\n autoClose: {\n type: Number,\n default: 0\n },\n showArrow: {\n type: Boolean,\n default: true\n },\n persistent: {\n type: Boolean,\n default: true\n },\n \"onUpdate:visible\": {\n type: Function\n }\n});\nconst popoverEmits = {\n \"update:visible\": (value) => isBoolean(value),\n \"before-enter\": () => true,\n \"before-leave\": () => true,\n \"after-enter\": () => true,\n \"after-leave\": () => true\n};\n\nexport { popoverEmits, popoverProps };\n//# sourceMappingURL=popover.mjs.map\n","import { defineComponent, computed, ref, unref, openBlock, createBlock, mergeProps, withCtx, createElementBlock, normalizeClass, toDisplayString, createCommentVNode, renderSlot, createTextVNode } from 'vue';\nimport { ElTooltip } from '../../tooltip/index.mjs';\nimport '../../../utils/index.mjs';\nimport '../../../hooks/index.mjs';\nimport { popoverProps, popoverEmits } from './popover.mjs';\nimport _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';\nimport { useNamespace } from '../../../hooks/use-namespace/index.mjs';\nimport { addUnit } from '../../../utils/dom/style.mjs';\n\nconst __default__ = {\n name: \"ElPopover\"\n};\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n ...__default__,\n props: popoverProps,\n emits: popoverEmits,\n setup(__props, { expose, emit }) {\n const props = __props;\n const updateEventKeyRaw = `onUpdate:visible`;\n const onUpdateVisible = computed(() => {\n return props[updateEventKeyRaw];\n });\n const ns = useNamespace(\"popover\");\n const tooltipRef = ref();\n const popperRef = computed(() => {\n var _a;\n return (_a = unref(tooltipRef)) == null ? void 0 : _a.popperRef;\n });\n const style = computed(() => {\n return [\n {\n width: addUnit(props.width)\n },\n props.popperStyle\n ];\n });\n const kls = computed(() => {\n return [ns.b(), props.popperClass, { [ns.m(\"plain\")]: !!props.content }];\n });\n const gpuAcceleration = computed(() => {\n return props.transition === \"el-fade-in-linear\";\n });\n const hide = () => {\n var _a;\n (_a = tooltipRef.value) == null ? void 0 : _a.hide();\n };\n const beforeEnter = () => {\n emit(\"before-enter\");\n };\n const beforeLeave = () => {\n emit(\"before-leave\");\n };\n const afterEnter = () => {\n emit(\"after-enter\");\n };\n const afterLeave = () => {\n emit(\"update:visible\", false);\n emit(\"after-leave\");\n };\n expose({\n popperRef,\n hide\n });\n return (_ctx, _cache) => {\n return openBlock(), createBlock(unref(ElTooltip), mergeProps({\n ref_key: \"tooltipRef\",\n ref: tooltipRef\n }, _ctx.$attrs, {\n trigger: _ctx.trigger,\n placement: _ctx.placement,\n disabled: _ctx.disabled,\n visible: _ctx.visible,\n transition: _ctx.transition,\n \"popper-options\": _ctx.popperOptions,\n tabindex: _ctx.tabindex,\n content: _ctx.content,\n offset: _ctx.offset,\n \"show-after\": _ctx.showAfter,\n \"hide-after\": _ctx.hideAfter,\n \"auto-close\": _ctx.autoClose,\n \"show-arrow\": _ctx.showArrow,\n \"aria-label\": _ctx.title,\n effect: _ctx.effect,\n enterable: _ctx.enterable,\n \"popper-class\": unref(kls),\n \"popper-style\": unref(style),\n teleported: _ctx.teleported,\n persistent: _ctx.persistent,\n \"gpu-acceleration\": unref(gpuAcceleration),\n \"onUpdate:visible\": unref(onUpdateVisible),\n onBeforeShow: beforeEnter,\n onBeforeHide: beforeLeave,\n onShow: afterEnter,\n onHide: afterLeave\n }), {\n content: withCtx(() => [\n _ctx.title ? (openBlock(), createElementBlock(\"div\", {\n key: 0,\n class: normalizeClass(unref(ns).e(\"title\")),\n role: \"title\"\n }, toDisplayString(_ctx.title), 3)) : createCommentVNode(\"v-if\", true),\n renderSlot(_ctx.$slots, \"default\", {}, () => [\n createTextVNode(toDisplayString(_ctx.content), 1)\n ])\n ]),\n default: withCtx(() => [\n _ctx.$slots.reference ? renderSlot(_ctx.$slots, \"reference\", { key: 0 }) : createCommentVNode(\"v-if\", true)\n ]),\n _: 3\n }, 16, [\"trigger\", \"placement\", \"disabled\", \"visible\", \"transition\", \"popper-options\", \"tabindex\", \"content\", \"offset\", \"show-after\", \"hide-after\", \"auto-close\", \"show-arrow\", \"aria-label\", \"effect\", \"enterable\", \"popper-class\", \"popper-style\", \"teleported\", \"persistent\", \"gpu-acceleration\", \"onUpdate:visible\"]);\n };\n }\n});\nvar Popover = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__file\", \"/home/runner/work/element-plus/element-plus/packages/components/popover/src/popover.vue\"]]);\n\nexport { Popover as default };\n//# sourceMappingURL=popover2.mjs.map\n","const attachEvents = (el, binding) => {\n const popperComponent = binding.arg || binding.value;\n const popover = popperComponent == null ? void 0 : popperComponent.popperRef;\n if (popover) {\n popover.triggerRef = el;\n }\n};\nvar PopoverDirective = {\n mounted(el, binding) {\n attachEvents(el, binding);\n },\n updated(el, binding) {\n attachEvents(el, binding);\n }\n};\nconst VPopover = \"popover\";\n\nexport { VPopover, PopoverDirective as default };\n//# sourceMappingURL=directive.mjs.map\n","import '../../utils/index.mjs';\nimport Popover from './src/popover2.mjs';\nimport PopoverDirective, { VPopover } from './src/directive.mjs';\nexport { popoverEmits, popoverProps } from './src/popover.mjs';\nimport { withInstallDirective, withInstall } from '../../utils/vue/install.mjs';\n\nconst ElPopoverDirective = withInstallDirective(PopoverDirective, VPopover);\nconst ElPopover = withInstall(Popover, {\n directive: ElPopoverDirective\n});\n\nexport { ElPopover, ElPopoverDirective, ElPopover as default };\n//# sourceMappingURL=index.mjs.map\n","import { defineComponent, openBlock, createElementBlock, createElementVNode } from 'vue';\nimport _export_sfc from './_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = defineComponent({\n name: \"Bell\"\n});\nconst _hoisted_1 = {\n viewBox: \"0 0 1024 1024\",\n xmlns: \"http://www.w3.org/2000/svg\"\n};\nconst _hoisted_2 = /* @__PURE__ */ createElementVNode(\"path\", {\n fill: \"currentColor\",\n d: \"M512 64a64 64 0 0 1 64 64v64H448v-64a64 64 0 0 1 64-64z\"\n}, null, -1);\nconst _hoisted_3 = /* @__PURE__ */ createElementVNode(\"path\", {\n fill: \"currentColor\",\n d: \"M256 768h512V448a256 256 0 1 0-512 0v320zm256-640a320 320 0 0 1 320 320v384H192V448a320 320 0 0 1 320-320z\"\n}, null, -1);\nconst _hoisted_4 = /* @__PURE__ */ createElementVNode(\"path\", {\n fill: \"currentColor\",\n d: \"M96 768h832q32 0 32 32t-32 32H96q-32 0-32-32t32-32zm352 128h128a64 64 0 0 1-128 0z\"\n}, null, -1);\nconst _hoisted_5 = [\n _hoisted_2,\n _hoisted_3,\n _hoisted_4\n];\nfunction _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {\n return openBlock(), createElementBlock(\"svg\", _hoisted_1, _hoisted_5);\n}\nvar bell = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render]]);\n\nexport { bell as default };\n","import { defineComponent, openBlock, createElementBlock, createElementVNode } from 'vue';\nimport _export_sfc from './_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = defineComponent({\n name: \"Close\"\n});\nconst _hoisted_1 = {\n viewBox: \"0 0 1024 1024\",\n xmlns: \"http://www.w3.org/2000/svg\"\n};\nconst _hoisted_2 = /* @__PURE__ */ createElementVNode(\"path\", {\n fill: \"currentColor\",\n d: \"M764.288 214.592 512 466.88 259.712 214.592a31.936 31.936 0 0 0-45.12 45.12L466.752 512 214.528 764.224a31.936 31.936 0 1 0 45.12 45.184L512 557.184l252.288 252.288a31.936 31.936 0 0 0 45.12-45.12L557.12 512.064l252.288-252.352a31.936 31.936 0 1 0-45.12-45.184z\"\n}, null, -1);\nconst _hoisted_3 = [\n _hoisted_2\n];\nfunction _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {\n return openBlock(), createElementBlock(\"svg\", _hoisted_1, _hoisted_3);\n}\nvar close = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render]]);\n\nexport { close as default };\n","import { defineComponent, openBlock, createElementBlock, createElementVNode } from 'vue';\nimport _export_sfc from './_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = defineComponent({\n name: \"Expand\"\n});\nconst _hoisted_1 = {\n viewBox: \"0 0 1024 1024\",\n xmlns: \"http://www.w3.org/2000/svg\"\n};\nconst _hoisted_2 = /* @__PURE__ */ createElementVNode(\"path\", {\n fill: \"currentColor\",\n d: \"M128 192h768v128H128V192zm0 256h512v128H128V448zm0 256h768v128H128V704zm576-352 192 160-192 128V352z\"\n}, null, -1);\nconst _hoisted_3 = [\n _hoisted_2\n];\nfunction _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {\n return openBlock(), createElementBlock(\"svg\", _hoisted_1, _hoisted_3);\n}\nvar expand = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render]]);\n\nexport { expand as default };\n","<script lang=\"ts\" setup>\nimport { ref, reactive, onMounted, watch, computed } from 'vue'\nimport { useStore } from 'vuex'\nimport { formatDate } from '@/utils/stringUtil'\nimport { SuperUserApi } from '@/apis'\n\nconst props = defineProps<{\n data: SuperUserApiTypes.MessageItem[]\n autoShow?: boolean\n}>()\n\nconst dialogMessage = reactive({\n show: false,\n title: '系统消息',\n text: '内容'\n})\nconst activeMessage = ref<SuperUserApiTypes.MessageItem>(null)\nconst handleViewDialogMessage = (v: SuperUserApiTypes.MessageItem) => {\n activeMessage.value = v\n dialogMessage.text = v.text\n // TODO: 魔法数字问题\n // TODO:支持更多的消息类型\n dialogMessage.title = v.type === 0 ? '【系统消息】' : '【私信】'\n dialogMessage.show = true\n}\n\nconst readMessage = () => {\n if (activeMessage.value.read) {\n dialogMessage.show = false\n return\n }\n SuperUserApi.readMessage(activeMessage.value.id).then(() => {\n activeMessage.value.read = true\n dialogMessage.show = false\n })\n}\n\nwatch(\n () => props.data.length,\n () => {\n if (!props.autoShow) {\n return\n }\n const showItem = props.data.find((v) => !v.read)\n if (showItem) {\n handleViewDialogMessage(showItem)\n }\n }\n)\n\n// TODO:换成自定义hook\nconst $store = useStore()\nconst isMobile = computed(() => $store.getters['public/isMobile'])\n</script>\n<template>\n <div v-if=\"!data.length\" class=\"empty\">暂无更多消息 ღ( ´・ᴗ・` )比心</div>\n <ul class=\"message-list\">\n <li\n v-for=\"d in data\"\n :key=\"d.id\"\n :class=\"{\n read: d.read\n }\"\n @click=\"handleViewDialogMessage(d)\"\n >\n <p class=\"text\">{{ d.text }}</p>\n <p class=\"date\">{{ formatDate(new Date(d.date)) }}</p>\n </li>\n </ul>\n <el-dialog\n center\n show-close\n append-to-body\n v-model=\"dialogMessage.show\"\n :close-on-click-modal=\"false\"\n :title=\"dialogMessage.title\"\n width=\"30%\"\n :fullscreen=\"isMobile\"\n >\n <div class=\"message-text\" v-html=\"dialogMessage.text\"></div>\n <template #footer>\n <p class=\"dialog-date\">\n 时间:{{ formatDate(new Date(activeMessage.date)) }}\n </p>\n <span>\n <el-button\n type=\"default\"\n @click=\"\n () => {\n dialogMessage.show = false\n }\n \"\n >\n 下次提醒\n </el-button>\n <el-button type=\"primary\" @click=\"readMessage\"> 确定 </el-button>\n </span>\n </template>\n </el-dialog>\n</template>\n\n<style lang=\"scss\" scoped>\n.message-list {\n list-style: none;\n max-height: 500px;\n overflow-y: scroll;\n li {\n border-bottom: 1px solid #ddd;\n padding: 10px;\n cursor: pointer;\n &.read {\n opacity: 0.5;\n &:hover {\n opacity: 0.9;\n }\n }\n &:last-child {\n border-bottom: none;\n }\n\n p.text {\n font-size: 16px;\n display: -webkit-box;\n overflow: hidden;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n }\n p.date {\n font-size: 14px;\n margin-top: 4px;\n }\n }\n}\n.empty {\n text-align: center;\n padding: 10px;\n}\n\n.dialog-date {\n font-size: 14px;\n text-align: right;\n padding: 10px;\n color: grey;\n}\n</style>\n<style lang=\"scss\">\n.message-text {\n overflow-y: scroll;\n max-height: 500px;\n ul,\n ol {\n list-style: none;\n }\n}\n</style>\n","<script lang=\"ts\" setup>\nimport { Bell } from '@element-plus/icons-vue'\nimport { computed, reactive, onMounted, ref } from 'vue'\nimport { useRoute } from 'vue-router'\nimport { SuperUserApi } from '@/apis'\nimport MessageList from '@/components/MessageList/index.vue'\n\nconst activeTab = ref<'all' | 'no'>('all')\nconst messageData = reactive<SuperUserApiTypes.MessageItem[]>([])\n\nconst noReadMessage = computed(() => messageData.filter((v) => !v.read))\nconst route = useRoute()\nonMounted(() => {\n if (route.name !== 'config') {\n SuperUserApi.getMessageList().then((v) => {\n messageData.push(...v.data)\n })\n }\n})\n</script>\n<template>\n <div class=\"message-panel\">\n <el-popover placement=\"bottom-end\" :width=\"375\" trigger=\"hover\">\n <template #reference>\n <el-badge :value=\"noReadMessage.length || ''\" :max=\"99\">\n <el-button :icon=\"Bell\" circle />\n </el-badge>\n </template>\n <div>\n <el-tabs v-model=\"activeTab\">\n <el-tab-pane :label=\"`未读 ${noReadMessage.length || ''}`\" name=\"no\">\n <message-list auto-show :data=\"noReadMessage\" />\n </el-tab-pane>\n <el-tab-pane :label=\"`全部 ${messageData.length || ''}`\" name=\"all\">\n <message-list :data=\"messageData\" />\n </el-tab-pane>\n </el-tabs>\n </div>\n </el-popover>\n </div>\n</template>\n<style lang=\"scss\" scoped>\n.message-panel {\n margin-right: 10px;\n}\n</style>\n","<template>\n <div class=\"dashboard\">\n <div class=\"pc-nav\">\n <div class=\"nav\">\n <!-- LOGO -->\n <div class=\"logo\">\n <router-link to=\"/\">\n <img\n src=\"https://img.cdn.sugarat.top/easypicker/EasyPicker.png\"\n alt=\"logo\"\n />\n </router-link>\n </div>\n <input v-if=\"isMobile\" type=\"checkbox\" id=\"navActive\" />\n <nav>\n <label v-if=\"isMobile\" for=\"navActive\" class=\"nav-item\">\n <span>Hello💐,</span>\n {{ userName }}\n </label>\n <label\n for=\"navActive\"\n class=\"nav-item\"\n v-for=\"(n, idx) in navList\"\n :key=\"idx\"\n :class=\"{\n active: navActiveIdx === idx\n }\"\n @click=\"handleNav(idx)\"\n >{{ n.title }}</label\n >\n <label\n @click=\"handleLogout\"\n v-if=\"isMobile\"\n for=\"navActive\"\n class=\"nav-item\"\n >\n <span style=\"margin-right: 6px\">退出</span>\n <el-icon size=\"16\">\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n data-v-53d86618\n >\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M10.6667 2.55473C13.0212 3.58347 14.6667 5.93291 14.6667 8.66667C14.6667 12.3486 11.6819 15.3333 8 15.3333C4.3181 15.3333 1.33333 12.3486 1.33333 8.66667C1.33333 5.93291 2.97879 3.58347 5.33333 2.55473V4.04684C3.7392 4.969 2.66667 6.69259 2.66667 8.66667C2.66667 11.6122 5.05448 14 8 14C10.9455 14 13.3333 11.6122 13.3333 8.66667C13.3333 6.69259 12.2608 4.969 10.6667 4.04684V2.55473ZM7.33333 8.66667V1.33333C7.33333 1.14924 7.48257 1 7.66667 1H8.33333C8.51743 1 8.66667 1.14924 8.66667 1.33333V8.66667C8.66667 8.85076 8.51743 9 8.33333 9H7.66667C7.48257 9 7.33333 8.85076 7.33333 8.66667Z\"\n fill=\"#86909C\"\n data-v-53d86618\n />\n </svg>\n </el-icon>\n </label>\n </nav>\n <div class=\"mask\"></div>\n </div>\n <!-- 移动端展示 -->\n <span id=\"navMenu\">\n <message-panel v-if=\"isMobile\" class=\"mobile-message-bell\" />\n <label for=\"navActive\">\n <el-icon size=\"32\">\n <Expand />\n </el-icon>\n </label>\n </span>\n <div class=\"flex fac\" v-if=\"!isMobile\">\n <message-panel />\n <span>Hello 💐,</span>\n <el-dropdown class=\"exit\">\n <span class=\"exit-info\">\n <span class=\"ellipsis\">{{ userName }}</span>\n <el-icon>\n <ArrowDown />\n </el-icon>\n </span>\n <template #dropdown>\n <el-dropdown-menu>\n <el-dropdown-item @click=\"handleLogout\" :icon=\"Close\"\n >退出</el-dropdown-item\n >\n </el-dropdown-menu>\n </template>\n </el-dropdown>\n </div>\n </div>\n <router-view></router-view>\n <div>\n <home-footer type=\"dashboard\"></home-footer>\n </div>\n </div>\n</template>\n<script lang=\"ts\" setup>\nimport { Expand, Close, ArrowDown, Bell } from '@element-plus/icons-vue'\nimport HomeFooter from '@components/HomeFooter/index.vue'\n\nimport { onMounted, reactive, ref, computed, watch } from 'vue'\nimport { useRoute, useRouter } from 'vue-router'\nimport { useStore } from 'vuex'\nimport { ElMessage, ElMessageBox } from 'element-plus'\nimport MessagePanel from '@/components/MessagePanel/index.vue'\nimport { UserApi } from '@/apis'\n\nconst $router = useRouter()\nconst $store = useStore()\nconst $route = useRoute()\nconst isMobile = computed(() => $store.getters['public/isMobile'])\nconst navList = reactive<\n { title: string; path: string; isExternal?: boolean }[]\n>([\n {\n title: '文件管理',\n path: '/dashboard/files'\n },\n {\n title: '任务管理',\n path: '/dashboard/tasks'\n }\n])\nconst navActiveIdx = ref(0)\nconst handleNav = (idx: number) => {\n const n = navList[idx]\n if (!n.isExternal && idx !== navActiveIdx.value) {\n $router.push({\n path: n.path\n })\n }\n if (n.isExternal) {\n window.open(n.path, '_blank')\n }\n}\n\n// 自动切换激活的标题栏\nwatch(\n () => $route.path,\n (path: string) => {\n const idx = navList.findIndex((n) => path.startsWith(n.path))\n if (idx !== -1) {\n navActiveIdx.value = idx\n }\n }\n)\n\nconst handleLogout = () => {\n ElMessageBox.confirm('确认退出登录?', '登出提示', {\n draggable: true\n })\n .then(() => {\n // 登出接口\n UserApi.logout().finally(() => {\n $store.commit('user/setToken', null)\n $router.replace({\n name: 'home'\n })\n })\n })\n .catch(() => {\n ElMessage.info('取消')\n })\n}\nconst userName = ref('World')\n\nconst refreshActiveTab = () => {\n // 动态修改active的项\n navActiveIdx.value = navList.findIndex((v) => $route.path.startsWith(v.path))\n}\nonMounted(() => {\n // 动态添加管理页面入口\n UserApi.checkPower().then((r) => {\n const isSuperAdmin = r.data?.power\n userName.value = r.data?.name\n $store.commit('user/setSuperAdmin', isSuperAdmin)\n if (isSuperAdmin) {\n const superNavList = [\n {\n title: '应用管理',\n path: '/dashboard/manage'\n },\n {\n title: '网站监控',\n path: 'https://www.frontjs.com/app/87c1ef7667a513f313b4abb22a88dc78',\n isExternal: true\n }\n ]\n navList.push(...superNavList)\n }\n const isSystem = r.data?.system\n if (isSystem) {\n navList.splice(0, navList.length)\n navList.push({\n title: '系统管理',\n path: '/dashboard/config'\n })\n }\n refreshActiveTab()\n })\n})\n</script>\n<style scoped lang=\"scss\">\n.dashboard {\n background-color: #fafafa;\n}\n.pc-nav {\n background-color: #fff;\n display: flex;\n padding: 10px;\n justify-content: space-between;\n align-items: center;\n .exit {\n cursor: pointer;\n display: flex;\n align-items: center;\n .exit-info {\n display: flex;\n justify-content: center;\n align-items: center;\n > span {\n margin-right: 5px;\n display: block;\n max-width: 70px;\n }\n }\n }\n .nav {\n display: flex;\n nav {\n display: flex;\n align-items: center;\n .nav-item {\n font-size: 1rem;\n color: #595959;\n padding: 10px;\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: center;\n &.active {\n color: #409eff !important;\n font-weight: 600;\n }\n }\n }\n .exit {\n color: #595959;\n }\n }\n .logo {\n width: 180px;\n margin: 0 10px;\n img {\n height: 40px;\n }\n }\n}\n#navActive {\n display: none;\n opacity: 0;\n}\n#navMenu {\n display: none;\n}\n.mobile-message-bell {\n display: none;\n position: fixed;\n right: 0;\n top: 0;\n}\n@media screen and (max-width: 700px) {\n #navActive {\n display: block;\n position: fixed;\n left: 0;\n top: 0;\n }\n .mobile-message-bell {\n display: block;\n }\n #navMenu {\n cursor: pointer;\n display: block;\n position: absolute;\n left: 10px;\n top: 5px;\n font-size: 2rem;\n }\n .pc-nav {\n position: fixed;\n left: 0;\n right: 0;\n top: 0;\n z-index: 6;\n .nav {\n flex-wrap: wrap;\n width: 100%;\n .logo {\n width: 100%;\n text-align: center;\n }\n }\n #navActive {\n & + nav {\n display: none;\n }\n }\n #navActive:checked {\n & + nav {\n display: flex;\n flex-direction: column;\n width: 100%;\n position: absolute;\n z-index: 1;\n background: #fff;\n left: 0;\n top: 50px;\n + .mask {\n display: block;\n position: fixed;\n left: 0;\n right: 0;\n bottom: 0;\n top: 50px;\n background-color: rgba(0, 0, 0, 0.5);\n }\n }\n }\n .exit {\n position: absolute;\n right: 10px;\n top: 20px;\n }\n }\n}\n</style>\n"],"names":["popoverProps","buildProps","useTooltipTriggerProps","dropdownProps","useTooltipContentProps","popoverEmits","value","isBoolean","__default__","_sfc_main","defineComponent","__props","expose","emit","props","updateEventKeyRaw","onUpdateVisible","computed","ns","useNamespace","tooltipRef","ref","popperRef","_a","unref","style","addUnit","kls","gpuAcceleration","hide","beforeEnter","beforeLeave","afterEnter","afterLeave","_ctx","_cache","openBlock","createBlock","ElTooltip","mergeProps","withCtx","createElementBlock","normalizeClass","toDisplayString","createCommentVNode","renderSlot","createTextVNode","Popover","_export_sfc","attachEvents","el","binding","popperComponent","popover","PopoverDirective","VPopover","ElPopoverDirective","withInstallDirective","ElPopover","withInstall","_hoisted_1","_hoisted_2","createElementVNode","_hoisted_3","_hoisted_4","_hoisted_5","_sfc_render","$props","$setup","$data","$options","bell","close","expand","dialogMessage","reactive","activeMessage","handleViewDialogMessage","v","readMessage","SuperUserApi","watch","showItem","$store","useStore","isMobile","activeTab","messageData","noReadMessage","route","useRoute","onMounted","$router","useRouter","$route","navList","navActiveIdx","handleNav","idx","n","path","handleLogout","ElMessageBox","UserApi","ElMessage","userName","refreshActiveTab","r","isSuperAdmin","_b","superNavList","_c"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
.fade-in-linear-enter-active,.fade-in-linear-leave-active{transition:var(--el-transition-fade-linear)}.fade-in-linear-enter-from,.fade-in-linear-leave-to{opacity:0}.el-fade-in-linear-enter-active,.el-fade-in-linear-leave-active{transition:var(--el-transition-fade-linear)}.el-fade-in-linear-enter-from,.el-fade-in-linear-leave-to{opacity:0}.el-fade-in-enter-active,.el-fade-in-leave-active{transition:all var(--el-transition-duration) cubic-bezier(.55,0,.1,1)}.el-fade-in-enter-from,.el-fade-in-leave-active{opacity:0}.el-zoom-in-center-enter-active,.el-zoom-in-center-leave-active{transition:all var(--el-transition-duration) cubic-bezier(.55,0,.1,1)}.el-zoom-in-center-enter-from,.el-zoom-in-center-leave-active{opacity:0;transform:scaleX(0)}.el-zoom-in-top-enter-active,.el-zoom-in-top-leave-active{opacity:1;transform:scaleY(1);transition:var(--el-transition-md-fade);transform-origin:center top}.el-zoom-in-top-enter-active[data-popper-placement^=top],.el-zoom-in-top-leave-active[data-popper-placement^=top]{transform-origin:center bottom}.el-zoom-in-top-enter-from,.el-zoom-in-top-leave-active{opacity:0;transform:scaleY(0)}.el-zoom-in-bottom-enter-active,.el-zoom-in-bottom-leave-active{opacity:1;transform:scaleY(1);transition:var(--el-transition-md-fade);transform-origin:center bottom}.el-zoom-in-bottom-enter-from,.el-zoom-in-bottom-leave-active{opacity:0;transform:scaleY(0)}.el-zoom-in-left-enter-active,.el-zoom-in-left-leave-active{opacity:1;transform:scale(1);transition:var(--el-transition-md-fade);transform-origin:top left}.el-zoom-in-left-enter-from,.el-zoom-in-left-leave-active{opacity:0;transform:scale(.45)}.collapse-transition{transition:var(--el-transition-duration) height ease-in-out,var(--el-transition-duration) padding-top ease-in-out,var(--el-transition-duration) padding-bottom ease-in-out}.el-collapse-transition-enter-active,.el-collapse-transition-leave-active{transition:var(--el-transition-duration) max-height ease-in-out,var(--el-transition-duration) padding-top ease-in-out,var(--el-transition-duration) padding-bottom ease-in-out}.horizontal-collapse-transition{transition:var(--el-transition-duration) width ease-in-out,var(--el-transition-duration) padding-left ease-in-out,var(--el-transition-duration) padding-right ease-in-out}.el-list-enter-active,.el-list-leave-active{transition:all 1s}.el-list-enter-from,.el-list-leave-to{opacity:0;transform:translateY(-30px)}.el-list-leave-active{position:absolute!important}.el-opacity-transition{transition:opacity var(--el-transition-duration) cubic-bezier(.55,0,.1,1)}:root{--el-menu-active-color:var(--el-color-primary);--el-menu-text-color:var(--el-text-color-primary);--el-menu-hover-text-color:var(--el-color-primary);--el-menu-bg-color:var(--el-fill-color-blank);--el-menu-hover-bg-color:var(--el-color-primary-light-9);--el-menu-item-height:56px;--el-menu-sub-item-height:calc(var(--el-menu-item-height) - 6px);--el-menu-horizontal-sub-item-height:36px;--el-menu-item-font-size:var(--el-font-size-base);--el-menu-item-hover-fill:var(--el-color-primary-light-9);--el-menu-border-color:var(--el-border-color);--el-menu-base-level-padding:20px;--el-menu-level-padding:20px;--el-menu-icon-width:24px;--el-menu-icon-transform-closed:none;--el-menu-icon-transform-open:rotateZ(180deg)}.el-menu{border-right:solid 1px var(--el-menu-border-color);list-style:none;position:relative;margin:0;padding-left:0;background-color:var(--el-menu-bg-color);box-sizing:border-box}.el-menu--vertical:not(.el-menu--collapse):not(.el-menu--popup-container) .el-menu-item,.el-menu--vertical:not(.el-menu--collapse):not(.el-menu--popup-container) .el-menu-item-group__title,.el-menu--vertical:not(.el-menu--collapse):not(.el-menu--popup-container) .el-sub-menu__title{white-space:nowrap;padding-left:calc(var(--el-menu-base-level-padding) + var(--el-menu-level) * var(--el-menu-level-padding))}.el-menu--horizontal{display:flex;flex-wrap:nowrap;border-bottom:solid 1px var(--el-menu-border-color);border-right:none}.el-menu--horizontal>.el-menu-item{display:inline-flex;justify-content:center;align-items:center;height:100%;margin:0;border-bottom:2px solid transparent;color:var(--el-menu-text-color)}.el-menu--horizontal>.el-menu-item a,.el-menu--horizontal>.el-menu-item a:hover{color:inherit}.el-menu--horizontal>.el-menu-item:not(.is-disabled):focus,.el-menu--horizontal>.el-menu-item:not(.is-disabled):hover{background-color:#fff}.el-menu--horizontal>.el-sub-menu:focus,.el-menu--horizontal>.el-sub-menu:hover{outline:0}.el-menu--horizontal>.el-sub-menu:hover .el-sub-menu__title{color:var(--el-menu-hover-text-color)}.el-menu--horizontal>.el-sub-menu.is-active .el-sub-menu__title{border-bottom:2px solid var(--el-menu-active-color);color:var(--el-menu-active-color)}.el-menu--horizontal>.el-sub-menu .el-sub-menu__title{height:100%;border-bottom:2px solid transparent;color:var(--el-menu-text-color)}.el-menu--horizontal>.el-sub-menu .el-sub-menu__title:hover{background-color:var(--el-bg-color-overlay)}.el-menu--horizontal>.el-sub-menu .el-sub-menu__icon-arrow{position:static;vertical-align:middle;margin-left:8px;margin-top:-3px}.el-menu--horizontal .el-menu .el-menu-item,.el-menu--horizontal .el-menu .el-sub-menu__title{background-color:var(--el-menu-bg-color);display:flex;align-items:center;height:var(--el-menu-horizontal-sub-item-height);padding:0 10px;color:var(--el-menu-text-color)}.el-menu--horizontal .el-menu .el-sub-menu__title{padding-right:40px}.el-menu--horizontal .el-menu .el-menu-item.is-active,.el-menu--horizontal .el-menu .el-sub-menu.is-active>.el-sub-menu__title{color:var(--el-menu-active-color)}.el-menu--horizontal .el-menu-item:not(.is-disabled):focus,.el-menu--horizontal .el-menu-item:not(.is-disabled):hover{outline:0;color:var(--el-menu-hover-text-color);background-color:var(--el-menu-hover-bg-color)}.el-menu--horizontal>.el-menu-item.is-active{border-bottom:2px solid var(--el-menu-active-color);color:var(--el-menu-active-color)!important}.el-menu--collapse{width:calc(var(--el-menu-icon-width) + var(--el-menu-base-level-padding) * 2)}.el-menu--collapse>.el-menu-item [class^=el-icon],.el-menu--collapse>.el-sub-menu>.el-sub-menu__title [class^=el-icon]{margin:0;vertical-align:middle;width:var(--el-menu-icon-width);text-align:center}.el-menu--collapse>.el-menu-item .el-sub-menu__icon-arrow,.el-menu--collapse>.el-sub-menu>.el-sub-menu__title .el-sub-menu__icon-arrow{display:none}.el-menu--collapse>.el-menu-item>span,.el-menu--collapse>.el-sub-menu>.el-sub-menu__title>span{height:0;width:0;overflow:hidden;visibility:hidden;display:inline-block}.el-menu--collapse>.el-menu-item.is-active i{color:inherit}.el-menu--collapse .el-menu .el-sub-menu{min-width:200px}.el-menu--collapse .el-sub-menu{position:relative}.el-menu--collapse .el-sub-menu .el-menu{position:absolute;margin-left:5px;top:0;left:100%;z-index:10;border:1px solid var(--el-border-color-light);border-radius:var(--el-border-radius-small);box-shadow:var(--el-box-shadow-light)}.el-menu--collapse .el-sub-menu.is-opened>.el-sub-menu__title .el-sub-menu__icon-arrow{transform:var(--el-menu-icon-transform-closed)}.el-menu--collapse .el-sub-menu.is-active .el-sub-menu__title{color:var(--el-menu-active-color)}.el-menu--popup{z-index:100;min-width:200px;border:none;padding:5px 0;border-radius:var(--el-border-radius-small);box-shadow:var(--el-box-shadow-light)}.el-menu .el-icon{flex-shrink:0}.el-menu-item{display:flex;align-items:center;height:var(--el-menu-item-height);line-height:var(--el-menu-item-height);font-size:var(--el-menu-item-font-size);color:var(--el-menu-text-color);padding:0 var(--el-menu-base-level-padding);list-style:none;cursor:pointer;position:relative;transition:border-color var(--el-transition-duration),background-color var(--el-transition-duration),color var(--el-transition-duration);box-sizing:border-box;white-space:nowrap}.el-menu-item *{vertical-align:bottom}.el-menu-item i{color:inherit}.el-menu-item:focus,.el-menu-item:hover{outline:0}.el-menu-item:hover{background-color:var(--el-menu-hover-bg-color)}.el-menu-item.is-disabled{opacity:.25;cursor:not-allowed;background:0 0!important}.el-menu-item [class^=el-icon]{margin-right:5px;width:var(--el-menu-icon-width);text-align:center;font-size:18px;vertical-align:middle}.el-menu-item.is-active{color:var(--el-menu-active-color)}.el-menu-item.is-active i{color:inherit}.el-menu-item .el-menu-tooltip__trigger{position:absolute;left:0;top:0;height:100%;width:100%;display:inline-flex;align-items:center;box-sizing:border-box;padding:0 var(--el-menu-base-level-padding)}.el-sub-menu{list-style:none;margin:0;padding-left:0}.el-sub-menu__title{display:flex;align-items:center;height:var(--el-menu-item-height);line-height:var(--el-menu-item-height);font-size:var(--el-menu-item-font-size);color:var(--el-menu-text-color);padding:0 var(--el-menu-base-level-padding);list-style:none;cursor:pointer;position:relative;transition:border-color var(--el-transition-duration),background-color var(--el-transition-duration),color var(--el-transition-duration);box-sizing:border-box;white-space:nowrap}.el-sub-menu__title *{vertical-align:bottom}.el-sub-menu__title i{color:inherit}.el-sub-menu__title:focus,.el-sub-menu__title:hover{outline:0}.el-sub-menu__title.is-disabled{opacity:.25;cursor:not-allowed;background:0 0!important}.el-sub-menu__title:hover{background-color:var(--el-menu-hover-bg-color)}.el-sub-menu .el-menu{border:none}.el-sub-menu .el-menu-item{height:var(--el-menu-sub-item-height);line-height:var(--el-menu-sub-item-height);min-width:200px}.el-sub-menu__hide-arrow .el-sub-menu__icon-arrow{display:none!important}.el-sub-menu.is-active .el-sub-menu__title{border-bottom-color:var(--el-menu-active-color)}.el-sub-menu.is-opened>.el-sub-menu__title .el-sub-menu__icon-arrow{transform:var(--el-menu-icon-transform-open)}.el-sub-menu.is-disabled .el-menu-item,.el-sub-menu.is-disabled .el-sub-menu__title{opacity:.25;cursor:not-allowed;background:0 0!important}.el-sub-menu .el-icon{vertical-align:middle;margin-right:5px;width:var(--el-menu-icon-width);text-align:center;font-size:18px}.el-sub-menu .el-icon.el-sub-menu__icon-more{margin-right:0!important}.el-sub-menu .el-sub-menu__icon-arrow{position:absolute;top:50%;right:var(--el-menu-base-level-padding);margin-top:-7px;transform:var(--el-menu-icon-transform-closed);transition:transform var(--el-transition-duration);font-size:12px;margin-right:0;width:inherit}.el-menu-item-group>ul{padding:0}.el-menu-item-group__title{padding:7px 0 7px var(--el-menu-base-level-padding);line-height:normal;font-size:12px;color:var(--el-text-color-secondary)}.horizontal-collapse-transition .el-sub-menu__title .el-sub-menu__icon-arrow{transition:var(--el-transition-duration-fast);opacity:0}.monitor[data-v-67f8ea8e]{width:96%;padding:10px;overflow:hidden;display:flex}.navs[data-v-67f8ea8e]{min-width:140px}.container[data-v-67f8ea8e]{padding-left:20px;flex-grow:1;width:calc(100% - 150px)}@media screen and (max-width: 700px){.monitor[data-v-67f8ea8e]{margin-top:70px;padding:10px 0;width:100%}.navs[data-v-67f8ea8e]{position:absolute;left:50%;transform:translate(-50%)}.el-radio-group[data-v-67f8ea8e]{display:none}.el-menu-nav[data-v-67f8ea8e]{display:flex}.container[data-v-67f8ea8e]{padding-left:0;margin-top:30px;width:100%}}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{g as Pe,d as me,f as m,c as A,a as n,h as Te,Z,r,O as q,o as Be,j as t,w as o,k as f,a0 as C,v as De,x as Fe,p as Le,e as Re,F as re,C as ie,D as k,b as s,t as b,s as x,S as $,E as i,q as de,P as ce,z as Ae,A as Ne,_ as Ie}from"./index-62c7029f.js";import{E as Oe,a as je}from"./el-form-item-f40006bf.js";import{d as X,E as He}from"./el-date-picker-5a3e3d86.js";import{E as Ze}from"./el-dialog-463960e0.js";import{E as qe,s as We}from"./el-pagination-ffb99240.js";import{E as Ge,a as Je}from"./el-select-7d894fd0.js";import{E as Ke,a as Qe}from"./el-table-column-22352e92.js";import{U as E}from"./index-9e6bd406.js";import{r as Xe}from"./refresh-6ae903c0.js";import{E as pe}from"./index-17fa8fb7.js";import"./isEqual-9c466456.js";import"./index-6d7ac779.js";import"./validator-853854a1.js";import"./aria-bc8e8b0f.js";const Ye=me({name:"Message"}),el={viewBox:"0 0 1024 1024",xmlns:"http://www.w3.org/2000/svg"},ll=n("path",{fill:"currentColor",d:"M128 224v512a64 64 0 0 0 64 64h640a64 64 0 0 0 64-64V224H128zm0-64h768a64 64 0 0 1 64 64v512a128 128 0 0 1-128 128H192A128 128 0 0 1 64 736V224a64 64 0 0 1 64-64z"},null,-1),tl=n("path",{fill:"currentColor",d:"M904 224 656.512 506.88a192 192 0 0 1-289.024 0L120 224h784zm-698.944 0 210.56 240.704a128 128 0 0 0 192.704 0L818.944 224H205.056z"},null,-1),ol=[ll,tl];function al(U,Y,V,z,S,M){return m(),A("svg",el,ol)}var nl=Pe(Ye,[["render",al]]);const sl=U=>(Le("data-v-0b1b911a"),U=U(),Re(),U),ul={class:"user"},rl={class:"panel"},il={class:"p10 log-filter"},dl={class:"item"},cl=sl(()=>n("span",{class:"label"},"状态",-1)),pl={class:"item"},ml={class:"item"},_l={class:"item"},fl={class:"user-oss-info"},vl={class:"text-btn-list"},hl={class:"flex fc p10"},gl={class:"tc"},wl={class:"dialog-footer"},bl={class:"tc"},Cl={key:0,style:{"margin-top":"10px"},class:"tc"},kl={class:"dialog-footer"},Vl={class:"tc"},yl={class:"dialog-footer"},xl={class:"tc"},$l={class:"dialog-footer"},El=me({__name:"index",setup(U){const Y=Te(),V=Z([]),z=()=>{C.getUserList().then(a=>{V.splice(0,V.length);const l=a.data.list;V.push(...l)})},S=r(E.NORMAL),M=r(""),ee=Z([{label:"正常",type:E.NORMAL},{label:"冻结",type:E.FREEZE},{label:"封禁",type:E.BAN}]),W=q(()=>V.filter(a=>a.status===S.value).filter(a=>{const{id:l,account:p,phone:h,join_time:g,login_count:u,login_time:c,open_time:K}=a;return M.value.length===0?!0:"".concat(l," ").concat(p," ").concat(h," ").concat(u," ").concat(x(K)," ").concat(x(c)," ").concat(x(g)).includes(M.value)})),P=r(10),_e=a=>{P.value=a},fe=q(()=>Math.ceil(W.value.length/P.value)),N=r(1),ve=q(()=>{const a=(N.value-1)*P.value,l=N.value*P.value;return W.value.slice(a,l)}),he=a=>{N.value=a},T=r(!1),v=r(0),y=r(E.NORMAL),ge=ee,B=r(""),we=(a,l,p)=>{v.value=a,y.value=l,B.value=p,T.value=!0},be=()=>{const a=V.find(l=>l.id===v.value);if(y.value===E.FREEZE){if(!B.value){i.warning("请设置解冻时间");return}a.open_time=B.value}else a.open_time="";a.status=y.value,T.value=!1,C.updateUserStatus(a.id,a.status,a.open_time).then(()=>{i.success("修改成功")})},D=r(!1),_=Z({pwd1:"",pwd2:""}),Ce=a=>{v.value=a,D.value=!0,_.pwd1="",_.pwd2=""},ke=()=>Ae.test(_.pwd1)?_.pwd1!==_.pwd2?(i.warning("两次输入的密码不一致"),!1):!0:(i.warning("密码格式不正确(6-16位 支持字母/数字/下划线)"),!1),Ve=()=>{ke()&&pe.confirm("此操作不可逆,请谨慎操作","确定要重置用户的密码吗?",{confirmButtonText:"确定",cancelButtonText:"取消",type:"warning"}).then(()=>{C.resetPassword(v.value,_.pwd1).then(()=>{i.success("重置成功"),D.value=!1})}).catch(()=>{})},F=r(!1),d=Z({phone:"",code:""}),G=r("获取验证码"),L=r(0),le=()=>{if(L.value===0){G.value="获取验证码";return}G.value="".concat(L.value,"s"),L.value-=1,setTimeout(le,1e3)},ye=()=>{if(!de.test(d.phone)){i.warning("手机号格式不正确");return}ce.checkPhone(d.phone).then(()=>{ce.getCode(d.phone).then(()=>{L.value=120,le(),i.success("获取成功,请注意查看手机短信")})}).catch(a=>{const{code:l}=a,p="注册失败,未知错误",h={1002:"手机号已被注册",1006:"手机号格式不正确"};i.error(h[l]||p)})},xe=()=>de.test(d.phone)?Ne.test(d.code)?!0:(i.warning("验证码格式不正确"),!1):(i.warning("手机号格式不正确"),!1),$e=a=>{v.value=a,F.value=!0},Ee=async()=>{xe()&&C.resetPhone(v.value,d.phone,d.code).then(()=>{i.success("绑定成功"),F.value=!1,d.code="",d.phone="",z()}).catch(a=>{const{code:l}=a,p="绑定失败,未知错误",h={1002:"手机号已被注册",1003:"验证码不正确"};i.error(h[l]||p)})},J=(a,l)=>{const p={month:"一个月前",quarter:"三个月前",half:"半年前"};v.value=a,pe.confirm("移除后这些文件将无法恢复,请谨慎操作","删除前确认?",{confirmButtonText:"确认删除 ".concat(p[l],"文件")}).then(()=>{C.clearOssFile(a,l).then(()=>{i.success("清理成功")})}).catch(()=>{})},te=r(1),R=r(!1),I=r(""),oe=(a,l=1)=>{v.value=a,te.value=l,R.value=!0},Ue=()=>{C.sendMessage(I.value,te.value,v.value).then(()=>{i.success("推送成功"),I.value="",R.value=!1})},ze=a=>{C.logout(a).then(()=>{i.success("下线成功 ".concat(a)),z()})};Be(()=>{z()});const O=q(()=>Y.getters["public/isMobile"]);return(a,l)=>{const p=Je,h=Ge,g=De,u=Fe,c=Qe,K=Ke,Se=qe,j=Ze,Me=He,H=Oe,ae=je;return m(),A("div",ul,[n("div",rl,[n("div",il,[n("span",dl,[cl,t(h,{modelValue:S.value,"onUpdate:modelValue":l[0]||(l[0]=e=>S.value=e),size:"default",placeholder:"请选择日志类型"},{default:o(()=>[(m(!0),A(re,null,ie(ee,(e,w)=>(m(),k(p,{key:w,label:e.label,value:e.type},null,8,["label","value"]))),128))]),_:1},8,["modelValue"])]),n("span",pl,[t(g,{size:"default",clearable:"",placeholder:"请输入要检索的内容","prefix-icon":f(We),modelValue:M.value,"onUpdate:modelValue":l[1]||(l[1]=e=>M.value=e)},null,8,["prefix-icon","modelValue"])]),n("span",ml,[t(u,{size:"default",icon:f(Xe),onClick:z},{default:o(()=>[s("刷新")]),_:1},8,["icon"])]),n("span",_l,[t(u,{size:"warning",icon:f(nl),onClick:l[2]||(l[2]=e=>oe(null,0))},{default:o(()=>[s("推送全局消息")]),_:1},8,["icon"])])]),t(K,{height:"550",stripe:"",border:"","default-sort":{prop:"date",order:"descending"},data:ve.value,style:{width:"100%"}},{default:o(()=>[t(c,{prop:"id",label:"ID",width:"60"}),t(c,{prop:"account",label:"账号",width:"120"}),t(c,{prop:"onlineCount",label:"token",width:"80"}),t(c,{prop:"phone",label:"手机号",width:"100"}),t(c,{sortable:"",prop:"login_time",label:"最后登录时间",width:"190"},{default:o(e=>[s(b(e.row.login_time&&f(x)(new Date(e.row.login_time))),1)]),_:1}),t(c,{prop:"join_time",label:"注册时间",width:"190"},{default:o(e=>[s(b(f(x)(new Date(e.row.join_time))),1)]),_:1}),t(c,{sortable:"",prop:"login_count",label:"登录次数"}),S.value===1?(m(),k(c,{key:0,prop:"open_time",label:"解封时间"},{default:o(e=>[s(b(e.row.open_time&&f(x)(new Date(e.row.open_time))),1)]),_:1})):$("",!0),t(c,{sortable:"",prop:"fileCount",label:"收集文件数"}),t(c,{label:"占用云空间",width:"200"},{default:o(({row:{resources:e,monthAgoSize:w,quarterAgoSize:ne,halfYearSize:se,id:Q}})=>[n("ul",fl,[n("li",null,"总大小:"+b(e),1),n("li",null,[s(" 一月前:"+b(w),1),e!=="0B"?(m(),k(u,{key:0,class:"clear-btn",onClick:ue=>J(Q,"month"),icon:f(X),circle:"",size:"small"},null,8,["onClick","icon"])):$("",!0)]),n("li",null,[s(" 三月前:"+b(ne),1),ne!=="0B"?(m(),k(u,{key:0,class:"clear-btn",onClick:ue=>J(Q,"quarter"),icon:f(X),circle:"",size:"small"},null,8,["onClick","icon"])):$("",!0)]),n("li",null,[s(" 半年前:"+b(se),1),se!=="0B"?(m(),k(u,{key:0,class:"clear-btn",onClick:ue=>J(Q,"half"),icon:f(X),circle:"",size:"small"},null,8,["onClick","icon"])):$("",!0)])])]),_:1}),t(c,{fixed:"right",label:"操作",width:"100"},{default:o(e=>[n("div",vl,[t(u,{onClick:w=>we(e.row.id,e.row.status,e.row.open_time),type:"primary",text:"",size:"small"},{default:o(()=>[s("修改状态")]),_:2},1032,["onClick"]),t(u,{onClick:w=>Ce(e.row.id),type:"primary",text:"",size:"small"},{default:o(()=>[s("重置密码")]),_:2},1032,["onClick"]),t(u,{onClick:w=>$e(e.row.id),type:"primary",text:"",size:"small"},{default:o(()=>[s("绑定手机号")]),_:2},1032,["onClick"]),t(u,{onClick:w=>oe(e.row.id),type:"warning",text:"",size:"small"},{default:o(()=>[s("发送消息")]),_:2},1032,["onClick"]),e.row.onlineCount!==0?(m(),k(u,{key:0,onClick:w=>ze(e.row.account),type:"danger",text:"",size:"small"},{default:o(()=>[s("一键下线")]),_:2},1032,["onClick"])):$("",!0)])]),_:1})]),_:1},8,["data"]),n("div",hl,[t(Se,{"current-page":N.value,onCurrentChange:he,background:"","page-count":fe.value,"page-sizes":[10,50,100,200],"page-size":P.value,onSizeChange:_e,total:W.value.length,layout:"total, sizes, prev, pager, next, jumper"},null,8,["current-page","page-count","page-size","total"])])]),t(j,{fullscreen:O.value,center:"",title:"消息推送",modelValue:R.value,"onUpdate:modelValue":l[5]||(l[5]=e=>R.value=e)},{footer:o(()=>[n("span",wl,[t(u,{onClick:l[4]||(l[4]=e=>R.value=!1)},{default:o(()=>[s("取 消")]),_:1}),t(u,{type:"primary",onClick:Ue},{default:o(()=>[s("确 定")]),_:1})])]),default:o(()=>[n("div",gl,[t(g,{modelValue:I.value,"onUpdate:modelValue":l[3]||(l[3]=e=>I.value=e),autosize:{minRows:6,maxRows:20},type:"textarea",placeholder:"输入要推送的消息,支持HTML内容(推荐使用mdnice 转 markdown 转html)"},null,8,["modelValue"])])]),_:1},8,["fullscreen","modelValue"]),t(j,{fullscreen:O.value,center:"",title:"状态修改",modelValue:T.value,"onUpdate:modelValue":l[9]||(l[9]=e=>T.value=e)},{footer:o(()=>[n("span",kl,[t(u,{onClick:l[8]||(l[8]=e=>T.value=!1)},{default:o(()=>[s("取 消")]),_:1}),t(u,{type:"primary",onClick:be},{default:o(()=>[s("确 定")]),_:1})])]),default:o(()=>[n("div",bl,[t(h,{modelValue:y.value,"onUpdate:modelValue":l[6]||(l[6]=e=>y.value=e),placeholder:"请选择新分类"},{default:o(()=>[(m(!0),A(re,null,ie(f(ge),e=>(m(),k(p,{key:e.type,label:e.label,value:e.type},null,8,["label","value"]))),128))]),_:1},8,["modelValue"])]),y.value===1?(m(),A("div",Cl,[t(Me,{editable:!1,modelValue:B.value,"onUpdate:modelValue":l[7]||(l[7]=e=>B.value=e),type:"datetime",placeholder:"点击设置解封日期"},null,8,["modelValue"])])):$("",!0)]),_:1},8,["fullscreen","modelValue"]),t(j,{fullscreen:O.value,center:"",title:"密码重置",modelValue:D.value,"onUpdate:modelValue":l[13]||(l[13]=e=>D.value=e)},{footer:o(()=>[n("span",yl,[t(u,{onClick:l[12]||(l[12]=e=>D.value=!1)},{default:o(()=>[s("取 消")]),_:1}),t(u,{type:"primary",onClick:Ve},{default:o(()=>[s("确 定")]),_:1})])]),default:o(()=>[n("div",Vl,[t(ae,{model:_,"label-width":"80px"},{default:o(()=>[t(H,{label:"新密码"},{default:o(()=>[t(g,{"show-word-limit":"",clearable:"",modelValue:_.pwd1,"onUpdate:modelValue":l[10]||(l[10]=e=>_.pwd1=e),placeholder:"请输入新密码",maxlength:"16",minlength:"6"},null,8,["modelValue"])]),_:1}),t(H,null,{default:o(()=>[t(g,{"show-word-limit":"",clearable:"",modelValue:_.pwd2,"onUpdate:modelValue":l[11]||(l[11]=e=>_.pwd2=e),placeholder:"请再次输入",maxlength:"16",minlength:"6"},null,8,["modelValue"])]),_:1})]),_:1},8,["model"])])]),_:1},8,["fullscreen","modelValue"]),t(j,{fullscreen:O.value,center:"",title:"绑定手机号",modelValue:F.value,"onUpdate:modelValue":l[17]||(l[17]=e=>F.value=e)},{footer:o(()=>[n("span",$l,[t(u,{onClick:l[16]||(l[16]=e=>F.value=!1)},{default:o(()=>[s("取 消")]),_:1}),t(u,{type:"primary",onClick:Ee},{default:o(()=>[s("确 定")]),_:1})])]),default:o(()=>[n("div",xl,[t(ae,{model:d,"label-width":"60px"},{default:o(()=>[t(H,{label:"手机号"},{default:o(()=>[t(g,{"show-word-limit":"",clearable:"",modelValue:d.phone,"onUpdate:modelValue":l[14]||(l[14]=e=>d.phone=e),placeholder:"请输入手机号",maxlength:"11"},{append:o(()=>[t(u,{disabled:L.value!==0,onClick:ye},{default:o(()=>[s(b(G.value),1)]),_:1},8,["disabled"])]),_:1},8,["modelValue"])]),_:1}),t(H,null,{default:o(()=>[t(g,{"show-word-limit":"",clearable:"",modelValue:d.code,"onUpdate:modelValue":l[15]||(l[15]=e=>d.code=e),placeholder:"请输入验证码",maxlength:"4"},null,8,["modelValue"])]),_:1})]),_:1},8,["model"])])]),_:1},8,["fullscreen","modelValue"])])}}});const Ol=Ie(El,[["__scopeId","data-v-0b1b911a"]]);export{Ol as default};
|
|
2
|
+
//# sourceMappingURL=index-98964915.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-98964915.js","sources":["../../node_modules/.pnpm/@element-plus+icons-vue@1.1.4_vue@3.3.4/node_modules/@element-plus/icons-vue/dist/es/message.mjs","../../src/pages/dashboard/manage/user/index.vue"],"sourcesContent":["import { defineComponent, openBlock, createElementBlock, createElementVNode } from 'vue';\nimport _export_sfc from './_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = defineComponent({\n name: \"Message\"\n});\nconst _hoisted_1 = {\n viewBox: \"0 0 1024 1024\",\n xmlns: \"http://www.w3.org/2000/svg\"\n};\nconst _hoisted_2 = /* @__PURE__ */ createElementVNode(\"path\", {\n fill: \"currentColor\",\n d: \"M128 224v512a64 64 0 0 0 64 64h640a64 64 0 0 0 64-64V224H128zm0-64h768a64 64 0 0 1 64 64v512a128 128 0 0 1-128 128H192A128 128 0 0 1 64 736V224a64 64 0 0 1 64-64z\"\n}, null, -1);\nconst _hoisted_3 = /* @__PURE__ */ createElementVNode(\"path\", {\n fill: \"currentColor\",\n d: \"M904 224 656.512 506.88a192 192 0 0 1-289.024 0L120 224h784zm-698.944 0 210.56 240.704a128 128 0 0 0 192.704 0L818.944 224H205.056z\"\n}, null, -1);\nconst _hoisted_4 = [\n _hoisted_2,\n _hoisted_3\n];\nfunction _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {\n return openBlock(), createElementBlock(\"svg\", _hoisted_1, _hoisted_4);\n}\nvar message = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render]]);\n\nexport { message as default };\n","<template>\n <div class=\"user\">\n <div class=\"panel\">\n <div class=\"p10 log-filter\">\n <span class=\"item\">\n <span class=\"label\">状态</span>\n <el-select\n v-model=\"filterLogType\"\n size=\"default\"\n placeholder=\"请选择日志类型\"\n >\n <el-option\n v-for=\"(item, idx) in logTypeList\"\n :key=\"idx\"\n :label=\"item.label\"\n :value=\"item.type\"\n ></el-option>\n </el-select>\n </span>\n <span class=\"item\">\n <el-input\n size=\"default\"\n clearable\n placeholder=\"请输入要检索的内容\"\n :prefix-icon=\"Search\"\n v-model=\"searchWord\"\n >\n </el-input>\n </span>\n <span class=\"item\">\n <el-button size=\"default\" :icon=\"Refresh\" @click=\"refreshUsers\"\n >刷新</el-button\n >\n </span>\n <span class=\"item\">\n <el-button\n size=\"warning\"\n :icon=\"Message\"\n @click=\"sendMessage(null, 0)\"\n >推送全局消息</el-button\n >\n </span>\n </div>\n <el-table\n height=\"550\"\n stripe\n border\n :default-sort=\"{ prop: 'date', order: 'descending' }\"\n :data=\"pageUsers\"\n style=\"width: 100%\"\n >\n <el-table-column prop=\"id\" label=\"ID\" width=\"60\"></el-table-column>\n <el-table-column\n prop=\"account\"\n label=\"账号\"\n width=\"120\"\n ></el-table-column>\n <el-table-column prop=\"onlineCount\" label=\"token\" width=\"80\">\n </el-table-column>\n <el-table-column\n prop=\"phone\"\n label=\"手机号\"\n width=\"100\"\n ></el-table-column>\n <el-table-column\n sortable\n prop=\"login_time\"\n label=\"最后登录时间\"\n width=\"190\"\n >\n <template #default=\"scope\">{{\n scope.row.login_time && formatDate(new Date(scope.row.login_time))\n }}</template>\n </el-table-column>\n <el-table-column prop=\"join_time\" label=\"注册时间\" width=\"190\">\n <template #default=\"scope\">{{\n formatDate(new Date(scope.row.join_time))\n }}</template>\n </el-table-column>\n <el-table-column\n sortable\n prop=\"login_count\"\n label=\"登录次数\"\n ></el-table-column>\n <el-table-column\n prop=\"open_time\"\n label=\"解封时间\"\n v-if=\"filterLogType === 1\"\n >\n <template #default=\"scope\">{{\n scope.row.open_time && formatDate(new Date(scope.row.open_time))\n }}</template>\n </el-table-column>\n <el-table-column\n sortable\n prop=\"fileCount\"\n label=\"收集文件数\"\n ></el-table-column>\n <el-table-column label=\"占用云空间\" width=\"200\">\n <template\n #default=\"{\n row: { resources, monthAgoSize, quarterAgoSize, halfYearSize, id }\n }\"\n >\n <ul class=\"user-oss-info\">\n <li>总大小:{{ resources }}</li>\n <li>\n 一月前:{{ monthAgoSize\n }}<el-button\n v-if=\"resources !== '0B'\"\n class=\"clear-btn\"\n @click=\"handleClearFiles(id, 'month')\"\n :icon=\"DeleteFilled\"\n circle\n size=\"small\"\n ></el-button>\n </li>\n <li>\n 三月前:{{ quarterAgoSize\n }}<el-button\n v-if=\"quarterAgoSize !== '0B'\"\n class=\"clear-btn\"\n @click=\"handleClearFiles(id, 'quarter')\"\n :icon=\"DeleteFilled\"\n circle\n size=\"small\"\n ></el-button>\n </li>\n <li>\n 半年前:{{ halfYearSize\n }}<el-button\n v-if=\"halfYearSize !== '0B'\"\n class=\"clear-btn\"\n @click=\"handleClearFiles(id, 'half')\"\n :icon=\"DeleteFilled\"\n circle\n size=\"small\"\n ></el-button>\n </li>\n </ul>\n </template>\n </el-table-column>\n <el-table-column fixed=\"right\" label=\"操作\" width=\"100\">\n <template #default=\"scope\">\n <div class=\"text-btn-list\">\n <el-button\n @click=\"\n handleChangeStatus(\n scope.row.id,\n scope.row.status,\n scope.row.open_time\n )\n \"\n type=\"primary\"\n text\n size=\"small\"\n >修改状态</el-button\n >\n <el-button\n @click=\"handleResetPassword(scope.row.id)\"\n type=\"primary\"\n text\n size=\"small\"\n >重置密码</el-button\n >\n <el-button\n @click=\"handleBindPhone(scope.row.id)\"\n type=\"primary\"\n text\n size=\"small\"\n >绑定手机号</el-button\n >\n <el-button\n @click=\"sendMessage(scope.row.id)\"\n type=\"warning\"\n text\n size=\"small\"\n >发送消息</el-button\n >\n <el-button\n v-if=\"scope.row.onlineCount !== 0\"\n @click=\"logout(scope.row.account)\"\n type=\"danger\"\n text\n size=\"small\"\n >一键下线</el-button\n >\n </div>\n </template>\n </el-table-column>\n </el-table>\n <div class=\"flex fc p10\">\n <el-pagination\n :current-page=\"pageCurrent\"\n @current-change=\"handlePageChange\"\n background\n :page-count=\"pageCount\"\n :page-sizes=\"[10, 50, 100, 200]\"\n :page-size=\"pageSize\"\n @size-change=\"handleSizeChange\"\n :total=\"filterUsers.length\"\n layout=\"total, sizes, prev, pager, next, jumper\"\n ></el-pagination>\n </div>\n </div>\n <!-- 消息推送弹窗 -->\n <el-dialog\n :fullscreen=\"isMobile\"\n center\n title=\"消息推送\"\n v-model=\"showMessageDialog\"\n >\n <div class=\"tc\">\n <el-input\n v-model=\"pushMessageText\"\n :autosize=\"{ minRows: 6, maxRows: 20 }\"\n type=\"textarea\"\n placeholder=\"输入要推送的消息,支持HTML内容(推荐使用mdnice 转 markdown 转html)\"\n />\n </div>\n <template #footer>\n <span class=\"dialog-footer\">\n <el-button @click=\"showMessageDialog = false\">取 消</el-button>\n <el-button type=\"primary\" @click=\"sureSendMessage\">确 定</el-button>\n </span>\n </template>\n </el-dialog>\n <!-- 用户状态修改弹窗 -->\n <el-dialog\n :fullscreen=\"isMobile\"\n center\n title=\"状态修改\"\n v-model=\"showUserStatusDialog\"\n >\n <div class=\"tc\">\n <el-select v-model=\"selectStatus\" placeholder=\"请选择新分类\">\n <el-option\n v-for=\"s in userStatusList\"\n :key=\"s.type\"\n :label=\"s.label\"\n :value=\"s.type\"\n ></el-option>\n </el-select>\n </div>\n <div style=\"margin-top: 10px\" class=\"tc\" v-if=\"selectStatus === 1\">\n <el-date-picker\n :editable=\"false\"\n v-model=\"openTime\"\n type=\"datetime\"\n placeholder=\"点击设置解封日期\"\n ></el-date-picker>\n </div>\n <template #footer>\n <span class=\"dialog-footer\">\n <el-button @click=\"showUserStatusDialog = false\">取 消</el-button>\n <el-button type=\"primary\" @click=\"handleSaveStatus\">确 定</el-button>\n </span>\n </template>\n </el-dialog>\n\n <!-- 重置密码 -->\n <el-dialog\n :fullscreen=\"isMobile\"\n center\n title=\"密码重置\"\n v-model=\"showResetPasswordDialog\"\n >\n <div class=\"tc\">\n <el-form :model=\"pwdForm\" label-width=\"80px\">\n <el-form-item label=\"新密码\">\n <el-input\n show-word-limit\n clearable\n v-model=\"pwdForm.pwd1\"\n placeholder=\"请输入新密码\"\n maxlength=\"16\"\n minlength=\"6\"\n />\n </el-form-item>\n <el-form-item>\n <el-input\n show-word-limit\n clearable\n v-model=\"pwdForm.pwd2\"\n placeholder=\"请再次输入\"\n maxlength=\"16\"\n minlength=\"6\"\n />\n </el-form-item>\n </el-form>\n </div>\n <template #footer>\n <span class=\"dialog-footer\">\n <el-button @click=\"showResetPasswordDialog = false\">取 消</el-button>\n <el-button type=\"primary\" @click=\"handleSavePassword\"\n >确 定</el-button\n >\n </span>\n </template>\n </el-dialog>\n <!-- 重绑定手机号 -->\n <el-dialog\n :fullscreen=\"isMobile\"\n center\n title=\"绑定手机号\"\n v-model=\"showPhoneDialog\"\n >\n <div class=\"tc\">\n <el-form :model=\"phoneForm\" label-width=\"60px\">\n <el-form-item label=\"手机号\">\n <el-input\n show-word-limit\n clearable\n v-model=\"phoneForm.phone\"\n placeholder=\"请输入手机号\"\n maxlength=\"11\"\n >\n <template #append>\n <!-- 获取验证码 -->\n <el-button :disabled=\"time !== 0\" @click=\"getCode\">{{\n codeText\n }}</el-button>\n </template>\n </el-input>\n </el-form-item>\n <el-form-item>\n <el-input\n show-word-limit\n clearable\n v-model=\"phoneForm.code\"\n placeholder=\"请输入验证码\"\n maxlength=\"4\"\n />\n </el-form-item>\n </el-form>\n </div>\n <template #footer>\n <span class=\"dialog-footer\">\n <el-button @click=\"showPhoneDialog = false\">取 消</el-button>\n <el-button type=\"primary\" @click=\"handleSavePhone\">确 定</el-button>\n </span>\n </template>\n </el-dialog>\n </div>\n</template>\n<script lang=\"ts\" setup>\nimport { ElMessage, ElMessageBox } from 'element-plus'\nimport { computed, onMounted, reactive, ref } from 'vue'\nimport { useStore } from 'vuex'\nimport { Search, DeleteFilled, Refresh, Message } from '@element-plus/icons-vue'\nimport { PublicApi, SuperUserApi } from '@/apis'\nimport { USER_STATUS } from '@/constants'\nimport { formatDate } from '@/utils/stringUtil'\nimport { rMobilePhone, rPassword, rVerCode } from '@/utils/regExp'\n\nconst $store = useStore()\n// 用户\nconst users: any[] = reactive([])\nconst refreshUsers = () => {\n SuperUserApi.getUserList().then((res) => {\n users.splice(0, users.length)\n const d = res.data.list\n users.push(...d)\n })\n}\n\n// 筛选用户状态\nconst filterLogType = ref(USER_STATUS.NORMAL)\nconst searchWord = ref('')\nconst logTypeList = reactive([\n {\n label: '正常',\n type: USER_STATUS.NORMAL\n },\n {\n label: '冻结',\n type: USER_STATUS.FREEZE\n },\n {\n label: '封禁',\n type: USER_STATUS.BAN\n }\n])\n\nconst filterUsers = computed(() =>\n users\n .filter((v) => v.status === filterLogType.value)\n .filter((v) => {\n const {\n id,\n account,\n phone,\n join_time,\n login_count,\n login_time,\n open_time\n } = v\n if (searchWord.value.length === 0) return true\n return `${id} ${account} ${phone} ${login_count} ${formatDate(\n open_time\n )} ${formatDate(login_time)} ${formatDate(join_time)}`.includes(\n searchWord.value\n )\n })\n)\n\n// 分页\nconst pageSize = ref(10)\nconst handleSizeChange = (v: number) => {\n pageSize.value = v\n}\nconst pageCount = computed(() => {\n const t = Math.ceil(filterUsers.value.length / pageSize.value)\n return t\n})\nconst pageCurrent = ref(1)\nconst pageUsers = computed(() => {\n const start = (pageCurrent.value - 1) * pageSize.value\n const end = pageCurrent.value * pageSize.value\n return filterUsers.value.slice(start, end)\n})\nconst handlePageChange = (idx: number) => {\n pageCurrent.value = idx\n}\n\n// 状态修改\nconst showUserStatusDialog = ref(false)\nconst selectUserId = ref(0)\nconst selectStatus = ref(USER_STATUS.NORMAL)\nconst userStatusList = logTypeList\nconst openTime = ref('')\nconst handleChangeStatus = (\n userId: number,\n status: USER_STATUS,\n oTime: string\n) => {\n selectUserId.value = userId\n selectStatus.value = status\n openTime.value = oTime\n showUserStatusDialog.value = true\n}\nconst handleSaveStatus = () => {\n const user = users.find((u) => u.id === selectUserId.value)\n if (selectStatus.value === USER_STATUS.FREEZE) {\n if (!openTime.value) {\n ElMessage.warning('请设置解冻时间')\n return\n }\n user.open_time = openTime.value\n } else {\n user.open_time = ''\n }\n user.status = selectStatus.value\n showUserStatusDialog.value = false\n SuperUserApi.updateUserStatus(user.id, user.status, user.open_time).then(\n () => {\n ElMessage.success('修改成功')\n }\n )\n}\n\n// 重置密码\nconst showResetPasswordDialog = ref(false)\nconst pwdForm = reactive({\n pwd1: '',\n pwd2: ''\n})\nconst handleResetPassword = (userId: number) => {\n selectUserId.value = userId\n showResetPasswordDialog.value = true\n pwdForm.pwd1 = ''\n pwdForm.pwd2 = ''\n}\n\nconst checkPwdForm = () => {\n if (!rPassword.test(pwdForm.pwd1)) {\n ElMessage.warning('密码格式不正确(6-16位 支持字母/数字/下划线)')\n return false\n }\n if (pwdForm.pwd1 !== pwdForm.pwd2) {\n ElMessage.warning('两次输入的密码不一致')\n return false\n }\n\n return true\n}\n\nconst handleSavePassword = () => {\n if (!checkPwdForm()) return\n ElMessageBox.confirm('此操作不可逆,请谨慎操作', '确定要重置用户的密码吗?', {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: 'warning'\n })\n .then(() => {\n SuperUserApi.resetPassword(selectUserId.value, pwdForm.pwd1).then(() => {\n ElMessage.success('重置成功')\n showResetPasswordDialog.value = false\n })\n })\n .catch(() => {\n //\n })\n}\n\n// 绑定手机号\nconst showPhoneDialog = ref(false)\nconst phoneForm = reactive({\n phone: '',\n code: ''\n})\nconst codeText = ref('获取验证码')\nconst time = ref(0)\nconst refreshCodeText = () => {\n if (time.value === 0) {\n codeText.value = '获取验证码'\n return\n }\n codeText.value = `${time.value}s`\n time.value -= 1\n setTimeout(refreshCodeText, 1000)\n}\nconst getCode = () => {\n if (!rMobilePhone.test(phoneForm.phone)) {\n ElMessage.warning('手机号格式不正确')\n return\n }\n // check是否可用\n PublicApi.checkPhone(phoneForm.phone)\n .then(() => {\n PublicApi.getCode(phoneForm.phone).then(() => {\n time.value = 120\n refreshCodeText()\n ElMessage.success('获取成功,请注意查看手机短信')\n })\n })\n .catch((err) => {\n const { code: c } = err\n const msg = '注册失败,未知错误'\n const options: any = {\n 1002: '手机号已被注册',\n 1006: '手机号格式不正确'\n }\n ElMessage.error(options[c] || msg)\n })\n}\nconst checkPhoneForm = () => {\n if (!rMobilePhone.test(phoneForm.phone)) {\n ElMessage.warning('手机号格式不正确')\n return false\n }\n if (!rVerCode.test(phoneForm.code)) {\n ElMessage.warning('验证码格式不正确')\n return false\n }\n\n return true\n}\nconst handleBindPhone = (id: number) => {\n selectUserId.value = id\n showPhoneDialog.value = true\n}\nconst handleSavePhone = async () => {\n if (!checkPhoneForm()) {\n return\n }\n // 调用API更新,验证码 不正确判断\n SuperUserApi.resetPhone(selectUserId.value, phoneForm.phone, phoneForm.code)\n .then(() => {\n ElMessage.success('绑定成功')\n showPhoneDialog.value = false\n phoneForm.code = ''\n phoneForm.phone = ''\n refreshUsers()\n })\n .catch((err) => {\n const { code: c } = err\n const msg = '绑定失败,未知错误'\n const options: any = {\n 1002: '手机号已被注册',\n 1003: '验证码不正确'\n }\n ElMessage.error(options[c] || msg)\n })\n}\n\nconst handleClearFiles = (\n userId: number,\n type: 'month' | 'quarter' | 'half'\n) => {\n const tipWords = {\n month: '一个月前',\n quarter: '三个月前',\n half: '半年前'\n }\n selectUserId.value = userId\n ElMessageBox.confirm('移除后这些文件将无法恢复,请谨慎操作', '删除前确认?', {\n confirmButtonText: `确认删除 ${tipWords[type]}文件`\n })\n .then(() => {\n SuperUserApi.clearOssFile(userId, type).then(() => {\n ElMessage.success('清理成功')\n })\n })\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n .catch(() => {})\n}\n\n// TODO: 0 global 1 user_push\nconst pushMessageType = ref(1)\nconst showMessageDialog = ref(false)\nconst pushMessageText = ref('')\nconst sendMessage = (id: number, type = 1) => {\n selectUserId.value = id\n pushMessageType.value = type\n showMessageDialog.value = true\n}\n\nconst sureSendMessage = () => {\n SuperUserApi.sendMessage(\n pushMessageText.value,\n pushMessageType.value,\n selectUserId.value\n ).then(() => {\n ElMessage.success('推送成功')\n // 推送成功\n pushMessageText.value = ''\n showMessageDialog.value = false\n })\n}\nconst logout = (account: string) => {\n SuperUserApi.logout(account).then(() => {\n ElMessage.success(`下线成功 ${account}`)\n refreshUsers()\n })\n}\n\nonMounted(() => {\n refreshUsers()\n})\nconst isMobile = computed(() => $store.getters['public/isMobile'])\n</script>\n\n<style scoped lang=\"scss\">\n@media screen and (max-width: 700px) {\n .user {\n margin-top: 40px !important;\n }\n\n .log-filter {\n justify-content: center;\n }\n}\n\n.user {\n margin: 0 auto;\n}\n\n.panel {\n max-width: 1256px;\n padding: 1em;\n background-color: #fff;\n margin: 10px auto;\n box-sizing: border-box;\n box-shadow: 0 2px 12px 0 rgb(0 0 0 / 10%);\n border-radius: 4px;\n}\n\n.log-filter {\n display: flex;\n flex-wrap: wrap;\n\n .item {\n margin-right: 10px;\n margin-bottom: 10px;\n\n .label {\n margin-right: 10px;\n font-size: 12px;\n }\n }\n}\n\n.text-btn-list {\n display: flex;\n flex-wrap: wrap;\n\n button {\n margin-left: 0;\n }\n}\n\n.user-oss-info {\n list-style: none;\n li {\n margin-bottom: 10px;\n }\n .clear-btn {\n margin-left: 10px;\n }\n}\n</style>\n"],"names":["_sfc_main","defineComponent","_hoisted_1","_hoisted_2","createElementVNode","_hoisted_3","_hoisted_4","_sfc_render","_ctx","_cache","$props","$setup","$data","$options","openBlock","createElementBlock","message","_export_sfc","$store","useStore","users","reactive","refreshUsers","SuperUserApi","res","d","filterLogType","ref","USER_STATUS","searchWord","logTypeList","filterUsers","computed","v","id","account","phone","join_time","login_count","login_time","open_time","formatDate","pageSize","handleSizeChange","pageCount","pageCurrent","pageUsers","start","end","handlePageChange","idx","showUserStatusDialog","selectUserId","selectStatus","userStatusList","openTime","handleChangeStatus","userId","status","oTime","handleSaveStatus","user","u","ElMessage","showResetPasswordDialog","pwdForm","handleResetPassword","checkPwdForm","rPassword","handleSavePassword","ElMessageBox","showPhoneDialog","phoneForm","codeText","time","refreshCodeText","getCode","rMobilePhone","PublicApi","err","c","msg","options","checkPhoneForm","rVerCode","handleBindPhone","handleSavePhone","handleClearFiles","type","tipWords","pushMessageType","showMessageDialog","pushMessageText","sendMessage","sureSendMessage","logout","onMounted","isMobile"],"mappings":"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","x_google_ignoreList":[0]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
@media screen and (max-width: 700px){.user[data-v-8f592632]{margin-top:40px!important}.log-filter[data-v-8f592632]{justify-content:center}}.user[data-v-8f592632]{margin:0 auto}.panel[data-v-8f592632]{max-width:1256px;padding:1em;background-color:#fff;margin:10px auto;box-sizing:border-box;box-shadow:0 2px 12px rgba(0,0,0,.1);border-radius:4px}.log-filter[data-v-8f592632]{display:flex;flex-wrap:wrap}.log-filter .item[data-v-8f592632]{margin-right:10px;margin-bottom:10px}.log-filter .item .label[data-v-8f592632]{margin-right:10px;font-size:12px}.text-btn-list[data-v-8f592632]{display:flex;flex-wrap:wrap}.text-btn-list button[data-v-8f592632]{margin-left:0}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var r=(E=>(E[E.NORMAL=0]="NORMAL",E[E.FREEZE=1]="FREEZE",E[E.BAN=2]="BAN",E))(r||{}),I=(E=>(E[E.REVIEW=0]="REVIEW",E[E.WAIT=1]="WAIT",E[E.START=2]="START",E[E.END=3]="END",E[E.CLOSE=4]="CLOSE",E))(I||{}),R=(E=>(E[E.PRAISE=0]="PRAISE",E[E.Download=1]="Download",E[E.Compress=2]="Compress",E[E.DisabledRoute=3]="DisabledRoute",E))(R||{}),C=(E=>(E[E.ARCHIVE=0]="ARCHIVE",E[E.EXPIRED=1]="EXPIRED",E[E.SUCCESS=2]="SUCCESS",E[E.FAIL=3]="FAIL",E))(C||{});const e=/[\\/:*?"<>|]/g;export{R as A,C as D,r as U,I as W,e as f};
|
|
2
|
+
//# sourceMappingURL=index-9e6bd406.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-9e6bd406.js","sources":["../../src/constants/index.ts"],"sourcesContent":["/**\n * 用户状态\n */\nexport enum USER_STATUS {\n /**\n * 正常\n */\n NORMAL,\n /**\n * 冻结\n */\n FREEZE,\n /**\n * 封禁\n */\n BAN\n}\n\nexport enum WishStatus {\n /**\n * 审核中\n */\n REVIEW,\n /**\n * 待开始\n */\n WAIT,\n /**\n * 开发中\n */\n START,\n /**\n * 已上线\n */\n END,\n /**\n * 关闭\n */\n CLOSE\n}\n\nexport enum ActionType {\n /**\n * 点赞\n */\n PRAISE,\n\n /**\n * 文件下载\n */\n Download,\n\n /**\n * 文件归档\n */\n Compress,\n\n /**\n * 路由禁用\n */\n DisabledRoute\n}\n\nexport enum DownloadStatus {\n /**\n * 归档中\n */\n ARCHIVE,\n /**\n * 链接已失效\n */\n EXPIRED,\n /**\n * 可下载\n */\n SUCCESS,\n /**\n * 归档失败\n */\n FAIL\n}\n\nexport const filenamePattern = /[\\\\/:*?\"<>|]/g\n"],"names":["USER_STATUS","USER_STATUS2","WishStatus","WishStatus2","ActionType","ActionType2","DownloadStatus","DownloadStatus2","filenamePattern"],"mappings":"AAGY,IAAAA,GAAAA,IAIVA,EAAAC,EAAA,OAAA,CAAA,EAAA,SAIAD,EAAAC,EAAA,OAAA,CAAA,EAAA,SAIAD,EAAAC,EAAA,IAAA,CAAA,EAAA,MAZUD,IAAAA,GAAA,CAAA,CAAA,EAeAE,GAAAA,IAIVA,EAAAC,EAAA,OAAA,CAAA,EAAA,SAIAD,EAAAC,EAAA,KAAA,CAAA,EAAA,OAIAD,EAAAC,EAAA,MAAA,CAAA,EAAA,QAIAD,EAAAC,EAAA,IAAA,CAAA,EAAA,MAIAD,EAAAC,EAAA,MAAA,CAAA,EAAA,QApBUD,IAAAA,GAAA,CAAA,CAAA,EAuBAE,GAAAA,IAIVA,EAAAC,EAAA,OAAA,CAAA,EAAA,SAKAD,EAAAC,EAAA,SAAA,CAAA,EAAA,WAKAD,EAAAC,EAAA,SAAA,CAAA,EAAA,WAKAD,EAAAC,EAAA,cAAA,CAAA,EAAA,gBAnBUD,IAAAA,GAAA,CAAA,CAAA,EAsBAE,GAAAA,IAIVA,EAAAC,EAAA,QAAA,CAAA,EAAA,UAIAD,EAAAC,EAAA,QAAA,CAAA,EAAA,UAIAD,EAAAC,EAAA,QAAA,CAAA,EAAA,UAIAD,EAAAC,EAAA,KAAA,CAAA,EAAA,OAhBUD,IAAAA,GAAA,CAAA,CAAA,EAmBL,MAAME,EAAkB"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{d,_ as r,i as F,c as i,a as u,j as c,w as e,b as t,B as s,f,p as o,e as n}from"./index-62c7029f.js";const v=d({setup(){return{}}});const l=a=>(o("data-v-57f0136c"),a=a(),n(),a),A={class:"about"},p={class:"panel"},B=l(()=>u("img",{class:"logo",src:"https://img.cdn.sugarat.top/easypicker/EasyPicker.png"},null,-1)),D=l(()=>u("div",{class:"panel"},[u("h1",null,"简介"),u("p",null,"在线文件收取助手,帮助用户快速的完成一对多的文件收取")],-1)),h={class:"panel"},g=s('<h1 data-v-57f0136c>诞生背景</h1><p data-v-57f0136c>校园学习或者工作场景中会有以下几个场景:</p><ul data-v-57f0136c><li data-v-57f0136c><strong data-v-57f0136c>电子文件:</strong> 班委向同学收取各种实验电子报告</li><li data-v-57f0136c><strong data-v-57f0136c>图片:</strong> 收取各种截图证明/活动照片</li><li data-v-57f0136c>...</li></ul><p data-v-57f0136c>目前最广泛的收取方式为,通过邮箱,QQ,微信等通讯工具传递</p><p data-v-57f0136c>弊端显而易见,不方便整理统计。还占用电脑/手机内存</p><p data-v-57f0136c>为了解决这个问题,此项目应运而生</p><p data-v-57f0136c>当然<span data-v-57f0136c><strong data-v-57f0136c>市面上也有几款类似的办公工具</strong></span> ,功能及使用方式都差不多</p><p data-v-57f0136c>本项目<strong data-v-57f0136c>是 <a href="https://github.com/ATQQ/easypicker2-client" data-v-57f0136c>开源</a> 的</strong></p>',8),_=s('<div class="panel" data-v-57f0136c><h1 data-v-57f0136c>现有功能 <span style="color:grey;font-size:0.8rem;" data-v-57f0136c>(用户关心的)</span></h1><h2 data-v-57f0136c>收集任务</h2><ul data-v-57f0136c><li data-v-57f0136c><strong data-v-57f0136c>分类管理: </strong> 收集任务支持分类管理</li><li data-v-57f0136c><strong data-v-57f0136c>设置DDL(截止日期): </strong> 任务截止后不可再提交文件</li><li data-v-57f0136c><strong data-v-57f0136c>限制提交人员: </strong> 非指定的人员(姓名),无法提交文件</li><li data-v-57f0136c><strong data-v-57f0136c>设置模板文件: </strong> 提交者可直接在提交页面下载此文件</li><li data-v-57f0136c><strong data-v-57f0136c>自动重命名: </strong> 提交的文件按填写表单信息进行自动重名(如:姓名-工号.后缀)</li></ul><h2 data-v-57f0136c>文件相关</h2><ul data-v-57f0136c><li data-v-57f0136c><strong data-v-57f0136c>上传(提交): </strong>单个/多个</li><li data-v-57f0136c><strong data-v-57f0136c>下载: </strong>单个/多个/按收集任务</li><li data-v-57f0136c><strong data-v-57f0136c>撤回: </strong>用户可以撤回自己提交的文件</li><li data-v-57f0136c><strong data-v-57f0136c>分享: </strong>用户可以将文件下载链接分享给朋友</li><li data-v-57f0136c><strong data-v-57f0136c>模板下载: </strong> 下载任务发布者设置的模板文件</li><li data-v-57f0136c><strong data-v-57f0136c>导出: </strong> 导出提交记录</li></ul></div><div class="panel" data-v-57f0136c><h1 data-v-57f0136c>相关链接</h1><h2 data-v-57f0136c>应用链接相关</h2><ul data-v-57f0136c><li data-v-57f0136c><a href="https://docs.ep.sugarat.top" target="_blank" rel="noopener noreferrer" data-v-57f0136c>私有化部署</a></li><li data-v-57f0136c><a target="_blank" href="https://ep.sugarat.top" data-v-57f0136c>Easypicker1.0</a></li><li data-v-57f0136c><a target="_blank" href="https://ep2.sugarat.top" data-v-57f0136c>Easypicker2.0</a></li></ul><h2 data-v-57f0136c>应用源代码 <span style="color:grey;font-size:0.8rem;" data-v-57f0136c>(开发者需要的)</span></h2><ul data-v-57f0136c><li data-v-57f0136c><a target="_blank" href="https://github.com/ATQQ/EasyPicker-webpack" data-v-57f0136c>Easypicker1.0-客户端</a></li><li data-v-57f0136c><a target="_blank" href="https://github.com/ATQQ/easypicker-server" data-v-57f0136c>Easypicker1.0-服务端</a></li></ul><ul data-v-57f0136c><li data-v-57f0136c><a target="_blank" href="https://github.com/ATQQ/easypicker2-client" data-v-57f0136c>Easypicker2.0-客户端</a></li><li data-v-57f0136c><a target="_blank" href="https://github.com/ATQQ/easypicker2-server" data-v-57f0136c>Easypicker2.0-服务端</a></li></ul><ul data-v-57f0136c><li data-v-57f0136c><a target="_blank" href="https://github.com/ATQQ/vite-vue3-template" data-v-57f0136c>Easypicker2.0-客户端模板仓库</a></li><li data-v-57f0136c><a target="_blank" href="https://github.com/ATQQ/node-server" data-v-57f0136c>Easypicker2.0-服务端模板仓库</a></li></ul><h2 data-v-57f0136c>作者 <span style="color:grey;font-size:0.8rem;" data-v-57f0136c>(夹带私货)</span></h2><ul data-v-57f0136c><li data-v-57f0136c><a target="_blank" href="https://sugarat.top" data-v-57f0136c>博客</a></li><li data-v-57f0136c><a target="_blank" href="https://github.com/ATQQ" data-v-57f0136c>GitHub</a></li><li data-v-57f0136c><a target="_blank" href="https://juejin.cn/user/1028798615918983" data-v-57f0136c>掘金</a></li></ul></div>',2);function C(a,k,b,y,m,Q){const E=F("router-link");return f(),i("div",A,[u("main",null,[u("div",p,[c(E,{to:"/"},{default:e(()=>[B]),_:1})]),D,u("div",h,[g,u("p",null,[t("如有私有化的需求,可自行部署使用(也可 "),c(E,{to:"/author"},{default:e(()=>[t("联系作者")]),_:1}),t(" 提供帮助)")])]),_])])}const x=r(v,[["render",C],["__scopeId","data-v-57f0136c"]]);export{x as default};
|
|
2
|
+
//# sourceMappingURL=index-afb7d164.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-afb7d164.js","sources":["../../src/pages/about/index.vue"],"sourcesContent":["<template>\n <div class=\"about\">\n <main>\n <div class=\"panel\">\n <router-link to=\"/\">\n <img class=\"logo\" src=\"https://img.cdn.sugarat.top/easypicker/EasyPicker.png\">\n </router-link>\n </div>\n <div class=\"panel\">\n <h1>简介</h1>\n <p>在线文件收取助手,帮助用户快速的完成一对多的文件收取</p>\n </div>\n <div class=\"panel\">\n <h1>诞生背景</h1>\n <p>校园学习或者工作场景中会有以下几个场景:</p>\n <ul>\n <li><strong>电子文件:</strong> 班委向同学收取各种实验电子报告</li>\n <li><strong>图片:</strong> 收取各种截图证明/活动照片</li>\n <li>...</li>\n </ul>\n <p>目前最广泛的收取方式为,通过邮箱,QQ,微信等通讯工具传递</p>\n <p>弊端显而易见,不方便整理统计。还占用电脑/手机内存</p>\n <p>为了解决这个问题,此项目应运而生</p>\n <p>当然<span><strong>市面上也有几款类似的办公工具</strong></span> ,功能及使用方式都差不多</p>\n <p>本项目<strong>是 <a href=\"https://github.com/ATQQ/easypicker2-client\">开源</a> 的</strong> </p>\n <p>如有私有化的需求,可自行部署使用(也可 <router-link to=\"/author\">联系作者</router-link> 提供帮助)</p>\n </div>\n <div class=\"panel\">\n <h1>现有功能 <span style=\"color:grey;font-size:0.8rem;\">(用户关心的)</span></h1>\n <h2>收集任务</h2>\n <ul>\n <li><strong>分类管理: </strong> 收集任务支持分类管理</li>\n <li><strong>设置DDL(截止日期): </strong> 任务截止后不可再提交文件</li>\n <li><strong>限制提交人员: </strong> 非指定的人员(姓名),无法提交文件</li>\n <li><strong>设置模板文件: </strong> 提交者可直接在提交页面下载此文件</li>\n <li><strong>自动重命名: </strong> 提交的文件按填写表单信息进行自动重名(如:姓名-工号.后缀)</li>\n </ul>\n <h2>文件相关</h2>\n <ul>\n <li><strong>上传(提交): </strong>单个/多个</li>\n <li><strong>下载: </strong>单个/多个/按收集任务</li>\n <li><strong>撤回: </strong>用户可以撤回自己提交的文件</li>\n <li><strong>分享: </strong>用户可以将文件下载链接分享给朋友</li>\n <li><strong>模板下载: </strong> 下载任务发布者设置的模板文件</li>\n <li><strong>导出: </strong> 导出提交记录</li>\n </ul>\n </div>\n <div class=\"panel\">\n <h1>相关链接</h1>\n <h2>应用链接相关</h2>\n <ul>\n <li><a href=\"https://docs.ep.sugarat.top\" target=\"_blank\" rel=\"noopener noreferrer\">私有化部署</a></li>\n <li><a target=\"_blank\" href=\"https://ep.sugarat.top\">Easypicker1.0</a></li>\n <li><a target=\"_blank\" href=\"https://ep2.sugarat.top\">Easypicker2.0</a></li>\n </ul>\n <h2>应用源代码 <span style=\"color:grey;font-size:0.8rem;\">(开发者需要的)</span></h2>\n <ul>\n <li><a target=\"_blank\" href=\"https://github.com/ATQQ/EasyPicker-webpack\">Easypicker1.0-客户端</a></li>\n <li><a target=\"_blank\" href=\"https://github.com/ATQQ/easypicker-server\">Easypicker1.0-服务端</a></li>\n </ul>\n <ul>\n <li><a target=\"_blank\" href=\"https://github.com/ATQQ/easypicker2-client\">Easypicker2.0-客户端</a></li>\n <li><a target=\"_blank\" href=\"https://github.com/ATQQ/easypicker2-server\">Easypicker2.0-服务端</a></li>\n </ul>\n <ul>\n <li><a target=\"_blank\" href=\"https://github.com/ATQQ/vite-vue3-template\">Easypicker2.0-客户端模板仓库</a></li>\n <li><a target=\"_blank\" href=\"https://github.com/ATQQ/node-server\">Easypicker2.0-服务端模板仓库</a></li>\n </ul>\n <h2>作者 <span style=\"color:grey;font-size:0.8rem;\">(夹带私货)</span></h2>\n <ul>\n <li><a target=\"_blank\" href=\"https://sugarat.top\">博客</a></li>\n <li><a target=\"_blank\" href=\"https://github.com/ATQQ\">GitHub</a></li>\n <li><a target=\"_blank\" href=\"https://juejin.cn/user/1028798615918983\">掘金</a></li>\n </ul>\n </div>\n <!-- <div class=\"panel\">\n <h1>开发计划</h1>\n <h2>...未完待续</h2>\n </div>\n <div class=\"panel\">\n <h1>涉及技术</h1>\n <h2>...未完待续</h2>\n </div> -->\n </main>\n </div>\n</template>\n<script lang=\"ts\">\nimport { defineComponent } from 'vue'\n\nexport default defineComponent({\n setup() {\n return {\n\n }\n },\n})\n</script>\n<style lang=\"scss\" scoped>\nh1,\nh2,\nh3,\nh4 {\n font-weight: 500;\n}\n.about {\n background-image: linear-gradient(120deg, #a1c4fd 0%, #c2e9fb 100%);\n min-height: 100vh;\n}\nmain {\n max-width: 860px;\n margin: 0 auto;\n padding: 20px;\n .panel {\n position: relative;\n margin: 0 auto 10px;\n padding: 16px 20px;\n width: 100%;\n overflow: hidden;\n border-radius: 0.25rem;\n box-shadow: #eee;\n box-sizing: border-box;\n transition: all 0.3s;\n background-color: #fff;\n }\n .logo{\n width: 100%;\n max-width: 520px;\n margin: 0 auto;\n display: block;\n }\n h1 {\n font-size: 1.6rem;\n margin-bottom: 10px;\n }\n h2{\n font-size: 1.3rem;\n margin-bottom: 12px;\n }\n ul,ol{\n margin-left: 20px;\n font-size: 15px;\n margin-bottom: 1em;\n }\n p{\n font-size: 15px;\n margin-bottom: 1em;\n }\n a{\n color: #409eff;\n }\n}\n</style>\n"],"names":["_sfc_main","defineComponent","_withScopeId","n","_pushScopeId","_popScopeId","_hoisted_3","_createElementVNode","_hoisted_4","_hoisted_2","_createVNode","_component_router_link","_withCtx","_hoisted_6","_createTextVNode"],"mappings":"2GAyFA,MAAAA,EAAAC,EAAA,CAA+B,OAAA,CAE3B,MAAA,EAEA,CAEJ,CAAA,EA5FiB,MAAAC,EAAAC,IAAAC,EAAA,iBAAA,EAAAD,EAAAA,IAAAE,IAAAF,uCAEwBG,EAAAJ,EAAA,IAAAK,EAAA,MAAA,CAAwD,MAAA,8EAKjFC,EAAAN,EAAA,IAAAK,EAAA,MAAA,CAAA,MAAA,SAAA,CAA6BA,EAAA,KAAA,KAAA,IAAA,EAEfA,EAAA,IAAA,KAAA,4BAAA,+rHALZA,EAAA,OAAA,KAAA,CADYA,EAAA,MAAAE,EAAA,CADoEC,EAAAC,EAAA,CAAA,GAAA,GAAA,EAAA,CAAA,QAAAC,EAAA,IAAA,QAGtF,CAAA,CAAA,CAAA,EAIAJ,aAaiFK,EAAVN,EAAA,IAAA,KAAA,CAAAO,EAAA,sBAAA,EAAdJ,EAAAC,EAAA,CAAA,GAAA,SAAA,EAAA,CAAA,QAAAC,EAAA,IAAA,8BAEzD,CAAA,CAAA,CAAA"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{g as je,d as $e,f as o,c,a as s,h as Ae,O as v,u as He,a1 as Ge,Z as E,r as h,$ as Je,o as qe,aU as ge,E as u,bd as Ke,i as Ye,j as d,w as i,F,C as te,a6 as ae,t as k,S as y,a7 as ye,D as g,ae as se,a9 as we,bU as Ze,ab as W,a8 as Qe,ad as ke,y as Xe,x as et,bV as tt,aY as at,P as st,b as r,k as xe,a3 as lt,a_ as ot,s as nt,aW as be,v as it,I as rt,p as ut,e as dt,_ as ct}from"./index-62c7029f.js";import{v as pt}from"./el-loading-5d91bb6c.js";import{E as mt,a as vt}from"./el-progress-2fff98be.js";import{a as ft,E as _t}from"./el-form-item-f40006bf.js";import{T as S,E as ht}from"./tip-00ddf749.js";import{I as gt,L as yt}from"./index-34bd5929.js";import{E as wt}from"./index-17fa8fb7.js";import"./index-6d7ac779.js";import"./isEqual-9c466456.js";import"./el-dialog-463960e0.js";import"./el-select-7d894fd0.js";import"./validator-853854a1.js";import"./aria-bc8e8b0f.js";const kt=$e({name:"UploadFilled"}),xt={viewBox:"0 0 1024 1024",xmlns:"http://www.w3.org/2000/svg"},bt=s("path",{fill:"currentColor",d:"M544 864V672h128L512 480 352 672h128v192H320v-1.6c-5.376.32-10.496 1.6-16 1.6A240 240 0 0 1 64 624c0-123.136 93.12-223.488 212.608-237.248A239.808 239.808 0 0 1 512 192a239.872 239.872 0 0 1 235.456 194.752c119.488 13.76 212.48 114.112 212.48 237.248a240 240 0 0 1-240 240c-5.376 0-10.56-1.28-16-1.6v1.6H544z"},null,-1),$t=[bt];function Nt(V,le,A,oe,ne,M){return o(),c("svg",xt,$t)}var Et=je(kt,[["render",Nt]]);const z=V=>(ut("data-v-d3f704e9"),V=V(),dt(),V),Ft={class:"task-panel"},St={class:"pc-nav"},zt={class:"nav"},Ct={class:"logo"},Tt=z(()=>s("img",{style:{height:"40px",width:"170px"},src:"https://img.cdn.sugarat.top/easypicker/EasyPicker.png",alt:"logo"},null,-1)),Ut=["onClick"],It={key:0,"element-loading-text":"Loading...",class:"panel tc"},Lt={class:"name"},Vt={class:"tip-wrapper"},Mt={class:"ddl"},Dt={key:0},Bt={key:3},Pt={class:"infos"},Rt={key:0},Wt={class:"infos"},Ot=z(()=>s("div",{class:"el-upload__text"},[r(" 将文件拖于此处 or "),s("em",null,"直接选择文件")],-1)),jt={class:"p10"},At={class:"p10"},Ht={class:"p10 option-tips"},Gt={style:{color:"red"}},Jt={style:{color:"red"}},qt=z(()=>s("br",null,null,-1)),Kt=z(()=>s("br",null,null,-1)),Yt=z(()=>s("br",null,null,-1)),Zt=z(()=>s("strong",null,"选择大文件后需要等待一会儿才展示处理",-1)),Qt=z(()=>s("br",null,null,-1)),Xt={class:"withdraw"},ea={key:1,class:"panel tc"},ta={class:"name"},aa={style:{"padding-top":"20px"}},sa=$e({__name:"index",setup(V){const le=Ae(),A=v(()=>le.getters["public/isMobile"]),oe=He(),ne=Ge(),M=E([{title:"我也要收集",path:"https://docs.ep.sugarat.top/"}]),Ne=t=>{if(M[t].path.startsWith("http")){window.location.href=M[t].path;return}oe.push({path:M[t].path})},C=E({name:"",category:""}),l=E({bindField:""}),f=v(()=>ot(l.format)),p=h(""),O=h(0),D=v(()=>O.value<=0),Ee=v(()=>{let t=~~(O.value/1e3),e=~~(t/(60*60));const a=~~(e/24);e%=24;const n=~~(t%3600/60);return t%=60,"剩余".concat(a,"天").concat(e,"时").concat(n,"分").concat(t,"秒")}),H=(t=!0)=>{if(l!=null&&l.ddl){const e=new Date(l.ddl);O.value=e.getTime()-Date.now()}else O.value=0;t&&setTimeout(()=>{H()},1e3)},T=v(()=>{if(l!=null&&l.ddl){const t=new Date(l.ddl);return nt(t)}return""}),_=E([]),$=h([]),G=h(),J=v(()=>$.value.filter(t=>t.status==="uploading").length>0),Fe=t=>t.status==="uploading"||t.status==="success"?wt.confirm("不影响已经上传成功的,正在上传的将取消上传","确定从列表移除文件吗?").then(()=>(t.status==="uploading"&&(u.info("取消".concat(t.name,"的上传")),t.subscription.unsubscribe()),!0)).catch(()=>!1):!0,q=v(()=>_.every(t=>t.value)),U=v(()=>l.bindField.trim()||"姓名"),ie=v(()=>_.find(t=>t.text===U.value)),Se=v(()=>l.people&&!ie.value),x=E({peopleName:""}),re=(t,e,a)=>{if(!e){const n="请输入".concat(U.value);a(new Error(n)),u.error(n);return}be.checkPeopleIsExist(p.value,e).then(n=>{n.data.exist||u.error("你不在此次提交名单中,如有疑问请联系管理员"),a(n.data.exist?void 0:new Error("你不在此次提交名单中,如有疑问请联系管理员"))})},ue=h(),ze=E({peopleName:[{validator:re,trigger:"blur"}]}),K=()=>{var t;if(ie.value){const e=(t=_.find(a=>a.text===U.value))==null?void 0:t.value;return x.peopleName=e||"",new Promise(a=>{re(null,e,a)}).then(a=>!a)}return ue.value.validate(e=>e)},Ce=()=>{const t=$.value;for(const e of t)if(!e.md5)u.info("文件(".concat(e.name,")的唯一指纹还在计算中,再等待一会儿再点击上传")),setTimeout(()=>{u.info("文件越大计算时间越长(1G通常需要20s)")},100);else if(e.status==="ready"){e.status="uploading";let{name:a}=e;const n=a;l.rewrite&&(a=_.map(P=>P.value).join(f.value.splitChar||"-")+se(a)),a=tt(a);const X="easypicker2/".concat(p.value,"/").concat(e.md5,"/").concat(a);W.getUploadToken().then(P=>{at(P.data.token,e.raw,X,{success(R){const{fsize:j}=R;W.addFile({originName:n,name:a,taskKey:p.value,taskName:C.name,size:j,hash:e.md5,info:JSON.stringify(_),people:x.peopleName}).then(()=>{e.status="success",u.success("文件:".concat(e.name,"提交成功")),l.people&&be.updatePeopleStatus(p.value,a,x.peopleName,e.md5)})},process(R,j,ee){e.percentage=Math.floor(R),e.subscription=ee}})})}},Te=async()=>{if(!q.value){u.warning("请先完成必要信息的填写");return}l.people&&!await K()||Ce()},Ue=v(()=>{for(const t of $.value)if(t.status==="ready")return!0;return!1}),Ie=v(()=>{for(const t of $.value)if(["success","ready"].includes(t.status))return!0;return!1}),I=h(0),Le=t=>{const{name:e}=t;if(f.value.format.length&&f.value.status){const a=se(e);if(!f.value.format.find(n=>a.endsWith(n))){u.error("".concat(e," 格式不符合要球")),G.value.handleRemove(t);return}}if(f.value.size&&f.value.size<t.size){u.error("".concat(e," 大小").concat(we(t.size)," 不符合要求")),G.value.handleRemove(t);return}I.value+=1,Ze(t.raw).then(a=>{t.md5=a,I.value-=1})},de=v(()=>f.value.limit||10),Ve=()=>{u.warning("一次提交最多只能选择".concat(de.value,"个文件,请移除已经上传成功的或刷新页面"))},Y=h(!1),ce=h(""),Me=()=>{const t=$.value;for(const e of t)if(!e.md5)u.info("文件(".concat(e.name,")的唯一指纹还在计算中,再等待一会儿再点击上传")),setTimeout(()=>{u.info("文件越大计算时间越长(1G通常需要20s)")},100);else if(!["fail","uploading"].includes(e.status)){let{name:a}=e;l.rewrite&&(a=_.map(n=>n.value).join(f.value.splitChar||"-")+se(a)),W.withdrawFile({taskKey:p.value,taskName:C.name,filename:a,hash:e.md5,info:JSON.stringify(_),peopleName:x.peopleName}).then(()=>{u.success("文件:".concat(e.name,"撤回成功")),e.name+=" - (已撤回 ✅ )",e.status="fail"}).catch(()=>{u.error("撤回失败: 没有文件:".concat(e.name,"对应提交记录"))})}},pe=()=>{W.getTemplateUrl(l.template,p.value).then(t=>{Y.value=!0;const{link:e}=t.data;ce.value=e,Qe(e,l.template)}).catch(()=>{u.warning("文件已从服务器上移除,请联系管理员重新上传")})},B=h(!1),De=async()=>{if(!q.value){u.warning("请先完成必要信息的填写");return}l.people&&!await K()||Me()},Be=async()=>{if(!q.value){u.warning("请先完成必要信息的填写,需和提交时信息完全一致");return}l.people&&!await K()||W.checkSubmitStatus(p.value,_,x.peopleName).then(t=>{t.data.isSubmit?u.success("已经提交过啦"):u.warning("还未提交过哟")})},Z=h(!1),Q=h(!1),me=(t=[],e=[])=>t.length!==e.length?!1:t.every((a,n)=>a.type===e[n].type&&a.text===e[n].text&&me(a.children,e[n].children)),ve=(t=!1)=>{ge.getTaskMoreInfo(p.value).then(e=>{Object.assign(l,e.data),me(_,ke(l.info))||(_.splice(0,_.length),_.push(...ke(l.info)),t&&u.success("表单信息有更新")),H(!1),Z.value=!1})},fe=()=>{Q.value=!0},_e=()=>{Q.value&&!J.value&&(Q.value=!1,ve(!0))},Pe=v(()=>D.value?T.value:T.value+Ee.value),N=E({text:"",imgs:[]}),w=h([]);return Je(()=>l.tip,()=>{try{const t=JSON.parse(l.tip);N.imgs=t.imgs,N.text=t.text||"",w.value=N.imgs.map(e=>({...e,url:"https://img.cdn.sugarat.top/mdImg/MTY3NzkxMDI1NTU1Nw==20140524124237518.gif"})),w.value.length&&st.getTipImageUrl(p.value,w.value.map(e=>({uid:e.uid,name:e.name}))).then(e=>{e.data.forEach((a,n)=>{w.value[n].url=a.cover,Object.assign(w.value[n],{preview:a.preview})})})}catch(t){N.text="",N.imgs=[],w.value=[]}}),qe(()=>{p.value=ne.params.key,p.value&&(Z.value=!0,ge.getTaskInfo(p.value).then(t=>{Object.assign(C,t.data)}).catch(t=>{t.code===4001&&(u.error("任务不存在"),p.value="",C.name="任务不存在")}),ve(),H()),window.addEventListener("blur",fe),window.addEventListener("focus",_e)}),Ke(()=>{window.removeEventListener("blur",fe),window.removeEventListener("focus",_e)}),(t,e)=>{const a=Ye("router-link"),n=Xe,X=ht,P=vt,R=it,j=_t,ee=ft,b=et,Re=rt,We=mt,Oe=pt;return o(),c("div",Ft,[s("div",St,[s("div",zt,[s("div",Ct,[d(a,{to:"/"},{default:i(()=>[Tt]),_:1})]),s("nav",null,[(o(!0),c(F,null,te(M,(m,L)=>(o(),c("div",{class:"nav-item",key:L,onClick:he=>Ne(L)},k(m.title),9,Ut))),128))])])]),p.value?ae((o(),c("div",It,[s("h1",Lt,k(C.name),1),N.text&&(!T.value||!D.value)?(o(),c(F,{key:0},[d(n,null,{default:i(()=>[r("⚠️ 注意事项 ⚠️")]),_:1}),d(S,null,{default:i(()=>[s("div",Vt,[(o(!0),c(F,null,te(N.text.split("\n"),(m,L)=>(o(),c("p",{key:L},k(m.replace(/\s/g," ")),1))),128))])]),_:1})],64)):y("",!0),w.value.length&&(!T.value||!D.value)?(o(!0),c(F,{key:1},te(w.value,(m,L)=>(o(),g(X,{"hide-on-click-modal":"",key:m.uid,style:{width:"100px",height:"100px",margin:"10px"},src:m.url,"zoom-rate":1.2,"preview-src-list":w.value.map(he=>he.preview),"initial-index":L,fit:"contain"},null,8,["src","preview-src-list","initial-index"]))),128)):y("",!0),T.value?(o(),c(F,{key:2},[d(n,null,{default:i(()=>[r("截止时间")]),_:1}),s("h2",Mt,k(Pe.value),1),D.value?(o(),c("div",Dt,[d(P,{description:"已经结束啦!"})])):y("",!0)],64)):y("",!0),!T.value||!D.value?(o(),c("div",Bt,[d(n,null,{default:i(()=>[r("必要信息填写")]),_:1}),s("div",Pt,[ae(s("div",null,[d(S,null,{default:i(()=>[r("“"+k(U.value)+"”在参与名单里才能正常提交",1)]),_:1})],512),[[ye,l.people]]),Se.value?(o(),c("div",Rt,[s("div",Wt,[d(ee,{ref_key:"validModalRef",ref:ue,rules:ze,"status-icon":"",model:x,disabled:J.value,"label-position":"top"},{default:i(()=>[d(j,{prop:"peopleName",label:U.value},{default:i(()=>[d(R,{maxlength:14,clearable:"","show-word-limit":"",placeholder:"请输入 ".concat(U.value),modelValue:x.peopleName,"onUpdate:modelValue":e[0]||(e[0]=m=>x.peopleName=m)},null,8,["placeholder","modelValue"])]),_:1},8,["label"])]),_:1},8,["rules","model","disabled"])])])):y("",!0),d(gt,{infos:_,disabled:J.value},null,8,["infos","disabled"])]),d(We,{style:{"max-width":"400px",margin:"0 auto"},drag:!A.value,action:"",ref_key:"fileUpload",ref:G,"on-change":Le,"before-remove":Fe,"on-exceed":Ve,"auto-upload":!1,multiple:"",limit:de.value,"file-list":$.value,"onUpdate:fileList":e[1]||(e[1]=m=>$.value=m)},{tip:i(()=>[ae(s("div",jt,[d(S,null,{default:i(()=>[r("还有 "+k(I.value)+" 个文件正在生成校验信息,请稍等(1G通常需要20s)",1)]),_:1})],512),[[ye,!!I.value]])]),default:i(()=>[A.value?(o(),g(b,{key:0,type:"primary"},{default:i(()=>[r("选择文件")]),_:1})):(o(),c(F,{key:1},[d(Re,{class:"el-icon--upload"},{default:i(()=>[d(xe(Et))]),_:1}),Ot],64))]),_:1},8,["drag","limit","file-list"]),s("div",At,[B.value?(o(),g(b,{key:0,size:"default",onClick:De,type:"warning",disabled:!Ie.value||!!I.value},{default:i(()=>[r("一键撤回")]),_:1},8,["disabled"])):(o(),g(b,{key:1,size:"default",onClick:Te,type:"success",disabled:!Ue.value||!!I.value},{default:i(()=>[r("提交文件")]),_:1},8,["disabled"])),d(b,{onClick:Be,size:"default"},{default:i(()=>[r("查询提交情况")]),_:1})]),s("div",Ht,[f.value.status&&f.value.format.length?(o(),g(S,{key:0},{default:i(()=>[r("限制格式为: "),s("span",Gt,k(f.value.format.join(", ")),1)]),_:1})):y("",!0),f.value.size?(o(),g(S,{key:1},{default:i(()=>[r("限制文件大小不超过: "),s("span",Jt,k(xe(we)(f.value.size)),1)]),_:1})):y("",!0),B.value?(o(),g(S,{key:2},{default:i(()=>[r("① 须保证选择的文件与提交时的文件一致"),qt,r(" ② 填写表单信息一致 "),Kt,r(" ③ 完全一模一样的文件的提交记录(内容md5+命名),将会一次性全部撤回")]),_:1})):(o(),g(S,{key:3},{default:i(()=>[r("① 选择完文件,点击 ”提交文件“即可 "),Yt,r(" ② "),Zt,l.template?(o(),c(F,{key:0},[Qt,r(" ③ "),s("strong",null,[d(b,{type:"primary",text:"",style:{color:"#85ce61"},size:"small",onClick:pe},{default:i(()=>[r("右下角可 “查看提交示例” ")]),_:1})])],64)):y("",!0)]),_:1}))]),s("div",Xt,[l.template?(o(),g(b,{key:0,type:"primary",text:"",style:{color:"#85ce61"},size:"small",onClick:pe},{default:i(()=>[r("查看提交示例")]),_:1})):y("",!0),B.value?(o(),g(b,{key:1,onClick:e[2]||(e[2]=m=>B.value=!1),size:"small",type:"primary",text:""},{default:i(()=>[r("正常提交")]),_:1})):(o(),g(b,{key:2,size:"small",onClick:e[3]||(e[3]=m=>B.value=!0),type:"primary",text:""},{default:i(()=>[r("我要撤回")]),_:1}))])])):y("",!0)])),[[Oe,Z.value]]):(o(),c("div",ea,[s("h1",ta,k(C.name),1)])),d(yt,{value:Y.value,"onUpdate:value":e[4]||(e[4]=m=>Y.value=m),title:"示例文件下载链接",link:ce.value},null,8,["value","link"]),s("div",aa,[d(lt,{type:"task"})])])}}});const ha=ct(sa,[["__scopeId","data-v-d3f704e9"]]);export{ha as default};
|
|
2
|
+
//# sourceMappingURL=index-b0a4c236.js.map
|