Refactor oil more, we now have more generic functions which we can reuse when creating the sticky terminal panel

This commit is contained in:
Martin Larsson 2024-05-26 18:11:30 +02:00
parent 761f6e3e59
commit d1ed3fddb6
2 changed files with 6 additions and 45 deletions

View file

@ -3,33 +3,6 @@ local utils = require("utils")
local oil = nil
local oil_window = nil
local function lock_oil_buf_to_window(bufnr)
local augroup_id = vim.api.nvim_create_augroup("LockOil" .. oil_window, { clear = true })
-- Create an autocommand group to manage the buffer lock
vim.api.nvim_create_autocmd("BufEnter", {
group = augroup_id,
callback = function()
local current_win = vim.api.nvim_get_current_win()
if current_win ~= oil_window then
return
end
local current_buf = vim.api.nvim_win_get_buf(oil_window)
if current_buf == bufnr then
return
end
if utils.is_buf_filetype(current_buf, "oil") then
bufnr = current_buf
return
end
vim.api.nvim_win_set_buf(oil_window, bufnr)
end,
})
end
local function toggle_oil_window()
if oil_window and vim.api.nvim_win_is_valid(oil_window) then
vim.api.nvim_win_close(oil_window, true)
@ -42,20 +15,17 @@ local function toggle_oil_window()
local width_percentage = 0.175
local min_width = 30
local max_width = 50
local calculated_width = math.floor(term_width * width_percentage)
local final_width = math.min(math.max(calculated_width, min_width), max_width)
local width = utils.calculate_split_size(term_width, width_percentage, min_width, max_width)
-- Open a vertical split with the calculated width on the left and open oil.nvim
vim.cmd("topleft vertical " .. final_width .. "vnew")
vim.cmd("topleft vertical " .. width .. "vnew")
oil_window = vim.api.nvim_get_current_win()
vim.api.nvim_win_set_option(oil_window, "winfixwidth", true)
vim.api.nvim_win_set_option(oil_window, "winhighlight",
"Normal:Utility,FloatBorder:Utility")
vim.api.nvim_win_set_option(oil_window, "winhighlight", "Normal:Utility,FloatBorder:Utility")
oil.open()
local oil_buf_id = vim.api.nvim_get_current_buf()
lock_oil_buf_to_window(oil_buf_id)
utils.lock_buf_to_window(oil_window, oil_buf_id, "oil")
end
return {

View file

@ -8,20 +8,11 @@ function M.add_keymaps(maps)
end
end
function M.get_bufnr_for_filetype(filetype)
for _, bufnr in ipairs(vim.api.nvim_list_bufs()) do
if vim.api.nvim_buf_is_loaded(bufnr) and M.is_buf_filetype(bufnr, filetype) then
return bufnr
end
end
return nil
end
function M.is_buf_filetype(bufnr, filetype)
return vim.api.nvim_buf_get_option(bufnr, "filetype") == filetype
end
function M.lock_buf_to_window(win_id, bufnr, filetype_check)
function M.lock_buf_to_window(win_id, bufnr, filetype)
local augroup_id = vim.api.nvim_create_augroup("LockWindow" .. win_id, { clear = true })
vim.api.nvim_create_autocmd("BufEnter", {
@ -37,7 +28,7 @@ function M.lock_buf_to_window(win_id, bufnr, filetype_check)
return
end
if filetype_check and filetype_check(current_buf) then
if M.is_buf_filetype(current_buf, filetype) then
bufnr = current_buf
return
end