feat: show custom fields on edit/profile

This commit is contained in:
Barış Soner Uşaklı
2024-07-30 21:30:00 -04:00
parent 5e1d8769d4
commit f33c8849d8
9 changed files with 40 additions and 6 deletions

View File

@@ -8,6 +8,7 @@
"name": "Name",
"type": "Type",
"input-type-text": "Input (Text)",
"input-type-link": "Input (Link)",
"input-type-number": "Input (Number)",
"input-type-select": "Select",
"select-options": "Options",

View File

@@ -7,6 +7,7 @@ const groups = require('../../groups');
const privileges = require('../../privileges');
const plugins = require('../../plugins');
const file = require('../../file');
const accountHelpers = require('./helpers');
const editController = module.exports;
@@ -25,11 +26,13 @@ editController.get = async function (req, res, next) {
allowMultipleBadges,
} = userData;
const [canUseSignature, canManageUsers] = await Promise.all([
const [canUseSignature, canManageUsers, customUserFields] = await Promise.all([
privileges.global.can('signature', req.uid),
privileges.admin.can('admin:users', req.uid),
accountHelpers.getCustomUserFields(userData),
]);
userData.customUserFields = customUserFields;
userData.maximumSignatureLength = meta.config.maximumSignatureLength;
userData.maximumAboutMeLength = meta.config.maximumAboutMeLength;
userData.maximumProfileImageSize = meta.config.maximumProfileImageSize;

View File

@@ -134,6 +134,23 @@ helpers.getUserDataByUserSlug = async function (userslug, callerUID, query = {})
return hookData.userData;
};
helpers.getCustomUserFields = async function (userData) {
const keys = await db.getSortedSetRange('user-custom-fields', 0, -1);
const fields = (await db.getObjects(keys.map(k => `user-custom-field:${k}`))).filter(Boolean);
fields.forEach((f) => {
f['select-options'] = f['select-options'].split('\n').filter(Boolean).map(
opt => ({
value: opt,
selected: opt === userData[f.key],
})
);
if (userData[f.key]) {
f.value = validator.escape(String(userData[f.key]));
}
});
return fields;
};
function escape(value) {
return translator.escape(validator.escape(String(value || '')));
}

View File

@@ -9,6 +9,7 @@ const categories = require('../../categories');
const plugins = require('../../plugins');
const privileges = require('../../privileges');
const helpers = require('../helpers');
const accountHelpers = require('./helpers');
const utils = require('../../utils');
const profileController = module.exports;
@@ -21,12 +22,13 @@ profileController.get = async function (req, res, next) {
await incrementProfileViews(req, userData);
const [latestPosts, bestPosts] = await Promise.all([
const [latestPosts, bestPosts, customUserFields] = await Promise.all([
getLatestPosts(req.uid, userData),
getBestPosts(req.uid, userData),
accountHelpers.getCustomUserFields(userData),
posts.parseSignature(userData, req.uid),
]);
userData.customUserFields = customUserFields;
userData.posts = latestPosts; // for backwards compat.
userData.latestPosts = latestPosts;
userData.bestPosts = bestPosts;

View File

@@ -295,7 +295,7 @@ usersController.getCSV = async function (req, res, next) {
});
};
usersController.customFields = async function (req, res, next) {
usersController.customFields = async function (req, res) {
const keys = await db.getSortedSetRange('user-custom-fields', 0, -1);
const fields = await db.getObjects(keys.map(k => `user-custom-field:${k}`));
fields.forEach((field) => {

View File

@@ -201,6 +201,7 @@ User.saveCustomFields = async function (socket, fields) {
await db.setObjectBulk(
fields.map(field => [`user-custom-field:${field.key}`, field])
);
await user.reloadCustomFieldWhitelist();
};
User.deleteCustomField = async function (socket, key) {

View File

@@ -28,6 +28,8 @@ module.exports = function (User) {
'cover:position', 'groupTitle', 'mutedUntil', 'mutedReason',
];
let customFieldWhiteList = null;
User.guestData = {
uid: 0,
username: '[[global:guest]]',
@@ -46,6 +48,10 @@ module.exports = function (User) {
let iconBackgrounds;
User.reloadCustomFieldWhitelist = async () => {
customFieldWhiteList = await db.getSortedSetRange('user-custom-fields', 0, -1);
};
User.getUsersFields = async function (uids, fields) {
if (!Array.isArray(uids) || !uids.length) {
return [];
@@ -58,10 +64,12 @@ module.exports = function (User) {
ensureRequiredFields(fields, fieldsToRemove);
const uniqueUids = _.uniq(uids).filter(uid => uid > 0);
if (!customFieldWhiteList) {
await User.reloadCustomFieldWhitelist();
}
const results = await plugins.hooks.fire('filter:user.whitelistFields', {
uids: uids,
whitelist: fieldWhitelist.slice(),
whitelist: _.uniq(fieldWhitelist.concat(customFieldWhiteList)),
});
if (!fields.length) {
fields = results.whitelist;

View File

@@ -17,6 +17,7 @@ module.exports = function (User) {
let fields = [
'username', 'email', 'fullname', 'website', 'location',
'groupTitle', 'birthday', 'signature', 'aboutme',
...await db.getSortedSetRange('user-custom-fields', 0, -1),
];
if (Array.isArray(extraFields)) {
fields = _.uniq(fields.concat(extraFields));

View File

@@ -3,6 +3,7 @@
<label class="form-label">[[admin/manage/user-custom-fields:type-of-input]]</label>
<select class="form-select" id="type-select" name="type">
<option value="input-text" {{{ if (type == "input-text") }}}selected{{{ end }}}>[[admin/manage/user-custom-fields:input-type-text]]</option>
<option value="input-link" {{{ if (type == "input-link") }}}selected{{{ end }}}>[[admin/manage/user-custom-fields:input-type-link]]</option>
<option value="input-number" {{{ if (type == "input-number") }}}selected{{{ end }}}>[[admin/manage/user-custom-fields:input-type-number]]</option>
<option value="select" {{{ if (type == "select") }}}selected{{{ end }}}>[[admin/manage/user-custom-fields:input-type-select]]</option>
</select>