提问者:小点点

如何在EasyAdminBundle中设置自定义表单/页面


我已经能够使用Symfony EasyAdminBundle为一个项目构建一个简单的CRUD应用程序,它对于基于实体的正常用例非常有效。我还有一些额外的用例,我想在这些用例中做一些事情,比如重建数据。对于这些,我必须捕获某些请求属性,传递给控制器,然后委托给远程服务的后端API调用。

这一切都可以在Symfony中完成,但我遇到了如何将其连接到EasyAdmin视图/工作方法的问题。理想情况下,我希望这是easy admin中的一个页面,而不会丢失左侧菜单等。到目前为止,我发现的唯一方法是创建一个模型类,该类使用现有表之一,但只有一些属性需要驱动到API中。然后,我重写控制器操作,以便根据该远程API进行处理,而不是执行默认保存。

这种方法的问题是,很明显,我现在绑定到了条令实体,这对于无法映射到数据库的请求来说是有问题的。

有没有一种方法可以定义一个逻辑实体,使我能够利用关联,以便进行查找等,从而无缝地连接到捆绑包中,但实际上不绑定到后端数据库表或视图?


共3个答案

匿名用户

我补充了我对未来可能仍然面临这个问题的人的回应。我如何在不创建实体的情况下解决这个问题:

>

编辑控制器视图以继承EasyAdmin布局:

{# ./src/templates/home/index.html.twig #}
{% extends '@EasyAdmin/Default/layout.html.twig' %}

{# Let\'s remove/empty the header #}
{% block content_header_wrapper %} {% endblock content_header_wrapper %}

{# The main page content block #}
{% block main %}
   **PUT YOUR CODE HERE**
{% endblock main %}

{# Let\'s remove/empty the footer #}
{% block content_footer_wrapper %} {% endblock content_footer_wrapper %}
  • 将您的页面添加到侧边导航
design:
      menu:
        - {route: 'home', label: 'Home', default: true, icon: 'home'}
        - {entity: 'MyEntity', label: 'My Relevant Entity', icon: 'briefcase'}

匿名用户

我将解决这个问题,创建一个自定义操作(可能您需要基于路由的操作),然后使用从@EasyAdmin\default\layout扩展的模板。html。twig或任何其他类似于您想要实现的默认模板。

匿名用户

以下是解决方案:

{# easy_admin/form.html.twig #}
{% block _product_custom_title_widget %}
    {# ... #}
    <a href="...">More information</a>
{% endblock %}

最后,将此自定义主题添加到用于呈现后端表单的主题列表中:

easy_admin:
    # ...
    design:
        form_theme:
            - 'horizontal'
            # the following Twig template can be located anywhere in the application.
            # it can also be added to the twig.form_themes option to use it in the
            # entire application, not only the backend
            - 'easy_admin/form.html.twig'

以下是有关更多信息的链接:https://symfony.com/doc/master/bundles/EasyAdminBundle/book/edit-new-configuration.html

Easyadmin是一个捆绑包,您可以自定义任何捆绑包的所有页面。

此逻辑适用于包中的任何模板:只需遵循以下约定:app/Resources/{BUNDLE_NAME}/view/{PATH/TO/TEMPLATE.html.twig}。

假设您在项目中安装了一个虚构的开源AcmeBlogBundle。虽然您对一切都很满意,但您希望覆盖博客列表页面的模板。在捆绑包中,要覆盖的模板位于Resources/views/Blog/index。html。细枝

要覆盖捆绑包模板,只需复制索引即可。html。从捆绑包到app/Resources/AcmeBlogBundle/views/Blog/index的细枝模板。html。twig(app/Resources/AcmeBlogBundle目录将不存在,因此您需要创建它)。您现在可以自由自定义模板。

参考:https://symfony.com/doc/3.4/templating/overriding.html