UNPKG

openrouter-model-picker

Version:

Third-party React component for OpenRouter model selection

2 lines (1 loc) 5.41 kB
.openrouter-modal{--or-primary-color: #3b82f6;--or-primary-hover: #2563eb;--or-background: #ffffff;--or-text: #111827;--or-text-secondary: #6b7280;--or-border: #e5e7eb;--or-shadow: rgba(0, 0, 0, .1)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.modal-content{background-color:var(--or-background);border-radius:.5rem;box-shadow:0 25px 50px -12px #00000040;width:100%;max-width:64rem;max-height:calc(100vh - 2rem);display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--or-border)}.modal-title{font-size:1.125rem;font-weight:600;color:var(--or-text);margin:0}.modal-close-button{background:none;border:none;color:var(--or-text-secondary);cursor:pointer;padding:.5rem;border-radius:.375rem;transition:background-color .2s}.modal-close-button:hover{background-color:#0000000d}.modal-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.filter-bar{padding:.75rem 1.5rem;border-bottom:1px solid var(--or-border);background-color:var(--or-background)}.filter-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.search-input{flex:1;min-width:200px;padding:.5rem .75rem;border:1px solid var(--or-border);border-radius:.375rem;background-color:var(--or-background);color:var(--or-text);font-size:.875rem}.filter-select{padding:.5rem .75rem;border:1px solid var(--or-border);border-radius:.375rem;background-color:var(--or-background);color:var(--or-text);font-size:.875rem;min-width:120px}.filter-button{padding:.5rem 1rem;border:1px solid var(--or-border);border-radius:.375rem;background-color:var(--or-background);color:var(--or-text);font-size:.875rem;cursor:pointer;transition:all .2s}.filter-button:hover{background-color:#3b82f60d}.filter-button.active{background-color:var(--or-primary-color);color:#fff;border-color:var(--or-primary-color)}.clear-filters-button{padding:.5rem 1rem;border:none;border-radius:.375rem;background-color:transparent;color:var(--or-text-secondary);font-size:.875rem;cursor:pointer;transition:color .2s}.clear-filters-button:hover{color:var(--or-text)}.results-count{color:var(--or-text-secondary);font-size:.875rem;margin-left:auto}.categorized-models{flex:1;overflow:auto;min-height:0}.table-container{flex:1;overflow:auto;background-color:var(--or-background);min-height:0}.model-table{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}.model-table th,.model-table td{padding:.5rem;text-align:left;border-bottom:1px solid var(--or-border)}.model-table th{background-color:var(--or-background);font-weight:600;color:var(--or-text);cursor:pointer;-webkit-user-select:none;user-select:none;position:sticky;top:0;z-index:10}.model-table th:hover{background-color:#00000005}.model-table td{color:var(--or-text);font-size:.875rem}.model-table tbody tr{cursor:pointer;transition:background-color .2s}.loading-container,.error-container,.empty-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:var(--or-text-secondary)}.loading-spinner{width:2rem;height:2rem;border:2px solid var(--or-border);border-top:2px solid var(--or-primary-color);border-radius:50%;margin-bottom:1rem}.error-message{color:#ef4444;margin-bottom:1rem}.retry-button{padding:.5rem 1rem;background-color:var(--or-primary-color);color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem}.retry-button:hover{background-color:var(--or-primary-hover)}.openrouter-modal.dark{--or-background: #1f2937;--or-text: #f9fafb;--or-text-secondary: #9ca3af;--or-border: #374151;--or-shadow: rgba(0, 0, 0, .3)}.cost-tier-free{background-color:#10b981}.cost-tier-low{background-color:#3b82f6}.cost-tier-medium{background-color:#f59e0b}.cost-tier-high{background-color:#ef4444}.feature-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:.75rem;background-color:#f3f4f6;color:#374151;border-radius:.375rem}.model-table{font-variant-numeric:tabular-nums}.model-table thead th{position:sticky;top:0;background-color:var(--or-background);z-index:10}.model-table tbody tr:hover{background-color:#3b82f60d}.model-table tbody tr.selected{background-color:#3b82f61a;border-color:var(--or-primary-color)}@media (max-width: 768px){.openrouter-modal{margin:1rem;max-height:calc(100vh - 2rem)}.model-table{font-size:.875rem}.filter-bar{padding:1rem}.filter-bar .flex-wrap{flex-direction:column;align-items:flex-start;gap:.75rem}}.modal-overlay{animation:fadeIn .2s ease-out}.modal-content{animation:slideUp .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.openrouter-modal button:focus,.openrouter-modal input:focus,.openrouter-modal select:focus{outline:2px solid var(--or-primary-color);outline-offset:2px}@media (prefers-contrast: high){.openrouter-modal{--or-border: #000000;--or-text-secondary: #000000}.openrouter-modal.dark{--or-border: #ffffff;--or-text-secondary: #ffffff}}@media (prefers-reduced-motion: reduce){.modal-overlay,.modal-content,.spinner{animation:none}.openrouter-modal *{transition:none!important}}