pinnacle/api/lua/tag.lua

290 lines
7.7 KiB
Lua
Raw Normal View History

2023-07-01 04:34:07 +02:00
-- This Source Code Form is subject to the terms of the Mozilla Public
-- License, v. 2.0. If a copy of the MPL was not distributed with this
-- file, You can obtain one at https://mozilla.org/MPL/2.0/.
--
-- SPDX-License-Identifier: MPL-2.0
2023-07-18 19:37:40 +02:00
local tag = {}
2023-07-13 01:50:41 +02:00
---@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.
2023-07-18 03:40:56 +02:00
---| "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.
2023-07-13 01:50:41 +02:00
2023-07-18 17:31:08 +02:00
---@class Tag
2023-07-20 22:22:22 +02:00
---@field private _id integer The internal id of this tag.
2023-07-18 17:31:08 +02:00
local tg = {}
2023-07-20 22:22:22 +02:00
---@param tag_id integer
2023-07-18 17:31:08 +02:00
---@return Tag
2023-07-20 22:22:22 +02:00
local function new_tag(tag_id)
---@type Tag
local t = { _id = tag_id }
2023-07-18 17:31:08 +02:00
-- Copy functions over
for k, v in pairs(tg) do
2023-07-20 22:22:22 +02:00
t[k] = v
2023-07-18 17:31:08 +02:00
end
2023-07-20 22:22:22 +02:00
return t
end
---Get this tag's internal id.
---@return integer
function tg:id()
return self._id
2023-07-18 17:31:08 +02:00
end
2023-07-18 19:37:40 +02:00
---Get this tag's active status.
2023-07-20 01:55:22 +02:00
---@return boolean|nil active `true` if the tag is active, `false` if not, and `nil` if the tag doesn't exist.
2023-07-18 19:37:40 +02:00
function tg:active()
SendRequest({
GetTagActive = {
2023-07-20 22:22:22 +02:00
tag_id = self._id,
2023-07-18 19:37:40 +02:00
},
})
local response = ReadMsg()
local active = response.RequestResponse.response.TagActive.active
return active
end
2023-07-20 01:55:22 +02:00
---Get this tag's name.
---@return string|nil name The name of this tag, or nil if it doesn't exist.
2023-07-18 19:37:40 +02:00
function tg:name()
SendRequest({
GetTagName = {
2023-07-20 22:22:22 +02:00
tag_id = self._id,
2023-07-18 19:37:40 +02:00
},
})
local response = ReadMsg()
local name = response.RequestResponse.response.TagName.name
return name
end
2023-07-20 01:55:22 +02:00
---Get this tag's output.
---@return Output|nil output The output this tag is on, or nil if the tag doesn't exist.
function tg:output()
2023-07-20 22:22:22 +02:00
return require("output").get_for_tag(self)
2023-07-20 01:55:22 +02:00
end
2023-07-18 19:37:40 +02:00
---Set this tag's layout.
---@param layout Layout
function tg:set_layout(layout) -- TODO: output param
2023-07-20 01:55:22 +02:00
local name = self:name()
if name ~= nil then
tag.set_layout(name, layout)
end
2023-07-18 19:37:40 +02:00
end
-----------------------------------------------------------
2023-07-01 04:34:07 +02:00
---Add tags.
---
2023-07-11 18:59:38 +02:00
---If you need to add the names as a table, use `tag.add_table` instead.
---
2023-07-20 01:55:22 +02:00
---You can also do `op:add_tags(...)`.
---
2023-07-18 22:12:23 +02:00
---### Example
2023-07-01 04:34:07 +02:00
---
---```lua
2023-07-20 01:55:22 +02:00
---local op = output.get_by_name("DP-1")
---if op ~= nil then
--- tag.add(op, "1", "2", "3", "4", "5") -- Add tags with names 1-5
2023-07-11 18:59:38 +02:00
---end
2023-07-01 04:34:07 +02:00
---```
2023-07-11 18:59:38 +02:00
---@param output Output The output you want these tags to be added to.
2023-07-01 04:34:07 +02:00
---@param ... string The names of the new tags you want to add.
2023-07-11 18:59:38 +02:00
function tag.add(output, ...)
2023-07-18 22:12:23 +02:00
local tag_names = table.pack(...)
tag_names["n"] = nil -- remove the length to make it a true array for serializing
2023-07-01 04:34:07 +02:00
SendMsg({
AddTags = {
2023-07-20 22:22:22 +02:00
output_name = output:name(),
2023-07-18 22:12:23 +02:00
tag_names = tag_names,
2023-07-01 04:34:07 +02:00
},
})
end
---Like `tag.add`, but with a table of strings instead.
2023-07-11 18:59:38 +02:00
---
2023-07-18 22:12:23 +02:00
---### Example
2023-07-11 18:59:38 +02:00
---
---```lua
---local tags = { "Terminal", "Browser", "Mail", "Gaming", "Potato" }
---local output = output.get_by_name("DP-1")
---if output ~= nil then
--- tag.add(output, tags) -- Add tags with the names above
---end
---```
---@param output Output The output you want these tags to be added to.
2023-07-18 17:31:08 +02:00
---@param names string[] The names of the new tags you want to add, as a table.
function tag.add_table(output, names)
2023-07-01 04:34:07 +02:00
SendMsg({
AddTags = {
2023-07-20 22:22:22 +02:00
output_name = output:name(),
2023-07-18 22:12:23 +02:00
tag_names = names,
2023-07-01 04:34:07 +02:00
},
})
end
---Toggle a tag on the specified output. If `output` isn't specified, toggle it on the currently focused output instead.
2023-07-11 18:59:38 +02:00
---
2023-07-18 22:12:23 +02:00
---### Example
2023-07-11 18:59:38 +02:00
---
---```lua
----- Assuming all tags are toggled off...
---local op = output.get_by_name("DP-1")
---tag.toggle("1", op)
---tag.toggle("2", op)
2023-07-11 18:59:38 +02:00
----- will cause windows on both tags 1 and 2 to be displayed at the same time.
---```
2023-07-01 04:34:07 +02:00
---@param name string The name of the tag.
---@param output Output? The output.
function tag.toggle(name, output)
if output ~= nil then
SendMsg({
ToggleTag = {
2023-07-20 22:22:22 +02:00
output_name = output:name(),
tag_name = name,
},
})
else
local op = require("output").get_focused()
if op ~= nil then
SendMsg({
ToggleTag = {
2023-07-20 22:22:22 +02:00
output_name = op:name(),
tag_name = name,
},
})
end
end
2023-07-01 04:34:07 +02:00
end
---Switch to a tag on the specified output, deactivating any other active tags on it.
---If `output` is not specified, this uses the currently focused output instead.
2023-07-11 18:59:38 +02:00
---
---This is used to replicate what a traditional workspace is on some other Wayland compositors.
---
2023-07-18 22:12:23 +02:00
---### Example
2023-07-11 18:59:38 +02:00
---
---```lua
---tag.switch_to("3") -- Switches to and displays *only* windows on tag 3
---```
2023-07-02 02:06:37 +02:00
---@param name string The name of the tag.
---@param output Output? The output.
function tag.switch_to(name, output)
if output ~= nil then
SendMsg({
SwitchToTag = {
2023-07-20 22:22:22 +02:00
output_name = output:name(),
tag_name = name,
},
})
else
local op = require("output").get_focused()
if op ~= nil then
SendMsg({
SwitchToTag = {
2023-07-20 22:22:22 +02:00
output_name = op:name(),
tag_name = name,
},
})
end
end
2023-07-02 02:06:37 +02:00
end
2023-07-13 01:50:41 +02:00
---Set a layout for the tag on the specified output. If there is none, set it for the tag on the currently focused one.
---@param name string The name of the tag.
---@param layout Layout The layout.
---@param output Output? The output.
function tag.set_layout(name, layout, output)
if output ~= nil then
SendMsg({
SetLayout = {
2023-07-20 22:22:22 +02:00
output_name = output:name(),
2023-07-13 01:50:41 +02:00
tag_name = name,
layout = layout,
},
})
else
local op = require("output").get_focused()
if op ~= nil then
SendMsg({
SetLayout = {
2023-07-20 22:22:22 +02:00
output_name = op:name(),
2023-07-13 01:50:41 +02:00
tag_name = name,
layout = layout,
},
})
end
end
end
2023-07-18 17:31:08 +02:00
---Get all tags on the specified output.
---
---You can also use `output_obj:tags()`, which delegates to this function:
---```lua
---local tags_on_output = output.get_focused():tags()
----- This is the same as
----- local tags_on_output = tag.get_on_output(output.get_focused())
---```
---@param output Output
---@return Tag[]
function tag.get_on_output(output)
2023-07-18 19:37:40 +02:00
SendRequest({
2023-07-20 22:22:22 +02:00
GetOutputProps = {
output_name = output:name(),
2023-07-18 17:31:08 +02:00
},
})
local response = ReadMsg()
2023-07-20 22:22:22 +02:00
local tag_ids = response.RequestResponse.response.OutputProps.tag_ids
2023-07-18 17:31:08 +02:00
---@type Tag[]
local tags = {}
2023-07-20 22:22:22 +02:00
if tag_ids == nil then
return tags
end
2023-07-18 22:12:23 +02:00
for _, tag_id in pairs(tag_ids) do
2023-07-20 22:22:22 +02:00
table.insert(tags, new_tag(tag_id))
2023-07-18 17:31:08 +02:00
end
return tags
end
2023-07-20 01:55:22 +02:00
---Get all tags with this name across all outputs.
---@param name string The name of the tags you want.
---@return Tag[]
function tag.get_by_name(name)
SendRequest({
GetTagsByName = {
tag_name = name,
},
})
local response = ReadMsg()
local tag_ids = response.RequestResponse.response.Tags.tag_ids
---@type Tag[]
local tags = {}
for _, tag_id in pairs(tag_ids) do
2023-07-20 22:22:22 +02:00
table.insert(tags, new_tag(tag_id))
2023-07-20 01:55:22 +02:00
end
return tags
end
2023-07-01 04:34:07 +02:00
return tag