|  | @@ -2,20 +2,20 @@
 | 
											
												
													
														|  |    <div>
 |  |    <div>
 | 
											
												
													
														|  |      <el-form :model="form" :rules="rules" ref="form" label-width="110px">
 |  |      <el-form :model="form" :rules="rules" ref="form" label-width="110px">
 | 
											
												
													
														|  |        <el-form-item label="原乐器" prop="name">
 |  |        <el-form-item label="原乐器" prop="name">
 | 
											
												
													
														|  | -        <span>{{originalMusicalGoods || '无'}}</span>
 |  | 
 | 
											
												
													
														|  | 
 |  | +        <span>{{ originalMusicalGoods || "无" }}</span>
 | 
											
												
													
														|  |        </el-form-item>
 |  |        </el-form-item>
 | 
											
												
													
														|  |        <el-form-item label="原教辅" prop="name">
 |  |        <el-form-item label="原教辅" prop="name">
 | 
											
												
													
														|  | -        <span>{{originalAccessoriesGoods || '无'}}</span>
 |  | 
 | 
											
												
													
														|  | 
 |  | +        <span>{{ originalAccessoriesGoods || "无" }}</span>
 | 
											
												
													
														|  |        </el-form-item>
 |  |        </el-form-item>
 | 
											
												
													
														|  |        <el-form-item
 |  |        <el-form-item
 | 
											
												
													
														|  |          label="更改声部"
 |  |          label="更改声部"
 | 
											
												
													
														|  |          prop="subjectId"
 |  |          prop="subjectId"
 | 
											
												
													
														|  |          :rules="[
 |  |          :rules="[
 | 
											
												
													
														|  | -          { required: true, message: '请选择更改声部', trigger: 'change' }
 |  | 
 | 
											
												
													
														|  | 
 |  | +          { required: true, message: '请选择更改声部', trigger: 'change' },
 | 
											
												
													
														|  |          ]"
 |  |          ]"
 | 
											
												
													
														|  |        >
 |  |        >
 | 
											
												
													
														|  |          <el-select
 |  |          <el-select
 | 
											
												
													
														|  | -          style="width: 100%!important"
 |  | 
 | 
											
												
													
														|  | 
 |  | +          style="width: 100% !important"
 | 
											
												
													
														|  |            v-model="form.subjectId"
 |  |            v-model="form.subjectId"
 | 
											
												
													
														|  |            clearable
 |  |            clearable
 | 
											
												
													
														|  |            v-if="!changeInfo"
 |  |            v-if="!changeInfo"
 | 
											
										
											
												
													
														|  | @@ -26,62 +26,86 @@
 | 
											
												
													
														|  |              v-for="item in filterVoiceList"
 |  |              v-for="item in filterVoiceList"
 | 
											
												
													
														|  |              :key="item.subjectId"
 |  |              :key="item.subjectId"
 | 
											
												
													
														|  |              :label="item.subjectName"
 |  |              :label="item.subjectName"
 | 
											
												
													
														|  | -            :value="item.subjectId">
 |  | 
 | 
											
												
													
														|  | 
 |  | +            :value="item.subjectId"
 | 
											
												
													
														|  | 
 |  | +          >
 | 
											
												
													
														|  |            </el-option>
 |  |            </el-option>
 | 
											
												
													
														|  |          </el-select>
 |  |          </el-select>
 | 
											
												
													
														|  | -        <span v-else>{{changeSubjectName}}</span>
 |  | 
 | 
											
												
													
														|  | 
 |  | +        <span v-else>{{ changeSubjectName }}</span>
 | 
											
												
													
														|  |        </el-form-item>
 |  |        </el-form-item>
 | 
											
												
													
														|  |        <el-form-item
 |  |        <el-form-item
 | 
											
												
													
														|  |          label="更改乐器"
 |  |          label="更改乐器"
 | 
											
												
													
														|  |          prop="musicalGoods"
 |  |          prop="musicalGoods"
 | 
											
												
													
														|  |          :rules="[
 |  |          :rules="[
 | 
											
												
													
														|  | -          { required: true, message: '请选择更改乐器', trigger: 'change' }
 |  | 
 | 
											
												
													
														|  | 
 |  | +          { required: true, message: '请选择更改乐器', trigger: 'change' },
 | 
											
												
													
														|  |          ]"
 |  |          ]"
 | 
											
												
													
														|  |        >
 |  |        >
 | 
											
												
													
														|  |          <el-select
 |  |          <el-select
 | 
											
												
													
														|  | -          style="width: 100%!important"
 |  | 
 | 
											
												
													
														|  | 
 |  | +          style="width: 100% !important"
 | 
											
												
													
														|  |            v-model="form.musicalGoods"
 |  |            v-model="form.musicalGoods"
 | 
											
												
													
														|  |            clearable
 |  |            clearable
 | 
											
												
													
														|  |            v-if="!changeInfo"
 |  |            v-if="!changeInfo"
 | 
											
												
													
														|  |            @change="musicalGoodsChange"
 |  |            @change="musicalGoodsChange"
 | 
											
												
													
														|  |            placeholder="请选择乐器"
 |  |            placeholder="请选择乐器"
 | 
											
												
													
														|  |          >
 |  |          >
 | 
											
												
													
														|  | -          <el-option
 |  | 
 | 
											
												
													
														|  | -            label="自备乐器"
 |  | 
 | 
											
												
													
														|  | -            value="OWNED">
 |  | 
 | 
											
												
													
														|  | -          </el-option>
 |  | 
 | 
											
												
													
														|  | 
 |  | +          <el-option label="自备乐器" value="OWNED"> </el-option>
 | 
											
												
													
														|  |            <el-option
 |  |            <el-option
 | 
											
												
													
														|  |              v-for="item in musicalGoods"
 |  |              v-for="item in musicalGoods"
 | 
											
												
													
														|  |              :key="item.goodsIdList"
 |  |              :key="item.goodsIdList"
 | 
											
												
													
														|  |              :label="item.name"
 |  |              :label="item.name"
 | 
											
												
													
														|  | -            :value="item.goodsIdList">
 |  | 
 | 
											
												
													
														|  | 
 |  | +            :value="item.goodsIdList"
 | 
											
												
													
														|  | 
 |  | +          >
 | 
											
												
													
														|  |            </el-option>
 |  |            </el-option>
 | 
											
												
													
														|  |          </el-select>
 |  |          </el-select>
 | 
											
												
													
														|  | -        <span v-else-if="changeInfo && changeInfo.changeMusicalGoods">{{changeInfo.changeMusicalGoods.name}}</span>
 |  | 
 | 
											
												
													
														|  | 
 |  | +        <span v-else-if="changeInfo && changeInfo.changeMusicalGoods">{{
 | 
											
												
													
														|  | 
 |  | +          changeInfo.changeMusicalGoods.name
 | 
											
												
													
														|  | 
 |  | +        }}</span>
 | 
											
												
													
														|  |        </el-form-item>
 |  |        </el-form-item>
 | 
											
												
													
														|  |        <el-form-item
 |  |        <el-form-item
 | 
											
												
													
														|  | -        v-if="changeInfo || (form.musicalGoods && musicalGoodsById[form.musicalGoods] && musicalGoodsById[form.musicalGoods].kitGroupPurchaseTypeJsonParse)" label="乐器提供方式" prop="type"
 |  | 
 | 
											
												
													
														|  | 
 |  | +        v-if="
 | 
											
												
													
														|  | 
 |  | +          changeInfo ||
 | 
											
												
													
														|  | 
 |  | +          (form.musicalGoods &&
 | 
											
												
													
														|  | 
 |  | +            musicalGoodsById[form.musicalGoods] &&
 | 
											
												
													
														|  | 
 |  | +            musicalGoodsById[form.musicalGoods].kitGroupPurchaseTypeJsonParse)
 | 
											
												
													
														|  | 
 |  | +        "
 | 
											
												
													
														|  | 
 |  | +        label="乐器提供方式"
 | 
											
												
													
														|  | 
 |  | +        prop="type"
 | 
											
												
													
														|  |          :rules="[
 |  |          :rules="[
 | 
											
												
													
														|  | -          { required: true, message: '请选择乐器提供方式', trigger: 'change' }
 |  | 
 | 
											
												
													
														|  | 
 |  | +          { required: true, message: '请选择乐器提供方式', trigger: 'change' },
 | 
											
												
													
														|  |          ]"
 |  |          ]"
 | 
											
												
													
														|  |        >
 |  |        >
 | 
											
												
													
														|  |          <el-radio-group v-if="!changeInfo" v-model="form.type">
 |  |          <el-radio-group v-if="!changeInfo" v-model="form.type">
 | 
											
												
													
														|  |            <el-radio
 |  |            <el-radio
 | 
											
												
													
														|  |              :label="key"
 |  |              :label="key"
 | 
											
												
													
														|  | -            v-for="(item, key) in musicalGoodsById[form.musicalGoods].kitGroupPurchaseTypeJsonParse"
 |  | 
 | 
											
												
													
														|  | 
 |  | +            v-for="(item, key) in musicalGoodsById[form.musicalGoods]
 | 
											
												
													
														|  | 
 |  | +              .kitGroupPurchaseTypeJsonParse"
 | 
											
												
													
														|  |              :key="key"
 |  |              :key="key"
 | 
											
												
													
														|  | -          >{{`${kitGroupPurchaseTypeFormater[key]} ${(musicalGoodsById[form.musicalGoods][typeAndprice[key]] || 0) > 0 ? musicalGoodsById[form.musicalGoods][typeAndprice[key]] + '元' : '免费'}`}}</el-radio>
 |  | 
 | 
											
												
													
														|  | 
 |  | +            >{{
 | 
											
												
													
														|  | 
 |  | +              `${kitGroupPurchaseTypeFormater[key]} ${
 | 
											
												
													
														|  | 
 |  | +                (musicalGoodsById[form.musicalGoods][typeAndprice[key]] || 0) >
 | 
											
												
													
														|  | 
 |  | +                0
 | 
											
												
													
														|  | 
 |  | +                  ? musicalGoodsById[form.musicalGoods][typeAndprice[key]] +
 | 
											
												
													
														|  | 
 |  | +                    "元"
 | 
											
												
													
														|  | 
 |  | +                  : "免费"
 | 
											
												
													
														|  | 
 |  | +              }`
 | 
											
												
													
														|  | 
 |  | +            }}</el-radio
 | 
											
												
													
														|  | 
 |  | +          >
 | 
											
												
													
														|  |          </el-radio-group>
 |  |          </el-radio-group>
 | 
											
												
													
														|  | -        <span v-else-if="changeInfo && changeInfo.kitGroupPurchaseType">{{kitGroupPurchaseTypeFormater[changeInfo.kitGroupPurchaseType]}}</span>
 |  | 
 | 
											
												
													
														|  | 
 |  | +        <span v-else-if="changeInfo && changeInfo.kitGroupPurchaseType">{{
 | 
											
												
													
														|  | 
 |  | +          kitGroupPurchaseTypeFormater[changeInfo.kitGroupPurchaseType]
 | 
											
												
													
														|  | 
 |  | +        }}</span>
 | 
											
												
													
														|  |        </el-form-item>
 |  |        </el-form-item>
 | 
											
												
													
														|  | -      <el-form-item v-if="(activeAccessories.length || groupList.length) || changeInfo" label="更换教辅" prop="name">
 |  | 
 | 
											
												
													
														|  | 
 |  | +      <el-form-item
 | 
											
												
													
														|  | 
 |  | +        v-if="activeAccessories.length || groupList.length || changeInfo"
 | 
											
												
													
														|  | 
 |  | +        label="更换教辅"
 | 
											
												
													
														|  | 
 |  | +        prop="name"
 | 
											
												
													
														|  | 
 |  | +      >
 | 
											
												
													
														|  |          <accessories
 |  |          <accessories
 | 
											
												
													
														|  |            :list.sync="activeAccessories"
 |  |            :list.sync="activeAccessories"
 | 
											
												
													
														|  |            :groupList.sync="groupList"
 |  |            :groupList.sync="groupList"
 | 
											
												
													
														|  |            @change="accessoriesChange"
 |  |            @change="accessoriesChange"
 | 
											
												
													
														|  |            v-if="!changeInfo"
 |  |            v-if="!changeInfo"
 | 
											
												
													
														|  |          />
 |  |          />
 | 
											
												
													
														|  | -        <span v-else-if="changeInfo">{{changeAccessoriesGoods}}</span>
 |  | 
 | 
											
												
													
														|  | 
 |  | +        <span v-else-if="changeInfo">{{ changeAccessoriesGoods }}</span>
 | 
											
												
													
														|  |          <!-- <el-select style="width: 100%" v-model="form.accessories" clearable placeholder="请选择教辅">
 |  |          <!-- <el-select style="width: 100%" v-model="form.accessories" clearable placeholder="请选择教辅">
 | 
											
												
													
														|  |            <el-option
 |  |            <el-option
 | 
											
												
													
														|  |              v-for="item in accessories"
 |  |              v-for="item in accessories"
 | 
											
										
											
												
													
														|  | @@ -93,121 +117,145 @@
 | 
											
												
													
														|  |        </el-form-item>
 |  |        </el-form-item>
 | 
											
												
													
														|  |        <el-form-item label="查看链接" prop="name" v-if="changeInfo">
 |  |        <el-form-item label="查看链接" prop="name" v-if="changeInfo">
 | 
											
												
													
														|  |          <div class="viewlink">
 |  |          <div class="viewlink">
 | 
											
												
													
														|  | -          <el-tooltip class="item" effect="dark" :content="copyLink" placement="top">
 |  | 
 | 
											
												
													
														|  | -            <span class="link">{{copyLink}}</span>
 |  | 
 | 
											
												
													
														|  | -          </el-tooltip>
 |  | 
 | 
											
												
													
														|  | -          <el-popover
 |  | 
 | 
											
												
													
														|  | 
 |  | +          <el-tooltip
 | 
											
												
													
														|  | 
 |  | +            class="item"
 | 
											
												
													
														|  | 
 |  | +            effect="dark"
 | 
											
												
													
														|  | 
 |  | +            :content="copyLink"
 | 
											
												
													
														|  |              placement="top"
 |  |              placement="top"
 | 
											
												
													
														|  | -            width="220"
 |  | 
 | 
											
												
													
														|  | -            trigger="click">
 |  | 
 | 
											
												
													
														|  | 
 |  | +          >
 | 
											
												
													
														|  | 
 |  | +            <span class="link">{{ copyLink }}</span>
 | 
											
												
													
														|  | 
 |  | +          </el-tooltip>
 | 
											
												
													
														|  | 
 |  | +          <el-popover placement="top" width="220" trigger="click">
 | 
											
												
													
														|  |              <div class="left-code">
 |  |              <div class="left-code">
 | 
											
												
													
														|  | -              <div id="qrcode"
 |  | 
 | 
											
												
													
														|  | -                  class="qrcode code"
 |  | 
 | 
											
												
													
														|  | -                  ref="qrCodeUrl"></div>
 |  | 
 | 
											
												
													
														|  | -              <p class="code-url"
 |  | 
 | 
											
												
													
														|  | -                v-if="copyLink">{{ copyLink }} <el-link @click="copyUrl(copyLink)" class="linkbtn" type="primary">复制</el-link></p>
 |  | 
 | 
											
												
													
														|  | 
 |  | +              <div id="qrcode" class="qrcode code" ref="qrCodeUrl"></div>
 | 
											
												
													
														|  | 
 |  | +              <p class="code-url" v-if="copyLink">
 | 
											
												
													
														|  | 
 |  | +                {{ copyLink }}
 | 
											
												
													
														|  | 
 |  | +                <el-link
 | 
											
												
													
														|  | 
 |  | +                  @click="copyUrl(copyLink)"
 | 
											
												
													
														|  | 
 |  | +                  class="linkbtn"
 | 
											
												
													
														|  | 
 |  | +                  type="primary"
 | 
											
												
													
														|  | 
 |  | +                  >复制</el-link
 | 
											
												
													
														|  | 
 |  | +                >
 | 
											
												
													
														|  | 
 |  | +              </p>
 | 
											
												
													
														|  |              </div>
 |  |              </div>
 | 
											
												
													
														|  | -            <el-button type="primary" class="btn" slot="reference" @click="onCreateQRCode">二维码</el-button>
 |  | 
 | 
											
												
													
														|  | 
 |  | +            <el-button
 | 
											
												
													
														|  | 
 |  | +              type="primary"
 | 
											
												
													
														|  | 
 |  | +              class="btn"
 | 
											
												
													
														|  | 
 |  | +              slot="reference"
 | 
											
												
													
														|  | 
 |  | +              @click="onCreateQRCode"
 | 
											
												
													
														|  | 
 |  | +              >二维码</el-button
 | 
											
												
													
														|  | 
 |  | +            >
 | 
											
												
													
														|  |            </el-popover>
 |  |            </el-popover>
 | 
											
												
													
														|  |          </div>
 |  |          </div>
 | 
											
												
													
														|  |        </el-form-item>
 |  |        </el-form-item>
 | 
											
												
													
														|  |        <el-form-item label="支付差价" prop="name">
 |  |        <el-form-item label="支付差价" prop="name">
 | 
											
												
													
														|  | -        <span style="color: red;" v-if="!changeInfo">{{ spread | moneyFormat }}元</span>
 |  | 
 | 
											
												
													
														|  | -        <span style="color: red;" v-else>{{ editSpread | moneyFormat }}元</span>
 |  | 
 | 
											
												
													
														|  | 
 |  | +        <span style="color: red" v-if="!changeInfo"
 | 
											
												
													
														|  | 
 |  | +          >{{ spread | moneyFormat }}元</span
 | 
											
												
													
														|  | 
 |  | +        >
 | 
											
												
													
														|  | 
 |  | +        <span style="color: red" v-else>{{ editSpread | moneyFormat }}元</span>
 | 
											
												
													
														|  |        </el-form-item>
 |  |        </el-form-item>
 | 
											
												
													
														|  |      </el-form>
 |  |      </el-form>
 | 
											
												
													
														|  | -    <div
 |  | 
 | 
											
												
													
														|  | -      slot="footer"
 |  | 
 | 
											
												
													
														|  | -      class="dialog-footer"
 |  | 
 | 
											
												
													
														|  | -      style="text-align: right;"
 |  | 
 | 
											
												
													
														|  | -    >
 |  | 
 | 
											
												
													
														|  | -      <el-button
 |  | 
 | 
											
												
													
														|  | -        @click="$listeners.close"
 |  | 
 | 
											
												
													
														|  | -      >取 消</el-button>
 |  | 
 | 
											
												
													
														|  | 
 |  | +    <div slot="footer" class="dialog-footer" style="text-align: right">
 | 
											
												
													
														|  | 
 |  | +      <el-button @click="$listeners.close">取 消</el-button>
 | 
											
												
													
														|  |        <el-button
 |  |        <el-button
 | 
											
												
													
														|  |          @click="cancel"
 |  |          @click="cancel"
 | 
											
												
													
														|  |          type="danger"
 |  |          type="danger"
 | 
											
												
													
														|  |          v-permission="'subjectChange/cancel'"
 |  |          v-permission="'subjectChange/cancel'"
 | 
											
												
													
														|  |          v-if="changeInfo && changeInfo.status !== 1"
 |  |          v-if="changeInfo && changeInfo.status !== 1"
 | 
											
												
													
														|  | -      >取消订单</el-button>
 |  | 
 | 
											
												
													
														|  | 
 |  | +        >取消订单</el-button
 | 
											
												
													
														|  | 
 |  | +      >
 | 
											
												
													
														|  |        <el-button
 |  |        <el-button
 | 
											
												
													
														|  |          type="primary"
 |  |          type="primary"
 | 
											
												
													
														|  |          v-if="!changeInfo"
 |  |          v-if="!changeInfo"
 | 
											
												
													
														|  |          v-permission="'subjectChange/add'"
 |  |          v-permission="'subjectChange/add'"
 | 
											
												
													
														|  |          @click="submit"
 |  |          @click="submit"
 | 
											
												
													
														|  | -      >确 定</el-button>
 |  | 
 | 
											
												
													
														|  | 
 |  | +        >确 定</el-button
 | 
											
												
													
														|  | 
 |  | +      >
 | 
											
												
													
														|  |      </div>
 |  |      </div>
 | 
											
												
													
														|  |    </div>
 |  |    </div>
 | 
											
												
													
														|  |  </template>
 |  |  </template>
 | 
											
												
													
														|  |  <script>
 |  |  <script>
 | 
											
												
													
														|  | -import QRCode from 'qrcodejs2'
 |  | 
 | 
											
												
													
														|  | -import copy from 'copy-to-clipboard'
 |  | 
 | 
											
												
													
														|  | -import numeral from 'numeral'
 |  | 
 | 
											
												
													
														|  | -import { getStudentOriginal, getSubjectGoodsAndInfo, subjectChangeAdd, subjectChangeCancel, getChangeInfo } from '@/api/buildTeam'
 |  | 
 | 
											
												
													
														|  | -import { vaildStudentUrl } from '@/utils/validate'
 |  | 
 | 
											
												
													
														|  | -import accessories from './accessories'
 |  | 
 | 
											
												
													
														|  | -import { kitGroupPurchaseType } from '@/constant'
 |  | 
 | 
											
												
													
														|  | 
 |  | +import QRCode from "qrcodejs2";
 | 
											
												
													
														|  | 
 |  | +import copy from "copy-to-clipboard";
 | 
											
												
													
														|  | 
 |  | +import numeral from "numeral";
 | 
											
												
													
														|  | 
 |  | +import {
 | 
											
												
													
														|  | 
 |  | +  getStudentOriginal,
 | 
											
												
													
														|  | 
 |  | +  getSubjectGoodsAndInfo,
 | 
											
												
													
														|  | 
 |  | +  subjectChangeAdd,
 | 
											
												
													
														|  | 
 |  | +  subjectChangeCancel,
 | 
											
												
													
														|  | 
 |  | +  getChangeInfo,
 | 
											
												
													
														|  | 
 |  | +} from "@/api/buildTeam";
 | 
											
												
													
														|  | 
 |  | +import { vaildStudentUrl } from "@/utils/validate";
 | 
											
												
													
														|  | 
 |  | +import accessories from "./accessories";
 | 
											
												
													
														|  | 
 |  | +import { kitGroupPurchaseType } from "@/constant";
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  const formatAllGoods = (data, kitGroupPurchaseType) => {
 |  |  const formatAllGoods = (data, kitGroupPurchaseType) => {
 | 
											
												
													
														|  | 
 |  | +  const accessories = [];
 | 
											
												
													
														|  | 
 |  | +  const accessoriesById = {};
 | 
											
												
													
														|  | 
 |  | +  const musicalGoods = [];
 | 
											
												
													
														|  | 
 |  | +  const musicalGoodsById = {};
 | 
											
												
													
														|  | 
 |  | +  const groupList = [];
 | 
											
												
													
														|  | 
 |  | +  const groupListById = {};
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  const accessories = []
 |  | 
 | 
											
												
													
														|  | -  const accessoriesById = {}
 |  | 
 | 
											
												
													
														|  | -  const musicalGoods = []
 |  | 
 | 
											
												
													
														|  | -  const musicalGoodsById = {}
 |  | 
 | 
											
												
													
														|  | -  const groupList = []
 |  | 
 | 
											
												
													
														|  | -  const groupListById = {}
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -  const accessoriesByGoods = {}
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const accessoriesByGoods = {};
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |    if (data) {
 |  |    if (data) {
 | 
											
												
													
														|  | -    const { musicGroupSubjectGoodsGroupList } = data
 |  | 
 | 
											
												
													
														|  | 
 |  | +    const { musicGroupSubjectGoodsGroupList } = data;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -    const types = {}
 |  | 
 | 
											
												
													
														|  | 
 |  | +    const types = {};
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      for (const item of musicGroupSubjectGoodsGroupList) {
 |  |      for (const item of musicGroupSubjectGoodsGroupList) {
 | 
											
												
													
														|  |        if (!types[item.type]) {
 |  |        if (!types[item.type]) {
 | 
											
												
													
														|  | -        types[item.type] = []
 |  | 
 | 
											
												
													
														|  | 
 |  | +        types[item.type] = [];
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  | -      types[item.type].push(item)
 |  | 
 | 
											
												
													
														|  | 
 |  | +      types[item.type].push(item);
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -    const typesKeys = Object.keys(types)
 |  | 
 | 
											
												
													
														|  | 
 |  | +    const typesKeys = Object.keys(types);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      for (const key of typesKeys) {
 |  |      for (const key of typesKeys) {
 | 
											
												
													
														|  |        for (const item of types[key]) {
 |  |        for (const item of types[key]) {
 | 
											
												
													
														|  | -        if (key === 'INSTRUMENT') {
 |  | 
 | 
											
												
													
														|  | -          let json = {}
 |  | 
 | 
											
												
													
														|  | -          let courseJson = {}
 |  | 
 | 
											
												
													
														|  | 
 |  | +        if (key === "INSTRUMENT") {
 | 
											
												
													
														|  | 
 |  | +          let json = {};
 | 
											
												
													
														|  | 
 |  | +          let courseJson = {};
 | 
											
												
													
														|  |            try {
 |  |            try {
 | 
											
												
													
														|  | -            json = JSON.parse(item.kitGroupPurchaseTypeJson)
 |  | 
 | 
											
												
													
														|  | 
 |  | +            json = JSON.parse(item.kitGroupPurchaseTypeJson);
 | 
											
												
													
														|  |            } catch (error) {}
 |  |            } catch (error) {}
 | 
											
												
													
														|  |            try {
 |  |            try {
 | 
											
												
													
														|  | -            courseJson = JSON.parse(item.coursePurchaseTypeJson)
 |  | 
 | 
											
												
													
														|  | 
 |  | +            courseJson = JSON.parse(item.coursePurchaseTypeJson);
 | 
											
												
													
														|  |            } catch (error) {}
 |  |            } catch (error) {}
 | 
											
												
													
														|  |            // if (json[kitGroupPurchaseType] !== undefined) {
 |  |            // if (json[kitGroupPurchaseType] !== undefined) {
 | 
											
												
													
														|  | -            const _item = {
 |  | 
 | 
											
												
													
														|  | -              ...item,
 |  | 
 | 
											
												
													
														|  | -              kitGroupPurchaseTypeJsonParse: json,
 |  | 
 | 
											
												
													
														|  | -              kitGroupPurchaseTypePrice: json[kitGroupPurchaseType] || 0,
 |  | 
 | 
											
												
													
														|  | -              coursePurchaseTypeJsonTypePrice: courseJson[kitGroupPurchaseType] || 0,
 |  | 
 | 
											
												
													
														|  | -              _calculated_price: (kitGroupPurchaseType === 'FREE' ? 0 : (kitGroupPurchaseType === 'LEASE' ? item.depositFee : item.price))
 |  | 
 | 
											
												
													
														|  | 
 |  | +          const _item = {
 | 
											
												
													
														|  | 
 |  | +            ...item,
 | 
											
												
													
														|  | 
 |  | +            kitGroupPurchaseTypeJsonParse: json,
 | 
											
												
													
														|  | 
 |  | +            kitGroupPurchaseTypePrice: json[kitGroupPurchaseType] || 0,
 | 
											
												
													
														|  | 
 |  | +            coursePurchaseTypeJsonTypePrice:
 | 
											
												
													
														|  | 
 |  | +              courseJson[kitGroupPurchaseType] || 0,
 | 
											
												
													
														|  | 
 |  | +            _calculated_price:
 | 
											
												
													
														|  | 
 |  | +              kitGroupPurchaseType === "FREE"
 | 
											
												
													
														|  | 
 |  | +                ? 0
 | 
											
												
													
														|  | 
 |  | +                : kitGroupPurchaseType === "LEASE"
 | 
											
												
													
														|  | 
 |  | +                ? item.depositFee
 | 
											
												
													
														|  | 
 |  | +                : item.price,
 | 
											
												
													
														|  | 
 |  | +          };
 | 
											
												
													
														|  | 
 |  | +          musicalGoods.push(_item);
 | 
											
												
													
														|  | 
 |  | +          musicalGoodsById[item.goodsIdList] = _item;
 | 
											
												
													
														|  | 
 |  | +          if (!types.ACCESSORIES) {
 | 
											
												
													
														|  | 
 |  | +            if (!accessoriesByGoods[item.goodsIdList]) {
 | 
											
												
													
														|  | 
 |  | +              accessoriesByGoods[item.goodsIdList] = [];
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  | -            musicalGoods.push(_item)
 |  | 
 | 
											
												
													
														|  | -            musicalGoodsById[item.goodsIdList] = _item
 |  | 
 | 
											
												
													
														|  | -            if (!types.ACCESSORIES) {
 |  | 
 | 
											
												
													
														|  | -              if (!accessoriesByGoods[item.goodsIdList]) {
 |  | 
 | 
											
												
													
														|  | -                accessoriesByGoods[item.goodsIdList] = []
 |  | 
 | 
											
												
													
														|  | -              }
 |  | 
 | 
											
												
													
														|  | -              const acs = item.goodsList[0].goodsList ? item.goodsList[0].goodsList : []
 |  | 
 | 
											
												
													
														|  | -              for (const goods of acs) {
 |  | 
 | 
											
												
													
														|  | -                accessoriesByGoods[item.goodsIdList].push(goods)
 |  | 
 | 
											
												
													
														|  | -                accessoriesById[goods.id] = goods
 |  | 
 | 
											
												
													
														|  | -              }
 |  | 
 | 
											
												
													
														|  | 
 |  | +            const acs = item.goodsList[0].goodsList
 | 
											
												
													
														|  | 
 |  | +              ? item.goodsList[0].goodsList
 | 
											
												
													
														|  | 
 |  | +              : [];
 | 
											
												
													
														|  | 
 |  | +            for (const goods of acs) {
 | 
											
												
													
														|  | 
 |  | +              accessoriesByGoods[item.goodsIdList].push(goods);
 | 
											
												
													
														|  | 
 |  | +              accessoriesById[goods.id] = goods;
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  |            // }
 |  |            // }
 | 
											
												
													
														|  | -        } else if (item.type === 'ACCESSORIES') {
 |  | 
 | 
											
												
													
														|  | -          groupList.push(item)
 |  | 
 | 
											
												
													
														|  | -          groupListById[item.id] = item
 |  | 
 | 
											
												
													
														|  | 
 |  | +        } else if (item.type === "ACCESSORIES") {
 | 
											
												
													
														|  | 
 |  | +          groupList.push(item);
 | 
											
												
													
														|  | 
 |  | +          groupListById[item.id] = item;
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
										
											
												
													
														|  | @@ -220,19 +268,19 @@ const formatAllGoods = (data, kitGroupPurchaseType) => {
 | 
											
												
													
														|  |      musicalGoodsById,
 |  |      musicalGoodsById,
 | 
											
												
													
														|  |      groupList,
 |  |      groupList,
 | 
											
												
													
														|  |      groupListById,
 |  |      groupListById,
 | 
											
												
													
														|  | -    accessoriesByGoods
 |  | 
 | 
											
												
													
														|  | -  }
 |  | 
 | 
											
												
													
														|  | -}
 |  | 
 | 
											
												
													
														|  | 
 |  | +    accessoriesByGoods,
 | 
											
												
													
														|  | 
 |  | +  };
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  const typeAndprice = {
 |  |  const typeAndprice = {
 | 
											
												
													
														|  | -  GROUP: 'price',
 |  | 
 | 
											
												
													
														|  | -  LEASE: 'depositFee',
 |  | 
 | 
											
												
													
														|  | -}
 |  | 
 | 
											
												
													
														|  | 
 |  | +  GROUP: "price",
 | 
											
												
													
														|  | 
 |  | +  LEASE: "depositFee",
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  export default {
 |  |  export default {
 | 
											
												
													
														|  | -  props: ['detail', 'musicGroupId', 'voiceList'],
 |  | 
 | 
											
												
													
														|  | 
 |  | +  props: ["detail", "musicGroupId", "voiceList"],
 | 
											
												
													
														|  |    components: {
 |  |    components: {
 | 
											
												
													
														|  | -    accessories
 |  | 
 | 
											
												
													
														|  | 
 |  | +    accessories,
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  |    data() {
 |  |    data() {
 | 
											
												
													
														|  |      return {
 |  |      return {
 | 
											
										
											
												
													
														|  | @@ -252,76 +300,87 @@ export default {
 | 
											
												
													
														|  |        kitGroupPurchaseTypePrice: 0,
 |  |        kitGroupPurchaseTypePrice: 0,
 | 
											
												
													
														|  |        coursePurchaseTypeJsonTypePrice: 0,
 |  |        coursePurchaseTypeJsonTypePrice: 0,
 | 
											
												
													
														|  |        form: {
 |  |        form: {
 | 
											
												
													
														|  | -        subjectId: '',
 |  | 
 | 
											
												
													
														|  | -        accessories: '',
 |  | 
 | 
											
												
													
														|  | -        musicalGoods: '',
 |  | 
 | 
											
												
													
														|  | -        type: '',
 |  | 
 | 
											
												
													
														|  | 
 |  | +        subjectId: "",
 | 
											
												
													
														|  | 
 |  | +        accessories: "",
 | 
											
												
													
														|  | 
 |  | +        musicalGoods: "",
 | 
											
												
													
														|  | 
 |  | +        type: "",
 | 
											
												
													
														|  |        },
 |  |        },
 | 
											
												
													
														|  |        rules: {},
 |  |        rules: {},
 | 
											
												
													
														|  |        item: {},
 |  |        item: {},
 | 
											
												
													
														|  | -      originalMusicalGoods: '',
 |  | 
 | 
											
												
													
														|  | -      originalAccessoriesGoods: '',
 |  | 
 | 
											
												
													
														|  | 
 |  | +      originalMusicalGoods: "",
 | 
											
												
													
														|  | 
 |  | +      originalAccessoriesGoods: "",
 | 
											
												
													
														|  |        originalAccessoriesPrice: 0,
 |  |        originalAccessoriesPrice: 0,
 | 
											
												
													
														|  |        originalMusicalPrice: 0,
 |  |        originalMusicalPrice: 0,
 | 
											
												
													
														|  |        originalCourseFee: 0,
 |  |        originalCourseFee: 0,
 | 
											
												
													
														|  |        musicGroupSubjectPlanFee: 0,
 |  |        musicGroupSubjectPlanFee: 0,
 | 
											
												
													
														|  |        musicalPrice: 0,
 |  |        musicalPrice: 0,
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  | 
 |  | +    };
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  |    watch: {
 |  |    watch: {
 | 
											
												
													
														|  |      detail() {
 |  |      detail() {
 | 
											
												
													
														|  |        if (this.detail) {
 |  |        if (this.detail) {
 | 
											
												
													
														|  | -        this.fetchDetail()
 |  | 
 | 
											
												
													
														|  | 
 |  | +        this.fetchDetail();
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  | -    'form.musicalGoods'() {
 |  | 
 | 
											
												
													
														|  | -      this.$set(this.form, 'type', '')
 |  | 
 | 
											
												
													
														|  | 
 |  | +    "form.musicalGoods"() {
 | 
											
												
													
														|  | 
 |  | +      this.$set(this.form, "type", "");
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  | 
 |  | +    "form.type"() {
 | 
											
												
													
														|  | 
 |  | +      this.musicalGoodsChange(this.form.musicalGoods);
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  | -    'form.type'() {
 |  | 
 | 
											
												
													
														|  | -      this.musicalGoodsChange(this.form.musicalGoods)
 |  | 
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  |    computed: {
 |  |    computed: {
 | 
											
												
													
														|  |      copyLink() {
 |  |      copyLink() {
 | 
											
												
													
														|  |        if (this.changeInfo) {
 |  |        if (this.changeInfo) {
 | 
											
												
													
														|  | -        return vaildStudentUrl() + '/#/change-voice?id=' + this.changeInfo.id
 |  | 
 | 
											
												
													
														|  | 
 |  | +        return vaildStudentUrl() + "/#/change-voice?id=" + this.changeInfo.id;
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  | -      return ''
 |  | 
 | 
											
												
													
														|  | 
 |  | +      return "";
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      filterVoiceList() {
 |  |      filterVoiceList() {
 | 
											
												
													
														|  | -      return this.voiceList.filter(item => item.subjectId != this.detail.subjectId)
 |  | 
 | 
											
												
													
														|  | 
 |  | +      return this.voiceList.filter(
 | 
											
												
													
														|  | 
 |  | +        (item) => item.subjectId != this.detail.subjectId
 | 
											
												
													
														|  | 
 |  | +      );
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      activeAccessories() {
 |  |      activeAccessories() {
 | 
											
												
													
														|  | -      const { musicalGoods } = this.form || {}
 |  | 
 | 
											
												
													
														|  | -      return musicalGoods ? this.accessoriesByGoods[musicalGoods] || [] : []
 |  | 
 | 
											
												
													
														|  | 
 |  | +      const { musicalGoods } = this.form || {};
 | 
											
												
													
														|  | 
 |  | +      return musicalGoods ? this.accessoriesByGoods[musicalGoods] || [] : [];
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      changeSubjectName() {
 |  |      changeSubjectName() {
 | 
											
												
													
														|  | -      let name = ''
 |  | 
 | 
											
												
													
														|  | 
 |  | +      let name = "";
 | 
											
												
													
														|  |        if (this.item.changeSubjectId) {
 |  |        if (this.item.changeSubjectId) {
 | 
											
												
													
														|  |          for (const item of this.voiceList) {
 |  |          for (const item of this.voiceList) {
 | 
											
												
													
														|  |            if (item.subjectId === this.item.changeSubjectId) {
 |  |            if (item.subjectId === this.item.changeSubjectId) {
 | 
											
												
													
														|  | -            name = item.subjectName
 |  | 
 | 
											
												
													
														|  | -            break
 |  | 
 | 
											
												
													
														|  | 
 |  | +            name = item.subjectName;
 | 
											
												
													
														|  | 
 |  | +            break;
 | 
											
												
													
														|  |            }
 |  |            }
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  | -      return name
 |  | 
 | 
											
												
													
														|  | 
 |  | +      return name;
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      changeAccessoriesGoods() {
 |  |      changeAccessoriesGoods() {
 | 
											
												
													
														|  | -      const subjectChange = this.changeInfo || {}
 |  | 
 | 
											
												
													
														|  | -      const items = (subjectChange.changeAccessoriesGoods || []).map(item => item.name).join(',')
 |  | 
 | 
											
												
													
														|  | -      return items || '未选择教辅'
 |  | 
 | 
											
												
													
														|  | 
 |  | +      const subjectChange = this.changeInfo || {};
 | 
											
												
													
														|  | 
 |  | +      const items = (subjectChange.changeAccessoriesGoods || [])
 | 
											
												
													
														|  | 
 |  | +        .map((item) => item.name)
 | 
											
												
													
														|  | 
 |  | +        .join(",");
 | 
											
												
													
														|  | 
 |  | +      return items || "未选择教辅";
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      editSpread() {
 |  |      editSpread() {
 | 
											
												
													
														|  | -      const data = this.changeInfo || {}
 |  | 
 | 
											
												
													
														|  | -      const payed = (data.originalAccessoriesPrice || 0) + (data.originalCourseFee || 0) + (data.originalMusicalPrice || 0)
 |  | 
 | 
											
												
													
														|  | 
 |  | +      const data = this.changeInfo || {};
 | 
											
												
													
														|  | 
 |  | +      const payed =
 | 
											
												
													
														|  | 
 |  | +        (data.originalAccessoriesPrice || 0) +
 | 
											
												
													
														|  | 
 |  | +        (data.originalCourseFee || 0) +
 | 
											
												
													
														|  | 
 |  | +        (data.originalMusicalPrice || 0);
 | 
											
												
													
														|  |        // console.log(payed, data.changeMusicalPrice, data.changeAccessoriesPrice, data.changeCourseFee, {...data})
 |  |        // console.log(payed, data.changeMusicalPrice, data.changeAccessoriesPrice, data.changeCourseFee, {...data})
 | 
											
												
													
														|  | -      return (data.changeMusicalPrice || 0) + (data.changeAccessoriesPrice || 0) + (data.changeCourseFee || 0) - payed
 |  | 
 | 
											
												
													
														|  | 
 |  | +      return (
 | 
											
												
													
														|  | 
 |  | +        (data.changeMusicalPrice || 0) +
 | 
											
												
													
														|  | 
 |  | +        (data.changeAccessoriesPrice || 0) +
 | 
											
												
													
														|  | 
 |  | +        (data.changeCourseFee || 0) -
 | 
											
												
													
														|  | 
 |  | +        payed
 | 
											
												
													
														|  | 
 |  | +      );
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      spread() {
 |  |      spread() {
 | 
											
												
													
														|  | -      const money = (
 |  | 
 | 
											
												
													
														|  | -        this.numFormat(
 |  | 
 | 
											
												
													
														|  | -          this.musicalPrice +
 |  | 
 | 
											
												
													
														|  | 
 |  | +      const money = this.numFormat(
 | 
											
												
													
														|  | 
 |  | +        this.musicalPrice +
 | 
											
												
													
														|  |            this.selectAccessoriesMoney +
 |  |            this.selectAccessoriesMoney +
 | 
											
												
													
														|  |            this.musicGroupSubjectPlanFee -
 |  |            this.musicGroupSubjectPlanFee -
 | 
											
												
													
														|  |            this.originalAccessoriesPrice -
 |  |            this.originalAccessoriesPrice -
 | 
											
										
											
												
													
														|  | @@ -329,8 +388,7 @@ export default {
 | 
											
												
													
														|  |            this.originalCourseFee -
 |  |            this.originalCourseFee -
 | 
											
												
													
														|  |            this.coursePurchaseTypeJsonTypePrice -
 |  |            this.coursePurchaseTypeJsonTypePrice -
 | 
											
												
													
														|  |            this.kitGroupPurchaseTypePrice
 |  |            this.kitGroupPurchaseTypePrice
 | 
											
												
													
														|  | -        )
 |  | 
 | 
											
												
													
														|  | -      )
 |  | 
 | 
											
												
													
														|  | 
 |  | +      );
 | 
											
												
													
														|  |        // console.log(
 |  |        // console.log(
 | 
											
												
													
														|  |        //   this.item.kitGroupPurchaseType,
 |  |        //   this.item.kitGroupPurchaseType,
 | 
											
												
													
														|  |        //   '乐器价格', this.musicalPrice,
 |  |        //   '乐器价格', this.musicalPrice,
 | 
											
										
											
												
													
														|  | @@ -343,118 +401,127 @@ export default {
 | 
											
												
													
														|  |        //   '乐器减免费用', this.kitGroupPurchaseTypePrice,
 |  |        //   '乐器减免费用', this.kitGroupPurchaseTypePrice,
 | 
											
												
													
														|  |        //   '结果价格', money
 |  |        //   '结果价格', money
 | 
											
												
													
														|  |        // )
 |  |        // )
 | 
											
												
													
														|  | -      return money
 |  | 
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  | 
 |  | +      return money;
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  |    mounted() {
 |  |    mounted() {
 | 
											
												
													
														|  |      if (this.detail && this.detail.id) {
 |  |      if (this.detail && this.detail.id) {
 | 
											
												
													
														|  | -      this.fetchDetail()
 |  | 
 | 
											
												
													
														|  | 
 |  | +      this.fetchDetail();
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  |    methods: {
 |  |    methods: {
 | 
											
												
													
														|  |      copyUrl(url) {
 |  |      copyUrl(url) {
 | 
											
												
													
														|  | -      copy(url)
 |  | 
 | 
											
												
													
														|  | -      this.$message.success('复制成功')
 |  | 
 | 
											
												
													
														|  | 
 |  | +      copy(url);
 | 
											
												
													
														|  | 
 |  | +      this.$message.success("复制成功");
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      async fetchDetail() {
 |  |      async fetchDetail() {
 | 
											
												
													
														|  | -      const setRes = res => {
 |  | 
 | 
											
												
													
														|  | -        const { data } = res
 |  | 
 | 
											
												
													
														|  | -        this.item = data || {}
 |  | 
 | 
											
												
													
														|  | 
 |  | +      const setRes = (res) => {
 | 
											
												
													
														|  | 
 |  | +        const { data } = res;
 | 
											
												
													
														|  | 
 |  | +        this.item = data || {};
 | 
											
												
													
														|  | 
 |  | +        console.log(this.item, "item");
 | 
											
												
													
														|  |          if (data) {
 |  |          if (data) {
 | 
											
												
													
														|  | -          this.$set(this.form, 'type', this.item.kitGroupPurchaseType)
 |  | 
 | 
											
												
													
														|  | -          this.originalAccessoriesPrice = data.originalAccessoriesPrice
 |  | 
 | 
											
												
													
														|  | -          this.originalMusicalPrice = data.originalMusicalPrice
 |  | 
 | 
											
												
													
														|  | -          this.originalCourseFee = data.originalCourseFee
 |  | 
 | 
											
												
													
														|  | -          this.originalMusicalGoods = data.originalMusicalGoods && data.originalMusicalGoods.name
 |  | 
 | 
											
												
													
														|  | -          this.originalAccessoriesGoods = (data.originalAccessoriesGoods || []).map(item => item.name).join()
 |  | 
 | 
											
												
													
														|  | 
 |  | +          this.$set(this.form, "type", this.item.kitGroupPurchaseType);
 | 
											
												
													
														|  | 
 |  | +          this.originalAccessoriesPrice = data.originalAccessoriesPrice;
 | 
											
												
													
														|  | 
 |  | +          this.originalMusicalPrice = data.originalMusicalPrice;
 | 
											
												
													
														|  | 
 |  | +          this.originalCourseFee = data.originalCourseFee;
 | 
											
												
													
														|  | 
 |  | +          this.originalMusicalGoods =
 | 
											
												
													
														|  | 
 |  | +            data.originalMusicalGoods && data.originalMusicalGoods.name;
 | 
											
												
													
														|  | 
 |  | +          this.originalAccessoriesGoods = (data.originalAccessoriesGoods || [])
 | 
											
												
													
														|  | 
 |  | +            .map((item) => item.name)
 | 
											
												
													
														|  | 
 |  | +            .join();
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  | -      }
 |  | 
 | 
											
												
													
														|  | 
 |  | +      };
 | 
											
												
													
														|  |        if (this.detail.subjectChange) {
 |  |        if (this.detail.subjectChange) {
 | 
											
												
													
														|  |          await getChangeInfo({
 |  |          await getChangeInfo({
 | 
											
												
													
														|  | -          id: this.detail.subjectChange.id
 |  | 
 | 
											
												
													
														|  | -        })
 |  | 
 | 
											
												
													
														|  | -        .then(res => {
 |  | 
 | 
											
												
													
														|  | -          setRes(res)
 |  | 
 | 
											
												
													
														|  | -          this.changeInfo = res.data
 |  | 
 | 
											
												
													
														|  | -        })
 |  | 
 | 
											
												
													
														|  | 
 |  | +          id: this.detail.subjectChange.id,
 | 
											
												
													
														|  | 
 |  | +        }).then((res) => {
 | 
											
												
													
														|  | 
 |  | +          setRes(res);
 | 
											
												
													
														|  | 
 |  | +          this.changeInfo = res.data;
 | 
											
												
													
														|  | 
 |  | +        });
 | 
											
												
													
														|  |        } else {
 |  |        } else {
 | 
											
												
													
														|  | -        this.changeInfo = this.detail.subjectChange
 |  | 
 | 
											
												
													
														|  | 
 |  | +        this.changeInfo = this.detail.subjectChange;
 | 
											
												
													
														|  |          await getStudentOriginal({
 |  |          await getStudentOriginal({
 | 
											
												
													
														|  |            musicGroupId: this.musicGroupId,
 |  |            musicGroupId: this.musicGroupId,
 | 
											
												
													
														|  |            studentId: this.detail.studentId,
 |  |            studentId: this.detail.studentId,
 | 
											
												
													
														|  | -        })
 |  | 
 | 
											
												
													
														|  | -        .then(setRes)
 |  | 
 | 
											
												
													
														|  | 
 |  | +        }).then(setRes);
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      async subjectChange(id) {
 |  |      async subjectChange(id) {
 | 
											
												
													
														|  | -      this.$set(this.form, 'musicalGoods', '')
 |  | 
 | 
											
												
													
														|  | -      let data = null
 |  | 
 | 
											
												
													
														|  | 
 |  | +      this.$set(this.form, "musicalGoods", "");
 | 
											
												
													
														|  | 
 |  | +      let data = null;
 | 
											
												
													
														|  |        if (id) {
 |  |        if (id) {
 | 
											
												
													
														|  |          await getSubjectGoodsAndInfo({
 |  |          await getSubjectGoodsAndInfo({
 | 
											
												
													
														|  |            musicGroupId: this.musicGroupId,
 |  |            musicGroupId: this.musicGroupId,
 | 
											
												
													
														|  |            subjectId: id,
 |  |            subjectId: id,
 | 
											
												
													
														|  | -        })
 |  | 
 | 
											
												
													
														|  | -        .then(res => {
 |  | 
 | 
											
												
													
														|  | -          data = res.data
 |  | 
 | 
											
												
													
														|  | -          this.musicGroupSubjectPlanFee = res.data.musicGroupSubjectPlan.fee
 |  | 
 | 
											
												
													
														|  | -        })
 |  | 
 | 
											
												
													
														|  | 
 |  | +        }).then((res) => {
 | 
											
												
													
														|  | 
 |  | +          data = res.data;
 | 
											
												
													
														|  | 
 |  | +          this.musicGroupSubjectPlanFee = res.data.musicGroupSubjectPlan.fee;
 | 
											
												
													
														|  | 
 |  | +        });
 | 
											
												
													
														|  |        } else {
 |  |        } else {
 | 
											
												
													
														|  | -        this.musicGroupSubjectPlanFee = 0
 |  | 
 | 
											
												
													
														|  | 
 |  | +        this.musicGroupSubjectPlanFee = 0;
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  | -      const items = formatAllGoods(data, this.item.kitGroupPurchaseType)
 |  | 
 | 
											
												
													
														|  | 
 |  | +      const items = formatAllGoods(data, this.item.kitGroupPurchaseType);
 | 
											
												
													
														|  |        for (const key in items) {
 |  |        for (const key in items) {
 | 
											
												
													
														|  |          if (items.hasOwnProperty(key)) {
 |  |          if (items.hasOwnProperty(key)) {
 | 
											
												
													
														|  | -          const item = items[key]
 |  | 
 | 
											
												
													
														|  | -          this[key] = item
 |  | 
 | 
											
												
													
														|  | 
 |  | +          const item = items[key];
 | 
											
												
													
														|  | 
 |  | +          this[key] = item;
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  | -      this.musicalGoodsChange()
 |  | 
 | 
											
												
													
														|  | 
 |  | +      this.musicalGoodsChange();
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      musicalGoodsChange(val) {
 |  |      musicalGoodsChange(val) {
 | 
											
												
													
														|  | -      const item = this.musicalGoodsById[val]
 |  | 
 | 
											
												
													
														|  | 
 |  | +      const item = this.musicalGoodsById[val];
 | 
											
												
													
														|  |        if (item) {
 |  |        if (item) {
 | 
											
												
													
														|  | -        this.musicalPrice = this.numFormat(item[typeAndprice[this.form.type]] || 0)
 |  | 
 | 
											
												
													
														|  | 
 |  | +        this.musicalPrice = this.numFormat(
 | 
											
												
													
														|  | 
 |  | +          item[typeAndprice[this.form.type]] || 0
 | 
											
												
													
														|  | 
 |  | +        );
 | 
											
												
													
														|  |          // this.kitGroupPurchaseTypePrice = this.numFormat(item[typeAndprice[this.form.type]] || 0)
 |  |          // this.kitGroupPurchaseTypePrice = this.numFormat(item[typeAndprice[this.form.type]] || 0)
 | 
											
												
													
														|  | -        this.coursePurchaseTypeJsonTypePrice = this.numFormat(item.coursePurchaseTypeJsonTypePrice)
 |  | 
 | 
											
												
													
														|  | -        this.types = item.kitGroupPurchaseTypeJsonParse
 |  | 
 | 
											
												
													
														|  | 
 |  | +        this.coursePurchaseTypeJsonTypePrice = this.numFormat(
 | 
											
												
													
														|  | 
 |  | +          item.coursePurchaseTypeJsonTypePrice
 | 
											
												
													
														|  | 
 |  | +        );
 | 
											
												
													
														|  | 
 |  | +        this.types = item.kitGroupPurchaseTypeJsonParse;
 | 
											
												
													
														|  |        } else {
 |  |        } else {
 | 
											
												
													
														|  | -        this.musicalPrice = 0
 |  | 
 | 
											
												
													
														|  | 
 |  | +        this.musicalPrice = 0;
 | 
											
												
													
														|  |          // this.kitGroupPurchaseTypePrice = 0
 |  |          // this.kitGroupPurchaseTypePrice = 0
 | 
											
												
													
														|  | -        this.coursePurchaseTypeJsonTypePrice = 0
 |  | 
 | 
											
												
													
														|  | -        this.$set(this.form, 'type', '')
 |  | 
 | 
											
												
													
														|  | 
 |  | +        this.coursePurchaseTypeJsonTypePrice = 0;
 | 
											
												
													
														|  | 
 |  | +        this.$set(this.form, "type", "");
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      accessoriesChange(ids, money) {
 |  |      accessoriesChange(ids, money) {
 | 
											
												
													
														|  | -      this.selectAccessories = ids
 |  | 
 | 
											
												
													
														|  | -      this.selectAccessoriesMoney = money
 |  | 
 | 
											
												
													
														|  | 
 |  | +      this.selectAccessories = ids;
 | 
											
												
													
														|  | 
 |  | +      this.selectAccessoriesMoney = money;
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      numFormat(num) {
 |  |      numFormat(num) {
 | 
											
												
													
														|  | -      let _num = parseFloat(num)
 |  | 
 | 
											
												
													
														|  | 
 |  | +      let _num = parseFloat(num);
 | 
											
												
													
														|  |        if (isNaN(_num)) {
 |  |        if (isNaN(_num)) {
 | 
											
												
													
														|  | -        _num = 0
 |  | 
 | 
											
												
													
														|  | 
 |  | +        _num = 0;
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  | -      return parseFloat(_num.toFixed(2))
 |  | 
 | 
											
												
													
														|  | 
 |  | +      return parseFloat(_num.toFixed(2));
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  | -    onCreateQRCode () {
 |  | 
 | 
											
												
													
														|  | 
 |  | +    onCreateQRCode() {
 | 
											
												
													
														|  |        setTimeout(() => {
 |  |        setTimeout(() => {
 | 
											
												
													
														|  | -        this.$refs.qrCodeUrl.innerHTML = '';
 |  | 
 | 
											
												
													
														|  | 
 |  | +        this.$refs.qrCodeUrl.innerHTML = "";
 | 
											
												
													
														|  |          this.qrcode = new QRCode(this.$refs.qrCodeUrl, {
 |  |          this.qrcode = new QRCode(this.$refs.qrCodeUrl, {
 | 
											
												
													
														|  |            width: 200,
 |  |            width: 200,
 | 
											
												
													
														|  |            height: 200,
 |  |            height: 200,
 | 
											
												
													
														|  | -          colorDark: '#000000',
 |  | 
 | 
											
												
													
														|  | -          colorLight: '#ffffff',
 |  | 
 | 
											
												
													
														|  | -          correctLevel: QRCode.CorrectLevel.H
 |  | 
 | 
											
												
													
														|  | -        })
 |  | 
 | 
											
												
													
														|  | -        this.qrcode.makeCode(this.copyLink)
 |  | 
 | 
											
												
													
														|  | -        this.codeUrl = this.copyLink
 |  | 
 | 
											
												
													
														|  | -      }, 500)
 |  | 
 | 
											
												
													
														|  | 
 |  | +          colorDark: "#000000",
 | 
											
												
													
														|  | 
 |  | +          colorLight: "#ffffff",
 | 
											
												
													
														|  | 
 |  | +          correctLevel: QRCode.CorrectLevel.H,
 | 
											
												
													
														|  | 
 |  | +        });
 | 
											
												
													
														|  | 
 |  | +        this.qrcode.makeCode(this.copyLink);
 | 
											
												
													
														|  | 
 |  | +        this.codeUrl = this.copyLink;
 | 
											
												
													
														|  | 
 |  | +      }, 500);
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      submit() {
 |  |      submit() {
 | 
											
												
													
														|  | -      this.$refs['form'].validate((valid) => {
 |  | 
 | 
											
												
													
														|  | 
 |  | +      this.$refs["form"].validate((valid) => {
 | 
											
												
													
														|  |          if (valid) {
 |  |          if (valid) {
 | 
											
												
													
														|  | 
 |  | +          console.log(this.item)
 | 
											
												
													
														|  |            subjectChangeAdd({
 |  |            subjectChangeAdd({
 | 
											
												
													
														|  | -            changeCourseFee: this.numFormat(this.musicGroupSubjectPlanFee - this.coursePurchaseTypeJsonTypePrice),
 |  | 
 | 
											
												
													
														|  | -            changeAccessories: this.selectAccessories.join(','),
 |  | 
 | 
											
												
													
														|  | 
 |  | +            changeCourseFee: this.numFormat(
 | 
											
												
													
														|  | 
 |  | +              this.musicGroupSubjectPlanFee -
 | 
											
												
													
														|  | 
 |  | +                this.coursePurchaseTypeJsonTypePrice
 | 
											
												
													
														|  | 
 |  | +            ),
 | 
											
												
													
														|  | 
 |  | +            changeAccessories: this.selectAccessories.join(","),
 | 
											
												
													
														|  |              changeAccessoriesPrice: this.numFormat(this.selectAccessoriesMoney),
 |  |              changeAccessoriesPrice: this.numFormat(this.selectAccessoriesMoney),
 | 
											
												
													
														|  |              changeMusicalPrice: this.numFormat(this.musicalPrice),
 |  |              changeMusicalPrice: this.numFormat(this.musicalPrice),
 | 
											
												
													
														|  |              originalCourseFee: this.originalCourseFee,
 |  |              originalCourseFee: this.originalCourseFee,
 | 
											
										
											
												
													
														|  | @@ -463,67 +530,68 @@ export default {
 | 
											
												
													
														|  |              originalAccessories: this.item.originalAccessories,
 |  |              originalAccessories: this.item.originalAccessories,
 | 
											
												
													
														|  |              originalAccessoriesPrice: this.originalAccessoriesPrice,
 |  |              originalAccessoriesPrice: this.originalAccessoriesPrice,
 | 
											
												
													
														|  |              cooperationOrganId: this.item.cooperationOrganId,
 |  |              cooperationOrganId: this.item.cooperationOrganId,
 | 
											
												
													
														|  | -            kitGroupPurchaseType: (this.form.musicalGoods === 'OWNED' ? this.form.musicalGoods : this.form.type),
 |  | 
 | 
											
												
													
														|  | 
 |  | +            kitGroupPurchaseType:
 | 
											
												
													
														|  | 
 |  | +              this.form.musicalGoods === "OWNED"
 | 
											
												
													
														|  | 
 |  | +                ? this.form.musicalGoods
 | 
											
												
													
														|  | 
 |  | +                : this.form.type,
 | 
											
												
													
														|  |              musicGroupId: this.musicGroupId,
 |  |              musicGroupId: this.musicGroupId,
 | 
											
												
													
														|  |              studentId: this.detail.studentId,
 |  |              studentId: this.detail.studentId,
 | 
											
												
													
														|  | -            changeMusical: (this.form.musicalGoods === 'OWNED' ? 0 : this.form.musicalGoods),
 |  | 
 | 
											
												
													
														|  | 
 |  | +            changeMusical:
 | 
											
												
													
														|  | 
 |  | +              this.form.musicalGoods === "OWNED" ? 0 : this.form.musicalGoods,
 | 
											
												
													
														|  |              originalCost: this.item.originalCost,
 |  |              originalCost: this.item.originalCost,
 | 
											
												
													
														|  |              organId: this.item.organId,
 |  |              organId: this.item.organId,
 | 
											
												
													
														|  |              originalSubjectId: this.detail.actualSubjectId,
 |  |              originalSubjectId: this.detail.actualSubjectId,
 | 
											
												
													
														|  |              changeSubjectId: this.form.subjectId,
 |  |              changeSubjectId: this.form.subjectId,
 | 
											
												
													
														|  | -          })
 |  | 
 | 
											
												
													
														|  | -            .then(res => {
 |  | 
 | 
											
												
													
														|  | -              this.$listeners.close()
 |  | 
 | 
											
												
													
														|  | -              this.$listeners.submited()
 |  | 
 | 
											
												
													
														|  | -              this.$message.success('提交成功!')
 |  | 
 | 
											
												
													
														|  | -            })
 |  | 
 | 
											
												
													
														|  | 
 |  | +          }).then((res) => {
 | 
											
												
													
														|  | 
 |  | +            this.$listeners.close();
 | 
											
												
													
														|  | 
 |  | +            this.$listeners.submited();
 | 
											
												
													
														|  | 
 |  | +            this.$message.success("提交成功!");
 | 
											
												
													
														|  | 
 |  | +          });
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  | -      })
 |  | 
 | 
											
												
													
														|  | 
 |  | +      });
 | 
											
												
													
														|  |      },
 |  |      },
 | 
											
												
													
														|  |      cancel() {
 |  |      cancel() {
 | 
											
												
													
														|  | -      this.$confirm('是否确认取消订单?', '提示', {
 |  | 
 | 
											
												
													
														|  | -        onfirmButtonText: '确定',
 |  | 
 | 
											
												
													
														|  | -        cancelButtonText: '取消',
 |  | 
 | 
											
												
													
														|  | -        type: 'warning'
 |  | 
 | 
											
												
													
														|  | -      })
 |  | 
 | 
											
												
													
														|  | -      .then(() => {
 |  | 
 | 
											
												
													
														|  | 
 |  | +      this.$confirm("是否确认取消订单?", "提示", {
 | 
											
												
													
														|  | 
 |  | +        onfirmButtonText: "确定",
 | 
											
												
													
														|  | 
 |  | +        cancelButtonText: "取消",
 | 
											
												
													
														|  | 
 |  | +        type: "warning",
 | 
											
												
													
														|  | 
 |  | +      }).then(() => {
 | 
											
												
													
														|  |          subjectChangeCancel({
 |  |          subjectChangeCancel({
 | 
											
												
													
														|  | -          id: this.detail.subjectChange.id
 |  | 
 | 
											
												
													
														|  | -        })
 |  | 
 | 
											
												
													
														|  | -        .then(res => {
 |  | 
 | 
											
												
													
														|  | -          this.$listeners.close()
 |  | 
 | 
											
												
													
														|  | -          this.$listeners.submited()
 |  | 
 | 
											
												
													
														|  | -          this.$message.success('取消成功!')
 |  | 
 | 
											
												
													
														|  | -        })
 |  | 
 | 
											
												
													
														|  | -      })
 |  | 
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  | 
 |  | +          id: this.detail.subjectChange.id,
 | 
											
												
													
														|  | 
 |  | +        }).then((res) => {
 | 
											
												
													
														|  | 
 |  | +          this.$listeners.close();
 | 
											
												
													
														|  | 
 |  | +          this.$listeners.submited();
 | 
											
												
													
														|  | 
 |  | +          this.$message.success("取消成功!");
 | 
											
												
													
														|  | 
 |  | +        });
 | 
											
												
													
														|  | 
 |  | +      });
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  | -}
 |  | 
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  |  </script>
 |  |  </script>
 | 
											
												
													
														|  |  <style lang="less" scoped>
 |  |  <style lang="less" scoped>
 | 
											
												
													
														|  | -  .viewlink{
 |  | 
 | 
											
												
													
														|  | -    display: flex;
 |  | 
 | 
											
												
													
														|  | -    .link{
 |  | 
 | 
											
												
													
														|  | -      flex: 1;
 |  | 
 | 
											
												
													
														|  | -      overflow: hidden;
 |  | 
 | 
											
												
													
														|  | -      text-overflow: ellipsis;
 |  | 
 | 
											
												
													
														|  | -      display: block;
 |  | 
 | 
											
												
													
														|  | -      white-space: nowrap;
 |  | 
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  | -    .btn{
 |  | 
 | 
											
												
													
														|  | -      width: 100px;
 |  | 
 | 
											
												
													
														|  | -      margin-left: 20px;
 |  | 
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  | 
 |  | +.viewlink {
 | 
											
												
													
														|  | 
 |  | +  display: flex;
 | 
											
												
													
														|  | 
 |  | +  .link {
 | 
											
												
													
														|  | 
 |  | +    flex: 1;
 | 
											
												
													
														|  | 
 |  | +    overflow: hidden;
 | 
											
												
													
														|  | 
 |  | +    text-overflow: ellipsis;
 | 
											
												
													
														|  | 
 |  | +    display: block;
 | 
											
												
													
														|  | 
 |  | +    white-space: nowrap;
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  | -  .left-code{
 |  | 
 | 
											
												
													
														|  | -    height: 255px;
 |  | 
 | 
											
												
													
														|  | -    .code-url{
 |  | 
 | 
											
												
													
														|  | -      margin-top: 10px;
 |  | 
 | 
											
												
													
														|  | -      .linkbtn{
 |  | 
 | 
											
												
													
														|  | -        margin-top: 0;
 |  | 
 | 
											
												
													
														|  | -        margin-bottom: 0;
 |  | 
 | 
											
												
													
														|  | -        font-size: 12px;
 |  | 
 | 
											
												
													
														|  | -      }
 |  | 
 | 
											
												
													
														|  | 
 |  | +  .btn {
 | 
											
												
													
														|  | 
 |  | +    width: 100px;
 | 
											
												
													
														|  | 
 |  | +    margin-left: 20px;
 | 
											
												
													
														|  | 
 |  | +  }
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +.left-code {
 | 
											
												
													
														|  | 
 |  | +  height: 255px;
 | 
											
												
													
														|  | 
 |  | +  .code-url {
 | 
											
												
													
														|  | 
 |  | +    margin-top: 10px;
 | 
											
												
													
														|  | 
 |  | +    .linkbtn {
 | 
											
												
													
														|  | 
 |  | +      margin-top: 0;
 | 
											
												
													
														|  | 
 |  | +      margin-bottom: 0;
 | 
											
												
													
														|  | 
 |  | +      font-size: 12px;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  |  </style>
 |  |  </style>
 |