diff --git a/public/locales/en/message_contents.json b/public/locales/en/message_contents.json index e560817a9f..9f2aaa2a84 100644 --- a/public/locales/en/message_contents.json +++ b/public/locales/en/message_contents.json @@ -62,5 +62,20 @@ "txMigrateContract": "<0>{{admin}} migrated contract <1>{{contract}} to <1>{{newCodeId}}", "txUpdateContractAdmin": "<0>{{admin}} updated contract <1>{{contract}} admin to <2>{{newAdmin}}", "txClearContractAdmin": "<0>{{admin}} cleared admin on contract <1>{{contract}}", - "MsgSendToCosmosClaim": "<0>{{ethSender}} sent <1>{{amount}} to <2>{{receiver}}" + "MsgSendToCosmosClaim": "<0>{{ethSender}} sent <1>{{amount}} to <2>{{receiver}}", + "txCreateAddress": "<0>{{creator}} created an addressbook record with the following details - <1>", + "txUpdateAddress": "<0>{{creator}} updated an addressbook record. New details - <1>", + "txDeleteAddress": "<0>{{creator}} deleted the following addressbook record - <1>", + "txCreateCollection": "<0>{{creator}} created '<3>{{collectionId}}' collection. <1><2>", + "txPublishCollection": "<0>{{creator}} published '<3>{{collectionId}}' collection. <1><2>", + "txUpdateRoyalties": "<0>{{creator}} updated royalties for collection with ID: '<3>{{collectionId}}' <1><2>", + "txVerifyCollection": "Marketplace admin: <1>{{admin}} verified collection with ID: <2>{{collectionId}} created by: <0>{{creator}}", + "txUnverifyCollection": "Marketplace admin: <1>{{admin}} unverified collection with ID: <2>{{collectionId}} created by: <0>{{creator}}", + "txAddAdmin": "<0>{{creator}} added <1>{{address}} as marketplace admin", + "txRemoveAdmin": "<0>{{creator}} removed <1>{{address}} from marketplace admins", + "txMintNft": "<0>{{creator}} minted an NFT to <1>{{recipient}} <2>", + "txPublishNft": "<0>{{creator}} published for sale NFT with ID: <3>{{tokenId}} from collection ID: <2>{{denomId}} for <1>{{price}}", + "txRemoveNft": "<0>{{creator}} removed from sale NFT with ID: <1>{{id}}", + "txUpdatePrice": "<0>{{creator}} updated the price of NFT with ID: <2>{{id}}. New price: <1>{{price}}", + "txBuyNft": "<0>{{buyer}} purchased NFT with ID: <3>{{id}} from <1>{{seller}} for <2>{{price}}" } diff --git a/public/locales/en/message_labels.json b/public/locales/en/message_labels.json index 3aabfccb9e..671f44b8bc 100644 --- a/public/locales/en/message_labels.json +++ b/public/locales/en/message_labels.json @@ -63,5 +63,20 @@ "txMigrateContract": "Migrate Contract", "txUpdateContractAdmin": "Update Contract Admin", "txClearContractAdmin": "Clear Contract Admin", - "MsgSendToCosmosClaim": "Gravity Bridge - Ethereum to Cosmos" + "MsgSendToCosmosClaim": "Gravity Bridge - Ethereum to Cosmos", + "txCreateAddress": "New Address Book Record", + "txUpdateAddress": "Update Address Book Record", + "txDeleteAddress": "Delete Address Book Record", + "txCreateCollection": "Create NFT Collection", + "txPublishCollection": "Publish NFT Collection", + "txUpdateRoyalties": "Update NFT Collection Royalties", + "txVerifyCollection": "Verify NFT Collection", + "txUnverifyCollection": "Unverify NFT Collection", + "txAddAdmin": "Add Marketplace Admin", + "txRemoveAdmin": "Remove Marketplace Admin", + "txMintNft": "Mint NFT", + "txPublishNft": "Publish NFT for sale", + "txRemoveNft": "Remove NFT from sale", + "txUpdatePrice": "Update NFT price", + "txBuyNft": "Buy NFT" } diff --git a/src/components/addressbook_details/index.tsx b/src/components/addressbook_details/index.tsx new file mode 100644 index 0000000000..198907d0a2 --- /dev/null +++ b/src/components/addressbook_details/index.tsx @@ -0,0 +1,15 @@ +import React from 'react'; +import { AddressBookDetailsValue } from '@src/models/msg/types'; +import StyledTypographyPair from '../styled_typography_pair'; + +const AddressBookDetails = ({ content }: { content: AddressBookDetailsValue }) => { + return ( + <> + {content.network ? : null} + {content.label ? : null} + {content.value ? : null} + + ); +}; + +export default AddressBookDetails; diff --git a/src/components/addressbook_details/styles.ts b/src/components/addressbook_details/styles.ts new file mode 100644 index 0000000000..75846cc193 --- /dev/null +++ b/src/components/addressbook_details/styles.ts @@ -0,0 +1,5 @@ +export const addressBookDetails = { + gap: '10px', + width: '100%', + display: 'flex', +}; diff --git a/src/components/index.ts b/src/components/index.ts index 9f8a8ff1ef..e48fa64ee5 100644 --- a/src/components/index.ts +++ b/src/components/index.ts @@ -33,6 +33,9 @@ import AvatarNameListMsg from './avatar_name_list_msg'; import { ContractOverview, ContractMessages, ContractMessagesList, SingleContractMessageMobile, } from './cosmwasm'; +import AddressBookDetails from './addressbook_details'; +import RoyaltiesDetails from './royalties_details'; +import NftDetails from './nft_details'; export { Layout, @@ -71,4 +74,7 @@ export { ContractMessages, ContractMessagesList, SingleContractMessageMobile, + AddressBookDetails, + RoyaltiesDetails, + NftDetails, }; diff --git a/src/components/msg/addressbook/create_address/__snapshots__/index.test.tsx.snap b/src/components/msg/addressbook/create_address/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..8b8e0baa8f --- /dev/null +++ b/src/components/msg/addressbook/create_address/__snapshots__/index.test.tsx.snap @@ -0,0 +1,9 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgCreateAddress matches snapshot 1`] = ` +

+ message_contents:txCreateAddress +

+`; diff --git a/src/components/msg/addressbook/create_address/index.test.tsx b/src/components/msg/addressbook/create_address/index.test.tsx new file mode 100644 index 0000000000..53396d6256 --- /dev/null +++ b/src/components/msg/addressbook/create_address/index.test.tsx @@ -0,0 +1,45 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgCreateAddress } from '@models'; +import CreateAddress from '.'; + +// ================================== +// mocks +// ================================== + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgCreateAddress', () => { + it('matches snapshot', () => { + const message = new MsgCreateAddress({ + category: 'addressbook', + type: 'MsgCreateAddress', + creator: 'creatorAddress', + network: 'testNetwork', + label: 'testLabel', + value: 'testValue', + }); + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/addressbook/create_address/index.tsx b/src/components/msg/addressbook/create_address/index.tsx new file mode 100644 index 0000000000..42514e8261 --- /dev/null +++ b/src/components/msg/addressbook/create_address/index.tsx @@ -0,0 +1,42 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { + Name, + AddressBookDetails, +} from '@components'; +import { MsgCreateAddress } from '@models'; + +const CreateAddress = (props: { + message: MsgCreateAddress; +}) => { + const { message } = props; + const { creator } = message; + + return ( + + + ), + ( + + ), + ]} + /> + + ); +}; + +export default CreateAddress; diff --git a/src/components/msg/addressbook/delete_address/__snapshots__/index.test.tsx.snap b/src/components/msg/addressbook/delete_address/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..e1daae7767 --- /dev/null +++ b/src/components/msg/addressbook/delete_address/__snapshots__/index.test.tsx.snap @@ -0,0 +1,9 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgDeleteAddress matches snapshot 1`] = ` +

+ message_contents:txDeleteAddress +

+`; diff --git a/src/components/msg/addressbook/delete_address/index.test.tsx b/src/components/msg/addressbook/delete_address/index.test.tsx new file mode 100644 index 0000000000..929f37277a --- /dev/null +++ b/src/components/msg/addressbook/delete_address/index.test.tsx @@ -0,0 +1,45 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgDeleteAddress } from '@models'; +import CreateAddress from '.'; + +// ================================== +// mocks +// ================================== + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgDeleteAddress', () => { + it('matches snapshot', () => { + const message = new MsgDeleteAddress({ + category: 'addressbook', + type: 'MsgDeleteAddress', + creator: 'creatorAddress', + network: 'testNetwork', + label: 'testLabel', + value: 'testValue', + }); + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/addressbook/delete_address/index.tsx b/src/components/msg/addressbook/delete_address/index.tsx new file mode 100644 index 0000000000..c193189a7a --- /dev/null +++ b/src/components/msg/addressbook/delete_address/index.tsx @@ -0,0 +1,42 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { + Name, + AddressBookDetails, +} from '@components'; +import { MsgDeleteAddress } from '@models'; + +const DeleteAddress = (props: { + message: MsgDeleteAddress; +}) => { + const { message } = props; + const { creator } = message; + + return ( + + + ), + ( + + ), + ]} + /> + + ); +}; + +export default DeleteAddress; diff --git a/src/components/msg/addressbook/update_address/__snapshots__/index.test.tsx.snap b/src/components/msg/addressbook/update_address/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..05d11518cc --- /dev/null +++ b/src/components/msg/addressbook/update_address/__snapshots__/index.test.tsx.snap @@ -0,0 +1,9 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgUpdateAddress matches snapshot 1`] = ` +

+ message_contents:txUpdateAddress +

+`; diff --git a/src/components/msg/addressbook/update_address/index.test.tsx b/src/components/msg/addressbook/update_address/index.test.tsx new file mode 100644 index 0000000000..b12a4f1a7f --- /dev/null +++ b/src/components/msg/addressbook/update_address/index.test.tsx @@ -0,0 +1,45 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgUpdateAddress } from '@models'; +import CreateAddress from '.'; + +// ================================== +// mocks +// ================================== + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgUpdateAddress', () => { + it('matches snapshot', () => { + const message = new MsgUpdateAddress({ + category: 'addressbook', + type: 'MsgUpdateAddress', + creator: 'creatorAddress', + network: 'testNetwork', + label: 'testLabel', + value: 'testValue', + }); + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/addressbook/update_address/index.tsx b/src/components/msg/addressbook/update_address/index.tsx new file mode 100644 index 0000000000..97eda83578 --- /dev/null +++ b/src/components/msg/addressbook/update_address/index.tsx @@ -0,0 +1,42 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { + Name, + AddressBookDetails, +} from '@components'; +import { MsgUpdateAddress } from '@models'; + +const UpdateAddress = (props: { + message: MsgUpdateAddress; +}) => { + const { message } = props; + const { creator } = message; + + return ( + + + ), + ( + + ), + ]} + /> + + ); +}; + +export default UpdateAddress; diff --git a/src/components/msg/index.ts b/src/components/msg/index.ts index d4c6083eee..ce443b0dce 100644 --- a/src/components/msg/index.ts +++ b/src/components/msg/index.ts @@ -79,6 +79,21 @@ import MigrateContract from './cosmwasm/migrate_contract'; import UpdateContractAdmin from './cosmwasm/update_contract_admin'; import ClearContractAdmin from './cosmwasm/clear_contract_admin'; import SendToCosmos from './gravity/send_to_cosmos'; +import CreateAddress from './addressbook/create_address'; +import UpdateAddress from './addressbook/update_address'; +import DeleteAddress from './addressbook/delete_address'; +import CreateCollection from './marketplace/create_collection'; +import PublishCollection from './marketplace/publish_collection'; +import VerifyCollection from './marketplace/verify_collection'; +import UnverifyCollection from './marketplace/unverify_collection'; +import AddAdmin from './marketplace/add_admin'; +import MintNft from './marketplace/mint_nft'; +import PublishNft from './marketplace/publish_nft'; +import RemoveNft from './marketplace/remove_nft'; +import UpdatePrice from './marketplace/update_price'; +import UpdateRoyalties from './marketplace/update_royalties'; +import BuyNft from './marketplace/buy_nft'; +import RemoveAdmin from './marketplace/remove_admin'; export { getMessageModelByType, @@ -153,4 +168,19 @@ export { UpdateContractAdmin, ClearContractAdmin, SendToCosmos, + CreateAddress, + UpdateAddress, + DeleteAddress, + CreateCollection, + PublishCollection, + VerifyCollection, + UnverifyCollection, + AddAdmin, + MintNft, + PublishNft, + RemoveNft, + UpdatePrice, + UpdateRoyalties, + BuyNft, + RemoveAdmin, }; diff --git a/src/components/msg/marketplace/add_admin/__snapshots__/index.test.tsx.snap b/src/components/msg/marketplace/add_admin/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..750d13680f --- /dev/null +++ b/src/components/msg/marketplace/add_admin/__snapshots__/index.test.tsx.snap @@ -0,0 +1,24 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgAddAdmin matches snapshot 1`] = ` +

+

, + , + ] + } + i18nKey="message_contents:txAddAdmin" + id="message_contents:txAddAdmin" + /> +

+`; diff --git a/src/components/msg/marketplace/add_admin/index.test.tsx b/src/components/msg/marketplace/add_admin/index.test.tsx new file mode 100644 index 0000000000..443baaf25f --- /dev/null +++ b/src/components/msg/marketplace/add_admin/index.test.tsx @@ -0,0 +1,44 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgAddAdmin } from '@models'; +import AddAdmin from '.'; + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +jest.mock('next-translate/Trans', () => ( + (props) =>
+)); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgAddAdmin', () => { + it('matches snapshot', () => { + const message = new MsgAddAdmin({ + category: 'marketplace', + type: 'MsgAddAdmin', + creator: 'creator', + address: 'address', + }); + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + expect(component.root.findByProps({ id: 'message_contents:txAddAdmin' }).props.i18nKey).toEqual('message_contents:txAddAdmin'); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/marketplace/add_admin/index.tsx b/src/components/msg/marketplace/add_admin/index.tsx new file mode 100644 index 0000000000..a7c0f59bc6 --- /dev/null +++ b/src/components/msg/marketplace/add_admin/index.tsx @@ -0,0 +1,40 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { + Name, +} from '@components'; +import { MsgAddAdmin } from '@models'; + +const AddAdmin = (props: { + message: MsgAddAdmin; +}) => { + const { message } = props; + const { + creator, address, + } = message; + + return ( + + + ), + ( + + ), + ]} + /> + + ); +}; + +export default AddAdmin; diff --git a/src/components/msg/marketplace/buy_nft/__snapshots__/index.test.tsx.snap b/src/components/msg/marketplace/buy_nft/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..ff5f6c7a33 --- /dev/null +++ b/src/components/msg/marketplace/buy_nft/__snapshots__/index.test.tsx.snap @@ -0,0 +1,30 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgBuyNft matches snapshot 1`] = ` +

+

, + , + ] + } + i18nKey="message_contents:txBuyNft" + id="message_contents:txBuyNft" + values={ + Object { + "id": "id", + "price": "1 acudos", + } + } + /> +

+`; diff --git a/src/components/msg/marketplace/buy_nft/index.test.tsx b/src/components/msg/marketplace/buy_nft/index.test.tsx new file mode 100644 index 0000000000..a8a6aaa5dd --- /dev/null +++ b/src/components/msg/marketplace/buy_nft/index.test.tsx @@ -0,0 +1,48 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgBuyNft } from '@models'; +import { formatToken } from '@src/utils/format_token'; +import BuyNft from '.'; + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +jest.mock('next-translate/Trans', () => ( + (props) =>
+)); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgBuyNft', () => { + it('matches snapshot', () => { + const message = new MsgBuyNft({ + category: 'marketplace', + type: 'MsgBuyNft', + seller: 'seller', + buyer: 'buyer', + id: 'id', + price: formatToken('1', 'acudos'), + }); + + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + expect(component.root.findByProps({ id: 'message_contents:txBuyNft' }).props.i18nKey).toEqual('message_contents:txBuyNft'); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/marketplace/buy_nft/index.tsx b/src/components/msg/marketplace/buy_nft/index.tsx new file mode 100644 index 0000000000..187e3274d5 --- /dev/null +++ b/src/components/msg/marketplace/buy_nft/index.tsx @@ -0,0 +1,39 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { Name } from '@components'; +import { MsgBuyNft } from '@models'; + +const BuyNft = (props: { + message: MsgBuyNft; +}) => { + const { message } = props; + + return ( + + + ), + ( + + ), + ]} + values={{ + price: `${message.price.value} ${message.price.displayDenom}`, + id: message.id, + }} + /> + + ); +}; + +export default BuyNft; diff --git a/src/components/msg/marketplace/create_collection/__snapshots__/index.test.tsx.snap b/src/components/msg/marketplace/create_collection/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..4cd76e8bea --- /dev/null +++ b/src/components/msg/marketplace/create_collection/__snapshots__/index.test.tsx.snap @@ -0,0 +1,47 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgCreateCollection matches snapshot 1`] = ` +

+

, + , + , + ] + } + i18nKey="message_contents:txCreateCollection" + id="message_contents:txCreateCollection" + values={ + Object { + "collectionId": "collectionId", + } + } + /> +

+`; diff --git a/src/components/msg/marketplace/create_collection/index.test.tsx b/src/components/msg/marketplace/create_collection/index.test.tsx new file mode 100644 index 0000000000..655619eb51 --- /dev/null +++ b/src/components/msg/marketplace/create_collection/index.test.tsx @@ -0,0 +1,52 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgCreateCollection } from '@models'; +import CreateCollection from '.'; + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +jest.mock('next-translate/Trans', () => ( + (props) =>
+)); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgCreateCollection', () => { + it('matches snapshot', () => { + const message = new MsgCreateCollection({ + category: 'marketplace', + type: 'MsgCreateCollection', + creator: 'Creator', + collectionId: 'collectionId', + mintRoyalties: [{ + address: 'address', + percent: 'percent', + }], + resaleRoyalties: [{ + address: 'address', + percent: 'percent', + }], + }); + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + expect(component.root.findByProps({ id: 'message_contents:txCreateCollection' }).props.i18nKey).toEqual('message_contents:txCreateCollection'); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/marketplace/create_collection/index.tsx b/src/components/msg/marketplace/create_collection/index.tsx new file mode 100644 index 0000000000..1cefdb18fb --- /dev/null +++ b/src/components/msg/marketplace/create_collection/index.tsx @@ -0,0 +1,48 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { + Name, + RoyaltiesDetails, +} from '@components'; +import { MsgCreateCollection } from '@models'; + +const CreateCollection = (props: { + message: MsgCreateCollection; +}) => { + const { message } = props; + const { creator } = message; + + return ( + + + ), + ( + + ), + ( + + ), + ]} + values={{ + collectionId: message.collectionId, + }} + /> + + ); +}; + +export default CreateCollection; diff --git a/src/components/msg/marketplace/mint_nft/__snapshots__/index.test.tsx.snap b/src/components/msg/marketplace/mint_nft/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..158e542757 --- /dev/null +++ b/src/components/msg/marketplace/mint_nft/__snapshots__/index.test.tsx.snap @@ -0,0 +1,41 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgMintNft matches snapshot 1`] = ` +

+

, + , + , + ] + } + i18nKey="message_contents:txMintNft" + id="message_contents:txMintNft" + /> +

+`; diff --git a/src/components/msg/marketplace/mint_nft/index.test.tsx b/src/components/msg/marketplace/mint_nft/index.test.tsx new file mode 100644 index 0000000000..1020871087 --- /dev/null +++ b/src/components/msg/marketplace/mint_nft/index.test.tsx @@ -0,0 +1,53 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgMintNft } from '@models'; +import { formatToken } from '@src/utils/format_token'; +import MintNft from '.'; + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +jest.mock('next-translate/Trans', () => ( + (props) =>
+)); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgMintNft', () => { + it('matches snapshot', () => { + const message = new MsgMintNft({ + category: 'marketplace', + type: 'MsgMintNft', + creator: 'creator', + recipient: 'recipient', + mintedNftData: { + denomId: 'denomId', + uid: 'uid', + uri: 'uri', + data: 'data', + name: 'name', + price: formatToken('1', 'acudos'), + }, + }); + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + expect(component.root.findByProps({ id: 'message_contents:txMintNft' }).props.i18nKey).toEqual('message_contents:txMintNft'); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/marketplace/mint_nft/index.tsx b/src/components/msg/marketplace/mint_nft/index.tsx new file mode 100644 index 0000000000..866aab7593 --- /dev/null +++ b/src/components/msg/marketplace/mint_nft/index.tsx @@ -0,0 +1,46 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { + Name, + NftDetails, +} from '@components'; +import { MsgMintNft } from '@models'; + +const MintNft = (props: { + message: MsgMintNft; +}) => { + const { message } = props; + const { + creator, recipient, mintedNftData, + } = message; + + return ( + + + ), + ( + + ), + ( + + ), + ]} + /> + + ); +}; + +export default MintNft; diff --git a/src/components/msg/marketplace/publish_collection/__snapshots__/index.test.tsx.snap b/src/components/msg/marketplace/publish_collection/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..d55d930a8e --- /dev/null +++ b/src/components/msg/marketplace/publish_collection/__snapshots__/index.test.tsx.snap @@ -0,0 +1,47 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgPublishCollection matches snapshot 1`] = ` +

+

, + , + , + ] + } + i18nKey="message_contents:txPublishCollection" + id="message_contents:txPublishCollection" + values={ + Object { + "collectionId": "collectionId", + } + } + /> +

+`; diff --git a/src/components/msg/marketplace/publish_collection/index.test.tsx b/src/components/msg/marketplace/publish_collection/index.test.tsx new file mode 100644 index 0000000000..d3a8fd1813 --- /dev/null +++ b/src/components/msg/marketplace/publish_collection/index.test.tsx @@ -0,0 +1,52 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgPublishCollection } from '@models'; +import PublishCollection from '.'; + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +jest.mock('next-translate/Trans', () => ( + (props) =>
+)); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgPublishCollection', () => { + it('matches snapshot', () => { + const message = new MsgPublishCollection({ + category: 'marketplace', + type: 'MsgPublishCollection', + creator: 'Creator', + collectionId: 'collectionId', + mintRoyalties: [{ + address: 'address', + percent: 'percent', + }], + resaleRoyalties: [{ + address: 'address', + percent: 'percent', + }], + }); + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + expect(component.root.findByProps({ id: 'message_contents:txPublishCollection' }).props.i18nKey).toEqual('message_contents:txPublishCollection'); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/marketplace/publish_collection/index.tsx b/src/components/msg/marketplace/publish_collection/index.tsx new file mode 100644 index 0000000000..0288abcb57 --- /dev/null +++ b/src/components/msg/marketplace/publish_collection/index.tsx @@ -0,0 +1,48 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { + Name, + RoyaltiesDetails, +} from '@components'; +import { MsgPublishCollection } from '@models'; + +const PublishCollection = (props: { + message: MsgPublishCollection; +}) => { + const { message } = props; + const { creator } = message; + + return ( + + + ), + ( + + ), + ( + + ), + ]} + values={{ + collectionId: message.collectionId, + }} + /> + + ); +}; + +export default PublishCollection; diff --git a/src/components/msg/marketplace/publish_nft/__snapshots__/index.test.tsx.snap b/src/components/msg/marketplace/publish_nft/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..a0c352c529 --- /dev/null +++ b/src/components/msg/marketplace/publish_nft/__snapshots__/index.test.tsx.snap @@ -0,0 +1,27 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgPublishNft matches snapshot 1`] = ` +

+

, + ] + } + i18nKey="message_contents:txPublishNft" + id="message_contents:txPublishNft" + values={ + Object { + "denomId": "denomId", + "price": "1 acudos", + "tokenId": "tokenId", + } + } + /> +

+`; diff --git a/src/components/msg/marketplace/publish_nft/index.test.tsx b/src/components/msg/marketplace/publish_nft/index.test.tsx new file mode 100644 index 0000000000..ba577770ef --- /dev/null +++ b/src/components/msg/marketplace/publish_nft/index.test.tsx @@ -0,0 +1,48 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgPublishNft } from '@models'; +import { formatToken } from '@src/utils/format_token'; +import PublishNft from '.'; + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +jest.mock('next-translate/Trans', () => ( + (props) =>
+)); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgPublishNft', () => { + it('matches snapshot', () => { + const message = new MsgPublishNft({ + category: 'marketplace', + type: 'MsgPublishNft', + creator: 'creator', + denomId: 'denomId', + tokenId: 'tokenId', + price: formatToken('1', 'acudos'), + }); + + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + expect(component.root.findByProps({ id: 'message_contents:txPublishNft' }).props.i18nKey).toEqual('message_contents:txPublishNft'); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/marketplace/publish_nft/index.tsx b/src/components/msg/marketplace/publish_nft/index.tsx new file mode 100644 index 0000000000..e0b08fceae --- /dev/null +++ b/src/components/msg/marketplace/publish_nft/index.tsx @@ -0,0 +1,37 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { Name } from '@components'; +import { MsgPublishNft } from '@models'; + +const MintNft = (props: { + message: MsgPublishNft; +}) => { + const { message } = props; + const { + creator, price, denomId, tokenId, + } = message; + + return ( + + + ), + ]} + values={{ + price: `${price.value} ${price.displayDenom}`, + denomId, + tokenId, + }} + /> + + ); +}; + +export default MintNft; diff --git a/src/components/msg/marketplace/remove_admin/__snapshots__/index.test.tsx.snap b/src/components/msg/marketplace/remove_admin/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..252ce4c8ad --- /dev/null +++ b/src/components/msg/marketplace/remove_admin/__snapshots__/index.test.tsx.snap @@ -0,0 +1,24 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgRemoveAdmin matches snapshot 1`] = ` +

+

, + , + ] + } + i18nKey="message_contents:txRemoveAdmin" + id="message_contents:txRemoveAdmin" + /> +

+`; diff --git a/src/components/msg/marketplace/remove_admin/index.test.tsx b/src/components/msg/marketplace/remove_admin/index.test.tsx new file mode 100644 index 0000000000..80aef7c99d --- /dev/null +++ b/src/components/msg/marketplace/remove_admin/index.test.tsx @@ -0,0 +1,44 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgRemoveAdmin } from '@models'; +import RemoveAdmin from '.'; + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +jest.mock('next-translate/Trans', () => ( + (props) =>
+)); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgRemoveAdmin', () => { + it('matches snapshot', () => { + const message = new MsgRemoveAdmin({ + category: 'marketplace', + type: 'MsgRemoveAdmin', + creator: 'creator', + address: 'address', + }); + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + expect(component.root.findByProps({ id: 'message_contents:txRemoveAdmin' }).props.i18nKey).toEqual('message_contents:txRemoveAdmin'); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/marketplace/remove_admin/index.tsx b/src/components/msg/marketplace/remove_admin/index.tsx new file mode 100644 index 0000000000..e8ad53cb54 --- /dev/null +++ b/src/components/msg/marketplace/remove_admin/index.tsx @@ -0,0 +1,40 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { + Name, +} from '@components'; +import { MsgRemoveAdmin } from '@models'; + +const RemoveAdmin = (props: { + message: MsgRemoveAdmin; +}) => { + const { message } = props; + const { + creator, address, + } = message; + + return ( + + + ), + ( + + ), + ]} + /> + + ); +}; + +export default RemoveAdmin; diff --git a/src/components/msg/marketplace/remove_nft/__snapshots__/index.test.tsx.snap b/src/components/msg/marketplace/remove_nft/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..b291793bfd --- /dev/null +++ b/src/components/msg/marketplace/remove_nft/__snapshots__/index.test.tsx.snap @@ -0,0 +1,25 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgRemoveNft matches snapshot 1`] = ` +

+

, + ] + } + i18nKey="message_contents:txRemoveNft" + id="message_contents:txRemoveNft" + values={ + Object { + "id": "id", + } + } + /> +

+`; diff --git a/src/components/msg/marketplace/remove_nft/index.test.tsx b/src/components/msg/marketplace/remove_nft/index.test.tsx new file mode 100644 index 0000000000..b8fa8c87d9 --- /dev/null +++ b/src/components/msg/marketplace/remove_nft/index.test.tsx @@ -0,0 +1,45 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgRemoveNft } from '@models'; +import RemoveNft from '.'; + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +jest.mock('next-translate/Trans', () => ( + (props) =>
+)); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgRemoveNft', () => { + it('matches snapshot', () => { + const message = new MsgRemoveNft({ + category: 'marketplace', + type: 'MsgRemoveNft', + creator: 'creator', + id: 'id', + }); + + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + expect(component.root.findByProps({ id: 'message_contents:txRemoveNft' }).props.i18nKey).toEqual('message_contents:txRemoveNft'); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/marketplace/remove_nft/index.tsx b/src/components/msg/marketplace/remove_nft/index.tsx new file mode 100644 index 0000000000..b238e6f981 --- /dev/null +++ b/src/components/msg/marketplace/remove_nft/index.tsx @@ -0,0 +1,32 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { Name } from '@components'; +import { MsgRemoveNft } from '@models'; + +const RemoveNft = (props: { + message: MsgRemoveNft; +}) => { + const { message } = props; + + return ( + + + ), + ]} + values={{ + id: message.id, + }} + /> + + ); +}; + +export default RemoveNft; diff --git a/src/components/msg/marketplace/unverify_collection/__snapshots__/index.test.tsx.snap b/src/components/msg/marketplace/unverify_collection/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..ce887f8cc0 --- /dev/null +++ b/src/components/msg/marketplace/unverify_collection/__snapshots__/index.test.tsx.snap @@ -0,0 +1,29 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgUnverifyCollection matches snapshot 1`] = ` +

+

, + , + ] + } + i18nKey="message_contents:txUnverifyCollection" + id="message_contents:txUnverifyCollection" + values={ + Object { + "collectionId": "collectionId", + } + } + /> +

+`; diff --git a/src/components/msg/marketplace/unverify_collection/index.test.tsx b/src/components/msg/marketplace/unverify_collection/index.test.tsx new file mode 100644 index 0000000000..1a999b7be9 --- /dev/null +++ b/src/components/msg/marketplace/unverify_collection/index.test.tsx @@ -0,0 +1,45 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgUnverifyCollection } from '@models'; +import UnverifyCollection from '.'; + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +jest.mock('next-translate/Trans', () => ( + (props) =>
+)); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgUnverifyCollection', () => { + it('matches snapshot', () => { + const message = new MsgUnverifyCollection({ + category: 'marketplace', + type: 'MsgUnverifyCollection', + creator: 'Creator', + collectionId: 'collectionId', + admin: 'admin', + }); + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + expect(component.root.findByProps({ id: 'message_contents:txUnverifyCollection' }).props.i18nKey).toEqual('message_contents:txUnverifyCollection'); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/marketplace/unverify_collection/index.tsx b/src/components/msg/marketplace/unverify_collection/index.tsx new file mode 100644 index 0000000000..0713ffeb97 --- /dev/null +++ b/src/components/msg/marketplace/unverify_collection/index.tsx @@ -0,0 +1,43 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { + Name, +} from '@components'; +import { MsgUnverifyCollection } from '@models'; + +const UnverifyCollection = (props: { + message: MsgUnverifyCollection; +}) => { + const { message } = props; + const { + creator, admin, + } = message; + + return ( + + + ), + ( + + ), + ]} + values={{ + collectionId: message.collectionId, + }} + /> + + ); +}; + +export default UnverifyCollection; diff --git a/src/components/msg/marketplace/update_price/__snapshots__/index.test.tsx.snap b/src/components/msg/marketplace/update_price/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..03f3f31869 --- /dev/null +++ b/src/components/msg/marketplace/update_price/__snapshots__/index.test.tsx.snap @@ -0,0 +1,26 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgUpdatePrice matches snapshot 1`] = ` +

+

, + ] + } + i18nKey="message_contents:txUpdatePrice" + id="message_contents:txUpdatePrice" + values={ + Object { + "id": "id", + "price": "1 acudos", + } + } + /> +

+`; diff --git a/src/components/msg/marketplace/update_price/index.test.tsx b/src/components/msg/marketplace/update_price/index.test.tsx new file mode 100644 index 0000000000..186cb3777c --- /dev/null +++ b/src/components/msg/marketplace/update_price/index.test.tsx @@ -0,0 +1,47 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgUpdatePrice } from '@models'; +import { formatToken } from '@src/utils/format_token'; +import UpdatePrice from '.'; + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +jest.mock('next-translate/Trans', () => ( + (props) =>
+)); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgUpdatePrice', () => { + it('matches snapshot', () => { + const message = new MsgUpdatePrice({ + category: 'marketplace', + type: 'MsgUpdatePrice', + creator: 'creator', + id: 'id', + price: formatToken('1', 'acudos'), + }); + + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + expect(component.root.findByProps({ id: 'message_contents:txUpdatePrice' }).props.i18nKey).toEqual('message_contents:txUpdatePrice'); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/marketplace/update_price/index.tsx b/src/components/msg/marketplace/update_price/index.tsx new file mode 100644 index 0000000000..06888c23c6 --- /dev/null +++ b/src/components/msg/marketplace/update_price/index.tsx @@ -0,0 +1,33 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { Name } from '@components'; +import { MsgUpdatePrice } from '@models'; + +const UpdatePrice = (props: { + message: MsgUpdatePrice; +}) => { + const { message } = props; + + return ( + + + ), + ]} + values={{ + price: `${message.price.value} ${message.price.displayDenom}`, + id: message.id, + }} + /> + + ); +}; + +export default UpdatePrice; diff --git a/src/components/msg/marketplace/update_royalties/__snapshots__/index.test.tsx.snap b/src/components/msg/marketplace/update_royalties/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..f7cbedaa9e --- /dev/null +++ b/src/components/msg/marketplace/update_royalties/__snapshots__/index.test.tsx.snap @@ -0,0 +1,47 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgPublishCollection matches snapshot 1`] = ` +

+

, + , + , + ] + } + i18nKey="message_contents:txUpdateRoyalties" + id="message_contents:txUpdateRoyalties" + values={ + Object { + "collectionId": "collectionId", + } + } + /> +

+`; diff --git a/src/components/msg/marketplace/update_royalties/index.test.tsx b/src/components/msg/marketplace/update_royalties/index.test.tsx new file mode 100644 index 0000000000..0feee59c13 --- /dev/null +++ b/src/components/msg/marketplace/update_royalties/index.test.tsx @@ -0,0 +1,52 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgUpdateRoyalties } from '@models'; +import UpdateRoyalties from '.'; + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +jest.mock('next-translate/Trans', () => ( + (props) =>
+)); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgPublishCollection', () => { + it('matches snapshot', () => { + const message = new MsgUpdateRoyalties({ + category: 'marketplace', + type: 'MsgUpdateRoyalties', + creator: 'Creator', + collectionId: 'collectionId', + mintRoyalties: [{ + address: 'address', + percent: 'percent', + }], + resaleRoyalties: [{ + address: 'address', + percent: 'percent', + }], + }); + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + expect(component.root.findByProps({ id: 'message_contents:txUpdateRoyalties' }).props.i18nKey).toEqual('message_contents:txUpdateRoyalties'); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/marketplace/update_royalties/index.tsx b/src/components/msg/marketplace/update_royalties/index.tsx new file mode 100644 index 0000000000..7f6083b68e --- /dev/null +++ b/src/components/msg/marketplace/update_royalties/index.tsx @@ -0,0 +1,48 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { + Name, + RoyaltiesDetails, +} from '@components'; +import { MsgUpdateRoyalties } from '@models'; + +const UpdateRoyalties = (props: { + message: MsgUpdateRoyalties; +}) => { + const { message } = props; + const { creator } = message; + + return ( + + + ), + ( + + ), + ( + + ), + ]} + values={{ + collectionId: message.collectionId, + }} + /> + + ); +}; + +export default UpdateRoyalties; diff --git a/src/components/msg/marketplace/verify_collection/__snapshots__/index.test.tsx.snap b/src/components/msg/marketplace/verify_collection/__snapshots__/index.test.tsx.snap new file mode 100644 index 0000000000..022e14859b --- /dev/null +++ b/src/components/msg/marketplace/verify_collection/__snapshots__/index.test.tsx.snap @@ -0,0 +1,29 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`screen: TransactionDetails/MsgVerifyCollection matches snapshot 1`] = ` +

+

, + , + ] + } + i18nKey="message_contents:txVerifyCollection" + id="message_contents:txVerifyCollection" + values={ + Object { + "collectionId": "collectionId", + } + } + /> +

+`; diff --git a/src/components/msg/marketplace/verify_collection/index.test.tsx b/src/components/msg/marketplace/verify_collection/index.test.tsx new file mode 100644 index 0000000000..154ca91490 --- /dev/null +++ b/src/components/msg/marketplace/verify_collection/index.test.tsx @@ -0,0 +1,45 @@ +import React from 'react'; +import { RecoilRoot } from 'recoil'; +import renderer from 'react-test-renderer'; +import { MockTheme } from '@tests/utils'; +import { MsgVerifyCollection } from '@models'; +import VerifyCollection from '.'; + +jest.mock('@components', () => ({ + Name: (props) =>
, +})); + +jest.mock('next-translate/Trans', () => ( + (props) =>
+)); + +// ================================== +// unit tests +// ================================== +describe('screen: TransactionDetails/MsgVerifyCollection', () => { + it('matches snapshot', () => { + const message = new MsgVerifyCollection({ + category: 'marketplace', + type: 'MsgVerifyCollection', + creator: 'Creator', + collectionId: 'collectionId', + admin: 'admin', + }); + const component = renderer.create( + + + + + , + ); + const tree = component.toJSON(); + expect(tree).toMatchSnapshot(); + expect(component.root.findByProps({ id: 'message_contents:txVerifyCollection' }).props.i18nKey).toEqual('message_contents:txVerifyCollection'); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); +}); diff --git a/src/components/msg/marketplace/verify_collection/index.tsx b/src/components/msg/marketplace/verify_collection/index.tsx new file mode 100644 index 0000000000..3c47712bf1 --- /dev/null +++ b/src/components/msg/marketplace/verify_collection/index.tsx @@ -0,0 +1,43 @@ +import React from 'react'; +import Trans from 'next-translate/Trans'; +import { Typography } from '@material-ui/core'; +import { + Name, +} from '@components'; +import { MsgVerifyCollection } from '@models'; + +const VerifyCollection = (props: { + message: MsgVerifyCollection; +}) => { + const { message } = props; + const { + creator, admin, + } = message; + + return ( + + + ), + ( + + ), + ]} + values={{ + collectionId: message.collectionId, + }} + /> + + ); +}; + +export default VerifyCollection; diff --git a/src/components/msg/utils.tsx b/src/components/msg/utils.tsx index e65cd20b7a..06df13c3b0 100644 --- a/src/components/msg/utils.tsx +++ b/src/components/msg/utils.tsx @@ -456,6 +456,102 @@ const getDataByType = (type: string) => { tagTheme: 'four', tagDisplay: 'MsgSendToCosmosClaim', }, + // ======================== + // Addressbook + // ======================== + '/cudoventures.cudosnode.addressbook.MsgCreateAddress': { + model: MODELS.MsgCreateAddress, + content: COMPONENTS.CreateAddress, + tagTheme: 'twentyOne', + tagDisplay: 'txCreateAddress', + }, + '/cudoventures.cudosnode.addressbook.MsgUpdateAddress': { + model: MODELS.MsgUpdateAddress, + content: COMPONENTS.UpdateAddress, + tagTheme: 'twentyOne', + tagDisplay: 'txUpdateAddress', + }, + '/cudoventures.cudosnode.addressbook.MsgDeleteAddress': { + model: MODELS.MsgDeleteAddress, + content: COMPONENTS.DeleteAddress, + tagTheme: 'twentyOne', + tagDisplay: 'txCreateCollection', + }, + // ======================== + // Marketplace + // ======================== + '/cudoventures.cudosnode.marketplace.MsgCreateCollection': { + model: MODELS.MsgCreateCollection, + content: COMPONENTS.CreateCollection, + tagTheme: 'twentyTwo', + tagDisplay: 'txCreateCollection', + }, + '/cudoventures.cudosnode.marketplace.MsgPublishCollection': { + model: MODELS.MsgPublishCollection, + content: COMPONENTS.PublishCollection, + tagTheme: 'twentyTwo', + tagDisplay: 'txPublishCollection', + }, + '/cudoventures.cudosnode.marketplace.MsgVerifyCollection': { + model: MODELS.MsgVerifyCollection, + content: COMPONENTS.VerifyCollection, + tagTheme: 'twentyTwo', + tagDisplay: 'txPublishCollection', + }, + '/cudoventures.cudosnode.marketplace.MsgUnverifyCollection': { + model: MODELS.MsgUnverifyCollection, + content: COMPONENTS.UnverifyCollection, + tagTheme: 'twentyTwo', + tagDisplay: 'txUnverifyCollection', + }, + '/cudoventures.cudosnode.marketplace.MsgAddAdmin': { + model: MODELS.MsgAddAdmin, + content: COMPONENTS.AddAdmin, + tagTheme: 'twentyTwo', + tagDisplay: 'txAddAdmin', + }, + '/cudoventures.cudosnode.marketplace.MsgMintNft': { + model: MODELS.MsgMintNft, + content: COMPONENTS.MintNft, + tagTheme: 'twentyTwo', + tagDisplay: 'txMintNft', + }, + '/cudoventures.cudosnode.marketplace.MsgPublishNft': { + model: MODELS.MsgPublishNft, + content: COMPONENTS.PublishNft, + tagTheme: 'twentyTwo', + tagDisplay: 'txPublishNft', + }, + '/cudoventures.cudosnode.marketplace.MsgRemoveNft': { + model: MODELS.MsgRemoveNft, + content: COMPONENTS.RemoveNft, + tagTheme: 'twentyTwo', + tagDisplay: 'txRemoveNft', + }, + '/cudoventures.cudosnode.marketplace.MsgUpdatePrice': { + model: MODELS.MsgUpdatePrice, + content: COMPONENTS.UpdatePrice, + tagTheme: 'twentyTwo', + tagDisplay: 'txUpdatePrice', + }, + '/cudoventures.cudosnode.marketplace.MsgUpdateRoyalties': { + model: MODELS.MsgUpdateRoyalties, + content: COMPONENTS.UpdateRoyalties, + tagTheme: 'twentyTwo', + tagDisplay: 'txUpdateRoyalties', + }, + '/cudoventures.cudosnode.marketplace.MsgBuyNft': { + model: MODELS.MsgBuyNft, + content: COMPONENTS.BuyNft, + tagTheme: 'twentyTwo', + tagDisplay: 'txBuyNft', + }, + '/cudoventures.cudosnode.marketplace.MsgRemoveAdmin': { + model: MODELS.MsgRemoveAdmin, + content: COMPONENTS.RemoveAdmin, + tagTheme: 'twentyTwo', + tagDisplay: 'txRemoveAdmin', + }, }; if (defaultTypeToModel[type]) return defaultTypeToModel[type]; @@ -480,7 +576,7 @@ export const getMessageModelByType = (type: string) => { * Helper function to correctly display the correct UI * @param type Model type */ -export const getMessageByType = (message: any, viewRaw: boolean, t:any) => { +export const getMessageByType = (message: any, viewRaw: boolean, t: any) => { const { type } = message; let results: { content: any; @@ -522,7 +618,10 @@ export const convertMsgsToModels = (transaction: any) => { const model = getMessageModelByType(msg?.['@type']); if (model === MODELS.MsgWithdrawDelegatorReward || model === MODELS.MsgWithdrawValidatorCommission - || model === MODELS.MsgInstantiateContract) { + || model === MODELS.MsgInstantiateContract + || model === MODELS.MsgVerifyCollection + || model === MODELS.MsgUnverifyCollection + || model === MODELS.MsgBuyNft) { const log = R.pathOr(null, ['logs', i], transaction); return model.fromJson(msg, log); } diff --git a/src/components/nft_details/index.tsx b/src/components/nft_details/index.tsx new file mode 100644 index 0000000000..ab28eeb80f --- /dev/null +++ b/src/components/nft_details/index.tsx @@ -0,0 +1,21 @@ +import React from 'react'; +import { MintedNft } from '@src/models/msg/types'; +import { Typography } from '@material-ui/core'; +import StyledTypographyPair from '../styled_typography_pair'; +import { title } from '../styled_typography_pair/styles'; + +const NftDetails = ({ content }: { content: MintedNft }) => { + return ( + <> + NFT DETAILS + {content.denomId ? : null} + {content.name ? : null} + {content.price.value ? : null} + {content.uid ? : null} + {content.uri ? : null} + {content.data ? : null} + + ); +}; + +export default NftDetails; diff --git a/src/components/royalties_details/index.tsx b/src/components/royalties_details/index.tsx new file mode 100644 index 0000000000..e6168b3009 --- /dev/null +++ b/src/components/royalties_details/index.tsx @@ -0,0 +1,32 @@ +import React from 'react'; +import { + Typography, + Box, +} from '@material-ui/core'; +import { Royalties } from '@src/models/msg/types'; +import Name from '../name'; +import { + holder, title, +} from '../styled_typography_pair/styles'; + +const RoyaltiesDetails = ({ + type, royalties, +}: { type: 'Mint' | 'Resale', royalties: Royalties[] }) => { + return !royalties.length ? null : ( + <> + {`${type} Royalties`} + {royalties.map((royaltie) => { + return ( + + + + {`${parseFloat(royaltie.percent)} %`} + + + ); + })} + + ); +}; + +export default RoyaltiesDetails; diff --git a/src/components/styled_typography_pair/index.tsx b/src/components/styled_typography_pair/index.tsx new file mode 100644 index 0000000000..58cc3e9d6b --- /dev/null +++ b/src/components/styled_typography_pair/index.tsx @@ -0,0 +1,26 @@ +import { + Typography, + Box, +} from '@material-ui/core'; +import { holder } from './styles'; + +const StyledTypographyPair = ({ + text, + content, +}: { + text: string, + content: string +}) => { + return ( + + + {text} + + + {content} + + + ); +}; + +export default StyledTypographyPair; diff --git a/src/components/styled_typography_pair/styles.ts b/src/components/styled_typography_pair/styles.ts new file mode 100644 index 0000000000..31d246fc23 --- /dev/null +++ b/src/components/styled_typography_pair/styles.ts @@ -0,0 +1,10 @@ +export const holder = { + gap: '10px', + width: '100%', + display: 'flex', +}; + +export const title = { + marginTop: '10px', + fontWeight: 900, +}; diff --git a/src/components/tag/styles.tsx b/src/components/tag/styles.tsx index 210abe621c..71619d3718 100644 --- a/src/components/tag/styles.tsx +++ b/src/components/tag/styles.tsx @@ -102,6 +102,14 @@ export const useStyles = () => { color: theme.palette.custom.tags.twenty, background: Color(theme.palette.custom.tags.twenty).alpha(0.2).string(), }, + twentyOne: { + color: theme.palette.custom.tags.twentyOne, + background: Color(theme.palette.custom.tags.twentyOne).alpha(0.2).string(), + }, + twentyTwo: { + color: theme.palette.custom.tags.twentyTwo, + background: Color(theme.palette.custom.tags.twentyTwo).alpha(0.2).string(), + }, }); }, )(); diff --git a/src/models/index.ts b/src/models/index.ts index a847a7a2de..dcd5c69c9d 100644 --- a/src/models/index.ts +++ b/src/models/index.ts @@ -76,6 +76,21 @@ import MsgMigrateContract from './msg/cosmwasm/msg_migrate_contract'; import MsgUpdateContractAdmin from './msg/cosmwasm/msg_update_contract_admin'; import MsgClearContractAdmin from './msg/cosmwasm/msg_clear_contract_admin'; import MsgSendToCosmosClaim from './msg/gravity/msg_send_to_cosmos_claim'; +import MsgCreateAddress from './msg/addressbook/msg_create_address'; +import MsgUpdateAddress from './msg/addressbook/msg_update_address'; +import MsgDeleteAddress from './msg/addressbook/msg_delete_address'; +import MsgCreateCollection from './msg/marketplace/msg_create_collection'; +import MsgPublishCollection from './msg/marketplace/msg_publish_collection'; +import MsgVerifyCollection from './msg/marketplace/msg_verify_collection'; +import MsgUnverifyCollection from './msg/marketplace/msg_unverify_collection'; +import MsgAddAdmin from './msg/marketplace/msg_add_admin'; +import MsgMintNft from './msg/marketplace/msg_mint_nft'; +import MsgPublishNft from './msg/marketplace/msg_publish_nft'; +import MsgRemoveNft from './msg/marketplace/msg_remove_nft'; +import MsgUpdatePrice from './msg/marketplace/msg_update_price'; +import MsgUpdateRoyalties from './msg/marketplace/msg_update_royalties'; +import MsgBuyNft from './msg/marketplace/msg_buy_nft'; +import MsgRemoveAdmin from './msg/marketplace/msg_remove_admin'; export { BigDipperNetwork, @@ -156,4 +171,19 @@ export { MsgUpdateContractAdmin, MsgClearContractAdmin, MsgSendToCosmosClaim, + MsgCreateAddress, + MsgUpdateAddress, + MsgDeleteAddress, + MsgCreateCollection, + MsgPublishCollection, + MsgVerifyCollection, + MsgUnverifyCollection, + MsgAddAdmin, + MsgMintNft, + MsgPublishNft, + MsgRemoveNft, + MsgUpdatePrice, + MsgUpdateRoyalties, + MsgBuyNft, + MsgRemoveAdmin, }; diff --git a/src/models/msg/addressbook/msg_create_address.ts b/src/models/msg/addressbook/msg_create_address.ts new file mode 100644 index 0000000000..5517fbb77c --- /dev/null +++ b/src/models/msg/addressbook/msg_create_address.ts @@ -0,0 +1,34 @@ +import { Categories } from '../types'; + +class MsgCreateAddress { + public category: Categories; + public type: string; + public json: any; + public creator: string; + public network: string; + public label: string; + public value: string; + + constructor(payload: any) { + this.category = 'addressbook'; + this.type = payload.type; + this.json = payload.json; + this.creator = payload.creator; + this.network = payload.network; + this.label = payload.label; + this.value = payload.value; + } + + static fromJson(json: any) { + return new MsgCreateAddress({ + json, + type: json['@type'], + label: json.label, + creator: json.creator, + network: json.network, + value: json.value, + }); + } +} + +export default MsgCreateAddress; diff --git a/src/models/msg/addressbook/msg_delete_address.ts b/src/models/msg/addressbook/msg_delete_address.ts new file mode 100644 index 0000000000..24a19ece42 --- /dev/null +++ b/src/models/msg/addressbook/msg_delete_address.ts @@ -0,0 +1,32 @@ +import { Categories } from '../types'; + +class MsgDeleteAddress { + public category: Categories; + public type: string; + public json: any; + public creator: string; + public network: string; + public label: string; + public value: string; + + constructor(payload: any) { + this.category = 'addressbook'; + this.type = payload.type; + this.json = payload.json; + this.creator = payload.creator; + this.network = payload.network; + this.label = payload.label; + } + + static fromJson(json: any) { + return new MsgDeleteAddress({ + json, + type: json['@type'], + label: json.label, + creator: json.creator, + network: json.network, + }); + } +} + +export default MsgDeleteAddress; diff --git a/src/models/msg/addressbook/msg_update_address.ts b/src/models/msg/addressbook/msg_update_address.ts new file mode 100644 index 0000000000..70b25ff644 --- /dev/null +++ b/src/models/msg/addressbook/msg_update_address.ts @@ -0,0 +1,34 @@ +import { Categories } from '../types'; + +class MsgUpdateAddress { + public category: Categories; + public type: string; + public json: any; + public creator: string; + public network: string; + public label: string; + public value: string; + + constructor(payload: any) { + this.category = 'addressbook'; + this.type = payload.type; + this.json = payload.json; + this.creator = payload.creator; + this.network = payload.network; + this.label = payload.label; + this.value = payload.value; + } + + static fromJson(json: any) { + return new MsgUpdateAddress({ + json, + type: json['@type'], + label: json.label, + creator: json.creator, + network: json.network, + value: json.value, + }); + } +} + +export default MsgUpdateAddress; diff --git a/src/models/msg/marketplace/msg_add_admin.ts b/src/models/msg/marketplace/msg_add_admin.ts new file mode 100644 index 0000000000..f8928449c3 --- /dev/null +++ b/src/models/msg/marketplace/msg_add_admin.ts @@ -0,0 +1,28 @@ +import { Categories } from '../types'; + +class MsgAddAdmin { + public category: Categories; + public type: string; + public json: any; + public creator: string; + public address: string; + + constructor(payload: any) { + this.category = 'marketplace'; + this.type = payload.type; + this.json = payload.json; + this.creator = payload.creator; + this.address = payload.address; + } + + static fromJson(json: any) { + return new MsgAddAdmin({ + json, + type: json['@type'], + creator: json.creator, + address: json.address, + }); + } +} + +export default MsgAddAdmin; diff --git a/src/models/msg/marketplace/msg_buy_nft.ts b/src/models/msg/marketplace/msg_buy_nft.ts new file mode 100644 index 0000000000..455b7b8c60 --- /dev/null +++ b/src/models/msg/marketplace/msg_buy_nft.ts @@ -0,0 +1,54 @@ +import { formatToken } from '@src/utils/format_token'; +import { Categories } from '../types'; + +class MsgBuyNft { + public category: Categories; + public type: string; + public json: any; + public seller: string; + public buyer: string; + public id: string; + public price: TokenUnit; + + constructor(payload: any) { + this.category = 'marketplace'; + this.type = payload.type; + this.json = payload.json; + this.seller = payload.seller; + this.buyer = payload.buyer; + this.id = payload.id; + this.price = payload.price; + } + + static getPriceFromSaleEvents(events: any): TokenUnit { + const salePrice = events + .attributes.find((attribute: { key: string; }) => attribute.key === 'price') + .value || undefined; + const splitPrice = salePrice.split(/(\d+)/); + return formatToken(splitPrice[1], splitPrice[2]); + } + + static getSellerFromSaleEvents(events: any) { + return events + .attributes.find((attribute: { key: string; }) => attribute.key === 'owner') + .value || undefined; + } + + static getSaleEventsFromLog(log: any) { + return log.events.find((event: { type: string; }) => event.type === 'buy_nft'); + } + + static fromJson(json: any, log?: any) { + const saleEvents = this.getSaleEventsFromLog(log); + return new MsgBuyNft({ + json, + type: json['@type'], + seller: this.getSellerFromSaleEvents(saleEvents), + buyer: json.creator, + id: json.id, + price: this.getPriceFromSaleEvents(saleEvents), + }); + } +} + +export default MsgBuyNft; diff --git a/src/models/msg/marketplace/msg_create_collection.ts b/src/models/msg/marketplace/msg_create_collection.ts new file mode 100644 index 0000000000..60edebffd8 --- /dev/null +++ b/src/models/msg/marketplace/msg_create_collection.ts @@ -0,0 +1,36 @@ +import { + Royalties, Categories, +} from '@src/models/msg/types'; + +class MsgCreateCollection { + public category: Categories; + public type: string; + public json: any; + public creator: string; + public collectionId: string; + public mintRoyalties: Royalties[]; + public resaleRoyalties: Royalties[]; + + constructor(payload: any) { + this.category = 'marketplace'; + this.type = payload.type; + this.json = payload.json; + this.creator = payload.creator; + this.collectionId = payload.collectionId; + this.mintRoyalties = payload.mintRoyalties; + this.resaleRoyalties = payload.resaleRoyalties; + } + + static fromJson(json: any) { + return new MsgCreateCollection({ + json, + type: json['@type'], + creator: json.creator, + collectionId: json.id, + mintRoyalties: json.mintRoyalties, + resaleRoyalties: json.resaleRoyalties, + }); + } +} + +export default MsgCreateCollection; diff --git a/src/models/msg/marketplace/msg_mint_nft.ts b/src/models/msg/marketplace/msg_mint_nft.ts new file mode 100644 index 0000000000..04c6204d07 --- /dev/null +++ b/src/models/msg/marketplace/msg_mint_nft.ts @@ -0,0 +1,41 @@ +import { formatToken } from '@src/utils/format_token'; +import { + Categories, MintedNft, +} from '../types'; + +class MsgMintNft { + public category: Categories; + public type: string; + public json: any; + public mintedNftData: MintedNft; + public creator: string; + public recipient: string; + + constructor(payload: any) { + this.category = 'marketplace'; + this.type = payload.type; + this.json = payload.json; + this.creator = payload.creator; + this.recipient = payload.recipient; + this.mintedNftData = payload.mintedNftData; + } + + static fromJson(json: any) { + return new MsgMintNft({ + json, + type: json['@type'], + creator: json.creator, + recipient: json.recipient, + mintedNftData: { + denomId: json.denomId, + uid: json.uid, + uri: json.uri, + data: json.data, + name: json.name, + price: formatToken(json.price.amount, json.price.denom), + }, + }); + } +} + +export default MsgMintNft; diff --git a/src/models/msg/marketplace/msg_publish_collection.ts b/src/models/msg/marketplace/msg_publish_collection.ts new file mode 100644 index 0000000000..51648da2d6 --- /dev/null +++ b/src/models/msg/marketplace/msg_publish_collection.ts @@ -0,0 +1,36 @@ +import { + Royalties, Categories, +} from '@src/models/msg/types'; + +class MsgPublishCollection { + public category: Categories; + public type: string; + public json: any; + public creator: string; + public collectionId: string; + public mintRoyalties: Royalties[]; + public resaleRoyalties: Royalties[]; + + constructor(payload: any) { + this.category = 'marketplace'; + this.type = payload.type; + this.json = payload.json; + this.creator = payload.creator; + this.collectionId = payload.collectionId; + this.mintRoyalties = payload.mintRoyalties; + this.resaleRoyalties = payload.resaleRoyalties; + } + + static fromJson(json: any) { + return new MsgPublishCollection({ + json, + type: json['@type'], + creator: json.creator, + collectionId: json.denomId, + mintRoyalties: json.mintRoyalties, + resaleRoyalties: json.resaleRoyalties, + }); + } +} + +export default MsgPublishCollection; diff --git a/src/models/msg/marketplace/msg_publish_nft.ts b/src/models/msg/marketplace/msg_publish_nft.ts new file mode 100644 index 0000000000..a750e3f914 --- /dev/null +++ b/src/models/msg/marketplace/msg_publish_nft.ts @@ -0,0 +1,35 @@ +import { formatToken } from '@src/utils/format_token'; +import { Categories } from '../types'; + +class MsgPublishNft { + public category: Categories; + public type: string; + public json: any; + public creator: string; + public denomId: string; + public tokenId: string; + public price: TokenUnit + + constructor(payload: any) { + this.category = 'marketplace'; + this.type = payload.type; + this.json = payload.json; + this.creator = payload.creator; + this.denomId = payload.denomId; + this.tokenId = payload.tokenId; + this.price = payload.price; + } + + static fromJson(json: any) { + return new MsgPublishNft({ + json, + type: json['@type'], + creator: json.creator, + denomId: json.denomId, + tokenId: json.tokenId, + price: formatToken(json.price.amount, json.price.denom), + }); + } +} + +export default MsgPublishNft; diff --git a/src/models/msg/marketplace/msg_remove_admin.ts b/src/models/msg/marketplace/msg_remove_admin.ts new file mode 100644 index 0000000000..5243f019c5 --- /dev/null +++ b/src/models/msg/marketplace/msg_remove_admin.ts @@ -0,0 +1,28 @@ +import { Categories } from '../types'; + +class MsgRemoveAdmin { + public category: Categories; + public type: string; + public json: any; + public creator: string; + public address: string; + + constructor(payload: any) { + this.category = 'marketplace'; + this.type = payload.type; + this.json = payload.json; + this.creator = payload.creator; + this.address = payload.address; + } + + static fromJson(json: any) { + return new MsgRemoveAdmin({ + json, + type: json['@type'], + creator: json.creator, + address: json.address, + }); + } +} + +export default MsgRemoveAdmin; diff --git a/src/models/msg/marketplace/msg_remove_nft.ts b/src/models/msg/marketplace/msg_remove_nft.ts new file mode 100644 index 0000000000..297ec059c5 --- /dev/null +++ b/src/models/msg/marketplace/msg_remove_nft.ts @@ -0,0 +1,28 @@ +import { Categories } from '../types'; + +class MsgRemoveNft { + public category: Categories; + public type: string; + public json: any; + public creator: string; + public id: string; + + constructor(payload: any) { + this.category = 'marketplace'; + this.type = payload.type; + this.json = payload.json; + this.creator = payload.creator; + this.id = payload.id; + } + + static fromJson(json: any) { + return new MsgRemoveNft({ + json, + type: json['@type'], + creator: json.creator, + id: json.id, + }); + } +} + +export default MsgRemoveNft; diff --git a/src/models/msg/marketplace/msg_unverify_collection.ts b/src/models/msg/marketplace/msg_unverify_collection.ts new file mode 100644 index 0000000000..fb32fa494e --- /dev/null +++ b/src/models/msg/marketplace/msg_unverify_collection.ts @@ -0,0 +1,38 @@ +import { Categories } from '../types'; + +class MsgUnverifyCollection { + public category: Categories; + public type: string; + public json: any; + public creator: string; + public admin: string; + public collectionId: string; + + constructor(payload: any) { + this.category = 'marketplace'; + this.type = payload.type; + this.json = payload.json; + this.creator = payload.creator; + this.admin = payload.admin; + this.collectionId = payload.collectionId; + } + + static getAdminFromLog(log: any) { + return log + .events.find((event: { type: string; }) => event.type === 'message') + .attributes.find((attribute: { key: string; }) => attribute.key === 'sender') + .value || undefined; + } + + static fromJson(json: any, log?: any) { + return new MsgUnverifyCollection({ + json, + type: json['@type'], + creator: json.creator, + admin: this.getAdminFromLog(log), + collectionId: json.id, + }); + } +} + +export default MsgUnverifyCollection; diff --git a/src/models/msg/marketplace/msg_update_price.ts b/src/models/msg/marketplace/msg_update_price.ts new file mode 100644 index 0000000000..3eb7961fe4 --- /dev/null +++ b/src/models/msg/marketplace/msg_update_price.ts @@ -0,0 +1,32 @@ +import { formatToken } from '@src/utils/format_token'; +import { Categories } from '../types'; + +class MsgUpdatePrice { + public category: Categories; + public type: string; + public json: any; + public creator: string; + public id: string; + public price: TokenUnit; + + constructor(payload: any) { + this.category = 'marketplace'; + this.type = payload.type; + this.json = payload.json; + this.creator = payload.creator; + this.id = payload.id; + this.price = payload.price; + } + + static fromJson(json: any) { + return new MsgUpdatePrice({ + json, + type: json['@type'], + creator: json.creator, + id: json.id, + price: formatToken(json.price.amount, json.price.denom), + }); + } +} + +export default MsgUpdatePrice; diff --git a/src/models/msg/marketplace/msg_update_royalties.ts b/src/models/msg/marketplace/msg_update_royalties.ts new file mode 100644 index 0000000000..05a67f1654 --- /dev/null +++ b/src/models/msg/marketplace/msg_update_royalties.ts @@ -0,0 +1,36 @@ +import { + Royalties, Categories, +} from '@src/models/msg/types'; + +class MsgUpdateRoyalties { + public category: Categories; + public type: string; + public json: any; + public creator: string; + public collectionId: string; + public mintRoyalties: Royalties[]; + public resaleRoyalties: Royalties[]; + + constructor(payload: any) { + this.category = 'marketplace'; + this.type = payload.type; + this.json = payload.json; + this.creator = payload.creator; + this.collectionId = payload.collectionId; + this.mintRoyalties = payload.mintRoyalties; + this.resaleRoyalties = payload.resaleRoyalties; + } + + static fromJson(json: any) { + return new MsgUpdateRoyalties({ + json, + type: json['@type'], + creator: json.creator, + collectionId: json.id, + mintRoyalties: json.mintRoyalties, + resaleRoyalties: json.resaleRoyalties, + }); + } +} + +export default MsgUpdateRoyalties; diff --git a/src/models/msg/marketplace/msg_verify_collection.ts b/src/models/msg/marketplace/msg_verify_collection.ts new file mode 100644 index 0000000000..34b1d8560a --- /dev/null +++ b/src/models/msg/marketplace/msg_verify_collection.ts @@ -0,0 +1,38 @@ +import { Categories } from '../types'; + +class MsgVerifyCollection { + public category: Categories; + public type: string; + public json: any; + public creator: string; + public admin: string; + public collectionId: string; + + constructor(payload: any) { + this.category = 'marketplace'; + this.type = payload.type; + this.json = payload.json; + this.creator = payload.creator; + this.admin = payload.admin; + this.collectionId = payload.collectionId; + } + + static getAdminFromLog(log: any) { + return log + .events.find((event: { type: string; }) => event.type === 'message') + .attributes.find((attribute: { key: string; }) => attribute.key === 'sender') + .value || undefined; + } + + static fromJson(json: any, log?: any) { + return new MsgVerifyCollection({ + json, + type: json['@type'], + creator: json.creator, + admin: this.getAdminFromLog(log), + collectionId: json.id, + }); + } +} + +export default MsgVerifyCollection; diff --git a/src/models/msg/types.ts b/src/models/msg/types.ts index 9b6ef03819..58e6f3bff6 100644 --- a/src/models/msg/types.ts +++ b/src/models/msg/types.ts @@ -1,3 +1,20 @@ export type BaseCategories = 'bank' | 'crisis' | 'distribution' | 'governance' | 'slashing' | 'staking' | 'profiles' | 'ibc' | 'ibc-transfer' | 'authz' | 'feegrant' | 'vesting' | 'others' -export type CustomCategories = 'cosmwasm' | 'gravity'; // custom modules +export type CustomCategories = 'cosmwasm' | 'gravity' | 'addressbook' | 'marketplace'; // custom modules export type Categories = BaseCategories | CustomCategories +export interface MintedNft { + denomId: string; + uid: string; + uri: string; + data: string; + name: string; + price: TokenUnit; +} +export interface AddressBookDetailsValue { + network: string; + label: string; + value: string; +} +export interface Royalties { + address: string; + percent: string; +} diff --git a/src/screens/transaction_details/components/messages/styles.ts b/src/screens/transaction_details/components/messages/styles.ts index 7b399d2b08..898ac1daa9 100644 --- a/src/screens/transaction_details/components/messages/styles.ts +++ b/src/screens/transaction_details/components/messages/styles.ts @@ -68,7 +68,6 @@ export const useStyles = () => { tags: { marginBottom: theme.spacing(2), [theme.breakpoints.up('lg')]: { - minWidth: '200px', marginBottom: 0, paddingRight: theme.spacing(2), alignSelf: 'flex-start', diff --git a/src/styles/createPalette.d.ts b/src/styles/createPalette.d.ts index 29012412be..9dd29e6729 100644 --- a/src/styles/createPalette.d.ts +++ b/src/styles/createPalette.d.ts @@ -45,6 +45,8 @@ declare module '@material-ui/core/styles/createPalette' { eighteen: string, nineteen: string, twenty: string, + twentyOne: string, + twentyTwo: string, }, charts: { zero: string; diff --git a/src/styles/theme/index.ts b/src/styles/theme/index.ts index e65bd1d780..09cf3d195c 100644 --- a/src/styles/theme/index.ts +++ b/src/styles/theme/index.ts @@ -127,6 +127,8 @@ export const common = { eighteen: '#F0A479', nineteen: '#D37763', twenty: '#D9C788', + twentyOne: '#FF720C', + twentyTwo: '#BA0086', }, fonts: { fontFive: '#FFFFFF', @@ -190,11 +192,11 @@ export const common = { }, }; -export const lightTemplate:ThemeOptions = R.mergeDeepLeft(lightThemeOverride, common); -export const darkTemplate:ThemeOptions = R.mergeDeepLeft(darkThemeOverride, common); -export const deuteranopiaTemplate:ThemeOptions = R.mergeDeepLeft(deuteranopiaThemeOverride, common); -export const tritanopiaTemplate:ThemeOptions = R.mergeDeepLeft(tritanopiaThemeOverride, common); -export const cudosTemplate:ThemeOptions = R.mergeDeepLeft(cudosThemeOverride, common); +export const lightTemplate: ThemeOptions = R.mergeDeepLeft(lightThemeOverride, common); +export const darkTemplate: ThemeOptions = R.mergeDeepLeft(darkThemeOverride, common); +export const deuteranopiaTemplate: ThemeOptions = R.mergeDeepLeft(deuteranopiaThemeOverride, common); +export const tritanopiaTemplate: ThemeOptions = R.mergeDeepLeft(tritanopiaThemeOverride, common); +export const cudosTemplate: ThemeOptions = R.mergeDeepLeft(cudosThemeOverride, common); // export const lightTheme = createMuiTheme(lightTemplate); // export const darkTheme = createMuiTheme(darkTemplate);