Настройка данных-прототипа Symfony для формы редактирования - PullRequest
0 голосов
/ 01 февраля 2019

Я знаю, что это обычный вопрос, но я не могу понять, как этого добиться.

У меня есть сущность курса и сущность 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 голосов
/ 04 февраля 2019

Я наконец-то использовал макрос.

{% 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>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...