File "edit.blade.php"
Full Path: /home/clickysoft/public_html/jmapi5.clickysoft.net/resources/views/admin/users/edit.blade.php
File size: 8.81 KB
MIME-type: text/plain
Charset: utf-8
@extends('layouts.admin')
@section('content')
<div class="card">
<div class="card-header">
{{ trans('global.edit') }} {{ trans('cruds.user.title_singular') }}
</div>
<div class="card-body">
<form method="POST" action="{{ route("admin.users.update", [$user->id]) }}" enctype="multipart/form-data">
@method('PUT')
@csrf
<div class="form-group">
<label class="required" for="name">{{ trans('cruds.user.fields.name') }}</label>
<input class="form-control {{ $errors->has('name') ? 'is-invalid' : '' }}" type="text" name="name" id="name" value="{{ old('name', $user->name) }}" required>
@if($errors->has('name'))
<span class="text-danger">{{ $errors->first('name') }}</span>
@endif
<span class="help-block">{{ trans('cruds.user.fields.name_helper') }}</span>
</div>
<div class="form-group">
<label class="required" for="email">{{ trans('cruds.user.fields.email') }}</label>
<input class="form-control {{ $errors->has('email') ? 'is-invalid' : '' }}" type="email" name="email" id="email" value="{{ old('email', $user->email) }}" required>
@if($errors->has('email'))
<span class="text-danger">{{ $errors->first('email') }}</span>
@endif
<span class="help-block">{{ trans('cruds.user.fields.email_helper') }}</span>
</div>
<div class="form-group">
<label class="required" for="password">{{ trans('cruds.user.fields.password') }}</label>
<input class="form-control {{ $errors->has('password') ? 'is-invalid' : '' }}" type="password" name="password" id="password">
@if($errors->has('password'))
<span class="text-danger">{{ $errors->first('password') }}</span>
@endif
<span class="help-block">{{ trans('cruds.user.fields.password_helper') }}</span>
</div>
<div class="form-group">
<label for="profile_image">{{ trans('cruds.user.fields.profile_image') }}</label>
<div class="needsclick dropzone {{ $errors->has('profile_image') ? 'is-invalid' : '' }}" id="profile_image-dropzone">
</div>
@if($errors->has('profile_image'))
<span class="text-danger">{{ $errors->first('profile_image') }}</span>
@endif
<span class="help-block">{{ trans('cruds.user.fields.profile_image_helper') }}</span>
</div>
<div class="form-group">
<label class="required" for="roles">{{ trans('cruds.user.fields.roles') }}</label>
<div style="padding-bottom: 4px">
<span class="btn btn-info btn-xs select-all" style="border-radius: 0">{{ trans('global.select_all') }}</span>
<span class="btn btn-info btn-xs deselect-all" style="border-radius: 0">{{ trans('global.deselect_all') }}</span>
</div>
<select class="form-control select2 {{ $errors->has('roles') ? 'is-invalid' : '' }}" name="roles[]" id="roles" multiple required>
@foreach($roles as $id => $role)
<option value="{{ $id }}" {{ (in_array($id, old('roles', [])) || $user->roles->contains($id)) ? 'selected' : '' }}>{{ $role }}</option>
@endforeach
</select>
@if($errors->has('roles'))
<span class="text-danger">{{ $errors->first('roles') }}</span>
@endif
<span class="help-block">{{ trans('cruds.user.fields.roles_helper') }}</span>
</div>
<div class="form-group">
<label class="required">{{ trans('cruds.user.fields.user_type') }}</label>
@foreach(App\Models\User::USER_TYPE_RADIO as $key => $label)
<div class="form-check {{ $errors->has('user_type') ? 'is-invalid' : '' }}">
<input class="form-check-input" type="radio" id="user_type_{{ $key }}" name="user_type" value="{{ $key }}" {{ old('user_type', $user->user_type) === (string) $key ? 'checked' : '' }} required>
<label class="form-check-label" for="user_type_{{ $key }}">{{ $label }}</label>
</div>
@endforeach
@if($errors->has('user_type'))
<span class="text-danger">{{ $errors->first('user_type') }}</span>
@endif
<span class="help-block">{{ trans('cruds.user.fields.user_type_helper') }}</span>
</div>
<div class="form-group">
<label for="clock_in">{{ trans('cruds.user.fields.clock_in') }}</label>
<input class="form-control timepicker {{ $errors->has('clock_in') ? 'is-invalid' : '' }}" type="text" name="clock_in" id="clock_in" value="{{ old('clock_in', $user->clock_in) }}">
@if($errors->has('clock_in'))
<span class="text-danger">{{ $errors->first('clock_in') }}</span>
@endif
<span class="help-block">{{ trans('cruds.user.fields.clock_in_helper') }}</span>
</div>
<div class="form-group">
<label for="clock_out">{{ trans('cruds.user.fields.clock_out') }}</label>
<input class="form-control timepicker {{ $errors->has('clock_out') ? 'is-invalid' : '' }}" type="text" name="clock_out" id="clock_out" value="{{ old('clock_out', $user->clock_out) }}">
@if($errors->has('clock_out'))
<span class="text-danger">{{ $errors->first('clock_out') }}</span>
@endif
<span class="help-block">{{ trans('cruds.user.fields.clock_out_helper') }}</span>
</div>
<div class="form-group">
<label class="required">{{ trans('cruds.user.fields.status') }}</label>
@foreach(App\Models\User::STATUS_RADIO as $key => $label)
<div class="form-check {{ $errors->has('status') ? 'is-invalid' : '' }}">
<input class="form-check-input" type="radio" id="status_{{ $key }}" name="status" value="{{ $key }}" {{ old('status', $user->status) === (string) $key ? 'checked' : '' }} required>
<label class="form-check-label" for="status_{{ $key }}">{{ $label }}</label>
</div>
@endforeach
@if($errors->has('status'))
<span class="text-danger">{{ $errors->first('status') }}</span>
@endif
<span class="help-block">{{ trans('cruds.user.fields.status_helper') }}</span>
</div>
<div class="form-group">
<button class="btn btn-danger" type="submit">
{{ trans('global.save') }}
</button>
</div>
</form>
</div>
</div>
@endsection
@section('scripts')
<script>
Dropzone.options.profileImageDropzone = {
url: '{{ route('admin.users.storeMedia') }}',
maxFilesize: 2, // MB
acceptedFiles: '.jpeg,.jpg,.png,.gif',
maxFiles: 1,
addRemoveLinks: true,
headers: {
'X-CSRF-TOKEN': "{{ csrf_token() }}"
},
params: {
size: 2,
width: 4096,
height: 4096
},
success: function (file, response) {
$('form').find('input[name="profile_image"]').remove()
$('form').append('<input type="hidden" name="profile_image" value="' + response.name + '">')
},
removedfile: function (file) {
file.previewElement.remove()
if (file.status !== 'error') {
$('form').find('input[name="profile_image"]').remove()
this.options.maxFiles = this.options.maxFiles + 1
}
},
init: function () {
@if(isset($user) && $user->profile_image)
var file = {!! json_encode($user->profile_image) !!}
this.options.addedfile.call(this, file)
this.options.thumbnail.call(this, file, file.preview ?? file.preview_url)
file.previewElement.classList.add('dz-complete')
$('form').append('<input type="hidden" name="profile_image" value="' + file.file_name + '">')
this.options.maxFiles = this.options.maxFiles - 1
@endif
},
error: function (file, response) {
if ($.type(response) === 'string') {
var message = response //dropzone sends it's own error messages in string
} else {
var message = response.errors.file
}
file.previewElement.classList.add('dz-error')
_ref = file.previewElement.querySelectorAll('[data-dz-errormessage]')
_results = []
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
node = _ref[_i]
_results.push(node.textContent = message)
}
return _results
}
}
</script>
@endsection