Add setting to display underscores as spaces in tags
This commit is contained in:
parent
bbde0ab9a0
commit
7b236b02c9
9 changed files with 29 additions and 3 deletions
|
@ -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] %> <!--
|
--><%- ctx.getPrettyTagName(tag.names[0]) %> <!--
|
||||||
--><% if (ctx.canListPosts) { %><!--
|
--><% if (ctx.canListPosts) { %><!--
|
||||||
--></a><!--
|
--></a><!--
|
||||||
--><% } %><!--
|
--><% } %><!--
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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><!--
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
|
@ -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,
|
||||||
};
|
};
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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,
|
||||||
},
|
},
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
|
@ -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();
|
||||||
|
|
Loading…
Reference in a new issue