@morda-dev/create-sdk 1.0.1
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/bin/create-sdk.js +107 -0
- package/package.json +14 -0
- package/template/.editorconfig +0 -0
- package/template/.github/CODEOWNERS +2 -0
- package/template/.github/ISSUE_TEMPLATE/bug_report.md +35 -0
- package/template/.github/ISSUE_TEMPLATE/feature_request.md +26 -0
- package/template/.github/dependabot.yml +18 -0
- package/template/.github/pull_request_template.md +25 -0
- package/template/.github/workflows/auto-release.yml +77 -0
- package/template/.github/workflows/ci.yml +35 -0
- package/template/.github/workflows/deploy-pages.yml +73 -0
- package/template/.github/workflows/docs-ci.yml +38 -0
- package/template/.github/workflows/docs.yml +19 -0
- package/template/.github/workflows/release.yml +51 -0
- package/template/.husky/commit-msg +4 -0
- package/template/.husky/pre-commit +4 -0
- package/template/.prettierrc +0 -0
- package/template/CHANGELOG.md +49 -0
- package/template/CODE_OF_CONDUCT.md +40 -0
- package/template/CONTRIBUTING.md +38 -0
- package/template/LICENSE +21 -0
- package/template/README.md +49 -0
- package/template/SECURITY.md +16 -0
- package/template/TEST_DEPLOY.md +0 -0
- package/template/api-extractor.json +33 -0
- package/template/ci-cd.md +93 -0
- package/template/commitlint.config.cjs +3 -0
- package/template/coverage/base.css +224 -0
- package/template/coverage/block-navigation.js +87 -0
- package/template/coverage/clover.xml +6 -0
- package/template/coverage/coverage-final.json +1 -0
- package/template/coverage/favicon.png +0 -0
- package/template/coverage/index.html +101 -0
- package/template/coverage/prettify.css +1 -0
- package/template/coverage/prettify.js +2 -0
- package/template/coverage/sort-arrow-sprite.png +0 -0
- package/template/coverage/sorter.js +210 -0
- package/template/docs/api/README.md +5 -0
- package/template/docs/api-auto/README.md +5 -0
- package/template/docs/index.html +73 -0
- package/template/docs/index.md +28 -0
- package/template/docusaurus-build/.github/workflows/deploy-docs.yml +46 -0
- package/template/docusaurus-build/.github/workflows/deploy-pages.yml +43 -0
- package/template/docusaurus-build/README.md +44 -0
- package/template/docusaurus-build/blog/authors.yml +34 -0
- package/template/docusaurus-build/blog/hello-world.md +9 -0
- package/template/docusaurus-build/docs/ci-cd.md +62 -0
- package/template/docusaurus-build/docs/conventions.md +50 -0
- package/template/docusaurus-build/docs/folder-structure.md +24 -0
- package/template/docusaurus-build/docs/getting-started.md +24 -0
- package/template/docusaurus-build/docs/intro.md +14 -0
- package/template/docusaurus-build/docs/project-architecture.md +125 -0
- package/template/docusaurus-build/docs/project-template/architecture.md +82 -0
- package/template/docusaurus-build/docs/project-template/getting-started.md +24 -0
- package/template/docusaurus-build/docs/project-template/overview.md +78 -0
- package/template/docusaurus-build/docs/project-template/structure.md +145 -0
- package/template/docusaurus-build/docs/scripts.md +42 -0
- package/template/docusaurus-build/docs/testing.md +30 -0
- package/template/docusaurus-build/docusaurus-build/sidebars.ts +30 -0
- package/template/docusaurus-build/docusaurus-build/tsconfig.json +8 -0
- package/template/docusaurus-build/docusaurus-build/typedoc.tsconfig.json +28 -0
- package/template/docusaurus-build/docusaurus.config.ts +129 -0
- package/template/docusaurus-build/package-lock.json +18235 -0
- package/template/docusaurus-build/package.json +51 -0
- package/template/docusaurus-build/project-template/README.md +44 -0
- package/template/docusaurus-build/project-template/src/index.ts +4 -0
- package/template/docusaurus-build/project-template/src/modules/user.ts +20 -0
- package/template/docusaurus-build/project-template/src/types/user.ts +5 -0
- package/template/docusaurus-build/sidebars.ts +20 -0
- package/template/docusaurus-build/src/components/HomepageFeatures/index.tsx +71 -0
- package/template/docusaurus-build/src/components/HomepageFeatures/styles.module.css +11 -0
- package/template/docusaurus-build/src/css/custom.css +30 -0
- package/template/docusaurus-build/src/pages/index.module.css +23 -0
- package/template/docusaurus-build/src/pages/index.tsx +52 -0
- package/template/docusaurus-build/src/pages/markdown-page.md +7 -0
- package/template/docusaurus-build/static/.nojekyll +0 -0
- package/template/docusaurus-build/static/api/.nojekyll +1 -0
- package/template/docusaurus-build/static/api/assets/hierarchy.js +1 -0
- package/template/docusaurus-build/static/api/assets/highlight.css +22 -0
- package/template/docusaurus-build/static/api/assets/icons.js +18 -0
- package/template/docusaurus-build/static/api/assets/icons.svg +1 -0
- package/template/docusaurus-build/static/api/assets/main.js +60 -0
- package/template/docusaurus-build/static/api/assets/navigation.js +1 -0
- package/template/docusaurus-build/static/api/assets/search.js +1 -0
- package/template/docusaurus-build/static/api/assets/style.css +1633 -0
- package/template/docusaurus-build/static/api/functions/modules_user.getUser.html +1 -0
- package/template/docusaurus-build/static/api/functions/modules_user.sumAges.html +1 -0
- package/template/docusaurus-build/static/api/hierarchy.html +1 -0
- package/template/docusaurus-build/static/api/index.html +1 -0
- package/template/docusaurus-build/static/api/modules/index.html +1 -0
- package/template/docusaurus-build/static/api/modules/modules_user.html +1 -0
- package/template/docusaurus-build/static/api/modules/types_user.html +1 -0
- package/template/docusaurus-build/static/api/types/types_user.ApiResult.html +3 -0
- package/template/docusaurus-build/static/api/types/types_user.User.html +4 -0
- package/template/docusaurus-build/static/img/docusaurus-social-card.jpg +0 -0
- package/template/docusaurus-build/static/img/docusaurus.png +0 -0
- package/template/docusaurus-build/static/img/favicon.ico +0 -0
- package/template/docusaurus-build/static/img/logo.svg +1 -0
- package/template/docusaurus-build/static/img/undraw_docusaurus_mountain.svg +171 -0
- package/template/docusaurus-build/static/img/undraw_docusaurus_react.svg +170 -0
- package/template/docusaurus-build/static/img/undraw_docusaurus_tree.svg +40 -0
- package/template/docusaurus-build/tsconfig.json +8 -0
- package/template/docusaurus-build/typedoc.json +14 -0
- package/template/docusaurus-build/typedoc.tsconfig.json +7 -0
- package/template/eslint.config.mjs +72 -0
- package/template/etc/project-template.api.md +32 -0
- package/template/morda-dev-project-template-0.1.1.tgz +0 -0
- package/template/package-lock.json +45 -0
- package/template/package.json +35 -0
- package/template/scripts/commitlint-runner.mjs +10 -0
- package/template/src/index.ts +19 -0
- package/template/src/modules/user.ts +12 -0
- package/template/src/types/user.ts +9 -0
- package/template/test.ts +4 -0
- package/template/tests/example.test.js +3 -0
- package/template/tests/public-api.snapshot.test.ts +13 -0
- package/template/tests/public-api.test.ts +58 -0
- package/template/tests/user.test.ts +16 -0
- package/template/tsconfig.build.json +11 -0
- package/template/tsconfig.eslint.json +14 -0
- package/template/tsconfig.json +12 -0
- package/template/typedoc.json +6 -0
- package/template/vitest.config.ts +12 -0
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
window.PR_SHOULD_USE_CONTINUATION=true;(function(){var h=["break,continue,do,else,for,if,return,while"];var u=[h,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"];var p=[u,"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"];var l=[p,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"];var x=[p,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"];var R=[x,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var"];var r="all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,true,try,unless,until,when,while,yes";var w=[p,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"];var s="caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END";var I=[h,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"];var f=[h,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"];var H=[h,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"];var A=[l,R,w,s+I,f,H];var e=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)/;var C="str";var z="kwd";var j="com";var O="typ";var G="lit";var L="pun";var F="pln";var m="tag";var E="dec";var J="src";var P="atn";var n="atv";var N="nocode";var M="(?:^^\\.?|[+-]|\\!|\\!=|\\!==|\\#|\\%|\\%=|&|&&|&&=|&=|\\(|\\*|\\*=|\\+=|\\,|\\-=|\\->|\\/|\\/=|:|::|\\;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|\\?|\\@|\\[|\\^|\\^=|\\^\\^|\\^\\^=|\\{|\\||\\|=|\\|\\||\\|\\|=|\\~|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\\s*";function k(Z){var ad=0;var S=false;var ac=false;for(var V=0,U=Z.length;V<U;++V){var ae=Z[V];if(ae.ignoreCase){ac=true}else{if(/[a-z]/i.test(ae.source.replace(/\\u[0-9a-f]{4}|\\x[0-9a-f]{2}|\\[^ux]/gi,""))){S=true;ac=false;break}}}var Y={b:8,t:9,n:10,v:11,f:12,r:13};function ab(ah){var ag=ah.charCodeAt(0);if(ag!==92){return ag}var af=ah.charAt(1);ag=Y[af];if(ag){return ag}else{if("0"<=af&&af<="7"){return parseInt(ah.substring(1),8)}else{if(af==="u"||af==="x"){return parseInt(ah.substring(2),16)}else{return ah.charCodeAt(1)}}}}function T(af){if(af<32){return(af<16?"\\x0":"\\x")+af.toString(16)}var ag=String.fromCharCode(af);if(ag==="\\"||ag==="-"||ag==="["||ag==="]"){ag="\\"+ag}return ag}function X(am){var aq=am.substring(1,am.length-1).match(new RegExp("\\\\u[0-9A-Fa-f]{4}|\\\\x[0-9A-Fa-f]{2}|\\\\[0-3][0-7]{0,2}|\\\\[0-7]{1,2}|\\\\[\\s\\S]|-|[^-\\\\]","g"));var ak=[];var af=[];var ao=aq[0]==="^";for(var ar=ao?1:0,aj=aq.length;ar<aj;++ar){var ah=aq[ar];if(/\\[bdsw]/i.test(ah)){ak.push(ah)}else{var ag=ab(ah);var al;if(ar+2<aj&&"-"===aq[ar+1]){al=ab(aq[ar+2]);ar+=2}else{al=ag}af.push([ag,al]);if(!(al<65||ag>122)){if(!(al<65||ag>90)){af.push([Math.max(65,ag)|32,Math.min(al,90)|32])}if(!(al<97||ag>122)){af.push([Math.max(97,ag)&~32,Math.min(al,122)&~32])}}}}af.sort(function(av,au){return(av[0]-au[0])||(au[1]-av[1])});var ai=[];var ap=[NaN,NaN];for(var ar=0;ar<af.length;++ar){var at=af[ar];if(at[0]<=ap[1]+1){ap[1]=Math.max(ap[1],at[1])}else{ai.push(ap=at)}}var an=["["];if(ao){an.push("^")}an.push.apply(an,ak);for(var ar=0;ar<ai.length;++ar){var at=ai[ar];an.push(T(at[0]));if(at[1]>at[0]){if(at[1]+1>at[0]){an.push("-")}an.push(T(at[1]))}}an.push("]");return an.join("")}function W(al){var aj=al.source.match(new RegExp("(?:\\[(?:[^\\x5C\\x5D]|\\\\[\\s\\S])*\\]|\\\\u[A-Fa-f0-9]{4}|\\\\x[A-Fa-f0-9]{2}|\\\\[0-9]+|\\\\[^ux0-9]|\\(\\?[:!=]|[\\(\\)\\^]|[^\\x5B\\x5C\\(\\)\\^]+)","g"));var ah=aj.length;var an=[];for(var ak=0,am=0;ak<ah;++ak){var ag=aj[ak];if(ag==="("){++am}else{if("\\"===ag.charAt(0)){var af=+ag.substring(1);if(af&&af<=am){an[af]=-1}}}}for(var ak=1;ak<an.length;++ak){if(-1===an[ak]){an[ak]=++ad}}for(var ak=0,am=0;ak<ah;++ak){var ag=aj[ak];if(ag==="("){++am;if(an[am]===undefined){aj[ak]="(?:"}}else{if("\\"===ag.charAt(0)){var af=+ag.substring(1);if(af&&af<=am){aj[ak]="\\"+an[am]}}}}for(var ak=0,am=0;ak<ah;++ak){if("^"===aj[ak]&&"^"!==aj[ak+1]){aj[ak]=""}}if(al.ignoreCase&&S){for(var ak=0;ak<ah;++ak){var ag=aj[ak];var ai=ag.charAt(0);if(ag.length>=2&&ai==="["){aj[ak]=X(ag)}else{if(ai!=="\\"){aj[ak]=ag.replace(/[a-zA-Z]/g,function(ao){var ap=ao.charCodeAt(0);return"["+String.fromCharCode(ap&~32,ap|32)+"]"})}}}}return aj.join("")}var aa=[];for(var V=0,U=Z.length;V<U;++V){var ae=Z[V];if(ae.global||ae.multiline){throw new Error(""+ae)}aa.push("(?:"+W(ae)+")")}return new RegExp(aa.join("|"),ac?"gi":"g")}function a(V){var U=/(?:^|\s)nocode(?:\s|$)/;var X=[];var T=0;var Z=[];var W=0;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=document.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Y=S&&"pre"===S.substring(0,3);function aa(ab){switch(ab.nodeType){case 1:if(U.test(ab.className)){return}for(var ae=ab.firstChild;ae;ae=ae.nextSibling){aa(ae)}var ad=ab.nodeName;if("BR"===ad||"LI"===ad){X[W]="\n";Z[W<<1]=T++;Z[(W++<<1)|1]=ab}break;case 3:case 4:var ac=ab.nodeValue;if(ac.length){if(!Y){ac=ac.replace(/[ \t\r\n]+/g," ")}else{ac=ac.replace(/\r\n?/g,"\n")}X[W]=ac;Z[W<<1]=T;T+=ac.length;Z[(W++<<1)|1]=ab}break}}aa(V);return{sourceCode:X.join("").replace(/\n$/,""),spans:Z}}function B(S,U,W,T){if(!U){return}var V={sourceCode:U,basePos:S};W(V);T.push.apply(T,V.decorations)}var v=/\S/;function o(S){var V=undefined;for(var U=S.firstChild;U;U=U.nextSibling){var T=U.nodeType;V=(T===1)?(V?S:U):(T===3)?(v.test(U.nodeValue)?S:V):V}return V===S?undefined:V}function g(U,T){var S={};var V;(function(){var ad=U.concat(T);var ah=[];var ag={};for(var ab=0,Z=ad.length;ab<Z;++ab){var Y=ad[ab];var ac=Y[3];if(ac){for(var ae=ac.length;--ae>=0;){S[ac.charAt(ae)]=Y}}var af=Y[1];var aa=""+af;if(!ag.hasOwnProperty(aa)){ah.push(af);ag[aa]=null}}ah.push(/[\0-\uffff]/);V=k(ah)})();var X=T.length;var W=function(ah){var Z=ah.sourceCode,Y=ah.basePos;var ad=[Y,F];var af=0;var an=Z.match(V)||[];var aj={};for(var ae=0,aq=an.length;ae<aq;++ae){var ag=an[ae];var ap=aj[ag];var ai=void 0;var am;if(typeof ap==="string"){am=false}else{var aa=S[ag.charAt(0)];if(aa){ai=ag.match(aa[1]);ap=aa[0]}else{for(var ao=0;ao<X;++ao){aa=T[ao];ai=ag.match(aa[1]);if(ai){ap=aa[0];break}}if(!ai){ap=F}}am=ap.length>=5&&"lang-"===ap.substring(0,5);if(am&&!(ai&&typeof ai[1]==="string")){am=false;ap=J}if(!am){aj[ag]=ap}}var ab=af;af+=ag.length;if(!am){ad.push(Y+ab,ap)}else{var al=ai[1];var ak=ag.indexOf(al);var ac=ak+al.length;if(ai[2]){ac=ag.length-ai[2].length;ak=ac-al.length}var ar=ap.substring(5);B(Y+ab,ag.substring(0,ak),W,ad);B(Y+ab+ak,al,q(ar,al),ad);B(Y+ab+ac,ag.substring(ac),W,ad)}}ah.decorations=ad};return W}function i(T){var W=[],S=[];if(T.tripleQuotedStrings){W.push([C,/^(?:\'\'\'(?:[^\'\\]|\\[\s\S]|\'{1,2}(?=[^\']))*(?:\'\'\'|$)|\"\"\"(?:[^\"\\]|\\[\s\S]|\"{1,2}(?=[^\"]))*(?:\"\"\"|$)|\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$))/,null,"'\""])}else{if(T.multiLineStrings){W.push([C,/^(?:\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$)|\`(?:[^\\\`]|\\[\s\S])*(?:\`|$))/,null,"'\"`"])}else{W.push([C,/^(?:\'(?:[^\\\'\r\n]|\\.)*(?:\'|$)|\"(?:[^\\\"\r\n]|\\.)*(?:\"|$))/,null,"\"'"])}}if(T.verbatimStrings){S.push([C,/^@\"(?:[^\"]|\"\")*(?:\"|$)/,null])}var Y=T.hashComments;if(Y){if(T.cStyleComments){if(Y>1){W.push([j,/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,null,"#"])}else{W.push([j,/^#(?:(?:define|elif|else|endif|error|ifdef|include|ifndef|line|pragma|undef|warning)\b|[^\r\n]*)/,null,"#"])}S.push([C,/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h|[a-z]\w*)>/,null])}else{W.push([j,/^#[^\r\n]*/,null,"#"])}}if(T.cStyleComments){S.push([j,/^\/\/[^\r\n]*/,null]);S.push([j,/^\/\*[\s\S]*?(?:\*\/|$)/,null])}if(T.regexLiterals){var X=("/(?=[^/*])(?:[^/\\x5B\\x5C]|\\x5C[\\s\\S]|\\x5B(?:[^\\x5C\\x5D]|\\x5C[\\s\\S])*(?:\\x5D|$))+/");S.push(["lang-regex",new RegExp("^"+M+"("+X+")")])}var V=T.types;if(V){S.push([O,V])}var U=(""+T.keywords).replace(/^ | $/g,"");if(U.length){S.push([z,new RegExp("^(?:"+U.replace(/[\s,]+/g,"|")+")\\b"),null])}W.push([F,/^\s+/,null," \r\n\t\xA0"]);S.push([G,/^@[a-z_$][a-z_$@0-9]*/i,null],[O,/^(?:[@_]?[A-Z]+[a-z][A-Za-z_$@0-9]*|\w+_t\b)/,null],[F,/^[a-z_$][a-z_$@0-9]*/i,null],[G,new RegExp("^(?:0x[a-f0-9]+|(?:\\d(?:_\\d+)*\\d*(?:\\.\\d*)?|\\.\\d\\+)(?:e[+\\-]?\\d+)?)[a-z]*","i"),null,"0123456789"],[F,/^\\[\s\S]?/,null],[L,/^.[^\s\w\.$@\'\"\`\/\#\\]*/,null]);return g(W,S)}var K=i({keywords:A,hashComments:true,cStyleComments:true,multiLineStrings:true,regexLiterals:true});function Q(V,ag){var U=/(?:^|\s)nocode(?:\s|$)/;var ab=/\r\n?|\n/;var ac=V.ownerDocument;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=ac.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Z=S&&"pre"===S.substring(0,3);var af=ac.createElement("LI");while(V.firstChild){af.appendChild(V.firstChild)}var W=[af];function ae(al){switch(al.nodeType){case 1:if(U.test(al.className)){break}if("BR"===al.nodeName){ad(al);if(al.parentNode){al.parentNode.removeChild(al)}}else{for(var an=al.firstChild;an;an=an.nextSibling){ae(an)}}break;case 3:case 4:if(Z){var am=al.nodeValue;var aj=am.match(ab);if(aj){var ai=am.substring(0,aj.index);al.nodeValue=ai;var ah=am.substring(aj.index+aj[0].length);if(ah){var ak=al.parentNode;ak.insertBefore(ac.createTextNode(ah),al.nextSibling)}ad(al);if(!ai){al.parentNode.removeChild(al)}}}break}}function ad(ak){while(!ak.nextSibling){ak=ak.parentNode;if(!ak){return}}function ai(al,ar){var aq=ar?al.cloneNode(false):al;var ao=al.parentNode;if(ao){var ap=ai(ao,1);var an=al.nextSibling;ap.appendChild(aq);for(var am=an;am;am=an){an=am.nextSibling;ap.appendChild(am)}}return aq}var ah=ai(ak.nextSibling,0);for(var aj;(aj=ah.parentNode)&&aj.nodeType===1;){ah=aj}W.push(ah)}for(var Y=0;Y<W.length;++Y){ae(W[Y])}if(ag===(ag|0)){W[0].setAttribute("value",ag)}var aa=ac.createElement("OL");aa.className="linenums";var X=Math.max(0,((ag-1))|0)||0;for(var Y=0,T=W.length;Y<T;++Y){af=W[Y];af.className="L"+((Y+X)%10);if(!af.firstChild){af.appendChild(ac.createTextNode("\xA0"))}aa.appendChild(af)}V.appendChild(aa)}function D(ac){var aj=/\bMSIE\b/.test(navigator.userAgent);var am=/\n/g;var al=ac.sourceCode;var an=al.length;var V=0;var aa=ac.spans;var T=aa.length;var ah=0;var X=ac.decorations;var Y=X.length;var Z=0;X[Y]=an;var ar,aq;for(aq=ar=0;aq<Y;){if(X[aq]!==X[aq+2]){X[ar++]=X[aq++];X[ar++]=X[aq++]}else{aq+=2}}Y=ar;for(aq=ar=0;aq<Y;){var at=X[aq];var ab=X[aq+1];var W=aq+2;while(W+2<=Y&&X[W+1]===ab){W+=2}X[ar++]=at;X[ar++]=ab;aq=W}Y=X.length=ar;var ae=null;while(ah<T){var af=aa[ah];var S=aa[ah+2]||an;var ag=X[Z];var ap=X[Z+2]||an;var W=Math.min(S,ap);var ak=aa[ah+1];var U;if(ak.nodeType!==1&&(U=al.substring(V,W))){if(aj){U=U.replace(am,"\r")}ak.nodeValue=U;var ai=ak.ownerDocument;var ao=ai.createElement("SPAN");ao.className=X[Z+1];var ad=ak.parentNode;ad.replaceChild(ao,ak);ao.appendChild(ak);if(V<S){aa[ah+1]=ak=ai.createTextNode(al.substring(W,S));ad.insertBefore(ak,ao.nextSibling)}}V=W;if(V>=S){ah+=2}if(V>=ap){Z+=2}}}var t={};function c(U,V){for(var S=V.length;--S>=0;){var T=V[S];if(!t.hasOwnProperty(T)){t[T]=U}else{if(window.console){console.warn("cannot override language handler %s",T)}}}}function q(T,S){if(!(T&&t.hasOwnProperty(T))){T=/^\s*</.test(S)?"default-markup":"default-code"}return t[T]}c(K,["default-code"]);c(g([],[[F,/^[^<?]+/],[E,/^<!\w[^>]*(?:>|$)/],[j,/^<\!--[\s\S]*?(?:-\->|$)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],[L,/^(?:<[%?]|[%?]>)/],["lang-",/^<xmp\b[^>]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-js",/^<script\b[^>]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-css",/^<style\b[^>]*>([\s\S]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i]]),["default-markup","htm","html","mxml","xhtml","xml","xsl"]);c(g([[F,/^[\s]+/,null," \t\r\n"],[n,/^(?:\"[^\"]*\"?|\'[^\']*\'?)/,null,"\"'"]],[[m,/^^<\/?[a-z](?:[\w.:-]*\w)?|\/?>$/i],[P,/^(?!style[\s=]|on)[a-z](?:[\w:-]*\w)?/i],["lang-uq.val",/^=\s*([^>\'\"\s]*(?:[^>\'\"\s\/]|\/(?=\s)))/],[L,/^[=<>\/]+/],["lang-js",/^on\w+\s*=\s*\"([^\"]+)\"/i],["lang-js",/^on\w+\s*=\s*\'([^\']+)\'/i],["lang-js",/^on\w+\s*=\s*([^\"\'>\s]+)/i],["lang-css",/^style\s*=\s*\"([^\"]+)\"/i],["lang-css",/^style\s*=\s*\'([^\']+)\'/i],["lang-css",/^style\s*=\s*([^\"\'>\s]+)/i]]),["in.tag"]);c(g([],[[n,/^[\s\S]+/]]),["uq.val"]);c(i({keywords:l,hashComments:true,cStyleComments:true,types:e}),["c","cc","cpp","cxx","cyc","m"]);c(i({keywords:"null,true,false"}),["json"]);c(i({keywords:R,hashComments:true,cStyleComments:true,verbatimStrings:true,types:e}),["cs"]);c(i({keywords:x,cStyleComments:true}),["java"]);c(i({keywords:H,hashComments:true,multiLineStrings:true}),["bsh","csh","sh"]);c(i({keywords:I,hashComments:true,multiLineStrings:true,tripleQuotedStrings:true}),["cv","py"]);c(i({keywords:s,hashComments:true,multiLineStrings:true,regexLiterals:true}),["perl","pl","pm"]);c(i({keywords:f,hashComments:true,multiLineStrings:true,regexLiterals:true}),["rb"]);c(i({keywords:w,cStyleComments:true,regexLiterals:true}),["js"]);c(i({keywords:r,hashComments:3,cStyleComments:true,multilineStrings:true,tripleQuotedStrings:true,regexLiterals:true}),["coffee"]);c(g([],[[C,/^[\s\S]+/]]),["regex"]);function d(V){var U=V.langExtension;try{var S=a(V.sourceNode);var T=S.sourceCode;V.sourceCode=T;V.spans=S.spans;V.basePos=0;q(U,T)(V);D(V)}catch(W){if("console" in window){console.log(W&&W.stack?W.stack:W)}}}function y(W,V,U){var S=document.createElement("PRE");S.innerHTML=W;if(U){Q(S,U)}var T={langExtension:V,numberLines:U,sourceNode:S};d(T);return S.innerHTML}function b(ad){function Y(af){return document.getElementsByTagName(af)}var ac=[Y("pre"),Y("code"),Y("xmp")];var T=[];for(var aa=0;aa<ac.length;++aa){for(var Z=0,V=ac[aa].length;Z<V;++Z){T.push(ac[aa][Z])}}ac=null;var W=Date;if(!W.now){W={now:function(){return +(new Date)}}}var X=0;var S;var ab=/\blang(?:uage)?-([\w.]+)(?!\S)/;var ae=/\bprettyprint\b/;function U(){var ag=(window.PR_SHOULD_USE_CONTINUATION?W.now()+250:Infinity);for(;X<T.length&&W.now()<ag;X++){var aj=T[X];var ai=aj.className;if(ai.indexOf("prettyprint")>=0){var ah=ai.match(ab);var am;if(!ah&&(am=o(aj))&&"CODE"===am.tagName){ah=am.className.match(ab)}if(ah){ah=ah[1]}var al=false;for(var ak=aj.parentNode;ak;ak=ak.parentNode){if((ak.tagName==="pre"||ak.tagName==="code"||ak.tagName==="xmp")&&ak.className&&ak.className.indexOf("prettyprint")>=0){al=true;break}}if(!al){var af=aj.className.match(/\blinenums\b(?::(\d+))?/);af=af?af[1]&&af[1].length?+af[1]:true:false;if(af){Q(aj,af)}S={langExtension:ah,sourceNode:aj,numberLines:af};d(S)}}}if(X<T.length){setTimeout(U,250)}else{if(ad){ad()}}}U()}window.prettyPrintOne=y;window.prettyPrint=b;window.PR={createSimpleLexer:g,registerLangHandler:c,sourceDecorator:i,PR_ATTRIB_NAME:P,PR_ATTRIB_VALUE:n,PR_COMMENT:j,PR_DECLARATION:E,PR_KEYWORD:z,PR_LITERAL:G,PR_NOCODE:N,PR_PLAIN:F,PR_PUNCTUATION:L,PR_SOURCE:J,PR_STRING:C,PR_TAG:m,PR_TYPE:O}})();PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_DECLARATION,/^<!\w[^>]*(?:>|$)/],[PR.PR_COMMENT,/^<\!--[\s\S]*?(?:-\->|$)/],[PR.PR_PUNCTUATION,/^(?:<[%?]|[%?]>)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],["lang-",/^<xmp\b[^>]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-handlebars",/^<script\b[^>]*type\s*=\s*['"]?text\/x-handlebars-template['"]?\b[^>]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-js",/^<script\b[^>]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-css",/^<style\b[^>]*>([\s\S]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i],[PR.PR_DECLARATION,/^{{[#^>/]?\s*[\w.][^}]*}}/],[PR.PR_DECLARATION,/^{{&?\s*[\w.][^}]*}}/],[PR.PR_DECLARATION,/^{{{>?\s*[\w.][^}]*}}}/],[PR.PR_COMMENT,/^{{![^}]*}}/]]),["handlebars","hbs"]);PR.registerLangHandler(PR.createSimpleLexer([[PR.PR_PLAIN,/^[ \t\r\n\f]+/,null," \t\r\n\f"]],[[PR.PR_STRING,/^\"(?:[^\n\r\f\\\"]|\\(?:\r\n?|\n|\f)|\\[\s\S])*\"/,null],[PR.PR_STRING,/^\'(?:[^\n\r\f\\\']|\\(?:\r\n?|\n|\f)|\\[\s\S])*\'/,null],["lang-css-str",/^url\(([^\)\"\']*)\)/i],[PR.PR_KEYWORD,/^(?:url|rgb|\!important|@import|@page|@media|@charset|inherit)(?=[^\-\w]|$)/i,null],["lang-css-kw",/^(-?(?:[_a-z]|(?:\\[0-9a-f]+ ?))(?:[_a-z0-9\-]|\\(?:\\[0-9a-f]+ ?))*)\s*:/i],[PR.PR_COMMENT,/^\/\*[^*]*\*+(?:[^\/*][^*]*\*+)*\//],[PR.PR_COMMENT,/^(?:<!--|-->)/],[PR.PR_LITERAL,/^(?:\d+|\d*\.\d+)(?:%|[a-z]+)?/i],[PR.PR_LITERAL,/^#(?:[0-9a-f]{3}){1,2}/i],[PR.PR_PLAIN,/^-?(?:[_a-z]|(?:\\[\da-f]+ ?))(?:[_a-z\d\-]|\\(?:\\[\da-f]+ ?))*/i],[PR.PR_PUNCTUATION,/^[^\s\w\'\"]+/]]),["css"]);PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_KEYWORD,/^-?(?:[_a-z]|(?:\\[\da-f]+ ?))(?:[_a-z\d\-]|\\(?:\\[\da-f]+ ?))*/i]]),["css-kw"]);PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_STRING,/^[^\)\"\']+/]]),["css-str"]);
|
|
Binary file
|
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
var addSorting = (function() {
|
|
3
|
+
'use strict';
|
|
4
|
+
var cols,
|
|
5
|
+
currentSort = {
|
|
6
|
+
index: 0,
|
|
7
|
+
desc: false
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
// returns the summary table element
|
|
11
|
+
function getTable() {
|
|
12
|
+
return document.querySelector('.coverage-summary');
|
|
13
|
+
}
|
|
14
|
+
// returns the thead element of the summary table
|
|
15
|
+
function getTableHeader() {
|
|
16
|
+
return getTable().querySelector('thead tr');
|
|
17
|
+
}
|
|
18
|
+
// returns the tbody element of the summary table
|
|
19
|
+
function getTableBody() {
|
|
20
|
+
return getTable().querySelector('tbody');
|
|
21
|
+
}
|
|
22
|
+
// returns the th element for nth column
|
|
23
|
+
function getNthColumn(n) {
|
|
24
|
+
return getTableHeader().querySelectorAll('th')[n];
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
function onFilterInput() {
|
|
28
|
+
const searchValue = document.getElementById('fileSearch').value;
|
|
29
|
+
const rows = document.getElementsByTagName('tbody')[0].children;
|
|
30
|
+
|
|
31
|
+
// Try to create a RegExp from the searchValue. If it fails (invalid regex),
|
|
32
|
+
// it will be treated as a plain text search
|
|
33
|
+
let searchRegex;
|
|
34
|
+
try {
|
|
35
|
+
searchRegex = new RegExp(searchValue, 'i'); // 'i' for case-insensitive
|
|
36
|
+
} catch (error) {
|
|
37
|
+
searchRegex = null;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
for (let i = 0; i < rows.length; i++) {
|
|
41
|
+
const row = rows[i];
|
|
42
|
+
let isMatch = false;
|
|
43
|
+
|
|
44
|
+
if (searchRegex) {
|
|
45
|
+
// If a valid regex was created, use it for matching
|
|
46
|
+
isMatch = searchRegex.test(row.textContent);
|
|
47
|
+
} else {
|
|
48
|
+
// Otherwise, fall back to the original plain text search
|
|
49
|
+
isMatch = row.textContent
|
|
50
|
+
.toLowerCase()
|
|
51
|
+
.includes(searchValue.toLowerCase());
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
row.style.display = isMatch ? '' : 'none';
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
// loads the search box
|
|
59
|
+
function addSearchBox() {
|
|
60
|
+
var template = document.getElementById('filterTemplate');
|
|
61
|
+
var templateClone = template.content.cloneNode(true);
|
|
62
|
+
templateClone.getElementById('fileSearch').oninput = onFilterInput;
|
|
63
|
+
template.parentElement.appendChild(templateClone);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// loads all columns
|
|
67
|
+
function loadColumns() {
|
|
68
|
+
var colNodes = getTableHeader().querySelectorAll('th'),
|
|
69
|
+
colNode,
|
|
70
|
+
cols = [],
|
|
71
|
+
col,
|
|
72
|
+
i;
|
|
73
|
+
|
|
74
|
+
for (i = 0; i < colNodes.length; i += 1) {
|
|
75
|
+
colNode = colNodes[i];
|
|
76
|
+
col = {
|
|
77
|
+
key: colNode.getAttribute('data-col'),
|
|
78
|
+
sortable: !colNode.getAttribute('data-nosort'),
|
|
79
|
+
type: colNode.getAttribute('data-type') || 'string'
|
|
80
|
+
};
|
|
81
|
+
cols.push(col);
|
|
82
|
+
if (col.sortable) {
|
|
83
|
+
col.defaultDescSort = col.type === 'number';
|
|
84
|
+
colNode.innerHTML =
|
|
85
|
+
colNode.innerHTML + '<span class="sorter"></span>';
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
return cols;
|
|
89
|
+
}
|
|
90
|
+
// attaches a data attribute to every tr element with an object
|
|
91
|
+
// of data values keyed by column name
|
|
92
|
+
function loadRowData(tableRow) {
|
|
93
|
+
var tableCols = tableRow.querySelectorAll('td'),
|
|
94
|
+
colNode,
|
|
95
|
+
col,
|
|
96
|
+
data = {},
|
|
97
|
+
i,
|
|
98
|
+
val;
|
|
99
|
+
for (i = 0; i < tableCols.length; i += 1) {
|
|
100
|
+
colNode = tableCols[i];
|
|
101
|
+
col = cols[i];
|
|
102
|
+
val = colNode.getAttribute('data-value');
|
|
103
|
+
if (col.type === 'number') {
|
|
104
|
+
val = Number(val);
|
|
105
|
+
}
|
|
106
|
+
data[col.key] = val;
|
|
107
|
+
}
|
|
108
|
+
return data;
|
|
109
|
+
}
|
|
110
|
+
// loads all row data
|
|
111
|
+
function loadData() {
|
|
112
|
+
var rows = getTableBody().querySelectorAll('tr'),
|
|
113
|
+
i;
|
|
114
|
+
|
|
115
|
+
for (i = 0; i < rows.length; i += 1) {
|
|
116
|
+
rows[i].data = loadRowData(rows[i]);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
// sorts the table using the data for the ith column
|
|
120
|
+
function sortByIndex(index, desc) {
|
|
121
|
+
var key = cols[index].key,
|
|
122
|
+
sorter = function(a, b) {
|
|
123
|
+
a = a.data[key];
|
|
124
|
+
b = b.data[key];
|
|
125
|
+
return a < b ? -1 : a > b ? 1 : 0;
|
|
126
|
+
},
|
|
127
|
+
finalSorter = sorter,
|
|
128
|
+
tableBody = document.querySelector('.coverage-summary tbody'),
|
|
129
|
+
rowNodes = tableBody.querySelectorAll('tr'),
|
|
130
|
+
rows = [],
|
|
131
|
+
i;
|
|
132
|
+
|
|
133
|
+
if (desc) {
|
|
134
|
+
finalSorter = function(a, b) {
|
|
135
|
+
return -1 * sorter(a, b);
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
for (i = 0; i < rowNodes.length; i += 1) {
|
|
140
|
+
rows.push(rowNodes[i]);
|
|
141
|
+
tableBody.removeChild(rowNodes[i]);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
rows.sort(finalSorter);
|
|
145
|
+
|
|
146
|
+
for (i = 0; i < rows.length; i += 1) {
|
|
147
|
+
tableBody.appendChild(rows[i]);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
// removes sort indicators for current column being sorted
|
|
151
|
+
function removeSortIndicators() {
|
|
152
|
+
var col = getNthColumn(currentSort.index),
|
|
153
|
+
cls = col.className;
|
|
154
|
+
|
|
155
|
+
cls = cls.replace(/ sorted$/, '').replace(/ sorted-desc$/, '');
|
|
156
|
+
col.className = cls;
|
|
157
|
+
}
|
|
158
|
+
// adds sort indicators for current column being sorted
|
|
159
|
+
function addSortIndicators() {
|
|
160
|
+
getNthColumn(currentSort.index).className += currentSort.desc
|
|
161
|
+
? ' sorted-desc'
|
|
162
|
+
: ' sorted';
|
|
163
|
+
}
|
|
164
|
+
// adds event listeners for all sorter widgets
|
|
165
|
+
function enableUI() {
|
|
166
|
+
var i,
|
|
167
|
+
el,
|
|
168
|
+
ithSorter = function ithSorter(i) {
|
|
169
|
+
var col = cols[i];
|
|
170
|
+
|
|
171
|
+
return function() {
|
|
172
|
+
var desc = col.defaultDescSort;
|
|
173
|
+
|
|
174
|
+
if (currentSort.index === i) {
|
|
175
|
+
desc = !currentSort.desc;
|
|
176
|
+
}
|
|
177
|
+
sortByIndex(i, desc);
|
|
178
|
+
removeSortIndicators();
|
|
179
|
+
currentSort.index = i;
|
|
180
|
+
currentSort.desc = desc;
|
|
181
|
+
addSortIndicators();
|
|
182
|
+
};
|
|
183
|
+
};
|
|
184
|
+
for (i = 0; i < cols.length; i += 1) {
|
|
185
|
+
if (cols[i].sortable) {
|
|
186
|
+
// add the click event handler on the th so users
|
|
187
|
+
// dont have to click on those tiny arrows
|
|
188
|
+
el = getNthColumn(i).querySelector('.sorter').parentElement;
|
|
189
|
+
if (el.addEventListener) {
|
|
190
|
+
el.addEventListener('click', ithSorter(i));
|
|
191
|
+
} else {
|
|
192
|
+
el.attachEvent('onclick', ithSorter(i));
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
// adds sorting functionality to the UI
|
|
198
|
+
return function() {
|
|
199
|
+
if (!getTable()) {
|
|
200
|
+
return;
|
|
201
|
+
}
|
|
202
|
+
cols = loadColumns();
|
|
203
|
+
loadData();
|
|
204
|
+
addSearchBox();
|
|
205
|
+
addSortIndicators();
|
|
206
|
+
enableUI();
|
|
207
|
+
};
|
|
208
|
+
})();
|
|
209
|
+
|
|
210
|
+
window.addEventListener('load', addSorting);
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
<!doctype html>
|
|
2
|
+
<html lang="ru">
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="utf-8" />
|
|
5
|
+
<meta name="viewport" content="width=device-width,initial-scale=1" />
|
|
6
|
+
<title>Project Template — Morda Dev</title>
|
|
7
|
+
<style>
|
|
8
|
+
body {
|
|
9
|
+
font-family: Inter, system-ui, Arial, sans-serif;
|
|
10
|
+
line-height: 1.6;
|
|
11
|
+
padding: 40px;
|
|
12
|
+
max-width: 900px;
|
|
13
|
+
margin: 0 auto;
|
|
14
|
+
}
|
|
15
|
+
header {
|
|
16
|
+
display: flex;
|
|
17
|
+
gap: 12px;
|
|
18
|
+
align-items: center;
|
|
19
|
+
}
|
|
20
|
+
.hero {
|
|
21
|
+
margin-top: 28px;
|
|
22
|
+
}
|
|
23
|
+
.btn {
|
|
24
|
+
display: inline-block;
|
|
25
|
+
padding: 10px 16px;
|
|
26
|
+
border-radius: 8px;
|
|
27
|
+
text-decoration: none;
|
|
28
|
+
}
|
|
29
|
+
.primary {
|
|
30
|
+
background: #111;
|
|
31
|
+
color: #fff;
|
|
32
|
+
}
|
|
33
|
+
.muted {
|
|
34
|
+
background: #efefef;
|
|
35
|
+
color: #111;
|
|
36
|
+
margin-left: 8px;
|
|
37
|
+
}
|
|
38
|
+
</style>
|
|
39
|
+
</head>
|
|
40
|
+
<body>
|
|
41
|
+
<header>
|
|
42
|
+
<h1>Project Template</h1>
|
|
43
|
+
</header>
|
|
44
|
+
<section class="hero">
|
|
45
|
+
<p>
|
|
46
|
+
Оптимизированный TypeScript/NPM проект-стартер с CI, Husky, lint-staged,
|
|
47
|
+
release automation и шаблонами issues.
|
|
48
|
+
</p>
|
|
49
|
+
|
|
50
|
+
<p>
|
|
51
|
+
<a
|
|
52
|
+
class="btn primary"
|
|
53
|
+
href="https://github.com/mordaHQ/project-template"
|
|
54
|
+
target="_blank"
|
|
55
|
+
>GitHub</a
|
|
56
|
+
>
|
|
57
|
+
<a
|
|
58
|
+
class="btn muted"
|
|
59
|
+
href="https://github.com/sponsors/mordaHQ"
|
|
60
|
+
target="_blank"
|
|
61
|
+
>Поддержать</a
|
|
62
|
+
>
|
|
63
|
+
</p>
|
|
64
|
+
|
|
65
|
+
<h3>Скачать или купить улучшенную версию</h3>
|
|
66
|
+
<p>Позже добавим Stripe/Gumroad. Это базовая страница.</p>
|
|
67
|
+
</section>
|
|
68
|
+
|
|
69
|
+
<footer style="margin-top: 60px; color: #666; font-size: 14px">
|
|
70
|
+
v1 — готово к использованию.
|
|
71
|
+
</footer>
|
|
72
|
+
</body>
|
|
73
|
+
</html>
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
# Project Template — Документация
|
|
2
|
+
|
|
3
|
+
Кратко: это профессиональный TypeScript project template с настройкой CI, тестами, Prettier/ESLint, GitHub Actions и автоматическими релизами.
|
|
4
|
+
|
|
5
|
+
## 🚀 Быстрый старт
|
|
6
|
+
|
|
7
|
+
`ash
|
|
8
|
+
|
|
9
|
+
# клонируем
|
|
10
|
+
|
|
11
|
+
git clone https://github.com/mordaHQ/project-template.git
|
|
12
|
+
cd project-template
|
|
13
|
+
|
|
14
|
+
# установить зависимости
|
|
15
|
+
|
|
16
|
+
npm ci
|
|
17
|
+
|
|
18
|
+
# запустить тесты
|
|
19
|
+
|
|
20
|
+
npm test
|
|
21
|
+
|
|
22
|
+
# линтинг
|
|
23
|
+
|
|
24
|
+
npm run lint
|
|
25
|
+
|
|
26
|
+
# проверка форматирования
|
|
27
|
+
|
|
28
|
+
npx prettier --check .
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
name: Deploy Docusaurus
|
|
2
|
+
|
|
3
|
+
on:
|
|
4
|
+
push:
|
|
5
|
+
branches:
|
|
6
|
+
- main
|
|
7
|
+
|
|
8
|
+
jobs:
|
|
9
|
+
build-and-deploy:
|
|
10
|
+
runs-on: ubuntu-latest
|
|
11
|
+
|
|
12
|
+
steps:
|
|
13
|
+
- name: Checkout repository
|
|
14
|
+
uses: actions/checkout@v3
|
|
15
|
+
with:
|
|
16
|
+
fetch-depth: 0
|
|
17
|
+
submodules: true
|
|
18
|
+
|
|
19
|
+
- name: Setup Node.js
|
|
20
|
+
uses: actions/setup-node@v3
|
|
21
|
+
with:
|
|
22
|
+
node-version: 20
|
|
23
|
+
cache: npm
|
|
24
|
+
|
|
25
|
+
- name: Install dependencies
|
|
26
|
+
run: |
|
|
27
|
+
cd docusaurus-build
|
|
28
|
+
npm ci
|
|
29
|
+
|
|
30
|
+
- name: Generate API docs
|
|
31
|
+
run: |
|
|
32
|
+
cd docusaurus-build
|
|
33
|
+
cd ..
|
|
34
|
+
npm run api
|
|
35
|
+
|
|
36
|
+
- name: Build Docusaurus
|
|
37
|
+
run: |
|
|
38
|
+
cd docusaurus-build
|
|
39
|
+
npm run build
|
|
40
|
+
|
|
41
|
+
- name: Deploy to GitHub Pages
|
|
42
|
+
uses: peaceiris/actions-gh-pages@v3
|
|
43
|
+
with:
|
|
44
|
+
github_token: ${{ secrets.GITHUB_TOKEN }}
|
|
45
|
+
publish_dir: docusaurus-build/build
|
|
46
|
+
publish_branch: gh-pages
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
name: Build and Deploy Docs (Cloudflare Pages)
|
|
2
|
+
|
|
3
|
+
on:
|
|
4
|
+
push:
|
|
5
|
+
branches:
|
|
6
|
+
- main
|
|
7
|
+
pull_request:
|
|
8
|
+
|
|
9
|
+
jobs:
|
|
10
|
+
build-and-deploy:
|
|
11
|
+
runs-on: ubuntu-latest
|
|
12
|
+
|
|
13
|
+
defaults:
|
|
14
|
+
run:
|
|
15
|
+
working-directory: docusaurus-build
|
|
16
|
+
|
|
17
|
+
steps:
|
|
18
|
+
- name: Checkout repository
|
|
19
|
+
uses: actions/checkout@v4
|
|
20
|
+
|
|
21
|
+
- name: Use Node.js 20
|
|
22
|
+
uses: actions/setup-node@v4
|
|
23
|
+
with:
|
|
24
|
+
node-version: 20
|
|
25
|
+
cache: npm
|
|
26
|
+
cache-dependency-path: docusaurus-build/package-lock.json
|
|
27
|
+
|
|
28
|
+
- name: Install dependencies
|
|
29
|
+
run: npm ci
|
|
30
|
+
|
|
31
|
+
- name: Generate API docs (TypeDoc)
|
|
32
|
+
run: npm run docs:api
|
|
33
|
+
|
|
34
|
+
- name: Build Docusaurus site
|
|
35
|
+
run: npm run build
|
|
36
|
+
|
|
37
|
+
- name: Deploy to Cloudflare Pages
|
|
38
|
+
uses: cloudflare/pages-action@v1
|
|
39
|
+
with:
|
|
40
|
+
apiToken: ${{ secrets.CLOUDFLARE_API_TOKEN }}
|
|
41
|
+
accountId: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }}
|
|
42
|
+
projectName: ${{ secrets.CLOUDFLARE_PROJECT_NAME }}
|
|
43
|
+
directory: docusaurus-build/build
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
# @morda-dev/project-template
|
|
2
|
+
|
|
3
|
+
Production-ready TypeScript SDK template with a strict public API, ESM-first setup,
|
|
4
|
+
and best practices baked in.
|
|
5
|
+
|
|
6
|
+
This package can be used as:
|
|
7
|
+
- a base for building your own SDK
|
|
8
|
+
- a reference for ESM + TypeScript library architecture
|
|
9
|
+
- a starting point for production-ready npm packages
|
|
10
|
+
|
|
11
|
+
---
|
|
12
|
+
## Installation
|
|
13
|
+
|
|
14
|
+
```bash
|
|
15
|
+
npm install @morda-dev/project-template
|
|
16
|
+
```
|
|
17
|
+
Usage
|
|
18
|
+
|
|
19
|
+
import { getUser, sumAges } from '@morda-dev/project-template';
|
|
20
|
+
|
|
21
|
+
const user = getUser(1);
|
|
22
|
+
console.log(user);
|
|
23
|
+
|
|
24
|
+
const totalAge = sumAges([
|
|
25
|
+
{ id: 1, name: 'Alice', age: 20 },
|
|
26
|
+
{ id: 2, name: 'Bob', age: 30 },
|
|
27
|
+
]);
|
|
28
|
+
|
|
29
|
+
console.log(totalAge);
|
|
30
|
+
API
|
|
31
|
+
getUser(id: number)
|
|
32
|
+
|
|
33
|
+
Returns a user wrapped in ApiResult.
|
|
34
|
+
|
|
35
|
+
sumAges(users: User[])
|
|
36
|
+
|
|
37
|
+
Returns the sum of all user ages.
|
|
38
|
+
|
|
39
|
+
License
|
|
40
|
+
|
|
41
|
+
ISC
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
---
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
yangshun:
|
|
2
|
+
name: Yangshun Tay
|
|
3
|
+
title: Ex-Meta Staff Engineer, Co-founder GreatFrontEnd
|
|
4
|
+
url: https://linkedin.com/in/yangshun
|
|
5
|
+
image_url: https://github.com/yangshun.png
|
|
6
|
+
page: true
|
|
7
|
+
socials:
|
|
8
|
+
x: yangshunz
|
|
9
|
+
linkedin: yangshun
|
|
10
|
+
github: yangshun
|
|
11
|
+
newsletter: https://www.greatfrontend.com
|
|
12
|
+
|
|
13
|
+
slorber:
|
|
14
|
+
name: Sébastien Lorber
|
|
15
|
+
title: Docusaurus maintainer
|
|
16
|
+
url: https://sebastienlorber.com
|
|
17
|
+
image_url: https://github.com/slorber.png
|
|
18
|
+
page:
|
|
19
|
+
permalink: "/all-sebastien-lorber-articles"
|
|
20
|
+
socials:
|
|
21
|
+
x: sebastienlorber
|
|
22
|
+
linkedin: sebastienlorber
|
|
23
|
+
github: slorber
|
|
24
|
+
newsletter: https://thisweekinreact.com
|
|
25
|
+
|
|
26
|
+
morda:
|
|
27
|
+
name: Morda Dev
|
|
28
|
+
title: Author of Project Template
|
|
29
|
+
url: https://github.com/mordaHQ
|
|
30
|
+
image_url: https://avatars.githubusercontent.com/u/183162001?v=4
|
|
31
|
+
page: true
|
|
32
|
+
socials:
|
|
33
|
+
github: mordaHQ
|
|
34
|
+
x: morda_dev
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
---
|
|
2
|
+
sidebar_position: 8
|
|
3
|
+
title: CI/CD и автоматизация
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# 🚀 CI/CD и автоматизация проекта
|
|
7
|
+
|
|
8
|
+
Проект использует полностью автоматизированный процесс разработки и релизов, основанный на GitHub Actions и best-practice подходах к versioning & quality control.
|
|
9
|
+
|
|
10
|
+
## 🔍 Автоматическая проверка кода
|
|
11
|
+
|
|
12
|
+
Каждый коммит в репозиторий запускает пайплайн:
|
|
13
|
+
|
|
14
|
+
- Линтинг (eslint)
|
|
15
|
+
- Форматирование (prettier --check)
|
|
16
|
+
- Юнит-тесты (vitest)
|
|
17
|
+
- Проверка типов (tsc --noEmit)
|
|
18
|
+
|
|
19
|
+
Это исключает ситуации, когда в основную ветку попадает нерабочий код.
|
|
20
|
+
|
|
21
|
+
## 🔢 Автоматическая версияция
|
|
22
|
+
|
|
23
|
+
Используется standard-version:
|
|
24
|
+
|
|
25
|
+
- генерирует CHANGELOG
|
|
26
|
+
- увеличивает версию (patch / minor / major)
|
|
27
|
+
- создаёт git-тег
|
|
28
|
+
|
|
29
|
+
Команда:
|
|
30
|
+
|
|
31
|
+
\\\bash
|
|
32
|
+
npm run release
|
|
33
|
+
\\\
|
|
34
|
+
|
|
35
|
+
## 📦 Автосборка проекта
|
|
36
|
+
|
|
37
|
+
При пуше в main запускается:
|
|
38
|
+
|
|
39
|
+
- сборка TypeScript
|
|
40
|
+
- упаковка build-директории
|
|
41
|
+
- проверка артефактов
|
|
42
|
+
|
|
43
|
+
## 🌍 Деплой документации
|
|
44
|
+
|
|
45
|
+
Документация собирается в каталоге docusaurus-build и деплоится в GitHub Pages автоматически.
|
|
46
|
+
|
|
47
|
+
Процесс:
|
|
48
|
+
|
|
49
|
+
- сборка Docusaurus
|
|
50
|
+
- очистка ветки gh-pages
|
|
51
|
+
- загрузка обновлённого билда
|
|
52
|
+
- публикация на GitHub Pages
|
|
53
|
+
|
|
54
|
+
## 🧩 Почему это важно
|
|
55
|
+
|
|
56
|
+
Автоматизация даёт:
|
|
57
|
+
|
|
58
|
+
- прозрачные релизы
|
|
59
|
+
- отсутствие человеческих ошибок
|
|
60
|
+
- стабильные nightly-сборки
|
|
61
|
+
- быстрые фичи без ручной рутины
|
|
62
|
+
- высокое качество и единый стиль кода
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
---
|
|
2
|
+
sidebar_position: 9
|
|
3
|
+
title: Coding Conventions
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# 📐 Coding Conventions
|
|
7
|
+
|
|
8
|
+
Этот проект строго придерживается единых правил, чтобы весь код был предсказуемым, читаемым и простым в поддержке.
|
|
9
|
+
|
|
10
|
+
## 📝 Style Guide
|
|
11
|
+
|
|
12
|
+
Проект использует:
|
|
13
|
+
|
|
14
|
+
- ESLint — статический анализ
|
|
15
|
+
- Prettier — единый стиль форматирования
|
|
16
|
+
- TypeScript strict mode — максимально строгая типизация
|
|
17
|
+
|
|
18
|
+
Все настройки находятся в корне репозитория и применяются автоматически.
|
|
19
|
+
|
|
20
|
+
## 🔤 Правила именования
|
|
21
|
+
|
|
22
|
+
- Классы — PascalCase
|
|
23
|
+
- Функции и переменные — camelCase
|
|
24
|
+
- Константы — UPPER_SNAKE_CASE
|
|
25
|
+
- Файлы — kebab-case.ts
|
|
26
|
+
- Тесты — \*.test.ts
|
|
27
|
+
|
|
28
|
+
## 🧩 Структура типов
|
|
29
|
+
|
|
30
|
+
- Используем типобезопасные функции
|
|
31
|
+
- Избегаем any
|
|
32
|
+
- Предпочитаем type вместо interface
|
|
33
|
+
- Все входные данные должны иметь явный тип
|
|
34
|
+
|
|
35
|
+
## 🧪 Тесты
|
|
36
|
+
|
|
37
|
+
- Каждый модуль имеет хотя бы один тест
|
|
38
|
+
- Тесты располагаются рядом с кодом (\*.test.ts)
|
|
39
|
+
- Используем Vitest
|
|
40
|
+
|
|
41
|
+
## 📚 Комментарии
|
|
42
|
+
|
|
43
|
+
- Комментарии только там, где логика сложная
|
|
44
|
+
- Код должен быть самодокументируемым
|
|
45
|
+
- Допускаются JSDoc над публичными функциями
|
|
46
|
+
|
|
47
|
+
## 🔄 Форматирование
|
|
48
|
+
|
|
49
|
+
ash
|
|
50
|
+
npm run format
|