diff options
| author | 2 * r + 2 * t <61896496+soramanew@users.noreply.github.com> | 2025-05-28 22:03:05 +0800 |
|---|---|---|
| committer | 2 * r + 2 * t <61896496+soramanew@users.noreply.github.com> | 2025-05-28 22:03:05 +0800 |
| commit | b6a34cbc47fcef2f0b8b828314290f4e1270dae0 (patch) | |
| tree | bed54ff73413ae6c66820adc3afe60379c29f06c /services | |
| parent | drawers: change anim durations (diff) | |
| download | caelestia-shell-b6a34cbc47fcef2f0b8b828314290f4e1270dae0.tar.gz caelestia-shell-b6a34cbc47fcef2f0b8b828314290f4e1270dae0.tar.bz2 caelestia-shell-b6a34cbc47fcef2f0b8b828314290f4e1270dae0.zip | |
internal: move weather into service
Also fix not escaping city properly
Diffstat (limited to 'services')
| -rw-r--r-- | services/Weather.qml | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/services/Weather.qml b/services/Weather.qml new file mode 100644 index 0000000..13503f9 --- /dev/null +++ b/services/Weather.qml @@ -0,0 +1,32 @@ +pragma Singleton + +import "root:/utils" +import Quickshell +import Quickshell.Io + +Singleton { + id: root + + property string icon + property string description + property real temperature + + function reload(): void { + wttrProc.running = true; + } + + Process { + id: wttrProc + + running: true + command: ["fish", "-c", `curl "https://wttr.in/$(curl ipinfo.io | jq -r '.city' | string replace -a ' ' '%20')?format=j1" | jq -c '.current_condition[0] | {code: .weatherCode, desc: .weatherDesc[0].value, temp: .temp_C}'`] + stdout: SplitParser { + onRead: data => { + const json = JSON.parse(data); + root.icon = Icons.getWeatherIcon(json.code); + root.description = json.desc; + root.temperature = parseFloat(json.temp); + } + } + } +} |