Layui+larave-log-view日誌頁面調整

FLaravel發表於2018-12-12

日誌外掛配置layui資料表格
介面效果

@extends('layouts.admin')
@section('content')
<div class="layui-fluid">
    <div class="layui-card">
      <div class="layui-form layui-card-header layuiadmin-card-header-auto">
        <div class="layui-form-item">
          <div class="layui-inline">
            <label class="layui-form-label">日誌檔案</label>
            <div class="layui-input-block">
              <select id="logfile" name="top" lay-filter="file" data-type="changeLogfile">
                    @foreach($data['files'] as $file)
                      <option value="{{ $file }}" @if($data['current_file'] == $file) selected @endif>{{ $file }}</option>
                    @endforeach
              </select>
            </div>
        </div>
      </div>
       <div class="layui-card-body">
            <table id="LAY-mmk-common-data" lay-filter="LAY-mmk-common-data"
                data-url="{{ route('get_logs') }}"
                lay-contentType='application/json'
                data-field="{{ json_encode([
                    ['field'=>'level','title'=>'錯誤等級','width'=>150,"templet"=>'#level'],
                    ['field'=>'level_img','hide'=>true],
                    ['field'=>'level_class','hide'=>true],
                    ['field'=>'context','title'=>'Context','width'=>100],
                    ['field'=>'date','title'=>'日期','width'=>200,'sort'=>true],
                    ['field'=>'text','title'=>'內容',"templet"=>'#context'],
                ])}}"
                data-toolbar="buttons"
            ></table>
       </div>
  </div>
@endsection

@section('js')
    {{-- 設定 錯誤等級樣式 --}}
    <script type="text/html" id="level">
        @{{#  if(d.level_class == 'danger'){ }}
           <span style="color:#FF5722" class="fa fa-@{{ d.level_img }}" aria-hidden="true">  @{{ d.level }}</span>
        @{{#  } else if(d.level_class == 'warning') { }}
           <span style="color:#FFB800" class="fa fa-@{{ d.level_img }}" aria-hidden="true">  @{{ d.level }}</span>
        @{{#  } else { }}
          <span style="color:#5FB878" class="fa fa-@{{ d.level_img }}" aria-hidden="true">  @{{ d.level }}</span>
        @{{#  } }}
    </script>

    {{-- 工具欄按鈕 --}}
    <script type="text/html" id="buttons">
      <div class="layui-btn-container">
        <button class="layui-btn layui-btn-sm" lay-event="Downloadfile" >下載檔案</button>
        <button class="layui-btn layui-btn-sm" lay-event="CleanFile">清空檔案</button>
        <button class="layui-btn layui-btn-sm" lay-event="DeleteFile">刪除檔案</button>
        <button class="layui-btn layui-btn-sm" lay-event="DeleteFileAll">刪除所有Log</button>
      </div>
    </script>

    <script type="text/javascript">
        layui.use(['form','table'],function(){
            var form = layui.form;
            var table = layui.table

            form.on('select(file)',function(data){
                var type = $(data.elem).data('type');
                active[type] ? active[type].call(this,data.value) : '';
            })

            var active =  {
                changeLogfile: function(file){
                  //執行過載
                  table.reload('LAY-mmk-common-data', {
                    page: {
                      curr: 1 //重新從第 1 頁開始
                    }
                    ,url:"{{ route('get_logs') }}?l="+file
                  });
                },
                ajaxs:function(current_file,type){
                    if(type == 'dl')
                    {
                        location.href = '{{ route('get_logs') }}?'+type+"="+current_file;
                    }else{
                        layer.confirm('Are you sure?',{
                            offset: '100px'
                        },function(){
                            var ajax_lod = layer.load(1);
                            $.ajax({
                                type:"GET",
                                url:'{{ route('get_logs') }}?'+type+"="+current_file,
                                data:{
                                    _token:'{{ csrf_token() }}'
                                },
                                dataType: "json",
                                success: function(data){
                                    layer.close(ajax_lod);
                                    if(data.status == 1)
                                    {
                                        layer.msg(data.msg,{icon: 1,offset: '100px'})
                                    }
                                    setTimeout(function(){ location.reload() }, 500);
                                }
                                ,error:function(XMLHttpRequest, textStatus, errorThrow){
                                    layer.close(ajax_lod);
                                    var ret_json = XMLHttpRequest.responseJSON;
                                    layer.msg('請求失敗,系統異常:'+ret_json.message,{icon: 5,anim:6,offset: '100px'})
                                }
                            });
                        })
                    }
                }
            }

            //工具頭監聽
            table.on('toolbar(LAY-mmk-common-data)', function(obj){
                var checkStatus = table.checkStatus(obj.config.id);
                switch(obj.event){
                  case 'Downloadfile':
                      active.ajaxs.call(this,$('#logfile').val(),'dl')
                  break;
                  case 'CleanFile':
                    active.ajaxs.call(this,$('#logfile').val(),'clean')
                  break;
                  case 'DeleteFile':
                    active.ajaxs.call(this,$('#logfile').val(),'del')
                    break;
                  case 'DeleteFileAll':
                    active.ajaxs.call(this,$('#logfile').val(),'delall')
                  break;
                };
            });
        });
    </script>
@endsection
本作品採用《CC 協議》,轉載必須註明作者和本文連結

相關文章