@digigov/cli-build 2.0.0-85c27c19 → 2.0.0-87b6232d

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
@@ -1,107 +1,106 @@
1
- const { Command } = require("@oclif/command");
2
- const execa = require("execa");
3
- const { resolveProject, DigigovCommand } = require("@digigov/cli/lib");
4
- const path = require("path");
5
- const fs = require("fs");
6
- const esbuild = require("esbuild");
7
- const glob = require("glob");
1
+ import { DigigovCommand, resolveProject, logger } from "@digigov/cli/lib";
2
+ import { buildFormat, generateTypeDeclarationFiles } from "./build.js";
3
+ import { generateRegistryFiles } from "./generate-registry.js";
4
+ import copyFiles from "./copy-files.js";
8
5
 
9
- module.exports = class Build extends DigigovCommand {
10
- static description = "build digigov libraries";
11
- static id = "build";
12
- dirname = __dirname;
13
- static examples = [`$ digigov build`];
14
- static strict = false;
15
- static load() {
16
- return Build;
17
- }
18
- script = "babel";
19
- async run() {
20
- const { argv } = this.parse(Build);
21
- try {
22
- await this.exec("rimraf", ["dist"]);
23
- const project = resolveProject();
24
- const babelArgs = [
25
- "--config-file",
26
- path.join(__dirname, "babel.config.js"),
27
- project.src,
28
- "--extensions",
29
- ".tsx,.ts,.js,.jsx",
30
- "--copy-files",
31
- "--out-dir",
32
- ];
33
- const distDir = path.resolve(project.root, project.distDir);
34
- const basename = path.basename(project.root);
6
+ import { Option } from "commander";
7
+ import path from "path";
8
+ import glob from "globby";
9
+ import assert from "assert";
10
+ import { getProjectTsconfig } from "./common.js";
11
+
12
+ const command = new DigigovCommand("build", import.meta.url)
13
+ .option(
14
+ "--generate-registry",
15
+ "Generate a registry file for the build output",
16
+ )
17
+ .addOption(
18
+ new Option("--include-stories", "Include stories in the output").implies({
19
+ generateRegistry: true,
20
+ }),
21
+ )
22
+ .action(main);
23
+ export default command;
24
+
25
+ const SRC_GLOB = "src/**/*.{tsx,ts,js,jsx}";
26
+ const TEST_GLOBS = [
27
+ "**/*.test.{js,jsx,ts,tsx}",
28
+ "**/*.spec.{js,jsx,ts,tsx}",
29
+ "**/__tests__/**/*.{js,jsx,ts,tsx}",
30
+ ];
31
+ const STORIES_GLOBS = [
32
+ "**/*.stories.{js,jsx,ts,tsx}",
33
+ "**/__stories__/**/*.{js,jsxts,tsx}",
34
+ ];
35
+
36
+ /**
37
+ * @param {object} options - The command options
38
+ * @param {boolean} options.generateRegistry - Generate a registry file for the build output
39
+ * @param {boolean} options.includeStories - Include stories in the generated registry file
40
+ * @param {DigigovCommand} ctx
41
+ */
42
+ async function main(options, ctx) {
43
+ const project = resolveProject();
35
44
 
36
- if (project.isTs) {
37
- const tsconfigProduction = path.join(
38
- project.root,
39
- "tsconfig.production.json",
40
- );
41
- const tsArgs = [];
42
- if (fs.existsSync(tsconfigProduction)) {
43
- tsArgs.push("--project", tsconfigProduction);
44
- }
45
- await this.exec("tsc", [
46
- "--emitDeclarationOnly",
47
- "--outDir",
48
- "dist",
49
- ...tsArgs,
50
- ]);
51
- if (fs.existsSync(path.join(distDir, basename))) {
52
- const typesIncluded = fs.readdirSync(path.join(distDir));
53
- const paths = fs.readdirSync(
54
- path.join(distDir, basename, project.src),
55
- );
56
- paths.forEach((p) => {
57
- fs.renameSync(
58
- path.join(distDir, basename, project.src, p),
59
- path.join(distDir, p),
60
- );
61
- });
62
- typesIncluded.forEach((typesDir) => {
63
- fs.rmSync(path.join(distDir, typesDir), { recursive: true });
64
- });
65
- }
66
- }
45
+ await ctx.exec("rimraf", [project.distDir]);
67
46
 
68
- const files = glob.sync(
69
- path.join(project.root, "src", "**/*.{tsx,ts,js,jsx}"),
70
- {
71
- ignore: "**/*.{spec,test}.{ts,tsx,js,jsx}",
72
- },
73
- );
74
- const commonBuildOptions = {
75
- entryPoints: files,
76
- platform: "node",
77
- sourcemap: true,
78
- target: ["esnext"],
79
- logLevel: "error",
80
- };
81
- if (fs.existsSync(path.join(project.root, "tsconfig.production.json"))) {
82
- commonBuildOptions["tsconfig"] = "tsconfig.production.json";
83
- } else if (fs.existsSync(path.join(project.root, "tsconfig.json"))) {
84
- commonBuildOptions["tsconfig"] = "tsconfig.json";
85
- }
47
+ /**
48
+ * The project tsconfig, or undefined if the project is not using TypeScript
49
+ * @type {string | undefined}
50
+ */
51
+ let tsconfig;
52
+ if (project.isTs) {
53
+ tsconfig = getProjectTsconfig(project.root);
54
+ assert(tsconfig, "Expected tsconfig to be in project");
55
+ await generateTypeDeclarationFiles(project, tsconfig, ctx);
56
+ }
57
+
58
+ const ignore = [...TEST_GLOBS];
59
+ if (options.includeStories) {
60
+ logger.debug("Including stories in the build");
61
+ } else {
62
+ ignore.push(...STORIES_GLOBS);
63
+ }
64
+ const filesToBuild = await glob(path.join(project.root, SRC_GLOB), {
65
+ ignore,
66
+ });
67
+ logger.debug("Bundling ESM and CJS...");
68
+ await Promise.all([
69
+ buildFormat({
70
+ files: filesToBuild,
71
+ tsconfig: tsconfig,
72
+ format: "cjs",
73
+ outdir: project.distDir + "/cjs",
74
+ }),
75
+ buildFormat({
76
+ files: filesToBuild,
77
+ tsconfig,
78
+ format: "esm",
79
+ outdir: project.distDir,
80
+ }),
81
+ ]);
82
+ logger.debug("Bundling done.");
86
83
 
87
- await Promise.all([
88
- esbuild.build({
89
- ...commonBuildOptions,
90
- format: "esm",
91
- outdir: `dist`,
92
- }),
93
- esbuild.build({
94
- ...commonBuildOptions,
95
- format: "cjs",
96
- outdir: `dist/cjs`,
97
- }),
98
- ]);
99
- await execa("node", [path.join(__dirname, "copy-files.js")], {
100
- env: {},
101
- stdio: "inherit",
102
- });
103
- } catch (err) {
104
- console.error(err);
105
- }
84
+ if (options.generateRegistry) {
85
+ const registryFiles = filesToBuild.filter(
86
+ (file) => !(file.includes("native") || file.endsWith(".d.ts")),
87
+ );
88
+ logger.debug("Generating registry files...");
89
+ const registryFilePaths = await generateRegistryFiles(
90
+ project,
91
+ registryFiles,
92
+ options.includeStories,
93
+ );
94
+ await buildFormat({
95
+ files: registryFilePaths,
96
+ tsconfig: tsconfig,
97
+ format: "cjs",
98
+ outdir: project.distDir + "/cjs",
99
+ });
100
+ logger.log("Generated registry files");
106
101
  }
107
- };
102
+
103
+ logger.debug("Copying files to build directory...");
104
+ copyFiles();
105
+ logger.debug("Files copied.");
106
+ }
package/package.json CHANGED
@@ -1,15 +1,16 @@
1
1
  {
2
2
  "name": "@digigov/cli-build",
3
- "version": "2.0.0-85c27c19",
3
+ "version": "2.0.0-87b6232d",
4
4
  "description": "Build plugin for Digigov CLI",
5
5
  "main": "./index.js",
6
+ "type": "module",
6
7
  "author": "GRNET Devs <devs@lists.grnet.gr>",
7
8
  "license": "BSD-2-Clause",
8
9
  "private": false,
9
10
  "dependencies": {
10
11
  "@babel/cli": "7.12.1",
11
12
  "@babel/compat-data": "7.12.5",
12
- "@babel/core": "7.12.13",
13
+ "@babel/core": "7.26.0",
13
14
  "@babel/helper-validator-identifier": "7.9.5",
14
15
  "@babel/plugin-proposal-class-properties": "7.12.1",
15
16
  "@babel/plugin-proposal-object-rest-spread": "7.12.1",
@@ -26,22 +27,31 @@
26
27
  "babel-plugin-transform-react-constant-elements": "6.23.0",
27
28
  "babel-plugin-transform-react-remove-prop-types": "0.4.24",
28
29
  "fs-extra": "11.2.0",
29
- "glob": "7.1.6",
30
- "typescript": "5.3.2",
31
- "@digigov/babel-ts-to-proptypes": "1.1.0",
32
- "@types/node": "18.19.0",
30
+ "globby": "11.0.0",
33
31
  "babel-plugin-istanbul": "7.0.0",
34
32
  "publint": "0.1.8",
35
- "esbuild": "0.23.0"
33
+ "rimraf": "3.0.2",
34
+ "esbuild": "0.23.0",
35
+ "commander": "12.1.0",
36
+ "ts-morph": "25.0.0"
36
37
  },
37
38
  "devDependencies": {
38
- "publint": "0.1.8"
39
+ "publint": "0.1.8",
40
+ "vitest": "2.1.3",
41
+ "@digigov/cli-test": "2.0.0-87b6232d",
42
+ "@types/fs-extra": "11.0.4",
43
+ "@types/node": "18.19.0",
44
+ "typescript": "5.6.2"
39
45
  },
40
46
  "peerDependencies": {
41
- "@digigov/cli": "1.1.1-85c27c19",
42
- "rimraf": "3.0.2",
47
+ "@digigov/cli": "2.0.0-87b6232d",
43
48
  "next": "13.1.1"
44
49
  },
50
+ "peerDependenciesMeta": {
51
+ "next": {
52
+ "optional": true
53
+ }
54
+ },
45
55
  "scripts": {
46
56
  "publint": "publint"
47
57
  }
@@ -12,9 +12,6 @@
12
12
  "@digigov/auth/*": ["./auth/src/*"],
13
13
  "@digigov/auth/": ["./auth/src"],
14
14
  "@digigov/auth": ["./auth/src"],
15
- "@digigov/benchmark/*": ["./benchmark/src/*"],
16
- "@digigov/benchmark/": ["./benchmark/src"],
17
- "@digigov/benchmark": ["./benchmark/src"],
18
15
  "@digigov/text-search/*": ["./text-search/src/*"],
19
16
  "@digigov/text-search/": ["./text-search/src"],
20
17
  "@digigov/text-search": ["./text-search/src"],
@@ -36,14 +33,15 @@
36
33
  "@digigov/react-experimental/*": ["../libs-ui/react-experimental/src/*"],
37
34
  "@digigov/react-experimental/": ["../libs-ui/react-experimental/src"],
38
35
  "@digigov/react-experimental": ["../libs-ui/react-experimental/src"],
39
- "@digigov/storybook/*": ["../examples/storybook/stories/*"]
36
+ "@digigov/storybook/*": ["../examples/storybook/stories/*"],
37
+ "@uides/stepwise/*": ["./stepwise/src/*"],
38
+ "@uides/stepwise/": ["./stepwise/src"],
39
+ "@uides/stepwise": ["./stepwise/src"]
40
40
  }
41
41
  },
42
42
  "include": [
43
43
  "../../libs/auth/src/**/*.tsx",
44
44
  "../../libs/auth/src/*.tsx",
45
- "../../libs/benchmark/src/**/*.tsx",
46
- "../../libs/benchmark/src/*.tsx",
47
45
  "../../libs/text-search/src/**/*.tsx",
48
46
  "../../libs/text-search/src/*.tsx",
49
47
  "../../libs/text-search/src/**/*.ts",
package/tsconfig.json CHANGED
@@ -1,45 +1,12 @@
1
1
  {
2
- "extends": "./tsconfig.base.json",
2
+ "extends": "@digigov/cli/tsconfig.cli",
3
3
  "compilerOptions": {
4
4
  "types": [
5
- "node"
6
- ],
7
- "outDir": "dist",
8
- "paths": {
9
- "@digigov/babel-ts-to-proptypes": [
10
- "node_modules/@digigov/babel-ts-to-proptypes/src"
11
- ],
12
- "@digigov/babel-ts-to-proptypes/": [
13
- "node_modules/@digigov/babel-ts-to-proptypes/src/"
14
- ],
15
- "@digigov/babel-ts-to-proptypes/*": [
16
- "node_modules/@digigov/babel-ts-to-proptypes/src/*"
17
- ],
18
- "@digigov/cli": [
19
- "node_modules/@digigov/cli/src"
20
- ],
21
- "@digigov/cli/": [
22
- "node_modules/@digigov/cli/src/"
23
- ],
24
- "@digigov/cli/*": [
25
- "node_modules/@digigov/cli/src/*"
26
- ],
27
- "@digigov/cli-build": [
28
- "./src"
29
- ],
30
- "@digigov/cli-build/": [
31
- "./src/"
32
- ],
33
- "@digigov/cli-build/*": [
34
- "./src/*"
35
- ]
36
- },
37
- "baseUrl": "./"
5
+ "vitest/globals"
6
+ ]
38
7
  },
39
8
  "include": [
40
- "index.js"
41
- ],
42
- "exclude": [
43
- "node_modules"
9
+ "./*.js",
10
+ "__tests__"
44
11
  ]
45
12
  }
package/babel.config.js DELETED
@@ -1 +0,0 @@
1
- module.exports = require('./babel.common').config