UNPKG

react-cool-toast

Version:

A lightweight, customizable toast notification library for React

1 lines 10 kB
.cool-toast{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#fff;border:1px solid rgba(0,0,0,.05);border-radius:12px;box-shadow:0 10px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);cursor:pointer;display:flex;margin:4px 0;max-width:420px;min-width:320px;opacity:0;overflow:hidden;padding:16px 20px;position:relative;transform:translateX(100%) scale(.95);transition:all .4s cubic-bezier(.16,1,.3,1)}.cool-toast.visible{opacity:1;transform:translateX(0) scale(1)}.cool-toast.leaving{opacity:0;transform:translateX(100%) scale(.95)}.cool-toast-content{align-items:center;display:flex;gap:14px;width:100%}.cool-toast-icon{align-items:center;background:rgba(0,0,0,.05);border-radius:50%;display:flex;flex-shrink:0;height:28px;justify-content:center;transition:all .2s ease;width:28px}.cool-toast-message{color:#1f2937;flex:1;font-size:15px;font-weight:500;line-height:1.5}.cool-toast-close{align-items:center;background:rgba(0,0,0,.05);border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;height:24px;justify-content:center;opacity:.7;transition:all .2s ease;width:24px}.cool-toast-close:hover{background:rgba(0,0,0,.1);color:#374151;opacity:1;transform:scale(1.1)}.cool-toast.success{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border:1px solid rgba(34,197,94,.2);box-shadow:0 10px 25px -5px rgba(34,197,94,.1),0 10px 10px -5px rgba(34,197,94,.04)}.cool-toast.success .cool-toast-icon{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 2px 8px rgba(34,197,94,.3);color:#fff}.cool-toast.success .cool-toast-message{color:#166534}.cool-toast.error{background:linear-gradient(135deg,#fef2f2,#fef7f7);border:1px solid rgba(239,68,68,.2);box-shadow:0 10px 25px -5px rgba(239,68,68,.1),0 10px 10px -5px rgba(239,68,68,.04)}.cool-toast.error .cool-toast-icon{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 8px rgba(239,68,68,.3);color:#fff}.cool-toast.error .cool-toast-message{color:#991b1b}.cool-toast.warning{background:linear-gradient(135deg,#fffbeb,#fffbf0);border:1px solid rgba(245,158,11,.2);box-shadow:0 10px 25px -5px rgba(245,158,11,.1),0 10px 10px -5px rgba(245,158,11,.04)}.cool-toast.warning .cool-toast-icon{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 8px rgba(245,158,11,.3);color:#fff}.cool-toast.warning .cool-toast-message{color:#92400e}.cool-toast.info{background:linear-gradient(135deg,#eff6ff,#f0f9ff);border:1px solid rgba(59,130,246,.2);box-shadow:0 10px 25px -5px rgba(59,130,246,.1),0 10px 10px -5px rgba(59,130,246,.04)}.cool-toast.info .cool-toast-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 8px rgba(59,130,246,.3);color:#fff}.cool-toast.info .cool-toast-message{color:#1e40af}.cool-toast.loading{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:1px solid hsla(220,9%,46%,.2);box-shadow:0 10px 25px -5px hsla(220,9%,46%,.1),0 10px 10px -5px hsla(220,9%,46%,.04);cursor:default}.cool-toast.loading .cool-toast-icon{animation:spin 1s linear infinite;background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 2px 8px rgba(139,92,246,.3);color:#fff}.cool-toast.loading .cool-toast-message{color:#374151}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.cool-toast:first-child{z-index:1000}.cool-toast:nth-child(2){transform:translateX(100%) scale(.95) translateY(-2px);z-index:999}.cool-toast:nth-child(3){transform:translateX(100%) scale(.9) translateY(-4px);z-index:998}.cool-toast:nth-child(4){transform:translateX(100%) scale(.85) translateY(-6px);z-index:997}.cool-toast:nth-child(5){transform:translateX(100%) scale(.8) translateY(-8px);z-index:996}.cool-toast:nth-child(n+6){opacity:.7;transform:translateX(100%) scale(.75) translateY(-10px);z-index:995}.cool-toast.visible:first-child{transform:translateX(0) scale(1)}.cool-toast.visible:nth-child(2){transform:translateX(0) scale(.98) translateY(-2px)}.cool-toast.visible:nth-child(3){transform:translateX(0) scale(.96) translateY(-4px)}.cool-toast.visible:nth-child(4){transform:translateX(0) scale(.94) translateY(-6px)}.cool-toast.visible:nth-child(5){transform:translateX(0) scale(.92) translateY(-8px)}.cool-toast.visible:nth-child(n+6){opacity:.8;transform:translateX(0) scale(.9) translateY(-10px)}.cool-toaster[data-position*=left] .cool-toast{transform:translateX(-100%)}.cool-toaster[data-position*=left] .cool-toast.visible{transform:translateX(0)}.cool-toaster[data-position*=left] .cool-toast.leaving{transform:translateX(-100%)}.cool-toaster[data-position*=bottom] .cool-toast{transform:translateY(100%)}.cool-toaster[data-position*=bottom] .cool-toast.visible{transform:translateY(0)}.cool-toaster[data-position*=bottom] .cool-toast.leaving{transform:translateY(100%)}.cool-toaster[data-position*=bottom][data-position*=left] .cool-toast{transform:translate(-100%,100%)}.cool-toaster[data-position*=bottom][data-position*=left] .cool-toast.visible{transform:translate(0)}.cool-toaster[data-position*=bottom][data-position*=left] .cool-toast.leaving{transform:translate(-100%,100%)}.cool-toast-progress{background:linear-gradient(90deg,#3b82f6,#1d4ed8);border-radius:0 0 12px 12px;bottom:0;height:3px;left:0;position:absolute;transition:width .1s linear}.cool-toast.success .cool-toast-progress{background:linear-gradient(90deg,#22c55e,#16a34a)}.cool-toast.error .cool-toast-progress{background:linear-gradient(90deg,#ef4444,#dc2626)}.cool-toast.warning .cool-toast-progress{background:linear-gradient(90deg,#f59e0b,#d97706)}.cool-toast-actions{border-top:1px solid rgba(0,0,0,.1);display:flex;gap:8px;margin-top:12px;padding-top:12px}.cool-toast-action{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:all .2s ease}.cool-toast-action.primary{background:#3b82f6;color:#fff}.cool-toast-action.primary:hover{background:#2563eb;transform:translateY(-1px)}.cool-toast-action.secondary{background:rgba(0,0,0,.05);color:#374151}.cool-toast-action.secondary:hover{background:rgba(0,0,0,.1)}.cool-toast-action.danger{background:#ef4444;color:#fff}.cool-toast-action.danger:hover{background:#dc2626;transform:translateY(-1px)}.cool-toast.theme-glass{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);box-shadow:0 8px 32px rgba(0,0,0,.1),inset 0 1px 0 hsla(0,0%,100%,.2)}.cool-toast.theme-glass .cool-toast-message{color:rgba(0,0,0,.8)}.cool-toast.theme-neon{background:#000;border:2px solid #0f8;box-shadow:0 0 20px rgba(0,255,136,.3),inset 0 0 20px rgba(0,255,136,.1);color:#0f8}.cool-toast.theme-neon .cool-toast-message{color:#0f8;text-shadow:0 0 10px rgba(0,255,136,.5)}.cool-toast.theme-neon .cool-toast-icon{background:#0f8;box-shadow:0 0 15px rgba(0,255,136,.5);color:#000}.cool-toast.theme-minimal{background:#fff;border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 1px 3px rgba(0,0,0,.1)}.cool-toast.theme-minimal .cool-toast-icon{background:transparent;color:#6b7280}.cool-toast.theme-colorful.success{background:linear-gradient(135deg,#ff6b6b,#4ecdc4,#45b7d1,#96ceb4);border:none;color:#fff}.cool-toast.theme-colorful.error{background:linear-gradient(135deg,#ff6b6b,#ee5a24,#ff9ff3,#f368e0);border:none;color:#fff}.cool-toast.theme-colorful.warning{background:linear-gradient(135deg,#feca57,#ff9ff3,#48dbfb,#0abde3);border:none;color:#fff}.cool-toast.theme-colorful.info{background:linear-gradient(135deg,#48dbfb,#0abde3,#74b9ff,#6c5ce7);border:none;color:#fff}.cool-toast.theme-dark{background:#1a1a1a;border:1px solid #333;color:#fff}.cool-toast.theme-dark .cool-toast-message{color:#fff}.cool-toast.theme-dark .cool-toast-close{color:#ccc}.cool-toast.swiping{transition:transform .1s ease-out}.cool-toast.swipe-threshold{opacity:.7}.cool-toast.rich-content .cool-toast-message{line-height:1.6}.cool-toast.rich-content .cool-toast-message img{border-radius:6px;margin:8px 0;max-width:100%}.cool-toast.rich-content .cool-toast-message a{color:#3b82f6;text-decoration:none}.cool-toast.rich-content .cool-toast-message a:hover{text-decoration:underline}@media (max-width:640px){.cool-toast{margin:8px 16px;max-width:calc(100vw - 32px);min-width:280px}.cool-toast-actions{flex-direction:column}.cool-toast-action{text-align:center;width:100%}}@media (prefers-color-scheme:dark){.cool-toast{background:#1f2937;border-color:#374151}.cool-toast,.cool-toast-message{color:#f9fafb}.cool-toast-close{color:#9ca3af}.cool-toast-close:hover{background:hsla(0,0%,100%,.1);color:#f9fafb}.cool-toast.success{background:#064e3b;border-color:#065f46}.cool-toast.error{background:#7f1d1d;border-color:#991b1b}.cool-toast.warning{background:#78350f;border-color:#92400e}.cool-toast.info{background:#1e3a8a;border-color:#1e40af}.cool-toast.loading{background:#111827;border-color:#374151}.cool-toast-actions{border-top-color:hsla(0,0%,100%,.1)}.cool-toast-action.secondary{background:hsla(0,0%,100%,.1);color:#f9fafb}.cool-toast-action.secondary:hover{background:hsla(0,0%,100%,.2)}}.cool-toaster{box-sizing:border-box;display:flex;flex-direction:column;gap:var(--gutter,6px);max-height:100vh;max-width:100vw;padding:20px;pointer-events:none;position:fixed;z-index:9999}.cool-toaster[data-position=top-left]{align-items:flex-start;left:0;top:0}.cool-toaster[data-position=top-center]{align-items:center;left:50%;top:0;transform:translateX(-50%)}.cool-toaster[data-position=top-right]{align-items:flex-end;right:0;top:0}.cool-toaster[data-position=bottom-left]{align-items:flex-start;bottom:0;flex-direction:column-reverse;left:0}.cool-toaster[data-position=bottom-center]{align-items:center;bottom:0;flex-direction:column-reverse;left:50%;transform:translateX(-50%)}.cool-toaster[data-position=bottom-right]{align-items:flex-end;bottom:0;flex-direction:column-reverse;right:0}.cool-toaster .cool-toast{pointer-events:auto}@media (max-width:640px){.cool-toaster{align-items:stretch!important;left:0!important;padding:8px;right:0!important;transform:none!important}.cool-toaster .cool-toast{max-width:none;min-width:auto}}