* migrate to astal * Reorganize project structure. * progress * Migrate Dashboard and Window Title modules. * Migrate clock and notification bar modules. * Remove unused code * Media menu * Rework network and volume modules * Finish custom modules. * Migrate battery bar module. * Update battery module and organize helpers. * Migrate workspace module. * Wrap up bar modules. * Checkpoint before I inevitbly blow something up. * Updates * Fix event propagation logic. * Type fixes * More type fixes * Fix padding for event boxes. * Migrate volume menu and refactor scroll event handlers. * network module WIP * Migrate network service. * Migrate bluetooth menu * Updates * Migrate notifications * Update scrolling behavior for custom modules. * Improve popup notifications and add timer functionality. * Migration notifications menu header/controls. * Migrate notifications menu and consolidate notifications menu code. * Migrate power menu. * Dashboard progress * Migrate dashboard * Migrate media menu. * Reduce media menu nesting. * Finish updating media menu bindings to navigate active player. * Migrate battery menu * Consolidate code * Migrate calendar menu * Fix workspace logic to update on client add/change/remove and consolidate code. * Migrate osd * Consolidate hyprland service connections. * Implement startup dropdown menu position allocation. * Migrate settings menu (WIP) * Settings dialo menu fixes * Finish Dashboard menu * Type updates * update submoldule for types * update github ci * ci * Submodule update * Ci updates * Remove type checking for now. * ci fix * Fix a bunch of stuff, losing track... need rest. Brb coffee * Validate dropdown menu before render. * Consolidate code and add auto-hide functionality. * Improve auto-hide behavior. * Consolidate audio menu code * Organize bluetooth code * Improve active player logic * Properly dismiss a notification on action button resolution. * Implement CLI command engine and migrate CLI commands. * Handle variable disposal * Bar component fixes and add hyprland startup rules. * Handle potentially null bindings network and bluetooth bindings. * Handle potentially null wired adapter. * Fix GPU stats * Handle poller for GPU * Fix gpu bar logic. * Clean up logic for stat bars. * Handle wifi and wired bar icon bindings. * Fix battery percentages * Fix switch behavior * Wifi staging fixes * Reduce redundant hyprland service calls. * Code cleanup * Document the option code and reduce redundant calls to optimize performance. * Remove outdated comment. * Add JSDocs * Add meson to build hyprpanel * Consistency updates * Organize commands * Fix images not showing up on notifications. * Remove todo * Move hyprpanel configuration to the ~/.config/hyprpanel directory and add utility commands. * Handle SRC directory for the bundled/built hyprpanel. * Add namespaces to all windows * Migrate systray * systray updates * Update meson to include ts, tsx and scss files. * Remove log from meson * Fix file choose path and make it float. * Added a command to check the dependency status * Update dep names. * Get scale directly from env * Add todo
60 lines
2.2 KiB
TypeScript
60 lines
2.2 KiB
TypeScript
import { App, Gdk } from 'astal/gtk3';
|
|
import { GtkWidget } from 'src/lib/types/widget';
|
|
import { calculateMenuPosition } from 'src/components/menus/shared/dropdown/locationHandler';
|
|
|
|
export const closeAllMenus = (): void => {
|
|
const menuWindows = App.get_windows()
|
|
.filter((w) => {
|
|
if (w.name) {
|
|
return /.*menu/.test(w.name);
|
|
}
|
|
|
|
return false;
|
|
})
|
|
.map((window) => window.name);
|
|
|
|
menuWindows.forEach((window) => {
|
|
if (window) {
|
|
App.get_window(window)?.set_visible(false);
|
|
}
|
|
});
|
|
};
|
|
|
|
export const openMenu = async (clicked: GtkWidget, event: Gdk.Event, window: string): Promise<void> => {
|
|
/*
|
|
* NOTE: We have to make some adjustments so the menu pops up relatively
|
|
* to the center of the button clicked. We don't want the menu to spawn
|
|
* offcenter depending on which edge of the button you click on.
|
|
* -------------
|
|
* To fix this, we take the x coordinate of the click within the button's bounds.
|
|
* If you click the left edge of a 100 width button, then the x axis will be 0
|
|
* and if you click the right edge then the x axis will be 100.
|
|
* -------------
|
|
* Then we divide the width of the button by 2 to get the center of the button and then get
|
|
* the offset by subtracting the clicked x coordinate. Then we can apply that offset
|
|
* to the x coordinate of the click relative to the screen to get the center of the
|
|
* icon click.
|
|
*/
|
|
|
|
try {
|
|
const middleOfButton = Math.floor(clicked.get_allocated_width() / 2);
|
|
const xAxisOfButtonClick = clicked.get_pointer()[0];
|
|
const middleOffset = middleOfButton - xAxisOfButtonClick;
|
|
|
|
const clickPos = event.get_root_coords();
|
|
const adjustedXCoord = clickPos[1] + middleOffset;
|
|
const coords = [adjustedXCoord, clickPos[2]];
|
|
|
|
await calculateMenuPosition(coords, window);
|
|
|
|
closeAllMenus();
|
|
App.toggle_window(window);
|
|
} catch (error) {
|
|
if (error instanceof Error) {
|
|
console.error(`Error calculating menu position: ${error.stack}`);
|
|
} else {
|
|
console.error(`Unknown error occurred: ${error}`);
|
|
}
|
|
}
|
|
};
|