mirror of
https://github.com/Memo-2023/mana-monorepo.git
synced 2026-05-18 10:29:39 +02:00
Neuer Block-Type `formEmbed` im Website-Builder
(docs/plans/forms-module.md M8):
- @mana/website-blocks/src/formEmbed/:
- schema.ts: FormEmbedSchema mit token (32-char base64url) +
titleOverride + optional resolved-Block (formTitle, fields,
branching, settings.{submitButtonLabel, successMessage}).
FormFieldEmbedSchema duplicated leichtgewichtig statt cross-
package import — website-blocks bleibt self-contained.
- FormEmbed.svelte: edit/preview rendert Placeholder-Card mit
Token-Snippet und resolved-Status; public rendert die kompletten
11 Field-Types inkl. Live-Branching-aware-Render. Submitter-
Block (Name+Email optional). Submit POSTet an
/api/v1/forms/public/:token/submit. Lazy-Fallback fetcht
/api/v1/unlisted/public/:token wenn die publish-resolver-blob
fehlt. Bot-Honeypot bleibt M8-Polish.
- FormEmbedInspector.svelte: Token-Input mit base64url-Validierung
bei blur, optional titleOverride, resolved-Card mit
Field-Count + Logik-Regel-Count.
- BLOCK_SPECS + BLOCK_SCHEMAS + BLOCK_DEFAULTS um formEmbed
erweitert. schemas.test.ts erwartet jetzt 12 Block-Types.
- apps/mana/apps/web/src/lib/modules/website/forms-embeds.ts:
resolveFormEmbed scant formTable nach unlistedToken (linear scan
ist günstig bei <100 forms pro user, kein Index nötig), dekrypted,
validiert published-status, gibt resolved-Block zurück.
- publish.ts.resolveEmbedsInTree erweitert um formEmbed-Branch — ruft
resolveFormEmbed parallel zu resolveEmbed (moduleEmbed) im selben
Walk.
Trade-offs:
- Token statt formId: bei Token-Rotation (M4b) muss der User den Block
neu konfigurieren. Der formEmbed-Block-Resolver erkennt das + setzt
resolved.error; public-Renderer fällt auf lazy-fetch zurück.
- Plaintext stored: das resolved-Blob landet als plaintext im
public-snapshot, gleiches Trust-Modell wie moduleEmbed (öffentliche
Website per Definition).
Tests: website-blocks 50/50 grün (12 schema-block-types + per-type
defaults validation). svelte-check 0 errors. forms 26/26 unverändert.
Use-Case: Vereins-Sommerfest. User legt /forms/anmeldung an,
publisht, setzt unlisted, kopiert Token. Im Website-Builder fügt er
einen formEmbed-Block auf der Event-Seite ein, paste Token → bei
Publish wird der Form-Schema inlined → Besucher submitten direkt
auf der Vereins-Website.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
80 lines
1.7 KiB
TypeScript
80 lines
1.7 KiB
TypeScript
export type {
|
|
Block,
|
|
BlockMode,
|
|
BlockCategory,
|
|
BlockRenderProps,
|
|
BlockInspectorProps,
|
|
BlockSpec,
|
|
PropsOf,
|
|
InferProps,
|
|
} from './types';
|
|
|
|
export {
|
|
BLOCK_SPECS,
|
|
getBlockSpec,
|
|
requireBlockSpec,
|
|
getAllBlockSpecs,
|
|
validateBlockProps,
|
|
safeValidateBlockProps,
|
|
} from './registry';
|
|
|
|
export { heroBlockSpec, HeroSchema, HERO_DEFAULTS, type HeroProps } from './hero';
|
|
export {
|
|
richTextBlockSpec,
|
|
RichTextSchema,
|
|
RICH_TEXT_DEFAULTS,
|
|
type RichTextProps,
|
|
} from './richText';
|
|
export { spacerBlockSpec, SpacerSchema, SPACER_DEFAULTS, type SpacerProps } from './spacer';
|
|
export { imageBlockSpec, ImageSchema, IMAGE_DEFAULTS, type ImageProps } from './image';
|
|
export { ctaBlockSpec, CtaSchema, CTA_DEFAULTS, type CtaProps } from './cta';
|
|
export { faqBlockSpec, FaqSchema, FAQ_DEFAULTS, type FaqProps, type FaqItem } from './faq';
|
|
export {
|
|
columnsBlockSpec,
|
|
ColumnsSchema,
|
|
COLUMNS_DEFAULTS,
|
|
columnSlotKeys,
|
|
type ColumnsProps,
|
|
} from './columns';
|
|
export {
|
|
galleryBlockSpec,
|
|
GallerySchema,
|
|
GALLERY_DEFAULTS,
|
|
type GalleryProps,
|
|
type GalleryImage,
|
|
} from './gallery';
|
|
export { formBlockSpec, FormSchema, FORM_DEFAULTS, type FormProps, type FormField } from './form';
|
|
export {
|
|
formEmbedBlockSpec,
|
|
FormEmbedSchema,
|
|
FORM_EMBED_DEFAULTS,
|
|
type FormEmbedProps,
|
|
type FormEmbedField,
|
|
type FormEmbedBranching,
|
|
} from './formEmbed';
|
|
export {
|
|
moduleEmbedBlockSpec,
|
|
ModuleEmbedSchema,
|
|
MODULE_EMBED_DEFAULTS,
|
|
type ModuleEmbedProps,
|
|
type EmbedItem,
|
|
type EmbedSource,
|
|
} from './moduleEmbed';
|
|
export {
|
|
analyticsBlockSpec,
|
|
AnalyticsSchema,
|
|
ANALYTICS_DEFAULTS,
|
|
type AnalyticsProps,
|
|
} from './analytics';
|
|
|
|
export {
|
|
THEME_PRESETS,
|
|
PRESET_LABELS,
|
|
CLASSIC_LIGHT,
|
|
MODERN_DARK,
|
|
WARM,
|
|
resolveTheme,
|
|
themeCssVars,
|
|
type ThemeTokens,
|
|
type ThemePreset,
|
|
} from './themes';
|