pocketbase/ui/src/components/collections/docs/DeleteApiDocs.svelte

141 lines
3.6 KiB
Svelte
Raw Normal View History

2022-07-07 05:19:05 +08:00
<script>
import ApiClient from "@/utils/ApiClient";
import CommonHelper from "@/utils/CommonHelper";
2022-07-07 05:19:05 +08:00
import CodeBlock from "@/components/base/CodeBlock.svelte";
2022-07-31 02:00:18 +08:00
import SdkTabs from "@/components/collections/docs/SdkTabs.svelte";
2022-07-07 05:19:05 +08:00
2023-08-15 02:20:49 +08:00
export let collection;
2022-07-07 05:19:05 +08:00
let responseTab = 204;
let responses = [];
$: adminsOnly = collection?.deleteRule === null;
$: backendAbsUrl = CommonHelper.getApiExampleUrl(ApiClient.baseUrl);
2022-07-31 02:00:18 +08:00
2022-07-07 05:19:05 +08:00
$: if (collection?.id) {
responses.push({
code: 204,
body: `
null
`,
});
responses.push({
code: 400,
body: `
{
"code": 400,
"message": "Failed to delete record. Make sure that the record is not part of a required relation reference.",
"data": {}
}
`,
});
if (adminsOnly) {
responses.push({
code: 403,
body: `
{
"code": 403,
"message": "Only admins can access this action.",
"data": {}
}
`,
});
}
responses.push({
code: 404,
body: `
{
"code": 404,
"message": "The requested resource wasn't found.",
"data": {}
}
`,
});
}
</script>
2022-10-30 16:28:14 +08:00
<h3 class="m-b-sm">Delete ({collection.name})</h3>
<div class="content txt-lg m-b-sm">
2022-07-07 05:19:05 +08:00
<p>Delete a single <strong>{collection.name}</strong> record.</p>
</div>
2022-07-31 02:00:18 +08:00
<SdkTabs
js={`
import PocketBase from 'pocketbase';
2022-10-30 16:28:14 +08:00
const pb = new PocketBase('${backendAbsUrl}');
2022-07-31 02:00:18 +08:00
...
2022-10-30 16:28:14 +08:00
await pb.collection('${collection?.name}').delete('RECORD_ID');
2022-07-31 02:00:18 +08:00
`}
dart={`
import 'package:pocketbase/pocketbase.dart';
2022-10-30 16:28:14 +08:00
final pb = PocketBase('${backendAbsUrl}');
2022-07-31 02:00:18 +08:00
...
2022-10-30 16:28:14 +08:00
await pb.collection('${collection?.name}').delete('RECORD_ID');
2022-07-31 02:00:18 +08:00
`}
/>
2022-07-07 05:19:05 +08:00
2022-10-30 16:28:14 +08:00
<h6 class="m-b-xs">API details</h6>
<div class="alert alert-danger">
<strong class="label label-primary">DELETE</strong>
<div class="content">
<p>
/api/collections/<strong>{collection.name}</strong>/records/<strong>:id</strong>
</p>
</div>
{#if adminsOnly}
<p class="txt-hint txt-sm txt-right">Requires admin <code>Authorization:TOKEN</code> header</p>
{/if}
</div>
2022-07-07 05:19:05 +08:00
<div class="section-title">Path parameters</div>
2022-10-30 16:28:14 +08:00
<table class="table-compact table-border m-b-base">
2022-07-07 05:19:05 +08:00
<thead>
<tr>
<th>Param</th>
<th>Type</th>
<th width="60%">Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>id</td>
<td>
<span class="label">String</span>
</td>
<td>ID of the record to delete.</td>
</tr>
</tbody>
</table>
<div class="section-title">Responses</div>
<div class="tabs">
2023-09-01 17:44:43 +08:00
<div class="tabs-header compact combined left">
2022-07-07 05:19:05 +08:00
{#each responses as response (response.code)}
<button
class="tab-item"
class:active={responseTab === response.code}
on:click={() => (responseTab = response.code)}
>
{response.code}
</button>
{/each}
</div>
<div class="tabs-content">
{#each responses as response (response.code)}
<div class="tab-item" class:active={responseTab === response.code}>
<CodeBlock content={response.body} />
</div>
{/each}
</div>
</div>