| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956 | <template>  <div>    <el-table :data='activeSoundList'              :header-cell-style="{background:'#EDEEF0',color:'#444'}">      <el-table-column align='center'                       width="180px;"                       prop="sound"                       label="声部名称">      </el-table-column>      <el-table-column align='center'                       width="180px;"                       prop="yuji"                       label="课程费用">        <!-- <template slot-scope="scope">          <div>            <el-input style="width:100px"                      v-model.trim="scope.row.yuji"></el-input>          </div>        </template> -->      </el-table-column>      <el-table-column label="可选乐器规格"                       align="center"                       prop="zhonglei"                       width="300">        <template slot-scope="scope">          <!-- 'typeVisible':false,'provideVisible':false,'markVisible':false -->          <div>            <span>{{scope.row.zhonglei | zhongleiFilter(scope.row.goodsList)}}</span>            <el-popover placement="bottom"                        @show='chioseType(scope.row)'                        v-model.trim="scope.row.typeVisible"                        v-if='scope.row.type == 1'>              <el-button type="text"                         v-if="lookType!=='look'"                         slot='reference'>                修改              </el-button>              <!-- zhonglei -->              <el-select v-model.trim="scope.row.zhonglei"                         multiple                         clearable                         filterable                         @change="changezhonglei(scope.row)"                         collapse-tags>                <el-option v-for="(item,index) in scope.row.goodsList"                           :key='index'                           :label="item.name"                           :value="item.id"></el-option>              </el-select>              <div style="text-align: right; margin-top: 20px">                <!-- <el-button size="mini"                             type="text"                             @click="closechioseType(scope.row)">取消</el-button> -->                <el-button type="primary"                           size="mini"                           @click="scope.row.typeVisible  = false">确定</el-button>              </div>            </el-popover>          </div>        </template>      </el-table-column>      <el-table-column label="乐器提供方式"                       width="300"                       align="center"                       prop="fangshi">        <template slot-scope="scope">          <div>            <!-- <div class="chiose"                  >选择</div> -->            <div style='white-space:pre'                 v-if="scope.row.fangshi.length >0">{{scope.row.fangshi | fangshiFilter(scope.row)}}</div>            <i class='el-icon-edit'               v-if="lookType!=='look'"               @click="setGiveMode(scope.row)">            </i>            <!-- <el-popover placement="bottom"                          v-model.trim="scope.row.provideVisible"                          v-if='scope.row.type == 1'>                <i class='el-icon-edit'                   slot='reference'>                </i>                <el-select v-model.trim="scope.row.fangshi"                           clearable>                  <el-option label="团购"                             value="GROUP"></el-option>                  <el-option label="借用"                             value="LEASE"></el-option>                  <el-option label="免费"                             value="FREE"></el-option>                </el-select>                <el-input placeholder="请输入费用"                          v-if='scope.row.fangshi == "LEASE"'                          v-model.trim="scope.row.fangshiprice"                          style='width:180px; margin-top:20px'></el-input>                <div style="text-align: right; margin-top: 20px">                  <el-button type="primary"                             size="mini"                             @click="scope.row.provideVisible  = false">确定</el-button>                </div>              </el-popover> -->          </div>        </template>      </el-table-column>      <el-table-column label="教辅组合"                       align="center"                       prop="jiaopu">        <template slot-scope="scope">          <!-- item.name && -->          <div>            <el-dialog title="添加教辅" :visible.sync="scope.row.markVisible"                       style="text-align:left;"                       width="60%">              <el-button type='text'                         @click="addMark(scope.row)">添加教辅</el-button>              <div class="markWrap">                <div class="markItem"                     v-for="(item, index) in scope.row.markList"                     :key='index'>                  <el-form :model="item"                           :inline="true">                    <el-form-item label="教辅名称">                      <el-input type="text"                                v-model.trim="item.name"></el-input>                    </el-form-item>                    <el-form-item label="教辅商品">                      <el-select v-model.trim="item.goods"                                 filterable                                 multiple                                 collapse-tags>                        <el-option v-for='(item,index) in scope.row.markChioseList'                                   :key='index'                                   :label="item.name"                                   :value="item.id"></el-option>                      </el-select>                    </el-form-item>                    <el-form-item label="教辅打包价">                      <el-input type='number'                                @mousewheel.native.prevent                                v-model.trim="item.price"></el-input>                    </el-form-item>                    <el-form-item>                      <el-button type="danger"                                 icon="el-icon-delete"                                 circle                                 @click='removeMartItem(scope.row,index)'>                      </el-button>                    </el-form-item>                  </el-form>                </div>              </div>              <span slot="footer"                    class="dialog-footer">                <!-- <el-button @click="scope.row.markVisible = false">取 消</el-button> -->                <el-button type="primary"                           @click="scope.row.markVisible = false">确 定</el-button>              </span>            </el-dialog>            <span>              <span v-for='(item,index) in scope.row.markList'                    v-if=" scope.row.markChioseList.length>0"                    :key='index'>{{item.name?item.name+':':''}}{{item.goods|goodsFilter(scope.row.markChioseList)}}{{' 价格 '+item.price }} </span>            </span>            <i class='el-icon-edit'               slot='reference'               v-if="lookType!=='look'"               @click="chioseMark(scope.row)">            </i>          </div>        </template>      </el-table-column>    </el-table>    <!-- <div class="remove"             @click="removeListItem">删除</div> -->    <div class="floor"         v-if="lookType!=='look'">      <div class='add'           @click="addListItem">添加</div>    </div>    <div class="btnWrap"         v-if="lookType!=='look'"         style="margin-top:30px">      <div class="closeBtn"           @click="getSound">取消</div>      <div class="okBtn"           v-permission="{child: 'musicGroup/updateSubjectInfo', parent: '/resetTeaming/resetSound'}"           @click="saveInfo">保存</div>    </div>    <el-dialog title="声部选择"               :visible.sync="dialogTableVisible"               :modal-append-to-body="false">      <div class="soundWrap">        <div class="itemList">          <div class="categroy"               v-for="(item,index) in soundList"               :key="index">            <p>{{item.name }}</p>            <el-checkbox-group v-model.trim="soundLists[index]"                               @change='changeList'>              <!--  sound: this.activeSoundList[item].name,  // id                 jihua: '10', //计划招生人数                 yuji: '10', // 预计收费                 zhonglei: [], // 可选乐器种类                 fangshi: 2, // 乐器提供方式                 jiaopu: 'jiaopu1', // 教辅组合                 type: 1, // 操作                 id: this.activeSoundList[item].id, //声部id                 visible: false, // 当前乐器提供方式的pop提示框显示隐藏 -->              <el-checkbox :label="sound.id"                           @change="checkinlist({'id':sound.id,'sound':sound.name,'jihua':0,'yuji':0,'zhonglei':[],'fangshi':[],'fangshiprice':1500,'jiaopu':'','type':1,'typeVisible':false,'provideVisible':false,'markVisible':false,'goodsList':[],'markList':[],'markChioseList':[]})"                           v-for="(sound,indexs) in item.subjects"                           :key="indexs">{{sound.name }}</el-checkbox>            </el-checkbox-group>          </div>        </div>      </div>      <p class='soundSubP'>当前选择声部数:{{chioseSoundNum}}</p>      <div class="btnWrapss">        <div class="dialogBtn"             @click="generates">确定</div>      </div>    </el-dialog>    <el-dialog tilte='请选择乐器的提供方式及减免金额'               width="800px"               :visible.sync="reductionVisible">      <div v-if="editSound&&editSound.fangshi.length >0">        <div class="reductionWrap"             v-for="(item,index) in editSound.fangshi"             :key='index'>          <div class="lineWrap">            <div class="item">{{ item.shopName}}</div>            <div class="item">提供方式</div>            <div class="item">提供方式对应金额</div>            <div class="item">乐器费用减免</div>            <div class="item">课程费用减免</div>          </div>          <div class="lineWrap">            <div class="item"></div>            <div class="item">              <el-checkbox v-model.trim="item.mode.isGROUP"></el-checkbox>              团购            </div>            <div class="item">              <el-input style="width:80%"                        @mousewheel.native.prevent                        v-model.trim="item.mode.price"                        type="number"                        disabled></el-input>            </div>            <div class="item">              <el-input style="width:80%"                        @mousewheel.native.prevent                        @input='groupInput(item)'                        type="number"                        v-model.trim="item.mode.GROUP"></el-input>            </div>            <div class="item">              <el-input style="width:80%"                        type="number"                        @mousewheel.native.prevent                        v-model.trim="item.mode.courseGroup"                        @input="groupCourseInput(item)"></el-input>            </div>          </div>          <div class="lineWrap">            <div class="item"></div>            <div class="item">              <el-checkbox v-model.trim="item.mode.isLEASE"></el-checkbox>              租赁            </div>            <div class="item">              <el-input style="width:80%"                        @mousewheel.native.prevent                        type="number"                        @input='(val)=>{                            setDeposiInput(val,item)                         }'                        v-model.trim="item.mode.depositFee"></el-input>            </div>            <div class="item">              <el-input style="width:80%"                        type="number"                        disabled                        @mousewheel.native.prevent                        @input='deposiInput(item)'                        v-model.trim="item.mode.LEASE"></el-input>            </div>            <div class="item">              <el-input style="width:80%"                        disabled                        type="number"></el-input>            </div>          </div>          <div class="lineWrap">            <div class="item"></div>            <div class="item">              <el-checkbox v-model.trim="item.mode.isFREE"></el-checkbox>              免费            </div>            <div class="item">              <el-input style="width:80%"                        @mousewheel.native.prevent                        disabled></el-input>            </div>            <div class="item">              <!--  v-model.trim="item.mode.FREE" -->              <el-input style="width:80%"                        type="number"                        @mousewheel.native.prevent                        disabled></el-input>            </div>            <div class="item">              <el-input style="width:80%"                        disabled                        type="number"></el-input>            </div>          </div>        </div>      </div>      <div slot="footer"           class="dialog-footer">        <el-button type="primary"                   @click="resetSoundItem">确 定</el-button>      </div>    </el-dialog>  </div></template><script>import { findMusicGroupSubjectInfo, resetSubjectPlan, getSoundTree, getGoods, updateSubjectInfo } from '@/api/buildTeam'export default {  name: 'resetSound',  data () {    return {      reductionVisible: false,      dialogTableVisible: false,      tableList: [],      teamid: '',      activeSoundList: [],      soundList: [],      checkList: [],      multipleSelection: [], // 列表选择的集合      soundList: [],      soundLists: [], // 存储选中项的声部id 记录变量      editSound: null,      lookType: ''    }  },  mounted () {    this.init()  },  activated () {    this.init()  },  methods: {    init () {      // 获取声部信息      this.teamid = this.$route.query.id      this.lookType = this.$route.query.type      sessionStorage.setItem('resetCode', '2');      // 获取所有声部      getSoundTree({ tenantId: 1 }).then(res => {        if (res.code == 200) {          this.soundList = res.data.rows;          // // 生成动态的checkList          for (let key in this.soundList) {            this.$set(this.soundLists, key, [])          }          this.getSound();        }      })    },    changeList (e) {    },    getSound () {      findMusicGroupSubjectInfo({ musicGroupId: this.teamid }).then(res => {        if (res.code == 200) {          this.activeSoundList = res.data.musicGroupSubjectPlans.map(item => {            let fangshi = []            res.data.musicGroupSubjectGoodsGroups.forEach(sub => {              if (sub.subjectId == item.subjectId && sub.type == 'INSTRUMENT') {                let FREE, courseFree, LEASE, courseLease, GROUP, courseGroup;                let isFREE = false                let isLEASE = false                let isGROUP = false                let depositFee = sub.depositFee                let price = sub.price                if (sub.kitGroupPurchaseTypeJson) {                  let expectJson = JSON.parse(sub.kitGroupPurchaseTypeJson);                  if (expectJson && expectJson.hasOwnProperty("FREE")) {                    FREE = expectJson.FREE                    isFREE = true                  }                  if (expectJson && expectJson.hasOwnProperty("LEASE")) {                    LEASE = expectJson.LEASE                    isLEASE = true;                  }                  if (expectJson && expectJson.hasOwnProperty("GROUP")) {                    GROUP = expectJson.GROUP                    isGROUP = true                  }                }                if (sub.coursePurchaseTypeJson) {                  let courseJson = JSON.parse(sub.coursePurchaseTypeJson)                  if (courseJson && courseJson.hasOwnProperty("FREE")) {                    courseFree = courseJson.FREE;                  }                  if (courseJson && courseJson.hasOwnProperty("LEASE")) {                    courseLease = courseJson.LEASE;                  }                  if (courseJson && courseJson.hasOwnProperty("GROUP")) {                    courseGroup = courseJson.GROUP;                  }                }                fangshi.push({                  shopName: sub.name,                  id: sub.goodsIdList,                  mode: {                    'FREE': FREE || 0,                    'GROUP': GROUP || 0,                    'LEASE': LEASE || 0,                    courseFree: courseFree || 0,                    courseLease: courseLease || null,                    courseGroup: courseGroup || 0,                    'depositFee': depositFee || 1500, // 保证金                    'price': price,                    'isFREE': isFREE,                    'isGROUP': isGROUP,                    'isLEASE': isLEASE,                  }                })              }            })            let obj = { 'id': item.subjectId, 'sound': item.subName, 'jihua': item.expectedStudentNum, 'yuji': item.fee, 'zhonglei': [], 'fangshi': fangshi, 'fangshiprice': item.depositFee, 'jiaopu': '', 'type': 1, 'typeVisible': false, 'provideVisible': false, 'markVisible': false, 'goodsList': [], 'markList': [], 'markChioseList': [] }            this.checkinlist(obj)            return obj;          })          // 这里循环          for (let z = 0; z < this.activeSoundList.length; z++) {            for (let x = 0; x < this.soundList.length; x++) {              let tempSound = this.soundList[x].subjects              for (let y = 0; y < tempSound.length; y++) {                if (tempSound[y].id == this.activeSoundList[z].id) {                  tempSound.splice(y, 1)                  y--                }              }            }          }          // this.soundList.forEach((item, i) => {          //   item.subjects.forEach((some, j) => {          //     this.activeSoundList.forEach((sub, x) => {          //       console.log(some.name + '-' + sub.sound)          //       console.log(some.id + '-' + sub.id)          //       if (sub.id == some.id) {          //         console.log(1)          //         item.subjects.splice(x, 1)          //       }          //     })          //   })          // })          // 循环列表里的声部 拿取商品          for (let i in this.activeSoundList) {            for (let j in res.data.musicGroupSubjectGoodsGroups) {              if (this.activeSoundList[i].id == res.data.musicGroupSubjectGoodsGroups[j].subjectId) {                //                 if (res.data.musicGroupSubjectGoodsGroups[j].type == 'INSTRUMENT') {                  this.activeSoundList[i].zhonglei = this.activeSoundList[i].zhonglei.concat(res.data.musicGroupSubjectGoodsGroups[j].goodsIdList)                  this.activeSoundList[i].zhonglei = this.activeSoundList[i].zhonglei.map(item => {                    return parseInt(item);                  })                  this.activeSoundList[i].goodsList = this.activeSoundList[i].goodsList.concat(res.data.musicGroupSubjectGoodsGroups[j].goodsList);                  // goodsList                }                // 拿辅件                if (res.data.musicGroupSubjectGoodsGroups[j].type == 'ACCESSORIES') {                  if (res.data.musicGroupSubjectGoodsGroups[j].goodsList.length >= 0) {                    this.activeSoundList[i].markList ? this.activeSoundList[i].markList : this.activeSoundList[i].markList = []                    let obj = {};                    obj.goods = res.data.musicGroupSubjectGoodsGroups[j].goodsIdList.split(',');                    obj.goods = obj.goods.map(item => {                      return parseInt(item);                    })                    obj.name = res.data.musicGroupSubjectGoodsGroups[j].name                    obj.price = res.data.musicGroupSubjectGoodsGroups[j].price;                    this.activeSoundList[i].markList.push(obj);                    // this.activeSoundList[i].markList.goodsList.goods = JSON.parse(res.data.musicGroupSubjectGoodsGroups[j].goodsIdList)                    this.activeSoundList[i].markChioseList = this.activeSoundList[i].markChioseList.concat(res.data.musicGroupSubjectGoodsGroups[j].goodsList);                  }                }              }            }          }        }      })    },    // 添加教辅    addMark (row) {      row.markList.push({ 'name': '', 'goods': [], 'price': '' })    },    removeMartItem (row, index) {      row.markList.splice(index, 1);    },    saveInfo () {      // 只提交第二页的数据      let obj = {};      let activeSoundList = this.activeSoundList      // 添加商品以及教辅      obj.musicGroupId = this.teamid      obj.musicGroupStatus = 'PROGRESS';      obj.musicGroupSubjectGoodsGroups = []      obj.musicGroupSubjectPlans = []      activeSoundList.forEach(active => {        // 乐器        active.zhonglei.forEach(zl => {          let goodsItem = []          active.goodsList.forEach(goods => {            if (goods.id == zl) {              goodsItem = goods            }          })          let kitGroupPurchaseTypeJson = null          let depositFee;          let price          let coursePurchaseTypeJson = null;          active.fangshi.forEach(fs => {            if (fs.id == zl) {              depositFee = fs.mode.depositFee              price = fs.mode.price              let types = {}              if (fs.mode.isFREE) {                types.FREE = fs.mode.FREE              }              if (fs.mode.isGROUP) {                types.GROUP = fs.mode.GROUP              }              if (fs.mode.isLEASE) {                types.LEASE = fs.mode.LEASE              }              kitGroupPurchaseTypeJson = JSON.stringify(types)              if (kitGroupPurchaseTypeJson.length <= 0) {                kitGroupPurchaseTypeJson = null              }              let courseTypes = {}              if (fs.mode.courseFree) {                courseTypes.FREE = fs.mode.courseFree              }              if (fs.mode.courseGroup) {                courseTypes.GROUP = fs.mode.courseGroup ? fs.mode.courseGroup : 0              }              if (fs.mode.courseLease) {                courseTypes.LEASE = fs.mode.courseLease              }              coursePurchaseTypeJson = JSON.stringify(courseTypes)              if (coursePurchaseTypeJson.length <= 0) {                coursePurchaseTypeJson = null;              }            }          })          let some = {            subjectId: active.id,            type: 'INSTRUMENT',            goodsIdList: zl,            name: goodsItem.name,            kitGroupPurchaseTypeJson,            coursePurchaseTypeJson,            depositFee,            price          }          obj.musicGroupSubjectGoodsGroups.push(some);        })        // 遍历声部里的教辅        active.markList.forEach(mark => {          if (mark.goods.length >= 1) {            let some = {              subjectId: active.id,              type: 'ACCESSORIES',              goodsIdList: mark.goods.join(','),              name: mark.name,              price: mark.price            }            obj.musicGroupSubjectGoodsGroups.push(some);          }        })        // 添加声部        let item = {          expectedStudentNum: active.jihua,          fee: active.yuji,          // kitGroupPurchaseType: active.fangshi,          subName: active.sound,          subjectId: active.id,          depositFee: active.fangshiprice // depositFee  只有租赁才有        }        obj.musicGroupSubjectPlans.push(item);      })      // 发请求修改声部信息      this.$confirm(`确定提交?`, '提示', {        confirmButtonText: '确定',        cancelButtonText: '取消',        type: 'warning'      }).then(() => {        updateSubjectInfo(obj).then(res => {          if (res.code == 200) {            this.$message.success('提交成功')            // this.$router.push({ path: '/business/teamDetail' })            this.getSound();          }        })      }).catch(() => { })    },    // 根据声部id查询可选教辅    chioseMark (row) {      row.markVisible = true      let id = row.id;      getGoods({ 'subjectId': id, 'type': 'ACCESSORIES' }).then(res => {        if (res.code == 200) {          row.markChioseList = res.data;        }      })    },    // 根据声部id获取可选乐器种类    chioseType (row) {      // 根据id查询可选类型种类      let id = row.id;      // 'subjectId': id, ' type'='INSTRUMENT'      getGoods({ 'subjectId': id, 'type': 'INSTRUMENT' }).then(res => {        if (res.code == 200) {          row.goodsList = res.data;        }      })    },    // 勾选选中框处理数据,存储勾选过的checkbox值    checkinlist (obj) {      let flag = false;      this.activeSoundList.map(item => {        if (item.id == obj.id) {          flag = true        }      })      if (!flag) {        this.activeSoundList.push(obj)      } else {        for (let i = 0; i < this.activeSoundList.length; i++) {          if (this.activeSoundList[i].id == obj.id) {            this.activeSoundList.splice(i, 1);          }        }      }    },    // 添加声部    // 点击添加按钮    addListItem () {      this.dialogTableVisible = true;    },    // 点击确认按钮生成表单    generates () {      this.dialogTableVisible = false;    },    // 设置乐器提供方式    setGiveMode (row) {      // goodsList      if (row.zhonglei.length <= 0) {        this.$message.error('请先选择乐器规格')        return      }      // row.fangshi = []      // row.zhonglei      // row.goodsList      const tyuji = row.yuji      if (row.fangshi[0] && row.fangshi[0].mode) {        row.fangshi.forEach(item => {          item.mode.yuji = tyuji        })      } else {        for (let i in row.goodsList) {          for (let j in row.zhonglei) {            if (row.goodsList[i].id == row.zhonglei[j]) {              console.log(row.goodsList[i].groupPurchasePrice)              row.fangshi.push({                shopName: row.goodsList[i].name,                id: row.goodsList[i].id,                mode: {                  'FREE': 0,                  'GROUP': 0,                  'LEASE': 0,                  courseFree: 0,                  courseLease: null,                  courseGroup: 0,                  'depositFee': 1500, // 保证金                  'price': row.goodsList[i].groupPurchasePrice,// 团购价                  'isFREE': false,                  'isGROUP': false,                  'isLEASE': false,                }              })            }          }        }      }      this.editSound = row;      this.reductionVisible = true    },    resetSoundItem () {      for (let i in this.activeSoundList) {        if (this.activeSoundList[i].id == this.editSound.id) {          this.activeSoundList[i].id = this.editSound.id          this.reductionVisible = false        }      }    },    groupInput (item) {      if (item.mode.price - item.mode.GROUP < 0) {        item.mode.GROUP = item.mode.price      }    },    groupCourseInput (item) {      console.log(item)      let mode = item.mode      if (mode.yuji - mode.courseGroup < 0) {        mode.courseGroup = mode.yuji      }    },    deposiInput (item) {      if (item.mode.depositFee - item.mode.LEASE < 0) {        item.mode.LEASE = item.mode.depositFee      }    },    setDeposiInput (val, item) {      item.mode.LEASE = 0;    },    changezhonglei (row) {      row.fangshi = []    },  }, filters: {    zhongleiFilter (val, list) {      if (list && list.length <= 0) {        return;      }      let arr = []      for (let i = 0; i < list.length; i++) {        for (let j = 0; j < val.length; j++) {          if (val[j] == list[i].id) {            arr.push(list[i].name)          }        }      }      if (arr.length > 0) {        return arr.join(',')      } else {        return ''      }    },    fangshiFilter (val, price) {      let str = ''      for (let i in val) {        // str += `${val[i].shopName}:`        // if (val[i].mode.isFREE) {        //   str += `免费:减免金额${val[i].mode['FREE']}\n`        // }        // if (val[i].mode.isGROUP) {        //   str += `团购:减免金额${val[i].mode['GROUP']}\n`        // }        // if (val[i].mode.isLEASE) {        //   str += `租赁:${val[i].mode.depositFee},减免金额${val[i].mode['LEASE']}\n`        // }        let vals = val[i]        str += `${vals.shopName}:`;        if (vals.mode.isFREE) {          str += `免费:减免金额${vals.mode["FREE"]},课程减免${vals.mode['courseFree'] ? vals.mode['courseFree'] : 0}\n`;        }        if (vals.mode.isGROUP) {          str += `团购:团购价${vals.mode["price"]},减免金额${vals.mode["GROUP"] ? vals.mode["GROUP"] : 0},课程减免${vals.mode['courseGroup'] ? vals.mode['courseGroup'] : 0}\n`;        }        if (vals.mode.isLEASE) {          str += `租赁:${vals.mode.depositFee},减免金额${vals.mode["LEASE"] ? vals.mode["LEASE"] : 0},课程减免${vals.mode['courseLease'] ? vals.mode['courseLease'] : 0}\n`;        }      }      // if (val == 'FREE') {      //   str = '免费'      //   return str;      // } else if (val == 'GROUP') {      //   str = '团购'      //   return str      // } else if (val == 'LEASE') {      //   str = '借用'      // }      // str = str.substring(0, str.length - 1)      return str    },    goodsFilter (val, list) {      if (list && list.length <= 0) {        return '';      }      let arr = [];      for (let i = 0; i < val.length; i++) {        for (let j = 0; j < list.length; j++) {          if (val[i] == list[j].id) {            arr.push(list[j].name);          }        }      }      if (arr.length > 0) {        return arr.join(',')      } else {        return ''      }    }    // markFilter(val){    //   for    //   let name = val.name;    //   let goods = val.goods.join(',');    //   let price = val.price    // }  }, computed: {    // 返回当前选中声部数量    chioseSoundNum () {      let num = 0;      for (let key in this.soundList) {        num += this.soundLists[key].length;      }      return num;    }  }}</script><style lang="scss">.floor {  display: flex;  flex-direction: row;  justify-content: flex-start;  width: 100%;  height: 48px;  line-height: 48px;  background: rgba(237, 238, 240, 1);  font-size: 14px;  color: #444;  align-items: center;  position: relative;  z-index: 1;  .remove {    width: 98px;    height: 32px;    background: rgba(248, 80, 67, 1);    border-radius: 3px;    color: #fff;    line-height: 32px;    text-align: center;    margin-left: 164px;    cursor: pointer;  }  .add {    width: 98px;    height: 32px;    background: rgba(20, 146, 138, 1);    border-radius: 3px;    color: #fff;    line-height: 32px;    text-align: center;    margin-left: 20px;    cursor: pointer;  }}.soundWrap {  width: 100%;  overflow: auto;  .itemList {    display: flex;    flex-direction: row;    justify-content: flex-start;    flex-wrap: nowrap;    flex-grow: 1;    height: 300px;    max-height: 300px;    overflow: auto;    .categroy {      width: 150px;      min-width: 150px;      .el-checkbox {        height: 30px;        line-height: 30px;        display: block;        padding-left: 20px;      }      p {        height: 40px;        line-height: 40px;        background-color: #edeef0;        margin-bottom: 15px;        text-align: center;      }    }  }}.soundSubP {  height: 40px;  line-height: 40px;  background-color: #edeef0;  padding-left: 25px;}.btnWrapss {  display: flex;  flex-direction: column;  align-items: center;  margin-top: 150px;  .dialogBtn {    width: 188px;    height: 40px;    background: rgba(249, 114, 21, 1);    border-radius: 4px;    line-height: 40px;    color: #fff;    text-align: center;    cursor: pointer;  }}.reductionWrap {  width: 100%;  .lineWrap {    display: flex;    flex-direction: row;    justify-content: space-around;    height: 40px;    line-height: 40px;    margin-bottom: 10px;    .item {      width: 25%;      text-align: left;    }  }}</style>
 |