* Clean up unused code * Fix media player formatting issue for labels with new line characteres. * Refactor the media player handlers into a class. * More code cleanup and organize shared weather utils into distinct classes. * Flatten some nesting. * Move weather manager in dedicated class and build HTTP Utility class for Rest API calling. * Remove logs * Rebase master merge * Reorg code (WIP) * More reorg * Delete utility scripts * Reorg options * Finish moving all options over * Fix typescript issues * Update options imports to default * missed update * Screw barrel files honestly, work of the devil. * Only initialize power profiles if power-profiles-daemon is running. * Fix window positioning and weather service naming * style dir * More organization * Restructure types to be closer to their source * Remove lib types and constants * Update basic weather object to be saner with extensibility. * Service updates * Fix initialization strategy for services. * Fix Config Manager to only emit changed objects and added missing temp converters. * Update storage service to handle unit changes. * Added cpu temp sensor auto-discovery * Added missing JSDocs to services * remove unused * Migrate to network service. * Fix network password issue. * Move out password input into helper * Rename password mask constant to be less double-negativey. * Dropdown menu rename * Added a component to edit JSON in the settings dialog (rough/WIP) * Align settings * Add and style JSON Editor. * Adjust padding * perf(shortcuts): ⚡ avoid unnecessary polling when shortcuts are disabled Stops the recording poller when shortcuts are disabled, preventing redundant polling and reducing resource usage. * Fix types and return value if shortcut not enabled. * Move the swww daemon checking process outside of the wallpaper service into a dedicated deamon lifecyle processor. * Add more string formatters and use title case for weather status (as it was). * Fix startup errors. * Rgba fix * Remove zod from dependencies --------- Co-authored-by: KernelDiego <gonzalezdiego.contact@gmail.com>
119 lines
3.9 KiB
TypeScript
119 lines
3.9 KiB
TypeScript
import { Module } from '../../shared/module';
|
|
import NetworkUsageService from 'src/services/system/networkUsage';
|
|
import { bind, Variable } from 'astal';
|
|
import AstalNetwork from 'gi://AstalNetwork?version=0.1';
|
|
import { Astal } from 'astal/gtk3';
|
|
import { BarBoxChild } from '../../types';
|
|
import { NetstatLabelType } from 'src/services/system/types';
|
|
import { InputHandlerService } from '../../utils/input/inputHandler';
|
|
import options from 'src/configuration';
|
|
import { cycleArray, setupNetworkServiceBindings } from './helpers';
|
|
|
|
const inputHandler = InputHandlerService.getInstance();
|
|
const astalNetworkService = AstalNetwork.get_default();
|
|
|
|
const NETWORK_LABEL_TYPES: NetstatLabelType[] = ['full', 'in', 'out'];
|
|
|
|
const {
|
|
label,
|
|
labelType,
|
|
dynamicIcon,
|
|
icon,
|
|
networkInLabel,
|
|
networkOutLabel,
|
|
leftClick,
|
|
rightClick,
|
|
middleClick,
|
|
pollingInterval,
|
|
} = options.bar.customModules.netstat;
|
|
|
|
setupNetworkServiceBindings();
|
|
|
|
const networkService = new NetworkUsageService({ frequency: pollingInterval });
|
|
|
|
export const Netstat = (): BarBoxChild => {
|
|
networkService.initialize();
|
|
|
|
const renderNetworkLabel = (
|
|
lblType: NetstatLabelType,
|
|
networkData: { in: string; out: string },
|
|
): string => {
|
|
switch (lblType) {
|
|
case 'in':
|
|
return `${networkInLabel.get()} ${networkData.in}`;
|
|
case 'out':
|
|
return `${networkOutLabel.get()} ${networkData.out}`;
|
|
default:
|
|
return `${networkInLabel.get()} ${networkData.in} ${networkOutLabel.get()} ${networkData.out}`;
|
|
}
|
|
};
|
|
|
|
const iconBinding = Variable.derive(
|
|
[
|
|
bind(astalNetworkService, 'primary'),
|
|
bind(astalNetworkService, 'wifi'),
|
|
bind(astalNetworkService, 'wired'),
|
|
],
|
|
(primary, wifi, wired) => {
|
|
if (primary === AstalNetwork.Primary.WIRED) {
|
|
return wired?.icon_name;
|
|
}
|
|
return wifi?.icon_name;
|
|
},
|
|
);
|
|
|
|
const labelBinding = Variable.derive(
|
|
[bind(networkService.network), bind(labelType)],
|
|
(networkData, lblType: NetstatLabelType) => renderNetworkLabel(lblType, networkData),
|
|
);
|
|
|
|
let inputHandlerBindings: Variable<void>;
|
|
|
|
const netstatModule = Module({
|
|
useTextIcon: bind(dynamicIcon).as((useDynamicIcon) => !useDynamicIcon),
|
|
icon: iconBinding(),
|
|
textIcon: bind(icon),
|
|
label: labelBinding(),
|
|
tooltipText: bind(labelType).as((lblType) => {
|
|
return lblType === 'full' ? 'Ingress / Egress' : lblType === 'in' ? 'Ingress' : 'Egress';
|
|
}),
|
|
boxClass: 'netstat',
|
|
showLabelBinding: bind(label),
|
|
props: {
|
|
setup: (self: Astal.Button) => {
|
|
inputHandlerBindings = inputHandler.attachHandlers(self, {
|
|
onPrimaryClick: {
|
|
cmd: leftClick,
|
|
},
|
|
onSecondaryClick: {
|
|
cmd: rightClick,
|
|
},
|
|
onMiddleClick: {
|
|
cmd: middleClick,
|
|
},
|
|
onScrollUp: {
|
|
fn: () => {
|
|
const nextLabelType = cycleArray(NETWORK_LABEL_TYPES, labelType.get(), 'next');
|
|
labelType.set(nextLabelType);
|
|
},
|
|
},
|
|
onScrollDown: {
|
|
fn: () => {
|
|
const prevLabelType = cycleArray(NETWORK_LABEL_TYPES, labelType.get(), 'prev');
|
|
labelType.set(prevLabelType);
|
|
},
|
|
},
|
|
});
|
|
},
|
|
onDestroy: () => {
|
|
inputHandlerBindings.drop();
|
|
labelBinding.drop();
|
|
iconBinding.drop();
|
|
networkService.destroy();
|
|
},
|
|
},
|
|
});
|
|
|
|
return netstatModule;
|
|
};
|