Skip to main content

HTML Widget

Overviewโ€‹

The HTML widget allows you to embed custom HTML content directly into your interface. This widget provides complete flexibility for displaying rich content, custom layouts, or integrating third-party HTML components while maintaining full control over styling and behavior.

HTML Widget

Basic Configurationโ€‹

Global Settingsโ€‹

Nameโ€‹

  • Field: Widget name identifier
  • Usage: Set a descriptive name for easy identification in the widget tree
  • Example: "Custom Header", "Product Description"

Variable/Modelโ€‹

  • Field: Model binding for the widget
  • Usage: Bind the widget to a data model or variable for dynamic content
  • Validation: The system validates model names and shows warnings for potential issues
HTML Basic Configuration

HTML Content Editorโ€‹

Edit HTML Buttonโ€‹

  • Location: Global section โ†’ Edit HTML
  • Function: Opens a code editor for writing custom HTML content
  • Features:
    • Syntax highlighting
    • Code completion
    • Error detection
    • Preview capabilities

Supported HTMLโ€‹

  • Standard HTML5 elements and attributes
  • Inline CSS styling
  • JavaScript integration (with platform security considerations)
  • Dynamic content using template variables

Template Variablesโ€‹

Access dynamic data within your HTML content:

HTML Template Variables

Validation Configurationโ€‹

Screen-Based Validationโ€‹

Configure widget behavior across different screens/contexts:

Availableโ€‹

  • Purpose: Controls whether the widget exists in the DOM
  • Options:
    • Boolean toggle (true/false)
    • Advanced condition using JavaScript expressions

Visibleโ€‹

  • Purpose: Controls widget visibility (display/hide)
  • Options:
    • Boolean toggle
    • Advanced condition with template variables
  • Advanced Example: userRole == 'admin'

Requiredโ€‹

  • Purpose: Makes the widget mandatory for form validation
  • Note: Primarily used when HTML widget contains form elements
  • Options: Boolean or conditional expression

Disableโ€‹

  • Purpose: Disables interactive elements within the widget
  • Options: Boolean or conditional expression
HTML Screen-Based Validation

Style Configurationโ€‹

  • Field: Class names
  • Usage: Apply predefined CSS classes
  • Format: Space-separated class names
HTML Style

Widget Template Structureโ€‹

Generated Componentโ€‹

The widget generates a Vue.js component with:

  • Unique component ID
  • Reactive data binding
  • Conditional rendering
  • Event handling capabilities

DOM Structureโ€‹

<div
id="[widgetId]"
v-if="[visibilityCondition]"
class="[staticClasses]"
:class="[dynamicClasses]"
>
<!-- Your custom HTML content -->
</div>

Integration Examplesโ€‹

Basic HTML Contentโ€‹

<div class="custom-section">
<h2>Welcome {{SF_connectedUser.firstName}}</h2>
<p>Last login: {{models.lastLogin }}</p>
</div>

Interactive Elementsโ€‹

<div class="interactive-widget" style="display: flex; align-items: center; gap: 12px;">
<el-button type="primary" size="large" @click="customFunction">
Click
</el-button>

<el-input v-model="models.inputValue" placeholder="Enter text" clearable style="max-width: 220px;" />
</div>

Conditional Contentโ€‹

<div v-if="models.isAdmin">
<h3>Admin Panel</h3>
<div class="admin-controls">
<!-- Admin-specific content -->
</div>
</div>

Best Practicesโ€‹

Security Considerationsโ€‹

  • Sanitize user-generated content
  • Avoid inline JavaScript in production
  • Use platform-provided security features
  • Validate all dynamic data

Performance Optimizationโ€‹

  • Minimize DOM complexity
  • Use efficient CSS selectors
  • Implement lazy loading for heavy content
  • Optimize images and media

Accessibilityโ€‹

  • Include proper ARIA attributes
  • Ensure keyboard navigation support
  • Provide alternative text for images
  • Maintain proper heading hierarchy

Maintainabilityโ€‹

  • Use semantic HTML structure
  • Comment complex functionality
  • Follow consistent naming conventions
  • Separate concerns (structure, style, behavior)

Troubleshootingโ€‹

Common Issuesโ€‹

Widget Not Displayingโ€‹

  • Check visibility conditions
  • Verify model bindings
  • Ensure proper HTML syntax
  • Review browser console for errors

Styling Problemsโ€‹

  • Verify CSS class names
  • Check for conflicting styles
  • Ensure responsive design compatibility
  • Test across different screen sizes

Dynamic Content Not Updatingโ€‹

  • Confirm model binding syntax
  • Check for reactivity issues
  • Verify data source connections
  • Review JavaScript console errors

Debug Modeโ€‹

Enable debug mode to:

  • View generated component structure
  • Monitor data binding updates
  • Track validation rule execution
  • Inspect DOM changes

Advanced Featuresโ€‹

Form Integrationโ€‹

Include form elements that integrate with the platform's form system:

<div class="form-section">
<label for="customField">Custom Input:</label>
<el-input
id="customField"
v-model="model.customField"
placeholder="Enter value"
clearable
></el-input>
</div>

This HTML widget provides maximum flexibility while maintaining integration with the platform's validation, styling, and data binding systems. Use it when standard widgets don't meet your specific requirements or when you need complete control over the presentation layer.