All Projects → echuraev → keyboard_layout

echuraev / keyboard_layout

Licence: MIT license
Keyboard switcher for Awesome WM with additional layouts

Programming Languages

lua
6591 projects

Projects that are alternatives of or similar to keyboard layout

Net widgets
Network widgets for Awesome WM
Stars: ✭ 103 (+114.58%)
Mutual labels:  widget, awesomewm
Awesome Pulseaudio widget
PulseAudio widgtet for the Awesome Window Manager that uses DBus
Stars: ✭ 29 (-39.58%)
Mutual labels:  widget, awesomewm
awesome
Configs for awesomeWM
Stars: ✭ 42 (-12.5%)
Mutual labels:  widget, awesomewm
awesome-power widget
A Power widget for the Awesome Window Manager
Stars: ✭ 25 (-47.92%)
Mutual labels:  widget, awesomewm
KLineChartAndroid
A kline chart UI widget for android(Android版本的k线).
Stars: ✭ 51 (+6.25%)
Mutual labels:  widget
Accordion
Silky-smooth accordion widgets with no external dependencies.
Stars: ✭ 32 (-33.33%)
Mutual labels:  widget
mithril-datepicker
Pick a date! But only if you're using Mithril. (component for Mithril.js ^v1.0)
Stars: ✭ 23 (-52.08%)
Mutual labels:  widget
Pagination
a paging widget based on Qt
Stars: ✭ 22 (-54.17%)
Mutual labels:  widget
covid-19-status
Menu bar widget for MacOS with COVID-19 statistics
Stars: ✭ 50 (+4.17%)
Mutual labels:  widget
stomt-unreal-plugin
Collect feedback in-game/in-app with STOMT for Unreal Engine.
Stars: ✭ 23 (-52.08%)
Mutual labels:  widget
widgetci
a Cross-Platform Widget Management App. (Win/Linux/Mac)
Stars: ✭ 36 (-25%)
Mutual labels:  widget
incrementally loading listview
An extension of the Flutter ListView widget for incrementally loading items upon scrolling
Stars: ✭ 172 (+258.33%)
Mutual labels:  widget
LabPype
Framework for Creating Pipeline Software
Stars: ✭ 18 (-62.5%)
Mutual labels:  widget
handy-scroll
Handy dependency-free floating scrollbar widget
Stars: ✭ 15 (-68.75%)
Mutual labels:  widget
CheckableTextView
A simple and flexible Checked TextView or Checkable TextView
Stars: ✭ 108 (+125%)
Mutual labels:  widget
nixdots
I have no idea what the hell I'm doing
Stars: ✭ 46 (-4.17%)
Mutual labels:  awesomewm
AbsTK
The Abstract Toolkit – a widget toolkit for GUI and text-mode applications.
Stars: ✭ 67 (+39.58%)
Mutual labels:  widget
DiscoverRandomQuotes
Spontaneous - Random quotes is a free iOS app that generates random quotes. It values ease-of-use just as much as the users' privacy, so there are no ads or trackers to disrupt their experience. The app currently includes more than 75000 quotes, which you can only discover randomly.
Stars: ✭ 34 (-29.17%)
Mutual labels:  widget
flutter redux
A Flutter Starter Application
Stars: ✭ 25 (-47.92%)
Mutual labels:  widget
yii2-jstree-widget
jsTree tree widget for yii2
Stars: ✭ 16 (-66.67%)
Mutual labels:  widget

Keyboard switcher for Awesome WM with additional layouts

Intro

Usually I use two keyboard layouts on my computer there are English and Russian layouts. But sometimes I need to write something on another language, for example: German. But adding new keyboard layout was very annoying me. Because I have to press more than one time for changing my keyboard layout from Russian to English. But with this widget I can configure additional layouts. When I press on buttons on keyboard only my primary layouts will be switching. But when I want to use additional layout, I just click right mouse button on keyboard widget and select one of additional layouts. You can see how it is work in the Screenshot section.

Table of Contents

Features

  • Conception of additional layouts
  • Flexible configuration of the widget
  • GUI/TUI modes of display current layout.
  • Possibility of remembering layout per window.

Installing

Clone this repository to your Awesome WM configuration directory:

cd ~/.config/awesome
git clone https://github.com/echuraev/keyboard_layout

Usage

  1. Add call of keyboard_layout module to your rc.init:

    local keyboard_layout = require("keyboard_layout")
  2. Create instance of keyboard widget (full information about options that are supported, you can find in section: options). You can choose between text and graphical layout label, see below. Primary and Additional layouts can be set by add_primary_layout and add_additional_layout respectively. And when you add all necessary options to kbdcfg then you have to call bind functions. In this call all your settings will apply.

    2.1. Create text label:

    local kbdcfg = keyboard_layout.kbdcfg({type = "tui"})
    
    kbdcfg.add_primary_layout("English", "US", "us")
    kbdcfg.add_primary_layout("Русский", "RU", "ru")
    
    kbdcfg.add_additional_layout("Deutsch",  "DE", "de")
    kbdcfg.add_additional_layout("Français", "FR", "fr")
    kbdcfg.bind()

    2.2. Create graphical label:

    local kbdcfg = keyboard_layout.kbdcfg({type = "gui"})
    
    kbdcfg.add_primary_layout("English", beautiful.en_layout, "us")
    kbdcfg.add_primary_layout("Русский", beautiful.ru_layout, "ru")
    
    kbdcfg.add_additional_layout("Deutsch",  beautiful.de_layout, "de")
    kbdcfg.add_additional_layout("Français", beautiful.fr_layout, "fr")
    kbdcfg.bind()
  3. Bind your mouse keys:

    -- Mouse bindings
    kbdcfg.widget:buttons(
     awful.util.table.join(awful.button({ }, 1, function () kbdcfg.switch_next() end),
                           awful.button({ }, 3, function () kbdcfg.menu:toggle() end))
    )
  4. Bind your keyboard shortcuts:

    globalkeys = awful.util.table.join(globalkeys,
        -- Shift-Alt to change keyboard layout
        awful.key({"Shift"}, "Alt_L", function () kbdcfg.switch_next() end),
        -- Alt-Shift to change keyboard layout
        awful.key({"Mod1"}, "Shift_L", function () kbdcfg.switch_next() end)
    )
  5. Add widget to your wibar:

    s.mywibox = awful.wibar({ position = "top", screen = s })
    
    -- Add widgets to the wibox
    s.mywibox:setup {
        layout = wibox.layout.align.horizontal,
        { -- Left widgets
            -- ...
        },
        { -- Middle widgets
            -- ...
        },
        { -- Right widgets
            -- ...
            kbdcfg.widget,
            -- ...
        },
    }

Options

The following options you can pass to create function:

  • type - set type of widget. It is two types of widget gui or tui. Default: tui
  • cmd - command to change layout. For more information see section: How to use a different layout switch command. Default: setxkbmap
  • default_layout_index - set index of default layout. Default: 1
  • remember_layout - to remember selected layout per window set it to true. Default: false
  • tui_wrap_left, tui_wrap_right - allows you to customise the wrapping around the tui version of the widget. Default: " "

Functions

  • switch_next() - this function switches one primary keyboard layout to the next primary layout.
  • bind() - this function applies all settings to the widget.
  • switch_by_name(name) - this function is mostly used for setting additional layouts. It gets a layout name (first parameter of add_xxxx_layout() of layout that should be set.
  • add_primary_layout(name, label, subcmd) - this function adds a primary layout to the widget.
  • add_additional_layout(name, label, subcmd) - this function adds additional layout to the widget.

How to use a different layout switch command

By default the widget uses setxkbmap command to switch keyboard layouts. The following parameters allow it to use a non-standard layout switcher, for example the Fcitx for Chinese/Japanese/Korean input:

local kbdcfg = keyboard_layout.kbdcfg({cmd = "fcitx-remote -s", type = "tui"})

kbdcfg.add_primary_layout("English",  "us", "fcitx-keyboard-us")
kbdcfg.add_primary_layout("Russian",  "ru", "fcitx-keyboard-ru-ruu")
kbdcfg.add_primary_layout("Japanese", "ja", "mozc")

Note, that you should pass a valid input method name to fcitx-remote command. The last layout in the example uses the Mozc as an input method for Japanese input.

TUI wrap configuration

By default, the tui version adds a " " wrapping around the widget as a margin. In certain cases however, this might not be what you want. To change the wrapping around the widget, modify your config as such:

local kbdcfg = keyboard_layout.kbdcfg({
    type = "tui",
    tui_wrap_right = "",  -- wrapping on the right
    tui_wrap_left = ""  -- wrapping on the left
})

The example given should result in something kinda like this:

Screenshot of the widget accompanied by a nerd font keyboard icon on the left

Screenshots

In the beginning of both screen casts I changed layouts by keyboard shortcats and only primary layouts were switched. After that I showed how additional layouts work.

Usage of gui_layout: Usage of gui_layout.gif

Usage of tui_layout Usage of tui_layout.gif

References

Author

Egor Churaev [email protected]

Licence

MIT

Flags icons

Icon with British flag I take from here: https://www.gosquared.com/resources/flag-icons/

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].