%PDF- %GIF98; %PNG;
Server : ApacheSystem : Linux host.digitalbabaji.in 4.18.0-513.11.1.el8_9.x86_64 #1 SMP Wed Jan 17 02:00:40 EST 2024 x86_64 User : addictionfreeind ( 1003) PHP Version : 7.2.34 Disable Function : exec,passthru,shell_exec,system Directory : /home/addictionfreeind/www/admin1/resources/views/leaves/ajax/ |
Upload File : |
@php
$addLeadAgentPermission = user()->permission('manage_leave_setting');
$approveRejectPermission = user()->permission('approve_or_reject_leaves');
@endphp
<link rel="stylesheet" href="{{ asset('vendor/css/dropzone.min.css') }}">
<div class="row">
<div class="col-sm-12">
<x-form id="save-lead-data-form" method="PUT">
<div class="add-client bg-white rounded">
<h4 class="mb-0 p-20 f-21 font-weight-normal text-capitalize border-bottom-grey">
@lang('app.menu.editLeaves')</h4>
<div class="row p-20">
<div class="col-lg-3 col-md-6">
@if (isset($defaultAssign))
<x-forms.label class="my-3" fieldId="" :fieldLabel="__('app.name')"
fieldRequired="true">
</x-forms.label>
<input type="hidden" name="user_id" id="user_id" value="{{ $defaultAssign->id }}">
<input type="text" value="{{ $defaultAssign->name }}"
class="form-control height-35 f-15 readonly-background" readonly>
@else
<x-forms.label class="my-3" fieldId="" :fieldLabel="__('modules.messages.chooseMember')"
fieldRequired="true">
</x-forms.label>
<select class="form-control select-picker" name="user_id" id="user_id"
data-live-search="true">
<option value="">--</option>
@foreach ($employees as $employee)
<x-user-option :user="$employee"
:selected="(request()->has('default_assign') && request('default_assign') == $employee->id) || ($leave->user_id == $employee->id)">
</x-user-option>
@endforeach
</select>
@endif
</div>
<div class="col-lg-3 col-md-6">
<x-forms.label class="my-3" fieldId="" :fieldLabel="__('modules.leaves.leaveType')"
fieldRequired="true">
</x-forms.label>
<x-forms.input-group>
<select class="form-control select-picker" name="leave_type_id" id="leave_type_id"
data-live-search="true">
<option value="">--</option>
@foreach ($leaveQuotas as $leaveQuota)
@php
$leaveType = new \App\Models\LeaveType();
@endphp
@if($leaveType->leaveTypeCodition($leaveQuota, $userRole))
<option @if ($leave->leave_type_id == $leaveQuota->id) selected @endif value="{{ $leaveQuota->id }}">
{{ $leaveQuota->type_name }}</option>
@endif
@endforeach
</select>
@if ($addLeadAgentPermission == 'all' || $addLeadAgentPermission == 'added')
<x-slot name="append">
<button type="button"
class="btn btn-outline-secondary border-grey add-lead-type"
data-toggle="tooltip" data-original-title="{{ __('modules.leaves.addLeaveType') }}">@lang('app.add')</button>
</x-slot>
@endif
</x-forms.input-group>
</div>
@if ($approveRejectPermission == 'all')
<div class="col-lg-3 col-md-6">
<x-forms.select fieldId="status" :fieldLabel="__('app.status')" fieldName="status"
search="true">
<option @if ($leave->status == 'approved') selected @endif value="approved">@lang('app.approved')</option>
<option @if ($leave->status == 'pending') selected @endif value="pending">@lang('app.pending')</option>
<option @if ($leave->status == 'rejected') selected @endif value="rejected">@lang('app.rejected')</option>
</x-forms.select>
</div>
@endif
<div class="col-lg-3 col-md-6">
<x-forms.text :fieldLabel="__('app.date')" fieldName="leave_date" fieldId="single_date"
:fieldPlaceholder="__('app.date')"
:fieldValue="$leave->leave_date->translatedFormat(company()->date_format)" />
</div>
<div class="col-md-12">
<div class="form-group my-3">
<x-forms.textarea class="mr-0 mr-lg-2 mr-md-2" :fieldLabel="__('modules.leaves.reason')"
fieldName="reason" fieldId="reason" :fieldPlaceholder="__('placeholders.leave.reason')"
:fieldValue="$leave->reason" :fieldRequired="true">
</x-forms.textarea>
</div>
</div>
@if ($leave->status == 'rejected')
<div class="col-md-12">
<div class="form-group my-3">
<x-forms.textarea class="mr-0 mr-lg-2 mr-md-2"
:fieldLabel="__('modules.leaves.rejectReason')" fieldName="reject_reason"
fieldId="reject_reason" fieldPlaceholder="" :fieldValue="$leave->reject_reason">
</x-forms.textarea>
</div>
</div>
@endif
<div class="col-md-12 mt-3">
<a class="f-15 f-w-500" href="javascript:;" id="add-file"><i
class="icons icon-plus font-weight-bold mr-1"></i>@lang('modules.events.uploadFile')</a>
</div>
<div class="col-md-12 d-none" id="leave-file">
<x-forms.file-multiple class="mr-0"
:fieldLabel="__('app.menu.addFile')" fieldName="file"
fieldId="file-upload-dropzone" :popover="__('messages.leaveFileMessage')" />
<div class="w-100 justify-content-end d-flex mt-2">
<button id="cancel-file" type="button"
class="btn btn-secondary border-grey rounded f-14">@lang('app.cancel')</button>
</div>
</div>
<div class="col-sm-12">
<div div class="d-flex flex-wrap mt-3" id="leave-file-list">
@forelse($leave->files as $file)
<x-file-card :fileName="$file->filename" :dateAdded="$file->created_at->diffForHumans()">
@if ($file->icon == 'images')
<img src="{{ $file->file_url }}">
@else
<i class="fa {{ $file->icon }} text-lightest"></i>
@endif
<x-slot name="action">
<div class="dropdown ml-auto file-action">
<button class="btn btn-lg f-14 p-0 text-lightest text-capitalize rounded dropdown-toggle"
type="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
<i class="fa fa-ellipsis-h"></i>
</button>
<div class="dropdown-menu dropdown-menu-right border-grey rounded b-shadow-4 p-0"
aria-labelledby="dropdownMenuLink" tabindex="0">
@if ($file->icon = 'images')
<a class="cursor-pointer d-block text-dark-grey f-13 pt-3 px-3 " target="_blank"
href="{{ $file->file_url }}">@lang('app.view')</a>
@endif
<a class="cursor-pointer d-block text-dark-grey f-13 py-3 px-3 "
href="{{ route('leave-files.download', md5($file->id)) }}">@lang('app.download')</a>
<a class="cursor-pointer d-block text-dark-grey f-13 pb-3 px-3 delete-file"
data-row-id="{{ $file->id }}" href="javascript:;">@lang('app.delete')</a>
</div>
</div>
</x-slot>
</x-file-card>
@empty
<div class="col-md-12" id="no-files">
<x-cards.no-record :message="__('messages.noFileUploaded')" icon="file" />
</div>
@endforelse
</div>
</div>
</div>
<x-form-actions>
<x-forms.button-primary id="save-leave-form" class="mr-3" icon="check">@lang('app.save')
</x-forms.button-primary>
<x-forms.button-cancel :link="route('leaves.index')" class="border-0">@lang('app.cancel')
</x-forms.button-cancel>
</x-form-actions>
</div>
</x-form>
</div>
</div>
<script src="{{ asset('vendor/jquery/dropzone.min.js') }}"></script>
<script>
$(document).ready(function() {
Dropzone.autoDiscover = false;
//Dropzone class
leaveDropzone = new Dropzone("div#file-upload-dropzone", {
dictDefaultMessage: "{{ __('app.dragDrop') }}",
url: "{{ route('leave-files.store') }}",
headers: {
'X-CSRF-TOKEN': '{{ csrf_token() }}'
},
paramName: "file",
maxFilesize: DROPZONE_MAX_FILESIZE,
maxFiles: DROPZONE_MAX_FILES,
autoProcessQueue: false,
uploadMultiple: true,
addRemoveLinks: true,
parallelUploads: DROPZONE_MAX_FILES,
acceptedFiles: DROPZONE_FILE_ALLOW,
init: function() {
leaveDropzone = this;
}
});
leaveDropzone.on('sending', function(file, xhr, formData) {
var ids = "{{ $leave->id }}";
formData.append('leave_id', ids);
$.easyBlockUI();
});
leaveDropzone.on('uploadprogress', function() {
$.easyBlockUI();
});
leaveDropzone.on('queuecomplete', function() {
window.location.href = "{{ route('leaves.index') }}"
});
leaveDropzone.on('removedfile', function () {
var grp = $('div#file-upload-dropzone').closest(".form-group");
var label = $('div#file-upload-box').siblings("label");
$(grp).removeClass("has-error");
$(label).removeClass("is-invalid");
});
leaveDropzone.on('error', function (file, message) {
leaveDropzone.removeFile(file);
var grp = $('div#file-upload-dropzone').closest(".form-group");
var label = $('div#file-upload-box').siblings("label");
$(grp).find(".help-block").remove();
var helpBlockContainer = $(grp);
if (helpBlockContainer.length == 0) {
helpBlockContainer = $(grp);
}
helpBlockContainer.append('<div class="help-block invalid-feedback">' + message + '</div>');
$(grp).addClass("has-error");
$(label).addClass("is-invalid");
});
const dp1 = datepicker('#single_date', {
position: 'bl',
dateSelected: new Date("{{ str_replace('-', '/', $leave->leave_date) }}"),
...datepickerConfig
});
$('#add-file').click(function() {
$(this).addClass('d-none');
$('#leave-file').removeClass('d-none');
$('#no-files').addClass('d-none');
});
$('#cancel-file').click(function() {
$('#leave-file').toggleClass('d-none');
$('#add-file').toggleClass('d-none');
$('#no-files').toggleClass('d-none');
});
$('body').on('click', '.delete-file', function() {
var id = $(this).data('row-id');
Swal.fire({
title: "@lang('messages.sweetAlertTitle')",
text: "@lang('messages.recoverRecord')",
icon: 'warning',
showCancelButton: true,
focusConfirm: false,
confirmButtonText: "@lang('messages.confirmDelete')",
cancelButtonText: "@lang('app.cancel')",
customClass: {
confirmButton: 'btn btn-primary mr-3',
cancelButton: 'btn btn-secondary'
},
showClass: {
popup: 'swal2-noanimation',
backdrop: 'swal2-noanimation'
},
buttonsStyling: false
}).then((result) => {
if (result.isConfirmed) {
var url = "{{ route('leave-files.destroy', ':id') }}";
url = url.replace(':id', id);
var token = "{{ csrf_token() }}";
$.easyAjax({
type: 'POST',
url: url,
data: {
'_token': token,
'_method': 'DELETE'
},
success: function(response) {
if (response.status == "success") {
$('#leave-file-list').html(response.view);
}
}
});
}
});
});
$('#save-leave-form').click(function() {
const url = "{{ route('leaves.update', $leave->id) }}";
$.easyAjax({
url: url,
container: '#save-lead-data-form',
type: "POST",
disableButton: true,
blockUI: true,
buttonSelector: "#save-leave-form",
data: $('#save-lead-data-form').serialize(),
success: function(response) {
if (response.status == 'success') {
if (response.status == 'success') {
if(leaveDropzone.getQueuedFiles().length > 0) {
leaveDropzone.processQueue();
}
window.location.href = response.redirectUrl;
}
}
}
});
});
$('body').on('click', '.add-lead-type', function() {
var url = "{{ route('leaveType.create') }}";
$(MODAL_LG + ' ' + MODAL_HEADING).html('...');
$.ajaxModal(MODAL_LG, url);
});
init(RIGHT_MODAL);
});
</script>