自定义symfony数据原型以进行编辑

时间:2019-02-01 08:59:23

标签: symfony

我知道这是一个普遍的问题,但是我不知道该如何实现。

我有一个Course实体和一个CourseDocument实体。

Course(id, documents, ...) 
CourseDocument(id, file, course)

在我的课程表中:

class CourseType extends AbstractType
{
    /**
     * @param FormBuilderInterface $builder
     * @param array $options
     */
    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder
            ->add('title', TextType::class, [
                'label' => 'course.title',
            ])            
            ->add('documents', CollectionType::class, array(
                'entry_type' => MediaType::class,
                'label' => 'course.documents_list',
                'entry_options' => array(
                    'label' => false,
                    'data_class' => CourseDocument::class,
                ),
                'allow_add' => true,
                'allow_delete' => true,
                'by_reference' => false,
            ))
        ;
    }

在表单中,我希望能够添加任意数量的文档。我设置了所有内容,包括javascript。我唯一的问题是我不需要的数据原型。

{% import "macros/prototype.html.twig" as prototype %}

{{ form_start(form) }}
    <div class="row">
        <div class="col-md-6">
            <fieldset class="form-group">
                {{ form_label(form.documents) }}
                <div id="course_documents" class="collection_holder" data-prototype="{{ prototype.tagCollectionItem(form.documents.vars.prototype)|e }}">
                    {% for widget in form.documents %}
                        {{ prototype.tagCollectionItem(widget) }}
                    {% endfor %}
                </div>
                <button type="button" id="add-document-btn" data-target-collection="#{{ form.documents.vars.id }}" class="btn btn-sm btn-info"><i class="la la-plus"></i> {{ 'course.buttons.add_document' | trans({}, 'labels') }}</button>
            </fieldset>
        </div>
    </div>
{{ form_end(form) }}

我正在用宏生成原型:

{% macro tagCollectionItem(item) %}
<fieldset class="form-group">
    <div id="{{ item.vars.id }}">
        <div class="custom-file">
            {{ form_widget(item.uploadedFile) }}
            {{ form_label(item.uploadedFile, item.uploadedFile.vars.label, {'label_attr': {'class': 'custom-file-label'}}) }}
        </div>
    </div>
</fieldset>
{% endmacro %}

除编辑外,它运行良好。如果我已经选择了文件,则不需要输入。但是我想要文件的名称。

1 个答案:

答案 0 :(得分:0)

我终于使用了一个宏。

{% macro tagCollectionItem(item) %}
<fieldset class="form-group">
    <div id="{{ item.vars.id }}">
    {% if item.uploadedFile.vars.file_url or item.uploadedFile.vars.image_url %}
        {{ form_errors(item.uploadedFile) }}
        {{ form_widget(item.uploadedFile, {'attr': {'hidden': true}}) }}
    {% else %}
        <div class="custom-file">
            {{ form_widget(item.uploadedFile) }}
            {{ form_label(item.uploadedFile, item.uploadedFile.vars.label, {'label_attr': {'class': 'custom-file-label'}}) }}
        </div>
    {% endif %}
    </div>
</fieldset>
{% endmacro %}

表单的树枝文件

<fieldset class="form-group">
            {{ form_label(form.documents) }}
            <div id="course_documents" class="collection_holder" data-prototype="{{ prototype.tagCollectionItem(form.documents.vars.prototype)|e }}">
                {% for widget in form.documents.children %}
                    {{ prototype.tagCollectionItem(widget) }}
                {% endfor %}
            </div>
            <button type="button" id="add-document-btn" data-target-collection="#{{ form.documents.vars.id }}" class="btn btn-sm btn-info"><i class="la la-plus"></i> {{ 'course.buttons.add_document' | trans({}, 'labels') }}</button>
        </fieldset>