removed js sdk dto helpers

This commit is contained in:
Gani Georgiev
2023-08-14 21:20:49 +03:00
parent cbf1215bb1
commit 5960dc5f2d
94 changed files with 1226 additions and 1213 deletions
@@ -1,7 +1,6 @@
<script>
import { createEventDispatcher } from "svelte";
import { slide } from "svelte/transition";
import { Admin } from "pocketbase";
import CommonHelper from "@/utils/CommonHelper";
import ApiClient from "@/utils/ApiClient";
import tooltip from "@/actions/tooltip";
@@ -16,7 +15,7 @@
const formId = "admin_" + CommonHelper.randomString(5);
let panel;
let admin = new Admin();
let admin = {};
let isSaving = false;
let confirmClose = false; // prevent close recursion
let avatar = 0;
@@ -25,11 +24,10 @@
let passwordConfirm = "";
let changePasswordToggle = false;
$: isNew = !!admin?.id;
$: hasChanges =
(admin.$isNew && email != "") ||
changePasswordToggle ||
email !== admin.email ||
avatar !== admin.avatar;
(isNew && email != "") || changePasswordToggle || email !== admin.email || avatar !== admin.avatar;
export function show(model) {
load(model);
@@ -44,7 +42,7 @@
}
function load(model) {
admin = model?.$clone ? model.$clone() : new Admin();
admin = structuredClone(model || {});
reset(); // reset form
}
@@ -65,13 +63,13 @@
isSaving = true;
const data = { email, avatar };
if (admin.$isNew || changePasswordToggle) {
if (isNew || changePasswordToggle) {
data["password"] = password;
data["passwordConfirm"] = passwordConfirm;
}
let request;
if (admin.$isNew) {
if (isNew) {
request = ApiClient.admins.create(data);
} else {
request = ApiClient.admins.update(admin.id, data);
@@ -81,7 +79,7 @@
.then(async (result) => {
confirmClose = false;
hide();
addSuccessToast(admin.$isNew ? "Successfully created admin." : "Successfully updated admin.");
addSuccessToast(isNew ? "Successfully created admin." : "Successfully updated admin.");
if (ApiClient.authStore.model?.id === result.id) {
ApiClient.authStore.save(ApiClient.authStore.token, result);
@@ -137,12 +135,12 @@
>
<svelte:fragment slot="header">
<h4>
{admin.$isNew ? "New admin" : "Edit admin"}
{isNew ? "New admin" : "Edit admin"}
</h4>
</svelte:fragment>
<form id={formId} class="grid" autocomplete="off" on:submit|preventDefault={save}>
{#if !admin.$isNew}
{#if !isNew}
<Field class="form-field readonly" name="id" let:uniqueId>
<label for={uniqueId}>
<i class={CommonHelper.getFieldTypeIcon("primary")} />
@@ -187,14 +185,14 @@
<input type="email" autocomplete="off" id={uniqueId} required bind:value={email} />
</Field>
{#if !admin.$isNew}
{#if !isNew}
<Field class="form-field form-field-toggle" let:uniqueId>
<input type="checkbox" id={uniqueId} bind:checked={changePasswordToggle} />
<label for={uniqueId}>Change password</label>
</Field>
{/if}
{#if admin.$isNew || changePasswordToggle}
{#if isNew || changePasswordToggle}
<div class="col-12">
<div class="grid" transition:slide|local={{ duration: 150 }}>
<div class="col-sm-6">
@@ -233,7 +231,7 @@
</form>
<svelte:fragment slot="footer">
{#if !admin.$isNew}
{#if !isNew}
<button type="button" aria-label="More" class="btn btn-sm btn-circle btn-transparent">
<!-- empty span for alignment -->
<span />
@@ -258,7 +256,7 @@
class:btn-loading={isSaving}
disabled={!hasChanges || isSaving}
>
<span class="txt">{admin.$isNew ? "Create" : "Save changes"}</span>
<span class="txt">{isNew ? "Create" : "Save changes"}</span>
</button>
</svelte:fragment>
</OverlayPanel>