@akanjs/cli 0.0.88 → 0.0.89

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/index.js CHANGED
@@ -764,10 +764,10 @@ var getDefaultFileScan = () => ({
764
764
 
765
765
  // pkgs/@akanjs/devkit/src/executors.ts
766
766
  var import_child_process = require("child_process");
767
+ var import_dotenv = __toESM(require("dotenv"), 1);
767
768
  var import_fs7 = __toESM(require("fs"), 1);
768
769
  var import_promises = __toESM(require("fs/promises"), 1);
769
770
  var import_path3 = __toESM(require("path"), 1);
770
- var import_dotenv = __toESM(require("dotenv"), 1);
771
771
 
772
772
  // pkgs/@akanjs/devkit/src/dependencyScanner.ts
773
773
  var fs7 = __toESM(require("fs"), 1);
@@ -1206,10 +1206,10 @@ var WorkspaceExecutor = class _WorkspaceExecutor extends Executor {
1206
1206
  }
1207
1207
  async commit(message, { init = false, add = true } = {}) {
1208
1208
  if (init)
1209
- await this.exec(`git init`);
1209
+ await this.exec(`git init --quiet`);
1210
1210
  if (add)
1211
1211
  await this.exec(`git add .`);
1212
- await this.exec(`git commit -m "${message}"`);
1212
+ await this.exec(`git commit --quiet -m "${message}"`);
1213
1213
  }
1214
1214
  async #getDirHasFile(basePath2, targetFilename) {
1215
1215
  const AVOID_DIRS = ["node_modules", "dist", "public", "./next"];
@@ -1444,8 +1444,10 @@ var SysExecutor = class extends Executor {
1444
1444
  }
1445
1445
  };
1446
1446
  var AppExecutor = class _AppExecutor extends SysExecutor {
1447
+ dist;
1447
1448
  constructor({ workspace, name }) {
1448
1449
  super({ workspace, name, type: "app" });
1450
+ this.dist = new Executor(`${name} Dist App Executor`, `${this.workspace.workspaceRoot}/dist/apps/${name}`);
1449
1451
  }
1450
1452
  static from(executor, name) {
1451
1453
  if (executor instanceof WorkspaceExecutor)
@@ -1475,23 +1477,13 @@ var AppExecutor = class _AppExecutor extends SysExecutor {
1475
1477
  );
1476
1478
  }
1477
1479
  };
1478
- var DistAppExecutor = class _DistAppExecutor extends Executor {
1479
- name;
1480
- constructor({ workspace, name }) {
1481
- super(`${name} Dist App Executor`, `${workspace.workspaceRoot}/dist/apps/${name}`);
1482
- this.name = name;
1483
- }
1484
- static from(executor, name) {
1485
- if (executor instanceof WorkspaceExecutor)
1486
- return new _DistAppExecutor({ workspace: executor, name });
1487
- return new _DistAppExecutor({ workspace: executor.workspace, name });
1488
- }
1489
- };
1490
1480
  var LibExecutor = class _LibExecutor extends SysExecutor {
1491
1481
  workspaceRoot;
1492
1482
  repoName;
1483
+ dist;
1493
1484
  constructor({ workspace, name }) {
1494
1485
  super({ workspace, name, type: "lib" });
1486
+ this.dist = new Executor(`${name} Dist Lib Executor`, `${this.workspace.workspaceRoot}/dist/libs/${name}`);
1495
1487
  }
1496
1488
  static from(executor, name) {
1497
1489
  if (executor instanceof WorkspaceExecutor)
@@ -1510,10 +1502,12 @@ var LibExecutor = class _LibExecutor extends SysExecutor {
1510
1502
  var PkgExecutor = class _PkgExecutor extends Executor {
1511
1503
  workspace;
1512
1504
  name;
1505
+ dist;
1513
1506
  constructor({ workspace = WorkspaceExecutor.fromRoot(), name }) {
1514
1507
  super(`${name} Pkg Executor`, `${workspace.workspaceRoot}/pkgs/${name}`);
1515
1508
  this.workspace = workspace;
1516
1509
  this.name = name;
1510
+ this.dist = new Executor(`${name} Dist Pkg Executor`, `${this.workspace.workspaceRoot}/dist/pkgs/${name}`);
1517
1511
  }
1518
1512
  static from(executor, name) {
1519
1513
  if (executor instanceof WorkspaceExecutor)
@@ -1543,24 +1537,6 @@ var PkgExecutor = class _PkgExecutor extends Executor {
1543
1537
  return pkgScanResult;
1544
1538
  }
1545
1539
  };
1546
- var DistPkgExecutor = class _DistPkgExecutor extends Executor {
1547
- workspaceRoot;
1548
- repoName;
1549
- name;
1550
- constructor({ workspaceRoot, repoName, name }) {
1551
- super(`${name} Dist Pkg Executor`, `${workspaceRoot}/dist/pkgs/${name}`);
1552
- this.workspaceRoot = workspaceRoot;
1553
- this.repoName = repoName;
1554
- this.name = name;
1555
- }
1556
- static from(workspaceExecutor, name) {
1557
- return new _DistPkgExecutor({
1558
- workspaceRoot: workspaceExecutor.workspaceRoot,
1559
- repoName: workspaceExecutor.repoName,
1560
- name
1561
- });
1562
- }
1563
- };
1564
1540
 
1565
1541
  // pkgs/@akanjs/devkit/src/constants.ts
1566
1542
  var import_os = require("os");
@@ -2100,7 +2076,9 @@ var LibraryRunner = class {
2100
2076
  }
2101
2077
  async installLibrary(workspace, libName) {
2102
2078
  workspace.log(`Installing ${libName} library as git subtree...`);
2103
- await workspace.exec(`git subtree add --prefix=libs/${libName} git@github.com:akan-team/${libName}.git main`);
2079
+ await workspace.exec(
2080
+ `git subtree add --quiet --prefix=libs/${libName} git@github.com:akan-team/${libName}.git main`
2081
+ );
2104
2082
  await workspace.cp(`libs/${libName}/env/env.server.example.ts`, `libs/${libName}/env/env.server.testing.ts`);
2105
2083
  workspace.setTsPaths("lib", libName);
2106
2084
  await workspace.commit(`Add ${libName} library`);
@@ -2129,18 +2107,18 @@ var LibraryRunner = class {
2129
2107
  });
2130
2108
  const newRootPackageJson = { ...rootPackageJson, dependencies, devDependencies };
2131
2109
  lib.workspace.writeJson("package.json", newRootPackageJson);
2132
- await lib.workspace.spawn("pnpm", ["install"]);
2110
+ await lib.workspace.spawn("pnpm", ["install", "--reporter=silent"]);
2133
2111
  await lib.workspace.commit(`Merge ${lib.name} library dependencies`);
2134
2112
  }
2135
2113
  async pushLibrary(lib, branch) {
2136
2114
  await lib.workspace.exec(
2137
- `git subtree push --prefix=libs/${lib.name} git@github.com:akan-team/${lib.name}.git ${branch}`
2115
+ `git subtree push --quiet --prefix=libs/${lib.name} git@github.com:akan-team/${lib.name}.git ${branch}`
2138
2116
  );
2139
2117
  lib.logger.log(`${lib.name} library pushed to ${branch} branch`);
2140
2118
  }
2141
2119
  async pullLibrary(lib, branch) {
2142
2120
  await lib.workspace.exec(
2143
- `git subtree pull --prefix=libs/${lib.name} git@github.com:akan-team/${lib.name}.git ${branch}`
2121
+ `git subtree pull --quiet --prefix=libs/${lib.name} git@github.com:akan-team/${lib.name}.git ${branch}`
2144
2122
  );
2145
2123
  lib.logger.log(`${lib.name} library pulled from ${branch} branch`);
2146
2124
  }
@@ -2216,6 +2194,7 @@ var esbuild = __toESM(require("esbuild"));
2216
2194
  var import_fs12 = __toESM(require("fs"));
2217
2195
  var import_promises2 = __toESM(require("fs/promises"));
2218
2196
  var import_js_yaml2 = __toESM(require("js-yaml"));
2197
+ var import_open = __toESM(require("open"));
2219
2198
  var import_ora2 = __toESM(require("ora"));
2220
2199
  var import_path4 = __toESM(require("path"));
2221
2200
  var vite = __toESM(require("vite"));
@@ -3216,16 +3195,16 @@ var ApplicationRunner = class {
3216
3195
  ...env
3217
3196
  };
3218
3197
  }
3219
- async #prepareCommand(app, distApp, type, target) {
3220
- await distApp.exec(`rm -rf ${target}`);
3198
+ async #prepareCommand(app, type, target) {
3199
+ await app.dist.exec(`rm -rf ${target}`);
3221
3200
  if (target === "frontend") {
3222
3201
  await app.exec("rm -rf .next");
3223
3202
  app.writeFile("next.config.ts", defaultNextConfigFile);
3224
3203
  }
3225
3204
  return { env: this.#getEnv(app, { AKAN_COMMAND_TYPE: type }) };
3226
3205
  }
3227
- async buildBackend(app, distApp) {
3228
- await this.#prepareCommand(app, distApp, "serve", "backend");
3206
+ async buildBackend(app) {
3207
+ await this.#prepareCommand(app, "serve", "backend");
3229
3208
  const akanConfig = await app.getConfig("build");
3230
3209
  const buildResult = await esbuild.build({
3231
3210
  write: false,
@@ -3233,12 +3212,12 @@ var ApplicationRunner = class {
3233
3212
  bundle: true,
3234
3213
  packages: "external",
3235
3214
  platform: "node",
3236
- outdir: `${distApp.cwdPath}/backend`,
3215
+ outdir: `${app.dist.cwdPath}/backend`,
3237
3216
  logLevel: "warning"
3238
3217
  });
3239
3218
  const rootPackageJson = app.workspace.readJson("package.json");
3240
3219
  const dependencies = extractDependencies(buildResult.outputFiles, rootPackageJson);
3241
- buildResult.outputFiles.map((file) => distApp.writeFile(file.path, file.text));
3220
+ buildResult.outputFiles.map((file) => app.dist.writeFile(file.path, file.text));
3242
3221
  const appPackageJson = {
3243
3222
  name: `${app.name}/backend`,
3244
3223
  description: `${app.name} backend`,
@@ -3247,31 +3226,33 @@ var ApplicationRunner = class {
3247
3226
  engines: { node: ">=22" },
3248
3227
  dependencies
3249
3228
  };
3250
- distApp.writeJson("backend/package.json", appPackageJson);
3251
- distApp.writeFile(import_path4.default.join(distApp.cwdPath, "backend", "Dockerfile"), akanConfig.backend.dockerfile);
3229
+ app.dist.writeJson("backend/package.json", appPackageJson);
3230
+ app.dist.writeFile(import_path4.default.join(app.dist.cwdPath, "backend", "Dockerfile"), akanConfig.backend.dockerfile);
3252
3231
  }
3253
- async serveBackend(app, distApp) {
3254
- const { env } = await this.#prepareCommand(app, distApp, "serve", "backend");
3232
+ async serveBackend(app, { open: open2 = false } = {}) {
3233
+ const { env } = await this.#prepareCommand(app, "serve", "backend");
3255
3234
  const ctx = await esbuild.context({
3256
3235
  write: true,
3257
3236
  entryPoints: [`${app.cwdPath}/main.ts`],
3258
3237
  bundle: true,
3259
3238
  packages: "external",
3260
3239
  platform: "node",
3261
- outdir: import_path4.default.join(distApp.cwdPath, "backend"),
3240
+ outdir: import_path4.default.join(app.dist.cwdPath, "backend"),
3262
3241
  logLevel: "warning"
3263
3242
  });
3264
3243
  await ctx.watch();
3265
3244
  await sleep(100);
3266
- await distApp.spawn("node", ["--watch", "backend/main.js"], { env });
3245
+ if (open2)
3246
+ setTimeout(() => (0, import_open.default)("http://localhost:8080/backend/graphql"), 3e3);
3247
+ await app.dist.spawn("node", ["--watch", "backend/main.js"], { env });
3267
3248
  }
3268
- async buildFrontend(app, distApp) {
3269
- const { env } = await this.#prepareCommand(app, distApp, "build", "frontend");
3249
+ async buildFrontend(app) {
3250
+ const { env } = await this.#prepareCommand(app, "build", "frontend");
3270
3251
  const akanConfig = await app.getConfig("build");
3271
3252
  await app.spawn("npx", ["next", "build", "--no-lint"], { env });
3272
3253
  const buildResult = await esbuild.build({
3273
3254
  entryPoints: [`${app.cwdPath}/next.config.ts`],
3274
- outdir: `${distApp.cwdPath}/frontend`,
3255
+ outdir: `${app.dist.cwdPath}/frontend`,
3275
3256
  bundle: true,
3276
3257
  packages: "external",
3277
3258
  platform: "node",
@@ -3282,7 +3263,7 @@ var ApplicationRunner = class {
3282
3263
  });
3283
3264
  const rootPackageJson = app.workspace.readJson("package.json");
3284
3265
  const dependencies = extractDependencies(buildResult.outputFiles, rootPackageJson, ["next", "react", "react-dom"]);
3285
- buildResult.outputFiles.map((file) => distApp.writeFile(file.path, file.text));
3266
+ buildResult.outputFiles.map((file) => app.dist.writeFile(file.path, file.text));
3286
3267
  const appPackageJson = {
3287
3268
  name: `${app.name}/frontend`,
3288
3269
  description: `${app.name} frontend`,
@@ -3293,26 +3274,28 @@ var ApplicationRunner = class {
3293
3274
  start: "next start"
3294
3275
  }
3295
3276
  };
3296
- distApp.writeJson("frontend/package.json", appPackageJson);
3277
+ app.dist.writeJson("frontend/package.json", appPackageJson);
3297
3278
  await Promise.all([
3298
- app.cp(".next", import_path4.default.join(distApp.cwdPath, "frontend", ".next")),
3299
- app.cp("public", import_path4.default.join(distApp.cwdPath, "frontend", "public"))
3279
+ app.cp(".next", import_path4.default.join(app.dist.cwdPath, "frontend", ".next")),
3280
+ app.cp("public", import_path4.default.join(app.dist.cwdPath, "frontend", "public"))
3300
3281
  ]);
3301
- distApp.writeFile("frontend/Dockerfile", akanConfig.frontend.dockerfile);
3282
+ app.dist.writeFile("frontend/Dockerfile", akanConfig.frontend.dockerfile);
3302
3283
  }
3303
- async serveFrontend(app, distApp) {
3304
- const { env } = await this.#prepareCommand(app, distApp, "serve", "frontend");
3284
+ async serveFrontend(app, { open: open2 = false } = {}) {
3285
+ const { env } = await this.#prepareCommand(app, "serve", "frontend");
3286
+ if (open2)
3287
+ setTimeout(() => (0, import_open.default)("http://localhost:4200"), 3e3);
3305
3288
  await app.spawn("npx", ["next", "dev", "-p", "4200"], { env });
3306
3289
  }
3307
- async #getViteConfig(app, distApp) {
3308
- const { env } = await this.#prepareCommand(app, distApp, "build", "csr");
3290
+ async #getViteConfig(app) {
3291
+ const { env } = await this.#prepareCommand(app, "build", "csr");
3309
3292
  const processEnv = env;
3310
3293
  const akanjsPrefix = process.env.USE_AKANJS_PKGS === "true" ? "../../../../pkgs/" : "";
3311
3294
  const config = vite.defineConfig({
3312
3295
  root: `${app.cwdPath}/app`,
3313
3296
  base: "/",
3314
3297
  build: {
3315
- outDir: `${distApp.cwdPath}/csr`,
3298
+ outDir: `${app.dist.cwdPath}/csr`,
3316
3299
  sourcemap: false,
3317
3300
  emptyOutDir: true,
3318
3301
  rollupOptions: { external: ["next/server"], input: `${app.cwdPath}/app/index.html` }
@@ -3370,15 +3353,17 @@ var ApplicationRunner = class {
3370
3353
  });
3371
3354
  return config;
3372
3355
  }
3373
- async buildCsr(app, distApp) {
3374
- const config = await this.#getViteConfig(app, distApp);
3356
+ async buildCsr(app) {
3357
+ const config = await this.#getViteConfig(app);
3375
3358
  await vite.build(config);
3376
3359
  }
3377
- async serveCsr(app, distApp) {
3378
- const config = await this.#getViteConfig(app, distApp);
3360
+ async serveCsr(app, { open: open2 = false } = {}) {
3361
+ const config = await this.#getViteConfig(app);
3379
3362
  const server = await vite.createServer(config);
3380
3363
  await server.listen(4201);
3381
3364
  app.log(`CSR server is running on http://localhost:4201`);
3365
+ if (open2)
3366
+ setTimeout(() => (0, import_open.default)("http://localhost:4201"), 3e3);
3382
3367
  }
3383
3368
  async #prepareIos(app) {
3384
3369
  const isAdded = import_fs12.default.existsSync(`${app.cwdPath}/ios/App/Podfile`);
@@ -3495,24 +3480,23 @@ var ApplicationRunner = class {
3495
3480
  await capacitorApp.save();
3496
3481
  }
3497
3482
  async releaseSource(app, { rebuild, buildNum = 0, environment = "debug", local = true } = {}) {
3498
- const distApp = DistAppExecutor.from(app, app.name);
3499
3483
  const buildRoot = `${app.workspace.workspaceRoot}/releases/builds/${app.name}`;
3500
3484
  const appVersionInfo = import_js_yaml2.default.load(app.readFile("config.yaml"));
3501
3485
  const platformVersion = appVersionInfo.platforms.android.versionName;
3502
3486
  if (import_fs12.default.existsSync(buildRoot))
3503
3487
  await import_promises2.default.rm(buildRoot, { recursive: true, force: true });
3504
3488
  await import_promises2.default.mkdir(buildRoot, { recursive: true });
3505
- if (rebuild || !import_fs12.default.existsSync(`${distApp.cwdPath}/backend`))
3506
- await this.buildBackend(app, distApp);
3507
- if (rebuild || !import_fs12.default.existsSync(`${distApp.cwdPath}/frontend`))
3508
- await this.buildFrontend(app, distApp);
3509
- if (rebuild || !import_fs12.default.existsSync(`${distApp.cwdPath}/csr`))
3510
- await this.buildCsr(app, distApp);
3489
+ if (rebuild || !import_fs12.default.existsSync(`${app.dist.cwdPath}/backend`))
3490
+ await this.buildBackend(app);
3491
+ if (rebuild || !import_fs12.default.existsSync(`${app.dist.cwdPath}/frontend`))
3492
+ await this.buildFrontend(app);
3493
+ if (rebuild || !import_fs12.default.existsSync(`${app.dist.cwdPath}/csr`))
3494
+ await this.buildCsr(app);
3511
3495
  const buildVersion = `${platformVersion}-${buildNum}`;
3512
3496
  const buildPath = `${buildRoot}/${buildVersion}`;
3513
3497
  await import_promises2.default.mkdir(buildPath, { recursive: true });
3514
- await import_promises2.default.cp(`${distApp.cwdPath}/backend`, `${buildPath}/backend`, { recursive: true });
3515
- await import_promises2.default.cp(distApp.cwdPath, buildRoot, { recursive: true });
3498
+ await import_promises2.default.cp(`${app.dist.cwdPath}/backend`, `${buildPath}/backend`, { recursive: true });
3499
+ await import_promises2.default.cp(app.dist.cwdPath, buildRoot, { recursive: true });
3516
3500
  await import_promises2.default.rm(`${buildRoot}/frontend/.next`, { recursive: true, force: true });
3517
3501
  await app.workspace.spawn("tar", [
3518
3502
  "-zcf",
@@ -3521,8 +3505,8 @@ var ApplicationRunner = class {
3521
3505
  buildRoot,
3522
3506
  "./"
3523
3507
  ]);
3524
- if (import_fs12.default.existsSync(`${distApp.cwdPath}/csr`)) {
3525
- await import_promises2.default.cp(`${distApp.cwdPath}/csr`, "./csr", { recursive: true });
3508
+ if (import_fs12.default.existsSync(`${app.dist.cwdPath}/csr`)) {
3509
+ await import_promises2.default.cp(`${app.dist.cwdPath}/csr`, "./csr", { recursive: true });
3526
3510
  await app.workspace.spawn("zip", [
3527
3511
  "-r",
3528
3512
  `${app.workspace.workspaceRoot}/releases/builds/${app.name}-appBuild.zip`,
@@ -3541,7 +3525,7 @@ var ApplicationRunner = class {
3541
3525
  }
3542
3526
  }
3543
3527
  await import_promises2.default.mkdir(sourceRoot, { recursive: true });
3544
- await import_promises2.default.cp(distApp.cwdPath, `${sourceRoot}/apps/${app.name}`, { recursive: true });
3528
+ await import_promises2.default.cp(app.dist.cwdPath, `${sourceRoot}/apps/${app.name}`, { recursive: true });
3545
3529
  const libDeps = ["social", "shared", "platform", "util"];
3546
3530
  await Promise.all(
3547
3531
  libDeps.map(
@@ -3680,9 +3664,11 @@ var ApplicationRunner = class {
3680
3664
  var ApplicationScript = class {
3681
3665
  #runner = new ApplicationRunner();
3682
3666
  libraryScript = new LibraryScript();
3683
- async createApplication(appName, workspace) {
3667
+ async createApplication(appName, workspace, { serve = false } = {}) {
3684
3668
  const app = await this.#runner.createApplication(appName, workspace);
3685
3669
  await this.syncApplication(app);
3670
+ if (serve)
3671
+ await this.serve(app, { open: true });
3686
3672
  }
3687
3673
  async scanApplication(app, verbose = false) {
3688
3674
  const scanResult = await this.#runner.scanSync(app);
@@ -3697,64 +3683,78 @@ var ApplicationScript = class {
3697
3683
  for (const libName of scanResult.akanConfig.libs)
3698
3684
  await this.libraryScript.syncLibrary(LibExecutor.from(app, libName), { recursive: false });
3699
3685
  }
3700
- async build(app, distApp = DistAppExecutor.from(app, app.name)) {
3701
- await this.syncApplication(app);
3702
- await Promise.all([this.buildBackend(app, distApp), this.buildFrontend(app, distApp)]);
3703
- }
3704
- async serve(app, distApp = DistAppExecutor.from(app, app.name)) {
3705
- await this.syncApplication(app);
3706
- await Promise.all([this.#runner.serveBackend(app, distApp), this.#runner.serveFrontend(app, distApp)]);
3707
- }
3708
- async buildBackend(app, distApp = DistAppExecutor.from(app, app.name)) {
3709
- await this.syncApplication(app);
3710
- await this.#runner.buildBackend(app, distApp);
3711
- }
3712
- async serveBackend(app, distApp = DistAppExecutor.from(app, app.name)) {
3713
- await this.syncApplication(app);
3714
- await this.#runner.serveBackend(app, distApp);
3715
- }
3716
- async buildFrontend(app, distApp = DistAppExecutor.from(app, app.name)) {
3717
- await this.syncApplication(app);
3718
- await this.#runner.buildFrontend(app, distApp);
3719
- }
3720
- async serveFrontend(app, distApp = DistAppExecutor.from(app, app.name)) {
3721
- await this.syncApplication(app);
3722
- await this.#runner.serveFrontend(app, distApp);
3723
- }
3724
- async buildCsr(app, distApp = DistAppExecutor.from(app, app.name)) {
3725
- await this.syncApplication(app);
3726
- await this.#runner.buildCsr(app, distApp);
3727
- }
3728
- async serveCsr(app, distApp = DistAppExecutor.from(app, app.name)) {
3686
+ async build(app) {
3729
3687
  await this.syncApplication(app);
3730
- await this.#runner.serveCsr(app, distApp);
3688
+ await Promise.all([this.buildBackend(app), this.buildFrontend(app)]);
3731
3689
  }
3732
- async buildIos(app) {
3690
+ async serve(app, { open: open2 = false } = {}) {
3733
3691
  await this.syncApplication(app);
3734
- await this.#runner.buildCsr(app, DistAppExecutor.from(app, app.name));
3692
+ await Promise.all([this.serveBackend(app, { open: open2, sync: false }), this.serveFrontend(app, { open: open2, sync: false })]);
3693
+ }
3694
+ async buildBackend(app, { sync = true } = {}) {
3695
+ if (sync)
3696
+ await this.syncApplication(app);
3697
+ await this.#runner.buildBackend(app);
3698
+ }
3699
+ async serveBackend(app, { open: open2 = false, sync = true } = {}) {
3700
+ if (sync)
3701
+ await this.syncApplication(app);
3702
+ await this.#runner.serveBackend(app, { open: open2 });
3703
+ }
3704
+ async buildFrontend(app, { sync = true } = {}) {
3705
+ if (sync)
3706
+ await this.syncApplication(app);
3707
+ await this.#runner.buildFrontend(app);
3708
+ }
3709
+ async serveFrontend(app, { open: open2 = false, sync = true } = {}) {
3710
+ if (sync)
3711
+ await this.syncApplication(app);
3712
+ await this.#runner.serveFrontend(app, { open: open2 });
3713
+ }
3714
+ async buildCsr(app, { sync = true } = {}) {
3715
+ if (sync)
3716
+ await this.syncApplication(app);
3717
+ await this.#runner.buildCsr(app);
3718
+ }
3719
+ async serveCsr(app, { open: open2 = false, sync = true } = {}) {
3720
+ if (sync)
3721
+ await this.syncApplication(app);
3722
+ await this.#runner.serveCsr(app, { open: open2 });
3723
+ }
3724
+ async buildIos(app, { sync = true } = {}) {
3725
+ if (sync)
3726
+ await this.syncApplication(app);
3735
3727
  await this.#runner.buildIos(app);
3736
3728
  }
3737
- async serveIos(app, { open: open2 = false, operation = "local" } = {}) {
3738
- await this.syncApplication(app);
3739
- await this.#runner.buildCsr(app, DistAppExecutor.from(app, app.name));
3729
+ async serveIos(app, {
3730
+ open: open2 = false,
3731
+ operation = "local",
3732
+ sync = true
3733
+ } = {}) {
3734
+ if (sync)
3735
+ await this.syncApplication(app);
3740
3736
  await this.#runner.serveIos(app, { open: open2, operation });
3741
3737
  }
3742
- async releaseIos(app) {
3743
- await this.buildCsr(app);
3738
+ async releaseIos(app, { sync = true } = {}) {
3739
+ await this.buildCsr(app, { sync });
3744
3740
  await this.#runner.releaseIos(app);
3745
3741
  }
3746
- async buildAndroid(app) {
3747
- await this.syncApplication(app);
3748
- await this.#runner.buildCsr(app, DistAppExecutor.from(app, app.name));
3742
+ async buildAndroid(app, { sync = true } = {}) {
3743
+ if (sync)
3744
+ await this.syncApplication(app);
3749
3745
  await this.#runner.buildAndroid(app);
3750
3746
  }
3751
- async serveAndroid(app, { open: open2 = false, operation = "local" } = {}) {
3752
- await this.syncApplication(app);
3753
- await this.#runner.buildCsr(app, DistAppExecutor.from(app, app.name));
3747
+ async serveAndroid(app, {
3748
+ open: open2 = false,
3749
+ operation = "local",
3750
+ sync = true
3751
+ } = {}) {
3752
+ if (sync)
3753
+ await this.syncApplication(app);
3754
3754
  await this.#runner.serveAndroid(app, { open: open2, operation });
3755
3755
  }
3756
- async releaseAndroid(app) {
3757
- await this.buildCsr(app);
3756
+ async releaseAndroid(app, { sync = true } = {}) {
3757
+ await this.buildCsr(app, { sync });
3758
3758
  await this.#runner.releaseAndroid(app);
3759
3759
  }
3760
3760
  async dumpDatabase(app, environment) {
@@ -3797,8 +3797,8 @@ var ApplicationScript = class {
3797
3797
  // pkgs/@akanjs/cli/src/application/application.command.ts
3798
3798
  var ApplicationCommand = class {
3799
3799
  applicationScript = new ApplicationScript();
3800
- async createApplication(name, workspace) {
3801
- await this.applicationScript.createApplication(name, workspace);
3800
+ async createApplication(name, serve, workspace) {
3801
+ await this.applicationScript.createApplication(name, workspace, { serve });
3802
3802
  }
3803
3803
  async removeApplication(app, workspace) {
3804
3804
  }
@@ -3823,17 +3823,17 @@ var ApplicationCommand = class {
3823
3823
  async buildAndroid(app) {
3824
3824
  await this.applicationScript.buildAndroid(app);
3825
3825
  }
3826
- async serve(app) {
3827
- await this.applicationScript.serve(app);
3826
+ async serve(app, open2) {
3827
+ await this.applicationScript.serve(app, { open: open2 });
3828
3828
  }
3829
- async serveBackend(app) {
3830
- await this.applicationScript.serveBackend(app);
3829
+ async serveBackend(app, open2) {
3830
+ await this.applicationScript.serveBackend(app, { open: open2 });
3831
3831
  }
3832
- async serveFrontend(app) {
3833
- await this.applicationScript.serveFrontend(app);
3832
+ async serveFrontend(app, open2) {
3833
+ await this.applicationScript.serveFrontend(app, { open: open2 });
3834
3834
  }
3835
- async serveCsr(app) {
3836
- await this.applicationScript.serveCsr(app);
3835
+ async serveCsr(app, open2) {
3836
+ await this.applicationScript.serveCsr(app, { open: open2 });
3837
3837
  }
3838
3838
  async serveIos(app, open2, release) {
3839
3839
  await this.applicationScript.serveIos(app, { open: open2, operation: release ? "release" : "local" });
@@ -3875,7 +3875,8 @@ var ApplicationCommand = class {
3875
3875
  __decorateClass([
3876
3876
  Target.Public(),
3877
3877
  __decorateParam(0, Option("name", { desc: "name of application" })),
3878
- __decorateParam(1, Workspace())
3878
+ __decorateParam(1, Option("serve", { type: "boolean", desc: "serve application", default: false })),
3879
+ __decorateParam(2, Workspace())
3879
3880
  ], ApplicationCommand.prototype, "createApplication", 1);
3880
3881
  __decorateClass([
3881
3882
  Target.Public(),
@@ -3912,31 +3913,35 @@ __decorateClass([
3912
3913
  ], ApplicationCommand.prototype, "buildAndroid", 1);
3913
3914
  __decorateClass([
3914
3915
  Target.Public({ short: true }),
3915
- __decorateParam(0, App())
3916
+ __decorateParam(0, App()),
3917
+ __decorateParam(1, Option("open", { type: "boolean", desc: "open web browser", default: false }))
3916
3918
  ], ApplicationCommand.prototype, "serve", 1);
3917
3919
  __decorateClass([
3918
3920
  Target.Public({ short: true }),
3919
- __decorateParam(0, App())
3921
+ __decorateParam(0, App()),
3922
+ __decorateParam(1, Option("open", { type: "boolean", desc: "open graphql playground", default: false }))
3920
3923
  ], ApplicationCommand.prototype, "serveBackend", 1);
3921
3924
  __decorateClass([
3922
3925
  Target.Public({ short: true }),
3923
- __decorateParam(0, App())
3926
+ __decorateParam(0, App()),
3927
+ __decorateParam(1, Option("open", { type: "boolean", desc: "open web browser", default: false }))
3924
3928
  ], ApplicationCommand.prototype, "serveFrontend", 1);
3925
3929
  __decorateClass([
3926
3930
  Target.Public({ short: true }),
3927
- __decorateParam(0, App())
3931
+ __decorateParam(0, App()),
3932
+ __decorateParam(1, Option("open", { type: "boolean", desc: "open web browser", default: false }))
3928
3933
  ], ApplicationCommand.prototype, "serveCsr", 1);
3929
3934
  __decorateClass([
3930
3935
  Target.Public({ short: true }),
3931
3936
  __decorateParam(0, App()),
3932
- __decorateParam(1, Option("open", { desc: "open ios simulator", default: false })),
3933
- __decorateParam(2, Option("release", { desc: "release mode", default: false }))
3937
+ __decorateParam(1, Option("open", { type: "boolean", desc: "open ios simulator", default: false })),
3938
+ __decorateParam(2, Option("release", { type: "boolean", desc: "release mode", default: false }))
3934
3939
  ], ApplicationCommand.prototype, "serveIos", 1);
3935
3940
  __decorateClass([
3936
3941
  Target.Public({ short: true }),
3937
3942
  __decorateParam(0, App()),
3938
- __decorateParam(1, Option("open", { desc: "open android simulator", default: false })),
3939
- __decorateParam(2, Option("release", { desc: "release mode", default: false }))
3943
+ __decorateParam(1, Option("open", { type: "boolean", desc: "open android simulator", default: false })),
3944
+ __decorateParam(2, Option("release", { type: "boolean", desc: "release mode", default: false }))
3940
3945
  ], ApplicationCommand.prototype, "serveAndroid", 1);
3941
3946
  __decorateClass([
3942
3947
  Target.Public(),
@@ -3949,10 +3954,10 @@ __decorateClass([
3949
3954
  __decorateClass([
3950
3955
  Target.Public(),
3951
3956
  __decorateParam(0, App()),
3952
- __decorateParam(1, Option("rebuild", { desc: "rebuild", default: false })),
3957
+ __decorateParam(1, Option("rebuild", { type: "boolean", desc: "rebuild", default: false })),
3953
3958
  __decorateParam(2, Option("buildNum", { desc: "build number", default: 0 })),
3954
3959
  __decorateParam(3, Option("environment", { desc: "environment", default: "debug" })),
3955
- __decorateParam(4, Option("local", { desc: "local", default: true }))
3960
+ __decorateParam(4, Option("local", { type: "boolean", desc: "local", default: true }))
3956
3961
  ], ApplicationCommand.prototype, "releaseSource", 1);
3957
3962
  __decorateClass([
3958
3963
  Target.Public(),
@@ -4026,11 +4031,11 @@ var PackageRunner = class {
4026
4031
  const scanResult = await pkg.scan();
4027
4032
  return scanResult;
4028
4033
  }
4029
- async buildPackage(pkg, distPkg) {
4034
+ async buildPackage(pkg) {
4030
4035
  const rootPackageJson = pkg.workspace.readJson("package.json");
4031
4036
  const pkgJson = pkg.readJson("package.json");
4032
- if (import_fs13.default.existsSync(distPkg.cwdPath))
4033
- await pkg.workspace.exec(`rm -rf ${distPkg.cwdPath}`);
4037
+ if (import_fs13.default.existsSync(pkg.dist.cwdPath))
4038
+ await pkg.workspace.exec(`rm -rf ${pkg.dist.cwdPath}`);
4034
4039
  let buildResult;
4035
4040
  if (pkg.name === "@akanjs/config") {
4036
4041
  buildResult = await esbuild2.build({
@@ -4039,7 +4044,7 @@ var PackageRunner = class {
4039
4044
  bundle: false,
4040
4045
  packages: "external",
4041
4046
  format: "cjs",
4042
- outdir: distPkg.cwdPath,
4047
+ outdir: pkg.dist.cwdPath,
4043
4048
  logLevel: "error",
4044
4049
  outExtension: { ".js": pkgJson.type === "module" ? ".cjs" : ".js" },
4045
4050
  plugins: [(0, import_esbuild_plugin_d.dtsPlugin)({ tsconfig: `${pkg.cwdPath}/tsconfig.json` })]
@@ -4050,10 +4055,9 @@ var PackageRunner = class {
4050
4055
  bundle: false,
4051
4056
  packages: "external",
4052
4057
  format: "esm",
4053
- outdir: distPkg.cwdPath,
4058
+ outdir: pkg.dist.cwdPath,
4054
4059
  logLevel: "error",
4055
4060
  outExtension: { ".js": pkgJson.type === "module" ? ".js" : ".mjs" },
4056
- // copy css files
4057
4061
  loader: { ".css": "copy", ".js": "copy" }
4058
4062
  });
4059
4063
  } else if (pkg.name === "@akanjs/cli") {
@@ -4063,7 +4067,7 @@ var PackageRunner = class {
4063
4067
  bundle: true,
4064
4068
  format: "cjs",
4065
4069
  packages: "external",
4066
- outdir: distPkg.cwdPath,
4070
+ outdir: pkg.dist.cwdPath,
4067
4071
  logLevel: "error",
4068
4072
  plugins: [(0, import_esbuild_plugin_d.dtsPlugin)({ tsconfig: `${pkg.cwdPath}/tsconfig.json` })]
4069
4073
  });
@@ -4071,14 +4075,14 @@ var PackageRunner = class {
4071
4075
  write: true,
4072
4076
  entryPoints: [`${pkg.cwdPath}/src/templates/**/*.ts`, `${pkg.cwdPath}/src/templates/**/*.tsx`],
4073
4077
  packages: "external",
4074
- outdir: `${distPkg.cwdPath}/src/templates`,
4078
+ outdir: `${pkg.dist.cwdPath}/src/templates`,
4075
4079
  outbase: `${pkg.cwdPath}/src/templates`,
4076
4080
  format: "cjs",
4077
4081
  platform: "node",
4078
4082
  footer: { js: "module.exports = module.exports.default;" }
4079
4083
  });
4080
4084
  await pkg.workspace.exec(
4081
- `rsync -aq --exclude="*.ts" --exclude="*.tsx" ${pkg.cwdPath}/src/templates/ ${distPkg.cwdPath}/src/templates/`
4085
+ `rsync -aq --exclude="*.ts" --exclude="*.tsx" ${pkg.cwdPath}/src/templates/ ${pkg.dist.cwdPath}/src/templates/`
4082
4086
  );
4083
4087
  } else {
4084
4088
  const platform = [
@@ -4097,7 +4101,7 @@ var PackageRunner = class {
4097
4101
  splitting: false,
4098
4102
  platform,
4099
4103
  format: "cjs",
4100
- outdir: distPkg.cwdPath,
4104
+ outdir: pkg.dist.cwdPath,
4101
4105
  outExtension: { ".js": pkgJson.type === "module" ? ".cjs" : ".js" },
4102
4106
  logLevel: "error",
4103
4107
  plugins: [(0, import_esbuild_plugin_d.dtsPlugin)({ tsconfig: `${pkg.cwdPath}/tsconfig.json` })]
@@ -4110,7 +4114,7 @@ var PackageRunner = class {
4110
4114
  splitting: false,
4111
4115
  platform,
4112
4116
  format: "esm",
4113
- outdir: distPkg.cwdPath,
4117
+ outdir: pkg.dist.cwdPath,
4114
4118
  outExtension: { ".js": pkgJson.type === "module" ? ".js" : ".mjs" },
4115
4119
  logLevel: "error",
4116
4120
  plugins: []
@@ -4133,8 +4137,8 @@ var PackageRunner = class {
4133
4137
  }
4134
4138
  };
4135
4139
  if (buildResult.outputFiles)
4136
- buildResult.outputFiles.map((file) => distPkg.writeFile(file.path, file.text));
4137
- distPkg.writeJson("package.json", pkgPackageJson);
4140
+ buildResult.outputFiles.map((file) => pkg.dist.writeFile(file.path, file.text));
4141
+ pkg.dist.writeJson("package.json", pkgPackageJson);
4138
4142
  pkg.writeJson("package.json", pkgPackageJson);
4139
4143
  }
4140
4144
  };
@@ -4152,8 +4156,8 @@ var PackageScript = class {
4152
4156
  const scanResult = await this.#runner.scanSync(pkg);
4153
4157
  pkg.logger.rawLog(JSON.stringify(scanResult, null, 2));
4154
4158
  }
4155
- async buildPackage(pkg, distPkg = DistPkgExecutor.from(pkg.workspace, pkg.name)) {
4156
- await this.#runner.buildPackage(pkg, distPkg);
4159
+ async buildPackage(pkg) {
4160
+ await this.#runner.buildPackage(pkg);
4157
4161
  }
4158
4162
  };
4159
4163
 
@@ -4161,7 +4165,7 @@ var PackageScript = class {
4161
4165
  var import_prompts7 = require("@inquirer/prompts");
4162
4166
  var import_chalk = __toESM(require("chalk"));
4163
4167
  var import_latest_version = __toESM(require("latest-version"));
4164
- var import_open = __toESM(require("open"));
4168
+ var import_open2 = __toESM(require("open"));
4165
4169
  var QRcode = __toESM(require("qrcode"));
4166
4170
  var import_uuid = require("uuid");
4167
4171
  var CloudRunner = class {
@@ -4189,7 +4193,7 @@ ${import_chalk.default.green("\u27A4")} Authentication Required`));
4189
4193
  });
4190
4194
  });
4191
4195
  Logger.rawLog(qrcode);
4192
- await (0, import_open.default)(signinUrl);
4196
+ await (0, import_open2.default)(signinUrl);
4193
4197
  Logger.rawLog(import_chalk.default.dim("Opening browser..."));
4194
4198
  } catch {
4195
4199
  Logger.rawLog(import_chalk.default.yellow("Could not open browser. Please visit the URL manually."));
@@ -4839,7 +4843,7 @@ var WorkspaceScript = class {
4839
4843
  };
4840
4844
  workspace.writeFile("package.json", packageJson);
4841
4845
  workspace.log("Installing dependencies...");
4842
- await workspace.spawn("pnpm", ["i"]);
4846
+ await workspace.spawn("pnpm", ["install", "--reporter=silent"]);
4843
4847
  workspace.log("Initializing git repository and commit...");
4844
4848
  await workspace.commit("Initial commit", { init: true });
4845
4849
  await this.libraryScript.installLibrary(workspace, "util");
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "type": "commonjs",
3
3
  "name": "@akanjs/cli",
4
- "version": "0.0.88",
4
+ "version": "0.0.89",
5
5
  "bin": {
6
6
  "akan": "index.js"
7
7
  },
@@ -2,7 +2,7 @@ import { App, Sys, Workspace } from "@akanjs/devkit";
2
2
  import { ApplicationScript } from "./application.script";
3
3
  export declare class ApplicationCommand {
4
4
  applicationScript: ApplicationScript;
5
- createApplication(name: string, workspace: Workspace): Promise<void>;
5
+ createApplication(name: string, serve: boolean, workspace: Workspace): Promise<void>;
6
6
  removeApplication(app: App, workspace: Workspace): Promise<void>;
7
7
  scanApplication(app: App): Promise<void>;
8
8
  build(app: App): Promise<void>;
@@ -11,10 +11,10 @@ export declare class ApplicationCommand {
11
11
  buildCsr(app: App): Promise<void>;
12
12
  buildIos(app: App): Promise<void>;
13
13
  buildAndroid(app: App): Promise<void>;
14
- serve(app: App): Promise<void>;
15
- serveBackend(app: App): Promise<void>;
16
- serveFrontend(app: App): Promise<void>;
17
- serveCsr(app: App): Promise<void>;
14
+ serve(app: App, open: boolean): Promise<void>;
15
+ serveBackend(app: App, open: boolean): Promise<void>;
16
+ serveFrontend(app: App, open: boolean): Promise<void>;
17
+ serveCsr(app: App, open: boolean): Promise<void>;
18
18
  serveIos(app: App, open: boolean, release: boolean): Promise<void>;
19
19
  serveAndroid(app: App, open: boolean, release: boolean): Promise<void>;
20
20
  releaseIos(app: App): Promise<void>;
@@ -1,4 +1,4 @@
1
- import { App, AppExecutor, DistAppExecutor, type Workspace } from "@akanjs/devkit";
1
+ import { App, AppExecutor, type Workspace } from "@akanjs/devkit";
2
2
  export interface ReleaseSourceOptions {
3
3
  rebuild?: boolean;
4
4
  buildNum?: number;
@@ -9,12 +9,18 @@ export declare class ApplicationRunner {
9
9
  #private;
10
10
  createApplication(appName: string, workspace: Workspace): Promise<AppExecutor>;
11
11
  scanSync(app: App): Promise<import("@akanjs/config").AppScanResult | import("@akanjs/config").LibScanResult>;
12
- buildBackend(app: App, distApp: DistAppExecutor): Promise<void>;
13
- serveBackend(app: App, distApp: DistAppExecutor): Promise<void>;
14
- buildFrontend(app: App, distApp: DistAppExecutor): Promise<void>;
15
- serveFrontend(app: App, distApp: DistAppExecutor): Promise<void>;
16
- buildCsr(app: App, distApp: DistAppExecutor): Promise<void>;
17
- serveCsr(app: App, distApp: DistAppExecutor): Promise<void>;
12
+ buildBackend(app: App): Promise<void>;
13
+ serveBackend(app: App, { open }?: {
14
+ open?: boolean;
15
+ }): Promise<void>;
16
+ buildFrontend(app: App): Promise<void>;
17
+ serveFrontend(app: App, { open }?: {
18
+ open?: boolean;
19
+ }): Promise<void>;
20
+ buildCsr(app: App): Promise<void>;
21
+ serveCsr(app: App, { open }?: {
22
+ open?: boolean;
23
+ }): Promise<void>;
18
24
  buildIos(app: App): Promise<void>;
19
25
  serveIos(app: App, { open, operation }?: {
20
26
  open?: boolean;
@@ -1,35 +1,63 @@
1
1
  import type { App, Sys, Workspace } from "@akanjs/devkit";
2
- import { DistAppExecutor } from "@akanjs/devkit";
3
2
  import { LibraryScript } from "../library/library.script";
4
3
  import { type ReleaseSourceOptions } from "./application.runner";
5
4
  export declare class ApplicationScript {
6
5
  #private;
7
6
  libraryScript: LibraryScript;
8
- createApplication(appName: string, workspace: Workspace): Promise<void>;
7
+ createApplication(appName: string, workspace: Workspace, { serve }?: {
8
+ serve?: boolean;
9
+ }): Promise<void>;
9
10
  scanApplication(app: App, verbose?: boolean): Promise<import("@akanjs/config").AppScanResult | import("@akanjs/config").LibScanResult>;
10
11
  syncApplication(app: App, { recursive }?: {
11
12
  recursive?: boolean;
12
13
  }): Promise<void>;
13
- build(app: App, distApp?: DistAppExecutor): Promise<void>;
14
- serve(app: App, distApp?: DistAppExecutor): Promise<void>;
15
- buildBackend(app: App, distApp?: DistAppExecutor): Promise<void>;
16
- serveBackend(app: App, distApp?: DistAppExecutor): Promise<void>;
17
- buildFrontend(app: App, distApp?: DistAppExecutor): Promise<void>;
18
- serveFrontend(app: App, distApp?: DistAppExecutor): Promise<void>;
19
- buildCsr(app: App, distApp?: DistAppExecutor): Promise<void>;
20
- serveCsr(app: App, distApp?: DistAppExecutor): Promise<void>;
21
- buildIos(app: App): Promise<void>;
22
- serveIos(app: App, { open, operation }?: {
14
+ build(app: App): Promise<void>;
15
+ serve(app: App, { open }?: {
16
+ open?: boolean;
17
+ }): Promise<void>;
18
+ buildBackend(app: App, { sync }?: {
19
+ sync?: boolean;
20
+ }): Promise<void>;
21
+ serveBackend(app: App, { open, sync }?: {
22
+ open?: boolean;
23
+ sync?: boolean;
24
+ }): Promise<void>;
25
+ buildFrontend(app: App, { sync }?: {
26
+ sync?: boolean;
27
+ }): Promise<void>;
28
+ serveFrontend(app: App, { open, sync }?: {
29
+ open?: boolean;
30
+ sync?: boolean;
31
+ }): Promise<void>;
32
+ buildCsr(app: App, { sync }?: {
33
+ sync?: boolean;
34
+ }): Promise<void>;
35
+ serveCsr(app: App, { open, sync }?: {
36
+ open?: boolean;
37
+ sync?: boolean;
38
+ }): Promise<void>;
39
+ buildIos(app: App, { sync }?: {
40
+ sync?: boolean;
41
+ }): Promise<void>;
42
+ serveIos(app: App, { open, operation, sync, }?: {
23
43
  open?: boolean;
24
44
  operation?: "local" | "release";
45
+ sync?: boolean;
46
+ }): Promise<void>;
47
+ releaseIos(app: App, { sync }?: {
48
+ sync?: boolean;
25
49
  }): Promise<void>;
26
- releaseIos(app: App): Promise<void>;
27
- buildAndroid(app: App): Promise<void>;
28
- serveAndroid(app: App, { open, operation }?: {
50
+ buildAndroid(app: App, { sync }?: {
51
+ sync?: boolean;
52
+ }): Promise<void>;
53
+ serveAndroid(app: App, { open, operation, sync, }?: {
29
54
  open?: boolean;
30
55
  operation?: "local" | "release";
56
+ sync?: boolean;
57
+ }): Promise<void>;
58
+ releaseAndroid(app: App, { sync }?: {
59
+ sync?: boolean;
31
60
  }): Promise<void>;
32
- releaseAndroid(app: App): Promise<void>;
33
61
  dumpDatabase(app: App, environment: string): Promise<void>;
34
62
  restoreDatabase(app: App, source: string, target: string): Promise<void>;
35
63
  pullDatabase(app: App, environment: string, dump?: boolean): Promise<void>;
@@ -1,7 +1,7 @@
1
- import { type DistPkgExecutor, type Pkg, type Workspace } from "@akanjs/devkit";
1
+ import { type Pkg, type Workspace } from "@akanjs/devkit";
2
2
  export declare class PackageRunner {
3
3
  version(workspace: Workspace): Promise<void>;
4
4
  createPackage(workspace: Workspace, pkgName: string): Promise<void>;
5
5
  scanSync(pkg: Pkg): Promise<import("@akanjs/config").PkgScanResult>;
6
- buildPackage(pkg: Pkg, distPkg: DistPkgExecutor): Promise<void>;
6
+ buildPackage(pkg: Pkg): Promise<void>;
7
7
  }
@@ -1,8 +1,8 @@
1
- import { DistPkgExecutor, type Pkg, type Workspace } from "@akanjs/devkit";
1
+ import { type Pkg, type Workspace } from "@akanjs/devkit";
2
2
  export declare class PackageScript {
3
3
  #private;
4
4
  version(workspace: Workspace): Promise<void>;
5
5
  createPackage(workspace: Workspace, pkgName: string): Promise<void>;
6
6
  scanPackage(pkg: Pkg): Promise<void>;
7
- buildPackage(pkg: Pkg, distPkg?: DistPkgExecutor): Promise<void>;
7
+ buildPackage(pkg: Pkg): Promise<void>;
8
8
  }
@@ -110,20 +110,12 @@ interface AppExecutorOptions {
110
110
  name: string;
111
111
  }
112
112
  export declare class AppExecutor extends SysExecutor {
113
+ dist: Executor;
113
114
  constructor({ workspace, name }: AppExecutorOptions);
114
115
  static from(executor: SysExecutor | WorkspaceExecutor, name: string): AppExecutor;
115
116
  getConfig(command?: string): Promise<AppConfigResult>;
116
117
  syncAssets(libDeps: string[]): Promise<void>;
117
118
  }
118
- interface DistAppExecutorOptions {
119
- workspace: WorkspaceExecutor;
120
- name: string;
121
- }
122
- export declare class DistAppExecutor extends Executor {
123
- name: string;
124
- constructor({ workspace, name }: DistAppExecutorOptions);
125
- static from(executor: SysExecutor | WorkspaceExecutor, name: string): DistAppExecutor;
126
- }
127
119
  interface LibExecutorOptions {
128
120
  workspace?: WorkspaceExecutor;
129
121
  name: string;
@@ -131,19 +123,11 @@ interface LibExecutorOptions {
131
123
  export declare class LibExecutor extends SysExecutor {
132
124
  workspaceRoot: string;
133
125
  repoName: string;
126
+ dist: Executor;
134
127
  constructor({ workspace, name }: LibExecutorOptions);
135
128
  static from(executor: SysExecutor | WorkspaceExecutor, name: string): LibExecutor;
136
129
  getConfig(command?: string): Promise<LibConfigResult>;
137
130
  }
138
- interface DistLibExecutorOptions {
139
- workspace: WorkspaceExecutor;
140
- name: string;
141
- }
142
- export declare class DistLibExecutor extends Executor {
143
- name: string;
144
- constructor({ workspace, name }: DistLibExecutorOptions);
145
- static from(executor: SysExecutor | WorkspaceExecutor, name: string): DistAppExecutor | DistLibExecutor;
146
- }
147
131
  interface PkgExecutorOptions {
148
132
  workspace?: WorkspaceExecutor;
149
133
  name: string;
@@ -151,6 +135,7 @@ interface PkgExecutorOptions {
151
135
  export declare class PkgExecutor extends Executor {
152
136
  workspace: WorkspaceExecutor;
153
137
  name: string;
138
+ dist: Executor;
154
139
  constructor({ workspace, name }: PkgExecutorOptions);
155
140
  static from(executor: SysExecutor | WorkspaceExecutor, name: string): PkgExecutor;
156
141
  scan({ packageJson, tsconfig, }?: {
@@ -158,16 +143,4 @@ export declare class PkgExecutor extends Executor {
158
143
  tsconfig?: TsConfigJson;
159
144
  }): Promise<PkgScanResult>;
160
145
  }
161
- interface DistPkgExecutorOptions {
162
- workspaceRoot: string;
163
- repoName: string;
164
- name: string;
165
- }
166
- export declare class DistPkgExecutor extends Executor {
167
- workspaceRoot: string;
168
- repoName: string;
169
- name: string;
170
- constructor({ workspaceRoot, repoName, name }: DistPkgExecutorOptions);
171
- static from(workspaceExecutor: WorkspaceExecutor, name: string): DistPkgExecutor;
172
- }
173
146
  export {};
@@ -13,5 +13,4 @@ export * from "./types";
13
13
  export * from "./capacitorApp";
14
14
  export * from "./extractDeps";
15
15
  export * from "./commandDecorators";
16
- export * from "./installExternalLib";
17
16
  export * from "./aiEditor";
@@ -1,2 +0,0 @@
1
- import { type WorkspaceExecutor } from "@akanjs/devkit";
2
- export declare const installExternalLib: (libName: string, workspace: WorkspaceExecutor) => Promise<void>;