@dipansrimany/mlink-sdk 0.1.1 → 0.3.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.
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/constants.ts","../../src/utils.ts","../../src/validators.ts","../../src/react/useMlink.ts","../../src/react/useExecuteMlink.ts","../../src/react/themes.ts","../../src/react/MlinkProvider.tsx","../../src/react/Mlink.tsx","../../src/react/adapters.ts"],"names":["useState","useCallback","jsx","useMemo"],"mappings":"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","file":"index.mjs","sourcesContent":["import type { ChainConfig } from './types';\n\nexport const MANTLE_MAINNET: ChainConfig = {\n chainId: 5000,\n name: 'Mantle',\n rpcUrl: 'https://rpc.mantle.xyz',\n explorerUrl: 'https://mantlescan.xyz',\n nativeCurrency: {\n name: 'MNT',\n symbol: 'MNT',\n decimals: 18,\n },\n};\n\nexport const MANTLE_SEPOLIA: ChainConfig = {\n chainId: 5003,\n name: 'Mantle Sepolia',\n rpcUrl: 'https://rpc.sepolia.mantle.xyz',\n explorerUrl: 'https://sepolia.mantlescan.xyz',\n nativeCurrency: {\n name: 'MNT',\n symbol: 'MNT',\n decimals: 18,\n },\n};\n\nexport const SUPPORTED_CHAINS: ChainConfig[] = [MANTLE_MAINNET, MANTLE_SEPOLIA];\n\nexport const DEFAULT_CHAIN = MANTLE_SEPOLIA;\n\nexport const BLINK_BASE_URL = 'https://blink.mantle.xyz';\n\nexport const ACTION_QUERY_PARAM = 'action';\n","import {\n BLINK_BASE_URL,\n ACTION_QUERY_PARAM,\n SUPPORTED_CHAINS,\n} from './constants';\nimport type { ChainConfig } from './types';\n\n// Create Blink URL from Action URL\nexport function createBlinkUrl(\n actionUrl: string,\n baseUrl: string = BLINK_BASE_URL\n): string {\n // Validate actionUrl is a valid URL\n try {\n new URL(actionUrl);\n } catch {\n throw new Error('Invalid action URL');\n }\n\n const encodedAction = encodeURIComponent(actionUrl);\n return `${baseUrl}/mlink?${ACTION_QUERY_PARAM}=${encodedAction}`;\n}\n\n// Parse Blink URL to extract Action URL\nexport function parseBlinkUrl(blinkUrl: string): string | null {\n try {\n const url = new URL(blinkUrl);\n const actionParam = url.searchParams.get(ACTION_QUERY_PARAM);\n\n if (!actionParam) return null;\n\n const actionUrl = decodeURIComponent(actionParam);\n\n // Validate it's a valid URL\n new URL(actionUrl);\n\n return actionUrl;\n } catch {\n return null;\n }\n}\n\n// Check if URL is a valid Blink URL\nexport function isBlinkUrl(url: string): boolean {\n return parseBlinkUrl(url) !== null;\n}\n\n// Convert human readable amount to wei string\nexport function parseEther(amount: string | number): string {\n const value = typeof amount === 'string' ? parseFloat(amount) : amount;\n if (isNaN(value) || value < 0) {\n throw new Error('Invalid amount');\n }\n const wei = BigInt(Math.floor(value * 1e18));\n return wei.toString();\n}\n\n// Convert wei to human readable amount\nexport function formatEther(wei: string | bigint): string {\n const value = typeof wei === 'string' ? BigInt(wei) : wei;\n const ether = Number(value) / 1e18;\n return ether.toFixed(6).replace(/\\.?0+$/, '');\n}\n\n// Shorten address for display\nexport function shortenAddress(address: string): string {\n if (!address || address.length < 10) return address;\n return `${address.slice(0, 6)}...${address.slice(-4)}`;\n}\n\n// Get explorer URL for transaction\nexport function getExplorerUrl(chainId: number, txHash: string): string {\n const chain = getChainById(chainId);\n if (!chain) return '';\n return `${chain.explorerUrl}/tx/${txHash}`;\n}\n\n// Get chain config by ID\nexport function getChainById(chainId: number): ChainConfig | undefined {\n return SUPPORTED_CHAINS.find((c) => c.chainId === chainId);\n}\n\n// Get explorer URL for address\nexport function getAddressExplorerUrl(\n chainId: number,\n address: string\n): string {\n const chain = getChainById(chainId);\n if (!chain) return '';\n return `${chain.explorerUrl}/address/${address}`;\n}\n","import { z } from 'zod';\nimport type {\n ActionMetadata,\n TransactionRequest,\n TransactionResponse,\n ValidationResult,\n} from './types';\n\n// Ethereum address regex\nconst addressRegex = /^0x[a-fA-F0-9]{40}$/;\n\n// Hex string regex\nconst hexRegex = /^0x[a-fA-F0-9]*$/;\n\n// Zod Schemas\nexport const ActionButtonSchema = z.object({\n label: z.string().min(1).max(50),\n value: z.string().min(1),\n type: z.enum(['button', 'input']),\n placeholder: z.string().optional(),\n disabled: z.boolean().optional(),\n});\n\nexport const ActionMetadataSchema = z.object({\n title: z.string().min(1).max(100),\n icon: z.string().url(),\n description: z.string().min(1).max(500),\n actions: z.array(ActionButtonSchema).min(1),\n disabled: z.boolean().optional(),\n error: z.object({ message: z.string() }).optional(),\n});\n\nexport const TransactionRequestSchema = z.object({\n account: z.string().regex(addressRegex, 'Invalid Ethereum address'),\n action: z.string().min(1),\n input: z.string().optional(),\n});\n\nexport const EVMTransactionSchema = z.object({\n to: z.string().regex(addressRegex, 'Invalid to address'),\n value: z.string(),\n data: z.string().regex(hexRegex, 'Invalid hex data'),\n chainId: z.number().positive(),\n});\n\nexport const TransactionResponseSchema = z.object({\n transaction: EVMTransactionSchema,\n message: z.string().optional(),\n});\n\n// Validation functions\nexport function validateActionMetadata(\n data: unknown\n): ValidationResult<ActionMetadata> {\n const result = ActionMetadataSchema.safeParse(data);\n if (result.success) {\n return { success: true, data: result.data as ActionMetadata };\n }\n return { success: false, error: result.error.message };\n}\n\nexport function validateTransactionRequest(\n data: unknown\n): ValidationResult<TransactionRequest> {\n const result = TransactionRequestSchema.safeParse(data);\n if (result.success) {\n return { success: true, data: result.data };\n }\n return { success: false, error: result.error.message };\n}\n\nexport function validateTransactionResponse(\n data: unknown\n): ValidationResult<TransactionResponse> {\n const result = TransactionResponseSchema.safeParse(data);\n if (result.success) {\n return { success: true, data: result.data as TransactionResponse };\n }\n return { success: false, error: result.error.message };\n}\n\nexport function isValidAddress(address: string): boolean {\n return addressRegex.test(address);\n}\n\nexport function isValidHex(hex: string): boolean {\n return hexRegex.test(hex);\n}\n","'use client';\r\n\r\nimport { useState, useEffect, useCallback, useRef } from 'react';\r\nimport type { ActionMetadata } from '../types';\r\nimport type { MlinkInstance, MlinkStatus, UseMlinkOptions } from './types';\r\nimport { parseBlinkUrl } from '../utils';\r\nimport { validateActionMetadata } from '../validators';\r\n\r\nconst DEFAULT_REFRESH_INTERVAL = 10 * 60 * 1000; // 10 minutes\r\n\r\nexport function useMlink(\r\n url: string,\r\n options: UseMlinkOptions = {}\r\n): MlinkInstance {\r\n const { refreshInterval = DEFAULT_REFRESH_INTERVAL, enabled = true } =\r\n options;\r\n\r\n const [status, setStatus] = useState<MlinkStatus>('idle');\r\n const [metadata, setMetadata] = useState<ActionMetadata | null>(null);\r\n const [error, setError] = useState<string | null>(null);\r\n\r\n const abortControllerRef = useRef<AbortController | null>(null);\r\n const intervalRef = useRef<ReturnType<typeof setInterval> | null>(null);\r\n\r\n // Extract action URL from mlink URL if needed\r\n const actionUrl = parseBlinkUrl(url) || url;\r\n\r\n const fetchMetadata = useCallback(async () => {\r\n if (!actionUrl || !enabled) return;\r\n\r\n // Abort previous request if still pending\r\n if (abortControllerRef.current) {\r\n abortControllerRef.current.abort();\r\n }\r\n\r\n abortControllerRef.current = new AbortController();\r\n\r\n setStatus('loading');\r\n setError(null);\r\n\r\n try {\r\n const response = await fetch(actionUrl, {\r\n method: 'GET',\r\n headers: {\r\n Accept: 'application/json',\r\n },\r\n signal: abortControllerRef.current.signal,\r\n });\r\n\r\n if (!response.ok) {\r\n throw new Error(`HTTP ${response.status}: ${response.statusText}`);\r\n }\r\n\r\n const data = await response.json();\r\n\r\n // Validate the response\r\n const validation = validateActionMetadata(data);\r\n if (!validation.success) {\r\n throw new Error(`Invalid metadata: ${validation.error}`);\r\n }\r\n\r\n setMetadata(validation.data);\r\n setStatus('ready');\r\n } catch (err) {\r\n if (err instanceof Error && err.name === 'AbortError') {\r\n return; // Ignore abort errors\r\n }\r\n\r\n const errorMessage =\r\n err instanceof Error ? err.message : 'Failed to fetch mlink data';\r\n setError(errorMessage);\r\n setStatus('error');\r\n }\r\n }, [actionUrl, enabled]);\r\n\r\n // Initial fetch\r\n useEffect(() => {\r\n if (enabled) {\r\n fetchMetadata();\r\n }\r\n\r\n return () => {\r\n if (abortControllerRef.current) {\r\n abortControllerRef.current.abort();\r\n }\r\n };\r\n }, [fetchMetadata, enabled]);\r\n\r\n // Set up refresh interval\r\n useEffect(() => {\r\n if (!enabled || !refreshInterval) return;\r\n\r\n intervalRef.current = setInterval(() => {\r\n fetchMetadata();\r\n }, refreshInterval);\r\n\r\n return () => {\r\n if (intervalRef.current) {\r\n clearInterval(intervalRef.current);\r\n }\r\n };\r\n }, [fetchMetadata, refreshInterval, enabled]);\r\n\r\n return {\r\n status,\r\n metadata,\r\n error,\r\n url: actionUrl,\r\n refresh: fetchMetadata,\r\n };\r\n}\r\n","'use client';\r\n\r\nimport { useState, useCallback } from 'react';\r\nimport type {\r\n MlinkAdapter,\r\n MlinkStatus,\r\n ExecutionResult,\r\n UseExecuteMlinkReturn,\r\n} from './types';\r\nimport type { TransactionResponse } from '../types';\r\nimport { validateTransactionResponse } from '../validators';\r\n\r\ninterface UseExecuteMlinkOptions {\r\n adapter: MlinkAdapter;\r\n actionUrl: string;\r\n onSuccess?: (txHash: string, action: string) => void;\r\n onError?: (error: string) => void;\r\n}\r\n\r\nexport function useExecuteMlink(\r\n options: UseExecuteMlinkOptions\r\n): UseExecuteMlinkReturn {\r\n const { adapter, actionUrl, onSuccess, onError } = options;\r\n\r\n const [status, setStatus] = useState<MlinkStatus>('ready');\r\n const [txHash, setTxHash] = useState<string | null>(null);\r\n const [error, setError] = useState<string | null>(null);\r\n\r\n const reset = useCallback(() => {\r\n setStatus('ready');\r\n setTxHash(null);\r\n setError(null);\r\n }, []);\r\n\r\n const execute = useCallback(\r\n async (action: string, input?: string): Promise<ExecutionResult> => {\r\n setStatus('executing');\r\n setError(null);\r\n setTxHash(null);\r\n\r\n try {\r\n // Ensure wallet is connected\r\n let account = adapter.getAddress();\r\n if (!adapter.isConnected() || !account) {\r\n account = await adapter.connect();\r\n }\r\n\r\n // Make POST request to get transaction\r\n const response = await fetch(actionUrl, {\r\n method: 'POST',\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n },\r\n body: JSON.stringify({\r\n account,\r\n action,\r\n input,\r\n }),\r\n });\r\n\r\n if (!response.ok) {\r\n const errorData = await response.json().catch(() => ({}));\r\n throw new Error(\r\n errorData.message || `HTTP ${response.status}: ${response.statusText}`\r\n );\r\n }\r\n\r\n const data: TransactionResponse = await response.json();\r\n\r\n // Validate response\r\n const validation = validateTransactionResponse(data);\r\n if (!validation.success) {\r\n throw new Error(`Invalid response: ${validation.error}`);\r\n }\r\n\r\n // Sign and send transaction\r\n const hash = await adapter.signAndSendTransaction(data.transaction);\r\n\r\n setTxHash(hash);\r\n setStatus('success');\r\n onSuccess?.(hash, action);\r\n\r\n return {\r\n success: true,\r\n txHash: hash,\r\n message: data.message,\r\n };\r\n } catch (err) {\r\n const errorMessage =\r\n err instanceof Error ? err.message : 'Transaction failed';\r\n setError(errorMessage);\r\n setStatus('error');\r\n onError?.(errorMessage);\r\n\r\n return {\r\n success: false,\r\n error: errorMessage,\r\n };\r\n }\r\n },\r\n [adapter, actionUrl, onSuccess, onError]\r\n );\r\n\r\n return {\r\n execute,\r\n status,\r\n txHash,\r\n error,\r\n reset,\r\n };\r\n}\r\n","import type { MlinkTheme, MlinkThemePreset } from './types';\r\n\r\nexport const lightTheme: MlinkTheme = {\r\n // Colors\r\n '--mlink-bg-primary': '#ffffff',\r\n '--mlink-bg-secondary': '#f8f9fa',\r\n '--mlink-border-color': '#e9ecef',\r\n '--mlink-text-primary': '#212529',\r\n '--mlink-text-secondary': '#6c757d',\r\n '--mlink-text-link': '#0d6efd',\r\n '--mlink-button-bg': '#212529',\r\n '--mlink-button-text': '#ffffff',\r\n '--mlink-button-hover': '#343a40',\r\n '--mlink-button-disabled': '#adb5bd',\r\n '--mlink-input-bg': '#ffffff',\r\n '--mlink-input-border': '#ced4da',\r\n '--mlink-input-text': '#212529',\r\n '--mlink-input-placeholder': '#adb5bd',\r\n '--mlink-success': '#198754',\r\n '--mlink-error': '#dc3545',\r\n '--mlink-warning': '#ffc107',\r\n // Sizing\r\n '--mlink-border-radius': '12px',\r\n '--mlink-button-radius': '8px',\r\n '--mlink-input-radius': '8px',\r\n // Shadows\r\n '--mlink-shadow': '0 2px 8px rgba(0, 0, 0, 0.08)',\r\n};\r\n\r\nexport const darkTheme: MlinkTheme = {\r\n // Colors\r\n '--mlink-bg-primary': '#1a1a1a',\r\n '--mlink-bg-secondary': '#2d2d2d',\r\n '--mlink-border-color': '#404040',\r\n '--mlink-text-primary': '#ffffff',\r\n '--mlink-text-secondary': '#a0a0a0',\r\n '--mlink-text-link': '#60a5fa',\r\n '--mlink-button-bg': '#ffffff',\r\n '--mlink-button-text': '#1a1a1a',\r\n '--mlink-button-hover': '#e5e5e5',\r\n '--mlink-button-disabled': '#525252',\r\n '--mlink-input-bg': '#2d2d2d',\r\n '--mlink-input-border': '#404040',\r\n '--mlink-input-text': '#ffffff',\r\n '--mlink-input-placeholder': '#6b7280',\r\n '--mlink-success': '#22c55e',\r\n '--mlink-error': '#ef4444',\r\n '--mlink-warning': '#f59e0b',\r\n // Sizing\r\n '--mlink-border-radius': '12px',\r\n '--mlink-button-radius': '8px',\r\n '--mlink-input-radius': '8px',\r\n // Shadows\r\n '--mlink-shadow': '0 2px 8px rgba(0, 0, 0, 0.3)',\r\n};\r\n\r\nexport const mantleTheme: MlinkTheme = {\r\n // Colors - Mantle brand colors\r\n '--mlink-bg-primary': '#0a0a0a',\r\n '--mlink-bg-secondary': '#141414',\r\n '--mlink-border-color': '#2a2a2a',\r\n '--mlink-text-primary': '#ffffff',\r\n '--mlink-text-secondary': '#9ca3af',\r\n '--mlink-text-link': '#65d9e4',\r\n '--mlink-button-bg': '#65d9e4',\r\n '--mlink-button-text': '#000000',\r\n '--mlink-button-hover': '#85e3ec',\r\n '--mlink-button-disabled': '#374151',\r\n '--mlink-input-bg': '#1f1f1f',\r\n '--mlink-input-border': '#374151',\r\n '--mlink-input-text': '#ffffff',\r\n '--mlink-input-placeholder': '#6b7280',\r\n '--mlink-success': '#34d399',\r\n '--mlink-error': '#f87171',\r\n '--mlink-warning': '#fbbf24',\r\n // Sizing\r\n '--mlink-border-radius': '16px',\r\n '--mlink-button-radius': '10px',\r\n '--mlink-input-radius': '10px',\r\n // Shadows\r\n '--mlink-shadow': '0 4px 16px rgba(101, 217, 228, 0.1)',\r\n};\r\n\r\nexport const themePresets: Record<MlinkThemePreset, MlinkTheme> = {\r\n light: lightTheme,\r\n dark: darkTheme,\r\n mantle: mantleTheme,\r\n};\r\n\r\nexport function resolveTheme(\r\n theme?: Partial<MlinkTheme> | MlinkThemePreset\r\n): MlinkTheme {\r\n if (!theme) {\r\n return darkTheme;\r\n }\r\n\r\n if (typeof theme === 'string') {\r\n return themePresets[theme] || darkTheme;\r\n }\r\n\r\n // Merge custom theme with dark theme as base\r\n return { ...darkTheme, ...theme };\r\n}\r\n\r\nexport function themeToCSS(theme: MlinkTheme): React.CSSProperties {\r\n return theme as unknown as React.CSSProperties;\r\n}\r\n","'use client';\r\n\r\nimport React, { createContext, useContext, useMemo } from 'react';\r\nimport type { MlinkProviderConfig, MlinkTheme } from './types';\r\nimport type { ChainConfig } from '../types';\r\nimport { resolveTheme } from './themes';\r\nimport { DEFAULT_CHAIN } from '../constants';\r\n\r\ninterface MlinkContextValue {\r\n theme: MlinkTheme;\r\n defaultChain: ChainConfig;\r\n}\r\n\r\nconst MlinkContext = createContext<MlinkContextValue | null>(null);\r\n\r\nexport interface MlinkProviderProps extends MlinkProviderConfig {\r\n children: React.ReactNode;\r\n}\r\n\r\nexport function MlinkProvider({\r\n children,\r\n theme,\r\n defaultChain = DEFAULT_CHAIN,\r\n}: MlinkProviderProps) {\r\n const resolvedTheme = useMemo(() => resolveTheme(theme), [theme]);\r\n\r\n const value = useMemo(\r\n () => ({\r\n theme: resolvedTheme,\r\n defaultChain,\r\n }),\r\n [resolvedTheme, defaultChain]\r\n );\r\n\r\n return (\r\n <MlinkContext.Provider value={value}>{children}</MlinkContext.Provider>\r\n );\r\n}\r\n\r\nexport function useMlinkContext(): MlinkContextValue {\r\n const context = useContext(MlinkContext);\r\n if (!context) {\r\n // Return defaults if not wrapped in provider\r\n return {\r\n theme: resolveTheme('dark'),\r\n defaultChain: DEFAULT_CHAIN,\r\n };\r\n }\r\n return context;\r\n}\r\n","'use client';\r\n\r\nimport React, { useState, useCallback } from 'react';\r\nimport type { MlinkProps, MlinkTheme } from './types';\r\nimport type { ActionButton } from '../types';\r\nimport { useMlink } from './useMlink';\r\nimport { useExecuteMlink } from './useExecuteMlink';\r\nimport { useMlinkContext } from './MlinkProvider';\r\nimport { resolveTheme, themeToCSS } from './themes';\r\n\r\nexport function Mlink({\r\n url,\r\n adapter,\r\n theme: themeProp,\r\n onSuccess,\r\n onError,\r\n className = '',\r\n stylePreset = 'default',\r\n}: MlinkProps) {\r\n const context = useMlinkContext();\r\n const resolvedTheme = themeProp ? resolveTheme(themeProp) : context.theme;\r\n\r\n const { status: fetchStatus, metadata, error: fetchError } = useMlink(url);\r\n\r\n const {\r\n execute,\r\n status: execStatus,\r\n txHash,\r\n error: execError,\r\n reset,\r\n } = useExecuteMlink({\r\n adapter,\r\n actionUrl: url,\r\n onSuccess,\r\n onError,\r\n });\r\n\r\n const [inputValues, setInputValues] = useState<Record<string, string>>({});\r\n\r\n const handleInputChange = useCallback((actionValue: string, value: string) => {\r\n setInputValues((prev) => ({ ...prev, [actionValue]: value }));\r\n }, []);\r\n\r\n const handleAction = useCallback(\r\n async (action: ActionButton) => {\r\n const input = action.type === 'input' ? inputValues[action.value] : undefined;\r\n await execute(action.value, input);\r\n },\r\n [execute, inputValues]\r\n );\r\n\r\n // Loading state\r\n if (fetchStatus === 'loading') {\r\n return (\r\n <MlinkContainer theme={resolvedTheme} className={className} preset={stylePreset}>\r\n <MlinkSkeleton />\r\n </MlinkContainer>\r\n );\r\n }\r\n\r\n // Error state\r\n if (fetchStatus === 'error' || !metadata) {\r\n return (\r\n <MlinkContainer theme={resolvedTheme} className={className} preset={stylePreset}>\r\n <MlinkError message={fetchError || 'Failed to load action'} />\r\n </MlinkContainer>\r\n );\r\n }\r\n\r\n // Success state after transaction\r\n if (execStatus === 'success' && txHash) {\r\n return (\r\n <MlinkContainer theme={resolvedTheme} className={className} preset={stylePreset}>\r\n <MlinkSuccess\r\n message={metadata.title}\r\n txHash={txHash}\r\n onReset={reset}\r\n />\r\n </MlinkContainer>\r\n );\r\n }\r\n\r\n return (\r\n <MlinkContainer theme={resolvedTheme} className={className} preset={stylePreset}>\r\n {/* Icon */}\r\n <div className=\"mlink-icon\">\r\n <img src={metadata.icon} alt={metadata.title} />\r\n </div>\r\n\r\n {/* Content */}\r\n <div className=\"mlink-content\">\r\n <h3 className=\"mlink-title\">{metadata.title}</h3>\r\n <p className=\"mlink-description\">{metadata.description}</p>\r\n </div>\r\n\r\n {/* Error display */}\r\n {execError && (\r\n <div className=\"mlink-error-banner\">\r\n {execError}\r\n </div>\r\n )}\r\n\r\n {/* Actions */}\r\n <div className=\"mlink-actions\">\r\n {metadata.actions.map((action, index) => (\r\n <ActionButtonComponent\r\n key={`${action.value}-${index}`}\r\n action={action}\r\n inputValue={inputValues[action.value] || ''}\r\n onInputChange={(value) => handleInputChange(action.value, value)}\r\n onExecute={() => handleAction(action)}\r\n loading={execStatus === 'executing'}\r\n disabled={metadata.disabled === true || action.disabled === true}\r\n />\r\n ))}\r\n </div>\r\n </MlinkContainer>\r\n );\r\n}\r\n\r\n// Container component\r\ninterface MlinkContainerProps {\r\n theme: MlinkTheme;\r\n className: string;\r\n preset: 'default' | 'compact' | 'minimal';\r\n children: React.ReactNode;\r\n}\r\n\r\nfunction MlinkContainer({ theme, className, preset, children }: MlinkContainerProps) {\r\n return (\r\n <div\r\n className={`mlink-container mlink-${preset} ${className}`}\r\n style={themeToCSS(theme)}\r\n >\r\n {children}\r\n </div>\r\n );\r\n}\r\n\r\n// Skeleton loading component\r\nfunction MlinkSkeleton() {\r\n return (\r\n <div className=\"mlink-skeleton\">\r\n <div className=\"mlink-skeleton-icon\" />\r\n <div className=\"mlink-skeleton-content\">\r\n <div className=\"mlink-skeleton-title\" />\r\n <div className=\"mlink-skeleton-description\" />\r\n </div>\r\n <div className=\"mlink-skeleton-button\" />\r\n </div>\r\n );\r\n}\r\n\r\n// Error component\r\nfunction MlinkError({ message }: { message: string }) {\r\n return (\r\n <div className=\"mlink-error\">\r\n <div className=\"mlink-error-icon\">!</div>\r\n <p className=\"mlink-error-message\">{message}</p>\r\n </div>\r\n );\r\n}\r\n\r\n// Success component\r\ninterface MlinkSuccessProps {\r\n message: string;\r\n txHash: string;\r\n onReset: () => void;\r\n}\r\n\r\nfunction MlinkSuccess({ message, txHash, onReset }: MlinkSuccessProps) {\r\n const shortHash = `${txHash.slice(0, 10)}...${txHash.slice(-8)}`;\r\n\r\n return (\r\n <div className=\"mlink-success\">\r\n <div className=\"mlink-success-icon\">✓</div>\r\n <h3 className=\"mlink-success-title\">Transaction Sent</h3>\r\n <p className=\"mlink-success-message\">{message}</p>\r\n <code className=\"mlink-success-hash\">{shortHash}</code>\r\n <button className=\"mlink-button mlink-button-secondary\" onClick={onReset}>\r\n Done\r\n </button>\r\n </div>\r\n );\r\n}\r\n\r\n// Action button component\r\ninterface ActionButtonComponentProps {\r\n action: ActionButton;\r\n inputValue: string;\r\n onInputChange: (value: string) => void;\r\n onExecute: () => void;\r\n loading: boolean;\r\n disabled: boolean;\r\n}\r\n\r\nfunction ActionButtonComponent({\r\n action,\r\n inputValue,\r\n onInputChange,\r\n onExecute,\r\n loading,\r\n disabled,\r\n}: ActionButtonComponentProps) {\r\n if (action.type === 'input') {\r\n return (\r\n <div className=\"mlink-input-group\">\r\n <input\r\n type=\"text\"\r\n className=\"mlink-input\"\r\n placeholder={action.placeholder || action.label}\r\n value={inputValue}\r\n onChange={(e) => onInputChange(e.target.value)}\r\n disabled={disabled || loading}\r\n />\r\n <button\r\n className=\"mlink-button\"\r\n onClick={onExecute}\r\n disabled={disabled || loading || !inputValue.trim()}\r\n >\r\n {loading ? <MlinkSpinner /> : action.label}\r\n </button>\r\n </div>\r\n );\r\n }\r\n\r\n return (\r\n <button\r\n className=\"mlink-button\"\r\n onClick={onExecute}\r\n disabled={disabled || loading}\r\n >\r\n {loading ? <MlinkSpinner /> : action.label}\r\n </button>\r\n );\r\n}\r\n\r\n// Spinner component\r\nfunction MlinkSpinner() {\r\n return <span className=\"mlink-spinner\" />;\r\n}\r\n\r\nexport default Mlink;\r\n","'use client';\r\n\r\nimport { useMemo } from 'react';\r\nimport type {\r\n MlinkAdapter,\r\n WagmiAdapterConfig,\r\n EthersAdapterConfig,\r\n} from './types';\r\nimport type { EVMTransaction } from '../types';\r\n\r\n/**\r\n * Create a Mlink adapter from wagmi hooks\r\n *\r\n * @example\r\n * ```tsx\r\n * import { useAccount, useConnect, useSendTransaction } from 'wagmi';\r\n * import { useMlinkWagmiAdapter } from '@dipansrimany/mlink-sdk/react';\r\n *\r\n * function MyComponent() {\r\n * const { address, isConnected } = useAccount();\r\n * const { connectAsync, connectors } = useConnect();\r\n * const { sendTransactionAsync } = useSendTransaction();\r\n *\r\n * const adapter = useMlinkWagmiAdapter({\r\n * address,\r\n * isConnected,\r\n * connect: async () => {\r\n * await connectAsync({ connector: connectors[0] });\r\n * },\r\n * sendTransaction: sendTransactionAsync,\r\n * });\r\n *\r\n * return <Mlink url=\"...\" adapter={adapter} />;\r\n * }\r\n * ```\r\n */\r\nexport function useMlinkWagmiAdapter(config: WagmiAdapterConfig): MlinkAdapter {\r\n const { address, isConnected, connect, sendTransaction } = config;\r\n\r\n return useMemo(\r\n () => ({\r\n connect: async () => {\r\n await connect();\r\n if (!address) {\r\n throw new Error('Failed to connect wallet');\r\n }\r\n return address;\r\n },\r\n\r\n signAndSendTransaction: async (transaction: EVMTransaction) => {\r\n const txHash = await sendTransaction({\r\n to: transaction.to as `0x${string}`,\r\n value: BigInt(transaction.value),\r\n data: transaction.data as `0x${string}`,\r\n chainId: transaction.chainId,\r\n });\r\n return txHash;\r\n },\r\n\r\n isConnected: () => isConnected,\r\n\r\n getAddress: () => address || null,\r\n }),\r\n [address, isConnected, connect, sendTransaction]\r\n );\r\n}\r\n\r\n/**\r\n * Create a Mlink adapter from ethers.js signer\r\n *\r\n * @example\r\n * ```tsx\r\n * import { useSigner } from 'some-ethers-provider';\r\n * import { useMlinkEthersAdapter } from '@dipansrimany/mlink-sdk/react';\r\n *\r\n * function MyComponent() {\r\n * const { signer, connect } = useSigner();\r\n *\r\n * const adapter = useMlinkEthersAdapter({\r\n * signer,\r\n * connect,\r\n * });\r\n *\r\n * return <Mlink url=\"...\" adapter={adapter} />;\r\n * }\r\n * ```\r\n */\r\nexport function useMlinkEthersAdapter(\r\n config: EthersAdapterConfig\r\n): MlinkAdapter {\r\n const { signer, connect } = config;\r\n\r\n return useMemo(\r\n () => ({\r\n connect: async () => {\r\n await connect();\r\n if (!signer) {\r\n throw new Error('Failed to connect wallet');\r\n }\r\n return await signer.getAddress();\r\n },\r\n\r\n signAndSendTransaction: async (transaction: EVMTransaction) => {\r\n if (!signer) {\r\n throw new Error('Wallet not connected');\r\n }\r\n\r\n const tx = await signer.sendTransaction({\r\n to: transaction.to,\r\n value: BigInt(transaction.value),\r\n data: transaction.data,\r\n chainId: transaction.chainId,\r\n });\r\n\r\n return tx.hash;\r\n },\r\n\r\n isConnected: () => signer !== null,\r\n\r\n getAddress: () => null, // Ethers requires async call\r\n }),\r\n [signer, connect]\r\n );\r\n}\r\n\r\n/**\r\n * Create a custom Mlink adapter\r\n *\r\n * @example\r\n * ```tsx\r\n * import { createMlinkAdapter } from '@dipansrimany/mlink-sdk/react';\r\n *\r\n * const adapter = createMlinkAdapter({\r\n * connect: async () => {\r\n * // Your connect logic\r\n * return '0x...';\r\n * },\r\n * signAndSendTransaction: async (tx) => {\r\n * // Your transaction logic\r\n * return '0x...txHash';\r\n * },\r\n * isConnected: () => true,\r\n * getAddress: () => '0x...',\r\n * });\r\n * ```\r\n */\r\nexport function createMlinkAdapter(adapter: MlinkAdapter): MlinkAdapter {\r\n return adapter;\r\n}\r\n"]}
@@ -0,0 +1,339 @@
1
+ /* Mlink SDK Styles */
2
+
3
+ /* Container */
4
+ .mlink-container {
5
+ font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen,
6
+ Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
7
+ background: var(--mlink-bg-primary);
8
+ border: 1px solid var(--mlink-border-color);
9
+ border-radius: var(--mlink-border-radius);
10
+ box-shadow: var(--mlink-shadow);
11
+ overflow: hidden;
12
+ width: 100%;
13
+ max-width: 400px;
14
+ }
15
+
16
+ /* Style presets */
17
+ .mlink-default {
18
+ padding: 0;
19
+ }
20
+
21
+ .mlink-compact {
22
+ max-width: 320px;
23
+ }
24
+
25
+ .mlink-minimal {
26
+ border: none;
27
+ box-shadow: none;
28
+ background: transparent;
29
+ }
30
+
31
+ /* Icon */
32
+ .mlink-icon {
33
+ width: 100%;
34
+ aspect-ratio: 16 / 9;
35
+ background: var(--mlink-bg-secondary);
36
+ overflow: hidden;
37
+ }
38
+
39
+ .mlink-icon img {
40
+ width: 100%;
41
+ height: 100%;
42
+ object-fit: cover;
43
+ }
44
+
45
+ /* Content */
46
+ .mlink-content {
47
+ padding: 16px;
48
+ }
49
+
50
+ .mlink-title {
51
+ margin: 0 0 8px 0;
52
+ font-size: 18px;
53
+ font-weight: 600;
54
+ color: var(--mlink-text-primary);
55
+ line-height: 1.3;
56
+ }
57
+
58
+ .mlink-description {
59
+ margin: 0;
60
+ font-size: 14px;
61
+ color: var(--mlink-text-secondary);
62
+ line-height: 1.5;
63
+ }
64
+
65
+ /* Actions */
66
+ .mlink-actions {
67
+ padding: 0 16px 16px;
68
+ display: flex;
69
+ flex-direction: column;
70
+ gap: 8px;
71
+ }
72
+
73
+ /* Button */
74
+ .mlink-button {
75
+ display: inline-flex;
76
+ align-items: center;
77
+ justify-content: center;
78
+ gap: 8px;
79
+ padding: 12px 20px;
80
+ font-size: 14px;
81
+ font-weight: 600;
82
+ color: var(--mlink-button-text);
83
+ background: var(--mlink-button-bg);
84
+ border: none;
85
+ border-radius: var(--mlink-button-radius);
86
+ cursor: pointer;
87
+ transition: background-color 0.15s ease, opacity 0.15s ease;
88
+ width: 100%;
89
+ min-height: 44px;
90
+ }
91
+
92
+ .mlink-button:hover:not(:disabled) {
93
+ background: var(--mlink-button-hover);
94
+ }
95
+
96
+ .mlink-button:disabled {
97
+ background: var(--mlink-button-disabled);
98
+ cursor: not-allowed;
99
+ opacity: 0.7;
100
+ }
101
+
102
+ .mlink-button-secondary {
103
+ background: var(--mlink-bg-secondary);
104
+ color: var(--mlink-text-primary);
105
+ border: 1px solid var(--mlink-border-color);
106
+ }
107
+
108
+ .mlink-button-secondary:hover:not(:disabled) {
109
+ background: var(--mlink-border-color);
110
+ }
111
+
112
+ /* Input group */
113
+ .mlink-input-group {
114
+ display: flex;
115
+ gap: 8px;
116
+ }
117
+
118
+ .mlink-input-group .mlink-input {
119
+ flex: 1;
120
+ }
121
+
122
+ .mlink-input-group .mlink-button {
123
+ flex-shrink: 0;
124
+ width: auto;
125
+ padding: 12px 16px;
126
+ }
127
+
128
+ /* Input */
129
+ .mlink-input {
130
+ padding: 12px 16px;
131
+ font-size: 14px;
132
+ color: var(--mlink-input-text);
133
+ background: var(--mlink-input-bg);
134
+ border: 1px solid var(--mlink-input-border);
135
+ border-radius: var(--mlink-input-radius);
136
+ outline: none;
137
+ transition: border-color 0.15s ease, box-shadow 0.15s ease;
138
+ min-height: 44px;
139
+ width: 100%;
140
+ box-sizing: border-box;
141
+ }
142
+
143
+ .mlink-input::placeholder {
144
+ color: var(--mlink-input-placeholder);
145
+ }
146
+
147
+ .mlink-input:focus {
148
+ border-color: var(--mlink-button-bg);
149
+ box-shadow: 0 0 0 3px rgba(101, 217, 228, 0.1);
150
+ }
151
+
152
+ .mlink-input:disabled {
153
+ opacity: 0.7;
154
+ cursor: not-allowed;
155
+ }
156
+
157
+ /* Spinner */
158
+ .mlink-spinner {
159
+ width: 16px;
160
+ height: 16px;
161
+ border: 2px solid transparent;
162
+ border-top-color: currentColor;
163
+ border-radius: 50%;
164
+ animation: mlink-spin 0.8s linear infinite;
165
+ }
166
+
167
+ @keyframes mlink-spin {
168
+ to {
169
+ transform: rotate(360deg);
170
+ }
171
+ }
172
+
173
+ /* Skeleton loading */
174
+ .mlink-skeleton {
175
+ padding: 16px;
176
+ }
177
+
178
+ .mlink-skeleton-icon {
179
+ width: 100%;
180
+ aspect-ratio: 16 / 9;
181
+ background: var(--mlink-bg-secondary);
182
+ border-radius: 8px;
183
+ margin-bottom: 16px;
184
+ animation: mlink-pulse 1.5s ease-in-out infinite;
185
+ }
186
+
187
+ .mlink-skeleton-content {
188
+ margin-bottom: 16px;
189
+ }
190
+
191
+ .mlink-skeleton-title {
192
+ width: 60%;
193
+ height: 20px;
194
+ background: var(--mlink-bg-secondary);
195
+ border-radius: 4px;
196
+ margin-bottom: 8px;
197
+ animation: mlink-pulse 1.5s ease-in-out infinite;
198
+ }
199
+
200
+ .mlink-skeleton-description {
201
+ width: 100%;
202
+ height: 14px;
203
+ background: var(--mlink-bg-secondary);
204
+ border-radius: 4px;
205
+ animation: mlink-pulse 1.5s ease-in-out infinite;
206
+ }
207
+
208
+ .mlink-skeleton-button {
209
+ width: 100%;
210
+ height: 44px;
211
+ background: var(--mlink-bg-secondary);
212
+ border-radius: var(--mlink-button-radius);
213
+ animation: mlink-pulse 1.5s ease-in-out infinite;
214
+ }
215
+
216
+ @keyframes mlink-pulse {
217
+ 0%,
218
+ 100% {
219
+ opacity: 1;
220
+ }
221
+ 50% {
222
+ opacity: 0.5;
223
+ }
224
+ }
225
+
226
+ /* Error state */
227
+ .mlink-error {
228
+ padding: 24px;
229
+ text-align: center;
230
+ }
231
+
232
+ .mlink-error-icon {
233
+ width: 48px;
234
+ height: 48px;
235
+ margin: 0 auto 16px;
236
+ display: flex;
237
+ align-items: center;
238
+ justify-content: center;
239
+ background: var(--mlink-error);
240
+ color: white;
241
+ font-size: 24px;
242
+ font-weight: bold;
243
+ border-radius: 50%;
244
+ }
245
+
246
+ .mlink-error-message {
247
+ margin: 0;
248
+ font-size: 14px;
249
+ color: var(--mlink-text-secondary);
250
+ }
251
+
252
+ .mlink-error-banner {
253
+ margin: 0 16px 8px;
254
+ padding: 12px;
255
+ background: rgba(239, 68, 68, 0.1);
256
+ border: 1px solid var(--mlink-error);
257
+ border-radius: 8px;
258
+ color: var(--mlink-error);
259
+ font-size: 13px;
260
+ text-align: center;
261
+ }
262
+
263
+ /* Success state */
264
+ .mlink-success {
265
+ padding: 24px;
266
+ text-align: center;
267
+ }
268
+
269
+ .mlink-success-icon {
270
+ width: 48px;
271
+ height: 48px;
272
+ margin: 0 auto 16px;
273
+ display: flex;
274
+ align-items: center;
275
+ justify-content: center;
276
+ background: var(--mlink-success);
277
+ color: white;
278
+ font-size: 24px;
279
+ font-weight: bold;
280
+ border-radius: 50%;
281
+ }
282
+
283
+ .mlink-success-title {
284
+ margin: 0 0 8px 0;
285
+ font-size: 18px;
286
+ font-weight: 600;
287
+ color: var(--mlink-text-primary);
288
+ }
289
+
290
+ .mlink-success-message {
291
+ margin: 0 0 12px 0;
292
+ font-size: 14px;
293
+ color: var(--mlink-text-secondary);
294
+ }
295
+
296
+ .mlink-success-hash {
297
+ display: block;
298
+ margin: 0 0 16px 0;
299
+ padding: 8px 12px;
300
+ background: var(--mlink-bg-secondary);
301
+ border-radius: 6px;
302
+ font-size: 12px;
303
+ color: var(--mlink-text-link);
304
+ word-break: break-all;
305
+ }
306
+
307
+ /* Disabled state overlay */
308
+ .mlink-disabled {
309
+ opacity: 0.6;
310
+ pointer-events: none;
311
+ }
312
+
313
+ /* Link styles */
314
+ .mlink-link {
315
+ color: var(--mlink-text-link);
316
+ text-decoration: none;
317
+ }
318
+
319
+ .mlink-link:hover {
320
+ text-decoration: underline;
321
+ }
322
+
323
+ /* Responsive */
324
+ @media (max-width: 480px) {
325
+ .mlink-container {
326
+ max-width: 100%;
327
+ border-radius: 0;
328
+ border-left: none;
329
+ border-right: none;
330
+ }
331
+
332
+ .mlink-input-group {
333
+ flex-direction: column;
334
+ }
335
+
336
+ .mlink-input-group .mlink-button {
337
+ width: 100%;
338
+ }
339
+ }
@@ -65,20 +65,4 @@ type ValidationResult<T> = {
65
65
  error: string;
66
66
  };
67
67
 
68
- declare function button(config: {
69
- label: string;
70
- value: string;
71
- disabled?: boolean;
72
- }): ActionButton;
73
- declare function input(config: {
74
- label: string;
75
- placeholder?: string;
76
- disabled?: boolean;
77
- }): ActionButton;
78
- interface Action {
79
- getMetadata(): ActionMetadata;
80
- handleRequest(request: TransactionRequest): Promise<TransactionResponse>;
81
- }
82
- declare function createAction(definition: ActionDefinition): Action;
83
-
84
- export { type ActionMetadata as A, type ChainConfig as C, type EVMTransaction as E, type TransactionRequest as T, type ValidationResult as V, type TransactionResponse as a, type ActionType as b, type ActionButton as c, type ActionError as d, type ActionHandler as e, type ActionDefinition as f, type ActionContext as g, createAction as h, button as i, input as j, type Action as k };
68
+ export type { ActionMetadata as A, ChainConfig as C, EVMTransaction as E, TransactionRequest as T, ValidationResult as V, TransactionResponse as a, ActionType as b, ActionButton as c, ActionError as d, ActionHandler as e, ActionDefinition as f, ActionContext as g };
@@ -65,20 +65,4 @@ type ValidationResult<T> = {
65
65
  error: string;
66
66
  };
67
67
 
68
- declare function button(config: {
69
- label: string;
70
- value: string;
71
- disabled?: boolean;
72
- }): ActionButton;
73
- declare function input(config: {
74
- label: string;
75
- placeholder?: string;
76
- disabled?: boolean;
77
- }): ActionButton;
78
- interface Action {
79
- getMetadata(): ActionMetadata;
80
- handleRequest(request: TransactionRequest): Promise<TransactionResponse>;
81
- }
82
- declare function createAction(definition: ActionDefinition): Action;
83
-
84
- export { type ActionMetadata as A, type ChainConfig as C, type EVMTransaction as E, type TransactionRequest as T, type ValidationResult as V, type TransactionResponse as a, type ActionType as b, type ActionButton as c, type ActionError as d, type ActionHandler as e, type ActionDefinition as f, type ActionContext as g, createAction as h, button as i, input as j, type Action as k };
68
+ export type { ActionMetadata as A, ChainConfig as C, EVMTransaction as E, TransactionRequest as T, ValidationResult as V, TransactionResponse as a, ActionType as b, ActionButton as c, ActionError as d, ActionHandler as e, ActionDefinition as f, ActionContext as g };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@dipansrimany/mlink-sdk",
3
- "version": "0.1.1",
4
- "description": "SDK for building Mantle links - shareable blockchain transaction URLs",
3
+ "version": "0.3.1",
4
+ "description": "SDK for building Mantle links - shareable blockchain transaction URLs with React UI components",
5
5
  "author": "Mlink",
6
6
  "repository": {
7
7
  "type": "git",
@@ -29,16 +29,23 @@
29
29
  "types": "./dist/adapters/express.d.ts",
30
30
  "import": "./dist/adapters/express.mjs",
31
31
  "require": "./dist/adapters/express.js"
32
- }
32
+ },
33
+ "./react": {
34
+ "types": "./dist/react/index.d.ts",
35
+ "import": "./dist/react/index.mjs",
36
+ "require": "./dist/react/index.js"
37
+ },
38
+ "./styles.css": "./dist/styles.css"
33
39
  },
34
40
  "files": [
35
41
  "dist"
36
42
  ],
37
43
  "scripts": {
38
- "build": "tsup",
44
+ "build": "tsup && npm run build:css",
45
+ "build:css": "node -e \"require('fs').copyFileSync('src/react/styles.css', 'dist/styles.css')\"",
39
46
  "dev": "tsup --watch",
40
47
  "typecheck": "tsc --noEmit",
41
- "clean": "rm -rf dist",
48
+ "clean": "node -e \"require('fs').rmSync('dist', { recursive: true, force: true })\"",
42
49
  "prepublishOnly": "npm run build"
43
50
  },
44
51
  "dependencies": {
@@ -47,6 +54,8 @@
47
54
  "devDependencies": {
48
55
  "@types/express": "^4.17.21",
49
56
  "@types/node": "^20.10.0",
57
+ "@types/react": "^18.3.27",
58
+ "@types/react-dom": "^18.3.7",
50
59
  "express": "^4.18.0",
51
60
  "next": "^14.2.0",
52
61
  "react": "^18.2.0",
@@ -55,8 +64,10 @@
55
64
  "typescript": "^5.3.0"
56
65
  },
57
66
  "peerDependencies": {
67
+ "express": ">=4.0.0",
58
68
  "next": ">=14.0.0",
59
- "express": ">=4.0.0"
69
+ "react": ">=18.0.0",
70
+ "react-dom": ">=18.0.0"
60
71
  },
61
72
  "peerDependenciesMeta": {
62
73
  "next": {
@@ -64,6 +75,12 @@
64
75
  },
65
76
  "express": {
66
77
  "optional": true
78
+ },
79
+ "react": {
80
+ "optional": true
81
+ },
82
+ "react-dom": {
83
+ "optional": true
67
84
  }
68
85
  },
69
86
  "keywords": [
@@ -73,7 +90,10 @@
73
90
  "evm",
74
91
  "web3",
75
92
  "transactions",
76
- "mantle-network"
93
+ "mantle-network",
94
+ "mlink",
95
+ "react",
96
+ "ui-components"
77
97
  ],
78
98
  "license": "MIT"
79
99
  }