gnome-shell/data
Florian Müllner 62db8dc16e status/backlight: Add new quick toggle
Settings no longer exposes a slider for the keyboard brightness,
leaving keyboard shortcuts as the only way of adjusting it.

This is good enough in most cases, because devices with keyboard
backlight usually include corresponding keys on their keyboard.

However for devices without those keys, it would be good for the
settings to be exposed somewhere again. Quick settings seems like
a more appropriate place than "proper" Settings, since it gives
quick access that doesn't require a major focus change.

https://gitlab.gnome.org/GNOME/gnome-shell/-/issues/6765

Part-of: <https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/2820>
2023-07-30 11:12:50 +00:00
..
cldr2json
dbus-interfaces status/backlight: Add new quick toggle 2023-07-30 11:12:50 +00:00
icons status/backlight: Add new quick toggle 2023-07-30 11:12:50 +00:00
osk-layouts
theme status/backlight: Add new quick toggle 2023-07-30 11:12:50 +00:00
00_org.gnome.shell.gschema.override
50-gnome-shell-launchers.xml
50-gnome-shell-screenshots.xml
50-gnome-shell-system.xml windowManager: Add shortcut for toggling quick settings 2023-06-21 18:11:05 +00:00
emoji.json
gnome-shell-dbus-interfaces.gresource.xml status/backlight: Add new quick toggle 2023-07-30 11:12:50 +00:00
gnome-shell-icons.gresource.xml status/backlight: Add new quick toggle 2023-07-30 11:12:50 +00:00
gnome-shell-osk-layouts.gresource.xml
gnome-shell-theme.gresource.xml theme: Include both dark and light variant in resource 2023-05-25 17:10:53 +02:00
gnome-shell.portal
meson.build
org.gnome.Shell-disable-extensions.service
org.gnome.Shell-symbolic.Source.svg
org.gnome.Shell.desktop.in.in
org.gnome.Shell.Extensions.desktop.in.in
org.gnome.shell.gschema.xml.in windowManager: Add shortcut for toggling quick settings 2023-06-21 18:11:05 +00:00
org.gnome.Shell.PortalHelper.desktop.in.in
org.gnome.Shell.PortalHelper.service.in
org.gnome.Shell.target
org.gnome.Shell@wayland.service.in build: Specify systemd version requirement 2023-06-30 20:13:48 +00:00
org.gnome.Shell@x11.service.in build: Specify systemd version requirement 2023-06-30 20:13:48 +00:00
perf-background.xml.in
README.osk-layouts
update-osk-layouts.sh

Gnome-shell OSK layouts are extracted from CLDR layout definitions:
https://www.unicode.org/cldr/charts/latest/keyboards/layouts/index.html

To add new layouts from CLDR:

1) Run update-osk-layouts.sh

2) Modify JSON files to add extra keys, tweak appearance...

2) Do git add and git commit

JSON file format
================

Each JSON file describes a keymap for a certain language and layout,
it has the following structure:

- Root (Object)

  Root object of a layout, has the following properties:

  - levels (Array of Level): Levels in the keymap
  - locale (String): Locale name for this keymap
  - name (String): Human readable name for this keymap

- Level (Object)

  A level defines the keys available on a keyboard level,
  these are the key panels visible at a time. E.g. to type
  uppercase levels or symbols.

  Levels have the following properties:

  - level (String): Name of the level, common names are
    "", "shift", "opt" and "opt+shift".
  - mode (String): Mode for this level, common modes are
    "default", "latched" and "locked".
  - rows (Array of Row): Array of rows of keys.

- Row (Array)

  A row is an Array of Key.

- Key (Object)

  A keyboard key. Keys have the following properties:

  - iconName (String): Icon name to show on the key.
    Keys with an icon name do not have a label.
  - label (String): Label to show on the key.
  - strings (Array of String): Strings to commit. If
    label property does not exist, the first element
    will be also the label. Extra elements are shown
    in the extra keys popover.
  - keyval (String): Hexadecimal keyval to emit as
    emulated key presses. Committed strings are
    preferred.
  - width (Double): Relative width of the key in the
    row. 1 is for a square key. Multiples of 0.5 are
    accepted.
  - level (Integer): Level that the key switches to.
    See the levelSwitch action.
  - action (string): Action performed by the key,
    accepted actions are:

    - hide: Hides the OSK
    - languageMenu: Pops up the language selection
      menu
    - emoji: Switches to the emoji selection panel
    - modifier: Handles the keyval as a modifier
      key. This handles e.g. Ctrl+A as a sequence
      of Ctrl press, A press, A release, Ctrl
      release.
    - delete: Deletes text backwards
    - levelSwitch: Switches OSK to a different level