From 27e0397e6b4e79e131c474522b28796a5bb2644a Mon Sep 17 00:00:00 2001 From: Insality Date: Thu, 26 Sep 2019 00:03:53 +0300 Subject: [PATCH 1/3] cherry-pick simple-checkbox component --- druid/base/checkbox.lua | 44 +++++++++++++++++++++++++++++++++++++++++ druid/druid.lua | 1 + 2 files changed, 45 insertions(+) create mode 100644 druid/base/checkbox.lua diff --git a/druid/base/checkbox.lua b/druid/base/checkbox.lua new file mode 100644 index 0000000..cf149ff --- /dev/null +++ b/druid/base/checkbox.lua @@ -0,0 +1,44 @@ +--- Druid checkbox component +-- @module base.checkbox + +local helper = require("druid.helper") + +local M = {} + + +local function state_animate(node, state) + local target = state and 1 or 0 + gui.animate(node, "color.w", target, gui.EASING_OUTSINE, 0.1) +end + + +function M.set_state(self, state, is_silence) + if self.state == state then + return + end + + self.state = state + state_animate(self.node, state) + + if not is_silence and self.callback then + self.callback(self.parent.parent, state) + end +end + + +-- TODO: pass self as first parameter +local function on_click(context, self) + M.set_state(self, not self.state) +end + + +function M.init(self, node, callback, click_node) + self.node = helper.get_node(node) + self.click_node = helper.get_node(click_node) + self.callback = callback + self.button = self.parent:new_button(self.click_node or self.node, on_click, self) + M.set_state(self, false, true) +end + + +return M diff --git a/druid/druid.lua b/druid/druid.lua index ad3618c..93c0100 100644 --- a/druid/druid.lua +++ b/druid/druid.lua @@ -15,6 +15,7 @@ M.comps = { progress = require("druid.base.progress"), grid = require("druid.base.grid"), scroll = require("druid.base.scroll"), + checkbox = require("druid.base.checkbox"), progress_rich = require("druid.rich.progress_rich"), } From 2d3ef5f6c3690b40b4c8bfb96b9765db8ccabe26 Mon Sep 17 00:00:00 2001 From: Insality Date: Thu, 26 Sep 2019 00:46:42 +0300 Subject: [PATCH 2/3] cherry-pick checkbox_group component --- druid/base/checkbox.lua | 6 +++++ druid/base/checkbox_group.lua | 47 +++++++++++++++++++++++++++++++++++ druid/druid.lua | 1 + 3 files changed, 54 insertions(+) create mode 100644 druid/base/checkbox_group.lua diff --git a/druid/base/checkbox.lua b/druid/base/checkbox.lua index cf149ff..0b3dbb2 100644 --- a/druid/base/checkbox.lua +++ b/druid/base/checkbox.lua @@ -26,6 +26,11 @@ function M.set_state(self, state, is_silence) end +function M.get_state(self) + return self.state +end + + -- TODO: pass self as first parameter local function on_click(context, self) M.set_state(self, not self.state) @@ -36,6 +41,7 @@ function M.init(self, node, callback, click_node) self.node = helper.get_node(node) self.click_node = helper.get_node(click_node) self.callback = callback + self.button = self.parent:new_button(self.click_node or self.node, on_click, self) M.set_state(self, false, true) end diff --git a/druid/base/checkbox_group.lua b/druid/base/checkbox_group.lua new file mode 100644 index 0000000..459527e --- /dev/null +++ b/druid/base/checkbox_group.lua @@ -0,0 +1,47 @@ +local M = {} + + +local function on_checkbox_click(self, index) + if self.is_radio_mode then + for i = 1, #self.checkboxes do + self.checkboxes[i]:set_state(i == index, true) + end + end +end + + +function M.set_state(self, indexes) + for i = 1, #indexes do + if self.checkbox[indexes[i]] then + self.checkbox[indexes[i]]:set_state(true, true) + end + end +end + + +function M.get_state(self) + local result = {} + + for i = 1, #self.checkboxes do + table.insert(result, self.checkboxes[i]:get_state()) + end + + return result +end + + +function M.init(self, nodes, callback, is_radio_mode, anim_nodes) + self.is_radio_mode = is_radio_mode + self.checkboxes = {} + + for i = 1, #nodes do + local anim_node = anim_nodes and anim_nodes[i] or nil + local checkbox = self.parent:new_checkbox(nodes[i], function() + on_checkbox_click(self, i) + end, anim_node) + table.insert(self.checkboxes, checkbox) + end +end + + +return M diff --git a/druid/druid.lua b/druid/druid.lua index 93c0100..dad7c05 100644 --- a/druid/druid.lua +++ b/druid/druid.lua @@ -16,6 +16,7 @@ M.comps = { grid = require("druid.base.grid"), scroll = require("druid.base.scroll"), checkbox = require("druid.base.checkbox"), + checkbox_group = require("druid.base.checkbox_group"), progress_rich = require("druid.rich.progress_rich"), } From 05dd08b14916d15dbc03967bf5b20084f9c49f99 Mon Sep 17 00:00:00 2001 From: Insality Date: Thu, 26 Sep 2019 08:45:58 +0300 Subject: [PATCH 3/3] cherry-pick update checkbox_group --- druid/base/checkbox_group.lua | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/druid/base/checkbox_group.lua b/druid/base/checkbox_group.lua index 459527e..5510a5f 100644 --- a/druid/base/checkbox_group.lua +++ b/druid/base/checkbox_group.lua @@ -1,11 +1,12 @@ +--- Checkboux group module +-- @module base.checkbox_group + local M = {} local function on_checkbox_click(self, index) - if self.is_radio_mode then - for i = 1, #self.checkboxes do - self.checkboxes[i]:set_state(i == index, true) - end + if self.callback then + self.callback(self.parent.parent, index) end end @@ -30,15 +31,16 @@ function M.get_state(self) end -function M.init(self, nodes, callback, is_radio_mode, anim_nodes) - self.is_radio_mode = is_radio_mode +function M.init(self, nodes, callback, click_nodes) self.checkboxes = {} + self.callback = callback for i = 1, #nodes do - local anim_node = anim_nodes and anim_nodes[i] or nil + local click_node = click_nodes and click_nodes[i] or nil local checkbox = self.parent:new_checkbox(nodes[i], function() on_checkbox_click(self, i) - end, anim_node) + end, click_node) + table.insert(self.checkboxes, checkbox) end end