@saltcorn/server 0.7.3-beta.1 → 0.7.3-beta.6
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/app.js +5 -1
- package/auth/routes.js +37 -10
- package/locales/en.json +922 -916
- package/markup/admin.js +5 -1
- package/package.json +8 -8
- package/public/gridedit.js +6 -0
- package/public/jquery-menu-editor.min.js +5 -2
- package/public/saltcorn-common.js +78 -2
- package/public/saltcorn.css +5 -0
- package/public/saltcorn.js +19 -38
- package/routes/admin.js +386 -2
- package/routes/fields.js +3 -0
- package/routes/files.js +5 -3
- package/routes/homepage.js +7 -7
- package/routes/menu.js +13 -1
- package/routes/pageedit.js +1 -0
- package/routes/plugins.js +1 -0
- package/routes/tables.js +7 -6
- package/routes/viewedit.js +5 -0
- package/serve.js +1 -1
- package/tests/tenant.test.js +6 -0
package/markup/admin.js
CHANGED
|
@@ -124,6 +124,7 @@ const send_settings_page = ({
|
|
|
124
124
|
: [
|
|
125
125
|
{
|
|
126
126
|
type: "card",
|
|
127
|
+
class: "mt-0",
|
|
127
128
|
contents: div(
|
|
128
129
|
{ class: "d-flex" },
|
|
129
130
|
ul(
|
|
@@ -271,7 +272,7 @@ const send_events_page = (args) => {
|
|
|
271
272
|
* @returns {void}
|
|
272
273
|
*/
|
|
273
274
|
const send_admin_page = (args) => {
|
|
274
|
-
|
|
275
|
+
const isRoot = db.getTenantSchema() === db.connectObj.default_schema;
|
|
275
276
|
return send_settings_page({
|
|
276
277
|
main_section: "About application",
|
|
277
278
|
main_section_href: "/admin",
|
|
@@ -280,6 +281,9 @@ const send_admin_page = (args) => {
|
|
|
280
281
|
{ text: "Backup", href: "/admin/backup" },
|
|
281
282
|
{ text: "Email", href: "/admin/email" },
|
|
282
283
|
{ text: "System", href: "/admin/system" },
|
|
284
|
+
...(isRoot
|
|
285
|
+
? [{ text: "Mobile app", href: "/admin/build-mobile-app" }]
|
|
286
|
+
: []),
|
|
283
287
|
],
|
|
284
288
|
...args,
|
|
285
289
|
});
|
package/package.json
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@saltcorn/server",
|
|
3
|
-
"version": "0.7.3-beta.
|
|
3
|
+
"version": "0.7.3-beta.6",
|
|
4
4
|
"description": "Server app for Saltcorn, open-source no-code platform",
|
|
5
5
|
"homepage": "https://saltcorn.com",
|
|
6
6
|
"main": "index.js",
|
|
7
7
|
"license": "MIT",
|
|
8
8
|
"dependencies": {
|
|
9
|
-
"@saltcorn/base-plugin": "0.7.3-beta.
|
|
10
|
-
"@saltcorn/builder": "0.7.3-beta.
|
|
11
|
-
"@saltcorn/data": "0.7.3-beta.
|
|
12
|
-
"@saltcorn/admin-models": "0.7.3-beta.
|
|
13
|
-
"@saltcorn/markup": "0.7.3-beta.
|
|
14
|
-
"@saltcorn/sbadmin2": "0.7.3-beta.
|
|
9
|
+
"@saltcorn/base-plugin": "0.7.3-beta.6",
|
|
10
|
+
"@saltcorn/builder": "0.7.3-beta.6",
|
|
11
|
+
"@saltcorn/data": "0.7.3-beta.6",
|
|
12
|
+
"@saltcorn/admin-models": "0.7.3-beta.6",
|
|
13
|
+
"@saltcorn/markup": "0.7.3-beta.6",
|
|
14
|
+
"@saltcorn/sbadmin2": "0.7.3-beta.6",
|
|
15
15
|
"@socket.io/cluster-adapter": "^0.1.0",
|
|
16
16
|
"@socket.io/sticky": "^1.0.1",
|
|
17
17
|
"aws-sdk": "^2.1037.0",
|
|
@@ -48,7 +48,7 @@
|
|
|
48
48
|
"pg": "^8.2.1",
|
|
49
49
|
"pluralize": "^8.0.0",
|
|
50
50
|
"qrcode": "1.5.0",
|
|
51
|
-
"resize-with-sharp-or-jimp": "0.1.
|
|
51
|
+
"resize-with-sharp-or-jimp": "0.1.5",
|
|
52
52
|
"socket.io": "4.2.0",
|
|
53
53
|
"thirty-two": "1.0.2",
|
|
54
54
|
"tmp-promise": "^3.0.2",
|
package/public/gridedit.js
CHANGED
|
@@ -76,6 +76,8 @@ function isoDateTimeFormatter(cell, formatterParams, onRendered) {
|
|
|
76
76
|
function isoDateFormatter(cell, formatterParams, onRendered) {
|
|
77
77
|
const val = cell.getValue();
|
|
78
78
|
if (!val) return "";
|
|
79
|
+
if (formatterParams && formatterParams.format)
|
|
80
|
+
return moment(val).format(formatterParams.format);
|
|
79
81
|
|
|
80
82
|
return new Date(val).toLocaleDateString(window.detected_locale || "en");
|
|
81
83
|
}
|
|
@@ -144,6 +146,10 @@ function add_tabulator_row() {
|
|
|
144
146
|
}
|
|
145
147
|
|
|
146
148
|
function delete_tabulator_row(e, cell) {
|
|
149
|
+
const def = cell.getColumn().getDefinition();
|
|
150
|
+
if (def && def.formatterParams && def.formatterParams.confirm) {
|
|
151
|
+
if (!confirm("Are you sure you want to delete this row?")) return;
|
|
152
|
+
}
|
|
147
153
|
const row = cell.getRow().getData();
|
|
148
154
|
if (!row.id) {
|
|
149
155
|
cell.getRow().delete();
|
|
@@ -117,7 +117,7 @@ function MenuEditor(e, t) {
|
|
|
117
117
|
(n.prev("div").children(".sortableListsOpener").first().remove(),
|
|
118
118
|
n.remove()),
|
|
119
119
|
MenuEditor.updateButtons(s);
|
|
120
|
-
|
|
120
|
+
l.onUpdate();
|
|
121
121
|
}
|
|
122
122
|
}),
|
|
123
123
|
$(document).on("click", ".btnEdit", function (e) {
|
|
@@ -132,6 +132,9 @@ function MenuEditor(e, t) {
|
|
|
132
132
|
"checked",
|
|
133
133
|
true
|
|
134
134
|
);
|
|
135
|
+
} else if (el.prop("tagName") == "SELECT") {
|
|
136
|
+
el.val(t);
|
|
137
|
+
el.attr("data-selected", t);
|
|
135
138
|
} else el.val(t);
|
|
136
139
|
}),
|
|
137
140
|
i.find(".item-menu").first().focus(),
|
|
@@ -164,7 +167,7 @@ function MenuEditor(e, t) {
|
|
|
164
167
|
t.remove()),
|
|
165
168
|
MenuEditor.updateButtons(s),
|
|
166
169
|
s.updateLevels();
|
|
167
|
-
|
|
170
|
+
l.onUpdate();
|
|
168
171
|
}),
|
|
169
172
|
s.on("click", ".btnIn", function (e) {
|
|
170
173
|
e.preventDefault();
|
|
@@ -63,8 +63,8 @@ function apply_showif() {
|
|
|
63
63
|
.val();
|
|
64
64
|
|
|
65
65
|
var options = data[1][val];
|
|
66
|
-
var current = e.attr("data-selected");
|
|
67
|
-
//console.log({
|
|
66
|
+
var current = e.attr("data-selected") || e.val();
|
|
67
|
+
//console.log({ field: e.attr("name"), target: data[0], val, current });
|
|
68
68
|
e.empty();
|
|
69
69
|
(options || []).forEach((o) => {
|
|
70
70
|
if (
|
|
@@ -87,6 +87,39 @@ function apply_showif() {
|
|
|
87
87
|
e.attr("data-selected", ec.target.value);
|
|
88
88
|
});
|
|
89
89
|
});
|
|
90
|
+
$("[data-fetch-options]").each(function (ix, element) {
|
|
91
|
+
const e = $(element);
|
|
92
|
+
const rec = get_form_record(e);
|
|
93
|
+
const dynwhere = JSON.parse(
|
|
94
|
+
decodeURIComponent(e.attr("data-fetch-options"))
|
|
95
|
+
);
|
|
96
|
+
//console.log(dynwhere);
|
|
97
|
+
const qs = Object.entries(dynwhere.whereParsed)
|
|
98
|
+
.map(([k, v]) => `${k}=${v[0] === "$" ? rec[v.substring(1)] : v}`)
|
|
99
|
+
.join("&");
|
|
100
|
+
var current = e.attr("data-selected");
|
|
101
|
+
e.change(function (ec) {
|
|
102
|
+
e.attr("data-selected", ec.target.value);
|
|
103
|
+
});
|
|
104
|
+
$.ajax(`/api/${dynwhere.table}?${qs}`).then((resp) => {
|
|
105
|
+
if (resp.success) {
|
|
106
|
+
e.empty();
|
|
107
|
+
if (!dynwhere.required) e.append($(`<option></option>`));
|
|
108
|
+
resp.success.forEach((r) => {
|
|
109
|
+
e.append(
|
|
110
|
+
$(
|
|
111
|
+
`<option ${
|
|
112
|
+
`${current}` === `${r[dynwhere.refname]}` ? "selected" : ""
|
|
113
|
+
} value="${r[dynwhere.refname]}">${
|
|
114
|
+
r[dynwhere.summary_field]
|
|
115
|
+
}</option>`
|
|
116
|
+
)
|
|
117
|
+
);
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
});
|
|
121
|
+
});
|
|
122
|
+
|
|
90
123
|
$("[data-source-url]").each(function (ix, element) {
|
|
91
124
|
const e = $(element);
|
|
92
125
|
const rec = get_form_record(e);
|
|
@@ -583,6 +616,49 @@ function unique_field_from_rows(
|
|
|
583
616
|
}
|
|
584
617
|
}
|
|
585
618
|
|
|
619
|
+
function room_older(viewname, room_id, btn) {
|
|
620
|
+
view_post(
|
|
621
|
+
viewname,
|
|
622
|
+
"fetch_older_msg",
|
|
623
|
+
{ room_id, lt_msg_id: +$(btn).attr("data-lt-msg-id") },
|
|
624
|
+
(res) => {
|
|
625
|
+
if (res.prepend) $(`.msglist-${room_id}`).prepend(res.prepend);
|
|
626
|
+
if (res.new_fetch_older_lt)
|
|
627
|
+
$(btn).attr("data-lt-msg-id", res.new_fetch_older_lt);
|
|
628
|
+
if (res.remove_fetch_older) $(btn).remove();
|
|
629
|
+
}
|
|
630
|
+
);
|
|
631
|
+
}
|
|
632
|
+
|
|
633
|
+
function init_room(viewname, room_id) {
|
|
634
|
+
const socket = parent?.config?.server_path
|
|
635
|
+
? io(parent.config.server_path, {
|
|
636
|
+
query: `jwt=${localStorage.getItem("auth_jwt")}`,
|
|
637
|
+
transports: ["websocket"],
|
|
638
|
+
})
|
|
639
|
+
: io({ transports: ["websocket"] });
|
|
640
|
+
|
|
641
|
+
socket.emit("join_room", [viewname, room_id]);
|
|
642
|
+
socket.on("message", (msg) => {
|
|
643
|
+
if (msg.not_for_user_id) {
|
|
644
|
+
const my_user_id = $(`.msglist-${room_id}`).attr("data-user-id");
|
|
645
|
+
if (+my_user_id === +msg.not_for_user_id) return;
|
|
646
|
+
}
|
|
647
|
+
if (msg.append) $(`.msglist-${room_id}`).append(msg.append);
|
|
648
|
+
if (msg.pls_ack_msg_id)
|
|
649
|
+
view_post(viewname, "ack_read", { room_id, id: msg.pls_ack_msg_id });
|
|
650
|
+
});
|
|
651
|
+
|
|
652
|
+
$(`form.room-${room_id}`).submit((e) => {
|
|
653
|
+
e.preventDefault();
|
|
654
|
+
var form_data = $(`form.room-${room_id}`).serialize();
|
|
655
|
+
view_post(viewname, "submit_msg_ajax", form_data, (vpres) => {
|
|
656
|
+
if (vpres.append) $(`.msglist-${room_id}`).append(vpres.append);
|
|
657
|
+
$(`form.room-${room_id}`).trigger("reset");
|
|
658
|
+
});
|
|
659
|
+
});
|
|
660
|
+
}
|
|
661
|
+
|
|
586
662
|
function cancel_form(form) {
|
|
587
663
|
if (!form) return;
|
|
588
664
|
$(form).append(`<input type="hidden" name="_cancel" value="on">`);
|
package/public/saltcorn.css
CHANGED
|
@@ -298,3 +298,8 @@ section.range-slider input[type="range"]::-moz-focus-outer {
|
|
|
298
298
|
.btn-xs {
|
|
299
299
|
padding: 0.1rem 0.4rem !important;
|
|
300
300
|
}
|
|
301
|
+
|
|
302
|
+
table.table-inner-grid, table.table-inner-grid th, table.table-inner-grid td {
|
|
303
|
+
border: 1px solid black;
|
|
304
|
+
border-collapse: collapse;
|
|
305
|
+
}
|
package/public/saltcorn.js
CHANGED
|
@@ -169,7 +169,7 @@ function close_saltcorn_modal() {
|
|
|
169
169
|
if (modal) modal.dispose();
|
|
170
170
|
}
|
|
171
171
|
|
|
172
|
-
function
|
|
172
|
+
function ensure_modal_exists_and_closed() {
|
|
173
173
|
if ($("#scmodal").length === 0) {
|
|
174
174
|
$("body").append(`<div id="scmodal", class="modal">
|
|
175
175
|
<div class="modal-dialog">
|
|
@@ -188,6 +188,19 @@ function ajax_modal(url, opts = {}) {
|
|
|
188
188
|
} else if ($("#scmodal").hasClass("show")) {
|
|
189
189
|
close_saltcorn_modal();
|
|
190
190
|
}
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
function expand_thumbnail(img_id, filename) {
|
|
194
|
+
ensure_modal_exists_and_closed();
|
|
195
|
+
$("#scmodal .modal-body").html(
|
|
196
|
+
`<img src="/files/serve/${img_id}" style="width: 100%">`
|
|
197
|
+
);
|
|
198
|
+
$("#scmodal .modal-title").html(decodeURIComponent(filename));
|
|
199
|
+
new bootstrap.Modal($("#scmodal")).show();
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
function ajax_modal(url, opts = {}) {
|
|
203
|
+
ensure_modal_exists_and_closed();
|
|
191
204
|
if (opts.submitReload === false) $("#scmodal").addClass("no-submit-reload");
|
|
192
205
|
else $("#scmodal").removeClass("no-submit-reload");
|
|
193
206
|
$.ajax(url, {
|
|
@@ -296,7 +309,11 @@ function ajax_post(url, args) {
|
|
|
296
309
|
"CSRF-Token": _sc_globalCsrf,
|
|
297
310
|
},
|
|
298
311
|
...(args || {}),
|
|
299
|
-
})
|
|
312
|
+
})
|
|
313
|
+
.done(ajax_done)
|
|
314
|
+
.fail((e) =>
|
|
315
|
+
ajax_done(e.responseJSON || { error: "Unknown error: " + e.responseText })
|
|
316
|
+
);
|
|
300
317
|
}
|
|
301
318
|
function ajax_post_btn(e, reload_on_done, reload_delay) {
|
|
302
319
|
var form = $(e).closest("form");
|
|
@@ -366,42 +383,6 @@ function test_formula(tablename, stored) {
|
|
|
366
383
|
});
|
|
367
384
|
}
|
|
368
385
|
|
|
369
|
-
function init_room(viewname, room_id) {
|
|
370
|
-
const socket = io({ transports: ["websocket"] });
|
|
371
|
-
socket.emit("join_room", [viewname, room_id]);
|
|
372
|
-
socket.on("message", (msg) => {
|
|
373
|
-
if (msg.not_for_user_id) {
|
|
374
|
-
const my_user_id = $(`.msglist-${room_id}`).attr("data-user-id");
|
|
375
|
-
if (+my_user_id === +msg.not_for_user_id) return;
|
|
376
|
-
}
|
|
377
|
-
if (msg.append) $(`.msglist-${room_id}`).append(msg.append);
|
|
378
|
-
if (msg.pls_ack_msg_id)
|
|
379
|
-
view_post(viewname, "ack_read", { room_id, id: msg.pls_ack_msg_id });
|
|
380
|
-
});
|
|
381
|
-
|
|
382
|
-
$(`form.room-${room_id}`).submit((e) => {
|
|
383
|
-
e.preventDefault();
|
|
384
|
-
var form_data = $(`form.room-${room_id}`).serialize();
|
|
385
|
-
view_post(viewname, "submit_msg_ajax", form_data, (vpres) => {
|
|
386
|
-
if (vpres.append) $(`.msglist-${room_id}`).append(vpres.append);
|
|
387
|
-
$(`form.room-${room_id}`).trigger("reset");
|
|
388
|
-
});
|
|
389
|
-
});
|
|
390
|
-
}
|
|
391
|
-
function room_older(viewname, room_id, btn) {
|
|
392
|
-
view_post(
|
|
393
|
-
viewname,
|
|
394
|
-
"fetch_older_msg",
|
|
395
|
-
{ room_id, lt_msg_id: +$(btn).attr("data-lt-msg-id") },
|
|
396
|
-
(res) => {
|
|
397
|
-
if (res.prepend) $(`.msglist-${room_id}`).prepend(res.prepend);
|
|
398
|
-
if (res.new_fetch_older_lt)
|
|
399
|
-
$(btn).attr("data-lt-msg-id", res.new_fetch_older_lt);
|
|
400
|
-
if (res.remove_fetch_older) $(btn).remove();
|
|
401
|
-
}
|
|
402
|
-
);
|
|
403
|
-
}
|
|
404
|
-
|
|
405
386
|
async function fill_formula_btn_click(btn, k) {
|
|
406
387
|
const formula = decodeURIComponent($(btn).attr("data-formula"));
|
|
407
388
|
const free_vars = JSON.parse(
|