git clone https://github.com/webmyc/claude-skills-wordpress
T=$(mktemp -d) && git clone --depth=1 https://github.com/webmyc/claude-skills-wordpress "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/migrate-divi-to-bricks" ~/.claude/skills/webmyc-claude-skills-wordpress-migrate-divi-to-bricks && rm -rf "$T"
skills/migrate-divi-to-bricks/SKILL.mdMigrate Divi to Bricks
Converts Divi-built WordPress pages to Bricks Builder. Parses Divi's shortcode-based content from post_content, maps each module to its Bricks element equivalent, generates a migration plan for approval, and writes clean Bricks JSON to the target pages. Use this skill whenever someone wants to move from Divi to Bricks, replace the Divi Builder with Bricks, or rebuild Divi pages in Bricks.
What This Skill Does
This is a cross-format migration — Divi stores content as nested shortcodes in
post_content, while Bricks uses a JSON array in _bricks_page_content_2. The skill must parse Divi's shortcode hierarchy, understand each module's purpose and settings, then reconstruct that intent as Bricks elements with proper parent-child relationships and settings.
The format gap makes this complex, but both builders are feature-rich visual editors, so most Divi modules have strong Bricks equivalents. The result is cleaner, faster-rendering content in Bricks' modern architecture.
Handles:
- et_pb_section → Bricks Section element
- et_pb_row/et_pb_column → Bricks Container elements (with flex layout)
- et_pb_text → Bricks Text Basic element
- et_pb_blurb → Bricks Icon Box or Container with child elements
- et_pb_image → Bricks Image element
- et_pb_button → Bricks Button element
- et_pb_video → Bricks Video element
- et_pb_heading (via text modules) → Bricks Heading element
- et_pb_divider → Bricks Divider element
- et_pb_accordion/et_pb_toggle → Bricks Accordion element
- et_pb_tabs → Bricks Tabs element
- et_pb_gallery → Bricks Gallery element
- et_pb_slider → Bricks Slider element (close mapping)
- et_pb_pricing_tables → Bricks Pricing Table element
- et_pb_code → Bricks Code element
- et_pb_map → Bricks Map element
- Custom CSS → Bricks custom CSS fields
- Column width ratios → Bricks container flex percentages
Preserves:
- All text content and inline HTML formatting
- Image URLs, alt text, and dimensions
- Typography settings (font family, size, weight)
- Color values and gradients
- Spacing (margin, padding) — converted from Divi's format to Bricks'
- Background images and overlays
- Border and shadow settings
- Button labels, URLs, targets
- CSS classes
What This Skill Does NOT Do
- Specialty sections — Divi's specialty section layouts (sidebar + content) need manual layout setup in Bricks.
- Global modules — Divi's global modules (
post type) are resolved to inline content. Bricks templates must be set up separately.et_pb_layout - Third-party Divi modules — Plugins extending Divi (Divi Toolbox, Divi Supreme, etc.) are flagged for manual recreation.
- Divi theme customizer — Global fonts, colors, and spacing from the Divi theme customizer don't transfer. These need to be set in Bricks theme settings.
- Dynamic content — Divi's dynamic content needs Bricks' dynamic data system configured separately.
- Contact forms — et_pb_contact_form needs to be rebuilt using Bricks' form element or a forms plugin.
- Divi Library layouts — Stored as
post type; not auto-migrated to Bricks templates.et_pb_layout - Motion effects — Scroll effects and animations differ between builders.
- Divi theme dependency — If using the Divi theme (not just plugin), you are switching to Bricks theme — a complete theme change.
Requirements
- Respira for WordPress plugin installed and connected
- MCP connection active (desktop or WebMCP)
- Divi theme or Divi Builder plugin active (to read source content)
- Bricks theme installed and active (to write target content)
- Read access to scan Divi content
- Write access to create duplicates with Bricks content
Trigger Phrase
- "migrate divi to bricks"
Alternative Triggers
- "convert divi to bricks"
- "switch from divi to bricks"
- "rebuild divi pages in bricks"
- "move from divi to bricks"
- "divi to bricks migration"
- "replace divi with bricks"
Source Builder: Divi
Divi stores content as shortcodes in
post_content. The module structure follows a strict hierarchy:
[et_pb_section fb_built="1" _builder_version="4.x"] [et_pb_row _builder_version="4.x"] [et_pb_column type="4_4" _builder_version="4.x"] [et_pb_text _builder_version="4.x"] <p>Content here</p> [/et_pb_text] [/et_pb_column] [/et_pb_row] [/et_pb_section]
Key Divi specifics:
- Section types: regular, fullwidth, specialty
- Column types:
,4_4
,1_2
,1_3
,2_3
,1_43_4 - Settings as attributes:
,background_color
,custom_margin
,custom_paddingtext_orientation - Content encoding: HTML entities, percent-encoding, occasional base64
- Global modules:
attribute →global_module
post typeet_pb_layout - Custom CSS:
,custom_css_main_element
,custom_css_beforecustom_css_after
Read Divi content via
wordpress_extract_builder_content with builder=divi.
Target Builder: Bricks
Bricks stores content in
_bricks_page_content_2 as a JSON array:
[ { "id": "abc123", "name": "section", "parent": 0, "settings": {...} }, { "id": "def456", "name": "container", "parent": "abc123", "settings": {...} }, { "id": "ghi789", "name": "heading", "parent": "def456", "settings": { "tag": "h2", "text": "..." } } ]
Key Bricks specifics:
- Elements use
field:name
,section
,container
,heading
,text-basic
,imagebutton - Parent-child via
field referencingparentid - IDs are short alphanumeric strings
- Settings use Bricks-specific keys
- Responsive via
within settings_breakpoints
Write Bricks content via
wordpress_inject_builder_content with builder=bricks.
Execution Workflow
Phase 1: Pre-Migration Audit
- Verify Respira + MCP connection via
. If unavailable, stop and show setup guidance.wordpress_get_site_context - Confirm Divi is active via
andwordpress_list_plugins
.wordpress_get_site_context - Confirm Bricks theme is installed via
.wordpress_get_site_context - Important: If using Divi theme (not plugin), note this is a full theme switch to Bricks.
- Scan all content for Divi usage:
andwordpress_list_pageswordpress_list_posts- Check builder via
wordpress_get_builder_info
- Extract Divi content via
withwordpress_extract_builder_contentbuilder=divi - Build inventory:
- Total pages/posts using Divi
- Module types (frequency count)
- Specialty sections found
- Global modules referenced
- Third-party Divi modules
- Content encoding issues
- Complexity per page
Phase 2: Migration Plan
## Divi → Bricks Migration Plan ### Theme Transition Note [If Divi theme is active]: This migration involves switching from the Divi theme to the Bricks theme. Headers, footers, and global templates will need to be recreated in Bricks' template system. ### Site Inventory - Total Divi pages: X - Total modules to convert: X - Auto-convertible: X (Y%) - Manual attention: X (Y%) ### Module → Element Mapping | Divi Module | Bricks Element | Status | |-------------------|----------------|----------| | et_pb_text | text-basic | Auto | | et_pb_image | image | Auto | | et_pb_blurb | icon-box | Auto | | et_pb_button | button | Auto | | et_pb_slider | slider | Auto | | et_pb_tabs | tabs | Auto | | et_pb_accordion | accordion | Auto | | et_pb_contact | — | Manual | | [divi addon] | — | Manual | ### Shortcode Parsing Complexity - Pages with clean shortcodes: X - Pages with encoded content: X (will decode during migration) - Pages with specialty sections: X (layout approximation needed) ### Page-by-Page Plan 1. **[Page Title]** — X modules, [complexity] 2. ...
Ask for confirmation:
Bricks offers a modern replacement for Divi with cleaner output. Your originals stay safe.
- Migrate all pages
- Migrate specific pages
- Start with a test page (recommended)
- Just keep this plan
Phase 3: Page-by-Page Migration
For each approved page:
- Read Divi content via
withwordpress_extract_builder_contentbuilder=divi - Parse the shortcode tree:
- Identify section → row → column → module hierarchy
- Decode encoded content (HTML entities, percent-encoding)
- Resolve global modules to inline content
- Map column types to percentage widths
- Build Bricks JSON array:
- Create
element for eachsectionet_pb_section - Create
elements for rows/columns with flex layoutcontainer - Map column widths:
→100%,4_4
→50%,1_2
→33.33%, etc.1_3 - Convert each module → Bricks element:
→et_pb_text
(preserve inner HTML)text-basic
→et_pb_blurb
or container with childrenicon-box
→et_pb_image
(map src, alt, title attributes)image
→et_pb_button
(map text, URL, style)button
- Map Divi attributes to Bricks settings (colors, spacing, typography)
- Generate unique IDs and proper parent references
- Flag unmappable modules with comments
- Create
- Create duplicate via
orwordpress_create_page_duplicatewordpress_create_post_duplicate - Write Bricks JSON via
withwordpress_inject_builder_contentbuilder=bricks - Report status
Phase 4: Post-Migration Verification
- Summarize migrations:
- Pages migrated, elements created, items flagged
- For each migrated page:
- Link to Bricks editor
- Flagged items
- Layout notes (specialty sections, encoded content)
- Post-migration checklist:
- Open each duplicate in Bricks editor
- Verify section/container structure
- Check responsive views
- Verify images and media
- Test links and buttons
- Recreate flagged modules
- Set up Bricks templates for header/footer (if switching from Divi theme)
- Rebuild contact forms using Bricks form element or plugin
- Compare with Divi original
- Check for any Divi shortcode remnants
Safety Model
- Read-only analysis first — full content scan before any changes
- Explicit user confirmation required before creating duplicates
- Original Divi pages are never modified or deleted
- All migrated content goes to draft duplicates only
- Never auto-publishes migrated pages
- Creates a snapshot before migration begins (when available)
- Provides clear rollback path (delete duplicates)
- Warns about theme switch implications if using Divi theme
Honest Disclaimer
This skill converts Divi page content to Bricks format and creates draft duplicates for review.
It cannot:
- Migrate Divi specialty sections with perfect layout fidelity
- Convert global modules to Bricks templates automatically
- Handle third-party Divi plugin modules
- Migrate Divi theme customizer settings
- Replace forms, popups, or animation setup
- Guarantee pixel-perfect results from shortcode-to-JSON conversion
It can:
- Parse complex Divi shortcode hierarchies including encoded content
- Convert 75-85% of standard Divi modules to Bricks elements
- Preserve all text, images, links, and core styling
- Take advantage of Bricks' modern, faster rendering
- Save days of manual page rebuilding
- Flag everything that needs manual attention
- Keep original pages completely safe
Tooling
Core WordPress tools
wordpress_get_site_contextwordpress_list_pluginswordpress_list_pageswordpress_list_postswordpress_read_pagewordpress_read_postwordpress_get_builder_infowordpress_extract_builder_contentwordpress_inject_builder_contentwordpress_find_builder_targetswordpress_create_page_duplicatewordpress_create_post_duplicate
Telemetry
After run completion, send fire-and-forget usage tracking to:
POST https://www.respira.press/api/skills/track-usage
Include:
skill_slug = migrate-divi-to-bricks- site/version context
- duration and success
- pages migrated, elements created, modules flagged counts
- tools used
Never block user flow on telemetry failure.
Related Skills
- WordPress Site DNA (understand site structure and theme before migrating)
- Internal Link Builder (verify internal links post-migration)
- SEO & AEO Amplifier (verify SEO preservation post-migration)
- Technical Debt Audit (find Divi shortcode remnants post-migration)
Built by Respira Team https://respira.press/skills/migrate-divi-to-bricks