detail-info.vue 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504
  1. <template>
  2. <view class="Info">
  3. <view class="selection">
  4. <div class="title">
  5. <!-- Tournament -->
  6. {{ $t('live.lab2') }}
  7. </div>
  8. <view class="list">
  9. <u-row justify="space-between" @click="$toUrl(`/pages/Match/match-list?id=${matchDetail.tournament_id}&title=${detail_info.tournament_name}&type=${detail_info.type}`)">
  10. <view class="selection-info">
  11. <view class="flex-start">
  12. <text class="size28 c3 Bold">
  13. {{detail_info.tournament_name}}
  14. </text>
  15. </view>
  16. </view>
  17. <image src="/static/image/match/next_ico@2x.png" mode="heightFix" class="detail-right"></image>
  18. </u-row>
  19. </view>
  20. </view>
  21. <view class="selection">
  22. <text class="title">
  23. <!-- Teams -->
  24. {{ $t('live.lab1') }}
  25. </text>
  26. <view class="list">
  27. <u-row justify="space-between" @click="$toUrl(`/pages/Match/teams/teams?id=${detail_info.home_id}&title=${detail_info.home_name}`)">
  28. <view class="selection-info">
  29. <image :src="detail_info.home_logo || '/static/image/common/team.png'" mode="aspectFit" class="mg-rt24"></image>
  30. <view class="flex-start">
  31. <text class="size28 c3 Bold">
  32. {{detail_info.home_name}}
  33. </text>
  34. <view class="mg-tp8">
  35. <!-- <text class="c6 size24 bgE5">TOSS</text> -->
  36. <!-- <text class="size26 c4">
  37. {{detail_info.home_member}}
  38. </text> -->
  39. </view>
  40. </view>
  41. </view>
  42. <image src="/static/image/match/next_ico@2x.png" mode="heightFix" class="detail-right"></image>
  43. </u-row>
  44. <u-row justify="space-between" @click="$toUrl(`/pages/Match/teams/teams?id=${detail_info.away_id}&title=${detail_info.away_name}`)">
  45. <view class="selection-info">
  46. <image :src="detail_info.away_logo || '/static/image/common/team.png'" mode="aspectFit" class="mg-rt24"></image>
  47. <view class="flex-start">
  48. <text class="size28 c3 Bold">
  49. {{detail_info.away_name}}
  50. </text>
  51. <view class="mg-tp8">
  52. <!-- <text class="c6 size24 bgE5">TOSS</text> -->
  53. <!-- <text class="size26 c4">
  54. {{detail_info.away_member}}
  55. </text> -->
  56. </view>
  57. </view>
  58. </view>
  59. <image src="/static/image/match/next_ico@2x.png" mode="heightFix" class="detail-right"></image>
  60. </u-row>
  61. </view>
  62. </view>
  63. <view class="selection">
  64. <text class="title">
  65. <!-- Match Details -->
  66. {{ $t('live.lab3') }}
  67. </text>
  68. <view class="list">
  69. <view class="list-item">
  70. <text class="label">
  71. <!-- Match -->
  72. {{ $t('live.lab4') }}
  73. </text>
  74. <view class="content">
  75. {{detail_info.match}}
  76. </view>
  77. </view>
  78. <view class="list-item">
  79. <text class="label">
  80. <!-- Match Start Time -->
  81. {{ $t('live.lab5') }}
  82. </text>
  83. <view class="content">
  84. {{detail_info.match_start_time}}
  85. </view>
  86. </view>
  87. <view class="list-item" v-if="detail_info.venue_name">
  88. <text class="label">
  89. <!-- Stadium/Venue -->
  90. {{ $t('live.lab6') }}
  91. </text>
  92. <view class="content cDE9">
  93. {{detail_info.venue_name || '-'}}
  94. </view>
  95. </view>
  96. <view class="list-item">
  97. <text class="label">
  98. <!-- Toss -->
  99. {{ $t('live.lab57') }}
  100. </text>
  101. <view class="content">
  102. {{detail_info.toss || '-'}}
  103. </view>
  104. </view>
  105. <!-- <view class="list-item">
  106. <text class="label">Match Officials</text>
  107. <view class="content">
  108. Hassan Adnan (On Field),Richard Kettleborough
  109. (On Field),Wayne Noon (referee)
  110. </view>
  111. </view> -->
  112. </view>
  113. </view>
  114. <view class="selection">
  115. <text class="title">
  116. <!-- Playing XI -->
  117. {{ $t('live.lab7') }}
  118. </text>
  119. <view class="list">
  120. <view class="list-item">
  121. <text class="label">{{detail_info.home_name}}</text>
  122. <view class="content1">
  123. {{detail_info.home_member}}
  124. </view>
  125. </view>
  126. <view class="list-item">
  127. <text class="label">{{detail_info.away_name}}</text>
  128. <view class="content1">
  129. {{detail_info.away_member}}
  130. </view>
  131. <view class="full">
  132. <!-- View Full Squad Info -->
  133. {{ $t('live.lab8') }}
  134. </view>
  135. </view>
  136. </view>
  137. </view>
  138. <view class="flex-end selection-table-title">
  139. <text class="label">
  140. <!-- Updated 12 hrs ago -->
  141. {{ $t('live.lab9') }}
  142. </text>
  143. </view>
  144. <view class="selection-table">
  145. <view >
  146. <!-- 表头行 -->
  147. <u-row class="tr-header">
  148. <view class="text-center">#</view>
  149. <view class="text-center">
  150. <!-- TEAM -->
  151. {{ $t('live.lab25') }}
  152. </view>
  153. <view class="text-center">P</view>
  154. <view class="text-center">W</view>
  155. <view class="text-center">L</view>
  156. <view class="text-center">NR</view>
  157. <view class="text-center">NRR</view>
  158. <view class="text-center">PTS</view>
  159. </u-row>
  160. <!-- 表格数据行 -->
  161. <view v-for="(item,index) in tournament_list" :key="index" :class="{actives:acIndex == index}">
  162. <u-line color="#CCCCCC"></u-line>
  163. <u-row @click="clickItem(index)">
  164. <view class="trc6">{{index+1}}</view>
  165. <view class="trc3">{{item.competitor || 0}}</view>
  166. <view class="trc6">{{item.p || 0}}</view>
  167. <view class="trc6">{{item.w || 0}}</view>
  168. <view class="trc6">{{item.l || 0}}</view>
  169. <view class="trc6">{{item.nr || 0}}</view>
  170. <view class="trc6">{{item.nrr || 0}}</view>
  171. <view>
  172. <view class="flex pts">
  173. <text class="trc3 size28 mg-rt30 Bold"> {{item.pts}} </text>
  174. <image src="/static/image/match/expert_down_ico.png" mode="aspectFill"></image>
  175. </view>
  176. </view>
  177. </u-row>
  178. <view class="table-item-content" :class="{'active': acIndex==index}">
  179. <view class="table-item-content-th">
  180. <text class="label">
  181. {{ $t('live.lab10') }}
  182. </text>
  183. <text class="label">
  184. {{ $t('live.lab11') }}
  185. </text>
  186. <text class="label">
  187. {{ $t('live.lab12') }}
  188. </text>
  189. <text class="label">
  190. {{ $t('live.lab13') }}
  191. </text>
  192. </view>
  193. <view class="table-item-content-tr" v-for="(item1,index1) in item.match" :key="index1">
  194. <text class="td">{{item1.competitor}}</text>
  195. <text class="td1">{{item1.date}}</text>
  196. <text class="td1">{{item1.venue_name}}</text>
  197. <text class="td1 overflow1" :class="classFilter(item1.winner) == 1">{{item1.match_result}}</text>
  198. </view>
  199. </view>
  200. </view>
  201. </view>
  202. <u-empty
  203. v-if="tournament_list.length == 0"
  204. mode="data"
  205. width="474"
  206. height="312"
  207. textSize="28"
  208. marginTop="100"
  209. :text="$t('common.nodata')"
  210. icon="/static/image/common/nodata.png"
  211. >
  212. </u-empty>
  213. </view>
  214. <view class="selection" style="margin-top: 20rpx;">
  215. <view class="title">
  216. {{ $t('live.lab14') }}
  217. </view>
  218. <view class="li">
  219. <text class="D4199">#:</text>
  220. {{ $t('live.lab15') }}
  221. </view>
  222. <view class="li">
  223. <text class="D4199">
  224. {{ $t('live.lab16') }}:</text>
  225. {{ $t('live.lab17') }}
  226. </view>
  227. <view class="li">
  228. <text class="D4199">P:</text>
  229. {{ $t('live.lab18') }}
  230. </view>
  231. <view class="li">
  232. <text class="D4199">W:</text>
  233. {{ $t('live.lab19') }}
  234. </view>
  235. <view class="li">
  236. <text class="D4199">D:</text>
  237. {{ $t('live.lab20') }}
  238. </view>
  239. <view class="li">
  240. <text class="D4199">L:</text>
  241. {{ $t('live.lab21') }}
  242. </view>
  243. <view class="li">
  244. <text class="D4199">NR:</text>
  245. {{ $t('live.lab22') }}
  246. </view>
  247. <view class="li">
  248. <text class="D4199">NRR:</text>
  249. {{ $t('live.lab23') }}
  250. </view>
  251. <view class="li">
  252. <text class="D4199">PTS:</text>
  253. {{ $t('live.lab24') }}
  254. </view>
  255. <!-- <view class="li">
  256. <text class="cfff qqs">Q</text>:
  257. {{ $t('live.lab24') }}
  258. </view> -->
  259. </view>
  260. </view>
  261. </template>
  262. <script>
  263. export default {
  264. props: {
  265. matchDetail: {
  266. default: {}
  267. }
  268. },
  269. data() {
  270. return {
  271. acIndex:null,
  272. detail_info:{},
  273. tournament_list:[]
  274. }
  275. },
  276. created() {
  277. this.cricket_tournament_standings()
  278. this.cricket_match_detail_info()
  279. },
  280. methods:{
  281. clickItem(index){
  282. console.log('index :>> ', index);
  283. this.acIndex=(this.acIndex==index?null:index)
  284. console.log(this.acIndex);
  285. },
  286. /* 积分 */
  287. cricket_tournament_standings() {
  288. uni.$u.http.post('/api/Cricket/cricket_tournament_standings',{
  289. tournament_id: this.matchDetail.tournament_id
  290. }).then(res=>{
  291. this.tournament_list = res;
  292. }).catch(res=>{})
  293. },
  294. /* 详情 */
  295. cricket_match_detail_info() {
  296. let time = new Date();
  297. let timeZone = time.toLocaleTimeString('en-us',{timeZoneName:'short'}); //'1:12:38 PM GMT+8'
  298. let timeZoneId = Intl.DateTimeFormat().resolvedOptions().timeZone; //'Asia/Shanghai'
  299. uni.$u.http.post('/api/Cricket/cricket_match_detail_info',{
  300. match_id: this.matchDetail.match_id,
  301. timezone: timeZoneId
  302. }).then(res=>{
  303. this.detail_info = res;
  304. }).finally(() => {
  305. })
  306. },
  307. classFilter(key) {
  308. return key == 1 ? 'c430' : key == 2 ? 'cC23' : 'c666'
  309. }
  310. }
  311. }
  312. </script>
  313. <style lang="scss">
  314. .Info{
  315. padding: 12px 15rpx;
  316. .selection{
  317. background-color: #fff;
  318. margin-bottom: 10px;
  319. border-radius: 5px;
  320. overflow: hidden;
  321. .title {
  322. line-height: 33px;
  323. background-color: rgba(16, 5, 74, .1);
  324. padding: 0 28rpx;
  325. font-size: 17px;
  326. font-weight: 700;
  327. color: #242424;
  328. display: block;
  329. }
  330. .list{
  331. padding: 0 28rpx;
  332. .u-row{
  333. padding: 36rpx 0;
  334. border-bottom: 1rpx solid #ccc;
  335. &:last-child{
  336. border: none;
  337. }
  338. .selection-info{
  339. display: flex;
  340. image{
  341. width: 80rpx;
  342. height: auto;
  343. }
  344. }
  345. .detail-right{
  346. width: 48rpx;
  347. height: 48rpx;
  348. }
  349. }
  350. .list-item{
  351. padding: 24rpx 0;
  352. &+.list-item {
  353. border-top: 1rpx solid #d1d1d1;
  354. }
  355. }
  356. }
  357. .label {
  358. font-size: 12px;
  359. color: #939292;
  360. }
  361. .content {
  362. font-size: 17px;
  363. color: #242424;
  364. &.cDE9 {
  365. color: #0C52D2;
  366. }
  367. }
  368. .content1 {
  369. font-size: 15px;
  370. color: #242424;
  371. }
  372. .full {
  373. font-size: 15px;
  374. font-weight: 700;
  375. color: #ff3300;
  376. text-align: center;
  377. padding-top: 25px;
  378. padding-bottom: 8px;
  379. }
  380. }
  381. .selection-table-title{
  382. padding: 36rpx 28rpx 36rpx 0;
  383. }
  384. .selection-table{
  385. background-color: #fff;
  386. border-radius: 5px;
  387. overflow: hidden;
  388. .tr-header{
  389. background-color: rgba(16, 5, 74, .1);
  390. color: #484A4D;
  391. font-size: 12px;
  392. }
  393. .pts{
  394. image{
  395. width: 19rpx;
  396. height: 19rpx;
  397. transition: all 0.5s ease;
  398. }
  399. }
  400. .u-row{
  401. display: grid;
  402. grid-template-columns: 10% 15% 10% 10% 10% 10% 20% 10%;
  403. grid-template-rows:74rpx;
  404. transition: all 0.5s ease;
  405. font-size: 12px;
  406. }
  407. .trc6{
  408. color: #666;
  409. text-align: center;
  410. }
  411. .trc3{
  412. color: #333;
  413. text-align: center;
  414. }
  415. .table-item-content{
  416. height: 0rpx;
  417. overflow: hidden;
  418. line-height: 66rpx;
  419. transition: all 0.5s ease;
  420. height: 0;
  421. &.active {
  422. height: 100%;
  423. padding: 24rpx 28rpx 0;
  424. }
  425. .table-item-content-th{
  426. height: 27px;
  427. background: rgba(16, 5, 74, .1);
  428. border-radius: 10rpx;
  429. display: grid;
  430. grid-template-columns: 15% 20% 25% 40%;
  431. grid-template-rows:27px;
  432. padding-left: 24rpx;
  433. color: #505255;
  434. align-items: center;
  435. font-size: 12px;
  436. }
  437. .table-item-content-tr{
  438. display: grid;
  439. grid-template-columns: 15% 20% 25% 40%;
  440. grid-template-rows:70rpx;
  441. min-height: 70rpx;
  442. padding-left: 24rpx;
  443. }
  444. .td {
  445. font-size: 14px;
  446. color: #282828;
  447. }
  448. .td1 {
  449. font-size: 12px;
  450. color: #5A5C5F;
  451. }
  452. }
  453. .actives{
  454. .u-row{
  455. background-color: #1D2550;
  456. }
  457. .trc6{
  458. color: #999;
  459. }
  460. .trc3{
  461. color: #fff;
  462. }
  463. .pts{
  464. image{
  465. transform: rotateZ(180deg);
  466. }
  467. }
  468. // .table-item-content{
  469. // height: max-content;
  470. // }
  471. }
  472. }
  473. .li {
  474. font-size: 14px;
  475. font-weight: 400;
  476. text-align: left;
  477. color: #242424;
  478. line-height: 1;
  479. display: flex;
  480. align-items: center;
  481. height: 39px;
  482. .D4199 {
  483. color: #4D4199;
  484. display: inline-block;
  485. width: 50px;
  486. text-align: right;
  487. padding-right: 19px;
  488. }
  489. }
  490. .qqs{
  491. font-size: 28rpx;
  492. background-color: #EEA831;
  493. display: inline-block;
  494. padding: 0 8rpx;
  495. border-radius: 100rpx;
  496. }
  497. }
  498. </style>