yangfeng
2023-09-28 101ae06a200c513fcf3be01d047b310af7660b6c
src/views/reportForm/inboundOutboundDetail/index.vue
@@ -11,35 +11,29 @@
      />
    </div>
    <div class="list-view">
      <TableCommonView
        ref="tableListRef"
        :table-list="tableList"
        @selTableCol="selTableCol"
        @tableRowClick="tableRowClick"
      ></TableCommonView>
      <div class="table">
        <TableCommonView
          ref="tableListRef"
          :table-list="tableList"
          @selTableCol="selTableCol"
          @tableRowClick="tableRowClick"
        ></TableCommonView>
      </div>
      <div class="btn-pager">
        <PagerView
          class="page"
          :pager-options="pagerOptions"
          v-on="pagerEvents"
        />
        <PagerView class="page" :pager-options="pagerOptions" v-on="pagerEvents" />
      </div>
    </div>
    <!-- 编辑 -->
    <AddOverviewDialog
      v-if="editConfig.visible"
      :edit-common-config="editConfig"
      :add-name="this.$route.params.name"
    />
    <AddOverviewDialog v-if="editConfig.visible" :edit-common-config="editConfig" :add-name="this.$route.params.name" />
  </div>
</template>
<script>
import pageMixin from "@/components/makepager/pager/mixin/pageMixin";
import { getHistory } from "@/api/reportForm/inventoryRwport";
import { getProductOperatonList } from "@/api/product/product";
import pageMixin from "@/components/makepager/pager/mixin/pageMixin"
import { getHistory } from "@/api/reportForm/inventoryRwport"
import { getProductOperatonList } from "@/api/product/product"
import AddOverviewDialog from "@/views/overview/AddOverviewDialog";
import AddOverviewDialog from "@/views/overview/AddOverviewDialog"
export default {
  name: "InboundOutboundDetail",
@@ -55,23 +49,22 @@
      commonDetail: {
        visible: false,
        title: "新建",
        infomation: {},
        infomation: {}
      },
      editConfig: {
        visible: false,
        title: "新建",
        infomation: {},
        infomation: {}
      },
      productId: this.$route.params.id,
      productName: this.$route.params.name,
    };
      params: {}
    }
  },
  created() {
    this.setTable()
    console.log(this.$route.params)
    var paramsData = sessionStorage.getItem("paramsList")
    var paramsList = sessionStorage.getItem("paramsList")
    let params = {}
    if (paramsData) {
    if (paramsList) {
      params = JSON.parse(sessionStorage.getItem("paramsList"))
    } else {
      params = this.$route.params
@@ -81,6 +74,10 @@
    console.log(this.params)
    this.getData()
  },
  // 页面销毁之前
  beforeDestroy() {
    sessionStorage.removeItem("paramsList")
  },
  methods: {
    setTable() {
      this.tableList = {
@@ -88,155 +85,144 @@
        selectBox: true,
        showcol: this.showcol,
        allcol: [],
        tableColumn: this.setTableColumn(this.showcol),
      };
      let allcol = [];
        tableColumn: this.setTableColumn(this.showcol)
      }
      let allcol = []
      for (let i = 0; i < this.tableList.tableColumn.length; i++) {
        if (!this.tableList.tableColumn[i].default) {
          const label = this.tableList.tableColumn[i].label;
          allcol.push(label);
          const label = this.tableList.tableColumn[i].label
          allcol.push(label)
        }
      }
      this.tableList.allcol = allcol;
      this.tableList.allcol = allcol
    },
    setTableColumn(showcol) {
      let tableColumn = [
        {
          label: "日期",
          prop: this.$route.params.paramsKey.date,
          prop: "date",
          isShowColumn: true,
          default: true,
          date: true,
          date: true
        },
        {
          label: "单号",
          prop: this.$route.params.paramsKey.number,
          prop: "number",
          isShowColumn: true,
          default: true,
          default: true
        },
        {
          label: "产品",
          prop: this.$route.params.paramsKey.productName,
          prop: "productName",
          isShowColumn: true,
          default: true,
          default: true
        },
        {
          label: "从",
          prop: this.$route.params.paramsKey.fromLocation,
          prop: "fromLocation",
          isShowColumn: true,
          default: true,
          default: true
        },
        {
          label: "至",
          prop: this.$route.params.paramsKey.toLocation,
          prop: "toLocation",
          isShowColumn: true,
          default: true,
          default: true
        },
        {
          label: "数量",
          prop: this.$route.params.paramsKey.amount,
          prop: "amount",
          isShowColumn: true,
          default: true,
          default: true
        },
        {
          label: "单位",
          prop: this.$route.params.paramsKey.unit,
          prop: "unit",
          isShowColumn: true,
          default: true,
          default: true
        },
        {
          label: "状态",
          prop: this.$route.params.paramsKey.status,
          prop: "status",
          width: 120,
          isShowColumn: showcol.includes("状态"),
          default: false,
          status: true,
          isCallMethod: true,
          getCallMethod: this.getStatus,
          getCallMethod: this.getStatus
        },
        {
          label: "完成者",
          prop: this.$route.params.paramsKey.contactedName,
          prop: "contactedName",
          isShowColumn: showcol.includes("完成者"),
          default: false,
        },
      ];
      return tableColumn;
          default: false
        }
      ]
      return tableColumn
    },
    selTableCol(val) {
      this.showcol = val;
      this.tableList.tableColumn = this.setTableColumn(val);
      this.showcol = val
      this.tableList.tableColumn = this.setTableColumn(val)
    },
    // 库存报表跳转请求数据
    async getData() {
      if (this.$route.params.pageName == "产品") {
        await getProductOperatonList({
          productId: this.productId,
      if (this.params.name === "报表") {
        await getHistory({
          productId: this.params.id,
          page: this.pagerOptions.currPage,
          pageSize: this.pagerOptions.pageSize,
          pageSize: this.pagerOptions.pageSize
        }).then((res) => {
          if (res.code === 200) {
            this.tableList.tableInfomation = res.data
            this.pagerOptions.totalCount = res.total
          }
        })
      } else {
        await getProductOperatonList({
          productId: this.params.id,
          page: this.pagerOptions.currPage,
          pageSize: this.pagerOptions.pageSize
        }).then((res) => {
          if (res.code === 200) {
            const list = res.data.map((item) => {
              return {
                ...item,
                from: item.fromLocation.name,
                to: item.toLocation.name,
                productName: this.productName,
              };
            });
            this.tableList.tableInfomation = list || [];
            this.pagerOptions.totalCount = res.total;
                fromLocation: item.fromLocation.name,
                toLocation: item.toLocation.name,
                productName: this.params.name,
                amount: item.details[0].product.amount,
                unit: item.details[0].product.unit
              }
            })
            this.tableList.tableInfomation = list || []
            this.pagerOptions.totalCount = res.total
          }
        });
      } else if (this.$route.params.pageName == "报表") {
        await getHistory(this.$route.params.product).then((res) => {
          if (res.code === 200) {
            this.tableList.tableInfomation = res.data;
          }
        });
        })
      }
    },
    //产品跳转请求数据
    // 搜索
    getList(val) {
      console.log(val);
      console.log(val)
    },
    // 行点击
    tableRowClick(row) {
      console.log(row,"行row")
      this.editConfig.visible = true;
      this.editConfig.title = "查看";
      this.editConfig.infomation = { ...row };
      console.log(row, "行row")
      this.editConfig.visible = true
      this.editConfig.title = "查看"
      this.editConfig.infomation = { ...row }
    },
    // 新建
    addBtnClick() {
      // this.editConfig.visible = true
      this.editConfig.title = "新建";
      this.editConfig.title = "新建"
    },
    // 状态
    getStatus(val) {
      console.log(val,"val状态")
      return val === 1 ? "草稿" : val === 3 ? "就绪" : "完成";
    },
  },
};
      return val === 1 ? "草稿" : val === 3 ? "就绪" : "完成"
    }
  }
}
</script>
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style lang="scss" scoped>
// .rightContent {
//   height: 100%;
//   background: #e6ecf2;
//   padding: 10px;
//   .top {
//     margin-bottom: 20px;
//     height: 60px;
//     background: #fff;
//     border-radius: 8px;
//   }
//   .list-view {
//     height: calc(100% - 120px);
//   }
// }
</style>
<style lang="scss" scoped></style>