mirror of
https://github.com/appwrite/console.git
synced 2026-06-06 19:27:48 +00:00
60 lines
1.5 KiB
Svelte
60 lines
1.5 KiB
Svelte
<script lang="ts">
|
|
import { onMount } from 'svelte';
|
|
import { Input } from '@appwrite.io/pink-svelte';
|
|
|
|
export let label: string;
|
|
export let optionalText: string | undefined = undefined;
|
|
export let showLabel = true;
|
|
export let id: string;
|
|
export let name = id;
|
|
export let value = '';
|
|
export let placeholder = '';
|
|
export let required = false;
|
|
export let nullable = false;
|
|
export let disabled = false;
|
|
export let readonly = false;
|
|
export let autofocus = false;
|
|
export let autocomplete = false;
|
|
export let maxlength: number = null;
|
|
|
|
let error: string;
|
|
|
|
const handleInvalid = (event: Event & { currentTarget: EventTarget & HTMLInputElement }) => {
|
|
event.preventDefault();
|
|
|
|
if (event.currentTarget.validity.patternMismatch) {
|
|
error = 'Must be a valid URL';
|
|
return;
|
|
}
|
|
if (event.currentTarget.validity.valueMissing) {
|
|
error = 'This field is required';
|
|
return;
|
|
}
|
|
|
|
error = event.currentTarget.validationMessage;
|
|
};
|
|
|
|
$: if (value) {
|
|
error = null;
|
|
}
|
|
</script>
|
|
|
|
<Input.Text
|
|
{id}
|
|
{name}
|
|
{placeholder}
|
|
{disabled}
|
|
{readonly}
|
|
{required}
|
|
{maxlength}
|
|
{label}
|
|
{nullable}
|
|
type="url"
|
|
autofocus={autofocus || undefined}
|
|
autocomplete={autocomplete ? 'on' : 'off'}
|
|
helper={error}
|
|
state={error ? 'error' : 'default'}
|
|
on:invalid={handleInvalid}
|
|
on:input
|
|
bind:value />
|