| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211 | <template>    <view class="global-search">        <view class="global-search_input">            <image class="image" src="/static/c+unselected.svg" mode="widthFix" />            <view style="flex:1">                <My_search placeholder="搜索全站关键字" @onSearch="onSearch"></My_search>            </view>        </view>        <view class="content">            <view class="type-tabs">                <u-tabs :scrollable="false" lineColor="#C30D23" :activeStyle="{ color: '#C30D23', fontWeight: 'bold' }" :list="types"                @click="changeType" :current="current" />            </view>                        <My_listbox ref="List" @getlist="getList" :bottomHeight="70">                <view class="list-box">                    <navigator class="item-box" :url="calcUrl(item)"                    v-for="item in list" :key="item.sa_fadid"                    hover-class="navigator-hover">                        <view class="item">                            <u--image radius="5" :lazy-load="true" :width="tovw(100)" :height="tovw(100)" :src="calcImage(item)">                                <template v-slot:loading>                                    <u-loading-icon color="red"></u-loading-icon>                                </template>                            </u--image>                            <view class="title">                                {{ item.title }}                            </view>                        </view>                                            </navigator>                </view>            </My_listbox>        </view>           </view></template><script>import { formattedFiles } from '../../utils/settleFiles.js'export default {    data() {        return {            types: [                {                    name:'产品',                    value:1,                },                {                    name:'效果图',                    value:2,                },                {                    name:'课件',                    value:3,                },                {                    name:'资料',                    value:4,                }            ],            content: {                "type": 1,                //1:产品:来源单品、案例-电器系统                //2:效果图:来源效果图管理;                //3:课件:来源商学院授权可查看的课程中的课件;                //4:资料:来源装备资源库授权可查看的资料;                "pageNumber": 1,                "pageSize": 12,                "where": {                    "condition": ""                }            },            list:[],            current:0,            avatar:''        }    },    methods: {        onSearch (condition) {            this.content.where.condition = condition            this.getList(true)        },        changeType (type) {            this.current = type.index            this.content.type = type.value            this.getList(true)        },        getList(init = false) {            return new Promise((resolve, reject) => {                if (this.paging(this.content, init)) return resolve();                this.$Http.basic({                    "id": "20240513085802",                    content: this.content                }).then(res => {                    this.$refs.List.setHeight()                    this.$refs.List.RefreshToComplete()                    resolve();                    if (this.cutoff(res.msg)) return;                    res.data.forEach(item => {                        item.attinfos = formattedFiles(item.attinfos)                    })                    this.list = res.pageNumber == 1 ? res.data : this.list.concat(res.data);                    this.content = this.$refs.List.paging(this.content, res)                    console.log(this.list,'数据');                })            })        },    },    computed: {        calcUrl () {            return (data) => {                switch (this.current) {                    case 0:                        return '/packageCase/product/detail?id='+data.sa_fadid                        break;                    case 1:                        return '/packageCase/imgs/detail?id='+data.sat_sharematerialid                        break;                    case 2:                        return '/packageA/course/detail?id='+data.sat_coursewaredetailid                        break;                    case 3:                        return '/packageA/resourceLibrary/detail?id='+data.sat_sharematerialid                        break;                    default:                        break;                }            }        },        calcImage () {            return (data) => {                if (data.attinfos.length) {                    if (data.attinfos[0].fileType == 'video') {                        return data.attinfos[0].subfiles[0].url                    } else if (data.attinfos[0].fileType == 'image') {                        return data.attinfos[0].url                    } else {                        return this.avatar                    }                } else {                    return this.avatar                }            }        }    },    onLoad () {        uni.setNavigationBarTitle({            title: '全站搜索'                    });    },    created() {        this.avatar = uni.getStorageSync("site").logo        this.getList()    },}</script><style lang="scss">.global-search {    .global-search_input {        margin: 10px;        display: flex;        align-items: center;        .image{            width: 40px;            height: 20px;            margin-right: 10px;        }    }    .content {        background: #ffffff;        .type-tabs {            margin-bottom: 10px;        }        .list-box {            .item-box{                padding: 0 10px;                .item {                    display: flex;                    align-items: center;                    align-content: center;                    border-bottom: 0.5px solid #DDDDDd;                    padding: 10px 0;                    .image-box {                        margin-right: 10px;                        width: 100px;                        height: 100px;                        padding: 18px;                        background: #F5F5F5;                        .image{                            width: 100%;                            height: 100%;                        }                    }                    .title{                        font-family: PingFang SC, PingFang SC;                        font-weight: 400;                        font-size: 14px;                        color: #333333;                        margin-left: 10px;                    }                }            }        }    }    }</style>
 |