UNPKG

@tarojs/taro-h5

Version:
186 lines (183 loc) 10.8 kB
import { Current } from '@tarojs/runtime'; import { inlineStyle, getCurrentPath } from '../../../utils/index.js'; class Toast { constructor() { this.options = { title: '', icon: 'none', image: '', duration: 1500, mask: false }; this.style = { maskStyle: { position: 'fixed', 'z-index': '1000', top: '0', right: '0', left: '0', bottom: '0' }, toastStyle: { 'z-index': '5000', 'box-sizing': 'border-box', display: 'flex', 'flex-direction': 'column', 'justify-content': 'center', '-webkit-justify-content': 'center', position: 'fixed', top: '50%', left: '50%', 'min-width': '120px', 'max-width': '200px', 'min-height': '120px', padding: '15px', transform: 'translate(-50%, -50%)', 'border-radius': '5px', 'text-align': 'center', 'line-height': '1.6', color: '#FFFFFF', background: 'rgba(17, 17, 17, 0.7)' }, successStyle: { margin: '6px auto', width: '38px', height: '38px', background: 'transparent url() no-repeat', 'background-size': '100%' }, errrorStyle: { margin: '6px auto', width: '38px', height: '38px', background: 'transparent url() no-repeat', 'background-size': '100%' }, loadingStyle: { margin: '6px auto', width: '38px', height: '38px', '-webkit-animation': 'taroLoading 1s steps(12, end) infinite', animation: 'taroLoading 1s steps(12, end) infinite', background: 'transparent url() no-repeat', 'background-size': '100%' }, imageStyle: { margin: '6px auto', width: '40px', height: '40px', background: 'transparent no-repeat', 'background-size': '100%' }, textStyle: { margin: '0', 'font-size': '16px' } }; } create(options = {}, _type = 'toast') { var _a, _b; // style const { maskStyle, toastStyle, successStyle, errrorStyle, loadingStyle, imageStyle, textStyle } = this.style; // configuration const config = Object.assign(Object.assign(Object.assign({}, this.options), options), { _type }); // wrapper this.el = document.createElement('div'); this.el.className = 'taro__toast'; this.el.style.opacity = '0'; this.el.style.transition = 'opacity 0.1s linear'; this.el.ontouchmove = (e) => { e.stopPropagation(); e.preventDefault(); }; // mask this.mask = document.createElement('div'); this.mask.setAttribute('style', inlineStyle(maskStyle)); this.mask.style.display = config.mask ? 'block' : 'none'; // icon this.icon = document.createElement('p'); if (config.image) { this.icon.setAttribute('style', inlineStyle(Object.assign(Object.assign({}, imageStyle), { 'background-image': `url(${config.image})` }))); } else { const iconStyle = config.icon === 'loading' ? loadingStyle : config.icon === 'error' ? errrorStyle : successStyle; this.icon.setAttribute('style', inlineStyle(Object.assign(Object.assign({}, iconStyle), (config.icon === 'none' ? { display: 'none' } : {})))); } // toast this.toast = document.createElement('div'); this.toast.setAttribute('style', inlineStyle(Object.assign(Object.assign({}, toastStyle), (config.icon === 'none' ? { 'min-height': '0', padding: '10px 15px' } : {})))); // title this.title = document.createElement('p'); this.title.setAttribute('style', inlineStyle(textStyle)); this.title.textContent = config.title; // result this.toast.appendChild(this.icon); this.toast.appendChild(this.title); this.el.appendChild(this.mask); this.el.appendChild(this.toast); // show immediately document.body.appendChild(this.el); setTimeout(() => { this.el.style.opacity = '1'; }, 0); this.type = config._type; // disappear after duration config.duration >= 0 && this.hide(config.duration, this.type); // Current.page不存在时说明路由还未挂载,此时需根据url来分配将要渲染的页面path this.currentPath = (_b = (_a = Current.page) === null || _a === void 0 ? void 0 : _a.path) !== null && _b !== void 0 ? _b : getCurrentPath(); return ''; } show(options = {}, _type = 'toast') { var _a, _b; const config = Object.assign(Object.assign(Object.assign({}, this.options), options), { _type }); if (this.hideOpacityTimer) clearTimeout(this.hideOpacityTimer); if (this.hideDisplayTimer) clearTimeout(this.hideDisplayTimer); // title this.title.textContent = config.title || ''; // mask this.mask.style.display = config.mask ? 'block' : 'none'; // image const { toastStyle, successStyle, errrorStyle, loadingStyle, imageStyle } = this.style; if (config.image) { this.icon.setAttribute('style', inlineStyle(Object.assign(Object.assign({}, imageStyle), { 'background-image': `url(${config.image})` }))); } else { if (!config.image && config.icon) { const iconStyle = config.icon === 'loading' ? loadingStyle : config.icon === 'error' ? errrorStyle : successStyle; this.icon.setAttribute('style', inlineStyle(Object.assign(Object.assign({}, iconStyle), (config.icon === 'none' ? { display: 'none' } : {})))); } } // toast this.toast.setAttribute('style', inlineStyle(Object.assign(Object.assign({}, toastStyle), (config.icon === 'none' ? { 'min-height': '0', padding: '10px 15px' } : {})))); // show this.el.style.display = 'block'; setTimeout(() => { this.el.style.opacity = '1'; }, 0); this.type = config._type; // disappear after duration config.duration >= 0 && this.hide(config.duration, this.type); // Current.page不存在时说明路由还未挂载,此时需根据url来分配将要渲染的页面path this.currentPath = (_b = (_a = Current.page) === null || _a === void 0 ? void 0 : _a.path) !== null && _b !== void 0 ? _b : getCurrentPath(); return ''; } hide(duration = 0, type = '') { if (type && type !== this.type) return; if (this.hideOpacityTimer) clearTimeout(this.hideOpacityTimer); if (this.hideDisplayTimer) clearTimeout(this.hideDisplayTimer); this.currentPath = null; this.hideOpacityTimer = setTimeout(() => { this.el.style.opacity = '0'; this.hideDisplayTimer = setTimeout(() => { this.el.style.display = 'none'; }, 100); }, duration); } } export { Toast as default }; //# sourceMappingURL=toast.js.map