mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2025-01-25 00:29:27 +00:00
c84d7ce1ac
`2.1` -> `2.1.x`
295 lines
7.5 KiB
TypeScript
295 lines
7.5 KiB
TypeScript
import { themes } from 'prism-react-renderer';
|
|
import type { Config } from '@docusaurus/types';
|
|
import type * as Preset from '@docusaurus/preset-classic';
|
|
import * as path from 'path';
|
|
|
|
const config: Config = {
|
|
title: 'Woodpecker CI',
|
|
tagline: 'Woodpecker is a simple yet powerful CI/CD engine with great extensibility.',
|
|
url: 'https://woodpecker-ci.org',
|
|
baseUrl: '/',
|
|
onBrokenLinks: 'throw',
|
|
onBrokenMarkdownLinks: 'throw',
|
|
onDuplicateRoutes: 'throw',
|
|
organizationName: 'woodpecker-ci',
|
|
projectName: 'woodpecker-ci.github.io',
|
|
trailingSlash: false,
|
|
themeConfig: {
|
|
navbar: {
|
|
title: 'Woodpecker',
|
|
logo: {
|
|
alt: 'Woodpecker Logo',
|
|
src: 'img/logo.svg',
|
|
},
|
|
items: [
|
|
{
|
|
type: 'doc',
|
|
docId: 'intro',
|
|
activeBaseRegex: 'docs/(?!migrations|awesome)',
|
|
position: 'left',
|
|
label: 'Docs',
|
|
},
|
|
{
|
|
to: '/plugins',
|
|
position: 'left',
|
|
label: 'Plugins',
|
|
},
|
|
{
|
|
to: '/docs/next/migrations', // Always point to newest migration guide
|
|
activeBaseRegex: 'docs/(next/)?migrations',
|
|
position: 'left',
|
|
label: 'Migrations',
|
|
},
|
|
{
|
|
to: '/faq',
|
|
position: 'left',
|
|
label: 'FAQ',
|
|
},
|
|
{
|
|
to: '/docs/next/awesome', // Always point to newest awesome list
|
|
activeBaseRegex: 'docs/(next/)?awesome',
|
|
position: 'left',
|
|
label: 'Awesome',
|
|
},
|
|
{
|
|
to: '/api',
|
|
position: 'left',
|
|
label: 'API',
|
|
},
|
|
{ to: 'blog', label: 'Blog', position: 'left' },
|
|
{ to: 'cookbook', label: 'Cookbook', position: 'left' },
|
|
{
|
|
type: 'docsVersionDropdown',
|
|
position: 'right',
|
|
},
|
|
{
|
|
href: 'https://github.com/woodpecker-ci/woodpecker',
|
|
position: 'right',
|
|
className: 'header-github-link',
|
|
'aria-label': 'GitHub repository',
|
|
},
|
|
{
|
|
label: '🧡 Sponsor Us',
|
|
position: 'right',
|
|
href: 'https://opencollective.com/woodpecker-ci',
|
|
},
|
|
],
|
|
},
|
|
footer: {
|
|
style: 'dark',
|
|
links: [
|
|
{
|
|
title: 'Docs',
|
|
items: [
|
|
{
|
|
label: 'Introduction',
|
|
to: '/docs/intro',
|
|
},
|
|
{
|
|
label: 'Usage',
|
|
to: '/docs/usage/intro',
|
|
},
|
|
{
|
|
label: 'Server setup',
|
|
to: '/docs/administration/deployment/overview',
|
|
},
|
|
{
|
|
label: 'FAQ',
|
|
to: '/faq',
|
|
},
|
|
],
|
|
},
|
|
{
|
|
title: 'Community',
|
|
items: [
|
|
{
|
|
label: 'Discord',
|
|
href: 'https://discord.gg/fcMQqSMXJy',
|
|
},
|
|
{
|
|
label: 'Matrix',
|
|
href: 'https://matrix.to/#/#woodpecker:matrix.org',
|
|
},
|
|
{
|
|
label: 'Mastodon',
|
|
href: 'https://floss.social/@WoodpeckerCI',
|
|
},
|
|
],
|
|
},
|
|
{
|
|
title: 'More',
|
|
items: [
|
|
{
|
|
label: 'Translate',
|
|
href: 'https://translate.woodpecker-ci.org/engage/woodpecker-ci/',
|
|
},
|
|
{
|
|
label: 'GitHub',
|
|
href: 'https://github.com/woodpecker-ci/woodpecker',
|
|
},
|
|
{
|
|
href: 'https://ci.woodpecker-ci.org/woodpecker-ci/woodpecker',
|
|
label: 'CI',
|
|
},
|
|
],
|
|
},
|
|
],
|
|
copyright: `Copyright © ${new Date().getFullYear()} Woodpecker CI. Built with Docusaurus.`,
|
|
},
|
|
prism: {
|
|
theme: themes.github,
|
|
darkTheme: themes.dracula,
|
|
additionalLanguages: ['diff', 'json', 'docker', 'javascript', 'css', 'bash', 'nginx', 'apacheconf', 'ini', 'nix'],
|
|
},
|
|
announcementBar: {
|
|
id: 'github-star',
|
|
content: ` If you like Woodpecker-CI, <a href=https://github.com/woodpecker-ci/woodpecker rel="noopener noreferrer" target="_blank">give us a star on GitHub</a> ! ⭐️`,
|
|
backgroundColor: 'var(--ifm-color-primary)',
|
|
textColor: 'var(--ifm-color-gray-900)',
|
|
},
|
|
tableOfContents: {
|
|
minHeadingLevel: 2,
|
|
maxHeadingLevel: 4,
|
|
},
|
|
colorMode: {
|
|
respectPrefersColorScheme: true,
|
|
},
|
|
} satisfies Preset.ThemeConfig,
|
|
plugins: [
|
|
() => ({
|
|
name: 'docusaurus-plugin-favicon',
|
|
injectHtmlTags() {
|
|
return {
|
|
headTags: [
|
|
{
|
|
tagName: 'link',
|
|
attributes: {
|
|
rel: 'icon',
|
|
href: '/img/favicon.ico',
|
|
sizes: 'any',
|
|
},
|
|
},
|
|
{
|
|
tagName: 'link',
|
|
attributes: {
|
|
rel: 'icon',
|
|
href: '/img/favicon.svg',
|
|
type: 'image/svg+xml',
|
|
},
|
|
},
|
|
],
|
|
};
|
|
},
|
|
}),
|
|
() => ({
|
|
name: 'webpack-config',
|
|
configureWebpack() {
|
|
return {
|
|
devServer: {
|
|
client: {
|
|
webSocketURL: 'auto://0.0.0.0:0/ws',
|
|
},
|
|
},
|
|
};
|
|
},
|
|
}),
|
|
[
|
|
'@docusaurus/plugin-content-blog',
|
|
{
|
|
id: 'cookbook-blog',
|
|
/**
|
|
* URL route for the blog section of your site.
|
|
* *DO NOT* include a trailing slash.
|
|
*/
|
|
routeBasePath: 'cookbook',
|
|
/**
|
|
* Path to data on filesystem relative to site dir.
|
|
*/
|
|
path: './cookbook',
|
|
},
|
|
],
|
|
],
|
|
themes: [
|
|
path.resolve(__dirname, 'plugins', 'woodpecker-plugins', 'dist'),
|
|
[
|
|
require.resolve('@easyops-cn/docusaurus-search-local'),
|
|
{
|
|
hashed: true,
|
|
},
|
|
],
|
|
],
|
|
presets: [
|
|
[
|
|
'@docusaurus/preset-classic',
|
|
{
|
|
docs: {
|
|
sidebarPath: require.resolve('./sidebars.js'),
|
|
editUrl: 'https://github.com/woodpecker-ci/woodpecker/edit/main/docs/',
|
|
includeCurrentVersion: true,
|
|
lastVersion: '2.1',
|
|
versions: {
|
|
current: {
|
|
label: 'Next',
|
|
banner: 'unreleased',
|
|
},
|
|
'2.1': {
|
|
label: '2.1.x',
|
|
},
|
|
'2.0': {
|
|
label: '2.0.x',
|
|
banner: 'unmaintained',
|
|
},
|
|
'1.0': {
|
|
label: '1.0.x',
|
|
banner: 'unmaintained',
|
|
},
|
|
0.15: {
|
|
label: '0.15.x',
|
|
banner: 'unmaintained',
|
|
},
|
|
},
|
|
},
|
|
blog: {
|
|
blogTitle: 'Blog',
|
|
blogDescription: 'A blog for release announcements, turorials...',
|
|
// postsPerPage: 'ALL',
|
|
// blogSidebarCount: 0,
|
|
},
|
|
theme: {
|
|
customCss: require.resolve('./src/css/custom.css'),
|
|
},
|
|
} satisfies Preset.Options,
|
|
],
|
|
[
|
|
'redocusaurus',
|
|
{
|
|
// Plugin Options for loading OpenAPI files
|
|
specs: [
|
|
{
|
|
spec: 'swagger.json',
|
|
route: '/api/',
|
|
},
|
|
],
|
|
// Theme Options for modifying how redoc renders them
|
|
theme: {
|
|
// Change with your site colors
|
|
primaryColor: '#1890ff',
|
|
},
|
|
},
|
|
],
|
|
],
|
|
webpack: {
|
|
jsLoader: (isServer) => ({
|
|
loader: require.resolve('esbuild-loader'),
|
|
options: {
|
|
loader: 'tsx',
|
|
target: isServer ? 'node12' : 'es2017',
|
|
},
|
|
}),
|
|
},
|
|
markdown: {
|
|
format: 'detect',
|
|
},
|
|
};
|
|
|
|
export default config;
|