From ecc57ada6cd9ad7d5a831344ee61e7d698e2ed55 Mon Sep 17 00:00:00 2001 From: Bart Smykla Date: Wed, 23 Oct 2024 15:07:47 +0200 Subject: [PATCH] refactor(plugins/kuma): refactor custom block plugins specific to Kuma Remove separate `tip.rb` and `warning.rb` plugins, which were just copies of the same code with only difference in a block name. Now the code is the same and just registered for different tags. It also correctly maps different class names between Kong and Kuma docs. Signed-off-by: Bart Smykla --- app/_plugins/kuma-specific/custom_block.rb | 29 ++++++++++++++++++++++ app/_plugins/kuma-specific/tip.rb | 22 ---------------- app/_plugins/kuma-specific/warning.rb | 24 ------------------ 3 files changed, 29 insertions(+), 46 deletions(-) create mode 100644 app/_plugins/kuma-specific/custom_block.rb delete mode 100644 app/_plugins/kuma-specific/tip.rb delete mode 100644 app/_plugins/kuma-specific/warning.rb diff --git a/app/_plugins/kuma-specific/custom_block.rb b/app/_plugins/kuma-specific/custom_block.rb new file mode 100644 index 000000000000..f25b508567eb --- /dev/null +++ b/app/_plugins/kuma-specific/custom_block.rb @@ -0,0 +1,29 @@ +# frozen_string_literal: true + +module Jekyll + class CustomBlock < Liquid::Block + def initialize(tag_name, markup, options) + super + # Classes differs between Kuma and Kong docs, but they have the same + # underlying meanings + @class_name = { + 'tip' => 'note', + 'warning' => 'important', + 'danger' => 'warning' + }.fetch(tag_name, 'note') + end + + def render(context) + content = Kramdown::Document.new(super).to_html + <<~HTML +
+

#{content}

+
+ HTML + end + end +end + +Liquid::Template.register_tag('tip', Jekyll::CustomBlock) +Liquid::Template.register_tag('warning', Jekyll::CustomBlock) +Liquid::Template.register_tag('danger', Jekyll::CustomBlock) diff --git a/app/_plugins/kuma-specific/tip.rb b/app/_plugins/kuma-specific/tip.rb deleted file mode 100644 index 4862fb33cd28..000000000000 --- a/app/_plugins/kuma-specific/tip.rb +++ /dev/null @@ -1,22 +0,0 @@ -# frozen_string_literal: true - -module Jekyll - class Tip < Liquid::Block - def initialize(tag_name, markup, options) - super - - @markup = markup.strip - end - - def render(context) - content = Kramdown::Document.new(super).to_html - <<~TIP -
-

#{content}

-
- TIP - end - end -end - -Liquid::Template.register_tag('tip', Jekyll::Tip) diff --git a/app/_plugins/kuma-specific/warning.rb b/app/_plugins/kuma-specific/warning.rb deleted file mode 100644 index 2880bd07420f..000000000000 --- a/app/_plugins/kuma-specific/warning.rb +++ /dev/null @@ -1,24 +0,0 @@ -# frozen_string_literal: true - -module Jekyll - class Warning < Liquid::Block - def initialize(tag_name, markup, options) - super - - @markup = markup.strip - end - - def render(context) - content = Kramdown::Document.new(super).to_html - - # warnings in Kuma map to {:.important} in docs - <<~TIP -
-

#{content}

-
- TIP - end - end -end - -Liquid::Template.register_tag('warning', Jekyll::Warning)