| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207 |
- @extends('admin.table_layouts')
- @section('content')
- <div class="page-content container-fluid">
- <div class="row">
- <div class="col-xxl-9 col-lg-8 order-lg-1 order-2">
- <x-admin.table-panel :title="trans('admin.menu.customer_service.ticket')" :theads="[
- '#',
- trans('model.user.username'),
- ucfirst(trans('validation.attributes.title')),
- trans('common.status.attribute'),
- trans('common.action'),
- ]" :count="trans('admin.ticket.counts', ['num' => $ticketList->total()])" :pagination="$ticketList->links()">
- @can('admin.ticket.store')
- <x-slot:actions>
- <button class="btn btn-primary btn-animate btn-animate-side" data-toggle="modal" data-target="#add_ticket_modal">
- <span>
- <i class="icon wb-plus" aria-hidden="true"></i> {{ trans('user.ticket.new') }}
- </span>
- </button>
- </x-slot:actions>
- @endcan
- <x-slot:filters>
- <x-admin.filter.input class="col-lg-3 col-sm-6" name="username" :placeholder="trans('model.user.username')" />
- </x-slot:filters>
- <x-slot:tbody>
- @foreach ($ticketList as $ticket)
- <tr>
- <td> {{ $ticket->id }} </td>
- <td>
- @if (!$ticket->user)
- 【{{ trans('common.deleted_item', ['attribute' => trans('common.account')]) }}】
- @else
- @can('admin.user.index')
- <a href="{{ route('admin.user.index', ['id' => $ticket->user->id]) }}" target="_blank">{{ $ticket->user->username }}</a>
- @else
- {{ $ticket->user->username }}
- @endcan
- @endif
- </td>
- <td>
- {{ $ticket->title }}
- </td>
- <td>
- {!! $ticket->status_label !!}
- </td>
- <td>
- @can('admin.ticket.edit')
- <a class="btn btn-animate btn-animate-vertical btn-outline-info" href="{{ route('admin.ticket.edit', $ticket) }}">
- <span>
- @if ($ticket->status === 2)
- <i class="icon wb-eye" aria-hidden="true" style="left: 40%"> </i>{{ trans('common.view') }}
- @else
- <i class="icon wb-check" aria-hidden="true" style="left: 40%"> </i>{{ trans('common.open') }}
- @endif
- </span>
- </a>
- @endcan
- </td>
- </tr>
- @endforeach
- </x-slot:tbody>
- </x-admin.table-panel>
- </div>
- <div class="col-xxl-3 col-lg-4 order-lg-2 order-1">
- <div class="panel panel-bordered">
- <div class="panel-heading">
- <h3 class="panel-title cyan-600">
- <i class="icon wb-stats-bars"></i> {{ trans('admin.ticket.analysis_title') }}
- </h3>
- </div>
- <div class="panel-body pt-0">
- <ul class="list-group list-group-dividered list-group-full">
- <li class="list-group-item">
- <i class="icon wb-inbox"></i>
- {{ trans('admin.ticket.processed_30days') }}
- <span class="font-weight-bold float-right">
- {{ $responseStats['count'] }}
- </span>
- </li>
- @if ($responseStats['avg_time'])
- <li class="list-group-item">
- <i class="icon wb-time"></i>
- {{ trans('admin.ticket.first_response_30days') }}
- <span class="text-success font-weight-bold float-right">{{ formatTime($responseStats['avg_time']) }}</span>
- </li>
- @endif
- @if ($avgCloseTime > 0)
- <li class="list-group-item">
- <i class="icon wb-check"></i>
- {{ trans('admin.ticket.avg_processing_time_30days') }}
- <span class="text-success font-weight-bold float-right">
- {{ formatTime($avgCloseTime) }}
- </span>
- </li>
- @endif
- <li class="list-group-item">
- <i class="icon wb-chat-text blue-700"></i>
- {{ trans('admin.ticket.today_new') }}
- <span class="font-weight-bold float-right">
- <span class="text-info">{{ $todayTicketCount }}</span>
- </span>
- </li>
- <li class="list-group-item">
- <i class="icon wb-chat-working red-700"></i>
- {{ trans('admin.ticket.pending_tickets') }}
- <span class="font-weight-bold text-danger float-right">
- {{ $ticketStats['pending'] }}
- </span>
- </li>
- <li class="list-group-item">
- <i class="icon wb-chat green-700"></i>
- {{ trans('admin.ticket.total_tickets') }}
- <span class="font-weight-bold text-primary float-right">
- {{ $ticketStats['total'] }}
- </span>
- </li>
- </ul>
- </div>
- </div>
- </div>
- </div>
- </div>
- @can('admin.ticket.store')
- <x-ui.modal id="add_ticket_modal" :title="trans('user.ticket.new')" size="lg" position="center" :keyboard="false">
- <div class="form-group row">
- <label class="col-2 col-form-label" for="userId">{{ trans('model.user.attribute') }}</label>
- <div class="input-group col-10">
- <input class="form-control col-md-4" id="uid" name="uid" type="number" placeholder="{{ trans('model.user.id') }}" />
- <div class="input-group-prepend">
- <span class="input-group-text">{{ trans('common.or') }}</span>
- </div>
- <input class="form-control col-md-8" id="username" name="username" type="text" placeholder="{{ trans('model.user.username') }}" />
- </div>
- </div>
- <div class="form-group">
- <input class="form-control" id="title" name="title" type="text" placeholder="{{ ucfirst(trans('validation.attributes.title')) }}">
- </div>
- <div class="form-group">
- <textarea class="form-control" id="content" name="content" type="text" rows="5" placeholder="{{ ucfirst(trans('validation.attributes.content')) }}"></textarea>
- </div>
- <x-slot:actions>
- <button class="btn btn-success" data-dismiss="modal" type="button" onclick="createTicket()"> {{ trans('common.confirm') }} </button>
- </x-slot:actions>
- </x-ui.modal>
- @endcan
- @endsection
- @push('javascript')
- <script>
- @can('admin.ticket.store')
- // 发起工单
- function createTicket() {
- const uid = $("#uid").val();
- const username = $("#username").val();
- const title = $("#title").val();
- const content = $("#content").val();
- if (uid.trim() === "" && username.trim() === "") {
- showMessage({
- title: '{{ trans('admin.ticket.send_to') }}',
- icon: "warning"
- });
- return false;
- }
- if (title.trim() === "") {
- showMessage({
- title: '{{ ucfirst(trans('validation.required', ['attribute' => trans('validation.attributes.title')])) }}',
- icon: "warning"
- });
- return false;
- }
- if (content.trim() === "") {
- showMessage({
- title: '{{ ucfirst(trans('validation.required', ['attribute' => trans('validation.attributes.content')])) }}',
- icon: "warning"
- });
- return false;
- }
- showConfirm({
- title: '{{ trans('user.ticket.submit_tips') }}',
- onConfirm: function() {
- ajaxPost("{{ route('admin.ticket.store') }}", {
- uid: uid,
- username: username,
- title: title,
- content: content
- }, {
- success: function(ret) {
- $("#add_ticket_modal").modal("hide");
- handleResponse(ret);
- },
- error: function(xhr) {
- $("#add_ticket_modal").modal("hide");
- handleErrors(xhr);
- }
- });
- }
- });
- }
- @endcan
- </script>
- @endpush
|