From 196c2d248e463b4d465a0e05aee9ec7140582d2e Mon Sep 17 00:00:00 2001 From: SmartSpace Date: Sat, 30 Apr 2022 15:57:59 +0600 Subject: [PATCH 01/10] build_source --- .gitignore | 6 +++++- stale-data-from-build-time.json | 2 +- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/.gitignore b/.gitignore index 4ff78fd..cda4568 100644 --- a/.gitignore +++ b/.gitignore @@ -72,4 +72,8 @@ yarn-error.log graphql-types.ts # Auto-generated by gatsby-plugin-extract-schema -schema.graphql \ No newline at end of file +schema.graphql + + +.bin/* + diff --git a/stale-data-from-build-time.json b/stale-data-from-build-time.json index e3ca8d6..334c667 100644 --- a/stale-data-from-build-time.json +++ b/stale-data-from-build-time.json @@ -1 +1 @@ -{"saleInfo":{"status":"Open","presale_start":8640000000000000,"sale_start":1649267295545,"token_final_supply":10000,"price":"2000000000000000000000000"},"contractMetadata":{"spec":"nft-1.0.0","name":"TENK NFT","symbol":"TENK","icon":"","base_uri":"https://bafybeihmtke7glg2aec5oav5btzlv6ec4fxkbbh4xjre4x5ipaqdxroahe.ipfs.dweb.link","reference":null,"reference_hash":null},"tokensLeft":9922,"vip":false,"nfts":[],"mintRateLimit":10} \ No newline at end of file +{"saleInfo":{"status":"Open","presale_start":8640000000000000,"sale_start":1649267295545,"token_final_supply":10000,"price":"2000000000000000000000000"},"contractMetadata":{"spec":"nft-1.0.0","name":"TENK NFT","symbol":"TENK","icon":"","base_uri":"https://bafybeihmtke7glg2aec5oav5btzlv6ec4fxkbbh4xjre4x5ipaqdxroahe.ipfs.dweb.link","reference":null,"reference_hash":null},"tokensLeft":9920,"vip":false,"nfts":[],"mintRateLimit":10} \ No newline at end of file From d0adb991c28ce4cf1c4d356da899be8a7762fac3 Mon Sep 17 00:00:00 2001 From: SmartSpace Date: Sat, 30 Apr 2022 17:33:13 +0600 Subject: [PATCH 02/10] change_1 --- config/settings.json | 2 +- lib/locales/Locale.ts | 144 +++++++++++++++++----------------- lib/locales/runtimeUtils.ts | 29 ++++++- src/components/hero/index.tsx | 22 +++++- 4 files changed, 119 insertions(+), 78 deletions(-) diff --git a/config/settings.json b/config/settings.json index ece8b06..db8c3df 100644 --- a/config/settings.json +++ b/config/settings.json @@ -1,7 +1,7 @@ { "author": "@TenKBay", "siteUrl": "https://tenkbay.com", - "contractName": "v2.tenk.testnet", + "contractName": "nft.cheddar.testnet", "social": [ { "href": "https://discord.com/invite/UY9Xf2k", diff --git a/lib/locales/Locale.ts b/lib/locales/Locale.ts index 018541a..38142ae 100644 --- a/lib/locales/Locale.ts +++ b/lib/locales/Locale.ts @@ -7,76 +7,76 @@ /** * Commonmark-formatted markdown. @see https://remarkjs.github.io/react-markdown/ */ -type Markdown = string + type Markdown = string -// TODO: should be able to import Action from ./runtimeUtils, but currently breaks with typescript-json-validator -// import type { Action } from './runtimeUtils' -type Action = "ADD_TO_CALENDAR(SALE_START)" | "ADD_TO_CALENDAR(PRESALE_START)" | "SIGN_IN" | "MINT" | "GO_TO_PARAS" - -export const requiredHeroFields = [ - 'title', - 'body', - 'cta', - 'action', - 'remaining', -] as const - -export const optionalHeroFields = [ - 'backgroundImage', - 'backgroundColor', - 'image', - 'video', - 'ps', - 'setNumber', -] as const - -export type Hero = { - [K in typeof requiredHeroFields[number]]: K extends 'action' ? Action : Markdown -} & { - [K in typeof optionalHeroFields[number]]?: string -} - -export const userStatuses = ['signedOut', 'signedIn', 'vip'] as const - -type HeroSaleStatus = Partial & { - [K in typeof userStatuses[number]]?: Partial -} - -export const saleStatuses = ['saleClosed', 'presale', 'saleOpen', 'allSold'] as const - -export type RawHeroTree = Partial & { - [K in typeof saleStatuses[number]]?: HeroSaleStatus -} - -export interface SectionI18n { - text: Markdown - image?: string - video?: string - backgroundImage?: string - backgroundColor?: string - className?: string - blocks?: { - image?: string - text?: string - linkTo?: string - }[] -} - -export interface Locale { - viewIn: string - langPicker: string - title: string - description: string - calendarEvent: string - connectWallet: string - signOut: string - new: string - myNFTs: string - nextNFT: string - prevNFT: string - close: string - zoomIn: string - zoomOut: string - hero: RawHeroTree - extraSections?: SectionI18n[] -} \ No newline at end of file + // TODO: should be able to import Action from ./runtimeUtils, but currently breaks with typescript-json-validator + // import type { Action } from './runtimeUtils' + type Action = "ADD_TO_CALENDAR(SALE_START)" | "ADD_TO_CALENDAR(PRESALE_START)" | "SIGN_IN" | "MINT" | "GO_TO_PARAS" + + export const requiredHeroFields = [ + 'title', + 'body', + 'cta', + 'action', + 'remaining', + ] as const + + export const optionalHeroFields = [ + 'backgroundImage', + 'backgroundColor', + 'image', + 'video', + 'ps', + 'setNumber', + ] as const + + export type Hero = { + [K in typeof requiredHeroFields[number]]: K extends 'action' ? Action : Markdown + } & { + [K in typeof optionalHeroFields[number]]?: string + } + + export const userStatuses = ['signedOut', 'signedIn', 'vip'] as const + + type HeroSaleStatus = Partial & { + [K in typeof userStatuses[number]]?: Partial + } + + export const saleStatuses = ['saleClosed', 'presale', 'saleOpen', 'allSold'] as const + + export type RawHeroTree = Partial & { + [K in typeof saleStatuses[number]]?: HeroSaleStatus + } + + export interface SectionI18n { + text: Markdown + image?: string + video?: string + backgroundImage?: string + backgroundColor?: string + className?: string + blocks?: { + image?: string + text?: string + linkTo?: string + }[] + } + + export interface Locale { + viewIn: string + langPicker: string + title: string + description: string + calendarEvent: string + connectWallet: string + signOut: string + new: string + myNFTs: string + nextNFT: string + prevNFT: string + close: string + zoomIn: string + zoomOut: string + hero: RawHeroTree + extraSections?: SectionI18n[] + } \ No newline at end of file diff --git a/lib/locales/runtimeUtils.ts b/lib/locales/runtimeUtils.ts index 896d6b9..1eec89f 100644 --- a/lib/locales/runtimeUtils.ts +++ b/lib/locales/runtimeUtils.ts @@ -13,6 +13,8 @@ type Data = TenkData & { currentUser: string locale: Locale numberToMint?: number + nearMint?:number + chedMint?:number saleStatus: typeof saleStatuses[number] userStatus: typeof userStatuses[number] } @@ -43,6 +45,18 @@ function formatCurrency( return `${formatNumber(num, locale)} ${currency}` } +function formatCurrency1( + num: number | string, + currency: string = 'Cheddar', + + /** + * `undefined` will default to browser's locale (may not work correctly in Node during build) + */ + locale?: string, +) { + return `${formatNumber(num, locale)} ${currency}` +} + function formatDate( d: Timestamp | Date, @@ -66,9 +80,11 @@ const replacers = { PRESALE_START: (d: Data) => formatDate(d.saleInfo.presale_start), SALE_START: (d: Data) => formatDate(d.saleInfo.sale_start), MINT_LIMIT: (d: Data) => d.remainingAllowance ?? 0, - MINT_PRICE: (d: Data) => formatCurrency( + MINT_PRICE: (d: Data) => (d.nearMint == 1) ? (formatCurrency( NEAR.from(d.saleInfo.price).mul(NEAR.from('' + (d.numberToMint ?? 1))).toHuman().split(' ')[0] - ), + )):(formatCurrency1( + NEAR.from(3).mul(NEAR.from('' + (d.numberToMint ?? 1))).toHuman().split(' ')[0] + )), MINT_RATE_LIMIT: (d: Data) => d.mintRateLimit, INITIAL_COUNT: (d: Data) => formatNumber(d.saleInfo.token_final_supply), REMAINING_COUNT: (d: Data) => formatNumber(d.tokensLeft), @@ -81,6 +97,7 @@ export type PlaceholderString = keyof typeof replacers const placeholderRegex = new RegExp(`(${placeholderStrings.join('|')})`, 'gm') export function fill(text: string, data: Data): string { + console.log(data); return text.replace(placeholderRegex, (match) => { return String(replacers[match as PlaceholderString](data)) }) @@ -122,6 +139,14 @@ const actions = { gas: Gas.parse('40 Tgas').mul(Gas.from('' + d.numberToMint)), attachedDeposit: NEAR.from(d.saleInfo.price).mul(NEAR.from('' + d.numberToMint)), }), + 'MintForNear': (d: Data) => TenK.nft_mint_many({ num: d.numberToMint ?? 1 }, { + gas: Gas.parse('40 Tgas').mul(Gas.from('' + d.numberToMint)), + attachedDeposit: NEAR.from(d.saleInfo.price).mul(NEAR.from('' + d.numberToMint)), + }), + 'MintForChed': (d: Data) => TenK.nft_mint_many({ num: d.numberToMint ?? 1 }, { + gas: Gas.parse('40 Tgas').mul(Gas.from('' + d.numberToMint)), + attachedDeposit: NEAR.from(d.saleInfo.price).mul(NEAR.from('' + d.numberToMint)), + }), 'GO_TO_PARAS': () => window.open(`https://paras.id/search?q=${settings.contractName}&sort=priceasc&pmin=.01&is_verified=true`), } diff --git a/src/components/hero/index.tsx b/src/components/hero/index.tsx index dd04aa5..152fb02 100644 --- a/src/components/hero/index.tsx +++ b/src/components/hero/index.tsx @@ -17,6 +17,8 @@ const Hero: React.FC<{ heroTree: ExpandedHeroTree }> = ({ heroTree }) => { const tenkData = useTenk() const { saleStatus, userStatus } = useHeroStatuses() const [numberToMint, setNumberToMint] = React.useState(1) + const [nearMint, setNearMint] = React.useState(1); + const [chedMint, setChedMint] = React.useState(3); const hero = heroTree[saleStatus][userStatus] if (!locale) return null @@ -29,6 +31,17 @@ const Hero: React.FC<{ heroTree: ExpandedHeroTree }> = ({ heroTree }) => { userStatus, } + + const mintForNear = function () { + console.log("NEAR") + act("MintForNear", { ...data, numberToMint}) + } + + const mintForCheddar = function() { + console.log("Cheddar") + act("MintForChed", { ...data, numberToMint}) + } + return (
= ({ heroTree }) => { {can(hero.action, data) && (
{ e.preventDefault() - act(hero.action, { ...data, numberToMint }) + //act(hero.action, { ...data, numberToMint }) }}> {hero.setNumber && ( <> @@ -72,8 +85,11 @@ const Hero: React.FC<{ heroTree: ExpandedHeroTree }> = ({ heroTree }) => { /> )} - +
)} From 3ad8fe174552b43e3090efbbd7a70a1391d91217 Mon Sep 17 00:00:00 2001 From: RodrigoCSolari Date: Wed, 20 Jul 2022 14:47:50 -0300 Subject: [PATCH 03/10] fix: change mint contract call --- lib/locales/runtimeUtils.ts | 181 +-- src/near/contracts/tenk.ts | 1865 ++++++++++++++++++++----------- stale-data-from-build-time.json | 2 +- 3 files changed, 1342 insertions(+), 706 deletions(-) diff --git a/lib/locales/runtimeUtils.ts b/lib/locales/runtimeUtils.ts index 1eec89f..789d20d 100644 --- a/lib/locales/runtimeUtils.ts +++ b/lib/locales/runtimeUtils.ts @@ -1,11 +1,11 @@ -import { Gas, NEAR } from 'near-units' -import { atcb_action as addToCalendar } from 'add-to-calendar-button' -import settings from '../../config/settings.json' -import { signIn } from '../../src/near' -import { TenK } from '../../src/near/contracts' +import { Gas, NEAR } from "near-units" +import { atcb_action as addToCalendar } from "add-to-calendar-button" +import settings from "../../config/settings.json" +import { signIn } from "../../src/near" +import { TenK } from "../../src/near/contracts" import { TenkData } from "../../src/hooks/useTenk" -import { saleStatuses, userStatuses } from './Locale' -import { Locale } from '../../src/hooks/useLocales' +import { saleStatuses, userStatuses } from "./Locale" +import { Locale } from "../../src/hooks/useLocales" type Timestamp = number @@ -13,8 +13,8 @@ type Data = TenkData & { currentUser: string locale: Locale numberToMint?: number - nearMint?:number - chedMint?:number + nearMint?: number + chedMint?: number saleStatus: typeof saleStatuses[number] userStatus: typeof userStatuses[number] } @@ -25,9 +25,8 @@ function formatNumber( /** * `undefined` will default to browser's locale (may not work correctly in Node during build) */ - locale?: string, + locale?: string ) { - return new Intl.NumberFormat(locale, { maximumSignificantDigits: 3, }).format(Number(num)) @@ -35,24 +34,24 @@ function formatNumber( function formatCurrency( num: number | string, - currency: string = 'NEAR', + currency: string = "NEAR", /** * `undefined` will default to browser's locale (may not work correctly in Node during build) */ - locale?: string, + locale?: string ) { return `${formatNumber(num, locale)} ${currency}` } function formatCurrency1( num: number | string, - currency: string = 'Cheddar', + currency: string = "Cheddar", /** * `undefined` will default to browser's locale (may not work correctly in Node during build) */ - locale?: string, + locale?: string ) { return `${formatNumber(num, locale)} ${currency}` } @@ -68,9 +67,9 @@ function formatDate( ): string { const date = typeof d === "number" ? new Date(d) : d - return new Intl.DateTimeFormat(locale, { - dateStyle: 'short', - timeStyle: 'short', + return new Intl.DateTimeFormat(locale, { + dateStyle: "short", + timeStyle: "short", ...options, }).format(date) } @@ -80,11 +79,20 @@ const replacers = { PRESALE_START: (d: Data) => formatDate(d.saleInfo.presale_start), SALE_START: (d: Data) => formatDate(d.saleInfo.sale_start), MINT_LIMIT: (d: Data) => d.remainingAllowance ?? 0, - MINT_PRICE: (d: Data) => (d.nearMint == 1) ? (formatCurrency( - NEAR.from(d.saleInfo.price).mul(NEAR.from('' + (d.numberToMint ?? 1))).toHuman().split(' ')[0] - )):(formatCurrency1( - NEAR.from(3).mul(NEAR.from('' + (d.numberToMint ?? 1))).toHuman().split(' ')[0] - )), + MINT_PRICE: (d: Data) => + d.nearMint == 1 + ? formatCurrency( + NEAR.from(d.saleInfo.price) + .mul(NEAR.from("" + (d.numberToMint ?? 1))) + .toHuman() + .split(" ")[0] + ) + : formatCurrency1( + NEAR.from(3) + .mul(NEAR.from("" + (d.numberToMint ?? 1))) + .toHuman() + .split(" ")[0] + ), MINT_RATE_LIMIT: (d: Data) => d.mintRateLimit, INITIAL_COUNT: (d: Data) => formatNumber(d.saleInfo.token_final_supply), REMAINING_COUNT: (d: Data) => formatNumber(d.tokensLeft), @@ -94,21 +102,20 @@ export const placeholderStrings = Object.keys(replacers) export type PlaceholderString = keyof typeof replacers -const placeholderRegex = new RegExp(`(${placeholderStrings.join('|')})`, 'gm') +const placeholderRegex = new RegExp(`(${placeholderStrings.join("|")})`, "gm") export function fill(text: string, data: Data): string { - console.log(data); - return text.replace(placeholderRegex, (match) => { + return text.replace(placeholderRegex, match => { return String(replacers[match as PlaceholderString](data)) }) } // add-to-calendar-button has strange strict requirements on time format function formatDatesForAtcb(d: Timestamp) { - let [start, end] = new Date(d).toISOString().split('T') + let [start, end] = new Date(d).toISOString().split("T") return [ start, - end.replace(/:\d\d\..*$/, '') // strip seconds, ms, & TZ + end.replace(/:\d\d\..*$/, ""), // strip seconds, ms, & TZ ] } @@ -120,34 +127,73 @@ function getStartAndEnd(d: Timestamp) { } const actions = { - 'ADD_TO_CALENDAR(SALE_START)': (d: Data) => addToCalendar({ - name: d.locale.calendarEvent!, - ...getStartAndEnd(d.saleInfo.sale_start), - options: ['Google', 'iCal', 'Apple', 'Microsoft365', 'MicrosoftTeams', 'Outlook.com', 'Yahoo'], - timeZone: "UTC", - trigger: 'click', - }), - 'ADD_TO_CALENDAR(PRESALE_START)': (d: Data) => addToCalendar({ - name: d.locale.calendarEvent!, - ...getStartAndEnd(d.saleInfo.presale_start), - options: ['Google', 'iCal', 'Apple', 'Microsoft365', 'MicrosoftTeams', 'Outlook.com', 'Yahoo'], - timeZone: "UTC", - trigger: 'click', - }), - 'SIGN_IN': signIn, - 'MINT': (d: Data) => TenK.nft_mint_many({ num: d.numberToMint ?? 1 }, { - gas: Gas.parse('40 Tgas').mul(Gas.from('' + d.numberToMint)), - attachedDeposit: NEAR.from(d.saleInfo.price).mul(NEAR.from('' + d.numberToMint)), - }), - 'MintForNear': (d: Data) => TenK.nft_mint_many({ num: d.numberToMint ?? 1 }, { - gas: Gas.parse('40 Tgas').mul(Gas.from('' + d.numberToMint)), - attachedDeposit: NEAR.from(d.saleInfo.price).mul(NEAR.from('' + d.numberToMint)), - }), - 'MintForChed': (d: Data) => TenK.nft_mint_many({ num: d.numberToMint ?? 1 }, { - gas: Gas.parse('40 Tgas').mul(Gas.from('' + d.numberToMint)), - attachedDeposit: NEAR.from(d.saleInfo.price).mul(NEAR.from('' + d.numberToMint)), - }), - 'GO_TO_PARAS': () => window.open(`https://paras.id/search?q=${settings.contractName}&sort=priceasc&pmin=.01&is_verified=true`), + "ADD_TO_CALENDAR(SALE_START)": (d: Data) => + addToCalendar({ + name: d.locale.calendarEvent!, + ...getStartAndEnd(d.saleInfo.sale_start), + options: [ + "Google", + "iCal", + "Apple", + "Microsoft365", + "MicrosoftTeams", + "Outlook.com", + "Yahoo", + ], + timeZone: "UTC", + trigger: "click", + }), + "ADD_TO_CALENDAR(PRESALE_START)": (d: Data) => + addToCalendar({ + name: d.locale.calendarEvent!, + ...getStartAndEnd(d.saleInfo.presale_start), + options: [ + "Google", + "iCal", + "Apple", + "Microsoft365", + "MicrosoftTeams", + "Outlook.com", + "Yahoo", + ], + timeZone: "UTC", + trigger: "click", + }), + SIGN_IN: signIn, + MINT: (d: Data) => + TenK.nft_mint_many( + { num: d.numberToMint ?? 1 }, + { + gas: Gas.parse("40 Tgas").mul(Gas.from("" + d.numberToMint)), + attachedDeposit: NEAR.from(d.saleInfo.price).mul( + NEAR.from("" + d.numberToMint) + ), + } + ), + MintForNear: (d: Data) => + TenK.nft_mint_many( + { num: d.numberToMint ?? 1, with_cheddar: false }, + { + gas: Gas.parse("40 Tgas").mul(Gas.from("" + d.numberToMint)), + attachedDeposit: NEAR.from(d.saleInfo.price).mul( + NEAR.from("" + d.numberToMint) + ), + } + ), + MintForChed: (d: Data) => + TenK.nft_mint_many( + { num: d.numberToMint ?? 1, with_cheddar: true }, + { + gas: Gas.parse("40 Tgas").mul(Gas.from("" + d.numberToMint)), + attachedDeposit: NEAR.from(d.saleInfo.price).mul( + NEAR.from("" + d.numberToMint) + ), + } + ), + GO_TO_PARAS: () => + window.open( + `https://paras.id/search?q=${settings.contractName}&sort=priceasc&pmin=.01&is_verified=true` + ), } export type Action = keyof typeof actions @@ -157,19 +203,18 @@ export function act(action: Action, data: Data): void { } export function can(action: Action, data: Data): boolean { - if (action === 'MINT') { - return Boolean(data.currentUser) && ( - (data.saleStatus === 'presale' && + if (action === "MINT") { + return ( + Boolean(data.currentUser) && + ((data.saleStatus === "presale" && data.remainingAllowance !== undefined && - data.remainingAllowance > 0 - ) || - (data.saleStatus === 'saleOpen' && ( - // users are added to the whitelist as they mint during saleOpen; - // undefined means they haven't minted yet - data.remainingAllowance === undefined || - data.remainingAllowance > 0 - )) + data.remainingAllowance > 0) || + (data.saleStatus === "saleOpen" && + // users are added to the whitelist as they mint during saleOpen; + // undefined means they haven't minted yet + (data.remainingAllowance === undefined || + data.remainingAllowance > 0))) ) } return true -} \ No newline at end of file +} diff --git a/src/near/contracts/tenk.ts b/src/near/contracts/tenk.ts index db52f83..727da19 100644 --- a/src/near/contracts/tenk.ts +++ b/src/near/contracts/tenk.ts @@ -1,712 +1,1303 @@ -import { Account, transactions, providers, DEFAULT_FUNCTION_CALL_GAS } from 'near-api-js'; +import { + Account, + transactions, + providers, + DEFAULT_FUNCTION_CALL_GAS, +} from "near-api-js" - -import BN from 'bn.js'; +import BN from "bn.js" export interface ChangeMethodOptions { - gas?: BN; - attachedDeposit?: BN; - walletMeta?: string; - walletCallbackUrl?: string; + gas?: BN + attachedDeposit?: BN + walletMeta?: string + walletCallbackUrl?: string } export interface ViewFunctionOptions { - parse?: (response: Uint8Array) => any; - stringify?: (input: any) => any; + parse?: (response: Uint8Array) => any + stringify?: (input: any) => any } /** 64 bit unsigned integer less than 2^53 -1 */ -type u64 = number; +type u64 = number /** 64 bit signed integer less than 2^53 -1 */ -type i64 = number; +type i64 = number /** -* StorageUsage is used to count the amount of storage used by a contract. -*/ -export type StorageUsage = u64; + * StorageUsage is used to count the amount of storage used by a contract. + */ +export type StorageUsage = u64 /** -* Balance is a type for storing amounts of tokens, specified in yoctoNEAR. -*/ -export type Balance = U128; + * Balance is a type for storing amounts of tokens, specified in yoctoNEAR. + */ +export type Balance = U128 /** -* Represents the amount of NEAR tokens in "gas units" which are used to fund transactions. -*/ -export type Gas = u64; + * Represents the amount of NEAR tokens in "gas units" which are used to fund transactions. + */ +export type Gas = u64 /** -* base64 string. -*/ -export type Base64VecU8 = string; + * base64 string. + */ +export type Base64VecU8 = string /** -* Raw type for duration in nanoseconds -*/ -export type Duration = u64; -export type U128 = string; + * Raw type for duration in nanoseconds + */ +export type Duration = u64 +export type U128 = string /** -* Public key in a binary format with base58 string serialization with human-readable curve. -* The key types currently supported are `secp256k1` and `ed25519`. -* -* Ed25519 public keys accepted are 32 bytes and secp256k1 keys are the uncompressed 64 format. -*/ -export type PublicKey = string; -export type AccountId = string; + * Public key in a binary format with base58 string serialization with human-readable curve. + * The key types currently supported are `secp256k1` and `ed25519`. + * + * Ed25519 public keys accepted are 32 bytes and secp256k1 keys are the uncompressed 64 format. + */ +export type PublicKey = string +export type AccountId = string /** -* Raw type for timestamp in nanoseconds -*/ -export type Timestamp = u64; + * Raw type for timestamp in nanoseconds + */ +export type Timestamp = u64 export interface StorageBalanceBounds { - min: U128, - max?: U128, + min: U128 + max?: U128 } export interface FungibleTokenMetadata { - spec: string, - name: string, - symbol: string, - icon?: string, - reference?: string, - reference_hash?: Base64VecU8, - decimals: number, + spec: string + name: string + symbol: string + icon?: string + reference?: string + reference_hash?: Base64VecU8 + decimals: number } /** -* In this implementation, the Token struct takes two extensions standards (metadata and approval) as optional fields, as they are frequently used in modern NFTs. -*/ + * In this implementation, the Token struct takes two extensions standards (metadata and approval) as optional fields, as they are frequently used in modern NFTs. + */ export interface Token { - token_id: TokenId, - owner_id: AccountId, - metadata?: TokenMetadata, - approved_account_ids?: Record, + token_id: TokenId + owner_id: AccountId + metadata?: TokenMetadata + approved_account_ids?: Record } /** -* Note that token IDs for NFTs are strings on NEAR. It's still fine to use autoincrementing numbers as unique IDs if desired, but they should be stringified. This is to make IDs more future-proof as chain-agnostic conventions and standards arise, and allows for more flexibility with considerations like bridging NFTs across chains, etc. -*/ -export type TokenId = string; + * Note that token IDs for NFTs are strings on NEAR. It's still fine to use autoincrementing numbers as unique IDs if desired, but they should be stringified. This is to make IDs more future-proof as chain-agnostic conventions and standards arise, and allows for more flexibility with considerations like bridging NFTs across chains, etc. + */ +export type TokenId = string export interface StorageBalance { - total: U128, - available: U128, + total: U128 + available: U128 } -export type WrappedDuration = string; +export type WrappedDuration = string /** -* Metadata on the individual token level. -*/ + * Metadata on the individual token level. + */ export interface TokenMetadata { - title?: string, - description?: string, - media?: string, - media_hash?: Base64VecU8, - copies?: u64, - issued_at?: string, - expires_at?: string, - starts_at?: string, - updated_at?: string, - extra?: string, - reference?: string, - reference_hash?: Base64VecU8, + title?: string + description?: string + media?: string + media_hash?: Base64VecU8 + copies?: u64 + issued_at?: string + expires_at?: string + starts_at?: string + updated_at?: string + extra?: string + reference?: string + reference_hash?: Base64VecU8 } /** -* Metadata for the NFT contract itself. -*/ + * Metadata for the NFT contract itself. + */ export interface NftContractMetadata { - spec: string, - name: string, - symbol: string, - icon?: string, - base_uri?: string, - reference?: string, - reference_hash?: Base64VecU8, + spec: string + name: string + symbol: string + icon?: string + base_uri?: string + reference?: string + reference_hash?: Base64VecU8 } /** -* Current state of contract -*/ + * Current state of contract + */ export enum Status { /** - * Not open for any sales - */ + * Not open for any sales + */ Closed = "Closed", /** - * VIP accounts can mint - */ + * VIP accounts can mint + */ Presale = "Presale", /** - * Any account can mint - */ + * Any account can mint + */ Open = "Open", /** - * No more tokens to be minted - */ + * No more tokens to be minted + */ SoldOut = "SoldOut", } export interface InitialMetadata { - name: string, - symbol: string, - uri: string, - icon?: string, - spec?: string, - reference?: string, - reference_hash?: Base64VecU8, + name: string + symbol: string + uri: string + icon?: string + spec?: string + reference?: string + reference_hash?: Base64VecU8 } /** -* Information about the current sale -*/ + * Information about the current sale + */ export interface SaleInfo { /** - * Current state of contract - */ - status: Status, + * Current state of contract + */ + status: Status /** - * Start of the VIP sale - */ - presale_start: Duration, + * Start of the VIP sale + */ + presale_start: Duration /** - * Start of public sale - */ - sale_start: Duration, + * Start of public sale + */ + sale_start: Duration /** - * Total tokens that could be minted - */ - token_final_supply: u64, + * Total tokens that could be minted + */ + token_final_supply: u64 /** - * Current price for one token - */ - price: U128, + * Current price for one token + */ + price: U128 } export interface Sale { - royalties?: Royalties, - initial_royalties?: Royalties, - presale_start?: Duration, - public_sale_start?: Duration, - allowance?: number, - presale_price?: U128, - price: U128, - mint_rate_limit?: number, + royalties?: Royalties + initial_royalties?: Royalties + presale_start?: Duration + public_sale_start?: Duration + allowance?: number + presale_price?: U128 + price: U128 + mint_rate_limit?: number } -export type BasisPoint = number; +export type BasisPoint = number /** -* Information about the current sale from user perspective -*/ + * Information about the current sale from user perspective + */ export interface UserSaleInfo { - sale_info: SaleInfo, - is_vip: boolean, - remaining_allowance?: number, + sale_info: SaleInfo + is_vip: boolean + remaining_allowance?: number } /** -* Copied from https://github.com/near/NEPs/blob/6170aba1c6f4cd4804e9ad442caeae9dc47e7d44/specs/Standards/NonFungibleToken/Payout.md#reference-level-explanation -* A mapping of NEAR accounts to the amount each should be paid out, in -* the event of a token-sale. The payout mapping MUST be shorter than the -* maximum length specified by the financial contract obtaining this -* payout data. Any mapping of length 10 or less MUST be accepted by -* financial contracts, so 10 is a safe upper limit. -* This currently deviates from the standard but is in the process of updating to use this type -*/ + * Copied from https://github.com/near/NEPs/blob/6170aba1c6f4cd4804e9ad442caeae9dc47e7d44/specs/Standards/NonFungibleToken/Payout.md#reference-level-explanation + * A mapping of NEAR accounts to the amount each should be paid out, in + * the event of a token-sale. The payout mapping MUST be shorter than the + * maximum length specified by the financial contract obtaining this + * payout data. Any mapping of length 10 or less MUST be accepted by + * financial contracts, so 10 is a safe upper limit. + * This currently deviates from the standard but is in the process of updating to use this type + */ export interface Payout { - payout: Record, + payout: Record } export interface Royalties { - accounts: Record, - percent: BasisPoint, + accounts: Record + percent: BasisPoint } export class Contract { + constructor(public account: Account, public readonly contractId: string) {} - constructor(public account: Account, public readonly contractId: string){} - - check_key(args: { - public_key: PublicKey, - }, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "check_key", args, options); - } - async update_allowance(args: { - allowance: number, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.update_allowanceRaw(args, options)); - } - update_allowanceRaw(args: { - allowance: number, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "update_allowance", args, ...options}); - } - update_allowanceTx(args: { - allowance: number, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("update_allowance", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - whitelisted(args: { - account_id: AccountId, - }, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "whitelisted", args, options); - } - get_sale_info(args: { - } = {}, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "get_sale_info", args, options); - } - cost_per_token(args: { - minter: AccountId, - }, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "cost_per_token", args, options); - } - async transfer_ownership(args: { - new_owner: AccountId, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.transfer_ownershipRaw(args, options)); - } - transfer_ownershipRaw(args: { - new_owner: AccountId, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "transfer_ownership", args, ...options}); - } - transfer_ownershipTx(args: { - new_owner: AccountId, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("transfer_ownership", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - nft_total_supply(args: { - } = {}, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "nft_total_supply", args, options); - } - nft_tokens(args: { - from_index?: U128, - limit?: u64, - }, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "nft_tokens", args, options); - } - nft_token(args: { - token_id: TokenId, - }, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "nft_token", args, options); - } - async close_contract(args: { - } = {}, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.close_contractRaw(args, options)); - } - close_contractRaw(args: { - } = {}, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "close_contract", args, ...options}); - } - close_contractTx(args: { - } = {}, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("close_contract", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - async nft_approve(args: { - token_id: TokenId, - account_id: AccountId, - msg?: string, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.nft_approveRaw(args, options)); - } - nft_approveRaw(args: { - token_id: TokenId, - account_id: AccountId, - msg?: string, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "nft_approve", args, ...options}); - } - nft_approveTx(args: { - token_id: TokenId, - account_id: AccountId, - msg?: string, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("nft_approve", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - async start_sale(args: { - price?: U128, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.start_saleRaw(args, options)); - } - start_saleRaw(args: { - price?: U128, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "start_sale", args, ...options}); - } - start_saleTx(args: { - price?: U128, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("start_sale", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - async nft_mint_many(args: { - num: number, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.nft_mint_manyRaw(args, options)); - } - nft_mint_manyRaw(args: { - num: number, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "nft_mint_many", args, ...options}); - } - nft_mint_manyTx(args: { - num: number, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("nft_mint_many", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - async update_uri(args: { - uri: string, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.update_uriRaw(args, options)); - } - update_uriRaw(args: { - uri: string, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "update_uri", args, ...options}); - } - update_uriTx(args: { - uri: string, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("update_uri", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - async nft_transfer_call(args: { - receiver_id: AccountId, - token_id: TokenId, - approval_id?: u64, - memo?: string, - msg: string, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.nft_transfer_callRaw(args, options)); - } - nft_transfer_callRaw(args: { - receiver_id: AccountId, - token_id: TokenId, - approval_id?: u64, - memo?: string, - msg: string, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "nft_transfer_call", args, ...options}); - } - nft_transfer_callTx(args: { - receiver_id: AccountId, - token_id: TokenId, - approval_id?: u64, - memo?: string, - msg: string, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("nft_transfer_call", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - nft_payout(args: { - token_id: string, - balance: U128, - max_len_payout?: number, - }, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "nft_payout", args, options); - } - async nft_transfer_payout(args: { - receiver_id: AccountId, - token_id: string, - approval_id?: u64, - memo?: string, - balance: U128, - max_len_payout?: number, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.nft_transfer_payoutRaw(args, options)); - } - nft_transfer_payoutRaw(args: { - receiver_id: AccountId, - token_id: string, - approval_id?: u64, - memo?: string, - balance: U128, - max_len_payout?: number, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "nft_transfer_payout", args, ...options}); - } - nft_transfer_payoutTx(args: { - receiver_id: AccountId, - token_id: string, - approval_id?: u64, - memo?: string, - balance: U128, - max_len_payout?: number, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("nft_transfer_payout", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) + check_key( + args: { + public_key: PublicKey + }, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "check_key", + args, + options + ) + } + async update_allowance( + args: { + allowance: number + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.update_allowanceRaw(args, options) + ) + } + update_allowanceRaw( + args: { + allowance: number + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "update_allowance", + args, + ...options, + }) + } + update_allowanceTx( + args: { + allowance: number + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "update_allowance", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + whitelisted( + args: { + account_id: AccountId + }, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "whitelisted", + args, + options + ) + } + get_sale_info( + args: {} = {}, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "get_sale_info", + args, + options + ) + } + cost_per_token( + args: { + minter: AccountId + }, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "cost_per_token", + args, + options + ) + } + async transfer_ownership( + args: { + new_owner: AccountId + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.transfer_ownershipRaw(args, options) + ) + } + transfer_ownershipRaw( + args: { + new_owner: AccountId + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "transfer_ownership", + args, + ...options, + }) + } + transfer_ownershipTx( + args: { + new_owner: AccountId + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "transfer_ownership", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + nft_total_supply( + args: {} = {}, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "nft_total_supply", + args, + options + ) + } + nft_tokens( + args: { + from_index?: U128 + limit?: u64 + }, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "nft_tokens", + args, + options + ) + } + nft_token( + args: { + token_id: TokenId + }, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "nft_token", + args, + options + ) + } + async close_contract( + args: {} = {}, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.close_contractRaw(args, options) + ) + } + close_contractRaw( + args: {} = {}, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "close_contract", + args, + ...options, + }) + } + close_contractTx( + args: {} = {}, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "close_contract", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + async nft_approve( + args: { + token_id: TokenId + account_id: AccountId + msg?: string + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.nft_approveRaw(args, options) + ) + } + nft_approveRaw( + args: { + token_id: TokenId + account_id: AccountId + msg?: string + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "nft_approve", + args, + ...options, + }) + } + nft_approveTx( + args: { + token_id: TokenId + account_id: AccountId + msg?: string + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "nft_approve", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + async start_sale( + args: { + price?: U128 + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.start_saleRaw(args, options) + ) + } + start_saleRaw( + args: { + price?: U128 + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "start_sale", + args, + ...options, + }) + } + start_saleTx( + args: { + price?: U128 + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "start_sale", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + async nft_mint_many( + args: { + num: number + with_cheddar?: boolean + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.nft_mint_manyRaw(args, options) + ) + } + nft_mint_manyRaw( + args: { + num: number + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "nft_mint_many", + args, + ...options, + }) + } + nft_mint_manyTx( + args: { + num: number + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "nft_mint_many", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + async update_uri( + args: { + uri: string + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.update_uriRaw(args, options) + ) + } + update_uriRaw( + args: { + uri: string + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "update_uri", + args, + ...options, + }) + } + update_uriTx( + args: { + uri: string + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "update_uri", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + async nft_transfer_call( + args: { + receiver_id: AccountId + token_id: TokenId + approval_id?: u64 + memo?: string + msg: string + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.nft_transfer_callRaw(args, options) + ) + } + nft_transfer_callRaw( + args: { + receiver_id: AccountId + token_id: TokenId + approval_id?: u64 + memo?: string + msg: string + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "nft_transfer_call", + args, + ...options, + }) + } + nft_transfer_callTx( + args: { + receiver_id: AccountId + token_id: TokenId + approval_id?: u64 + memo?: string + msg: string + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "nft_transfer_call", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + nft_payout( + args: { + token_id: string + balance: U128 + max_len_payout?: number + }, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "nft_payout", + args, + options + ) + } + async nft_transfer_payout( + args: { + receiver_id: AccountId + token_id: string + approval_id?: u64 + memo?: string + balance: U128 + max_len_payout?: number + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.nft_transfer_payoutRaw(args, options) + ) + } + nft_transfer_payoutRaw( + args: { + receiver_id: AccountId + token_id: string + approval_id?: u64 + memo?: string + balance: U128 + max_len_payout?: number + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "nft_transfer_payout", + args, + ...options, + }) + } + nft_transfer_payoutTx( + args: { + receiver_id: AccountId + token_id: string + approval_id?: u64 + memo?: string + balance: U128 + max_len_payout?: number + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "nft_transfer_payout", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) } /** - * Returns the balance associated with given key. - */ - get_key_balance(args: { - } = {}, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "get_key_balance", args, options); + * Returns the balance associated with given key. + */ + get_key_balance(args: {} = {}, options?: ViewFunctionOptions): Promise { + return this.account.viewFunction( + this.contractId, + "get_key_balance", + args, + options + ) } /** - * Create a pending token that can be claimed with corresponding private key - */ - async create_linkdrop(args: { - public_key: PublicKey, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.create_linkdropRaw(args, options)); + * Create a pending token that can be claimed with corresponding private key + */ + async create_linkdrop( + args: { + public_key: PublicKey + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.create_linkdropRaw(args, options) + ) } /** - * Create a pending token that can be claimed with corresponding private key - */ - create_linkdropRaw(args: { - public_key: PublicKey, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "create_linkdrop", args, ...options}); + * Create a pending token that can be claimed with corresponding private key + */ + create_linkdropRaw( + args: { + public_key: PublicKey + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "create_linkdrop", + args, + ...options, + }) } /** - * Create a pending token that can be claimed with corresponding private key - */ - create_linkdropTx(args: { - public_key: PublicKey, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("create_linkdrop", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - async add_whitelist_accounts(args: { - accounts: AccountId[], - allowance?: number, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.add_whitelist_accountsRaw(args, options)); - } - add_whitelist_accountsRaw(args: { - accounts: AccountId[], - allowance?: number, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "add_whitelist_accounts", args, ...options}); - } - add_whitelist_accountsTx(args: { - accounts: AccountId[], - allowance?: number, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("add_whitelist_accounts", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - async new(args: { - owner_id: AccountId, - metadata: NftContractMetadata, - size: number, - sale: Sale, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.newRaw(args, options)); - } - newRaw(args: { - owner_id: AccountId, - metadata: NftContractMetadata, - size: number, - sale: Sale, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "new", args, ...options}); - } - newTx(args: { - owner_id: AccountId, - metadata: NftContractMetadata, - size: number, - sale: Sale, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("new", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - async start_presale(args: { - public_sale_start?: Duration, - presale_price?: U128, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.start_presaleRaw(args, options)); - } - start_presaleRaw(args: { - public_sale_start?: Duration, - presale_price?: U128, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "start_presale", args, ...options}); - } - start_presaleTx(args: { - public_sale_start?: Duration, - presale_price?: U128, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("start_presale", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - token_storage_cost(args: { - } = {}, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "token_storage_cost", args, options); - } - async nft_transfer(args: { - receiver_id: AccountId, - token_id: TokenId, - approval_id?: u64, - memo?: string, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.nft_transferRaw(args, options)); - } - nft_transferRaw(args: { - receiver_id: AccountId, - token_id: TokenId, - approval_id?: u64, - memo?: string, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "nft_transfer", args, ...options}); - } - nft_transferTx(args: { - receiver_id: AccountId, - token_id: TokenId, - approval_id?: u64, - memo?: string, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("nft_transfer", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - async nft_revoke_all(args: { - token_id: TokenId, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.nft_revoke_allRaw(args, options)); - } - nft_revoke_allRaw(args: { - token_id: TokenId, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "nft_revoke_all", args, ...options}); - } - nft_revoke_allTx(args: { - token_id: TokenId, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("nft_revoke_all", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - cost_of_linkdrop(args: { - minter: AccountId, - }, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "cost_of_linkdrop", args, options); - } - total_cost(args: { - num: number, - minter: AccountId, - }, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "total_cost", args, options); - } - get_linkdrop_contract(args: { - } = {}, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "get_linkdrop_contract", args, options); - } - async new_default_meta(args: { - owner_id: AccountId, - metadata: InitialMetadata, - size: number, - sale?: Sale, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.new_default_metaRaw(args, options)); - } - new_default_metaRaw(args: { - owner_id: AccountId, - metadata: InitialMetadata, - size: number, - sale?: Sale, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "new_default_meta", args, ...options}); - } - new_default_metaTx(args: { - owner_id: AccountId, - metadata: InitialMetadata, - size: number, - sale?: Sale, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("new_default_meta", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - async nft_revoke(args: { - token_id: TokenId, - account_id: AccountId, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.nft_revokeRaw(args, options)); - } - nft_revokeRaw(args: { - token_id: TokenId, - account_id: AccountId, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "nft_revoke", args, ...options}); - } - nft_revokeTx(args: { - token_id: TokenId, - account_id: AccountId, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("nft_revoke", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - nft_metadata(args: { - } = {}, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "nft_metadata", args, options); - } - mint_rate_limit(args: { - } = {}, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "mint_rate_limit", args, options); - } - nft_is_approved(args: { - token_id: TokenId, - approved_account_id: AccountId, - approval_id?: u64, - }, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "nft_is_approved", args, options); - } - remaining_allowance(args: { - account_id: AccountId, - }, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "remaining_allowance", args, options); - } - async nft_mint(args: { - token_id: TokenId, - token_owner_id: AccountId, - token_metadata: TokenMetadata, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.nft_mintRaw(args, options)); - } - nft_mintRaw(args: { - token_id: TokenId, - token_owner_id: AccountId, - token_metadata: TokenMetadata, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "nft_mint", args, ...options}); - } - nft_mintTx(args: { - token_id: TokenId, - token_owner_id: AccountId, - token_metadata: TokenMetadata, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("nft_mint", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - get_user_sale_info(args: { - account_id: AccountId, - }, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "get_user_sale_info", args, options); - } - nft_tokens_for_owner(args: { - account_id: AccountId, - from_index?: U128, - limit?: u64, - }, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "nft_tokens_for_owner", args, options); - } - async add_whitelist_account_ungaurded(args: { - account_id: AccountId, - allowance: number, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.add_whitelist_account_ungaurdedRaw(args, options)); - } - add_whitelist_account_ungaurdedRaw(args: { - account_id: AccountId, - allowance: number, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "add_whitelist_account_ungaurded", args, ...options}); - } - add_whitelist_account_ungaurdedTx(args: { - account_id: AccountId, - allowance: number, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("add_whitelist_account_ungaurded", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - tokens_left(args: { - } = {}, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "tokens_left", args, options); - } - nft_supply_for_owner(args: { - account_id: AccountId, - }, options?: ViewFunctionOptions): Promise { - return this.account.viewFunction(this.contractId, "nft_supply_for_owner", args, options); - } - async update_royalties(args: { - royalties: Royalties, - }, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.update_royaltiesRaw(args, options)); - } - update_royaltiesRaw(args: { - royalties: Royalties, - }, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "update_royalties", args, ...options}); - } - update_royaltiesTx(args: { - royalties: Royalties, - }, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("update_royalties", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) - } - async nft_mint_one(args: { - } = {}, options?: ChangeMethodOptions): Promise { - return providers.getTransactionLastResult(await this.nft_mint_oneRaw(args, options)); - } - nft_mint_oneRaw(args: { - } = {}, options?: ChangeMethodOptions): Promise { - return this.account.functionCall({contractId: this.contractId, methodName: "nft_mint_one", args, ...options}); - } - nft_mint_oneTx(args: { - } = {}, options?: ChangeMethodOptions): transactions.Action { - return transactions.functionCall("nft_mint_one", args, options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, options?.attachedDeposit ?? new BN(0)) + * Create a pending token that can be claimed with corresponding private key + */ + create_linkdropTx( + args: { + public_key: PublicKey + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "create_linkdrop", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + async add_whitelist_accounts( + args: { + accounts: AccountId[] + allowance?: number + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.add_whitelist_accountsRaw(args, options) + ) + } + add_whitelist_accountsRaw( + args: { + accounts: AccountId[] + allowance?: number + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "add_whitelist_accounts", + args, + ...options, + }) + } + add_whitelist_accountsTx( + args: { + accounts: AccountId[] + allowance?: number + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "add_whitelist_accounts", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + async new( + args: { + owner_id: AccountId + metadata: NftContractMetadata + size: number + sale: Sale + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult(await this.newRaw(args, options)) + } + newRaw( + args: { + owner_id: AccountId + metadata: NftContractMetadata + size: number + sale: Sale + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "new", + args, + ...options, + }) + } + newTx( + args: { + owner_id: AccountId + metadata: NftContractMetadata + size: number + sale: Sale + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "new", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + async start_presale( + args: { + public_sale_start?: Duration + presale_price?: U128 + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.start_presaleRaw(args, options) + ) + } + start_presaleRaw( + args: { + public_sale_start?: Duration + presale_price?: U128 + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "start_presale", + args, + ...options, + }) + } + start_presaleTx( + args: { + public_sale_start?: Duration + presale_price?: U128 + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "start_presale", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + token_storage_cost( + args: {} = {}, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "token_storage_cost", + args, + options + ) + } + async nft_transfer( + args: { + receiver_id: AccountId + token_id: TokenId + approval_id?: u64 + memo?: string + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.nft_transferRaw(args, options) + ) + } + nft_transferRaw( + args: { + receiver_id: AccountId + token_id: TokenId + approval_id?: u64 + memo?: string + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "nft_transfer", + args, + ...options, + }) + } + nft_transferTx( + args: { + receiver_id: AccountId + token_id: TokenId + approval_id?: u64 + memo?: string + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "nft_transfer", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + async nft_revoke_all( + args: { + token_id: TokenId + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.nft_revoke_allRaw(args, options) + ) + } + nft_revoke_allRaw( + args: { + token_id: TokenId + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "nft_revoke_all", + args, + ...options, + }) + } + nft_revoke_allTx( + args: { + token_id: TokenId + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "nft_revoke_all", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + cost_of_linkdrop( + args: { + minter: AccountId + }, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "cost_of_linkdrop", + args, + options + ) + } + total_cost( + args: { + num: number + minter: AccountId + }, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "total_cost", + args, + options + ) + } + get_linkdrop_contract( + args: {} = {}, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "get_linkdrop_contract", + args, + options + ) + } + async new_default_meta( + args: { + owner_id: AccountId + metadata: InitialMetadata + size: number + sale?: Sale + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.new_default_metaRaw(args, options) + ) + } + new_default_metaRaw( + args: { + owner_id: AccountId + metadata: InitialMetadata + size: number + sale?: Sale + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "new_default_meta", + args, + ...options, + }) + } + new_default_metaTx( + args: { + owner_id: AccountId + metadata: InitialMetadata + size: number + sale?: Sale + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "new_default_meta", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + async nft_revoke( + args: { + token_id: TokenId + account_id: AccountId + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.nft_revokeRaw(args, options) + ) + } + nft_revokeRaw( + args: { + token_id: TokenId + account_id: AccountId + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "nft_revoke", + args, + ...options, + }) + } + nft_revokeTx( + args: { + token_id: TokenId + account_id: AccountId + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "nft_revoke", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + nft_metadata( + args: {} = {}, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "nft_metadata", + args, + options + ) + } + mint_rate_limit( + args: {} = {}, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "mint_rate_limit", + args, + options + ) + } + nft_is_approved( + args: { + token_id: TokenId + approved_account_id: AccountId + approval_id?: u64 + }, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "nft_is_approved", + args, + options + ) + } + remaining_allowance( + args: { + account_id: AccountId + }, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "remaining_allowance", + args, + options + ) + } + async nft_mint( + args: { + token_id: TokenId + token_owner_id: AccountId + token_metadata: TokenMetadata + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.nft_mintRaw(args, options) + ) + } + nft_mintRaw( + args: { + token_id: TokenId + token_owner_id: AccountId + token_metadata: TokenMetadata + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "nft_mint", + args, + ...options, + }) + } + nft_mintTx( + args: { + token_id: TokenId + token_owner_id: AccountId + token_metadata: TokenMetadata + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "nft_mint", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + get_user_sale_info( + args: { + account_id: AccountId + }, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "get_user_sale_info", + args, + options + ) + } + nft_tokens_for_owner( + args: { + account_id: AccountId + from_index?: U128 + limit?: u64 + }, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "nft_tokens_for_owner", + args, + options + ) + } + async add_whitelist_account_ungaurded( + args: { + account_id: AccountId + allowance: number + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.add_whitelist_account_ungaurdedRaw(args, options) + ) + } + add_whitelist_account_ungaurdedRaw( + args: { + account_id: AccountId + allowance: number + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "add_whitelist_account_ungaurded", + args, + ...options, + }) + } + add_whitelist_account_ungaurdedTx( + args: { + account_id: AccountId + allowance: number + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "add_whitelist_account_ungaurded", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + tokens_left(args: {} = {}, options?: ViewFunctionOptions): Promise { + return this.account.viewFunction( + this.contractId, + "tokens_left", + args, + options + ) + } + nft_supply_for_owner( + args: { + account_id: AccountId + }, + options?: ViewFunctionOptions + ): Promise { + return this.account.viewFunction( + this.contractId, + "nft_supply_for_owner", + args, + options + ) + } + async update_royalties( + args: { + royalties: Royalties + }, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.update_royaltiesRaw(args, options) + ) + } + update_royaltiesRaw( + args: { + royalties: Royalties + }, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "update_royalties", + args, + ...options, + }) + } + update_royaltiesTx( + args: { + royalties: Royalties + }, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "update_royalties", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) + } + async nft_mint_one( + args: {} = {}, + options?: ChangeMethodOptions + ): Promise { + return providers.getTransactionLastResult( + await this.nft_mint_oneRaw(args, options) + ) + } + nft_mint_oneRaw( + args: {} = {}, + options?: ChangeMethodOptions + ): Promise { + return this.account.functionCall({ + contractId: this.contractId, + methodName: "nft_mint_one", + args, + ...options, + }) + } + nft_mint_oneTx( + args: {} = {}, + options?: ChangeMethodOptions + ): transactions.Action { + return transactions.functionCall( + "nft_mint_one", + args, + options?.gas ?? DEFAULT_FUNCTION_CALL_GAS, + options?.attachedDeposit ?? new BN(0) + ) } } diff --git a/stale-data-from-build-time.json b/stale-data-from-build-time.json index 334c667..b81a047 100644 --- a/stale-data-from-build-time.json +++ b/stale-data-from-build-time.json @@ -1 +1 @@ -{"saleInfo":{"status":"Open","presale_start":8640000000000000,"sale_start":1649267295545,"token_final_supply":10000,"price":"2000000000000000000000000"},"contractMetadata":{"spec":"nft-1.0.0","name":"TENK NFT","symbol":"TENK","icon":"","base_uri":"https://bafybeihmtke7glg2aec5oav5btzlv6ec4fxkbbh4xjre4x5ipaqdxroahe.ipfs.dweb.link","reference":null,"reference_hash":null},"tokensLeft":9920,"vip":false,"nfts":[],"mintRateLimit":10} \ No newline at end of file +{"saleInfo":{"status":"Open","presale_start":1654533037000,"sale_start":1654533937000,"token_final_supply":200,"price":"14000000000000000000000000"},"contractMetadata":{"spec":"nft-1.0.0","name":"Cheddar","symbol":"Cheddar","icon":"","base_uri":"https://bafybeibghcllcmurku7lxyg4wgxn2zsu5qqk7h4r6bmyhpztmyd564cx54.ipfs.nftstorage.link","reference":null,"reference_hash":null},"tokensLeft":189,"vip":false,"nfts":[],"mintRateLimit":10} \ No newline at end of file From b664eb43eed7f4b9f4ff4c5e1481a01810491d79 Mon Sep 17 00:00:00 2001 From: RodrigoCSolari Date: Wed, 20 Jul 2022 14:49:07 -0300 Subject: [PATCH 04/10] fix: remove slider --- src/components/hero/index.tsx | 94 ++++++++++++++++++----------------- 1 file changed, 48 insertions(+), 46 deletions(-) diff --git a/src/components/hero/index.tsx b/src/components/hero/index.tsx index 152fb02..089ff84 100644 --- a/src/components/hero/index.tsx +++ b/src/components/hero/index.tsx @@ -1,14 +1,14 @@ -import React from 'react' -import type { ExpandedHeroTree } from '../../../lib/locales' -import { act, can, fill } from '../../../lib/locales/runtimeUtils' +import React from "react" +import type { ExpandedHeroTree } from "../../../lib/locales" +import { act, can, fill } from "../../../lib/locales/runtimeUtils" import { wallet } from "../../near" -import Slider from '../slider' -import Section from '../section' +import Slider from "../slider" +import Section from "../section" import Markdown from "../markdown" -import useHeroStatuses from '../../hooks/useHeroStatuses' -import useTenk from '../../hooks/useTenk' -import useLocales from '../../hooks/useLocales' -import * as css from './hero.module.css' +import useHeroStatuses from "../../hooks/useHeroStatuses" +import useTenk from "../../hooks/useTenk" +import useLocales from "../../hooks/useLocales" +import * as css from "./hero.module.css" const currentUser = wallet.getAccountId() @@ -17,8 +17,8 @@ const Hero: React.FC<{ heroTree: ExpandedHeroTree }> = ({ heroTree }) => { const tenkData = useTenk() const { saleStatus, userStatus } = useHeroStatuses() const [numberToMint, setNumberToMint] = React.useState(1) - const [nearMint, setNearMint] = React.useState(1); - const [chedMint, setChedMint] = React.useState(3); + const [nearMint, setNearMint] = React.useState(1) + const [chedMint, setChedMint] = React.useState(3) const hero = heroTree[saleStatus][userStatus] if (!locale) return null @@ -31,38 +31,47 @@ const Hero: React.FC<{ heroTree: ExpandedHeroTree }> = ({ heroTree }) => { userStatus, } - const mintForNear = function () { - console.log("NEAR") - act("MintForNear", { ...data, numberToMint}) + console.log("NEAR") + act("MintForNear", { ...data, numberToMint }) } - - const mintForCheddar = function() { - console.log("Cheddar") - act("MintForChed", { ...data, numberToMint}) + + const mintForCheddar = function () { + console.log("Cheddar") + act("MintForChed", { ...data, numberToMint }) } return (
{can(hero.action, data) && ( -
{ - e.preventDefault() - //act(hero.action, { ...data, numberToMint }) - }}> + { + e.preventDefault() + //act(hero.action, { ...data, numberToMint }) + }} + > {hero.setNumber && ( <>
@@ -73,29 +82,22 @@ const Hero: React.FC<{ heroTree: ExpandedHeroTree }> = ({ heroTree }) => { {fill(hero.remaining, data)}
- setNumberToMint(v)} - value={[numberToMint]} - /> )} )}

{locale.title}

- +
@@ -106,4 +108,4 @@ const Hero: React.FC<{ heroTree: ExpandedHeroTree }> = ({ heroTree }) => { ) } -export default Hero \ No newline at end of file +export default Hero From 1f554584624abda33ac00c46704bca8261745ff7 Mon Sep 17 00:00:00 2001 From: RodrigoCSolari Date: Wed, 20 Jul 2022 14:51:08 -0300 Subject: [PATCH 05/10] feat: add connect modal --- package.json | 4 + src/components/connectModal/index.tsx | 128 +++++++++++++++++++++++++ src/components/hero/index.tsx | 27 +++++- src/components/layout/index.tsx | 7 +- src/components/nav/index.tsx | 39 +++++++- src/components/nav/nav.module.css | 30 +++++- src/components/nav/nav.module.css.d.ts | 2 + src/templates/[locale].tsx | 39 +++++--- yarn.lock | 36 +++++++ 9 files changed, 287 insertions(+), 25 deletions(-) create mode 100644 src/components/connectModal/index.tsx diff --git a/package.json b/package.json index b716043..cbae3b7 100644 --- a/package.json +++ b/package.json @@ -5,8 +5,12 @@ "version": "0.1.0", "author": "Chad Ostrowski ", "dependencies": { + "@radix-ui/colors": "^0.1.8", + "@radix-ui/react-dialog": "^0.1.7", "@radix-ui/react-dropdown-menu": "0.1.6", + "@radix-ui/react-icons": "^1.1.1", "@radix-ui/react-slider": "^0.1.4", + "@stitches/react": "^1.2.8", "add-to-calendar-button": "1.7.8", "bn.js": "^5.2.0", "gatsby-background-image": "^1.6.0", diff --git a/src/components/connectModal/index.tsx b/src/components/connectModal/index.tsx new file mode 100644 index 0000000..61d4cec --- /dev/null +++ b/src/components/connectModal/index.tsx @@ -0,0 +1,128 @@ +import React from "react" +import { styled, keyframes } from "@stitches/react" +import { violet, blackA, mauve, green } from "@radix-ui/colors" +import { Cross2Icon } from "@radix-ui/react-icons" +import * as DialogPrimitive from "@radix-ui/react-dialog" +import { signIn } from "../../near" + +const overlayShow = keyframes({ + "0%": { opacity: 0 }, + "100%": { opacity: 1 }, +}) + +const contentShow = keyframes({ + "0%": { opacity: 0, transform: "translate(-50%, -48%) scale(.96)" }, + "100%": { opacity: 1, transform: "translate(-50%, -50%) scale(1)" }, +}) + +const StyledOverlay = styled(DialogPrimitive.Overlay, { + backgroundColor: blackA.blackA9, + position: "fixed", + inset: 0, + "@media (prefers-reduced-motion: no-preference)": { + animation: `${overlayShow} 150ms cubic-bezier(0.16, 1, 0.3, 1) forwards`, + }, +}) + +const StyledContent = styled(DialogPrimitive.Content, { + backgroundColor: "white", + borderRadius: 6, + boxShadow: + "hsl(206 22% 7% / 35%) 0px 10px 38px -10px, hsl(206 22% 7% / 20%) 0px 10px 20px -15px", + position: "fixed", + top: "50%", + left: "50%", + transform: "translate(-50%, -50%)", + width: "90vw", + maxWidth: "450px", + maxHeight: "85vh", + padding: 25, + "@media (prefers-reduced-motion: no-preference)": { + animation: `${contentShow} 150ms cubic-bezier(0.16, 1, 0.3, 1) forwards`, + }, + "&:focus": { outline: "none" }, +}) + +const StyledTitle = styled(DialogPrimitive.Title, { + margin: 0, + fontWeight: 500, + color: mauve.mauve12, + fontSize: 17, +}) + +const StyledDescription = styled(DialogPrimitive.Description, { + margin: "10px 0 20px", + color: mauve.mauve11, + fontSize: 15, + lineHeight: 1.5, +}) + +// Exports +export const Dialog = DialogPrimitive.Root +export const DialogContent = DialogPrimitive.Portal +export const DialogTitle = StyledTitle +export const DialogDescription = StyledDescription +export const DialogClose = DialogPrimitive.Close + +// Your app... +const Flex = styled("div", { display: "flex" }) +const Box = styled("div", {}) + +const IconButton = styled("button", { + all: "unset", + fontFamily: "inherit", + borderRadius: "100%", + height: 25, + width: 25, + display: "inline-flex", + alignItems: "center", + justifyContent: "center", + color: violet.violet11, + position: "absolute", + top: 10, + right: 10, + + "&:hover": { backgroundColor: violet.violet4 }, + "&:focus": { boxShadow: `0 0 0 2px ${violet.violet7}` }, +}) + +type Props = { + showConnectModal: boolean + setShowConnectModal: React.Dispatch> +} + +const ConnectModal = ({ showConnectModal, setShowConnectModal }: Props) => { + const handleClose = () => { + setShowConnectModal(false) + } + + return ( + + + + + Error + + To mint a NFT you must first connect your wallet. + + + + + + + + + + + ) +} + +export default ConnectModal diff --git a/src/components/hero/index.tsx b/src/components/hero/index.tsx index 089ff84..5aaf3a9 100644 --- a/src/components/hero/index.tsx +++ b/src/components/hero/index.tsx @@ -9,10 +9,15 @@ import useHeroStatuses from "../../hooks/useHeroStatuses" import useTenk from "../../hooks/useTenk" import useLocales from "../../hooks/useLocales" import * as css from "./hero.module.css" +import ConnectModal from "../connectModal" const currentUser = wallet.getAccountId() -const Hero: React.FC<{ heroTree: ExpandedHeroTree }> = ({ heroTree }) => { +const Hero: React.FC<{ + heroTree: ExpandedHeroTree + showConnectModal: boolean + setShowConnectModal: React.Dispatch> +}> = ({ heroTree, showConnectModal, setShowConnectModal }) => { const { locale } = useLocales() const tenkData = useTenk() const { saleStatus, userStatus } = useHeroStatuses() @@ -32,13 +37,21 @@ const Hero: React.FC<{ heroTree: ExpandedHeroTree }> = ({ heroTree }) => { } const mintForNear = function () { - console.log("NEAR") - act("MintForNear", { ...data, numberToMint }) + if (userStatus === "signedOut") { + setShowConnectModal(true) + } else { + console.log("NEAR") + act("MintForNear", { ...data, numberToMint }) + } } const mintForCheddar = function () { - console.log("Cheddar") - act("MintForChed", { ...data, numberToMint }) + if (userStatus === "signedOut") { + setShowConnectModal(true) + } else { + console.log("Cheddar") + act("MintForChed", { ...data, numberToMint }) + } } return ( @@ -104,6 +117,10 @@ const Hero: React.FC<{ heroTree: ExpandedHeroTree }> = ({ heroTree }) => { {hero.ps && }
+
) } diff --git a/src/components/layout/index.tsx b/src/components/layout/index.tsx index f031f0e..2e1aaca 100644 --- a/src/components/layout/index.tsx +++ b/src/components/layout/index.tsx @@ -5,12 +5,15 @@ import Nav from "../nav" import Footer from "../footer" import * as css from "./layout.module.css" -const Layout: React.FC<{ style?: React.CSSProperties }> = ({ style, children }) => { +const Layout: React.FC<{ + style?: React.CSSProperties + showConnectModal: boolean +}> = ({ style, showConnectModal, children }) => { return (
-
diff --git a/src/components/nav/index.tsx b/src/components/nav/index.tsx index cb57ef7..f28e886 100644 --- a/src/components/nav/index.tsx +++ b/src/components/nav/index.tsx @@ -1,5 +1,5 @@ import settings from "../../../config/settings.json" -import React, { useState } from "react" +import React, { useEffect, useState } from "react" import { signIn, wallet } from "../../near" import * as css from "./nav.module.css" import useLocales from "../../hooks/useLocales" @@ -13,21 +13,46 @@ function signOut() { window.location.replace(window.location.origin + window.location.pathname) } -export default function Nav() { +type Props = { + showConnectModal: boolean +} + +export default function Nav({ showConnectModal }: Props) { const currentUser = wallet.getAccountId() const { locale } = useLocales() const { nfts } = useTenk() const [showNFTs, setShowNFTs] = useState(false) + const [firstRender, setFirstRender] = useState(true) + const [buttonClass, setButtonClass] = useState("secondary") if (!locale) return null + const handleOnAnimationEnd = () => { + setButtonClass("secondary") + } + + useEffect(() => { + if (showConnectModal) { + setFirstRender(false) + } + if (!showConnectModal && !firstRender) { + setButtonClass(`secondary ${css.buttonAnimation}`) + } + }, [showConnectModal]) + return ( <>
{showNFTs && setShowNFTs(false)} />} + {showSpinner && } ) } diff --git a/src/components/spinner/cheddar.svg b/src/components/spinner/cheddar.svg new file mode 100644 index 0000000..7034080 --- /dev/null +++ b/src/components/spinner/cheddar.svg @@ -0,0 +1,330 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/src/components/spinner/index.tsx b/src/components/spinner/index.tsx new file mode 100644 index 0000000..3736571 --- /dev/null +++ b/src/components/spinner/index.tsx @@ -0,0 +1,54 @@ +import React from "react" +import { styled, keyframes } from "@stitches/react" +import { blackA } from "@radix-ui/colors" +import * as DialogPrimitive from "@radix-ui/react-dialog" +import * as css from "./spinner.module.css" +import { StaticImage } from "gatsby-plugin-image" + +const overlayShow = keyframes({ + "0%": { opacity: 0 }, + "100%": { opacity: 1 }, +}) + +const StyledOverlay = styled(DialogPrimitive.Overlay, { + backgroundColor: blackA.blackA11, + position: "fixed", + inset: 0, + "@media (prefers-reduced-motion: no-preference)": { + animation: `${overlayShow} 150ms cubic-bezier(0.16, 1, 0.3, 1) forwards`, + }, +}) + +// Exports +export const Dialog = DialogPrimitive.Root +export const DialogContent = DialogPrimitive.Portal + +const Spinner = () => { + return ( + + + +
+ +
+
+
+ ) +} + +export default Spinner diff --git a/src/components/spinner/spinner.module.css b/src/components/spinner/spinner.module.css new file mode 100644 index 0000000..11bb28b --- /dev/null +++ b/src/components/spinner/spinner.module.css @@ -0,0 +1,18 @@ +.cheddarSpinner { + width: 70px !important; + margin: auto; + animation-iteration-count: infinite; + animation-timing-function: linear; + animation-duration: 0.8s; + animation-name: spinner-loading; + z-index: -1; +} + +@keyframes spinner-loading { + 0% { + transform: rotate(0deg); + } + to { + transform: rotate(1turn); + } +} diff --git a/src/components/spinner/spinner.module.css.d.ts b/src/components/spinner/spinner.module.css.d.ts new file mode 100644 index 0000000..d7b2a33 --- /dev/null +++ b/src/components/spinner/spinner.module.css.d.ts @@ -0,0 +1,3 @@ +// This file is automatically generated. Do not modify this file manually -- YOUR CHANGES WILL BE ERASED! +export const cheddarSpinner: string; +export const spinnerLoading: string; diff --git a/stale-data-from-build-time.json b/stale-data-from-build-time.json index b81a047..ffda819 100644 --- a/stale-data-from-build-time.json +++ b/stale-data-from-build-time.json @@ -1 +1 @@ -{"saleInfo":{"status":"Open","presale_start":1654533037000,"sale_start":1654533937000,"token_final_supply":200,"price":"14000000000000000000000000"},"contractMetadata":{"spec":"nft-1.0.0","name":"Cheddar","symbol":"Cheddar","icon":"","base_uri":"https://bafybeibghcllcmurku7lxyg4wgxn2zsu5qqk7h4r6bmyhpztmyd564cx54.ipfs.nftstorage.link","reference":null,"reference_hash":null},"tokensLeft":189,"vip":false,"nfts":[],"mintRateLimit":10} \ No newline at end of file +{"saleInfo":{"status":"Open","presale_start":1654533037000,"sale_start":1654533937000,"token_final_supply":200,"price":"14000000000000000000000000"},"contractMetadata":{"spec":"nft-1.0.0","name":"Cheddar","symbol":"Cheddar","icon":"","base_uri":"https://bafybeibghcllcmurku7lxyg4wgxn2zsu5qqk7h4r6bmyhpztmyd564cx54.ipfs.nftstorage.link","reference":null,"reference_hash":null},"tokensLeft":187,"vip":false,"nfts":[],"mintRateLimit":10} \ No newline at end of file From c345f8d907e54a93b774fccb280390f1fbceaacf Mon Sep 17 00:00:00 2001 From: RodrigoCSolari Date: Fri, 22 Jul 2022 15:49:57 -0300 Subject: [PATCH 08/10] fix: nft cards --- src/components/my-nfts/index.tsx | 110 +++++++++++------- src/components/my-nfts/my-nfts.module.css | 20 +++- .../my-nfts/my-nfts.module.css.d.ts | 1 + 3 files changed, 84 insertions(+), 47 deletions(-) diff --git a/src/components/my-nfts/index.tsx b/src/components/my-nfts/index.tsx index e384b13..d6b5e01 100644 --- a/src/components/my-nfts/index.tsx +++ b/src/components/my-nfts/index.tsx @@ -1,19 +1,20 @@ import React, { useEffect, useMemo, useRef, useState } from "react" -import { createPortal } from 'react-dom' -import Lightbox from 'react-image-lightbox'; +import { createPortal } from "react-dom" +import Lightbox from "react-image-lightbox" import { wallet } from "../../near" -import useLocales from '../../hooks/useLocales' -import useTenk from '../../hooks/useTenk' -import * as css from './my-nfts.module.css' -import 'react-image-lightbox/style.css'; +import useLocales from "../../hooks/useLocales" +import useTenk from "../../hooks/useTenk" +import * as css from "./my-nfts.module.css" +import "react-image-lightbox/style.css" -const portalRoot: undefined | HTMLElement = typeof document !== 'undefined' - ? document.getElementById("portal")! - : undefined +const portalRoot: undefined | HTMLElement = + typeof document !== "undefined" + ? document.getElementById("portal")! + : undefined const MyNFTs: React.FC<{ - highlight?: string[], - onClose: () => void, + highlight?: string[] + onClose: () => void }> = ({ highlight, onClose }) => { const currentUser = wallet.getAccountId() const { locale } = useLocales() @@ -23,23 +24,31 @@ const MyNFTs: React.FC<{ const portalElement = useRef(document.createElement("div")) const containerElement = useRef(null) - const onClick = useMemo(() => function onCloseRaw(this: Document, event: MouseEvent) { - if (!lightboxOpen && event.target && !containerElement.current?.contains(event.target as Node)) { - onClose() - } - }, [lightboxOpen, onClose]) + const onClick = useMemo( + () => + function onCloseRaw(this: Document, event: MouseEvent) { + if ( + !lightboxOpen && + event.target && + !containerElement.current?.contains(event.target as Node) + ) { + onClose() + } + }, + [lightboxOpen, onClose] + ) useEffect(() => { portalRoot?.appendChild(portalElement.current) - const bgContent: HTMLDivElement = document.querySelector('#___gatsby')! - bgContent.style.filter = 'blur(4px)' - bgContent.style.overflow = 'hidden' - document.addEventListener('click', onClick) + const bgContent: HTMLDivElement = document.querySelector("#___gatsby")! + bgContent.style.filter = "blur(4px)" + bgContent.style.overflow = "hidden" + document.addEventListener("click", onClick) return function onUnmount() { - bgContent.style.filter = '' - bgContent.style.overflow = '' + bgContent.style.filter = "" + bgContent.style.overflow = "" portalRoot?.removeChild(portalElement.current) - document.removeEventListener('click', onClick) + document.removeEventListener("click", onClick) } }, [onClick, portalRoot]) @@ -52,9 +61,13 @@ const MyNFTs: React.FC<{ ) { return null } - - const nextSrc = nfts.length > 1 ? nfts[(photoIndex + 1) % nfts.length].media : undefined - const prevSrc = nfts.length > 1 ? nfts[(photoIndex + nfts.length - 1) % nfts.length].media : undefined + console.log(nfts) + const nextSrc = + nfts.length > 1 ? nfts[(photoIndex + 1) % nfts.length].media : undefined + const prevSrc = + nfts.length > 1 + ? nfts[(photoIndex + nfts.length - 1) % nfts.length].media + : undefined return createPortal( <> @@ -68,23 +81,32 @@ const MyNFTs: React.FC<{
{nfts.map((nft, index) => ( - +
+ +
))}
@@ -115,4 +137,4 @@ const MyNFTs: React.FC<{ ) } -export default MyNFTs \ No newline at end of file +export default MyNFTs diff --git a/src/components/my-nfts/my-nfts.module.css b/src/components/my-nfts/my-nfts.module.css index fbd3b00..e6ff94e 100644 --- a/src/components/my-nfts/my-nfts.module.css +++ b/src/components/my-nfts/my-nfts.module.css @@ -50,6 +50,20 @@ display: flex; flex-direction: column; justify-content: space-between; + align-items: center; + text-align: left; +} + +.nft-wrapper { + background-color: #777; + color: inherit; + padding: 10px; + margin: 0; + border: none; + border-radius: 5px; + display: flex; + flex-direction: column; + justify-content: space-between; text-align: left; transition: transform 75ms; transform: scale(100%); @@ -58,7 +72,7 @@ .nft:hover, .nft:focus { box-shadow: none; - transform: scale(105%); + transform: scale(1.05); background-color: transparent; } @@ -72,7 +86,7 @@ font-weight: var(--fw-bold); } -.nft>div:first-child { +.nft > div:first-child { --aspect-ratio: 1 / 1; background-color: var(--gray-1); border-radius: var(--br-small); @@ -80,4 +94,4 @@ background-repeat: no-repeat; background-position: center; background-size: cover; -} \ No newline at end of file +} diff --git a/src/components/my-nfts/my-nfts.module.css.d.ts b/src/components/my-nfts/my-nfts.module.css.d.ts index e2644cd..e71289c 100644 --- a/src/components/my-nfts/my-nfts.module.css.d.ts +++ b/src/components/my-nfts/my-nfts.module.css.d.ts @@ -3,4 +3,5 @@ export const myNfts: string; export const close: string; export const grid: string; export const nft: string; +export const nftWrapper: string; export const highlight: string; From 714c53c722667d50994edde584a6498da13de0f5 Mon Sep 17 00:00:00 2001 From: RodrigoCSolari Date: Thu, 4 Aug 2022 20:38:53 -0300 Subject: [PATCH 09/10] feat: get cheddar price --- lib/locales/runtimeUtils.ts | 8 ++--- src/components/hero/index.tsx | 1 + src/hooks/useTenk.ts | 61 +++++++++++++++++++++++++++++------ 3 files changed, 55 insertions(+), 15 deletions(-) diff --git a/lib/locales/runtimeUtils.ts b/lib/locales/runtimeUtils.ts index 789d20d..da3a84e 100644 --- a/lib/locales/runtimeUtils.ts +++ b/lib/locales/runtimeUtils.ts @@ -17,6 +17,7 @@ type Data = TenkData & { chedMint?: number saleStatus: typeof saleStatuses[number] userStatus: typeof userStatuses[number] + price_cheddar_near: number } function formatNumber( @@ -87,12 +88,7 @@ const replacers = { .toHuman() .split(" ")[0] ) - : formatCurrency1( - NEAR.from(3) - .mul(NEAR.from("" + (d.numberToMint ?? 1))) - .toHuman() - .split(" ")[0] - ), + : formatCurrency1(d.price_cheddar_near), MINT_RATE_LIMIT: (d: Data) => d.mintRateLimit, INITIAL_COUNT: (d: Data) => formatNumber(d.saleInfo.token_final_supply), REMAINING_COUNT: (d: Data) => formatNumber(d.tokensLeft), diff --git a/src/components/hero/index.tsx b/src/components/hero/index.tsx index e972886..71136ab 100644 --- a/src/components/hero/index.tsx +++ b/src/components/hero/index.tsx @@ -10,6 +10,7 @@ import useLocales from "../../hooks/useLocales" import * as css from "./hero.module.css" import ConnectModal from "../connectModal" import Spinner from "../spinner" +import { NEAR } from "near-units" const currentUser = wallet.getAccountId() diff --git a/src/hooks/useTenk.ts b/src/hooks/useTenk.ts index 1731171..b04314f 100644 --- a/src/hooks/useTenk.ts +++ b/src/hooks/useTenk.ts @@ -1,5 +1,9 @@ import React from "react" -import { NftContractMetadata, SaleInfo, Token as RawToken } from "../near/contracts/tenk" +import { + NftContractMetadata, + SaleInfo, + Token as RawToken, +} from "../near/contracts/tenk" import { TenK } from "../near/contracts" import { wallet } from "../near" import staleData from "../../stale-data-from-build-time.json" @@ -22,6 +26,7 @@ export interface TenkData { interface ReturnedData extends TenkData { stale: boolean + price_cheddar_near: number } // initialize calls at root of file so that first evaluation of this file causes @@ -46,7 +51,7 @@ export async function rpcData(): Promise { vip, remainingAllowance, nfts, - mintRateLimit + mintRateLimit, ] = await rpcCalls return { saleInfo, @@ -54,22 +59,60 @@ export async function rpcData(): Promise { tokensLeft, vip: vip ?? false, remainingAllowance: remainingAllowance ?? undefined, - nfts: nfts?.map(nft => ({ ...nft, - media: new URL(nft.metadata?.media ?? '', contractMetadata.base_uri ?? '').href - })) ?? [], + nfts: + nfts?.map(nft => ({ + ...nft, + media: new URL( + nft.metadata?.media ?? "", + contractMetadata.base_uri ?? "" + ).href, + })) ?? [], mintRateLimit: mintRateLimit ?? 10, } } +const axios = require("axios") + +const cheddarNearPrice = async () => { + const url = "https://api.stats.ref.finance/api/top-tokens" + const returns = await axios.get(url) + const prices = returns.data + + let price_near = 0 + let price_cheddar = 0 + let price_cheddar_near = 0 + if (prices) { + for (let i = 0; i < prices.length; i++) { + const price = prices[i] + if (price.symbol == "wNEAR") { + price_near = price.price + } else if (price.symbol == "Cheddar") { + price_cheddar = price.price + } + } + + if (price_near > 0 && price_cheddar > 0) { + price_cheddar_near = + Math.round(price_near / price_cheddar) * Math.pow(10, 3) + } + } + return price_cheddar_near +} + export default function useTenk(): ReturnedData { const [data, setData] = React.useState({ - ...staleData as unknown as TenkData, - stale: true + ...(staleData as unknown as TenkData), + stale: true, + price_cheddar_near: 0, }) React.useEffect(() => { - rpcData().then(d => setData({ ...d, stale: false })) + rpcData().then(d => + cheddarNearPrice().then(resp => + setData({ ...d, stale: false, price_cheddar_near: resp }) + ) + ) }, []) return data -} \ No newline at end of file +} From c3ac99d716e2d42595e1b372e9bdb3c313fdbffd Mon Sep 17 00:00:00 2001 From: RodrigoCSolari Date: Thu, 18 Aug 2022 20:10:29 -0300 Subject: [PATCH 10/10] feat: buy whit cheddar --- lib/locales/runtimeUtils.ts | 61 +++++++++++++++++++++----- src/hooks/useTenk.ts | 15 ++++--- src/near/contracts/tenk.ts | 77 +++++++++++++++++++++++++++++++++ src/near/index.ts | 11 ++--- stale-data-from-build-time.json | 2 +- 5 files changed, 143 insertions(+), 23 deletions(-) diff --git a/lib/locales/runtimeUtils.ts b/lib/locales/runtimeUtils.ts index da3a84e..2d25f47 100644 --- a/lib/locales/runtimeUtils.ts +++ b/lib/locales/runtimeUtils.ts @@ -6,6 +6,8 @@ import { TenK } from "../../src/near/contracts" import { TenkData } from "../../src/hooks/useTenk" import { saleStatuses, userStatuses } from "./Locale" import { Locale } from "../../src/hooks/useLocales" +import { transactions } from "near-api-js" +import { BN } from "bn.js" type Timestamp = number @@ -17,7 +19,7 @@ type Data = TenkData & { chedMint?: number saleStatus: typeof saleStatuses[number] userStatus: typeof userStatuses[number] - price_cheddar_near: number + price_cheddar_near: string } function formatNumber( @@ -45,7 +47,7 @@ function formatCurrency( return `${formatNumber(num, locale)} ${currency}` } -function formatCurrency1( +function formatCurrencyCheddar( num: number | string, currency: string = "Cheddar", @@ -88,7 +90,9 @@ const replacers = { .toHuman() .split(" ")[0] ) - : formatCurrency1(d.price_cheddar_near), + : formatCurrencyCheddar( + (BigInt(d.price_cheddar_near) / BigInt(Math.pow(10, 24))).toString() + ), MINT_RATE_LIMIT: (d: Data) => d.mintRateLimit, INITIAL_COUNT: (d: Data) => formatNumber(d.saleInfo.token_final_supply), REMAINING_COUNT: (d: Data) => formatNumber(d.tokensLeft), @@ -176,16 +180,49 @@ const actions = { ), } ), - MintForChed: (d: Data) => - TenK.nft_mint_many( - { num: d.numberToMint ?? 1, with_cheddar: true }, - { - gas: Gas.parse("40 Tgas").mul(Gas.from("" + d.numberToMint)), - attachedDeposit: NEAR.from(d.saleInfo.price).mul( - NEAR.from("" + d.numberToMint) - ), + MintForChed: (d: Data) => { + TenK.get_cheddar_storage_balance("oreos.testnet").then(resp => { + const cheddarActions = [] + const tenkActions = [] + const finalActions = [] + if (!resp) { + cheddarActions.push( + transactions.functionCall( + "storage_deposit", + {}, + Gas.parse("100 Tgas"), + new BN("1120000000000000000000") + ) + ) } - ), + cheddarActions.push( + transactions.functionCall( + "ft_transfer_call", + { + receiver_id: TenK.contractId, + amount: d.price_cheddar_near, + msg: "", + }, + Gas.parse("200 Tgas"), + new BN("1") + ) + ) + tenkActions.push( + transactions.functionCall( + "nft_mint_many", + { num: d.numberToMint ?? 1, with_cheddar: true }, + + Gas.parse("40 Tgas").mul(Gas.from("" + d.numberToMint)), + new BN("1") + ) + ) + finalActions.push( + TenK.makeTransaction("token-v3.cheddar.testnet", cheddarActions) + ) + finalActions.push(TenK.makeTransaction(TenK.contractId, tenkActions)) + TenK.passToWallet(finalActions) + }) + }, GO_TO_PARAS: () => window.open( `https://paras.id/search?q=${settings.contractName}&sort=priceasc&pmin=.01&is_verified=true` diff --git a/src/hooks/useTenk.ts b/src/hooks/useTenk.ts index b04314f..086d9e1 100644 --- a/src/hooks/useTenk.ts +++ b/src/hooks/useTenk.ts @@ -26,7 +26,7 @@ export interface TenkData { interface ReturnedData extends TenkData { stale: boolean - price_cheddar_near: number + price_cheddar_near: string } // initialize calls at root of file so that first evaluation of this file causes @@ -73,7 +73,7 @@ export async function rpcData(): Promise { const axios = require("axios") -const cheddarNearPrice = async () => { +const cheddarNearPrice = async (nftNearPrice: string) => { const url = "https://api.stats.ref.finance/api/top-tokens" const returns = await axios.get(url) const prices = returns.data @@ -96,19 +96,24 @@ const cheddarNearPrice = async () => { Math.round(price_near / price_cheddar) * Math.pow(10, 3) } } - return price_cheddar_near + const nftCheddarPrice = ( + (BigInt(nftNearPrice) * BigInt(price_cheddar_near)) / + BigInt(Math.pow(10, 3)) + ).toString() + + return nftCheddarPrice } export default function useTenk(): ReturnedData { const [data, setData] = React.useState({ ...(staleData as unknown as TenkData), stale: true, - price_cheddar_near: 0, + price_cheddar_near: "0", }) React.useEffect(() => { rpcData().then(d => - cheddarNearPrice().then(resp => + cheddarNearPrice(d.saleInfo.price).then(resp => setData({ ...d, stale: false, price_cheddar_near: resp }) ) ) diff --git a/src/near/contracts/tenk.ts b/src/near/contracts/tenk.ts index 727da19..064ea21 100644 --- a/src/near/contracts/tenk.ts +++ b/src/near/contracts/tenk.ts @@ -3,9 +3,17 @@ import { transactions, providers, DEFAULT_FUNCTION_CALL_GAS, + Near, + connect, + keyStores, + WalletAccount, + utils, + WalletConnection, } from "near-api-js" import BN from "bn.js" +import { nearConfig } from ".." +import { baseDecode } from "borsh" export interface ChangeMethodOptions { gas?: BN attachedDeposit?: BN @@ -206,8 +214,68 @@ export interface Royalties { } export class Contract { + near: Near | undefined + walletAccount: WalletConnection | undefined + constructor(public account: Account, public readonly contractId: string) {} + async passToWallet( + preTXs: Promise[] + ): Promise { + const TXs = await Promise.all(preTXs) + if (!this.walletAccount) { + throw new Error("You have to make a transaction first") + } + + this.walletAccount.requestSignTransactions({ + transactions: TXs, + callbackUrl: window.location.href, + }) + } + + async makeTransaction( + receiverId: string, + actions: transactions.Action[], + nonceOffset = 1 + ): Promise { + this.near = await connect( + Object.assign( + { + deps: { + keyStore: new keyStores.BrowserLocalStorageKeyStore(), + }, + }, + nearConfig + ) + ) + this.walletAccount = new WalletAccount(this.near) + const accountAux = this.walletAccount.account() + const [accessKey, block] = await Promise.all([ + accountAux.accessKeyForTransaction(receiverId, actions), + this.near.connection.provider.block({ finality: "final" }), + ]) + + if (!accessKey) { + throw new Error( + `Cannot find matching key for transaction sent to ${receiverId}` + ) + } + + const blockHash = baseDecode(block.header.hash) + + const publicKey = utils.PublicKey.from(accessKey.public_key) + const nonce = accessKey.access_key.nonce + nonceOffset + + return transactions.createTransaction( + accountAux.accountId, + publicKey, + receiverId, + nonce, + actions, + blockHash + ) + } + check_key( args: { public_key: PublicKey @@ -281,6 +349,15 @@ export class Contract { options ) } + get_cheddar_storage_balance(account_id: string): Promise { + return this.account.viewFunction( + "token-v3.cheddar.testnet", + "storage_balance_of", + { + account_id, + } + ) + } cost_per_token( args: { minter: AccountId diff --git a/src/near/index.ts b/src/near/index.ts index 680cbd1..7a3ba74 100644 --- a/src/near/index.ts +++ b/src/near/index.ts @@ -8,7 +8,7 @@ import { Buffer } from "buffer" if (typeof window !== "undefined") window.Buffer = Buffer if (typeof global !== "undefined") global.Buffer = Buffer -const nearConfig = /near$/.test(contractName) +export const nearConfig = /near$/.test(contractName) ? { networkId: "mainnet", nodeUrl: "https://rpc.mainnet.near.org", @@ -35,9 +35,10 @@ if (!nearConfig) { */ export const near = new naj.Near({ ...nearConfig, - keyStore: typeof window === "undefined" - ? new naj.keyStores.InMemoryKeyStore() - : new naj.keyStores.BrowserLocalStorageKeyStore() + keyStore: + typeof window === "undefined" + ? new naj.keyStores.InMemoryKeyStore() + : new naj.keyStores.BrowserLocalStorageKeyStore(), }) /** @@ -47,4 +48,4 @@ export const wallet = new naj.WalletConnection(near) export function signIn() { wallet.requestSignIn({ contractId: settings.contractName }) -} \ No newline at end of file +} diff --git a/stale-data-from-build-time.json b/stale-data-from-build-time.json index ffda819..37472f5 100644 --- a/stale-data-from-build-time.json +++ b/stale-data-from-build-time.json @@ -1 +1 @@ -{"saleInfo":{"status":"Open","presale_start":1654533037000,"sale_start":1654533937000,"token_final_supply":200,"price":"14000000000000000000000000"},"contractMetadata":{"spec":"nft-1.0.0","name":"Cheddar","symbol":"Cheddar","icon":"","base_uri":"https://bafybeibghcllcmurku7lxyg4wgxn2zsu5qqk7h4r6bmyhpztmyd564cx54.ipfs.nftstorage.link","reference":null,"reference_hash":null},"tokensLeft":187,"vip":false,"nfts":[],"mintRateLimit":10} \ No newline at end of file +{"saleInfo":{"status":"Open","presale_start":1654533037000,"sale_start":1654533937000,"token_final_supply":200,"price":"15000000000000000000000000"},"contractMetadata":{"spec":"nft-1.0.0","name":"Cheddar","symbol":"Cheddar","icon":"","base_uri":"https://bafybeibghcllcmurku7lxyg4wgxn2zsu5qqk7h4r6bmyhpztmyd564cx54.ipfs.nftstorage.link","reference":null,"reference_hash":null},"tokensLeft":184,"vip":false,"nfts":[],"mintRateLimit":10} \ No newline at end of file