Skip to content

Commit

Permalink
Support extra context for time required
Browse files Browse the repository at this point in the history
  • Loading branch information
evadecker committed Nov 26, 2024
1 parent ef382a1 commit 2058d7c
Show file tree
Hide file tree
Showing 6 changed files with 75 additions and 37 deletions.
5 changes: 5 additions & 0 deletions .changeset/afraid-cougars-tease.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"namesake": minor
---

Display additional context beside time required
1 change: 1 addition & 0 deletions convex/constants.ts
Original file line number Diff line number Diff line change
Expand Up @@ -375,6 +375,7 @@ export type TimeRequired = {
min: number;
max: number;
unit: TimeUnit;
description?: string;
};

export const DEFAULT_TIME_REQUIRED: TimeRequired = {
Expand Down
1 change: 1 addition & 0 deletions convex/quests.ts
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,7 @@ export const updateQuest = userMutation({
min: v.number(),
max: v.number(),
unit: timeRequiredUnit,
description: v.optional(v.string()),
}),
),
urls: v.optional(v.array(v.string())),
Expand Down
1 change: 1 addition & 0 deletions convex/schema.ts
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ const quests = defineTable({
min: v.number(),
max: v.number(),
unit: timeRequiredUnit,
description: v.optional(v.string()),
}),
urls: v.optional(v.array(v.string())),
deletionTime: v.optional(v.number()),
Expand Down
18 changes: 17 additions & 1 deletion src/routes/_authenticated/_home/quests.$questId.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -111,7 +111,23 @@ const QuestTimeRequired = ({
};

const formattedTime = getFormattedTime(timeRequired);
return <StatGroup label="Time" value={formattedTime} />;
return (
<StatGroup label="Time" value={formattedTime}>
{timeRequired.description && (
<DialogTrigger>
<TooltipTrigger>
<Button variant="icon" size="small">
<CircleHelp />
</Button>
<Tooltip>See details</Tooltip>
</TooltipTrigger>
<Popover className="p-4">
<p className="text-sm max-w-xs">{timeRequired.description}</p>
</Popover>
</DialogTrigger>
)}
</StatGroup>
);
};

const QuestUrls = ({ urls }: { urls?: string[] }) => {
Expand Down
86 changes: 50 additions & 36 deletions src/routes/_authenticated/admin/quests/$questId.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -156,48 +156,62 @@ const TimeRequiredInput = memo(function TimeRequiredInput({
if (!timeRequired) return null;

return (
<div className="flex items-end gap-2">
<NumberField
label="Min. Req. Time"
className="w-28"
value={timeRequired?.min}
maxValue={Math.max(timeRequired.max, 60)}
onChange={(value) =>
onChange({
...timeRequired,
min: value,
})
}
/>
<NumberField
label="Max Req. Time"
className="w-28"
value={timeRequired.max}
minValue={Math.min(timeRequired.min, 1)}
<div className="flex flex-col gap-4">
<div className="flex items-end gap-2">
<NumberField
label="Min. Req. Time"
className="w-28"
value={timeRequired?.min}
maxValue={Math.max(timeRequired.max, 60)}
onChange={(value) =>
onChange({
...timeRequired,
min: value,
})
}
/>
<NumberField
label="Max Req. Time"
className="w-28"
value={timeRequired.max}
minValue={Math.min(timeRequired.min, 1)}
onChange={(value) =>
onChange({
...timeRequired,
max: value,
})
}
/>
<Select
label="Unit"
className="w-40"
selectedKey={timeRequired.unit}
onSelectionChange={(key) =>
onChange({
...timeRequired,
unit: key as TimeUnit,
})
}
>
{Object.entries(TIME_UNITS).map(([key, unit]) => (
<SelectItem key={key} id={key}>
{unit.label}
</SelectItem>
))}
</Select>
</div>
<TextField
label="Description"
description="Add optional context about the time required."
className="w-full"
value={timeRequired.description ?? ""}
onChange={(value) =>
onChange({
...timeRequired,
max: value,
description: value || undefined,
})
}
/>
<Select
label="Unit"
className="w-40"
selectedKey={timeRequired.unit}
onSelectionChange={(key) =>
onChange({
...timeRequired,
unit: key as TimeUnit,
})
}
>
{Object.entries(TIME_UNITS).map(([key, unit]) => (
<SelectItem key={key} id={key}>
{unit.label}
</SelectItem>
))}
</Select>
</div>
);
});
Expand Down

0 comments on commit 2058d7c

Please sign in to comment.