zxl
3 天以前 cb084b230023cfed42249b0145e177deb4b8261c
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
<template>
  <div class="search">
    <Card>
      <Row class="operation">
        <Button @click="add()" type="primary">设置今日热词</Button>
      </Row>
      <Row>
        <p>
          <Alert type="success">
            这里展示今日系统中搜索前一百的搜索热词,分数为热词在排序系统中的分数,分数越高,可以在用户获取热词时进行优先展示(首页商品搜索栏下方推荐位)(分数可以填写负数,会降低推荐度)
          </Alert>
        </p>
      </Row>
 
      <div class="card-list">
        <Card v-for="words in data" class="card-item" :key="words" onclick="">
          <p>
            <a href="#" slot="extra" @click.prevent="add(words)">{{ words }}</a>
          </p>
          <p slot="extra">
            <a @click="deleteWords(words)">
              <Icon type="md-close"/>
            </a>
          </p>
        </Card>
      </div>
    </Card>
    <Modal :title="modalTitle" v-model="modalVisible" :mask-closable="false" :width="500">
      <Form ref="form" :model="form" :label-width="100" :rules="formValidate">
        <FormItem label="热词" prop="keywords">
          <Input v-model="form.keywords" clearable style="width: 100%"/>
        </FormItem>
        <FormItem label="分数" prop="point">
          <Input v-model="form.point" clearable style="width: 100%"/>
        </FormItem>
      </Form>
      <div slot="footer">
        <Button type="text" @click="modalVisible = false">取消</Button>
        <Button type="primary" :loading="submitLoading" @click="handleSubmit"
        >提交
        </Button
        >
      </div>
    </Modal>
  </div>
</template>
 
<script>
import {getHotWords, setHotWords, deleteHotWords} from "@/api/index";
 
import {regular} from "@/utils";
 
export default {
  name: "hotWords",
  components: {},
  data() {
    return {
      submitLoading: false,
      modalTitle: "",
      loading: true, // 表单加载状态
      modalVisible: false, //弹出框
      form: {
        keywords: "",
        point: 0,
      },
      data: [], // 表单数据
 
      // 表单验证规则
      formValidate: {
        keywords: [regular.REQUIRED, regular.VARCHAR20],
        point: [regular.REQUIRED, regular.NUMBER],
      },
    };
  },
  methods: {
    init() {
      this.getDataList();
    },
    getDataList() {
      this.loading = true;
      getHotWords().then((res) => {
        this.loading = false;
        if (res.success) {
          this.data = res.result;
        }
      });
      this.loading = false;
    },
    handleSubmit() {
      this.$refs.form.validate((valid) => {
        if (valid) {
          this.submitLoading = true;
          setHotWords(this.form).then((res) => {
            this.submitLoading = false;
            if (res.success) {
              this.$Message.success("操作成功");
              this.getDataList();
              this.modalVisible = false;
            }
          });
        }
      });
    },
    //设置热词优先
    add(words) {
      this.modalType = 0;
      this.modalTitle = "设置热词";
      if (words) {
        this.form.keywords = words;
      } else {
        this.form.keywords = "";
      }
      this.form.point = 1;
      this.modalVisible = true;
    },
    deleteWords(words) {
      this.$Modal.confirm({
        title: "是否确定删除热词",
        content: "<p>您确定要删除此热词吗?</p>",
        okText: "确实",
        cancelText: "取消",
        onOk: () => {
          let params = {words: words}
          deleteHotWords(params).then((res) => {
            if (res.success) {
              this.$Message.success("删除成功");
              this.getDataList();
            }
          });
        },
      });
    },
  },
  mounted() {
    this.init();
  },
};
</script>
<style lang="scss" scoped>
.card-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
 
.card-item {
  min-width: 100px;
  margin: 20px;
}
</style>
<style>
.ivu-card-extra {
  right: 3px;
  top: 15px;
  z-index: 99;
}
</style>