From 63ddbbb2d166666382d68509606ee7c625d95d38 Mon Sep 17 00:00:00 2001 From: Folyd Date: Mon, 2 May 2022 19:15:32 +0800 Subject: [PATCH] Support customize pre block color, remove border radius --- src/entity/markdown.rs | 20 ++++++++++++++++++-- src/entity/zine.rs | 1 + tailwind.config.js | 5 +++++ templates/base.jinja | 2 ++ 4 files changed, 26 insertions(+), 2 deletions(-) diff --git a/src/entity/markdown.rs b/src/entity/markdown.rs index eca41c7..3502bbc 100644 --- a/src/entity/markdown.rs +++ b/src/entity/markdown.rs @@ -1,12 +1,16 @@ -use serde::Deserialize; +use serde::{Deserialize, Serialize}; -#[derive(Debug, Deserialize, Clone)] +#[derive(Debug, Serialize, Deserialize, Clone)] #[serde(rename_all(deserialize = "snake_case"))] pub struct MarkdownConfig { #[serde(default = "MarkdownConfig::default_highlight_code")] pub highlight_code: bool, #[serde(default = "MarkdownConfig::default_highlight_theme")] pub highlight_theme: String, + #[serde(default = "MarkdownConfig::default_pre_code_color")] + pub pre_code_color: String, + #[serde(default = "MarkdownConfig::default_pre_bg_color")] + pub pre_bg_color: String, } impl Default for MarkdownConfig { @@ -14,17 +18,29 @@ impl Default for MarkdownConfig { Self { highlight_code: true, highlight_theme: Self::default_highlight_theme(), + pre_code_color: Self::default_pre_code_color(), + pre_bg_color: Self::default_pre_code_color(), } } } impl MarkdownConfig { const DEFAULT_HIGHLIGHT_THEME: &'static str = "monokai"; + const DEFAULT_PRE_CODE_COLOR: &'static str = "#61676c"; + const DEFAULT_PRE_BG_COLOR: &'static str = "#f5f5f5"; fn default_highlight_theme() -> String { Self::DEFAULT_HIGHLIGHT_THEME.to_string() } + fn default_pre_code_color() -> String { + Self::DEFAULT_PRE_CODE_COLOR.to_string() + } + + fn default_pre_bg_color() -> String { + Self::DEFAULT_PRE_BG_COLOR.to_string() + } + fn default_highlight_code() -> bool { true } diff --git a/src/entity/zine.rs b/src/entity/zine.rs index 99a764b..d92b87f 100644 --- a/src/entity/zine.rs +++ b/src/entity/zine.rs @@ -205,6 +205,7 @@ impl Entity for Zine { fn render(&self, mut context: Context, dest: &Path) -> Result<()> { context.insert("theme", &self.theme); context.insert("site", &self.site); + context.insert("markdown_config", &self.markdown_config); // Render all authors pages. let authors = self.authors(); diff --git a/tailwind.config.js b/tailwind.config.js index dedacc0..0cef97c 100644 --- a/tailwind.config.js +++ b/tailwind.config.js @@ -30,6 +30,11 @@ module.exports = { strong: { fontWeight: '500', }, + pre: { + borderRadius: 0, + color: 'var(--pre-code-color)', + backgroundColor: 'var(--pre-bg-color)', + }, blockquote: { color: "#7c8088", borderLeftWidth: '2px', diff --git a/templates/base.jinja b/templates/base.jinja index eac0560..111af9f 100644 --- a/templates/base.jinja +++ b/templates/base.jinja @@ -20,6 +20,8 @@ --main-color: {{ theme.main_color }}; --link-color: {{ theme.link_color }}; --secondary-color: {{ theme.secondary_color }}; + --pre-code-color: {{ markdown_config.pre_code_color }}; + --pre-bg-color: {{ markdown_config.pre_bg_color }}; }