Quote.vue 44 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385
  1. <template>
  2. <div>
  3. <div
  4. v-if="quoteLoadState == 0"
  5. v-loading="true"
  6. class="com-loading"></div>
  7. <div v-else-if="quoteLoadState == 1">
  8. <tab-nav
  9. :borderType="'allBorder'" :liWidth="100" :liHeight="40" :marginRight="5"
  10. :currTab.sync="curWeek"
  11. :tabList="priceList" />
  12. <div
  13. v-for="(items, indexs) in priceList"
  14. :key="items.name"
  15. v-show="curWeek == indexs">
  16. <div>
  17. <tab-nav
  18. :borderType="'incompleteBorder'"
  19. :currTab.sync="items.curPrint"
  20. :tabList="items.basePrice"
  21. :allPrintTab="allPrintTab"
  22. :marginTop="0"
  23. :marginRight="5"
  24. :marginBottom="items.basePrice?.length>1?7:0"
  25. @handle="sortBy(items)" />
  26. <!-- <el-popover
  27. placement="bottom-start"
  28. trigger="hover">
  29. <div
  30. class="exclamation-icon"
  31. slot="reference">!</div>
  32. <div class="popover">
  33. <p class="title">Print Price Comparison</p>
  34. <div
  35. v-for="(item,index) in items.basePrice"
  36. :key="item.name">
  37. <total-table
  38. :tableColumns="[...undecorated_columns, ...items.part_columns]"
  39. :tableData="item.data"
  40. :tableType="'Comparison'"
  41. :title="item.name"
  42. :curDecoration="items.decorationOrign[items.curPrint]" :indexDecoration="items.decorationOrign[index]"></total-table>
  43. </div>
  44. </div>
  45. </el-popover> -->
  46. </div>
  47. <div
  48. v-for="(item, index) in items.basePrice"
  49. :key="item.name"
  50. v-show="items.curPrint == index">
  51. <new-price-table
  52. :tableColumns="[...undecorated_columns, ...item.part_columns]"
  53. :tableData="item.data"
  54. :tableType="'Undecorated'"
  55. :curPrint="item.name"
  56. :curModel="items.decorationOrign[index]?.model"
  57. :data="items"
  58. :selectRow.sync="item.selectBaseRow"></new-price-table>
  59. </div>
  60. <!-- decoration_multiple is_more_print 打印开关,ID1001092需求 ;additional_print 颜色数量开关
  61. 以上需求作废,改版为多色多面的需求-->
  62. <new-price-table
  63. v-if="items.decoration?.length || items.basePrice?.[items.curPrint]?.decoration_addition?.length"
  64. :tableData="items.decoration"
  65. :tableColumns="[...decoration_columns, ...comCurBaseColumns]"
  66. :tableType="'Decoration'"
  67. :marginBottom="0"
  68. :hasDecAdd="items.basePrice?.[items.curPrint]?.decoration_addition?.length"></new-price-table>
  69. <div
  70. v-for="(item, index) in items.basePrice"
  71. :key="item.name + index"
  72. v-show="items.curPrint == index && item.decoration_addition.length">
  73. <new-price-table
  74. :tableData="item.decoration_addition"
  75. :tableColumns="[...addon_columns, ...item.part_columns]"
  76. :isCheckBox="true"
  77. :tableType="'Addon'"
  78. :multipleSelection.sync="items.selectAdditionRow"></new-price-table>
  79. </div>
  80. </div>
  81. <!-- <section>
  82. <p class="title1">
  83. <span></span>
  84. <span>Currency GBP(£)</span>
  85. </p>
  86. <total-table
  87. :comLocationNum="comLocationNum"
  88. :tableData="comBuyData"
  89. :tableColumns="[
  90. ...buy_columns,
  91. ...comCurBaseTotalColumns
  92. ]"
  93. :curOrder="`${curWeek}-${comCurPrint}`"
  94. :min="comCurBaseColumns[0]?.label"
  95. :title="'Buy Price'" @send-idx="getChildIdx"></total-table>
  96. <p class="text-red">Price is ex- gst</p>
  97. <ul>
  98. <li class="entry">
  99. <div class="entry-l">Delivery Locations</div>
  100. <el-input
  101. placeholder="Enter Num"
  102. v-model="comCurBasePrice.locationNum"
  103. size="small" max="7" min="1"
  104. style="width: 130px;"
  105. type="number" @input="setMaxNum"></el-input>
  106. </li>
  107. <li
  108. class="entry"
  109. v-if="comLocationNum > 1">
  110. <div class="entry-text">Qty / Location</div>
  111. </li>
  112. <li class="entry" v-for="(i,k) in comCurBaseTotalColumns" :key="i.prop" v-show="comLocationNum > k">
  113. <div class="entry-l">Delivery Postcode</div>
  114. <el-input
  115. clearable
  116. placeholder="Enter Postcode"
  117. v-model="
  118. i.postcode"
  119. size="small"
  120. style="width: 130px; margin-right: 20px;"
  121. @input="getDebFreight(k)"></el-input>
  122. <el-input
  123. v-if="comLocationNum > 1"
  124. placeholder="Enter Qty"
  125. type="number"
  126. :min="comCurBaseColumns[0]?.label"
  127. @blur="getNumber($event, comCurBaseTotalColumns[k],comCurBaseColumns[0]?.label)"
  128. v-model="i.label"
  129. size="small"
  130. style="width: 130px; margin-right: 20px;"></el-input>
  131. <div class="entry-r">
  132. <span>Freight Method</span>
  133. <el-radio-group
  134. v-model="i.freight_type"
  135. @change="getFreight(k)">
  136. <el-radio :label="1">Road Express</el-radio>
  137. <el-radio :label="2">Air Freight</el-radio>
  138. </el-radio-group>
  139. </div>
  140. </li>
  141. </ul>
  142. <div class="entry">
  143. <div class="entry-l">Setup</div>
  144. <div class="entry-l">include in unit price</div>
  145. <pc-switch v-model="setup_switch"></pc-switch>
  146. </div>
  147. <div class="entry">
  148. <div class="entry-l">Freight</div>
  149. <div class="entry-l">include in unit price</div>
  150. <div>
  151. <pc-switch v-model="freight_switch"></pc-switch>
  152. </div>
  153. </div>
  154. <el-button
  155. size="medium"
  156. class="button-black"
  157. @click="openMailDialog">
  158. Enquiry
  159. </el-button>
  160. </section> -->
  161. <!-- <section>
  162. <unit-table
  163. :tableData="unitData"
  164. :tableColumns="[
  165. ...unit_columns,
  166. ...comCurBaseTotalColumns
  167. ]"></unit-table>
  168. 直接用comMergeColumns会出现summary数值问题,改用v-show="comLocationNum"控制
  169. <total-table
  170. v-show="comLocationNum == 1"
  171. :tableData="comSellData"
  172. :tableColumns="comNoSumCol"
  173. :comLocationNum="comLocationNum"
  174. :title="'Sell Price'"></total-table>
  175. <total-table
  176. v-show="comLocationNum != 1"
  177. :tableData="comSellData"
  178. :tableColumns="comHasSumCol"
  179. :comLocationNum="comLocationNum"
  180. :title="'Sell Price'"></total-table>
  181. <el-button
  182. class="button-black button-margin"
  183. size="medium"
  184. @click="openDownloadDialog(0)"
  185. >View Quote</el-button>
  186. <el-button
  187. class="button-black button-margin"
  188. size="medium"
  189. @click="openDownloadDialog(1)"
  190. >Send Order Enquiry</el-button>
  191. </section> -->
  192. </div>
  193. <div
  194. v-else
  195. class="quote-tips">
  196. Current item prices are missing, please contact<a
  197. href="mailto:Info@promocollection.uk">
  198. info@promocollection.uk</a>
  199. </div>
  200. <no-ssr>
  201. <div v-if="quoteLoadState == 1">
  202. <!-- Enquiry按钮 -->
  203. <form-dialog
  204. :emailForm="enquiryForm"
  205. :enquiryConfig="enquiryConfig"
  206. :visible.sync="enquiryFormVisible"
  207. @handleSend="sendPriceMail"
  208. :rules="rules"
  209. :labelWidth="
  210. enquiryConfig[3].selectlist?.length ? 140 : 82
  211. "></form-dialog>
  212. <mail-table
  213. ref="mailtable"
  214. :mailData="mailData"
  215. v-show="false">
  216. <price-to-img
  217. :pageData="pageData"
  218. :specificationsObj="specificationsObj"
  219. :tableData="comFilterSwitchSellData"
  220. :tableColumns="comMergeColumns"
  221. :comLocationNum="comLocationNum"
  222. :emailForm="commentObj"></price-to-img>
  223. </mail-table>
  224. <el-dialog
  225. ref="dialogRef"
  226. :lock-scroll="false"
  227. title="Customer Quote"
  228. :visible.sync="priceToImgVisible"
  229. custom-class="price-to-img-dialog">
  230. <price-to-img
  231. :isImgSrc="false"
  232. ref="priceToImgRef"
  233. :loading.sync="pdfLoading"
  234. :pageData="pageData"
  235. :specificationsObj="specificationsObj"
  236. :tableData="comFilterSwitchSellData"
  237. :tableColumns="comMergeColumns"
  238. :comLocationNum="comLocationNum"
  239. :emailForm="commentObj"></price-to-img>
  240. <p class="tips">Change default standard comment:</p>
  241. <el-input v-model="commentObj.Comments"></el-input>
  242. <div class="btn-wrap">
  243. <el-button
  244. class="button-black button-margin"
  245. size="medium"
  246. @click="handleDownloadPdf"
  247. :loading="pdfLoading"
  248. >Download</el-button>
  249. </div>
  250. </el-dialog>
  251. <!-- <form-dialog
  252. :emailForm="commentObj"
  253. :enquiryConfig="enquiryConfig1"
  254. :visible.sync="downloadDialogVisible"
  255. @handleSend="sendPdfMail"
  256. :rules="rules1"
  257. :labelWidth="120"
  258. :isSendPdf="true"></form-dialog> -->
  259. <price-to-img
  260. ref="pdf"
  261. v-show="false"
  262. :loading.sync="pdfLoading"
  263. :pageData="pageData"
  264. :specificationsObj="specificationsObj"
  265. :tableData="comFilterSwitchSellData"
  266. :tableColumns="comMergeColumns"
  267. :comLocationNum="comLocationNum"
  268. :emailForm="commentObj"></price-to-img>
  269. <!-- 报价图片弹框 -->
  270. <dialog-XX-success
  271. :visible.sync="xxContentVisible" :imgType="false"
  272. :content="'This quantity is below the MOQ for this product'"></dialog-XX-success>
  273. </div>
  274. </no-ssr>
  275. </div>
  276. </template>
  277. <script>
  278. import { mapState, mapMutations, mapActions } from 'vuex'
  279. import _ from 'lodash'
  280. import { times as npTimes,plus as npPlus, minus as npMinus, divide as npDivide } from 'number-precision';
  281. import NewPriceTable from '@/components/table/NewPriceTable'
  282. import TotalTable from '@/components/table/TotalTable'
  283. import UnitTable from '@/components/table/UnitTable'
  284. import MailTable from '@/components/table/MailTable'
  285. import dialogXXSuccess from '@/components/DIalogXXSuccess.vue'
  286. export default {
  287. components: {
  288. NewPriceTable,
  289. TotalTable,
  290. UnitTable,
  291. MailTable,
  292. 'dialog-XX-success': dialogXXSuccess
  293. },
  294. props: {
  295. pageData: {
  296. type: Object,
  297. default: () => {
  298. return {}
  299. },
  300. },
  301. id: {
  302. type: Number,
  303. default: null
  304. },
  305. },
  306. data() {
  307. return {
  308. quoteLoadState: 0,
  309. curWeek: 0,
  310. allPrintTab: [],
  311. priceList: [],
  312. initZeroObj: {},
  313. initSetupObj: {},
  314. initUnitObj: {},
  315. initChangeUnitObj: {},
  316. initFrightObj: {},
  317. initTotalObj: {},
  318. xxContentVisible: false,
  319. setup_switch: false,
  320. freight_switch: false,
  321. weight: {},
  322. undecorated_columns: [
  323. {
  324. label: 'MODEL',
  325. prop: 'model',
  326. type: 'text',
  327. align: 'left',
  328. width: 150,
  329. extraWidth: 50, // 配合组件 (820-tableColumns[0].width-tableColumns[0].extraWidth)/(tableColumns.length-1)
  330. isFirstColumn: true, // 去掉$符号
  331. },
  332. {
  333. label: 'SETUP',
  334. prop: 'website_setup',
  335. },
  336. ],
  337. decoration_columns: [
  338. {
  339. label: 'PRINT OPTION',
  340. prop: 'dec_code',
  341. type: 'radioInput',
  342. align: 'left',
  343. width: 150,
  344. extraWidth: 50,
  345. },
  346. {
  347. label: 'SETUP',
  348. prop: 'website_setup',
  349. },
  350. ],
  351. addon_columns: [
  352. {
  353. label: 'Addon',
  354. prop: 'name',
  355. type: 'text',
  356. width: 150,
  357. extraWidth: 50,
  358. isFirstColumn: true, // 去掉$符号
  359. },
  360. {
  361. label: 'Setup',
  362. prop: 'website_setup',
  363. },
  364. ],
  365. buy_columns: [
  366. {
  367. label: 'QTY',
  368. prop: 'project',
  369. isFirstColumn: true, // 去掉$符号
  370. },
  371. ],
  372. unit_columns: [
  373. {
  374. label: 'QTY',
  375. prop: 'total',
  376. align: 'left',
  377. isText: true,
  378. },
  379. ],
  380. buyData: [
  381. { project: 'Setup' },
  382. { project: 'Unit' },
  383. { project: 'Freight' },
  384. { project: 'Total' }
  385. ],
  386. unitData: [
  387. { total: 'Unit Rate %' },
  388. { total: 'Setup %' },
  389. { total: 'Freight %' },
  390. ],
  391. sellData: [
  392. { project: 'Postcode',summary: '-' },
  393. { project: 'Setup',summary: 0.00 },
  394. { project: 'Unit',summary: 0.00 },
  395. { project: 'Freight',summary: 0.00 },
  396. { project: 'Total',summary: 0.00 },
  397. ],
  398. POA_Config: ['111', '111.00', '999', '999.00'],
  399. enquiryFormVisible: false,
  400. enquiryForm: {
  401. Name: '',
  402. Email: '',
  403. Phone: '',
  404. 'Customer manager': null,
  405. Comments: '',
  406. },
  407. enquiryConfig: [
  408. { prop: 'Name', type: 'input' },
  409. { prop: 'Email', type: 'input' },
  410. { prop: 'Phone', type: 'input' },
  411. {
  412. prop: 'Customer manager',
  413. type: 'select',
  414. selectlist: [],
  415. isShow: true,
  416. },
  417. { prop: 'Comments', type: 'textarea' },
  418. ],
  419. rules: {
  420. Name: [{ required: true, message: 'Please enter', trigger: 'blur' }],
  421. Email: [
  422. {
  423. required: true,
  424. message: 'Please enter the correct format',
  425. pattern:
  426. /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((.[a-zA-Z0-9_-]{2,3}){1,2})$/,
  427. trigger: 'blur',
  428. },
  429. ],
  430. Phone: [
  431. {
  432. required: true,
  433. message: 'Please enter the correct format',
  434. // pattern: /^1[0-9]{10}$/,
  435. trigger: 'blur',
  436. },
  437. ],
  438. 'Customer manager': [
  439. { required: true, message: 'Please select', trigger: 'change' },
  440. ],
  441. },
  442. mailData: {
  443. Url: '',
  444. },
  445. priceToImgVisible: false,
  446. downloadDialogVisible: false,
  447. commentObj: {
  448. 'Email Address': '',
  449. Comments: '',
  450. },
  451. enquiryConfig1: [
  452. { prop: 'Email Address', type: 'input' },
  453. { prop: 'Comments', type: 'input' },
  454. ],
  455. rules1: {
  456. 'Email Address': [
  457. {
  458. required: true,
  459. message: 'Please enter the correct format',
  460. pattern:
  461. /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((.[a-zA-Z0-9_-]{2,3}){1,2})$/,
  462. trigger: 'blur',
  463. },
  464. ],
  465. },
  466. specificationsObj: {
  467. time: null,
  468. model: null,
  469. decoration: null,
  470. addonArr: null,
  471. },
  472. pdfLoading: false,
  473. }
  474. },
  475. computed: {
  476. ...mapState('config', { configInfo: state => state.configInfo }),
  477. userInfo() {
  478. return this.$store.state.userInfo
  479. },
  480. comCurWeekPrice() {
  481. return this.priceList[this.curWeek] || {}
  482. },
  483. comCurPrint() {
  484. return this.comCurWeekPrice.curPrint
  485. },
  486. comCurBasePrice() {
  487. return this.comCurWeekPrice.basePrice[this.comCurPrint]
  488. },
  489. comLocationNum() {
  490. return +(this.comCurWeekPrice.basePrice[this.comCurPrint].locationNum)
  491. },
  492. comCurBaseColumns() {
  493. return this.comCurBasePrice.part_columns
  494. },
  495. comCurBaseTotalColumns() {
  496. const d = this.comCurWeekPrice.basePrice[this.comCurPrint].total_part_columns
  497. const n = this.comLocationNum
  498. if (n === 1) {
  499. return d
  500. }else{
  501. const concatAdd = [...d,...this.comCurWeekPrice.basePrice[this.comCurPrint].remainingAttr].slice(0, n);
  502. return concatAdd
  503. }
  504. },
  505. comTotalLabel(){
  506. // 计算所有元素label的和
  507. return this.comCurBaseTotalColumns.reduce((sum, item) => sum + Number(item.label), 0);
  508. },
  509. comSummaryColumns(){
  510. return [{ label: this.comTotalLabel.toString(), prop: 'summary' }];
  511. },
  512. comAttributeList() {
  513. const obj = {}
  514. this.comCurBaseTotalColumns?.forEach(item => {
  515. obj[item.prop] = item.label
  516. })
  517. obj.summary = this.comTotalLabel;
  518. return obj
  519. },
  520. // 当前已选基础价
  521. comBasePrice() {
  522. return this.comCurBasePrice.selectBaseRow
  523. },
  524. // 当前累加打印价
  525. comDecoPrice() {
  526. if (!this.comCurWeekPrice.decoration?.length) {
  527. return []
  528. }
  529. const arr = this.comCurWeekPrice.decoration
  530. .map((item, idx) => {
  531. const obj = {}
  532. if (+item.num > 0) {
  533. for (const i in this.initUnitObj) {
  534. if (idx === 0) {
  535. // 首个打印价要取附加价计算
  536. const keyArr = i.split('_')
  537. const supplier_val = item[`supplier_${keyArr[1]}`]
  538. if (this.POA_Config.includes(supplier_val)) {
  539. obj[`${i}`] = supplier_val
  540. } else {
  541. obj[`${i}`] = npTimes(+supplier_val, item.num)
  542. }
  543. } else {
  544. obj[`${i}`] = this.POA_Config.includes(item[i]) ? item[i] : npTimes(+item[i], item.num);
  545. }
  546. }
  547. }
  548. return obj
  549. })
  550. .filter(obj => Object.keys(obj).length !== 0)
  551. return arr
  552. },
  553. comBuyData() {
  554. this.calculateBuyData();
  555. return this.buyData
  556. },
  557. comNoSumCol(){
  558. return [
  559. ...this.buy_columns,
  560. ...this.comCurBaseTotalColumns
  561. ]
  562. },
  563. comHasSumCol(){
  564. return [
  565. ...this.buy_columns,
  566. ...this.comCurBaseTotalColumns,
  567. ...this.comSummaryColumns
  568. ];
  569. },
  570. comMergeColumns(){
  571. return this.comLocationNum == 1 ? this.comNoSumCol:this.comHasSumCol
  572. },
  573. comSellData() {
  574. if (Object.keys(this.comAttributeList).length !== 0) {
  575. this.calculateSellData();
  576. }
  577. return this.sellData
  578. },
  579. comFilterSwitchSellData() {
  580. return this.comSellData?.filter((item, i) => {
  581. if (i === 1 && this.setup_switch) {
  582. return false;
  583. } else if (i === 3 && this.freight_switch) {
  584. return false;
  585. } else {
  586. return item
  587. }
  588. })
  589. },
  590. },
  591. methods: {
  592. ...mapActions(['getUserInfo']),
  593. getQuote() {
  594. this.$axios
  595. .post('/uk-api/quote/pricequote', { id: this.id })
  596. .then(res => {
  597. if (localStorage.getItem('unit')) {
  598. this.unitData = JSON.parse(localStorage.getItem('unit'))
  599. }
  600. const { attributeList, priceList, default: defaultID } = res.result
  601. if (
  602. !Object.keys(attributeList).length ||
  603. !Object.keys(priceList).length
  604. ) {
  605. this.quoteLoadState = 2
  606. return
  607. }
  608. for (const a in attributeList) {
  609. // 过滤掉website_qty标签无数量
  610. if (attributeList[a]) {
  611. this.initZeroObj[a] = 0
  612. }else{
  613. delete attributeList[a]
  614. }
  615. for (const unit of this.unitData) {
  616. // 如果对象中缺少 attributeList 的 key,则设置为 40
  617. if (!(a in unit) || unit[a] === '') {
  618. this.$set(unit,a,40)
  619. }
  620. }
  621. }
  622. // 格式化数据,对象改成数组
  623. for (const keys in priceList) {
  624. const vals = {}
  625. const { decoration, additionlist, ...remaining } = priceList[keys]
  626. vals.basePrice = []
  627. vals.selectAdditionRow = []
  628. vals.curPrint = 0
  629. vals.name = this.formatDurationString(keys)
  630. vals.nameOrigin = keys
  631. vals.decorationOrign = [...decoration]
  632. vals.decorationID = decoration.map(i => i.id)
  633. vals.decoration = [...decoration].flatMap(item => {
  634. const result = [];
  635. if (item.max_color > 0) {
  636. result.push({ ...item, max_num: item.max_color,id:`${item.id}-1`,decName:item.max_color_name });
  637. }
  638. if (item.max_point > 0) {
  639. result.push({ ...item, max_num: item.max_point,id:`${item.id}-2`,decName:item.max_point_name });
  640. }
  641. return result;
  642. });
  643. vals.additionlist = additionlist
  644. for (const k in remaining) {
  645. const o = {}
  646. o.attributeList = this.copyData(attributeList)
  647. if (remaining[k]?.length>1) {
  648. // 检查数组中各元素的 website_qtyN 是否都等于 "-" or "POA",则删除key
  649. for (const a in attributeList) {
  650. const is111Poa = remaining[k].every(item => this.POA_Config.includes(item[a]));
  651. if (is111Poa) {
  652. delete o.attributeList[a]
  653. }
  654. }
  655. }else if (remaining[k]?.length === 1) {
  656. // 判断 remaining[k][0] 中是否包含 vals.attributeList 的键,并且对应的值都等于 "-" or "POA",则不删除key
  657. const obj = remaining[k][0];
  658. const attributeKeys = Object.keys(o.attributeList);
  659. const areAllKeysInPOAConfig = attributeKeys.every(key => {
  660. return Object.prototype.hasOwnProperty.call(obj, key) && this.POA_Config.includes(obj[key]);
  661. });
  662. if (!areAllKeysInPOAConfig) {
  663. attributeKeys.forEach(key => {
  664. if (Object.prototype.hasOwnProperty.call(obj, key) && this.POA_Config.includes(obj[key])) {
  665. delete o.attributeList[key];
  666. }
  667. });
  668. }
  669. }
  670. o.name = k
  671. o.data = remaining[k]
  672. o.locationNum = 1
  673. o.part_columns = Object.keys(o.attributeList).map(e => {
  674. return { label: o.attributeList[e].toString(), prop: e }
  675. })
  676. const freightParam = {
  677. postcode: '',
  678. freight_type: 1,
  679. freight: {}
  680. }
  681. o.total_part_columns = this.copyData(o.part_columns).map(obj => ({
  682. ...obj,
  683. ...freightParam
  684. }));
  685. o.remainingAttr = []
  686. const firstColumns = { ...o.part_columns[0],...freightParam}
  687. for(let i = 1; i < 9; i++){
  688. if(!Object.keys(o.attributeList).includes(`website_qty${i}`)){
  689. const newColumn = {...firstColumns}
  690. this.$set(newColumn,'prop',`website_qty${i}`)
  691. o.remainingAttr.push(newColumn)
  692. }
  693. };
  694. vals.basePrice.push(o)
  695. if (!this.allPrintTab.includes(k)) {
  696. this.allPrintTab.push(k)
  697. }
  698. }
  699. this.priceList.push(vals)
  700. }
  701. this.priceList.forEach((options, index) => {
  702. // 原始数据name没空格,需要映射到
  703. if (options.nameOrigin === defaultID?.name) {
  704. this.curWeek = index
  705. options.decorationOrign.forEach((opt, idx) => {
  706. if (opt.id === defaultID?.decoration?.id) {
  707. this.$set(options, 'curPrint', idx)
  708. }
  709. })
  710. }
  711. // 所有周期的所有打印,进来页面时默认勾选第一条价格
  712. options.basePrice.forEach((opt,idx) => {
  713. this.$set(opt, 'selectBaseRow', opt.data[0] ||{})
  714. opt.decoration_addition = [...(options.decorationOrign?.[idx]?.decoration_addition || []),...(options.additionlist || [])]
  715. })
  716. options.decoration.forEach(opt => {
  717. this.$set(opt, 'num', 0)
  718. })
  719. })
  720. this.initSetupObj = Object.assign({}, this.initZeroObj)
  721. this.initUnitObj = Object.assign({}, this.initZeroObj, {
  722. website_setup: 0,
  723. })
  724. this.initFrightObj = Object.assign({}, this.initZeroObj)
  725. this.buyData = this.buyData.map(item => {
  726. return { ...item, ...this.initSetupObj }
  727. })
  728. this.sellData = this.sellData.map(item => {
  729. return { ...item, ...this.initSetupObj }
  730. })
  731. this.quoteLoadState = 1
  732. })
  733. .catch((e) => {
  734. console.log('this.quoteLoadState1: ', e);
  735. this.quoteLoadState = 2
  736. })
  737. },
  738. formatDurationString(input) {
  739. // 匹配数字和字符串的正则表达式
  740. const regex = /(\d+)([a-zA-Z]+)/g;
  741. const result = input.replace(regex, '$1 $2');
  742. return result;
  743. },
  744. // getWeight() {
  745. // this.$axios
  746. // .post('/api/quote/weight', { id: this.id })
  747. // .then(res => {
  748. // this.weight = res.result
  749. // })
  750. // .catch(() => {})
  751. // },
  752. // getFreight(k) {
  753. // const postcode = this.comCurBaseTotalColumns[k].postcode
  754. // const type = this.comCurBaseTotalColumns[k].freight_type
  755. // const init = { basic:0,pickup:0,minimum:0 }
  756. // if (postcode.length < 3) {
  757. // this.comCurBaseTotalColumns[k].freight = init
  758. // return
  759. // }
  760. // this.$axios
  761. // .post('/api/quote/freight', {
  762. // postcode,
  763. // type
  764. // })
  765. // .then(res => {
  766. // this.comCurBaseTotalColumns[k].freight = Array.isArray(res.result)?init:res.result
  767. // })
  768. // },
  769. getDebFreight: _.debounce(function (k) {
  770. this.getFreight(k)
  771. }, 200),
  772. getNumber(e, row, min) {
  773. if (parseInt(e.target.value) < min) {
  774. this.xxContentVisible = true;
  775. row.label = min
  776. } else {
  777. this.xxContentVisible = false;
  778. }
  779. },
  780. sortBy(items) {
  781. // items.decoration.sort(this.customSort(items.decorationID))
  782. // const targetElement = items.decoration.splice(items.curPrint, 1)[0]
  783. // items.decoration.unshift(targetElement)
  784. },
  785. // 按原打印数组的id字段排序
  786. customSort(decorationID) {
  787. return (a, b) => {
  788. return decorationID.indexOf(a.id) - decorationID.indexOf(b.id)
  789. }
  790. },
  791. dividePrice(a) {
  792. return npDivide(+a, 100)
  793. },
  794. // openMailDialog() {
  795. // if (this.$utils.checkLogin()) {
  796. // this.getUserInfo()
  797. // const { contacts, email, phone, crm_users_id:crmUsersId } = this.userInfo
  798. // this.enquiryForm.Name = contacts
  799. // this.enquiryForm.Email = email
  800. // this.enquiryForm.Phone = phone
  801. // if (crmUsersId?.length) {
  802. // this.enquiryConfig[3].selectlist = crmUsersId
  803. // if (crmUsersId?.length === 1) {
  804. // this.enquiryForm['Customer manager'] = crmUsersId[0].name
  805. // }
  806. // } else {
  807. // this.enquiryConfig[3].isShow = false
  808. // this.$delete(this.enquiryForm, 'Customer manager')
  809. // }
  810. // this.enquiryFormVisible = true
  811. // } else {
  812. // this.openDialog()
  813. // }
  814. // },
  815. getMailData() {
  816. this.mailData.Url = window.location.href
  817. const { Name, Email, Phone, Comments } = this.enquiryForm
  818. this.mailData['Customer Name'] = Name
  819. this.mailData['Customer Email'] = Email
  820. this.mailData['Customer Phone'] = Phone
  821. this.mailData.Comments = Comments
  822. const { email, level, createTime } = this.userInfo
  823. this.mailData['Member Account'] = email
  824. this.mailData['Member Grade'] = level.name
  825. this.mailData['Member Registration time'] = createTime
  826. this.mailData['Quote time'] = this.$utils.formatTime(new Date())
  827. },
  828. // 发送价格邮件 Enquiry按钮
  829. // async sendPriceMail() {
  830. // await this.getMailData()
  831. // await this.getCustomerQuoteData()
  832. // const {
  833. // Name,
  834. // Email,
  835. // Phone,
  836. // Comments,
  837. // 'Customer manager': customerManager,
  838. // } = this.enquiryForm
  839. // this.$axios
  840. // .post('/uk-api/quote/sendenquiry', {
  841. // content: this.$refs.mailtable.$el.innerHTML,
  842. // name: Name,
  843. // email: Email,
  844. // phone: Phone,
  845. // customer_manager: customerManager || '',
  846. // url: this.mailData.Url,
  847. // product_code: this.pageData.product_code,
  848. // comments: Comments,
  849. // member_id: this.userInfo.id,
  850. // })
  851. // .then(res => {
  852. // this.setLoading(false)
  853. // this.enquiryFormVisible = false
  854. // this.$confirm('Enquiry Sent', {
  855. // confirmButtonText: 'OK',
  856. // showCancelButton: false,
  857. // type: 'success',
  858. // center: true,
  859. // showClose: false,
  860. // confirmButtonClass: 'com-btnblack',
  861. // }).then(() => {})
  862. // })
  863. // .catch(() => {
  864. // this.setLoading(false)
  865. // })
  866. // },
  867. // getCustomerQuoteData() {
  868. // const { name, selectAdditionRow } = this.comCurWeekPrice
  869. // this.specificationsObj.time = name
  870. // this.specificationsObj.model = this.comBasePrice.model
  871. // this.specificationsObj.decoration = this.comCurBasePrice.name
  872. // if (selectAdditionRow.length) {
  873. // this.specificationsObj.addonArr = selectAdditionRow.map(
  874. // item => item.name
  875. // )
  876. // } else {
  877. // this.specificationsObj.addonArr = null
  878. // }
  879. // },
  880. // openDownloadDialog(type) {
  881. // this.getCustomerQuoteData()
  882. // type
  883. // ? (this.downloadDialogVisible = true)
  884. // : (this.priceToImgVisible = true)
  885. // },
  886. handleDownloadPdf() {
  887. this.pdfLoading = true
  888. this.$nextTick(() => {
  889. this.$refs.priceToImgRef.htmlToPdf(this.pageData.product_code)
  890. })
  891. },
  892. // 发送PDF邮件
  893. // sendPdfMail() {
  894. // this.$axios
  895. // .post('/api/quote/sendpdf', {
  896. // content: this.$refs.pdf.$el.innerHTML,
  897. // product_code: this.pageData.product_code,
  898. // email: this.commentObj['Email Address'],
  899. // })
  900. // .then(res => {
  901. // this.setLoading(false)
  902. // this.downloadDialogVisible = false
  903. // this.$confirm('Enquiry Sent', {
  904. // confirmButtonText: 'OK',
  905. // showCancelButton: false,
  906. // type: 'success',
  907. // center: true,
  908. // showClose: false,
  909. // confirmButtonClass: 'com-btnblack',
  910. // })
  911. // })
  912. // .catch(() => {
  913. // this.setLoading(false)
  914. // })
  915. // },
  916. copyData(data) {
  917. return JSON.parse(JSON.stringify(data))
  918. },
  919. calculateBuyData(){
  920. const selPriceArr = []
  921. if (JSON.stringify(this.comBasePrice) !== '{}') {
  922. selPriceArr.push(this.comBasePrice)
  923. }
  924. selPriceArr.push(...this.comDecoPrice, ...this.comCurWeekPrice.selectAdditionRow);
  925. if(selPriceArr.length === 0){
  926. this.buyData = this.buyData.map(item => ({ ...item, ...this.initZeroObj }));
  927. return
  928. }
  929. // 累加所选,初始数量对应的单价。赋值给this.initUnitObj
  930. for (const i in this.initUnitObj) {
  931. const columnSum = this.copyData(selPriceArr).reduce(function (prev, cur) {
  932. if (cur[i] === '111' || cur[i] === '111.00') {
  933. return (cur[i] = '-')
  934. } else if (cur[i] === '999' || cur[i] === '999.00') {
  935. return (cur[i] = 'POA')
  936. } else {
  937. // 当基础价格是-POA,后续累加价格是正常数字价,依然返回-POA
  938. if (prev === '-' || prev === 'POA') {
  939. return prev
  940. }
  941. return npPlus(+cur[i], prev).toFixed(2)
  942. }
  943. }, 0)
  944. this.$set(this.initUnitObj, i, columnSum)
  945. }
  946. for (const a in this.comAttributeList) {
  947. // 每次更改选择价格,必须遍历整个comAttributeList
  948. const tempIdx = this.comCurBaseColumns.findIndex(
  949. items => +this.comAttributeList[a] < +items.label
  950. )
  951. if (tempIdx > 0) {
  952. const key = this.comCurBaseColumns[tempIdx - 1].prop
  953. this.$set(this.initChangeUnitObj, a, this.initUnitObj[key])
  954. } else {
  955. const length = this.comCurBaseColumns.length
  956. const key = this.comCurBaseColumns[length - 1].prop
  957. this.$set(this.initChangeUnitObj, a, this.initUnitObj[key])
  958. }
  959. if (
  960. this.initChangeUnitObj[a] === 'POA' ||
  961. this.initChangeUnitObj[a] === '-'
  962. ) {
  963. this.$set(this.initSetupObj, a, this.initChangeUnitObj[a])
  964. this.$set(this.initFrightObj, a, this.initChangeUnitObj[a])
  965. } else {
  966. this.$set(this.initSetupObj, a, this.initUnitObj.website_setup)
  967. // 计算运费
  968. // 单独批次数量的总重
  969. // weight定义是{},后端没数据传回[]
  970. const unitWLocal = this.weight.unit_w_local ? +this.weight.unit_w_local : 0;
  971. const totalWeight = Math.ceil(
  972. npTimes(unitWLocal, this.comAttributeList[a])
  973. )
  974. // Road express 1 AAE:AAEFactor 2
  975. const setupFuel = this.dividePrice(this.configInfo.fuel)
  976. const setupBagFreight = this.dividePrice(this.configInfo.bag_freight)
  977. const setupExpressFreight = this.dividePrice(
  978. this.configInfo.express_freight
  979. )
  980. const AAEFactor = npPlus(1, setupBagFreight, setupFuel)
  981. const expressFactor = npPlus(1, setupExpressFreight, setupFuel)
  982. let frightCost = 0
  983. let freightType
  984. let postcode
  985. let freight = {}
  986. const matchIndex = this.comCurBaseTotalColumns.findIndex(item => item.prop === a)
  987. // 1,所有按第一个运费统计;不为1,则只计算 comCurBaseTotalColumns的[地址数]长度
  988. if (+this.comLocationNum === 1 || this.comLocationNum >= matchIndex + 1) {
  989. ({ freight, freight_type: freightType, postcode } = this.comCurBaseTotalColumns[+this.comLocationNum === 1 ? 0 : matchIndex] || {});
  990. }
  991. if (freightType === 1 && postcode >= 3) {
  992. if (totalWeight > 20) {
  993. const a1 = npMinus(totalWeight, 20)
  994. const a2 = npTimes(a1, +freight.basic)
  995. const a3 = npPlus(+freight.pickup, a2)
  996. frightCost = npTimes(a3, expressFactor)
  997. } else {
  998. frightCost = npTimes(+freight.pickup, expressFactor)
  999. }
  1000. } else if (freightType === 2 && postcode >= 3) {
  1001. const a1 = npDivide(totalWeight, 5)
  1002. const a2 = npTimes(+freight.minimum, Math.ceil(a1))
  1003. frightCost = npTimes(a2, AAEFactor)
  1004. } else {
  1005. frightCost = 0
  1006. }
  1007. this.$set(this.initFrightObj, a, Math.ceil(frightCost).toFixed(2))
  1008. }
  1009. if (
  1010. this.initChangeUnitObj[a] === '-' ||
  1011. this.initChangeUnitObj[a] === 'POA'
  1012. ) {
  1013. this.$set(this.initTotalObj, a, this.initChangeUnitObj[a])
  1014. } else {
  1015. const unitQTY = npTimes(
  1016. this.initChangeUnitObj[a],
  1017. this.comAttributeList[a]
  1018. )
  1019. this.$set(
  1020. this.initTotalObj,
  1021. a,
  1022. npPlus(
  1023. this.initUnitObj.website_setup,
  1024. unitQTY,
  1025. this.initFrightObj[a]
  1026. ).toFixed(2)
  1027. )
  1028. }
  1029. if (this.setup_switch) {
  1030. // 业务:Setup价格/对应数量后向上取整
  1031. if (
  1032. this.initChangeUnitObj[a] === '-' ||
  1033. this.initChangeUnitObj[a] === 'POA'
  1034. ) {
  1035. this.$set(this.initChangeUnitObj, a, this.initChangeUnitObj[a])
  1036. } else {
  1037. const num =
  1038. Math.ceil(
  1039. (this.initSetupObj[a] / this.comAttributeList[a]) * 100
  1040. ) / 100
  1041. this.$set(
  1042. this.initChangeUnitObj,
  1043. a,
  1044. npPlus(this.initChangeUnitObj[a], num).toFixed(2)
  1045. )
  1046. }
  1047. }
  1048. if (this.freight_switch) {
  1049. if (
  1050. this.initChangeUnitObj[a] === '-' ||
  1051. this.initChangeUnitObj[a] === 'POA'
  1052. ) {
  1053. this.$set(this.initChangeUnitObj, a, this.initChangeUnitObj[a])
  1054. } else {
  1055. const num =
  1056. Math.ceil(
  1057. (this.initFrightObj[a] / this.comAttributeList[a]) * 100
  1058. ) / 100
  1059. this.$set(
  1060. this.initChangeUnitObj,
  1061. a,
  1062. npPlus(this.initChangeUnitObj[a], num).toFixed(2)
  1063. )
  1064. }
  1065. }
  1066. }
  1067. if (this.setup_switch) {
  1068. this.$set(this.buyData, 0, { ...this.buyData[0], ...this.initZeroObj, ...{'summary':0.00} })
  1069. } else {
  1070. this.$set(this.buyData, 0, { ...this.buyData[0], ...this.initSetupObj })
  1071. }
  1072. this.$set(this.buyData, 1, {
  1073. ...this.buyData[1],
  1074. ...this.initChangeUnitObj,
  1075. })
  1076. if (this.freight_switch) {
  1077. this.$set(this.buyData, 2, { ...this.buyData[2], ...this.initZeroObj })
  1078. } else {
  1079. this.$set(this.buyData, 2, {
  1080. ...this.buyData[2],
  1081. ...this.initFrightObj,
  1082. })
  1083. }
  1084. this.$set(this.buyData, 3, { ...this.buyData[3], ...this.initTotalObj })
  1085. },
  1086. calculateSellData() {
  1087. // 放置comSellData计算和副作用的代码
  1088. const buySetup = this.comBuyData[0]
  1089. const buyUnit = this.comBuyData[1]
  1090. const buyFright = this.comBuyData[2]
  1091. let frightSummary = 0
  1092. for (const i in this.comAttributeList) {
  1093. if (buyUnit[i] === '-' || buyUnit[i] === 'POA') {
  1094. this.sellData[0][i] = '-'
  1095. this.sellData[1][i] = buyUnit[i]
  1096. this.sellData[2][i] = buyUnit[i]
  1097. this.sellData[3][i] = buyUnit[i]
  1098. this.sellData[4][i] = buyUnit[i]
  1099. } else {
  1100. const item = this.comLocationNum === 1 ? this.comCurBaseTotalColumns[0] : this.comCurBaseTotalColumns.find(element => element.prop === i);
  1101. this.sellData[0][i] = item && item.postcode !== '' ? item.postcode : '-';
  1102. // 分别乘以Markup %表格
  1103. const key = this.comCurBaseTotalColumns[0]?.prop
  1104. if (this.unitData[1] && this.unitData[1][key]) {
  1105. const a = npPlus(this.unitData[1][key] / 100, 1)
  1106. this.sellData[1][i] = npTimes(buySetup[i], a).toFixed(2)
  1107. } else {
  1108. this.sellData[1][i] = buySetup[i]
  1109. }
  1110. if (this.unitData[0][i]) {
  1111. const a = npPlus(this.unitData[0][i] / 100, 1)
  1112. this.sellData[2][i] = npTimes(buyUnit[i], a).toFixed(2)
  1113. } else {
  1114. this.sellData[2][i] = buyUnit[i]
  1115. }
  1116. if (this.unitData[2] && this.unitData[2][key]) {
  1117. const a = npPlus(this.unitData[2][key] / 100, 1)
  1118. this.sellData[3][i] = npTimes(buyFright[i], a).toFixed(2)
  1119. // freight_switch会使qty的运费=0无法计算,故用了initFrightObj
  1120. const fa = npTimes(this.initFrightObj[i], a)
  1121. frightSummary = npPlus(frightSummary,fa).toFixed(2)
  1122. } else {
  1123. this.sellData[3][i] = buyFright[i]
  1124. frightSummary = npPlus(frightSummary,this.initFrightObj[i]).toFixed(2)
  1125. }
  1126. const unitQTY = npTimes(this.sellData[2][i], this.comAttributeList[i])
  1127. this.$set(
  1128. this.sellData[4],
  1129. i,
  1130. npPlus(this.sellData[1][i], unitQTY, this.sellData[3][i]).toFixed(2)
  1131. )
  1132. }
  1133. }
  1134. // 迭代加了Total列,需要统计qty的运费后才能合计运费
  1135. if (this.sellData[2].summary !== '-' && this.sellData[2].summary !== 'POA') {
  1136. if (this.freight_switch) {
  1137. const num = Math.ceil((frightSummary / this.comAttributeList.summary) * 100) / 100
  1138. this.sellData[2].summary = npPlus(this.sellData[2].summary, num).toFixed(2)
  1139. this.sellData[3].summary = 0.00
  1140. const a = npTimes(this.sellData[2].summary,this.comAttributeList.summary)
  1141. this.sellData[4].summary = npPlus(this.sellData[1].summary,a).toFixed(2)
  1142. } else {
  1143. this.sellData[3].summary = frightSummary
  1144. this.sellData[4].summary = npPlus(frightSummary,this.sellData[4].summary).toFixed(2)
  1145. }
  1146. }
  1147. },
  1148. // 低于最小起订量 把该栏的数值重置到最小起订量
  1149. getChildIdx(idx){
  1150. this.xxContentVisible = true;
  1151. this.$set(this.comCurBaseTotalColumns[idx-1],'label',this.comCurBaseColumns[0]?.label)
  1152. },
  1153. setMaxNum(val){
  1154. if(val > 7){
  1155. this.comCurBasePrice.locationNum = 7
  1156. }else if(val < 1){
  1157. this.comCurBasePrice.locationNum = 1
  1158. }
  1159. },
  1160. ...mapMutations({ openDialog: 'openDialog', setLoading: 'product/setLoading' })
  1161. },
  1162. }
  1163. </script>
  1164. <style lang='scss' scoped>
  1165. $deep-blue: #004a97;
  1166. .exclamation-icon {
  1167. width: 18px;
  1168. height: 18px;
  1169. line-height: 18px;
  1170. display: inline-block;
  1171. text-align: center;
  1172. color: #000;
  1173. border-radius: 100%;
  1174. border: 1px solid #000;
  1175. font-size: 18px;
  1176. font-weight: 550;
  1177. }
  1178. .popover {
  1179. border: 1px solid #eee;
  1180. padding: 20px;
  1181. .title {
  1182. text-align: center;
  1183. font-weight: bold;
  1184. font-size: 20px;
  1185. }
  1186. }
  1187. .title1 {
  1188. margin: 30px 0 0;
  1189. padding: 20px 0 0;
  1190. font-size: 16px;
  1191. color: #15263d;
  1192. display: flex;
  1193. font-family: ProximaNova-Regular;
  1194. font-weight: 600;
  1195. justify-content: space-between;
  1196. border-top: 1px solid #eee;
  1197. span {
  1198. &:nth-child(2) {
  1199. font-size: 14px;
  1200. color: #50596b;
  1201. }
  1202. }
  1203. }
  1204. .text-red {
  1205. text-align: right;
  1206. color: #e90000;
  1207. padding: 10px 10px 0 0;
  1208. font-size: 16px;
  1209. font-weight: bold;
  1210. }
  1211. .entry {
  1212. color: #50596b;
  1213. margin: 15px 10px;
  1214. display: flex;
  1215. flex-direction: row;
  1216. align-items: center;
  1217. .entry-l {
  1218. width: 120px;
  1219. margin-right: 10px;
  1220. }
  1221. .entry-text{
  1222. margin-left: 280px;
  1223. width: 130px;
  1224. text-align: center;
  1225. font-weight: bold;
  1226. }
  1227. :deep(.el-input__inner) {
  1228. text-align: center;
  1229. padding: 0;
  1230. }
  1231. .entry-r {
  1232. flex: 1;
  1233. text-align: right;
  1234. span {
  1235. margin-right: 10px;
  1236. }
  1237. //修改radio选中为✔样式
  1238. :deep(.el-radio__inner) {
  1239. border-radius: 0;
  1240. width: 18px;
  1241. height: 18px;
  1242. }
  1243. :deep(.el-radio__input.is-checked .el-radio__inner) {
  1244. background: $deep-blue;
  1245. border: 1px solid $deep-blue;
  1246. }
  1247. :deep(.el-radio__input.is-checked + .el-radio__label) {
  1248. color: $deep-blue;
  1249. }
  1250. :deep(.el-radio__input.is-checked .el-radio__inner::after) {
  1251. content: '';
  1252. width: 10px;
  1253. height: 5px;
  1254. border: 1px solid white;
  1255. border-top: transparent;
  1256. border-right: transparent;
  1257. text-align: center;
  1258. display: block;
  1259. position: absolute;
  1260. top: 3px;
  1261. left: 2px;
  1262. transform: rotate(-45deg);
  1263. border-radius: 0px;
  1264. background: none;
  1265. }
  1266. }
  1267. }
  1268. .button-margin {
  1269. margin: 20px 0 0;
  1270. }
  1271. .quote-tips {
  1272. font-size: 16px;
  1273. a {
  1274. color: #6495ed;
  1275. text-decoration: underline;
  1276. margin-left: 5px;
  1277. }
  1278. }
  1279. button {
  1280. font-size: 12px;
  1281. width: 200px;
  1282. height: 30px;
  1283. border-radius: 5px;
  1284. margin-right: 20px;
  1285. cursor: pointer;
  1286. border: none;
  1287. box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.2);
  1288. }
  1289. .button-black {
  1290. background-color: $deep-blue;
  1291. color: #ffffff;
  1292. &:hover {
  1293. background-color: #013269;
  1294. }
  1295. }
  1296. .button-white {
  1297. background-color: #fff;
  1298. color: #50596b;
  1299. img,
  1300. span {
  1301. vertical-align: middle;
  1302. }
  1303. }
  1304. // 报价图片弹框样式
  1305. :deep(.price-to-img-dialog) {
  1306. min-width: 840px;
  1307. margin-top: 2vh !important;
  1308. .el-dialog__header {
  1309. background-color: #00213b;
  1310. padding: 10px 20px;
  1311. .el-dialog__title {
  1312. color: #fff;
  1313. }
  1314. .el-dialog__headerbtn {
  1315. top: 15px;
  1316. }
  1317. }
  1318. .el-dialog__body {
  1319. background-color: #f1f4f9;
  1320. padding: 13px 20px;
  1321. }
  1322. .tips {
  1323. font-size: 16px;
  1324. color: #00213b;
  1325. margin: 12px 0;
  1326. }
  1327. .btn-wrap {
  1328. text-align: left;
  1329. .button-black {
  1330. margin-top: 20px;
  1331. }
  1332. }
  1333. }
  1334. :deep(.el-switch) {
  1335. .el-switch__label {
  1336. position: absolute;
  1337. display: none;
  1338. color: #fff !important;
  1339. }
  1340. /*打开时文字位置设置*/
  1341. .el-switch__label--right {
  1342. z-index: 1;
  1343. right: -3px;
  1344. }
  1345. /*关闭时文字位置设置*/
  1346. .el-switch__label--left {
  1347. z-index: 1;
  1348. left: 20px;
  1349. }
  1350. /*显示文字*/
  1351. .el-switch__label.is-active {
  1352. display: block;
  1353. }
  1354. .el-switch .el-switch__core,
  1355. .el-switch .el-switch__label {
  1356. width: 50px !important;
  1357. }
  1358. .el-switch__label * {
  1359. font-size: 13px !important;
  1360. }
  1361. }
  1362. </style>