mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-11-03 20:48:07 +00:00 
			
		
		
		
	Co-authored-by: Muhsin Keloth <muhsinkeramam@gmail.com> Co-authored-by: Pranav Raj S <pranav@chatwoot.com> Co-authored-by: Sojan Jose <sojan@pepalo.com>
		
			
				
	
	
		
			63 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import Vue from 'vue';
 | 
						|
import Vuelidate from 'vuelidate';
 | 
						|
import VueI18n from 'vue-i18n';
 | 
						|
import VueDOMPurifyHTML from 'vue-dompurify-html';
 | 
						|
import VueFormulate from '@braid/vue-formulate';
 | 
						|
import store from '../widget/store';
 | 
						|
import App from '../widget/App.vue';
 | 
						|
import ActionCableConnector from '../widget/helpers/actionCable';
 | 
						|
import i18n from '../widget/i18n';
 | 
						|
import {
 | 
						|
  startsWithPlus,
 | 
						|
  isPhoneNumberValidWithDialCode,
 | 
						|
} from 'shared/helpers/Validators';
 | 
						|
import router from '../widget/router';
 | 
						|
import { domPurifyConfig } from '../shared/helpers/HTMLSanitizer';
 | 
						|
const PhoneInput = () => import('../widget/components/Form/PhoneInput');
 | 
						|
 | 
						|
Vue.use(VueI18n);
 | 
						|
Vue.use(Vuelidate);
 | 
						|
Vue.use(VueDOMPurifyHTML, domPurifyConfig);
 | 
						|
 | 
						|
const i18nConfig = new VueI18n({
 | 
						|
  locale: 'en',
 | 
						|
  messages: i18n,
 | 
						|
});
 | 
						|
Vue.use(VueFormulate, {
 | 
						|
  library: {
 | 
						|
    phoneInput: {
 | 
						|
      classification: 'number',
 | 
						|
      component: PhoneInput,
 | 
						|
      slotProps: {
 | 
						|
        component: ['placeholder', 'hasErrorInPhoneInput'],
 | 
						|
      },
 | 
						|
    },
 | 
						|
  },
 | 
						|
  rules: {
 | 
						|
    startsWithPlus: ({ value }) => startsWithPlus(value),
 | 
						|
    isValidPhoneNumber: ({ value }) => isPhoneNumberValidWithDialCode(value),
 | 
						|
  },
 | 
						|
  classes: {
 | 
						|
    outer: 'mb-4 wrapper',
 | 
						|
    error: 'text-red-400 mt-2 text-xs font-medium',
 | 
						|
  },
 | 
						|
});
 | 
						|
// Event Bus
 | 
						|
window.bus = new Vue();
 | 
						|
 | 
						|
Vue.config.productionTip = false;
 | 
						|
 | 
						|
window.onload = () => {
 | 
						|
  window.WOOT_WIDGET = new Vue({
 | 
						|
    router,
 | 
						|
    store,
 | 
						|
    i18n: i18nConfig,
 | 
						|
    render: h => h(App),
 | 
						|
  }).$mount('#app');
 | 
						|
 | 
						|
  window.actionCable = new ActionCableConnector(
 | 
						|
    window.WOOT_WIDGET,
 | 
						|
    window.chatwootPubsubToken
 | 
						|
  );
 | 
						|
};
 |