UNPKG

shogun-button-react

Version:

Shogun connector button

454 lines (401 loc) 9.37 kB
/* Base styles */ :root { --shogun-primary: #3b82f6; --shogun-primary-hover: #2563eb; --shogun-secondary: #6b7280; --shogun-success: #10b981; --shogun-danger: #ef4444; --shogun-warning: #f59e0b; --shogun-text: #1f2937; --shogun-text-secondary: #6b7280; --shogun-bg: #ffffff; --shogun-bg-secondary: #f3f4f6; --shogun-border: #e5e7eb; --shogun-border-radius: 12px; --shogun-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06); --shogun-transition: all 0.2s ease; --shogun-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif; } /* Dark mode support */ @media (prefers-color-scheme: dark) { :root { --shogun-text: #f3f4f6; --shogun-text-secondary: #9ca3af; --shogun-bg: #1f2937; --shogun-bg-secondary: #374151; --shogun-border: #4b5563; } } /* Connect Button */ .shogun-connect-button { display: flex; align-items: center; justify-content: center; gap: 8px; background-color: var(--shogun-primary); color: white; border: none; border-radius: var(--shogun-border-radius); padding: 10px 16px; font-family: var(--shogun-font); font-weight: 600; font-size: 14px; cursor: pointer; transition: var(--shogun-transition); box-shadow: var(--shogun-shadow); } .shogun-connect-button:hover { background-color: var(--shogun-primary-hover); } .shogun-connect-button:focus { outline: none; box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.5); } /* Logged in state */ .shogun-logged-in-container { position: relative; } .shogun-dropdown { position: relative; } .shogun-button.shogun-logged-in { display: flex; align-items: center; gap: 8px; background-color: var(--shogun-bg-secondary); color: var(--shogun-text); border: 1px solid var(--shogun-border); border-radius: var(--shogun-border-radius); padding: 8px 12px; font-family: var(--shogun-font); font-size: 14px; cursor: pointer; transition: var(--shogun-transition); } .shogun-button.shogun-logged-in:hover { background-color: var(--shogun-bg); } .shogun-avatar { width: 24px; height: 24px; background-color: var(--shogun-primary); color: white; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 12px; } .shogun-username { font-weight: 500; } .shogun-dropdown-menu { position: absolute; top: calc(100% + 8px); right: 0; background-color: var(--shogun-bg); border: 1px solid var(--shogun-border); border-radius: var(--shogun-border-radius); box-shadow: var(--shogun-shadow); width: 240px; z-index: 9999; overflow: hidden; animation: shogun-dropdown-fade 0.2s ease; } @keyframes shogun-dropdown-fade { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } } .shogun-dropdown-header { padding: 16px; border-bottom: 1px solid var(--shogun-border); display: flex; align-items: center; gap: 12px; } .shogun-avatar-large { width: 40px; height: 40px; background-color: var(--shogun-primary); color: white; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 16px; } .shogun-user-info { display: flex; flex-direction: column; } .shogun-username-full { font-weight: 600; color: var(--shogun-text); font-size: 14px; } .shogun-dropdown-item { padding: 12px 16px; display: flex; align-items: center; gap: 12px; color: var(--shogun-text); font-size: 14px; cursor: pointer; transition: var(--shogun-transition); } .shogun-dropdown-item:hover { background-color: var(--shogun-bg-secondary); } /* Modal */ .shogun-modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background-color: rgba(0, 0, 0, 0.5); display: flex; align-items: center; justify-content: center; z-index: 1000; animation: shogun-fade-in 0.2s ease; } @keyframes shogun-fade-in { from { opacity: 0; } to { opacity: 1; } } .shogun-modal { background-color: var(--shogun-bg); border-radius: var(--shogun-border-radius); box-shadow: var(--shogun-shadow); width: 90%; max-width: 400px; max-height: 90vh; overflow-y: auto; animation: shogun-scale-in 0.2s ease; } @keyframes shogun-scale-in { from { opacity: 0; transform: scale(0.95); } to { opacity: 1; transform: scale(1); } } .shogun-modal-header { display: flex; justify-content: space-between; align-items: center; padding: 16px 20px; border-bottom: 1px solid var(--shogun-border); } .shogun-modal-header h2 { margin: 0; font-size: 1.5rem; font-weight: 600; color: var(--shogun-text); text-align: center; width: 100%; } .shogun-close-button { background: none; border: none; cursor: pointer; color: var(--shogun-text-secondary); padding: 4px; display: flex; align-items: center; justify-content: center; border-radius: 50%; transition: var(--shogun-transition); } .shogun-close-button:hover { background-color: var(--shogun-bg-secondary); color: var(--shogun-text); } .shogun-modal-content { padding: 20px; } /* Auth options */ .shogun-auth-options { display: flex; flex-direction: column; gap: 12px; margin-bottom: 24px; } .shogun-auth-option-button { display: flex; align-items: center; justify-content: center; gap: 12px; background-color: var(--shogun-bg); color: var(--shogun-text); border: 1px solid var(--shogun-border); border-radius: var(--shogun-border-radius); padding: 12px 16px; font-family: var(--shogun-font); font-weight: 500; font-size: 14px; cursor: pointer; transition: var(--shogun-transition); width: 100%; } .shogun-auth-option-button:hover { background-color: var(--shogun-bg-secondary); } .shogun-auth-option-button:disabled { opacity: 0.6; cursor: not-allowed; } .shogun-google-button { border-color: #4285F4; } /* Divider */ .shogun-divider { display: flex; align-items: center; margin: 20px 0; color: var(--shogun-text-secondary); font-size: 14px; } .shogun-divider::before, .shogun-divider::after { content: ""; flex: 1; border-bottom: 1px solid var(--shogun-border); } .shogun-divider span { padding: 0 10px; } /* Form */ .shogun-auth-form { display: flex; flex-direction: column; gap: 16px; } .shogun-form-group { display: flex; flex-direction: column; gap: 8px; } .shogun-form-group label { display: flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 500; color: var(--shogun-text); } .shogun-form-group input { padding: 12px; border: 1px solid var(--shogun-border); border-radius: var(--shogun-border-radius); background-color: var(--shogun-bg); color: var(--shogun-text); font-size: 14px; transition: var(--shogun-transition); } .shogun-form-group input:focus { outline: none; border-color: var(--shogun-primary); box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.2); } .shogun-submit-button { background-color: var(--shogun-primary); color: white; border: none; border-radius: var(--shogun-border-radius); padding: 12px 16px; font-family: var(--shogun-font); font-weight: 600; font-size: 14px; cursor: pointer; transition: var(--shogun-transition); margin-top: 8px; } .shogun-submit-button:hover:not(:disabled) { background-color: var(--shogun-primary-hover); } .shogun-submit-button:disabled { opacity: 0.6; cursor: not-allowed; } /* Footer */ .shogun-form-footer { margin-top: 20px; text-align: center; font-size: 14px; color: var(--shogun-text-secondary); } .shogun-toggle-mode { background: none; border: none; color: var(--shogun-primary); font-weight: 600; cursor: pointer; padding: 0; margin-left: 4px; transition: var(--shogun-transition); } .shogun-toggle-mode:hover { text-decoration: underline; } .shogun-toggle-mode:disabled { opacity: 0.6; cursor: not-allowed; } /* Error message */ .shogun-error-message { background-color: rgba(239, 68, 68, 0.1); color: var(--shogun-danger); padding: 12px; border-radius: var(--shogun-border-radius); margin-bottom: 16px; font-size: 14px; border: 1px solid rgba(239, 68, 68, 0.2); } .shogun-back-button { background: none; border: none; color: var(--shogun-text-secondary); cursor: pointer; font-size: 14px; margin-bottom: 16px; padding: 4px; display: flex; align-items: center; gap: 4px; font-weight: 500; transition: color 0.2s ease; } .shogun-back-button:hover { color: var(--shogun-text); } .shogun-prominent-toggle { font-weight: 600; color: var(--shogun-primary); padding: 8px 16px; margin-top: 16px; border: none; border-radius: 6px; background-color: transparent; transition: all 0.2s ease; } .shogun-prominent-toggle:hover { text-decoration: underline; } /* Redundant dark theme styles removed */