Compare commits

..

2 commits

Author SHA1 Message Date
295cd26ea2
fix: Removes automated drive selection 2025-12-18 17:11:46 +01:00
1b8ea223ab
sway 2025-12-18 16:47:47 +01:00
5 changed files with 26 additions and 476 deletions

View file

@ -54,9 +54,21 @@ tee /usr/lib/firefox-esr/distribution/policies.json > /dev/null <<'EOF'
}
EOF
chown -R kiosk:kiosk /home/kiosk/.config
tee /etc/systemd/system/firefox-kiosk.service > /dev/null <<'EOF'
[Unit]
Description=Firefox Kiosk
After=graphical.target
Wants=graphical.target
tee /home/kiosk/.bash_profile > /dev/null <<'EOF'
if [ -z "$WAYLAND_DISPLAY" ] && [ "$(tty)" = "/dev/tty1" ]; then
exec cage firefox --kiosk https://c3nav.de
fi
EOF
[Service]
User=kiosk
Type=simple
ExecStart=/usr/bin/firefox --kiosk https://mahn.ke
Restart=always
RestartSec=5
Environment=DISPLAY=:0
[Install]
WantedBy=graphical.target
EOF
systemctl enable firefox-kiosk.service

View file

@ -47,15 +47,19 @@ d-i apt-setup/disable-cdrom-entries boolean true
tasksel tasksel/first multiselect standard, ssh-server
d-i pkgsel/include string \
xorg \
openbox \
sway \
swaybg \
swayidle \
swaylock \
wayland-protocols \
xwayland \
chromium \
sudo \
cage \
firefox-esr \
curl
d-i pkgsel/exclude string gnome-software
d-i pkgsel/exclude string \
gnome-software \
xserver-xorg*
d-i grub-installer/only_debian boolean true
d-i grub-installer/bootdev string default

View file

@ -1,122 +0,0 @@
// ==UserScript==
// @name Back to Home (39C3 Kiosk)
// @namespace http://tampermonkey.net/
// @version 2025-12-18
// @description Adds buttons to every website to return to home page and prompts on idle
// @author You
// @match *://*/*
// @icon https://www.google.com/s2/favicons?sz=64&domain=google.com
// @grant GM_addStyle
// ==/UserScript==
(function() {
'use strict';
const btn = document.createElement('button');
btn.textContent = 'Home';
btn.style.cssText = ' all: unset; box-sizing: border-box; border: 2px solid #141414; background: #faf5f5; text-align: center; color: #141414; position: fixed; right: 10px; bottom: 10px; width: 60px; height: 60px; z-index: 2147483647; padding-top: 6px; border-radius: 60px;';
btn.innerHTML = '<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-house-icon lucide-house"><path d="M15 21v-8a1 1 0 0 0-1-1h-4a1 1 0 0 0-1 1v8"/><path d="M3 10a2 2 0 0 1 .709-1.528l7-6a2 2 0 0 1 2.582 0l7 6A2 2 0 0 1 21 10v9a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z"/></svg>';
btn.addEventListener('click', () => {
window.location.href = 'http://127.0.0.1:8080';
});
(document.body || document.documentElement).appendChild(btn);
const IDLE_LIMIT_MS = 30_000; // 30 seconds
let idleTimer = null;
let promptVisible = false;
const modal = document.createElement('div');
modal.id = 'idle-modal';
modal.hidden = true;
modal.style.cssText = `
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
background-color: #141414 !important;
border-radius: 0.385em;
border: 2px solid #444;
padding: 20px;
z-index: 2147483647;
box-shadow: 0 4px 8px rgba(0,0,0,0.2);
`;
modal.innerHTML = `
<h2>You seem to be idle</h2>
<p>Do you want to stay on this page or go back to the home page?</p>
<button id="idle-stay">Stay</button>
<button id="idle-go">Go to Home</button>
`;
document.body.appendChild(modal);
const backdrop = document.createElement('div');
backdrop.id = 'idle-backdrop';
backdrop.hidden = true;
backdrop.style.cssText = `
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0,0,0,0.5);
z-index: 2147483646;
`;
document.body.appendChild(backdrop);
const userEvents = [
'mousemove',
'mousedown',
'keydown',
'wheel',
'touchstart',
'scroll'
];
function showPrompt() {
promptVisible = true;
modal.hidden = false;
backdrop.hidden = false;
debugger;
// Move focus to the primary action for accessibility
document.querySelector("#idle-stay").addEventListener("click", () => {
hidePrompt();
resetIdleTimer();
});
document.querySelector("#idle-go").addEventListener("click", () => {
window.location.href = 'https://www.google.com';
});
}
function hidePrompt() {
promptVisible = false;
modal.hidden = true;
backdrop.hidden = true;
}
function onIdle() {
showPrompt();
}
function resetIdleTimer() {
if (promptVisible) return; // Don't auto-dismiss while prompt is visible
if (idleTimer) clearTimeout(idleTimer);
idleTimer = setTimeout(onIdle, IDLE_LIMIT_MS);
}
// Any user activity resets the timer
userEvents.forEach(evt => {
document.addEventListener(evt, resetIdleTimer, { passive: true });
});
// When returning to a visible tab, refresh the timer
document.addEventListener('visibilitychange', () => {
if (document.visibilityState === 'visible') {
resetIdleTimer();
}
});
// Actions
// Kick things off
resetIdleTimer();
})();

View file

@ -1,214 +0,0 @@
// ==UserScript==
// @name HVV Styling (39C3 Kiosk)
// @namespace http://tampermonkey.net/
// @version 2025-12-18
// @description try to take over the world!
// @author You
// @match https://www.hvv.de/de/fahrplaene/abruf-fahrplaninfos/abfahrten-auf-ihrem-monitor/abfahrten-anzeige?show=66c992574d6c4179a65009c84f0f74fc
// @icon https://www.google.com/s2/favicons?sz=64&domain=hvv.de
// @grant GM_addStyle
// ==/UserScript==
(function() {
'use strict';
GM_addStyle(`:root {
--color-neutral-50: #f2f0f5;
--color-neutral-100: #d1c6e0;
--color-neutral-200: #b2a0cb;
--color-neutral-300: #957eb5;
--color-neutral-400: #7a60a0;
--color-neutral-500: #61468b;
--color-neutral-600: #4b3176;
--color-neutral-700: #371f60;
--color-neutral-800: #26114b;
--color-neutral-900: #180736;
--color-neutral-950: #0c011f;
--color-argon-50: #e1abc9;
--color-argon-100: #da87b5;
--color-argon-200: #d464a1;
--color-argon-300: #cd448f;
--color-argon-400: #c6257d;
--color-argon-500: #b0166f;
--color-argon-600: #9a0a61;
--color-argon-700: #830755;
--color-argon-800: #6d0449;
--color-argon-900: #56023c;
--color-argon-950: #3f012d;
--color-krypton-50: #b2d9ea;
--color-krypton-100: #8cc9e4;
--color-krypton-200: #69bade;
--color-krypton-300: #4badd8;
--color-krypton-400: #2493c2;
--color-krypton-500: #167fac;
--color-krypton-600: #0a6c96;
--color-krypton-700: #075c81;
--color-krypton-800: #044c6b;
--color-krypton-900: #023c55;
--color-krypton-950: #012c3f;
--color-green-50: #c0f49a;
--color-green-100: #a7e57a;
--color-green-200: #8fd75d;
--color-green-300: #7ac843;
--color-green-400: #66b92d;
--color-green-500: #54aa18;
--color-green-600: #47990f;
--color-green-700: #397e0a;
--color-green-800: #2b6206;
--color-green-900: #1f4703;
--color-green-950: #122b01;
--color-red-50: #e6afaf;
--color-red-100: #dd9090;
--color-red-200: #d57272;
--color-red-300: #cc5757;
--color-red-400: #c33d3d;
--color-red-500: #bb2626;
--color-red-600: #b21010;
--color-red-700: #950808;
--color-red-800: #780404;
--color-red-900: #5c0202;
--color-red-950: #3f0101;
--color-yellow-50: #fefce8;
--color-yellow-100: #fef9c2;
--color-yellow-200: #fff085;
--color-yellow-300: #ffdf20;
--color-yellow-400: #fdc700;
--color-yellow-500: #efb100;
--color-yellow-600: #d08700;
--color-yellow-700: #a65f00;
--color-yellow-800: #894b00;
--color-yellow-900: #733e0a;
--color-yellow-950: #432004;
--color-white: #ffffff;
--color-dark-foreground: var(--color-neutral-50);
--color-dark-background: var(--color-neutral-950);
--color-dark-shade-1: var(--color-neutral-900);
--color-dark-shade-2: var(--color-neutral-800);
--color-dark-shade-3: var(--color-neutral-700);
--color-dark-shade-4: var(--color-neutral-600);
--color-dark-text-1: rgba(250, 245, 245, 0.8);
--color-dark-text-2: var(--color-neutral-300);
--color-dark-text-3: var(--color-neutral-400);
--color-dark-text-4: var(--color-neutral-500);
--color-dark-primary: var(--color-argon-400);
--color-dark-secondary: #9673ff;
--color-dark-error: var(--color-red-500);
--color-dark-success: var(--color-green-500);
--color-dark-warning: var(--color-yellow-500);
--color-dark-accent-1: #60a5f9;
--color-dark-accent-2: #d381f7;
--color-dark-accent-3: #ff7975;
--color-light-foreground: var(--color-neutral-950);
--color-light-background: var(--color-neutral-50);
--color-light-shade-1: var(--color-neutral-100);
--color-light-shade-2: var(--color-neutral-200);
--color-light-shade-3: var(--color-neutral-300);
--color-light-shade-4: var(--color-neutral-400);
--color-light-text-1: var(--color-neutral-800);
--color-light-text-2: var(--color-neutral-700);
--color-light-text-3: var(--color-neutral-600);
--color-light-text-4: var(--color-neutral-500);
--color-light-primary: var(--color-argon-600);
--color-light-secondary: var(--color-krypton-500);
--color-light-error: var(--color-red-600);
--color-light-success: var(--color-green-600);
--color-light-warning: var(--color-yellow-600);
--color-light-accent-1: #303ec0;
--color-light-accent-2: #6c366c;
--color-light-accent-3: #932f0a;
--color-cmyk-primary: var(--color-dark-primary);
--color-cmyk-secondary: var(--color-dark-secondary);
--line-height-loose: 1.4;
--line-height-relaxed: 1.3;
--line-height-base: 1.2;
--line-height-snug: 1.1;
--line-height-tight: 1;
--text-xs: 0.75rem;
--text-sm: 0.875rem;
--text-base: 1rem;
--text-lg: 1.125rem;
--text-xl: 1.25rem;
--text-2xl: 1.5rem;
--text-3xl: 1.875rem;
--text-4xl: 2.25rem;
--text-5xl: 3rem;
--text-6xl: 3.75rem;
--text-7xl: 4.5rem;
--container-3xs: 16rem;
--container-2xs: 18rem;
--container-xs: 20rem;
--container-sm: 24rem;
--container-md: 28rem;
--container-lg: 32rem;
--container-xl: 36rem;
--container-2xl: 42rem;
--container-3xl: 48rem;
--container-4xl: 56rem;
--container-5xl: 64rem;
--container-6xl: 72rem;
--container-7xl: 80rem;
}
#page-content, .f-body {
margin: 0;
padding: 0
}
.o-headline1 {
color: rgb(102, 246, 102);
font-size: 3em
}
.o-headline2 {
color: var(--color-dark-secondary);
font-size: 3em
}
.js-span-station-name {
color: var(--color-dark-text-1);
font-size: 1.5em
}
.o-table table{
color: var(--color-dark-text-1);
font-size: 2em
}
.o-transport-icon {
transform: scale(2);
color: var(--color-argon-600);
margin-left: 20px !important;
}
.c-departures-monitor__delay-time.is-late {
color: #ff3719;
}
.c-departures-monitor__delay-time.is-on-time {
color: #009900;
}
.c-departures-monitor__logo {
opacity: 0.7
}
body {
background-color: #141414;
}
.js-span-station-name {
margin: 0 !important;
}
.o-transport-icon--transparent .o-transport-icon__number {
color: #faf5f5 !important;
}
`);
})();

View file

@ -1,130 +0,0 @@
// ==UserScript==
// @name Mastodon Styling (39C3 Kiosk)
// @namespace http://tampermonkey.net/
// @version 2025-12-18
// @description Reduces actions not required to serve a Kiosk at 39C3
// @author You
// @match https://chaos.social/tags/39c3/
// @icon https://www.google.com/s2/favicons?sz=64&domain=chaos.social
// @grant GM_addStyle
// ==/UserScript==
(function() {
'use strict';
GM_addStyle(`
.columns-area__panels__pane.columns-area__panels__pane--compositional {
display: none;
}
.columns-area__panels__pane.columns-area__panels__pane--start.columns-area__panels__pane--navigational {
display: none;
}
div#tabs-bar__portal {
display: none;
}
.hashtag-header__header__buttons {
display: none;
}
span.display-name {
background-color: #9673ff;
font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}
span.display-name * {
display: inline !important;
font-weight: normal !important;
color: black !important;
text-transform: uppercase;
}
span.display-name__account::before {
content: '(';
}
span.display-name__account::after {
content: ')';
}
.hashtag-header__header__buttons {
display: none;
}
span.display-name, .status__relative-time {
background-color: #9673ff;
font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
padding: 5px 5px 2px;
}
span.display-name *, .status__relative-time {
display: inline !important;
font-weight: normal !important;
color: black !important;
text-transform: uppercase;
height: auto;
}
span.display-name__account::before {
content: '(';
}
span.display-name__account::after {
content: ')';
}
.status {
border-bottom: 0 !important;
}
.status p {
color: rgba(250, 245, 245, 0.8) !important;
}
.status p a{
color: rgba(102, 246, 102) !important;
}
.status__action-bar {
display: none !important;
}
.column>.scrollable {
border: 0 !important;
background: transparent !important;
}
article {
background-color: #242424;
border-radius: 0.375rem;
margin-bottom: 40px !important;
}
.columns-area__panels__main {
max-width: 60vw;
}
.hashtag-bar a {
--hub-tag-bg: transparent;
--hub-tag-border: 1px solid #9673ff;
--hub-tag-color: #9673ff;
--bs-border-radius: 0.375rem;
background-color: var(--hub-tag-bg);
border-radius: var(--bs-border-radius) 0;
border: var(--hub-tag-border);
color: var(--hub-tag-color);
display: inline-flex;
gap: 5px;
min-width: 0;
overflow: hidden;
padding: 5px 5px 2px;
text-overflow: ellipsis;
text-transform: uppercase;
white-space: nowrap;
}
.hashtag-header {
display: none;
}
`);
})();