@adobe/ccweb-add-on-scaffolder 3.0.0 → 3.1.0
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/.c8rc.json +5 -1
- package/.mocharc.json +3 -1
- package/dist/app/AddOnBuilder.d.ts +27 -7
- package/dist/app/AddOnBuilder.d.ts.map +1 -1
- package/dist/app/AddOnBuilder.js +247 -0
- package/dist/app/AddOnScaffolder.d.ts +29 -2
- package/dist/app/AddOnScaffolder.d.ts.map +1 -1
- package/dist/app/AddOnScaffolder.js +106 -1
- package/dist/app/PackageBuilder.d.ts +21 -7
- package/dist/app/PackageBuilder.d.ts.map +1 -1
- package/dist/app/PackageBuilder.js +68 -1
- package/dist/app/index.d.ts +0 -3
- package/dist/app/index.d.ts.map +1 -1
- package/dist/app/index.js +0 -3
- package/dist/config/inversify.config.js +8 -6
- package/dist/config/inversify.types.d.ts +0 -1
- package/dist/config/inversify.types.d.ts.map +1 -1
- package/dist/config/inversify.types.js +0 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +0 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/validators/TemplateValidator.d.ts +12 -2
- package/dist/validators/TemplateValidator.d.ts.map +1 -1
- package/dist/validators/TemplateValidator.js +54 -1
- package/dist/validators/index.d.ts +0 -1
- package/dist/validators/index.d.ts.map +1 -1
- package/dist/validators/index.js +0 -1
- package/package.json +8 -8
- package/src/app/AddOnBuilder.ts +258 -15
- package/src/app/AddOnScaffolder.ts +120 -3
- package/src/app/PackageBuilder.ts +75 -9
- package/src/app/index.ts +0 -3
- package/src/config/inversify.config.ts +8 -8
- package/src/config/inversify.types.ts +0 -2
- package/src/index.ts +1 -1
- package/src/test/app/{TemplateAddOnBuilder.spec.ts → AddOnBuilder.spec.ts} +21 -22
- package/src/test/app/{TemplateAddOnScaffolder.spec.ts → AddOnScaffolder.spec.ts} +11 -13
- package/src/test/app/{TemplatePackageBuilder.spec.ts → PackageBuilder.spec.ts} +13 -14
- package/src/test/models/ScaffolderOptions.spec.ts +1 -1
- package/src/test/validators/{AppTemplateValidator.spec.ts → TemplateValidator.spec.ts} +2 -3
- package/src/validators/TemplateValidator.ts +46 -3
- package/src/validators/index.ts +0 -1
- package/dist/app/TemplateAddOnBuilder.d.ts +0 -90
- package/dist/app/TemplateAddOnBuilder.d.ts.map +0 -1
- package/dist/app/TemplateAddOnBuilder.js +0 -273
- package/dist/app/TemplateAddOnScaffolder.d.ts +0 -63
- package/dist/app/TemplateAddOnScaffolder.d.ts.map +0 -1
- package/dist/app/TemplateAddOnScaffolder.js +0 -130
- package/dist/app/TemplatePackageBuilder.d.ts +0 -49
- package/dist/app/TemplatePackageBuilder.d.ts.map +0 -1
- package/dist/app/TemplatePackageBuilder.js +0 -92
- package/dist/validators/AddOnTemplateValidator.d.ts +0 -46
- package/dist/validators/AddOnTemplateValidator.d.ts.map +0 -1
- package/dist/validators/AddOnTemplateValidator.js +0 -78
- package/src/app/TemplateAddOnBuilder.ts +0 -319
- package/src/app/TemplateAddOnScaffolder.ts +0 -153
- package/src/app/TemplatePackageBuilder.ts +0 -102
- package/src/validators/AddOnTemplateValidator.ts +0 -79
package/.c8rc.json
CHANGED
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
{
|
|
2
2
|
"all": true,
|
|
3
3
|
"include": ["src/**/*.ts"],
|
|
4
|
-
"exclude": ["src/**/*.spec.ts", "src
|
|
4
|
+
"exclude": ["src/**/*.spec.ts", "src/**/index.ts", "src/config/*", "src/constants.ts"],
|
|
5
|
+
"lines": 100,
|
|
6
|
+
"functions": 100,
|
|
7
|
+
"branches": 100,
|
|
8
|
+
"statements": 100,
|
|
5
9
|
"reporter": ["html", "text", "text-summary"],
|
|
6
10
|
"report-dir": "coverage"
|
|
7
11
|
}
|
package/.mocharc.json
CHANGED
|
@@ -21,13 +21,31 @@
|
|
|
21
21
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
22
22
|
* SOFTWARE.
|
|
23
23
|
********************************************************************************/
|
|
24
|
-
import type {
|
|
24
|
+
import type { Logger } from "@adobe/ccweb-add-on-core";
|
|
25
|
+
import { PackageJson, TemplateJson } from "@adobe/ccweb-add-on-core";
|
|
25
26
|
import "reflect-metadata";
|
|
26
27
|
import type { ScaffolderOptions } from "../models/ScaffolderOptions.js";
|
|
27
28
|
/**
|
|
28
|
-
* Add-on builder
|
|
29
|
+
* Add-on builder factory.
|
|
29
30
|
*/
|
|
30
|
-
export
|
|
31
|
+
export type AddOnBuilderFactory = (options: ScaffolderOptions) => AddOnBuilder;
|
|
32
|
+
/**
|
|
33
|
+
* Builder class for constructing the add-on project.
|
|
34
|
+
*/
|
|
35
|
+
export declare class AddOnBuilder {
|
|
36
|
+
private readonly _logger;
|
|
37
|
+
private _options;
|
|
38
|
+
private _require;
|
|
39
|
+
private _templateRootDirectory;
|
|
40
|
+
private _gitignoreExists;
|
|
41
|
+
private _readmeExists;
|
|
42
|
+
/**
|
|
43
|
+
* Instantiate {@link AddOnBuilder}.
|
|
44
|
+
* @param options - {@link ScaffolderOptions}.
|
|
45
|
+
* @param logger - {@link Logger} reference.
|
|
46
|
+
* @returns Reference to a new {@link AddOnBuilder} instance.
|
|
47
|
+
*/
|
|
48
|
+
constructor(options: ScaffolderOptions, logger: Logger);
|
|
31
49
|
/**
|
|
32
50
|
* Get {@link PackageJson}.
|
|
33
51
|
*
|
|
@@ -64,9 +82,11 @@ export interface AddOnBuilder {
|
|
|
64
82
|
* Display success message.
|
|
65
83
|
*/
|
|
66
84
|
displaySuccess(): void;
|
|
85
|
+
private _updateReadMe;
|
|
86
|
+
private _copyTemplateFiles;
|
|
87
|
+
private _updateGitIgnore;
|
|
88
|
+
private _updateManifest;
|
|
89
|
+
private _getAddOnName;
|
|
90
|
+
private _removeTemplateTempFiles;
|
|
67
91
|
}
|
|
68
|
-
/**
|
|
69
|
-
* Add-on builder factory.
|
|
70
|
-
*/
|
|
71
|
-
export type AddOnBuilderFactory = (options: ScaffolderOptions) => AddOnBuilder;
|
|
72
92
|
//# sourceMappingURL=AddOnBuilder.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AddOnBuilder.d.ts","sourceRoot":"","sources":["../../src/app/AddOnBuilder.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;kFAsBkF;AAElF,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"AddOnBuilder.d.ts","sourceRoot":"","sources":["../../src/app/AddOnBuilder.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;kFAsBkF;AAElF,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,0BAA0B,CAAC;AACvD,OAAO,EAIH,WAAW,EACX,YAAY,EAGf,MAAM,0BAA0B,CAAC;AAQlC,OAAO,kBAAkB,CAAC;AAI1B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AAExE;;GAEG;AACH,MAAM,MAAM,mBAAmB,GAAG,CAAC,OAAO,EAAE,iBAAiB,KAAK,YAAY,CAAC;AAE/E;;GAEG;AACH,qBACa,YAAY;IACrB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IAEjC,OAAO,CAAC,QAAQ,CAAqB;IACrC,OAAO,CAAC,QAAQ,CAAe;IAC/B,OAAO,CAAC,sBAAsB,CAAU;IAExC,OAAO,CAAC,gBAAgB,CAAS;IACjC,OAAO,CAAC,aAAa,CAAS;IAE9B;;;;;OAKG;gBACS,OAAO,EAAE,iBAAiB,EAA6B,MAAM,EAAE,MAAM;IAQjF;;;;OAIG;IACH,cAAc,IAAI,WAAW;IAK7B;;;;OAIG;IACH,eAAe,IAAI,YAAY;IAO/B;;;;;OAKG;IACH,2BAA2B,CAAC,QAAQ,EAAE,YAAY,GAAG,GAAG,CAAC,MAAM,CAAC;IAWhE;;;;;OAKG;IACH,wBAAwB,CAAC,QAAQ,EAAE,YAAY,GAAG,GAAG,CAAC,MAAM,CAAC;IAW7D;;;;OAIG;IACH,KAAK,CAAC,WAAW,EAAE,MAAM,GAAG,IAAI;IAUhC;;OAEG;IACH,cAAc,IAAI,IAAI;IA8CtB,OAAO,CAAC,aAAa;IAUrB,OAAO,CAAC,kBAAkB;IAU1B,OAAO,CAAC,gBAAgB;IAcxB,OAAO,CAAC,eAAe;IA4DvB,OAAO,CAAC,aAAa;IAMrB,OAAO,CAAC,wBAAwB;CAGnC"}
|
package/dist/app/AddOnBuilder.js
CHANGED
|
@@ -21,5 +21,252 @@
|
|
|
21
21
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
22
22
|
* SOFTWARE.
|
|
23
23
|
********************************************************************************/
|
|
24
|
+
import { __decorate, __metadata, __param } from "tslib";
|
|
25
|
+
import { ADDITIONAL_ADD_ON_INFO, DEFAULT_ADD_ON_VERSION, ITypes as ICoreTypes, PackageJson, TemplateJson, getJSONString, isNullOrWhiteSpace } from "@adobe/ccweb-add-on-core";
|
|
26
|
+
import { AddOnManifest, EntrypointType } from "@adobe/ccweb-add-on-manifest";
|
|
27
|
+
import fs from "fs-extra";
|
|
28
|
+
import { inject, injectable } from "inversify";
|
|
29
|
+
import { createRequire } from "module";
|
|
30
|
+
import os from "os";
|
|
31
|
+
import path from "path";
|
|
24
32
|
import "reflect-metadata";
|
|
33
|
+
import format from "string-template";
|
|
34
|
+
import { v4 as uuidv4 } from "uuid";
|
|
35
|
+
import { MANIFEST_JSON, PACKAGE_JSON, TEMPLATE_JSON, TEMP_TEMPLATE_PATH } from "../constants.js";
|
|
36
|
+
/**
|
|
37
|
+
* Builder class for constructing the add-on project.
|
|
38
|
+
*/
|
|
39
|
+
let AddOnBuilder = class AddOnBuilder {
|
|
40
|
+
_logger;
|
|
41
|
+
_options;
|
|
42
|
+
_require;
|
|
43
|
+
_templateRootDirectory;
|
|
44
|
+
_gitignoreExists = false;
|
|
45
|
+
_readmeExists = false;
|
|
46
|
+
/**
|
|
47
|
+
* Instantiate {@link AddOnBuilder}.
|
|
48
|
+
* @param options - {@link ScaffolderOptions}.
|
|
49
|
+
* @param logger - {@link Logger} reference.
|
|
50
|
+
* @returns Reference to a new {@link AddOnBuilder} instance.
|
|
51
|
+
*/
|
|
52
|
+
constructor(options, logger) {
|
|
53
|
+
this._options = options;
|
|
54
|
+
this._logger = logger;
|
|
55
|
+
this._require = createRequire(import.meta.url);
|
|
56
|
+
this._templateRootDirectory = path.join(process.cwd(), TEMP_TEMPLATE_PATH);
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Get {@link PackageJson}.
|
|
60
|
+
*
|
|
61
|
+
* @returns Reference of {@link PackageJson}.
|
|
62
|
+
*/
|
|
63
|
+
getPackageJson() {
|
|
64
|
+
const packageJsonPath = path.join(this._options.addOnDirectory, PACKAGE_JSON);
|
|
65
|
+
return new PackageJson(this._require(packageJsonPath));
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Get {@link TemplateJson}.
|
|
69
|
+
*
|
|
70
|
+
* @returns Reference of {@link TemplateJson}.
|
|
71
|
+
*/
|
|
72
|
+
getTemplateJson() {
|
|
73
|
+
const templateJsonPath = path.join(this._templateRootDirectory, TEMPLATE_JSON);
|
|
74
|
+
return fs.existsSync(templateJsonPath)
|
|
75
|
+
? new TemplateJson(this._require(templateJsonPath))
|
|
76
|
+
: new TemplateJson({});
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Get template devDependencies.
|
|
80
|
+
*
|
|
81
|
+
* @param template - {@link TemplateJson}
|
|
82
|
+
* @returns Set of template devDependencies.
|
|
83
|
+
*/
|
|
84
|
+
getDevDependenciesToInstall(template) {
|
|
85
|
+
const devDependencies = new Set();
|
|
86
|
+
if (template.devDependencies) {
|
|
87
|
+
template.devDependencies.forEach((value, key) => {
|
|
88
|
+
devDependencies.add(`${key}@${value}`);
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
return devDependencies;
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Get template dependencies.
|
|
95
|
+
*
|
|
96
|
+
* @param template - {@link TemplateJson}
|
|
97
|
+
* @returns Set of template dependencies.
|
|
98
|
+
*/
|
|
99
|
+
getDependenciesToInstall(template) {
|
|
100
|
+
const dependencies = new Set();
|
|
101
|
+
if (template.dependencies) {
|
|
102
|
+
template.dependencies.forEach((value, key) => {
|
|
103
|
+
dependencies.add(`${key}@${value}`);
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
return dependencies;
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Build the Add-on.
|
|
110
|
+
*
|
|
111
|
+
* @param packageJson - {@link PackageJson}
|
|
112
|
+
*/
|
|
113
|
+
build(packageJson) {
|
|
114
|
+
fs.writeFileSync(path.join(this._options.addOnDirectory, PACKAGE_JSON), packageJson + os.EOL);
|
|
115
|
+
this._updateReadMe();
|
|
116
|
+
this._copyTemplateFiles();
|
|
117
|
+
this._updateGitIgnore();
|
|
118
|
+
this._updateManifest();
|
|
119
|
+
this._removeTemplateTempFiles();
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Display success message.
|
|
123
|
+
*/
|
|
124
|
+
displaySuccess() {
|
|
125
|
+
let cdPath;
|
|
126
|
+
if (!isNullOrWhiteSpace(this._options.rootDirectory) &&
|
|
127
|
+
path.join(this._options.rootDirectory, this._options.addOnName) === this._options.addOnDirectory) {
|
|
128
|
+
cdPath = this._options.addOnName;
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
cdPath = this._options.addOnDirectory;
|
|
132
|
+
}
|
|
133
|
+
this._logger.success(format(LOGS.successCreatedAddOn, {
|
|
134
|
+
addOnName: this._options.addOnName,
|
|
135
|
+
addOnDirectory: this._options.addOnDirectory
|
|
136
|
+
}));
|
|
137
|
+
this._logger.success(LOGS.insideDirectoryCommandsToRun, { postfix: LOGS.newLine });
|
|
138
|
+
this._logger.information(LOGS.npmRunBuild, { prefix: `${LOGS.tab}` });
|
|
139
|
+
this._logger.message(LOGS.buildsTheAddOn, { prefix: `${LOGS.tab}${LOGS.tab}` });
|
|
140
|
+
this._logger.information(LOGS.npmRunStart, { prefix: LOGS.tab });
|
|
141
|
+
this._logger.message(LOGS.startsTheAddOn, { prefix: `${LOGS.tab}${LOGS.tab}` });
|
|
142
|
+
this._logger.message(LOGS.suggestBeginByTyping, {
|
|
143
|
+
prefix: LOGS.newLine,
|
|
144
|
+
postfix: LOGS.newLine
|
|
145
|
+
});
|
|
146
|
+
this._logger.warning(format(LOGS.changeDirectoryIntoCreatedApp, { cdPath }), {
|
|
147
|
+
prefix: LOGS.tab
|
|
148
|
+
});
|
|
149
|
+
this._logger.information(LOGS.npmRunBuild, { prefix: LOGS.tab });
|
|
150
|
+
this._logger.information(LOGS.npmRunStart, { prefix: LOGS.tab, postfix: LOGS.newLine });
|
|
151
|
+
if (this._readmeExists) {
|
|
152
|
+
this._logger.warning(LOGS.renamedReadme, { postfix: LOGS.newLine });
|
|
153
|
+
}
|
|
154
|
+
if (this._gitignoreExists) {
|
|
155
|
+
this._logger.warning(LOGS.mergedGitIgnore, { postfix: LOGS.newLine });
|
|
156
|
+
}
|
|
157
|
+
this._logger.warning(LOGS.whatWillYouCreateToday, { postfix: LOGS.newLine });
|
|
158
|
+
}
|
|
159
|
+
_updateReadMe() {
|
|
160
|
+
this._readmeExists = fs.existsSync(path.join(this._options.addOnDirectory, "README.md"));
|
|
161
|
+
if (this._readmeExists) {
|
|
162
|
+
fs.renameSync(path.join(this._options.addOnDirectory, "README.md"), path.join(this._options.addOnDirectory, "README.OLD.md"));
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
_copyTemplateFiles() {
|
|
166
|
+
const templateContentDirectory = path.join(this._templateRootDirectory, "template");
|
|
167
|
+
if (fs.existsSync(templateContentDirectory)) {
|
|
168
|
+
fs.copySync(templateContentDirectory, this._options.addOnDirectory);
|
|
169
|
+
}
|
|
170
|
+
else {
|
|
171
|
+
this._logger.warning(format(LOGS.couldNotLocateTemplate, { templateContentDirectory }));
|
|
172
|
+
process.exit(1);
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
_updateGitIgnore() {
|
|
176
|
+
this._gitignoreExists = fs.existsSync(path.join(this._options.addOnDirectory, ".gitignore"));
|
|
177
|
+
if (this._gitignoreExists) {
|
|
178
|
+
const data = fs.readFileSync(path.join(this._options.addOnDirectory, "gitignore"));
|
|
179
|
+
fs.appendFileSync(path.join(this._options.addOnDirectory, ".gitignore"), data);
|
|
180
|
+
fs.unlinkSync(path.join(this._options.addOnDirectory, "gitignore"));
|
|
181
|
+
}
|
|
182
|
+
else {
|
|
183
|
+
fs.moveSync(path.join(this._options.addOnDirectory, "gitignore"), path.join(this._options.addOnDirectory, ".gitignore"));
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
_updateManifest() {
|
|
187
|
+
const manifestJsonPath = path.join(this._options.addOnDirectory, "src", MANIFEST_JSON);
|
|
188
|
+
const manifestExists = fs.existsSync(manifestJsonPath);
|
|
189
|
+
let createManifestResult;
|
|
190
|
+
if (manifestExists) {
|
|
191
|
+
const manifestFile = this._require(manifestJsonPath);
|
|
192
|
+
const addOnName = this._getAddOnName(this._options.addOnName);
|
|
193
|
+
const manifestEntryPoints = manifestFile.entryPoints ?? [];
|
|
194
|
+
createManifestResult = AddOnManifest.createManifest({
|
|
195
|
+
manifest: {
|
|
196
|
+
...manifestFile,
|
|
197
|
+
testId: uuidv4(),
|
|
198
|
+
name: addOnName,
|
|
199
|
+
version: DEFAULT_ADD_ON_VERSION,
|
|
200
|
+
entryPoints: manifestEntryPoints
|
|
201
|
+
},
|
|
202
|
+
additionalInfo: ADDITIONAL_ADD_ON_INFO
|
|
203
|
+
});
|
|
204
|
+
fs.unlinkSync(manifestJsonPath);
|
|
205
|
+
}
|
|
206
|
+
else {
|
|
207
|
+
createManifestResult = AddOnManifest.createManifest({
|
|
208
|
+
manifest: {
|
|
209
|
+
testId: uuidv4(),
|
|
210
|
+
name: this._getAddOnName(this._options.addOnName),
|
|
211
|
+
version: DEFAULT_ADD_ON_VERSION,
|
|
212
|
+
manifestVersion: 2,
|
|
213
|
+
requirements: {
|
|
214
|
+
apps: [
|
|
215
|
+
{
|
|
216
|
+
name: "Express",
|
|
217
|
+
apiVersion: 1
|
|
218
|
+
}
|
|
219
|
+
]
|
|
220
|
+
},
|
|
221
|
+
entryPoints: [
|
|
222
|
+
{
|
|
223
|
+
type: EntrypointType.PANEL,
|
|
224
|
+
id: this._options.addOnName,
|
|
225
|
+
main: ""
|
|
226
|
+
}
|
|
227
|
+
]
|
|
228
|
+
},
|
|
229
|
+
additionalInfo: ADDITIONAL_ADD_ON_INFO
|
|
230
|
+
});
|
|
231
|
+
}
|
|
232
|
+
if (createManifestResult.manifest === undefined) {
|
|
233
|
+
return this._logger.warning(format(LOGS.invalidManifestInTemplate, {
|
|
234
|
+
templateName: this._options.templateName,
|
|
235
|
+
error: getJSONString(createManifestResult.manifestValidationResult)
|
|
236
|
+
}));
|
|
237
|
+
}
|
|
238
|
+
fs.writeFileSync(manifestJsonPath, getJSONString(createManifestResult.manifest.manifestProperties) + os.EOL);
|
|
239
|
+
}
|
|
240
|
+
_getAddOnName(addOnName) {
|
|
241
|
+
const camelCase = addOnName.replace(/[-_]\w/g, text => text.replace(/[-_]/, "").toUpperCase());
|
|
242
|
+
const wordCase = camelCase.replace(/([A-Z])/g, " $1");
|
|
243
|
+
return wordCase.charAt(0).toUpperCase() + wordCase.slice(1);
|
|
244
|
+
}
|
|
245
|
+
_removeTemplateTempFiles() {
|
|
246
|
+
fs.removeSync(this._templateRootDirectory);
|
|
247
|
+
}
|
|
248
|
+
};
|
|
249
|
+
AddOnBuilder = __decorate([
|
|
250
|
+
injectable(),
|
|
251
|
+
__param(1, inject(ICoreTypes.Logger)),
|
|
252
|
+
__metadata("design:paramtypes", [Function, Object])
|
|
253
|
+
], AddOnBuilder);
|
|
254
|
+
export { AddOnBuilder };
|
|
255
|
+
const LOGS = {
|
|
256
|
+
newLine: "\n",
|
|
257
|
+
tab: " ",
|
|
258
|
+
couldNotLocateTemplate: "Could not locate template: {templateContentDirectory}",
|
|
259
|
+
invalidManifestInTemplate: "Invalid manifest in the template: {templateName}. Error: {error}",
|
|
260
|
+
successCreatedAddOn: "Success! Created {addOnName} at {addOnDirectory}.",
|
|
261
|
+
insideDirectoryCommandsToRun: "Inside this directory, you can run the following commands:",
|
|
262
|
+
npmRunBuild: "npm run build",
|
|
263
|
+
npmRunStart: "npm run start",
|
|
264
|
+
buildsTheAddOn: "Builds the Add-on.",
|
|
265
|
+
startsTheAddOn: "Starts the development server and hosts the Add-on.",
|
|
266
|
+
suggestBeginByTyping: "We suggest that you begin by typing:",
|
|
267
|
+
changeDirectoryIntoCreatedApp: "cd {cdPath}",
|
|
268
|
+
renamedReadme: "You had a 'README.md' file, we renamed it to 'README.OLD.md'",
|
|
269
|
+
mergedGitIgnore: "You had a '.gitignore' file, we merged it with the template '.gitignore'",
|
|
270
|
+
whatWillYouCreateToday: "So what will you create today?"
|
|
271
|
+
};
|
|
25
272
|
//# sourceMappingURL=AddOnBuilder.js.map
|
|
@@ -21,16 +21,43 @@
|
|
|
21
21
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
22
22
|
* SOFTWARE.
|
|
23
23
|
********************************************************************************/
|
|
24
|
+
import type { Logger, Process } from "@adobe/ccweb-add-on-core";
|
|
25
|
+
import type { CommandExecutor as SSLCommandExecutor } from "@adobe/ccweb-add-on-ssl";
|
|
26
|
+
import { SetupCommandOptions as SSLSetupCommandOptions } from "@adobe/ccweb-add-on-ssl";
|
|
27
|
+
import "reflect-metadata";
|
|
24
28
|
import type { ScaffolderOptions } from "../models/ScaffolderOptions.js";
|
|
29
|
+
import type { TemplateValidator } from "../validators/TemplateValidator.js";
|
|
30
|
+
import type { AddOnBuilderFactory } from "./AddOnBuilder.js";
|
|
31
|
+
import type { PackageBuilderFactory } from "./PackageBuilder.js";
|
|
25
32
|
/**
|
|
26
|
-
*
|
|
33
|
+
* Scaffolder class for orchestrating the creation of the add-on project.
|
|
27
34
|
*/
|
|
28
|
-
export
|
|
35
|
+
export declare class AddOnScaffolder {
|
|
36
|
+
private readonly _addOnBuilderFactory;
|
|
37
|
+
private readonly _packageBuilderFactory;
|
|
38
|
+
private readonly _templateValidator;
|
|
39
|
+
private readonly _sslCommandExecutor;
|
|
40
|
+
private readonly _process;
|
|
41
|
+
private readonly _logger;
|
|
42
|
+
/**
|
|
43
|
+
* Instantiate {@link TemplateAppScaffolder}.
|
|
44
|
+
* @param addOnBuilderFactory - {@link AddOnBuilderFactory} reference.
|
|
45
|
+
* @param packageBuilderFactory - {@link PackageBuilderFactory} reference.
|
|
46
|
+
* @param templateValidator - {@link TemplateValidator} reference.
|
|
47
|
+
* @param sslCommandExecutor - {@link SSLCommandExecutor} reference.
|
|
48
|
+
* @param cliProcess - {@link Process} reference.
|
|
49
|
+
* @param logger - {@link Logger} reference.
|
|
50
|
+
* @returns Reference to a new {@link TemplateAppScaffolder} instance.
|
|
51
|
+
*/
|
|
52
|
+
constructor(addOnBuilderFactory: AddOnBuilderFactory, packageBuilderFactory: PackageBuilderFactory, templateValidator: TemplateValidator, sslCommandExecutor: SSLCommandExecutor<SSLSetupCommandOptions>, cliProcess: Process, logger: Logger);
|
|
29
53
|
/**
|
|
30
54
|
* Run the scaffolder to create the Add-on project from the provided options.
|
|
31
55
|
* @param options - {@link ScaffolderOptions} reference.
|
|
32
56
|
* @returns Promise.
|
|
33
57
|
*/
|
|
34
58
|
run(options: ScaffolderOptions): Promise<void>;
|
|
59
|
+
private _installDevDependencies;
|
|
60
|
+
private _installDependencies;
|
|
61
|
+
private _setupSSL;
|
|
35
62
|
}
|
|
36
63
|
//# sourceMappingURL=AddOnScaffolder.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AddOnScaffolder.d.ts","sourceRoot":"","sources":["../../src/app/AddOnScaffolder.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;kFAsBkF;AAElF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;
|
|
1
|
+
{"version":3,"file":"AddOnScaffolder.d.ts","sourceRoot":"","sources":["../../src/app/AddOnScaffolder.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;kFAsBkF;AAElF,OAAO,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AAEhE,OAAO,KAAK,EAAE,eAAe,IAAI,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AACrF,OAAO,EAAuB,mBAAmB,IAAI,sBAAsB,EAAE,MAAM,yBAAyB,CAAC;AAE7G,OAAO,kBAAkB,CAAC;AAE1B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AAC5E,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAC7D,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAEjE;;GAEG;AACH,qBACa,eAAe;IACxB,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAsB;IAC3D,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAAwB;IAC/D,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAoB;IAEvD,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAA6C;IAEjF,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAU;IACnC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IAEjC;;;;;;;;;OASG;gBAE8B,mBAAmB,EAAE,mBAAmB,EACtC,qBAAqB,EAAE,qBAAqB,EACzC,iBAAiB,EAAE,iBAAiB,EAGtE,kBAAkB,EAAE,kBAAkB,CAAC,sBAAsB,CAAC,EAClC,UAAU,EAAE,OAAO,EACpB,MAAM,EAAE,MAAM;IAY7C;;;;OAIG;IACG,GAAG,CAAC,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC;YA4BtC,uBAAuB;YAevB,oBAAoB;YAepB,SAAS;CAI1B"}
|
|
@@ -21,5 +21,110 @@
|
|
|
21
21
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
22
22
|
* SOFTWARE.
|
|
23
23
|
********************************************************************************/
|
|
24
|
-
|
|
24
|
+
import { __decorate, __metadata, __param } from "tslib";
|
|
25
|
+
import { DEFAULT_HOST_NAME, ITypes as ICoreTypes } from "@adobe/ccweb-add-on-core";
|
|
26
|
+
import { ITypes as ISSLTypes, SetupCommandOptions as SSLSetupCommandOptions } from "@adobe/ccweb-add-on-ssl";
|
|
27
|
+
import { inject, injectable, named } from "inversify";
|
|
28
|
+
import "reflect-metadata";
|
|
29
|
+
import { ITypes } from "../config/inversify.types.js";
|
|
30
|
+
/**
|
|
31
|
+
* Scaffolder class for orchestrating the creation of the add-on project.
|
|
32
|
+
*/
|
|
33
|
+
let AddOnScaffolder = class AddOnScaffolder {
|
|
34
|
+
_addOnBuilderFactory;
|
|
35
|
+
_packageBuilderFactory;
|
|
36
|
+
_templateValidator;
|
|
37
|
+
_sslCommandExecutor;
|
|
38
|
+
_process;
|
|
39
|
+
_logger;
|
|
40
|
+
/**
|
|
41
|
+
* Instantiate {@link TemplateAppScaffolder}.
|
|
42
|
+
* @param addOnBuilderFactory - {@link AddOnBuilderFactory} reference.
|
|
43
|
+
* @param packageBuilderFactory - {@link PackageBuilderFactory} reference.
|
|
44
|
+
* @param templateValidator - {@link TemplateValidator} reference.
|
|
45
|
+
* @param sslCommandExecutor - {@link SSLCommandExecutor} reference.
|
|
46
|
+
* @param cliProcess - {@link Process} reference.
|
|
47
|
+
* @param logger - {@link Logger} reference.
|
|
48
|
+
* @returns Reference to a new {@link TemplateAppScaffolder} instance.
|
|
49
|
+
*/
|
|
50
|
+
constructor(addOnBuilderFactory, packageBuilderFactory, templateValidator, sslCommandExecutor, cliProcess, logger) {
|
|
51
|
+
this._addOnBuilderFactory = addOnBuilderFactory;
|
|
52
|
+
this._packageBuilderFactory = packageBuilderFactory;
|
|
53
|
+
this._templateValidator = templateValidator;
|
|
54
|
+
this._sslCommandExecutor = sslCommandExecutor;
|
|
55
|
+
this._process = cliProcess;
|
|
56
|
+
this._logger = logger;
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Run the scaffolder to create the Add-on project from the provided options.
|
|
60
|
+
* @param options - {@link ScaffolderOptions} reference.
|
|
61
|
+
* @returns Promise.
|
|
62
|
+
*/
|
|
63
|
+
async run(options) {
|
|
64
|
+
try {
|
|
65
|
+
this._templateValidator.validateTemplate(options.templateName);
|
|
66
|
+
const addOnBuilder = this._addOnBuilderFactory(options);
|
|
67
|
+
const packageJson = addOnBuilder.getPackageJson();
|
|
68
|
+
const templateJson = addOnBuilder.getTemplateJson();
|
|
69
|
+
const packageBuilder = this._packageBuilderFactory(packageJson)(templateJson);
|
|
70
|
+
const combinedPackage = packageBuilder.build();
|
|
71
|
+
addOnBuilder.build(combinedPackage.toJSON());
|
|
72
|
+
const templateDevDependencies = addOnBuilder.getDevDependenciesToInstall(templateJson);
|
|
73
|
+
await this._installDevDependencies(templateDevDependencies, options.verbose);
|
|
74
|
+
const templateDependencies = addOnBuilder.getDependenciesToInstall(templateJson);
|
|
75
|
+
await this._installDependencies(templateDependencies, options.verbose);
|
|
76
|
+
await this._setupSSL(options.verbose);
|
|
77
|
+
addOnBuilder.displaySuccess();
|
|
78
|
+
}
|
|
79
|
+
catch (error) {
|
|
80
|
+
this._process.handleError(error);
|
|
81
|
+
process.exit(1);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
async _installDevDependencies(templateDevDependencies, verbose) {
|
|
85
|
+
if (templateDevDependencies.size > 0) {
|
|
86
|
+
const devDependencyArgs = ["install", "--save-dev", "--save-exact", ...templateDevDependencies];
|
|
87
|
+
if (verbose) {
|
|
88
|
+
devDependencyArgs.push("--verbose");
|
|
89
|
+
}
|
|
90
|
+
this._logger.information(LOGS.installingTemplateDevDependencies, {
|
|
91
|
+
prefix: LOGS.newLine
|
|
92
|
+
});
|
|
93
|
+
await this._process.execute("npm", devDependencyArgs, { stdio: "inherit" });
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
async _installDependencies(templateDependencies, verbose) {
|
|
97
|
+
if (templateDependencies.size > 0) {
|
|
98
|
+
const dependencyArgs = ["install", "--save", "--save-exact", ...templateDependencies];
|
|
99
|
+
if (verbose) {
|
|
100
|
+
dependencyArgs.push("--verbose");
|
|
101
|
+
}
|
|
102
|
+
this._logger.information(LOGS.installingTemplateDependencies, {
|
|
103
|
+
prefix: LOGS.newLine
|
|
104
|
+
});
|
|
105
|
+
await this._process.execute("npm", dependencyArgs, { stdio: "inherit" });
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
async _setupSSL(verbose) {
|
|
109
|
+
const setupCommandOptions = new SSLSetupCommandOptions(DEFAULT_HOST_NAME, true, verbose);
|
|
110
|
+
await this._sslCommandExecutor.execute(setupCommandOptions);
|
|
111
|
+
}
|
|
112
|
+
};
|
|
113
|
+
AddOnScaffolder = __decorate([
|
|
114
|
+
injectable(),
|
|
115
|
+
__param(0, inject(ITypes.AddOnBuilder)),
|
|
116
|
+
__param(1, inject(ITypes.PackageBuilder)),
|
|
117
|
+
__param(2, inject(ITypes.TemplateValidator)),
|
|
118
|
+
__param(3, inject(ISSLTypes.CommandExecutor)),
|
|
119
|
+
__param(3, named("setup")),
|
|
120
|
+
__param(4, inject(ICoreTypes.Process)),
|
|
121
|
+
__param(5, inject(ICoreTypes.Logger)),
|
|
122
|
+
__metadata("design:paramtypes", [Function, Function, Function, Object, Object, Object])
|
|
123
|
+
], AddOnScaffolder);
|
|
124
|
+
export { AddOnScaffolder };
|
|
125
|
+
const LOGS = {
|
|
126
|
+
newLine: "\n",
|
|
127
|
+
installingTemplateDevDependencies: "Installing template dev dependencies ...",
|
|
128
|
+
installingTemplateDependencies: "Installing template dependencies ..."
|
|
129
|
+
};
|
|
25
130
|
//# sourceMappingURL=AddOnScaffolder.js.map
|
|
@@ -21,18 +21,32 @@
|
|
|
21
21
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
22
22
|
* SOFTWARE.
|
|
23
23
|
********************************************************************************/
|
|
24
|
-
import type {
|
|
24
|
+
import type { TemplateJson } from "@adobe/ccweb-add-on-core";
|
|
25
|
+
import { PackageJson } from "@adobe/ccweb-add-on-core";
|
|
25
26
|
/**
|
|
26
|
-
* Package builder
|
|
27
|
+
* Package builder factory.
|
|
27
28
|
*/
|
|
28
|
-
export
|
|
29
|
+
export type PackageBuilderFactory = (packageJson: PackageJson) => (templateJson: TemplateJson) => PackageBuilder;
|
|
30
|
+
/**
|
|
31
|
+
* Package builder class for constructing the package.json of the add-on project.
|
|
32
|
+
*/
|
|
33
|
+
export declare class PackageBuilder {
|
|
34
|
+
private _combinedPackage;
|
|
35
|
+
private _templateJson;
|
|
36
|
+
/**
|
|
37
|
+
* Instantiate {@link PackageBuilder}.
|
|
38
|
+
*
|
|
39
|
+
* @param packageJson - {@link PackageJson}.
|
|
40
|
+
* @param templateJson - {@link TemplateJson}.
|
|
41
|
+
* @returns Reference to a new {@link PackageBuilder} instance.
|
|
42
|
+
*/
|
|
43
|
+
constructor(packageJson: PackageJson, templateJson: TemplateJson);
|
|
29
44
|
/**
|
|
30
45
|
* Build {@link PackageJson}.
|
|
31
46
|
*/
|
|
32
47
|
build(): PackageJson;
|
|
48
|
+
private _buildDevDependencies;
|
|
49
|
+
private _buildDependencies;
|
|
50
|
+
private _buildScripts;
|
|
33
51
|
}
|
|
34
|
-
/**
|
|
35
|
-
* Package builder factory.
|
|
36
|
-
*/
|
|
37
|
-
export type PackageBuilderFactory = (packageJson: PackageJson) => (templateJson: TemplateJson) => PackageBuilder;
|
|
38
52
|
//# sourceMappingURL=PackageBuilder.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PackageBuilder.d.ts","sourceRoot":"","sources":["../../src/app/PackageBuilder.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;kFAsBkF;AAElF,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"PackageBuilder.d.ts","sourceRoot":"","sources":["../../src/app/PackageBuilder.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;kFAsBkF;AAElF,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAGvD;;GAEG;AACH,MAAM,MAAM,qBAAqB,GAAG,CAAC,WAAW,EAAE,WAAW,KAAK,CAAC,YAAY,EAAE,YAAY,KAAK,cAAc,CAAC;AAEjH;;GAEG;AACH,qBACa,cAAc;IACvB,OAAO,CAAC,gBAAgB,CAAc;IACtC,OAAO,CAAC,aAAa,CAAe;IAEpC;;;;;;OAMG;gBACS,WAAW,EAAE,WAAW,EAAE,YAAY,EAAE,YAAY;IAKhE;;OAEG;IACH,KAAK,IAAI,WAAW;IAQpB,OAAO,CAAC,qBAAqB;IAc7B,OAAO,CAAC,kBAAkB;IAc1B,OAAO,CAAC,aAAa;CAaxB"}
|
|
@@ -21,5 +21,72 @@
|
|
|
21
21
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
22
22
|
* SOFTWARE.
|
|
23
23
|
********************************************************************************/
|
|
24
|
-
|
|
24
|
+
import { __decorate, __metadata } from "tslib";
|
|
25
|
+
import { PackageJson } from "@adobe/ccweb-add-on-core";
|
|
26
|
+
import { injectable } from "inversify";
|
|
27
|
+
/**
|
|
28
|
+
* Package builder class for constructing the package.json of the add-on project.
|
|
29
|
+
*/
|
|
30
|
+
let PackageBuilder = class PackageBuilder {
|
|
31
|
+
_combinedPackage;
|
|
32
|
+
_templateJson;
|
|
33
|
+
/**
|
|
34
|
+
* Instantiate {@link PackageBuilder}.
|
|
35
|
+
*
|
|
36
|
+
* @param packageJson - {@link PackageJson}.
|
|
37
|
+
* @param templateJson - {@link TemplateJson}.
|
|
38
|
+
* @returns Reference to a new {@link PackageBuilder} instance.
|
|
39
|
+
*/
|
|
40
|
+
constructor(packageJson, templateJson) {
|
|
41
|
+
this._combinedPackage = new PackageJson({ ...packageJson });
|
|
42
|
+
this._templateJson = templateJson;
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Build {@link PackageJson}.
|
|
46
|
+
*/
|
|
47
|
+
build() {
|
|
48
|
+
this._buildDevDependencies();
|
|
49
|
+
this._buildDependencies();
|
|
50
|
+
this._buildScripts();
|
|
51
|
+
return this._combinedPackage;
|
|
52
|
+
}
|
|
53
|
+
_buildDevDependencies() {
|
|
54
|
+
if (!this._templateJson.devDependencies || this._templateJson.devDependencies.size === 0) {
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
this._templateJson.devDependencies.forEach((value, key) => {
|
|
58
|
+
if (!this._combinedPackage.devDependencies) {
|
|
59
|
+
this._combinedPackage.devDependencies = new Map();
|
|
60
|
+
}
|
|
61
|
+
this._combinedPackage.devDependencies.set(key, value);
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
_buildDependencies() {
|
|
65
|
+
if (!this._templateJson.dependencies || this._templateJson.dependencies.size === 0) {
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
this._templateJson.dependencies.forEach((value, key) => {
|
|
69
|
+
if (!this._combinedPackage.dependencies) {
|
|
70
|
+
this._combinedPackage.dependencies = new Map();
|
|
71
|
+
}
|
|
72
|
+
this._combinedPackage.dependencies.set(key, value);
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
_buildScripts() {
|
|
76
|
+
if (!this._templateJson.scripts || this._templateJson.scripts.size === 0) {
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
this._templateJson.scripts.forEach((value, key) => {
|
|
80
|
+
if (!this._combinedPackage.scripts) {
|
|
81
|
+
this._combinedPackage.scripts = new Map();
|
|
82
|
+
}
|
|
83
|
+
this._combinedPackage.scripts.set(key, value);
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
PackageBuilder = __decorate([
|
|
88
|
+
injectable(),
|
|
89
|
+
__metadata("design:paramtypes", [PackageJson, Function])
|
|
90
|
+
], PackageBuilder);
|
|
91
|
+
export { PackageBuilder };
|
|
25
92
|
//# sourceMappingURL=PackageBuilder.js.map
|
package/dist/app/index.d.ts
CHANGED
|
@@ -24,7 +24,4 @@
|
|
|
24
24
|
export * from "./AddOnBuilder.js";
|
|
25
25
|
export * from "./AddOnScaffolder.js";
|
|
26
26
|
export * from "./PackageBuilder.js";
|
|
27
|
-
export * from "./TemplateAddOnBuilder.js";
|
|
28
|
-
export * from "./TemplateAddOnScaffolder.js";
|
|
29
|
-
export * from "./TemplatePackageBuilder.js";
|
|
30
27
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/app/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/app/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;kFAsBkF;AAElF,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/app/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;kFAsBkF;AAElF,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC"}
|
package/dist/app/index.js
CHANGED
|
@@ -24,7 +24,4 @@
|
|
|
24
24
|
export * from "./AddOnBuilder.js";
|
|
25
25
|
export * from "./AddOnScaffolder.js";
|
|
26
26
|
export * from "./PackageBuilder.js";
|
|
27
|
-
export * from "./TemplateAddOnBuilder.js";
|
|
28
|
-
export * from "./TemplateAddOnScaffolder.js";
|
|
29
|
-
export * from "./TemplatePackageBuilder.js";
|
|
30
27
|
//# sourceMappingURL=index.js.map
|