Move slug sanitizer to a seperate function.

This commit is contained in:
Caleb 2017-10-03 09:01:06 -06:00
parent 4e5a004010
commit 72492749d9
2 changed files with 26 additions and 15 deletions

View File

@ -5,8 +5,7 @@ import GitGatewayBackend from "./git-gateway/implementation";
import { resolveFormat } from "../formats/formats";
import { selectListMethod, selectEntrySlug, selectEntryPath, selectAllowNewEntries, selectFolderEntryExtension } from "../reducers/collections";
import { createEntry } from "../valueObjects/Entry";
import { sanitizeIRI } from "../lib/urlHelper";
import sanitizeFilename from 'sanitize-filename';
import { sanitizeSlug } from "../lib/urlHelper";
class LocalStorageAuthStore {
storageKey = "netlify-cms-user";
@ -43,7 +42,7 @@ const slugFormatter = (template = "{{slug}}", entryData) => {
return identifier;
};
let slug = template.replace(/\{\{([^\}]+)\}\}/g, (_, field) => {
const slug = template.replace(/\{\{([^\}]+)\}\}/g, (_, field) => {
switch (field) {
case "year":
return date.getFullYear();
@ -56,21 +55,14 @@ const slugFormatter = (template = "{{slug}}", entryData) => {
default:
return entryData.get(field, "").trim();
}
});
// Convert slug to lower-case;
slug = slug.toLocaleLowerCase();
})
// Convert slug to lower-case
.toLocaleLowerCase()
// Replace periods and spaces with dashes.
slug = slug.replace(/[.\s]/g, '-');
// Sanitize as IRI (i18n URI) and as filename.
slug = sanitizeIRI(slug, {replacement: "-"});
slug = sanitizeFilename(slug, {replacement: "-"});
.replace(/[.\s]/g, '-');
// Remove any doubled or trailing replacement characters (that were added in the sanitizers).
slug = slug.replace(/-+/g, '-').replace(/-$/, '');
return slug;
return sanitizeSlug(slug);
};
class Backend {

View File

@ -1,4 +1,6 @@
import url from 'url';
import sanitizeFilename from 'sanitize-filename';
import { isString, escapeRegExp } from 'lodash';
function getUrl(url, direct) {
return `${ direct ? '/#' : '' }${ url }`;
@ -28,6 +30,23 @@ export function sanitizeIRI(str, { replacement }) {
return result;
}
export function sanitizeSlug(str, { replacement = '-' }) {
if (!isString(str)) throw "`sanitizeSlug` only accepts strings as input.";
if (!isString(replacement)) throw "the `sanitizeSlug` replacement character must be a string.";
let slug = str;
// Sanitize as IRI (i18n URI) and as filename.
slug = sanitizeIRI(slug, {replacement});
slug = sanitizeFilename(slug, {replacement});
// Remove any doubled or trailing replacement characters (that were added in the sanitizers).
const doubleReplacement = new RegExp('(?:' + escapeRegExp(replacement) + ')+', 'g');
const trailingReplacment = new RegExp(escapeRegExp(replacement) + '$')
slug = slug.replace(doubleReplacement, '-').replace(trailingReplacment, '');
return slug;
}
export function urlize(string) {
const sanitized = makePathSanitized(string);
const parsedURL = url.parse(sanitized);