Skip to content

Commit

Permalink
Merge pull request #375 from MeshJS/playground-update
Browse files Browse the repository at this point in the history
Playground update and provider
  • Loading branch information
jinglescode authored Nov 11, 2024
2 parents a749565 + 2603a1e commit f26d21d
Show file tree
Hide file tree
Showing 41 changed files with 604 additions and 111 deletions.
1 change: 1 addition & 0 deletions apps/playground/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
"@meshsdk/react": "*",
"@next/mdx": "^14.2.3",
"@next/third-parties": "^14.2.5",
"@vercel/og": "^0.6.3",
"copy-to-clipboard": "^3.3.3",
"flowbite": "^2.5.1",
"flowbite-react": "^0.9.0",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ export default function HeroTwoSections({

{code && <Codeblock data={code} />}

{children && children}
{children && <div className="my-1">{children}</div>}
</div>
<div className="hidden lg:col-span-5 lg:mt-0 lg:flex">
{typeof image === "string" ? <img src={image} /> : image}
Expand Down
20 changes: 15 additions & 5 deletions apps/playground/src/components/site/metatags.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ export default function Metatags({
title,
keywords,
description,
image = "/logo-mesh/mesh.png",
image,
}: {
title?: string;
keywords?: string;
Expand Down Expand Up @@ -38,20 +38,30 @@ export default function Metatags({
<meta property="og:site_name" content={title} />
<meta property="og:type" content="website" />
<meta property="og:description" content={description} />
{image && (
{image ? (
<meta property="og:image" content={`https://meshjs.dev${image}`} />
) : (
<meta
property="og:image"
content={`https://meshjs.dev/api/og?title=${title}`}
/>
)}
{image && <meta property="og:image:alt" content={title} />}
<meta property="og:image:alt" content={title} />

<meta name="twitter:card" content="summary_large_image" />
<meta name="twitter:site" content="@meshsdk" />
<meta name="twitter:title" content={title} />
<meta name="twitter:description" content={description} />
<meta name="twitter:creator" content="@meshsdk" />
{image && (
{image ? (
<meta name="twitter:image" content={`https://meshjs.dev${image}`} />
) : (
<meta
name="twitter:image"
content={`https://meshjs.dev/api/og?title=${title}`}
/>
)}
{image && <meta name="twitter:image:alt" content={title} />}
<meta name="twitter:image:alt" content={title} />

<link
rel="apple-touch-icon"
Expand Down
2 changes: 1 addition & 1 deletion apps/playground/src/data/catalyst.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { LightBulbIcon } from "@heroicons/react/24/solid";
export const metaCatalyst = {
link: `/about/catalyst`,
title: "Project Catalyst",
desc: "Here are proposals that we have submitted to Project Catalyst and its progress.",
desc: "Proposals that we have submitted to Project Catalyst and its progress.",
icon: LightBulbIcon,
};

Expand Down
2 changes: 2 additions & 0 deletions apps/playground/src/pages/404.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ const ReactPage: NextPage = () => {
<div className="mx-auto max-w-screen-sm text-center">
<p className="mb-8 font-medium text-gray-500 sm:text-2xl dark:text-gray-400">
Whoops! This page doesn't exist.
<br />
Check the links below to find what you're looking for.
</p>
</div>
</div>
Expand Down
77 changes: 77 additions & 0 deletions apps/playground/src/pages/api/og.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
import { NextRequest } from "next/server";
import { ImageResponse } from "@vercel/og";

export const config = {
runtime: "edge",
};

export default function handler(request: NextRequest) {
try {
const { searchParams } = new URL(request.url);

// ?title=<title>
const hasTitle = searchParams.has("title");
const title = hasTitle
? searchParams.get("title")?.slice(0, 100)
: "Mesh JS - Cardano Web3 TypeScript SDK & off-chain Framework";

return new ImageResponse(
(
<div
style={{
backgroundColor: "black",
backgroundSize: "150px 150px",
height: "100%",
width: "100%",
display: "flex",
textAlign: "center",
alignItems: "center",
justifyContent: "center",
flexDirection: "column",
flexWrap: "nowrap",
}}
>
<div
style={{
display: "flex",
alignItems: "center",
justifyContent: "center",
justifyItems: "center",
}}
>
<svg
viewBox="0 0 300 200"
xmlns="http://www.w3.org/2000/svg"
fill="white"
>
<path d="m289 127-45-60-45-60c-.9-1.3-2.4-2-4-2s-3.1.7-4 2l-37 49.3c-2 2.7-6 2.7-8 0l-37-49.3c-.9-1.3-2.4-2-4-2s-3.1.7-4 2l-45 60-45 60c-1.3 1.8-1.3 4.2 0 6l45 60c.9 1.3 2.4 2 4 2s3.1-.7 4-2l37-49.3c2-2.7 6-2.7 8 0l37 49.3c.9 1.3 2.4 2 4 2s3.1-.7 4-2l37-49.3c2-2.7 6-2.7 8 0l37 49.3c.9 1.3 2.4 2 4 2s3.1-.7 4-2l45-60c1.3-1.8 1.3-4.2 0-6zm-90-103.3 32.5 43.3c1.3 1.8 1.3 4.2 0 6l-32.5 43.3c-2 2.7-6 2.7-8 0l-32.5-43.3c-1.3-1.8-1.3-4.2 0-6l32.5-43.3c2-2.7 6-2.7 8 0zm-90 0 32.5 43.3c1.3 1.8 1.3 4.2 0 6l-32.5 43.3c-2 2.7-6 2.7-8 0l-32.5-43.3c-1.3-1.8-1.3-4.2 0-6l32.5-43.3c2-2.7 6-2.7 8 0zm-53 152.6-32.5-43.3c-1.3-1.8-1.3-4.2 0-6l32.5-43.3c2-2.7 6-2.7 8 0l32.5 43.3c1.3 1.8 1.3 4.2 0 6l-32.5 43.3c-2 2.7-6 2.7-8 0zm90 0-32.5-43.3c-1.3-1.8-1.3-4.2 0-6l32.5-43.3c2-2.7 6-2.7 8 0l32.5 43.3c1.3 1.8 1.3 4.2 0 6l-32.5 43.3c-2 2.7-6 2.7-8 0zm90 0-32.5-43.3c-1.3-1.8-1.3-4.2 0-6l32.5-43.3c2-2.7 6-2.7 8 0l32.5 43.3c1.3 1.8 1.3 4.2 0 6l-32.5 43.3c-2 2.7-6 2.7-8 0z" />
</svg>
</div>
<div
style={{
fontSize: 60,
fontStyle: "normal",
letterSpacing: "-0.025em",
color: "white",
marginTop: 30,
padding: "0 120px",
lineHeight: 1.4,
whiteSpace: "pre-wrap",
}}
>
{title}
</div>
</div>
),
{
width: 1200,
height: 630,
},
);
} catch (e: any) {
console.log(`${e.message}`);
return new Response(`Failed to generate the image`, {
status: 500,
});
}
}
2 changes: 1 addition & 1 deletion apps/playground/src/pages/apis/transaction/common.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import Codeblock from "~/components/text/codeblock";
export function Intro() {
let example = ``;
example += `import { Transaction } from '@meshsdk/core';\n\n`;
example += `const tx = new Transaction({ initiator: wallet, verbose: true });\n`;
example += `const tx = new Transaction({ initiator: wallet, fetcher: blockchainProvider, verbose: true });\n`;
example += `tx.foo(...); // add transaction methods\n`;
example += `tx.bar(...); // add transaction methods\n\n`;
example += `const unsignedTx = await tx.build();\n`;
Expand Down
8 changes: 8 additions & 0 deletions apps/playground/src/pages/guides/aiken.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,20 @@ import LayoutImageHeaderAndBody from "~/components/layouts/image-header-and-body
import { guideaiken } from "~/data/links-guides";

export default function MDXPage({ children }) {
const sidebarItems = [
{ label: 'System setup', to: 'systemsetup' },
{ label: 'Writing a smart contract with Aiken', to: 'writingasmartcontractwithaiken' },
{ label: 'Creating locking transaction', to: 'creatinglockingtransaction' },
{ label: 'Unlocking assets', to: 'unlockingassets' },
]

return (
<LayoutImageHeaderAndBody
title={guideaiken.title}
description={guideaiken.description}
image={guideaiken.image}
cover={guideaiken.cover}
sidebarItems={sidebarItems}
>
{children}
</LayoutImageHeaderAndBody>
Expand Down
10 changes: 10 additions & 0 deletions apps/playground/src/pages/guides/custom-provider.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,22 @@ import LayoutImageHeaderAndBody from "~/components/layouts/image-header-and-body
import { guideprovider } from "~/data/links-guides";

export default function MDXPage({ children }) {
const sidebarItems = [
{ label: 'How does it work?', to: 'howdoesitwork' },
{ label: 'Implement your own provider', to: 'implementyourownprovider' },
{
label: 'Implement Constructor and Functions',
to: 'implementconstructorandfunctions'
}
]

return (
<LayoutImageHeaderAndBody
title={guideprovider.title}
description={guideprovider.description}
image={guideprovider.image}
cover={guideprovider.cover}
sidebarItems={sidebarItems}
>
{children}
</LayoutImageHeaderAndBody>
Expand Down
6 changes: 6 additions & 0 deletions apps/playground/src/pages/guides/minting-on-nodejs.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,18 @@ import LayoutImageHeaderAndBody from "~/components/layouts/image-header-and-body
import { guidenodejs } from "~/data/links-guides";

export default function MDXPage({ children }) {
const sidebarItems = [
{ label: 'System setup', to: 'systemsetup' },
{ label: 'Build the minting transaction', to: 'buildthemintingtransaction' },
];

return (
<LayoutImageHeaderAndBody
title={guidenodejs.title}
description={guidenodejs.description}
image={guidenodejs.image}
cover={guidenodejs.cover}
sidebarItems={sidebarItems}
>
{children}
</LayoutImageHeaderAndBody>
Expand Down
1 change: 0 additions & 1 deletion apps/playground/src/pages/guides/multisig-minting/demo.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -112,7 +112,6 @@ export default function Demo() {

return (
<>
<h2>Demo</h2>
<p>Connect your wallet and click on the button to mint a token.</p>
<CardanoWallet />
<Button
Expand Down
12 changes: 12 additions & 0 deletions apps/playground/src/pages/guides/multisig-minting/index.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,22 @@ import { guideminting } from "~/data/links-guides";
import Demo from "./demo";

export default function MDXPage({ children }) {
const sidebarItems = [
{ label: 'Connect wallet (client)', to: 'connectwalletclient' },
{ label: 'Build transaction (application)', to: 'buildtransactionapplication' },
{ label: 'Sign transaction (client)', to: 'signtransactionclient' },
{ label: 'Sign transaction (application)', to: 'signtransactionapplication' },
{ label: 'Submit transaction (application)', to: 'submittransactionapplication' },
{ label: 'Demo', to: 'demo' },
];

return (
<LayoutImageHeaderAndBody
title={guideminting.title}
description={guideminting.description}
image={guideminting.image}
cover={guideminting.cover}
sidebarItems={sidebarItems}
>
<>
{children}
Expand Down Expand Up @@ -188,3 +198,5 @@ const txHash = await wallet.submitTx(signedTx);
Voila! You can build any multi-sig transactions!

[Check out the code here](https://github.com/MeshJS/mesh/blob/main/apps/playground/src/pages/guides/multisig-minting/demo.tsx).

## Demo
26 changes: 21 additions & 5 deletions apps/playground/src/pages/guides/nextjs.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -2,23 +2,27 @@ import LayoutImageHeaderAndBody from "~/components/layouts/image-header-and-body
import { guidenextjs } from "~/data/links-guides";

export default function MDXPage({ children }) {
// const sidebarItems = [
// { label: 'System setup', to: 'systemsetup' },
// ];
const sidebarItems = [
{ label: 'System setup', to: 'systemsetup' },
{ label: 'Setup Mesh', to: 'setupmesh' },
{ label: 'See it in action', to: 'seeitinaction' },
];

return (
<LayoutImageHeaderAndBody
title={guidenextjs.title}
description={guidenextjs.description}
image={guidenextjs.image}
cover={guidenextjs.cover}
// sidebarItems={sidebarItems}
sidebarItems={sidebarItems}
>
{children}
</LayoutImageHeaderAndBody>
);
}

In this guide, you will get your application running, [check this demo](https://starter-template.meshjs.dev/) to see the final result.

[Next.js](https://nextjs.org/) is a web development framework built on top of Node.js enabling React-based web applications functionalities such as server-side rendering and generating static websites.

Next.js and Mesh are JavaScript libraries, and so we will assume that you have some familiarity with HTML and JavaScript language, but you should be able to follow along even if you are coming from a different programming language. If you don't feel very confident, we recommend going through this [JS tutorial](https://developer.mozilla.org/en-US/docs/Web/JavaScript/A_re-introduction_to_JavaScript), or the [MDN JavaScript Reference](https://developer.mozilla.org/en-US/docs/Web/JavaScript) or my preferred method, by watch a few [videos from YouTube](https://www.youtube.com/results?search_query=get+started+with+nextjs).
Expand All @@ -43,10 +47,22 @@ Create a new folder for your project, and give the folder a meaningful name. Ope

From the menu options in on your Visual Studio Code, open the **Terminal** and execute this command to create a new NextJs application:

```
```bash
npx create-next-app@latest --typescript .
```

```bash
Need to install the following packages:
Ok to proceed? (y)

✔ Would you like to use ESLint? … Yes
✔ Would you like to use Tailwind CSS? … Yes
✔ Would you like your code inside a `src/` directory? … Yes
✔ Would you like to use App Router? … No
✔ Would you like to use Turbopack for next dev? … No
✔ Would you like to customize the import alias (@/* by default)? … No
```

### 3. Start development server

After the installation is complete, start the development server with:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,6 @@ export default function Demo() {

return (
<>
<h2>Demo</h2>
<p>Connect your wallet and click on the button to sign a message.</p>
<CardanoWallet />
<Button
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,12 +9,23 @@ import { guideownership } from "~/data/links-guides";
import Demo from "./demo";

export default function MDXPage({ children }) {
const sidebarItems = [
{ label: 'How does it work?', to: 'howdoesitwork' },
{ label: 'Client: Connect Wallet and Get Staking Address', to: 'clientconnectwalletandgetstakingaddress' },
{ label: 'Server: Generate Nonce and Store in Database', to: 'servergeneratenonceandstoreindatabase' },
{ label: 'Client: Verify ownership by signing the nonce', to: 'clientverifyownershipbysigningthenonce' },
{ label: 'Server: Verify Signature', to: 'serververifysignature' },
{ label: 'Putting It All Together', to: 'puttingitalltogether' },
{ label: 'Demo', to: 'demo' },
];

return (
<LayoutImageHeaderAndBody
title={guideownership.title}
description={guideownership.description}
image={guideownership.image}
cover={guideownership.cover}
sidebarItems={sidebarItems}
>
<>
{children}
Expand All @@ -34,7 +45,7 @@ Some example uses of data signing to cryptographically prove ownership:
- **Authenticate user's action**. If the backend wants to confirm a user's authorization on an off-chain action, for example, engaging in in-game trading.
- **Off chain account flow**. If you need to display certain data that is off-chain or on a website only to a particular user identified by their wallet, you could use message signing as a means of doing so.

## How does It Work?
## How does it work?

![image](/guides/cryptographically-prove-wallet-ownership-process.png)

Expand Down Expand Up @@ -217,3 +228,5 @@ async function backendVerifySignature(userAddress, signature) {
```

There you go! Although this guide shows you how somebody can sign in with wallet, the same technique can be used to authenticate any of a user's actions.

## Demo
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,21 @@ import LayoutImageHeaderAndBody from "~/components/layouts/image-header-and-body
import { guidetransactions } from "~/data/links-guides";

export default function MDXPage({ children }) {
const sidebarItems = [
{ label: 'Initialize the Plutus script', to: 'initializetheplutusscript' },
{ label: 'Listing Asset for Sale', to: 'listingassetforsale' },
{ label: 'Cancel the Listing', to: 'cancelthelisting' },
{ label: 'Purchase the Listed Asset', to: 'purchasethelistedasset' },
{ label: 'Update the Listing', to: 'updatethelisting' },
];

return (
<LayoutImageHeaderAndBody
title={guidetransactions.title}
description={guidetransactions.description}
image={guidetransactions.image}
cover={guidetransactions.cover}
sidebarItems={sidebarItems}
>
{children}
</LayoutImageHeaderAndBody>
Expand Down
Loading

0 comments on commit f26d21d

Please sign in to comment.