Newer
Older
urbanLifeline_YanAn / src / views / dataBasePlatform / dataService / apiMarket / index.vue
@zhangzhihui zhangzhihui 25 days ago 14 KB api市场
<template>
  <div class="apiMarket publicContainer">
    <div class="dataTitle">API市场</div>
    <el-divider />
    <div class="dataContent">
      <el-row class="dataTop">
        <el-col :span="16" class="dataLeft">
          <div class="dataBox">
            <el-input v-model="qlCode" style="width: 200px" placeholder="请输入关键字">
              <template #suffix>
                <el-icon class="el-input__icon searchBtn"><search /></el-icon>
              </template>
            </el-input>
          </div>
        </el-col>
        <el-col :span="3">
          <el-button type="primary" icon="search">查询</el-button>
          <el-button type="primary" icon="Refresh" plain>重置</el-button>
          <!-- <el-button type="primary" icon="Plus" @click="addInfo">新增</el-button>
          <el-button type="primary" plain>批量删除</el-button> -->
        </el-col>
      </el-row>

      <!-- 表单 -->
      <div class="dataForm" v-setHeight="{ bottom: 60 }">
        <div class="apiBox" v-for="(item, index) in tableData" :key="index">
          <div class="apiLeft">
            <img :src="tj_icon" alt="" class="apiImg" />
          </div>
          <div class="apiRight">
            <div class="rightTop">
              <div class="apiTitle">API ID: {{ item.code }}</div>
              <div class="apiTitle">API名称: {{ item.name }}</div>
              <div class="apiTitle">API标签: {{ item.p1 }}</div>
              <div class="apiTitle">认证方式: {{ item.p2 }}</div>
            </div>
            <div class="rightBottom">
              <el-button type="primary" plain>API 详情</el-button>
              <el-button type="primary" plain @click="addInfo(item)">申请调用</el-button>
            </div>
          </div>
        </div>
      </div>

      <pagination
        class="pagingPosition"
        v-show="total > 0"
        :total="total"
        v-model:page="queryParams.pageNum"
        v-model:limit="queryParams.pageSize"
        @pagination="getList"
      />
    </div>

    <!-- 新增 及 修改 -->
    <el-dialog v-model="dialogConfig.open" :show-close="true" class="dia" destroy-on-close width="800px">
      <template #header>
        <div class="diaHeader">
          {{ dialogConfig.title }}
        </div>
      </template>
      <el-form :model="addForm" :rules="rules" label-width="auto" ref="ruleAddFormRef">
        <!-- <el-row>
          <el-col :span="24">
            <el-form-item label="桥梁编号" prop="title">
              <el-input v-model="addForm.code" placeholder="请输入" clearable />
            </el-form-item>
          </el-col>
        </el-row> -->

        <el-row>
          <el-col :span="24">
            <el-form-item label="申请人" prop="title">
              <el-input v-model="addForm.name" placeholder="请输入" clearable />
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="24">
            <el-form-item label="最大请求量" prop="">
              <el-input v-model="addForm.p1" placeholder="请输入" clearable />
            </el-form-item>
          </el-col>
        </el-row>

        <el-row>
          <el-col :span="24">
            <el-form-item label="期限" prop="">
              <!-- <el-input v-model="addForm.p5" placeholder="请输入" clearable /> -->
              <el-select v-model="addForm.p2" style="width: 100%">
                <el-option v-for="item in stationType" :key="item.value" :label="item.label" :value="item.value" />
              </el-select>
            </el-form-item>
          </el-col>
        </el-row>

        <el-row>
          <el-col :span="24">
            <el-form-item label="关联应用" prop="">
              <!-- <el-input v-model="addForm.p5" placeholder="请输入" clearable /> -->
              <el-select v-model="addForm.p3" style="width: 100%">
                <el-option v-for="item in stateType1" :key="item.value" :label="item.label" :value="item.value" />
              </el-select>
            </el-form-item>
          </el-col>
        </el-row>

        <el-row>
          <el-col :span="24">
            <el-form-item label="申请原因" prop="">
              <el-input
                v-model="addForm.p4"
                :autosize="{ minRows: 2, maxRows: 4 }"
                type="textarea"
                placeholder="请输入"
                maxlength="300"
                show-word-limit
              />
            </el-form-item>
          </el-col>
        </el-row>

        <el-row class="diaCheck">
          <el-button type="primary" @click="submitForm(ruleAddFormRef)">确 定</el-button>
          <el-button class="cancel" @click="close">取 消</el-button>
        </el-row>
      </el-form>
    </el-dialog>
  </div>
</template>

<script setup name="apiMarket">
import tj_icon from '@/assets/images/order/tj_icon.png';
import ImageFileUpload from '@/components/ImageFileUpload/index.vue'; //图片文件上传
import { onMounted, reactive, toRefs } from 'vue';

const { proxy } = getCurrentInstance();

const stationType = ref([
  {
    id: 1,
    value: 1,
    label: '一周',
  },
  {
    id: 2,
    value: 2,
    label: '一个月',
  },
  {
    id: 3,
    value: 3,
    label: '三个月',
  },
  {
    id: 4,
    value: 4,
    label: '半年',
  },
  {
    id: 5,
    value: 5,
    label: '一年',
  },
]);
const stateType = ref([
  {
    id: 1,
    value: 1,
    label: '待上线',
  },
  {
    id: 2,
    value: 2,
    label: '已上线',
  },
  {
    id: 3,
    value: 3,
    label: '已下线',
  },
]);
const stateType1 = ref([
  {
    id: 1,
    value: 1,
    label: '应用1',
  },
  {
    id: 2,
    value: 2,
    label: '应用2',
  },
  {
    id: 3,
    value: 3,
    label: '应用3',
  },
  {
    id: 4,
    value: 4,
    label: '应用4',
  },
]);

const ruleAddFormRef = ref();
const total = ref(0);
const loading = ref(false);
const queryParams = ref({
  pageNum: 1,
  pageSize: 10,
});
const qlCode = ref('');
const tableData = ref([]);
const multipleSelection = ref([]); // 多选数据
const dataList = reactive({
  dialogConfig: {
    title: '',
    open: false,
  },
  addForm: {
    id: undefined,
    code: '',
    name: '',
    p1: '',
    p2: '',
    p3: '',
    p4: '',
    p5: '',
    p6: '',
    p7: '',
    p8: '',
    p9: '',
    info: '',
    handlePicList: [],
  },
  rules: {
    title: [{ required: true, message: '请输入标题', trigger: 'blur' }],
    content: [{ required: true, message: '请输入内容', trigger: 'blur' }],
  },
});

const { dialogConfig, addForm, rules } = toRefs(dataList);

// 新增和编辑
const addInfo = row => {
  dialogConfig.value.open = true;
  // addForm.value = row;
  dialogConfig.value.title = '申请调用';
  // if (row.id) {
  //   addForm.value = row;
  //   dialogConfig.value.title = '编辑API管理';
  // } else {
  //   addForm.value = {
  //     id: undefined,
  //     code: '',
  //     name: '',
  //     p1: '',
  //     p2: '',
  //     p3: '',
  //     p4: '',
  //     p5: '',
  //     p6: '',
  //     p7: '',
  //     p8: '',
  //     p9: '',
  //     info: '',
  //     handlePicList: [],
  //   };
  //   dialogConfig.value.title = '新增API管理';
  // }
};
// 新增和编辑 提交
const submitForm = formRef => {
  if (!formRef) return;
  formRef.validate(valid => {
    if (valid) {
      console.log('---------', addForm.value);
      // addInfo(addForm.value).then(response => {
      //   proxy.$modal.msgSuccess('新增成功');
      //   getInfoList();
      // });
      dialogConfig.value.open = false;
    }
  });
};

const close = () => {
  dialogConfig.value.open = false;
};

// table多选
const handleSelectionChange = val => {
  console.log('🚀 ~ handleSelectionChange ~ val:', val);
  multipleSelection.value = val;
};

// 新增和编辑

// 删除
const deleteInfo = () => {};

// 获取表单数据
const getList = () => {
  loading.value = true;
  setTimeout(() => {
    tableData.value = [
      {
        id: '001',
        code: '123456789',
        date: '2022-06-01 12:00:00',
        name: '桥梁名称',
        p1: '1',
        p2: '001',
        p3: '002',
        p4: 1,
        p5: 1,
        p6: 1,
        p7: '34',
        p8: '2022-06-01 12:00:00',
        p9: '',
        info: '',
        handlePicList: [],
      },
      {
        id: '002',
        code: '123456789',
        date: '2022-06-01 12:00:00',
        name: '桥梁名称',
        p1: '1',
        p2: '20',
        p3: '2022',
        p4: 1,
        p5: 1,
        p6: 1,
        p7: '34',
        p8: '2022-06-01 12:00:00',
        p9: '',
        info: '',
        handlePicList: [],
      },
      {
        id: '002',
        code: '123456789',
        date: '2022-06-01 12:00:00',
        name: '桥梁名称',
        p1: '1',
        p2: '20',
        p3: '2022',
        p4: 1,
        p5: 1,
        p6: 1,
        p7: '34',
        p8: '2022-06-01 12:00:00',
        p9: '',
        info: '',
        handlePicList: [],
      },
      {
        id: '002',
        code: '123456789',
        date: '2022-06-01 12:00:00',
        name: '桥梁名称',
        p1: '1',
        p2: '20',
        p3: '2022',
        p4: 1,
        p5: 1,
        p6: 1,
        p7: '34',
        p8: '2022-06-01 12:00:00',
        p9: '',
        info: '',
        handlePicList: [],
      },
      {
        id: '002',
        code: '123456789',
        date: '2022-06-01 12:00:00',
        name: '桥梁名称',
        p1: '1',
        p2: '20',
        p3: '2022',
        p4: 1,
        p5: 1,
        p6: 1,
        p7: '34',
        p8: '2022-06-01 12:00:00',
        p9: '',
        info: '',
        handlePicList: [],
      },
      {
        id: '002',
        code: '123456789',
        date: '2022-06-01 12:00:00',
        name: '桥梁名称',
        p1: '1',
        p2: '20',
        p3: '2022',
        p4: 1,
        p5: 1,
        p6: 1,
        p7: '34',
        p8: '2022-06-01 12:00:00',
        p9: '',
        info: '',
        handlePicList: [],
      },
      {
        id: '002',
        code: '123456789',
        date: '2022-06-01 12:00:00',
        name: '桥梁名称',
        p1: '1',
        p2: '20',
        p3: '2022',
        p4: 1,
        p5: 1,
        p6: 1,
        p7: '34',
        p8: '2022-06-01 12:00:00',
        p9: '',
        info: '',
        handlePicList: [],
      },
      {
        id: '002',
        code: '123456789',
        date: '2022-06-01 12:00:00',
        name: '桥梁名称',
        p1: '1',
        p2: '20',
        p3: '2022',
        p4: 1,
        p5: 1,
        p6: 1,
        p7: '34',
        p8: '2022-06-01 12:00:00',
        p9: '',
        info: '',
        handlePicList: [],
      },
      {
        id: '002',
        code: '123456789',
        date: '2022-06-01 12:00:00',
        name: '桥梁名称',
        p1: '1',
        p2: '20',
        p3: '2022',
        p4: 1,
        p5: 1,
        p6: 1,
        p7: '34',
        p8: '2022-06-01 12:00:00',
        p9: '',
        info: '',
        handlePicList: [],
      },
      {
        id: '002',
        code: '123456789',
        date: '2022-06-01 12:00:00',
        name: '桥梁名称',
        p1: '1',
        p2: '20',
        p3: '2022',
        p4: 1,
        p5: 1,
        p6: 1,
        p7: '34',
        p8: '2022-06-01 12:00:00',
        p9: '',
        info: '',
        handlePicList: [],
      },
      {
        id: '002',
        code: '123456789',
        date: '2022-06-01 12:00:00',
        name: '桥梁名称',
        p1: '1',
        p2: '20',
        p3: '2022',
        p4: 1,
        p5: 1,
        p6: 1,
        p7: '34',
        p8: '2022-06-01 12:00:00',
        p9: '',
        info: '',
        handlePicList: [],
      },
      {
        id: '002',
        code: '123456789',
        date: '2022-06-01 12:00:00',
        name: '桥梁名称',
        p1: '1',
        p2: '20',
        p3: '2022',
        p4: 1,
        p5: 1,
        p6: 1,
        p7: '34',
        p8: '2022-06-01 12:00:00',
        p9: '',
        info: '',
        handlePicList: [],
      },
      {
        id: '002',
        code: '123456789',
        date: '2022-06-01 12:00:00',
        name: '桥梁名称',
        p1: '1',
        p2: '20',
        p3: '2022',
        p4: 1,
        p5: 1,
        p6: 1,
        p7: '34',
        p8: '2022-06-01 12:00:00',
        p9: '',
        info: '',
        handlePicList: [],
      },
      {
        id: '002',
        code: '123456789',
        date: '2022-06-01 12:00:00',
        name: '桥梁名称',
        p1: '1',
        p2: '20',
        p3: '2022',
        p4: 1,
        p5: 1,
        p6: 1,
        p7: '34',
        p8: '2022-06-01 12:00:00',
        p9: '',
        info: '',
        handlePicList: [],
      },
    ];
    total.value = tableData.value.length;
    loading.value = false;
  }, 500);
};

onMounted(() => {
  getList();
});
</script>

<style lang="scss" scoped>
.apiMarket {
  position: relative;
  width: 100%;
  height: 100%;
  //   border: 1px solid red;
  // background: #fff;
  .dataTitle {
    position: relative;
    padding-left: 10px;
    &::before {
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%);
      content: '';
      width: 5px;
      height: 14px;
      background: #2561ef;
      border-radius: 3px;
    }
  }
  .dataContent {
    height: calc(100% - 35px);
    .dataTop {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 10px;
      .dataLeft {
        display: flex;
        .dataBox {
          margin-right: 20px;
        }
      }
    }
    .dataForm {
      // border: 1px solid red;
      display: flex;
      justify-content: flex-start;
      align-items: flex-start;
      flex-wrap: wrap;
      overflow-y: auto;
      .apiBox {
        border: 1px solid #ccc;
        padding: 20px 30px;
        // margin-bottom: 30px;
        // margin-right: 40px;
        margin: 0px 20px 30px 20px;
        border-radius: 20px;
        // height: 160px;
        display: flex;
        .apiLeft {
          margin-right: 20px;
          .apiImg {
            width: 100px;
            height: 100px;
          }
        }
        .apiRight {
          .apiTitle {
            font-size: 16px;
            font-weight: bold;
            margin-bottom: 10px;
          }
        }
      }
    }
  }
}
.el-divider {
  margin: 10px 0 15px 0;
}
.searchBtn {
  cursor: pointer;
  &:hover {
    color: #2561ef;
  }
}
.pagingPosition {
  position: absolute !important;
  right: 0px;
  bottom: 0px;
}

// .dia{
//   height: 800px !important;
// }
</style>