Skip to content

Commit

Permalink
Merge pull request #84 from oskarrrrrrr/preview_window_size_settings
Browse files Browse the repository at this point in the history
Improve preview window size calculation
  • Loading branch information
hedyhli authored Aug 22, 2024
2 parents d31ffcf + 32b5c96 commit 1469fe2
Show file tree
Hide file tree
Showing 4 changed files with 42 additions and 15 deletions.
7 changes: 6 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -300,12 +300,17 @@ Pass a table to the setup call with your configuration options.
-- below.
open_hover_on_preview = false,
width = 50, -- Percentage or integer of columns
min_width = 50, -- This is the number of columns
min_width = 50, -- Minimum number of columns
-- Whether width is relative to the total width of nvim.
-- When relative_width = true, this means take 50% of the total
-- screen width for preview window, ensure the result width is at least 50
-- characters wide.
relative_width = true,
height = 50, -- Percentage or integer of lines
min_height = 10, -- Minimum number of lines
-- Similar to relative_width, except the height is relative to the outline
-- window's height.
relative_height = true,
-- Border option for floating preview window.
-- Options include: single/double/rounded/solid/shadow or an array of border
-- characters.
Expand Down
5 changes: 5 additions & 0 deletions doc/outline.txt
Original file line number Diff line number Diff line change
Expand Up @@ -257,6 +257,11 @@ Show defaults ~
-- screen width for preview window, ensure the result width is at least 50
-- characters wide.
relative_width = true,
height = 50, -- Percentage or integer of lines
min_height = 10, -- Minimum number of lines
-- Similar to relative_width, except the height is relative to the outline
-- window's height.
relative_height = true,
-- Border option for floating preview window.
-- Options include: single/double/rounded/solid/shadow or an array of border
-- characters.
Expand Down
31 changes: 23 additions & 8 deletions lua/outline/config.lua
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,9 @@ M.defaults = {
width = 50,
min_width = 50,
relative_width = true,
height = 50,
min_height = 10,
relative_height = true,
border = 'single',
open_hover_on_preview = false,
winhl = 'NormalFloat:',
Expand Down Expand Up @@ -162,16 +164,31 @@ function M.get_window_width()
return M.o.outline_window.width
end

function M.get_preview_width()
if M.o.preview_window.relative_width then
---@param conf table
function M.get_preview_width(conf)
if conf.relative_width then
local relative_width = math.max(
math.ceil(vim.o.columns * (M.o.preview_window.width / 100)),
M.o.preview_window.min_width
math.ceil(vim.o.columns * (conf.width / 100)),
conf.min_width
)

return relative_width
else
return M.o.preview_window.width
return conf.width
end
end

---@param conf table
---@param outline_height integer
---@return integer
function M.get_preview_height(conf, outline_height)
if conf.relative_height then
local relative_height = math.max(
math.ceil(outline_height * (conf.height / 100)),
conf.min_height
)
return relative_height
else
return conf.height
end
end

Expand Down Expand Up @@ -318,8 +335,6 @@ function M.resolve_config()
M.o.keymaps[action] = { keys }
end
end
----- PREVIEW -----
M.o.preview_window.width = M.get_preview_width()
----- WINDOW -----
M.o.outline_window.width = M.get_window_width()
----- LSP BLACKLIST -----
Expand Down
14 changes: 8 additions & 6 deletions lua/outline/preview.lua
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
local cfg = require('outline.config')

-- A floating window to preview the location of a symbol from the outline.
-- Classical preview reads entire lines into a new buffer for preview. Live
-- preview sets the buffer of floating window to the code buffer, which allows
Expand Down Expand Up @@ -95,8 +97,8 @@ local function update_size(self)
end

self.outline_height = vim.api.nvim_win_get_height(self.s.view.win)
self.width = self.conf.width
self.height = math.max(math.ceil(self.outline_height / 2), self.conf.min_height)
self.width = cfg.get_preview_width(self.conf)
self.height = cfg.get_preview_height(self.conf, self.outline_height)
local row = calc_row(self)
local col = calc_col(self)
vim.api.nvim_win_set_config(self.win, {
Expand All @@ -117,8 +119,8 @@ function Preview:create()
end,
})
self.outline_height = vim.api.nvim_win_get_height(self.s.view.win)
self.width = self.conf.width
self.height = math.max(math.ceil(self.outline_height / 2), self.conf.min_height)
self.width = cfg.get_preview_width(self.conf)
self.height = cfg.get_preview_height(self.conf, self.outline_height)
self.win = vim.api.nvim_open_win(self.buf, false, {
relative = 'editor',
height = self.height,
Expand Down Expand Up @@ -221,8 +223,8 @@ function LivePreview:create()
self.codewin = self.s.code.win
self.initial_cursorline = vim.api.nvim_win_get_option(self.s.code.win, 'cursorline')
self.outline_height = vim.api.nvim_win_get_height(self.s.view.win)
self.width = self.conf.width
self.height = math.max(math.ceil(self.outline_height / 2), self.conf.min_height)
self.width = cfg.get_preview_width(self.conf)
self.height = cfg.get_preview_height(self.conf, self.outline_height)
self.win = vim.api.nvim_open_win(self.s.code.buf, false, {
relative = 'editor',
height = self.height,
Expand Down

0 comments on commit 1469fe2

Please sign in to comment.