<!-- 资产管理 -- 小程序 -->
<template>
  <div class="L-main" id="L-size-main">
    <div class="content-search" id="L-header">
      <div class="search-title">查询条件</div>
      <el-form :inline="true" ref="queryForm" :model="formInline" size="small" class="demo-form-inline" label-width="100px">
        <el-row>
          <!-- <el-col :span="7">
            <el-form-item label="所属单位:" prop="dwmc">
              <el-input v-model="formInline.dwmc" placeholder="请输入所属单位"></el-input>
            </el-form-item>
          </el-col> -->
          <el-col :span="7">
            <el-form-item label="小程序名称:" prop="xcxmc">
              <el-input v-model="formInline.xcxmc" placeholder="请输入小程序名称"></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="7">
            <el-form-item label="小程序状态:" prop="xtzt">
              <el-select v-model="formInline.xtzt" placeholder="请选择小程序状态">
                <el-option
                  v-for="dict in dict.type.gzh_state"
                  :key="dict.value"
                  :label="dict.label"
                  :value="dict.value">
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="3" style="text-align: right;">
            <el-form-item class="unit-form">
              <el-button size="mini" @click="resetQuery('queryFrom')">重置</el-button>
              <el-button size="mini" type="primary" @click="handleQuery('queryFrom')">查询</el-button>
            </el-form-item>
          </el-col>
        </el-row>
        <!-- <el-row>
          <el-col :span="8">
            <el-form-item label="小程序状态:" prop="xtzt">
              <el-select v-model="formInline.xtzt" placeholder="请选择系统状态">
                <el-option
                  v-for="dict in dict.type.gzh_state"
                  :key="dict.value"
                  :label="dict.label"
                  :value="dict.value">
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="16" style="text-align: right;padding-right: 30px;">
            <el-form-item>
              <el-button size="mini" @click="resetQuery('queryFrom')">重置</el-button>
              <el-button size="mini" type="primary" @click="handleQuery('queryFrom')">查询</el-button>
            </el-form-item>
          </el-col>
        </el-row> -->
      </el-form>
    </div>
    <main>
      <div class="search-title">
        <span class="search-title-span">资产列表</span>
        <el-row :gutter="10" class="mb8">
          <el-col :span="1.5">
            <el-button
              type="warning"
              plain
              icon="el-icon-download"
              size="mini"
              @click="handleExport"
            >导出</el-button>
          </el-col>
        </el-row>
      </div>
      <section>
        <el-table v-loading="loading" :data="tableData" :height="tabHeader" :row-class-name="tableRowClassName" :max-height="tabHeader">
          <el-table-column type="index" width="50" label="序号" align="center"/>
          <el-table-column label="小程序名称" key="xcxmc" prop="xcxmc" align="center">
            <!-- <template slot-scope="scope">
              <dict-tag :options="dict.type.zc_xtlx" :value="scope.row.xtlx"/>
            </template> -->
          </el-table-column>
          <el-table-column label="所属单位" key="ssdw" prop="ssdw" align="center" />
          <!-- <el-table-column label="单位名称" key="dwmc" prop="dwmc" align="center">
          </el-table-column> -->
          <!-- <el-table-column label="新增时间" key="createTime" prop="createTime" align="center" /> -->
          <el-table-column label="小程序状态" key="state" prop="state" class-name="table-status" align="center">
            <template slot-scope="scope">
              <span  v-if="scope.row.state == 1" style="color: #16B771;">
                正常
              </span>
              <span v-if="scope.row.state == 2" style="color: #F58A0C;">
                注销
              </span>
              <span v-if="scope.row.state == 3" style="color: #1485EF;">
                迁移
              </span>
              <span v-if="scope.row.state == 4" style="color: #29A07A;">
                受限
              </span>
              <span v-if="scope.row.state == 5" style="color: #F50C0C;">
                违规
              </span>
              <span v-if="scope.row.state == 6" style="color: #F58A0C;">
                未知
              </span>
            </template>
          </el-table-column>
          <el-table-column label="操作" prop="userId" class-name="table-operation" align="center">
            <template slot-scope="scope">
              <div style="display: flex;align-items: center;justify-content: center;">
                <div style="display: flex;align-items: center;cursor: pointer;" @click="goInfo(scope.row,1)">
                  <img src="@/assets/images/icon-ck@2x.png" alt="" style="width: 20px;margin-right: 5px;">
                  <span class="look-info" style="color: #1485EF;margin-right: 15px;">查看</span>
                </div>
                <div v-if="!scope.row.auditState || scope.row.auditState == 2" style="display: flex;align-items: center;cursor: pointer;margin-left: 10px;" @click="goInfo(scope.row,2)">
                  <img src="@/assets/images/edit.png" alt="" style="width: 15px;margin-right: 5px;">
                  <span class="look-info" style="color: #1485EF;margin-right: 15px;">编辑</span>
                </div>
              </div>
            </template>
          </el-table-column>
        </el-table>
      </section>
      <my-pagination 
        id="L-pagination"
        :total="total"
        :page="formInline.current"
        :limit="formInline.size"
        @pagination="getPagination"
        :current-page.sync="formInline.current" 
      ></my-pagination>
    </main>
  </div>
</template>
<script>
import myPagination from "@/views/components/Pagination/index.vue"
// import myDialog from "@/views/components/myDialog/index.vue"
import { miniProgramsList, deleteMiniPrograms } from "@/api/auditPagesApi/index";
export default {
  dicts: ['gzh_state'],
  components:{myPagination},
  data() {
    return {
      formInline:{
        xtzt:"",
        xcxmc:"",
        // startTime:"",
        // endTime:"",
        current:1,
        size:10,
      },
      // time:[],
      total:0,
      tableData:[],
      loading:false,
      tabHeader: undefined,
    }
  },
  mounted(){
    this.getList();
    this.cancalDebounce();
    window.addEventListener('resize', this.cancalDebounce);
  },
  destroyed() {
    window.removeEventListener('resize', this.cancalDebounce);
  },
  methods:{
    // 获取列表
    getList(){
      this.loading = true;
      miniProgramsList(this.formInline).then(res=>{
        this.loading = false;
        this.total = res.data.total;
        this.tableData = res.data.records;
      })
    },
    // 重置
    resetQuery(){
      this.resetForm("queryForm");
      // this.time = [];
      this.handleQuery();
    },
    // 查询
    handleQuery(){
      this.formInline.current = 1;
      // if(this.time) {
      //   this.formInline.startTime = this.time[0]
      //   this.formInline.endTime = this.time[1]
      // }
      this.getList();
    },
    // 页码获取
    getPagination(pages){
      this.formInline.current = pages.page;
      this.formInline.size = pages.limit;
      this.getList();
    },
    // 导出
    handleExport(){
      this.download('/tc/miniPrograms/export', {
        ...this.formInline
      }, `小程序资产${new Date().getTime()}.xlsx`)
    },
    // 查看详情
    goInfo(row,id){
      this.$router.push({name: 'myAssetsAuth',query: {
        pageType: id == 1 ? "look" : "change",
        type:1,
        id:row.id
      }})
    },
    // 修改table背景色
    tableRowClassName({row, rowIndex}){
      if (rowIndex % 2 !== 0) {
        return 'evenNumber-row';
      }
      return '';
    },
    // 屏幕尺寸变化
    cancalDebounce(){
      const element = document.getElementById('L-size-main'); // 通过元素的 ID 获取元素
      const header = document.getElementById('L-header'); // 通过元素的 ID 获取元素
      const pagination = document.getElementById('L-pagination'); // 通过元素的 ID 获取元素
      const elementHeight = element.offsetHeight;
      const headerHeight = header.offsetHeight;
      const paginationtHeight = pagination.offsetHeight;
      this.tabHeader = elementHeight - headerHeight - paginationtHeight - 110;
    }
  },
}
</script>