opnform-host-nginx/client/lib/forms/FormModeStrategy.js

90 lines
2.8 KiB
JavaScript
Raw Normal View History

Decouple title from title block (#696) * Decouple title from title block * fix lint * remove dry run for FormTitleMigration * Skip form title migration for forms with hidden titles * Refactor AI Form Generation with Dedicated Prompt Services - Extract AI form generation logic from GenerateTemplate command into dedicated prompt service classes - Update GenerateAiForm job to use new prompt generation services - Improve GptCompleter with more robust error handling and token tracking - Add error field to AiFormCompletion model for better error logging - Simplify command signature from 'ai:make-form-template' to 'form:generate' * Consolidate Template Metadata Generation with Unified Prompt Service - Create GenerateTemplateMetadataPrompt to centralize template metadata generation - Update GenerateTemplate command to use new consolidated metadata generation approach - Enhance GptCompleter to support strict JSON schema validation - Increase form prompt max length to support more complex form descriptions - Refactor form generation to simplify metadata extraction and processing * Implement Form Mode Strategy for Flexible Form Rendering - Introduce FormModeStrategy to centralize form rendering logic - Add support for different form modes: LIVE, PREVIEW, TEST, EDIT, PREFILL - Refactor components to use mode-based rendering strategy - Remove legacy boolean props like adminPreview and creating - Enhance form component flexibility and reusability * Refine Form Mode Strategy Display Behavior - Update FormModeStrategy to hide hidden fields in PREVIEW mode - Add FormMode getter in UrlFormPrefill component for mode-specific rendering - Clarify mode-specific validation and display logic in form strategies * Enhance Form Template Generation with Advanced Field Options - Update GenerateTemplate command to use front_url for template URL output - Expand GenerateFormPrompt with comprehensive field configuration options - Add support for advanced field types: date with time, toggle switches, radio/checkbox selections - Introduce field width configuration and HTML formatting for text elements - Re-enable select, multi-select, and matrix field type definitions with enhanced configurations * Remove Deprecated Template Metadata Generation Services - Delete multiple AI prompt services related to template metadata generation - Simplify GenerateTemplate command to use default values instead of complex metadata generation - Remove GenerateTemplateMetadataPrompt and related classes like GenerateTemplateDescriptionPrompt, GenerateTemplateImageKeywordsPrompt, etc. - Update form template generation to use basic fallback metadata generation approach * Restore GenerateTemplateMetadataPrompt for Comprehensive Template Generation - Reintroduce GenerateTemplateMetadataPrompt to replace default metadata generation - Update GenerateTemplate command to use consolidated metadata generation approach - Extract detailed metadata components including title, description, industries, and image search query - Improve template generation with more dynamic and AI-generated metadata * Refactor Template Preview Section Layout - Remove unnecessary nested div in template preview section - Simplify HTML structure for the template preview component - Maintain existing styling and functionality while improving code readability * Refactor Constructor and Code Formatting in AI Form Generation and Prompt Classes - Updated the constructor in GenerateAiForm.php to use a block structure for improved readability and consistency. - Added a blank line in the Prompt.php file to enhance code formatting and maintain consistency with PHP coding standards. - Modified the migration file to use a more concise class declaration syntax, improving clarity. These changes aim to enhance code readability and maintainability across the affected files. --------- Co-authored-by: Julien Nahum <julien@nahum.net>
2025-03-21 16:59:18 +01:00
/**
* Form modes for OpenForm components
*/
export const FormMode = {
LIVE: 'live', // Real form with full validation and submission
PREVIEW: 'preview', // Admin preview with no validation
PREFILL: 'prefill', // URL prefill preview with no validation
EDIT: 'edit', // Editing an existing submission
TEST: 'test' // Test mode with validation but no actual submission
}
/**
* Creates a comprehensive strategy based on the form mode
* This handles all mode-specific behaviors, not just validation
*
* @param {string} mode - One of the FormMode values
* @returns {Object} - Strategy object with all mode-specific behaviors
*/
export function createFormModeStrategy(mode) {
// Default configuration (LIVE mode)
const defaultStrategy = {
// Validation behaviors
validation: {
validateOnNextPage: true,
validateOnSubmit: true,
performActualSubmission: true
},
// Display behaviors
display: {
showHiddenFields: false,
showFormCleanings: true,
showFontLink: false
},
// Admin behaviors
admin: {
allowDragging: false,
showAdminControls: false,
}
}
// Return default strategy for LIVE mode or unknown modes
if (mode === FormMode.LIVE || !Object.values(FormMode).includes(mode)) {
return defaultStrategy
}
// Create a copy of the default strategy to modify
const strategy = JSON.parse(JSON.stringify(defaultStrategy))
// Apply mode-specific overrides
switch (mode) {
case FormMode.PREVIEW:
// Admin preview - no validation, show admin controls but NOT hidden fields
strategy.validation.validateOnNextPage = false
strategy.validation.validateOnSubmit = false
strategy.validation.performActualSubmission = false
strategy.display.showHiddenFields = false
strategy.display.showFormCleanings = false
strategy.display.showFontLink = true
strategy.admin.allowDragging = true
strategy.admin.showAdminControls = true
break
case FormMode.PREFILL:
// URL prefill - no validation, show hidden fields
strategy.validation.validateOnNextPage = false
strategy.validation.validateOnSubmit = false
strategy.validation.performActualSubmission = false
strategy.display.showHiddenFields = true
break
case FormMode.EDIT:
// Editing submission - same validation as LIVE mode, but show hidden fields
// This ensures edit mode behaves like live mode for validation
strategy.display.showHiddenFields = true
break
case FormMode.TEST:
// Test mode - validate on submit but don't submit, and don't validate on next page
strategy.validation.performActualSubmission = false
strategy.validation.validateOnNextPage = false
break
}
return strategy
}