refs #443 invoice create and edit add stack
This commit is contained in:
		@@ -8,17 +8,19 @@
 | 
			
		||||
    {!! Form::open(['url' => 'incomes/invoices', 'files' => true, 'role' => 'form']) !!}
 | 
			
		||||
 | 
			
		||||
    <div class="box-body">
 | 
			
		||||
        @stack('customer_id_input_start')
 | 
			
		||||
        <div class="form-group col-md-6 required {{ $errors->has('customer_id') ? 'has-error' : ''}}">
 | 
			
		||||
            {!! Form::label('customer_id', trans_choice('general.customers', 1), ['class' => 'control-label']) !!}
 | 
			
		||||
            <div class="input-group">
 | 
			
		||||
                <div class="input-group-addon"><i class="fa fa-user"></i></div>
 | 
			
		||||
                {!! Form::select('customer_id', $customers, null, array_merge(['class' => 'form-control', 'placeholder' => trans('general.form.select.field', ['field' => trans_choice('general.customers', 1)])])) !!}
 | 
			
		||||
                <div class="input-group-btn">
 | 
			
		||||
                    <button type="button" onclick="createCustomer();" class="btn btn-default btn-icon"><i class="fa fa-plus"></i></button>
 | 
			
		||||
                    <button type="button" id="button-customer" class="btn btn-default btn-icon"><i class="fa fa-plus"></i></button>
 | 
			
		||||
                </div>
 | 
			
		||||
            </div>
 | 
			
		||||
            {!! $errors->first('customer_id', '<p class="help-block">:message</p>') !!}
 | 
			
		||||
        </div>
 | 
			
		||||
        @stack('customer_id_input_end')
 | 
			
		||||
 | 
			
		||||
        {{ Form::selectGroup('currency_code', trans_choice('general.currencies', 1), 'exchange', $currencies, setting('general.default_currency')) }}
 | 
			
		||||
 | 
			
		||||
@@ -36,46 +38,43 @@
 | 
			
		||||
                <table class="table table-bordered" id="items">
 | 
			
		||||
                    <thead>
 | 
			
		||||
                        <tr style="background-color: #f9f9f9;">
 | 
			
		||||
                            @stack('actions_th_start')
 | 
			
		||||
                            <th width="5%"  class="text-center">{{ trans('general.actions') }}</th>
 | 
			
		||||
                            @stack('actions_th_end')
 | 
			
		||||
                            @stack('name_th_start')
 | 
			
		||||
                            <th width="40%" class="text-left">{{ trans('general.name') }}</th>
 | 
			
		||||
                            @stack('name_th_end')
 | 
			
		||||
                            @stack('quantity_th_start')
 | 
			
		||||
                            <th width="5%" class="text-center">{{ trans('invoices.quantity') }}</th>
 | 
			
		||||
                            @stack('quantity_th_end')
 | 
			
		||||
                            @stack('price_th_start')
 | 
			
		||||
                            <th width="10%" class="text-right">{{ trans('invoices.price') }}</th>
 | 
			
		||||
                            @stack('price_th_end')
 | 
			
		||||
                            @stack('taxes_th_start')
 | 
			
		||||
                            <th width="15%" class="text-right">{{ trans_choice('general.taxes', 1) }}</th>
 | 
			
		||||
                            @stack('taxes_th_end')
 | 
			
		||||
                            @stack('total_th_start')
 | 
			
		||||
                            <th width="10%" class="text-right">{{ trans('invoices.total') }}</th>
 | 
			
		||||
                            @stack('total_th_end')
 | 
			
		||||
                        </tr>
 | 
			
		||||
                    </thead>
 | 
			
		||||
                    <tbody>
 | 
			
		||||
                        <?php $item_row = 0; ?>
 | 
			
		||||
                        <tr id="item-row-{{ $item_row }}">
 | 
			
		||||
                            <td class="text-center" style="vertical-align: middle;">
 | 
			
		||||
                                <button type="button" onclick="$(this).tooltip('destroy'); $('#item-row-{{ $item_row }}').remove(); totalItem();" data-toggle="tooltip" title="{{ trans('general.delete') }}" class="btn btn-xs btn-danger"><i class="fa fa-trash"></i></button>
 | 
			
		||||
                            </td>
 | 
			
		||||
                            <td>
 | 
			
		||||
                                <input class="form-control typeahead" required="required" placeholder="{{ trans('general.form.enter', ['field' => trans_choice('invoices.item_name', 1)]) }}" name="item[{{ $item_row }}][name]" type="text" id="item-name-{{ $item_row }}" autocomplete="off">
 | 
			
		||||
                                <input name="item[{{ $item_row }}][item_id]" type="hidden" id="item-id-{{ $item_row }}">
 | 
			
		||||
                            </td>
 | 
			
		||||
                            <td>
 | 
			
		||||
                                <input class="form-control text-center" required="required" name="item[{{ $item_row }}][quantity]" type="text" id="item-quantity-{{ $item_row }}">
 | 
			
		||||
                            </td>
 | 
			
		||||
                            <td>
 | 
			
		||||
                                <input class="form-control text-right" required="required" name="item[{{ $item_row }}][price]" type="text" id="item-price-{{ $item_row }}">
 | 
			
		||||
                            </td>
 | 
			
		||||
                            <td>
 | 
			
		||||
                                {!! Form::select('item[' . $item_row . '][tax_id]', $taxes, setting('general.default_tax'), ['id'=> 'item-tax-'. $item_row, 'class' => 'form-control tax-select2', 'placeholder' => trans('general.form.select.field', ['field' => trans_choice('general.taxes', 1)])]) !!}
 | 
			
		||||
                            </td>
 | 
			
		||||
                            <td class="text-right" style="vertical-align: middle;">
 | 
			
		||||
                                <span id="item-total-{{ $item_row }}">0</span>
 | 
			
		||||
                            </td>
 | 
			
		||||
                        </tr>
 | 
			
		||||
                        @include('incomes.invoices.item')
 | 
			
		||||
                        <?php $item_row++; ?>
 | 
			
		||||
                        @stack('add_item_td_start')
 | 
			
		||||
                        <tr id="addItem">
 | 
			
		||||
                            <td class="text-center"><button type="button" onclick="addItem();" data-toggle="tooltip" title="{{ trans('general.add') }}" class="btn btn-xs btn-primary" data-original-title="{{ trans('general.add') }}"><i class="fa fa-plus"></i></button></td>
 | 
			
		||||
                            <td class="text-center"><button type="button" id="button-add-item" data-toggle="tooltip" title="{{ trans('general.add') }}" class="btn btn-xs btn-primary" data-original-title="{{ trans('general.add') }}"><i class="fa fa-plus"></i></button></td>
 | 
			
		||||
                            <td class="text-right" colspan="5"></td>
 | 
			
		||||
                        </tr>
 | 
			
		||||
                        @stack('add_item_td_end')
 | 
			
		||||
                        @stack('sub_total_td_start')
 | 
			
		||||
                        <tr>
 | 
			
		||||
                            <td class="text-right" colspan="5"><strong>{{ trans('invoices.sub_total') }}</strong></td>
 | 
			
		||||
                            <td class="text-right"><span id="sub-total">0</span></td>
 | 
			
		||||
                        </tr>
 | 
			
		||||
                        @stack('sub_total_td_end')
 | 
			
		||||
                        @stack('add_discount_td_start')
 | 
			
		||||
                        <tr>
 | 
			
		||||
                            <td class="text-right" style="vertical-align: middle;" colspan="5">
 | 
			
		||||
                                <a href="javascript:void(0)" id="discount-text" rel="popover">{{ trans('invoices.add_discount') }}</a>
 | 
			
		||||
@@ -85,14 +84,19 @@
 | 
			
		||||
                                {!! Form::hidden('discount', null, ['id' => 'discount', 'class' => 'form-control text-right']) !!}
 | 
			
		||||
                            </td>
 | 
			
		||||
                        </tr>
 | 
			
		||||
                        @stack('add_discount_td_end')
 | 
			
		||||
                        @stack('tax_total_td_start')
 | 
			
		||||
                        <tr>
 | 
			
		||||
                            <td class="text-right" colspan="5"><strong>{{ trans_choice('general.taxes', 1) }}</strong></td>
 | 
			
		||||
                            <td class="text-right"><span id="tax-total">0</span></td>
 | 
			
		||||
                        </tr>
 | 
			
		||||
                        @stack('tax_total_td_end')
 | 
			
		||||
                        @stack('grand_total_td_start')
 | 
			
		||||
                        <tr>
 | 
			
		||||
                            <td class="text-right" colspan="5"><strong>{{ trans('invoices.total') }}</strong></td>
 | 
			
		||||
                            <td class="text-right"><span id="grand-total">0</span></td>
 | 
			
		||||
                        </tr>
 | 
			
		||||
                        @stack('grand_total_td_end')
 | 
			
		||||
                    </tbody>
 | 
			
		||||
                </table>
 | 
			
		||||
            </div>
 | 
			
		||||
@@ -100,17 +104,19 @@
 | 
			
		||||
 | 
			
		||||
        {{ Form::textareaGroup('notes', trans_choice('general.notes', 2)) }}
 | 
			
		||||
 | 
			
		||||
        @stack('category_id_input_start')
 | 
			
		||||
        <div class="form-group col-md-6 required {{ $errors->has('category_id') ? 'has-error' : ''}}">
 | 
			
		||||
            {!! Form::label('category_id', trans_choice('general.categories', 1), ['class' => 'control-label']) !!}
 | 
			
		||||
            <div class="input-group">
 | 
			
		||||
                <div class="input-group-addon"><i class="fa fa-folder-open-o"></i></div>
 | 
			
		||||
                {!! Form::select('category_id', $categories, null, array_merge(['class' => 'form-control', 'placeholder' => trans('general.form.select.field', ['field' => trans_choice('general.categories', 1)])])) !!}
 | 
			
		||||
                <div class="input-group-btn">
 | 
			
		||||
                    <button type="button" onclick="createCategory();" class="btn btn-default btn-icon"><i class="fa fa-plus"></i></button>
 | 
			
		||||
                    <button type="button" id="button-category" class="btn btn-default btn-icon"><i class="fa fa-plus"></i></button>
 | 
			
		||||
                </div>
 | 
			
		||||
            </div>
 | 
			
		||||
            {!! $errors->first('category_id', '<p class="help-block">:message</p>') !!}
 | 
			
		||||
        </div>
 | 
			
		||||
        @stack('category_id_input_end')
 | 
			
		||||
 | 
			
		||||
        {{ Form::recurring('create') }}
 | 
			
		||||
 | 
			
		||||
@@ -154,47 +160,31 @@
 | 
			
		||||
    <script type="text/javascript">
 | 
			
		||||
        var item_row = '{{ $item_row }}';
 | 
			
		||||
 | 
			
		||||
        function addItem() {
 | 
			
		||||
            html  = '<tr id="item-row-' + item_row + '">';
 | 
			
		||||
            html += '  <td class="text-center" style="vertical-align: middle;">';
 | 
			
		||||
            html += '      <button type="button" onclick="$(this).tooltip(\'destroy\'); $(\'#item-row-' + item_row + '\').remove(); totalItem();" data-toggle="tooltip" title="{{ trans('general.delete') }}" class="btn btn-xs btn-danger"><i class="fa fa-trash"></i></button>';
 | 
			
		||||
            html += '  </td>';
 | 
			
		||||
            html += '  <td>';
 | 
			
		||||
            html += '      <input class="form-control typeahead" required="required" placeholder="{{ trans('general.form.enter', ['field' => trans_choice('invoices.item_name', 1)]) }}" name="item[' + item_row + '][name]" type="text" id="item-name-' + item_row + '" autocomplete="off">';
 | 
			
		||||
            html += '      <input name="item[' + item_row + '][item_id]" type="hidden" id="item-id-' + item_row + '">';
 | 
			
		||||
            html += '  </td>';
 | 
			
		||||
            html += '  <td>';
 | 
			
		||||
            html += '      <input class="form-control text-center" required="required" name="item[' + item_row + '][quantity]" type="text" id="item-quantity-' + item_row + '">';
 | 
			
		||||
            html += '  </td>';
 | 
			
		||||
            html += '  <td>';
 | 
			
		||||
            html += '      <input class="form-control text-right" required="required" name="item[' + item_row + '][price]" type="text" id="item-price-' + item_row + '">';
 | 
			
		||||
            html += '  </td>';
 | 
			
		||||
            html += '  <td>';
 | 
			
		||||
            html += '      <select class="form-control tax-select2" name="item[' + item_row + '][tax_id]" id="item-tax-' + item_row + '">';
 | 
			
		||||
            html += '         <option selected="selected" value="">{{ trans('general.form.select.field', ['field' => trans_choice('general.taxes', 1)]) }}</option>';
 | 
			
		||||
            @foreach($taxes as $tax_key => $tax_value)
 | 
			
		||||
            html += '         <option value="{{ $tax_key }}">{{ $tax_value }}</option>';
 | 
			
		||||
            @endforeach
 | 
			
		||||
            html += '      </select>';
 | 
			
		||||
            html += '  </td>';
 | 
			
		||||
            html += '  <td class="text-right" style="vertical-align: middle;">';
 | 
			
		||||
            html += '      <span id="item-total-' + item_row + '">0</span>';
 | 
			
		||||
            html += '  </td>';
 | 
			
		||||
        $(document).on('click', '#button-add-item', function (e) {
 | 
			
		||||
            $.ajax({
 | 
			
		||||
                url: '{{ url("incomes/invoices/addItem") }}',
 | 
			
		||||
                type: 'GET',
 | 
			
		||||
                dataType: 'JSON',
 | 
			
		||||
                data: {item_row: item_row},
 | 
			
		||||
                success: function(json) {
 | 
			
		||||
                    if (json['success']) {
 | 
			
		||||
                        $('#items tbody #addItem').before(json['html']);
 | 
			
		||||
                        //$('[rel=tooltip]').tooltip();
 | 
			
		||||
 | 
			
		||||
            $('#items tbody #addItem').before(html);
 | 
			
		||||
            //$('[rel=tooltip]').tooltip();
 | 
			
		||||
                        $('[data-toggle="tooltip"]').tooltip('hide');
 | 
			
		||||
 | 
			
		||||
            $('[data-toggle="tooltip"]').tooltip('hide');
 | 
			
		||||
                        $('#item-row-' + item_row + ' .tax-select2').select2({
 | 
			
		||||
                            placeholder: {
 | 
			
		||||
                                id: '-1', // the value of the option
 | 
			
		||||
                                text: "{{ trans('general.form.select.field', ['field' => trans_choice('general.taxes', 1)]) }}"
 | 
			
		||||
                            }
 | 
			
		||||
                        });
 | 
			
		||||
 | 
			
		||||
            $('#item-row-' + item_row + ' .tax-select2').select2({
 | 
			
		||||
                placeholder: {
 | 
			
		||||
                    id: '-1', // the value of the option
 | 
			
		||||
                    text: "{{ trans('general.form.select.field', ['field' => trans_choice('general.taxes', 1)]) }}"
 | 
			
		||||
                        item_row++;
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
            });
 | 
			
		||||
 | 
			
		||||
            item_row++;
 | 
			
		||||
        }
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        $(document).ready(function(){
 | 
			
		||||
            //Date picker
 | 
			
		||||
@@ -382,200 +372,31 @@
 | 
			
		||||
            });
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        function createCustomer() {
 | 
			
		||||
        $(document).on('click', '#button-customer', function (e) {
 | 
			
		||||
            $('#modal-create-customer').remove();
 | 
			
		||||
 | 
			
		||||
            modal  = '<div class="modal fade" id="modal-create-customer" style="display: none;">';
 | 
			
		||||
            modal += '  <div class="modal-dialog  modal-lg">';
 | 
			
		||||
            modal += '      <div class="modal-content">';
 | 
			
		||||
            modal += '          <div class="modal-header">';
 | 
			
		||||
            modal += '              <h4 class="modal-title">{{ trans('general.title.new', ['type' => trans_choice('general.customers', 1)]) }}</h4>';
 | 
			
		||||
            modal += '          </div>';
 | 
			
		||||
            modal += '          <div class="modal-body">';
 | 
			
		||||
            modal += '              {!! Form::open(['id' => 'form-create-customer', 'role' => 'form']) !!}';
 | 
			
		||||
            modal += '              <div class="row">';
 | 
			
		||||
            modal += '                  <div class="form-group col-md-6 required">';
 | 
			
		||||
            modal += '                      <label for="name" class="control-label">{{ trans('general.name') }}</label>';
 | 
			
		||||
            modal += '                      <div class="input-group">';
 | 
			
		||||
            modal += '                          <div class="input-group-addon"><i class="fa fa-id-card-o"></i></div>';
 | 
			
		||||
            modal += '                          <input class="form-control" placeholder="{{ trans('general.name') }}" required="required" name="name" type="text" id="name">';
 | 
			
		||||
            modal += '                      </div>';
 | 
			
		||||
            modal += '                  </div>';
 | 
			
		||||
            modal += '                  <div class="form-group col-md-6">';
 | 
			
		||||
            modal += '                      <label for="email" class="control-label">{{ trans('general.email') }}</label>';
 | 
			
		||||
            modal += '                      <div class="input-group">';
 | 
			
		||||
            modal += '                          <div class="input-group-addon"><i class="fa fa-envelope"></i></div>';
 | 
			
		||||
            modal += '                          <input class="form-control" placeholder="{{ trans('general.email') }}" required="required" name="email" type="text" id="email">';
 | 
			
		||||
            modal += '                      </div>';
 | 
			
		||||
            modal += '                  </div>';
 | 
			
		||||
            modal += '                  <div class="form-group col-md-6">';
 | 
			
		||||
            modal += '                      <label for="tax_number" class="control-label">{{ trans('general.tax_number') }}</label>';
 | 
			
		||||
            modal += '                      <div class="input-group">';
 | 
			
		||||
            modal += '                          <div class="input-group-addon"><i class="fa fa-percent"></i></div>';
 | 
			
		||||
            modal += '                          <input class="form-control" placeholder="{{ trans('general.tax_number') }}" name="tax_number" type="text" id="tax_number">';
 | 
			
		||||
            modal += '                      </div>';
 | 
			
		||||
            modal += '                  </div>';
 | 
			
		||||
            modal += '                  <div class="form-group col-md-6 required">';
 | 
			
		||||
            modal += '                      <label for="email" class="control-label">{{ trans_choice('general.currencies', 1) }}</label>';
 | 
			
		||||
            modal += '                      <div class="input-group">';
 | 
			
		||||
            modal += '                          <div class="input-group-addon"><i class="fa fa-exchange"></i></div>';
 | 
			
		||||
            modal += '                          <select class="form-control" required="required" id="currency_code" name="currency_code">';
 | 
			
		||||
            modal += '                              <option value="">{{ trans('general.form.select.field', ['field' => trans_choice('general.currencies', 1)]) }}</option>';
 | 
			
		||||
            @foreach($currencies as $currency_code => $currency_name)
 | 
			
		||||
            modal += '                              <option value="{{ $currency_code }}" {{ (setting('general.default_currency') == $currency_code) ? 'selected' : '' }}>{{ $currency_name }}</option>';
 | 
			
		||||
            @endforeach
 | 
			
		||||
            modal += '                          </select>';
 | 
			
		||||
            modal += '                      </div>';
 | 
			
		||||
            modal += '                  </div>';
 | 
			
		||||
            modal += '                  <div class="form-group col-md-12">';
 | 
			
		||||
            modal += '                      <label for="address" class="control-label">{{ trans('general.address') }}</label>';
 | 
			
		||||
            modal += '                      <textarea class="form-control" placeholder="{{ trans('general.address') }}" rows="3" name="address" cols="50" id="address"></textarea>';
 | 
			
		||||
            modal += '                  </div>';
 | 
			
		||||
            modal += '                  {!! Form::hidden('enabled', '1', []) !!}';
 | 
			
		||||
            modal += '              </div>';
 | 
			
		||||
            modal += '              {!! Form::close() !!}';
 | 
			
		||||
            modal += '          </div>';
 | 
			
		||||
            modal += '          <div class="modal-footer">';
 | 
			
		||||
            modal += '              <div class="pull-left">';
 | 
			
		||||
            modal += '              {!! Form::button('<span class="fa fa-save"></span>  ' . trans('general.save'), ['type' => 'button', 'id' =>'button-create-customer', 'class' => 'btn btn-success']) !!}';
 | 
			
		||||
            modal += '              <button type="button" class="btn btn-default" data-dismiss="modal"><span class="fa fa-times-circle"></span>  {{ trans('general.cancel') }}</button>';
 | 
			
		||||
            modal += '              </div>';
 | 
			
		||||
            modal += '          </div>';
 | 
			
		||||
            modal += '      </div>';
 | 
			
		||||
            modal += '  </div>';
 | 
			
		||||
            modal += '</div>';
 | 
			
		||||
 | 
			
		||||
            $('body').append(modal);
 | 
			
		||||
 | 
			
		||||
            $("#modal-create-customer #currency_code").select2({
 | 
			
		||||
                placeholder: "{{ trans('general.form.select.field', ['field' => trans_choice('general.currencies', 1)]) }}"
 | 
			
		||||
            });
 | 
			
		||||
 | 
			
		||||
            $('#modal-create-customer').modal('show');
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        $(document).on('click', '#button-create-customer', function (e) {
 | 
			
		||||
            $('#modal-create-customer .modal-header').before('<span id="span-loading" style="position: absolute; height: 100%; width: 100%; z-index: 99; background: #6da252; opacity: 0.4;"><i class="fa fa-spinner fa-spin" style="font-size: 16em !important;margin-left: 35%;margin-top: 8%;"></i></span>');
 | 
			
		||||
 | 
			
		||||
            $.ajax({
 | 
			
		||||
                url: '{{ url("incomes/customers/customer") }}',
 | 
			
		||||
                type: 'POST',
 | 
			
		||||
                url: '{{ url("modals/customers/create") }}',
 | 
			
		||||
                type: 'GET',
 | 
			
		||||
                dataType: 'JSON',
 | 
			
		||||
                data: $("#form-create-customer").serialize(),
 | 
			
		||||
                beforeSend: function () {
 | 
			
		||||
                    $(".form-group").removeClass("has-error");
 | 
			
		||||
                    $(".help-block").remove();
 | 
			
		||||
                },
 | 
			
		||||
                success: function(data) {
 | 
			
		||||
                    $('#span-loading').remove();
 | 
			
		||||
 | 
			
		||||
                    $('#modal-create-customer').modal('hide');
 | 
			
		||||
 | 
			
		||||
                    $("#customer_id").append('<option value="' + data.id + '" selected="selected">' + data.name + '</option>');
 | 
			
		||||
                    $('#customer_id').trigger('change');
 | 
			
		||||
 | 
			
		||||
                    $("#customer_id").select2('refresh');
 | 
			
		||||
                },
 | 
			
		||||
                error: function(error, textStatus, errorThrown) {
 | 
			
		||||
                    $('#span-loading').remove();
 | 
			
		||||
 | 
			
		||||
                    if (error.responseJSON.name) {
 | 
			
		||||
                        $("input[name='name']").parent().parent().addClass('has-error');
 | 
			
		||||
                        $("input[name='name']").parent().after('<p class="help-block">' + error.responseJSON.name + '</p>');
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
                    if (error.responseJSON.email) {
 | 
			
		||||
                        $("input[name='email']").parent().parent().addClass('has-error');
 | 
			
		||||
                        $("input[name='email']").parent().after('<p class="help-block">' + error.responseJSON.email + '</p>');
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
                    if (error.responseJSON.currency_code) {
 | 
			
		||||
                        $("select[name='currency_code']").parent().parent().addClass('has-error');
 | 
			
		||||
                        $("select[name='currency_code']").parent().after('<p class="help-block">' + error.responseJSON.currency_code + '</p>');
 | 
			
		||||
                success: function(json) {
 | 
			
		||||
                    if (json['success']) {
 | 
			
		||||
                        $('body').append(json['html']);
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
            });
 | 
			
		||||
        });
 | 
			
		||||
 | 
			
		||||
        function createCategory() {
 | 
			
		||||
        $(document).on('click', '#button-category', function (e) {
 | 
			
		||||
            $('#modal-create-category').remove();
 | 
			
		||||
 | 
			
		||||
            modal  = '<div class="modal fade" id="modal-create-category" style="display: none;">';
 | 
			
		||||
            modal += '  <div class="modal-dialog  modal-lg">';
 | 
			
		||||
            modal += '      <div class="modal-content">';
 | 
			
		||||
            modal += '          <div class="modal-header">';
 | 
			
		||||
            modal += '              <h4 class="modal-title">{{ trans('general.title.new', ['type' => trans_choice('general.categories', 1)]) }}</h4>';
 | 
			
		||||
            modal += '          </div>';
 | 
			
		||||
            modal += '          <div class="modal-body">';
 | 
			
		||||
            modal += '              {!! Form::open(['id' => 'form-create-category', 'role' => 'form']) !!}';
 | 
			
		||||
            modal += '              <div class="row">';
 | 
			
		||||
            modal += '                  <div class="form-group col-md-6 required">';
 | 
			
		||||
            modal += '                      <label for="name" class="control-label">{{ trans('general.name') }}</label>';
 | 
			
		||||
            modal += '                      <div class="input-group">';
 | 
			
		||||
            modal += '                          <div class="input-group-addon"><i class="fa fa-id-card-o"></i></div>';
 | 
			
		||||
            modal += '                          <input class="form-control" placeholder="{{ trans('general.name') }}" required="required" name="name" type="text" id="name">';
 | 
			
		||||
            modal += '                      </div>';
 | 
			
		||||
            modal += '                  </div>';
 | 
			
		||||
            modal += '                  <div class="form-group col-md-6 required">';
 | 
			
		||||
            modal += '                      <label for="color" class="control-label">{{ trans('general.color') }}</label>';
 | 
			
		||||
            modal += '                      <div  id="category-color-picker" class="input-group colorpicker-component">';
 | 
			
		||||
            modal += '                          <div class="input-group-addon"><i></i></div>';
 | 
			
		||||
            modal += '                          <input class="form-control" value="#00a65a" placeholder="{{ trans('general.color') }}" required="required" name="color" type="text" id="color">';
 | 
			
		||||
            modal += '                      </div>';
 | 
			
		||||
            modal += '                  </div>';
 | 
			
		||||
            modal += '                  {!! Form::hidden('type', 'income', []) !!}';
 | 
			
		||||
            modal += '                  {!! Form::hidden('enabled', '1', []) !!}';
 | 
			
		||||
            modal += '              </div>';
 | 
			
		||||
            modal += '              {!! Form::close() !!}';
 | 
			
		||||
            modal += '          </div>';
 | 
			
		||||
            modal += '          <div class="modal-footer">';
 | 
			
		||||
            modal += '              <div class="pull-left">';
 | 
			
		||||
            modal += '              {!! Form::button('<span class="fa fa-save"></span>  ' . trans('general.save'), ['type' => 'button', 'id' =>'button-create-category', 'class' => 'btn btn-success']) !!}';
 | 
			
		||||
            modal += '              <button type="button" class="btn btn-default" data-dismiss="modal"><span class="fa fa-times-circle"></span>  {{ trans('general.cancel') }}</button>';
 | 
			
		||||
            modal += '              </div>';
 | 
			
		||||
            modal += '          </div>';
 | 
			
		||||
            modal += '      </div>';
 | 
			
		||||
            modal += '  </div>';
 | 
			
		||||
            modal += '</div>';
 | 
			
		||||
 | 
			
		||||
            $('body').append(modal);
 | 
			
		||||
 | 
			
		||||
            $('#category-color-picker').colorpicker();
 | 
			
		||||
 | 
			
		||||
            $('#modal-create-category').modal('show');
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        $(document).on('click', '#button-create-category', function (e) {
 | 
			
		||||
            $('#modal-create-category .modal-header').before('<span id="span-loading" style="position: absolute; height: 100%; width: 100%; z-index: 99; background: #6da252; opacity: 0.4;"><i class="fa fa-spinner fa-spin" style="font-size: 10em !important;margin-left: 35%;margin-top: 8%;"></i></span>');
 | 
			
		||||
 | 
			
		||||
            $.ajax({
 | 
			
		||||
                url: '{{ url("settings/categories/category") }}',
 | 
			
		||||
                type: 'POST',
 | 
			
		||||
                url: '{{ url("modals/categories/create") }}',
 | 
			
		||||
                type: 'GET',
 | 
			
		||||
                dataType: 'JSON',
 | 
			
		||||
                data: $("#form-create-category").serialize(),
 | 
			
		||||
                beforeSend: function () {
 | 
			
		||||
                    $(".form-group").removeClass("has-error");
 | 
			
		||||
                    $(".help-block").remove();
 | 
			
		||||
                },
 | 
			
		||||
                success: function(data) {
 | 
			
		||||
                    $('#span-loading').remove();
 | 
			
		||||
 | 
			
		||||
                    $('#modal-create-category').modal('hide');
 | 
			
		||||
 | 
			
		||||
                    $("#category_id").append('<option value="' + data.id + '" selected="selected">' + data.name + '</option>');
 | 
			
		||||
                    $("#category_id").select2('refresh');
 | 
			
		||||
                },
 | 
			
		||||
                error: function(error, textStatus, errorThrown) {
 | 
			
		||||
                    $('#span-loading').remove();
 | 
			
		||||
 | 
			
		||||
                    if (error.responseJSON.name) {
 | 
			
		||||
                        $("input[name='name']").parent().parent().addClass('has-error');
 | 
			
		||||
                        $("input[name='name']").parent().after('<p class="help-block">' + error.responseJSON.name + '</p>');
 | 
			
		||||
                    }
 | 
			
		||||
 | 
			
		||||
                    if (error.responseJSON.color) {
 | 
			
		||||
                        $("input[name='color']").parent().parent().addClass('has-error');
 | 
			
		||||
                        $("input[name='color']").parent().after('<p class="help-block">' + error.responseJSON.color + '</p>');
 | 
			
		||||
                success: function(json) {
 | 
			
		||||
                    if (json['success']) {
 | 
			
		||||
                        $('body').append(json['html']);
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
            });
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user