diff --git a/packages/taro-h5/src/api/ui/interaction/toast.ts b/packages/taro-h5/src/api/ui/interaction/toast.ts index 5e601317776d..453475d43309 100644 --- a/packages/taro-h5/src/api/ui/interaction/toast.ts +++ b/packages/taro-h5/src/api/ui/interaction/toast.ts @@ -40,13 +40,18 @@ export default class Toast { background: 'rgba(17, 17, 17, 0.7)' }, successStyle: { - margin: '0', - 'vertical-align': 'middle', - 'font-family': 'taro', - '-webkit-font-smoothing': 'antialiased', - color: '#FFFFFF', - 'font-size': '55px', - 'line-height': '1' + 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', @@ -81,7 +86,7 @@ export default class Toast { create (options = {}, _type: 'loading' | 'toast' = 'toast') { // style - const { maskStyle, toastStyle, successStyle, loadingStyle, imageStyle, textStyle } = this.style + const { maskStyle, toastStyle, successStyle, errrorStyle, loadingStyle, imageStyle, textStyle } = this.style // configuration const config = { @@ -109,12 +114,11 @@ export default class Toast { 'background-image': `url(${config.image})` })) } else { - const iconStyle = config.icon === 'loading' ? loadingStyle : successStyle + const iconStyle = config.icon === 'loading' ? loadingStyle : config.icon === 'error' ? errrorStyle : successStyle this.icon.setAttribute('style', inlineStyle({ ...iconStyle, ...(config.icon === 'none' ? { display: 'none' } : {}) })) - if (config.icon !== 'loading') this.icon.textContent = '' } // toast @@ -166,21 +170,19 @@ export default class Toast { this.mask.style.display = config.mask ? 'block' : 'none' // image - const { toastStyle, successStyle, loadingStyle, imageStyle } = this.style + const { toastStyle, successStyle, errrorStyle, loadingStyle, imageStyle } = this.style if (config.image) { this.icon.setAttribute('style', inlineStyle({ ...imageStyle, 'background-image': `url(${config.image})` })) - this.icon.textContent = '' } else { if (!config.image && config.icon) { - const iconStyle = config.icon === 'loading' ? loadingStyle : successStyle + const iconStyle = config.icon === 'loading' ? loadingStyle : config.icon === 'error' ? errrorStyle : successStyle this.icon.setAttribute('style', inlineStyle({ ...iconStyle, ...(config.icon === 'none' ? { display: 'none' } : {}) })) - this.icon.textContent = config.icon === 'loading' ? '' : '' } }