summaryrefslogtreecommitdiff
path: root/src/config/theme
diff options
context:
space:
mode:
authorNathan Reiner <nathan@nathanreiner.xyz>2024-08-02 20:41:29 +0200
committerNathan Reiner <nathan@nathanreiner.xyz>2024-08-02 20:41:29 +0200
commit219c560c7c0ad9e3960298ec125d4e64637fe84b (patch)
treeb04df9aa63b68739383528a77c229828bdb95773 /src/config/theme
parent595bcac243cb9cdd87e7484ab102c86f3235db8a (diff)
add editor theme and state lua bindings
Diffstat (limited to 'src/config/theme')
-rw-r--r--src/config/theme/bar.rs17
-rw-r--r--src/config/theme/editor/bar.rs8
-rw-r--r--src/config/theme/editor/mod.rs22
-rw-r--r--src/config/theme/mod.rs15
-rw-r--r--src/config/theme/sheetview/bar.rs3
5 files changed, 41 insertions, 24 deletions
diff --git a/src/config/theme/bar.rs b/src/config/theme/bar.rs
index 68a3b13..a28bede 100644
--- a/src/config/theme/bar.rs
+++ b/src/config/theme/bar.rs
@@ -1,16 +1,15 @@
macro_rules! BarTheme {
- ($name:ident, $cfg:expr, $cfg_mut:expr) => {
+ ($name:ident, $type:ty, $cfg:expr, $cfg_mut:expr) => {
use crate::config::theme::style::Style;
use crate::lua::evalsto::EvalTo;
- use crate::state::view::mode::Mode;
use crate::widgets::statusbar::StatusBar;
use mlua::{Lua, UserData};
#[derive(Debug, Default, Clone)]
pub struct $name {
- pub left: EvalTo<Style, Mode>,
- pub middle: EvalTo<Style, Mode>,
- pub right: EvalTo<Style, Mode>,
+ pub left: EvalTo<Style, $type>,
+ pub middle: EvalTo<Style, $type>,
+ pub right: EvalTo<Style, $type>,
}
impl $name {
@@ -22,7 +21,7 @@ macro_rules! BarTheme {
}
}
- pub fn apply(bar: &mut StatusBar, mode: Mode, lua: &Lua) {
+ pub fn apply(bar: &mut StatusBar, mode: $type, lua: &Lua) {
let (left, middle, right) = (
$cfg.left.get(mode, lua).unwrap_or_default().style(),
$cfg.middle.get(mode, lua).unwrap_or_default().style(),
@@ -38,19 +37,19 @@ macro_rules! BarTheme {
impl UserData for $name {
fn add_fields<'lua, F: mlua::prelude::LuaUserDataFields<'lua, Self>>(fields: &mut F) {
fields.add_field_function_get("left", |_, _| Ok($cfg.left.clone()));
- fields.add_field_function_set("left", |_, _, style: EvalTo<Style, Mode>| {
+ fields.add_field_function_set("left", |_, _, style: EvalTo<Style, $type>| {
$cfg_mut.left = style;
Ok(())
});
fields.add_field_function_get("middle", |_, _| Ok($cfg.middle.clone()));
- fields.add_field_function_set("middle", |_, _, style: EvalTo<Style, Mode>| {
+ fields.add_field_function_set("middle", |_, _, style: EvalTo<Style, $type>| {
$cfg_mut.middle = style;
Ok(())
});
fields.add_field_function_get("right", |_, _| Ok($cfg.right.clone()));
- fields.add_field_function_set("right", |_, _, style: EvalTo<Style, Mode>| {
+ fields.add_field_function_set("right", |_, _, style: EvalTo<Style, $type>| {
$cfg_mut.right = style;
Ok(())
});
diff --git a/src/config/theme/editor/bar.rs b/src/config/theme/editor/bar.rs
new file mode 100644
index 0000000..62be7b0
--- /dev/null
+++ b/src/config/theme/editor/bar.rs
@@ -0,0 +1,8 @@
+use crate::config::{theme::bar::BarTheme, GlobalConfig};
+
+BarTheme!(
+ EditorBarTheme,
+ (),
+ GlobalConfig::instance().theme.editor.bar,
+ GlobalConfig::instance_mut().theme.editor.bar
+);
diff --git a/src/config/theme/editor/mod.rs b/src/config/theme/editor/mod.rs
index d9e2b16..662dacc 100644
--- a/src/config/theme/editor/mod.rs
+++ b/src/config/theme/editor/mod.rs
@@ -1,11 +1,16 @@
use mlua::UserData;
+use crate::config::DUMMY_CONFIG;
use crate::lua::evalsto::EvalTo;
use crate::widgets::luaeditor::theme::HighlightTheme;
+use self::bar::EditorBarTheme;
+
use super::super::GlobalConfig;
use super::style::Style;
+pub mod bar;
+
#[derive(Clone, Debug, Default)]
pub struct EditorTheme {
pub background: EvalTo<Style, ()>,
@@ -13,6 +18,7 @@ pub struct EditorTheme {
pub cursor_line: EvalTo<Style, ()>,
pub line_number: EvalTo<Style, ()>,
pub active_line_number: EvalTo<Style, ()>,
+ pub bar: EditorBarTheme,
}
impl EditorTheme {
@@ -23,6 +29,7 @@ impl EditorTheme {
cursor_line: EvalTo::Value(Style::new()),
line_number: EvalTo::Value(Style::new()),
active_line_number: EvalTo::Value(Style::new()),
+ bar: EditorBarTheme::new(),
}
}
}
@@ -65,10 +72,17 @@ impl UserData for EditorTheme {
Ok(())
});
- fields.add_field_function_get("active_line_number", |_, _| Ok(cfg!().active_line_number.clone()));
- fields.add_field_function_set("active_line_number", |_, _, active_line_number: EvalTo<Style, ()>| {
- cfg_mut!().active_line_number = active_line_number;
- Ok(())
+ fields.add_field_function_get("active_line_number", |_, _| {
+ Ok(cfg!().active_line_number.clone())
});
+ fields.add_field_function_set(
+ "active_line_number",
+ |_, _, active_line_number: EvalTo<Style, ()>| {
+ cfg_mut!().active_line_number = active_line_number;
+ Ok(())
+ },
+ );
+
+ fields.add_field_method_get("bar", |_, _| Ok(DUMMY_CONFIG.theme.editor.bar))
}
}
diff --git a/src/config/theme/mod.rs b/src/config/theme/mod.rs
index ca9723b..b714e86 100644
--- a/src/config/theme/mod.rs
+++ b/src/config/theme/mod.rs
@@ -1,14 +1,13 @@
-
use mlua::UserData;
use self::{editor::EditorTheme, sheetview::SheetViewTheme};
use super::DUMMY_CONFIG;
-pub mod style;
-pub mod sheetview;
-pub mod editor;
mod bar;
+pub mod editor;
+pub mod sheetview;
+pub mod style;
#[derive(Clone, Debug, Default)]
pub struct Theme {
@@ -27,12 +26,8 @@ impl Theme {
impl UserData for Theme {
fn add_fields<'lua, F: mlua::prelude::LuaUserDataFields<'lua, Self>>(fields: &mut F) {
- fields.add_field_function_get("sheetview", |_, _| {
- Ok(DUMMY_CONFIG.theme.sheetview)
- });
+ fields.add_field_function_get("sheetview", |_, _| Ok(DUMMY_CONFIG.theme.sheetview));
- fields.add_field_function_get("editor", |_, _| {
- Ok(DUMMY_CONFIG.theme.editor)
- })
+ fields.add_field_function_get("editor", |_, _| Ok(DUMMY_CONFIG.theme.editor))
}
}
diff --git a/src/config/theme/sheetview/bar.rs b/src/config/theme/sheetview/bar.rs
index c3d1d50..b23f785 100644
--- a/src/config/theme/sheetview/bar.rs
+++ b/src/config/theme/sheetview/bar.rs
@@ -1,8 +1,9 @@
use super::super::bar::BarTheme;
-use crate::config::GlobalConfig;
+use crate::{config::GlobalConfig, state::view::mode::Mode};
BarTheme!(
SheetViewBarTheme,
+ Mode,
GlobalConfig::instance().theme.sheetview.bar,
GlobalConfig::instance_mut().theme.sheetview.bar
);