Rename Infinity list to Data list

This commit is contained in:
Insality 2021-04-01 22:02:15 +03:00
parent 03a00fe3d2
commit 72efdc13bf
3 changed files with 33 additions and 33 deletions

View File

@ -4,10 +4,10 @@ local const = require("druid.const")
local helper = require("druid.helper") local helper = require("druid.helper")
local component = require("druid.component") local component = require("druid.component")
local M = component.create("infinity_list") local DataList = component.create("data_list")
function M:init(data_list, scroll, grid, create_function) function DataList.init(self, data, scroll, grid, create_function)
self.view_size = gui.get_size(scroll.view_node) self.view_size = gui.get_size(scroll.view_node)
self.prefab_size = grid.node_size self.prefab_size = grid.node_size
self.druid = self:get_druid() self.druid = self:get_druid()
@ -28,23 +28,23 @@ function M:init(data_list, scroll, grid, create_function)
self.scroll.on_scroll:subscribe(self._check_elements, self) self.scroll.on_scroll:subscribe(self._check_elements, self)
self:set_data(data_list) self:set_data(data)
end end
function M:on_remove() function DataList.on_remove(self)
self.scroll.on_scroll:unsubscribe(self._check_elements, self) self.scroll.on_scroll:unsubscribe(self._check_elements, self)
end end
function M:set_data(data_list) function DataList.set_data(self, data)
self._data = data_list self._data = data
self:_update_data_info() self:_update_data_info()
self:_refresh() self:_refresh()
end end
function M:add(data, index, shift_policy) function DataList.add(self, data, index, shift_policy)
index = index or self._data_last_index + 1 index = index or self._data_last_index + 1
shift_policy = shift_policy or const.SHIFT.RIGHT shift_policy = shift_policy or const.SHIFT.RIGHT
@ -66,13 +66,13 @@ function M:add(data, index, shift_policy)
end end
function M:remove(index, shift_policy) function DataList.remove(self, index, shift_policy)
table.remove(self._data, index) table.remove(self._data, index)
self:_refresh() self:_refresh()
end end
function M:remove_by_data(data, shift_policy) function DataList.remove_by_data(self, data, shift_policy)
local index = helper.contains(self._data, data) local index = helper.contains(self._data, data)
if index then if index then
table.remove(self._data, index) table.remove(self._data, index)
@ -81,28 +81,28 @@ function M:remove_by_data(data, shift_policy)
end end
function M:clear() function DataList.clear(self)
self._data = {} self._data = {}
self:_refresh() self:_refresh()
end end
function M:get_first_index() function DataList.get_first_index(self)
return self._data_first_index return self._data_first_index
end end
function M:get_last_index() function DataList.get_last_index(self)
return self._data_last_index return self._data_last_index
end end
function M:get_length() function DataList.get_length(self)
return self._data_length return self._data_length
end end
function M:get_index(data) function DataList.get_index(self, data)
for index, value in pairs(self._data) do for index, value in pairs(self._data) do
if value == data then if value == data then
return index return index
@ -113,14 +113,14 @@ function M:get_index(data)
end end
function M:scroll_to_index(index) function DataList.scroll_to_index(self, index)
self.top_index = helper.clamp(index, 1, #self._data) self.top_index = helper.clamp(index, 1, #self._data)
self:_refresh() self:_refresh()
self.scroll.on_scroll:trigger(self:get_context(), self) self.scroll.on_scroll:trigger(self:get_context(), self)
end end
function M:_add_at(index) function DataList._add_at(self, index)
if self._data_visual[index] then if self._data_visual[index] then
self:_remove_at(index) self:_remove_at(index)
end end
@ -134,7 +134,7 @@ function M:_add_at(index)
end end
function M:_remove_at(index) function DataList._remove_at(self, index)
self.grid:remove(index, const.SHIFT.NO_SHIFT) self.grid:remove(index, const.SHIFT.NO_SHIFT)
local node = self._data_visual[index].node local node = self._data_visual[index].node
@ -147,7 +147,7 @@ function M:_remove_at(index)
end end
function M:_refresh() function DataList._refresh(self)
for index, _ in pairs(self._data_visual) do for index, _ in pairs(self._data_visual) do
self:_remove_at(index) self:_remove_at(index)
end end
@ -155,7 +155,7 @@ function M:_refresh()
end end
function M:_check_elements() function DataList._check_elements(self)
for index, data in pairs(self._data_visual) do for index, data in pairs(self._data_visual) do
if self.scroll:is_node_in_view(data.node) then if self.scroll:is_node_in_view(data.node) then
self.top_index = index self.top_index = index
@ -173,7 +173,7 @@ function M:_check_elements()
end end
function M:_check_elements_from(index, step) function DataList._check_elements_from(self, index, step)
local is_outside = false local is_outside = false
while not is_outside do while not is_outside do
if not self._data[index] then if not self._data[index] then
@ -202,7 +202,7 @@ function M:_check_elements_from(index, step)
end end
function M:_update_data_info() function DataList._update_data_info(self)
self._data_first_index = false self._data_first_index = false
self._data_last_index = false self._data_last_index = false
self._data_length = 0 self._data_length = 0
@ -220,4 +220,4 @@ function M:_update_data_info()
end end
return M return DataList

View File

@ -53,7 +53,7 @@ local progress = require("druid.extended.progress")
local radio_group = require("druid.extended.radio_group") local radio_group = require("druid.extended.radio_group")
local slider = require("druid.extended.slider") local slider = require("druid.extended.slider")
local timer = require("druid.extended.timer") local timer = require("druid.extended.timer")
local infinity_list = require("druid.extended.infinity_list") local data_list = require("druid.extended.data_list")
local DruidInstance = class("druid.druid_instance") local DruidInstance = class("druid.druid_instance")
@ -542,12 +542,12 @@ function DruidInstance.new_checkbox_group(self, nodes, callback, click_nodes)
end end
--- Create infinity list basic component --- Create data list basic component
-- @function druid:new_infinity_list -- @function druid:new_data_list
-- @tparam args ... drag init args -- @tparam args ... drag init args
-- @treturn Component infinity list component -- @treturn Component data list component
function DruidInstance.new_infinity_list(self, ...) function DruidInstance.new_data_list(self, ...)
return DruidInstance.create(self, infinity_list, ...) return DruidInstance.create(self, data_list, ...)
end end

View File

@ -86,14 +86,14 @@ local function setup_infinity_list(self)
table.insert(data, i) table.insert(data, i)
end end
self.infinity_list = self.druid:new_infinity_list(data, self.infinity_scroll, self.infinity_grid, function(record, index) self.infinity_list = self.druid:new_data_list(data, self.infinity_scroll, self.infinity_grid, function(record, index)
-- function should return gui_node, [druid_component] -- function should return gui_node, [druid_component]
local root, button = create_infinity_instance(self, record, index) local root, button = create_infinity_instance(self, record, index)
button:set_click_zone(self.infinity_scroll.view_node) button:set_click_zone(self.infinity_scroll.view_node)
return root, button return root, button
end) end)
self.infinity_list_hor = self.druid:new_infinity_list(data, self.infinity_scroll_hor, self.infinity_grid_hor, function(record, index) self.infinity_list_hor = self.druid:new_data_list(data, self.infinity_scroll_hor, self.infinity_grid_hor, function(record, index)
-- function should return gui_node, [druid_component] -- function should return gui_node, [druid_component]
local root, button = create_infinity_instance_hor(self, record, index) local root, button = create_infinity_instance_hor(self, record, index)
button:set_click_zone(self.infinity_scroll_hor.view_node) button:set_click_zone(self.infinity_scroll_hor.view_node)
@ -108,12 +108,12 @@ local function setup_infinity_list(self)
end) end)
self.infinity_list_small = self.druid:new_infinity_list(data, self.infinity_scroll_3, self.infinity_grid_3, function(record, index) self.infinity_list_small = self.druid:new_data_list(data, self.infinity_scroll_3, self.infinity_grid_3, function(record, index)
-- function should return gui_node, [druid_component] -- function should return gui_node, [druid_component]
return create_infinity_instance_small(self, record, index) return create_infinity_instance_small(self, record, index)
end) end)
self.infinity_list_dynamic = self.druid:new_infinity_list(data, self.infinity_scroll_dynamic, self.infinity_grid_dynamic, function(record, index) self.infinity_list_dynamic = self.druid:new_data_list(data, self.infinity_scroll_dynamic, self.infinity_grid_dynamic, function(record, index)
-- function should return gui_node, [druid_component] -- function should return gui_node, [druid_component]
return create_infinity_instance_dynamic(self, record, index) return create_infinity_instance_dynamic(self, record, index)
end) end)
@ -122,7 +122,7 @@ local function setup_infinity_list(self)
self.infinity_list_dynamic:scroll_to_index(25) self.infinity_list_dynamic:scroll_to_index(25)
end) end)
self.infinity_list_dynamic_hor = self.druid:new_infinity_list(data, self.infinity_scroll_dynamic_hor, self.infinity_grid_dynamic_hor, function(record, index) self.infinity_list_dynamic_hor = self.druid:new_data_list(data, self.infinity_scroll_dynamic_hor, self.infinity_grid_dynamic_hor, function(record, index)
-- function should return gui_node, [druid_component] -- function should return gui_node, [druid_component]
return create_infinity_instance_dynamic_hor(self, record, index) return create_infinity_instance_dynamic_hor(self, record, index)
end) end)