create-near-app 5.3.1 → 6.0.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/make.js +19 -15
- package/dist/messages.js +2 -2
- package/dist/package-json.js +17 -1
- package/dist/types.js +1 -1
- package/dist/user-input.js +16 -15
- package/package.json +4 -1
- package/templates/contracts/js/deploy.sh +6 -1
- package/templates/contracts/js/package-lock.json +5966 -0
- package/templates/contracts/js/src/contract.ts +5 -5
- package/templates/contracts/rust/Cargo.toml +1 -1
- package/templates/contracts/rust/README.md +2 -2
- package/templates/contracts/rust/deploy.sh +5 -0
- package/templates/contracts/rust/src/lib.rs +11 -11
- package/templates/frontend/gateway/.nvmrc +1 -0
- package/templates/frontend/gateway/.prettierrc +6 -0
- package/templates/frontend/gateway/next.config.js +15 -0
- package/templates/frontend/gateway/package.json +74 -0
- package/templates/frontend/gateway/public/apple-touch-icon.png +0 -0
- package/templates/frontend/gateway/public/bos-meta.png +0 -0
- package/templates/frontend/gateway/public/favicon.ico +0 -0
- package/templates/frontend/gateway/public/favicon.png +0 -0
- package/templates/frontend/gateway/public/fonts/FKGrotesk.woff2 +0 -0
- package/templates/frontend/gateway/public/fonts/Mona-Sans.woff2 +0 -0
- package/templates/frontend/gateway/public/logo192.png +0 -0
- package/templates/frontend/gateway/public/next.svg +1 -0
- package/templates/frontend/gateway/public/robots.txt +3 -0
- package/templates/frontend/gateway/public/site.webmanifest +8 -0
- package/templates/frontend/gateway/public/vercel.svg +1 -0
- package/templates/frontend/gateway/src/assets/images/near-icon.svg +3 -0
- package/templates/frontend/gateway/src/components/MetaTags.tsx +22 -0
- package/templates/frontend/gateway/src/components/component/ComponentWrapperPage.tsx +27 -0
- package/templates/frontend/gateway/src/components/layouts/DefaultLayout.tsx +16 -0
- package/templates/frontend/gateway/src/components/layouts/SimpleLayout.tsx +9 -0
- package/templates/frontend/gateway/src/components/lib/Button/Button.tsx +379 -0
- package/templates/frontend/gateway/src/components/lib/Button/index.tsx +1 -0
- package/templates/frontend/gateway/src/components/lib/Spinner/Spinner.tsx +33 -0
- package/templates/frontend/gateway/src/components/lib/Spinner/index.ts +1 -0
- package/templates/frontend/gateway/src/components/lib/Text/Text.tsx +14 -0
- package/templates/frontend/gateway/src/components/lib/Text/index.tsx +1 -0
- package/templates/frontend/gateway/src/components/lib/Toast/README.md +83 -0
- package/templates/frontend/gateway/src/components/lib/Toast/Toast.tsx +25 -0
- package/templates/frontend/gateway/src/components/lib/Toast/Toaster.tsx +48 -0
- package/templates/frontend/gateway/src/components/lib/Toast/api.ts +6 -0
- package/templates/frontend/gateway/src/components/lib/Toast/index.ts +3 -0
- package/templates/frontend/gateway/src/components/lib/Toast/store.ts +83 -0
- package/templates/frontend/gateway/src/components/lib/Toast/styles.ts +126 -0
- package/templates/frontend/gateway/src/components/navigation/Navigation.tsx +23 -0
- package/templates/frontend/gateway/src/components/navigation/UserDropdownMenu.tsx +209 -0
- package/templates/frontend/gateway/src/components/navigation/desktop/DesktopNavigation.tsx +109 -0
- package/templates/frontend/gateway/src/components/navigation/desktop/MainNavigationMenu.tsx +170 -0
- package/templates/frontend/gateway/src/components/navigation/icons/close.svg +22 -0
- package/templates/frontend/gateway/src/components/navigation/icons/near-icon.svg +3 -0
- package/templates/frontend/gateway/src/components/navigation/icons/near-logo.svg +14 -0
- package/templates/frontend/gateway/src/components/navigation/icons/return.svg +29 -0
- package/templates/frontend/gateway/src/components/navigation/icons/search.svg +3 -0
- package/templates/frontend/gateway/src/components/navigation/mobile/AccordionMenu.tsx +141 -0
- package/templates/frontend/gateway/src/components/navigation/mobile/Menu.tsx +86 -0
- package/templates/frontend/gateway/src/components/navigation/mobile/MobileNavigation.tsx +131 -0
- package/templates/frontend/gateway/src/components/navigation/navigation-categories.ts +75 -0
- package/templates/frontend/gateway/src/components/vm/VmCommitButton.tsx +20 -0
- package/templates/frontend/gateway/src/components/vm/VmComponent.tsx +29 -0
- package/templates/frontend/gateway/src/components/vm/VmInitializer.tsx +124 -0
- package/templates/frontend/gateway/src/data/components.ts +50 -0
- package/templates/frontend/gateway/src/data/web3.ts +292 -0
- package/templates/frontend/gateway/src/hooks/useBosComponents.ts +14 -0
- package/templates/frontend/gateway/src/hooks/useBosLoaderInitializer.ts +60 -0
- package/templates/frontend/gateway/src/hooks/useFlags.ts +40 -0
- package/templates/frontend/gateway/src/hooks/useLayout.tsx +12 -0
- package/templates/frontend/gateway/src/index.d.ts +9 -0
- package/templates/frontend/gateway/src/pages/_app.tsx +47 -0
- package/templates/frontend/gateway/src/pages/_document.tsx +27 -0
- package/templates/frontend/gateway/src/pages/dig.tsx +25 -0
- package/templates/frontend/gateway/src/pages/flags.tsx +83 -0
- package/templates/frontend/gateway/src/pages/hello-api.tsx +105 -0
- package/templates/frontend/gateway/src/pages/hello-component.tsx +23 -0
- package/templates/frontend/gateway/src/pages/hello-ethereum.tsx +23 -0
- package/templates/frontend/gateway/src/pages/hello-social.tsx +31 -0
- package/templates/frontend/gateway/src/pages/index.tsx +51 -0
- package/templates/frontend/gateway/src/pages/nui.tsx +25 -0
- package/templates/frontend/gateway/src/stores/auth.ts +29 -0
- package/templates/frontend/gateway/src/stores/bos-loader.ts +20 -0
- package/templates/frontend/gateway/src/stores/current-component.ts +11 -0
- package/templates/frontend/gateway/src/stores/vm.ts +24 -0
- package/templates/frontend/gateway/src/styles/globals.css +68 -0
- package/templates/frontend/gateway/src/styles/theme.css +129 -0
- package/templates/frontend/gateway/src/utils/config.ts +49 -0
- package/templates/frontend/gateway/src/utils/form-validation.ts +18 -0
- package/templates/frontend/gateway/src/utils/keypom-options.ts +59 -0
- package/templates/frontend/gateway/src/utils/route/privateRoute.tsx +20 -0
- package/templates/frontend/gateway/src/utils/route/signedOutRoute.tsx +21 -0
- package/templates/frontend/gateway/src/utils/types.ts +33 -0
- package/templates/frontend/gateway/tsconfig.json +24 -0
- package/templates/frontend/vanilla/.env +1 -0
- package/templates/frontend/vanilla/index.html +15 -6
- package/templates/frontend/vanilla/index.js +1 -1
- package/templates/frontend/{shared → vanilla}/near-wallet.js +2 -2
- package/templates/frontend/vanilla/package.json +9 -8
- package/templates/integration-tests/js-tests/package-lock.json +5014 -0
- package/templates/integration-tests/js-tests/package.json +3 -0
- package/templates/integration-tests/js-tests/src/main.ava.ts +6 -6
- package/templates/integration-tests/rust-tests/src/tests.rs +7 -7
- package/templates/frontend/react/App.js +0 -75
- package/templates/frontend/react/assets/favicon.ico +0 -0
- package/templates/frontend/react/assets/global.css +0 -231
- package/templates/frontend/react/assets/logo-black.svg +0 -1
- package/templates/frontend/react/assets/logo-white.svg +0 -1
- package/templates/frontend/react/index.html +0 -15
- package/templates/frontend/react/index.js +0 -23
- package/templates/frontend/react/package.json +0 -52
- package/templates/frontend/react/ui-components.js +0 -59
- package/templates/frontend/shared/start.sh +0 -26
- /package/templates/{shared → contracts/rust}/rust-toolchain.toml +0 -0
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import type { NetworkId } from './types';
|
|
2
|
+
|
|
3
|
+
export const KEYPOM_OPTIONS = (networkId: NetworkId) => {
|
|
4
|
+
return {
|
|
5
|
+
beginTrial: {
|
|
6
|
+
landing: {
|
|
7
|
+
title: 'Create an Account',
|
|
8
|
+
body: 'To start, enter a username.',
|
|
9
|
+
fieldPlaceholder: 'Account ID',
|
|
10
|
+
buttonText: 'Create',
|
|
11
|
+
},
|
|
12
|
+
claiming: {
|
|
13
|
+
title: 'Creating Account',
|
|
14
|
+
body: 'Your account is being created. Please wait...',
|
|
15
|
+
},
|
|
16
|
+
claimed: {
|
|
17
|
+
title: 'You\'re all set! 🎉',
|
|
18
|
+
body: 'Your account has been successfully created.',
|
|
19
|
+
buttonText: 'Continue to app',
|
|
20
|
+
},
|
|
21
|
+
},
|
|
22
|
+
trialOver: {
|
|
23
|
+
mainBody: {
|
|
24
|
+
title: 'Your trial has ended',
|
|
25
|
+
body: 'Choose a wallet provider and onboard fully into the NEAR ecosystem.',
|
|
26
|
+
imageOne: {
|
|
27
|
+
title: 'Secure Your Digital Assets',
|
|
28
|
+
body: 'Now that your trial is over, secure your account with an official wallet provider!',
|
|
29
|
+
},
|
|
30
|
+
imageTwo: {
|
|
31
|
+
title: 'Log In to Any NEAR App',
|
|
32
|
+
body: 'Once your account is secured, you can use any app on NEAR!',
|
|
33
|
+
},
|
|
34
|
+
},
|
|
35
|
+
offboardingOptions: {
|
|
36
|
+
title: 'Choose a Wallet',
|
|
37
|
+
},
|
|
38
|
+
},
|
|
39
|
+
invalidAction: {
|
|
40
|
+
title: 'Invalid Action',
|
|
41
|
+
body: 'Your trial does not allow you to perform this action. For more information, please contact the site administrator.',
|
|
42
|
+
},
|
|
43
|
+
insufficientBalance: {
|
|
44
|
+
title: 'Insufficient Balance',
|
|
45
|
+
body: 'Your account does not have enough balance for the action you are trying to perform. Please try again with a different action. For more information, please contact the site administrator.',
|
|
46
|
+
},
|
|
47
|
+
wallets: [
|
|
48
|
+
{
|
|
49
|
+
name: 'MyNEARWallet',
|
|
50
|
+
description: 'Secure your account with a Seed Phrase',
|
|
51
|
+
iconUrl:
|
|
52
|
+
'',
|
|
53
|
+
redirectUrl: `${
|
|
54
|
+
networkId === 'testnet' ? 'https://testnet.mynearwallet.com' : 'https://app.mynearwallet.com'
|
|
55
|
+
}/linkdrop/ACCOUNT_ID/SECRET_KEY`,
|
|
56
|
+
},
|
|
57
|
+
],
|
|
58
|
+
};
|
|
59
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { useAuthStore } from '@/stores/auth';
|
|
2
|
+
import type { NextComponentType } from 'next';
|
|
3
|
+
import { useRouter } from 'next/router';
|
|
4
|
+
|
|
5
|
+
const privateRoute = (Component: NextComponentType) => {
|
|
6
|
+
const Private = (props: any) => {
|
|
7
|
+
const signedIn = useAuthStore((store) => store.signedIn);
|
|
8
|
+
const router = useRouter();
|
|
9
|
+
|
|
10
|
+
if (!signedIn && router) {
|
|
11
|
+
// `signin` or `signup`?
|
|
12
|
+
router.push('/signup');
|
|
13
|
+
}
|
|
14
|
+
return <Component {...props} />;
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
return Private;
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
export default privateRoute;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { useRouter } from 'next/router';
|
|
2
|
+
|
|
3
|
+
import { useAuthStore } from '@/stores/auth';
|
|
4
|
+
|
|
5
|
+
import type { NextPageWithLayout } from '../types';
|
|
6
|
+
|
|
7
|
+
const signedOutRoute = (Component: NextPageWithLayout) => {
|
|
8
|
+
const SignedOut = (props: NextPageWithLayout) => {
|
|
9
|
+
const signedIn = useAuthStore((store) => store.signedIn);
|
|
10
|
+
const router = useRouter();
|
|
11
|
+
|
|
12
|
+
if (signedIn && router) {
|
|
13
|
+
router.push('/');
|
|
14
|
+
}
|
|
15
|
+
return <Component {...props} />;
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
return SignedOut;
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
export default signedOutRoute;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import type { NextPage } from 'next';
|
|
2
|
+
import type { ReactElement, ReactNode } from 'react';
|
|
3
|
+
|
|
4
|
+
export type NextPageWithLayout<T = any> = NextPage<T> & {
|
|
5
|
+
getLayout?: (page: ReactElement) => ReactNode;
|
|
6
|
+
};
|
|
7
|
+
|
|
8
|
+
export type NetworkId = ProductionNetwork['networkId'];
|
|
9
|
+
export type Network = ProductionNetwork;
|
|
10
|
+
// export type NetworkId = ProductionNetwork['networkId'] | DevelopmentNetwork['networkId'];
|
|
11
|
+
// export type Network = ProductionNetwork | DevelopmentNetwork;
|
|
12
|
+
|
|
13
|
+
type ProductionNetwork = {
|
|
14
|
+
networkId: 'testnet' | 'mainnet';
|
|
15
|
+
viewAccountId: string;
|
|
16
|
+
nodeUrl: string;
|
|
17
|
+
walletUrl: string;
|
|
18
|
+
helperUrl: string;
|
|
19
|
+
fastAuth: {
|
|
20
|
+
mpcRecoveryUrl: string;
|
|
21
|
+
authHelperUrl: string; // TODO refactor: review by fastauth team
|
|
22
|
+
accountIdSuffix: string;
|
|
23
|
+
firebase: {
|
|
24
|
+
apiKey: string;
|
|
25
|
+
authDomain: string;
|
|
26
|
+
projectId: string;
|
|
27
|
+
storageBucket: string;
|
|
28
|
+
messagingSenderId: string;
|
|
29
|
+
appId: string;
|
|
30
|
+
measurementId: string;
|
|
31
|
+
};
|
|
32
|
+
};
|
|
33
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
{
|
|
2
|
+
"compilerOptions": {
|
|
3
|
+
"target": "es5",
|
|
4
|
+
"lib": ["dom", "dom.iterable", "esnext"],
|
|
5
|
+
"allowJs": true,
|
|
6
|
+
"skipLibCheck": true,
|
|
7
|
+
"strict": true,
|
|
8
|
+
"forceConsistentCasingInFileNames": true,
|
|
9
|
+
"strictPropertyInitialization": false,
|
|
10
|
+
"noEmit": true,
|
|
11
|
+
"esModuleInterop": true,
|
|
12
|
+
"module": "esnext",
|
|
13
|
+
"moduleResolution": "node",
|
|
14
|
+
"resolveJsonModule": true,
|
|
15
|
+
"isolatedModules": true,
|
|
16
|
+
"jsx": "preserve",
|
|
17
|
+
"incremental": true,
|
|
18
|
+
"paths": {
|
|
19
|
+
"@/*": ["./src/*"]
|
|
20
|
+
}
|
|
21
|
+
},
|
|
22
|
+
"include": ["next-env.d.ts", "**/*.ts", "**/*.tsx", "types/**/*.d.ts"],
|
|
23
|
+
"exclude": ["node_modules"]
|
|
24
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
CONTRACT_NAME=hello.near-examples.testnet
|
|
@@ -18,15 +18,24 @@
|
|
|
18
18
|
Welcome to NEAR!
|
|
19
19
|
</h3>
|
|
20
20
|
<p>
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
21
|
+
<b data-behavior="contract"></b>
|
|
22
|
+
is storing a greeting message in the NEAR blockchain. To change it you
|
|
23
|
+
need to sign in using the NEAR Wallet. It is very simple, just use the
|
|
24
|
+
button below.
|
|
24
25
|
</p>
|
|
25
26
|
<p>
|
|
26
27
|
Do not worry, this app runs in the test network ("testnet"). It works
|
|
27
28
|
just like the main network ("mainnet"), but using NEAR Tokens that are
|
|
28
29
|
only for testing!
|
|
29
30
|
</p>
|
|
31
|
+
|
|
32
|
+
<p>
|
|
33
|
+
<b> Note </b>: The contract address is being loaded from
|
|
34
|
+
an <code> env </code> variable. If you chose to add a contract during
|
|
35
|
+
the wizard, running <code> npm run deploy </code> will deploy the
|
|
36
|
+
contract code and update the <code> env </code> variable used here.
|
|
37
|
+
</p>
|
|
38
|
+
|
|
30
39
|
<p style="text-align: center; margin-top: 2.5em">
|
|
31
40
|
<button id="sign-in-button">Sign in with NEAR Wallet</button>
|
|
32
41
|
</p>
|
|
@@ -56,7 +65,7 @@
|
|
|
56
65
|
</div>
|
|
57
66
|
</form>
|
|
58
67
|
<p>
|
|
59
|
-
Look at that! A Hello World app! This greeting is stored on
|
|
68
|
+
Look at that! A Hello World app! This greeting is stored on <b data-behavior="contract"></b>.
|
|
60
69
|
</p>
|
|
61
70
|
<ol>
|
|
62
71
|
<li>
|
|
@@ -64,11 +73,11 @@
|
|
|
64
73
|
to interact with the methods <code>set_greeting</code> and <code>get_greeting</code>.
|
|
65
74
|
</li>
|
|
66
75
|
<li>
|
|
67
|
-
These method live in the <a target="_blank" href="https://docs.near.org/
|
|
76
|
+
These method live in the <a target="_blank" href="https://docs.near.org/develop/contracts/welcome">smart contract</a>,
|
|
68
77
|
who's code is defined in the <code>contract/</code> folder.
|
|
69
78
|
</li>
|
|
70
79
|
<li>
|
|
71
|
-
When you run <code>npm run
|
|
80
|
+
When you run <code>npm run deploy</code> the code in the <code>contract/</code> folder is compiled and deployed to the NEAR testnet.
|
|
72
81
|
You can see how this happens by looking in <code>package.json</code> at the <code>scripts</code> section to
|
|
73
82
|
find the <code>dev</code> command.
|
|
74
83
|
</li>
|
|
@@ -5,7 +5,7 @@ const CONTRACT_ADDRESS = process.env.CONTRACT_NAME;
|
|
|
5
5
|
|
|
6
6
|
// When creating the wallet you can optionally ask to create an access key
|
|
7
7
|
// Having the key enables to call non-payable methods without interrupting the user to sign
|
|
8
|
-
const wallet = new Wallet({ createAccessKeyFor: CONTRACT_ADDRESS })
|
|
8
|
+
const wallet = new Wallet({ createAccessKeyFor: CONTRACT_ADDRESS });
|
|
9
9
|
|
|
10
10
|
// Setup on page load
|
|
11
11
|
window.onload = async () => {
|
|
@@ -24,8 +24,8 @@ export class Wallet {
|
|
|
24
24
|
// key, so the user skips signing non-payable transactions.
|
|
25
25
|
// Omitting the accountId will result in the user being
|
|
26
26
|
// asked to sign all transactions.
|
|
27
|
-
this.createAccessKeyFor = createAccessKeyFor
|
|
28
|
-
this.network = 'testnet'
|
|
27
|
+
this.createAccessKeyFor = createAccessKeyFor;
|
|
28
|
+
this.network = 'testnet';
|
|
29
29
|
}
|
|
30
30
|
|
|
31
31
|
// To be called when the website loads
|
|
@@ -3,26 +3,27 @@
|
|
|
3
3
|
"version": "1.0.0",
|
|
4
4
|
"license": "(MIT AND Apache-2.0)",
|
|
5
5
|
"scripts": {
|
|
6
|
-
"start": "
|
|
6
|
+
"start": "parcel index.html --open",
|
|
7
|
+
"dev": "parcel index.html --open",
|
|
7
8
|
"build": "parcel build index.html --public-url ./"
|
|
8
9
|
},
|
|
9
10
|
"devDependencies": {
|
|
10
|
-
"
|
|
11
|
+
"buffer": "^6.0.0",
|
|
11
12
|
"events": "^3.3.0",
|
|
12
13
|
"https-browserify": "^1.0.0",
|
|
13
14
|
"nodemon": "^2.0.16",
|
|
14
15
|
"parcel": "^2.7.0",
|
|
15
|
-
"punycode": "^1.4.1",
|
|
16
16
|
"process": "^0.11.10",
|
|
17
|
+
"punycode": "^1.4.1",
|
|
17
18
|
"stream-http": "^3.1.0",
|
|
18
19
|
"url": "^0.11.0"
|
|
19
20
|
},
|
|
20
21
|
"dependencies": {
|
|
21
|
-
"@near-wallet-selector/core": "^8.
|
|
22
|
-
"@near-wallet-selector/ledger": "^8.
|
|
23
|
-
"@near-wallet-selector/modal-ui": "^8.
|
|
24
|
-
"@near-wallet-selector/my-near-wallet": "^8.
|
|
25
|
-
"@near-wallet-selector/near-wallet": "^8.
|
|
22
|
+
"@near-wallet-selector/core": "^8.7.0",
|
|
23
|
+
"@near-wallet-selector/ledger": "^8.7.0",
|
|
24
|
+
"@near-wallet-selector/modal-ui": "^8.7.0",
|
|
25
|
+
"@near-wallet-selector/my-near-wallet": "^8.7.0",
|
|
26
|
+
"@near-wallet-selector/near-wallet": "^8.7.0",
|
|
26
27
|
"near-api-js": "^2.1.4"
|
|
27
28
|
}
|
|
28
29
|
}
|