✨ chore(runner): try a new approach to show results, make plugins return properties instead of the actual widget
returning the results as objects seems to be a better approach, also, the new way of showing results doesn't work for some reason(i didn't discover it yet lol)
This commit is contained in:
+45
-48
@@ -1,56 +1,53 @@
|
||||
import { createBinding, createComputed } from "ags";
|
||||
import { ResultWidget, ResultWidgetProps } from "../../widget/runner/ResultWidget";
|
||||
import { Runner } from "../Runner";
|
||||
import AstalMpris from "gi://AstalMpris";
|
||||
import { player } from "../../widget/bar/Media";
|
||||
|
||||
import AstalMpris from "gi://AstalMpris";
|
||||
|
||||
|
||||
export const PluginMedia = {
|
||||
prefix: ":",
|
||||
handle() {
|
||||
if(!player.get().available) return new ResultWidget({
|
||||
icon: "folder-music-symbolic",
|
||||
title: "Couldn't find any players",
|
||||
handle: () => !player.get().available ? {
|
||||
icon: "folder-music-symbolic",
|
||||
title: "Couldn't find any players",
|
||||
closeOnClick: false,
|
||||
description: "No media / player found with mpris"
|
||||
} : [
|
||||
{
|
||||
icon: createBinding(player.get(), "playbackStatus").as((status) => status === AstalMpris.PlaybackStatus.PLAYING ?
|
||||
"media-playback-pause-symbolic"
|
||||
: "media-playback-start-symbolic"),
|
||||
closeOnClick: false,
|
||||
description: "No media / player found with mpris"
|
||||
} as ResultWidgetProps);
|
||||
|
||||
return [
|
||||
new ResultWidget({
|
||||
icon: createBinding(player.get(), "playbackStatus").as((status) => status === AstalMpris.PlaybackStatus.PLAYING ?
|
||||
"media-playback-pause-symbolic"
|
||||
: "media-playback-start-symbolic"),
|
||||
closeOnClick: false,
|
||||
title: createComputed([
|
||||
createBinding(player.get(), "title"),
|
||||
createBinding(player.get(), "artist"),
|
||||
createBinding(player.get(), "playbackStatus")
|
||||
], (title, artist, status) => `${ status === AstalMpris.PlaybackStatus.PLAYING ?
|
||||
"Pause" : "Play"
|
||||
} ${title} | ${artist}`),
|
||||
onClick: () => player.get().play_pause()
|
||||
} as ResultWidgetProps),
|
||||
new ResultWidget({
|
||||
icon: "media-skip-backward-symbolic",
|
||||
closeOnClick: false,
|
||||
title: createComputed([
|
||||
createBinding(player.get(), "title"),
|
||||
createBinding(player.get(), "artist")
|
||||
], (title, artist) =>
|
||||
`Go Previous ${ title ? title : player.get().busName }${ artist ? ` | ${artist}` : "" }`
|
||||
),
|
||||
onClick: () => player.get().canGoPrevious && player.get().previous()
|
||||
} as ResultWidgetProps),
|
||||
new ResultWidget({
|
||||
icon: "media-skip-forward-symbolic",
|
||||
closeOnClick: false,
|
||||
title: createComputed([
|
||||
createBinding(player.get(), "title"),
|
||||
createBinding(player.get(), "artist")
|
||||
], (title, artist) =>
|
||||
`Go Next ${ title ? title : player.get().busName }${ artist ? ` | ${artist}` : "" }`
|
||||
),
|
||||
onClick: () => player.get().canGoNext && player.get().next()
|
||||
} as ResultWidgetProps)
|
||||
]
|
||||
},
|
||||
title: createComputed([
|
||||
createBinding(player.get(), "title"),
|
||||
createBinding(player.get(), "artist"),
|
||||
createBinding(player.get(), "playbackStatus")
|
||||
], (title, artist, status) => `${ status === AstalMpris.PlaybackStatus.PLAYING ?
|
||||
"Pause" : "Play"
|
||||
} ${title} | ${artist}`),
|
||||
actionClick: () => player.get().play_pause()
|
||||
},
|
||||
{
|
||||
icon: "media-skip-backward-symbolic",
|
||||
closeOnClick: false,
|
||||
title: createComputed([
|
||||
createBinding(player.get(), "title"),
|
||||
createBinding(player.get(), "artist")
|
||||
], (title, artist) =>
|
||||
`Go Previous ${ title ? title : player.get().busName }${ artist ? ` | ${artist}` : "" }`
|
||||
),
|
||||
actionClick: () => player.get().canGoPrevious && player.get().previous()
|
||||
},
|
||||
{
|
||||
icon: "media-skip-forward-symbolic",
|
||||
closeOnClick: false,
|
||||
title: createComputed([
|
||||
createBinding(player.get(), "title"),
|
||||
createBinding(player.get(), "artist")
|
||||
], (title, artist) =>
|
||||
`Go Next ${ title ? title : player.get().busName }${ artist ? ` | ${artist}` : "" }`
|
||||
),
|
||||
actionClick: () => player.get().canGoNext && player.get().next()
|
||||
}
|
||||
]
|
||||
} as Runner.Plugin;
|
||||
|
||||
Reference in New Issue
Block a user