ignore: cloud styles
This commit is contained in:
@@ -23,453 +23,451 @@
|
|||||||
padding-bottom: var(--space-16);
|
padding-bottom: var(--space-16);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/* Common elements */
|
/* Common elements */
|
||||||
button {
|
button {
|
||||||
padding: var(--space-3) var(--space-4);
|
padding: var(--space-3) var(--space-4);
|
||||||
border: 1px solid var(--color-border);
|
border: 1px solid var(--color-border);
|
||||||
border-radius: var(--border-radius-sm);
|
border-radius: var(--border-radius-sm);
|
||||||
background-color: var(--color-bg);
|
background-color: var(--color-bg);
|
||||||
color: var(--color-text);
|
color: var(--color-text);
|
||||||
font-size: var(--font-size-sm);
|
font-size: var(--font-size-sm);
|
||||||
font-family: var(--font-sans);
|
font-family: var(--font-sans);
|
||||||
font-weight: 500;
|
font-weight: 500;
|
||||||
text-transform: uppercase;
|
text-transform: uppercase;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
transition: all 0.15s ease;
|
transition: all 0.15s ease;
|
||||||
|
|
||||||
&:hover {
|
|
||||||
background-color: var(--color-surface-hover);
|
|
||||||
border-color: var(--color-accent);
|
|
||||||
}
|
|
||||||
|
|
||||||
&:active {
|
|
||||||
transform: translateY(1px);
|
|
||||||
}
|
|
||||||
|
|
||||||
&:disabled {
|
|
||||||
opacity: 0.5;
|
|
||||||
cursor: not-allowed;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
background-color: var(--color-bg);
|
|
||||||
border-color: var(--color-border);
|
|
||||||
transform: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&[color="primary"] {
|
|
||||||
background-color: var(--color-primary);
|
|
||||||
border-color: var(--color-primary);
|
|
||||||
color: var(--color-primary-text);
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
background-color: var(--color-primary-hover);
|
|
||||||
border-color: var(--color-primary-hover);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&[color="ghost"] {
|
|
||||||
background-color: transparent;
|
|
||||||
border-color: transparent;
|
|
||||||
color: var(--color-text-muted);
|
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
background-color: var(--color-surface-hover);
|
background-color: var(--color-surface-hover);
|
||||||
border-color: var(--color-border);
|
border-color: var(--color-accent);
|
||||||
color: var(--color-text);
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
a {
|
&:active {
|
||||||
color: var(--color-text);
|
transform: translateY(1px);
|
||||||
text-decoration: underline;
|
}
|
||||||
text-underline-offset: var(--space-0-75);
|
|
||||||
text-decoration-thickness: 1px;
|
|
||||||
}
|
|
||||||
|
|
||||||
[data-slot="empty-state"] {
|
&:disabled {
|
||||||
padding: var(--space-20) var(--space-6);
|
opacity: 0.5;
|
||||||
text-align: center;
|
cursor: not-allowed;
|
||||||
border: 1px dashed var(--color-border);
|
|
||||||
border-radius: var(--border-radius-sm);
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
gap: var(--space-2);
|
|
||||||
|
|
||||||
p {
|
&:hover {
|
||||||
font-size: var(--font-size-sm);
|
background-color: var(--color-bg);
|
||||||
color: var(--color-text-muted);
|
border-color: var(--color-border);
|
||||||
margin: 0;
|
transform: none;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Title section */
|
&[data-color="primary"] {
|
||||||
[data-slot="title-section"] {
|
background-color: var(--color-primary);
|
||||||
display: flex;
|
border-color: var(--color-primary);
|
||||||
flex-direction: column;
|
color: var(--color-primary-text);
|
||||||
gap: var(--space-2);
|
|
||||||
padding-bottom: var(--space-8);
|
|
||||||
border-bottom: 1px solid var(--color-border);
|
|
||||||
|
|
||||||
h1 {
|
&:hover {
|
||||||
font-size: var(--font-size-2xl);
|
background-color: var(--color-primary-hover);
|
||||||
font-weight: 500;
|
border-color: var(--color-primary-hover);
|
||||||
line-height: 1.2;
|
}
|
||||||
letter-spacing: -0.03125rem;
|
}
|
||||||
margin: 0;
|
|
||||||
text-transform: uppercase;
|
|
||||||
|
|
||||||
@media (max-width: 30rem) {
|
&[data-color="ghost"] {
|
||||||
font-size: var(--font-size-xl);
|
background-color: transparent;
|
||||||
line-height: 1.25;
|
border-color: transparent;
|
||||||
|
color: var(--color-text-muted);
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
background-color: var(--color-surface-hover);
|
||||||
|
border-color: var(--color-border);
|
||||||
|
color: var(--color-text);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
p {
|
a {
|
||||||
font-size: var(--font-size-md);
|
color: var(--color-text);
|
||||||
color: var(--color-text-muted);
|
text-decoration: underline;
|
||||||
|
text-underline-offset: var(--space-0-75);
|
||||||
|
text-decoration-thickness: 1px;
|
||||||
|
}
|
||||||
|
|
||||||
a {
|
[data-slot="empty-state"] {
|
||||||
|
padding: var(--space-20) var(--space-6);
|
||||||
|
text-align: center;
|
||||||
|
border: 1px dashed var(--color-border);
|
||||||
|
border-radius: var(--border-radius-sm);
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
gap: var(--space-2);
|
||||||
|
|
||||||
|
p {
|
||||||
|
font-size: var(--font-size-sm);
|
||||||
|
color: var(--color-text-muted);
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Title section */
|
||||||
|
[data-slot="title-section"] {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
gap: var(--space-2);
|
||||||
|
padding-bottom: var(--space-8);
|
||||||
|
border-bottom: 1px solid var(--color-border);
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-size: var(--font-size-2xl);
|
||||||
|
font-weight: 500;
|
||||||
|
line-height: 1.2;
|
||||||
|
letter-spacing: -0.03125rem;
|
||||||
|
margin: 0;
|
||||||
|
text-transform: uppercase;
|
||||||
|
|
||||||
|
@media (max-width: 30rem) {
|
||||||
|
font-size: var(--font-size-xl);
|
||||||
|
line-height: 1.25;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
font-size: var(--font-size-md);
|
||||||
|
color: var(--color-text-muted);
|
||||||
|
|
||||||
|
a {
|
||||||
|
color: var(--color-text-muted);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Section titles */
|
||||||
|
[data-slot="section-title"] {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
gap: var(--space-1);
|
||||||
|
|
||||||
|
h2 {
|
||||||
|
font-size: var(--font-size-md);
|
||||||
|
font-weight: 600;
|
||||||
|
line-height: 1.2;
|
||||||
|
letter-spacing: -0.03125rem;
|
||||||
|
margin: 0;
|
||||||
|
color: var(--color-text-secondary);
|
||||||
|
text-transform: uppercase;
|
||||||
|
|
||||||
|
@media (max-width: 30rem) {
|
||||||
|
font-size: var(--font-size-lg);
|
||||||
|
line-height: 1.25;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
font-size: var(--font-size-sm);
|
||||||
color: var(--color-text-muted);
|
color: var(--color-text-muted);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/* Section titles */
|
/* API Keys Section */
|
||||||
[data-slot="section-title"] {
|
[data-slot="api-keys-section"] {
|
||||||
display: flex;
|
[data-slot="create-form"] {
|
||||||
flex-direction: column;
|
display: flex;
|
||||||
gap: var(--space-1);
|
flex-direction: column;
|
||||||
|
gap: var(--space-3);
|
||||||
h2 {
|
padding: var(--space-4);
|
||||||
font-size: var(--font-size-md);
|
|
||||||
font-weight: 600;
|
|
||||||
line-height: 1.2;
|
|
||||||
letter-spacing: -0.03125rem;
|
|
||||||
margin: 0;
|
|
||||||
color: var(--color-text-secondary);
|
|
||||||
text-transform: uppercase;
|
|
||||||
|
|
||||||
@media (max-width: 30rem) {
|
|
||||||
font-size: var(--font-size-lg);
|
|
||||||
line-height: 1.25;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
p {
|
|
||||||
font-size: var(--font-size-sm);
|
|
||||||
color: var(--color-text-muted);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* API Keys Section */
|
|
||||||
[data-slot="api-keys-section"] {
|
|
||||||
[data-slot="create-form"] {
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
gap: var(--space-3);
|
|
||||||
padding: var(--space-4);
|
|
||||||
background-color: var(--color-bg-surface);
|
|
||||||
border: 1px solid var(--color-border);
|
|
||||||
border-radius: var(--border-radius-sm);
|
|
||||||
max-width: 32rem;
|
|
||||||
|
|
||||||
input {
|
|
||||||
padding: var(--space-2) var(--space-3);
|
|
||||||
border: 1px solid var(--color-border);
|
border: 1px solid var(--color-border);
|
||||||
border-radius: var(--border-radius-sm);
|
border-radius: var(--border-radius-sm);
|
||||||
background-color: var(--color-bg);
|
|
||||||
color: var(--color-text);
|
input {
|
||||||
|
padding: var(--space-2) var(--space-3);
|
||||||
|
border: 1px solid var(--color-border);
|
||||||
|
border-radius: var(--border-radius-sm);
|
||||||
|
background-color: var(--color-bg);
|
||||||
|
color: var(--color-text);
|
||||||
|
font-size: var(--font-size-sm);
|
||||||
|
font-family: var(--font-mono);
|
||||||
|
|
||||||
|
&:focus {
|
||||||
|
outline: none;
|
||||||
|
border-color: var(--color-accent);
|
||||||
|
}
|
||||||
|
|
||||||
|
&::placeholder {
|
||||||
|
color: var(--color-text-disabled);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
[data-slot="form-actions"] {
|
||||||
|
display: flex;
|
||||||
|
gap: var(--space-2);
|
||||||
|
justify-content: flex-end;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
[data-slot="api-keys-table"] {
|
||||||
|
overflow-x: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
[data-slot="api-keys-table-element"] {
|
||||||
|
width: 100%;
|
||||||
|
border-collapse: collapse;
|
||||||
font-size: var(--font-size-sm);
|
font-size: var(--font-size-sm);
|
||||||
font-family: var(--font-mono);
|
|
||||||
|
|
||||||
&:focus {
|
thead {
|
||||||
outline: none;
|
border-bottom: 1px solid var(--color-border);
|
||||||
border-color: var(--color-accent);
|
|
||||||
}
|
|
||||||
|
|
||||||
&::placeholder {
|
|
||||||
color: var(--color-text-disabled);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
[data-slot="form-actions"] {
|
|
||||||
display: flex;
|
|
||||||
gap: var(--space-2);
|
|
||||||
justify-content: flex-end;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
[data-slot="api-keys-table"] {
|
|
||||||
overflow-x: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
[data-slot="api-keys-table-element"] {
|
|
||||||
width: 100%;
|
|
||||||
border-collapse: collapse;
|
|
||||||
font-size: var(--font-size-sm);
|
|
||||||
|
|
||||||
thead {
|
|
||||||
border-bottom: 1px solid var(--color-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
th {
|
|
||||||
padding: var(--space-3) var(--space-4);
|
|
||||||
text-align: left;
|
|
||||||
font-weight: normal;
|
|
||||||
color: var(--color-text-muted);
|
|
||||||
text-transform: uppercase;
|
|
||||||
}
|
|
||||||
|
|
||||||
td {
|
|
||||||
padding: var(--space-3) var(--space-4);
|
|
||||||
border-bottom: 1px solid var(--color-border-muted);
|
|
||||||
color: var(--color-text-muted);
|
|
||||||
font-family: var(--font-mono);
|
|
||||||
|
|
||||||
&[data-slot="key-name"] {
|
|
||||||
color: var(--color-text);
|
|
||||||
font-family: var(--font-sans);
|
|
||||||
font-weight: 500;
|
|
||||||
}
|
|
||||||
|
|
||||||
&[data-slot="key-value"] {
|
|
||||||
font-family: var(--font-mono);
|
|
||||||
|
|
||||||
div {
|
|
||||||
cursor: pointer;
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
gap: var(--space-2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&[data-slot="key-date"] {
|
|
||||||
color: var(--color-text);
|
|
||||||
}
|
|
||||||
|
|
||||||
&[data-slot="key-actions"] {
|
|
||||||
font-family: var(--font-sans);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
tbody tr {
|
|
||||||
&:last-child td {
|
|
||||||
border-bottom: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: 40rem) {
|
|
||||||
th,
|
|
||||||
td {
|
|
||||||
padding: var(--space-2) var(--space-3);
|
|
||||||
font-size: var(--font-size-xs);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
th {
|
th {
|
||||||
&:nth-child(3) /* Date */ {
|
padding: var(--space-3) var(--space-4);
|
||||||
display: none;
|
text-align: left;
|
||||||
}
|
font-weight: normal;
|
||||||
|
color: var(--color-text-muted);
|
||||||
|
text-transform: uppercase;
|
||||||
}
|
}
|
||||||
|
|
||||||
td {
|
td {
|
||||||
&:nth-child(3) /* Date */ {
|
padding: var(--space-3) var(--space-4);
|
||||||
display: none;
|
border-bottom: 1px solid var(--color-border-muted);
|
||||||
|
color: var(--color-text-muted);
|
||||||
|
font-family: var(--font-mono);
|
||||||
|
|
||||||
|
&[data-slot="key-name"] {
|
||||||
|
color: var(--color-text);
|
||||||
|
font-family: var(--font-sans);
|
||||||
|
font-weight: 500;
|
||||||
|
}
|
||||||
|
|
||||||
|
&[data-slot="key-value"] {
|
||||||
|
font-family: var(--font-mono);
|
||||||
|
|
||||||
|
div {
|
||||||
|
cursor: pointer;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
gap: var(--space-2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&[data-slot="key-date"] {
|
||||||
|
color: var(--color-text);
|
||||||
|
}
|
||||||
|
|
||||||
|
&[data-slot="key-actions"] {
|
||||||
|
font-family: var(--font-sans);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
tbody tr {
|
||||||
|
&:last-child td {
|
||||||
|
border-bottom: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 40rem) {
|
||||||
|
th,
|
||||||
|
td {
|
||||||
|
padding: var(--space-2) var(--space-3);
|
||||||
|
font-size: var(--font-size-xs);
|
||||||
|
}
|
||||||
|
|
||||||
|
th {
|
||||||
|
&:nth-child(3) /* Date */ {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
td {
|
||||||
|
&:nth-child(3) /* Date */ {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/* Balance Section */
|
/* Balance Section */
|
||||||
[data-slot="balance-section"] {
|
[data-slot="balance-section"] {
|
||||||
[data-slot="balance"] {
|
[data-slot="balance"] {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
gap: var(--space-3);
|
gap: var(--space-3);
|
||||||
padding: var(--space-4);
|
padding: var(--space-4);
|
||||||
border: 1px solid var(--color-border);
|
border: 1px solid var(--color-border);
|
||||||
border-radius: var(--border-radius-sm);
|
|
||||||
min-width: 14.5rem;
|
|
||||||
width: fit-content;
|
|
||||||
|
|
||||||
[data-slot="amount"] {
|
|
||||||
padding: var(--space-3-5) var(--space-4);
|
|
||||||
background-color: var(--color-bg-surface);
|
|
||||||
border-radius: var(--border-radius-sm);
|
border-radius: var(--border-radius-sm);
|
||||||
display: flex;
|
min-width: 14.5rem;
|
||||||
align-items: baseline;
|
width: fit-content;
|
||||||
gap: var(--space-1);
|
|
||||||
justify-content: flex-end;
|
[data-slot="amount"] {
|
||||||
|
padding: var(--space-3-5) var(--space-4);
|
||||||
|
background-color: var(--color-bg-surface);
|
||||||
|
border-radius: var(--border-radius-sm);
|
||||||
|
display: flex;
|
||||||
|
align-items: baseline;
|
||||||
|
gap: var(--space-1);
|
||||||
|
justify-content: flex-end;
|
||||||
|
|
||||||
|
&.danger {
|
||||||
|
[data-slot="value"] {
|
||||||
|
color: var(--color-danger);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
[data-slot="currency"] {
|
||||||
|
position: relative;
|
||||||
|
bottom: 2px;
|
||||||
|
font-size: var(--font-size-lg);
|
||||||
|
color: var(--color-text-muted);
|
||||||
|
font-weight: 400;
|
||||||
|
}
|
||||||
|
|
||||||
&.danger {
|
|
||||||
[data-slot="value"] {
|
[data-slot="value"] {
|
||||||
color: var(--color-danger);
|
font-size: var(--font-size-3xl);
|
||||||
|
font-weight: 500;
|
||||||
|
color: var(--color-text);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
[data-slot="currency"] {
|
/* Payments Section */
|
||||||
position: relative;
|
[data-slot="payments-section"] {
|
||||||
bottom: 2px;
|
[data-slot="payments-table"] {
|
||||||
font-size: var(--font-size-lg);
|
overflow-x: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
[data-slot="payments-table-element"] {
|
||||||
|
width: 100%;
|
||||||
|
border-collapse: collapse;
|
||||||
|
font-size: var(--font-size-sm);
|
||||||
|
|
||||||
|
thead {
|
||||||
|
border-bottom: 1px solid var(--color-border);
|
||||||
|
}
|
||||||
|
|
||||||
|
th {
|
||||||
|
padding: var(--space-3) var(--space-4);
|
||||||
|
text-align: left;
|
||||||
|
font-weight: normal;
|
||||||
color: var(--color-text-muted);
|
color: var(--color-text-muted);
|
||||||
font-weight: 400;
|
text-transform: uppercase;
|
||||||
}
|
}
|
||||||
|
|
||||||
[data-slot="value"] {
|
td {
|
||||||
font-size: var(--font-size-3xl);
|
padding: var(--space-3) var(--space-4);
|
||||||
font-weight: 500;
|
border-bottom: 1px solid var(--color-border-muted);
|
||||||
color: var(--color-text);
|
color: var(--color-text-muted);
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Payments Section */
|
|
||||||
[data-slot="payments-section"] {
|
|
||||||
[data-slot="payments-table"] {
|
|
||||||
overflow-x: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
[data-slot="payments-table-element"] {
|
|
||||||
width: 100%;
|
|
||||||
border-collapse: collapse;
|
|
||||||
font-size: var(--font-size-sm);
|
|
||||||
|
|
||||||
thead {
|
|
||||||
border-bottom: 1px solid var(--color-border);
|
|
||||||
}
|
|
||||||
|
|
||||||
th {
|
|
||||||
padding: var(--space-3) var(--space-4);
|
|
||||||
text-align: left;
|
|
||||||
font-weight: normal;
|
|
||||||
color: var(--color-text-muted);
|
|
||||||
text-transform: uppercase;
|
|
||||||
}
|
|
||||||
|
|
||||||
td {
|
|
||||||
padding: var(--space-3) var(--space-4);
|
|
||||||
border-bottom: 1px solid var(--color-border-muted);
|
|
||||||
color: var(--color-text-muted);
|
|
||||||
font-family: var(--font-mono);
|
|
||||||
|
|
||||||
&[data-slot="payment-date"] {
|
|
||||||
color: var(--color-text);
|
|
||||||
}
|
|
||||||
|
|
||||||
&[data-slot="payment-id"] {
|
|
||||||
font-family: var(--font-mono);
|
font-family: var(--font-mono);
|
||||||
font-weight: 400;
|
|
||||||
|
&[data-slot="payment-date"] {
|
||||||
|
color: var(--color-text);
|
||||||
|
}
|
||||||
|
|
||||||
|
&[data-slot="payment-id"] {
|
||||||
|
font-family: var(--font-mono);
|
||||||
|
font-weight: 400;
|
||||||
|
color: var(--color-text-muted);
|
||||||
|
max-width: 200px;
|
||||||
|
word-break: break-word;
|
||||||
|
}
|
||||||
|
|
||||||
|
&[data-slot="payment-amount"] {
|
||||||
|
color: var(--color-text);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
tbody tr {
|
||||||
|
&:last-child td {
|
||||||
|
border-bottom: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 40rem) {
|
||||||
|
th,
|
||||||
|
td {
|
||||||
|
padding: var(--space-2) var(--space-3);
|
||||||
|
font-size: var(--font-size-xs);
|
||||||
|
}
|
||||||
|
|
||||||
|
th {
|
||||||
|
&:nth-child(2) /* Payment ID */ {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
td {
|
||||||
|
&:nth-child(2) /* Payment ID */ {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Usage Section */
|
||||||
|
[data-slot="usage-section"] {
|
||||||
|
[data-slot="usage-table"] {
|
||||||
|
overflow-x: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
[data-slot="usage-table-element"] {
|
||||||
|
width: 100%;
|
||||||
|
border-collapse: collapse;
|
||||||
|
font-size: var(--font-size-sm);
|
||||||
|
|
||||||
|
thead {
|
||||||
|
border-bottom: 1px solid var(--color-border);
|
||||||
|
}
|
||||||
|
|
||||||
|
th {
|
||||||
|
padding: var(--space-3) var(--space-4);
|
||||||
|
text-align: left;
|
||||||
|
font-weight: normal;
|
||||||
color: var(--color-text-muted);
|
color: var(--color-text-muted);
|
||||||
max-width: 200px;
|
text-transform: uppercase;
|
||||||
word-break: break-word;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
&[data-slot="payment-amount"] {
|
|
||||||
color: var(--color-text);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
tbody tr {
|
|
||||||
&:last-child td {
|
|
||||||
border-bottom: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: 40rem) {
|
|
||||||
th,
|
|
||||||
td {
|
td {
|
||||||
padding: var(--space-2) var(--space-3);
|
padding: var(--space-3) var(--space-4);
|
||||||
font-size: var(--font-size-xs);
|
border-bottom: 1px solid var(--color-border-muted);
|
||||||
}
|
color: var(--color-text-muted);
|
||||||
|
font-family: var(--font-mono);
|
||||||
|
|
||||||
th {
|
&[data-slot="usage-date"] {
|
||||||
&:nth-child(2) /* Payment ID */ {
|
color: var(--color-text);
|
||||||
display: none;
|
}
|
||||||
|
|
||||||
|
&[data-slot="usage-model"] {
|
||||||
|
font-family: var(--font-sans);
|
||||||
|
font-weight: 400;
|
||||||
|
color: var(--color-text-secondary);
|
||||||
|
max-width: 200px;
|
||||||
|
word-break: break-word;
|
||||||
|
}
|
||||||
|
|
||||||
|
&[data-slot="usage-cost"] {
|
||||||
|
color: var(--color-text);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
td {
|
tbody tr {
|
||||||
&:nth-child(2) /* Payment ID */ {
|
&:last-child td {
|
||||||
display: none;
|
border-bottom: none;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
@media (max-width: 40rem) {
|
||||||
}
|
th,
|
||||||
|
td {
|
||||||
/* Usage Section */
|
padding: var(--space-2) var(--space-3);
|
||||||
[data-slot="usage-section"] {
|
font-size: var(--font-size-xs);
|
||||||
[data-slot="usage-table"] {
|
}
|
||||||
overflow-x: auto;
|
|
||||||
}
|
th {
|
||||||
|
&:nth-child(2) /* Model */ {
|
||||||
[data-slot="usage-table-element"] {
|
display: none;
|
||||||
width: 100%;
|
}
|
||||||
border-collapse: collapse;
|
}
|
||||||
font-size: var(--font-size-sm);
|
|
||||||
|
td {
|
||||||
thead {
|
&:nth-child(2) /* Model */ {
|
||||||
border-bottom: 1px solid var(--color-border);
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
th {
|
|
||||||
padding: var(--space-3) var(--space-4);
|
|
||||||
text-align: left;
|
|
||||||
font-weight: normal;
|
|
||||||
color: var(--color-text-muted);
|
|
||||||
text-transform: uppercase;
|
|
||||||
}
|
|
||||||
|
|
||||||
td {
|
|
||||||
padding: var(--space-3) var(--space-4);
|
|
||||||
border-bottom: 1px solid var(--color-border-muted);
|
|
||||||
color: var(--color-text-muted);
|
|
||||||
font-family: var(--font-mono);
|
|
||||||
|
|
||||||
&[data-slot="usage-date"] {
|
|
||||||
color: var(--color-text);
|
|
||||||
}
|
|
||||||
|
|
||||||
&[data-slot="usage-model"] {
|
|
||||||
font-family: var(--font-sans);
|
|
||||||
font-weight: 400;
|
|
||||||
color: var(--color-text-secondary);
|
|
||||||
max-width: 200px;
|
|
||||||
word-break: break-word;
|
|
||||||
}
|
|
||||||
|
|
||||||
&[data-slot="usage-cost"] {
|
|
||||||
color: var(--color-text);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
tbody tr {
|
|
||||||
&:last-child td {
|
|
||||||
border-bottom: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: 40rem) {
|
|
||||||
th,
|
|
||||||
td {
|
|
||||||
padding: var(--space-2) var(--space-3);
|
|
||||||
font-size: var(--font-size-xs);
|
|
||||||
}
|
|
||||||
|
|
||||||
th {
|
|
||||||
&:nth-child(2) /* Model */ {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
td {
|
|
||||||
&:nth-child(2) /* Model */ {
|
|
||||||
display: none;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -168,7 +168,7 @@ const dummyApiKeyData = [
|
|||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
|
||||||
export default function () {
|
export default function() {
|
||||||
const actor = createAsync(() => getActor())
|
const actor = createAsync(() => getActor())
|
||||||
onMount(() => {
|
onMount(() => {
|
||||||
console.log("MOUNTED", actor())
|
console.log("MOUNTED", actor())
|
||||||
@@ -292,15 +292,6 @@ export default function () {
|
|||||||
</section>
|
</section>
|
||||||
|
|
||||||
<div data-slot="sections">
|
<div data-slot="sections">
|
||||||
{/* Actor Section */}
|
|
||||||
<section data-slot="actor-section">
|
|
||||||
<div data-slot="section-title">
|
|
||||||
<h2>Actor</h2>
|
|
||||||
<p>Current authenticated user information and session details.</p>
|
|
||||||
</div>
|
|
||||||
<div>{JSON.stringify(actor())}</div>
|
|
||||||
</section>
|
|
||||||
|
|
||||||
{/* API Keys Section */}
|
{/* API Keys Section */}
|
||||||
<section data-slot="api-keys-section">
|
<section data-slot="api-keys-section">
|
||||||
<div data-slot="section-title">
|
<div data-slot="section-title">
|
||||||
@@ -321,14 +312,7 @@ export default function () {
|
|||||||
/>
|
/>
|
||||||
<div data-slot="form-actions">
|
<div data-slot="form-actions">
|
||||||
<button
|
<button
|
||||||
color="primary"
|
data-color="ghost"
|
||||||
disabled={createKeySubmission.pending || !keyName().trim()}
|
|
||||||
onClick={handleCreateKey}
|
|
||||||
>
|
|
||||||
{createKeySubmission.pending ? "Creating..." : "Create"}
|
|
||||||
</button>
|
|
||||||
<button
|
|
||||||
color="ghost"
|
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
setShowCreateForm(false)
|
setShowCreateForm(false)
|
||||||
setKeyName("")
|
setKeyName("")
|
||||||
@@ -336,12 +320,19 @@ export default function () {
|
|||||||
>
|
>
|
||||||
Cancel
|
Cancel
|
||||||
</button>
|
</button>
|
||||||
|
<button
|
||||||
|
data-color="primary"
|
||||||
|
disabled={createKeySubmission.pending || !keyName().trim()}
|
||||||
|
onClick={handleCreateKey}
|
||||||
|
>
|
||||||
|
{createKeySubmission.pending ? "Creating..." : "Create"}
|
||||||
|
</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
>
|
>
|
||||||
<button
|
<button
|
||||||
color="primary"
|
data-color="primary"
|
||||||
onClick={() => {
|
onClick={() => {
|
||||||
console.log("clicked")
|
console.log("clicked")
|
||||||
setShowCreateForm(true)
|
setShowCreateForm(true)
|
||||||
@@ -351,8 +342,9 @@ export default function () {
|
|||||||
</button>
|
</button>
|
||||||
</Show>
|
</Show>
|
||||||
<div data-slot="api-keys-table">
|
<div data-slot="api-keys-table">
|
||||||
|
{/* when={keys()?.length */}
|
||||||
<Show
|
<Show
|
||||||
when={keys()?.length}
|
when={dummyApiKeyData.length > 0}
|
||||||
fallback={
|
fallback={
|
||||||
<div data-slot="empty-state">
|
<div data-slot="empty-state">
|
||||||
<p>Create an opencode Gateway API key</p>
|
<p>Create an opencode Gateway API key</p>
|
||||||
@@ -369,7 +361,7 @@ export default function () {
|
|||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
<For each={keys()!}>
|
<For each={dummyApiKeyData}>
|
||||||
{/* Real data: keys() */}
|
{/* Real data: keys() */}
|
||||||
{(key) => (
|
{(key) => (
|
||||||
<tr>
|
<tr>
|
||||||
@@ -389,7 +381,7 @@ export default function () {
|
|||||||
{formatDateForTable(key.timeCreated)}
|
{formatDateForTable(key.timeCreated)}
|
||||||
</td>
|
</td>
|
||||||
<td data-slot="key-actions">
|
<td data-slot="key-actions">
|
||||||
<button color="ghost" onClick={() => handleDeleteKey(key.id)} title="Delete API key">
|
<button data-color="ghost" onClick={() => handleDeleteKey(key.id)} title="Delete API key">
|
||||||
Delete
|
Delete
|
||||||
</button>
|
</button>
|
||||||
</td>
|
</td>
|
||||||
@@ -426,7 +418,7 @@ export default function () {
|
|||||||
})()}
|
})()}
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<button color="primary" disabled={createCheckoutUrlSubmission.pending} onClick={handleBuyCredits}>
|
<button data-color="primary" disabled={createCheckoutUrlSubmission.pending} onClick={handleBuyCredits}>
|
||||||
{createCheckoutUrlSubmission.pending ? "Loading..." : "Buy Credits"}
|
{createCheckoutUrlSubmission.pending ? "Loading..." : "Buy Credits"}
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
Reference in New Issue
Block a user