diff options
-rw-r--r-- | package.json | 2 | ||||
-rw-r--r-- | packages/gitbook/lib/cli/getBook.js | 23 | ||||
-rw-r--r-- | packages/gitbook/lib/cli/getOutputFolder.js | 17 | ||||
-rw-r--r-- | packages/gitbook/lib/cli/init.js | 17 | ||||
-rw-r--r-- | packages/gitbook/lib/cli/server.js | 128 | ||||
-rw-r--r-- | packages/gitbook/lib/constants/configDefault.js | 6 | ||||
-rw-r--r-- | packages/gitbook/lib/json/encodeBook.js | 39 | ||||
-rw-r--r-- | packages/gitbook/lib/output/createTemplateEngine.js | 45 | ||||
-rw-r--r-- | packages/gitbook/lib/output/modifiers/__tests__/fetchRemoteImages.js | 40 | ||||
-rw-r--r-- | packages/gitbook/lib/output/modifiers/__tests__/inlinePng.js | 25 | ||||
-rw-r--r-- | packages/gitbook/lib/output/modifiers/__tests__/svgToImg.js | 25 | ||||
-rw-r--r-- | packages/gitbook/lib/output/modifiers/__tests__/svgToPng.js | 33 | ||||
-rw-r--r-- | packages/gitbook/lib/output/website/onFinish.js | 35 | ||||
-rw-r--r-- | packages/gitbook/lib/plugins/__tests__/installPlugin.js | 29 | ||||
-rw-r--r-- | packages/gitbook/lib/plugins/locateRootFolder.js | 22 | ||||
-rw-r--r-- | packages/gitbook/lib/utils/git.js | 133 | ||||
-rw-r--r-- | packages/gitbook/src/__tests__/gitbook.js (renamed from packages/gitbook/lib/__tests__/gitbook.js) | 2 | ||||
-rw-r--r-- | packages/gitbook/src/__tests__/init.js (renamed from packages/gitbook/lib/__tests__/init.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/__tests__/module.js (renamed from packages/gitbook/lib/__tests__/module.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/api/decodeConfig.js (renamed from packages/gitbook/lib/api/decodeConfig.js) | 2 | ||||
-rw-r--r-- | packages/gitbook/src/api/decodeGlobal.js (renamed from packages/gitbook/lib/api/decodeGlobal.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/api/decodePage.js (renamed from packages/gitbook/lib/api/decodePage.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/api/deprecate.js (renamed from packages/gitbook/lib/api/deprecate.js) | 20 | ||||
-rw-r--r-- | packages/gitbook/src/api/encodeConfig.js (renamed from packages/gitbook/lib/api/encodeConfig.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/api/encodeGlobal.js (renamed from packages/gitbook/lib/api/encodeGlobal.js) | 94 | ||||
-rw-r--r-- | packages/gitbook/src/api/encodeNavigation.js (renamed from packages/gitbook/lib/api/encodeNavigation.js) | 24 | ||||
-rw-r--r-- | packages/gitbook/src/api/encodePage.js (renamed from packages/gitbook/lib/api/encodePage.js) | 16 | ||||
-rw-r--r-- | packages/gitbook/src/api/encodeProgress.js (renamed from packages/gitbook/lib/api/encodeProgress.js) | 22 | ||||
-rw-r--r-- | packages/gitbook/src/api/encodeSummary.js (renamed from packages/gitbook/lib/api/encodeSummary.js) | 21 | ||||
-rw-r--r-- | packages/gitbook/src/api/index.js (renamed from packages/gitbook/lib/api/index.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/browser.js (renamed from packages/gitbook/lib/browser.js) | 2 | ||||
-rw-r--r-- | packages/gitbook/src/cli/build.js (renamed from packages/gitbook/lib/cli/build.js) | 20 | ||||
-rw-r--r-- | packages/gitbook/src/cli/buildEbook.js (renamed from packages/gitbook/lib/cli/buildEbook.js) | 40 | ||||
-rw-r--r-- | packages/gitbook/src/cli/getBook.js | 23 | ||||
-rw-r--r-- | packages/gitbook/src/cli/getOutputFolder.js | 17 | ||||
-rw-r--r-- | packages/gitbook/src/cli/index.js (renamed from packages/gitbook/lib/cli/index.js) | 2 | ||||
-rw-r--r-- | packages/gitbook/src/cli/init.js | 17 | ||||
-rw-r--r-- | packages/gitbook/src/cli/install.js (renamed from packages/gitbook/lib/cli/install.js) | 12 | ||||
-rw-r--r-- | packages/gitbook/src/cli/options.js (renamed from packages/gitbook/lib/cli/options.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/cli/parse.js (renamed from packages/gitbook/lib/cli/parse.js) | 40 | ||||
-rw-r--r-- | packages/gitbook/src/cli/serve.js (renamed from packages/gitbook/lib/cli/serve.js) | 54 | ||||
-rw-r--r-- | packages/gitbook/src/cli/server.js | 127 | ||||
-rw-r--r-- | packages/gitbook/src/cli/watch.js (renamed from packages/gitbook/lib/cli/watch.js) | 16 | ||||
-rw-r--r-- | packages/gitbook/src/constants/__tests__/configSchema.js (renamed from packages/gitbook/lib/constants/__tests__/configSchema.js) | 12 | ||||
-rw-r--r-- | packages/gitbook/src/constants/configDefault.js | 6 | ||||
-rw-r--r-- | packages/gitbook/src/constants/configFiles.js (renamed from packages/gitbook/lib/constants/configFiles.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/constants/configSchema.js (renamed from packages/gitbook/lib/constants/configSchema.js) | 2 | ||||
-rw-r--r-- | packages/gitbook/src/constants/defaultBlocks.js (renamed from packages/gitbook/lib/constants/defaultBlocks.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/constants/defaultFilters.js (renamed from packages/gitbook/lib/constants/defaultFilters.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/constants/defaultPlugins.js (renamed from packages/gitbook/lib/constants/defaultPlugins.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/constants/extsAsciidoc.js (renamed from packages/gitbook/lib/constants/extsAsciidoc.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/constants/extsMarkdown.js (renamed from packages/gitbook/lib/constants/extsMarkdown.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/constants/ignoreFiles.js (renamed from packages/gitbook/lib/constants/ignoreFiles.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/constants/pluginAssetsFolder.js (renamed from packages/gitbook/lib/constants/pluginAssetsFolder.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/constants/pluginHooks.js (renamed from packages/gitbook/lib/constants/pluginHooks.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/constants/pluginPrefix.js (renamed from packages/gitbook/lib/constants/pluginPrefix.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/constants/pluginResources.js (renamed from packages/gitbook/lib/constants/pluginResources.js) | 2 | ||||
-rw-r--r-- | packages/gitbook/src/constants/templatesFolder.js (renamed from packages/gitbook/lib/constants/templatesFolder.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/constants/themePrefix.js (renamed from packages/gitbook/lib/constants/themePrefix.js) | 2 | ||||
-rw-r--r-- | packages/gitbook/src/fs/__tests__/mock.js (renamed from packages/gitbook/lib/fs/__tests__/mock.js) | 5 | ||||
-rw-r--r-- | packages/gitbook/src/fs/mock.js (renamed from packages/gitbook/lib/fs/mock.js) | 34 | ||||
-rw-r--r-- | packages/gitbook/src/fs/node.js (renamed from packages/gitbook/lib/fs/node.js) | 18 | ||||
-rw-r--r-- | packages/gitbook/src/gitbook.js (renamed from packages/gitbook/lib/gitbook.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/index.js (renamed from packages/gitbook/lib/index.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/init.js (renamed from packages/gitbook/lib/init.js) | 42 | ||||
-rw-r--r-- | packages/gitbook/src/json/encodeBook.js | 39 | ||||
-rw-r--r-- | packages/gitbook/src/json/encodeBookWithPage.js (renamed from packages/gitbook/lib/json/encodeBookWithPage.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/json/encodeFile.js (renamed from packages/gitbook/lib/json/encodeFile.js) | 2 | ||||
-rw-r--r-- | packages/gitbook/src/json/encodeGlossary.js (renamed from packages/gitbook/lib/json/encodeGlossary.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/json/encodeGlossaryEntry.js (renamed from packages/gitbook/lib/json/encodeGlossaryEntry.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/json/encodeLanguages.js (renamed from packages/gitbook/lib/json/encodeLanguages.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/json/encodeOutput.js (renamed from packages/gitbook/lib/json/encodeOutput.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/json/encodeOutputWithPage.js (renamed from packages/gitbook/lib/json/encodeOutputWithPage.js) | 12 | ||||
-rw-r--r-- | packages/gitbook/src/json/encodePage.js (renamed from packages/gitbook/lib/json/encodePage.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/json/encodeReadme.js (renamed from packages/gitbook/lib/json/encodeReadme.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/json/encodeSummary.js (renamed from packages/gitbook/lib/json/encodeSummary.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/json/encodeSummaryArticle.js (renamed from packages/gitbook/lib/json/encodeSummaryArticle.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/json/encodeSummaryPart.js (renamed from packages/gitbook/lib/json/encodeSummaryPart.js) | 2 | ||||
-rw-r--r-- | packages/gitbook/src/json/index.js (renamed from packages/gitbook/lib/json/index.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/models/__tests__/config.js (renamed from packages/gitbook/lib/models/__tests__/config.js) | 33 | ||||
-rw-r--r-- | packages/gitbook/src/models/__tests__/glossary.js (renamed from packages/gitbook/lib/models/__tests__/glossary.js) | 15 | ||||
-rw-r--r-- | packages/gitbook/src/models/__tests__/glossaryEntry.js (renamed from packages/gitbook/lib/models/__tests__/glossaryEntry.js) | 5 | ||||
-rw-r--r-- | packages/gitbook/src/models/__tests__/page.js (renamed from packages/gitbook/lib/models/__tests__/page.js) | 9 | ||||
-rw-r--r-- | packages/gitbook/src/models/__tests__/plugin.js (renamed from packages/gitbook/lib/models/__tests__/plugin.js) | 9 | ||||
-rw-r--r-- | packages/gitbook/src/models/__tests__/pluginDependency.js (renamed from packages/gitbook/lib/models/__tests__/pluginDependency.js) | 22 | ||||
-rw-r--r-- | packages/gitbook/src/models/__tests__/summary.js (renamed from packages/gitbook/lib/models/__tests__/summary.js) | 21 | ||||
-rw-r--r-- | packages/gitbook/src/models/__tests__/summaryArticle.js (renamed from packages/gitbook/lib/models/__tests__/summaryArticle.js) | 21 | ||||
-rw-r--r-- | packages/gitbook/src/models/__tests__/summaryPart.js (renamed from packages/gitbook/lib/models/__tests__/summaryPart.js) | 7 | ||||
-rw-r--r-- | packages/gitbook/src/models/__tests__/templateBlock.js (renamed from packages/gitbook/lib/models/__tests__/templateBlock.js) | 74 | ||||
-rw-r--r-- | packages/gitbook/src/models/__tests__/templateEngine.js (renamed from packages/gitbook/lib/models/__tests__/templateEngine.js) | 28 | ||||
-rw-r--r-- | packages/gitbook/src/models/book.js (renamed from packages/gitbook/lib/models/book.js) | 70 | ||||
-rw-r--r-- | packages/gitbook/src/models/config.js (renamed from packages/gitbook/lib/models/config.js) | 28 | ||||
-rw-r--r-- | packages/gitbook/src/models/file.js (renamed from packages/gitbook/lib/models/file.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/models/fs.js (renamed from packages/gitbook/lib/models/fs.js) | 207 | ||||
-rw-r--r-- | packages/gitbook/src/models/glossary.js (renamed from packages/gitbook/lib/models/glossary.js) | 34 | ||||
-rw-r--r-- | packages/gitbook/src/models/glossaryEntry.js (renamed from packages/gitbook/lib/models/glossaryEntry.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/models/ignore.js (renamed from packages/gitbook/lib/models/ignore.js) | 12 | ||||
-rw-r--r-- | packages/gitbook/src/models/language.js (renamed from packages/gitbook/lib/models/language.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/models/languages.js (renamed from packages/gitbook/lib/models/languages.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/models/output.js (renamed from packages/gitbook/lib/models/output.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/models/page.js (renamed from packages/gitbook/lib/models/page.js) | 16 | ||||
-rw-r--r-- | packages/gitbook/src/models/parser.js (renamed from packages/gitbook/lib/models/parser.js) | 32 | ||||
-rw-r--r-- | packages/gitbook/src/models/plugin.js (renamed from packages/gitbook/lib/models/plugin.js) | 28 | ||||
-rw-r--r-- | packages/gitbook/src/models/pluginDependency.js (renamed from packages/gitbook/lib/models/pluginDependency.js) | 30 | ||||
-rw-r--r-- | packages/gitbook/src/models/readme.js (renamed from packages/gitbook/lib/models/readme.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/models/summary.js (renamed from packages/gitbook/lib/models/summary.js) | 52 | ||||
-rw-r--r-- | packages/gitbook/src/models/summaryArticle.js (renamed from packages/gitbook/lib/models/summaryArticle.js) | 36 | ||||
-rw-r--r-- | packages/gitbook/src/models/summaryPart.js (renamed from packages/gitbook/lib/models/summaryPart.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/models/templateBlock.js (renamed from packages/gitbook/lib/models/templateBlock.js) | 93 | ||||
-rw-r--r-- | packages/gitbook/src/models/templateEngine.js (renamed from packages/gitbook/lib/models/templateEngine.js) | 28 | ||||
-rw-r--r-- | packages/gitbook/src/models/templateOutput.js (renamed from packages/gitbook/lib/models/templateOutput.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/models/templateShortcut.js (renamed from packages/gitbook/lib/models/templateShortcut.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/config/__tests__/addPlugin.js (renamed from packages/gitbook/lib/modifiers/config/__tests__/addPlugin.js) | 15 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/config/__tests__/removePlugin.js (renamed from packages/gitbook/lib/modifiers/config/__tests__/removePlugin.js) | 19 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/config/__tests__/togglePlugin.js (renamed from packages/gitbook/lib/modifiers/config/__tests__/togglePlugin.js) | 15 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/config/addPlugin.js (renamed from packages/gitbook/lib/modifiers/config/addPlugin.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/config/editPlugin.js (renamed from packages/gitbook/lib/modifiers/config/editPlugin.js) | 2 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/config/getPluginConfig.js (renamed from packages/gitbook/lib/modifiers/config/getPluginConfig.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/config/hasPlugin.js (renamed from packages/gitbook/lib/modifiers/config/hasPlugin.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/config/index.js (renamed from packages/gitbook/lib/modifiers/config/index.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/config/isDefaultPlugin.js (renamed from packages/gitbook/lib/modifiers/config/isDefaultPlugin.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/config/removePlugin.js (renamed from packages/gitbook/lib/modifiers/config/removePlugin.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/config/togglePlugin.js (renamed from packages/gitbook/lib/modifiers/config/togglePlugin.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/index.js (renamed from packages/gitbook/lib/modifiers/index.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/__tests__/editArticle.js (renamed from packages/gitbook/lib/modifiers/summary/__tests__/editArticle.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/__tests__/editPartTitle.js (renamed from packages/gitbook/lib/modifiers/summary/__tests__/editPartTitle.js) | 19 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/__tests__/insertArticle.js (renamed from packages/gitbook/lib/modifiers/summary/__tests__/insertArticle.js) | 26 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/__tests__/insertPart.js (renamed from packages/gitbook/lib/modifiers/summary/__tests__/insertPart.js) | 24 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/__tests__/mergeAtLevel.js (renamed from packages/gitbook/lib/modifiers/summary/__tests__/mergeAtLevel.js) | 22 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/__tests__/moveArticle.js (renamed from packages/gitbook/lib/modifiers/summary/__tests__/moveArticle.js) | 24 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/__tests__/moveArticleAfter.js (renamed from packages/gitbook/lib/modifiers/summary/__tests__/moveArticleAfter.js) | 26 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/__tests__/removeArticle.js (renamed from packages/gitbook/lib/modifiers/summary/__tests__/removeArticle.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/editArticleRef.js (renamed from packages/gitbook/lib/modifiers/summary/editArticleRef.js) | 2 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/editArticleTitle.js (renamed from packages/gitbook/lib/modifiers/summary/editArticleTitle.js) | 2 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/editPartTitle.js (renamed from packages/gitbook/lib/modifiers/summary/editPartTitle.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/index.js (renamed from packages/gitbook/lib/modifiers/summary/index.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/indexArticleLevels.js (renamed from packages/gitbook/lib/modifiers/summary/indexArticleLevels.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/indexLevels.js (renamed from packages/gitbook/lib/modifiers/summary/indexLevels.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/indexPartLevels.js (renamed from packages/gitbook/lib/modifiers/summary/indexPartLevels.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/insertArticle.js (renamed from packages/gitbook/lib/modifiers/summary/insertArticle.js) | 18 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/insertPart.js (renamed from packages/gitbook/lib/modifiers/summary/insertPart.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/mergeAtLevel.js (renamed from packages/gitbook/lib/modifiers/summary/mergeAtLevel.js) | 16 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/moveArticle.js (renamed from packages/gitbook/lib/modifiers/summary/moveArticle.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/moveArticleAfter.js (renamed from packages/gitbook/lib/modifiers/summary/moveArticleAfter.js) | 20 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/removeArticle.js (renamed from packages/gitbook/lib/modifiers/summary/removeArticle.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/removePart.js (renamed from packages/gitbook/lib/modifiers/summary/removePart.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/modifiers/summary/unshiftArticle.js (renamed from packages/gitbook/lib/modifiers/summary/unshiftArticle.js) | 12 | ||||
-rw-r--r-- | packages/gitbook/src/output/__tests__/createMock.js (renamed from packages/gitbook/lib/output/__tests__/createMock.js) | 22 | ||||
-rw-r--r-- | packages/gitbook/src/output/__tests__/ebook.js (renamed from packages/gitbook/lib/output/__tests__/ebook.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/output/__tests__/generateMock.js (renamed from packages/gitbook/lib/output/__tests__/generateMock.js) | 18 | ||||
-rw-r--r-- | packages/gitbook/src/output/__tests__/json.js (renamed from packages/gitbook/lib/output/__tests__/json.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/output/__tests__/website.js (renamed from packages/gitbook/lib/output/__tests__/website.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/output/callHook.js (renamed from packages/gitbook/lib/output/callHook.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/output/callPageHook.js (renamed from packages/gitbook/lib/output/callPageHook.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/output/createTemplateEngine.js | 45 | ||||
-rw-r--r-- | packages/gitbook/src/output/ebook/getConvertOptions.js (renamed from packages/gitbook/lib/output/ebook/getConvertOptions.js) | 24 | ||||
-rw-r--r-- | packages/gitbook/src/output/ebook/getCoverPath.js (renamed from packages/gitbook/lib/output/ebook/getCoverPath.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/output/ebook/getPDFTemplate.js (renamed from packages/gitbook/lib/output/ebook/getPDFTemplate.js) | 18 | ||||
-rw-r--r-- | packages/gitbook/src/output/ebook/index.js (renamed from packages/gitbook/lib/output/ebook/index.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/output/ebook/onFinish.js (renamed from packages/gitbook/lib/output/ebook/onFinish.js) | 40 | ||||
-rw-r--r-- | packages/gitbook/src/output/ebook/onPage.js (renamed from packages/gitbook/lib/output/ebook/onPage.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/output/ebook/options.js (renamed from packages/gitbook/lib/output/ebook/options.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/output/generateAssets.js (renamed from packages/gitbook/lib/output/generateAssets.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/output/generateBook.js (renamed from packages/gitbook/lib/output/generateBook.js) | 74 | ||||
-rw-r--r-- | packages/gitbook/src/output/generatePage.js (renamed from packages/gitbook/lib/output/generatePage.js) | 32 | ||||
-rw-r--r-- | packages/gitbook/src/output/generatePages.js (renamed from packages/gitbook/lib/output/generatePages.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/output/getModifiers.js (renamed from packages/gitbook/lib/output/getModifiers.js) | 38 | ||||
-rw-r--r-- | packages/gitbook/src/output/helper/fileToOutput.js (renamed from packages/gitbook/lib/output/helper/fileToOutput.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/output/helper/fileToURL.js (renamed from packages/gitbook/lib/output/helper/fileToURL.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/output/helper/index.js (renamed from packages/gitbook/lib/output/helper/index.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/output/helper/resolveFileToURL.js (renamed from packages/gitbook/lib/output/helper/resolveFileToURL.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/output/helper/writeFile.js (renamed from packages/gitbook/lib/output/helper/writeFile.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/output/index.js (renamed from packages/gitbook/lib/output/index.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/output/json/index.js (renamed from packages/gitbook/lib/output/json/index.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/output/json/onFinish.js (renamed from packages/gitbook/lib/output/json/onFinish.js) | 18 | ||||
-rw-r--r-- | packages/gitbook/src/output/json/onPage.js (renamed from packages/gitbook/lib/output/json/onPage.js) | 20 | ||||
-rw-r--r-- | packages/gitbook/src/output/json/options.js (renamed from packages/gitbook/lib/output/json/options.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/__tests__/addHeadingId.js (renamed from packages/gitbook/lib/output/modifiers/__tests__/addHeadingId.js) | 13 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/__tests__/annotateText.js (renamed from packages/gitbook/lib/output/modifiers/__tests__/annotateText.js) | 23 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/__tests__/fetchRemoteImages.js | 39 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/__tests__/highlightCode.js (renamed from packages/gitbook/lib/output/modifiers/__tests__/highlightCode.js) | 23 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/__tests__/inlinePng.js | 24 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/__tests__/resolveLinks.js (renamed from packages/gitbook/lib/output/modifiers/__tests__/resolveLinks.js) | 44 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/__tests__/svgToImg.js | 24 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/__tests__/svgToPng.js | 32 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/addHeadingId.js (renamed from packages/gitbook/lib/output/modifiers/addHeadingId.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/annotateText.js (renamed from packages/gitbook/lib/output/modifiers/annotateText.js) | 45 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/editHTMLElement.js (renamed from packages/gitbook/lib/output/modifiers/editHTMLElement.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/fetchRemoteImages.js (renamed from packages/gitbook/lib/output/modifiers/fetchRemoteImages.js) | 22 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/highlightCode.js (renamed from packages/gitbook/lib/output/modifiers/highlightCode.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/index.js (renamed from packages/gitbook/lib/output/modifiers/index.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/inlineAssets.js (renamed from packages/gitbook/lib/output/modifiers/inlineAssets.js) | 12 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/inlinePng.js (renamed from packages/gitbook/lib/output/modifiers/inlinePng.js) | 22 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/modifyHTML.js (renamed from packages/gitbook/lib/output/modifiers/modifyHTML.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/resolveImages.js (renamed from packages/gitbook/lib/output/modifiers/resolveImages.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/resolveLinks.js (renamed from packages/gitbook/lib/output/modifiers/resolveLinks.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/svgToImg.js (renamed from packages/gitbook/lib/output/modifiers/svgToImg.js) | 26 | ||||
-rw-r--r-- | packages/gitbook/src/output/modifiers/svgToPng.js (renamed from packages/gitbook/lib/output/modifiers/svgToPng.js) | 24 | ||||
-rw-r--r-- | packages/gitbook/src/output/prepareAssets.js (renamed from packages/gitbook/lib/output/prepareAssets.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/output/preparePages.js (renamed from packages/gitbook/lib/output/preparePages.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/output/preparePlugins.js (renamed from packages/gitbook/lib/output/preparePlugins.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/output/website/__tests__/i18n.js (renamed from packages/gitbook/lib/output/website/__tests__/i18n.js) | 16 | ||||
-rw-r--r-- | packages/gitbook/src/output/website/copyPluginAssets.js (renamed from packages/gitbook/lib/output/website/copyPluginAssets.js) | 44 | ||||
-rw-r--r-- | packages/gitbook/src/output/website/createTemplateEngine.js (renamed from packages/gitbook/lib/output/website/createTemplateEngine.js) | 81 | ||||
-rw-r--r-- | packages/gitbook/src/output/website/index.js (renamed from packages/gitbook/lib/output/website/index.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/output/website/listSearchPaths.js (renamed from packages/gitbook/lib/output/website/listSearchPaths.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/output/website/onAsset.js (renamed from packages/gitbook/lib/output/website/onAsset.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/output/website/onFinish.js | 35 | ||||
-rw-r--r-- | packages/gitbook/src/output/website/onInit.js (renamed from packages/gitbook/lib/output/website/onInit.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/output/website/onPage.js (renamed from packages/gitbook/lib/output/website/onPage.js) | 50 | ||||
-rw-r--r-- | packages/gitbook/src/output/website/options.js (renamed from packages/gitbook/lib/output/website/options.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/output/website/prepareI18n.js (renamed from packages/gitbook/lib/output/website/prepareI18n.js) | 16 | ||||
-rw-r--r-- | packages/gitbook/src/output/website/prepareResources.js (renamed from packages/gitbook/lib/output/website/prepareResources.js) | 26 | ||||
-rw-r--r-- | packages/gitbook/src/output/website/state.js (renamed from packages/gitbook/lib/output/website/state.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/parse/__tests__/listAssets.js (renamed from packages/gitbook/lib/parse/__tests__/listAssets.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/parse/__tests__/parseBook.js (renamed from packages/gitbook/lib/parse/__tests__/parseBook.js) | 38 | ||||
-rw-r--r-- | packages/gitbook/src/parse/__tests__/parseGlossary.js (renamed from packages/gitbook/lib/parse/__tests__/parseGlossary.js) | 24 | ||||
-rw-r--r-- | packages/gitbook/src/parse/__tests__/parseIgnore.js (renamed from packages/gitbook/lib/parse/__tests__/parseIgnore.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/parse/__tests__/parsePageFromString.js (renamed from packages/gitbook/lib/parse/__tests__/parsePageFromString.js) | 20 | ||||
-rw-r--r-- | packages/gitbook/src/parse/__tests__/parseReadme.js (renamed from packages/gitbook/lib/parse/__tests__/parseReadme.js) | 20 | ||||
-rw-r--r-- | packages/gitbook/src/parse/__tests__/parseSummary.js (renamed from packages/gitbook/lib/parse/__tests__/parseSummary.js) | 22 | ||||
-rw-r--r-- | packages/gitbook/src/parse/findParsableFile.js (renamed from packages/gitbook/lib/parse/findParsableFile.js) | 18 | ||||
-rw-r--r-- | packages/gitbook/src/parse/index.js (renamed from packages/gitbook/lib/parse/index.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/parse/listAssets.js (renamed from packages/gitbook/lib/parse/listAssets.js) | 20 | ||||
-rw-r--r-- | packages/gitbook/src/parse/lookupStructureFile.js (renamed from packages/gitbook/lib/parse/lookupStructureFile.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/parse/parseBook.js (renamed from packages/gitbook/lib/parse/parseBook.js) | 28 | ||||
-rw-r--r-- | packages/gitbook/src/parse/parseConfig.js (renamed from packages/gitbook/lib/parse/parseConfig.js) | 16 | ||||
-rw-r--r-- | packages/gitbook/src/parse/parseGlossary.js (renamed from packages/gitbook/lib/parse/parseGlossary.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/parse/parseIgnore.js (renamed from packages/gitbook/lib/parse/parseIgnore.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/parse/parseLanguages.js (renamed from packages/gitbook/lib/parse/parseLanguages.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/parse/parsePage.js (renamed from packages/gitbook/lib/parse/parsePage.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/parse/parsePageFromString.js (renamed from packages/gitbook/lib/parse/parsePageFromString.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/parse/parsePagesList.js (renamed from packages/gitbook/lib/parse/parsePagesList.js) | 24 | ||||
-rw-r--r-- | packages/gitbook/src/parse/parseReadme.js (renamed from packages/gitbook/lib/parse/parseReadme.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/parse/parseStructureFile.js (renamed from packages/gitbook/lib/parse/parseStructureFile.js) | 12 | ||||
-rw-r--r-- | packages/gitbook/src/parse/parseSummary.js (renamed from packages/gitbook/lib/parse/parseSummary.js) | 16 | ||||
-rw-r--r-- | packages/gitbook/src/parse/validateConfig.js (renamed from packages/gitbook/lib/parse/validateConfig.js) | 16 | ||||
-rw-r--r-- | packages/gitbook/src/parse/walkSummary.js (renamed from packages/gitbook/lib/parse/walkSummary.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/parsers.js (renamed from packages/gitbook/lib/parsers.js) | 20 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/__tests__/findForBook.js (renamed from packages/gitbook/lib/plugins/__tests__/findForBook.js) | 12 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/__tests__/findInstalled.js (renamed from packages/gitbook/lib/plugins/__tests__/findInstalled.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/__tests__/installPlugin.js | 29 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/__tests__/installPlugins.js (renamed from packages/gitbook/lib/plugins/__tests__/installPlugins.js) | 16 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/__tests__/listDependencies.js (renamed from packages/gitbook/lib/plugins/__tests__/listDependencies.js) | 24 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/__tests__/locateRootFolder.js (renamed from packages/gitbook/lib/plugins/__tests__/locateRootFolder.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/__tests__/resolveVersion.js (renamed from packages/gitbook/lib/plugins/__tests__/resolveVersion.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/__tests__/sortDependencies.js (renamed from packages/gitbook/lib/plugins/__tests__/sortDependencies.js) | 20 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/__tests__/validatePlugin.js (renamed from packages/gitbook/lib/plugins/__tests__/validatePlugin.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/findForBook.js (renamed from packages/gitbook/lib/plugins/findForBook.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/findInstalled.js (renamed from packages/gitbook/lib/plugins/findInstalled.js) | 44 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/index.js (renamed from packages/gitbook/lib/plugins/index.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/installPlugin.js (renamed from packages/gitbook/lib/plugins/installPlugin.js) | 18 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/installPlugins.js (renamed from packages/gitbook/lib/plugins/installPlugins.js) | 16 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/listBlocks.js (renamed from packages/gitbook/lib/plugins/listBlocks.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/listDependencies.js (renamed from packages/gitbook/lib/plugins/listDependencies.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/listDepsForBook.js (renamed from packages/gitbook/lib/plugins/listDepsForBook.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/listFilters.js (renamed from packages/gitbook/lib/plugins/listFilters.js) | 2 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/listResources.js (renamed from packages/gitbook/lib/plugins/listResources.js) | 16 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/loadForBook.js (renamed from packages/gitbook/lib/plugins/loadForBook.js) | 24 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/loadPlugin.js (renamed from packages/gitbook/lib/plugins/loadPlugin.js) | 34 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/locateRootFolder.js | 22 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/resolveVersion.js (renamed from packages/gitbook/lib/plugins/resolveVersion.js) | 22 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/sortDependencies.js (renamed from packages/gitbook/lib/plugins/sortDependencies.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/toNames.js (renamed from packages/gitbook/lib/plugins/toNames.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/validateConfig.js (renamed from packages/gitbook/lib/plugins/validateConfig.js) | 28 | ||||
-rw-r--r-- | packages/gitbook/src/plugins/validatePlugin.js (renamed from packages/gitbook/lib/plugins/validatePlugin.js) | 10 | ||||
-rw-r--r-- | packages/gitbook/src/templating/__tests__/conrefsLoader.js (renamed from packages/gitbook/lib/templating/__tests__/conrefsLoader.js) | 18 | ||||
-rw-r--r-- | packages/gitbook/src/templating/__tests__/include.md (renamed from packages/gitbook/lib/templating/__tests__/include.md) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/templating/__tests__/postRender.js (renamed from packages/gitbook/lib/templating/__tests__/postRender.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/templating/__tests__/replaceShortcuts.js (renamed from packages/gitbook/lib/templating/__tests__/replaceShortcuts.js) | 12 | ||||
-rw-r--r-- | packages/gitbook/src/templating/conrefsLoader.js (renamed from packages/gitbook/lib/templating/conrefsLoader.js) | 30 | ||||
-rw-r--r-- | packages/gitbook/src/templating/index.js (renamed from packages/gitbook/lib/templating/index.js) | 0 | ||||
-rw-r--r-- | packages/gitbook/src/templating/listShortcuts.js (renamed from packages/gitbook/lib/templating/listShortcuts.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/templating/postRender.js (renamed from packages/gitbook/lib/templating/postRender.js) | 16 | ||||
-rw-r--r-- | packages/gitbook/src/templating/render.js (renamed from packages/gitbook/lib/templating/render.js) | 12 | ||||
-rw-r--r-- | packages/gitbook/src/templating/renderFile.js (renamed from packages/gitbook/lib/templating/renderFile.js) | 12 | ||||
-rw-r--r-- | packages/gitbook/src/templating/replaceShortcuts.js (renamed from packages/gitbook/lib/templating/replaceShortcuts.js) | 16 | ||||
-rw-r--r-- | packages/gitbook/src/templating/themesLoader.js (renamed from packages/gitbook/lib/templating/themesLoader.js) | 48 | ||||
-rw-r--r-- | packages/gitbook/src/utils/__tests__/git.js (renamed from packages/gitbook/lib/utils/__tests__/git.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/utils/__tests__/location.js (renamed from packages/gitbook/lib/utils/__tests__/location.js) | 3 | ||||
-rw-r--r-- | packages/gitbook/src/utils/__tests__/path.js (renamed from packages/gitbook/lib/utils/__tests__/path.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/utils/command.js (renamed from packages/gitbook/lib/utils/command.js) | 36 | ||||
-rw-r--r-- | packages/gitbook/src/utils/error.js (renamed from packages/gitbook/lib/utils/error.js) | 48 | ||||
-rw-r--r-- | packages/gitbook/src/utils/fs.js (renamed from packages/gitbook/lib/utils/fs.js) | 62 | ||||
-rw-r--r-- | packages/gitbook/src/utils/genKey.js (renamed from packages/gitbook/lib/utils/genKey.js) | 4 | ||||
-rw-r--r-- | packages/gitbook/src/utils/git.js | 135 | ||||
-rw-r--r-- | packages/gitbook/src/utils/images.js (renamed from packages/gitbook/lib/utils/images.js) | 24 | ||||
-rw-r--r-- | packages/gitbook/src/utils/location.js (renamed from packages/gitbook/lib/utils/location.js) | 40 | ||||
-rw-r--r-- | packages/gitbook/src/utils/logger.js (renamed from packages/gitbook/lib/utils/logger.js) | 48 | ||||
-rw-r--r-- | packages/gitbook/src/utils/mergeDefaults.js (renamed from packages/gitbook/lib/utils/mergeDefaults.js) | 6 | ||||
-rw-r--r-- | packages/gitbook/src/utils/path.js (renamed from packages/gitbook/lib/utils/path.js) | 25 | ||||
-rw-r--r-- | packages/gitbook/src/utils/promise.js (renamed from packages/gitbook/lib/utils/promise.js) | 14 | ||||
-rw-r--r-- | packages/gitbook/src/utils/reducedObject.js (renamed from packages/gitbook/lib/utils/reducedObject.js) | 8 | ||||
-rw-r--r-- | packages/gitbook/src/utils/timing.js (renamed from packages/gitbook/lib/utils/timing.js) | 34 |
294 files changed, 2775 insertions, 2813 deletions
diff --git a/package.json b/package.json index 878eaa8..5940776 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "private": true, "devDependencies": { - "eslint": "2.10.2", + "eslint": "3.4.0", "eslint-config-gitbook": "^1.2.0", "expect": "^1.20.1", "lerna": "2.0.0-beta.26", diff --git a/packages/gitbook/lib/cli/getBook.js b/packages/gitbook/lib/cli/getBook.js deleted file mode 100644 index ac82187..0000000 --- a/packages/gitbook/lib/cli/getBook.js +++ /dev/null @@ -1,23 +0,0 @@ -var path = require('path'); -var Book = require('../models/book'); -var createNodeFS = require('../fs/node'); - -/** - Return a book instance to work on from - command line args/kwargs - - @param {Array} args - @param {Object} kwargs - @return {Book} -*/ -function getBook(args, kwargs) { - var input = path.resolve(args[0] || process.cwd()); - var logLevel = kwargs.log; - - var fs = createNodeFS(input); - var book = Book.createForFS(fs); - - return book.setLogLevel(logLevel); -} - -module.exports = getBook; diff --git a/packages/gitbook/lib/cli/getOutputFolder.js b/packages/gitbook/lib/cli/getOutputFolder.js deleted file mode 100644 index 272dff9..0000000 --- a/packages/gitbook/lib/cli/getOutputFolder.js +++ /dev/null @@ -1,17 +0,0 @@ -var path = require('path'); - -/** - Return path to output folder - - @param {Array} args - @return {String} -*/ -function getOutputFolder(args) { - var bookRoot = path.resolve(args[0] || process.cwd()); - var defaultOutputRoot = path.join(bookRoot, '_book'); - var outputFolder = args[1]? path.resolve(process.cwd(), args[1]) : defaultOutputRoot; - - return outputFolder; -} - -module.exports = getOutputFolder; diff --git a/packages/gitbook/lib/cli/init.js b/packages/gitbook/lib/cli/init.js deleted file mode 100644 index 55f1b15..0000000 --- a/packages/gitbook/lib/cli/init.js +++ /dev/null @@ -1,17 +0,0 @@ -var path = require('path'); - -var options = require('./options'); -var initBook = require('../init'); - -module.exports = { - name: 'init [book]', - description: 'setup and create files for chapters', - options: [ - options.log - ], - exec: function(args, kwargs) { - var bookRoot = path.resolve(process.cwd(), args[0] || './'); - - return initBook(bookRoot); - } -}; diff --git a/packages/gitbook/lib/cli/server.js b/packages/gitbook/lib/cli/server.js deleted file mode 100644 index 752f867..0000000 --- a/packages/gitbook/lib/cli/server.js +++ /dev/null @@ -1,128 +0,0 @@ -var events = require('events'); -var http = require('http'); -var send = require('send'); -var util = require('util'); -var url = require('url'); - -var Promise = require('../utils/promise'); - -function Server() { - this.running = null; - this.dir = null; - this.port = 0; - this.sockets = []; -} -util.inherits(Server, events.EventEmitter); - -/** - Return true if the server is running - - @return {Boolean} -*/ -Server.prototype.isRunning = function() { - return !!this.running; -}; - -/** - Stop the server - - @return {Promise} -*/ -Server.prototype.stop = function() { - var that = this; - if (!this.isRunning()) return Promise(); - - var d = Promise.defer(); - this.running.close(function(err) { - that.running = null; - that.emit('state', false); - - if (err) d.reject(err); - else d.resolve(); - }); - - for (var i = 0; i < this.sockets.length; i++) { - this.sockets[i].destroy(); - } - - return d.promise; -}; - -/** - Start the server - - @return {Promise} -*/ -Server.prototype.start = function(dir, port) { - var that = this, pre = Promise(); - port = port || 8004; - - if (that.isRunning()) pre = this.stop(); - return pre - .then(function() { - var d = Promise.defer(); - - that.running = http.createServer(function(req, res){ - // Render error - function error(err) { - res.statusCode = err.status || 500; - res.end(err.message); - } - - // Redirect to directory's index.html - function redirect() { - var resultURL = urlTransform(req.url, function(parsed) { - parsed.pathname += '/'; - return parsed; - }); - - res.statusCode = 301; - res.setHeader('Location', resultURL); - res.end('Redirecting to ' + resultURL); - } - - res.setHeader('X-Current-Location', req.url); - - // Send file - send(req, url.parse(req.url).pathname, { - root: dir - }) - .on('error', error) - .on('directory', redirect) - .pipe(res); - }); - - that.running.on('connection', function (socket) { - that.sockets.push(socket); - socket.setTimeout(4000); - socket.on('close', function () { - that.sockets.splice(that.sockets.indexOf(socket), 1); - }); - }); - - that.running.listen(port, function(err) { - if (err) return d.reject(err); - - that.port = port; - that.dir = dir; - that.emit('state', true); - d.resolve(); - }); - - return d.promise; - }); -}; - -/** - urlTransform is a helper function that allows a function to transform - a url string in it's parsed form and returns the new url as a string - - @param {String} uri - @param {Function} fn - @return {String} -*/ -function urlTransform(uri, fn) { - return url.format(fn(url.parse(uri))); -} - -module.exports = Server; diff --git a/packages/gitbook/lib/constants/configDefault.js b/packages/gitbook/lib/constants/configDefault.js deleted file mode 100644 index 0d95883..0000000 --- a/packages/gitbook/lib/constants/configDefault.js +++ /dev/null @@ -1,6 +0,0 @@ -var Immutable = require('immutable'); -var jsonSchemaDefaults = require('json-schema-defaults'); - -var schema = require('./configSchema'); - -module.exports = Immutable.fromJS(jsonSchemaDefaults(schema)); diff --git a/packages/gitbook/lib/json/encodeBook.js b/packages/gitbook/lib/json/encodeBook.js deleted file mode 100644 index 9d7ec77..0000000 --- a/packages/gitbook/lib/json/encodeBook.js +++ /dev/null @@ -1,39 +0,0 @@ -var extend = require('extend'); - -var gitbook = require('../gitbook'); -var encodeSummary = require('./encodeSummary'); -var encodeGlossary = require('./encodeGlossary'); -var encodeReadme = require('./encodeReadme'); -var encodeLanguages = require('./encodeLanguages'); - -/** - Encode a book to JSON - - @param {Book} - @return {Object} -*/ -function encodeBookToJson(book) { - var config = book.getConfig(); - var language = book.getLanguage(); - - var variables = config.getValue('variables', {}); - - return { - summary: encodeSummary(book.getSummary()), - glossary: encodeGlossary(book.getGlossary()), - readme: encodeReadme(book.getReadme()), - config: book.getConfig().getValues().toJS(), - - languages: book.isMultilingual()? encodeLanguages(book.getLanguages()) : undefined, - - gitbook: { - version: gitbook.version, - time: gitbook.START_TIME - }, - book: extend({ - language: language? language : undefined - }, variables.toJS()) - }; -} - -module.exports = encodeBookToJson; diff --git a/packages/gitbook/lib/output/createTemplateEngine.js b/packages/gitbook/lib/output/createTemplateEngine.js deleted file mode 100644 index 8cf320e..0000000 --- a/packages/gitbook/lib/output/createTemplateEngine.js +++ /dev/null @@ -1,45 +0,0 @@ -var Templating = require('../templating'); -var TemplateEngine = require('../models/templateEngine'); - -var Api = require('../api'); -var Plugins = require('../plugins'); - -var defaultBlocks = require('../constants/defaultBlocks'); -var defaultFilters = require('../constants/defaultFilters'); - -/** - Create template engine for an output. - It adds default filters/blocks, then add the ones from plugins - - @param {Output} output - @return {TemplateEngine} -*/ -function createTemplateEngine(output) { - var plugins = output.getPlugins(); - var book = output.getBook(); - var rootFolder = book.getContentRoot(); - var logger = book.getLogger(); - - var filters = Plugins.listFilters(plugins); - var blocks = Plugins.listBlocks(plugins); - - // Extend with default - blocks = defaultBlocks.merge(blocks); - filters = defaultFilters.merge(filters); - - // Create loader - var transformFn = Templating.replaceShortcuts.bind(null, blocks); - var loader = new Templating.ConrefsLoader(rootFolder, transformFn, logger); - - // Create API context - var context = Api.encodeGlobal(output); - - return new TemplateEngine({ - filters: filters, - blocks: blocks, - loader: loader, - context: context - }); -} - -module.exports = createTemplateEngine; diff --git a/packages/gitbook/lib/output/modifiers/__tests__/fetchRemoteImages.js b/packages/gitbook/lib/output/modifiers/__tests__/fetchRemoteImages.js deleted file mode 100644 index bc1704d..0000000 --- a/packages/gitbook/lib/output/modifiers/__tests__/fetchRemoteImages.js +++ /dev/null @@ -1,40 +0,0 @@ -var cheerio = require('cheerio'); -var tmp = require('tmp'); -var path = require('path'); - -var URL = 'https://upload.wikimedia.org/wikipedia/commons/thumb/4/47/PNG_transparency_demonstration_1.png/280px-PNG_transparency_demonstration_1.png'; - -describe('fetchRemoteImages', function() { - var dir; - var fetchRemoteImages = require('../fetchRemoteImages'); - - beforeEach(function() { - dir = tmp.dirSync(); - }); - - it('should download image file', function() { - var $ = cheerio.load('<img src="' + URL + '" />'); - - return fetchRemoteImages(dir.name, 'index.html', $) - .then(function() { - var $img = $('img'); - var src = $img.attr('src'); - - expect(dir.name).toHaveFile(src); - }); - }); - - it('should download image file and replace with relative path', function() { - var $ = cheerio.load('<img src="' + URL + '" />'); - - return fetchRemoteImages(dir.name, 'test/index.html', $) - .then(function() { - var $img = $('img'); - var src = $img.attr('src'); - - expect(dir.name).toHaveFile(path.join('test', src)); - }); - }); -}); - - diff --git a/packages/gitbook/lib/output/modifiers/__tests__/inlinePng.js b/packages/gitbook/lib/output/modifiers/__tests__/inlinePng.js deleted file mode 100644 index 0073cff..0000000 --- a/packages/gitbook/lib/output/modifiers/__tests__/inlinePng.js +++ /dev/null @@ -1,25 +0,0 @@ -var cheerio = require('cheerio'); -var tmp = require('tmp'); -var inlinePng = require('../inlinePng'); - -describe('inlinePng', function() { - var dir; - - beforeEach(function() { - dir = tmp.dirSync(); - }); - - it('should write an inline PNG using data URI as a file', function() { - var $ = cheerio.load('<img alt="GitBook Logo 20x20" src=""/>'); - - return inlinePng(dir.name, 'index.html', $) - .then(function() { - var $img = $('img'); - var src = $img.attr('src'); - - expect(dir.name).toHaveFile(src); - }); - }); -}); - - diff --git a/packages/gitbook/lib/output/modifiers/__tests__/svgToImg.js b/packages/gitbook/lib/output/modifiers/__tests__/svgToImg.js deleted file mode 100644 index 5fe9796..0000000 --- a/packages/gitbook/lib/output/modifiers/__tests__/svgToImg.js +++ /dev/null @@ -1,25 +0,0 @@ -var cheerio = require('cheerio'); -var tmp = require('tmp'); - -describe('svgToImg', function() { - var dir; - var svgToImg = require('../svgToImg'); - - beforeEach(function() { - dir = tmp.dirSync(); - }); - - it('should write svg as a file', function() { - var $ = cheerio.load('<svg xmlns="http://www.w3.org/2000/svg" width="200" height="100" version="1.1"><rect width="200" height="100" stroke="black" stroke-width="6" fill="green"/></svg>'); - - return svgToImg(dir.name, 'index.html', $) - .then(function() { - var $img = $('img'); - var src = $img.attr('src'); - - expect(dir.name).toHaveFile(src); - }); - }); -}); - - diff --git a/packages/gitbook/lib/output/modifiers/__tests__/svgToPng.js b/packages/gitbook/lib/output/modifiers/__tests__/svgToPng.js deleted file mode 100644 index dbb3502..0000000 --- a/packages/gitbook/lib/output/modifiers/__tests__/svgToPng.js +++ /dev/null @@ -1,33 +0,0 @@ -var cheerio = require('cheerio'); -var tmp = require('tmp'); -var path = require('path'); - -var svgToImg = require('../svgToImg'); -var svgToPng = require('../svgToPng'); - -describe('svgToPng', function() { - var dir; - - beforeEach(function() { - dir = tmp.dirSync(); - }); - - it('should write svg as png file', function() { - var $ = cheerio.load('<svg xmlns="http://www.w3.org/2000/svg" width="200" height="100" version="1.1"><rect width="200" height="100" stroke="black" stroke-width="6" fill="green"/></svg>'); - var fileName = 'index.html'; - - return svgToImg(dir.name, fileName, $) - .then(function() { - return svgToPng(dir.name, fileName, $); - }) - .then(function() { - var $img = $('img'); - var src = $img.attr('src'); - - expect(dir.name).toHaveFile(src); - expect(path.extname(src)).toBe('.png'); - }); - }); -}); - - diff --git a/packages/gitbook/lib/output/website/onFinish.js b/packages/gitbook/lib/output/website/onFinish.js deleted file mode 100644 index 5267458..0000000 --- a/packages/gitbook/lib/output/website/onFinish.js +++ /dev/null @@ -1,35 +0,0 @@ -var Promise = require('../../utils/promise'); -var JSONUtils = require('../../json'); -var Templating = require('../../templating'); -var writeFile = require('../helper/writeFile'); -var createTemplateEngine = require('./createTemplateEngine'); - -/** - Finish the generation, write the languages index - - @param {Output} - @return {Output} -*/ -function onFinish(output) { - var book = output.getBook(); - var options = output.getOptions(); - var prefix = options.get('prefix'); - - if (!book.isMultilingual()) { - return Promise(output); - } - - var filePath = 'index.html'; - var engine = createTemplateEngine(output, filePath); - var context = JSONUtils.encodeOutput(output); - - // Render the theme - return Templating.renderFile(engine, prefix + '/languages.html', context) - - // Write it to the disk - .then(function(tplOut) { - return writeFile(output, filePath, tplOut.getContent()); - }); -} - -module.exports = onFinish; diff --git a/packages/gitbook/lib/plugins/__tests__/installPlugin.js b/packages/gitbook/lib/plugins/__tests__/installPlugin.js deleted file mode 100644 index 0c1a346..0000000 --- a/packages/gitbook/lib/plugins/__tests__/installPlugin.js +++ /dev/null @@ -1,29 +0,0 @@ -var path = require('path'); - -var PluginDependency = require('../../models/pluginDependency'); -var Book = require('../../models/book'); -var NodeFS = require('../../fs/node'); -var installPlugin = require('../installPlugin'); - -var Parse = require('../../parse'); - -describe('installPlugin', function() { - var book; - - this.timeout(30000); - - before(function() { - var fs = NodeFS(path.resolve(__dirname, '../../../')); - var baseBook = Book.createForFS(fs); - - return Parse.parseConfig(baseBook) - .then(function(_book) { - book = _book; - }); - }); - - it('must install a plugin from NPM', function() { - var dep = PluginDependency.createFromString('ga'); - return installPlugin(book, dep); - }); -}); diff --git a/packages/gitbook/lib/plugins/locateRootFolder.js b/packages/gitbook/lib/plugins/locateRootFolder.js deleted file mode 100644 index 1139510..0000000 --- a/packages/gitbook/lib/plugins/locateRootFolder.js +++ /dev/null @@ -1,22 +0,0 @@ -var path = require('path'); -var resolve = require('resolve'); - -var DEFAULT_PLUGINS = require('../constants/defaultPlugins'); - -/** - * Resolve the root folder containing for node_modules - * since gitbook can be used as a library and dependency can be flattened. - * - * @return {String} folderPath - */ -function locateRootFolder() { - var firstDefaultPlugin = DEFAULT_PLUGINS.first(); - var pluginPath = resolve.sync(firstDefaultPlugin.getNpmID() + '/package.json', { - basedir: __dirname - }); - var nodeModules = path.resolve(pluginPath, '../../..'); - - return nodeModules; -} - -module.exports = locateRootFolder; diff --git a/packages/gitbook/lib/utils/git.js b/packages/gitbook/lib/utils/git.js deleted file mode 100644 index 6884b83..0000000 --- a/packages/gitbook/lib/utils/git.js +++ /dev/null @@ -1,133 +0,0 @@ -var is = require('is'); -var path = require('path'); -var crc = require('crc'); -var URI = require('urijs'); - -var pathUtil = require('./path'); -var Promise = require('./promise'); -var command = require('./command'); -var fs = require('./fs'); - -var GIT_PREFIX = 'git+'; - -function Git() { - this.tmpDir; - this.cloned = {}; -} - -// Return an unique ID for a combinaison host/ref -Git.prototype.repoID = function(host, ref) { - return crc.crc32(host+'#'+(ref || '')).toString(16); -}; - -// Allocate a temporary folder for cloning repos in it -Git.prototype.allocateDir = function() { - var that = this; - - if (this.tmpDir) return Promise(); - - return fs.tmpDir() - .then(function(dir) { - that.tmpDir = dir; - }); -}; - -// Clone a git repository if non existant -Git.prototype.clone = function(host, ref) { - var that = this; - - return this.allocateDir() - - // Return or clone the git repo - .then(function() { - // Unique ID for repo/ref combinaison - var repoId = that.repoID(host, ref); - - // Absolute path to the folder - var repoPath = path.join(that.tmpDir, repoId); - - if (that.cloned[repoId]) return repoPath; - - // Clone repo - return command.exec('git clone '+host+' '+repoPath) - - // Checkout reference if specified - .then(function() { - that.cloned[repoId] = true; - - if (!ref) return; - return command.exec('git checkout '+ref, { cwd: repoPath }); - }) - .thenResolve(repoPath); - }); -}; - -// Get file from a git repo -Git.prototype.resolve = function(giturl) { - // Path to a file in a git repo? - if (!Git.isUrl(giturl)) { - if (this.resolveRoot(giturl)) return Promise(giturl); - return Promise(null); - } - if (is.string(giturl)) giturl = Git.parseUrl(giturl); - if (!giturl) return Promise(null); - - // Clone or get from cache - return this.clone(giturl.host, giturl.ref) - .then(function(repo) { - return path.resolve(repo, giturl.filepath); - }); -}; - -// Return root of git repo from a filepath -Git.prototype.resolveRoot = function(filepath) { - var relativeToGit, repoId; - - // No git repo cloned, or file is not in a git repository - if (!this.tmpDir || !pathUtil.isInRoot(this.tmpDir, filepath)) return null; - - // Extract first directory (is the repo id) - relativeToGit = path.relative(this.tmpDir, filepath); - repoId = relativeToGit.split(path.sep)[0]; - if (!repoId) { - return; - } - - // Return an absolute file - return path.resolve(this.tmpDir, repoId); -}; - -// Check if an url is a git dependency url -Git.isUrl = function(giturl) { - return (giturl.indexOf(GIT_PREFIX) === 0); -}; - -// Parse and extract infos -Git.parseUrl = function(giturl) { - var ref, uri, fileParts, filepath; - - if (!Git.isUrl(giturl)) return null; - giturl = giturl.slice(GIT_PREFIX.length); - - uri = new URI(giturl); - ref = uri.fragment() || null; - uri.fragment(null); - - // Extract file inside the repo (after the .git) - fileParts = uri.path().split('.git'); - filepath = fileParts.length > 1? fileParts.slice(1).join('.git') : ''; - if (filepath[0] == '/') { - filepath = filepath.slice(1); - } - - // Recreate pathname without the real filename - uri.path(fileParts[0] + '.git'); - - return { - host: uri.toString(), - ref: ref, - filepath: filepath - }; -}; - -module.exports = Git; diff --git a/packages/gitbook/lib/__tests__/gitbook.js b/packages/gitbook/src/__tests__/gitbook.js index c3669bb..5292e01 100644 --- a/packages/gitbook/lib/__tests__/gitbook.js +++ b/packages/gitbook/src/__tests__/gitbook.js @@ -1,4 +1,4 @@ -var gitbook = require('../gitbook'); +const gitbook = require('../gitbook'); describe('satisfies', function() { diff --git a/packages/gitbook/lib/__tests__/init.js b/packages/gitbook/src/__tests__/init.js index 66188a3..d8e5398 100644 --- a/packages/gitbook/lib/__tests__/init.js +++ b/packages/gitbook/src/__tests__/init.js @@ -1,10 +1,10 @@ -var tmp = require('tmp'); -var initBook = require('../init'); +const tmp = require('tmp'); +const initBook = require('../init'); describe('initBook', function() { it('should create a README and SUMMARY for empty book', function() { - var dir = tmp.dirSync(); + const dir = tmp.dirSync(); return initBook(dir.name) .then(function() { diff --git a/packages/gitbook/lib/__tests__/module.js b/packages/gitbook/src/__tests__/module.js index d9220f5..d9220f5 100644 --- a/packages/gitbook/lib/__tests__/module.js +++ b/packages/gitbook/src/__tests__/module.js diff --git a/packages/gitbook/lib/api/decodeConfig.js b/packages/gitbook/src/api/decodeConfig.js index 5e00df5..0c5ba66 100644 --- a/packages/gitbook/lib/api/decodeConfig.js +++ b/packages/gitbook/src/api/decodeConfig.js @@ -6,7 +6,7 @@ @return {Config} */ function decodeGlobal(config, result) { - var values = result.values; + const values = result.values; delete values.generator; delete values.output; diff --git a/packages/gitbook/lib/api/decodeGlobal.js b/packages/gitbook/src/api/decodeGlobal.js index 118afb2..063683a 100644 --- a/packages/gitbook/lib/api/decodeGlobal.js +++ b/packages/gitbook/src/api/decodeGlobal.js @@ -1,4 +1,4 @@ -var decodeConfig = require('./decodeConfig'); +const decodeConfig = require('./decodeConfig'); /** Decode changes from a JS API to a output object. @@ -9,8 +9,8 @@ var decodeConfig = require('./decodeConfig'); @return {Output} */ function decodeGlobal(output, result) { - var book = output.getBook(); - var config = book.getConfig(); + let book = output.getBook(); + let config = book.getConfig(); // Update config config = decodeConfig(config, result.config); diff --git a/packages/gitbook/lib/api/decodePage.js b/packages/gitbook/src/api/decodePage.js index c85dd1b..4fd78af 100644 --- a/packages/gitbook/lib/api/decodePage.js +++ b/packages/gitbook/src/api/decodePage.js @@ -1,4 +1,4 @@ -var deprecate = require('./deprecate'); +const deprecate = require('./deprecate'); /** Decode changes from a JS API to a page object. @@ -10,7 +10,7 @@ var deprecate = require('./deprecate'); @return {Page} */ function decodePage(output, page, result) { - var originalContent = page.getContent(); + const originalContent = page.getContent(); // No returned value // Existing content will be used diff --git a/packages/gitbook/lib/api/deprecate.js b/packages/gitbook/src/api/deprecate.js index 7a93a91..879355c 100644 --- a/packages/gitbook/lib/api/deprecate.js +++ b/packages/gitbook/src/api/deprecate.js @@ -1,8 +1,8 @@ -var is = require('is'); -var objectPath = require('object-path'); +const is = require('is'); +const objectPath = require('object-path'); -var logged = {}; -var disabled = {}; +const logged = {}; +const disabled = {}; /** Log a deprecated notice @@ -16,7 +16,7 @@ function logNotice(book, key, message) { logged[key] = true; - var logger = book.getLogger(); + const logger = book.getLogger(); logger.warn.ln(message); } @@ -48,22 +48,22 @@ function deprecateMethod(book, key, fn, msg) { @return {Function} */ function deprecateField(book, key, instance, property, value, msg) { - var store = undefined; + let store = undefined; - var prepare = function() { + const prepare = function() { if (!is.undefined(store)) return; if (is.fn(value)) store = value(); else store = value; }; - var getter = function(){ + const getter = function() { prepare(); logNotice(book, key, msg); return store; }; - var setter = function(v) { + const setter = function(v) { prepare(); logNotice(book, key, msg); @@ -108,7 +108,7 @@ function disableDeprecation(key) { */ function deprecateRenamedMethod(book, key, instance, oldName, newName, msg) { msg = msg || ('"' + oldName + '" is deprecated, use "' + newName + '()" instead'); - var fn = objectPath.get(instance, newName); + const fn = objectPath.get(instance, newName); instance[oldName] = deprecateMethod(book, key, fn, msg); } diff --git a/packages/gitbook/lib/api/encodeConfig.js b/packages/gitbook/src/api/encodeConfig.js index 2a05528..096f136 100644 --- a/packages/gitbook/lib/api/encodeConfig.js +++ b/packages/gitbook/src/api/encodeConfig.js @@ -1,5 +1,5 @@ -var objectPath = require('object-path'); -var deprecate = require('./deprecate'); +const objectPath = require('object-path'); +const deprecate = require('./deprecate'); /** Encode a config object into a JS config api @@ -9,14 +9,14 @@ var deprecate = require('./deprecate'); @return {Object} */ function encodeConfig(output, config) { - var result = { + const result = { values: config.getValues().toJS(), - get: function(key, defaultValue) { + get(key, defaultValue) { return objectPath.get(result.values, key, defaultValue); }, - set: function(key, value) { + set(key, value) { return objectPath.set(result.values, key, value); } }; diff --git a/packages/gitbook/lib/api/encodeGlobal.js b/packages/gitbook/src/api/encodeGlobal.js index a366526..21a1e73 100644 --- a/packages/gitbook/lib/api/encodeGlobal.js +++ b/packages/gitbook/src/api/encodeGlobal.js @@ -1,19 +1,19 @@ -var path = require('path'); -var Promise = require('../utils/promise'); -var PathUtils = require('../utils/path'); -var fs = require('../utils/fs'); - -var Plugins = require('../plugins'); -var deprecate = require('./deprecate'); -var fileToURL = require('../output/helper/fileToURL'); -var defaultBlocks = require('../constants/defaultBlocks'); -var gitbook = require('../gitbook'); -var parsers = require('../parsers'); - -var encodeConfig = require('./encodeConfig'); -var encodeSummary = require('./encodeSummary'); -var encodeNavigation = require('./encodeNavigation'); -var encodePage = require('./encodePage'); +const path = require('path'); +const Promise = require('../utils/promise'); +const PathUtils = require('../utils/path'); +const fs = require('../utils/fs'); + +const Plugins = require('../plugins'); +const deprecate = require('./deprecate'); +const fileToURL = require('../output/helper/fileToURL'); +const defaultBlocks = require('../constants/defaultBlocks'); +const gitbook = require('../gitbook'); +const parsers = require('../parsers'); + +const encodeConfig = require('./encodeConfig'); +const encodeSummary = require('./encodeSummary'); +const encodeNavigation = require('./encodeNavigation'); +const encodePage = require('./encodePage'); /** Encode a global context into a JS object @@ -23,14 +23,14 @@ var encodePage = require('./encodePage'); @return {Object} */ function encodeGlobal(output) { - var book = output.getBook(); - var bookFS = book.getContentFS(); - var logger = output.getLogger(); - var outputFolder = output.getRoot(); - var plugins = output.getPlugins(); - var blocks = Plugins.listBlocks(plugins); - - var result = { + const book = output.getBook(); + const bookFS = book.getContentFS(); + const logger = output.getLogger(); + const outputFolder = output.getRoot(); + const plugins = output.getPlugins(); + const blocks = Plugins.listBlocks(plugins); + + const result = { log: logger, config: encodeConfig(output, book.getConfig()), summary: encodeSummary(output, book.getSummary()), @@ -40,7 +40,7 @@ function encodeGlobal(output) { @return {Boolean} */ - isMultilingual: function() { + isMultilingual() { return book.isMultilingual(); }, @@ -49,7 +49,7 @@ function encodeGlobal(output) { @return {Boolean} */ - isLanguageBook: function() { + isLanguageBook() { return book.isLanguageBook(); }, @@ -59,7 +59,7 @@ function encodeGlobal(output) { @param {String} fileName @return {Promise<Buffer>} */ - readFile: function(fileName) { + readFile(fileName) { return bookFS.read(fileName); }, @@ -69,7 +69,7 @@ function encodeGlobal(output) { @param {String} fileName @return {Promise<String>} */ - readFileAsString: function(fileName) { + readFileAsString(fileName) { return bookFS.readAsString(fileName); }, @@ -79,7 +79,7 @@ function encodeGlobal(output) { @param {String} fileName @return {String} */ - resolve: function(fileName) { + resolve(fileName) { return path.resolve(book.getContentRoot(), fileName); }, @@ -89,8 +89,8 @@ function encodeGlobal(output) { @param {String} filePath @return {String} */ - getPageByPath: function(filePath) { - var page = output.getPage(filePath); + getPageByPath(filePath) { + const page = output.getPage(filePath); if (!page) return undefined; return encodePage(output, page); @@ -103,8 +103,8 @@ function encodeGlobal(output) { @param {String} text @return {Promise<String>} */ - renderBlock: function(type, text) { - var parser = parsers.get(type); + renderBlock(type, text) { + const parser = parsers.get(type); return parser.parsePage(text) .get('content'); @@ -117,14 +117,15 @@ function encodeGlobal(output) { @param {String} text @return {Promise<String>} */ - renderInline: function(type, text) { - var parser = parsers.get(type); + renderInline(type, text) { + const parser = parsers.get(type); return parser.parseInline(text) .get('content'); }, template: { + /** Apply a templating block and returns its result @@ -132,13 +133,14 @@ function encodeGlobal(output) { @param {Object} blockData @return {Promise|Object} */ - applyBlock: function(name, blockData) { - var block = blocks.get(name) || defaultBlocks.get(name); + applyBlock(name, blockData) { + const block = blocks.get(name) || defaultBlocks.get(name); return Promise(block.applyBlock(blockData, result)); } }, output: { + /** Name of the generator being used {String} @@ -149,7 +151,7 @@ function encodeGlobal(output) { Return absolute path to the root folder of output @return {String} */ - root: function() { + root() { return outputFolder; }, @@ -159,7 +161,7 @@ function encodeGlobal(output) { @param {String} fileName @return {String} */ - resolve: function(fileName) { + resolve(fileName) { return path.resolve(outputFolder, fileName); }, @@ -167,7 +169,7 @@ function encodeGlobal(output) { Convert a filepath into an url @return {String} */ - toURL: function(filePath) { + toURL(filePath) { return fileToURL(output, filePath); }, @@ -177,10 +179,10 @@ function encodeGlobal(output) { @param {String} fileName @return {Promise} */ - hasFile: function(fileName, content) { + hasFile(fileName, content) { return Promise() .then(function() { - var filePath = PathUtils.resolveInRoot(outputFolder, fileName); + const filePath = PathUtils.resolveInRoot(outputFolder, fileName); return fs.exists(filePath); }); @@ -194,10 +196,10 @@ function encodeGlobal(output) { @param {Buffer} content @return {Promise} */ - writeFile: function(fileName, content) { + writeFile(fileName, content) { return Promise() .then(function() { - var filePath = PathUtils.resolveInRoot(outputFolder, fileName); + const filePath = PathUtils.resolveInRoot(outputFolder, fileName); return fs.ensureFile(filePath) .then(function() { @@ -215,10 +217,10 @@ function encodeGlobal(output) { @param {Buffer} content @return {Promise} */ - copyFile: function(inputFile, outputFile, content) { + copyFile(inputFile, outputFile, content) { return Promise() .then(function() { - var outputFilePath = PathUtils.resolveInRoot(outputFolder, outputFile); + const outputFilePath = PathUtils.resolveInRoot(outputFolder, outputFile); return fs.ensureFile(outputFilePath) .then(function() { diff --git a/packages/gitbook/lib/api/encodeNavigation.js b/packages/gitbook/src/api/encodeNavigation.js index 8e329a1..d54239d 100644 --- a/packages/gitbook/lib/api/encodeNavigation.js +++ b/packages/gitbook/src/api/encodeNavigation.js @@ -1,4 +1,4 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); /** Encode an article for next/prev @@ -8,7 +8,7 @@ var Immutable = require('immutable'); @return {Object} */ function encodeArticle(pages, article) { - var articlePath = article.getPath(); + const articlePath = article.getPath(); return { path: articlePath, @@ -26,21 +26,21 @@ function encodeArticle(pages, article) { @return {Object} */ function encodeNavigation(output) { - var book = output.getBook(); - var pages = output.getPages(); - var summary = book.getSummary(); - var articles = summary.getArticlesAsList(); + const book = output.getBook(); + const pages = output.getPages(); + const summary = book.getSummary(); + const articles = summary.getArticlesAsList(); - var navigation = articles + const navigation = articles .map(function(article, i) { - var ref = article.getRef(); + const ref = article.getRef(); if (!ref) { return undefined; } - var prev = articles.get(i - 1); - var next = articles.get(i + 1); + const prev = articles.get(i - 1); + const next = articles.get(i + 1); return [ ref, @@ -48,8 +48,8 @@ function encodeNavigation(output) { index: i, title: article.getTitle(), introduction: (i === 0), - prev: prev? encodeArticle(pages, prev) : undefined, - next: next? encodeArticle(pages, next) : undefined, + prev: prev ? encodeArticle(pages, prev) : undefined, + next: next ? encodeArticle(pages, next) : undefined, level: article.getLevel() } ]; diff --git a/packages/gitbook/lib/api/encodePage.js b/packages/gitbook/src/api/encodePage.js index 379d3d5..fb77fcd 100644 --- a/packages/gitbook/lib/api/encodePage.js +++ b/packages/gitbook/src/api/encodePage.js @@ -1,6 +1,6 @@ -var JSONUtils = require('../json'); -var deprecate = require('./deprecate'); -var encodeProgress = require('./encodeProgress'); +const JSONUtils = require('../json'); +const deprecate = require('./deprecate'); +const encodeProgress = require('./encodeProgress'); /** Encode a page in a context to a JS API @@ -10,13 +10,13 @@ var encodeProgress = require('./encodeProgress'); @return {Object} */ function encodePage(output, page) { - var book = output.getBook(); - var summary = book.getSummary(); - var fs = book.getContentFS(); - var file = page.getFile(); + const book = output.getBook(); + const summary = book.getSummary(); + const fs = book.getContentFS(); + const file = page.getFile(); // JS Page is based on the JSON output - var result = JSONUtils.encodePage(page, summary); + const result = JSONUtils.encodePage(page, summary); result.type = file.getType(); result.path = file.getPath(); diff --git a/packages/gitbook/lib/api/encodeProgress.js b/packages/gitbook/src/api/encodeProgress.js index afa0341..3224370 100644 --- a/packages/gitbook/lib/api/encodeProgress.js +++ b/packages/gitbook/src/api/encodeProgress.js @@ -1,5 +1,5 @@ -var Immutable = require('immutable'); -var encodeNavigation = require('./encodeNavigation'); +const Immutable = require('immutable'); +const encodeNavigation = require('./encodeNavigation'); /** page.progress is a deprecated property from GitBook v2 @@ -9,15 +9,15 @@ var encodeNavigation = require('./encodeNavigation'); @return {Object} */ function encodeProgress(output, page) { - var current = page.getPath(); - var navigation = encodeNavigation(output); + const current = page.getPath(); + let navigation = encodeNavigation(output); navigation = Immutable.Map(navigation); - var n = navigation.size; - var percent = 0, prevPercent = 0, currentChapter = null; - var done = true; + const n = navigation.size; + let percent = 0, prevPercent = 0, currentChapter = null; + let done = true; - var chapters = navigation + const chapters = navigation .map(function(nav, chapterPath) { nav.path = chapterPath; return nav; @@ -46,13 +46,13 @@ function encodeProgress(output, page) { return { // Previous percent - prevPercent: prevPercent, + prevPercent, // Current percent - percent: percent, + percent, // List of chapter with progress - chapters: chapters, + chapters, // Current chapter current: currentChapter diff --git a/packages/gitbook/lib/api/encodeSummary.js b/packages/gitbook/src/api/encodeSummary.js index 0d66ded..323f5d4 100644 --- a/packages/gitbook/lib/api/encodeSummary.js +++ b/packages/gitbook/src/api/encodeSummary.js @@ -1,4 +1,4 @@ -var encodeSummaryArticle = require('../json/encodeSummaryArticle'); +const encodeSummaryArticle = require('../json/encodeSummaryArticle'); /** Encode summary to provide an API to plugin @@ -8,15 +8,16 @@ var encodeSummaryArticle = require('../json/encodeSummaryArticle'); @return {Object} */ function encodeSummary(output, summary) { - var result = { + const result = { + /** Iterate over the summary, it stops when the "iter" returns false @param {Function} iter */ - walk: function (iter) { + walk(iter) { summary.getArticle(function(article) { - var jsonArticle = encodeSummaryArticle(article, false); + const jsonArticle = encodeSummaryArticle(article, false); return iter(jsonArticle); }); @@ -28,9 +29,9 @@ function encodeSummary(output, summary) { @param {String} level @return {Object} */ - getArticleByLevel: function(level) { - var article = summary.getByLevel(level); - return (article? encodeSummaryArticle(article) : undefined); + getArticleByLevel(level) { + const article = summary.getByLevel(level); + return (article ? encodeSummaryArticle(article) : undefined); }, /** @@ -39,9 +40,9 @@ function encodeSummary(output, summary) { @param {String} level @return {Object} */ - getArticleByPath: function(level) { - var article = summary.getByPath(level); - return (article? encodeSummaryArticle(article) : undefined); + getArticleByPath(level) { + const article = summary.getByPath(level); + return (article ? encodeSummaryArticle(article) : undefined); } }; diff --git a/packages/gitbook/lib/api/index.js b/packages/gitbook/src/api/index.js index 5e67525..5e67525 100644 --- a/packages/gitbook/lib/api/index.js +++ b/packages/gitbook/src/api/index.js diff --git a/packages/gitbook/lib/browser.js b/packages/gitbook/src/browser.js index 87a4dc4..771ecd5 100644 --- a/packages/gitbook/lib/browser.js +++ b/packages/gitbook/src/browser.js @@ -1,4 +1,4 @@ -var Modifiers = require('./modifiers'); +const Modifiers = require('./modifiers'); module.exports = { Parse: require('./parse'), diff --git a/packages/gitbook/lib/cli/build.js b/packages/gitbook/src/cli/build.js index 023901e..3f5c937 100644 --- a/packages/gitbook/lib/cli/build.js +++ b/packages/gitbook/src/cli/build.js @@ -1,10 +1,10 @@ -var Parse = require('../parse'); -var Output = require('../output'); -var timing = require('../utils/timing'); +const Parse = require('../parse'); +const Output = require('../output'); +const timing = require('../utils/timing'); -var options = require('./options'); -var getBook = require('./getBook'); -var getOutputFolder = require('./getOutputFolder'); +const options = require('./options'); +const getBook = require('./getBook'); +const getOutputFolder = require('./getOutputFolder'); module.exports = { @@ -15,11 +15,11 @@ module.exports = { options.format, options.timing ], - exec: function(args, kwargs) { - var book = getBook(args, kwargs); - var outputFolder = getOutputFolder(args); + exec(args, kwargs) { + const book = getBook(args, kwargs); + const outputFolder = getOutputFolder(args); - var Generator = Output.getGenerator(kwargs.format); + const Generator = Output.getGenerator(kwargs.format); return Parse.parseBook(book) .then(function(resultBook) { diff --git a/packages/gitbook/lib/cli/buildEbook.js b/packages/gitbook/src/cli/buildEbook.js index a87fac7..56e63f8 100644 --- a/packages/gitbook/lib/cli/buildEbook.js +++ b/packages/gitbook/src/cli/buildEbook.js @@ -1,13 +1,13 @@ -var path = require('path'); -var tmp = require('tmp'); +const path = require('path'); +const tmp = require('tmp'); -var Promise = require('../utils/promise'); -var fs = require('../utils/fs'); -var Parse = require('../parse'); -var Output = require('../output'); +const Promise = require('../utils/promise'); +const fs = require('../utils/fs'); +const Parse = require('../parse'); +const Output = require('../output'); -var options = require('./options'); -var getBook = require('./getBook'); +const options = require('./options'); +const getBook = require('./getBook'); module.exports = function(format) { @@ -17,37 +17,37 @@ module.exports = function(format) { options: [ options.log ], - exec: function(args, kwargs) { - var extension = '.' + format; + exec(args, kwargs) { + const extension = '.' + format; // Output file will be stored in - var outputFile = args[1] || ('book' + extension); + const outputFile = args[1] || ('book' + extension); // Create temporary directory - var outputFolder = tmp.dirSync().name; + const outputFolder = tmp.dirSync().name; - var book = getBook(args, kwargs); - var logger = book.getLogger(); - var Generator = Output.getGenerator('ebook'); + const book = getBook(args, kwargs); + const logger = book.getLogger(); + const Generator = Output.getGenerator('ebook'); return Parse.parseBook(book) .then(function(resultBook) { return Output.generate(Generator, resultBook, { root: outputFolder, - format: format + format }); }) // Extract ebook file .then(function(output) { - var book = output.getBook(); - var languages = book.getLanguages(); + const book = output.getBook(); + const languages = book.getLanguages(); if (book.isMultilingual()) { return Promise.forEach(languages.getList(), function(lang) { - var langID = lang.getID(); + const langID = lang.getID(); - var langOutputFile = path.join( + const langOutputFile = path.join( path.dirname(outputFile), path.basename(outputFile, extension) + '_' + langID + extension ); diff --git a/packages/gitbook/src/cli/getBook.js b/packages/gitbook/src/cli/getBook.js new file mode 100644 index 0000000..b37e49c --- /dev/null +++ b/packages/gitbook/src/cli/getBook.js @@ -0,0 +1,23 @@ +const path = require('path'); +const Book = require('../models/book'); +const createNodeFS = require('../fs/node'); + +/** + Return a book instance to work on from + command line args/kwargs + + @param {Array} args + @param {Object} kwargs + @return {Book} +*/ +function getBook(args, kwargs) { + const input = path.resolve(args[0] || process.cwd()); + const logLevel = kwargs.log; + + const fs = createNodeFS(input); + const book = Book.createForFS(fs); + + return book.setLogLevel(logLevel); +} + +module.exports = getBook; diff --git a/packages/gitbook/src/cli/getOutputFolder.js b/packages/gitbook/src/cli/getOutputFolder.js new file mode 100644 index 0000000..94f22da --- /dev/null +++ b/packages/gitbook/src/cli/getOutputFolder.js @@ -0,0 +1,17 @@ +const path = require('path'); + +/** + Return path to output folder + + @param {Array} args + @return {String} +*/ +function getOutputFolder(args) { + const bookRoot = path.resolve(args[0] || process.cwd()); + const defaultOutputRoot = path.join(bookRoot, '_book'); + const outputFolder = args[1] ? path.resolve(process.cwd(), args[1]) : defaultOutputRoot; + + return outputFolder; +} + +module.exports = getOutputFolder; diff --git a/packages/gitbook/lib/cli/index.js b/packages/gitbook/src/cli/index.js index f1fca1d..48ad117 100644 --- a/packages/gitbook/lib/cli/index.js +++ b/packages/gitbook/src/cli/index.js @@ -1,4 +1,4 @@ -var buildEbook = require('./buildEbook'); +const buildEbook = require('./buildEbook'); module.exports = [ require('./build'), diff --git a/packages/gitbook/src/cli/init.js b/packages/gitbook/src/cli/init.js new file mode 100644 index 0000000..51d6869 --- /dev/null +++ b/packages/gitbook/src/cli/init.js @@ -0,0 +1,17 @@ +const path = require('path'); + +const options = require('./options'); +const initBook = require('../init'); + +module.exports = { + name: 'init [book]', + description: 'setup and create files for chapters', + options: [ + options.log + ], + exec(args, kwargs) { + const bookRoot = path.resolve(process.cwd(), args[0] || './'); + + return initBook(bookRoot); + } +}; diff --git a/packages/gitbook/lib/cli/install.js b/packages/gitbook/src/cli/install.js index c001711..6af4013 100644 --- a/packages/gitbook/lib/cli/install.js +++ b/packages/gitbook/src/cli/install.js @@ -1,8 +1,8 @@ -var options = require('./options'); -var getBook = require('./getBook'); +const options = require('./options'); +const getBook = require('./getBook'); -var Parse = require('../parse'); -var Plugins = require('../plugins'); +const Parse = require('../parse'); +const Plugins = require('../plugins'); module.exports = { name: 'install [book]', @@ -10,8 +10,8 @@ module.exports = { options: [ options.log ], - exec: function(args, kwargs) { - var book = getBook(args, kwargs); + exec(args, kwargs) { + const book = getBook(args, kwargs); return Parse.parseConfig(book) .then(function(resultBook) { diff --git a/packages/gitbook/lib/cli/options.js b/packages/gitbook/src/cli/options.js index 72961ab..d643f91 100644 --- a/packages/gitbook/lib/cli/options.js +++ b/packages/gitbook/src/cli/options.js @@ -1,6 +1,6 @@ -var Logger = require('../utils/logger'); +const Logger = require('../utils/logger'); -var logOptions = { +const logOptions = { name: 'log', description: 'Minimum log level to display', values: Logger.LEVELS @@ -11,14 +11,14 @@ var logOptions = { defaults: 'info' }; -var formatOption = { +const formatOption = { name: 'format', description: 'Format to build to', values: ['website', 'json', 'ebook'], defaults: 'website' }; -var timingOption = { +const timingOption = { name: 'timing', description: 'Print timing debug information', defaults: false diff --git a/packages/gitbook/lib/cli/parse.js b/packages/gitbook/src/cli/parse.js index 0fa509a..3d38fe7 100644 --- a/packages/gitbook/lib/cli/parse.js +++ b/packages/gitbook/src/cli/parse.js @@ -1,22 +1,22 @@ -var options = require('./options'); -var getBook = require('./getBook'); +const options = require('./options'); +const getBook = require('./getBook'); -var Parse = require('../parse'); +const Parse = require('../parse'); function printBook(book) { - var logger = book.getLogger(); + const logger = book.getLogger(); - var config = book.getConfig(); - var configFile = config.getFile(); + const config = book.getConfig(); + const configFile = config.getFile(); - var summary = book.getSummary(); - var summaryFile = summary.getFile(); + const summary = book.getSummary(); + const summaryFile = summary.getFile(); - var readme = book.getReadme(); - var readmeFile = readme.getFile(); + const readme = book.getReadme(); + const readmeFile = readme.getFile(); - var glossary = book.getGlossary(); - var glossaryFile = glossary.getFile(); + const glossary = book.getGlossary(); + const glossaryFile = glossary.getFile(); if (configFile.exists()) { logger.info.ln('Configuration file is', configFile.getPath()); @@ -36,9 +36,9 @@ function printBook(book) { } function printMultingualBook(book) { - var logger = book.getLogger(); - var languages = book.getLanguages(); - var books = book.getBooks(); + const logger = book.getLogger(); + const languages = book.getLanguages(); + const books = book.getBooks(); logger.info.ln(languages.size + ' languages'); @@ -55,14 +55,14 @@ module.exports = { options: [ options.log ], - exec: function(args, kwargs) { - var book = getBook(args, kwargs); - var logger = book.getLogger(); + exec(args, kwargs) { + const book = getBook(args, kwargs); + const logger = book.getLogger(); return Parse.parseBook(book) .then(function(resultBook) { - var rootFolder = book.getRoot(); - var contentFolder = book.getContentRoot(); + const rootFolder = book.getRoot(); + const contentFolder = book.getContentRoot(); logger.info.ln('Book located in:', rootFolder); if (contentFolder != rootFolder) { diff --git a/packages/gitbook/lib/cli/serve.js b/packages/gitbook/src/cli/serve.js index 5340851..6397c2e 100644 --- a/packages/gitbook/lib/cli/serve.js +++ b/packages/gitbook/src/cli/serve.js @@ -1,24 +1,24 @@ /* eslint-disable no-console */ -var tinylr = require('tiny-lr'); -var open = require('open'); +const tinylr = require('tiny-lr'); +const open = require('open'); -var Parse = require('../parse'); -var Output = require('../output'); -var ConfigModifier = require('../modifiers').Config; +const Parse = require('../parse'); +const Output = require('../output'); +const ConfigModifier = require('../modifiers').Config; -var Promise = require('../utils/promise'); +const Promise = require('../utils/promise'); -var options = require('./options'); -var getBook = require('./getBook'); -var getOutputFolder = require('./getOutputFolder'); -var Server = require('./server'); -var watch = require('./watch'); +const options = require('./options'); +const getBook = require('./getBook'); +const getOutputFolder = require('./getOutputFolder'); +const Server = require('./server'); +const watch = require('./watch'); -var server, lrServer, lrPath; +let server, lrServer, lrPath; function waitForCtrlC() { - var d = Promise.defer(); + const d = Promise.defer(); process.on('SIGINT', function() { d.resolve(); @@ -29,15 +29,15 @@ function waitForCtrlC() { function generateBook(args, kwargs) { - var port = kwargs.port; - var outputFolder = getOutputFolder(args); - var book = getBook(args, kwargs); - var Generator = Output.getGenerator(kwargs.format); - var browser = kwargs['browser']; + const port = kwargs.port; + const outputFolder = getOutputFolder(args); + const book = getBook(args, kwargs); + const Generator = Output.getGenerator(kwargs.format); + const browser = kwargs['browser']; - var hasWatch = kwargs['watch']; - var hasLiveReloading = kwargs['live']; - var hasOpen = kwargs['open']; + const hasWatch = kwargs['watch']; + const hasLiveReloading = kwargs['live']; + const hasOpen = kwargs['open']; // Stop server if running if (server.isRunning()) console.log('Stopping server'); @@ -48,7 +48,7 @@ function generateBook(args, kwargs) { .then(function(resultBook) { if (hasLiveReloading) { // Enable livereload plugin - var config = resultBook.getConfig(); + let config = resultBook.getConfig(); config = ConfigModifier.addPlugin(config, 'livereload'); resultBook = resultBook.set('config', config); } @@ -64,7 +64,7 @@ function generateBook(args, kwargs) { return server.start(outputFolder, port); }) .then(function() { - console.log('Serving book on http://localhost:'+port); + console.log('Serving book on http://localhost:' + port); if (lrPath && hasLiveReloading) { // trigger livereload @@ -76,7 +76,7 @@ function generateBook(args, kwargs) { } if (hasOpen) { - open('http://localhost:'+port, browser); + open('http://localhost:' + port, browser); } }) .then(function() { @@ -132,10 +132,10 @@ module.exports = { options.log, options.format ], - exec: function(args, kwargs) { + exec(args, kwargs) { server = new Server(); - var hasWatch = kwargs['watch']; - var hasLiveReloading = kwargs['live']; + const hasWatch = kwargs['watch']; + const hasLiveReloading = kwargs['live']; return Promise() .then(function() { diff --git a/packages/gitbook/src/cli/server.js b/packages/gitbook/src/cli/server.js new file mode 100644 index 0000000..c494efc --- /dev/null +++ b/packages/gitbook/src/cli/server.js @@ -0,0 +1,127 @@ +const events = require('events'); +const http = require('http'); +const send = require('send'); +const url = require('url'); + +const Promise = require('../utils/promise'); + +class Server extends events.EventEmitter { + constructor() { + super(); + this.running = null; + this.dir = null; + this.port = 0; + this.sockets = []; + } + + /** + * Return true if the server is running + * @return {Boolean} + */ + isRunning() { + return !!this.running; + } + + /** + * Stop the server + * @return {Promise} + */ + stop() { + const that = this; + if (!this.isRunning()) return Promise(); + + const d = Promise.defer(); + this.running.close(function(err) { + that.running = null; + that.emit('state', false); + + if (err) d.reject(err); + else d.resolve(); + }); + + for (let i = 0; i < this.sockets.length; i++) { + this.sockets[i].destroy(); + } + + return d.promise; + } + + /** + * Start the server + * @return {Promise} + */ + start(dir, port) { + const that = this; + let pre = Promise(); + port = port || 8004; + + if (that.isRunning()) pre = this.stop(); + return pre + .then(function() { + const d = Promise.defer(); + + that.running = http.createServer(function(req, res) { + // Render error + function error(err) { + res.statusCode = err.status || 500; + res.end(err.message); + } + + // Redirect to directory's index.html + function redirect() { + const resultURL = urlTransform(req.url, function(parsed) { + parsed.pathname += '/'; + return parsed; + }); + + res.statusCode = 301; + res.setHeader('Location', resultURL); + res.end('Redirecting to ' + resultURL); + } + + res.setHeader('X-Current-Location', req.url); + + // Send file + send(req, url.parse(req.url).pathname, { + root: dir + }) + .on('error', error) + .on('directory', redirect) + .pipe(res); + }); + + that.running.on('connection', function(socket) { + that.sockets.push(socket); + socket.setTimeout(4000); + socket.on('close', function() { + that.sockets.splice(that.sockets.indexOf(socket), 1); + }); + }); + + that.running.listen(port, function(err) { + if (err) return d.reject(err); + + that.port = port; + that.dir = dir; + that.emit('state', true); + d.resolve(); + }); + + return d.promise; + }); + } +} + +/** + * urlTransform is a helper function that allows a function to transform + * a url string in it's parsed form and returns the new url as a string + * + * @param {String} uri + * @param {Function} fn + * @return {String} + */ +function urlTransform(uri, fn) { + return url.format(fn(url.parse(uri))); +} + +module.exports = Server; diff --git a/packages/gitbook/lib/cli/watch.js b/packages/gitbook/src/cli/watch.js index 14434ab..e1d453c 100644 --- a/packages/gitbook/lib/cli/watch.js +++ b/packages/gitbook/src/cli/watch.js @@ -1,8 +1,8 @@ -var path = require('path'); -var chokidar = require('chokidar'); +const path = require('path'); +const chokidar = require('chokidar'); -var Promise = require('../utils/promise'); -var parsers = require('../parsers'); +const Promise = require('../utils/promise'); +const parsers = require('../parsers'); /** Watch a folder and resolve promise once a file is modified @@ -11,19 +11,19 @@ var parsers = require('../parsers'); @return {Promise} */ function watch(dir) { - var d = Promise.defer(); + const d = Promise.defer(); dir = path.resolve(dir); - var toWatch = [ + const toWatch = [ 'book.json', 'book.js', '_layouts/**' ]; // Watch all parsable files parsers.extensions.forEach(function(ext) { - toWatch.push('**/*'+ext); + toWatch.push('**/*' + ext); }); - var watcher = chokidar.watch(toWatch, { + const watcher = chokidar.watch(toWatch, { cwd: dir, ignored: '_book/**', ignoreInitial: true diff --git a/packages/gitbook/lib/constants/__tests__/configSchema.js b/packages/gitbook/src/constants/__tests__/configSchema.js index efc99b9..df83680 100644 --- a/packages/gitbook/lib/constants/__tests__/configSchema.js +++ b/packages/gitbook/src/constants/__tests__/configSchema.js @@ -1,10 +1,10 @@ -var jsonschema = require('jsonschema'); -var schema = require('../configSchema'); +const jsonschema = require('jsonschema'); +const schema = require('../configSchema'); describe('configSchema', function() { function validate(cfg) { - var v = new jsonschema.Validator(); + const v = new jsonschema.Validator(); return v.validate(cfg, schema, { propertyName: 'config' }); @@ -13,7 +13,7 @@ describe('configSchema', function() { describe('structure', function() { it('should accept dot in filename', function() { - var result = validate({ + const result = validate({ structure: { readme: 'book-intro.adoc' } @@ -23,7 +23,7 @@ describe('configSchema', function() { }); it('should accept uppercase in filename', function() { - var result = validate({ + const result = validate({ structure: { readme: 'BOOK.adoc' } @@ -33,7 +33,7 @@ describe('configSchema', function() { }); it('should not accept filepath', function() { - var result = validate({ + const result = validate({ structure: { readme: 'folder/myFile.md' } diff --git a/packages/gitbook/src/constants/configDefault.js b/packages/gitbook/src/constants/configDefault.js new file mode 100644 index 0000000..c384c6c --- /dev/null +++ b/packages/gitbook/src/constants/configDefault.js @@ -0,0 +1,6 @@ +const Immutable = require('immutable'); +const jsonSchemaDefaults = require('json-schema-defaults'); + +const schema = require('./configSchema'); + +module.exports = Immutable.fromJS(jsonSchemaDefaults(schema)); diff --git a/packages/gitbook/lib/constants/configFiles.js b/packages/gitbook/src/constants/configFiles.js index a67fd74..a67fd74 100644 --- a/packages/gitbook/lib/constants/configFiles.js +++ b/packages/gitbook/src/constants/configFiles.js diff --git a/packages/gitbook/lib/constants/configSchema.js b/packages/gitbook/src/constants/configSchema.js index d2126c6..9aaf8cd 100644 --- a/packages/gitbook/lib/constants/configSchema.js +++ b/packages/gitbook/src/constants/configSchema.js @@ -1,4 +1,4 @@ -var FILENAME_REGEX = '^[a-zA-Z-._\d,\s]+$'; +const FILENAME_REGEX = '^[a-zA-Z-._\d,\s]+$'; module.exports = { '$schema': 'http://json-schema.org/schema#', diff --git a/packages/gitbook/lib/constants/defaultBlocks.js b/packages/gitbook/src/constants/defaultBlocks.js index 74d1f1f..05c9b09 100644 --- a/packages/gitbook/lib/constants/defaultBlocks.js +++ b/packages/gitbook/src/constants/defaultBlocks.js @@ -1,17 +1,17 @@ -var Immutable = require('immutable'); -var TemplateBlock = require('../models/templateBlock'); +const Immutable = require('immutable'); +const TemplateBlock = require('../models/templateBlock'); module.exports = Immutable.Map({ html: TemplateBlock({ name: 'html', - process: function(blk) { + process(blk) { return blk; } }), code: TemplateBlock({ name: 'code', - process: function(blk) { + process(blk) { return { html: false, body: blk.body @@ -21,7 +21,7 @@ module.exports = Immutable.Map({ markdown: TemplateBlock({ name: 'markdown', - process: function(blk) { + process(blk) { return this.book.renderInline('markdown', blk.body) .then(function(out) { return { body: out }; @@ -31,7 +31,7 @@ module.exports = Immutable.Map({ asciidoc: TemplateBlock({ name: 'asciidoc', - process: function(blk) { + process(blk) { return this.book.renderInline('asciidoc', blk.body) .then(function(out) { return { body: out }; @@ -41,7 +41,7 @@ module.exports = Immutable.Map({ markup: TemplateBlock({ name: 'markup', - process: function(blk) { + process(blk) { return this.book.renderInline(this.ctx.file.type, blk.body) .then(function(out) { return { body: out }; diff --git a/packages/gitbook/lib/constants/defaultFilters.js b/packages/gitbook/src/constants/defaultFilters.js index 35025cc..c9bffe1 100644 --- a/packages/gitbook/lib/constants/defaultFilters.js +++ b/packages/gitbook/src/constants/defaultFilters.js @@ -1,15 +1,15 @@ -var Immutable = require('immutable'); -var moment = require('moment'); +const Immutable = require('immutable'); +const moment = require('moment'); module.exports = Immutable.Map({ // Format a date // ex: 'MMMM Do YYYY, h:mm:ss a - date: function(time, format) { + date(time, format) { return moment(time).format(format); }, // Relative Time - dateFromNow: function(time) { + dateFromNow(time) { return moment(time).fromNow(); } }); diff --git a/packages/gitbook/lib/constants/defaultPlugins.js b/packages/gitbook/src/constants/defaultPlugins.js index 6d15971..cd1c0c8 100644 --- a/packages/gitbook/lib/constants/defaultPlugins.js +++ b/packages/gitbook/src/constants/defaultPlugins.js @@ -1,7 +1,7 @@ -var Immutable = require('immutable'); -var PluginDependency = require('../models/pluginDependency'); +const Immutable = require('immutable'); +const PluginDependency = require('../models/pluginDependency'); -var pkg = require('../../package.json'); +const pkg = require('../../package.json'); /** * Create a PluginDependency from a dependency of gitbook @@ -9,8 +9,8 @@ var pkg = require('../../package.json'); * @return {PluginDependency} */ function createFromDependency(pluginName) { - var npmID = PluginDependency.nameToNpmID(pluginName); - var version = pkg.dependencies[npmID]; + const npmID = PluginDependency.nameToNpmID(pluginName); + const version = pkg.dependencies[npmID]; return PluginDependency.create(pluginName, version); } diff --git a/packages/gitbook/lib/constants/extsAsciidoc.js b/packages/gitbook/src/constants/extsAsciidoc.js index b2f4ce4..b2f4ce4 100644 --- a/packages/gitbook/lib/constants/extsAsciidoc.js +++ b/packages/gitbook/src/constants/extsAsciidoc.js diff --git a/packages/gitbook/lib/constants/extsMarkdown.js b/packages/gitbook/src/constants/extsMarkdown.js index 44bf36b..44bf36b 100644 --- a/packages/gitbook/lib/constants/extsMarkdown.js +++ b/packages/gitbook/src/constants/extsMarkdown.js diff --git a/packages/gitbook/lib/constants/ignoreFiles.js b/packages/gitbook/src/constants/ignoreFiles.js index aac225e..aac225e 100644 --- a/packages/gitbook/lib/constants/ignoreFiles.js +++ b/packages/gitbook/src/constants/ignoreFiles.js diff --git a/packages/gitbook/lib/constants/pluginAssetsFolder.js b/packages/gitbook/src/constants/pluginAssetsFolder.js index cd44722..cd44722 100644 --- a/packages/gitbook/lib/constants/pluginAssetsFolder.js +++ b/packages/gitbook/src/constants/pluginAssetsFolder.js diff --git a/packages/gitbook/lib/constants/pluginHooks.js b/packages/gitbook/src/constants/pluginHooks.js index 2d5dcaa..2d5dcaa 100644 --- a/packages/gitbook/lib/constants/pluginHooks.js +++ b/packages/gitbook/src/constants/pluginHooks.js diff --git a/packages/gitbook/lib/constants/pluginPrefix.js b/packages/gitbook/src/constants/pluginPrefix.js index c7f2dd0..c7f2dd0 100644 --- a/packages/gitbook/lib/constants/pluginPrefix.js +++ b/packages/gitbook/src/constants/pluginPrefix.js diff --git a/packages/gitbook/lib/constants/pluginResources.js b/packages/gitbook/src/constants/pluginResources.js index ae283bf..cc9d134 100644 --- a/packages/gitbook/lib/constants/pluginResources.js +++ b/packages/gitbook/src/constants/pluginResources.js @@ -1,4 +1,4 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); module.exports = Immutable.List([ 'js', diff --git a/packages/gitbook/lib/constants/templatesFolder.js b/packages/gitbook/src/constants/templatesFolder.js index aad6a72..aad6a72 100644 --- a/packages/gitbook/lib/constants/templatesFolder.js +++ b/packages/gitbook/src/constants/templatesFolder.js diff --git a/packages/gitbook/lib/constants/themePrefix.js b/packages/gitbook/src/constants/themePrefix.js index 99428de..621e85c 100644 --- a/packages/gitbook/lib/constants/themePrefix.js +++ b/packages/gitbook/src/constants/themePrefix.js @@ -1,4 +1,4 @@ /* All GitBook themes plugins name start with this prefix once shorted. */ -module.exports = 'theme-';
\ No newline at end of file +module.exports = 'theme-'; diff --git a/packages/gitbook/lib/fs/__tests__/mock.js b/packages/gitbook/src/fs/__tests__/mock.js index 04bd46a..7d1ea48 100644 --- a/packages/gitbook/lib/fs/__tests__/mock.js +++ b/packages/gitbook/src/fs/__tests__/mock.js @@ -1,7 +1,7 @@ -var createMockFS = require('../mock'); +const createMockFS = require('../mock'); describe('MockFS', function() { - var fs = createMockFS({ + const fs = createMockFS({ 'README.md': 'Hello World', 'SUMMARY.md': '# Summary', 'folder': { @@ -79,4 +79,3 @@ describe('MockFS', function() { }); }); - diff --git a/packages/gitbook/lib/fs/mock.js b/packages/gitbook/src/fs/mock.js index 784c533..91f3bd6 100644 --- a/packages/gitbook/lib/fs/mock.js +++ b/packages/gitbook/src/fs/mock.js @@ -1,10 +1,10 @@ -var path = require('path'); -var is = require('is'); -var Buffer = require('buffer').Buffer; -var Immutable = require('immutable'); +const path = require('path'); +const is = require('is'); +const Buffer = require('buffer').Buffer; +const Immutable = require('immutable'); -var FS = require('../models/fs'); -var error = require('../utils/error'); +const FS = require('../models/fs'); +const error = require('../utils/error'); /** Create a fake filesystem for unit testing GitBook. @@ -13,14 +13,14 @@ var error = require('../utils/error'); */ function createMockFS(files) { files = Immutable.fromJS(files); - var mtime = new Date(); + const mtime = new Date(); function getFile(filePath) { - var parts = path.normalize(filePath).split(path.sep); + const parts = path.normalize(filePath).split(path.sep); return parts.reduce(function(list, part, i) { if (!list) return null; - var file; + let file; if (!part || part === '.') file = list; else file = list.get(part); @@ -41,7 +41,7 @@ function createMockFS(files) { } function fsReadFile(filePath) { - var file = getFile(filePath); + const file = getFile(filePath); if (!is.string(file)) { throw error.FileNotFoundError({ filename: filePath @@ -52,7 +52,7 @@ function createMockFS(files) { } function fsStatFile(filePath) { - var file = getFile(filePath); + const file = getFile(filePath); if (!file) { throw error.FileNotFoundError({ filename: filePath @@ -60,12 +60,12 @@ function createMockFS(files) { } return { - mtime: mtime + mtime }; } function fsReadDir(filePath) { - var dir = getFile(filePath); + const dir = getFile(filePath); if (!dir || is.string(dir)) { throw error.FileNotFoundError({ filename: filePath @@ -85,10 +85,10 @@ function createMockFS(files) { return FS.create({ root: '', - fsExists: fsExists, - fsReadFile: fsReadFile, - fsStatFile: fsStatFile, - fsReadDir: fsReadDir + fsExists, + fsReadFile, + fsStatFile, + fsReadDir }); } diff --git a/packages/gitbook/lib/fs/node.js b/packages/gitbook/src/fs/node.js index dfe9fae..6e28daf 100644 --- a/packages/gitbook/lib/fs/node.js +++ b/packages/gitbook/src/fs/node.js @@ -1,9 +1,9 @@ -var path = require('path'); -var Immutable = require('immutable'); -var fresh = require('fresh-require'); +const path = require('path'); +const Immutable = require('immutable'); +const fresh = require('fresh-require'); -var fs = require('../utils/fs'); -var FS = require('../models/fs'); +const fs = require('../utils/fs'); +const FS = require('../models/fs'); function fsReadDir(folder) { return fs.readdir(folder) @@ -14,7 +14,7 @@ function fsReadDir(folder) { .map(function(file) { if (file == '.' || file == '..') return; - var stat = fs.statSync(path.join(folder, file)); + const stat = fs.statSync(path.join(folder, file)); if (stat.isDirectory()) file = file + path.sep; return file; }) @@ -30,13 +30,13 @@ function fsLoadObject(filename) { module.exports = function createNodeFS(root) { return FS.create({ - root: root, + root, fsExists: fs.exists, fsReadFile: fs.readFile, fsStatFile: fs.stat, - fsReadDir: fsReadDir, - fsLoadObject: fsLoadObject, + fsReadDir, + fsLoadObject, fsReadAsStream: fs.readStream }); }; diff --git a/packages/gitbook/lib/gitbook.js b/packages/gitbook/src/gitbook.js index bafd3b8..5786e68 100644 --- a/packages/gitbook/lib/gitbook.js +++ b/packages/gitbook/src/gitbook.js @@ -1,10 +1,10 @@ -var semver = require('semver'); -var pkg = require('../package.json'); +const semver = require('semver'); +const pkg = require('../package.json'); -var VERSION = pkg.version; -var VERSION_STABLE = VERSION.replace(/\-(\S+)/g, ''); +const VERSION = pkg.version; +const VERSION_STABLE = VERSION.replace(/\-(\S+)/g, ''); -var START_TIME = new Date(); +const START_TIME = new Date(); /** Verify that this gitbook version satisfies a requirement @@ -23,6 +23,6 @@ function satisfies(condition) { module.exports = { version: pkg.version, - satisfies: satisfies, - START_TIME: START_TIME + satisfies, + START_TIME }; diff --git a/packages/gitbook/lib/index.js b/packages/gitbook/src/index.js index 1f683e2..7919000 100644 --- a/packages/gitbook/lib/index.js +++ b/packages/gitbook/src/index.js @@ -1,6 +1,6 @@ -var extend = require('extend'); +const extend = require('extend'); -var common = require('./browser'); +const common = require('./browser'); module.exports = extend({ initBook: require('./init'), diff --git a/packages/gitbook/lib/init.js b/packages/gitbook/src/init.js index c112d4d..bbd5f90 100644 --- a/packages/gitbook/lib/init.js +++ b/packages/gitbook/src/init.js @@ -1,12 +1,12 @@ -var path = require('path'); +const path = require('path'); -var createNodeFS = require('./fs/node'); -var fs = require('./utils/fs'); -var Promise = require('./utils/promise'); -var File = require('./models/file'); -var Readme = require('./models/readme'); -var Book = require('./models/book'); -var Parse = require('./parse'); +const createNodeFS = require('./fs/node'); +const fs = require('./utils/fs'); +const Promise = require('./utils/promise'); +const File = require('./models/file'); +const Readme = require('./models/readme'); +const Book = require('./models/book'); +const Parse = require('./parse'); /** Initialize folder structure for a book @@ -17,38 +17,38 @@ var Parse = require('./parse'); @return {Promise} */ function initBook(rootFolder) { - var extension = '.md'; + const extension = '.md'; return fs.mkdirp(rootFolder) // Parse the summary and readme .then(function() { - var fs = createNodeFS(rootFolder); - var book = Book.createForFS(fs); + const bookFS = createNodeFS(rootFolder); + const book = Book.createForFS(bookFS); return Parse.parseReadme(book) // Setup default readme if doesn't found one .fail(function() { - var readmeFile = File.createWithFilepath('README' + extension); - var readme = Readme.create(readmeFile); + const readmeFile = File.createWithFilepath('README' + extension); + const readme = Readme.create(readmeFile); return book.setReadme(readme); }); }) .then(Parse.parseSummary) .then(function(book) { - var logger = book.getLogger(); - var summary = book.getSummary(); - var summaryFile = summary.getFile(); - var summaryFilename = summaryFile.getPath() || ('SUMMARY' + extension); + const logger = book.getLogger(); + const summary = book.getSummary(); + const summaryFile = summary.getFile(); + const summaryFilename = summaryFile.getPath() || ('SUMMARY' + extension); - var articles = summary.getArticlesAsList(); + const articles = summary.getArticlesAsList(); // Write pages return Promise.forEach(articles, function(article) { - var articlePath = article.getPath(); - var filePath = articlePath? path.join(rootFolder, articlePath) : null; + const articlePath = article.getPath(); + const filePath = articlePath ? path.join(rootFolder, articlePath) : null; if (!filePath) { return; } @@ -64,7 +64,7 @@ function initBook(rootFolder) { // Write summary .then(function() { - var filePath = path.join(rootFolder, summaryFilename); + const filePath = path.join(rootFolder, summaryFilename); return fs.ensureFile(filePath) .then(function() { diff --git a/packages/gitbook/src/json/encodeBook.js b/packages/gitbook/src/json/encodeBook.js new file mode 100644 index 0000000..0b259a9 --- /dev/null +++ b/packages/gitbook/src/json/encodeBook.js @@ -0,0 +1,39 @@ +const extend = require('extend'); + +const gitbook = require('../gitbook'); +const encodeSummary = require('./encodeSummary'); +const encodeGlossary = require('./encodeGlossary'); +const encodeReadme = require('./encodeReadme'); +const encodeLanguages = require('./encodeLanguages'); + +/** + Encode a book to JSON + + @param {Book} + @return {Object} +*/ +function encodeBookToJson(book) { + const config = book.getConfig(); + const language = book.getLanguage(); + + const variables = config.getValue('variables', {}); + + return { + summary: encodeSummary(book.getSummary()), + glossary: encodeGlossary(book.getGlossary()), + readme: encodeReadme(book.getReadme()), + config: book.getConfig().getValues().toJS(), + + languages: book.isMultilingual() ? encodeLanguages(book.getLanguages()) : undefined, + + gitbook: { + version: gitbook.version, + time: gitbook.START_TIME + }, + book: extend({ + language: language ? language : undefined + }, variables.toJS()) + }; +} + +module.exports = encodeBookToJson; diff --git a/packages/gitbook/lib/json/encodeBookWithPage.js b/packages/gitbook/src/json/encodeBookWithPage.js index 1c5c7a3..f593af2 100644 --- a/packages/gitbook/lib/json/encodeBookWithPage.js +++ b/packages/gitbook/src/json/encodeBookWithPage.js @@ -1,6 +1,6 @@ -var encodeBook = require('./encodeBook'); -var encodePage = require('./encodePage'); -var encodeFile = require('./encodeFile'); +const encodeBook = require('./encodeBook'); +const encodePage = require('./encodePage'); +const encodeFile = require('./encodeFile'); /** * Return a JSON representation of a book with a specific file @@ -10,9 +10,9 @@ var encodeFile = require('./encodeFile'); * @return {Object} */ function encodeBookWithPage(book, page) { - var file = page.getFile(); + const file = page.getFile(); - var result = encodeBook(book); + const result = encodeBook(book); result.page = encodePage(page, book.getSummary()); result.file = encodeFile(file); diff --git a/packages/gitbook/lib/json/encodeFile.js b/packages/gitbook/src/json/encodeFile.js index d2c9e8a..487a74c 100644 --- a/packages/gitbook/lib/json/encodeFile.js +++ b/packages/gitbook/src/json/encodeFile.js @@ -6,7 +6,7 @@ @return {Object} */ function encodeFileToJson(file) { - var filePath = file.getPath(); + const filePath = file.getPath(); if (!filePath) { return undefined; } diff --git a/packages/gitbook/lib/json/encodeGlossary.js b/packages/gitbook/src/json/encodeGlossary.js index e9bcfc9..6bdd683 100644 --- a/packages/gitbook/lib/json/encodeGlossary.js +++ b/packages/gitbook/src/json/encodeGlossary.js @@ -1,5 +1,5 @@ -var encodeFile = require('./encodeFile'); -var encodeGlossaryEntry = require('./encodeGlossaryEntry'); +const encodeFile = require('./encodeFile'); +const encodeGlossaryEntry = require('./encodeGlossaryEntry'); /** Encode a glossary to JSON @@ -8,8 +8,8 @@ var encodeGlossaryEntry = require('./encodeGlossaryEntry'); @return {Object} */ function encodeGlossary(glossary) { - var file = glossary.getFile(); - var entries = glossary.getEntries(); + const file = glossary.getFile(); + const entries = glossary.getEntries(); return { file: encodeFile(file), diff --git a/packages/gitbook/lib/json/encodeGlossaryEntry.js b/packages/gitbook/src/json/encodeGlossaryEntry.js index d163f45..d163f45 100644 --- a/packages/gitbook/lib/json/encodeGlossaryEntry.js +++ b/packages/gitbook/src/json/encodeGlossaryEntry.js diff --git a/packages/gitbook/lib/json/encodeLanguages.js b/packages/gitbook/src/json/encodeLanguages.js index 8447e80..fc7487b 100644 --- a/packages/gitbook/lib/json/encodeLanguages.js +++ b/packages/gitbook/src/json/encodeLanguages.js @@ -1,4 +1,4 @@ -var encodeFile = require('./encodeFile'); +const encodeFile = require('./encodeFile'); /** Encode a languages listing to JSON @@ -7,8 +7,8 @@ var encodeFile = require('./encodeFile'); @return {Object} */ function encodeLanguages(languages) { - var file = languages.getFile(); - var list = languages.getList(); + const file = languages.getFile(); + const list = languages.getList(); return { file: encodeFile(file), diff --git a/packages/gitbook/lib/json/encodeOutput.js b/packages/gitbook/src/json/encodeOutput.js index 7347e57..31e5757 100644 --- a/packages/gitbook/lib/json/encodeOutput.js +++ b/packages/gitbook/src/json/encodeOutput.js @@ -1,4 +1,4 @@ -var encodeBook = require('./encodeBook'); +const encodeBook = require('./encodeBook'); /** * Encode an output to JSON @@ -7,11 +7,11 @@ var encodeBook = require('./encodeBook'); * @return {Object} */ function encodeOutputToJson(output) { - var book = output.getBook(); - var generator = output.getGenerator(); - var options = output.getOptions(); + const book = output.getBook(); + const generator = output.getGenerator(); + const options = output.getOptions(); - var result = encodeBook(book); + const result = encodeBook(book); result.output = { name: generator diff --git a/packages/gitbook/lib/json/encodeOutputWithPage.js b/packages/gitbook/src/json/encodeOutputWithPage.js index 8b21e3d..58db070 100644 --- a/packages/gitbook/lib/json/encodeOutputWithPage.js +++ b/packages/gitbook/src/json/encodeOutputWithPage.js @@ -1,6 +1,6 @@ -var encodeOutput = require('./encodeOutput'); -var encodePage = require('./encodePage'); -var encodeFile = require('./encodeFile'); +const encodeOutput = require('./encodeOutput'); +const encodePage = require('./encodePage'); +const encodeFile = require('./encodeFile'); /** * Return a JSON representation of a book with a specific file @@ -10,10 +10,10 @@ var encodeFile = require('./encodeFile'); * @return {Object} */ function encodeOutputWithPage(output, page) { - var file = page.getFile(); - var book = output.getBook(); + const file = page.getFile(); + const book = output.getBook(); - var result = encodeOutput(output); + const result = encodeOutput(output); result.page = encodePage(page, book.getSummary()); result.file = encodeFile(file); diff --git a/packages/gitbook/lib/json/encodePage.js b/packages/gitbook/src/json/encodePage.js index be92117..b20a40c 100644 --- a/packages/gitbook/lib/json/encodePage.js +++ b/packages/gitbook/src/json/encodePage.js @@ -1,4 +1,4 @@ -var encodeSummaryArticle = require('./encodeSummaryArticle'); +const encodeSummaryArticle = require('./encodeSummaryArticle'); /** Return a JSON representation of a page @@ -8,23 +8,23 @@ var encodeSummaryArticle = require('./encodeSummaryArticle'); @return {Object} */ function encodePage(page, summary) { - var file = page.getFile(); - var attributes = page.getAttributes(); - var article = summary.getByPath(file.getPath()); + const file = page.getFile(); + const attributes = page.getAttributes(); + const article = summary.getByPath(file.getPath()); - var result = attributes.toJS(); + const result = attributes.toJS(); if (article) { result.title = article.getTitle(); result.level = article.getLevel(); result.depth = article.getDepth(); - var nextArticle = summary.getNextArticle(article); + const nextArticle = summary.getNextArticle(article); if (nextArticle) { result.next = encodeSummaryArticle(nextArticle); } - var prevArticle = summary.getPrevArticle(article); + const prevArticle = summary.getPrevArticle(article); if (prevArticle) { result.previous = encodeSummaryArticle(prevArticle); } diff --git a/packages/gitbook/lib/json/encodeReadme.js b/packages/gitbook/src/json/encodeReadme.js index 96176a3..cc71bcb 100644 --- a/packages/gitbook/lib/json/encodeReadme.js +++ b/packages/gitbook/src/json/encodeReadme.js @@ -1,4 +1,4 @@ -var encodeFile = require('./encodeFile'); +const encodeFile = require('./encodeFile'); /** Encode a readme to JSON @@ -7,7 +7,7 @@ var encodeFile = require('./encodeFile'); @return {Object} */ function encodeReadme(readme) { - var file = readme.getFile(); + const file = readme.getFile(); return { file: encodeFile(file) diff --git a/packages/gitbook/lib/json/encodeSummary.js b/packages/gitbook/src/json/encodeSummary.js index 97db910..9a07da4 100644 --- a/packages/gitbook/lib/json/encodeSummary.js +++ b/packages/gitbook/src/json/encodeSummary.js @@ -1,5 +1,5 @@ -var encodeFile = require('./encodeFile'); -var encodeSummaryPart = require('./encodeSummaryPart'); +const encodeFile = require('./encodeFile'); +const encodeSummaryPart = require('./encodeSummaryPart'); /** Encode a summary to JSON @@ -8,8 +8,8 @@ var encodeSummaryPart = require('./encodeSummaryPart'); @return {Object} */ function encodeSummary(summary) { - var file = summary.getFile(); - var parts = summary.getParts(); + const file = summary.getFile(); + const parts = summary.getParts(); return { file: encodeFile(file), diff --git a/packages/gitbook/lib/json/encodeSummaryArticle.js b/packages/gitbook/src/json/encodeSummaryArticle.js index 2fc5144..0b9461c 100644 --- a/packages/gitbook/lib/json/encodeSummaryArticle.js +++ b/packages/gitbook/src/json/encodeSummaryArticle.js @@ -6,7 +6,7 @@ @return {Object} */ function encodeSummaryArticle(article, recursive) { - var articles = undefined; + let articles = undefined; if (recursive !== false) { articles = article.getArticles() .map(encodeSummaryArticle) @@ -21,7 +21,7 @@ function encodeSummaryArticle(article, recursive) { url: article.getUrl(), path: article.getPath(), ref: article.getRef(), - articles: articles + articles }; } diff --git a/packages/gitbook/lib/json/encodeSummaryPart.js b/packages/gitbook/src/json/encodeSummaryPart.js index a5e7218..eb16719 100644 --- a/packages/gitbook/lib/json/encodeSummaryPart.js +++ b/packages/gitbook/src/json/encodeSummaryPart.js @@ -1,4 +1,4 @@ -var encodeSummaryArticle = require('./encodeSummaryArticle'); +const encodeSummaryArticle = require('./encodeSummaryArticle'); /** Encode a SummaryPart to JSON diff --git a/packages/gitbook/lib/json/index.js b/packages/gitbook/src/json/index.js index 3b68f5e..3b68f5e 100644 --- a/packages/gitbook/lib/json/index.js +++ b/packages/gitbook/src/json/index.js diff --git a/packages/gitbook/lib/models/__tests__/config.js b/packages/gitbook/src/models/__tests__/config.js index abad754..a865f96 100644 --- a/packages/gitbook/lib/models/__tests__/config.js +++ b/packages/gitbook/src/models/__tests__/config.js @@ -1,8 +1,8 @@ -var Immutable = require('immutable'); -var Config = require('../config'); +const Immutable = require('immutable'); +const Config = require('../config'); describe('Config', function() { - var config = Config.createWithValues({ + const config = Config.createWithValues({ hello: { world: 1, test: 'Hello', @@ -12,32 +12,32 @@ describe('Config', function() { describe('getValue', function() { it('must return value as immutable', function() { - var value = config.getValue('hello'); + const value = config.getValue('hello'); expect(Immutable.Map.isMap(value)).toBeTruthy(); }); it('must return deep value', function() { - var value = config.getValue('hello.world'); + const value = config.getValue('hello.world'); expect(value).toBe(1); }); it('must return default value if non existant', function() { - var value = config.getValue('hello.nonExistant', 'defaultValue'); + const value = config.getValue('hello.nonExistant', 'defaultValue'); expect(value).toBe('defaultValue'); }); it('must not return default value for falsy values', function() { - var value = config.getValue('hello.isFalse', 'defaultValue'); + const value = config.getValue('hello.isFalse', 'defaultValue'); expect(value).toBe(false); }); }); describe('setValue', function() { it('must set value as immutable', function() { - var testConfig = config.setValue('hello', { + const testConfig = config.setValue('hello', { 'cool': 1 }); - var value = testConfig.getValue('hello'); + const value = testConfig.getValue('hello'); expect(Immutable.Map.isMap(value)).toBeTruthy(); expect(value.size).toBe(1); @@ -45,9 +45,9 @@ describe('Config', function() { }); it('must set deep value', function() { - var testConfig = config.setValue('hello.world', 2); - var hello = testConfig.getValue('hello'); - var world = testConfig.getValue('hello.world'); + const testConfig = config.setValue('hello.world', 2); + const hello = testConfig.getValue('hello'); + const world = testConfig.getValue('hello.world'); expect(Immutable.Map.isMap(hello)).toBeTruthy(); expect(hello.size).toBe(3); @@ -58,11 +58,11 @@ describe('Config', function() { describe('toReducedVersion', function() { it('must only return diffs for simple values', function() { - var _config = Config.createWithValues({ + const _config = Config.createWithValues({ gitbook: '3.0.0' }); - var reducedVersion = _config.toReducedVersion(); + const reducedVersion = _config.toReducedVersion(); expect(reducedVersion.toJS()).toEqual({ gitbook: '3.0.0' @@ -70,13 +70,13 @@ describe('Config', function() { }); it('must only return diffs for deep values', function() { - var _config = Config.createWithValues({ + const _config = Config.createWithValues({ structure: { readme: 'intro.md' } }); - var reducedVersion = _config.toReducedVersion(); + const reducedVersion = _config.toReducedVersion(); expect(reducedVersion.toJS()).toEqual({ structure: { @@ -87,4 +87,3 @@ describe('Config', function() { }); }); - diff --git a/packages/gitbook/lib/models/__tests__/glossary.js b/packages/gitbook/src/models/__tests__/glossary.js index 5bf64dc..b50338a 100644 --- a/packages/gitbook/lib/models/__tests__/glossary.js +++ b/packages/gitbook/src/models/__tests__/glossary.js @@ -1,9 +1,9 @@ -var File = require('../file'); -var Glossary = require('../glossary'); -var GlossaryEntry = require('../glossaryEntry'); +const File = require('../file'); +const Glossary = require('../glossary'); +const GlossaryEntry = require('../glossaryEntry'); describe('Glossary', function() { - var glossary = Glossary.createFromEntries(File(), [ + const glossary = Glossary.createFromEntries(File(), [ { name: 'Hello World', description: 'Awesome!' @@ -16,13 +16,13 @@ describe('Glossary', function() { describe('createFromEntries', function() { it('must add all entries', function() { - var entries = glossary.getEntries(); + const entries = glossary.getEntries(); expect(entries.size).toBe(2); }); it('must add entries as GlossaryEntries', function() { - var entries = glossary.getEntries(); - var entry = entries.get('hello-world'); + const entries = glossary.getEntries(); + const entry = entries.get('hello-world'); expect(entry instanceof GlossaryEntry).toBeTruthy(); }); }); @@ -37,4 +37,3 @@ describe('Glossary', function() { }); }); - diff --git a/packages/gitbook/lib/models/__tests__/glossaryEntry.js b/packages/gitbook/src/models/__tests__/glossaryEntry.js index 833115d..66ddab4 100644 --- a/packages/gitbook/lib/models/__tests__/glossaryEntry.js +++ b/packages/gitbook/src/models/__tests__/glossaryEntry.js @@ -1,9 +1,9 @@ -var GlossaryEntry = require('../glossaryEntry'); +const GlossaryEntry = require('../glossaryEntry'); describe('GlossaryEntry', function() { describe('getID', function() { it('must return a normalized ID', function() { - var entry = new GlossaryEntry({ + const entry = new GlossaryEntry({ name: 'Hello World' }); @@ -12,4 +12,3 @@ describe('GlossaryEntry', function() { }); }); - diff --git a/packages/gitbook/lib/models/__tests__/page.js b/packages/gitbook/src/models/__tests__/page.js index 479d276..ad9420e 100644 --- a/packages/gitbook/lib/models/__tests__/page.js +++ b/packages/gitbook/src/models/__tests__/page.js @@ -1,11 +1,11 @@ -var Immutable = require('immutable'); -var Page = require('../page'); +const Immutable = require('immutable'); +const Page = require('../page'); describe('Page', function() { describe('toText', function() { it('must not prepend frontmatter if no attributes', function() { - var page = Page().merge({ + const page = Page().merge({ content: 'Hello World' }); @@ -13,7 +13,7 @@ describe('Page', function() { }); it('must prepend frontmatter if attributes', function() { - var page = Page().merge({ + const page = Page().merge({ content: 'Hello World', attributes: Immutable.fromJS({ hello: 'world' @@ -25,4 +25,3 @@ describe('Page', function() { }); }); - diff --git a/packages/gitbook/lib/models/__tests__/plugin.js b/packages/gitbook/src/models/__tests__/plugin.js index b229664..63cb58c 100644 --- a/packages/gitbook/lib/models/__tests__/plugin.js +++ b/packages/gitbook/src/models/__tests__/plugin.js @@ -1,15 +1,15 @@ describe('Plugin', function() { - var Plugin = require('../plugin'); + const Plugin = require('../plugin'); describe('createFromString', function() { it('must parse name', function() { - var plugin = Plugin.createFromString('hello'); + const plugin = Plugin.createFromString('hello'); expect(plugin.getName()).toBe('hello'); expect(plugin.getVersion()).toBe('*'); }); it('must parse version', function() { - var plugin = Plugin.createFromString('hello@1.0.0'); + const plugin = Plugin.createFromString('hello@1.0.0'); expect(plugin.getName()).toBe('hello'); expect(plugin.getVersion()).toBe('1.0.0'); }); @@ -17,11 +17,10 @@ describe('Plugin', function() { describe('isLoaded', function() { it('must return false for empty plugin', function() { - var plugin = Plugin.createFromString('hello'); + const plugin = Plugin.createFromString('hello'); expect(plugin.isLoaded()).toBe(false); }); }); }); - diff --git a/packages/gitbook/lib/models/__tests__/pluginDependency.js b/packages/gitbook/src/models/__tests__/pluginDependency.js index cb04cf2..cda0cc2 100644 --- a/packages/gitbook/lib/models/__tests__/pluginDependency.js +++ b/packages/gitbook/src/models/__tests__/pluginDependency.js @@ -1,29 +1,29 @@ -var Immutable = require('immutable'); -var PluginDependency = require('../pluginDependency'); +const Immutable = require('immutable'); +const PluginDependency = require('../pluginDependency'); describe('PluginDependency', function() { describe('createFromString', function() { it('must parse name', function() { - var plugin = PluginDependency.createFromString('hello'); + const plugin = PluginDependency.createFromString('hello'); expect(plugin.getName()).toBe('hello'); expect(plugin.getVersion()).toBe('*'); }); it('must parse state', function() { - var plugin = PluginDependency.createFromString('-hello'); + const plugin = PluginDependency.createFromString('-hello'); expect(plugin.getName()).toBe('hello'); expect(plugin.isEnabled()).toBe(false); }); describe('Version', function() { it('must parse version', function() { - var plugin = PluginDependency.createFromString('hello@1.0.0'); + const plugin = PluginDependency.createFromString('hello@1.0.0'); expect(plugin.getName()).toBe('hello'); expect(plugin.getVersion()).toBe('1.0.0'); }); it('must parse semver', function() { - var plugin = PluginDependency.createFromString('hello@>=4.0.0'); + const plugin = PluginDependency.createFromString('hello@>=4.0.0'); expect(plugin.getName()).toBe('hello'); expect(plugin.getVersion()).toBe('>=4.0.0'); }); @@ -31,13 +31,13 @@ describe('PluginDependency', function() { describe('GIT Version', function() { it('must handle HTTPS urls', function() { - var plugin = PluginDependency.createFromString('hello@git+https://github.com/GitbookIO/plugin-ga.git'); + const plugin = PluginDependency.createFromString('hello@git+https://github.com/GitbookIO/plugin-ga.git'); expect(plugin.getName()).toBe('hello'); expect(plugin.getVersion()).toBe('git+https://github.com/GitbookIO/plugin-ga.git'); }); it('must handle SSH urls', function() { - var plugin = PluginDependency.createFromString('hello@git+ssh://samy@github.com/GitbookIO/plugin-ga.git'); + const plugin = PluginDependency.createFromString('hello@git+ssh://samy@github.com/GitbookIO/plugin-ga.git'); expect(plugin.getName()).toBe('hello'); expect(plugin.getVersion()).toBe('git+ssh://samy@github.com/GitbookIO/plugin-ga.git'); }); @@ -45,7 +45,7 @@ describe('PluginDependency', function() { describe('listToArray', function() { it('must create an array from a list of plugin dependencies', function() { - var list = PluginDependency.listToArray(Immutable.List([ + const list = PluginDependency.listToArray(Immutable.List([ PluginDependency.createFromString('hello@1.0.0'), PluginDependency.createFromString('noversion'), PluginDependency.createFromString('-disabled') @@ -61,14 +61,14 @@ describe('PluginDependency', function() { describe('listFromArray', function() { it('must create an array from a list of plugin dependencies', function() { - var arr = Immutable.fromJS([ + const arr = Immutable.fromJS([ 'hello@1.0.0', { 'name': 'plugin-ga', 'version': 'git+ssh://samy@github.com/GitbookIO/plugin-ga.git' } ]); - var list = PluginDependency.listFromArray(arr); + const list = PluginDependency.listFromArray(arr); expect(list.first().getName()).toBe('hello'); expect(list.first().getVersion()).toBe('1.0.0'); diff --git a/packages/gitbook/lib/models/__tests__/summary.js b/packages/gitbook/src/models/__tests__/summary.js index 29c9330..49ed9b1 100644 --- a/packages/gitbook/lib/models/__tests__/summary.js +++ b/packages/gitbook/src/models/__tests__/summary.js @@ -1,9 +1,9 @@ describe('Summary', function() { - var File = require('../file'); - var Summary = require('../summary'); + const File = require('../file'); + const Summary = require('../summary'); - var summary = Summary.createFromParts(File(), [ + const summary = Summary.createFromParts(File(), [ { articles: [ { @@ -30,21 +30,21 @@ describe('Summary', function() { describe('createFromEntries', function() { it('must add all parts', function() { - var parts = summary.getParts(); + const parts = summary.getParts(); expect(parts.size).toBe(2); }); }); describe('getByLevel', function() { it('can return a Part', function() { - var part = summary.getByLevel('1'); + const part = summary.getByLevel('1'); expect(part).toBeDefined(); expect(part.getArticles().size).toBe(4); }); it('can return a Part (2)', function() { - var part = summary.getByLevel('2'); + const part = summary.getByLevel('2'); expect(part).toBeDefined(); expect(part.getTitle()).toBe('Test'); @@ -52,7 +52,7 @@ describe('Summary', function() { }); it('can return an Article', function() { - var article = summary.getByLevel('1.1'); + const article = summary.getByLevel('1.1'); expect(article).toBeDefined(); expect(article.getTitle()).toBe('My First Article'); @@ -61,21 +61,21 @@ describe('Summary', function() { describe('getByPath', function() { it('return correct article', function() { - var article = summary.getByPath('README.md'); + const article = summary.getByPath('README.md'); expect(article).toBeDefined(); expect(article.getTitle()).toBe('My First Article'); }); it('return correct article', function() { - var article = summary.getByPath('article.md'); + const article = summary.getByPath('article.md'); expect(article).toBeDefined(); expect(article.getTitle()).toBe('My Second Article'); }); it('return undefined if not found', function() { - var article = summary.getByPath('NOT_EXISTING.md'); + const article = summary.getByPath('NOT_EXISTING.md'); expect(article).toBeFalsy(); }); @@ -91,4 +91,3 @@ describe('Summary', function() { }); }); - diff --git a/packages/gitbook/lib/models/__tests__/summaryArticle.js b/packages/gitbook/src/models/__tests__/summaryArticle.js index 22a7a20..506d481 100644 --- a/packages/gitbook/lib/models/__tests__/summaryArticle.js +++ b/packages/gitbook/src/models/__tests__/summaryArticle.js @@ -1,15 +1,15 @@ -var SummaryArticle = require('../summaryArticle'); -var File = require('../file'); +const SummaryArticle = require('../summaryArticle'); +const File = require('../file'); describe('SummaryArticle', function() { describe('createChildLevel', function() { it('must create the right level', function() { - var article = SummaryArticle.create({}, '1.1'); + const article = SummaryArticle.create({}, '1.1'); expect(article.createChildLevel()).toBe('1.1.1'); }); it('must create the right level when has articles', function() { - var article = SummaryArticle.create({ + const article = SummaryArticle.create({ articles: [ { title: 'Test' @@ -22,32 +22,31 @@ describe('SummaryArticle', function() { describe('isFile', function() { it('must return true when exactly the file', function() { - var article = SummaryArticle.create({ + const article = SummaryArticle.create({ ref: 'hello.md' }, '1.1'); - var file = File.createWithFilepath('hello.md'); + const file = File.createWithFilepath('hello.md'); expect(article.isFile(file)).toBe(true); }); it('must return true when path is not normalized', function() { - var article = SummaryArticle.create({ + const article = SummaryArticle.create({ ref: '/hello.md' }, '1.1'); - var file = File.createWithFilepath('hello.md'); + const file = File.createWithFilepath('hello.md'); expect(article.isFile(file)).toBe(true); }); it('must return false when has anchor', function() { - var article = SummaryArticle.create({ + const article = SummaryArticle.create({ ref: 'hello.md#world' }, '1.1'); - var file = File.createWithFilepath('hello.md'); + const file = File.createWithFilepath('hello.md'); expect(article.isFile(file)).toBe(false); }); }); }); - diff --git a/packages/gitbook/lib/models/__tests__/summaryPart.js b/packages/gitbook/src/models/__tests__/summaryPart.js index 8ee50b6..fc9e8b5 100644 --- a/packages/gitbook/lib/models/__tests__/summaryPart.js +++ b/packages/gitbook/src/models/__tests__/summaryPart.js @@ -1,14 +1,14 @@ -var SummaryPart = require('../summaryPart'); +const SummaryPart = require('../summaryPart'); describe('SummaryPart', function() { describe('createChildLevel', function() { it('must create the right level', function() { - var article = SummaryPart.create({}, '1'); + const article = SummaryPart.create({}, '1'); expect(article.createChildLevel()).toBe('1.1'); }); it('must create the right level when has articles', function() { - var article = SummaryPart.create({ + const article = SummaryPart.create({ articles: [ { title: 'Test' @@ -20,4 +20,3 @@ describe('SummaryPart', function() { }); }); - diff --git a/packages/gitbook/lib/models/__tests__/templateBlock.js b/packages/gitbook/src/models/__tests__/templateBlock.js index e5f7666..20511be 100644 --- a/packages/gitbook/lib/models/__tests__/templateBlock.js +++ b/packages/gitbook/src/models/__tests__/templateBlock.js @@ -1,13 +1,13 @@ -var nunjucks = require('nunjucks'); -var Immutable = require('immutable'); -var Promise = require('../../utils/promise'); +const nunjucks = require('nunjucks'); +const Immutable = require('immutable'); +const Promise = require('../../utils/promise'); describe('TemplateBlock', function() { - var TemplateBlock = require('../templateBlock'); + const TemplateBlock = require('../templateBlock'); describe('create', function() { it('must initialize a simple TemplateBlock from a function', function() { - var templateBlock = TemplateBlock.create('sayhello', function(block) { + const templateBlock = TemplateBlock.create('sayhello', function(block) { return { body: '<p>Hello, World!</p>', parse: true @@ -34,7 +34,7 @@ describe('TemplateBlock', function() { describe('getShortcuts', function() { it('must return undefined if no shortcuts', function() { - var templateBlock = TemplateBlock.create('sayhello', function(block) { + const templateBlock = TemplateBlock.create('sayhello', function(block) { return { body: '<p>Hello, World!</p>', parse: true @@ -45,8 +45,8 @@ describe('TemplateBlock', function() { }); it('must return complete shortcut', function() { - var templateBlock = TemplateBlock.create('sayhello', { - process: function(block) { + const templateBlock = TemplateBlock.create('sayhello', { + process(block) { return '<p>Hello, World!</p>'; }, shortcuts: { @@ -56,7 +56,7 @@ describe('TemplateBlock', function() { } }); - var shortcut = templateBlock.getShortcuts(); + const shortcut = templateBlock.getShortcuts(); expect(shortcut).toBeDefined(); expect(shortcut.getStart()).toEqual('$'); @@ -68,28 +68,28 @@ describe('TemplateBlock', function() { describe('toNunjucksExt()', function() { it('should replace by block anchor', function() { - var templateBlock = TemplateBlock.create('sayhello', function(block) { + const templateBlock = TemplateBlock.create('sayhello', function(block) { return 'Hello'; }); - var blocks = {}; + let blocks = {}; // Create a fresh Nunjucks environment - var env = new nunjucks.Environment(null, { autoescape: false }); + const env = new nunjucks.Environment(null, { autoescape: false }); // Add template block to environement - var Ext = templateBlock.toNunjucksExt({}, blocks); + const Ext = templateBlock.toNunjucksExt({}, blocks); env.addExtension(templateBlock.getExtensionName(), new Ext()); // Render a template using the block - var src = '{% sayhello %}{% endsayhello %}'; + const src = '{% sayhello %}{% endsayhello %}'; return Promise.nfcall(env.renderString.bind(env), src) .then(function(res) { blocks = Immutable.fromJS(blocks); expect(blocks.size).toBe(1); - var blockId = blocks.keySeq().get(0); - var block = blocks.get(blockId); + const blockId = blocks.keySeq().get(0); + const block = blocks.get(blockId); expect(res).toBe('{{-%' + blockId + '%-}}'); expect(block.get('body')).toBe('Hello'); @@ -98,7 +98,7 @@ describe('TemplateBlock', function() { }); it('must create a valid nunjucks extension', function() { - var templateBlock = TemplateBlock.create('sayhello', function(block) { + const templateBlock = TemplateBlock.create('sayhello', function(block) { return { body: '<p>Hello, World!</p>', parse: true @@ -106,14 +106,14 @@ describe('TemplateBlock', function() { }); // Create a fresh Nunjucks environment - var env = new nunjucks.Environment(null, { autoescape: false }); + const env = new nunjucks.Environment(null, { autoescape: false }); // Add template block to environement - var Ext = templateBlock.toNunjucksExt(); + const Ext = templateBlock.toNunjucksExt(); env.addExtension(templateBlock.getExtensionName(), new Ext()); // Render a template using the block - var src = '{% sayhello %}{% endsayhello %}'; + const src = '{% sayhello %}{% endsayhello %}'; return Promise.nfcall(env.renderString.bind(env), src) .then(function(res) { expect(res).toBe('<p>Hello, World!</p>'); @@ -121,22 +121,22 @@ describe('TemplateBlock', function() { }); it('must apply block arguments correctly', function() { - var templateBlock = TemplateBlock.create('sayhello', function(block) { + const templateBlock = TemplateBlock.create('sayhello', function(block) { return { - body: '<'+block.kwargs.tag+'>Hello, '+block.kwargs.name+'!</'+block.kwargs.tag+'>', + body: '<' + block.kwargs.tag + '>Hello, ' + block.kwargs.name + '!</' + block.kwargs.tag + '>', parse: true }; }); // Create a fresh Nunjucks environment - var env = new nunjucks.Environment(null, { autoescape: false }); + const env = new nunjucks.Environment(null, { autoescape: false }); // Add template block to environement - var Ext = templateBlock.toNunjucksExt(); + const Ext = templateBlock.toNunjucksExt(); env.addExtension(templateBlock.getExtensionName(), new Ext()); // Render a template using the block - var src = '{% sayhello name="Samy", tag="p" %}{% endsayhello %}'; + const src = '{% sayhello name="Samy", tag="p" %}{% endsayhello %}'; return Promise.nfcall(env.renderString.bind(env), src) .then(function(res) { expect(res).toBe('<p>Hello, Samy!</p>'); @@ -144,7 +144,7 @@ describe('TemplateBlock', function() { }); it('must accept an async function', function() { - var templateBlock = TemplateBlock.create('sayhello', function(block) { + const templateBlock = TemplateBlock.create('sayhello', function(block) { return Promise() .then(function() { return { @@ -155,14 +155,14 @@ describe('TemplateBlock', function() { }); // Create a fresh Nunjucks environment - var env = new nunjucks.Environment(null, { autoescape: false }); + const env = new nunjucks.Environment(null, { autoescape: false }); // Add template block to environement - var Ext = templateBlock.toNunjucksExt(); + const Ext = templateBlock.toNunjucksExt(); env.addExtension(templateBlock.getExtensionName(), new Ext()); // Render a template using the block - var src = '{% sayhello %}Samy{% endsayhello %}'; + const src = '{% sayhello %}Samy{% endsayhello %}'; return Promise.nfcall(env.renderString.bind(env), src) .then(function(res) { expect(res).toBe('Hello Samy'); @@ -170,36 +170,36 @@ describe('TemplateBlock', function() { }); it('must handle nested blocks', function() { - var templateBlock = new TemplateBlock({ + const templateBlock = new TemplateBlock({ name: 'yoda', blocks: Immutable.List(['start', 'end']), - process: function(block) { - var nested = {}; + process(block) { + const nested = {}; block.blocks.forEach(function(blk) { nested[blk.name] = blk.body.trim(); }); return { - body: '<p class="yoda">'+nested.end+' '+nested.start+'</p>', + body: '<p class="yoda">' + nested.end + ' ' + nested.start + '</p>', parse: true }; } }); // Create a fresh Nunjucks environment - var env = new nunjucks.Environment(null, { autoescape: false }); + const env = new nunjucks.Environment(null, { autoescape: false }); // Add template block to environement - var Ext = templateBlock.toNunjucksExt(); + const Ext = templateBlock.toNunjucksExt(); env.addExtension(templateBlock.getExtensionName(), new Ext()); // Render a template using the block - var src = '{% yoda %}{% start %}this sentence should be{% end %}inverted{% endyoda %}'; + const src = '{% yoda %}{% start %}this sentence should be{% end %}inverted{% endyoda %}'; return Promise.nfcall(env.renderString.bind(env), src) .then(function(res) { expect(res).toBe('<p class="yoda">inverted this sentence should be</p>'); }); }); }); -});
\ No newline at end of file +}); diff --git a/packages/gitbook/lib/models/__tests__/templateEngine.js b/packages/gitbook/src/models/__tests__/templateEngine.js index 6f18b18..30cd543 100644 --- a/packages/gitbook/lib/models/__tests__/templateEngine.js +++ b/packages/gitbook/src/models/__tests__/templateEngine.js @@ -1,40 +1,40 @@ describe('TemplateBlock', function() { - var TemplateEngine = require('../templateEngine'); + const TemplateEngine = require('../templateEngine'); describe('create', function() { it('must initialize with a list of filters', function() { - var engine = TemplateEngine.create({ + const engine = TemplateEngine.create({ filters: { - hello: function(name) { + hello(name) { return 'Hello ' + name + '!'; } } }); - var env = engine.toNunjucks(); - var res = env.renderString('{{ "Luke"|hello }}'); + const env = engine.toNunjucks(); + const res = env.renderString('{{ "Luke"|hello }}'); expect(res).toBe('Hello Luke!'); }); it('must initialize with a list of globals', function() { - var engine = TemplateEngine.create({ + const engine = TemplateEngine.create({ globals: { - hello: function(name) { + hello(name) { return 'Hello ' + name + '!'; } } }); - var env = engine.toNunjucks(); - var res = env.renderString('{{ hello("Luke") }}'); + const env = engine.toNunjucks(); + const res = env.renderString('{{ hello("Luke") }}'); expect(res).toBe('Hello Luke!'); }); it('must pass context to filters and blocks', function() { - var engine = TemplateEngine.create({ + const engine = TemplateEngine.create({ filters: { - hello: function(name) { + hello(name) { return 'Hello ' + name + ' ' + this.lastName + '!'; } }, @@ -42,10 +42,10 @@ describe('TemplateBlock', function() { lastName: 'Skywalker' } }); - var env = engine.toNunjucks(); - var res = env.renderString('{{ "Luke"|hello }}'); + const env = engine.toNunjucks(); + const res = env.renderString('{{ "Luke"|hello }}'); expect(res).toBe('Hello Luke Skywalker!'); }); }); -});
\ No newline at end of file +}); diff --git a/packages/gitbook/lib/models/book.js b/packages/gitbook/src/models/book.js index f774ee8..4164536 100644 --- a/packages/gitbook/lib/models/book.js +++ b/packages/gitbook/src/models/book.js @@ -1,17 +1,17 @@ -var path = require('path'); -var Immutable = require('immutable'); +const path = require('path'); +const Immutable = require('immutable'); -var Logger = require('../utils/logger'); +const Logger = require('../utils/logger'); -var FS = require('./fs'); -var Config = require('./config'); -var Readme = require('./readme'); -var Summary = require('./summary'); -var Glossary = require('./glossary'); -var Languages = require('./languages'); -var Ignore = require('./ignore'); +const FS = require('./fs'); +const Config = require('./config'); +const Readme = require('./readme'); +const Summary = require('./summary'); +const Glossary = require('./glossary'); +const Languages = require('./languages'); +const Ignore = require('./ignore'); -var Book = Immutable.Record({ +const Book = Immutable.Record({ // Logger for outptu message logger: Logger(), @@ -81,9 +81,9 @@ Book.prototype.getLanguage = function() { @return {FS} */ Book.prototype.getContentFS = function() { - var fs = this.getFS(); - var config = this.getConfig(); - var rootFolder = config.getValue('root'); + const fs = this.getFS(); + const config = this.getConfig(); + const rootFolder = config.getValue('root'); if (rootFolder) { return FS.reduceScope(fs, rootFolder); @@ -98,7 +98,7 @@ Book.prototype.getContentFS = function() { @return {String} */ Book.prototype.getRoot = function() { - var fs = this.getFS(); + const fs = this.getFS(); return fs.getRoot(); }; @@ -108,7 +108,7 @@ Book.prototype.getRoot = function() { @return {String} */ Book.prototype.getContentRoot = function() { - var fs = this.getContentFS(); + const fs = this.getContentFS(); return fs.getRoot(); }; @@ -119,8 +119,8 @@ Book.prototype.getContentRoot = function() { @return {Page|undefined} */ Book.prototype.isFileIgnored = function(filename) { - var ignore = this.getIgnore(); - var language = this.getLanguage(); + const ignore = this.getIgnore(); + const language = this.getLanguage(); // Ignore is always relative to the root of the main book if (language) { @@ -137,8 +137,8 @@ Book.prototype.isFileIgnored = function(filename) { @return {Page|undefined} */ Book.prototype.isContentFileIgnored = function(filename) { - var config = this.getConfig(); - var rootFolder = config.getValue('root'); + const config = this.getConfig(); + const rootFolder = config.getValue('root'); if (rootFolder) { filename = path.join(rootFolder, filename); @@ -182,7 +182,7 @@ Book.prototype.isLanguageBook = function() { @return {Book} */ Book.prototype.getLanguageBook = function(language) { - var books = this.getBooks(); + const books = this.getBooks(); return books.get(language); }; @@ -194,7 +194,7 @@ Book.prototype.getLanguageBook = function(language) { @return {Book} */ Book.prototype.addLanguageBook = function(language, book) { - var books = this.getBooks(); + let books = this.getBooks(); books = books.set(language, book); return this.set('books', books); @@ -259,7 +259,7 @@ Book.prototype.setLogLevel = function(level) { */ Book.createForFS = function createForFS(fs) { return new Book({ - fs: fs + fs }); }; @@ -269,15 +269,15 @@ Book.createForFS = function createForFS(fs) { */ Book.prototype.getDefaultExt = function() { // Inferring sources - var clues = [ + const clues = [ this.getReadme(), this.getSummary(), this.getGlossary() ]; // List their extensions - var exts = clues.map(function (clue) { - var file = clue.getFile(); + const exts = clues.map(function(clue) { + const file = clue.getFile(); if (file.exists()) { return file.getParser().getExtensions().first(); } else { @@ -288,7 +288,7 @@ Book.prototype.getDefaultExt = function() { exts.push('.md'); // Choose the first non null - return exts.find(function (e) { return e !== null; }); + return exts.find(function(e) { return e !== null; }); }; /** @@ -298,7 +298,7 @@ Book.prototype.getDefaultExt = function() { @return {String} */ Book.prototype.getDefaultReadmePath = function(absolute) { - var defaultPath = 'README'+this.getDefaultExt(); + const defaultPath = 'README' + this.getDefaultExt(); if (absolute) { return path.join(this.getContentRoot(), defaultPath); } else { @@ -313,7 +313,7 @@ Book.prototype.getDefaultReadmePath = function(absolute) { @return {String} */ Book.prototype.getDefaultSummaryPath = function(absolute) { - var defaultPath = 'SUMMARY'+this.getDefaultExt(); + const defaultPath = 'SUMMARY' + this.getDefaultExt(); if (absolute) { return path.join(this.getContentRoot(), defaultPath); } else { @@ -328,7 +328,7 @@ Book.prototype.getDefaultSummaryPath = function(absolute) { @return {String} */ Book.prototype.getDefaultGlossaryPath = function(absolute) { - var defaultPath = 'GLOSSARY'+this.getDefaultExt(); + const defaultPath = 'GLOSSARY' + this.getDefaultExt(); if (absolute) { return path.join(this.getContentRoot(), defaultPath); } else { @@ -344,8 +344,8 @@ Book.prototype.getDefaultGlossaryPath = function(absolute) { @return {Book} */ Book.createFromParent = function createFromParent(parent, language) { - var ignore = parent.getIgnore(); - var config = parent.getConfig(); + const ignore = parent.getIgnore(); + let config = parent.getConfig(); // Set language in configuration config = config.setValue('language', language); @@ -353,10 +353,10 @@ Book.createFromParent = function createFromParent(parent, language) { return new Book({ // Inherits config. logegr and list of ignored files logger: parent.getLogger(), - config: config, - ignore: ignore, + config, + ignore, - language: language, + language, fs: FS.reduceScope(parent.getContentFS(), language) }); }; diff --git a/packages/gitbook/lib/models/config.js b/packages/gitbook/src/models/config.js index 6de52f9..6a0be5e 100644 --- a/packages/gitbook/lib/models/config.js +++ b/packages/gitbook/src/models/config.js @@ -1,12 +1,12 @@ -var is = require('is'); -var Immutable = require('immutable'); +const is = require('is'); +const Immutable = require('immutable'); -var File = require('./file'); -var PluginDependency = require('./pluginDependency'); -var configDefault = require('../constants/configDefault'); -var reducedObject = require('../utils/reducedObject'); +const File = require('./file'); +const PluginDependency = require('./pluginDependency'); +const configDefault = require('../constants/configDefault'); +const reducedObject = require('../utils/reducedObject'); -var Config = Immutable.Record({ +const Config = Immutable.Record({ file: File(), values: configDefault }, 'Config'); @@ -51,7 +51,7 @@ Config.prototype.setFile = function(file) { * @return {Mixed} */ Config.prototype.getValue = function(keyPath, def) { - var values = this.getValues(); + const values = this.getValues(); keyPath = Config.keyToKeyPath(keyPath); if (!values.hasIn(keyPath)) { @@ -72,7 +72,7 @@ Config.prototype.setValue = function(keyPath, value) { value = Immutable.fromJS(value); - var values = this.getValues(); + let values = this.getValues(); values = values.setIn(keyPath, value); return this.set('values', values); @@ -83,7 +83,7 @@ Config.prototype.setValue = function(keyPath, value) { * @return {List<PluginDependency>} */ Config.prototype.getPluginDependencies = function() { - var plugins = this.getValue('plugins'); + const plugins = this.getValue('plugins'); if (is.string(plugins)) { return PluginDependency.listFromString(plugins); @@ -98,7 +98,7 @@ Config.prototype.getPluginDependencies = function() { * @return {PluginDependency} */ Config.prototype.getPluginDependency = function(name) { - var plugins = this.getPluginDependencies(); + const plugins = this.getPluginDependencies(); return plugins.find(function(dep) { return dep.getName() === name; @@ -111,7 +111,7 @@ Config.prototype.getPluginDependency = function(name) { * @return {Config} */ Config.prototype.setPluginDependencies = function(deps) { - var plugins = PluginDependency.listToArray(deps); + const plugins = PluginDependency.listToArray(deps); return this.setValue('plugins', plugins); }; @@ -135,7 +135,7 @@ Config.prototype.updateValues = function(values) { * @returns {Config} */ Config.prototype.mergeValues = function(values) { - var currentValues = this.getValues(); + let currentValues = this.getValues(); values = Immutable.fromJS(values); currentValues = currentValues.mergeDeep(values); @@ -151,7 +151,7 @@ Config.prototype.mergeValues = function(values) { */ Config.create = function(file, values) { return new Config({ - file: file, + file, values: Immutable.fromJS(values) }); }; diff --git a/packages/gitbook/lib/models/file.js b/packages/gitbook/src/models/file.js index 8ddd4af..84828ce 100644 --- a/packages/gitbook/lib/models/file.js +++ b/packages/gitbook/src/models/file.js @@ -1,9 +1,9 @@ -var path = require('path'); -var Immutable = require('immutable'); +const path = require('path'); +const Immutable = require('immutable'); -var parsers = require('../parsers'); +const parsers = require('../parsers'); -var File = Immutable.Record({ +const File = Immutable.Record({ // Path of the file, relative to the FS path: String(), @@ -34,7 +34,7 @@ File.prototype.exists = function() { @return {String} */ File.prototype.getType = function() { - var parser = this.getParser(); + const parser = this.getParser(); if (parser) { return parser.getName(); } else { diff --git a/packages/gitbook/lib/models/fs.js b/packages/gitbook/src/models/fs.js index 16bd4ea..7afbfbd 100644 --- a/packages/gitbook/lib/models/fs.js +++ b/packages/gitbook/src/models/fs.js @@ -1,13 +1,13 @@ -var path = require('path'); -var Immutable = require('immutable'); -var stream = require('stream'); +const path = require('path'); +const Immutable = require('immutable'); +const stream = require('stream'); -var File = require('./file'); -var Promise = require('../utils/promise'); -var error = require('../utils/error'); -var PathUtil = require('../utils/path'); +const File = require('./file'); +const Promise = require('../utils/promise'); +const error = require('../utils/error'); +const PathUtil = require('../utils/path'); -var FS = Immutable.Record({ +const FS = Immutable.Record({ root: String(), fsExists: Function(), @@ -35,27 +35,25 @@ FS.prototype.getRoot = function() { @return {Boolean} */ FS.prototype.isInScope = function(filename) { - var rootPath = this.getRoot(); + const rootPath = this.getRoot(); filename = path.join(rootPath, filename); return PathUtil.isInRoot(rootPath, filename); }; /** - Resolve a file in this FS - - @param {String} - @return {String} -*/ -FS.prototype.resolve = function() { - var rootPath = this.getRoot(); - var args = Array.prototype.slice.call(arguments); - var filename = path.join.apply(path, [rootPath].concat(args)); + * Resolve a file in this FS + * @param {String} + * @return {String} + */ +FS.prototype.resolve = function(...args) { + const rootPath = this.getRoot(); + let filename = path.join(rootPath, ...args); filename = path.normalize(filename); if (!this.isInScope(filename)) { throw error.FileOutOfScopeError({ - filename: filename, + filename, root: this.root }); } @@ -64,47 +62,44 @@ FS.prototype.resolve = function() { }; /** - Check if a file exists, run a Promise(true) if that's the case, Promise(false) otherwise - - @param {String} filename - @return {Promise<Boolean>} -*/ + * Check if a file exists, run a Promise(true) if that's the case, Promise(false) otherwise + * @param {String} filename + * @return {Promise<Boolean>} + */ FS.prototype.exists = function(filename) { - var that = this; + const that = this; return Promise() .then(function() { filename = that.resolve(filename); - var exists = that.get('fsExists'); + const exists = that.get('fsExists'); return exists(filename); }); }; /** - Read a file and returns a promise with the content as a buffer - - @param {String} filename - @return {Promise<Buffer>} -*/ + * Read a file and returns a promise with the content as a buffer + * @param {String} filename + * @return {Promise<Buffer>} + */ FS.prototype.read = function(filename) { - var that = this; + const that = this; return Promise() .then(function() { filename = that.resolve(filename); - var read = that.get('fsReadFile'); + const read = that.get('fsReadFile'); return read(filename); }); }; /** - Read a file as a string (utf-8) - - @param {String} filename - @return {Promise<String>} -*/ + * Read a file as a string (utf-8) + * @param {String} filename + * @return {Promise<String>} + */ FS.prototype.readAsString = function(filename, encoding) { encoding = encoding || 'utf8'; @@ -115,15 +110,14 @@ FS.prototype.readAsString = function(filename, encoding) { }; /** - Read file as a stream - - @param {String} filename - @return {Promise<Stream>} -*/ + * Read file as a stream + * @param {String} filename + * @return {Promise<Stream>} + */ FS.prototype.readAsStream = function(filename) { - var that = this; - var filepath = that.resolve(filename); - var fsReadAsStream = this.get('fsReadAsStream'); + const that = this; + const filepath = that.resolve(filename); + const fsReadAsStream = this.get('fsReadAsStream'); if (fsReadAsStream) { return Promise(fsReadAsStream(filepath)); @@ -131,7 +125,7 @@ FS.prototype.readAsStream = function(filename) { return this.read(filename) .then(function(buf) { - var bufferStream = new stream.PassThrough(); + const bufferStream = new stream.PassThrough(); bufferStream.end(buf); return bufferStream; @@ -139,18 +133,17 @@ FS.prototype.readAsStream = function(filename) { }; /** - Read stat infos about a file - - @param {String} filename - @return {Promise<File>} -*/ + * Read stat infos about a file + * @param {String} filename + * @return {Promise<File>} + */ FS.prototype.statFile = function(filename) { - var that = this; + const that = this; return Promise() .then(function() { - var filepath = that.resolve(filename); - var stat = that.get('fsStatFile'); + const filepath = that.resolve(filename); + const stat = that.get('fsStatFile'); return stat(filepath); }) @@ -160,19 +153,19 @@ FS.prototype.statFile = function(filename) { }; /** - List files/directories in a directory. - Directories ends with '/' + * List files/directories in a directory. + * Directories ends with '/' - @param {String} dirname - @return {Promise<List<String>>} -*/ + * @param {String} dirname + * @return {Promise<List<String>>} + */ FS.prototype.readDir = function(dirname) { - var that = this; + const that = this; return Promise() .then(function() { - var dirpath = that.resolve(dirname); - var readDir = that.get('fsReadDir'); + const dirpath = that.resolve(dirname); + const readDir = that.get('fsReadDir'); return readDir(dirpath); }) @@ -182,12 +175,12 @@ FS.prototype.readDir = function(dirname) { }; /** - List only files in a diretcory - Directories ends with '/' - - @param {String} dirname - @return {Promise<List<String>>} -*/ + * List only files in a diretcory + * Directories ends with '/' + * + * @param {String} dirname + * @return {Promise<List<String>>} + */ FS.prototype.listFiles = function(dirname) { return this.readDir(dirname) .then(function(files) { @@ -196,21 +189,21 @@ FS.prototype.listFiles = function(dirname) { }; /** - List all files in a directory - - @param {String} dirName - @param {Function(dirName)} filterFn: call it for each file/directory to test if it should stop iterating - @return {Promise<List<String>>} -*/ + * List all files in a directory + * + * @param {String} dirName + * @param {Function(dirName)} filterFn: call it for each file/directory to test if it should stop iterating + * @return {Promise<List<String>>} + */ FS.prototype.listAllFiles = function(dirName, filterFn) { - var that = this; + const that = this; dirName = dirName || '.'; return this.readDir(dirName) .then(function(files) { return Promise.reduce(files, function(out, file) { - var isDirectory = pathIsFolder(file); - var newDirName = path.join(dirName, file); + const isDirectory = pathIsFolder(file); + const newDirName = path.join(dirName, file); if (filterFn && filterFn(newDirName) === false) { return out; @@ -229,13 +222,13 @@ FS.prototype.listAllFiles = function(dirName, filterFn) { }; /** - Find a file in a folder (case insensitive) - Return the found filename - - @param {String} dirname - @param {String} filename - @return {Promise<String>} -*/ + * Find a file in a folder (case insensitive) + * Return the found filename + * + * @param {String} dirname + * @param {String} filename + * @return {Promise<String>} + */ FS.prototype.findFile = function(dirname, filename) { return this.listFiles(dirname) .then(function(files) { @@ -246,20 +239,20 @@ FS.prototype.findFile = function(dirname, filename) { }; /** - Load a JSON file - By default, fs only supports JSON - - @param {String} filename - @return {Promise<Object>} -*/ + * Load a JSON file + * By default, fs only supports JSON + * + * @param {String} filename + * @return {Promise<Object>} + */ FS.prototype.loadAsObject = function(filename) { - var that = this; - var fsLoadObject = this.get('fsLoadObject'); + const that = this; + const fsLoadObject = this.get('fsLoadObject'); return this.exists(filename) .then(function(exists) { if (!exists) { - var err = new Error('Module doesn\'t exist'); + const err = new Error('Module doesn\'t exist'); err.code = 'MODULE_NOT_FOUND'; throw err; @@ -277,22 +270,22 @@ FS.prototype.loadAsObject = function(filename) { }; /** - Create a FS instance - - @param {Object} def - @return {FS} -*/ + * Create a FS instance + * + * @param {Object} def + * @return {FS} + */ FS.create = function create(def) { return new FS(def); }; /** - Create a new FS instance with a reduced scope - - @param {FS} fs - @param {String} scope - @return {FS} -*/ + * Create a new FS instance with a reduced scope + * + * @param {FS} fs + * @param {String} scope + * @return {FS} + */ FS.reduceScope = function reduceScope(fs, scope) { return fs.set('root', path.join(fs.getRoot(), scope)); }; @@ -300,8 +293,8 @@ FS.reduceScope = function reduceScope(fs, scope) { // .readdir return files/folder as a list of string, folder ending with '/' function pathIsFolder(filename) { - var lastChar = filename[filename.length - 1]; + const lastChar = filename[filename.length - 1]; return lastChar == '/' || lastChar == '\\'; } -module.exports = FS;
\ No newline at end of file +module.exports = FS; diff --git a/packages/gitbook/lib/models/glossary.js b/packages/gitbook/src/models/glossary.js index 0033248..e269b14 100644 --- a/packages/gitbook/lib/models/glossary.js +++ b/packages/gitbook/src/models/glossary.js @@ -1,11 +1,11 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var error = require('../utils/error'); -var File = require('./file'); -var GlossaryEntry = require('./glossaryEntry'); -var parsers = require('../parsers'); +const error = require('../utils/error'); +const File = require('./file'); +const GlossaryEntry = require('./glossaryEntry'); +const parsers = require('../parsers'); -var Glossary = Immutable.Record({ +const Glossary = Immutable.Record({ file: File(), entries: Immutable.OrderedMap() }); @@ -25,8 +25,8 @@ Glossary.prototype.getEntries = function() { @return {GlossaryEntry} */ Glossary.prototype.getEntry = function(name) { - var entries = this.getEntries(); - var id = GlossaryEntry.nameToID(name); + const entries = this.getEntries(); + const id = GlossaryEntry.nameToID(name); return entries.get(id); }; @@ -37,10 +37,10 @@ Glossary.prototype.getEntry = function(name) { @return {Promise<String>} */ Glossary.prototype.toText = function(parser) { - var file = this.getFile(); - var entries = this.getEntries(); + const file = this.getFile(); + const entries = this.getEntries(); - parser = parser? parsers.getByExt(parser) : file.getParser(); + parser = parser ? parsers.getByExt(parser) : file.getParser(); if (!parser) { throw error.FileNotParsableError({ @@ -60,8 +60,8 @@ Glossary.prototype.toText = function(parser) { @return {Glossary} */ Glossary.addEntry = function addEntry(glossary, entry) { - var id = entry.getID(); - var entries = glossary.getEntries(); + const id = entry.getID(); + let entries = glossary.getEntries(); entries = entries.set(id, entry); return glossary.set('entries', entries); @@ -75,9 +75,9 @@ Glossary.addEntry = function addEntry(glossary, entry) { @return {Glossary} */ Glossary.addEntryByName = function addEntryByName(glossary, name, description) { - var entry = new GlossaryEntry({ - name: name, - description: description + const entry = new GlossaryEntry({ + name, + description }); return Glossary.addEntry(glossary, entry); @@ -100,7 +100,7 @@ Glossary.createFromEntries = function createFromEntries(file, entries) { }); return new Glossary({ - file: file, + file, entries: Immutable.OrderedMap(entries) }); }; diff --git a/packages/gitbook/lib/models/glossaryEntry.js b/packages/gitbook/src/models/glossaryEntry.js index 10791db..b36b276 100644 --- a/packages/gitbook/lib/models/glossaryEntry.js +++ b/packages/gitbook/src/models/glossaryEntry.js @@ -1,11 +1,11 @@ -var Immutable = require('immutable'); -var slug = require('github-slugid'); +const Immutable = require('immutable'); +const slug = require('github-slugid'); /* A definition represents an entry in the glossary */ -var GlossaryEntry = Immutable.Record({ +const GlossaryEntry = Immutable.Record({ name: String(), description: String() }); diff --git a/packages/gitbook/lib/models/ignore.js b/packages/gitbook/src/models/ignore.js index 499195e..99ade9a 100644 --- a/packages/gitbook/lib/models/ignore.js +++ b/packages/gitbook/src/models/ignore.js @@ -1,10 +1,10 @@ -var Immutable = require('immutable'); -var IgnoreMutable = require('ignore'); +const Immutable = require('immutable'); +const IgnoreMutable = require('ignore'); /* Immutable version of node-ignore */ -var Ignore = Immutable.Record({ +const Ignore = Immutable.Record({ ignore: new IgnoreMutable() }, 'Ignore'); @@ -19,7 +19,7 @@ Ignore.prototype.getIgnore = function() { @return {Boolean} */ Ignore.prototype.isFileIgnored = function(filename) { - var ignore = this.getIgnore(); + const ignore = this.getIgnore(); return ignore.filter([filename]).length == 0; }; @@ -30,8 +30,8 @@ Ignore.prototype.isFileIgnored = function(filename) { @return {Ignore} */ Ignore.prototype.add = function(rule) { - var ignore = this.getIgnore(); - var newIgnore = new IgnoreMutable(); + const ignore = this.getIgnore(); + const newIgnore = new IgnoreMutable(); newIgnore.add(ignore); newIgnore.add(rule); diff --git a/packages/gitbook/lib/models/language.js b/packages/gitbook/src/models/language.js index dcefbf6..1413091 100644 --- a/packages/gitbook/lib/models/language.js +++ b/packages/gitbook/src/models/language.js @@ -1,7 +1,7 @@ -var path = require('path'); -var Immutable = require('immutable'); +const path = require('path'); +const Immutable = require('immutable'); -var Language = Immutable.Record({ +const Language = Immutable.Record({ title: String(), path: String() }); diff --git a/packages/gitbook/lib/models/languages.js b/packages/gitbook/src/models/languages.js index 42f05f9..9540546 100644 --- a/packages/gitbook/lib/models/languages.js +++ b/packages/gitbook/src/models/languages.js @@ -1,9 +1,9 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var File = require('./file'); -var Language = require('./language'); +const File = require('./file'); +const Language = require('./language'); -var Languages = Immutable.Record({ +const Languages = Immutable.Record({ file: File(), list: Immutable.OrderedMap() }); @@ -52,7 +52,7 @@ Languages.prototype.getCount = function() { @return {Language} */ Languages.createFromList = function(file, langs) { - var list = Immutable.OrderedMap(); + let list = Immutable.OrderedMap(); langs.forEach(function(lang) { lang = Language({ @@ -63,8 +63,8 @@ Languages.createFromList = function(file, langs) { }); return Languages({ - file: file, - list: list + file, + list }); }; diff --git a/packages/gitbook/lib/models/output.js b/packages/gitbook/src/models/output.js index 0f008ec..55d83a4 100644 --- a/packages/gitbook/lib/models/output.js +++ b/packages/gitbook/src/models/output.js @@ -1,9 +1,9 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var Book = require('./book'); -var LocationUtils = require('../utils/location'); +const Book = require('./book'); +const LocationUtils = require('../utils/location'); -var Output = Immutable.Record({ +const Output = Immutable.Record({ book: Book(), // Name of the generator being used @@ -62,7 +62,7 @@ Output.prototype.getState = function() { Output.prototype.getPage = function(filePath) { filePath = LocationUtils.normalize(filePath); - var pages = this.getPages(); + const pages = this.getPages(); return pages.get(filePath); }; diff --git a/packages/gitbook/lib/models/page.js b/packages/gitbook/src/models/page.js index 275a034..dd60298 100644 --- a/packages/gitbook/lib/models/page.js +++ b/packages/gitbook/src/models/page.js @@ -1,9 +1,9 @@ -var Immutable = require('immutable'); -var yaml = require('js-yaml'); +const Immutable = require('immutable'); +const yaml = require('js-yaml'); -var File = require('./file'); +const File = require('./file'); -var Page = Immutable.Record({ +const Page = Immutable.Record({ file: File(), // Attributes extracted from the YAML header @@ -37,14 +37,14 @@ Page.prototype.getDir = function() { * @return {String} */ Page.prototype.toText = function() { - var attrs = this.getAttributes(); - var content = this.getContent(); + const attrs = this.getAttributes(); + const content = this.getContent(); if (attrs.size === 0) { return content; } - var frontMatter = '---\n' + yaml.safeDump(attrs.toJS(), { skipInvalid: true }) + '---\n\n'; + const frontMatter = '---\n' + yaml.safeDump(attrs.toJS(), { skipInvalid: true }) + '---\n\n'; return (frontMatter + content); }; @@ -63,7 +63,7 @@ Page.prototype.getPath = function() { */ Page.createForFile = function(file) { return new Page({ - file: file + file }); }; diff --git a/packages/gitbook/lib/models/parser.js b/packages/gitbook/src/models/parser.js index d64542f..3769dd3 100644 --- a/packages/gitbook/lib/models/parser.js +++ b/packages/gitbook/src/models/parser.js @@ -1,7 +1,7 @@ -var Immutable = require('immutable'); -var Promise = require('../utils/promise'); +const Immutable = require('immutable'); +const Promise = require('../utils/promise'); -var Parser = Immutable.Record({ +const Parser = Immutable.Record({ name: String(), // List of extensions that can be processed using this parser @@ -27,22 +27,22 @@ Parser.prototype.getExtensions = function() { // PARSE Parser.prototype.parseReadme = function(content) { - var readme = this.get('readme'); + const readme = this.get('readme'); return Promise(readme(content)); }; Parser.prototype.parseSummary = function(content) { - var summary = this.get('summary'); + const summary = this.get('summary'); return Promise(summary(content)); }; Parser.prototype.parseGlossary = function(content) { - var glossary = this.get('glossary'); + const glossary = this.get('glossary'); return Promise(glossary(content)); }; Parser.prototype.preparePage = function(content) { - var page = this.get('page'); + const page = this.get('page'); if (!page.prepare) { return Promise(content); } @@ -51,39 +51,39 @@ Parser.prototype.preparePage = function(content) { }; Parser.prototype.parsePage = function(content) { - var page = this.get('page'); + const page = this.get('page'); return Promise(page(content)); }; Parser.prototype.parseInline = function(content) { - var inline = this.get('inline'); + const inline = this.get('inline'); return Promise(inline(content)); }; Parser.prototype.parseLanguages = function(content) { - var langs = this.get('langs'); + const langs = this.get('langs'); return Promise(langs(content)); }; Parser.prototype.parseInline = function(content) { - var inline = this.get('inline'); + const inline = this.get('inline'); return Promise(inline(content)); }; // TO TEXT Parser.prototype.renderLanguages = function(content) { - var langs = this.get('langs'); + const langs = this.get('langs'); return Promise(langs.toText(content)); }; Parser.prototype.renderSummary = function(content) { - var summary = this.get('summary'); + const summary = this.get('summary'); return Promise(summary.toText(content)); }; Parser.prototype.renderGlossary = function(content) { - var glossary = this.get('glossary'); + const glossary = this.get('glossary'); return Promise(glossary.toText(content)); }; @@ -94,7 +94,7 @@ Parser.prototype.renderGlossary = function(content) { @return {Boolean} */ Parser.prototype.matchExtension = function(ext) { - var exts = this.getExtensions(); + const exts = this.getExtensions(); return exts.includes(ext.toLowerCase()); }; @@ -108,7 +108,7 @@ Parser.prototype.matchExtension = function(ext) { */ Parser.create = function(name, extensions, module) { return new Parser({ - name: name, + name, extensions: Immutable.List(extensions), readme: module.readme, langs: module.langs, diff --git a/packages/gitbook/lib/models/plugin.js b/packages/gitbook/src/models/plugin.js index acabba9..0e4c774 100644 --- a/packages/gitbook/lib/models/plugin.js +++ b/packages/gitbook/src/models/plugin.js @@ -1,12 +1,12 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var TemplateBlock = require('./templateBlock'); -var PluginDependency = require('./pluginDependency'); -var THEME_PREFIX = require('../constants/themePrefix'); +const TemplateBlock = require('./templateBlock'); +const PluginDependency = require('./pluginDependency'); +const THEME_PREFIX = require('../constants/themePrefix'); -var DEFAULT_VERSION = '*'; +const DEFAULT_VERSION = '*'; -var Plugin = Immutable.Record({ +const Plugin = Immutable.Record({ name: String(), // Requirement version (ex: ">1.0.0") @@ -77,7 +77,7 @@ Plugin.prototype.isLoaded = function() { * @return {Boolean} */ Plugin.prototype.isTheme = function() { - var name = this.getName(); + const name = this.getName(); return (name && name.indexOf(THEME_PREFIX) === 0); }; @@ -99,9 +99,9 @@ Plugin.prototype.getResources = function(type) { throw new Error('Invalid assets type ' + type); } - var content = this.getContent(); + const content = this.getContent(); return (content.get(type) - || (type == 'website'? content.get('book') : null) + || (type == 'website' ? content.get('book') : null) || Immutable.Map()); }; @@ -118,7 +118,7 @@ Plugin.prototype.getFilters = function() { * @return {Map<String:TemplateBlock>} */ Plugin.prototype.getBlocks = function() { - var blocks = this.getContent().get('blocks'); + let blocks = this.getContent().get('blocks'); blocks = blocks || Immutable.Map(); return blocks @@ -142,12 +142,12 @@ Plugin.prototype.getHook = function(name) { * @return {Plugin} */ Plugin.createFromString = function(s) { - var parts = s.split('@'); - var name = parts[0]; - var version = parts.slice(1).join('@'); + const parts = s.split('@'); + const name = parts[0]; + const version = parts.slice(1).join('@'); return new Plugin({ - name: name, + name, version: version || DEFAULT_VERSION }); }; diff --git a/packages/gitbook/lib/models/pluginDependency.js b/packages/gitbook/src/models/pluginDependency.js index 8866294..4e5d464 100644 --- a/packages/gitbook/lib/models/pluginDependency.js +++ b/packages/gitbook/src/models/pluginDependency.js @@ -1,15 +1,15 @@ -var is = require('is'); -var semver = require('semver'); -var Immutable = require('immutable'); +const is = require('is'); +const semver = require('semver'); +const Immutable = require('immutable'); -var PREFIX = require('../constants/pluginPrefix'); -var DEFAULT_VERSION = '*'; +const PREFIX = require('../constants/pluginPrefix'); +const DEFAULT_VERSION = '*'; /* * PluginDependency represents the informations about a plugin * stored in config.plugins */ -var PluginDependency = Immutable.Record({ +const PluginDependency = Immutable.Record({ name: String(), // Requirement version (ex: ">1.0.0") @@ -71,7 +71,7 @@ PluginDependency.create = function(name, version, enabled) { } return new PluginDependency({ - name: name, + name, version: version || DEFAULT_VERSION, enabled: Boolean(enabled) }); @@ -83,10 +83,10 @@ PluginDependency.create = function(name, version, enabled) { * @return {Plugin|undefined} */ PluginDependency.createFromString = function(s) { - var parts = s.split('@'); - var name = parts[0]; - var version = parts.slice(1).join('@'); - var enabled = true; + const parts = s.split('@'); + let name = parts[0]; + const version = parts.slice(1).join('@'); + let enabled = true; if (name[0] === '-') { enabled = false; @@ -94,9 +94,9 @@ PluginDependency.createFromString = function(s) { } return new PluginDependency({ - name: name, + name, version: version || DEFAULT_VERSION, - enabled: enabled + enabled }); }; @@ -106,7 +106,7 @@ PluginDependency.createFromString = function(s) { * @return {List<PluginDependency>} */ PluginDependency.listFromString = function(s) { - var parts = s.split(','); + const parts = s.split(','); return PluginDependency.listFromArray(parts); }; @@ -140,7 +140,7 @@ PluginDependency.listFromArray = function(arr) { PluginDependency.listToArray = function(list) { return list .map(function(dep) { - var result = ''; + let result = ''; if (!dep.isEnabled()) { result += '-'; diff --git a/packages/gitbook/lib/models/readme.js b/packages/gitbook/src/models/readme.js index c655c82..0fb52b4 100644 --- a/packages/gitbook/lib/models/readme.js +++ b/packages/gitbook/src/models/readme.js @@ -1,8 +1,8 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var File = require('./file'); +const File = require('./file'); -var Readme = Immutable.Record({ +const Readme = Immutable.Record({ file: File(), title: String(), description: String() @@ -31,7 +31,7 @@ Readme.create = function(file, def) { def = def || {}; return new Readme({ - file: file, + file, title: def.title || '', description: def.description || '' }); diff --git a/packages/gitbook/lib/models/summary.js b/packages/gitbook/src/models/summary.js index 70f0535..edc202e 100644 --- a/packages/gitbook/lib/models/summary.js +++ b/packages/gitbook/src/models/summary.js @@ -1,14 +1,14 @@ -var is = require('is'); -var Immutable = require('immutable'); +const is = require('is'); +const Immutable = require('immutable'); -var error = require('../utils/error'); -var LocationUtils = require('../utils/location'); -var File = require('./file'); -var SummaryPart = require('./summaryPart'); -var SummaryArticle = require('./summaryArticle'); -var parsers = require('../parsers'); +const error = require('../utils/error'); +const LocationUtils = require('../utils/location'); +const File = require('./file'); +const SummaryPart = require('./summaryPart'); +const SummaryArticle = require('./summaryArticle'); +const parsers = require('../parsers'); -var Summary = Immutable.Record({ +const Summary = Immutable.Record({ file: File(), parts: Immutable.List() }, 'Summary'); @@ -28,7 +28,7 @@ Summary.prototype.getParts = function() { @return {Part} */ Summary.prototype.getPart = function(i) { - var parts = this.getParts(); + const parts = this.getParts(); return parts.get(i); }; @@ -41,7 +41,7 @@ Summary.prototype.getPart = function(i) { @return {Article|Part} */ Summary.prototype.getArticle = function(iter, partIter) { - var parts = this.getParts(); + const parts = this.getParts(); return parts.reduce(function(result, part) { if (result) return result; @@ -74,7 +74,7 @@ Summary.prototype.getByLevel = function(level) { */ Summary.prototype.getByPath = function(filePath) { return this.getArticle(function(article) { - var articlePath = article.getPath(); + const articlePath = article.getPath(); return ( articlePath && @@ -101,8 +101,8 @@ Summary.prototype.getFirstArticle = function() { @return {Article} */ Summary.prototype.getNextArticle = function(current) { - var level = is.string(current)? current : current.getLevel(); - var wasPrev = false; + const level = is.string(current) ? current : current.getLevel(); + let wasPrev = false; return this.getArticle(function(article) { if (wasPrev) return true; @@ -119,8 +119,8 @@ Summary.prototype.getNextArticle = function(current) { @return {Article} */ Summary.prototype.getPrevArticle = function(current) { - var level = is.string(current)? current : current.getLevel(); - var prev = undefined; + const level = is.string(current) ? current : current.getLevel(); + let prev = undefined; this.getArticle(function(article) { if (article.getLevel() == level) { @@ -140,18 +140,18 @@ Summary.prototype.getPrevArticle = function(current) { @param {String|Article} current @return {Article|Part|Null} */ -Summary.prototype.getParent = function (level) { +Summary.prototype.getParent = function(level) { // Coerce to level - level = is.string(level)? level : level.getLevel(); + level = is.string(level) ? level : level.getLevel(); // Get parent level - var parentLevel = getParentLevel(level); + const parentLevel = getParentLevel(level); if (!parentLevel) { return null; } // Get parent of the position - var parentArticle = this.getByLevel(parentLevel); + const parentArticle = this.getByLevel(parentLevel); return parentArticle || null; }; @@ -162,10 +162,10 @@ Summary.prototype.getParent = function (level) { @return {Promise<String>} */ Summary.prototype.toText = function(parseExt) { - var file = this.getFile(); - var parts = this.getParts(); + const file = this.getFile(); + const parts = this.getParts(); - var parser = parseExt? parsers.getByExt(parseExt) : file.getParser(); + const parser = parseExt ? parsers.getByExt(parseExt) : file.getParser(); if (!parser) { throw error.FileNotParsableError({ @@ -184,7 +184,7 @@ Summary.prototype.toText = function(parseExt) { @return {List<Article>} */ Summary.prototype.getArticlesAsList = function() { - var accu = []; + const accu = []; this.getArticle(function(article) { accu.push(article); @@ -209,7 +209,7 @@ Summary.createFromParts = function createFromParts(file, parts) { }); return new Summary({ - file: file, + file, parts: new Immutable.List(parts) }); }; @@ -221,7 +221,7 @@ Summary.createFromParts = function createFromParts(file, parts) { @return {String} */ function getParentLevel(level) { - var parts = level.split('.'); + const parts = level.split('.'); return parts.slice(0, -1).join('.'); } diff --git a/packages/gitbook/lib/models/summaryArticle.js b/packages/gitbook/src/models/summaryArticle.js index 6da8d1d..919e6b9 100644 --- a/packages/gitbook/lib/models/summaryArticle.js +++ b/packages/gitbook/src/models/summaryArticle.js @@ -1,12 +1,12 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var location = require('../utils/location'); +const location = require('../utils/location'); /* An article represents an entry in the Summary / table of Contents */ -var SummaryArticle = Immutable.Record({ +const SummaryArticle = Immutable.Record({ level: String(), title: String(), ref: String(), @@ -50,14 +50,14 @@ SummaryArticle.prototype.getPath = function() { return undefined; } - var ref = this.getRef(); + const ref = this.getRef(); if (!ref) { return undefined; } - var parts = ref.split('#'); + const parts = ref.split('#'); - var pathname = (parts.length > 1? parts.slice(0, -1).join('#') : ref); + const pathname = (parts.length > 1 ? parts.slice(0, -1).join('#') : ref); // Normalize path to remove ('./', '/...', etc) return location.flatten(pathname); @@ -69,7 +69,7 @@ SummaryArticle.prototype.getPath = function() { * @return {String} */ SummaryArticle.prototype.getUrl = function() { - return this.isExternal()? this.getRef() : undefined; + return this.isExternal() ? this.getRef() : undefined; }; /** @@ -78,10 +78,10 @@ SummaryArticle.prototype.getUrl = function() { * @return {String} */ SummaryArticle.prototype.getAnchor = function() { - var ref = this.getRef(); - var parts = ref.split('#'); + const ref = this.getRef(); + const parts = ref.split('#'); - var anchor = (parts.length > 1? '#' + parts[parts.length - 1] : undefined); + const anchor = (parts.length > 1 ? '#' + parts[parts.length - 1] : undefined); return anchor; }; @@ -91,9 +91,9 @@ SummaryArticle.prototype.getAnchor = function() { * @return {String} */ SummaryArticle.prototype.createChildLevel = function() { - var level = this.getLevel(); - var subArticles = this.getArticles(); - var childLevel = level + '.' + (subArticles.size + 1); + const level = this.getLevel(); + const subArticles = this.getArticles(); + const childLevel = level + '.' + (subArticles.size + 1); return childLevel; }; @@ -127,8 +127,8 @@ SummaryArticle.prototype.isFile = function(file) { * @return {Boolean} */ SummaryArticle.prototype.isReadme = function(book) { - var readme = book.getFile? book : book.getReadme(); - var file = readme.getFile(); + const readme = book.getFile ? book : book.getReadme(); + const file = readme.getFile(); return this.isFile(file); }; @@ -149,7 +149,7 @@ SummaryArticle.prototype.isExternal = function() { * @return {SummaryArticle} */ SummaryArticle.create = function(def, level) { - var articles = (def.articles || []).map(function(article, i) { + const articles = (def.articles || []).map(function(article, i) { if (article instanceof SummaryArticle) { return article; } @@ -157,7 +157,7 @@ SummaryArticle.create = function(def, level) { }); return new SummaryArticle({ - level: level, + level, title: def.title, ref: def.ref || def.path || '', articles: Immutable.List(articles) @@ -172,7 +172,7 @@ SummaryArticle.create = function(def, level) { * @return {Article} */ SummaryArticle.findArticle = function(base, iter) { - var articles = base.getArticles(); + const articles = base.getArticles(); return articles.reduce(function(result, article) { if (result) return result; diff --git a/packages/gitbook/lib/models/summaryPart.js b/packages/gitbook/src/models/summaryPart.js index f0e6f57..0bb5369 100644 --- a/packages/gitbook/lib/models/summaryPart.js +++ b/packages/gitbook/src/models/summaryPart.js @@ -1,12 +1,12 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var SummaryArticle = require('./summaryArticle'); +const SummaryArticle = require('./summaryArticle'); /* A part represents a section in the Summary / table of Contents */ -var SummaryPart = Immutable.Record({ +const SummaryPart = Immutable.Record({ level: String(), title: String(), articles: Immutable.List() @@ -30,9 +30,9 @@ SummaryPart.prototype.getArticles = function() { * @return {String} */ SummaryPart.prototype.createChildLevel = function() { - var level = this.getLevel(); - var subArticles = this.getArticles(); - var childLevel = level + '.' + (subArticles.size + 1); + const level = this.getLevel(); + const subArticles = this.getArticles(); + const childLevel = level + '.' + (subArticles.size + 1); return childLevel; }; @@ -44,7 +44,7 @@ SummaryPart.prototype.createChildLevel = function() { * @return {SummaryPart} */ SummaryPart.create = function(def, level) { - var articles = (def.articles || []).map(function(article, i) { + const articles = (def.articles || []).map(function(article, i) { if (article instanceof SummaryArticle) { return article; } diff --git a/packages/gitbook/lib/models/templateBlock.js b/packages/gitbook/src/models/templateBlock.js index 458f084..a0b9aaa 100644 --- a/packages/gitbook/lib/models/templateBlock.js +++ b/packages/gitbook/src/models/templateBlock.js @@ -1,14 +1,14 @@ -var is = require('is'); -var extend = require('extend'); -var Immutable = require('immutable'); +const is = require('is'); +const extend = require('extend'); +const Immutable = require('immutable'); -var Promise = require('../utils/promise'); -var genKey = require('../utils/genKey'); -var TemplateShortcut = require('./templateShortcut'); +const Promise = require('../utils/promise'); +const genKey = require('../utils/genKey'); +const TemplateShortcut = require('./templateShortcut'); -var NODE_ENDARGS = '%%endargs%%'; +const NODE_ENDARGS = '%%endargs%%'; -var TemplateBlock = Immutable.Record({ +const TemplateBlock = Immutable.Record({ // Name of block, also the start tag name: String(), @@ -47,7 +47,7 @@ TemplateBlock.prototype.getBlocks = function() { * @return {TemplateShortcut|undefined} */ TemplateBlock.prototype.getShortcuts = function() { - var shortcuts = this.get('shortcuts'); + const shortcuts = this.get('shortcuts'); if (shortcuts.size === 0) { return undefined; } @@ -70,33 +70,33 @@ TemplateBlock.prototype.getExtensionName = function() { TemplateBlock.prototype.toNunjucksExt = function(mainContext, blocksOutput) { blocksOutput = blocksOutput || {}; - var that = this; - var name = this.getName(); - var endTag = this.getEndTag(); - var blocks = this.getBlocks().toJS(); + const that = this; + const name = this.getName(); + const endTag = this.getEndTag(); + const blocks = this.getBlocks().toJS(); function Ext() { this.tags = [name]; this.parse = function(parser, nodes) { - var lastBlockName = null; - var lastBlockArgs = null; - var allBlocks = blocks.concat([endTag]); + let lastBlockName = null; + let lastBlockArgs = null; + const allBlocks = blocks.concat([endTag]); // Parse first block - var tok = parser.nextToken(); + const tok = parser.nextToken(); lastBlockArgs = parser.parseSignature(null, true); parser.advanceAfterBlockEnd(tok.value); - var args = new nodes.NodeList(); - var bodies = []; - var blockNamesNode = new nodes.Array(tok.lineno, tok.colno); - var blockArgCounts = new nodes.Array(tok.lineno, tok.colno); + const args = new nodes.NodeList(); + const bodies = []; + const blockNamesNode = new nodes.Array(tok.lineno, tok.colno); + const blockArgCounts = new nodes.Array(tok.lineno, tok.colno); // Parse while we found "end<block>" do { // Read body - var currentBody = parser.parseUntilBlocks.apply(parser, allBlocks); + const currentBody = parser.parseUntilBlocks(...allBlocks); // Handle body with previous block name and args blockNamesNode.addChild(new nodes.Literal(args.lineno, args.colno, lastBlockName)); @@ -126,53 +126,48 @@ TemplateBlock.prototype.toNunjucksExt = function(mainContext, blocksOutput) { return new nodes.CallExtensionAsync(this, 'run', args, bodies); }; - this.run = function(context) { - var fnArgs = Array.prototype.slice.call(arguments, 1); - - var args; - var blocks = []; - var bodies = []; - var blockNames; - var blockArgCounts; - var callback; + this.run = function(context, ...fnArgs) { + let args; + const blocks = []; + let bodies = []; // Extract callback - callback = fnArgs.pop(); + const callback = fnArgs.pop(); // Detect end of arguments - var endArgIndex = fnArgs.indexOf(NODE_ENDARGS); + const endArgIndex = fnArgs.indexOf(NODE_ENDARGS); // Extract arguments and bodies args = fnArgs.slice(0, endArgIndex); bodies = fnArgs.slice(endArgIndex + 1); // Extract block counts - blockArgCounts = args.pop(); - blockNames = args.pop(); + const blockArgCounts = args.pop(); + const blockNames = args.pop(); // Recreate list of blocks - blockNames.forEach(function(name, i) { - var countArgs = blockArgCounts[i]; - var blockBody = bodies.shift(); + blockNames.forEach((blkName, i) => { + const countArgs = blockArgCounts[i]; + const blockBody = bodies.shift(); - var blockArgs = countArgs > 0? args.slice(0, countArgs) : []; + const blockArgs = countArgs > 0 ? args.slice(0, countArgs) : []; args = args.slice(countArgs); - var blockKwargs = extractKwargs(blockArgs); + const blockKwargs = extractKwargs(blockArgs); blocks.push({ - name: name, + blkName, body: blockBody(), args: blockArgs, kwargs: blockKwargs }); }); - var mainBlock = blocks.shift(); + const mainBlock = blocks.shift(); mainBlock.blocks = blocks; Promise() .then(function() { - var ctx = extend({ + const ctx = extend({ ctx: context }, mainContext || {}); @@ -195,14 +190,14 @@ TemplateBlock.prototype.toNunjucksExt = function(mainContext, blocksOutput) { * @return {Promise<String>|String} */ TemplateBlock.prototype.applyBlock = function(inner, context) { - var processFn = this.getProcess(); + const processFn = this.getProcess(); inner = inner || {}; inner.args = inner.args || []; inner.kwargs = inner.kwargs || {}; inner.blocks = inner.blocks || []; - var r = processFn.call(context, inner); + const r = processFn.call(context, inner); if (Promise.isPromiseAlike(r)) { return r.then(this.normalizeBlockResult.bind(this)); @@ -232,8 +227,8 @@ TemplateBlock.prototype.normalizeBlockResult = function(result) { * @return {String} */ TemplateBlock.prototype.blockResultToHtml = function(result, blocksOutput) { - var indexedKey; - var toIndex = (!result.parse) || (result.post !== undefined); + let indexedKey; + const toIndex = (!result.parse) || (result.post !== undefined); if (toIndex) { indexedKey = genKey(); @@ -274,8 +269,8 @@ TemplateBlock.create = function(blockName, block) { * @return {Object} */ function extractKwargs(args) { - var last = args[args.length - 1]; - return (is.object(last) && last.__keywords)? args.pop() : {}; + const last = args[args.length - 1]; + return (is.object(last) && last.__keywords) ? args.pop() : {}; } module.exports = TemplateBlock; diff --git a/packages/gitbook/lib/models/templateEngine.js b/packages/gitbook/src/models/templateEngine.js index 5724d55..b218a9d 100644 --- a/packages/gitbook/lib/models/templateEngine.js +++ b/packages/gitbook/src/models/templateEngine.js @@ -1,7 +1,7 @@ -var nunjucks = require('nunjucks'); -var Immutable = require('immutable'); +const nunjucks = require('nunjucks'); +const Immutable = require('immutable'); -var TemplateEngine = Immutable.Record({ +const TemplateEngine = Immutable.Record({ // Map of {TemplateBlock} blocks: Immutable.Map(), @@ -56,7 +56,7 @@ TemplateEngine.prototype.getExtensions = function() { @return {TemplateBlock} */ TemplateEngine.prototype.getBlock = function(name) { - var blocks = this.getBlocks(); + const blocks = this.getBlocks(); return blocks.find(function(block) { return block.getName() === name; }); @@ -68,14 +68,14 @@ TemplateEngine.prototype.getBlock = function(name) { @return {Nunjucks.Environment} */ TemplateEngine.prototype.toNunjucks = function(blocksOutput) { - var loader = this.getLoader(); - var blocks = this.getBlocks(); - var filters = this.getFilters(); - var globals = this.getGlobals(); - var extensions = this.getExtensions(); - var context = this.getContext(); - - var env = new nunjucks.Environment( + const loader = this.getLoader(); + const blocks = this.getBlocks(); + const filters = this.getFilters(); + const globals = this.getGlobals(); + const extensions = this.getExtensions(); + const context = this.getContext(); + + const env = new nunjucks.Environment( loader, { // Escaping is done after by the asciidoc/markdown parser @@ -100,8 +100,8 @@ TemplateEngine.prototype.toNunjucks = function(blocksOutput) { // Add blocks blocks.forEach(function(block) { - var extName = block.getExtensionName(); - var Ext = block.toNunjucksExt(context, blocksOutput); + const extName = block.getExtensionName(); + const Ext = block.toNunjucksExt(context, blocksOutput); env.addExtension(extName, new Ext()); }); diff --git a/packages/gitbook/lib/models/templateOutput.js b/packages/gitbook/src/models/templateOutput.js index ae63c06..c6ff730 100644 --- a/packages/gitbook/lib/models/templateOutput.js +++ b/packages/gitbook/src/models/templateOutput.js @@ -1,6 +1,6 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var TemplateOutput = Immutable.Record({ +const TemplateOutput = Immutable.Record({ // Text content of the template content: String(), @@ -34,7 +34,7 @@ TemplateOutput.prototype.setContent = function(content) { */ TemplateOutput.create = function(content, blocks) { return new TemplateOutput({ - content: content, + content, blocks: Immutable.fromJS(blocks) }); }; diff --git a/packages/gitbook/lib/models/templateShortcut.js b/packages/gitbook/src/models/templateShortcut.js index 309fa6d..b6e1ed9 100644 --- a/packages/gitbook/lib/models/templateShortcut.js +++ b/packages/gitbook/src/models/templateShortcut.js @@ -1,11 +1,11 @@ -var Immutable = require('immutable'); -var is = require('is'); +const Immutable = require('immutable'); +const is = require('is'); /* A TemplateShortcut is defined in plugin's template blocks to replace content with a templating block using delimiters. */ -var TemplateShortcut = Immutable.Record({ +const TemplateShortcut = Immutable.Record({ // List of parser names accepting this shortcut parsers: Immutable.Map(), @@ -47,7 +47,7 @@ TemplateShortcut.prototype.acceptParser = function(parser) { parser = parser.getName(); } - var parserNames = this.get('parsers'); + const parserNames = this.get('parsers'); return parserNames.includes(parser); }; diff --git a/packages/gitbook/lib/modifiers/config/__tests__/addPlugin.js b/packages/gitbook/src/modifiers/config/__tests__/addPlugin.js index 61082c9..65fd8f9 100644 --- a/packages/gitbook/lib/modifiers/config/__tests__/addPlugin.js +++ b/packages/gitbook/src/modifiers/config/__tests__/addPlugin.js @@ -1,13 +1,13 @@ -var addPlugin = require('../addPlugin'); -var Config = require('../../../models/config'); +const addPlugin = require('../addPlugin'); +const Config = require('../../../models/config'); describe('addPlugin', function() { - var config = Config.createWithValues({ + const config = Config.createWithValues({ plugins: ['hello', 'world', '-disabled'] }); it('should have correct state of dependencies', function() { - var disabledDep = config.getPluginDependency('disabled'); + const disabledDep = config.getPluginDependency('disabled'); expect(disabledDep).toBeDefined(); expect(disabledDep.getVersion()).toEqual('*'); @@ -15,18 +15,17 @@ describe('addPlugin', function() { }); it('should add the plugin to the list', function() { - var newConfig = addPlugin(config, 'test'); + const newConfig = addPlugin(config, 'test'); - var testDep = newConfig.getPluginDependency('test'); + const testDep = newConfig.getPluginDependency('test'); expect(testDep).toBeDefined(); expect(testDep.getVersion()).toEqual('*'); expect(testDep.isEnabled()).toBeTruthy(); - var disabledDep = newConfig.getPluginDependency('disabled'); + const disabledDep = newConfig.getPluginDependency('disabled'); expect(disabledDep).toBeDefined(); expect(disabledDep.getVersion()).toEqual('*'); expect(disabledDep.isEnabled()).toBeFalsy(); }); }); - diff --git a/packages/gitbook/lib/modifiers/config/__tests__/removePlugin.js b/packages/gitbook/src/modifiers/config/__tests__/removePlugin.js index 253cc39..5450b30 100644 --- a/packages/gitbook/lib/modifiers/config/__tests__/removePlugin.js +++ b/packages/gitbook/src/modifiers/config/__tests__/removePlugin.js @@ -1,33 +1,32 @@ -var removePlugin = require('../removePlugin'); -var Config = require('../../../models/config'); +const removePlugin = require('../removePlugin'); +const Config = require('../../../models/config'); describe('removePlugin', function() { - var config = Config.createWithValues({ + const config = Config.createWithValues({ plugins: ['hello', 'world', '-disabled'] }); it('should remove the plugin from the list', function() { - var newConfig = removePlugin(config, 'hello'); + const newConfig = removePlugin(config, 'hello'); - var testDep = newConfig.getPluginDependency('hello'); + const testDep = newConfig.getPluginDependency('hello'); expect(testDep).toNotBeDefined(); }); it('should remove the disabled plugin from the list', function() { - var newConfig = removePlugin(config, 'disabled'); + const newConfig = removePlugin(config, 'disabled'); - var testDep = newConfig.getPluginDependency('disabled'); + const testDep = newConfig.getPluginDependency('disabled'); expect(testDep).toNotBeDefined(); }); it('should disable default plugin', function() { - var newConfig = removePlugin(config, 'search'); + const newConfig = removePlugin(config, 'search'); - var disabledDep = newConfig.getPluginDependency('search'); + const disabledDep = newConfig.getPluginDependency('search'); expect(disabledDep).toBeDefined(); expect(disabledDep.getVersion()).toEqual('*'); expect(disabledDep.isEnabled()).toBeFalsy(); }); }); - diff --git a/packages/gitbook/lib/modifiers/config/__tests__/togglePlugin.js b/packages/gitbook/src/modifiers/config/__tests__/togglePlugin.js index 4127853..6d23ae0 100644 --- a/packages/gitbook/lib/modifiers/config/__tests__/togglePlugin.js +++ b/packages/gitbook/src/modifiers/config/__tests__/togglePlugin.js @@ -1,28 +1,27 @@ -var togglePlugin = require('../togglePlugin'); -var Config = require('../../../models/config'); +const togglePlugin = require('../togglePlugin'); +const Config = require('../../../models/config'); describe('togglePlugin', function() { - var config = Config.createWithValues({ + const config = Config.createWithValues({ plugins: ['hello', 'world', '-disabled'] }); it('should enable plugin', function() { - var newConfig = togglePlugin(config, 'disabled'); + const newConfig = togglePlugin(config, 'disabled'); - var testDep = newConfig.getPluginDependency('disabled'); + const testDep = newConfig.getPluginDependency('disabled'); expect(testDep).toBeDefined(); expect(testDep.getVersion()).toEqual('*'); expect(testDep.isEnabled()).toBeTruthy(); }); it('should disable plugin', function() { - var newConfig = togglePlugin(config, 'world'); + const newConfig = togglePlugin(config, 'world'); - var testDep = newConfig.getPluginDependency('world'); + const testDep = newConfig.getPluginDependency('world'); expect(testDep).toBeDefined(); expect(testDep.getVersion()).toEqual('*'); expect(testDep.isEnabled()).toBeFalsy(); }); }); - diff --git a/packages/gitbook/lib/modifiers/config/addPlugin.js b/packages/gitbook/src/modifiers/config/addPlugin.js index b8d4ea1..e9ed259 100644 --- a/packages/gitbook/lib/modifiers/config/addPlugin.js +++ b/packages/gitbook/src/modifiers/config/addPlugin.js @@ -1,6 +1,6 @@ -var PluginDependency = require('../../models/pluginDependency'); -var togglePlugin = require('./togglePlugin'); -var isDefaultPlugin = require('./isDefaultPlugin'); +const PluginDependency = require('../../models/pluginDependency'); +const togglePlugin = require('./togglePlugin'); +const isDefaultPlugin = require('./isDefaultPlugin'); /** * Add a plugin to a book's configuration @@ -15,8 +15,8 @@ function addPlugin(config, pluginName, version) { return togglePlugin(config, pluginName, true); } - var deps = config.getPluginDependencies(); - var dep = PluginDependency.create(pluginName, version); + let deps = config.getPluginDependencies(); + const dep = PluginDependency.create(pluginName, version); deps = deps.push(dep); return config.setPluginDependencies(deps); diff --git a/packages/gitbook/lib/modifiers/config/editPlugin.js b/packages/gitbook/src/modifiers/config/editPlugin.js index a792acd..dd7fd11 100644 --- a/packages/gitbook/lib/modifiers/config/editPlugin.js +++ b/packages/gitbook/src/modifiers/config/editPlugin.js @@ -7,7 +7,7 @@ * @return {Config} */ function editPlugin(config, pluginName, pluginConfig) { - return config.setValue('pluginsConfig.'+pluginName, pluginConfig); + return config.setValue('pluginsConfig.' + pluginName, pluginConfig); } module.exports = editPlugin; diff --git a/packages/gitbook/lib/modifiers/config/getPluginConfig.js b/packages/gitbook/src/modifiers/config/getPluginConfig.js index ae76de8..ed7d6ea 100644 --- a/packages/gitbook/lib/modifiers/config/getPluginConfig.js +++ b/packages/gitbook/src/modifiers/config/getPluginConfig.js @@ -5,11 +5,11 @@ * @return {Object} */ function getPluginConfig(config, pluginName) { - var pluginsConfig = config.getValues().get('pluginsConfig'); + const pluginsConfig = config.getValues().get('pluginsConfig'); if (pluginsConfig === undefined) { return {}; } - var pluginConf = pluginsConfig.get(pluginName); + const pluginConf = pluginsConfig.get(pluginName); if (pluginConf === undefined) { return {}; } else { diff --git a/packages/gitbook/lib/modifiers/config/hasPlugin.js b/packages/gitbook/src/modifiers/config/hasPlugin.js index 9aab4f2..9aab4f2 100644 --- a/packages/gitbook/lib/modifiers/config/hasPlugin.js +++ b/packages/gitbook/src/modifiers/config/hasPlugin.js diff --git a/packages/gitbook/lib/modifiers/config/index.js b/packages/gitbook/src/modifiers/config/index.js index b3de0b0..b3de0b0 100644 --- a/packages/gitbook/lib/modifiers/config/index.js +++ b/packages/gitbook/src/modifiers/config/index.js diff --git a/packages/gitbook/lib/modifiers/config/isDefaultPlugin.js b/packages/gitbook/src/modifiers/config/isDefaultPlugin.js index 63a141d..096e21a 100644 --- a/packages/gitbook/lib/modifiers/config/isDefaultPlugin.js +++ b/packages/gitbook/src/modifiers/config/isDefaultPlugin.js @@ -1,5 +1,5 @@ -var DEFAULT_PLUGINS = require('../../constants/defaultPlugins'); -var hasPlugin = require('./hasPlugin'); +const DEFAULT_PLUGINS = require('../../constants/defaultPlugins'); +const hasPlugin = require('./hasPlugin'); /** * Test if a plugin is a default one diff --git a/packages/gitbook/lib/modifiers/config/removePlugin.js b/packages/gitbook/src/modifiers/config/removePlugin.js index ec06d1e..c80ab84 100644 --- a/packages/gitbook/lib/modifiers/config/removePlugin.js +++ b/packages/gitbook/src/modifiers/config/removePlugin.js @@ -1,5 +1,5 @@ -var togglePlugin = require('./togglePlugin'); -var isDefaultPlugin = require('./isDefaultPlugin'); +const togglePlugin = require('./togglePlugin'); +const isDefaultPlugin = require('./isDefaultPlugin'); /** * Remove a plugin from a book's configuration @@ -8,7 +8,7 @@ var isDefaultPlugin = require('./isDefaultPlugin'); * @return {Config} */ function removePlugin(config, pluginName) { - var deps = config.getPluginDependencies(); + let deps = config.getPluginDependencies(); // For default plugin, we have to disable it instead of removing from the list if (isDefaultPlugin(pluginName)) { diff --git a/packages/gitbook/lib/modifiers/config/togglePlugin.js b/packages/gitbook/src/modifiers/config/togglePlugin.js index a49e3b9..12a6dec 100644 --- a/packages/gitbook/lib/modifiers/config/togglePlugin.js +++ b/packages/gitbook/src/modifiers/config/togglePlugin.js @@ -1,6 +1,6 @@ -var PluginDependency = require('../../models/pluginDependency'); -var hasPlugin = require('./hasPlugin'); -var isDefaultPlugin = require('./isDefaultPlugin'); +const PluginDependency = require('../../models/pluginDependency'); +const hasPlugin = require('./hasPlugin'); +const isDefaultPlugin = require('./isDefaultPlugin'); /** * Enable/disable a plugin dependency @@ -10,7 +10,7 @@ var isDefaultPlugin = require('./isDefaultPlugin'); * @return {Config} */ function togglePlugin(config, pluginName, state) { - var deps = config.getPluginDependencies(); + let deps = config.getPluginDependencies(); // For default plugin, we should ensure it's listed first if (isDefaultPlugin(pluginName) && !hasPlugin(deps, pluginName)) { diff --git a/packages/gitbook/lib/modifiers/index.js b/packages/gitbook/src/modifiers/index.js index ad24604..ad24604 100644 --- a/packages/gitbook/lib/modifiers/index.js +++ b/packages/gitbook/src/modifiers/index.js diff --git a/packages/gitbook/lib/modifiers/summary/__tests__/editArticle.js b/packages/gitbook/src/modifiers/summary/__tests__/editArticle.js index e69de29..e69de29 100644 --- a/packages/gitbook/lib/modifiers/summary/__tests__/editArticle.js +++ b/packages/gitbook/src/modifiers/summary/__tests__/editArticle.js diff --git a/packages/gitbook/lib/modifiers/summary/__tests__/editPartTitle.js b/packages/gitbook/src/modifiers/summary/__tests__/editPartTitle.js index d1b916b..aa14a34 100644 --- a/packages/gitbook/lib/modifiers/summary/__tests__/editPartTitle.js +++ b/packages/gitbook/src/modifiers/summary/__tests__/editPartTitle.js @@ -1,9 +1,9 @@ -var Summary = require('../../../models/summary'); -var File = require('../../../models/file'); +const Summary = require('../../../models/summary'); +const File = require('../../../models/file'); describe('editPartTitle', function() { - var editPartTitle = require('../editPartTitle'); - var summary = Summary.createFromParts(File(), [ + const editPartTitle = require('../editPartTitle'); + const summary = Summary.createFromParts(File(), [ { articles: [ { @@ -22,23 +22,22 @@ describe('editPartTitle', function() { ]); it('should correctly set title of first part', function() { - var newSummary = editPartTitle(summary, 0, 'Hello World'); - var part = newSummary.getPart(0); + const newSummary = editPartTitle(summary, 0, 'Hello World'); + const part = newSummary.getPart(0); expect(part.getTitle()).toBe('Hello World'); }); it('should correctly set title of second part', function() { - var newSummary = editPartTitle(summary, 1, 'Hello'); - var part = newSummary.getPart(1); + const newSummary = editPartTitle(summary, 1, 'Hello'); + const part = newSummary.getPart(1); expect(part.getTitle()).toBe('Hello'); }); it('should not fail if part doesn\'t exist', function() { - var newSummary = editPartTitle(summary, 3, 'Hello'); + const newSummary = editPartTitle(summary, 3, 'Hello'); expect(newSummary.getParts().size).toBe(2); }); }); - diff --git a/packages/gitbook/lib/modifiers/summary/__tests__/insertArticle.js b/packages/gitbook/src/modifiers/summary/__tests__/insertArticle.js index 1ee1c8a..d5ae9bc 100644 --- a/packages/gitbook/lib/modifiers/summary/__tests__/insertArticle.js +++ b/packages/gitbook/src/modifiers/summary/__tests__/insertArticle.js @@ -1,10 +1,10 @@ -var Summary = require('../../../models/summary'); -var SummaryArticle = require('../../../models/summaryArticle'); -var File = require('../../../models/file'); +const Summary = require('../../../models/summary'); +const SummaryArticle = require('../../../models/summaryArticle'); +const File = require('../../../models/file'); describe('insertArticle', function() { - var insertArticle = require('../insertArticle'); - var summary = Summary.createFromParts(File(), [ + const insertArticle = require('../insertArticle'); + const summary = Summary.createFromParts(File(), [ { articles: [ { @@ -43,14 +43,14 @@ describe('insertArticle', function() { ]); it('should insert an article at a given level', function() { - var article = SummaryArticle.create({ + const article = SummaryArticle.create({ title: 'Inserted' }, 'fake.level'); - var newSummary = insertArticle(summary, article, '2.1.1'); + const newSummary = insertArticle(summary, article, '2.1.1'); - var inserted = newSummary.getByLevel('2.1.1'); - var nextOne = newSummary.getByLevel('2.1.2'); + const inserted = newSummary.getByLevel('2.1.1'); + const nextOne = newSummary.getByLevel('2.1.2'); expect(inserted.getTitle()).toBe('Inserted'); expect(inserted.getLevel()).toBe('2.1.1'); @@ -60,14 +60,14 @@ describe('insertArticle', function() { }); it('should insert an article in last position', function() { - var article = SummaryArticle.create({ + const article = SummaryArticle.create({ title: 'Inserted' }, 'fake.level'); - var newSummary = insertArticle(summary, article, '2.2'); + const newSummary = insertArticle(summary, article, '2.2'); - var inserted = newSummary.getByLevel('2.2'); - var previousOne = newSummary.getByLevel('2.1'); + const inserted = newSummary.getByLevel('2.2'); + const previousOne = newSummary.getByLevel('2.1'); expect(inserted.getTitle()).toBe('Inserted'); expect(inserted.getLevel()).toBe('2.2'); diff --git a/packages/gitbook/lib/modifiers/summary/__tests__/insertPart.js b/packages/gitbook/src/modifiers/summary/__tests__/insertPart.js index 11c2cbc..5112931 100644 --- a/packages/gitbook/lib/modifiers/summary/__tests__/insertPart.js +++ b/packages/gitbook/src/modifiers/summary/__tests__/insertPart.js @@ -1,11 +1,11 @@ -var Summary = require('../../../models/summary'); -var SummaryPart = require('../../../models/summaryPart'); +const Summary = require('../../../models/summary'); +const SummaryPart = require('../../../models/summaryPart'); -var File = require('../../../models/file'); +const File = require('../../../models/file'); describe('insertPart', function() { - var insertPart = require('../insertPart'); - var summary = Summary.createFromParts(File(), [ + const insertPart = require('../insertPart'); + const summary = Summary.createFromParts(File(), [ { articles: [ { @@ -31,29 +31,29 @@ describe('insertPart', function() { ]); it('should insert an part at a given level', function() { - var part = SummaryPart.create({ + const part = SummaryPart.create({ title: 'Inserted' }, 'meaningless.level'); - var newSummary = insertPart(summary, part, 1); + const newSummary = insertPart(summary, part, 1); - var inserted = newSummary.getPart(1); + const inserted = newSummary.getPart(1); expect(inserted.getTitle()).toBe('Inserted'); expect(newSummary.getParts().count()).toBe(3); - var otherArticle = newSummary.getByLevel('3.1'); + const otherArticle = newSummary.getByLevel('3.1'); expect(otherArticle.getTitle()).toBe('2.1'); expect(otherArticle.getLevel()).toBe('3.1'); }); it('should insert an part in last position', function() { - var part = SummaryPart.create({ + const part = SummaryPart.create({ title: 'Inserted' }, 'meaningless.level'); - var newSummary = insertPart(summary, part, 2); + const newSummary = insertPart(summary, part, 2); - var inserted = newSummary.getPart(2); + const inserted = newSummary.getPart(2); expect(inserted.getTitle()).toBe('Inserted'); expect(newSummary.getParts().count()).toBe(3); }); diff --git a/packages/gitbook/lib/modifiers/summary/__tests__/mergeAtLevel.js b/packages/gitbook/src/modifiers/summary/__tests__/mergeAtLevel.js index e2635ec..e0d4a62 100644 --- a/packages/gitbook/lib/modifiers/summary/__tests__/mergeAtLevel.js +++ b/packages/gitbook/src/modifiers/summary/__tests__/mergeAtLevel.js @@ -1,10 +1,10 @@ -var Immutable = require('immutable'); -var Summary = require('../../../models/summary'); -var File = require('../../../models/file'); +const Immutable = require('immutable'); +const Summary = require('../../../models/summary'); +const File = require('../../../models/file'); describe('mergeAtLevel', function() { - var mergeAtLevel = require('../mergeAtLevel'); - var summary = Summary.createFromParts(File(), [ + const mergeAtLevel = require('../mergeAtLevel'); + const summary = Summary.createFromParts(File(), [ { articles: [ { @@ -24,9 +24,9 @@ describe('mergeAtLevel', function() { ]); it('should edit a part', function() { - var beforeChildren = summary.getByLevel('1').getArticles(); - var newSummary = mergeAtLevel(summary, '1', {title: 'Part O'}); - var edited = newSummary.getByLevel('1'); + const beforeChildren = summary.getByLevel('1').getArticles(); + const newSummary = mergeAtLevel(summary, '1', {title: 'Part O'}); + const edited = newSummary.getByLevel('1'); expect(edited.getTitle()).toBe('Part O'); // Same children @@ -34,9 +34,9 @@ describe('mergeAtLevel', function() { }); it('should edit a part', function() { - var beforePath = summary.getByLevel('1.2').getPath(); - var newSummary = mergeAtLevel(summary, '1.2', {title: 'Renamed article'}); - var edited = newSummary.getByLevel('1.2'); + const beforePath = summary.getByLevel('1.2').getPath(); + const newSummary = mergeAtLevel(summary, '1.2', {title: 'Renamed article'}); + const edited = newSummary.getByLevel('1.2'); expect(edited.getTitle()).toBe('Renamed article'); // Same children diff --git a/packages/gitbook/lib/modifiers/summary/__tests__/moveArticle.js b/packages/gitbook/src/modifiers/summary/__tests__/moveArticle.js index aed0b94..a7d111b 100644 --- a/packages/gitbook/lib/modifiers/summary/__tests__/moveArticle.js +++ b/packages/gitbook/src/modifiers/summary/__tests__/moveArticle.js @@ -1,10 +1,10 @@ -var Immutable = require('immutable'); -var Summary = require('../../../models/summary'); -var File = require('../../../models/file'); +const Immutable = require('immutable'); +const Summary = require('../../../models/summary'); +const File = require('../../../models/file'); describe('moveArticle', function() { - var moveArticle = require('../moveArticle'); - var summary = Summary.createFromParts(File(), [ + const moveArticle = require('../moveArticle'); + const summary = Summary.createFromParts(File(), [ { articles: [ { @@ -43,24 +43,24 @@ describe('moveArticle', function() { ]); it('should move an article to the same place', function() { - var newSummary = moveArticle(summary, '2.1', '2.1'); + const newSummary = moveArticle(summary, '2.1', '2.1'); expect(Immutable.is(summary, newSummary)).toBe(true); }); it('should move an article to an previous level', function() { - var newSummary = moveArticle(summary, '2.2', '2.1'); - var moved = newSummary.getByLevel('2.1'); - var other = newSummary.getByLevel('2.2'); + const newSummary = moveArticle(summary, '2.2', '2.1'); + const moved = newSummary.getByLevel('2.1'); + const other = newSummary.getByLevel('2.2'); expect(moved.getTitle()).toBe('2.2'); expect(other.getTitle()).toBe('2.1'); }); it('should move an article to a next level', function() { - var newSummary = moveArticle(summary, '2.1', '2.2'); - var moved = newSummary.getByLevel('2.1'); - var other = newSummary.getByLevel('2.2'); + const newSummary = moveArticle(summary, '2.1', '2.2'); + const moved = newSummary.getByLevel('2.1'); + const other = newSummary.getByLevel('2.2'); expect(moved.getTitle()).toBe('2.2'); expect(other.getTitle()).toBe('2.1'); diff --git a/packages/gitbook/lib/modifiers/summary/__tests__/moveArticleAfter.js b/packages/gitbook/src/modifiers/summary/__tests__/moveArticleAfter.js index c380575..446d8a4 100644 --- a/packages/gitbook/lib/modifiers/summary/__tests__/moveArticleAfter.js +++ b/packages/gitbook/src/modifiers/summary/__tests__/moveArticleAfter.js @@ -1,10 +1,10 @@ -var Immutable = require('immutable'); -var Summary = require('../../../models/summary'); -var File = require('../../../models/file'); +const Immutable = require('immutable'); +const Summary = require('../../../models/summary'); +const File = require('../../../models/file'); describe('moveArticleAfter', function() { - var moveArticleAfter = require('../moveArticleAfter'); - var summary = Summary.createFromParts(File(), [ + const moveArticleAfter = require('../moveArticleAfter'); + const summary = Summary.createFromParts(File(), [ { articles: [ { @@ -43,28 +43,28 @@ describe('moveArticleAfter', function() { ]); it('moving right after itself should be invariant', function() { - var newSummary = moveArticleAfter(summary, '2.1', '2.1'); + const newSummary = moveArticleAfter(summary, '2.1', '2.1'); expect(Immutable.is(summary, newSummary)).toBe(true); }); it('moving after previous one should be invariant too', function() { - var newSummary = moveArticleAfter(summary, '2.1', '2.0'); + const newSummary = moveArticleAfter(summary, '2.1', '2.0'); expect(Immutable.is(summary, newSummary)).toBe(true); }); it('should move an article after a previous level', function() { - var newSummary = moveArticleAfter(summary, '2.2', '2.0'); - var moved = newSummary.getByLevel('2.1'); + const newSummary = moveArticleAfter(summary, '2.2', '2.0'); + const moved = newSummary.getByLevel('2.1'); expect(moved.getTitle()).toBe('2.2'); expect(newSummary.getByLevel('2.2').getTitle()).toBe('2.1'); }); it('should move an article after a previous and less deep level', function() { - var newSummary = moveArticleAfter(summary, '2.1.1', '2.0'); - var moved = newSummary.getByLevel('2.1'); + const newSummary = moveArticleAfter(summary, '2.1.1', '2.0'); + const moved = newSummary.getByLevel('2.1'); expect(moved.getTitle()).toBe('2.1.1'); expect(newSummary.getByLevel('2.2.1').getTitle()).toBe('2.1.2'); @@ -72,8 +72,8 @@ describe('moveArticleAfter', function() { }); it('should move an article after a next level', function() { - var newSummary = moveArticleAfter(summary, '2.1', '2.2'); - var moved = newSummary.getByLevel('2.2'); + const newSummary = moveArticleAfter(summary, '2.1', '2.2'); + const moved = newSummary.getByLevel('2.2'); expect(moved.getTitle()).toBe('2.1'); expect(newSummary.getByLevel('2.1').getTitle()).toBe('2.2'); diff --git a/packages/gitbook/lib/modifiers/summary/__tests__/removeArticle.js b/packages/gitbook/src/modifiers/summary/__tests__/removeArticle.js index b45fb49..14587ca 100644 --- a/packages/gitbook/lib/modifiers/summary/__tests__/removeArticle.js +++ b/packages/gitbook/src/modifiers/summary/__tests__/removeArticle.js @@ -1,9 +1,9 @@ -var Summary = require('../../../models/summary'); -var File = require('../../../models/file'); +const Summary = require('../../../models/summary'); +const File = require('../../../models/file'); describe('removeArticle', function() { - var removeArticle = require('../removeArticle'); - var summary = Summary.createFromParts(File(), [ + const removeArticle = require('../removeArticle'); + const summary = Summary.createFromParts(File(), [ { articles: [ { @@ -42,10 +42,10 @@ describe('removeArticle', function() { ]); it('should remove an article at a given level', function() { - var newSummary = removeArticle(summary, '2.1.1'); + const newSummary = removeArticle(summary, '2.1.1'); - var removed = newSummary.getByLevel('2.1.1'); - var nextOne = newSummary.getByLevel('2.1.2'); + const removed = newSummary.getByLevel('2.1.1'); + const nextOne = newSummary.getByLevel('2.1.2'); expect(removed.getTitle()).toBe('2.1.2'); expect(nextOne).toBe(null); diff --git a/packages/gitbook/lib/modifiers/summary/editArticleRef.js b/packages/gitbook/src/modifiers/summary/editArticleRef.js index 7106960..c5c1868 100644 --- a/packages/gitbook/lib/modifiers/summary/editArticleRef.js +++ b/packages/gitbook/src/modifiers/summary/editArticleRef.js @@ -1,4 +1,4 @@ -var mergeAtLevel = require('./mergeAtLevel'); +const mergeAtLevel = require('./mergeAtLevel'); /** Edit the ref of an article diff --git a/packages/gitbook/lib/modifiers/summary/editArticleTitle.js b/packages/gitbook/src/modifiers/summary/editArticleTitle.js index 4edee83..f55c97e 100644 --- a/packages/gitbook/lib/modifiers/summary/editArticleTitle.js +++ b/packages/gitbook/src/modifiers/summary/editArticleTitle.js @@ -1,4 +1,4 @@ -var mergeAtLevel = require('./mergeAtLevel'); +const mergeAtLevel = require('./mergeAtLevel'); /** Edit title of an article diff --git a/packages/gitbook/lib/modifiers/summary/editPartTitle.js b/packages/gitbook/src/modifiers/summary/editPartTitle.js index b79ac1e..ace7058 100644 --- a/packages/gitbook/lib/modifiers/summary/editPartTitle.js +++ b/packages/gitbook/src/modifiers/summary/editPartTitle.js @@ -7,9 +7,9 @@ @return {Summary} */ function editPartTitle(summary, index, newTitle) { - var parts = summary.getParts(); + let parts = summary.getParts(); - var part = parts.get(index); + let part = parts.get(index); if (!part) { return summary; } diff --git a/packages/gitbook/lib/modifiers/summary/index.js b/packages/gitbook/src/modifiers/summary/index.js index f91fdb6..f91fdb6 100644 --- a/packages/gitbook/lib/modifiers/summary/index.js +++ b/packages/gitbook/src/modifiers/summary/index.js diff --git a/packages/gitbook/lib/modifiers/summary/indexArticleLevels.js b/packages/gitbook/src/modifiers/summary/indexArticleLevels.js index f311f74..03c26c7 100644 --- a/packages/gitbook/lib/modifiers/summary/indexArticleLevels.js +++ b/packages/gitbook/src/modifiers/summary/indexArticleLevels.js @@ -8,7 +8,7 @@ */ function indexArticleLevels(article, baseLevel) { baseLevel = baseLevel || article.getLevel(); - var articles = article.getArticles(); + let articles = article.getArticles(); articles = articles.map(function(inner, i) { return indexArticleLevels(inner, baseLevel + '.' + (i + 1)); @@ -16,7 +16,7 @@ function indexArticleLevels(article, baseLevel) { return article.merge({ level: baseLevel, - articles: articles + articles }); } diff --git a/packages/gitbook/lib/modifiers/summary/indexLevels.js b/packages/gitbook/src/modifiers/summary/indexLevels.js index 604e9ff..deb76da 100644 --- a/packages/gitbook/lib/modifiers/summary/indexLevels.js +++ b/packages/gitbook/src/modifiers/summary/indexLevels.js @@ -1,4 +1,4 @@ -var indexPartLevels = require('./indexPartLevels'); +const indexPartLevels = require('./indexPartLevels'); /** Index all levels in the summary @@ -7,7 +7,7 @@ var indexPartLevels = require('./indexPartLevels'); @return {Summary} */ function indexLevels(summary) { - var parts = summary.getParts(); + let parts = summary.getParts(); parts = parts.map(indexPartLevels); return summary.set('parts', parts); diff --git a/packages/gitbook/lib/modifiers/summary/indexPartLevels.js b/packages/gitbook/src/modifiers/summary/indexPartLevels.js index d19c70a..6e48778 100644 --- a/packages/gitbook/lib/modifiers/summary/indexPartLevels.js +++ b/packages/gitbook/src/modifiers/summary/indexPartLevels.js @@ -1,4 +1,4 @@ -var indexArticleLevels = require('./indexArticleLevels'); +const indexArticleLevels = require('./indexArticleLevels'); /** Index levels in a part @@ -8,8 +8,8 @@ var indexArticleLevels = require('./indexArticleLevels'); @return {Part} */ function indexPartLevels(part, index) { - var baseLevel = String(index + 1); - var articles = part.getArticles(); + const baseLevel = String(index + 1); + let articles = part.getArticles(); articles = articles.map(function(inner, i) { return indexArticleLevels(inner, baseLevel + '.' + (i + 1)); @@ -17,7 +17,7 @@ function indexPartLevels(part, index) { return part.merge({ level: baseLevel, - articles: articles + articles }); } diff --git a/packages/gitbook/lib/modifiers/summary/insertArticle.js b/packages/gitbook/src/modifiers/summary/insertArticle.js index 3a084b3..537f548 100644 --- a/packages/gitbook/lib/modifiers/summary/insertArticle.js +++ b/packages/gitbook/src/modifiers/summary/insertArticle.js @@ -1,7 +1,7 @@ -var is = require('is'); -var SummaryArticle = require('../../models/summaryArticle'); -var mergeAtLevel = require('./mergeAtLevel'); -var indexArticleLevels = require('./indexArticleLevels'); +const is = require('is'); +const SummaryArticle = require('../../models/summaryArticle'); +const mergeAtLevel = require('./mergeAtLevel'); +const indexArticleLevels = require('./indexArticleLevels'); /** Returns a new Summary with the article at the given level, with @@ -14,16 +14,16 @@ var indexArticleLevels = require('./indexArticleLevels'); */ function insertArticle(summary, article, level) { article = SummaryArticle(article); - level = is.string(level)? level : level.getLevel(); + level = is.string(level) ? level : level.getLevel(); - var parent = summary.getParent(level); + let parent = summary.getParent(level); if (!parent) { return summary; } // Find the index to insert at - var articles = parent.getArticles(); - var index = getLeafIndex(level); + let articles = parent.getArticles(); + const index = getLeafIndex(level); // Insert the article at the right index articles = articles.insert(index, article); @@ -40,7 +40,7 @@ function insertArticle(summary, article, level) { @return {Number} The index of this level within its parent's children */ function getLeafIndex(level) { - var arr = level.split('.').map(function (char) { + const arr = level.split('.').map(function(char) { return parseInt(char, 10); }); return arr[arr.length - 1] - 1; diff --git a/packages/gitbook/lib/modifiers/summary/insertPart.js b/packages/gitbook/src/modifiers/summary/insertPart.js index 199cba7..ea99f89 100644 --- a/packages/gitbook/lib/modifiers/summary/insertPart.js +++ b/packages/gitbook/src/modifiers/summary/insertPart.js @@ -1,5 +1,5 @@ -var SummaryPart = require('../../models/summaryPart'); -var indexLevels = require('./indexLevels'); +const SummaryPart = require('../../models/summaryPart'); +const indexLevels = require('./indexLevels'); /** Returns a new Summary with a part inserted at given index @@ -12,7 +12,7 @@ var indexLevels = require('./indexLevels'); function insertPart(summary, part, index) { part = SummaryPart(part); - var parts = summary.getParts().insert(index, part); + const parts = summary.getParts().insert(index, part); return indexLevels(summary.set('parts', parts)); } diff --git a/packages/gitbook/lib/modifiers/summary/mergeAtLevel.js b/packages/gitbook/src/modifiers/summary/mergeAtLevel.js index 9a95ffc..ea01763 100644 --- a/packages/gitbook/lib/modifiers/summary/mergeAtLevel.js +++ b/packages/gitbook/src/modifiers/summary/mergeAtLevel.js @@ -9,14 +9,14 @@ */ function editArticleInList(articles, level, newArticle) { return articles.map(function(article) { - var articleLevel = article.getLevel(); + const articleLevel = article.getLevel(); if (articleLevel === level) { // it is the article to edit return article.merge(newArticle); } else if (level.indexOf(articleLevel) === 0) { // it is a parent - var articles = editArticleInList(article.getArticles(), level, newArticle); + const articles = editArticleInList(article.getArticles(), level, newArticle); return article.set('articles', articles); } else { // This is not the article you are looking for @@ -35,7 +35,7 @@ function editArticleInList(articles, level, newArticle) { @return {Part} */ function editArticleInPart(part, level, newArticle) { - var articles = part.getArticles(); + let articles = part.getArticles(); articles = editArticleInList(articles, level, newArticle); return part.set('articles', articles); @@ -51,16 +51,16 @@ function editArticleInPart(part, level, newArticle) { @return {Summary} */ function mergeAtLevel(summary, level, newValue) { - var levelParts = level.split('.'); - var partIndex = Number(levelParts[0]) -1; + const levelParts = level.split('.'); + const partIndex = Number(levelParts[0]) - 1; - var parts = summary.getParts(); - var part = parts.get(partIndex); + let parts = summary.getParts(); + let part = parts.get(partIndex); if (!part) { return summary; } - var isEditingPart = levelParts.length < 2; + const isEditingPart = levelParts.length < 2; if (isEditingPart) { part = part.merge(newValue); } else { diff --git a/packages/gitbook/lib/modifiers/summary/moveArticle.js b/packages/gitbook/src/modifiers/summary/moveArticle.js index 5cb1868..29d4748 100644 --- a/packages/gitbook/lib/modifiers/summary/moveArticle.js +++ b/packages/gitbook/src/modifiers/summary/moveArticle.js @@ -1,6 +1,6 @@ -var is = require('is'); -var removeArticle = require('./removeArticle'); -var insertArticle = require('./insertArticle'); +const is = require('is'); +const removeArticle = require('./removeArticle'); +const insertArticle = require('./insertArticle'); /** Returns a new summary, with the given article removed from its @@ -13,12 +13,12 @@ var insertArticle = require('./insertArticle'); */ function moveArticle(summary, origin, target) { // Coerce to level - var originLevel = is.string(origin)? origin : origin.getLevel(); - var targetLevel = is.string(target)? target : target.getLevel(); - var article = summary.getByLevel(originLevel); + const originLevel = is.string(origin) ? origin : origin.getLevel(); + const targetLevel = is.string(target) ? target : target.getLevel(); + const article = summary.getByLevel(originLevel); // Remove first - var removed = removeArticle(summary, originLevel); + const removed = removeArticle(summary, originLevel); return insertArticle(removed, article, targetLevel); } diff --git a/packages/gitbook/lib/modifiers/summary/moveArticleAfter.js b/packages/gitbook/src/modifiers/summary/moveArticleAfter.js index e268f73..a1ed28f 100644 --- a/packages/gitbook/lib/modifiers/summary/moveArticleAfter.js +++ b/packages/gitbook/src/modifiers/summary/moveArticleAfter.js @@ -1,6 +1,6 @@ -var is = require('is'); -var removeArticle = require('./removeArticle'); -var insertArticle = require('./insertArticle'); +const is = require('is'); +const removeArticle = require('./removeArticle'); +const insertArticle = require('./insertArticle'); /** Returns a new summary, with the an article moved after another @@ -14,20 +14,20 @@ var insertArticle = require('./insertArticle'); */ function moveArticleAfter(summary, origin, afterTarget) { // Coerce to level - var originLevel = is.string(origin)? origin : origin.getLevel(); - var afterTargetLevel = is.string(afterTarget)? afterTarget : afterTarget.getLevel(); - var article = summary.getByLevel(originLevel); + const originLevel = is.string(origin) ? origin : origin.getLevel(); + const afterTargetLevel = is.string(afterTarget) ? afterTarget : afterTarget.getLevel(); + const article = summary.getByLevel(originLevel); - var targetLevel = increment(afterTargetLevel); + const targetLevel = increment(afterTargetLevel); if (targetLevel < origin) { // Remove first - var removed = removeArticle(summary, originLevel); + const removed = removeArticle(summary, originLevel); // Insert then return insertArticle(removed, article, targetLevel); } else { // Insert right after first - var inserted = insertArticle(summary, article, targetLevel); + const inserted = insertArticle(summary, article, targetLevel); // Remove old one return removeArticle(inserted, originLevel); } @@ -38,7 +38,7 @@ function moveArticleAfter(summary, origin, afterTarget) { @return {Array<Number>} */ function levelToArray(l) { - return l.split('.').map(function (char) { + return l.split('.').map(function(char) { return parseInt(char, 10); }); } diff --git a/packages/gitbook/lib/modifiers/summary/removeArticle.js b/packages/gitbook/src/modifiers/summary/removeArticle.js index 8a30d0a..0c4cd33 100644 --- a/packages/gitbook/lib/modifiers/summary/removeArticle.js +++ b/packages/gitbook/src/modifiers/summary/removeArticle.js @@ -1,6 +1,6 @@ -var is = require('is'); -var mergeAtLevel = require('./mergeAtLevel'); -var indexArticleLevels = require('./indexArticleLevels'); +const is = require('is'); +const mergeAtLevel = require('./mergeAtLevel'); +const indexArticleLevels = require('./indexArticleLevels'); /** Remove an article from a level. @@ -11,13 +11,13 @@ var indexArticleLevels = require('./indexArticleLevels'); */ function removeArticle(summary, level) { // Coerce to level - level = is.string(level)? level : level.getLevel(); + level = is.string(level) ? level : level.getLevel(); - var parent = summary.getParent(level); + let parent = summary.getParent(level); - var articles = parent.getArticles(); + let articles = parent.getArticles(); // Find the index to remove - var index = articles.findIndex(function(art) { + const index = articles.findIndex(function(art) { return art.getLevel() === level; }); if (index === -1) { diff --git a/packages/gitbook/lib/modifiers/summary/removePart.js b/packages/gitbook/src/modifiers/summary/removePart.js index 2f8affc..30502dc 100644 --- a/packages/gitbook/lib/modifiers/summary/removePart.js +++ b/packages/gitbook/src/modifiers/summary/removePart.js @@ -1,4 +1,4 @@ -var indexLevels = require('./indexLevels'); +const indexLevels = require('./indexLevels'); /** Remove a part at given index @@ -8,7 +8,7 @@ var indexLevels = require('./indexLevels'); @return {Summary} */ function removePart(summary, index) { - var parts = summary.getParts().remove(index); + const parts = summary.getParts().remove(index); return indexLevels(summary.set('parts', parts)); } diff --git a/packages/gitbook/lib/modifiers/summary/unshiftArticle.js b/packages/gitbook/src/modifiers/summary/unshiftArticle.js index d1ebc05..c5810f0 100644 --- a/packages/gitbook/lib/modifiers/summary/unshiftArticle.js +++ b/packages/gitbook/src/modifiers/summary/unshiftArticle.js @@ -1,7 +1,7 @@ -var SummaryArticle = require('../../models/summaryArticle'); -var SummaryPart = require('../../models/summaryPart'); +const SummaryArticle = require('../../models/summaryArticle'); +const SummaryPart = require('../../models/summaryPart'); -var indexLevels = require('./indexLevels'); +const indexLevels = require('./indexLevels'); /** Insert an article at the beginning of summary @@ -13,10 +13,10 @@ var indexLevels = require('./indexLevels'); function unshiftArticle(summary, article) { article = SummaryArticle(article); - var parts = summary.getParts(); - var part = parts.get(0) || SummaryPart(); + let parts = summary.getParts(); + let part = parts.get(0) || SummaryPart(); - var articles = part.getArticles(); + let articles = part.getArticles(); articles = articles.unshift(article); part = part.set('articles', articles); diff --git a/packages/gitbook/lib/output/__tests__/createMock.js b/packages/gitbook/src/output/__tests__/createMock.js index f21c544..09b93da 100644 --- a/packages/gitbook/lib/output/__tests__/createMock.js +++ b/packages/gitbook/src/output/__tests__/createMock.js @@ -1,10 +1,10 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var Output = require('../../models/output'); -var Book = require('../../models/book'); -var parseBook = require('../../parse/parseBook'); -var createMockFS = require('../../fs/mock'); -var preparePlugins = require('../preparePlugins'); +const Output = require('../../models/output'); +const Book = require('../../models/book'); +const parseBook = require('../../parse/parseBook'); +const createMockFS = require('../../fs/mock'); +const preparePlugins = require('../preparePlugins'); /** * Create an output using a generator @@ -16,9 +16,9 @@ var preparePlugins = require('../preparePlugins'); * @return {Promise<Output>} */ function createMockOutput(generator, files, options) { - var fs = createMockFS(files); - var book = Book.createForFS(fs); - var state = generator.State? generator.State({}) : Immutable.Map(); + const fs = createMockFS(files); + let book = Book.createForFS(fs); + const state = generator.State ? generator.State({}) : Immutable.Map(); book = book.setLogLevel('disabled'); options = generator.Options(options); @@ -27,8 +27,8 @@ function createMockOutput(generator, files, options) { .then(function(resultBook) { return new Output({ book: resultBook, - options: options, - state: state, + options, + state, generator: generator.name }); }) diff --git a/packages/gitbook/lib/output/__tests__/ebook.js b/packages/gitbook/src/output/__tests__/ebook.js index 9266e9f..425ab6b 100644 --- a/packages/gitbook/lib/output/__tests__/ebook.js +++ b/packages/gitbook/src/output/__tests__/ebook.js @@ -1,5 +1,5 @@ -var generateMock = require('./generateMock'); -var EbookGenerator = require('../ebook'); +const generateMock = require('./generateMock'); +const EbookGenerator = require('../ebook'); describe('EbookGenerator', function() { diff --git a/packages/gitbook/lib/output/__tests__/generateMock.js b/packages/gitbook/src/output/__tests__/generateMock.js index 691ee2d..a0be244 100644 --- a/packages/gitbook/lib/output/__tests__/generateMock.js +++ b/packages/gitbook/src/output/__tests__/generateMock.js @@ -1,9 +1,9 @@ -var tmp = require('tmp'); +const tmp = require('tmp'); -var Book = require('../../models/book'); -var createMockFS = require('../../fs/mock'); -var parseBook = require('../../parse/parseBook'); -var generateBook = require('../generateBook'); +const Book = require('../../models/book'); +const createMockFS = require('../../fs/mock'); +const parseBook = require('../../parse/parseBook'); +const generateBook = require('../generateBook'); /** * Generate a book using a generator @@ -16,13 +16,13 @@ var generateBook = require('../generateBook'); * @return {Promise<String>} */ function generateMock(Generator, files) { - var fs = createMockFS(files); - var book = Book.createForFS(fs); - var dir; + const fs = createMockFS(files); + let book = Book.createForFS(fs); + let dir; try { dir = tmp.dirSync(); - } catch(err) { + } catch (err) { throw err; } diff --git a/packages/gitbook/lib/output/__tests__/json.js b/packages/gitbook/src/output/__tests__/json.js index 12ab567..d4992ec 100644 --- a/packages/gitbook/lib/output/__tests__/json.js +++ b/packages/gitbook/src/output/__tests__/json.js @@ -1,5 +1,5 @@ -var generateMock = require('./generateMock'); -var JSONGenerator = require('../json'); +const generateMock = require('./generateMock'); +const JSONGenerator = require('../json'); describe('JSONGenerator', function() { diff --git a/packages/gitbook/lib/output/__tests__/website.js b/packages/gitbook/src/output/__tests__/website.js index 1f8c3c0..d39842f 100644 --- a/packages/gitbook/lib/output/__tests__/website.js +++ b/packages/gitbook/src/output/__tests__/website.js @@ -1,6 +1,6 @@ -var fs = require('fs'); -var generateMock = require('./generateMock'); -var WebsiteGenerator = require('../website'); +const fs = require('fs'); +const generateMock = require('./generateMock'); +const WebsiteGenerator = require('../website'); describe('WebsiteGenerator', function() { @@ -14,7 +14,7 @@ describe('WebsiteGenerator', function() { }); describe('Glossary', function() { - var folder; + let folder; before(function() { return generateMock(WebsiteGenerator, { @@ -35,12 +35,12 @@ describe('WebsiteGenerator', function() { }); it('should correctly resolve glossary links in README', function() { - var html = fs.readFileSync(folder + '/index.html', 'utf8'); + const html = fs.readFileSync(folder + '/index.html', 'utf8'); expect(html).toHaveDOMElement('.page-inner a[href="GLOSSARY.html#hello"]'); }); it('should correctly resolve glossary links in directory', function() { - var html = fs.readFileSync(folder + '/folder/page.html', 'utf8'); + const html = fs.readFileSync(folder + '/folder/page.html', 'utf8'); expect(html).toHaveDOMElement('.page-inner a[href="../GLOSSARY.html#hello"]'); }); @@ -54,7 +54,7 @@ describe('WebsiteGenerator', function() { expect(folder).toHaveFile('custom.html'); expect(folder).toNotHaveFile('GLOSSARY.html'); - var html = fs.readFileSync(folder + '/index.html', 'utf8'); + const html = fs.readFileSync(folder + '/index.html', 'utf8'); expect(html).toHaveDOMElement('.page-inner a[href="custom.html#hello"]'); }); }); diff --git a/packages/gitbook/lib/output/callHook.js b/packages/gitbook/src/output/callHook.js index 4914e52..2180102 100644 --- a/packages/gitbook/lib/output/callHook.js +++ b/packages/gitbook/src/output/callHook.js @@ -1,6 +1,6 @@ -var Promise = require('../utils/promise'); -var timing = require('../utils/timing'); -var Api = require('../api'); +const Promise = require('../utils/promise'); +const timing = require('../utils/timing'); +const Api = require('../api'); function defaultGetArgument() { return undefined; @@ -23,13 +23,13 @@ function callHook(name, getArgument, handleResult, output) { getArgument = getArgument || defaultGetArgument; handleResult = handleResult || defaultHandleResult; - var logger = output.getLogger(); - var plugins = output.getPlugins(); + const logger = output.getLogger(); + const plugins = output.getPlugins(); logger.debug.ln('calling hook "' + name + '"'); // Create the JS context for plugins - var context = Api.encodeGlobal(output); + const context = Api.encodeGlobal(output); return timing.measure( 'call.hook.' + name, @@ -40,7 +40,7 @@ function callHook(name, getArgument, handleResult, output) { // Call the hooks in serie .then(function(arg) { return Promise.reduce(plugins, function(prev, plugin) { - var hook = plugin.getHook(name); + const hook = plugin.getHook(name); if (!hook) { return prev; } diff --git a/packages/gitbook/lib/output/callPageHook.js b/packages/gitbook/src/output/callPageHook.js index c66cef0..af249c9 100644 --- a/packages/gitbook/lib/output/callPageHook.js +++ b/packages/gitbook/src/output/callPageHook.js @@ -1,5 +1,5 @@ -var Api = require('../api'); -var callHook = require('./callHook'); +const Api = require('../api'); +const callHook = require('./callHook'); /** Call a hook for a specific page diff --git a/packages/gitbook/src/output/createTemplateEngine.js b/packages/gitbook/src/output/createTemplateEngine.js new file mode 100644 index 0000000..03e7d84 --- /dev/null +++ b/packages/gitbook/src/output/createTemplateEngine.js @@ -0,0 +1,45 @@ +const Templating = require('../templating'); +const TemplateEngine = require('../models/templateEngine'); + +const Api = require('../api'); +const Plugins = require('../plugins'); + +const defaultBlocks = require('../constants/defaultBlocks'); +const defaultFilters = require('../constants/defaultFilters'); + +/** + Create template engine for an output. + It adds default filters/blocks, then add the ones from plugins + + @param {Output} output + @return {TemplateEngine} +*/ +function createTemplateEngine(output) { + const plugins = output.getPlugins(); + const book = output.getBook(); + const rootFolder = book.getContentRoot(); + const logger = book.getLogger(); + + let filters = Plugins.listFilters(plugins); + let blocks = Plugins.listBlocks(plugins); + + // Extend with default + blocks = defaultBlocks.merge(blocks); + filters = defaultFilters.merge(filters); + + // Create loader + const transformFn = Templating.replaceShortcuts.bind(null, blocks); + const loader = new Templating.ConrefsLoader(rootFolder, transformFn, logger); + + // Create API context + const context = Api.encodeGlobal(output); + + return new TemplateEngine({ + filters, + blocks, + loader, + context + }); +} + +module.exports = createTemplateEngine; diff --git a/packages/gitbook/lib/output/ebook/getConvertOptions.js b/packages/gitbook/src/output/ebook/getConvertOptions.js index bc80493..b37c68e 100644 --- a/packages/gitbook/lib/output/ebook/getConvertOptions.js +++ b/packages/gitbook/src/output/ebook/getConvertOptions.js @@ -1,8 +1,8 @@ -var extend = require('extend'); +const extend = require('extend'); -var Promise = require('../../utils/promise'); -var getPDFTemplate = require('./getPDFTemplate'); -var getCoverPath = require('./getCoverPath'); +const Promise = require('../../utils/promise'); +const getPDFTemplate = require('./getPDFTemplate'); +const getCoverPath = require('./getCoverPath'); /** Generate options for ebook-convert @@ -11,16 +11,16 @@ var getCoverPath = require('./getCoverPath'); @return {Promise<Object>} */ function getConvertOptions(output) { - var options = output.getOptions(); - var format = options.get('format'); + const options = output.getOptions(); + const format = options.get('format'); - var book = output.getBook(); - var config = book.getConfig(); + const book = output.getBook(); + const config = book.getConfig(); return Promise() .then(function() { - var coverPath = getCoverPath(output); - var options = { + const coverPath = getCoverPath(output); + let options = { '--cover': coverPath, '--title': config.getValue('title'), '--comments': config.getValue('description'), @@ -36,7 +36,7 @@ function getConvertOptions(output) { '--max-levels': '1', '--no-chapters-in-toc': true, '--breadth-first': true, - '--dont-split-on-page-breaks': format === 'epub'? true : undefined + '--dont-split-on-page-breaks': format === 'epub' ? true : undefined }; if (format !== 'pdf') { @@ -48,7 +48,7 @@ function getConvertOptions(output) { getPDFTemplate(output, 'footer') ]) .spread(function(headerTpl, footerTpl) { - var pdfOptions = config.getValue('pdf').toJS(); + const pdfOptions = config.getValue('pdf').toJS(); return options = extend(options, { '--chapter-mark': String(pdfOptions.chapterMark), diff --git a/packages/gitbook/lib/output/ebook/getCoverPath.js b/packages/gitbook/src/output/ebook/getCoverPath.js index ab6b579..cf18c8d 100644 --- a/packages/gitbook/lib/output/ebook/getCoverPath.js +++ b/packages/gitbook/src/output/ebook/getCoverPath.js @@ -1,5 +1,5 @@ -var path = require('path'); -var fs = require('../../utils/fs'); +const path = require('path'); +const fs = require('../../utils/fs'); /** Resolve path to cover file to use @@ -8,13 +8,13 @@ var fs = require('../../utils/fs'); @return {String} */ function getCoverPath(output) { - var outputRoot = output.getRoot(); - var book = output.getBook(); - var config = book.getConfig(); - var coverName = config.getValue('cover', 'cover.jpg'); + const outputRoot = output.getRoot(); + const book = output.getBook(); + const config = book.getConfig(); + const coverName = config.getValue('cover', 'cover.jpg'); // Resolve to absolute - var cover = fs.pickFile(outputRoot, coverName); + let cover = fs.pickFile(outputRoot, coverName); if (cover) { return cover; } diff --git a/packages/gitbook/lib/output/ebook/getPDFTemplate.js b/packages/gitbook/src/output/ebook/getPDFTemplate.js index b767daf..c0faed3 100644 --- a/packages/gitbook/lib/output/ebook/getPDFTemplate.js +++ b/packages/gitbook/src/output/ebook/getPDFTemplate.js @@ -1,9 +1,9 @@ -var juice = require('juice'); +const juice = require('juice'); -var WebsiteGenerator = require('../website'); -var JSONUtils = require('../../json'); -var Templating = require('../../templating'); -var Promise = require('../../utils/promise'); +const WebsiteGenerator = require('../website'); +const JSONUtils = require('../../json'); +const Templating = require('../../templating'); +const Promise = require('../../utils/promise'); /** @@ -14,12 +14,12 @@ var Promise = require('../../utils/promise'); @return {String} */ function getPDFTemplate(output, type) { - var filePath = 'pdf_' + type + '.html'; - var outputRoot = output.getRoot(); - var engine = WebsiteGenerator.createTemplateEngine(output, filePath); + const filePath = 'pdf_' + type + '.html'; + const outputRoot = output.getRoot(); + const engine = WebsiteGenerator.createTemplateEngine(output, filePath); // Generate context - var context = JSONUtils.encodeOutput(output); + const context = JSONUtils.encodeOutput(output); context.page = { num: '_PAGENUM_', title: '_SECTION_' diff --git a/packages/gitbook/lib/output/ebook/index.js b/packages/gitbook/src/output/ebook/index.js index 786a10a..c5c07c2 100644 --- a/packages/gitbook/lib/output/ebook/index.js +++ b/packages/gitbook/src/output/ebook/index.js @@ -1,5 +1,5 @@ -var extend = require('extend'); -var WebsiteGenerator = require('../website'); +const extend = require('extend'); +const WebsiteGenerator = require('../website'); module.exports = extend({}, WebsiteGenerator, { name: 'ebook', diff --git a/packages/gitbook/lib/output/ebook/onFinish.js b/packages/gitbook/src/output/ebook/onFinish.js index 7f21548..adff798 100644 --- a/packages/gitbook/lib/output/ebook/onFinish.js +++ b/packages/gitbook/src/output/ebook/onFinish.js @@ -1,15 +1,15 @@ -var path = require('path'); +const path = require('path'); -var WebsiteGenerator = require('../website'); -var JSONUtils = require('../../json'); -var Templating = require('../../templating'); -var Promise = require('../../utils/promise'); -var error = require('../../utils/error'); -var command = require('../../utils/command'); -var writeFile = require('../helper/writeFile'); +const WebsiteGenerator = require('../website'); +const JSONUtils = require('../../json'); +const Templating = require('../../templating'); +const Promise = require('../../utils/promise'); +const error = require('../../utils/error'); +const command = require('../../utils/command'); +const writeFile = require('../helper/writeFile'); -var getConvertOptions = require('./getConvertOptions'); -var SUMMARY_FILE = 'SUMMARY.html'; +const getConvertOptions = require('./getConvertOptions'); +const SUMMARY_FILE = 'SUMMARY.html'; /** Write the SUMMARY.html @@ -18,12 +18,12 @@ var SUMMARY_FILE = 'SUMMARY.html'; @return {Output} */ function writeSummary(output) { - var options = output.getOptions(); - var prefix = options.get('prefix'); + const options = output.getOptions(); + const prefix = options.get('prefix'); - var filePath = SUMMARY_FILE; - var engine = WebsiteGenerator.createTemplateEngine(output, filePath); - var context = JSONUtils.encodeOutput(output); + const filePath = SUMMARY_FILE; + const engine = WebsiteGenerator.createTemplateEngine(output, filePath); + const context = JSONUtils.encodeOutput(output); // Render the theme return Templating.renderFile(engine, prefix + '/summary.html', context) @@ -41,10 +41,10 @@ function writeSummary(output) { @return {Output} */ function runEbookConvert(output) { - var logger = output.getLogger(); - var options = output.getOptions(); - var format = options.get('format'); - var outputFolder = output.getRoot(); + const logger = output.getLogger(); + const options = output.getOptions(); + const format = options.get('format'); + const outputFolder = output.getRoot(); if (!format) { return Promise(output); @@ -52,7 +52,7 @@ function runEbookConvert(output) { return getConvertOptions(output) .then(function(options) { - var cmd = [ + const cmd = [ 'ebook-convert', path.resolve(outputFolder, SUMMARY_FILE), path.resolve(outputFolder, 'index.' + format), diff --git a/packages/gitbook/lib/output/ebook/onPage.js b/packages/gitbook/src/output/ebook/onPage.js index b7b9b42..520d296 100644 --- a/packages/gitbook/lib/output/ebook/onPage.js +++ b/packages/gitbook/src/output/ebook/onPage.js @@ -1,5 +1,5 @@ -var WebsiteGenerator = require('../website'); -var Modifiers = require('../modifiers'); +const WebsiteGenerator = require('../website'); +const Modifiers = require('../modifiers'); /** Write a page for ebook output @@ -8,7 +8,7 @@ var Modifiers = require('../modifiers'); @param {Output} */ function onPage(output, page) { - var options = output.getOptions(); + const options = output.getOptions(); // Inline assets return Modifiers.modifyHTML(page, [ diff --git a/packages/gitbook/lib/output/ebook/options.js b/packages/gitbook/src/output/ebook/options.js index ea7b8b4..4156fac 100644 --- a/packages/gitbook/lib/output/ebook/options.js +++ b/packages/gitbook/src/output/ebook/options.js @@ -1,6 +1,6 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var Options = Immutable.Record({ +const Options = Immutable.Record({ // Root folder for the output root: String(), diff --git a/packages/gitbook/lib/output/generateAssets.js b/packages/gitbook/src/output/generateAssets.js index 7a6e104..2129553 100644 --- a/packages/gitbook/lib/output/generateAssets.js +++ b/packages/gitbook/src/output/generateAssets.js @@ -1,4 +1,4 @@ -var Promise = require('../utils/promise'); +const Promise = require('../utils/promise'); /** Output all assets using a generator @@ -8,8 +8,8 @@ var Promise = require('../utils/promise'); @return {Promise<Output>} */ function generateAssets(generator, output) { - var assets = output.getAssets(); - var logger = output.getLogger(); + const assets = output.getAssets(); + const logger = output.getLogger(); // Is generator ignoring assets? if (!generator.onAsset) { diff --git a/packages/gitbook/lib/output/generateBook.js b/packages/gitbook/src/output/generateBook.js index 46712bd..ea8c78e 100644 --- a/packages/gitbook/lib/output/generateBook.js +++ b/packages/gitbook/src/output/generateBook.js @@ -1,16 +1,16 @@ -var path = require('path'); -var Immutable = require('immutable'); +const path = require('path'); +const Immutable = require('immutable'); -var Output = require('../models/output'); -var Promise = require('../utils/promise'); -var fs = require('../utils/fs'); +const Output = require('../models/output'); +const Promise = require('../utils/promise'); +const fs = require('../utils/fs'); -var callHook = require('./callHook'); -var preparePlugins = require('./preparePlugins'); -var preparePages = require('./preparePages'); -var prepareAssets = require('./prepareAssets'); -var generateAssets = require('./generateAssets'); -var generatePages = require('./generatePages'); +const callHook = require('./callHook'); +const preparePlugins = require('./preparePlugins'); +const preparePages = require('./preparePages'); +const prepareAssets = require('./prepareAssets'); +const generateAssets = require('./generateAssets'); +const generatePages = require('./generatePages'); /** * Process an output to generate the book @@ -29,15 +29,15 @@ function processOutput(generator, startOutput) { callHook.bind(null, 'config', function(output) { - var book = output.getBook(); - var config = book.getConfig(); - var values = config.getValues(); + const book = output.getBook(); + const config = book.getConfig(); + const values = config.getValues(); return values.toJS(); }, function(output, result) { - var book = output.getBook(); - var config = book.getConfig(); + let book = output.getBook(); + let config = book.getConfig(); config = config.updateValues(result); book = book.set('config', config); @@ -70,28 +70,28 @@ function processOutput(generator, startOutput) { .then(generatePages.bind(null, generator)) .tap(function(output) { - var book = output.getBook(); + const book = output.getBook(); if (!book.isMultilingual()) { return; } - var logger = book.getLogger(); - var books = book.getBooks(); - var outputRoot = output.getRoot(); - var plugins = output.getPlugins(); - var state = output.getState(); - var options = output.getOptions(); + const logger = book.getLogger(); + const books = book.getBooks(); + const outputRoot = output.getRoot(); + const plugins = output.getPlugins(); + const state = output.getState(); + const options = output.getOptions(); return Promise.forEach(books, function(langBook) { // Inherits plugins list, options and state - var langOptions = options.set('root', path.join(outputRoot, langBook.getLanguage())); - var langOutput = new Output({ + const langOptions = options.set('root', path.join(outputRoot, langBook.getLanguage())); + const langOutput = new Output({ book: langBook, options: langOptions, - state: state, + state, generator: generator.name, - plugins: plugins + plugins }); logger.info.ln(''); @@ -154,22 +154,22 @@ function processOutput(generator, startOutput) { */ function generateBook(generator, book, options) { options = generator.Options(options); - var state = generator.State? generator.State({}) : Immutable.Map(); - var start = Date.now(); + const state = generator.State ? generator.State({}) : Immutable.Map(); + const start = Date.now(); return Promise( new Output({ - book: book, - options: options, - state: state, + book, + options, + state, generator: generator.name }) ) // Cleanup output folder .then(function(output) { - var logger = output.getLogger(); - var rootFolder = output.getRoot(); + const logger = output.getLogger(); + const rootFolder = output.getRoot(); logger.debug.ln('cleanup folder "' + rootFolder + '"'); return fs.ensureFolder(rootFolder) @@ -180,9 +180,9 @@ function generateBook(generator, book, options) { // Log duration and end message .then(function(output) { - var logger = output.getLogger(); - var end = Date.now(); - var duration = (end - start)/1000; + const logger = output.getLogger(); + const end = Date.now(); + const duration = (end - start) / 1000; logger.info.ok('generation finished with success in ' + duration.toFixed(1) + 's !'); diff --git a/packages/gitbook/lib/output/generatePage.js b/packages/gitbook/src/output/generatePage.js index 090a870..0fc99a3 100644 --- a/packages/gitbook/lib/output/generatePage.js +++ b/packages/gitbook/src/output/generatePage.js @@ -1,13 +1,13 @@ -var path = require('path'); +const path = require('path'); -var Promise = require('../utils/promise'); -var error = require('../utils/error'); -var timing = require('../utils/timing'); +const Promise = require('../utils/promise'); +const error = require('../utils/error'); +const timing = require('../utils/timing'); -var Templating = require('../templating'); -var JSONUtils = require('../json'); -var createTemplateEngine = require('./createTemplateEngine'); -var callPageHook = require('./callPageHook'); +const Templating = require('../templating'); +const JSONUtils = require('../json'); +const createTemplateEngine = require('./createTemplateEngine'); +const callPageHook = require('./callPageHook'); /** * Prepare and generate HTML for a page @@ -17,17 +17,17 @@ var callPageHook = require('./callPageHook'); * @return {Promise<Page>} */ function generatePage(output, page) { - var book = output.getBook(); - var engine = createTemplateEngine(output); + const book = output.getBook(); + const engine = createTemplateEngine(output); return timing.measure( 'page.generate', Promise(page) .then(function(resultPage) { - var file = resultPage.getFile(); - var filePath = file.getPath(); - var parser = file.getParser(); - var context = JSONUtils.encodeOutputWithPage(output, resultPage); + const file = resultPage.getFile(); + const filePath = file.getPath(); + const parser = file.getParser(); + const context = JSONUtils.encodeOutputWithPage(output, resultPage); if (!parser) { return Promise.reject(error.FileNotParsableError({ @@ -45,12 +45,12 @@ function generatePage(output, page) { // Render templating syntax .then(function(content) { - var absoluteFilePath = path.join(book.getContentRoot(), filePath); + const absoluteFilePath = path.join(book.getContentRoot(), filePath); return Templating.render(engine, absoluteFilePath, content, context); }) .then(function(output) { - var content = output.getContent(); + const content = output.getContent(); return parser.parsePage(content) .then(function(result) { diff --git a/packages/gitbook/lib/output/generatePages.js b/packages/gitbook/src/output/generatePages.js index 73c5c09..21b6610 100644 --- a/packages/gitbook/lib/output/generatePages.js +++ b/packages/gitbook/src/output/generatePages.js @@ -1,5 +1,5 @@ -var Promise = require('../utils/promise'); -var generatePage = require('./generatePage'); +const Promise = require('../utils/promise'); +const generatePage = require('./generatePage'); /** Output all pages using a generator @@ -9,8 +9,8 @@ var generatePage = require('./generatePage'); @return {Promise<Output>} */ function generatePages(generator, output) { - var pages = output.getPages(); - var logger = output.getLogger(); + const pages = output.getPages(); + const logger = output.getLogger(); // Is generator ignoring assets? if (!generator.onPage) { @@ -18,7 +18,7 @@ function generatePages(generator, output) { } return Promise.reduce(pages, function(out, page) { - var file = page.getFile(); + const file = page.getFile(); logger.debug.ln('generate page "' + file.getPath() + '"'); diff --git a/packages/gitbook/lib/output/getModifiers.js b/packages/gitbook/src/output/getModifiers.js index bb44e80..df32fcb 100644 --- a/packages/gitbook/lib/output/getModifiers.js +++ b/packages/gitbook/src/output/getModifiers.js @@ -1,12 +1,12 @@ -var Modifiers = require('./modifiers'); -var resolveFileToURL = require('./helper/resolveFileToURL'); -var Api = require('../api'); -var Plugins = require('../plugins'); -var Promise = require('../utils/promise'); -var defaultBlocks = require('../constants/defaultBlocks'); -var fileToOutput = require('./helper/fileToOutput'); +const Modifiers = require('./modifiers'); +const resolveFileToURL = require('./helper/resolveFileToURL'); +const Api = require('../api'); +const Plugins = require('../plugins'); +const Promise = require('../utils/promise'); +const defaultBlocks = require('../constants/defaultBlocks'); +const fileToOutput = require('./helper/fileToOutput'); -var CODEBLOCK = 'code'; +const CODEBLOCK = 'code'; /** * Return default modifier to prepare a page for @@ -15,25 +15,25 @@ var CODEBLOCK = 'code'; * @return {Array<Modifier>} */ function getModifiers(output, page) { - var book = output.getBook(); - var plugins = output.getPlugins(); - var glossary = book.getGlossary(); - var file = page.getFile(); + const book = output.getBook(); + const plugins = output.getPlugins(); + const glossary = book.getGlossary(); + const file = page.getFile(); // Glossary entries - var entries = glossary.getEntries(); - var glossaryFile = glossary.getFile(); - var glossaryFilename = fileToOutput(output, glossaryFile.getPath()); + const entries = glossary.getEntries(); + const glossaryFile = glossary.getFile(); + const glossaryFilename = fileToOutput(output, glossaryFile.getPath()); // Current file path - var currentFilePath = file.getPath(); + const currentFilePath = file.getPath(); // Get TemplateBlock for highlighting - var blocks = Plugins.listBlocks(plugins); - var code = blocks.get(CODEBLOCK) || defaultBlocks.get(CODEBLOCK); + const blocks = Plugins.listBlocks(plugins); + const code = blocks.get(CODEBLOCK) || defaultBlocks.get(CODEBLOCK); // Current context - var context = Api.encodeGlobal(output); + const context = Api.encodeGlobal(output); return [ // Normalize IDs on headings diff --git a/packages/gitbook/lib/output/helper/fileToOutput.js b/packages/gitbook/src/output/helper/fileToOutput.js index 361c6eb..a514854 100644 --- a/packages/gitbook/lib/output/helper/fileToOutput.js +++ b/packages/gitbook/src/output/helper/fileToOutput.js @@ -1,9 +1,9 @@ -var path = require('path'); +const path = require('path'); -var PathUtils = require('../../utils/path'); -var LocationUtils = require('../../utils/location'); +const PathUtils = require('../../utils/path'); +const LocationUtils = require('../../utils/location'); -var OUTPUT_EXTENSION = '.html'; +const OUTPUT_EXTENSION = '.html'; /** * Convert a filePath (absolute) to a filename for output @@ -13,9 +13,9 @@ var OUTPUT_EXTENSION = '.html'; * @return {String} */ function fileToOutput(output, filePath) { - var book = output.getBook(); - var readme = book.getReadme(); - var fileReadme = readme.getFile(); + const book = output.getBook(); + const readme = book.getReadme(); + const fileReadme = readme.getFile(); if ( path.basename(filePath, path.extname(filePath)) == 'README' || diff --git a/packages/gitbook/lib/output/helper/fileToURL.js b/packages/gitbook/src/output/helper/fileToURL.js index 44ad2d8..a42bca6 100644 --- a/packages/gitbook/lib/output/helper/fileToURL.js +++ b/packages/gitbook/src/output/helper/fileToURL.js @@ -1,7 +1,7 @@ -var path = require('path'); -var LocationUtils = require('../../utils/location'); +const path = require('path'); +const LocationUtils = require('../../utils/location'); -var fileToOutput = require('./fileToOutput'); +const fileToOutput = require('./fileToOutput'); /** Convert a filePath (absolute) to an url (without hostname). @@ -16,8 +16,8 @@ var fileToOutput = require('./fileToOutput'); @return {String} */ function fileToURL(output, filePath) { - var options = output.getOptions(); - var directoryIndex = options.get('directoryIndex'); + const options = output.getOptions(); + const directoryIndex = options.get('directoryIndex'); filePath = fileToOutput(output, filePath); diff --git a/packages/gitbook/lib/output/helper/index.js b/packages/gitbook/src/output/helper/index.js index f8bc109..f8bc109 100644 --- a/packages/gitbook/lib/output/helper/index.js +++ b/packages/gitbook/src/output/helper/index.js diff --git a/packages/gitbook/lib/output/helper/resolveFileToURL.js b/packages/gitbook/src/output/helper/resolveFileToURL.js index 3f52713..907cfdd 100644 --- a/packages/gitbook/lib/output/helper/resolveFileToURL.js +++ b/packages/gitbook/src/output/helper/resolveFileToURL.js @@ -1,6 +1,6 @@ -var LocationUtils = require('../../utils/location'); +const LocationUtils = require('../../utils/location'); -var fileToURL = require('./fileToURL'); +const fileToURL = require('./fileToURL'); /** * Resolve an absolute path (extracted from a link) @@ -13,7 +13,7 @@ function resolveFileToURL(output, filePath) { // Convert /test.png -> test.png filePath = LocationUtils.toAbsolute(filePath, '', ''); - var page = output.getPage(filePath); + const page = output.getPage(filePath); // if file is a page, return correct .html url if (page) { diff --git a/packages/gitbook/lib/output/helper/writeFile.js b/packages/gitbook/src/output/helper/writeFile.js index a6d4645..01a8e68 100644 --- a/packages/gitbook/lib/output/helper/writeFile.js +++ b/packages/gitbook/src/output/helper/writeFile.js @@ -1,5 +1,5 @@ -var path = require('path'); -var fs = require('../../utils/fs'); +const path = require('path'); +const fs = require('../../utils/fs'); /** Write a file to the output folder @@ -10,7 +10,7 @@ var fs = require('../../utils/fs'); @return {Promise} */ function writeFile(output, filePath, content) { - var rootFolder = output.getRoot(); + const rootFolder = output.getRoot(); filePath = path.join(rootFolder, filePath); return fs.ensureFile(filePath) diff --git a/packages/gitbook/lib/output/index.js b/packages/gitbook/src/output/index.js index 9b8ec17..574b3df 100644 --- a/packages/gitbook/lib/output/index.js +++ b/packages/gitbook/src/output/index.js @@ -1,6 +1,6 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var generators = Immutable.List([ +const generators = Immutable.List([ require('./json'), require('./website'), require('./ebook') @@ -20,5 +20,5 @@ function getGenerator(name) { module.exports = { generate: require('./generateBook'), - getGenerator: getGenerator + getGenerator }; diff --git a/packages/gitbook/lib/output/json/index.js b/packages/gitbook/src/output/json/index.js index 361da06..361da06 100644 --- a/packages/gitbook/lib/output/json/index.js +++ b/packages/gitbook/src/output/json/index.js diff --git a/packages/gitbook/lib/output/json/onFinish.js b/packages/gitbook/src/output/json/onFinish.js index d41d778..b05057a 100644 --- a/packages/gitbook/lib/output/json/onFinish.js +++ b/packages/gitbook/src/output/json/onFinish.js @@ -1,8 +1,8 @@ -var path = require('path'); +const path = require('path'); -var Promise = require('../../utils/promise'); -var fs = require('../../utils/fs'); -var JSONUtils = require('../../json'); +const Promise = require('../../utils/promise'); +const fs = require('../../utils/fs'); +const JSONUtils = require('../../json'); /** Finish the generation @@ -11,23 +11,23 @@ var JSONUtils = require('../../json'); @return {Output} */ function onFinish(output) { - var book = output.getBook(); - var outputRoot = output.getRoot(); + const book = output.getBook(); + const outputRoot = output.getRoot(); if (!book.isMultilingual()) { return Promise(output); } // Get main language - var languages = book.getLanguages(); - var mainLanguage = languages.getDefaultLanguage(); + const languages = book.getLanguages(); + const mainLanguage = languages.getDefaultLanguage(); // Read the main JSON return fs.readFile(path.resolve(outputRoot, mainLanguage.getID(), 'README.json'), 'utf8') // Extend the JSON .then(function(content) { - var json = JSON.parse(content); + const json = JSON.parse(content); json.languages = JSONUtils.encodeLanguages(languages); diff --git a/packages/gitbook/lib/output/json/onPage.js b/packages/gitbook/src/output/json/onPage.js index 2315ba0..8bee711 100644 --- a/packages/gitbook/lib/output/json/onPage.js +++ b/packages/gitbook/src/output/json/onPage.js @@ -1,10 +1,10 @@ -var JSONUtils = require('../../json'); -var PathUtils = require('../../utils/path'); -var Modifiers = require('../modifiers'); -var writeFile = require('../helper/writeFile'); -var getModifiers = require('../getModifiers'); +const JSONUtils = require('../../json'); +const PathUtils = require('../../utils/path'); +const Modifiers = require('../modifiers'); +const writeFile = require('../helper/writeFile'); +const getModifiers = require('../getModifiers'); -var JSON_VERSION = '3'; +const JSON_VERSION = '3'; /** * Write a page as a json file @@ -13,13 +13,13 @@ var JSON_VERSION = '3'; * @param {Page} page */ function onPage(output, page) { - var file = page.getFile(); - var readme = output.getBook().getReadme().getFile(); + const file = page.getFile(); + const readme = output.getBook().getReadme().getFile(); return Modifiers.modifyHTML(page, getModifiers(output, page)) .then(function(resultPage) { // Generate the JSON - var json = JSONUtils.encodeBookWithPage(output.getBook(), resultPage); + const json = JSONUtils.encodeBookWithPage(output.getBook(), resultPage); // Delete some private properties delete json.config; @@ -28,7 +28,7 @@ function onPage(output, page) { json.version = JSON_VERSION; // File path in the output folder - var filePath = file.getPath() == readme.getPath()? 'README.json' : file.getPath(); + let filePath = file.getPath() == readme.getPath() ? 'README.json' : file.getPath(); filePath = PathUtils.setExtension(filePath, '.json'); // Write it to the disk diff --git a/packages/gitbook/lib/output/json/options.js b/packages/gitbook/src/output/json/options.js index 79167b1..2a9de0e 100644 --- a/packages/gitbook/lib/output/json/options.js +++ b/packages/gitbook/src/output/json/options.js @@ -1,6 +1,6 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var Options = Immutable.Record({ +const Options = Immutable.Record({ // Root folder for the output root: String() }); diff --git a/packages/gitbook/lib/output/modifiers/__tests__/addHeadingId.js b/packages/gitbook/src/output/modifiers/__tests__/addHeadingId.js index a3b1d81..4d77e75 100644 --- a/packages/gitbook/lib/output/modifiers/__tests__/addHeadingId.js +++ b/packages/gitbook/src/output/modifiers/__tests__/addHeadingId.js @@ -1,26 +1,25 @@ -var cheerio = require('cheerio'); -var addHeadingId = require('../addHeadingId'); +const cheerio = require('cheerio'); +const addHeadingId = require('../addHeadingId'); describe('addHeadingId', function() { it('should add an ID if none', function() { - var $ = cheerio.load('<h1>Hello World</h1><h2>Cool !!</h2>'); + const $ = cheerio.load('<h1>Hello World</h1><h2>Cool !!</h2>'); return addHeadingId($) .then(function() { - var html = $.html(); + const html = $.html(); expect(html).toBe('<h1 id="hello-world">Hello World</h1><h2 id="cool-">Cool !!</h2>'); }); }); it('should not change existing IDs', function() { - var $ = cheerio.load('<h1 id="awesome">Hello World</h1>'); + const $ = cheerio.load('<h1 id="awesome">Hello World</h1>'); return addHeadingId($) .then(function() { - var html = $.html(); + const html = $.html(); expect(html).toBe('<h1 id="awesome">Hello World</h1>'); }); }); }); - diff --git a/packages/gitbook/lib/output/modifiers/__tests__/annotateText.js b/packages/gitbook/src/output/modifiers/__tests__/annotateText.js index 67e7a10..28a5cc5 100644 --- a/packages/gitbook/lib/output/modifiers/__tests__/annotateText.js +++ b/packages/gitbook/src/output/modifiers/__tests__/annotateText.js @@ -1,46 +1,45 @@ -var Immutable = require('immutable'); -var cheerio = require('cheerio'); -var GlossaryEntry = require('../../../models/glossaryEntry'); -var annotateText = require('../annotateText'); +const Immutable = require('immutable'); +const cheerio = require('cheerio'); +const GlossaryEntry = require('../../../models/glossaryEntry'); +const annotateText = require('../annotateText'); describe('annotateText', function() { - var entries = Immutable.List([ + const entries = Immutable.List([ GlossaryEntry({ name: 'Word' }), GlossaryEntry({ name: 'Multiple Words' }) ]); it('should annotate text', function() { - var $ = cheerio.load('<p>This is a word, and multiple words</p>'); + const $ = cheerio.load('<p>This is a word, and multiple words</p>'); annotateText(entries, 'GLOSSARY.md', $); - var links = $('a'); + const links = $('a'); expect(links.length).toBe(2); - var word = $(links.get(0)); + const word = $(links.get(0)); expect(word.attr('href')).toBe('/GLOSSARY.md#word'); expect(word.text()).toBe('word'); expect(word.hasClass('glossary-term')).toBeTruthy(); - var words = $(links.get(1)); + const words = $(links.get(1)); expect(words.attr('href')).toBe('/GLOSSARY.md#multiple-words'); expect(words.text()).toBe('multiple words'); expect(words.hasClass('glossary-term')).toBeTruthy(); }); it('should not annotate scripts', function() { - var $ = cheerio.load('<script>This is a word, and multiple words</script>'); + const $ = cheerio.load('<script>This is a word, and multiple words</script>'); annotateText(entries, 'GLOSSARY.md', $); expect($('a').length).toBe(0); }); it('should not annotate when has class "no-glossary"', function() { - var $ = cheerio.load('<p class="no-glossary">This is a word, and multiple words</p>'); + const $ = cheerio.load('<p class="no-glossary">This is a word, and multiple words</p>'); annotateText(entries, 'GLOSSARY.md', $); expect($('a').length).toBe(0); }); }); - diff --git a/packages/gitbook/src/output/modifiers/__tests__/fetchRemoteImages.js b/packages/gitbook/src/output/modifiers/__tests__/fetchRemoteImages.js new file mode 100644 index 0000000..9145cae --- /dev/null +++ b/packages/gitbook/src/output/modifiers/__tests__/fetchRemoteImages.js @@ -0,0 +1,39 @@ +const cheerio = require('cheerio'); +const tmp = require('tmp'); +const path = require('path'); + +const URL = 'https://upload.wikimedia.org/wikipedia/commons/thumb/4/47/PNG_transparency_demonstration_1.png/280px-PNG_transparency_demonstration_1.png'; + +describe('fetchRemoteImages', function() { + let dir; + const fetchRemoteImages = require('../fetchRemoteImages'); + + beforeEach(function() { + dir = tmp.dirSync(); + }); + + it('should download image file', function() { + const $ = cheerio.load('<img src="' + URL + '" />'); + + return fetchRemoteImages(dir.name, 'index.html', $) + .then(function() { + const $img = $('img'); + const src = $img.attr('src'); + + expect(dir.name).toHaveFile(src); + }); + }); + + it('should download image file and replace with relative path', function() { + const $ = cheerio.load('<img src="' + URL + '" />'); + + return fetchRemoteImages(dir.name, 'test/index.html', $) + .then(function() { + const $img = $('img'); + const src = $img.attr('src'); + + expect(dir.name).toHaveFile(path.join('test', src)); + }); + }); +}); + diff --git a/packages/gitbook/lib/output/modifiers/__tests__/highlightCode.js b/packages/gitbook/src/output/modifiers/__tests__/highlightCode.js index 75d9902..d93417b 100644 --- a/packages/gitbook/lib/output/modifiers/__tests__/highlightCode.js +++ b/packages/gitbook/src/output/modifiers/__tests__/highlightCode.js @@ -1,6 +1,6 @@ -var cheerio = require('cheerio'); -var Promise = require('../../../utils/promise'); -var highlightCode = require('../highlightCode'); +const cheerio = require('cheerio'); +const Promise = require('../../../utils/promise'); +const highlightCode = require('../highlightCode'); describe('highlightCode', function() { function doHighlight(lang, code) { @@ -17,44 +17,43 @@ describe('highlightCode', function() { } it('should call it for normal code element', function() { - var $ = cheerio.load('<p>This is a <code>test</code></p>'); + const $ = cheerio.load('<p>This is a <code>test</code></p>'); return highlightCode(doHighlight, $) .then(function() { - var $code = $('code'); + const $code = $('code'); expect($code.text()).toBe('$test'); }); }); it('should call it for markdown code block', function() { - var $ = cheerio.load('<pre><code class="lang-js">test</code></pre>'); + const $ = cheerio.load('<pre><code class="lang-js">test</code></pre>'); return highlightCode(doHighlight, $) .then(function() { - var $code = $('code'); + const $code = $('code'); expect($code.text()).toBe('js$test'); }); }); it('should call it for asciidoc code block', function() { - var $ = cheerio.load('<pre><code class="language-python">test</code></pre>'); + const $ = cheerio.load('<pre><code class="language-python">test</code></pre>'); return highlightCode(doHighlight, $) .then(function() { - var $code = $('code'); + const $code = $('code'); expect($code.text()).toBe('python$test'); }); }); it('should accept async highlighter', function() { - var $ = cheerio.load('<pre><code class="language-python">test</code></pre>'); + const $ = cheerio.load('<pre><code class="language-python">test</code></pre>'); return highlightCode(doHighlightAsync, $) .then(function() { - var $code = $('code'); + const $code = $('code'); expect($code.text()).toBe('python$test'); }); }); }); - diff --git a/packages/gitbook/src/output/modifiers/__tests__/inlinePng.js b/packages/gitbook/src/output/modifiers/__tests__/inlinePng.js new file mode 100644 index 0000000..fd031b0 --- /dev/null +++ b/packages/gitbook/src/output/modifiers/__tests__/inlinePng.js @@ -0,0 +1,24 @@ +const cheerio = require('cheerio'); +const tmp = require('tmp'); +const inlinePng = require('../inlinePng'); + +describe('inlinePng', function() { + let dir; + + beforeEach(function() { + dir = tmp.dirSync(); + }); + + it('should write an inline PNG using data URI as a file', function() { + const $ = cheerio.load('<img alt="GitBook Logo 20x20" src=""/>'); + + return inlinePng(dir.name, 'index.html', $) + .then(function() { + const $img = $('img'); + const src = $img.attr('src'); + + expect(dir.name).toHaveFile(src); + }); + }); +}); + diff --git a/packages/gitbook/lib/output/modifiers/__tests__/resolveLinks.js b/packages/gitbook/src/output/modifiers/__tests__/resolveLinks.js index 8904c11..167af5d 100644 --- a/packages/gitbook/lib/output/modifiers/__tests__/resolveLinks.js +++ b/packages/gitbook/src/output/modifiers/__tests__/resolveLinks.js @@ -1,6 +1,6 @@ -var path = require('path'); -var cheerio = require('cheerio'); -var resolveLinks = require('../resolveLinks'); +const path = require('path'); +const cheerio = require('cheerio'); +const resolveLinks = require('../resolveLinks'); describe('resolveLinks', function() { function resolveFileBasic(href) { @@ -16,24 +16,24 @@ describe('resolveLinks', function() { } describe('Absolute path', function() { - var TEST = '<p>This is a <a href="/test/cool.md"></a></p>'; + const TEST = '<p>This is a <a href="/test/cool.md"></a></p>'; it('should resolve path starting by "/" in root directory', function() { - var $ = cheerio.load(TEST); + const $ = cheerio.load(TEST); return resolveLinks('hello.md', resolveFileBasic, $) .then(function() { - var link = $('a'); + const link = $('a'); expect(link.attr('href')).toBe('fakeDir/test/cool.md'); }); }); it('should resolve path starting by "/" in child directory', function() { - var $ = cheerio.load(TEST); + const $ = cheerio.load(TEST); return resolveLinks('afolder/hello.md', resolveFileBasic, $) .then(function() { - var link = $('a'); + const link = $('a'); expect(link.attr('href')).toBe('../fakeDir/test/cool.md'); }); }); @@ -41,61 +41,61 @@ describe('resolveLinks', function() { describe('Anchor', function() { it('should prevent anchors in resolution', function() { - var TEST = '<p>This is a <a href="test/cool.md#an-anchor"></a></p>'; - var $ = cheerio.load(TEST); + const TEST = '<p>This is a <a href="test/cool.md#an-anchor"></a></p>'; + const $ = cheerio.load(TEST); return resolveLinks('hello.md', resolveFileCustom, $) .then(function() { - var link = $('a'); + const link = $('a'); expect(link.attr('href')).toBe('test/cool.html#an-anchor'); }); }); it('should ignore pure anchor links', function() { - var TEST = '<p>This is a <a href="#an-anchor"></a></p>'; - var $ = cheerio.load(TEST); + const TEST = '<p>This is a <a href="#an-anchor"></a></p>'; + const $ = cheerio.load(TEST); return resolveLinks('hello.md', resolveFileCustom, $) .then(function() { - var link = $('a'); + const link = $('a'); expect(link.attr('href')).toBe('#an-anchor'); }); }); }); describe('Custom Resolver', function() { - var TEST = '<p>This is a <a href="/test/cool.md"></a> <a href="afile.png"></a></p>'; + const TEST = '<p>This is a <a href="/test/cool.md"></a> <a href="afile.png"></a></p>'; it('should resolve path correctly for absolute path', function() { - var $ = cheerio.load(TEST); + const $ = cheerio.load(TEST); return resolveLinks('hello.md', resolveFileCustom, $) .then(function() { - var link = $('a').first(); + const link = $('a').first(); expect(link.attr('href')).toBe('test/cool.html'); }); }); it('should resolve path correctly for absolute path (2)', function() { - var $ = cheerio.load(TEST); + const $ = cheerio.load(TEST); return resolveLinks('afodler/hello.md', resolveFileCustom, $) .then(function() { - var link = $('a').first(); + const link = $('a').first(); expect(link.attr('href')).toBe('../test/cool.html'); }); }); }); describe('External link', function() { - var TEST = '<p>This is a <a href="http://www.github.com">external link</a></p>'; + const TEST = '<p>This is a <a href="http://www.github.com">external link</a></p>'; it('should have target="_blank" attribute', function() { - var $ = cheerio.load(TEST); + const $ = cheerio.load(TEST); return resolveLinks('hello.md', resolveFileBasic, $) .then(function() { - var link = $('a'); + const link = $('a'); expect(link.attr('target')).toBe('_blank'); }); }); diff --git a/packages/gitbook/src/output/modifiers/__tests__/svgToImg.js b/packages/gitbook/src/output/modifiers/__tests__/svgToImg.js new file mode 100644 index 0000000..4bdab59 --- /dev/null +++ b/packages/gitbook/src/output/modifiers/__tests__/svgToImg.js @@ -0,0 +1,24 @@ +const cheerio = require('cheerio'); +const tmp = require('tmp'); + +describe('svgToImg', function() { + let dir; + const svgToImg = require('../svgToImg'); + + beforeEach(function() { + dir = tmp.dirSync(); + }); + + it('should write svg as a file', function() { + const $ = cheerio.load('<svg xmlns="http://www.w3.org/2000/svg" width="200" height="100" version="1.1"><rect width="200" height="100" stroke="black" stroke-width="6" fill="green"/></svg>'); + + return svgToImg(dir.name, 'index.html', $) + .then(function() { + const $img = $('img'); + const src = $img.attr('src'); + + expect(dir.name).toHaveFile(src); + }); + }); +}); + diff --git a/packages/gitbook/src/output/modifiers/__tests__/svgToPng.js b/packages/gitbook/src/output/modifiers/__tests__/svgToPng.js new file mode 100644 index 0000000..0a12938 --- /dev/null +++ b/packages/gitbook/src/output/modifiers/__tests__/svgToPng.js @@ -0,0 +1,32 @@ +const cheerio = require('cheerio'); +const tmp = require('tmp'); +const path = require('path'); + +const svgToImg = require('../svgToImg'); +const svgToPng = require('../svgToPng'); + +describe('svgToPng', function() { + let dir; + + beforeEach(function() { + dir = tmp.dirSync(); + }); + + it('should write svg as png file', function() { + const $ = cheerio.load('<svg xmlns="http://www.w3.org/2000/svg" width="200" height="100" version="1.1"><rect width="200" height="100" stroke="black" stroke-width="6" fill="green"/></svg>'); + const fileName = 'index.html'; + + return svgToImg(dir.name, fileName, $) + .then(function() { + return svgToPng(dir.name, fileName, $); + }) + .then(function() { + const $img = $('img'); + const src = $img.attr('src'); + + expect(dir.name).toHaveFile(src); + expect(path.extname(src)).toBe('.png'); + }); + }); +}); + diff --git a/packages/gitbook/lib/output/modifiers/addHeadingId.js b/packages/gitbook/src/output/modifiers/addHeadingId.js index e2e2720..e5bab3e 100644 --- a/packages/gitbook/lib/output/modifiers/addHeadingId.js +++ b/packages/gitbook/src/output/modifiers/addHeadingId.js @@ -1,5 +1,5 @@ -var slug = require('github-slugid'); -var editHTMLElement = require('./editHTMLElement'); +const slug = require('github-slugid'); +const editHTMLElement = require('./editHTMLElement'); /** Add ID to an heading diff --git a/packages/gitbook/lib/output/modifiers/annotateText.js b/packages/gitbook/src/output/modifiers/annotateText.js index 490c228..36ee4e9 100644 --- a/packages/gitbook/lib/output/modifiers/annotateText.js +++ b/packages/gitbook/src/output/modifiers/annotateText.js @@ -1,46 +1,43 @@ -var escape = require('escape-html'); +const escape = require('escape-html'); // Selector to ignore -var ANNOTATION_IGNORE = '.no-glossary,code,pre,a,script,h1,h2,h3,h4,h5,h6'; +const ANNOTATION_IGNORE = '.no-glossary,code,pre,a,script,h1,h2,h3,h4,h5,h6'; -function pregQuote( str ) { - return (str+'').replace(/([\\\.\+\*\?\[\^\]\$\(\)\{\}\=\!\<\>\|\:])/g, '\\$1'); +function pregQuote(str) { + return (str + '').replace(/([\\\.\+\*\?\[\^\]\$\(\)\{\}\=\!\<\>\|\:])/g, '\\$1'); } -function replaceText($, el, search, replace, text_only ) { - return $(el).each(function(){ - var node = this.firstChild, - val, - new_val, - - // Elements to be removed at the end. - remove = []; +function replaceText($, el, search, replace, text_only) { + return $(el).each(function() { + let node = this.firstChild, val, new_val; + // Elements to be removed at the end. + const remove = []; // Only continue if firstChild exists. - if ( node ) { + if (node) { // Loop over all childNodes. while (node) { // Only process text nodes. - if ( node.nodeType === 3 ) { + if (node.nodeType === 3) { // The original node value. val = node.nodeValue; // The new value. - new_val = val.replace( search, replace ); + new_val = val.replace(search, replace); // Only replace text if the new value is actually different! - if ( new_val !== val ) { + if (new_val !== val) { - if ( !text_only && /</.test( new_val ) ) { + if (!text_only && /</.test(new_val)) { // The new value contains HTML, set it in a slower but far more // robust way. - $(node).before( new_val ); + $(node).before(new_val); // Don't remove the node yet, or the loop will lose its place. - remove.push( node ); + remove.push(node); } else { // The new value contains no HTML, so it can be set in this // very fast, simple way. @@ -67,13 +64,13 @@ function replaceText($, el, search, replace, text_only ) { */ function annotateText(entries, glossaryFilePath, $) { entries.forEach(function(entry) { - var entryId = entry.getID(); - var name = entry.getName(); - var description = entry.getDescription(); - var searchRegex = new RegExp( '\\b(' + pregQuote(name.toLowerCase()) + ')\\b' , 'gi' ); + const entryId = entry.getID(); + const name = entry.getName(); + const description = entry.getDescription(); + const searchRegex = new RegExp('\\b(' + pregQuote(name.toLowerCase()) + ')\\b' , 'gi'); $('*').each(function() { - var $this = $(this); + const $this = $(this); if ( $this.is(ANNOTATION_IGNORE) || diff --git a/packages/gitbook/lib/output/modifiers/editHTMLElement.js b/packages/gitbook/src/output/modifiers/editHTMLElement.js index 755598e..d0d2b19 100644 --- a/packages/gitbook/lib/output/modifiers/editHTMLElement.js +++ b/packages/gitbook/src/output/modifiers/editHTMLElement.js @@ -1,13 +1,13 @@ -var Promise = require('../../utils/promise'); +const Promise = require('../../utils/promise'); /** Edit all elements matching a selector */ function editHTMLElement($, selector, fn) { - var $elements = $(selector); + const $elements = $(selector); return Promise.forEach($elements, function(el) { - var $el = $(el); + const $el = $(el); return fn($el); }); } diff --git a/packages/gitbook/lib/output/modifiers/fetchRemoteImages.js b/packages/gitbook/src/output/modifiers/fetchRemoteImages.js index ef868b9..1732247 100644 --- a/packages/gitbook/lib/output/modifiers/fetchRemoteImages.js +++ b/packages/gitbook/src/output/modifiers/fetchRemoteImages.js @@ -1,9 +1,9 @@ -var path = require('path'); -var crc = require('crc'); +const path = require('path'); +const crc = require('crc'); -var editHTMLElement = require('./editHTMLElement'); -var fs = require('../../utils/fs'); -var LocationUtils = require('../../utils/location'); +const editHTMLElement = require('./editHTMLElement'); +const fs = require('../../utils/fs'); +const LocationUtils = require('../../utils/location'); /** Fetch all remote images @@ -14,20 +14,20 @@ var LocationUtils = require('../../utils/location'); @return {Promise} */ function fetchRemoteImages(rootFolder, currentFile, $) { - var currentDirectory = path.dirname(currentFile); + const currentDirectory = path.dirname(currentFile); return editHTMLElement($, 'img', function($img) { - var src = $img.attr('src'); - var extension = path.extname(src); + let src = $img.attr('src'); + const extension = path.extname(src); if (!LocationUtils.isExternal(src)) { return; } // We avoid generating twice the same PNG - var hash = crc.crc32(src).toString(16); - var fileName = hash + extension; - var filePath = path.join(rootFolder, fileName); + const hash = crc.crc32(src).toString(16); + const fileName = hash + extension; + const filePath = path.join(rootFolder, fileName); return fs.assertFile(filePath, function() { return fs.download(src, filePath); diff --git a/packages/gitbook/lib/output/modifiers/highlightCode.js b/packages/gitbook/src/output/modifiers/highlightCode.js index 5d397bb..622432d 100644 --- a/packages/gitbook/lib/output/modifiers/highlightCode.js +++ b/packages/gitbook/src/output/modifiers/highlightCode.js @@ -1,8 +1,8 @@ -var is = require('is'); -var Immutable = require('immutable'); +const is = require('is'); +const Immutable = require('immutable'); -var Promise = require('../../utils/promise'); -var editHTMLElement = require('./editHTMLElement'); +const Promise = require('../../utils/promise'); +const editHTMLElement = require('./editHTMLElement'); /** Return language for a code blocks from a list of class names @@ -40,9 +40,9 @@ function getLanguageForClass(classNames) { */ function highlightCode(highlight, $) { return editHTMLElement($, 'code', function($code) { - var classNames = ($code.attr('class') || '').split(' '); - var lang = getLanguageForClass(classNames); - var source = $code.text(); + const classNames = ($code.attr('class') || '').split(' '); + const lang = getLanguageForClass(classNames); + const source = $code.text(); return Promise(highlight(lang, source)) .then(function(r) { diff --git a/packages/gitbook/lib/output/modifiers/index.js b/packages/gitbook/src/output/modifiers/index.js index f1daa2b..f1daa2b 100644 --- a/packages/gitbook/lib/output/modifiers/index.js +++ b/packages/gitbook/src/output/modifiers/index.js diff --git a/packages/gitbook/lib/output/modifiers/inlineAssets.js b/packages/gitbook/src/output/modifiers/inlineAssets.js index 7cd874b..1ed4344 100644 --- a/packages/gitbook/lib/output/modifiers/inlineAssets.js +++ b/packages/gitbook/src/output/modifiers/inlineAssets.js @@ -1,10 +1,10 @@ -var svgToImg = require('./svgToImg'); -var svgToPng = require('./svgToPng'); -var inlinePng = require('./inlinePng'); -var resolveImages = require('./resolveImages'); -var fetchRemoteImages = require('./fetchRemoteImages'); +const svgToImg = require('./svgToImg'); +const svgToPng = require('./svgToPng'); +const inlinePng = require('./inlinePng'); +const resolveImages = require('./resolveImages'); +const fetchRemoteImages = require('./fetchRemoteImages'); -var Promise = require('../../utils/promise'); +const Promise = require('../../utils/promise'); /** Inline all assets in a page diff --git a/packages/gitbook/lib/output/modifiers/inlinePng.js b/packages/gitbook/src/output/modifiers/inlinePng.js index 161f164..218aaa2 100644 --- a/packages/gitbook/lib/output/modifiers/inlinePng.js +++ b/packages/gitbook/src/output/modifiers/inlinePng.js @@ -1,11 +1,11 @@ -var crc = require('crc'); -var path = require('path'); +const crc = require('crc'); +const path = require('path'); -var imagesUtil = require('../../utils/images'); -var fs = require('../../utils/fs'); -var LocationUtils = require('../../utils/location'); +const imagesUtil = require('../../utils/images'); +const fs = require('../../utils/fs'); +const LocationUtils = require('../../utils/location'); -var editHTMLElement = require('./editHTMLElement'); +const editHTMLElement = require('./editHTMLElement'); /** Convert all inline PNG images to PNG file @@ -15,20 +15,20 @@ var editHTMLElement = require('./editHTMLElement'); @return {Promise} */ function inlinePng(rootFolder, currentFile, $) { - var currentDirectory = path.dirname(currentFile); + const currentDirectory = path.dirname(currentFile); return editHTMLElement($, 'img', function($img) { - var src = $img.attr('src'); + const src = $img.attr('src'); if (!LocationUtils.isDataURI(src)) { return; } // We avoid generating twice the same PNG - var hash = crc.crc32(src).toString(16); - var fileName = hash + '.png'; + const hash = crc.crc32(src).toString(16); + let fileName = hash + '.png'; // Result file path - var filePath = path.join(rootFolder, fileName); + const filePath = path.join(rootFolder, fileName); return fs.assertFile(filePath, function() { return imagesUtil.convertInlinePNG(src, filePath); diff --git a/packages/gitbook/lib/output/modifiers/modifyHTML.js b/packages/gitbook/src/output/modifiers/modifyHTML.js index cd3d6e5..00177fc 100644 --- a/packages/gitbook/lib/output/modifiers/modifyHTML.js +++ b/packages/gitbook/src/output/modifiers/modifyHTML.js @@ -1,5 +1,5 @@ -var cheerio = require('cheerio'); -var Promise = require('../../utils/promise'); +const cheerio = require('cheerio'); +const Promise = require('../../utils/promise'); /** Apply a list of operations to a page and @@ -10,14 +10,14 @@ var Promise = require('../../utils/promise'); @return {Promise<Page>} */ function modifyHTML(page, operations) { - var html = page.getContent(); - var $ = cheerio.load(html); + const html = page.getContent(); + const $ = cheerio.load(html); return Promise.forEach(operations, function(op) { return op($); }) .then(function() { - var resultHTML = $.html(); + const resultHTML = $.html(); return page.set('content', resultHTML); }); } diff --git a/packages/gitbook/lib/output/modifiers/resolveImages.js b/packages/gitbook/src/output/modifiers/resolveImages.js index cc25cfa..339ddeb 100644 --- a/packages/gitbook/lib/output/modifiers/resolveImages.js +++ b/packages/gitbook/src/output/modifiers/resolveImages.js @@ -1,7 +1,7 @@ -var path = require('path'); +const path = require('path'); -var LocationUtils = require('../../utils/location'); -var editHTMLElement = require('./editHTMLElement'); +const LocationUtils = require('../../utils/location'); +const editHTMLElement = require('./editHTMLElement'); /** Resolve all HTML images: @@ -11,10 +11,10 @@ var editHTMLElement = require('./editHTMLElement'); @param {HTMLDom} $ */ function resolveImages(currentFile, $) { - var currentDirectory = path.dirname(currentFile); + const currentDirectory = path.dirname(currentFile); return editHTMLElement($, 'img', function($img) { - var src = $img.attr('src'); + let src = $img.attr('src'); if (LocationUtils.isExternal(src) || LocationUtils.isDataURI(src)) { return; diff --git a/packages/gitbook/lib/output/modifiers/resolveLinks.js b/packages/gitbook/src/output/modifiers/resolveLinks.js index 9d15e5e..8b15315 100644 --- a/packages/gitbook/lib/output/modifiers/resolveLinks.js +++ b/packages/gitbook/src/output/modifiers/resolveLinks.js @@ -1,8 +1,8 @@ -var path = require('path'); -var url = require('url'); +const path = require('path'); +const url = require('url'); -var LocationUtils = require('../../utils/location'); -var editHTMLElement = require('./editHTMLElement'); +const LocationUtils = require('../../utils/location'); +const editHTMLElement = require('./editHTMLElement'); /** Resolve all HTML links: @@ -13,10 +13,10 @@ var editHTMLElement = require('./editHTMLElement'); @param {HTMLDom} $ */ function resolveLinks(currentFile, resolveFile, $) { - var currentDirectory = path.dirname(currentFile); + const currentDirectory = path.dirname(currentFile); return editHTMLElement($, 'a', function($a) { - var href = $a.attr('href'); + let href = $a.attr('href'); // Don't change a tag without href if (!href) { @@ -29,7 +29,7 @@ function resolveLinks(currentFile, resolveFile, $) { } // Split anchor - var parsed = url.parse(href); + const parsed = url.parse(href); href = parsed.pathname || ''; if (href) { diff --git a/packages/gitbook/lib/output/modifiers/svgToImg.js b/packages/gitbook/src/output/modifiers/svgToImg.js index f31b06d..ac37d07 100644 --- a/packages/gitbook/lib/output/modifiers/svgToImg.js +++ b/packages/gitbook/src/output/modifiers/svgToImg.js @@ -1,10 +1,10 @@ -var path = require('path'); -var crc = require('crc'); -var domSerializer = require('dom-serializer'); +const path = require('path'); +const crc = require('crc'); +const domSerializer = require('dom-serializer'); -var editHTMLElement = require('./editHTMLElement'); -var fs = require('../../utils/fs'); -var LocationUtils = require('../../utils/location'); +const editHTMLElement = require('./editHTMLElement'); +const fs = require('../../utils/fs'); +const LocationUtils = require('../../utils/location'); /** Render a cheerio DOM as html @@ -18,7 +18,7 @@ function renderDOM($, dom, options) { if (!dom && $._root && $._root.children) { dom = $._root.children; } - options = options|| dom.options || $._options; + options = options || dom.options || $._options; return domSerializer(dom, options); } @@ -29,16 +29,16 @@ function renderDOM($, dom, options) { @param {HTMLDom} $ */ function svgToImg(baseFolder, currentFile, $) { - var currentDirectory = path.dirname(currentFile); + const currentDirectory = path.dirname(currentFile); return editHTMLElement($, 'svg', function($svg) { - var content = '<?xml version="1.0" encoding="UTF-8"?>' + + const content = '<?xml version="1.0" encoding="UTF-8"?>' + renderDOM($, $svg); // We avoid generating twice the same PNG - var hash = crc.crc32(content).toString(16); - var fileName = hash + '.svg'; - var filePath = path.join(baseFolder, fileName); + const hash = crc.crc32(content).toString(16); + const fileName = hash + '.svg'; + const filePath = path.join(baseFolder, fileName); // Write the svg to the file return fs.assertFile(filePath, function() { @@ -47,7 +47,7 @@ function svgToImg(baseFolder, currentFile, $) { // Return as image .then(function() { - var src = LocationUtils.relative(currentDirectory, fileName); + const src = LocationUtils.relative(currentDirectory, fileName); $svg.replaceWith('<img src="' + src + '" />'); }); }); diff --git a/packages/gitbook/lib/output/modifiers/svgToPng.js b/packages/gitbook/src/output/modifiers/svgToPng.js index 1093106..ad3f31f 100644 --- a/packages/gitbook/lib/output/modifiers/svgToPng.js +++ b/packages/gitbook/src/output/modifiers/svgToPng.js @@ -1,11 +1,11 @@ -var crc = require('crc'); -var path = require('path'); +const crc = require('crc'); +const path = require('path'); -var imagesUtil = require('../../utils/images'); -var fs = require('../../utils/fs'); -var LocationUtils = require('../../utils/location'); +const imagesUtil = require('../../utils/images'); +const fs = require('../../utils/fs'); +const LocationUtils = require('../../utils/location'); -var editHTMLElement = require('./editHTMLElement'); +const editHTMLElement = require('./editHTMLElement'); /** Convert all SVG images to PNG @@ -15,10 +15,10 @@ var editHTMLElement = require('./editHTMLElement'); @return {Promise} */ function svgToPng(rootFolder, currentFile, $) { - var currentDirectory = path.dirname(currentFile); + const currentDirectory = path.dirname(currentFile); return editHTMLElement($, 'img', function($img) { - var src = $img.attr('src'); + let src = $img.attr('src'); if (path.extname(src) !== '.svg') { return; } @@ -27,14 +27,14 @@ function svgToPng(rootFolder, currentFile, $) { src = LocationUtils.toAbsolute(src, currentDirectory, '.'); // We avoid generating twice the same PNG - var hash = crc.crc32(src).toString(16); - var fileName = hash + '.png'; + const hash = crc.crc32(src).toString(16); + let fileName = hash + '.png'; // Input file path - var inputPath = path.join(rootFolder, src); + const inputPath = path.join(rootFolder, src); // Result file path - var filePath = path.join(rootFolder, fileName); + const filePath = path.join(rootFolder, fileName); return fs.assertFile(filePath, function() { return imagesUtil.convertSVGToPNG(inputPath, filePath); diff --git a/packages/gitbook/lib/output/prepareAssets.js b/packages/gitbook/src/output/prepareAssets.js index ae9b55a..6694a74 100644 --- a/packages/gitbook/lib/output/prepareAssets.js +++ b/packages/gitbook/src/output/prepareAssets.js @@ -1,4 +1,4 @@ -var Parse = require('../parse'); +const Parse = require('../parse'); /** List all assets in the book @@ -7,9 +7,9 @@ var Parse = require('../parse'); @return {Promise<Output>} */ function prepareAssets(output) { - var book = output.getBook(); - var pages = output.getPages(); - var logger = output.getLogger(); + const book = output.getBook(); + const pages = output.getPages(); + const logger = output.getLogger(); return Parse.listAssets(book, pages) .then(function(assets) { diff --git a/packages/gitbook/lib/output/preparePages.js b/packages/gitbook/src/output/preparePages.js index 83944ed..e65367e 100644 --- a/packages/gitbook/lib/output/preparePages.js +++ b/packages/gitbook/src/output/preparePages.js @@ -1,5 +1,5 @@ -var Parse = require('../parse'); -var Promise = require('../utils/promise'); +const Parse = require('../parse'); +const Promise = require('../utils/promise'); /** List and prepare all pages @@ -8,8 +8,8 @@ var Promise = require('../utils/promise'); @return {Promise<Output>} */ function preparePages(output) { - var book = output.getBook(); - var logger = book.getLogger(); + const book = output.getBook(); + const logger = book.getLogger(); if (book.isMultilingual()) { return Promise(output); diff --git a/packages/gitbook/lib/output/preparePlugins.js b/packages/gitbook/src/output/preparePlugins.js index 5c4be93..c84bade 100644 --- a/packages/gitbook/lib/output/preparePlugins.js +++ b/packages/gitbook/src/output/preparePlugins.js @@ -1,5 +1,5 @@ -var Plugins = require('../plugins'); -var Promise = require('../utils/promise'); +const Plugins = require('../plugins'); +const Promise = require('../utils/promise'); /** * Load and setup plugins @@ -8,7 +8,7 @@ var Promise = require('../utils/promise'); * @return {Promise<Output>} */ function preparePlugins(output) { - var book = output.getBook(); + const book = output.getBook(); return Promise() @@ -27,7 +27,7 @@ function preparePlugins(output) { .then(function(newBook) { return output.merge({ book: newBook, - plugins: plugins + plugins }); }); }); diff --git a/packages/gitbook/lib/output/website/__tests__/i18n.js b/packages/gitbook/src/output/website/__tests__/i18n.js index fd610fb..24f01f3 100644 --- a/packages/gitbook/lib/output/website/__tests__/i18n.js +++ b/packages/gitbook/src/output/website/__tests__/i18n.js @@ -1,8 +1,8 @@ -var createMockOutput = require('../../__tests__/createMock'); -var prepareI18n = require('../prepareI18n'); -var createTemplateEngine = require('../createTemplateEngine'); +const createMockOutput = require('../../__tests__/createMock'); +const prepareI18n = require('../prepareI18n'); +const createTemplateEngine = require('../createTemplateEngine'); -var WebsiteGenerator = require('../'); +const WebsiteGenerator = require('../'); describe('i18n', function() { it('should correctly use english as default language', function() { @@ -13,8 +13,8 @@ describe('i18n', function() { return prepareI18n(output); }) .then(function(output) { - var engine = createTemplateEngine(output, 'README.md'); - var t = engine.getFilters().get('t'); + const engine = createTemplateEngine(output, 'README.md'); + const t = engine.getFilters().get('t'); expect(t('SUMMARY_INTRODUCTION')).toEqual('Introduction'); }); @@ -29,8 +29,8 @@ describe('i18n', function() { return prepareI18n(output); }) .then(function(output) { - var engine = createTemplateEngine(output, 'README.md'); - var t = engine.getFilters().get('t'); + const engine = createTemplateEngine(output, 'README.md'); + const t = engine.getFilters().get('t'); expect(t('GITBOOK_LINK')).toEqual('Publié avec GitBook'); }); diff --git a/packages/gitbook/lib/output/website/copyPluginAssets.js b/packages/gitbook/src/output/website/copyPluginAssets.js index 9150636..315804a 100644 --- a/packages/gitbook/lib/output/website/copyPluginAssets.js +++ b/packages/gitbook/src/output/website/copyPluginAssets.js @@ -1,8 +1,8 @@ -var path = require('path'); +const path = require('path'); -var ASSET_FOLDER = require('../../constants/pluginAssetsFolder'); -var Promise = require('../../utils/promise'); -var fs = require('../../utils/fs'); +const ASSET_FOLDER = require('../../constants/pluginAssetsFolder'); +const Promise = require('../../utils/promise'); +const fs = require('../../utils/fs'); /** Copy all assets from plugins. @@ -13,7 +13,7 @@ var fs = require('../../utils/fs'); @return {Promise} */ function copyPluginAssets(output) { - var book = output.getBook(); + const book = output.getBook(); // Don't copy plugins assets for language book // It'll be resolved to the parent folder @@ -21,7 +21,7 @@ function copyPluginAssets(output) { return Promise(output); } - var plugins = output.getPlugins() + const plugins = output.getPlugins() // We reverse the order of plugins to copy // so that first plugins can replace assets from other plugins. @@ -43,15 +43,15 @@ function copyPluginAssets(output) { @return {Promise} */ function copyAssets(output, plugin) { - var logger = output.getLogger(); - var pluginRoot = plugin.getPath(); - var options = output.getOptions(); + const logger = output.getLogger(); + const pluginRoot = plugin.getPath(); + const options = output.getOptions(); - var outputRoot = options.get('root'); - var assetOutputFolder = path.join(outputRoot, 'gitbook'); - var prefix = options.get('prefix'); + const outputRoot = options.get('root'); + const assetOutputFolder = path.join(outputRoot, 'gitbook'); + const prefix = options.get('prefix'); - var assetFolder = path.join(pluginRoot, ASSET_FOLDER, prefix); + const assetFolder = path.join(pluginRoot, ASSET_FOLDER, prefix); if (!fs.existsSync(assetFolder)) { return Promise(); @@ -76,19 +76,19 @@ function copyAssets(output, plugin) { @return {Promise} */ function copyResources(output, plugin) { - var logger = output.getLogger(); + const logger = output.getLogger(); - var options = output.getOptions(); - var outputRoot = options.get('root'); + const options = output.getOptions(); + const outputRoot = options.get('root'); - var state = output.getState(); - var resources = state.getResources(); + const state = output.getState(); + const resources = state.getResources(); - var pluginRoot = plugin.getPath(); - var pluginResources = resources.get(plugin.getName()); + const pluginRoot = plugin.getPath(); + const pluginResources = resources.get(plugin.getName()); - var assetsFolder = pluginResources.get('assets'); - var assetOutputFolder = path.join(outputRoot, 'gitbook', plugin.getNpmID()); + let assetsFolder = pluginResources.get('assets'); + const assetOutputFolder = path.join(outputRoot, 'gitbook', plugin.getNpmID()); if (!assetsFolder) { return Promise(); diff --git a/packages/gitbook/lib/output/website/createTemplateEngine.js b/packages/gitbook/src/output/website/createTemplateEngine.js index 02ec796..42a0bea 100644 --- a/packages/gitbook/lib/output/website/createTemplateEngine.js +++ b/packages/gitbook/src/output/website/createTemplateEngine.js @@ -1,21 +1,21 @@ -var path = require('path'); -var nunjucks = require('nunjucks'); -var DoExtension = require('nunjucks-do')(nunjucks); - -var Api = require('../../api'); -var deprecate = require('../../api/deprecate'); -var JSONUtils = require('../../json'); -var LocationUtils = require('../../utils/location'); -var fs = require('../../utils/fs'); -var PathUtils = require('../../utils/path'); -var TemplateEngine = require('../../models/templateEngine'); -var templatesFolder = require('../../constants/templatesFolder'); -var defaultFilters = require('../../constants/defaultFilters'); -var Templating = require('../../templating'); -var listSearchPaths = require('./listSearchPaths'); - -var fileToURL = require('../helper/fileToURL'); -var resolveFileToURL = require('../helper/resolveFileToURL'); +const path = require('path'); +const nunjucks = require('nunjucks'); +const DoExtension = require('nunjucks-do')(nunjucks); + +const Api = require('../../api'); +const deprecate = require('../../api/deprecate'); +const JSONUtils = require('../../json'); +const LocationUtils = require('../../utils/location'); +const fs = require('../../utils/fs'); +const PathUtils = require('../../utils/path'); +const TemplateEngine = require('../../models/templateEngine'); +const templatesFolder = require('../../constants/templatesFolder'); +const defaultFilters = require('../../constants/defaultFilters'); +const Templating = require('../../templating'); +const listSearchPaths = require('./listSearchPaths'); + +const fileToURL = require('../helper/fileToURL'); +const resolveFileToURL = require('../helper/resolveFileToURL'); /** * Directory for a theme with the templates @@ -32,25 +32,25 @@ function templateFolder(dir) { * @return {TemplateEngine} */ function createTemplateEngine(output, currentFile) { - var book = output.getBook(); - var state = output.getState(); - var i18n = state.getI18n(); - var config = book.getConfig(); - var summary = book.getSummary(); - var outputFolder = output.getRoot(); + const book = output.getBook(); + const state = output.getState(); + const i18n = state.getI18n(); + const config = book.getConfig(); + const summary = book.getSummary(); + const outputFolder = output.getRoot(); // Search paths for templates - var searchPaths = listSearchPaths(output); - var tplSearchPaths = searchPaths.map(templateFolder); + const searchPaths = listSearchPaths(output); + const tplSearchPaths = searchPaths.map(templateFolder); // Create loader - var loader = new Templating.ThemesLoader(tplSearchPaths); + const loader = new Templating.ThemesLoader(tplSearchPaths); // Get languages - var language = config.getValue('language'); + const language = config.getValue('language'); // Create API context - var context = Api.encodeGlobal(output); + const context = Api.encodeGlobal(output); /** @@ -63,7 +63,7 @@ function createTemplateEngine(output, currentFile) { return false; } - var filePath = PathUtils.resolveInRoot(outputFolder, fileName); + const filePath = PathUtils.resolveInRoot(outputFolder, fileName); return fs.existsSync(filePath); } @@ -73,7 +73,7 @@ function createTemplateEngine(output, currentFile) { * @return {Object|undefined} */ function getArticleByPath(filePath) { - var article = summary.getByPath(filePath); + const article = summary.getByPath(filePath); if (!article) return undefined; return JSONUtils.encodeSummaryArticle(article); @@ -85,24 +85,25 @@ function createTemplateEngine(output, currentFile) { * @return {Object|undefined} */ function getPageByPath(filePath) { - var page = output.getPage(filePath); + const page = output.getPage(filePath); if (!page) return undefined; return JSONUtils.encodePage(page, summary); } return TemplateEngine.create({ - loader: loader, + loader, - context: context, + context, globals: { - getArticleByPath: getArticleByPath, - getPageByPath: getPageByPath, - fileExists: fileExists + getArticleByPath, + getPageByPath, + fileExists }, filters: defaultFilters.merge({ + /** * Translate a sentence */ @@ -115,12 +116,12 @@ function createTemplateEngine(output, currentFile) { * relative path. * it also resolve pages */ - resolveFile: function(filePath) { + resolveFile(filePath) { filePath = resolveFileToURL(output, filePath); return LocationUtils.relativeForFile(currentFile, filePath); }, - resolveAsset: function(filePath) { + resolveAsset(filePath) { filePath = LocationUtils.toAbsolute(filePath, '', ''); filePath = path.join('gitbook', filePath); filePath = LocationUtils.relativeForFile(currentFile, filePath); @@ -137,7 +138,7 @@ function createTemplateEngine(output, currentFile) { fileExists: deprecate.method(book, 'fileExists', fileExists, 'Filter "fileExists" is deprecated, use "fileExists(filename)" '), getArticleByPath: deprecate.method(book, 'getArticleByPath', fileExists, 'Filter "getArticleByPath" is deprecated, use "getArticleByPath(filename)" '), - contentURL: function(filePath) { + contentURL(filePath) { return fileToURL(output, filePath); } }), diff --git a/packages/gitbook/lib/output/website/index.js b/packages/gitbook/src/output/website/index.js index 7818a28..7818a28 100644 --- a/packages/gitbook/lib/output/website/index.js +++ b/packages/gitbook/src/output/website/index.js diff --git a/packages/gitbook/lib/output/website/listSearchPaths.js b/packages/gitbook/src/output/website/listSearchPaths.js index c45f39c..c07dade 100644 --- a/packages/gitbook/lib/output/website/listSearchPaths.js +++ b/packages/gitbook/src/output/website/listSearchPaths.js @@ -6,10 +6,10 @@ @return {List<String>} */ function listSearchPaths(output) { - var book = output.getBook(); - var plugins = output.getPlugins(); + const book = output.getBook(); + const plugins = output.getPlugins(); - var searchPaths = plugins + const searchPaths = plugins .valueSeq() .map(function(plugin) { return plugin.getPath(); diff --git a/packages/gitbook/lib/output/website/onAsset.js b/packages/gitbook/src/output/website/onAsset.js index 69dfc4f..b996375 100644 --- a/packages/gitbook/lib/output/website/onAsset.js +++ b/packages/gitbook/src/output/website/onAsset.js @@ -1,5 +1,5 @@ -var path = require('path'); -var fs = require('../../utils/fs'); +const path = require('path'); +const fs = require('../../utils/fs'); /** Copy an asset to the output folder @@ -8,12 +8,12 @@ var fs = require('../../utils/fs'); @param {Page} page */ function onAsset(output, asset) { - var book = output.getBook(); - var options = output.getOptions(); - var bookFS = book.getContentFS(); + const book = output.getBook(); + const options = output.getOptions(); + const bookFS = book.getContentFS(); - var outputFolder = options.get('root'); - var outputPath = path.resolve(outputFolder, asset); + const outputFolder = options.get('root'); + const outputPath = path.resolve(outputFolder, asset); return fs.ensureFile(outputPath) .then(function() { diff --git a/packages/gitbook/src/output/website/onFinish.js b/packages/gitbook/src/output/website/onFinish.js new file mode 100644 index 0000000..b032c90 --- /dev/null +++ b/packages/gitbook/src/output/website/onFinish.js @@ -0,0 +1,35 @@ +const Promise = require('../../utils/promise'); +const JSONUtils = require('../../json'); +const Templating = require('../../templating'); +const writeFile = require('../helper/writeFile'); +const createTemplateEngine = require('./createTemplateEngine'); + +/** + Finish the generation, write the languages index + + @param {Output} + @return {Output} +*/ +function onFinish(output) { + const book = output.getBook(); + const options = output.getOptions(); + const prefix = options.get('prefix'); + + if (!book.isMultilingual()) { + return Promise(output); + } + + const filePath = 'index.html'; + const engine = createTemplateEngine(output, filePath); + const context = JSONUtils.encodeOutput(output); + + // Render the theme + return Templating.renderFile(engine, prefix + '/languages.html', context) + + // Write it to the disk + .then(function(tplOut) { + return writeFile(output, filePath, tplOut.getContent()); + }); +} + +module.exports = onFinish; diff --git a/packages/gitbook/lib/output/website/onInit.js b/packages/gitbook/src/output/website/onInit.js index 3465eef..3f6d26e 100644 --- a/packages/gitbook/lib/output/website/onInit.js +++ b/packages/gitbook/src/output/website/onInit.js @@ -1,8 +1,8 @@ -var Promise = require('../../utils/promise'); +const Promise = require('../../utils/promise'); -var copyPluginAssets = require('./copyPluginAssets'); -var prepareI18n = require('./prepareI18n'); -var prepareResources = require('./prepareResources'); +const copyPluginAssets = require('./copyPluginAssets'); +const prepareI18n = require('./prepareI18n'); +const prepareResources = require('./prepareResources'); /** Initialize the generator diff --git a/packages/gitbook/lib/output/website/onPage.js b/packages/gitbook/src/output/website/onPage.js index 5fb40a7..3b40536 100644 --- a/packages/gitbook/lib/output/website/onPage.js +++ b/packages/gitbook/src/output/website/onPage.js @@ -1,15 +1,15 @@ -var path = require('path'); -var omit = require('omit-keys'); +const path = require('path'); +const omit = require('omit-keys'); -var Templating = require('../../templating'); -var Plugins = require('../../plugins'); -var JSONUtils = require('../../json'); -var LocationUtils = require('../../utils/location'); -var Modifiers = require('../modifiers'); -var writeFile = require('../helper/writeFile'); -var getModifiers = require('../getModifiers'); -var createTemplateEngine = require('./createTemplateEngine'); -var fileToOutput = require('../helper/fileToOutput'); +const Templating = require('../../templating'); +const Plugins = require('../../plugins'); +const JSONUtils = require('../../json'); +const LocationUtils = require('../../utils/location'); +const Modifiers = require('../modifiers'); +const writeFile = require('../helper/writeFile'); +const getModifiers = require('../getModifiers'); +const createTemplateEngine = require('./createTemplateEngine'); +const fileToOutput = require('../helper/fileToOutput'); /** * Write a page as a json file @@ -18,41 +18,41 @@ var fileToOutput = require('../helper/fileToOutput'); * @param {Page} page */ function onPage(output, page) { - var options = output.getOptions(); - var prefix = options.get('prefix'); + const options = output.getOptions(); + const prefix = options.get('prefix'); - var file = page.getFile(); + const file = page.getFile(); - var book = output.getBook(); - var plugins = output.getPlugins(); - var state = output.getState(); - var resources = state.getResources(); + const book = output.getBook(); + const plugins = output.getPlugins(); + const state = output.getState(); + const resources = state.getResources(); - var engine = createTemplateEngine(output, page.getPath()); + const engine = createTemplateEngine(output, page.getPath()); // Output file path - var filePath = fileToOutput(output, file.getPath()); + const filePath = fileToOutput(output, file.getPath()); // Calcul relative path to the root - var outputDirName = path.dirname(filePath); - var basePath = LocationUtils.normalize(path.relative(outputDirName, './')); + const outputDirName = path.dirname(filePath); + const basePath = LocationUtils.normalize(path.relative(outputDirName, './')); return Modifiers.modifyHTML(page, getModifiers(output, page)) .then(function(resultPage) { // Generate the context - var context = JSONUtils.encodeOutputWithPage(output, resultPage); + const context = JSONUtils.encodeOutputWithPage(output, resultPage); context.plugins = { resources: Plugins.listResources(plugins, resources).toJS() }; context.template = { - getJSContext: function() { + getJSContext() { return { page: omit(context.page, 'content'), config: context.config, file: context.file, gitbook: context.gitbook, - basePath: basePath, + basePath, book: { language: book.getLanguage() } diff --git a/packages/gitbook/lib/output/website/options.js b/packages/gitbook/src/output/website/options.js index ac9cdad..43314df 100644 --- a/packages/gitbook/lib/output/website/options.js +++ b/packages/gitbook/src/output/website/options.js @@ -1,6 +1,6 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var Options = Immutable.Record({ +const Options = Immutable.Record({ // Root folder for the output root: String(), diff --git a/packages/gitbook/lib/output/website/prepareI18n.js b/packages/gitbook/src/output/website/prepareI18n.js index cedd3b9..b02ef77 100644 --- a/packages/gitbook/lib/output/website/prepareI18n.js +++ b/packages/gitbook/src/output/website/prepareI18n.js @@ -1,8 +1,8 @@ -var path = require('path'); +const path = require('path'); -var fs = require('../../utils/fs'); -var Promise = require('../../utils/promise'); -var listSearchPaths = require('./listSearchPaths'); +const fs = require('../../utils/fs'); +const Promise = require('../../utils/promise'); +const listSearchPaths = require('./listSearchPaths'); /** * Prepare i18n, load translations from plugins and book @@ -11,14 +11,14 @@ var listSearchPaths = require('./listSearchPaths'); * @return {Promise<Output>} */ function prepareI18n(output) { - var state = output.getState(); - var i18n = state.getI18n(); - var searchPaths = listSearchPaths(output); + const state = output.getState(); + const i18n = state.getI18n(); + const searchPaths = listSearchPaths(output); searchPaths .reverse() .forEach(function(searchPath) { - var i18nRoot = path.resolve(searchPath, '_i18n'); + const i18nRoot = path.resolve(searchPath, '_i18n'); if (!fs.existsSync(i18nRoot)) return; i18n.load(i18nRoot); diff --git a/packages/gitbook/lib/output/website/prepareResources.js b/packages/gitbook/src/output/website/prepareResources.js index 4e6835d..e93f45f 100644 --- a/packages/gitbook/lib/output/website/prepareResources.js +++ b/packages/gitbook/src/output/website/prepareResources.js @@ -1,8 +1,8 @@ -var is = require('is'); -var Immutable = require('immutable'); -var Promise = require('../../utils/promise'); +const is = require('is'); +const Immutable = require('immutable'); +const Promise = require('../../utils/promise'); -var Api = require('../../api'); +const Api = require('../../api'); /** Prepare plugins resources, add all output corresponding type resources @@ -11,16 +11,16 @@ var Api = require('../../api'); @return {Promise<Output>} */ function prepareResources(output) { - var plugins = output.getPlugins(); - var options = output.getOptions(); - var type = options.get('prefix'); - var state = output.getState(); - var context = Api.encodeGlobal(output); + const plugins = output.getPlugins(); + const options = output.getOptions(); + const type = options.get('prefix'); + let state = output.getState(); + const context = Api.encodeGlobal(output); - var result = Immutable.Map(); + let result = Immutable.Map(); return Promise.forEach(plugins, function(plugin) { - var pluginResources = plugin.getResources(type); + const pluginResources = plugin.getResources(type); return Promise() .then(function() { @@ -44,11 +44,11 @@ function prepareResources(output) { }); output = output.merge({ - state: state + state }); return output; }); } -module.exports = prepareResources;
\ No newline at end of file +module.exports = prepareResources; diff --git a/packages/gitbook/lib/output/website/state.js b/packages/gitbook/src/output/website/state.js index cb8f750..813b850 100644 --- a/packages/gitbook/lib/output/website/state.js +++ b/packages/gitbook/src/output/website/state.js @@ -1,7 +1,7 @@ -var I18n = require('i18n-t'); -var Immutable = require('immutable'); +const I18n = require('i18n-t'); +const Immutable = require('immutable'); -var GeneratorState = Immutable.Record({ +const GeneratorState = Immutable.Record({ i18n: I18n(), // List of plugins' resources diff --git a/packages/gitbook/lib/parse/__tests__/listAssets.js b/packages/gitbook/src/parse/__tests__/listAssets.js index 4c5b0a0..102aed9 100644 --- a/packages/gitbook/lib/parse/__tests__/listAssets.js +++ b/packages/gitbook/src/parse/__tests__/listAssets.js @@ -1,20 +1,20 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var Book = require('../../models/book'); -var createMockFS = require('../../fs/mock'); -var listAssets = require('../listAssets'); -var parseGlossary = require('../parseGlossary'); +const Book = require('../../models/book'); +const createMockFS = require('../../fs/mock'); +const listAssets = require('../listAssets'); +const parseGlossary = require('../parseGlossary'); describe('listAssets', function() { it('should not list glossary as asset', function() { - var fs = createMockFS({ + const fs = createMockFS({ 'GLOSSARY.md': '# Glossary\n\n## Hello\nDescription for hello', 'assetFile.js': '', 'assets': { 'file.js': '' } }); - var book = Book.createForFS(fs); + const book = Book.createForFS(fs); return parseGlossary(book) .then(function(resultBook) { diff --git a/packages/gitbook/lib/parse/__tests__/parseBook.js b/packages/gitbook/src/parse/__tests__/parseBook.js index b1236c9..d5de25c 100644 --- a/packages/gitbook/lib/parse/__tests__/parseBook.js +++ b/packages/gitbook/src/parse/__tests__/parseBook.js @@ -1,11 +1,11 @@ -var Book = require('../../models/book'); -var createMockFS = require('../../fs/mock'); +const Book = require('../../models/book'); +const createMockFS = require('../../fs/mock'); describe('parseBook', function() { - var parseBook = require('../parseBook'); + const parseBook = require('../parseBook'); it('should parse multilingual book', function() { - var fs = createMockFS({ + const fs = createMockFS({ 'LANGS.md': '# Languages\n\n* [en](en)\n* [fr](fr)', 'en': { 'README.md': 'Hello' @@ -14,12 +14,12 @@ describe('parseBook', function() { 'README.md': 'Bonjour' } }); - var book = Book.createForFS(fs); + const book = Book.createForFS(fs); return parseBook(book) .then(function(resultBook) { - var languages = resultBook.getLanguages(); - var books = resultBook.getBooks(); + const languages = resultBook.getLanguages(); + const books = resultBook.getBooks(); expect(resultBook.isMultilingual()).toBe(true); expect(languages.getList().size).toBe(2); @@ -28,7 +28,7 @@ describe('parseBook', function() { }); it('should extend configuration for multilingual book', function() { - var fs = createMockFS({ + const fs = createMockFS({ 'LANGS.md': '# Languages\n\n* [en](en)\n* [fr](fr)', 'book.json': '{ "title": "Test", "author": "GitBook" }', 'en': { @@ -39,20 +39,20 @@ describe('parseBook', function() { 'README.md': 'Bonjour' } }); - var book = Book.createForFS(fs); + const book = Book.createForFS(fs); return parseBook(book) .then(function(resultBook) { - var books = resultBook.getBooks(); + const books = resultBook.getBooks(); expect(resultBook.isMultilingual()).toBe(true); expect(books.size).toBe(2); - var en = books.get('en'); - var fr = books.get('fr'); + const en = books.get('en'); + const fr = books.get('fr'); - var enConfig = en.getConfig(); - var frConfig = fr.getConfig(); + const enConfig = en.getConfig(); + const frConfig = fr.getConfig(); expect(enConfig.getValue('title')).toBe('Test EN'); expect(enConfig.getValue('author')).toBe('GitBook'); @@ -63,7 +63,7 @@ describe('parseBook', function() { }); it('should parse book in a directory', function() { - var fs = createMockFS({ + const fs = createMockFS({ 'book.json': JSON.stringify({ root: './test' }), @@ -73,13 +73,13 @@ describe('parseBook', function() { 'page.md': 'Page' } }); - var book = Book.createForFS(fs); + const book = Book.createForFS(fs); return parseBook(book) .then(function(resultBook) { - var readme = resultBook.getReadme(); - var summary = resultBook.getSummary(); - var articles = summary.getArticlesAsList(); + const readme = resultBook.getReadme(); + const summary = resultBook.getSummary(); + const articles = summary.getArticlesAsList(); expect(summary.getFile().exists()).toBe(true); expect(readme.getFile().exists()).toBe(true); diff --git a/packages/gitbook/lib/parse/__tests__/parseGlossary.js b/packages/gitbook/src/parse/__tests__/parseGlossary.js index 9069af6..ba2e407 100644 --- a/packages/gitbook/lib/parse/__tests__/parseGlossary.js +++ b/packages/gitbook/src/parse/__tests__/parseGlossary.js @@ -1,20 +1,20 @@ -var Book = require('../../models/book'); -var createMockFS = require('../../fs/mock'); +const Book = require('../../models/book'); +const createMockFS = require('../../fs/mock'); describe('parseGlossary', function() { - var parseGlossary = require('../parseGlossary'); + const parseGlossary = require('../parseGlossary'); it('should parse glossary if exists', function() { - var fs = createMockFS({ + const fs = createMockFS({ 'GLOSSARY.md': '# Glossary\n\n## Hello\nDescription for hello' }); - var book = Book.createForFS(fs); + const book = Book.createForFS(fs); return parseGlossary(book) .then(function(resultBook) { - var glossary = resultBook.getGlossary(); - var file = glossary.getFile(); - var entries = glossary.getEntries(); + const glossary = resultBook.getGlossary(); + const file = glossary.getFile(); + const entries = glossary.getEntries(); expect(file.exists()).toBeTruthy(); expect(entries.size).toBe(1); @@ -22,13 +22,13 @@ describe('parseGlossary', function() { }); it('should not fail if doesn\'t exist', function() { - var fs = createMockFS({}); - var book = Book.createForFS(fs); + const fs = createMockFS({}); + const book = Book.createForFS(fs); return parseGlossary(book) .then(function(resultBook) { - var glossary = resultBook.getGlossary(); - var file = glossary.getFile(); + const glossary = resultBook.getGlossary(); + const file = glossary.getFile(); expect(file.exists()).toBeFalsy(); }); diff --git a/packages/gitbook/lib/parse/__tests__/parseIgnore.js b/packages/gitbook/src/parse/__tests__/parseIgnore.js index 54e7dae..b1bd43c 100644 --- a/packages/gitbook/lib/parse/__tests__/parseIgnore.js +++ b/packages/gitbook/src/parse/__tests__/parseIgnore.js @@ -1,9 +1,9 @@ -var Book = require('../../models/book'); -var createMockFS = require('../../fs/mock'); +const Book = require('../../models/book'); +const createMockFS = require('../../fs/mock'); describe('parseIgnore', function() { - var parseIgnore = require('../parseIgnore'); - var fs = createMockFS({ + const parseIgnore = require('../parseIgnore'); + const fs = createMockFS({ '.ignore': 'test-1.js', '.gitignore': 'test-2.js\ntest-3.js', '.bookignore': '!test-3.js', @@ -13,7 +13,7 @@ describe('parseIgnore', function() { }); function getBook() { - var book = Book.createForFS(fs); + const book = Book.createForFS(fs); return parseIgnore(book); } diff --git a/packages/gitbook/lib/parse/__tests__/parsePageFromString.js b/packages/gitbook/src/parse/__tests__/parsePageFromString.js index 2911fa3..13bc544 100644 --- a/packages/gitbook/lib/parse/__tests__/parsePageFromString.js +++ b/packages/gitbook/src/parse/__tests__/parsePageFromString.js @@ -1,25 +1,25 @@ -var parsePageFromString = require('../parsePageFromString'); -var Page = require('../../models/page'); +const parsePageFromString = require('../parsePageFromString'); +const Page = require('../../models/page'); describe('parsePageFromString', function() { - var page = new Page(); + const page = new Page(); it('should parse YAML frontmatter', function() { - var CONTENT = '---\nhello: true\nworld: "cool"\n---\n# Hello World\n'; - var newPage = parsePageFromString(page, CONTENT); + const CONTENT = '---\nhello: true\nworld: "cool"\n---\n# Hello World\n'; + const newPage = parsePageFromString(page, CONTENT); expect(newPage.getDir()).toBe('ltr'); expect(newPage.getContent()).toBe('# Hello World\n'); - var attrs = newPage.getAttributes(); + const attrs = newPage.getAttributes(); expect(attrs.size).toBe(2); expect(attrs.get('hello')).toBe(true); expect(attrs.get('world')).toBe('cool'); }); it('should parse text direction (english)', function() { - var CONTENT = 'Hello World'; - var newPage = parsePageFromString(page, CONTENT); + const CONTENT = 'Hello World'; + const newPage = parsePageFromString(page, CONTENT); expect(newPage.getDir()).toBe('ltr'); expect(newPage.getContent()).toBe('Hello World'); @@ -27,8 +27,8 @@ describe('parsePageFromString', function() { }); it('should parse text direction (arab)', function() { - var CONTENT = 'Ù…Ø±ØØ¨Ø§ بالعالم'; - var newPage = parsePageFromString(page, CONTENT); + const CONTENT = 'Ù…Ø±ØØ¨Ø§ بالعالم'; + const newPage = parsePageFromString(page, CONTENT); expect(newPage.getDir()).toBe('rtl'); expect(newPage.getContent()).toBe('Ù…Ø±ØØ¨Ø§ بالعالم'); diff --git a/packages/gitbook/lib/parse/__tests__/parseReadme.js b/packages/gitbook/src/parse/__tests__/parseReadme.js index 4270ea3..45ecfa3 100644 --- a/packages/gitbook/lib/parse/__tests__/parseReadme.js +++ b/packages/gitbook/src/parse/__tests__/parseReadme.js @@ -1,20 +1,20 @@ -var Promise = require('../../utils/promise'); -var Book = require('../../models/book'); -var createMockFS = require('../../fs/mock'); +const Promise = require('../../utils/promise'); +const Book = require('../../models/book'); +const createMockFS = require('../../fs/mock'); describe('parseReadme', function() { - var parseReadme = require('../parseReadme'); + const parseReadme = require('../parseReadme'); it('should parse summary if exists', function() { - var fs = createMockFS({ + const fs = createMockFS({ 'README.md': '# Hello\n\nAnd here is the description.' }); - var book = Book.createForFS(fs); + const book = Book.createForFS(fs); return parseReadme(book) .then(function(resultBook) { - var readme = resultBook.getReadme(); - var file = readme.getFile(); + const readme = resultBook.getReadme(); + const file = readme.getFile(); expect(file.exists()).toBeTruthy(); expect(readme.getTitle()).toBe('Hello'); @@ -23,8 +23,8 @@ describe('parseReadme', function() { }); it('should fail if doesn\'t exist', function() { - var fs = createMockFS({}); - var book = Book.createForFS(fs); + const fs = createMockFS({}); + const book = Book.createForFS(fs); return parseReadme(book) .then(function(resultBook) { diff --git a/packages/gitbook/lib/parse/__tests__/parseSummary.js b/packages/gitbook/src/parse/__tests__/parseSummary.js index 55a445e..8b86c45 100644 --- a/packages/gitbook/lib/parse/__tests__/parseSummary.js +++ b/packages/gitbook/src/parse/__tests__/parseSummary.js @@ -1,32 +1,32 @@ -var Book = require('../../models/book'); -var createMockFS = require('../../fs/mock'); +const Book = require('../../models/book'); +const createMockFS = require('../../fs/mock'); describe('parseSummary', function() { - var parseSummary = require('../parseSummary'); + const parseSummary = require('../parseSummary'); it('should parse summary if exists', function() { - var fs = createMockFS({ + const fs = createMockFS({ 'SUMMARY.md': '# Summary\n\n* [Hello](hello.md)' }); - var book = Book.createForFS(fs); + const book = Book.createForFS(fs); return parseSummary(book) .then(function(resultBook) { - var summary = resultBook.getSummary(); - var file = summary.getFile(); + const summary = resultBook.getSummary(); + const file = summary.getFile(); expect(file.exists()).toBeTruthy(); }); }); it('should not fail if doesn\'t exist', function() { - var fs = createMockFS({}); - var book = Book.createForFS(fs); + const fs = createMockFS({}); + const book = Book.createForFS(fs); return parseSummary(book) .then(function(resultBook) { - var summary = resultBook.getSummary(); - var file = summary.getFile(); + const summary = resultBook.getSummary(); + const file = summary.getFile(); expect(file.exists()).toBeFalsy(); }); diff --git a/packages/gitbook/lib/parse/findParsableFile.js b/packages/gitbook/src/parse/findParsableFile.js index 51e2dd0..c30dbbd 100644 --- a/packages/gitbook/lib/parse/findParsableFile.js +++ b/packages/gitbook/src/parse/findParsableFile.js @@ -1,7 +1,7 @@ -var path = require('path'); +const path = require('path'); -var Promise = require('../utils/promise'); -var parsers = require('../parsers'); +const Promise = require('../utils/promise'); +const parsers = require('../parsers'); /** Find a file parsable (Markdown or AsciiDoc) in a book @@ -11,16 +11,16 @@ var parsers = require('../parsers'); @return {Promise<File | Undefined>} */ function findParsableFile(book, filename) { - var fs = book.getContentFS(); - var ext = path.extname(filename); - var basename = path.basename(filename, ext); - var basedir = path.dirname(filename); + const fs = book.getContentFS(); + const ext = path.extname(filename); + const basename = path.basename(filename, ext); + const basedir = path.dirname(filename); // Ordered list of extensions to test - var exts = parsers.extensions; + const exts = parsers.extensions; return Promise.some(exts, function(ext) { - var filepath = basename + ext; + const filepath = basename + ext; return fs.findFile(basedir, filepath) .then(function(found) { diff --git a/packages/gitbook/lib/parse/index.js b/packages/gitbook/src/parse/index.js index 1f73946..1f73946 100644 --- a/packages/gitbook/lib/parse/index.js +++ b/packages/gitbook/src/parse/index.js diff --git a/packages/gitbook/lib/parse/listAssets.js b/packages/gitbook/src/parse/listAssets.js index d83d8fd..07cf2e1 100644 --- a/packages/gitbook/lib/parse/listAssets.js +++ b/packages/gitbook/src/parse/listAssets.js @@ -1,4 +1,4 @@ -var timing = require('../utils/timing'); +const timing = require('../utils/timing'); /** List all assets in a book @@ -9,19 +9,19 @@ var timing = require('../utils/timing'); @param */ function listAssets(book, pages) { - var fs = book.getContentFS(); + const fs = book.getContentFS(); - var summary = book.getSummary(); - var summaryFile = summary.getFile().getPath(); + const summary = book.getSummary(); + const summaryFile = summary.getFile().getPath(); - var glossary = book.getGlossary(); - var glossaryFile = glossary.getFile().getPath(); + const glossary = book.getGlossary(); + const glossaryFile = glossary.getFile().getPath(); - var langs = book.getLanguages(); - var langsFile = langs.getFile().getPath(); + const langs = book.getLanguages(); + const langsFile = langs.getFile().getPath(); - var config = book.getConfig(); - var configFile = config.getFile().getPath(); + const config = book.getConfig(); + const configFile = config.getFile().getPath(); function filterFile(file) { return !( diff --git a/packages/gitbook/lib/parse/lookupStructureFile.js b/packages/gitbook/src/parse/lookupStructureFile.js index 36b37f8..e54a769 100644 --- a/packages/gitbook/lib/parse/lookupStructureFile.js +++ b/packages/gitbook/src/parse/lookupStructureFile.js @@ -1,4 +1,4 @@ -var findParsableFile = require('./findParsableFile'); +const findParsableFile = require('./findParsableFile'); /** Lookup a structure file (ex: SUMMARY.md, GLOSSARY.md) in a book. Uses @@ -10,9 +10,9 @@ var findParsableFile = require('./findParsableFile'); to the book content root. */ function lookupStructureFile(book, type) { - var config = book.getConfig(); + const config = book.getConfig(); - var fileToSearch = config.getValue(['structure', type]); + const fileToSearch = config.getValue(['structure', type]); return findParsableFile(book, fileToSearch); } diff --git a/packages/gitbook/lib/parse/parseBook.js b/packages/gitbook/src/parse/parseBook.js index a92f39e..85f4519 100644 --- a/packages/gitbook/lib/parse/parseBook.js +++ b/packages/gitbook/src/parse/parseBook.js @@ -1,13 +1,13 @@ -var Promise = require('../utils/promise'); -var timing = require('../utils/timing'); -var Book = require('../models/book'); +const Promise = require('../utils/promise'); +const timing = require('../utils/timing'); +const Book = require('../models/book'); -var parseIgnore = require('./parseIgnore'); -var parseConfig = require('./parseConfig'); -var parseGlossary = require('./parseGlossary'); -var parseSummary = require('./parseSummary'); -var parseReadme = require('./parseReadme'); -var parseLanguages = require('./parseLanguages'); +const parseIgnore = require('./parseIgnore'); +const parseConfig = require('./parseConfig'); +const parseGlossary = require('./parseGlossary'); +const parseSummary = require('./parseSummary'); +const parseReadme = require('./parseReadme'); +const parseLanguages = require('./parseLanguages'); /** Parse content of a book @@ -29,13 +29,13 @@ function parseBookContent(book) { @return {Promise<Book>} */ function parseMultilingualBook(book) { - var languages = book.getLanguages(); - var langList = languages.getList(); + const languages = book.getLanguages(); + const langList = languages.getList(); return Promise.reduce(langList, function(currentBook, lang) { - var langID = lang.getID(); - var child = Book.createFromParent(currentBook, langID); - var ignore = currentBook.getIgnore(); + const langID = lang.getID(); + const child = Book.createFromParent(currentBook, langID); + let ignore = currentBook.getIgnore(); return Promise(child) .then(parseConfig) diff --git a/packages/gitbook/lib/parse/parseConfig.js b/packages/gitbook/src/parse/parseConfig.js index a411af8..cd27426 100644 --- a/packages/gitbook/lib/parse/parseConfig.js +++ b/packages/gitbook/src/parse/parseConfig.js @@ -1,7 +1,7 @@ -var Promise = require('../utils/promise'); +const Promise = require('../utils/promise'); -var validateConfig = require('./validateConfig'); -var CONFIG_FILES = require('../constants/configFiles'); +const validateConfig = require('./validateConfig'); +const CONFIG_FILES = require('../constants/configFiles'); /** Parse configuration from "book.json" or "book.js" @@ -10,8 +10,8 @@ var CONFIG_FILES = require('../constants/configFiles'); @return {Promise<Book>} */ function parseConfig(book) { - var fs = book.getFS(); - var config = book.getConfig(); + const fs = book.getFS(); + let config = book.getConfig(); return Promise.some(CONFIG_FILES, function(filename) { // Is this file ignored? @@ -25,19 +25,19 @@ function parseConfig(book) { return fs.statFile(filename) .then(function(file) { return { - file: file, + file, values: cfg }; }); }) .fail(function(err) { - if (err.code != 'MODULE_NOT_FOUND') throw(err); + if (err.code != 'MODULE_NOT_FOUND') throw (err); else return Promise(false); }); }) .then(function(result) { - var values = result? result.values : {}; + let values = result ? result.values : {}; values = validateConfig(values); // Set the file diff --git a/packages/gitbook/lib/parse/parseGlossary.js b/packages/gitbook/src/parse/parseGlossary.js index a96e5fc..052985b 100644 --- a/packages/gitbook/lib/parse/parseGlossary.js +++ b/packages/gitbook/src/parse/parseGlossary.js @@ -1,5 +1,5 @@ -var parseStructureFile = require('./parseStructureFile'); -var Glossary = require('../models/glossary'); +const parseStructureFile = require('./parseStructureFile'); +const Glossary = require('../models/glossary'); /** Parse glossary @@ -8,7 +8,7 @@ var Glossary = require('../models/glossary'); @return {Promise<Book>} */ function parseGlossary(book) { - var logger = book.getLogger(); + const logger = book.getLogger(); return parseStructureFile(book, 'glossary') .spread(function(file, entries) { @@ -18,7 +18,7 @@ function parseGlossary(book) { logger.debug.ln('glossary index file found at', file.getPath()); - var glossary = Glossary.createFromEntries(file, entries); + const glossary = Glossary.createFromEntries(file, entries); return book.set('glossary', glossary); }); } diff --git a/packages/gitbook/lib/parse/parseIgnore.js b/packages/gitbook/src/parse/parseIgnore.js index 84d8c33..3059447 100644 --- a/packages/gitbook/lib/parse/parseIgnore.js +++ b/packages/gitbook/src/parse/parseIgnore.js @@ -1,7 +1,7 @@ -var Promise = require('../utils/promise'); -var IGNORE_FILES = require('../constants/ignoreFiles'); +const Promise = require('../utils/promise'); +const IGNORE_FILES = require('../constants/ignoreFiles'); -var DEFAULT_IGNORES = [ +const DEFAULT_IGNORES = [ // Skip Git stuff '.git/', @@ -29,8 +29,8 @@ function parseIgnore(book) { return Promise.reject(new Error('Ignore files could be parsed for language books')); } - var fs = book.getFS(); - var ignore = book.getIgnore(); + const fs = book.getFS(); + let ignore = book.getIgnore(); ignore = ignore.add(DEFAULT_IGNORES); diff --git a/packages/gitbook/lib/parse/parseLanguages.js b/packages/gitbook/src/parse/parseLanguages.js index 346f3a3..1b28930 100644 --- a/packages/gitbook/lib/parse/parseLanguages.js +++ b/packages/gitbook/src/parse/parseLanguages.js @@ -1,5 +1,5 @@ -var parseStructureFile = require('./parseStructureFile'); -var Languages = require('../models/languages'); +const parseStructureFile = require('./parseStructureFile'); +const Languages = require('../models/languages'); /** Parse languages list from book @@ -8,7 +8,7 @@ var Languages = require('../models/languages'); @return {Promise<Book>} */ function parseLanguages(book) { - var logger = book.getLogger(); + const logger = book.getLogger(); return parseStructureFile(book, 'langs') .spread(function(file, result) { @@ -16,7 +16,7 @@ function parseLanguages(book) { return book; } - var languages = Languages.createFromList(file, result); + const languages = Languages.createFromList(file, result); logger.debug.ln('languages index file found at', file.getPath()); logger.info.ln('parsing multilingual book, with', languages.getList().size, 'languages'); diff --git a/packages/gitbook/lib/parse/parsePage.js b/packages/gitbook/src/parse/parsePage.js index fdc56a3..72f9ddf 100644 --- a/packages/gitbook/lib/parse/parsePage.js +++ b/packages/gitbook/src/parse/parsePage.js @@ -1,4 +1,4 @@ -var parsePageFromString = require('./parsePageFromString'); +const parsePageFromString = require('./parsePageFromString'); /** * Parse a page, read its content and parse the YAMl header @@ -8,8 +8,8 @@ var parsePageFromString = require('./parsePageFromString'); * @return {Promise<Page>} */ function parsePage(book, page) { - var fs = book.getContentFS(); - var file = page.getFile(); + const fs = book.getContentFS(); + const file = page.getFile(); return fs.readAsString(file.getPath()) .then(function(content) { diff --git a/packages/gitbook/lib/parse/parsePageFromString.js b/packages/gitbook/src/parse/parsePageFromString.js index 80c147b..2e4a598 100644 --- a/packages/gitbook/lib/parse/parsePageFromString.js +++ b/packages/gitbook/src/parse/parsePageFromString.js @@ -1,6 +1,6 @@ -var Immutable = require('immutable'); -var fm = require('front-matter'); -var direction = require('direction'); +const Immutable = require('immutable'); +const fm = require('front-matter'); +const direction = require('direction'); /** * Parse a page, its content and the YAMl header @@ -9,7 +9,7 @@ var direction = require('direction'); * @return {Page} */ function parsePageFromString(page, content) { - var parsed = fm(content); + const parsed = fm(content); return page.merge({ content: parsed.body, diff --git a/packages/gitbook/lib/parse/parsePagesList.js b/packages/gitbook/src/parse/parsePagesList.js index 1cf42f5..ddac20e 100644 --- a/packages/gitbook/lib/parse/parsePagesList.js +++ b/packages/gitbook/src/parse/parsePagesList.js @@ -1,9 +1,9 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var timing = require('../utils/timing'); -var Page = require('../models/page'); -var walkSummary = require('./walkSummary'); -var parsePage = require('./parsePage'); +const timing = require('../utils/timing'); +const Page = require('../models/page'); +const walkSummary = require('./walkSummary'); +const parsePage = require('./parsePage'); /** @@ -14,11 +14,11 @@ var parsePage = require('./parsePage'); @return {Page} */ function parseFilePage(book, filePath) { - var fs = book.getContentFS(); + const fs = book.getContentFS(); return fs.statFile(filePath) .then(function(file) { - var page = Page.createForFile(file); + const page = Page.createForFile(file); return parsePage(book, page); }); } @@ -31,9 +31,9 @@ function parseFilePage(book, filePath) { @return {Promise<OrderedMap<Page>>} */ function parsePagesList(book) { - var summary = book.getSummary(); - var glossary = book.getGlossary(); - var map = Immutable.OrderedMap(); + const summary = book.getSummary(); + const glossary = book.getGlossary(); + let map = Immutable.OrderedMap(); // Parse pages from summary return timing.measure( @@ -41,7 +41,7 @@ function parsePagesList(book) { walkSummary(summary, function(article) { if (!article.isPage()) return; - var filepath = article.getPath(); + const filepath = article.getPath(); // Is the page ignored? if (book.isContentFileIgnored(filepath)) return; @@ -57,7 +57,7 @@ function parsePagesList(book) { // Parse glossary .then(function() { - var file = glossary.getFile(); + const file = glossary.getFile(); if (!file.exists()) { return; diff --git a/packages/gitbook/lib/parse/parseReadme.js b/packages/gitbook/src/parse/parseReadme.js index a2ede77..82f8f19 100644 --- a/packages/gitbook/lib/parse/parseReadme.js +++ b/packages/gitbook/src/parse/parseReadme.js @@ -1,7 +1,7 @@ -var parseStructureFile = require('./parseStructureFile'); -var Readme = require('../models/readme'); +const parseStructureFile = require('./parseStructureFile'); +const Readme = require('../models/readme'); -var error = require('../utils/error'); +const error = require('../utils/error'); /** Parse readme from book @@ -10,7 +10,7 @@ var error = require('../utils/error'); @return {Promise<Book>} */ function parseReadme(book) { - var logger = book.getLogger(); + const logger = book.getLogger(); return parseStructureFile(book, 'readme') .spread(function(file, result) { @@ -20,7 +20,7 @@ function parseReadme(book) { logger.debug.ln('readme found at', file.getPath()); - var readme = Readme.create(file, result); + const readme = Readme.create(file, result); return book.set('readme', readme); }); } diff --git a/packages/gitbook/lib/parse/parseStructureFile.js b/packages/gitbook/src/parse/parseStructureFile.js index 718f731..951da96 100644 --- a/packages/gitbook/lib/parse/parseStructureFile.js +++ b/packages/gitbook/src/parse/parseStructureFile.js @@ -1,6 +1,6 @@ -var Promise = require('../utils/promise'); -var error = require('../utils/error'); -var lookupStructureFile = require('./lookupStructureFile'); +const Promise = require('../utils/promise'); +const error = require('../utils/error'); +const lookupStructureFile = require('./lookupStructureFile'); /** Parse a ParsableFile using a specific method @@ -11,8 +11,8 @@ var lookupStructureFile = require('./lookupStructureFile'); @return {Promise<Array<String, List|Map>>} */ function parseFile(fs, file, type) { - var filepath = file.getPath(); - var parser = file.getParser(); + const filepath = file.getPath(); + const parser = file.getParser(); if (!parser) { return Promise.reject( @@ -54,7 +54,7 @@ function parseFile(fs, file, type) { @return {Promise<List|Map>} */ function parseStructureFile(book, type) { - var fs = book.getContentFS(); + const fs = book.getContentFS(); return lookupStructureFile(book, type) .then(function(file) { diff --git a/packages/gitbook/lib/parse/parseSummary.js b/packages/gitbook/src/parse/parseSummary.js index 2c1e3b3..9488341 100644 --- a/packages/gitbook/lib/parse/parseSummary.js +++ b/packages/gitbook/src/parse/parseSummary.js @@ -1,6 +1,6 @@ -var parseStructureFile = require('./parseStructureFile'); -var Summary = require('../models/summary'); -var SummaryModifier = require('../modifiers').Summary; +const parseStructureFile = require('./parseStructureFile'); +const Summary = require('../models/summary'); +const SummaryModifier = require('../modifiers').Summary; /** Parse summary in a book, the summary can only be parsed @@ -10,13 +10,13 @@ var SummaryModifier = require('../modifiers').Summary; @return {Promise<Book>} */ function parseSummary(book) { - var readme = book.getReadme(); - var logger = book.getLogger(); - var readmeFile = readme.getFile(); + const readme = book.getReadme(); + const logger = book.getLogger(); + const readmeFile = readme.getFile(); return parseStructureFile(book, 'summary') .spread(function(file, result) { - var summary; + let summary; if (!file) { logger.warn.ln('no summary file in this book'); @@ -27,7 +27,7 @@ function parseSummary(book) { } // Insert readme as first entry if not in SUMMARY.md - var readmeArticle = summary.getByPath(readmeFile.getPath()); + const readmeArticle = summary.getByPath(readmeFile.getPath()); if (readmeFile.exists() && !readmeArticle) { summary = SummaryModifier.unshiftArticle(summary, { diff --git a/packages/gitbook/lib/parse/validateConfig.js b/packages/gitbook/src/parse/validateConfig.js index 21294ac..e766fae 100644 --- a/packages/gitbook/lib/parse/validateConfig.js +++ b/packages/gitbook/src/parse/validateConfig.js @@ -1,9 +1,9 @@ -var jsonschema = require('jsonschema'); -var jsonSchemaDefaults = require('json-schema-defaults'); +const jsonschema = require('jsonschema'); +const jsonSchemaDefaults = require('json-schema-defaults'); -var schema = require('../constants/configSchema'); -var error = require('../utils/error'); -var mergeDefaults = require('../utils/mergeDefaults'); +const schema = require('../constants/configSchema'); +const error = require('../utils/error'); +const mergeDefaults = require('../utils/mergeDefaults'); /** Validate a book.json content @@ -13,8 +13,8 @@ var mergeDefaults = require('../utils/mergeDefaults'); @return {Object} */ function validateConfig(bookJson) { - var v = new jsonschema.Validator(); - var result = v.validate(bookJson, schema, { + const v = new jsonschema.Validator(); + const result = v.validate(bookJson, schema, { propertyName: 'config' }); @@ -24,7 +24,7 @@ function validateConfig(bookJson) { } // Insert default values - var defaults = jsonSchemaDefaults(schema); + const defaults = jsonSchemaDefaults(schema); return mergeDefaults(bookJson, defaults); } diff --git a/packages/gitbook/lib/parse/walkSummary.js b/packages/gitbook/src/parse/walkSummary.js index 0117752..47feb1f 100644 --- a/packages/gitbook/lib/parse/walkSummary.js +++ b/packages/gitbook/src/parse/walkSummary.js @@ -1,4 +1,4 @@ -var Promise = require('../utils/promise'); +const Promise = require('../utils/promise'); /** Walk over a list of articles @@ -24,7 +24,7 @@ function walkArticles(articles, fn) { @return {Promise} */ function walkSummary(summary, fn) { - var parts = summary.getParts(); + const parts = summary.getParts(); return Promise.forEach(parts, function(part) { return walkArticles(part.getArticles(), fn); diff --git a/packages/gitbook/lib/parsers.js b/packages/gitbook/src/parsers.js index 70e44f4..62c3776 100644 --- a/packages/gitbook/lib/parsers.js +++ b/packages/gitbook/src/parsers.js @@ -1,15 +1,15 @@ -var path = require('path'); -var Immutable = require('immutable'); +const path = require('path'); +const Immutable = require('immutable'); -var markdownParser = require('gitbook-markdown'); -var asciidocParser = require('gitbook-asciidoc'); +const markdownParser = require('gitbook-markdown'); +const asciidocParser = require('gitbook-asciidoc'); -var EXTENSIONS_MARKDOWN = require('./constants/extsMarkdown'); -var EXTENSIONS_ASCIIDOC = require('./constants/extsAsciidoc'); -var Parser = require('./models/parser'); +const EXTENSIONS_MARKDOWN = require('./constants/extsMarkdown'); +const EXTENSIONS_ASCIIDOC = require('./constants/extsAsciidoc'); +const Parser = require('./models/parser'); // This list is ordered by priority of parsers to use -var parsers = Immutable.List([ +const parsers = Immutable.List([ Parser.create('markdown', EXTENSIONS_MARKDOWN, markdownParser), Parser.create('asciidoc', EXTENSIONS_ASCIIDOC, asciidocParser) ]); @@ -49,14 +49,14 @@ function getParserForFile(filename) { } // List all parsable extensions -var extensions = parsers +const extensions = parsers .map(function(parser) { return parser.getExtensions(); }) .flatten(); module.exports = { - extensions: extensions, + extensions, get: getParser, getByExt: getParserByExt, getForFile: getParserForFile diff --git a/packages/gitbook/lib/plugins/__tests__/findForBook.js b/packages/gitbook/src/plugins/__tests__/findForBook.js index d8af2e9..41df77e 100644 --- a/packages/gitbook/lib/plugins/__tests__/findForBook.js +++ b/packages/gitbook/src/plugins/__tests__/findForBook.js @@ -1,14 +1,14 @@ -var path = require('path'); +const path = require('path'); -var Book = require('../../models/book'); -var createNodeFS = require('../../fs/node'); -var findForBook = require('../findForBook'); +const Book = require('../../models/book'); +const createNodeFS = require('../../fs/node'); +const findForBook = require('../findForBook'); describe('findForBook', function() { - var fs = createNodeFS( + const fs = createNodeFS( path.resolve(__dirname, '../../..') ); - var book = Book.createForFS(fs); + const book = Book.createForFS(fs); it('should list default plugins', function() { return findForBook(book) diff --git a/packages/gitbook/lib/plugins/__tests__/findInstalled.js b/packages/gitbook/src/plugins/__tests__/findInstalled.js index 9377190..dcaa62b 100644 --- a/packages/gitbook/lib/plugins/__tests__/findInstalled.js +++ b/packages/gitbook/src/plugins/__tests__/findInstalled.js @@ -1,13 +1,13 @@ -var path = require('path'); -var Immutable = require('immutable'); +const path = require('path'); +const Immutable = require('immutable'); describe('findInstalled', function() { - var findInstalled = require('../findInstalled'); + const findInstalled = require('../findInstalled'); it('must list default plugins for gitbook directory', function() { // Read gitbook-plugins from package.json - var pkg = require(path.resolve(__dirname, '../../../package.json')); - var gitbookPlugins = Immutable.Seq(pkg.dependencies) + const pkg = require(path.resolve(__dirname, '../../../package.json')); + const gitbookPlugins = Immutable.Seq(pkg.dependencies) .filter(function(v, k) { return k.indexOf('gitbook-plugin') === 0; }) diff --git a/packages/gitbook/src/plugins/__tests__/installPlugin.js b/packages/gitbook/src/plugins/__tests__/installPlugin.js new file mode 100644 index 0000000..1a8debe --- /dev/null +++ b/packages/gitbook/src/plugins/__tests__/installPlugin.js @@ -0,0 +1,29 @@ +const path = require('path'); + +const PluginDependency = require('../../models/pluginDependency'); +const Book = require('../../models/book'); +const NodeFS = require('../../fs/node'); +const installPlugin = require('../installPlugin'); + +const Parse = require('../../parse'); + +describe('installPlugin', function() { + let book; + + this.timeout(30000); + + before(function() { + const fs = NodeFS(path.resolve(__dirname, '../../../')); + const baseBook = Book.createForFS(fs); + + return Parse.parseConfig(baseBook) + .then(function(_book) { + book = _book; + }); + }); + + it('must install a plugin from NPM', function() { + const dep = PluginDependency.createFromString('ga'); + return installPlugin(book, dep); + }); +}); diff --git a/packages/gitbook/lib/plugins/__tests__/installPlugins.js b/packages/gitbook/src/plugins/__tests__/installPlugins.js index 1a66f90..b6bb1f4 100644 --- a/packages/gitbook/lib/plugins/__tests__/installPlugins.js +++ b/packages/gitbook/src/plugins/__tests__/installPlugins.js @@ -1,19 +1,19 @@ -var path = require('path'); +const path = require('path'); -var Book = require('../../models/book'); -var NodeFS = require('../../fs/node'); -var installPlugins = require('../installPlugins'); +const Book = require('../../models/book'); +const NodeFS = require('../../fs/node'); +const installPlugins = require('../installPlugins'); -var Parse = require('../../parse'); +const Parse = require('../../parse'); describe('installPlugins', function() { - var book; + let book; this.timeout(30000); before(function() { - var fs = NodeFS(path.resolve(__dirname, '../../../')); - var baseBook = Book.createForFS(fs); + const fs = NodeFS(path.resolve(__dirname, '../../../')); + const baseBook = Book.createForFS(fs); return Parse.parseConfig(baseBook) .then(function(_book) { diff --git a/packages/gitbook/lib/plugins/__tests__/listDependencies.js b/packages/gitbook/src/plugins/__tests__/listDependencies.js index 940faba..d30e46c 100644 --- a/packages/gitbook/lib/plugins/__tests__/listDependencies.js +++ b/packages/gitbook/src/plugins/__tests__/listDependencies.js @@ -1,12 +1,12 @@ -var PluginDependency = require('../../models/pluginDependency'); -var listDependencies = require('../listDependencies'); -var toNames = require('../toNames'); +const PluginDependency = require('../../models/pluginDependency'); +const listDependencies = require('../listDependencies'); +const toNames = require('../toNames'); describe('listDependencies', function() { it('must list default', function() { - var deps = PluginDependency.listFromString('ga,great'); - var plugins = listDependencies(deps); - var names = toNames(plugins); + const deps = PluginDependency.listFromString('ga,great'); + const plugins = listDependencies(deps); + const names = toNames(plugins); expect(names).toEqual([ 'ga', 'great', @@ -15,9 +15,9 @@ describe('listDependencies', function() { }); it('must list from array with -', function() { - var deps = PluginDependency.listFromString('ga,-great'); - var plugins = listDependencies(deps); - var names = toNames(plugins); + const deps = PluginDependency.listFromString('ga,-great'); + const plugins = listDependencies(deps); + const names = toNames(plugins); expect(names).toEqual([ 'ga', @@ -26,9 +26,9 @@ describe('listDependencies', function() { }); it('must remove default plugins using -', function() { - var deps = PluginDependency.listFromString('ga,-search'); - var plugins = listDependencies(deps); - var names = toNames(plugins); + const deps = PluginDependency.listFromString('ga,-search'); + const plugins = listDependencies(deps); + const names = toNames(plugins); expect(names).toEqual([ 'ga', diff --git a/packages/gitbook/lib/plugins/__tests__/locateRootFolder.js b/packages/gitbook/src/plugins/__tests__/locateRootFolder.js index bb414a3..54e095b 100644 --- a/packages/gitbook/lib/plugins/__tests__/locateRootFolder.js +++ b/packages/gitbook/src/plugins/__tests__/locateRootFolder.js @@ -1,5 +1,5 @@ -var path = require('path'); -var locateRootFolder = require('../locateRootFolder'); +const path = require('path'); +const locateRootFolder = require('../locateRootFolder'); describe('locateRootFolder', function() { it('should correctly resolve the node_modules for gitbook', function() { diff --git a/packages/gitbook/lib/plugins/__tests__/resolveVersion.js b/packages/gitbook/src/plugins/__tests__/resolveVersion.js index 1877c9e..949d078 100644 --- a/packages/gitbook/lib/plugins/__tests__/resolveVersion.js +++ b/packages/gitbook/src/plugins/__tests__/resolveVersion.js @@ -1,9 +1,9 @@ -var PluginDependency = require('../../models/pluginDependency'); -var resolveVersion = require('../resolveVersion'); +const PluginDependency = require('../../models/pluginDependency'); +const resolveVersion = require('../resolveVersion'); describe('resolveVersion', function() { it('must skip resolving and return non-semver versions', function() { - var plugin = PluginDependency.createFromString('ga@git+ssh://samy@github.com/GitbookIO/plugin-ga.git'); + const plugin = PluginDependency.createFromString('ga@git+ssh://samy@github.com/GitbookIO/plugin-ga.git'); return resolveVersion(plugin) .then(function(version) { @@ -12,7 +12,7 @@ describe('resolveVersion', function() { }); it('must resolve a normal plugin dependency', function() { - var plugin = PluginDependency.createFromString('ga@>0.9.0 < 1.0.1'); + const plugin = PluginDependency.createFromString('ga@>0.9.0 < 1.0.1'); return resolveVersion(plugin) .then(function(version) { diff --git a/packages/gitbook/lib/plugins/__tests__/sortDependencies.js b/packages/gitbook/src/plugins/__tests__/sortDependencies.js index 87df477..a08d59d 100644 --- a/packages/gitbook/lib/plugins/__tests__/sortDependencies.js +++ b/packages/gitbook/src/plugins/__tests__/sortDependencies.js @@ -1,17 +1,17 @@ -var PluginDependency = require('../../models/pluginDependency'); -var sortDependencies = require('../sortDependencies'); -var toNames = require('../toNames'); +const PluginDependency = require('../../models/pluginDependency'); +const sortDependencies = require('../sortDependencies'); +const toNames = require('../toNames'); describe('sortDependencies', function() { it('must load themes after plugins', function() { - var allPlugins = PluginDependency.listFromArray([ + const allPlugins = PluginDependency.listFromArray([ 'hello', 'theme-test', 'world' ]); - var sorted = sortDependencies(allPlugins); - var names = toNames(sorted); + const sorted = sortDependencies(allPlugins); + const names = toNames(sorted); expect(names).toEqual([ 'hello', @@ -21,15 +21,15 @@ describe('sortDependencies', function() { }); it('must keep order of themes', function() { - var allPlugins = PluginDependency.listFromArray([ + const allPlugins = PluginDependency.listFromArray([ 'theme-test', 'theme-test1', 'hello', 'theme-test2', 'world' ]); - var sorted = sortDependencies(allPlugins); - var names = toNames(sorted); + const sorted = sortDependencies(allPlugins); + const names = toNames(sorted); expect(names).toEqual([ 'hello', @@ -39,4 +39,4 @@ describe('sortDependencies', function() { 'theme-test2' ]); }); -});
\ No newline at end of file +}); diff --git a/packages/gitbook/lib/plugins/__tests__/validatePlugin.js b/packages/gitbook/src/plugins/__tests__/validatePlugin.js index 635423c..a2bd23b 100644 --- a/packages/gitbook/lib/plugins/__tests__/validatePlugin.js +++ b/packages/gitbook/src/plugins/__tests__/validatePlugin.js @@ -1,10 +1,10 @@ -var Promise = require('../../utils/promise'); -var Plugin = require('../../models/plugin'); -var validatePlugin = require('../validatePlugin'); +const Promise = require('../../utils/promise'); +const Plugin = require('../../models/plugin'); +const validatePlugin = require('../validatePlugin'); describe('validatePlugin', function() { it('must not validate a not loaded plugin', function() { - var plugin = Plugin.createFromString('test'); + const plugin = Plugin.createFromString('test'); return validatePlugin(plugin) .then(function() { diff --git a/packages/gitbook/lib/plugins/findForBook.js b/packages/gitbook/src/plugins/findForBook.js index be2ad9f..b72d526 100644 --- a/packages/gitbook/lib/plugins/findForBook.js +++ b/packages/gitbook/src/plugins/findForBook.js @@ -1,9 +1,9 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var Promise = require('../utils/promise'); -var timing = require('../utils/timing'); -var findInstalled = require('./findInstalled'); -var locateRootFolder = require('./locateRootFolder'); +const Promise = require('../utils/promise'); +const timing = require('../utils/timing'); +const findInstalled = require('./findInstalled'); +const locateRootFolder = require('./locateRootFolder'); /** * List all plugins installed in a book diff --git a/packages/gitbook/lib/plugins/findInstalled.js b/packages/gitbook/src/plugins/findInstalled.js index 06cc6c4..15556b6 100644 --- a/packages/gitbook/lib/plugins/findInstalled.js +++ b/packages/gitbook/src/plugins/findInstalled.js @@ -1,11 +1,11 @@ -var readInstalled = require('read-installed'); -var Immutable = require('immutable'); -var path = require('path'); +const readInstalled = require('read-installed'); +const Immutable = require('immutable'); +const path = require('path'); -var Promise = require('../utils/promise'); -var fs = require('../utils/fs'); -var Plugin = require('../models/plugin'); -var PREFIX = require('../constants/pluginPrefix'); +const Promise = require('../utils/promise'); +const fs = require('../utils/fs'); +const Plugin = require('../models/plugin'); +const PREFIX = require('../constants/pluginPrefix'); /** * Validate if a package name is a GitBook plugin @@ -24,33 +24,33 @@ function validateId(name) { * @return {OrderedMap<String:Plugin>} */ function findInstalled(folder) { - var options = { + const options = { dev: false, - log: function() {}, + log() {}, depth: 4 }; - var results = Immutable.OrderedMap(); + let results = Immutable.OrderedMap(); function onPackage(pkg, parent) { if (!pkg.name) return; - var name = pkg.name; - var version = pkg.version; - var pkgPath = pkg.realPath; - var depth = pkg.depth; - var dependencies = pkg.dependencies; + const name = pkg.name; + const version = pkg.version; + const pkgPath = pkg.realPath; + const depth = pkg.depth; + const dependencies = pkg.dependencies; - var pluginName = name.slice(PREFIX.length); + const pluginName = name.slice(PREFIX.length); - if (!validateId(name)){ + if (!validateId(name)) { if (parent) return; } else { results = results.set(pluginName, Plugin({ name: pluginName, - version: version, + version, path: pkgPath, - depth: depth, - parent: parent + depth, + parent })); } @@ -60,7 +60,7 @@ function findInstalled(folder) { } // Search for gitbook-plugins in node_modules folder - var node_modules = path.join(folder, 'node_modules'); + const node_modules = path.join(folder, 'node_modules'); // List all folders in node_modules return fs.readdir(node_modules) @@ -75,7 +75,7 @@ function findInstalled(folder) { } // Read gitbook-plugin package details - var module_folder = path.join(node_modules, module); + const module_folder = path.join(node_modules, module); return Promise.nfcall(readInstalled, module_folder, options) .then(function(data) { onPackage(data); diff --git a/packages/gitbook/lib/plugins/index.js b/packages/gitbook/src/plugins/index.js index 607a7f1..607a7f1 100644 --- a/packages/gitbook/lib/plugins/index.js +++ b/packages/gitbook/src/plugins/index.js diff --git a/packages/gitbook/lib/plugins/installPlugin.js b/packages/gitbook/src/plugins/installPlugin.js index 37852df..edf4dc5 100644 --- a/packages/gitbook/lib/plugins/installPlugin.js +++ b/packages/gitbook/src/plugins/installPlugin.js @@ -1,7 +1,7 @@ -var npmi = require('npmi'); +const npmi = require('npmi'); -var Promise = require('../utils/promise'); -var resolveVersion = require('./resolveVersion'); +const Promise = require('../utils/promise'); +const resolveVersion = require('./resolveVersion'); /** Install a plugin for a book @@ -11,11 +11,11 @@ var resolveVersion = require('./resolveVersion'); @return {Promise} */ function installPlugin(book, plugin) { - var logger = book.getLogger(); + const logger = book.getLogger(); - var installFolder = book.getRoot(); - var name = plugin.getName(); - var requirement = plugin.getVersion(); + const installFolder = book.getRoot(); + const name = plugin.getName(); + const requirement = plugin.getVersion(); logger.info.ln(''); logger.info.ln('installing plugin "' + name + '"'); @@ -27,10 +27,10 @@ function installPlugin(book, plugin) { throw new Error('Found no satisfactory version for plugin "' + name + '" with requirement "' + requirement + '"'); } - logger.info.ln('install plugin "' + name +'" (' + requirement + ') from NPM with version', version); + logger.info.ln('install plugin "' + name + '" (' + requirement + ') from NPM with version', version); return Promise.nfcall(npmi, { 'name': plugin.getNpmID(), - 'version': version, + version, 'path': installFolder, 'npmLoad': { 'loglevel': 'silent', diff --git a/packages/gitbook/lib/plugins/installPlugins.js b/packages/gitbook/src/plugins/installPlugins.js index 307c41e..8c36c92 100644 --- a/packages/gitbook/lib/plugins/installPlugins.js +++ b/packages/gitbook/src/plugins/installPlugins.js @@ -1,8 +1,8 @@ -var npmi = require('npmi'); +const npmi = require('npmi'); -var DEFAULT_PLUGINS = require('../constants/defaultPlugins'); -var Promise = require('../utils/promise'); -var installPlugin = require('./installPlugin'); +const DEFAULT_PLUGINS = require('../constants/defaultPlugins'); +const Promise = require('../utils/promise'); +const installPlugin = require('./installPlugin'); /** Install plugin requirements for a book @@ -11,14 +11,14 @@ var installPlugin = require('./installPlugin'); @return {Promise<Number>} */ function installPlugins(book) { - var logger = book.getLogger(); - var config = book.getConfig(); - var plugins = config.getPluginDependencies(); + const logger = book.getLogger(); + const config = book.getConfig(); + let plugins = config.getPluginDependencies(); // Remove default plugins // (only if version is same as installed) plugins = plugins.filterNot(function(plugin) { - var dependency = DEFAULT_PLUGINS.find(function(dep) { + const dependency = DEFAULT_PLUGINS.find(function(dep) { return dep.getName() === plugin.getName(); }); diff --git a/packages/gitbook/lib/plugins/listBlocks.js b/packages/gitbook/src/plugins/listBlocks.js index 3ac28af..991b386 100644 --- a/packages/gitbook/lib/plugins/listBlocks.js +++ b/packages/gitbook/src/plugins/listBlocks.js @@ -1,4 +1,4 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); /** List blocks from a list of plugins @@ -10,7 +10,7 @@ function listBlocks(plugins) { return plugins .reverse() .reduce(function(result, plugin) { - var blocks = plugin.getBlocks(); + const blocks = plugin.getBlocks(); return result.merge(blocks); }, Immutable.Map()); } diff --git a/packages/gitbook/lib/plugins/listDependencies.js b/packages/gitbook/src/plugins/listDependencies.js index d52eaa9..3930ae7 100644 --- a/packages/gitbook/lib/plugins/listDependencies.js +++ b/packages/gitbook/src/plugins/listDependencies.js @@ -1,5 +1,5 @@ -var DEFAULT_PLUGINS = require('../constants/defaultPlugins'); -var sortDependencies = require('./sortDependencies'); +const DEFAULT_PLUGINS = require('../constants/defaultPlugins'); +const sortDependencies = require('./sortDependencies'); /** * List all dependencies for a book, including default plugins. @@ -10,7 +10,7 @@ var sortDependencies = require('./sortDependencies'); */ function listDependencies(deps) { // Extract list of plugins to disable (starting with -) - var toRemove = deps + const toRemove = deps .filter(function(plugin) { return !plugin.isEnabled(); }) diff --git a/packages/gitbook/lib/plugins/listDepsForBook.js b/packages/gitbook/src/plugins/listDepsForBook.js index 196e3aa..b173572 100644 --- a/packages/gitbook/lib/plugins/listDepsForBook.js +++ b/packages/gitbook/src/plugins/listDepsForBook.js @@ -1,4 +1,4 @@ -var listDependencies = require('./listDependencies'); +const listDependencies = require('./listDependencies'); /** * List all plugin requirements for a book. @@ -9,8 +9,8 @@ var listDependencies = require('./listDependencies'); * @return {List<PluginDependency>} */ function listDepsForBook(book) { - var config = book.getConfig(); - var plugins = config.getPluginDependencies(); + const config = book.getConfig(); + const plugins = config.getPluginDependencies(); return listDependencies(plugins); } diff --git a/packages/gitbook/lib/plugins/listFilters.js b/packages/gitbook/src/plugins/listFilters.js index 4d8a471..edf6c0d 100644 --- a/packages/gitbook/lib/plugins/listFilters.js +++ b/packages/gitbook/src/plugins/listFilters.js @@ -1,4 +1,4 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); /** List filters from a list of plugins diff --git a/packages/gitbook/lib/plugins/listResources.js b/packages/gitbook/src/plugins/listResources.js index fe31b5a..df50097 100644 --- a/packages/gitbook/lib/plugins/listResources.js +++ b/packages/gitbook/src/plugins/listResources.js @@ -1,8 +1,8 @@ -var Immutable = require('immutable'); -var path = require('path'); +const Immutable = require('immutable'); +const path = require('path'); -var LocationUtils = require('../utils/location'); -var PLUGIN_RESOURCES = require('../constants/pluginResources'); +const LocationUtils = require('../utils/location'); +const PLUGIN_RESOURCES = require('../constants/pluginResources'); /** List all resources from a list of plugins @@ -13,14 +13,14 @@ var PLUGIN_RESOURCES = require('../constants/pluginResources'); */ function listResources(plugins, resources) { return plugins.reduce(function(result, plugin) { - var npmId = plugin.getNpmID(); - var pluginResources = resources.get(plugin.getName()); + const npmId = plugin.getNpmID(); + const pluginResources = resources.get(plugin.getName()); PLUGIN_RESOURCES.forEach(function(resourceType) { - var assets = pluginResources.get(resourceType); + let assets = pluginResources.get(resourceType); if (!assets) return; - var list = result.get(resourceType) || Immutable.List(); + let list = result.get(resourceType) || Immutable.List(); assets = assets.map(function(assetFile) { if (LocationUtils.isExternal(assetFile)) { diff --git a/packages/gitbook/lib/plugins/loadForBook.js b/packages/gitbook/src/plugins/loadForBook.js index 757677e..0baa78e 100644 --- a/packages/gitbook/lib/plugins/loadForBook.js +++ b/packages/gitbook/src/plugins/loadForBook.js @@ -1,9 +1,9 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var Promise = require('../utils/promise'); -var listDepsForBook = require('./listDepsForBook'); -var findForBook = require('./findForBook'); -var loadPlugin = require('./loadPlugin'); +const Promise = require('../utils/promise'); +const listDepsForBook = require('./listDepsForBook'); +const findForBook = require('./findForBook'); +const loadPlugin = require('./loadPlugin'); /** @@ -13,21 +13,21 @@ var loadPlugin = require('./loadPlugin'); * @return {Promise<Map<String:Plugin>} */ function loadForBook(book) { - var logger = book.getLogger(); + const logger = book.getLogger(); // List the dependencies - var requirements = listDepsForBook(book); + const requirements = listDepsForBook(book); // List all plugins installed in the book return findForBook(book) .then(function(installedMap) { - var missing = []; - var plugins = requirements.reduce(function(result, dep) { - var name = dep.getName(); - var installed = installedMap.get(name); + const missing = []; + let plugins = requirements.reduce(function(result, dep) { + const name = dep.getName(); + const installed = installedMap.get(name); if (installed) { - var deps = installedMap + const deps = installedMap .filter(function(plugin) { return plugin.getParent() === name; }) diff --git a/packages/gitbook/lib/plugins/loadPlugin.js b/packages/gitbook/src/plugins/loadPlugin.js index 9ed83a1..4a349e2 100644 --- a/packages/gitbook/lib/plugins/loadPlugin.js +++ b/packages/gitbook/src/plugins/loadPlugin.js @@ -1,12 +1,12 @@ -var path = require('path'); -var resolve = require('resolve'); -var Immutable = require('immutable'); +const path = require('path'); +const resolve = require('resolve'); +const Immutable = require('immutable'); -var Promise = require('../utils/promise'); -var error = require('../utils/error'); -var timing = require('../utils/timing'); +const Promise = require('../utils/promise'); +const error = require('../utils/error'); +const timing = require('../utils/timing'); -var validatePlugin = require('./validatePlugin'); +const validatePlugin = require('./validatePlugin'); // Return true if an error is a "module not found" // Wait on https://github.com/substack/node-resolve/pull/81 to be merged @@ -23,21 +23,21 @@ function isModuleNotFound(err) { @return {Promise<Plugin>} */ function loadPlugin(book, plugin) { - var logger = book.getLogger(); + const logger = book.getLogger(); - var name = plugin.getName(); - var pkgPath = plugin.getPath(); + const name = plugin.getName(); + let pkgPath = plugin.getPath(); // Try loading plugins from different location - var p = Promise() + let p = Promise() .then(function() { - var packageContent; - var packageMain; - var content; + let packageContent; + let packageMain; + let content; // Locate plugin and load package.json try { - var res = resolve.sync('./package.json', { basedir: pkgPath }); + const res = resolve.sync('./package.json', { basedir: pkgPath }); pkgPath = path.dirname(res); packageContent = require(res); @@ -52,7 +52,7 @@ function loadPlugin(book, plugin) { // Locate the main package try { - var indexJs = path.normalize(packageContent.main || 'index.js'); + const indexJs = path.normalize(packageContent.main || 'index.js'); packageMain = resolve.sync('./' + indexJs, { basedir: pkgPath }); } catch (err) { if (!isModuleNotFound(err)) throw err; @@ -63,7 +63,7 @@ function loadPlugin(book, plugin) { if (packageMain) { try { content = require(packageMain); - } catch(err) { + } catch (err) { throw new error.PluginError(err, { plugin: name }); diff --git a/packages/gitbook/src/plugins/locateRootFolder.js b/packages/gitbook/src/plugins/locateRootFolder.js new file mode 100644 index 0000000..64e06a8 --- /dev/null +++ b/packages/gitbook/src/plugins/locateRootFolder.js @@ -0,0 +1,22 @@ +const path = require('path'); +const resolve = require('resolve'); + +const DEFAULT_PLUGINS = require('../constants/defaultPlugins'); + +/** + * Resolve the root folder containing for node_modules + * since gitbook can be used as a library and dependency can be flattened. + * + * @return {String} folderPath + */ +function locateRootFolder() { + const firstDefaultPlugin = DEFAULT_PLUGINS.first(); + const pluginPath = resolve.sync(firstDefaultPlugin.getNpmID() + '/package.json', { + basedir: __dirname + }); + const nodeModules = path.resolve(pluginPath, '../../..'); + + return nodeModules; +} + +module.exports = locateRootFolder; diff --git a/packages/gitbook/lib/plugins/resolveVersion.js b/packages/gitbook/src/plugins/resolveVersion.js index 61aef8d..07b771e 100644 --- a/packages/gitbook/lib/plugins/resolveVersion.js +++ b/packages/gitbook/src/plugins/resolveVersion.js @@ -1,12 +1,12 @@ -var npm = require('npm'); -var semver = require('semver'); -var Immutable = require('immutable'); +const npm = require('npm'); +const semver = require('semver'); +const Immutable = require('immutable'); -var Promise = require('../utils/promise'); -var Plugin = require('../models/plugin'); -var gitbook = require('../gitbook'); +const Promise = require('../utils/promise'); +const Plugin = require('../models/plugin'); +const gitbook = require('../gitbook'); -var npmIsReady; +let npmIsReady; /** Initialize and prepare NPM @@ -31,8 +31,8 @@ function initNPM() { @return {Promise<String>} */ function resolveVersion(plugin) { - var npmId = Plugin.nameToNpmID(plugin.getName()); - var requiredVersion = plugin.getVersion(); + const npmId = Plugin.nameToNpmID(plugin.getName()); + const requiredVersion = plugin.getVersion(); if (plugin.isGitDependency()) { return Promise.resolve(requiredVersion); @@ -45,7 +45,7 @@ function resolveVersion(plugin) { .then(function(versions) { versions = Immutable.Map(versions).entrySeq(); - var result = versions + const result = versions .map(function(entry) { return { version: entry[0], @@ -56,7 +56,7 @@ function resolveVersion(plugin) { return v.gitbook && gitbook.satisfies(v.gitbook); }) .sort(function(v1, v2) { - return semver.lt(v1.version, v2.version)? 1 : -1; + return semver.lt(v1.version, v2.version) ? 1 : -1; }) .get(0); diff --git a/packages/gitbook/lib/plugins/sortDependencies.js b/packages/gitbook/src/plugins/sortDependencies.js index 7f10095..2adfa20 100644 --- a/packages/gitbook/lib/plugins/sortDependencies.js +++ b/packages/gitbook/src/plugins/sortDependencies.js @@ -1,9 +1,9 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var THEME_PREFIX = require('../constants/themePrefix'); +const THEME_PREFIX = require('../constants/themePrefix'); -var TYPE_PLUGIN = 'plugin'; -var TYPE_THEME = 'theme'; +const TYPE_PLUGIN = 'plugin'; +const TYPE_THEME = 'theme'; /** @@ -12,7 +12,7 @@ var TYPE_THEME = 'theme'; * @return {String} */ function pluginType(plugin) { - var name = plugin.getName(); + const name = plugin.getName(); return (name && name.indexOf(THEME_PREFIX) === 0) ? TYPE_THEME : TYPE_PLUGIN; } @@ -25,10 +25,10 @@ function pluginType(plugin) { * @return {List<PluginDependency>} */ function sortDependencies(plugins) { - var byTypes = plugins.groupBy(pluginType); + const byTypes = plugins.groupBy(pluginType); return byTypes.get(TYPE_PLUGIN, Immutable.List()) .concat(byTypes.get(TYPE_THEME, Immutable.List())); } -module.exports = sortDependencies;
\ No newline at end of file +module.exports = sortDependencies; diff --git a/packages/gitbook/lib/plugins/toNames.js b/packages/gitbook/src/plugins/toNames.js index ad0dd8f..ad0dd8f 100644 --- a/packages/gitbook/lib/plugins/toNames.js +++ b/packages/gitbook/src/plugins/toNames.js diff --git a/packages/gitbook/lib/plugins/validateConfig.js b/packages/gitbook/src/plugins/validateConfig.js index fab1fef..8e24775 100644 --- a/packages/gitbook/lib/plugins/validateConfig.js +++ b/packages/gitbook/src/plugins/validateConfig.js @@ -1,10 +1,10 @@ -var Immutable = require('immutable'); -var jsonschema = require('jsonschema'); -var jsonSchemaDefaults = require('json-schema-defaults'); +const Immutable = require('immutable'); +const jsonschema = require('jsonschema'); +const jsonSchemaDefaults = require('json-schema-defaults'); -var Promise = require('../utils/promise'); -var error = require('../utils/error'); -var mergeDefaults = require('../utils/mergeDefaults'); +const Promise = require('../utils/promise'); +const error = require('../utils/error'); +const mergeDefaults = require('../utils/mergeDefaults'); /** Validate one plugin for a book and update book's confiration @@ -14,17 +14,17 @@ var mergeDefaults = require('../utils/mergeDefaults'); @return {Book} */ function validatePluginConfig(book, plugin) { - var config = book.getConfig(); - var packageInfos = plugin.getPackage(); + let config = book.getConfig(); + const packageInfos = plugin.getPackage(); - var configKey = [ + const configKey = [ 'pluginsConfig', plugin.getName() ].join('.'); - var pluginConfig = config.getValue(configKey, {}).toJS(); + let pluginConfig = config.getValue(configKey, {}).toJS(); - var schema = (packageInfos.get('gitbook') || Immutable.Map()).toJS(); + const schema = (packageInfos.get('gitbook') || Immutable.Map()).toJS(); if (!schema) return book; // Normalize schema @@ -32,8 +32,8 @@ function validatePluginConfig(book, plugin) { schema.type = 'object'; // Validate and throw if invalid - var v = new jsonschema.Validator(); - var result = v.validate(pluginConfig, schema, { + const v = new jsonschema.Validator(); + const result = v.validate(pluginConfig, schema, { propertyName: configKey }); @@ -43,7 +43,7 @@ function validatePluginConfig(book, plugin) { } // Insert default values - var defaults = jsonSchemaDefaults(schema); + const defaults = jsonSchemaDefaults(schema); pluginConfig = mergeDefaults(pluginConfig, defaults); diff --git a/packages/gitbook/lib/plugins/validatePlugin.js b/packages/gitbook/src/plugins/validatePlugin.js index 4baa911..f0e96ba 100644 --- a/packages/gitbook/lib/plugins/validatePlugin.js +++ b/packages/gitbook/src/plugins/validatePlugin.js @@ -1,6 +1,6 @@ -var gitbook = require('../gitbook'); +const gitbook = require('../gitbook'); -var Promise = require('../utils/promise'); +const Promise = require('../utils/promise'); /** Validate a plugin @@ -9,9 +9,9 @@ var Promise = require('../utils/promise'); @return {Promise<Plugin>} */ function validatePlugin(plugin) { - var packageInfos = plugin.getPackage(); + const packageInfos = plugin.getPackage(); - var isValid = ( + const isValid = ( plugin.isLoaded() && packageInfos && packageInfos.get('name') && @@ -23,7 +23,7 @@ function validatePlugin(plugin) { return Promise.reject(new Error('Error loading plugin "' + plugin.getName() + '" at "' + plugin.getPath() + '"')); } - var engine = packageInfos.get('engines').get('gitbook'); + const engine = packageInfos.get('engines').get('gitbook'); if (!gitbook.satisfies(engine)) { return Promise.reject(new Error('GitBook doesn\'t satisfy the requirements of this plugin: ' + engine)); } diff --git a/packages/gitbook/lib/templating/__tests__/conrefsLoader.js b/packages/gitbook/src/templating/__tests__/conrefsLoader.js index 196b513..431d0a3 100644 --- a/packages/gitbook/lib/templating/__tests__/conrefsLoader.js +++ b/packages/gitbook/src/templating/__tests__/conrefsLoader.js @@ -1,15 +1,15 @@ -var path = require('path'); +const path = require('path'); -var TemplateEngine = require('../../models/templateEngine'); -var renderTemplate = require('../render'); -var ConrefsLoader = require('../conrefsLoader'); +const TemplateEngine = require('../../models/templateEngine'); +const renderTemplate = require('../render'); +const ConrefsLoader = require('../conrefsLoader'); describe('ConrefsLoader', function() { - var dirName = __dirname + '/'; - var fileName = path.join(dirName, 'test.md'); + const dirName = __dirname + '/'; + const fileName = path.join(dirName, 'test.md'); describe('Git', function() { - var engine = TemplateEngine({ + const engine = TemplateEngine({ loader: new ConrefsLoader(dirName) }); @@ -36,7 +36,7 @@ describe('ConrefsLoader', function() { }); describe('Local', function() { - var engine = TemplateEngine({ + const engine = TemplateEngine({ loader: new ConrefsLoader(dirName) }); @@ -83,7 +83,7 @@ describe('ConrefsLoader', function() { return 'test-' + source + '-endtest'; } - var engine = TemplateEngine({ + const engine = TemplateEngine({ loader: new ConrefsLoader(dirName, transform) }); diff --git a/packages/gitbook/lib/templating/__tests__/include.md b/packages/gitbook/src/templating/__tests__/include.md index 5e1c309..5e1c309 100644 --- a/packages/gitbook/lib/templating/__tests__/include.md +++ b/packages/gitbook/src/templating/__tests__/include.md diff --git a/packages/gitbook/lib/templating/__tests__/postRender.js b/packages/gitbook/src/templating/__tests__/postRender.js index 131e29b..ff5bb61 100644 --- a/packages/gitbook/lib/templating/__tests__/postRender.js +++ b/packages/gitbook/src/templating/__tests__/postRender.js @@ -1,12 +1,12 @@ -var TemplateEngine = require('../../models/templateEngine'); -var TemplateBlock = require('../../models/templateBlock'); +const TemplateEngine = require('../../models/templateEngine'); +const TemplateBlock = require('../../models/templateBlock'); -var renderTemplate = require('../render'); -var postRender = require('../postRender'); +const renderTemplate = require('../render'); +const postRender = require('../postRender'); describe('postRender', function() { - var testPost; - var engine = TemplateEngine.create({ + let testPost; + const engine = TemplateEngine.create({ blocks: [ TemplateBlock.create('lower', function(blk) { return blk.body.toLowerCase(); @@ -14,7 +14,7 @@ describe('postRender', function() { TemplateBlock.create('prefix', function(blk) { return { body: '_' + blk.body + '_', - post: function() { + post() { testPost = true; } }; diff --git a/packages/gitbook/lib/templating/__tests__/replaceShortcuts.js b/packages/gitbook/src/templating/__tests__/replaceShortcuts.js index 216a1c8..cfd18b5 100644 --- a/packages/gitbook/lib/templating/__tests__/replaceShortcuts.js +++ b/packages/gitbook/src/templating/__tests__/replaceShortcuts.js @@ -1,10 +1,10 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); -var TemplateBlock = require('../../models/templateBlock'); -var replaceShortcuts = require('../replaceShortcuts'); +const TemplateBlock = require('../../models/templateBlock'); +const replaceShortcuts = require('../replaceShortcuts'); describe('replaceShortcuts', function() { - var blocks = Immutable.List([ + const blocks = Immutable.List([ TemplateBlock.create('math', { shortcuts: { start: '$$', @@ -15,12 +15,12 @@ describe('replaceShortcuts', function() { ]); it('should correctly replace inline matches by block', function() { - var content = replaceShortcuts(blocks, 'test.md', 'Hello $$a = b$$'); + const content = replaceShortcuts(blocks, 'test.md', 'Hello $$a = b$$'); expect(content).toBe('Hello {% math %}a = b{% endmath %}'); }); it('should correctly replace block matches', function() { - var content = replaceShortcuts(blocks, 'test.md', 'Hello\n$$\na = b\n$$\n'); + const content = replaceShortcuts(blocks, 'test.md', 'Hello\n$$\na = b\n$$\n'); expect(content).toBe('Hello\n{% math %}\na = b\n{% endmath %}\n'); }); }); diff --git a/packages/gitbook/lib/templating/conrefsLoader.js b/packages/gitbook/src/templating/conrefsLoader.js index b3cdb3f..4024a19 100644 --- a/packages/gitbook/lib/templating/conrefsLoader.js +++ b/packages/gitbook/src/templating/conrefsLoader.js @@ -1,10 +1,10 @@ -var path = require('path'); -var nunjucks = require('nunjucks'); +const path = require('path'); +const nunjucks = require('nunjucks'); -var fs = require('../utils/fs'); -var Git = require('../utils/git'); -var LocationUtils = require('../utils/location'); -var PathUtils = require('../utils/path'); +const fs = require('../utils/fs'); +const Git = require('../utils/git'); +const LocationUtils = require('../utils/location'); +const PathUtils = require('../utils/path'); /** @@ -17,18 +17,18 @@ var PathUtils = require('../utils/path'); * @param {Function(filePath, source)} transformFn (optional) * @param {Logger} logger (optional) */ -var ConrefsLoader = nunjucks.Loader.extend({ +const ConrefsLoader = nunjucks.Loader.extend({ async: true, - init: function(rootFolder, transformFn, logger) { + init(rootFolder, transformFn, logger) { this.rootFolder = rootFolder; this.transformFn = transformFn; this.logger = logger; this.git = new Git(); }, - getSource: function(sourceURL, callback) { - var that = this; + getSource(sourceURL, callback) { + const that = this; this.git.resolve(sourceURL) .then(function(filepath) { @@ -60,22 +60,22 @@ var ConrefsLoader = nunjucks.Loader.extend({ .nodeify(callback); }, - resolve: function(from, to) { + resolve(from, to) { // If origin is in the book, we enforce result file to be in the book if (PathUtils.isInRoot(this.rootFolder, from)) { // Path of current template in the rootFolder (not absolute to fs) - var fromRelative = path.relative(this.rootFolder, from); + const fromRelative = path.relative(this.rootFolder, from); // Resolve "to" to a filepath relative to rootFolder - var href = LocationUtils.toAbsolute(to, path.dirname(fromRelative), ''); + const href = LocationUtils.toAbsolute(to, path.dirname(fromRelative), ''); // Return absolute path return PathUtils.resolveInRoot(this.rootFolder, href); } // If origin is in a git repository, we resolve file in the git repository - var gitRoot = this.git.resolveRoot(from); + const gitRoot = this.git.resolveRoot(from); if (gitRoot) { return PathUtils.resolveInRoot(gitRoot, to); } @@ -85,7 +85,7 @@ var ConrefsLoader = nunjucks.Loader.extend({ }, // Handle all files as relative, so that nunjucks pass responsability to 'resolve' - isRelative: function(filename) { + isRelative(filename) { return LocationUtils.isRelative(filename); } }); diff --git a/packages/gitbook/lib/templating/index.js b/packages/gitbook/src/templating/index.js index bd74aca..bd74aca 100644 --- a/packages/gitbook/lib/templating/index.js +++ b/packages/gitbook/src/templating/index.js diff --git a/packages/gitbook/lib/templating/listShortcuts.js b/packages/gitbook/src/templating/listShortcuts.js index 8d0a64a..5df88bb 100644 --- a/packages/gitbook/lib/templating/listShortcuts.js +++ b/packages/gitbook/src/templating/listShortcuts.js @@ -1,5 +1,5 @@ -var Immutable = require('immutable'); -var parsers = require('../parsers'); +const Immutable = require('immutable'); +const parsers = require('../parsers'); /** * Return a list of all shortcuts that can apply @@ -10,7 +10,7 @@ var parsers = require('../parsers'); * @return {List<TemplateShortcut>} */ function listShortcuts(blocks, filePath) { - var parser = parsers.getForFile(filePath); + const parser = parsers.getForFile(filePath); if (!parser) { return Immutable.List(); diff --git a/packages/gitbook/lib/templating/postRender.js b/packages/gitbook/src/templating/postRender.js index f464f86..7fdfbf4 100644 --- a/packages/gitbook/lib/templating/postRender.js +++ b/packages/gitbook/src/templating/postRender.js @@ -1,4 +1,4 @@ -var Promise = require('../utils/promise'); +const Promise = require('../utils/promise'); /** @@ -9,10 +9,10 @@ var Promise = require('../utils/promise'); * @return {Object} {blocks: Set, content: String} */ function replaceBlocks(content, blocks) { - var newContent = content.replace(/\{\{\-\%([\s\S]+?)\%\-\}\}/g, function(match, key) { - var replacedWith = match; + const newContent = content.replace(/\{\{\-\%([\s\S]+?)\%\-\}\}/g, function(match, key) { + let replacedWith = match; - var block = blocks.get(key); + const block = blocks.get(key); if (block) { replacedWith = replaceBlocks(block.get('body'), blocks); } @@ -33,13 +33,13 @@ function replaceBlocks(content, blocks) { * @return {Promise<String>} */ function postRender(engine, output) { - var content = output.getContent(); - var blocks = output.getBlocks(); + const content = output.getContent(); + const blocks = output.getBlocks(); - var result = replaceBlocks(content, blocks); + const result = replaceBlocks(content, blocks); return Promise.forEach(blocks, function(block) { - var post = block.get('post'); + const post = block.get('post'); if (!post) { return; diff --git a/packages/gitbook/lib/templating/render.js b/packages/gitbook/src/templating/render.js index 1a8b0cd..53ed546 100644 --- a/packages/gitbook/lib/templating/render.js +++ b/packages/gitbook/src/templating/render.js @@ -1,7 +1,7 @@ -var Promise = require('../utils/promise'); -var timing = require('../utils/timing'); -var TemplateOutput = require('../models/templateOutput'); -var replaceShortcuts = require('./replaceShortcuts'); +const Promise = require('../utils/promise'); +const timing = require('../utils/timing'); +const TemplateOutput = require('../models/templateOutput'); +const replaceShortcuts = require('./replaceShortcuts'); /** * Render a template @@ -16,10 +16,10 @@ function renderTemplate(engine, filePath, content, context) { context = context || {}; // Mutable objects to contains all blocks requiring post-processing - var blocks = {}; + const blocks = {}; // Create nunjucks environment - var env = engine.toNunjucks(blocks); + const env = engine.toNunjucks(blocks); // Replace shortcuts from plugin's blocks content = replaceShortcuts(engine.getBlocks(), filePath, content); diff --git a/packages/gitbook/lib/templating/renderFile.js b/packages/gitbook/src/templating/renderFile.js index 8672e8b..a2463f8 100644 --- a/packages/gitbook/lib/templating/renderFile.js +++ b/packages/gitbook/src/templating/renderFile.js @@ -1,6 +1,6 @@ -var Promise = require('../utils/promise'); -var error = require('../utils/error'); -var render = require('./render'); +const Promise = require('../utils/promise'); +const error = require('../utils/error'); +const render = require('./render'); /** * Render a template @@ -11,10 +11,10 @@ var render = require('./render'); * @return {Promise<TemplateOutput>} */ function renderTemplateFile(engine, filePath, context) { - var loader = engine.getLoader(); + const loader = engine.getLoader(); // Resolve the filePath - var resolvedFilePath = loader.resolve(null, filePath); + const resolvedFilePath = loader.resolve(null, filePath); return Promise() .then(function() { @@ -22,7 +22,7 @@ function renderTemplateFile(engine, filePath, context) { return loader.getSource(resolvedFilePath); } - var deferred = Promise.defer(); + const deferred = Promise.defer(); loader.getSource(resolvedFilePath, deferred.makeNodeResolver()); return deferred.promise; }) diff --git a/packages/gitbook/lib/templating/replaceShortcuts.js b/packages/gitbook/src/templating/replaceShortcuts.js index 1cfdbf0..25f598f 100644 --- a/packages/gitbook/lib/templating/replaceShortcuts.js +++ b/packages/gitbook/src/templating/replaceShortcuts.js @@ -1,5 +1,5 @@ -var escapeStringRegexp = require('escape-string-regexp'); -var listShortcuts = require('./listShortcuts'); +const escapeStringRegexp = require('escape-string-regexp'); +const listShortcuts = require('./listShortcuts'); /** * Apply a shortcut of block to a template @@ -8,13 +8,13 @@ var listShortcuts = require('./listShortcuts'); * @return {String} */ function applyShortcut(content, shortcut) { - var start = shortcut.getStart(); - var end = shortcut.getEnd(); + const start = shortcut.getStart(); + const end = shortcut.getEnd(); - var tagStart = shortcut.getStartTag(); - var tagEnd = shortcut.getEndTag(); + const tagStart = shortcut.getStartTag(); + const tagEnd = shortcut.getEndTag(); - var regex = new RegExp( + const regex = new RegExp( escapeStringRegexp(start) + '([\\s\\S]*?[^\\$])' + escapeStringRegexp(end), 'g' ); @@ -32,7 +32,7 @@ function applyShortcut(content, shortcut) { * @return {String} */ function replaceShortcuts(blocks, filePath, content) { - var shortcuts = listShortcuts(blocks, filePath); + const shortcuts = listShortcuts(blocks, filePath); return shortcuts.reduce(applyShortcut, content); } diff --git a/packages/gitbook/lib/templating/themesLoader.js b/packages/gitbook/src/templating/themesLoader.js index bae4c12..b1639c5 100644 --- a/packages/gitbook/lib/templating/themesLoader.js +++ b/packages/gitbook/src/templating/themesLoader.js @@ -1,13 +1,13 @@ -var Immutable = require('immutable'); -var nunjucks = require('nunjucks'); -var fs = require('fs'); -var path = require('path'); +const Immutable = require('immutable'); +const nunjucks = require('nunjucks'); +const fs = require('fs'); +const path = require('path'); -var PathUtils = require('../utils/path'); +const PathUtils = require('../utils/path'); -var ThemesLoader = nunjucks.Loader.extend({ - init: function(searchPaths) { +const ThemesLoader = nunjucks.Loader.extend({ + init(searchPaths) { this.searchPaths = Immutable.List(searchPaths) .map(path.normalize); }, @@ -17,24 +17,24 @@ var ThemesLoader = nunjucks.Loader.extend({ * @param {String} * @return {Object} */ - getSource: function(fullpath) { + getSource(fullpath) { if (!fullpath) return null; fullpath = this.resolve(null, fullpath); - var templateName = this.getTemplateName(fullpath); + const templateName = this.getTemplateName(fullpath); - if(!fullpath) { + if (!fullpath) { return null; } - var src = fs.readFileSync(fullpath, 'utf-8'); + let src = fs.readFileSync(fullpath, 'utf-8'); src = '{% do %}var template = template || {}; template.stack = template.stack || []; template.stack.push(template.self); template.self = ' + JSON.stringify(templateName) + '{% enddo %}\n' + src + '\n{% do %}template.self = template.stack.pop();{% enddo %}'; return { - src: src, + src, path: fullpath, noCache: true }; @@ -44,7 +44,7 @@ var ThemesLoader = nunjucks.Loader.extend({ * Nunjucks calls "isRelative" to determine when to call "resolve". * We handle absolute paths ourselves in ".resolve" so we always return true */ - isRelative: function() { + isRelative() { return true; }, @@ -53,7 +53,7 @@ var ThemesLoader = nunjucks.Loader.extend({ * @param {String} filepath * @return {String} searchPath */ - getSearchPath: function(filepath) { + getSearchPath(filepath) { return this.searchPaths .sortBy(function(s) { return -s.length; @@ -68,9 +68,9 @@ var ThemesLoader = nunjucks.Loader.extend({ * @param {String} filepath * @return {String} name */ - getTemplateName: function(filepath) { - var originalSearchPath = this.getSearchPath(filepath); - return originalSearchPath? path.relative(originalSearchPath, filepath) : null; + getTemplateName(filepath) { + const originalSearchPath = this.getSearchPath(filepath); + return originalSearchPath ? path.relative(originalSearchPath, filepath) : null; }, /** @@ -79,8 +79,8 @@ var ThemesLoader = nunjucks.Loader.extend({ * @param {String} to * @return {String|null} */ - resolve: function(from, to) { - var searchPaths = this.searchPaths; + resolve(from, to) { + let searchPaths = this.searchPaths; // Relative template like "./test.html" if (PathUtils.isPureRelative(to) && from) { @@ -88,19 +88,19 @@ var ThemesLoader = nunjucks.Loader.extend({ } // Determine in which search folder we currently are - var originalSearchPath = this.getSearchPath(from); - var originalFilename = this.getTemplateName(from); + const originalSearchPath = this.getSearchPath(from); + const originalFilename = this.getTemplateName(from); // If we are including same file from a different search path // Slice the search paths to avoid including from previous ones if (originalFilename == to) { - var currentIndex = searchPaths.indexOf(originalSearchPath); + const currentIndex = searchPaths.indexOf(originalSearchPath); searchPaths = searchPaths.slice(currentIndex + 1); } // Absolute template to resolve in root folder - var resultFolder = searchPaths.find(function(basePath) { - var p = path.resolve(basePath, to); + const resultFolder = searchPaths.find(function(basePath) { + const p = path.resolve(basePath, to); return ( p.indexOf(basePath) === 0 diff --git a/packages/gitbook/lib/utils/__tests__/git.js b/packages/gitbook/src/utils/__tests__/git.js index abc1ea1..445b8eb 100644 --- a/packages/gitbook/lib/utils/__tests__/git.js +++ b/packages/gitbook/src/utils/__tests__/git.js @@ -1,7 +1,7 @@ -var path = require('path'); -var os = require('os'); +const path = require('path'); +const os = require('os'); -var Git = require('../git'); +const Git = require('../git'); describe('Git', function() { @@ -20,7 +20,7 @@ describe('Git', function() { }); it('should parse HTTPS urls', function() { - var parts = Git.parseUrl('git+https://gist.github.com/69ea4542e4c8967d2fa7.git/test.md'); + const parts = Git.parseUrl('git+https://gist.github.com/69ea4542e4c8967d2fa7.git/test.md'); expect(parts.host).toBe('https://gist.github.com/69ea4542e4c8967d2fa7.git'); expect(parts.ref).toBe(null); @@ -28,7 +28,7 @@ describe('Git', function() { }); it('should parse HTTPS urls with a reference', function() { - var parts = Git.parseUrl('git+https://gist.github.com/69ea4542e4c8967d2fa7.git/test.md#1.0.0'); + const parts = Git.parseUrl('git+https://gist.github.com/69ea4542e4c8967d2fa7.git/test.md#1.0.0'); expect(parts.host).toBe('https://gist.github.com/69ea4542e4c8967d2fa7.git'); expect(parts.ref).toBe('1.0.0'); @@ -36,7 +36,7 @@ describe('Git', function() { }); it('should parse SSH urls', function() { - var parts = Git.parseUrl('git+git@github.com:GitbookIO/gitbook.git/directory/README.md#e1594cde2c32e4ff48f6c4eff3d3d461743d74e1'); + const parts = Git.parseUrl('git+git@github.com:GitbookIO/gitbook.git/directory/README.md#e1594cde2c32e4ff48f6c4eff3d3d461743d74e1'); expect(parts.host).toBe('git@github.com:GitbookIO/gitbook.git'); expect(parts.ref).toBe('e1594cde2c32e4ff48f6c4eff3d3d461743d74e1'); @@ -46,7 +46,7 @@ describe('Git', function() { describe('Cloning and resolving', function() { it('should clone an HTTPS url', function() { - var git = new Git(path.join(os.tmpdir(), 'test-git-'+Date.now())); + const git = new Git(path.join(os.tmpdir(), 'test-git-' + Date.now())); return git.resolve('git+https://gist.github.com/69ea4542e4c8967d2fa7.git/test.md') .then(function(filename) { expect(path.extname(filename)).toBe('.md'); diff --git a/packages/gitbook/lib/utils/__tests__/location.js b/packages/gitbook/src/utils/__tests__/location.js index 822338e..a565adb 100644 --- a/packages/gitbook/lib/utils/__tests__/location.js +++ b/packages/gitbook/src/utils/__tests__/location.js @@ -1,4 +1,4 @@ -var LocationUtils = require('../location'); +const LocationUtils = require('../location'); describe('LocationUtils', function() { it('should correctly test external location', function() { @@ -97,4 +97,3 @@ describe('LocationUtils', function() { }); - diff --git a/packages/gitbook/lib/utils/__tests__/path.js b/packages/gitbook/src/utils/__tests__/path.js index 22bb016..1f8a1d3 100644 --- a/packages/gitbook/lib/utils/__tests__/path.js +++ b/packages/gitbook/src/utils/__tests__/path.js @@ -1,7 +1,7 @@ -var path = require('path'); +const path = require('path'); describe('Paths', function() { - var PathUtils = require('..//path'); + const PathUtils = require('..//path'); describe('setExtension', function() { it('should correctly change extension of filename', function() { diff --git a/packages/gitbook/lib/utils/command.js b/packages/gitbook/src/utils/command.js index 90a556e..efa9699 100644 --- a/packages/gitbook/lib/utils/command.js +++ b/packages/gitbook/src/utils/command.js @@ -1,7 +1,7 @@ -var is = require('is'); -var childProcess = require('child_process'); -var spawn = require('spawn-cmd').spawn; -var Promise = require('./promise'); +const is = require('is'); +const childProcess = require('child_process'); +const spawn = require('spawn-cmd').spawn; +const Promise = require('./promise'); /** Execute a command @@ -11,9 +11,9 @@ var Promise = require('./promise'); @return {Promise} */ function exec(command, options) { - var d = Promise.defer(); + const d = Promise.defer(); - var child = childProcess.exec(command, options, function(err, stdout, stderr) { + const child = childProcess.exec(command, options, function(err, stdout, stderr) { if (!err) { return d.resolve(); } @@ -22,11 +22,11 @@ function exec(command, options) { d.reject(err); }); - child.stdout.on('data', function (data) { + child.stdout.on('data', function(data) { d.notify(data); }); - child.stderr.on('data', function (data) { + child.stderr.on('data', function(data) { d.notify(data); }); @@ -42,18 +42,18 @@ function exec(command, options) { @return {Promise} */ function spawnCmd(command, args, options) { - var d = Promise.defer(); - var child = spawn(command, args, options); + const d = Promise.defer(); + const child = spawn(command, args, options); child.on('error', function(error) { return d.reject(error); }); - child.stdout.on('data', function (data) { + child.stdout.on('data', function(data) { d.notify(data); }); - child.stderr.on('data', function (data) { + child.stderr.on('data', function(data) { d.notify(data); }); @@ -61,7 +61,7 @@ function spawnCmd(command, args, options) { if (code === 0) { d.resolve(); } else { - d.reject(new Error('Error with command "'+command+'"')); + d.reject(new Error('Error with command "' + command + '"')); } }); @@ -92,10 +92,10 @@ function escapeShellArg(value) { @return {String} */ function optionsToShellArgs(options) { - var result = []; + const result = []; - for (var key in options) { - var value = options[key]; + for (const key in options) { + const value = options[key]; if (value === null || value === undefined || value === false) { continue; @@ -112,7 +112,7 @@ function optionsToShellArgs(options) { } module.exports = { - exec: exec, + exec, spawn: spawnCmd, - optionsToShellArgs: optionsToShellArgs + optionsToShellArgs }; diff --git a/packages/gitbook/lib/utils/error.js b/packages/gitbook/src/utils/error.js index 7686779..925b5ff 100644 --- a/packages/gitbook/lib/utils/error.js +++ b/packages/gitbook/src/utils/error.js @@ -1,7 +1,7 @@ -var is = require('is'); +const is = require('is'); -var TypedError = require('error/typed'); -var WrappedError = require('error/wrapped'); +const TypedError = require('error/typed'); +const WrappedError = require('error/wrapped'); // Enforce as an Error object, and cleanup message @@ -13,31 +13,31 @@ function enforce(err) { } // Random error wrappers during parsing/generation -var ParsingError = WrappedError({ +const ParsingError = WrappedError({ message: 'Parsing Error: {origMessage}', type: 'parse' }); -var OutputError = WrappedError({ +const OutputError = WrappedError({ message: 'Output Error: {origMessage}', type: 'generate' }); // A file does not exists -var FileNotFoundError = TypedError({ +const FileNotFoundError = TypedError({ type: 'file.not-found', message: 'No "{filename}" file (or is ignored)', filename: null }); // A file cannot be parsed -var FileNotParsableError = TypedError({ +const FileNotParsableError = TypedError({ type: 'file.not-parsable', message: '"{filename}" file cannot be parsed', filename: null }); // A file is outside the scope -var FileOutOfScopeError = TypedError({ +const FileOutOfScopeError = TypedError({ type: 'file.out-of-scope', message: '"{filename}" not in "{root}"', filename: null, @@ -46,7 +46,7 @@ var FileOutOfScopeError = TypedError({ }); // A file is outside the scope -var RequireInstallError = TypedError({ +const RequireInstallError = TypedError({ type: 'install.required', message: '"{cmd}" is not installed.\n{install}', cmd: null, @@ -55,45 +55,45 @@ var RequireInstallError = TypedError({ }); // Error for nunjucks templates -var TemplateError = WrappedError({ +const TemplateError = WrappedError({ message: 'Error compiling template "{filename}": {origMessage}', type: 'template', filename: null }); // Error for nunjucks templates -var PluginError = WrappedError({ +const PluginError = WrappedError({ message: 'Error with plugin "{plugin}": {origMessage}', type: 'plugin', plugin: null }); // Error with the book's configuration -var ConfigurationError = WrappedError({ +const ConfigurationError = WrappedError({ message: 'Error with book\'s configuration: {origMessage}', type: 'configuration' }); // Error during ebook generation -var EbookError = WrappedError({ +const EbookError = WrappedError({ message: 'Error during ebook generation: {origMessage}\n{stdout}', type: 'ebook', stdout: '' }); module.exports = { - enforce: enforce, + enforce, - ParsingError: ParsingError, - OutputError: OutputError, - RequireInstallError: RequireInstallError, + ParsingError, + OutputError, + RequireInstallError, - FileNotParsableError: FileNotParsableError, - FileNotFoundError: FileNotFoundError, - FileOutOfScopeError: FileOutOfScopeError, + FileNotParsableError, + FileNotFoundError, + FileOutOfScopeError, - TemplateError: TemplateError, - PluginError: PluginError, - ConfigurationError: ConfigurationError, - EbookError: EbookError + TemplateError, + PluginError, + ConfigurationError, + EbookError }; diff --git a/packages/gitbook/lib/utils/fs.js b/packages/gitbook/src/utils/fs.js index 35839a3..17b2ebb 100644 --- a/packages/gitbook/lib/utils/fs.js +++ b/packages/gitbook/src/utils/fs.js @@ -1,30 +1,30 @@ -var fs = require('graceful-fs'); -var mkdirp = require('mkdirp'); -var destroy = require('destroy'); -var rmdir = require('rmdir'); -var tmp = require('tmp'); -var request = require('request'); -var path = require('path'); -var cp = require('cp'); -var cpr = require('cpr'); - -var Promise = require('./promise'); +const fs = require('graceful-fs'); +const mkdirp = require('mkdirp'); +const destroy = require('destroy'); +const rmdir = require('rmdir'); +const tmp = require('tmp'); +const request = require('request'); +const path = require('path'); +const cp = require('cp'); +const cpr = require('cpr'); + +const Promise = require('./promise'); // Write a stream to a file function writeStream(filename, st) { - var d = Promise.defer(); + const d = Promise.defer(); - var wstream = fs.createWriteStream(filename); - var cleanup = function() { + const wstream = fs.createWriteStream(filename); + const cleanup = function() { destroy(wstream); wstream.removeAllListeners(); }; - wstream.on('finish', function () { + wstream.on('finish', function() { cleanup(); d.resolve(); }); - wstream.on('error', function (err) { + wstream.on('error', function(err) { cleanup(); d.reject(err); }); @@ -41,7 +41,7 @@ function writeStream(filename, st) { // Return a promise resolved with a boolean function fileExists(filename) { - var d = Promise.defer(); + const d = Promise.defer(); fs.exists(filename, function(exists) { d.resolve(exists); @@ -69,13 +69,13 @@ function download(uri, dest) { // Find a filename available in a folder function uniqueFilename(base, filename) { - var ext = path.extname(filename); + const ext = path.extname(filename); filename = path.resolve(base, filename); filename = path.join(path.dirname(filename), path.basename(filename, ext)); - var _filename = filename+ext; + let _filename = filename + ext; - var i = 0; + let i = 0; while (fs.existsSync(filename)) { _filename = filename + '_' + i + ext; i = i + 1; @@ -86,14 +86,14 @@ function uniqueFilename(base, filename) { // Create all required folder to create a file function ensureFile(filename) { - var base = path.dirname(filename); + const base = path.dirname(filename); return Promise.nfcall(mkdirp, base); } // Remove a folder function rmDir(base) { return Promise.nfcall(rmdir, base, { - fs: fs + fs }); } @@ -121,7 +121,7 @@ function assertFile(filePath, generator) { @return {String} */ function pickFile(rootFolder, fileName) { - var result = path.join(rootFolder, fileName); + const result = path.join(rootFolder, fileName); if (fs.existsSync(result)) { return result; } @@ -151,20 +151,20 @@ module.exports = { mkdirp: Promise.nfbind(mkdirp), readFile: Promise.nfbind(fs.readFile), writeFile: Promise.nfbind(fs.writeFile), - assertFile: assertFile, - pickFile: pickFile, + assertFile, + pickFile, stat: Promise.nfbind(fs.stat), statSync: fs.statSync, readdir: Promise.nfbind(fs.readdir), - writeStream: writeStream, + writeStream, readStream: fs.createReadStream, copy: Promise.nfbind(cp), copyDir: Promise.nfbind(cpr), tmpFile: genTmpFile, tmpDir: genTmpDir, - download: download, - uniqueFilename: uniqueFilename, - ensureFile: ensureFile, - ensureFolder: ensureFolder, - rmDir: rmDir + download, + uniqueFilename, + ensureFile, + ensureFolder, + rmDir }; diff --git a/packages/gitbook/lib/utils/genKey.js b/packages/gitbook/src/utils/genKey.js index 0650011..e4982f4 100644 --- a/packages/gitbook/lib/utils/genKey.js +++ b/packages/gitbook/src/utils/genKey.js @@ -1,4 +1,4 @@ -var lastKey = 0; +let lastKey = 0; /* Generate a random key @@ -6,7 +6,7 @@ var lastKey = 0; */ function generateKey() { lastKey += 1; - var str = lastKey.toString(16); + const str = lastKey.toString(16); return '00000'.slice(str.length) + str; } diff --git a/packages/gitbook/src/utils/git.js b/packages/gitbook/src/utils/git.js new file mode 100644 index 0000000..8ec23dd --- /dev/null +++ b/packages/gitbook/src/utils/git.js @@ -0,0 +1,135 @@ +const is = require('is'); +const path = require('path'); +const crc = require('crc'); +const URI = require('urijs'); + +const pathUtil = require('./path'); +const Promise = require('./promise'); +const command = require('./command'); +const fs = require('./fs'); + +const GIT_PREFIX = 'git+'; + +class Git { + constructor() { + this.tmpDir = null; + this.cloned = {}; + } + + // Return an unique ID for a combinaison host/ref + repoID(host, ref) { + return crc.crc32(host + '#' + (ref || '')).toString(16); + } + + // Allocate a temporary folder for cloning repos in it + allocateDir() { + const that = this; + + if (this.tmpDir) return Promise(); + + return fs.tmpDir() + .then(function(dir) { + that.tmpDir = dir; + }); + } + + // Clone a git repository if non existant + clone(host, ref) { + const that = this; + + return this.allocateDir() + + // Return or clone the git repo + .then(function() { + // Unique ID for repo/ref combinaison + const repoId = that.repoID(host, ref); + + // Absolute path to the folder + const repoPath = path.join(that.tmpDir, repoId); + + if (that.cloned[repoId]) return repoPath; + + // Clone repo + return command.exec('git clone ' + host + ' ' + repoPath) + + // Checkout reference if specified + .then(function() { + that.cloned[repoId] = true; + + if (!ref) return; + return command.exec('git checkout ' + ref, { cwd: repoPath }); + }) + .thenResolve(repoPath); + }); + } + + // Get file from a git repo + resolve(giturl) { + // Path to a file in a git repo? + if (!Git.isUrl(giturl)) { + if (this.resolveRoot(giturl)) return Promise(giturl); + return Promise(null); + } + if (is.string(giturl)) giturl = Git.parseUrl(giturl); + if (!giturl) return Promise(null); + + // Clone or get from cache + return this.clone(giturl.host, giturl.ref) + .then(function(repo) { + return path.resolve(repo, giturl.filepath); + }); + } + + // Return root of git repo from a filepath + resolveRoot(filepath) { + // No git repo cloned, or file is not in a git repository + if (!this.tmpDir || !pathUtil.isInRoot(this.tmpDir, filepath)) return null; + + // Extract first directory (is the repo id) + const relativeToGit = path.relative(this.tmpDir, filepath); + const repoId = relativeToGit.split(path.sep)[0]; + + if (!repoId) { + return; + } + + // Return an absolute file + return path.resolve(this.tmpDir, repoId); + } + + // Check if an url is a git dependency url + static isUrl(giturl) { + return (giturl.indexOf(GIT_PREFIX) === 0); + } + + // Parse and extract infos + static parseUrl(giturl) { + if (!Git.isUrl(giturl)) { + return null; + } + giturl = giturl.slice(GIT_PREFIX.length); + + const uri = new URI(giturl); + const ref = uri.fragment() || null; + uri.fragment(null); + + // Extract file inside the repo (after the .git) + const fileParts = uri.path().split('.git'); + let filepath = fileParts.length > 1 ? fileParts.slice(1).join('.git') : ''; + if (filepath[0] == '/') { + filepath = filepath.slice(1); + } + + // Recreate pathname without the real filename + uri.path(fileParts[0] + '.git'); + + return { + host: uri.toString(), + ref, + filepath + }; + } + +} + +module.exports = Git; diff --git a/packages/gitbook/lib/utils/images.js b/packages/gitbook/src/utils/images.js index 6d4b927..808be63 100644 --- a/packages/gitbook/lib/utils/images.js +++ b/packages/gitbook/src/utils/images.js @@ -1,7 +1,7 @@ -var Promise = require('./promise'); -var command = require('./command'); -var fs = require('./fs'); -var error = require('./error'); +const Promise = require('./promise'); +const command = require('./command'); +const fs = require('./fs'); +const error = require('./error'); // Convert a svg file to a pmg function convertSVGToPNG(source, dest, options) { @@ -20,7 +20,7 @@ function convertSVGToPNG(source, dest, options) { .then(function() { if (fs.existsSync(dest)) return; - throw new Error('Error converting '+source+' into '+dest); + throw new Error('Error converting ' + source + ' into ' + dest); }); } @@ -42,19 +42,19 @@ function convertSVGBufferToPNG(buf, dest) { function convertInlinePNG(source, dest) { if (!/^data\:image\/png/.test(source)) return Promise.reject(new Error('Source is not a PNG data-uri')); - var base64data = source.split('data:image/png;base64,')[1]; - var buf = new Buffer(base64data, 'base64'); + const base64data = source.split('data:image/png;base64,')[1]; + const buf = new Buffer(base64data, 'base64'); return fs.writeFile(dest, buf) .then(function() { if (fs.existsSync(dest)) return; - throw new Error('Error converting '+source+' into '+dest); + throw new Error('Error converting ' + source + ' into ' + dest); }); } module.exports = { - convertSVGToPNG: convertSVGToPNG, - convertSVGBufferToPNG: convertSVGBufferToPNG, - convertInlinePNG: convertInlinePNG -};
\ No newline at end of file + convertSVGToPNG, + convertSVGBufferToPNG, + convertInlinePNG +}; diff --git a/packages/gitbook/lib/utils/location.js b/packages/gitbook/src/utils/location.js index 00d8004..6dc41ba 100644 --- a/packages/gitbook/lib/utils/location.js +++ b/packages/gitbook/src/utils/location.js @@ -1,11 +1,11 @@ -var url = require('url'); -var path = require('path'); +const url = require('url'); +const path = require('path'); // Is the url an external url function isExternal(href) { try { return Boolean(url.parse(href).protocol) && !isDataURI(href); - } catch(err) { + } catch (err) { return false; } } @@ -14,7 +14,7 @@ function isExternal(href) { function isDataURI(href) { try { return Boolean(url.parse(href).protocol) && (url.parse(href).protocol === 'data:'); - } catch(err) { + } catch (err) { return false; } } @@ -27,9 +27,9 @@ function isRelative(href) { // Return true if the link is an achor function isAnchor(href) { try { - var parsed = url.parse(href); + const parsed = url.parse(href); return !!(!parsed.protocol && !parsed.path && parsed.hash); - } catch(err) { + } catch (err) { return false; } } @@ -67,14 +67,14 @@ function toAbsolute(_href, dir, outdir) { return _href; } - outdir = outdir == undefined? dir : outdir; + outdir = outdir == undefined ? dir : outdir; _href = normalize(_href); dir = normalize(dir); outdir = normalize(outdir); // Path "_href" inside the base folder - var hrefInRoot = normalize(path.join(dir, _href)); + let hrefInRoot = normalize(path.join(dir, _href)); if (_href[0] == '/') { hrefInRoot = normalize(_href.slice(1)); } @@ -97,8 +97,8 @@ function toAbsolute(_href, dir, outdir) { * @return {String} */ function relative(dir, file) { - var isDirectory = file.slice(-1) === '/'; - return normalize(path.relative(dir, file)) + (isDirectory? '/': ''); + const isDirectory = file.slice(-1) === '/'; + return normalize(path.relative(dir, file)) + (isDirectory ? '/' : ''); } /** @@ -126,14 +126,14 @@ function areIdenticalPaths(p1, p2) { } module.exports = { - areIdenticalPaths: areIdenticalPaths, - isDataURI: isDataURI, - isExternal: isExternal, - isRelative: isRelative, - isAnchor: isAnchor, - normalize: normalize, - toAbsolute: toAbsolute, - relative: relative, - relativeForFile: relativeForFile, - flatten: flatten + areIdenticalPaths, + isDataURI, + isExternal, + isRelative, + isAnchor, + normalize, + toAbsolute, + relative, + relativeForFile, + flatten }; diff --git a/packages/gitbook/lib/utils/logger.js b/packages/gitbook/src/utils/logger.js index 6fac92b..25f8517 100644 --- a/packages/gitbook/lib/utils/logger.js +++ b/packages/gitbook/src/utils/logger.js @@ -1,9 +1,9 @@ -var is = require('is'); -var util = require('util'); -var color = require('bash-color'); -var Immutable = require('immutable'); +const is = require('is'); +const util = require('util'); +const color = require('bash-color'); +const Immutable = require('immutable'); -var LEVELS = Immutable.Map({ +const LEVELS = Immutable.Map({ DEBUG: 0, INFO: 1, WARN: 2, @@ -11,7 +11,7 @@ var LEVELS = Immutable.Map({ DISABLED: 10 }); -var COLORS = Immutable.Map({ +const COLORS = Immutable.Map({ DEBUG: color.purple, INFO: color.cyan, WARN: color.yellow, @@ -22,7 +22,7 @@ function Logger(write, logLevel) { if (!(this instanceof Logger)) return new Logger(write, logLevel); this._write = write || function(msg) { - if(process.stdout) { + if (process.stdout) { process.stdout.write(msg); } }; @@ -82,8 +82,8 @@ Logger.prototype.write = function(msg) { /** Format a string using the first argument as a printf-like format. */ -Logger.prototype.format = function() { - return util.format.apply(util, arguments); +Logger.prototype.format = function(...args) { + return util.format(...args); }; /** @@ -92,7 +92,7 @@ Logger.prototype.format = function() { @param {String} */ Logger.prototype.writeLn = function(msg) { - return this.write((msg || '')+'\n'); + return this.write((msg || '') + '\n'); }; /** @@ -100,17 +100,16 @@ Logger.prototype.writeLn = function(msg) { @param {Number} level */ -Logger.prototype.log = function(level) { +Logger.prototype.log = function(level, ...args) { if (level < this.logLevel) return; - var levelKey = LEVELS.findKey(function(v) { + const levelKey = LEVELS.findKey(function(v) { return v === level; }); - var args = Array.prototype.slice.apply(arguments, [1]); - var msg = this.format.apply(this, args); + let msg = this.format(...args); if (this.lastChar == '\n') { - msg = COLORS.get(levelKey)(levelKey.toLowerCase()+':')+' '+msg; + msg = COLORS.get(levelKey)(levelKey.toLowerCase() + ':') + ' ' + msg; } return this.write(msg); @@ -119,21 +118,20 @@ Logger.prototype.log = function(level) { /** Log/Print a line if level is allowed */ -Logger.prototype.logLn = function() { +Logger.prototype.logLn = function(...args) { if (this.lastChar != '\n') this.write('\n'); - var args = Array.prototype.slice.apply(arguments); args.push('\n'); - return this.log.apply(this, args); + return this.log(...args); }; /** Log a confirmation [OK] */ -Logger.prototype.ok = function(level) { - var args = Array.prototype.slice.apply(arguments, [1]); - var msg = this.format.apply(this, args); - if (arguments.length > 1) { +Logger.prototype.ok = function(level, ...args) { + const msg = this.format(...args); + + if (args.length > 0) { this.logLn(level, color.green('>> ') + msg.trim().replace(/\n/g, color.green('\n>> '))); } else { this.log(level, color.green('OK'), '\n'); @@ -155,10 +153,10 @@ Logger.prototype.fail = function(level) { @return {Promise} */ Logger.prototype.promise = function(level, p) { - var that = this; + const that = this; - return p. - then(function(st) { + return p + .then(function(st) { that.ok(level); return st; }, function(err) { diff --git a/packages/gitbook/lib/utils/mergeDefaults.js b/packages/gitbook/src/utils/mergeDefaults.js index 47a374b..b2e8c3d 100644 --- a/packages/gitbook/lib/utils/mergeDefaults.js +++ b/packages/gitbook/src/utils/mergeDefaults.js @@ -1,4 +1,4 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); /** * Merge @@ -7,8 +7,8 @@ var Immutable = require('immutable'); * @return {Object} */ function mergeDefaults(obj, src) { - var objValue = Immutable.fromJS(obj); - var srcValue = Immutable.fromJS(src); + const objValue = Immutable.fromJS(obj); + const srcValue = Immutable.fromJS(src); return srcValue.mergeDeep(objValue).toJS(); } diff --git a/packages/gitbook/lib/utils/path.js b/packages/gitbook/src/utils/path.js index 26b6005..01c2cbf 100644 --- a/packages/gitbook/lib/utils/path.js +++ b/packages/gitbook/src/utils/path.js @@ -1,5 +1,5 @@ -var path = require('path'); -var error = require('./error'); +const path = require('path'); +const error = require('./error'); // Normalize a filename function normalizePath(filename) { @@ -23,24 +23,21 @@ function isInRoot(root, filename) { // Resolve paths in a specific folder // Throw error if file is outside this folder -function resolveInRoot(root) { - var input, result; - var args = Array.prototype.slice.call(arguments, 1); - - input = args +function resolveInRoot(root, ...args) { + const input = args .reduce(function(current, p) { // Handle path relative to book root ("/README.md") if (p[0] == '/' || p[0] == '\\') return p.slice(1); - return current? path.join(current, p) : path.normalize(p); + return current ? path.join(current, p) : path.normalize(p); }, ''); - result = path.resolve(root, input); + const result = path.resolve(root, input); if (!isInRoot(root, result)) { throw new error.FileOutOfScopeError({ filename: result, - root: root + root }); } @@ -66,9 +63,9 @@ function isPureRelative(filename) { } module.exports = { - isInRoot: isInRoot, - resolveInRoot: resolveInRoot, + isInRoot, + resolveInRoot, normalize: normalizePath, - setExtension: setExtension, - isPureRelative: isPureRelative + setExtension, + isPureRelative }; diff --git a/packages/gitbook/lib/utils/promise.js b/packages/gitbook/src/utils/promise.js index b5cca4b..8cbbd47 100644 --- a/packages/gitbook/lib/utils/promise.js +++ b/packages/gitbook/src/utils/promise.js @@ -1,5 +1,5 @@ -var Q = require('q'); -var Immutable = require('immutable'); +const Q = require('q'); +const Immutable = require('immutable'); // Debugging for long stack traces if (process.env.DEBUG || process.env.CI) { @@ -14,7 +14,7 @@ if (process.env.DEBUG || process.env.CI) { * @return {Promise<Mixed>} */ function reduce(arr, iter, base) { - arr = Immutable.Iterable.isIterable(arr)? arr : Immutable.List(arr); + arr = Immutable.Iterable.isIterable(arr) ? arr : Immutable.List(arr); return arr.reduce(function(prev, elem, key) { return prev @@ -99,7 +99,7 @@ function mapAsList(arr, iter) { */ function map(arr, iter) { if (Immutable.Map.isMap(arr)) { - var type = 'Map'; + let type = 'Map'; if (Immutable.OrderedMap.isOrderedMap(arr)) { type = 'OrderedMap'; } @@ -129,12 +129,10 @@ function map(arr, iter) { * @return {Funciton} */ function wrap(func) { - return function() { - var args = Array.prototype.slice.call(arguments, 0); - + return function(...args) { return Q() .then(function() { - return func.apply(null, args); + return func(...args); }); }; } diff --git a/packages/gitbook/lib/utils/reducedObject.js b/packages/gitbook/src/utils/reducedObject.js index 7bcfd5b..196a72c 100644 --- a/packages/gitbook/lib/utils/reducedObject.js +++ b/packages/gitbook/src/utils/reducedObject.js @@ -1,4 +1,4 @@ -var Immutable = require('immutable'); +const Immutable = require('immutable'); /** * Reduce the difference between a map and its default version @@ -7,15 +7,15 @@ var Immutable = require('immutable'); * @return {Map} The properties of currentVersion that differs from defaultVersion */ function reducedObject(defaultVersion, currentVersion) { - if(defaultVersion === undefined) { + if (defaultVersion === undefined) { return currentVersion; } return currentVersion.reduce(function(result, value, key) { - var defaultValue = defaultVersion.get(key); + const defaultValue = defaultVersion.get(key); if (Immutable.Map.isMap(value)) { - var diffs = reducedObject(defaultValue, value); + const diffs = reducedObject(defaultValue, value); if (diffs.size > 0) { return result.set(key, diffs); diff --git a/packages/gitbook/lib/utils/timing.js b/packages/gitbook/src/utils/timing.js index e6b0323..1dce2a1 100644 --- a/packages/gitbook/lib/utils/timing.js +++ b/packages/gitbook/src/utils/timing.js @@ -1,8 +1,8 @@ -var Immutable = require('immutable'); -var is = require('is'); +const Immutable = require('immutable'); +const is = require('is'); -var timers = {}; -var startDate = Date.now(); +const timers = {}; +const startDate = Date.now(); /** Mesure an operation @@ -13,19 +13,19 @@ var startDate = Date.now(); */ function measure(type, p) { timers[type] = timers[type] || { - type: type, + type, count: 0, total: 0, min: undefined, max: 0 }; - var start = Date.now(); + const start = Date.now(); return p .fin(function() { - var end = Date.now(); - var duration = (end - start); + const end = Date.now(); + const duration = (end - start); timers[type].count ++; timers[type].total += duration; @@ -51,7 +51,7 @@ function time(ms) { return (ms.toFixed(0)) + 'ms'; } - return (ms/1000).toFixed(2) + 's'; + return (ms / 1000).toFixed(2) + 's'; } /** @@ -60,12 +60,12 @@ function time(ms) { @param {Logger} logger */ function dump(logger) { - var prefix = ' > '; - var measured = 0; - var totalDuration = Date.now() - startDate; + const prefix = ' > '; + let measured = 0; + const totalDuration = Date.now() - startDate; // Enable debug logging - var logLevel = logger.getLevel(); + const logLevel = logger.getLevel(); logger.setLevel('debug'); Immutable.Map(timers) @@ -75,11 +75,11 @@ function dump(logger) { return timer.total; }) .forEach(function(timer) { - var percent = (timer.total * 100) / totalDuration; + const percent = (timer.total * 100) / totalDuration; logger.debug.ln((percent.toFixed(1)) + '% of time spent in "' + timer.type + '" (' + timer.count + ' times) :'); - logger.debug.ln(prefix + 'Total: ' + time(timer.total)+ ' | Average: ' + time(timer.total / timer.count)); + logger.debug.ln(prefix + 'Total: ' + time(timer.total) + ' | Average: ' + time(timer.total / timer.count)); logger.debug.ln(prefix + 'Min: ' + time(timer.min) + ' | Max: ' + time(timer.max)); logger.debug.ln('---------------------------'); }); @@ -92,6 +92,6 @@ function dump(logger) { } module.exports = { - measure: measure, - dump: dump + measure, + dump }; |