* Create declarative module scaffolding * Added ram module (WIP) * Updates to options, styling and more. * Added function for styling custom modules. * Added utility functions and cleaned up code * Type and fn name updates. * Update module utils to handle absent values. * Added icon color in style2 that was missing. * Linted utils.ts * Add CPU module and update RAM module to use /proc/meminfo. * Added disk storage module. * Consolidate code * Added netstat module and removed elements from systray default ignore list. * Added keyboard layout module. * Fix hook types and move module to customModules directory * Added updates modules. * Spacing updates * Added weather module. * Added power menu and power module in bar. Increased update default interval to 6 ours. * Updated styling of bar buttons, made power menu label toggleable, etc. * Consolidate code and add dynamic tooltips based on data being used. * Make default custom mogules matugen compatible * Update base theme * Fix custom module background coloring * Remove testing opacity. * Update themes to account for new modules * Update nix stuff for libgtop (Need someone to test this) * Update nix * Update fractions to multiplications * Move styling in style directory * Implement a polling framework for variables that can dynamically adjust polling intervals. * Netstat module updates when interface name is changed. * Readme update
74 lines
2.1 KiB
TypeScript
74 lines
2.1 KiB
TypeScript
const hyprland = await Service.import("hyprland");
|
|
|
|
import options from "options";
|
|
import { module } from "../module"
|
|
|
|
import { inputHandler } from "customModules/utils";
|
|
import Gtk from "types/@girs/gtk-3.0/gtk-3.0";
|
|
import Button from "types/widgets/button";
|
|
import Label from "types/widgets/label";
|
|
import { getKeyboardLayout } from "./getLayout";
|
|
|
|
const {
|
|
label,
|
|
labelType,
|
|
icon,
|
|
leftClick,
|
|
rightClick,
|
|
middleClick,
|
|
scrollUp,
|
|
scrollDown,
|
|
} = options.bar.customModules.kbLayout;
|
|
|
|
export const KbInput = () => {
|
|
const keyboardModule = module({
|
|
textIcon: icon.bind("value"),
|
|
tooltipText: "",
|
|
labelHook: (self: Label<Gtk.Widget>): void => {
|
|
self.hook(hyprland, () => {
|
|
Utils.execAsync('hyprctl devices -j')
|
|
.then((obj) => {
|
|
self.label = getKeyboardLayout(obj, labelType.value);
|
|
})
|
|
.catch((err) => { console.error(err); });
|
|
}, "keyboard-layout");
|
|
|
|
self.hook(labelType, () => {
|
|
Utils.execAsync('hyprctl devices -j')
|
|
.then((obj) => {
|
|
self.label = getKeyboardLayout(obj, labelType.value);
|
|
})
|
|
.catch((err) => { console.error(err); });
|
|
});
|
|
},
|
|
|
|
boxClass: "kblayout",
|
|
showLabelBinding: label.bind("value"),
|
|
props: {
|
|
setup: (self: Button<Gtk.Widget, Gtk.Widget>) => {
|
|
inputHandler(self, {
|
|
onPrimaryClick: {
|
|
cmd: leftClick,
|
|
},
|
|
onSecondaryClick: {
|
|
cmd: rightClick,
|
|
},
|
|
onMiddleClick: {
|
|
cmd: middleClick,
|
|
},
|
|
onScrollUp: {
|
|
cmd: scrollUp,
|
|
},
|
|
onScrollDown: {
|
|
cmd: scrollDown,
|
|
},
|
|
});
|
|
},
|
|
},
|
|
});
|
|
|
|
return keyboardModule;
|
|
}
|
|
|
|
|