Merge pull request #2701 from thejch/hl-ws-click

Add button click check to hyprland workspaces module
This commit is contained in:
Alexis Rouillard 2023-11-28 09:20:51 +01:00 committed by GitHub
commit 58db0baaf4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 15 additions and 13 deletions

View File

@ -311,7 +311,7 @@ void Workspaces::on_workspace_created(std::string const &payload) {
void Workspaces::on_workspace_moved(std::string const &payload) { void Workspaces::on_workspace_moved(std::string const &payload) {
std::string workspace = payload.substr(0, payload.find(',')); std::string workspace = payload.substr(0, payload.find(','));
std::string new_output = payload.substr(payload.find(',') + 1); std::string new_output = payload.substr(payload.find(',') + 1);
bool should_show = show_special() || ! workspace.starts_with("special"); bool should_show = show_special() || !workspace.starts_with("special");
if (should_show && bar_.output->name == new_output) { // TODO: implement this better if (should_show && bar_.output->name == new_output) { // TODO: implement this better
const Json::Value workspaces_json = gIPC->getSocket1JsonReply("workspaces"); const Json::Value workspaces_json = gIPC->getSocket1JsonReply("workspaces");
for (Json::Value workspace_json : workspaces_json) { for (Json::Value workspace_json : workspaces_json) {
@ -849,19 +849,21 @@ std::string &Workspace::select_icon(std::map<std::string, std::string> &icons_ma
} }
bool Workspace::handle_clicked(GdkEventButton *bt) const { bool Workspace::handle_clicked(GdkEventButton *bt) const {
try { if (bt->type == GDK_BUTTON_PRESS) {
if (id() > 0) { // normal or numbered persistent try {
gIPC->getSocket1Reply("dispatch workspace " + std::to_string(id())); if (id() > 0) { // normal or numbered persistent
} else if (!is_special()) { // named gIPC->getSocket1Reply("dispatch workspace " + std::to_string(id()));
gIPC->getSocket1Reply("dispatch workspace name:" + name()); } else if (!is_special()) { // named
} else if (id() != -99) { // named special gIPC->getSocket1Reply("dispatch workspace name:" + name());
gIPC->getSocket1Reply("dispatch togglespecialworkspace " + name()); } else if (id() != -99) { // named special
} else { // special gIPC->getSocket1Reply("dispatch togglespecialworkspace " + name());
gIPC->getSocket1Reply("dispatch togglespecialworkspace"); } else { // special
gIPC->getSocket1Reply("dispatch togglespecialworkspace");
}
return true;
} catch (const std::exception &e) {
spdlog::error("Failed to dispatch workspace: {}", e.what());
} }
return true;
} catch (const std::exception &e) {
spdlog::error("Failed to dispatch workspace: {}", e.what());
} }
return false; return false;
} }