mirror of
https://codeberg.org/PLG-Development/PLG-MuDiCS
synced 2026-07-05 16:37:09 +00:00
feat: show website button (#15)
This commit is contained in:
@@ -9,18 +9,26 @@
|
|||||||
Presentation,
|
Presentation,
|
||||||
SquareTerminal,
|
SquareTerminal,
|
||||||
TextAlignStart,
|
TextAlignStart,
|
||||||
TrafficCone
|
TrafficCone,
|
||||||
|
Globe
|
||||||
} from 'lucide-svelte';
|
} from 'lucide-svelte';
|
||||||
import Button from '$lib/components/Button.svelte';
|
import Button from '$lib/components/Button.svelte';
|
||||||
import PopUp from '$lib/components/PopUp.svelte';
|
import PopUp from '$lib/components/PopUp.svelte';
|
||||||
import type { PopupContent } from '$lib/ts/types';
|
import type { PopupContent } from '$lib/ts/types';
|
||||||
import KeyInput from './KeyInput.svelte';
|
import KeyInput from './KeyInput.svelte';
|
||||||
import { send_keyboard_input, show_blackscreen, shutdown, startup } from '$lib/ts/api_handler';
|
import {
|
||||||
|
send_keyboard_input,
|
||||||
|
show_blackscreen,
|
||||||
|
shutdown,
|
||||||
|
startup,
|
||||||
|
show_html
|
||||||
|
} from '$lib/ts/api_handler';
|
||||||
import { get_display_by_id, run_on_all_selected_displays } from '$lib/ts/stores/displays';
|
import { get_display_by_id, run_on_all_selected_displays } from '$lib/ts/stores/displays';
|
||||||
import { selected_display_ids } from '$lib/ts/stores/select';
|
import { selected_display_ids } from '$lib/ts/stores/select';
|
||||||
import TipTapInput from './TipTapInput.svelte';
|
import TipTapInput from './TipTapInput.svelte';
|
||||||
import { db } from '$lib/ts/database';
|
import { db } from '$lib/ts/database';
|
||||||
import { liveQuery, type Observable } from 'dexie';
|
import { liveQuery, type Observable } from 'dexie';
|
||||||
|
import TextInput from '$lib/components/TextInput.svelte';
|
||||||
|
|
||||||
let all_display_states: Observable<'on' | 'off' | 'mixed'> | undefined = $state();
|
let all_display_states: Observable<'on' | 'off' | 'mixed'> | undefined = $state();
|
||||||
$effect(() => {
|
$effect(() => {
|
||||||
@@ -60,6 +68,17 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const show_website_popup = () => {
|
||||||
|
popup_content = {
|
||||||
|
open: true,
|
||||||
|
snippet: website_popup,
|
||||||
|
title: 'Webseite anzeigen',
|
||||||
|
window_class: 'w-xl',
|
||||||
|
title_icon: Globe,
|
||||||
|
closable: true
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
async function all_state(selected_display_ids: string[]): Promise<'on' | 'off' | 'mixed'> {
|
async function all_state(selected_display_ids: string[]): Promise<'on' | 'off' | 'mixed'> {
|
||||||
const selected_displays = await Promise.all(
|
const selected_displays = await Promise.all(
|
||||||
selected_display_ids.map(async (id) => await get_display_by_id(id))
|
selected_display_ids.map(async (id) => await get_display_by_id(id))
|
||||||
@@ -116,8 +135,51 @@
|
|||||||
10
|
10
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
let website_url = $state('');
|
||||||
|
let website_url_valid = $state(false);
|
||||||
|
|
||||||
|
function validate_website_url(url: string): [boolean, string] {
|
||||||
|
if (url === '') return [true, ''];
|
||||||
|
const regex = /^https?:\/\/[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}/;
|
||||||
|
if (regex.test(url)) {
|
||||||
|
return [true, ''];
|
||||||
|
}
|
||||||
|
return [false, 'Ungültige URL'];
|
||||||
|
}
|
||||||
|
|
||||||
|
async function send_website() {
|
||||||
|
popup_content.open = false;
|
||||||
|
await run_on_all_selected_displays((d) =>
|
||||||
|
show_html(d.ip, `<iframe src="${website_url}"></iframe>`)
|
||||||
|
);
|
||||||
|
website_url = '';
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
{#snippet website_popup()}
|
||||||
|
<div class="flex flex-col gap-2">
|
||||||
|
<TextInput
|
||||||
|
title="URL"
|
||||||
|
placeholder="https://example.com"
|
||||||
|
bind:current_value={website_url}
|
||||||
|
bind:current_valid={website_url_valid}
|
||||||
|
is_valid_function={validate_website_url}
|
||||||
|
enter_mode="submit"
|
||||||
|
enter_function={send_website}
|
||||||
|
/>
|
||||||
|
<div class="flex flex-row justify-end gap-2">
|
||||||
|
<Button className="button space font-bold" click_function={popup_close_function}>
|
||||||
|
Abbrechen
|
||||||
|
</Button>
|
||||||
|
<Button
|
||||||
|
click_function={send_website}
|
||||||
|
disabled={!website_url_valid || website_url === ''}
|
||||||
|
className="button success space">Anzeigen</Button
|
||||||
|
>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{/snippet}
|
||||||
|
|
||||||
{#snippet ask_shutdonw_popup()}
|
{#snippet ask_shutdonw_popup()}
|
||||||
<p>Bist du sicher, dass du alle ausgewählten Displays herunterfahren möchtest?</p>
|
<p>Bist du sicher, dass du alle ausgewählten Displays herunterfahren möchtest?</p>
|
||||||
|
|
||||||
@@ -176,6 +238,12 @@
|
|||||||
click_function={show_text_popup}><TextAlignStart /> Text anzeigen</Button
|
click_function={show_text_popup}><TextAlignStart /> Text anzeigen</Button
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<Button
|
||||||
|
className="px-3 flex gap-3 w-75 justify-normal"
|
||||||
|
disabled={$selected_display_ids.length === 0}
|
||||||
|
click_function={show_website_popup}><Globe /> Webseite anzeigen</Button
|
||||||
|
>
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
className="px-3 flex gap-3 w-75 justify-normal"
|
className="px-3 flex gap-3 w-75 justify-normal"
|
||||||
disabled={$selected_display_ids.length === 0}
|
disabled={$selected_display_ids.length === 0}
|
||||||
|
|||||||
@@ -20,7 +20,14 @@ func OpenBrowserWindow(url string, fullscreen bool, profile string) error {
|
|||||||
return fmt.Errorf("failed to create local config directory: %w", err)
|
return fmt.Errorf("failed to create local config directory: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
args := []string{fmt.Sprintf("--app=%s", url), "--autoplay-policy=no-user-gesture-required", fmt.Sprintf("--user-data-dir=%s", browserProfileDirPath)}
|
args := []string{
|
||||||
|
fmt.Sprintf("--app=%s", url),
|
||||||
|
"--autoplay-policy=no-user-gesture-required",
|
||||||
|
fmt.Sprintf("--user-data-dir=%s", browserProfileDirPath),
|
||||||
|
"--disable-web-security",
|
||||||
|
"--allow-running-insecure-content",
|
||||||
|
"--disable-features=XFrameOptions",
|
||||||
|
}
|
||||||
if fullscreen {
|
if fullscreen {
|
||||||
args = append(args, "--start-fullscreen")
|
args = append(args, "--start-fullscreen")
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user