Skip to content

Commit

Permalink
feat: add new layout strategy
Browse files Browse the repository at this point in the history
  • Loading branch information
tjdevries committed May 15, 2021
1 parent b78d4ef commit 100d18a
Show file tree
Hide file tree
Showing 5 changed files with 189 additions and 40 deletions.
102 changes: 67 additions & 35 deletions lua/telescope/pickers/layout_strategies.lua
Original file line number Diff line number Diff line change
Expand Up @@ -61,38 +61,7 @@
local config = require('telescope.config')
local resolve = require("telescope.config.resolve")

local function get_initial_window_options(picker)
local popup_border = resolve.win_option(picker.window.border)
local popup_borderchars = resolve.win_option(picker.window.borderchars)

local preview = {
title = picker.preview_title,
border = popup_border.preview,
borderchars = popup_borderchars.preview,
enter = false,
highlight = false
}

local results = {
title = picker.results_title,
border = popup_border.results,
borderchars = popup_borderchars.results,
enter = false,
}

local prompt = {
title = picker.prompt_title,
border = popup_border.prompt,
borderchars = popup_borderchars.prompt,
enter = true
}

return {
preview = preview,
results = results,
prompt = prompt,
}
end
local p_window = require('telescope.pickers.window')


-- Check if there are any borders. Right now it's a little raw as
Expand Down Expand Up @@ -139,7 +108,7 @@ layout_strategies.horizontal = function(self, max_columns, max_lines)
scroll_speed = "The speed when scrolling through the previewer",
})

local initial_options = get_initial_window_options(self)
local initial_options = p_window.get_initial_window_options(self)
local preview = initial_options.preview
local results = initial_options.results
local prompt = initial_options.prompt
Expand Down Expand Up @@ -237,7 +206,7 @@ end
--- +--------------+
--- </pre>
layout_strategies.center = function(self, columns, lines)
local initial_options = get_initial_window_options(self)
local initial_options = p_window.get_initial_window_options(self)
local preview = initial_options.preview
local results = initial_options.results
local prompt = initial_options.prompt
Expand Down Expand Up @@ -307,7 +276,7 @@ layout_strategies.vertical = function(self, max_columns, max_lines)
scroll_speed = "The speed when scrolling through the previewer",
})

local initial_options = get_initial_window_options(self)
local initial_options = p_window.get_initial_window_options(self)
local preview = initial_options.preview
local results = initial_options.results
local prompt = initial_options.prompt
Expand Down Expand Up @@ -447,4 +416,67 @@ layout_strategies.current_buffer = function(self, _, _)
}
end

layout_strategies.bottom_pane = function(self, max_columns, max_lines)
local layout_config = validate_layout_config(self.layout_config or {}, {
height = "The height of the layout",
})

local initial_options = p_window.get_initial_window_options(self)
local results = initial_options.results
local prompt = initial_options.prompt
local preview = initial_options.preview

local result_height = layout_config.height or 25

local prompt_width = max_columns
local col = 0

local has_border = not not self.window.border
if has_border then
col = 1
prompt_width = prompt_width - 2
end

local result_width
if self.previewer then
result_width = math.floor(prompt_width / 2)

local base_col = result_width + 1
if has_border then
preview = vim.tbl_deep_extend("force", {
col = base_col + 2,
line = max_lines - result_height + 1,
width = prompt_width - result_width - 2,
height = result_height - 1,
}, preview)
else
preview = vim.tbl_deep_extend("force", {
col = base_col,
line = max_lines - result_height,
width = prompt_width - result_width,
height = result_height,
}, preview)
end
else
preview = nil
result_width = prompt_width
end

return {
preview = preview,
prompt = vim.tbl_deep_extend("force", prompt, {
line = max_lines - result_height - 1,
col = col,
height = 1,
width = prompt_width,
}),
results = vim.tbl_deep_extend("force", results, {
line = max_lines - result_height,
col = col,
height = result_height,
width = result_width,
}),
}
end

return layout_strategies
37 changes: 35 additions & 2 deletions lua/telescope/pickers/window.lua
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
local p_layouts = require('telescope.pickers.layout_strategies')
local resolve = require("telescope.config.resolve")

local p_window = {}

function p_window.get_window_options(picker, max_columns, max_lines)
local layout_strategy = picker.layout_strategy
local getter = p_layouts[layout_strategy]
local getter = require('telescope.pickers.layout_strategies')[layout_strategy]

if not getter then
error("Not a valid layout strategy: " .. layout_strategy)
Expand All @@ -13,5 +13,38 @@ function p_window.get_window_options(picker, max_columns, max_lines)
return getter(picker, max_columns, max_lines)
end

function p_window.get_initial_window_options(picker)
local popup_border = resolve.win_option(picker.window.border)
local popup_borderchars = resolve.win_option(picker.window.borderchars)

local preview = {
title = picker.preview_title,
border = popup_border.preview,
borderchars = popup_borderchars.preview,
enter = false,
highlight = false
}

local results = {
title = picker.results_title,
border = popup_border.results,
borderchars = popup_borderchars.results,
enter = false,
}

local prompt = {
title = picker.prompt_title,
border = popup_border.prompt,
borderchars = popup_borderchars.prompt,
enter = true
}

return {
preview = preview,
results = results,
prompt = prompt,
}
end


return p_window
58 changes: 55 additions & 3 deletions lua/telescope/themes.lua
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,27 @@
-- Currently certain designs need a number of parameters.
--
-- local opts = themes.get_dropdown { winblend = 3 }
--

---@tag telescope.themes

---@brief [[
--- Themes are ways to combine several elements of styling together.
---
--- They are helpful for managing the several differnt UI aspects for telescope and provide
--- a simple interface for users to get a particular "style" of picker.
---@brief ]]

local themes = {}

--- Dropdown style theme.
--- <pre>
---
--- Usage:
---
--- `local builtin = require('telescope.builtin')`
--- `local themes = require('telescope.themes')`
--- `builtin.find_files(themes.get_dropdown())`
--- </pre>
function themes.get_dropdown(opts)
opts = opts or {}

Expand All @@ -21,14 +38,49 @@ function themes.get_dropdown(opts)
width = 80,
results_height = 15,
borderchars = {
{ '', '', '', '', '', '', '', ''},
{ "", "", "", "", "", "", "", ""},
prompt = {"", "", " ", "", "", "", "", ""},
results = {"", "", "", "", "", "", "", ""},
preview = { '', '', '', '', '', '', '', ''},
preview = { "", "", "", "", "", "", "", ""},
},
}

return vim.tbl_deep_extend("force", theme_opts, opts)
end

--- Ivy style theme.
--- <pre>
---
--- Usage:
---
--- `local builtin = require('telescope.builtin')`
--- `local themes = require('telescope.themes')`
--- `builtin.find_files(themes.get_ivy())`
--- </pre>
function themes.get_ivy(opts)
opts = opts or {}

return vim.tbl_deep_extend("force", {
theme = "ivy",

sorting_strategy = "ascending",

preview_title = "",

layout_strategy = "bottom_pane",
layout_config = {
height = 25,
},

border = true,
borderchars = {
"z",
prompt = { "", " ", " ", " ", "", "", " ", " " },
results = { " " },
-- results = { "a", "b", "c", "d", "e", "f", "g", "h" },
preview = { "", "", "", "", "", "", "", ""},
},
}, opts)
end

return themes
31 changes: 31 additions & 0 deletions scratch/ivy.lua
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@

RELOAD('telescope')
require('telescope.builtin').find_files(require('telescope.themes').get_ivy { previewer = false })




























1 change: 1 addition & 0 deletions scripts/gendocs.lua
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ docs.test = function()
"./lua/telescope/actions/state.lua",
"./lua/telescope/actions/set.lua",
"./lua/telescope/previewers/init.lua",
"./lua/telescope/themes.lua",
}

table.sort(input_files, function(a, b)
Expand Down

0 comments on commit 100d18a

Please sign in to comment.