Minor: Refactor the code-base for better organization and compartmentalization. (#934)
* 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>
This commit is contained in:
102
src/services/network/ethernet.ts
Normal file
102
src/services/network/ethernet.ts
Normal file
@@ -0,0 +1,102 @@
|
||||
import { bind, Variable } from 'astal';
|
||||
import AstalNetwork from 'gi://AstalNetwork?version=0.1';
|
||||
|
||||
/**
|
||||
* EthernetManager handles ethernet-related functionality for dropdowns
|
||||
*/
|
||||
export class EthernetManager {
|
||||
private _astalNetwork: AstalNetwork.Network;
|
||||
|
||||
public wiredState: Variable<AstalNetwork.DeviceState> = Variable(AstalNetwork.DeviceState.UNKNOWN);
|
||||
public wiredInternet: Variable<AstalNetwork.Internet> = Variable(AstalNetwork.Internet.DISCONNECTED);
|
||||
public wiredIcon: Variable<string> = Variable('');
|
||||
public wiredSpeed: Variable<number> = Variable(0);
|
||||
|
||||
private _wiredStateBinding: Variable<void> | undefined;
|
||||
private _wiredInternetBinding: Variable<void> | undefined;
|
||||
private _wiredIconBinding: Variable<void> | undefined;
|
||||
private _wiredSpeedBinding: Variable<void> | undefined;
|
||||
|
||||
constructor(networkService: AstalNetwork.Network) {
|
||||
this._astalNetwork = networkService;
|
||||
}
|
||||
|
||||
/**
|
||||
* Called when the wired service changes to update bindings
|
||||
*/
|
||||
public onWiredServiceChanged(): void {
|
||||
this._getWiredState();
|
||||
this._getWiredInternet();
|
||||
this._getWiredIcon();
|
||||
this._getWiredSpeed();
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieves the current state of the wired network.
|
||||
*/
|
||||
private _getWiredState(): void {
|
||||
this._wiredStateBinding?.drop();
|
||||
this._wiredStateBinding = undefined;
|
||||
|
||||
if (this._astalNetwork.wired === null) {
|
||||
this.wiredState.set(AstalNetwork.DeviceState.UNAVAILABLE);
|
||||
return;
|
||||
}
|
||||
|
||||
this._wiredStateBinding = Variable.derive([bind(this._astalNetwork.wired, 'state')], (state) => {
|
||||
this.wiredState.set(state);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieves the current internet status of the wired network.
|
||||
*/
|
||||
private _getWiredInternet(): void {
|
||||
this._wiredInternetBinding?.drop();
|
||||
this._wiredInternetBinding = undefined;
|
||||
|
||||
if (this._astalNetwork.wired === null) {
|
||||
return;
|
||||
}
|
||||
|
||||
this._wiredInternetBinding = Variable.derive(
|
||||
[bind(this._astalNetwork.wired, 'internet')],
|
||||
(internet) => {
|
||||
this.wiredInternet.set(internet);
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieves the current icon for the wired network.
|
||||
*/
|
||||
private _getWiredIcon(): void {
|
||||
this._wiredIconBinding?.drop();
|
||||
this._wiredIconBinding = undefined;
|
||||
|
||||
if (this._astalNetwork.wired === null) {
|
||||
this.wiredIcon.set('network-wired-symbolic');
|
||||
return;
|
||||
}
|
||||
|
||||
this._wiredIconBinding = Variable.derive([bind(this._astalNetwork.wired, 'iconName')], (icon) => {
|
||||
this.wiredIcon.set(icon);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieves the current speed of the wired network.
|
||||
*/
|
||||
private _getWiredSpeed(): void {
|
||||
this._wiredSpeedBinding?.drop();
|
||||
this._wiredSpeedBinding = undefined;
|
||||
|
||||
if (this._astalNetwork.wired === null) {
|
||||
return;
|
||||
}
|
||||
|
||||
this._wiredSpeedBinding = Variable.derive([bind(this._astalNetwork.wired, 'speed')], (speed) => {
|
||||
this.wiredSpeed.set(speed);
|
||||
});
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user