\n
\n Ownership Validated\n Amount owned: {data.asset.amount}\n {/* Number of Proofs: {data.number_of_proofs} */}\n\n Is Burn: {data.is_burn ? \"Yes\" : \"No\"}\n\n \n\n \n \n \n \n \n \n \n\n \n \n \n \n \n \n\n \n \n\n \n \n \n \n \n\n \n \n {data.exclusion_proofs.map((proof, index) => (\n \n ))}\n \n
\n \n
\n );\n}\n\nexport default ShowProof;\n","import { createConsumer } from \"@rails/actioncable\";\nimport { ExplorerWorkspace } from \"../stores/ExplorerWorkspace\";\n\ndeclare global {\n interface Window {\n ExplorerChannelSubscription: any;\n }\n}\n\nexport const startExplorerActionCable = (\n explorerWorkspace: ExplorerWorkspace\n) => {\n const consumer = createConsumer();\n //console.log(consumer);\n console.log(\"--in start action cable---\");\n // console.log(\"workspace.channelIndex\", workspace.channelIndex);\n window.ExplorerChannelSubscription = consumer.subscriptions.create(\n {\n channel: \"ExplorerChannel\",\n workspaceUuid: explorerWorkspace.workspaceUuid,\n },\n\n {\n connected() {\n console.log(\"a cable connect\");\n },\n\n disconnected() {\n // Called when the subscription has been terminated by the server\n },\n received(data) {\n console.log(\"data received from rails\", data);\n console.log(data);\n if (data.message == \"verify-and-decode-proof\") {\n explorerWorkspace.handleVerifyAndDecodeProof(data);\n }\n\n // if (data.message == \"question-failed\") {\n // workspace.handleQuestionFailure();\n // }\n },\n }\n );\n};\n","export const updateSearchQueryParam = (newSearchValue) => {\n // Create a URL object based on the current document location\n const currentUrl = new URL(window.location);\n\n // Access the URL's search parameters\n const params = currentUrl.searchParams;\n\n // Get the current value of the 'search' parameter\n const currentSearchValue = params.get(\"search\");\n\n // Check if the current search value is different from the new search value\n if (currentSearchValue !== newSearchValue) {\n // Set the 'search' parameter to the new value\n params.set(\"search\", newSearchValue);\n\n // Update the browser's address bar without reloading the page\n window.history.pushState(\n { search: newSearchValue },\n \"\",\n currentUrl.toString()\n );\n }\n};\n\n// Listen for popstate event to handle browser navigation\nwindow.addEventListener(\"popstate\", (event) => {\n window.location.reload();\n});\n","export const MEGALITH_NODE_ADDRESS =\n \"0322d0e43b3d92d30ed187f4e101a9a9605c3ee5fc9721e6dac3ce3d7732fbb13e@164.92.106.32:9735\";\n\nexport const NO_IMAGE_DATA_URL =\n \"\";\n","import { timeFormat } from \"d3-time-format\";\n\n// Arrow function to convert Unix timestamp to a nicely formatted local time string\nexport const formatUnixTimestamp = (unixTimestamp) => {\n // Convert Unix timestamp to milliseconds, create a Date object, and format it\n /// %I:%M:%S\n return timeFormat(\"%B %d, %Y\")(new Date(unixTimestamp * 1000));\n};\n\nexport const formatUnixTimeStampWithTime = (unixTimestamp) => {\n const utcDate = new Date(unixTimestamp * 1000).toISOString();\n return timeFormat(\"%B %d, %Y %I:%M:%S %p\")(new Date(utcDate));\n};\n","export const setNostrDataToLocalStorage = (\n nostrPublicKey: string,\n nostrPlatform: string\n) => {\n localStorage.setItem(\"nostrPublicKey\", nostrPublicKey);\n localStorage.setItem(\"nostrPlatform\", nostrPlatform);\n};\n\nexport const getNostrDataFromLocalStorage = () => {\n const nostrPublicKey = localStorage.getItem(\"nostrPublicKey\");\n const nostrPlatform = localStorage.getItem(\"nostrPlatform\");\n\n return {\n nostrPublicKey: nostrPublicKey === \"null\" ? null : nostrPublicKey,\n nostrPlatform: nostrPlatform === \"null\" ? null : nostrPlatform,\n };\n};\n","declare global {\n interface Window {\n nostr?: {\n getPublicKey: () => Promise