Add format setting on long form fields to allow choice between rich text and plain text, and default to automatically determining from the schema

This commit is contained in:
Andrew Kingston 2022-02-07 12:12:02 +00:00
parent a575763bf6
commit 750b266e90
2 changed files with 56 additions and 15 deletions

View File

@ -2391,6 +2391,27 @@
"label": "Default value", "label": "Default value",
"key": "defaultValue" "key": "defaultValue"
}, },
{
"type": "select",
"label": "Formatting",
"key": "format",
"placeholder": null,
"options": [
{
"label": "Auto",
"value": "auto"
},
{
"label": "Plain text",
"value": "plain"
},
{
"label": "Rich text (markdown)",
"value": "rich"
}
],
"defaultValue": "auto"
},
{ {
"type": "boolean", "type": "boolean",
"label": "Disabled", "label": "Disabled",

View File

@ -1,7 +1,7 @@
<script> <script>
import { getContext, setContext } from "svelte" import { getContext, setContext } from "svelte"
import { writable } from "svelte/store" import { writable } from "svelte/store"
import { CoreRichTextField } from "@budibase/bbui" import { CoreRichTextField, CoreTextArea } from "@budibase/bbui"
import Field from "./Field.svelte" import Field from "./Field.svelte"
export let field export let field
@ -10,15 +10,22 @@
export let disabled = false export let disabled = false
export let validation export let validation
export let defaultValue = "" export let defaultValue = ""
export let format = "auto"
let fieldState let fieldState
let fieldApi let fieldApi
let fieldSchema
const context = getContext("context") const context = getContext("context")
const component = getContext("component") const component = getContext("component")
const newContext = writable($component) const newContext = writable($component)
setContext("component", newContext) setContext("component", newContext)
// Determine whether we should use a rich or plain text component.
// We treat undefined as "auto".
$: useRichText =
format === "rich" || (format !== "plain" && fieldSchema?.useRichText)
// Determine the offset needed for full screen mode // Determine the offset needed for full screen mode
$: offset = $context.device.mobile ? "61px" : "137px" $: offset = $context.device.mobile ? "61px" : "137px"
@ -27,7 +34,7 @@
// itself based on the height of the rich text field. // itself based on the height of the rich text field.
let height let height
$: { $: {
height = $component.styles?.normal?.height height = $component.styles?.normal?.height || "150px"
newContext.set({ newContext.set({
...$component, ...$component,
styles: { styles: {
@ -50,8 +57,10 @@
type="longform" type="longform"
bind:fieldState bind:fieldState
bind:fieldApi bind:fieldApi
bind:fieldSchema
> >
{#if fieldState} {#if fieldState}
{#if useRichText}
<CoreRichTextField <CoreRichTextField
value={fieldState.value} value={fieldState.value}
on:change={e => fieldApi.setValue(e.detail)} on:change={e => fieldApi.setValue(e.detail)}
@ -65,5 +74,16 @@
hideIcons: $context.device.mobile ? ["side-by-side", "guide"] : [], hideIcons: $context.device.mobile ? ["side-by-side", "guide"] : [],
}} }}
/> />
{:else}
<CoreTextArea
value={fieldState.value}
on:change={e => fieldApi.setValue(e.detail)}
disabled={fieldState.disabled}
error={fieldState.error}
id={fieldState.fieldId}
{placeholder}
minHeight={height}
/>
{/if}
{/if} {/if}
</Field> </Field>