73 Commits

Author SHA1 Message Date
5e4a314115 [NeoVim] add gopls 2022-12-05 13:17:46 +01:00
aaa06a4df8 [NeoVim] add markdown preview 2022-11-24 18:01:30 +01:00
5fcd4d168e [NeoVim] calm down firenvim 2022-11-24 18:00:46 +01:00
bfc0fb49fc [mpv] thumbfast conf 2022-11-09 19:51:30 +01:00
87c8314567 [mpv] steal mugen script from amoethyst 2022-11-09 19:51:05 +01:00
584b9a0d9f [NeoVim] Add FireNvim 2022-10-25 18:51:20 +02:00
52954da5ee [Waybar] Fix pacman module (again) 2022-10-25 15:34:48 +02:00
271450c509 [NeoVim] Update and add noice 2022-10-21 20:11:06 +02:00
5028abfdf5 [Sway] Add border around kitty-scratches 2022-10-21 19:22:58 +02:00
0f335550b5 [Waybar] Fix pacman module 2022-10-21 19:14:18 +02:00
1a0f52ec04 [Waybar] Improve look 2022-10-03 18:36:32 +02:00
70d96e45f1 [Waybar] Add custom update manager 2022-10-03 15:21:57 +02:00
7b9a3c41dd [mpv] UOSC conf 2022-09-30 12:37:07 +02:00
1444f19ae7 [Sway] Switch to waybar 2022-09-30 12:36:49 +02:00
813af84bba [NeoVim] Add impatient 2022-09-09 14:34:03 +02:00
86e2d5ab84 [NeoVim] Updates 2022-09-08 18:42:49 +02:00
2c900d1ca5 [NeoVim] Fix file open in neo-tree 2022-09-07 18:37:00 +02:00
f0f796572c [NeoVim] Small changes 2022-08-30 17:48:42 +02:00
a87dbbef64 [PipeWire] Add noboost mic rules 2022-08-30 13:35:15 +02:00
ab38c8b5b3 [NeoVim] Disable Hologram auto display 2022-08-30 12:14:30 +02:00
5e638eed29 [NeoVim] Call PackerSync after Fennel changes 2022-08-30 12:14:30 +02:00
85a4b244d0 [NeoVim] Display PNGs directly in floating windows 2022-08-26 17:46:55 +02:00
27a642d04e [NeoVim] Add Hologram 2022-08-25 21:37:07 +02:00
370a677344 [NeoVim] Slight syntax improvements 2022-08-25 21:36:31 +02:00
cebfc517fe [NeoVim] Open binary files with xdg-open 2022-08-25 17:03:52 +02:00
65004eb166 [NeoVim] Fix tree-sitter bootstrap error 2022-08-25 03:58:48 +02:00
4059a6501a [NeoVim] Actually working bootstrap 2022-08-24 18:33:02 +02:00
b411775c77 [NeoVim] Clean plugins settings 2022-08-24 16:05:58 +02:00
a68c8f70b2 Small fixes 2022-08-24 14:04:55 +02:00
4f2eda40e6 [NeoVim] The world is now Fennel 2022-08-24 14:04:55 +02:00
bf8d567d01 [NeoVim] Fennel More 2022-08-23 20:44:19 +02:00
643958bb39 [NeoTree] Handle vimtex QuickFix window 2022-08-23 16:09:56 +02:00
d15417dce5 [NeoVim] More Fennel 2022-08-23 14:25:51 +02:00
4ec619d04e [NeoVim] Starting the Fennel journey 2022-08-22 20:48:51 +02:00
ae90912567 [NeoVim] Better LSP management 2022-08-22 16:01:07 +02:00
32e6c9f4d5 [NeoVim] Packer Bootstrap 2022-08-22 16:00:38 +02:00
84dbb0666a [NeoVim] Configure LTeX 2022-08-22 15:11:03 +02:00
69b73d8323 [Ranger] Add dragon-drop shortcut 2022-08-18 15:44:11 +02:00
43ffd3ae92 Make KeePassXC float 2022-08-17 18:50:54 +02:00
fd49af2c96 [i3status] Update configuration 2022-08-17 18:50:35 +02:00
e4b925062c Remove outdated Sway scripts 2022-08-17 18:35:01 +02:00
af1ebdaede Get rid of some old coc files 2022-08-17 18:13:37 +02:00
61d3f1dffe Autostart KeePassXC 2022-08-17 15:22:27 +02:00
aea55f75e8 [NeoVim] Add Mason 2022-08-17 15:21:59 +02:00
4732cf9b1a [NeoVim] Update cmp template 2022-08-05 19:31:20 +02:00
b0999f012c [NeoVim] Add null-ls 2022-08-05 18:57:58 +02:00
43ba9953aa [NeoVim] LaTeX + Snippets 2022-07-25 19:08:00 +02:00
d38ce6a1c7 [NeoVim] Install nvim-cmp 2022-07-25 15:37:57 +02:00
f850d9588c [WorkspaceRename] Add Vivaldi 2022-07-25 15:36:33 +02:00
217ff74e2e Make the world even more opaque 2022-07-12 14:26:43 +02:00
c8a88f5f15 [NeoVim] Add diffview 2022-07-12 14:23:56 +02:00
14a9061e3d Make the world opaque 2022-07-12 13:20:38 +02:00
a504e27e19 Update status bar configuration 2022-07-11 17:17:34 +02:00
176e5dd276 [NeoVim] Remove neo-tree's fading 2022-07-08 19:44:55 +02:00
94428c4747 Perfected NeoVim 2022-07-04 21:02:36 +02:00
b79cb19b10 Add smartindent 2022-07-04 15:02:06 +02:00
cf85b92cad More changes 2022-07-04 14:47:07 +02:00
7ec8924d10 Changes 2022-07-04 11:52:55 +02:00
8f40b17cad Small theming changes 2022-06-10 15:49:16 +02:00
e813a072da NeoVim clean and updated config 2022-06-10 15:48:14 +02:00
6c67b9a43c Configure Sway client titles 2022-05-23 17:49:23 +02:00
b0f154e479 Update 2022-05-05 17:38:38 +02:00
23e8261859 Stuff 2021-12-06 17:14:36 +01:00
421e7b21f4 Cleaning 2021-11-19 12:31:15 +01:00
8b65270f5a Mouse cursor and electron flags 2021-11-19 12:22:59 +01:00
c538cc0ff5 Disable opacity for kitty-scratch 2021-11-16 18:27:32 +01:00
e5bb82de21 Icon for kitty-scratch 2021-11-16 16:43:59 +01:00
c2f9d53ead Use scratchpad + more workspace icons 2021-11-16 16:40:27 +01:00
6cf171227a Add mako and update confs 2021-11-10 15:38:52 +01:00
02a9e46f96 Can't believe I didn't commit mpv bindsym 2021-02-26 18:30:37 +01:00
a63e61145c Add systemd environment variables 2020-09-11 18:12:32 +02:00
fb5bd85e77 Mostly just slurp 2020-08-25 15:40:25 +02:00
6532cab1f6 Update JACK setup 2020-07-17 13:45:45 +02:00
57 changed files with 883 additions and 1771 deletions

View File

@@ -1,23 +1,9 @@
alias update='yay -Pw && yay -Sc && yay -Syu --sudoloop && yay -c && sudo pacdiff' alias update='yay -Pw && yay -Sc && yay --editmenu -Syu --sudoloop --devel && yay -c \
alias gemocstudio='PATH=/usr/lib/jvm/java-9-jdk/bin/:$PATH ~/gemoc/GemocStudio' && sudo pacdiff \
; pkill -SIGUSR1 i3status-rs \
; read -s -k "?Update finished! Press any key to exit..."'
alias sl='ls' alias sl='ls'
alias ls='ls --color=auto' alias ls='ls --color=auto'
alias cat='ccat -G Keyword="*glay*" -G Decimal="glay" -G Plaintext="glay" --bg=dark' alias cat='ccat -G Keyword="*glay*" -G Decimal="glay" -G Plaintext="glay" --bg=dark'
alias youtube='URL=https://www.youtube.com/watch\?v\=Mvvsa5HAJiI\&list\=RDMM\&start_radio\=1 && PLAYLIST="" && for i in {1..30} ; do URL="https://www.youtube.com"`curl -s -b ~/.config/youtube-dl/youtube.txt $URL | grep "next-playlist-list-item" | sed '\''s/.*href=\"//'\'' | sed '\''s/\".*//'\'' | sed '\''s/\&/\&/g'\''` ; PLAYLIST="$PLAYLIST\n`echo $URL | sed '\''s/\&list.*//'\''`" ; done ; echo "$PLAYLIST" | mpv --playlist=-' alias youtube='URL=https://www.youtube.com/watch\?v\=Mvvsa5HAJiI\&list\=RDMM\&start_radio\=1 && PLAYLIST="" && for i in {1..30} ; do URL="https://www.youtube.com"`curl -s -b ~/.config/youtube-dl/youtube.txt $URL | grep "next-playlist-list-item" | sed '\''s/.*href=\"//'\'' | sed '\''s/\".*//'\'' | sed '\''s/\&/\&/g'\''` ; PLAYLIST="$PLAYLIST\n`echo $URL | sed '\''s/\&list.*//'\''`" ; done ; echo "$PLAYLIST" | mpv --playlist=-'
function javaversion() {
if [ "$#" -ne 1 ]; then
echo "Expected parameter <java_version>"
else
if [ "$1" -eq 8 ]; then
export JAVA_HOME=/usr/lib/jvm/java-8-openjdk
elif [ "$1" -eq 9 ]; then
export JAVA_HOME=/usr/lib/jvm/java-9-jdk
elif [ "$1" -eq 10 ]; then
export JAVA_HOME=/usr/lib/jvm/java-10-openjdk
elif [ "$1" -eq 11 ]; then
export JAVA_HOME=/usr/lib/jvm/java-11-openjdk
fi
export PATH=$JAVA_HOME/bin:$PATH
fi
}

View File

@@ -4,8 +4,8 @@
export EDITOR=nvim export EDITOR=nvim
export CUPS_SERVER=cups-sam.inria.fr:631 export CUPS_SERVER=cups-sam.inria.fr:631
export GTK_THEME=NumixSolarizedDarkBlue export GTK_THEME=SolArc-Dark
export GTK2_RC_FILES=/usr/share/themes/NumixSolarizedDarkBlue/gtk-2.0/gtkrc export GTK2_RC_FILES=/usr/share/themes/SolArc-Dark/gtk-2.0/gtkrc
export QT_QPA_PLATFORMTHEME=gtk2 export QT_QPA_PLATFORMTHEME=gtk2
[[ -f ~/.bashrc ]] && . ~/.bashrc [[ -f ~/.bashrc ]] && . ~/.bashrc

View File

@@ -1,2 +0,0 @@
emote_data.json
logs.log

View File

@@ -1,51 +0,0 @@
{
"settings": {
"stable": {
"settings": {
"bda-gs-1": true,
"bda-gs-2": false,
"bda-gs-3": false,
"bda-gs-4": false,
"bda-gs-5": false,
"bda-gs-6": false,
"bda-gs-7": false,
"bda-gs-8": true,
"bda-es-0": false,
"bda-es-1": false,
"bda-es-2": false,
"bda-es-4": false,
"bda-es-6": false,
"bda-es-7": false,
"bda-gs-b": false,
"bda-es-8": false,
"bda-dc-0": false,
"bda-css-0": true,
"bda-css-1": false,
"bda-es-9": false,
"fork-dm-1": false,
"fork-ps-1": true,
"fork-ps-2": true,
"fork-ps-3": true,
"fork-ps-4": true,
"fork-ps-5": true,
"fork-es-2": false,
"fork-es-3": false,
"fork-wp-1": true,
"fork-wp-2": false,
"fork-beta": true,
"reactDevTools": false,
"transparency": true
},
"plugins": {},
"themes": {
"Frosted Glass": true
}
},
"canary": {},
"ptb": {}
},
"version": "0.3.5",
"emoteCacheDays": 7,
"emoteCacheDate": "2020-10-24T10:21:17.385Z",
"bdcustomcss": "I2FwcC1tb3VudCAuY2hhdC0zYlJ4eHUgLm1lc3NhZ2VzV3JhcHBlci0zbFpEZlkgW2NsYXNzKj10aW1lc3RhbXBdLAojYXBwLW1vdW50IC5jaGF0LTNiUnh4dSAubWVzc2FnZXNXcmFwcGVyLTNsWkRmWSAubWVzc2FnZUNvbnRlbnQtMnFXV3hDLAojYXBwLW1vdW50IC5zaWRlYmFyLTJLOHBGaCAuY29udGFpbmVyLVBOa2ltYyAuY29udGFpbmVyRGVmYXVsdC0xWm5BRHEgLndyYXBwZXItMXVjalRkOm5vdCgubW9kZU11dGVkLTNvc3k3aik6bm90KC5tb2RlVW5yZWFkLTF6cEZkQSk6bm90KC5tb2RlU2VsZWN0ZWQtMXpBcEpfKSAuY29udGVudC0zYXRfQVUgLm5hbWUtM19Ec21nLAojYXBwLW1vdW50IC5zaWRlYmFyLTJLOHBGaCAuY29udGFpbmVyLVBOa2ltYyAuY29udGFpbmVyRGVmYXVsdC0xWm5BRHEgLndyYXBwZXItMXVjalRkOm5vdCgubW9kZU11dGVkLTNvc3k3aik6bm90KC5tb2RlVW5yZWFkLTF6cEZkQSk6bm90KC5tb2RlU2VsZWN0ZWQtMXpBcEpfKSAuY29udGVudC0zYXRfQVUgc3ZnLAojYXBwLW1vdW50IC5zaWRlYmFyLTJLOHBGaCAuY2hhbm5lbC0yUUQ5X08gewogICAgY29sb3I6ICM5M2ExYTEgIWltcG9ydGFudDsKfQoKI2FwcC1tb3VudCA6OnNlbGVjdGlvbiwKI2FwcC1tb3VudCAuY2hhdC0zYlJ4eHUgLm1lbnRpb24sCiNhcHAtbW91bnQgLm1lbWJlcnMtMTk5OHBCIC5tZW1iZXItMy1ZWFVlLnNlbGVjdGVkLWFYaFFSNiAucm9sZUNvbG9yLXJ6MnZNMCwKI2FwcC1tb3VudCAubWVtYmVycy0xOTk4cEIgLm1lbWJlci0zLVlYVWUgLmJvdFRhZy0yV1BKNzQsCiNhcHAtbW91bnQgLnNpZGViYXItMks4cEZoIC5jb250YWluZXItUE5raW1jIC5jb250YWluZXJEZWZhdWx0LTFabkFEcS5zZWxlY3RlZC0zN2pfaVUgLmNvbnRlbnQtM2F0X0FVIC5uYW1lLTNfRHNtZywKI2FwcC1tb3VudCAuc2lkZWJhci0ySzhwRmggLmNvbnRhaW5lci1QTmtpbWMgLmNvbnRhaW5lckRlZmF1bHQtMVpuQURxLnNlbGVjdGVkLTM3al9pVSAuY29udGVudC0zYXRfQVUgc3ZnLAojYXBwLW1vdW50IC50b29sdGlwQmxhY2stUFBHNDd6LCAjYXBwLW1vdW50IC50b29sdGlwQnJhbmQtZzAzTno4LCAjYXBwLW1vdW50IC50b29sdGlwUmVkLTgtOU5lUCwKI2FwcC1tb3VudCAuYnViYmxlLTN3ZTJkaSwgI2FwcC1tb3VudCAuc2lkZWJhci0ySzhwRmggLmNvbnRhaW5lci1QTmtpbWMgLmNvbnRhaW5lckRlZmF1bHQtMVpuQURxIC53cmFwcGVyLTF1Y2pUZDpub3QoLm1vZGVNdXRlZC0zb3N5N2opLm1vZGVVbnJlYWQtMXpwRmRBIC5jb250ZW50LTNhdF9BVSAubmFtZS0zX0RzbWcsCiNhcHAtbW91bnQgLnNpZGViYXItMks4cEZoIC5jb250YWluZXItUE5raW1jIC5jb250YWluZXJEZWZhdWx0LTFabkFEcSAud3JhcHBlci0xdWNqVGQ6bm90KC5tb2RlTXV0ZWQtM29zeTdqKS5tb2RlVW5yZWFkLTF6cEZkQSAuY29udGVudC0zYXRfQVUgc3ZnIHsKICAgIGNvbG9yOiAjMDAyYjM2ICFpbXBvcnRhbnQ7CiAgICB0ZXh0LXNoYWRvdzogbm9uZSAhaW1wb3J0YW50Owp9CgojYXBwLW1vdW50IC5zaWRlYmFyLTJLOHBGaCAuY29udGFpbmVyLVBOa2ltYyAuY29udGFpbmVyRGVmYXVsdC0xWm5BRHEgLndyYXBwZXItMXVjalRkOm5vdCgubW9kZU11dGVkLTNvc3k3aikubW9kZVVucmVhZC0xenBGZEEgLmNvbnRlbnQtM2F0X0FVIHsKICAgIGJhY2tncm91bmQ6ICMyNjhiZDIgIWltcG9ydGFudDsKfQoKI2FwcC1tb3VudCAuc2lkZWJhci0ySzhwRmggLmNoYW5uZWwtMlFEOV9PLnNlbGVjdGVkLWFYaFFSNiB7CiAgICBiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQodmFyKC0tQkctZ3JhZGllbnQtZGlyZWN0aW9uKSwgcmdiYSh2YXIoLS1CRy1ncmFkaWVudC1vbmUpLCAxKSAyMCUsIHJnYmEodmFyKC0tQkctZ3JhZGllbnQtdHdvKSwgMSkpOwogICAgY29sb3I6ICMwMDJiMzYgIWltcG9ydGFudDsKICAgIHRleHQtc2hhZG93OiBub25lICFpbXBvcnRhbnQ7Cgp9"
}

View File

@@ -1,45 +0,0 @@
/**
* @name Frosted Glass
* @author Gibbu#1211
* @version 2.0.0
* @description Edited with https://gibbu.me/editor/frostedglass | Base theme: Frosted Glass by Gibbu#1211
* @invite ZHthyCw
* @donate https://paypal.me/IanRGibson
* @authorId 174868361040232448
* @source https://github.com/Gibbu/BetterDiscord-Themes/tree/master/FrostedGlass
* @website https://gibbu.me/editor/frostedglass
*/
@import url('https://fonts.googleapis.com/css?family=DejaVu+Sans+Mono:300,400,500,600,700,800,900&display=swap');
@import url('https://gibbu.github.io/BetterDiscord-Themes/FrostedGlass/base.css');
@import url('https://discord-custom-covers.github.io/usrbg/snippets/userPopouts.css');
@import url('https://discord-custom-covers.github.io/usrbg/snippets/modals.css');
@import url('https://monstrousdev.github.io/themes/addons/user-tags.css');
@import url('https://gibbu.github.io/BetterDiscord-Themes/addons/windows-titlebar.css');
:root {
--background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAoAAAAKCAYAAACNMs+9AAADGHpUWHRSYXcgcHJvZmlsZSB0eXBlIGV4aWYAAHja7ZZbkhshDEX/WUWWgCSEYDk8q7KDLD8XGnvsSTKZqXylyk01DwGS4Ehtu/Hj+3Tf8LAX74JaijlGjyfkkLmgk/z1lF2TD7t+lK3xk9zdJxgiQSvXMMUjH5Az1vORt6OnQK4PivI4E/V5ohxFnI6Bm0fHkNBlwPejqBxFwsdyuMb1WI452eMRzr51fDrtft2qghhHjWQBdWBvFjP6iX0w3Ftfjs7Gee3Teul5P3a3pbh55iEkftfp8lKut+BV1CwZ6zCLfsCooB/2/XoHZHABnudzt8Pfb/Ppbm7tHx73mWOdcHgOg1vvhIH7ZeJdGMRx5PKOXry3W+7eT5D+Hvdm+uCRhbthfvIIE/Hp0OntnbOnOcd1uhIijhzPoW4nIbdRzl5XEOxtEcXwKvq2S0ZJyICGGOu++YrSKBMD8aRAnQpNR2N3GjX4GHiwoWVuLFuWwCJzkwU9rEKTTbJ0hABLQ6jICoQ53fGFtt287TVKsNwJS5mgjLDlr8V9ZtFHZc6VS0Tu5AxdgHmlIdxY5FaNZSBC81yq7gu+leeAPGAFCHVfc8IBi6+Xiqr0FluyQQvWKdorucn6tX8pCrCtcIYECHwkUYrkjdmIcJEJgAr5xBK4ggCpcoeTHEQi2CAJYNphj9Fey8qXHF9JkFCJYmCTpQBWCIr4sZAQQ0VFg6pGNU2atUSJwSHDYrS4PrfFxIKpRTNLlq0kSSFpislSSjmVzFnwNdaMdMwp51wKbBZoLtEVrC+QVK5SQ9Uaq9VUcy0N4dNC0xabtdRyK527dORxj9166rmXQQOhNMJQN+KwkUYeZSLWpswwdcZpM808y53aofpL+QI1OtR4k1rr7E4NUrOrdTteoGQxAzEOBOK2CCCgeTHziULgRW4x85mRFcpwUhebTr5Q5OAkDGKddGf3Ru5L3FwMH3Ljz5JzC90/ktvc3NAHbr+h1tcvcdvErixcd+oF2TdpFE6Fa/WTm1vdVNYv6r+1L0UvRS9FL0UvRS9FL0X/tyL8fcjuJ86avGDS/Nk0AAABhGlDQ1BJQ0MgcHJvZmlsZQAAeJx9kT1Iw0AcxV9Ti1IqCnYQUcjQOlkQFXHUKhShQqgVWnUwufQLmjQkKS6OgmvBwY/FqoOLs64OroIg+AHi5Oik6CIl/i8ttIjx4Lgf7+497t4BQr3MNKtrHNB020wl4mImuyp2vyKAEfQjiqDMLGNOkpLwHF/38PH1LsazvM/9OXrVnMUAn0g8ywzTJt4gnt60Dc77xGFWlFXic+Ixky5I/Mh1pclvnAsuCzwzbKZT88RhYrHQwUoHs6KpEU8RR1RNp3wh02SV8xZnrVxlrXvyF4Zy+soy12kOI4FFLEGCCAVVlFCGjRitOikWUrQf9/APuX6JXAq5SmDkWEAFGmTXD/4Hv7u18pMTzaRQHAi8OM5HFOjeBRo1x/k+dpzGCeB/Bq70tr9SB2Y+Sa+1tcgR0LcNXFy3NWUPuNwBBp8M2ZRdyU9TyOeB9zP6piwwcAsE15q9tfZx+gCkqavkDXBwCIwWKHvd4909nb39e6bV3w9c3HKeW1/O7QAAAAZiS0dEAP8A/wD/oL2nkwAAAAlwSFlzAAAuIwAALiMBeKU/dgAAAAd0SU1FB+QFHRAqDr9nsVkAAAAZdEVYdENvbW1lbnQAQ3JlYXRlZCB3aXRoIEdJTVBXgQ4XAAAAGElEQVQY02Nk0DbrYSACMDEQCUYVUkchAIoXAQHyaCuwAAAAAElFTkSuQmCC');
--background-image-blur: 0px;
--popout-modal-image: var(--background-image);
--popout-modal-blur: 0px;
--home-button-image: url('https://gibbu.github.io/BetterDiscord-Themes/FrostedGlass/assets/discord.svg');
--serverlist-brightness: 0;
--left-brightness: 0;
--middle-brightness: 0;
--right-brightness: 0;
--popout-modal-brightness: 0.5;
--gradient-primary: 133,153,0;
--gradient-secondary: 133,153,0;
--gradient-direction: 320deg;
--tint-colour: 255,51,159;
--tint-brightness: 0;
--window-padding: 0px;
--window-roundness: 0px;
--scrollbar-colour: rgba(255,255,255,0.05);
--link-colour: #00b0f4;
--show-gift-gif-buttons: none;
--font: 'DejaVu Sans Mono';
--update-notice-1: none;
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

View File

@@ -1,3 +1,2 @@
--enable-features=VaapiVideoDecoder,VaapiVideoEncoder,WebUIDarkMode --enable-features=VaapiVideoDecoder,VaapiVideoEncoder,WebUIDarkMode
--ozone-platform=wayland
--force-dark-mode --force-dark-mode

View File

@@ -1,243 +0,0 @@
{
"output": {
"blocklist": [],
"equalizer#0": {
"balance": 0.0,
"bypass": false,
"input-gain": -9.3,
"left": {
"band0": {
"frequency": 19.952623149688797,
"gain": 4.000000000000001,
"mode": "RLC (BT)",
"mute": false,
"q": 1.0999999999999996,
"slope": "x1",
"solo": false,
"type": "Bell",
"width": 1.27
},
"band1": {
"frequency": 96.76334020503853,
"gain": -2.4999999999999893,
"mode": "RLC (BT)",
"mute": false,
"q": 0.6999999999999997,
"slope": "x1",
"solo": false,
"type": "Bell",
"width": 1.92
},
"band2": {
"frequency": 105.24354052777788,
"gain": 5.499999999999989,
"mode": "RLC (BT)",
"mute": false,
"q": 0.7099999999999997,
"slope": "x1",
"solo": false,
"type": "Lo-shelf",
"width": 1.89
},
"band3": {
"frequency": 214.92214271853953,
"gain": -1.7000000000000006,
"mode": "RLC (BT)",
"mute": false,
"q": 1.0999999999999996,
"slope": "x1",
"solo": false,
"type": "Bell",
"width": 1.27
},
"band4": {
"frequency": 1399.7170852629492,
"gain": -2.099999999999998,
"mode": "RLC (BT)",
"mute": false,
"q": 1.5047602375372453,
"slope": "x1",
"solo": false,
"type": "Bell",
"width": 0.94
},
"band5": {
"frequency": 2000.1851104970312,
"gain": 3.0,
"mode": "RLC (BT)",
"mute": false,
"q": 0.7099999999999997,
"slope": "x1",
"solo": false,
"type": "Hi-shelf",
"width": 1.89
},
"band6": {
"frequency": 2699.882756274361,
"gain": -1.3000000000000003,
"mode": "RLC (BT)",
"mute": false,
"q": 3.0000000000000013,
"slope": "x1",
"solo": false,
"type": "Bell",
"width": 0.48
},
"band7": {
"frequency": 3369.811843303749,
"gain": -3.900000000000002,
"mode": "RLC (BT)",
"mute": false,
"q": 2.500000000000001,
"slope": "x1",
"solo": false,
"type": "Bell",
"width": 0.57
},
"band8": {
"frequency": 5349.758767782307,
"gain": -3.4999999999999893,
"mode": "RLC (BT)",
"mute": false,
"q": 3.0000000000000013,
"slope": "x1",
"solo": false,
"type": "Bell",
"width": 0.48
},
"band9": {
"frequency": 10999.87233627273,
"gain": -4.0,
"mode": "RLC (BT)",
"mute": false,
"q": 0.7099999999999997,
"slope": "x1",
"solo": false,
"type": "Hi-shelf",
"width": 1.89
}
},
"mode": "IIR",
"num-bands": 10,
"output-gain": 9.0,
"pitch-left": 0.0,
"pitch-right": 0.0,
"right": {
"band0": {
"frequency": 19.952623149688797,
"gain": 4.000000000000001,
"mode": "RLC (BT)",
"mute": false,
"q": 1.0999999999999996,
"slope": "x1",
"solo": false,
"type": "Bell",
"width": 4.0
},
"band1": {
"frequency": 96.76334020503853,
"gain": -2.4999999999999893,
"mode": "RLC (BT)",
"mute": false,
"q": 0.6999999999999997,
"slope": "x1",
"solo": false,
"type": "Bell",
"width": 4.0
},
"band2": {
"frequency": 105.24354052777788,
"gain": 5.499999999999989,
"mode": "RLC (BT)",
"mute": false,
"q": 0.7099999999999997,
"slope": "x1",
"solo": false,
"type": "Lo-shelf",
"width": 4.0
},
"band3": {
"frequency": 214.92214271853953,
"gain": -1.7000000000000006,
"mode": "RLC (BT)",
"mute": false,
"q": 1.0999999999999996,
"slope": "x1",
"solo": false,
"type": "Bell",
"width": 4.0
},
"band4": {
"frequency": 1399.7170852629492,
"gain": -2.099999999999998,
"mode": "RLC (BT)",
"mute": false,
"q": 1.5047602375372453,
"slope": "x1",
"solo": false,
"type": "Bell",
"width": 4.0
},
"band5": {
"frequency": 2000.1851104970312,
"gain": 3.0,
"mode": "RLC (BT)",
"mute": false,
"q": 0.7099999999999997,
"slope": "x1",
"solo": false,
"type": "Hi-shelf",
"width": 4.0
},
"band6": {
"frequency": 2699.882756274361,
"gain": -1.3000000000000003,
"mode": "RLC (BT)",
"mute": false,
"q": 3.0000000000000013,
"slope": "x1",
"solo": false,
"type": "Bell",
"width": 4.0
},
"band7": {
"frequency": 3369.811843303749,
"gain": -3.900000000000002,
"mode": "RLC (BT)",
"mute": false,
"q": 2.500000000000001,
"slope": "x1",
"solo": false,
"type": "Bell",
"width": 4.0
},
"band8": {
"frequency": 5349.758767782307,
"gain": -3.4999999999999893,
"mode": "RLC (BT)",
"mute": false,
"q": 3.0000000000000013,
"slope": "x1",
"solo": false,
"type": "Bell",
"width": 4.0
},
"band9": {
"frequency": 10999.87233627273,
"gain": -4.0,
"mode": "RLC (BT)",
"mute": false,
"q": 0.7099999999999997,
"slope": "x1",
"solo": false,
"type": "Hi-shelf",
"width": 4.0
}
},
"split-channels": false
},
"plugins_order": [
"equalizer#0"
]
}
}

View File

@@ -1,3 +1,2 @@
--enable-features=VaapiVideoDecoder --enable-features=UseOzonePlatform
--ozone-platform=wayland --ozone-platform=wayland
--in-process-gpu

View File

@@ -0,0 +1,2 @@
--enable-features=UseOzonePlatform
--ozone-platform=wayland

View File

@@ -1,2 +1 @@
export XDG_CURRENT_DESKTOP=sway XDG_CURRENT_DESKTOP=sway
export XDG_SESSION_TYPE=wayland

View File

@@ -1,2 +0,0 @@
#!/bin/sh
find ~/.config/kitty/bells -type f | shuf -n 1 | mpv --audio-display=no --playlist=-

Binary file not shown.

View File

@@ -184,6 +184,11 @@ font_family DejaVuSansMono
#: map cmd+shift+v paste_from_buffer a1 #: map cmd+shift+v paste_from_buffer a1
map ctrl+shift+up send_text application \033[0A
map ctrl+shift+right send_text application \033[0C
map ctrl+shift+down send_text application \033[0B
map ctrl+shift+left send_text application \033[0D
#: Note that copying to the clipboard is a security risk, as all #: Note that copying to the clipboard is a security risk, as all
#: programs, including websites open in your browser can read the #: programs, including websites open in your browser can read the
#: contents of the system clipboard. #: contents of the system clipboard.
@@ -261,7 +266,7 @@ font_family DejaVuSansMono
#: Terminal bell {{{ #: Terminal bell {{{
# enable_audio_bell yes enable_audio_bell no
#: Enable/disable the audio bell. Useful in environments that require #: Enable/disable the audio bell. Useful in environments that require
#: silence. #: silence.
@@ -282,8 +287,7 @@ font_family DejaVuSansMono
#: windows in the tab and the window is not the currently focused #: windows in the tab and the window is not the currently focused
#: window #: window
# command_on_bell mpv --audio-display=no ~/loli.mp3 # command_on_bell none
# command_on_bell ~/.config/kitty/bell.sh
#: Program to run when a bell occurs. #: Program to run when a bell occurs.
@@ -491,6 +495,7 @@ color15 #fdf6e3
#: The foreground and background colors #: The foreground and background colors
#background_opacity 0.8
background_opacity 1.0 background_opacity 1.0
#: The opacity of the background. A number between 0 and 1, where 1 is #: The opacity of the background. A number between 0 and 1, where 1 is
@@ -1035,8 +1040,6 @@ shell /bin/zsh
# map kitty_mod+a>1 set_background_opacity 1 # map kitty_mod+a>1 set_background_opacity 1
# map kitty_mod+a>d set_background_opacity default # map kitty_mod+a>d set_background_opacity default
# map kitty_mod+delete clear_terminal reset active # map kitty_mod+delete clear_terminal reset active
map kitty_mod+a>o set_background_opacity 1.0
map kitty_mod+a>t set_background_opacity 0.8
#: You can create shortcuts to clear/reset the terminal. For example:: #: You can create shortcuts to clear/reset the terminal. For example::

View File

@@ -2,13 +2,17 @@ ctrl+r cycle-values video-rotate 0 90 180 270
ctrl+b cycle deband ctrl+b cycle deband
b cycle-values scale "bilinear" "spline64"; cycle-values dscale "bilinear" "mitchell"; cycle-values cscale "bilinear" "sinc" b cycle-values scale "bilinear" "spline64"; cycle-values dscale "bilinear" "mitchell"; cycle-values cscale "bilinear" "sinc"
ctrl+s sub-reload ctrl+s sub-reload
ctrl+S cycle shuffle
S screenshot-to-file /tmp/mpv-screenshot.png ; run sh -c "cat /tmp/mpv-screenshot.png | wl-copy -t image/png" S screenshot-to-file /tmp/mpv-screenshot.png ; run sh -c "cat /tmp/mpv-screenshot.png | wl-copy -t image/png"
x add sub-delay -0.04 x add sub-delay -0.04
X add sub-delay +0.04 X add sub-delay +0.04
# increase subtitle font size - add video-zoom -.25
ALT+k add sub-scale +0.1 + add video-zoom .25
kp8 add video-pan-y .05
kp6 add video-pan-x -.05
kp2 add video-pan-y -.05
kp4 add video-pan-x .05
# decrease subtitle font size kp5 set video-pan-x 0; set video-pan-y 0; set video-zoom 0
ALT+j add sub-scale -0.1

View File

@@ -1,9 +1,8 @@
profile=gpu-hq profile=gpu-hq
#gpu-api=vulkan #gpu-api=vulkan
#gpu-context=waylandvk
gpu-context=wayland gpu-context=wayland
hwdec=none hwdec=none
hdr-compute-peak=no fullscreen=yes
#ao=jack #ao=jack
#audio-channels=stereo #audio-channels=stereo
@@ -28,18 +27,10 @@ screenshot-format=png
sub-gray=yes # pour pas avoir des subs jaunes de merde sub-gray=yes # pour pas avoir des subs jaunes de merde
sub-gauss=0.7 # ça rend les subs un peu moins carrés, peut-être à adapter à vos envies sub-gauss=0.7 # ça rend les subs un peu moins carrés, peut-être à adapter à vos envies
sub-font="Roboto Regular" sub-font="Roboto Regular"
#sub-ass-vsfilter-aspect-compat=no
#sub-ass-vsfilter-blur-compat=no
prefetch-playlist=yes prefetch-playlist=yes
rebase-start-time=no rebase-start-time=no
ytdl-format=bestvideo[height<=?1440]+bestaudio/best ytdl-format=bestvideo[height<=?1080]+bestaudio/best
#ytdl-raw-options="rm-cache-dir=:yes-playlist=" #ytdl-raw-options="rm-cache-dir=:yes-playlist="
osd-fractions=yes osd-fractions=yes
[downmix]
profile-desc="downmixing profile"
profile-cond=p["audio-params/channel-count"] > 2
ad-lavc-downmix=no
af=lavfi="pan=stereo|FL=0.707*FC+0.5*FL+0.5*BL+0.1*LFE|FR=0.707*FC+0.5*FR+0.5*BR+0.1*LFE"

View File

@@ -1 +0,0 @@
japan7.conf

View File

@@ -1 +0,0 @@
auto=no

View File

@@ -1,29 +1 @@
# Socket path (leave empty for auto)
socket=
# Thumbnail path (leave empty for auto)
thumbnail=
# Maximum thumbnail size in pixels (scaled down to fit)
# Values are scaled when hidpi is enabled
max_height=200
max_width=200
# Overlay id
overlay_id=42
# Thumbnail interval in seconds set to 0 to disable (warning: high cpu usage)
interval=6
# Number of thumbnails
min_thumbnails=6
max_thumbnails=120
# Spawn thumbnailer on file load for faster initial thumbnails
spawn_first=no
# Enable on network playback
network=yes network=yes
# Enable on audio playback
audio=no

View File

@@ -1,329 +0,0 @@
--[[
This script uses the lavfi cropdetect filter to automatically
insert a crop filter with appropriate parameters for the
currently playing video.
It will automatically crop the video, when playback starts.
Also It registers the key-binding "C" (shift+c). You can manually
crop the video by pressing the "C" (shift+c) key.
If the "C" key is pressed again, the crop filter is removed
restoring playback to its original state.
The workflow is as follows: First, it inserts the filter
vf=lavfi=cropdetect. After <detect_seconds> (default is 1)
seconds, it then inserts the filter vf=crop=w:h:x:y, where
w,h,x,y are determined from the vf-metadata gathered by
cropdetect. The cropdetect filter is removed immediately after
the crop filter is inserted as it is no longer needed.
Since the crop parameters are determined from the 1 second of
video between inserting the cropdetect and crop filters, the "C"
key should be pressed at a position in the video where the crop
region is unambiguous (i.e., not a black frame, black background
title card, or dark scene).
The default options can be overridden by adding
script-opts-append=autocrop-<parameter>=<value> into mpv.conf
List of available parameters (For default values, see <options>)
auto: bool - Whether to automatically apply crop at the start of
playback. If you don't want to crop automatically, set it to
false or add "script-opts-append=autocrop-auto=no" into
mpv.conf.
auto_delay: seconds - Delay before starting crop in auto mode.
You can try to increase this value to avoid dark scene or
fade in at beginning. Automatic cropping will not occur if
the value is larger than the remaining playback time.
detect_limit: number[0-255] - Black threshold for cropdetect.
Smaller values will generally result in less cropping.
See limit of https://ffmpeg.org/ffmpeg-filters.html#cropdetect
detect_round: number[2^n] - The value which the width/height
should be divisible by. Smaller values have better detection
accuracy. If you have problems with other filters,
you can try to set it to 4 or 16.
See round of https://ffmpeg.org/ffmpeg-filters.html#cropdetect
detect_min_ratio: number[0.0-1.0] - The ratio of the minimum clip
size to the original. If the picture is over cropped or under
cropped, try adjusting this value.
detect_seconds: seconds - How long to gather cropdetect data.
Increasing this may be desirable to allow cropdetect more
time to collect data.
suppress_osd: bool - Whether the OSD shouldn't be used when filters
are applied and removed.
--]]
require "mp.msg"
require 'mp.options'
local options = {
auto = true,
auto_delay = 4,
detect_limit = "24/255",
detect_round = 2,
detect_min_ratio = 0.5,
detect_seconds = 1,
suppress_osd = false,
}
read_options(options)
local label_prefix = mp.get_script_name()
local labels = {
crop = string.format("%s-crop", label_prefix),
cropdetect = string.format("%s-cropdetect", label_prefix)
}
timers = {
auto_delay = nil,
detect_crop = nil
}
local command_prefix = options.suppress_osd and 'no-osd' or ''
function is_filter_present(label)
local filters = mp.get_property_native("vf")
for index, filter in pairs(filters) do
if filter["label"] == label then
return true
end
end
return false
end
function is_enough_time(seconds)
-- Plus 1 second for deviation.
local time_needed = seconds + 1
local playtime_remaining = mp.get_property_native("playtime-remaining")
return playtime_remaining and time_needed < playtime_remaining
end
function is_cropable()
for _, track in pairs(mp.get_property_native('track-list')) do
if track.type == 'video' and track.selected then
return not track.albumart
end
end
return false
end
function remove_filter(label)
if is_filter_present(label) then
mp.command(string.format('%s vf remove @%s', command_prefix, label))
return true
end
return false
end
function cleanup()
-- Remove all existing filters.
for key, value in pairs(labels) do
remove_filter(value)
end
-- Kill all timers.
for index, timer in pairs(timers) do
if timer then
timer:kill()
timer = nil
end
end
end
function detect_crop()
-- If it's not cropable, exit.
if not is_cropable() then
mp.msg.warn("autocrop only works for videos.")
return
end
-- Verify if there is enough time to detect crop.
local time_needed = options.detect_seconds
if not is_enough_time(time_needed) then
mp.msg.warn("Not enough time to detect crop.")
return
end
-- Insert the cropdetect filter.
local limit = options.detect_limit
local round = options.detect_round
mp.command(
string.format(
'%s vf pre @%s:cropdetect=limit=%s:round=%d:reset=0',
command_prefix, labels.cropdetect, limit, round
)
)
-- Wait to gather data.
timers.detect_crop = mp.add_timeout(time_needed, detect_end)
end
function detect_end()
-- Get the metadata and remove the cropdetect filter.
local cropdetect_metadata =
mp.get_property_native(
string.format("vf-metadata/%s",
labels.cropdetect
)
)
remove_filter(labels.cropdetect)
-- Remove the timer of detect crop.
if timers.detect_crop then
timers.detect_crop:kill()
timers.detect_crop = nil
end
local meta = {}
-- Verify the existence of metadata.
if cropdetect_metadata then
meta = {
w = cropdetect_metadata["lavfi.cropdetect.w"],
h = cropdetect_metadata["lavfi.cropdetect.h"],
x = cropdetect_metadata["lavfi.cropdetect.x"],
y = cropdetect_metadata["lavfi.cropdetect.y"],
}
else
mp.msg.error("No crop data.")
mp.msg.info("Was the cropdetect filter successfully inserted?")
mp.msg.info("Does your version of ffmpeg/libav support AVFrame metadata?")
return
end
-- Verify that the metadata meets the requirements and convert it.
if meta.w and meta.h and meta.x and meta.y then
local width = mp.get_property_native("width")
local height = mp.get_property_native("height")
meta = {
w = tonumber(meta.w),
h = tonumber(meta.h),
x = tonumber(meta.x),
y = tonumber(meta.y),
min_w = width * options.detect_min_ratio,
min_h = height * options.detect_min_ratio,
max_w = width,
max_h = height
}
else
mp.msg.error("Got empty crop data.")
mp.msg.info("You might need to increase detect_seconds.")
return
end
apply_crop(meta)
end
function apply_crop(meta)
-- Verify if it is necessary to crop.
local is_effective = meta.x > 0 or meta.y > 0
or meta.w < meta.max_w or meta.h < meta.max_h
if not is_effective then
mp.msg.info("No area detected for cropping.")
return
end
-- Verify it is not over cropped.
local is_excessive = meta.w < meta.min_w and meta.h < meta.min_h
if is_excessive then
mp.msg.info("The area to be cropped is too large.")
mp.msg.info("You might need to decrease detect_min_ratio.")
return
end
-- Remove existing crop.
remove_filter(labels.crop)
-- Apply crop.
mp.command(
string.format("%s vf pre @%s:lavfi-crop=w=%s:h=%s:x=%s:y=%s",
command_prefix, labels.crop, meta.w, meta.h, meta.x, meta.y
)
)
end
function on_start()
-- Clean up at the beginning.
cleanup()
-- If auto is not true, exit.
if not options.auto then
return
end
-- If it is the beginning, wait for detect_crop
-- after auto_delay seconds, otherwise immediately.
local playback_time = mp.get_property_native("playback-time")
local is_delay_needed = playback_time
and options.auto_delay > playback_time
if is_delay_needed then
-- Verify if there is enough time for autocrop.
local time_needed = options.auto_delay + options.detect_seconds
if not is_enough_time(time_needed) then
mp.msg.warn("Not enough time for autocrop.")
return
end
timers.auto_delay = mp.add_timeout(time_needed,
function()
detect_crop()
-- Remove the timer of auto delay.
timers.auto_delay:kill()
timers.auto_delay = nil
end
)
else
detect_crop()
end
end
function on_toggle()
-- If it is during auto_delay, kill the timer.
if timers.auto_delay then
timers.auto_delay:kill()
timers.auto_delay = nil
end
-- Cropped => Remove it.
if remove_filter(labels.crop) then
return
end
-- Detecting => Leave it.
if timers.detect_crop then
mp.msg.warn("Already cropdetecting!")
return
end
-- Neither => Do delectcrop.
detect_crop()
end
mp.add_key_binding("C", "toggle_crop", on_toggle)
mp.register_event("end-file", cleanup)
mp.register_event("file-loaded", on_start)

View File

@@ -1,35 +0,0 @@
local settings = {
username = "",
password = "",
projo_host = ""
}
local opts = require 'mp.options'
opts.read_options(settings, "japan7")
local function is_projo(path)
return path:match("^https://projection")
end
function on_load()
local path = mp.get_property("path")
local match = path:gsub("^https://fubuki.aidoru.agency", "https://"..settings.username..":"..settings.password.."@fubuki.aidoru.agency")
match = match:gsub("^https://korone.aidoru.agency", "https://"..settings.username..":"..settings.password.."@korone.aidoru.agency")
match = match:gsub("^https://yuyuko.butaishoujo.moe", "https://"..settings.username..":"..settings.password.."@yuyuko.butaishoujo.moe")
match = match:gsub("^https://projo.yuru.moe", "https://"..settings.username..":"..settings.password.."@projo.yuru.moe")
match = match:gsub("^https://gungnir.dato.moe", "https://"..settings.username..":"..settings.password.."@gungnir.dato.moe")
match = match:gsub("^https://projection", settings.projo_host)
if match ~= path then
if is_projo(path) then
local stream = match:gsub("^(.+)/.-$", "%1/stream")
mp.set_property("ordered-chapters-files", stream)
end
mp.set_property("stream-open-filename", match)
local ass = match:gsub("...$", "ass")
mp.commandv("sub-add", ass)
end
end
mp.register_event('start-file', on_load)

View File

@@ -0,0 +1,34 @@
local utils = require("mp.utils")
local function get_kdata(kid)
local resp = mp.command_native({
name = "subprocess",
args = { "curl", "-s", "https://kara.moe/api/karas/" .. kid },
capture_stdout = true,
})
return utils.parse_json(resp.stdout)
end
local function get_title(kdata)
return kdata.titles[kdata.titles_default_language]
end
local function on_load()
local path = mp.get_property("path")
local kid = path:match("^https://kara.moe/kara/.-([0-9a-z-]+)$")
if kid == nil then
kid = path:match("^https://live.karaokes.moe/%?video=([0-9a-z-]+)$")
end
if kid ~= nil then
local kdata = get_kdata(kid)
local mediafile = "https://kara.moe/downloads/medias/" .. kdata.mediafile
local subfile = "https://kara.moe/downloads/lyrics/" .. kdata.subfile
mp.set_property("stream-open-filename", mediafile)
mp.set_property("replaygain-fallback", kdata.gain)
mp.set_property("title", get_title(kdata))
mp.commandv("sub-add", subfile)
end
end
mp.register_event("start-file", on_load)

View File

@@ -0,0 +1,675 @@
-- repl.lua -- A graphical REPL for mpv input commands
--
-- © 2016, James Ross-Gowan
--
-- Permission to use, copy, modify, and/or distribute this software for any
-- purpose with or without fee is hereby granted, provided that the above
-- copyright notice and this permission notice appear in all copies.
--
-- THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
-- WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
-- MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
-- SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
-- WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
-- OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
-- CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
local utils = require 'mp.utils'
local options = require 'mp.options'
local assdraw = require 'mp.assdraw'
-- Default options
local opts = {
-- All drawing is scaled by this value, including the text borders and the
-- cursor. Change it if you have a high-DPI display.
scale = 1,
-- Set the font used for the REPL and the console. This probably doesn't
-- have to be a monospaced font.
font = 'monospace',
-- Set the font size used for the REPL and the console. This will be
-- multiplied by "scale."
['font-size'] = 16,
}
function detect_platform()
local o = {}
-- Kind of a dumb way of detecting the platform but whatever
if mp.get_property_native('options/vo-mmcss-profile', o) ~= o then
return 'windows'
elseif mp.get_property_native('options/cocoa-force-dedicated-gpu', o) ~= o then
return 'macos'
end
return 'linux'
end
-- Pick a better default font for Windows and macOS
local platform = detect_platform()
if platform == 'windows' then
opts.font = 'Consolas'
elseif platform == 'macos' then
opts.font = 'Menlo'
end
-- Apply user-set options
options.read_options(opts)
-- Build a list of commands, properties and options for tab-completion
local option_info = {
'name', 'type', 'set-from-commandline', 'set-locally', 'default-value',
'min', 'max', 'choices',
}
local cmd_list = {
'ignore', 'seek', 'revert-seek', 'quit', 'quit-watch-later', 'stop',
'frame-step', 'frame-back-step', 'playlist-next', 'playlist-prev',
'playlist-shuffle', 'sub-step', 'sub-seek', 'osd', 'print-text',
'show-text', 'show-progress', 'sub-add', 'sub-remove', 'sub-reload',
'tv-last-channel', 'screenshot', 'screenshot-to-file', 'screenshot-raw',
'loadfile', 'loadlist', 'playlist-clear', 'playlist-remove',
'playlist-move', 'run', 'set', 'add', 'cycle', 'multiply', 'cycle-values',
'enable-section', 'disable-section', 'define-section', 'ab-loop',
'drop-buffers', 'af', 'af-command', 'ao-reload', 'vf', 'vf-command',
'script-binding', 'script-message', 'script-message-to', 'overlay-add',
'overlay-remove', 'write-watch-later-config', 'hook-add', 'hook-ack',
'mouse', 'keypress', 'keydown', 'keyup', 'audio-add', 'audio-remove',
'audio-reload', 'rescan-external-file', 'apply-profile', 'load-script',
}
local prop_list = mp.get_property_native('property-list')
for _, opt in ipairs(mp.get_property_native('options')) do
prop_list[#prop_list + 1] = 'options/' .. opt
prop_list[#prop_list + 1] = 'file-local-options/' .. opt
prop_list[#prop_list + 1] = 'option-info/' .. opt
for _, p in ipairs(option_info) do
prop_list[#prop_list + 1] = 'option-info/' .. opt .. '/' .. p
end
end
local repl_active = false
local insert_mode = false
local line = ''
local cursor = 1
local history = {}
local history_pos = 1
local log_ring = {}
-- Add a line to the log buffer (which is limited to 100 lines)
function log_add(style, text)
log_ring[#log_ring + 1] = { style = style, text = text }
if #log_ring > 100 then
table.remove(log_ring, 1)
end
end
-- Escape a string for verbatim display on the OSD
function ass_escape(str)
-- There is no escape for '\' in ASS (I think?) but '\' is used verbatim if
-- it isn't followed by a recognised character, so add a zero-width
-- non-breaking space
str = str:gsub('\\', '\\\239\187\191')
str = str:gsub('{', '\\{')
str = str:gsub('}', '\\}')
-- Precede newlines with a ZWNBSP to prevent ASS's weird collapsing of
-- consecutive newlines
str = str:gsub('\n', '\239\187\191\\N')
return str
end
-- Render the REPL and console as an ASS OSD
function update()
local screenx, screeny, aspect = mp.get_osd_size()
screenx = screenx / opts.scale
screeny = screeny / opts.scale
-- Clear the OSD if the REPL is not active
if not repl_active then
mp.set_osd_ass(screenx, screeny, '')
return
end
local ass = assdraw.ass_new()
local style = '{\\r' ..
'\\1a&H00&\\3a&H00&\\4a&H99&' ..
'\\1c&Heeeeee&\\3c&H111111&\\4c&H000000&' ..
'\\fn' .. opts.font .. '\\fs' .. opts['font-size'] ..
'\\bord2\\xshad0\\yshad1\\fsp0\\q1}'
-- Create the cursor glyph as an ASS drawing. ASS will draw the cursor
-- inline with the surrounding text, but it sets the advance to the width
-- of the drawing. So the cursor doesn't affect layout too much, make it as
-- thin as possible and make it appear to be 1px wide by giving it 0.5px
-- horizontal borders.
local cheight = opts['font-size'] * 8
local cglyph = '{\\r' ..
'\\1a&H44&\\3a&H44&\\4a&H99&' ..
'\\1c&Heeeeee&\\3c&Heeeeee&\\4c&H000000&' ..
'\\xbord0.5\\ybord0\\xshad0\\yshad1\\p4\\pbo24}' ..
'm 0 0 l 1 0 l 1 ' .. cheight .. ' l 0 ' .. cheight ..
'{\\p0}'
local before_cur = ass_escape(line:sub(1, cursor - 1))
local after_cur = ass_escape(line:sub(cursor))
-- Render log messages as ASS. This will render at most screeny / font-size
-- messages.
local log_ass = ''
local log_messages = #log_ring
local log_max_lines = math.ceil(screeny / opts['font-size'])
if log_max_lines < log_messages then
log_messages = log_max_lines
end
for i = #log_ring - log_messages + 1, #log_ring do
log_ass = log_ass .. style .. log_ring[i].style .. ass_escape(log_ring[i].text)
end
ass:new_event()
ass:an(1)
ass:pos(2, screeny - 2)
ass:append(log_ass .. '\\N')
ass:append(style .. '> ' .. before_cur)
ass:append(cglyph)
ass:append(style .. after_cur)
-- Redraw the cursor with the REPL text invisible. This will make the
-- cursor appear in front of the text.
ass:new_event()
ass:an(1)
ass:pos(2, screeny - 2)
ass:append(style .. '{\\alpha&HFF&}> ' .. before_cur)
ass:append(cglyph)
ass:append(style .. '{\\alpha&HFF&}' .. after_cur)
mp.set_osd_ass(screenx, screeny, ass.text)
end
-- Set the REPL visibility (`, Esc)
function set_active(active)
if active == repl_active then return end
if active then
repl_active = true
insert_mode = false
mp.enable_key_bindings('repl-input', 'allow-hide-cursor+allow-vo-dragging')
else
repl_active = false
mp.disable_key_bindings('repl-input')
end
update()
end
-- Show the repl if hidden and replace its contents with 'text'
-- (script-message-to repl type)
function show_and_type(text)
text = text or ''
-- Save the line currently being edited, just in case
if line ~= text and line ~= '' and history[#history] ~= line then
history[#history + 1] = line
end
line = text
cursor = line:len() + 1
history_pos = #history + 1
insert_mode = false
if repl_active then
update()
else
set_active(true)
end
end
-- Naive helper function to find the next UTF-8 character in 'str' after 'pos'
-- by skipping continuation bytes. Assumes 'str' contains valid UTF-8.
function next_utf8(str, pos)
if pos > str:len() then return pos end
repeat
pos = pos + 1
until pos > str:len() or str:byte(pos) < 0x80 or str:byte(pos) > 0xbf
return pos
end
-- As above, but finds the previous UTF-8 charcter in 'str' before 'pos'
function prev_utf8(str, pos)
if pos <= 1 then return pos end
repeat
pos = pos - 1
until pos <= 1 or str:byte(pos) < 0x80 or str:byte(pos) > 0xbf
return pos
end
-- Insert a character at the current cursor position (' '-'~', Shift+Enter)
function handle_char_input(c)
if insert_mode then
line = line:sub(1, cursor - 1) .. c .. line:sub(next_utf8(line, cursor))
else
line = line:sub(1, cursor - 1) .. c .. line:sub(cursor)
end
cursor = cursor + 1
update()
end
-- Remove the character behind the cursor (Backspace)
function handle_backspace()
if cursor <= 1 then return end
local prev = prev_utf8(line, cursor)
line = line:sub(1, prev - 1) .. line:sub(cursor)
cursor = prev
update()
end
-- Remove the character in front of the cursor (Del)
function handle_del()
if cursor > line:len() then return end
line = line:sub(1, cursor - 1) .. line:sub(next_utf8(line, cursor))
update()
end
-- Toggle insert mode (Ins)
function handle_ins()
insert_mode = not insert_mode
end
-- Move the cursor to the next character (Right)
function next_char(amount)
cursor = next_utf8(line, cursor)
update()
end
-- Move the cursor to the previous character (Left)
function prev_char(amount)
cursor = prev_utf8(line, cursor)
update()
end
-- Clear the current line (Ctrl+C)
function clear()
line = ''
cursor = 1
insert_mode = false
history_pos = #history + 1
update()
end
-- Close the REPL if the current line is empty, otherwise do nothing (Ctrl+D)
function maybe_exit()
if line == '' then
set_active(false)
end
end
-- Run the current command and clear the line (Enter)
function handle_enter()
if line == '' then
return
end
if history[#history] ~= line then
history[#history + 1] = line
end
mp.command(line)
clear()
end
-- Go to the specified position in the command history
function go_history(new_pos)
local old_pos = history_pos
history_pos = new_pos
-- Restrict the position to a legal value
if history_pos > #history + 1 then
history_pos = #history + 1
elseif history_pos < 1 then
history_pos = 1
end
-- Do nothing if the history position didn't actually change
if history_pos == old_pos then
return
end
-- If the user was editing a non-history line, save it as the last history
-- entry. This makes it much less frustrating to accidentally hit Up/Down
-- while editing a line.
if old_pos == #history + 1 and line ~= '' and history[#history] ~= line then
history[#history + 1] = line
end
-- Now show the history line (or a blank line for #history + 1)
if history_pos <= #history then
line = history[history_pos]
else
line = ''
end
cursor = line:len() + 1
insert_mode = false
update()
end
-- Go to the specified relative position in the command history (Up, Down)
function move_history(amount)
go_history(history_pos + amount)
end
-- Go to the first command in the command history (PgUp)
function handle_pgup()
go_history(1)
end
-- Stop browsing history and start editing a blank line (PgDown)
function handle_pgdown()
go_history(#history + 1)
end
-- Move to the start of the current word, or if already at the start, the start
-- of the previous word. (Ctrl+Left)
function prev_word()
-- This is basically the same as next_word() but backwards, so reverse the
-- string in order to do a "backwards" find. This wouldn't be as annoying
-- to do if Lua didn't insist on 1-based indexing.
cursor = line:len() - select(2, line:reverse():find('%s*[^%s]*', line:len() - cursor + 2)) + 1
update()
end
-- Move to the end of the current word, or if already at the end, the end of
-- the next word. (Ctrl+Right)
function next_word()
cursor = select(2, line:find('%s*[^%s]*', cursor)) + 1
update()
end
-- List of tab-completions:
-- pattern: A Lua pattern used in string:find. Should return the start and
-- end positions of the word to be completed in the first and second
-- capture groups (using the empty parenthesis notation "()")
-- list: A list of candidate completion values.
-- append: An extra string to be appended to the end of a successful
-- completion. It is only appended if 'list' contains exactly one
-- match.
local completers = {
{ pattern = '^%s*()[%w_-]+()$', list = cmd_list, append = ' ' },
{ pattern = '^%s*set%s+()[%w_/-]+()$', list = prop_list, append = ' ' },
{ pattern = '^%s*set%s+"()[%w_/-]+()$', list = prop_list, append = '" ' },
{ pattern = '^%s*add%s+()[%w_/-]+()$', list = prop_list, append = ' ' },
{ pattern = '^%s*add%s+"()[%w_/-]+()$', list = prop_list, append = '" ' },
{ pattern = '^%s*cycle%s+()[%w_/-]+()$', list = prop_list, append = ' ' },
{ pattern = '^%s*cycle%s+"()[%w_/-]+()$', list = prop_list, append = '" ' },
{ pattern = '^%s*multiply%s+()[%w_/-]+()$', list = prop_list, append = ' ' },
{ pattern = '^%s*multiply%s+"()[%w_/-]+()$', list = prop_list, append = '" ' },
{ pattern = '${()[%w_/-]+()$', list = prop_list, append = '}' },
}
-- Use 'list' to find possible tab-completions for 'part.' Returns the longest
-- common prefix of all the matching list items and a flag that indicates
-- whether the match was unique or not.
function complete_match(part, list)
local completion = nil
local full_match = false
for _, candidate in ipairs(list) do
if candidate:sub(1, part:len()) == part then
if completion and completion ~= candidate then
local prefix_len = part:len()
while completion:sub(1, prefix_len + 1)
== candidate:sub(1, prefix_len + 1) do
prefix_len = prefix_len + 1
end
completion = candidate:sub(1, prefix_len)
full_match = false
else
completion = candidate
full_match = true
end
end
end
return completion, full_match
end
-- Complete the option or property at the cursor (TAB)
function complete()
local before_cur = line:sub(1, cursor - 1)
local after_cur = line:sub(cursor)
-- Try the first completer that works
for _, completer in ipairs(completers) do
-- Completer patterns should return the start and end of the word to be
-- completed as the first and second capture groups
local _, _, s, e = before_cur:find(completer.pattern)
if not s then
-- Multiple input commands can be separated by semicolons, so all
-- completions that are anchored at the start of the string with
-- '^' can start from a semicolon as well. Replace ^ with ; and try
-- to match again.
_, _, s, e = before_cur:find(completer.pattern:gsub('^^', ';'))
end
if s then
-- If the completer's pattern found a word, check the completer's
-- list for possible completions
local part = before_cur:sub(s, e)
local c, full = complete_match(part, completer.list)
if c then
-- If there was only one full match from the list, add
-- completer.append to the final string. This is normally a
-- space or a quotation mark followed by a space.
if full and completer.append then
c = c .. completer.append
end
-- Insert the completion and update
before_cur = before_cur:sub(1, s - 1) .. c
cursor = before_cur:len() + 1
line = before_cur .. after_cur
update()
return
end
end
end
end
-- Move the cursor to the beginning of the line (HOME)
function go_home()
cursor = 1
update()
end
-- Move the cursor to the end of the line (END)
function go_end()
cursor = line:len() + 1
update()
end
-- Delete from the cursor to the end of the word (Ctrl+W)
function del_word()
local before_cur = line:sub(1, cursor - 1)
local after_cur = line:sub(cursor)
before_cur = before_cur:gsub('[^%s]+%s*$', '', 1)
line = before_cur .. after_cur
cursor = before_cur:len() + 1
update()
end
-- Delete from the cursor to the end of the line (Ctrl+K)
function del_to_eol()
line = line:sub(1, cursor - 1)
update()
end
-- Delete from the cursor back to the start of the line (Ctrl+U)
function del_to_start()
line = line:sub(cursor)
cursor = 1
update()
end
-- Empty the log buffer of all messages (Ctrl+L)
function clear_log_buffer()
log_ring = {}
update()
end
-- Returns a string of UTF-8 text from the clipboard (or the primary selection)
function get_clipboard(clip)
if platform == 'linux' then
local res = utils.subprocess({
args = { 'xclip', '-selection', clip and 'clipboard' or 'primary', '-out' },
playback_only = false,
})
if not res.error then
return res.stdout
end
elseif platform == 'windows' then
local res = utils.subprocess({
args = { 'powershell', '-NoProfile', '-Command', [[& {
Trap {
Write-Error -ErrorRecord $_
Exit 1
}
$clip = ""
if (Get-Command "Get-Clipboard" -errorAction SilentlyContinue) {
$clip = Get-Clipboard -Raw -Format Text -TextFormatType UnicodeText
} else {
Add-Type -AssemblyName PresentationCore
$clip = [Windows.Clipboard]::GetText()
}
$clip = $clip -Replace "`r",""
$u8clip = [System.Text.Encoding]::UTF8.GetBytes($clip)
[Console]::OpenStandardOutput().Write($u8clip, 0, $u8clip.Length)
}]] },
playback_only = false,
})
if not res.error then
return res.stdout
end
elseif platform == 'macos' then
local res = utils.subprocess({
args = { 'pbpaste' },
playback_only = false,
})
if not res.error then
return res.stdout
end
end
return ''
end
-- Paste text from the window-system's clipboard. 'clip' determines whether the
-- clipboard or the primary selection buffer is used (on X11 only.)
function paste(clip)
local text = get_clipboard(clip)
local before_cur = line:sub(1, cursor - 1)
local after_cur = line:sub(cursor)
line = before_cur .. text .. after_cur
cursor = cursor + text:len()
update()
end
-- The REPL has pretty specific requirements for key bindings that aren't
-- really satisified by any of mpv's helper methods, since they must be in
-- their own input section, but they must also raise events on key-repeat.
-- Hence, this function manually creates an input section and puts a list of
-- bindings in it.
function add_repl_bindings(bindings)
local cfg = ''
for i, binding in ipairs(bindings) do
local key = binding[1]
local fn = binding[2]
local name = '__repl_binding_' .. i
mp.add_key_binding(nil, name, fn, 'repeatable')
cfg = cfg .. key .. ' script-binding ' .. mp.script_name .. '/' ..
name .. '\n'
end
mp.commandv('define-section', 'repl-input', cfg, 'force')
end
-- Mapping from characters to mpv key names
local binding_name_map = {
[' '] = 'SPACE',
['#'] = 'SHARP',
}
-- List of input bindings. This is a weird mashup between common GUI text-input
-- bindings and readline bindings.
local bindings = {
{ 'esc', function() set_active(false) end },
{ 'enter', handle_enter },
{ 'shift+enter', function() handle_char_input('\n') end },
{ 'bs', handle_backspace },
{ 'shift+bs', handle_backspace },
{ 'del', handle_del },
{ 'shift+del', handle_del },
{ 'ins', handle_ins },
{ 'shift+ins', function() paste(false) end },
{ 'mouse_btn1', function() paste(false) end },
{ 'left', function() prev_char() end },
{ 'right', function() next_char() end },
{ 'up', function() move_history(-1) end },
{ 'axis_up', function() move_history(-1) end },
{ 'mouse_btn3', function() move_history(-1) end },
{ 'down', function() move_history(1) end },
{ 'axis_down', function() move_history(1) end },
{ 'mouse_btn4', function() move_history(1) end },
{ 'axis_left', function() end },
{ 'axis_right', function() end },
{ 'ctrl+left', prev_word },
{ 'ctrl+right', next_word },
{ 'tab', complete },
{ 'home', go_home },
{ 'end', go_end },
{ 'pgup', handle_pgup },
{ 'pgdwn', handle_pgdown },
{ 'ctrl+c', clear },
{ 'ctrl+d', maybe_exit },
{ 'ctrl+k', del_to_eol },
{ 'ctrl+l', clear_log_buffer },
{ 'ctrl+u', del_to_start },
{ 'ctrl+v', function() paste(true) end },
{ 'meta+v', function() paste(true) end },
{ 'ctrl+w', del_word },
}
-- Add bindings for all the printable US-ASCII characters from ' ' to '~'
-- inclusive. Note, this is a pretty hacky way to do text input. mpv's input
-- system was designed for single-key key bindings rather than text input, so
-- things like dead-keys and non-ASCII input won't work. This is probably okay
-- though, since all mpv's commands and properties can be represented in ASCII.
for b = (' '):byte(), ('~'):byte() do
local c = string.char(b)
local binding = binding_name_map[c] or c
bindings[#bindings + 1] = {binding, function() handle_char_input(c) end}
end
add_repl_bindings(bindings)
-- Add a global binding for enabling the REPL. While it's enabled, its bindings
-- will take over and it can be closed with ESC.
mp.add_key_binding('œ', 'repl-enable', function()
set_active(true)
end)
-- Add a script-message to show the REPL and fill it with the provided text
mp.register_script_message('type', function(text)
show_and_type(text)
end)
-- Redraw the REPL when the OSD size changes. This is needed because the
-- PlayRes of the OSD will need to be adjusted.
mp.observe_property('osd-width', 'native', update)
mp.observe_property('osd-height', 'native', update)
-- Watch for log-messages and print them in the REPL console
mp.enable_messages('info')
mp.register_event('log-message', function(e)
-- Ignore log messages from the OSD because of paranoia, since writing them
-- to the OSD could generate more messages in an infinite loop.
if e.prefix:sub(1, 3) == 'osd' then return end
-- Use color for warn/error/fatal messages. Colors are stolen from base16
-- Eighties by Chris Kempson.
local style = ''
if e.level == 'warn' then
style = '{\\1c&H66ccff&}'
elseif e.level == 'error' then
style = '{\\1c&H7a77f2&}'
elseif e.level == 'fatal' then
style = '{\\1c&H5791f9&\\b1}'
end
log_add(style, '[' .. e.prefix .. '] ' .. e.text)
update()
end)

View File

@@ -1,7 +1,7 @@
(import-macros {: packer-setup! : use!} :hibiscus.packer) (import-macros {: packer-setup : use!} :hibiscus.packer)
(import-macros {: packer : setup} :macros) (import-macros {: packer : setup} :macros)
(packer-setup!) (packer-setup)
(packer (packer
{:display {:open_fn (. (require :packer.util) :float)}} {:display {:open_fn (. (require :packer.util) :float)}}
@@ -12,20 +12,20 @@
(use! :udayvir-singh/hibiscus.nvim) (use! :udayvir-singh/hibiscus.nvim)
(use! "~/.config/nvim/themes/solarized.nvim" (use! "~/.config/nvim/themes/solarized.nvim"
:require :settings.solarized) :module :settings.solarized)
(use! :nvim-treesitter/nvim-treesitter (use! :nvim-treesitter/nvim-treesitter
:run (fn [] ((. (require :nvim-treesitter.install) :update) {:with_sync true})) :run (fn [] ((. (require :nvim-treesitter.install) :update) {:with_sync true}))
:require :settings.treesitter) :module :settings.treesitter)
(use! :feline-nvim/feline.nvim (use! :feline-nvim/feline.nvim
:requires [:kyazdani42/nvim-web-devicons :requires [:kyazdani42/nvim-web-devicons
"~/.config/nvim/themes/solarized.nvim"] "~/.config/nvim/themes/solarized.nvim"]
:after [:solarized.nvim] :after [:solarized.nvim]
:require :settings.feline) :module :settings.feline)
(use! :s1n7ax/nvim-window-picker (use! :s1n7ax/nvim-window-picker
:require :settings.window-picker) :module :settings.window-picker)
(use! :nvim-neo-tree/neo-tree.nvim (use! :nvim-neo-tree/neo-tree.nvim
:branch "v2.x" :branch "v2.x"
@@ -37,13 +37,13 @@
:edluffy/hologram.nvim] :edluffy/hologram.nvim]
:after [:nvim-window-picker :after [:nvim-window-picker
:hologram.nvim] :hologram.nvim]
:require :settings.neo-tree) :module :settings.neo-tree)
(use! :mrjones2014/smart-splits.nvim (use! :mrjones2014/smart-splits.nvim
:require :settings.smart-splits) :module :settings.smart-splits)
(use! :famiu/bufdelete.nvim (use! :famiu/bufdelete.nvim
:require :bufdelete) :module :bufdelete)
(use! :akinsho/bufferline.nvim (use! :akinsho/bufferline.nvim
:tag "v2.*" :tag "v2.*"
@@ -52,32 +52,32 @@
"~/.config/nvim/themes/solarized.nvim"] "~/.config/nvim/themes/solarized.nvim"]
:after [:bufdelete.nvim :after [:bufdelete.nvim
:solarized.nvim] :solarized.nvim]
:require :settings.bufferline) :module :settings.bufferline)
(use! :windwp/nvim-autopairs (use! :windwp/nvim-autopairs
:require :settings.autopairs) :module :settings.autopairs)
(use! :lewis6991/gitsigns.nvim (use! :lewis6991/gitsigns.nvim
:require :settings.gitsigns) :module :settings.gitsigns)
(use! :declancm/cinnamon.nvim (use! :declancm/cinnamon.nvim
:require :settings.cinnamon) :module :settings.cinnamon)
(use! :stevearc/aerial.nvim (use! :stevearc/aerial.nvim
:require :settings.aerial) :module :settings.aerial)
(use! :nmac427/guess-indent.nvim (use! :nmac427/guess-indent.nvim
:require :settings.guess-indent) :module :settings.guess-indent)
(use! :nvim-telescope/telescope.nvim (use! :nvim-telescope/telescope.nvim
:requires [:nvim-lua/plenary.nvim :requires [:nvim-lua/plenary.nvim
:s1n7ax/nvim-window-picker] :s1n7ax/nvim-window-picker]
:after [:nvim-window-picker] :after [:nvim-window-picker]
:require :settings.telescope) :module :settings.telescope)
(use! :sindrets/diffview.nvim (use! :sindrets/diffview.nvim
:requires [:nvim-lua/plenary.nvim] :requires [:nvim-lua/plenary.nvim]
:require :settings.diffview) :module :settings.diffview)
(use! :neovim/nvim-lspconfig (use! :neovim/nvim-lspconfig
:requires [:williamboman/mason-lspconfig.nvim :requires [:williamboman/mason-lspconfig.nvim
@@ -89,24 +89,27 @@
:saadparwaiz1/cmp_luasnip :saadparwaiz1/cmp_luasnip
:rafamadriz/friendly-snippets :rafamadriz/friendly-snippets
:L3MON4D3/LuaSnip] :L3MON4D3/LuaSnip]
:require :settings.lspconfig) :module :settings.lspconfig)
(use! :jose-elias-alvarez/null-ls.nvim (use! :jose-elias-alvarez/null-ls.nvim
:require :settings.null-ls) :module :settings.null-ls)
(use! :lervag/vimtex (use! :lervag/vimtex
:require :settings.vimtex) :module :settings.vimtex)
(use! :edluffy/hologram.nvim (use! :edluffy/hologram.nvim
:require :settings.hologram) :module :settings.hologram)
(use! :lambdalisue/suda.vim) (use! :lambdalisue/suda.vim)
(use! :folke/noice.nvim (use! :folke/noice.nvim
:event :VimEnter :event :VimEnter
:requires [:MunifTanjim/nui.nvim] :requires [:MunifTanjim/nui.nvim]
:require :settings.noice) :module :settings.noice)
(use! :glacambre/firenvim (use! :glacambre/firenvim
:run (fn [] ((. vim.fn :firenvim#install) 0)) :run (fn [] ((. vim.fn :firenvim#install) 0))
:require :settings.firenvim)) :module :settings.firenvim)
(use! :iamcco/markdown-preview.nvim
:run (fn [] ((. vim.fn :mkdp#util#install)))))

View File

@@ -5,5 +5,8 @@
:content "text" :content "text"
:priority 0 :priority 0
:selector "textarea" :selector "textarea"
:takeover "always"} :takeover "never"}
:https://zimbra.inria.fr/ {:selector "body[id=tinymce]"}}}) :https://www.deepl.com/ {:selector "textarea[aria-labelledby=translation-source-heading]"
:takeover "always"}
:https://zimbra.inria.fr/ {:selector "body[id=tinymce]"
:takeover "always"}}})

View File

@@ -1,4 +1,4 @@
(import-macros {: exec! : map!} :hibiscus.vim) (import-macros {: exec : map!} :hibiscus.vim)
(local M {}) (local M {})
@@ -58,15 +58,15 @@
(fn [command _] (do_command (. command.arguments 1 :falsePositives) :hiddenFalsePositives))) (fn [command _] (do_command (. command.arguments 1 :falsePositives) :hiddenFalsePositives)))
(fn post_attach [] (fn post_attach []
(exec! [setlocal spell] [setlocal nospell]) (exec [[:setlocal "spell"] [:setlocal "nospell"]])
(update_config "en-US" "dictionary") (update_config "en-US" "dictionary")
(update_config "en-US" "disabledRules") (update_config "en-US" "disabledRules")
(update_config "en-US" "hiddenFalsePositives") (update_config "en-US" "hiddenFalsePositives")
(map! [n :buffer :verbose] :zug (fn [] (exec! [normal! zug]) (map! [n :buffer :verbose] :zug (fn [] (exec [[:normal! "zug"]])
(update_config "en-US" "dictionary") (update_config "en-US" "dictionary")
nil) nil)
"Remove word from spellfile and update ltex") "Remove word from spellfile and update ltex")
(map! [n :buffer :verbose] :zg (fn [] (exec! [normal! zg]) (map! [n :buffer :verbose] :zg (fn [] (exec [[:normal! "zg"]])
(update_config "en-US" "dictionary") (update_config "en-US" "dictionary")
nil) nil)
"Add word to spellfile and update ltex") "Add word to spellfile and update ltex")

View File

@@ -2,13 +2,11 @@
(import-macros {: setup} :macros) (import-macros {: setup} :macros)
(local servers (local servers
[:bashls [:eslint
:eslint
:gopls :gopls
:java_language_server
:ltex :ltex
:lua_ls
:pyright :pyright
:sumneko_lua
:tsserver]) :tsserver])
; Mappings. ; Mappings.

View File

@@ -1,4 +1,4 @@
(import-macros {: g! : exec! : map! : augroup!} :hibiscus.vim) (import-macros {: g! : exec : map! : augroup!} :hibiscus.vim)
(import-macros {: setup} :macros) (import-macros {: setup} :macros)
(g! :neo_tree_remove_legacy_commands 1) (g! :neo_tree_remove_legacy_commands 1)
@@ -14,8 +14,8 @@
:window {:mappings {:/ "noop" :window {:mappings {:/ "noop"
:g/ "fuzzy_finder" :g/ "fuzzy_finder"
:f "noop" :f "noop"
:ff (fn [] (exec! [Telescope find_files])) :ff (fn [] (exec [[:Telescope "find_files"]]))
:fg (fn [] (exec! [Telescope live_grep])) :fg (fn [] (exec [[:Telescope "live_grep"]]))
:<CR> "custom_open" :<CR> "custom_open"
:e "open" :e "open"
:<S-Right> (fn []) :<S-Right> (fn [])
@@ -38,19 +38,19 @@
:height (+ (math.ceil height) 1) :height (+ (math.ceil height) 1)
:row 0 :row 0
:col 2})] :col 2})]
(exec! [setlocal nonumber]) (exec [[:setlocal "nonumber"]])
(vim.api.nvim_buf_attach bufnr false {:on_detach (fn [_ bufnr] (vim.api.nvim_buf_attach bufnr false {:on_detach (fn [_ bufnr]
(image:delete bufnr {:free true}))}) (image:delete bufnr {:free true}))})
(image:display 1 0 bufnr {})) (image:display 1 0 bufnr {}))
_ (do _ (do
(exec! [silent (exec [[:silent
!file -bL --mime `(.. "'" quoted_path "'") "!file -bL --mime" quoted_path
| grep -qv "^text\\|^inode\\|^application/json"]) "| grep -qv '^text\\|^inode\\|^application/json'"]])
(if (= vim.v.shell_error 1) (if (= vim.v.shell_error 1)
((. (require :neo-tree.sources.filesystem.commands) :open_with_window_picker) state) ((. (require :neo-tree.sources.filesystem.commands) :open_with_window_picker) state)
(exec! [silent (exec [[:silent
!xdg-open `(.. "'" quoted_path "'") "!xdg-open" quoted_path
&]))))))}} "&"]]))))))}}
:renderers {:directory [[:indent] :renderers {:directory [[:indent]
[:icon] [:icon]
[:current_filter] [:current_filter]
@@ -67,7 +67,7 @@
[:git_status]]}}) [:git_status]]}})
(map! [n] :f ":Neotree focus<CR>") (map! [n] :f ":Neotree focus<CR>")
(map! [n] :F (fn [] (exec! [Neotree toggle] [Neotree toggle action=show]))) (map! [n] :F (fn [] (exec [[:Neotree "toggle"] [:Neotree "toggle" "action=show"]])))
(augroup! :neo-tree [[FileType] [qf] "set nobuflisted|call feedkeys(\"F\")"]) (augroup! :neo-tree [[FileType] [qf] "set nobuflisted|call feedkeys(\"F\")"])

View File

@@ -2,8 +2,7 @@
(setup :nvim-treesitter.configs (setup :nvim-treesitter.configs
{:ensure_installed {:ensure_installed
[:bash [:c
:c
:fennel :fennel
:java :java
:javascript :javascript

View File

@@ -340,7 +340,7 @@ map i display_file
map ? help map ? help
map W display_log map W display_log
map w taskview_open map w taskview_open
map S shell $SHELL map S shell zsh
map : console map : console
map ; console map ; console

View File

@@ -163,3 +163,6 @@ textbox-prompt-colon {
text-color: @normal-foreground; text-color: @normal-foreground;
} }
element-text {
text-color: inherit;
}

View File

@@ -23,5 +23,5 @@ fi
# choose karaoke # choose karaoke
[ -z "$kid" ] && exit [ -z "$kid" ] && exit
umpv "https://kara.moe/kara/$kid" > /dev/null 2>&1 & mpv "https://kara.moe/kara/$kid" > /dev/null 2>&1 &
exec 1>&- exec 1>&-

View File

@@ -1,2 +0,0 @@
Backup/**
Extracted/**

View File

@@ -1,37 +0,0 @@
# Solarized Dark official palette
# Base03 #002b36
# Base02 #073642
# Base01 #586e75
# Base00 #657b83
# Base0 #839496
# Base1 #93a1a1
# Base2 #eee8d5
# Base3 #fdf6e3
# Yellow #b58900
# Orange #cb4b16
# Red #dc322f
# Magenta #d33682
# Violet #6c71c4
# Blue #268bd2
# Cyan #2aa198
# Green #859900
[Base]
main_fg = 859900
secondary_fg = 93a1a1
main_bg = 002b36
sidebar_and_player_bg = 002b36
cover_overlay_and_shadow = 000000
indicator_fg_and_button_bg = 859900
pressing_fg = 002b36
slider_bg = 073642
sidebar_indicator = 859900
hover_button_bg = 859900
scrollbar_fg_and_selected_row_bg = 073642
sidebar_indicator_and_hover_button_bg = 859900
pressing_button_fg = 002b36
pressing_button_bg = 859900
selected_button = 859900
miscellaneous_bg = 859900
miscellaneous_hover_bg = 859900
preserve_1 = FFFFFF

View File

@@ -1,657 +0,0 @@
:root {
--bar-height: 60px;
--modspotify_sidebar_indicator: #839496;
--modspotify_hover_button_bg: #b58900;
}
* {
font-family: "DejaVu Sans Mono", "Helvetica Neue", "Arial", sans-serif !important;
font-weight: 400;
}
/*Round corner cover image*/
.card-image,
.card-placeholder-wrapper,
.card-image-content-wrapper,
.Card:not(.Card--artist) .Card__image,
.Card:not(.Card--artist) .Card__image-wrapper {
border-radius: 0px !important;
overflow: hidden !important
}
/*Hide some annoying elements like profile name and pic, upgrade button and device connect bar at bottom, new playlist button*/
.upgrade-button,
.view-player .remote-playback-bar,
.NewPlaylistButton {
display: none !important;
}
/*Exclude these elements from draggable property because it stops them from clickable*/
.profile-items-container,
.profile {
-webkit-app-region: no-drag !important;
}
/*Thinner scrollbar*/
::-webkit-scrollbar {
height: 6px !important;
width: 6px !important;
background-color: transparent;
}
/*Round corner scrollbar*/
::-webkit-scrollbar-thumb {
border-radius: 0px !important;
}
/*Hide top and bottom buttons of scrollbar */
/*who uses those, lol*/
::-webkit-scrollbar-button {
display: none !important;
}
/*Hide cover image overlay*/
.card-overlay {
visibility: hidden !important;
}
/*Lift up cover when hovering on it*/
.card-image-content-wrapper,
.Card:not(.Card--artist) .Card__image-wrapper {
transition-property: transform, box-shadow !important;
transition-duration: 1s !important;
transition-timing-function: cubic-bezier(.3,0,0,1) !important;
box-shadow: 0 5px 20px rgba(0,0,0,0.1);
}
.card-image-hit-area:not(.no-hover):hover .card-image-content-wrapper,
.Card:not(.Card--artist) .Card__image-hit-area-counter-scale:hover .Card__image-wrapper {
transform: translateY(-10px);
box-shadow: 0 15px 30px rgba(0,0,0,0.3);
}
.card-image-hit-area .card-button-add,
.card-image-hit-area .card-button-play,
.card-image-hit-area .card-button-more,
.Card__image-hit-area .card-button-add,
.Card__image-hit-area .card-button-play,
.Card__image-hit-area .card-button-more,
.Card__image-hit-area .Card__play-button,
.Card__image-hit-area .Card__add-button,
.Card__image-hit-area .Card__more-button,
.Card__image-hit-area .Card__overlay {
transition-property: all !important;
transition-duration: 1s !important;
transition-timing-function: cubic-bezier(.3,0,0,1) !important;
opacity: 0 !important;
}
.card-image-hit-area:not(.no-hover):hover .card-button-add,
.card-image-hit-area:not(.no-hover):hover .card-button-play,
.card-image-hit-area:not(.no-hover):hover .card-button-more,
.Card__image-hit-area:not(.no-hover):hover .card-button-add,
.Card__image-hit-area:not(.no-hover):hover .card-button-play,
.Card__image-hit-area:not(.no-hover):hover .card-button-more {
opacity: 1 !important;
transform: translateY(-10px);
}
.Card__image-hit-area:hover .Card__play-button,
.Card__image-hit-area:hover .Card__add-button,
.Card__image-hit-area:hover .Card__more-button,
.Card__image-hit-area:hover .Card__overlay {
opacity: 1 !important;
}
.glue-page-header__content .glue-page-header__image-inner {
border-radius: 0px;
box-shadow: unset !important;
}
.glue-page-header__full-description-overlay {
box-shadow: unset !important;
}
.card-placeholder-wrapper {
background: transparent !important;
}
/*Spice up search input background*/
.SearchInput {
color: var(--modspotify_main_fg);
}
.SearchInput__input {
color: var(--modspotify_secondary_fg);
background-color: rgba(var(--modspotify_rgb_scrollbar_fg_and_selected_row_bg), 0.5) !important;
border-radius: 0px !important;
padding-left: 34px;
}
.sidebar:hover .sidebar-navbar.sidebar-scroll-element {
opacity: 1!important;
}
.view-player .player-controls-container,
.view-player .player-controls-container .controls {
overflow: visible !important;
}
.view-player .player-controls-container .controls .button-play{
height:50px !important;
border-radius:50px !important;
background: transparent !important;
box-shadow:0 0 0 0 !important;
width:50px !important;
overflow: visible !important;
box-shadow: 0 4px 15px rgba(0,0,0,0.2) !important;
transition:none 0.3s cubic-bezier(.3,0,.7,1);
}
.view-player .player-controls-container .controls .button-play:before{
font-size:18px !important;
padding-left: 16px !important;
padding-top: 9px !important;
}
.view-player .player-controls-container .controls .button-play:after {
box-shadow: unset !important;
}
.view-player .player-controls-container {
position: absolute !important;
width: 100% !important;
}
.view-player .player-controls-container .controls {
width: 100% !important;
height: 100% !important;
align-items: center !important;
margin-top : 0px !important;
}
/*
Hide the song duration and elapsed text. I dont know where to put those so I just hide them
*/
.view-player .player-controls-container .progress-container .elapsed,
.view-player .player-controls-container .progress-container .remaining {
display: none !important;
}
/* Add round corner for Gerne and Mood cards */
.gc-image-container,
.gc-image {
border-radius: 0px !important;
}
/*
Collage of 3 album covers is usually seen in Browse and Chart.
*/
.card-puff__image-wrapper,
.card-puff__info-container,
.card-puff__card-image {
border-radius: 0px !important;
}
.card-puff__image-wrapper {
overflow: visible;
}
.card-puff__card-image {
box-shadow: 5px 0 30px rgba(0,0,0,0.7);
overflow: visible;
}
.card-puff__title-container {
background-color: transparent !important;
}
.card-puff.pressed .card-puff__image-wrapper,
.card-puff.pressed .card-puff__info-container {
opacity: 0.7 !important;
}
.card-puff__title {
padding: 5px 10px 5px 10px !important;
background-color: var(--modspotify_main_bg) !important;
border-radius: 0px;
border: 2px solid var(--modspotify_main_fg);
}
/*
We use round corner on cover so they look weird in original
form, so I move last cover to the right 20px and first one to the left 20px
*/
.card-puff__card-image:nth-child(1) {
right: 20px;
box-shadow: 0 0 0 0 !important;
}
.card-puff__card-image:nth-child(3) {
left: 20px;
}
.grid-overlay-label {
top: 140px !important;
}
/**/
.glue-page-header__background-color {
background-image: none !important;
background: var(--modspotify_main_bg);
}
/* .glue-page-header__sticky {
padding-top: 60px !important;
} */
/*
Remove those title, cringy description and
meaningless followers number
*/
.carousel .card-info-subtitle-description,
.carousel .card-info-subtitle-metadata,
.carousel .card:not(.card-type-station).card-info-title,
.carousel .card.card-type-playlist.image-loaded .card-info-subtitle-description,
.carousel .card.card-type-playlist.image-loaded .card-info-subtitle-metadata {
display: none !important;
}
/*
In top of Browse usually has bunch of Playlist or Album cards,
and they has .carousel as a wrapper and it hides anything that
overflows from its zone, aka our shadow and lifting animation.
*/
.carousel {
overflow: visible !important;
}
/*
Button with text Play
*/
.button.button-green,
.GlueButton.GlueButton--style-green {
color: var(--modspotify_main_bg) !important;
}
/*
Change text color in playlist
*/
.tl-explicit .label,
.tl-premium .label,
.tl-cell:not(.tl-number),
.tl-cell a:link,
.tl-highlight {
color: var(--modspotify_secondary_fg);
}
.card-type-album .card-info-title,
.card-type-track .card-info-title,
.card-type-collection-album .card-info-title,
.card-type-episode .card-info-title {
font-size: 15px;
font-weight: 600 !important;
text-align: center !important;
width: 100% !important;
}
.card-type-album .card-info-subtitle-links,
.card-type-track .card-info-subtitle-links,
.card-type-collection-album .card-info-subtitle-links,
.card-type-episode .card-info-subtitle-links {
text-align: center !important;
width: 100% !important;
}
.tracklist-station-container::after {
background: transparent !important;
}
.GlueHeader__background-overlay {
background: var(--modspotify_main_bg) !important;
}
/* Move navigation buttons and search field to the right and down */
.browser-navigation-top-bar {
margin-left: 40px !important;
margin-top: 15px !important;
}
.SearchInput__input,
.SearchInput__searchIcon,
.SearchInput__clearButton {
margin-top: 15px !important;
}
.content-top-bar__profile-menu-button {
margin-top: 15px !important;
}
.body-container--windows:not(.with-buddy-list):not(.messagebar) .content-top-bar__profile {
margin-right: 110px !important;
margin-top: -5px;
}
/* Spice up Fullscreen mode */
#view-player .album-art .album-art__image {
border-radius: 0px !important;
box-shadow: 0 10px 70px rgba(var(--modspotify_rgb_cover_overlay_and_shadow),.5) !important;
}
#view-player .album-art .album-art__image .card-image-content-wrapper,
#view-player .album-art .album-art__image .card-image-content-wrapper .card-image {
border-radius: 0px !important;
}
/* Daily mixes */
.carousel .card-info-wrapper.card-info-with-description.card-info-with-metadata {
height: 50px !important;
}
/* Remove section divider */
.section-divider {
border-bottom: 0 !important;
}
/* Adjust Position of border active tab in Nav bar at top
and add little glowing effect
*/
.nav.navbar-nav {
overflow: hidden !important;
}
.nav.navbar-nav a {
overflow: visible !important;
}
.nav.navbar-nav a::after {
bottom: 0px !important;
width: 100% !important;
}
.nav.navbar-nav .active a::after{
box-shadow: 0 0px 20px !important;
}
.nav.navbar-nav a:focus:not(.button):active::after{
background-color: var(--modspotify_pressing_fg) !important;
}
/* Notification bar */
#content-wrapper #view-message-bar {
position: absolute !important;
width: calc(100% - 160px) !important;
margin-left: 80px !important;
border-radius: 0 0 0px 0px !important;
}
/* Small cover Big cover mechanism */
.now-playing.cover-size-transition.active.image-expanded .cover-image {
width: 10px !important;
height: 10px !important;
}
.now-playing.cover-size-transition.active.image-expanded .caption {
padding-left: 0px !important;
}
#view-now-playing a.image {
overflow: visible !important;
}
#view-now-playing.expanded {
width: 200px;
height: 200px;
}
#now-playing-image-large .cover-image {
height: 200px !important;
}
/* Profile arrow in top left */
.content-top-bar__profile-menu-button .dropdown {
position: fixed !important;
top: 10px !important;
-webkit-app-region: no-drag !important;
}
body.body-container--windows .content-top-bar__profile-menu-button .dropdown {
right: 190px !important;
}
body:not(.body-container--windows) .content-top-bar__profile-menu-button .dropdown {
right: 20px !important;
}
/* Small tooltip */
#tooltip {
box-shadow: 0 0 10px rgba(0,0,0,0.2) !important;
border-radius: 0px !important;
border: 2px solid var(--modspotify_main_fg);
padding: 10px 10px;
}
.tooltip-arrow-top, .tooltip-arrow-bottom {
display: none !important;
}
.lyrics-lines-container,
.message-container {
color: #FFFFFF !important;
}
/* Home page */
.GlueCarousel__grid-wrapper::-webkit-scrollbar-thumb {
display: none;
}
.GlueCard__info-wrapper,
.Card__info-wrapper {
margin-bottom: 30px;
}
.card-horizontal-interior-wrapper .card-info-title {
text-align: start !important;
}
.tl-row.selected:hover .tl-cell {
background: var(--modspotify_scrollbar_fg_and_selected_row_bg) !important;
}
.GlueTableRow--is-selected {
background-color: var(--modspotify_scrollbar_fg_and_selected_row_bg) !important;
}
.tracklist-podcast .tl-progress .row-progress__bar {
background-color: var(--modspotify_main_fg);
}
.Header__background-color{
background-color: var(--modspotify_main_bg) !important;
}
.Button--style-green,
.button.button-green, .button.button-white {
border-radius: 25px;
color: var(--modspotify_main_bg) !important;
}
.glue-page-header:not(.glue-page-header--album):not(.glue-page-header--playlist):not(.glue-page-header--artist):not(.glue-page-header--dailymix):not(.glue-page-header--user):not(.glue-page-header--show)
.glue-page-header__content-inner .glue-page-header__title-text,
.HomeHeader .Header__content-inner .Header__title-text-inner,
.MadeForYouHeader .Header__content-inner .Header__title-text-inner,
.RecentlyPlayedPage__header .Header__content-inner .Header__title-text-inner {
background-color: var(--modspotify_main_bg);
padding: 5px 20px;
border: 5px solid var(--modspotify_main_fg) !important;
border-radius: 0px;
box-shadow: 0 4px 12px 0 rgba(var(--modspotify_rgb_cover_overlay_and_shadow),.2);
text-transform: uppercase;
}
.glue-page-header.glue-page-header--album .glue-page-header__content-inner .glue-page-header__title,
.glue-page-header.glue-page-header--artist .glue-page-header__content-inner .glue-page-header__title,
.glue-page-header.glue-page-header--dailymix .glue-page-header__content-inner .glue-page-header__title,
.glue-page-header.glue-page-header--playlist .glue-page-header__content-inner .glue-page-header__title {
margin-top: 10px;
}
span.glue-page-header__title-text {
color: var(--modspotify_main_fg);
}
.glue-page-header .glue-page-header__content-inner .glue-page-header__button {
margin-top: 40px;
}
.glue-page-header__content-inner,
.glue-page-header__data,
.glue-page-header__title,
.Header__content-inner,
.Header__data,
.Header__title,
.Header__title-text,
.Header__title-text-inner {
overflow: visible !important;
}
/*Force player bar to has fixed height*/
.view-player {
height: var(--bar-height) !important;
border-top: 0;
}
.view-player .now-playing {
overflow: unset;
}
.view-player .now-playing .cover-image-link,
.view-player .now-playing .cover-image-link figure {
width: var(--bar-height);
height: var(--bar-height);
}
#now-playing-image-small .cover-image {
position: fixed !important;
width: var(--bar-height);
height: var(--bar-height);
left: 0;
bottom: 0;
}
.view-player .now-playing .cover-image-link-wrapper {
flex: 0 1 calc(var(--bar-height) + 10px);
}
.text-container {
z-index: 3;
}
.view-player .now-playing-container .button-add {
color: var(--modspotify_main_fg) !important;
}
.progress-container .progress-bar,
.progress-container .inner {
top: 0 !important;
margin-top: 0 !important;
height: 5px;
}
.progress-container .progress-bar-wrapper {
top: 0 !important;
height: 5px;
}
.progress-container {
position: fixed !important;
width: 100% !important;
bottom: var(--bar-height) !important;
margin : 0 !important;
}
.progress-container .inner {
border-radius: 0 0px 0px 0 !important;
background-color: var(--modspotify_main_fg) !important;
box-shadow: 0 0px 0px 0 var(--modspotify_main_fg);
}
.glue-page-header__p2s-details,
.glue-page-header__p2s-followers {
display: none;
}
.context-menu {
border: 2px solid var(--modspotify_main_fg);
box-shadow: 0 4px 12px 0 rgba(var(--modspotify_rgb_cover_overlay_and_shadow),.2);
border-radius: 0px !important;
overflow: hidden;
}
#menu-wrapper ::-webkit-scrollbar {
display: none;
}
#menu-wrapper {
border-right: 3px solid black;
border-image: linear-gradient(0deg, transparent , var(--modspotify_scrollbar_fg_and_selected_row_bg) 40%, var(--modspotify_scrollbar_fg_and_selected_row_bg) 60%, transparent 90%) 2 90%;
}
.main-view-wrapper {
overflow: unset;
}
.Button--style-icon-stroke:after,
.Button--style-icon-stroke:hover:after,
.Button--style-icon-stroke,
.glue-page-header__button .button-icon-with-stroke,
.glue-page-header__button .button-icon-with-stroke::after {
box-shadow: unset;
}
.glue-page-header.glue-page-header--artist .glue-page-header__label {
padding-top: 10px;
}
.glue-page-header.glue-page-header--artist.has-custom-image .glue-page-header__label {
padding-top: 8px;
}
.glue-page-header__content .glue-page-header__label {
margin-left: -2px;
z-index: 2;
}
.glue-page-header__label span,
.Header__label span {
background-color: var(--modspotify_main_fg);
color: var(--modspotify_main_bg);
padding: 2px 10px;
}
.glue-page-header__label .header-verified-check {
background-color: transparent;
}
body.remotebar .view-player .player-bar-wrapper {
height: 100%;
}
.SidebarListItem--is-active:after,
.RootlistItem--is-active:after,
/* For Linux */ #view-navigation-bar .item.active:after {
background-color: transparent;
background-image: linear-gradient(90deg, var(--modspotify_sidebar_indicator) , transparent);
opacity: 0.2;
bottom: unset;
top: 5%;
height: 90%;
width: 100%
}
.Header__image-inner {
box-shadow: unset;
}
.button.button-green.contextmenu-active, .button.button-green:not(:disabled):hover {
background-color: var(--modspotify_hover_button_bg);
}

View File

@@ -1,31 +0,0 @@
[AdditionalOptions]
extensions =
custom_apps =
sidebar_config = 1
home_config = 1
[Patch]
[Setting]
prefs_path = /home/rhiobet/.config/spotify/prefs
overwrite_assets = 0
check_spicetify_upgrade = 0
spotify_path = /opt/spotify
current_theme = SpicetifyDefault
color_scheme =
inject_css = 1
replace_colors = 1
spotify_launch_flags =
[Preprocesses]
disable_sentry = 1
disable_ui_logging = 1
remove_rtl_rule = 1
expose_apis = 1
disable_upgrade_check = 1
; DO NOT CHANGE!
[Backup]
version =
with =

View File

@@ -1,39 +0,0 @@
[Setting]
spotify_path = /opt/spotify
prefs_path = /home/rhiobet/.config/spotify/prefs
current_theme = SolarizedDarkGreen
color_scheme =
inject_css = 1
replace_colors = 1
overwrite_assets = 0
spotify_launch_flags =
check_spicetify_upgrade = 0
[Preprocesses]
remove_rtl_rule = 1
expose_apis = 1
disable_sentry = 1
disable_ui_logging = 1
disable_upgrade_check = 1
[AdditionalOptions]
home = 0
lyric_always_show = 0
lyric_force_no_sync = 0
tastebuds = 0
fastUser_switching = 0
made_for_you_hub = 0
new_feedback_ui = 0
radio = 0
song_page = 0
extensions =
minimal_ui = 0
experimental_features = 0
search_in_sidebar = 0
visualization_high_framerate = 0
custom_apps =
; DO NOT CHANGE!
[Backup]
version = 1.1.56.595.g2d2da0de

View File

@@ -1,3 +0,0 @@
body {
--glue-font-family: Karla;
}

View File

@@ -21,31 +21,26 @@ set $term kitty
# set $menu dmenu_path | dmenu | xargs swaymsg exec -- # set $menu dmenu_path | dmenu | xargs swaymsg exec --
set $menu rofi -no-levenshtein-sort -color-enabled -show run\ set $menu rofi -no-levenshtein-sort -color-enabled -show run\
-run-command "zsh -i -c '{cmd}'" | xargs swaymsg exec -- -run-command "zsh -i -c '{cmd}'" | xargs swaymsg exec --
#set $srclocker swaylock -c 222222 -u -i eDP-1:~/wallpapers/radiance.png\ set $srclocker swaylock -c 222222 -i eDP-1:~/wallpapers/radiance.png\
# -i DP-5:~/wallpapers/hornet.jpg -i DP-4:~/wallpapers/knight.jpg -i DP-5:~/wallpapers/hornet.jpg -i DP-4:~/wallpapers/knight.jpg\
-i DP-7:~/wallpapers/hornet.jpg -i DP-6:~/wallpapers/knight.jpg\
-i DP-9:~/wallpapers/hornet.jpg -i DP-8:~/wallpapers/knight.jpg\
-i HDMI-A-1:~/wallpapers/radiance.png
### Output configuration ### Output configuration
# #
# Default wallpaper (more resolutions are available in /usr/share/backgrounds/sway/) # Default wallpaper (more resolutions are available in /usr/share/backgrounds/sway/)
# output * bg /usr/share/backgrounds/sway/Sway_Wallpaper_Blue_1920x1080.png fill # output * bg /usr/share/backgrounds/sway/Sway_Wallpaper_Blue_1920x1080.png fill
output * pos 1920 0 res 1920 1080 output eDP-1 pos 0 1480 res 1920 1080
output eDP-1 { output HDMI-A-1 pos 1920 1480 res 1920 1080
pos 0 0 output "Samsung Electric Company SyncMaster H1AK500000" res 3840 2160
res 2256 1504 output "Dell Inc. DELL U2410 F525M0A1082L" pos 1920 680 res 1920 1200
scale 1.5 #output "Dell Inc. DELL U2717D JXRPT83GAHKS" pos 3840 0 mode --custom 2560x1440@39Hz transform 90
bg "~/wallpapers/priscilla.png" fill output "Dell Inc. DELL U2717D JXRPT83GAHKS" pos 1920 1480 mode 2560 1440
} output "Hewlett Packard HP LA2405x CN43480QK5" pos 3840 320 mode 1920 1200 transform 270
output "Beihai Century Joint Innovation Technology Co.,Ltd MD49DQHD-2 0000000000000" { output "Dell Inc. DELL U2410 F525M98C17AL" pos 0 680 mode 1920 1200
pos 1504 0 output * bg ~/wallpapers/filianore-u.jpg fill
res 5120 1440
bg "~/wallpapers/ranni.png" fill
}
focus output eDP-1 focus output eDP-1
bindswitch --reload --locked lid:on output eDP-1 disable
bindswitch --reload --locked lid:off output eDP-1 enable
# #
# Example configuration: # Example configuration:
# #
@@ -54,7 +49,14 @@ bindswitch --reload --locked lid:off output eDP-1 enable
# You can get the names of your outputs by running: swaymsg -t get_outputs # You can get the names of your outputs by running: swaymsg -t get_outputs
# Mouse cursor # Mouse cursor
seat seat0 xcursor_theme capitaine-cursors 32 set $my_cursor capitaine-cursors
set $my_cursor_size 32
seat seat0 xcursor_theme $my_cursor $my_cursor_size
exec_always {
gsettings set org.gnome.desktop.interface cursor-theme $my_cursor
gsettings set org.gnome.desktop.interface cursor-size $my_cursor_size
}
### Idle configuration ### Idle configuration
# #
@@ -89,11 +91,14 @@ input "*" {
xkb_variant latin9 xkb_variant latin9
} }
input "2362:628:PIXA3854:00_093A:0274_Touchpad" { input "1102:4619:DLL07A0:01_044E:120B" {
tap enabled tap enabled
natural_scroll enabled natural_scroll enabled
} }
input "9653:84:Samsung_electronics_inc._Samsung_HID_Multi-Touch"\
map_to_output "Samsung Electric Company SyncMaster H1AK500000"
### Key bindings ### Key bindings
# #
# Basics: # Basics:
@@ -105,14 +110,14 @@ input "2362:628:PIXA3854:00_093A:0274_Touchpad" {
bindsym $mod+Shift+q kill bindsym $mod+Shift+q kill
# Sound # Sound
bindsym XF86AudioRaiseVolume exec amixer -c 0 sset Master 5%+ bindsym XF86AudioRaiseVolume exec pactl set-sink-volume @DEFAULT_SINK@ +5%
bindsym XF86AudioLowerVolume exec amixer -c 0 sset Master 5%- bindsym XF86AudioLowerVolume exec pactl set-sink-volume @DEFAULT_SINK@ -5%
bindsym XF86AudioMute exec 'amixer -c 0 sset Master toggle && amixer -c 0 sset Speaker on && amixer -c 0 sset Headphone on' bindsym XF86AudioMute exec pactl set-sink-mute @DEFAULT_SINK@ toggle
bindsym XF86AudioMicMute exec amixer -c 0 sset Capture toggle bindsym XF86AudioMicMute exec pactl set-source-mute @DEFAULT_SOURCE@ toggle
# Brightness # Brightness
bindsym XF86MonBrightnessUp exec brightnessctl s +5% bindsym XF86MonBrightnessUp exec xbacklight -inc 5
bindsym XF86MonBrightnessDown exec brightnessctl s 5%- bindsym XF86MonBrightnessDown exec xbacklight -dec 5
# Start your launcher # Start your launcher
bindsym $mod+r exec $menu bindsym $mod+r exec $menu
@@ -133,11 +138,9 @@ input "2362:628:PIXA3854:00_093A:0274_Touchpad" {
'swaymsg exit' 'swaymsg exit'
# Screenshot # Screenshot
bindsym Print exec slurp -d | grim -g - - | wl-copy -t image/png bindsym Print exec grim -g "$(slurp -d)" - | wl-copy -t image/png
bindsym Ctrl+Print exec swaymsg -t get_tree | jq -r 'recurse(.nodes[], .floating_nodes[]) | select(.focused and .pid).rect | "\(.x),\(.y) \(.width)x\(.height)"' | grim -g - - | wl-copy -t image/png bindsym Ctrl+Print exec swaymsg -t get_tree | jq -r 'recurse(.nodes[], .floating_nodes[]) | select(.focused and .pid).rect | "\(.x),\(.y) \(.width)x\(.height)"' | grim -g - - | wl-copy -t image/png
bindsym Shift+Print exec grim -o $(swaymsg -t get_outputs | jq -r '.[] | select(.focused) | .name') - | wl-copy -t image/png bindsym Shift+Print exec grim -o $(swaymsg -t get_outputs | jq -r '.[] | select(.focused) | .name') - | wl-copy -t image/png
#bindsym Shift+Print exec grim -o $(swaymsg -t get_outputs | jq -r '.[] | select(.focused) | .name') - > /home/rhiobet/screenshots/$(date +%s).png
# #
# Moving around: # Moving around:
# #
@@ -207,6 +210,9 @@ input "2362:628:PIXA3854:00_093A:0274_Touchpad" {
# Make the current focus fullscreen # Make the current focus fullscreen
bindsym $mod+f fullscreen bindsym $mod+f fullscreen
# Maximize current focus
bindsym $mod+m exec swaymsg floating true && swaymsg resize set $(swaymsg -t get_workspaces | jq -r '.[] | select(.focused) | .rect | "\(.width)px \(.height)px"')
# Toggle the current focus between tiling and floating mode # Toggle the current focus between tiling and floating mode
bindsym $mod+Shift+space floating toggle bindsym $mod+Shift+space floating toggle
@@ -261,7 +267,7 @@ bindsym Ctrl+Alt+l exec $srclocker
bar { bar {
position top position top
pango_markup enabled pango_markup enabled
font pango:DejaVuSansM Nerd Font Mono, FontAwesome 10 font pango:DejaVu Sans Mono, devicons, FontAwesome 10
# When the status_command prints a new line to stdout, swaybar updates. # When the status_command prints a new line to stdout, swaybar updates.
# The default just shows the current date and time. # The default just shows the current date and time.
@@ -269,6 +275,7 @@ bar {
# status_command i3status-rs ~/.config/sway/status.toml # status_command i3status-rs ~/.config/sway/status.toml
swaybar_command waybar swaybar_command waybar
status_padding 0 status_padding 0
height 22
colors { colors {
statusline #ffffff statusline #ffffff
@@ -279,6 +286,11 @@ bar {
} }
} }
bindswitch --locked --reload lid:on output eDP-1 disable
bindswitch --locked --reload lid:off output eDP-1 enable
bindsym Ctrl+m exec mpv "$(wl-paste -t text)"
hide_edge_borders both hide_edge_borders both
default_border none default_border none
gaps inner 6 gaps inner 6
@@ -294,28 +306,12 @@ include /etc/sway/config.d/*
assign [class="discord"] workspace 3 assign [class="discord"] workspace 3
assign [class="Spotify"] workspace 3 assign [class="Spotify"] workspace 3
for_window [class="Spotify"] { exec redshift -O 4500 -m wayland
floating enable
sticky enable
}
for_window [app_id="boop-gtk"] floating enable
#exec redshift -O 4500 -m wayland
exec wlanthy -i pass
# exec ~/.local/start-jack.sh
exec ~/.config/sway/workspace_rename.py > ~/.cache/workspace_rename.log 2> ~/.cache/workspace_rename_error.log exec ~/.config/sway/workspace_rename.py > ~/.cache/workspace_rename.log 2> ~/.cache/workspace_rename_error.log
for_window [class="Tor Browser"] floating enable for_window [class="Tor Browser"] floating enable
for_window [class="steam_proton"] floating enable
for_window [app_id="mpv"] {
floating enable
sticky enable
}
for_window [app_id="kitty-scratch"] { for_window [app_id="kitty-scratch"] {
border pixel 1 border pixel 1
} }
@@ -331,10 +327,23 @@ exec $term
workspace 2 output eDP-1 workspace 2 output eDP-1
workspace 3 output eDP-1 workspace 3 output eDP-1
exec discord
exec spotify-launcher workspace 4 output "Dell Inc. DELL U2410 F525M0A1082L"
workspace 5 output "Dell Inc. DELL U2410 F525M0A1082L"
workspace 6 output "Dell Inc. DELL U2410 F525M0A1082L"
workspace 7 output "Dell Inc. DELL U2717D JXRPT83GAHKS"
workspace 8 output "Dell Inc. DELL U2717D JXRPT83GAHKS"
workspace 9 output "Dell Inc. DELL U2717D JXRPT83GAHKS"
exec xrdb -load ~/.Xresources exec xrdb -load ~/.Xresources
# Application keybinds exec autotiling
bindsym Ctrl+m exec mpv $(wl-paste -t text)
exec keepassxc
exec "systemctl --user import-environment; systemctl --user start sway-session.target"

5
.config/sway/run-once.sh Executable file
View File

@@ -0,0 +1,5 @@
#!/bin/bash
if ! pgrep -x $1; then
${@:1}
fi

View File

@@ -10,7 +10,7 @@ good_bg = "#859900ff"
warning_bg = "#b58900ff" warning_bg = "#b58900ff"
critical_bg = "#dc322fff" critical_bg = "#dc322fff"
alternating_tint_bg = "#00000000" alternating_tint_bg = "#00000000"
separator = "<span font='15'>\ue0b2</span>" separator = "<span font='14'>\ue0b2</span>"
#separator = "" #separator = ""
#[[block]] #[[block]]

View File

@@ -1,35 +0,0 @@
#!/bin/sh
swaymsg -t subscribe -m '[ "window" ]' | while read -r event ; do
if [ "$(jq -r '.change' <<< $event)" = 'focus' ] ; then
current_workspace="$(swaymsg -t get_workspaces | jq -r '.[] | select(.focused)')"
workspace_num="$(jq -r '.num' <<< $current_workspace)"
workspace_name="$(jq -r '.name' <<< $current_workspace)"
app_name="$(jq -r '.container.app_id' <<< $event)"
if [ $app_name = 'null' ] ; then
app_name="$(jq -r '.container.window_properties.instance' <<< $event)"
fi
if [ "$app_name" = "kitty" ] ; then
app_name=""
elif [[ "$app_name" == *"chrom"* ]] || [[ "$app_name" == *"Chrom"* ]]; then
case "$(jq -r '.container.name' <<< $event)" in
*YouTube*)
app_name=""
;;
*)
app_name=""
;;
esac
elif [ "$app_name" = "discord" ] ; then
app_name=""
elif [ "$app_name" = "spotify" ] ; then
app_name=""
elif [ "$app_name" = "GEMOC Studio" ] ; then
app_name=""
fi
swaymsg rename workspace "$workspace_name" to "$workspace_num:$app_name"
fi
done

View File

@@ -21,7 +21,10 @@ async def main():
for d in w.descendants(): for d in w.descendants():
app_name = d.app_id app_name = d.app_id
if not app_name: if not app_name:
app_name = d.window_instance if d.name and 'Vivaldi' in d.name:
new_name += '<span font=\'10\' rise=\'-500\' letter_spacing=\'2048\'></span>'
else:
app_name = d.window_instance
if app_name: if app_name:
if not first_descendant: if not first_descendant:

View File

@@ -1,30 +1,16 @@
[{ [{
"spacing": 4, // Gaps between modules (4px) "spacing": 4, // Gaps between modules (4px)
"modules-left": ["sway/workspaces", "wlr/taskbar"], "modules-left": ["sway/workspaces"],
"modules-center": [],
"modules-right": ["pulseaudio", "memory", "cpu", "battery", "network", "custom/pacman", "clock", "tray"], "modules-right": ["pulseaudio", "memory", "cpu", "battery", "network", "custom/pacman", "clock", "tray"],
"memory": { "memory": {
"format": "\uf538 {used:0.1f}GiB", "format": "\uf538 {used:0.1f}GiB",
"on-click": "kitty --class kitty-scratch -c ~/.config/kitty/kitty-scratch.conf btop" "on-click": "kitty --class kitty-scratch -c ~/.config/kitty/kitty-scratch.conf btop"
}, },
"sway/workspaces": {
"format": "{value}"
},
"wlr/taskbar": {
"on-click": "activate"
},
"tray": { "tray": {
"spacing": 10 "spacing": 10
}, },
"clock": { "clock": {
"tooltip-format": "<tt><small>{calendar}</small></tt>", "tooltip-format": "<big>{:%Y %B}</big>\n<tt><small>{calendar}</small></tt>",
"calendar": {
"mode": "year",
"mode-mon-col": 3,
"format": {
"today": "<b><u>{}</u></b>"
}
},
"format": "\uf017 {:%A %d/%m/%Y %H:%M}" "format": "\uf017 {:%A %d/%m/%Y %H:%M}"
}, },
"cpu": { "cpu": {

View File

@@ -1,5 +1,5 @@
* { * {
font-family: "DejaVu Sans Mono", "Font Awesome 6 Free"; font-family: DejaVu Sans Mono, devicons, "Font Awesome 6 Free";
font-size: 13px; font-size: 13px;
} }
@@ -14,39 +14,9 @@ window#waybar.hidden {
opacity: 0.2; opacity: 0.2;
} }
tooltip {
background-color: #002b36;
border: 1px solid #859900;
border-radius: 0px;
}
tooltip label {
color: #93a1a1;
}
#taskbar {
margin-left: 10px;
padding: 0px;
}
#taskbar button {
padding: 0px;
box-shadow: inset 0 -3px transparent;
border: none;
}
#taskbar button:hover {
background: inherit;
background-color: #268bd2;
-gtk-icon-shadow: none;
}
#taskbar button.active {
background-color: #859900;
}
#workspaces button { #workspaces button {
color: #93a1a1;
padding: 0px; padding: 0px;
background-color: transparent;
/* Use box-shadow instead of border so the text isn't offset */ /* Use box-shadow instead of border so the text isn't offset */
box-shadow: inset 0 -3px transparent; box-shadow: inset 0 -3px transparent;
/* Avoid rounded borders under each workspace name */ /* Avoid rounded borders under each workspace name */
@@ -55,8 +25,6 @@ tooltip label {
/* https://github.com/Alexays/Waybar/wiki/FAQ#the-workspace-buttons-have-a-strange-hover-effect */ /* https://github.com/Alexays/Waybar/wiki/FAQ#the-workspace-buttons-have-a-strange-hover-effect */
#workspaces button:hover { #workspaces button:hover {
background: inherit;
text-shadow: none;
background-color: #268bd2; background-color: #268bd2;
color: #002b36; color: #002b36;
} }
@@ -77,7 +45,6 @@ tooltip label {
} }
#workspaces button, #workspaces button,
#taskbar button,
#clock, #clock,
#battery, #battery,
#cpu, #cpu,
@@ -99,7 +66,7 @@ tooltip label {
#window, #window,
#workspaces { #workspaces {
margin: 0 20px; margin: 0 4px;
} }
/* If workspaces is the leftmost module, omit left margin */ /* If workspaces is the leftmost module, omit left margin */

1
.gitignore vendored
View File

@@ -1,2 +1,3 @@
.config/nvim/plugged .config/nvim/plugged
.config/nvim/.netrwhist .config/nvim/.netrwhist
.config/mpv/scripts/japan7.lua

2
.gitmodules vendored
View File

@@ -1,3 +1,3 @@
[submodule ".config/nvim/solarized.nvim"] [submodule ".config/nvim/solarized.nvim"]
path = .config/nvim/themes/solarized.nvim path = .config/nvim/themes/solarized.nvim
url = https://git.rhiobet.sh/rhiobet/solarized.nvim.git url = ssh://git@git.rhiobet.sh:42424/rhiobet/solarized.nvim.git

View File

@@ -1,14 +0,0 @@
#!/bin/sh
pkill jackd
jack_control start
sleep 1
alsa_in -d hw:PCH,0 -j alsa_in &
alsa_out -d hw:PCH,0 -j alsa_out &
sleep 1
jack_connect system:monitor_1 alsa_out:playback_1
jack_connect system:monitor_2 alsa_out:playback_2
jack_connect system:capture_1 system:playback_1
jack_connect system:capture_2 system:playback_2
jack_connect alsa_in:capture_1 "PulseAudio JACK Source":front-left
jack_connect alsa_in:capture_2 "PulseAudio JACK Source":front-right

View File

@@ -1,7 +1,2 @@
export JAVA_HOME=/usr/lib/jvm/$(archlinux-java get) export JAVA_HOME=/usr/lib/jvm/$(archlinux-java get)
#export GDK_BACKEND=x11 export JAVAFX_HOME=/lib/jvm/java-16-openjdk
export EDITOR=nvim
export XDG_CURRENT_DESKTOP=sway
export XDG_SESSION_TYPE=wayland
#export VK_ICD_FILENAMES=/usr/share/vulkan/icd.d/intel_icd.x86_64.json:/usr/share/vulkan/icd.d/radeon_icd.x86_64.json

23
.zshrc
View File

@@ -13,7 +13,6 @@ compinit
export ZSH=/usr/share/oh-my-zsh export ZSH=/usr/share/oh-my-zsh
export ZSH_CUSTOM=/usr/share/zsh export ZSH_CUSTOM=/usr/share/zsh
ZSH_AUTOSUGGEST_HIGHLIGHT_STYLE="fg=10"
ZSH_THEME="af-magic" ZSH_THEME="af-magic"
plugins=( plugins=(
@@ -29,30 +28,34 @@ plugins=(
) )
source $ZSH/oh-my-zsh.sh source $ZSH/oh-my-zsh.sh
#bindkey '^R' history-incremental-pattern-search-backward
if [ -f ~/.bash_aliases ]; then if [ -f ~/.bash_aliases ]; then
source ~/.bash_aliases source ~/.bash_aliases
fi fi
eval $(thefuck --alias) eval $(thefuck --alias)
#alias discord="export GDK_BACKEND=wayland && discord-canary" ranger() {
if [ -z "$RANGER_LEVEL" ]; then
/usr/bin/ranger "$@"
else
exit
fi
}
export MAVEN_OPTS="-Xmx2048m" alias start_gnome='XDG_SESSION_TYPE=wayland exec dbus-run-session gnome-session'
export _JAVA_AWT_WM_NONREPARENTING=1
# >>> mamba initialize >>> # >>> mamba initialize >>>
# !! Contents within this block are managed by 'mamba init' !! # !! Contents within this block are managed by 'mamba init' !!
export MAMBA_EXE="/usr/bin/micromamba"; export MAMBA_EXE="/usr/bin/micromamba";
export MAMBA_ROOT_PREFIX="/home/rhiobet/.mamba"; export MAMBA_ROOT_PREFIX="/home/rhiobet/micromamba";
__mamba_setup="$("$MAMBA_EXE" shell hook --shell zsh --prefix "$MAMBA_ROOT_PREFIX" 2> /dev/null)" __mamba_setup="$('/usr/bin/micromamba' shell hook --shell zsh --prefix '/home/rhiobet/micromamba' 2> /dev/null)"
if [ $? -eq 0 ]; then if [ $? -eq 0 ]; then
eval "$__mamba_setup" eval "$__mamba_setup"
else else
if [ -f "/home/rhiobet/.mamba/etc/profile.d/micromamba.sh" ]; then if [ -f "/home/rhiobet/micromamba/etc/profile.d/micromamba.sh" ]; then
. "/home/rhiobet/.mamba/etc/profile.d/micromamba.sh" . "/home/rhiobet/micromamba/etc/profile.d/micromamba.sh"
else else
export PATH="/home/rhiobet/.mamba/bin:$PATH" # extra space after export prevents interference from conda init export PATH="/home/rhiobet/micromamba/bin:$PATH" # extra space after export prevents interference from conda init
fi fi
fi fi
unset __mamba_setup unset __mamba_setup

BIN
wallpapers/filianore-u.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.3 MiB

BIN
wallpapers/filianore.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 MiB

BIN
wallpapers/hornet.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 268 KiB

BIN
wallpapers/knight.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 241 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 MiB

BIN
wallpapers/radiance.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 78 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.2 MiB