Fallback to broader scope if theme scope not found (#1714)
This commit is contained in:
parent
c484b08923
commit
74a9dd51ff
@ -27,16 +27,15 @@ pub struct Markdown {
|
||||
// better yet, just use Tendril + subtendril for references
|
||||
|
||||
impl Markdown {
|
||||
// theme keys, including fallbacks
|
||||
const TEXT_STYLE: [&'static str; 2] = ["ui.text", "ui"];
|
||||
const BLOCK_STYLE: [&'static str; 3] = ["markup.raw.inline", "markup.raw", "markup"];
|
||||
const HEADING_STYLES: [[&'static str; 3]; 6] = [
|
||||
["markup.heading.1", "markup.heading", "markup"],
|
||||
["markup.heading.2", "markup.heading", "markup"],
|
||||
["markup.heading.3", "markup.heading", "markup"],
|
||||
["markup.heading.4", "markup.heading", "markup"],
|
||||
["markup.heading.5", "markup.heading", "markup"],
|
||||
["markup.heading.6", "markup.heading", "markup"],
|
||||
const TEXT_STYLE: &'static str = "ui.text";
|
||||
const BLOCK_STYLE: &'static str = "markup.raw.inline";
|
||||
const HEADING_STYLES: [&'static str; 6] = [
|
||||
"markup.heading.1",
|
||||
"markup.heading.2",
|
||||
"markup.heading.3",
|
||||
"markup.heading.4",
|
||||
"markup.heading.5",
|
||||
"markup.heading.6",
|
||||
];
|
||||
|
||||
pub fn new(contents: String, config_loader: Arc<syntax::Loader>) -> Self {
|
||||
@ -59,15 +58,9 @@ fn parse(&self, theme: Option<&Theme>) -> tui::text::Text<'_> {
|
||||
let mut spans = Vec::new();
|
||||
let mut lines = Vec::new();
|
||||
|
||||
let get_theme = |keys: &[&str]| match theme {
|
||||
Some(theme) => keys
|
||||
.iter()
|
||||
.find_map(|key| theme.try_get(key))
|
||||
.unwrap_or_default(),
|
||||
None => Default::default(),
|
||||
};
|
||||
let text_style = get_theme(&Self::TEXT_STYLE);
|
||||
let code_style = get_theme(&Self::BLOCK_STYLE);
|
||||
let get_theme = |key: &str| -> Style { theme.map(|t| t.get(key)).unwrap_or_default() };
|
||||
let text_style = get_theme(Self::TEXT_STYLE);
|
||||
let code_style = get_theme(Self::BLOCK_STYLE);
|
||||
let heading_styles: Vec<Style> = Self::HEADING_STYLES
|
||||
.iter()
|
||||
.map(|key| get_theme(key))
|
||||
|
@ -153,8 +153,12 @@ pub fn get(&self, scope: &str) -> Style {
|
||||
self.try_get(scope).unwrap_or_default()
|
||||
}
|
||||
|
||||
/// Get the style of a scope, falling back to dot separated broader
|
||||
/// scopes. For example if `ui.text.focus` is not defined in the theme,
|
||||
/// `ui.text` is tried and then `ui` is tried.
|
||||
pub fn try_get(&self, scope: &str) -> Option<Style> {
|
||||
self.styles.get(scope).copied()
|
||||
std::iter::successors(Some(scope), |s| Some(s.rsplit_once('.')?.0))
|
||||
.find_map(|s| self.styles.get(s).copied())
|
||||
}
|
||||
|
||||
#[inline]
|
||||
|
Loading…
Reference in New Issue
Block a user