create-near-app 5.3.1 → 6.0.0-beta.1

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.
Files changed (112) hide show
  1. package/dist/make.js +19 -17
  2. package/dist/messages.js +2 -2
  3. package/dist/package-json.js +17 -1
  4. package/dist/types.js +1 -1
  5. package/dist/user-input.js +16 -15
  6. package/package.json +4 -1
  7. package/templates/contracts/js/deploy.sh +6 -1
  8. package/templates/contracts/js/package-lock.json +5966 -0
  9. package/templates/contracts/js/src/contract.ts +5 -5
  10. package/templates/contracts/rust/Cargo.toml +1 -1
  11. package/templates/contracts/rust/README.md +2 -2
  12. package/templates/contracts/rust/deploy.sh +5 -0
  13. package/templates/contracts/rust/src/lib.rs +11 -11
  14. package/templates/frontend/gateway/.nvmrc +1 -0
  15. package/templates/frontend/gateway/.prettierrc +6 -0
  16. package/templates/frontend/gateway/next.config.js +15 -0
  17. package/templates/frontend/gateway/package.json +74 -0
  18. package/templates/frontend/gateway/public/apple-touch-icon.png +0 -0
  19. package/templates/frontend/gateway/public/bos-meta.png +0 -0
  20. package/templates/frontend/gateway/public/favicon.ico +0 -0
  21. package/templates/frontend/gateway/public/favicon.png +0 -0
  22. package/templates/frontend/gateway/public/fonts/FKGrotesk.woff2 +0 -0
  23. package/templates/frontend/gateway/public/fonts/Mona-Sans.woff2 +0 -0
  24. package/templates/frontend/gateway/public/logo192.png +0 -0
  25. package/templates/frontend/gateway/public/next.svg +1 -0
  26. package/templates/frontend/gateway/public/robots.txt +3 -0
  27. package/templates/frontend/gateway/public/site.webmanifest +8 -0
  28. package/templates/frontend/gateway/public/vercel.svg +1 -0
  29. package/templates/frontend/gateway/src/assets/images/near-icon.svg +3 -0
  30. package/templates/frontend/gateway/src/components/MetaTags.tsx +22 -0
  31. package/templates/frontend/gateway/src/components/component/ComponentWrapperPage.tsx +27 -0
  32. package/templates/frontend/gateway/src/components/layouts/DefaultLayout.tsx +16 -0
  33. package/templates/frontend/gateway/src/components/layouts/SimpleLayout.tsx +9 -0
  34. package/templates/frontend/gateway/src/components/lib/Button/Button.tsx +379 -0
  35. package/templates/frontend/gateway/src/components/lib/Button/index.tsx +1 -0
  36. package/templates/frontend/gateway/src/components/lib/Spinner/Spinner.tsx +33 -0
  37. package/templates/frontend/gateway/src/components/lib/Spinner/index.ts +1 -0
  38. package/templates/frontend/gateway/src/components/lib/Text/Text.tsx +14 -0
  39. package/templates/frontend/gateway/src/components/lib/Text/index.tsx +1 -0
  40. package/templates/frontend/gateway/src/components/lib/Toast/README.md +83 -0
  41. package/templates/frontend/gateway/src/components/lib/Toast/Toast.tsx +25 -0
  42. package/templates/frontend/gateway/src/components/lib/Toast/Toaster.tsx +48 -0
  43. package/templates/frontend/gateway/src/components/lib/Toast/api.ts +6 -0
  44. package/templates/frontend/gateway/src/components/lib/Toast/index.ts +3 -0
  45. package/templates/frontend/gateway/src/components/lib/Toast/store.ts +83 -0
  46. package/templates/frontend/gateway/src/components/lib/Toast/styles.ts +126 -0
  47. package/templates/frontend/gateway/src/components/navigation/Navigation.tsx +23 -0
  48. package/templates/frontend/gateway/src/components/navigation/UserDropdownMenu.tsx +209 -0
  49. package/templates/frontend/gateway/src/components/navigation/desktop/DesktopNavigation.tsx +109 -0
  50. package/templates/frontend/gateway/src/components/navigation/desktop/MainNavigationMenu.tsx +170 -0
  51. package/templates/frontend/gateway/src/components/navigation/icons/close.svg +22 -0
  52. package/templates/frontend/gateway/src/components/navigation/icons/near-icon.svg +3 -0
  53. package/templates/frontend/gateway/src/components/navigation/icons/near-logo.svg +14 -0
  54. package/templates/frontend/gateway/src/components/navigation/icons/return.svg +29 -0
  55. package/templates/frontend/gateway/src/components/navigation/icons/search.svg +3 -0
  56. package/templates/frontend/gateway/src/components/navigation/mobile/AccordionMenu.tsx +141 -0
  57. package/templates/frontend/gateway/src/components/navigation/mobile/Menu.tsx +86 -0
  58. package/templates/frontend/gateway/src/components/navigation/mobile/MobileNavigation.tsx +131 -0
  59. package/templates/frontend/gateway/src/components/navigation/navigation-categories.ts +75 -0
  60. package/templates/frontend/gateway/src/components/vm/VmCommitButton.tsx +20 -0
  61. package/templates/frontend/gateway/src/components/vm/VmComponent.tsx +29 -0
  62. package/templates/frontend/gateway/src/components/vm/VmInitializer.tsx +124 -0
  63. package/templates/frontend/gateway/src/data/components.ts +50 -0
  64. package/templates/frontend/gateway/src/data/web3.ts +292 -0
  65. package/templates/frontend/gateway/src/hooks/useBosComponents.ts +14 -0
  66. package/templates/frontend/gateway/src/hooks/useBosLoaderInitializer.ts +60 -0
  67. package/templates/frontend/gateway/src/hooks/useFlags.ts +40 -0
  68. package/templates/frontend/gateway/src/hooks/useLayout.tsx +12 -0
  69. package/templates/frontend/gateway/src/index.d.ts +9 -0
  70. package/templates/frontend/gateway/src/pages/_app.tsx +47 -0
  71. package/templates/frontend/gateway/src/pages/_document.tsx +27 -0
  72. package/templates/frontend/gateway/src/pages/dig.tsx +25 -0
  73. package/templates/frontend/gateway/src/pages/flags.tsx +83 -0
  74. package/templates/frontend/gateway/src/pages/hello-api.tsx +105 -0
  75. package/templates/frontend/gateway/src/pages/hello-component.tsx +23 -0
  76. package/templates/frontend/gateway/src/pages/hello-ethereum.tsx +23 -0
  77. package/templates/frontend/gateway/src/pages/hello-social.tsx +31 -0
  78. package/templates/frontend/gateway/src/pages/index.tsx +51 -0
  79. package/templates/frontend/gateway/src/pages/nui.tsx +25 -0
  80. package/templates/frontend/gateway/src/stores/auth.ts +29 -0
  81. package/templates/frontend/gateway/src/stores/bos-loader.ts +20 -0
  82. package/templates/frontend/gateway/src/stores/current-component.ts +11 -0
  83. package/templates/frontend/gateway/src/stores/vm.ts +24 -0
  84. package/templates/frontend/gateway/src/styles/globals.css +68 -0
  85. package/templates/frontend/gateway/src/styles/theme.css +129 -0
  86. package/templates/frontend/gateway/src/utils/config.ts +49 -0
  87. package/templates/frontend/gateway/src/utils/form-validation.ts +18 -0
  88. package/templates/frontend/gateway/src/utils/keypom-options.ts +59 -0
  89. package/templates/frontend/gateway/src/utils/route/privateRoute.tsx +20 -0
  90. package/templates/frontend/gateway/src/utils/route/signedOutRoute.tsx +21 -0
  91. package/templates/frontend/gateway/src/utils/types.ts +33 -0
  92. package/templates/frontend/gateway/tsconfig.json +24 -0
  93. package/templates/frontend/vanilla/.env +1 -0
  94. package/templates/frontend/vanilla/index.html +15 -6
  95. package/templates/frontend/vanilla/index.js +1 -1
  96. package/templates/frontend/{shared → vanilla}/near-wallet.js +2 -2
  97. package/templates/frontend/vanilla/package.json +9 -8
  98. package/templates/integration-tests/js-tests/package-lock.json +5014 -0
  99. package/templates/integration-tests/js-tests/package.json +3 -0
  100. package/templates/integration-tests/js-tests/src/main.ava.ts +6 -6
  101. package/templates/integration-tests/rust-tests/src/tests.rs +7 -7
  102. package/templates/frontend/react/App.js +0 -75
  103. package/templates/frontend/react/assets/favicon.ico +0 -0
  104. package/templates/frontend/react/assets/global.css +0 -231
  105. package/templates/frontend/react/assets/logo-black.svg +0 -1
  106. package/templates/frontend/react/assets/logo-white.svg +0 -1
  107. package/templates/frontend/react/index.html +0 -15
  108. package/templates/frontend/react/index.js +0 -23
  109. package/templates/frontend/react/package.json +0 -52
  110. package/templates/frontend/react/ui-components.js +0 -59
  111. package/templates/frontend/shared/start.sh +0 -26
  112. /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
- Your contract is storing a greeting message in the NEAR blockchain. To
22
- change it you need to sign in using the NEAR Wallet. It is very simple,
23
- just use the button below.
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 the NEAR blockchain. Check it out:
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/docs/develop/contracts/overview">smart contract</a>,
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 start</code>, the code in <code>contract/</code> gets deployed to the NEAR testnet.
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": "./start.sh",
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
- "env-cmd": "^10.1.0",
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.1.4",
22
- "@near-wallet-selector/ledger": "^8.1.4",
23
- "@near-wallet-selector/modal-ui": "^8.1.4",
24
- "@near-wallet-selector/my-near-wallet": "^8.1.4",
25
- "@near-wallet-selector/near-wallet": "^8.1.4",
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
  }