@oak-digital/types-4-strapi-2 0.2.1 → 0.2.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.editorconfig +9 -0
- package/.eslintrc.json +52 -0
- package/.prettierrc.json +7 -0
- package/README.md +2 -1
- package/lib/.prettierrc.json +7 -0
- package/lib/index.js +5 -3
- package/lib/interface/Attributes.d.ts +1 -1
- package/lib/interface/Attributes.js +46 -46
- package/lib/interface/Interface.d.ts +1 -1
- package/lib/interface/Interface.js +13 -15
- package/lib/interface/InterfaceManager.d.ts +3 -0
- package/lib/interface/InterfaceManager.js +47 -20
- package/lib/interface/schemaReader.js +15 -11
- package/lib/src/index.d.ts +1 -0
- package/lib/src/index.js +25 -0
- package/lib/src/interface/Attributes.d.ts +11 -0
- package/lib/src/interface/Attributes.js +148 -0
- package/lib/src/interface/BuiltinComponentInterface.d.ts +5 -0
- package/lib/src/interface/BuiltinComponentInterface.js +36 -0
- package/lib/src/interface/BuiltinInterface.d.ts +5 -0
- package/lib/src/interface/BuiltinInterface.js +33 -0
- package/lib/src/interface/ComponentInterface.d.ts +8 -0
- package/lib/src/interface/ComponentInterface.js +58 -0
- package/lib/src/interface/Interface.d.ts +31 -0
- package/lib/src/interface/Interface.js +112 -0
- package/lib/src/interface/InterfaceManager.d.ts +25 -0
- package/lib/src/interface/InterfaceManager.js +288 -0
- package/lib/src/interface/builtinInterfaces.d.ts +4 -0
- package/lib/src/interface/builtinInterfaces.js +81 -0
- package/lib/src/interface/schemaReader.d.ts +14 -0
- package/lib/src/interface/schemaReader.js +172 -0
- package/lib/src/utils/index.d.ts +3 -0
- package/lib/src/utils/index.js +67 -0
- package/package.json +8 -2
package/.editorconfig
ADDED
package/.eslintrc.json
ADDED
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
{
|
|
2
|
+
"env": {
|
|
3
|
+
"es2021": true,
|
|
4
|
+
"node": true
|
|
5
|
+
},
|
|
6
|
+
"extends": [
|
|
7
|
+
"eslint:recommended",
|
|
8
|
+
"plugin:@typescript-eslint/recommended"
|
|
9
|
+
],
|
|
10
|
+
"overrides": [
|
|
11
|
+
],
|
|
12
|
+
"parser": "@typescript-eslint/parser",
|
|
13
|
+
"parserOptions": {
|
|
14
|
+
"ecmaVersion": "latest",
|
|
15
|
+
"sourceType": "module"
|
|
16
|
+
},
|
|
17
|
+
"plugins": [
|
|
18
|
+
"@typescript-eslint"
|
|
19
|
+
],
|
|
20
|
+
"rules": {
|
|
21
|
+
"@typescript-eslint/no-explicit-any": "off",
|
|
22
|
+
"no-case-declarations": "off",
|
|
23
|
+
"@typescript-eslint/no-unused-vars": "off",
|
|
24
|
+
"default-case-last": ["error"],
|
|
25
|
+
"eqeqeq": ["error", "always"],
|
|
26
|
+
"no-lonely-if": ["error"],
|
|
27
|
+
"no-magic-numbers": ["warn", {
|
|
28
|
+
"ignoreArrayIndexes": true,
|
|
29
|
+
"ignore": [-1, 0, 1]
|
|
30
|
+
}],
|
|
31
|
+
"no-return-assign": ["error", "always"],
|
|
32
|
+
"no-return-await": ["error"],
|
|
33
|
+
"no-var": ["error"],
|
|
34
|
+
"no-cond-assign": ["error", "always"],
|
|
35
|
+
"indent": [
|
|
36
|
+
"error",
|
|
37
|
+
4
|
|
38
|
+
],
|
|
39
|
+
"linebreak-style": [
|
|
40
|
+
"error",
|
|
41
|
+
"unix"
|
|
42
|
+
],
|
|
43
|
+
"quotes": [
|
|
44
|
+
"error",
|
|
45
|
+
"single"
|
|
46
|
+
],
|
|
47
|
+
"semi": [
|
|
48
|
+
"error",
|
|
49
|
+
"always"
|
|
50
|
+
]
|
|
51
|
+
}
|
|
52
|
+
}
|
package/.prettierrc.json
ADDED
package/README.md
CHANGED
|
@@ -41,11 +41,12 @@ This can be done with the `--out` flag like in the following example.
|
|
|
41
41
|
* Generate typescript interfaces for all your api content-types and components
|
|
42
42
|
* Generate typescript interfaces for builtin types such as `Media` and `MediaFormat`
|
|
43
43
|
* Select input and output directory
|
|
44
|
+
* Prettier formatting and ability to use your own `.prettierrc`.
|
|
44
45
|
|
|
45
46
|
### Planned features
|
|
46
47
|
|
|
48
|
+
* Support for localization
|
|
47
49
|
* Support if you are using other plugins, such as `url-alias`, which should add extra fields for some interfaces.
|
|
48
|
-
* Nicer formatted interfaces
|
|
49
50
|
|
|
50
51
|
## Help
|
|
51
52
|
|
package/lib/index.js
CHANGED
|
@@ -6,16 +6,18 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
var commander_1 = require("commander");
|
|
7
7
|
var InterfaceManager_1 = __importDefault(require("./interface/InterfaceManager"));
|
|
8
8
|
commander_1.program
|
|
9
|
-
.name(
|
|
9
|
+
.name('t4s');
|
|
10
10
|
commander_1.program
|
|
11
11
|
.option('-i, --in <dir>', 'The src directory for strapi', './src')
|
|
12
12
|
.option('-o, --out <dir>', 'The output directory to output the types to', './types')
|
|
13
|
-
.option('--component-prefix <prefix>', 'A prefix for components',
|
|
13
|
+
.option('--component-prefix <prefix>', 'A prefix for components', '')
|
|
14
|
+
.option('--prettier <file>', 'The prettier config file to use for formatting typescript interfaces');
|
|
14
15
|
commander_1.program.parse();
|
|
15
16
|
var options = commander_1.program.opts();
|
|
16
|
-
var input = options.in, out = options.out, componentPrefix = options.componentPrefix;
|
|
17
|
+
var input = options.in, out = options.out, componentPrefix = options.componentPrefix, prettierFile = options.prettier;
|
|
17
18
|
var manager = new InterfaceManager_1.default(out, input, {
|
|
18
19
|
componentPrefix: componentPrefix,
|
|
20
|
+
prettierFile: prettierFile,
|
|
19
21
|
});
|
|
20
22
|
manager.run().catch(function (err) {
|
|
21
23
|
console.error(err);
|
|
@@ -9,11 +9,11 @@ var Attributes = /** @class */ (function () {
|
|
|
9
9
|
Attributes.prototype.isAttributeOptional = function (attr) {
|
|
10
10
|
// If it is a component / relation / dynamiczone it is always optional due to population
|
|
11
11
|
switch (attr.type) {
|
|
12
|
-
case
|
|
12
|
+
case 'nested':
|
|
13
13
|
return attr.nullable === true;
|
|
14
|
-
case
|
|
15
|
-
case
|
|
16
|
-
case
|
|
14
|
+
case 'component':
|
|
15
|
+
case 'dynamiczone':
|
|
16
|
+
case 'relation':
|
|
17
17
|
return true;
|
|
18
18
|
default:
|
|
19
19
|
break;
|
|
@@ -26,18 +26,18 @@ var Attributes = /** @class */ (function () {
|
|
|
26
26
|
var attr = this.Attrs[attrName];
|
|
27
27
|
var dependencyNames = [];
|
|
28
28
|
switch (attr.type) {
|
|
29
|
-
case
|
|
29
|
+
case 'nested':
|
|
30
30
|
var attrs = new Attributes(attr.fields, this.RelationNames);
|
|
31
31
|
dependencyNames.push.apply(dependencyNames, attrs.getDependencies());
|
|
32
32
|
break;
|
|
33
|
-
case
|
|
33
|
+
case 'relation':
|
|
34
34
|
dependencyNames.push(attr.target);
|
|
35
35
|
break;
|
|
36
|
-
case
|
|
36
|
+
case 'component':
|
|
37
37
|
dependencyNames.push(attr.component);
|
|
38
38
|
break;
|
|
39
|
-
case
|
|
40
|
-
dependencyNames.push(
|
|
39
|
+
case 'media':
|
|
40
|
+
dependencyNames.push('builtins::Media');
|
|
41
41
|
break;
|
|
42
42
|
default:
|
|
43
43
|
continue;
|
|
@@ -55,70 +55,70 @@ var Attributes = /** @class */ (function () {
|
|
|
55
55
|
return dependencies;
|
|
56
56
|
};
|
|
57
57
|
Attributes.prototype.attributeToString = function (attrName, attr) {
|
|
58
|
-
var _a
|
|
58
|
+
var _a;
|
|
59
59
|
var optionalString = this.isAttributeOptional(attr) ? '?' : '';
|
|
60
60
|
var str = " ".concat(attrName).concat(optionalString, ": ");
|
|
61
61
|
var isArray = false;
|
|
62
62
|
switch (attr.type) {
|
|
63
63
|
// types-4-strapi-2 specific, used for builtin types
|
|
64
|
-
case
|
|
64
|
+
case 'nested':
|
|
65
65
|
// Be careful with recursion
|
|
66
66
|
// console.log(attr);
|
|
67
67
|
var newAttrs = new Attributes(attr.fields, this.RelationNames);
|
|
68
68
|
str += newAttrs.toString();
|
|
69
69
|
break;
|
|
70
|
-
case
|
|
70
|
+
case 'relation':
|
|
71
71
|
var apiName = attr.target;
|
|
72
72
|
// console.log(this.RelationNames, apiName)
|
|
73
73
|
var dependencyName = this.RelationNames[apiName].name;
|
|
74
|
-
|
|
75
|
-
str += dependencyName;
|
|
74
|
+
var relationMultipleString = attr.relation.endsWith('ToMany') ? '[]' : ' | null';
|
|
75
|
+
str += "{ data: ".concat(dependencyName).concat(relationMultipleString, "; }");
|
|
76
76
|
break;
|
|
77
|
-
case
|
|
77
|
+
case 'component':
|
|
78
78
|
var componentName = attr.component;
|
|
79
79
|
var relationNameObj = this.RelationNames[componentName];
|
|
80
80
|
var dependencyComponentName = relationNameObj.name;
|
|
81
81
|
isArray = (_a = attr.repeatable) !== null && _a !== void 0 ? _a : false;
|
|
82
82
|
str += dependencyComponentName;
|
|
83
83
|
break;
|
|
84
|
-
case
|
|
85
|
-
var mediaOptional = attr.required !== true ?
|
|
86
|
-
|
|
87
|
-
|
|
84
|
+
case 'media':
|
|
85
|
+
var mediaOptional = attr.required !== true ? '?' : '';
|
|
86
|
+
var mediaMultipleString = attr.multiple ? '[]' : ' | null';
|
|
87
|
+
str += "{ data".concat(mediaOptional, ": ").concat(this.RelationNames['builtins::Media'].name).concat(mediaMultipleString, "; }");
|
|
88
88
|
break;
|
|
89
|
-
case
|
|
89
|
+
case 'password':
|
|
90
90
|
return null;
|
|
91
|
-
case
|
|
92
|
-
var hasDefault =
|
|
91
|
+
case 'enumeration':
|
|
92
|
+
var hasDefault = 'default' in attr;
|
|
93
93
|
var enums = attr.enum.map(function (en) { return "\"".concat(en, "\""); });
|
|
94
|
-
enums.push(
|
|
95
|
-
var typeString = enums.join(
|
|
94
|
+
enums.push('null');
|
|
95
|
+
var typeString = enums.join(' | ');
|
|
96
96
|
str += typeString;
|
|
97
97
|
break;
|
|
98
|
-
case
|
|
99
|
-
case
|
|
100
|
-
case
|
|
101
|
-
case
|
|
102
|
-
case
|
|
103
|
-
str +=
|
|
98
|
+
case 'string':
|
|
99
|
+
case 'text':
|
|
100
|
+
case 'richtext':
|
|
101
|
+
case 'email':
|
|
102
|
+
case 'uid':
|
|
103
|
+
str += 'string';
|
|
104
104
|
break;
|
|
105
|
-
case
|
|
106
|
-
case
|
|
107
|
-
case
|
|
108
|
-
case
|
|
109
|
-
str +=
|
|
105
|
+
case 'integer':
|
|
106
|
+
case 'biginteger':
|
|
107
|
+
case 'decimal':
|
|
108
|
+
case 'float':
|
|
109
|
+
str += 'number';
|
|
110
110
|
break;
|
|
111
|
-
case
|
|
112
|
-
case
|
|
113
|
-
case
|
|
114
|
-
str +=
|
|
111
|
+
case 'date':
|
|
112
|
+
case 'datetime':
|
|
113
|
+
case 'time':
|
|
114
|
+
str += 'Date';
|
|
115
115
|
break;
|
|
116
|
-
case
|
|
116
|
+
case 'boolean':
|
|
117
117
|
str += attr.type;
|
|
118
118
|
break;
|
|
119
|
-
case
|
|
119
|
+
case 'json':
|
|
120
120
|
default:
|
|
121
|
-
str +=
|
|
121
|
+
str += 'any';
|
|
122
122
|
break;
|
|
123
123
|
}
|
|
124
124
|
var isArrayString = isArray ? '[]' : '';
|
|
@@ -135,13 +135,13 @@ var Attributes = /** @class */ (function () {
|
|
|
135
135
|
}
|
|
136
136
|
strings.push(attrString);
|
|
137
137
|
}
|
|
138
|
-
return strings.map(function (s) { return "".concat(s, "\n"); }).join(
|
|
138
|
+
return strings.map(function (s) { return "".concat(s, "\n"); }).join('');
|
|
139
139
|
};
|
|
140
140
|
Attributes.prototype.toString = function () {
|
|
141
|
-
var strings = [
|
|
141
|
+
var strings = ['{'];
|
|
142
142
|
strings.push(this.toFieldsString());
|
|
143
|
-
strings.push(
|
|
144
|
-
return strings.join(
|
|
143
|
+
strings.push('}');
|
|
144
|
+
return strings.join('\n');
|
|
145
145
|
};
|
|
146
146
|
return Attributes;
|
|
147
147
|
}());
|
|
@@ -3,16 +3,16 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
var
|
|
6
|
+
var posix_1 = require("path/posix");
|
|
7
7
|
var utils_1 = require("../utils");
|
|
8
8
|
var Attributes_1 = __importDefault(require("./Attributes"));
|
|
9
9
|
var Interface = /** @class */ (function () {
|
|
10
10
|
function Interface(baseName, attributes, relativeDirectoryPath, prefix) {
|
|
11
|
-
if (prefix === void 0) { prefix =
|
|
11
|
+
if (prefix === void 0) { prefix = ''; }
|
|
12
12
|
this.Relations = []; // Components and relations
|
|
13
13
|
this.RelationNames = {};
|
|
14
14
|
this.RelationNamesCounter = {};
|
|
15
|
-
this.NamePrefix =
|
|
15
|
+
this.NamePrefix = '';
|
|
16
16
|
this.BaseName = baseName;
|
|
17
17
|
this.updateStrapiName();
|
|
18
18
|
this.NamePrefix = prefix;
|
|
@@ -38,11 +38,11 @@ var Interface = /** @class */ (function () {
|
|
|
38
38
|
};
|
|
39
39
|
// For typescript import from index file
|
|
40
40
|
Interface.prototype.getRelativeRootPath = function () {
|
|
41
|
-
var path = (0,
|
|
41
|
+
var path = (0, posix_1.join)(this.RelativeDirectoryPath, this.getBaseName());
|
|
42
42
|
return (0, utils_1.prefixDotSlash)(path);
|
|
43
43
|
};
|
|
44
44
|
Interface.prototype.getRelativeRootDir = function () {
|
|
45
|
-
var path = (0,
|
|
45
|
+
var path = (0, posix_1.dirname)(this.getRelativeRootPathFile());
|
|
46
46
|
return path;
|
|
47
47
|
};
|
|
48
48
|
Interface.prototype.getRelativeRootPathFile = function () {
|
|
@@ -55,9 +55,7 @@ var Interface = /** @class */ (function () {
|
|
|
55
55
|
this.Relations.forEach(function (inter) {
|
|
56
56
|
var name = inter.getFullInterfaceName();
|
|
57
57
|
// FIXME: clean up this mess...
|
|
58
|
-
if (inter.getStrapiName()
|
|
59
|
-
}
|
|
60
|
-
else {
|
|
58
|
+
if (inter.getStrapiName() !== _this.getStrapiName()) {
|
|
61
59
|
// Avoid duplicate names
|
|
62
60
|
if (name in _this.RelationNamesCounter) {
|
|
63
61
|
name += ++_this.RelationNamesCounter[name];
|
|
@@ -73,15 +71,15 @@ var Interface = /** @class */ (function () {
|
|
|
73
71
|
var _this = this;
|
|
74
72
|
return Object.keys(this.RelationNames).map(function (strapiName) {
|
|
75
73
|
if (strapiName === _this.getStrapiName()) {
|
|
76
|
-
return
|
|
74
|
+
return '';
|
|
77
75
|
}
|
|
78
76
|
var relationName = _this.RelationNames[strapiName].name;
|
|
79
77
|
var inter = _this.RelationNames[strapiName].inter;
|
|
80
|
-
var importPath = (0, utils_1.prefixDotSlash)((0,
|
|
78
|
+
var importPath = (0, utils_1.prefixDotSlash)((0, posix_1.relative)(_this.getRelativeRootDir(), inter.getRelativeRootPath()));
|
|
81
79
|
var fullName = inter.getFullInterfaceName();
|
|
82
80
|
var importNameString = fullName === relationName ? fullName : "".concat(fullName, " as ").concat(relationName);
|
|
83
81
|
return "import { ".concat(importNameString, " } from '").concat(importPath, "';");
|
|
84
|
-
}).filter(function (s) { return s; }).join(
|
|
82
|
+
}).filter(function (s) { return s; }).join('\n');
|
|
85
83
|
};
|
|
86
84
|
Interface.prototype.getAttributes = function () {
|
|
87
85
|
return new Attributes_1.default(this.Attributes, this.RelationNames);
|
|
@@ -93,13 +91,13 @@ var Interface = /** @class */ (function () {
|
|
|
93
91
|
Interface.prototype.getInerfaceString = function () {
|
|
94
92
|
var str = "export interface ".concat(this.getFullInterfaceName(), " {\n");
|
|
95
93
|
str += this.getInterfaceFieldsString();
|
|
96
|
-
str +=
|
|
94
|
+
str += '}';
|
|
97
95
|
return str;
|
|
98
96
|
};
|
|
99
97
|
Interface.prototype.getInterfaceFieldsString = function () {
|
|
100
98
|
var str = '';
|
|
101
|
-
str +=
|
|
102
|
-
str += "
|
|
99
|
+
str += 'id: number;\n';
|
|
100
|
+
str += "attributes: ".concat(this.attributesToString(), "\n");
|
|
103
101
|
return str;
|
|
104
102
|
};
|
|
105
103
|
Interface.prototype.toString = function () {
|
|
@@ -107,7 +105,7 @@ var Interface = /** @class */ (function () {
|
|
|
107
105
|
this.getTsImports(),
|
|
108
106
|
this.getInerfaceString()
|
|
109
107
|
];
|
|
110
|
-
return strings.join(
|
|
108
|
+
return strings.join('\n');
|
|
111
109
|
};
|
|
112
110
|
return Interface;
|
|
113
111
|
}());
|
|
@@ -3,6 +3,7 @@ export default class InterfaceManager {
|
|
|
3
3
|
private OutRoot;
|
|
4
4
|
private StrapiSrcRoot;
|
|
5
5
|
private Options;
|
|
6
|
+
private PrettierOptions;
|
|
6
7
|
static BaseOptions: {
|
|
7
8
|
prefix: string;
|
|
8
9
|
useCategoryPrefix: boolean;
|
|
@@ -10,8 +11,10 @@ export default class InterfaceManager {
|
|
|
10
11
|
componentPrefixOverridesPrefix: boolean;
|
|
11
12
|
builtinsPrefix: string;
|
|
12
13
|
builtinsPrefixOverridesPrefix: boolean;
|
|
14
|
+
prettierFile: any;
|
|
13
15
|
};
|
|
14
16
|
constructor(outRoot: string, strapiSrcRoot: string, options?: any);
|
|
17
|
+
loadPrettierConfig(): Promise<void>;
|
|
15
18
|
createInterfaces(): Promise<void>;
|
|
16
19
|
createBuiltinInterfaces(): void;
|
|
17
20
|
injectDependencies(): void;
|
|
@@ -41,12 +41,13 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
41
41
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
42
42
|
var fs_1 = require("fs");
|
|
43
43
|
var promises_1 = require("fs/promises");
|
|
44
|
-
var
|
|
44
|
+
var posix_1 = require("path/posix");
|
|
45
45
|
var utils_1 = require("../utils");
|
|
46
46
|
var builtinInterfaces_1 = require("./builtinInterfaces");
|
|
47
47
|
var ComponentInterface_1 = __importDefault(require("./ComponentInterface"));
|
|
48
48
|
var Interface_1 = __importDefault(require("./Interface"));
|
|
49
49
|
var schemaReader_1 = require("./schemaReader");
|
|
50
|
+
var prettier_1 = __importDefault(require("prettier"));
|
|
50
51
|
var InterfaceManager = /** @class */ (function () {
|
|
51
52
|
function InterfaceManager(outRoot, strapiSrcRoot, options) {
|
|
52
53
|
if (options === void 0) { options = {}; }
|
|
@@ -55,6 +56,28 @@ var InterfaceManager = /** @class */ (function () {
|
|
|
55
56
|
this.StrapiSrcRoot = strapiSrcRoot;
|
|
56
57
|
this.Options = Object.assign({}, InterfaceManager.BaseOptions, options);
|
|
57
58
|
}
|
|
59
|
+
InterfaceManager.prototype.loadPrettierConfig = function () {
|
|
60
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
61
|
+
var defaultOptions, resolved;
|
|
62
|
+
return __generator(this, function (_a) {
|
|
63
|
+
switch (_a.label) {
|
|
64
|
+
case 0:
|
|
65
|
+
defaultOptions = {
|
|
66
|
+
parser: 'typescript',
|
|
67
|
+
};
|
|
68
|
+
if (!this.Options.prettierFile) {
|
|
69
|
+
this.PrettierOptions = defaultOptions;
|
|
70
|
+
return [2 /*return*/];
|
|
71
|
+
}
|
|
72
|
+
return [4 /*yield*/, prettier_1.default.resolveConfig(this.Options.prettierFile)];
|
|
73
|
+
case 1:
|
|
74
|
+
resolved = _a.sent();
|
|
75
|
+
this.PrettierOptions = Object.assign({}, defaultOptions, resolved);
|
|
76
|
+
return [2 /*return*/];
|
|
77
|
+
}
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
};
|
|
58
81
|
InterfaceManager.prototype.createInterfaces = function () {
|
|
59
82
|
return __awaiter(this, void 0, void 0, function () {
|
|
60
83
|
var apiSchemasPromise, componentSchemasPromise, apiSchemas, componentSchemas;
|
|
@@ -70,7 +93,7 @@ var InterfaceManager = /** @class */ (function () {
|
|
|
70
93
|
apiSchemas.forEach(function (schema) {
|
|
71
94
|
var name = schema.name, attributes = schema.attributes;
|
|
72
95
|
var strapiName = "api::".concat(name, ".").concat(name);
|
|
73
|
-
var inter = new Interface_1.default(name, attributes,
|
|
96
|
+
var inter = new Interface_1.default(name, attributes, './', _this.Options.prefix);
|
|
74
97
|
_this.Interfaces[strapiName] = inter;
|
|
75
98
|
});
|
|
76
99
|
return [4 /*yield*/, componentSchemasPromise];
|
|
@@ -81,7 +104,7 @@ var InterfaceManager = /** @class */ (function () {
|
|
|
81
104
|
category.schemas.forEach(function (schema) {
|
|
82
105
|
var componentName = schema.name;
|
|
83
106
|
var strapiName = "".concat(categoryName, ".").concat(schema.name);
|
|
84
|
-
var componentPrefix = "".concat(_this.Options.componentPrefix).concat(_this.Options.useCategoryPrefix ? (0, utils_1.pascalCase)(categoryName) :
|
|
107
|
+
var componentPrefix = "".concat(_this.Options.componentPrefix).concat(_this.Options.useCategoryPrefix ? (0, utils_1.pascalCase)(categoryName) : '');
|
|
85
108
|
var prefix = _this.Options.componentPrefixOverridesPrefix ? componentPrefix : _this.Options.prefix + componentPrefix;
|
|
86
109
|
// TODO: make component interface
|
|
87
110
|
var inter = new ComponentInterface_1.default(componentName, schema.attributes, "./".concat(categoryName), categoryName, prefix);
|
|
@@ -95,7 +118,7 @@ var InterfaceManager = /** @class */ (function () {
|
|
|
95
118
|
};
|
|
96
119
|
InterfaceManager.prototype.createBuiltinInterfaces = function () {
|
|
97
120
|
var _this = this;
|
|
98
|
-
var outDir =
|
|
121
|
+
var outDir = './builtins';
|
|
99
122
|
var builtinInterfaces = [];
|
|
100
123
|
builtinInterfaces.push((0, builtinInterfaces_1.createMediaInterface)(outDir, this.Options.prefix));
|
|
101
124
|
builtinInterfaces.push((0, builtinInterfaces_1.createMediaFormatInterface)(outDir, this.Options.prefix));
|
|
@@ -140,7 +163,7 @@ var InterfaceManager = /** @class */ (function () {
|
|
|
140
163
|
return __generator(this, function (_a) {
|
|
141
164
|
switch (_a.label) {
|
|
142
165
|
case 0:
|
|
143
|
-
path = (0,
|
|
166
|
+
path = (0, posix_1.join)(this.OutRoot, category);
|
|
144
167
|
if ((0, fs_1.existsSync)(path)) {
|
|
145
168
|
return [2 /*return*/];
|
|
146
169
|
}
|
|
@@ -152,9 +175,9 @@ var InterfaceManager = /** @class */ (function () {
|
|
|
152
175
|
});
|
|
153
176
|
}); });
|
|
154
177
|
promises.push.apply(promises, componentCategoriesPromises);
|
|
155
|
-
builtinsPath = (0,
|
|
178
|
+
builtinsPath = (0, posix_1.join)(this.OutRoot, 'builtins');
|
|
156
179
|
if (!(0, fs_1.existsSync)(builtinsPath)) {
|
|
157
|
-
promises.push((0, promises_1.mkdir)((0,
|
|
180
|
+
promises.push((0, promises_1.mkdir)((0, posix_1.join)(this.OutRoot, 'builtins')));
|
|
158
181
|
}
|
|
159
182
|
return [4 /*yield*/, Promise.all(promises)];
|
|
160
183
|
case 4:
|
|
@@ -172,14 +195,15 @@ var InterfaceManager = /** @class */ (function () {
|
|
|
172
195
|
switch (_a.label) {
|
|
173
196
|
case 0:
|
|
174
197
|
writePromises = Object.keys(this.Interfaces).map(function (strapiName) { return __awaiter(_this, void 0, void 0, function () {
|
|
175
|
-
var inter, fileData, filePath;
|
|
198
|
+
var inter, fileData, formattedFileData, filePath;
|
|
176
199
|
return __generator(this, function (_a) {
|
|
177
200
|
switch (_a.label) {
|
|
178
201
|
case 0:
|
|
179
202
|
inter = this.Interfaces[strapiName];
|
|
180
203
|
fileData = inter.toString();
|
|
181
|
-
|
|
182
|
-
|
|
204
|
+
formattedFileData = prettier_1.default.format(fileData, this.PrettierOptions);
|
|
205
|
+
filePath = (0, posix_1.join)(this.OutRoot, inter.getRelativeRootPathFile());
|
|
206
|
+
return [4 /*yield*/, (0, promises_1.writeFile)(filePath, formattedFileData)];
|
|
183
207
|
case 1:
|
|
184
208
|
_a.sent();
|
|
185
209
|
return [2 /*return*/];
|
|
@@ -196,7 +220,7 @@ var InterfaceManager = /** @class */ (function () {
|
|
|
196
220
|
};
|
|
197
221
|
InterfaceManager.prototype.writeIndexFile = function () {
|
|
198
222
|
return __awaiter(this, void 0, void 0, function () {
|
|
199
|
-
var strings, fileData, filePath;
|
|
223
|
+
var strings, fileData, formattedFileData, filePath;
|
|
200
224
|
var _this = this;
|
|
201
225
|
return __generator(this, function (_a) {
|
|
202
226
|
switch (_a.label) {
|
|
@@ -205,9 +229,10 @@ var InterfaceManager = /** @class */ (function () {
|
|
|
205
229
|
var inter = _this.Interfaces[strapiName];
|
|
206
230
|
return "export * from '".concat(inter.getRelativeRootPath(), "'");
|
|
207
231
|
});
|
|
208
|
-
fileData = strings.join(
|
|
209
|
-
|
|
210
|
-
|
|
232
|
+
fileData = strings.join('\n');
|
|
233
|
+
formattedFileData = prettier_1.default.format(fileData, this.PrettierOptions);
|
|
234
|
+
filePath = (0, posix_1.join)(this.OutRoot, 'index.ts');
|
|
235
|
+
return [4 /*yield*/, (0, promises_1.writeFile)(filePath, formattedFileData)];
|
|
211
236
|
case 1:
|
|
212
237
|
_a.sent();
|
|
213
238
|
return [2 /*return*/];
|
|
@@ -217,20 +242,21 @@ var InterfaceManager = /** @class */ (function () {
|
|
|
217
242
|
};
|
|
218
243
|
InterfaceManager.prototype.run = function () {
|
|
219
244
|
return __awaiter(this, void 0, void 0, function () {
|
|
220
|
-
var createInterfacesPromise, makeFoldersPromise, err_1;
|
|
245
|
+
var createInterfacesPromise, makeFoldersPromise, loadPrettierPromise, err_1;
|
|
221
246
|
return __generator(this, function (_a) {
|
|
222
247
|
switch (_a.label) {
|
|
223
248
|
case 0:
|
|
224
249
|
_a.trys.push([0, 4, , 5]);
|
|
225
250
|
createInterfacesPromise = this.createInterfaces();
|
|
226
251
|
makeFoldersPromise = this.makeFolders();
|
|
252
|
+
loadPrettierPromise = this.loadPrettierConfig();
|
|
227
253
|
this.createBuiltinInterfaces();
|
|
228
254
|
return [4 /*yield*/, createInterfacesPromise];
|
|
229
255
|
case 1:
|
|
230
256
|
_a.sent();
|
|
231
257
|
// Create all interfaces before injecting
|
|
232
258
|
this.injectDependencies();
|
|
233
|
-
return [4 /*yield*/, makeFoldersPromise];
|
|
259
|
+
return [4 /*yield*/, Promise.all([makeFoldersPromise, loadPrettierPromise])];
|
|
234
260
|
case 2:
|
|
235
261
|
_a.sent();
|
|
236
262
|
return [4 /*yield*/, Promise.all([this.writeInterfaces(), this.writeIndexFile()])];
|
|
@@ -247,12 +273,13 @@ var InterfaceManager = /** @class */ (function () {
|
|
|
247
273
|
});
|
|
248
274
|
};
|
|
249
275
|
InterfaceManager.BaseOptions = {
|
|
250
|
-
prefix:
|
|
276
|
+
prefix: 'I',
|
|
251
277
|
useCategoryPrefix: true,
|
|
252
|
-
componentPrefix:
|
|
278
|
+
componentPrefix: '',
|
|
253
279
|
componentPrefixOverridesPrefix: false,
|
|
254
|
-
builtinsPrefix:
|
|
255
|
-
builtinsPrefixOverridesPrefix: false
|
|
280
|
+
builtinsPrefix: '',
|
|
281
|
+
builtinsPrefixOverridesPrefix: false,
|
|
282
|
+
prettierFile: null,
|
|
256
283
|
};
|
|
257
284
|
return InterfaceManager;
|
|
258
285
|
}());
|