陶杰
2024-08-22 4aa0bd47801606b4d0e0a6a2ed8fe92a7e5f2444
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
<template>
    <view class="p15 bg-white">
        <view class="search-container m-t-12 flex">
            <view class="flex m-r-20" @click="changeType">
                <view class="m-r-10" style="line-height: 80rpx;" >
                    {{type=='flower'?'按鲜花':'按店铺'}}
                </view>
                <u-icon name="arrow-down"></u-icon>
 
            </view>
            <view class="flex1 input">
                <u-input placeholder="请输入花名" v-model="search_flow" clearable @confirm="buttonSearchFlow" @clear="()=>{
                    $nextTick(()=>{buttonSearchFlow()})
                }">
                    <!-- <u--text text="http://" slot="prefix" margin="0 3px 0 0" type="tips"></u--text> -->
 
 
                    <template slot="suffix">
                        <uni-icons color="#20613D" type="search" size="24" @click="buttonSearchFlow"></uni-icons>
                    </template>
                </u-input>
            </view>
 
        </view>
        <view class="m-t-20">
            <view class="title flex">
                <view class="m-l-0 m-r-a">搜索历史</view>
                <view class="bg-white desc-gray  text-center m-l-a m-r-0" @click.stop="clearHistory">
                    一键清空
                </view>
            </view>
            <view class="m-t-12 flex history-item-list" v-show="type=='flower'">
                <view class="history-item" v-for="(item,j) of history_flower" :key="j" @click="searchBy(item)">
                    {{item}}
                </view>
            </view>
            <view class="m-t-12 flex history-item-list" v-show="type=='supplier'">
                <view class="history-item" v-for="(item,j) of history_supplier" :key="j" @click="searchBy(item)">
                    {{item}}
                </view>
            </view>
        </view>
    </view>
</template>
 
<script>
    export default {
        data() {
            return {
                search_flow: '',
                history_supplier: [],
                history_flower: [],
 
                type: 'flower', //supplierName
            }
        },
        onShow() {
 
        },
        onHide() {
            this.$storage.setItem("cache_home_search_supplier", JSON.stringify(this.history_supplier))
            this.$storage.setItem("cache_home_search_flower", JSON.stringify(this.history_flower))
        },
        onLoad() {
            if (true) {
                var k = this.$storage.getItem("cache_home_search_flower")
                this.history_flower = k && JSON.parse(k) || []
            }
            if (true) {
                var k = this.$storage.getItem("cache_home_search_supplier")
                this.history_supplier = k && JSON.parse(k) || []
            }
        },
        methods: {
            changeType() {
                if (this.type == 'flower') {
                    this.type = 'supplier'
                } else {
                    this.type = 'flower'
                }
            },
            buttonSearchFlow() {
                var name = this.search_flow
                if (name) {
 
 
                    var p = ''
                    if (this.type === 'flower') {
                        p = 'name=' + this.search_flow
                        if (this.history_flower.indexOf(name) >= 0) {
 
                        } else {
                            this.history_flower.unshift(name)
                        }
                        if (this.history_flower.length >= 10) {
                            this.history_flower.splice(this.history_flower.length - 1, 1)
                        }
                    } else {
                        p = 'supplierName=' + this.search_flow
                        if (this.history_supplier.indexOf(name) >= 0) {
 
                        } else {
                            this.history_supplier.unshift(name)
                        }
                        if (this.history_supplier.length >= 10) {
                            this.history_supplier.splice(this.history_supplier.length - 1, 1)
                        }
                    }
                    uni.navigateTo({
                        url: '/sub_pages/customer/trade/list?' + p
                    })
                }
            },
            async clearHistory() {
                await this.$message.confirm('是否清空历史记录')
                if (this.type === 'flower') {
                    this.history_flower = []
                    this.$storage.setItem("cache_home_search_flower", JSON.stringify(this.history_flower))
                }
                if (this.type === 'supplier') {
                    this.history_supplier = []
                    this.$storage.setItem("cache_home_search_supplier", JSON.stringify(this.history_supplier))
                }
 
            },
            searchBy(clickname) {
                //值一瞬间会变,引用,所以用加一个,来更改引用
                var name = '' + clickname
 
                var p = ''
                if (this.type === 'flower') {
                    p = 'name=' + name
                } else {
                    p = 'supplierName=' + name
                }
                console.log('searchBy', clickname, name, p)
 
                uni.navigateTo({
                    url: '/sub_pages/customer/trade/list?' + p
                })
            }
        }
    }
</script>
 
<style lang="scss" scoped>
    .history-item-list {
        .history-item {
            margin-right: 30rpx;
            min-width: 100rpx;
            padding: 10rpx 20rpx;
            margin-bottom: 30rpx;
            text-align: center;
            height: 30rpx;
            line-height: 30rpx;
            font-size: 28rpx;
            // padding-left: 10rpx;
            // padding-right: 10rpx;
            border: 2rpx solid #e9e9e9;
        }
    }
</style>