Webview: add clanList edit
All checks were successful
buildbot/nix-build .#checks.x86_64-linux.package-zt-tcp-relay Build done.
buildbot/nix-build .#checks.x86_64-linux.package-docs Build done.
buildbot/nix-build .#checks.x86_64-linux.package-zerotierone Build done.
buildbot/nix-build .#checks.x86_64-linux.nixos-test_install_machine Build done.
buildbot/nix-build .#checks.x86_64-linux.postgresql Build done.
buildbot/nix-build .#checks.x86_64-linux.secrets Build done.
checks / checks-impure (pull_request) Successful in 3m22s
buildbot/nix-build .#checks.x86_64-linux.devShell-clan-app Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-app-no-breakpoints Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-mypy Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-bash Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-e2fsprogs Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-age Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-git Build done.
buildbot/nix-build .#checks.x86_64-linux.check-for-breakpoints Build done.
buildbot/nix-build .#checks.aarch64-darwin.nixos-test-backup Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-app-pytest Build done.
buildbot/nix-build .#checks.x86_64-linux.package-gui-installer-apk Build done.
buildbot/nix-build .#checks.x86_64-linux.package-module-schema Build done.
buildbot/nix-build .#checks.x86_64-linux.template-minimal Build done.
buildbot/nix-build .#checks.x86_64-linux.package-function-schema Build done.
buildbot/nix-build .#checks.x86_64-linux.nixos-test-backup Build done.
buildbot/nix-build .#checks.x86_64-linux.package-gui-installer-archlinux Build done.
buildbot/nix-build .#checks.x86_64-linux.devShell-docs Build done.
buildbot/nix-build .#checks.x86_64-linux.package-gui-installer-rpm Build done.
buildbot/nix-build .#checks.x86_64-linux.package-gui-installer-deb Build done.
buildbot/nix-build .#checks.aarch64-darwin.nixos-minimal-inventory-machine Build done.
buildbot/nix-build .#checks.x86_64-linux.treefmt Build done.
buildbot/nix-build .#checks.x86_64-linux.renderClanOptions Build done.
buildbot/nix-build .#checks.aarch64-darwin.nixos-flash-installer Build done.
buildbot/nix-build .#checks.x86_64-linux.borgbackup Build done.
buildbot/nix-build .#checks.aarch64-darwin.nixos-test_install_machine Build done.
buildbot/nix-build .#checks.x86_64-linux.package-module-docs Build done.
buildbot/nix-build .#checks.aarch64-linux.nixos-test-backup Build done.
buildbot/nix-build .#checks.aarch64-linux.nixos-test_install_machine Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-openssh Build done.
buildbot/nix-build .#checks.aarch64-linux.nixos-flash-installer Build done.
buildbot/nix-build .#checks.aarch64-linux.nixos-minimal-inventory-machine Build done.
buildbot/nix-build .#checks.x86_64-linux.nixos-flash-installer Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-qemu Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-rsync Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-sops Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-sshpass Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-tor Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-pytest-without-core Build done.
buildbot/nix-build .#checks.x86_64-linux.devShell-clan-cli Build done.
buildbot/nix-build .#checks.x86_64-linux.devShell-inventory-schema Build done.
buildbot/nix-build .#checks.x86_64-linux.devShell-webview-ui Build done.
buildbot/nix-build .#checks.x86_64-linux.zt-tcp-relay Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-zbar Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-nix Build done.
buildbot/nix-build .#checks.x86_64-linux.wayland-proxy-virtwl Build done.
buildbot/nix-build .#checks.x86_64-linux.package-webview-ui Build done.
buildbot/nix-build .#checks.x86_64-linux.syncthing Build done.
buildbot/nix-build .#checks.x86_64-linux.module-clan-vars-eval Build done.
buildbot/nix-build .#checks.x86_64-linux.package-gui-install-test-ubuntu-22-04 Build done.
buildbot/nix-build .#checks.x86_64-linux.lib-inventory-eval Build done.
buildbot/nix-build .#checks.x86_64-linux.package-clan-app Build done.
buildbot/nix-build .#checks.x86_64-linux.container Build done.
buildbot/nix-build .#checks.x86_64-linux.test-backups Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-pytest-with-core Build done.
buildbot/nix-build .#checks.x86_64-linux.devShell-default Build done.
buildbot/nix-build .#checks.x86_64-linux.flash Build done.
buildbot/nix-build .#checks.x86_64-linux.test-installation Build done.
buildbot/nix-eval Build done.
buildbot/nix-build .#checks.x86_64-linux.lib-inventory-schema Build done.
buildbot/nix-build .#checks.x86_64-linux.lib-jsonschema-example-valid Build done.
buildbot/nix-build .#checks.x86_64-linux.package-clan-cli Build done.
buildbot/nix-build .#checks.x86_64-linux.package-clan-ts-api Build done.
buildbot/nix-build .#checks.x86_64-linux.package-default Build done.
buildbot/nix-build .#checks.x86_64-linux.package-editor Build done.
buildbot/nix-build .#checks.x86_64-linux.package-pending-reviews Build done.
buildbot/nix-build .#checks.x86_64-linux.deltachat Build done.
buildbot/nix-build .#checks.x86_64-linux.matrix-synapse Build done.
buildbot/nix-build .#checks.x86_64-linux.package-clan-cli-docs Build done.
buildbot/nix-build .#checks.x86_64-linux.package-clan-cli-full Build done.
buildbot/nix-build .#checks.x86_64-linux.package-deploy-docs Build done.
buildbot/nix-build .#checks.x86_64-linux.module-schema Build done.
buildbot/nix-build .#checks.x86_64-linux.lib-jsonschema-nix-unit-tests Build done.
buildbot/nix-build .#checks.x86_64-linux.package-impure-checks Build done.
buildbot/nix-build .#checks.x86_64-linux.nixos-minimal-inventory-machine Build done.
buildbot/nix-build .#checks.x86_64-linux.package-merge-after-ci Build done.
buildbot/nix-build .#checks.x86_64-linux.package-moonlight-sunshine-accept Build done.
buildbot/nix-build .#checks.x86_64-linux.package-tea-create-pr Build done.
buildbot/nix-build .#checks.x86_64-linux.package-zerotier-members Build done.

This commit is contained in:
Johannes Kirschbauer 2024-07-11 18:45:29 +02:00
parent 3736f492d3
commit ba8a9c7565
Signed by: hsjobeki
SSH Key Fingerprint: SHA256:vX3utDqig7Ph5L0JPv87ZTPb/w7cMzREKVZzzLFg9qU
3 changed files with 82 additions and 65 deletions

View File

@ -17,6 +17,8 @@ const [clanList, setClanList] = makePersisted(createSignal<string[]>([]), {
storage: localStorage, storage: localStorage,
}); });
clanList() && setActiveURI(clanList()[0]);
export { clanList, setClanList }; export { clanList, setClanList };
const App: Component = () => { const App: Component = () => {

View File

@ -1,17 +1,13 @@
import { Component, JSXElement, Show } from "solid-js"; import { Component, JSXElement, Show } from "solid-js";
import { Header } from "./header"; import { Header } from "./header";
import { Sidebar } from "../Sidebar"; import { Sidebar } from "../Sidebar";
import { route, setRoute } from "../App"; import { clanList, route, setRoute } from "../App";
import { effect } from "solid-js/web";
interface LayoutProps { interface LayoutProps {
children: JSXElement; children: JSXElement;
} }
export const Layout: Component<LayoutProps> = (props) => { export const Layout: Component<LayoutProps> = (props) => {
effect(() => {
console.log(route());
});
return ( return (
<> <>
<div class="drawer bg-base-100 lg:drawer-open"> <div class="drawer bg-base-100 lg:drawer-open">
@ -24,12 +20,13 @@ export const Layout: Component<LayoutProps> = (props) => {
<Show when={route() !== "welcome"}> <Show when={route() !== "welcome"}>
<Header /> <Header />
</Show> </Show>
{props.children} {props.children}
</div> </div>
<div <div
class="drawer-side z-40" class="drawer-side z-40"
classList={{ "!hidden": route() === "welcome" }} classList={{
"!hidden": route() === "welcome" || clanList().length === 0,
}}
> >
<label <label
for="toplevel-drawer" for="toplevel-drawer"

View File

@ -5,12 +5,14 @@ import {
required, required,
setValue, setValue,
} from "@modular-forms/solid"; } from "@modular-forms/solid";
import { activeURI, setClanList, setActiveURI, setRoute } from "@/src/App"; import {
activeURI,
// eslint-disable-next-line @typescript-eslint/consistent-type-definitions setClanList,
type SettingsForm = { setActiveURI,
base_dir: string | null; setRoute,
}; clanList,
} from "@/src/App";
import { For } from "solid-js";
export const registerClan = async () => { export const registerClan = async () => {
try { try {
@ -20,7 +22,10 @@ export const registerClan = async () => {
console.log(loc); console.log(loc);
if (loc.status === "success" && loc.data) { if (loc.status === "success" && loc.data) {
// @ts-expect-error: data is a string // @ts-expect-error: data is a string
setClanList((s) => [...s, loc.data]); setClanList((s) => {
const res = new Set([...s, loc.data]);
return Array.from(res);
});
setRoute((r) => { setRoute((r) => {
if (r === "welcome") return "machines"; if (r === "welcome") return "machines";
return r; return r;
@ -33,66 +38,79 @@ export const registerClan = async () => {
}; };
export const Settings = () => { export const Settings = () => {
const [formStore, { Form, Field }] = createForm<SettingsForm>({
initialValues: {
base_dir: activeURI(),
},
});
const handleSubmit: SubmitHandler<SettingsForm> = async (values, event) => {
//
};
return ( return (
<div class="card card-normal"> <div class="card card-normal">
<Form onSubmit={handleSubmit} shouldActive> <div class="card-body">
<div class="card-body"> <div class="label">
<Field name="base_dir" validate={[required("Clan URI is required")]}> <div class="label-text">Registered Clans</div>
{(field, props) => ( <button
<label class="form-control w-full"> class="btn btn-square btn-primary"
<div class="label"> onClick={() => {
<span class="label-text block after:ml-0.5 after:text-primary"> registerClan();
Directory }}
</span> >
</div> <span class="material-icons">add</span>
<div class="stats shadow"> </button>
<div class="stat"> </div>
<div class="stat-figure text-primary"> <div class="stats stats-vertical shadow">
<span class="material-icons">inventory</span> <For each={clanList()}>
</div> {(value) => (
<div class="stat-title">Clan URI</div> <div class="stat">
<div <div class="stat-figure text-primary">
class="stat-value" <div class="join">
classList={{ "text-slate-500": !field.value }} <button
class=" join-item btn-sm"
classList={{
"btn btn-ghost btn-outline": activeURI() !== value,
"badge badge-primary": activeURI() === value,
}}
disabled={activeURI() === value}
onClick={() => {
setActiveURI(value);
}}
> >
{field.value || "Not set"} {activeURI() === value ? "active" : "select"}
<button </button>
class="btn btn-ghost mx-4" <button
onClick={async () => { class="btn btn-ghost btn-outline join-item btn-sm"
const location = await registerClan(); onClick={() => {
if (location) { setClanList((s) =>
setActiveURI(location); s.filter((v, idx) => {
setValue(formStore, "base_dir", location); if (v == value) {
} setActiveURI(
}} clanList()[idx - 1] ||
> clanList()[idx + 1] ||
<span class="material-icons">edit</span> null
</button> );
</div> return false;
<div class="stat-desc">Where the clan source resides</div> }
return true;
})
);
// if (activeURI() === value) {
// setActiveURI();
// }
}}
>
Remove URI
</button>
</div> </div>
</div> </div>
<div class="stat-title">Clan URI</div>
<div class="label"> <div
{field.error && ( class="stat-desc text-lg"
<span class="label-text-alt">{field.error}</span> classList={{
)} "text-primary": activeURI() === value,
}}
>
{value}
</div> </div>
</label> </div>
)} )}
</Field> </For>
</div> </div>
</Form> </div>
</div> </div>
); );
}; };