Blame view

src/pages/socialMedia/socialMedia.vue 14.3 KB
8bb178441   Neeraj Sharma   implemnt api in s...
1
  <template>
68d742034   Neeraj Sharma   implement new des...
2
3
4
5
6
7
8
9
    <v-container fluid class="body-color">
      <!-- ****** EDIT Social Media ****** -->
      <v-dialog v-model="editSocialMediaDialog" max-width="400px">
        <v-card flat class="card-style pa-2" dark>
          <v-layout>
            <v-flex xs12>
              <label class="title text-xs-center">Edit Social Media</label>
              <v-icon size="24" class="right" @click="editSocialMediaDialog = false">cancel</v-icon>
8bb178441   Neeraj Sharma   implemnt api in s...
10
            </v-flex>
68d742034   Neeraj Sharma   implement new des...
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
          </v-layout>
          <v-form ref="form">
            <v-container fluid>
              <v-flex xs12 sm12>
                <v-layout>
                  <v-flex xs4 class="pt-4 subheading">
                    <label class="right">Type:</label>
                  </v-flex>
                  <v-flex xs8 sm8 class="ml-3">
                    <v-select
                      v-model="editedItem.type"
                      placeholder="fill your Title"
                      :items="socialLink"
                      item-text="name"
                      item-value="value"
                    ></v-select>
                  </v-flex>
                </v-layout>
              </v-flex>
              <v-flex xs12 sm12>
                <v-layout>
                  <v-flex xs4 class="pt-4 subheading">
                    <label class="right">Url lINK:</label>
                  </v-flex>
                  <v-flex xs8 sm8 class="ml-3">
                    <v-text-field placeholder="fill your Description" v-model="editedItem.linkUrl"></v-text-field>
                  </v-flex>
                </v-layout>
              </v-flex>
              <v-layout>
                <v-flex xs12 sm12>
                  <v-card-actions>
                    <v-spacer></v-spacer>
                    <v-btn round dark @click="save" class="add-button">Save</v-btn>
                    <v-spacer></v-spacer>
                  </v-card-actions>
                </v-flex>
              </v-layout>
            </v-container>
          </v-form>
        </v-card>
      </v-dialog>
8bb178441   Neeraj Sharma   implemnt api in s...
53

68d742034   Neeraj Sharma   implement new des...
54
      <!-- ****** PROFILE VIEW Social ******  -->
8bb178441   Neeraj Sharma   implemnt api in s...
55

68d742034   Neeraj Sharma   implement new des...
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
      <v-dialog v-model="profileSocialMediaDialog" max-width="500px">
        <v-card flat class="card-style pa-3" dark>
          <v-layout>
            <v-flex xs12>
              <label class="title text-xs-center">View Social Media</label>
              <v-icon size="24" class="right" @click="profileSocialMediaDialog = false">cancel</v-icon>
            </v-flex>
          </v-layout>
          <v-card-text>
            <v-container grid-list-md>
              <v-layout>
                <v-flex xs4 sm6>
                  <h5 class="right my-1">
                    <b>Title:</b>
                  </h5>
                </v-flex>
                <v-flex sm6 xs8>
                  <h5 class="my-1">{{ editedItem.type }}</h5>
                </v-flex>
              </v-layout>
              <v-layout>
                <v-flex xs5 sm6>
                  <h5 class="right my-1">
                    <b>Description:</b>
                  </h5>
                </v-flex>
                <v-flex sm6 xs8>
                  <h5 class="my-1 linkCover">{{ editedItem.linkUrl }}</h5>
                </v-flex>
              </v-layout>
            </v-container>
          </v-card-text>
        </v-card>
      </v-dialog>
      <!-- ****** Social TABLE ****** -->
      <v-toolbar color="transparent" flat>
        <v-btn
          fab
          dark
          class="open-dialog-button hidden-xl-only hidden-md-only hidden-lg-only"
          small
          @click="addSocialMediaDialog = true"
        >
          <v-icon dark>add</v-icon>
        </v-btn>
        <v-btn
          round
          class="open-dialog-button hidden-sm-only hidden-xs-only"
          dark
          @click="addSocialMediaDialog = true"
        >
          <v-icon class="white--text pr-1" size="20">add</v-icon>Add Social Media
        </v-btn>
        <v-spacer></v-spacer>
        <v-card-title class="body-1" v-show="show">
          <v-btn icon large flat @click="displaySearch">
            <v-avatar size="27">
aa310d61a   Shikha Mishra   added functionali...
113
              <img src="/static/icon/search.png" alt="icon" />
68d742034   Neeraj Sharma   implement new des...
114
115
116
            </v-avatar>
          </v-btn>
        </v-card-title>
8e8d14254   Shikha Mishra   Cleared data whil...
117
        <v-flex xs8 sm8 md3 lg2 v-if="showSearch">
68d742034   Neeraj Sharma   implement new des...
118
          <v-layout>
8e8d14254   Shikha Mishra   Cleared data whil...
119
120
121
122
123
124
125
            <v-text-field
              autofocus
              v-model="search"
              label="Search"
              prepend-inner-icon="search"
              color="primary"
            ></v-text-field>
68d742034   Neeraj Sharma   implement new des...
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
            <v-icon @click="closeSearch" color="error">close</v-icon>
          </v-layout>
        </v-flex>
      </v-toolbar>
      <v-data-table
        :headers="headers"
        :items="desserts"
        :pagination.sync="pagination"
        :search="search"
      >
        <template slot="items" slot-scope="props">
          <tr class="tr">
            <td class="td td-row">{{ props.index + 1}}</td>
            <td class="td td-row text-xs-center">{{ props.item.type}}</td>
            <td class="td td-row text-xs-center linkCover">{{ props.item.linkUrl}}</td>
            <td class="td td-row text-xs-center">
              <span>
                <v-tooltip top>
                  <img
                    slot="activator"
                    style="cursor:pointer; width:25px; height:25px; "
                    class="mr-3"
                    @click="profile(props.item)"
aa310d61a   Shikha Mishra   added functionali...
149
                    src="/static/icon/view.png"
68d742034   Neeraj Sharma   implement new des...
150
151
152
153
154
155
156
157
158
                  />
                  <span>View</span>
                </v-tooltip>
                <v-tooltip top>
                  <img
                    slot="activator"
                    style="cursor:pointer; width:20 px; height:18px; "
                    class="mr-3"
                    @click="editItem(props.item)"
aa310d61a   Shikha Mishra   added functionali...
159
                    src="/static/icon/edit.png"
68d742034   Neeraj Sharma   implement new des...
160
161
162
163
164
165
166
167
168
                  />
                  <span>Edit</span>
                </v-tooltip>
                <v-tooltip top>
                  <img
                    slot="activator"
                    style="cursor:pointer; width:20px; height:20px; "
                    class="mr-3"
                    @click="deleteItem(props.item)"
aa310d61a   Shikha Mishra   added functionali...
169
                    src="/static/icon/delete.png"
68d742034   Neeraj Sharma   implement new des...
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
                  />
                  <span>Delete</span>
                </v-tooltip>
              </span>
            </td>
          </tr>
        </template>
        <v-alert
          slot="no-results"
          :value="true"
          color="error"
          icon="warning"
        >Your search for "{{ search }}" found no results.</v-alert>
      </v-data-table>
      <!-- ****** ADD MULTIPLE REMINDER ****** -->
8e8d14254   Shikha Mishra   Cleared data whil...
185
      <v-dialog v-model="addSocialMediaDialog" max-width="400px" v-if="addSocialMediaDialog">
68d742034   Neeraj Sharma   implement new des...
186
187
188
189
        <v-card flat class="card-style pa-2" dark>
          <v-layout>
            <v-flex xs12>
              <label class="title text-xs-center">Add Social Media</label>
8e8d14254   Shikha Mishra   Cleared data whil...
190
              <v-icon size="24" class="right" @click="closeAddSocialMediaModel">cancel</v-icon>
8bb178441   Neeraj Sharma   implemnt api in s...
191
            </v-flex>
68d742034   Neeraj Sharma   implement new des...
192
193
194
195
196
197
198
199
200
201
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
245
246
247
248
249
250
251
          </v-layout>
          <v-form ref="form" v-model="valid" lazy-validation>
            <v-container fluid>
              <v-flex xs12>
                <v-layout>
                  <v-flex xs4 class="pt-4 subheading">
                    <label class="right">Type:</label>
                  </v-flex>
                  <v-flex xs8 sm8 class="ml-3">
                    <v-select
                      v-model="socialMedia.type"
                      :items="socialLink"
                      item-text="name"
                      item-value="value"
                      label="Selct Type"
                      type="text"
                      :rules="socialRules"
                      required
                    ></v-select>
                  </v-flex>
                </v-layout>
              </v-flex>
              <v-flex xs12>
                <v-layout>
                  <v-flex xs4 class="pt-4 subheading">
                    <label class="right">Link Url:</label>
                  </v-flex>
                  <v-flex xs8 sm8 class="ml-3">
                    <v-text-field
                      placeholder="fill your link url"
                      :rules="linkUrlnRules"
                      v-model="socialMedia.linkUrl"
                      type="text"
                      required
                    ></v-text-field>
                  </v-flex>
                </v-layout>
              </v-flex>
              <v-layout>
                <v-flex xs12 sm12>
                  <v-card-actions>
                    <v-spacer></v-spacer>
                    <v-btn @click="clear" round class="clear-button" dark>clear</v-btn>
                    <v-spacer></v-spacer>
                    <v-btn @click="submit" round dark :loading="loading" class="add-button">Add</v-btn>
                  </v-card-actions>
                </v-flex>
              </v-layout>
            </v-container>
          </v-form>
        </v-card>
      </v-dialog>
      <v-snackbar
        :timeout="timeout"
        :top="y === 'top'"
        :right="x === 'right'"
        :vertical="mode === 'vertical'"
        v-model="snackbar"
        :color="color"
      >{{ text }}</v-snackbar>
8bb178441   Neeraj Sharma   implemnt api in s...
252
253
254
      <div class="loader" v-if="showLoader">
        <v-progress-circular indeterminate color="white"></v-progress-circular>
      </div>
68d742034   Neeraj Sharma   implement new des...
255
    </v-container>
8bb178441   Neeraj Sharma   implemnt api in s...
256
257
258
259
  </template>
  
  <script>
  import http from "@/Services/http.js";
8bb178441   Neeraj Sharma   implemnt api in s...
260
261
262
263
264
265
266
267
268
269
  
  export default {
    data: () => ({
      snackbar: false,
      y: "top",
      x: "right",
      mode: "",
      timeout: 3000,
      text: "",
      loading: false,
68d742034   Neeraj Sharma   implement new des...
270
      color: "",
8bb178441   Neeraj Sharma   implemnt api in s...
271
272
      date: null,
      search: "",
68d742034   Neeraj Sharma   implement new des...
273
274
275
      show: true,
      showSearch: false,
      addSocialMediaDialog: false,
8bb178441   Neeraj Sharma   implemnt api in s...
276
      showLoader: false,
68d742034   Neeraj Sharma   implement new des...
277
278
      editSocialMediaDialog: false,
      profileSocialMediaDialog: false,
8bb178441   Neeraj Sharma   implemnt api in s...
279
      valid: true,
8bb178441   Neeraj Sharma   implemnt api in s...
280
      pagination: {
8e8d14254   Shikha Mishra   Cleared data whil...
281
        rowsPerPage: 10,
8bb178441   Neeraj Sharma   implemnt api in s...
282
283
284
285
286
      },
      imageData: {},
      imageName: "",
      imageUrl: "",
      imageFile: "",
8e8d14254   Shikha Mishra   Cleared data whil...
287
288
      socialRules: [(v) => !!v || " Social media type is required"],
      linkUrlnRules: [(v) => !!v || " Link Url is required"],
8bb178441   Neeraj Sharma   implemnt api in s...
289
290
291
      headers: [
        {
          text: "No",
68d742034   Neeraj Sharma   implement new des...
292
          align: "",
8bb178441   Neeraj Sharma   implemnt api in s...
293
          sortable: false,
8e8d14254   Shikha Mishra   Cleared data whil...
294
          value: "No",
8bb178441   Neeraj Sharma   implemnt api in s...
295
        },
68d742034   Neeraj Sharma   implement new des...
296
        { text: "Type", value: "type", sortable: false, align: "center" },
8bb178441   Neeraj Sharma   implemnt api in s...
297
        {
68d742034   Neeraj Sharma   implement new des...
298
          text: "Link Url",
8bb178441   Neeraj Sharma   implemnt api in s...
299
300
          value: "linkUrl",
          sortable: false,
8e8d14254   Shikha Mishra   Cleared data whil...
301
          align: "center",
8bb178441   Neeraj Sharma   implemnt api in s...
302
        },
8e8d14254   Shikha Mishra   Cleared data whil...
303
        { text: "Action", value: "", sortable: false, align: "center" },
8bb178441   Neeraj Sharma   implemnt api in s...
304
305
306
307
308
309
310
311
      ],
      desserts: [],
      editedIndex: -1,
      socialMedia: {},
      editedItem: {},
      socialLink: [
        {
          name: "Face Book",
8e8d14254   Shikha Mishra   Cleared data whil...
312
          value: "FACEBOOK",
8bb178441   Neeraj Sharma   implemnt api in s...
313
314
315
        },
        {
          name: "You Tube",
8e8d14254   Shikha Mishra   Cleared data whil...
316
317
          value: "YOUTUBE",
        },
8bb178441   Neeraj Sharma   implemnt api in s...
318
      ],
8e8d14254   Shikha Mishra   Cleared data whil...
319
      userName: "",
8bb178441   Neeraj Sharma   implemnt api in s...
320
    }),
8e8d14254   Shikha Mishra   Cleared data whil...
321
322
323
324
325
326
327
    watch: {
      addSocialMediaDialog: function (val) {
        if (!val) {
          this.socialMedia = [];
        }
      },
    },
8bb178441   Neeraj Sharma   implemnt api in s...
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
    methods: {
      // pickFile() {
      //   this.$refs.image.click();
      // },
  
      // onFilePicked(e) {
      //   // console.log(e)
      //   const files = e.target.files;
      //   this.imageData.upload = e.target.files[0];
      //   if (files[0] !== undefined) {
      //     this.imageName = files[0].name;
      //     if (this.imageName.lastIndexOf(".") <= 0) {
      //       return;
      //     }
      //     const fr = new FileReader();
      //     fr.readAsDataURL(files[0]);
      //     fr.addEventListener("load", () => {
      //       this.imageUrl = fr.result;
      //       this.imageFile = files[0]; // this is an image file that can be sent to server...
      //       this.imageData.imageUrl = URL.createObjectURL(this.imageFile);
      //       console.log("upload=======>", this.imageData.imageUrl);
      //       console.log("imageFile", this.imageFile);
      //     });
      //   } else {
      //     this.imageName = "";
      //     this.imageFile = "";
      //     this.imageUrl = "";
      //   }
      // },
      getSocialMedia() {
        this.showLoader = true;
        var token = this.$store.state.token;
        http()
          .get("/getSocialList", {
8e8d14254   Shikha Mishra   Cleared data whil...
362
            headers: { Authorization: "Bearer " + token },
8bb178441   Neeraj Sharma   implemnt api in s...
363
          })
8e8d14254   Shikha Mishra   Cleared data whil...
364
          .then((response) => {
8bb178441   Neeraj Sharma   implemnt api in s...
365
366
367
            this.desserts = response.data.data;
            this.showLoader = false;
          })
8e8d14254   Shikha Mishra   Cleared data whil...
368
          .catch((error) => {
8bb178441   Neeraj Sharma   implemnt api in s...
369
            this.showLoader = false;
1571e40b5   Neeraj Sharma   gallery and socia...
370
371
372
373
374
            if (error.response.status === 401) {
              this.$router.replace({ path: "/" });
              this.$store.dispatch("setToken", null);
              this.$store.dispatch("Id", null);
            }
8bb178441   Neeraj Sharma   implemnt api in s...
375
376
377
378
379
          });
      },
      editItem(item) {
        this.editedIndex = this.desserts.indexOf(item);
        this.editedItem = Object.assign({}, item);
68d742034   Neeraj Sharma   implement new des...
380
        this.editSocialMediaDialog = true;
8bb178441   Neeraj Sharma   implemnt api in s...
381
382
383
384
      },
      profile(item) {
        this.editedIndex = this.desserts.indexOf(item);
        this.editedItem = Object.assign({}, item);
68d742034   Neeraj Sharma   implement new des...
385
        this.profileSocialMediaDialog = true;
8bb178441   Neeraj Sharma   implemnt api in s...
386
387
388
389
      },
  
      deleteItem(item) {
        let deleteSocialMedia = {
8e8d14254   Shikha Mishra   Cleared data whil...
390
          socialId: item._id,
8bb178441   Neeraj Sharma   implemnt api in s...
391
392
393
394
395
        };
        http()
          .delete(
            "/deleteSocial",
            confirm("Are you sure you want to delete this?") && {
8e8d14254   Shikha Mishra   Cleared data whil...
396
              params: deleteSocialMedia,
8bb178441   Neeraj Sharma   implemnt api in s...
397
398
            }
          )
8e8d14254   Shikha Mishra   Cleared data whil...
399
          .then((response) => {
68d742034   Neeraj Sharma   implement new des...
400
            this.snackbar = true;
8bb178441   Neeraj Sharma   implemnt api in s...
401
            this.text = response.data.message;
68d742034   Neeraj Sharma   implement new des...
402
            this.color = "green";
8bb178441   Neeraj Sharma   implemnt api in s...
403
404
            this.getSocialMedia();
          })
8e8d14254   Shikha Mishra   Cleared data whil...
405
          .catch((error) => {
68d742034   Neeraj Sharma   implement new des...
406
407
408
            this.snackbar = true;
            this.text = error.response.data.message;
            this.color = "error";
8bb178441   Neeraj Sharma   implemnt api in s...
409
410
          });
      },
8bb178441   Neeraj Sharma   implemnt api in s...
411
      close() {
68d742034   Neeraj Sharma   implement new des...
412
        this.editSocialMediaDialog = false;
8bb178441   Neeraj Sharma   implemnt api in s...
413
      },
8e8d14254   Shikha Mishra   Cleared data whil...
414
415
416
417
      closeAddSocialMediaModel() {
        this.addSocialMediaDialog = false;
        this.socialMedia = [];
      },
8bb178441   Neeraj Sharma   implemnt api in s...
418
419
420
421
422
      submit() {
        if (this.$refs.form.validate()) {
          this.loading = true;
          http()
            .post("/addSocialLinks", this.socialMedia)
8e8d14254   Shikha Mishra   Cleared data whil...
423
            .then((response) => {
8bb178441   Neeraj Sharma   implemnt api in s...
424
425
              this.snackbar = true;
              this.text = response.data.message;
68d742034   Neeraj Sharma   implement new des...
426
              this.color = "green";
8bb178441   Neeraj Sharma   implemnt api in s...
427
428
              this.getSocialMedia();
              this.clear();
68d742034   Neeraj Sharma   implement new des...
429
              this.addSocialMediaDialog = false;
8bb178441   Neeraj Sharma   implemnt api in s...
430
431
              this.loading = false;
            })
8e8d14254   Shikha Mishra   Cleared data whil...
432
            .catch((error) => {
8bb178441   Neeraj Sharma   implemnt api in s...
433
              this.snackbar = true;
68d742034   Neeraj Sharma   implement new des...
434
              this.color = "error";
8bb178441   Neeraj Sharma   implemnt api in s...
435
436
437
438
439
440
441
442
443
444
445
446
              this.text = error.response.data.message;
              this.loading = false;
            });
        }
      },
      clear() {
        this.$refs.form.reset();
      },
      save() {
        (this.editedItem.socialId = this.editedItem._id),
          http()
            .put("/updateSocial", this.editedItem)
8e8d14254   Shikha Mishra   Cleared data whil...
447
            .then((response) => {
68d742034   Neeraj Sharma   implement new des...
448
449
450
              this.snackbar = true;
              this.text = response.data.message;
              this.color = "green";
8bb178441   Neeraj Sharma   implemnt api in s...
451
452
453
              this.getSocialMedia();
              this.close();
            })
8e8d14254   Shikha Mishra   Cleared data whil...
454
            .catch((error) => {
68d742034   Neeraj Sharma   implement new des...
455
456
457
              this.snackbar = true;
              this.text = error.response.data.message;
              this.color = "error";
8bb178441   Neeraj Sharma   implemnt api in s...
458
            });
68d742034   Neeraj Sharma   implement new des...
459
460
461
462
463
464
465
466
      },
      displaySearch() {
        (this.show = false), (this.showSearch = true);
      },
      closeSearch() {
        this.showSearch = false;
        this.show = true;
        this.search = "";
8e8d14254   Shikha Mishra   Cleared data whil...
467
      },
8bb178441   Neeraj Sharma   implemnt api in s...
468
469
470
    },
    mounted() {
      this.getSocialMedia();
8e8d14254   Shikha Mishra   Cleared data whil...
471
    },
8bb178441   Neeraj Sharma   implemnt api in s...
472
  };
68d742034   Neeraj Sharma   implement new des...
473
  </script>