eddev 0.1.50 → 0.2.0-beta.10
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/build/build-favicon.d.ts +1 -0
- package/build/build-favicon.js +71 -0
- package/build/create-serverless-dev-worker.d.ts +3 -0
- package/build/create-serverless-dev-worker.js +99 -0
- package/build/file-tree.js +4 -0
- package/build/get-webpack-config.js +58 -143
- package/build/manifests/manifest-blocks.d.ts +12 -0
- package/build/manifests/manifest-blocks.js +61 -0
- package/build/manifests/manifest-fields.d.ts +12 -0
- package/build/manifests/manifest-fields.js +42 -0
- package/build/manifests/manifest-views.d.ts +12 -0
- package/build/manifests/manifest-views.js +49 -0
- package/build/manifests/manifest.d.ts +11 -0
- package/build/manifests/manifest.js +96 -0
- package/build/reporter.js +0 -109
- package/build/serverless/create-next-app.d.ts +9 -0
- package/build/serverless/create-next-app.js +434 -0
- package/build/state/serverless-state.d.ts +26 -0
- package/build/state/serverless-state.js +2 -0
- package/build/workers/serverless-worker-dev-script.d.ts +1 -0
- package/build/workers/serverless-worker-dev-script.js +21 -0
- package/build/workers/serverless-worker-script.d.ts +0 -0
- package/build/workers/serverless-worker-script.js +1 -0
- package/cli/build.dev.js +30 -7
- package/cli/build.prod.js +5 -0
- package/cli/cli.js +32 -3
- package/cli/display/components/DevCLIDisplay.d.ts +3 -0
- package/cli/display/components/DevCLIDisplay.js +20 -1
- package/cli/display/components/ServerlessDisplay.d.ts +9 -0
- package/cli/display/components/ServerlessDisplay.js +68 -0
- package/components/NextRouter.d.ts +9 -0
- package/components/NextRouter.js +36 -0
- package/components/ServerlessRouter.d.ts +0 -0
- package/components/ServerlessRouter.js +1 -0
- package/config/config-schema.d.ts +65 -0
- package/config/config-schema.js +23 -0
- package/config/create-schema-file.d.ts +1 -0
- package/config/create-schema-file.js +20 -0
- package/config/get-config.d.ts +45 -0
- package/config/get-config.js +32 -0
- package/config/index.d.ts +2 -0
- package/config/index.js +14 -0
- package/config/parse-config.d.ts +29 -0
- package/config/parse-config.js +8 -0
- package/config/print-zod-errors.d.ts +2 -0
- package/config/print-zod-errors.js +14 -0
- package/dynamic/dynamic-component.d.ts +10 -0
- package/dynamic/dynamic-component.js +8 -0
- package/dynamic/index.d.ts +1 -0
- package/dynamic/index.js +13 -0
- package/gravityforms/useGravityForm.js +1 -1
- package/hooks/queryUtils.js +2 -2
- package/hooks/useAppData.js +15 -4
- package/package.json +11 -6
- package/routing/routing.js +5 -0
- package/serverless/create-rpc-client.d.ts +33 -0
- package/serverless/create-rpc-client.js +20 -0
- package/serverless/define-api.d.ts +2 -0
- package/serverless/define-api.js +66 -0
- package/serverless/define-rpc-router.d.ts +2 -0
- package/serverless/define-rpc-router.js +27 -0
- package/serverless/error-codes.d.ts +2 -0
- package/serverless/error-codes.js +14 -0
- package/serverless/index.d.ts +4 -0
- package/serverless/index.js +16 -0
- package/serverless/rpc-provider.d.ts +1 -0
- package/serverless/rpc-provider.js +5 -0
- package/serverless-template/README.md +34 -0
- package/serverless-template/_utils/ed-config.ts +5 -0
- package/serverless-template/_utils/fetch-wordpress-props.ts +39 -0
- package/serverless-template/global.d.ts +9 -0
- package/serverless-template/next-env.d.ts +3 -0
- package/serverless-template/next.config.js +69 -0
- package/serverless-template/null.ts +1 -0
- package/serverless-template/package-lock.json +641 -0
- package/serverless-template/package.json +19 -0
- package/serverless-template/pages/[...slug].tsx +20 -0
- package/serverless-template/pages/_app.tsx +34 -0
- package/serverless-template/pages/_document.tsx +19 -0
- package/serverless-template/pages/api/hello.ts +10 -0
- package/serverless-template/pages/api/rest/[...method].ts +38 -0
- package/serverless-template/pages/index.tsx +12 -0
- package/serverless-template/tsconfig.json +37 -0
- package/utils/getRepoName.d.ts +2 -2
- package/utils/getRepoName.js +6 -52
- package/utils/serverlessAppContext.d.ts +3 -0
- package/utils/serverlessAppContext.js +6 -0
- package/fields/ImageWell.d.ts +0 -8
- package/fields/ImageWell.js +0 -64
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function buildFavicon(output?: string): Promise<void>;
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
12
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
13
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
14
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
15
|
+
function step(op) {
|
|
16
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
17
|
+
while (_) try {
|
|
18
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
19
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
20
|
+
switch (op[0]) {
|
|
21
|
+
case 0: case 1: t = op; break;
|
|
22
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
23
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
24
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
25
|
+
default:
|
|
26
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
27
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
28
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
29
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
30
|
+
if (t[2]) _.ops.pop();
|
|
31
|
+
_.trys.pop(); continue;
|
|
32
|
+
}
|
|
33
|
+
op = body.call(thisArg, _);
|
|
34
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
35
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
39
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
40
|
+
};
|
|
41
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
42
|
+
exports.buildFavicon = void 0;
|
|
43
|
+
// @ts-ignore
|
|
44
|
+
var to_icon_1 = __importDefault(require("to-icon"));
|
|
45
|
+
var promises_1 = require("fs/promises");
|
|
46
|
+
var glob_promise_1 = __importDefault(require("glob-promise"));
|
|
47
|
+
var path_1 = require("path");
|
|
48
|
+
function buildFavicon(output) {
|
|
49
|
+
if (output === void 0) { output = (0, path_1.join)(process.cwd(), "favicon.ico"); }
|
|
50
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
51
|
+
var files, buffers, buf;
|
|
52
|
+
return __generator(this, function (_a) {
|
|
53
|
+
switch (_a.label) {
|
|
54
|
+
case 0: return [4 /*yield*/, (0, glob_promise_1.default)((0, path_1.join)(process.cwd(), "assets/favicon/favicon-*.png"))];
|
|
55
|
+
case 1:
|
|
56
|
+
files = _a.sent();
|
|
57
|
+
if (!files.length)
|
|
58
|
+
return [2 /*return*/];
|
|
59
|
+
return [4 /*yield*/, Promise.all(files.map(function (file) { return (0, promises_1.readFile)(file); }))];
|
|
60
|
+
case 2:
|
|
61
|
+
buffers = _a.sent();
|
|
62
|
+
return [4 /*yield*/, (0, to_icon_1.default)(buffers)];
|
|
63
|
+
case 3:
|
|
64
|
+
buf = _a.sent();
|
|
65
|
+
(0, promises_1.writeFile)(output, buf);
|
|
66
|
+
return [2 /*return*/];
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
exports.buildFavicon = buildFavicon;
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
exports.createServerlessWorker = void 0;
|
|
15
|
+
var worker_threads_1 = require("worker_threads");
|
|
16
|
+
var path_1 = require("path");
|
|
17
|
+
var Observable_1 = require("../utils/Observable");
|
|
18
|
+
function createServerlessWorker() {
|
|
19
|
+
var worker = new worker_threads_1.Worker((0, path_1.join)(__dirname, "workers/serverless-worker-dev-script.js"), {
|
|
20
|
+
workerData: {},
|
|
21
|
+
stderr: true,
|
|
22
|
+
stdin: false,
|
|
23
|
+
stdout: true,
|
|
24
|
+
env: __assign(__assign({}, process.env), { FORCE_COLOR: "1" }),
|
|
25
|
+
});
|
|
26
|
+
var subject = new Observable_1.Observable({
|
|
27
|
+
title: "Serverless",
|
|
28
|
+
status: "starting",
|
|
29
|
+
log: "",
|
|
30
|
+
});
|
|
31
|
+
var parseChunk = function (str) {
|
|
32
|
+
var escaped = JSON.stringify(str).replace(/(^"|"$)/g, "");
|
|
33
|
+
var status;
|
|
34
|
+
var duration = 0;
|
|
35
|
+
if (str.includes("\u001b[31merror\u001b[39m")) {
|
|
36
|
+
status = "error";
|
|
37
|
+
}
|
|
38
|
+
else if (str.includes("\u001b[35mevent\u001b[39m") && str.includes("successfully")) {
|
|
39
|
+
status = "success";
|
|
40
|
+
var secondsMatch = str.match(/[0-9.]+s/);
|
|
41
|
+
var msMatch = str.match(/[0-9.]+ ms/);
|
|
42
|
+
if (secondsMatch) {
|
|
43
|
+
duration = parseFloat(secondsMatch[0].replace("s", "")) * 1000;
|
|
44
|
+
}
|
|
45
|
+
if (msMatch) {
|
|
46
|
+
duration = parseFloat(msMatch[0].replace(" ms", ""));
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
else if (str.includes("\u001b[36mwait\u001b[39m")) {
|
|
50
|
+
status = "compiling";
|
|
51
|
+
}
|
|
52
|
+
return {
|
|
53
|
+
text: str,
|
|
54
|
+
status: status,
|
|
55
|
+
duration: duration,
|
|
56
|
+
};
|
|
57
|
+
};
|
|
58
|
+
var handleChunk = function (chunk) {
|
|
59
|
+
var result = parseChunk(String(chunk));
|
|
60
|
+
subject.update(function (state) { return (__assign(__assign({}, state), { log: (state.log || "") + result.text, status: result.status ? result.status : state.status, duration: result.status === "success" ? result.duration : state.duration })); });
|
|
61
|
+
};
|
|
62
|
+
worker.stderr.on("data", handleChunk);
|
|
63
|
+
worker.stdout.on("data", handleChunk);
|
|
64
|
+
worker.on("error", function (err) {
|
|
65
|
+
console.log(err);
|
|
66
|
+
subject.update(function (state) { return (__assign(__assign({}, state), { status: "error" })); });
|
|
67
|
+
});
|
|
68
|
+
worker.on("exit", function (code) {
|
|
69
|
+
subject.update(function (state) { return (__assign(__assign({}, state), { status: "error" })); });
|
|
70
|
+
});
|
|
71
|
+
worker.on("message", function (data) {
|
|
72
|
+
if (data.code === "preparing") {
|
|
73
|
+
subject.update(function (state) { return (__assign(__assign({}, state), { status: "preparing" })); });
|
|
74
|
+
}
|
|
75
|
+
else if (data.code === "packaging") {
|
|
76
|
+
subject.update(function (state) { return (__assign(__assign({}, state), { status: "packaging" })); });
|
|
77
|
+
}
|
|
78
|
+
else if (data.code === "compiling") {
|
|
79
|
+
subject.update(function (state) { return (__assign(__assign({}, state), { status: "compiling" })); });
|
|
80
|
+
}
|
|
81
|
+
else if (data.code === "finished") {
|
|
82
|
+
subject.update(function (state) { return (__assign(__assign({}, state), { status: "success", duration: data.duration })); });
|
|
83
|
+
}
|
|
84
|
+
else if (data.code === "error") {
|
|
85
|
+
subject.update(function (state) { return (__assign(__assign({}, state), { status: "error" })); });
|
|
86
|
+
}
|
|
87
|
+
else if (data.code === "url") {
|
|
88
|
+
subject.update(function (state) { return (__assign(__assign({}, state), { url: data.url })); });
|
|
89
|
+
}
|
|
90
|
+
});
|
|
91
|
+
// worker.on("exit", () => {
|
|
92
|
+
// subject.update((state) => ({
|
|
93
|
+
// ...state,
|
|
94
|
+
// status: "success",
|
|
95
|
+
// }))
|
|
96
|
+
// })
|
|
97
|
+
return subject;
|
|
98
|
+
}
|
|
99
|
+
exports.createServerlessWorker = createServerlessWorker;
|
package/build/file-tree.js
CHANGED
|
@@ -67,8 +67,6 @@ var webpack_virtual_modules_1 = __importDefault(require("webpack-virtual-modules
|
|
|
67
67
|
var friendly_errors_webpack_plugin_1 = __importDefault(require("@soda/friendly-errors-webpack-plugin"));
|
|
68
68
|
// @ts-ignore
|
|
69
69
|
var webpack_plugin_1 = __importDefault(require("@loadable/webpack-plugin"));
|
|
70
|
-
var file_tree_1 = require("./file-tree");
|
|
71
|
-
var change_case_1 = require("change-case");
|
|
72
70
|
// @ts-ignore
|
|
73
71
|
var webpack_bundle_analyzer_1 = require("webpack-bundle-analyzer");
|
|
74
72
|
// @ts-ignore
|
|
@@ -76,11 +74,14 @@ var mini_css_extract_plugin_1 = __importDefault(require("mini-css-extract-plugin
|
|
|
76
74
|
var autoprefixer_1 = __importDefault(require("autoprefixer"));
|
|
77
75
|
// Custom Babel plugins
|
|
78
76
|
var plugin_name_defined_components_1 = __importDefault(require("./babel/plugin-name-defined-components"));
|
|
77
|
+
var manifest_blocks_1 = require("./manifests/manifest-blocks");
|
|
78
|
+
var manifest_fields_1 = require("./manifests/manifest-fields");
|
|
79
|
+
var manifest_views_1 = require("./manifests/manifest-views");
|
|
79
80
|
function getWebpackConfig(opts) {
|
|
80
81
|
return __awaiter(this, void 0, void 0, function () {
|
|
81
|
-
var compiling, ALIAS, ENTRY, PLUGINS, RULES, DEFINES, VIRTUAL_MODULES, EXTERNALS, virtualModules, isServerless, isBrowser, isSSR, isDev, entryDir, distSuffix, outputFolder, loadableManifestFile, writeVirtualModule,
|
|
82
|
-
return __generator(this, function (
|
|
83
|
-
switch (
|
|
82
|
+
var compiling, ALIAS, ENTRY, PLUGINS, RULES, DEFINES, VIRTUAL_MODULES, EXTERNALS, virtualModules, isServerless, isBrowser, isSSR, isDev, entryDir, distSuffix, outputFolder, loadableManifestFile, writeVirtualModule, manifestLoaders, buildID;
|
|
83
|
+
return __generator(this, function (_a) {
|
|
84
|
+
switch (_a.label) {
|
|
84
85
|
case 0:
|
|
85
86
|
compiling = false;
|
|
86
87
|
ALIAS = {};
|
|
@@ -243,146 +244,60 @@ function getWebpackConfig(opts) {
|
|
|
243
244
|
VIRTUAL_MODULES[name] = contents;
|
|
244
245
|
}
|
|
245
246
|
};
|
|
247
|
+
manifestLoaders = [];
|
|
248
|
+
// Views
|
|
246
249
|
ALIAS["@manifest/views"] = path_1.default.resolve(opts.baseDirectory, "_view_manifest.js");
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
: "", "\n\n export { App }\n\n export default {\n ").concat(files
|
|
264
|
-
.map(function (_a) {
|
|
265
|
-
var relative = _a.relative, componentName = _a.componentName, module = _a.module;
|
|
266
|
-
if (useLoadableViews) {
|
|
267
|
-
// In serverless mode, export @loadable components. Script tags will be
|
|
268
|
-
// auto-included in output HTML
|
|
269
|
-
return "\"".concat(relative, "\": loadable(() => import(").concat(module, "))");
|
|
270
|
-
}
|
|
271
|
-
else {
|
|
272
|
-
// On non-serverless, the templates are bundled straight into the main app.
|
|
273
|
-
return "\"".concat(relative, "\": ").concat(componentName);
|
|
274
|
-
}
|
|
275
|
-
})
|
|
276
|
-
.join(",\n"), "\n }\n "));
|
|
277
|
-
};
|
|
278
|
-
templateLookupPattern = path_1.default.resolve(opts.baseDirectory, "views/**/*.tsx");
|
|
279
|
-
if (!opts.isAdmin) return [3 /*break*/, 1];
|
|
280
|
-
writeVirtualModule(ALIAS["@manifest/views"], "\n export const App = null\n export default {}\n ");
|
|
281
|
-
return [3 /*break*/, 5];
|
|
282
|
-
case 1:
|
|
283
|
-
if (!isDev) return [3 /*break*/, 3];
|
|
284
|
-
return [4 /*yield*/, (0, file_tree_1.watchFileTree)(templateLookupPattern, updateTemplateRouter)];
|
|
285
|
-
case 2:
|
|
286
|
-
_d.sent();
|
|
287
|
-
return [3 /*break*/, 5];
|
|
288
|
-
case 3:
|
|
289
|
-
_a = updateTemplateRouter;
|
|
290
|
-
return [4 /*yield*/, (0, file_tree_1.getFileTree)(templateLookupPattern)];
|
|
291
|
-
case 4:
|
|
292
|
-
_a.apply(void 0, [_d.sent()]);
|
|
293
|
-
_d.label = 5;
|
|
294
|
-
case 5:
|
|
250
|
+
if (opts.isAdmin) {
|
|
251
|
+
writeVirtualModule(ALIAS["@manifest/views"], "export default {}");
|
|
252
|
+
}
|
|
253
|
+
else {
|
|
254
|
+
manifestLoaders.push((0, manifest_views_1.createViewManifestGenerator)({
|
|
255
|
+
baseDirectory: opts.baseDirectory,
|
|
256
|
+
isAdmin: false,
|
|
257
|
+
isDev: isDev,
|
|
258
|
+
isServerless: isServerless,
|
|
259
|
+
watch: isDev,
|
|
260
|
+
onGenerate: function (manifest) {
|
|
261
|
+
writeVirtualModule(ALIAS["@manifest/views"], manifest);
|
|
262
|
+
},
|
|
263
|
+
}));
|
|
264
|
+
}
|
|
265
|
+
// Field manifest
|
|
295
266
|
ALIAS["@manifest/fields"] = path_1.default.resolve(opts.baseDirectory, "_fields_manifest.js");
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
return "\"".concat(name, "\": ").concat(componentName);
|
|
313
|
-
})
|
|
314
|
-
.join(",\n"), "\n }\n "));
|
|
315
|
-
};
|
|
316
|
-
fieldTypeLookupPattern = path_1.default.resolve(opts.baseDirectory, "backend/fields/**.tsx");
|
|
317
|
-
if (!!opts.isAdmin) return [3 /*break*/, 6];
|
|
318
|
-
writeVirtualModule(ALIAS["@manifest/fields"], "\n export default {}\n ");
|
|
319
|
-
return [3 /*break*/, 10];
|
|
320
|
-
case 6:
|
|
321
|
-
if (!isDev) return [3 /*break*/, 8];
|
|
322
|
-
return [4 /*yield*/, (0, file_tree_1.watchFileTree)(fieldTypeLookupPattern, updateFieldManifest)];
|
|
323
|
-
case 7:
|
|
324
|
-
_d.sent();
|
|
325
|
-
return [3 /*break*/, 10];
|
|
326
|
-
case 8:
|
|
327
|
-
_b = updateFieldManifest;
|
|
328
|
-
return [4 /*yield*/, (0, file_tree_1.getFileTree)(fieldTypeLookupPattern)];
|
|
329
|
-
case 9:
|
|
330
|
-
_b.apply(void 0, [_d.sent()]);
|
|
331
|
-
_d.label = 10;
|
|
332
|
-
case 10:
|
|
267
|
+
if (opts.isAdmin) {
|
|
268
|
+
manifestLoaders.push((0, manifest_fields_1.createFieldManifestGenerator)({
|
|
269
|
+
baseDirectory: opts.baseDirectory,
|
|
270
|
+
isAdmin: true,
|
|
271
|
+
isDev: isDev,
|
|
272
|
+
isServerless: isServerless,
|
|
273
|
+
watch: isDev,
|
|
274
|
+
onGenerate: function (manifest) {
|
|
275
|
+
writeVirtualModule(ALIAS["@manifest/fields"], manifest);
|
|
276
|
+
},
|
|
277
|
+
}));
|
|
278
|
+
}
|
|
279
|
+
else {
|
|
280
|
+
writeVirtualModule(ALIAS["@manifest/fields"], "\n export default {}\n ");
|
|
281
|
+
}
|
|
282
|
+
// Block manifest
|
|
333
283
|
ALIAS["@manifest/blocks"] = path_1.default.resolve(opts.baseDirectory, "_blocks_manifest.js");
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
return "\"".concat(blockName, "\": loadable(() => import(").concat(module, "))");
|
|
352
|
-
})
|
|
353
|
-
.join(",\n"), "\n }\n "));
|
|
354
|
-
}
|
|
355
|
-
else {
|
|
356
|
-
writeVirtualModule(ALIAS["@manifest/blocks"], "\n import coreBlocks from './blocks/_core.tsx'\n\n ".concat(files
|
|
357
|
-
.map(function (_a) {
|
|
358
|
-
var relative = _a.relative, componentName = _a.componentName, module = _a.module;
|
|
359
|
-
var parts = relative.replace(/\.tsx$/, "").split("/");
|
|
360
|
-
var blockName = "acf/" + parts.slice(1).join("-");
|
|
361
|
-
return "import ".concat(componentName, " from ").concat(module);
|
|
362
|
-
})
|
|
363
|
-
.join("\n"), "\n\n export default {\n ...coreBlocks,\n ").concat(files
|
|
364
|
-
.map(function (_a) {
|
|
365
|
-
var relative = _a.relative, componentName = _a.componentName, module = _a.module;
|
|
366
|
-
var parts = relative.replace(/\.tsx$/, "").split("/");
|
|
367
|
-
var blockName = "acf/" + parts.slice(1).join("-");
|
|
368
|
-
return "\"".concat(blockName, "\": ").concat(componentName);
|
|
369
|
-
})
|
|
370
|
-
.join(",\n"), "\n }\n "));
|
|
371
|
-
}
|
|
372
|
-
};
|
|
373
|
-
blockLookupManifest = path_1.default.resolve(opts.baseDirectory, "blocks/**/*.tsx");
|
|
374
|
-
if (!isDev) return [3 /*break*/, 12];
|
|
375
|
-
return [4 /*yield*/, (0, file_tree_1.watchFileTree)(blockLookupManifest, updateBlocksManifest)];
|
|
376
|
-
case 11:
|
|
377
|
-
_d.sent();
|
|
378
|
-
return [3 /*break*/, 14];
|
|
379
|
-
case 12:
|
|
380
|
-
_c = updateBlocksManifest;
|
|
381
|
-
return [4 /*yield*/, (0, file_tree_1.getFileTree)(blockLookupManifest)];
|
|
382
|
-
case 13:
|
|
383
|
-
_c.apply(void 0, [_d.sent()]);
|
|
384
|
-
_d.label = 14;
|
|
385
|
-
case 14:
|
|
284
|
+
manifestLoaders.push((0, manifest_blocks_1.createBlockManifestGenerator)({
|
|
285
|
+
baseDirectory: opts.baseDirectory,
|
|
286
|
+
isAdmin: opts.isAdmin,
|
|
287
|
+
isDev: isDev,
|
|
288
|
+
isServerless: isServerless,
|
|
289
|
+
watch: isDev,
|
|
290
|
+
onGenerate: function (manifest) {
|
|
291
|
+
writeVirtualModule(ALIAS["@manifest/blocks"], manifest);
|
|
292
|
+
},
|
|
293
|
+
}));
|
|
294
|
+
// Wait for all manifests to resolve
|
|
295
|
+
return [4 /*yield*/, Promise.all(manifestLoaders)
|
|
296
|
+
// External Gutenberg
|
|
297
|
+
];
|
|
298
|
+
case 1:
|
|
299
|
+
// Wait for all manifests to resolve
|
|
300
|
+
_a.sent();
|
|
386
301
|
// External Gutenberg
|
|
387
302
|
EXTERNALS["@wordpress/components"] = ["window", "wp"];
|
|
388
303
|
EXTERNALS["@wordpress/element"] = ["window", "wp"];
|
|
@@ -404,6 +319,7 @@ function getWebpackConfig(opts) {
|
|
|
404
319
|
}
|
|
405
320
|
// Define some values
|
|
406
321
|
DEFINES["process.browser"] = JSON.stringify(isBrowser);
|
|
322
|
+
DEFINES["process.serverless"] = "false";
|
|
407
323
|
DEFINES["process.ssr"] = JSON.stringify(isServerless && !isBrowser);
|
|
408
324
|
DEFINES["process.LOADABLE_STATS_FILE"] = JSON.stringify(loadableManifestFile);
|
|
409
325
|
DEFINES["process.dev"] = isDev ? "true" : "false";
|
|
@@ -431,7 +347,6 @@ function getWebpackConfig(opts) {
|
|
|
431
347
|
output: {
|
|
432
348
|
filename: "[name].".concat(opts.isAdmin ? "admin" : "frontend", ".js?v=").concat(buildID),
|
|
433
349
|
chunkFilename: "[name].".concat(opts.isAdmin ? "admin" : "frontend", ".js?v=").concat(buildID),
|
|
434
|
-
// publicPath: isDev ? `//127.0.0.1:${opts.hotPort}/` : `/wp-content/themes/${opts.themeName}/dist/${distSuffix}/`,
|
|
435
350
|
publicPath: "/wp-content/themes/".concat(opts.themeName, "/dist/").concat(distSuffix, "/"),
|
|
436
351
|
path: outputFolder,
|
|
437
352
|
globalObject: isSSR ? "this" : "self",
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
declare type Options = {
|
|
2
|
+
baseDirectory: string;
|
|
3
|
+
isAdmin: boolean;
|
|
4
|
+
isDev: boolean;
|
|
5
|
+
isServerless: boolean;
|
|
6
|
+
onGenerate: (value: string) => void;
|
|
7
|
+
watch: boolean;
|
|
8
|
+
};
|
|
9
|
+
export declare function createBlockManifestGenerator(opts: Options): Promise<{
|
|
10
|
+
close(): void;
|
|
11
|
+
}>;
|
|
12
|
+
export {};
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createBlockManifestGenerator = void 0;
|
|
7
|
+
var manifest_1 = require("./manifest");
|
|
8
|
+
var path_1 = __importDefault(require("path"));
|
|
9
|
+
var change_case_1 = require("change-case");
|
|
10
|
+
var fs_1 = require("fs");
|
|
11
|
+
var JSX = /\.(jsx|tsx|ts|js)$/i;
|
|
12
|
+
function createBlockManifestGenerator(opts) {
|
|
13
|
+
return (0, manifest_1.createManifestGenerator)({
|
|
14
|
+
glob: path_1.default.join(opts.baseDirectory, "/blocks/**/*.tsx"),
|
|
15
|
+
onGenerate: opts.onGenerate,
|
|
16
|
+
watch: opts.watch,
|
|
17
|
+
generate: function (fileNames) {
|
|
18
|
+
var files = fileNames
|
|
19
|
+
.filter(function (file) { return !file.includes("/_core"); })
|
|
20
|
+
.map(function (file) {
|
|
21
|
+
var relative = path_1.default.relative(opts.baseDirectory, file).replace(JSX, "");
|
|
22
|
+
var name = path_1.default.basename(file).replace(JSX, "");
|
|
23
|
+
var module = JSON.stringify("./" + relative).replace(JSX, "");
|
|
24
|
+
var componentName = (0, change_case_1.pascalCase)(name);
|
|
25
|
+
// Test if the block has Dynamic: true in the header
|
|
26
|
+
var dynamic = !opts.isAdmin &&
|
|
27
|
+
!!(0, fs_1.readFileSync)(file)
|
|
28
|
+
.toString()
|
|
29
|
+
.match(/\*[\s]*dynamic: true/i);
|
|
30
|
+
return { relative: relative, name: name, module: module, componentName: componentName, dynamic: dynamic };
|
|
31
|
+
});
|
|
32
|
+
return "\n import coreBlocks from './blocks/_core'\n import { dynamic } from 'eddev/dynamic';\n \n ".concat(files
|
|
33
|
+
.map(function (_a) {
|
|
34
|
+
var relative = _a.relative, componentName = _a.componentName, module = _a.module, dynamic = _a.dynamic;
|
|
35
|
+
var parts = relative.replace(/\.tsx$/, "").split("/");
|
|
36
|
+
var blockName = "acf/" + parts.slice(1).join("-");
|
|
37
|
+
if (dynamic) {
|
|
38
|
+
return null;
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
return "import ".concat(componentName, " from ").concat(module);
|
|
42
|
+
}
|
|
43
|
+
})
|
|
44
|
+
.filter(Boolean)
|
|
45
|
+
.join("\n"), "\n \n export default {\n ...coreBlocks,\n ").concat(files
|
|
46
|
+
.map(function (_a) {
|
|
47
|
+
var relative = _a.relative, componentName = _a.componentName, module = _a.module, dynamic = _a.dynamic;
|
|
48
|
+
var parts = relative.replace(/\.tsx$/, "").split("/");
|
|
49
|
+
var blockName = "acf/" + parts.slice(1).join("-");
|
|
50
|
+
if (dynamic) {
|
|
51
|
+
return "\"".concat(blockName, "\": dynamic(() => import(").concat(module, "))");
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
return "\"".concat(blockName, "\": ").concat(componentName);
|
|
55
|
+
}
|
|
56
|
+
})
|
|
57
|
+
.join(",\n"), "\n }\n ");
|
|
58
|
+
},
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
exports.createBlockManifestGenerator = createBlockManifestGenerator;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
declare type Options = {
|
|
2
|
+
baseDirectory: string;
|
|
3
|
+
isAdmin: boolean;
|
|
4
|
+
isDev: boolean;
|
|
5
|
+
isServerless: boolean;
|
|
6
|
+
onGenerate: (value: string) => void;
|
|
7
|
+
watch: boolean;
|
|
8
|
+
};
|
|
9
|
+
export declare function createFieldManifestGenerator(opts: Options): Promise<{
|
|
10
|
+
close(): void;
|
|
11
|
+
}>;
|
|
12
|
+
export {};
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createFieldManifestGenerator = void 0;
|
|
7
|
+
var manifest_1 = require("./manifest");
|
|
8
|
+
var path_1 = __importDefault(require("path"));
|
|
9
|
+
var change_case_1 = require("change-case");
|
|
10
|
+
function createFieldManifestGenerator(opts) {
|
|
11
|
+
return (0, manifest_1.createManifestGenerator)({
|
|
12
|
+
glob: path_1.default.join(opts.baseDirectory, "/backend/fields/**.tsx"),
|
|
13
|
+
onGenerate: opts.onGenerate,
|
|
14
|
+
watch: opts.watch,
|
|
15
|
+
generate: function (fileNames) {
|
|
16
|
+
if (opts.isAdmin) {
|
|
17
|
+
var files = fileNames
|
|
18
|
+
.filter(function (file) { return !file.includes("/_app"); })
|
|
19
|
+
.map(function (file) {
|
|
20
|
+
var relative = path_1.default.relative(opts.baseDirectory, file);
|
|
21
|
+
var name = path_1.default.basename(file).replace(/\.(jsx|tsx|ts|js)$/i, "");
|
|
22
|
+
var module = JSON.stringify("./" + relative);
|
|
23
|
+
var componentName = "FieldType" + (0, change_case_1.pascalCase)(name);
|
|
24
|
+
return { relative: relative, name: name, module: module, componentName: componentName };
|
|
25
|
+
});
|
|
26
|
+
return "\n ".concat(files.map(function (_a) {
|
|
27
|
+
var componentName = _a.componentName, module = _a.module;
|
|
28
|
+
return "import ".concat(componentName, " from ").concat(module);
|
|
29
|
+
}).join("\n"), "\n\n export default {\n ").concat(files
|
|
30
|
+
.map(function (_a) {
|
|
31
|
+
var relative = _a.relative, componentName = _a.componentName, module = _a.module, name = _a.name;
|
|
32
|
+
return "\"".concat(name, "\": ").concat(componentName);
|
|
33
|
+
})
|
|
34
|
+
.join(",\n"), "\n }\n ");
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
return "export default {}";
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
exports.createFieldManifestGenerator = createFieldManifestGenerator;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
declare type Options = {
|
|
2
|
+
baseDirectory: string;
|
|
3
|
+
isAdmin: boolean;
|
|
4
|
+
isDev: boolean;
|
|
5
|
+
isServerless: boolean;
|
|
6
|
+
onGenerate: (value: string) => void;
|
|
7
|
+
watch: boolean;
|
|
8
|
+
};
|
|
9
|
+
export declare function createViewManifestGenerator(opts: Options): Promise<{
|
|
10
|
+
close(): void;
|
|
11
|
+
}>;
|
|
12
|
+
export {};
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createViewManifestGenerator = void 0;
|
|
7
|
+
var manifest_1 = require("./manifest");
|
|
8
|
+
var path_1 = __importDefault(require("path"));
|
|
9
|
+
var change_case_1 = require("change-case");
|
|
10
|
+
var JSX = /\.(jsx|tsx|ts|js)$/i;
|
|
11
|
+
function createViewManifestGenerator(opts) {
|
|
12
|
+
return (0, manifest_1.createManifestGenerator)({
|
|
13
|
+
glob: path_1.default.join(opts.baseDirectory, "/views/**/*.tsx"),
|
|
14
|
+
onGenerate: opts.onGenerate,
|
|
15
|
+
watch: opts.watch,
|
|
16
|
+
generate: function (fileNames) {
|
|
17
|
+
var files = fileNames
|
|
18
|
+
.filter(function (file) { return !file.includes("/_app"); })
|
|
19
|
+
.map(function (file) {
|
|
20
|
+
var relative = path_1.default.relative(opts.baseDirectory, file).replace(JSX, "");
|
|
21
|
+
var name = path_1.default.basename(file).replace(JSX, "");
|
|
22
|
+
var module = JSON.stringify("./" + relative);
|
|
23
|
+
var componentName = "View" + (0, change_case_1.pascalCase)(name);
|
|
24
|
+
return { relative: relative, name: name, module: module, componentName: componentName };
|
|
25
|
+
});
|
|
26
|
+
var useDynamicViews = opts.isServerless;
|
|
27
|
+
return "\n ".concat(useDynamicViews && "import { dynamic } from 'eddev/dynamic';", "\n import App from ").concat(JSON.stringify("./views/_app"), "\n\n ").concat(!useDynamicViews
|
|
28
|
+
? files.map(function (_a) {
|
|
29
|
+
var componentName = _a.componentName, module = _a.module;
|
|
30
|
+
return "import ".concat(componentName, " from ").concat(module);
|
|
31
|
+
}).join("\n")
|
|
32
|
+
: "", "\n\n export { App }\n\n export default {\n ").concat(files
|
|
33
|
+
.map(function (_a) {
|
|
34
|
+
var relative = _a.relative, componentName = _a.componentName, module = _a.module;
|
|
35
|
+
if (useDynamicViews) {
|
|
36
|
+
// In serverless mode, export @loadable components. Script tags will be
|
|
37
|
+
// auto-included in output HTML
|
|
38
|
+
return "\"".concat(relative, "\": dynamic(() => import(").concat(module, "))");
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
// On non-serverless, the templates are bundled straight into the main app.
|
|
42
|
+
return "\"".concat(relative, "\": ").concat(componentName);
|
|
43
|
+
}
|
|
44
|
+
})
|
|
45
|
+
.join(",\n"), "\n }\n ");
|
|
46
|
+
},
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
exports.createViewManifestGenerator = createViewManifestGenerator;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
declare type Options = {
|
|
2
|
+
glob: string;
|
|
3
|
+
watch: boolean;
|
|
4
|
+
generate: (files: string[]) => Promise<string> | string;
|
|
5
|
+
onGenerate: (value: string) => void;
|
|
6
|
+
};
|
|
7
|
+
declare type ManifestGenerator = {
|
|
8
|
+
close(): void;
|
|
9
|
+
};
|
|
10
|
+
export declare function createManifestGenerator(opts: Options): Promise<ManifestGenerator>;
|
|
11
|
+
export {};
|