Удалить файл из формы, если нарушено ограничение - PullRequest
1 голос
/ 27 сентября 2019

Я следовал руководству по управлению загрузкой нескольких файлов http://growingcookies.com/easy-multiple-file-upload-in-symfony-using-the-collectiontype-field/

Система загрузки нескольких файлов работает нормально.

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

Когда это ограничение включено, загруженные файлы все еще присутствуют в форме, но фактически удаляются.

Код javascript всегда отображает файлы как настоящие, когда на самом деле их больше нет:

enter image description here

Кнопки для удаленияфайлы все еще присутствуют. Знаете ли вы, как я могу полностью удалить файлы формы в случае нарушения ограничения при отображении сообщения об ошибке?Или у вас есть лучший способ загрузить несколько файлов с ограничениями в Symfony 4?

Моя веточка:

{% extends '@Ticketing/base.html.twig' %}

{% block title %}{{ 'New Ticket'|trans({}, 'TicketingBundle') }}{% endblock %}
{% block header %}<h1>{{ 'New Ticket'|trans({}, 'TicketingBundle') }}</h1>{% endblock %}

{% block form_group_class -%}
    col-sm-8
{%- endblock form_group_class %}


{% block main %}

    <script type="text/javascript" src="http://code.jquery.com/jquery-latest.min.js"></script>

    {% form_theme form 'bootstrap_4_layout.html.twig' _self %}

    <div class="box box-danger">
        <div class="box-header with-border">
            <h3 class="box-title">{{ 'Create a new ticket'|trans({}, 'TicketingBundle') }}</h3>
        </div>

        {% form_theme form 'bootstrap_3_horizontal_layout.html.twig' _self %}

        {{ form_start(form, {'attr': {'class': 'form-horizontal'} }) }}
        <div class="box-body">

            <div class="hr-line-dashed"></div>

            <div id="filesProto" data-prototype="{{ form_widget(form.documents.vars.prototype)|e }}"></div>

            <div class="form-group">
                <label class="col-sm-2 control-label" for="ticket_form_documents">Pièce-jointe</label>
                <div class="col-sm-8" id="filesBox">
                    {% set pos = 0 %}
                    {% for doc in form.documents %}
                        <div class="row">
                            <div class="col col-xs-1" id="jsRemove{{ pos }}" style="">
                                <button type="button" class="btn btn-danger" onclick="removeFile($(this));"><i class="fa fa-times" aria-hidden="true"></i></button>
                            </div>
                            <div class="col col-xs-11" id="jsPreview{{ pos }}">{{ doc.vars.value.name }}</div>

                            <div style="display:none">
                                {{ form_widget(doc) }}
                            </div>
                        </div>

                        {% set pos = pos + 1 %}
                    {% endfor %}
                </div>
            </div>

        </div>
        <!-- /.box-body -->

        <div class="box-footer">
            <div class="col-md-offset-2 col-sm-8">

                <button id="dropbutton" class="btn bg-ticketing btn-flat form-control" type="submit">
                    {{ 'Submit the ticket'|trans({}, 'TicketingBundle') }}
                </button>


            </div>
        </div>
        <!-- /.box-footer -->
        {{ form_end(form) }}
    </div>

    <script>
        var fileCount = '{{ form.documents|length }}';
        var removeButton = "<button type='button' class='btn btn-danger btn-xs' onclick='removeFile($(this));'><i class='fa fa-times' aria-hidden='true'></i></button>";
        function removeFile(ob)
        {
            ob.parent().parent().remove();
        }
        function createAddFile(fileCount)
        {
            // grab the prototype template
            var newWidget = $("#filesProto").attr('data-prototype');
            // replace the "__name__" used in the id and name of the prototype
            newWidget = newWidget.replace(/__name__/g, fileCount);
            newWidget = "<div style='display:none'>" + newWidget + "</div>";
            hideStuff = "";
            hideStuff += "<div class='col col-xs-1' id='jsRemove" + fileCount + "' style='display: none;'>";
            hideStuff += removeButton;
            hideStuff += "</div>";
            hideStuff += "<div class='col col-xs-11' id='jsPreview" + fileCount + "'>";
            hideStuff += "</div>";
            hideStuff += "<div class='col-sm-8'>";
            hideStuff += "<button type='button' id='jsBtnUpload" + fileCount + "' class='btn btn-default'>";
            hideStuff += "<i class='fa fa-plus'></i> {{ 'Pièce-jointe' | trans }}";
            hideStuff += "</button>";
            hideStuff += "</div>";
            $("#filesBox").append("<div class='form-group'>" + hideStuff + newWidget + "</div>");
            // On click => Simulate file behaviour
            $("#jsBtnUpload" + fileCount).on('click', function(e){
                $('#ticket_form_documents_' + fileCount + '_file').trigger('click');
            });
            // Once the file is added
            $('#ticket_form_documents_' + fileCount + '_file').on('change', function() {
                // Show its name
                fileName = $(this).prop('files')[0].name;
                $("#jsPreview" + fileCount).append(fileName);
                // Hide the add file button
                $("#jsBtnUpload" + fileCount).hide();
                // Show the remove file button
                $("#jsRemove" + fileCount).show();
                // Create another instance of add file button and company
                createAddFile(parseInt(fileCount)+1);
            });
        }
        $(document).ready(function(){
            createAddFile(fileCount);
            fileCount++;
        });
    </script>

{% endblock %}

Код доступен здесь: https://github.com/oanalivia/Multiple-File-Upload-in-Symfony-using-the-CollectionType-Field

1 Ответ

1 голос
/ 28 сентября 2019

Одно банальное решение - адаптировать вывод и просто отфильтровать документы, которые не имеют значения.

                {% for doc in form.documents %}
                    {% if doc.vars.value %} {### <-- new 1/2 ###}
                    <div class="row">
                        <div class="col col-xs-1" id="jsRemove{{ pos }}" style="">
                            <button type="button" class="btn btn-danger" onclick="removeFile($(this));"><i class="fa fa-times" aria-hidden="true"></i></button>
                        </div>
                        <div class="col col-xs-11" id="jsPreview{{ pos }}">{{ doc.vars.value.name }}</div>

                        <div style="display:none">
                            {{ form_widget(doc) }}
                        </div>
                    </div>

                    {% set pos = pos + 1 %}
                    {% endif %}  {### <-- new 2/2 ###}
                {% endfor %}

, если вы используете довольно новую версию twig (> =2.10, я считаю), вы также можете изменить только первую строку этого раздела:

{% for doc in form.documents|filter(doc => doc.vars.value) %}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...