Blame view

admin-web-master/src/views/advertisement/advertisingReview/advertisingReview.vue 15.5 KB
3f535f30   杨鑫   '初始'
1
2
  <template>
    <div style="background-color:#f7f7f7;padding:10px 10px;">
ad921312   wesley88   1
3
      <div class="zhuti" v-if="onaction == '1'">
3f535f30   杨鑫   '初始'
4
5
6
7
        <div style="height:58px;line-height:58px;">
          <div style="color:#0006"> <span>广告服务</span> <span style="padding:0 5px;">></span> <span
              style="color:#000000e6">广告审核</span></div>
        </div>
ad921312   wesley88   1
8
        <!-- 线上 -->
3f535f30   杨鑫   '初始'
9
        <div>
ad921312   wesley88   1
10
11
12
13
          <div style="display: flex;font-size: 14px;" >
            <div style="margin-right: 4px;cursor: pointer;" @click="chenge(1)" :class="leixing?'chengeXia greens':''">线上({{xsNum}})</div>
            <div style="margin-left: 20px;margin-right: 4px;cursor: pointer;" @click="chenge(2)" :class="leixing?'':'chengeXia greens'">实体({{xxNum}})</div>
          </div>
3f535f30   杨鑫   '初始'
14
15
          <!-- 搜索 -->
          <div class="formSearch">
ad921312   wesley88   1
16
17
18
            <el-form :inline="true" :model="pagequery" style="margin-top: 15px;">
              <el-form-item label="广告位名称" prop="advertisingName">
                <el-input v-model="pagequery.advertisingName" placeholder="请输入" maxlength="50"></el-input>
3f535f30   杨鑫   '初始'
19
              </el-form-item>
ad921312   wesley88   1
20
21
22
23
              <el-form-item label="所属端" prop="affiliation" v-if="leixing">
                <el-select v-model="pagequery.affiliation" placeholder="请选择" style="width: 168px;margin-right: 15px">
                  <el-option label="游客小程序" value="游客小程序" />
                  <el-option label="商家客户端" value="商家客户端" />
3f535f30   杨鑫   '初始'
24
25
                </el-select>
              </el-form-item>
ad921312   wesley88   1
26
27
28
29
              <el-form-item label="设备类型" prop="deviceType" v-if="leixing == false">
                <el-select v-model="pagequery.deviceType" placeholder="请选择" style="width: 168px;margin-right: 15px">
                  <el-option label="灯箱广告牌" value="灯箱广告牌"></el-option>
                </el-select>
3f535f30   杨鑫   '初始'
30
              </el-form-item>
3f535f30   杨鑫   '初始'
31
            </el-form>
ad921312   wesley88   1
32
  
3f535f30   杨鑫   '初始'
33
            <div>
ad921312   wesley88   1
34
              <el-button @click="onSubmit" style="background-color: #3F9B6A;color: #fff">查询
3f535f30   杨鑫   '初始'
35
36
              </el-button>
              <el-button @click="resetting" class="buttonHover"
ad921312   wesley88   1
37
                style="color: #606266;border: 1px solid #dddfe5;background-color: #fff;">重置
3f535f30   杨鑫   '初始'
38
39
40
              </el-button>
            </div>
          </div>
ad921312   wesley88   1
41
42
43
44
45
          <div style="margin-bottom: 20px;">
            <el-button @click="removeonaction('2')" style="background-color: #3F9B6A;color: #fff;padding:8px 15px;"
              icon="el-icon-circle-plus-outline">新增</el-button>
            <!-- <el-button @click="" style="background-color: #3F9B6A;color: #fff">批量导入</el-button> -->
          </div>
3f535f30   杨鑫   '初始'
46
          <!-- 表格 -->
ad921312   wesley88   1
47
          <el-table :data="tableData"
3f535f30   杨鑫   '初始'
48
            :header-cell-style="{fontSize: '14px',color:'#0009',fontWeight: 'normal',backgroundColor:'#F2F3F5'}">
ad921312   wesley88   1
49
            <el-table-column label="序号" width="50" prop="id">
3f535f30   杨鑫   '初始'
50
51
52
53
              <template slot-scope="scope">
                {{scope.$index + 1 }}
              </template>
            </el-table-column>
ad921312   wesley88   1
54
            <el-table-column label="编号" prop="id">
3f535f30   杨鑫   '初始'
55
            </el-table-column>
ad921312   wesley88   1
56
            <el-table-column label="所属端"  v-if="leixing == 1">
3f535f30   杨鑫   '初始'
57
              <template slot-scope="scope">
ad921312   wesley88   1
58
                {{scope.row.cereAdvertisingInformation.affiliation}}
3f535f30   杨鑫   '初始'
59
              </template>
3f535f30   杨鑫   '初始'
60
            </el-table-column>
ad921312   wesley88   1
61
            <el-table-column label="轮播顺序"  v-if="leixing == 1">
3f535f30   杨鑫   '初始'
62
63
              <template slot-scope="scope">
                {{scope.row.cereAdvertisingInformation.rotationOrder}}
3f535f30   杨鑫   '初始'
64
              </template>
3f535f30   杨鑫   '初始'
65
            </el-table-column>
3f535f30   杨鑫   '初始'
66
  
3f535f30   杨鑫   '初始'
67
  
ad921312   wesley88   1
68
69
            <el-table-column label="申请人" prop="applicant" ></el-table-column>
            <el-table-column label="投放定价" prop="tenant">
3f535f30   杨鑫   '初始'
70
71
              <template slot-scope="scope">
                {{scope.row.rotationOrde}}
3f535f30   杨鑫   '初始'
72
73
              </template>
            </el-table-column>
ad921312   wesley88   1
74
            <el-table-column label="投放时间" prop="scheduleTime" >
3f535f30   杨鑫   '初始'
75
            </el-table-column>
ad921312   wesley88   1
76
            <el-table-column prop="applicationTime" label="提交时间" >
3f535f30   杨鑫   '初始'
77
            </el-table-column>
ad921312   wesley88   1
78
            <el-table-column label="状态" prop="auditStatus" >
3f535f30   杨鑫   '初始'
79
80
81
82
              <template slot-scope="scope">
                {{scope.row.auditStatus =='1'?'待审核':scope.row.auditStatus =='2'?'待签约':scope.row.auditStatus =='3'?'已驳回':scope.row.auditStatus =='4'?'已签约':'已终止'}}
              </template>
            </el-table-column>
ad921312   wesley88   1
83
            <el-table-column label="操作" fixed="right">
3f535f30   杨鑫   '初始'
84
85
              <template slot-scope="scope">
                <div @click="details(scope.row)" class="tableBtn greens">查看</div>
ad921312   wesley88   1
86
87
88
89
                <div class="tableBtn greens" v-if="scope.row.publishStatus=='0'" @click="removeinfo(scope.row,'编辑')">编辑</div>
                <div class="tableBtn greens" v-if="scope.row.publishStatus=='0' || scope.row.publishStatus=='2'" @click="closemsg(scope.row)">删除</div>
                <div class="tableBtn greens" v-if="scope.row.publishStatus=='0' || scope.row.publishStatus=='2'" @click="opencl(scope.row,'gg')">发布</div>
                <div class="tableBtn greens" v-if="scope.row.publishStatus=='1'" @click="removeinfozz(scope.row,'2','下架')">下架</div>
3f535f30   杨鑫   '初始'
90
91
92
              </template>
            </el-table-column>
          </el-table>
ad921312   wesley88   1
93
94
95
96
97
98
          <div style="display: flex;justify-content: space-between;" class="bom">
            <div style="font-size: 14px;">共 <span style="color: #3F9B6A;">{{total}}</span> 项数据</div>
            <el-pagination :current-page="pagequery.pageNumber+1" :page-sizes="[10, 20, 50, 100]" :page-size="10"
              background small layout="prev, pager, next" :total="total" @size-change="handleSizeChange"
              @current-change="handleCurrentChange">
            </el-pagination>
3f535f30   杨鑫   '初始'
99
100
101
102
          </div>
  
        </div>
  
ad921312   wesley88   1
103
      </div>
3f535f30   杨鑫   '初始'
104
  
3f535f30   杨鑫   '初始'
105
  
3f535f30   杨鑫   '初始'
106
  
3f535f30   杨鑫   '初始'
107
  
3f535f30   杨鑫   '初始'
108
  
3f535f30   杨鑫   '初始'
109
  
ad921312   wesley88   1
110
111
112
113
114
      <div class="zhuti" v-if="onaction == '2'">
        <div style="height:58px;line-height:58px;">
          <div style="color:#0006"> <span>广告位基本信息管理</span> <span style="padding:0 5px;">></span> <span
              style="color:#000000e6">新增</span></div>
        </div>
3f535f30   杨鑫   '初始'
115
  
ad921312   wesley88   1
116
117
118
        <div style="padding: 20px 20px 20px 0;">
          <add :info="{}" @removeonaction="removeonaction" :leixing="leixing"></add>
        </div>
3f535f30   杨鑫   '初始'
119
      </div>
ad921312   wesley88   1
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
      <div class="zhuti" v-if="onaction == '3'">
        <div style="height:58px;line-height:58px;">
          <div style="color:#0006"> <span>广告位基本信息管理</span> <span style="padding:0 5px;">></span> <span
              style="color:#000000e6">查看</span></div>
        </div>
        <div>
          <resourceCommodity :editbgid="detailsinfo" @removeonaction="removeonaction" :leixing="leixing">
          </resourceCommodity>
        </div>
      </div>
      <div class="zhuti" v-if="onaction == '4'">
        <div style="height:58px;line-height:58px;">
          <div style="color:#0006"> <span>广告位基本信息管理</span> <span style="padding:0 5px;">></span> <span
              style="color:#000000e6">{{contractChangeReason}}</span></div>
        </div>
        <div style="padding: 20px 20px 20px 0;">
          <add :info="detailsinfo" @removeonaction="removeonaction" :leixing="leixing"></add>
        </div>
      </div>
      <el-dialog :visible.sync="addcl" title="选择策略" width="65%" append-to-body center :close-on-click-modal="false"
        :close-on-press-escape="false" :show-close="false">
        <cl v-if="addcl" @minSev="minSev" @mingClose="mingClose"></cl>
      </el-dialog>
3f535f30   杨鑫   '初始'
143
    </div>
3f535f30   杨鑫   '初始'
144
  
ad921312   wesley88   1
145
  
3f535f30   杨鑫   '初始'
146
147
148
149
  </template>
  
  <script>
    import {
3f535f30   杨鑫   '初始'
150
151
152
153
154
155
156
157
158
159
160
161
      contractGetAll,
      contractDel,
      addList,
      updateList,
      queryById,
      hetongById,
      hetongadd,
      hetongEdit,
      AdvertiserInfoGetAll,
      AdvertiserInfoEdit,
      AdvertiserInfoDel
    } from '../../../api/advertisement.js'
ad921312   wesley88   1
162
163
    import add from '../../../components/add/addmap'
    import resourceCommodity from '../../../components/chakan/map'
3f535f30   杨鑫   '初始'
164
    import {
ad921312   wesley88   1
165
166
167
168
      cereResourceStrategy,
      editStatus
    } from '@/api/newly.js'
     import cl from '@/components/change/cl.vue'
3f535f30   杨鑫   '初始'
169
170
171
    export default {
      data() {
        return {
ad921312   wesley88   1
172
173
174
175
176
177
178
179
180
181
182
          oncetype: '',
          addcl: false,
          oninfo: {},
          multipleSelection: [],
  
          xsNum: 0,
          xxNum: 0,
          leixing: true,
          contractChangeReason: '',
          detailsinfo: {},
          pagequery: {
3f535f30   杨鑫   '初始'
183
184
            pageNumber: 1,
            pageSize: 10,
ad921312   wesley88   1
185
            advertisingSpaceType: '实体广告位'
3f535f30   杨鑫   '初始'
186
          },
ad921312   wesley88   1
187
188
189
190
          tableData: [],
          total: 0,
          onaction: '1',
          formInline: {},
3f535f30   杨鑫   '初始'
191
192
        }
      },
ad921312   wesley88   1
193
194
195
196
      components: {
        cl,
        add,
        resourceCommodity,
3f535f30   杨鑫   '初始'
197
      },
ad921312   wesley88   1
198
199
      created() {
        this.getAll()
3f535f30   杨鑫   '初始'
200
201
      },
      methods: {
ad921312   wesley88   1
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
        minSev(e) {
          this.multipleSelection = e
          console.error(this.multipleSelection)
          let ids = []
          for (let index = 0; index < this.multipleSelection.length; index++) {
            ids.push(this.multipleSelection[index].id)
          }
          console.error(this.oninfo)
          let c1 = {
            resourcesId: this.oncetype + this.oninfo.id,
            rentalPoliciesIds: ids,
          }
          console.error(c1)
          cereResourceStrategy(c1).then(res => {
            if (res.code == 200) {
              this.addcl = false
              this.$message({
                message: '绑定成功',
                type: 'success'
              })
              editStatus({
                resourcesId: this.oncetype + this.oninfo.id,
                publishStatus: '3'
              }).then(res => {
                this.onSubmit()
              })
            } else {
              this.$message({
                message: '绑定失败',
                type: 'error'
              })
            }
          })
        },
        mingClose() {
          this.multipleSelection = []
          this.addcl = false
        },
        async opencl(row, e) {
          this.oncetype = e
          this.oninfo = row
          this.multipleSelection = []
          this.addcl = true
3f535f30   杨鑫   '初始'
245
246
        },
        chenge(val) {
3f535f30   杨鑫   '初始'
247
          if (val == 1) {
ad921312   wesley88   1
248
249
250
            this.leixing = true
            this.pagequery.advertisingType = '线上广告位'
            this.getAll((this.pagequery))
3f535f30   杨鑫   '初始'
251
          } else {
ad921312   wesley88   1
252
253
254
            this.leixing = false
            this.pagequery.advertisingType = '实体广告位'
            this.getAll((this.pagequery))
3f535f30   杨鑫   '初始'
255
          }
3f535f30   杨鑫   '初始'
256
        },
ad921312   wesley88   1
257
258
259
        gettime() {
          // 获取当前时间
          let currentTime = new Date();
3f535f30   杨鑫   '初始'
260
  
ad921312   wesley88   1
261
262
          // 获取年份
          let year = currentTime.getFullYear();
3f535f30   杨鑫   '初始'
263
  
ad921312   wesley88   1
264
265
          // 获取月份(注意月份是从0开始计数的,所以需要加1)
          let month = currentTime.getMonth() + 1;
3f535f30   杨鑫   '初始'
266
  
ad921312   wesley88   1
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
          // 获取日期
          let day = currentTime.getDate();
  
          // 获取小时
          let hours = currentTime.getHours();
  
          // 获取分钟
          let minutes = currentTime.getMinutes();
  
          // 获取秒数
          let seconds = currentTime.getSeconds();
  
          // 获取毫秒数
          let milliseconds = currentTime.getMilliseconds();
  
          // 格式化时间为 YYYY-MM-DD
          let formattedDate = `${year}-${month.toString().padStart(2, '0')}-${day.toString().padStart(2, '0')}`;
  
          // 格式化时间为 HH:MM:SS
          let formattedTime =
            `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}:${seconds.toString().padStart(2, '0')}`;
  
          // 格式化时间为 YYYY-MM-DD HH:MM:SS
          let formattedDateTime = `${formattedDate} ${formattedTime}`;
          return formattedDateTime
3f535f30   杨鑫   '初始'
292
293
  
        },
ad921312   wesley88   1
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
        removeinfozz(row, e, tit) {
          let that = this
          this.$confirm('确定要' + tit + '吗?', '提示', {
            confirmButtonText: '确定',
            cancelButtonText: '取消',
            type: 'warning'
          }).then(() => {
            editList({
              ...row,
              publishStatus: e
            }).then(res => {
              console.error(res)
              if (res.code == 200) {
                this.$message({
                  message: tit + '成功',
                  type: 'success'
                })
                this.removeonaction('1')
              } else {
                this.$message({
                  message: res.msg,
                  type: 'error'
                })
              }
3f535f30   杨鑫   '初始'
318
  
ad921312   wesley88   1
319
            })
3f535f30   杨鑫   '初始'
320
          })
3f535f30   杨鑫   '初始'
321
        },
ad921312   wesley88   1
322
323
324
        details(row) {
          this.detailsinfo = row
          this.onaction = '3'
3f535f30   杨鑫   '初始'
325
        },
ad921312   wesley88   1
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
        removeinfo(row, e) {
          this.contractChangeReason = e
          let dimensions_parts = row.dimensions.split(" ")
          let dimensions = row.equipmentSize.split(" ")
  
          dimensions_parts.forEach(part => {
            if (part.startsWith("长")) {
              row.dimensionsH = part.split(":")[1];
            } else if (part.startsWith("宽")) {
              row.dimensionsK = part.split(":")[1];
            }
          })
          dimensions.forEach(part => {
            if (part.startsWith("长")) {
              row.equipmentSizeH = part.split(":")[1];
            } else if (part.startsWith("宽")) {
              row.equipmentSizeK = part.split(":")[1];
            } else if (part.startsWith("高")) {
              row.equipmentSizeG = part.split(":")[1];
            }
          })
          this.detailsinfo = row
          this.onaction = '4'
        },
        async getAll() {
          const res = await AdvertiserInfoGetAll(this.pagequery)
          this.tableData = res.data.content
          this.total = res.data.totalElements
          let obj1 = {
            pageNumber: 1,
            pageSize: 10,
            advertisingSpaceType: '线上广告位'
          }
          AdvertiserInfoGetAll(obj1).then(res1 => {
            this.xsNum = res1.data.totalElements
          })
          let obj2 = {
            pageNumber: 1,
            pageSize: 10,
            advertisingSpaceType: '实体广告位'
          }
          AdvertiserInfoGetAll(obj2).then(res2 => {
            this.xxNum = res2.data.totalElements
          })
        },
        removeonaction(e) {
          console.error(e)
          this.onaction = e
          this.pagequery.pageNumber = 0
          this.getAll()
3f535f30   杨鑫   '初始'
376
377
        },
        handleCurrentChange(val) {
ad921312   wesley88   1
378
379
          this.pagequery.pageNumber = val - 1
          this.getAll()
3f535f30   杨鑫   '初始'
380
        },
ad921312   wesley88   1
381
382
        handleSizeChange(val) {
          this.pagequery.pageSize = val
3f535f30   杨鑫   '初始'
383
384
385
        },
        // 查询按钮
        async onSubmit() {
ad921312   wesley88   1
386
387
          this.pagequery.pageNumber = 0
          this.getAll()
3f535f30   杨鑫   '初始'
388
389
390
        },
        //重置按钮
        resetting() {
ad921312   wesley88   1
391
392
393
394
395
          this.pagequery = {
              pageNumber: 0,
              pageSize: 10,
              advertisingName:''
            },
3f535f30   杨鑫   '初始'
396
            this.getAll()
3f535f30   杨鑫   '初始'
397
        },
ad921312   wesley88   1
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
        //删除
        closemsg(item) {
          const h = this.$createElement;
          this.$msgbox({
            title: '消息',
            message: h('p', null, [
              h('span', null, '是否删除 '),
            ]),
            showCancelButton: true,
            showClose: false,
            confirmButtonText: '确定',
            cancelButtonText: '取消',
            customClass: 'oe-dialog-btn',
            beforeClose: (action, instance, done) => {
              if (action === 'confirm') {
                delList({
                  id: item.id
                }).then(res => {
                  this.$message({
                    message: '删除成功',
                    type: 'success'
                  })
                  this.getAll()
                  done();
                })
              } else {
                done();
              }
            }
          })
3f535f30   杨鑫   '初始'
428
        },
3f535f30   杨鑫   '初始'
429
      }
3f535f30   杨鑫   '初始'
430
  
3f535f30   杨鑫   '初始'
431
432
433
434
435
436
437
438
    }
  </script>
  
  <style scoped>
    .zhuti {
      padding: 0 20px 20px 20px;
      min-height: calc(100vh - 50px - 20px);
      background-color: #Fff;
3f535f30   杨鑫   '初始'
439
  
ad921312   wesley88   1
440
    }
3f535f30   杨鑫   '初始'
441
442
443
444
445
446
    .chengeXia {
      border-bottom: 6px solid #3F9B6A;
      padding-bottom: 4px;
      color: #3F9B6A;
    }
  
3f535f30   杨鑫   '初始'
447
448
  
    .formSearch {
3f535f30   杨鑫   '初始'
449
450
451
452
      display: flex;
      width: 100%;
      font-size: 14px;
      justify-content: space-between;
3f535f30   杨鑫   '初始'
453
454
455
456
457
458
459
460
461
462
463
464
465
    }
  
    .bg-purple-dark {
      background: #99a9bf;
    }
  
    .bg-purple {
      background: #d3dce6;
    }
  
    .bg-purple-light {
      background: #e5e9f2;
    }
3f535f30   杨鑫   '初始'
466
467
468
469
470
    .grid-content {
      border-radius: 4px;
      min-height: 36px;
    }
  
3f535f30   杨鑫   '初始'
471
  
3f535f30   杨鑫   '初始'
472
473
  </style>
  <style lang="scss" scoped>
ad921312   wesley88   1
474
475
    ::v-deep .el-dialog__body {
      padding: 0 0 !important;
3f535f30   杨鑫   '初始'
476
477
    }
  
3f535f30   杨鑫   '初始'
478
  
ad921312   wesley88   1
479
480
481
    .el-dialog__header{
      padding: 0;
      display: none;
3f535f30   杨鑫   '初始'
482
    }
ad921312   wesley88   1
483
  </style>