From 0e15e7e6a67b1b20009d6fa409e323cd97a936ce Mon Sep 17 00:00:00 2001 From: Franck Date: Tue, 21 Dec 2021 15:17:23 +1100 Subject: [PATCH 1/6] Setup mainnet example with DAI --- packages/mainnet-poll-example/.eslintrc.json | 5 + packages/mainnet-poll-example/.mocharc.json | 8 ++ packages/mainnet-poll-example/README.md | 72 +++++++++++++++ packages/mainnet-poll-example/package.json | 62 +++++++++++++ .../mainnet-poll-example/prettier.config.js | 1 + packages/mainnet-poll-example/src/_redirects | 1 + .../src/assets/assets.d.ts | 14 +++ .../src/assets/images/pollingIcon.png | Bin 0 -> 24674 bytes .../src/components/WakuPolling.tsx | 79 ++++++++++++++++ packages/mainnet-poll-example/src/index.html | 16 ++++ packages/mainnet-poll-example/src/index.tsx | 87 ++++++++++++++++++ .../mainnet-poll-example/test/index.test.ts | 7 ++ packages/mainnet-poll-example/test/setup.ts | 0 packages/mainnet-poll-example/tsconfig.json | 25 +++++ 14 files changed, 377 insertions(+) create mode 100644 packages/mainnet-poll-example/.eslintrc.json create mode 100644 packages/mainnet-poll-example/.mocharc.json create mode 100644 packages/mainnet-poll-example/README.md create mode 100644 packages/mainnet-poll-example/package.json create mode 100644 packages/mainnet-poll-example/prettier.config.js create mode 100644 packages/mainnet-poll-example/src/_redirects create mode 100644 packages/mainnet-poll-example/src/assets/assets.d.ts create mode 100644 packages/mainnet-poll-example/src/assets/images/pollingIcon.png create mode 100644 packages/mainnet-poll-example/src/components/WakuPolling.tsx create mode 100644 packages/mainnet-poll-example/src/index.html create mode 100644 packages/mainnet-poll-example/src/index.tsx create mode 100644 packages/mainnet-poll-example/test/index.test.ts create mode 100644 packages/mainnet-poll-example/test/setup.ts create mode 100644 packages/mainnet-poll-example/tsconfig.json diff --git a/packages/mainnet-poll-example/.eslintrc.json b/packages/mainnet-poll-example/.eslintrc.json new file mode 100644 index 0000000..128cd29 --- /dev/null +++ b/packages/mainnet-poll-example/.eslintrc.json @@ -0,0 +1,5 @@ +{ + "extends": [ + "../../.eslintrc.json" + ] +} diff --git a/packages/mainnet-poll-example/.mocharc.json b/packages/mainnet-poll-example/.mocharc.json new file mode 100644 index 0000000..59d511f --- /dev/null +++ b/packages/mainnet-poll-example/.mocharc.json @@ -0,0 +1,8 @@ +{ + "spec": "test/**/*.test.{ts,tsx}", + "require": "ts-node/register", + "watchExtensions": "ts", + "extension": "ts", + "timeout": 3000, + "file": "./test/setup.ts" +} diff --git a/packages/mainnet-poll-example/README.md b/packages/mainnet-poll-example/README.md new file mode 100644 index 0000000..c5b4ee9 --- /dev/null +++ b/packages/mainnet-poll-example/README.md @@ -0,0 +1,72 @@ +# DappConnect Poll SDK Example + +This package is example usage of WakuPolling + +Example uses usedapp for exposing web3 provider + +For using usedapp please see usedapp docs + +## creating WakuPolling object + +to create waku polling object you can just use react hook + +``` +const wakuPolling = useWakuPolling( + appName, + tokenaddress, + library, + multicallAddress + ) +``` + +it is a good idea for token address and multicall address to be dependent on current chainId. + +useWakuPolling creates a new WakuPolling object whenever chainId changes. + +## creating new poll + +to create new poll you can use `createTimedPoll` function from WakuPolling class + +``` +wakuPolling.createTimedPoll( + question, + answers, + selectedType, + undefined, + endTime + ) +``` + +If you want you can use already created modal component for creating polls + +``` +const [showPollCreation, setShowPollCreation] = useState(false) +. +. +. +{showPollCreation && ( + + )} +``` + +### showing polls + +to show list of polls you can either use `PollList` component from polling-component + +``` + +``` + +If you want to create your own react component please use + +``` +usePollList(wakuPolling: WakuPolling | undefined) +``` + +Which returns memoized DetailedTimedPoll[] array. + +Waku polling also exposes `getDetailedTimedPolls` + +``` +const DetailedTimedPolls = await wakuPolling.getDetailedTimedPolls() +``` diff --git a/packages/mainnet-poll-example/package.json b/packages/mainnet-poll-example/package.json new file mode 100644 index 0000000..6fe1de5 --- /dev/null +++ b/packages/mainnet-poll-example/package.json @@ -0,0 +1,62 @@ +{ + "name": "@dappconnect/mainnet-poll-sdk-example", + "version": "0.1.0", + "main": "dist/cjs/src/index.js", + "module": "dist/esm/src/index.js", + "types": "dist/esm/src/index.d.ts", + "license": "MIT", + "watch": { + "build": { + "patterns": ["src"], + "extensions": "ts,tsx", + "runOnChangeOnly": false + } + }, + "scripts": { + "watch": "yarn npm-watch", + "clean:all": "yarn clean && rimraf node_modules/", + "clean": "rimraf dist/", + "copy-assets": "yarn copy-files:cjs && yarn copy-files:esm", + "copy-files:cjs": "copyfiles -u 1 src/**/*.svg src/**/*.png dist/cjs/src", + "copy-files:esm": "copyfiles -u 1 src/**/*.svg src/**/*.png dist/esm/src", + "build": "yarn build:all && yarn copy-assets", + "build:all": "yarn run build:esm && yarn run build:cjs", + "build:esm": "tsc --module es2020 --target es2017 --outDir dist/esm", + "build:cjs": "tsc --outDir dist/cjs", + "test": "mocha -r jsdom-global/register", + "lint": "yarn lint:prettier --check && yarn lint:eslint", + "lint:fix": "yarn lint:prettier --write && yarn lint:eslint --fix", + "lint:eslint": "eslint './{src,test}/**/*.{ts,tsx}'", + "lint:prettier": "yarn prettier './{src,test}/**/*.{ts,tsx}'" + }, + "dependencies": { + "@dappconnect/vote-poll-sdk-core": "^0.1.0", + "@dappconnect/poll-sdk-react-components": "^0.1.0", + "@dappconnect/poll-sdk-react-hooks": "^0.1.0", + "@dappconnect/vote-poll-sdk-react-components": "^0.1.0", + "@usedapp/core": "^0.4.7", + "ethers": "^5.4.4", + "react": "^17.0.2", + "react-dom": "^17.0.2", + "react-router-dom": "^5.2.0", + "styled-components": "^5.3.0" + }, + "devDependencies": { + "@types/chai": "^4.2.21", + "@types/mocha": "^9.0.0", + "@types/react": "^17.0.16", + "@types/styled-components": "^5.1.12", + "@typescript-eslint/eslint-plugin": "^4.29.0", + "@typescript-eslint/parser": "^4.29.0", + "chai": "^4.3.4", + "copyfiles": "^2.4.1", + "eslint": "^7.32.0", + "jsdom": "^16.7.0", + "jsdom-global": "^3.0.2", + "mocha": "^9.0.3", + "npm-watch": "^0.11.0", + "rimraf": "^3.0.2", + "ts-node": "^10.1.0", + "typescript": "^4.3.5" + } +} diff --git a/packages/mainnet-poll-example/prettier.config.js b/packages/mainnet-poll-example/prettier.config.js new file mode 100644 index 0000000..3bcd29e --- /dev/null +++ b/packages/mainnet-poll-example/prettier.config.js @@ -0,0 +1 @@ +module.exports = require('../../.prettierrc.json') diff --git a/packages/mainnet-poll-example/src/_redirects b/packages/mainnet-poll-example/src/_redirects new file mode 100644 index 0000000..ad37e2c --- /dev/null +++ b/packages/mainnet-poll-example/src/_redirects @@ -0,0 +1 @@ +/* /index.html 200 diff --git a/packages/mainnet-poll-example/src/assets/assets.d.ts b/packages/mainnet-poll-example/src/assets/assets.d.ts new file mode 100644 index 0000000..4ce4da1 --- /dev/null +++ b/packages/mainnet-poll-example/src/assets/assets.d.ts @@ -0,0 +1,14 @@ +declare module '*.svg' { + const url: string + export default url +} + +declare module '*.jpg' { + const url: string + export default url +} + +declare module '*.png' { + const url: string + export default url +} diff --git a/packages/mainnet-poll-example/src/assets/images/pollingIcon.png b/packages/mainnet-poll-example/src/assets/images/pollingIcon.png new file mode 100644 index 0000000000000000000000000000000000000000..153425035c4504a1078569919ff44531380c3762 GIT binary patch literal 24674 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ℜ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 E2NHk + {showPollCreation && signer && ( + + )} + {account ? ( + setShowPollCreation(true)}> + Create a poll + + ) : ( + { + if ((window as any)?.ethereum) { + activateBrowserWallet() + } else setSelectConnect(true) + }} + > + Connect to vote + + )} + {selectConnect && ( + + + + )} + + + + ) +} + +const Wrapper = styled.div` + display: flex; + flex-direction: column; + align-items: center; + max-width: 1146px; + position: relative; + margin: 0 auto; + padding: 150px 32px 50px; + width: 100%; + @media (max-width: 1146px) { + max-width: 780px; + } + @media (max-width: 600px) { + padding: 132px 16px 32px; + } + @media (max-width: 425px) { + padding: 96px 16px 84px; + } +` diff --git a/packages/mainnet-poll-example/src/index.html b/packages/mainnet-poll-example/src/index.html new file mode 100644 index 0000000..067de06 --- /dev/null +++ b/packages/mainnet-poll-example/src/index.html @@ -0,0 +1,16 @@ + + + + + + + + + Polling Dapp + + +
+ + + + diff --git a/packages/mainnet-poll-example/src/index.tsx b/packages/mainnet-poll-example/src/index.tsx new file mode 100644 index 0000000..1b72691 --- /dev/null +++ b/packages/mainnet-poll-example/src/index.tsx @@ -0,0 +1,87 @@ +import React, { useEffect, useState } from 'react' +import styled from 'styled-components' +import { DAppProvider, ChainId, useEthers } from '@usedapp/core' +import { DEFAULT_CONFIG } from '@usedapp/core/dist/cjs/src/model/config/default' +import { WakuPolling } from './components/WakuPolling' +import { TopBar, GlobalStyle } from '@dappconnect/vote-poll-sdk-react-components' +import pollingIcon from './assets/images/pollingIcon.png' +import { JsonRpcSigner } from '@ethersproject/providers' +import { orangeTheme } from '@dappconnect/vote-poll-sdk-react-components/dist/esm/src/style/themes' +import ReactDOM from "react-dom" +import {BrowserRouter} from "react-router-dom" +import {Route, Switch} from "react-router" + +const daiTokenContract = "0x6B175474E89094C44Da98b954EedeAC495271d0F"; + +const config = { + readOnlyChainId: ChainId.Mainnet, + readOnlyUrls: { + [ChainId.Mainnet]: 'https://infura.io/v3/b4451d780cc64a078ccf2181e872cfcf', + }, + multicallAddresses: { + 1: '0xeefba1e63905ef1d7acba5a8513c70307c1ce441', + 3: '0x53c43764255c17bd724f74c4ef150724ac50a3ed', + 1337: process.env.GANACHE_MULTICALL_CONTRACT ?? '0x0000000000000000000000000000000000000000', + }, + supportedChains: [...DEFAULT_CONFIG.supportedChains, 1337], + notifications: { + checkInterval: 500, + expirationPeriod: 50000, + }, +} + +export function Polling({tokenAddress}: {tokenAddress: string}) { + const { account, library, activateBrowserWallet, deactivate } = useEthers() + const [signer, setSigner] = useState(undefined) + + useEffect(() => { + setSigner(library?.getSigner()) + }, [account]) + + return ( + + + + + ) +} + +export function DaiPollingPage() { + return ( + + + + + + + ) +} + +const Page = styled.div` + height: 100%; + width: 100%; +` + +const Wrapper = styled.div` + height: 100%; + width: 100%; +` + +ReactDOM.render( +
+ + + + + +
, + document.getElementById('root') +) diff --git a/packages/mainnet-poll-example/test/index.test.ts b/packages/mainnet-poll-example/test/index.test.ts new file mode 100644 index 0000000..1dba999 --- /dev/null +++ b/packages/mainnet-poll-example/test/index.test.ts @@ -0,0 +1,7 @@ +import { expect } from 'chai' + +describe('test react-components', () => { + it('foo', async () => { + expect('Hello world').to.eq('Hello world') + }) +}) diff --git a/packages/mainnet-poll-example/test/setup.ts b/packages/mainnet-poll-example/test/setup.ts new file mode 100644 index 0000000..e69de29 diff --git a/packages/mainnet-poll-example/tsconfig.json b/packages/mainnet-poll-example/tsconfig.json new file mode 100644 index 0000000..4bd6269 --- /dev/null +++ b/packages/mainnet-poll-example/tsconfig.json @@ -0,0 +1,25 @@ +{ + "compilerOptions": { + "outDir": "dist", + "jsx":"react", + "esModuleInterop": true, + "moduleResolution": "node", + "resolveJsonModule": true, + "skipLibCheck": true, + "downlevelIteration": true, + "strict": true, + "composite": true, + "declaration": true, + "sourceMap": true, + "declarationMap": true, + "module": "commonjs", + "forceConsistentCasingInFileNames": true, + "target": "es6", + "typeRoots": [ "./types", "./node_modules/@types", "../../node_modules/@types"] + }, + "include": [ + "src", + "src/**/*.json", + "test" + ] +} From 1fe89fe8a94556ecd8ed3ded1af724c84bd4dc13 Mon Sep 17 00:00:00 2001 From: Franck Date: Wed, 22 Dec 2021 09:49:57 +1100 Subject: [PATCH 2/6] Use url path to get ERC20 contract --- packages/mainnet-poll-example/package.json | 21 +---- .../src/components/WakuPolling.tsx | 7 +- packages/mainnet-poll-example/src/index.tsx | 36 ++++---- .../mainnet-poll-example/webpack.config.js | 82 +++++++++++++++++++ 4 files changed, 104 insertions(+), 42 deletions(-) create mode 100644 packages/mainnet-poll-example/webpack.config.js diff --git a/packages/mainnet-poll-example/package.json b/packages/mainnet-poll-example/package.json index 6fe1de5..080f09e 100644 --- a/packages/mainnet-poll-example/package.json +++ b/packages/mainnet-poll-example/package.json @@ -1,28 +1,13 @@ { "name": "@dappconnect/mainnet-poll-sdk-example", "version": "0.1.0", - "main": "dist/cjs/src/index.js", - "module": "dist/esm/src/index.js", - "types": "dist/esm/src/index.d.ts", + "main": "index.js", "license": "MIT", - "watch": { - "build": { - "patterns": ["src"], - "extensions": "ts,tsx", - "runOnChangeOnly": false - } - }, "scripts": { - "watch": "yarn npm-watch", "clean:all": "yarn clean && rimraf node_modules/", "clean": "rimraf dist/", - "copy-assets": "yarn copy-files:cjs && yarn copy-files:esm", - "copy-files:cjs": "copyfiles -u 1 src/**/*.svg src/**/*.png dist/cjs/src", - "copy-files:esm": "copyfiles -u 1 src/**/*.svg src/**/*.png dist/esm/src", - "build": "yarn build:all && yarn copy-assets", - "build:all": "yarn run build:esm && yarn run build:cjs", - "build:esm": "tsc --module es2020 --target es2017 --outDir dist/esm", - "build:cjs": "tsc --outDir dist/cjs", + "build": "rm -rf dist && webpack --mode=production --env ENV=production", + "start": "webpack serve --mode=development --env ENV=development --https --port 8181", "test": "mocha -r jsdom-global/register", "lint": "yarn lint:prettier --check && yarn lint:eslint", "lint:fix": "yarn lint:prettier --write && yarn lint:eslint --fix", diff --git a/packages/mainnet-poll-example/src/components/WakuPolling.tsx b/packages/mainnet-poll-example/src/components/WakuPolling.tsx index b2cbf8f..dcf8e8a 100644 --- a/packages/mainnet-poll-example/src/components/WakuPolling.tsx +++ b/packages/mainnet-poll-example/src/components/WakuPolling.tsx @@ -20,12 +20,7 @@ export function WakuPolling({ appName, signer, theme, tokenAddress }: WakuPollin const config = useConfig() const [showPollCreation, setShowPollCreation] = useState(false) const [selectConnect, setSelectConnect] = useState(false) - const wakuPolling = useWakuPolling( - appName, - tokenAddress, - library, - config?.multicallAddresses?.[chainId ?? 1337] - ) + const wakuPolling = useWakuPolling(appName, tokenAddress, library, config?.multicallAddresses?.[chainId ?? 1337]) return ( {showPollCreation && signer && ( diff --git a/packages/mainnet-poll-example/src/index.tsx b/packages/mainnet-poll-example/src/index.tsx index 1b72691..b410dda 100644 --- a/packages/mainnet-poll-example/src/index.tsx +++ b/packages/mainnet-poll-example/src/index.tsx @@ -7,16 +7,14 @@ import { TopBar, GlobalStyle } from '@dappconnect/vote-poll-sdk-react-components import pollingIcon from './assets/images/pollingIcon.png' import { JsonRpcSigner } from '@ethersproject/providers' import { orangeTheme } from '@dappconnect/vote-poll-sdk-react-components/dist/esm/src/style/themes' -import ReactDOM from "react-dom" -import {BrowserRouter} from "react-router-dom" -import {Route, Switch} from "react-router" - -const daiTokenContract = "0x6B175474E89094C44Da98b954EedeAC495271d0F"; +import ReactDOM from 'react-dom' +import { BrowserRouter, useParams } from 'react-router-dom' +import { Route, Switch } from 'react-router' const config = { readOnlyChainId: ChainId.Mainnet, readOnlyUrls: { - [ChainId.Mainnet]: 'https://infura.io/v3/b4451d780cc64a078ccf2181e872cfcf', + [ChainId.Mainnet]: 'https://mainnet.infura.io/v3/b4451d780cc64a078ccf2181e872cfcf', }, multicallAddresses: { 1: '0xeefba1e63905ef1d7acba5a8513c70307c1ce441', @@ -30,7 +28,7 @@ const config = { }, } -export function Polling({tokenAddress}: {tokenAddress: string}) { +export function Polling({ tokenAddress }: { tokenAddress: string }) { const { account, library, activateBrowserWallet, deactivate } = useEthers() const [signer, setSigner] = useState(undefined) @@ -43,7 +41,7 @@ export function Polling({tokenAddress}: {tokenAddress: string}) { () + return ( - + ) @@ -76,12 +76,12 @@ const Wrapper = styled.div` ` ReactDOM.render( -
- - - - - -
, - document.getElementById('root') +
+ + + + + +
, + document.getElementById('root') ) diff --git a/packages/mainnet-poll-example/webpack.config.js b/packages/mainnet-poll-example/webpack.config.js new file mode 100644 index 0000000..cc8a6a8 --- /dev/null +++ b/packages/mainnet-poll-example/webpack.config.js @@ -0,0 +1,82 @@ +const path = require('path') +const HtmlWebpackPlugin = require('html-webpack-plugin') +const ForkTsCheckerWebpackPlugin = require('fork-ts-checker-webpack-plugin') +const webpack = require('webpack') +const { ESBuildMinifyPlugin } = require('esbuild-loader') + +module.exports = (env) => { + let environment = 'development' + if (env.ENV) { + environment = env.ENV + } + + return { + entry: './src/index.tsx', + output: { + filename: 'index.[fullhash].js', + path: path.join(__dirname, 'dist'), + publicPath: "/", + }, + devtool: 'source-map', + resolve: { + extensions: ['.ts', '.tsx', '.js', '.json'], + fallback: { + "buffer": require.resolve("buffer/"), + "crypto": require.resolve("crypto-browserify"), + "stream": require.resolve("stream-browserify"), + "assert": require.resolve("assert") + } + }, + module: { + rules: [ + { + test: /\.tsx?$/, + loader: 'esbuild-loader', + exclude: /node_modules/, + options: { + loader: 'tsx', + target: 'es2018', + }, + }, + { + enforce: 'pre', + test: /\.js$/, + exclude: /node_modules/, + loader: 'source-map-loader' + }, + { + test: /\.(png|svg|jpg|gif|woff|woff2|eot|ttf|otf|ico)$/, + use: ['file-loader'], + }, + ], + }, + optimization: { + minimizer: [ + new ESBuildMinifyPlugin({ + target: 'es2018', + }), + ], + }, + plugins: [ + new ForkTsCheckerWebpackPlugin(), + new HtmlWebpackPlugin({ + template: 'src/index.html', + }), + new webpack.DefinePlugin({ + 'process.env.ENV': JSON.stringify(environment), + }), + new webpack.ProvidePlugin({ + process: 'process/browser.js', + Buffer: ['buffer', 'Buffer'], + }), + ], + devServer: { + historyApiFallback: true, + host: '0.0.0.0', + stats: 'errors-only', + overlay: true, + hot: true, + }, + stats: 'minimal' + } +} \ No newline at end of file From b081895cb219643b1e538d62aafac583d6811729 Mon Sep 17 00:00:00 2001 From: Franck Date: Wed, 22 Dec 2021 11:06:55 +1100 Subject: [PATCH 3/6] Update readme --- packages/mainnet-poll-example/README.md | 73 +------------------------ 1 file changed, 1 insertion(+), 72 deletions(-) diff --git a/packages/mainnet-poll-example/README.md b/packages/mainnet-poll-example/README.md index c5b4ee9..58e5604 100644 --- a/packages/mainnet-poll-example/README.md +++ b/packages/mainnet-poll-example/README.md @@ -1,72 +1 @@ -# DappConnect Poll SDK Example - -This package is example usage of WakuPolling - -Example uses usedapp for exposing web3 provider - -For using usedapp please see usedapp docs - -## creating WakuPolling object - -to create waku polling object you can just use react hook - -``` -const wakuPolling = useWakuPolling( - appName, - tokenaddress, - library, - multicallAddress - ) -``` - -it is a good idea for token address and multicall address to be dependent on current chainId. - -useWakuPolling creates a new WakuPolling object whenever chainId changes. - -## creating new poll - -to create new poll you can use `createTimedPoll` function from WakuPolling class - -``` -wakuPolling.createTimedPoll( - question, - answers, - selectedType, - undefined, - endTime - ) -``` - -If you want you can use already created modal component for creating polls - -``` -const [showPollCreation, setShowPollCreation] = useState(false) -. -. -. -{showPollCreation && ( - - )} -``` - -### showing polls - -to show list of polls you can either use `PollList` component from polling-component - -``` - -``` - -If you want to create your own react component please use - -``` -usePollList(wakuPolling: WakuPolling | undefined) -``` - -Which returns memoized DetailedTimedPoll[] array. - -Waku polling also exposes `getDetailedTimedPolls` - -``` -const DetailedTimedPolls = await wakuPolling.getDetailedTimedPolls() -``` +# Mainnet DappConnect Poll SDK Example From 2bf0d0dcd1de704f3d993b342783d1a9eea40f0b Mon Sep 17 00:00:00 2001 From: Franck Date: Wed, 22 Dec 2021 15:22:37 +1100 Subject: [PATCH 4/6] Use query parameters to pass token address --- packages/mainnet-poll-example/src/index.tsx | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/packages/mainnet-poll-example/src/index.tsx b/packages/mainnet-poll-example/src/index.tsx index b410dda..05a5004 100644 --- a/packages/mainnet-poll-example/src/index.tsx +++ b/packages/mainnet-poll-example/src/index.tsx @@ -8,8 +8,11 @@ import pollingIcon from './assets/images/pollingIcon.png' import { JsonRpcSigner } from '@ethersproject/providers' import { orangeTheme } from '@dappconnect/vote-poll-sdk-react-components/dist/esm/src/style/themes' import ReactDOM from 'react-dom' -import { BrowserRouter, useParams } from 'react-router-dom' +import { BrowserRouter } from 'react-router-dom' import { Route, Switch } from 'react-router' +import { useLocation } from 'react-router-dom' + +const sntTokenAddress = '0x744d70FDBE2Ba4CF95131626614a1763DF805B9E' const config = { readOnlyChainId: ChainId.Mainnet, @@ -41,7 +44,7 @@ export function Polling({ tokenAddress }: { tokenAddress: string }) { () + const location = useLocation() + const tokenAddress = new URLSearchParams(location.search).get('token') return ( - + ) @@ -79,7 +83,7 @@ ReactDOM.render(
- +
, From b1ef502e9570247583ee60a78aede195b5abaf94 Mon Sep 17 00:00:00 2001 From: Franck Date: Wed, 22 Dec 2021 15:42:05 +1100 Subject: [PATCH 5/6] Set default poll duration to one week --- .../poll-react-components/src/components/PollCreation.tsx | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/packages/poll-react-components/src/components/PollCreation.tsx b/packages/poll-react-components/src/components/PollCreation.tsx index b7bda20..35c7ce0 100644 --- a/packages/poll-react-components/src/components/PollCreation.tsx +++ b/packages/poll-react-components/src/components/PollCreation.tsx @@ -5,6 +5,8 @@ import { WakuPolling } from '@dappconnect/vote-poll-sdk-core' import { Input, addIcon, SmallButton, Modal, Theme } from '@dappconnect/vote-poll-sdk-react-components' import { MESSAGE_SENDING_RESULT } from '@dappconnect/vote-poll-sdk-core/dist/esm/src/classes/WakuPolling' +const defaultPollDuration = 7 * 24 * 60 * 60 * 1000 // One week in ms. + function getLocaleIsoTime(dateTime: Date) { const MS_PER_MINUTE = 60000 const milliseconds = dateTime.getTime() - dateTime.getTimezoneOffset() * MS_PER_MINUTE @@ -45,7 +47,7 @@ export function PollCreation({ wakuPolling, theme, setShowPollCreation }: PollCr const [showCreateConfirmation, setShowCreateConfirmation] = useState(false) const [showNotEnoughTokens, setShowNotEnoughTokens] = useState(false) const [selectedType, setSelectedType] = useState(PollType.NON_WEIGHTED) - const [endTimePicker, setEndTimePicker] = useState(new Date(new Date().getTime() + 10000000)) + const [endTimePicker, setEndTimePicker] = useState(new Date(new Date().getTime() + defaultPollDuration)) return ( From 2634f8ff91882854f2510433c3a8c8bb19e63d23 Mon Sep 17 00:00:00 2001 From: Franck Date: Wed, 22 Dec 2021 15:50:22 +1100 Subject: [PATCH 6/6] Do not allow to vote without selecting an answer --- packages/poll-react-components/src/components/Poll.tsx | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/packages/poll-react-components/src/components/Poll.tsx b/packages/poll-react-components/src/components/Poll.tsx index 3ad6c79..272c7d0 100644 --- a/packages/poll-react-components/src/components/Poll.tsx +++ b/packages/poll-react-components/src/components/Poll.tsx @@ -55,12 +55,12 @@ export function Poll({ poll, wakuPolling, theme, account }: PollProps) { {userInVoters < 0 && ( { - if (wakuPolling && account) { + if (wakuPolling && account && selectedAnswer !== undefined) { const result = await wakuPolling.sendTimedPollVote( poll.poll.id, - selectedAnswer ?? 0, + selectedAnswer, poll.poll.pollType === PollType.WEIGHTED ? BigNumber.from(tokenAmount) : undefined ) if (result === 1) {