Add setting to display underscores as spaces in tags

This commit is contained in:
neobooru 2019-05-22 23:08:26 +02:00
parent bbde0ab9a0
commit 7b236b02c9
9 changed files with 29 additions and 3 deletions

View file

@ -91,7 +91,7 @@
--><% if (ctx.canListPosts) { %><!-- --><% if (ctx.canListPosts) { %><!--
--><a href='<%- ctx.formatClientLink('posts', {query: ctx.escapeColons(tag.names[0])}) %>' class='<%= ctx.makeCssName(tag.category, 'tag') %>'><!-- --><a href='<%- ctx.formatClientLink('posts', {query: ctx.escapeColons(tag.names[0])}) %>' class='<%= ctx.makeCssName(tag.category, 'tag') %>'><!--
--><% } %><!-- --><% } %><!--
--><%- tag.names[0] %>&#32;<!-- --><%- ctx.getPrettyTagName(tag.names[0]) %>&#32;<!--
--><% if (ctx.canListPosts) { %><!-- --><% if (ctx.canListPosts) { %><!--
--></a><!-- --></a><!--
--><% } %><!-- --><% } %><!--

View file

@ -63,6 +63,15 @@
checked: ctx.browsingSettings.autoplayVideos, checked: ctx.browsingSettings.autoplayVideos,
}) %> }) %>
</li> </li>
<li>
<%= ctx.makeCheckbox({
text: 'Display underscores as spaces in tags',
name: 'tag-underscores-as-spaces',
checked: ctx.browsingSettings.tagUnderscoresAsSpaces,
}) %>
<p class='hint'>Display all underscores as if they were spaces. This is only a visual change, which means that you'll still have to use underscores when searching or editing tags.</p>
</li>
</ul> </ul>
<div class='messages'></div> <div class='messages'></div>

View file

@ -1,5 +1,5 @@
<div class='content-wrapper' id='tag'> <div class='content-wrapper' id='tag'>
<h1><%- ctx.tag.names[0] %></h1> <h1><%- ctx.getPrettyTagName(ctx.tag.names[0]) %></h1>
<nav class='buttons'><!-- <nav class='buttons'><!--
--><ul><!-- --><ul><!--
--><li data-name='summary'><a href='<%- ctx.formatClientLink('tag', ctx.tag.names[0]) %>'>Summary</a></li><!-- --><li data-name='summary'><a href='<%- ctx.formatClientLink('tag', ctx.tag.names[0]) %>'>Summary</a></li><!--

View file

@ -4,6 +4,7 @@ const api = require('../api.js');
const events = require('../events.js'); const events = require('../events.js');
const views = require('../util/views.js'); const views = require('../util/views.js');
const uri = require('../util/uri.js'); const uri = require('../util/uri.js');
const misc = require('../util/misc.js');
const template = views.getTemplate('post-readonly-sidebar'); const template = views.getTemplate('post-readonly-sidebar');
const scoreTemplate = views.getTemplate('score'); const scoreTemplate = views.getTemplate('score');
@ -26,6 +27,7 @@ class PostReadonlySidebarControl extends events.EventTarget {
canEditPosts: api.hasPrivilege('posts:edit'), canEditPosts: api.hasPrivilege('posts:edit'),
canViewTags: api.hasPrivilege('tags:view'), canViewTags: api.hasPrivilege('tags:view'),
escapeColons: uri.escapeColons, escapeColons: uri.escapeColons,
getPrettyTagName: misc.getPrettyTagName,
})); }));
this._installFav(); this._installFav();

View file

@ -16,6 +16,7 @@ const defaultSettings = {
tagSuggestions: true, tagSuggestions: true,
autoplayVideos: false, autoplayVideos: false,
postsPerPage: 42, postsPerPage: 42,
tagUnderscoresAsSpaces: false,
}; };
class Settings extends events.EventTarget { class Settings extends events.EventTarget {

View file

@ -2,6 +2,9 @@
const markdown = require('./markdown.js'); const markdown = require('./markdown.js');
const uri = require('./uri.js'); const uri = require('./uri.js');
const settings = require('../models/settings.js');
const tagUnderscoresAsSpaces = settings.get().tagUnderscoresAsSpaces;
function decamelize(str, sep) { function decamelize(str, sep) {
sep = sep === undefined ? '-' : sep; sep = sep === undefined ? '-' : sep;
@ -197,6 +200,13 @@ function dataURItoBlob(dataURI) {
return new Blob([data], {type: mimeString}); return new Blob([data], {type: mimeString});
} }
function getPrettyTagName(tag) {
if (tagUnderscoresAsSpaces) {
return tag.replace(/_/g, " ");
}
return tag;
}
module.exports = { module.exports = {
range: range, range: range,
formatRelativeTime: formatRelativeTime, formatRelativeTime: formatRelativeTime,
@ -214,4 +224,5 @@ module.exports = {
decamelize: decamelize, decamelize: decamelize,
escapeSearchTerm: escapeSearchTerm, escapeSearchTerm: escapeSearchTerm,
dataURItoBlob: dataURItoBlob, dataURItoBlob: dataURItoBlob,
getPrettyTagName: getPrettyTagName,
}; };

View file

@ -200,7 +200,7 @@ function makePostLink(id, includeHash) {
function makeTagLink(name, includeHash, includeCount, tag) { function makeTagLink(name, includeHash, includeCount, tag) {
const category = tag ? tag.category : 'unknown'; const category = tag ? tag.category : 'unknown';
let text = name; let text = misc.getPrettyTagName(name);
if (includeHash === true) { if (includeHash === true) {
text = '#' + text; text = '#' + text;
} }

View file

@ -37,6 +37,7 @@ class SettingsView extends events.EventTarget {
tagSuggestions: this._find('tag-suggestions').checked, tagSuggestions: this._find('tag-suggestions').checked,
autoplayVideos: this._find('autoplay-videos').checked, autoplayVideos: this._find('autoplay-videos').checked,
postsPerPage: this._find('posts-per-page').value, postsPerPage: this._find('posts-per-page').value,
tagUnderscoresAsSpaces: this._find('tag-underscores-as-spaces').checked,
}, },
})); }));
} }

View file

@ -2,6 +2,7 @@
const events = require('../events.js'); const events = require('../events.js');
const views = require('../util/views.js'); const views = require('../util/views.js');
const misc = require('../util/misc.js');
const TagSummaryView = require('./tag_summary_view.js'); const TagSummaryView = require('./tag_summary_view.js');
const TagEditView = require('./tag_edit_view.js'); const TagEditView = require('./tag_edit_view.js');
const TagMergeView = require('./tag_merge_view.js'); const TagMergeView = require('./tag_merge_view.js');
@ -17,6 +18,7 @@ class TagView extends events.EventTarget {
this._ctx = ctx; this._ctx = ctx;
ctx.tag.addEventListener('change', e => this._evtChange(e)); ctx.tag.addEventListener('change', e => this._evtChange(e));
ctx.section = ctx.section || 'summary'; ctx.section = ctx.section || 'summary';
ctx.getPrettyTagName = misc.getPrettyTagName;
this._hostNode = document.getElementById('content-holder'); this._hostNode = document.getElementById('content-holder');
this._install(); this._install();