Skip to content

Commit

Permalink
Cleaned up empty card display
Browse files Browse the repository at this point in the history
# Conflicts:
#	.mise.toml
#	src/index.tsx
  • Loading branch information
CEbbinghaus committed Dec 17, 2024
1 parent f468166 commit 3480f28
Show file tree
Hide file tree
Showing 5 changed files with 63 additions and 40 deletions.
2 changes: 1 addition & 1 deletion .mise.toml
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ outputs = ['build/bin/backend']
[tasks."build:frontend"]
description = 'Build the Frontend'
run = "node --no-warnings=ExperimentalWarning 'util/build.mjs' -q -o frontend"
sources = ['package.json', 'lib/package.json', '{src,lib}/**/*.*']
sources = ['package.json', 'lib/package.json', '{src,lib,docs}/**/*.*']
outputs = ['dist/index.js']

[tasks."build:collect"]
Expand Down
1 change: 0 additions & 1 deletion build.sh
Original file line number Diff line number Diff line change
@@ -1,3 +1,2 @@
#!/bin/bash
exec node "--no-warnings=ExperimentalWarning" "util/build.mjs" "$@"

2 changes: 1 addition & 1 deletion docs/index.mdx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Navigation, SideMenu } from "decky-frontend-lib";
import { Navigation, SideMenu } from "@decky/ui";
import { CurrentCard } from "./components/CurrentCard";
import { CheckList, CheckListItem } from "./components/QuickStart/CheckList";
import { FaPlug } from "react-icons/fa"
Expand Down
86 changes: 52 additions & 34 deletions src/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -54,16 +54,18 @@ function EditCardButton(props: EditCardButtonProps) {
)
}

function Content() {
const { currentCardAndGames, cardsAndGames, microSDeck, frontendSettings, refresh } = useMicroSDeckContext();

const [dismiss_docs, setDismissDocs] = useState(frontendSettings?.dismissed_docs || false);
function CardsList({ cardsAndGames, currentCardAndGames, microSDeck }: { cardsAndGames: CardAndGames[], currentCardAndGames: CardAndGames | undefined, microSDeck: MicroSDeck }) {

const [currentCard] = currentCardAndGames || [undefined];

const isLoaded = !!cardsAndGames;
function CardInteractables({ entry }: {
entry: ReorderableEntry<MicroSDCard>
}) {
const cardAndGames = cardsAndGames.find(([card]) => card.uid == entry.data!.uid)!;
return (<EditCardButton {...{ cardAndGames, currentCard, microSDeck: microSDeck }} />);
}

const entries = cardsAndGames?.sort(([a], [b]) => a.position - b.position).map(([card], index) => {
const entries = cardsAndGames.sort(([a], [b]) => a.position - b.position).map(([card], index) => {
const currentCardMark = card.uid === currentCard?.uid ? (<small style={{ marginLeft: "0.5em" }}><FaStar size={12} /></small>) : "";

return {
Expand All @@ -81,32 +83,58 @@ function Content() {
};
});

function CardInteractables({ entry }: {
entry: ReorderableEntry<MicroSDCard>
}) {
const cardAndGames = cardsAndGames!.find(([card]) => card.uid == entry.data!.uid)!;
return (<EditCardButton {...{ cardAndGames, currentCard, microSDeck: microSDeck }} />);
if (entries.length == 0) {
return (
<div style={{ width: "100%", display: "flex", justifyContent: "center", alignItems: "center", padding: "5px" }}>
No Cards (yet)
</div>
);
}

return (
<ReorderableList<MicroSDCard>
entries={entries!}
interactables={CardInteractables}
onSave={async (entries: ReorderableEntry<MicroSDCard>[]) => {
await backend.fetchUpdateCards({
url: API_URL, logger: Logger, cards: entries.map(v => {
v.data!.position = v.position;
return v.data!;
})
});

Logger.Log(`Reordered Tabs`)
}}
/>
);
}

function Content() {
const { currentCardAndGames, cardsAndGames, microSDeck, frontendSettings, refresh } = useMicroSDeckContext();

const [dismiss_docs, setDismissDocs] = useState(frontendSettings?.dismissed_docs || false);

const isLoaded = !!cardsAndGames;

let docs_card = (<></>);

if (frontendSettings && frontendSettings.dismissed_docs === false) {
docs_card = (
<div style={{backgroundColor: "#577ca8", width: "100%", paddingBottom: "8px"}}>
<div style={{padding: "5px", width: "80%", margin: "auto"}}>
<div style={{ backgroundColor: "#577ca8", width: "100%", paddingBottom: "8px" }}>
<div style={{ padding: "5px", width: "80%", margin: "auto" }}>
<div>
<h3 style={{margin: "0px"}}>Check out the new Docs!</h3>
Open them using
<div style={{display: "inline-block", marginLeft: ".2em"}}>
<div style={{backgroundColor: "black", borderRadius: "100px", display: "flex", justifyContent: "center", width: "40px"}}>
<h3 style={{ margin: "0px" }}>Check out the new Docs!</h3>
Open them using
<div style={{ display: "inline-block", marginLeft: ".2em" }}>
<div style={{ backgroundColor: "black", borderRadius: "100px", display: "flex", justifyContent: "center", width: "40px" }}>
<GiHamburgerMenu />
</div>
</div>
</div>
<DialogCheckbox onChange={setDismissDocs} label="Don't remind me again" />
<DialogButton
style={{ width: "100%" }}
onOKButton={() => {
onOKButton={() => {
if (dismiss_docs) {
refresh();
fetchSetSetting({ url: API_URL, logger: Logger, setting_name: "frontend:dismissed_docs", value: dismiss_docs });
Expand All @@ -120,25 +148,15 @@ function Content() {
}

return (
<div style={{scrollPadding: "48px 0px" }}>
<div style={{ scrollPadding: "48px 0px" }}>
<Focusable onMenuActionDescription='Open Docs' onMenuButton={() => { Navigation.CloseSideMenus(); Navigation.Navigate(DOCUMENTATION_PATH); }}>
<div style={{ margin: "5px", marginTop: "0px" }}>
Edit MicroSD Cards
</div>
{docs_card}
<PanelSection title="Cards">
{isLoaded ? (
<ReorderableList<MicroSDCard>
entries={entries!}
interactables={CardInteractables}
onSave={async (entries: ReorderableEntry<MicroSDCard>[]) => {
await backend.fetchUpdateCards({
url: API_URL, logger: Logger, cards: entries.map(v => {
v.data!.position = v.position;
return v.data!;
})
});

Logger.Log(`Reordered Tabs`)
}}
/>
<CardsList cardsAndGames={cardsAndGames} currentCardAndGames={currentCardAndGames} microSDeck={microSDeck} />
) : (
<div style={{ width: "100%", display: "flex", justifyContent: "center", alignItems: "center", padding: "5px" }}>
Loading...
Expand All @@ -162,7 +180,7 @@ export default definePlugin(() => {
const patch = PatchAppScreen(window.MicroSDeck);

routerHook.addRoute(DOCUMENTATION_PATH, () => (
<MicroSDeckContextProvider microSDeck={window.MicroSDeck || (() => {throw "MicroSDeck not initialized";})()}>
<MicroSDeckContextProvider microSDeck={window.MicroSDeck || (() => { throw "MicroSDeck not initialized"; })()}>
<Docs />
</MicroSDeckContextProvider>));

Expand Down
12 changes: 9 additions & 3 deletions util/build.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -155,14 +155,20 @@ if (is_local && tasks.includes('copy')) {
if (tasks.includes('upload')) {
Logger.Log("Uploading plugin to SteamDeck");

var deployJsonPath = join(basePath, 'deploy.json');
try {
statfsSync(join(basePath, 'deploy.json'))
statfsSync(deployJsonPath)
} catch (e) {
Logger.Error("deploy.json not found. Cannot deploy without it");
Logger.Error(`deploy.json not found under \"${basePath}\" Cannot deploy without it`);
exit(1);
}

const { host, user, keyfile } = importJson('deploy.json');
const { host, user, keyfile } = await importJson(deployJsonPath);

if (!host || !user) {
Logger.Error('malformed deploy.json. missing host and user fields');
exit(1);
}

// ping host to make sure its avaliable
try {
Expand Down

0 comments on commit 3480f28

Please sign in to comment.