mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2024-12-15 04:56:35 +00:00
309 lines
7.7 KiB
TypeScript
309 lines
7.7 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',
|
|
onBrokenAnchors: 'throw',
|
|
onDuplicateRoutes: 'throw',
|
|
organizationName: 'woodpecker-ci',
|
|
projectName: 'woodpecker-ci.github.io',
|
|
trailingSlash: false,
|
|
headTags: [
|
|
{
|
|
tagName: 'link',
|
|
attributes: {
|
|
href: 'https://floss.social/@WoodpeckerCI',
|
|
rel: 'me',
|
|
},
|
|
},
|
|
],
|
|
themeConfig: {
|
|
navbar: {
|
|
title: 'Woodpecker',
|
|
logo: {
|
|
alt: 'Woodpecker Logo',
|
|
src: 'img/logo.svg',
|
|
},
|
|
items: [
|
|
{
|
|
type: 'doc',
|
|
docId: 'intro/index',
|
|
activeBaseRegex: 'docs/(?!migrations|awesome)',
|
|
position: 'left',
|
|
label: 'Docs',
|
|
},
|
|
{
|
|
to: '/plugins',
|
|
position: 'left',
|
|
label: 'Plugins',
|
|
},
|
|
{ to: 'blog', label: 'Blog', position: 'left' },
|
|
{
|
|
label: 'More Resources',
|
|
position: 'left',
|
|
items: [
|
|
{
|
|
to: '/migrations', // Always point to newest migration guide
|
|
activeBaseRegex: 'migrations',
|
|
label: 'Migrations',
|
|
},
|
|
{
|
|
to: '/awesome', // Always point to newest awesome list
|
|
activeBaseRegex: 'awesome',
|
|
label: 'Awesome',
|
|
},
|
|
{
|
|
to: '/api',
|
|
label: 'API',
|
|
},
|
|
],
|
|
},
|
|
{
|
|
type: 'docsVersionDropdown',
|
|
position: 'right',
|
|
dropdownItemsAfter: [
|
|
{
|
|
to: '/versions',
|
|
label: 'All versions',
|
|
},
|
|
],
|
|
},
|
|
{
|
|
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/getting-started',
|
|
},
|
|
],
|
|
},
|
|
{
|
|
title: 'Community',
|
|
items: [
|
|
{
|
|
label: 'Matrix',
|
|
href: 'https://matrix.to/#/#woodpecker:matrix.org',
|
|
},
|
|
{
|
|
label: 'Mastodon',
|
|
href: 'https://floss.social/@WoodpeckerCI',
|
|
},
|
|
{
|
|
label: 'X',
|
|
href: 'https://twitter.com/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/repos/3780',
|
|
label: 'CI',
|
|
},
|
|
{
|
|
href: 'https://opencollective.com/woodpecker-ci',
|
|
label: 'Open Collective',
|
|
},
|
|
],
|
|
},
|
|
],
|
|
copyright: `Copyright © ${new Date().getFullYear()} Woodpecker Authors. Built with Docusaurus.`,
|
|
},
|
|
prism: {
|
|
theme: themes.github,
|
|
darkTheme: themes.dracula,
|
|
additionalLanguages: [
|
|
'diff',
|
|
'json',
|
|
'docker',
|
|
'javascript',
|
|
'css',
|
|
'bash',
|
|
'nginx',
|
|
'apacheconf',
|
|
'ini',
|
|
'nix',
|
|
'uri',
|
|
],
|
|
},
|
|
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',
|
|
},
|
|
},
|
|
} as any;
|
|
},
|
|
}),
|
|
],
|
|
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.8',
|
|
onlyIncludeVersions:
|
|
process.env.NODE_ENV === 'development' ? ['current', '2.8'] : ['current', '2.8', '2.7', '2.6', '1.0'],
|
|
versions: {
|
|
current: {
|
|
label: 'Next 🚧',
|
|
banner: 'unreleased',
|
|
},
|
|
'2.8': {
|
|
label: '2.8.x',
|
|
},
|
|
'2.7': {
|
|
label: '2.7.x',
|
|
banner: 'unmaintained',
|
|
},
|
|
'2.6': {
|
|
label: '2.6.x 💀',
|
|
banner: 'unmaintained',
|
|
},
|
|
'1.0': {
|
|
label: '1.0.x 💀',
|
|
banner: 'unmaintained',
|
|
},
|
|
},
|
|
},
|
|
blog: {
|
|
blogTitle: 'Blog',
|
|
blogDescription: 'A blog for release announcements, turorials...',
|
|
onInlineAuthors: 'ignore',
|
|
// postsPerPage: 'ALL',
|
|
// blogSidebarCount: 0,
|
|
},
|
|
theme: {
|
|
customCss: require.resolve('./src/css/custom.css'),
|
|
},
|
|
} satisfies Preset.Options,
|
|
],
|
|
[
|
|
'redocusaurus',
|
|
{
|
|
// Plugin Options for loading OpenAPI files
|
|
specs: [
|
|
{
|
|
spec: 'openapi.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',
|
|
supported: { 'dynamic-import': false },
|
|
},
|
|
}),
|
|
},
|
|
markdown: {
|
|
format: 'detect',
|
|
},
|
|
};
|
|
|
|
export default config;
|