From 0190b66958bcd3618ec07008e1c170d78445ba2d Mon Sep 17 00:00:00 2001 From: Ottatop Date: Fri, 4 Aug 2023 16:28:17 -0500 Subject: [PATCH] Add output location helper methods --- api/lua/doc/output.lua | 32 +++++++++ api/lua/doc/tag.lua | 9 --- api/lua/output.lua | 142 +++++++++++++++++++++++++++++++++++++++- api/lua/test_config.lua | 7 +- 4 files changed, 174 insertions(+), 16 deletions(-) diff --git a/api/lua/doc/output.lua b/api/lua/doc/output.lua index 519bf93..e6213f4 100644 --- a/api/lua/doc/output.lua +++ b/api/lua/doc/output.lua @@ -219,3 +219,35 @@ function output:focused() end ---dp2:set_loc({ x = 2560, y = 1440 - 1080 }) ---@tparam table loc A table of the form `{ x: integer?, y: integer? }` function output:set_loc(loc) end + +---Set this output's location to the right of `op`. +--- +---This will fail if `op` is an invalid output. +---@tparam Output op +---@tparam[opt="top"] string alignment One of `top`, `center`, or `bottom`. This is how you want to align the `self` output. +---@see Output.set_loc +function output:set_loc_right_of(op, alignment) end + +---Set this output's location to the left of `op`. +--- +---This will fail if `op` is an invalid output. +---@tparam Output op +---@tparam[opt="top"] string alignment One of `top`, `center`, or `bottom`. This is how you want to align the `self` output. +---@see Output.set_loc +function output:set_loc_left_of(op, alignment) end + +---Set this output's location to the top of `op`. +--- +---This will fail if `op` is an invalid output. +---@tparam Output op +---@tparam[opt="left"] string alignment One of `left`, `center`, or `right`. This is how you want to align the `self` output. +---@see Output.set_loc +function output:set_loc_top_of(op, alignment) end + +---Set this output's location to the bottom of `op`. +--- +---This will fail if `op` is an invalid output. +---@tparam Output op +---@tparam[opt="left"] string alignment One of `left`, `center`, or `right`. This is how you want to align the `self` output. +---@see Output.set_loc +function output:set_loc_bottom_of(op, alignment) end diff --git a/api/lua/doc/tag.lua b/api/lua/doc/tag.lua index a2bdc56..f1c9518 100644 --- a/api/lua/doc/tag.lua +++ b/api/lua/doc/tag.lua @@ -4,15 +4,6 @@ ---@module TagModule local tag_module = {} ----@alias Layout ----| "MasterStack" # One master window on the left with all other windows stacked to the right. ----| "Dwindle" # Windows split in half towards the bottom right corner. ----| "Spiral" # Windows split in half in a spiral. ----| "CornerTopLeft" # One main corner window in the top left with a column of windows on the right and a row on the bottom. ----| "CornerTopRight" # One main corner window in the top right with a column of windows on the left and a row on the bottom. ----| "CornerBottomLeft" # One main corner window in the bottom left with a column of windows on the right and a row on the top. ----| "CornerBottomRight" # One main corner window in the bottom right with a column of windows on the left and a row on the top. - ---Add tags to the specified output. --- ---@usage diff --git a/api/lua/output.lua b/api/lua/output.lua index bae47d0..0004d8d 100644 --- a/api/lua/output.lua +++ b/api/lua/output.lua @@ -115,9 +115,149 @@ end ---``` ---@param loc { x: integer?, y: integer? } function output:set_loc(loc) - return output_module.set_loc(self, loc) + output_module.set_loc(self, loc) end +-- TODO: move this into own file or something --------------------------------------------- + +---@alias AlignmentVertical +---| "top" Align the tops of the outputs +---| "center" Center the outputs vertically +---| "bottom" Align the bottoms of the outputs + +---@alias AlignmentHorizontal +---| "left" Align the left edges of the outputs +---| "center" Center the outputs vertically +---| "right" Align the right edges of the outputs + +---@param op1 Output +---@param op2 Output +---@param left_or_right "left" | "right" +---@param alignment AlignmentVertical? How you want to align the `self` output. Defaults to `top`. +local function set_loc_horizontal(op1, op2, left_or_right, alignment) + local alignment = alignment or "top" + local self_loc = op1:loc() + local self_res = op1:res() + local other_loc = op2:loc() + local other_res = op2:res() + + if + self_loc == nil + or self_res == nil + or other_loc == nil + or other_res == nil + then + return + end + + ---@type integer + local x + if left_or_right == "left" then + x = other_loc.x - self_res.w + else + x = other_loc.x + other_res.w + end + + if alignment == "top" then + output_module.set_loc(op1, { x = x, y = other_loc.y }) + elseif alignment == "center" then + output_module.set_loc( + op1, + { x = x, y = other_loc.y + (other_res.h - self_res.h) // 2 } + ) + elseif alignment == "bottom" then + output_module.set_loc( + op1, + { x = x, y = other_loc.y + (other_res.h - self_res.h) } + ) + end +end + +---Set this output's location to the right of the specified output. +--- +---This will fail if `op` is an invalid output. +---@param op Output +---@param alignment AlignmentVertical? How you want to align the `self` output. Defaults to `top`. +---@see Output.set_loc if you need more granular control +function output:set_loc_right_of(op, alignment) + set_loc_horizontal(self, op, "right", alignment) +end + +---Set this output's location to the left of the specified output. +--- +---This will fail if `op` is an invalid output. +---@param op Output +---@param alignment AlignmentVertical? How you want to align the `self` output. Defaults to `top`. +---@see Output.set_loc if you need more granular control +function output:set_loc_left_of(op, alignment) + set_loc_horizontal(self, op, "left", alignment) +end + +---@param op1 Output +---@param op2 Output +---@param top_or_bottom "top" | "bottom" +---@param alignment AlignmentHorizontal? How you want to align the `self` output. Defaults to `top`. +local function set_loc_vertical(op1, op2, top_or_bottom, alignment) + local alignment = alignment or "left" + local self_loc = op1:loc() + local self_res = op1:res() + local other_loc = op2:loc() + local other_res = op2:res() + + if + self_loc == nil + or self_res == nil + or other_loc == nil + or other_res == nil + then + return + end + + ---@type integer + local y + if top_or_bottom == "top" then + y = other_loc.y - self_res.h + else + y = other_loc.y + other_res.h + end + + if alignment == "left" then + output_module.set_loc(op1, { x = other_loc.x, y = y }) + elseif alignment == "center" then + output_module.set_loc( + op1, + { x = other_loc.x + (other_res.w - self_res.w) // 2, y = y } + ) + elseif alignment == "right" then + output_module.set_loc( + op1, + { x = other_loc.x + (other_res.w - self_res.w), y = y } + ) + end +end + +---Set this output's location to the top of the specified output. +--- +---This will fail if `op` is an invalid output. +---@param op Output +---@param alignment AlignmentHorizontal? How you want to align the `self` output. Defaults to `left`. +---@see Output.set_loc if you need more granular control +function output:set_loc_top_of(op, alignment) + set_loc_vertical(self, op, "top", alignment) +end + +---Set this output's location to the bottom of the specified output. +--- +---This will fail if `op` is an invalid output. +---@param op Output +---@param alignment AlignmentHorizontal? How you want to align the `self` output. Defaults to `left`. +---@see Output.set_loc if you need more granular control +function output:set_loc_bottom_of(op, alignment) + set_loc_vertical(self, op, "bottom", alignment) +end + +-- TODO: ---------------------------------------------------------------------------------- + ------------------------------------------------------ ---Get an output by its name. diff --git a/api/lua/test_config.lua b/api/lua/test_config.lua index ccb097a..796b522 100644 --- a/api/lua/test_config.lua +++ b/api/lua/test_config.lua @@ -68,13 +68,8 @@ require("pinnacle").setup(function(pinnacle) input.keybind({ mod_key }, keys.h, function() local dp2 = output.get_by_name("DP-2") local dp3 = output.get_by_name("DP-3") - output.set_loc(dp2, { x = 1920, y = 0 }) - output.set_loc(dp3, { x = 0, y = 1440 - 1080 }) - local dp2loc = dp2:loc() - local dp3loc = dp3:loc() - print("dp2: " .. dp2loc.x .. ", " .. dp2loc.y) - print("dp3: " .. dp3loc.x .. ", " .. dp3loc.y) + dp2:set_loc_bottom_of(dp3, "right") -- local win = window.get_focused() -- if win ~= nil then