DEV: Add markdown_additional_options to Site (#15738)

Sometimes plugins need to have additional data or options available
when rendering custom markdown features/rules that are not available
on the default opts.discourse object. These additional options should
be namespaced to the plugin adding them.

```
Site.markdown_additional_options["chat"] = { limited_pretty_text_markdown_rules: [] }
```

These are passed down to markdown rules on opts.discourse.additionalOptions.

The main motivation for adding this is the chat plugin, which currently stores
chat_pretty_text_features and chat_pretty_text_markdown_rules on
the Site object via additions to the serializer, and the Site object is
not accessible to import via markdown rules (either through
Site.current() or through container.lookup). So, to have this working
for both front + backend code, we need to attach these additional options
from the Site object onto the markdown options object.
This commit is contained in:
Martin Brennan 2022-01-28 13:02:02 +10:00 committed by GitHub
parent 68fe6903f7
commit 0b8d0a14d7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 27 additions and 1 deletions

View File

@ -23,6 +23,7 @@ function getOpts(opts) {
formatUsername, formatUsername,
watchedWordsReplace: context.site.watched_words_replace, watchedWordsReplace: context.site.watched_words_replace,
watchedWordsLink: context.site.watched_words_link, watchedWordsLink: context.site.watched_words_link,
additionalOptions: context.site.markdown_additional_options,
}, },
opts opts
); );

View File

@ -40,6 +40,7 @@ export function buildOptions(state) {
watchedWordsLink, watchedWordsLink,
featuresOverride, featuresOverride,
markdownItRules, markdownItRules,
additionalOptions,
} = state; } = state;
let features = {}; let features = {};
@ -80,6 +81,7 @@ export function buildOptions(state) {
watchedWordsLink, watchedWordsLink,
featuresOverride, featuresOverride,
markdownItRules, markdownItRules,
additionalOptions,
}; };
// note, this will mutate options due to the way the API is designed // note, this will mutate options due to the way the API is designed

View File

@ -7,6 +7,20 @@ class Site
cattr_accessor :preloaded_category_custom_fields cattr_accessor :preloaded_category_custom_fields
self.preloaded_category_custom_fields = Set.new self.preloaded_category_custom_fields = Set.new
##
# Sometimes plugins need to have additional data or options available
# when rendering custom markdown features/rules that are not available
# on the default opts.discourse object. These additional options should
# be namespaced to the plugin adding them.
#
# ```
# Site.markdown_additional_options["chat"] = { limited_pretty_text_markdown_rules: [] }
# ```
#
# These are passed down to markdown rules on opts.discourse.additionalOptions.
cattr_accessor :markdown_additional_options
self.markdown_additional_options = {}
def self.add_categories_callbacks(&block) def self.add_categories_callbacks(&block)
categories_callbacks << block categories_callbacks << block
end end

View File

@ -32,7 +32,8 @@ class SiteSerializer < ApplicationSerializer
:custom_emoji_translation, :custom_emoji_translation,
:watched_words_replace, :watched_words_replace,
:watched_words_link, :watched_words_link,
:categories :categories,
:markdown_additional_options
) )
has_many :archetypes, embed: :objects, serializer: ArchetypeSerializer has_many :archetypes, embed: :objects, serializer: ArchetypeSerializer
@ -203,6 +204,10 @@ class SiteSerializer < ApplicationSerializer
object.categories.map { |c| c.to_h } object.categories.map { |c| c.to_h }
end end
def markdown_additional_options
Site.markdown_additional_options
end
private private
def ordered_flags(flags) def ordered_flags(flags)

View File

@ -201,6 +201,7 @@ module PrettyText
__optInput.censoredRegexp = #{WordWatcher.word_matcher_regexp(:censor)&.source.to_json}; __optInput.censoredRegexp = #{WordWatcher.word_matcher_regexp(:censor)&.source.to_json};
__optInput.watchedWordsReplace = #{WordWatcher.word_matcher_regexps(:replace).to_json}; __optInput.watchedWordsReplace = #{WordWatcher.word_matcher_regexps(:replace).to_json};
__optInput.watchedWordsLink = #{WordWatcher.word_matcher_regexps(:link).to_json}; __optInput.watchedWordsLink = #{WordWatcher.word_matcher_regexps(:link).to_json};
__optInput.additionalOptions = #{Site.markdown_additional_options.to_json};
JS JS
if opts[:topic_id] if opts[:topic_id]

View File

@ -466,6 +466,9 @@
"null" "null"
] ]
}, },
"markdown_additional_options" : {
"type": "object"
},
"categories": { "categories": {
"type": "array", "type": "array",
"items": [ "items": [