mirror of
				https://github.com/youzan/vant.git
				synced 2025-10-20 18:54:24 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			92 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import Vue from 'vue';
 | |
| import VueToast from './toast';
 | |
| import { isObj } from '../utils';
 | |
| 
 | |
| const defaultOptions = {
 | |
|   type: 'text',
 | |
|   mask: false,
 | |
|   message: '',
 | |
|   visible: true,
 | |
|   duration: 3000,
 | |
|   position: 'middle',
 | |
|   forbidClick: false
 | |
| };
 | |
| const parseOptions = message => isObj(message) ? message : { message };
 | |
| 
 | |
| let queue = [];
 | |
| let singleton = true;
 | |
| let currentOptions = { ...defaultOptions };
 | |
| 
 | |
| function createInstance() {
 | |
|   if (!queue.length || !singleton) {
 | |
|     const toast = new (Vue.extend(VueToast))({
 | |
|       el: document.createElement('div')
 | |
|     });
 | |
|     document.body.appendChild(toast.$el);
 | |
|     queue.push(toast);
 | |
|   }
 | |
|   return queue[queue.length - 1];
 | |
| };
 | |
| 
 | |
| function Toast(options = {}) {
 | |
|   const toast = createInstance();
 | |
| 
 | |
|   options = {
 | |
|     ...currentOptions,
 | |
|     ...parseOptions(options),
 | |
|     clear() {
 | |
|       toast.visible = false;
 | |
|     }
 | |
|   };
 | |
| 
 | |
|   Object.assign(toast, options);
 | |
|   clearTimeout(toast.timer);
 | |
| 
 | |
|   if (options.duration > 0) {
 | |
|     toast.timer = setTimeout(() => {
 | |
|       toast.clear();
 | |
|     }, options.duration);
 | |
|   }
 | |
| 
 | |
|   return toast;
 | |
| };
 | |
| 
 | |
| const createMethod = type => options => Toast({
 | |
|   type, ...parseOptions(options)
 | |
| });
 | |
| 
 | |
| ['loading', 'success', 'fail'].forEach(method => {
 | |
|   Toast[method] = createMethod(method);
 | |
| });
 | |
| 
 | |
| Toast.clear = all => {
 | |
|   if (queue.length) {
 | |
|     if (all) {
 | |
|       queue.forEach(toast => {
 | |
|         toast.clear();
 | |
|       });
 | |
|       queue = [];
 | |
|     } else if (singleton) {
 | |
|       queue[0].clear();
 | |
|     } else {
 | |
|       queue.shift().clear();
 | |
|     }
 | |
|   }
 | |
| };
 | |
| 
 | |
| Toast.setDefaultOptions = options => {
 | |
|   Object.assign(currentOptions, options);
 | |
| };
 | |
| 
 | |
| Toast.resetDefaultOptions = () => {
 | |
|   currentOptions = { ...defaultOptions };
 | |
| };
 | |
| 
 | |
| Toast.allowMultiple = (allow = true) => {
 | |
|   singleton = !allow;
 | |
| };
 | |
| 
 | |
| Vue.prototype.$toast = Toast;
 | |
| 
 | |
| export default Toast;
 | 
