extension-create 2.0.0-alpha.6 → 2.0.0-alpha.7
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/dist/module.js +13 -12
- package/package.json +2 -2
package/dist/module.js
CHANGED
|
@@ -1,25 +1,26 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var ze=Object.create;var k=Object.defineProperty;var Ve=Object.getOwnPropertyDescriptor;var Xe=Object.getOwnPropertyNames;var Le=Object.getPrototypeOf,Ue=Object.prototype.hasOwnProperty;var Ye=(e,t)=>{for(var i in t)k(e,i,{get:t[i],enumerable:!0})},W=(e,t,i,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of Xe(t))!Ue.call(e,n)&&n!==i&&k(e,n,{get:()=>t[n],enumerable:!(r=Ve(t,n))||r.enumerable});return e};var c=(e,t,i)=>(i=e!=null?ze(Le(e)):{},W(t||!e||!e.__esModule?k(i,"default",{value:e,enumerable:!0}):i,e)),qe=e=>W(k({},"__esModule",{value:!0}),e);var ot={};Ye(ot,{extensionCreate:()=>it});module.exports=qe(ot);var C=c(require("path"));var x=c(require("path")),o=require("@colors/colors/safe"),G=c(require("fs/promises")),A=require("detect-package-manager");function O(e){let t=x.default.basename(e);return`Failed to write in the destination directory. Path for \`${t}\` is not writable.
|
|
2
2
|
Ensure you have write permissions for this folder.
|
|
3
|
-
Path: ${t}`}async function
|
|
4
|
-
Conflict! Path to ${(0,
|
|
3
|
+
Path: ${t}`}async function z(e,t){let i=x.default.basename(e),r=`
|
|
4
|
+
Conflict! Path to ${(0,o.cyan)(i)} includes conflicting files:
|
|
5
5
|
|
|
6
|
-
`;for(let n of t){let
|
|
7
|
-
`:`${(0,
|
|
8
|
-
`}return
|
|
6
|
+
`;for(let n of t){let s=await G.default.lstat(x.default.join(e,n));r+=s.isDirectory()?`${(0,o.gray)("-")} ${(0,o.brightYellow)(n)}
|
|
7
|
+
`:`${(0,o.gray)("-")} ${(0,o.brightYellow)(n)}
|
|
8
|
+
`}return r+=`
|
|
9
9
|
You need to either rename/remove the files listed above, or choose a new directory name for your extension.
|
|
10
10
|
|
|
11
|
-
Path to conflicting directory: ${(0,
|
|
11
|
+
Path to conflicting directory: ${(0,o.underline)(e)}`,r}function V(){return"You need to provide an extension name to create one. \nSee `--help` for command info."}function X(){return"URLs are not allowed as a project path. Either write a name or a path to a local folder."}async function L(e,t){let i=x.default.relative(process.cwd(),e),r=await(0,A.detect)(),n="npm run";switch(r){case"yarn":n="yarn dev";break;case"pnpm":n="pnpm run dev";break;default:n="npm run dev"}return`\u{1F9E9} - ${(0,o.brightGreen)("Success!")} Extension ${(0,o.cyan)(t)} created.
|
|
12
12
|
|
|
13
|
-
Now ${(0,
|
|
13
|
+
Now ${(0,o.brightBlue)(`cd ${(0,o.underline)(i)}`)} and ${(0,o.brightBlue)(`${n}`)} to open a new browser instance
|
|
14
14
|
with your extension installed, loaded, and enabled for development.
|
|
15
15
|
|
|
16
|
-
${(0,
|
|
16
|
+
${(0,o.brightGreen)("You are ready")}. Time to hack on your extension!`}function U(e){return`\u{1F423} - Starting a new browser extension named ${(0,o.cyan)(e)}...`}function Y(){return"\u{1F91E} - Checking if destination path is writeable..."}function q(){return"\u{1F50E} - Scanning for potential conflicting files..."}function H(e,t){return`${(0,o.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")} Can't create directory ${(0,o.cyan)(e)}. ${t}`}function B(e){return`\u{1F537} - Writing ${(0,o.cyan)(e)} type definitions...`}function K(e){return`${(0,o.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")} Failed to write the extension type definition. ${e}`}function h(e,t){return t==="init"?`\u{1F9F0} - Installing ${(0,o.cyan)(e)}...`:`\u{1F9F0} - Installing ${(0,o.cyan)(e)} from template ${(0,o.brightBlue)(t)}...`}function b(e,t,i){return`${(0,o.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")} Can't find template ${(0,o.brightBlue)(t)} for ${(0,o.cyan)(e)}. ${i}`}function Q(e){return`\u{1F332} - Initializing git repository for ${(0,o.cyan)(e)}...`}function Z(e,t,i){return`Command ${e} ${t.join(" ")} failed with exit code ${i}`}function ee(e,t){return`${(0,o.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")} Child process error: Can't initialize ${(0,o.brightYellow)("git")} for ${(0,o.cyan)(e)}. ${t.message}`}function te(e,t){return`${(0,o.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")} Can't initialize ${(0,o.brightYellow)("git")} for ${(0,o.cyan)(e)}. ${t.message||t.toString()}`}function ne(){return"\u{1F6E0} - Installing dependencies... (takes a moment)"}function re(e,t,i){return`Command ${e} ${t.join(" ")} failed with exit code ${i}`}function ie(e,t){return`${(0,o.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")} Child process error: Can't install dependencies for ${(0,o.cyan)(e)}. ${t}`}function oe(e,t){return`${(0,o.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")} Can't install dependencies for ${(0,o.cyan)(e)}. ${t.message||t.toString()}`}function se(){return"Symlink created successfully."}function ae(e,t){return`Failed to create symlink: ${e} ${t.join(" ")}`}function ce(){return`\u{1F4DD} - Writing ${(0,o.brightYellow)("package.json")} metadata...`}function le(e,t){return`${(0,o.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")} Can't write ${(0,o.brightYellow)("package.json")} for ${(0,o.cyan)(e)}. ${t}`}function me(){return`\u{1F4DC} - Writing ${(0,o.brightYellow)("manifest.json")} metadata...`}function pe(e,t){return`${(0,o.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")} Can't write ${(0,o.brightYellow)("manifest.json")} for ${(0,o.cyan)(e)}. ${t}`}function ge(){return`\u{1F4C4} - Writing ${(0,o.brightYellow)("README.md")} metadata...`}function de(){return`\u{1F648} - Writing ${(0,o.brightYellow)(".gitignore")} lines...`}function fe(e,t){return`${(0,o.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")} Can't write the ${(0,o.brightYellow)("README.md")} file for ${(0,o.cyan)(e)}. ${t}`}function ue(e){return`\u{1F91D} - Ensuring ${(0,o.cyan)(e)} folder exists...`}function we(e){return"Error while checking directory writability: "+e}var E=c(require("fs/promises")),$=c(require("path")),ye=require("detect-package-manager");async function S(e,t){let i=await E.default.readdir(e,{withFileTypes:!0});return await E.default.mkdir(t,{recursive:!0}),await Promise.all(i.map(async r=>{let n=$.default.join(e,r.name),s=$.default.join(t,r.name);r.isDirectory()?await S(n,s):await E.default.copyFile(n,s)}))}async function y(){let e=await(0,ye.detect)(),t="npm run";switch(e){case"yarn":t="yarn";break;case"pnpm":t="pnpm run";break;default:t="npm run"}return t}function xe(e){let t=$.default.resolve(__dirname,"template");return $.default.resolve(e,t)}async function he(e,t){try{return console.log(ue(t)),await E.default.mkdir(e,{recursive:!0}),!0}catch(i){return console.log(we(i)),!1}}function P(e){return e!=="init"}function Ee(e){return P(e)?!1:e==="typescript"||e.startsWith("typescript-")||e.endsWith("-typescript")}var $e=c(require("path")),I=c(require("fs/promises"));var He=["LICENSE","node_modules"];async function ve(e,t){console.log(U(t));try{let i=await he(e,t);console.log(Y()),i||(console.error(O(e)),process.exit(1));let r=await I.default.readdir(e);console.log(q());let n=await Promise.all(r.filter(s=>!s.startsWith(".")).filter(s=>!s.endsWith(".log")).filter(s=>!He.includes(s)).map(async s=>(await I.default.lstat($e.default.join(e,s))).isDirectory()?`${s}/`:`${s}`));if(n.length>0){let s=await z(e,n);throw new Error(s)}}catch(i){console.error(H(t,i)),process.exit(1)}}var ke=c(require("path"));async function be(e,t,i){let r=ke.default.resolve(__dirname,"template");try{console.log(h(t,i)),await S(r,e)}catch(n){console.error(b(t,i,n)),process.exit(1)}}var p=c(require("path")),f=c(require("fs/promises")),De=c(require("go-git-it"));async function Te(e,t,i){let r=p.default.dirname(e),n=p.default.basename(i),a=`https://github.com/extension-js/extension.js/tree/main/examples/${i}`;try{await f.default.mkdir(e,{recursive:!0});let l="";if(process.env.EXTENSION_ENV==="development"?(console.log(h(t,i)),l=p.default.join(e,n),await f.default.cp(p.default.join(__dirname,"..","..","..","examples",n),l,{recursive:!0})):(await(0,De.default)(a,r,h(t,n)),l=p.default.join(r,n)),t!==n){let m=p.default.join(r,t);await f.default.mkdir(m,{recursive:!0});let g=await f.default.readdir(l);for(let u of g)await f.default.rename(p.default.join(l,u),p.default.join(m,u));await f.default.rm(l,{recursive:!0,force:!0})}else{let m=p.default.join(r,t+"-temp");await f.default.rename(l,m);let g=p.default.join(m,n),u=p.default.join(r,t);await f.default.mkdir(u,{recursive:!0});let Oe=await f.default.readdir(g);for(let j of Oe)await f.default.rename(p.default.join(g,j),p.default.join(u,j));await f.default.rm(m,{recursive:!0,force:!0})}}catch(l){console.error(b(t,n,l)),process.exit(1)}}var v=c(require("path")),J=c(require("fs/promises"));var Be={dev:process.env.EXTENSION_ENV==="development"?"node node_modules/extension dev":"extension dev",start:process.env.EXTENSION_ENV==="development"?"node node_modules/extension start":"extension start",build:process.env.EXTENSION_ENV==="development"?"node node_modules/extension build":"extension build"};async function Fe(e,t,i){let r=xe(process.cwd()),n=P(i)?v.default.join(e,"package.json"):v.default.join(r,"package.json"),s=await J.default.readFile(n),a=JSON.parse(s.toString());a.scripts=a.scripts||{},a.dependencies=a.dependencies||{},a.devDependencies={...a.devDependencies||{},extension:process.env.EXTENSION_ENV==="development"?"*":"latest"};let l={...a,name:v.default.basename(e),private:!0,scripts:{...a.scripts,...Be},dependencies:a.dependencies,devDependencies:a.devDependencies,author:{name:"Your Name",email:"your@email.com",url:"https://yourwebsite.com"}};try{console.log(ce()),await J.default.writeFile(v.default.join(e,"package.json"),JSON.stringify(l,null,2))}catch(m){console.error(le(t,m)),process.exit(1)}}var Pe=c(require("path")),Ie=require("cross-spawn"),Je=c(require("fs"));var Ce=c(require("path")),M=require("cross-spawn");async function Se(e){let t=Ce.default.join(__dirname,"../../cli"),i=await y(),r=["link"];await new Promise((n,s)=>{(0,M.spawn)(i,r,{cwd:t}).on("close",()=>{(0,M.spawn)(i,[...r,"extension"],{stdio:"inherit",cwd:e}).on("close",m=>{m===0?(console.log(se()),n()):s(new Error(ae(i,r)))})})}),console.log("Symlink creation completed.")}function Ke(){return["install","--silent"]}async function Me(e,t){let i=Pe.default.join(e,"node_modules"),r=await y(),n=Ke();console.log(ne()),process.env.EXTENSION_ENV==="development"&&await Se(e);try{let s=process.cwd();process.chdir(e),await Je.default.promises.mkdir(i,{recursive:!0});let a=process.env.EXTENSION_ENV==="development"?"inherit":"ignore",l=(0,Ie.spawn)(r,n,{stdio:a});await new Promise((m,g)=>{l.on("close",u=>{process.chdir(s),u!==0?g(new Error(re(r,n,u))):m()}),l.on("error",u=>{process.chdir(s),console.error(ie(t,u)),g(u)})})}catch(s){console.error(oe(t,s)),process.exit(1)}}var D=c(require("path")),T=c(require("fs/promises"));async function _e(e,t){let i=await T.default.readFile(D.default.join(__dirname,"template","README.md"),"utf-8"),r=await y(),n=require(D.default.join(e,"manifest.json")),s=i.replaceAll("[projectName]",t).replaceAll("[templateDescription]",n.description).replaceAll("[runCommand]",r);try{console.log(ge()),await T.default.mkdir(e,{recursive:!0}),await T.default.writeFile(D.default.join(e,"README.md"),s)}catch(a){console.error(fe(t,a)),process.exit(1)}}var F=c(require("path")),_=c(require("fs/promises"));async function Ne(e,t){let i=F.default.join(e,"manifest.json"),r=await _.default.readFile(i),s={...JSON.parse(r.toString()),name:F.default.basename(e),author:"Your Name"};try{console.log(me()),await _.default.writeFile(F.default.join(e,"manifest.json"),JSON.stringify(s,null,2))}catch(a){console.error(pe(t,a)),process.exit(1)}}var N=c(require("path")),R=c(require("fs/promises"));async function Re(e,t){let i=N.default.join(e,"extension-env.d.ts"),r=process.env.EXTENSION_ENV==="development"?N.default.resolve(process.cwd(),"programs/develop/types"):"extension-develop/dist/types",n=`// Required Extension.js types for TypeScript projects.
|
|
17
17
|
// This file auto-generated and should not be excluded.
|
|
18
18
|
// If you need extra types, consider creating a new *.d.ts and
|
|
19
19
|
// referencing it in the "include" array in your tsconfig.json file.
|
|
20
20
|
// See https://www.typescriptlang.org/tsconfig#include for info.
|
|
21
|
-
/// <reference types="${
|
|
21
|
+
/// <reference types="${r}/index.d.ts" />
|
|
22
22
|
|
|
23
23
|
// Polyfill types for browser.* APIs.
|
|
24
|
-
/// <reference types="${
|
|
25
|
-
`;try{await R.default.mkdir(e,{recursive:!0}),console.log(B(t)),await R.default.writeFile(
|
|
24
|
+
/// <reference types="${r}/polyfill.d.ts" />
|
|
25
|
+
`;try{await R.default.mkdir(e,{recursive:!0}),console.log(B(t)),await R.default.writeFile(i,n)}catch(s){console.error(K(s)),process.exit(1)}}var je=c(require("fs/promises"));var Qe=["# dependencies","/node_modules"],Ze=["# testing","/coverage"],et=["# production","/dist"],tt=["# misc",".DS_Store",".env.local",".env.development.local",".env.test.local",".env.production.local","npm-debug.log*","yarn-debug.log*","yarn-error.log*","extension.d.ts"],nt=["# lock files","yarn.lock","package-lock.json"],rt=[...Qe,...Ze,...et,...tt,...nt];async function We(e){let t=e+"/.gitignore",i=await je.default.open(t,"a+").catch(s=>{console.error(s),process.exit(1)}),r=new Set;for await(let s of i.readLines({autoClose:!1}))s=s.trim(),s.length!==0&&r.add(s);let n=rt.filter(s=>!r.has(s));console.log(de()),await i.appendFile(n.join(`
|
|
26
|
+
`),{flush:!0}).catch(s=>{console.error(s),process.exit(1)})}var Ge=require("cross-spawn");async function Ae(e,t){let i="git",r=["init","--quiet"];console.log(Q(t));try{let n=process.cwd();process.chdir(e);let s=process.env.EXTENSION_ENV==="development"?"inherit":"ignore",a=(0,Ge.spawn)(i,r,{stdio:s});await new Promise((l,m)=>{a.on("close",g=>{process.chdir(n),g!==0?m(new Error(Z(i,r,g))):l()}),a.on("error",g=>{process.chdir(n),console.error(ee(t,g)),m(g)})})}catch(n){console.error(te(t,n)),process.exit(1)}}async function it(e,{template:t="init",noInstall:i=!1}){if(!e)throw new Error(V());if(e.startsWith("http"))throw new Error(X());let r=C.default.isAbsolute(e)?e:C.default.join(process.cwd(),e),n=C.default.basename(r);try{await ve(r,n),t==="init"?await be(r,n,t):await Te(r,n,t),await Fe(r,n,t),i||await Me(r,n),await _e(r,n),await Ne(r,n),await Ae(r,n),await We(r),Ee(t)&&await Re(r,n);let s=await L(r,n);console.log(s)}catch(s){throw console.error(s),s}}0&&(module.exports={extensionCreate});
|
package/package.json
CHANGED
|
@@ -9,7 +9,7 @@
|
|
|
9
9
|
"node": ">=18"
|
|
10
10
|
},
|
|
11
11
|
"name": "extension-create",
|
|
12
|
-
"version": "2.0.0-alpha.
|
|
12
|
+
"version": "2.0.0-alpha.7",
|
|
13
13
|
"description": "The Extension.js create step",
|
|
14
14
|
"main": "./dist/module.js",
|
|
15
15
|
"types": "./dist/module.d.ts",
|
|
@@ -32,7 +32,7 @@
|
|
|
32
32
|
"@colors/colors": "^1.6.0",
|
|
33
33
|
"cross-spawn": "^7.0.3",
|
|
34
34
|
"detect-package-manager": "^3.0.2",
|
|
35
|
-
"go-git-it": "
|
|
35
|
+
"go-git-it": "2.0.4"
|
|
36
36
|
},
|
|
37
37
|
"devDependencies": {
|
|
38
38
|
"@types/cross-spawn": "^6.0.6",
|