@whitesev/data-paging 0.0.4 → 0.0.5

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.
@@ -1,2 +1,2 @@
1
- System.register("DataPaging",[],function(t){"use strict";return{execute:function(){const e={setSafeHTML(t,e){try{t.innerHTML=e}catch{if(!globalThis.trustedTypes)throw new Error("PagingUtils trustedTypes is not defined");{const i=globalThis.trustedTypes.createPolicy("safe-innerHTML",{createHTML:t=>t});t.innerHTML=i.createHTML(e)}}}};t("default",class{version="0.0.4";CONFIG;PAGE_CONFIG={currentPage:()=>{const t=this.DOM_CONFIG.getAttributeWithCurrentPage();return this.DOM_CONFIG.getAttributeWithPageId(t)??1},maxPage:1};DOM_CONFIG={$pageWrapper:{localName:"div",id:"data-paging-wrapper",dom:null},firstBtnNode:{localName:"a",className:"pg-first",svgHTML:'<svg t="1694497357294" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4758" width="20"><path d="M730.639277 211.376748l60.943177 60.943176-301.698894 301.698893L428.940384 513.075641z" p-id="4759"></path><path d="M730.496772 814.924547l60.943176-60.943176-301.698893-301.698893L428.797879 513.225654z" p-id="4760"></path><path d="M298.666667 213.333333h85.333333v597.333334H298.666667z" p-id="4761"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.firstBtnNode.localName}.${this.DOM_CONFIG.firstBtnNode.className}`)},prevBtnNode:{localName:"a",className:"pg-prev",svgHTML:'<svg t="1694497840770" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5272" width="20"><path d="M620.322607 151.04875l60.943176 60.943176-362.038672 362.038672L258.283935 513.087422z" p-id="5273"></path><path d="M620.180101 875.252545l60.943177-60.943176-362.038672-362.038672L258.141429 513.213873z" p-id="5274"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.prevBtnNode.localName}.${this.DOM_CONFIG.prevBtnNode.className}`)},nextBtnNode:{localName:"a",className:"pg-next",svgHTML:'<svg t="1694497949481" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5465" width="20"><path d="M403.399239 151.02258l-60.943177 60.943177 362.038672 362.038672L765.437911 513.061252z" p-id="5466"></path><path d="M403.576858 875.263008l-60.943176-60.943176 362.038672-362.038672L765.61553 513.224336z" p-id="5467"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.nextBtnNode.localName}.${this.DOM_CONFIG.nextBtnNode.className}`)},lastBtnNode:{localName:"a",className:"pg-last",svgHTML:'<svg t="1694498035538" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2299" width="20"><path d="M516.266667 490.666667L256 230.4 315.733333 170.666667l320 320L315.733333 810.666667 256 750.933333l260.266667-260.266666zM678.4 170.666667h85.333333v640h-85.333333V170.666667z" p-id="2300"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.lastBtnNode.localName}.${this.DOM_CONFIG.lastBtnNode.className}`)},setAttributeWithPageId:(t,e)=>{t.setAttribute("page-id",String(e))},getAttributeWithPageId:t=>{const e=t?.getAttribute("page-id");return e?parseInt(e):null},hasAttributeWithPageId:t=>t.hasAttribute("page-id"),setAttributeWithCurrentPage:t=>{t.setAttribute("data-current-page","")},getAttributeWithCurrentPage:t=>(t||this.DOM_CONFIG.$pageWrapper.dom).querySelector("a[data-current-page]"),hasAttributeWithCurrentPage:t=>t.hasAttribute("data-current-page"),removeAttributeWithCurrentPage:t=>{t.removeAttribute("data-current-page")},setAttributeWithDisabled:t=>{t.setAttribute("disabled","true")},removeAllAttributeWithDisabled:t=>{(t||this.DOM_CONFIG.$pageWrapper.dom)?.querySelectorAll("a[class][disabled]").forEach(t=>{t.removeAttribute("disabled")})},getFirstPageNode:t=>(t||this.DOM_CONFIG.$pageWrapper.dom).querySelector("a[page-id='1']"),getLastPageNode:t=>(t||this.DOM_CONFIG.$pageWrapper.dom).querySelector(`a[page-id='${this.PAGE_CONFIG.maxPage}']`),getAllPageNode:t=>Array.from((t||this.DOM_CONFIG.$pageWrapper.dom).querySelectorAll("a[page-id]"))};constructor(t){this.CONFIG={data:[],pageShowDataMaxCount:5,pageMaxStep:3,currentPage:1,pageChangeCallBack:function(){},prevBtn:{enable:!0,callBack:function(){}},nextBtn:{enable:!0,callBack:function(){}},firstBtn:{enable:!0,callBack:function(){}},lastBtn:{enable:!0,callBack:function(){}}},this.changeConfig(t)}hide(t=this.DOM_CONFIG.$pageWrapper.dom){t&&(t.style.display="none")}show(t=this.DOM_CONFIG.$pageWrapper.dom){t&&(t.style.display="")}isHide(t=this.DOM_CONFIG.$pageWrapper.dom){if(t)return t.style.display.includes("none")}destory(){const t=this.DOM_CONFIG.$pageWrapper.dom;if(!t)return;const e=t.parentElement;e?.removeChild?.(t),this.DOM_CONFIG.$pageWrapper.dom=null}addCSS(t=document.head){const i=document.createElement("style");i.setAttribute("type","text/css");const a=`@charset "utf-8";\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} {\n\t\t\ttext-align: center;\n\t\t\tdisplay: inline-block;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.firstBtnNode.className},\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.prevBtnNode.className},\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.nextBtnNode.className},\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.lastBtnNode.className} {\n\t\t\tfont-family: Arial, sans-serif;\n\t\t\tcolor: #333;\n\t\t\tfont-size: 22px;\n\t\t\tfill: currentColor;\n\t\t\tdisplay: inline-flex;\n\t\t\tjustify-content: center;\n\t\t\talign-items: center;\n\t\t\ttext-decoration: none;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a,\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} span {\n\t\t\twidth: 45px;\n\t\t\theight: 40px;\n\t\t\tborder: 1px solid #ebebeb;\n\t\t\tmargin-left: -1px;\n\t\t\tcolor: #000000;\n\t\t\tline-height: 40px;\n\t\t\tfloat: left;\n\t\t\tfont-size: 15px;\n\t\t\ttext-decoration: none;\n\t\t\tmargin: 0 2px;\n\t\t\tborder-radius: 6px;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a:hover,\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} span:hover {\n\t\t\tborder-color: #3897cd;\n\t\t\tcolor: #3897cd;\n\t\t\tposition: relative;\n\t\t\tz-index: 1;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a {\n\t\t\tcursor: pointer;\n\t\t\tuser-select: none;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a[data-current-page] {\n\t\t\tbackground-color: #222a35;\n\t\t\tcolor: #fff;\n\t\t\tborder-color: #ebebeb;\n\t\t\tposition: relative;\n\t\t\tz-index: 1;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.firstBtnNode.className}[disabled="true"],\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.prevBtnNode.className}[disabled="true"],\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.nextBtnNode.className}[disabled="true"],\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.lastBtnNode.className}[disabled="true"]{\n\t\t\tcursor: not-allowed;\n\t\t\tborder: 1px solid transparent;\n\t\t\tcolor: #c9c9c9;\n\t\t}\n\t\t`;e.setSafeHTML(i,a),t.appendChild(i)}createDataPagingWrapper(){const t=document.createElement(this.DOM_CONFIG.$pageWrapper.localName);this.DOM_CONFIG.$pageWrapper.dom=t,t.id=this.DOM_CONFIG.$pageWrapper.id;const i=document.createElement(this.DOM_CONFIG.firstBtnNode.localName);e.setSafeHTML(i,this.DOM_CONFIG.firstBtnNode.svgHTML);const a=document.createElement(this.DOM_CONFIG.prevBtnNode.localName);e.setSafeHTML(a,this.DOM_CONFIG.prevBtnNode.svgHTML);const s=document.createElement(this.DOM_CONFIG.nextBtnNode.localName);e.setSafeHTML(s,this.DOM_CONFIG.nextBtnNode.svgHTML);const r=document.createElement(this.DOM_CONFIG.lastBtnNode.localName);if(e.setSafeHTML(r,this.DOM_CONFIG.lastBtnNode.svgHTML),i.className=this.DOM_CONFIG.firstBtnNode.className,a.className=this.DOM_CONFIG.prevBtnNode.className,s.className=this.DOM_CONFIG.nextBtnNode.className,r.className=this.DOM_CONFIG.lastBtnNode.className,this.PAGE_CONFIG.maxPage=Math.ceil(this.CONFIG.data.length/this.CONFIG.pageShowDataMaxCount),this.CONFIG.currentPage<1?this.CONFIG.currentPage=1:this.CONFIG.currentPage>this.PAGE_CONFIG.maxPage&&(this.CONFIG.currentPage=this.PAGE_CONFIG.maxPage),this.PAGE_CONFIG.maxPage<2)return t;this.CONFIG.firstBtn.enable&&(this.setFirstBtnClickEvent(i,t),t.appendChild(i)),this.CONFIG.prevBtn.enable&&(this.setPrevBtnClickEvent(a,t),t.appendChild(a));let n=this.CONFIG.currentPage;if(this.CONFIG.pageMaxStep>this.PAGE_CONFIG.maxPage)for(let e=n;e<=this.PAGE_CONFIG.maxPage;e++){const i=document.createElement("a");this.DOM_CONFIG.setAttributeWithPageId(i,e),i.innerText=String(e),this.CONFIG.currentPage===e&&this.DOM_CONFIG.setAttributeWithCurrentPage(i),this.setPageBtnClickEvent(i,t),t.appendChild(i)}else if(n+this.CONFIG.pageMaxStep>this.PAGE_CONFIG.maxPage){n=this.PAGE_CONFIG.maxPage;const e=[];for(let i=0;i<this.CONFIG.pageMaxStep;i++){const i=document.createElement("a");this.DOM_CONFIG.setAttributeWithPageId(i,n),i.innerText=String(n),this.CONFIG.currentPage===n&&this.DOM_CONFIG.setAttributeWithCurrentPage(i),this.setPageBtnClickEvent(i,t),e.push(i),n--}e.reverse(),e.forEach(e=>{t.appendChild(e)})}else for(let e=0;e<this.CONFIG.pageMaxStep;e++){const e=document.createElement("a");this.DOM_CONFIG.setAttributeWithPageId(e,n),e.innerText=String(n),this.CONFIG.currentPage===n&&this.DOM_CONFIG.setAttributeWithCurrentPage(e),this.setPageBtnClickEvent(e,t),t.appendChild(e),n++}return this.CONFIG.nextBtn.enable&&(this.setNextBtnClickEvent(s,t),t.appendChild(s)),this.CONFIG.lastBtn.enable&&(this.setLastBtnClickEvent(r,t),t.appendChild(r)),1===this.CONFIG.currentPage?(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get())):this.CONFIG.currentPage===this.PAGE_CONFIG.maxPage&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get())),t}setFirstBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(1===this.DOM_CONFIG.getAttributeWithPageId(i))return;await(this.CONFIG.firstBtn?.callBack?.(t));const a=this.DOM_CONFIG.getAllPageNode(e);for(let t=0;t<this.CONFIG.pageMaxStep;t++){const e=a[t];null!=e&&(0===t?this.DOM_CONFIG.setAttributeWithCurrentPage(e):this.DOM_CONFIG.removeAttributeWithCurrentPage(e),this.DOM_CONFIG.setAttributeWithPageId(e,t+1),e.innerText=String(t+1))}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getFirstPageNode(e)&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get())),this.CONFIG.pageChangeCallBack(1)})}setPrevBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(1===this.DOM_CONFIG.getAttributeWithPageId(i))return;await(this.CONFIG.prevBtn?.callBack?.(t));const a=i.previousElementSibling;if(a&&this.DOM_CONFIG.hasAttributeWithPageId(a))a.click();else{this.DOM_CONFIG.getAllPageNode(e).forEach(t=>{let e=this.DOM_CONFIG.getAttributeWithPageId(t);e--,this.DOM_CONFIG.setAttributeWithPageId(t,e),t.innerText=String(e)}),this.CONFIG.pageChangeCallBack(this.PAGE_CONFIG.currentPage())}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getFirstPageNode(e)&&1==this.PAGE_CONFIG.currentPage()&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get()))})}setNextBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(this.DOM_CONFIG.getAttributeWithPageId(i)===this.PAGE_CONFIG.maxPage)return;await(this.CONFIG.nextBtn?.callBack?.(t));const a=i.nextElementSibling;if(a&&this.DOM_CONFIG.hasAttributeWithPageId(a))a.click();else{this.DOM_CONFIG.getAllPageNode(e).forEach(t=>{let e=this.DOM_CONFIG.getAttributeWithPageId(t);e++,e>this.PAGE_CONFIG.maxPage||(this.DOM_CONFIG.setAttributeWithPageId(t,e),t.innerText=String(e))}),this.CONFIG.pageChangeCallBack(this.PAGE_CONFIG.currentPage())}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getLastPageNode()&&this.PAGE_CONFIG.currentPage()==this.PAGE_CONFIG.maxPage&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get()))})}setLastBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(this.DOM_CONFIG.getAttributeWithPageId(i)===this.PAGE_CONFIG.maxPage)return;await(this.CONFIG.lastBtn?.callBack?.(t));const a=Array.from(this.DOM_CONFIG.getAllPageNode(e));a.reverse();let s=this.PAGE_CONFIG.maxPage,r=0;for(;!(this.PAGE_CONFIG.maxPage-s>3);){const t=a[r];if(null==t)break;0===r?this.DOM_CONFIG.setAttributeWithCurrentPage(t):this.DOM_CONFIG.removeAttributeWithCurrentPage(t),this.DOM_CONFIG.setAttributeWithPageId(t,s),t.innerText=String(s),s--,r++}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get()),this.CONFIG.pageChangeCallBack(this.PAGE_CONFIG.maxPage)})}setPageBtnClickEvent(t,e){t.addEventListener("click",async()=>{const i=t,a=this.DOM_CONFIG.getAllPageNode(e);for(const t of a)if(t==i){if(!this.DOM_CONFIG.hasAttributeWithCurrentPage(i)){this.DOM_CONFIG.setAttributeWithCurrentPage(i);const t=this.PAGE_CONFIG.currentPage();await(this.CONFIG?.pageChangeCallBack?.(t))}}else this.DOM_CONFIG.removeAttributeWithCurrentPage(t);this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getFirstPageNode(e)&&1==this.PAGE_CONFIG.currentPage()&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get())),this.DOM_CONFIG.getLastPageNode()&&this.PAGE_CONFIG.currentPage()==this.PAGE_CONFIG.maxPage&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get()))})}append(t){const e=this.isHide();this.destory();const i=this.createDataPagingWrapper();e&&this.hide(i),t.appendChild(i)}after(t){const e=this.isHide(),i=t.parentElement,a=t.nextSibling;this.destory();const s=this.createDataPagingWrapper();e&&this.hide(s),!i||a?t.after(s):i.insertBefore(s,a)}changeConfig(t){Object.assign(this.CONFIG,t)}refresh(t){this.CONFIG.data=[],this.CONFIG.data=t;let e=this.PAGE_CONFIG.currentPage();const i=Math.ceil(t.length/this.CONFIG.pageShowDataMaxCount);e>i&&(e=i),this.CONFIG.currentPage=e;const a=this.DOM_CONFIG.$pageWrapper.dom;a&&this.after(a)}})}}});
1
+ System.register("DataPaging",[],function(t){"use strict";return{execute:function(){const e={setSafeHTML(t,e){try{t.innerHTML=e}catch{if(!globalThis.trustedTypes)throw new Error("PagingUtils trustedTypes is not defined");{const i=globalThis.trustedTypes.createPolicy("safe-innerHTML",{createHTML:t=>t});t.innerHTML=i.createHTML(e)}}}};t("default",class{version="0.0.5";CONFIG;PAGE_CONFIG={currentPage:()=>{const t=this.DOM_CONFIG.getAttributeWithCurrentPage();return this.DOM_CONFIG.getAttributeWithPageId(t)??1},maxPage:1};DOM_CONFIG={$pageWrapper:{localName:"div",id:"data-paging-wrapper",dom:null},firstBtnNode:{localName:"a",className:"pg-first",svgHTML:'<svg t="1694497357294" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4758" width="20"><path d="M730.639277 211.376748l60.943177 60.943176-301.698894 301.698893L428.940384 513.075641z" p-id="4759"></path><path d="M730.496772 814.924547l60.943176-60.943176-301.698893-301.698893L428.797879 513.225654z" p-id="4760"></path><path d="M298.666667 213.333333h85.333333v597.333334H298.666667z" p-id="4761"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.firstBtnNode.localName}.${this.DOM_CONFIG.firstBtnNode.className}`)},prevBtnNode:{localName:"a",className:"pg-prev",svgHTML:'<svg t="1694497840770" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5272" width="20"><path d="M620.322607 151.04875l60.943176 60.943176-362.038672 362.038672L258.283935 513.087422z" p-id="5273"></path><path d="M620.180101 875.252545l60.943177-60.943176-362.038672-362.038672L258.141429 513.213873z" p-id="5274"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.prevBtnNode.localName}.${this.DOM_CONFIG.prevBtnNode.className}`)},nextBtnNode:{localName:"a",className:"pg-next",svgHTML:'<svg t="1694497949481" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5465" width="20"><path d="M403.399239 151.02258l-60.943177 60.943177 362.038672 362.038672L765.437911 513.061252z" p-id="5466"></path><path d="M403.576858 875.263008l-60.943176-60.943176 362.038672-362.038672L765.61553 513.224336z" p-id="5467"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.nextBtnNode.localName}.${this.DOM_CONFIG.nextBtnNode.className}`)},lastBtnNode:{localName:"a",className:"pg-last",svgHTML:'<svg t="1694498035538" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2299" width="20"><path d="M516.266667 490.666667L256 230.4 315.733333 170.666667l320 320L315.733333 810.666667 256 750.933333l260.266667-260.266666zM678.4 170.666667h85.333333v640h-85.333333V170.666667z" p-id="2300"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.lastBtnNode.localName}.${this.DOM_CONFIG.lastBtnNode.className}`)},setAttributeWithPageId:(t,e)=>{t.setAttribute("page-id",String(e))},getAttributeWithPageId:t=>{const e=t?.getAttribute("page-id");return e?parseInt(e):null},hasAttributeWithPageId:t=>t.hasAttribute("page-id"),setAttributeWithCurrentPage:t=>{t.setAttribute("data-current-page","")},getAttributeWithCurrentPage:t=>(t||this.DOM_CONFIG.$pageWrapper.dom).querySelector("a[data-current-page]"),hasAttributeWithCurrentPage:t=>t.hasAttribute("data-current-page"),removeAttributeWithCurrentPage:t=>{t.removeAttribute("data-current-page")},setAttributeWithDisabled:t=>{t.setAttribute("disabled","true")},removeAllAttributeWithDisabled:t=>{(t||this.DOM_CONFIG.$pageWrapper.dom)?.querySelectorAll("a[class][disabled]").forEach(t=>{t.removeAttribute("disabled")})},getFirstPageNode:t=>(t||this.DOM_CONFIG.$pageWrapper.dom).querySelector("a[page-id='1']"),getLastPageNode:t=>(t||this.DOM_CONFIG.$pageWrapper.dom).querySelector(`a[page-id='${this.PAGE_CONFIG.maxPage}']`),getAllPageNode:t=>Array.from((t||this.DOM_CONFIG.$pageWrapper.dom).querySelectorAll("a[page-id]"))};constructor(t){this.CONFIG={data:[],pageShowDataMaxCount:5,pageMaxStep:3,currentPage:1,pageChangeCallBack:function(){},prevBtn:{enable:!0,callBack:function(){}},nextBtn:{enable:!0,callBack:function(){}},firstBtn:{enable:!0,callBack:function(){}},lastBtn:{enable:!0,callBack:function(){}}},this.changeConfig(t)}hide(t=this.DOM_CONFIG.$pageWrapper.dom){t&&(t.style.display="none")}show(t=this.DOM_CONFIG.$pageWrapper.dom){t&&(t.style.display="")}isHide(t=this.DOM_CONFIG.$pageWrapper.dom){if(t)return t.style.display.includes("none")}destory(){const t=this.DOM_CONFIG.$pageWrapper.dom;if(!t)return;const e=t.parentElement;e?.removeChild?.(t),this.DOM_CONFIG.$pageWrapper.dom=null}addCSS(t=document.head){const i=document.createElement("style");i.setAttribute("type","text/css");const a=`@charset "utf-8";\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} {\n\t\t\ttext-align: center;\n\t\t\tdisplay: inline-block;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.firstBtnNode.className},\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.prevBtnNode.className},\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.nextBtnNode.className},\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.lastBtnNode.className} {\n\t\t\tfont-family: Arial, sans-serif;\n\t\t\tcolor: #333;\n\t\t\tfont-size: 22px;\n\t\t\tfill: currentColor;\n\t\t\tdisplay: inline-flex;\n\t\t\tjustify-content: center;\n\t\t\talign-items: center;\n\t\t\ttext-decoration: none;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a,\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} span {\n\t\t\twidth: 45px;\n\t\t\theight: 40px;\n\t\t\tborder: 1px solid #ebebeb;\n\t\t\tmargin-left: -1px;\n\t\t\tcolor: #000000;\n\t\t\tline-height: 40px;\n\t\t\tfloat: left;\n\t\t\tfont-size: 15px;\n\t\t\ttext-decoration: none;\n\t\t\tmargin: 0 2px;\n\t\t\tborder-radius: 6px;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a:hover,\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} span:hover {\n\t\t\tborder-color: #3897cd;\n\t\t\tcolor: #3897cd;\n\t\t\tposition: relative;\n\t\t\tz-index: 1;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a {\n\t\t\tcursor: pointer;\n\t\t\tuser-select: none;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a[data-current-page] {\n\t\t\tbackground-color: #222a35;\n\t\t\tcolor: #fff;\n\t\t\tborder-color: #ebebeb;\n\t\t\tposition: relative;\n\t\t\tz-index: 1;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.firstBtnNode.className}[disabled="true"],\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.prevBtnNode.className}[disabled="true"],\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.nextBtnNode.className}[disabled="true"],\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.lastBtnNode.className}[disabled="true"]{\n\t\t\tcursor: not-allowed;\n\t\t\tborder: 1px solid transparent;\n\t\t\tcolor: #c9c9c9;\n\t\t}\n\t\t`;e.setSafeHTML(i,a),t.appendChild(i)}createDataPagingWrapper(){const t=document.createElement(this.DOM_CONFIG.$pageWrapper.localName);this.DOM_CONFIG.$pageWrapper.dom=t,t.id=this.DOM_CONFIG.$pageWrapper.id;const i=document.createElement(this.DOM_CONFIG.firstBtnNode.localName);e.setSafeHTML(i,this.DOM_CONFIG.firstBtnNode.svgHTML);const a=document.createElement(this.DOM_CONFIG.prevBtnNode.localName);e.setSafeHTML(a,this.DOM_CONFIG.prevBtnNode.svgHTML);const s=document.createElement(this.DOM_CONFIG.nextBtnNode.localName);e.setSafeHTML(s,this.DOM_CONFIG.nextBtnNode.svgHTML);const r=document.createElement(this.DOM_CONFIG.lastBtnNode.localName);if(e.setSafeHTML(r,this.DOM_CONFIG.lastBtnNode.svgHTML),i.className=this.DOM_CONFIG.firstBtnNode.className,a.className=this.DOM_CONFIG.prevBtnNode.className,s.className=this.DOM_CONFIG.nextBtnNode.className,r.className=this.DOM_CONFIG.lastBtnNode.className,this.PAGE_CONFIG.maxPage=Math.ceil(this.CONFIG.data.length/this.CONFIG.pageShowDataMaxCount),this.CONFIG.currentPage<1?this.CONFIG.currentPage=1:this.CONFIG.currentPage>this.PAGE_CONFIG.maxPage&&(this.CONFIG.currentPage=this.PAGE_CONFIG.maxPage),this.PAGE_CONFIG.maxPage<2)return t;this.CONFIG.firstBtn.enable&&(this.setFirstBtnClickEvent(i,t),t.appendChild(i)),this.CONFIG.prevBtn.enable&&(this.setPrevBtnClickEvent(a,t),t.appendChild(a));let n=this.CONFIG.currentPage;if(this.CONFIG.pageMaxStep>this.PAGE_CONFIG.maxPage)for(let e=n;e<=this.PAGE_CONFIG.maxPage;e++){const i=document.createElement("a");this.DOM_CONFIG.setAttributeWithPageId(i,e),i.innerText=String(e),this.CONFIG.currentPage===e&&this.DOM_CONFIG.setAttributeWithCurrentPage(i),this.setPageBtnClickEvent(i,t),t.appendChild(i)}else if(n+this.CONFIG.pageMaxStep>this.PAGE_CONFIG.maxPage){n=this.PAGE_CONFIG.maxPage;const e=[];for(let i=0;i<this.CONFIG.pageMaxStep;i++){const i=document.createElement("a");this.DOM_CONFIG.setAttributeWithPageId(i,n),i.innerText=String(n),this.CONFIG.currentPage===n&&this.DOM_CONFIG.setAttributeWithCurrentPage(i),this.setPageBtnClickEvent(i,t),e.push(i),n--}e.reverse(),e.forEach(e=>{t.appendChild(e)})}else for(let e=0;e<this.CONFIG.pageMaxStep;e++){const e=document.createElement("a");this.DOM_CONFIG.setAttributeWithPageId(e,n),e.innerText=String(n),this.CONFIG.currentPage===n&&this.DOM_CONFIG.setAttributeWithCurrentPage(e),this.setPageBtnClickEvent(e,t),t.appendChild(e),n++}return this.CONFIG.nextBtn.enable&&(this.setNextBtnClickEvent(s,t),t.appendChild(s)),this.CONFIG.lastBtn.enable&&(this.setLastBtnClickEvent(r,t),t.appendChild(r)),1===this.CONFIG.currentPage?(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get())):this.CONFIG.currentPage===this.PAGE_CONFIG.maxPage&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get())),t}setFirstBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(1===this.DOM_CONFIG.getAttributeWithPageId(i))return;await(this.CONFIG.firstBtn?.callBack?.(t));const a=this.DOM_CONFIG.getAllPageNode(e);for(let t=0;t<this.CONFIG.pageMaxStep;t++){const e=a[t];null!=e&&(0===t?this.DOM_CONFIG.setAttributeWithCurrentPage(e):this.DOM_CONFIG.removeAttributeWithCurrentPage(e),this.DOM_CONFIG.setAttributeWithPageId(e,t+1),e.innerText=String(t+1))}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getFirstPageNode(e)&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get())),this.CONFIG.pageChangeCallBack(1)})}setPrevBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(1===this.DOM_CONFIG.getAttributeWithPageId(i))return;await(this.CONFIG.prevBtn?.callBack?.(t));const a=i.previousElementSibling;if(a&&this.DOM_CONFIG.hasAttributeWithPageId(a))a.click();else{this.DOM_CONFIG.getAllPageNode(e).forEach(t=>{let e=this.DOM_CONFIG.getAttributeWithPageId(t);e--,this.DOM_CONFIG.setAttributeWithPageId(t,e),t.innerText=String(e)}),this.CONFIG.pageChangeCallBack(this.PAGE_CONFIG.currentPage())}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getFirstPageNode(e)&&1==this.PAGE_CONFIG.currentPage()&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get()))})}setNextBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(this.DOM_CONFIG.getAttributeWithPageId(i)===this.PAGE_CONFIG.maxPage)return;await(this.CONFIG.nextBtn?.callBack?.(t));const a=i.nextElementSibling;if(a&&this.DOM_CONFIG.hasAttributeWithPageId(a))a.click();else{this.DOM_CONFIG.getAllPageNode(e).forEach(t=>{let e=this.DOM_CONFIG.getAttributeWithPageId(t);e++,e>this.PAGE_CONFIG.maxPage||(this.DOM_CONFIG.setAttributeWithPageId(t,e),t.innerText=String(e))}),this.CONFIG.pageChangeCallBack(this.PAGE_CONFIG.currentPage())}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getLastPageNode()&&this.PAGE_CONFIG.currentPage()==this.PAGE_CONFIG.maxPage&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get()))})}setLastBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(this.DOM_CONFIG.getAttributeWithPageId(i)===this.PAGE_CONFIG.maxPage)return;await(this.CONFIG.lastBtn?.callBack?.(t));const a=Array.from(this.DOM_CONFIG.getAllPageNode(e));a.reverse();let s=this.PAGE_CONFIG.maxPage,r=0;for(;!(this.PAGE_CONFIG.maxPage-s>3);){const t=a[r];if(null==t)break;0===r?this.DOM_CONFIG.setAttributeWithCurrentPage(t):this.DOM_CONFIG.removeAttributeWithCurrentPage(t),this.DOM_CONFIG.setAttributeWithPageId(t,s),t.innerText=String(s),s--,r++}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get()),this.CONFIG.pageChangeCallBack(this.PAGE_CONFIG.maxPage)})}setPageBtnClickEvent(t,e){t.addEventListener("click",async()=>{const i=t,a=this.DOM_CONFIG.getAllPageNode(e);for(const t of a)if(t==i){if(!this.DOM_CONFIG.hasAttributeWithCurrentPage(i)){this.DOM_CONFIG.setAttributeWithCurrentPage(i);const t=this.PAGE_CONFIG.currentPage();await(this.CONFIG?.pageChangeCallBack?.(t))}}else this.DOM_CONFIG.removeAttributeWithCurrentPage(t);this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getFirstPageNode(e)&&1==this.PAGE_CONFIG.currentPage()&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get())),this.DOM_CONFIG.getLastPageNode()&&this.PAGE_CONFIG.currentPage()==this.PAGE_CONFIG.maxPage&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get()))})}append(t){const e=this.isHide();this.destory();const i=this.createDataPagingWrapper();e&&this.hide(i),t.appendChild(i)}after(t){const e=this.isHide(),i=t.parentElement,a=t.nextSibling;this.destory();const s=this.createDataPagingWrapper();e&&this.hide(s),!i||a?t.after(s):i.insertBefore(s,a)}changeConfig(t){Object.assign(this.CONFIG,t)}refresh(t){this.CONFIG.data=[],this.CONFIG.data=t;let e=this.PAGE_CONFIG.currentPage();const i=Math.ceil(t.length/this.CONFIG.pageShowDataMaxCount);e>i&&(e=i),this.CONFIG.currentPage=e;const a=this.DOM_CONFIG.$pageWrapper.dom;a&&this.after(a)}})}}});
2
2
  //# sourceMappingURL=index.system.min.js.map
package/dist/index.umd.js CHANGED
@@ -40,9 +40,9 @@
40
40
  $el.innerHTML = text;
41
41
  }
42
42
  catch {
43
- // @ts-ignore
43
+ // @ts-expect-error
44
44
  if (globalThis.trustedTypes) {
45
- // @ts-ignore
45
+ // @ts-expect-error
46
46
  const policy = globalThis.trustedTypes.createPolicy("safe-innerHTML", {
47
47
  createHTML: (html) => html,
48
48
  });
@@ -55,7 +55,7 @@
55
55
  },
56
56
  };
57
57
 
58
- const version = "0.0.4";
58
+ const version = "0.0.5";
59
59
 
60
60
  class Paging {
61
61
  version = version;
@@ -259,64 +259,64 @@
259
259
  addCSS($parent = document.head) {
260
260
  const $style = document.createElement("style");
261
261
  $style.setAttribute("type", "text/css");
262
- const cssText = /*css*/ `@charset "utf-8";
263
- #${this.DOM_CONFIG.$pageWrapper.id} {
264
- text-align: center;
265
- display: inline-block;
266
- }
267
- #${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.firstBtnNode.className},
268
- #${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.prevBtnNode.className},
269
- #${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.nextBtnNode.className},
270
- #${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.lastBtnNode.className} {
271
- font-family: Arial, sans-serif;
272
- color: #333;
273
- font-size: 22px;
274
- fill: currentColor;
275
- display: inline-flex;
276
- justify-content: center;
277
- align-items: center;
278
- text-decoration: none;
279
- }
280
- #${this.DOM_CONFIG.$pageWrapper.id} a,
281
- #${this.DOM_CONFIG.$pageWrapper.id} span {
282
- width: 45px;
283
- height: 40px;
284
- border: 1px solid #ebebeb;
285
- margin-left: -1px;
286
- color: #000000;
287
- line-height: 40px;
288
- float: left;
289
- font-size: 15px;
290
- text-decoration: none;
291
- margin: 0 2px;
292
- border-radius: 6px;
293
- }
294
- #${this.DOM_CONFIG.$pageWrapper.id} a:hover,
295
- #${this.DOM_CONFIG.$pageWrapper.id} span:hover {
296
- border-color: #3897cd;
297
- color: #3897cd;
298
- position: relative;
299
- z-index: 1;
300
- }
301
- #${this.DOM_CONFIG.$pageWrapper.id} a {
302
- cursor: pointer;
303
- user-select: none;
304
- }
305
- #${this.DOM_CONFIG.$pageWrapper.id} a[data-current-page] {
306
- background-color: #222a35;
307
- color: #fff;
308
- border-color: #ebebeb;
309
- position: relative;
310
- z-index: 1;
311
- }
312
- #${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.firstBtnNode.className}[disabled="true"],
313
- #${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.prevBtnNode.className}[disabled="true"],
314
- #${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.nextBtnNode.className}[disabled="true"],
315
- #${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.lastBtnNode.className}[disabled="true"]{
316
- cursor: not-allowed;
317
- border: 1px solid transparent;
318
- color: #c9c9c9;
319
- }
262
+ const cssText = /*css*/ `@charset "utf-8";
263
+ #${this.DOM_CONFIG.$pageWrapper.id} {
264
+ text-align: center;
265
+ display: inline-block;
266
+ }
267
+ #${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.firstBtnNode.className},
268
+ #${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.prevBtnNode.className},
269
+ #${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.nextBtnNode.className},
270
+ #${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.lastBtnNode.className} {
271
+ font-family: Arial, sans-serif;
272
+ color: #333;
273
+ font-size: 22px;
274
+ fill: currentColor;
275
+ display: inline-flex;
276
+ justify-content: center;
277
+ align-items: center;
278
+ text-decoration: none;
279
+ }
280
+ #${this.DOM_CONFIG.$pageWrapper.id} a,
281
+ #${this.DOM_CONFIG.$pageWrapper.id} span {
282
+ width: 45px;
283
+ height: 40px;
284
+ border: 1px solid #ebebeb;
285
+ margin-left: -1px;
286
+ color: #000000;
287
+ line-height: 40px;
288
+ float: left;
289
+ font-size: 15px;
290
+ text-decoration: none;
291
+ margin: 0 2px;
292
+ border-radius: 6px;
293
+ }
294
+ #${this.DOM_CONFIG.$pageWrapper.id} a:hover,
295
+ #${this.DOM_CONFIG.$pageWrapper.id} span:hover {
296
+ border-color: #3897cd;
297
+ color: #3897cd;
298
+ position: relative;
299
+ z-index: 1;
300
+ }
301
+ #${this.DOM_CONFIG.$pageWrapper.id} a {
302
+ cursor: pointer;
303
+ user-select: none;
304
+ }
305
+ #${this.DOM_CONFIG.$pageWrapper.id} a[data-current-page] {
306
+ background-color: #222a35;
307
+ color: #fff;
308
+ border-color: #ebebeb;
309
+ position: relative;
310
+ z-index: 1;
311
+ }
312
+ #${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.firstBtnNode.className}[disabled="true"],
313
+ #${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.prevBtnNode.className}[disabled="true"],
314
+ #${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.nextBtnNode.className}[disabled="true"],
315
+ #${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.lastBtnNode.className}[disabled="true"]{
316
+ cursor: not-allowed;
317
+ border: 1px solid transparent;
318
+ color: #c9c9c9;
319
+ }
320
320
  `;
321
321
  PagingUtils.setSafeHTML($style, cssText);
322
322
  $parent.appendChild($style);
@@ -1,2 +1,2 @@
1
- !function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t="undefined"!=typeof globalThis?globalThis:t||self).DataPaging=e()}(this,function(){"use strict";const t={setSafeHTML(t,e){try{t.innerHTML=e}catch{if(!globalThis.trustedTypes)throw new Error("PagingUtils trustedTypes is not defined");{const i=globalThis.trustedTypes.createPolicy("safe-innerHTML",{createHTML:t=>t});t.innerHTML=i.createHTML(e)}}}};return class{version="0.0.4";CONFIG;PAGE_CONFIG={currentPage:()=>{const t=this.DOM_CONFIG.getAttributeWithCurrentPage();return this.DOM_CONFIG.getAttributeWithPageId(t)??1},maxPage:1};DOM_CONFIG={$pageWrapper:{localName:"div",id:"data-paging-wrapper",dom:null},firstBtnNode:{localName:"a",className:"pg-first",svgHTML:'<svg t="1694497357294" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4758" width="20"><path d="M730.639277 211.376748l60.943177 60.943176-301.698894 301.698893L428.940384 513.075641z" p-id="4759"></path><path d="M730.496772 814.924547l60.943176-60.943176-301.698893-301.698893L428.797879 513.225654z" p-id="4760"></path><path d="M298.666667 213.333333h85.333333v597.333334H298.666667z" p-id="4761"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.firstBtnNode.localName}.${this.DOM_CONFIG.firstBtnNode.className}`)},prevBtnNode:{localName:"a",className:"pg-prev",svgHTML:'<svg t="1694497840770" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5272" width="20"><path d="M620.322607 151.04875l60.943176 60.943176-362.038672 362.038672L258.283935 513.087422z" p-id="5273"></path><path d="M620.180101 875.252545l60.943177-60.943176-362.038672-362.038672L258.141429 513.213873z" p-id="5274"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.prevBtnNode.localName}.${this.DOM_CONFIG.prevBtnNode.className}`)},nextBtnNode:{localName:"a",className:"pg-next",svgHTML:'<svg t="1694497949481" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5465" width="20"><path d="M403.399239 151.02258l-60.943177 60.943177 362.038672 362.038672L765.437911 513.061252z" p-id="5466"></path><path d="M403.576858 875.263008l-60.943176-60.943176 362.038672-362.038672L765.61553 513.224336z" p-id="5467"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.nextBtnNode.localName}.${this.DOM_CONFIG.nextBtnNode.className}`)},lastBtnNode:{localName:"a",className:"pg-last",svgHTML:'<svg t="1694498035538" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2299" width="20"><path d="M516.266667 490.666667L256 230.4 315.733333 170.666667l320 320L315.733333 810.666667 256 750.933333l260.266667-260.266666zM678.4 170.666667h85.333333v640h-85.333333V170.666667z" p-id="2300"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.lastBtnNode.localName}.${this.DOM_CONFIG.lastBtnNode.className}`)},setAttributeWithPageId:(t,e)=>{t.setAttribute("page-id",String(e))},getAttributeWithPageId:t=>{const e=t?.getAttribute("page-id");return e?parseInt(e):null},hasAttributeWithPageId:t=>t.hasAttribute("page-id"),setAttributeWithCurrentPage:t=>{t.setAttribute("data-current-page","")},getAttributeWithCurrentPage:t=>(t||this.DOM_CONFIG.$pageWrapper.dom).querySelector("a[data-current-page]"),hasAttributeWithCurrentPage:t=>t.hasAttribute("data-current-page"),removeAttributeWithCurrentPage:t=>{t.removeAttribute("data-current-page")},setAttributeWithDisabled:t=>{t.setAttribute("disabled","true")},removeAllAttributeWithDisabled:t=>{(t||this.DOM_CONFIG.$pageWrapper.dom)?.querySelectorAll("a[class][disabled]").forEach(t=>{t.removeAttribute("disabled")})},getFirstPageNode:t=>(t||this.DOM_CONFIG.$pageWrapper.dom).querySelector("a[page-id='1']"),getLastPageNode:t=>(t||this.DOM_CONFIG.$pageWrapper.dom).querySelector(`a[page-id='${this.PAGE_CONFIG.maxPage}']`),getAllPageNode:t=>Array.from((t||this.DOM_CONFIG.$pageWrapper.dom).querySelectorAll("a[page-id]"))};constructor(t){this.CONFIG={data:[],pageShowDataMaxCount:5,pageMaxStep:3,currentPage:1,pageChangeCallBack:function(){},prevBtn:{enable:!0,callBack:function(){}},nextBtn:{enable:!0,callBack:function(){}},firstBtn:{enable:!0,callBack:function(){}},lastBtn:{enable:!0,callBack:function(){}}},this.changeConfig(t)}hide(t=this.DOM_CONFIG.$pageWrapper.dom){t&&(t.style.display="none")}show(t=this.DOM_CONFIG.$pageWrapper.dom){t&&(t.style.display="")}isHide(t=this.DOM_CONFIG.$pageWrapper.dom){if(t)return t.style.display.includes("none")}destory(){const t=this.DOM_CONFIG.$pageWrapper.dom;if(!t)return;const e=t.parentElement;e?.removeChild?.(t),this.DOM_CONFIG.$pageWrapper.dom=null}addCSS(e=document.head){const i=document.createElement("style");i.setAttribute("type","text/css");const a=`@charset "utf-8";\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} {\n\t\t\ttext-align: center;\n\t\t\tdisplay: inline-block;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.firstBtnNode.className},\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.prevBtnNode.className},\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.nextBtnNode.className},\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.lastBtnNode.className} {\n\t\t\tfont-family: Arial, sans-serif;\n\t\t\tcolor: #333;\n\t\t\tfont-size: 22px;\n\t\t\tfill: currentColor;\n\t\t\tdisplay: inline-flex;\n\t\t\tjustify-content: center;\n\t\t\talign-items: center;\n\t\t\ttext-decoration: none;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a,\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} span {\n\t\t\twidth: 45px;\n\t\t\theight: 40px;\n\t\t\tborder: 1px solid #ebebeb;\n\t\t\tmargin-left: -1px;\n\t\t\tcolor: #000000;\n\t\t\tline-height: 40px;\n\t\t\tfloat: left;\n\t\t\tfont-size: 15px;\n\t\t\ttext-decoration: none;\n\t\t\tmargin: 0 2px;\n\t\t\tborder-radius: 6px;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a:hover,\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} span:hover {\n\t\t\tborder-color: #3897cd;\n\t\t\tcolor: #3897cd;\n\t\t\tposition: relative;\n\t\t\tz-index: 1;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a {\n\t\t\tcursor: pointer;\n\t\t\tuser-select: none;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a[data-current-page] {\n\t\t\tbackground-color: #222a35;\n\t\t\tcolor: #fff;\n\t\t\tborder-color: #ebebeb;\n\t\t\tposition: relative;\n\t\t\tz-index: 1;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.firstBtnNode.className}[disabled="true"],\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.prevBtnNode.className}[disabled="true"],\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.nextBtnNode.className}[disabled="true"],\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.lastBtnNode.className}[disabled="true"]{\n\t\t\tcursor: not-allowed;\n\t\t\tborder: 1px solid transparent;\n\t\t\tcolor: #c9c9c9;\n\t\t}\n\t\t`;t.setSafeHTML(i,a),e.appendChild(i)}createDataPagingWrapper(){const e=document.createElement(this.DOM_CONFIG.$pageWrapper.localName);this.DOM_CONFIG.$pageWrapper.dom=e,e.id=this.DOM_CONFIG.$pageWrapper.id;const i=document.createElement(this.DOM_CONFIG.firstBtnNode.localName);t.setSafeHTML(i,this.DOM_CONFIG.firstBtnNode.svgHTML);const a=document.createElement(this.DOM_CONFIG.prevBtnNode.localName);t.setSafeHTML(a,this.DOM_CONFIG.prevBtnNode.svgHTML);const s=document.createElement(this.DOM_CONFIG.nextBtnNode.localName);t.setSafeHTML(s,this.DOM_CONFIG.nextBtnNode.svgHTML);const r=document.createElement(this.DOM_CONFIG.lastBtnNode.localName);if(t.setSafeHTML(r,this.DOM_CONFIG.lastBtnNode.svgHTML),i.className=this.DOM_CONFIG.firstBtnNode.className,a.className=this.DOM_CONFIG.prevBtnNode.className,s.className=this.DOM_CONFIG.nextBtnNode.className,r.className=this.DOM_CONFIG.lastBtnNode.className,this.PAGE_CONFIG.maxPage=Math.ceil(this.CONFIG.data.length/this.CONFIG.pageShowDataMaxCount),this.CONFIG.currentPage<1?this.CONFIG.currentPage=1:this.CONFIG.currentPage>this.PAGE_CONFIG.maxPage&&(this.CONFIG.currentPage=this.PAGE_CONFIG.maxPage),this.PAGE_CONFIG.maxPage<2)return e;this.CONFIG.firstBtn.enable&&(this.setFirstBtnClickEvent(i,e),e.appendChild(i)),this.CONFIG.prevBtn.enable&&(this.setPrevBtnClickEvent(a,e),e.appendChild(a));let n=this.CONFIG.currentPage;if(this.CONFIG.pageMaxStep>this.PAGE_CONFIG.maxPage)for(let t=n;t<=this.PAGE_CONFIG.maxPage;t++){const i=document.createElement("a");this.DOM_CONFIG.setAttributeWithPageId(i,t),i.innerText=String(t),this.CONFIG.currentPage===t&&this.DOM_CONFIG.setAttributeWithCurrentPage(i),this.setPageBtnClickEvent(i,e),e.appendChild(i)}else if(n+this.CONFIG.pageMaxStep>this.PAGE_CONFIG.maxPage){n=this.PAGE_CONFIG.maxPage;const t=[];for(let i=0;i<this.CONFIG.pageMaxStep;i++){const i=document.createElement("a");this.DOM_CONFIG.setAttributeWithPageId(i,n),i.innerText=String(n),this.CONFIG.currentPage===n&&this.DOM_CONFIG.setAttributeWithCurrentPage(i),this.setPageBtnClickEvent(i,e),t.push(i),n--}t.reverse(),t.forEach(t=>{e.appendChild(t)})}else for(let t=0;t<this.CONFIG.pageMaxStep;t++){const t=document.createElement("a");this.DOM_CONFIG.setAttributeWithPageId(t,n),t.innerText=String(n),this.CONFIG.currentPage===n&&this.DOM_CONFIG.setAttributeWithCurrentPage(t),this.setPageBtnClickEvent(t,e),e.appendChild(t),n++}return this.CONFIG.nextBtn.enable&&(this.setNextBtnClickEvent(s,e),e.appendChild(s)),this.CONFIG.lastBtn.enable&&(this.setLastBtnClickEvent(r,e),e.appendChild(r)),1===this.CONFIG.currentPage?(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get())):this.CONFIG.currentPage===this.PAGE_CONFIG.maxPage&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get())),e}setFirstBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(1===this.DOM_CONFIG.getAttributeWithPageId(i))return;await(this.CONFIG.firstBtn?.callBack?.(t));const a=this.DOM_CONFIG.getAllPageNode(e);for(let t=0;t<this.CONFIG.pageMaxStep;t++){const e=a[t];null!=e&&(0===t?this.DOM_CONFIG.setAttributeWithCurrentPage(e):this.DOM_CONFIG.removeAttributeWithCurrentPage(e),this.DOM_CONFIG.setAttributeWithPageId(e,t+1),e.innerText=String(t+1))}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getFirstPageNode(e)&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get())),this.CONFIG.pageChangeCallBack(1)})}setPrevBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(1===this.DOM_CONFIG.getAttributeWithPageId(i))return;await(this.CONFIG.prevBtn?.callBack?.(t));const a=i.previousElementSibling;if(a&&this.DOM_CONFIG.hasAttributeWithPageId(a))a.click();else{this.DOM_CONFIG.getAllPageNode(e).forEach(t=>{let e=this.DOM_CONFIG.getAttributeWithPageId(t);e--,this.DOM_CONFIG.setAttributeWithPageId(t,e),t.innerText=String(e)}),this.CONFIG.pageChangeCallBack(this.PAGE_CONFIG.currentPage())}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getFirstPageNode(e)&&1==this.PAGE_CONFIG.currentPage()&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get()))})}setNextBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(this.DOM_CONFIG.getAttributeWithPageId(i)===this.PAGE_CONFIG.maxPage)return;await(this.CONFIG.nextBtn?.callBack?.(t));const a=i.nextElementSibling;if(a&&this.DOM_CONFIG.hasAttributeWithPageId(a))a.click();else{this.DOM_CONFIG.getAllPageNode(e).forEach(t=>{let e=this.DOM_CONFIG.getAttributeWithPageId(t);e++,e>this.PAGE_CONFIG.maxPage||(this.DOM_CONFIG.setAttributeWithPageId(t,e),t.innerText=String(e))}),this.CONFIG.pageChangeCallBack(this.PAGE_CONFIG.currentPage())}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getLastPageNode()&&this.PAGE_CONFIG.currentPage()==this.PAGE_CONFIG.maxPage&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get()))})}setLastBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(this.DOM_CONFIG.getAttributeWithPageId(i)===this.PAGE_CONFIG.maxPage)return;await(this.CONFIG.lastBtn?.callBack?.(t));const a=Array.from(this.DOM_CONFIG.getAllPageNode(e));a.reverse();let s=this.PAGE_CONFIG.maxPage,r=0;for(;!(this.PAGE_CONFIG.maxPage-s>3);){const t=a[r];if(null==t)break;0===r?this.DOM_CONFIG.setAttributeWithCurrentPage(t):this.DOM_CONFIG.removeAttributeWithCurrentPage(t),this.DOM_CONFIG.setAttributeWithPageId(t,s),t.innerText=String(s),s--,r++}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get()),this.CONFIG.pageChangeCallBack(this.PAGE_CONFIG.maxPage)})}setPageBtnClickEvent(t,e){t.addEventListener("click",async()=>{const i=t,a=this.DOM_CONFIG.getAllPageNode(e);for(const t of a)if(t==i){if(!this.DOM_CONFIG.hasAttributeWithCurrentPage(i)){this.DOM_CONFIG.setAttributeWithCurrentPage(i);const t=this.PAGE_CONFIG.currentPage();await(this.CONFIG?.pageChangeCallBack?.(t))}}else this.DOM_CONFIG.removeAttributeWithCurrentPage(t);this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getFirstPageNode(e)&&1==this.PAGE_CONFIG.currentPage()&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get())),this.DOM_CONFIG.getLastPageNode()&&this.PAGE_CONFIG.currentPage()==this.PAGE_CONFIG.maxPage&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get()))})}append(t){const e=this.isHide();this.destory();const i=this.createDataPagingWrapper();e&&this.hide(i),t.appendChild(i)}after(t){const e=this.isHide(),i=t.parentElement,a=t.nextSibling;this.destory();const s=this.createDataPagingWrapper();e&&this.hide(s),!i||a?t.after(s):i.insertBefore(s,a)}changeConfig(t){Object.assign(this.CONFIG,t)}refresh(t){this.CONFIG.data=[],this.CONFIG.data=t;let e=this.PAGE_CONFIG.currentPage();const i=Math.ceil(t.length/this.CONFIG.pageShowDataMaxCount);e>i&&(e=i),this.CONFIG.currentPage=e;const a=this.DOM_CONFIG.$pageWrapper.dom;a&&this.after(a)}}});
1
+ !function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t="undefined"!=typeof globalThis?globalThis:t||self).DataPaging=e()}(this,function(){"use strict";const t={setSafeHTML(t,e){try{t.innerHTML=e}catch{if(!globalThis.trustedTypes)throw new Error("PagingUtils trustedTypes is not defined");{const i=globalThis.trustedTypes.createPolicy("safe-innerHTML",{createHTML:t=>t});t.innerHTML=i.createHTML(e)}}}};return class{version="0.0.5";CONFIG;PAGE_CONFIG={currentPage:()=>{const t=this.DOM_CONFIG.getAttributeWithCurrentPage();return this.DOM_CONFIG.getAttributeWithPageId(t)??1},maxPage:1};DOM_CONFIG={$pageWrapper:{localName:"div",id:"data-paging-wrapper",dom:null},firstBtnNode:{localName:"a",className:"pg-first",svgHTML:'<svg t="1694497357294" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="4758" width="20"><path d="M730.639277 211.376748l60.943177 60.943176-301.698894 301.698893L428.940384 513.075641z" p-id="4759"></path><path d="M730.496772 814.924547l60.943176-60.943176-301.698893-301.698893L428.797879 513.225654z" p-id="4760"></path><path d="M298.666667 213.333333h85.333333v597.333334H298.666667z" p-id="4761"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.firstBtnNode.localName}.${this.DOM_CONFIG.firstBtnNode.className}`)},prevBtnNode:{localName:"a",className:"pg-prev",svgHTML:'<svg t="1694497840770" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5272" width="20"><path d="M620.322607 151.04875l60.943176 60.943176-362.038672 362.038672L258.283935 513.087422z" p-id="5273"></path><path d="M620.180101 875.252545l60.943177-60.943176-362.038672-362.038672L258.141429 513.213873z" p-id="5274"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.prevBtnNode.localName}.${this.DOM_CONFIG.prevBtnNode.className}`)},nextBtnNode:{localName:"a",className:"pg-next",svgHTML:'<svg t="1694497949481" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="5465" width="20"><path d="M403.399239 151.02258l-60.943177 60.943177 362.038672 362.038672L765.437911 513.061252z" p-id="5466"></path><path d="M403.576858 875.263008l-60.943176-60.943176 362.038672-362.038672L765.61553 513.224336z" p-id="5467"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.nextBtnNode.localName}.${this.DOM_CONFIG.nextBtnNode.className}`)},lastBtnNode:{localName:"a",className:"pg-last",svgHTML:'<svg t="1694498035538" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2299" width="20"><path d="M516.266667 490.666667L256 230.4 315.733333 170.666667l320 320L315.733333 810.666667 256 750.933333l260.266667-260.266666zM678.4 170.666667h85.333333v640h-85.333333V170.666667z" p-id="2300"></path></svg>',get:()=>this.DOM_CONFIG.$pageWrapper.dom.querySelector(`${this.DOM_CONFIG.lastBtnNode.localName}.${this.DOM_CONFIG.lastBtnNode.className}`)},setAttributeWithPageId:(t,e)=>{t.setAttribute("page-id",String(e))},getAttributeWithPageId:t=>{const e=t?.getAttribute("page-id");return e?parseInt(e):null},hasAttributeWithPageId:t=>t.hasAttribute("page-id"),setAttributeWithCurrentPage:t=>{t.setAttribute("data-current-page","")},getAttributeWithCurrentPage:t=>(t||this.DOM_CONFIG.$pageWrapper.dom).querySelector("a[data-current-page]"),hasAttributeWithCurrentPage:t=>t.hasAttribute("data-current-page"),removeAttributeWithCurrentPage:t=>{t.removeAttribute("data-current-page")},setAttributeWithDisabled:t=>{t.setAttribute("disabled","true")},removeAllAttributeWithDisabled:t=>{(t||this.DOM_CONFIG.$pageWrapper.dom)?.querySelectorAll("a[class][disabled]").forEach(t=>{t.removeAttribute("disabled")})},getFirstPageNode:t=>(t||this.DOM_CONFIG.$pageWrapper.dom).querySelector("a[page-id='1']"),getLastPageNode:t=>(t||this.DOM_CONFIG.$pageWrapper.dom).querySelector(`a[page-id='${this.PAGE_CONFIG.maxPage}']`),getAllPageNode:t=>Array.from((t||this.DOM_CONFIG.$pageWrapper.dom).querySelectorAll("a[page-id]"))};constructor(t){this.CONFIG={data:[],pageShowDataMaxCount:5,pageMaxStep:3,currentPage:1,pageChangeCallBack:function(){},prevBtn:{enable:!0,callBack:function(){}},nextBtn:{enable:!0,callBack:function(){}},firstBtn:{enable:!0,callBack:function(){}},lastBtn:{enable:!0,callBack:function(){}}},this.changeConfig(t)}hide(t=this.DOM_CONFIG.$pageWrapper.dom){t&&(t.style.display="none")}show(t=this.DOM_CONFIG.$pageWrapper.dom){t&&(t.style.display="")}isHide(t=this.DOM_CONFIG.$pageWrapper.dom){if(t)return t.style.display.includes("none")}destory(){const t=this.DOM_CONFIG.$pageWrapper.dom;if(!t)return;const e=t.parentElement;e?.removeChild?.(t),this.DOM_CONFIG.$pageWrapper.dom=null}addCSS(e=document.head){const i=document.createElement("style");i.setAttribute("type","text/css");const a=`@charset "utf-8";\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} {\n\t\t\ttext-align: center;\n\t\t\tdisplay: inline-block;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.firstBtnNode.className},\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.prevBtnNode.className},\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.nextBtnNode.className},\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} .${this.DOM_CONFIG.lastBtnNode.className} {\n\t\t\tfont-family: Arial, sans-serif;\n\t\t\tcolor: #333;\n\t\t\tfont-size: 22px;\n\t\t\tfill: currentColor;\n\t\t\tdisplay: inline-flex;\n\t\t\tjustify-content: center;\n\t\t\talign-items: center;\n\t\t\ttext-decoration: none;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a,\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} span {\n\t\t\twidth: 45px;\n\t\t\theight: 40px;\n\t\t\tborder: 1px solid #ebebeb;\n\t\t\tmargin-left: -1px;\n\t\t\tcolor: #000000;\n\t\t\tline-height: 40px;\n\t\t\tfloat: left;\n\t\t\tfont-size: 15px;\n\t\t\ttext-decoration: none;\n\t\t\tmargin: 0 2px;\n\t\t\tborder-radius: 6px;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a:hover,\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} span:hover {\n\t\t\tborder-color: #3897cd;\n\t\t\tcolor: #3897cd;\n\t\t\tposition: relative;\n\t\t\tz-index: 1;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a {\n\t\t\tcursor: pointer;\n\t\t\tuser-select: none;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a[data-current-page] {\n\t\t\tbackground-color: #222a35;\n\t\t\tcolor: #fff;\n\t\t\tborder-color: #ebebeb;\n\t\t\tposition: relative;\n\t\t\tz-index: 1;\n\t\t}\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.firstBtnNode.className}[disabled="true"],\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.prevBtnNode.className}[disabled="true"],\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.nextBtnNode.className}[disabled="true"],\n\t\t#${this.DOM_CONFIG.$pageWrapper.id} a.${this.DOM_CONFIG.lastBtnNode.className}[disabled="true"]{\n\t\t\tcursor: not-allowed;\n\t\t\tborder: 1px solid transparent;\n\t\t\tcolor: #c9c9c9;\n\t\t}\n\t\t`;t.setSafeHTML(i,a),e.appendChild(i)}createDataPagingWrapper(){const e=document.createElement(this.DOM_CONFIG.$pageWrapper.localName);this.DOM_CONFIG.$pageWrapper.dom=e,e.id=this.DOM_CONFIG.$pageWrapper.id;const i=document.createElement(this.DOM_CONFIG.firstBtnNode.localName);t.setSafeHTML(i,this.DOM_CONFIG.firstBtnNode.svgHTML);const a=document.createElement(this.DOM_CONFIG.prevBtnNode.localName);t.setSafeHTML(a,this.DOM_CONFIG.prevBtnNode.svgHTML);const s=document.createElement(this.DOM_CONFIG.nextBtnNode.localName);t.setSafeHTML(s,this.DOM_CONFIG.nextBtnNode.svgHTML);const r=document.createElement(this.DOM_CONFIG.lastBtnNode.localName);if(t.setSafeHTML(r,this.DOM_CONFIG.lastBtnNode.svgHTML),i.className=this.DOM_CONFIG.firstBtnNode.className,a.className=this.DOM_CONFIG.prevBtnNode.className,s.className=this.DOM_CONFIG.nextBtnNode.className,r.className=this.DOM_CONFIG.lastBtnNode.className,this.PAGE_CONFIG.maxPage=Math.ceil(this.CONFIG.data.length/this.CONFIG.pageShowDataMaxCount),this.CONFIG.currentPage<1?this.CONFIG.currentPage=1:this.CONFIG.currentPage>this.PAGE_CONFIG.maxPage&&(this.CONFIG.currentPage=this.PAGE_CONFIG.maxPage),this.PAGE_CONFIG.maxPage<2)return e;this.CONFIG.firstBtn.enable&&(this.setFirstBtnClickEvent(i,e),e.appendChild(i)),this.CONFIG.prevBtn.enable&&(this.setPrevBtnClickEvent(a,e),e.appendChild(a));let n=this.CONFIG.currentPage;if(this.CONFIG.pageMaxStep>this.PAGE_CONFIG.maxPage)for(let t=n;t<=this.PAGE_CONFIG.maxPage;t++){const i=document.createElement("a");this.DOM_CONFIG.setAttributeWithPageId(i,t),i.innerText=String(t),this.CONFIG.currentPage===t&&this.DOM_CONFIG.setAttributeWithCurrentPage(i),this.setPageBtnClickEvent(i,e),e.appendChild(i)}else if(n+this.CONFIG.pageMaxStep>this.PAGE_CONFIG.maxPage){n=this.PAGE_CONFIG.maxPage;const t=[];for(let i=0;i<this.CONFIG.pageMaxStep;i++){const i=document.createElement("a");this.DOM_CONFIG.setAttributeWithPageId(i,n),i.innerText=String(n),this.CONFIG.currentPage===n&&this.DOM_CONFIG.setAttributeWithCurrentPage(i),this.setPageBtnClickEvent(i,e),t.push(i),n--}t.reverse(),t.forEach(t=>{e.appendChild(t)})}else for(let t=0;t<this.CONFIG.pageMaxStep;t++){const t=document.createElement("a");this.DOM_CONFIG.setAttributeWithPageId(t,n),t.innerText=String(n),this.CONFIG.currentPage===n&&this.DOM_CONFIG.setAttributeWithCurrentPage(t),this.setPageBtnClickEvent(t,e),e.appendChild(t),n++}return this.CONFIG.nextBtn.enable&&(this.setNextBtnClickEvent(s,e),e.appendChild(s)),this.CONFIG.lastBtn.enable&&(this.setLastBtnClickEvent(r,e),e.appendChild(r)),1===this.CONFIG.currentPage?(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get())):this.CONFIG.currentPage===this.PAGE_CONFIG.maxPage&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get())),e}setFirstBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(1===this.DOM_CONFIG.getAttributeWithPageId(i))return;await(this.CONFIG.firstBtn?.callBack?.(t));const a=this.DOM_CONFIG.getAllPageNode(e);for(let t=0;t<this.CONFIG.pageMaxStep;t++){const e=a[t];null!=e&&(0===t?this.DOM_CONFIG.setAttributeWithCurrentPage(e):this.DOM_CONFIG.removeAttributeWithCurrentPage(e),this.DOM_CONFIG.setAttributeWithPageId(e,t+1),e.innerText=String(t+1))}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getFirstPageNode(e)&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get())),this.CONFIG.pageChangeCallBack(1)})}setPrevBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(1===this.DOM_CONFIG.getAttributeWithPageId(i))return;await(this.CONFIG.prevBtn?.callBack?.(t));const a=i.previousElementSibling;if(a&&this.DOM_CONFIG.hasAttributeWithPageId(a))a.click();else{this.DOM_CONFIG.getAllPageNode(e).forEach(t=>{let e=this.DOM_CONFIG.getAttributeWithPageId(t);e--,this.DOM_CONFIG.setAttributeWithPageId(t,e),t.innerText=String(e)}),this.CONFIG.pageChangeCallBack(this.PAGE_CONFIG.currentPage())}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getFirstPageNode(e)&&1==this.PAGE_CONFIG.currentPage()&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get()))})}setNextBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(this.DOM_CONFIG.getAttributeWithPageId(i)===this.PAGE_CONFIG.maxPage)return;await(this.CONFIG.nextBtn?.callBack?.(t));const a=i.nextElementSibling;if(a&&this.DOM_CONFIG.hasAttributeWithPageId(a))a.click();else{this.DOM_CONFIG.getAllPageNode(e).forEach(t=>{let e=this.DOM_CONFIG.getAttributeWithPageId(t);e++,e>this.PAGE_CONFIG.maxPage||(this.DOM_CONFIG.setAttributeWithPageId(t,e),t.innerText=String(e))}),this.CONFIG.pageChangeCallBack(this.PAGE_CONFIG.currentPage())}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getLastPageNode()&&this.PAGE_CONFIG.currentPage()==this.PAGE_CONFIG.maxPage&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get()))})}setLastBtnClickEvent(t,e){t.addEventListener("click",async t=>{const i=this.DOM_CONFIG.getAttributeWithCurrentPage();if(this.DOM_CONFIG.getAttributeWithPageId(i)===this.PAGE_CONFIG.maxPage)return;await(this.CONFIG.lastBtn?.callBack?.(t));const a=Array.from(this.DOM_CONFIG.getAllPageNode(e));a.reverse();let s=this.PAGE_CONFIG.maxPage,r=0;for(;!(this.PAGE_CONFIG.maxPage-s>3);){const t=a[r];if(null==t)break;0===r?this.DOM_CONFIG.setAttributeWithCurrentPage(t):this.DOM_CONFIG.removeAttributeWithCurrentPage(t),this.DOM_CONFIG.setAttributeWithPageId(t,s),t.innerText=String(s),s--,r++}this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get()),this.CONFIG.pageChangeCallBack(this.PAGE_CONFIG.maxPage)})}setPageBtnClickEvent(t,e){t.addEventListener("click",async()=>{const i=t,a=this.DOM_CONFIG.getAllPageNode(e);for(const t of a)if(t==i){if(!this.DOM_CONFIG.hasAttributeWithCurrentPage(i)){this.DOM_CONFIG.setAttributeWithCurrentPage(i);const t=this.PAGE_CONFIG.currentPage();await(this.CONFIG?.pageChangeCallBack?.(t))}}else this.DOM_CONFIG.removeAttributeWithCurrentPage(t);this.DOM_CONFIG.removeAllAttributeWithDisabled(e),this.DOM_CONFIG.getFirstPageNode(e)&&1==this.PAGE_CONFIG.currentPage()&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.firstBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.prevBtnNode.get())),this.DOM_CONFIG.getLastPageNode()&&this.PAGE_CONFIG.currentPage()==this.PAGE_CONFIG.maxPage&&(this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.nextBtnNode.get()),this.DOM_CONFIG.setAttributeWithDisabled(this.DOM_CONFIG.lastBtnNode.get()))})}append(t){const e=this.isHide();this.destory();const i=this.createDataPagingWrapper();e&&this.hide(i),t.appendChild(i)}after(t){const e=this.isHide(),i=t.parentElement,a=t.nextSibling;this.destory();const s=this.createDataPagingWrapper();e&&this.hide(s),!i||a?t.after(s):i.insertBefore(s,a)}changeConfig(t){Object.assign(this.CONFIG,t)}refresh(t){this.CONFIG.data=[],this.CONFIG.data=t;let e=this.PAGE_CONFIG.currentPage();const i=Math.ceil(t.length/this.CONFIG.pageShowDataMaxCount);e>i&&(e=i),this.CONFIG.currentPage=e;const a=this.DOM_CONFIG.$pageWrapper.dom;a&&this.after(a)}}});
2
2
  //# sourceMappingURL=index.umd.min.js.map
@@ -1,3 +1,3 @@
1
1
  import { Paging } from "./src";
2
2
  declare const DataPaging: typeof Paging;
3
- export default DataPaging;
3
+ export { DataPaging as default };
@@ -1,58 +1,58 @@
1
- export declare interface PagingStepButtonConfig {
2
- /**
3
- * 是否启用按钮
4
- * @default true
5
- */
6
- enable: boolean;
7
- /**
8
- * 点击回调
9
- */
10
- callBack?: (event: PointerEvent) => Promise<void> | void;
11
- }
12
-
13
- export declare interface PagingConfig<T> {
14
- /**
15
- * 数据源
16
- */
17
- data: T[];
18
- /**
19
- * 每一页显示的数据的最大数量
20
- * @default 5
21
- */
22
- pageShowDataMaxCount?: number;
23
- /**
24
- * 显示的最大的分页页码数量
25
- * @default 3
26
- */
27
- pageMaxStep?: number;
28
- /**
29
- * 当前显示的页码
30
- * @default 1
31
- */
32
- currentPage?: number;
33
- /**
34
- * 页码改变的回调
35
- */
36
- pageChangeCallBack: (
37
- /**
38
- * 当前的页码
39
- */
40
- page: number
41
- ) => Promise<void> | void;
42
- /**
43
- * 上一页按钮的配置
44
- */
45
- prevBtn?: PagingStepButtonConfig;
46
- /**
47
- * 下一页按钮的配置
48
- */
49
- nextBtn?: PagingStepButtonConfig;
50
- /**
51
- * 第一页按钮的配置
52
- */
53
- firstBtn?: PagingStepButtonConfig;
54
- /**
55
- * 最后一页按钮的配置
56
- */
57
- lastBtn?: PagingStepButtonConfig;
58
- }
1
+ export declare interface PagingStepButtonConfig {
2
+ /**
3
+ * 是否启用按钮
4
+ * @default true
5
+ */
6
+ enable: boolean;
7
+ /**
8
+ * 点击回调
9
+ */
10
+ callBack?: (event: PointerEvent) => Promise<void> | void;
11
+ }
12
+
13
+ export declare interface PagingConfig<T> {
14
+ /**
15
+ * 数据源
16
+ */
17
+ data: T[];
18
+ /**
19
+ * 每一页显示的数据的最大数量
20
+ * @default 5
21
+ */
22
+ pageShowDataMaxCount?: number;
23
+ /**
24
+ * 显示的最大的分页页码数量
25
+ * @default 3
26
+ */
27
+ pageMaxStep?: number;
28
+ /**
29
+ * 当前显示的页码
30
+ * @default 1
31
+ */
32
+ currentPage?: number;
33
+ /**
34
+ * 页码改变的回调
35
+ */
36
+ pageChangeCallBack: (
37
+ /**
38
+ * 当前的页码
39
+ */
40
+ page: number
41
+ ) => Promise<void> | void;
42
+ /**
43
+ * 上一页按钮的配置
44
+ */
45
+ prevBtn?: PagingStepButtonConfig;
46
+ /**
47
+ * 下一页按钮的配置
48
+ */
49
+ nextBtn?: PagingStepButtonConfig;
50
+ /**
51
+ * 第一页按钮的配置
52
+ */
53
+ firstBtn?: PagingStepButtonConfig;
54
+ /**
55
+ * 最后一页按钮的配置
56
+ */
57
+ lastBtn?: PagingStepButtonConfig;
58
+ }
package/index.ts CHANGED
@@ -1,4 +1,5 @@
1
- import { Paging } from "./src";
2
-
3
- const DataPaging = Paging;
4
- export default DataPaging;
1
+ import { Paging } from "./src";
2
+
3
+ const DataPaging = Paging;
4
+
5
+ export { DataPaging as default };
package/package.json CHANGED
@@ -1,8 +1,22 @@
1
1
  {
2
2
  "name": "@whitesev/data-paging",
3
- "version": "0.0.4",
4
- "type": "module",
3
+ "version": "0.0.5",
5
4
  "description": "数据分页导航UI组件",
5
+ "keywords": [
6
+ "ScriptCat",
7
+ "TamperMonkey",
8
+ "VioletMonkey",
9
+ "javascript",
10
+ "typescript"
11
+ ],
12
+ "license": "MIT",
13
+ "author": "WhiteSev",
14
+ "files": [
15
+ "dist",
16
+ "src",
17
+ "./index.ts"
18
+ ],
19
+ "type": "module",
6
20
  "main": "dist/index.cjs.js",
7
21
  "module": "dist/index.esm.js",
8
22
  "types": "dist/types/index.d.ts",
@@ -11,54 +25,43 @@
11
25
  "./dist/*": "./dist/*",
12
26
  "./package.json": "./package.json",
13
27
  ".": {
28
+ "types": "./dist/types/index.d.ts",
14
29
  "import": "./dist/index.esm.js",
15
- "require": "./dist/index.cjs.js",
16
- "types": "./dist/types/index.d.ts"
30
+ "require": "./dist/index.cjs.js"
17
31
  }
18
32
  },
19
- "files": [
20
- "dist",
21
- "src",
22
- "./index.ts"
23
- ],
24
33
  "publishConfig": {
25
- "registry": "https://registry.npmjs.org/",
26
- "access": "public"
34
+ "access": "public",
35
+ "registry": "https://registry.npmjs.org/"
27
36
  },
28
- "keywords": [
29
- "javascript",
30
- "typescript",
31
- "TamperMonkey",
32
- "VioletMonkey",
33
- "ScriptCat"
34
- ],
35
- "author": "WhiteSev",
36
- "license": "MIT",
37
37
  "devDependencies": {
38
- "@eslint/js": "^9.38.0",
39
- "@rollup/plugin-commonjs": "^28.0.9",
38
+ "@eslint/js": "^9.39.1",
39
+ "@oxlint/migrate": "^1.46.0",
40
+ "@rollup/plugin-commonjs": "^29.0.0",
40
41
  "@rollup/plugin-json": "^6.1.0",
41
42
  "@rollup/plugin-node-resolve": "^16.0.3",
42
43
  "@rollup/plugin-terser": "^0.4.4",
43
44
  "@rollup/plugin-typescript": "^12.3.0",
44
45
  "browserslist": "^4.27.0",
45
- "caniuse-lite": "^1.0.30001751",
46
- "eslint": "^9.38.0",
46
+ "caniuse-lite": "^1.0.30001770",
47
+ "eslint": "^9.39.1",
47
48
  "eslint-config-prettier": "^10.1.8",
48
49
  "eslint-plugin-compat": "^6.0.2",
49
50
  "eslint-plugin-prettier": "^5.5.4",
50
- "globals": "^16.4.0",
51
+ "globals": "^17.3.0",
52
+ "oxfmt": "^0.32.0",
53
+ "oxlint": "^1.46.0",
51
54
  "rollup": "^4.52.5",
52
55
  "rollup-plugin-clear": "^2.0.7",
53
56
  "tslib": "^2.8.1",
54
57
  "typescript": "^5.9.3",
55
- "typescript-eslint": "^8.46.2"
58
+ "typescript-eslint": "^8.46.3"
56
59
  },
57
60
  "scripts": {
58
- "lint": "eslint .",
59
- "lint:fix": "eslint . --fix",
60
- "format": "prettier . --write",
61
- "dev": "pnpm run format && pnpm run lint && rollup -c -w",
61
+ "lint": "oxlint .",
62
+ "lint:fix": "oxlint . --fix",
63
+ "format": "oxfmt . --write",
64
+ "dev": "vue-tsc --noEmit && vite --force",
62
65
  "build": "pnpm run format && pnpm run lint && rollup -c"
63
66
  }
64
67
  }
package/src/config.ts CHANGED
@@ -1,27 +1,27 @@
1
- import type { PagingConfig } from "./types/config";
2
-
3
- export const PagingDefaultConfig = <T>(): Required<PagingConfig<T>> => {
4
- return {
5
- data: [],
6
- pageShowDataMaxCount: 5,
7
- pageMaxStep: 3,
8
- currentPage: 1,
9
- pageChangeCallBack: function () {},
10
- prevBtn: {
11
- enable: true,
12
- callBack: function () {},
13
- },
14
- nextBtn: {
15
- enable: true,
16
- callBack: function () {},
17
- },
18
- firstBtn: {
19
- enable: true,
20
- callBack: function () {},
21
- },
22
- lastBtn: {
23
- enable: true,
24
- callBack: function () {},
25
- },
26
- };
27
- };
1
+ import type { PagingConfig } from "./types/config";
2
+
3
+ export const PagingDefaultConfig = <T>(): Required<PagingConfig<T>> => {
4
+ return {
5
+ data: [],
6
+ pageShowDataMaxCount: 5,
7
+ pageMaxStep: 3,
8
+ currentPage: 1,
9
+ pageChangeCallBack: function () {},
10
+ prevBtn: {
11
+ enable: true,
12
+ callBack: function () {},
13
+ },
14
+ nextBtn: {
15
+ enable: true,
16
+ callBack: function () {},
17
+ },
18
+ firstBtn: {
19
+ enable: true,
20
+ callBack: function () {},
21
+ },
22
+ lastBtn: {
23
+ enable: true,
24
+ callBack: function () {},
25
+ },
26
+ };
27
+ };