|  | @@ -5,7 +5,6 @@
 | 
												
													
														
															|  |        <b-form-group :label="labels.title"
 |  |        <b-form-group :label="labels.title"
 | 
												
													
														
															|  |                      label-for="distributor_title">
 |  |                      label-for="distributor_title">
 | 
												
													
														
															|  |          <b-form-input id="distributor_title"
 |  |          <b-form-input id="distributor_title"
 | 
												
													
														
															|  | -                      type="email"
 |  | 
 | 
												
													
														
															|  |                        v-model="distributor.title"
 |  |                        v-model="distributor.title"
 | 
												
													
														
															|  |                        required
 |  |                        required
 | 
												
													
														
															|  |                        :placeholder="labels.titlePlaceholder">
 |  |                        :placeholder="labels.titlePlaceholder">
 | 
												
											
												
													
														
															|  | @@ -39,13 +38,14 @@
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |            <b-input class="mb-3 mr-sm-3" 
 |  |            <b-input class="mb-3 mr-sm-3" 
 | 
												
													
														
															|  |                v-model="contact.email" 
 |  |                v-model="contact.email" 
 | 
												
													
														
															|  | 
 |  | +              type="email"
 | 
												
													
														
															|  |                :placeholder="labels.email" />
 |  |                :placeholder="labels.email" />
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |            <b-input class="mb-3 mr-sm-3" 
 |  |            <b-input class="mb-3 mr-sm-3" 
 | 
												
													
														
															|  |                v-model="contact.phone" 
 |  |                v-model="contact.phone" 
 | 
												
													
														
															|  |                :placeholder="labels.phone"/>
 |  |                :placeholder="labels.phone"/>
 | 
												
													
														
															|  |                
 |  |                
 | 
												
													
														
															|  | -          <b-button @click.stop="onDelete(key)" class="mb-3 mr-sm-3"  variant="primary">{{labels.delete}}</b-button>
 |  | 
 | 
												
													
														
															|  | 
 |  | +          <b-button @click.stop="onDelete(key)" class="mb-3 mr-sm-3" variant="danger">{{labels.delete}}</b-button>
 | 
												
													
														
															|  |          
 |  |          
 | 
												
													
														
															|  |          </b-form>
 |  |          </b-form>
 | 
												
													
														
															|  |  
 |  |  
 | 
												
											
												
													
														
															|  | @@ -55,7 +55,7 @@
 | 
												
													
														
															|  |      
 |  |      
 | 
												
													
														
															|  |          <b-form-group class="text-right">
 |  |          <b-form-group class="text-right">
 | 
												
													
														
															|  |            <b-button  type="submit" variant="primary">{{labels.submit}}</b-button>
 |  |            <b-button  type="submit" variant="primary">{{labels.submit}}</b-button>
 | 
												
													
														
															|  | -          <b-button @click.stop="onCancel()" type="reset" variant="danger">{{labels.cancel}}</b-button>
 |  | 
 | 
												
													
														
															|  | 
 |  | +          <b-button @click.stop="onCancel()" variant="danger">{{labels.cancel}}</b-button>
 | 
												
													
														
															|  |          </b-form-group>
 |  |          </b-form-group>
 | 
												
													
														
															|  |        </b-form-group>
 |  |        </b-form-group>
 | 
												
													
														
															|  |      </b-form>
 |  |      </b-form>
 | 
												
											
												
													
														
															|  | @@ -66,6 +66,7 @@
 | 
												
													
														
															|  |  import {mapGetters, mapActions} from 'vuex';
 |  |  import {mapGetters, mapActions} from 'vuex';
 | 
												
													
														
															|  |  import * as types from '../store/types';
 |  |  import * as types from '../store/types';
 | 
												
													
														
															|  |  import {store} from '../store/store';
 |  |  import {store} from '../store/store';
 | 
												
													
														
															|  | 
 |  | +import {cloneDeep, debounce} from 'lodash';
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  export default {
 |  |  export default {
 | 
												
													
														
															|  |    props: {
 |  |    props: {
 | 
												
											
												
													
														
															|  | @@ -84,11 +85,12 @@ export default {
 | 
												
													
														
															|  |          cancel: 'Cancel',
 |  |          cancel: 'Cancel',
 | 
												
													
														
															|  |          titlePlaceholder: 'Enter title',
 |  |          titlePlaceholder: 'Enter title',
 | 
												
													
														
															|  |          notesPlaceholder: 'Enter something',
 |  |          notesPlaceholder: 'Enter something',
 | 
												
													
														
															|  | -        add: 'Add',
 |  | 
 | 
												
													
														
															|  | 
 |  | +        add: 'Add Contact',
 | 
												
													
														
															|  |          name: 'Name',
 |  |          name: 'Name',
 | 
												
													
														
															|  |          email: 'Email',
 |  |          email: 'Email',
 | 
												
													
														
															|  |          phone: 'Phone',
 |  |          phone: 'Phone',
 | 
												
													
														
															|  | -      }
 |  | 
 | 
												
													
														
															|  | 
 |  | +      },
 | 
												
													
														
															|  | 
 |  | +      backup: {},
 | 
												
													
														
															|  |      }
 |  |      }
 | 
												
													
														
															|  |    },
 |  |    },
 | 
												
													
														
															|  |    computed: {
 |  |    computed: {
 | 
												
											
												
													
														
															|  | @@ -103,17 +105,22 @@ export default {
 | 
												
													
														
															|  |          set(val) {
 |  |          set(val) {
 | 
												
													
														
															|  |            //Placeholder
 |  |            //Placeholder
 | 
												
													
														
															|  |          },
 |  |          },
 | 
												
													
														
															|  | -      }
 |  | 
 | 
												
													
														
															|  | 
 |  | +      },
 | 
												
													
														
															|  |    },
 |  |    },
 | 
												
													
														
															|  |    watch: {
 |  |    watch: {
 | 
												
													
														
															|  |      distributor: {
 |  |      distributor: {
 | 
												
													
														
															|  |        handler(val){
 |  |        handler(val){
 | 
												
													
														
															|  | -        this.saveDistributor({
 |  | 
 | 
												
													
														
															|  | -          id: val.id, 
 |  | 
 | 
												
													
														
															|  | -          distributor: val
 |  | 
 | 
												
													
														
															|  | -        });
 |  | 
 | 
												
													
														
															|  | 
 |  | +          this.saveDistributor({
 | 
												
													
														
															|  | 
 |  | +            id: val.id, 
 | 
												
													
														
															|  | 
 |  | +            distributor: val
 | 
												
													
														
															|  | 
 |  | +          });
 | 
												
													
														
															|  |        },
 |  |        },
 | 
												
													
														
															|  |        deep: true
 |  |        deep: true
 | 
												
													
														
															|  | 
 |  | +    },
 | 
												
													
														
															|  | 
 |  | +    id(newId, oldId) {
 | 
												
													
														
															|  | 
 |  | +      if (newId !== oldId) {
 | 
												
													
														
															|  | 
 |  | +        this.backup = cloneDeep(this.distributor);
 | 
												
													
														
															|  | 
 |  | +      }
 | 
												
													
														
															|  |      }
 |  |      }
 | 
												
													
														
															|  |    },
 |  |    },
 | 
												
													
														
															|  |    methods: {
 |  |    methods: {
 | 
												
											
												
													
														
															|  | @@ -121,7 +128,8 @@ export default {
 | 
												
													
														
															|  |            saveDistributor: types.SET_DISTRIBUTOR,
 |  |            saveDistributor: types.SET_DISTRIBUTOR,
 | 
												
													
														
															|  |        }),
 |  |        }),
 | 
												
													
														
															|  |      onSubmit (ev) {
 |  |      onSubmit (ev) {
 | 
												
													
														
															|  | -      console.log(ev);
 |  | 
 | 
												
													
														
															|  | 
 |  | +      // No need to save as all should already be saved
 | 
												
													
														
															|  | 
 |  | +      this.$root.$emit('bv::hide::modal', 'distributor_modal_form');
 | 
												
													
														
															|  |      },
 |  |      },
 | 
												
													
														
															|  |      onAddContact () {
 |  |      onAddContact () {
 | 
												
													
														
															|  |        console.log('add');
 |  |        console.log('add');
 | 
												
											
												
													
														
															|  | @@ -130,7 +138,12 @@ export default {
 | 
												
													
														
															|  |        console.log('delete', item);
 |  |        console.log('delete', item);
 | 
												
													
														
															|  |      },
 |  |      },
 | 
												
													
														
															|  |      onCancel() {
 |  |      onCancel() {
 | 
												
													
														
															|  | -      console.log('onCancel');
 |  | 
 | 
												
													
														
															|  | 
 |  | +      //Reset the changes
 | 
												
													
														
															|  | 
 |  | +      this.saveDistributor({
 | 
												
													
														
															|  | 
 |  | +          id: this.backup.id, 
 | 
												
													
														
															|  | 
 |  | +          distributor: this.backup
 | 
												
													
														
															|  | 
 |  | +        });
 | 
												
													
														
															|  | 
 |  | +      this.$root.$emit('bv::hide::modal', 'distributor_modal_form');
 | 
												
													
														
															|  |      }
 |  |      }
 | 
												
													
														
															|  |    },
 |  |    },
 | 
												
													
														
															|  |  }
 |  |  }
 |