2023-02-28 18:36:52 -08:00
|
|
|
@section('title')
|
|
|
|
{{ trans('general.import') }}
|
|
|
|
@parent
|
|
|
|
@stop
|
2023-02-28 21:58:02 -08:00
|
|
|
<div>
|
|
|
|
{{-- Livewire requires a 'master' <div>, above --}}
|
2022-01-13 01:19:13 -08:00
|
|
|
<div class="row">
|
|
|
|
|
|
|
|
{{-- alert --}}
|
2022-09-19 21:04:46 -07:00
|
|
|
@if($message != '')
|
|
|
|
<div class="col-md-12" class="{{ $message_type }}">
|
|
|
|
<div class="alert alert-{{ $this->message_type }} ">
|
|
|
|
<button type="button" class="close" wire:click="hideMessages">×</button>
|
|
|
|
@if($message_type == 'success')
|
|
|
|
<i class="fas fa-check faa-pulse animated" aria-hidden="true"></i>
|
|
|
|
@endif
|
|
|
|
<strong>{{-- title --}} </strong>
|
|
|
|
{{ $message }}
|
2022-01-13 01:19:13 -08:00
|
|
|
</div>
|
2022-09-19 21:04:46 -07:00
|
|
|
</div>
|
|
|
|
@endif
|
2022-01-13 01:19:13 -08:00
|
|
|
|
2022-12-14 10:55:50 -08:00
|
|
|
@if($import_errors)
|
|
|
|
<div class="box">
|
|
|
|
<div class="box-body">
|
|
|
|
<div class="alert alert-warning">
|
2023-02-28 18:36:52 -08:00
|
|
|
<strong>Warning</strong> Some Errors occurred while importing {{-- FIXME: hardcoded string --}}
|
2022-12-14 10:55:50 -08:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="errors-table">
|
|
|
|
<table class="table table-striped table-bordered" id="errors-table">
|
|
|
|
<thead>
|
|
|
|
<th>Item</th>
|
|
|
|
<th>Errors</th>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
@foreach($import_errors as $field => $error_list)
|
|
|
|
<tr>
|
|
|
|
<td>{{ $processDetails->file_path }}</td>
|
|
|
|
<td>
|
|
|
|
<b>{{ $field }}:</b>
|
|
|
|
<span>{{ implode(", ",$error_list) }}</span>
|
|
|
|
<br />
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
@endforeach
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
@endif
|
2022-01-13 01:19:13 -08:00
|
|
|
|
|
|
|
<div class="col-md-9">
|
|
|
|
<div class="box">
|
|
|
|
<div class="box-body">
|
|
|
|
<div class="row">
|
|
|
|
|
|
|
|
<div class="col-md-12">
|
2022-09-19 21:04:46 -07:00
|
|
|
@if($progress != -1)
|
|
|
|
<div class="col-md-9" style="padding-bottom:20px" id='progress-container'>
|
|
|
|
<div class="progress progress-striped-active" style="margin-top: 8px"> {{-- so someof these values are in importer.vue! --}}
|
|
|
|
<div id='progress-bar' class="progress-bar {{ $progress_bar_class }}" role="progressbar" style="width: {{ $progress }}%">
|
|
|
|
<span id='progress-text'>{{ $progress_message }}</span>
|
|
|
|
</div>
|
2022-01-13 01:19:13 -08:00
|
|
|
</div>
|
|
|
|
</div>
|
2022-09-19 21:04:46 -07:00
|
|
|
@endif
|
2022-01-13 01:19:13 -08:00
|
|
|
|
|
|
|
<div class="col-md-3 text-right pull-right">
|
|
|
|
|
|
|
|
<!-- The fileinput-button span is used to style the file input field as button -->
|
|
|
|
@if (!config('app.lock_passwords'))
|
|
|
|
<span class="btn btn-primary fileinput-button">
|
2023-02-28 21:58:02 -08:00
|
|
|
<span>{{ trans('button.select_file') }}</span>
|
2022-01-13 01:19:13 -08:00
|
|
|
<!-- The file input field used as target for the file upload widget -->
|
|
|
|
<label for="files[]"><span class="sr-only">{{ trans('admin/importer/general.select_file') }}</span></label>
|
|
|
|
<input id="fileupload" type="file" name="files[]" data-url="{{ route('api.imports.index') }}" accept="text/csv" aria-label="files[]">
|
|
|
|
</span>
|
|
|
|
@endif
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
</div>
|
|
|
|
<div class="row">
|
|
|
|
<div class="col-md-12 table-responsive" style="padding-top: 30px;">
|
|
|
|
<table data-pagination="true"
|
|
|
|
data-id-table="upload-table"
|
|
|
|
data-search="true"
|
|
|
|
data-side-pagination="client"
|
|
|
|
id="upload-table"
|
|
|
|
class="col-md-12 table table-striped snipe-table">
|
|
|
|
|
|
|
|
<tr>
|
2023-02-28 21:58:02 -08:00
|
|
|
<th class="col-md-6">{{ trans('general.file_name') }}</th>
|
|
|
|
<th class="col-md-3">{{ trans('general.created_at') }}</th>
|
|
|
|
<th class="col-md-1">{{ trans('general.filesize') }}</th>
|
|
|
|
<th class="col-md-1 text-right"><span class="sr-only">{{ trans('general.actions') }}</span></th>
|
2022-01-13 01:19:13 -08:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
@foreach($files as $currentFile)
|
|
|
|
<tr>
|
|
|
|
<td class="col-md-6">{{ $currentFile->file_path }}</td>
|
|
|
|
<td class="col-md-3">{{ $currentFile->created_at }} </td>
|
|
|
|
<td class="col-md-1">{{ $currentFile->filesize }}</td>
|
|
|
|
<td class="col-md-1 text-right">
|
|
|
|
<button class="btn btn-sm btn-info" wire:click="toggleEvent({{ $currentFile->id }})">
|
2023-02-28 21:58:02 -08:00
|
|
|
{{ trans('general.import') }}
|
2022-01-13 01:19:13 -08:00
|
|
|
</button>
|
2022-09-19 21:04:46 -07:00
|
|
|
<button class="btn btn-sm btn-danger" wire:click="destroy({{ $currentFile->id }})">
|
2022-01-13 01:19:13 -08:00
|
|
|
<i class="fas fa-trash icon-white" aria-hidden="true"></i><span class="sr-only"></span></button>
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
@if( $currentFile && $processDetails && ($currentFile->id == $processDetails->id))
|
|
|
|
@livewire('importer-file', ['activeFile' => $currentFile])
|
|
|
|
@endif
|
|
|
|
@endforeach
|
|
|
|
</table>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="col-md-3">
|
|
|
|
<h2>{{ trans('general.importing') }}</h2>
|
|
|
|
<p>{!! trans('general.importing_help') !!}</p>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
@push('js')
|
|
|
|
<script>
|
|
|
|
|
2023-02-28 21:58:02 -08:00
|
|
|
{{-- TODO: Maybe change this to the file upload thing that's baked-in to Livewire? --}}
|
2022-01-13 01:19:13 -08:00
|
|
|
$('#fileupload').fileupload({
|
|
|
|
dataType: 'json',
|
|
|
|
done: function(e, data) {
|
2022-09-19 21:04:46 -07:00
|
|
|
@this.progress_bar_class = 'progress-bar-success';
|
2023-02-28 21:58:02 -08:00
|
|
|
@this.progress_message = 'Success!'; // TODO - we're already round-tripping to the server here - I'd love it if we could get internationalized text here
|
2022-09-19 21:04:46 -07:00
|
|
|
@this.progress = 100;
|
2022-01-13 01:19:13 -08:00
|
|
|
},
|
|
|
|
add: function(e, data) {
|
|
|
|
data.headers = {
|
|
|
|
"X-Requested-With": 'XMLHttpRequest',
|
|
|
|
"X-CSRF-TOKEN": $('meta[name="csrf-token"]').attr('content')
|
|
|
|
};
|
|
|
|
data.process().done( function () {data.submit();});
|
2022-09-19 21:04:46 -07:00
|
|
|
@this.progress = 0;
|
2022-01-13 01:19:13 -08:00
|
|
|
},
|
|
|
|
progress: function(e, data) {
|
2022-09-19 21:04:46 -07:00
|
|
|
@this.progress = parseInt((data.loaded / data.total * 100, 10));
|
|
|
|
@this.progress_message = @this.progress+'% Complete'; // FIXME - this should come from server (so it can be internationalized)
|
2022-01-13 01:19:13 -08:00
|
|
|
},
|
|
|
|
fail: function(e, data) {
|
2022-09-19 21:04:46 -07:00
|
|
|
@this.progress_bar_class = "progress-bar-danger";
|
|
|
|
@this.progress = 100;
|
2023-02-28 21:58:02 -08:00
|
|
|
|
2022-12-14 10:55:50 -08:00
|
|
|
var error_message = ''
|
|
|
|
for(var i in data.jqXHR.responseJSON.messages) {
|
|
|
|
error_message += i+": "+data.jqXHR.responseJSON.messages[i].join(", ")
|
|
|
|
}
|
|
|
|
@this.progress_message = error_message;
|
2022-01-13 01:19:13 -08:00
|
|
|
}
|
|
|
|
})
|
|
|
|
</script>
|
|
|
|
@endpush
|