diff --git a/.github/workflows/versions_robot.yaml b/.github/workflows/versions_robot.yaml
index 413c01e1ce..e38aec6660 100644
--- a/.github/workflows/versions_robot.yaml
+++ b/.github/workflows/versions_robot.yaml
@@ -85,6 +85,9 @@ jobs:
id: check_noindex
run: node scripts/noindex_docusaurus_config.js $RUNNER_TEMP $PWD && mv $RUNNER_TEMP/temp.docusaurus.config.js $PWD/docusaurus.config.js
+ - name: Auto Format (Prettier)
+ run: make format
+
- name: Commit Changes
id: commit
uses: stefanzweifel/git-auto-commit-action@v5
diff --git a/docusaurus.config.js b/docusaurus.config.js
index 1d1312e058..13d81e2ac5 100644
--- a/docusaurus.config.js
+++ b/docusaurus.config.js
@@ -5,12 +5,8 @@ const themes = require("prism-react-renderer").themes;
const lightCodeTheme = themes.oceanicNext;
const darkCodeTheme = themes.dracula;
const redirects = require("./redirects");
-const {
- pluginPacksAndIntegrationsData
-} = require("./plugins/packs-integrations");
-const {
- pluginImportFontAwesomeIcons
-} = require("./plugins/font-awesome");
+const { pluginPacksAndIntegrationsData } = require("./plugins/packs-integrations");
+const { pluginImportFontAwesomeIcons } = require("./plugins/font-awesome");
import path from "path";
import { Logger } from "sass";
@@ -36,318 +32,377 @@ const config = {
// to replace "en" with "zh-Hans".
i18n: {
defaultLocale: "en",
- locales: ["en"]
+ locales: ["en"],
},
staticDirectories: ["static", "static/assets/docs/images", "static/assets"],
- headTags: [{
- tagName: "script",
- attributes: {
- type: "text/plain",
- "data-usercentrics": "FullStory",
- src: "/scripts/fullstory.js"
- }
- }, {
- tagName: "link",
- attributes: {
- rel: "preconnect",
- href: "https://api.usercentrics.eu"
- }
- }, {
- tagName: "link",
- attributes: {
- rel: "preload",
- href: "https://app.usercentrics.eu/browser-ui/latest/loader.js",
- as: "script"
- }
- }, {
- tagName: "script",
- attributes: {
- src: "https://app.usercentrics.eu/browser-ui/latest/loader.js",
- "data-settings-id": "0IhiFXOBwy0Z2U",
- id: "usercentrics-cmp",
- async: "true"
- }
- }, {
- tagName: "link",
- attributes: {
- rel: "preconnect",
- href: "https://www.googletagmanager.com"
- }
- }, {
- tagName: "script",
- attributes: {
- type: "text/javascript",
- "data-usercentrics": "Google Tag Manager",
- src: "/scripts/googleTagManager.js"
- }
- }],
- stylesheets: [],
- presets: [["classic", /** @type {import('@docusaurus/preset-classic').Options} */
- {
- docs: {
- path: "docs/docs-content",
- showLastUpdateAuthor: false,
- showLastUpdateTime: true,
- routeBasePath: "/",
- lastVersion: "current",
- includeCurrentVersion: true,
- versions: {
- current: {
- label: "v3.4.x"
- }
+ headTags: [
+ {
+ tagName: "script",
+ attributes: {
+ type: "text/plain",
+ "data-usercentrics": "FullStory",
+ src: "/scripts/fullstory.js",
},
- admonitions: {
- keywords: ["preview", "further"],
- extendDefaults: true
+ },
+ {
+ tagName: "link",
+ attributes: {
+ rel: "preconnect",
+ href: "https://api.usercentrics.eu",
},
- // exclude: ["api/v1/palette-apis-3-4"],
-
- sidebarPath: require.resolve("./sidebars.js"),
- async sidebarItemsGenerator({
- defaultSidebarItemsGenerator,
- ...args
- }) {
- const {
- docs
- } = args;
- const filteredDocs = docs.filter(doc => {
- return true;
- });
- const sidebarItems = await defaultSidebarItemsGenerator({
- ...args,
- docs: filteredDocs
- });
- return sidebarItems;
+ },
+ {
+ tagName: "link",
+ attributes: {
+ rel: "preload",
+ href: "https://app.usercentrics.eu/browser-ui/latest/loader.js",
+ as: "script",
},
- editUrl: "https://github.com/spectrocloud/librarium/blob/master"
},
- sitemap: {
- changefreq: "daily",
- priority: 0.5,
- ignorePatterns: ["/tags/**"],
- filename: "sitemap.xml"
+ {
+ tagName: "script",
+ attributes: {
+ src: "https://app.usercentrics.eu/browser-ui/latest/loader.js",
+ "data-settings-id": "0IhiFXOBwy0Z2U",
+ id: "usercentrics-cmp",
+ async: "true",
+ },
},
- theme: {
- customCss: require.resolve("./src/css/custom.scss")
- }
- }]],
- plugins: ["docusaurus-plugin-sass", ["@docusaurus/plugin-content-docs", {
- id: "api",
- path: "docs/api-content/api-docs",
- routeBasePath: "api",
- docItemComponent: "@theme/ApiItem",
- lastVersion: "current",
- includeCurrentVersion: true,
- admonitions: {
- keywords: ["preview", "further"],
- extendDefaults: true
+ {
+ tagName: "link",
+ attributes: {
+ rel: "preconnect",
+ href: "https://www.googletagmanager.com",
+ },
},
- versions: {
- current: {
- label: "3.4.x"
- }
+ {
+ tagName: "script",
+ attributes: {
+ type: "text/javascript",
+ "data-usercentrics": "Google Tag Manager",
+ src: "/scripts/googleTagManager.js",
+ },
},
- sidebarPath: require.resolve("./apisidebar.js")
- }], ["docusaurus-plugin-openapi-docs", {
- // Visit https://docusaurus-openapi.tryingpan.dev/#config to learn more about this plugin's config options.
- id: "apidocs",
- docsPluginId: "api",
- config: {
- palette: {
- specPath: "docs/api-content/api-docs/v1/api.json",
- outputDir: "docs/api-content/api-docs/v1",
- downloadUrl: "https://github.com/spectrocloud/librarium/blob/master/docs/api-content/api-docs/palette-apis.json",
- sidebarOptions: {
- groupPathsBy: "tag",
- categoryLinkSource: "tag"
+ ],
+ stylesheets: [],
+ presets: [
+ [
+ "classic",
+ /** @type {import('@docusaurus/preset-classic').Options} */
+ {
+ docs: {
+ path: "docs/docs-content",
+ showLastUpdateAuthor: false,
+ showLastUpdateTime: true,
+ routeBasePath: "/",
+ lastVersion: "current",
+ includeCurrentVersion: true,
+ versions: {
+ current: {
+ label: "v3.4.x",
+ },
+ },
+ admonitions: {
+ keywords: ["preview", "further"],
+ extendDefaults: true,
+ },
+ // exclude: ["api/v1/palette-apis-3-4"],
+
+ sidebarPath: require.resolve("./sidebars.js"),
+ async sidebarItemsGenerator({ defaultSidebarItemsGenerator, ...args }) {
+ const { docs } = args;
+ const filteredDocs = docs.filter((doc) => {
+ return true;
+ });
+ const sidebarItems = await defaultSidebarItemsGenerator({
+ ...args,
+ docs: filteredDocs,
+ });
+ return sidebarItems;
+ },
+ editUrl: "https://github.com/spectrocloud/librarium/blob/master",
+ },
+ sitemap: {
+ changefreq: "daily",
+ priority: 0.5,
+ ignorePatterns: ["/tags/**"],
+ filename: "sitemap.xml",
+ },
+ theme: {
+ customCss: require.resolve("./src/css/custom.scss"),
+ },
+ },
+ ],
+ ],
+ plugins: [
+ "docusaurus-plugin-sass",
+ [
+ "@docusaurus/plugin-content-docs",
+ {
+ id: "api",
+ path: "docs/api-content/api-docs",
+ routeBasePath: "api",
+ docItemComponent: "@theme/ApiItem",
+ lastVersion: "current",
+ includeCurrentVersion: true,
+ admonitions: {
+ keywords: ["preview", "further"],
+ extendDefaults: true,
},
- template: "api.mustache",
- // Customize API MDX with mustache template
- hideSendButton: true
- }
- }
- }], process.env.NODE_ENV !== "production" && [() => ({
- name: "plugin-enable-source-map",
- configureWebpack() {
+ versions: {
+ current: {
+ label: "3.4.x",
+ },
+ },
+ sidebarPath: require.resolve("./apisidebar.js"),
+ },
+ ],
+ [
+ "docusaurus-plugin-openapi-docs",
+ {
+ // Visit https://docusaurus-openapi.tryingpan.dev/#config to learn more about this plugin's config options.
+ id: "apidocs",
+ docsPluginId: "api",
+ config: {
+ palette: {
+ specPath: "docs/api-content/api-docs/v1/api.json",
+ outputDir: "docs/api-content/api-docs/v1",
+ downloadUrl:
+ "https://github.com/spectrocloud/librarium/blob/master/docs/api-content/api-docs/palette-apis.json",
+ sidebarOptions: {
+ groupPathsBy: "tag",
+ categoryLinkSource: "tag",
+ },
+ template: "api.mustache",
+ // Customize API MDX with mustache template
+ hideSendButton: true,
+ },
+ },
+ },
+ ],
+ process.env.NODE_ENV !== "production" && [
+ () => ({
+ name: "plugin-enable-source-map",
+ configureWebpack() {
+ return {
+ devtool: "source-map",
+ };
+ },
+ }),
+ {
+ id: "enable-source-map",
+ },
+ ],
+ [
+ pluginPacksAndIntegrationsData,
+ {
+ repositories: ["Palette Registry", "Public Repo", "Spectro Addon Repo", "Palette Community Registry"],
+ },
+ ],
+ pluginImportFontAwesomeIcons,
+ function () {
return {
- devtool: "source-map"
+ name: "plugin-watch-custom-plugin-path",
+ getPathsToWatch() {
+ return ["plugins/font-awesome.js", "plugins/packs-integrations.js"];
+ },
};
- }
- }), {
- id: "enable-source-map"
- }], [pluginPacksAndIntegrationsData, {
- repositories: ["Palette Registry", "Public Repo", "Spectro Addon Repo", "Palette Community Registry"]
- }], pluginImportFontAwesomeIcons, function () {
- return {
- name: "plugin-watch-custom-plugin-path",
- getPathsToWatch() {
- return ["plugins/font-awesome.js", "plugins/packs-integrations.js"];
- }
- };
- }, ["@docusaurus/plugin-ideal-image", {
- quality: 50,
- max: 1035,
- steps: 4,
- disableInDev: false
- }], [require.resolve("docusaurus-plugin-image-zoom"), {
- id: "docusaurus-plugin-image-zoom"
- }], ["@docusaurus/plugin-client-redirects", {
- redirects: [...redirects]
- }]].filter(Boolean),
- scripts: [{
- src: `https://w.appzi.io/w.js?token=${process.env.APPZI_TOKEN}`,
- defer: true
- }],
+ },
+ [
+ "@docusaurus/plugin-ideal-image",
+ {
+ quality: 50,
+ max: 1035,
+ steps: 4,
+ disableInDev: false,
+ },
+ ],
+ [
+ require.resolve("docusaurus-plugin-image-zoom"),
+ {
+ id: "docusaurus-plugin-image-zoom",
+ },
+ ],
+ [
+ "@docusaurus/plugin-client-redirects",
+ {
+ redirects: [...redirects],
+ },
+ ],
+ ].filter(Boolean),
+ scripts: [
+ {
+ src: `https://w.appzi.io/w.js?token=${process.env.APPZI_TOKEN}`,
+ defer: true,
+ },
+ ],
themes: ["docusaurus-theme-openapi-docs"],
customFields: {
// Put your custom environment here
},
- themeConfig: /** @type {import('@docusaurus/preset-classic').ThemeConfig} */
- {
- // announcementBar: {
- // id: "docs_announcement_bar",
- // content:
- // REPLACE MESSAGE BELOW
- // 'The 2024 State of Production Kubernetes report is now available and it\'s full of insights and goodies. Click here to get your own copy.',
- // backgroundColor: "#FBB117",
- // textColor: "#091E42",
- // isCloseable: false,
- // },
- colorMode: {
- respectPrefersColorScheme: true
- },
- docs: {
+ themeConfig:
+ /** @type {import('@docusaurus/preset-classic').ThemeConfig} */
+ {
+ // announcementBar: {
+ // id: "docs_announcement_bar",
+ // content:
+ // REPLACE MESSAGE BELOW
+ // 'The 2024 State of Production Kubernetes report is now available and it\'s full of insights and goodies. Click here to get your own copy.',
+ // backgroundColor: "#FBB117",
+ // textColor: "#091E42",
+ // isCloseable: false,
+ // },
+ colorMode: {
+ respectPrefersColorScheme: true,
+ },
+ docs: {
+ sidebar: {
+ hideable: false,
+ autoCollapseCategories: true,
+ },
+ },
+ tableOfContents: {
+ minHeadingLevel: 2,
+ maxHeadingLevel: 3,
+ },
+ // Replace with your project's social card
+ image: "img/spectro-cloud-social-card.png",
+ navbar: {
+ title: "",
+ logo: {
+ href: "/",
+ target: "self",
+ width: 144,
+ height: 36,
+ alt: "Spectro cloud logo",
+ src: "img/spectrocloud-logo-light.svg",
+ srcDark: "img/spectrocloud-logo-dark.svg",
+ },
+ items: [
+ {
+ to: "/",
+ type: "docSidebar",
+ sidebarId: "docSidebar",
+ label: "Docs",
+ position: "left",
+ activeBaseRegex: "^(?!/api/).*$",
+ },
+ {
+ to: "/tutorials",
+ type: "docSidebar",
+ sidebarId: "tutorialSidebar",
+ label: "Tutorials",
+ position: "left",
+ activeBaseRegex: "^(?!/api/).*$",
+ },
+ {
+ to: "/api/introduction",
+ label: "API",
+ position: "left",
+ },
+ {
+ href: "https://github.com/spectrocloud/librarium",
+ position: "right",
+ className: "header-github-link",
+ "aria-label": "GitHub repository",
+ },
+ {
+ type: "docsVersionDropdown",
+ position: "left",
+ docsPluginId: "default",
+ },
+ {
+ type: "docsVersionDropdown",
+ position: "left",
+ docsPluginId: "api",
+ },
+ ],
+ hideOnScroll: true,
+ },
+ languageTabs: [
+ {
+ highlight: "bash",
+ language: "curl",
+ logoClass: "bash",
+ },
+ {
+ highlight: "python",
+ language: "python",
+ logoClass: "python",
+ variant: "requests",
+ },
+ {
+ highlight: "go",
+ language: "go",
+ logoClass: "go",
+ },
+ {
+ highlight: "javascript",
+ language: "nodejs",
+ logoClass: "nodejs",
+ variant: "axios",
+ },
+ {
+ highlight: "java",
+ language: "java",
+ logoClass: "java",
+ variant: "unirest",
+ },
+ ],
+ algolia: {
+ // The application ID provided by Algolia
+ appId: process.env.ALGOLIA_APP_ID,
+ // Public API key: it is safe to commit it
+ apiKey: process.env.ALGOLIA_SEARCH_KEY,
+ indexName: process.env.ALGOLIA_INDEX_NAME,
+ // Optional: see doc section below
+ contextualSearch: true,
+ // Optional: Specify domains where the navigation should occur through window.location instead on history.push. Useful when our Algolia config crawls multiple documentation sites and we want to navigate with window.location.href to them.
+ externalUrlRegex: "external\\.com|domain\\.com",
+ // Optional: Replace parts of the item URLs from Algolia. Useful when using the same search index for multiple deployments using a different baseUrl. You can use regexp or string in the `from` param. For example: localhost:3000 vs myCompany.com/docs
+ replaceSearchResultPathname: {
+ from: "/docs/",
+ // or as RegExp: /\/docs\//
+ to: "/",
+ },
+ // Optional: Algolia search parameters
+ searchParameters: {},
+ // Optional: path for search page that enabled by default (`false` to disable it)
+ searchPagePath: "search",
+ maxResultsPerGroup: 7,
+ },
sidebar: {
- hideable: false,
- autoCollapseCategories: true
- }
- },
- tableOfContents: {
- minHeadingLevel: 2,
- maxHeadingLevel: 3
- },
- // Replace with your project's social card
- image: "img/spectro-cloud-social-card.png",
- navbar: {
- title: "",
- logo: {
- href: "/",
- target: "self",
- width: 144,
- height: 36,
- alt: "Spectro cloud logo",
- src: "img/spectrocloud-logo-light.svg",
- srcDark: "img/spectrocloud-logo-dark.svg"
+ hideable: true,
},
- items: [{
- to: "/",
- type: "docSidebar",
- sidebarId: "docSidebar",
- label: "Docs",
- position: "left",
- activeBaseRegex: "^(?!/api/).*$"
- }, {
- to: "/tutorials",
- type: "docSidebar",
- sidebarId: "tutorialSidebar",
- label: "Tutorials",
- position: "left",
- activeBaseRegex: "^(?!/api/).*$"
- }, {
- to: "/api/introduction",
- label: "API",
- position: "left"
- }, {
- href: "https://github.com/spectrocloud/librarium",
- position: "right",
- className: "header-github-link",
- "aria-label": "GitHub repository"
- }, {
- type: "docsVersionDropdown",
- position: "left",
- docsPluginId: "default"
- }, {
- type: "docsVersionDropdown",
- position: "left",
- docsPluginId: "api"
- }],
- hideOnScroll: true
- },
- languageTabs: [{
- highlight: "bash",
- language: "curl",
- logoClass: "bash"
- }, {
- highlight: "python",
- language: "python",
- logoClass: "python",
- variant: "requests"
- }, {
- highlight: "go",
- language: "go",
- logoClass: "go"
- }, {
- highlight: "javascript",
- language: "nodejs",
- logoClass: "nodejs",
- variant: "axios"
- }, {
- highlight: "java",
- language: "java",
- logoClass: "java",
- variant: "unirest"
- }],
- algolia: {
- // The application ID provided by Algolia
- appId: process.env.ALGOLIA_APP_ID,
- // Public API key: it is safe to commit it
- apiKey: process.env.ALGOLIA_SEARCH_KEY,
- indexName: process.env.ALGOLIA_INDEX_NAME,
- // Optional: see doc section below
- contextualSearch: true,
- // Optional: Specify domains where the navigation should occur through window.location instead on history.push. Useful when our Algolia config crawls multiple documentation sites and we want to navigate with window.location.href to them.
- externalUrlRegex: "external\\.com|domain\\.com",
- // Optional: Replace parts of the item URLs from Algolia. Useful when using the same search index for multiple deployments using a different baseUrl. You can use regexp or string in the `from` param. For example: localhost:3000 vs myCompany.com/docs
- replaceSearchResultPathname: {
- from: "/docs/",
- // or as RegExp: /\/docs\//
- to: "/"
+ prism: {
+ defaultLanguage: "json",
+ theme: lightCodeTheme,
+ darkTheme: darkCodeTheme,
+ additionalLanguages: ["hcl", "bash", "json", "powershell", "go", "javascript", "rust"],
+ magicComments: [
+ {
+ className: "theme-code-block-highlighted-line",
+ line: "highlight-next-line",
+ block: {
+ start: "highlight-start",
+ end: "highlight-end",
+ },
+ },
+ {
+ className: "code-block-error-line",
+ line: "This will error",
+ },
+ ],
},
- // Optional: Algolia search parameters
- searchParameters: {},
- // Optional: path for search page that enabled by default (`false` to disable it)
- searchPagePath: "search",
- maxResultsPerGroup: 7
- },
- sidebar: {
- hideable: true
- },
- prism: {
- defaultLanguage: "json",
- theme: lightCodeTheme,
- darkTheme: darkCodeTheme,
- additionalLanguages: ["hcl", "bash", "json", "powershell", "go", "javascript", "rust"],
- magicComments: [{
- className: "theme-code-block-highlighted-line",
- line: "highlight-next-line",
- block: {
- start: "highlight-start",
- end: "highlight-end"
- }
- }, {
- className: "code-block-error-line",
- line: "This will error"
- }]
- },
- zoom: {
- selector: ".markdown-image",
- background: {
- light: "rgb(255, 255, 255)",
- dark: "rgb(50, 50, 50)"
+ zoom: {
+ selector: ".markdown-image",
+ background: {
+ light: "rgb(255, 255, 255)",
+ dark: "rgb(50, 50, 50)",
+ },
+ config: {},
},
- config: {}
- }
- }
+ },
};
module.exports = config;
export default function (context, options) {
@@ -356,6 +411,6 @@ export default function (context, options) {
getPathsToWatch() {
const contentPath = path.resolve(context.siteDir, options.path);
return [`${contentPath}/_partials/*/*.{mdx}`];
- }
+ },
};
-}
\ No newline at end of file
+}