adding different layouts for testing
This commit is contained in:
@@ -12,7 +12,7 @@ import cfg from "../config.mjs";
|
||||
import security from "../security.mjs";
|
||||
import crypto from "crypto";
|
||||
import path from "path";
|
||||
import { getManualApproval, setManualApproval, getMinTags, setMinTags, getRegistrationOpen, setRegistrationOpen, getTrustedUploads, setTrustedUploads, getEnablePdf, setEnablePdf, getLogUserIps, setLogUserIps, getHashUserIps, setHashUserIps, getEnableCleanup, setEnableCleanup, getCleanupStartDate, setCleanupStartDate, getCleanupEndDate, setCleanupEndDate, getShitpostMode } from "../settings.mjs";
|
||||
import { getManualApproval, setManualApproval, getMinTags, setMinTags, getRegistrationOpen, setRegistrationOpen, getTrustedUploads, setTrustedUploads, getEnablePdf, setEnablePdf, getLogUserIps, setLogUserIps, getHashUserIps, setHashUserIps, getEnableCleanup, setEnableCleanup, getCleanupStartDate, setCleanupStartDate, getCleanupEndDate, setCleanupEndDate, getShitpostMode, getDefaultFeedLayout, setDefaultFeedLayout } from "../settings.mjs";
|
||||
|
||||
export default (router, tpl) => {
|
||||
router.get(/^\/login(\/)?$/, async (req, res) => {
|
||||
@@ -287,6 +287,7 @@ export default (router, tpl) => {
|
||||
enable_cleanup: getEnableCleanup(),
|
||||
shitpost_mode: getShitpostMode(),
|
||||
enable_cleanup_config: cfg.websrv.enable_cleanup !== false,
|
||||
default_feed_layout: getDefaultFeedLayout(),
|
||||
tmp: null
|
||||
}, req)
|
||||
});
|
||||
@@ -618,6 +619,8 @@ export default (router, tpl) => {
|
||||
const registration_open = req.post.registration_open === 'on' ? 'true' : 'false';
|
||||
const min_tags = isNaN(parseInt(req.post.min_tags)) ? 3 : Math.max(0, parseInt(req.post.min_tags));
|
||||
const trusted_uploads = Math.max(0, parseInt(req.post.trusted_uploads) ?? 3);
|
||||
const raw_feed_layout = parseInt(req.post.default_feed_layout, 10);
|
||||
const default_feed_layout = (!isNaN(raw_feed_layout) && raw_feed_layout >= 0 && raw_feed_layout <= 3) ? raw_feed_layout : getDefaultFeedLayout();
|
||||
|
||||
await db`INSERT INTO site_settings (key, value) VALUES ('manual_approval', ${manual_approval}) ON CONFLICT (key) DO UPDATE SET value = EXCLUDED.value`;
|
||||
|
||||
@@ -626,13 +629,14 @@ export default (router, tpl) => {
|
||||
setRegistrationOpen(registration_open === 'true');
|
||||
}
|
||||
|
||||
|
||||
await db`INSERT INTO site_settings (key, value) VALUES ('min_tags', ${min_tags.toString()}) ON CONFLICT (key) DO UPDATE SET value = EXCLUDED.value`;
|
||||
await db`INSERT INTO site_settings (key, value) VALUES ('trusted_uploads', ${trusted_uploads.toString()}) ON CONFLICT (key) DO UPDATE SET value = EXCLUDED.value`;
|
||||
await db`INSERT INTO site_settings (key, value) VALUES ('default_feed_layout', ${default_feed_layout.toString()}) ON CONFLICT (key) DO UPDATE SET value = EXCLUDED.value`;
|
||||
|
||||
setManualApproval(manual_approval === 'true');
|
||||
setMinTags(min_tags);
|
||||
setTrustedUploads(trusted_uploads);
|
||||
setDefaultFeedLayout(default_feed_layout);
|
||||
|
||||
if (req.headers['x-requested-with'] === 'XMLHttpRequest') {
|
||||
res.setHeader('Content-Type', 'application/json');
|
||||
@@ -642,7 +646,8 @@ export default (router, tpl) => {
|
||||
manual_approval: getManualApproval(),
|
||||
registration_open: getRegistrationOpen(),
|
||||
min_tags: getMinTags(),
|
||||
trusted_uploads: getTrustedUploads()
|
||||
trusted_uploads: getTrustedUploads(),
|
||||
default_feed_layout: getDefaultFeedLayout()
|
||||
})
|
||||
});
|
||||
}
|
||||
|
||||
@@ -295,19 +295,34 @@ export default router => {
|
||||
}
|
||||
});
|
||||
|
||||
// Update New Layout visibility preference
|
||||
// Update feed layout preference (0=grid, 1=modern, 2=feed/instagram, 3=youtube)
|
||||
group.put(/\/layout/, lib.loggedin, async (req, res) => {
|
||||
const use_new_layout = req.post.use_new_layout === true || req.post.use_new_layout === 'true';
|
||||
const raw = req.post.feed_layout !== undefined ? req.post.feed_layout : req.post.use_new_layout;
|
||||
let feed_layout;
|
||||
|
||||
// Backward compat: if old boolean use_new_layout was sent, map to int
|
||||
if (req.post.feed_layout === undefined && req.post.use_new_layout !== undefined) {
|
||||
feed_layout = (req.post.use_new_layout === true || req.post.use_new_layout === 'true') ? 1 : 0;
|
||||
} else {
|
||||
feed_layout = parseInt(raw, 10);
|
||||
}
|
||||
|
||||
if (isNaN(feed_layout) || feed_layout < 0 || feed_layout > 3) {
|
||||
return res.json({ success: false, msg: 'Invalid layout value: must be 0–3' }, 400);
|
||||
}
|
||||
|
||||
try {
|
||||
await db`
|
||||
update user_options
|
||||
set use_new_layout = ${use_new_layout}
|
||||
set feed_layout = ${feed_layout},
|
||||
use_new_layout = ${feed_layout === 1}
|
||||
where user_id = ${+req.session.id}
|
||||
`;
|
||||
// Sync session immediately
|
||||
if (req.session) req.session.use_new_layout = use_new_layout;
|
||||
return res.json({ success: true, use_new_layout }, 200);
|
||||
if (req.session) {
|
||||
req.session.feed_layout = feed_layout;
|
||||
req.session.use_new_layout = feed_layout === 1;
|
||||
}
|
||||
return res.json({ success: true, feed_layout }, 200);
|
||||
} catch (e) {
|
||||
console.error('Update Layout pref error:', e);
|
||||
return res.json({ success: false, msg: 'Error updating preference' }, 500);
|
||||
|
||||
@@ -2,6 +2,7 @@ import cfg from "../config.mjs";
|
||||
import db from "../sql.mjs";
|
||||
import lib from "../lib.mjs";
|
||||
import f0cklib from "../routeinc/f0cklib.mjs";
|
||||
import { getDefaultFeedLayout } from "../settings.mjs";
|
||||
|
||||
const auth = async (req, res, next) => {
|
||||
if (!req.session)
|
||||
@@ -320,6 +321,15 @@ export default (router, tpl) => {
|
||||
// Only inject session for authenticated users to avoid showing member UI to guests
|
||||
data.session = (req.session && req.session.user) ? { ...req.session } : false;
|
||||
|
||||
// Pre-compute feed layout class (avoids template engine issues with complex ternaries)
|
||||
// Logic: use user's own feed_layout if they explicitly set one (> 0),
|
||||
// otherwise fall back to the site-wide default set in the admin dashboard.
|
||||
const userFeedLayout = data.session ? parseInt(data.session.feed_layout, 10) : 0;
|
||||
const siteFeedLayout = getDefaultFeedLayout();
|
||||
const rawFeedLayout = (userFeedLayout > 0) ? userFeedLayout : siteFeedLayout;
|
||||
const feedLayoutNum = (!isNaN(rawFeedLayout) && rawFeedLayout >= 0 && rawFeedLayout <= 3) ? rawFeedLayout : 0;
|
||||
data.feed_layout_class = 'layout-' + feedLayoutNum;
|
||||
|
||||
// Precompute boolean helpers for template @if() — the flummpress template engine uses a
|
||||
// non-greedy regex to parse @if(condition) and stops at the FIRST ')' it encounters.
|
||||
// This means any nested parens (e.g. indexOf('x'), .some(fn), (a || b)) inside @if()
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
import db from "../sql.mjs";
|
||||
import lib from "../lib.mjs";
|
||||
import security from "../security.mjs";
|
||||
import { getRegistrationOpen, getDefaultLayout } from "../settings.mjs";
|
||||
import { getRegistrationOpen, getDefaultLayout, getDefaultFeedLayout } from "../settings.mjs";
|
||||
import { sendMail } from "../../lib/smtp.mjs";
|
||||
import cfg from "../config.mjs";
|
||||
import crypto from "crypto";
|
||||
@@ -145,8 +145,8 @@ export default (router, tpl) => {
|
||||
const avatarFile = 'default.png';
|
||||
|
||||
await db`
|
||||
insert into user_options (user_id, mode, theme, fullscreen, avatar, avatar_file, use_new_layout, disable_autoplay, disable_swiping)
|
||||
values (${userId}, 3, 'amoled', 0, ${avatarId}, ${avatarFile}, ${getDefaultLayout() === 'modern'}, ${cfg.websrv.enable_autoplay === false}, ${cfg.websrv.enable_swiping === false})
|
||||
insert into user_options (user_id, mode, theme, fullscreen, avatar, avatar_file, use_new_layout, feed_layout, disable_autoplay, disable_swiping)
|
||||
values (${userId}, 3, 'amoled', 0, ${avatarId}, ${avatarFile}, ${getDefaultFeedLayout() === 1}, ${getDefaultFeedLayout()}, ${cfg.websrv.enable_autoplay === false}, ${cfg.websrv.enable_swiping === false})
|
||||
`;
|
||||
} catch (err) {
|
||||
console.error(`[REGISTER] DB Error during user creation:`, err);
|
||||
|
||||
Reference in New Issue
Block a user