123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231 |
- <template>
- <!-- 新闻播报 -->
- <view :style="[newsStyle]">
- <view class="news" v-if="dataConfig.styleConfig.tabVal" :style="[newsWrapperStyle]">
- <view class="acea-row row-between-wrapper news-top">
- <view v-if="dataConfig.titleConfig.tabVal" :style="[titleStyle]">{{ dataConfig.titleTxtConfig.value }}</view>
- <image v-else :src="dataConfig.imgConfig.url" mode="aspectFit" class="image"></image>
- <view v-if="!dataConfig.buttonConfig.tabVal" class="more"
- @click="moreTab(linkConfig)" :style="[moreStyle]">更多<text
- class="iconfont icon-ic_rightarrow"></text></view>
- </view>
- <view class="news-bottom">
- <view v-for="(item, index) in dataConfig.listConfig.list" :key="index" class="acea-row row-middle item" :style="[itemStyle]">
- <view class="number">{{ index + 1 }}</view>
- <view class="text">{{ item.chiild[0].val }}</view>
- </view>
- </view>
- </view>
- <view class="news-scroll acea-row row-middle" :style="[newsWrapperStyle]" v-else>
- <view class="news-left">
- <view class="text" v-if="dataConfig.titleConfig.tabVal" :style="[leftStyle]">{{ dataConfig.titleTxtConfig.value }}</view>
- <image class="image" :src="dataConfig.imgConfig.url" mode="aspectFit" v-else></image>
- </view>
- <view class="news-center" :style="[itemStyle]">
- <view v-if="dataConfig.rollConfig.tabVal" @click="moreTab(dataConfig.listConfig.list[0].chiild[0].val)">
- <uniNoticeBar scrollable single showGetMore background-color="transparent" :color="dataConfig.newsColor.color[0].item" :speed="50"
- :text="dataConfig.listConfig.list[0].chiild[0].val"></uniNoticeBar>
- </view>
- <swiper v-else class="swiper" :indicator-dots="indicatorDots" :autoplay="autoplay" interval="2500" :duration="duration" vertical="true" circular="true">
- <swiper-item v-for="(item,index) in dataConfig.listConfig.list" :key="index">
- <view @click="moreTab(item.chiild[1].val)">{{ item.chiild[0].val }}</view>
- </swiper-item>
- </swiper>
- </view>
- <view v-if="!dataConfig.buttonConfig.tabVal" class="iconfont icon-ic_rightarrow" :style="[moreStyle]"></view>
- </view>
- </view>
- </template>
- <script>
- import uniNoticeBar from '@/components/uniNoticeBar/uni-notice-bar.vue';
- export default {
- components: {
- uniNoticeBar
- },
- name: 'news',
- props: {
- dataConfig: {
- type: Object,
- default: () => {}
- },
- },
- data() {
- return {
- indicatorDots: false,
- autoplay: true,
- duration: 500,
- };
- },
- computed: {
- newsStyle() {
- return {
- padding: `${this.dataConfig.topConfig.val * 2}rpx ${this.dataConfig.prConfig.val * 2}rpx ${this.dataConfig.bottomConfig.val * 2}rpx`,
- marginTop: `${this.dataConfig.mbConfig.val * 2}rpx`,
- background: this.dataConfig.bottomBgColor.color[0].item,
- };
- },
- newsWrapperStyle() {
- let borderRadius = `${this.dataConfig.fillet.val * 2}rpx`;
- if (this.dataConfig.fillet.type) {
- borderRadius =
- `${this.dataConfig.fillet.valList[0].val * 2}rpx ${this.dataConfig.fillet.valList[1].val * 2}rpx ${this.dataConfig.fillet.valList[2].val * 2}rpx ${this.dataConfig.fillet.valList[3].val * 2}rpx`;
- }
- return {
- borderRadius,
- background: `linear-gradient(90deg, ${this.dataConfig.moduleColor.color[0].item} 0%, ${this.dataConfig.moduleColor.color[1].item} 100%)`,
- };
- },
- moreStyle() {
- return {
- color: this.dataConfig.bntColor.color[0].item,
- };
- },
- titleStyle() {
- return {
- color: this.dataConfig.titleColor.color[0].item,
- };
- },
- leftStyle(){
- return {
- background: this.dataConfig.toneConfig.tabVal ? `linear-gradient(90deg, ${this.dataConfig.titleBgColor.color[0].item} 0%, ${this.dataConfig.titleBgColor.color[1].item} 100%)` : 'var(--view-theme)',
- color: this.dataConfig.toneConfig.tabVal ? this.dataConfig.titleColor.color[0].item : '#ffffff'
- }
- },
- itemStyle() {
- return {
- color: this.dataConfig.newsColor.color[0].item,
- };
- },
- linkConfig(){
- return this.dataConfig.linkConfig.value ? this.dataConfig.linkConfig.value : '/pages/extension/news_list/index'
- }
- },
- methods: {
- moreTab(url) {
- this.$util.JumpPath(url);
- }
- }
- }
- </script>
- <style lang="scss">
- .news-scroll {
- height: 88rpx;
- padding: 0 20rpx;
- background: #FFFFFF;
- }
- .news-left {
- margin-right: 16rpx;
- .text {
- height: 40rpx;
- padding: 0 12rpx;
- border-radius: 8rpx;
- // background: #FCEAE9;
- font-weight: 500;
- font-size: 26rpx;
- line-height: 40rpx;
- // color: #E93323;
- }
- .image {
- display: block;
- width: 48rpx;
- height: 48rpx;
- }
- }
- .news-scroll .news-center {
- flex: 1;
- min-width: 0;
- height: 36rpx;
- font-size: 26rpx;
- line-height: 36rpx;
- color: #333333;
- }
- .news-scroll .swiper {
- height: 36rpx;
- }
- .news-scroll .iconfont {
- margin-left: 16rpx;
- font-size: 24rpx;
- }
- .news {
- padding: 32rpx 24rpx;
- background: #FFFFFF;
- }
- .news-top {
- font-weight: 500;
- font-size: 32rpx;
- line-height: 36rpx;
- color: #333333;
- .image {
- display: block;
- width: 140rpx;
- height: 36rpx;
- }
- .more {
- font-weight: 400;
- font-size: 24rpx;
- color: #999999;
- }
- .iconfont {
- font-size: 24rpx;
- }
- }
- .news-bottom {
- margin-top: 32rpx;
- .item {
- font-size: 28rpx;
- line-height: 40rpx;
- color: #282828;
- +.item {
- margin-top: 24rpx;
- }
- &:nth-child(1) {
- .number {
- color: #E93323;
- }
- }
- &:nth-child(2) {
- .number {
- color: #FF7300;
- }
- }
- &:nth-child(3) {
- .number {
- color: #FFC300;
- }
- }
- }
- .number {
- width: 30rpx;
- font-family: SemiBold;
- font-size: 30rpx;
- color: #999999;
- }
- .text {
- flex: 1;
- overflow: hidden;
- white-space: nowrap;
- text-overflow: ellipsis;
- }
- }
- </style>
|