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 3b6128f33f
commit 2975e4a8f7
2 changed files with 56 additions and 15 deletions

View File

@ -2391,6 +2391,27 @@
"label": "Default value",
"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",
"label": "Disabled",

View File

@ -1,7 +1,7 @@
<script>
import { getContext, setContext } from "svelte"
import { writable } from "svelte/store"
import { CoreRichTextField } from "@budibase/bbui"
import { CoreRichTextField, CoreTextArea } from "@budibase/bbui"
import Field from "./Field.svelte"
export let field
@ -10,15 +10,22 @@
export let disabled = false
export let validation
export let defaultValue = ""
export let format = "auto"
let fieldState
let fieldApi
let fieldSchema
const context = getContext("context")
const component = getContext("component")
const newContext = writable($component)
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
$: offset = $context.device.mobile ? "61px" : "137px"
@ -27,7 +34,7 @@
// itself based on the height of the rich text field.
let height
$: {
height = $component.styles?.normal?.height
height = $component.styles?.normal?.height || "150px"
newContext.set({
...$component,
styles: {
@ -50,20 +57,33 @@
type="longform"
bind:fieldState
bind:fieldApi
bind:fieldSchema
>
{#if fieldState}
<CoreRichTextField
value={fieldState.value}
on:change={e => fieldApi.setValue(e.detail)}
disabled={fieldState.disabled}
error={fieldState.error}
id={fieldState.fieldId}
{placeholder}
{height}
fullScreenOffset={offset}
easyMDEOptions={{
hideIcons: $context.device.mobile ? ["side-by-side", "guide"] : [],
}}
/>
{#if useRichText}
<CoreRichTextField
value={fieldState.value}
on:change={e => fieldApi.setValue(e.detail)}
disabled={fieldState.disabled}
error={fieldState.error}
id={fieldState.fieldId}
{placeholder}
{height}
fullScreenOffset={offset}
easyMDEOptions={{
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}
</Field>