zet-lib 3.3.1 → 3.3.3
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/lib/Form.js +2 -2
- package/lib/views/zgenerator/routerApp.ejs +359 -359
- package/lib/zAppRouter.js +13 -13
- package/lib/zRoleRouter.js +1 -0
- package/lib/zapp.js +113 -85
- package/package.json +1 -1
package/lib/Form.js
CHANGED
|
@@ -512,11 +512,11 @@ Form.field = (obj) => {
|
|
|
512
512
|
});
|
|
513
513
|
|
|
514
514
|
displayForm += `<div id="dragdrop_${obj.id}" class="row contentfields">
|
|
515
|
-
<div class="col-
|
|
515
|
+
<div class="col-6">
|
|
516
516
|
<h5>${obj.attributes.left}</h5>
|
|
517
517
|
<ol class="mydragable${obj.id} divboxlittle" data-type="left" data-name="${obj.name}[]">${leftButtons}</ol>
|
|
518
518
|
</div>
|
|
519
|
-
<div class="col-
|
|
519
|
+
<div class="col-6">
|
|
520
520
|
<h5>${obj.attributes.right}</h5>
|
|
521
521
|
<ol class="mydragable${obj.id} divboxlittle" data-type="right" data-name="trashx">
|
|
522
522
|
${rightButtons}
|
|
@@ -1,359 +1,359 @@
|
|
|
1
|
-
const router = require('express').Router();
|
|
2
|
-
const {csrf} = require('zet-lib');
|
|
3
|
-
const csrfProtection = csrf({cookie: true});
|
|
4
|
-
const {Util, access, connection, moduleLib, zDebug, zRoute, zRole, zDataTable, zForm} = require('zet-lib');
|
|
5
|
-
const MYMODEL = require('./../models/[[[TABLE_NAME]]]');
|
|
6
|
-
|
|
7
|
-
router.get('/', async (req, res) => {
|
|
8
|
-
await zRoute.attributeData(res, MYMODEL);
|
|
9
|
-
let dataTable = new zDataTable(res.locals);
|
|
10
|
-
dataTable.filterMODEL = await zRoute.dataTableFilterSync(req,res, MYMODEL, res.locals.gridFilter);
|
|
11
|
-
const levels = zRole.myLevel(req, res, MYMODEL.table);
|
|
12
|
-
dataTable.levels = levels;
|
|
13
|
-
res.render(`layouts/${layout}`, {
|
|
14
|
-
dataTable: dataTable,
|
|
15
|
-
levels : levels,
|
|
16
|
-
titleHeader: `<strong class="text text-info">${MYMODEL.title}</strong>`,
|
|
17
|
-
breadcrumb : zForm.breadcrumbIndex(),
|
|
18
|
-
myModal : zForm.modal({
|
|
19
|
-
attributeData: res.locals.attributeData,
|
|
20
|
-
visibles: res.locals.visibles,
|
|
21
|
-
invisibles: res.locals.invisibles,
|
|
22
|
-
routeName: MYMODEL.table,
|
|
23
|
-
}, LANGUAGE),
|
|
24
|
-
renderHead: `${MYMODEL.routeName}/indexcss.ejs`,
|
|
25
|
-
renderBody: `${MYMODEL.routeName}/index.ejs`,
|
|
26
|
-
renderEnd: `${MYMODEL.routeName}/indexjs.ejs`
|
|
27
|
-
});
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
router.post('/list', async (req, res) => {
|
|
31
|
-
const data = await zRoute.listData(req, res, MYMODEL, zRole);
|
|
32
|
-
res.json(data);
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
router.get('/create', csrfProtection, async(req, res) => {
|
|
36
|
-
let data = MYMODEL.datas;
|
|
37
|
-
const zForms = await zRoute.formsFieldSync(req, res, MYMODEL, data);
|
|
38
|
-
res.render(`layouts/${layout}`, {
|
|
39
|
-
data: data,
|
|
40
|
-
zForms: zForms,
|
|
41
|
-
titleHeader: `${LANGUAGE['form_create']} : <strong><a href="/${MYMODEL.routeName}">${MYMODEL.title}</a></strong>`,
|
|
42
|
-
csrfToken: req.csrfToken(),
|
|
43
|
-
breadcrumb : zForm.breadcrumbCreate(MYMODEL.routeName),
|
|
44
|
-
renderBody: `${MYMODEL.routeName}/create.ejs`,
|
|
45
|
-
renderEnd: `${MYMODEL.routeName}/createjs.ejs`
|
|
46
|
-
});
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
router.post('/create', csrfProtection, async (req, res) => {
|
|
50
|
-
let json = Util.jsonSuccess(LANGUAGE['data_saved']);
|
|
51
|
-
try {
|
|
52
|
-
let data = zRoute.post(req,res, MYMODEL)[MYMODEL.routeName];
|
|
53
|
-
const validator = zRoute.validator(data, MYMODEL);
|
|
54
|
-
if(validator.status == 0) return res.json(validator.message);
|
|
55
|
-
const result = await zRoute.insertSQL(req, res, MYMODEL.table, data);
|
|
56
|
-
json.data=result;
|
|
57
|
-
} catch (err) {
|
|
58
|
-
if(Object.hasOwn(err,"sqlMessage")){
|
|
59
|
-
json = Util.flashError(err.sqlMessage);
|
|
60
|
-
} else {
|
|
61
|
-
json = Util.flashError(err.toString());
|
|
62
|
-
}
|
|
63
|
-
zDebug(req, res, err);
|
|
64
|
-
}
|
|
65
|
-
res.json(json);
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
router.get('/update/:id', csrfProtection, async (req, res) => {
|
|
69
|
-
const id = parseInt(req.params.id);
|
|
70
|
-
const results = await connection.results({
|
|
71
|
-
select:zRoute.selectData(MYMODEL),
|
|
72
|
-
table: MYMODEL.table,
|
|
73
|
-
where: {
|
|
74
|
-
id: id,
|
|
75
|
-
company_id: res.locals.companyId
|
|
76
|
-
}
|
|
77
|
-
});
|
|
78
|
-
if (results.length == 0) {
|
|
79
|
-
req.session.sessionFlash = Util.flashError(LANGUAGE['data_not_found']);
|
|
80
|
-
return res.redirect('/' + MYMODEL.routeName);
|
|
81
|
-
}
|
|
82
|
-
let data = results[0];
|
|
83
|
-
const zForms = await zRoute.formsFieldSync(req, res, MYMODEL, data);
|
|
84
|
-
res.render(`layouts/${layout}`, {
|
|
85
|
-
data: data,
|
|
86
|
-
zForms: zForms,
|
|
87
|
-
titleHeader: `${LANGUAGE['form_update']} : <strong><a href="/${MYMODEL.routeName}">${MYMODEL.title}</a></strong>`,
|
|
88
|
-
csrfToken: req.csrfToken(),
|
|
89
|
-
breadcrumb : zForm.breadcrumbUpdate(MYMODEL.routeName, id),
|
|
90
|
-
renderBody: `${MYMODEL.routeName}/update.ejs`,
|
|
91
|
-
renderEnd: `${MYMODEL.routeName}/updatejs.ejs`,
|
|
92
|
-
});
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
router.post('/update/:id', csrfProtection, async (req, res) => {
|
|
96
|
-
let json = Util.jsonSuccess(LANGUAGE['data_saved']);
|
|
97
|
-
try {
|
|
98
|
-
const id = parseInt(req.params.id);
|
|
99
|
-
let data = zRoute.post(req,res, MYMODEL)[MYMODEL.routeName];
|
|
100
|
-
const validator = zRoute.validator(data, MYMODEL);
|
|
101
|
-
if(validator.status == 0) return res.json(validator.message);
|
|
102
|
-
const result = await zRoute.updateSQL(req, res,MYMODEL.table, data, {id:id});
|
|
103
|
-
json.data=result;
|
|
104
|
-
} catch (err) {
|
|
105
|
-
console.log(err)
|
|
106
|
-
if(Object.hasOwn(err,"sqlMessage")){
|
|
107
|
-
json = Util.flashError(err.sqlMessage);
|
|
108
|
-
} else {
|
|
109
|
-
json = Util.flashError(err.toString());
|
|
110
|
-
}
|
|
111
|
-
zDebug(req, res, err)
|
|
112
|
-
}
|
|
113
|
-
res.json(json);
|
|
114
|
-
});
|
|
115
|
-
|
|
116
|
-
router.delete('/delete', async (req, res) => {
|
|
117
|
-
const id = req.body.id;
|
|
118
|
-
let json = Util.jsonSuccess(LANGUAGE['data_delete']);
|
|
119
|
-
try {
|
|
120
|
-
await zRoute.deleteSQL(MYMODEL.table, id, res.locals.companyId);
|
|
121
|
-
} catch (err) {
|
|
122
|
-
json = Util.flashError(err.toString());
|
|
123
|
-
zDebug(req, res, err)
|
|
124
|
-
}
|
|
125
|
-
res.json(json);
|
|
126
|
-
});
|
|
127
|
-
|
|
128
|
-
router.get('/view/:id', async (req, res) => {
|
|
129
|
-
await zRoute.attributeData(res, MYMODEL);
|
|
130
|
-
const id = req.params.id;
|
|
131
|
-
let data = {};
|
|
132
|
-
let zForms = {};
|
|
133
|
-
try {
|
|
134
|
-
const results = await connection.results({select:zRoute.selectData(MYMODEL),table:MYMODEL.table,where:{id:id}});
|
|
135
|
-
if (results.length == 0) {
|
|
136
|
-
req.session.sessionFlash = Util.flashError(LANGUAGE['data_not_found']);
|
|
137
|
-
return res.redirect('/' + MYMODEL.routeName);
|
|
138
|
-
}
|
|
139
|
-
data = results[0];
|
|
140
|
-
zForms = await zRoute.viewFormsSync(req, res, MYMODEL, data);
|
|
141
|
-
} catch (err){
|
|
142
|
-
zDebug(req, res, err);
|
|
143
|
-
res.send("Err");
|
|
144
|
-
}
|
|
145
|
-
res.render(`layouts/${layout}`, {
|
|
146
|
-
data: data,
|
|
147
|
-
Util:Util,
|
|
148
|
-
zForms:zForms,
|
|
149
|
-
titleHeader: `View : <strong><a href="/${MYMODEL.routeName}">${MYMODEL.title}</a></strong>`,
|
|
150
|
-
breadcrumb : zForm.breadcrumbView(MYMODEL.routeName),
|
|
151
|
-
levels: zRole.myLevel(req, res, MYMODEL.table),
|
|
152
|
-
renderBody: `${MYMODEL.routeName}/view.ejs`
|
|
153
|
-
});
|
|
154
|
-
});
|
|
155
|
-
|
|
156
|
-
router.get('/excel-query', async (req,res) => {
|
|
157
|
-
await zRoute.excelQuery(req, res, MYMODEL);
|
|
158
|
-
});
|
|
159
|
-
|
|
160
|
-
router.get('/excel', async (req, res) => {
|
|
161
|
-
const fields = MYMODEL.keysExcel;
|
|
162
|
-
const results = await connection.results({
|
|
163
|
-
table: MYMODEL.table,
|
|
164
|
-
where: {company_id: res.locals.companyId},
|
|
165
|
-
orderBy: ['id', 'DESC']
|
|
166
|
-
});
|
|
167
|
-
await zRoute.excel(req, res, MYMODEL, fields, results);
|
|
168
|
-
});
|
|
169
|
-
|
|
170
|
-
router.get('/sample', async (req, res) => {
|
|
171
|
-
let fields = [];
|
|
172
|
-
for (let i = 0; i < MYMODEL.keysExcel.length; i++) {
|
|
173
|
-
if (!Util.in_array(MYMODEL.keysExcel[i], Util.nots)) {
|
|
174
|
-
fields.push(MYMODEL.keysExcel[i]);
|
|
175
|
-
}
|
|
176
|
-
}
|
|
177
|
-
const results = await connection.results({
|
|
178
|
-
table:MYMODEL.table,
|
|
179
|
-
where:{
|
|
180
|
-
company_id:res.locals.companyId
|
|
181
|
-
},
|
|
182
|
-
orderBy:["id","desc"], limit:10
|
|
183
|
-
});
|
|
184
|
-
let callback=(result,field)=> {
|
|
185
|
-
return MYMODEL.widgets[field] && MYMODEL.widgets[field].name == 'datepicker' ? Util.dateSql(result[field]) : result[field];
|
|
186
|
-
};
|
|
187
|
-
await zRoute.excel(req, res, MYMODEL, fields, results, callback);
|
|
188
|
-
});
|
|
189
|
-
|
|
190
|
-
router.get('/import',csrfProtection, async (req, res) => {
|
|
191
|
-
const room = res.locals.token;
|
|
192
|
-
res.render(`layouts/${layout}`, {
|
|
193
|
-
room: room,
|
|
194
|
-
titleHeader: `Import / Upload data : <strong><a href="/${MYMODEL.routeName}">${MYMODEL.title}</a></strong>`,
|
|
195
|
-
csrfToken: req.csrfToken(),
|
|
196
|
-
breadcrumb : zForm.breadcrumbImport(MYMODEL.routeName),
|
|
197
|
-
renderBody: `${MYMODEL.routeName}/import.ejs`,
|
|
198
|
-
renderEnd: `${MYMODEL.routeName}/importjs.ejs`
|
|
199
|
-
});
|
|
200
|
-
});
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
router.post('/import', async(req, res) => {
|
|
204
|
-
res.json(await zRoute.import(req,res,MYMODEL));
|
|
205
|
-
});
|
|
206
|
-
|
|
207
|
-
router.get('/approval/:id', async (req, res) => {
|
|
208
|
-
await zRoute.attributeData(res, MYMODEL);
|
|
209
|
-
const id = req.params.id;
|
|
210
|
-
let data = {};
|
|
211
|
-
let data2 = {};
|
|
212
|
-
let zForms = {};
|
|
213
|
-
let zForms2 = {};
|
|
214
|
-
let result = {};
|
|
215
|
-
try {
|
|
216
|
-
result = await connection.result({table: MYMODEL.table, where: {id: id}});
|
|
217
|
-
if (!result.id) {
|
|
218
|
-
req.session.sessionFlash = Util.flashError(LANGUAGE['data_not_found']);
|
|
219
|
-
return res.redirect('/' + MYMODEL.routeName);
|
|
220
|
-
}
|
|
221
|
-
data=result;
|
|
222
|
-
moduleLib.editor(req, res);
|
|
223
|
-
zForms = await zRoute.viewFormsSync(req, res, MYMODEL, result);
|
|
224
|
-
const contentScript = `$("#submit_draft").on("click", function () {$("#status").val(1);ajaxPost("/zzapproval",$("#form-group").serializeArray(), function (data) {
|
|
225
|
-
if (data.status == 0) {
|
|
226
|
-
toastr.error(data.message, data.title);
|
|
227
|
-
} else {
|
|
228
|
-
toastr.success(data.title, data.message);
|
|
229
|
-
}
|
|
230
|
-
});});
|
|
231
|
-
$("#submit").on("click", function () {
|
|
232
|
-
$('[name="zapprovals[status]"]').val(2);
|
|
233
|
-
ajaxPost("/zzapproval",$("#form-group").serializeArray(), function (data) {
|
|
234
|
-
if (data.status == 0) {
|
|
235
|
-
toastr.error(data.message, data.title);
|
|
236
|
-
} else {
|
|
237
|
-
toastr.success(data.title, data.message);
|
|
238
|
-
location.href = "";
|
|
239
|
-
}
|
|
240
|
-
});
|
|
241
|
-
});
|
|
242
|
-
`;
|
|
243
|
-
await moduleLib.addScript(req, res, contentScript);
|
|
244
|
-
const MODEL_APROVALS = require("./../models/zapprovals");
|
|
245
|
-
const rows = await connection.results({
|
|
246
|
-
table: "zapprovals",
|
|
247
|
-
where: {table: MYMODEL.table, company_id: res.locals.companyId, id_data: id}
|
|
248
|
-
});
|
|
249
|
-
if (rows.length) {
|
|
250
|
-
data2 = rows[0];
|
|
251
|
-
} else {
|
|
252
|
-
let obj = {};
|
|
253
|
-
obj.token = Util.uuid();
|
|
254
|
-
obj.status = 1;
|
|
255
|
-
obj.table = MYMODEL.table;
|
|
256
|
-
obj.company_id = res.locals.companyId;
|
|
257
|
-
obj.id_data = id;
|
|
258
|
-
obj.created_by = res.locals.userId;
|
|
259
|
-
obj.updated_by = res.locals.userId;
|
|
260
|
-
obj.created_at = Util.now();
|
|
261
|
-
let zfields = await connection.result({table: "zfields", where: {table: MYMODEL.table}});
|
|
262
|
-
let jsonApproval = zfields.approval_json || {}
|
|
263
|
-
obj.template = jsonApproval.content || {}
|
|
264
|
-
let title = jsonApproval.title;
|
|
265
|
-
if (title) {
|
|
266
|
-
let titleData = title;
|
|
267
|
-
for (var key in data) {
|
|
268
|
-
titleData = Util.replaceAll(titleData, "{{" + key + "}}", data[key])
|
|
269
|
-
}
|
|
270
|
-
obj.title = titleData
|
|
271
|
-
}
|
|
272
|
-
if (jsonApproval.hasOwnProperty("approvers")) {
|
|
273
|
-
obj.approvers = JSON.stringify(jsonApproval.approvers);
|
|
274
|
-
obj.knowings = JSON.stringify(jsonApproval.knowings);
|
|
275
|
-
obj.type = 1;
|
|
276
|
-
}
|
|
277
|
-
//insert default data
|
|
278
|
-
await connection.insert({table: "zapprovals", data: obj});
|
|
279
|
-
data2 = obj;
|
|
280
|
-
}
|
|
281
|
-
zForms2 = await zRoute.formsFieldSync(req, res, MODEL_APROVALS, data2);
|
|
282
|
-
} catch (err) {
|
|
283
|
-
zDebug(req, res, err);
|
|
284
|
-
res.send("Err");
|
|
285
|
-
}
|
|
286
|
-
res.render(`layouts/${layout}`, {
|
|
287
|
-
zForms: zForms,
|
|
288
|
-
zForms2: zForms2,
|
|
289
|
-
data: result,
|
|
290
|
-
result:result,
|
|
291
|
-
data2: data2,
|
|
292
|
-
Util: Util,
|
|
293
|
-
levels: zRole.myLevel(req, res, MYMODEL.table),
|
|
294
|
-
breadcrumb : zForm.breadcrumbApproval(MYMODEL.routeName, id),
|
|
295
|
-
renderBody: `${MYMODEL.routeName}/approval.ejs`
|
|
296
|
-
});
|
|
297
|
-
});
|
|
298
|
-
|
|
299
|
-
router.get('/preview/:token', async (req, res) => {
|
|
300
|
-
let token = req.params.token;
|
|
301
|
-
let data = {}, data2 = {};
|
|
302
|
-
let template = "";
|
|
303
|
-
let footers = "";
|
|
304
|
-
try {
|
|
305
|
-
let zfields = await connection.result({table: "zfields", where: {table: MYMODEL.table}});
|
|
306
|
-
let jsonApproval = zfields.approval_json || {}
|
|
307
|
-
let mytemplate = jsonApproval.content || {}
|
|
308
|
-
let results = await connection.results({table: "zapprovals", where: {token: token}});
|
|
309
|
-
if (results.length == 0) {
|
|
310
|
-
req.session.sessionFlash = Util.flashError(LANGUAGE['data_not_found']);
|
|
311
|
-
return res.redirect('/' + MYMODEL.routeName);
|
|
312
|
-
}
|
|
313
|
-
if(results[0].status == 1){
|
|
314
|
-
await connection.update({
|
|
315
|
-
table : "zapprovals",
|
|
316
|
-
data: {
|
|
317
|
-
template : mytemplate
|
|
318
|
-
},
|
|
319
|
-
where : {
|
|
320
|
-
token:token
|
|
321
|
-
}
|
|
322
|
-
})
|
|
323
|
-
results = await connection.results({table: "zapprovals", where: {token: token}});
|
|
324
|
-
}
|
|
325
|
-
let MYMODEL2 = require("./../models/zapprovals")
|
|
326
|
-
data = await zRoute.viewTable(req, res, MYMODEL2, results[0], true);
|
|
327
|
-
let row = await connection.result({table: results[0].table, where: {id: results[0].id_data}});
|
|
328
|
-
data2 = await zRoute.viewTable(req, res, MYMODEL, row, true);
|
|
329
|
-
template = data.template;
|
|
330
|
-
let title = data.title || ""
|
|
331
|
-
for (var key in data2) {
|
|
332
|
-
template = Util.replaceAll(template, "{{" + key + "}}", data2[key])
|
|
333
|
-
title = Util.replaceAll(title, "{{" + key + "}}", data2[key])
|
|
334
|
-
}
|
|
335
|
-
data.title = title;
|
|
336
|
-
var details = await connection.results({table: "zapprovals_details", where: {title_id: results[0].id}});
|
|
337
|
-
if (details.length) {
|
|
338
|
-
footers = await zRoute.approversFooter(details);
|
|
339
|
-
}
|
|
340
|
-
} catch (err) {
|
|
341
|
-
zDebug(req, res, err);
|
|
342
|
-
res.send("Err");
|
|
343
|
-
}
|
|
344
|
-
res.render(`layouts/blank`, {
|
|
345
|
-
template: template,
|
|
346
|
-
data: data,
|
|
347
|
-
footers: footers,
|
|
348
|
-
Util: Util,
|
|
349
|
-
details: details,
|
|
350
|
-
renderBody: 'index/zapprovals_preview.ejs'
|
|
351
|
-
});
|
|
352
|
-
});
|
|
353
|
-
|
|
354
|
-
router.post('/grid', access, zRoute.postGrid);
|
|
355
|
-
router.post('/reload', access, zRoute.postGridReload);
|
|
356
|
-
router.post('/chains', access, zRoute.chains);
|
|
357
|
-
router.post('/get_attributes',access, zRoute.getAttributes);
|
|
358
|
-
|
|
359
|
-
module.exports = router;
|
|
1
|
+
const router = require('express').Router();
|
|
2
|
+
const {csrf} = require('zet-lib');
|
|
3
|
+
const csrfProtection = csrf({cookie: true});
|
|
4
|
+
const {Util, access, connection, moduleLib, zDebug, zRoute, zRole, zDataTable, zForm} = require('zet-lib');
|
|
5
|
+
const MYMODEL = require('./../models/[[[TABLE_NAME]]]');
|
|
6
|
+
|
|
7
|
+
router.get('/', async (req, res) => {
|
|
8
|
+
await zRoute.attributeData(res, MYMODEL);
|
|
9
|
+
let dataTable = new zDataTable(res.locals);
|
|
10
|
+
dataTable.filterMODEL = await zRoute.dataTableFilterSync(req,res, MYMODEL, res.locals.gridFilter);
|
|
11
|
+
const levels = zRole.myLevel(req, res, MYMODEL.table);
|
|
12
|
+
dataTable.levels = levels;
|
|
13
|
+
res.render(`layouts/${layout}`, {
|
|
14
|
+
dataTable: dataTable,
|
|
15
|
+
levels : levels,
|
|
16
|
+
titleHeader: `<strong class="text text-info">${MYMODEL.title}</strong>`,
|
|
17
|
+
breadcrumb : zForm.breadcrumbIndex(),
|
|
18
|
+
myModal : zForm.modal({
|
|
19
|
+
attributeData: res.locals.attributeData,
|
|
20
|
+
visibles: res.locals.visibles,
|
|
21
|
+
invisibles: res.locals.invisibles,
|
|
22
|
+
routeName: MYMODEL.table,
|
|
23
|
+
}, LANGUAGE),
|
|
24
|
+
renderHead: `${MYMODEL.routeName}/indexcss.ejs`,
|
|
25
|
+
renderBody: `${MYMODEL.routeName}/index.ejs`,
|
|
26
|
+
renderEnd: `${MYMODEL.routeName}/indexjs.ejs`
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
router.post('/list', async (req, res) => {
|
|
31
|
+
const data = await zRoute.listData(req, res, MYMODEL, zRole);
|
|
32
|
+
res.json(data);
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
router.get('/create', csrfProtection, async(req, res) => {
|
|
36
|
+
let data = MYMODEL.datas;
|
|
37
|
+
const zForms = await zRoute.formsFieldSync(req, res, MYMODEL, data);
|
|
38
|
+
res.render(`layouts/${layout}`, {
|
|
39
|
+
data: data,
|
|
40
|
+
zForms: zForms,
|
|
41
|
+
titleHeader: `${LANGUAGE['form_create']} : <strong><a href="/${MYMODEL.routeName}">${MYMODEL.title}</a></strong>`,
|
|
42
|
+
csrfToken: req.csrfToken(),
|
|
43
|
+
breadcrumb : zForm.breadcrumbCreate(MYMODEL.routeName),
|
|
44
|
+
renderBody: `${MYMODEL.routeName}/create.ejs`,
|
|
45
|
+
renderEnd: `${MYMODEL.routeName}/createjs.ejs`
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
router.post('/create', csrfProtection, async (req, res) => {
|
|
50
|
+
let json = Util.jsonSuccess(LANGUAGE['data_saved']);
|
|
51
|
+
try {
|
|
52
|
+
let data = zRoute.post(req,res, MYMODEL)[MYMODEL.routeName];
|
|
53
|
+
const validator = zRoute.validator(data, MYMODEL);
|
|
54
|
+
if(validator.status == 0) return res.json(validator.message);
|
|
55
|
+
const result = await zRoute.insertSQL(req, res, MYMODEL.table, data);
|
|
56
|
+
json.data=result;
|
|
57
|
+
} catch (err) {
|
|
58
|
+
if(Object.hasOwn(err,"sqlMessage")){
|
|
59
|
+
json = Util.flashError(err.sqlMessage);
|
|
60
|
+
} else {
|
|
61
|
+
json = Util.flashError(err.toString());
|
|
62
|
+
}
|
|
63
|
+
zDebug(req, res, err);
|
|
64
|
+
}
|
|
65
|
+
res.json(json);
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
router.get('/update/:id', csrfProtection, async (req, res) => {
|
|
69
|
+
const id = parseInt(req.params.id);
|
|
70
|
+
const results = await connection.results({
|
|
71
|
+
select:zRoute.selectData(MYMODEL),
|
|
72
|
+
table: MYMODEL.table,
|
|
73
|
+
where: {
|
|
74
|
+
id: id,
|
|
75
|
+
company_id: res.locals.companyId
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
if (results.length == 0) {
|
|
79
|
+
req.session.sessionFlash = Util.flashError(LANGUAGE['data_not_found']);
|
|
80
|
+
return res.redirect('/' + MYMODEL.routeName);
|
|
81
|
+
}
|
|
82
|
+
let data = results[0];
|
|
83
|
+
const zForms = await zRoute.formsFieldSync(req, res, MYMODEL, data);
|
|
84
|
+
res.render(`layouts/${layout}`, {
|
|
85
|
+
data: data,
|
|
86
|
+
zForms: zForms,
|
|
87
|
+
titleHeader: `${LANGUAGE['form_update']} : <strong><a href="/${MYMODEL.routeName}">${MYMODEL.title}</a></strong>`,
|
|
88
|
+
csrfToken: req.csrfToken(),
|
|
89
|
+
breadcrumb : zForm.breadcrumbUpdate(MYMODEL.routeName, id),
|
|
90
|
+
renderBody: `${MYMODEL.routeName}/update.ejs`,
|
|
91
|
+
renderEnd: `${MYMODEL.routeName}/updatejs.ejs`,
|
|
92
|
+
});
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
router.post('/update/:id', csrfProtection, async (req, res) => {
|
|
96
|
+
let json = Util.jsonSuccess(LANGUAGE['data_saved']);
|
|
97
|
+
try {
|
|
98
|
+
const id = parseInt(req.params.id);
|
|
99
|
+
let data = zRoute.post(req,res, MYMODEL)[MYMODEL.routeName];
|
|
100
|
+
const validator = zRoute.validator(data, MYMODEL);
|
|
101
|
+
if(validator.status == 0) return res.json(validator.message);
|
|
102
|
+
const result = await zRoute.updateSQL(req, res,MYMODEL.table, data, {id:id});
|
|
103
|
+
json.data=result;
|
|
104
|
+
} catch (err) {
|
|
105
|
+
console.log(err)
|
|
106
|
+
if(Object.hasOwn(err,"sqlMessage")){
|
|
107
|
+
json = Util.flashError(err.sqlMessage);
|
|
108
|
+
} else {
|
|
109
|
+
json = Util.flashError(err.toString());
|
|
110
|
+
}
|
|
111
|
+
zDebug(req, res, err)
|
|
112
|
+
}
|
|
113
|
+
res.json(json);
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
router.delete('/delete', async (req, res) => {
|
|
117
|
+
const id = req.body.id;
|
|
118
|
+
let json = Util.jsonSuccess(LANGUAGE['data_delete']);
|
|
119
|
+
try {
|
|
120
|
+
await zRoute.deleteSQL(MYMODEL.table, id, res.locals.companyId);
|
|
121
|
+
} catch (err) {
|
|
122
|
+
json = Util.flashError(err.toString());
|
|
123
|
+
zDebug(req, res, err)
|
|
124
|
+
}
|
|
125
|
+
res.json(json);
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
router.get('/view/:id', async (req, res) => {
|
|
129
|
+
await zRoute.attributeData(res, MYMODEL);
|
|
130
|
+
const id = req.params.id;
|
|
131
|
+
let data = {};
|
|
132
|
+
let zForms = {};
|
|
133
|
+
try {
|
|
134
|
+
const results = await connection.results({select:zRoute.selectData(MYMODEL),table:MYMODEL.table,where:{id:id}});
|
|
135
|
+
if (results.length == 0) {
|
|
136
|
+
req.session.sessionFlash = Util.flashError(LANGUAGE['data_not_found']);
|
|
137
|
+
return res.redirect('/' + MYMODEL.routeName);
|
|
138
|
+
}
|
|
139
|
+
data = results[0];
|
|
140
|
+
zForms = await zRoute.viewFormsSync(req, res, MYMODEL, data);
|
|
141
|
+
} catch (err){
|
|
142
|
+
zDebug(req, res, err);
|
|
143
|
+
res.send("Err");
|
|
144
|
+
}
|
|
145
|
+
res.render(`layouts/${layout}`, {
|
|
146
|
+
data: data,
|
|
147
|
+
Util:Util,
|
|
148
|
+
zForms:zForms,
|
|
149
|
+
titleHeader: `View : <strong><a href="/${MYMODEL.routeName}">${MYMODEL.title}</a></strong>`,
|
|
150
|
+
breadcrumb : zForm.breadcrumbView(MYMODEL.routeName),
|
|
151
|
+
levels: zRole.myLevel(req, res, MYMODEL.table),
|
|
152
|
+
renderBody: `${MYMODEL.routeName}/view.ejs`
|
|
153
|
+
});
|
|
154
|
+
});
|
|
155
|
+
|
|
156
|
+
router.get('/excel-query', async (req,res) => {
|
|
157
|
+
await zRoute.excelQuery(req, res, MYMODEL);
|
|
158
|
+
});
|
|
159
|
+
|
|
160
|
+
router.get('/excel', async (req, res) => {
|
|
161
|
+
const fields = MYMODEL.keysExcel;
|
|
162
|
+
const results = await connection.results({
|
|
163
|
+
table: MYMODEL.table,
|
|
164
|
+
where: {company_id: res.locals.companyId},
|
|
165
|
+
orderBy: ['id', 'DESC']
|
|
166
|
+
});
|
|
167
|
+
await zRoute.excel(req, res, MYMODEL, fields, results);
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
router.get('/sample', async (req, res) => {
|
|
171
|
+
let fields = [];
|
|
172
|
+
for (let i = 0; i < MYMODEL.keysExcel.length; i++) {
|
|
173
|
+
if (!Util.in_array(MYMODEL.keysExcel[i], Util.nots)) {
|
|
174
|
+
fields.push(MYMODEL.keysExcel[i]);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
const results = await connection.results({
|
|
178
|
+
table:MYMODEL.table,
|
|
179
|
+
where:{
|
|
180
|
+
company_id:res.locals.companyId
|
|
181
|
+
},
|
|
182
|
+
orderBy:["id","desc"], limit:10
|
|
183
|
+
});
|
|
184
|
+
let callback=(result,field)=> {
|
|
185
|
+
return MYMODEL.widgets[field] && MYMODEL.widgets[field].name == 'datepicker' ? Util.dateSql(result[field]) : result[field];
|
|
186
|
+
};
|
|
187
|
+
await zRoute.excel(req, res, MYMODEL, fields, results, callback);
|
|
188
|
+
});
|
|
189
|
+
|
|
190
|
+
router.get('/import',csrfProtection, async (req, res) => {
|
|
191
|
+
const room = res.locals.token;
|
|
192
|
+
res.render(`layouts/${layout}`, {
|
|
193
|
+
room: room,
|
|
194
|
+
titleHeader: `Import / Upload data : <strong><a href="/${MYMODEL.routeName}">${MYMODEL.title}</a></strong>`,
|
|
195
|
+
csrfToken: req.csrfToken(),
|
|
196
|
+
breadcrumb : zForm.breadcrumbImport(MYMODEL.routeName),
|
|
197
|
+
renderBody: `${MYMODEL.routeName}/import.ejs`,
|
|
198
|
+
renderEnd: `${MYMODEL.routeName}/importjs.ejs`
|
|
199
|
+
});
|
|
200
|
+
});
|
|
201
|
+
|
|
202
|
+
|
|
203
|
+
router.post('/import', async(req, res) => {
|
|
204
|
+
res.json(await zRoute.import(req,res,MYMODEL));
|
|
205
|
+
});
|
|
206
|
+
|
|
207
|
+
router.get('/approval/:id', async (req, res) => {
|
|
208
|
+
await zRoute.attributeData(res, MYMODEL);
|
|
209
|
+
const id = req.params.id;
|
|
210
|
+
let data = {};
|
|
211
|
+
let data2 = {};
|
|
212
|
+
let zForms = {};
|
|
213
|
+
let zForms2 = {};
|
|
214
|
+
let result = {};
|
|
215
|
+
try {
|
|
216
|
+
result = await connection.result({table: MYMODEL.table, where: {id: id}});
|
|
217
|
+
if (!result.id) {
|
|
218
|
+
req.session.sessionFlash = Util.flashError(LANGUAGE['data_not_found']);
|
|
219
|
+
return res.redirect('/' + MYMODEL.routeName);
|
|
220
|
+
}
|
|
221
|
+
data=result;
|
|
222
|
+
moduleLib.editor(req, res);
|
|
223
|
+
zForms = await zRoute.viewFormsSync(req, res, MYMODEL, result);
|
|
224
|
+
const contentScript = `$("#submit_draft").on("click", function () {$("#status").val(1);ajaxPost("/zzapproval",$("#form-group").serializeArray(), function (data) {
|
|
225
|
+
if (data.status == 0) {
|
|
226
|
+
toastr.error(data.message, data.title);
|
|
227
|
+
} else {
|
|
228
|
+
toastr.success(data.title, data.message);
|
|
229
|
+
}
|
|
230
|
+
});});
|
|
231
|
+
$("#submit").on("click", function () {
|
|
232
|
+
$('[name="zapprovals[status]"]').val(2);
|
|
233
|
+
ajaxPost("/zzapproval",$("#form-group").serializeArray(), function (data) {
|
|
234
|
+
if (data.status == 0) {
|
|
235
|
+
toastr.error(data.message, data.title);
|
|
236
|
+
} else {
|
|
237
|
+
toastr.success(data.title, data.message);
|
|
238
|
+
location.href = "";
|
|
239
|
+
}
|
|
240
|
+
});
|
|
241
|
+
});
|
|
242
|
+
`;
|
|
243
|
+
await moduleLib.addScript(req, res, contentScript);
|
|
244
|
+
const MODEL_APROVALS = require("./../models/zapprovals");
|
|
245
|
+
const rows = await connection.results({
|
|
246
|
+
table: "zapprovals",
|
|
247
|
+
where: {table: MYMODEL.table, company_id: res.locals.companyId, id_data: id}
|
|
248
|
+
});
|
|
249
|
+
if (rows.length) {
|
|
250
|
+
data2 = rows[0];
|
|
251
|
+
} else {
|
|
252
|
+
let obj = {};
|
|
253
|
+
obj.token = Util.uuid();
|
|
254
|
+
obj.status = 1;
|
|
255
|
+
obj.table = MYMODEL.table;
|
|
256
|
+
obj.company_id = res.locals.companyId;
|
|
257
|
+
obj.id_data = id;
|
|
258
|
+
obj.created_by = res.locals.userId;
|
|
259
|
+
obj.updated_by = res.locals.userId;
|
|
260
|
+
obj.created_at = Util.now();
|
|
261
|
+
let zfields = await connection.result({table: "zfields", where: {table: MYMODEL.table}});
|
|
262
|
+
let jsonApproval = zfields.approval_json || {}
|
|
263
|
+
obj.template = jsonApproval.content || {}
|
|
264
|
+
let title = jsonApproval.title;
|
|
265
|
+
if (title) {
|
|
266
|
+
let titleData = title;
|
|
267
|
+
for (var key in data) {
|
|
268
|
+
titleData = Util.replaceAll(titleData, "{{" + key + "}}", data[key])
|
|
269
|
+
}
|
|
270
|
+
obj.title = titleData
|
|
271
|
+
}
|
|
272
|
+
if (jsonApproval.hasOwnProperty("approvers")) {
|
|
273
|
+
obj.approvers = JSON.stringify(jsonApproval.approvers);
|
|
274
|
+
obj.knowings = JSON.stringify(jsonApproval.knowings);
|
|
275
|
+
obj.type = 1;
|
|
276
|
+
}
|
|
277
|
+
//insert default data
|
|
278
|
+
await connection.insert({table: "zapprovals", data: obj});
|
|
279
|
+
data2 = obj;
|
|
280
|
+
}
|
|
281
|
+
zForms2 = await zRoute.formsFieldSync(req, res, MODEL_APROVALS, data2);
|
|
282
|
+
} catch (err) {
|
|
283
|
+
zDebug(req, res, err);
|
|
284
|
+
res.send("Err");
|
|
285
|
+
}
|
|
286
|
+
res.render(`layouts/${layout}`, {
|
|
287
|
+
zForms: zForms,
|
|
288
|
+
zForms2: zForms2,
|
|
289
|
+
data: result,
|
|
290
|
+
result:result,
|
|
291
|
+
data2: data2,
|
|
292
|
+
Util: Util,
|
|
293
|
+
levels: zRole.myLevel(req, res, MYMODEL.table),
|
|
294
|
+
breadcrumb : zForm.breadcrumbApproval(MYMODEL.routeName, id),
|
|
295
|
+
renderBody: `${MYMODEL.routeName}/approval.ejs`
|
|
296
|
+
});
|
|
297
|
+
});
|
|
298
|
+
|
|
299
|
+
router.get('/preview/:token', async (req, res) => {
|
|
300
|
+
let token = req.params.token;
|
|
301
|
+
let data = {}, data2 = {};
|
|
302
|
+
let template = "";
|
|
303
|
+
let footers = "";
|
|
304
|
+
try {
|
|
305
|
+
let zfields = await connection.result({table: "zfields", where: {table: MYMODEL.table}});
|
|
306
|
+
let jsonApproval = zfields.approval_json || {}
|
|
307
|
+
let mytemplate = jsonApproval.content || {}
|
|
308
|
+
let results = await connection.results({table: "zapprovals", where: {token: token}});
|
|
309
|
+
if (results.length == 0) {
|
|
310
|
+
req.session.sessionFlash = Util.flashError(LANGUAGE['data_not_found']);
|
|
311
|
+
return res.redirect('/' + MYMODEL.routeName);
|
|
312
|
+
}
|
|
313
|
+
if(results[0].status == 1){
|
|
314
|
+
await connection.update({
|
|
315
|
+
table : "zapprovals",
|
|
316
|
+
data: {
|
|
317
|
+
template : mytemplate
|
|
318
|
+
},
|
|
319
|
+
where : {
|
|
320
|
+
token:token
|
|
321
|
+
}
|
|
322
|
+
})
|
|
323
|
+
results = await connection.results({table: "zapprovals", where: {token: token}});
|
|
324
|
+
}
|
|
325
|
+
let MYMODEL2 = require("./../models/zapprovals")
|
|
326
|
+
data = await zRoute.viewTable(req, res, MYMODEL2, results[0], true);
|
|
327
|
+
let row = await connection.result({table: results[0].table, where: {id: results[0].id_data}});
|
|
328
|
+
data2 = await zRoute.viewTable(req, res, MYMODEL, row, true);
|
|
329
|
+
template = data.template;
|
|
330
|
+
let title = data.title || ""
|
|
331
|
+
for (var key in data2) {
|
|
332
|
+
template = Util.replaceAll(template, "{{" + key + "}}", data2[key])
|
|
333
|
+
title = Util.replaceAll(title, "{{" + key + "}}", data2[key])
|
|
334
|
+
}
|
|
335
|
+
data.title = title;
|
|
336
|
+
var details = await connection.results({table: "zapprovals_details", where: {title_id: results[0].id}});
|
|
337
|
+
if (details.length) {
|
|
338
|
+
footers = await zRoute.approversFooter(details);
|
|
339
|
+
}
|
|
340
|
+
} catch (err) {
|
|
341
|
+
zDebug(req, res, err);
|
|
342
|
+
res.send("Err");
|
|
343
|
+
}
|
|
344
|
+
res.render(`layouts/blank`, {
|
|
345
|
+
template: template,
|
|
346
|
+
data: data,
|
|
347
|
+
footers: footers,
|
|
348
|
+
Util: Util,
|
|
349
|
+
details: details,
|
|
350
|
+
renderBody: 'index/zapprovals_preview.ejs'
|
|
351
|
+
});
|
|
352
|
+
});
|
|
353
|
+
|
|
354
|
+
router.post('/grid', access, zRoute.postGrid);
|
|
355
|
+
router.post('/reload', access, zRoute.postGridReload);
|
|
356
|
+
router.post('/chains', access, zRoute.chains);
|
|
357
|
+
router.post('/get_attributes',access, zRoute.getAttributes);
|
|
358
|
+
|
|
359
|
+
module.exports = router;
|
package/lib/zAppRouter.js
CHANGED
|
@@ -93,6 +93,7 @@ router.get("/profile", csrfProtection, access, async (req, res) => {
|
|
|
93
93
|
let verify_signed = result.verify_signed
|
|
94
94
|
? "/uploads/zuser/" + result.verify_signed
|
|
95
95
|
: "/img/user.png";
|
|
96
|
+
const layout = res.locals.layout || "finsrecipe";
|
|
96
97
|
res.render("layouts/" + layout, {
|
|
97
98
|
menu: { menu: "profile" },
|
|
98
99
|
data: result,
|
|
@@ -574,8 +575,9 @@ router.get(
|
|
|
574
575
|
|
|
575
576
|
router.get("/no-access", async (req, res) => {
|
|
576
577
|
let myview = "fronts";
|
|
577
|
-
if (req.session.user) {
|
|
578
|
-
|
|
578
|
+
if (req.session && req.session.user) {
|
|
579
|
+
// backend layout mengikuti preferensi user (res.locals.layout)
|
|
580
|
+
myview = res.locals.layout || "main";
|
|
579
581
|
}
|
|
580
582
|
res.render("layouts/" + myview, {
|
|
581
583
|
data: { table: "error" },
|
|
@@ -623,27 +625,24 @@ router.get("/session/:id", access, async (req, res) => {
|
|
|
623
625
|
res.redirect(backURL);
|
|
624
626
|
});
|
|
625
627
|
|
|
626
|
-
//
|
|
628
|
+
// Ubah layout backend (per user / personalized: tiap user punya preferensi sendiri)
|
|
627
629
|
router.get("/layout_changes/:layout", access, async (req, res) => {
|
|
628
|
-
const selectedLayout = req.params.layout;
|
|
630
|
+
const selectedLayout = String(req.params.layout || "").replace(/\.ejs$/i, "");
|
|
629
631
|
const backURL = req.header("Referer") || "/";
|
|
630
632
|
try {
|
|
631
|
-
// persist user preference
|
|
632
|
-
await connection.update({
|
|
633
|
-
table: "zuser",
|
|
634
|
-
data: { layout: selectedLayout },
|
|
635
|
-
where: { id: res.locals.userId },
|
|
636
|
-
});
|
|
637
|
-
// update session + locals for next requests
|
|
638
633
|
if (req.session && req.session.user) {
|
|
639
634
|
req.session.user.layout = selectedLayout;
|
|
640
635
|
}
|
|
641
636
|
res.locals.layout = selectedLayout;
|
|
642
|
-
global.layout = selectedLayout;
|
|
643
637
|
} catch (err) {
|
|
644
638
|
debug(req, res, err);
|
|
645
639
|
}
|
|
646
|
-
|
|
640
|
+
|
|
641
|
+
// pastikan perubahan session tersimpan sebelum redirect (tergantung session store)
|
|
642
|
+
if (req.session && typeof req.session.save === "function") {
|
|
643
|
+
return req.session.save(() => res.redirect(backURL));
|
|
644
|
+
}
|
|
645
|
+
return res.redirect(backURL);
|
|
647
646
|
});
|
|
648
647
|
|
|
649
648
|
//RESTART
|
|
@@ -671,6 +670,7 @@ router.get("/error", async (err, req, res, next) => {
|
|
|
671
670
|
// render the error page
|
|
672
671
|
res.status(err.status || 500);
|
|
673
672
|
debug(req, res, err);
|
|
673
|
+
const layout = res.locals.layout || "finsrecipe";
|
|
674
674
|
res.render("layouts/" + layout, {
|
|
675
675
|
renderBody: "index/error.ejs",
|
|
676
676
|
});
|
package/lib/zRoleRouter.js
CHANGED
|
@@ -65,6 +65,7 @@ router.get('/', csrfProtection, async function (req, res, next) {
|
|
|
65
65
|
const endBody = ejs.render(js, datas)
|
|
66
66
|
datas.bodyHTML = bodyHTML
|
|
67
67
|
moduleLib.addModule(req, res, endBody)
|
|
68
|
+
const layout = res.locals.layout || 'finsrecipe'
|
|
68
69
|
res.render('layouts/' + layout, datas)
|
|
69
70
|
})
|
|
70
71
|
|
package/lib/zapp.js
CHANGED
|
@@ -1,93 +1,121 @@
|
|
|
1
1
|
const myCache = require("./cache");
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
if (
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
2
|
+
const Util = require('./Util')
|
|
3
|
+
const zRole = require('./zRole')
|
|
4
|
+
module.exports = (req, res, next) => {
|
|
5
|
+
res.locals.BACKEND_LAYOUTS = myCache.get("BACKEND_LAYOUTS");
|
|
6
|
+
res.locals.renderHead = "";
|
|
7
|
+
res.locals.renderBody = "";
|
|
8
|
+
res.locals.renderEnd = "";
|
|
9
|
+
res.locals.headHTML = '';
|
|
10
|
+
res.locals.bodyHTML = '';
|
|
11
|
+
res.locals.endHTML = '';
|
|
12
|
+
res.locals.titleApp = process.env.APP_TITLE;
|
|
13
|
+
res.locals.descriptionApp = process.env.APP_DESCRIPTION;
|
|
14
|
+
res.locals.moduleHead = "";
|
|
15
|
+
res.locals.relationsVariable = "";
|
|
16
|
+
res.locals.moduleEnd = "";
|
|
17
|
+
res.locals.menuApp = "home";
|
|
18
|
+
res.locals.routeName = "index";
|
|
19
|
+
res.locals.userId = -1;
|
|
20
|
+
res.locals.csrfToken = "";
|
|
21
|
+
res.locals.roleId = 0;
|
|
22
|
+
res.locals.token = "guest";
|
|
23
|
+
res.locals.companyId = 0;
|
|
24
|
+
res.locals.userId = 0;
|
|
25
|
+
res.locals.userAvatar = "/img/user.png";
|
|
26
|
+
res.locals.zuser = {
|
|
27
|
+
fullname: 'test'
|
|
28
|
+
};
|
|
29
|
+
res.locals.frameworkcss = "bootstrap5";
|
|
30
|
+
res.locals.startup = 0;
|
|
31
|
+
global.frameworkcss = "bootstrap5";
|
|
32
|
+
global.LANGUAGE = require('./languages/lang_en');
|
|
33
|
+
res.locals.socketUrl = process.env.APP_URL;
|
|
34
|
+
res.locals.zcompanies = [];
|
|
35
|
+
res.locals.backend_layouts = [];
|
|
36
|
+
res.locals.isLogin = false;
|
|
37
|
+
res.locals.objectStores = {};
|
|
38
|
+
if (req.session) {
|
|
39
|
+
let reqSession = req.session;
|
|
40
|
+
if (reqSession.hasOwnProperty('user')) {
|
|
41
|
+
const tUser = req.session.user;
|
|
42
|
+
if (tUser && Object.prototype.hasOwnProperty.call(tUser, "id")) {
|
|
43
|
+
res.locals.isLogin = true;
|
|
44
|
+
res.locals.token = tUser.token;
|
|
45
|
+
res.locals.roleId = tUser.role_id;
|
|
46
|
+
res.locals.isLogin = true;
|
|
47
|
+
res.locals.zuser = tUser;
|
|
48
|
+
res.locals.userId = tUser.id;
|
|
49
|
+
res.locals.companyId = tUser.company.id;
|
|
50
|
+
res.locals.userAvatar = tUser.image ? tUser.image.indexOf("http") > -1 ? tUser.image : "/uploads/zuser/" + tUser.image : "/img/user.png";
|
|
51
|
+
res.locals.zcompanies = tUser.companies;
|
|
52
|
+
res.locals.zcompany = tUser.company;
|
|
53
|
+
if (tUser.language) {
|
|
54
|
+
let objLanguage = {
|
|
55
|
+
1: "lang_en",
|
|
56
|
+
2: "lang_id",
|
|
57
|
+
3: "lang_jp",
|
|
58
|
+
4: "lang_fr"
|
|
59
|
+
};
|
|
60
|
+
global.LANGUAGE = require(`./languages/${objLanguage[tUser.language]}`);
|
|
61
|
+
}
|
|
62
|
+
// Layout per user (personalized): dari preferensi user di session
|
|
63
|
+
if (tUser.layout) {
|
|
64
|
+
res.locals.layout = String(tUser.layout).replace(/\.ejs$/i, "");
|
|
65
|
+
}
|
|
66
|
+
}
|
|
59
67
|
}
|
|
60
|
-
if(tUser.layout){
|
|
61
|
-
res.locals.layout = tUser.layout;
|
|
62
|
-
//global.layout = tUser.layout;
|
|
63
|
-
}
|
|
64
|
-
console.log(global.layout)
|
|
65
|
-
}
|
|
66
68
|
}
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
69
|
+
// Default layout jika user belum pilih; tiap user bisa punya layout berbeda
|
|
70
|
+
res.locals.layout = res.locals.layout || "admin";
|
|
71
|
+
global.COMPANY_ID = res.locals.companyId;
|
|
72
|
+
global.USER_ID = res.locals.userId;
|
|
73
|
+
res.locals.LANGUAGE = global.LANGUAGE;
|
|
71
74
|
|
|
72
|
-
|
|
75
|
+
const path = req.route && req.route.path ? req.route.path : req.path;
|
|
76
|
+
const MYMODELS = myCache.get("MYMODELS");
|
|
77
|
+
// Mapping manual per route
|
|
78
|
+
let map = {
|
|
79
|
+
'/dashboard': {title: 'Dashboard', subtitle: 'Systems'},
|
|
80
|
+
'/users': {title: 'Users', subtitle: 'List'},
|
|
81
|
+
'/users/new': {title: 'Users', subtitle: 'Create'},
|
|
82
|
+
};
|
|
83
|
+
for (let key in MYMODELS) {
|
|
84
|
+
map[`/${key}`] = {title: MYMODELS[key].name, subtitle: 'List'}
|
|
85
|
+
map[`/${key}/create`] = {title: MYMODELS[key].name, subtitle: 'Create'}
|
|
86
|
+
map[`/${key}/update`] = {title: MYMODELS[key].name, subtitle: 'Update'}
|
|
87
|
+
map[`/${key}/view`] = {title: MYMODELS[key].name, subtitle: 'View'}
|
|
88
|
+
}
|
|
73
89
|
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
'/dashboard': { title: 'Dashboard', subtitle: 'Systems' },
|
|
78
|
-
'/users': { title: 'Users', subtitle: 'List' },
|
|
79
|
-
'/users/new': { title: 'Users', subtitle: 'Create' },
|
|
80
|
-
};
|
|
81
|
-
for(let key in MYMODELS) {
|
|
82
|
-
map[`/${key}`] = {title : MYMODELS[key].name, subtitle:'List'}
|
|
83
|
-
map[`/${key}/create`] = {title : MYMODELS[key].name, subtitle:'Create'}
|
|
84
|
-
map[`/${key}/update`] = {title : MYMODELS[key].name, subtitle:'Update'}
|
|
85
|
-
map[`/${key}/view`] = {title : MYMODELS[key].name, subtitle:'View'}
|
|
86
|
-
}
|
|
90
|
+
const info = map[path] || {};
|
|
91
|
+
res.locals.pagetitle = info.title || 'Dashboard';
|
|
92
|
+
res.locals.pagesubtitle = info.subtitle || '';
|
|
87
93
|
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
94
|
+
const explode = req.path.split("/");
|
|
95
|
+
const route = explode[1];
|
|
96
|
+
let action = "index";
|
|
97
|
+
res.locals.menuApp = Util.capitalizeAfterSpace(route);
|
|
98
|
+
res.locals.routeName = route;
|
|
99
|
+
if (explode.length > 2) {
|
|
100
|
+
action = explode[2] || "index";
|
|
101
|
+
}
|
|
102
|
+
res.locals.titleApp = `${process.env.APP_TITLE} - ${route} ${action}`;
|
|
103
|
+
if (global.hasCacheLogo == 0) {
|
|
104
|
+
try {
|
|
105
|
+
global.hasCacheLogo = 1;
|
|
106
|
+
} catch (e) {
|
|
107
|
+
console.log(e);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
// define role for route base on session or not
|
|
111
|
+
//define routes at zRole
|
|
112
|
+
if (zRole.routes.indexOf(route) > -1) {
|
|
113
|
+
req.route = route;
|
|
114
|
+
req.action = action;
|
|
115
|
+
zRole.access(req, res, next);
|
|
116
|
+
} else {
|
|
117
|
+
next();
|
|
118
|
+
}
|
|
91
119
|
|
|
92
|
-
|
|
120
|
+
//next();
|
|
93
121
|
}
|