Greasy Fork

ClassSyntax

Library for simplifying code logic and syntax (Class Type)

当前为 2024-12-04 提交的版本,查看 最新版本

此脚本不应直接安装。它是供其他脚本使用的外部库,要使用该库请加入元指令 // @require https://update.greasyfork.icu/scripts/487608/1496878/ClassSyntax.js

// ==UserScript==
// @name         ClassSyntax
// @version      2024/12/05
// @author       Canaan HS
// @description  Library for simplifying code logic and syntax (Class Type)
// @namespace    https://greasyfork.org/users/989635
// @match        *://*/*
// @license      MIT
// ==/UserScript==
class Syntax{constructor(){this.Mark={};this.Parser=new DOMParser;this.ListenerRecord=new Map;this.Type=a=>Object.prototype.toString.call(a).slice(8,-1);this.Print={log:a=>console.log(a),warn:a=>console.warn(a),trace:a=>console.trace(a),error:a=>console.error(a),count:a=>console.count(a)};this.Query={Match:/[ .#=:]/,"#":(a,b)=>a.getElementById(b.slice(1)),".":(a,b,c)=>{a=a.getElementsByClassName(b.slice(1));return c?[...a]:a[0]},tag:(a,b,c)=>{a=a.getElementsByTagName(b);return c?[...a]:a[0]},"default":(a,b,c)=>c?a.querySelectorAll(b):a.querySelector(b)};this.TemplateMatch={Process:(a,b,c=null)=>{a=a[b.toLowerCase()];return"Function"===this.Type(a)?a(c):void 0!==a?a:"None"}};this.StoreMatch={verify:a=>void 0!==a?a:!1,d:a=>GM_deleteValue(a),a:()=>this.StoreMatch.verify(GM_listValues()),s:(a,b)=>GM_setValue(a,b),g:(a,b)=>this.StoreMatch.verify(GM_getValue(a,b)),sj:(a,b)=>GM_setValue(a,JSON.stringify(b,null,4)),gj:(a,b)=>JSON.parse(this.StoreMatch.verify(GM_getValue(a,b)))};this.StorageMatch={String:(a,b,c)=>null!=c?(a.setItem(b,JSON.stringify(c)),!0):JSON.parse(b),Number:(a,b,c)=>null!=c?(a.setItem(b,JSON.stringify(c)),!0):Number(b),Array:(a,b,c)=>null!=c?(a.setItem(b,JSON.stringify(c)),!0):(b=JSON.parse(b),Array.isArray(b[0])?new Map(b):b),Object:(a,b,c)=>null!=c?(a.setItem(b,JSON.stringify(c)),!0):JSON.parse(b),Boolean:(a,b,c)=>null!=c?(a.setItem(b,JSON.stringify(c)),!0):JSON.parse(b),Date:(a,b,c)=>null!=c?(a.setItem(b,JSON.stringify(c)),!0):new Date(b),Map:(a,b,c)=>(a.setItem(b,JSON.stringify([...c])),!0)};this.Device={sX:()=>window.scrollX,sY:()=>window.scrollY,iW:()=>window.innerWidth,iH:()=>window.innerHeight,_Type:void 0,Url:location.href,Orig:location.origin,Host:location.hostname,Path:location.pathname,Lang:navigator.language,Agen:navigator.userAgent,Type:function(){return this._Type=this._Type?this._Type:this._Type=/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(this.Agen)||768>this.iW?"Mobile":"Desktop"}}}$$(a,{all:b=!1,root:c=document}={}){const d=this.Query.Match.test(a)?this.Query.Match.test(a.slice(1))?"default":a[0]:"tag";return this.Query[d](c,a,b)}Sleep(a){return new Promise(b=>setTimeout(b,a))}async Log(a=null,b="print",{dev:c=!0,type:d="log",collapsed:e=!0}={}){c&&(c=this.Print[d]||this.Print.log,null==a?c(b):(e?console.groupCollapsed(a):console.group(a),c(b),console.groupEnd()))}async AddStyle(a,b="New-Style",c=!0){let d=document.getElementById(b);if(!d)d=document.createElement("style"),d.id=b,document.head.appendChild(d);else if(!c)return;d.textContent+=a}async AddScript(a,b="New-Script",c=!0){let d=document.getElementById(b);if(!d)d=document.createElement("script"),d.id=b,document.head.appendChild(d);else if(!c)return;d.textContent+=a}async Listen(a,b,c,d={},e=null){try{a.addEventListener(b,c,d),e&&e(!0)}catch{e&&e(!1)}}async AddListener(a,b,c,d={}){const {mark:e,...m}=d;d=e??a;const k=this.ListenerRecord.get(d);k?.has(b)||(a.addEventListener(b,c,m),k||this.ListenerRecord.set(d,new Map),this.ListenerRecord.get(d).set(b,c))}async RemovListener(a,b){const c=this.ListenerRecord.get(a)?.get(b);c&&(a.removeEventListener(b,c),this.ListenerRecord.get(a).delete(b))}async Observer(a,b,{mark:c=!1,throttle:d=0,subtree:e=!0,childList:m=!0,attributes:k=!0,characterData:g=!1}={},l=null){if(c){if(this.Mark[c])return;this.Mark[c]=!0}c={subtree:e,childList:m,attributes:k,characterData:g};d=new MutationObserver(this.Throttle(()=>{b()},d));d.observe(a,c);l&&l({ob:d,op:c})}async WaitElem(a,b,{raf:c=!1,all:d=!1,timeout:e=8,throttle:m=50,subtree:k=!0,childList:g=!0,attributes:l=!1,characterData:r=!1,timeoutResult:p=!1,object:u=document.body}={}){const t=this;return new Promise((w,x)=>{const v=async function(){let h,f,q;if(c){let n;const y=()=>{f=d?document.querySelectorAll(a):document.querySelector(a);(q=d?0<f.length:f)?(cancelAnimationFrame(n),clearTimeout(h),b&&b(f),w(f)):n=requestAnimationFrame(y)};n=requestAnimationFrame(y);h=setTimeout(()=>{cancelAnimationFrame(n);p&&(b&&b(f),w(f))},1E3*e)}else{const n=new MutationObserver(t.Throttle(()=>{f=d?document.querySelectorAll(a):document.querySelector(a);if(q=d?0<f.length:f)n.disconnect(),clearTimeout(h),b&&b(f),w(f)},m));n.observe(u,{subtree:k,childList:g,attributes:l,characterData:r});h=setTimeout(()=>{n.disconnect();p&&(b&&b(f),w(f))},1E3*e)}};"hidden"===document.visibilityState?document.addEventListener("visibilitychange",()=>v(),{once:!0}):v()})}async WaitMap(a,b,{raf:c=!1,timeout:d=8,throttle:e=50,subtree:m=!0,childList:k=!0,attributes:g=!1,characterData:l=!1,timeoutResult:r=!1,object:p=document.body}={}){const u=this;return new Promise((t,w)=>{const x=async function(){let v,h;if(c){let f;const q=()=>{h=a.map(n=>document.querySelector(n));h.every(n=>null!==n&&"undefined"!==typeof n)?(cancelAnimationFrame(f),clearTimeout(v),b&&b(h),t(h)):f=requestAnimationFrame(q)};f=requestAnimationFrame(q);v=setTimeout(()=>{cancelAnimationFrame(f);r&&(b&&b(h),t(h))},1E3*d)}else{const f=new MutationObserver(u.Throttle(()=>{h=a.map(q=>document.querySelector(q));h.every(q=>null!==q&&"undefined"!==typeof q)&&(f.disconnect(),clearTimeout(v),b&&b(h),t(h))},e));f.observe(p,{subtree:m,childList:k,attributes:g,characterData:l});v=setTimeout(()=>{f.disconnect();r&&(b&&b(h),t(h))},1E3*d)}};"hidden"===document.visibilityState?document.addEventListener("visibilitychange",()=>x(),{once:!0}):x()})}Storage(a,{type:b=sessionStorage,value:c=null,error:d}={}){let e;return null!=c?this.StorageMatch[this.Type(c)](b,a,c):(e=b.getItem(a),void 0!=e?this.StorageMatch[this.Type(JSON.parse(e))](b,e):d)}DomParse(a){return this.Parser.parseFromString(a,"text/html")}NameFilter(a){return a.replace(/[\/\?<>\\:\*\|":]/g,"")}GetFill(a){return Math.max(2,`${a}`.length)}ExtensionName(a){try{return a.match(/\.([^.]+)$/)[1].toLowerCase()||"png"}catch{return"png"}}Mantissa(a,b,c="0",d=null){return d?`${++a}`.padStart(b,c)+`.${this.ExtensionName(d)}`:`${++a}`.padStart(b,c)}ScopeParsing(a,b){if("string"!=typeof a||""===a.trim())return b;const c=b.length,d=new Set,e=new Set,m=(g,l,r)=>{const p=g<=l;for(;p?g<=l:g>=l;p?g++:g--)r.add(g)};let k;for(k of a.split(/\s*[\.,|/]\s*/))if(/^(!|-)?\d+(~\d+|-\d+)?$/.test(k)){a=k.slice(1);const g=/^[!-]/.test(k),l=/[~-]/.test(a),[r,p]=g?[e,a]:[d,k],[u,t]=l?p.split(/-|~/):[p,p];u==t?r.add(+u-1):m(+u-1,+t-1,r)}return[...d].filter(g=>!e.has(g)&&g<c&&0<=g).sort((g,l)=>g-l).map(g=>b[g])}FormatTemplate(a,b){if("Object"!==this.Type(a))return"Template must be an object";a=Object.fromEntries(Object.entries(a).map(([c,d])=>[c.toLowerCase(),d]));return"String"===this.Type(b)?b.replace(/\{\s*([^}\s]+)\s*\}/g,(c,d)=>this.TemplateMatch.Process(a,d)):"Object"===this.Type(b)?Object.entries(b).map(([c,d])=>this.TemplateMatch.Process(a,c,d)):{"Unsupported format":b}}async OutputJson(a,b,c=null){try{a="string"!==typeof a?JSON.stringify(a,null,4):a;b="string"!==typeof b?"Anonymous":b.replace(".json","");const d=document.createElement("a");d.href=`data:application/json;charset=utf-8,${encodeURIComponent(a)}`;d.download=`${b}.json`;d.click();await new Promise(e=>setTimeout(e,100));d.remove();c&&c({State:!0})}catch(d){c&&c({State:!1,Info:d})}}WorkerCreation(a){a=new Blob([a],{type:"application/javascript"});return new Worker(URL.createObjectURL(a))}Runtime(a=null,{log:b=!0,format:c=!0,label:d="Elapsed Time:",style:e="\u001b[1m\u001b[36m%s\u001b[0m"}={}){if(!a)return performance.now();a=c?`${((performance.now()-a)/1E3).toPrecision(3)}s`:performance.now()-a;return b?console.log(e,`${d} ${a}`):a}GetDate(a=null){const b=new Date,c={year:b.getFullYear(),month:`${b.getMonth()+1}`.padStart(2,"0"),date:`${b.getDate()}`.padStart(2,"0"),hour:`${b.getHours()}`.padStart(2,"0"),minute:`${b.getMinutes()}`.padStart(2,"0"),second:`${b.getSeconds()}`.padStart(2,"0")};return(d=>d.replace(/{([^}]+)}/g,(e,m)=>c[m]??"Error"))("string"===typeof a?a:"{year}-{month}-{date} {hour}:{minute}:{second}")}Throttle(a,b){let c=0;return(...d)=>{const e=Date.now();e-c>=b&&(c=e,a(...d))}}Debounce(a,b=500){let c=null;return(...d)=>{clearTimeout(c);c=setTimeout(function(){a(...d)},b)}}async Menu(a,b="Menu",c=1){for(const [d,e]of Object.entries(a))GM_registerMenuCommand(d,()=>{e.func()},{title:e.desc,id:`${b}-${c++}`,autoClose:e.close,accessKey:e.hotkey})}Store(a,b=null,c=null){return this.StoreMatch[a](b,c)}async StoreListen(a,b){a.forEach(c=>{this.Mark[c]||(this.Mark[c]=!0,GM_addValueChangeListener(c,function(d,e,m,k){b({key:d,ov:e,nv:m,far:k})}))})}};