定制 symkit/builder-bundle 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

symkit/builder-bundle

Composer 安装命令:

composer require symkit/builder-bundle

包简介

Visual Content Builder Bundle

README 文档

README

CI Latest Version PHPStan Level 9

A powerful, strategy-based block building system for Symfony applications. This bundle provides a flexible architecture for managing, editing, and rendering dynamic content blocks.

Features

  • Strategy Pattern Architecture: Extensible system where each block type is handled by a dedicated strategy.
  • Dual-View Rendering:
    • Editor: Complex, interactive templates (Twig + Stimulus + LiveComponents) for the admin interface.
    • Frontend: Lightweight, clean HTML structures defined in the database for performance and separation of concerns.
  • Markdown Import: Intelligent service to convert Markdown content into structured blocks, delegating logic to strategies.
  • Live Components Integration: Built-in support for Symfony UX Live Components for a rich editing experience.
  • 13 Built-in Block Types: paragraph, image, quote, table, list, code, infobox, cta, howto, separator, video, faq_block, and snippet.
  • 183 Tailwind CSS Snippets: Pre-built UI components across 32 categories, optionally loadable via sync command.

Documentation

Installation

  1. Require the bundle:

    composer require symkit/builder-bundle
  2. Enable the bundle (if not auto-enabled):

    // config/bundles.php
    return [
        // ...
        Symkit\BuilderBundle\SymkitBuilderBundle::class => ['all' => true],
    ];

Configuration

All features are enabled by default. You can override entity classes and toggle features in config/packages/symkit_builder.yaml:

symkit_builder:
    admin:
        enabled: true
        route_prefix: admin   # URL prefix for admin routes (default: admin)
    doctrine:
        enabled: true
        entity:
            block_class: Symkit\BuilderBundle\Entity\Block
            block_repository_class: Symkit\BuilderBundle\Repository\BlockRepository
            block_category_class: Symkit\BuilderBundle\Entity\BlockCategory
            block_category_repository_class: Symkit\BuilderBundle\Repository\BlockCategoryRepository
    twig:
        enabled: true
    assets:
        enabled: true
    command:
        enabled: true
    live_component:
        enabled: true

Routes

Include the bundle admin routes in your app (e.g. config/routes.yaml):

symkit_builder:
    resource: '@SymkitBuilderBundle/Resources/config/routing.yaml'
    prefix: '%symkit_builder.admin.route_prefix%'

This registers routes such as admin_block_list, admin_block_create, admin_block_edit, admin_block_category_*. Change route_prefix in config to alter the URL prefix (e.g. /back-office/blocks).

Dependencies

Ensure you have the following bundles enabled and configured:

  • Symfony\UX\LiveComponent\LiveComponentBundle
  • Symfony\UX\TwigComponent\TwigComponentBundle
  • Symfony\UX\StimulusBundle\StimulusBundle

Usage

1. Rendering Blocks

Two Twig functions are available for rendering blocks in your frontend templates.

Render a single block (accepts an array):

{# templates/page/show.html.twig #}

{% for block in page.content %}
    {{ symkit_render_block(block) }}
{% endfor %}

Render all blocks at once (accepts a JSON string or an array):

{{ symkit_render_content_blocks(page.content) }}

Or manually via the service:

use Symkit\BuilderBundle\Contract\BlockRendererInterface;

public function show(BlockRendererInterface $renderer, array $blocks)
{
    // Render a single block
    $html = $renderer->renderBlock($block);

    // Or render all blocks at once
    $html = $renderer->renderBlocks($blocks);
}

2. Synchronizing Blocks

Blocks are defined within the BlockSynchronizer service. To ensure your database is updated with the latest block definitions, run the synchronization command:

php bin/console builder:sync-blocks

To also include the 183 Tailwind CSS snippets:

php bin/console builder:sync-blocks --snippets

This command uses an idempotent "upsert" logic, updating existing blocks by their code and creating new ones as needed.

3. Built-in Block Types

The bundle ships with 13 core block types across 6 categories:

Category Block Type Description
text paragraph Rich text content (visual / HTML modes)
text quote Blockquote with optional author
media image Image via media manager
media video Embedded video (YouTube, etc.)
layout table Data table with optional header row
layout separator Horizontal rule (solid, dashed, dotted)
content list Ordered or unordered list
content code Syntax-highlighted code block
design infobox Highlighted info box (info, success, warning, error)
marketing cta Call-to-action with button and URL
marketing howto Step-by-step guide
marketing faq_block FAQ section (requires symkit/faq-bundle)
(snippets) snippet Pre-built Tailwind CSS component

4. Adding a New Block Type

To add a block type without custom logic, register it in BlockSynchronizer and use AbstractBlockStrategy as the default fallback. See How to Add a New Block Type for the full guide.

For complex blocks (e.g., fetching data, processing URLs), create a Strategy:

  1. Create a class implementing BlockStrategyInterface (or extending AbstractBlockStrategy).
  2. Implement supports(), prepareData(), render().
  3. Implement supportsNode() and createFromNode() for Markdown import support.
namespace App\Block\Strategy;

use Symkit\BuilderBundle\Render\Strategy\AbstractBlockStrategy;

class MyCustomBlockStrategy extends AbstractBlockStrategy
{
    public function supports(array $block): bool
    {
        return $block['type'] === 'my_custom_block';
    }

    // ... implement other methods
}

The service will be automatically tagged and used by the BlockRenderer.

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 2
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-02-22

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固