@cookill/wallet-adapter 0.1.0

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.
@@ -0,0 +1,137 @@
1
+ /**
2
+ * @cookillabs/wallet-adapter
3
+ * Community wallet adapter for Rialo blockchain dApps
4
+ *
5
+ * ⚠️ DISCLAIMER: This is a community package, NOT officially maintained by Rialo.
6
+ * For official Rialo packages, see: https://www.npmjs.com/package/@rialo/frost
7
+ */
8
+ /** Supported Rialo chains */
9
+ type RialoChain = 'rialo:mainnet' | 'rialo:testnet' | 'rialo:devnet' | 'rialo:localnet';
10
+ /** Network shorthand */
11
+ type RialoNetwork = 'mainnet' | 'testnet' | 'devnet' | 'localnet';
12
+ /** Wallet account */
13
+ interface WalletAccount {
14
+ address: string;
15
+ publicKey?: Uint8Array | string;
16
+ label?: string;
17
+ }
18
+ /** Transaction request */
19
+ interface TransactionRequest {
20
+ to: string;
21
+ value: string;
22
+ data?: string;
23
+ memo?: string;
24
+ }
25
+ /** Transaction result */
26
+ interface TransactionResult {
27
+ hash: string;
28
+ status: 'pending' | 'confirmed' | 'failed';
29
+ blockNumber?: number;
30
+ }
31
+ /** Signed message */
32
+ interface SignedMessage {
33
+ signature: string;
34
+ message: string;
35
+ address: string;
36
+ }
37
+ /** Network configuration */
38
+ interface NetworkConfig {
39
+ chainId: string;
40
+ name: string;
41
+ rpcUrl: string;
42
+ wsUrl?: string;
43
+ explorerUrl?: string;
44
+ }
45
+ /** Wallet info for registry */
46
+ interface WalletInfo {
47
+ id: string;
48
+ name: string;
49
+ icon: string;
50
+ installed?: boolean;
51
+ downloadUrl?: string;
52
+ }
53
+ /** Wallet adapter events */
54
+ type WalletEvent = 'connect' | 'disconnect' | 'accountChange' | 'networkChange' | 'error';
55
+ declare const NETWORKS: Record<RialoNetwork, NetworkConfig>;
56
+ /**
57
+ * Provider interface injected by Rialo Wallet extension
58
+ * Available at window.rialo when extension is installed
59
+ */
60
+ interface RialoProvider {
61
+ isRialo: boolean;
62
+ version: string;
63
+ connect(): Promise<string[]>;
64
+ disconnect(): Promise<void>;
65
+ isConnected(): Promise<boolean>;
66
+ getAccounts(): Promise<string[]>;
67
+ signTransaction(tx: TransactionRequest): Promise<{
68
+ signature: string;
69
+ rawTransaction?: string;
70
+ }>;
71
+ sendTransaction(tx: TransactionRequest): Promise<TransactionResult>;
72
+ signAndSendTransaction(tx: TransactionRequest): Promise<TransactionResult>;
73
+ signMessage(message: string): Promise<SignedMessage>;
74
+ getNetwork(): Promise<string>;
75
+ switchNetwork(network: RialoNetwork): Promise<void>;
76
+ getBalance(address?: string): Promise<string>;
77
+ on(event: WalletEvent, callback: (data: unknown) => void): () => void;
78
+ removeListener(event: WalletEvent, callback: (data: unknown) => void): void;
79
+ removeAllListeners(event?: WalletEvent): void;
80
+ }
81
+ /**
82
+ * Check if Rialo Wallet extension is installed
83
+ */
84
+ declare function isRialoInstalled(): boolean;
85
+ /**
86
+ * Get the Rialo provider if available
87
+ */
88
+ declare function getRialoProvider(): RialoProvider | undefined;
89
+ /**
90
+ * Wait for Rialo provider to be available (with timeout)
91
+ */
92
+ declare function waitForRialoProvider(timeout?: number): Promise<RialoProvider | undefined>;
93
+ declare class RialoWallet {
94
+ private provider;
95
+ private _connected;
96
+ private _accounts;
97
+ private _network;
98
+ constructor();
99
+ get isInstalled(): boolean;
100
+ get connected(): boolean;
101
+ get accounts(): WalletAccount[];
102
+ get activeAccount(): WalletAccount | undefined;
103
+ get network(): RialoNetwork;
104
+ connect(): Promise<WalletAccount[]>;
105
+ disconnect(): Promise<void>;
106
+ signMessage(message: string): Promise<SignedMessage>;
107
+ signTransaction(tx: TransactionRequest): Promise<string>;
108
+ sendTransaction(tx: TransactionRequest): Promise<TransactionResult>;
109
+ signAndSendTransaction(tx: TransactionRequest): Promise<TransactionResult>;
110
+ getBalance(address?: string): Promise<string>;
111
+ switchNetwork(network: RialoNetwork): Promise<void>;
112
+ on(event: WalletEvent, callback: (data: unknown) => void): () => void;
113
+ }
114
+ /**
115
+ * Format address for display (truncated base58)
116
+ */
117
+ declare function formatAddress(address: string, chars?: number): string;
118
+ /**
119
+ * Format balance from kelvins (smallest unit) to RLO
120
+ */
121
+ declare function formatBalance(kelvins: string | bigint, decimals?: number): string;
122
+ /**
123
+ * Parse RLO to kelvins
124
+ */
125
+ declare function parseBalance(rlo: string | number): bigint;
126
+ /**
127
+ * Validate Rialo address format (base58)
128
+ * Real Rialo addresses are base58 encoded public keys (32-50 chars)
129
+ */
130
+ declare function isValidAddress(address: string): boolean;
131
+ declare global {
132
+ interface Window {
133
+ rialo?: RialoProvider;
134
+ }
135
+ }
136
+
137
+ export { NETWORKS, type NetworkConfig, type RialoChain, type RialoNetwork, type RialoProvider, RialoWallet, type SignedMessage, type TransactionRequest, type TransactionResult, type WalletAccount, type WalletEvent, type WalletInfo, RialoWallet as default, formatAddress, formatBalance, getRialoProvider, isRialoInstalled, isValidAddress, parseBalance, waitForRialoProvider };
@@ -0,0 +1,137 @@
1
+ /**
2
+ * @cookillabs/wallet-adapter
3
+ * Community wallet adapter for Rialo blockchain dApps
4
+ *
5
+ * ⚠️ DISCLAIMER: This is a community package, NOT officially maintained by Rialo.
6
+ * For official Rialo packages, see: https://www.npmjs.com/package/@rialo/frost
7
+ */
8
+ /** Supported Rialo chains */
9
+ type RialoChain = 'rialo:mainnet' | 'rialo:testnet' | 'rialo:devnet' | 'rialo:localnet';
10
+ /** Network shorthand */
11
+ type RialoNetwork = 'mainnet' | 'testnet' | 'devnet' | 'localnet';
12
+ /** Wallet account */
13
+ interface WalletAccount {
14
+ address: string;
15
+ publicKey?: Uint8Array | string;
16
+ label?: string;
17
+ }
18
+ /** Transaction request */
19
+ interface TransactionRequest {
20
+ to: string;
21
+ value: string;
22
+ data?: string;
23
+ memo?: string;
24
+ }
25
+ /** Transaction result */
26
+ interface TransactionResult {
27
+ hash: string;
28
+ status: 'pending' | 'confirmed' | 'failed';
29
+ blockNumber?: number;
30
+ }
31
+ /** Signed message */
32
+ interface SignedMessage {
33
+ signature: string;
34
+ message: string;
35
+ address: string;
36
+ }
37
+ /** Network configuration */
38
+ interface NetworkConfig {
39
+ chainId: string;
40
+ name: string;
41
+ rpcUrl: string;
42
+ wsUrl?: string;
43
+ explorerUrl?: string;
44
+ }
45
+ /** Wallet info for registry */
46
+ interface WalletInfo {
47
+ id: string;
48
+ name: string;
49
+ icon: string;
50
+ installed?: boolean;
51
+ downloadUrl?: string;
52
+ }
53
+ /** Wallet adapter events */
54
+ type WalletEvent = 'connect' | 'disconnect' | 'accountChange' | 'networkChange' | 'error';
55
+ declare const NETWORKS: Record<RialoNetwork, NetworkConfig>;
56
+ /**
57
+ * Provider interface injected by Rialo Wallet extension
58
+ * Available at window.rialo when extension is installed
59
+ */
60
+ interface RialoProvider {
61
+ isRialo: boolean;
62
+ version: string;
63
+ connect(): Promise<string[]>;
64
+ disconnect(): Promise<void>;
65
+ isConnected(): Promise<boolean>;
66
+ getAccounts(): Promise<string[]>;
67
+ signTransaction(tx: TransactionRequest): Promise<{
68
+ signature: string;
69
+ rawTransaction?: string;
70
+ }>;
71
+ sendTransaction(tx: TransactionRequest): Promise<TransactionResult>;
72
+ signAndSendTransaction(tx: TransactionRequest): Promise<TransactionResult>;
73
+ signMessage(message: string): Promise<SignedMessage>;
74
+ getNetwork(): Promise<string>;
75
+ switchNetwork(network: RialoNetwork): Promise<void>;
76
+ getBalance(address?: string): Promise<string>;
77
+ on(event: WalletEvent, callback: (data: unknown) => void): () => void;
78
+ removeListener(event: WalletEvent, callback: (data: unknown) => void): void;
79
+ removeAllListeners(event?: WalletEvent): void;
80
+ }
81
+ /**
82
+ * Check if Rialo Wallet extension is installed
83
+ */
84
+ declare function isRialoInstalled(): boolean;
85
+ /**
86
+ * Get the Rialo provider if available
87
+ */
88
+ declare function getRialoProvider(): RialoProvider | undefined;
89
+ /**
90
+ * Wait for Rialo provider to be available (with timeout)
91
+ */
92
+ declare function waitForRialoProvider(timeout?: number): Promise<RialoProvider | undefined>;
93
+ declare class RialoWallet {
94
+ private provider;
95
+ private _connected;
96
+ private _accounts;
97
+ private _network;
98
+ constructor();
99
+ get isInstalled(): boolean;
100
+ get connected(): boolean;
101
+ get accounts(): WalletAccount[];
102
+ get activeAccount(): WalletAccount | undefined;
103
+ get network(): RialoNetwork;
104
+ connect(): Promise<WalletAccount[]>;
105
+ disconnect(): Promise<void>;
106
+ signMessage(message: string): Promise<SignedMessage>;
107
+ signTransaction(tx: TransactionRequest): Promise<string>;
108
+ sendTransaction(tx: TransactionRequest): Promise<TransactionResult>;
109
+ signAndSendTransaction(tx: TransactionRequest): Promise<TransactionResult>;
110
+ getBalance(address?: string): Promise<string>;
111
+ switchNetwork(network: RialoNetwork): Promise<void>;
112
+ on(event: WalletEvent, callback: (data: unknown) => void): () => void;
113
+ }
114
+ /**
115
+ * Format address for display (truncated base58)
116
+ */
117
+ declare function formatAddress(address: string, chars?: number): string;
118
+ /**
119
+ * Format balance from kelvins (smallest unit) to RLO
120
+ */
121
+ declare function formatBalance(kelvins: string | bigint, decimals?: number): string;
122
+ /**
123
+ * Parse RLO to kelvins
124
+ */
125
+ declare function parseBalance(rlo: string | number): bigint;
126
+ /**
127
+ * Validate Rialo address format (base58)
128
+ * Real Rialo addresses are base58 encoded public keys (32-50 chars)
129
+ */
130
+ declare function isValidAddress(address: string): boolean;
131
+ declare global {
132
+ interface Window {
133
+ rialo?: RialoProvider;
134
+ }
135
+ }
136
+
137
+ export { NETWORKS, type NetworkConfig, type RialoChain, type RialoNetwork, type RialoProvider, RialoWallet, type SignedMessage, type TransactionRequest, type TransactionResult, type WalletAccount, type WalletEvent, type WalletInfo, RialoWallet as default, formatAddress, formatBalance, getRialoProvider, isRialoInstalled, isValidAddress, parseBalance, waitForRialoProvider };
package/dist/index.js ADDED
@@ -0,0 +1,170 @@
1
+ // src/index.ts
2
+ var NETWORKS = {
3
+ mainnet: {
4
+ chainId: "rialo:mainnet",
5
+ name: "Rialo Mainnet",
6
+ rpcUrl: "https://mainnet.rialo.io:4101",
7
+ wsUrl: "wss://mainnet.rialo.io:4102",
8
+ explorerUrl: "https://explorer.rialo.io"
9
+ },
10
+ testnet: {
11
+ chainId: "rialo:testnet",
12
+ name: "Rialo Testnet",
13
+ rpcUrl: "https://testnet.rialo.io:4101",
14
+ wsUrl: "wss://testnet.rialo.io:4102",
15
+ explorerUrl: "https://testnet.explorer.rialo.io"
16
+ },
17
+ devnet: {
18
+ chainId: "rialo:devnet",
19
+ name: "Rialo Devnet",
20
+ rpcUrl: "https://devnet.rialo.io:4101",
21
+ wsUrl: "wss://devnet.rialo.io:4102",
22
+ explorerUrl: "https://devnet.explorer.rialo.io"
23
+ },
24
+ localnet: {
25
+ chainId: "rialo:localnet",
26
+ name: "Rialo Localnet",
27
+ rpcUrl: "http://localhost:4101",
28
+ wsUrl: "ws://localhost:4102",
29
+ explorerUrl: "http://localhost:3000"
30
+ }
31
+ };
32
+ function isRialoInstalled() {
33
+ if (typeof window === "undefined") return false;
34
+ return !!window.rialo?.isRialo;
35
+ }
36
+ function getRialoProvider() {
37
+ if (typeof window === "undefined") return void 0;
38
+ const rialo = window.rialo;
39
+ return rialo?.isRialo ? rialo : void 0;
40
+ }
41
+ function waitForRialoProvider(timeout = 3e3) {
42
+ return new Promise((resolve) => {
43
+ if (isRialoInstalled()) {
44
+ resolve(getRialoProvider());
45
+ return;
46
+ }
47
+ const checkInterval = setInterval(() => {
48
+ if (isRialoInstalled()) {
49
+ clearInterval(checkInterval);
50
+ resolve(getRialoProvider());
51
+ }
52
+ }, 100);
53
+ setTimeout(() => {
54
+ clearInterval(checkInterval);
55
+ resolve(void 0);
56
+ }, timeout);
57
+ });
58
+ }
59
+ var RialoWallet = class {
60
+ constructor() {
61
+ this._connected = false;
62
+ this._accounts = [];
63
+ this._network = "devnet";
64
+ this.provider = getRialoProvider();
65
+ }
66
+ get isInstalled() {
67
+ return isRialoInstalled();
68
+ }
69
+ get connected() {
70
+ return this._connected;
71
+ }
72
+ get accounts() {
73
+ return this._accounts;
74
+ }
75
+ get activeAccount() {
76
+ return this._accounts[0];
77
+ }
78
+ get network() {
79
+ return this._network;
80
+ }
81
+ async connect() {
82
+ this.provider = getRialoProvider();
83
+ if (!this.provider) {
84
+ throw new Error("Rialo Wallet not installed. Download at https://rialo.io/wallet");
85
+ }
86
+ const addresses = await this.provider.connect();
87
+ this._accounts = addresses.map((address) => ({ address }));
88
+ this._connected = true;
89
+ const networkStr = await this.provider.getNetwork();
90
+ this._network = networkStr.replace("rialo:", "");
91
+ return this._accounts;
92
+ }
93
+ async disconnect() {
94
+ if (this.provider) {
95
+ await this.provider.disconnect();
96
+ }
97
+ this._connected = false;
98
+ this._accounts = [];
99
+ }
100
+ async signMessage(message) {
101
+ if (!this.provider || !this._connected) {
102
+ throw new Error("Wallet not connected");
103
+ }
104
+ return this.provider.signMessage(message);
105
+ }
106
+ async signTransaction(tx) {
107
+ if (!this.provider || !this._connected) {
108
+ throw new Error("Wallet not connected");
109
+ }
110
+ const result = await this.provider.signTransaction(tx);
111
+ return result.signature;
112
+ }
113
+ async sendTransaction(tx) {
114
+ if (!this.provider || !this._connected) {
115
+ throw new Error("Wallet not connected");
116
+ }
117
+ return this.provider.sendTransaction(tx);
118
+ }
119
+ async signAndSendTransaction(tx) {
120
+ if (!this.provider || !this._connected) {
121
+ throw new Error("Wallet not connected");
122
+ }
123
+ return this.provider.signAndSendTransaction(tx);
124
+ }
125
+ async getBalance(address) {
126
+ if (!this.provider) {
127
+ throw new Error("Wallet not available");
128
+ }
129
+ return this.provider.getBalance(address);
130
+ }
131
+ async switchNetwork(network) {
132
+ if (!this.provider) {
133
+ throw new Error("Wallet not available");
134
+ }
135
+ await this.provider.switchNetwork(network);
136
+ this._network = network;
137
+ }
138
+ on(event, callback) {
139
+ if (!this.provider) {
140
+ return () => {
141
+ };
142
+ }
143
+ return this.provider.on(event, callback);
144
+ }
145
+ };
146
+ function formatAddress(address, chars = 4) {
147
+ if (!address) return "";
148
+ if (address.length <= chars * 2 + 3) return address;
149
+ return `${address.slice(0, chars + 2)}...${address.slice(-chars)}`;
150
+ }
151
+ function formatBalance(kelvins, decimals = 4) {
152
+ const value = typeof kelvins === "string" ? BigInt(kelvins) : kelvins;
153
+ const rlo = Number(value) / 1e9;
154
+ return rlo.toFixed(decimals);
155
+ }
156
+ function parseBalance(rlo) {
157
+ const value = typeof rlo === "string" ? parseFloat(rlo) : rlo;
158
+ return BigInt(Math.floor(value * 1e9));
159
+ }
160
+ function isValidAddress(address) {
161
+ if (!address || typeof address !== "string") return false;
162
+ if (address.length < 32 || address.length > 50) return false;
163
+ const base58Regex = /^[1-9A-HJ-NP-Za-km-z]+$/;
164
+ return base58Regex.test(address);
165
+ }
166
+ var src_default = RialoWallet;
167
+
168
+ export { NETWORKS, RialoWallet, src_default as default, formatAddress, formatBalance, getRialoProvider, isRialoInstalled, isValidAddress, parseBalance, waitForRialoProvider };
169
+ //# sourceMappingURL=index.js.map
170
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.ts"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["/**\n * @cookillabs/wallet-adapter\n * Community wallet adapter for Rialo blockchain dApps\n * \n * ⚠️ DISCLAIMER: This is a community package, NOT officially maintained by Rialo.\n * For official Rialo packages, see: https://www.npmjs.com/package/@rialo/frost\n */\n\n// ============================================================================\n// Types\n// ============================================================================\n\n/** Supported Rialo chains */\nexport type RialoChain = 'rialo:mainnet' | 'rialo:testnet' | 'rialo:devnet' | 'rialo:localnet';\n\n/** Network shorthand */\nexport type RialoNetwork = 'mainnet' | 'testnet' | 'devnet' | 'localnet';\n\n/** Wallet account */\nexport interface WalletAccount {\n address: string;\n publicKey?: Uint8Array | string;\n label?: string;\n}\n\n/** Transaction request */\nexport interface TransactionRequest {\n to: string;\n value: string;\n data?: string;\n memo?: string;\n}\n\n/** Transaction result */\nexport interface TransactionResult {\n hash: string;\n status: 'pending' | 'confirmed' | 'failed';\n blockNumber?: number;\n}\n\n/** Signed message */\nexport interface SignedMessage {\n signature: string;\n message: string;\n address: string;\n}\n\n/** Network configuration */\nexport interface NetworkConfig {\n chainId: string;\n name: string;\n rpcUrl: string;\n wsUrl?: string;\n explorerUrl?: string;\n}\n\n/** Wallet info for registry */\nexport interface WalletInfo {\n id: string;\n name: string;\n icon: string;\n installed?: boolean;\n downloadUrl?: string;\n}\n\n/** Wallet adapter events */\nexport type WalletEvent = 'connect' | 'disconnect' | 'accountChange' | 'networkChange' | 'error';\n\n// ============================================================================\n// Network Configurations\n// ============================================================================\n\nexport const NETWORKS: Record<RialoNetwork, NetworkConfig> = {\n mainnet: {\n chainId: 'rialo:mainnet',\n name: 'Rialo Mainnet',\n rpcUrl: 'https://mainnet.rialo.io:4101',\n wsUrl: 'wss://mainnet.rialo.io:4102',\n explorerUrl: 'https://explorer.rialo.io',\n },\n testnet: {\n chainId: 'rialo:testnet',\n name: 'Rialo Testnet',\n rpcUrl: 'https://testnet.rialo.io:4101',\n wsUrl: 'wss://testnet.rialo.io:4102',\n explorerUrl: 'https://testnet.explorer.rialo.io',\n },\n devnet: {\n chainId: 'rialo:devnet',\n name: 'Rialo Devnet',\n rpcUrl: 'https://devnet.rialo.io:4101',\n wsUrl: 'wss://devnet.rialo.io:4102',\n explorerUrl: 'https://devnet.explorer.rialo.io',\n },\n localnet: {\n chainId: 'rialo:localnet',\n name: 'Rialo Localnet',\n rpcUrl: 'http://localhost:4101',\n wsUrl: 'ws://localhost:4102',\n explorerUrl: 'http://localhost:3000',\n },\n};\n\n// ============================================================================\n// Wallet Provider Interface\n// ============================================================================\n\n/**\n * Provider interface injected by Rialo Wallet extension\n * Available at window.rialo when extension is installed\n */\nexport interface RialoProvider {\n isRialo: boolean;\n version: string;\n\n // Connection\n connect(): Promise<string[]>;\n disconnect(): Promise<void>;\n isConnected(): Promise<boolean>;\n getAccounts(): Promise<string[]>;\n\n // Transactions\n signTransaction(tx: TransactionRequest): Promise<{ signature: string; rawTransaction?: string }>;\n sendTransaction(tx: TransactionRequest): Promise<TransactionResult>;\n signAndSendTransaction(tx: TransactionRequest): Promise<TransactionResult>;\n\n // Message signing\n signMessage(message: string): Promise<SignedMessage>;\n\n // Network\n getNetwork(): Promise<string>;\n switchNetwork(network: RialoNetwork): Promise<void>;\n getBalance(address?: string): Promise<string>;\n\n // Events\n on(event: WalletEvent, callback: (data: unknown) => void): () => void;\n removeListener(event: WalletEvent, callback: (data: unknown) => void): void;\n removeAllListeners(event?: WalletEvent): void;\n}\n\n// ============================================================================\n// Detection & Access\n// ============================================================================\n\n/**\n * Check if Rialo Wallet extension is installed\n */\nexport function isRialoInstalled(): boolean {\n if (typeof window === 'undefined') return false;\n return !!(window as RialoWindow).rialo?.isRialo;\n}\n\n/**\n * Get the Rialo provider if available\n */\nexport function getRialoProvider(): RialoProvider | undefined {\n if (typeof window === 'undefined') return undefined;\n const rialo = (window as RialoWindow).rialo;\n return rialo?.isRialo ? rialo : undefined;\n}\n\n/**\n * Wait for Rialo provider to be available (with timeout)\n */\nexport function waitForRialoProvider(timeout = 3000): Promise<RialoProvider | undefined> {\n return new Promise((resolve) => {\n if (isRialoInstalled()) {\n resolve(getRialoProvider());\n return;\n }\n\n const checkInterval = setInterval(() => {\n if (isRialoInstalled()) {\n clearInterval(checkInterval);\n resolve(getRialoProvider());\n }\n }, 100);\n\n setTimeout(() => {\n clearInterval(checkInterval);\n resolve(undefined);\n }, timeout);\n });\n}\n\n// ============================================================================\n// Simple Wallet Class (Non-React)\n// ============================================================================\n\nexport class RialoWallet {\n private provider: RialoProvider | undefined;\n private _connected = false;\n private _accounts: WalletAccount[] = [];\n private _network: RialoNetwork = 'devnet';\n\n constructor() {\n this.provider = getRialoProvider();\n }\n\n get isInstalled(): boolean {\n return isRialoInstalled();\n }\n\n get connected(): boolean {\n return this._connected;\n }\n\n get accounts(): WalletAccount[] {\n return this._accounts;\n }\n\n get activeAccount(): WalletAccount | undefined {\n return this._accounts[0];\n }\n\n get network(): RialoNetwork {\n return this._network;\n }\n\n async connect(): Promise<WalletAccount[]> {\n this.provider = getRialoProvider();\n if (!this.provider) {\n throw new Error('Rialo Wallet not installed. Download at https://rialo.io/wallet');\n }\n\n const addresses = await this.provider.connect();\n this._accounts = addresses.map((address) => ({ address }));\n this._connected = true;\n\n const networkStr = await this.provider.getNetwork();\n this._network = networkStr.replace('rialo:', '') as RialoNetwork;\n\n return this._accounts;\n }\n\n async disconnect(): Promise<void> {\n if (this.provider) {\n await this.provider.disconnect();\n }\n this._connected = false;\n this._accounts = [];\n }\n\n async signMessage(message: string): Promise<SignedMessage> {\n if (!this.provider || !this._connected) {\n throw new Error('Wallet not connected');\n }\n return this.provider.signMessage(message);\n }\n\n async signTransaction(tx: TransactionRequest): Promise<string> {\n if (!this.provider || !this._connected) {\n throw new Error('Wallet not connected');\n }\n const result = await this.provider.signTransaction(tx);\n return result.signature;\n }\n\n async sendTransaction(tx: TransactionRequest): Promise<TransactionResult> {\n if (!this.provider || !this._connected) {\n throw new Error('Wallet not connected');\n }\n return this.provider.sendTransaction(tx);\n }\n\n async signAndSendTransaction(tx: TransactionRequest): Promise<TransactionResult> {\n if (!this.provider || !this._connected) {\n throw new Error('Wallet not connected');\n }\n return this.provider.signAndSendTransaction(tx);\n }\n\n async getBalance(address?: string): Promise<string> {\n if (!this.provider) {\n throw new Error('Wallet not available');\n }\n return this.provider.getBalance(address);\n }\n\n async switchNetwork(network: RialoNetwork): Promise<void> {\n if (!this.provider) {\n throw new Error('Wallet not available');\n }\n await this.provider.switchNetwork(network);\n this._network = network;\n }\n\n on(event: WalletEvent, callback: (data: unknown) => void): () => void {\n if (!this.provider) {\n return () => {};\n }\n return this.provider.on(event, callback);\n }\n}\n\n// ============================================================================\n// Utility Functions\n// ============================================================================\n\n/**\n * Format address for display (truncated base58)\n */\nexport function formatAddress(address: string, chars = 4): string {\n if (!address) return '';\n if (address.length <= chars * 2 + 3) return address;\n return `${address.slice(0, chars + 2)}...${address.slice(-chars)}`;\n}\n\n/**\n * Format balance from kelvins (smallest unit) to RLO\n */\nexport function formatBalance(kelvins: string | bigint, decimals = 4): string {\n const value = typeof kelvins === 'string' ? BigInt(kelvins) : kelvins;\n const rlo = Number(value) / 1_000_000_000;\n return rlo.toFixed(decimals);\n}\n\n/**\n * Parse RLO to kelvins\n */\nexport function parseBalance(rlo: string | number): bigint {\n const value = typeof rlo === 'string' ? parseFloat(rlo) : rlo;\n return BigInt(Math.floor(value * 1_000_000_000));\n}\n\n/**\n * Validate Rialo address format (base58)\n * Real Rialo addresses are base58 encoded public keys (32-50 chars)\n */\nexport function isValidAddress(address: string): boolean {\n if (!address || typeof address !== 'string') return false;\n if (address.length < 32 || address.length > 50) return false;\n \n // Base58 character set (no 0, O, I, l)\n const base58Regex = /^[1-9A-HJ-NP-Za-km-z]+$/;\n return base58Regex.test(address);\n}\n\n// ============================================================================\n// Window Extension\n// ============================================================================\n\ninterface RialoWindow extends Window {\n rialo?: RialoProvider;\n}\n\ndeclare global {\n interface Window {\n rialo?: RialoProvider;\n }\n}\n\n// ============================================================================\n// Default Export\n// ============================================================================\n\nexport default RialoWallet;\n"]}