@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.
Files changed (123) hide show
  1. package/bin/create-sdk.js +107 -0
  2. package/package.json +14 -0
  3. package/template/.editorconfig +0 -0
  4. package/template/.github/CODEOWNERS +2 -0
  5. package/template/.github/ISSUE_TEMPLATE/bug_report.md +35 -0
  6. package/template/.github/ISSUE_TEMPLATE/feature_request.md +26 -0
  7. package/template/.github/dependabot.yml +18 -0
  8. package/template/.github/pull_request_template.md +25 -0
  9. package/template/.github/workflows/auto-release.yml +77 -0
  10. package/template/.github/workflows/ci.yml +35 -0
  11. package/template/.github/workflows/deploy-pages.yml +73 -0
  12. package/template/.github/workflows/docs-ci.yml +38 -0
  13. package/template/.github/workflows/docs.yml +19 -0
  14. package/template/.github/workflows/release.yml +51 -0
  15. package/template/.husky/commit-msg +4 -0
  16. package/template/.husky/pre-commit +4 -0
  17. package/template/.prettierrc +0 -0
  18. package/template/CHANGELOG.md +49 -0
  19. package/template/CODE_OF_CONDUCT.md +40 -0
  20. package/template/CONTRIBUTING.md +38 -0
  21. package/template/LICENSE +21 -0
  22. package/template/README.md +49 -0
  23. package/template/SECURITY.md +16 -0
  24. package/template/TEST_DEPLOY.md +0 -0
  25. package/template/api-extractor.json +33 -0
  26. package/template/ci-cd.md +93 -0
  27. package/template/commitlint.config.cjs +3 -0
  28. package/template/coverage/base.css +224 -0
  29. package/template/coverage/block-navigation.js +87 -0
  30. package/template/coverage/clover.xml +6 -0
  31. package/template/coverage/coverage-final.json +1 -0
  32. package/template/coverage/favicon.png +0 -0
  33. package/template/coverage/index.html +101 -0
  34. package/template/coverage/prettify.css +1 -0
  35. package/template/coverage/prettify.js +2 -0
  36. package/template/coverage/sort-arrow-sprite.png +0 -0
  37. package/template/coverage/sorter.js +210 -0
  38. package/template/docs/api/README.md +5 -0
  39. package/template/docs/api-auto/README.md +5 -0
  40. package/template/docs/index.html +73 -0
  41. package/template/docs/index.md +28 -0
  42. package/template/docusaurus-build/.github/workflows/deploy-docs.yml +46 -0
  43. package/template/docusaurus-build/.github/workflows/deploy-pages.yml +43 -0
  44. package/template/docusaurus-build/README.md +44 -0
  45. package/template/docusaurus-build/blog/authors.yml +34 -0
  46. package/template/docusaurus-build/blog/hello-world.md +9 -0
  47. package/template/docusaurus-build/docs/ci-cd.md +62 -0
  48. package/template/docusaurus-build/docs/conventions.md +50 -0
  49. package/template/docusaurus-build/docs/folder-structure.md +24 -0
  50. package/template/docusaurus-build/docs/getting-started.md +24 -0
  51. package/template/docusaurus-build/docs/intro.md +14 -0
  52. package/template/docusaurus-build/docs/project-architecture.md +125 -0
  53. package/template/docusaurus-build/docs/project-template/architecture.md +82 -0
  54. package/template/docusaurus-build/docs/project-template/getting-started.md +24 -0
  55. package/template/docusaurus-build/docs/project-template/overview.md +78 -0
  56. package/template/docusaurus-build/docs/project-template/structure.md +145 -0
  57. package/template/docusaurus-build/docs/scripts.md +42 -0
  58. package/template/docusaurus-build/docs/testing.md +30 -0
  59. package/template/docusaurus-build/docusaurus-build/sidebars.ts +30 -0
  60. package/template/docusaurus-build/docusaurus-build/tsconfig.json +8 -0
  61. package/template/docusaurus-build/docusaurus-build/typedoc.tsconfig.json +28 -0
  62. package/template/docusaurus-build/docusaurus.config.ts +129 -0
  63. package/template/docusaurus-build/package-lock.json +18235 -0
  64. package/template/docusaurus-build/package.json +51 -0
  65. package/template/docusaurus-build/project-template/README.md +44 -0
  66. package/template/docusaurus-build/project-template/src/index.ts +4 -0
  67. package/template/docusaurus-build/project-template/src/modules/user.ts +20 -0
  68. package/template/docusaurus-build/project-template/src/types/user.ts +5 -0
  69. package/template/docusaurus-build/sidebars.ts +20 -0
  70. package/template/docusaurus-build/src/components/HomepageFeatures/index.tsx +71 -0
  71. package/template/docusaurus-build/src/components/HomepageFeatures/styles.module.css +11 -0
  72. package/template/docusaurus-build/src/css/custom.css +30 -0
  73. package/template/docusaurus-build/src/pages/index.module.css +23 -0
  74. package/template/docusaurus-build/src/pages/index.tsx +52 -0
  75. package/template/docusaurus-build/src/pages/markdown-page.md +7 -0
  76. package/template/docusaurus-build/static/.nojekyll +0 -0
  77. package/template/docusaurus-build/static/api/.nojekyll +1 -0
  78. package/template/docusaurus-build/static/api/assets/hierarchy.js +1 -0
  79. package/template/docusaurus-build/static/api/assets/highlight.css +22 -0
  80. package/template/docusaurus-build/static/api/assets/icons.js +18 -0
  81. package/template/docusaurus-build/static/api/assets/icons.svg +1 -0
  82. package/template/docusaurus-build/static/api/assets/main.js +60 -0
  83. package/template/docusaurus-build/static/api/assets/navigation.js +1 -0
  84. package/template/docusaurus-build/static/api/assets/search.js +1 -0
  85. package/template/docusaurus-build/static/api/assets/style.css +1633 -0
  86. package/template/docusaurus-build/static/api/functions/modules_user.getUser.html +1 -0
  87. package/template/docusaurus-build/static/api/functions/modules_user.sumAges.html +1 -0
  88. package/template/docusaurus-build/static/api/hierarchy.html +1 -0
  89. package/template/docusaurus-build/static/api/index.html +1 -0
  90. package/template/docusaurus-build/static/api/modules/index.html +1 -0
  91. package/template/docusaurus-build/static/api/modules/modules_user.html +1 -0
  92. package/template/docusaurus-build/static/api/modules/types_user.html +1 -0
  93. package/template/docusaurus-build/static/api/types/types_user.ApiResult.html +3 -0
  94. package/template/docusaurus-build/static/api/types/types_user.User.html +4 -0
  95. package/template/docusaurus-build/static/img/docusaurus-social-card.jpg +0 -0
  96. package/template/docusaurus-build/static/img/docusaurus.png +0 -0
  97. package/template/docusaurus-build/static/img/favicon.ico +0 -0
  98. package/template/docusaurus-build/static/img/logo.svg +1 -0
  99. package/template/docusaurus-build/static/img/undraw_docusaurus_mountain.svg +171 -0
  100. package/template/docusaurus-build/static/img/undraw_docusaurus_react.svg +170 -0
  101. package/template/docusaurus-build/static/img/undraw_docusaurus_tree.svg +40 -0
  102. package/template/docusaurus-build/tsconfig.json +8 -0
  103. package/template/docusaurus-build/typedoc.json +14 -0
  104. package/template/docusaurus-build/typedoc.tsconfig.json +7 -0
  105. package/template/eslint.config.mjs +72 -0
  106. package/template/etc/project-template.api.md +32 -0
  107. package/template/morda-dev-project-template-0.1.1.tgz +0 -0
  108. package/template/package-lock.json +45 -0
  109. package/template/package.json +35 -0
  110. package/template/scripts/commitlint-runner.mjs +10 -0
  111. package/template/src/index.ts +19 -0
  112. package/template/src/modules/user.ts +12 -0
  113. package/template/src/types/user.ts +9 -0
  114. package/template/test.ts +4 -0
  115. package/template/tests/example.test.js +3 -0
  116. package/template/tests/public-api.snapshot.test.ts +13 -0
  117. package/template/tests/public-api.test.ts +58 -0
  118. package/template/tests/user.test.ts +16 -0
  119. package/template/tsconfig.build.json +11 -0
  120. package/template/tsconfig.eslint.json +14 -0
  121. package/template/tsconfig.json +12 -0
  122. package/template/typedoc.json +6 -0
  123. 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"]);
@@ -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,5 @@
1
+ **project-template**
2
+
3
+ ***
4
+
5
+ # project-template
@@ -0,0 +1,5 @@
1
+ **project-template**
2
+
3
+ ***
4
+
5
+ # project-template
@@ -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,9 @@
1
+ ---
2
+ title: Hello World
3
+ description: Первый пост в блоге
4
+ authors: [morda]
5
+ tags: [intro]
6
+ ---
7
+
8
+ Добро пожаловать в блог!
9
+ Этот пост нужен, чтобы корректно работала страница **/blog**.
@@ -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