mirror of https://github.com/Budibase/budibase.git
4 changed files with 189 additions and 12 deletions
@ -0,0 +1,142 @@ |
|||||
|
<script> |
||||
|
import { onMount } from "svelte" |
||||
|
export let _bb |
||||
|
export let model |
||||
|
|
||||
|
const TYPE_MAP = { |
||||
|
string: "text", |
||||
|
boolean: "checkbox", |
||||
|
number: "number" |
||||
|
} |
||||
|
|
||||
|
let username |
||||
|
let password |
||||
|
let newModel = { |
||||
|
modelId: model, |
||||
|
} |
||||
|
let store = _bb.store |
||||
|
let schema = {} |
||||
|
let modelDef = {} |
||||
|
$: if (model && model.length !== 0) { |
||||
|
fetchModel() |
||||
|
} |
||||
|
$: fields = Object.keys(schema) |
||||
|
async function fetchModel() { |
||||
|
const FETCH_MODEL_URL = `/api/models/${model}` |
||||
|
const response = await _bb.api.get(FETCH_MODEL_URL) |
||||
|
modelDef = await response.json() |
||||
|
schema = modelDef.schema |
||||
|
} |
||||
|
async function save() { |
||||
|
const SAVE_RECORD_URL = `/api/${model}/records` |
||||
|
const response = await _bb.api.post(SAVE_RECORD_URL, newModel) |
||||
|
const json = await response.json() |
||||
|
store.update(state => { |
||||
|
state[model] = state[model] ? [...state[model], json] : [json] |
||||
|
return state |
||||
|
}) |
||||
|
} |
||||
|
const handleInput = field => event => { |
||||
|
let value |
||||
|
if (event.target.type === "checkbox") { |
||||
|
value = event.target.checked |
||||
|
newModel[field] = value |
||||
|
return |
||||
|
} |
||||
|
if (event.target.type === "number") { |
||||
|
value = parseInt(event.target.value) |
||||
|
newModel[field] = value |
||||
|
return |
||||
|
} |
||||
|
value = event.target.value |
||||
|
newModel[field] = value |
||||
|
} |
||||
|
</script> |
||||
|
<form class="form" on:submit|preventDefault> |
||||
|
<h1>{modelDef.name} Form</h1> |
||||
|
<hr /> |
||||
|
<div class="form-content"> |
||||
|
{#each fields as field} |
||||
|
<div class="form-item"> |
||||
|
<label class="form-label" for="form-stacked-text">{field}</label> |
||||
|
<input |
||||
|
class="input" |
||||
|
placeholder={field} |
||||
|
type={TYPE_MAP[schema[field].type]} |
||||
|
on:change={handleInput(field)} /> |
||||
|
</div> |
||||
|
<hr /> |
||||
|
{/each} |
||||
|
<div class="button-block"> |
||||
|
<button on:click={save}>Submit Form</button> |
||||
|
</div> |
||||
|
</div> |
||||
|
</form> |
||||
|
<style> |
||||
|
.form { |
||||
|
display: flex; |
||||
|
flex-direction: column; |
||||
|
justify-content: center; |
||||
|
margin: auto; |
||||
|
padding: 40px; |
||||
|
} |
||||
|
.form-content { |
||||
|
margin-bottom: 20px; |
||||
|
} |
||||
|
.input { |
||||
|
height: 40px; |
||||
|
border-radius: 5px; |
||||
|
border: 1px solid #e6e6e6; |
||||
|
padding: 6px 12px 6px 12px; |
||||
|
font-size: 16px; |
||||
|
} |
||||
|
.input::placeholder { |
||||
|
color: #cccccc; |
||||
|
} |
||||
|
.form-item { |
||||
|
display: grid; |
||||
|
grid-template-columns: 30% 1fr; |
||||
|
margin-bottom: 16px; |
||||
|
align-items: center; |
||||
|
gap: 1em; |
||||
|
} |
||||
|
|
||||
|
hr { |
||||
|
border: 1px solid #f5f5f5; |
||||
|
margin: 40px 0px; |
||||
|
} |
||||
|
hr:nth-last-child(2) { |
||||
|
border: 1px solid #f5f5f5; |
||||
|
margin: 40px 0px; |
||||
|
} |
||||
|
.button-block { |
||||
|
display: flex; |
||||
|
justify-content: flex-end; |
||||
|
} |
||||
|
button { |
||||
|
font-size: 16px; |
||||
|
padding: 8px 16px; |
||||
|
box-sizing: border-box; |
||||
|
border-radius: 4px; |
||||
|
color: white; |
||||
|
background-color: #393c44; |
||||
|
outline: none; |
||||
|
height: 40px; |
||||
|
cursor: pointer; |
||||
|
transition: all 0.2s ease 0s; |
||||
|
overflow: hidden; |
||||
|
outline: none; |
||||
|
user-select: none; |
||||
|
white-space: nowrap; |
||||
|
text-align: center; |
||||
|
} |
||||
|
button:hover { |
||||
|
box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05); |
||||
|
} |
||||
|
|
||||
|
input[type=checkbox] { |
||||
|
transform: scale(2); |
||||
|
cursor: pointer; |
||||
|
} |
||||
|
|
||||
|
</style> |
||||
Loading…
Reference in new issue