Skip to content

Commit

Permalink
feat: add textarea property to allow additional textarea properties
Browse files Browse the repository at this point in the history
fix #26
  • Loading branch information
BearToCode committed Dec 9, 2023
1 parent 4075b8a commit 661cd13
Show file tree
Hide file tree
Showing 5 changed files with 53 additions and 2 deletions.
8 changes: 8 additions & 0 deletions docs/src/pages/api/core.svelte.md
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,14 @@ Type: `string`

Set the textarea placeholder.

### `textarea`

Type: `TextAreaProps` (extends `Record<string, unknown>`)

Additional properties that will be used in the textarea used under the hood in the editor.
`class`, `placeholder` and `value` are not allowed. Use the corresponding editor properties
instead.

# `CartaViewer` options

List of options that can be used in the `<CartaViewer>` component.
Expand Down
3 changes: 3 additions & 0 deletions packages/carta-md/src/lib/CartaEditor.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
import CartaRenderer from './internal/components/CartaRenderer.svelte';
import MarkdownInput from './internal/components/MarkdownInput.svelte';
import { debounce } from './internal/utils';
import type { TextAreaProps } from './internal/textarea-props';
export let carta: Carta;
export let theme = 'default';
Expand All @@ -12,6 +13,7 @@
export let scroll: 'sync' | 'async' = 'sync';
export let disableToolbar = false;
export let placeholder = '';
export let textarea: TextAreaProps = {};
let width: number;
let selectedTab: 'write' | 'preview' = 'write';
Expand Down Expand Up @@ -134,6 +136,7 @@
{carta}
{placeholder}
{handleScroll}
props={textarea}
bind:value
bind:resize={resizeInput}
bind:elem={inputElem}
Expand Down
1 change: 1 addition & 0 deletions packages/carta-md/src/lib/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,5 +6,6 @@ export type { KeyboardShortcut } from '$lib/internal/shortcuts';
export type { Prefix } from '$lib/internal/prefixes';
export * from '$lib/internal/carta';
export * from '$lib/internal/highlight';
export * from '$lib/internal/textarea-props';
export * from './default.css?inline';
export * from './light.css?inline';
Original file line number Diff line number Diff line change
@@ -1,12 +1,14 @@
<script lang="ts">
import type { Carta } from '../carta';
import { onMount } from 'svelte';
import type { Carta } from '../carta';
import type { TextAreaProps } from '../textarea-props';
export let carta: Carta;
export let value = '';
export let placeholder = '';
export let elem: HTMLDivElement;
export let handleScroll: (e: UIEvent) => void;
export let props: TextAreaProps = {};
let textarea: HTMLTextAreaElement;
let highlighElem: HTMLPreElement;
Expand Down Expand Up @@ -62,6 +64,7 @@
spellcheck="false"
class="carta-font-code"
{placeholder}
{...props}
bind:value
bind:this={textarea}
on:scroll={() => (textarea.scrollTop = 0)}
Expand All @@ -84,7 +87,7 @@
font-family: monospace;
}
textarea#md {
textarea {
position: relative;
width: 100%;
max-width: 100%;
Expand Down
36 changes: 36 additions & 0 deletions packages/carta-md/src/lib/internal/textarea-props.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
/**
* Base props for HTML textarea element.
*/
interface BaseTextAreaProps {
id?: string;
name?: string;
spellCheck?: boolean;
autoCapitalize?: string;
autoComplete?: string;
autoFocus?: boolean;
dirname?: string;
disabled?: boolean;
form?: string;
maxLength?: number;
minLength?: number;
required?: boolean;
spellcheck?: boolean;

// Props handled by Carta

/**
* Bind the value to the Editor instead.
*/
value?: never;
/**
* Use the placeholder property of the Editor instead.
*/
placeholder?: never;
class?: never;
}

/**
* Props for HTML textarea element.
*/
export type TextAreaProps<T extends Record<string, unknown> = Record<string, unknown>> =
BaseTextAreaProps & T;

0 comments on commit 661cd13

Please sign in to comment.