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
    <v-container fluid class="body-color">
      <!-- ****** EDIT Social Media ****** -->
db965de89   Amber Dev   added dialog pers...
4
      <v-dialog v-model="editSocialMediaDialog" max-width="400px" persistent>
4dd422bef   Shikha Mishra   change ui of card...
5
        <v-card flat class="Card-style pa-2">
68d742034   Neeraj Sharma   implement new des...
6
7
8
9
          <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

db965de89   Amber Dev   added dialog pers...
56
      <v-dialog v-model="profileSocialMediaDialog" max-width="500px" persistent>
4dd422bef   Shikha Mishra   change ui of card...
57
        <v-card flat class="Card-style pa-3">
68d742034   Neeraj Sharma   implement new des...
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-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 ****** -->
4dd422bef   Shikha Mishra   change ui of card...
185
186
187
188
189
190
191
      <v-dialog
        v-model="addSocialMediaDialog"
        max-width="400px"
        v-if="addSocialMediaDialog"
        persistent
      >
        <v-card flat class="Card-style pa-2">
68d742034   Neeraj Sharma   implement new des...
192
193
194
          <v-layout>
            <v-flex xs12>
              <label class="title text-xs-center">Add Social Media</label>
8e8d14254   Shikha Mishra   Cleared data whil...
195
              <v-icon size="24" class="right" @click="closeAddSocialMediaModel">cancel</v-icon>
8bb178441   Neeraj Sharma   implemnt api in s...
196
            </v-flex>
68d742034   Neeraj Sharma   implement new des...
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
252
253
254
255
256
          </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...
257
258
259
      <div class="loader" v-if="showLoader">
        <v-progress-circular indeterminate color="white"></v-progress-circular>
      </div>
68d742034   Neeraj Sharma   implement new des...
260
    </v-container>
8bb178441   Neeraj Sharma   implemnt api in s...
261
262
263
264
  </template>
  
  <script>
  import http from "@/Services/http.js";
8bb178441   Neeraj Sharma   implemnt api in s...
265
266
267
268
269
270
271
272
273
274
  
  export default {
    data: () => ({
      snackbar: false,
      y: "top",
      x: "right",
      mode: "",
      timeout: 3000,
      text: "",
      loading: false,
68d742034   Neeraj Sharma   implement new des...
275
      color: "",
8bb178441   Neeraj Sharma   implemnt api in s...
276
277
      date: null,
      search: "",
68d742034   Neeraj Sharma   implement new des...
278
279
280
      show: true,
      showSearch: false,
      addSocialMediaDialog: false,
8bb178441   Neeraj Sharma   implemnt api in s...
281
      showLoader: false,
68d742034   Neeraj Sharma   implement new des...
282
283
      editSocialMediaDialog: false,
      profileSocialMediaDialog: false,
8bb178441   Neeraj Sharma   implemnt api in s...
284
      valid: true,
8bb178441   Neeraj Sharma   implemnt api in s...
285
      pagination: {
8e8d14254   Shikha Mishra   Cleared data whil...
286
        rowsPerPage: 10,
8bb178441   Neeraj Sharma   implemnt api in s...
287
288
289
290
291
      },
      imageData: {},
      imageName: "",
      imageUrl: "",
      imageFile: "",
8e8d14254   Shikha Mishra   Cleared data whil...
292
293
      socialRules: [(v) => !!v || " Social media type is required"],
      linkUrlnRules: [(v) => !!v || " Link Url is required"],
8bb178441   Neeraj Sharma   implemnt api in s...
294
295
296
      headers: [
        {
          text: "No",
68d742034   Neeraj Sharma   implement new des...
297
          align: "",
8bb178441   Neeraj Sharma   implemnt api in s...
298
          sortable: false,
8e8d14254   Shikha Mishra   Cleared data whil...
299
          value: "No",
8bb178441   Neeraj Sharma   implemnt api in s...
300
        },
68d742034   Neeraj Sharma   implement new des...
301
        { text: "Type", value: "type", sortable: false, align: "center" },
8bb178441   Neeraj Sharma   implemnt api in s...
302
        {
68d742034   Neeraj Sharma   implement new des...
303
          text: "Link Url",
8bb178441   Neeraj Sharma   implemnt api in s...
304
305
          value: "linkUrl",
          sortable: false,
8e8d14254   Shikha Mishra   Cleared data whil...
306
          align: "center",
8bb178441   Neeraj Sharma   implemnt api in s...
307
        },
8e8d14254   Shikha Mishra   Cleared data whil...
308
        { text: "Action", value: "", sortable: false, align: "center" },
8bb178441   Neeraj Sharma   implemnt api in s...
309
310
311
312
313
314
315
316
      ],
      desserts: [],
      editedIndex: -1,
      socialMedia: {},
      editedItem: {},
      socialLink: [
        {
          name: "Face Book",
8e8d14254   Shikha Mishra   Cleared data whil...
317
          value: "FACEBOOK",
8bb178441   Neeraj Sharma   implemnt api in s...
318
319
320
        },
        {
          name: "You Tube",
8e8d14254   Shikha Mishra   Cleared data whil...
321
322
          value: "YOUTUBE",
        },
8bb178441   Neeraj Sharma   implemnt api in s...
323
      ],
8e8d14254   Shikha Mishra   Cleared data whil...
324
      userName: "",
8bb178441   Neeraj Sharma   implemnt api in s...
325
    }),
8e8d14254   Shikha Mishra   Cleared data whil...
326
327
328
329
330
331
332
    watch: {
      addSocialMediaDialog: function (val) {
        if (!val) {
          this.socialMedia = [];
        }
      },
    },
8bb178441   Neeraj Sharma   implemnt api in s...
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
    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...
367
            headers: { Authorization: "Bearer " + token },
8bb178441   Neeraj Sharma   implemnt api in s...
368
          })
8e8d14254   Shikha Mishra   Cleared data whil...
369
          .then((response) => {
8bb178441   Neeraj Sharma   implemnt api in s...
370
371
372
            this.desserts = response.data.data;
            this.showLoader = false;
          })
8e8d14254   Shikha Mishra   Cleared data whil...
373
          .catch((error) => {
8bb178441   Neeraj Sharma   implemnt api in s...
374
            this.showLoader = false;
1571e40b5   Neeraj Sharma   gallery and socia...
375
376
377
378
379
            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...
380
381
382
383
384
          });
      },
      editItem(item) {
        this.editedIndex = this.desserts.indexOf(item);
        this.editedItem = Object.assign({}, item);
68d742034   Neeraj Sharma   implement new des...
385
        this.editSocialMediaDialog = true;
8bb178441   Neeraj Sharma   implemnt api in s...
386
387
388
389
      },
      profile(item) {
        this.editedIndex = this.desserts.indexOf(item);
        this.editedItem = Object.assign({}, item);
68d742034   Neeraj Sharma   implement new des...
390
        this.profileSocialMediaDialog = true;
8bb178441   Neeraj Sharma   implemnt api in s...
391
392
393
394
      },
  
      deleteItem(item) {
        let deleteSocialMedia = {
8e8d14254   Shikha Mishra   Cleared data whil...
395
          socialId: item._id,
8bb178441   Neeraj Sharma   implemnt api in s...
396
397
398
399
400
        };
        http()
          .delete(
            "/deleteSocial",
            confirm("Are you sure you want to delete this?") && {
8e8d14254   Shikha Mishra   Cleared data whil...
401
              params: deleteSocialMedia,
8bb178441   Neeraj Sharma   implemnt api in s...
402
403
            }
          )
8e8d14254   Shikha Mishra   Cleared data whil...
404
          .then((response) => {
68d742034   Neeraj Sharma   implement new des...
405
            this.snackbar = true;
8bb178441   Neeraj Sharma   implemnt api in s...
406
            this.text = response.data.message;
68d742034   Neeraj Sharma   implement new des...
407
            this.color = "green";
8bb178441   Neeraj Sharma   implemnt api in s...
408
409
            this.getSocialMedia();
          })
8e8d14254   Shikha Mishra   Cleared data whil...
410
          .catch((error) => {
68d742034   Neeraj Sharma   implement new des...
411
412
413
            this.snackbar = true;
            this.text = error.response.data.message;
            this.color = "error";
8bb178441   Neeraj Sharma   implemnt api in s...
414
415
          });
      },
8bb178441   Neeraj Sharma   implemnt api in s...
416
      close() {
68d742034   Neeraj Sharma   implement new des...
417
        this.editSocialMediaDialog = false;
8bb178441   Neeraj Sharma   implemnt api in s...
418
      },
8e8d14254   Shikha Mishra   Cleared data whil...
419
420
421
422
      closeAddSocialMediaModel() {
        this.addSocialMediaDialog = false;
        this.socialMedia = [];
      },
8bb178441   Neeraj Sharma   implemnt api in s...
423
424
425
426
427
      submit() {
        if (this.$refs.form.validate()) {
          this.loading = true;
          http()
            .post("/addSocialLinks", this.socialMedia)
8e8d14254   Shikha Mishra   Cleared data whil...
428
            .then((response) => {
8bb178441   Neeraj Sharma   implemnt api in s...
429
430
              this.snackbar = true;
              this.text = response.data.message;
68d742034   Neeraj Sharma   implement new des...
431
              this.color = "green";
8bb178441   Neeraj Sharma   implemnt api in s...
432
433
              this.getSocialMedia();
              this.clear();
68d742034   Neeraj Sharma   implement new des...
434
              this.addSocialMediaDialog = false;
8bb178441   Neeraj Sharma   implemnt api in s...
435
436
              this.loading = false;
            })
8e8d14254   Shikha Mishra   Cleared data whil...
437
            .catch((error) => {
8bb178441   Neeraj Sharma   implemnt api in s...
438
              this.snackbar = true;
68d742034   Neeraj Sharma   implement new des...
439
              this.color = "error";
8bb178441   Neeraj Sharma   implemnt api in s...
440
441
442
443
444
445
446
447
448
449
450
451
              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...
452
            .then((response) => {
68d742034   Neeraj Sharma   implement new des...
453
454
455
              this.snackbar = true;
              this.text = response.data.message;
              this.color = "green";
8bb178441   Neeraj Sharma   implemnt api in s...
456
457
458
              this.getSocialMedia();
              this.close();
            })
8e8d14254   Shikha Mishra   Cleared data whil...
459
            .catch((error) => {
68d742034   Neeraj Sharma   implement new des...
460
461
462
              this.snackbar = true;
              this.text = error.response.data.message;
              this.color = "error";
8bb178441   Neeraj Sharma   implemnt api in s...
463
            });
68d742034   Neeraj Sharma   implement new des...
464
465
466
467
468
469
470
471
      },
      displaySearch() {
        (this.show = false), (this.showSearch = true);
      },
      closeSearch() {
        this.showSearch = false;
        this.show = true;
        this.search = "";
8e8d14254   Shikha Mishra   Cleared data whil...
472
      },
8bb178441   Neeraj Sharma   implemnt api in s...
473
474
475
    },
    mounted() {
      this.getSocialMedia();
8e8d14254   Shikha Mishra   Cleared data whil...
476
    },
8bb178441   Neeraj Sharma   implemnt api in s...
477
  };
68d742034   Neeraj Sharma   implement new des...
478
  </script>