Browse Source

2021-06-15

East 3 years ago
parent
commit
8551aaec54

File diff suppressed because it is too large
+ 1 - 1
src/element-ui-theme/element-#0BB2D4/index.css


File diff suppressed because it is too large
+ 1 - 1
src/element-ui-theme/element-#11C26D/index.css


File diff suppressed because it is too large
+ 1 - 1
src/element-ui-theme/element-#17B3A3/index.css


File diff suppressed because it is too large
+ 1 - 1
src/element-ui-theme/element-#3E8EF7/index.css


File diff suppressed because it is too large
+ 1 - 1
src/element-ui-theme/element-#667AFA/index.css


File diff suppressed because it is too large
+ 1 - 1
src/element-ui-theme/element-#757575/index.css


File diff suppressed because it is too large
+ 1 - 1
src/element-ui-theme/element-#9463F7/index.css


File diff suppressed because it is too large
+ 1 - 1
src/element-ui-theme/element-#997B71/index.css


File diff suppressed because it is too large
+ 1 - 1
src/element-ui-theme/element-#EB6709/index.css


File diff suppressed because it is too large
+ 1 - 1
src/element-ui-theme/element-#F74584/index.css


File diff suppressed because it is too large
+ 1 - 1
src/element-ui-theme/element-#FCB900/index.css


File diff suppressed because it is too large
+ 1 - 1
src/element-ui-theme/element-#FF4C52/index.css


+ 6 - 2
src/store/modules/user.js

@@ -2,7 +2,8 @@ export default {
   namespaced: true,
   state: {
     id: 0,
-    name: ''
+    name: '',
+    token: ''
   },
   mutations: {
     updateId (state, id) {
@@ -10,6 +11,9 @@ export default {
     },
     updateName (state, name) {
       state.name = name
-    }
+    },
+    // updateToken (state, token) {
+    //   state.token = token
+    // }
   }
 }

+ 6 - 1
src/views/main.vue

@@ -55,7 +55,11 @@
       userName: {
         get () { return this.$store.state.user.name },
         set (val) { this.$store.commit('user/updateName', val) }
-      }
+      },
+      // token: {
+      //   get () { return this.$store.state.user.token },
+      //   set (val) { this.$store.commit('user/updateToken', val) }
+      // }
     },
     created () {
       this.getUserInfo()
@@ -82,6 +86,7 @@
             this.loading = false
             this.userId = data.user.userId
             this.userName = data.user.username
+            // this.token = data.user.token
           }
         })
       }

+ 77 - 3
src/views/modules/pigbasic/pbbasic.vue

@@ -149,10 +149,11 @@
               @expand-change="expandChange"
               ref="table"
               stripe
+              border
               :header-cell-style="{background:'rgb(245,245,245)',color:'#000',height: '45px',fontSize: '13px',fontWeight: 'normal',borderBottom: '1px solid #ccc'}" 
               :cell-style="{color: '#888',fontSize: '13px'}"
               size="mini">
-              <el-table-column
+              <!-- <el-table-column
                 type="selection"
                 header-align="center"
                 align="center"
@@ -219,7 +220,7 @@
                     </el-row>
                     <el-form-item label="所属牧场:">
                       <span>{{ props.row.name }}</span>
-                    </el-form-item>
+                    </el-form-item> -->
                     <!-- 三列保留 -->
                     <!-- <el-row>
                     <el-col span="8">
@@ -295,7 +296,7 @@
                     <!-- <el-form-item label="所属牧场">
                     <span>{{ props.row.name }}</span>
                   </el-form-item> -->
-                  </el-form>
+                  <!-- </el-form>
                   </div>
                 </template>
               </el-table-column>
@@ -328,6 +329,76 @@
                 header-align="center"
                 align="center"
                 label="所属牧场">
+              </el-table-column> -->
+              <el-table-column
+                type="selection"
+                header-align="center"
+                align="center"
+                width="50">
+              </el-table-column>
+              <el-table-column
+                prop="id"
+                header-align="center"
+                align="center"
+                label="id">
+              </el-table-column>
+              <el-table-column
+                prop="eartag"
+                header-align="center"
+                align="center"
+                label="耳标">
+              </el-table-column>
+              <el-table-column
+                prop="sex"
+                header-align="center"
+                align="center"
+                label="性别">
+              </el-table-column>
+              <el-table-column
+                prop="birthday"
+                header-align="center"
+                align="center"
+                label="出生日期">
+              </el-table-column>
+              <el-table-column
+                header-align="center"
+                align="center"
+                label="健康状态">
+                <template slot-scope="scope">
+                  <span>{{scope.row.healthStatus? '健康': '不健康'}}</span>
+                </template>
+              </el-table-column>
+              <el-table-column
+                header-align="center"
+                align="center"
+                label="养殖状态">
+                <template slot-scope="scope">
+                  <span>{{scope.row.outFenceStatus? '出栏': '育肥'}}</span>
+                </template>
+              </el-table-column>
+              <el-table-column
+                prop="breed"
+                header-align="center"
+                align="center"
+                label="品种">
+              </el-table-column>
+              <el-table-column
+                prop="phNumber"
+                header-align="center"
+                align="center"
+                label="栋舍">
+              </el-table-column>
+              <el-table-column
+                prop="unitNumber"
+                header-align="center"
+                align="center"
+                label="单元">
+              </el-table-column>
+              <el-table-column
+                prop="periodNumber"
+                header-align="center"
+                align="center"
+                label="栏期">
               </el-table-column>
               <el-table-column
                 fixed="right"
@@ -624,6 +695,9 @@ export default {
     },
     // 获取数据列表
     getDataList() {
+      console.log(this.$store.state.user.id);
+      console.log(this.$store.state.user.name);
+      console.log(this.$cookie.get('token'));
       this.dataListLoading = true;
       // 获取所有猪只信息
       this.$http({

+ 435 - 0
src/views/modules/pigbasic/pbentry-add-or-update.vue

@@ -0,0 +1,435 @@
+<template>
+  <el-dialog
+    :title="!dataForm.id ? '新增' : '修改'"
+    :close-on-click-modal="false"
+    :visible.sync="visible"
+    width="600px">
+    <el-form 
+      :model="dataForm" 
+      :rules="dataRule" 
+      ref="dataForm" 
+      @keyup.enter.native="dataFormSubmit()" 
+      label-width="80px" 
+      size="mini"
+      style="margin-left: 20px;width: 500px">
+      <el-form-item label="耳标" prop="eartag">
+        <el-input
+          type="textarea"
+          :rows="2"
+          placeholder="每个耳标之间用英文逗号隔开,最多可以添加50头猪"
+          v-model="dataForm.eartag"
+          :disabled="dataForm.id? true: false">
+        </el-input>
+      </el-form-item>
+      <el-form-item label="栋舍" prop="pigstyId">
+        <el-select 
+          v-model="dataForm.pigstyId"
+          style="width: 100%">
+          <el-option
+            v-for="item in pigstyList"
+            :key="item.value"
+            :label="item.label"
+            :value="item.value">
+          </el-option>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="单元" prop="unitId">
+        <el-select 
+          v-model="dataForm.unitId"
+          style="width: 100%">
+          <el-option
+            v-for="item in unitList"
+            :key="item.value"
+            :label="item.label"
+            :value="item.value">
+          </el-option>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="栏期" prop="periodId">
+        <el-select 
+          v-model="dataForm.periodId"
+          style="width: 100%">
+          <el-option
+            v-for="item in periodList"
+            :key="item.value"
+            :label="item.label"
+            :value="item.value">
+          </el-option>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="性别" prop="sex">
+        <el-select 
+          v-model="dataForm.sex"
+          style="width: 100%">
+          <el-option
+            v-for="item in gender"
+            :key="item.value"
+            :label="item.label"
+            :value="item.value">
+          </el-option>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="出生日期" prop="birthday">
+        <el-date-picker
+          v-model="dataForm.birthday"
+          type="date"
+          value-format="yyyy-MM-dd"
+          placeholder="请选择出生日期"
+          @change="changeBirth"
+          style="width: 100%">
+        </el-date-picker>
+      </el-form-item>
+      <el-form-item label="健康状态" prop="healthStatus">
+        <el-select 
+          v-model="dataForm.healthStatus"
+          style="width: 100%">
+          <el-option
+            v-for="item in healthStatus"
+            :key="item.value"
+            :label="item.label"
+            :value="item.value">
+          </el-option>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="体重" prop="weight">
+        <el-input-number
+          v-model="dataForm.weight"
+          :step="0.01"
+          :max="1000000"
+          :min="0"
+          style="width: 91%">
+        </el-input-number>
+        千克
+      </el-form-item>
+      <el-form-item label="产地" prop="originPlace">
+        <el-select 
+          v-model="dataForm.originPlace"
+          style="width: 100%">
+          <el-option
+            v-for="item in originPlaceList"
+            :key="item.value"
+            :label="item.label"
+            :value="item.value">
+          </el-option>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="品种" prop="breed">
+        <el-select 
+          v-model="dataForm.breed"
+          style="width: 100%">
+          <el-option
+            v-for="item in breedList"
+            :key="item.value"
+            :label="item.label"
+            :value="item.value">
+          </el-option>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="养殖状态" prop="outFenceStatus">
+        <el-select 
+          v-model="dataForm.outFenceStatus"
+          style="width: 100%">
+          <el-option
+            v-for="item in outFenceStatus"
+            :key="item.value"
+            :label="item.label"
+            :value="item.value">
+          </el-option>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="父亲" prop="fatherEartag">
+        <el-input v-model="dataForm.fatherEartag"></el-input>
+      </el-form-item>
+      <el-form-item label="母亲" prop="motherEartag">
+        <el-input v-model="dataForm.motherEartag"></el-input>
+      </el-form-item>
+    </el-form>
+    <span slot="footer" class="dialog-footer">
+      <el-button size="mini" @click="visible = false">关闭</el-button>
+      <el-button size="mini" type="primary" @click="dataFormSubmit()">确定</el-button>
+    </span>
+  </el-dialog>
+</template>
+
+<script>
+  // import { treeDataTranslate } from '@/utils'
+  import { isEmail, isMobile } from '@/utils/validate'
+  export default {
+    data () {
+      var validateEmail = (rule, value, callback) => {
+        // if (!isEmail(value)) {
+        //   callback(new Error('邮箱格式错误'))
+        // } else {
+        //   callback()
+        // }
+        if (value === '') {
+          callback()
+        } else if (!isEmail(value)) {
+          callback(new Error('邮箱格式错误'))
+        } else {
+          callback()
+        }
+      }
+      var validateMobile = (rule, value, callback) => {
+        if (!isMobile(value)) {
+          callback(new Error('手机号格式错误'))
+        } else {
+          callback()
+        }
+      }
+      return {
+        visible: false,
+        dataForm: {
+          id: '',
+          eartag: '',
+          pigstyId: '',
+          unitId: '',
+          periodId: '',
+          sex: '',
+          birthday: '',
+          healthStatus: true,
+          weight: '',
+          originPlace: '',
+          breed: '',
+          outFenceStatus: 0,
+          motherEartag: '',
+          fatherEartag: ''
+        },
+        dataRule: {
+          eartag: [
+            { required: true, message: '耳标不能为空', trigger: 'blur' }
+          ],
+          pigstyId: [
+            { required: true, message: '栋舍不能为空', trigger: 'blur' }
+          ],
+          unitId: [
+            { required: true, message: '单元不能为空', trigger: 'blur' }
+          ],
+          periodId: [
+            { required: true, message: '栏期不能为空', trigger: 'blur' }
+          ],
+          // mobile: [
+          //   { required: true, message: '手机号码不能为空', trigger: 'blur' },
+          //   { validator: validateMobile, trigger: 'blur' }
+          // ],
+          // email: [
+          //   // { required: true, message: '邮箱不能为空', trigger: 'blur' },
+          //   { validator: validateEmail, trigger: 'blur' }
+          // ],
+          // farmId: [
+          //   // { required: true, message: '牧场不能为空', trigger: 'blur' }
+          // ],
+          // departmentCode: [
+          //   // { required: true, message: '部门不能为空', trigger: 'blur' }
+          // ],
+          // jobCode: [
+          //   // { required: true, message: '岗位不能为空', trigger: 'blur' }
+          // ],
+          // address: [
+          //   // { required: true, message: '住址不能为空', trigger: 'blur' }
+          // ],
+          // roleIdList: [
+          //   // { required: true, message: '角色不能为空', trigger: 'blur' }
+          // ],
+          // status: [
+          //   // { required: true, message: '状态不能为空', trigger: 'blur' }
+          // ]
+        },
+        gender: [
+          {
+            value: '公',
+            label: '公'
+          },
+          {
+            value: '母',
+            label: '母'
+          }
+        ],
+        pigstyList: [], // 栋舍List
+        unitList: [], // 单元List
+        unitSelectedList: [], // 单元SelectedList
+        periodList: [], // 栏期List
+        periodSelectedList: [], // 栏期SelectedList
+        healthStatus: [
+          {
+            value: true,
+            label: '健康'
+          },
+          {
+            value: false,
+            label: '不健康'
+          }
+        ],
+        breedList: [
+          {
+            value: 1,
+            label: '杜巴嘉'
+          },
+          {
+            value: 2,
+            label: '长白'
+          }
+        ], // 品种List
+        originPlaceList: [], // 产地List
+        outFenceStatus: [
+          {
+            value: 0,
+            label: '育肥'
+          },
+          {
+            value: 1,
+            label: '出栏'
+          }
+        ]
+      }
+    },
+    methods: {
+      // 在pbentry.vue调用该方法
+      init (pigs) {
+        this.visible = true
+        this.dataForm.id = ''
+        this.$nextTick(() => {
+          this.$refs['dataForm'].resetFields()
+          if (pigs.length > 0) {
+            console.log(pigs);
+            let ids = []
+            let eartags = []
+            pigs.forEach(pig => {
+              ids.push(pig.id)
+              eartags.push(pig.eartag)
+            })
+            this.dataForm.id = ids.join()
+            this.dataForm.eartag = eartags.join()
+          }
+        })
+        if (pigs.length) {
+          this.$http({
+            url: this.$http.adornUrl(`/management/yearpigbase/info/${pigs[0].id}`),
+            method: "get"
+          }).then(({data}) => {
+            console.log(data.yearPigBase)
+            // this.dataForm
+          })
+        }
+        this.$http({
+          url: this.$http.adornUrl("/management/pigsty/findAll"),
+          method: "get"
+        }).then(async({ data }) => {
+          // 栋舍List
+          this.pigstyList = []
+          let pigstyList = []
+          data.all && (pigstyList = data.all)
+          pigstyList.forEach(pigsty => {
+            let item = {
+              value: pigsty.id,
+              label: pigsty.number
+            }
+            this.pigstyList.push(item)
+          })
+          // 单元List
+          this.unitList = []
+          let unitList = []
+          let unitR = await this.$http({
+            url: this.$http.adornUrl("/management/unit/findAll"),
+            method: "get"
+          })
+          unitR.data.all && (unitList = unitR.data.all)
+          unitList.forEach(unit => {
+            let item = {
+              value: unit.id,
+              label: unit.number,
+              pigstyId: unit.pigstyId,
+              farmId: unit.farmId
+            }
+            this.unitList.push(item)
+          })
+          this.unitSelectedList = this.unitList
+          // 栏期List
+          this.periodList = []
+          let periodList = []
+          let periodR = await this.$http({
+            url: this.$http.adornUrl("/management/period/findAll"),
+            method: "get"
+          })
+          periodR.data.all && (periodList = periodR.data.all)
+          periodList.forEach(period => {
+            let item = {
+              value: period.id,
+              label: period.number,
+              pigstyId: period.pigstyId
+            }
+            this.periodList.push(item)
+          })
+          this.periodSelectedList = this.periodList
+
+
+
+
+          
+        })
+      },
+      // 表单提交
+      dataFormSubmit () {
+        this.$refs['dataForm'].validate((valid) => {
+          console.log(valid);
+          if (valid) {
+            this.$http({
+              url: this.$http.adornUrl(`${!this.dataForm.id ?'/management/yearpigbase/batchLairage': '/management/yearpigbase/update'}`),
+              method: 'post',
+              data: this.$http.adornData({
+                'id': this.dataForm.id || undefined,
+                'eartag': this.dataForm.eartag,
+                'pigstyId': this.dataForm.pigstyId,
+                'unitId': this.dataForm.unitId,
+                'periodId': this.dataForm.periodId,
+                'sex': this.dataForm.sex,
+                'birthday': this.dataForm.birthday,
+                'healthStatus': this.dataForm.healthStatus,
+                'weight': this.dataForm.weight,
+                'originPlace': this.dataForm.originPlace,
+                'breed': this.dataForm.breed,
+                'outFenceTime': this.dataForm.outFenceTime,
+                'motherEartag': this.dataForm.motherEartag,
+                'fatherEartag': this.dataForm.fatherEartag
+              })
+            }).then(({data}) => {
+              if (data && data.code === 0) {
+                this.visible = false
+                this.$emit('refreshDataList')
+                this.$message({
+                  message: '操作成功',
+                  type: 'success',
+                  duration: 1500,
+                  // onClose: () => {
+                  //   this.visible = false
+                  //   this.$emit('refreshDataList')
+                  // }
+                })
+                // this.resetForm()
+                this.visible = false
+              } else {
+                this.$message.error(data.msg)
+              }
+            })
+          }
+        })
+      },
+      // 获取出生日期
+      changeBirth(val) {
+        let birth = new Date(val);
+        let now = new Date();
+        let days = now.getTime() - birth.getTime();
+        if (days < 0) {
+          this.$confirm(`出生日期有误`, "提示", {
+            confirmButtonText: "确定",
+            cancelButtonText: "取消",
+            type: "warning",
+          }).then(() => {
+            this.dataForm.birthday = ''
+            console.log("还没出生呢...");
+          }).catch(() => {});
+        }
+      }
+    }
+  }
+</script>

+ 569 - 0
src/views/modules/pigbasic/pbentry.vue

@@ -0,0 +1,569 @@
+<template>
+  <div class="mod-role">
+    <el-container>
+      <!-- form表单 -->
+      <el-header>
+        <div class="rect rect-form">
+          <el-form :inline="true" :model="form" @keyup.enter.native="getDataList()" size="mini" ref="form">
+            <el-form-item>
+              <el-input v-model="form.eartag" placeholder="耳标" clearable></el-input>
+            </el-form-item>
+            <el-form-item style="width: 140px">
+              <el-select placeholder="性别" v-model="form.sex">
+                <el-option
+                  v-for="item in gender"
+                  :key="item.value"
+                  :label="item.label"
+                  :value="item.value">
+                </el-option>
+              </el-select>
+            </el-form-item>
+            <el-form-item style="width: 140px">
+              <el-select placeholder="品种" v-model="form.breed">
+                <el-option
+                  v-for="item in breed"
+                  :key="item.value"
+                  :label="item.label"
+                  :value="item.value">
+                </el-option>
+              </el-select>
+            </el-form-item>
+            <el-form-item style="width: 140px">
+              <el-select placeholder="健康状态" v-model="form.healthStatus">
+                <el-option
+                  v-for="item in healthStatus"
+                  :key="item.value"
+                  :label="item.label"
+                  :value="item.value">
+                </el-option>
+              </el-select>
+            </el-form-item>
+            <el-form-item style="width: 140px">
+              <el-select placeholder="养殖状态" v-model="form.outFenceStatus">
+                <el-option
+                  v-for="item in outFenceStatus"
+                  :key="item.value"
+                  :label="item.label"
+                  :value="item.value">
+                </el-option>
+              </el-select>
+            </el-form-item>
+            <el-form-item style="width: 140px">
+              <el-select placeholder="栏期" v-model="form.periodId">
+                <el-option
+                  v-for="item in periodSelectedList"
+                  :key="item.value"
+                  :label="item.label"
+                  :value="item.value">
+                </el-option>
+              </el-select>
+            </el-form-item>
+            <el-form-item style="width: 140px">
+              <el-select placeholder="栋舍" v-model="form.pigstyId" @change="pigstyChange">
+                <el-option
+                  v-for="item in pigstyList"
+                  :key="item.value"
+                  :label="item.label"
+                  :value="item.value">
+                </el-option>
+              </el-select>
+            </el-form-item>
+            <el-form-item style="width: 140px">
+              <el-select placeholder="单元" v-model="form.unitId">
+                <el-option
+                  v-for="item in unitSelectedList"
+                  :key="item.value"
+                  :label="item.label"
+                  :value="item.value">
+                </el-option>
+              </el-select>
+            </el-form-item>
+
+            <el-form-item>
+              <el-button @click="getDataList()" icon="el-icon-search">查 询</el-button>
+            </el-form-item>
+            <el-form-item>
+              <el-button 
+                icon="el-icon-circle-close"
+                @click="clearAll">清 空</el-button>
+            </el-form-item>
+          </el-form>
+        </div>
+      </el-header>
+      <!-- role表格 -->
+      <el-main>
+        <div class="rect rect-table">
+          <!-- 新增 删除按钮 -->
+          <el-form inline size="mini">
+            <el-form-item>
+              <el-button 
+                icon="el-icon-plus" 
+                @click="addOrUpdateHandle()">
+                新 增
+              </el-button>
+            </el-form-item>
+            <el-form-item>
+              <el-button 
+                icon="el-icon-delete" 
+                type="danger" 
+                @click="deleteHandle()" 
+                :disabled="dataListSelections.length <= 0">
+                删 除
+              </el-button>
+            </el-form-item>
+            <el-form-item>
+              <el-button 
+                icon="el-icon-edit" 
+                type="danger" 
+                @click="addOrUpdateHandle()" 
+                :disabled="dataListSelections.length <= 0">
+                批量修改
+              </el-button>
+            </el-form-item>
+          </el-form>
+          
+          <el-table
+            :data="dataList"
+            border
+            stripe
+            v-loading="dataListLoading"
+            @selection-change="selectionChangeHandle"
+            style="width: 100%;"
+            size="mini"
+            height="540"
+            :header-cell-style="{background:'rgb(245,245,245)',color:'#000',height: '45px',fontSize: '13px',fontWeight: 'normal',borderBottom: '1px solid #ccc'}" 
+            :cell-style="{color: '#888',fontSize: '13px'}">
+            <el-table-column
+              type="selection"
+              header-align="center"
+              align="center"
+              width="50">
+            </el-table-column>
+            <el-table-column
+              prop="id"
+              header-align="center"
+              align="center"
+              label="id">
+            </el-table-column>
+            <el-table-column
+              prop="eartag"
+              header-align="center"
+              align="center"
+              label="耳标">
+            </el-table-column>
+            <el-table-column
+              prop="sex"
+              header-align="center"
+              align="center"
+              label="性别">
+            </el-table-column>
+            <el-table-column
+              prop="birthday"
+              header-align="center"
+              align="center"
+              label="出生日期">
+            </el-table-column>
+            <el-table-column
+              header-align="center"
+              align="center"
+              label="健康状态">
+              <template slot-scope="scope">
+                <span>{{scope.row.healthStatus? '健康': '不健康'}}</span>
+              </template>
+            </el-table-column>
+            <el-table-column
+              header-align="center"
+              align="center"
+              label="养殖状态">
+              <template slot-scope="scope">
+                <span>{{scope.row.outFenceStatus? '出栏': '育肥'}}</span>
+              </template>
+            </el-table-column>
+            <el-table-column
+              prop="breed"
+              header-align="center"
+              align="center"
+              label="品种">
+            </el-table-column>
+            <el-table-column
+              prop="phNumber"
+              header-align="center"
+              align="center"
+              label="栋舍">
+            </el-table-column>
+            <el-table-column
+              prop="unitNumber"
+              header-align="center"
+              align="center"
+              label="单元">
+            </el-table-column>
+            <el-table-column
+              prop="periodNumber"
+              header-align="center"
+              align="center"
+              label="栏期">
+            </el-table-column>
+            <el-table-column
+              fixed="right"
+              header-align="center"
+              align="center"
+              label="操作">
+              <template slot-scope="scope">
+                <el-button
+                  type="text"
+                  size="medium"
+                  style="color: rgb(24,144,255)">
+                  查看
+                </el-button>
+                <el-button
+                  type="text"
+                  size="medium"
+                  @click="addOrUpdateHandle(scope.row)"
+                  style="color: rgb(24,144,255)">
+                  编辑
+                </el-button>
+              </template>
+            </el-table-column>
+          </el-table>
+          <el-pagination
+            @size-change="sizeChangeHandle"
+            @current-change="currentChangeHandle"
+            :current-page="pageIndex"
+            :page-sizes="[10, 20, 50, 100]"
+            :page-size="pageSize"
+            :total="totalPage"
+            layout="total, sizes, prev, pager, next, jumper">
+          </el-pagination>
+          <!-- 弹窗, 新增 / 修改 -->
+          <add-or-update v-if="addOrUpdateVisible" ref="addOrUpdate" @refreshDataList="getDataList"></add-or-update>
+        </div>
+      </el-main>
+      
+      
+    </el-container>
+  </div>
+</template>
+
+<script>
+  import AddOrUpdate from './pbentry-add-or-update'
+  export default {
+    data () {
+      return {
+        form: {
+          eartag: '',
+          sex: '',
+          breed: '',
+          healthStatus: '',
+          outFenceStatus: '',
+          periodId: '',
+          pigstyId: '',
+          unitId: ''
+        },
+        dataList: [],
+        pageIndex: 1,
+        pageSize: 10,
+        totalPage: 0,
+        dataListLoading: false,
+        dataListSelections: [],
+        addOrUpdateVisible: false,
+        farmId: undefined,
+        gender: [
+          {
+            value: '公',
+            label: '公'
+          },
+          {
+            value: '母',
+            label: '母'
+          }
+        ],
+        breed: [
+          {
+            value: 1,
+            label: '杜巴嘉'
+          },
+          {
+            value: 2,
+            label: '长白'
+          }
+        ],
+        healthStatus: [
+          {
+            value: true,
+            label: '健康'
+          },
+          {
+            value: false,
+            label: '不健康'
+          }
+        ],
+        outFenceStatus: [
+          {
+            value: 0,
+            label: '育肥'
+          },
+          {
+            value: 1,
+            label: '出栏'
+          }
+        ],
+        periodList: [], // 所有栏期
+        periodSelectedList: [], // 根据栋舍限制的栏期
+        pigstyList: [], // 所有栋舍
+        unitList: [], // 所有单元
+        unitSelectedList: [], // 根据栋舍限制的单元
+        labelPosition: 'right'
+      }
+    },
+    components: {
+      AddOrUpdate
+    },
+    activated () {
+      this.getDataList()
+    },
+    methods: {
+      // 获取数据列表
+      getDataList () {
+        this.dataListLoading = true
+        this.$http({
+          url: this.$http.adornUrl('/management/yearpigbase/list'),
+          method: 'get',
+          params: this.$http.adornParams({
+            'page': this.pageIndex,
+            'limit': this.pageSize,
+            // 'username': this.form.username,
+            // 'departmentCode': this.form.departmentCode,
+            // 'jobCode': this.form.jobCode,
+            // 'sex': this.form.gender,
+            // 'farmId': this.farmId
+          })
+        }).then(async({data}) => {
+          // // 获取所有牧场
+          // let pastureList = []
+          // let pastureResult = await this.$http({
+          //   url: this.$http.adornUrl("/management/farm/findAll"),
+          //   method: "post",
+          // })
+          // pastureResult.data.all && (pastureList = pastureResult.data.all)
+          // 栋舍List
+          this.pigstyList = []
+          let pigstyList = []
+          let pigstyR = await this.$http({
+            url: this.$http.adornUrl("/management/pigsty/findAll"),
+            method: "get"
+          })
+          pigstyR.data.all && (pigstyList = pigstyR.data.all)
+          pigstyList.forEach(pigsty => {
+            let item = {
+              value: pigsty.id,
+              label: pigsty.number
+            }
+            this.pigstyList.push(item)
+          })
+          // 单元List
+          this.unitList = []
+          let unitList = []
+          let unitR = await this.$http({
+            url: this.$http.adornUrl("/management/unit/findAll"),
+            method: "get"
+          })
+          unitR.data.all && (unitList = unitR.data.all)
+          unitList.forEach(unit => {
+            let item = {
+              value: unit.id,
+              label: unit.number,
+              pigstyId: unit.pigstyId,
+              farmId: unit.farmId
+            }
+            this.unitList.push(item)
+          })
+          this.unitSelectedList = this.unitList
+          // 栏期List
+          this.periodList = []
+          let periodList = []
+          let periodR = await this.$http({
+            url: this.$http.adornUrl("/management/period/findAll"),
+            method: "get"
+          })
+          periodR.data.all && (periodList = periodR.data.all)
+          periodList.forEach(period => {
+            let item = {
+              value: period.id,
+              label: period.number,
+              pigstyId: period.pigstyId
+            }
+            this.periodList.push(item)
+          })
+          this.periodSelectedList = this.periodList
+          // 获取猪只List
+          if (data && data.code === 0) {
+            this.dataList = data.page.list
+            this.totalPage = data.page.totalCount
+          } else {
+            this.dataList = []
+            this.totalPage = 0
+            this.$message.error(data.msg)
+          }
+          // 猪只信息与单元、牧场、栏期、栋舍对应
+          this.dataList.forEach((item) => {
+            // 单元对应
+            for (let unit of this.unitList) {
+              if (item.unitId === unit.value) {
+                item.unitNumber = unit.label;
+                item.farmId = unit.farmId;
+                item.pigstyId = unit.pigstyId;
+                break;
+              }
+            }
+            // // 牧场对应
+            // for (let pasture of pastureList) {
+            //   if (item.farmId === pasture.id) {
+            //     item.name = pasture.name;
+            //     break;
+            //   }
+            // }
+            // 栋舍对应
+            for (let pighouse of this.pigstyList) {
+              if (item.pigstyId === pighouse.value) {
+                item.phNumber = pighouse.label;
+                break;
+              }
+            }
+            // 栏期对应
+            for (let period of this.periodList) {
+              if (item.periodId === period.value) {
+                item.periodNumber = period.label;
+                break;
+              }
+            }
+          })
+          this.dataListLoading = false
+        })
+      },
+      // 根据栋舍选择限制单元和栏期
+      pigstyChange (val) {
+        this.unitSelectedList = this.unitList.filter(item => item.pigstyId === val)
+        this.periodSelectedList = this.periodList.filter(item => item.pigstyId === val)
+      },
+      // form表单清空,单元SelectedList 和 栏期SelectedList重置
+      clearAll () {
+        for (let i in this.form) {
+          this.form[i] = ''
+        }
+        this.unitSelectedList = this.unitList
+        this.periodSelectedList = this.periodList
+      },
+      // 每页数
+      sizeChangeHandle (val) {
+        this.pageSize = val
+        this.pageIndex = 1
+        this.getDataList()
+      },
+      // 当前页
+      currentChangeHandle (val) {
+        this.pageIndex = val
+        this.getDataList()
+      },
+      // 多选
+      selectionChangeHandle (val) {
+        this.dataListSelections = val
+      },
+      // 新增 / 修改
+      addOrUpdateHandle (id) {
+        this.addOrUpdateVisible = true
+        var ids = id ? [id] : this.dataListSelections.map(item => {
+          return {
+            id: item.id,
+            eartag: item.eartag
+          }
+        })
+        this.$nextTick(() => {
+          this.$refs.addOrUpdate.init(ids)
+        })
+      },
+      // 删除
+      deleteHandle (id) {
+        var ids = id ? [id] : this.dataListSelections.map(item => {
+          return item.id
+        })
+        this.$confirm(`确定对[id=${ids.join(',')}]进行[${id ? '删除' : '批量删除'}]操作?`, '提示', {
+          confirmButtonText: '确定',
+          cancelButtonText: '取消',
+          type: 'warning'
+        }).then(() => {
+          this.$http({
+            url: this.$http.adornUrl('/management/yearpigbase/delete'),
+            method: 'post',
+            data: this.$http.adornData(ids, false)
+          }).then(({data}) => {
+            if (data && data.code === 0) {
+              this.$message({
+                message: '操作成功',
+                type: 'success',
+                duration: 1500,
+                onClose: () => {
+                  this.getDataList()
+                }
+              })
+            } else {
+              this.$message.error(data.msg)
+            }
+          })
+        }).catch(() => {})
+      }
+    }
+  }
+</script>
+<style scoped>
+.rect {
+  background-color: #fff;
+  padding: 30px 15px;
+  border-radius: 5px;
+  border: 1px solid #e8e8e8;
+}
+.rect-form {
+  padding-bottom: 10px;
+}
+.rect-table {
+  margin-top: 20px;
+}
+.demo-table-expand {
+  font-size: 0;
+  margin-left: 40px;
+}
+.demo-table-expand label {
+  width: 90px;
+  color: #99a9bf;
+}
+.demo-table-expand .el-form-item {
+  margin-right: 0;
+  margin-bottom: 0;
+  width: 80%;
+}
+.el-table .height {
+  background: rgba(254, 254, 254, 0.5);
+}
+/deep/ .el-table--mini td, .el-table--mini th {
+  padding: 3px 0 !important;
+  height: 20px !important;
+}
+/deep/ .el-checkbox__input.is-checked+.el-checkbox__label {
+  color: rgb(24,144,255);
+  background-color: rgb(24,144,255);
+  border-color: rgb(24,144,255);
+}
+/deep/.el-table .el-checkbox__input.is-checked .el-checkbox__inner, .el-checkbox__input.is-indeterminate .el-checkbox__inner {
+  background-color: rgb(24,144,255);
+  border-color: rgb(24,144,255);
+}
+/deep/.el-table .el-checkbox__inner:hover {
+  border-color: rgb(24,144,255);
+}
+/deep/.el-table .el-checkbox__input.is-focus .el-checkbox__inner {
+  border-color: rgb(24,144,255);
+}
+/deep/.el-table #select .cell .el-checkbox__input.is-checked .el-checkbox__inner, .el-checkbox__input.is-indeterminate .el-checkbox__inner {
+  background-color: rgb(24,144,255);
+  border-color: rgb(24,144,255);
+}
+</style>