1 |
- {"remainingRequest":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/vue-loader/lib/index.js??vue-loader-options!/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/src/views/system/menu/index.vue?vue&type=template&id=0304e458&scoped=true","dependencies":[{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/src/views/system/menu/index.vue","mtime":1708395041891},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/cache-loader/dist/cjs.js","mtime":1708395146433},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/vue-loader/lib/loaders/templateLoader.js","mtime":1708395147801},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/cache-loader/dist/cjs.js","mtime":1708395146433},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/vue-loader/lib/index.js","mtime":1708395147382}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:
<div class="dashboard-container">
  <div class="search-content">
    <el-input clearable style="width: 220px;" placeholder="请输入菜单名称" v-model="searchData.menuName"></el-input>
    <el-select style="width: 220px;" clearable placeholder="请选择状态" v-model="searchData.status">
      <el-option v-for="item in statusOptions" :key="item.value" :label="item.label" :value="item.value">
      </el-option>
    </el-select>
    <div class="search-btn">
      <div class="search" @click="handleQuery">查询</div>
      <div class="reset" @click="resetSearchData()">重置</div>
    </div>
  </div>
  <div class="table-content">
    <div class="btn" @click="handleAdd()">
      <span class="icon font_family">&#xe604;</span>
      新增
    </div>
    <div class="btn" @click="exportExcel">
      <span class="icon font_family">&#xe605;</span>
      <a>导出</a>
    </div>
    <el-table :indent="50" v-loading="loading" :data="menuList" stripe ref="tableRef" row-key="menuId"
      :default-expand-all="false" :tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
      highlight-current-row style="width: 100%;">
      <el-table-column prop="menuName" label="菜单名称" :show-overflow-tooltip="true" width="300"></el-table-column>
      <el-table-column prop="icon" label="图标" align="center" width="100">
        <template slot-scope="scope">
          <svg-icon style="color: #1096DB;" :icon-class="scope.row.icon" />
        </template>
      </el-table-column>
      <el-table-column prop="orderNum" label="排序" width="60"></el-table-column>
      <el-table-column prop="perms" label="权限标识" :show-overflow-tooltip="true"></el-table-column>
      <el-table-column prop="component" label="组件路径" :show-overflow-tooltip="true"></el-table-column>
      <el-table-column prop="status" label="状态" width="80">
        <!-- <template #default="scope">
          <dict-tag :options="sys_normal_disable" :value="scope.row.status" />
        </template> -->
        <template slot-scope="scope">
          <div class="startUsing" v-if="scope.row.status == '1'">启用</div>
          <div class="Deactivate" v-else>停用</div>
        </template>
      </el-table-column>
      <el-table-column label="创建时间" align="center" prop="createTime" width="170">
        <template #default="scope">
          <span>{{ parseTime(scope.row.createTime) }}</span>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" width="200" class-name="small-padding fixed-width">
        <template #default="scope">
          <el-button type="text" style="color: #2866DD;" @click="handleUpdate(scope.row)"
            v-hasPermi="['system:menu:edit']">修改</el-button>
          <el-divider direction="vertical"></el-divider>
          <el-button type="text" style="color: #2866DD;" @click="handleAdd(scope.row)">新增</el-button>
          <el-divider direction="vertical"></el-divider>
          <el-button type="text" style="color: #2866DD;" @click="delMenu(scope.row)"
            v-hasPermi="['system:menu:remove']">删除</el-button>
        </template>
      </el-table-column>
      <template v-slot:empty>
        <svg-icon icon-class="search-none" style="font-size: 64px;" />
        <p>暂无数据</p>
      </template>
    </el-table>
    <!-- 修改菜单对话框 -->
    <el-dialog center @close="cancel" :title="title" v-if='this.open' :visible.sync="open" width="636px"
      :before-close="handleClose" append-to-body>
      <div class="dialog_box" style="height: 502px;overflow: auto;">
        <el-form label-width="100px" ref="editMenuRef" :model="form" :rules="rules" label-position="right">
          <el-form-item v-if="form.parentId !== 0" label="上级菜单" prop="parentName" key="parentName">
            <el-select style="width: 340px;" clearable v-model="form.parentName" placeholder="选择上级菜单">
              <el-option :key="form.parentId" :value="menuOptions.id" :label="menuOptions.label" hidden />
              <el-tree :data="menuOptions" :props="defaultProps" :node-key="menuOptions.id" accordion highlight-current
                @node-click="handleNodeClick" /></el-select>
          </el-form-item>
          <el-form-item label="菜单类型" prop="menuType" key="menuType">
            <el-radio-group v-model="form.menuType">
              <el-radio label="M">目录</el-radio>
              <el-radio label="C">菜单</el-radio>
              <el-radio label="F">按钮</el-radio>
            </el-radio-group>
          </el-form-item>
          <el-form-item v-if="form.menuType != 'F'" label="菜单图标" prop="icon">
            <el-popover width="290" trigger="click">
              <div class="svgList">
                <el-tabs v-model="activeName" type="card">
                  <el-tab-pane v-for="item in titleData" :label="item.title" :name="item.index">
                    <svg-icon style="display: inline-block;margin-right: 5px;" @click="editSvg(items)"
                      v-for="items in svgData[item.index - 1]" :icon-class="items" />
                  </el-tab-pane>
                </el-tabs>
              </div>
              <el-input style="width: 340px;" slot="reference" placeholder="请选择菜单图标" v-model="form.icon">
                <template #prefix>
                  <svg-icon v-if="form.icon" :icon-class="form.icon" class="el-input__icon"
                    style="height: 32px;width: 16px;position: relative;top: 5px;left: 5px;" />
                  <el-icon v-else style="height: 32px;width: 16px;position: relative;top: 5px;left: 5px;">
                    <search />
                  </el-icon>
                </template></el-input>
            </el-popover>
          </el-form-item>
          <el-form-item label="菜单名称" prop="menuName" key="menuName">
            <el-input style="width: 340px;" v-model="form.menuName" placeholder="请输入菜单名称" />
          </el-form-item>
          <el-form-item label="显示排序" prop="orderNum" key="orderNum">
            <el-input-number placeholder="请输入显示排序" v-model="form.orderNum" controls-position="right" :step="1" style="width: 340px;"
              :min="1" />
          </el-form-item>
          <el-form-item label="是否外链" v-if="form.menuType != 'F'" key="isFrame">
            <el-radio-group v-model="form.isFrame">
              <el-radio label="1">是</el-radio>
              <el-radio label="2">否</el-radio>
            </el-radio-group>
          </el-form-item>
          <el-form-item label="路由地址" prop="path" key="path">
            <el-input style="width: 340px;" v-model="form.path" placeholder="请输入路由地址" />
          </el-form-item>
          <el-form-item label="组件路径" v-if="form.menuType == 'C'" prop="component" key="component">
            <el-input style="width: 340px;" v-model="form.component" placeholder="请输入组件路径" />
          </el-form-item>
          <el-form-item label="权限字符" v-if="form.menuType != 'M'" prop="perms" key="perms">
            <el-input style="width: 340px;" v-model="form.perms" placeholder="请输入权限标识" maxlength="100" />
          </el-form-item>
          <el-form-item label="路由参数" v-if="form.menuType == 'C'" key="query">
            <el-input style="width: 340px;" v-model="form.query" placeholder="请输入路由参数" maxlength="255" />
          </el-form-item>
          <el-form-item label="是否缓存" v-if="form.menuType == 'C'" key="isCache">
            <el-radio-group v-model="form.isCache">
              <el-radio-button label="1">缓存</el-radio-button>
              <el-radio-button label="2">不缓存</el-radio-button>
            </el-radio-group>
          </el-form-item>
          <el-form-item label="显示状态" v-if="form.menuType != 'F'" key="visible">
            <el-radio-group v-model="form.visible">
              <el-radio-button label="1">显示</el-radio-button>
              <el-radio-button label="2">隐藏</el-radio-button>
            </el-radio-group>
          </el-form-item>
          <el-form-item label="菜单状态" v-if="form.menuType != 'F'" key="status">
            <el-radio-group v-model="form.status">
              <el-radio-button label="1">启用</el-radio-button>
              <el-radio-button label="2">停用</el-radio-button>
            </el-radio-group>
          </el-form-item>
        </el-form>
      </div>
      <template #footer>
        <div class="dialog-footer">
          <div class="search" @click="editMenu">保 存</div>
          <div class="reset" @click="cancel()">取 消</div>
        </div>
      </template>
    </el-dialog>
    <!-- 添加菜单对话框 -->
    <el-dialog center :title="addMenuTitle" v-if='this.addMenuOpen' :visible.sync="addMenuOpen" width="636px"
      :before-close="handleClose" append-to-body>
      <div class="dialog_box" style="height: 502px;overflow: auto;">
        <el-form label-width="100px" ref="addMenuRef" :model="addMenuForm" :rules="addRules" label-position="right">
          <el-form-item v-if="isShoeParentName" label="上级菜单" prop="parentName" key="parentName">
            <el-select style="width: 340px;" :disabled="true" clearable v-model="addMenuForm.parentName"
              placeholder="选择上级菜单">
              <el-option :key="addMenuForm.parentId" :value="menuOptions.id" :label="menuOptions.label" hidden />
              <el-tree :data="menuOptions" :props="defaultProps" :node-key="menuOptions.id" accordion highlight-current
                @node-click="handleNodeClick" /></el-select>
          </el-form-item>
          <el-form-item label="菜单类型" prop="menuType" key="menuType">
            <el-radio-group v-model="addMenuForm.menuType">
              <el-radio label="M">目录</el-radio>
              <el-radio label="C">菜单</el-radio>
              <el-radio label="F">按钮</el-radio>
            </el-radio-group>
          </el-form-item>
          <el-form-item v-if="addMenuForm.menuType != 'F'" label="菜单图标" prop="icon">
            <el-popover width="290" trigger="click">
              <div class="svgList">
                <el-tabs v-model="activeName" type="card">
                  <el-tab-pane v-for="item in titleData" :label="item.title" :name="item.index">
                    <svg-icon style="display: inline-block;margin-right: 5px;" @click="addSvg(items)"
                      v-for="items in svgData[item.index - 1]" :icon-class="items" />
                  </el-tab-pane>
                </el-tabs>
              </div>
              <el-input class="iconInput" style="width: 340px;" slot="reference" v-model="addMenuForm.icon" placeholder="请选择菜单图标">
                <template #prefix>
                  <svg-icon v-if="addMenuForm.icon" :icon-class="addMenuForm.icon" class="el-input__icon"
                    style="height: 32px;width: 16px;position: relative;top: 5px;left: 5px;" />
                  <el-icon v-else style="height: 32px;width: 16px;position: relative;top: 5px;left: 5px;">
                    <search />
                  </el-icon>
                </template></el-input>
            </el-popover>
          </el-form-item>
          <el-form-item label="菜单名称" prop="menuName" key="menuName">
            <el-input style="width: 340px;" v-model="addMenuForm.menuName" placeholder="请输入菜单名称" />
          </el-form-item>
          <el-form-item label="显示排序" prop="orderNum" key="orderNum">
            <el-input-number placeholder="请输入显示排序" v-model="addMenuForm.orderNum" controls-position="right" :step="1" style="width: 340px;"
              :min="1" />
          </el-form-item>
          <el-form-item v-if="addMenuForm.menuType != 'F'" key="isFrame">
            <template #label>
              <span>
                是否外链
                <el-tooltip content="选择是外链则路由地址需要以`http(s)://`开头" placement="top">
                  <el-icon><question-filled /></el-icon>
                </el-tooltip>
              </span>
            </template>
            <el-radio-group v-model="addMenuForm.isFrame">
              <el-radio label="1">是</el-radio>
              <el-radio label="2">否</el-radio>
            </el-radio-group>
          </el-form-item>
          <el-form-item label="路由地址" prop="path" key="path">
            <el-input style="width: 340px;" v-model="addMenuForm.path" placeholder="请输入路由地址" />
          </el-form-item>
          <el-form-item label="组件路径" prop="component" v-if="addMenuForm.menuType == 'C'" key="component">
            <el-input style="width: 340px;" v-model="addMenuForm.component" placeholder="请输入组件路径" />
          </el-form-item>            
          <el-form-item label="路由参数" v-if="addMenuForm.menuType !== 'F'" key="query">
            <el-input style="width: 340px;" v-model="addMenuForm.query" placeholder="请输入路由参数" maxlength="255" />
          </el-form-item>
          <el-form-item label="权限字符" v-if="addMenuForm.menuType !== 'M'" prop="perms"  key="perms">
            <el-input style="width: 340px;" v-model="addMenuForm.perms" placeholder="请输入权限字符" maxlength="100" />
          </el-form-item>            
          <el-form-item label="是否缓存" v-if="addMenuForm.menuType == 'C'" key="isCache">
            <el-radio-group v-model="addMenuForm.isCache">
              <el-radio-button label="1">缓存</el-radio-button>
              <el-radio-button label="2">不缓存</el-radio-button>
            </el-radio-group>
          </el-form-item>
          <el-form-item label="显示状态" v-if="addMenuForm.menuType != 'F'" key="visible">
            <el-radio-group v-model="addMenuForm.visible">
              <el-radio-button label="1">显示</el-radio-button>
              <el-radio-button label="2">隐藏</el-radio-button>
            </el-radio-group>
          </el-form-item>
          <el-form-item label="菜单状态" v-if="addMenuForm.menuType != 'F'" key="status">
            <el-radio-group v-model="addMenuForm.status">
              <el-radio-button label="1">启用</el-radio-button>
              <el-radio-button label="2">停用</el-radio-button>
            </el-radio-group>
          </el-form-item>
        </el-form>
      </div>
      <template #footer>
        <div class="c">
          <div class="search" @click="submitForm">保 存</div>
          <div class="reset" @click="editCancel()">取 消</div>
        </div>
      </template>
    </el-dialog>
  </div>

</div>
"},null]}
|