You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Dejvino 59e2a38f63 Fixed lisgd version with for the patch file 3 years ago
home/config Add vertical waybar for landscape mode 3 years ago
lisgd @ 877beea273 Add lisgd and rot8 support 3 years ago
patches Add lisgd patch to support screen rotation. 3 years ago
pinephone-toolkit @ 51b6fa81ab Fix minimal backlight value 3 years ago
rot8 @ 8f2128c172 Add lisgd and rot8 support 3 years ago
usr Add vertical waybar for landscape mode 3 years ago
.gitmodules Add vertical waybar for landscape mode 3 years ago
LICENSE Initial commit 3 years ago
Makefile Fixed lisgd version with for the patch file 3 years ago
README.md Update README.md with rot8 3 years ago
screenshots.png Update README with screenshot. 3 years ago

README.md

pinephone-sway-poc

Sway UI configured for PINE64 PinePhone (Proof Of Concept)

You can find ready-made config files, scripts and installation instructions on how to set up Sway on postmarketOS and use it with a PinePhone.

Screenshots

Install

Start with a postmarketOS for PinePhone image with postmarketos-ui-sway installed. Either use the pre-built demo image or build a custom one with pmbootstrap.

Flash the system onto the phone (either to an SD card or directly to the eMMC with Jumpdrive).

Open a terminal on the phone (either through SSH, the serial connection or directly on the screen) and run this:

# components
$ sudo apk add waybar bemenu swaylock swayidle networkmanager htop pavucontrol

# build tools
$ sudo apk add git make meson ninja cargo

# installation
$ git clone --recurse-submodules https://github.com/Dejvino/pinephone-sway-poc
$ cd pinephone-sway-poc
$ make install_user
$ sudo make install_system

That’s it. You should now have everything in place. Reboot to use the new settings.

Usage

Study the provided config files and shell scripts to get more details. The following is just an introduction.

Power Button

The power button activates or deactivates a “sleep mode”, in which the backlight is turned off, all the CPUs except for the primary one are shut down and the red LED is turned on to indicate the phone is turned on.

Top and bottom waybar

The bars show you CPU/MEM usage, backlight brightness, time, etc. Touching them opens a relevant app (e.g. NetworkManager or htop). Touching the date opens a custom “quick execute” menu to launch an app. The [x] icon closes the active window. Touching the backlight indicator brings up a custom brightness setting app.

Touch gestures

Swiping two fingers up / down activates or hides the on-screen keyboard. Swiping two fingers left / right changes the active workspace. Three fingers change the active window in the direction of the swipe. Four fingers move the active window accordingly.

Screen Rotation

The screen is automatically rotated based on the readings from the phone’s built-in accelerometer.

TIP!

You can use this as a configs backup mechanism!

$ make fetch

Running this command gathers the relevant config files from your running system and replaces the files in the repository. You can then git add and commit your own changes, straight from the phone! This is actually how the config files here were created.

Components

  • postmarketOS - base Linux distribution (though any other would work as well)
  • sway (pmos package) - tiling Wayland compositor
    • swayidle, swaylock - utils for sway
  • bemenu (pmos package) - app launcher
  • waybar (pmos package) - Wayland status bar
  • squeekboard (pmos package) - on-screen keyboard for Wayland
  • pinephone-toolkit - various utilities for the PinePhone
  • sxmo-lisgd - gesture detection daemon
  • rot8 - screen rotation daemon using data from the accelerometer
  • htop (pmos package) - Processes monitoring
  • pavucontrol (pmos package) - PulseAudio control panel

(pmos package = available as a package directly from the postmarketOS repository)