extension-create 1.2.2 → 1.2.4

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 (3) hide show
  1. package/README.md +0 -4
  2. package/dist/cli.js +35 -15
  3. package/package.json +4 -2
package/README.md CHANGED
@@ -102,10 +102,6 @@ If you want to target a specific browser, just pass the `--browser` flag to the
102
102
 
103
103
  That's it!
104
104
 
105
- ## Program Options Table
106
-
107
- For a list of all commands available, see [OPTIONS_TABLE.md](OPTIONS_TABLE.md).
108
-
109
105
  ## License
110
106
 
111
107
  MIT (c) Cezar Augusto.
package/dist/cli.js CHANGED
@@ -30,6 +30,28 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
30
30
  // cli.ts
31
31
  var import_semver = __toESM(require("semver"));
32
32
  var import_commander = require("commander");
33
+ var import_create = __toESM(require("@extension-create/create"));
34
+ var import_develop = require("@extension-create/develop");
35
+
36
+ // check-updates.ts
37
+ var import_update_check = __toESM(require("update-check"));
38
+ var import_safe = require("@colors/colors/safe");
39
+ async function checkUpdates(packageJson) {
40
+ let update = null;
41
+ try {
42
+ update = await (0, import_update_check.default)(packageJson);
43
+ } catch (err) {
44
+ if (process.env.EXTENSION_ENV === "development") {
45
+ console.error((0, import_safe.bold)((0, import_safe.red)(`Failed to check for updates: ${err}`)));
46
+ }
47
+ }
48
+ if (update) {
49
+ console.log(
50
+ `Your \u{1F9E9} ${(0, import_safe.bold)("extension-create")} version is ${(0, import_safe.red)("outdated")}.
51
+ The latest version is ${(0, import_safe.bold)(update.latest)}. Please update!`
52
+ );
53
+ }
54
+ }
33
55
 
34
56
  // messages/blockingErrors.ts
35
57
  var blockingErrors_exports = {};
@@ -117,7 +139,7 @@ var package_default = {
117
139
  node: ">=18"
118
140
  },
119
141
  name: "extension-create",
120
- version: "1.2.2",
142
+ version: "1.2.4",
121
143
  description: "Create cross-browser extensions with no build configuration.",
122
144
  main: "./dist/cli.js",
123
145
  types: "./dist/cli.d.ts",
@@ -155,10 +177,12 @@ var package_default = {
155
177
  "typescript"
156
178
  ],
157
179
  dependencies: {
180
+ "@colors/colors": "^1.6.0",
158
181
  "@extension-create/create": "*",
159
182
  "@extension-create/develop": "*",
160
183
  commander: "^11.1.0",
161
- semver: "^7.5.4"
184
+ semver: "^7.5.4",
185
+ "update-check": "^1.5.4"
162
186
  },
163
187
  devDependencies: {
164
188
  "@types/jest": "^29.5.11",
@@ -175,18 +199,18 @@ var package_default = {
175
199
  };
176
200
 
177
201
  // cli.ts
178
- var import_create = __toESM(require("@extension-create/create"));
179
- var import_develop = require("@extension-create/develop");
202
+ checkUpdates(package_default);
180
203
  if (import_semver.default.lte(process.version, "18.0.0")) {
181
204
  messages_default.unsupportedNodeVersion();
182
205
  process.exit(1);
183
206
  }
184
207
  var extensionCreate = import_commander.program;
185
- var isExtensionCreateNamespace = package_default.name === "extension-create";
208
+ var isExtensionCreateNamespace = package_default.name !== "extension";
186
209
  if (process.env.EXTENSION_ENV === "development") {
187
210
  console.log(`Running extension-create via ${package_default.name}...`);
188
211
  }
189
212
  extensionCreate.name(package_default.name).description(package_default.description).version(package_default.version).addHelpText("after", messages_default.programHelp());
213
+ var vendors = (browser) => browser === "all" ? "chrome,edge".split(",") : browser.split(",");
190
214
  extensionCreate.command("create", { isDefault: isExtensionCreateNamespace }).arguments("<project-name|project-path>").usage("create <project-name|project-path> [options]").description("Creates a new extension.").option(
191
215
  "-t, --template <template-name>",
192
216
  "specify a template for the created project"
@@ -195,10 +219,9 @@ extensionCreate.command("create", { isDefault: isExtensionCreateNamespace }).arg
195
219
  template,
196
220
  ...otherCommandOptions
197
221
  }) {
198
- const vendors = browser.split(",");
199
222
  switch (pathOrRemoteUrl) {
200
223
  case "dev":
201
- for (const vendor of vendors) {
224
+ for (const vendor of vendors(browser)) {
202
225
  await (0, import_develop.extensionDev)(pathOrRemoteUrl, {
203
226
  mode: "development",
204
227
  browser: vendor,
@@ -207,7 +230,7 @@ extensionCreate.command("create", { isDefault: isExtensionCreateNamespace }).arg
207
230
  }
208
231
  break;
209
232
  case "start":
210
- for (const vendor of vendors) {
233
+ for (const vendor of vendors(browser)) {
211
234
  await (0, import_develop.extensionStart)(pathOrRemoteUrl, {
212
235
  mode: "production",
213
236
  browser: vendor,
@@ -216,7 +239,7 @@ extensionCreate.command("create", { isDefault: isExtensionCreateNamespace }).arg
216
239
  }
217
240
  break;
218
241
  case "build":
219
- for (const vendor of vendors) {
242
+ for (const vendor of vendors(browser)) {
220
243
  await (0, import_develop.extensionBuild)(pathOrRemoteUrl, {
221
244
  browser: vendor,
222
245
  ...otherCommandOptions
@@ -241,8 +264,7 @@ extensionCreate.command("dev").arguments("[project-path|remote-url]").usage("dev
241
264
  "-p, --port <number>",
242
265
  "what port should extension-create/develop run. Defaults to `3000`"
243
266
  ).action(async function(pathOrRemoteUrl, { browser = "chrome", ...devOptions }) {
244
- const vendors = browser.split(",");
245
- for (const vendor of vendors) {
267
+ for (const vendor of vendors(browser)) {
246
268
  await (0, import_develop.extensionDev)(pathOrRemoteUrl, {
247
269
  mode: "development",
248
270
  browser: vendor,
@@ -263,8 +285,7 @@ extensionCreate.command("start").arguments("[project-path|remote-url]").usage("s
263
285
  "-p, --port <number>",
264
286
  "what port should extension-create/develop run. Defaults to `3000`"
265
287
  ).action(async function(pathOrRemoteUrl, { browser = "chrome", ...startOptions }) {
266
- const vendors = browser.split(",");
267
- for (const vendor of vendors) {
288
+ for (const vendor of vendors(browser)) {
268
289
  await (0, import_develop.extensionStart)(pathOrRemoteUrl, {
269
290
  mode: "production",
270
291
  browser: vendor,
@@ -279,8 +300,7 @@ extensionCreate.command("build").arguments("[project-name]").usage("build [path-
279
300
  "--polyfill <boolean>",
280
301
  "whether or not to apply the cross-browser polyfill. Defaults to `false`"
281
302
  ).action(async function(pathOrRemoteUrl, { browser = "chrome", ...buildOptions }) {
282
- const vendors = browser.split(",");
283
- for (const vendor of vendors) {
303
+ for (const vendor of vendors(browser)) {
284
304
  await (0, import_develop.extensionBuild)(pathOrRemoteUrl, {
285
305
  browser: vendor,
286
306
  ...buildOptions
package/package.json CHANGED
@@ -9,7 +9,7 @@
9
9
  "node": ">=18"
10
10
  },
11
11
  "name": "extension-create",
12
- "version": "1.2.2",
12
+ "version": "1.2.4",
13
13
  "description": "Create cross-browser extensions with no build configuration.",
14
14
  "main": "./dist/cli.js",
15
15
  "types": "./dist/cli.d.ts",
@@ -47,10 +47,12 @@
47
47
  "typescript"
48
48
  ],
49
49
  "dependencies": {
50
+ "@colors/colors": "^1.6.0",
50
51
  "@extension-create/create": "*",
51
52
  "@extension-create/develop": "*",
52
53
  "commander": "^11.1.0",
53
- "semver": "^7.5.4"
54
+ "semver": "^7.5.4",
55
+ "update-check": "^1.5.4"
54
56
  },
55
57
  "devDependencies": {
56
58
  "@types/jest": "^29.5.11",