- | {addr.index} |
- {addr.path} |
- {addr.address} |
-
+ | {addr.index} |
+ {addr.path} |
+ {addr.address} |
+
{addr.private_key_wif}
|
-
+ |
diff --git a/frontend/src/index.css b/frontend/src/index.css
index bf8ca8b..401a1bc 100644
--- a/frontend/src/index.css
+++ b/frontend/src/index.css
@@ -121,6 +121,7 @@ html, body, #root {
flex: 1;
overflow-y: auto;
padding: 28px 32px;
+ width: 100%;
}
.page-title {
@@ -153,6 +154,14 @@ html, body, #root {
margin-bottom: 14px;
}
+.card-title-row {
+ display: flex;
+ justify-content: space-between;
+ align-items: center;
+ gap: 10px;
+ flex-wrap: wrap;
+}
+
/* ── Form ─────────────────────────────────────────────────────────────────── */
.form-grid {
display: grid;
@@ -161,6 +170,16 @@ html, body, #root {
margin-bottom: 16px;
}
+.save-form-grid {
+ grid-template-columns: 1fr !important;
+}
+
+.viewer-file-columns {
+ display: grid;
+ grid-template-columns: 1fr;
+ gap: 10px;
+}
+
.form-group { display: flex; flex-direction: column; gap: 5px; }
.form-label {
@@ -338,6 +357,7 @@ html, body, #root {
.addr-mono { font-family: var(--mono); }
.addr-index { color: var(--text-xs); font-family: var(--mono); }
.addr-path { color: var(--text-dim); font-family: var(--mono); font-size: 11px; }
+.addr-clip { max-width: 160px; overflow: hidden; text-overflow: ellipsis; }
/* ── Tabs ─────────────────────────────────────────────────────────────────── */
.tabs { display: flex; gap: 4px; margin-bottom: 20px; flex-wrap: wrap; }
@@ -414,3 +434,273 @@ html, body, #root {
text-transform: uppercase;
letter-spacing: 0.06em;
}
+
+.wallet-file-btn {
+ width: 100%;
+ justify-content: space-between;
+ margin-bottom: 6px;
+ text-align: left;
+}
+
+.wallet-file-btn.active {
+ border-color: var(--accent);
+ color: var(--accent);
+}
+
+.wallet-file-name {
+ overflow: hidden;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+}
+
+.wallet-file-meta {
+ font-size: 11px;
+ color: var(--text-xs);
+ flex-shrink: 0;
+}
+
+@media (max-width: 900px) {
+ .main {
+ padding: 20px;
+ }
+
+ .page-title {
+ font-size: 18px;
+ }
+
+ .page-subtitle {
+ margin-bottom: 18px;
+ }
+
+ .card {
+ padding: 16px;
+ margin-bottom: 14px;
+ }
+
+ .form-grid {
+ grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
+ gap: 10px;
+ }
+}
+
+@media (max-width: 768px) {
+ .app {
+ flex-direction: column;
+ height: 100dvh;
+ overflow: hidden;
+ }
+
+ .sidebar {
+ width: 100%;
+ min-width: 0;
+ border-right: none;
+ border-bottom: 1px solid var(--border);
+ overflow: visible;
+ }
+
+ .sidebar-logo {
+ padding: 10px 12px;
+ border-bottom: none;
+ }
+
+ .sidebar-logo svg {
+ width: 24px;
+ height: 24px;
+ }
+
+ .sidebar-logo span {
+ font-size: 12px;
+ }
+
+ .sidebar-nav {
+ flex: none;
+ display: flex;
+ gap: 8px;
+ padding: 8px 12px 10px;
+ overflow-x: auto;
+ overflow-y: hidden;
+ border-top: 1px solid var(--border);
+ }
+
+ .nav-item {
+ width: auto;
+ flex: 0 0 auto;
+ border-radius: 999px;
+ border: 1px solid var(--border);
+ background: var(--panel);
+ font-size: 12px;
+ padding: 7px 12px;
+ }
+
+ .nav-item.active {
+ background: var(--accent);
+ border-color: var(--accent);
+ color: #000;
+ }
+
+ .main {
+ padding: 12px;
+ }
+
+ .page-title {
+ font-size: 18px;
+ margin-bottom: 2px;
+ }
+
+ .page-subtitle {
+ font-size: 12px;
+ margin-bottom: 14px;
+ }
+
+ .card {
+ padding: 14px;
+ margin-bottom: 12px;
+ border-radius: 9px;
+ }
+
+ .card-title {
+ font-size: 11px;
+ margin-bottom: 10px;
+ }
+
+ .form-grid {
+ grid-template-columns: 1fr;
+ gap: 10px;
+ margin-bottom: 12px;
+ }
+
+ .tabs {
+ gap: 6px;
+ margin-bottom: 14px;
+ flex-wrap: nowrap;
+ overflow-x: auto;
+ padding-bottom: 2px;
+ }
+
+ .tab {
+ flex: 0 0 auto;
+ padding: 7px 10px;
+ font-size: 11px;
+ }
+
+ .btn {
+ padding: 9px 14px;
+ }
+
+ .card > .btn-primary,
+ .card > .btn-secondary,
+ .save-actions .btn {
+ width: 100%;
+ justify-content: center;
+ }
+
+ .checkbox-group {
+ align-items: flex-start;
+ padding: 6px 0;
+ }
+
+ .kv-row {
+ flex-direction: column;
+ gap: 6px;
+ padding: 10px 0;
+ }
+
+ .kv-label {
+ min-width: 0;
+ padding-top: 0;
+ font-size: 10px;
+ }
+
+ .kv-actions {
+ align-self: flex-end;
+ }
+
+ .seed-word {
+ padding: 4px 10px;
+ font-size: 12px;
+ }
+
+ .wallet-file-btn {
+ align-items: flex-start;
+ flex-direction: column;
+ gap: 4px;
+ }
+
+ .wallet-file-name {
+ width: 100%;
+ max-width: 100%;
+ }
+
+ .wallet-file-meta {
+ font-size: 10px;
+ }
+
+ .addr-table {
+ border-collapse: separate;
+ border-spacing: 0;
+ font-size: 12px;
+ }
+
+ .addr-table thead {
+ display: none;
+ }
+
+ .addr-table tbody {
+ display: block;
+ }
+
+ .addr-table tr {
+ display: block;
+ margin-bottom: 10px;
+ border: 1px solid var(--border);
+ border-radius: 8px;
+ background: var(--panel);
+ overflow: hidden;
+ }
+
+ .addr-table tr:last-child {
+ margin-bottom: 0;
+ }
+
+ .addr-table td {
+ display: block;
+ padding: 8px 10px;
+ border-bottom: 1px solid var(--border);
+ }
+
+ .addr-table td:last-child {
+ border-bottom: none;
+ }
+
+ .addr-table td::before {
+ content: attr(data-label);
+ display: block;
+ margin-bottom: 4px;
+ color: var(--text-xs);
+ font-size: 10px;
+ font-weight: 600;
+ text-transform: uppercase;
+ letter-spacing: 0.05em;
+ }
+
+ .addr-table td[data-label=""]::before {
+ content: none;
+ }
+
+ .addr-table .addr-clip {
+ max-width: none;
+ overflow: visible;
+ text-overflow: initial;
+ word-break: break-all;
+ }
+
+ .addr-table .addr-mono,
+ .addr-table .addr-path,
+ .addr-table .addr-index {
+ word-break: break-all;
+ }
+
+ .addr-table .addr-actions .btn-row {
+ justify-content: flex-start;
+ }
+}
|