From c765cb0b76caacc8f1f7a337d1f28a47bda186ab Mon Sep 17 00:00:00 2001 From: Caleb Date: Tue, 27 Feb 2018 15:23:20 -0700 Subject: [PATCH] Support extensions with multiple parts (i.e. `en.md`) (#1123) * Support extensions with multiple parts (i.e. `en.md`) * Strip entire extension from slug, not just last extension. * Clean leading periods from extensions. --- src/backends/github/implementation.js | 3 +-- src/backends/test-repo/implementation.js | 3 +-- src/reducers/collections.js | 6 +++--- 3 files changed, 5 insertions(+), 7 deletions(-) diff --git a/src/backends/github/implementation.js b/src/backends/github/implementation.js index f357b6c8..19947dd3 100644 --- a/src/backends/github/implementation.js +++ b/src/backends/github/implementation.js @@ -1,6 +1,5 @@ import trimStart from 'lodash/trimStart'; import semaphore from "semaphore"; -import { fileExtension } from 'Lib/pathHelper' import AuthenticationPage from "./AuthenticationPage"; import API from "./API"; @@ -53,7 +52,7 @@ export default class GitHub { entriesByFolder(collection, extension) { return this.api.listFiles(collection.get("folder")) - .then(files => files.filter(file => fileExtension(file.name) === extension)) + .then(files => files.filter(file => file.name.endsWith('.' + extension))) .then(this.fetchFiles); } diff --git a/src/backends/test-repo/implementation.js b/src/backends/test-repo/implementation.js index 55a723de..40d9b123 100644 --- a/src/backends/test-repo/implementation.js +++ b/src/backends/test-repo/implementation.js @@ -1,6 +1,5 @@ import { remove, attempt, isError } from 'lodash'; import uuid from 'uuid/v4'; -import { fileExtension } from 'Lib/pathHelper' import AuthenticationPage from './AuthenticationPage'; window.repoFiles = window.repoFiles || {}; @@ -45,7 +44,7 @@ export default class TestRepo { const folder = collection.get('folder'); if (folder) { for (const path in window.repoFiles[folder]) { - if (fileExtension(path) !== extension) { + if (!path.endsWith('.' + extension)) { continue; } diff --git a/src/reducers/collections.js b/src/reducers/collections.js index bddf78a7..9f798baf 100644 --- a/src/reducers/collections.js +++ b/src/reducers/collections.js @@ -1,5 +1,5 @@ import { OrderedMap, fromJS } from 'immutable'; -import { has, get } from 'lodash'; +import { has, get, escapeRegExp } from 'lodash'; import consoleError from 'Lib/consoleError'; import { CONFIG_SUCCESS } from 'Actions/config'; import { FILES, FOLDER } from 'Constants/collectionTypes'; @@ -48,7 +48,7 @@ function validateCollection(configCollection) { const selectors = { [FOLDER]: { entryExtension(collection) { - return collection.get('extension') || formatToExtension(collection.get('format') || 'frontmatter'); + return (collection.get('extension') || formatToExtension(collection.get('format') || 'frontmatter')).replace(/^\./, ''); }, fields(collection) { return collection.get('fields'); @@ -57,7 +57,7 @@ const selectors = { return `${ collection.get('folder').replace(/\/$/, '') }/${ slug }.${ this.entryExtension(collection) }`; }, entrySlug(collection, path) { - return path.split('/').pop().replace(/\.[^\.]+$/, ''); + return path.split('/').pop().replace(new RegExp(`\.${ escapeRegExp(this.entryExtension(collection)) }$`), ''); }, listMethod() { return 'entriesByFolder';