New file |
| | |
| | | .iziToast-capsule { |
| | | font-size: 0; |
| | | height: 0; |
| | | width: 100%; |
| | | transform: translateZ(0); |
| | | backface-visibility: hidden; |
| | | transition: transform 0.5s cubic-bezier(0.25, 0.8, 0.25, 1), height 0.5s cubic-bezier(0.25, 0.8, 0.25, 1); |
| | | } |
| | | |
| | | .iziToast-capsule, .iziToast-capsule * { |
| | | box-sizing: border-box; |
| | | } |
| | | |
| | | .iziToast-overlay { |
| | | display: block; |
| | | position: fixed; |
| | | top: -100px; |
| | | left: 0; |
| | | right: 0; |
| | | bottom: -100px; |
| | | z-index: 19891100; |
| | | } |
| | | |
| | | .iziToast { |
| | | display: inline-block; |
| | | clear: both; |
| | | position: relative; |
| | | font-family: 'Lato', Tahoma, Arial; |
| | | font-size: 14px; |
| | | padding: 8px 45px 9px 0; |
| | | background: #fff; |
| | | border-color: #fff; |
| | | width: 100%; |
| | | pointer-events: all; |
| | | cursor: default; |
| | | transform: translateX(0); |
| | | -webkit-touch-callout: none /* iOS Safari */; |
| | | -webkit-user-select: none /* Chrome/Safari/Opera */; |
| | | -khtml-user-select: none /* Konqueror */; |
| | | -moz-user-select: none /* Firefox */; |
| | | -ms-user-select: none /* Internet Explorer/Edge */; |
| | | user-select: none; |
| | | min-height: 45px; |
| | | box-shadow: 0 2px 12px 0 rgba(0, 0, 0, .1); |
| | | max-width: 90%; |
| | | margin: 5px 0; |
| | | border-radius: 4px; |
| | | } |
| | | |
| | | .iziToast > .iziToast-progressbar { |
| | | position: absolute; |
| | | left: 0; |
| | | bottom: 0; |
| | | width: 100%; |
| | | z-index: 1; |
| | | background: rgba(255, 255, 255, 0.5); |
| | | } |
| | | |
| | | .iziToast > .iziToast-progressbar > div { |
| | | height: 2px; |
| | | width: 100%; |
| | | background: #dddddd; |
| | | border-radius: 0 0 3px 3px; |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark > .iziToast-progressbar > div { |
| | | background: #fff; |
| | | } |
| | | |
| | | .iziToast.iziToast-balloon:before { |
| | | content: ''; |
| | | position: absolute; |
| | | right: 8px; |
| | | left: auto; |
| | | width: 0px; |
| | | height: 0px; |
| | | top: 100%; |
| | | border-right: 0px solid transparent; |
| | | border-left: 15px solid transparent; |
| | | border-top: 10px solid #000; |
| | | border-top-color: inherit; |
| | | border-radius: 0; |
| | | } |
| | | |
| | | .iziToast.iziToast-balloon .iziToast-progressbar { |
| | | top: 0; |
| | | bottom: auto; |
| | | } |
| | | |
| | | .iziToast.iziToast-balloon > div { |
| | | border-radius: 0 0 0 3px; |
| | | } |
| | | |
| | | .iziToast > .iziToast-cover { |
| | | position: absolute; |
| | | left: 0; |
| | | top: 0; |
| | | bottom: 0; |
| | | height: 100%; |
| | | margin: 0; |
| | | background-size: 100%; |
| | | background-position: 50% 50%; |
| | | background-repeat: no-repeat; |
| | | } |
| | | |
| | | .iziToast > .iziToast-close { |
| | | position: absolute; |
| | | right: 0; |
| | | top: 0; |
| | | border: 0; |
| | | padding: 0; |
| | | opacity: 0.6; |
| | | width: 42px; |
| | | height: 100%; |
| | | background: url("") no-repeat 50% 50%; |
| | | background-size: 8px; |
| | | cursor: pointer; |
| | | outline: none; |
| | | } |
| | | |
| | | .iziToast > .iziToast-close:hover { |
| | | opacity: 1; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body { |
| | | position: relative; |
| | | padding: 0 0 0 10px; |
| | | height: auto; |
| | | min-height: 28px; |
| | | margin: 0 0 0 15px; |
| | | text-align: left; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body:after { |
| | | content: ""; |
| | | display: table; |
| | | clear: both; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-texts { |
| | | margin: 6px 0; |
| | | padding-right: 2px; |
| | | display: inline-block; |
| | | float: left; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-inputs { |
| | | min-height: 19px; |
| | | float: left; |
| | | margin: 3px -2px; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-inputs > input:not([type=checkbox]):not([type=radio]), |
| | | .iziToast > .iziToast-body .iziToast-inputs > select { |
| | | position: relative; |
| | | display: inline-block; |
| | | margin: 2px; |
| | | border-radius: 2px; |
| | | border: 0; |
| | | padding: 4px 7px; |
| | | font-size: 13px; |
| | | letter-spacing: 0.02em; |
| | | background: rgba(0, 0, 0, 0.1); |
| | | color: #000; |
| | | box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.2); |
| | | min-height: 26px; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-inputs > input:not([type=checkbox]):not([type=radio]):focus, |
| | | .iziToast > .iziToast-body .iziToast-inputs > select:focus { |
| | | box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.6); |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-buttons { |
| | | min-height: 17px; |
| | | float: left; |
| | | margin: 4px 0 0 0; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-buttons > a, |
| | | .iziToast > .iziToast-body .iziToast-buttons > button, |
| | | .iziToast > .iziToast-body .iziToast-buttons > input:not([type=checkbox]):not([type=radio]) { |
| | | position: relative; |
| | | display: inline-block; |
| | | margin: 2px; |
| | | border-radius: 2px; |
| | | border: 0; |
| | | padding: 5px 10px; |
| | | font-size: 12px; |
| | | letter-spacing: 0.02em; |
| | | cursor: pointer; |
| | | background: rgba(0, 0, 0, 0.1); |
| | | color: #555; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-buttons > a:hover, |
| | | .iziToast > .iziToast-body .iziToast-buttons > button:hover, |
| | | .iziToast > .iziToast-body .iziToast-buttons > input:not([type=checkbox]):not([type=radio]):hover { |
| | | background: rgba(0, 0, 0, 0.15); |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-buttons > a:focus, |
| | | .iziToast > .iziToast-body .iziToast-buttons > button:focus, |
| | | .iziToast > .iziToast-body .iziToast-buttons > input:not([type=checkbox]):not([type=radio]):focus { |
| | | box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.6); |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-buttons > a:active, |
| | | .iziToast > .iziToast-body .iziToast-buttons > button:active, |
| | | .iziToast > .iziToast-body .iziToast-buttons > input:not([type=checkbox]):not([type=radio]):active { |
| | | top: 1px; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-icon { |
| | | height: 100%; |
| | | position: absolute; |
| | | left: 0; |
| | | top: 50%; |
| | | display: table; |
| | | font-size: 23px; |
| | | line-height: 24px; |
| | | margin-top: -11px; |
| | | color: #000; |
| | | width: 24px; |
| | | height: 24px; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-icon.ico-info { |
| | | background: url("") no-repeat 50% 50%; |
| | | background-size: 85%; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-icon.ico-warning { |
| | | background: url("") no-repeat 50% 50%; |
| | | background-size: 85%; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-icon.ico-error { |
| | | background: url("") no-repeat 50% 50%; |
| | | background-size: 80%; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-icon.ico-success { |
| | | background: url("") no-repeat 50% 50%; |
| | | background-size: 85%; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-icon.ico-question { |
| | | background: url("") no-repeat 50% 50%; |
| | | background-size: 85%; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-icon.ico-load { |
| | | background: url('') no-repeat 50% 50%; |
| | | background-size: 85%; |
| | | animation: rotating 1.2s linear infinite |
| | | } |
| | | |
| | | @keyframes rotating { |
| | | from { |
| | | transform: rotate(0) |
| | | } |
| | | to { |
| | | transform: rotate(360deg) |
| | | } |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-title { |
| | | padding: 0; |
| | | margin: 0 0 10px 0; |
| | | line-height: 16px; |
| | | font-size: 14px; |
| | | text-align: left; |
| | | float: left; |
| | | color: #303133; |
| | | white-space: normal; |
| | | } |
| | | |
| | | .iziToast > .iziToast-body .iziToast-message { |
| | | padding: 0; |
| | | margin: 0; |
| | | font-size: 14px; |
| | | line-height: 16px; |
| | | text-align: left; |
| | | float: left; |
| | | color: #606266; |
| | | white-space: normal; |
| | | } |
| | | |
| | | .iziToast.iziToast-animateInside .iziToast-title, |
| | | .iziToast.iziToast-animateInside .iziToast-message, |
| | | .iziToast.iziToast-animateInside .iziToast-icon, |
| | | .iziToast.iziToast-animateInside .iziToast-buttons-child, |
| | | .iziToast.iziToast-animateInside .iziToast-inputs-child { |
| | | opacity: 0; |
| | | } |
| | | |
| | | .iziToast-target { |
| | | position: relative; |
| | | width: 100%; |
| | | margin: 0 auto; |
| | | } |
| | | |
| | | .iziToast-target .iziToast-capsule { |
| | | overflow: hidden; |
| | | } |
| | | |
| | | .iziToast-target .iziToast-capsule:after { |
| | | visibility: hidden; |
| | | display: block; |
| | | font-size: 0; |
| | | content: " "; |
| | | clear: both; |
| | | height: 0; |
| | | } |
| | | |
| | | .iziToast-target .iziToast-capsule .iziToast { |
| | | width: 100%; |
| | | float: left; |
| | | } |
| | | |
| | | .iziToast-wrapper { |
| | | z-index: 19891101; |
| | | position: fixed; |
| | | width: 100%; |
| | | pointer-events: none; |
| | | display: flex; |
| | | flex-direction: column; |
| | | } |
| | | |
| | | .iziToast-wrapper .iziToast.iziToast-balloon:before { |
| | | border-right: 0 solid transparent; |
| | | border-left: 15px solid transparent; |
| | | border-top: 10px solid #000; |
| | | border-top-color: inherit; |
| | | right: 8px; |
| | | left: auto; |
| | | } |
| | | |
| | | .iziToast-wrapper-bottomLeft { |
| | | left: 0; |
| | | bottom: 0; |
| | | text-align: left; |
| | | } |
| | | |
| | | .iziToast-wrapper-bottomLeft .iziToast.iziToast-balloon:before { |
| | | border-right: 15px solid transparent; |
| | | border-left: 0 solid transparent; |
| | | right: auto; |
| | | left: 8px; |
| | | } |
| | | |
| | | .iziToast-wrapper-bottomRight { |
| | | right: 0; |
| | | bottom: 0; |
| | | text-align: right; |
| | | } |
| | | |
| | | .iziToast-wrapper-topLeft { |
| | | left: 0; |
| | | top: 0; |
| | | text-align: left; |
| | | } |
| | | |
| | | .iziToast-wrapper-topLeft .iziToast.iziToast-balloon:before { |
| | | border-right: 15px solid transparent; |
| | | border-left: 0 solid transparent; |
| | | right: auto; |
| | | left: 8px; |
| | | } |
| | | |
| | | .iziToast-wrapper-topRight { |
| | | top: 0; |
| | | right: 0; |
| | | text-align: right; |
| | | } |
| | | |
| | | .iziToast-wrapper-topCenter { |
| | | top: 0; |
| | | left: 0; |
| | | right: 0; |
| | | text-align: center; |
| | | } |
| | | |
| | | .iziToast-wrapper-bottomCenter { |
| | | bottom: 0; |
| | | left: 0; |
| | | right: 0; |
| | | text-align: center; |
| | | } |
| | | |
| | | .iziToast-wrapper-center { |
| | | top: 0; |
| | | bottom: 0; |
| | | left: 0; |
| | | right: 0; |
| | | text-align: center; |
| | | justify-content: center; |
| | | flex-flow: column; |
| | | align-items: center; |
| | | } |
| | | |
| | | .iziToast-rtl { |
| | | direction: rtl; |
| | | padding: 8px 0 9px 45px; |
| | | font-family: Tahoma, 'Lato', Arial; |
| | | } |
| | | |
| | | .iziToast-rtl .iziToast-cover { |
| | | left: auto; |
| | | right: 0; |
| | | } |
| | | |
| | | .iziToast-rtl .iziToast-close { |
| | | right: auto; |
| | | left: 0; |
| | | } |
| | | |
| | | .iziToast-rtl .iziToast-body { |
| | | padding: 0 10px 0 0; |
| | | margin: 0 16px 0 0; |
| | | text-align: right; |
| | | } |
| | | |
| | | .iziToast-rtl .iziToast-body .iziToast-buttons, |
| | | .iziToast-rtl .iziToast-body .iziToast-inputs, |
| | | .iziToast-rtl .iziToast-body .iziToast-texts, |
| | | .iziToast-rtl .iziToast-body .iziToast-title, |
| | | .iziToast-rtl .iziToast-body .iziToast-message { |
| | | float: right; |
| | | text-align: right; |
| | | } |
| | | |
| | | .iziToast-rtl .iziToast-body .iziToast-icon { |
| | | left: auto; |
| | | right: 0; |
| | | } |
| | | |
| | | @media only screen and (min-width: 568px) { |
| | | .iziToast-wrapper { |
| | | padding: 10px 15px; |
| | | } |
| | | |
| | | .iziToast { |
| | | width: auto; |
| | | } |
| | | |
| | | .iziToast:not(.iziToast-rtl) .iziToast-cover { |
| | | border-radius: 3px 0 0 3px; |
| | | } |
| | | |
| | | .iziToast.iziToast-rtl .iziToast-cover { |
| | | border-radius: 0 3px 3px 0; |
| | | } |
| | | |
| | | .iziToast.iziToast-color-dark:after { |
| | | box-shadow: inset 0 -10px 20px -10px rgba(255, 255, 255, 0.3), 0 10px 10px -5px rgba(0, 0, 0, 0.25); |
| | | } |
| | | |
| | | .iziToast.iziToast-balloon .iziToast-progressbar { |
| | | background: transparent; |
| | | } |
| | | |
| | | .iziToast.iziToast-balloon:after { |
| | | box-shadow: 0 10px 10px -5px rgba(0, 0, 0, 0.25), inset 0 10px 20px -5px rgba(0, 0, 0, 0.25); |
| | | } |
| | | |
| | | .iziToast-target .iziToast:after { |
| | | box-shadow: inset 0 -10px 20px -10px rgba(0, 0, 0, 0.2), inset 0 0 5px rgba(0, 0, 0, 0.1); |
| | | } |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark { |
| | | background: #565c70; |
| | | border-color: #565c70; |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark .iziToast-title { |
| | | color: #fff; |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark .iziToast-message { |
| | | color: rgba(255, 255, 255, 0.9); |
| | | font-weight: 300; |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark .iziToast-close { |
| | | background: url("") no-repeat 50% 50%; |
| | | background-size: 8px; |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark .iziToast-icon { |
| | | color: #fff; |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark .iziToast-icon.ico-info { |
| | | background: url("") no-repeat 50% 50%; |
| | | background-size: 85%; |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark .iziToast-icon.ico-warning { |
| | | background: url("") no-repeat 50% 50%; |
| | | background-size: 85%; |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark .iziToast-icon.ico-error { |
| | | background: url("") no-repeat 50% 50%; |
| | | background-size: 80%; |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark .iziToast-icon.ico-success { |
| | | background: url("") no-repeat 50% 50%; |
| | | background-size: 85%; |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark .iziToast-icon.ico-question { |
| | | background: url("") no-repeat 50% 50%; |
| | | background-size: 85%; |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark .iziToast-buttons > a, |
| | | .iziToast.iziToast-theme-dark .iziToast-buttons > button, |
| | | .iziToast.iziToast-theme-dark .iziToast-buttons > input { |
| | | color: #fff; |
| | | background: rgba(255, 255, 255, 0.1); |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark .iziToast-buttons > a:hover, |
| | | .iziToast.iziToast-theme-dark .iziToast-buttons > button:hover, |
| | | .iziToast.iziToast-theme-dark .iziToast-buttons > input:hover { |
| | | background: rgba(255, 255, 255, 0.2); |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark .iziToast-buttons > a:focus, |
| | | .iziToast.iziToast-theme-dark .iziToast-buttons > button:focus, |
| | | .iziToast.iziToast-theme-dark .iziToast-buttons > input:focus { |
| | | box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.6); |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark.iziToast-color-red { |
| | | background: #F56C6C; |
| | | border-color: #F56C6C; |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark.iziToast-color-orange { |
| | | background: #E6A23C; |
| | | border-color: #E6A23C; |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark.iziToast-color-yellow { |
| | | background: rgba(255, 249, 178, 0.9); |
| | | border-color: rgba(255, 249, 178, 0.9); |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark.iziToast-color-blue { |
| | | background: #409EFF; |
| | | border-color: #409EFF; |
| | | } |
| | | |
| | | .iziToast.iziToast-theme-dark.iziToast-color-green { |
| | | background: #67C23A; |
| | | border-color: #67C23A; |
| | | } |
| | | |
| | | .iziToast.iziToast-layout2 .iziToast-body .iziToast-texts, |
| | | .iziToast.iziToast-layout2 .iziToast-body .iziToast-message { |
| | | width: 100%; |
| | | } |
| | | |
| | | .iziToast.iziToast-layout3 { |
| | | border-radius: 2px; |
| | | } |
| | | |
| | | .iziToast.iziToast-layout3::after { |
| | | display: none; |
| | | } |
| | | |
| | | .iziToast.revealIn, |
| | | .iziToast .revealIn { |
| | | -webkit-animation: iziT-revealIn 1s cubic-bezier(0.25, 1.6, 0.25, 1) both; |
| | | -moz-animation: iziT-revealIn 1s cubic-bezier(0.25, 1.6, 0.25, 1) both; |
| | | animation: iziT-revealIn 1s cubic-bezier(0.25, 1.6, 0.25, 1) both; |
| | | } |
| | | |
| | | .iziToast.slideIn, |
| | | .iziToast .slideIn { |
| | | -webkit-animation: iziT-slideIn 1s cubic-bezier(0.16, 0.81, 0.32, 1) both; |
| | | -moz-animation: iziT-slideIn 1s cubic-bezier(0.16, 0.81, 0.32, 1) both; |
| | | animation: iziT-slideIn 1s cubic-bezier(0.16, 0.81, 0.32, 1) both; |
| | | } |
| | | |
| | | .iziToast.bounceInLeft { |
| | | -webkit-animation: iziT-bounceInLeft 0.7s ease-in-out both; |
| | | animation: iziT-bounceInLeft 0.7s ease-in-out both; |
| | | } |
| | | |
| | | .iziToast.bounceInRight { |
| | | -webkit-animation: iziT-bounceInRight 0.85s ease-in-out both; |
| | | animation: iziT-bounceInRight 0.85s ease-in-out both; |
| | | } |
| | | |
| | | .iziToast.bounceInDown { |
| | | -webkit-animation: iziT-bounceInDown 0.7s ease-in-out both; |
| | | animation: iziT-bounceInDown 0.7s ease-in-out both; |
| | | } |
| | | |
| | | .iziToast.bounceInUp { |
| | | -webkit-animation: iziT-bounceInUp 0.7s ease-in-out both; |
| | | animation: iziT-bounceInUp 0.7s ease-in-out both; |
| | | } |
| | | |
| | | .iziToast.fadeIn, |
| | | .iziToast .fadeIn { |
| | | -webkit-animation: iziT-fadeIn 0.5s ease both; |
| | | animation: iziT-fadeIn 0.5s ease both; |
| | | } |
| | | |
| | | .iziToast.fadeInUp { |
| | | -webkit-animation: iziT-fadeInUp 0.7s ease both; |
| | | animation: iziT-fadeInUp 0.7s ease both; |
| | | } |
| | | |
| | | .iziToast.fadeInDown { |
| | | -webkit-animation: iziT-fadeInDown 0.7s ease both; |
| | | animation: iziT-fadeInDown 0.7s ease both; |
| | | } |
| | | |
| | | .iziToast.fadeInLeft { |
| | | -webkit-animation: iziT-fadeInLeft 0.85s cubic-bezier(0.25, 0.8, 0.25, 1) both; |
| | | animation: iziT-fadeInLeft 0.85s cubic-bezier(0.25, 0.8, 0.25, 1) both; |
| | | } |
| | | |
| | | .iziToast.fadeInRight { |
| | | -webkit-animation: iziT-fadeInRight 0.85s cubic-bezier(0.25, 0.8, 0.25, 1) both; |
| | | animation: iziT-fadeInRight 0.85s cubic-bezier(0.25, 0.8, 0.25, 1) both; |
| | | } |
| | | |
| | | .iziToast.flipInX { |
| | | -webkit-animation: iziT-flipInX 0.85s cubic-bezier(0.35, 0, 0.25, 1) both; |
| | | animation: iziT-flipInX 0.85s cubic-bezier(0.35, 0, 0.25, 1) both; |
| | | } |
| | | |
| | | .iziToast.fadeOut { |
| | | -webkit-animation: iziT-fadeOut 0.7s ease both; |
| | | animation: iziT-fadeOut 0.7s ease both; |
| | | } |
| | | |
| | | .iziToast.fadeOutDown { |
| | | -webkit-animation: iziT-fadeOutDown 0.7s cubic-bezier(0.4, 0.45, 0.15, 0.91) both; |
| | | animation: iziT-fadeOutDown 0.7s cubic-bezier(0.4, 0.45, 0.15, 0.91) both; |
| | | } |
| | | |
| | | .iziToast.fadeOutUp { |
| | | -webkit-animation: iziT-fadeOutUp 0.7s cubic-bezier(0.4, 0.45, 0.15, 0.91) both; |
| | | animation: iziT-fadeOutUp 0.7s cubic-bezier(0.4, 0.45, 0.15, 0.91) both; |
| | | } |
| | | |
| | | .iziToast.fadeOutLeft { |
| | | -webkit-animation: iziT-fadeOutLeft 0.5s ease both; |
| | | animation: iziT-fadeOutLeft 0.5s ease both; |
| | | } |
| | | |
| | | .iziToast.fadeOutRight { |
| | | -webkit-animation: iziT-fadeOutRight 0.5s ease both; |
| | | animation: iziT-fadeOutRight 0.5s ease both; |
| | | } |
| | | |
| | | .iziToast.flipOutX { |
| | | -webkit-backface-visibility: visible !important; |
| | | backface-visibility: visible !important; |
| | | -webkit-animation: iziT-flipOutX 0.7s cubic-bezier(0.4, 0.45, 0.15, 0.91) both; |
| | | animation: iziT-flipOutX 0.7s cubic-bezier(0.4, 0.45, 0.15, 0.91) both; |
| | | } |
| | | |
| | | .iziToast-overlay.fadeIn { |
| | | -webkit-animation: iziT-fadeIn 0.5s ease both; |
| | | animation: iziT-fadeIn 0.5s ease both; |
| | | } |
| | | |
| | | .iziToast-overlay.fadeOut { |
| | | -webkit-animation: iziT-fadeOut 0.7s ease both; |
| | | animation: iziT-fadeOut 0.7s ease both; |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-revealIn { |
| | | 0% { |
| | | opacity: 0; |
| | | -webkit-transform: scale3d(0.3, 0.3, 1); |
| | | } |
| | | 100% { |
| | | opacity: 1; |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-revealIn { |
| | | 0% { |
| | | opacity: 0; |
| | | -moz-transform: scale3d(0.3, 0.3, 1); |
| | | } |
| | | 100% { |
| | | opacity: 1; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-slideIn { |
| | | 0% { |
| | | opacity: 0; |
| | | -webkit-transform: translateX(50px); |
| | | } |
| | | 100% { |
| | | opacity: 1; |
| | | -webkit-transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-slideIn { |
| | | 0% { |
| | | opacity: 0; |
| | | -moz-transform: translateX(50px); |
| | | } |
| | | 100% { |
| | | opacity: 1; |
| | | -moz-transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-bounceInLeft { |
| | | 0% { |
| | | opacity: 0; |
| | | -webkit-transform: translateX(280px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | -webkit-transform: translateX(-20px); |
| | | } |
| | | 70% { |
| | | -webkit-transform: translateX(10px); |
| | | } |
| | | 100% { |
| | | -webkit-transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-bounceInRight { |
| | | 0% { |
| | | opacity: 0; |
| | | -webkit-transform: translateX(-280px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | -webkit-transform: translateX(20px); |
| | | } |
| | | 70% { |
| | | -webkit-transform: translateX(-10px); |
| | | } |
| | | 100% { |
| | | -webkit-transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-bounceInDown { |
| | | 0% { |
| | | opacity: 0; |
| | | -webkit-transform: translateY(-200px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | -webkit-transform: translateY(10px); |
| | | } |
| | | 70% { |
| | | -webkit-transform: translateY(-5px); |
| | | } |
| | | 100% { |
| | | -webkit-transform: translateY(0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-bounceInUp { |
| | | 0% { |
| | | opacity: 0; |
| | | -webkit-transform: translateY(200px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | -webkit-transform: translateY(-10px); |
| | | } |
| | | 70% { |
| | | -webkit-transform: translateY(5px); |
| | | } |
| | | 100% { |
| | | -webkit-transform: translateY(0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeIn { |
| | | from { |
| | | opacity: 0; |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeInUp { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, 100%, 0); |
| | | transform: translate3d(0, 100%, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeInDown { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, -100%, 0); |
| | | transform: translate3d(0, -100%, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeInLeft { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(300px, 0, 0); |
| | | transform: translate3d(300px, 0, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeInRight { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(-300px, 0, 0); |
| | | transform: translate3d(-300px, 0, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-flipInX { |
| | | from { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | opacity: 0; |
| | | } |
| | | 40% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | } |
| | | 60% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 10deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 10deg); |
| | | opacity: 1; |
| | | } |
| | | 80% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -5deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -5deg); |
| | | } |
| | | to { |
| | | -webkit-transform: perspective(400px); |
| | | transform: perspective(400px); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeOut { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeOutDown { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, 100%, 0); |
| | | transform: translate3d(0, 100%, 0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeOutUp { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, -100%, 0); |
| | | transform: translate3d(0, -100%, 0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeOutLeft { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(-200px, 0, 0); |
| | | transform: translate3d(-200px, 0, 0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeOutRight { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(200px, 0, 0); |
| | | transform: translate3d(200px, 0, 0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-flipOutX { |
| | | from { |
| | | -webkit-transform: perspective(400px); |
| | | transform: perspective(400px); |
| | | } |
| | | 30% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | opacity: 0; |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-revealIn { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: scale3d(0.3, 0.3, 1); |
| | | } |
| | | 100% { |
| | | opacity: 1; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-revealIn { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: scale3d(0.3, 0.3, 1); |
| | | } |
| | | 100% { |
| | | opacity: 1; |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-revealIn { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: scale3d(0.3, 0.3, 1); |
| | | } |
| | | 100% { |
| | | opacity: 1; |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-revealIn { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: scale3d(0.3, 0.3, 1); |
| | | } |
| | | 100% { |
| | | opacity: 1; |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-slideIn { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateX(50px); |
| | | } |
| | | 100% { |
| | | opacity: 1; |
| | | transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-slideIn { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateX(50px); |
| | | } |
| | | 100% { |
| | | opacity: 1; |
| | | transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-slideIn { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateX(50px); |
| | | } |
| | | 100% { |
| | | opacity: 1; |
| | | transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-slideIn { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateX(50px); |
| | | } |
| | | 100% { |
| | | opacity: 1; |
| | | transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-bounceInLeft { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateX(280px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateX(-20px); |
| | | } |
| | | 70% { |
| | | transform: translateX(10px); |
| | | } |
| | | 100% { |
| | | transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-bounceInLeft { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateX(280px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateX(-20px); |
| | | } |
| | | 70% { |
| | | transform: translateX(10px); |
| | | } |
| | | 100% { |
| | | transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-bounceInLeft { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateX(280px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateX(-20px); |
| | | } |
| | | 70% { |
| | | transform: translateX(10px); |
| | | } |
| | | 100% { |
| | | transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-bounceInLeft { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateX(280px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateX(-20px); |
| | | } |
| | | 70% { |
| | | transform: translateX(10px); |
| | | } |
| | | 100% { |
| | | transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-bounceInRight { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateX(-280px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateX(20px); |
| | | } |
| | | 70% { |
| | | transform: translateX(-10px); |
| | | } |
| | | 100% { |
| | | transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-bounceInRight { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateX(-280px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateX(20px); |
| | | } |
| | | 70% { |
| | | transform: translateX(-10px); |
| | | } |
| | | 100% { |
| | | transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-bounceInRight { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateX(-280px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateX(20px); |
| | | } |
| | | 70% { |
| | | transform: translateX(-10px); |
| | | } |
| | | 100% { |
| | | transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-bounceInRight { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateX(-280px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateX(20px); |
| | | } |
| | | 70% { |
| | | transform: translateX(-10px); |
| | | } |
| | | 100% { |
| | | transform: translateX(0); |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-bounceInDown { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateY(-200px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateY(10px); |
| | | } |
| | | 70% { |
| | | transform: translateY(-5px); |
| | | } |
| | | 100% { |
| | | transform: translateY(0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-bounceInDown { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateY(-200px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateY(10px); |
| | | } |
| | | 70% { |
| | | transform: translateY(-5px); |
| | | } |
| | | 100% { |
| | | transform: translateY(0); |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-bounceInDown { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateY(-200px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateY(10px); |
| | | } |
| | | 70% { |
| | | transform: translateY(-5px); |
| | | } |
| | | 100% { |
| | | transform: translateY(0); |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-bounceInDown { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateY(-200px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateY(10px); |
| | | } |
| | | 70% { |
| | | transform: translateY(-5px); |
| | | } |
| | | 100% { |
| | | transform: translateY(0); |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-bounceInUp { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateY(200px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateY(-10px); |
| | | } |
| | | 70% { |
| | | transform: translateY(5px); |
| | | } |
| | | 100% { |
| | | transform: translateY(0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-bounceInUp { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateY(200px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateY(-10px); |
| | | } |
| | | 70% { |
| | | transform: translateY(5px); |
| | | } |
| | | 100% { |
| | | transform: translateY(0); |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-bounceInUp { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateY(200px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateY(-10px); |
| | | } |
| | | 70% { |
| | | transform: translateY(5px); |
| | | } |
| | | 100% { |
| | | transform: translateY(0); |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-bounceInUp { |
| | | 0% { |
| | | opacity: 0; |
| | | transform: translateY(200px); |
| | | } |
| | | 50% { |
| | | opacity: 1; |
| | | transform: translateY(-10px); |
| | | } |
| | | 70% { |
| | | transform: translateY(5px); |
| | | } |
| | | 100% { |
| | | transform: translateY(0); |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-fadeIn { |
| | | from { |
| | | opacity: 0; |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeIn { |
| | | from { |
| | | opacity: 0; |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-fadeIn { |
| | | from { |
| | | opacity: 0; |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-fadeIn { |
| | | from { |
| | | opacity: 0; |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-fadeInUp { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, 100%, 0); |
| | | transform: translate3d(0, 100%, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeInUp { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, 100%, 0); |
| | | transform: translate3d(0, 100%, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-fadeInUp { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, 100%, 0); |
| | | transform: translate3d(0, 100%, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-fadeInUp { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, 100%, 0); |
| | | transform: translate3d(0, 100%, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-fadeInDown { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, -100%, 0); |
| | | transform: translate3d(0, -100%, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeInDown { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, -100%, 0); |
| | | transform: translate3d(0, -100%, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-fadeInDown { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, -100%, 0); |
| | | transform: translate3d(0, -100%, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-fadeInDown { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, -100%, 0); |
| | | transform: translate3d(0, -100%, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-fadeInLeft { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(300px, 0, 0); |
| | | transform: translate3d(300px, 0, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeInLeft { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(300px, 0, 0); |
| | | transform: translate3d(300px, 0, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-fadeInLeft { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(300px, 0, 0); |
| | | transform: translate3d(300px, 0, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-fadeInLeft { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(300px, 0, 0); |
| | | transform: translate3d(300px, 0, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-fadeInRight { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(-300px, 0, 0); |
| | | transform: translate3d(-300px, 0, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeInRight { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(-300px, 0, 0); |
| | | transform: translate3d(-300px, 0, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-fadeInRight { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(-300px, 0, 0); |
| | | transform: translate3d(-300px, 0, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-fadeInRight { |
| | | from { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(-300px, 0, 0); |
| | | transform: translate3d(-300px, 0, 0); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | -webkit-transform: none; |
| | | transform: none; |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-flipInX { |
| | | from { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | opacity: 0; |
| | | } |
| | | 40% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | } |
| | | 60% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 10deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 10deg); |
| | | opacity: 1; |
| | | } |
| | | 80% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -5deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -5deg); |
| | | } |
| | | to { |
| | | -webkit-transform: perspective(400px); |
| | | transform: perspective(400px); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-flipInX { |
| | | from { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | opacity: 0; |
| | | } |
| | | 40% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | } |
| | | 60% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 10deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 10deg); |
| | | opacity: 1; |
| | | } |
| | | 80% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -5deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -5deg); |
| | | } |
| | | to { |
| | | -webkit-transform: perspective(400px); |
| | | transform: perspective(400px); |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-flipInX { |
| | | from { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | opacity: 0; |
| | | } |
| | | 40% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | } |
| | | 60% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 10deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 10deg); |
| | | opacity: 1; |
| | | } |
| | | 80% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -5deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -5deg); |
| | | } |
| | | to { |
| | | -webkit-transform: perspective(400px); |
| | | transform: perspective(400px); |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-flipInX { |
| | | from { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | opacity: 0; |
| | | } |
| | | 40% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | } |
| | | 60% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 10deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 10deg); |
| | | opacity: 1; |
| | | } |
| | | 80% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -5deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -5deg); |
| | | } |
| | | to { |
| | | -webkit-transform: perspective(400px); |
| | | transform: perspective(400px); |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-fadeOut { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeOut { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-fadeOut { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-fadeOut { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-fadeOutDown { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, 100%, 0); |
| | | transform: translate3d(0, 100%, 0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeOutDown { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, 100%, 0); |
| | | transform: translate3d(0, 100%, 0); |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-fadeOutDown { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, 100%, 0); |
| | | transform: translate3d(0, 100%, 0); |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-fadeOutDown { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, 100%, 0); |
| | | transform: translate3d(0, 100%, 0); |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-fadeOutUp { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, -100%, 0); |
| | | transform: translate3d(0, -100%, 0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeOutUp { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, -100%, 0); |
| | | transform: translate3d(0, -100%, 0); |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-fadeOutUp { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, -100%, 0); |
| | | transform: translate3d(0, -100%, 0); |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-fadeOutUp { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(0, -100%, 0); |
| | | transform: translate3d(0, -100%, 0); |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-fadeOutLeft { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(-200px, 0, 0); |
| | | transform: translate3d(-200px, 0, 0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeOutLeft { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(-200px, 0, 0); |
| | | transform: translate3d(-200px, 0, 0); |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-fadeOutLeft { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(-200px, 0, 0); |
| | | transform: translate3d(-200px, 0, 0); |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-fadeOutLeft { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(-200px, 0, 0); |
| | | transform: translate3d(-200px, 0, 0); |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-fadeOutRight { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(200px, 0, 0); |
| | | transform: translate3d(200px, 0, 0); |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-fadeOutRight { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(200px, 0, 0); |
| | | transform: translate3d(200px, 0, 0); |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-fadeOutRight { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(200px, 0, 0); |
| | | transform: translate3d(200px, 0, 0); |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-fadeOutRight { |
| | | from { |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | opacity: 0; |
| | | -webkit-transform: translate3d(200px, 0, 0); |
| | | transform: translate3d(200px, 0, 0); |
| | | } |
| | | } |
| | | |
| | | @-moz-keyframes iziT-flipOutX { |
| | | from { |
| | | -webkit-transform: perspective(400px); |
| | | transform: perspective(400px); |
| | | } |
| | | 30% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | opacity: 0; |
| | | } |
| | | } |
| | | |
| | | @-webkit-keyframes iziT-flipOutX { |
| | | from { |
| | | -webkit-transform: perspective(400px); |
| | | transform: perspective(400px); |
| | | } |
| | | 30% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | opacity: 0; |
| | | } |
| | | } |
| | | |
| | | @-o-keyframes iziT-flipOutX { |
| | | from { |
| | | -webkit-transform: perspective(400px); |
| | | transform: perspective(400px); |
| | | } |
| | | 30% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | opacity: 0; |
| | | } |
| | | } |
| | | |
| | | @keyframes iziT-flipOutX { |
| | | from { |
| | | -webkit-transform: perspective(400px); |
| | | transform: perspective(400px); |
| | | } |
| | | 30% { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, -20deg); |
| | | opacity: 1; |
| | | } |
| | | to { |
| | | -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | transform: perspective(400px) rotate3d(1, 0, 0, 90deg); |
| | | opacity: 0; |
| | | } |
| | | } |
New file |
| | |
| | | layui.define([], function (exports) { |
| | | var PLUGIN_NAME = 'iziToast'; // 样式类名 |
| | | var BODY = document.querySelector('body'); |
| | | var ISMOBILE = (/Mobi/.test(navigator.userAgent)) ? true : false; |
| | | var MOBILEWIDTH = 568; |
| | | var ISCHROME = /Chrome/.test(navigator.userAgent) && /Google Inc/.test(navigator.vendor); |
| | | var ISFIREFOX = typeof InstallTrigger !== 'undefined'; |
| | | var ACCEPTSTOUCH = 'ontouchstart' in document.documentElement; |
| | | // 显示区域 |
| | | var POSITIONS = ['bottomRight', 'bottomLeft', 'bottomCenter', 'topRight', 'topLeft', 'topCenter', 'center']; |
| | | // 默认主题 |
| | | var THEMES = { |
| | | info: { |
| | | color: 'blue', |
| | | icon: 'ico-info' |
| | | }, |
| | | success: { |
| | | color: 'green', |
| | | icon: 'ico-success' |
| | | }, |
| | | warning: { |
| | | color: 'orange', |
| | | icon: 'ico-warning' |
| | | }, |
| | | error: { |
| | | color: 'red', |
| | | icon: 'ico-error' |
| | | }, |
| | | question: { |
| | | color: 'yellow', |
| | | icon: 'ico-question' |
| | | } |
| | | }; |
| | | var CONFIG = {}; // 全局配置 |
| | | // 默认配置 |
| | | var defaults = { |
| | | id: null, |
| | | className: '', // 自定义class,用空格分割 |
| | | title: '', // 标题 |
| | | titleColor: '', // 标题文字颜色 |
| | | titleSize: '', // 标题文字大小 |
| | | titleLineHeight: '', // 标题高度 |
| | | message: '', // 内容 |
| | | messageColor: '', // 内容文字颜色 |
| | | messageSize: '', // 内容文字大小 |
| | | messageLineHeight: '', // 内容高度 |
| | | backgroundColor: '', // 背景颜色 |
| | | theme: 'light', // dark |
| | | color: '', // 背景颜色 |
| | | icon: '', // 图标 |
| | | iconText: '', // 图标文字 |
| | | iconColor: '', // 图标颜色 |
| | | iconUrl: null, // 图标地址 |
| | | image: '', // 是否显示图片 |
| | | imageWidth: 60, // 图片宽度 |
| | | maxWidth: null, // 最大宽度 |
| | | zindex: null, // |
| | | layout: 2, // 布局类型 |
| | | balloon: false, // 气泡 |
| | | close: true, // 是否显示关闭按钮 |
| | | closeOnEscape: false, |
| | | closeOnClick: false, // 点击关闭 |
| | | displayMode: 0, // 0无限制,1存在就不发出,2销毁之前 |
| | | position: 'topRight', // bottomRight, bottomLeft, topRight, topLeft, topCenter, bottomCenter, center |
| | | target: '', // 显示位置 |
| | | targetFirst: null, // 插入顺序 |
| | | timeout: 5000, // 关闭时间,false不自动关闭 |
| | | rtl: false, // 内容居右 |
| | | animateInside: false, // 进入动画效果 |
| | | drag: true, // 是否可滑动移除 |
| | | pauseOnHover: true, // 鼠标移入暂停进度条时间 |
| | | resetOnHover: false, // 鼠标移入重置进度条时间 |
| | | progressBar: true, // 是否显示进度条 |
| | | progressBarColor: '', // 进度条颜色 |
| | | progressBarEasing: 'linear', // 进度条动画效果 |
| | | overlay: false, // 是否显示遮罩层 |
| | | overlayClose: false, // 点击遮罩层是否关闭 |
| | | overlayColor: 'rgba(0, 0, 0, 0.1)', // 遮罩层颜色 |
| | | transitionIn: 'fadeInLeft', // bounceInLeft, bounceInRight, bounceInUp, bounceInDown, fadeIn, fadeInDown, fadeInUp, fadeInLeft, fadeInRight, flipInX |
| | | transitionOut: 'fadeOutRight', // fadeOut, fadeOutUp, fadeOutDown, fadeOutLeft, fadeOutRight, flipOutX |
| | | transitionInMobile: 'bounceInDown', // 移动端进入动画 |
| | | transitionOutMobile: 'fadeOutUp', // 移动端退出动画 |
| | | buttons: {}, // 操作按钮 |
| | | inputs: {}, // 输入框 |
| | | audio: '', // 音效 |
| | | onOpening: function () { |
| | | }, |
| | | onOpened: function () { |
| | | }, |
| | | onClosing: function () { |
| | | }, |
| | | onClosed: function () { |
| | | } |
| | | }; |
| | | |
| | | var $iziToast = { |
| | | children: {}, |
| | | setSetting: function (ref, option, value) { |
| | | $iziToast.children[ref][option] = value; |
| | | }, |
| | | getSetting: function (ref, option) { |
| | | return $iziToast.children[ref][option]; |
| | | }, |
| | | // 全局设置 |
| | | settings: function (options) { |
| | | $iziToast.destroy(); // 全部销毁之前的通知 |
| | | CONFIG = options; |
| | | defaults = extend(defaults, options || {}); |
| | | }, |
| | | // 关闭所有通知 |
| | | destroy: function () { |
| | | forEach(document.querySelectorAll('.' + PLUGIN_NAME + '-overlay'), function (element, index) { |
| | | element.remove(); |
| | | }); |
| | | forEach(document.querySelectorAll('.' + PLUGIN_NAME + '-wrapper'), function (element, index) { |
| | | element.remove(); |
| | | }); |
| | | forEach(document.querySelectorAll('.' + PLUGIN_NAME), function (element, index) { |
| | | element.remove(); |
| | | }); |
| | | this.children = {}; |
| | | // 移除事件监听 |
| | | document.removeEventListener(PLUGIN_NAME + '-opened', {}, false); |
| | | document.removeEventListener(PLUGIN_NAME + '-opening', {}, false); |
| | | document.removeEventListener(PLUGIN_NAME + '-closing', {}, false); |
| | | document.removeEventListener(PLUGIN_NAME + '-closed', {}, false); |
| | | document.removeEventListener('keyup', {}, false); |
| | | CONFIG = {}; // 移除全局配置 |
| | | }, |
| | | // msg类型 |
| | | msg: function (msg, options) { |
| | | if (options.icon == 4) { |
| | | options.overlay = true; |
| | | options.timeout = false; |
| | | options.drag = false; |
| | | options.displayMode = 0; |
| | | } |
| | | var icons = ['ico-success', 'ico-error', 'ico-warning', 'ico-load', 'ico-info']; |
| | | options.icon = icons[options.icon - 1]; |
| | | var theme = { |
| | | message: msg, |
| | | position: 'topCenter', |
| | | transitionIn: 'bounceInDown', |
| | | transitionOut: 'fadeOut', |
| | | transitionOutMobile: 'fadeOut', |
| | | progressBar: false, |
| | | close: false, |
| | | layout: 1, |
| | | audio: '' |
| | | }; |
| | | var settings = extend(CONFIG, options || {}); |
| | | settings = extend(theme, settings || {}); |
| | | this.show(settings); |
| | | } |
| | | }; |
| | | |
| | | // 关闭指定的通知 |
| | | $iziToast.hide = function (options, $toast, closedBy) { |
| | | if (typeof $toast != 'object') { |
| | | $toast = document.querySelector($toast); |
| | | } |
| | | var that = this; |
| | | var settings = extend(this.children[$toast.getAttribute('data-iziToast-ref')], options || {}); |
| | | settings.closedBy = closedBy || null; |
| | | delete settings.time.REMAINING; |
| | | $toast.classList.add(PLUGIN_NAME + '-closing'); |
| | | // 移除遮罩层 |
| | | (function () { |
| | | var $overlay = document.querySelector('.' + PLUGIN_NAME + '-overlay'); |
| | | if ($overlay !== null) { |
| | | var refs = $overlay.getAttribute('data-iziToast-ref'); |
| | | refs = refs.split(','); |
| | | var index = refs.indexOf(String(settings.ref)); |
| | | if (index !== -1) { |
| | | refs.splice(index, 1); |
| | | } |
| | | $overlay.setAttribute('data-iziToast-ref', refs.join()); |
| | | if (refs.length === 0) { |
| | | $overlay.classList.remove('fadeIn'); |
| | | $overlay.classList.add('fadeOut'); |
| | | setTimeout(function () { |
| | | $overlay.remove(); |
| | | }, 700); |
| | | } |
| | | } |
| | | })(); |
| | | // 移除动画 |
| | | if (settings.transitionIn) { |
| | | $toast.classList.remove(settings.transitionIn); |
| | | } |
| | | if (settings.transitionInMobile) { |
| | | $toast.classList.remove(settings.transitionInMobile); |
| | | } |
| | | if (ISMOBILE || window.innerWidth <= MOBILEWIDTH) { |
| | | if (settings.transitionOutMobile) |
| | | $toast.classList.add(settings.transitionOutMobile); |
| | | } else { |
| | | if (settings.transitionOut) |
| | | $toast.classList.add(settings.transitionOut); |
| | | } |
| | | var H = $toast.parentNode.offsetHeight; |
| | | $toast.parentNode.style.height = H + 'px'; |
| | | $toast.style.pointerEvents = 'none'; |
| | | if (!ISMOBILE || window.innerWidth > MOBILEWIDTH) { |
| | | $toast.parentNode.style.transitionDelay = '0.2s'; |
| | | } |
| | | try { |
| | | var event = new CustomEvent(PLUGIN_NAME + '-closing', {detail: settings, bubbles: true, cancelable: true}); |
| | | document.dispatchEvent(event); |
| | | } catch (ex) { |
| | | console.warn(ex); |
| | | } |
| | | setTimeout(function () { |
| | | $toast.parentNode.style.height = '0px'; |
| | | $toast.parentNode.style.overflow = ''; |
| | | setTimeout(function () { |
| | | delete that.children[settings.ref]; |
| | | $toast.parentNode.remove(); |
| | | try { |
| | | var event = new CustomEvent(PLUGIN_NAME + '-closed', { |
| | | detail: settings, |
| | | bubbles: true, |
| | | cancelable: true |
| | | }); |
| | | document.dispatchEvent(event); |
| | | } catch (ex) { |
| | | console.warn(ex); |
| | | } |
| | | if (typeof settings.onClosed !== 'undefined') { |
| | | settings.onClosed.apply(null, [settings, $toast, closedBy]); |
| | | } |
| | | }, 1000); |
| | | }, 200); |
| | | // 回调关闭事件 |
| | | if (typeof settings.onClosing !== 'undefined') { |
| | | settings.onClosing.apply(null, [settings, $toast, closedBy]); |
| | | } |
| | | }; |
| | | |
| | | // 显示通知 |
| | | $iziToast.show = function (options) { |
| | | var that = this; |
| | | // Merge user options with defaults |
| | | var settings = extend(CONFIG, options || {}); |
| | | settings = extend(defaults, settings); |
| | | settings.time = {}; |
| | | if (settings.id === null) { |
| | | settings.id = generateId(settings.title + settings.message + settings.color); |
| | | } |
| | | if (settings.displayMode == 1 || settings.displayMode == 'once') { |
| | | try { |
| | | if (document.querySelectorAll('.' + PLUGIN_NAME + '#' + settings.id).length > 0) { |
| | | return false; |
| | | } |
| | | } catch (exc) { |
| | | console.warn('[' + PLUGIN_NAME + '] Could not find an element with this selector: ' + '#' + settings.id + '. Try to set an valid id.'); |
| | | } |
| | | } |
| | | if (settings.displayMode == 2 || settings.displayMode == 'replace') { |
| | | try { |
| | | forEach(document.querySelectorAll('.' + PLUGIN_NAME + '#' + settings.id), function (element, index) { |
| | | that.hide(settings, element, 'replaced'); |
| | | }); |
| | | } catch (exc) { |
| | | console.warn('[' + PLUGIN_NAME + '] Could not find an element with this selector: ' + '#' + settings.id + '. Try to set an valid id.'); |
| | | } |
| | | } |
| | | settings.ref = new Date().getTime() + Math.floor((Math.random() * 10000000) + 1); |
| | | $iziToast.children[settings.ref] = settings; |
| | | var $DOM = { |
| | | body: document.querySelector('body'), |
| | | overlay: document.createElement('div'), |
| | | toast: document.createElement('div'), |
| | | toastBody: document.createElement('div'), |
| | | toastTexts: document.createElement('div'), |
| | | toastCapsule: document.createElement('div'), |
| | | cover: document.createElement('div'), |
| | | buttons: document.createElement('div'), |
| | | inputs: document.createElement('div'), |
| | | icon: !settings.iconUrl ? document.createElement('i') : document.createElement('img'), |
| | | wrapper: null |
| | | }; |
| | | $DOM.toast.setAttribute('data-iziToast-ref', settings.ref); |
| | | $DOM.toast.appendChild($DOM.toastBody); |
| | | $DOM.toastCapsule.appendChild($DOM.toast); |
| | | // CSS Settings |
| | | (function () { |
| | | $DOM.toast.classList.add(PLUGIN_NAME); |
| | | $DOM.toast.classList.add(PLUGIN_NAME + '-opening'); |
| | | $DOM.toastCapsule.classList.add(PLUGIN_NAME + '-capsule'); |
| | | $DOM.toastBody.classList.add(PLUGIN_NAME + '-body'); |
| | | $DOM.toastTexts.classList.add(PLUGIN_NAME + '-texts'); |
| | | if (ISMOBILE || window.innerWidth <= MOBILEWIDTH) { |
| | | if (settings.transitionInMobile) |
| | | $DOM.toast.classList.add(settings.transitionInMobile); |
| | | } else { |
| | | if (settings.transitionIn) |
| | | $DOM.toast.classList.add(settings.transitionIn); |
| | | } |
| | | if (settings.className) { |
| | | var classes = settings.className.split(' '); |
| | | forEach(classes, function (value, index) { |
| | | $DOM.toast.classList.add(value); |
| | | }); |
| | | } |
| | | if (settings.id) { |
| | | $DOM.toast.id = settings.id; |
| | | } |
| | | if (settings.rtl) { |
| | | $DOM.toast.classList.add(PLUGIN_NAME + '-rtl'); |
| | | $DOM.toast.setAttribute('dir', 'rtl'); |
| | | } |
| | | if (settings.layout > 1) { |
| | | $DOM.toast.classList.add(PLUGIN_NAME + '-layout' + settings.layout); |
| | | } |
| | | if (settings.balloon) { |
| | | $DOM.toast.classList.add(PLUGIN_NAME + '-balloon'); |
| | | } |
| | | if (settings.maxWidth) { |
| | | if (!isNaN(settings.maxWidth)) { |
| | | $DOM.toast.style.maxWidth = settings.maxWidth + 'px'; |
| | | } else { |
| | | $DOM.toast.style.maxWidth = settings.maxWidth; |
| | | } |
| | | } |
| | | if (settings.theme !== '' || settings.theme !== 'light') { |
| | | $DOM.toast.classList.add(PLUGIN_NAME + '-theme-' + settings.theme); |
| | | } |
| | | if (settings.color) { //#, rgb, rgba, hsl |
| | | if (isColor(settings.color)) { |
| | | $DOM.toast.style.background = settings.color; |
| | | } else { |
| | | $DOM.toast.classList.add(PLUGIN_NAME + '-color-' + settings.color); |
| | | } |
| | | } |
| | | if (settings.backgroundColor) { |
| | | $DOM.toast.style.background = settings.backgroundColor; |
| | | if (settings.balloon) { |
| | | $DOM.toast.style.borderColor = settings.backgroundColor; |
| | | } |
| | | } |
| | | })(); |
| | | // Cover image |
| | | (function () { |
| | | if (settings.image) { |
| | | $DOM.cover.classList.add(PLUGIN_NAME + '-cover'); |
| | | $DOM.cover.style.width = settings.imageWidth + 'px'; |
| | | if (isBase64(settings.image.replace(/ /g, ''))) { |
| | | $DOM.cover.style.backgroundImage = 'url(data:image/png;base64,' + settings.image.replace(/ /g, '') + ')'; |
| | | } else { |
| | | $DOM.cover.style.backgroundImage = 'url(' + settings.image + ')'; |
| | | } |
| | | if (settings.rtl) { |
| | | $DOM.toastBody.style.marginRight = (settings.imageWidth) + 'px'; |
| | | } else { |
| | | $DOM.toastBody.style.marginLeft = (settings.imageWidth) + 'px'; |
| | | } |
| | | $DOM.toast.appendChild($DOM.cover); |
| | | } |
| | | })(); |
| | | // Button close |
| | | (function () { |
| | | if (settings.close) { |
| | | $DOM.buttonClose = document.createElement('button'); |
| | | // $DOM.buttonClose.type = 'button'; |
| | | $DOM.buttonClose.setAttribute('type', 'button'); |
| | | $DOM.buttonClose.classList.add(PLUGIN_NAME + '-close'); |
| | | $DOM.buttonClose.addEventListener('click', function (e) { |
| | | var button = e.target; |
| | | that.hide(settings, $DOM.toast, 'button'); |
| | | }); |
| | | $DOM.toast.appendChild($DOM.buttonClose); |
| | | } else { |
| | | if (settings.rtl) { |
| | | $DOM.toast.style.paddingLeft = '18px'; |
| | | } else { |
| | | $DOM.toast.style.paddingRight = '18px'; |
| | | } |
| | | } |
| | | })(); |
| | | // Progress Bar & Timeout |
| | | (function () { |
| | | if (settings.progressBar) { |
| | | $DOM.progressBar = document.createElement('div'); |
| | | $DOM.progressBarDiv = document.createElement('div'); |
| | | $DOM.progressBar.classList.add(PLUGIN_NAME + '-progressbar'); |
| | | $DOM.progressBarDiv.style.background = settings.progressBarColor; |
| | | $DOM.progressBar.appendChild($DOM.progressBarDiv); |
| | | $DOM.toast.appendChild($DOM.progressBar); |
| | | } |
| | | if (settings.timeout) { |
| | | if (settings.pauseOnHover && !settings.resetOnHover) { |
| | | $DOM.toast.addEventListener('mouseenter', function (e) { |
| | | that.progress(settings, $DOM.toast).pause(); |
| | | }); |
| | | $DOM.toast.addEventListener('mouseleave', function (e) { |
| | | that.progress(settings, $DOM.toast).resume(); |
| | | }); |
| | | } |
| | | if (settings.resetOnHover) { |
| | | $DOM.toast.addEventListener('mouseenter', function (e) { |
| | | that.progress(settings, $DOM.toast).reset(); |
| | | }); |
| | | $DOM.toast.addEventListener('mouseleave', function (e) { |
| | | that.progress(settings, $DOM.toast).start(); |
| | | }); |
| | | } |
| | | } |
| | | })(); |
| | | // Icon |
| | | (function () { |
| | | if (settings.iconUrl) { |
| | | $DOM.icon.setAttribute('class', PLUGIN_NAME + '-icon'); |
| | | $DOM.icon.setAttribute('src', settings.iconUrl); |
| | | } else if (settings.icon) { |
| | | $DOM.icon.setAttribute('class', PLUGIN_NAME + '-icon ' + settings.icon); |
| | | if (settings.iconText) { |
| | | $DOM.icon.appendChild(document.createTextNode(settings.iconText)); |
| | | } |
| | | if (settings.iconColor) { |
| | | $DOM.icon.style.color = settings.iconColor; |
| | | } |
| | | } |
| | | if (settings.icon || settings.iconUrl) { |
| | | if (settings.rtl) { |
| | | $DOM.toastBody.style.paddingRight = '33px'; |
| | | } else { |
| | | $DOM.toastBody.style.paddingLeft = '33px'; |
| | | } |
| | | $DOM.toastBody.appendChild($DOM.icon); |
| | | } |
| | | |
| | | })(); |
| | | // Title & Message |
| | | (function () { |
| | | if (settings.title.length > 0) { |
| | | $DOM.strong = document.createElement('strong'); |
| | | $DOM.strong.classList.add(PLUGIN_NAME + '-title'); |
| | | $DOM.strong.appendChild(createFragElem(settings.title)); |
| | | $DOM.toastTexts.appendChild($DOM.strong); |
| | | if (settings.titleColor) { |
| | | $DOM.strong.style.color = settings.titleColor; |
| | | } |
| | | if (settings.titleSize) { |
| | | if (!isNaN(settings.titleSize)) { |
| | | $DOM.strong.style.fontSize = settings.titleSize + 'px'; |
| | | } else { |
| | | $DOM.strong.style.fontSize = settings.titleSize; |
| | | } |
| | | } |
| | | if (settings.titleLineHeight) { |
| | | if (!isNaN(settings.titleSize)) { |
| | | $DOM.strong.style.lineHeight = settings.titleLineHeight + 'px'; |
| | | } else { |
| | | $DOM.strong.style.lineHeight = settings.titleLineHeight; |
| | | } |
| | | } |
| | | } |
| | | if (settings.message.length > 0) { |
| | | $DOM.p = document.createElement('p'); |
| | | $DOM.p.classList.add(PLUGIN_NAME + '-message'); |
| | | $DOM.p.appendChild(createFragElem(settings.message)); |
| | | $DOM.toastTexts.appendChild($DOM.p); |
| | | if (settings.messageColor) { |
| | | $DOM.p.style.color = settings.messageColor; |
| | | } |
| | | if (settings.messageSize) { |
| | | if (!isNaN(settings.titleSize)) { |
| | | $DOM.p.style.fontSize = settings.messageSize + 'px'; |
| | | } else { |
| | | $DOM.p.style.fontSize = settings.messageSize; |
| | | } |
| | | } |
| | | if (settings.messageLineHeight) { |
| | | if (!isNaN(settings.titleSize)) { |
| | | $DOM.p.style.lineHeight = settings.messageLineHeight + 'px'; |
| | | } else { |
| | | $DOM.p.style.lineHeight = settings.messageLineHeight; |
| | | } |
| | | } |
| | | } |
| | | if (settings.title.length > 0 && settings.message.length > 0) { |
| | | if (settings.rtl) { |
| | | $DOM.strong.style.marginLeft = '10px'; |
| | | } else if (settings.layout != 2 && !settings.rtl) { |
| | | $DOM.strong.style.marginRight = '10px'; |
| | | $DOM.strong.style.marginBottom = '0px'; |
| | | } |
| | | } |
| | | })(); |
| | | $DOM.toastBody.appendChild($DOM.toastTexts); |
| | | // Inputs |
| | | var $inputs; |
| | | (function () { |
| | | if (settings.inputs.length > 0) { |
| | | $DOM.inputs.classList.add(PLUGIN_NAME + '-inputs'); |
| | | forEach(settings.inputs, function (value, index) { |
| | | $DOM.inputs.appendChild(createFragElem(value[0])); |
| | | $inputs = $DOM.inputs.childNodes; |
| | | $inputs[index].classList.add(PLUGIN_NAME + '-inputs-child'); |
| | | if (value[3]) { |
| | | setTimeout(function () { |
| | | $inputs[index].focus(); |
| | | }, 300); |
| | | } |
| | | $inputs[index].addEventListener(value[1], function (e) { |
| | | var ts = value[2]; |
| | | return ts(that, $DOM.toast, this, e); |
| | | }); |
| | | }); |
| | | $DOM.toastBody.appendChild($DOM.inputs); |
| | | } |
| | | })(); |
| | | // Buttons |
| | | (function () { |
| | | if (settings.buttons.length > 0) { |
| | | $DOM.buttons.classList.add(PLUGIN_NAME + '-buttons'); |
| | | forEach(settings.buttons, function (value, index) { |
| | | $DOM.buttons.appendChild(createFragElem(value[0])); |
| | | var $btns = $DOM.buttons.childNodes; |
| | | $btns[index].classList.add(PLUGIN_NAME + '-buttons-child'); |
| | | if (value[2]) { |
| | | setTimeout(function () { |
| | | $btns[index].focus(); |
| | | }, 300); |
| | | } |
| | | $btns[index].addEventListener('click', function (e) { |
| | | e.preventDefault(); |
| | | var ts = value[1]; |
| | | return ts(that, $DOM.toast, this, e, $inputs); |
| | | }); |
| | | }); |
| | | } |
| | | $DOM.toastTexts.appendChild($DOM.buttons); |
| | | })(); |
| | | if (settings.message.length > 0 && (settings.inputs.length > 0 || settings.buttons.length > 0)) { |
| | | $DOM.p.style.marginBottom = '0'; |
| | | } |
| | | if (settings.inputs.length > 0 || settings.buttons.length > 0) { |
| | | if (settings.rtl) { |
| | | $DOM.toastTexts.style.marginLeft = '10px'; |
| | | } else { |
| | | $DOM.toastTexts.style.marginRight = '10px'; |
| | | } |
| | | if (settings.inputs.length > 0 && settings.buttons.length > 0) { |
| | | if (settings.rtl) { |
| | | $DOM.inputs.style.marginLeft = '8px'; |
| | | } else { |
| | | $DOM.inputs.style.marginRight = '8px'; |
| | | } |
| | | } |
| | | } |
| | | // Wrap |
| | | (function () { |
| | | $DOM.toastCapsule.style.visibility = 'hidden'; |
| | | setTimeout(function () { |
| | | var H = $DOM.toast.offsetHeight; |
| | | var style = $DOM.toast.currentStyle || window.getComputedStyle($DOM.toast); |
| | | var marginTop = style.marginTop; |
| | | marginTop = marginTop.split('px'); |
| | | marginTop = parseInt(marginTop[0]); |
| | | var marginBottom = style.marginBottom; |
| | | marginBottom = marginBottom.split('px'); |
| | | marginBottom = parseInt(marginBottom[0]); |
| | | |
| | | $DOM.toastCapsule.style.visibility = ''; |
| | | $DOM.toastCapsule.style.height = (H + marginBottom + marginTop) + 'px'; |
| | | |
| | | setTimeout(function () { |
| | | $DOM.toastCapsule.style.height = 'auto'; |
| | | if (settings.target) { |
| | | $DOM.toastCapsule.style.overflow = 'visible'; |
| | | } |
| | | }, 500); |
| | | |
| | | if (settings.timeout) { |
| | | that.progress(settings, $DOM.toast).start(); |
| | | } |
| | | }, 100); |
| | | })(); |
| | | // Target |
| | | (function () { |
| | | var position = settings.position; |
| | | if (settings.target) { |
| | | $DOM.wrapper = document.querySelector(settings.target); |
| | | $DOM.wrapper.classList.add(PLUGIN_NAME + '-target'); |
| | | if (settings.targetFirst) { |
| | | $DOM.wrapper.insertBefore($DOM.toastCapsule, $DOM.wrapper.firstChild); |
| | | } else { |
| | | $DOM.wrapper.appendChild($DOM.toastCapsule); |
| | | } |
| | | } else { |
| | | if (POSITIONS.indexOf(settings.position) == -1) { |
| | | console.warn('[' + PLUGIN_NAME + '] Incorrect position.\nIt can be › ' + POSITIONS); |
| | | return; |
| | | } |
| | | if (ISMOBILE || window.innerWidth <= MOBILEWIDTH) { |
| | | if (settings.position == 'bottomLeft' || settings.position == 'bottomRight' || settings.position == 'bottomCenter') { |
| | | position = PLUGIN_NAME + '-wrapper-bottomCenter'; |
| | | } else if (settings.position == 'topLeft' || settings.position == 'topRight' || settings.position == 'topCenter') { |
| | | position = PLUGIN_NAME + '-wrapper-topCenter'; |
| | | } else { |
| | | position = PLUGIN_NAME + '-wrapper-center'; |
| | | } |
| | | } else { |
| | | position = PLUGIN_NAME + '-wrapper-' + position; |
| | | } |
| | | $DOM.wrapper = document.querySelector('.' + PLUGIN_NAME + '-wrapper.' + position); |
| | | if (!$DOM.wrapper) { |
| | | $DOM.wrapper = document.createElement('div'); |
| | | $DOM.wrapper.classList.add(PLUGIN_NAME + '-wrapper'); |
| | | $DOM.wrapper.classList.add(position); |
| | | document.body.appendChild($DOM.wrapper); |
| | | } |
| | | var targetFirst = settings.targetFirst; |
| | | if ((targetFirst == undefined || targetFirst == null) && (settings.position == 'topLeft' || settings.position == 'topCenter' || settings.position == 'topRight')) { |
| | | targetFirst = true; |
| | | } |
| | | if (targetFirst) { |
| | | $DOM.wrapper.insertBefore($DOM.toastCapsule, $DOM.wrapper.firstChild); |
| | | } else { |
| | | $DOM.wrapper.appendChild($DOM.toastCapsule); |
| | | } |
| | | } |
| | | if (!isNaN(settings.zindex)) { |
| | | $DOM.wrapper.style.zIndex = settings.zindex; |
| | | } else { |
| | | console.warn('[' + PLUGIN_NAME + '] Invalid zIndex.'); |
| | | } |
| | | })(); |
| | | // Overlay |
| | | (function () { |
| | | if (settings.overlay) { |
| | | if (document.querySelector('.' + PLUGIN_NAME + '-overlay.fadeIn') !== null) { |
| | | $DOM.overlay = document.querySelector('.' + PLUGIN_NAME + '-overlay'); |
| | | $DOM.overlay.setAttribute('data-iziToast-ref', $DOM.overlay.getAttribute('data-iziToast-ref') + ',' + settings.ref); |
| | | if (!isNaN(settings.zindex) && settings.zindex !== null) { |
| | | $DOM.overlay.style.zIndex = settings.zindex - 1; |
| | | } |
| | | } else { |
| | | $DOM.overlay.classList.add(PLUGIN_NAME + '-overlay'); |
| | | $DOM.overlay.classList.add('fadeIn'); |
| | | $DOM.overlay.style.background = settings.overlayColor; |
| | | $DOM.overlay.setAttribute('data-iziToast-ref', settings.ref); |
| | | if (!isNaN(settings.zindex) && settings.zindex !== null) { |
| | | $DOM.overlay.style.zIndex = settings.zindex - 1; |
| | | } |
| | | document.querySelector('body').appendChild($DOM.overlay); |
| | | } |
| | | if (settings.overlayClose) { |
| | | $DOM.overlay.removeEventListener('click', {}); |
| | | $DOM.overlay.addEventListener('click', function (e) { |
| | | that.hide(settings, $DOM.toast, 'overlay'); |
| | | }); |
| | | } else { |
| | | $DOM.overlay.removeEventListener('click', {}); |
| | | } |
| | | } |
| | | })(); |
| | | // Inside animations |
| | | (function () { |
| | | if (settings.animateInside) { |
| | | $DOM.toast.classList.add(PLUGIN_NAME + '-animateInside'); |
| | | var animationTimes = [200, 100, 300]; |
| | | if (settings.transitionIn == 'bounceInLeft' || settings.transitionIn == 'bounceInRight') { |
| | | animationTimes = [400, 200, 400]; |
| | | } |
| | | if (settings.title.length > 0) { |
| | | setTimeout(function () { |
| | | $DOM.strong.classList.add('slideIn'); |
| | | }, animationTimes[0]); |
| | | } |
| | | if (settings.message.length > 0) { |
| | | setTimeout(function () { |
| | | $DOM.p.classList.add('slideIn'); |
| | | }, animationTimes[1]); |
| | | } |
| | | if (settings.icon || settings.iconUrl) { |
| | | setTimeout(function () { |
| | | $DOM.icon.classList.add('revealIn'); |
| | | }, animationTimes[2]); |
| | | } |
| | | var counter = 150; |
| | | if (settings.buttons.length > 0 && $DOM.buttons) { |
| | | setTimeout(function () { |
| | | forEach($DOM.buttons.childNodes, function (element, index) { |
| | | setTimeout(function () { |
| | | element.classList.add('revealIn'); |
| | | }, counter); |
| | | counter = counter + 150; |
| | | }); |
| | | }, settings.inputs.length > 0 ? 150 : 0); |
| | | } |
| | | if (settings.inputs.length > 0 && $DOM.inputs) { |
| | | counter = 150; |
| | | forEach($DOM.inputs.childNodes, function (element, index) { |
| | | setTimeout(function () { |
| | | element.classList.add('revealIn'); |
| | | }, counter); |
| | | counter = counter + 150; |
| | | }); |
| | | } |
| | | } |
| | | })(); |
| | | settings.onOpening.apply(null, [settings, $DOM.toast]); |
| | | try { |
| | | var event = new CustomEvent(PLUGIN_NAME + '-opening', {detail: settings, bubbles: true, cancelable: true}); |
| | | document.dispatchEvent(event); |
| | | } catch (ex) { |
| | | console.warn(ex); |
| | | } |
| | | setTimeout(function () { |
| | | $DOM.toast.classList.remove(PLUGIN_NAME + '-opening'); |
| | | $DOM.toast.classList.add(PLUGIN_NAME + '-opened'); |
| | | try { |
| | | var event = new CustomEvent(PLUGIN_NAME + '-opened', { |
| | | detail: settings, |
| | | bubbles: true, |
| | | cancelable: true |
| | | }); |
| | | document.dispatchEvent(event); |
| | | } catch (ex) { |
| | | console.warn(ex); |
| | | } |
| | | settings.onOpened.apply(null, [settings, $DOM.toast]); |
| | | }, 1000); |
| | | if (settings.drag) { |
| | | if (ACCEPTSTOUCH) { |
| | | $DOM.toast.addEventListener('touchstart', function (e) { |
| | | drag.startMoving(this, that, settings, e); |
| | | }, false); |
| | | $DOM.toast.addEventListener('touchend', function (e) { |
| | | drag.stopMoving(this, e); |
| | | }, false); |
| | | } else { |
| | | $DOM.toast.addEventListener('mousedown', function (e) { |
| | | e.preventDefault(); |
| | | drag.startMoving(this, that, settings, e); |
| | | }, false); |
| | | $DOM.toast.addEventListener('mouseup', function (e) { |
| | | e.preventDefault(); |
| | | drag.stopMoving(this, e); |
| | | }, false); |
| | | } |
| | | } |
| | | if (settings.closeOnEscape) { |
| | | document.addEventListener('keyup', function (evt) { |
| | | evt = evt || window.event; |
| | | if (evt.keyCode == 27) { |
| | | that.hide(settings, $DOM.toast, 'esc'); |
| | | } |
| | | }); |
| | | } |
| | | if (settings.closeOnClick) { |
| | | $DOM.toast.addEventListener('click', function (evt) { |
| | | that.hide(settings, $DOM.toast, 'toast'); |
| | | }); |
| | | } |
| | | // 播放声音 |
| | | if (settings.audio) { |
| | | that.playSound(settings.audio); |
| | | } |
| | | that.toast = $DOM.toast; |
| | | }; |
| | | |
| | | // 控制进度条 |
| | | $iziToast.progress = function (options, $toast, callback) { |
| | | var that = this, |
| | | ref = $toast.getAttribute('data-iziToast-ref'), |
| | | settings = extend(this.children[ref], options || {}), |
| | | $elem = $toast.querySelector('.' + PLUGIN_NAME + '-progressbar div'); |
| | | return { |
| | | start: function () { |
| | | if (typeof settings.time.REMAINING == 'undefined') { |
| | | $toast.classList.remove(PLUGIN_NAME + '-reseted'); |
| | | if ($elem !== null) { |
| | | $elem.style.transition = 'width ' + settings.timeout + 'ms ' + settings.progressBarEasing; |
| | | $elem.style.width = '0%'; |
| | | } |
| | | settings.time.START = new Date().getTime(); |
| | | settings.time.END = settings.time.START + settings.timeout; |
| | | settings.time.TIMER = setTimeout(function () { |
| | | clearTimeout(settings.time.TIMER); |
| | | if (!$toast.classList.contains(PLUGIN_NAME + '-closing')) { |
| | | that.hide(settings, $toast, 'timeout'); |
| | | if (typeof callback === 'function') { |
| | | callback.apply(that); |
| | | } |
| | | } |
| | | }, settings.timeout); |
| | | that.setSetting(ref, 'time', settings.time); |
| | | } |
| | | }, |
| | | pause: function () { |
| | | if (typeof settings.time.START !== 'undefined' && !$toast.classList.contains(PLUGIN_NAME + '-paused') && !$toast.classList.contains(PLUGIN_NAME + '-reseted')) { |
| | | $toast.classList.add(PLUGIN_NAME + '-paused'); |
| | | settings.time.REMAINING = settings.time.END - new Date().getTime(); |
| | | clearTimeout(settings.time.TIMER); |
| | | that.setSetting(ref, 'time', settings.time); |
| | | if ($elem !== null) { |
| | | var computedStyle = window.getComputedStyle($elem), |
| | | propertyWidth = computedStyle.getPropertyValue('width'); |
| | | $elem.style.transition = 'none'; |
| | | $elem.style.width = propertyWidth; |
| | | } |
| | | if (typeof callback === 'function') { |
| | | setTimeout(function () { |
| | | callback.apply(that); |
| | | }, 10); |
| | | } |
| | | } |
| | | }, |
| | | resume: function () { |
| | | if (typeof settings.time.REMAINING !== 'undefined') { |
| | | $toast.classList.remove(PLUGIN_NAME + '-paused'); |
| | | if ($elem !== null) { |
| | | $elem.style.transition = 'width ' + settings.time.REMAINING + 'ms ' + settings.progressBarEasing; |
| | | $elem.style.width = '0%'; |
| | | } |
| | | settings.time.END = new Date().getTime() + settings.time.REMAINING; |
| | | settings.time.TIMER = setTimeout(function () { |
| | | clearTimeout(settings.time.TIMER); |
| | | if (!$toast.classList.contains(PLUGIN_NAME + '-closing')) { |
| | | that.hide(settings, $toast, 'timeout'); |
| | | if (typeof callback === 'function') { |
| | | callback.apply(that); |
| | | } |
| | | } |
| | | }, settings.time.REMAINING); |
| | | that.setSetting(ref, 'time', settings.time); |
| | | } else { |
| | | this.start(); |
| | | } |
| | | }, |
| | | reset: function () { |
| | | clearTimeout(settings.time.TIMER); |
| | | delete settings.time.REMAINING; |
| | | that.setSetting(ref, 'time', settings.time); |
| | | $toast.classList.add(PLUGIN_NAME + '-reseted'); |
| | | $toast.classList.remove(PLUGIN_NAME + '-paused'); |
| | | if ($elem !== null) { |
| | | $elem.style.transition = 'none'; |
| | | $elem.style.width = '100%'; |
| | | } |
| | | if (typeof callback === 'function') { |
| | | setTimeout(function () { |
| | | callback.apply(that); |
| | | }, 10); |
| | | } |
| | | } |
| | | }; |
| | | }; |
| | | |
| | | // 判断是否是ie9以下版本 |
| | | var isIE9_ = function () { |
| | | var userAgent = navigator.userAgent; |
| | | if (window.navigator.userAgent.indexOf("MSIE") >= 1) { |
| | | var reIE = new RegExp("MSIE (\\d+\\.\\d+);"); |
| | | reIE.test(userAgent); |
| | | var fIEVersion = parseFloat(RegExp["$1"]); |
| | | if (fIEVersion != 10) { |
| | | return true; |
| | | } |
| | | } |
| | | return false; |
| | | }; |
| | | |
| | | // 给Element添加remove方法 |
| | | if (!('remove' in Element.prototype)) { |
| | | Element.prototype.remove = function () { |
| | | if (this.parentNode) { |
| | | this.parentNode.removeChild(this); |
| | | } |
| | | }; |
| | | } |
| | | |
| | | // 自定义事件 |
| | | if (typeof window.CustomEvent !== 'function') { |
| | | var CustomEventPolyfill = function (event, params) { |
| | | params = params || {bubbles: false, cancelable: false, detail: undefined}; |
| | | var evt = document.createEvent('CustomEvent'); |
| | | evt.initCustomEvent(event, params.bubbles, params.cancelable, params.detail); |
| | | return evt; |
| | | }; |
| | | CustomEventPolyfill.prototype = window.Event.prototype; |
| | | window.CustomEvent = CustomEventPolyfill; |
| | | } |
| | | |
| | | // 遍历数据 |
| | | var forEach = function (collection, callback, scope) { |
| | | if (Object.prototype.toString.call(collection) === '[object Object]') { |
| | | for (var prop in collection) { |
| | | if (Object.prototype.hasOwnProperty.call(collection, prop)) { |
| | | callback.call(scope, collection[prop], prop, collection); |
| | | } |
| | | } |
| | | } else { |
| | | if (collection) { |
| | | for (var i = 0, len = collection.length; i < len; i++) { |
| | | callback.call(scope, collection[i], i, collection); |
| | | } |
| | | } |
| | | } |
| | | }; |
| | | |
| | | // 合并自定义参数和默认参数 |
| | | var extend = function (defaults, options) { |
| | | var extended = {}; |
| | | forEach(defaults, function (value, prop) { |
| | | extended[prop] = defaults[prop]; |
| | | }); |
| | | forEach(options, function (value, prop) { |
| | | extended[prop] = options[prop]; |
| | | }); |
| | | return extended; |
| | | }; |
| | | |
| | | // 创建新的文档片段 |
| | | var createFragElem = function (htmlStr) { |
| | | var frag = document.createDocumentFragment(), |
| | | temp = document.createElement('div'); |
| | | temp.innerHTML = htmlStr; |
| | | while (temp.firstChild) { |
| | | frag.appendChild(temp.firstChild); |
| | | } |
| | | return frag; |
| | | }; |
| | | |
| | | // 生成ID |
| | | var generateId = function (params) { |
| | | var newId = btoa(encodeURIComponent(params)); |
| | | return newId.replace(/=/g, ""); |
| | | }; |
| | | |
| | | // 判断是否是颜色字符串 |
| | | var isColor = function (color) { |
| | | if (color.substring(0, 1) == '#' || color.substring(0, 3) == 'rgb' || color.substring(0, 3) == 'hsl') { |
| | | return true; |
| | | } else { |
| | | return false; |
| | | } |
| | | }; |
| | | |
| | | // 判断是否是base64字符串 |
| | | var isBase64 = function (str) { |
| | | try { |
| | | return btoa(atob(str)) == str; |
| | | } catch (err) { |
| | | return false; |
| | | } |
| | | }; |
| | | |
| | | // 拖拽方法 |
| | | var drag = function () { |
| | | return { |
| | | move: function (toast, instance, settings, xpos) { |
| | | var opacity, |
| | | opacityRange = 0.3, |
| | | distance = 180; |
| | | if (xpos !== 0) { |
| | | toast.classList.add(PLUGIN_NAME + '-dragged'); |
| | | toast.style.transform = 'translateX(' + xpos + 'px)'; |
| | | if (xpos > 0) { |
| | | opacity = (distance - xpos) / distance; |
| | | if (opacity < opacityRange) { |
| | | instance.hide(extend(settings, { |
| | | transitionOut: 'fadeOutRight', |
| | | transitionOutMobile: 'fadeOutRight' |
| | | }), toast, 'drag'); |
| | | } |
| | | } else { |
| | | opacity = (distance + xpos) / distance; |
| | | if (opacity < opacityRange) { |
| | | instance.hide(extend(settings, { |
| | | transitionOut: 'fadeOutLeft', |
| | | transitionOutMobile: 'fadeOutLeft' |
| | | }), toast, 'drag'); |
| | | } |
| | | } |
| | | toast.style.opacity = opacity; |
| | | if (opacity < opacityRange) { |
| | | if (ISCHROME || ISFIREFOX) |
| | | toast.style.left = xpos + 'px'; |
| | | toast.parentNode.style.opacity = opacityRange; |
| | | this.stopMoving(toast, null); |
| | | } |
| | | } |
| | | }, |
| | | startMoving: function (toast, instance, settings, e) { |
| | | e = e || window.event; |
| | | var posX = ((ACCEPTSTOUCH) ? e.touches[0].clientX : e.clientX), |
| | | toastLeft = toast.style.transform.replace('px)', ''); |
| | | toastLeft = toastLeft.replace('translateX(', ''); |
| | | var offsetX = posX - toastLeft; |
| | | if (settings.transitionIn) { |
| | | toast.classList.remove(settings.transitionIn); |
| | | } |
| | | if (settings.transitionInMobile) { |
| | | toast.classList.remove(settings.transitionInMobile); |
| | | } |
| | | toast.style.transition = ''; |
| | | if (ACCEPTSTOUCH) { |
| | | document.ontouchmove = function (e) { |
| | | e.preventDefault(); |
| | | e = e || window.event; |
| | | var posX = e.touches[0].clientX, |
| | | finalX = posX - offsetX; |
| | | drag.move(toast, instance, settings, finalX); |
| | | }; |
| | | } else { |
| | | document.onmousemove = function (e) { |
| | | e.preventDefault(); |
| | | e = e || window.event; |
| | | var posX = e.clientX, |
| | | finalX = posX - offsetX; |
| | | drag.move(toast, instance, settings, finalX); |
| | | }; |
| | | } |
| | | }, |
| | | stopMoving: function (toast, e) { |
| | | if (ACCEPTSTOUCH) { |
| | | document.ontouchmove = function () { |
| | | }; |
| | | } else { |
| | | document.onmousemove = function () { |
| | | }; |
| | | } |
| | | toast.style.opacity = ''; |
| | | toast.style.transform = ''; |
| | | if (toast.classList.contains(PLUGIN_NAME + '-dragged')) { |
| | | toast.classList.remove(PLUGIN_NAME + '-dragged'); |
| | | toast.style.transition = 'transform 0.4s ease, opacity 0.4s ease'; |
| | | setTimeout(function () { |
| | | toast.style.transition = ''; |
| | | }, 400); |
| | | } |
| | | } |
| | | }; |
| | | }(); |
| | | |
| | | // 兼容IE |
| | | var Base64 = { |
| | | _keyStr: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=", encode: function (e) { |
| | | var t = ""; |
| | | var n, r, i, s, o, u, a; |
| | | var f = 0; |
| | | e = Base64._utf8_encode(e); |
| | | while (f < e.length) { |
| | | n = e.charCodeAt(f++); |
| | | r = e.charCodeAt(f++); |
| | | i = e.charCodeAt(f++); |
| | | s = n >> 2; |
| | | o = (n & 3) << 4 | r >> 4; |
| | | u = (r & 15) << 2 | i >> 6; |
| | | a = i & 63; |
| | | if (isNaN(r)) { |
| | | u = a = 64 |
| | | } else if (isNaN(i)) { |
| | | a = 64 |
| | | } |
| | | t = t + this._keyStr.charAt(s) + this._keyStr.charAt(o) + this._keyStr.charAt(u) + this._keyStr.charAt(a) |
| | | } |
| | | return t |
| | | }, decode: function (e) { |
| | | var t = ""; |
| | | var n, r, i; |
| | | var s, o, u, a; |
| | | var f = 0; |
| | | e = e.replace(/[^A-Za-z0-9+/=]/g, ""); |
| | | while (f < e.length) { |
| | | s = this._keyStr.indexOf(e.charAt(f++)); |
| | | o = this._keyStr.indexOf(e.charAt(f++)); |
| | | u = this._keyStr.indexOf(e.charAt(f++)); |
| | | a = this._keyStr.indexOf(e.charAt(f++)); |
| | | n = s << 2 | o >> 4; |
| | | r = (o & 15) << 4 | u >> 2; |
| | | i = (u & 3) << 6 | a; |
| | | t = t + String.fromCharCode(n); |
| | | if (u != 64) { |
| | | t = t + String.fromCharCode(r) |
| | | } |
| | | if (a != 64) { |
| | | t = t + String.fromCharCode(i) |
| | | } |
| | | } |
| | | t = Base64._utf8_decode(t); |
| | | return t |
| | | }, _utf8_encode: function (e) { |
| | | e = e.replace(/rn/g, "n"); |
| | | var t = ""; |
| | | for (var n = 0; n < e.length; n++) { |
| | | var r = e.charCodeAt(n); |
| | | if (r < 128) { |
| | | t += String.fromCharCode(r) |
| | | } else if (r > 127 && r < 2048) { |
| | | t += String.fromCharCode(r >> 6 | 192); |
| | | t += String.fromCharCode(r & 63 | 128) |
| | | } else { |
| | | t += String.fromCharCode(r >> 12 | 224); |
| | | t += String.fromCharCode(r >> 6 & 63 | 128); |
| | | t += String.fromCharCode(r & 63 | 128) |
| | | } |
| | | } |
| | | return t |
| | | }, _utf8_decode: function (e) { |
| | | var t = ""; |
| | | var n = 0; |
| | | var r = c1 = c2 = 0; |
| | | while (n < e.length) { |
| | | r = e.charCodeAt(n); |
| | | if (r < 128) { |
| | | t += String.fromCharCode(r); |
| | | n++ |
| | | } else if (r > 191 && r < 224) { |
| | | c2 = e.charCodeAt(n + 1); |
| | | t += String.fromCharCode((r & 31) << 6 | c2 & 63); |
| | | n += 2 |
| | | } else { |
| | | c2 = e.charCodeAt(n + 1); |
| | | c3 = e.charCodeAt(n + 2); |
| | | t += String.fromCharCode((r & 15) << 12 | (c2 & 63) << 6 | c3 & 63); |
| | | n += 3 |
| | | } |
| | | } |
| | | return t |
| | | } |
| | | }; |
| | | if (isIE9_()) { |
| | | // 兼容btoa和atob方法 |
| | | window.btoa = function (str) { |
| | | return Base64.encode(str); |
| | | }; |
| | | window.atob = function (str) { |
| | | return Base64.decode(str); |
| | | }; |
| | | // 兼容classList属性 |
| | | if (!("classList" in document.documentElement)) { |
| | | Object.defineProperty(window.Element.prototype, 'classList', { |
| | | get: function () { |
| | | var self = this; |
| | | |
| | | function update(fn) { |
| | | return function () { |
| | | var className = self.className.replace(/^\s+|\s+$/g, ''), |
| | | valArr = arguments; |
| | | return fn(className, valArr) |
| | | } |
| | | } |
| | | |
| | | function add_rmv(className, valArr, tag) { |
| | | for (var i in valArr) { |
| | | if (typeof valArr[i] !== 'string' || !!~valArr[i].search(/\s+/g)) throw TypeError('the type of value is error') |
| | | var temp = valArr[i] |
| | | var flag = !!~className.search(new RegExp('(\\s+)?' + temp + '(\\s+)?')) |
| | | if (tag === 1) { |
| | | !flag ? className += ' ' + temp : '' |
| | | } else if (tag === 2) { |
| | | flag ? className = className.replace(new RegExp('(\\s+)?' + temp), '') : '' |
| | | } |
| | | } |
| | | self.className = className; |
| | | return tag; |
| | | } |
| | | |
| | | return { |
| | | add: update(function (className, valArr) { |
| | | add_rmv(className, valArr, 1) |
| | | }), |
| | | remove: update(function (className, valArr) { |
| | | add_rmv(className, valArr, 2) |
| | | }), |
| | | toggle: function (value) { |
| | | if (typeof value !== 'string' || arguments.length === 0) throw TypeError("Failed to execute 'toggle' on 'DOMTokenList': 1 argument(string) required, but only 0 present.") |
| | | if (arguments.length === 1) { |
| | | this.contains(value) ? this.remove(value) : this.add(value) |
| | | return |
| | | } |
| | | !arguments[1] ? this.remove(value) : this.add(value) |
| | | }, |
| | | contains: update(function (className, valArr) { |
| | | if (valArr.length === 0) throw TypeError("Failed to execute 'contains' on 'DOMTokenList': 1 argument required, but only 0 present.") |
| | | if (typeof valArr[0] !== 'string' || !!~valArr[0].search(/\s+/g)) return false |
| | | return !!~className.search(new RegExp(valArr[0])) |
| | | }), |
| | | item: function (index) { |
| | | typeof index === 'string' ? index = parseInt(index) : '' |
| | | if (arguments.length === 0 || typeof index !== 'number') throw TypeError("Failed to execute 'toggle' on 'DOMTokenList': 1 argument required, but only 0 present.") |
| | | var claArr = self.className.replace(/^\s+|\s+$/, '').split(/\s+/) |
| | | var len = claArr.length |
| | | if (index < 0 || index >= len) return null |
| | | return claArr[index] |
| | | } |
| | | } |
| | | } |
| | | }); |
| | | } |
| | | } |
| | | |
| | | // 播放声音 |
| | | $iziToast.playSound = function (src) { |
| | | if (!(src.indexOf('http') == 0)) { |
| | | src = layui.cache.base + 'notice/' + src + '.wav'; |
| | | } |
| | | if (!!window.ActiveXObject || "ActiveXObject" in window) { // IE |
| | | var embed = document.noticePlay; |
| | | if (embed) { |
| | | embed.remove(); |
| | | } |
| | | embed = document.createElement('embed'); |
| | | embed.setAttribute('name', 'noticePlay'); |
| | | embed.setAttribute('src', src); |
| | | embed.setAttribute('autostart', true); |
| | | embed.setAttribute('loop', false); |
| | | embed.setAttribute('hidden', true); |
| | | document.body.appendChild(embed); |
| | | embed = document.noticePlay; |
| | | embed.volume = 100; |
| | | } else { // 非IE |
| | | var audio = document.createElement('audio'); |
| | | audio.setAttribute('hidden', true); |
| | | audio.setAttribute('src', src); |
| | | document.body.appendChild(audio); |
| | | audio.addEventListener('ended', function () { |
| | | audio.parentNode.removeChild(audio); |
| | | }, false); |
| | | audio.play(); |
| | | } |
| | | }; |
| | | |
| | | // 不同主题的通知 |
| | | forEach(THEMES, function (theme, name) { |
| | | $iziToast[name] = function (options) { |
| | | var settings = extend(CONFIG, options || {}); |
| | | settings = extend(theme, settings || {}); |
| | | this.show(settings); |
| | | }; |
| | | }); |
| | | |
| | | layui.link(layui.cache.base + 'notice/notice.css'); // 加载css |
| | | exports('notice', $iziToast); |
| | | }); |
| | |
| | | <!DOCTYPE html> |
| | | <html lang="en"> |
| | | <html> |
| | | <head> |
| | | <meta charset="UTF-8"> |
| | | <title>Title</title> |
| | | <meta charset="utf-8"/> |
| | | <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> |
| | | <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"> |
| | | <title>404</title> |
| | | <link rel="stylesheet" href="../static/layui/css/layui.css" media="all"> |
| | | <link rel="stylesheet" href="../static/css/admin.css?v=318"> |
| | | </head> |
| | | <body background="../static/image/404.jpg" style="background-repeat:no-repeat; background-size:100% 100%; background-attachment:fixed;"> |
| | | <body> |
| | | <!-- 正文开始 --> |
| | | <div class="error-page"> |
| | | <img class="error-page-img" src="../static/image/ic_404.png"> |
| | | <div class="error-page-info"> |
| | | <h1>404</h1> |
| | | <p>啊哦,你访问的页面不存在(⋟﹏⋞)</p> |
| | | <div> |
| | | <a ew-href="home/console.html" class="layui-btn">返回首页</a> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <style> |
| | | .error-page { |
| | | position: absolute; |
| | | top: 50%; |
| | | width: 100%; |
| | | text-align: center; |
| | | -o-transform: translateY(-50%); |
| | | -ms-transform: translateY(-50%); |
| | | -moz-transform: translateY(-50%); |
| | | -webkit-transform: translateY(-50%); |
| | | transform: translateY(-50%); |
| | | } |
| | | |
| | | .error-page .error-page-img { |
| | | display: inline-block; |
| | | height: 260px; |
| | | margin: 10px 15px; |
| | | } |
| | | |
| | | .error-page .error-page-info { |
| | | vertical-align: middle; |
| | | display: inline-block; |
| | | margin: 10px 15px; |
| | | } |
| | | |
| | | .error-page .error-page-info > h1 { |
| | | color: #434e59; |
| | | font-size: 72px; |
| | | font-weight: 600; |
| | | } |
| | | |
| | | .error-page .error-page-info > p { |
| | | color: #777; |
| | | font-size: 20px; |
| | | margin-top: 5px; |
| | | } |
| | | |
| | | .error-page .error-page-info > div { |
| | | margin-top: 30px; |
| | | } |
| | | </style> |
| | | |
| | | <!-- js部分 --> |
| | | <script type="text/javascript" src="../static/layui/layui.js"></script> |
| | | <script> |
| | | layui.use(['admin'], function () { |
| | | |
| | | }); |
| | | </script> |
| | | </body> |
| | | </html> |
| | |
| | | <!DOCTYPE html> |
| | | <html lang="en"> |
| | | <head> |
| | | <meta charset="UTF-8"> |
| | | <title>别样肉客</title> |
| | | <script>if (window !== top) top.location.replace(location.href);</script> |
| | | <meta charset="utf-8"/> |
| | | <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> |
| | | <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"> |
| | | <link rel="icon" type="image/x-icon" href="../static/image/log.png" /> |
| | | <title>用户登录</title> |
| | | <link rel="stylesheet" href="../static/layui/css/layui.css" media="all"> |
| | | <script type="text/javascript" src="../static/layui/layui.js"></script> |
| | | <script type="text/javascript" src="../static/js/common.js"></script> |
| | | <link rel="stylesheet" href="../static/css/admin.css?v=318"> |
| | | <!--[if lt IE 9]> |
| | | <script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> |
| | | <script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> |
| | | <![endif]--> |
| | | <style> |
| | | html{ |
| | | height: 100%; |
| | | } |
| | | body.login-bg { |
| | | color: #777; |
| | | height: 100%; |
| | | background-image: url("../static/image/bg-imgage.jpg"); |
| | | /*background-image: url("../static/image/login_bg.jpg");*/ |
| | | body { |
| | | background-image: url("../static/image/bg-login.jpg"); |
| | | background-repeat: no-repeat; |
| | | background-size: cover; |
| | | background-position: top center; |
| | | min-height: 100vh; |
| | | } |
| | | |
| | | #login-wrapper { |
| | | /*color: #fff;*/ |
| | | box-sizing:border-box; |
| | | /*background: #576669;*/ |
| | | background: #fff; |
| | | position: absolute; |
| | | top: 45%; |
| | | left: 50%; |
| | | margin-top: -210px; |
| | | margin-left: -220px; |
| | | width: 440px; |
| | | min-height: 420px; |
| | | padding: 50px; |
| | | text-align: center; |
| | | border-radius: 5px; |
| | | |
| | | transform-origin: 50% 50%; |
| | | animation: loading 1s 0s forwards; |
| | | transform: rotateX(0deg); |
| | | body:before { |
| | | content: ""; |
| | | background-color: rgba(0, 0, 0, .2); |
| | | position: fixed; |
| | | top: 0; |
| | | left: 0; |
| | | right: 0; |
| | | bottom: 0; |
| | | } |
| | | |
| | | #login-wrapper h2 { |
| | | letter-spacing: 3px; |
| | | font-size: 26px; |
| | | margin-bottom: 30px; |
| | | } |
| | | |
| | | .layadmin-user-login-body .layui-form-item { |
| | | margin-bottom: 20px; |
| | | .login-wrapper { |
| | | max-width: 420px; |
| | | padding: 20px; |
| | | margin: 0 auto; |
| | | position: relative; |
| | | box-sizing: border-box; |
| | | z-index: 2; |
| | | } |
| | | .layadmin-user-login-body .layui-form-item .layui-input { |
| | | height: 42px; |
| | | padding-left: 40px; |
| | | font-size: 16px; |
| | | border: 1px solid #c8cccf; |
| | | color: inherit; |
| | | } |
| | | .login-submit { |
| | | margin-top: 30px; |
| | | } |
| | | .layadmin-user-login-icon { |
| | | position: absolute; |
| | | left: 1px; |
| | | top: 1px; |
| | | width: 38px; |
| | | line-height: 40px; |
| | | text-align: center; |
| | | color: #B2B2B2; |
| | | font-size: 18px; |
| | | } |
| | | .layui-btn-normal { |
| | | background-color: #0767aa; |
| | | font-size: 20px; |
| | | |
| | | .login-wrapper > .layui-form { |
| | | padding: 25px 30px; |
| | | background-color: #fff; |
| | | box-shadow: 0 3px 6px -1px rgba(0, 0, 0, 0.19); |
| | | box-sizing: border-box; |
| | | border-radius: 4px; |
| | | height: 52px; |
| | | } |
| | | .layui-form-checked[lay-skin=primary] i { |
| | | border-color: #0767aa!important; |
| | | background-color: #0767aa; |
| | | color: #fff; |
| | | |
| | | .login-wrapper > .layui-form > h2 { |
| | | color: #333; |
| | | font-size: 18px; |
| | | text-align: center; |
| | | margin-bottom: 25px; |
| | | } |
| | | .layui-form-checkbox[lay-skin=primary]:hover i { |
| | | border-color: #0767aa; |
| | | color: #fff; |
| | | } |
| | | #code-box { |
| | | |
| | | .login-wrapper > .layui-form > .layui-form-item { |
| | | margin-bottom: 25px; |
| | | position: relative; |
| | | height: 42px; |
| | | } |
| | | #code-label { |
| | | z-index: 999; |
| | | |
| | | .login-wrapper > .layui-form > .layui-form-item:last-child { |
| | | margin-bottom: 0; |
| | | } |
| | | #code { |
| | | |
| | | .login-wrapper > .layui-form > .layui-form-item > .layui-input { |
| | | height: 46px; |
| | | line-height: 46px; |
| | | border-radius: 2px !important; |
| | | } |
| | | |
| | | .login-wrapper .layui-input-icon-group > .layui-input { |
| | | padding-left: 46px; |
| | | } |
| | | |
| | | .login-wrapper .layui-input-icon-group > .layui-icon { |
| | | width: 46px; |
| | | height: 46px; |
| | | line-height: 46px; |
| | | font-size: 20px; |
| | | color: #909399; |
| | | position: absolute; |
| | | left: 0; |
| | | top: 0; |
| | | display: inline-block; |
| | | width: 60%; |
| | | text-align: center; |
| | | } |
| | | #codeImg { |
| | | border: 1px solid rgba(0,0,0,0.1); |
| | | |
| | | .login-wrapper > .layui-form > .layui-form-item.login-captcha-group { |
| | | padding-right: 135px; |
| | | } |
| | | |
| | | .login-wrapper > .layui-form > .layui-form-item.login-captcha-group > .login-captcha { |
| | | height: 46px; |
| | | width: 120px; |
| | | cursor: pointer; |
| | | box-sizing: border-box; |
| | | border: 1px solid #e6e6e6; |
| | | border-radius: 2px !important; |
| | | position: absolute; |
| | | right: 5%; |
| | | right: 0; |
| | | top: 0; |
| | | width: 30%; |
| | | height: 90%; |
| | | } |
| | | |
| | | .login-wrapper > .layui-form > .layui-form-item > .layui-form-checkbox { |
| | | margin: 0 !important; |
| | | padding-left: 25px; |
| | | } |
| | | |
| | | .login-wrapper > .layui-form > .layui-form-item > .layui-form-checkbox > .layui-icon { |
| | | width: 15px !important; |
| | | height: 15px !important; |
| | | } |
| | | |
| | | .login-wrapper > .layui-form .layui-btn-fluid { |
| | | height: 48px; |
| | | line-height: 48px; |
| | | font-size: 16px; |
| | | border-radius: 2px !important; |
| | | } |
| | | |
| | | .login-wrapper > .layui-form > .layui-form-item.login-oauth-group > a > .layui-icon { |
| | | font-size: 26px; |
| | | } |
| | | |
| | | .login-copyright { |
| | | color: #eee; |
| | | padding-bottom: 20px; |
| | | text-align: center; |
| | | position: relative; |
| | | z-index: 1; |
| | | } |
| | | |
| | | @media screen and (min-height: 550px) { |
| | | .login-wrapper { |
| | | margin: -250px auto 0; |
| | | position: absolute; |
| | | top: 50%; |
| | | left: 0; |
| | | right: 0; |
| | | width: 100%; |
| | | } |
| | | |
| | | .login-copyright { |
| | | position: absolute; |
| | | bottom: 0; |
| | | right: 0; |
| | | left: 0; |
| | | } |
| | | } |
| | | |
| | | .layui-btn { |
| | | background-color: #5FB878; |
| | | border-color: #5FB878; |
| | | } |
| | | |
| | | .layui-link { |
| | | color: #5FB878 !important; |
| | | } |
| | | </style> |
| | | </head> |
| | | <body class="login-bg"> |
| | | |
| | | <div id="login-wrapper"> |
| | | <header> |
| | | <h2>系统登录</h2> |
| | | </header> |
| | | <div class="layui-form layadmin-user-login-body"> |
| | | <div class="layui-form-item"> |
| | | <label class="layui-icon layui-icon-username layadmin-user-login-icon"></label> |
| | | <input id="username" class="layui-input" type="text" name="username" lay-verify="username" placeholder="账号"> |
| | | <body> |
| | | <div class="login-wrapper layui-anim layui-anim-scale layui-hide"> |
| | | <form class="layui-form"> |
| | | <h2>用户登录</h2> |
| | | <div class="layui-form-item layui-input-icon-group"> |
| | | <i class="layui-icon layui-icon-username"></i> |
| | | <input class="layui-input" id="username" name="username" placeholder="请输入登录账号" autocomplete="off" |
| | | lay-verType="tips" lay-verify="required" required/> |
| | | </div> |
| | | <div class="layui-form-item"> |
| | | <label class="layui-icon layui-icon-password layadmin-user-login-icon"></label> |
| | | <input id="password" class="layui-input" type="password" name="password" lay-verify="password" placeholder="密码"> |
| | | <div class="layui-form-item layui-input-icon-group"> |
| | | <i class="layui-icon layui-icon-password"></i> |
| | | <input class="layui-input" id="password" name="password" placeholder="请输入登录密码" type="password" |
| | | lay-verType="tips" lay-verify="required" required/> |
| | | </div> |
| | | <div id="code-box" class="layui-form-item" style=""> |
| | | <label id="code-label" class="layui-icon layui-icon-vercode layadmin-user-login-icon"></label> |
| | | <div id="code-box" class="layui-form-item layui-input-icon-group login-captcha-group"> |
| | | <i class="layui-icon layui-icon-auz"></i> |
| | | <input id="code" class="layui-input" type="text" name="password" lay-verify="code" placeholder="验证码"> |
| | | <img id="codeImg" title="看不清?点击换一张。"> |
| | | <img class="login-captcha" id="codeImg" title="看不清?点击换一张。"> |
| | | </div> |
| | | <div class="layui-form-item" style="text-align: left;padding-left: 3px;"> |
| | | <input id="rememberPwd" style="vertical-align: middle" type="checkbox" lay-skin='primary' lay-filter="remPwd" title="记住密码" checked="checked"> |
| | | <div class="layui-form-item"> |
| | | <input type="checkbox" name="remember" title="记住密码" lay-skin="primary" checked> |
| | | </div> |
| | | </div> |
| | | <div class="layui-form-item login-submit"> |
| | | <button id="login-button" class="layui-btn layui-btn-fluid layui-btn-normal" lay-submit="" lay-filter="login">登 录</button> |
| | | </div> |
| | | <div class="layui-form-item"> |
| | | <button class="layui-btn layui-btn-fluid" lay-filter="login" lay-submit>登录</button> |
| | | </div> |
| | | </form> |
| | | </div> |
| | | <div class="login-copyright">copyright © 2020 浙江中扬 all rights reserved.</div> |
| | | |
| | | </body> |
| | | <script type="text/javascript" src="../static/layui/layui.js"></script> |
| | | <script type="text/javascript" src="../static/js/common.js"></script> |
| | | <script type="text/javascript" src="../static/js/jquery/jquery-3.3.1.min.js"></script> |
| | | <script type="text/javascript" src="../static/js/tools/md5.js"></script> |
| | | <script type="text/javascript"> |
| | |
| | | }, 100); |
| | | } |
| | | |
| | | layui.use(['form','layer'],function () { |
| | | var form = layui.form, |
| | | layer = layui.layer, |
| | | $ = layui.jquery; |
| | | layui.config({ |
| | | base: baseUrl + "/static/layui/lay/modules/" |
| | | }).extend({ |
| | | notice: 'notice/notice', |
| | | }).use(['form','layer', 'notice'],function () { |
| | | var $ = layui.jquery; |
| | | var layer = layui.layer; |
| | | var form = layui.form; |
| | | var notice = layui.notice; |
| | | $('.login-wrapper').removeClass('layui-hide'); |
| | | |
| | | form.on('submit(login)', function (data) { |
| | | var username = $("#username").val(); |
| | | if (username === "") { |
| | | layer.msg("请输入账号", {offset: '150px'}); |
| | | return; |
| | | return false; |
| | | } |
| | | var password = $("#password").val(); |
| | | // if (password === "") { |
| | |
| | | // } |
| | | var code = $("#code").val(); |
| | | if (code === "" && codeSwitch === 'Y') { |
| | | layer.msg("请输入验证码", {offset: '150px'}); |
| | | return; |
| | | notice.msg('请输入验证码', {icon: 2}); |
| | | return false; |
| | | } |
| | | if (sessionStorage.getItem("code").toUpperCase() !== code.toUpperCase()&&codeSwitch==='Y'){ |
| | | layer.msg("验证码错误", {offset: '150px'}); |
| | | return; |
| | | notice.msg('验证码错误', {icon: 2}); |
| | | return false; |
| | | } |
| | | |
| | | var user = { |
| | |
| | | localStorage.setItem("nickname", res.data.nickname); |
| | | window.location.href = "index.html"; |
| | | } else { |
| | | layer.msg(res.msg, {offset: '150px'}); |
| | | notice.msg(res.msg, {icon: 2}); |
| | | } |
| | | } |
| | | }); |