@waiaas/daemon 2.1.4-rc.1 → 2.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@waiaas/daemon",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.2.1",
|
|
4
4
|
"description": "WAIaaS daemon - self-hosted wallet service for AI agents",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"type": "module",
|
|
@@ -44,9 +44,9 @@
|
|
|
44
44
|
"uuidv7": "^1.0.2",
|
|
45
45
|
"viem": "^2.21.0",
|
|
46
46
|
"zod": "^3.24.0",
|
|
47
|
-
"@waiaas/adapter-
|
|
48
|
-
"@waiaas/
|
|
49
|
-
"@waiaas/
|
|
47
|
+
"@waiaas/adapter-solana": "2.2.1",
|
|
48
|
+
"@waiaas/core": "2.2.1",
|
|
49
|
+
"@waiaas/adapter-evm": "2.2.1"
|
|
50
50
|
},
|
|
51
51
|
"devDependencies": {
|
|
52
52
|
"@types/better-sqlite3": "^7.6.0",
|
|
@@ -57,6 +57,7 @@
|
|
|
57
57
|
"msw": "^2.12.10"
|
|
58
58
|
},
|
|
59
59
|
"scripts": {
|
|
60
|
+
"prebuild": "mkdir -p public/admin && cp -r ../admin/dist/* public/admin/ 2>/dev/null || true",
|
|
60
61
|
"build": "tsc -p tsconfig.build.json",
|
|
61
62
|
"test": "vitest run",
|
|
62
63
|
"test:unit": "vitest run",
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-light: #eff6ff;--color-bg: #ffffff;--color-bg-secondary: #f8fafc;--color-bg-tertiary: #f1f5f9;--color-border: #e2e8f0;--color-text: #0f172a;--color-text-secondary: #64748b;--color-text-muted: #94a3b8;--color-success: #16a34a;--color-success-bg: #f0fdf4;--color-warning: #d97706;--color-warning-bg: #fffbeb;--color-danger: #dc2626;--color-danger-bg: #fef2f2;--color-info: #2563eb;--color-info-bg: #eff6ff;--color-tier-instant: #16a34a;--color-tier-delay: #d97706;--color-tier-blocked: #dc2626;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height: 1.5;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--sidebar-width: 220px;--header-height: 56px;--content-max-width: 1200px}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-primary);text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-bg);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:10}.sidebar-brand{padding:var(--space-4) var(--space-4);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary);border-bottom:1px solid var(--color-border)}.sidebar-nav{display:flex;flex-direction:column;padding:var(--space-2);gap:var(--space-1)}.sidebar-link{display:block;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:background .15s,color .15s;text-decoration:none}.sidebar-link:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.sidebar-link.active{background:var(--color-primary-light);color:var(--color-primary)}.main{margin-left:var(--sidebar-width);flex:1;display:flex;flex-direction:column}.header{min-height:var(--header-height);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-6);background:var(--color-bg);position:sticky;top:0;z-index:5}.header-left{display:flex;flex-direction:column;justify-content:center;gap:0}.header-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.header-subtitle{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-normal);margin:0}.btn-logout{padding:var(--space-1) var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:none;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:background .15s,color .15s}.btn-logout:hover{background:var(--color-danger-bg);color:var(--color-danger);border-color:var(--color-danger)}.content{padding:var(--space-6);max-width:var(--content-max-width);width:100%}.page h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-4)}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}table th{text-align:left;padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--color-border);background:var(--color-bg-secondary)}table td{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);border-bottom:1px solid var(--color-border)}table tbody tr:hover{background:var(--color-bg-secondary)}table tbody tr.clickable{cursor:pointer}table .table-empty,table .table-loading{text-align:center;color:var(--color-text-muted);padding:var(--space-8) var(--space-4)}.form-field{margin-bottom:var(--space-4)}.form-field label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);margin-bottom:var(--space-1)}.form-field input,.form-field select,.form-field textarea{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg);color:var(--color-text);outline:none;transition:border-color .15s}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.form-field textarea{min-height:80px;resize:vertical}.form-field .form-error{display:block;font-size:var(--font-size-xs);color:var(--color-danger);margin-top:var(--space-1)}.form-field input[type=checkbox]{width:auto;margin-right:var(--space-2)}.form-field .form-description{display:block;font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--space-1)}.field-group{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-6);margin-bottom:var(--space-4)}.field-group-legend{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);padding:0 var(--space-2)}.field-group-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-3)}.field-group-body{display:flex;flex-direction:column;gap:var(--space-3)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs)}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--color-bg);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-secondary)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-bg-tertiary);color:var(--color-text)}.badge{display:inline-flex;align-items:center;padding:.125rem var(--space-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:9999px}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge-info{background:var(--color-info-bg);color:var(--color-info)}.badge-neutral{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal-card{background:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.modal-body{padding:var(--space-4) var(--space-6)}.modal-footer{padding:var(--space-3) var(--space-6);border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:var(--space-2)}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:200;display:flex;flex-direction:column;gap:var(--space-2);max-width:360px}.toast{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);box-shadow:var(--shadow-md);cursor:pointer;animation:toast-in .2s ease-out}@keyframes toast-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-success{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success)}.toast-error{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger)}.toast-info{background:var(--color-info-bg);color:var(--color-info);border:1px solid var(--color-info)}.toast-warning{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid var(--color-warning)}.empty-state{text-align:center;padding:var(--space-8) var(--space-4);color:var(--color-text-muted)}.empty-state h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.empty-state p{font-size:var(--font-size-sm);margin-bottom:var(--space-4)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.stat-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-6);box-shadow:var(--shadow-sm)}.stat-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text)}.stat-skeleton{height:2rem;background:var(--color-bg-tertiary);border-radius:var(--radius-md);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.dashboard-error{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger);border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:var(--font-size-sm)}.page-actions{display:flex;justify-content:flex-end;margin-bottom:var(--space-4)}.inline-form{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-6);margin-bottom:var(--space-4)}.inline-form-actions{display:flex;gap:var(--space-2);margin-top:var(--space-2)}.back-link{display:inline-block;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4)}.back-link:hover{color:var(--color-primary)}.wallet-detail{margin-top:var(--space-4)}.detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.detail-name{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.detail-grid{display:grid;gap:0}.detail-row{display:flex;padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}.detail-row-label{width:160px;flex-shrink:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.detail-row-value{font-size:var(--font-size-sm);display:flex;align-items:center;gap:var(--space-2);word-break:break-all}.inline-edit{display:flex;align-items:center;gap:var(--space-2)}.inline-edit-input{padding:var(--space-1) var(--space-2);border:1px solid var(--color-primary);border-radius:var(--radius-md);font-size:var(--font-size-base);outline:none}.session-controls{display:flex;align-items:flex-end;gap:var(--space-4);margin-bottom:var(--space-4)}.session-wallet-select{flex:1;max-width:400px}.session-wallet-select label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);margin-bottom:var(--space-1)}.session-wallet-select select{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg);color:var(--color-text);outline:none}.session-wallet-select select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.token-warning{color:var(--color-warning);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);margin-bottom:var(--space-3)}.token-display{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.token-value{flex:1;font-size:var(--font-size-xs);word-break:break-all;font-family:SF Mono,Fira Code,monospace}.policy-controls{display:flex;align-items:flex-end;gap:var(--space-4);margin-bottom:var(--space-4)}.policy-filter-select{flex:1;max-width:400px}.policy-filter-select label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);margin-bottom:var(--space-1)}.policy-filter-select select{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg);color:var(--color-text);outline:none}.policy-filter-select select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.tier-bars{display:flex;flex-direction:column;gap:3px;min-width:180px}.tier-bar{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-xs)}.tier-bar-label{width:52px;flex-shrink:0;font-weight:var(--font-weight-medium)}.tier-bar-track{flex:1;height:6px;background:var(--color-bg-tertiary);border-radius:3px;overflow:hidden}.tier-bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.tier-bar-value{font-size:var(--font-size-xs);color:var(--color-text-secondary);min-width:60px;text-align:right}.tier-bar-fill--instant{background:var(--color-tier-instant)}.tier-bar-fill--notify{background:var(--color-info)}.tier-bar-fill--delay{background:var(--color-tier-delay)}.tier-bar-fill--approval{background:var(--color-tier-blocked)}.spending-limit-summary{display:flex;flex-direction:column;gap:.5rem}.cumulative-limits{display:flex;flex-direction:column;gap:.125rem;padding-top:.25rem;border-top:1px solid var(--color-border)}.cumulative-limits-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:500}.cumulative-limit-row{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-xs)}.cumulative-limit-type{color:var(--color-text-secondary);min-width:72px}.cumulative-limit-value{color:var(--color-warning);font-weight:600}.rules-vis-text{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.rules-vis-badges{display:flex;flex-wrap:wrap;gap:4px}.rules-summary{font-size:var(--font-size-xs);color:var(--color-text-secondary);max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:SF Mono,Fira Code,monospace}.edit-rules-textarea textarea{min-height:120px;font-family:SF Mono,Fira Code,monospace;font-size:var(--font-size-xs)}.policy-type-readonly{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text);padding:var(--space-2) 0;margin-bottom:var(--space-2)}.settings-section{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-4)}.settings-section--danger{border-color:var(--color-danger)}.settings-section-header{margin-bottom:var(--space-4)}.settings-section-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-1)}.settings-description{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.settings-section-body{display:flex;align-items:center;gap:var(--space-4)}.ks-state-card{display:flex;align-items:center;gap:var(--space-4);flex:1}.ks-state-info{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.shutdown-overlay{position:fixed;inset:0;background:#000c;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:300;color:#fff}.shutdown-overlay h2{font-size:var(--font-size-2xl);margin-bottom:var(--space-4);color:#fff}.shutdown-overlay p{font-size:var(--font-size-base);color:var(--color-text-muted)}.shutdown-confirm-input{margin-top:var(--space-3)}.shutdown-confirm-input label{display:block;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-1)}.shutdown-confirm-input input{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg);color:var(--color-text);outline:none}.shutdown-confirm-input input:focus{border-color:var(--color-danger);box-shadow:0 0 0 2px var(--color-danger-bg)}.channel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.channel-card{padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg)}.channel-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.channel-card-name{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);text-transform:capitalize}.test-results{margin-top:var(--space-4)}.test-result-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0}.test-result-success{color:var(--color-success)}.test-result-failure{color:var(--color-danger)}.config-guidance{margin-top:var(--space-6);padding:var(--space-4);background:var(--color-info-bg);border:1px solid var(--color-info);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.config-guidance pre{margin-top:var(--space-2);padding:var(--space-3);background:var(--color-bg-tertiary);border-radius:var(--radius-sm);font-family:monospace;font-size:var(--font-size-xs);overflow-x:auto;white-space:pre}.config-guidance p{color:var(--color-text-secondary);margin-bottom:var(--space-2)}.breadcrumb{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.breadcrumb-page{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:inherit;padding:0;font-family:inherit}.breadcrumb-page:hover{text-decoration:underline}.breadcrumb-separator{color:var(--color-text-muted)}.breadcrumb-current{color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.tab-nav{display:flex;gap:var(--space-1);border-bottom:1px solid var(--color-border)}.tab-btn{padding:var(--space-2) var(--space-4);background:none;border:none;border-bottom:2px solid transparent;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--color-text)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-4)}.pagination-info{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.pagination-buttons{display:flex;gap:var(--space-2)}.notif-disabled-banner{padding:var(--space-3) var(--space-4);background:var(--color-warning-bg);border:1px solid var(--color-warning);border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:var(--font-size-sm);color:var(--color-text)}.settings-save-bar{position:sticky;top:var(--header-height);z-index:4;display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--color-warning-bg);border:1px solid var(--color-warning);border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:var(--font-size-sm);color:var(--color-text)}.settings-save-bar-actions{display:flex;gap:var(--space-2)}.settings-category{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-4);overflow:hidden}.settings-category-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border)}.settings-category-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-1)}.settings-category-body{padding:var(--space-4) var(--space-6)}.settings-fields-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.settings-fields-grid .form-field{margin-bottom:0}.settings-field-full{grid-column:1 / -1}.settings-subgroup{margin-bottom:var(--space-4)}.settings-subgroup-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border)}.rpc-field-row{display:flex;gap:var(--space-2);align-items:flex-end}.rpc-field-row .form-field{flex:1;margin-bottom:0}.rpc-test-result{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);margin-top:var(--space-1)}.rpc-test-result--success{color:var(--color-success)}.rpc-test-result--failure{color:var(--color-danger)}.settings-info-box{padding:var(--space-3) var(--space-4);background:var(--color-info-bg);border:1px solid var(--color-info);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-3)}.settings-info-box a{color:var(--color-primary);text-decoration:underline}.notif-test-section{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border)}.settings-category-actions{display:flex;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--color-border)}.dynamic-row-list{display:flex;flex-direction:column;gap:var(--space-2)}.dynamic-row{display:flex;align-items:flex-start;gap:var(--space-2)}.dynamic-row-fields{flex:1;display:flex;gap:var(--space-2);align-items:flex-start}.dynamic-row-fields .form-field{flex:1;margin-bottom:0}.dynamic-row-remove{flex-shrink:0;margin-top:var(--space-6);color:var(--color-danger)}.policy-form-section{margin-bottom:var(--space-4)}.policy-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.policy-form-header label{font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm)}.json-toggle{font-size:var(--font-size-xs)}.policy-form-placeholder{color:var(--color-text-secondary);font-size:var(--font-size-sm);padding:var(--space-4);border:1px dashed var(--color-border);border-radius:var(--radius-md);text-align:center}.policy-form-fields{display:flex;flex-direction:column;gap:var(--space-3)}.policy-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.policy-form-grid .form-field{margin-bottom:0}.currency-select{position:relative}.currency-select-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);cursor:pointer;font-size:var(--font-size-sm);font-family:var(--font-family);color:var(--color-text)}.currency-select-trigger:hover{border-color:var(--color-primary)}.currency-select-chevron{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.currency-rate-preview{margin-top:var(--space-1);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.currency-select-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);box-shadow:0 4px 12px #0000001a;margin-top:var(--space-1)}.currency-select-search{width:100%;padding:var(--space-2) var(--space-3);border:none;border-bottom:1px solid var(--color-border);outline:none;font-size:var(--font-size-sm);font-family:var(--font-family)}.currency-select-list{max-height:300px;overflow-y:auto}.currency-select-option{width:100%;display:flex;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:none;background:none;cursor:pointer;text-align:left;font-size:var(--font-size-sm);font-family:var(--font-family);color:var(--color-text)}.currency-select-option:hover{background:var(--color-bg-secondary)}.currency-select-option--active{background:var(--color-primary-light);font-weight:var(--font-weight-semibold)}.currency-option-code{font-weight:var(--font-weight-semibold);min-width:3rem}.currency-option-name{flex:1}.currency-option-symbol{color:var(--color-text-secondary)}.currency-select-empty{padding:var(--space-3);text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.search-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-start;justify-content:center;padding-top:15vh;z-index:100}.search-popover{background:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:60vh;overflow:hidden;display:flex;flex-direction:column}.search-input-wrapper{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border)}.search-input{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);outline:none;background:var(--color-bg);color:var(--color-text)}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.search-results{overflow-y:auto;flex:1}.search-result-item{display:block;width:100%;padding:var(--space-3) var(--space-4);border:none;border-bottom:1px solid var(--color-border);background:none;text-align:left;cursor:pointer;font-family:inherit;color:var(--color-text)}.search-result-item:hover,.search-result-item.selected{background:var(--color-bg-secondary)}.search-result-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-bottom:2px}.search-result-desc{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result-path{font-size:var(--font-size-xs);color:var(--color-text-muted)}.search-empty{padding:var(--space-6) var(--space-4);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.search-hint{padding:var(--space-2) var(--space-4);font-size:var(--font-size-xs);color:var(--color-text-muted);border-top:1px solid var(--color-border);display:flex;gap:var(--space-4)}.search-hint kbd{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:0 var(--space-1);font-size:var(--font-size-xs);font-family:inherit}.header-actions{display:flex;align-items:center;gap:var(--space-2)}.btn-search{padding:var(--space-1) var(--space-2);font-size:var(--font-size-base);background:none;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-secondary);transition:background .15s,color .15s;line-height:1}.btn-search:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.form-field--highlight{animation:field-highlight 2s ease-out;border-radius:var(--radius-md)}@keyframes field-highlight{0%{background:var(--color-primary-light);box-shadow:0 0 0 2px var(--color-primary)}to{background:transparent;box-shadow:none}}.unsaved-dialog-footer{justify-content:flex-end;gap:var(--space-2)}@media(max-width:768px){.channel-grid,.settings-fields-grid{grid-template-columns:1fr}}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var rt,$,pa,fa,ye,Vt,_a,ya,ga,Wt,Ct,It,$e={},ba=[],za=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i,ot=Array.isArray;function ce(a,t){for(var n in t)a[n]=t[n];return a}function Mt(a){a&&a.parentNode&&a.parentNode.removeChild(a)}function Ga(a,t,n){var l,i,s,r={};for(s in t)s=="key"?l=t[s]:s=="ref"?i=t[s]:r[s]=t[s];if(arguments.length>2&&(r.children=arguments.length>3?rt.call(arguments,2):n),typeof a=="function"&&a.defaultProps!=null)for(s in a.defaultProps)r[s]===void 0&&(r[s]=a.defaultProps[s]);return tt(a,r,l,i,null)}function tt(a,t,n,l,i){var s={type:a,props:t,key:n,ref:l,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:i??++pa,__i:-1,__u:0};return i==null&&$.vnode!=null&&$.vnode(s),s}function V(a){return a.children}function Pe(a,t){this.props=a,this.context=t}function Ae(a,t){if(t==null)return a.__?Ae(a.__,a.__i+1):null;for(var n;t<a.__k.length;t++)if((n=a.__k[t])!=null&&n.__e!=null)return n.__e;return typeof a.type=="function"?Ae(a):null}function wa(a){var t,n;if((a=a.__)!=null&&a.__c!=null){for(a.__e=a.__c.base=null,t=0;t<a.__k.length;t++)if((n=a.__k[t])!=null&&n.__e!=null){a.__e=a.__c.base=n.__e;break}return wa(a)}}function qt(a){(!a.__d&&(a.__d=!0)&&ye.push(a)&&!nt.__r++||Vt!=$.debounceRendering)&&((Vt=$.debounceRendering)||_a)(nt)}function nt(){for(var a,t,n,l,i,s,r,c=1;ye.length;)ye.length>c&&ye.sort(ya),a=ye.shift(),c=ye.length,a.__d&&(n=void 0,l=void 0,i=(l=(t=a).__v).__e,s=[],r=[],t.__P&&((n=ce({},l)).__v=l.__v+1,$.vnode&&$.vnode(n),Ut(t.__P,n,l,t.__n,t.__P.namespaceURI,32&l.__u?[i]:null,s,i??Ae(l),!!(32&l.__u),r),n.__v=l.__v,n.__.__k[n.__i]=n,ka(s,n,r),l.__e=l.__=null,n.__e!=i&&wa(n)));nt.__r=0}function Sa(a,t,n,l,i,s,r,c,m,o,u){var d,p,h,k,C,w,_,I=l&&l.__k||ba,B=t.length;for(m=ja(n,t,I,m,B),d=0;d<B;d++)(h=n.__k[d])!=null&&(p=h.__i==-1?$e:I[h.__i]||$e,h.__i=d,w=Ut(a,h,p,i,s,r,c,m,o,u),k=h.__e,h.ref&&p.ref!=h.ref&&(p.ref&&$t(p.ref,null,h),u.push(h.ref,h.__c||k,h)),C==null&&k!=null&&(C=k),(_=!!(4&h.__u))||p.__k===h.__k?m=Na(h,m,a,_):typeof h.type=="function"&&w!==void 0?m=w:k&&(m=k.nextSibling),h.__u&=-7);return n.__e=C,m}function ja(a,t,n,l,i){var s,r,c,m,o,u=n.length,d=u,p=0;for(a.__k=new Array(i),s=0;s<i;s++)(r=t[s])!=null&&typeof r!="boolean"&&typeof r!="function"?(typeof r=="string"||typeof r=="number"||typeof r=="bigint"||r.constructor==String?r=a.__k[s]=tt(null,r,null,null,null):ot(r)?r=a.__k[s]=tt(V,{children:r},null,null,null):r.constructor===void 0&&r.__b>0?r=a.__k[s]=tt(r.type,r.props,r.key,r.ref?r.ref:null,r.__v):a.__k[s]=r,m=s+p,r.__=a,r.__b=a.__b+1,c=null,(o=r.__i=Ya(r,n,m,d))!=-1&&(d--,(c=n[o])&&(c.__u|=2)),c==null||c.__v==null?(o==-1&&(i>u?p--:i<u&&p++),typeof r.type!="function"&&(r.__u|=4)):o!=m&&(o==m-1?p--:o==m+1?p++:(o>m?p--:p++,r.__u|=4))):a.__k[s]=null;if(d)for(s=0;s<u;s++)(c=n[s])!=null&&(2&c.__u)==0&&(c.__e==l&&(l=Ae(c)),Ea(c,c));return l}function Na(a,t,n,l){var i,s;if(typeof a.type=="function"){for(i=a.__k,s=0;i&&s<i.length;s++)i[s]&&(i[s].__=a,t=Na(i[s],t,n,l));return t}a.__e!=t&&(l&&(t&&a.type&&!t.parentNode&&(t=Ae(a)),n.insertBefore(a.__e,t||null)),t=a.__e);do t=t&&t.nextSibling;while(t!=null&&t.nodeType==8);return t}function Ya(a,t,n,l){var i,s,r,c=a.key,m=a.type,o=t[n],u=o!=null&&(2&o.__u)==0;if(o===null&&c==null||u&&c==o.key&&m==o.type)return n;if(l>(u?1:0)){for(i=n-1,s=n+1;i>=0||s<t.length;)if((o=t[r=i>=0?i--:s++])!=null&&(2&o.__u)==0&&c==o.key&&m==o.type)return r}return-1}function zt(a,t,n){t[0]=="-"?a.setProperty(t,n??""):a[t]=n==null?"":typeof n!="number"||za.test(t)?n:n+"px"}function je(a,t,n,l,i){var s,r;e:if(t=="style")if(typeof n=="string")a.style.cssText=n;else{if(typeof l=="string"&&(a.style.cssText=l=""),l)for(t in l)n&&t in n||zt(a.style,t,"");if(n)for(t in n)l&&n[t]==l[t]||zt(a.style,t,n[t])}else if(t[0]=="o"&&t[1]=="n")s=t!=(t=t.replace(ga,"$1")),r=t.toLowerCase(),t=r in a||t=="onFocusOut"||t=="onFocusIn"?r.slice(2):t.slice(2),a.l||(a.l={}),a.l[t+s]=n,n?l?n.u=l.u:(n.u=Wt,a.addEventListener(t,s?It:Ct,s)):a.removeEventListener(t,s?It:Ct,s);else{if(i=="http://www.w3.org/2000/svg")t=t.replace(/xlink(H|:h)/,"h").replace(/sName$/,"s");else if(t!="width"&&t!="height"&&t!="href"&&t!="list"&&t!="form"&&t!="tabIndex"&&t!="download"&&t!="rowSpan"&&t!="colSpan"&&t!="role"&&t!="popover"&&t in a)try{a[t]=n??"";break e}catch{}typeof n=="function"||(n==null||n===!1&&t[4]!="-"?a.removeAttribute(t):a.setAttribute(t,t=="popover"&&n==1?"":n))}}function Gt(a){return function(t){if(this.l){var n=this.l[t.type+a];if(t.t==null)t.t=Wt++;else if(t.t<n.u)return;return n($.event?$.event(t):t)}}}function Ut(a,t,n,l,i,s,r,c,m,o){var u,d,p,h,k,C,w,_,I,B,F,N,O,P,G,q,Q,j=t.type;if(t.constructor!==void 0)return null;128&n.__u&&(m=!!(32&n.__u),s=[c=t.__e=n.__e]),(u=$.__b)&&u(t);e:if(typeof j=="function")try{if(_=t.props,I="prototype"in j&&j.prototype.render,B=(u=j.contextType)&&l[u.__c],F=u?B?B.props.value:u.__:l,n.__c?w=(d=t.__c=n.__c).__=d.__E:(I?t.__c=d=new j(_,F):(t.__c=d=new Pe(_,F),d.constructor=j,d.render=Xa),B&&B.sub(d),d.state||(d.state={}),d.__n=l,p=d.__d=!0,d.__h=[],d._sb=[]),I&&d.__s==null&&(d.__s=d.state),I&&j.getDerivedStateFromProps!=null&&(d.__s==d.state&&(d.__s=ce({},d.__s)),ce(d.__s,j.getDerivedStateFromProps(_,d.__s))),h=d.props,k=d.state,d.__v=t,p)I&&j.getDerivedStateFromProps==null&&d.componentWillMount!=null&&d.componentWillMount(),I&&d.componentDidMount!=null&&d.__h.push(d.componentDidMount);else{if(I&&j.getDerivedStateFromProps==null&&_!==h&&d.componentWillReceiveProps!=null&&d.componentWillReceiveProps(_,F),t.__v==n.__v||!d.__e&&d.shouldComponentUpdate!=null&&d.shouldComponentUpdate(_,d.__s,F)===!1){for(t.__v!=n.__v&&(d.props=_,d.state=d.__s,d.__d=!1),t.__e=n.__e,t.__k=n.__k,t.__k.some(function(T){T&&(T.__=t)}),N=0;N<d._sb.length;N++)d.__h.push(d._sb[N]);d._sb=[],d.__h.length&&r.push(d);break e}d.componentWillUpdate!=null&&d.componentWillUpdate(_,d.__s,F),I&&d.componentDidUpdate!=null&&d.__h.push(function(){d.componentDidUpdate(h,k,C)})}if(d.context=F,d.props=_,d.__P=a,d.__e=!1,O=$.__r,P=0,I){for(d.state=d.__s,d.__d=!1,O&&O(t),u=d.render(d.props,d.state,d.context),G=0;G<d._sb.length;G++)d.__h.push(d._sb[G]);d._sb=[]}else do d.__d=!1,O&&O(t),u=d.render(d.props,d.state,d.context),d.state=d.__s;while(d.__d&&++P<25);d.state=d.__s,d.getChildContext!=null&&(l=ce(ce({},l),d.getChildContext())),I&&!p&&d.getSnapshotBeforeUpdate!=null&&(C=d.getSnapshotBeforeUpdate(h,k)),q=u,u!=null&&u.type===V&&u.key==null&&(q=Ta(u.props.children)),c=Sa(a,ot(q)?q:[q],t,n,l,i,s,r,c,m,o),d.base=t.__e,t.__u&=-161,d.__h.length&&r.push(d),w&&(d.__E=d.__=null)}catch(T){if(t.__v=null,m||s!=null)if(T.then){for(t.__u|=m?160:128;c&&c.nodeType==8&&c.nextSibling;)c=c.nextSibling;s[s.indexOf(c)]=null,t.__e=c}else{for(Q=s.length;Q--;)Mt(s[Q]);Dt(t)}else t.__e=n.__e,t.__k=n.__k,T.then||Dt(t);$.__e(T,t,n)}else s==null&&t.__v==n.__v?(t.__k=n.__k,t.__e=n.__e):c=t.__e=Ja(n.__e,t,n,l,i,s,r,m,o);return(u=$.diffed)&&u(t),128&t.__u?void 0:c}function Dt(a){a&&a.__c&&(a.__c.__e=!0),a&&a.__k&&a.__k.forEach(Dt)}function ka(a,t,n){for(var l=0;l<n.length;l++)$t(n[l],n[++l],n[++l]);$.__c&&$.__c(t,a),a.some(function(i){try{a=i.__h,i.__h=[],a.some(function(s){s.call(i)})}catch(s){$.__e(s,i.__v)}})}function Ta(a){return typeof a!="object"||a==null||a.__b&&a.__b>0?a:ot(a)?a.map(Ta):ce({},a)}function Ja(a,t,n,l,i,s,r,c,m){var o,u,d,p,h,k,C,w=n.props||$e,_=t.props,I=t.type;if(I=="svg"?i="http://www.w3.org/2000/svg":I=="math"?i="http://www.w3.org/1998/Math/MathML":i||(i="http://www.w3.org/1999/xhtml"),s!=null){for(o=0;o<s.length;o++)if((h=s[o])&&"setAttribute"in h==!!I&&(I?h.localName==I:h.nodeType==3)){a=h,s[o]=null;break}}if(a==null){if(I==null)return document.createTextNode(_);a=document.createElementNS(i,I,_.is&&_),c&&($.__m&&$.__m(t,s),c=!1),s=null}if(I==null)w===_||c&&a.data==_||(a.data=_);else{if(s=s&&rt.call(a.childNodes),!c&&s!=null)for(w={},o=0;o<a.attributes.length;o++)w[(h=a.attributes[o]).name]=h.value;for(o in w)if(h=w[o],o!="children"){if(o=="dangerouslySetInnerHTML")d=h;else if(!(o in _)){if(o=="value"&&"defaultValue"in _||o=="checked"&&"defaultChecked"in _)continue;je(a,o,null,h,i)}}for(o in _)h=_[o],o=="children"?p=h:o=="dangerouslySetInnerHTML"?u=h:o=="value"?k=h:o=="checked"?C=h:c&&typeof h!="function"||w[o]===h||je(a,o,h,w[o],i);if(u)c||d&&(u.__html==d.__html||u.__html==a.innerHTML)||(a.innerHTML=u.__html),t.__k=[];else if(d&&(a.innerHTML=""),Sa(t.type=="template"?a.content:a,ot(p)?p:[p],t,n,l,I=="foreignObject"?"http://www.w3.org/1999/xhtml":i,s,r,s?s[0]:n.__k&&Ae(n,0),c,m),s!=null)for(o=s.length;o--;)Mt(s[o]);c||(o="value",I=="progress"&&k==null?a.removeAttribute("value"):k!=null&&(k!==a[o]||I=="progress"&&!k||I=="option"&&k!=w[o])&&je(a,o,k,w[o],i),o="checked",C!=null&&C!=a[o]&&je(a,o,C,w[o],i))}return a}function $t(a,t,n){try{if(typeof a=="function"){var l=typeof a.__u=="function";l&&a.__u(),l&&t==null||(a.__u=a(t))}else a.current=t}catch(i){$.__e(i,n)}}function Ea(a,t,n){var l,i;if($.unmount&&$.unmount(a),(l=a.ref)&&(l.current&&l.current!=a.__e||$t(l,null,t)),(l=a.__c)!=null){if(l.componentWillUnmount)try{l.componentWillUnmount()}catch(s){$.__e(s,t)}l.base=l.__P=null}if(l=a.__k)for(i=0;i<l.length;i++)l[i]&&Ea(l[i],t,n||typeof a.type!="function");n||Mt(a.__e),a.__c=a.__=a.__e=void 0}function Xa(a,t,n){return this.constructor(a,n)}function Za(a,t,n){var l,i,s,r;t==document&&(t=document.documentElement),$.__&&$.__(a,t),i=(l=!1)?null:t.__k,s=[],r=[],Ut(t,a=t.__k=Ga(V,null,[a]),i||$e,$e,t.namespaceURI,i?null:t.firstChild?rt.call(t.childNodes):null,s,i?i.__e:t.firstChild,l,r),ka(s,a,r)}rt=ba.slice,$={__e:function(a,t,n,l){for(var i,s,r;t=t.__;)if((i=t.__c)&&!i.__)try{if((s=i.constructor)&&s.getDerivedStateFromError!=null&&(i.setState(s.getDerivedStateFromError(a)),r=i.__d),i.componentDidCatch!=null&&(i.componentDidCatch(a,l||{}),r=i.__d),r)return i.__E=i}catch(c){a=c}throw a}},pa=0,fa=function(a){return a!=null&&a.constructor===void 0},Pe.prototype.setState=function(a,t){var n;n=this.__s!=null&&this.__s!=this.state?this.__s:this.__s=ce({},this.state),typeof a=="function"&&(a=a(ce({},n),this.props)),a&&ce(n,a),a!=null&&this.__v&&(t&&this._sb.push(t),qt(this))},Pe.prototype.forceUpdate=function(a){this.__v&&(this.__e=!0,a&&this.__h.push(a),qt(this))},Pe.prototype.render=V,ye=[],_a=typeof Promise=="function"?Promise.prototype.then.bind(Promise.resolve()):setTimeout,ya=function(a,t){return a.__v.__b-t.__v.__b},nt.__r=0,ga=/(PointerCapture)$|Capture$/i,Wt=0,Ct=Gt(!1),It=Gt(!0);var Qa=0;function e(a,t,n,l,i,s){t||(t={});var r,c,m=t;if("ref"in m)for(c in m={},t)c=="ref"?r=t[c]:m[c]=t[c];var o={type:a,props:m,key:n,ref:r,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:--Qa,__i:-1,__u:0,__source:i,__self:s};if(typeof a=="function"&&(r=a.defaultProps))for(c in r)m[c]===void 0&&(m[c]=r[c]);return $.vnode&&$.vnode(o),o}var lt,ae,wt,jt,Lt=0,Aa=[],z=$,Yt=z.__b,Jt=z.__r,Xt=z.diffed,Zt=z.__c,Qt=z.unmount,ea=z.__;function Ca(a,t){z.__h&&z.__h(ae,a,Lt||t),Lt=0;var n=ae.__H||(ae.__H={__:[],__h:[]});return a>=n.__.length&&n.__.push({}),n.__[a]}function L(a,t){var n=Ca(lt++,3);!z.__s&&Ia(n.__H,t)&&(n.__=a,n.u=t,ae.__H.__h.push(n))}function Kt(a){return Lt=5,ct(function(){return{current:a}},[])}function ct(a,t){var n=Ca(lt++,7);return Ia(n.__H,t)&&(n.__=a(),n.__H=t,n.__h=a),n.__}function en(){for(var a;a=Aa.shift();)if(a.__P&&a.__H)try{a.__H.__h.forEach(at),a.__H.__h.forEach(Ot),a.__H.__h=[]}catch(t){a.__H.__h=[],z.__e(t,a.__v)}}z.__b=function(a){ae=null,Yt&&Yt(a)},z.__=function(a,t){a&&t.__k&&t.__k.__m&&(a.__m=t.__k.__m),ea&&ea(a,t)},z.__r=function(a){Jt&&Jt(a),lt=0;var t=(ae=a.__c).__H;t&&(wt===ae?(t.__h=[],ae.__h=[],t.__.forEach(function(n){n.__N&&(n.__=n.__N),n.u=n.__N=void 0})):(t.__h.forEach(at),t.__h.forEach(Ot),t.__h=[],lt=0)),wt=ae},z.diffed=function(a){Xt&&Xt(a);var t=a.__c;t&&t.__H&&(t.__H.__h.length&&(Aa.push(t)!==1&&jt===z.requestAnimationFrame||((jt=z.requestAnimationFrame)||tn)(en)),t.__H.__.forEach(function(n){n.u&&(n.__H=n.u),n.u=void 0})),wt=ae=null},z.__c=function(a,t){t.some(function(n){try{n.__h.forEach(at),n.__h=n.__h.filter(function(l){return!l.__||Ot(l)})}catch(l){t.some(function(i){i.__h&&(i.__h=[])}),t=[],z.__e(l,n.__v)}}),Zt&&Zt(a,t)},z.unmount=function(a){Qt&&Qt(a);var t,n=a.__c;n&&n.__H&&(n.__H.__.forEach(function(l){try{at(l)}catch(i){t=i}}),n.__H=void 0,t&&z.__e(t,n.__v))};var ta=typeof requestAnimationFrame=="function";function tn(a){var t,n=function(){clearTimeout(l),ta&&cancelAnimationFrame(t),setTimeout(a)},l=setTimeout(n,35);ta&&(t=requestAnimationFrame(n))}function at(a){var t=ae,n=a.__c;typeof n=="function"&&(a.__c=void 0,n()),ae=t}function Ot(a){var t=ae;a.__c=a.__(),ae=t}function Ia(a,t){return!a||a.length!==t.length||t.some(function(n,l){return n!==a[l]})}var an=Symbol.for("preact-signals");function dt(){if(he>1)he--;else{for(var a,t=!1;We!==void 0;){var n=We;for(We=void 0,Rt++;n!==void 0;){var l=n.o;if(n.o=void 0,n.f&=-3,!(8&n.f)&&Oa(n))try{n.c()}catch(i){t||(a=i,t=!0)}n=l}}if(Rt=0,he--,t)throw a}}function nn(a){if(he>0)return a();he++;try{return a()}finally{dt()}}var U=void 0;function Da(a){var t=U;U=void 0;try{return a()}finally{U=t}}var We=void 0,he=0,Rt=0,it=0;function La(a){if(U!==void 0){var t=a.n;if(t===void 0||t.t!==U)return t={i:0,S:a,p:U.s,n:void 0,t:U,e:void 0,x:void 0,r:t},U.s!==void 0&&(U.s.n=t),U.s=t,a.n=t,32&U.f&&a.S(t),t;if(t.i===-1)return t.i=0,t.n!==void 0&&(t.n.p=t.p,t.p!==void 0&&(t.p.n=t.n),t.p=U.s,t.n=void 0,U.s.n=t,U.s=t),t}}function Z(a,t){this.v=a,this.i=0,this.n=void 0,this.t=void 0,this.W=t?.watched,this.Z=t?.unwatched,this.name=t?.name}Z.prototype.brand=an;Z.prototype.h=function(){return!0};Z.prototype.S=function(a){var t=this,n=this.t;n!==a&&a.e===void 0&&(a.x=n,this.t=a,n!==void 0?n.e=a:Da(function(){var l;(l=t.W)==null||l.call(t)}))};Z.prototype.U=function(a){var t=this;if(this.t!==void 0){var n=a.e,l=a.x;n!==void 0&&(n.x=l,a.e=void 0),l!==void 0&&(l.e=n,a.x=void 0),a===this.t&&(this.t=l,l===void 0&&Da(function(){var i;(i=t.Z)==null||i.call(t)}))}};Z.prototype.subscribe=function(a){var t=this;return Be(function(){var n=t.value,l=U;U=void 0;try{a(n)}finally{U=l}},{name:"sub"})};Z.prototype.valueOf=function(){return this.value};Z.prototype.toString=function(){return this.value+""};Z.prototype.toJSON=function(){return this.value};Z.prototype.peek=function(){var a=U;U=void 0;try{return this.value}finally{U=a}};Object.defineProperty(Z.prototype,"value",{get:function(){var a=La(this);return a!==void 0&&(a.i=this.i),this.v},set:function(a){if(a!==this.v){if(Rt>100)throw new Error("Cycle detected");this.v=a,this.i++,it++,he++;try{for(var t=this.t;t!==void 0;t=t.x)t.t.N()}finally{dt()}}}});function ee(a,t){return new Z(a,t)}function Oa(a){for(var t=a.s;t!==void 0;t=t.n)if(t.S.i!==t.i||!t.S.h()||t.S.i!==t.i)return!0;return!1}function Ra(a){for(var t=a.s;t!==void 0;t=t.n){var n=t.S.n;if(n!==void 0&&(t.r=n),t.S.n=t,t.i=-1,t.n===void 0){a.s=t;break}}}function xa(a){for(var t=a.s,n=void 0;t!==void 0;){var l=t.p;t.i===-1?(t.S.U(t),l!==void 0&&(l.n=t.n),t.n!==void 0&&(t.n.p=l)):n=t,t.S.n=t.r,t.r!==void 0&&(t.r=void 0),t=l}a.s=n}function be(a,t){Z.call(this,void 0),this.x=a,this.s=void 0,this.g=it-1,this.f=4,this.W=t?.watched,this.Z=t?.unwatched,this.name=t?.name}be.prototype=new Z;be.prototype.h=function(){if(this.f&=-3,1&this.f)return!1;if((36&this.f)==32||(this.f&=-5,this.g===it))return!0;if(this.g=it,this.f|=1,this.i>0&&!Oa(this))return this.f&=-2,!0;var a=U;try{Ra(this),U=this;var t=this.x();(16&this.f||this.v!==t||this.i===0)&&(this.v=t,this.f&=-17,this.i++)}catch(n){this.v=n,this.f|=16,this.i++}return U=a,xa(this),this.f&=-2,!0};be.prototype.S=function(a){if(this.t===void 0){this.f|=36;for(var t=this.s;t!==void 0;t=t.n)t.S.S(t)}Z.prototype.S.call(this,a)};be.prototype.U=function(a){if(this.t!==void 0&&(Z.prototype.U.call(this,a),this.t===void 0)){this.f&=-33;for(var t=this.s;t!==void 0;t=t.n)t.S.U(t)}};be.prototype.N=function(){if(!(2&this.f)){this.f|=6;for(var a=this.t;a!==void 0;a=a.x)a.t.N()}};Object.defineProperty(be.prototype,"value",{get:function(){if(1&this.f)throw new Error("Cycle detected");var a=La(this);if(this.h(),a!==void 0&&(a.i=this.i),16&this.f)throw this.v;return this.v}});function Ke(a,t){return new be(a,t)}function Pa(a){var t=a.u;if(a.u=void 0,typeof t=="function"){he++;var n=U;U=void 0;try{t()}catch(l){throw a.f&=-2,a.f|=8,Ft(a),l}finally{U=n,dt()}}}function Ft(a){for(var t=a.s;t!==void 0;t=t.n)t.S.U(t);a.x=void 0,a.s=void 0,Pa(a)}function ln(a){if(U!==this)throw new Error("Out-of-order effect");xa(this),U=a,this.f&=-2,8&this.f&&Ft(this),dt()}function De(a,t){this.x=a,this.u=void 0,this.s=void 0,this.o=void 0,this.f=32,this.name=t?.name}De.prototype.c=function(){var a=this.S();try{if(8&this.f||this.x===void 0)return;var t=this.x();typeof t=="function"&&(this.u=t)}finally{a()}};De.prototype.S=function(){if(1&this.f)throw new Error("Cycle detected");this.f|=1,this.f&=-9,Pa(this),Ra(this),he++;var a=U;return U=this,ln.bind(this,a)};De.prototype.N=function(){2&this.f||(this.f|=2,this.o=We,We=this)};De.prototype.d=function(){this.f|=8,1&this.f||Ft(this)};De.prototype.dispose=function(){this.d()};function Be(a,t){var n=new De(a,t);try{n.c()}catch(i){throw n.d(),i}var l=n.d.bind(n);return l[Symbol.dispose]=l,l}var Wa,ut,Ye,sn=typeof window<"u"&&!!window.__PREACT_SIGNALS_DEVTOOLS__,Ma=[];Be(function(){Wa=this.N})();function Le(a,t){$[a]=t.bind(null,$[a]||function(){})}function st(a){if(Ye){var t=Ye;Ye=void 0,t()}Ye=a&&a.S()}function Ua(a){var t=this,n=a.data,l=v(n);l.value=n;var i=ct(function(){for(var c=t,m=t.__v;m=m.__;)if(m.__c){m.__c.__$f|=4;break}var o=Ke(function(){var h=l.value.value;return h===0?0:h===!0?"":h||""}),u=Ke(function(){return!Array.isArray(o.value)&&!fa(o.value)}),d=Be(function(){if(this.N=$a,u.value){var h=o.value;c.__v&&c.__v.__e&&c.__v.__e.nodeType===3&&(c.__v.__e.data=h)}}),p=t.__$u.d;return t.__$u.d=function(){d(),p.call(this)},[u,o]},[]),s=i[0],r=i[1];return s.value?r.peek():r.value}Ua.displayName="ReactiveTextNode";Object.defineProperties(Z.prototype,{constructor:{configurable:!0,value:void 0},type:{configurable:!0,value:Ua},props:{configurable:!0,get:function(){return{data:this}}},__b:{configurable:!0,value:1}});Le("__b",function(a,t){if(typeof t.type=="string"){var n,l=t.props;for(var i in l)if(i!=="children"){var s=l[i];s instanceof Z&&(n||(t.__np=n={}),n[i]=s,l[i]=s.peek())}}a(t)});Le("__r",function(a,t){if(a(t),t.type!==V){st();var n,l=t.__c;l&&(l.__$f&=-2,(n=l.__$u)===void 0&&(l.__$u=n=(function(i,s){var r;return Be(function(){r=this},{name:s}),r.c=i,r})(function(){var i;sn&&((i=n.y)==null||i.call(n)),l.__$f|=1,l.setState({})},typeof t.type=="function"?t.type.displayName||t.type.name:""))),ut=l,st(n)}});Le("__e",function(a,t,n,l){st(),ut=void 0,a(t,n,l)});Le("diffed",function(a,t){st(),ut=void 0;var n;if(typeof t.type=="string"&&(n=t.__e)){var l=t.__np,i=t.props;if(l){var s=n.U;if(s)for(var r in s){var c=s[r];c!==void 0&&!(r in l)&&(c.d(),s[r]=void 0)}else s={},n.U=s;for(var m in l){var o=s[m],u=l[m];o===void 0?(o=rn(n,m,u,i),s[m]=o):o.o(u,i)}}}a(t)});function rn(a,t,n,l){var i=t in a&&a.ownerSVGElement===void 0,s=ee(n);return{o:function(r,c){s.value=r,l=c},d:Be(function(){this.N=$a;var r=s.value.value;l[t]!==r&&(l[t]=r,i?a[t]=r:r!=null&&(r!==!1||t[4]==="-")?a.setAttribute(t,r):a.removeAttribute(t))})}}Le("unmount",function(a,t){if(typeof t.type=="string"){var n=t.__e;if(n){var l=n.U;if(l){n.U=void 0;for(var i in l){var s=l[i];s&&s.d()}}}}else{var r=t.__c;if(r){var c=r.__$u;c&&(r.__$u=void 0,c.d())}}a(t)});Le("__h",function(a,t,n,l){(l<3||l===9)&&(t.__$f|=2),a(t,n,l)});Pe.prototype.shouldComponentUpdate=function(a,t){if(this.__R)return!0;var n=this.__$u,l=n&&n.s!==void 0;for(var i in t)return!0;if(this.__f||typeof this.u=="boolean"&&this.u===!0){var s=2&this.__$f;if(!(l||s||4&this.__$f)||1&this.__$f)return!0}else if(!(l||4&this.__$f)||3&this.__$f)return!0;for(var r in a)if(r!=="__source"&&a[r]!==this.props[r])return!0;for(var c in this.props)if(!(c in a))return!0;return!1};function v(a,t){return ct(function(){return ee(a,t)},[])}function on(a,t){var n=Kt(a);return n.current=a,ut.__$f|=4,ct(function(){return Ke(function(){return n.current()},t)},[])}var cn=function(a){queueMicrotask(function(){queueMicrotask(a)})};function dn(){nn(function(){for(var a;a=Ma.shift();)Wa.call(a)})}function $a(){Ma.push(this)===1&&($.requestAnimationFrame||cn)(dn)}const Fe=ee(null),un=Ke(()=>Fe.value!==null),Ka=ee(900),vn=ee(!1);let ke=null;const Te=()=>{Ht()};function hn(){document.addEventListener("mousemove",Te,{passive:!0}),document.addEventListener("keydown",Te,{passive:!0}),document.addEventListener("click",Te,{passive:!0}),Ht()}function mn(){document.removeEventListener("mousemove",Te),document.removeEventListener("keydown",Te),document.removeEventListener("click",Te),ke!==null&&(clearTimeout(ke),ke=null)}function Ht(){ke!==null&&clearTimeout(ke),ke=setTimeout(()=>{Bt()},Ka.value*1e3)}function pn(a,t){Fe.value=a,t!==void 0&&(Ka.value=t),hn(),location.hash="#/dashboard"}function Bt(){Fe.value=null,mn(),location.hash="#/login"}const E={ADMIN_STATUS:"/v1/admin/status",ADMIN_KILL_SWITCH:"/v1/admin/kill-switch",ADMIN_KILL_SWITCH_ESCALATE:"/v1/admin/kill-switch/escalate",ADMIN_RECOVER:"/v1/admin/recover",ADMIN_SHUTDOWN:"/v1/admin/shutdown",ADMIN_ROTATE_SECRET:"/v1/admin/rotate-secret",WALLETS:"/v1/wallets",WALLET:a=>`/v1/wallets/${a}`,SESSIONS:"/v1/sessions",SESSION:a=>`/v1/sessions/${a}`,POLICIES:"/v1/policies",POLICY:a=>`/v1/policies/${a}`,ADMIN_NOTIFICATIONS_STATUS:"/v1/admin/notifications/status",ADMIN_NOTIFICATIONS_TEST:"/v1/admin/notifications/test",ADMIN_NOTIFICATIONS_LOG:"/v1/admin/notifications/log",MCP_TOKENS:"/v1/mcp/tokens",ADMIN_SETTINGS:"/v1/admin/settings",ADMIN_SETTINGS_TEST_RPC:"/v1/admin/settings/test-rpc",WALLET_NETWORKS:a=>`/v1/wallets/${a}/networks`,WALLET_DEFAULT_NETWORK:a=>`/v1/wallets/${a}/default-network`,ADMIN_WALLET_BALANCE:a=>`/v1/admin/wallets/${a}/balance`,ADMIN_WALLET_TRANSACTIONS:a=>`/v1/admin/wallets/${a}/transactions`,ADMIN_API_KEYS:"/v1/admin/api-keys",ADMIN_API_KEY:a=>`/v1/admin/api-keys/${a}`,ADMIN_FOREX_RATES:"/v1/admin/forex/rates",ADMIN_TELEGRAM_USERS:"/v1/admin/telegram-users",ADMIN_TELEGRAM_USER:a=>`/v1/admin/telegram-users/${a}`,WALLET_OWNER:a=>`/v1/wallets/${a}/owner`,WALLET_WITHDRAW:a=>`/v1/wallets/${a}/withdraw`,WALLET_WC_PAIR:a=>`/v1/wallets/${a}/wc/pair`,WALLET_WC_SESSION:a=>`/v1/wallets/${a}/wc/session`,WALLET_WC_PAIR_STATUS:a=>`/v1/wallets/${a}/wc/pair/status`,WALLET_OWNER_VERIFY:a=>`/v1/wallets/${a}/owner/verify`},Me=ee(""),Ne=ee(null),Ue=ee(!1),de={wrapper:{display:"flex",alignItems:"center",justifyContent:"center",minHeight:"100vh",background:"var(--color-bg-secondary)"},card:{background:"var(--color-bg)",border:"1px solid var(--color-border)",borderRadius:"var(--radius-lg)",padding:"var(--space-8)",width:"100%",maxWidth:"360px",boxShadow:"var(--shadow-md)"},title:{fontSize:"var(--font-size-2xl)",fontWeight:"var(--font-weight-bold)",textAlign:"center",marginBottom:"var(--space-1)"},subtitle:{fontSize:"var(--font-size-sm)",color:"var(--color-text-secondary)",textAlign:"center",marginBottom:"var(--space-6)"},input:{width:"100%",padding:"var(--space-2) var(--space-3)",border:"1px solid var(--color-border)",borderRadius:"var(--radius-md)",fontSize:"var(--font-size-base)",outline:"none"},button:{width:"100%",padding:"var(--space-2) var(--space-4)",background:"var(--color-primary)",color:"white",border:"none",borderRadius:"var(--radius-md)",fontSize:"var(--font-size-base)",fontWeight:"var(--font-weight-medium)",marginTop:"var(--space-4)"},buttonDisabled:{opacity:.6,cursor:"not-allowed"},error:{color:"var(--color-danger)",fontSize:"var(--font-size-sm)",textAlign:"center",marginTop:"var(--space-3)"}},fn=async a=>{if(a.preventDefault(),!!Me.value.trim()){Ue.value=!0,Ne.value=null;try{const t=await fetch(E.ADMIN_STATUS,{headers:{"X-Master-Password":Me.value},signal:AbortSignal.timeout(1e4)});if(t.status===401){Ne.value="Invalid master password";return}if(!t.ok){Ne.value="Cannot connect to daemon";return}const n=await t.json();pn(Me.value,n.adminTimeout)}catch{Ne.value="Cannot connect to daemon"}finally{Ue.value=!1}}};function _n(){return e("div",{style:de.wrapper,children:e("form",{style:de.card,onSubmit:fn,children:[e("h1",{style:de.title,children:"WAIaaS Admin"}),e("p",{style:de.subtitle,children:"Enter master password to continue"}),e("input",{type:"password",placeholder:"Master password",autoFocus:!0,value:Me.value,onInput:a=>{Me.value=a.target.value},style:de.input}),e("button",{type:"submit",disabled:Ue.value,style:{...de.button,...Ue.value?de.buttonDisabled:{}},children:Ue.value?"Signing in...":"Sign in"}),Ne.value&&e("p",{style:de.error,children:Ne.value})]})})}const yn=[{id:"wallets.rpc.solana_mainnet",label:"Solana Mainnet",description:"RPC endpoint URL for Solana mainnet",page:"/wallets",tab:"rpc",fieldName:"rpc.solana_mainnet",keywords:["blockchain","rpc","solana","url","endpoint"]},{id:"wallets.rpc.solana_devnet",label:"Solana Devnet",description:"RPC endpoint URL for Solana devnet",page:"/wallets",tab:"rpc",fieldName:"rpc.solana_devnet",keywords:["blockchain","rpc","solana","url","endpoint","test"]},{id:"wallets.rpc.solana_testnet",label:"Solana Testnet",description:"RPC endpoint URL for Solana testnet",page:"/wallets",tab:"rpc",fieldName:"rpc.solana_testnet",keywords:["blockchain","rpc","solana","url","endpoint","test"]},{id:"wallets.rpc.evm_ethereum_mainnet",label:"Ethereum Mainnet",description:"RPC endpoint URL for Ethereum mainnet",page:"/wallets",tab:"rpc",fieldName:"rpc.evm_ethereum_mainnet",keywords:["blockchain","rpc","evm","ethereum","url","endpoint"]},{id:"wallets.rpc.evm_ethereum_sepolia",label:"Ethereum Sepolia",description:"RPC endpoint URL for Ethereum Sepolia testnet",page:"/wallets",tab:"rpc",fieldName:"rpc.evm_ethereum_sepolia",keywords:["blockchain","rpc","evm","ethereum","url","endpoint","test"]},{id:"wallets.rpc.evm_polygon_mainnet",label:"Polygon Mainnet",description:"RPC endpoint URL for Polygon mainnet",page:"/wallets",tab:"rpc",fieldName:"rpc.evm_polygon_mainnet",keywords:["blockchain","rpc","evm","polygon","matic","url","endpoint"]},{id:"wallets.rpc.evm_polygon_amoy",label:"Polygon Amoy",description:"RPC endpoint URL for Polygon Amoy testnet",page:"/wallets",tab:"rpc",fieldName:"rpc.evm_polygon_amoy",keywords:["blockchain","rpc","evm","polygon","url","endpoint","test"]},{id:"wallets.rpc.evm_arbitrum_mainnet",label:"Arbitrum Mainnet",description:"RPC endpoint URL for Arbitrum mainnet",page:"/wallets",tab:"rpc",fieldName:"rpc.evm_arbitrum_mainnet",keywords:["blockchain","rpc","evm","arbitrum","l2","url","endpoint"]},{id:"wallets.rpc.evm_arbitrum_sepolia",label:"Arbitrum Sepolia",description:"RPC endpoint URL for Arbitrum Sepolia testnet",page:"/wallets",tab:"rpc",fieldName:"rpc.evm_arbitrum_sepolia",keywords:["blockchain","rpc","evm","arbitrum","l2","url","endpoint","test"]},{id:"wallets.rpc.evm_optimism_mainnet",label:"Optimism Mainnet",description:"RPC endpoint URL for Optimism mainnet",page:"/wallets",tab:"rpc",fieldName:"rpc.evm_optimism_mainnet",keywords:["blockchain","rpc","evm","optimism","l2","url","endpoint"]},{id:"wallets.rpc.evm_optimism_sepolia",label:"Optimism Sepolia",description:"RPC endpoint URL for Optimism Sepolia testnet",page:"/wallets",tab:"rpc",fieldName:"rpc.evm_optimism_sepolia",keywords:["blockchain","rpc","evm","optimism","l2","url","endpoint","test"]},{id:"wallets.rpc.evm_base_mainnet",label:"Base Mainnet",description:"RPC endpoint URL for Base mainnet",page:"/wallets",tab:"rpc",fieldName:"rpc.evm_base_mainnet",keywords:["blockchain","rpc","evm","base","coinbase","l2","url","endpoint"]},{id:"wallets.rpc.evm_base_sepolia",label:"Base Sepolia",description:"RPC endpoint URL for Base Sepolia testnet",page:"/wallets",tab:"rpc",fieldName:"rpc.evm_base_sepolia",keywords:["blockchain","rpc","evm","base","coinbase","l2","url","endpoint","test"]},{id:"wallets.rpc.evm_default_network",label:"Default EVM Network",description:"Default EVM network for new wallets",page:"/wallets",tab:"rpc",fieldName:"rpc.evm_default_network",keywords:["blockchain","evm","default","network"]},{id:"wallets.monitoring.enabled",label:"Enabled",description:"Enable or disable balance monitoring",page:"/wallets",tab:"monitoring",fieldName:"monitoring.enabled",keywords:["balance","monitoring","toggle","enable"]},{id:"wallets.monitoring.check_interval_sec",label:"Check Interval (seconds)",description:"How often to check wallet balances",page:"/wallets",tab:"monitoring",fieldName:"monitoring.check_interval_sec",keywords:["balance","monitoring","interval","frequency"]},{id:"wallets.monitoring.low_balance_threshold_sol",label:"Low Balance Threshold (SOL)",description:"Alert when SOL balance drops below this amount",page:"/wallets",tab:"monitoring",fieldName:"monitoring.low_balance_threshold_sol",keywords:["balance","monitoring","threshold","solana","alert","low"]},{id:"wallets.monitoring.low_balance_threshold_eth",label:"Low Balance Threshold (ETH)",description:"Alert when ETH balance drops below this amount",page:"/wallets",tab:"monitoring",fieldName:"monitoring.low_balance_threshold_eth",keywords:["balance","monitoring","threshold","ethereum","alert","low"]},{id:"wallets.monitoring.cooldown_hours",label:"Alert Cooldown (hours)",description:"Suppress duplicate alerts for this many hours",page:"/wallets",tab:"monitoring",fieldName:"monitoring.cooldown_hours",keywords:["balance","monitoring","cooldown","alert","suppress"]},{id:"wallets.walletconnect.project_id",label:"Project ID",description:"WalletConnect Cloud project identifier",page:"/wallets",tab:"walletconnect",fieldName:"walletconnect.project_id",keywords:["walletconnect","project","cloud","dapp"]},{id:"wallets.walletconnect.relay_url",label:"Relay URL",description:"WalletConnect relay server URL",page:"/wallets",tab:"walletconnect",fieldName:"walletconnect.relay_url",keywords:["walletconnect","relay","websocket","server"]},{id:"sessions.settings.session_ttl",label:"Session TTL (seconds)",description:"How long a session token is valid before renewal",page:"/sessions",tab:"settings",fieldName:"security.session_ttl",keywords:["session","ttl","lifetime","expiry","timeout"]},{id:"sessions.settings.session_absolute_lifetime",label:"Absolute Lifetime (seconds)",description:"Maximum total session duration regardless of renewals",page:"/sessions",tab:"settings",fieldName:"security.session_absolute_lifetime",keywords:["session","lifetime","absolute","maximum"]},{id:"sessions.settings.session_max_renewals",label:"Max Renewals",description:"Maximum number of times a session can be renewed",page:"/sessions",tab:"settings",fieldName:"security.session_max_renewals",keywords:["session","renewal","limit","maximum"]},{id:"sessions.settings.max_sessions_per_wallet",label:"Max Sessions per Wallet",description:"Maximum concurrent sessions for a single wallet",page:"/sessions",tab:"settings",fieldName:"security.max_sessions_per_wallet",keywords:["session","limit","concurrent","wallet"]},{id:"sessions.settings.max_pending_tx",label:"Max Pending Transactions",description:"Maximum in-flight transactions per session",page:"/sessions",tab:"settings",fieldName:"security.max_pending_tx",keywords:["transaction","pending","limit","queue"]},{id:"sessions.settings.rate_limit_session_rpm",label:"Session Rate Limit (RPM)",description:"Max requests per minute per session",page:"/sessions",tab:"settings",fieldName:"security.rate_limit_session_rpm",keywords:["rate","limit","rpm","session","throttle"]},{id:"sessions.settings.rate_limit_tx_rpm",label:"Transaction Rate Limit (RPM)",description:"Max transaction requests per minute per session",page:"/sessions",tab:"settings",fieldName:"security.rate_limit_tx_rpm",keywords:["rate","limit","rpm","transaction","throttle"]},{id:"policies.defaults.policy_defaults_delay_seconds",label:"Policy Delay (seconds)",description:"Default delay before executing delayed-tier transactions",page:"/policies",tab:"defaults",fieldName:"security.policy_defaults_delay_seconds",keywords:["policy","delay","default","seconds","timer"]},{id:"policies.defaults.policy_defaults_approval_timeout",label:"Approval Timeout (seconds)",description:"How long to wait for owner approval before timeout",page:"/policies",tab:"defaults",fieldName:"security.policy_defaults_approval_timeout",keywords:["policy","approval","timeout","owner","default"]},{id:"policies.defaults.default_deny_tokens",label:"Default Deny: Token Transfers",description:"Deny token transfers unless a matching whitelist policy exists",page:"/policies",tab:"defaults",fieldName:"policy.default_deny_tokens",keywords:["policy","deny","token","transfer","default","security"]},{id:"policies.defaults.default_deny_contracts",label:"Default Deny: Contract Calls",description:"Deny contract calls unless a matching whitelist policy exists",page:"/policies",tab:"defaults",fieldName:"policy.default_deny_contracts",keywords:["policy","deny","contract","call","default","security"]},{id:"policies.defaults.default_deny_spenders",label:"Default Deny: Token Approvals",description:"Deny token approvals unless a matching whitelist policy exists",page:"/policies",tab:"defaults",fieldName:"policy.default_deny_spenders",keywords:["policy","deny","spender","approval","default","security"]},{id:"notifications.settings.enabled",label:"Enabled",description:"Enable or disable notifications globally",page:"/notifications",tab:"settings",fieldName:"notifications.enabled",keywords:["notifications","enable","toggle","global"]},{id:"notifications.settings.telegram_bot_token",label:"Telegram Bot Token",description:"Bot token for Telegram notifications",page:"/notifications",tab:"settings",fieldName:"notifications.telegram_bot_token",keywords:["telegram","bot","token","notification","credential"]},{id:"notifications.settings.telegram_chat_id",label:"Telegram Chat ID",description:"Chat ID for Telegram notification delivery",page:"/notifications",tab:"settings",fieldName:"notifications.telegram_chat_id",keywords:["telegram","chat","notification"]},{id:"notifications.settings.locale",label:"Locale",description:"Language for notification messages",page:"/notifications",tab:"settings",fieldName:"notifications.locale",keywords:["locale","language","notification","i18n"]},{id:"notifications.settings.discord_webhook_url",label:"Discord Webhook URL",description:"Webhook URL for Discord notifications",page:"/notifications",tab:"settings",fieldName:"notifications.discord_webhook_url",keywords:["discord","webhook","notification","credential"]},{id:"notifications.settings.ntfy_server",label:"Ntfy Server",description:"Server URL for ntfy notifications",page:"/notifications",tab:"settings",fieldName:"notifications.ntfy_server",keywords:["ntfy","server","push","notification"]},{id:"notifications.settings.ntfy_topic",label:"Ntfy Topic",description:"Topic name for ntfy notifications",page:"/notifications",tab:"settings",fieldName:"notifications.ntfy_topic",keywords:["ntfy","topic","push","notification"]},{id:"notifications.settings.slack_webhook_url",label:"Slack Webhook URL",description:"Webhook URL for Slack notifications",page:"/notifications",tab:"settings",fieldName:"notifications.slack_webhook_url",keywords:["slack","webhook","notification","credential"]},{id:"notifications.settings.rate_limit_rpm",label:"Rate Limit (RPM)",description:"Max notifications per minute",page:"/notifications",tab:"settings",fieldName:"notifications.rate_limit_rpm",keywords:["rate","limit","rpm","notification","throttle"]},{id:"notifications.settings.telegram_bot_enabled",label:"Bot Enabled",description:"Enable or disable the Telegram bot",page:"/notifications",tab:"settings",fieldName:"telegram.enabled",keywords:["telegram","bot","enable","toggle"]},{id:"notifications.settings.telegram_dedicated_bot_token",label:"Bot Token",description:"Dedicated bot token for Telegram bot (optional, uses notification token if empty)",page:"/notifications",tab:"settings",fieldName:"telegram.bot_token",keywords:["telegram","bot","token","credential"]},{id:"security.autostop.enabled",label:"Enabled",description:"Enable or disable AutoStop protection rules",page:"/security",tab:"autostop",fieldName:"autostop.enabled",keywords:["autostop","protection","enable","toggle","security"]},{id:"security.autostop.consecutive_failures_threshold",label:"Consecutive Failures Threshold",description:"Suspend wallet after this many consecutive failed transactions",page:"/security",tab:"autostop",fieldName:"autostop.consecutive_failures_threshold",keywords:["autostop","failure","threshold","suspend","security"]},{id:"security.autostop.unusual_activity_threshold",label:"Unusual Activity Threshold",description:"Max transactions within window before triggering unusual activity alert",page:"/security",tab:"autostop",fieldName:"autostop.unusual_activity_threshold",keywords:["autostop","unusual","activity","threshold","security"]},{id:"security.autostop.unusual_activity_window_sec",label:"Unusual Activity Window (seconds)",description:"Time window for unusual activity detection",page:"/security",tab:"autostop",fieldName:"autostop.unusual_activity_window_sec",keywords:["autostop","unusual","activity","window","time","security"]},{id:"security.autostop.idle_timeout_sec",label:"Idle Timeout (seconds)",description:"Revoke sessions with no activity for this duration",page:"/security",tab:"autostop",fieldName:"autostop.idle_timeout_sec",keywords:["autostop","idle","timeout","session","revoke","security"]},{id:"security.autostop.idle_check_interval_sec",label:"Idle Check Interval (seconds)",description:"How often to check for idle sessions",page:"/security",tab:"autostop",fieldName:"autostop.idle_check_interval_sec",keywords:["autostop","idle","check","interval","security"]},{id:"system..currency",label:"Display Currency",description:"Currency for USD amount conversion in dashboard and notifications",page:"/system",tab:"",fieldName:"display.currency",keywords:["currency","display","usd","conversion","fiat"]},{id:"system..rate_limit_global_ip_rpm",label:"Global IP Rate Limit (RPM)",description:"Maximum API requests per minute from a single IP address",page:"/system",tab:"",fieldName:"security.rate_limit_global_ip_rpm",keywords:["rate","limit","rpm","ip","global","throttle"]},{id:"system..log_level",label:"Log Level",description:"Daemon logging verbosity level",page:"/system",tab:"",fieldName:"daemon.log_level",keywords:["log","level","debug","info","warn","error","daemon"]},{id:"system..cross_validation_threshold",label:"Cross Validation Threshold (%)",description:"Maximum allowed deviation between price oracle sources",page:"/system",tab:"",fieldName:"oracle.cross_validation_threshold",keywords:["oracle","price","validation","threshold","deviation"]}],se=ee(""),Y=ee(null),gn={"/wallets":"Wallets","/sessions":"Sessions","/policies":"Policies","/notifications":"Notifications","/security":"Security","/system":"System"};function bn(a){if(!a.trim())return[];const t=a.toLowerCase();return yn.filter(n=>[n.label,n.description,n.keywords.join(" ")].join(" ").toLowerCase().includes(t)).slice(0,10)}function wn(a){const t=gn[a.page]??a.page;return a.tab?`${t} > ${a.tab}`:t}function Sn({open:a}){const t=v(""),n=v(0),l=Kt(null),i=a.value?bn(t.value):[];if(L(()=>{a.value&&(t.value="",n.value=0,requestAnimationFrame(()=>{l.current?.focus()}))},[a.value]),!a.value)return null;const s=()=>{a.value=!1,t.value="",n.value=0},r=o=>{o.target.classList.contains("search-overlay")&&s()},c=o=>{window.location.hash="#"+o.page,o.tab?Y.value={tab:o.tab,fieldName:o.fieldName}:setTimeout(()=>{se.value=o.fieldName},100),s()};return e("div",{class:"search-overlay",onClick:r,children:e("div",{class:"search-popover",onKeyDown:o=>{if(o.key==="Escape"){s();return}if(o.key==="ArrowDown"){o.preventDefault(),n.value=Math.min(n.value+1,i.length-1);return}if(o.key==="ArrowUp"){o.preventDefault(),n.value=Math.max(n.value-1,0);return}if(o.key==="Enter"&&i.length>0){o.preventDefault(),c(i[n.value]);return}},children:[e("div",{class:"search-input-wrapper",children:e("input",{ref:l,class:"search-input",type:"text",placeholder:"Search settings...",value:t.value,onInput:o=>{t.value=o.target.value,n.value=0}})}),e("div",{class:"search-results",children:[t.value.trim()&&i.length===0&&e("div",{class:"search-empty",children:"No settings found"}),i.map((o,u)=>e("button",{class:`search-result-item${u===n.value?" selected":""}`,onClick:()=>c(o),onMouseEnter:()=>{n.value=u},children:[e("div",{class:"search-result-label",children:o.label}),e("div",{class:"search-result-desc",children:o.description}),e("div",{class:"search-result-path",children:wn(o)})]},o.id))]}),e("div",{class:"search-hint",children:[e("span",{children:[e("kbd",{children:"Esc"})," close"]}),e("span",{children:[e("kbd",{children:"↑"}),e("kbd",{children:"↓"})," navigate"]}),e("span",{children:[e("kbd",{children:"Enter"})," select"]})]})]})})}const ge=ee([]),Fa=Ke(()=>ge.value.some(a=>a.isDirty()));function pe(a){ge.value=[...ge.value.filter(t=>t.id!==a.id),a]}function fe(a){ge.value=ge.value.filter(t=>t.id!==a)}async function Nn(){const a=ge.value.filter(t=>t.isDirty());try{for(const t of a)await t.save();return!0}catch{return!1}}function kn(){const a=ge.value.filter(t=>t.isDirty());for(const t of a)t.discard()}function S({label:a,name:t,type:n="text",value:l,onChange:i,options:s,error:r,required:c,disabled:m,placeholder:o,min:u,max:d,description:p}){const h=se.value===t;if(L(()=>{if(h){const C=document.querySelector(`[name="${t}"]`);C&&C.closest(".form-field")?.scrollIntoView({behavior:"smooth",block:"center"});const w=setTimeout(()=>{se.value=""},2500);return()=>clearTimeout(w)}},[h,t]),n==="checkbox")return e("div",{class:`form-field${h?" form-field--highlight":""}`,children:[e("label",{children:[e("input",{type:"checkbox",name:t,checked:!!l,onChange:C=>i(C.target.checked),disabled:m}),a,c&&e("span",{children:" *"})]}),p&&e("span",{class:"form-description",children:p}),r&&e("span",{class:"form-error",children:r})]});const k=`field-${t}`;return e("div",{class:`form-field${h?" form-field--highlight":""}`,children:[e("label",{for:k,children:[a,c&&e("span",{children:" *"})]}),n==="select"?e("select",{id:k,name:t,value:l,onChange:C=>i(C.target.value),disabled:m,children:s?.map(C=>e("option",{value:C.value,children:C.label},C.value))}):n==="textarea"?e("textarea",{id:k,name:t,value:l,onInput:C=>i(C.target.value),disabled:m,placeholder:o}):e("input",{id:k,type:n,name:t,value:l,onInput:C=>{const w=C.target;i(n==="number"?Number(w.value):w.value)},disabled:m,placeholder:o,min:u,max:d,required:c}),p&&e("span",{class:"form-description",children:p}),r&&e("span",{class:"form-error",children:r})]})}function A({variant:a="primary",size:t="md",loading:n=!1,disabled:l=!1,onClick:i,children:s,type:r="button"}){const c=["btn",`btn-${a}`,t==="sm"?"btn-sm":""].filter(Boolean).join(" ");return e("button",{type:r,class:c,disabled:l||n,onClick:i,children:n?"...":s})}function W({variant:a,children:t}){return e("span",{class:`badge badge-${a}`,children:t})}const xe=ee(null),Oe=ee(!1);function Ha(a){xe.value=a}function Tn(){const a=xe.value;if(!a)return null;const t=async()=>{Oe.value=!0;const i=await Nn();Oe.value=!1,i&&(xe.value=null,a.execute())},n=()=>{kn(),xe.value=null,a.execute()},l=()=>{xe.value=null};return e("div",{class:"modal-overlay",onClick:l,children:e("div",{class:"modal-card",onClick:i=>i.stopPropagation(),children:[e("div",{class:"modal-header",children:"Unsaved Changes"}),e("div",{class:"modal-body",children:e("p",{children:"You have unsaved changes. What would you like to do?"})}),e("div",{class:"modal-footer unsaved-dialog-footer",children:[e(A,{variant:"secondary",onClick:l,disabled:Oe.value,children:"Cancel"}),e(A,{variant:"ghost",onClick:n,disabled:Oe.value,children:"Discard & Navigate"}),e(A,{variant:"primary",onClick:t,loading:Oe.value,children:"Save & Navigate"})]})]})})}class f extends Error{constructor(t,n,l){super(`[${t}] ${n}: ${l}`),this.status=t,this.code=n,this.serverMessage=l,this.name="ApiError"}}async function vt(a,t){const n={"Content-Type":"application/json",...t?.headers};Fe.value!==null&&(n["X-Master-Password"]=Fe.value);let l;try{l=await fetch(a,{...t,headers:n,signal:AbortSignal.timeout(1e4)})}catch(i){const s=i;throw s.name==="AbortError"||s.name==="TimeoutError"?new f(0,"TIMEOUT","Request timed out"):new f(0,"NETWORK_ERROR","Cannot connect to daemon")}if(l.status===401)throw Bt(),new f(401,"INVALID_MASTER_PASSWORD","Authentication failed");if(!l.ok){let i={};try{i=await l.json()}catch{}throw new f(l.status,i.code??"UNKNOWN",i.message??"Unknown error")}return Ht(),await l.json()}const K=a=>vt(a,{method:"GET"}),ne=(a,t)=>vt(a,{method:"POST",body:t?JSON.stringify(t):void 0}),le=(a,t)=>vt(a,{method:"PUT",body:t?JSON.stringify(t):void 0}),Ce=a=>vt(a,{method:"DELETE"});function En(a){const t=Math.floor(a/86400),n=Math.floor(a%86400/3600),l=Math.floor(a%3600/60);return t>0?`${t}d ${n}h ${l}m`:n>0?`${n}h ${l}m`:`${l}m`}function ie(a){const t=new Date(a*1e3),n=l=>l.toString().padStart(2,"0");return`${t.getFullYear()}-${n(t.getMonth()+1)}-${n(t.getDate())} ${n(t.getHours())}:${n(t.getMinutes())}`}function xt(a){return a.length<=10?a:`${a.slice(0,4)}..${a.slice(-4)}`}const An=new Set(["KRW","JPY","VND","CLP","HUF","PKR"]),Cn=new Set(["KWD","BHD"]);function In(a){return An.has(a)?0:Cn.has(a)?3:2}function Dn(a,t,n){const l=a*n,i=In(t),s=new Intl.NumberFormat("en-US",{style:"currency",currency:t,minimumFractionDigits:i,maximumFractionDigits:i}).format(l);return t==="USD"?s:`≈${s}`}let Se=null;const Ln=300*1e3;async function On(){if(Se&&Date.now()-Se.fetchedAt<Ln)return{currency:Se.currency,rate:Se.rate};try{const t=(await K(E.ADMIN_SETTINGS)).display?.["display.currency"]??"USD";if(t==="USD")return Se={currency:"USD",rate:1,fetchedAt:Date.now()},{currency:"USD",rate:1};const i=(await K(`${E.ADMIN_FOREX_RATES}?currencies=${t}`)).rates[t]?.rate??null;return Se={currency:t,rate:i,fetchedAt:Date.now()},{currency:t,rate:i}}catch{return{currency:"USD",rate:1}}}function Rn(a,t,n){return a==null?"":n==null?`$${a.toFixed(2)}`:Dn(a,t,n)}function we({columns:a,data:t,onRowClick:n,emptyMessage:l="No data",loading:i=!1}){return e("div",{class:"table-container",children:e("table",{children:[e("thead",{children:e("tr",{children:a.map(s=>e("th",{style:s.width?{width:s.width}:void 0,children:s.header},s.key))})}),e("tbody",{children:i?e("tr",{children:e("td",{colSpan:a.length,class:"table-loading",children:"Loading..."})}):!t||t.length===0?e("tr",{children:e("td",{colSpan:a.length,class:"table-empty",children:l})}):t.map((s,r)=>e("tr",{class:n?"clickable":"",onClick:n?()=>n(s):void 0,children:a.map(c=>e("td",{children:c.render?c.render(s):s[c.key]},c.key))},r))})]})})}const xn={INVALID_TOKEN:"Your authentication token is invalid. Please log in again.",TOKEN_EXPIRED:"Your session token has expired. Please log in again.",SESSION_REVOKED:"Your session has been revoked by an administrator.",INVALID_SIGNATURE:"The cryptographic signature is invalid.",INVALID_NONCE:"The authentication nonce is invalid or has expired.",INVALID_MASTER_PASSWORD:"Invalid master password. Please try again.",MASTER_PASSWORD_LOCKED:"Master password is locked due to too many failed attempts. Please wait.",SYSTEM_LOCKED:"The system is currently locked.",SESSION_NOT_FOUND:"Session not found.",SESSION_EXPIRED:"The session has expired.",SESSION_LIMIT_EXCEEDED:"Maximum number of sessions reached.",CONSTRAINT_VIOLATED:"A session constraint was violated.",RENEWAL_LIMIT_REACHED:"Session renewal limit has been reached. Create a new session.",SESSION_ABSOLUTE_LIFETIME_EXCEEDED:"Session has exceeded its maximum lifetime.",RENEWAL_TOO_EARLY:"Session renewal attempted too early. Please wait.",SESSION_RENEWAL_MISMATCH:"Session renewal count mismatch. The session may have been renewed elsewhere.",PIPELINE_HALTED:"Transaction is queued for delay or approval.",INSUFFICIENT_BALANCE:"Insufficient balance for this transaction.",INVALID_ADDRESS:"The blockchain address is invalid.",TX_NOT_FOUND:"Transaction not found.",TX_EXPIRED:"The transaction has expired.",TX_ALREADY_PROCESSED:"This transaction has already been processed.",CHAIN_ERROR:"A blockchain network error occurred. Please try again.",SIMULATION_FAILED:"Transaction simulation failed. The transaction may revert.",TOKEN_NOT_FOUND:"Token not found.",TOKEN_NOT_ALLOWED:"This token is not in the allowed list.",INSUFFICIENT_TOKEN_BALANCE:"Insufficient token balance.",CONTRACT_CALL_DISABLED:"Contract calls are disabled. Configure a CONTRACT_WHITELIST policy first.",CONTRACT_NOT_WHITELISTED:"This contract address is not whitelisted.",METHOD_NOT_WHITELISTED:"This contract method is not whitelisted.",APPROVE_DISABLED:"Token approvals are disabled. Configure an APPROVED_SPENDERS policy first.",SPENDER_NOT_APPROVED:"This spender address is not in the approved list.",APPROVE_AMOUNT_EXCEEDED:"The approve amount exceeds the configured limit.",UNLIMITED_APPROVE_BLOCKED:"Unlimited token approvals are blocked by policy.",BATCH_NOT_SUPPORTED:"Batch transactions are not supported on this chain.",BATCH_SIZE_EXCEEDED:"Batch contains too many instructions (maximum 20).",BATCH_POLICY_VIOLATION:"A policy violation occurred in the batch transaction.",POLICY_NOT_FOUND:"Policy not found.",POLICY_DENIED:"Transaction denied by policy.",SPENDING_LIMIT_EXCEEDED:"Spending limit has been exceeded.",RATE_LIMIT_EXCEEDED:"Rate limit exceeded. Please wait before retrying.",WHITELIST_DENIED:"The destination address is not in the whitelist.",OWNER_ALREADY_CONNECTED:"An owner wallet is already connected to this wallet.",OWNER_NOT_CONNECTED:"No owner wallet is connected to this wallet.",OWNER_NOT_FOUND:"Owner not found.",APPROVAL_TIMEOUT:"The approval request has timed out.",APPROVAL_NOT_FOUND:"Approval request not found.",OWNER_NOT_SET:"Owner address must be set before connecting WalletConnect.",OWNER_ADDRESS_MISMATCH:"Connected wallet address does not match registered owner.",KILL_SWITCH_ACTIVE:"Kill switch is active. All operations are suspended.",KILL_SWITCH_NOT_ACTIVE:"Kill switch is not currently active.",KEYSTORE_LOCKED:"The keystore is locked. Please try again.",CHAIN_NOT_SUPPORTED:"This blockchain is not supported.",SHUTTING_DOWN:"The daemon is shutting down.",ADAPTER_NOT_AVAILABLE:"Chain adapter is not available. Please try again.",WALLET_NOT_FOUND:"Wallet not found.",WALLET_SUSPENDED:"This wallet is currently suspended.",WALLET_TERMINATED:"This wallet has been terminated.",WC_NOT_CONFIGURED:"WalletConnect is not configured. Set the Project ID in Settings first.",WC_SESSION_NOT_FOUND:"No active WalletConnect session.",WC_SESSION_EXISTS:"A WalletConnect session already exists. Disconnect first.",WC_SIGNING_FAILED:"WalletConnect signing request failed.",NO_OWNER:"No owner connected. Withdrawal requires an owner wallet.",WITHDRAW_LOCKED_ONLY:"Withdrawal is only available when the owner state is LOCKED.",SWEEP_TOTAL_FAILURE:"All sweep operations failed. Please try again.",INSUFFICIENT_FOR_FEE:"Insufficient balance to cover transaction fees.",ACTION_NOT_FOUND:"Action not found.",ACTION_VALIDATION_FAILED:"Action input validation failed.",ACTION_RESOLVE_FAILED:"Action failed due to an external API error. Please try again.",ACTION_RETURN_INVALID:"Action returned an invalid result.",ACTION_PLUGIN_LOAD_FAILED:"Failed to load the action plugin.",ACTION_NAME_CONFLICT:"An action with this name already exists.",ACTION_CHAIN_MISMATCH:"The request chain does not match the action provider.",ROTATION_TOO_RECENT:"Key rotation was attempted too recently. Please wait.",NETWORK_ERROR:"Cannot connect to the daemon. Check if it is running.",TIMEOUT:"Request timed out. The daemon may be busy."};function D(a){return xn[a]??`An error occurred (${a}).`}function oe({label:a,value:t,loading:n,badge:l,href:i}){const s=e(V,{children:[e("div",{class:"stat-label",children:[a,i&&e("span",{class:"stat-link-arrow",children:" →"})]}),n?e("div",{class:"stat-skeleton"}):l?e(W,{variant:l,children:t}):e("div",{class:"stat-value",children:t})]});return i?e("a",{href:i,class:"stat-card stat-card-link",style:{textDecoration:"none",color:"inherit",cursor:"pointer"},children:s}):e("div",{class:"stat-card",children:s})}function Pn(a,t){return[{key:"createdAt",header:"Time",render:n=>n.createdAt?ie(n.createdAt):"—"},{key:"walletName",header:"Wallet",render:n=>n.walletName??n.walletId.slice(0,8)},{key:"type",header:"Type"},{key:"amount",header:"Amount",render:n=>{if(!n.amount)return"—";const l=Rn(n.amountUsd,a,t);return l?`${n.amount} (${l})`:n.amount}},{key:"status",header:"Status",render:n=>{const l=n.status==="CONFIRMED"?"success":n.status==="FAILED"?"danger":"warning";return e(W,{variant:l,children:n.status})}}]}function aa(){const a=v(null),t=v(!0),n=v(null),l=v("USD"),i=v(1),s=async()=>{t.value=!0,n.value=null;try{const c=await K(E.ADMIN_STATUS);a.value=c}catch(c){c instanceof f?n.value=D(c.code):n.value="An unexpected error occurred."}finally{t.value=!1}};L(()=>{s(),On().then(({currency:m,rate:o})=>{l.value=m,i.value=o}).catch(()=>{});const c=setInterval(s,3e4);return()=>clearInterval(c)},[]);const r=t.value&&!a.value;return e("div",{class:"page",children:[n.value&&e("div",{class:"dashboard-error",children:[e("span",{children:n.value}),e(A,{variant:"secondary",size:"sm",onClick:s,children:"Retry"})]}),e("div",{class:"stat-grid",children:[e(oe,{label:"Version",value:a.value?.version??"—",loading:r}),e(oe,{label:"Uptime",value:a.value?En(a.value.uptime):"—",loading:r}),e(oe,{label:"Wallets",value:a.value?.walletCount?.toString()??"—",loading:r,href:"#/wallets"}),e(oe,{label:"Active Sessions",value:a.value?.activeSessionCount?.toString()??"—",loading:r,href:"#/sessions"})]}),e("div",{class:"stat-grid",style:{marginTop:"var(--space-4)"},children:[e(oe,{label:"Kill Switch",value:a.value?.killSwitchState==="ACTIVATED"?"ACTIVATED":"NORMAL",loading:r,badge:a.value?a.value.killSwitchState==="ACTIVATED"?"danger":"success":void 0}),e(oe,{label:"Status",value:a.value?.status??"—",loading:r})]}),e("div",{class:"stat-grid",style:{marginTop:"var(--space-4)"},children:[e(oe,{label:"Policies",value:a.value?.policyCount?.toString()??"—",loading:r,href:"#/policies"}),e(oe,{label:"Recent Txns (24h)",value:a.value?.recentTxCount?.toString()??"—",loading:r}),e(oe,{label:"Failed Txns (24h)",value:a.value?.failedTxCount?.toString()??"—",loading:r,badge:a.value?a.value.failedTxCount===0?"success":"danger":void 0})]}),e("div",{style:{marginTop:"var(--space-6)"},children:[e("h3",{style:{marginBottom:"var(--space-3)"},children:"Recent Activity"}),e(we,{columns:Pn(l.value,i.value),data:a.value?.recentTransactions??[],loading:r,emptyMessage:"No recent transactions"})]})]})}function re({open:a,title:t,children:n,onConfirm:l,onCancel:i,confirmText:s="Confirm",cancelText:r="Cancel",confirmVariant:c="primary",confirmDisabled:m=!1,loading:o=!1}){return L(()=>{if(!a)return;const u=d=>{d.key==="Escape"&&i()};return document.addEventListener("keydown",u),()=>document.removeEventListener("keydown",u)},[a,i]),a?e("div",{class:"modal-overlay",onClick:i,children:e("div",{class:"modal-card",onClick:u=>u.stopPropagation(),children:[e("div",{class:"modal-header",children:t}),e("div",{class:"modal-body",children:n}),e("div",{class:"modal-footer",children:[e(A,{variant:"secondary",onClick:i,disabled:o,children:r}),l&&e(A,{variant:c,onClick:l,loading:o,disabled:m,children:s})]})]})}):null}function He({value:a,label:t}){const n=v(!1);return e("button",{class:"btn btn-ghost btn-sm",onClick:async()=>{try{await navigator.clipboard.writeText(a)}catch{const i=document.createElement("textarea");i.value=a,i.style.position="fixed",i.style.left="-9999px",document.body.appendChild(i),i.select(),document.execCommand("copy"),document.body.removeChild(i)}n.value=!0,setTimeout(()=>{n.value=!1},2e3)},children:n.value?"Copied!":t??"Copy"})}function Wn({title:a,description:t,actionLabel:n,onAction:l}){return e("div",{class:"empty-state",children:[e("h3",{children:a}),t&&e("p",{children:t}),n&&l&&e("button",{class:"btn btn-primary",onClick:l,children:n})]})}const ve=ee([]);let Mn=0;function g(a,t){const n=Mn++;ve.value=[...ve.value,{id:n,type:a,message:t}],setTimeout(()=>{ve.value=ve.value.filter(l=>l.id!==n)},5e3)}function Un(a){ve.value=ve.value.filter(t=>t.id!==a)}function $n(){return ve.value.length===0?null:e("div",{class:"toast-container",children:ve.value.map(a=>e("div",{class:`toast toast-${a.type}`,onClick:()=>Un(a.id),children:a.message},a.id))})}function Ve({tabs:a,activeTab:t,onTabChange:n}){return e("div",{class:"tab-nav",children:a.map(l=>e("button",{class:`tab-btn ${t===l.key?"active":""}`,onClick:()=>{l.key!==t&&(Fa.value?Ha({type:"tab",execute:()=>n(l.key)}):n(l.key))},children:l.label},l.key))})}function qe({pageName:a,tabName:t,onPageClick:n}){return t?e("nav",{class:"breadcrumb","aria-label":"Breadcrumb",children:[e("button",{class:"breadcrumb-page",onClick:n,type:"button",children:a}),e("span",{class:"breadcrumb-separator","aria-hidden":"true",children:">"}),e("span",{class:"breadcrumb-current","aria-current":"page",children:t})]}):null}const Kn=new Set(["notifications.telegram_bot_token","notifications.discord_webhook_url","notifications.slack_webhook_url","telegram.bot_token"]);function Fn(a){return Kn.has(a)}function x(a){return{enabled:"Enabled",telegram_bot_token:"Telegram Bot Token",telegram_chat_id:"Telegram Chat ID",discord_webhook_url:"Discord Webhook URL",ntfy_server:"Ntfy Server",ntfy_topic:"Ntfy Topic",locale:"Locale",rate_limit_rpm:"Rate Limit (RPM)",solana_mainnet:"Solana Mainnet",solana_devnet:"Solana Devnet",solana_testnet:"Solana Testnet",evm_ethereum_mainnet:"Ethereum Mainnet",evm_ethereum_sepolia:"Ethereum Sepolia",evm_polygon_mainnet:"Polygon Mainnet",evm_polygon_amoy:"Polygon Amoy",evm_arbitrum_mainnet:"Arbitrum Mainnet",evm_arbitrum_sepolia:"Arbitrum Sepolia",evm_optimism_mainnet:"Optimism Mainnet",evm_optimism_sepolia:"Optimism Sepolia",evm_base_mainnet:"Base Mainnet",evm_base_sepolia:"Base Sepolia",evm_default_network:"Default EVM Network",session_ttl:"Session TTL (seconds)",max_sessions_per_wallet:"Max Sessions per Wallet",max_pending_tx:"Max Pending Transactions",rate_limit_global_ip_rpm:"Global IP Rate Limit (RPM)",rate_limit_session_rpm:"Session Rate Limit (RPM)",rate_limit_tx_rpm:"Transaction Rate Limit (RPM)",policy_defaults_delay_seconds:"Policy Delay (seconds)",policy_defaults_approval_timeout:"Approval Timeout (seconds)",default_deny_tokens:"Default Deny: Token Transfers",default_deny_contracts:"Default Deny: Contract Calls",default_deny_spenders:"Default Deny: Token Approvals",project_id:"Project ID",log_level:"Log Level",currency:"Display Currency",consecutive_failures_threshold:"Consecutive Failures Threshold",unusual_activity_threshold:"Unusual Activity Threshold",unusual_activity_window_sec:"Unusual Activity Window (seconds)",idle_timeout_sec:"Idle Timeout (seconds)",idle_check_interval_sec:"Idle Check Interval (seconds)",check_interval_sec:"Check Interval (seconds)",low_balance_threshold_sol:"Low Balance Threshold (SOL)",low_balance_threshold_eth:"Low Balance Threshold (ETH)",cooldown_hours:"Alert Cooldown (hours)",relay_url:"Relay URL",session_absolute_lifetime:"Absolute Lifetime (seconds)",session_max_renewals:"Max Renewals",bot_token:"Bot Token"}[a]??a.replace(/_/g," ").replace(/\b\w/g,n=>n.toUpperCase())}function M(a,t,n,l){const i=`${n}.${l}`;if(t[i]!==void 0)return t[i];const s=a[n];if(!s)return"";const r=s[l];return typeof r=="boolean"?Fn(i)?"":String(r):r??""}function Ee(a,t,n,l){const i=`${n}.${l}`;if(t[i]!==void 0)return t[i]==="true";const s=a[n];if(!s)return!1;const r=s[l];return typeof r=="boolean"?r:r==="true"}function Je(a,t,n,l){const i=`${n}.${l}`;if(t[i]!==void 0)return!1;const s=a[n];return s?s[l]===!0:!1}const Hn=[{key:"name",header:"Name"},{key:"chain",header:"Chain"},{key:"environment",header:"Environment",render:a=>e(W,{variant:a.environment==="mainnet"?"warning":"info",children:a.environment})},{key:"publicKey",header:"Public Key",render:a=>e("span",{style:{display:"flex",alignItems:"center",gap:"0.25rem"},children:[xt(a.publicKey)," ",e(He,{value:a.publicKey})]})},{key:"status",header:"Status",render:a=>e(W,{variant:a.status==="ACTIVE"?"success":"danger",children:a.status})},{key:"ownerState",header:"Owner",render:a=>e(W,{variant:Ba(a.ownerState),children:a.ownerState})},{key:"createdAt",header:"Created",render:a=>ie(a.createdAt)}];function Ba(a){switch(a){case"NONE":return"neutral";case"GRACE":return"warning";case"LOCKED":return"success";default:return"neutral"}}function X({label:a,value:t,copy:n,children:l}){return e("div",{class:"detail-row",children:[e("div",{class:"detail-row-label",children:a}),e("div",{class:"detail-row-value",children:[l??t??"—",n&&t&&e(He,{value:t})]})]})}function Bn({id:a}){const t=v(null),n=v(!0),l=v(!1),i=v(""),s=v(!1),r=v(!1),c=v(!1),m=v(!1),o=v(null),u=v([]),d=v(!0),p=v(!1),h=v(null),k=v(!0),C=v([]),w=v(!0),_=v(!1),I=v(null),B=v(!1),F=v(null),N=v(!0),O=v(!1),P=v(null),G=v(!1),q=v(""),Q=v(!1),j=async()=>{try{const b=await K(E.WALLET(a));t.value=b}catch(b){const J=b instanceof f?b:new f(0,"UNKNOWN","Unknown error");g("error",D(J.code))}finally{n.value=!1}},T=async()=>{s.value=!0;try{const b=await le(E.WALLET(a),{name:i.value});t.value=b,l.value=!1,g("success","Wallet name updated")}catch(b){const J=b instanceof f?b:new f(0,"UNKNOWN","Unknown error");g("error",D(J.code))}finally{s.value=!1}},R=async()=>{c.value=!0;try{await Ce(E.WALLET(a)),g("success","Wallet terminated"),window.location.hash="#/wallets"}catch(b){const J=b instanceof f?b:new f(0,"UNKNOWN","Unknown error");g("error",D(J.code))}finally{c.value=!1}},te=()=>{i.value=t.value.name,l.value=!0},ht=()=>{l.value=!1},_e=async()=>{m.value=!0;try{const b=await ne(E.MCP_TOKENS,{walletId:a});o.value=b,g("success","MCP token provisioned successfully")}catch(b){const J=b instanceof f?b:new f(0,"UNKNOWN","Unknown error");g("error",D(J.code))}finally{m.value=!1}},ze=async()=>{d.value=!0;try{const b=await K(E.WALLET_NETWORKS(a));u.value=b.availableNetworks??[]}catch(b){const J=b instanceof f?b:new f(0,"UNKNOWN","Unknown error");g("error",D(J.code)),u.value=[]}finally{d.value=!1}},mt=async()=>{k.value=!0;try{h.value=await K(E.ADMIN_WALLET_BALANCE(a))}catch{h.value=null}finally{k.value=!1}},pt=async()=>{w.value=!0;try{const b=await K(E.ADMIN_WALLET_TRANSACTIONS(a));C.value=b.items}catch{C.value=[]}finally{w.value=!1}},ft=async()=>{N.value=!0;try{F.value=await K(E.WALLET_WC_SESSION(a))}catch{F.value=null}finally{N.value=!1}},_t=()=>{P.value&&clearInterval(P.value),P.value=setInterval(async()=>{try{const b=await K(E.WALLET_WC_PAIR_STATUS(a));b.status==="connected"?(P.value&&clearInterval(P.value),P.value=null,_.value=!1,I.value=null,F.value=b.session??null,g("success","Wallet connected via WalletConnect")):(b.status==="expired"||b.status==="none")&&(P.value&&clearInterval(P.value),P.value=null,_.value=!1,I.value=null,g("error","Pairing expired. Try again."))}catch{}},3e3)},yt=async()=>{B.value=!0;try{const b=await ne(E.WALLET_WC_PAIR(a));I.value=b,_.value=!0,_t()}catch(b){const J=b instanceof f?b:new f(0,"UNKNOWN","Unknown error");g("error",D(J.code))}finally{B.value=!1}},gt=async()=>{O.value=!0;try{await Ce(E.WALLET_WC_SESSION(a)),F.value=null,g("success","WalletConnect session disconnected")}catch(b){const J=b instanceof f?b:new f(0,"UNKNOWN","Unknown error");g("error",D(J.code))}finally{O.value=!1}},Ge=()=>{q.value=t.value?.ownerAddress??"",G.value=!0},bt=()=>{G.value=!1},y=async()=>{if(!q.value.trim()){g("error","Owner address is required");return}Q.value=!0;try{const b=await le(E.WALLET_OWNER(a),{owner_address:q.value.trim()});t.value={...t.value,...b},G.value=!1,g("success","Owner address updated")}catch(b){const J=b instanceof f?b:new f(0,"UNKNOWN","Unknown error");g("error",D(J.code))}finally{Q.value=!1}},H=async b=>{p.value=!0;try{await le(E.WALLET_DEFAULT_NETWORK(a),{network:b}),g("success",`Default network changed to ${b}`),await j(),await ze()}catch(J){const qa=J instanceof f?J:new f(0,"UNKNOWN","Unknown error");g("error",D(qa.code))}finally{p.value=!1}};return L(()=>{j(),ze(),mt(),pt(),ft()},[a]),L(()=>()=>{P.value&&clearInterval(P.value)},[]),e("div",{class:"page",children:[e("a",{href:"#/wallets",class:"back-link",children:"← Back to Wallets"}),n.value?e("div",{class:"stat-skeleton",style:{height:"200px",marginTop:"var(--space-4)"}}):t.value?e("div",{class:"wallet-detail",children:[e("div",{class:"detail-header",children:[e("div",{class:"detail-name",children:l.value?e("div",{class:"inline-edit",children:[e("input",{value:i.value,onInput:b=>{i.value=b.target.value},class:"inline-edit-input"}),e(A,{size:"sm",onClick:T,loading:s.value,children:"Save"}),e(A,{size:"sm",variant:"secondary",onClick:ht,children:"Cancel"})]}):e("span",{children:[t.value.name,e("button",{class:"btn btn-ghost btn-sm",onClick:te,title:"Edit name",children:"✎"})]})}),e(A,{variant:"danger",onClick:()=>{r.value=!0},children:"Terminate Wallet"})]}),e("div",{class:"detail-grid",children:[e(X,{label:"ID",value:t.value.id,copy:!0}),e(X,{label:"Public Key",value:t.value.publicKey,copy:!0}),e(X,{label:"Chain",value:t.value.chain}),e(X,{label:"Environment",children:e(W,{variant:t.value.environment==="mainnet"?"warning":"info",children:t.value.environment})}),e(X,{label:"Default Network",value:t.value.defaultNetwork??t.value.network}),e(X,{label:"Status",children:e(W,{variant:t.value.status==="ACTIVE"?"success":"danger",children:t.value.status})}),e(X,{label:"Created",value:ie(t.value.createdAt)}),e(X,{label:"Updated",value:t.value.updatedAt?ie(t.value.updatedAt):"Never"})]}),e("div",{class:"balance-section",style:{marginTop:"var(--space-6)"},children:[e("h3",{style:{marginBottom:"var(--space-3)"},children:"Balance"}),k.value?e("div",{class:"stat-skeleton",style:{height:"60px"}}):h.value?.native?e("div",{children:[e(X,{label:"Native",value:`${h.value.native.balance} ${h.value.native.symbol} (${h.value.native.network})`}),h.value.tokens.length>0?h.value.tokens.map(b=>e(X,{label:b.symbol,value:b.balance},b.address)):e("p",{style:{color:"var(--color-text-secondary)",marginTop:"var(--space-2)"},children:"No tokens registered"})]}):e("p",{style:{color:"var(--color-text-secondary)"},children:h.value?.error??"Balance unavailable"})]}),e("div",{class:"networks-section",style:{marginTop:"var(--space-6)"},children:[e("h3",{style:{marginBottom:"var(--space-3)"},children:"Available Networks"}),d.value?e("div",{class:"stat-skeleton",style:{height:"80px"}}):e("div",{style:{display:"flex",flexDirection:"column",gap:"var(--space-2)"},children:(u.value??[]).map(b=>e("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"var(--space-2) var(--space-3)",background:"var(--color-bg-secondary)",borderRadius:"var(--radius-md)"},children:[e("span",{children:[b.name??b.network,b.isDefault&&e(W,{variant:"success",style:{marginLeft:"var(--space-2)"},children:"Default"})]}),!b.isDefault&&t.value?.status==="ACTIVE"&&e(A,{size:"sm",variant:"secondary",onClick:()=>H(b.network),loading:p.value,children:"Set Default"})]},b.network))})]}),e("div",{class:"transactions-section",style:{marginTop:"var(--space-6)"},children:[e("h3",{style:{marginBottom:"var(--space-3)"},children:"Recent Transactions"}),e(we,{columns:[{key:"createdAt",header:"Time",render:b=>b.createdAt?ie(b.createdAt):"--"},{key:"type",header:"Type",render:b=>b.type},{key:"toAddress",header:"To",render:b=>b.toAddress?xt(b.toAddress):"--"},{key:"amount",header:"Amount",render:b=>b.amount??"--"},{key:"status",header:"Status",render:b=>e(W,{variant:b.status==="CONFIRMED"?"success":b.status==="FAILED"?"danger":"warning",children:b.status})},{key:"network",header:"Network",render:b=>b.network??"--"}],data:C.value,loading:w.value,emptyMessage:"No transactions yet"})]}),e("div",{class:"owner-section",style:{marginTop:"var(--space-6)"},children:[e("h3",{style:{marginBottom:"var(--space-3)"},children:"Owner Wallet"}),t.value.ownerState==="NONE"&&t.value.status!=="TERMINATED"&&e("div",{style:{background:"var(--color-bg-secondary)",border:"1px solid var(--color-border)",borderRadius:"var(--radius-md)",padding:"var(--space-3) var(--space-4)",marginBottom:"var(--space-4)"},children:[e("p",{style:{marginBottom:"var(--space-2)",fontWeight:500},children:"What is an Owner Wallet?"}),e("p",{style:{color:"var(--color-text-secondary)",fontSize:"0.85rem",marginBottom:"var(--space-3)"},children:"Register an Owner wallet to enable transaction approval (APPROVAL policy) for high-value transfers. Connect D'CENT, MetaMask, or other WalletConnect-compatible wallets to approve transactions directly."}),e(A,{size:"sm",onClick:Ge,children:"Set Owner Address"})]}),e(X,{label:"Address",children:G.value?e("div",{class:"inline-edit",children:[e("input",{value:q.value,onInput:b=>{q.value=b.target.value},class:"inline-edit-input",placeholder:"Enter owner wallet address"}),e(A,{size:"sm",onClick:y,loading:Q.value,children:"Save"}),e(A,{size:"sm",variant:"secondary",onClick:bt,children:"Cancel"})]}):e("span",{children:[t.value.ownerAddress?e(V,{children:[xt(t.value.ownerAddress),e(He,{value:t.value.ownerAddress})]}):"Not set",t.value.ownerState!=="LOCKED"&&t.value.status==="ACTIVE"&&e("button",{class:"btn btn-ghost btn-sm",onClick:Ge,title:"Set owner address",children:"✎"})]})}),e(X,{label:"State",children:e(W,{variant:Ba(t.value.ownerState),children:t.value.ownerState})}),t.value.ownerState==="GRACE"&&e("div",{style:{background:"var(--color-bg-secondary)",border:"1px solid var(--color-border)",borderRadius:"var(--radius-md)",padding:"var(--space-3) var(--space-4)",marginTop:"var(--space-3)"},children:[e("p",{style:{marginBottom:"var(--space-2)",fontWeight:500,fontSize:"0.85rem"},children:"Verify Owner"}),e("p",{style:{color:"var(--color-text-secondary)",fontSize:"0.85rem"},children:"Sign a verification message with the Owner wallet to transition from GRACE to LOCKED. Connect via WalletConnect first, then trigger an APPROVAL-tier transaction or use the CLI/SDK to call the verify endpoint."})]}),e("div",{style:{marginTop:"var(--space-4)",paddingTop:"var(--space-3)",borderTop:"1px solid var(--color-border)"},children:[e("h4",{style:{marginBottom:"var(--space-2)",fontSize:"0.9rem"},children:"WalletConnect"}),N.value?e("div",{class:"stat-skeleton",style:{height:"60px"}}):F.value?e("div",{children:[e(X,{label:"Status",children:e(W,{variant:"success",children:"Connected"})}),e(X,{label:"Peer",value:F.value.peerName??"Unknown"}),e(X,{label:"Chain ID",value:F.value.chainId}),e(X,{label:"Expires",value:ie(F.value.expiry)}),e("div",{style:{marginTop:"var(--space-3)"},children:e(A,{variant:"danger",onClick:gt,loading:O.value,children:"Disconnect"})})]}):e("div",{children:[e("p",{style:{marginBottom:"var(--space-3)",color:"var(--color-text-secondary)",fontSize:"0.85rem"},children:"Connect an external wallet (D'CENT, MetaMask, Phantom) via WalletConnect for transaction approval."}),t.value?.ownerAddress?e(A,{onClick:yt,loading:B.value,children:"Connect Wallet"}):e("p",{style:{color:"var(--color-text-secondary)",fontSize:"0.85rem"},children:"Set an Owner address first to enable WalletConnect."})]})]})]}),e("div",{class:"mcp-setup-section",style:{marginTop:"var(--space-6)"},children:[e("h3",{style:{marginBottom:"var(--space-3)"},children:"MCP Setup"}),o.value?e("div",{children:[e("div",{class:"detail-grid",style:{marginBottom:"var(--space-4)"},children:[e(X,{label:"Token Path",value:o.value.tokenPath}),e(X,{label:"Expires At",value:ie(o.value.expiresAt)})]}),e("div",{style:{marginBottom:"var(--space-2)"},children:e("strong",{children:"Claude Desktop Config"})}),e("div",{style:{position:"relative"},children:[e("pre",{children:e("code",{style:{display:"block",whiteSpace:"pre-wrap",wordBreak:"break-all",background:"var(--color-bg-secondary)",padding:"var(--space-3)",borderRadius:"var(--radius-md)",fontSize:"0.85rem",maxHeight:"300px",overflow:"auto"},children:JSON.stringify({mcpServers:o.value.claudeDesktopConfig},null,2)})}),e("div",{style:{marginTop:"var(--space-2)"},children:e(He,{value:JSON.stringify({mcpServers:o.value.claudeDesktopConfig},null,2),label:"Copy Config"})})]}),e("div",{style:{marginTop:"var(--space-3)"},children:e(A,{variant:"secondary",onClick:_e,loading:m.value,children:"Re-provision"})})]}):e("div",{children:[e("p",{style:{marginBottom:"var(--space-3)",color:"var(--color-text-secondary)"},children:"Provision an MCP token for Claude Desktop integration."}),e(A,{onClick:_e,loading:m.value,children:"Setup MCP"})]})]}),e(re,{open:r.value,title:"Terminate Wallet",onCancel:()=>{r.value=!1},onConfirm:R,confirmText:"Terminate",confirmVariant:"danger",loading:c.value,children:e("p",{children:["Are you sure you want to terminate wallet ",e("strong",{children:t.value.name}),"? This action cannot be undone."]})}),e(re,{open:_.value,title:"Scan QR Code",onCancel:()=>{_.value=!1,P.value&&clearInterval(P.value),P.value=null},children:I.value&&e("div",{style:{textAlign:"center"},children:[e("img",{src:I.value.qrCode,alt:"WalletConnect QR Code",style:{width:"280px",height:"280px",margin:"0 auto"}}),e("p",{style:{marginTop:"var(--space-3)",color:"var(--color-text-secondary)",fontSize:"0.85rem"},children:"Scan with D'CENT, MetaMask, Phantom, or any WalletConnect-compatible wallet"}),e("p",{style:{marginTop:"var(--space-2)",color:"var(--color-text-secondary)",fontSize:"0.75rem"},children:"Waiting for connection..."})]})})]}):e(Wn,{title:"Wallet not found",description:"The wallet may have been deleted."})]})}const Vn=["solana_mainnet","solana_devnet","solana_testnet"],qn=["evm_ethereum_mainnet","evm_ethereum_sepolia","evm_polygon_mainnet","evm_polygon_amoy","evm_arbitrum_mainnet","evm_arbitrum_sepolia","evm_optimism_mainnet","evm_optimism_sepolia","evm_base_mainnet","evm_base_sepolia"],zn={solana_mainnet:"RPC endpoint URL for Solana mainnet",solana_devnet:"RPC endpoint URL for Solana devnet",solana_testnet:"RPC endpoint URL for Solana testnet",evm_ethereum_mainnet:"RPC endpoint URL for Ethereum mainnet",evm_ethereum_sepolia:"RPC endpoint URL for Ethereum Sepolia testnet",evm_polygon_mainnet:"RPC endpoint URL for Polygon mainnet",evm_polygon_amoy:"RPC endpoint URL for Polygon Amoy testnet",evm_arbitrum_mainnet:"RPC endpoint URL for Arbitrum mainnet",evm_arbitrum_sepolia:"RPC endpoint URL for Arbitrum Sepolia testnet",evm_optimism_mainnet:"RPC endpoint URL for Optimism mainnet",evm_optimism_sepolia:"RPC endpoint URL for Optimism Sepolia testnet",evm_base_mainnet:"RPC endpoint URL for Base mainnet",evm_base_sepolia:"RPC endpoint URL for Base Sepolia testnet"},na={enabled:"Enable or disable balance monitoring",check_interval_sec:"How often to check wallet balances",low_balance_threshold_sol:"Alert when SOL balance drops below this amount",low_balance_threshold_eth:"Alert when ETH balance drops below this amount",cooldown_hours:"Suppress duplicate alerts for this many hours"},Gn=[{label:"Ethereum Mainnet",value:"ethereum-mainnet"},{label:"Ethereum Sepolia",value:"ethereum-sepolia"},{label:"Polygon Mainnet",value:"polygon-mainnet"},{label:"Polygon Amoy",value:"polygon-amoy"},{label:"Arbitrum Mainnet",value:"arbitrum-mainnet"},{label:"Arbitrum Sepolia",value:"arbitrum-sepolia"},{label:"Optimism Mainnet",value:"optimism-mainnet"},{label:"Optimism Sepolia",value:"optimism-sepolia"},{label:"Base Mainnet",value:"base-mainnet"},{label:"Base Sepolia",value:"base-sepolia"}];function jn(){const a=v({}),t=v({}),n=v(!1),l=v(!0),i=v({}),s=v({}),r=async()=>{try{const h=await K(E.ADMIN_SETTINGS);a.value=h}catch(h){const k=h instanceof f?h:new f(0,"UNKNOWN","Unknown error");g("error",D(k.code))}finally{l.value=!1}};L(()=>{r()},[]);const c=(h,k)=>{const C=String(k);t.value={...t.value,[h]:C}},m=async()=>{n.value=!0;try{const h=Object.entries(t.value).filter(([k])=>k.startsWith("rpc.")).map(([k,C])=>({key:k,value:C}));await le(E.ADMIN_SETTINGS,{settings:h}),t.value={},await r(),g("success","Settings saved and applied")}catch(h){const k=h instanceof f?h:new f(0,"UNKNOWN","Unknown error");g("error",D(k.code))}finally{n.value=!1}},o=()=>{t.value={}};L(()=>(pe({id:"wallets-rpc",isDirty:()=>Object.keys(t.value).filter(h=>h.startsWith("rpc.")).length>0,save:m,discard:o}),()=>fe("wallets-rpc")),[]);const u=async h=>{const k=h.split(".")[1]??"",C=M(a.value,t.value,"rpc",k);if(!C){g("warning","Enter a URL before testing");return}const w=k.startsWith("solana")?"solana":"evm";s.value={...s.value,[h]:!0};try{const _=await ne(E.ADMIN_SETTINGS_TEST_RPC,{url:C,chain:w});i.value={...i.value,[h]:_}}catch{i.value={...i.value,[h]:{success:!1,latencyMs:0,error:"Request failed"}}}finally{s.value={...s.value,[h]:!1}}};function d({shortKey:h}){const k=`rpc.${h}`,C=i.value[k],w=s.value[k];return e("div",{class:"settings-field-full",children:[e("div",{class:"rpc-field-row",children:[e(S,{label:x(h),name:k,type:"text",value:M(a.value,t.value,"rpc",h),onChange:_=>c(k,_),placeholder:"https://...",description:zn[h]}),e(A,{variant:"ghost",size:"sm",onClick:()=>u(k),loading:!!w,children:"Test"})]}),C&&e("div",{class:`rpc-test-result ${C.success?"rpc-test-result--success":"rpc-test-result--failure"}`,children:[e(W,{variant:C.success?"success":"danger",children:C.success?"OK":"FAIL"}),e("span",{children:[C.latencyMs,"ms"]}),C.blockNumber!==void 0&&e("span",{children:[" (block #",C.blockNumber.toLocaleString(),")"]}),C.error&&e("span",{children:[" - ",C.error]})]})]})}const p=Object.keys(t.value).filter(h=>h.startsWith("rpc.")).length;return l.value?e("div",{class:"empty-state",children:e("p",{children:"Loading settings..."})}):e(V,{children:[p>0&&e("div",{class:"settings-save-bar",children:[e("span",{children:[p," unsaved change",p>1?"s":""]}),e("div",{class:"settings-save-bar-actions",children:[e(A,{variant:"ghost",size:"sm",onClick:o,children:"Discard"}),e(A,{variant:"primary",size:"sm",onClick:m,loading:n.value,children:"Save"})]})]}),e("div",{class:"settings-category",children:[e("div",{class:"settings-category-header",children:[e("h3",{children:"RPC Endpoints"}),e("p",{class:"settings-description",children:"Configure blockchain RPC URLs for Solana and EVM networks"})]}),e("div",{class:"settings-category-body",children:[e("div",{class:"settings-subgroup",children:[e("div",{class:"settings-subgroup-title",children:"Solana"}),e("div",{class:"settings-fields-grid",children:Vn.map(h=>e(d,{shortKey:h},h))})]}),e("div",{class:"settings-subgroup",children:[e("div",{class:"settings-subgroup-title",children:"EVM"}),e("div",{class:"settings-fields-grid",children:[qn.map(h=>e(d,{shortKey:h},h)),e("div",{class:"settings-field-full",children:e(S,{label:x("evm_default_network"),name:"rpc.evm_default_network",type:"select",value:M(a.value,t.value,"rpc","evm_default_network")||"ethereum-sepolia",onChange:h=>c("rpc.evm_default_network",h),options:Gn,description:"Default EVM network for new wallets"})})]})]})]})]})]})}function Yn(){const a=v({}),t=v({}),n=v(!1),l=v(!0),i=async()=>{try{const u=await K(E.ADMIN_SETTINGS);a.value=u}catch(u){const d=u instanceof f?u:new f(0,"UNKNOWN","Unknown error");g("error",D(d.code))}finally{l.value=!1}};L(()=>{i()},[]);const s=(u,d)=>{const p=String(d);t.value={...t.value,[u]:p}},r=async()=>{n.value=!0;try{const u=Object.entries(t.value).filter(([d])=>d.startsWith("monitoring.")).map(([d,p])=>({key:d,value:p}));await le(E.ADMIN_SETTINGS,{settings:u}),t.value={},await i(),g("success","Settings saved and applied")}catch(u){const d=u instanceof f?u:new f(0,"UNKNOWN","Unknown error");g("error",D(d.code))}finally{n.value=!1}},c=()=>{t.value={}};L(()=>(pe({id:"wallets-monitoring",isDirty:()=>Object.keys(t.value).filter(u=>u.startsWith("monitoring.")).length>0,save:r,discard:c}),()=>fe("wallets-monitoring")),[]);const m=[{key:"enabled",type:"checkbox"},{key:"check_interval_sec",type:"number",min:60,max:86400},{key:"low_balance_threshold_sol",type:"number",min:0},{key:"low_balance_threshold_eth",type:"number",min:0},{key:"cooldown_hours",type:"number",min:1,max:168}],o=Object.keys(t.value).filter(u=>u.startsWith("monitoring.")).length;return l.value?e("div",{class:"empty-state",children:e("p",{children:"Loading settings..."})}):e(V,{children:[o>0&&e("div",{class:"settings-save-bar",children:[e("span",{children:[o," unsaved change",o>1?"s":""]}),e("div",{class:"settings-save-bar-actions",children:[e(A,{variant:"ghost",size:"sm",onClick:c,children:"Discard"}),e(A,{variant:"primary",size:"sm",onClick:r,loading:n.value,children:"Save"})]})]}),e("div",{class:"settings-category",children:[e("div",{class:"settings-category-header",children:[e("h3",{children:"Balance Monitoring"}),e("p",{class:"settings-description",children:"Periodic balance checks for all active wallets. Sends LOW_BALANCE alerts when native token balance drops below thresholds. Changes apply immediately."})]}),e("div",{class:"settings-category-body",children:[e("div",{class:"settings-fields-grid",children:m.map(u=>u.type==="checkbox"?e("div",{class:"settings-field-full",children:e(S,{label:x(u.key),name:`monitoring.${u.key}`,type:"checkbox",value:Ee(a.value,t.value,"monitoring",u.key),onChange:d=>s(`monitoring.${u.key}`,d),description:na[u.key]})},u.key):e(S,{label:x(u.key),name:`monitoring.${u.key}`,type:"number",value:Number(M(a.value,t.value,"monitoring",u.key))||0,onChange:d=>s(`monitoring.${u.key}`,d),min:u.min,max:u.max,description:na[u.key]},u.key))}),e("div",{class:"settings-info-box",children:"Monitors all active wallet native token balances (SOL, ETH) at the configured interval. When balance drops below threshold, a LOW_BALANCE notification is sent. Duplicate alerts are suppressed for the cooldown period (per wallet)."})]})]})]})}function Jn(){const a=v({}),t=v({}),n=v(!1),l=v(!0),i=async()=>{try{const o=await K(E.ADMIN_SETTINGS);a.value=o}catch(o){const u=o instanceof f?o:new f(0,"UNKNOWN","Unknown error");g("error",D(u.code))}finally{l.value=!1}};L(()=>{i()},[]);const s=(o,u)=>{const d=String(u);t.value={...t.value,[o]:d}},r=async()=>{n.value=!0;try{const o=Object.entries(t.value).filter(([u])=>u.startsWith("walletconnect.")).map(([u,d])=>({key:u,value:d}));await le(E.ADMIN_SETTINGS,{settings:o}),t.value={},await i(),g("success","Settings saved and applied")}catch(o){const u=o instanceof f?o:new f(0,"UNKNOWN","Unknown error");g("error",D(u.code))}finally{n.value=!1}},c=()=>{t.value={}};L(()=>(pe({id:"wallets-walletconnect",isDirty:()=>Object.keys(t.value).filter(o=>o.startsWith("walletconnect.")).length>0,save:r,discard:c}),()=>fe("wallets-walletconnect")),[]);const m=Object.keys(t.value).filter(o=>o.startsWith("walletconnect.")).length;return l.value?e("div",{class:"empty-state",children:e("p",{children:"Loading settings..."})}):e(V,{children:[m>0&&e("div",{class:"settings-save-bar",children:[e("span",{children:[m," unsaved change",m>1?"s":""]}),e("div",{class:"settings-save-bar-actions",children:[e(A,{variant:"ghost",size:"sm",onClick:c,children:"Discard"}),e(A,{variant:"primary",size:"sm",onClick:r,loading:n.value,children:"Save"})]})]}),e("div",{class:"settings-category",children:[e("div",{class:"settings-category-header",children:[e("h3",{children:"WalletConnect"}),e("p",{class:"settings-description",children:"WalletConnect integration for dApp connections"})]}),e("div",{class:"settings-category-body",children:[e("div",{class:"settings-fields-grid",children:[e("div",{class:"settings-field-full",children:e(S,{label:x("project_id"),name:"walletconnect.project_id",type:"text",value:M(a.value,t.value,"walletconnect","project_id"),onChange:o=>s("walletconnect.project_id",o),description:"WalletConnect Cloud project identifier"})}),e("div",{class:"settings-field-full",children:e(S,{label:x("relay_url"),name:"walletconnect.relay_url",type:"text",value:M(a.value,t.value,"walletconnect","relay_url"),onChange:o=>s("walletconnect.relay_url",o),placeholder:"wss://relay.walletconnect.com",description:"WalletConnect relay server URL"})})]}),e("div",{class:"settings-info-box",children:["Get your project ID from"," ",e("a",{href:"https://cloud.walletconnect.com",target:"_blank",rel:"noopener noreferrer",children:"https://cloud.walletconnect.com"})," ","— Create a free account and project to obtain your project ID."]}),e("div",{class:"settings-info-box",children:"Relay URL defaults to wss://relay.walletconnect.com if not set."})]})]})]})}function Xn(){const a=v([]),t=v(!0),n=v(!1),l=v(""),i=v("solana"),s=v("testnet"),r=v(null),c=v(!1),m=v(null),o=async()=>{try{const h=await K(E.WALLETS);a.value=h.items}catch(h){const k=h instanceof f?h:new f(0,"UNKNOWN","Unknown error");g("error",D(k.code))}finally{t.value=!1}},u=async()=>{if(!l.value.trim()){r.value="Name is required";return}r.value=null,c.value=!0;try{const h=await ne(E.WALLETS,{name:l.value.trim(),chain:i.value,environment:s.value});h.session?.token?(m.value=h.session.token,g("success","Wallet created with session")):g("success","Wallet created"),l.value="",i.value="solana",s.value="testnet",n.value=!1,t.value=!0,await o()}catch(h){const k=h instanceof f?h:new f(0,"UNKNOWN","Unknown error");r.value=D(k.code)}finally{c.value=!1}},d=h=>{window.location.hash="#/wallets/"+h.id},p=h=>{i.value=h};return L(()=>{o()},[]),e(V,{children:[e("div",{class:"page-actions",children:!n.value&&e(A,{onClick:()=>{n.value=!0},children:"Create Wallet"})}),n.value&&e("div",{class:"inline-form",children:[e(S,{label:"Name",name:"name",value:l.value,onChange:h=>{l.value=h},required:!0,placeholder:"e.g. trading-bot",error:r.value??void 0}),e(S,{label:"Chain",name:"chain",type:"select",value:i.value,onChange:p,options:[{label:"Solana",value:"solana"},{label:"Ethereum",value:"ethereum"}]}),e(S,{label:"Environment",name:"environment",type:"select",value:s.value,onChange:h=>{s.value=h},options:[{label:"Testnet",value:"testnet"},{label:"Mainnet",value:"mainnet"}]}),e("div",{class:"inline-form-actions",children:[e(A,{onClick:u,loading:c.value,children:"Create"}),e(A,{variant:"secondary",onClick:()=>{n.value=!1,r.value=null},children:"Cancel"})]})]}),m.value&&e("div",{class:"inline-form",style:{marginBottom:"1rem"},children:[e("div",{style:{fontWeight:"bold",marginBottom:"0.5rem"},children:"Session Token (copy now — shown only once)"}),e("div",{style:{display:"flex",gap:"0.5rem",alignItems:"center"},children:[e("input",{type:"text",readOnly:!0,value:m.value,style:{flex:1,fontFamily:"monospace",fontSize:"0.85rem",padding:"0.5rem"},onClick:h=>h.target.select()}),e(A,{variant:"secondary",onClick:()=>{navigator.clipboard.writeText(m.value),g("success","Token copied")},children:"Copy"}),e(A,{variant:"secondary",onClick:()=>{m.value=null},children:"Dismiss"})]})]}),e(we,{columns:Hn,data:a.value,loading:t.value,onRowClick:d,emptyMessage:"No wallets yet"})]})}const la=[{key:"wallets",label:"Wallets"},{key:"rpc",label:"RPC Endpoints"},{key:"monitoring",label:"Balance Monitoring"},{key:"walletconnect",label:"WalletConnect"}];function Zn(){const a=v("wallets");return L(()=>{const t=Y.value;t&&t.tab&&(a.value=t.tab,setTimeout(()=>{se.value=t.fieldName},100),Y.value=null)},[Y.value]),e("div",{class:"page",children:[e(qe,{pageName:"Wallets",tabName:la.find(t=>t.key===a.value)?.label??"",onPageClick:()=>{a.value="wallets"}}),e(Ve,{tabs:la,activeTab:a.value,onTabChange:t=>{a.value=t}}),a.value==="wallets"&&e(Xn,{}),a.value==="rpc"&&e(jn,{}),a.value==="monitoring"&&e(Yn,{}),a.value==="walletconnect"&&e(Jn,{})]})}function ia(){const a=ue.value,t=a.startsWith("/wallets/")?a.slice(9):null;return t?e(Bn,{id:t}):e(Zn,{})}function Ie({legend:a,children:t,description:n}){return e("fieldset",{class:"field-group",children:[e("legend",{class:"field-group-legend",children:a}),n&&e("p",{class:"field-group-description",children:n}),e("div",{class:"field-group-body",children:t})]})}function Qn(a,t,n){t.value=a,n.value=!0}const sa=[{key:"sessions",label:"Sessions"},{key:"settings",label:"Settings"}],St=["security.session_ttl","security.session_absolute_lifetime","security.session_max_renewals","security.max_sessions_per_wallet","security.max_pending_tx","security.rate_limit_session_rpm","security.rate_limit_tx_rpm"];function el(){const a=v({}),t=v({}),n=v(!1),l=v(!0),i=async()=>{try{const o=await K(E.ADMIN_SETTINGS);a.value=o}catch(o){const u=o instanceof f?o:new f(0,"UNKNOWN","Unknown error");g("error",D(u.code))}finally{l.value=!1}};L(()=>{i()},[]);const s=(o,u)=>{const d=String(u);t.value={...t.value,[o]:d}},r=async()=>{n.value=!0;try{const o=Object.entries(t.value).filter(([u])=>St.includes(u)).map(([u,d])=>({key:u,value:d}));await le(E.ADMIN_SETTINGS,{settings:o}),t.value={},await i(),g("success","Session settings saved and applied")}catch(o){const u=o instanceof f?o:new f(0,"UNKNOWN","Unknown error");g("error",D(u.code))}finally{n.value=!1}},c=()=>{t.value={}};L(()=>(pe({id:"sessions-settings",isDirty:()=>Object.keys(t.value).filter(o=>St.includes(o)).length>0,save:r,discard:c}),()=>fe("sessions-settings")),[]);const m=Object.keys(t.value).filter(o=>St.includes(o)).length;return l.value?e("div",{class:"empty-state",children:e("p",{children:"Loading settings..."})}):e(V,{children:[m>0&&e("div",{class:"settings-save-bar",children:[e("span",{children:[m," unsaved change",m>1?"s":""]}),e("div",{class:"settings-save-bar-actions",children:[e(A,{variant:"ghost",size:"sm",onClick:c,children:"Discard"}),e(A,{variant:"primary",size:"sm",onClick:r,loading:n.value,children:"Save"})]})]}),e("div",{class:"settings-category",children:[e("div",{class:"settings-category-header",children:[e("h3",{children:"Session Configuration"}),e("p",{class:"settings-description",children:"Configure session lifetime, renewal limits, and request rate limiting. Changes apply immediately without daemon restart."})]}),e("div",{class:"settings-category-body",children:[e(Ie,{legend:"Lifetime",description:"Session duration and renewal limits",children:e("div",{class:"settings-fields-grid",children:[e(S,{label:x("session_ttl"),name:"security.session_ttl",type:"number",value:Number(M(a.value,t.value,"security","session_ttl"))||0,onChange:o=>s("security.session_ttl",o),min:300,description:"How long a session token is valid before renewal"}),e(S,{label:x("session_absolute_lifetime"),name:"security.session_absolute_lifetime",type:"number",value:Number(M(a.value,t.value,"security","session_absolute_lifetime"))||0,onChange:o=>s("security.session_absolute_lifetime",o),min:0,description:"Maximum total session duration regardless of renewals"}),e(S,{label:x("session_max_renewals"),name:"security.session_max_renewals",type:"number",value:Number(M(a.value,t.value,"security","session_max_renewals"))||0,onChange:o=>s("security.session_max_renewals",o),min:0,description:"Maximum number of times a session can be renewed"}),e(S,{label:x("max_sessions_per_wallet"),name:"security.max_sessions_per_wallet",type:"number",value:Number(M(a.value,t.value,"security","max_sessions_per_wallet"))||0,onChange:o=>s("security.max_sessions_per_wallet",o),min:1,max:100,description:"Maximum concurrent sessions for a single wallet"})]})}),e(Ie,{legend:"Rate Limits",description:"Request throttling per session and transaction",children:e("div",{class:"settings-fields-grid",children:[e(S,{label:x("max_pending_tx"),name:"security.max_pending_tx",type:"number",value:Number(M(a.value,t.value,"security","max_pending_tx"))||0,onChange:o=>s("security.max_pending_tx",o),min:1,max:100,description:"Maximum in-flight transactions per session"}),e(S,{label:x("rate_limit_session_rpm"),name:"security.rate_limit_session_rpm",type:"number",value:Number(M(a.value,t.value,"security","rate_limit_session_rpm"))||0,onChange:o=>s("security.rate_limit_session_rpm",o),min:10,description:"Max requests per minute per session"}),e(S,{label:x("rate_limit_tx_rpm"),name:"security.rate_limit_tx_rpm",type:"number",value:Number(M(a.value,t.value,"security","rate_limit_tx_rpm"))||0,onChange:o=>s("security.rate_limit_tx_rpm",o),min:1,description:"Max transaction requests per minute per session"})]})})]})]})]})}function tl(){const a=v("sessions");L(()=>{const _=Y.value;_&&_.tab&&(a.value=_.tab,setTimeout(()=>{se.value=_.fieldName},100),Y.value=null)},[Y.value]);const t=v([]),n=v(""),l=v([]),i=v(!1),s=v(!0),r=v(!1),c=v(!1),m=v(""),o=v(!1),u=v(""),d=v(!1),p=async()=>{try{const _=await K(E.WALLETS);t.value=_.items.filter(I=>I.status==="ACTIVE")}catch(_){const I=_ instanceof f?_:new f(0,"UNKNOWN","Unknown error");g("error",D(I.code))}finally{s.value=!1}},h=async()=>{i.value=!0;try{const _=n.value?`${E.SESSIONS}?walletId=${n.value}`:E.SESSIONS,I=await K(_);l.value=I}catch(_){const I=_ instanceof f?_:new f(0,"UNKNOWN","Unknown error");g("error",D(I.code))}finally{i.value=!1}},k=async()=>{r.value=!0;try{const _=await ne(E.SESSIONS,{walletId:n.value});m.value=_.token,c.value=!0,await h()}catch(_){const I=_ instanceof f?_:new f(0,"UNKNOWN","Unknown error");g("error",D(I.code))}finally{r.value=!1}},C=async()=>{d.value=!0;try{await Ce(E.SESSION(u.value)),g("success","Session revoked"),o.value=!1,await h()}catch(_){const I=_ instanceof f?_:new f(0,"UNKNOWN","Unknown error");g("error",D(I.code))}finally{d.value=!1}};L(()=>{p()},[]),L(()=>{l.value=[],h()},[n.value]);const w=[{key:"id",header:"ID",render:_=>_.id.slice(0,8)+"..."},{key:"walletName",header:"Wallet",render:_=>_.walletName??_.walletId.slice(0,8)+"..."},{key:"status",header:"Status",render:_=>e(W,{variant:_.status==="ACTIVE"?"success":_.status==="EXPIRED"?"warning":"danger",children:_.status})},{key:"expiresAt",header:"Expires At",render:_=>ie(_.expiresAt)},{key:"renewals",header:"Renewals",render:_=>`${_.renewalCount}/${_.maxRenewals}`},{key:"createdAt",header:"Created",render:_=>ie(_.createdAt)},{key:"actions",header:"Actions",render:_=>_.status==="ACTIVE"?e(A,{size:"sm",variant:"danger",onClick:()=>Qn(_.id,u,o),children:"Revoke"}):null}];return e("div",{class:"page",children:[e(qe,{pageName:"Sessions",tabName:sa.find(_=>_.key===a.value)?.label??"",onPageClick:()=>{a.value="sessions"}}),e(Ve,{tabs:sa,activeTab:a.value,onTabChange:_=>{a.value=_}}),a.value==="sessions"&&e(V,{children:[e("div",{class:"session-controls",children:[e("div",{class:"session-wallet-select",children:[e("label",{for:"wallet-select",children:"Wallet"}),e("select",{id:"wallet-select",value:n.value,onChange:_=>{n.value=_.target.value},disabled:s.value,children:[e("option",{value:"",children:"All Wallets"}),t.value.map(_=>e("option",{value:_.id,children:[_.name," (",_.chain,"/",_.network,")"]},_.id))]})]}),e(A,{onClick:k,disabled:!n.value,loading:r.value,children:"Create Session"})]}),e(we,{columns:w,data:l.value,loading:i.value,emptyMessage:"No sessions"}),e(re,{open:c.value,title:"Session Created",onCancel:()=>{c.value=!1},cancelText:"Close",children:[e("p",{class:"token-warning",children:"Copy this token now. It will not be shown again."}),e("div",{class:"token-display",children:[e("code",{class:"token-value",children:m.value}),e(He,{value:m.value,label:"Copy Token"})]})]}),e(re,{open:o.value,title:"Revoke Session",onCancel:()=>{o.value=!1},onConfirm:C,confirmText:"Revoke",confirmVariant:"danger",loading:d.value,children:e("p",{children:"Are you sure you want to revoke this session? The associated token will be immediately invalidated."})})]}),a.value==="settings"&&e(el,{})]})}function al({rules:a,onChange:t,errors:n}){const l=s=>r=>{t({...a,[s]:r})},i=s=>r=>{const c=Number(r),m={...a};r===""||r===0||Number.isNaN(c)?delete m[s]:m[s]=c,t(m)};return e("div",{class:"policy-form-fields",children:[e("h4",{children:"Native Amount Tiers"}),e("div",{class:"policy-form-grid",children:[e(S,{label:"Instant Max (lamports/wei)",name:"instant_max",value:a.instant_max||"",onChange:l("instant_max"),error:n.instant_max,required:!0}),e(S,{label:"Notify Max (lamports/wei)",name:"notify_max",value:a.notify_max||"",onChange:l("notify_max"),error:n.notify_max,required:!0}),e(S,{label:"Delay Max (lamports/wei)",name:"delay_max",value:a.delay_max||"",onChange:l("delay_max"),error:n.delay_max,required:!0})]}),e("h4",{children:"USD Amount Tiers (Optional)"}),e("div",{class:"policy-form-grid",children:[e(S,{label:"Instant Max USD",name:"instant_max_usd",type:"number",value:a.instant_max_usd??"",onChange:i("instant_max_usd"),placeholder:"Optional"}),e(S,{label:"Notify Max USD",name:"notify_max_usd",type:"number",value:a.notify_max_usd??"",onChange:i("notify_max_usd"),placeholder:"Optional"}),e(S,{label:"Delay Max USD",name:"delay_max_usd",type:"number",value:a.delay_max_usd??"",onChange:i("delay_max_usd"),placeholder:"Optional"})]}),e("h4",{children:"Cumulative USD Limits (Optional)"}),e("div",{class:"policy-form-grid",children:[e(S,{label:"Daily Limit USD (24h rolling)",name:"daily_limit_usd",type:"number",value:a.daily_limit_usd??"",onChange:i("daily_limit_usd"),placeholder:"e.g. 500",error:n.daily_limit_usd}),e(S,{label:"Monthly Limit USD (30d rolling)",name:"monthly_limit_usd",type:"number",value:a.monthly_limit_usd??"",onChange:i("monthly_limit_usd"),placeholder:"e.g. 5000",error:n.monthly_limit_usd})]}),e(S,{label:"Delay Duration (seconds, min 60)",name:"delay_seconds",type:"number",value:a.delay_seconds??900,onChange:l("delay_seconds"),error:n.delay_seconds,required:!0,min:60})]})}function me({items:a,onAdd:t,onRemove:n,renderRow:l,onChange:i,addLabel:s="+ Add",minItems:r=0,error:c}){return e("div",{class:"dynamic-row-list",children:[a.map((m,o)=>e("div",{class:"dynamic-row",children:[e("div",{class:"dynamic-row-fields",children:l(m,o,i)}),e("button",{class:"btn btn-ghost btn-sm dynamic-row-remove",onClick:()=>n(o),disabled:a.length<=r,title:"Remove",children:"x"})]},o)),e("button",{class:"btn btn-secondary btn-sm",onClick:t,children:s}),c&&e("span",{class:"form-error",children:c})]})}function nl({rules:a,onChange:t,errors:n}){const l=a.allowed_addresses||[];return e("div",{class:"policy-form-fields",children:e(me,{items:l,onAdd:()=>t({...a,allowed_addresses:[...l,""]}),onRemove:i=>t({...a,allowed_addresses:l.filter((s,r)=>r!==i)}),onChange:(i,s)=>{const r=[...l];r[i]=s,t({...a,allowed_addresses:r})},renderRow:(i,s,r)=>e(S,{label:`Address ${s+1}`,name:`address-${s}`,value:i,onChange:c=>r(s,c),placeholder:"Wallet address",error:n[`allowed_addresses.${s}`],required:!0}),addLabel:"+ Add Address",error:n.allowed_addresses})})}function ll({rules:a,onChange:t,errors:n}){const l=i=>s=>{t({...a,[i]:s})};return e("div",{class:"policy-form-fields",children:[e(S,{label:"Max Requests",name:"max_requests",type:"number",value:a.max_requests??100,onChange:l("max_requests"),error:n.max_requests,required:!0,min:1}),e(S,{label:"Window (seconds)",name:"window_seconds",type:"number",value:a.window_seconds??3600,onChange:l("window_seconds"),error:n.window_seconds,required:!0,min:1})]})}function il({rules:a,onChange:t,errors:n}){const l=i=>{const s={...a};i===""||i===void 0?delete s.maxAmount:s.maxAmount=i,t(s)};return e("div",{class:"policy-form-fields",children:[e(S,{label:"Max Amount (lamports/wei, optional)",name:"maxAmount",value:a.maxAmount??"",onChange:l,error:n.maxAmount,placeholder:"Leave empty for no limit"}),e(S,{label:"Block Unlimited Approvals",name:"blockUnlimited",type:"checkbox",value:a.blockUnlimited??!0,onChange:i=>t({...a,blockUnlimited:i})})]})}const sl=[{label:"Instant",value:"INSTANT"},{label:"Notify",value:"NOTIFY"},{label:"Delay",value:"DELAY"},{label:"Approval",value:"APPROVAL"}];function rl({rules:a,onChange:t,errors:n}){return e("div",{class:"policy-form-fields",children:e(S,{label:"Override Tier",name:"tier",type:"select",value:a.tier??"DELAY",onChange:l=>t({...a,tier:l}),options:sl,error:n.tier})})}const ol=[{label:"All Chains",value:""},{label:"Solana",value:"solana"},{label:"Ethereum",value:"ethereum"}];function cl({rules:a,onChange:t,errors:n}){const l=a.tokens||[];return e("div",{class:"policy-form-fields",children:e(me,{items:l,onAdd:()=>t({...a,tokens:[...l,{address:"",symbol:"",chain:""}]}),onRemove:i=>t({...a,tokens:l.filter((s,r)=>r!==i)}),onChange:(i,s)=>{const r=[...l];r[i]=s,t({...a,tokens:r})},renderRow:(i,s,r)=>e("div",{class:"dynamic-row-fields",style:{display:"flex",gap:"0.5rem",flex:1},children:[e(S,{label:`Address ${s+1}`,name:`token-addr-${s}`,value:i.address,onChange:c=>r(s,{...i,address:c}),placeholder:"Token mint/contract address",error:n[`tokens.${s}.address`],required:!0}),e(S,{label:"Symbol",name:`token-symbol-${s}`,value:i.symbol,onChange:c=>r(s,{...i,symbol:c}),placeholder:"e.g. USDC"}),e(S,{label:"Chain",name:`token-chain-${s}`,type:"select",value:i.chain,onChange:c=>{const m={...i,chain:c};c||delete m.chain,r(s,m)},options:ol})]}),addLabel:"+ Add Token",error:n.tokens})})}const dl=[{label:"All Chains",value:""},{label:"Solana",value:"solana"},{label:"Ethereum",value:"ethereum"}];function ul({rules:a,onChange:t,errors:n}){const l=a.contracts||[];return e("div",{class:"policy-form-fields",children:e(me,{items:l,onAdd:()=>t({...a,contracts:[...l,{address:"",name:"",chain:""}]}),onRemove:i=>t({...a,contracts:l.filter((s,r)=>r!==i)}),onChange:(i,s)=>{const r=[...l];r[i]=s,t({...a,contracts:r})},renderRow:(i,s,r)=>e("div",{class:"dynamic-row-fields",style:{display:"flex",gap:"0.5rem",flex:1},children:[e(S,{label:`Address ${s+1}`,name:`contract-addr-${s}`,value:i.address,onChange:c=>r(s,{...i,address:c}),placeholder:"Contract address",error:n[`contracts.${s}.address`],required:!0}),e(S,{label:"Name",name:`contract-name-${s}`,value:i.name,onChange:c=>r(s,{...i,name:c}),placeholder:"e.g. Uniswap Router"}),e(S,{label:"Chain",name:`contract-chain-${s}`,type:"select",value:i.chain,onChange:c=>{const m={...i,chain:c};c||delete m.chain,r(s,m)},options:dl})]}),addLabel:"+ Add Contract",error:n.contracts})})}function vl({rules:a,onChange:t,errors:n}){const l=a.methods||[],i=s=>{t({...a,methods:s})};return e("div",{class:"policy-form-fields",children:e(me,{items:l,onAdd:()=>i([...l,{contractAddress:"",selectors:[""]}]),onRemove:s=>i(l.filter((r,c)=>c!==s)),onChange:(s,r)=>{const c=[...l];c[s]=r,i(c)},renderRow:(s,r,c)=>e("div",{style:{flex:1},children:[e(S,{label:`Contract Address ${r+1}`,name:`method-addr-${r}`,value:s.contractAddress,onChange:m=>c(r,{...s,contractAddress:m}),placeholder:"Contract address",error:n[`methods.${r}.contractAddress`],required:!0}),e("div",{style:{marginTop:"0.5rem",marginLeft:"1rem"},children:[e("label",{style:{fontSize:"0.85rem",fontWeight:500},children:"Selectors"}),e(me,{items:s.selectors,onAdd:()=>c(r,{...s,selectors:[...s.selectors,""]}),onRemove:m=>c(r,{...s,selectors:s.selectors.filter((o,u)=>u!==m)}),onChange:(m,o)=>{const u=[...s.selectors];u[m]=o,c(r,{...s,selectors:u})},renderRow:(m,o,u)=>e(S,{label:`Selector ${o+1}`,name:`method-sel-${r}-${o}`,value:m,onChange:d=>u(o,d),placeholder:"e.g. 0xa9059cbb or transfer(address,uint256)",error:n[`methods.${r}.selectors.${o}`],required:!0}),addLabel:"+ Add Selector",error:n[`methods.${r}.selectors`]})]})]}),addLabel:"+ Add Method Entry",error:n.methods})})}function hl({rules:a,onChange:t,errors:n}){const l=a.spenders||[];return e("div",{class:"policy-form-fields",children:e(me,{items:l,onAdd:()=>t({...a,spenders:[...l,{address:"",name:"",maxAmount:""}]}),onRemove:i=>t({...a,spenders:l.filter((s,r)=>r!==i)}),onChange:(i,s)=>{const r=[...l];r[i]=s,s.maxAmount||delete r[i].maxAmount,t({...a,spenders:r})},renderRow:(i,s,r)=>e("div",{class:"dynamic-row-fields",style:{display:"flex",gap:"0.5rem",flex:1},children:[e(S,{label:`Address ${s+1}`,name:`spender-addr-${s}`,value:i.address,onChange:c=>r(s,{...i,address:c}),placeholder:"Spender address",error:n[`spenders.${s}.address`],required:!0}),e(S,{label:"Name",name:`spender-name-${s}`,value:i.name,onChange:c=>r(s,{...i,name:c}),placeholder:"e.g. Uniswap"}),e(S,{label:"Max Amount",name:`spender-max-${s}`,value:i.maxAmount||"",onChange:c=>r(s,{...i,maxAmount:c}),placeholder:"Leave empty for unlimited",error:n[`spenders.${s}.maxAmount`]})]}),addLabel:"+ Add Spender",error:n.spenders})})}const ml=Array.from({length:24},(a,t)=>({label:`${String(t).padStart(2,"0")}:00`,value:String(t)})),pl=Array.from({length:24},(a,t)=>({label:`${String(t+1).padStart(2,"0")}:00`,value:String(t+1)})),fl=[{label:"Sun",value:0},{label:"Mon",value:1},{label:"Tue",value:2},{label:"Wed",value:3},{label:"Thu",value:4},{label:"Fri",value:5},{label:"Sat",value:6}];function _l({rules:a,onChange:t,errors:n}){const l=a.allowed_hours||{start:0,end:24},i=a.allowed_days||[],s=c=>m=>{const o={...l,[c]:Number(m)};t({...a,allowed_hours:o})},r=c=>{const m=i.includes(c)?i.filter(o=>o!==c):[...i,c].sort((o,u)=>o-u);t({...a,allowed_days:m})};return e("div",{class:"policy-form-fields",children:[e("h4",{children:"Allowed Hours"}),e("div",{class:"policy-form-grid",children:[e(S,{label:"Start Hour",name:"allowed_hours_start",type:"select",value:String(l.start),onChange:s("start"),options:ml,error:n.allowed_hours}),e(S,{label:"End Hour",name:"allowed_hours_end",type:"select",value:String(l.end),onChange:s("end"),options:pl})]}),e("h4",{children:"Allowed Days"}),e("div",{style:{display:"flex",gap:"0.75rem",flexWrap:"wrap"},children:fl.map(c=>e("label",{style:{display:"flex",alignItems:"center",gap:"0.25rem",cursor:"pointer"},children:[e("input",{type:"checkbox",checked:i.includes(c.value),onChange:()=>r(c.value)}),c.label]},c.value))}),n.allowed_days&&e("span",{class:"form-error",children:n.allowed_days})]})}const yl=[{label:"mainnet",value:"mainnet"},{label:"devnet",value:"devnet"},{label:"testnet",value:"testnet"},{label:"ethereum-mainnet",value:"ethereum-mainnet"},{label:"ethereum-sepolia",value:"ethereum-sepolia"},{label:"polygon-mainnet",value:"polygon-mainnet"},{label:"polygon-amoy",value:"polygon-amoy"},{label:"arbitrum-mainnet",value:"arbitrum-mainnet"},{label:"arbitrum-sepolia",value:"arbitrum-sepolia"},{label:"optimism-mainnet",value:"optimism-mainnet"},{label:"optimism-sepolia",value:"optimism-sepolia"},{label:"base-mainnet",value:"base-mainnet"},{label:"base-sepolia",value:"base-sepolia"}];function gl({rules:a,onChange:t,errors:n}){const l=a.networks||[];return e("div",{class:"policy-form-fields",children:e(me,{items:l,onAdd:()=>t({...a,networks:[...l,{network:"mainnet",name:""}]}),onRemove:i=>t({...a,networks:l.filter((s,r)=>r!==i)}),onChange:(i,s)=>{const r=[...l];r[i]=s,t({...a,networks:r})},renderRow:(i,s,r)=>e("div",{class:"dynamic-row-fields",style:{display:"flex",gap:"0.5rem",flex:1},children:[e(S,{label:`Network ${s+1}`,name:`network-sel-${s}`,type:"select",value:i.network,onChange:c=>r(s,{...i,network:c}),options:yl,error:n[`networks.${s}.network`],required:!0}),e(S,{label:"Label",name:`network-name-${s}`,value:i.name,onChange:c=>r(s,{...i,name:c}),placeholder:"Optional label"})]}),addLabel:"+ Add Network",error:n.networks})})}function bl({rules:a,onChange:t,errors:n}){const l=a.domains||[];return e("div",{class:"policy-form-fields",children:e(me,{items:l,onAdd:()=>t({...a,domains:[...l,""]}),onRemove:i=>t({...a,domains:l.filter((s,r)=>r!==i)}),onChange:(i,s)=>{const r=[...l];r[i]=s,t({...a,domains:r})},renderRow:(i,s,r)=>e(S,{label:`Domain ${s+1}`,name:`domain-${s}`,value:i,onChange:c=>r(s,c),placeholder:"e.g. api.example.com or *.service.io",error:n[`domains.${s}`],required:!0}),addLabel:"+ Add Domain",error:n.domains})})}function ra({type:a,rules:t,onChange:n,errors:l}){switch(a){case"SPENDING_LIMIT":return e(al,{rules:t,onChange:n,errors:l});case"WHITELIST":return e(nl,{rules:t,onChange:n,errors:l});case"RATE_LIMIT":return e(ll,{rules:t,onChange:n,errors:l});case"APPROVE_AMOUNT_LIMIT":return e(il,{rules:t,onChange:n,errors:l});case"APPROVE_TIER_OVERRIDE":return e(rl,{rules:t,onChange:n,errors:l});case"ALLOWED_TOKENS":return e(cl,{rules:t,onChange:n,errors:l});case"CONTRACT_WHITELIST":return e(ul,{rules:t,onChange:n,errors:l});case"METHOD_WHITELIST":return e(vl,{rules:t,onChange:n,errors:l});case"APPROVED_SPENDERS":return e(hl,{rules:t,onChange:n,errors:l});case"TIME_RESTRICTION":return e(_l,{rules:t,onChange:n,errors:l});case"ALLOWED_NETWORKS":return e(gl,{rules:t,onChange:n,errors:l});case"X402_ALLOWED_DOMAINS":return e(bl,{rules:t,onChange:n,errors:l});default:return e("p",{class:"policy-form-placeholder",children:"This policy type uses JSON editor. Toggle to JSON mode."})}}function Pt(a){const t=typeof a=="string"?Number(a):a;return Number.isNaN(t)?String(a):t.toLocaleString("en-US")}function wl(a){return a===86400?"1d":a%86400===0?`${a/86400}d`:a===3600?"1h":a%3600===0?`${a/3600}h`:a===60?"1m":a%60===0?`${a/60}m`:`${a}s`}const Nt=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"];function Sl(a){if(!a||a.length===0)return"";const t=[...a].sort((l,i)=>l-i);let n=!0;for(let l=1;l<t.length;l++)if(t[l]!==t[l-1]+1){n=!1;break}return n&&t.length>2?`${Nt[t[0]]}-${Nt[t[t.length-1]]}`:t.map(l=>Nt[l]??String(l)).join(", ")}function oa(a){return String(a).padStart(2,"0")}function Nl({rules:a}){const t=Number(a.instant_max??0),n=Number(a.notify_max??0),l=Number(a.delay_max??0),i=Math.max(t,n,l,1),s=[{label:"Instant",value:a.instant_max,width:t/i*100,cls:"instant"},{label:"Notify",value:a.notify_max,width:n/i*100,cls:"notify"},{label:"Delay",value:a.delay_max,width:l/i*100,cls:"delay"},{label:"Approval",value:"",width:100,cls:"approval"}];return e("div",{class:"tier-bars",children:s.map(r=>e("div",{class:"tier-bar",children:[e("span",{class:"tier-bar-label",children:r.label}),e("div",{class:"tier-bar-track",children:e("div",{class:`tier-bar-fill tier-bar-fill--${r.cls}`,style:{width:`${r.width}%`}})}),e("span",{class:"tier-bar-value",children:r.value?Pt(r.value):""})]},r.cls))})}function ca(a){return a.toLocaleString("en-US",{minimumFractionDigits:0,maximumFractionDigits:2})}function kl({rules:a}){const t=a.daily_limit_usd,n=a.monthly_limit_usd;return!t&&!n?null:e("div",{class:"cumulative-limits",children:[e("div",{class:"cumulative-limits-label",children:"Cumulative Limits"}),t&&e("div",{class:"cumulative-limit-row",children:[e("span",{class:"cumulative-limit-type",children:"Daily (24h)"}),e("span",{class:"cumulative-limit-value",children:["$",ca(t)]})]}),n&&e("div",{class:"cumulative-limit-row",children:[e("span",{class:"cumulative-limit-type",children:"Monthly (30d)"}),e("span",{class:"cumulative-limit-value",children:["$",ca(n)]})]})]})}const Tl={INSTANT:"success",NOTIFY:"info",DELAY:"warning",APPROVAL:"danger"};function El({type:a,rules:t}){switch(a){case"SPENDING_LIMIT":return e("div",{class:"spending-limit-summary",children:[e(Nl,{rules:t}),e(kl,{rules:t})]});case"ALLOWED_TOKENS":{const n=t.tokens||[];return n.length===0?e("span",{class:"rules-vis-text",children:"No tokens"}):e("div",{class:"rules-vis-badges",children:n.map((l,i)=>e(W,{variant:"info",children:l.symbol||(l.address?l.address.slice(0,8)+"...":"?")},i))})}case"RATE_LIMIT":{const n=t.max_requests,l=t.window_seconds;return e("span",{class:"rules-vis-text",children:[n," req / ",wl(l)]})}case"WHITELIST":{const n=t.allowed_addresses||[];return e(W,{variant:"neutral",children:[n.length," addresses"]})}case"TIME_RESTRICTION":{const n=t.allowed_days||[],l=t.allowed_hours,i=Sl(n),s=l?`${oa(l.start)}:00-${oa(l.end)}:00`:"";return e("span",{class:"rules-vis-text",children:[i," ",s]})}case"CONTRACT_WHITELIST":{const n=t.contracts||[];if(n.length===0)return e("span",{class:"rules-vis-text",children:"No contracts"});const l=n.slice(0,3),i=n.length-3;return e("div",{class:"rules-vis-badges",children:[l.map((s,r)=>e(W,{variant:"neutral",children:s.name||(s.address?s.address.slice(0,8)+"...":"?")},r)),i>0&&e(W,{variant:"neutral",children:["+",i," more"]})]})}case"METHOD_WHITELIST":{const n=t.methods||[],l=n.length,i=n.reduce((s,r)=>s+(r.selectors?.length||0),0);return e(W,{variant:"neutral",children:[l," contracts, ",i," methods"]})}case"APPROVED_SPENDERS":{const n=t.spenders||[];return e(W,{variant:"neutral",children:[n.length," spenders"]})}case"APPROVE_AMOUNT_LIMIT":{const n=t.maxAmount,l=t.blockUnlimited;return n&&l?e("span",{class:"rules-vis-text",children:["Max: ",Pt(n)," + Block unlimited"]}):n?e("span",{class:"rules-vis-text",children:["Max: ",Pt(n)]}):l?e("span",{class:"rules-vis-text",children:"Block unlimited only"}):e("span",{class:"rules-vis-text",children:"No limits"})}case"APPROVE_TIER_OVERRIDE":{const n=t.tier||"DELAY",l=Tl[n]||"neutral";return e(W,{variant:l,children:n})}case"ALLOWED_NETWORKS":{const n=t.networks||[];if(n.length===0)return e("span",{class:"rules-vis-text",children:"No networks"});const l=n.slice(0,3),i=n.length-3;return e("div",{class:"rules-vis-badges",children:[l.map((s,r)=>e(W,{variant:"info",children:s.network},r)),i>0&&e(W,{variant:"info",children:["+",i," more"]})]})}case"X402_ALLOWED_DOMAINS":{const n=t.domains||[];if(n.length===0)return e("span",{class:"rules-vis-text",children:"No domains"});const l=n.slice(0,3),i=n.length-3;return e("div",{class:"rules-vis-badges",children:[l.map((s,r)=>e(W,{variant:"neutral",children:s},r)),i>0&&e(W,{variant:"neutral",children:["+",i," more"]})]})}default:{const n=JSON.stringify(t);return e("span",{class:"rules-summary",children:n.length>60?n.slice(0,60)+"...":n})}}}const Va=[{label:"Spending Limit",value:"SPENDING_LIMIT"},{label:"Whitelist",value:"WHITELIST"},{label:"Time Restriction",value:"TIME_RESTRICTION"},{label:"Rate Limit",value:"RATE_LIMIT"},{label:"Allowed Tokens",value:"ALLOWED_TOKENS"},{label:"Contract Whitelist",value:"CONTRACT_WHITELIST"},{label:"Method Whitelist",value:"METHOD_WHITELIST"},{label:"Approved Spenders",value:"APPROVED_SPENDERS"},{label:"Approve Amount Limit",value:"APPROVE_AMOUNT_LIMIT"},{label:"Approve Tier Override",value:"APPROVE_TIER_OVERRIDE"},{label:"Allowed Networks",value:"ALLOWED_NETWORKS"},{label:"x402 Allowed Domains",value:"X402_ALLOWED_DOMAINS"}],Re={SPENDING_LIMIT:{instant_max:"1000000",notify_max:"5000000",delay_max:"10000000",delay_seconds:300,approval_timeout:3600},WHITELIST:{allowed_addresses:[]},TIME_RESTRICTION:{allowed_hours:{start:0,end:24},allowed_days:[0,1,2,3,4,5,6]},RATE_LIMIT:{max_requests:100,window_seconds:3600},ALLOWED_TOKENS:{tokens:[]},CONTRACT_WHITELIST:{contracts:[]},METHOD_WHITELIST:{methods:[]},APPROVED_SPENDERS:{spenders:[]},APPROVE_AMOUNT_LIMIT:{maxAmount:"1000000",blockUnlimited:!0},APPROVE_TIER_OVERRIDE:{tier:"DELAY"},ALLOWED_NETWORKS:{networks:[]},X402_ALLOWED_DOMAINS:{domains:[]}};function Xe(a,t){const n={};if(a==="SPENDING_LIMIT"){(!t.instant_max||!/^\d+$/.test(t.instant_max))&&(n.instant_max="Positive integer required"),(!t.notify_max||!/^\d+$/.test(t.notify_max))&&(n.notify_max="Positive integer required"),(!t.delay_max||!/^\d+$/.test(t.delay_max))&&(n.delay_max="Positive integer required");const l=Number(t.delay_seconds);(t.delay_seconds===void 0||t.delay_seconds===""||Number.isNaN(l)||l<60)&&(n.delay_seconds="Minimum 60 seconds");const i=t.daily_limit_usd;if(i!==void 0&&i!==""){const r=Number(i);(Number.isNaN(r)||r<=0)&&(n.daily_limit_usd="Must be a positive number")}const s=t.monthly_limit_usd;if(s!==void 0&&s!==""){const r=Number(s);(Number.isNaN(r)||r<=0)&&(n.monthly_limit_usd="Must be a positive number")}}else if(a==="WHITELIST"){const l=t.allowed_addresses||[];l.length===0&&(n.allowed_addresses="At least one address required"),l.forEach((i,s)=>{(!i||i.trim()==="")&&(n[`allowed_addresses.${s}`]="Address required")})}else if(a==="RATE_LIMIT"){const l=Number(t.max_requests);(!t.max_requests||Number.isNaN(l)||l<1||!Number.isInteger(l))&&(n.max_requests="Positive integer required");const i=Number(t.window_seconds);(!t.window_seconds||Number.isNaN(i)||i<1||!Number.isInteger(i))&&(n.window_seconds="Positive integer required")}else if(a==="APPROVE_AMOUNT_LIMIT")t.maxAmount&&!/^\d+$/.test(t.maxAmount)&&(n.maxAmount="Must be a positive integer string");else if(a==="ALLOWED_TOKENS"){const l=t.tokens||[];l.length===0&&(n.tokens="At least one token required"),l.forEach((i,s)=>{(!i.address||i.address.trim()==="")&&(n[`tokens.${s}.address`]="Address required")})}else if(a==="CONTRACT_WHITELIST"){const l=t.contracts||[];l.length===0&&(n.contracts="At least one contract required"),l.forEach((i,s)=>{(!i.address||i.address.trim()==="")&&(n[`contracts.${s}.address`]="Address required")})}else if(a==="METHOD_WHITELIST"){const l=t.methods||[];l.length===0&&(n.methods="At least one method entry required"),l.forEach((i,s)=>{(!i.contractAddress||i.contractAddress.trim()==="")&&(n[`methods.${s}.contractAddress`]="Contract address required"),!i.selectors||i.selectors.length===0?n[`methods.${s}.selectors`]="At least one selector required":i.selectors.forEach((r,c)=>{(!r||r.trim()==="")&&(n[`methods.${s}.selectors.${c}`]="Selector required")})})}else if(a==="APPROVED_SPENDERS"){const l=t.spenders||[];l.length===0&&(n.spenders="At least one spender required"),l.forEach((i,s)=>{(!i.address||i.address.trim()==="")&&(n[`spenders.${s}.address`]="Address required"),i.maxAmount&&!/^\d+$/.test(i.maxAmount)&&(n[`spenders.${s}.maxAmount`]="Must be a positive integer")})}else if(a==="TIME_RESTRICTION"){(t.allowed_days||[]).length===0&&(n.allowed_days="At least one day required");const i=t.allowed_hours;i&&i.start>=i.end&&(n.allowed_hours="Start must be before end")}else if(a==="ALLOWED_NETWORKS"){const l=t.networks||[];l.length===0&&(n.networks="At least one network required"),l.forEach((i,s)=>{(!i.network||i.network.trim()==="")&&(n[`networks.${s}.network`]="Network required")})}else if(a==="X402_ALLOWED_DOMAINS"){const l=t.domains||[];l.length===0&&(n.domains="At least one domain required"),l.forEach((i,s)=>{(!i||i.trim()==="")&&(n[`domains.${s}`]="Domain required")})}return n}function Al(a,t){if(!a)return"Global";const n=t.find(l=>l.id===a);return n?n.name:a.slice(0,8)+"..."}function kt(a){const t=Va.find(n=>n.value===a);return t?t.label:a}const da=[{key:"policies",label:"Policies"},{key:"defaults",label:"Defaults"}],Tt=["security.policy_defaults_delay_seconds","security.policy_defaults_approval_timeout","policy.default_deny_tokens","policy.default_deny_contracts","policy.default_deny_spenders"];function Cl(){const a=v({}),t=v({}),n=v(!1),l=v(!0),i=async()=>{try{const o=await K(E.ADMIN_SETTINGS);a.value=o}catch(o){const u=o instanceof f?o:new f(0,"UNKNOWN","Unknown error");g("error",D(u.code))}finally{l.value=!1}};L(()=>{i()},[]);const s=(o,u)=>{const d=String(u);t.value={...t.value,[o]:d}},r=async()=>{n.value=!0;try{const o=Object.entries(t.value).filter(([u])=>Tt.includes(u)).map(([u,d])=>({key:u,value:d}));await le(E.ADMIN_SETTINGS,{settings:o}),t.value={},await i(),g("success","Policy defaults saved and applied")}catch(o){const u=o instanceof f?o:new f(0,"UNKNOWN","Unknown error");g("error",D(u.code))}finally{n.value=!1}},c=()=>{t.value={}};L(()=>(pe({id:"policies-defaults",isDirty:()=>Object.keys(t.value).filter(o=>Tt.includes(o)).length>0,save:r,discard:c}),()=>fe("policies-defaults")),[]);const m=Object.keys(t.value).filter(o=>Tt.includes(o)).length;return l.value?e("div",{class:"empty-state",children:e("p",{children:"Loading settings..."})}):e(V,{children:[m>0&&e("div",{class:"settings-save-bar",children:[e("span",{children:[m," unsaved change",m>1?"s":""]}),e("div",{class:"settings-save-bar-actions",children:[e(A,{variant:"ghost",size:"sm",onClick:c,children:"Discard"}),e(A,{variant:"primary",size:"sm",onClick:r,loading:n.value,children:"Save"})]})]}),e("div",{class:"settings-category",children:[e("div",{class:"settings-category-header",children:[e("h3",{children:"Policy Defaults"}),e("p",{class:"settings-description",children:"Configure default delay, approval timeout, and default-deny policies. Changes apply immediately without daemon restart."})]}),e("div",{class:"settings-category-body",children:[e("div",{class:"settings-fields-grid",children:[e(S,{label:x("policy_defaults_delay_seconds"),name:"security.policy_defaults_delay_seconds",type:"number",value:Number(M(a.value,t.value,"security","policy_defaults_delay_seconds"))||0,onChange:o=>s("security.policy_defaults_delay_seconds",o),min:0,description:"Default delay before executing delayed-tier transactions"}),e(S,{label:x("policy_defaults_approval_timeout"),name:"security.policy_defaults_approval_timeout",type:"number",value:Number(M(a.value,t.value,"security","policy_defaults_approval_timeout"))||0,onChange:o=>s("security.policy_defaults_approval_timeout",o),min:60,description:"How long to wait for owner approval before timeout"})]}),e("div",{class:"settings-subgroup",style:{marginTop:"1rem",borderTop:"1px solid var(--border)",paddingTop:"1rem"},children:[e("h4",{style:{margin:"0 0 0.5rem 0",fontSize:"0.875rem",fontWeight:600,color:"var(--text-secondary)"},children:"Default Deny Policies"}),e("div",{class:"settings-fields-grid",children:[e(S,{label:x("default_deny_tokens"),name:"policy.default_deny_tokens",type:"checkbox",value:Ee(a.value,t.value,"security","default_deny_tokens"),onChange:o=>s("policy.default_deny_tokens",o),description:"Deny token transfers unless a matching whitelist policy exists"}),e(S,{label:x("default_deny_contracts"),name:"policy.default_deny_contracts",type:"checkbox",value:Ee(a.value,t.value,"security","default_deny_contracts"),onChange:o=>s("policy.default_deny_contracts",o),description:"Deny contract calls unless a matching whitelist policy exists"}),e(S,{label:x("default_deny_spenders"),name:"policy.default_deny_spenders",type:"checkbox",value:Ee(a.value,t.value,"security","default_deny_spenders"),onChange:o=>s("policy.default_deny_spenders",o),description:"Deny token approvals unless a matching whitelist policy exists"})]})]}),e("div",{class:"settings-info-box",children:"When enabled, transactions are denied if no matching whitelist policy exists. Disable to allow all transactions of that type when no policy is configured."})]})]})]})}function Il(){const a=v("policies");L(()=>{const y=Y.value;y&&y.tab&&(a.value=y.tab,setTimeout(()=>{se.value=y.fieldName},100),Y.value=null)},[Y.value]);const t=v([]),n=v([]),l=v("__all__"),i=v(!1),s=v(!0),r=v(!1),c=v("SPENDING_LIMIT"),m=v(""),o=v(JSON.stringify(Re.SPENDING_LIMIT,null,2)),u=v(Re.SPENDING_LIMIT),d=v({}),p=v(!1),h=v(0),k=v(!0),C=v(""),w=v(null),_=v(!1),I=v(!1),B=v(null),F=v(""),N=v({}),O=v(!1),P=v({}),G=v(0),q=v(!0),Q=v(null),j=v(!1),T=v(!1),R=v(null),te=v(!1),ht=async()=>{try{const y=await K(E.WALLETS);t.value=y.items}catch(y){const H=y instanceof f?y:new f(0,"UNKNOWN","Unknown error");g("error",D(H.code))}finally{s.value=!1}},_e=async()=>{i.value=!0;try{let y=E.POLICIES;l.value!=="__all__"&&l.value!=="__global__"&&(y=`${E.POLICIES}?walletId=${l.value}`);const H=await K(y);l.value==="__global__"?n.value=H.filter(b=>b.walletId===null):n.value=H}catch(y){const H=y instanceof f?y:new f(0,"UNKNOWN","Unknown error");g("error",D(H.code))}finally{i.value=!1}},ze=async()=>{w.value=null;let y;if(p.value)try{y=JSON.parse(o.value)}catch{w.value="Invalid JSON in rules field";return}else{const H=Xe(c.value,u.value);if(Object.keys(H).length>0){d.value=H;return}d.value={},y=u.value}_.value=!0;try{await ne(E.POLICIES,{walletId:m.value||void 0,type:c.value,rules:y,priority:h.value,enabled:k.value,network:C.value||void 0}),g("success","Policy created"),r.value=!1,c.value="SPENDING_LIMIT",m.value="",C.value="",o.value=JSON.stringify(Re.SPENDING_LIMIT,null,2),u.value=Re.SPENDING_LIMIT,d.value={},p.value=!1,h.value=0,k.value=!0,w.value=null,await _e()}catch(H){const b=H instanceof f?H:new f(0,"UNKNOWN","Unknown error");g("error",D(b.code))}finally{_.value=!1}},mt=y=>{B.value=y,F.value=JSON.stringify(y.rules,null,2),N.value={...y.rules},O.value=!1,P.value={},G.value=y.priority,q.value=y.enabled,Q.value=null,I.value=!0},pt=async()=>{Q.value=null;let y;if(O.value)try{y=JSON.parse(F.value)}catch{Q.value="Invalid JSON in rules field";return}else{const H=Xe(B.value.type,N.value);if(Object.keys(H).length>0){P.value=H;return}P.value={},y=N.value}j.value=!0;try{await le(E.POLICY(B.value.id),{rules:y,priority:G.value,enabled:q.value}),g("success","Policy updated"),I.value=!1,await _e()}catch(H){const b=H instanceof f?H:new f(0,"UNKNOWN","Unknown error");g("error",D(b.code))}finally{j.value=!1}},ft=()=>{if(!O.value)F.value=JSON.stringify(N.value,null,2);else try{N.value=JSON.parse(F.value),Q.value=null}catch{Q.value="Invalid JSON — cannot switch to form mode";return}O.value=!O.value},_t=y=>{R.value=y,T.value=!0},yt=async()=>{te.value=!0;try{await Ce(E.POLICY(R.value.id)),g("success","Policy deleted"),T.value=!1,await _e()}catch(y){const H=y instanceof f?y:new f(0,"UNKNOWN","Unknown error");g("error",D(H.code))}finally{te.value=!1}},gt=y=>{const H=y;c.value=H;const b=Re[H];b&&(o.value=JSON.stringify(b,null,2),u.value={...b}),d.value={},p.value=!1},Ge=()=>{if(!p.value)o.value=JSON.stringify(u.value,null,2);else try{u.value=JSON.parse(o.value),w.value=null}catch{w.value="Invalid JSON — cannot switch to form mode";return}p.value=!p.value};L(()=>{ht()},[]),L(()=>{_e()},[l.value]);const bt=[{key:"type",header:"Type",render:y=>e(W,{variant:y.type==="SPENDING_LIMIT"?"success":"info",children:kt(y.type)})},{key:"walletId",header:"Wallet",render:y=>Al(y.walletId,t.value)},{key:"network",header:"Network",render:y=>y.network??"All"},{key:"rules",header:"Rules",render:y=>e(El,{type:y.type,rules:y.rules})},{key:"priority",header:"Priority"},{key:"enabled",header:"Enabled",render:y=>e(W,{variant:y.enabled?"success":"danger",children:y.enabled?"ON":"OFF"})},{key:"actions",header:"Actions",render:y=>e("span",{style:{display:"flex",gap:"0.25rem"},children:[e("button",{class:"btn btn-ghost btn-sm",onClick:H=>{H.stopPropagation(),mt(y)},children:"Edit"}),e(A,{size:"sm",variant:"danger",onClick:()=>_t(y),children:"Delete"})]})}];return e("div",{class:"page",children:[e(qe,{pageName:"Policies",tabName:da.find(y=>y.key===a.value)?.label??"",onPageClick:()=>{a.value="policies"}}),e(Ve,{tabs:da,activeTab:a.value,onTabChange:y=>{a.value=y}}),a.value==="policies"&&e(V,{children:[e("div",{class:"policy-controls",children:[e("div",{class:"policy-filter-select",children:[e("label",{for:"policy-wallet-filter",children:"Filter by Wallet"}),e("select",{id:"policy-wallet-filter",value:l.value,onChange:y=>{l.value=y.target.value},disabled:s.value,children:[e("option",{value:"__all__",children:"All Policies"}),e("option",{value:"__global__",children:"Global Only"}),t.value.map(y=>e("option",{value:y.id,children:[y.name," (",y.chain,"/",y.network,")"]},y.id))]})]}),!r.value&&e(A,{onClick:()=>{r.value=!0},children:"Create Policy"})]}),r.value&&e("div",{class:"inline-form",children:[e(S,{label:"Type",name:"type",type:"select",value:c.value,onChange:gt,options:Va}),e(S,{label:"Wallet",name:"walletId",type:"select",value:m.value,onChange:y=>{m.value=y},options:[{label:"Global (no wallet)",value:""},...t.value.map(y=>({label:`${y.name} (${y.chain}/${y.network})`,value:y.id}))]}),e(S,{label:"Network Scope",name:"network",value:C.value,onChange:y=>{C.value=y},placeholder:"e.g. polygon-mainnet (leave empty for all networks)"}),e("div",{class:"policy-form-section",children:[e("div",{class:"policy-form-header",children:[e("label",{children:"Rules"}),e("button",{class:"btn btn-ghost btn-sm json-toggle",onClick:Ge,children:p.value?"Switch to Form":"JSON Direct Edit"})]}),p.value?e(S,{label:"",name:"rules",type:"textarea",value:o.value,onChange:y=>{o.value=y},error:w.value??void 0}):e(ra,{type:c.value,rules:u.value,onChange:y=>{u.value=y,Object.keys(d.value).length>0&&(d.value=Xe(c.value,y))},errors:d.value})]}),e(S,{label:"Priority",name:"priority",type:"number",value:h.value,onChange:y=>{h.value=y},min:0,max:999}),e(S,{label:"Enabled",name:"enabled",type:"checkbox",value:k.value,onChange:y=>{k.value=y}}),e("div",{class:"inline-form-actions",children:[e(A,{onClick:ze,loading:_.value,children:"Create"}),e(A,{variant:"secondary",onClick:()=>{r.value=!1,w.value=null},children:"Cancel"})]})]}),e(we,{columns:bt,data:n.value,loading:i.value,emptyMessage:"No policies found"}),e(re,{open:I.value,title:"Edit Policy",onCancel:()=>{I.value=!1},onConfirm:pt,confirmText:"Save",loading:j.value,children:B.value&&e("div",{children:[e("div",{class:"policy-type-readonly",children:["Type: ",kt(B.value.type)]}),e("div",{class:"policy-form-section",children:[e("div",{class:"policy-form-header",children:[e("label",{children:"Rules"}),e("button",{class:"btn btn-ghost btn-sm json-toggle",onClick:ft,children:O.value?"Switch to Form":"JSON Direct Edit"})]}),O.value?e("div",{class:"edit-rules-textarea",children:e(S,{label:"",name:"edit-rules",type:"textarea",value:F.value,onChange:y=>{F.value=y},error:Q.value??void 0})}):e(ra,{type:B.value.type,rules:N.value,onChange:y=>{N.value=y,Object.keys(P.value).length>0&&(P.value=Xe(B.value.type,y))},errors:P.value})]}),e(S,{label:"Priority",name:"edit-priority",type:"number",value:G.value,onChange:y=>{G.value=y},min:0,max:999}),e(S,{label:"Enabled",name:"edit-enabled",type:"checkbox",value:q.value,onChange:y=>{q.value=y}})]})}),e(re,{open:T.value,title:"Delete Policy",onCancel:()=>{T.value=!1},onConfirm:yt,confirmText:"Delete",confirmVariant:"danger",loading:te.value,children:R.value&&e("p",{children:["Are you sure you want to delete this"," ",e("strong",{children:kt(R.value.type)})," policy? This action cannot be undone."]})})]}),a.value==="defaults"&&e(Cl,{})]})}function Dl(){return e(Ll,{})}function Ll(){const a=v([]),t=v(!0),n=v(!1),l=v(null),i=v("ADMIN"),s=v(!1),r=v(!1),c=v(null),m=v(!1),o=async()=>{t.value=!0;try{const w=await K(E.ADMIN_TELEGRAM_USERS);a.value=w.users}catch(w){const _=w instanceof f?w:new f(0,"UNKNOWN","Unknown error");g("error",D(_.code))}finally{t.value=!1}};L(()=>{o()},[]);const u=w=>{l.value=w,i.value="ADMIN",n.value=!0},d=async()=>{if(l.value){s.value=!0;try{await le(E.ADMIN_TELEGRAM_USER(l.value.chat_id),{role:i.value}),g("success",`User approved as ${i.value}`),n.value=!1,l.value=null,await o()}catch(w){const _=w instanceof f?w:new f(0,"UNKNOWN","Unknown error");g("error",D(_.code))}finally{s.value=!1}}},p=w=>{c.value=w,r.value=!0},h=async()=>{if(c.value){m.value=!0;try{await Ce(E.ADMIN_TELEGRAM_USER(c.value.chat_id)),g("success","User deleted"),r.value=!1,c.value=null,await o()}catch(w){const _=w instanceof f?w:new f(0,"UNKNOWN","Unknown error");g("error",D(_.code))}finally{m.value=!1}}},k=w=>w==="PENDING"?"warning":w==="ADMIN"?"success":"info";return e("div",{class:"page",children:[e(we,{columns:[{key:"chat_id",header:"Chat ID",render:w=>String(w.chat_id)},{key:"username",header:"Username",render:w=>w.username??"-"},{key:"role",header:"Role",render:w=>e(W,{variant:k(w.role),children:w.role})},{key:"registered_at",header:"Registered",render:w=>ie(w.registered_at)},{key:"approved_at",header:"Approved",render:w=>w.approved_at?ie(w.approved_at):"-"},{key:"actions",header:"Actions",render:w=>e("div",{style:{display:"flex",gap:"var(--space-1)"},children:[w.role==="PENDING"&&e(A,{size:"sm",variant:"primary",onClick:()=>u(w),children:"Approve"}),e(A,{size:"sm",variant:"danger",onClick:()=>p(w),children:"Delete"})]})}],data:a.value,loading:t.value,emptyMessage:"No Telegram users registered. Users appear here after sending /start to the bot."}),e(re,{open:n.value,title:"Approve Telegram User",onCancel:()=>{n.value=!1,l.value=null},onConfirm:d,confirmText:"Approve",confirmVariant:"primary",loading:s.value,children:l.value&&e("div",{children:[e("p",{children:[e("strong",{children:"Chat ID:"})," ",l.value.chat_id,l.value.username&&e("span",{children:[" (",e("strong",{children:["@",l.value.username]}),")"]})]}),e("div",{class:"form-field",style:{marginTop:"var(--space-3)"},children:[e("label",{for:"approve-role",children:"Role"}),e("select",{id:"approve-role",value:i.value,onChange:w=>{i.value=w.target.value},children:[e("option",{value:"ADMIN",children:"ADMIN"}),e("option",{value:"READONLY",children:"READONLY"})]})]})]})}),e(re,{open:r.value,title:"Delete Telegram User",onCancel:()=>{r.value=!1,c.value=null},onConfirm:h,confirmText:"Delete",confirmVariant:"danger",loading:m.value,children:e("p",{children:"Are you sure you want to remove this user? They will need to /start again to re-register."})})]})}const Et=20,ua=[{key:"channels",label:"Channels & Logs"},{key:"telegram",label:"Telegram Users"},{key:"settings",label:"Settings"}];function Ol(){const a=v({}),t=v({}),n=v(!1),l=v(!0),i=v([]),s=v(!1),r=async()=>{try{const p=await K(E.ADMIN_SETTINGS);a.value=p}catch(p){const h=p instanceof f?p:new f(0,"UNKNOWN","Unknown error");g("error",D(h.code))}finally{l.value=!1}};L(()=>{r()},[]);const c=(p,h)=>{const k=String(h);t.value={...t.value,[p]:k}},m=async()=>{n.value=!0;try{const p=Object.entries(t.value).filter(([h])=>h.startsWith("notifications.")||h.startsWith("telegram.")).map(([h,k])=>({key:h,value:k}));await le(E.ADMIN_SETTINGS,{settings:p}),t.value={},await r(),g("success","Notification settings saved and applied")}catch(p){const h=p instanceof f?p:new f(0,"UNKNOWN","Unknown error");g("error",D(h.code))}finally{n.value=!1}},o=()=>{t.value={}};L(()=>(pe({id:"notifications-settings",isDirty:()=>Object.keys(t.value).filter(p=>p.startsWith("notifications.")||p.startsWith("telegram.")).length>0,save:m,discard:o}),()=>fe("notifications-settings")),[]);const u=async()=>{s.value=!0,i.value=[];try{const p=await ne(E.ADMIN_NOTIFICATIONS_TEST,{});if(i.value=p.results,p.results.length===0)g("info","No notification channels configured");else{const h=p.results.every(k=>k.success);g(h?"success":"warning",h?"All test notifications sent":"Some channels failed")}}catch(p){const h=p instanceof f?p:new f(0,"UNKNOWN","Unknown error");g("error",D(h.code))}finally{s.value=!1}},d=Object.keys(t.value).filter(p=>p.startsWith("notifications.")||p.startsWith("telegram.")).length;return l.value?e("div",{class:"empty-state",children:e("p",{children:"Loading settings..."})}):e(V,{children:[d>0&&e("div",{class:"settings-save-bar",children:[e("span",{children:[d," unsaved change",d>1?"s":""]}),e("div",{class:"settings-save-bar-actions",children:[e(A,{variant:"ghost",size:"sm",onClick:o,children:"Discard"}),e(A,{variant:"primary",size:"sm",onClick:m,loading:n.value,children:"Save"})]})]}),e("div",{class:"settings-category",children:[e("div",{class:"settings-category-header",children:[e("h3",{children:"Notification Configuration"}),e("p",{class:"settings-description",children:"Configure notification channels for transaction alerts. Changes apply immediately via hot-reload."})]}),e("div",{class:"settings-category-body",children:[e(Ie,{legend:"Telegram",description:"Telegram notification channel and bot configuration",children:[e("div",{class:"settings-fields-grid",children:[e("div",{class:"settings-field-full",children:e(S,{label:"Enabled",name:"notifications.enabled",type:"checkbox",value:Ee(a.value,t.value,"notifications","enabled"),onChange:p=>c("notifications.enabled",p),description:"Enable or disable notifications globally"})}),e(S,{label:x("telegram_bot_token"),name:"notifications.telegram_bot_token",type:"password",value:M(a.value,t.value,"notifications","telegram_bot_token"),onChange:p=>c("notifications.telegram_bot_token",p),placeholder:Je(a.value,t.value,"notifications","telegram_bot_token")?"(configured)":"",description:"Bot token for Telegram notifications"}),e(S,{label:x("telegram_chat_id"),name:"notifications.telegram_chat_id",type:"text",value:M(a.value,t.value,"notifications","telegram_chat_id"),onChange:p=>c("notifications.telegram_chat_id",p),description:"Chat ID for Telegram notification delivery"}),e(S,{label:x("locale"),name:"notifications.locale",type:"select",value:M(a.value,t.value,"notifications","locale")||"en",onChange:p=>c("notifications.locale",p),options:[{label:"English",value:"en"},{label:"Korean",value:"ko"}],description:"Language for notification messages"})]}),e("div",{class:"settings-subgroup",style:{marginTop:"0.75rem",borderTop:"1px solid var(--border)",paddingTop:"0.75rem"},children:[e("div",{class:"settings-subgroup-title",children:"Telegram Bot"}),e("div",{class:"settings-fields-grid",children:[e(S,{label:"Bot Enabled",name:"telegram.enabled",type:"select",value:M(a.value,t.value,"telegram","enabled")||"false",onChange:p=>c("telegram.enabled",p),options:[{label:"Yes",value:"true"},{label:"No",value:"false"}],description:"Enable or disable the Telegram bot"}),e(S,{label:x("bot_token"),name:"telegram.bot_token",type:"password",value:M(a.value,t.value,"telegram","bot_token"),onChange:p=>c("telegram.bot_token",p),placeholder:Je(a.value,t.value,"telegram","bot_token")?"(configured)":"Leave empty to use notification token",description:"Dedicated bot token for Telegram bot (optional, uses notification token if empty)"}),e(S,{label:"Locale",name:"telegram.locale",type:"select",value:M(a.value,t.value,"telegram","locale")||"en",onChange:p=>c("telegram.locale",p),options:[{label:"English",value:"en"},{label:"한국어",value:"ko"}],description:"Language for Telegram bot messages"})]})]})]}),e(Ie,{legend:"Other Channels",description:"Discord, ntfy, Slack, and rate limiting",children:e("div",{class:"settings-fields-grid",children:[e(S,{label:x("discord_webhook_url"),name:"notifications.discord_webhook_url",type:"password",value:M(a.value,t.value,"notifications","discord_webhook_url"),onChange:p=>c("notifications.discord_webhook_url",p),placeholder:Je(a.value,t.value,"notifications","discord_webhook_url")?"(configured)":"",description:"Webhook URL for Discord notifications"}),e(S,{label:x("ntfy_server"),name:"notifications.ntfy_server",type:"text",value:M(a.value,t.value,"notifications","ntfy_server"),onChange:p=>c("notifications.ntfy_server",p),description:"Server URL for ntfy notifications"}),e(S,{label:x("ntfy_topic"),name:"notifications.ntfy_topic",type:"text",value:M(a.value,t.value,"notifications","ntfy_topic"),onChange:p=>c("notifications.ntfy_topic",p),description:"Topic name for ntfy notifications"}),e(S,{label:"Slack Webhook URL",name:"notifications.slack_webhook_url",type:"password",value:M(a.value,t.value,"notifications","slack_webhook_url"),onChange:p=>c("notifications.slack_webhook_url",p),placeholder:Je(a.value,t.value,"notifications","slack_webhook_url")?"(configured)":"",description:"Webhook URL for Slack notifications"}),e(S,{label:x("rate_limit_rpm"),name:"notifications.rate_limit_rpm",type:"number",value:Number(M(a.value,t.value,"notifications","rate_limit_rpm"))||20,onChange:p=>c("notifications.rate_limit_rpm",p),min:1,max:1e3,description:"Max notifications per minute"})]})}),e("div",{class:"notif-test-section",children:[e(A,{variant:"secondary",size:"sm",onClick:u,loading:s.value,children:"Test Notification"}),i.value.length>0&&e("div",{class:"test-results",children:i.value.map(p=>e("div",{class:`test-result-item ${p.success?"test-result-success":"test-result-failure"}`,children:[e(W,{variant:p.success?"success":"danger",children:p.success?"OK":"FAIL"}),e("span",{children:p.channel}),p.error&&e("span",{style:"font-size: var(--font-size-xs); color: var(--color-danger);",children:[" - ",p.error]})]},p.channel))})]})]})]})]})}function va(){const a=v("channels");L(()=>{const N=Y.value;N&&N.tab&&(a.value=N.tab,setTimeout(()=>{se.value=N.fieldName},100),Y.value=null)},[Y.value]);const t=v(null),n=v(!0),l=v(!1),i=v(null),s=v(null),r=v(null),c=v(!0),m=v(1),o=v(null),u=async()=>{try{const N=await K(E.ADMIN_NOTIFICATIONS_STATUS);t.value=N}catch(N){const O=N instanceof f?N:new f(0,"UNKNOWN","Unknown error");g("error",D(O.code))}finally{n.value=!1}},d=async N=>{c.value=!0;try{const O=await K(`${E.ADMIN_NOTIFICATIONS_LOG}?page=${N}&pageSize=${Et}`);r.value=O}catch(O){const P=O instanceof f?O:new f(0,"UNKNOWN","Unknown error");g("error",D(P.code))}finally{c.value=!1}},p=async()=>{l.value=!0,s.value=null;try{const O=(await ne(E.ADMIN_NOTIFICATIONS_TEST,{})).results;s.value=O,O.every(G=>G.success)?g("success","Test sent successfully"):g("warning","Some channels failed")}catch(N){const O=N instanceof f?N:new f(0,"UNKNOWN","Unknown error");g("error",D(O.code))}finally{l.value=!1}},h=async N=>{i.value=N,s.value=null;try{const P=(await ne(E.ADMIN_NOTIFICATIONS_TEST,{channel:N})).results;s.value=P,P.every(q=>q.success)?g("success",`Test sent to ${N}`):g("warning",`${N} test failed`)}catch(O){const P=O instanceof f?O:new f(0,"UNKNOWN","Unknown error");g("error",D(P.code))}finally{i.value=null}},k=()=>{m.value>1&&(m.value-=1,d(m.value))},C=()=>{const N=r.value?Math.ceil(r.value.total/Et):1;m.value<N&&(m.value+=1,d(m.value))},w=N=>{o.value=o.value?.id===N.id?null:N};L(()=>{u(),d(1);const N=setInterval(()=>d(m.value),3e4);return()=>clearInterval(N)},[]);const _=n.value&&!t.value,I=t.value?.channels.some(N=>N.enabled)??!1,B=r.value?Math.max(1,Math.ceil(r.value.total/Et)):1,F=[{key:"eventType",header:"Event Type"},{key:"walletId",header:"Wallet ID",render:N=>N.walletId?N.walletId.slice(0,8)+"...":"—"},{key:"channel",header:"Channel",render:N=>e("span",{style:{textTransform:"capitalize"},children:N.channel})},{key:"status",header:"Status",render:N=>e(W,{variant:N.status==="sent"?"success":"danger",children:N.status})},{key:"createdAt",header:"Time",render:N=>ie(N.createdAt)}];return e("div",{class:"page",children:[e(qe,{pageName:"Notifications",tabName:ua.find(N=>N.key===a.value)?.label??"",onPageClick:()=>{a.value="channels"}}),e(Ve,{tabs:ua,activeTab:a.value,onTabChange:N=>{a.value=N}}),a.value==="telegram"?e(Dl,{}):a.value==="settings"?e(Ol,{}):e(V,{children:[e("h2",{children:"Channel Status"}),t.value&&!t.value.enabled&&e("div",{class:"notif-disabled-banner",children:["Notifications are disabled. Set ",e("code",{children:"notifications.enabled = true"})," in config.toml"]}),_?e("div",{class:"channel-grid",children:[1,2,3].map(N=>e("div",{class:"channel-card",children:e("div",{class:"stat-skeleton"})},N))}):e("div",{class:"channel-grid",children:t.value?.channels.map(N=>e("div",{class:"channel-card",children:e("div",{class:"channel-card-header",children:[e("span",{class:"channel-card-name",children:N.name}),e("div",{class:"channel-card-actions",children:[e(W,{variant:N.enabled?"success":"neutral",children:N.enabled?"Connected":"Not Configured"}),N.enabled&&e(A,{variant:"secondary",size:"sm",onClick:()=>h(N.name),loading:i.value===N.name,children:"Test"})]})]})},N.name))}),e("div",{style:{marginTop:"var(--space-4)",marginBottom:"var(--space-6)"},children:[e(A,{onClick:p,loading:l.value,disabled:!I,children:"Test All Channels"}),s.value&&e("div",{class:"test-results",children:s.value.map(N=>e("div",{class:"test-result-item",children:[e("span",{class:N.success?"test-result-success":"test-result-failure",children:N.success?"✓":"✗"}),e("span",{style:{textTransform:"capitalize"},children:N.channel}),!N.success&&N.error&&e("span",{class:"test-result-failure",children:[" - ",N.error]})]},N.channel))})]}),e("h2",{children:"Delivery Log"}),e(we,{columns:F,data:r.value?.logs??[],loading:c.value,emptyMessage:"No notification logs",onRowClick:w}),o.value&&e("div",{class:"log-message-detail",children:[e("div",{class:"log-message-detail-header",children:[e("strong",{children:o.value.eventType})," via ",e("span",{style:{textTransform:"capitalize"},children:o.value.channel}),e(A,{variant:"ghost",size:"sm",onClick:()=>{o.value=null},children:"Close"})]}),e("div",{class:"log-message-detail-body",children:o.value.message?e("pre",{style:{whiteSpace:"pre-wrap",margin:0,fontSize:"var(--font-size-sm)"},children:o.value.message}):e("span",{class:"text-muted",children:"(No message recorded)"})})]}),e("div",{class:"pagination",children:[e("span",{class:"pagination-info",children:["Page ",m.value," of ",B,r.value?` (${r.value.total} total)`:""]}),e("div",{class:"pagination-buttons",children:[e(A,{variant:"secondary",size:"sm",onClick:k,disabled:m.value<=1,children:"Previous"}),e(A,{variant:"secondary",size:"sm",onClick:C,disabled:m.value>=B,children:"Next"})]})]}),e("div",{class:"config-guidance",children:e("p",{children:"Configure notification channels in the Settings tab above. Changes are applied immediately via hot-reload."})})]})]})}const ha=[{key:"killswitch",label:"Kill Switch"},{key:"autostop",label:"AutoStop Rules"},{key:"jwt",label:"JWT Rotation"}];function Rl(){const a=v(null),t=v(!0),n=v(!1),l=async()=>{try{const d=await K(E.ADMIN_KILL_SWITCH);a.value=d}catch(d){const p=d instanceof f?d:new f(0,"UNKNOWN","Unknown error");g("error",D(p.code))}finally{t.value=!1}};L(()=>{l()},[]);const i=async()=>{n.value=!0;try{await ne(E.ADMIN_KILL_SWITCH),g("success","Kill switch activated - all operations suspended"),await l()}catch(d){const p=d instanceof f?d:new f(0,"UNKNOWN","Unknown error");g("error",D(p.code))}finally{n.value=!1}},s=async()=>{n.value=!0;try{await ne(E.ADMIN_KILL_SWITCH_ESCALATE),g("success","Kill switch escalated to LOCKED"),await l()}catch(d){const p=d instanceof f?d:new f(0,"UNKNOWN","Unknown error");g("error",D(p.code))}finally{n.value=!1}},r=async()=>{n.value=!0;try{await ne(E.ADMIN_RECOVER),g("success","Kill switch recovered - operations resumed"),await l()}catch(d){const p=d instanceof f?d:new f(0,"UNKNOWN","Unknown error");g("error",D(p.code))}finally{n.value=!1}},c=a.value,m=c?.state==="ACTIVE",o=c?.state==="SUSPENDED",u=c?.state==="LOCKED";return e("div",{class:"settings-category",children:[e("div",{class:"settings-category-header",children:[e("h3",{children:"Kill Switch"}),e("p",{class:"settings-description",children:"Emergency stop - suspends all wallet operations immediately. 3-state: ACTIVE (normal) → SUSPENDED (paused) → LOCKED (permanent)."})]}),e("div",{class:"settings-category-body",children:t.value?e("span",{children:"Loading..."}):c?e(V,{children:[e("div",{class:"ks-state-card",style:{marginBottom:"var(--space-4)"},children:[e(W,{variant:m?"success":u?"danger":"warning",children:c.state}),!m&&c.activatedAt&&e("span",{class:"ks-state-info",children:["Since ",ie(c.activatedAt),c.activatedBy?` by ${c.activatedBy}`:""]})]}),e("div",{style:{display:"flex",gap:"var(--space-2)",flexWrap:"wrap"},children:[m&&e(A,{variant:"danger",onClick:i,loading:n.value,children:"Activate Kill Switch"}),o&&e(V,{children:[e(A,{variant:"primary",onClick:r,loading:n.value,children:"Recover"}),e(A,{variant:"danger",onClick:s,loading:n.value,children:"Escalate to LOCKED"})]}),u&&e(A,{variant:"primary",onClick:r,loading:n.value,children:"Recover from LOCKED (5s wait)"})]}),o&&e("div",{class:"settings-info-box",style:{marginTop:"var(--space-3)"},children:"All wallet operations are suspended. Sessions revoked, transactions cancelled. You can Recover to resume operations, or Escalate to LOCKED for permanent lockdown."}),u&&e("div",{class:"settings-info-box",style:{marginTop:"var(--space-3)",borderColor:"var(--color-danger)"},children:"System is permanently locked. Recovery requires dual-auth (Owner signature + Master password) and has a mandatory 5-second wait period."})]}):null})]})}function xl(){const a=v({}),t=v({}),n=v(!1),l=v(!0),i=async()=>{try{const o=await K(E.ADMIN_SETTINGS);a.value=o}catch(o){const u=o instanceof f?o:new f(0,"UNKNOWN","Unknown error");g("error",D(u.code))}finally{l.value=!1}};L(()=>{i()},[]);const s=(o,u)=>{const d=String(u);t.value={...t.value,[o]:d}},r=async()=>{n.value=!0;try{const o=Object.entries(t.value).filter(([u])=>u.startsWith("autostop.")).map(([u,d])=>({key:u,value:d}));await le(E.ADMIN_SETTINGS,{settings:o}),t.value={},await i(),g("success","AutoStop settings saved and applied")}catch(o){const u=o instanceof f?o:new f(0,"UNKNOWN","Unknown error");g("error",D(u.code))}finally{n.value=!1}},c=()=>{t.value={}};L(()=>(pe({id:"security-autostop",isDirty:()=>Object.keys(t.value).filter(o=>o.startsWith("autostop.")).length>0,save:r,discard:c}),()=>fe("security-autostop")),[]);const m=Object.keys(t.value).filter(o=>o.startsWith("autostop.")).length;return l.value?e("div",{class:"empty-state",children:e("p",{children:"Loading settings..."})}):e(V,{children:[m>0&&e("div",{class:"settings-save-bar",children:[e("span",{children:[m," unsaved change",m>1?"s":""]}),e("div",{class:"settings-save-bar-actions",children:[e(A,{variant:"ghost",size:"sm",onClick:c,children:"Discard"}),e(A,{variant:"primary",size:"sm",onClick:r,loading:n.value,children:"Save"})]})]}),e("div",{class:"settings-category",children:[e("div",{class:"settings-category-header",children:[e("h3",{children:"AutoStop Rules"}),e("p",{class:"settings-description",children:"Automatic protection rules that suspend wallets or trigger Kill Switch on anomalies. Changes apply immediately without daemon restart."})]}),e("div",{class:"settings-category-body",children:[e("div",{class:"settings-field-full",style:{marginBottom:"var(--space-4)"},children:e(S,{label:x("enabled"),name:"autostop.enabled",type:"checkbox",value:Ee(a.value,t.value,"autostop","enabled"),onChange:o=>s("autostop.enabled",o),description:"Enable or disable AutoStop protection rules"})}),e(Ie,{legend:"Activity Detection",description:"Detects failures and unusual transaction patterns",children:e("div",{class:"settings-fields-grid",children:[e(S,{label:x("consecutive_failures_threshold"),name:"autostop.consecutive_failures_threshold",type:"number",value:Number(M(a.value,t.value,"autostop","consecutive_failures_threshold"))||0,onChange:o=>s("autostop.consecutive_failures_threshold",o),min:1,max:100,description:"Suspend wallet after this many consecutive failed transactions"}),e(S,{label:x("unusual_activity_threshold"),name:"autostop.unusual_activity_threshold",type:"number",value:Number(M(a.value,t.value,"autostop","unusual_activity_threshold"))||0,onChange:o=>s("autostop.unusual_activity_threshold",o),min:5,max:1e3,description:"Max transactions within window before triggering unusual activity alert"}),e(S,{label:x("unusual_activity_window_sec"),name:"autostop.unusual_activity_window_sec",type:"number",value:Number(M(a.value,t.value,"autostop","unusual_activity_window_sec"))||0,onChange:o=>s("autostop.unusual_activity_window_sec",o),min:60,max:86400,description:"Time window for unusual activity detection"})]})}),e(Ie,{legend:"Idle Detection",description:"Monitors inactivity and revokes idle sessions",children:e("div",{class:"settings-fields-grid",children:[e(S,{label:x("idle_timeout_sec"),name:"autostop.idle_timeout_sec",type:"number",value:Number(M(a.value,t.value,"autostop","idle_timeout_sec"))||0,onChange:o=>s("autostop.idle_timeout_sec",o),min:60,max:604800,description:"Revoke sessions with no activity for this duration"}),e(S,{label:x("idle_check_interval_sec"),name:"autostop.idle_check_interval_sec",type:"number",value:Number(M(a.value,t.value,"autostop","idle_check_interval_sec"))||0,onChange:o=>s("autostop.idle_check_interval_sec",o),min:10,max:3600,description:"How often to check for idle sessions"})]})}),e("div",{class:"settings-info-box",children:[e("strong",{children:"Consecutive Failures:"})," Suspends wallet after N consecutive failed transactions.",e("br",{}),e("strong",{children:"Unusual Activity:"})," Suspends wallet if transaction count exceeds threshold within the time window.",e("br",{}),e("strong",{children:"Idle Timeout:"})," Revokes sessions with no activity for the configured duration."]})]})]})]})}function Pl(){const a=v(!1),t=v(!1),n=async()=>{t.value=!0;try{await ne(E.ADMIN_ROTATE_SECRET),a.value=!1,g("success","JWT secret rotated. Old tokens valid for 5 minutes.")}catch(l){const i=l instanceof f?l:new f(0,"UNKNOWN","Unknown error");g("error",D(i.code))}finally{t.value=!1}};return e(V,{children:[e("div",{class:"settings-section",children:[e("div",{class:"settings-section-header",children:[e("h3",{children:"JWT Secret Rotation"}),e("p",{class:"settings-description",children:"Invalidate all existing JWT tokens. Old tokens remain valid for 5 minutes."})]}),e("div",{class:"settings-section-body",children:e(A,{variant:"secondary",onClick:()=>{a.value=!0},children:"Rotate JWT Secret"})})]}),e(re,{open:a.value,title:"Rotate JWT Secret",onCancel:()=>{a.value=!1},onConfirm:n,confirmText:"Rotate",confirmVariant:"primary",loading:t.value,children:e("p",{children:"Are you sure you want to rotate the JWT secret? All existing session tokens will remain valid for 5 more minutes, then expire. Wallets will need new sessions."})})]})}function Wl(){const a=v("killswitch");L(()=>{const n=Y.value;n&&n.tab&&(a.value=n.tab,setTimeout(()=>{se.value=n.fieldName},100),Y.value=null)},[Y.value]);const t=ha.find(n=>n.key===a.value)?.label??"";return e("div",{class:"page",children:[e(qe,{pageName:"Security",tabName:t,onPageClick:()=>{a.value="killswitch"}}),e(Ve,{tabs:ha,activeTab:a.value,onTabChange:n=>{a.value=n}}),a.value==="killswitch"&&e(Rl,{}),a.value==="autostop"&&e(xl,{}),a.value==="jwt"&&e(Pl,{})]})}const Ze=[{code:"USD",name:"US Dollar",symbol:"$"},{code:"KRW",name:"Korean Won",symbol:"₩"},{code:"JPY",name:"Japanese Yen",symbol:"¥"},{code:"EUR",name:"Euro",symbol:"€"},{code:"GBP",name:"British Pound",symbol:"£"},{code:"CNY",name:"Chinese Yuan",symbol:"¥"},{code:"CAD",name:"Canadian Dollar",symbol:"CA$"},{code:"AUD",name:"Australian Dollar",symbol:"A$"},{code:"CHF",name:"Swiss Franc",symbol:"CHF"},{code:"SGD",name:"Singapore Dollar",symbol:"S$"},{code:"HKD",name:"Hong Kong Dollar",symbol:"HK$"},{code:"INR",name:"Indian Rupee",symbol:"₹"},{code:"TWD",name:"Taiwan Dollar",symbol:"NT$"},{code:"THB",name:"Thai Baht",symbol:"฿"},{code:"MYR",name:"Malaysian Ringgit",symbol:"RM"},{code:"IDR",name:"Indonesian Rupiah",symbol:"Rp"},{code:"PHP",name:"Philippine Peso",symbol:"₱"},{code:"VND",name:"Vietnamese Dong",symbol:"₫"},{code:"BRL",name:"Brazilian Real",symbol:"R$"},{code:"MXN",name:"Mexican Peso",symbol:"MX$"},{code:"CLP",name:"Chilean Peso",symbol:"CL$"},{code:"TRY",name:"Turkish Lira",symbol:"₺"},{code:"PLN",name:"Polish Zloty",symbol:"zł"},{code:"CZK",name:"Czech Koruna",symbol:"Kč"},{code:"HUF",name:"Hungarian Forint",symbol:"Ft"},{code:"SEK",name:"Swedish Krona",symbol:"kr"},{code:"NOK",name:"Norwegian Krone",symbol:"kr"},{code:"DKK",name:"Danish Krone",symbol:"kr"},{code:"NZD",name:"New Zealand Dollar",symbol:"NZ$"},{code:"ZAR",name:"South African Rand",symbol:"R"},{code:"ILS",name:"Israeli Shekel",symbol:"₪"},{code:"SAR",name:"Saudi Riyal",symbol:"SR"},{code:"AED",name:"UAE Dirham",symbol:"AED"},{code:"KWD",name:"Kuwaiti Dinar",symbol:"KD"},{code:"BHD",name:"Bahraini Dinar",symbol:"BD"},{code:"NGN",name:"Nigerian Naira",symbol:"₦"},{code:"RUB",name:"Russian Ruble",symbol:"₽"},{code:"UAH",name:"Ukrainian Hryvnia",symbol:"₴"},{code:"PKR",name:"Pakistani Rupee",symbol:"Rs"},{code:"BDT",name:"Bangladeshi Taka",symbol:"৳"},{code:"LKR",name:"Sri Lankan Rupee",symbol:"Rs"},{code:"MMK",name:"Myanmar Kyat",symbol:"K"},{code:"GEL",name:"Georgian Lari",symbol:"₾"}];function Ml({value:a,onChange:t,name:n}){const l=v(""),i=v(!1),s=v(null),r=v(!1),c=Kt(null),m=on(()=>{const u=l.value.toLowerCase();return u?Ze.filter(d=>d.code.toLowerCase().includes(u)||d.name.toLowerCase().includes(u)||d.symbol.includes(u)):Ze});L(()=>{if(a==="USD"){s.value="1 USD = $1.00";return}r.value=!0,K(`${E.ADMIN_FOREX_RATES}?currencies=${a}`).then(u=>{const d=u.rates[a];s.value=d?.preview??null}).catch(()=>{s.value=null}).finally(()=>{r.value=!1})},[a]),L(()=>{const u=d=>{c.current&&!c.current.contains(d.target)&&(i.value=!1,l.value="")};return document.addEventListener("mousedown",u),()=>document.removeEventListener("mousedown",u)},[]);const o=Ze.find(u=>u.code===a)??Ze[0];return e("div",{class:"currency-select",ref:c,children:[n&&e("input",{type:"hidden",name:n,value:a}),e("button",{type:"button",class:"currency-select-trigger",onClick:()=>{i.value=!i.value},children:[e("span",{class:"currency-select-value",children:[o.code," - ",o.name," (",o.symbol,")"]}),e("span",{class:"currency-select-chevron",children:i.value?"▲":"▼"})]}),s.value&&e("div",{class:"currency-rate-preview",children:r.value?"...":s.value}),i.value&&e("div",{class:"currency-select-dropdown",children:[e("input",{type:"text",class:"currency-select-search",placeholder:"Search currency...",value:l.value,onInput:u=>{l.value=u.target.value},autoFocus:!0}),e("div",{class:"currency-select-list",children:[m.value.map(u=>e("button",{type:"button",class:`currency-select-option ${u.code===a?"currency-select-option--active":""}`,onClick:()=>{t(u.code),i.value=!1,l.value=""},children:[e("span",{class:"currency-option-code",children:u.code}),e("span",{class:"currency-option-name",children:u.name}),e("span",{class:"currency-option-symbol",children:u.symbol})]},u.code)),m.value.length===0&&e("div",{class:"currency-select-empty",children:"No currencies found"})]})]})]})}const Ul=["display.","daemon.","oracle."],$l=new Set(["security.rate_limit_global_ip_rpm"]);function At(a){return Ul.some(t=>a.startsWith(t))||$l.has(a)}function Kl(){const a=v({}),t=v({}),n=v(!1),l=v(!0),i=v([]),s=v(!0),r=v(null),c=v(""),m=v(!1),o=v(!1),u=v(!1),d=v(""),p=v(!1),h=async()=>{try{const T=await K(E.ADMIN_SETTINGS);a.value=T}catch(T){const R=T instanceof f?T:new f(0,"UNKNOWN","Unknown error");g("error",D(R.code))}finally{l.value=!1}},k=async()=>{try{const T=await K(E.ADMIN_API_KEYS);i.value=T.keys}catch{}finally{s.value=!1}};L(()=>{h(),k()},[]),L(()=>{const T=Y.value;T&&(setTimeout(()=>{se.value=T.fieldName},100),Y.value=null)},[Y.value]);const C=(T,R)=>M(a.value,t.value,T,R),w=(T,R)=>{const te=String(R);t.value={...t.value,[T]:te}},_=async()=>{n.value=!0;try{const T=Object.entries(t.value).filter(([R])=>At(R)).map(([R,te])=>({key:R,value:te}));await le(E.ADMIN_SETTINGS,{settings:T}),t.value={},await h(),g("success","Settings saved and applied")}catch(T){const R=T instanceof f?T:new f(0,"UNKNOWN","Unknown error");g("error",D(R.code))}finally{n.value=!1}},I=()=>{t.value={}};L(()=>(pe({id:"system-settings",isDirty:()=>Object.keys(t.value).filter(T=>At(T)).length>0,save:_,discard:I}),()=>fe("system-settings")),[]);const B=async T=>{m.value=!0;try{await le(E.ADMIN_API_KEY(T),{apiKey:c.value}),g("success",`API key saved for ${T}`),r.value=null,c.value="",await k()}catch(R){const te=R instanceof f?R:new f(0,"UNKNOWN","Unknown error");g("error",D(te.code))}finally{m.value=!1}},F=async T=>{try{await Ce(E.ADMIN_API_KEY(T)),g("success",`API key deleted for ${T}`),await k()}catch(R){const te=R instanceof f?R:new f(0,"UNKNOWN","Unknown error");g("error",D(te.code))}},N=async()=>{u.value=!0;try{await ne(E.ADMIN_SHUTDOWN),o.value=!1,d.value="",g("info","Shutdown initiated"),p.value=!0}catch(T){const R=T instanceof f?T:new f(0,"UNKNOWN","Unknown error");g("error",D(R.code))}finally{u.value=!1}},O=Object.keys(t.value).filter(T=>At(T)).length;function P(){return s.value?e("div",{class:"settings-loading",children:"Loading API keys..."}):i.value.length===0?null:e("div",{class:"settings-category",children:[e("div",{class:"settings-category-header",children:[e("h3",{children:"API Keys"}),e("p",{class:"settings-description",children:"Manage API keys for Action Providers"})]}),e("div",{class:"settings-category-body",children:i.value.map(T=>e("div",{class:"settings-field-row",children:[e("div",{class:"settings-field-label",children:[e("span",{children:T.providerName}),T.requiresApiKey&&!T.hasKey&&e(W,{variant:"warning",children:"Required"})]}),e("div",{class:"settings-field-value",children:r.value===T.providerName?e("div",{class:"api-key-edit-row",children:[e(S,{label:"API Key",type:"password",name:`apikey-${T.providerName}`,value:c.value,onChange:R=>{c.value=String(R)},placeholder:"Enter API key"}),e(A,{onClick:()=>B(T.providerName),loading:m.value,size:"sm",children:"Save"}),e(A,{variant:"ghost",onClick:()=>{r.value=null,c.value=""},size:"sm",children:"Cancel"})]}):e("div",{class:"api-key-display-row",children:[e("span",{class:"api-key-masked",children:T.hasKey?T.maskedKey:"Not set"}),e(A,{variant:"ghost",onClick:()=>{r.value=T.providerName,c.value=""},size:"sm",children:T.hasKey?"Change":"Set"}),T.hasKey&&e(A,{variant:"danger",onClick:()=>F(T.providerName),size:"sm",children:"Delete"})]})})]},T.providerName))})]})}function G(){return e("div",{class:"settings-category",children:[e("div",{class:"settings-category-header",children:[e("h3",{children:"Oracle"}),e("p",{class:"settings-description",children:"Price oracle configuration for cross-validation"})]}),e("div",{class:"settings-category-body",children:[e("div",{class:"settings-fields-grid",children:e(S,{label:"Cross Validation Threshold (%)",name:"oracle.cross_validation_threshold",type:"number",value:Number(C("oracle","cross_validation_threshold"))||5,onChange:T=>w("oracle.cross_validation_threshold",T),min:0,max:100,description:"Maximum allowed deviation between price oracle sources"})}),e("div",{class:"settings-info-box",children:"Maximum allowed deviation between price sources before flagging a discrepancy. Default is 5%."})]})]})}function q(){const T=se.value==="display.currency";return L(()=>{if(T){const R=document.querySelector('[name="display.currency"]');R&&R.closest(".form-field")?.scrollIntoView({behavior:"smooth",block:"center"});const te=setTimeout(()=>{se.value=""},2500);return()=>clearTimeout(te)}},[T]),e("div",{class:"settings-category",children:[e("div",{class:"settings-category-header",children:[e("h3",{children:"Display Currency"}),e("p",{class:"settings-description",children:"Configure display currency for USD amount conversion"})]}),e("div",{class:"settings-category-body",children:[e("div",{class:"settings-fields-grid",children:e("div",{class:`form-field${T?" form-field--highlight":""}`,children:[e("label",{children:x("currency")}),e(Ml,{name:"display.currency",value:C("display","currency")||"USD",onChange:R=>w("display.currency",R)})]})}),e("div",{class:"settings-info-box",children:"All USD amounts in the dashboard, notifications, and API responses will be converted to the selected currency. Policy evaluation always uses USD. The “≈” prefix indicates an approximate conversion."})]})]})}function Q(){return e("div",{class:"settings-category",children:[e("div",{class:"settings-category-header",children:[e("h3",{children:"Global IP Rate Limit"}),e("p",{class:"settings-description",children:"Maximum API requests per minute from a single IP address"})]}),e("div",{class:"settings-category-body",children:e("div",{class:"settings-fields-grid",children:e(S,{label:x("rate_limit_global_ip_rpm"),name:"security.rate_limit_global_ip_rpm",type:"number",value:Number(C("security","rate_limit_global_ip_rpm"))||0,onChange:T=>w("security.rate_limit_global_ip_rpm",T),min:10,description:"Maximum API requests per minute from a single IP address"})})})]})}function j(){return e("div",{class:"settings-category",children:[e("div",{class:"settings-category-header",children:[e("h3",{children:"Log Level"}),e("p",{class:"settings-description",children:"General daemon configuration"})]}),e("div",{class:"settings-category-body",children:e("div",{class:"settings-fields-grid",children:e(S,{label:x("log_level"),name:"daemon.log_level",type:"select",value:C("daemon","log_level")||"info",onChange:T=>w("daemon.log_level",T),options:[{label:"debug",value:"debug"},{label:"info",value:"info"},{label:"warn",value:"warn"},{label:"error",value:"error"}],description:"Daemon logging verbosity level"})})})]})}return e("div",{class:"page",children:[p.value&&e("div",{class:"shutdown-overlay",children:[e("h2",{children:"Daemon is shutting down..."}),e("p",{children:"You can close this tab."})]}),O>0&&e("div",{class:"settings-save-bar",children:[e("span",{children:[O," unsaved change",O>1?"s":""]}),e("div",{class:"settings-save-bar-actions",children:[e(A,{variant:"ghost",size:"sm",onClick:I,children:"Discard"}),e(A,{variant:"primary",size:"sm",onClick:_,loading:n.value,children:"Save"})]})]}),l.value?e("div",{class:"empty-state",children:e("p",{children:"Loading settings..."})}):e(V,{children:[e(P,{}),e(G,{}),e(q,{}),e(Q,{}),e(j,{})]}),e("div",{class:"settings-section settings-section--danger",children:[e("div",{class:"settings-section-header",children:[e("h3",{children:"Danger Zone"}),e("p",{class:"settings-description",children:"Irreversible actions. Proceed with caution."})]}),e("div",{class:"settings-section-body",children:e(A,{variant:"danger",onClick:()=>{o.value=!0},children:"Shutdown Daemon"})})]}),e(re,{open:o.value,title:"Shutdown Daemon",onCancel:()=>{o.value=!1,d.value=""},onConfirm:N,confirmText:"Shutdown",confirmVariant:"danger",confirmDisabled:d.value!=="SHUTDOWN",loading:u.value,children:[e("p",{children:"This will gracefully stop the daemon process. All active connections will be terminated."}),e("div",{class:"shutdown-confirm-input",children:[e("label",{children:["Type ",e("strong",{children:"SHUTDOWN"})," to confirm"]}),e("input",{type:"text",value:d.value,onInput:T=>{d.value=T.target.value},placeholder:"SHUTDOWN"})]})]})]})}const ue=ee(window.location.hash.slice(1)||"/dashboard"),Qe=ee(!1);window.addEventListener("hashchange",()=>{ue.value=window.location.hash.slice(1)||"/dashboard"});const Fl={"/dashboard":"Dashboard","/wallets":"Wallets","/sessions":"Sessions","/policies":"Policies","/notifications":"Notifications","/security":"Security","/system":"System"},Hl={"/dashboard":"System overview and key metrics","/wallets":"Manage wallets, balances, and connections","/sessions":"View and manage active sessions","/policies":"Configure transaction policies and rules","/notifications":"Channel status, delivery logs, and settings","/security":"Emergency controls and automatic protection rules","/system":"API keys, display preferences, and daemon configuration"};function Bl(a){return a.startsWith("/wallets/")?"Wallet Detail":Fl[a]??"Dashboard"}function ma(a){return Hl[a]}const Vl=[{path:"/dashboard",label:"Dashboard"},{path:"/wallets",label:"Wallets"},{path:"/sessions",label:"Sessions"},{path:"/policies",label:"Policies"},{path:"/notifications",label:"Notifications"},{path:"/security",label:"Security"},{path:"/system",label:"System"}];function ql(){const a=ue.value;return a==="/sessions"?e(tl,{}):a==="/policies"?e(Il,{}):a==="/notifications"?e(va,{}):a==="/telegram-users"?(window.location.hash="#/notifications",e(va,{})):a==="/settings"?(window.location.hash="#/dashboard",e(aa,{})):a==="/walletconnect"?(window.location.hash="#/wallets",e(ia,{})):a==="/security"?e(Wl,{}):a==="/system"?e(Kl,{}):a.startsWith("/wallets")?e(ia,{}):e(aa,{})}function zl(){return L(()=>{const a=t=>{(t.metaKey||t.ctrlKey)&&t.key==="k"&&(t.preventDefault(),Qe.value=!Qe.value)};return document.addEventListener("keydown",a),()=>document.removeEventListener("keydown",a)},[]),e("div",{class:"layout",children:[e("aside",{class:"sidebar",children:[e("div",{class:"sidebar-brand",children:"WAIaaS"}),e("nav",{class:"sidebar-nav",children:Vl.map(a=>{const t=a.path==="/wallets"?ue.value.startsWith("/wallets"):ue.value===a.path;return e("a",{href:`#${a.path}`,class:`sidebar-link ${t?"active":""}`,onClick:n=>{Fa.value&&(n.preventDefault(),Ha({type:"nav",execute:()=>{window.location.hash=`#${a.path}`}}))},children:a.label})})})]}),e("main",{class:"main",children:[e("header",{class:"header",children:[e("div",{class:"header-left",children:[e("h1",{class:"header-title",children:Bl(ue.value)}),ma(ue.value)&&e("p",{class:"header-subtitle",children:ma(ue.value)})]}),e("div",{class:"header-actions",children:[e("button",{class:"btn-search",onClick:()=>{Qe.value=!0},title:"Search settings (Ctrl+K)",children:"🔍"}),e("button",{class:"btn-logout",onClick:()=>Bt(),children:"Logout"})]})]}),e("div",{class:"content",children:e(ql,{})})]}),e(Sn,{open:Qe}),e(Tn,{})]})}const et={overlay:{position:"fixed",inset:0,display:"flex",alignItems:"center",justifyContent:"center",background:"rgba(0, 0, 0, 0.7)",color:"white",zIndex:9999},content:{textAlign:"center"},title:{fontSize:"var(--font-size-2xl)",fontWeight:"var(--font-weight-bold)",marginBottom:"var(--space-2)"},message:{fontSize:"var(--font-size-base)",color:"var(--color-text-muted)"}};function Gl(){return e("div",{style:et.overlay,children:e("div",{style:et.content,children:[e("h1",{style:et.title,children:"Daemon Shutting Down"}),e("p",{style:et.message,children:"The daemon is shutting down. Please wait or restart."})]})})}function jl(){return vn.value?e(Gl,{}):un.value?e(V,{children:[e(zl,{}),e($n,{})]}):e(_n,{})}Za(e(jl,{}),document.getElementById("app"));
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
<!DOCTYPE html>
|
|
2
|
+
<html lang="en">
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="UTF-8" />
|
|
5
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
6
|
+
<title>WAIaaS Admin</title>
|
|
7
|
+
<script type="module" crossorigin src="/admin/assets/index-Ddm9jbh5.js"></script>
|
|
8
|
+
<link rel="stylesheet" crossorigin href="/admin/assets/index-BTZ185m_.css">
|
|
9
|
+
</head>
|
|
10
|
+
<body>
|
|
11
|
+
<div id="app"></div>
|
|
12
|
+
</body>
|
|
13
|
+
</html>
|