mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-10-31 11:08:04 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			87 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <modal :show.sync="show" :on-close="closeModal">
 | |
|     <woot-modal-header :header-title="title" :header-content="message" />
 | |
|     <form @submit.prevent="onConfirm">
 | |
|       <woot-input
 | |
|         v-model="value"
 | |
|         type="text"
 | |
|         :class="{ error: $v.value.$error }"
 | |
|         :placeholder="confirmPlaceHolderText"
 | |
|         @blur="$v.value.$touch"
 | |
|       />
 | |
|       <div class="button-wrapper">
 | |
|         <woot-button color-scheme="alert" :is-disabled="$v.value.$invalid">
 | |
|           {{ confirmText }}
 | |
|         </woot-button>
 | |
|         <woot-button class="clear" @click.prevent="closeModal">
 | |
|           {{ rejectText }}
 | |
|         </woot-button>
 | |
|       </div>
 | |
|     </form>
 | |
|   </modal>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| import { required } from 'vuelidate/lib/validators';
 | |
| import Modal from '../../Modal.vue';
 | |
| 
 | |
| export default {
 | |
|   components: {
 | |
|     Modal,
 | |
|   },
 | |
| 
 | |
|   props: {
 | |
|     show: {
 | |
|       type: Boolean,
 | |
|       default: false,
 | |
|     },
 | |
|     title: {
 | |
|       type: String,
 | |
|       default: '',
 | |
|     },
 | |
|     message: {
 | |
|       type: String,
 | |
|       default: '',
 | |
|     },
 | |
|     confirmText: {
 | |
|       type: String,
 | |
|       default: '',
 | |
|     },
 | |
|     rejectText: {
 | |
|       type: String,
 | |
|       default: '',
 | |
|     },
 | |
|     confirmValue: {
 | |
|       type: String,
 | |
|       default: '',
 | |
|     },
 | |
|     confirmPlaceHolderText: {
 | |
|       type: String,
 | |
|       default: '',
 | |
|     },
 | |
|   },
 | |
|   data() {
 | |
|     return {
 | |
|       value: '',
 | |
|     };
 | |
|   },
 | |
|   validations: {
 | |
|     value: {
 | |
|       required,
 | |
|       isEqual(value) {
 | |
|         return value === this.confirmValue;
 | |
|       },
 | |
|     },
 | |
|   },
 | |
|   methods: {
 | |
|     closeModal() {
 | |
|       this.value = '';
 | |
|       this.$emit('on-close');
 | |
|     },
 | |
|     onConfirm() {
 | |
|       this.$emit('on-confirm');
 | |
|     },
 | |
|   },
 | |
| };
 | |
| </script>
 | 
