Skip to content

Commit

Permalink
Update UI extensions for local preview (#183)
Browse files Browse the repository at this point in the history
  • Loading branch information
eric-schneider authored Aug 23, 2024
1 parent 30de76b commit 430e26f
Show file tree
Hide file tree
Showing 5 changed files with 86 additions and 47 deletions.
24 changes: 24 additions & 0 deletions docs/extensions/assets-processor.js
Original file line number Diff line number Diff line change
@@ -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;
});
};
29 changes: 21 additions & 8 deletions docs/extensions/tailwind-processor.js
Original file line number Diff line number Diff line change
@@ -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");
});
};
74 changes: 37 additions & 37 deletions docs/extensions/unlisted-pages-extension.js
Original file line number Diff line number Diff line change
@@ -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
}
4 changes: 3 additions & 1 deletion docs/local-preview-playbook.yml
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ antora:
extensions:
- '@antora/atlas-extension'
- '@antora/collector-extension'
- extensions/assets-processor.js
- extensions/tailwind-processor.js
- id: unlisted-pages
enabled: true
Expand All @@ -37,7 +38,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: '-'
Expand Down
2 changes: 1 addition & 1 deletion docs/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
"url": "https://github.com/datastax/cdc-apache-cassandra"
},
"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": {
Expand Down

0 comments on commit 430e26f

Please sign in to comment.