mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-10-31 19:17:48 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			90 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <script>
 | |
| import { required } from '@vuelidate/validators';
 | |
| import { useVuelidate } from '@vuelidate/core';
 | |
| import Modal from '../../Modal.vue';
 | |
| 
 | |
| import NextButton from 'dashboard/components-next/button/Button.vue';
 | |
| 
 | |
| export default {
 | |
|   components: {
 | |
|     Modal,
 | |
|     NextButton,
 | |
|   },
 | |
|   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: '' },
 | |
|   },
 | |
|   emits: ['onClose', 'onConfirm', 'update:show'],
 | |
|   setup() {
 | |
|     return { v$: useVuelidate() };
 | |
|   },
 | |
|   data() {
 | |
|     return {
 | |
|       value: '',
 | |
|     };
 | |
|   },
 | |
|   validations: {
 | |
|     value: {
 | |
|       required,
 | |
|       isEqual(value) {
 | |
|         return value === this.confirmValue;
 | |
|       },
 | |
|     },
 | |
|   },
 | |
|   computed: {
 | |
|     localShow: {
 | |
|       get() {
 | |
|         return this.show;
 | |
|       },
 | |
|       set(value) {
 | |
|         this.$emit('update:show', value);
 | |
|       },
 | |
|     },
 | |
|   },
 | |
|   methods: {
 | |
|     closeModal() {
 | |
|       this.value = '';
 | |
|       this.$emit('onClose');
 | |
|     },
 | |
|     onConfirm() {
 | |
|       this.$emit('onConfirm');
 | |
|     },
 | |
|   },
 | |
| };
 | |
| </script>
 | |
| 
 | |
| <template>
 | |
|   <Modal v-model:show="localShow" :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="flex items-center justify-end gap-2">
 | |
|         <NextButton
 | |
|           faded
 | |
|           slate
 | |
|           type="reset"
 | |
|           :label="rejectText"
 | |
|           @click.prevent="closeModal"
 | |
|         />
 | |
|         <NextButton
 | |
|           ruby
 | |
|           type="submit"
 | |
|           :label="confirmText"
 | |
|           :disabled="v$.value.$invalid"
 | |
|         />
 | |
|       </div>
 | |
|     </form>
 | |
|   </Modal>
 | |
| </template>
 | 
