You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

693 lines
21 KiB

7 months ago
5 months ago
5 months ago
5 months ago
5 months ago
5 months ago
5 months ago
5 months ago
5 months ago
5 months ago
5 months ago
5 months ago
5 months ago
5 months ago
5 months ago
5 months ago
5 months ago
5 months ago
5 months ago
  1. <script setup>
  2. import { computed, onMounted, ref, watch, nextTick } from 'vue'
  3. import { dayjs, ElMessage } from 'element-plus'
  4. import request from '@/util/http.js'
  5. import API from '@/util/http.js'
  6. import moment from 'moment'
  7. import { useAdminStore } from "@/store/index.js";
  8. import { storeToRefs } from "pinia";
  9. const adminStore = useAdminStore();
  10. const { flag } = storeToRefs(adminStore);
  11. // 国际化
  12. import { useI18n } from 'vue-i18n';
  13. const { t } = useI18n();
  14. // 监听全局flag状态变化
  15. watch(flag, (newFlag, oldFlag) => {
  16. // 当flag状态改变时,重新发送请求
  17. if (newFlag !== oldFlag) {
  18. ConsumeSelectBy()
  19. }
  20. })
  21. // 之后整理一下
  22. /*
  23. ====================工具方法==============================
  24. */
  25. const format3 = (num) => {
  26. // 每三位添加逗号
  27. return num.toLocaleString('en-US')
  28. }
  29. // 时间格式化
  30. const formatTime = (val) => val ? dayjs(val).format('YYYY-MM-DD HH:mm:ss') : ''
  31. const defaultTime = [
  32. new Date(2000, 1, 1, 0, 0, 0),
  33. new Date(2000, 2, 1, 23, 59, 59),
  34. ]
  35. /*
  36. ====================数据=================================
  37. */
  38. //这是获取用户信息的接口
  39. const adminData = ref({})
  40. // 充值明细表格
  41. const tableData = ref([])
  42. const tableRef = ref(null)
  43. const scrollTableTop = () => {
  44. tableRef.value?.setScrollTop?.(0)
  45. }
  46. // 搜索beanConsumeFan 表单
  47. const beanConsumeFan = ref({
  48. jwcode: null,
  49. dept: "",
  50. type: "",
  51. gift: "",
  52. channel: "",
  53. liveRoom: "",
  54. startTime: '',
  55. endTime: '',
  56. })
  57. // 频道列表
  58. const channels = ref([])
  59. // 获取频道列表的方法
  60. const getChannel = async function () {
  61. try {
  62. const result = await request({
  63. url: '/beanConsume/getLiveChannel', // todo 换成实际接口地址
  64. data: { account: adminData.value.account }
  65. })
  66. console.log('请求频道列表成功', result)
  67. // 存储频道数据
  68. channels.value = result.data
  69. console.log('频道数据', channels.value)
  70. } catch (error) {
  71. console.log('请求频道列表失败', error)
  72. ElMessage({
  73. type: 'error',
  74. message: t('elmessage.getChannelListFailed')
  75. })
  76. }
  77. }
  78. // // 频道模糊查询方法
  79. // const filterChannel = (query) => {
  80. // if (query) {
  81. // return channels.value.filter(item => item.toLowerCase().includes(query.toLowerCase()));
  82. // }
  83. // return channels.value;
  84. // };
  85. // 抽离类型选项到响应式数组
  86. const consumeTypes = ref([
  87. { label: t('consume.consumeTypes.1'), value: 1 },
  88. { label: t('consume.consumeTypes.2'), value: 2 },
  89. { label: t('consume.consumeTypes.3'), value: 3 },
  90. { label: t('consume.consumeTypes.4'), value: 4 },
  91. { label: t('consume.consumeTypes.5'), value: 5 },
  92. { label: t('consume.consumeTypes.6'), value: 6 },
  93. { label: t('consume.consumeTypes.7'), value: 7 },
  94. { label: t('consume.consumeTypes.8'), value: 8 }
  95. ])
  96. // // 处理类型选择变化
  97. // const handleTypeChange = (value) => {
  98. // if (value !== 1) {
  99. // beanConsumeFan.value.gift = ''
  100. // }
  101. // }
  102. //------------------------
  103. // 标记当前激活的时间范围按钮
  104. const activeTimeRange = ref('')
  105. // 日期选择器变化时清除按钮激活状态
  106. const handleDatePickerChange = () => {
  107. activeTimeRange.value = ''
  108. }
  109. // 搜索对象
  110. const getObj = ref({
  111. pageNum: 1,
  112. pageSize: 50
  113. })
  114. //分页总条目
  115. const total = ref(100)
  116. // 搜索对象时间
  117. const getTime = ref({
  118. startTime: '',
  119. endTime: ''
  120. })
  121. // 搜索活动列表
  122. // const activity = ref([])
  123. // 搜索地区列表
  124. const dept = ref([])
  125. // 新增排序字段和排序方式
  126. const sortField = ref('')
  127. const sortOrder = ref('')
  128. // 合计数
  129. const permanentBean = ref(0)
  130. const freeBean = ref(0)
  131. const totalNum = ref(0)
  132. /*
  133. ====================方法=================================
  134. */
  135. // 获取登录用户信息
  136. const getAdminData = async function () {
  137. try {
  138. const result = await request({
  139. url: '/admin/userinfo',
  140. data: {}
  141. })
  142. adminData.value = result
  143. console.log('请求成功', result)
  144. console.log('用户信息', adminData.value)
  145. } catch (error) {
  146. console.log('请求失败', error)
  147. }
  148. }
  149. const ConsumeSelectBy = async function (val) {
  150. try {
  151. // 搜索参数页码赋值
  152. if (typeof val === 'number') {
  153. getObj.value.pageNum = val
  154. }
  155. // 搜索参数时间赋值
  156. if (getTime.value != null) {
  157. if (getTime.value.startTime != '' && getTime.value.endTime != '') {
  158. beanConsumeFan.value.startTime = formatTime(getTime.value[0])
  159. beanConsumeFan.value.endTime = formatTime(getTime.value[1])
  160. }
  161. } else {
  162. beanConsumeFan.value.startTime = ''
  163. beanConsumeFan.value.endTime = ''
  164. }
  165. beanConsumeFan.value.sortField = sortField.value
  166. beanConsumeFan.value.sortOrder = sortOrder.value
  167. console.log('搜索参数_时间', beanConsumeFan.value.startTime)
  168. console.log('搜索参数1', getObj.value)
  169. console.log('搜索参数2', beanConsumeFan.value)
  170. // 发送POST请求
  171. const result = await request({
  172. url: '/beanConsume/selectFanBy',
  173. data: {
  174. pageNum: getObj.value.pageNum,
  175. pageSize: getObj.value.pageSize,
  176. beanConsumeFan: {
  177. ...beanConsumeFan.value,
  178. jwcode: beanConsumeFan.value.jwcode ? String(beanConsumeFan.value.jwcode) : '',
  179. dept: beanConsumeFan.value.dept || '',
  180. channel: beanConsumeFan.value.channel || '',
  181. startTime: beanConsumeFan.value.startTime || '',
  182. endTime: beanConsumeFan.value.endTime || '',
  183. sortField: beanConsumeFan.value.sortField || 'consumeTime',
  184. sortOrder: beanConsumeFan.value.sortOrder || 'desc',
  185. flag: flag.value,
  186. roleId: adminData.value.roleId
  187. }
  188. }
  189. })
  190. console.log('请求成功3', sortField)
  191. console.log('接口响应结果', result);
  192. if (result.code === 200 && result.data && result.data.list) {
  193. tableData.value = result.data.list;
  194. await nextTick()
  195. scrollTableTop()
  196. total.value = result.data.total;
  197. }
  198. // 合计数的接口
  199. // 复制一份 beanConsumeFan.value 并设置固定的 payType 值 1是直播 7是铁粉
  200. const sumConsumeParams = {
  201. payType: 7, // 固定传入 payType 值 7
  202. beanConsumeFan: {
  203. ...beanConsumeFan.value,
  204. roleId: adminData.value.roleId,
  205. flag: flag.value
  206. }
  207. };
  208. // 发送 POST 请求获取合计数
  209. const resultTotalGold = await request({
  210. url: '/beanConsume/sumConsumeGold',
  211. data: sumConsumeParams
  212. });
  213. console.log("总计2", resultTotalGold);
  214. const data = resultTotalGold.data || resultTotalGold;
  215. console.log('请求成功2', resultTotalGold.data)
  216. console.log('permanentBean2', data.permanentBean)
  217. // 返回字段为 permanentBean、freeBean、totalNum
  218. permanentBean.value = Number(data.permanentBean) || 0;
  219. freeBean.value = Number(data.freeBean) || 0;
  220. totalNum.value = Number(data.totalNum) || 0;
  221. // 存储分页总数
  222. total.value = result.data.total
  223. console.log('total', total.value)
  224. } catch (error) {
  225. console.log('请求失败', error)
  226. }
  227. }
  228. // 搜索
  229. const search = function () {
  230. getObj.value.pageNum = 1
  231. if (beanConsumeFan.value.jwcode) {
  232. const numRef = /^\d{1,9}$/;
  233. if (!numRef.test(beanConsumeFan.value.jwcode)) {
  234. ElMessage.error(t('elmessage.checkJwcodeFormat'))
  235. return
  236. }
  237. }
  238. ConsumeSelectBy()
  239. }
  240. // 重置
  241. const reset = function () {
  242. console.log('兄弟,你点了重置')
  243. beanConsumeFan.value.jwcode = null
  244. beanConsumeFan.value.type = ''
  245. beanConsumeFan.value.gift = ''
  246. beanConsumeFan.value.channel = ''
  247. beanConsumeFan.value.liveRoom = ''
  248. beanConsumeFan.value.dept = ''
  249. beanConsumeFan.value.startTime = ''
  250. beanConsumeFan.value.endTime = ''
  251. sortField.value = ''
  252. sortOrder.value = ''
  253. getTime.value = {}
  254. activeTimeRange.value = '' // 清除激活状态
  255. // 重置页码
  256. getObj.value.pageNum = 1
  257. // 点完重置后,重新请求数据
  258. ConsumeSelectBy()
  259. console.log(' beanConsumeFan', beanConsumeFan.value)
  260. }
  261. // 今天
  262. const getToday = function () {
  263. const today = dayjs()
  264. const startTime = today.startOf('day').format('YYYY-MM-DD HH:mm:ss')
  265. const endTime = today.endOf('day').format('YYYY-MM-DD HH:mm:ss')
  266. getTime.value = [startTime, endTime]
  267. console.log('getTime', getTime.value)
  268. activeTimeRange.value = 'today' // 标记当前激活状态
  269. ConsumeSelectBy()
  270. }
  271. // 昨天
  272. const getYesterday = function () {
  273. const today = dayjs()
  274. const startTime = today.subtract(1, 'day').startOf('day').format('YYYY-MM-DD HH:mm:ss')
  275. const endTime = today.subtract(1, 'day').endOf('day').format('YYYY-MM-DD HH:mm:ss')
  276. getTime.value = [startTime, endTime]
  277. console.log('getTime', getTime.value)
  278. activeTimeRange.value = 'yesterday' // 标记当前激活状态
  279. console.log('昨', getTime.value)
  280. ConsumeSelectBy()
  281. }
  282. // 近7天
  283. const get7Days = function () {
  284. const today = dayjs()
  285. const startTime = today.subtract(6, 'day').startOf('day').format('YYYY-MM-DD HH:mm:ss')
  286. const endTime = today.endOf('day').format('YYYY-MM-DD HH:mm:ss')
  287. getTime.value = [startTime, endTime]
  288. console.log('getTime', getTime.value)
  289. activeTimeRange.value = '7days' // 标记当前激活状态
  290. ConsumeSelectBy()
  291. }
  292. // 获取地区列表的方法
  293. const getDept = async function () {
  294. try {
  295. // 发送请求获取地区列表
  296. const result = await request({
  297. // url: '/general/dept',
  298. url: '/beanConsume/getDept', // todo 换成实际接口地址
  299. data: { account: adminData.value.account }
  300. })
  301. console.log('请求地区列表成功', result)
  302. // 存储地区数据
  303. dept.value = result.data
  304. console.log('地区数据', dept.value)
  305. } catch (error) {
  306. console.log('请求地区列表失败', error)
  307. ElMessage({
  308. type: 'error',
  309. message: t('elmessage.getRegionListFailed')
  310. })
  311. }
  312. }
  313. // 处理排序事件
  314. const handleSortChange = (column) => {
  315. console.log('排序字段:', column.prop)
  316. console.log('排序方式:', column.order)
  317. if (column.prop === 'beanNum') {
  318. sortField.value = 'beanNum'
  319. } else if (column.prop === 'consumeTime') {
  320. sortField.value = 'consumeTime'
  321. } else if (column.prop === 'buyBean') {
  322. sortField.value = 'buyBean'
  323. } else if (column.prop === 'freeBean') {
  324. sortField.value = 'freeBean'
  325. }
  326. sortOrder.value = column.order === 'ascending' ? 'DESC' : 'ASC'
  327. ConsumeSelectBy()
  328. }
  329. const handlePageSizeChange = function (val) {
  330. getObj.value.pageSize = val
  331. ConsumeSelectBy()
  332. }
  333. const handleCurrentChange = function (val) {
  334. getObj.value.pageNum = val
  335. ConsumeSelectBy()
  336. }
  337. /*
  338. ====================计算属性=================================
  339. */
  340. // 计算总金币数
  341. // const totalBean = computed(() => permanentBean.value + freeBean.value)
  342. /*
  343. ====================监听=================================
  344. */
  345. /*
  346. ====================挂载=================================
  347. */
  348. onMounted(async function () {
  349. await getAdminData()
  350. await ConsumeSelectBy()
  351. await getChannel()
  352. await getDept()
  353. })
  354. const exportExcel = async function () {
  355. const params = { //需要修改
  356. ...getObj.value,
  357. "beanConsumeFan": {
  358. ...beanConsumeFan.value,
  359. sortField: sortField.value,
  360. sortOrder: sortOrder.value,
  361. roleId: adminData.value.roleId,
  362. flag: flag.value,
  363. },
  364. }
  365. try {
  366. const res = await API({url: '/export/exportFan', data: params});
  367. if (res.code === 200) {
  368. ElMessage.success(t('elmessage.exportSuccess'));
  369. } else {
  370. ElMessage.error(res.message || t('elmessage.exportFailed'));
  371. }
  372. } catch (error) {
  373. console.error('导出请求出错:', error);
  374. ElMessage.error(t('elmessage.exportFailed'));
  375. }
  376. }
  377. const exportListVisible = ref(false)
  378. // 打开导出列表弹窗
  379. const openExportList = () => {
  380. getExportList()
  381. exportListVisible.value = true
  382. }
  383. // 导出列表数据
  384. const exportList = ref([])
  385. // 导出列表加载状态
  386. const exportListLoading = ref(false)
  387. // 获取导出列表
  388. const getExportList = async () => {
  389. exportListLoading.value = true
  390. try {
  391. const result = await API({ url: '/export/export' })
  392. if (result.code === 200) {
  393. const filteredData = result.data.filter(item => {
  394. return item.type === 7; //7是铁粉
  395. });
  396. exportList.value = filteredData
  397. } else {
  398. ElMessage.error(result.msg || t('elmessage.getExportListError'))
  399. }
  400. } catch (error) {
  401. console.error('获取导出列表出错:', error)
  402. ElMessage.error(t('elmessage.getExportListError'))
  403. } finally {
  404. exportListLoading.value = false
  405. }
  406. }
  407. // 下载导出文件
  408. const downloadExportFile = (item) => {
  409. if (item.state === 2) {
  410. const link = document.createElement('a')
  411. link.href = item.url
  412. link.download = item.fileName
  413. link.click()
  414. } else {
  415. ElMessage.warning(t('elmessage.exportingInProgress'))
  416. }
  417. }
  418. //根据状态返回对应的标签类型
  419. const getTagType = (state) => {
  420. switch (state) {
  421. case 0:
  422. return 'info';
  423. case 1:
  424. return 'primary';
  425. case 2:
  426. return 'success';
  427. case 3:
  428. return 'danger';
  429. default:
  430. return 'info';
  431. }
  432. }
  433. //根据状态返回对应的标签文案
  434. const getTagText = (state) => {
  435. switch (state) {
  436. case 0:
  437. return t('elmessage.pendingExecution');
  438. case 1:
  439. return t('elmessage.executing');
  440. case 2:
  441. return t('elmessage.executed');
  442. case 3:
  443. return t('elmessage.errorExecution');
  444. default:
  445. return t('elmessage.unknownStatus');
  446. }
  447. }
  448. </script>
  449. <template>
  450. <el-card class="card1" style="margin-bottom: 0.5vh;">
  451. <el-col style="margin-bottom: 1vh">
  452. <div class="select">
  453. <div class="selectRow">
  454. <el-text class="text">{{ t('common.jwcode') }}</el-text>
  455. <el-input class="selectContent" v-model="beanConsumeFan.jwcode" :placeholder="t('common.jwcodePlaceholder')" clearable />
  456. </div>
  457. <div class="selectRow">
  458. <el-text class="text">{{ t('common.market') }}</el-text>
  459. <el-select class="selectContent" v-model="beanConsumeFan.dept" :placeholder="t('common.marketPlaceholder')" clearable>
  460. <el-option v-for="(item, index) in dept" :key="index" :label="item" :value="item" />
  461. </el-select>
  462. </div>
  463. <div class="selectRow">
  464. <el-text class="text">{{ t('common.channel') }}</el-text>
  465. <el-select class="selectContent" v-model="beanConsumeFan.channel" :placeholder="t('common.channelPlaceholder')" clearable filterable>
  466. <el-option v-for="(item, index) in channels" :key="index" :label="item" :value="item" />
  467. </el-select>
  468. </div>
  469. </div>
  470. </el-col>
  471. <el-col>
  472. <div class="select">
  473. <div class="selectRow" style="width: 36vw;">
  474. <el-text class="text" size="large">{{ t('common.consumetime') }}</el-text>
  475. <el-date-picker class="selectContent" v-model="getTime" type="datetimerange" :range-separator="t('common.to')"
  476. :start-placeholder="t('common.startTime')" :end-placeholder="t('common.endTime')" style="margin-right:1vw;width:25vw"
  477. @change="handleDatePickerChange" value-format="YYYY-MM-DD HH:mm:ss" :default-time="defaultTime" />
  478. <div v-if="false">
  479. <el-button @click="getToday()" :type="activeTimeRange === 'today' ? 'primary' : ''"></el-button>
  480. <el-button @click="getYesterday()" :type="activeTimeRange === 'yesterday' ? 'primary' : ''"></el-button>
  481. <el-button @click="get7Days()" :type="activeTimeRange === '7days' ? 'primary' : ''">近7天</el-button>
  482. </div>
  483. </div>
  484. <div class="selectRow" style="justify-content: flex-start;">
  485. <el-button type="primary" @click="search()">{{ t('common.search') }}</el-button>
  486. <el-button type="primary" @click="exportExcel()">{{ t('common.exportExcel') }}</el-button>
  487. <el-button type="primary" @click="openExportList">{{ t('common.viewExportList') }}</el-button>
  488. <el-button type="success" @click="reset()">{{ t('common.reset') }}</el-button>
  489. </div>
  490. </div>
  491. </el-col>
  492. </el-card>
  493. <el-card class="card2">
  494. <div class="goldStatistics">
  495. {{ t('common.totalGoldBean') }}{{ format3(Math.abs(permanentBean + freeBean)) }}&nbsp;&nbsp;&nbsp;&nbsp;
  496. {{ t('common.payGoldBean') }}{{ format3(Math.abs(permanentBean)) }}&nbsp;&nbsp;&nbsp;&nbsp;
  497. {{ t('common.freeGoldBean') }}{{ format3(Math.abs(freeBean)) }}
  498. </div>
  499. <div style="overflow-y: auto">
  500. <el-table ref="tableRef" :data="tableData" style="width: 82vw" height="65vh" @sort-change="handleSortChange"
  501. :row-style="{ height: '50px' }">
  502. <el-table-column type="index" :label="t('common_list.id')" width="80px" fixed="left">
  503. <template #default="scope">
  504. <span>{{
  505. scope.$index + 1 + (getObj.pageNum - 1) * getObj.pageSize
  506. }}</span>
  507. </template>
  508. </el-table-column>
  509. <!-- 固定姓名列 -->
  510. <el-table-column prop="name" :label="t('common_list.name')" width="150px" fixed="left" show-overflow-tooltip />
  511. <!-- 固定精网号列 -->
  512. <el-table-column prop="jwcode" :label="t('common_list.jwcode')" width="110px" fixed="left" />
  513. <el-table-column prop="dept" :label="t('common_list.market')" width="120px" />
  514. <el-table-column prop="beanNum" :label="t('common_list.beanNum')" sortable="custom" width="120px" />
  515. <el-table-column prop="buyBean" :label="t('common_list.permanentBean')" sortable="custom" width="170px" />
  516. <el-table-column prop="freeBean" :label="t('common_list.freeBean')" sortable="custom" width="130px" />
  517. <el-table-column prop="channel" :label="t('common_list.channel')" width="190px" show-overflow-tooltip />
  518. <el-table-column prop="type" :label="t('common_list.memberType')" width="140px">
  519. <template #default="scope">
  520. {{consumeTypes.find(item => item.value === Number(scope.row.type))?.label || t('common_list.unknownType')}}
  521. </template>
  522. </el-table-column>
  523. <el-table-column prop="consumeTime" :label="t('common_list.joinTime')" sortable="custom" width="190px" />
  524. </el-table>
  525. </div>
  526. <!-- 分页 -->
  527. <div class="pagination">
  528. <el-pagination background :current-page="getObj.pageNum" :page-size="getObj.pageSize" :page-sizes="[5, 10, 20, 50, 100]"
  529. layout="total, sizes, prev, pager, next, jumper" :total="total" @size-change="handlePageSizeChange"
  530. @current-change="handleCurrentChange"></el-pagination>
  531. </div>
  532. </el-card>
  533. <!-- 导出弹窗 -->
  534. <el-dialog v-model="exportListVisible" :title="t('common_export.exportList')" width="80%">
  535. <el-table :data="exportList" style="width: 100% ;height: 60vh;" :loading="exportListLoading">
  536. <el-table-column prop="fileName" :label="t('common_export.fileName')" />
  537. <el-table-column prop="state" :label="t('common_export.status')">
  538. <template #default="scope">
  539. <el-tag :type="getTagType(scope.row.state)" :effect="scope.row.state === 3 ? 'light' : 'plain'">
  540. {{ getTagText(scope.row.state) }}
  541. </el-tag>
  542. </template>
  543. </el-table-column>
  544. <el-table-column prop="createTime" :label="t('common_export.createTime')">
  545. <template #default="scope">
  546. {{ moment(scope.row.createTime).format('YYYY-MM-DD HH:mm:ss') }}
  547. </template>
  548. </el-table-column>
  549. <el-table-column :label="t('common_export.operation')">
  550. <template #default="scope">
  551. <el-button type="primary" size="small" @click="downloadExportFile(scope.row)"
  552. :disabled="scope.row.state !== 2">
  553. {{ t('common_export.download') }}
  554. </el-button>
  555. </template>
  556. </el-table-column>
  557. </el-table>
  558. <template #footer>
  559. <div class="dialog-footer">
  560. <el-button text @click="exportListVisible = false">{{ t('common_export.close') }}</el-button>
  561. </div>
  562. </template>
  563. </el-dialog>
  564. </template>
  565. <style scoped lang="scss">
  566. // 搜索的卡片样式
  567. .card1 {
  568. background: #F3FAFE;
  569. }
  570. // 表单的卡片样式
  571. .card2 {
  572. background: #E7F4FD;
  573. }
  574. // 新币总数等等
  575. .goldStatistics {
  576. margin-left: 1vw;
  577. margin-bottom: 1vh;
  578. color: #000000;
  579. font-family: "PingFang SC";
  580. font-size: 16px;
  581. font-style: normal;
  582. font-weight: 700;
  583. line-height: 20px;
  584. }
  585. // 表头背景等
  586. :deep(.el-table__header-wrapper),
  587. :deep(.el-table__body-wrapper),
  588. :deep(.el-table__cell),
  589. /* 表格 */
  590. :deep(.el-table__body td) {
  591. background-color: #F3FAFE !important;
  592. }
  593. /* 表头 */
  594. :deep(.el-table__header th) {
  595. background-color: #F3FAFE !important;
  596. }
  597. /* 鼠标悬停 */
  598. :deep(.el-table__row:hover > .el-table__cell) {
  599. background-color: #E5EBFE !important;
  600. }
  601. .pagination {
  602. display: flex;
  603. margin-top: 20px;
  604. }
  605. /** 搜索的样式 */
  606. .select {
  607. display: flex;
  608. .selectRow {
  609. width: 17vw;
  610. display: flex;
  611. align-items: center;
  612. justify-content: center;
  613. padding: 0 0.5vw;
  614. .text {
  615. width: 5.3vw;
  616. font-size: 15px;
  617. }
  618. .selectContent {
  619. flex: 1;
  620. }
  621. }
  622. }
  623. </style>