From 928263e5c02bd3d820efd1548395c7c7510c2615 Mon Sep 17 00:00:00 2001 From: Eric Schneider <37347760+eric-schneider@users.noreply.github.com> Date: Thu, 22 Aug 2024 18:23:26 -0700 Subject: [PATCH] Update UI extensions for local preview --- lib/assets-processor.js | 24 +++++++++++ lib/tailwind-processor.js | 29 +++++++++---- lib/unlisted-pages-extension.js | 74 ++++++++++++++++----------------- local-preview-playbook.yml | 16 ++++++- package.json | 2 +- 5 files changed, 98 insertions(+), 47 deletions(-) create mode 100644 lib/assets-processor.js diff --git a/lib/assets-processor.js b/lib/assets-processor.js new file mode 100644 index 00000000..7d1e5e7f --- /dev/null +++ b/lib/assets-processor.js @@ -0,0 +1,24 @@ +"use strict"; + +module.exports.register = (context) => { + const logger = context.getLogger("assets-processor-extension"); + + context.once("uiLoaded", ({ uiCatalog }) => { + const manifestContents = uiCatalog + .findByType("asset") + .find((file) => file.stem === "assets-manifest") + .contents?.toString(); + if (!manifestContents) { + logger.error("Could not find assets-manifest.json in the UI bundle."); + return; + } + const manifest = JSON.parse(manifestContents); + // Add manifest to node global context so it can be accessed by the handlebars helper during createPageComposer + global.assetsManifest = manifest; + }); + + context.once("pagesComposed", () => { + // Clean up the global context + delete global.assetsManifest; + }); +}; diff --git a/lib/tailwind-processor.js b/lib/tailwind-processor.js index 894d1e8c..d88f1025 100644 --- a/lib/tailwind-processor.js +++ b/lib/tailwind-processor.js @@ -1,12 +1,25 @@ -'use strict' +"use strict"; -const { execSync } = require('child_process') +const { execSync } = require("child_process"); module.exports.register = (context) => { - context.once('sitePublished', () => { + context.once("sitePublished", ({ playbook }) => { const logger = context.getLogger('tailwind-processor-extension') - logger.info('Building Tailwind') - execSync('npm run tailwindcss', { stdio: 'inherit' }) - logger.info('Tailwind Build Successful') - }) -} + const outputDir = playbook?.output?.dir || "build/site"; + logger.info("Building Tailwind"); + var configPath = execSync(`find ${outputDir} -name tailwind.config.js`) + .toString() + .trim(); + var cssPath = execSync(`find ${outputDir} -name site*.css`) + .toString() + .trim(); + logger.info( + `npm run tailwindcss --tailwind-config-path=${configPath} --css-path=${cssPath}` + ); + execSync( + `npm run tailwindcss --tailwind-config-path=${configPath} --css-path=${cssPath}`, + { stdio: "inherit" } + ); + logger.info("Tailwind Build Successful"); + }); +}; diff --git a/lib/unlisted-pages-extension.js b/lib/unlisted-pages-extension.js index ec1b337f..d588690c 100644 --- a/lib/unlisted-pages-extension.js +++ b/lib/unlisted-pages-extension.js @@ -1,41 +1,41 @@ module.exports.register = function ({ config }) { - const { addToNavigation, unlistedPagesHeading = 'Unlisted Pages' } = config - const logger = this.getLogger('unlisted-pages-extension') - this - .on('navigationBuilt', ({ contentCatalog }) => { - contentCatalog.getComponents().forEach(({ versions }) => { - versions.forEach(({ name: component, version, navigation: nav, url: defaultUrl }) => { - const navEntriesByUrl = getNavEntriesByUrl(nav) - const unlistedPages = contentCatalog - .findBy({ component, version, family: 'page' }) - .filter((page) => page.out) - .reduce((collector, page) => { - // Check if the 'unlisted-page' attribute is set to true - if (page.asciidoc.attributes['unlisted-page'] === 'true') { - return collector; // Skip this page - } - if ((page.pub.url in navEntriesByUrl) || page.pub.url === defaultUrl) return collector - logger.warn({ file: page.src, source: page.src.origin }, 'detected unlisted page') - return collector.concat(page) - }, []) - if (unlistedPages.length && addToNavigation) { - nav.push({ - content: unlistedPagesHeading, - items: unlistedPages.map((page) => { - return { content: page.asciidoc.navtitle, url: page.pub.url, urlType: 'internal' } - }), - root: true, - }) - } + const { addToNavigation, unlistedPagesHeading = 'Unlisted Pages' } = config + const logger = this.getLogger('unlisted-pages-extension') + this + .on('navigationBuilt', ({ contentCatalog }) => { + contentCatalog.getComponents().forEach(({ versions }) => { + versions.forEach(({ name: component, version, navigation: nav, url: defaultUrl }) => { + const navEntriesByUrl = getNavEntriesByUrl(nav) + const unlistedPages = contentCatalog + .findBy({ component, version, family: 'page' }) + .filter((page) => page.out) + .reduce((collector, page) => { + // Check if the 'unlisted-page' attribute is set to true + if (page.asciidoc.attributes['unlisted-page'] === 'true') { + return collector; // Skip this page + } + if ((page.pub.url in navEntriesByUrl) || page.pub.url === defaultUrl) return collector + logger.warn({ file: page.src, source: page.src.origin }, 'detected unlisted page') + return collector.concat(page) + }, []) + if (unlistedPages.length && addToNavigation) { + nav.push({ + content: unlistedPagesHeading, + items: unlistedPages.map((page) => { + return { content: page.asciidoc.navtitle, url: page.pub.url, urlType: 'internal' } + }), + root: true, + }) + } + }) }) }) - }) -} + } -function getNavEntriesByUrl (items = [], accum = {}) { - items.forEach((item) => { - if (item.urlType === 'internal') accum[item.url.split('#')[0]] = item - getNavEntriesByUrl(item.items, accum) - }) - return accum -} + function getNavEntriesByUrl (items = [], accum = {}) { + items.forEach((item) => { + if (item.urlType === 'internal') accum[item.url.split('#')[0]] = item + getNavEntriesByUrl(item.items, accum) + }) + return accum + } diff --git a/local-preview-playbook.yml b/local-preview-playbook.yml index 8e75c06d..0ee2c6e4 100644 --- a/local-preview-playbook.yml +++ b/local-preview-playbook.yml @@ -20,6 +20,7 @@ antora: extensions: - '@antora/atlas-extension' - '@antora/collector-extension' + - lib/assets-processor.js - lib/tailwind-processor.js - id: unlisted-pages enabled: true @@ -36,7 +37,8 @@ asciidoc: - asciidoctor-external-callout attributes: # BUILT-IN ATTRIBUTES - allow-uri-read: '' # this has no effect in antora, but does help development in Intellij + # allow-uri-read: '' # Quality-of-life benefit for IntelliJ users. CAUTION: Opens the door to malicious code insertion - must remain disabled in prod build environment. + # hide-uri-scheme: '' # Consider enabling this attribute to make raw http hyperlinks look cleaner. experimental: '' idprefix: '' idseparator: '-' @@ -55,8 +57,20 @@ asciidoc: astra_db: 'Astra DB' astra_stream: 'Astra Streaming' astra_ui: 'Astra Portal' + astra_cli: 'Astra CLI' + astra-streaming-examples-repo: 'https://raw.githubusercontent.com/datastax/astra-streaming-examples/master' + luna-streaming-examples-repo: 'https://raw.githubusercontent.com/datastaxdevs/luna-streaming-examples/main' support_url: 'https://support.datastax.com' glossary-url: 'https://docs.datastax.com/en/glossary/docs/index.html#' + emoji-tada: "🎉" + emoji-rocket: "🚀" + emoji-smile: "😀" + dse: 'DataStax Enterprise (DSE)' + cassandra: 'Apache Cassandra(R)' + classic: 'classic' + classic_cap: 'Classic' + serverless: 'serverless' + serverless_cap: 'Serverless' # Antora Atlas primary-site-url: https://docs.datastax.com/en primary-site-manifest-url: https://docs.datastax.com/en/site-manifest.json diff --git a/package.json b/package.json index 1772ff9d..ec231e76 100644 --- a/package.json +++ b/package.json @@ -9,7 +9,7 @@ "url": "https://github.com/datastax/migration-docs.git" }, "scripts": { - "tailwindcss": "tailwindcss build -c ./build/site/_/js/tailwind.config.js -i ./build/site/_/css/site.css -o ./build/site/_/css/site.css --minify", + "tailwindcss": "tailwindcss build -c ${npm_config_tailwind_config_path} -i ${npm_config_css_path} -o ${npm_config_css_path} --minify", "build:local": "env FORCE_SHOW_EDIT_PAGE_LINK=true antora --clean --fetch --stacktrace local-preview-playbook.yml" }, "dependencies": {