@monkeyplus/flow 3.2.6 → 3.4.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/dist/decorators.d.ts +5 -0
- package/dist/decorators.js +105 -0
- package/dist/decorators.js.map +1 -0
- package/dist/generator/index.d.ts +8 -0
- package/dist/generator/index.js +242 -0
- package/dist/generator/index.js.map +1 -0
- package/dist/{helper.js → helpers/handler.js} +11 -4
- package/dist/helpers/handler.js.map +1 -0
- package/dist/index.d.ts +17 -4
- package/dist/index.js +75 -276
- package/dist/index.js.map +1 -1
- package/dist/lifeCircle.d.ts +5 -0
- package/dist/lifeCircle.js +81 -0
- package/dist/lifeCircle.js.map +1 -0
- package/dist/pages.d.ts +2 -2
- package/dist/pages.js +4 -5
- package/dist/pages.js.map +1 -1
- package/dist/runMethods.d.ts +9 -0
- package/dist/runMethods.js +60 -0
- package/dist/runMethods.js.map +1 -0
- package/dist/serverInfo.d.ts +7 -0
- package/dist/serverInfo.js +36 -0
- package/dist/serverInfo.js.map +1 -0
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.js +5 -2
- package/dist/utils/index.js.map +1 -1
- package/package.json +3 -3
- package/types/flow.d.ts +41 -16
- package/types/index.d.ts +4 -2
- package/types/interfaces.d.ts +5 -0
- package/dist/generate.d.ts +0 -10
- package/dist/generate.js +0 -233
- package/dist/generate.js.map +0 -1
- package/dist/helper.js.map +0 -1
- /package/dist/{helper.d.ts → helpers/handler.d.ts} +0 -0
package/dist/index.js
CHANGED
|
@@ -3,18 +3,17 @@ 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
|
-
exports.
|
|
6
|
+
exports.definePage = exports.plugin = void 0;
|
|
7
7
|
const config_1 = require("./config");
|
|
8
|
-
const flow_core_1 = require("@monkeyplus/flow-core");
|
|
9
|
-
const os_1 = __importDefault(require("os"));
|
|
10
|
-
const chalk_1 = __importDefault(require("chalk"));
|
|
11
|
-
// import { PageInfo } from '@monkeyplus/flow-core';
|
|
12
|
-
const utils_1 = require("./utils");
|
|
13
|
-
const helper_1 = require("./helper");
|
|
14
8
|
const path_1 = __importDefault(require("path"));
|
|
15
|
-
const
|
|
9
|
+
const lifeCircle_1 = __importDefault(require("./lifeCircle"));
|
|
10
|
+
const serverInfo_1 = __importDefault(require("./serverInfo"));
|
|
11
|
+
const decorators_1 = __importDefault(require("./decorators"));
|
|
12
|
+
const utils_1 = require("./utils");
|
|
13
|
+
const generator_1 = __importDefault(require("./generator"));
|
|
16
14
|
const pages_1 = require("./pages");
|
|
17
15
|
Object.defineProperty(exports, "definePage", { enumerable: true, get: function () { return pages_1.definePage; } });
|
|
16
|
+
const runMethods_1 = __importDefault(require("./runMethods"));
|
|
18
17
|
// const logger = require('consola').withScope('@monkeyplus/flow');
|
|
19
18
|
// const isProduction = process.env.NODE_ENV === 'production';
|
|
20
19
|
exports.plugin = {
|
|
@@ -24,308 +23,108 @@ exports.plugin = {
|
|
|
24
23
|
const config = utils_1.getConfigs(server, _options);
|
|
25
24
|
server.expose('configs', config);
|
|
26
25
|
/**
|
|
27
|
-
*
|
|
26
|
+
* Definite State
|
|
28
27
|
*/
|
|
29
28
|
const state = {
|
|
30
|
-
redirects: {},
|
|
31
|
-
pages: {},
|
|
29
|
+
pages: { statics: {}, redirects: {}, dynamics: {}, all: {} },
|
|
32
30
|
truncates: {},
|
|
33
|
-
urls: {},
|
|
34
|
-
dynamicPages: {},
|
|
35
31
|
extensions: {},
|
|
36
32
|
generate: {
|
|
37
|
-
folders: {}
|
|
33
|
+
folders: {},
|
|
34
|
+
postGenerate: {},
|
|
35
|
+
beforePackage: {}
|
|
38
36
|
},
|
|
39
|
-
prePackage: {},
|
|
40
37
|
engines: {},
|
|
38
|
+
routes: {},
|
|
41
39
|
//@ts-ignore
|
|
42
40
|
plugins: {}
|
|
43
41
|
};
|
|
44
|
-
// const stateExtension: any = {};
|
|
45
|
-
// const stateGenerate = {
|
|
46
|
-
// folders: {}
|
|
47
|
-
// };
|
|
48
|
-
// const dynamicContent: Flow.DynamicContent = {};
|
|
49
42
|
server.app.flow = state;
|
|
50
|
-
// server.app.generate = stateGenerate;
|
|
51
43
|
/**
|
|
52
|
-
*
|
|
44
|
+
* Expose
|
|
53
45
|
*/
|
|
46
|
+
const { serverInfo } = serverInfo_1.default.register(server);
|
|
47
|
+
const serverDecorate = {
|
|
48
|
+
serverInfo
|
|
49
|
+
};
|
|
54
50
|
const helpers = {
|
|
51
|
+
getPath: (...paths) => path_1.default.join(config.relativeTo, ...paths),
|
|
55
52
|
addRedirect: (key, urlPath) => {
|
|
56
|
-
state.redirects[key] = urlPath;
|
|
53
|
+
state.pages.redirects[key] = urlPath;
|
|
57
54
|
},
|
|
58
|
-
|
|
59
|
-
if (
|
|
55
|
+
addStaticPage: (key, url) => {
|
|
56
|
+
if (utils_1.isDinamyc(url.url)) {
|
|
60
57
|
return void 0;
|
|
61
58
|
}
|
|
62
|
-
if (state.
|
|
63
|
-
config_1.logger.warn('The namePage %s already exist', state.
|
|
59
|
+
if (state.pages.statics[key]) {
|
|
60
|
+
config_1.logger.warn('The namePage %s already exist', state.pages.statics[key]);
|
|
64
61
|
}
|
|
65
62
|
else {
|
|
66
|
-
state.
|
|
63
|
+
state.pages.statics[key] = url;
|
|
67
64
|
}
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
*/
|
|
73
|
-
server.ext('onRequest', (req, h) => {
|
|
74
|
-
const stateRequest = {
|
|
75
|
-
global: {},
|
|
76
|
-
local: {},
|
|
77
|
-
context: {},
|
|
78
|
-
//@ts-ignore
|
|
79
|
-
utils: {},
|
|
80
|
-
//@ts-ignore
|
|
81
|
-
extensions: {}
|
|
82
|
-
};
|
|
83
|
-
/**
|
|
84
|
-
* Initize states route
|
|
85
|
-
*/
|
|
86
|
-
req.plugins.flow = stateRequest;
|
|
87
|
-
const pathRedirect = state.redirects[req.path];
|
|
88
|
-
if (state.truncates[req.path]) {
|
|
89
|
-
return h.redirect('/').takeover();
|
|
90
|
-
}
|
|
91
|
-
if (pathRedirect) {
|
|
92
|
-
return h.redirect(pathRedirect).takeover();
|
|
93
|
-
}
|
|
94
|
-
return h.continue;
|
|
95
|
-
});
|
|
96
|
-
// const addContext = (_context: any) => {
|
|
97
|
-
// const { context } = statePlugins;
|
|
98
|
-
// Object.assign(context, _context);
|
|
99
|
-
// };
|
|
100
|
-
const getUrl = (_locale, _name) => {
|
|
101
|
-
// console.log('locale: %s, name:%s', _locale, _name);
|
|
102
|
-
try {
|
|
103
|
-
const pageName = path_1.default.posix.join(_locale, _name);
|
|
104
|
-
const page = state.urls[pageName];
|
|
105
|
-
if (page) {
|
|
106
|
-
return page.url;
|
|
65
|
+
},
|
|
66
|
+
addDynamicPages: (key, method) => {
|
|
67
|
+
if (state.pages.dynamics[key]) {
|
|
68
|
+
config_1.logger.warn('The dynamdcPages %s already exist', key);
|
|
107
69
|
}
|
|
108
70
|
else {
|
|
109
|
-
|
|
110
|
-
return '/404';
|
|
71
|
+
state.pages.dynamics[key] = method;
|
|
111
72
|
}
|
|
112
73
|
}
|
|
113
|
-
catch (error) {
|
|
114
|
-
config_1.logger.error(error);
|
|
115
|
-
return '/';
|
|
116
|
-
}
|
|
117
74
|
};
|
|
118
|
-
server.
|
|
119
|
-
server.method('
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
// route.settings.
|
|
123
|
-
// route.settings.
|
|
124
|
-
// route.settings.
|
|
125
|
-
const { plugins, app } = route.settings;
|
|
126
|
-
Object.assign(plugins, { generate: '.html' });
|
|
127
|
-
const flow = (_a = route.settings.app) === null || _a === void 0 ? void 0 : _a.flow;
|
|
128
|
-
const runCommons = (pageInfo) => {
|
|
129
|
-
helpers.addUrl(pageInfo.localeName, {
|
|
130
|
-
url: route.path,
|
|
131
|
-
locale: pageInfo.locale,
|
|
132
|
-
localeName: pageInfo.localeName,
|
|
133
|
-
name: pageInfo.name
|
|
134
|
-
});
|
|
135
|
-
if (pageInfo.redirect) {
|
|
136
|
-
helpers.addRedirect(pageInfo.redirect, route.path);
|
|
137
|
-
}
|
|
75
|
+
server.expose('helpers', helpers);
|
|
76
|
+
server.method('flow.pages', async () => {
|
|
77
|
+
const pages = {
|
|
78
|
+
...state.pages.statics
|
|
138
79
|
};
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
})().pages([
|
|
155
|
-
{ locale: options.locale || config.locale, url: route.path }
|
|
156
|
-
]);
|
|
157
|
-
const pageInfo = routes[0];
|
|
158
|
-
runCommons(pageInfo);
|
|
159
|
-
Object.assign(app, { flow: pageInfo, content: options.content });
|
|
160
|
-
}
|
|
161
|
-
/**
|
|
162
|
-
*
|
|
163
|
-
*/
|
|
164
|
-
// if (!route.settings.plugins?.flow?.proxy) {
|
|
165
|
-
// state.truncates[route.path] = route.path;
|
|
166
|
-
// }
|
|
167
|
-
const extensions = ((_b = plugins === null || plugins === void 0 ? void 0 : plugins.flow) === null || _b === void 0 ? void 0 : _b.extensions) || {};
|
|
168
|
-
for (const extension in extensions) {
|
|
169
|
-
// @ts-ignore
|
|
170
|
-
const optionExtension = (_c = plugins === null || plugins === void 0 ? void 0 : plugins.flow) === null || _c === void 0 ? void 0 : _c.extensions[extension];
|
|
171
|
-
const routeMethod = (_d = state.extensions[extension]) === null || _d === void 0 ? void 0 : _d.routeMethod;
|
|
172
|
-
if (routeMethod) {
|
|
173
|
-
routeMethod({ pageInfo: app.flow, route }, optionExtension);
|
|
80
|
+
for (const key in state.pages.dynamics) {
|
|
81
|
+
if (Object.prototype.hasOwnProperty.call(state.pages.dynamics, key)) {
|
|
82
|
+
const element = state.pages.dynamics[key];
|
|
83
|
+
const dynamicPages = await element();
|
|
84
|
+
for (const keyPage in dynamicPages) {
|
|
85
|
+
if (Object.prototype.hasOwnProperty.call(dynamicPages, keyPage)) {
|
|
86
|
+
const page = dynamicPages[keyPage];
|
|
87
|
+
if (!pages[keyPage]) {
|
|
88
|
+
pages[keyPage] = page;
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
config_1.logger.warn('Duplicate page %s', keyPage);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}
|
|
174
95
|
}
|
|
175
|
-
// console.log(extension, optionExtension);
|
|
176
96
|
}
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
97
|
+
state.pages.all = pages;
|
|
98
|
+
return pages;
|
|
99
|
+
}, {
|
|
100
|
+
cache: { expiresIn: 3000, generateTimeout: 200 }
|
|
101
|
+
});
|
|
102
|
+
server.expose('pages', () => {
|
|
103
|
+
return state.pages.all;
|
|
104
|
+
});
|
|
105
|
+
/**
|
|
106
|
+
* Server decorate
|
|
107
|
+
*/
|
|
108
|
+
server.decorate('server', 'flow', serverDecorate);
|
|
109
|
+
decorators_1.default.register(server);
|
|
110
|
+
/**
|
|
111
|
+
* Router Lifecircle
|
|
112
|
+
*/
|
|
113
|
+
lifeCircle_1.default.register(server);
|
|
190
114
|
/**
|
|
191
115
|
*
|
|
192
116
|
*/
|
|
193
|
-
const
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
}
|
|
203
|
-
};
|
|
204
|
-
const registerRoute = (route) => {
|
|
205
|
-
const _routes = server.table();
|
|
206
|
-
const _route = _routes.find((v) => v.path === route.path);
|
|
207
|
-
if (_route) {
|
|
208
|
-
config_1.logger.warn(`Duplicate route, the route ${route.path} already exists`);
|
|
209
|
-
}
|
|
210
|
-
else {
|
|
211
|
-
server.route(route);
|
|
212
|
-
}
|
|
213
|
-
};
|
|
214
|
-
const addPage = (_page) => {
|
|
215
|
-
let _pages;
|
|
216
|
-
if (typeof _page === 'function') {
|
|
217
|
-
_pages = _page(config);
|
|
218
|
-
registerPages(_pages);
|
|
219
|
-
}
|
|
220
|
-
else {
|
|
221
|
-
_pages = pages_1.definePage(_page)()(config);
|
|
222
|
-
registerPages(_pages);
|
|
223
|
-
}
|
|
224
|
-
};
|
|
225
|
-
// const loadDinamicContent = async (key: string) => {
|
|
226
|
-
// interface DPage {
|
|
227
|
-
// url: string;
|
|
228
|
-
// slug: string;
|
|
229
|
-
// name?: string;
|
|
230
|
-
// }
|
|
231
|
-
// try {
|
|
232
|
-
// //@ts-ignore
|
|
233
|
-
// const list = await server.$content(key).fetch<DPage[]>();
|
|
234
|
-
// const dRoutes: string[] = [];
|
|
235
|
-
// for (const contentPage of list) {
|
|
236
|
-
// const singlePage = dynamicContent[key];
|
|
237
|
-
// const baseUrl = singlePage.path.replace(
|
|
238
|
-
// /\/\{url?(.+)\}/,
|
|
239
|
-
// contentPage.url
|
|
240
|
-
// );
|
|
241
|
-
// const name = path.posix.join(singlePage.page.name, contentPage.slug);
|
|
242
|
-
// const originalName = path.posix.join(
|
|
243
|
-
// singlePage.page.originName,
|
|
244
|
-
// contentPage.slug
|
|
245
|
-
// );
|
|
246
|
-
// helpers.addUrl(name, {
|
|
247
|
-
// url: baseUrl,
|
|
248
|
-
// locale: singlePage.page.locale,
|
|
249
|
-
// name,
|
|
250
|
-
// originalName
|
|
251
|
-
// });
|
|
252
|
-
// dRoutes.push(baseUrl);
|
|
253
|
-
// }
|
|
254
|
-
// state.dynamicPages[key] = dRoutes;
|
|
255
|
-
// } catch (error) {
|
|
256
|
-
// logger.warn(error);
|
|
257
|
-
// }
|
|
258
|
-
// };
|
|
259
|
-
const init = async () => {
|
|
260
|
-
for (const key in state.pages) {
|
|
261
|
-
const page = state.pages[key];
|
|
262
|
-
registerRoute(page);
|
|
263
|
-
// if (isProduction) {
|
|
264
|
-
// if ((page as any)?.options?.plugins?.flow?.proxy) {
|
|
265
|
-
// registerRoute({
|
|
266
|
-
// ...page,
|
|
267
|
-
// handler: {
|
|
268
|
-
// file: `${config.outputDir}${page.path}.html`
|
|
269
|
-
// }
|
|
270
|
-
// });
|
|
271
|
-
// }
|
|
272
|
-
// } else {
|
|
273
|
-
// registerRoute(page);
|
|
274
|
-
// }
|
|
275
|
-
}
|
|
276
|
-
for (const key in state.extensions) {
|
|
277
|
-
const ext = state.extensions[key];
|
|
278
|
-
if (ext.initMethod) {
|
|
279
|
-
await ext.initMethod({ helpers });
|
|
280
|
-
}
|
|
117
|
+
const { runGenerate } = generator_1.default.register(server);
|
|
118
|
+
serverDecorate.runGenerate = runGenerate;
|
|
119
|
+
const { addPage, init } = runMethods_1.default.register(server);
|
|
120
|
+
serverDecorate.addPage = addPage;
|
|
121
|
+
serverDecorate.init = init;
|
|
122
|
+
// serverDecorate.
|
|
123
|
+
serverDecorate.prepagePackage = async () => {
|
|
124
|
+
for (const key in state.generate.beforePackage) {
|
|
125
|
+
await state.generate.beforePackage[key]();
|
|
281
126
|
}
|
|
282
|
-
config_1.logger.debug(`Register %s pages`, `${Object.values(state.urls).length}`);
|
|
283
|
-
};
|
|
284
|
-
const getPath = (...paths) => path_1.default.join(config.relativeTo, ...paths);
|
|
285
|
-
const { runGenerate } = generate_1.registerGenerate(server, {
|
|
286
|
-
outputDir: config.outputDir || 'build',
|
|
287
|
-
getPath
|
|
288
|
-
});
|
|
289
|
-
// server.$content.
|
|
290
|
-
const serverInfo = () => {
|
|
291
|
-
//
|
|
292
|
-
const interfaces = os_1.default.networkInterfaces();
|
|
293
|
-
const hostname = 'localhost';
|
|
294
|
-
const protocol = 'http';
|
|
295
|
-
console.log('');
|
|
296
|
-
config_1.logger.success(chalk_1.default.green(`Flow v${config_1.pkg.version} dev server running at:`));
|
|
297
|
-
console.log('');
|
|
298
|
-
Object.keys(interfaces).forEach((key) => (interfaces[key] || [])
|
|
299
|
-
.filter((details) => details.family === 'IPv4')
|
|
300
|
-
.map((detail) => {
|
|
301
|
-
return {
|
|
302
|
-
type: detail.address.includes('127.0.0.1')
|
|
303
|
-
? 'Local: '
|
|
304
|
-
: 'Network: ',
|
|
305
|
-
host: detail.address.replace('127.0.0.1', hostname)
|
|
306
|
-
};
|
|
307
|
-
})
|
|
308
|
-
.forEach(({ type, host }) => {
|
|
309
|
-
const url = `${protocol}://${host}:${chalk_1.default.bold(server.info.port)}`;
|
|
310
|
-
console.log(` > ${type} ${chalk_1.default.cyan(url)}`);
|
|
311
|
-
}));
|
|
312
|
-
};
|
|
313
|
-
const runPrePackage = async () => {
|
|
314
|
-
//
|
|
315
|
-
for (const key in state.prePackage) {
|
|
316
|
-
await state.prePackage[key]();
|
|
317
|
-
}
|
|
318
|
-
};
|
|
319
|
-
const flow = {
|
|
320
|
-
runPrePackage,
|
|
321
|
-
serverInfo,
|
|
322
|
-
init,
|
|
323
|
-
addPage,
|
|
324
|
-
getPath,
|
|
325
|
-
runGenerate
|
|
326
127
|
};
|
|
327
|
-
server.decorate('server', 'flow', flow);
|
|
328
|
-
// server.log(['debug', FULL_NAME_PLUGIN], { message: 'Registered plugin' });
|
|
329
128
|
}
|
|
330
129
|
};
|
|
331
130
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;AACA,qCAAqD;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
+
}) : function(o, v) {
|
|
12
|
+
o["default"] = v;
|
|
13
|
+
});
|
|
14
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
+
if (mod && mod.__esModule) return mod;
|
|
16
|
+
var result = {};
|
|
17
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
+
__setModuleDefault(result, mod);
|
|
19
|
+
return result;
|
|
20
|
+
};
|
|
21
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
|
+
const R = __importStar(require("ramda"));
|
|
23
|
+
const boom_1 = require("@hapi/boom");
|
|
24
|
+
exports.default = {
|
|
25
|
+
register: (server) => {
|
|
26
|
+
//
|
|
27
|
+
server.ext('onPreStart', async () => {
|
|
28
|
+
await server.methods.flow.pages();
|
|
29
|
+
});
|
|
30
|
+
//
|
|
31
|
+
server.ext('onRequest', async (req, h) => {
|
|
32
|
+
await server.methods.flow.pages();
|
|
33
|
+
const stateRequest = {
|
|
34
|
+
global: {},
|
|
35
|
+
local: {},
|
|
36
|
+
context: {},
|
|
37
|
+
//@ts-ignore
|
|
38
|
+
utils: {},
|
|
39
|
+
//@ts-ignore
|
|
40
|
+
extensions: {}
|
|
41
|
+
};
|
|
42
|
+
/**
|
|
43
|
+
* Initize states route
|
|
44
|
+
*/
|
|
45
|
+
req.plugins.flow = stateRequest;
|
|
46
|
+
const { flow: state } = server.app;
|
|
47
|
+
const pathRedirect = state.pages.redirects[req.path];
|
|
48
|
+
if (state.truncates[req.path]) {
|
|
49
|
+
return h.redirect('/').takeover();
|
|
50
|
+
}
|
|
51
|
+
if (pathRedirect) {
|
|
52
|
+
return h.redirect(pathRedirect).takeover();
|
|
53
|
+
}
|
|
54
|
+
return h.continue;
|
|
55
|
+
});
|
|
56
|
+
server.ext('onPreHandler', async (req, h) => {
|
|
57
|
+
var _a, _b, _c;
|
|
58
|
+
const dynamic = (_b = (_a = req.route.settings.plugins) === null || _a === void 0 ? void 0 : _a.flow) === null || _b === void 0 ? void 0 : _b.dynamic;
|
|
59
|
+
if (!dynamic)
|
|
60
|
+
return h.continue;
|
|
61
|
+
const pages = await dynamic.pages({
|
|
62
|
+
server,
|
|
63
|
+
route: req.route
|
|
64
|
+
});
|
|
65
|
+
if (!pages)
|
|
66
|
+
return h.continue;
|
|
67
|
+
const listPages = Object.values(pages);
|
|
68
|
+
const page = listPages.find((_page) => _page.url === req.url.pathname);
|
|
69
|
+
if (!page) {
|
|
70
|
+
return boom_1.notFound();
|
|
71
|
+
}
|
|
72
|
+
// console.log(page.context);
|
|
73
|
+
Object.assign(req.plugins.flow.local, {
|
|
74
|
+
[dynamic.assign || 'dynamic']: (_c = page.context) !== null && _c !== void 0 ? _c : { a: '' }
|
|
75
|
+
});
|
|
76
|
+
req.app.dynamic = R.omit(['context'], page);
|
|
77
|
+
return h.continue;
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
//# sourceMappingURL=lifeCircle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lifeCircle.js","sourceRoot":"","sources":["../src/lifeCircle.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AACA,yCAA2B;AAC3B,qCAAsC;AACtC,kBAAe;IACb,QAAQ,EAAE,CAAC,MAAc,EAAE,EAAE;QAC3B,EAAE;QACF,MAAM,CAAC,GAAG,CAAC,YAAY,EAAE,KAAK,IAAI,EAAE;YAClC,MAAM,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;QACpC,CAAC,CAAC,CAAC;QACH,EAAE;QACF,MAAM,CAAC,GAAG,CAAC,WAAW,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE;YACvC,MAAM,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAElC,MAAM,YAAY,GAAG;gBACnB,MAAM,EAAE,EAAE;gBACV,KAAK,EAAE,EAAE;gBACT,OAAO,EAAE,EAAE;gBACX,YAAY;gBACZ,KAAK,EAAE,EAAE;gBACT,YAAY;gBACZ,UAAU,EAAE,EAAE;aACf,CAAC;YACF;;eAEG;YACH,GAAG,CAAC,OAAO,CAAC,IAAI,GAAG,YAAmB,CAAC;YACvC,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC,GAAG,CAAC;YAEnC,MAAM,YAAY,GAAG,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAErD,IAAI,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;gBAC7B,OAAO,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;aACnC;YAED,IAAI,YAAY,EAAE;gBAChB,OAAO,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE,CAAC;aAC5C;YACD,OAAO,CAAC,CAAC,QAAQ,CAAC;QACpB,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,GAAG,CAAC,cAAc,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE;;YAC1C,MAAM,OAAO,GAAG,MAAA,MAAA,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,0CAAE,IAAI,0CAAE,OAAO,CAAC;YAC1D,IAAI,CAAC,OAAO;gBAAE,OAAO,CAAC,CAAC,QAAQ,CAAC;YAEhC,MAAM,KAAK,GAAG,MAAM,OAAO,CAAC,KAAK,CAAC;gBAChC,MAAM;gBACN,KAAK,EAAE,GAAG,CAAC,KAAK;aACjB,CAAC,CAAC;YAEH,IAAI,CAAC,KAAK;gBAAE,OAAO,CAAC,CAAC,QAAQ,CAAC;YAE9B,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAEvC,MAAM,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,KAAK,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;YACvE,IAAI,CAAC,IAAI,EAAE;gBACT,OAAO,eAAQ,EAAE,CAAC;aACnB;YACD,6BAA6B;YAE7B,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE;gBACpC,CAAC,OAAO,CAAC,MAAM,IAAI,SAAS,CAAC,EAAE,MAAA,IAAI,CAAC,OAAO,mCAAI,EAAE,CAAC,EAAE,EAAE,EAAE;aACzD,CAAC,CAAC;YACH,GAAG,CAAC,GAAG,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,CAAC;YAE5C,OAAO,CAAC,CAAC,QAAQ,CAAC;QACpB,CAAC,CAAC,CAAC;IACL,CAAC;CACF,CAAC"}
|
package/dist/pages.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { OptionsHapiPage, RunPreDefinePage } from "../types";
|
|
2
|
-
export declare type DefinePage = (page: OptionsHapiPage) => RunPreDefinePage;
|
|
1
|
+
import { OptionsHapiPage, RunPreDefinePage, OptionsDynamicPages } from "../types";
|
|
2
|
+
export declare type DefinePage = (page: OptionsHapiPage, dynamic?: OptionsDynamicPages) => RunPreDefinePage;
|
|
3
3
|
export declare const definePage: DefinePage;
|
package/dist/pages.js
CHANGED
|
@@ -22,8 +22,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
22
22
|
exports.definePage = void 0;
|
|
23
23
|
const flow_core_1 = require("@monkeyplus/flow-core");
|
|
24
24
|
const R = __importStar(require("ramda"));
|
|
25
|
-
const definePage = (pageOptions) => (levelOptions) => (configs) => {
|
|
25
|
+
const definePage = (pageOptions, dynamic) => (levelOptions) => (configs) => {
|
|
26
26
|
//
|
|
27
|
+
// if(isDinamyc(pageOptions.))
|
|
27
28
|
const pages = [];
|
|
28
29
|
for (const locale in pageOptions.locales) {
|
|
29
30
|
if (configs.locales.find((_locale) => _locale === locale)) {
|
|
@@ -31,9 +32,6 @@ const definePage = (pageOptions) => (levelOptions) => (configs) => {
|
|
|
31
32
|
pages.push({ url: singlePage.url, locale });
|
|
32
33
|
}
|
|
33
34
|
}
|
|
34
|
-
// R.mapObjIndexed((singlePage, locale) => {
|
|
35
|
-
// return { [locale]: singlePage.u };
|
|
36
|
-
// }, page.locales);
|
|
37
35
|
const infoPages = flow_core_1.definePages({
|
|
38
36
|
name: pageOptions.name,
|
|
39
37
|
view: pageOptions.view,
|
|
@@ -61,7 +59,8 @@ const definePage = (pageOptions) => (levelOptions) => (configs) => {
|
|
|
61
59
|
},
|
|
62
60
|
plugins: {
|
|
63
61
|
flow: {
|
|
64
|
-
extensions: pageOptions.extensions || {}
|
|
62
|
+
extensions: pageOptions.extensions || {},
|
|
63
|
+
dynamic
|
|
65
64
|
}
|
|
66
65
|
}
|
|
67
66
|
},
|
package/dist/pages.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pages.js","sourceRoot":"","sources":["../src/pages.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAEA,qDAAgE;AAChE,yCAA2B;
|
|
1
|
+
{"version":3,"file":"pages.js","sourceRoot":"","sources":["../src/pages.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Server } from '@hapi/hapi';
|
|
2
|
+
import { OptionsHapiPage, RunDefinePage, OptionsDynamicPages } from "../types";
|
|
3
|
+
declare const _default: {
|
|
4
|
+
register: (server: Server) => {
|
|
5
|
+
init: () => Promise<void>;
|
|
6
|
+
addPage: (_page: RunDefinePage | OptionsHapiPage, dynamic?: OptionsDynamicPages | undefined) => void;
|
|
7
|
+
};
|
|
8
|
+
};
|
|
9
|
+
export default _default;
|