Merge pull request #236 from ismaelpuerto/master
Add module for view and change keyboard layout
This commit is contained in:
commit
5c6cb5e862
31
i3pystatus/xkblayout.py
Normal file
31
i3pystatus/xkblayout.py
Normal file
@ -0,0 +1,31 @@
|
||||
from i3pystatus import IntervalModule
|
||||
import subprocess
|
||||
|
||||
|
||||
class Xkblayout(IntervalModule):
|
||||
interval = 1
|
||||
format = u"\u2328 {name}"
|
||||
settings = (
|
||||
("layouts", "Layouts list"),
|
||||
)
|
||||
on_leftclick = "change_layout"
|
||||
|
||||
def run(self):
|
||||
kblayout = subprocess.check_output("setxkbmap -query | awk '/layout/{print $2}'", shell=True).decode('utf-8').strip()
|
||||
|
||||
self.output = {
|
||||
"full_text": self.format.format(name=kblayout).upper(),
|
||||
"color": "#ffffff"
|
||||
}
|
||||
|
||||
def change_layout(self):
|
||||
layouts = self.layouts
|
||||
kblayout = subprocess.check_output("setxkbmap -query | awk '/layout/{print $2}'", shell=True).decode('utf-8').strip()
|
||||
if kblayout in layouts:
|
||||
position = layouts.index(kblayout)
|
||||
try:
|
||||
subprocess.check_call(["setxkbmap", layouts[position + 1]])
|
||||
except IndexError:
|
||||
subprocess.check_call(["setxkbmap", layouts[0]])
|
||||
else:
|
||||
subprocess.check_call(["setxkbmap", layouts[0]])
|
Loading…
Reference in New Issue
Block a user