<template>
  <div class="app-container">
    <div class="operation">
      <el-button class="success" style="float: left;" @click="handleNutritional">营养评估</el-button>
      <el-button class="import" style="float: right;">导入</el-button>
      <el-dropdown style="float: right;margin-right: 10px;">
        <el-button class="export">导出</el-button>
        <el-dropdown-menu slot="dropdown">
          <el-dropdown-item @click.native="handleExport(1)">导出模板</el-dropdown-item>
          <el-dropdown-item @click.native="handleExport(2)">导出数据</el-dropdown-item>
        </el-dropdown-menu>
      </el-dropdown>
      <el-button class="export" style="float: right;margin-right: 10px;" @click="handleHistoryRecords">历史记录</el-button>
    </div>
    <div class="search" />
    <div class="table">
      <el-table
        :key="table.tableKey"
        v-loading="table.listLoading"
        element-loading-text="给我一点时间"
        :data="table.list"
        border
        fit
        highlight-current-row
        style="width: 100%;"
        :row-style="rowStyle"
        :cell-style="cellStyle"
        class="elTable table-fixed"
        @header-click="headerClick"
        @cell-click="cellClick"
        @selection-change="handleSelect"
      >
        <el-table-column type="selection" width="50" />
        <el-table-column :key="1" label="序号" align="center" type="index" width="50px">
          <template slot-scope="scope">
            <span>{{ scope.$index + (table.pageNum-1) * table.pageSize + 1 }}</span>
          </template>
        </el-table-column>
        <el-table-column :key="2" label="栏舍名称" min-width="100px" align="center">
          <template slot-scope="scope">
            <span>{{ scope.row.barname }}</span>
          </template>
        </el-table-column>
        <el-table-column :key="3" label="软件牛头数" min-width="100px" align="center">
          <template slot-scope="scope">
            <span>{{ scope.row.softccount }}</span>
          </template>
        </el-table-column>
        <el-table-column :key="4" label="实际牛头数" min-width="130px" align="center">
          <template slot-scope="scope">
            <span v-if="scope.row.NoEdit">{{ scope.row.ccount }}</span>
            <el-input v-if="scope.row.Edit" v-model="scope.row.ccount" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurCcount(scope.row)" />
          </template>
        </el-table-column>
        <el-table-column :key="5" label="系数(%)" min-width="130px" align="center">
          <template slot-scope="scope">
            <span v-if="scope.row.NoEdit">{{ scope.row.ratio }}</span>
            <el-input v-if="scope.row.Edit" v-model="scope.row.ratio" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurRatio(scope.row)" />
          </template>
        </el-table-column>
        <el-table-column :key="6" label="系数头数" min-width="130px" align="center">
          <template slot-scope="scope">
            <span v-if="scope.row.NoEdit">{{ scope.row.ccountratio }}</span>
            <el-input v-if="scope.row.Edit" v-model="scope.row.ccountratio" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurCcountratio(scope.row)" />
          </template>
        </el-table-column>
        <el-table-column :key="7" label="配方模板" min-width="130px" align="center">
          <template slot-scope="scope">
            <span v-if="scope.row.NoEdit">{{ scope.row.ftname }}</span>
            <el-select v-if="scope.row.Edit" v-model="scope.row.ftid" filterable placeholder="配方模板" class="filter-item" style="width:95%;padding:10px 0;"@change="(value)=> {changeRecipeTemplate(value, scope.row)}">
              <el-option v-for="item in recipeTemplateList" :key="item.id" :label="item.tname" :value="item.id" />
            </el-select>
          </template>
        </el-table-column>
        <el-table-column v-if="table.isPtsfname" :key="8" label="补料配方" min-width="130px" align="center">
          <template slot-scope="scope">
            <span v-if="scope.row.NoEdit">{{ scope.row.ptsfname }}</span>
            <el-select v-if="scope.row.Edit" v-model="scope.row.ptsfid" clearable filterable placeholder="补料配方" class="filter-item" style="width:95%;padding:10px 0;" @change="(value)=> {changeFeedingFormula(value, scope.row)}">
              <el-option v-for="item in feedingFormulaList" :key="item.id" :label="item.tname" :value="item.id" />
            </el-select>
          </template>
        </el-table-column>
        <el-table-column v-if="table.isRW1" :key="9" label="第一班比例(%)" min-width="130px" align="center">
          <template slot-scope="scope">
            <span v-if="scope.row.NoEdit">{{ scope.row.r1 }}</span>
            <el-input v-if="scope.row.Edit" v-model="scope.row.r1" :disabled="scope.row.isOneWeight" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurR(scope.row)" />
          </template>
        </el-table-column>
        <el-table-column v-if="table.isRW1" :key="10" label="第一班重量" min-width="130px" align="center" :render-header="renderHeader">
          <template slot-scope="scope">
            <span v-if="scope.row.NoEdit">{{ scope.row.w1 }}</span>
            <el-input v-if="scope.row.Edit" v-model="scope.row.w1" :disabled="scope.row.isOneWeight" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurW(scope.row)" @focus="focusW(scope.row)" />
          </template>
        </el-table-column>
        <el-table-column v-if="table.isRW2" :key="11" label="第二班比例(%)" min-width="130px" align="center">
          <template slot-scope="scope">
            <span v-if="scope.row.NoEdit">{{ scope.row.r2 }}</span>
            <el-input v-if="scope.row.Edit" v-model="scope.row.r2" step="0.01" type="number" :disabled="scope.row.isTwoWeight" style="width:95%;padding:10px 0;" @blur="blurR(scope.row)" />
          </template>
        </el-table-column>
        <el-table-column v-if="table.isRW2" :key="12" label="第二班重量" min-width="130px" align="center" :render-header="renderHeader">
          <template slot-scope="scope">
            <span v-if="scope.row.NoEdit">{{ scope.row.w2 }}</span>
            <el-input v-if="scope.row.Edit" v-model="scope.row.w2" :disabled="scope.row.isTwoWeight" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurW2(scope.row)" @focus="focusW2(scope.row)" />
          </template>
        </el-table-column>
        <el-table-column v-if="table.isRW3" :key="13" label="第三班比例(%)" min-width="130px" align="center">
          <template slot-scope="scope">
            <span v-if="scope.row.NoEdit">{{ scope.row.r3 }}</span>
            <el-input v-if="scope.row.Edit" v-model="scope.row.r3" step="0.01" type="number" :disabled="scope.row.isThreeWeight" style="width:95%;padding:10px 0;" @blur="blurR(scope.row)" />
          </template>
        </el-table-column>
        <el-table-column v-if="table.isRW3" :key="14" label="第三班重量" min-width="130px" align="center" :render-header="renderHeader">
          <template slot-scope="scope">
            <span v-if="scope.row.NoEdit">{{ scope.row.w3 }}</span>
            <el-input v-if="scope.row.Edit" v-model="scope.row.w3" :disabled="scope.row.isThreeWeight" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurW3(scope.row)" @focus="focusW3(scope.row)" />
          </template>
        </el-table-column>
        <el-table-column v-if="table.isRW4" :key="15" label="第四班比例(%)" min-width="130px" align="center">
          <template slot-scope="scope">
            <span v-if="scope.row.NoEdit">{{ scope.row.r4 }}</span>
            <el-input v-if="scope.row.Edit" v-model="scope.row.r4" step="0.01" type="number" :disabled="scope.row.isFourWeight" style="width:95%;padding:10px 0;" @blur="blurR(scope.row)" />
          </template>
        </el-table-column>
        <el-table-column v-if="table.isRW4" :key="16" label="第四班重量" min-width="130px" align="center" :render-header="renderHeader">
          <template slot-scope="scope">
            <span v-if="scope.row.NoEdit">{{ scope.row.w4 }}</span>
            <el-input v-if="scope.row.Edit" v-model="scope.row.w4" :disabled="scope.row.isFourWeight" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurW4(scope.row)" @focus="focusW4(scope.row)" />
          </template>
        </el-table-column>
        <el-table-column :key="17" label="总比例(%)" min-width="130px" align="center">
          <template slot-scope="scope">
            <span>{{ scope.row.sumr }}</span>
          </template>
        </el-table-column>
        <el-table-column :key="18" label="投喂量" min-width="130px" align="center">
          <template slot-scope="scope">
            <span>{{ scope.row.feedweight }}</span>
          </template>
        </el-table-column>
        <el-table-column :key="19" label="配方重量" min-width="130px" align="center">
          <template slot-scope="scope">
            <span>{{ scope.row.ftweight }}</span>
          </template>
        </el-table-column>
        <el-table-column v-if="table.isPtsfname" :key="20" label="补料重量" min-width="130px" align="center">
          <template slot-scope="scope">
            <span>{{ scope.row.supplyweight }}</span>
          </template>
        </el-table-column>
        <el-table-column label="操作" align="center" width="250" class-name="small-padding fixed-width" fixed="right">
          <template slot-scope="{row,column,event}">
            <!-- 编辑 -->
            <el-button v-if="row.isUpdate" class="miniSuccess" @click="handleUpdate(row)">编辑</el-button>
            <!-- 编辑保存 -->
            <el-button v-if="row.isUpdateSave" class="miniSuccess" :disabled="isokDisable" @click="updateData(row)">保存</el-button>
            <el-button v-if="row.isUpdateSave" class="minCancel" @click="updateCancel(row)">取消</el-button>
          </template>
        </el-table-column>
      </el-table>
      <pagination v-show="table.total>=0" :total="table.total" :page.sync="table.getdataListParm.offset" :limit.sync="table.getdataListParm.pagecount" @pagination="getList" />
    </div>
    <!-- 历史记录 -->
    <el-dialog :title="textMap[history.dialogStatus]" :destroy-on-close="true" :visible.sync="history.dialogFormVisible" :close-on-click-modal="false" width="90%">
      <div class="app-history">
        <div class="search">
          <el-date-picker v-model="history.getdataListParm.parammaps.date" type="date" placeholder="请选择历史记录时间" :clearable="false" style="width: 180px;" format="yyyy-MM-dd" value-format="yyyy-MM-dd" @change="changeDate" />
          <el-button class="successBorder" @click="handleApplication">应用</el-button>
        </div>
        <div class="table">
          <el-table
            :key="history.tableKey"
            v-loading="history.listLoading"
            element-loading-text="给我一点时间"
            :data="history.list"
            border
            fit
            highlight-current-row
            style="width: 100%;"
            :row-style="rowStyle"
            :cell-style="cellStyle"
            class="elTable table-fixed"
          >
            <el-table-column type="selection" width="50" />
            <el-table-column label="序号" align="center" type="index" width="50px">
              <template slot-scope="scope">
                <span>{{ scope.$index + (history.pageNum-1) * history.pageSize + 1 }}</span>
              </template>
            </el-table-column>
            <el-table-column label="栏舍名称" min-width="100px" align="center">
              <template slot-scope="scope">
                <span>{{ scope.row.barname }}</span>
              </template>
            </el-table-column>
            <el-table-column label="软件牛头数" min-width="100px" align="center">
              <template slot-scope="scope">
                <span>{{ scope.row.softccount }}</span>
              </template>
            </el-table-column>
            <el-table-column label="实际牛头数" min-width="130px" align="center">
              <template slot-scope="scope">
                <span v-if="scope.row.NoEdit">{{ scope.row.ccount }}</span>
                <el-input v-if="scope.row.Edit" v-model="scope.row.ccount" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurCcount(scope.row)" />
              </template>
            </el-table-column>
            <el-table-column label="系数(%)" min-width="130px" align="center">
              <template slot-scope="scope">
                <span v-if="scope.row.NoEdit">{{ scope.row.ratio }}</span>
                <el-input v-if="scope.row.Edit" v-model="scope.row.ratio" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurRatio(scope.row)" />
              </template>
            </el-table-column>
            <el-table-column label="系数头数" min-width="130px" align="center">
              <template slot-scope="scope">
                <span v-if="scope.row.NoEdit">{{ scope.row.ccountratio }}</span>
                <el-input v-if="scope.row.Edit" v-model="scope.row.ccountratio" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurCcountratio(scope.row)" />
              </template>
            </el-table-column>
            <el-table-column label="配方模板" min-width="130px" align="center">
              <template slot-scope="scope">
                <span v-if="scope.row.NoEdit">{{ scope.row.ftname }}</span>
                <el-select v-if="scope.row.Edit" v-model="scope.row.ftid" filterable placeholder="配方模板" class="filter-item" style="width:95%;padding:10px 0;" @change="(value)=> {changeRecipeTemplate(value, scope.row)}">
                  <el-option v-for="item in recipeTemplateList" :key="item.id" :label="item.tname" :value="item.id" />
                </el-select>
              </template>
            </el-table-column>
            <el-table-column v-if="history.isPtsfname" label="补料配方" min-width="130px" align="center">
              <template slot-scope="scope">
                <span v-if="scope.row.NoEdit">{{ scope.row.ptsfname }}</span>
                <el-select v-if="scope.row.Edit" v-model="scope.row.ptsfid" filterable placeholder="补料配方" class="filter-item" style="width:95%;padding:10px 0;" @change="(value)=> {changeFeedingFormula(value, scope.row)}">
                  <el-option v-for="item in feedingFormulaList" :key="item.id" :label="item.tname" :value="item.id" />
                </el-select>
              </template>
            </el-table-column>
            <el-table-column v-if="history.isRW1" label="第一班比例(%)" min-width="130px" align="center">
              <template slot-scope="scope">
                <span v-if="scope.row.NoEdit">{{ scope.row.r1 }}</span>
                <el-input v-if="scope.row.Edit" v-model="scope.row.r1" step="0.01" type="number" :disabled="scope.row.isOneWeight" style="width:95%;padding:10px 0;" @blur="blurR(scope.row)" />
              </template>
            </el-table-column>
            <el-table-column v-if="history.isRW1" label="第一班重量" min-width="130px" align="center">
              <template slot-scope="scope">
                <span v-if="scope.row.NoEdit">{{ scope.row.w1 }}</span>
                <el-input v-if="scope.row.Edit" v-model="scope.row.w1" :disabled="scope.row.isTwoWeight" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurW(scope.row)" />
              </template>
            </el-table-column>
            <el-table-column v-if="table.isRW2" label="第二班比例(%)" min-width="130px" align="center">
              <template slot-scope="scope">
                <span v-if="scope.row.NoEdit">{{ scope.row.r2 }}</span>
                <el-input v-if="scope.row.Edit" v-model="scope.row.r2" step="0.01" type="number" :disabled="scope.row.isTwoWeight" style="width:95%;padding:10px 0;" @blur="blurR(scope.row)" />
              </template>
            </el-table-column>
            <el-table-column v-if="history.isRW2" label="第二班重量" min-width="130px" align="center">
              <template slot-scope="scope">
                <span v-if="scope.row.NoEdit">{{ scope.row.w2 }}</span>
                <el-input v-if="scope.row.Edit" v-model="scope.row.w2" :disabled="scope.row.isTwoWeight" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurW2(scope.row)" />
              </template>
            </el-table-column>
            <el-table-column v-if="history.isRW3" label="第三班比例(%)" min-width="130px" align="center">
              <template slot-scope="scope">
                <span v-if="scope.row.NoEdit">{{ scope.row.r3 }}</span>
                <el-input v-if="scope.row.Edit" v-model="scope.row.r3" step="0.01" type="number" :disabled="scope.row.isThreeWeight" style="width:95%;padding:10px 0;" @blur="blurR(scope.row)" />
              </template>
            </el-table-column>
            <el-table-column v-if="history.isRW3" label="第三班重量" min-width="130px" align="center">
              <template slot-scope="scope">
                <span v-if="scope.row.NoEdit">{{ scope.row.w3 }}</span>
                <el-input v-if="scope.row.Edit" v-model="scope.row.w3" :disabled="scope.row.isThreeWeight" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurW3(scope.row)" />
              </template>
            </el-table-column>
            <el-table-column v-if="table.isRW4" label="第四班比例(%)" min-width="130px" align="center">
              <template slot-scope="scope">
                <span v-if="scope.row.NoEdit">{{ scope.row.r4 }}</span>
                <el-input v-if="scope.row.Edit" v-model="scope.row.r4" step="0.01" type="number" disabled="scope.row.isFourWeight" style="width:95%;padding:10px 0;" @blur="blurR(scope.row)" />
              </template>
            </el-table-column>
            <el-table-column v-if="history.isRW4" label="第四班重量" min-width="130px" align="center">
              <template slot-scope="scope">
                <span v-if="scope.row.NoEdit">{{ scope.row.w4 }}</span>
                <el-input v-if="scope.row.Edit" v-model="scope.row.w4" :disabled="scope.row.isFourWeight" step="0.01" type="number" style="width:95%;padding:10px 0;" @blur="blurW4(scope.row)" />
              </template>
            </el-table-column>
            <el-table-column label="总比例(%)" min-width="130px" align="center">
              <template slot-scope="scope">
                <span>{{ scope.row.sumr }}</span>
              </template>
            </el-table-column>
            <el-table-column label="投喂量" min-width="130px" align="center">
              <template slot-scope="scope">
                <span>{{ scope.row.feedweight }}</span>
              </template>
            </el-table-column>
            <el-table-column label="配方重量" min-width="130px" align="center">
              <template slot-scope="scope">
                <span>{{ scope.row.ftweight }}</span>
              </template>
            </el-table-column>
            <el-table-column v-if="history.isPtsfname" label="补料重量" min-width="130px" align="center">
              <template slot-scope="scope">
                <span>{{ scope.row.supplyweight }}</span>
              </template>
            </el-table-column>
          </el-table>
          <pagination v-show="history.total>0" :total="history.total" :page.sync="history.getdataListParm.offset" :limit.sync="history.getdataListParm.pagecount" @pagination="getHistoryList" />
        </div>
        <div slot="footer" class="dialog-footer">
          <el-button class="cancelClose" @click="history.dialogFormVisible = false; ">关闭</el-button>
        </div>
      </div>
    </el-dialog>

    <!-- 营养评估 -->
    <el-dialog :title="textMap[nutritional.dialogStatus]" :destroy-on-close="true" :visible.sync="nutritional.dialogFormVisible" :close-on-click-modal="false" width="90%">
      <div class="app-nutritional">
        <h4 style="position: absolute;top:-5px;left:140px;font:18px/24px '' ;color:#303133;">栏舍:{{ nutritional.temp.barname }}</h4>
        <el-form ref="temp" :rules="rules" :model="nutritional.temp" label-position="right" label-width="95px" style="width: 100%;margin-bottom:30px">
          <el-row>
            <el-col :span="4">
              <el-form-item label="类别" prop="cowclassid">
                <el-select v-model="nutritional.temp.cowclassid" :disabled="nutritional.disabledCowclass" filterable placeholder="" class="filter-item" style="width:100%;">
                  <el-option v-for="item in livestockTypeList" :key="item.id" :label="item.mixname" :value="item.id" />
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="4">
              <el-form-item label="月龄" prop="avgmonthage">
                <el-input ref="avgmonthage" v-model="nutritional.temp.avgmonthage" class="filter-item" placeholder="" style="width:100%;" />
              </el-form-item>
            </el-col>
            <el-col :span="4">
              <el-form-item label="体重(kg)" prop="bw">
                <el-input ref="bw" v-model="nutritional.temp.bw" class="filter-item" placeholder="" style="width:100%;" />
              </el-form-item>
            </el-col>
            <el-col :span="4">
              <el-form-item label="日增重(kg)" prop="dayw">
                <el-input ref="dayw" v-model="nutritional.temp.dayw" class="filter-item" placeholder="" style="width:100%;" />
              </el-form-item>
            </el-col>
            <el-col :span="4">
              <el-form-item label="胎次(次)" prop="fetal">
                <el-input ref="fetal" v-model="nutritional.temp.fetal" class="filter-item" placeholder="" style="width:100%;" />
              </el-form-item>
            </el-col>
            <el-col :span="4">
              <el-form-item label="泌乳天数(天)" prop="avgdim">
                <el-input ref="avgdim" v-model="nutritional.temp.avgdim" class="filter-item" placeholder="" style="width:100%;" />
              </el-form-item>
            </el-col>
          </el-row>
          <el-row>
            <el-col :span="4">
              <el-form-item label="怀孕天数(天)" prop="dayspre">
                <el-input ref="dayspre" v-model="nutritional.temp.dayspre" class="filter-item" placeholder="" style="width:100%;" />
              </el-form-item>
            </el-col>
            <el-col :span="4">
              <el-form-item label="产奶量(kg)" prop="product">
                <el-input ref="product" v-model="nutritional.temp.product" class="filter-item" placeholder="" style="width:100%;" />
              </el-form-item>
            </el-col>
            <el-col :span="4">
              <el-form-item label="乳脂率(%)" prop="fat">
                <el-input ref="fat" v-model="nutritional.temp.fat" class="filter-item" placeholder="" style="width:100%;" />
              </el-form-item>
            </el-col>
            <el-col :span="4">
              <el-form-item label="乳蛋白率(%)" prop="pro">
                <el-input ref="pro" v-model="nutritional.temp.pro" class="filter-item" placeholder="" style="width:100%;" />
              </el-form-item>
            </el-col>
            <el-col :span="4">
              <el-form-item label="乳糖率(%)" prop="lactose">
                <el-input ref="lactose" v-model="nutritional.temp.lactose" class="filter-item" placeholder="" style="width:100%;" />
              </el-form-item>
            </el-col>
            <el-col :span="4">
              <el-form-item label="温度(℃)" prop="tem">
                <el-input ref="tem" v-model="nutritional.temp.tem" class="filter-item" placeholder="" style="width:100%;" />
              </el-form-item>
            </el-col>
          </el-row>
        </el-form>
        <div style="position: relative;height: 50px;">
          <el-button class="success" :disabled="isokDisable" style="position: absolute;left: 0;right: 0;margin:0 auto;" @click="assessmentData()">评估</el-button>
        </div>
        <div class="table">
          <el-table
            :key="nutritional.tableKey"
            v-loading="nutritional.listLoading"
            element-loading-text="给我一点时间"
            :data="nutritional.list"
            border
            fit
            highlight-current-row
            style="width: 100%;margin-bottom:60px;"
            :row-style="rowStyle"
            :cell-style="cellStyle"
            class="elTable table-fixed"
          >
            <el-table-column type="selection" width="50" />
            <el-table-column label="序号" align="center" type="index" width="50px">
              <template slot-scope="scope">
                <span>{{ scope.$index + (nutritional.pageNum-1) * nutritional.pageSize + 1 }}</span>
              </template>
            </el-table-column>
            <el-table-column label="指标" min-width="130px" align="center">
              <template slot-scope="scope">
                <span>{{ scope.row.standard }}</span>
              </template>
            </el-table-column>
            <el-table-column label="奶牛需要" min-width="130px" align="center">
              <template slot-scope="scope">
                <span>{{ scope.row.cowneed }}</span>
              </template>
            </el-table-column>
            <el-table-column label="饲料提供" min-width="130px" align="center">
              <template slot-scope="scope">
                <span>{{ scope.row.feedprov }}</span>
              </template>
            </el-table-column>
            <el-table-column label="实际执行" min-width="130px" align="center">
              <template slot-scope="scope">
                <span>{{ scope.row.actprov }}</span>
              </template>
            </el-table-column>
            <el-table-column label="相差" min-width="130px" align="center">
              <template slot-scope="scope">
                <span>{{ scope.row.diff }}</span>
              </template>
            </el-table-column>
            <el-table-column label="粗料提供" min-width="130px" align="center">
              <template slot-scope="scope">
                <span>{{ scope.row.cprov }}</span>
              </template>
            </el-table-column>
            <el-table-column label="精料提供" min-width="130px" align="center">
              <template slot-scope="scope">
                <span>{{ scope.row.jprov }}</span>
              </template>
            </el-table-column>
          </el-table>
        </div>
        <div slot="footer" class="dialog-footer">
          <el-button class="cancelClose" @click="nutritional.dialogFormVisible = false; ">关闭</el-button>
        </div>
      </div>
    </el-dialog>

  </div>
</template>

<script>
import { GetDataByName, GetDataByNames, ExecDataByConfig, failproccess, PostDataByName } from '@/api/common'
import Pagination from '@/components/Pagination'
import { parseTime } from '@/utils/index.js'
import { MessageBox } from 'element-ui'
import Cookies from 'js-cookie'
export default {
  inject: ['reload'],
  name: 'DhedFormula',
  components: { Pagination },
  data() {
    return {
      requestParams: [
        { name: 'getFTSWList', offset: 0, pagecount: 0, parammaps: { pastureid: Cookies.get('pastureid') }},
        { name: 'getFTBLList', offset: 0, pagecount: 0, parammaps: { pastureid: Cookies.get('pastureid') }},
        { name: 'getCowclassListEnable', offset: 0, pagecount: 0, parammaps: { pastureid: Cookies.get('pastureid') }}
      ],
      recipeTemplateList: [], // 配方模板
      feedingFormulaList: [], // 补料配方
      livestockTypeList: [], // 类别
      rules: {
        cowclassid: [{ type: 'string', required: true, message: '必填', trigger: 'blur' }]
      },
      table: {
        getdataListParm: {
          name: 'getFPList',
          page: 1,
          offset: 1,
          pagecount: 10,
          returntype: 'Map',
          parammaps: {
            pastureid: Cookies.get('pastureid'),
            enable: ''
          }
        },
        tableKey: 0,
        list: [],
        total: 0,
        listLoading: true,
        temp: {},
        rwList: [],
        isPtsfname: false, // 补料配方/补料重量
        getdataListParm2: {
          name: 'getSysoptEnable',
          page: 1,
          offset: 1,
          pagecount: 1,
          returntype: 'Map',
          parammaps: {
            pastureid: Cookies.get('pastureid'),
            inforname: 'isEnableSupplyFeed'
          }
        },
        isRW1: false, // 第一班
        isRW2: false, // 第二班
        isRW3: false, // 第三班
        isRW4: false, // 第四班
        getdataListParm3: {
          name: 'getSysoptEnable1',
          page: 1,
          offset: 1,
          pagecount: 1,
          returntype: 'Map',
          parammaps: {
            pastureid: Cookies.get('pastureid'),
            inforname: 'times'
          }
        },
        RWLength: '' // 班次长度
      },
      selectList: [],
      // 营养评估
      nutritional: {
        dialogFormVisible: false,
        dialogStatus: '',
        listLoading1: true,
        getdataListParm1: {
          name: 'getnurj',
          page: 1,
          offset: 1,
          pagecount: 10,
          returntype: 'Map',
          parammaps: {
            pastureid: '',
            barid: ''
          }
        },
        disabledCowclass: false,
        temp: {},
        tableKey: 0,
        list: [],
        total2: 0,
        listLoading2: true,
        getdataListParm2: {
          name: 'judgenurV2',
          page: 1,
          offset: 1,
          pagecount: 10,
          returntype: 'Map',
          parammaps: {
            pastureid: '',
            cowclassid: ''
          }
        }
      },
      history: {
        dialogFormVisible: false,
        dialogStatus: '',
        temp: {},
        rules: {},
        tableKey: 0,
        list: [],
        total: 0,
        listLoading: true,
        getdataListParm: {
          name: 'getFPListDate',
          page: 1,
          offset: 1,
          pagecount: 10,
          returntype: 'Map',
          parammaps: {
            pastureid: Cookies.get('pastureid'),
            date: ''
          }
        },
        isPtsfname: false, // 补料配方/补料重量
        getdataListParm2: {
          name: 'getSysoptEnable',
          page: 1,
          offset: 1,
          pagecount: 1,
          returntype: 'Map',
          parammaps: {
            pastureid: Cookies.get('pastureid'),
            inforname: 'isEnableSupplyFeed'
          }
        },
        isRW1: false, // 第一班
        isRW2: false, // 第二班
        isRW3: false, // 第三班
        isRW4: false, // 第四班
        getdataListParm3: {
          name: 'getSysoptEnable1',
          page: 1,
          offset: 1,
          pagecount: 1,
          returntype: 'Map',
          parammaps: {
            pastureid: Cookies.get('pastureid'),
            inforname: 'times'
          }
        },
        getdataDateParm: {
          name: 'getFPMaxDate',
          page: 1,
          offset: 1,
          pagecount: 10,
          returntype: 'Map',
          parammaps: {
            pastureid: Cookies.get('pastureid')
          }
        }
      },
      textMap: {
        Nutritional: '营养评估',
        history: '历史记录'
      },
      focusWRow: {}, // 一班重量得到焦点暂存
      focusWRow2: {}, // 2班重量得到焦点暂存
      focusWRow3: {}, // 3班重量得到焦点暂存
      focusWRow4: {}, // 4班重量得到焦点暂存

      requestParam: {},
      isokDisable: false,
      rowStyle: { maxHeight: 50 + 'px', height: 45 + 'px' },
      cellStyle: { padding: 0 + 'px' }
    }
  },

  created() {
    this.getIsDisplay()
    this.getDownList()
  },

  methods: {
    getDownList() {
      GetDataByNames(this.requestParams).then(response => {
        this.recipeTemplateList = response.data.getFTSWList.list
        this.feedingFormulaList = response.data.getFTBLList.list
        this.livestockTypeList = response.data.getCowclassListEnable.list
      })
    },

    getIsDisplay() {
      GetDataByName(this.table.getdataListParm2).then(response => {
        console.log(response.data.list[0].inforvalue)
        if (response.data.list !== null) {
          if (response.data.list[0].inforvalue == 0) {
            this.table.isPtsfname = false
          } else {
            this.table.isPtsfname = true
          }
        }
      })
      GetDataByName(this.table.getdataListParm3).then(response => {
        console.log(response.data.list[0].inforvalue)
        if (response.data.list !== null) {
          this.table.RWLength = response.data.list[0].inforvalue
          if (response.data.list[0].inforvalue == 1) {
            this.table.isRW1 = true
            this.table.isRW2 = false
            this.table.isRW3 = false
            this.table.isRW4 = false
          } else if (response.data.list[0].inforvalue == 2) {
            this.table.isRW1 = true
            this.table.isRW2 = true
            this.table.isRW3 = false
            this.table.isRW4 = false
          } else if (response.data.list[0].inforvalue == 3) {
            this.table.isRW1 = true
            this.table.isRW2 = true
            this.table.isRW3 = true
            this.table.isRW4 = false
          } else if (response.data.list[0].inforvalue == 4) {
            this.table.isRW1 = true
            this.table.isRW2 = true
            this.table.isRW3 = true
            this.table.isRW4 = true
          }
        } else {
          this.table.isRW1 = false
          this.table.isRW2 = false
          this.table.isRW3 = false
          this.table.isRW4 = false
        }
      })
      this.getList()
    },
    getList() {
      this.table.listLoading = true
      GetDataByName(this.table.getdataListParm).then(response => {
        console.log('table数据', response.data.list)
        if (response.data.list !== null) {
          for (let i = 0; i < response.data.list.length; i++) {
            this.$set(response.data.list[i], 'Edit', false) // 编辑
            this.$set(response.data.list[i], 'NoEdit', true) // 不可编辑/输入
            this.$set(response.data.list[i], 'isUpdate', true) // 编辑操作
            this.$set(response.data.list[i], 'isUpdateSave', false) // 编辑保存
            if (response.data.list[i].ftid == undefined || response.data.list[i].ftname == '') {
              this.$set(response.data.list[i], 'ftid', '')
              this.$set(response.data.list[i], 'ftname', '')
            }
            if (response.data.list[i].ptsfid == undefined || response.data.list[i].ptsfname == '') {
              this.$set(response.data.list[i], 'ptsfid', '')
              this.$set(response.data.list[i], 'ptsfname', '')
            }
            if (response.data.list[i].ccount == undefined) {
              this.$set(response.data.list[i], 'ccount', '')
            }
            if (response.data.list[i].softccount == undefined) {
              this.$set(response.data.list[i], 'softccount', '')
            }
            if (response.data.list[i].ratio == undefined) {
              this.$set(response.data.list[i], 'ratio', 100)
            }
            if (response.data.list[i].ccountratio == undefined) {
              this.$set(response.data.list[i], 'ccountratio', '')
            }
            if (response.data.list[i].r1 == undefined) {
              this.$set(response.data.list[i], 'r1', '')
            }
            if (response.data.list[i].r2 == undefined) {
              this.$set(response.data.list[i], 'r2', '')
            }
            if (response.data.list[i].r3 == undefined) {
              this.$set(response.data.list[i], 'r3', '')
            }
            if (response.data.list[i].r4 == undefined) {
              this.$set(response.data.list[i], 'r4', '')
            }
            if (response.data.list[i].w1 == undefined) {
              this.$set(response.data.list[i], 'w1', '')
            }
            if (response.data.list[i].w2 == undefined) {
              this.$set(response.data.list[i], 'w2', '')
            }
            if (response.data.list[i].w3 == undefined) {
              this.$set(response.data.list[i], 'w3', '')
            }
            if (response.data.list[i].w4 == undefined) {
              this.$set(response.data.list[i], 'w4', '')
            }
            if (response.data.list[i].supplyweight == undefined) {
              this.$set(response.data.list[i], 'supplyweight', '')
            }
            if (response.data.list[i].feedweight == undefined) {
              this.$set(response.data.list[i], 'feedweight', '')
            }
            if (response.data.list[i].Bfweight == undefined) {
              this.$set(response.data.list[i], 'Bfweight', '')
            }
            if (response.data.list[i].Sfweight == undefined) {
              this.$set(response.data.list[i], 'Sfweight', '')
            }
            if (response.data.list[i].isOneWeight == undefined) {
              this.$set(response.data.list[i], 'isOneWeight', false)
            }
            if (response.data.list[i].isTwoWeight == undefined) {
              this.$set(response.data.list[i], 'isTwoWeight', false)
            }
            if (response.data.list[i].isThreeWeight == undefined) {
              this.$set(response.data.list[i], 'isThreeWeight', false)
            }
            if (response.data.list[i].isFourWeight == undefined) {
              this.$set(response.data.list[i], 'isFourWeight', false)
            }
            if (response.data.list[i].timesopt !== undefined) {
              var timesoptArr = response.data.list[i].timesopt.split(',')
              for (let j = 0; j < timesoptArr.length; j++) {
                response.data.list[i]['r' + timesoptArr[j].split(':')[0]] = timesoptArr[j].split(':')[1]
                response.data.list[i]['w' + timesoptArr[j].split(':')[0]] = timesoptArr[j].split(':')[2]
              }
            }
          }
          // console.log(response.data.list, sumr)
          for (let i = 0; i < response.data.list.length; i++) {
            if (response.data.list[i].r1 == '') {
              response.data.list[i].r1 = 0
            }
            if (response.data.list[i].r2 == '') {
              response.data.list[i].r2 = 0
            }
            if (response.data.list[i].r3 == '') {
              response.data.list[i].r3 = 0
            }
            if (response.data.list[i].r4 == '') {
              response.data.list[i].r4 = 0
            }
            this.$set(response.data.list[i], 'sumr', parseFloat(response.data.list[i].r1) + parseFloat(response.data.list[i].r2) + parseFloat(response.data.list[i].r3) + parseFloat(response.data.list[i].r4))
            response.data.list[i].sumr = response.data.list[i].sumr.toFixed(2)
          }
          this.table.list = response.data.list
          console.log(this.table.list, 'this.table.list')
          this.table.pageNum = response.data.pageNum
          this.table.pageSize = response.data.pageSize
          this.table.total = response.data.total
        } else {
          this.table.list = []
        }
        setTimeout(() => {
          this.table.listLoading = false
        }, 100)
      })
    },

    renderHeader(h, { column, $index }) { // h即为cerateElement的简写,具体可看vue官方文档
      // console.log(column)
      return h(
        'div',
        [
          h('span', column.label),
          h('i', {
            class: 'el-icon-unlock',
            ref: 'el-icon-unlock',
            style: 'margin-left:5px;'
          })
        ]
      )
    },

    headerClick(column, event) {
      console.log(column, event)
      if (column.label == '第一班重量') {
        for (let i = 0; i < this.table.list.length; i++) {
          if (this.table.list[i].Edit == true) {
            if (event.target.outerHTML == '<i class="el-icon-unlock" style="margin-left: 5px;"></i>') {
              event.target.className = 'el-icon-lock'
              this.$set(this.table.list[i], 'isOneWeight', true) // 锁住不可编辑
            } else if (event.target.outerHTML == '<i class="el-icon-lock" style="margin-left: 5px;"></i>') {
              event.target.className = 'el-icon-unlock'
              this.$set(this.table.list[i], 'isOneWeight', false) // 解锁可编辑
            }
          }
        }
      } else if (column.label == '第二班重量') {
        for (let i = 0; i < this.table.list.length; i++) {
          if (this.table.list[i].Edit == true) {
            if (event.target.outerHTML == '<i class="el-icon-unlock" style="margin-left: 5px;"></i>') {
              event.target.className = 'el-icon-lock'
              this.$set(this.table.list[i], 'isTwoWeight', true) // 锁住不可编辑
            } else if (event.target.outerHTML == '<i class="el-icon-lock" style="margin-left: 5px;"></i>') {
              event.target.className = 'el-icon-unlock'
              this.$set(this.table.list[i], 'isTwoWeight', false) // 解锁可编辑
            }
          }
        }
      } else if (column.label == '第三班重量') {
        for (let i = 0; i < this.table.list.length; i++) {
          if (this.table.list[i].Edit == true) {
            if (event.target.outerHTML == '<i class="el-icon-unlock" style="margin-left: 5px;"></i>') {
              event.target.className = 'el-icon-lock'
              this.$set(this.table.list[i], 'isThreeWeight', true) // 锁住不可编辑
            } else if (event.target.outerHTML == '<i class="el-icon-lock" style="margin-left: 5px;"></i>') {
              event.target.className = 'el-icon-unlock'
              this.$set(this.table.list[i], 'isThreeWeight', false) // 解锁可编辑
            }
          }
        }
      } else if (column.label == '第四班重量') {
        for (let i = 0; i < this.table.list.length; i++) {
          if (this.table.list[i].Edit == true) {
            if (event.target.outerHTML == '<i class="el-icon-unlock" style="margin-left: 5px;"></i>') {
              event.target.className = 'el-icon-lock'
              this.$set(this.table.list[i], 'isFourWeight', true) // 锁住不可编辑
            } else if (event.target.outerHTML == '<i class="el-icon-lock" style="margin-left: 5px;"></i>') {
              event.target.className = 'el-icon-unlock'
              this.$set(this.table.list[i], 'isFourWeight', false) // 解锁可编辑
            }
          }
        }
      }
    },
    // 配方模板
    changeRecipeTemplate(item, row) {
      console.log(row.supplyweight, 'row.supplyweight')
      row.ftname = this.recipeTemplateList.find(obj => obj.id == item).tname
      row.Sfweight = this.recipeTemplateList.find(obj => obj.id == item).Sfweight// Sfweight
      row.SfweightLock = this.recipeTemplateList.find(obj => obj.id == item).SfweightLock// SfweightLock
      // 补料重量supplyweight
      // 配方重量ftweight
      // 系数头数ccountratio
      // 投喂量feedweight
      // 实际牛头数ccount
      // 投喂量 = 配方重量 + 补料重量
      // 配方重量 = Sfweight * 系数头数 + SfweightLock * 实际牛头数ccount
      console.log(row.Sfweight, 'row.Sfweight')
      console.log(row.ccountratio, '系数头数')
      console.log(row.SfweightLock, 'SfweightLock')
      console.log(row.ccount, '实际牛头数')
      if (row.Sfweight !== '' && row.ccount !== '') {
        this.$set(row, 'ftweight', (parseFloat(row.Sfweight) * parseFloat(row.ccountratio) + parseFloat(row.SfweightLock) * parseFloat(row.ccount)).toFixed(2))
      } else {
        row.ftweight = ''
      }
      // console.log(row.ftweight, 'row.ftweight')
      // console.log(row.supplyweight, 'row.supplyweight')
      // console.log(this.table.isPtsfname, 'isPtsfname')
      if (this.table.isPtsfname == false) {
        row.feedweight = parseFloat(row.ftweight).toFixed(2)
      } else {
        if (row.supplyweight == 'NaN') {
          row.supplyweight = 0
        }
        console.log(row.supplyweight)
        if (row.supplyweight !== '' && row.ftweight !== '') {
          row.feedweight = (parseFloat(row.supplyweight) + parseFloat(row.ftweight)).toFixed(2)
        } else if (row.supplyweight == '' && row.ftweight !== '') {
          row.feedweight = parseFloat(row.ftweight).toFixed(2)
        } else if (row.supplyweight !== '' && row.ftweight !== '') {
          row.feedweight = parseFloat(row.supplyweight).toFixed(2)
        }

        if (row.ccountratio !== '' && row.ftweight !== '') {
          row.ftweight = (parseFloat(row.Sfweight) * parseFloat(row.ccountratio) + parseFloat(row.SfweightLock) * parseFloat(row.ccount)).toFixed(2)
        }
        // if (row.ccountratio !== '' && row.BLweight !== '') {
        //   row.supplyweight = (parseFloat(row.BLweight) * parseFloat(row.ccountratio)).toFixed(2)
        // }
        // console.log(row.BLweight, row.ccountratio)
        if (row.Sfweight !== '' && row.ccount !== '') {
          this.$set(row, 'ftweight', (parseFloat(row.Sfweight) * parseFloat(row.ccountratio) + parseFloat(row.SfweightLock) * parseFloat(row.ccount)).toFixed(2))
        } else {
          row.ftweight = ''
        }
      }
      console.log(row.supplyweight)
      if (row.supplyweight == 'NaN') { row.supplyweight = 0 }
      if (row.r1 !== '') { this.$set(row, 'w1', (parseFloat(row.feedweight) * (parseFloat(row.r1) / 100)).toFixed(2)) }
      if (row.r2 !== '') { this.$set(row, 'w2', (parseFloat(row.feedweight) * (parseFloat(row.r2) / 100)).toFixed(2)) }
      if (row.r3 !== '') { this.$set(row, 'w3', (parseFloat(row.feedweight) * (parseFloat(row.r3) / 100)).toFixed(2)) }
      if (row.r4 !== '') { this.$set(row, 'w4', (parseFloat(row.feedweight) * (parseFloat(row.r4) / 100)).toFixed(2)) }
    },
    // 补料配方
    changeFeedingFormula(item, row) {
      console.log(item, '=========')
      // 补料重量supplyweight
      // 配方重量ftweight
      // 系数头数ccountratio
      // 投喂量feedweight
      // 实际牛头数ccount
      // 投喂量 = 配方重量 + 补料重量
      if (item !== '') {
        console.log(456)
        row.ptsfname = this.feedingFormulaList.find(obj => obj.id == item).tname
        row.BLweight = this.feedingFormulaList.find(obj => obj.id == item).Sfweight
        row.BLSfweightLock = this.feedingFormulaList.find(obj => obj.id == item).SfweightLock
      } else {
        console.log(123)
        row.ptsfname = ''
        row.BLweight = 0
        row.BLSfweightLock = 0
      }
      // 配方重量 = 系数头数 * Sfweight
      // if (row.ccountratio !== '' && row.ftweight !== '') {
      //   row.ftweight = parseFloat(row.Sfweight) * parseFloat(row.ccountratio)
      // }

      // 补料重量 = 系数头数 * BLweight
      // console.log(row.ccountratio)
      // console.log(row.ccount)
      // console.log(row.BLweight)
      // console.log(row.BLSfweightLock)
      if (row.ccountratio !== '' && row.ccount !== '' && row.ccount.BLweight !== '' && row.BLSfweightLock !== '') {
        this.$set(row, 'supplyweight', (parseFloat(row.BLweight) * parseFloat(row.ccountratio) + parseFloat(row.BLSfweightLock) * parseFloat(row.ccount)).toFixed(2))
      } else {
        row.supplyweight = ''
      }
      // if (row.Sfweight !== '' && row.ccount !== '') {
      //   this.$set(row, 'ftweight', (parseFloat(row.Sfweight) * parseFloat(row.ccountratio) + parseFloat(row.SfweightLock) * parseFloat(row.ccount)).toFixed(2))
      // } else {
      //   row.ftweight = ''
      // }

      if (this.table.isPtsfname == false) {
        row.feedweight = parseFloat(row.ftweight)
      } else {
        if (row.supplyweight !== '' && row.ftweight !== '') {
          row.feedweight = (parseFloat(row.supplyweight) + parseFloat(row.ftweight)).toFixed(2)
        } else if (row.supplyweight == '' && row.ftweight !== '') {
          row.feedweight = parseFloat(row.ftweight).toFixed(2)
        } else if (row.supplyweight !== '' && row.ftweight == '') {
          row.feedweight = parseFloat(row.supplyweight).toFixed(2)
        }
        // if (row.ccountratio !== '' && row.ftweight !== '') {
        //   row.ftweight = parseFloat(row.Sfweight) * parseFloat(row.ccountratio)
        // }
        // if (row.ccountratio !== '' && row.BLweight !== '') {
        //   row.supplyweight = parseFloat(row.BLweight) * parseFloat(row.ccountratio)
        // }
      }
      if (row.r1 !== '') { this.$set(row, 'w1', (parseFloat(row.feedweight) * (parseFloat(row.r1) / 100)).toFixed(2)) }
      if (row.r2 !== '') { this.$set(row, 'w2', (parseFloat(row.feedweight) * (parseFloat(row.r2) / 100)).toFixed(2)) }
      if (row.r3 !== '') { this.$set(row, 'w3', (parseFloat(row.feedweight) * (parseFloat(row.r3) / 100)).toFixed(2)) }
      if (row.r4 !== '') { this.$set(row, 'w4', (parseFloat(row.feedweight) * (parseFloat(row.r4) / 100)).toFixed(2)) }
    },
    // 实际牛头数失去焦点计算
    // ccount实际牛头数
    // ratio系数
    // ccountratio系数牛头数
    blurCcount(row) { // 实际牛头数
      console.log(row)
      if (row.ftid !== '-1' && row.ftid !== '') {
        console.log(this.recipeTemplateList.find(obj => obj.id == row.ftid).Sfweight)
        row.Sfweight = this.recipeTemplateList.find(obj => obj.id == row.ftid).Sfweight
        row.SfweightLock = this.recipeTemplateList.find(obj => obj.id == row.ftid).SfweightLock
      }
      if (row.ptsfid !== '-1' && row.ptsfid !== '' && this.table.isPtsfname == true) {
        // row.ptsfid = parseInt(row.ptsfid)
        row.BLweight = parseFloat(this.feedingFormulaList.find(obj => obj.id == row.ptsfid).Sfweight)
        row.BLweightLock = parseFloat(this.feedingFormulaList.find(obj => obj.id == row.ptsfid).SfweightLock)
      }
      if (row.ptsfid == '') {
        row.BLweight = 0
        row.BLweightLock = 0
      }
      if (row.Sfweight !== '' && row.ccount !== '') {
        // console.log(parseFloat(row.Sfweight) * parseFloat(row.ccountratio) + parseFloat(row.SfweightLock) * parseFloat(row.ccount))
        row.ftweight = parseFloat(row.Sfweight) * parseFloat(row.ccountratio) + parseFloat(row.SfweightLock) * parseFloat(row.ccount)
      }
      // 系数牛头数 = 实际牛头数 * 系数/100
      if (row.ccount !== '' && row.ratio !== '') {
        row.ccountratio = parseFloat(row.ccount) * parseFloat(row.ratio) / 100
      } else if (row.ratio !== '' && row.ccountratio !== '') {
        row.ccount = parseFloat(row.ccountratio) * 100 / parseFloat(row.ratio) / 100
      } else if (row.ccount !== '' || row.ratio !== '') {
        row.ccountratio = ''
      }
      // 补料重量
      console.log(row.ccountratio, row.BLweight)
      if (row.BLweight == 'undefined') {
        this.$set(row, 'BLweight', '')
      }
      console.log('BLweight', row.BLweight)
      console.log('ccountratio', row.ccountratio)
      console.log('BLweightLock', row.BLweightLock)
      console.log('ccount', row.ccount)
      if (row.ccountratio !== '' && row.BLweight !== '') {
        row.supplyweight = (parseFloat(row.BLweight) * parseFloat(row.ccountratio) + parseFloat(row.BLweightLock) * parseFloat(row.ccount)).toFixed(2)
      } else if (row.ccountratio !== '' && row.BLweight == '') {
        row.supplyweight = ''
        row.feedweight = ''
      } else if (row.ccountratio == '' && row.BLweight !== '') {
        row.supplyweight = ''
        row.feedweight = ''
      }
      // 配方重量
      if (row.ccountratio !== '' && row.Sfweight !== '') {
        row.ftweight = parseFloat(row.Sfweight) * parseFloat(row.ccountratio) + parseFloat(row.SfweightLock) * parseFloat(row.ccount)
      } else if (row.ccountratio !== '' && row.Sfweight == '') {
        row.ftweight = ''
        row.feedweight = ''
      } else if (row.ccountratio == '' && row.Sfweight !== '') {
        row.ftweight = ''
        row.feedweight = ''
      }
      if (this.table.isPtsfname == false) {
        row.feedweight = parseFloat(row.ftweight)
      } else {
        if (row.supplyweight !== '' && row.ftweight !== '') {
          row.feedweight = (parseFloat(row.supplyweight) + parseFloat(row.ftweight)).toFixed(2)
        } else if (row.supplyweight !== '' && row.ftweight == '') {
          row.feedweight = parseFloat(row.supplyweight).toFixed(2)
        } else if (row.supplyweight == '' && row.ftweight !== '') {
          row.feedweight = parseFloat(row.ftweight).toFixed(2)
        }
        // 配方重量 = 系数头数 * Sfweight
        if (row.ccountratio !== '' && row.ftweight !== '') {
          row.ftweight = parseFloat(row.Sfweight) * parseFloat(row.ccountratio) + parseFloat(row.SfweightLock) * parseFloat(row.ccount)
        }
        // 补料重量 = 系数头数 * BLweight
        if (row.ccountratio !== '' && row.BLweight !== '') {
          row.supplyweight = (parseFloat(row.BLweight) * parseFloat(row.ccountratio) + parseFloat(row.BLweightLock) * parseFloat(row.ccount)).toFixed(2)
        }
      }
      if (row.r1 !== '') { this.$set(row, 'w1', (parseFloat(row.feedweight) * (parseFloat(row.r1) / 100)).toFixed(2)) }
      if (row.r2 !== '') { this.$set(row, 'w2', (parseFloat(row.feedweight) * (parseFloat(row.r2) / 100)).toFixed(2)) }
      if (row.r3 !== '') { this.$set(row, 'w3', (parseFloat(row.feedweight) * (parseFloat(row.r3) / 100)).toFixed(2)) }
      if (row.r4 !== '') { this.$set(row, 'w4', (parseFloat(row.feedweight) * (parseFloat(row.r4) / 100)).toFixed(2)) }
    },
    blurRatio(row) {
      console.log(row, '--------------')

      if (row.ftid !== '-1' && row.ftid !== '') {
        row.Sfweight = this.recipeTemplateList.find(obj => obj.id == row.ftid).Sfweight
        row.SfweightLock = this.recipeTemplateList.find(obj => obj.id == row.ftid).SfweightLock
      }
      if (row.ptsfid !== '-1' && row.ptsfid !== '' && this.table.isPtsfname == true) {
        // row.ptsfid = parseInt(row.ptsfid)
        row.BLweight = parseFloat(this.feedingFormulaList.find(obj => obj.id == row.ptsfid).Sfweight)
        row.BLweightLock = parseFloat(this.feedingFormulaList.find(obj => obj.id == row.ptsfid).SfweightLock)
      }
      if (row.ptsfid == '') {
        row.BLweight = 0
        row.BLweightLock = 0
      }
      // 系数
      if (row.ccount !== '' && row.ratio !== '' && row.ccountratio !== '') {
        row.ccountratio = parseFloat(row.ccount) * parseFloat(row.ratio) / 100
      } else if (row.ccount !== '' && row.ccountratio !== '') {
        row.ratio = (parseFloat(row.ccountratio) * 100 / parseFloat(row.ccount)).toFixed(2)
      } else if (row.ccount !== '' || row.ccountratio !== '') {
        row.ratio = ''
      }
      // 补料重量
      if (row.ccountratio !== '' && row.BLweight !== '') {
        row.supplyweight = (parseFloat(row.BLweight) * parseFloat(row.ccountratio) + parseFloat(row.BLweightLock) * parseFloat(row.ccount)).toFixed(2)
      } else if (row.ccountratio !== '' && row.BLweight == '' || row.ccountratio == '' && row.BLweight !== '') {
        row.supplyweight = ''
        row.feedweight = ''
      }
      // 配方重量
      if (row.ccountratio !== '' && row.Sfweight !== '') {
        row.ftweight = parseFloat(row.Sfweight) * parseFloat(row.ccountratio) + parseFloat(row.SfweightLock) * parseFloat(row.ccount)
      } else if (row.ccountratio !== '' && row.Sfweight == '' || row.ccountratio == '' && row.Sfweight !== '') {
        row.ftweight = ''
        row.feedweight = ''
      }
      // 投喂量
      if (row.supplyweight !== '' && row.ftweight !== '') {
        // row.feedweight = (parseFloat(row.supplyweight) + parseFloat(row.ftweight)).toFixed(2)
        row.feedweight = (parseFloat(row.BLweight) * parseFloat(row.ccountratio) + parseFloat(row.BLweightLock) * parseFloat(row.ccount)).toFixed(2)
      } else if (row.supplyweight == '' && row.ftweight !== '') {
        row.feedweight = parseFloat(row.ftweight).toFixed(2)
      } else if (row.supplyweight !== '' && row.ftweight == '') {
        row.feedweight = parseFloat(row.supplyweight).toFixed(2)
      }
      console.log(row.supplyweight, '补料重量')
      console.log(row.ftweight, '配方重量')
      if (this.table.isPtsfname == false) {
        row.feedweight = parseFloat(row.ftweight).toFixed(2)
      } else {
        // 投喂量
        if (row.supplyweight !== '' && row.ftweight !== '') {
          row.feedweight = (parseFloat(row.supplyweight) + parseFloat(row.ftweight)).toFixed(2)
        } else if (row.supplyweight == '' && row.ftweight !== '') {
          row.feedweight = parseFloat(row.ftweight).toFixed(2)
        } else if (row.supplyweight !== '' && row.ftweight == '') {
          row.feedweight = parseFloat(row.supplyweight).toFixed(2)
        }
        // 补料重量
        if (row.ccountratio !== '' && row.BLweight !== '') {
          row.supplyweight = (parseFloat(row.BLweight) * parseFloat(row.ccountratio) + parseFloat(row.BLweightLock) * parseFloat(row.ccount)).toFixed(2)
        } else if (row.ccountratio !== '' && row.BLweight == '') {
          row.supplyweight = ''
          row.feedweight = ''
        } else if (row.ccountratio == '' && row.BLweight !== '') {
          row.supplyweight = ''
          row.feedweight = ''
        }
        // 配方重量
        if (row.ccountratio !== '' && row.Sfweight !== '') {
          row.ftweight = parseFloat(row.Sfweight) * parseFloat(row.ccountratio) + parseFloat(row.SfweightLock) * parseFloat(row.ccount)
        } else if (row.ccountratio !== '' && row.Sfweight == '') {
          row.ftweight = ''
          row.feedweight = ''
        } else if (row.ccountratio == '' && row.Sfweight !== '') {
          row.ftweight = ''
          row.feedweight = ''
        }
      }
      if (row.r1 !== '') { this.$set(row, 'w1', (parseFloat(row.feedweight) * (parseFloat(row.r1) / 100)).toFixed(2)) }
      if (row.r2 !== '') { this.$set(row, 'w2', (parseFloat(row.feedweight) * (parseFloat(row.r2) / 100)).toFixed(2)) }
      if (row.r3 !== '') { this.$set(row, 'w3', (parseFloat(row.feedweight) * (parseFloat(row.r3) / 100)).toFixed(2)) }
      if (row.r4 !== '') { this.$set(row, 'w4', (parseFloat(row.feedweight) * (parseFloat(row.r4) / 100)).toFixed(2)) }
    },
    blurCcountratio(row) {
      if (row.ftid !== '-1' && row.ftid !== '') {
        row.Sfweight = this.recipeTemplateList.find(obj => obj.id == row.ftid).Sfweight
        row.SfweightLock = this.recipeTemplateList.find(obj => obj.id == row.ftid).SfweightLock
      }
      if (row.ptsfid !== '-1' && row.ptsfid !== '' && this.table.isPtsfname == true) {
        // row.ptsfid = parseInt(row.ptsfid)
        row.BLweight = parseFloat(this.feedingFormulaList.find(obj => obj.id == row.ptsfid).Sfweight)
        row.BLweightLock = parseFloat(this.feedingFormulaList.find(obj => obj.id == row.ptsfid).SfweightLock)
      }
      if (row.ptsfid == '') {
        row.BLweight = 0
        row.BLweightLock = 0
      }
      if (row.ptsfid == '') {
        row.BLweight = 0
        row.BLweightLock = 0
      }
      // 系数头数
      if (row.ccountratio !== '' && row.ccount !== '' && row.ratio !== '') {
        row.ratio = (parseFloat(row.ccountratio) * 100 / parseFloat(row.ccount)).toFixed(2)
      } else if (row.ccount !== '' && row.ratio !== '') {
        row.ccountratio = parseFloat(row.ccount) * parseFloat(row.ratio) / 100
      } else if (row.ccountratio !== '' && row.ccount !== '') {
        row.ratio = (parseFloat(row.ccountratio) * 100 / parseFloat(row.ccount)).toFixed(2)
      } else if (row.ccountratio !== '' && row.ratio !== '') {
        row.ccount = parseFloat(row.ccountratio) * 100 / parseFloat(row.ratio) / 100
      }
      // 补料重量
      if (row.ccountratio !== '' && row.BLweight !== '') {
        row.supplyweight = (parseFloat(row.BLweight) * parseFloat(row.ccountratio) + parseFloat(row.BLweightLock) * parseFloat(row.ccount)).toFixed(2)
      } else if (row.ccountratio !== '' && row.BLweight == '') {
        row.supplyweight = ''
        row.feedweight = ''
      } else if (row.ccountratio == '' && row.BLweight !== '') {
        row.supplyweight = ''
        row.feedweight = ''
      }
      // 配方重量
      if (row.ccountratio !== '' && row.Sfweight !== '') {
        row.ftweight = parseFloat(row.Sfweight) * parseFloat(row.ccountratio) + parseFloat(row.SfweightLock) * parseFloat(row.ccount)
      } else if (row.ccountratio !== '' && row.Sfweight == '') {
        row.ftweight = ''
        row.feedweight = ''
      } else if (row.ccountratio == '' && row.Sfweight !== '') {
        row.ftweight = ''
        row.feedweight = ''
      }
      // 投喂量
      if (row.supplyweight !== '' && row.ftweight !== '') {
        row.feedweight = (parseFloat(row.supplyweight) + parseFloat(row.ftweight)).toFixed(2)
      } else if (row.supplyweight == '' && row.ftweight !== '') {
        row.feedweight = parseFloat(row.ftweight).toFixed(2)
      } else if (row.supplyweight !== '' && row.ftweight == '') {
        row.feedweight = parseFloat(row.supplyweight).toFixed(2)
      }
      if (this.table.isPtsfname == false) {
        console.log(row)
        row.feedweight = parseFloat(row.ftweight).toFixed(2)
      } else {
        // 投喂量
        if (row.supplyweight !== '' && row.ftweight !== '') {
          row.feedweight = (parseFloat(row.supplyweight) + parseFloat(row.ftweight)).toFixed(2)
        } else if (row.supplyweight == '' && row.ftweight !== '') {
          row.feedweight = parseFloat(row.ftweight).toFixed(2)
        } else if (row.supplyweight !== '' && row.ftweight == '') {
          row.feedweight = parseFloat(row.supplyweight).toFixed(2)
        }
        // 补料重量
        if (row.ccountratio !== '' && row.BLweight !== '') {
          row.supplyweight = (parseFloat(row.BLweight) * parseFloat(row.ccountratio) + parseFloat(row.BLweightLock) * parseFloat(row.ccount)).toFixed(2)
        } else if (row.ccountratio !== '' && row.BLweight == '') {
          row.supplyweight = ''
          row.feedweight = ''
        } else if (row.ccountratio == '' && row.BLweight !== '') {
          row.supplyweight = ''
          row.feedweight = ''
        }
        // 配方重量
        if (row.ccountratio !== '' && row.Sfweight !== '') {
          row.ftweight = parseFloat(row.Sfweight) * parseFloat(row.ccountratio) + parseFloat(row.SfweightLock) * parseFloat(row.ccount)
        } else if (row.ccountratio !== '' && row.Sfweight == '') {
          row.ftweight = ''
          row.feedweight = ''
        } else if (row.ccountratio == '' && row.Sfweight !== '') {
          row.ftweight = ''
          row.feedweight = ''
        }
      }
      if (row.r1 !== '') { this.$set(row, 'w1', (parseFloat(row.feedweight) * (parseFloat(row.r1) / 100)).toFixed(2)) }
      if (row.r2 !== '') { this.$set(row, 'w2', (parseFloat(row.feedweight) * (parseFloat(row.r2) / 100)).toFixed(2)) }
      if (row.r3 !== '') { this.$set(row, 'w3', (parseFloat(row.feedweight) * (parseFloat(row.r3) / 100)).toFixed(2)) }
      if (row.r4 !== '') { this.$set(row, 'w4', (parseFloat(row.feedweight) * (parseFloat(row.r4) / 100)).toFixed(2)) }
    },
    // 总比例
    blurR(row) {
      if (row.r1 == '') { row.r1 = 0 }
      if (row.r2 == '') { row.r2 = 0 }
      if (row.r3 == '') { row.r3 = 0 }
      if (row.r4 == '') { row.r4 = 0 }
      if (row.r1 !== '') {
        row.w1 = parseFloat(row.feedweight) * parseFloat(row.r1) / 100
        row.w1 = row.w1.toFixed(2)
      }
      if (row.r2 !== '') {
        row.w2 = parseFloat(row.feedweight) * parseFloat(row.r2) / 100
        row.w2 = row.w2.toFixed(2)
      }
      if (row.r3 !== '') {
        row.w3 = parseFloat(row.feedweight) * parseFloat(row.r3) / 100
        row.w3 = row.w3.toFixed(2)
      }
      if (row.r4 !== '') {
        row.w4 = parseFloat(row.feedweight) * parseFloat(row.r4) / 100
        row.w4 = row.w4.toFixed(2)
      }
      this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
    },
    // 一班重量得到焦点
    focusW(row) {
      console.log(row)
      this.focusWRow = Object.assign({}, row)
    },
    // 1班重量得到焦点
    focusW2(row) {
      console.log(row)
      this.focusWRow2 = Object.assign({}, row)
    },
    // 3班重量得到焦点
    focusW3(row) {
      console.log(row)
      this.focusWRow3 = Object.assign({}, row)
    },
    // 4班重量得到焦点
    focusW4(row) {
      console.log(row)
      this.focusWRow4 = Object.assign({}, row)
    },
    // 一班重量
    blurW(row) {
      if (row.w1 == '') {
        row.w1 = 0
      }
      if (row.w2 == '') {
        row.w2 = 0
      }
      if (row.w3 == '') {
        row.w3 = 0
      }
      if (row.w4 == '') {
        row.w4 = 0
      }
      if (row.r1 == '') {
        row.r1 = 0
      }
      if (row.r2 == '') {
        row.r2 = 0
      }
      if (row.r3 == '') {
        row.r3 = 0
      }
      if (row.r4 == '') {
        row.r4 = 0
      }
      // row.ftweight = parseFloat(row.w1) + parseFloat(row.w2) + parseFloat(row.w3) + parseFloat(row.w4)
      console.log(row, '=======投喂量feedweight')
      // isOneWeight,isTwoWeight,isThreeWeight,isFourWeight
      if (this.table.RWLength == 4) {
        // 2班3班4班都锁定
        if (row.isTwoWeight == true && row.isThreeWeight == true && row.isFourWeight == true) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          this.$set(row, 'sumr', parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4))
        }
        // 2班3班锁定4班未锁定
        if (row.isTwoWeight == true && row.isThreeWeight == true && row.isFourWeight == false) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w4 = (parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w2) - parseFloat(row.w3)).toFixed(2)
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w4 <= 0) {
            row.w4 = 0
            row.r4 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 2班4班锁定3班未锁定
        if (row.isTwoWeight == true && row.isFourWeight == true && row.isThreeWeight == false) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = (parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w2) - parseFloat(row.w4)).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 3班4班锁定2班未锁定
        if (row.isTwoWeight == false && row.isThreeWeight == true && row.isFourWeight == true) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = (parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w3) - parseFloat(row.w4)).toFixed(2)
          row.r2 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }

        // 2班锁定,3班4班未锁
        if (row.isTwoWeight == true && row.isThreeWeight == false && row.isFourWeight == false) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = ((parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w2)) * parseFloat(row.r3) / (parseFloat(this.focusWRow.r3) + parseFloat(this.focusWRow.r4))).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w4 = ((parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w2)) * parseFloat(row.r4) / (parseFloat(this.focusWRow.r3) + parseFloat(row.r4))).toFixed(2)
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          if (row.w4 <= 0) {
            row.w4 = 0
            row.r4 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 3班锁定,2班4班未锁
        if (row.isTwoWeight == false && row.isThreeWeight == true && row.isFourWeight == false) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = ((parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w3)) * parseFloat(row.r2) / (parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r4))).toFixed(2)
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w4 = ((parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w3)) * parseFloat(row.r4) / (parseFloat(this.focusWRow.r2) + parseFloat(row.r4))).toFixed(2)
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          if (row.w4 <= 0) {
            row.w4 = 0
            row.r4 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 4班锁定,2班3班未锁
        if (row.isTwoWeight == false && row.isThreeWeight == false && row.isFourWeight == true) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = ((parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w4)) * parseFloat(row.r2) / (parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r3))).toFixed(2)
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = ((parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w4)) * parseFloat(row.r3) / (parseFloat(this.focusWRow.r2) + parseFloat(row.r3))).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 2班3班4班未锁
        if (row.isTwoWeight == false && row.isThreeWeight == false && row.isFourWeight == false) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = ((parseFloat(row.feedweight) - parseFloat(row.w1)) * parseFloat(row.r2) / (parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r3) + parseFloat(this.focusWRow.r4))).toFixed(2)
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = ((parseFloat(row.feedweight) - parseFloat(row.w1)) * parseFloat(row.r3) / (parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r3) + parseFloat(this.focusWRow.r4))).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w4 = ((parseFloat(row.feedweight) - parseFloat(row.w1)) * parseFloat(row.r4) / (parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r3) + parseFloat(this.focusWRow.r4))).toFixed(2)
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          if (row.w4 <= 0) {
            row.w4 = 0
            row.r4 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
      } else if (this.table.RWLength == 3) {
        // 三班
        // 2班/3班锁定
        if (row.isTwoWeight == true && row.isThreeWeight == true) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3)).toFixed(2))
        }
        // 2班不锁3班锁
        if (row.isTwoWeight == false && row.isThreeWeight == true) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = (parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w3)).toFixed(2)
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3)).toFixed(2))
        }
        // 3班不锁2班锁
        if (row.isTwoWeight == true && row.isThreeWeight == false) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = (parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w2)).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3)).toFixed(2))
        }
        // 2班3班都不锁
        if (row.isTwoWeight == false && row.isThreeWeight == false) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = ((parseFloat(row.feedweight) - parseFloat(row.w1)) * parseFloat(row.r2) / (parseFloat(row.r2) + parseFloat(row.r3))).toFixed(2)
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = ((parseFloat(row.feedweight) - parseFloat(row.w1)) * parseFloat(row.r3) / (parseFloat(this.focusWRow.r2) + parseFloat(row.r3))).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3)).toFixed(2))
        }
      } else if (this.table.RWLength == 2) {
        // 两班isOneWeight,isTwoWeight
        if (row.w1 == '') { row.w1 = 0 }
        if (row.w2 == '') { row.w2 = 0 }
        if (row.r1 == '') { row.r1 = 0 }
        if (row.r2 == '') { row.r2 = 0 }
        if (row.isTwoWeight == false) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = (parseFloat(row.feedweight) - parseFloat(row.w1)).toFixed(2)
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w2 <= 0) { row.w2 = 0; row.r2 = 0 }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2)).toFixed(2))
        } else {
          row.r1 = parseFloat(row.w1) / parseFloat(row.feedweight) * 100
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2)).toFixed(2))
        }
      }
    },
    blurW2(row) {
      // 2班重量
      if (row.w1 == '') {
        row.w1 = 0
      }
      if (row.w2 == '') {
        row.w2 = 0
      }
      if (row.w3 == '') {
        row.w3 = 0
      }
      if (row.w4 == '') {
        row.w4 = 0
      }
      if (row.r1 == '') {
        row.r1 = 0
      }
      if (row.r2 == '') {
        row.r2 = 0
      }
      if (row.r3 == '') {
        row.r3 = 0
      }
      if (row.r4 == '') {
        row.r4 = 0
      }
      // row.ftweight = parseFloat(row.w1) + parseFloat(row.w2) + parseFloat(row.w3) + parseFloat(row.w4)
      console.log(row, '=======投喂量feedweight')
      // isOneWeight,isTwoWeight,isThreeWeight,isFourWeight
      if (this.table.RWLength == 4) {
        // 四班
        // 1班3班4班都锁定
        if (row.isOneWeight == true && row.isThreeWeight == true && row.isFourWeight == true) {
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 1班3班锁定4班未锁定
        if (row.isOneWeight == true && row.isThreeWeight == true && row.isFourWeight == false) {
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)

          row.w4 = (parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w2) - parseFloat(row.w3)).toFixed(2)
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w4 <= 0) {
            row.w4 = 0
            row.r4 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 1班4班锁定3班未锁定
        if (row.isOneWeight == true && row.isFourWeight == true && row.isThreeWeight == false) {
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = (parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w2) - parseFloat(row.w4)).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 3班4班锁定1班未锁定
        if (row.isOneWeight == false && row.isThreeWeight == true && row.isFourWeight == true) {
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)

          row.w1 = (parseFloat(row.feedweight) - parseFloat(row.w2) - parseFloat(row.w3) - parseFloat(row.w4)).toFixed(2)
          row.r1 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }

        // 1班锁定,3班4班未锁
        if (row.isOneWeight == true && row.isThreeWeight == false && row.isFourWeight == false) {
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)

          row.w3 = ((parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w2)) * parseFloat(row.r3) / (parseFloat(this.focusWRow.r3) + parseFloat(this.focusWRow.r4))).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w4 = ((parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w2)) * parseFloat(row.r4) / (parseFloat(this.focusWRow.r3) + parseFloat(row.r4))).toFixed(2)
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          if (row.w4 <= 0) {
            row.w4 = 0
            row.r4 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 3班锁定,1班4班未锁
        if (row.isOneWeight == false && row.isThreeWeight == true && row.isFourWeight == false) {
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = ((parseFloat(row.feedweight) - parseFloat(row.w2) - parseFloat(row.w3)) * parseFloat(row.r1) / (parseFloat(this.focusWRow.r1) + parseFloat(this.focusWRow.r2))).toFixed(2)
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w4 = ((parseFloat(row.feedweight) - parseFloat(row.w2) - parseFloat(row.w3)) * parseFloat(row.r4) / (parseFloat(this.focusWRow.r1) + parseFloat(row.r2))).toFixed(2)
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          if (row.w4 <= 0) {
            row.w4 = 0
            row.r4 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 4班锁定,1班3班未锁
        if (row.isOneWeight == false && row.isThreeWeight == false && row.isFourWeight == true) {
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = ((parseFloat(row.feedweight) - parseFloat(row.w2) - parseFloat(row.w4)) * parseFloat(row.r1) / (parseFloat(this.focusWRow.r1) + parseFloat(this.focusWRow.r3))).toFixed(2)
          row.r1 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = ((parseFloat(row.feedweight) - parseFloat(row.w2) - parseFloat(row.w4)) * parseFloat(row.r3) / (parseFloat(this.focusWRow.r1) + parseFloat(row.r3))).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 1班3班4班未锁
        if (row.isOneWeight == false && row.isThreeWeight == false && row.isFourWeight == false) {
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = ((parseFloat(row.feedweight) - parseFloat(row.w2)) * parseFloat(row.r1) / (parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r3) + parseFloat(this.focusWRow.r1))).toFixed(2)
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = ((parseFloat(row.feedweight) - parseFloat(row.w2)) * parseFloat(row.r3) / (parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r3) + parseFloat(this.focusWRow.r1))).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w4 = ((parseFloat(row.feedweight) - parseFloat(row.w2)) * parseFloat(row.r4) / (parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r3) + parseFloat(this.focusWRow.r1))).toFixed(2)
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          if (row.w4 <= 0) {
            row.w4 = 0
            row.r4 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
      } else if (this.table.RWLength == 3) {
        // 三班
        // 1班/3班锁定
        if (row.isOneWeight == true && row.isThreeWeight == true) {
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3)).toFixed(2))
        }
        // 1班不锁3班锁
        if (row.isOneWeight == false && row.isThreeWeight == true) {
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = (parseFloat(row.feedweight) - parseFloat(row.w2) - parseFloat(row.w3)).toFixed(2)
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3)).toFixed(2))
        }
        // 3班不锁1班锁
        if (row.isOneWeight == true && row.isThreeWeight == false) {
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = (parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w2)).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3)).toFixed(2))
        }
        // 1班3班都不锁
        if (row.isOneWeight == false && row.isThreeWeight == false) {
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = ((parseFloat(row.feedweight) - parseFloat(row.w2)) * parseFloat(row.r1) / (parseFloat(row.r1) + parseFloat(row.r3))).toFixed(2)
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = ((parseFloat(row.feedweight) - parseFloat(row.w2)) * parseFloat(row.r3) / (parseFloat(this.focusWRow2.r1) + parseFloat(row.r3))).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3)).toFixed(2))
        }
      } else if (this.table.RWLength == 2) {
        // 两班
        if (row.isTwoWeight == false) {
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = (parseFloat(row.feedweight) - parseFloat(row.w2))
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w1 <= 0) { row.w1 = 0; row.r1 = 0 }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2)).toFixed(2))
        } else {
          row.r2 = parseFloat(row.w2) / parseFloat(row.feedweight) * 100
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2)).toFixed(2))
        }
      }
    },
    blurW3(row) {
      // 3班重量
      if (row.w1 == '') {
        row.w1 = 0
      }
      if (row.w2 == '') {
        row.w2 = 0
      }
      if (row.w3 == '') {
        row.w3 = 0
      }
      if (row.w4 == '') {
        row.w4 = 0
      }
      if (row.r1 == '') {
        row.r1 = 0
      }
      if (row.r2 == '') {
        row.r2 = 0
      }
      if (row.r3 == '') {
        row.r3 = 0
      }
      if (row.r4 == '') {
        row.r4 = 0
      }
      // row.ftweight = parseFloat(row.w1) + parseFloat(row.w2) + parseFloat(row.w3) + parseFloat(row.w4)
      console.log(row, '=======投喂量feedweight')
      // isOneWeight,isTwoWeight,isThreeWeight,isFourWeight
      if (this.table.RWLength == 4) {
        // 四班
        // 1班2班4班都锁定
        if (row.isOneWeight == true && row.isTwoWeight == true && row.isFourWeight == true) {
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 1班2班锁定4班未锁定
        if (row.isOneWeight == true && row.isTwoWeight == true && row.isFourWeight == false) {
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w4 = (parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w2) - parseFloat(row.w3)).toFixed(2)
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w4 <= 0) {
            row.w4 = 0
            row.r4 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 2班4班锁定1班未锁定
        if (row.isOneWeight == false && row.isTwoWeight == true && row.isFourWeight == true) {
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = (parseFloat(row.feedweight) - parseFloat(row.w2) - parseFloat(row.w3) - parseFloat(row.w4)).toFixed(2)
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 1班4班锁定2班未锁定
        if (row.isTwoWeight == false && row.isOneWeight == true && row.isFourWeight == true) {
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100)
          row.w2 = (parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w3) - parseFloat(row.w4)).toFixed(2)
          row.r2 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }

        // 2班锁定,1班4班未锁
        if (row.isTwoWeight == true && row.isOneWeight == false && row.isFourWeight == false) {
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = ((parseFloat(row.feedweight) - parseFloat(row.w2) - parseFloat(row.w3)) * parseFloat(row.r1) / (parseFloat(this.focusWRow.r1) + parseFloat(this.focusWRow.r4))).toFixed(2)
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w4 = ((parseFloat(row.feedweight) - parseFloat(row.w2) - parseFloat(row.w3)) * parseFloat(row.r4) / (parseFloat(this.focusWRow.r1) + parseFloat(row.r4))).toFixed(2)
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          if (row.w4 <= 0) {
            row.w4 = 0
            row.r4 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 1班锁定,2班4班未锁
        if (row.isTwoWeight == false && row.isOneWeight == true && row.isFourWeight == false) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = ((parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w3)) * parseFloat(row.r2) / (parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r4))).toFixed(2)
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w4 = ((parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w3)) * parseFloat(row.r4) / (parseFloat(this.focusWRow.r2) + parseFloat(row.r4))).toFixed(2)
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          if (row.w4 <= 0) {
            row.w4 = 0
            row.r4 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 4班锁定,2班1班未锁
        if (row.isTwoWeight == false && row.isOneWeight == false && row.isFourWeight == true) {
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100)
          row.w2 = ((parseFloat(row.feedweight) - parseFloat(row.w3) - parseFloat(row.w4)) * parseFloat(row.r1) / (parseFloat(this.focusWRow.r1) + parseFloat(this.focusWRow.r2))).toFixed(2)
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = ((parseFloat(row.feedweight) - parseFloat(row.w3) - parseFloat(row.w4)) * parseFloat(row.r2) / (parseFloat(this.focusWRow.r1) + parseFloat(row.r2))).toFixed(2)
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 2班1班4班未锁
        if (row.isTwoWeight == false && row.isOneWeight == false && row.isFourWeight == false) {
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = ((parseFloat(row.feedweight) - parseFloat(row.w3)) * parseFloat(row.r1) / (parseFloat(this.focusWRow.r1) + parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r4))).toFixed(2)
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = ((parseFloat(row.feedweight) - parseFloat(row.w3)) * parseFloat(row.r2) / (parseFloat(this.focusWRow.r1) + parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r4))).toFixed(2)
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w4 = ((parseFloat(row.feedweight) - parseFloat(row.w3)) * parseFloat(row.r4) / (parseFloat(this.focusWRow.r1) + parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r4))).toFixed(2)
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          if (row.w4 <= 0) {
            row.w4 = 0
            row.r4 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
      } else if (this.table.RWLength == 3) {
        // 三班
        // 1班/2班锁定
        if (row.isOneWeight == true && row.isTwoWeight == true) {
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3)).toFixed(2))
        }
        // 1班不锁2班锁
        if (row.isOneWeight == false && row.isTwoWeight == true) {
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = (parseFloat(row.feedweight) - parseFloat(row.w2) - parseFloat(row.w3)).toFixed(2)
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3)).toFixed(2))
        }
        // 3班不锁2班锁
        // 2班不锁1班锁
        if (row.isOneWeight == true && row.isTwoWeight == false) {
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = (parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w3)).toFixed(2)
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3)).toFixed(2))
        }
        // 2班3班都不锁
        // 1班2班都不锁
        if (row.isOneWeight == false && row.isTwoWeight == false) {
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = ((parseFloat(row.feedweight) - parseFloat(row.w3)) * parseFloat(row.r1) / (parseFloat(row.r1) + parseFloat(row.r2))).toFixed(2)
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = ((parseFloat(row.feedweight) - parseFloat(row.w3)) * parseFloat(row.r2) / (parseFloat(this.focusWRow3.r1) + parseFloat(row.r2))).toFixed(2)
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3)).toFixed(2))
        }
      }
    },
    blurW4(row) {
      if (row.w1 == '') {
        row.w1 = 0
      }
      if (row.w2 == '') {
        row.w2 = 0
      }
      if (row.w3 == '') {
        row.w3 = 0
      }
      if (row.w4 == '') {
        row.w4 = 0
      }
      if (row.r1 == '') {
        row.r1 = 0
      }
      if (row.r2 == '') {
        row.r2 = 0
      }
      if (row.r3 == '') {
        row.r3 = 0
      }
      if (row.r4 == '') {
        row.r4 = 0
      }
      // row.ftweight = parseFloat(row.w1) + parseFloat(row.w2) + parseFloat(row.w3) + parseFloat(row.w4)
      console.log(row, '=======投喂量feedweight')
      // isOneWeight,isTwoWeight,isThreeWeight,isFourWeight
      if (this.table.RWLength == 4) {
        // 四班
        // 1班2班3班都锁定
        if (row.isOneWeight == true && row.isTwoWeight == true && row.isThreeWeight == true) {
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 2班3班锁定1班未锁定
        if (row.isOneWeight == false && row.isTwoWeight == true && row.isThreeWeight == true) {
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = (parseFloat(row.feedweight) - parseFloat(row.w4) - parseFloat(row.w2) - parseFloat(row.w3)).toFixed(2)
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 2班1班锁定3班未锁定
        if (row.isOneWeight == true && row.isTwoWeight == true && row.isThreeWeight == false) {
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = (parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w2) - parseFloat(row.w4)).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 3班1班锁定2班未锁定
        if (row.isOneWeight == true && row.isTwoWeight == false && row.isThreeWeight == true) {
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = (parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w3) - parseFloat(row.w4)).toFixed(2)
          row.r2 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }

        // 2班锁定,3班1班未锁
        if (row.isOneWeight == false && row.isTwoWeight == true && row.isThreeWeight == false) {
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = ((parseFloat(row.feedweight) - parseFloat(row.w4) - parseFloat(row.w2)) * parseFloat(row.r3) / (parseFloat(this.focusWRow.r3) + parseFloat(this.focusWRow.r1))).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = ((parseFloat(row.feedweight) - parseFloat(row.w4) - parseFloat(row.w2)) * parseFloat(row.r1) / (parseFloat(this.focusWRow.r3) + parseFloat(row.r1))).toFixed(2)
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 3班锁定,2班1班未锁
        if (row.isOneWeight == false && row.isTwoWeight == false && row.isThreeWeight == true) {
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = ((parseFloat(row.feedweight) - parseFloat(row.w4) - parseFloat(row.w3)) * parseFloat(row.r2) / (parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r1))).toFixed(2)
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = ((parseFloat(row.feedweight) - parseFloat(row.w4) - parseFloat(row.w3)) * parseFloat(row.r1) / (parseFloat(this.focusWRow.r2) + parseFloat(row.r1))).toFixed(2)
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 1班锁定,2班3班未锁
        if (row.isOneWeight == true && row.isTwoWeight == false && row.isThreeWeight == false) {
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = ((parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w4)) * parseFloat(row.r2) / (parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r3))).toFixed(2)
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = ((parseFloat(row.feedweight) - parseFloat(row.w1) - parseFloat(row.w4)) * parseFloat(row.r3) / (parseFloat(this.focusWRow.r2) + parseFloat(row.r3))).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
        // 2班3班1班未锁
        if (row.isOneWeight == false && row.isTwoWeight == false && row.isThreeWeight == false) {
          row.r4 = (parseFloat(row.w4) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w1 = ((parseFloat(row.feedweight) - parseFloat(row.w4)) * parseFloat(row.r1) / (parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r3) + parseFloat(this.focusWRow.r1))).toFixed(2)
          row.r1 = (parseFloat(row.w1) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w2 = ((parseFloat(row.feedweight) - parseFloat(row.w4)) * parseFloat(row.r2) / (parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r3) + parseFloat(this.focusWRow.r1))).toFixed(2)
          row.r2 = (parseFloat(row.w2) / parseFloat(row.feedweight) * 100).toFixed(2)
          row.w3 = ((parseFloat(row.feedweight) - parseFloat(row.w4)) * parseFloat(row.r3) / (parseFloat(this.focusWRow.r2) + parseFloat(this.focusWRow.r3) + parseFloat(this.focusWRow.r1))).toFixed(2)
          row.r3 = (parseFloat(row.w3) / parseFloat(row.feedweight) * 100).toFixed(2)
          if (row.w1 <= 0) {
            row.w1 = 0
            row.r1 = 0
          }
          if (row.w2 <= 0) {
            row.w2 = 0
            row.r2 = 0
          }
          if (row.w3 <= 0) {
            row.w3 = 0
            row.r3 = 0
          }
          this.$set(row, 'sumr', (parseFloat(row.r1) + parseFloat(row.r2) + parseFloat(row.r3) + parseFloat(row.r4)).toFixed(2))
        }
      }
    },
    // 编辑
    handleUpdate(row) {
      console.log(row)
      for (let i = 0; i < this.table.list.length; i++) {
        if (this.table.list[i].Edit == true) {
          this.$message({
            type: 'error',
            message: '当前内容未保存,请点击取消或保存继续进行操作',
            duration: 2000
          })
          return false
        }
      }
      // 编辑true,不可编辑false
      row.Edit = true
      row.NoEdit = false
      // 编辑false,编辑保存true
      row.isUpdate = false
      row.isUpdateSave = true
      row.ftid = String(row.ftid)
      if (row.ptsfid == '-1') {
        row.ptsfid = ''
      }
      row.ptsfid = String(row.ptsfid)
      this.table.temp.ftid = row.ftid
      this.table.temp.ftname = row.ftname
      this.table.temp.ptsfid = row.ptsfid
      this.table.temp.ptsfname = row.ptsfname
    },
    updateData(row) {
      console.log(row)
      if (row.r1 == 'NaN') { this.$set(row, 'r1', 0) }
      if (row.r2 == 'NaN') { this.$set(row, 'r2', 0) }
      if (row.r3 == 'NaN') { this.$set(row, 'r3', 0) }
      if (row.r4 == 'NaN') { this.$set(row, 'r4', 0) }
      if (row.w1 == 'NaN') { this.$set(row, 'w1', 0) }
      if (row.w2 == 'NaN') { this.$set(row, 'w2', 0) }
      if (row.w3 == 'NaN') { this.$set(row, 'w3', 0) }
      if (row.w4 == 'NaN') { this.$set(row, 'w4', 0) }
      console.log(row)
      var arr = []
      for (let i = 1; i <= this.table.RWLength; i++) {
        var obj = {}
        obj['times'] = i
        obj['pastureid'] = row.pastureid
        obj['barid'] = row.barid
        obj['cowcount'] = row.ccount
        obj['ccountradio'] = row.ccountradio
        obj['ptid'] = row.ftid
        if (row.ptsfid !== '') {
          obj['ptsid'] = row.ptsfid
        } else {
          obj['ptsid'] = '-1'
        }
        obj['weight'] = row['w' + i]
        obj['tratio'] = Math.round(row['r' + i])
        arr.push(obj)
      }
      if (this.table.isPtsfname == 0) {
        row.ptsfid = '-1'
        row.ptsfname = ''
      } else {
        if (row.ptsfid == '') {
          row.ptsfid = '-1'
          row.ptsfname = ''
        }
      }
      if (row.supplyweight == '') {
        row.supplyweight = '0'
      }
      if (this.table.isPtsfname == false) {
        row.supplyweight = '0'
      }
      console.log(row, '============')
      this.$set(row, 'ratio', Math.floor(parseFloat(row.ratio) * 100) / 100)
      this.$set(row, 'ccountratio', Math.floor(parseFloat(row.ccountratio) * 100) / 100)
      row.ratio = String(row.ratio)
      row.ccountratio = String(row.ccountratio)
      row.sumr = Math.round(row.sumr)
      this.table.rwList = arr
      console.log('点击了编辑保存', row)
      this.table.temp.pastureid = row.pastureid
      this.table.temp.id = row.id
      this.table.temp.barname = row.barname
      this.table.temp.barid = row.barid
      this.table.temp.ccount = row.ccount
      this.table.temp.ratio = row.ratio
      this.table.temp.ccountratio = row.ccountratio
      this.table.temp.ftid = row.ftid
      this.table.temp.ftname = row.ftname
      this.table.temp.ptsfid = row.ptsfid
      this.table.temp.ptsfname = row.ptsfname
      this.table.temp.ftweight = row.ftweight
      this.table.temp.supplyweight = row.supplyweight
      this.table.temp.feedweight = row.feedweight
      this.table.temp.owner = row.owner
      this.table.temp.sumr = row.sumr
      if (row.softccount == '') {
        row.softccount = 0
      }
      if (row.r1 == '') {
        row.r1 = 0
      }
      if (row.r2 == '') {
        row.r2 = 0
      }
      if (row.r3 == '') {
        row.r3 = 0
      }
      if (row.r4 == '') {
        row.r4 = 0
      }
      if (row.w1 == '') {
        row.w1 = 0
      }
      if (row.w2 == '' || row.w4 == NaN) {
        row.w2 = 0
      }
      if (row.w3 == '' || row.w4 == NaN) {
        row.w3 = 0
      }
      if (row.w4 == '' || row.w4 == NaN) {
        row.w4 = 0
      }
      console.log(row, '===========')
      this.table.temp.softccount = row.softccount
      this.table.temp.r1 = Math.round(row.r1)
      this.table.temp.r2 = Math.round(row.r2)
      this.table.temp.r3 = Math.round(row.r3)
      this.table.temp.r4 = Math.round(row.r4)
      this.table.temp.w1 = row.w1
      this.table.temp.w2 = row.w2
      this.table.temp.w3 = row.w3
      this.table.temp.w4 = row.w4

      if (this.table.temp.ccount == '' && this.table.temp.ratio == '' && this.table.temp.ccountratio == '' && this.table.temp.ftid == '') {
        this.$message({
          type: 'error',
          message: '实际牛头数/系数/系数头数/配方模版不能为空',
          duration: 2000
        })
        return false
      }
      if (this.table.temp.ratio == '' && this.table.temp.ccountratio == '' && this.table.temp.ftid == '') {
        this.$message({
          type: 'error',
          message: '系数/系数头数/配方模版不能为空',
          duration: 2000
        })
        return false
      }
      if (this.table.temp.ccountratio == '' && this.table.temp.ftid == '') {
        this.$message({
          type: 'error',
          message: '系数头数/配方模版不能为空',
          duration: 2000
        })
        return false
      }
      if (this.table.temp.ccount == '') {
        this.$message({
          type: 'error',
          message: '实际牛头数不能为空',
          duration: 2000
        })
        return false
      }
      if (this.table.temp.ratio == '') {
        this.$message({
          type: 'error',
          message: '系数不能为空',
          duration: 2000
        })
        return false
      }
      if (this.table.temp.ccountratio == '') {
        this.$message({
          type: 'error',
          message: '系数头数不能为空',
          duration: 2000
        })
        return false
      }
      if (this.table.temp.ftid == '') {
        this.$message({
          type: 'error',
          message: '配方模版不能为空',
          duration: 2000
        })
        return false
      }
      const positiveInteger = /^[1-9]\d*$/
      if (!positiveInteger.test(parseFloat(this.table.temp.ccount))) {
        this.$message({
          type: 'error',
          message: '实际牛头数请输入正整数',
          duration: 2000
        })
        return false
      }
      this.isokDisable = true
      setTimeout(() => {
        this.isokDisable = false
      }, 1000)
      // this.requestParam.parammaps = this.table.temp
      this.requestParam.common = {
        'returnmap': '0'
      }
      this.requestParam.data = []
      this.requestParam.data[0] = { 'name': 'updateBigFP', 'type': 'e', 'parammaps': {
        pastureid: row.pastureid,
        id: row.id,
        barname: row.barname,
        barid: row.barid,
        softccount: row.softccount,
        ccount: row.ccount,
        ratio: row.ratio,
        ccountratio: row.ccountratio,
        ftid: row.ftid,
        ftname: row.ftname,
        ptsfid: row.ptsfid,
        ptsfname: row.ptsfname,
        ftweight: row.ftweight,
        supplyweight: row.supplyweight,
        feedweight: row.feedweight,
        owner: row.owner,
        sumr: row.sumr
      }}
      this.requestParam.data[1] = { 'name': 'insertSpotList', 'resultmaps': { 'list': this.table.rwList }}
      this.requestParam.data[1].children = []
      this.requestParam.data[1].children[0] = { 'name': 'updateBigFPDetail', 'type': 'e', 'parammaps': {
        pastureid: '@insertSpotList.pastureid',
        barname: row.barname,
        barid: '@insertSpotList.barid',
        times: '@insertSpotList.times',
        tratio: '@insertSpotList.tratio',
        weight: '@insertSpotList.weight',
        cowcount: '@insertSpotList.cowcount',
        ccountradio: row.ccountratio,
        ptid: '@insertSpotList.ptid',
        ptsid: '@insertSpotList.ptsid',
        feedweight: row.feedweight,
        supplyweight: row.supplyweight,
        ratio: row.ratio
      }}
      this.requestParam.data[2] = { 'name': 'updateLPPbyFPChange', 'type': 'e', 'parammaps': {
        pastureid: row.pastureid,
        fpid: row.id
      }}
      ExecDataByConfig(this.requestParam).then(response => {
        console.log('编辑保存发送参数', this.requestParam)
        if (response.msg === 'fail') {
          this.$notify({
            title: '保存失败',
            message: response.data,
            type: 'warning',
            duration: 2000
          })
        } else {
          this.$notify({
            title: '成功',
            message: '保存成功',
            type: 'success',
            duration: 2000
          })
          this.getList()
        }
      })
    },
    updateCancel(row) {
      console.log('点击了编辑取消')
      // 编辑false,不可编辑true
      row.Edit = false
      row.NoEdit = true
      // 编辑true,编辑保存false
      row.isUpdate = true
      row.isUpdateSave = false
      this.getList()
      this.reload()
      // this.$router.push('/formulationPlan/dhedFormula')
    },
    cellClick(row, column, event) {
      console.log(column)
    },
    handleSelect(val) {
      console.log('勾选数据', val)
      this.selectList = val
    },
    // 营养评估
    handleNutritional() {
      console.log('点击了营养评估')
      if (this.selectList.length !== 1) {
        this.$message({
          type: 'error',
          message: '请选择一条栏舍信息进行营养评估',
          duration: 2000
        })
        return false
      } else {
        console.log(this.nutritional.temp)
        this.nutritional.dialogStatus = 'Nutritional'
        this.nutritional.dialogFormVisible = true
        this.nutritional.getdataListParm1.parammaps.pastureid = this.selectList[0].pastureid
        this.nutritional.getdataListParm1.parammaps.barid = this.selectList[0].barid
        this.getNutritionalList()
      }
    },
    getNutritionalList() {
      this.nutritional.listLoading1 = true
      GetDataByName(this.nutritional.getdataListParm1).then(response => {
        console.log('评估上方数据', response.data.list)
        if (response.data.list !== null) {
          response.data.list[0].cowclassid = String(response.data.list[0].cowclassid)
          this.nutritional.temp = response.data.list[0]
          this.nutritional.disabledCowclass = true
        } else {
          this.nutritional.temp = []
          this.nutritional.disabledCowclass = false
        }
        setTimeout(() => {
          this.nutritional.listLoading = false
        }, 100)
      })
    },
    assessmentData() {
      console.log('评估保存')
      this.$refs['temp'].validate(valid => {
        if (valid) {
          this.nutritional.getdataListParm2.parammaps.pastureid = this.selectList[0].pastureid
          this.nutritional.getdataListParm2.parammaps.cowclassid = this.nutritional.temp.cowclassid
          this.getNutritionalList2()
        }
      })
    },
    getNutritionalList2() {
      this.nutritional.listLoading2 = true
      GetDataByName(this.nutritional.getdataListParm2).then(response => {
        console.log('评估下方数据', response.data.list)
        if (response.data.list !== null) {
          this.nutritional.list = response.data.list
          this.nutritional.pageNum = response.data.pageNum
          this.nutritional.pageSize = response.data.pageSize
          this.nutritional.total = response.data.total
        } else {
          this.nutritional.list = []
        }
        setTimeout(() => {
          this.nutritional.listLoading2 = false
        }, 100)
      })
    },
    // 历史记录
    handleHistoryRecords() {
      console.log('点击了历史记录')
      this.history.dialogStatus = 'history'
      this.history.dialogFormVisible = true
      this.getDateList()
    },
    // 历史时间
    getDateList() {
      GetDataByName(this.history.getdataDateParm).then(response => {
        console.log('table数据', response.data.list)
        if (response.data.list !== null) {
          this.history.getdataListParm.parammaps.date = response.data.list[0].maxdate
          this.getHistoryIsDisplay()
        } else {
          this.history.getdataListParm.parammaps.date = ''
        }
      })
    },
    getHistoryIsDisplay() {
      GetDataByName(this.table.getdataListParm2).then(response => {
        console.log(response.data.list[0].inforvalue)
        if (response.data.list !== null) {
          if (response.data.list[0].inforvalue == 0) {
            this.table.isPtsfname = false
          } else {
            this.table.isPtsfname = true
          }
        }
      })
      GetDataByName(this.table.getdataListParm3).then(response => {
        if (response.data.list !== null) {
          if (response.data.list[0].inforvalue == 1) {
            this.history.isRW1 = true
            this.history.isRW2 = false
            this.history.isRW3 = false
            this.history.isRW4 = false
          } else if (response.data.list[0].inforvalue == 2) {
            this.history.isRW1 = true
            this.history.isRW2 = true
            this.history.isRW3 = false
            this.history.isRW4 = false
          } else if (response.data.list[0].inforvalue == 3) {
            this.history.isRW1 = true
            this.history.isRW2 = true
            this.history.isRW3 = true
            this.history.isRW4 = false
          } else if (response.data.list[0].inforvalue == 4) {
            this.history.isRW1 = true
            this.history.isRW2 = true
            this.history.isRW3 = true
            this.history.isRW4 = true
          }
        } else {
          this.history.isRW1 = false
          this.history.isRW2 = false
          this.history.isRW3 = false
          this.history.isRW4 = false
        }
      })
      this.getHistoryList()
    },
    getHistoryList() {
      this.history.listLoading = true
      GetDataByName(this.history.getdataListParm).then(response => {
        console.log('table数据', response.data.list)
        if (response.data.list !== null) {
          console.log('table数据', response.data.list)
          for (let i = 0; i < response.data.list.length; i++) {
            this.$set(response.data.list[i], 'Edit', false) // 编辑
            this.$set(response.data.list[i], 'NoEdit', true) // 不可编辑/输入
            this.$set(response.data.list[i], 'isUpdate', true) // 编辑操作
            this.$set(response.data.list[i], 'isUpdateSave', false) // 编辑保存

            if (response.data.list[i].ftid == undefined || response.data.list[i].ftname == '') {
              this.$set(response.data.list[i], 'ftid', '')
              this.$set(response.data.list[i], 'ftname', '')
            }
            if (response.data.list[i].ptsfid == undefined || response.data.list[i].ptsfname == '') {
              this.$set(response.data.list[i], 'ptsfid', '')
              this.$set(response.data.list[i], 'ptsfname', '')
            }
            if (response.data.list[i].ccount == undefined) {
              this.$set(response.data.list[i], 'ccount', '')
            }
            if (response.data.list[i].ratio == undefined) {
              this.$set(response.data.list[i], 'ratio', '100')
            }
            if (response.data.list[i].ccountratio == undefined) {
              this.$set(response.data.list[i], 'ccountratio', '')
            }
            if (response.data.list[i].r1 == undefined) {
              this.$set(response.data.list[i], 'r1', '')
            }
            if (response.data.list[i].r2 == undefined) {
              this.$set(response.data.list[i], 'r2', '')
            }
            if (response.data.list[i].r3 == undefined) {
              this.$set(response.data.list[i], 'r3', '')
            }
            if (response.data.list[i].r4 == undefined) {
              this.$set(response.data.list[i], 'r4', '')
            }
            if (response.data.list[i].w1 == undefined) {
              this.$set(response.data.list[i], 'w1', '')
            }
            if (response.data.list[i].w2 == undefined) {
              this.$set(response.data.list[i], 'w2', '')
            }
            if (response.data.list[i].w3 == undefined) {
              this.$set(response.data.list[i], 'w3', '')
            }
            if (response.data.list[i].w4 == undefined) {
              this.$set(response.data.list[i], 'w4', '')
            }
            if (response.data.list[i].feedweight == undefined) {
              this.$set(response.data.list[i], 'feedweight', '')
            }
            if (response.data.list[i].Bfweight == undefined) {
              this.$set(response.data.list[i], 'Bfweight', '')
            }
            if (response.data.list[i].Sfweight == undefined) {
              this.$set(response.data.list[i], 'Sfweight', '')
            }
            if (response.data.list[i].timesopt !== undefined) {
              var timesoptArr = response.data.list[i].timesopt.split(',')
              for (let j = 0; j < timesoptArr.length; j++) {
                response.data.list[i]['r' + timesoptArr[j].split(':')[0]] = timesoptArr[j].split(':')[1]
                response.data.list[i]['w' + timesoptArr[j].split(':')[0]] = timesoptArr[j].split(':')[2]
              }
            }
          }
          this.history.list = response.data.list
          for (let i = 0; i < response.data.list.length; i++) {
            if (response.data.list[i].r1 == '') { response.data.list[i].r1 = 0 }
            if (response.data.list[i].r2 == '') { response.data.list[i].r2 = 0 }
            if (response.data.list[i].r3 == '') { response.data.list[i].r3 = 0 }
            if (response.data.list[i].r4 == '') { response.data.list[i].r4 = 0 }
            this.$set(response.data.list[i], 'sumr', Math.round(parseFloat(response.data.list[i].r1) + parseFloat(response.data.list[i].r2) + parseFloat(response.data.list[i].r3) + parseFloat(response.data.list[i].r4)))
          }
          this.history.pageNum = response.data.pageNum
          this.history.pageSize = response.data.pageSize
          this.history.total = response.data.total
        } else {
          this.history.list = []
        }
        setTimeout(() => {
          this.history.listLoading = false
        }, 100)
      })
    },
    changeDate() {
      this.getHistoryList()
    },
    // 应用
    handleApplication() {
      console.log('点击了应用')
      MessageBox.confirm('是否确认将' + this.history.getdataListParm.parammaps.date + '的数据应用到当前?', {
        confirmButtonText: '确认', cancelButtonText: '取消', type: 'warning'
      }).then(() => {
        this.requestParam.name = 'applyFPdate'
        this.requestParam.parammaps = {}
        this.requestParam.parammaps.pastureid = Cookies.get('pastureid')
        this.requestParam.parammaps.date = this.history.getdataListParm.parammaps.date
        PostDataByName(this.requestParam).then(response => {
          if (response.msg === 'fail') {
            this.$notify({ title: '保存失败', message: response.data, type: 'warning', duration: 2000 })
          } else {
            this.$notify({ title: '成功', message: '保存成功', type: 'success', duration: 2000 })
            this.getHistoryIsDisplay()
            this.getList()
          }
        })
      }).catch(() => {
        this.$message({ type: 'info', message: '已取消应用' })
      })
    },
    // 导出
    handleExport(item) {
      if (item == 1) {
        console.log('点击了导出模板')
      } else {
        console.log('点击了导出数据')
      }
    },

    // 导入
    handleImport() {
      console.log('点击了导入')
    }
  }
}
</script>
<style lang="scss" scoped>
  .search {
    clear: both;
  }

  .table {
    margin-top: 10px;
  }
</style>