123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429 |
- <template>
- <view>
- <view v-if="(shop || null) != null" class="pr">
- <!-- 搜索 -->
- <view :class="'padding-main bg-white pr oh br-b search '+(is_shop_whole_search == 1 ? '' : 'header-shop-whole-search')">
- <input class="bg-white fl padding-left-xxl text-size-xs round border-color-main" type="done" placeholder="请输入您搜索的商品关键字" :value="search_keywords_value || ''" placeholder-class="cr-grey" @input="search_keywords_event">
- <view class="search-btn pa">
- <button class="bg-main br-main cr-white round text-size-xs" type="default" size="mini" hover-class="none" @tap="search_button_event" :data-value="'/pages/plugins/shop/search/search?shop_id='+shop.id+'&'">{{is_shop_whole_search == 1 ? '搜本店' : '搜索'}}</button>
- <button v-if="is_shop_whole_search == 1" class="bg-main-pair br-main-pair cr-white round text-size-xs" type="default" size="mini" hover-class="none" @tap="search_button_event" data-value="/pages/goods-search/goods-search?">搜全站</button>
- </view>
- </view>
- <!-- 顶部 -->
- <view class="header plugins-shop-data-list bg-white oh">
- <image :src="shop.logo_long" mode="widthFix" class="shop-logo fl br-r padding-right-lg margin-top-xs cp"></image>
- <view class="base fr item">
- <view class="shop-title single-text">
- <!-- 认证信息 -->
- <view v-if="(data_base.is_enable_auth || 0) == 1 && ((shop.auth_type != -1 && (shop.auth_type_msg || null) != null) || ((shop.bond_status || 0) == 1 && (shop.bond_status_msg || null) != null))" class="auth-icon dis-inline-block">
- <!-- 实名认证 -->
- <block v-if="shop.auth_type != -1 && (shop.auth_type_msg || null) != null">
- <block v-if="shop.auth_type == 0">
- <image :src="data_base.shop_auth_personal_icon" class="icon va-m" mode="aspectFill"></image>
- </block>
- <block v-if="shop.auth_type == 1">
- <image :src="data_base.shop_auth_company_icon" class="icon va-m" mode="aspectFill"></image>
- </block>
- </block>
- <!-- 保证金认证 -->
- <block v-if="(shop.bond_status || 0) == 1 && (shop.bond_status_msg || null) != null">
- <image :src="data_base.shop_auth_bond_icon" class="icon va-m" mode="aspectFill"></image>
- </block>
- </view>
- <!-- 标题 -->
- <text class="fw-b text-size va-m">{{shop.name}}</text>
- </view>
- <view class="base-bottom oh margin-top-sm">
- <view v-if="(data_base.is_service_info || 0) == 1" class="fl margin-right-xxl cp" @tap="header_service_event">
- <image class="va-m margin-right-sm" :src="common_static_url+'customer-service-icon.png'" mode="scaleToFill"></image>
- <text class="va-m cr-base">在线客服</text>
- </view>
- <view class="fl single-text cp" @tap="shop_favor_event">
- <image class="va-m margin-right-sm" :src="common_static_url+'favor'+(shop_favor_info.status == 1 ? '-active' : '')+'-icon.png'" mode="scaleToFill"></image>
- <text :class="'va-m ' + (shop_favor_info.status == 1 ? 'cr-main' : '')">{{shop_favor_info.text}}({{shop_favor_info.count}})</text>
- </view>
- </view>
- </view>
- </view>
- <!-- 在线客服 -->
- <view v-if="header_service_status && ((data_base.is_service_info || 0) == 1 || (shop.chat_info || null) != null)" class="header-service pa border-radius-main oh bg-white br">
- <view v-if="(shop.chat_info || null) != null" class="item padding-main br-t single-text">
- <text class="va-m">客服:</text>
- <view class="dis-inline-block chat-info cp" @tap="chat_event">
- <image class="dis-inline-block va-m" :src="shop.chat_info.icon" mode="scaleToFill"></image>
- <text class="margin-left-sm va-m cr-blue" :data-value="shop.chat_info.chat_url">{{shop.chat_info.name}}</text>
- </view>
- </view>
- <view v-if="(shop.service_qq || null) != null" class="item padding-main br-t single-text">
- <text>Q Q:</text>
- <text class="cp" @tap="text_copy_event" :data-value="shop.service_qq">{{shop.service_qq}}</text>
- </view>
- <view v-if="(shop.service_tel || null) != null" class="item padding-main br-t single-text">
- <text>电话:</text>
- <text class="cp" @tap="tel_event" :data-value="shop.service_tel">{{shop.service_tel}}</text>
- </view>
- <view v-if="(shop.open_week_name || null) != null && (shop.close_week_name || null) != null" class="item padding-main br-t single-text">
- <text>时间:</text>
- <text class="cp" @tap="text_copy_event" :data-value="shop.open_week_name + '至' + shop.close_week_name + ',' + shop.open_time + '-' + shop.close_time">{{shop.open_week_name}}至{{shop.close_week_name}},{{shop.open_time}}-{{shop.close_time}}</text>
- </view>
- <view v-if="(shop.service_weixin_qrcode || null) != null || (shop.service_line_qrcode || null) != null" class="oh qrcode tc br-t">
- <view v-if="(shop.service_weixin_qrcode || null) != null" class="item padding-bottom-lg dis-inline-block">
- <image class="radius cp" :src="shop.service_weixin_qrcode" mode="scaleToFill" @tap="image_show_event" :data-value="shop.service_weixin_qrcode"></image>
- <view>长按微信咨询</view>
- </view>
- <view v-if="(shop.service_line_qrcode || null) != null" class="item padding-bottom-lg dis-inline-block">
- <image class="radius cp" :src="shop.service_line_qrcode" mode="scaleToFill" @tap="image_show_event" :data-value="shop.service_line_qrcode"></image>
- <view>长按line咨询</view>
- </view>
- </view>
- </view>
- <!-- 导航 -->
- <view v-if="shop_goods_category.length > 0 || shop_navigation.length > 0" class="nav scroll-view-horizontal bg-white padding-top-lg border-color-main">
- <view v-if="shop_goods_category.length > 0" class="item padding-main arrow-bottom nav-shop-category dis-inline-block fw-b cp" @tap="nav_shop_category_event">查看商品分类</view>
- <scroll-view scroll-x class="nav-scroll">
- <block v-if="shop_navigation.length > 0">
- <block v-for="(item, index) in shop_navigation" :key="index">
- <view class="item dis-inline-block fw-b cp" @tap="nav_event" :data-value="item.url" :data-index="index">{{item.name}}</view>
- </block>
- </block>
- </scroll-view>
- <view v-if="nav_category_status" class="nav-category bg-white pa tc">
- <scroll-view scroll-y class="category-scroll">
- <block v-if="shop_goods_category.length > 0">
- <block v-for="(item, index) in shop_goods_category" :key="index">
- <view class="item dis-block cr-base single-text cp" @tap="shop_category_event" :data-value="item.id">{{item.name}}</view>
- </block>
- </block>
- <block v-else>
- <view class="padding-top-xxl padding-bottom-xxl cr-grey">暂无数据</view>
- </block>
- </scroll-view>
- </view>
- </view>
- <!-- 数据模式 -->
- <!-- 自动模式 -->
- <block v-if="(shop.data_model || 0) == 0">
- <view v-if="(data || null) != null && data.length > 0" class="padding-main oh">
- <component-goods-list :propData="{style_type: 1, goods_list: data}" :propCurrencySymbol="currency_symbol"></component-goods-list>
- <button class="bg-main br-main cr-white round dis-block margin-top-xl margin-bottom-xl margin-horizontal-main" @tap="url_event" :data-value="'/pages/plugins/shop/search/search?shop_id='+shop.id" size="mini">查看更多商品 >></button>
- </view>
- <block v-else>
- <component-no-data propStatus="0"></component-no-data>
- </block>
- </block>
- <!-- 标准模式 -->
- <block v-if="(shop.data_model || 0) == 1">
- <block v-if="((slider || null) != null && slider.length > 0) || ((data || null) != null && data.length > 0)">
- <view class="data-list padding-horizontal-main oh">
- <!-- 轮播 -->
- <view v-if="slider.length > 0" class="margin-top-main">
- <component-banner :propData="slider"></component-banner>
- </view>
- <!-- 商品列表 -->
- <block v-if="data.length > 0">
- <block v-for="(item, index) in data" :key="index">
- <component-goods-list :propData="item" propMoreUrlKey="more_url" :propKeywordsUrl="'/pages/plugins/shop/search/search?shop_id='+shop.id+'&keywords='" :propIsAutoPlay="true" :propCurrencySymbol="currency_symbol"></component-goods-list>
- </block>
- </block>
- </view>
- </block>
- <block v-else>
- <component-no-data propStatus="0"></component-no-data>
- </block>
- </block>
- <!-- 拖拽模式 -->
- <block v-if="(shop.data_model || 0) == 2">
- <block v-if="(data || null) != null && data.length > 0">
- <!-- 拖拽模式、引入拖拽数据模块 -->
- <component-layout :propData="data"></component-layout>
- </block>
- <block v-else>
- <component-no-data propStatus="0"></component-no-data>
- </block>
- </block>
- <!-- 结尾 -->
- <component-bottom-line :propStatus="data_bottom_line_status"></component-bottom-line>
- </view>
- <view v-else>
- <!-- 提示信息 -->
- <component-no-data :propStatus="data_list_loding_status" :propMsg="data_list_loding_msg"></component-no-data>
- </view>
- </view>
- </template>
- <script>
- const app = getApp();
- import componentLayout from "../../../../components/layout/layout";
- import componentNoData from "../../../../components/no-data/no-data";
- import componentBottomLine from "../../../../components/bottom-line/bottom-line";
- import componentBanner from "../../../../components/slider/slider";
- import componentGoodsList from "../../../../components/goods-list/goods-list";
- var common_static_url = app.globalData.get_static_url('common');
- export default {
- data() {
- return {
- common_static_url: common_static_url,
- data_bottom_line_status: false,
- data_list_loding_status: 1,
- data_list_loding_msg: '',
- currency_symbol: app.globalData.data.currency_symbol,
- is_shop_whole_search: app.globalData.data.is_shop_whole_search || 0,
- params: null,
- user: null,
- data_base: null,
- shop: null,
- shop_favor_user: [],
- shop_navigation: [],
- shop_goods_category: [],
- slider: [],
- data: [],
- search_keywords_value: '',
- header_service_status: false,
- nav_category_status: false,
- shop_favor_info: {
- "text": "收藏",
- "status": 0,
- "count": 0
- },
- // 自定义分享信息
- share_info: {}
- };
- },
- components: {
- componentLayout,
- componentNoData,
- componentBottomLine,
- componentBanner,
- componentGoodsList
- },
- props: {},
- onLoad(params) {
- this.setData({
- params: params,
- user: app.globalData.get_user_cache_info()
- });
- },
- onShow() {
- this.get_data();
- // 初始化配置
- this.init_config();
- },
- // 下拉刷新
- onPullDownRefresh() {
- this.get_data();
- },
- methods: {
- // 初始化配置
- init_config(status) {
- if ((status || false) == true) {
- this.setData({
- currency_symbol: app.globalData.get_config('currency_symbol')
- });
- } else {
- app.globalData.is_config(this, 'init_config');
- }
- },
- // 获取数据
- get_data() {
- uni.request({
- url: app.globalData.get_request_url("detail", "index", "shop"),
- method: 'POST',
- data: {
- "id": this.params.id || 0
- },
- dataType: 'json',
- success: res => {
- uni.stopPullDownRefresh();
- if (res.data.code == 0) {
- var data = res.data.data;
- var temp_data = data.data || [];
- this.setData({
- data_base: data.base || null,
- shop: data.shop || null,
- shop_favor_user: data.shop_favor_user || [],
- shop_navigation: data.shop_navigation || [],
- shop_goods_category: data.shop_goods_category || [],
- data: temp_data,
- slider: data.slider || [],
- data_list_loding_msg: '',
- data_list_loding_status: 0,
- data_bottom_line_status: temp_data.length > 0
- });
- if ((this.shop || null) != null) {
- // 收藏信息
- var status = this.shop_favor_user.indexOf(this.shop.id) != -1 ? 1 : 0;
- this.setData({
- shop_favor_info: {
- "count": this.shop.shop_favor_count || 0,
- "status": status,
- "text": (status == 1 ? '已' : '') + '收藏'
- }
- });
- // 基础自定义分享
- this.setData({
- share_info: {
- title: this.shop.seo_title || this.shop.name,
- desc: this.shop.seo_desc || this.shop.describe,
- path: '/pages/plugins/shop/detail/detail',
- query: 'id='+this.shop.id,
- img: this.shop.logo
- }
- });
- // 标题名称
- uni.setNavigationBarTitle({
- title: this.shop.name
- });
- }
- } else {
- this.setData({
- data_bottom_line_status: false,
- data_list_loding_status: 2,
- data_list_loding_msg: res.data.msg
- });
- }
- // 分享菜单处理
- app.globalData.page_share_handle(this.share_info);
- },
- fail: () => {
- uni.stopPullDownRefresh();
- this.setData({
- data_bottom_line_status: false,
- data_list_loding_status: 2,
- data_list_loding_msg: '服务器请求出错'
- });
- app.globalData.showToast('服务器请求出错');
- }
- });
- },
- // 店铺收藏事件
- shop_favor_event(e) {
- var user = app.globalData.get_user_info(this, 'shop_favor_event');
- if (user != false) {
- // 用户未绑定用户则转到登录页面
- if (app.globalData.user_is_need_login(user)) {
- uni.navigateTo({
- url: "/pages/login/login?event_callback=shop_favor_event"
- });
- return false;
- } else {
- uni.showLoading({
- title: '处理中...'
- });
- uni.request({
- url: app.globalData.get_request_url("favor", "shopfavor", "shop"),
- method: 'POST',
- data: {
- "id": this.shop.id
- },
- dataType: 'json',
- success: res => {
- uni.hideLoading();
- if (res.data.code == 0) {
- this.setData({
- shop_favor_info: res.data.data
- });
- app.globalData.showToast(res.data.msg, 'success');
- } else {
- if (app.globalData.is_login_check(res.data, this, 'shop_favor_event')) {
- app.globalData.showToast(res.data.msg);
- }
- }
- },
- fail: () => {
- uni.hideLoading();
- app.globalData.showToast('服务器请求出错');
- }
- });
- }
- }
- },
- // 搜索输入事件
- search_keywords_event(e) {
- this.setData({
- search_keywords_value: e.detail.value || ''
- });
- },
- // 搜索事件
- search_button_event(e) {
- var value = e.currentTarget.dataset.value || null;
- uni.navigateTo({
- url: value + 'keywords=' + this.search_keywords_value || ''
- });
- },
- // 导航分类事件
- header_service_event(e) {
- this.setData({
- header_service_status: !this.header_service_status
- });
- },
- // 导航分类事件
- nav_shop_category_event(e) {
- this.setData({
- nav_category_status: !this.nav_category_status
- });
- },
- // 导航分类事件
- shop_category_event(e) {
- var value = e.currentTarget.dataset.value || null;
- uni.navigateTo({
- url: '/pages/plugins/shop/search/search?shop_id=' + this.shop.id + '&category_id=' + value
- });
- },
- // 导航事件
- nav_event(e) {
- app.globalData.url_event(e);
- },
- // url事件
- url_event(e) {
- app.globalData.url_event(e);
- },
- // 剪切板
- text_copy_event(e) {
- app.globalData.text_copy_event(e);
- },
- // 电话
- tel_event(e) {
- app.globalData.call_tel(e.currentTarget.dataset.value || null);
- },
- // 图片预览
- image_show_event(e) {
- app.globalData.image_show_event(e);
- },
- // 进入客服系统
- chat_event() {
- app.globalData.chat_entry_handle(this.shop.chat_info.chat_url);
- }
- }
- };
- </script>
- <style>
- @import './detail.css';
- </style>
|