Skip to content
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
170b16e
API visual first pass
royendo Feb 3, 2026
b50943c
nit
royendo Feb 3, 2026
737d298
args
royendo Feb 3, 2026
05a5b87
simpler, prettier
royendo Feb 3, 2026
8614d13
web code qual
royendo Feb 3, 2026
74ad9bb
code qual
royendo Feb 3, 2026
cd82c30
Update VisualAPIEditor.svelte
royendo Feb 3, 2026
7cc6139
Update VisualAPIEditor.svelte
royendo Feb 3, 2026
a96efa5
fixed heights and JSON view
royendo Feb 3, 2026
08b2ef7
prettier
royendo Feb 3, 2026
2d1f1f5
code qual
royendo Feb 3, 2026
0a45bdc
Update APIWorkspace.svelte
royendo Feb 3, 2026
7d6e002
Merge branch 'main' into feat/visual-editor-api
royendo Feb 20, 2026
425ecfb
Update errors.ts
royendo Feb 20, 2026
83779f2
themeing css
royendo Feb 20, 2026
05d2383
remove viz editor, consolidate tests into text editor
royendo Mar 5, 2026
563a773
Merge branch 'main' into feat/visual-editor-api
royendo Mar 5, 2026
813ad67
rename
royendo Mar 5, 2026
c34565b
reset review on nav
royendo Mar 5, 2026
8272f9b
reset
royendo Mar 5, 2026
1dbc8f3
template overwrites
royendo Mar 5, 2026
b04e4b9
local PR reviews
royendo Mar 5, 2026
c63a253
Remove unused `mapParseErrorsToLines` import in `+page.svelte`
royendo Mar 11, 2026
a6f6529
Merge branch 'main' into feat/visual-editor-api
royendo Mar 11, 2026
c1ff4d6
importing runtime changes
royendo Mar 11, 2026
2c5ec94
Merge remote-tracking branch 'origin/main' into feat/visual-editor-api
royendo Mar 30, 2026
4b68698
migration svelte/vite
royendo Mar 30, 2026
08af507
prettier
royendo Mar 30, 2026
e670982
prettier
royendo Mar 30, 2026
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
migration svelte/vite
  • Loading branch information
royendo committed Mar 30, 2026
commit 4b68698de4883e6e91591f87734d5fd51490ef8c
38 changes: 20 additions & 18 deletions web-common/src/features/apis/editor/APITestPanel.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
let apiResponse: unknown[] | null = null;
let responseError: string | null = null;
let isLoading = false;
let previewHeight = 200;
let previewHeight = 300;

// Clear response and args when switching to a different API
$: apiName, resetState();
Expand Down Expand Up @@ -135,14 +135,14 @@
class="preview-panel"
style:height="{previewHeight}px"
style:min-height="100px"
style:max-height="60%"
style:max-height="80%"
>
<Resizer max={500} direction="NS" side="top" bind:dimension={previewHeight} />

<div class="flex items-center gap-x-3 px-3 py-2 border-b">
<div class="flex items-center gap-x-2 flex-1 min-w-0">
<span class="text-xs font-medium text-fg-secondary shrink-0">GET</span>
<span class="text-xs font-mono text-fg-muted truncate">{fullUrl}</span>
<span class="text-xs font-medium text-fg-secondary shrink-0">URL Preview: </span>
<span class="text-[11px] font-mono text-fg-muted truncate">{fullUrl}</span>
</div>

<div class="flex items-center gap-x-2 shrink-0">
Expand All @@ -154,24 +154,26 @@
</Tooltip>

<DropdownMenu.Root closeOnItemClick={false}>
<DropdownMenu.Trigger asChild let:builder>
<Button type="text" compact small builders={[builder]}>
Args
{#if args.length > 0}
<span
class="inline-flex items-center justify-center w-4 h-4 text-[10px] font-medium bg-surface-active text-fg-accent rounded-full"
>
{args.length}
</span>
{/if}
<ChevronDownIcon size="10px" />
</Button>
<DropdownMenu.Trigger>
{#snippet child({ props })}
<Button {...props} type="text" compact small>
Args
{#if args.length > 0}
<span
class="inline-flex items-center justify-center w-4 h-4 text-[10px] font-medium bg-surface-active text-fg-accent rounded-full"
>
{args.length}
</span>
{/if}
<ChevronDownIcon size="10px" />
</Button>
{/snippet}
</DropdownMenu.Trigger>
<DropdownMenu.Content align="end" class="w-72 p-2">
<DropdownMenu.Content align="end" class="w-96 p-3">
<!-- svelte-ignore a11y-no-static-element-interactions -->
<div
class="args-container flex flex-col gap-y-2"
on:keydown={handleArgsKeydown}
onkeydown={handleArgsKeydown}
>
{#if args.length === 0}
<p class="text-xs text-fg-muted px-1 py-2">
Expand Down
34 changes: 17 additions & 17 deletions web-common/src/features/workspaces/APIWorkspace.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -103,21 +103,23 @@
>
<svelte:fragment slot="workspace-controls">
<DropdownMenu.Root bind:open={dropdownOpen}>
<DropdownMenu.Trigger asChild let:builder>
<Tooltip distance={8} suppress={dropdownOpen}>
<Button type="text" compact small builders={[builder]}>
Templates
<ChevronDownIcon size="12px" />
</Button>
<TooltipContent slot="tooltip-content">
Insert a starter API template
</TooltipContent>
</Tooltip>
<DropdownMenu.Trigger>
{#snippet child({ props })}
<Tooltip distance={8} suppress={dropdownOpen}>
<Button {...props} type="text" compact small>
Templates
<ChevronDownIcon size="12px" />
</Button>
<TooltipContent slot="tooltip-content">
Insert a starter API template
</TooltipContent>
</Tooltip>
{/snippet}
</DropdownMenu.Trigger>
<DropdownMenu.Content align="end" class="w-56">
<DropdownMenu.Content align="end" class="w-44">
{#each templates as template}
<DropdownMenu.Item on:click={() => selectTemplate(template)}>
<span class="text-sm">{template.label}</span>
<DropdownMenu.Item onclick={() => selectTemplate(template)}>
<span class="text-xs">{template.label}</span>
</DropdownMenu.Item>
{/each}
</DropdownMenu.Content>
Expand Down Expand Up @@ -146,10 +148,8 @@
>
<AlertDialogDescription>
{pendingTemplate?.description ?? ""}
{#if $hasUnsavedChanges}
<br /><br />
<strong>This will replace your current editor content.</strong>
{/if}
<br /><br />
Warning: this will overwrite your current file.
</AlertDialogDescription>
</AlertDialogHeader>
<AlertDialogFooter>
Expand Down
Loading