{"version":3,"sources":["webpack:///./src/views/Finance/CalculatorVersion.vue?60b5","webpack:///./src/views/Finance/CalculatorVersion.vue?a681","webpack:///./src/views/Finance/data.ts","webpack:///./src/views/Finance/CalculatorVersion.vue","webpack:///./src/views/Finance/CalculatorVersion.vue?9794","webpack:///./src/API/finance.ts"],"names":["_hoisted_1","class","_hoisted_2","style","_hoisted_3","_hoisted_4","_hoisted_5","_hoisted_6","_hoisted_7","_hoisted_8","_hoisted_9","render","_ctx","_cache","$props","$setup","$data","$options","_component_Breadcrumb","_component_a_button","_component_a_tab_pane","_component_a_tabs","_component_a_table","dataSource","name","onClick","handleDownload","default","_","handleExtendAll","disabled","selectedRowKeys","length","type","handleSearch","activeKey","$event","onChange","cutTabs","sheetArr","sheet","key","tab","columns","pagination","onSelectChange","rowKey","data","programVersion","rowClassName","record","index","timestemp","text","moment","format","verCompareList","ver","version","currentVersion","columnsVersion","scroll","x","versionKey","rowIndex","showText","includes","substring","indexOf","title","dataIndex","slots","customRender","width","columnsFlarr","columnsEnd","finanArrCopy","deepClone","splice","columnsFinan","concat","columnsFl","push","columnsEqcEnd","columnsCopy","columnsEq","columnsEqCopy","columnsEqfl","setup","route","getTable","sheetName","params","programId","query","pgmId","then","res","value","selected","init","configColumns","forEach","item","assignColumns","bu","arr","filter","url","method","blobDownload","__exports__","getFileList","getCalculatorOperation","updateState","configParams","status","offer","offerType","brand","customerType","saveStatus","getmappedAll","saveFaSetting","buId","tableId","getVersionList","getVersionCompareList","getEstimatedPerReg","getCustomerType","getCalculatorMaintain","getSelectVehicle","getBrandList","property","getCurrentUserBrands","getAllBu","getBrandByBu","getTypeModelYearList","deleteCalculator","uploadCalculator","formData","validateCalculator"],"mappings":"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","file":"js/chunk-37874756.76ee8643.js","sourcesContent":["export * from \"-!../../../node_modules/mini-css-extract-plugin/dist/loader.js??ref--9-oneOf-1-0!../../../node_modules/@vue/cli-service/node_modules/css-loader/dist/cjs.js??ref--9-oneOf-1-1!../../../node_modules/@vue/cli-service/node_modules/vue-loader-v16/dist/stylePostLoader.js!../../../node_modules/postcss-loader/src/index.js??ref--9-oneOf-1-2!../../../node_modules/sass-loader/dist/cjs.js??ref--9-oneOf-1-3!../../../node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../node_modules/@vue/cli-service/node_modules/vue-loader-v16/dist/index.js??ref--1-1!./CalculatorVersion.vue?vue&type=style&index=0&id=3f8692d4&lang=scss\"","import { resolveComponent as _resolveComponent, createVNode as _createVNode, createTextVNode as _createTextVNode, withCtx as _withCtx, createElementVNode as _createElementVNode, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, createBlock as _createBlock, toDisplayString as _toDisplayString, normalizeClass as _normalizeClass, createCommentVNode as _createCommentVNode } from \"vue\"\n\nconst _hoisted_1 = { class: \"bg-fff p-l-r-10\" }\nconst _hoisted_2 = { style: {\"position\":\"relative\"} }\nconst _hoisted_3 = { style: {\"position\":\"absolute\",\"right\":\"10px\",\"z-index\":\"10\"} }\nconst _hoisted_4 = /*#__PURE__*/_createTextVNode(\"Download\")\nconst _hoisted_5 = /*#__PURE__*/_createTextVNode(\"Extend All\")\nconst _hoisted_6 = /*#__PURE__*/_createTextVNode(\"Search\")\nconst _hoisted_7 = { class: \"bg-fff m-10 p-10\" }\nconst _hoisted_8 = { class: \"bg-fff m-10 p-10\" }\nconst _hoisted_9 = { style: {\"margin\":\"10px 0\"} }\n\nexport function render(_ctx: any,_cache: any,$props: any,$setup: any,$data: any,$options: any) {\n const _component_Breadcrumb = _resolveComponent(\"Breadcrumb\")!\n const _component_a_button = _resolveComponent(\"a-button\")!\n const _component_a_tab_pane = _resolveComponent(\"a-tab-pane\")!\n const _component_a_tabs = _resolveComponent(\"a-tabs\")!\n const _component_a_table = _resolveComponent(\"a-table\")!\n\n return (_openBlock(), _createElementBlock(\"div\", null, [\n _createVNode(_component_Breadcrumb, { dataSource: [{name: 'Calculator Version'}] }),\n _createElementVNode(\"div\", _hoisted_1, [\n _createElementVNode(\"div\", _hoisted_2, [\n _createElementVNode(\"div\", _hoisted_3, [\n _createVNode(_component_a_button, {\n class: \"m-r-8\",\n onClick: _ctx.handleDownload\n }, {\n default: _withCtx(() => [\n _hoisted_4\n ]),\n _: 1\n }, 8, [\"onClick\"]),\n _createVNode(_component_a_button, {\n class: \"m-r-8\",\n onClick: _ctx.handleExtendAll\n }, {\n default: _withCtx(() => [\n _hoisted_5\n ]),\n _: 1\n }, 8, [\"onClick\"]),\n _createVNode(_component_a_button, {\n class: \"f-r\",\n disabled: !_ctx.selectedRowKeys || _ctx.selectedRowKeys.length === 0,\n type: !_ctx.selectedRowKeys || _ctx.selectedRowKeys.length === 0 ? '' : 'primary',\n onClick: _ctx.handleSearch\n }, {\n default: _withCtx(() => [\n _hoisted_6\n ]),\n _: 1\n }, 8, [\"disabled\", \"type\", \"onClick\"])\n ])\n ]),\n _createVNode(_component_a_tabs, {\n activeKey: _ctx.activeKey,\n \"onUpdate:activeKey\": _cache[0] || (_cache[0] = ($event: any) => ((_ctx.activeKey) = $event)),\n onChange: _ctx.cutTabs\n }, {\n default: _withCtx(() => [\n (_openBlock(true), _createElementBlock(_Fragment, null, _renderList(_ctx.sheetArr, (sheet) => {\n return (_openBlock(), _createBlock(_component_a_tab_pane, {\n key: sheet,\n tab: sheet\n }, null, 8, [\"tab\"]))\n }), 128))\n ]),\n _: 1\n }, 8, [\"activeKey\", \"onChange\"])\n ]),\n _createElementVNode(\"div\", _hoisted_7, [\n _createVNode(_component_a_table, {\n columns: _ctx.columns,\n pagination: false,\n \"row-selection\": { selectedRowKeys: _ctx.selectedRowKeys, onChange: _ctx.onSelectChange },\n \"data-source\": _ctx.dataSource,\n rowKey: (data) => data.programVersion,\n class: \"clearfix\",\n rowClassName: (record, index) => (index % 2 === 1 ? 'table-striped' : null)\n }, {\n timestemp: _withCtx(({text}) => [\n _createTextVNode(_toDisplayString(_ctx.moment(text).format('YYYY-MM-DD HH:mm:ss')), 1)\n ]),\n _: 1\n }, 8, [\"columns\", \"row-selection\", \"data-source\", \"rowKey\", \"rowClassName\"])\n ]),\n (_openBlock(true), _createElementBlock(_Fragment, null, _renderList(_ctx.verCompareList, (ver, index) => {\n return (_openBlock(), _createElementBlock(\"div\", { key: index }, [\n _createElementVNode(\"div\", _hoisted_8, [\n _createElementVNode(\"p\", _hoisted_9, \"Version \" + _toDisplayString(ver.version) + \" \" + _toDisplayString(ver.version === ver.currentVersion ? '(Current)' : ''), 1),\n _createVNode(_component_a_table, {\n columns: _ctx.columnsVersion,\n pagination: false,\n scroll: {x: 800},\n \"data-source\": ver[_ctx.versionKey[_ctx.activeKey]],\n rowKey: (data,rowIndex) => rowIndex,\n class: \"clearfix self-table-text\",\n rowClassName: (record, index) => (index % 2 === 1 ? 'table-striped' : null)\n }, {\n showText: _withCtx(({text}) => [\n text\n ? (_openBlock(), _createElementBlock(\"span\", {\n key: 0,\n class: _normalizeClass({'color-r2 unlink-style': text.includes('@')})\n }, _toDisplayString(text.includes('@')? text.substring(0, text.indexOf('@')) : text), 3))\n : _createCommentVNode(\"\", true)\n ]),\n _: 2\n }, 1032, [\"columns\", \"data-source\", \"rowKey\", \"rowClassName\"])\n ])\n ]))\n }), 128))\n ]))\n}","import deepClone from \"@/utils/deepClone\";\nconst columns = [\n {\n title: \"Type Class\",\n dataIndex: \"typeClassName\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Type Class Code\",\n dataIndex: \"typeClassCode\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Model Year\",\n dataIndex: \"modelYear\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Type\",\n dataIndex: \"type\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Nst Group Name\",\n dataIndex: \"nstGroupName\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Model\",\n dataIndex: \"model\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"MSRP\",\n dataIndex: \"msrp\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Transaction Price\",\n dataIndex: \"transactionPrice\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n\n // EQC 有个不一样的\n {\n title: \"Service Package\",\n dataIndex: \"servicePackage\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Term\",\n dataIndex: \"term\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Bill Rate\",\n dataIndex: \"billRate\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n // EQC 有 3 个不一样的 、 fl finan 有个 customer Rate\n // if (agilty) RV RV Amount / BAll\n];\n\nconst columnsFlarr = [\n {\n title: \"Customer Rate\",\n dataIndex: \"customerRate\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Pre-payment%\",\n dataIndex: \"prePaymentPer\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"RV%\",\n dataIndex: \"rvPer\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Balloon%\",\n dataIndex: \"balloonPer\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n];\n\nconst columnsEnd = [\n {\n title: \"DP Amount\",\n dataIndex: \"dpAmount\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Loan Amount\",\n dataIndex: \"loanAmount\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Balloon Amount\",\n dataIndex: \"balloonAmount\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Monthly Payment\",\n dataIndex: \"monthlyPayment\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Subsidy to MSRP/1.13\",\n dataIndex: \"subsidyToMsrpDivideOnedotthirteen\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Total Subsidy Amount\",\n dataIndex: \"totalSubsidyAmount\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Product Mix\",\n dataIndex: \"productMix\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Rounding subsidy\",\n dataIndex: \"roundingSubsidy\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n];\n\nconst finanArrCopy = deepClone(columnsFlarr);\nfinanArrCopy.splice(1, 2, {\n title: \"Down payment%\",\n dataIndex: \"downPaymentPer\",\n slots: { customRender: \"showText\" },\n width: 130,\n});\n// Financing\nlet columnsFinan = finanArrCopy;\ncolumnsFinan = columns.concat(columnsFinan).concat(columnsEnd);\n\n// FL with balloon\nconst columnsFl = columns.concat(columnsFlarr).concat(columnsEnd);\ncolumnsFl.push({\n title: \"Daily Pay\",\n dataIndex: \"dailyPay\",\n slots: { customRender: \"showText\" },\n width: 130,\n});\n\nconst columnsEqcEnd = [\n {\n title: \"Customer Rate Before DBD\",\n dataIndex: \"customerRateDeforeDbd\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Customer Rate After DBD\",\n dataIndex: \"customerRateAfterDbd\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Pre-payment%\",\n dataIndex: \"prePaymentPer\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n // dddd\n {\n title: \"RV%\",\n dataIndex: \"rvPer\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"RV Amount\",\n dataIndex: \"rvAmount\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n //\n {\n title: \"DP Amount\",\n dataIndex: \"dpAmount\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Loan Amount\",\n dataIndex: \"loanAmount\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Monthly Payment Before DBD\",\n dataIndex: \"monthlyPaymentBeforeDbd\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Monthly Payment Before DBD\",\n dataIndex: \"monthlyPaymentAfterDbd\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Subsidy to MSRP/1.13\",\n dataIndex: \"subsidyToMsrpDivideOnedotthirteen\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Subsidy to Amount By OEM\",\n dataIndex: \"subsidyAmountDyOem\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Subsidy Amount By Dealer\",\n dataIndex: \"subsidyAmountDyDealer\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Total Subsidy Amount\",\n dataIndex: \"totalSubsidyAmount\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Dealer Subsidy Portion\",\n dataIndex: \"dealerSubsidyPortion\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Product Mix\",\n dataIndex: \"productMix\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"OEM Rounding subsidy\",\n dataIndex: \"oemRoundingSubsidy\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Faily Pay\",\n dataIndex: \"dailyPay\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n];\n\n// EQC Agility\nconst columnsCopy = deepClone(columns);\ncolumnsCopy.splice(7, 0, {\n title: \"Net Vehicle Price\",\n dataIndex: \"netVehiclePrice\",\n slots: { customRender: \"showText\" },\n width: 130,\n});\nconst columnsEq = columnsCopy.concat(columnsEqcEnd);\n\nconst columnsEqCopy = deepClone(columnsEqcEnd);\ncolumnsEqCopy.splice(\n 3,\n 2,\n {\n title: \"Balloon%\",\n dataIndex: \"balloonPer\",\n slots: { customRender: \"showText\" },\n width: 130,\n },\n {\n title: \"Balloon Amount\",\n dataIndex: \"balloonAmount\",\n slots: { customRender: \"showText\" },\n width: 130,\n }\n);\nconst columnsEqfl = columnsCopy.concat(columnsEqCopy);\nexport { columnsFinan, columnsFl, columnsEq, columnsEqfl };\n","\nimport { defineComponent, onMounted, ref } from 'vue'\nimport { getVersionList, getVersionCompareList } from '@/API/finance'\nimport blobDownload from '@/utils/blobDownload'\nimport { columnsFinan, columnsFl, columnsEq, columnsEqfl } from './data'\nimport { ColmunsProps, } from '@/API/types'\nimport { useRoute } from 'vue-router';\n\nimport moment from \"moment\";\n\nconst columns = [\n {\n title: 'Version History',\n dataIndex: 'programVersion',\n key: 'programVersion'\n },\n {\n title: 'Modified By',\n dataIndex: 'createUser',\n key: 'createUser'\n },\n {\n title: 'Modified On',\n dataIndex: 'uploadDate',\n key: 'uploadDate',\n slots: {customRender: 'timestemp'}\n }\n]\n\ninterface VersionParams {\n typeClass: string;\n modelYear: string;\n sheetName: string;\n brand: string;\n versionList: string[];\n}\nconst versionKey = {\n 'Financing': 'calculatorCompareDtos',\n 'FL with Balloon': 'calculatorFLCompareDtos',\n 'NEV Agility': 'calculatorEQCCompareDtos',\n 'NEV FL with Balloon': 'calculatorEQCCompareDtos'\n}\nexport default defineComponent({\n name: '',\n setup() {\n // sheet 页的数据\n // 导航的数据\n const sheetArr = ref(['Financing', 'FL with Balloon', 'NEV Agility', 'NEV FL with Balloon'])\n const activeKey = ref()\n const route = useRoute()\n // 表格的数据\n const dataSource = ref()\n const getTable = (sheetName = 'Financing') => {\n \n const params = {\n programId: route.query.pgmId\n }\n getVersionList({params}).then((res: any) => {\n dataSource.value = res[sheetName]\n }) \n }\n \n // 配置选择框\n const selectedRowKeys = ref([])\n const onSelectChange = (selected: string[]) => {\n selectedRowKeys.value = selected\n }\n\n const init = async() => {\n // 获取sheet页数据\n // sheetArr.value = await getSheetAllAtfasetting()\n activeKey.value = sheetArr.value[0]\n getTable()\n }\n\n const columnsVersion = ref([])\n \n const configColumns = (data: any) => {\n columnsVersion.value = []\n data.forEach((item: {}) => {\n for (const key in item) {\n columnsVersion.value.push({\n title: item[key],\n dataIndex: key\n })\n }\n })\n }\n\n // 给columnsV 赋值\n const assignColumns = () => {\n if (activeKey.value === 'Financing') {\n columnsVersion.value = columnsFinan\n } else if (activeKey.value === 'FL with Balloon') {\n columnsVersion.value = columnsFl\n } else if (activeKey.value === 'NEV Agility') {\n columnsVersion.value = columnsEq\n } else if (activeKey.value === 'NEV FL with Balloon') {\n columnsVersion.value = columnsEqfl \n } \n }\n\n const verCompareList = ref()\n const handleSearch = () => {\n const {pgmId: programId, bu} = route.query\n const arr = dataSource.value.filter((item: any) => (selectedRowKeys.value).includes(item.programVersion))\n getVersionCompareList(programId as string, bu as string ,arr).then((res: any) => {\n verCompareList.value = res\n if (res[0].title.length === 0) {\n assignColumns()\n } else {\n configColumns(res[0].title)\n }\n })\n }\n\n // 获取全部的table数据\n const handleExtendAll = () => {\n assignColumns()\n }\n\n // 下载当前勾选的版本数据\n const handleDownload = () => {\n const arr = dataSource.value.filter((item: any) => (selectedRowKeys.value).includes(item.programVersion))\n arr.forEach((item: any) => {\n const params = { \n url: `/pgapi/prog/setting/fa/downloadFile`,\n method: 'post',\n params: item\n }\n blobDownload(params)\n })\n }\n\n // 切换sheet\n const cutTabs = (sheetName: string) => {\n getTable(sheetName)\n verCompareList.value = []\n selectedRowKeys.value = []\n }\n onMounted(() => {\n init()\n })\n return {\n sheetArr,\n activeKey,\n cutTabs,\n\n columns,\n dataSource,\n // rowSelection,\n selectedRowKeys,\n onSelectChange,\n\n handleSearch,\n verCompareList,\n\n columnsVersion,\n handleDownload,\n handleExtendAll,\n moment,\n versionKey\n\n\n }\n\n }\n });\n","import { render } from \"./CalculatorVersion.vue?vue&type=template&id=3f8692d4&ts=true\"\nimport script from \"./CalculatorVersion.vue?vue&type=script&lang=ts\"\nexport * from \"./CalculatorVersion.vue?vue&type=script&lang=ts\"\n\nimport \"./CalculatorVersion.vue?vue&type=style&index=0&id=3f8692d4&lang=scss\"\n\nimport exportComponent from \"/app/node_modules/@vue/cli-service/node_modules/vue-loader-v16/dist/exportHelper.js\"\nconst __exports__ = /*#__PURE__*/exportComponent(script, [['render',render]])\n\nexport default __exports__","import { fetchGet, fetchPost, fetchPostPic } from './index';\nimport { MaintainTablelProps, MaintainBrandProps, FaSettingTableProps } from '@/views/Finance/types';\ninterface FileProps {\n excelName: string;\n sourceFilePath: string;\n}\n// 获取 fa maintain的数据\nexport const getMaintainNormal = (params = {}): Promise => {\n return fetchGet('/pgapi/prog/setting/fa/normal', params);\n};\n\nexport const getMaintainRetention = (params = {}): Promise => {\n return fetchGet('/pgapi/prog/setting/fa/retention', params);\n};\n\n// 获取 fa maintain 中 brand 下拉内容\nexport const getMaintainBrand = (params = {}): Promise => {\n return fetchGet('/pgapi/prog/setting/fa/brand', params);\n};\n\n// 获取下载文件的列表\nexport const getFileList = (params = {}): Promise => {\n return fetchGet('pgapi/prog/setting/fa/getFileList', params);\n};\n\n// 获取 fa confirm 的数据 ---- confirm/re open\nexport const getCalculatorOperation = (params = {}): Promise => {\n return fetchGet('/pgapi/prog/setting/fa/calculator', params);\n};\n\n// 更改 fa 状态\nexport const updateState = (configParams: any, params = {}) => {\n const { status, offer, offerType, brand, bu, customerType } = configParams;\n let saveStatus = '';\n if (status === 'unconfirm') {\n saveStatus = 'confirm';\n } else if (status === 'confirm') {\n saveStatus = 'reopen';\n } else if (status === 'reopen') {\n saveStatus = 'unconfirm';\n }\n return fetchPost(\n `/pgapi/prog/setting/fa/updateState?status=${saveStatus}&offer=${offer}&offerType=${offerType}&brand=${brand}&bu=${bu}&customerType=${customerType}`,\n params\n );\n};\n\n// 获取fa setting 的数据 初始化时\nexport const getmappedAll = (params = {}): Promise => {\n return fetchGet('/pgapi/setting/commu_stting/findCommuSet', params);\n};\n\n// 保存fa setting 的配置\nexport const saveFaSetting = (\n brand: string,\n buId: string,\n sheetName: string,\n programId: string | number,\n tableId: string | number,\n params = {}\n) => {\n return fetchPost(`pgapi/setting/commu_stting/${brand}/${buId}/${sheetName}/${programId}/${tableId}/save`, params);\n};\n\n// 查询version 信息\nexport const getVersionList = (params = {}) => {\n return fetchGet('/pgapi/prog/setting/fa/getVersionList', params);\n};\n\n// 查询版本对比信息\nexport const getVersionCompareList = (programId: string, bu: string, params = {}) => {\n return fetchPost(`/pgapi/prog/setting/fa/getVersionCompareList/${programId}/${bu}`, params);\n};\n\n// 查询百分比的数据 regular\nexport const getEstimatedPerReg = (params = {}): Promise => {\n return fetchGet('/pgapi/prog/setting/fa/estimated_penetration_regular', params);\n};\n\n// 查询百分比的数据 retention\nexport const getEstimatedPerRet = (params = {}): Promise => {\n return fetchGet('/pgapi//prog/setting/fa/estimated_penetration_retention', params);\n};\n\n// 上传excel文件\nexport const uploadPer = (params = {}) => {\n return fetchPost(`/pgapi/prog/setting/fa/upload_estimated_penetration`, params);\n};\n\n// 获取Customer Type\nexport const getCustomerType = (): Promise => {\n return fetchGet('/pgapi/program/setting/get_customer_type');\n};\n\nexport const getCalculatorMaintain = (params = {}): Promise => {\n return fetchGet('/pgapi/prog/setting/fa/calculatorMaintain', params);\n};\n\n// 获取type class 和 model的关系\nexport const getSelectVehicle = (params = {}) => {\n return fetchGet('/pgapi/prog/setting/fa/selectVehicle', { params });\n};\n\n// 获取brand list\nexport const getBrandList = () => {\n const params = {\n property: 'brand'\n };\n return fetchGet('/vapi/get_property_lov', { params });\n};\n\nexport const getCurrentUserBrands = (): Promise => {\n return fetchGet('/vapi/noAuth/currentUserBrands');\n};\n\n// 获取bu list\nexport const getAllBu = () => {\n return fetchGet('/usapi/users/bu/selected');\n};\n\n// 根据bu 获取brand\nexport const getBrandByBu = (params = {}) => {\n return fetchPost('/pgapi/program/design/search_eligible_vehicle', params);\n};\n\n// 获取typeclass model year的关系\nexport const getTypeModelYearList = (params = {}) => {\n return fetchGet('/pgapi/program_approval/selectVehicle', { params });\n};\n\n// oasis-25929 delete 计算器\nexport const deleteCalculator = (configParams: any, params = {}) => {\n const { offer, offerType, brand, bu, customerType } = configParams;\n return fetchPost(\n `/pgapi/prog/setting/fa/delete_calculator?offer=${offer}&offerType=${offerType}&brand=${brand}&bu=${bu}&customerType=${customerType}`,\n params\n );\n};\n\nexport const uploadCalculator = (formData: FormData, params: any): Promise => {\n return fetchPostPic(`/pgapi/prog/setting/fa/upload_calculator`, formData, {\n params\n });\n};\n\nexport const validateCalculator = (formData: FormData, params: any): Promise => {\n return fetchPost(`/pgapi/prog/setting/fa/validate_calculator`, formData, {\n params\n });\n};\n"],"sourceRoot":""}