@dmitryvim/form-builder 0.2.18 → 0.2.19
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +57 -0
- package/dist/browser/formbuilder.min.js +142 -80
- package/dist/browser/formbuilder.v0.2.19.min.js +448 -0
- package/dist/cjs/index.cjs +1042 -2
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/esm/index.js +1024 -2
- package/dist/esm/index.js.map +1 -1
- package/dist/form-builder.js +142 -80
- package/dist/types/components/index.d.ts +2 -1
- package/dist/types/components/table.d.ts +4 -0
- package/dist/types/types/config.d.ts +6 -0
- package/dist/types/types/index.d.ts +1 -1
- package/dist/types/types/schema.d.ts +28 -1
- package/package.json +1 -1
- package/dist/browser/formbuilder.v0.2.18.min.js +0 -386
|
@@ -9,6 +9,7 @@ import { renderColourElement, renderMultipleColourElement } from "./colour.js";
|
|
|
9
9
|
import { renderSliderElement, renderMultipleSliderElement } from "./slider.js";
|
|
10
10
|
import { renderSingleContainerElement, renderMultipleContainerElement, setValidateElement as setContainerValidateElement } from "./container.js";
|
|
11
11
|
import { renderGroupElement } from "./group.js";
|
|
12
|
+
import { renderTableElement } from "./table.js";
|
|
12
13
|
export declare function renderElement(element: Element, ctx: RenderContext): HTMLElement;
|
|
13
14
|
export { setContainerValidateElement };
|
|
14
|
-
export { renderTextElement, renderMultipleTextElement, renderTextareaElement, renderMultipleTextareaElement, renderNumberElement, renderMultipleNumberElement, renderSelectElement, renderMultipleSelectElement, renderSwitcherElement, renderMultipleSwitcherElement, renderFileElement, renderFilesElement, renderMultipleFileElement, renderColourElement, renderMultipleColourElement, renderSliderElement, renderMultipleSliderElement, renderSingleContainerElement, renderMultipleContainerElement, renderGroupElement, };
|
|
15
|
+
export { renderTextElement, renderMultipleTextElement, renderTextareaElement, renderMultipleTextareaElement, renderNumberElement, renderMultipleNumberElement, renderSelectElement, renderMultipleSelectElement, renderSwitcherElement, renderMultipleSwitcherElement, renderFileElement, renderFilesElement, renderMultipleFileElement, renderColourElement, renderMultipleColourElement, renderSliderElement, renderMultipleSliderElement, renderSingleContainerElement, renderMultipleContainerElement, renderGroupElement, renderTableElement, };
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { TableElement, RenderContext, ComponentContext, ValidationResult } from "../types/index.js";
|
|
2
|
+
export declare function renderTableElement(element: TableElement, ctx: RenderContext, wrapper: HTMLElement, pathKey: string): void;
|
|
3
|
+
export declare function validateTableElement(element: TableElement, key: string, context: ComponentContext): ValidationResult;
|
|
4
|
+
export declare function updateTableField(_element: TableElement, fieldPath: string, value: unknown, context: ComponentContext): void;
|
|
@@ -41,6 +41,12 @@ export interface Translations {
|
|
|
41
41
|
maxFiles: string;
|
|
42
42
|
unsupportedFieldType: string;
|
|
43
43
|
invalidOption: string;
|
|
44
|
+
tableAddRow: string;
|
|
45
|
+
tableAddColumn: string;
|
|
46
|
+
tableRemoveRow: string;
|
|
47
|
+
tableRemoveColumn: string;
|
|
48
|
+
tableMergeCells: string;
|
|
49
|
+
tableSplitCell: string;
|
|
44
50
|
}
|
|
45
51
|
export type Locale = "en" | "ru" | (string & {});
|
|
46
52
|
export interface Config {
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export type { SelectOption, ElementAction, EnableCondition, BaseElement, TextElement, TextareaElement, NumberElement, SelectElement, SwitcherElement, FileElement, FilesElement, ColourElement, SliderElement, ContainerElement, GroupElement, Element, Schema, ExternalAction, FormData, RenderContext, } from "./schema.js";
|
|
1
|
+
export type { SelectOption, ElementAction, EnableCondition, BaseElement, TextElement, TextareaElement, NumberElement, SelectElement, SwitcherElement, FileElement, FilesElement, ColourElement, SliderElement, ContainerElement, GroupElement, TableElement, TableMerge, TableData, Element, Schema, ExternalAction, FormData, RenderContext, } from "./schema.js";
|
|
2
2
|
export type { Translations, Locale, Config, ResourceMetadata, } from "./config.js";
|
|
3
3
|
export type { State } from "./state.js";
|
|
4
4
|
export type { ComponentContext, ValidationResult, ComponentValidator, ComponentUpdater, ComponentOperations, } from "./component-operations.js";
|
|
@@ -135,7 +135,34 @@ export interface GroupElement extends BaseElement {
|
|
|
135
135
|
max?: number;
|
|
136
136
|
};
|
|
137
137
|
}
|
|
138
|
-
|
|
138
|
+
/**
|
|
139
|
+
* A single cell merge region in the table
|
|
140
|
+
*/
|
|
141
|
+
export interface TableMerge {
|
|
142
|
+
/** Row index of the top-left cell (0-based) */
|
|
143
|
+
row: number;
|
|
144
|
+
/** Column index of the top-left cell (0-based) */
|
|
145
|
+
col: number;
|
|
146
|
+
/** Number of rows spanned (>= 1) */
|
|
147
|
+
rowspan: number;
|
|
148
|
+
/** Number of columns spanned (>= 1) */
|
|
149
|
+
colspan: number;
|
|
150
|
+
}
|
|
151
|
+
/**
|
|
152
|
+
* Table data structure stored as form data
|
|
153
|
+
*/
|
|
154
|
+
export interface TableData {
|
|
155
|
+
cells: string[][];
|
|
156
|
+
merges?: TableMerge[];
|
|
157
|
+
}
|
|
158
|
+
export interface TableElement extends BaseElement {
|
|
159
|
+
type: "table";
|
|
160
|
+
/** Initial column count (default: 3) */
|
|
161
|
+
columns?: number;
|
|
162
|
+
/** Initial row count (default: 3) */
|
|
163
|
+
rows?: number;
|
|
164
|
+
}
|
|
165
|
+
export type Element = TextElement | TextareaElement | NumberElement | SelectElement | SwitcherElement | FileElement | FilesElement | ColourElement | SliderElement | ContainerElement | GroupElement | TableElement;
|
|
139
166
|
export interface Schema {
|
|
140
167
|
version?: string;
|
|
141
168
|
elements: Element[];
|