-
-
Notifications
You must be signed in to change notification settings - Fork 3
/
main.jsx
78 lines (61 loc) · 2.53 KB
/
main.jsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
import Space from './lib/components/space.jsx'
import Process from './lib/components/process.jsx'
import CustomWidgets from './lib/components/custom-widgets.jsx'
import Battery from './lib/components/battery.jsx'
import Sound from './lib/components/sound.jsx'
import DateTime from './lib/components/date-time.jsx'
import Network from './lib/components/network.jsx'
import CustomComponents from './lib/custom-components/index.jsx'
import * as Settings from './lib/services/settings'
import * as Json from './lib/services/json'
import * as Output from './lib/services/output'
import * as Styles from './lib/services/styles'
import * as ClassNames from './lib/services/classnames'
const widgets = {
battery: Battery,
input: Sound,
output: Sound,
dateTime: DateTime,
network: Network
}
const refreshFrequency = false
const settings = Settings.get()
const { yabaiPath, shell, dataWidgets } = settings
const command = `${shell} simple-bar-lite/lib/scripts/init.sh ${yabaiPath}`
Styles.inject('simple-bar-lite-spaces', [Styles.variables])
Styles.load('simple-bar-lite/lib/styles/index.css', 'simple-bar-lite-styles')
const { customComponents } = Settings.get()
const render = ({ output, error }) => {
if (!output || error) return null
const cleanedOutput = Output.cleanup(output)
if (cleanedOutput === 'yabai_error') return null
const json = Json.parse(cleanedOutput)
if (!json) return null
const { currentWindow, displays, spaces, sip, shadow } = json
const displayId = parseInt(window.location.pathname.replace('/', ''))
const displayIndex = displays.find((d) => d.id === displayId).index
const { index: currentSpaceIndex } = spaces.find((space) => space.display === displayIndex)
const classes = ClassNames.build('spl-bar', { 'spl-bar--no-shadow': shadow !== 'on' })
return (
<div className={classes}>
{spaces.map((space, index) => (
<Space key={index} currentSpaceIndex={currentSpaceIndex} displayIndex={displayIndex} space={space} sip={sip} />
))}
<Process currentWindow={currentWindow} />
<div className="spl-bar__data">
<CustomWidgets />
<CustomComponents />
{Object.keys(dataWidgets)
.map((key) => ({ key, ...dataWidgets[key] }))
.map(({ key, enabled, args }) => {
if (!enabled) return undefined
const Widget = widgets[key]
if (!Widget) return undefined
return <Widget {...args} key={key} />
})
.filter(Boolean)}
</div>
</div>
)
}
export { command, refreshFrequency, render }