czt
2026-02-03 e67f52078602f3efb6da02ef8fc8cf0cf7fa7e7a
fzzy-igdss-web/src/main/resources/templates/monitor/operlog/operlog.html
@@ -1,188 +1,216 @@
<!DOCTYPE html>
<html lang="zh" xmlns:th="http://www.thymeleaf.org" xmlns:shiro="http://www.pollix.at/thymeleaf/shiro">
<head>
   <th:block th:include="include :: header('操作日志列表')" />
   <th:block th:include="include :: bootstrap-select-css" />
    <th:block th:include="include :: header('操作日志列表')"/>
    <th:block th:include="include :: bootstrap-select-css"/>
</head>
<body class="gray-bg">
   <div class="container-div">
      <div class="row">
         <div class="col-sm-12 search-collapse">
            <form id="operlog-form">
               <div class="select-list">
                  <ul>
                     <li>
                        <label>操作地址:</label><input type="text" name="operIp"/>
                     </li>
                     <li>
                        <label>系统模块: </label><input type="text" name="title"/>
                     </li>
                     <li>
                        <label>操作人员: </label><input type="text" name="operName"/>
                     </li>
                     <li class="select-selectpicker">
                        <label>操作类型: </label><select id="businessTypes" name="businessTypes" th:with="type=${@dict.getType('sys_oper_type')}" class="selectpicker" data-none-selected-text="请选择" multiple>
                           <option th:each="dict : ${type}" th:text="${dict.dictLabel}" th:value="${dict.dictValue}"></option>
                        </select>
                     </li>
                     <li>
                        <label>操作状态:</label><select name="status" th:with="type=${@dict.getType('sys_common_status')}">
                           <option value="">所有</option>
                           <option th:each="dict : ${type}" th:text="${dict.dictLabel}" th:value="${dict.dictValue}"></option>
                        </select>
                     </li>
                     <li class="select-time">
                        <label>操作时间: </label>
                        <input type="text" class="time-input" id="startTime" placeholder="开始时间"/>
                        <span>-</span>
                        <input type="text" class="time-input" id="endTime" placeholder="结束时间"/>
                     </li>
                     <li>
                        <a class="btn btn-primary btn-rounded btn-sm" onclick="searchPre()"><i class="fa fa-search"></i>&nbsp;搜索</a>
                        <a class="btn btn-warning btn-rounded btn-sm" onclick="resetPre()"><i class="fa fa-refresh"></i>&nbsp;重置</a>
                     </li>
                  </ul>
               </div>
            </form>
         </div>
         <div class="btn-group-sm" id="toolbar" role="group">
            <a class="btn btn-danger multiple disabled" onclick="$.operate.removeAll()" shiro:hasPermission="monitor:operlog:remove">
                  <i class="fa fa-remove"></i> 删除
              </a>
              <a class="btn btn-danger" onclick="$.operate.clean()" shiro:hasPermission="monitor:operlog:remove">
                   <i class="fa fa-trash"></i> 清空
               </a>
               <a class="btn btn-warning" onclick="$.table.exportExcel()" shiro:hasPermission="monitor:operlog:export">
                  <i class="fa fa-download"></i> 导出
              </a>
           </div>
         <div class="col-sm-12 select-table table-striped">
            <table id="bootstrap-table"></table>
         </div>
      </div>
   </div>
   <th:block th:include="include :: footer" />
   <th:block th:include="include :: bootstrap-select-js" />
   <script th:inline="javascript">
      var detailFlag = [[${@permission.hasPermi('monitor:operlog:detail')}]];
      var datas = [[${@dict.getType('sys_oper_type')}]];
      var prefix = ctx + "monitor/operlog";
<div class="container-div">
    <div class="row">
        <div class="col-sm-12 search-collapse">
            <form id="operlog-form">
                <div class="select-list">
                    <ul>
                        <li>
                            <label>操作地址:</label><input type="text" name="operIp"/>
                        </li>
                        <li>
                            <label>系统模块: </label><input type="text" name="title"/>
                        </li>
                        <li class="select-selectpicker">
                            <label>业务类型: </label>
                            <select id="bizType" name="bizType"
                                    class="selectpicker" data-none-selected-text="请选择">
                                <option value="">所有</option>
                                <option th:each="dict : ${bizTypeDatas}" th:text="${dict.dictLabel}"
                                        th:value="${dict.dictValue}"></option>
                            </select>
                        </li>
                        <li>
                            <label>操作人员: </label><input type="text" name="operName"/>
                        </li>
                        <li class="select-selectpicker">
                            <label>操作类型: </label><select id="businessTypes" name="businessTypes"
                                                             th:with="type=${@dict.getType('sys_oper_type')}"
                                                             class="selectpicker" data-none-selected-text="请选择"
                                                             multiple>
                            <option th:each="dict : ${type}" th:text="${dict.dictLabel}"
                                    th:value="${dict.dictValue}"></option>
                        </select>
                        </li>
                        <li>
                            <label>操作状态:</label><select name="status"
                                                            th:with="type=${@dict.getType('sys_common_status')}">
                            <option value="">所有</option>
                            <option th:each="dict : ${type}" th:text="${dict.dictLabel}"
                                    th:value="${dict.dictValue}"></option>
                        </select>
                        </li>
                        <li class="select-time">
                            <label>操作时间: </label>
                            <input type="text" class="time-input" id="startTime" placeholder="开始时间"/>
                            <span>-</span>
                            <input type="text" class="time-input" id="endTime" placeholder="结束时间"/>
                        </li>
                        <li>
                            <a class="btn btn-primary btn-rounded btn-sm" onclick="searchPre()"><i
                                    class="fa fa-search"></i>&nbsp;搜索</a>
                            <a class="btn btn-warning btn-rounded btn-sm" onclick="resetPre()"><i
                                    class="fa fa-refresh"></i>&nbsp;重置</a>
                        </li>
                    </ul>
                </div>
            </form>
        </div>
      $(function() {
          var options = {
              url: prefix + "/list",
              cleanUrl: prefix + "/clean",
              detailUrl: prefix + "/detail/{id}",
              removeUrl: prefix + "/remove",
              exportUrl: prefix + "/export",
              queryParams: queryParams,
              sortName: "operTime",
              sortOrder: "desc",
              modalName: "操作日志",
              escape: true,
              showPageGo: true,
              rememberSelected: true,
              columns: [{
                 field: 'state',
                  checkbox: true
              },
              {
                  field: 'operId',
                  title: '日志编号'
              },
              {
                  field: 'title',
                  title: '系统模块',
                    formatter: function(value, row, index) {
        <div class="btn-group-sm" id="toolbar" role="group">
            <a class="btn btn-danger multiple disabled" onclick="$.operate.removeAll()"
               shiro:hasPermission="monitor:operlog:remove">
                <i class="fa fa-remove"></i> 删除
            </a>
            <a class="btn btn-danger" onclick="$.operate.clean()" shiro:hasPermission="monitor:operlog:remove">
                <i class="fa fa-trash"></i> 清空
            </a>
            <a class="btn btn-warning" onclick="$.table.exportExcel()" shiro:hasPermission="monitor:operlog:export">
                <i class="fa fa-download"></i> 导出
            </a>
        </div>
        <div class="col-sm-12 select-table table-striped">
            <table id="bootstrap-table"></table>
        </div>
    </div>
</div>
<th:block th:include="include :: footer"/>
<th:block th:include="include :: bootstrap-select-js"/>
<script th:inline="javascript">
    var detailFlag = [[${@permission.hasPermi('monitor:operlog:detail')}]];
    var datas = [[${@dict.getType('sys_oper_type')}]];
    var bizTypeDatas = [[${bizTypeDatas}]];
    var prefix = ctx + "monitor/operlog";
    $(function () {
        var options = {
            url: prefix + "/list",
            cleanUrl: prefix + "/clean",
            detailUrl: prefix + "/detail/{id}",
            removeUrl: prefix + "/remove",
            exportUrl: prefix + "/export",
            queryParams: queryParams,
            sortName: "operTime",
            sortOrder: "desc",
            modalName: "操作日志",
            escape: true,
            showPageGo: true,
            rememberSelected: true,
            columns: [{
                field: 'state',
                checkbox: true
            },
                {
                    field: 'operId',
                    title: '日志编号'
                },
                {
                    field: 'title',
                    title: '系统模块',
                    formatter: function (value, row, index) {
                        return $.table.tooltip(value);
                    }
                },
              {
                  field: 'businessType',
                  title: '操作类型',
                  align: 'center',
                  formatter: function(value, row, index) {
                      return $.table.selectDictLabel(datas, value);
                  }
              },
              {
                  field: 'operName',
                  title: '操作人员',
                  sortable: true
              },
              {
                  field: 'deptName',
                  title: '部门名称'
              },
              {
                  field: 'operIp',
                  title: '操作地址'
              },
              {
                  field: 'operLocation',
                  title: '操作地点'
              },
              {
                  field: 'status',
                  title: '操作状态',
                  align: 'center',
                  formatter: function(value, row, index) {
                      if (value == 0) {
                          return '<span class="badge badge-primary">成功</span>';
                      } else if (value == 1) {
                          return '<span class="badge badge-danger">失败</span>';
                      }
                  }
              },
              {
                  field: 'operTime',
                  title: '操作时间',
                  sortable: true
              },
              {
                  field: 'costTime',
                  title: '消耗时间',
                  sortable: true,
                  formatter: function(value, row, index) {
                      return $.common.sprintf("%s毫秒", value);
                  }
              },
              {
                  title: '操作',
                  align: 'center',
                  formatter: function(value, row, index) {
                      var actions = [];
                      actions.push('<a class="btn btn-warning btn-xs ' + detailFlag + '" href="javascript:void(0)" onclick="$.operate.detail(\'' + row.operId + '\')"><i class="fa fa-search"></i>详细</a>');
                      return actions.join('');
                  }
              }]
          };
          $.table.init(options);
      });
      function queryParams(params) {
         var search = $.table.queryParams(params);
         search.params = {
             beginTime : beginOfTime($("#startTime").val()),
             endTime : endOfTime($("#endTime").val())
         };
         search.businessTypes = $.common.join($('#businessTypes').selectpicker('val'));
         return search;
      }
      function searchPre() {
          $.table.search('operlog-form', 'bootstrap-table');
      }
      function resetPre() {
         resetDate();
         $("#operlog-form")[0].reset();
         $("#businessTypes").selectpicker('refresh');
         $.table.search('operlog-form', 'bootstrap-table', 1);
      }
   </script>
                {
                    field: 'businessType',
                    title: '操作类型',
                    align: 'center',
                    formatter: function (value, row, index) {
                        return $.table.selectDictLabel(datas, value);
                    }
                },
                {
                    field: 'bizType',
                    title: '业务类型',
                    align: 'center',
                    formatter: function (value, row, index) {
                        return $.table.selectDictLabel(bizTypeDatas, value);
                    }
                },
                {
                    field: 'operName',
                    title: '操作人员',
                    sortable: true
                },
                {
                    field: 'deptName',
                    title: '部门名称'
                },
                {
                    field: 'operIp',
                    title: '操作地址'
                },
                {
                    field: 'operLocation',
                    title: '操作地点'
                },
                {
                    field: 'status',
                    title: '操作状态',
                    align: 'center',
                    formatter: function (value, row, index) {
                        if (value == 0) {
                            return '<span class="badge badge-primary">成功</span>';
                        } else if (value == 1) {
                            return '<span class="badge badge-danger">失败</span>';
                        }
                    }
                },
                {
                    field: 'operTime',
                    title: '操作时间',
                    sortable: true
                },
                {
                    field: 'costTime',
                    title: '消耗时间',
                    sortable: true,
                    formatter: function (value, row, index) {
                        return $.common.sprintf("%s毫秒", value);
                    }
                },
                {
                    title: '操作',
                    align: 'center',
                    formatter: function (value, row, index) {
                        var actions = [];
                        actions.push('<a class="btn btn-warning btn-xs ' + detailFlag + '" href="javascript:void(0)" onclick="$.operate.detail(\'' + row.operId + '\')"><i class="fa fa-search"></i>详细</a>');
                        return actions.join('');
                    }
                }]
        };
        $.table.init(options);
    });
    function queryParams(params) {
        var search = $.table.queryParams(params);
        search.params = {
            beginTime: beginOfTime($("#startTime").val()),
            endTime: endOfTime($("#endTime").val())
        };
        search.businessTypes = $.common.join($('#businessTypes').selectpicker('val'));
        return search;
    }
    function searchPre() {
        $.table.search('operlog-form', 'bootstrap-table');
    }
    function resetPre() {
        resetDate();
        $("#operlog-form")[0].reset();
        $("#businessTypes").selectpicker('refresh');
        $.table.search('operlog-form', 'bootstrap-table', 1);
    }
</script>
</body>
</html>