mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-11-04 04:57:51 +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';
 | 
						|
 | 
						|
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>
 |