diff --git a/.eslintrc.cjs b/.eslintrc.cjs deleted file mode 100644 index 0be2eda90045..000000000000 --- a/.eslintrc.cjs +++ /dev/null @@ -1,30 +0,0 @@ -// Copyright 2017-2023 @polkadot/apps authors & contributors -// SPDX-License-Identifier: Apache-2.0 - -const base = require('@polkadot/dev/config/eslint.cjs'); - -// add override for any (a metric ton of them, initial conversion) -module.exports = { - ...base, - ignorePatterns: [ - ...base.ignorePatterns, - 'jest/**/*', - 'scripts/**/*', - '*.cjs' - ], - parserOptions: { - ...base.parserOptions, - project: [ - './tsconfig.eslint.json' - ] - }, - rules: { - ...base.rules, - // needs to be switched on at some point - '@typescript-eslint/no-explicit-any': 'off', - // this seems very broken atm, false positives - '@typescript-eslint/unbound-method': 'off', - 'header/header' : 'off', - 'react/jsx-newline': 'off', - } -}; diff --git a/.github/chain-types.md b/.github/chain-types.md deleted file mode 100644 index 4774398317ad..000000000000 --- a/.github/chain-types.md +++ /dev/null @@ -1,10 +0,0 @@ ---- -title: Outdated chain types -labels: ['ci'] ---- - -cc @polkadot-js/notifications - -Some configured chains have outdated types and is determined to problematic as an available chain. - -Check the nightly cron output (or via `yarn ci:chainTypes` locally) and disable the chains (either with `isDisabled` or `isUnreachable`) until the issue is resolved. The output as found from the test includes: diff --git a/.github/workflows/chain-endpoints.yml b/.github/workflows/chain-endpoints.yml index f262dd8d20ac..bfbfa93167f1 100644 --- a/.github/workflows/chain-endpoints.yml +++ b/.github/workflows/chain-endpoints.yml @@ -1,7 +1,10 @@ name: Chain endpoints on: schedule: - - cron: '50 0/12 * * *' + # twice daily (mornings/afternoons, the latter being busy) + # - cron: '50 0/12 * * *' + # once daily (early mornings, 02:50 GMT, generally not busy) + - cron: '50 2 * * *' jobs: endpoints: diff --git a/.github/workflows/chain-types.yml b/.github/workflows/chain-types.yml deleted file mode 100644 index 2f872a78bfc1..000000000000 --- a/.github/workflows/chain-types.yml +++ /dev/null @@ -1,28 +0,0 @@ -name: Chain types -on: - schedule: - - cron: '30 0/12 * * *' - -jobs: - types: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v3 - - uses: actions/setup-node@v3 - with: - node-version: 'lts/*' - - name: check - env: - CI_LOG: 123 - run: | - yarn install --immutable | grep -v 'YN0013' - yarn ci:chainTypes - - - name: issue - if: ${{ failure() }} - uses: JasonEtco/create-an-issue@e27dddc79c92bc6e4562f268fffa5ed752639abd - env: - GITHUB_TOKEN: ${{ secrets.GH_PAT_BOT }} - with: - filename: .github/chain-types.md - update_existing: true diff --git a/.github/workflows/lock.yml b/.github/workflows/lock.yml deleted file mode 100644 index 5f7400fabfbf..000000000000 --- a/.github/workflows/lock.yml +++ /dev/null @@ -1,23 +0,0 @@ -name: 'Lock Threads' - -on: - schedule: - - cron: '15 2/3 * * *' - -jobs: - lock: - runs-on: ubuntu-latest - steps: - - uses: dessant/lock-threads@c1b35aecc5cdb1a34539d14196df55838bb2f836 - with: - github-token: ${{ secrets.GH_PAT_BOT }} - issue-inactive-days: '7' - issue-comment: > - This thread has been automatically locked since there has not been - any recent activity after it was closed. Please open a new issue - if you think you have a related problem or query. - pr-inactive-days: '2' - pr-comment: > - This pull request has been automatically locked since there - has not been any recent activity after it was closed. - Please open a new issue for related bugs. diff --git a/.github/workflows/pr-any.yml b/.github/workflows/pr-any.yml index 39ec0242593a..81d907cea7e9 100644 --- a/.github/workflows/pr-any.yml +++ b/.github/workflows/pr-any.yml @@ -17,5 +17,5 @@ jobs: node-version: 'lts/*' - name: ${{ matrix.step }} run: | - yarn install --immutable | grep -v 'YN0013' + yarn install --immutable yarn ${{ matrix.step }} diff --git a/.github/workflows/push-master.yml b/.github/workflows/push-master.yml index be20c3e70876..bbd3ae9cd03a 100644 --- a/.github/workflows/push-master.yml +++ b/.github/workflows/push-master.yml @@ -32,7 +32,7 @@ jobs: PINATA_API_KEY: ${{ secrets.PINATA_API_KEY }} PINATA_SECRET_KEY: ${{ secrets.PINATA_SECRET_KEY }} run: | - yarn install --immutable | grep -v 'YN0013' + yarn install --immutable yarn ${{ matrix.step }} # only run on "CI skip", i.e. when the actual version has been bumped to release/stable @@ -84,6 +84,7 @@ jobs: # GitHub token, automatically provided to the action # (No need to define this secret in the repo settings) github_token: ${{ secrets.GITHUB_TOKEN }} + args: '--project packages/apps-electron' build_script_name: build:release:electron # If the commit is tagged with a version (e.g. "v1.0.0"), # release the app after building diff --git a/.github/workflows/test-nightly.yml b/.github/workflows/test-nightly.yml index b1bc14de468d..d76dba7af0fa 100644 --- a/.github/workflows/test-nightly.yml +++ b/.github/workflows/test-nightly.yml @@ -18,5 +18,5 @@ jobs: node-version: 'lts/*' - name: ${{ matrix.step }} run: | - yarn install --immutable | grep -v 'YN0013' + yarn install --immutable yarn ${{ matrix.step }} diff --git a/.nvmrc b/.nvmrc index b6a7d89c68e0..932b2b01d712 100644 --- a/.nvmrc +++ b/.nvmrc @@ -1 +1 @@ -16 +18.15 diff --git a/.vscode/settings.json b/.vscode/settings.json new file mode 100644 index 000000000000..688d936a965a --- /dev/null +++ b/.vscode/settings.json @@ -0,0 +1,4 @@ +{ + "eslint.enable": true, + "eslint.experimental.useFlatConfig": true +} diff --git a/.yarnrc.yml b/.yarnrc.yml index 21d7e170de9d..1c6274c50286 100644 --- a/.yarnrc.yml +++ b/.yarnrc.yml @@ -2,6 +2,11 @@ enableImmutableInstalls: false enableProgressBars: false +logFilters: + # Discard any "cannot be found in cache" messages + - code: YN0013 + level: discard + nodeLinker: node-modules plugins: diff --git a/CHANGELOG.md b/CHANGELOG.md index 2cabf36c9aed..505bd1036351 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,10 +1,132 @@ # CHANGELOG -## master +## 0.132.1 Jun 19, 2023 + +Contributed: + +- Add Karmachain testnet endpoints (Thanks to https://github.com/HolyGrease) +- Adjust Subscocial endpoints (Thanks to https://github.com/olehmell) +- Update RadiumBlock Polkadot endpoints (Thanks to https://github.com/radiumb) +- Add RadiumBlock Collectives endpoints (Thanks to https://github.com/radiumb) +- Update RadiumBlock Westend endpoints (Thanks to https://github.com/radiumb) +- Update Liebi Rococo endpoints (Thanks to https://github.com/TomatoAres) +- Add Dwellir endpoint for Interlay (Thanks to https://github.com/jonathanudd) +- Add Stakeworld endpoints for AssetHub (Thanks to https://github.com/stakeworld) +- Add Stakeworld endpoints for BridgeHub (Thanks to https://github.com/stakeworld) +- Additional chains for external Sub.ID links (Thanks to https://github.com/olehmell) +- Add Subsquare links for Collectives (Thanks to https://github.com/wliyongfeng) +- Add Subsquare links for Bifrost (Thanks to https://github.com/wliyongfeng) +- Add endpoint for Krest network (Thanks to https://github.com/sfffaaa) +- Add endpoint for Peaq network (Thanks to https://github.com/sfffaaa) +- Expand supported Dwellir networks (Thanks to https://github.com/jonathanudd) +- Add Darwinia community provider (Thanks to https://github.com/fewensa) +- Fix JSONRPC payload creation (Thanks to https://github.com/pmikolajczyk41) +- Expand Legacy ETH support (Thanks to https://github.com/sirius651) +- Add Jur chain (Thanks to https://github.com/ashi20192020) +- Rename State* to AssetHub (Thanks to https://github.com/BulatSaif) +- Add Polkaseembly links for Collectives (Thanks to https://github.com/rajdeep7Singh) +- Re-active teleport with Xcm V3 support (Thanks to https://github.com/loanMaster) + +Changes: + +- Disable unreachable endpoints +- Extend chain config with ui logo overrides +- Adjust Enum inputs with unsued filtering + + +## 0.131.4 May 23, 2023 + +Changes: + +- Attempt fix for electron build (Linux executable name) + + +## 0.131.3 May 23, 2023 + +Changes: + +- Attempt fix for electron build (Linux executable name) + + +## 0.131.2 May 23, 2023 + +Changes: + +- Attempt fix for electron build (Mac entitlements) + + +## 0.131.1 May 23, 2023 + +Contributed: + +- Extend links for Polkassembly (Thanks to https://github.com/niklabh) +- Add Subsquare links for Darwinia2 (Thanks to https://github.com/wliyongfeng) +- Update Mangata Kusama endpoints (Thanks to https://github.com/tenequm) +- Add JurNode testnet (Thanks to https://github.com/ashi20192020) +- Add Ethereum support for Ferrum (Thanks to https://github.com/3ierratango) +- Add Gens parachain (Thanks to https://github.com/alex-nax) +- Add Dwellir endpoint for Kapex (Thanks to https://github.com/jonathanudd) +- Add Phala Rococo parachain (Thanks to https://github.com/tolak) +- Add Societal Rococo parachain (Thanks to https://github.com/okalenyk) +- Restore Nodle testnet endpoint (Thanks to https://github.com/simonsso) + +Changes: + +- Cater for current Substrate bonding extrinsic arguments +- Add basic NIS dashboard +- Break circular dependencies, use composite tsconfig +- Adjust electron build to use `--project` specifiers +- Disable unreachable endpoints + + +## 0.130.1 May 9, 2023 + +Contributed: + +- OnFinality Ajuna endpoint (Thanks to https://github.com/jamesbayly) +- OnFinality Basilisk endpoint (Thanks to https://github.com/jamesbayly) +- Dwellir Phala endpoint (Thanks to https://github.com/Maharacha) +- LuckyFriday Polkadot endpoint (Thanks to https://github.com/paradox-tt) +- StakeWorld Polkadot endpoint (Thanks to https://github.com/stakeworld) +- Subspace EVM to ethereum-compatible list (Thanks to https://github.com/vedhavyas) +- Re-activate Centrifuge endpoints (Thanks to https://github.com/wischli) + +Changes: + +- Extend unbonding info message in case of stalled eras +- Ensure only positive values on stalled era unbonding block calculations +- Display hex public key in address conversion utility +- Disable unreachable endpoints + + +## 0.129.1 Apr 30, 2023 + +Contributed: + +- Add BlockOps Kusama/Polkadot endpoints (Thanks to https://github.com/haroldsphinx) +- Update Darwinia endpoints (Thanks to https://github.com/fewensa) + +Changes: + +- Disable unreachable endpoints + + +## 0.128.1 Apr 24, 2023 + +Contributed: + +- Update Manta endpoint (Thanks to https://github.com/grenade) +- Update Mangata endpoints (Thanks to https://github.com/tenequm) +- Update Rococo Basilisk endpoint (Thanks to https://github.com/mrq1911) +- Add Rococo MD5 endpoint (Thanks to https://github.com/sebastianmontero) +- Add Stakeworld Kusama endpoint (Thanks to https://github.com/stakeworld) +- Add LuckyFriday Kusama & Statemine endpoints (Thanks to https://github.com/paradox-tt) + Changes: - Link to IPFS version from development URL +- Disable unreachable endpoints ## 0.127.1 Apr 16, 2023 @@ -2133,7 +2255,7 @@ Contributed: - Added ChainX endpoints & logo (thanks to https://github.com/qinghuan-chain) - Add Ares Rococo relay endpoints (Thanks to https://github.com/jiyilanzhou) - Adjust Rococo types for Plasm (Thanks to https://github.com/akru) -- Add Rococo Ares parachain (Thanks to https://github.com/jiyilanzhou) +- Add Rococo Ares parachain (https://github.com/jiyilanzhou) - Add Rococo PolkaBTC endpoint (Thanks to https://github.com/savudani8) - Add Rococo Hydrate parachain (thanks to https://github.com/lumir-mrkva) - Adjust Darwinia for new chain properties (Thanks to https://github.com/WoeOm) @@ -2177,7 +2299,7 @@ Contributed: - Allow for bounty extension (Thanks to https://github.com/MiZiet) - Add tooltips to bounties (Thanks to https://github.com/MiZiet) - Adjust styling for bounties (thanks to https://github.com/MiZiet) -- Allow using bounties without default treasury (Thanks to https://github.com/ekowalsk) +- Allow using bounties without default treasury (https://github.com/ekowalsk) - Add close bounty action (Thanks to https://github.com/ekowalsk) - Fix Chinese i18n (Thanks to https://github.com/pfcoder) - Update chain types for Galois (Thanks to https://github.com/hging) @@ -2455,7 +2577,7 @@ Changes: Contributed: - Improve support/naming for Ethereum-compatible accounts (Thanks to https://github.com/joelamouche) -- Support for Ethereum-compatible signature verification (Thanks to https://github.com/joelamouche) +- Support for Ethereum-compatible signature verification (https://github.com/joelamouche) - Added Moonbeam types for current versions (Thanks to https://github.com/joelamouche) - Added Moonbase Alpha to list of test networks (Thanks to (Thanks to https://github.com/joelamouche)) - Add Equilibrium Mainnet; updated Equilibrium Testnet (Thanks to https://github.com/pr0fedt) @@ -2705,7 +2827,7 @@ Contributed: - Initial i18n Italian (Thanks to https://github.com/excerebrose) - i18n Bahasa Indonesian updates (Thanks to https://github.com/nzjourney) - Ad per-block/end-block vesting info (thanks to https://github.com/niklabh) -- Update Polkastats logo (Thanks to https://github.com/mariopino) +- Update Polkastats logo (https://github.com/mariopino) - Fixes for i18n translation page on swapping (Thanks to https://github.com/motinados) Changes: diff --git a/CONTRIBUTORS b/CONTRIBUTORS index 50845fb229b7..6c59f474c93f 100644 --- a/CONTRIBUTORS +++ b/CONTRIBUTORS @@ -1,36 +1,38 @@ - 4242 Jaco Disable unreachable endpoints (#9339) - 79 Thibaut Sardan Nit, use as LedgerTypes casting (#4425) + 4325 Jaco Disable unreachable endpoints (#9862) + 80 Thibaut Sardan Fix delegation with x0.1 conviction and typo (#9599) 62 kwingram25 iadd fix (#2911) - 48 pan update bifrost providers (#8065) + 49 pan update Bifrost kusama on Subsquare (#9752) 46 Antoine Estienne Update moonbeam endpoints and moonbase logo and color (#6890) 41 MiZiet Apply styles to the unbonding icon (#6314) - 31 Joakim Nyman Added Dwellir endpoint for Darwinia Crab on Kusama. (#9143) + 32 Joakim Nyman Added Dwellir endpoint for Phala. (#9404) 31 Stefanie Doll Set higher default gas limit, switch from bitlength u32 to u128 for input fields (#2743) 29 Ewa Kowalska Style badges in accounts list (#6208) - 26 Yiwei Li Remove OnFinality endpoint for Westmint due to instability (#9233) + 28 Yongfeng LI Add subsquare external link to moonriver (#9661) + 27 Yiwei Li Re-add OnFinality endpoints for Parallel and Unique (#9641) 25 Aleksandr Krupenkin Added Shiden Crowdloan 2 (#7426) 25 Krzysztof Jelski Increase UI test timeouts and mark interBTC unreachable (#6247) 25 Luke Schoen fix typo kusama (#3083) 24 brenzi Encointer rococo para setup as teleporter (#7160) 24 sxlwar crab config (#6995) 24 WoeOm feat: subscan support fellowship, referenda v2 (#8987) - 24 Yongfeng LI Statescan support polkadot (#9258) + 23 RadiumBlock Update testingRelayWestend.ts (#9863) 20 Nikita Update icon and colors for Realis.Network (#6336) 18 fomod-in Update translation.json (#5942) 18 Wei Tang Re-enable Neatcoin endpoint (#8271) + 18 William Freudenberger re-activate centrifuge fullnodes (#9377) 17 Frank Liu Add Onfinality endpoint for Statemint (#6513) - 17 William Freudenberger fix: rollback KILT custom type decorations (#8279) 16 Xiliang Chen allow submit from Decod page (#5759) 15 Eliott Teissonniere add nodle parachain colors (#7353) 15 Jun Jiang Update and fix Khala typedef (#8272) - 14 RadiumBlock Adding Westend RadiumBlock Endpoint Accelerator (#9316) + 15 lumir-mrkva moved HydraDX rococo RPC (#9732) + 15 Sam Elamin enable imbue api (#9814) 13 Gabriel Facco de Arruda Add InvArch to apps-config (#9145) - 13 lumir-mrkva HydraDX rpc added - ZeePrime (#9047) 13 Miguel Hervas Adding Centrifuge OnFinality Service (#7328) 13 Stefan Popov Add SORA relaychain info (#9275) 13 Zombieliu Update Web3Games Chain Network (#8685) + 12 Alex D Gens parachain (#9447) 12 Kun [Substrate Files] New files module (#6106) - 11 Alex D added genshiro crowdloan 2 (#8210) + 12 Oleh Mell Add new chains for Sub.ID external link (#9540) 11 Cheng JIANG switch to load balanced endpoints for parallel (#6056) 11 Daniel Savu Change InterBTC network name to Interlay (#6700) 11 Kodeist add robonomics and integritee ksm endpoints (#8087) @@ -38,30 +40,34 @@ 11 Nikos Kontakis Add support of light client to rococo (#7363) 11 qwer951123 update acala types (#8394) 11 Ross Bulat Substrate tab theme adjustment (#939) - 11 Sam Elamin use the same paraid as kusama (#7829) 10 Greg Zaitsev Update Unique Network and Quartz by Unique endpoints (#7689) + 10 Jay Update display name (#9868) 10 Nantian add karura (#5441) - 10 Oleh Mell Move Subsocial RPC from Kusama to Polkadot (#9218) 10 zzcwoshizz rm elara endpoint (#6778) 9 Chevdor Add doc related to IPFS and pinning (#2788) 9 darkfriend77 fix: bad logo after PR 8941 (#8947) - 9 Jay Fix darwinia parachain subscan link (#8084) 8 frank Add Live Network Odyssey (#7866) 8 Gonza Montiel make pendulum reachable (#9014) 8 Greg Hill split interlay and kintsugi testnets (#7927) 8 Hging Add MathChain mainnet support (#6214) 8 illlefr4u new additions to Russian translation (#2948) 8 Jakub Jóźwiak Code signing and Notarization (#2794) + 8 Justin Pham Update Pioneer Blockchain to Metaverse.Network Pioneer (#9850) + 8 Xing Added equilibrium OnFinality API back (#9831) 7 abhath-labs [fix] Update Bitgreen urls (#8866) 7 alanchang124 add onfinality endpoint for acala mandala tc7 (#7615) 7 albertov19 modified UnitedBloc endpoints (#9244) 7 Drew Stone Update production.ts (#5757) 7 icodezjb Update OmniBTC wss url (#8678) - 7 Justin Pham Add Bit.Country Pioneer Network to Kusama Relay (#6356) + 7 James Bayly Add Ajuna OnFinality (#9409) + 7 Jonathan Udd Adding Dwellir endpoint for Clover, Polkadex and Parallel (#9878) 7 Kai Update litentry logo and metadata (#9203) 7 Logan Saether Add Zeitgeist para config (#6628) + 7 Nikhil Ranjan Added links for polkassembly (#9434) 7 Rob Thijssen new (Manta Network) load balanced provider url (#9343) + 7 Stakeworld Renaming stakeworld's /statemint/statemine/westmint endpoints to /assethub (#9651) 6 Ayush Mishra Added configuration for DataHighway Tanganika (#7285) + 6 Bulat Saifullin Enable parity endpoints (#9756) 6 Carl chore: update network list in Subscan config (#9192) 6 Daniel Yamuza Swap yes/no (voting) to Toggle (#2519) 6 Dominik Harz refactor: update testnet URL (#7013) @@ -72,7 +78,6 @@ 6 Ivan Rukhavets Update README.md for electron apps (#3362) 6 Joshy Orndorff clarify conviction locking (#6008) 6 mateuszaaa replace outdate mangata testnet with rococo testnet (#7710) - 6 Nikhil Ranjan WeightsV2 support for contracts pallet (#8538) 6 Nizar L Firmansyah Update Bahasa Indonesia Translation (#3823) 6 NZT48 Enable OriginTrail Parachain for Polkadot and update OriginTrail Parachain Testnet (#7674) 6 pangwa update clover types (#6852) @@ -90,7 +95,6 @@ 5 Christian Groeschel DataHighway mainnet westlake (#5066) 5 FreePoi remove support of karura by elara (#6639) 5 Ismail Mbarack (Nas) updated Darwinia crab RPC (#9166) - 5 James Bayly Added OnFinality endpoints after testing liveness against GitHub checks (#9084) 5 Lovesh Harchandani Update types (#5499) 5 marco feat: add subzero (#8657) 5 Marko Petrlić Update Ternoa logo and mainnet name (#7758) @@ -102,9 +106,10 @@ 5 Myron [Crust] Add crust shadow crowdloan 2 (#8185) 5 Nazar Mokrynskyi Remove extra Subspace Gemini 2a RPC endpoints (#8438) 5 xnorly trying to improve the filtering options for target validators (#7080) + 4 1xstj fix : Update tangle testnet url/images (#9885) 4 Arsenii Medoev Unique Network - remove OnFinality endpoints (#9181) + 4 Ashi Add end points for Jur-mainnet (#9586) 4 billjhlee Update Unorthodox Kusama Parachain / Standard Westend Test Network Chain Logo (#6192) - 4 Bulat Saifullin New parachain for Kusama (#8590) 4 Caio Update Parachain ID of Zeitgeist (#5798) 4 Dee Evans DotScanner Kusama Support (#5843) 4 Gautham Update Polkadex's parade (#7303) @@ -112,6 +117,7 @@ 4 helixstreet Update index.ts (#7771) 4 imstar15 Fix turing chain image (#7921) 4 irsal Remove onfinality from Turing rpc selection (#7959) + 4 JelliedOwl (Paul) Re-enable jelliedowl.edgeware.net (#9737) 4 Jianping Deng Update calamari crowdloan UI and Dropdown menu (#6021) 4 John Whitton Update EAVE Parachain id for Rococo (#5286) 4 Leemo Updated Robonomics RPCs (#8329) @@ -119,14 +125,18 @@ 4 Marcin Wachulski Account row collapsible row details (#5894) 4 marco feat: add subzero (#8657) 4 Max Gravitt adding Hashed Network endpoint back and removing Luhn Network (#9100) + 4 Milos Kriz Add IBP BridgeHub support in Polkadot & Westend (#9725) + 4 Min-seong Kwon Update testnet providers url. (thebifrost network) (#9655) 4 mn13 update actual equilibrium version (#6836) 4 Pavel Sheremetev Add DAO IPCI endpoint (#8223) 4 philipstanislaus Upgrade Centrifuge types (#2428) 4 Rishi Karthikeyan Removed pinknode enpoints. (#9018) + 4 Shamilkhan Add typeBundle for Cere Network (#9789) 4 Shankar D. Warang Update production.ts (#8332) 4 toxotguo Add ChainX endpoints hosted by Patract Elara (#4582) + 4 Will | Paradox | ParaNodes.io Adding LuckyFriday nodes (#9677) 4 Yashiro Add crust parachain endpoint (#8770) - 3 1xstj [fix] update tangle rococo url (#9024) + 3 3ierratango [feat] add qpn kusama chain (#9771) 3 Adam Dossa Fix `Option` encoding (#8336) 3 Alex Siman Add name, color and url of Subsocial parachain (#5006) 3 alexdniep added Genshiro as kusama parachain; fixed colors and logos (#5417) @@ -138,6 +148,7 @@ 3 benjichat Remove Dwellir endpoints for Composable and Picasso (#8158) 3 Bhanu Teja P Display extrinsic meta documentation on hover (#1247) 3 Bruno Škvorc Clarify signed message input (#3303) + 3 Calvin Job Puram Restore blockops rpcs (#9830) 3 Cameron Fairchild Add bittensor nakamoto (#8618) 3 Caos Update NFTMart logo (#5815) 3 Chris D'Costa Add Totem Stagex & remove Totem Lego & Wapex networks #8144 (#8145) @@ -149,7 +160,7 @@ 3 Hyungsuk Kang Update opportunity types (#5574) 3 iiiiiiii update jupiter (#5018) 3 jasonberger0 update logo (#4612) - 3 JelliedOwl (Paul) Re-enable jelliedowl RPC for kabocha and beresheet testnet (#9295) + 3 Jegor Sidorenko Fix the way we read the nft's metadata (#9707) 3 Jhon added validator/nominator flags (#4546) 3 Jiacheng Add metadata for Phala Network (#7290) 3 Kami Replace Kusama chain logo with a high quality svg (#8660) @@ -160,11 +171,13 @@ 3 Leszek Wiesner Joystream mainnet released (#8513) 3 limichange Bump @phala/typedefs version (#5709) 3 Mario Pino update PolkaStats logo (#3600) + 3 Michal Danco [Mangata] Replace rpc and types with type definition package (#9657) 3 Mike James Li Update bit country pioneer logo for nodes (#7980) - 3 Milos Kriz Add and update IBP endpoints (#9176) + 3 MinjieTian please get onfinality hydradx back thanks (#9874) 3 nahuseyoum Update Aventus endpoints and colors (#9121) 3 Radha Add info about Bags List (#7283) 3 Ramsey R Update domain of RPC nodes for Edgeware and Kabocha (#8168) + 3 Rodrigo Quelhas Update acurast provider for Kusama (#9816) 3 RossAtOnfinality add OnFinality endpoint for Nodle Network (#6850) 3 RyuH1 Update automata-network type definitions (#7321) 3 Sam re-enable dock testnet endpoint (#6472) @@ -175,17 +188,20 @@ 3 Vincent Geddes Update @snowfork/snowbridge-types to v0.2.6 (#6255) 3 Vitaliy Add sorting for accounts view (#5923) 3 Wil Wade Update Frequency to 1.5.2 with esm support (#9322) + 3 Will add ethtransaction type for legacy (#9578) 3 xtony77 feat: update SubGame types (#6674) 2 1devNdogs Subspace farmers network (#11) (#6675) 2 akashi6824 fix PolkaFoundry color (#4985) 2 Albrecht chore: update WILT paraID & KILT types (#6005) 2 Alexander Popiak Add extra Input types to the UI (#2324) + 2 Alistair Singh Add new Snowbridge forks (#9837) 2 André Silva Fix typo in chain specifications (#5659) 2 Andy Smith Enable appPromotion RPC for Unique Network (#9188) 2 Anoymous Hentai Update Phala's type definition (#5131) 2 Antonio feat: re-introduce support for chain names (#8594) 2 Antonio chore: replace spec-based with name-based declarations for KILT (#8696) 2 Aten Jin add altlayer's ethereum chain to `ethereumChains` (#8337) + 2 Bobo Rename StakeTechnologies to Astar (#9813) 2 Branan Riley Re-enable Altair endpoint (#5739) 2 Btwiuse Arch Add NFTMart mainnet staking params (#6405) 2 carumusan Update commonwealth.ts (#3697) @@ -194,22 +210,28 @@ 2 composabledev added picasso logo (#6043) 2 Dan Shields Update ED and reaping info in app (#4771) 2 dansoft update manta network logo (#6972) + 2 Danylo Kyrieiev update karmachain endpoints (#9883) 2 david-rio feat: add RioChain live network config (#5076) 2 Dean update wss endpoint (#5093) 2 EugenWay Vara network alive (#9215) + 2 fewensa Add darwinia community provider (#9556) 2 firke fix: Opportunity chain re-enabled (#7022) + 2 Fredrik Simonsson Restore nodle testnet link (#9481) 2 Gilles Barnier Fix display issues on the democracy dashboard page (#7360) 2 Hanwen Cheng feat: support import with mini secret key (#2944) 2 Hayden Update Zenlink types (#4835) 2 hellotrongo fix typing error (#5140) 2 Ignacio Palacios Add Watr Polkadot (#9061) 2 Irman Nur Muhammad Alamsyah feat: add DeBio Network endpoint (#8478) + 2 Jakob Restore Dwellir endpoint for Darwinia Crab (#9876) 2 Jakub Pánik Update types for HydraDX (#5369) 2 Jared Norris Fix Sora configuration (#6677) - 2 Jegor Sidorenko NFTs page (#7144) + 2 Jay Pan Peaq rpc add (#9547) 2 jimmy-tudeski Update add-accounts.json (#4759) 2 JimYam fix the bug that have no icon for listen in https://polkadot.js.org/apps (#7241) 2 Justin Zhou currently unreachable (#8130) + 2 Krishna Singh Updated Polkadex mainnet and parachain endpoints (#9765) + 2 Kyilkhor Moonsama listing + types (#9682) 2 LL change riodefi network (#8446) 2 Lohsea Add new color and logo (#6004) 2 Maciej Nemś Change Aleph Zero Testnet name (#6145) @@ -217,9 +239,8 @@ 2 Marian Vanderka add rest of types and rpcs for mangata chain (#9269) 2 maxwellfoley Allow custom node URLs in settings (issue #644) (#657) 2 Michael (GP) Updating gamepower types (#5251) - 2 Michal Danco Add archive node url for mangata (#9257) 2 Mikhail Fedosov feat: update 3dpass logo (#9293) - 2 Min-seong Kwon Fix to use the correct logo. (thebifrost network) (#8977) + 2 Misha Kolesnik Chore: Update Mangata Kusama endpoints (#9427) 2 momo200e add new types to SubGame network (#5954) 2 mosonyi Add integritee to polkadot (#7846) 2 Muhammad Yahya Fix/display oli logo (#7886) @@ -228,9 +249,10 @@ 2 NingBo Wang Update bifrost rococo paraId (#8232) 2 Nisheeth Barthwal display discord identity in profile sidebar (#9185) 2 qinghuan add chainx rococo node (#4772) + 2 Robert Sprunk Add Energy Web X network and logo (#9833) 2 sander2 fix: add account derive (#8683) + 2 sebastianmontero Add hashed network polkadot collator node endpoints (#9623) 2 Serban Iorga Add bridge hub logos (#8883) - 2 Shamilkhan Cere Network config improvements (#9259) 2 sharkygg add subdao test and polkadot parachain network; (#6515) 2 Shawn Tabrizi allow dissolve by anyone when ended (#7184) 2 Shumo Chu Manta crowdloan (#6493) @@ -240,18 +262,21 @@ 2 Teodorus Nathaniel Set provider for subsocial to only para.subsocial.network (#8868) 2 Toney change chainid from 128 to 2048 for apron (#5081) 2 usetech-llc Fix unique types import (#4764) + 2 Vedhavyas Singareddi add subspace evm domain into ethereum chains (#9399) 2 Vladimir Pouzanov Add dracones mainnet & test to ethereumChains.ts (#9246) 2 VladSemenik change Equilibrium production relay polkadot provider (#7323) - 2 Will Update homepage for Shiden Network (#7464) + 2 Wenfeng Wang Add Phala to Rococo (#9461) 2 Witek Make Efinity reachable productionRelayPolkadot.ts (#6580) 2 Yashiro Add crust mainnet endpoint (#5929) 2 Yuri Gii update singular url to singular v2 (#7888) 2 zhenfei updating `Manta Network` parachain ID (#5149) + 2 战神西红柿 restore Liebi rococo provider (#9519) 1 0xrust Add snow to kusama endpoint option array (#7893) 1 0xSamsara Added Samsara RPC to Robonomics parachain (#8240) - 1 3ierratango add ferrum network (#8877) 1 abhi fix text and isUnreachable properties for SNOW Network (#8252) + 1 Abhishek Shah Add mythical-devnet to ethereumChains (#9642) 1 Adam new edeware logo and color (#6249) + 1 Adedayo Akinpelu Add blockops endpoint (#9375) 1 Aidan Starke Add `Root Network` types (#8034) 1 Albert Apply Nunito fonts globally (#3882) 1 Alex Add Curio parachain (#9183) @@ -259,22 +284,18 @@ 1 Alex Won support ethereum compatibility for bifrost network (#8733) 1 Alexander Wilke add t3rn parachain (#9195) 1 Alexey Rename SORA-staging Node to Sora (#5084) - 1 Alistair Singh Add Rococo Snowbridge (#7630) 1 Anakorn Tata Kyavatanakij fix SummaryBar (#1981) 1 Andrew Jones Fix upload and deploy contract(s) after rename (#1346) 1 Andy Bell Dali to Picasso (#9102) 1 Anthony Chan fix the cess testnet logo wrong bug (#8649) - 1 Ayush Ethos added to Rococo (#8571) 1 Bart200c add kylin network (#7865) 1 Bill Laboon Add explanation that Docker port is 80 (#1480) 1 BoBin Add subscan rococo extra link (#4439) - 1 Bobo type def update (#6612) 1 BOBOKaa update ipfs endpoint domain (#8686) 1 Bojian Ho Added fantour network config (#5764) 1 Boyquotes Fix FR translation (#7817) 1 Brandon Kite Support for optional usage of pallet_balance (#2578) 1 Brendon Votteler feat: add derives mapping and spec records for testnet-interlay and testnet-kintsugi (#8000) - 1 Calvin Job Puram Add BlockOps RPC node to Westend (#9326) 1 Carl Update Subscan link config (#6194) 1 CCBro add `armonia-eva` and `armonia-wall-e` for ethereumChains (#7732) 1 CherryLiang show play/stop button (#1804) @@ -304,11 +325,11 @@ 1 Fr4ctalbit Turn Submit proposal tab into a modal (#1698) 1 Francesco Occhipinti [CI Skip] update the remote server location, closes #487 (#492) 1 Francisco Gamundi Updated Moonbeam Foundation's Moonriver endpoint (#7028) - 1 Fredrik Simonsson Polkadex testnet have been resurrected (#6783) 1 gabriel klawitter CI: add file for substrate-ui and substrate-ui-light domains (#767) 1 George Angelopoulos typo fix (#5704) 1 Georgi Zlatarev Dolphin parachain on Rococo (#7401) 1 Gerawork Aynekulu Update RILT paraId (#7736) + 1 gianfra-t Request to register custom RPC for Pendulum, Amplitude, Foucoco (#9855) 1 Giovanni Petrantoni Add Fragnova mainnet and testnet (#9198) 1 gojazdev feat(apps-config): introduce Jaz node (#7805) 1 goldsteinsveta Style bug fix: Balances asset selector (#6668) @@ -331,6 +352,7 @@ 1 Jhon Identicon and error red shading adjustments for dark theme (#4483) 1 jizer add trustbase infos (#4627) 1 joe petrowski unscrupelous to unscrupulous (#7935) + 1 Julien Remove now sunset dotscanner (#9714) 1 Jun Zhang Update translation.json (#4508) 1 Kai Fix broken contract deployment function (#1643) 1 kaichao Refresh zh translations (#3322) @@ -340,9 +362,9 @@ 1 Kirill Shirobokov ru translations for page-accouts are added (#9219) 1 KkenWv Add KICO logo and endpoint (#6906) 1 KRogLA sub accounts search fix (#2572) - 1 kyilkhor feat: Moonsama Development parachain on Rococo (#7014) 1 Lauro Gripa Neto Add portuguese translation (#2940) 1 Letho Coinversation (#6597) + 1 loanMaster fix: issue 9127. teleport reactivated (#9529) 1 lreesby Turing added to Rococo (#7603) 1 lulu Update Ares Protocol parachain ID (#5160) 1 LusWar Update Phala testnet (PoC2 => PoC3) (#4148) @@ -359,17 +381,19 @@ 1 Mickael Faust Added TerraBioDAO to the GM nodes list (#8010) 1 Mike Godenzi Acurast added to Rococo (#8546) 1 mikolajsobolewski Added Equilibrium Test Network logos & endpoints (#3792) - 1 MinjieTian deleted onfinality ajuna endpoint (#8848) + 1 mmaurello add moonbeam apps as external resource for referenda (#9790) 1 Mokhtar Naamani Fix app-accounts Restore feature (#761) 1 motinados fill in all empty values in all languageCaches. (#3606) 1 MOZGIII Add Humanode network endpoint and logo (#8919) 1 Nantian update acala rpc (#6704) 1 nasa8x Add GeekCash testnet, logo, color (#5265) + 1 Natacha De la Rosa Add Subspace Gemini 3f endpoint (#9835) 1 NightingaleAsh Add loom network kusama (#5591) 1 Nikhil Saboo Add Zeitgeist battery station endpoint (#6265) 1 Nikolay Pasynkov Enable Opal by Unique (#7833) 1 octavei add aband info (#8929) 1 ok.man update-mandala (#6785) + 1 okalenyk *added Societal to Rococo (#9477) 1 Owen add kico2 (#8374) 1 paulhealy09 Update Unit Network logo (Thanks to https://github.com/unit-network) (#5027) 1 Pavel Added new community node for SORA (#5600) @@ -377,11 +401,13 @@ 1 Peter White Small fixes to provide council page compatibility (#8791) 1 Pierre Krieger Update translation.json (#6266) 1 Pierre-Luc Gagné Added a warning popup at account creation for seed backup (#325) + 1 Piotr Mikołajczyk Fix `jsonrpc` attribute (#9576) 1 Polkassembly Added fellowship refrenda (#9135) 1 Preschian Febryantara add KodaDot logo (#7151) 1 Puneet Saraswat Frequency rococo (#8076) 1 Qinxuan Chen Add frontier template into ethereum chains (#9202) 1 Radka Gettová Make Block Hash "Hover to Copy"-able (#458) + 1 Rajdeep Singh add collectives to polkassembly links (#9595) 1 Raoul Millais Upgrade @substrate/connect@0.3.16 (#5855) 1 Raphael Flechtner chore: use new kilt logo (#5649) 1 Ravi Kumar Add hi_IN translation (#5420) @@ -395,6 +421,7 @@ 1 Sam Hellawell Fix dock logos being blurry/low res (#4427) 1 Satyam Agrawal Add Polymesh ITN Provider (#5242) 1 Sergei Lonshakov Robonomics ParaID 2077 added (#5706) + 1 serkixenos Add Peerplays to ethereumChains (#9820) 1 Shailesh B Nair Add KlugDossier (#5456) 1 Shamil Move Vara from Live networks to Test networks (#8295) 1 Shaun Wang Fix spelling: Javascript -> JavaScript. (#4698) @@ -405,8 +432,8 @@ 1 Sota Watanabe update (#2949) 1 Sourabh Niyogi Add polkaholic.io to external links (#7783) 1 Spencer Judge Don't crash if there is no tip field in extrinsics (#2466) - 1 Stakeworld Add stakeworld westend rpc node (#9249) 1 Stéphane P Fix Fr translations typos (#5104) + 1 Steve Degosserie Add Trappist Rococo parachain (#9669) 1 Subsocial Specify the custom types for Subsocial parachain (#5009) 1 tarrball Grammar fix in staking tooltip (#6727) 1 Teddy Rogers Add CESS Testnet to TEST NETWORK (#7908) @@ -419,11 +446,8 @@ 1 Vadim fix overflow issue in extensions table (#7767) 1 valentunn Fix Kusama name in ru translation (#7498) 1 Vasylenko Yevhen Add Subzero Rococo parachain (#7919) - 1 Vedhavyas Singareddi enable subscan external link for centrifuge (#4307) 1 Vlad Proshchavaiev Add Subsocial into apps-config (#3523) 1 Vladyslav Samchuk Enable sub.id link (#7806) - 1 Wenfeng Wang Added Phala PC1 Rococo V1 endpoint (#4468) - 1 Will | Paradox | ParaNodes.io Adding LuckyFriday to Westend (#9284) 1 willeslau Add Konomi Network chain info to Rococo (#5171) 1 wimel 25 modules translated from ES_es (#2969) 1 Witek Add Efinity parachain (#6571) @@ -437,5 +461,4 @@ 1 Илья Петров Add files via upload (#7001) 1 制杖 add trustbase network (#5854) 1 小白 My contacts chinese suggest calling 我的合约账户 (#3288) - 1 战神西红柿 restore onfinality provider (#9081) 1 早晨海风 Confti added to Rococo (#8029) diff --git a/I18N.md b/I18N.md index 1391c77b2782..23a530a6f62f 100644 --- a/I18N.md +++ b/I18N.md @@ -2,6 +2,7 @@ The apps UI allows all strings to be translated. Additionally it has a basic UI that allows for the creation of the required translation files, which will give an overview on the progress for a specific language. + ## Updating translations To update translations, the following process is required. @@ -15,6 +16,7 @@ Here you will find a dropdown of all the available languages and all the modules - once completed with the changes, click the `Generate translation.json` button to download the translation file - this file can now be added to the repo with a PR to https://github.com/polkadot-js/apps/tree/master/packages/apps/public/locales + ## Adding a new language (if not in dropdown above) The process is similar for the above, but does require a new folder with the language identifier to be added. Create [packages/apps/public/locales/](https://github.com/polkadot-js/apps/tree/master/packages/apps/public/locales) folder with an empty `translation.json` (containing only `{}`). After addition of the folder, run `yarn build:i18n` and then the new language will be available for update as per the process in the previous section. diff --git a/docker/Dockerfile b/docker/Dockerfile index 2b003a08c6b7..7dc388724c39 100644 --- a/docker/Dockerfile +++ b/docker/Dockerfile @@ -24,7 +24,7 @@ ENV WS_URL= WORKDIR /usr/share/nginx/html -COPY env.sh . +COPY docker/env.sh . RUN apk add --no-cache bash; chmod +x env.sh diff --git a/env.sh b/docker/env.sh similarity index 100% rename from env.sh rename to docker/env.sh diff --git a/eslint.config.js b/eslint.config.js new file mode 100644 index 000000000000..7112bc6ba2be --- /dev/null +++ b/eslint.config.js @@ -0,0 +1,16 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +import baseConfig from '@polkadot/dev/config/eslint'; + +export default [ + ...baseConfig, + { + rules: { + // add override for any (a metric ton of them, initial conversion) + '@typescript-eslint/no-explicit-any': 'off', + // we generally use this in isFunction, not via calling + '@typescript-eslint/unbound-method': 'off' + } + } +]; diff --git a/package.json b/package.json index 9bd2e6c0559c..2ad444567e09 100644 --- a/package.json +++ b/package.json @@ -15,10 +15,11 @@ "url": "https://github.com/Cardinal-Cryptography/azero-dev.git" }, "sideEffects": false, - "version": "0.127.2-2-x", + "type": "module", + "version": "0.132.2-98-x", "versions": { - "git": "0.127.2-2-x", - "npm": "0.127.1" + "git": "0.132.2-98-x", + "npm": "0.132.1" }, "workspaces": [ "packages/*" @@ -41,9 +42,9 @@ "build:release:ipfs": "node scripts/ipfsUpload.mjs", "build:release:www": "yarn polkadot-ci-ghact-build && yarn build:release:ghpages && yarn build:release:ipfs", "build:robohash": "node scripts/robohash.cjs", - "build:typesBundle": "polkadot-dev-run-test --env node --experimental-specifier-resolution=node packages/apps-config/src/api/typesBundle.spec.ts", + "build:typesBundle": "polkadot-dev-run-test --env node --loader extensionless typesBundle", "build:www": "rm -rf packages/apps/build && mkdir -p packages/apps/build && yarn run build:i18n && cd packages/apps && yarn polkadot-exec-webpack --config webpack.config.cjs", - "ci:chainEndpoints": "polkadot-dev-run-test --env node packages/apps-config/src/ci/chainEndpoints --log .github/chain-endpoints.md", + "ci:chainEndpoints": "polkadot-dev-run-test --env node --logfile .github/chain-endpoints.md packages/apps-config/src/ci/chainEndpoints", "ci:chainTypes": "echo ok", "clean": "polkadot-dev-clean-build", "clean:electronBuild": "cd packages/apps-electron && polkadot-dev-clean-build", @@ -52,15 +53,15 @@ "docs": "echo \"skipping docs\"", "lint": "polkadot-dev-run-lint", "packElectron": "yarn build:release:electron && yarn clean:electronRelease && electron-builder build -mwl", - "packElectron:linux": "yarn build:release:electron && electron-builder build --linux", - "packElectron:mac": "yarn build:release:electron && electron-builder build --mac", - "packElectron:test": "yarn build:release:electron && electron-builder --dir", - "packElectron:win": "yarn build:release:electron && electron-builder build --win", + "packElectron:linux": "yarn build:release:electron && electron-builder build --linux --project packages/apps-electron", + "packElectron:mac": "yarn build:release:electron && electron-builder build --mac --project packages/apps-electron", + "packElectron:test": "yarn build:release:electron && electron-builder --dir --project packages/apps-electron", + "packElectron:win": "yarn build:release:electron && electron-builder build --win --project packages/apps-electron", "postinstall": "polkadot-dev-yarn-only", "postinstall:electron": "electron-builder install-app-deps", "start": "yarn clean && cd packages/apps && yarn polkadot-exec-webpack serve --config webpack.serve.cjs --port 3000", "start:electron": "yarn clean:electronBuild && concurrently 'yarn build:devElectronMain && cd packages/apps-electron && electron ./build/electron.js' 'yarn build:devElectronRenderer'", - "test": "polkadot-dev-run-test --env browser --experimental-specifier-resolution=node ^typesBundle ^chainEndpoints ^chainTypes ^page- ^react- ^apps-electron", + "test": "polkadot-dev-run-test --env browser ^typesBundle ^chainEndpoints ^chainTypes ^page- ^react- ^apps-electron", "test:all": "polkadot-dev-run-test --env browser ^chainEndpoints ^chainTypes", "test:one": "polkadot-dev-run-test --env browser", "test:skipped": "echo 'tests skipped'" @@ -73,60 +74,56 @@ "devDependencies": { "@crustio/crust-pin": "^1.0.0", "@pinata/sdk": "^1.2.1", - "@polkadot/dev": "^0.72.43", + "@polkadot/dev": "^0.76.18", "@types/chart.js": "^2.9.37", "@types/file-saver": "^2.0.5", "@types/react-beautiful-dnd": "^13.1.4", "@types/react-copy-to-clipboard": "^5.0.4", - "@types/react-dom": "^18.0.11", + "@types/react-dom": "^18.2.7", "@types/react-router-dom": "^5.3.3", "@types/store": "^2.0.2", - "@types/styled-components": "^5.1.26", - "@types/styled-theming": "^2.2.5", - "concurrently": "^8.0.1", + "concurrently": "^8.2.1", "devtron": "^1.4.0", "dnslink-cloudflare": "^3.0.0", - "electron": "^23.2.4", + "electron": "25.0.1", "electron-builder": "23.6.0", "electron-builder-notarize": "^1.5.1", - "i18next-scanner": "^4.2.0", + "extensionless": "^1.4.5", + "i18next-scanner": "^4.3.0", "react": "^18.2.0", "react-dom": "^18.2.0", "react-is": "^18.2.0", - "source-map-explorer": "^2.5.3", - "styled-components": "^5.3.9" + "source-map-explorer": "^2.5.3" }, "resolutions": { - "@polkadot/api": "^10.3.4", - "@polkadot/api-augment": "^10.3.4", - "@polkadot/api-base": "^10.3.4", - "@polkadot/api-contract": "^10.3.4", - "@polkadot/api-derive": "^10.3.4", - "@polkadot/hw-ledger": "^11.1.3", - "@polkadot/keyring": "^11.1.3", - "@polkadot/networks": "^11.1.3", - "@polkadot/phishing": "^0.20.5", - "@polkadot/rpc-augment": "^10.3.4", - "@polkadot/rpc-core": "^10.3.4", - "@polkadot/rpc-provider": "^10.3.4", - "@polkadot/types": "^10.3.4", - "@polkadot/types-augment": "^10.3.4", - "@polkadot/types-codec": "^10.3.4", - "@polkadot/types-create": "^10.3.4", - "@polkadot/types-known": "^10.3.4", - "@polkadot/types-support": "^10.3.4", - "@polkadot/util": "^11.1.3", - "@polkadot/util-crypto": "^11.1.3", - "@polkadot/wasm-crypto": "^7.0.3", - "@polkadot/x-bigint": "^11.1.3", - "@polkadot/x-fetch": "^11.1.3", - "@polkadot/x-global": "^11.1.3", - "@polkadot/x-randomvalues": "^11.1.3", - "@polkadot/x-textdecoder": "^11.1.3", - "@polkadot/x-textencoder": "^11.1.3", - "@polkadot/x-ws": "^11.1.3", - "@types/react": "^18.2.21", - "styled-components": "^5.3.1", - "typescript": "^5.0.4" + "@polkadot/api": "^10.9.1", + "@polkadot/api-augment": "^10.9.1", + "@polkadot/api-base": "^10.9.1", + "@polkadot/api-contract": "^10.9.1", + "@polkadot/api-derive": "^10.9.1", + "@polkadot/hw-ledger": "^12.4.2", + "@polkadot/keyring": "^12.4.2", + "@polkadot/networks": "^12.4.2", + "@polkadot/phishing": "^0.21.5", + "@polkadot/rpc-augment": "^10.9.1", + "@polkadot/rpc-core": "^10.9.1", + "@polkadot/rpc-provider": "^10.9.1", + "@polkadot/types": "^10.9.1", + "@polkadot/types-augment": "^10.9.1", + "@polkadot/types-codec": "^10.9.1", + "@polkadot/types-create": "^10.9.1", + "@polkadot/types-known": "^10.9.1", + "@polkadot/types-support": "^10.9.1", + "@polkadot/util": "^12.4.2", + "@polkadot/util-crypto": "^12.4.2", + "@polkadot/wasm-crypto": "^7.2.2", + "@polkadot/x-bigint": "^12.4.2", + "@polkadot/x-fetch": "^12.4.2", + "@polkadot/x-global": "^12.4.2", + "@polkadot/x-randomvalues": "^12.4.2", + "@polkadot/x-textdecoder": "^12.4.2", + "@polkadot/x-textencoder": "^12.4.2", + "@polkadot/x-ws": "^12.4.2", + "typescript": "^5.1.6" } } diff --git a/packages/apps-config/package.json b/packages/apps-config/package.json index b8cc96f8fd5e..655c1a9ef1b3 100644 --- a/packages/apps-config/package.json +++ b/packages/apps-config/package.json @@ -1,31 +1,66 @@ { - "bugs": "https://github.com/polkadot-js/apps/issues", + "bugs": "https://github.com/Cardinal-Cryptography/azero-dev/issues", "engines": { - "node": ">=14" + "node": ">=16" }, - "homepage": "https://github.com/polkadot-js/apps/tree/master/packages/apps-config#readme", + "homepage": "https://github.com/Cardinal-Cryptography/azero-dev/tree/master/packages/apps-config#readme", "license": "Apache-2.0", "name": "@polkadot/apps-config", "repository": { "directory": "packages/apps-config", "type": "git", - "url": "https://github.com/polkadot-js/apps.git" + "url": "https://github.com/Cardinal-Cryptography/azero-dev.git" }, "sideEffects": false, "type": "module", - "version": "0.127.2-2-x", + "version": "0.132.2-98-x", "main": "index.js", "dependencies": { + "@acala-network/type-definitions": "5.1.2", "@azns/resolver-core": "^1.4.0", - "@polkadot/api": "^10.3.4", - "@polkadot/api-derive": "^10.3.4", - "@polkadot/networks": "^11.1.3", - "@polkadot/types": "^10.3.4", - "@polkadot/util": "^11.1.3", - "@polkadot/wasm-util": "^7.0.3", - "@polkadot/x-fetch": "^11.1.3", - "@polkadot/x-ws": "^11.1.3", - "rxjs": "^7.8.0", - "tslib": "^2.5.0" + "@bifrost-finance/type-definitions": "1.8.4", + "@crustio/type-definitions": "1.3.0", + "@darwinia/types": "2.8.10", + "@darwinia/types-known": "2.8.10", + "@digitalnative/type-definitions": "1.1.27", + "@docknetwork/node-types": "0.16.0", + "@edgeware/node-types": "3.6.2-wako", + "@equilab/definitions": "1.4.18", + "@fragnova/api-augment": "0.1.0-spec-1.0.4-mainnet", + "@frequency-chain/api-augment": "1.7.4", + "@interlay/interbtc-types": "1.13.0", + "@kiltprotocol/type-definitions": "0.33.1", + "@laminar/type-definitions": "0.3.1", + "@logion/node-api": "0.19.0-2", + "@mangata-finance/type-definitions": "^1.0.0", + "@metaverse-network-sdk/type-definitions": "0.0.1-16", + "@parallel-finance/type-definitions": "2.0.0", + "@peaqnetwork/type-definitions": "0.0.4", + "@pendulum-chain/type-definitions": "0.3.7", + "@phala/typedefs": "0.2.33", + "@polkadot/api": "^10.9.1", + "@polkadot/api-derive": "^10.9.1", + "@polkadot/networks": "^12.4.2", + "@polkadot/react-identicon": "^3.6.2", + "@polkadot/types": "^10.9.1", + "@polkadot/types-codec": "^10.9.1", + "@polkadot/util": "^12.4.2", + "@polkadot/wasm-util": "^7.2.2", + "@polkadot/x-fetch": "^12.4.2", + "@polkadot/x-ws": "^12.4.2", + "@polymeshassociation/polymesh-types": "5.5.2", + "@snowfork/snowbridge-types": "0.2.7", + "@sora-substrate/type-definitions": "1.20.1", + "@subsocial/definitions": "0.8.13", + "@unique-nft/opal-testnet-types": "942.57.0", + "@unique-nft/quartz-mainnet-types": "942.57.0", + "@unique-nft/sapphire-mainnet-types": "942.57.0", + "@unique-nft/unique-mainnet-types": "942.57.0", + "@zeitgeistpm/type-defs": "1.0.0", + "@zeroio/type-definitions": "0.0.14", + "moonbeam-types-bundle": "2.0.10", + "pontem-types-bundle": "1.0.15", + "rxjs": "^7.8.1", + "tslib": "^2.6.2" } } diff --git a/packages/apps-config/src/api/chain/cere.ts b/packages/apps-config/src/api/chain/cere.ts new file mode 100644 index 000000000000..4a6117a0de7c --- /dev/null +++ b/packages/apps-config/src/api/chain/cere.ts @@ -0,0 +1,83 @@ +// Copyright 2017-2023 @polkadot/apps-config authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +import type { OverrideBundleDefinition } from '@polkadot/types/types'; + +/* eslint-disable sort-keys */ +const definitions: OverrideBundleDefinition = { + types: [ + { + minmax: [ + 266, + 281 + ], + types: { + ChainId: 'u8', + DepositNonce: 'u64', + ResourceId: '[u8; 32]', + ProposalStatus: { + _enum: [ + 'Initiated', + 'Approved', + 'Rejected' + ] + }, + ProposalVotes: { + votes_for: 'Vec', + votes_against: 'Vec', + status: 'ProposalStatus', + expiry: 'BlockNumber' + }, + TokenId: 'u256', + Erc721Token: { + id: 'TokenId', + metadata: 'Vec' + }, + Address: 'IndicesLookupSource', + LookupSource: 'IndicesLookupSource', + AccountInfo: 'AccountInfoWithDualRefCount', + ValidatorPrefs: { + commission: 'Compact' + } + } + }, + { + minmax: [ + 282, + 294 + ], + types: { + ChainId: 'u8', + DepositNonce: 'u64', + ResourceId: '[u8; 32]', + ProposalStatus: { + _enum: [ + 'Initiated', + 'Approved', + 'Rejected' + ] + }, + ProposalVotes: { + votes_for: 'Vec', + votes_against: 'Vec', + status: 'ProposalStatus', + expiry: 'BlockNumber' + }, + TokenId: 'u256', + Erc721Token: { + id: 'TokenId', + metadata: 'Vec' + }, + Address: 'MultiAddress', + LookupSource: 'MultiAddress', + AccountInfo: 'AccountInfoWithDualRefCount' + } + }, + { + minmax: [295, null], + types: {} + } + ] +}; + +export default definitions; diff --git a/packages/apps-config/src/api/chain/index.ts b/packages/apps-config/src/api/chain/index.ts new file mode 100644 index 000000000000..cc2f9b8b1791 --- /dev/null +++ b/packages/apps-config/src/api/chain/index.ts @@ -0,0 +1,23 @@ +// Copyright 2017-2023 @polkadot/apps-config authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +import type { OverrideBundleDefinition } from '@polkadot/types/types'; + +import cere from './cere.js'; +import kilt from './kilt.js'; + +if (!kilt) { + throw new Error('Unable to retrieve kilt'); +} + +// NOTE: The mapping is done from chain name in system.chain +const chain: Record = { + 'Cere Mainnet Beta': cere, + 'KILT Mashnet': kilt['KILT Mashnet'], + 'KILT Peregrine': kilt['KILT Peregrine'], + 'KILT Peregrine Stagenet': kilt['KILT Peregrine Stagenet'], + 'KILT Spiritnet': kilt['KILT Spiritnet'], + 'KILT Spiritnet Develop': kilt['KILT Spiritnet Develop'] +}; + +export default chain; diff --git a/packages/apps-config/src/api/chain/kilt.ts b/packages/apps-config/src/api/chain/kilt.ts new file mode 100644 index 000000000000..15d6bebd92ba --- /dev/null +++ b/packages/apps-config/src/api/chain/kilt.ts @@ -0,0 +1,10 @@ +// Copyright 2017-2023 @polkadot/apps-config authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +import { typesBundle } from '@kiltprotocol/type-definitions'; + +if (!typesBundle.chain) { + throw new Error('Unable to find chain defintions'); +} + +export default typesBundle.chain; diff --git a/packages/apps-config/src/api/constants.ts b/packages/apps-config/src/api/constants.ts index 5fb6290ff760..eac4e46ca2ff 100644 --- a/packages/apps-config/src/api/constants.ts +++ b/packages/apps-config/src/api/constants.ts @@ -1,13 +1,15 @@ -// Copyright 2017-2023 @polkadot/app-accounts authors & contributors +// Copyright 2017-2023 @polkadot/apps-config authors & contributors // SPDX-License-Identifier: Apache-2.0 +import type { HexString } from '@polkadot/util/types'; + import { knownGenesis } from '@polkadot/networks/defaults'; import { assert, BN } from '@polkadot/util'; -function getGenesis (name: string): string { +function getGenesis (name: string): HexString { const network = Object.entries(knownGenesis).find(([network]) => network === name); - assert(network && network[1][0], `Unable to find genesisHash for ${name}`); + assert(network?.[1][0], `Unable to find genesisHash for ${name}`); return network[1][0]; } diff --git a/packages/apps-config/src/api/index.ts b/packages/apps-config/src/api/index.ts index d1a74d03e1c6..193a957443de 100644 --- a/packages/apps-config/src/api/index.ts +++ b/packages/apps-config/src/api/index.ts @@ -1,7 +1,6 @@ // Copyright 2017-2023 @polkadot/apps-config authors & contributors // SPDX-License-Identifier: Apache-2.0 -export { typesBundle } from './typesBundle.js'; - -export * from './params/index.js'; export * from './constants.js'; +export * from './params/index.js'; +export { typesBundle } from './typesBundle.js'; diff --git a/packages/apps-config/src/api/params/inflation.ts b/packages/apps-config/src/api/params/inflation.ts index b9fe102c92f7..41d76af40625 100644 --- a/packages/apps-config/src/api/params/inflation.ts +++ b/packages/apps-config/src/api/params/inflation.ts @@ -1,4 +1,4 @@ -// Copyright 2017-2023 @polkadot/app-config authors & contributors +// Copyright 2017-2023 @polkadot/apps-config authors & contributors // SPDX-License-Identifier: Apache-2.0 import type { ApiPromise } from '@polkadot/api'; diff --git a/packages/apps-config/src/api/params/teleport.ts b/packages/apps-config/src/api/params/teleport.ts index e78df02ab632..d0f87384cb6d 100644 --- a/packages/apps-config/src/api/params/teleport.ts +++ b/packages/apps-config/src/api/params/teleport.ts @@ -1,4 +1,4 @@ -// Copyright 2017-2023 @polkadot/app-config authors & contributors +// Copyright 2017-2023 @polkadot/apps-config authors & contributors // SPDX-License-Identifier: Apache-2.0 import type { ApiPromise } from '@polkadot/api'; diff --git a/packages/apps-config/src/api/params/tracks/index.ts b/packages/apps-config/src/api/params/tracks/index.ts index bf32da77fa3d..74ffbd39aa12 100644 --- a/packages/apps-config/src/api/params/tracks/index.ts +++ b/packages/apps-config/src/api/params/tracks/index.ts @@ -1,4 +1,4 @@ -// Copyright 2017-2023 @polkadot/app-config authors & contributors +// Copyright 2017-2023 @polkadot/apps-config authors & contributors // SPDX-License-Identifier: Apache-2.0 import type { ApiPromise } from '@polkadot/api'; @@ -31,5 +31,5 @@ const KNOWN_SPEC_TRACKS: Record> = { export function getGovernanceTracks (api: ApiPromise, specName: string, palletReferenda: string): TrackInfo[] | undefined { const lookup = KNOWN_GENE_TRACKS[api.genesisHash.toHex()] || KNOWN_SPEC_TRACKS[specName]; - return lookup && lookup[palletReferenda]; + return lookup?.[palletReferenda]; } diff --git a/packages/apps-config/src/api/params/tracks/kusama.ts b/packages/apps-config/src/api/params/tracks/kusama.ts index 082a0373015e..4b74a3bc6d56 100644 --- a/packages/apps-config/src/api/params/tracks/kusama.ts +++ b/packages/apps-config/src/api/params/tracks/kusama.ts @@ -1,4 +1,4 @@ -// Copyright 2017-2023 @polkadot/app-config authors & contributors +// Copyright 2017-2023 @polkadot/apps-config authors & contributors // SPDX-License-Identifier: Apache-2.0 import type { TrackInfo } from './types.js'; diff --git a/packages/apps-config/src/api/params/tracks/polkadot.ts b/packages/apps-config/src/api/params/tracks/polkadot.ts index 3cc6ef05cf69..f6d113162fca 100644 --- a/packages/apps-config/src/api/params/tracks/polkadot.ts +++ b/packages/apps-config/src/api/params/tracks/polkadot.ts @@ -1,4 +1,4 @@ -// Copyright 2017-2023 @polkadot/app-config authors & contributors +// Copyright 2017-2023 @polkadot/apps-config authors & contributors // SPDX-License-Identifier: Apache-2.0 import type { TrackInfo } from './types.js'; diff --git a/packages/apps-config/src/api/params/tracks/types.ts b/packages/apps-config/src/api/params/tracks/types.ts index 88f51321b9ec..b35941a9cc95 100644 --- a/packages/apps-config/src/api/params/tracks/types.ts +++ b/packages/apps-config/src/api/params/tracks/types.ts @@ -1,4 +1,4 @@ -// Copyright 2017-2023 @polkadot/app-config authors & contributors +// Copyright 2017-2023 @polkadot/apps-config authors & contributors // SPDX-License-Identifier: Apache-2.0 import type { BN } from '@polkadot/util'; diff --git a/packages/apps-config/src/api/params/tracks/util.ts b/packages/apps-config/src/api/params/tracks/util.ts index 1714e38b4b21..03557cac0a26 100644 --- a/packages/apps-config/src/api/params/tracks/util.ts +++ b/packages/apps-config/src/api/params/tracks/util.ts @@ -1,7 +1,9 @@ -// Copyright 2017-2023 @polkadot/app-config authors & contributors +// Copyright 2017-2023 @polkadot/apps-config authors & contributors // SPDX-License-Identifier: Apache-2.0 -import { BN, formatBalance } from '@polkadot/util'; +import type { BN } from '@polkadot/util'; + +import { formatBalance } from '@polkadot/util'; interface FormatOptions { decimals: number; diff --git a/packages/apps-config/src/api/spec/bittensor.ts b/packages/apps-config/src/api/spec/bittensor.ts new file mode 100644 index 000000000000..512c8425191d --- /dev/null +++ b/packages/apps-config/src/api/spec/bittensor.ts @@ -0,0 +1,44 @@ +// Copyright 2017-2023 @polkadot/apps-config authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +import type { OverrideBundleDefinition } from '@polkadot/types/types'; + +// structs need to be in order +/* eslint-disable sort-keys */ + +const definitions: OverrideBundleDefinition = { + types: [ + { + // on all versions + minmax: [0, undefined], + types: { + Balance: 'u64', + NeuronMetadata: { + version: 'u32', + ip: 'u128', + port: 'u16', + ipType: 'u8', + uid: 'u32', + netuid: 'u16', + modality: 'u8', + hotkey: 'AccountId', + coldkey: 'AccountId', + active: 'u32', + lastUpdate: 'u64', + priority: 'u64', + stake: 'u64', + rank: 'u64', + trust: 'u64', + consensus: 'u64', + incentive: 'u64', + dividends: 'u64', + emission: 'u64', + bonds: 'Vec<(u32, u64)>', + weights: 'Vec<(u32, u32)>' + } + } + } + ] +}; + +export default definitions; diff --git a/packages/apps-config/src/api/spec/curio.ts b/packages/apps-config/src/api/spec/curio.ts new file mode 100644 index 000000000000..4795cba4ddee --- /dev/null +++ b/packages/apps-config/src/api/spec/curio.ts @@ -0,0 +1,48 @@ +// Copyright 2017-2023 @polkadot/apps-config authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +import type { OverrideBundleDefinition } from '@polkadot/types/types'; + +/* eslint-disable sort-keys */ +const definitions: OverrideBundleDefinition = { + types: [ + { + // on all versions + minmax: [0, undefined], + types: { + StakingRates: { + collatorStakingRate: 'Perquintill', + collatorRewardRate: 'Perquintill', + delegatorStakingRate: 'Perquintill', + delegatorRewardRate: 'Perquintill' + } + } + } + ], + runtime: { + Staking: [ + { + methods: { + get_staking_rates: { + description: 'Calculate the current staking and reward rates for collators and delegators', + params: [], + type: 'StakingRates' + }, + get_unclaimed_staking_rewards: { + description: 'Calculate the claimable staking rewards for a given account address', + params: [ + { + name: 'account', + type: 'AccountId32' + } + ], + type: 'Balance' + } + }, + version: 1 + } + ] + } +}; + +export default definitions; diff --git a/packages/apps-config/src/api/spec/fragnova.ts b/packages/apps-config/src/api/spec/fragnova.ts new file mode 100644 index 000000000000..5a7cff6276f9 --- /dev/null +++ b/packages/apps-config/src/api/spec/fragnova.ts @@ -0,0 +1,19 @@ +// Copyright 2017-2023 @polkadot/apps-config authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Not used/included in index.ts as of https://github.com/polkadot-js/apps/pull/9243 + +import type { OverrideBundleDefinition } from '@polkadot/types/types'; + +import { options } from '@fragnova/api-augment'; + +export default { + ...options, + types: [ + { + // on all versions + minmax: [0, undefined], + types: options.types + } + ] +} as OverrideBundleDefinition; diff --git a/packages/apps-config/src/api/spec/peaq.ts b/packages/apps-config/src/api/spec/peaq.ts new file mode 100644 index 000000000000..5baa016584aa --- /dev/null +++ b/packages/apps-config/src/api/spec/peaq.ts @@ -0,0 +1,8 @@ +// Copyright 2017-2023 @polkadot/apps-config authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +import type { OverrideBundleDefinition } from '@polkadot/types/types'; + +import { typesBundleForPolkadot } from '@peaqnetwork/type-definitions'; + +export default (typesBundleForPolkadot as { spec: { peaq: OverrideBundleDefinition } }).spec.peaq; diff --git a/packages/apps-config/src/api/spec/pendulum.ts b/packages/apps-config/src/api/spec/pendulum.ts new file mode 100644 index 000000000000..62a3a91305e6 --- /dev/null +++ b/packages/apps-config/src/api/spec/pendulum.ts @@ -0,0 +1,8 @@ +// Copyright 2017-2023 @polkadot/apps-config authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +import type { OverrideBundleDefinition } from '@polkadot/types/types'; + +import { typesBundleForPolkadot } from '@pendulum-chain/type-definitions'; + +export default (typesBundleForPolkadot as { spec: { pendulum: OverrideBundleDefinition } }).spec.pendulum; diff --git a/packages/apps-config/src/api/spec/polymesh-mainnet.ts b/packages/apps-config/src/api/spec/polymesh-mainnet.ts new file mode 100644 index 000000000000..7cfd50785ed2 --- /dev/null +++ b/packages/apps-config/src/api/spec/polymesh-mainnet.ts @@ -0,0 +1,10 @@ +// Copyright 2017-2023 @polkadot/apps-config authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +import type { OverrideBundleDefinition } from '@polkadot/types/types'; + +import { typesBundle } from '@polymeshassociation/polymesh-types'; + +const definitions: OverrideBundleDefinition = typesBundle.spec.polymesh_mainnet; + +export default definitions; diff --git a/packages/apps-config/src/api/spec/polymesh-testnet.ts b/packages/apps-config/src/api/spec/polymesh-testnet.ts new file mode 100644 index 000000000000..6f67b9ca6a97 --- /dev/null +++ b/packages/apps-config/src/api/spec/polymesh-testnet.ts @@ -0,0 +1,10 @@ +// Copyright 2017-2023 @polkadot/apps-config authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +import type { OverrideBundleDefinition } from '@polkadot/types/types'; + +import { typesBundle } from '@polymeshassociation/polymesh-types'; + +const definitions: OverrideBundleDefinition = typesBundle.spec.polymesh_testnet; + +export default definitions; diff --git a/packages/apps-config/src/api/spec/sapphire.ts b/packages/apps-config/src/api/spec/sapphire.ts new file mode 100644 index 000000000000..a2176e7329be --- /dev/null +++ b/packages/apps-config/src/api/spec/sapphire.ts @@ -0,0 +1,13 @@ +// Copyright 2017-2023 @polkadot/apps-config authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +import type { OverrideBundleDefinition } from '@polkadot/types/types'; + +import pkg from '@unique-nft/sapphire-mainnet-types/definitions.js'; + +export default { + rpc: { + appPromotion: pkg.appPromotion.rpc, + unique: pkg.unique.rpc + } +} as OverrideBundleDefinition; diff --git a/packages/apps-config/src/api/index.spec.ts b/packages/apps-config/src/api/typesBundleCheck.spec.ts similarity index 93% rename from packages/apps-config/src/api/index.spec.ts rename to packages/apps-config/src/api/typesBundleCheck.spec.ts index 13843c1e56f8..76a3a67e5b7a 100644 --- a/packages/apps-config/src/api/index.spec.ts +++ b/packages/apps-config/src/api/typesBundleCheck.spec.ts @@ -15,7 +15,7 @@ function getDerives (spec: Record): string[] { .map(([k]) => k); } -describe('typesBundle', (): void => { +describe('typesBundle checks', (): void => { it('all derives are re-exported', (): void => { expect( getDerives(spec) diff --git a/packages/apps-config/src/ci/chainEndpoints.spec.ts b/packages/apps-config/src/ci/chainEndpoints.spec.ts index faceba173953..3cf070d4e093 100644 --- a/packages/apps-config/src/ci/chainEndpoints.spec.ts +++ b/packages/apps-config/src/ci/chainEndpoints.spec.ts @@ -40,17 +40,17 @@ describe('check endpoints', (): void => { ws: value })) .filter((v): v is Endpoint => !!v.ws); - let websocket: WebSocket | null = null; - let closeTimerId: ReturnType | null = null; for (const { name, ws: endpoint } of checks) { it(`${name} @ ${endpoint}`, async (): Promise => { const [,, hostWithPort] = endpoint.split('/'); const [host] = hostWithPort.split(':'); + let websocket: WebSocket | null = null; + let closeTimerId: ReturnType | null = null; await fetchJson(`https://dns.google/resolve?name=${host}`) .then((json) => - assert(json && json.Answer, 'No DNS entry') + assert(json?.Answer, 'No DNS entry') ) .then(() => new Promise((resolve, reject): void => { @@ -72,9 +72,9 @@ describe('check endpoints', (): void => { websocket.onmessage = (message: { data: string }): void => { try { - const result = (JSON.parse(message.data) as { result: unknown }).result as string; + const result = (JSON.parse(message.data) as { result?: string }).result; - assert(result.startsWith('0x'), 'Invalid response'); + assert(result?.startsWith('0x'), 'Invalid/non-hex response'); resolve(result); } catch (e) { reject(e); diff --git a/packages/apps-config/src/ci/fetch.ts b/packages/apps-config/src/ci/fetch.ts index bce2d80f97d1..bb8e6dcfc8a4 100644 --- a/packages/apps-config/src/ci/fetch.ts +++ b/packages/apps-config/src/ci/fetch.ts @@ -1,4 +1,4 @@ -// Copyright 2017-2023 @polkadot/apps authors & contributors +// Copyright 2017-2023 @polkadot/apps-config authors & contributors // SPDX-License-Identifier: Apache-2.0 import { fetch } from '@polkadot/x-fetch'; @@ -37,9 +37,9 @@ function fetchWithTimeout (url: string, timeout = 2_000): Promise (url: string, timeout?: number): Promise { - return fetchWithTimeout(url, timeout).then((r) => r && r.json()); + return fetchWithTimeout(url, timeout).then((r) => r?.json() || null); } export function fetchText (url: string, timeout?: number): Promise { - return fetchWithTimeout(url, timeout).then((r) => r && r.text()); + return fetchWithTimeout(url, timeout).then((r) => r?.text() || null); } diff --git a/packages/apps-config/src/endpoints/index.spec.ts b/packages/apps-config/src/endpoints/index.spec.ts index 27ef6c9fd23f..ba68cd978336 100644 --- a/packages/apps-config/src/endpoints/index.spec.ts +++ b/packages/apps-config/src/endpoints/index.spec.ts @@ -49,19 +49,28 @@ describe('urls are sorted', (): void => { return !hasDevelopment; }); - filtered.forEach(({ isHeader, text, textBy }, index): void => { + filtered.forEach(({ isHeader, paraId, text, textBy }, index): void => { if (isHeader) { lastHeader = text as string; } else { it(`${lastHeader}:: ${text as string}:: ${textBy}`, (): void => { + const item = filtered[index - 1]; + assert(( - filtered[index - 1].isHeader || - filtered[index - 1].linked || - (isNumber(filtered[index - 1].paraId) && (filtered[index - 1].paraId as number) < 2000) || - filtered[index - 1].text === '' || - text === filtered[index - 1].text || - (text as string).localeCompare(filtered[index - 1].text as string) === 1 - ), `${lastHeader}:: ${text as string} needs to be before ${filtered[index - 1].text as string}`); + item.isHeader || + item.linked || + ( + isNumber(item.paraId) && + ( + item.paraId < 2000 + ? isNumber(paraId) && paraId >= 2000 + : false + ) + ) || + item.text === '' || + text === item.text || + (text as string).localeCompare(item.text as string) === 1 + ), `${lastHeader}:: ${text as string} needs to be before ${item.text as string}`); }); } }); @@ -93,7 +102,7 @@ describe('urls are not duplicated', (): void => { }, {} as Record); for (const [url, paths] of Object.entries(map)) { - it(url, (): void => { + it(`${url}`, (): void => { assert(paths.length === 1, `${url} appears multiple times - ${paths.map((p) => `\n\t"${p}"`).join('')}`); }); } @@ -118,7 +127,7 @@ describe('endpopints naming', (): void => { }), {}); for (const [key, { name, provider }] of Object.entries(endpoints)) { - describe(key, (): void => { + describe(`${key}`, (): void => { it(`[${key}] has no emojis`, (): void => { assert(!emoji.test(name), `${name} should not contain any emojis`); assert(!emoji.test(provider), `${name}:: ${provider} should not contain any emojis`); diff --git a/packages/apps-config/src/endpoints/index.ts b/packages/apps-config/src/endpoints/index.ts index d3805eff50ac..7d1673cad71b 100644 --- a/packages/apps-config/src/endpoints/index.ts +++ b/packages/apps-config/src/endpoints/index.ts @@ -13,14 +13,10 @@ export { CUSTOM_ENDPOINT_KEY } from './development.js'; export * from './production.js'; export * from './testing.js'; -function defaultT (keyOrText: string, text?: string, options?: TOptions): string { +function defaultT (keyOrText: string, text?: string | TOptions, options?: TOptions): string { return ( - ( - options && - options.replace && - options.replace.host - ) || - text || + (options?.replace?.host as string) || + text?.toString() || keyOrText ); } diff --git a/packages/apps-config/src/endpoints/types.ts b/packages/apps-config/src/endpoints/types.ts index ae16bbf6fac7..110d8619e638 100644 --- a/packages/apps-config/src/endpoints/types.ts +++ b/packages/apps-config/src/endpoints/types.ts @@ -1,17 +1,21 @@ // Copyright 2017-2023 @polkadot/apps-config authors & contributors // SPDX-License-Identifier: Apache-2.0 +import type React from 'react'; +import type { IconTheme } from '@polkadot/react-identicon/types'; +import type { HexString } from '@polkadot/util/types'; import type { Option } from '../settings/types.js'; interface BaseOption { dnslink?: string; - genesisHash?: string; + genesisHash?: HexString; homepage?: string; paraId?: number; summary?: string; teleport?: number[]; ui: { color?: string; + identityIcon?: IconTheme; logo?: string; } } @@ -23,12 +27,12 @@ export interface EndpointOption extends BaseOption { isUnreachable?: boolean; linked?: EndpointOption[]; info?: string; - providers: Record; + providers: Record; text: string; } export interface LinkOption extends BaseOption, Option { - genesisHashRelay?: string; + genesisHashRelay?: HexString; isChild?: boolean; isDevelopment?: boolean; isLightClient?: boolean; diff --git a/packages/apps-config/src/endpoints/util.ts b/packages/apps-config/src/endpoints/util.ts index aca9116e91d3..8600703f603e 100644 --- a/packages/apps-config/src/endpoints/util.ts +++ b/packages/apps-config/src/endpoints/util.ts @@ -38,6 +38,14 @@ function expandLinked (input: LinkOption[]): LinkOption[] { : undefined; child.valueRelay = valueRelay; + if (entry.ui?.identityIcon && child.paraId && child.paraId < 2000) { + if (!child.ui) { + child.ui = { identityIcon: entry.ui.identityIcon }; + } else if (!child.ui.identityIcon) { + child.ui.identityIcon = entry.ui.identityIcon; + } + } + return child; }) ) diff --git a/packages/apps-config/src/extensions/polkadot-js.ts b/packages/apps-config/src/extensions/polkadot-js.ts index cf9ffe2df663..482f474f22b8 100644 --- a/packages/apps-config/src/extensions/polkadot-js.ts +++ b/packages/apps-config/src/extensions/polkadot-js.ts @@ -6,7 +6,7 @@ import type { Known } from './types.js'; import { extensionsPolkadotJsSVG } from '../ui/logos/extensions/index.js'; import { externalEmptySVG } from '../ui/logos/external/index.js'; -export const PolkadotJs = { +export const PolkadotJs: Known = { all: { chrome: 'https://chrome.google.com/webstore/detail/polkadot%7Bjs%7D-extension/mopnmbcafieddcagagdcbnhejhlodfdd', firefox: 'https://addons.mozilla.org/en-US/firefox/addon/polkadot-js-extension/' @@ -18,4 +18,4 @@ export const PolkadotJs = { // check, aka it actually has no effect (the first part is always defined) logo: extensionsPolkadotJsSVG || externalEmptySVG } -} satisfies Known; +}; diff --git a/packages/apps-config/src/links/moonbeamApps.ts b/packages/apps-config/src/links/moonbeamApps.ts new file mode 100644 index 000000000000..31bbdd8d5fef --- /dev/null +++ b/packages/apps-config/src/links/moonbeamApps.ts @@ -0,0 +1,28 @@ +// Copyright 2017-2023 @polkadot/apps-config authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +import type { BN } from '@polkadot/util'; +import type { ExternalDef } from './types.js'; + +import { externalMoonbeamAppsSVG } from '../ui/logos/external/index.js'; + +export const MoonbeamApps: ExternalDef = { + chains: { + 'Moonbase Alpha': 'moonbase-alpha', + Moonbeam: 'moonbeam', + Moonriver: 'moonriver' + }, + create: (chain: string, path: string, data: BN | number | string): string => + `https://apps.moonbeam.network/${chain}/${path}/${data.toString()}`, + homepage: 'https://apps.moonbeam.network/', + isActive: true, + paths: { + referenda: 'referendum' + }, + ui: { + logo: { + dark: externalMoonbeamAppsSVG, + light: externalMoonbeamAppsSVG + } + } +}; diff --git a/packages/apps-config/src/links/types.ts b/packages/apps-config/src/links/types.ts index d5d2e6cad467..33b73877a5cb 100644 --- a/packages/apps-config/src/links/types.ts +++ b/packages/apps-config/src/links/types.ts @@ -1,10 +1,9 @@ // Copyright 2017-2023 @polkadot/apps-config authors & contributors // SPDX-License-Identifier: Apache-2.0 +import type { ApiPromise } from '@polkadot/api'; import type { BN } from '@polkadot/util'; -import { ApiPromise } from '@polkadot/api'; - export interface LinkPath { // general address?: string; diff --git a/packages/apps-config/src/packageInfo.ts b/packages/apps-config/src/packageInfo.ts index 3d33fc70ef17..65ee4e952257 100644 --- a/packages/apps-config/src/packageInfo.ts +++ b/packages/apps-config/src/packageInfo.ts @@ -3,4 +3,4 @@ // Do not edit, auto-generated by @polkadot/dev -export const packageInfo = { name: '@polkadot/apps-config', path: 'auto', type: 'auto', version: '0.127.2-2-x' }; +export const packageInfo = { name: '@polkadot/apps-config', path: 'auto', type: 'auto', version: '0.132.2-98-x' }; diff --git a/packages/apps-config/src/settings/ethereumChains.ts b/packages/apps-config/src/settings/ethereumChains.ts index 8fd952bcf964..f2f7aaa31cc4 100644 --- a/packages/apps-config/src/settings/ethereumChains.ts +++ b/packages/apps-config/src/settings/ethereumChains.ts @@ -4,11 +4,13 @@ // The list of Ethereum networks, for these the UI will default to Ethereum-only accounts export const ethereumChains = [ + 'mythical-devnet', 'frontier-template', 'jaz', 'moonbase', 'moonbeam', 'moonriver', + 'moonsama', 'moonshadow', 'altbeacon', 'alt-producer', @@ -24,5 +26,9 @@ export const ethereumChains = [ 'thebifrost-testnet', 'thebifrost-mainnet', 'dracones', - 'dracones-dwarf' + 'dracones-dwarf', + 'subspace-evm-domain', + 'ferrum-parachain', + 'quantum-portal-network-parachain', + 'peerplays' ]; diff --git a/packages/apps-config/src/settings/ss58.ts b/packages/apps-config/src/settings/ss58.ts index 0fd3aacba836..2b17d331c17e 100644 --- a/packages/apps-config/src/settings/ss58.ts +++ b/packages/apps-config/src/settings/ss58.ts @@ -1,4 +1,4 @@ -// Copyright 2017-2023 @polkadot/ui-settings authors & contributors +// Copyright 2017-2023 @polkadot/apps-config authors & contributors // SPDX-License-Identifier: Apache-2.0 import type { TFunction } from '../types.js'; diff --git a/packages/apps-config/src/settings/types.ts b/packages/apps-config/src/settings/types.ts index 472c06041b55..b608cfaf7b08 100644 --- a/packages/apps-config/src/settings/types.ts +++ b/packages/apps-config/src/settings/types.ts @@ -1,6 +1,8 @@ // Copyright 2017-2023 @polkadot/apps-config authors & contributors // SPDX-License-Identifier: Apache-2.0 +import type React from 'react'; + export interface Option { info?: string; isDisabled?: boolean; diff --git a/packages/apps-config/src/types.ts b/packages/apps-config/src/types.ts index 807a34c9455a..88a4c9693e94 100644 --- a/packages/apps-config/src/types.ts +++ b/packages/apps-config/src/types.ts @@ -3,7 +3,7 @@ export interface TOptions { ns?: string; - replace?: Record + replace?: Record } -export type TFunction = (keyOrText: string, text?: string, options?: TOptions) => string; +export type TFunction = (keyOrText: string, textOrOptions?: string | TOptions, options?: TOptions) => string; diff --git a/packages/apps-config/src/ui/identityIcons/index.ts b/packages/apps-config/src/ui/identityIcons/index.ts index c7de1d80233c..bddcd639738a 100644 --- a/packages/apps-config/src/ui/identityIcons/index.ts +++ b/packages/apps-config/src/ui/identityIcons/index.ts @@ -18,10 +18,7 @@ export const identitySpec: Record = [ ['kusama', 'polkadot'], ['polkadot', 'polkadot'], ['rococo', 'polkadot'], - ['statemine', 'polkadot'], - ['statemint', 'polkadot'], - ['westend', 'polkadot'], - ['westmint', 'polkadot'] + ['westend', 'polkadot'] ].reduce((icons, [spec, icon]): Record => ({ ...icons, [spec.toLowerCase().replace(/-/g, ' ')]: icon diff --git a/packages/apps-config/src/ui/logos/chains/3dpass.svg b/packages/apps-config/src/ui/logos/chains/3dpass.svg new file mode 100644 index 000000000000..fe5a1a56fed6 --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/3dpass.svg @@ -0,0 +1,26 @@ + + + + + + + + + + + + + + + + + + + + + diff --git a/packages/apps-config/src/ui/logos/chains/aband.png b/packages/apps-config/src/ui/logos/chains/aband.png new file mode 100644 index 000000000000..38c619c2ceec Binary files /dev/null and b/packages/apps-config/src/ui/logos/chains/aband.png differ diff --git a/packages/apps-config/src/ui/logos/chains/acurast.png b/packages/apps-config/src/ui/logos/chains/acurast.png new file mode 100644 index 000000000000..e74d75abe1bd Binary files /dev/null and b/packages/apps-config/src/ui/logos/chains/acurast.png differ diff --git a/packages/apps-config/src/ui/logos/chains/bittensor.png b/packages/apps-config/src/ui/logos/chains/bittensor.png new file mode 100644 index 000000000000..8228a99c2f08 Binary files /dev/null and b/packages/apps-config/src/ui/logos/chains/bittensor.png differ diff --git a/packages/apps-config/src/ui/logos/chains/debio.svg b/packages/apps-config/src/ui/logos/chains/debio.svg new file mode 100644 index 000000000000..7407499d0e8f --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/debio.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/packages/apps-config/src/ui/logos/chains/ferrum.png b/packages/apps-config/src/ui/logos/chains/ferrum.png new file mode 100644 index 000000000000..58fc430b81bf Binary files /dev/null and b/packages/apps-config/src/ui/logos/chains/ferrum.png differ diff --git a/packages/apps-config/src/ui/logos/chains/fragnova.png b/packages/apps-config/src/ui/logos/chains/fragnova.png new file mode 100644 index 000000000000..b89a0fa33978 Binary files /dev/null and b/packages/apps-config/src/ui/logos/chains/fragnova.png differ diff --git a/packages/apps-config/src/ui/logos/chains/generated/3dpassSVG.ts b/packages/apps-config/src/ui/logos/chains/generated/3dpassSVG.ts new file mode 100644 index 000000000000..4fd0eab7e878 --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/3dpassSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chains3dpassSVG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/abandPNG.ts b/packages/apps-config/src/ui/logos/chains/generated/abandPNG.ts new file mode 100644 index 000000000000..30f2347fb57b --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/abandPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsAbandPNG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/acurastPNG.ts b/packages/apps-config/src/ui/logos/chains/generated/acurastPNG.ts new file mode 100644 index 000000000000..3d1b8934e91f --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/acurastPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsAcurastPNG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/bittensorPNG.ts b/packages/apps-config/src/ui/logos/chains/generated/bittensorPNG.ts new file mode 100644 index 000000000000..2ac8e4b8244e --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/bittensorPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsBittensorPNG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/debioSVG.ts b/packages/apps-config/src/ui/logos/chains/generated/debioSVG.ts new file mode 100644 index 000000000000..efe337c073c5 --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/debioSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsDebioSVG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/ferrumPNG.ts b/packages/apps-config/src/ui/logos/chains/generated/ferrumPNG.ts new file mode 100644 index 000000000000..c954619678af --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/ferrumPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsFerrumPNG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/fragnovaPNG.ts b/packages/apps-config/src/ui/logos/chains/generated/fragnovaPNG.ts new file mode 100644 index 000000000000..7266c51c6b44 --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/fragnovaPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsFragnovaPNG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/gmJPEG.ts b/packages/apps-config/src/ui/logos/chains/generated/gmJPEG.ts new file mode 100644 index 000000000000..9b385a378add --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/gmJPEG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsGmJPEG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/idiyanale_logo_whiteSVG.ts b/packages/apps-config/src/ui/logos/chains/generated/idiyanale_logo_whiteSVG.ts new file mode 100644 index 000000000000..ea05ac4d1e2f --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/idiyanale_logo_whiteSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsIdiyanaleLogoWhiteSVG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/invarchJPEG.ts b/packages/apps-config/src/ui/logos/chains/generated/invarchJPEG.ts new file mode 100644 index 000000000000..69f59d318fb7 --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/invarchJPEG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsInvarchJPEG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/jurPNG.ts b/packages/apps-config/src/ui/logos/chains/generated/jurPNG.ts new file mode 100644 index 000000000000..938228bc3833 --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/jurPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsJurPNG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/kusamaSVG.ts b/packages/apps-config/src/ui/logos/chains/generated/kusamaSVG.ts new file mode 100644 index 000000000000..fc6c0af91f9d --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/kusamaSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsKusamaSVG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/mangataxPNG.ts b/packages/apps-config/src/ui/logos/chains/generated/mangataxPNG.ts new file mode 100644 index 000000000000..8a144b6e63da --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/mangataxPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsMangataxPNG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/myriadPNG.ts b/packages/apps-config/src/ui/logos/chains/generated/myriadPNG.ts new file mode 100644 index 000000000000..94e3e1a2328b --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/myriadPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsMyriadPNG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/peaqPNG.ts b/packages/apps-config/src/ui/logos/chains/generated/peaqPNG.ts new file mode 100644 index 000000000000..d444f8993f20 --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/peaqPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsPeaqPNG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/qpnPNG.ts b/packages/apps-config/src/ui/logos/chains/generated/qpnPNG.ts new file mode 100644 index 000000000000..fb46c2bbe51e --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/qpnPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsQpnPNG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/generated/tanglePNG.ts b/packages/apps-config/src/ui/logos/chains/generated/tanglePNG.ts new file mode 100644 index 000000000000..f57fd113aaff --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/generated/tanglePNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const chainsTanglePNG = ''; diff --git a/packages/apps-config/src/ui/logos/chains/gm.jpeg b/packages/apps-config/src/ui/logos/chains/gm.jpeg new file mode 100644 index 000000000000..99300bbbd10e Binary files /dev/null and b/packages/apps-config/src/ui/logos/chains/gm.jpeg differ diff --git a/packages/apps-config/src/ui/logos/chains/idiyanale_logo_white.svg b/packages/apps-config/src/ui/logos/chains/idiyanale_logo_white.svg new file mode 100644 index 000000000000..1945959979a5 --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/idiyanale_logo_white.svg @@ -0,0 +1,16 @@ + + + + + + + + + + + + + + + + diff --git a/packages/apps-config/src/ui/logos/chains/index.ts b/packages/apps-config/src/ui/logos/chains/index.ts index 65769a0ac5aa..d0b504c9a4c2 100644 --- a/packages/apps-config/src/ui/logos/chains/index.ts +++ b/packages/apps-config/src/ui/logos/chains/index.ts @@ -3,4 +3,21 @@ // Do not edit. Auto-generated via node scripts/imgConvert.mjs +export { chains3dpassSVG } from './generated/3dpassSVG.js'; +export { chainsAbandPNG } from './generated/abandPNG.js'; +export { chainsAcurastPNG } from './generated/acurastPNG.js'; export { chainsAlephSVG } from './generated/alephSVG.js'; +export { chainsBittensorPNG } from './generated/bittensorPNG.js'; +export { chainsDebioSVG } from './generated/debioSVG.js'; +export { chainsFerrumPNG } from './generated/ferrumPNG.js'; +export { chainsFragnovaPNG } from './generated/fragnovaPNG.js'; +export { chainsGmJPEG } from './generated/gmJPEG.js'; +export { chainsIdiyanaleLogoWhiteSVG } from './generated/idiyanale_logo_whiteSVG.js'; +export { chainsInvarchJPEG } from './generated/invarchJPEG.js'; +export { chainsJurPNG } from './generated/jurPNG.js'; +export { chainsKusamaSVG } from './generated/kusamaSVG.js'; +export { chainsMangataxPNG } from './generated/mangataxPNG.js'; +export { chainsMyriadPNG } from './generated/myriadPNG.js'; +export { chainsPeaqPNG } from './generated/peaqPNG.js'; +export { chainsQpnPNG } from './generated/qpnPNG.js'; +export { chainsTanglePNG } from './generated/tanglePNG.js'; diff --git a/packages/apps-config/src/ui/logos/chains/invarch.jpeg b/packages/apps-config/src/ui/logos/chains/invarch.jpeg new file mode 100644 index 000000000000..38e6ff7c870c Binary files /dev/null and b/packages/apps-config/src/ui/logos/chains/invarch.jpeg differ diff --git a/packages/apps-config/src/ui/logos/chains/jur.png b/packages/apps-config/src/ui/logos/chains/jur.png new file mode 100644 index 000000000000..16503bae1857 Binary files /dev/null and b/packages/apps-config/src/ui/logos/chains/jur.png differ diff --git a/packages/apps-config/src/ui/logos/chains/kusama.svg b/packages/apps-config/src/ui/logos/chains/kusama.svg new file mode 100644 index 000000000000..b7b9da8de32a --- /dev/null +++ b/packages/apps-config/src/ui/logos/chains/kusama.svg @@ -0,0 +1 @@ +kusama-ksm-logo \ No newline at end of file diff --git a/packages/apps-config/src/ui/logos/chains/mangatax.png b/packages/apps-config/src/ui/logos/chains/mangatax.png new file mode 100644 index 000000000000..d3b1a2a5229d Binary files /dev/null and b/packages/apps-config/src/ui/logos/chains/mangatax.png differ diff --git a/packages/apps-config/src/ui/logos/chains/myriad.png b/packages/apps-config/src/ui/logos/chains/myriad.png new file mode 100644 index 000000000000..62305eb232a3 Binary files /dev/null and b/packages/apps-config/src/ui/logos/chains/myriad.png differ diff --git a/packages/apps-config/src/ui/logos/chains/peaq.png b/packages/apps-config/src/ui/logos/chains/peaq.png new file mode 100644 index 000000000000..1c963402c548 Binary files /dev/null and b/packages/apps-config/src/ui/logos/chains/peaq.png differ diff --git a/packages/apps-config/src/ui/logos/chains/qpn.png b/packages/apps-config/src/ui/logos/chains/qpn.png new file mode 100644 index 000000000000..9debdad9c926 Binary files /dev/null and b/packages/apps-config/src/ui/logos/chains/qpn.png differ diff --git a/packages/apps-config/src/ui/logos/chains/tangle.png b/packages/apps-config/src/ui/logos/chains/tangle.png new file mode 100644 index 000000000000..f3f1fe465324 Binary files /dev/null and b/packages/apps-config/src/ui/logos/chains/tangle.png differ diff --git a/packages/apps-config/src/ui/logos/external/generated/moonbeamAppsSVG.ts b/packages/apps-config/src/ui/logos/external/generated/moonbeamAppsSVG.ts new file mode 100644 index 000000000000..d258d599969e --- /dev/null +++ b/packages/apps-config/src/ui/logos/external/generated/moonbeamAppsSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const externalMoonbeamAppsSVG = ''; diff --git a/packages/apps-config/src/ui/logos/external/index.ts b/packages/apps-config/src/ui/logos/external/index.ts index d662cc52f818..24ad43239bf7 100644 --- a/packages/apps-config/src/ui/logos/external/index.ts +++ b/packages/apps-config/src/ui/logos/external/index.ts @@ -11,6 +11,7 @@ export { externalDotreasurySVG } from './generated/dotreasurySVG.js'; export { externalDotscannerPNG } from './generated/dotscannerPNG.js'; export { externalEmptySVG } from './generated/emptySVG.js'; export { externalKodadotPNG } from './generated/kodadotPNG.js'; +export { externalMoonbeamAppsSVG } from './generated/moonbeamAppsSVG.js'; export { externalPolkaholicPNG } from './generated/polkaholicPNG.js'; export { externalPolkascanPNG } from './generated/polkascanPNG.js'; export { externalPolkassemblyPNG } from './generated/polkassemblyPNG.js'; diff --git a/packages/apps-config/src/ui/logos/external/moonbeamApps.svg b/packages/apps-config/src/ui/logos/external/moonbeamApps.svg new file mode 100644 index 000000000000..5c248360899e --- /dev/null +++ b/packages/apps-config/src/ui/logos/external/moonbeamApps.svg @@ -0,0 +1,29 @@ + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/packages/apps-config/src/ui/logos/nodes/assetHub.svg b/packages/apps-config/src/ui/logos/nodes/assetHub.svg new file mode 100644 index 000000000000..322c339afc12 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/assetHub.svg @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + diff --git a/packages/apps-config/src/ui/logos/nodes/bridgeHub.svg b/packages/apps-config/src/ui/logos/nodes/bridgeHub.svg new file mode 100644 index 000000000000..f0204b3bf696 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/bridgeHub.svg @@ -0,0 +1,26 @@ + + + + + + + + + + + + + + + diff --git a/packages/apps-config/src/ui/logos/nodes/bridgeHubBlack.svg b/packages/apps-config/src/ui/logos/nodes/bridgeHubBlack.svg new file mode 100644 index 000000000000..8871a844ae90 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/bridgeHubBlack.svg @@ -0,0 +1,24 @@ + + + + + + + + + + + + + + + diff --git a/packages/apps-config/src/ui/logos/nodes/cere.svg b/packages/apps-config/src/ui/logos/nodes/cere.svg new file mode 100644 index 000000000000..ae7adc7ecfd9 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/cere.svg @@ -0,0 +1,26 @@ + + + + + + + + + + + + + + + + + diff --git a/packages/apps-config/src/ui/logos/nodes/curio.svg b/packages/apps-config/src/ui/logos/nodes/curio.svg new file mode 100644 index 000000000000..90eae47fa487 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/curio.svg @@ -0,0 +1,4 @@ + + + + diff --git a/packages/apps-config/src/ui/logos/nodes/ewx.svg b/packages/apps-config/src/ui/logos/nodes/ewx.svg new file mode 100644 index 000000000000..dd264adc57db --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/ewx.svg @@ -0,0 +1,5 @@ + + + + + diff --git a/packages/apps-config/src/ui/logos/nodes/generated/assetHubSVG.ts b/packages/apps-config/src/ui/logos/nodes/generated/assetHubSVG.ts new file mode 100644 index 000000000000..0405b4cb7602 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/assetHubSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesAssetHubSVG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/bridgeHubBlackSVG.ts b/packages/apps-config/src/ui/logos/nodes/generated/bridgeHubBlackSVG.ts new file mode 100644 index 000000000000..8c0043295b50 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/bridgeHubBlackSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesBridgeHubBlackSVG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/bridgeHubSVG.ts b/packages/apps-config/src/ui/logos/nodes/generated/bridgeHubSVG.ts new file mode 100644 index 000000000000..3086dcbd6877 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/bridgeHubSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesBridgeHubSVG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/cereSVG.ts b/packages/apps-config/src/ui/logos/nodes/generated/cereSVG.ts new file mode 100644 index 000000000000..2ccc6752fc04 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/cereSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesCereSVG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/curioSVG.ts b/packages/apps-config/src/ui/logos/nodes/generated/curioSVG.ts new file mode 100644 index 000000000000..d3fe515ce174 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/curioSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesCurioSVG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/ewxSVG.ts b/packages/apps-config/src/ui/logos/nodes/generated/ewxSVG.ts new file mode 100644 index 000000000000..6ce638f7728d --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/ewxSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesEwxSVG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/giantPNG.ts b/packages/apps-config/src/ui/logos/nodes/generated/giantPNG.ts new file mode 100644 index 000000000000..1622114d2fd2 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/giantPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesGiantPNG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/hanyonycashPNG.ts b/packages/apps-config/src/ui/logos/nodes/generated/hanyonycashPNG.ts new file mode 100644 index 000000000000..defb15af9c94 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/hanyonycashPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesHanyonycashPNG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/humanodePNG.ts b/packages/apps-config/src/ui/logos/nodes/generated/humanodePNG.ts new file mode 100644 index 000000000000..33a9e3d2d420 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/humanodePNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesHumanodePNG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/karmachainSVG.ts b/packages/apps-config/src/ui/logos/nodes/generated/karmachainSVG.ts new file mode 100644 index 000000000000..d580818687cd --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/karmachainSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesKarmachainSVG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/krestPNG.ts b/packages/apps-config/src/ui/logos/nodes/generated/krestPNG.ts new file mode 100644 index 000000000000..ed43db425ac5 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/krestPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesKrestPNG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/litentry-rococoPNG.ts b/packages/apps-config/src/ui/logos/nodes/generated/litentry-rococoPNG.ts new file mode 100644 index 000000000000..2cbc3a583e3a --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/litentry-rococoPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesLitentryRococoPNG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/moonbase_alphaSVG.ts b/packages/apps-config/src/ui/logos/nodes/generated/moonbase_alphaSVG.ts new file mode 100644 index 000000000000..0d99f7dcfbe2 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/moonbase_alphaSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesMoonbaseAlphaSVG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/moonbeamSVG.ts b/packages/apps-config/src/ui/logos/nodes/generated/moonbeamSVG.ts new file mode 100644 index 000000000000..346175b3c907 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/moonbeamSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesMoonbeamSVG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/moonsamaSVG.ts b/packages/apps-config/src/ui/logos/nodes/generated/moonsamaSVG.ts new file mode 100644 index 000000000000..a83e3a9a08ac --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/moonsamaSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesMoonsamaSVG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/paramiJPEG.ts b/packages/apps-config/src/ui/logos/nodes/generated/paramiJPEG.ts new file mode 100644 index 000000000000..ab7f0874c771 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/paramiJPEG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesParamiJPEG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/rexSVG.ts b/packages/apps-config/src/ui/logos/nodes/generated/rexSVG.ts new file mode 100644 index 000000000000..c6237b29500a --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/rexSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesRexSVG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/societalSVG.ts b/packages/apps-config/src/ui/logos/nodes/generated/societalSVG.ts new file mode 100644 index 000000000000..6df11b27b196 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/societalSVG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesSocietalSVG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/t3rnPNG.ts b/packages/apps-config/src/ui/logos/nodes/generated/t3rnPNG.ts new file mode 100644 index 000000000000..e1aa22442743 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/t3rnPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesT3rnPNG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/thebifrostPNG.ts b/packages/apps-config/src/ui/logos/nodes/generated/thebifrostPNG.ts new file mode 100644 index 000000000000..cbb0dcec91d6 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/thebifrostPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesThebifrostPNG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/generated/trappist-rococoPNG.ts b/packages/apps-config/src/ui/logos/nodes/generated/trappist-rococoPNG.ts new file mode 100644 index 000000000000..eb043d090b8c --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/generated/trappist-rococoPNG.ts @@ -0,0 +1,6 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export const nodesTrappistRococoPNG = ''; diff --git a/packages/apps-config/src/ui/logos/nodes/giant.png b/packages/apps-config/src/ui/logos/nodes/giant.png new file mode 100644 index 000000000000..c8323df28cf1 Binary files /dev/null and b/packages/apps-config/src/ui/logos/nodes/giant.png differ diff --git a/packages/apps-config/src/ui/logos/nodes/hanyonycash.png b/packages/apps-config/src/ui/logos/nodes/hanyonycash.png new file mode 100644 index 000000000000..9db64274707f Binary files /dev/null and b/packages/apps-config/src/ui/logos/nodes/hanyonycash.png differ diff --git a/packages/apps-config/src/ui/logos/nodes/humanode.png b/packages/apps-config/src/ui/logos/nodes/humanode.png new file mode 100644 index 000000000000..eb71780ac1ef Binary files /dev/null and b/packages/apps-config/src/ui/logos/nodes/humanode.png differ diff --git a/packages/apps-config/src/ui/logos/nodes/index.ts b/packages/apps-config/src/ui/logos/nodes/index.ts new file mode 100644 index 000000000000..43c97171c8f5 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/index.ts @@ -0,0 +1,26 @@ +// Copyright 2017-2023 @polkadot/apps authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +// Do not edit. Auto-generated via node scripts/imgConvert.mjs + +export { nodesAssetHubSVG } from './generated/assetHubSVG.js'; +export { nodesBridgeHubBlackSVG } from './generated/bridgeHubBlackSVG.js'; +export { nodesBridgeHubSVG } from './generated/bridgeHubSVG.js'; +export { nodesCereSVG } from './generated/cereSVG.js'; +export { nodesCurioSVG } from './generated/curioSVG.js'; +export { nodesEwxSVG } from './generated/ewxSVG.js'; +export { nodesGiantPNG } from './generated/giantPNG.js'; +export { nodesHanyonycashPNG } from './generated/hanyonycashPNG.js'; +export { nodesHumanodePNG } from './generated/humanodePNG.js'; +export { nodesKarmachainSVG } from './generated/karmachainSVG.js'; +export { nodesKrestPNG } from './generated/krestPNG.js'; +export { nodesLitentryRococoPNG } from './generated/litentry-rococoPNG.js'; +export { nodesMoonbaseAlphaSVG } from './generated/moonbase_alphaSVG.js'; +export { nodesMoonbeamSVG } from './generated/moonbeamSVG.js'; +export { nodesMoonsamaSVG } from './generated/moonsamaSVG.js'; +export { nodesParamiJPEG } from './generated/paramiJPEG.js'; +export { nodesRexSVG } from './generated/rexSVG.js'; +export { nodesSocietalSVG } from './generated/societalSVG.js'; +export { nodesT3rnPNG } from './generated/t3rnPNG.js'; +export { nodesThebifrostPNG } from './generated/thebifrostPNG.js'; +export { nodesTrappistRococoPNG } from './generated/trappist-rococoPNG.js'; diff --git a/packages/apps-config/src/ui/logos/nodes/karmachain.svg b/packages/apps-config/src/ui/logos/nodes/karmachain.svg new file mode 100644 index 000000000000..c15c4d4fe430 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/karmachain.svg @@ -0,0 +1,13 @@ + + + + + + + + + + + + + diff --git a/packages/apps-config/src/ui/logos/nodes/krest.png b/packages/apps-config/src/ui/logos/nodes/krest.png new file mode 100644 index 000000000000..6e8dad25a7c5 Binary files /dev/null and b/packages/apps-config/src/ui/logos/nodes/krest.png differ diff --git a/packages/apps-config/src/ui/logos/nodes/litentry-rococo.png b/packages/apps-config/src/ui/logos/nodes/litentry-rococo.png new file mode 100644 index 000000000000..9666e2431ee4 Binary files /dev/null and b/packages/apps-config/src/ui/logos/nodes/litentry-rococo.png differ diff --git a/packages/apps-config/src/ui/logos/nodes/moonbase_alpha.svg b/packages/apps-config/src/ui/logos/nodes/moonbase_alpha.svg new file mode 100644 index 000000000000..6e7977e3abf4 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/moonbase_alpha.svg @@ -0,0 +1,136 @@ + + diff --git a/packages/apps-config/src/ui/logos/nodes/moonbeam.svg b/packages/apps-config/src/ui/logos/nodes/moonbeam.svg new file mode 100644 index 000000000000..92410ce5e509 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/moonbeam.svg @@ -0,0 +1,160 @@ + + diff --git a/packages/apps-config/src/ui/logos/nodes/moonsama.svg b/packages/apps-config/src/ui/logos/nodes/moonsama.svg new file mode 100644 index 000000000000..c6730b02e93c --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/moonsama.svg @@ -0,0 +1,17 @@ + + + + + + + + \ No newline at end of file diff --git a/packages/apps-config/src/ui/logos/nodes/parami.jpeg b/packages/apps-config/src/ui/logos/nodes/parami.jpeg new file mode 100644 index 000000000000..61be89004f6a Binary files /dev/null and b/packages/apps-config/src/ui/logos/nodes/parami.jpeg differ diff --git a/packages/apps-config/src/ui/logos/nodes/rex.svg b/packages/apps-config/src/ui/logos/nodes/rex.svg new file mode 100644 index 000000000000..e67c6fd7a231 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/rex.svg @@ -0,0 +1,5 @@ + + + + + diff --git a/packages/apps-config/src/ui/logos/nodes/societal.svg b/packages/apps-config/src/ui/logos/nodes/societal.svg new file mode 100644 index 000000000000..6165e2c4fff6 --- /dev/null +++ b/packages/apps-config/src/ui/logos/nodes/societal.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/packages/apps-config/src/ui/logos/nodes/t3rn.png b/packages/apps-config/src/ui/logos/nodes/t3rn.png new file mode 100644 index 000000000000..a0be9636a786 Binary files /dev/null and b/packages/apps-config/src/ui/logos/nodes/t3rn.png differ diff --git a/packages/apps-config/src/ui/logos/nodes/thebifrost.png b/packages/apps-config/src/ui/logos/nodes/thebifrost.png new file mode 100644 index 000000000000..54d6ef499cdb Binary files /dev/null and b/packages/apps-config/src/ui/logos/nodes/thebifrost.png differ diff --git a/packages/apps-config/src/ui/logos/nodes/trappist-rococo.png b/packages/apps-config/src/ui/logos/nodes/trappist-rococo.png new file mode 100644 index 000000000000..acc27645873e Binary files /dev/null and b/packages/apps-config/src/ui/logos/nodes/trappist-rococo.png differ diff --git a/packages/apps-config/tsconfig.build.json b/packages/apps-config/tsconfig.build.json index da24d9f22599..5df00c785e0b 100644 --- a/packages/apps-config/tsconfig.build.json +++ b/packages/apps-config/tsconfig.build.json @@ -3,7 +3,13 @@ "compilerOptions": { "baseUrl": "..", "outDir": "./build", - "rootDir": "./src" + "rootDir": "./src", + /* Some of our types dependencies are not playing along nicely */ + "verbatimModuleSyntax": false }, + "exclude": [ + "**/build-*", + "**/*.spec.ts" + ], "references": [] } diff --git a/packages/apps-config/tsconfig.spec.json b/packages/apps-config/tsconfig.spec.json new file mode 100644 index 000000000000..cd3d7f37b2b5 --- /dev/null +++ b/packages/apps-config/tsconfig.spec.json @@ -0,0 +1,16 @@ +{ + "extends": "../../tsconfig.base.json", + "compilerOptions": { + "baseUrl": "..", + "outDir": "./build", + "rootDir": "./src", + "emitDeclarationOnly": false, + "noEmit": true + }, + "include": [ + "**/*.spec.ts" + ], + "references": [ + { "path": "../apps-config/tsconfig.build.json" } + ] +} diff --git a/electron-builder.yml b/packages/apps-electron/electron-builder.yml similarity index 69% rename from electron-builder.yml rename to packages/apps-electron/electron-builder.yml index df6ad0a93c0b..0894de4aa613 100644 --- a/electron-builder.yml +++ b/packages/apps-electron/electron-builder.yml @@ -2,10 +2,12 @@ productName: Polkadot-JS Apps artifactName: Polkadot-JS-Apps-${version}.${ext} files: - - "./packages/apps-electron/build" - - "./packages/apps-electron/assets" - - "./packages/apps-electron/appleEntitlements" + - "./build" + - "./assets" + - "./appleEntitlements" appId: com.polkadotjs.polkadotjs-apps +linux: + executableName: polkadot-apps mac: artifactName: Polkadot-JS-Apps-mac-${version}.${ext} category: public.app-category.finance @@ -14,6 +16,6 @@ mac: NSCameraUsageDescription: "This app requires camera access to capture account data on imports" hardenedRuntime: true directories: - buildResources: "./packages/apps-electron/assets" - output: "./packages/apps-electron/release" + buildResources: "./assets" + output: "./release" afterSign: electron-builder-notarize diff --git a/packages/apps-electron/package.json b/packages/apps-electron/package.json index bb82a0cb4d22..769063a19915 100644 --- a/packages/apps-electron/package.json +++ b/packages/apps-electron/package.json @@ -1,32 +1,37 @@ { - "bugs": "https://github.com/polkadot-js/apps/issues", + "author": "Jaco Greeff ", + "bugs": "https://github.com/Cardinal-Cryptography/azero-dev/issues", + "description": "An Apps portal into the Polkadot network", "engines": { - "node": ">=14" + "node": ">=16" }, - "homepage": "https://github.com/polkadot-js/apps/tree/master/packages/apps-electron#readme", + "homepage": "https://github.com/Cardinal-Cryptography/azero-dev/tree/master/packages/apps-electron#readme", "license": "Apache-2.0", "name": "@polkadot/apps-electron", "private": true, "repository": { "directory": "packages/apps-electron", "type": "git", - "url": "https://github.com/polkadot-js/apps.git" + "url": "https://github.com/Cardinal-Cryptography/azero-dev.git" }, "sideEffects": false, - "version": "0.127.2-2-x", + "version": "0.132.2-98-x", + "main": "build/electron.js", "dependencies": { - "@polkadot/dev": "^0.72.43", - "@polkadot/react-components": "^0.127.2-2-x", - "electron-log": "^5.0.0-beta.16", + "electron-log": "^5.0.0-beta.23", "electron-updater": "^5.3.0" }, "devDependencies": { - "@types/react-dom": "^18.0.11", + "@polkadot/dev": "^0.76.18", "@types/tmp": "^0.2.3", "copy-webpack-plugin": "^11.0.0", - "html-webpack-plugin": "^5.5.1", - "react": "^18.2.0", - "react-dom": "^18.2.0", + "electron": "25.0.1", + "electron-builder": "23.6.0", + "electron-builder-notarize": "^1.5.1", + "html-webpack-plugin": "^5.5.3", "tmp": "^0.2.1" + }, + "peerDependencies": { + "webpack": "*" } } diff --git a/packages/apps-electron/src/electron/autoUpdater.ts b/packages/apps-electron/src/electron/autoUpdater.ts index 45eff9bf1cb9..935c1fe85ce8 100644 --- a/packages/apps-electron/src/electron/autoUpdater.ts +++ b/packages/apps-electron/src/electron/autoUpdater.ts @@ -1,7 +1,7 @@ // Copyright 2017-2023 @polkadot/apps authors & contributors // SPDX-License-Identifier: Apache-2.0 -import { AppUpdater } from 'electron-updater'; +import type { AppUpdater } from 'electron-updater'; export async function setupAutoUpdater (): Promise { const { autoUpdater } = await import('electron-updater'); diff --git a/packages/apps-electron/src/electron/contentSecurityPolicy.ts b/packages/apps-electron/src/electron/contentSecurityPolicy.ts index a9d105a12056..4c6f6f540228 100644 --- a/packages/apps-electron/src/electron/contentSecurityPolicy.ts +++ b/packages/apps-electron/src/electron/contentSecurityPolicy.ts @@ -1,7 +1,9 @@ // Copyright 2017-2023 @polkadot/apps authors & contributors // SPDX-License-Identifier: Apache-2.0 -import { HeadersReceivedResponse, session } from 'electron'; +import type { HeadersReceivedResponse } from 'electron'; + +import { session } from 'electron'; export function setupContentSecurityPolicy (_: string): void { session.defaultSession.webRequest.onHeadersReceived((details, respond: (response: HeadersReceivedResponse) => void) => { diff --git a/packages/apps-electron/src/main/account-store.spec.ts b/packages/apps-electron/src/main/account-store.spec.ts index 50a2182ac9df..663ac4fa1716 100644 --- a/packages/apps-electron/src/main/account-store.spec.ts +++ b/packages/apps-electron/src/main/account-store.spec.ts @@ -6,6 +6,7 @@ // eslint-disable-next-line @typescript-eslint/ban-ts-comment // @ts-ignore Warned on by nodenext resolution (while package does build in bundler mode) import type { KeyringJson } from '@polkadot/ui-keyring/types'; +import type { IpcMainHandler } from './ipc-main-handler.js'; import * as tmp from 'tmp'; @@ -14,7 +15,6 @@ import * as tmp from 'tmp'; import { FileStore } from '@polkadot/ui-keyring/stores'; import { accountStoreIpcHandler } from './account-store.js'; -import { IpcMainHandler } from './ipc-main-handler.js'; const exampleAccount = (address: string): KeyringJson => ({ address, diff --git a/packages/apps-electron/src/main/account-store.ts b/packages/apps-electron/src/main/account-store.ts index 76f22af10743..5d62b22cd976 100644 --- a/packages/apps-electron/src/main/account-store.ts +++ b/packages/apps-electron/src/main/account-store.ts @@ -4,6 +4,7 @@ // eslint-disable-next-line @typescript-eslint/ban-ts-comment // @ts-ignore Warned on by nodenext resolution (while package does build in bundler mode) import type { KeyringJson } from '@polkadot/ui-keyring/types'; +import type { IpcMainHandler } from './ipc-main-handler.js'; import electron from 'electron'; import path from 'path'; @@ -12,7 +13,6 @@ import path from 'path'; // @ts-ignore Warned on by nodenext resolution (while package does build in bundler mode) import { FileStore } from '@polkadot/ui-keyring/stores'; -import { IpcMainHandler } from './ipc-main-handler.js'; import { registerIpcHandler } from './register-ipc-handler.js'; const ACCOUNTS_SUBFOLDER = 'polkadot-accounts'; diff --git a/packages/apps-electron/src/main/ipc-main-handler.ts b/packages/apps-electron/src/main/ipc-main-handler.ts index 38193ab4e4ef..2b875715b0c8 100644 --- a/packages/apps-electron/src/main/ipc-main-handler.ts +++ b/packages/apps-electron/src/main/ipc-main-handler.ts @@ -1,6 +1,4 @@ // Copyright 2017-2023 @polkadot/apps authors & contributors // SPDX-License-Identifier: Apache-2.0 -export type IpcMainHandler = { - [channel: string]: (...args: any[]) => unknown -} +export type IpcMainHandler = Record unknown>; diff --git a/packages/apps-electron/src/main/register-ipc-handler.ts b/packages/apps-electron/src/main/register-ipc-handler.ts index 5f0bcb50777b..46baa105f64f 100644 --- a/packages/apps-electron/src/main/register-ipc-handler.ts +++ b/packages/apps-electron/src/main/register-ipc-handler.ts @@ -1,9 +1,9 @@ // Copyright 2017-2023 @polkadot/apps authors & contributors // SPDX-License-Identifier: Apache-2.0 -import electron from 'electron'; +import type { IpcMainHandler } from './ipc-main-handler.js'; -import { IpcMainHandler } from './ipc-main-handler.js'; +import electron from 'electron'; export const registerIpcHandler = (ipcHandler: IpcMainHandler): void => { for (const [channel, listener] of Object.entries(ipcHandler)) { diff --git a/packages/apps-electron/src/renderer/remote-electron-store.spec.ts b/packages/apps-electron/src/renderer/remote-electron-store.spec.ts index 11feb752d6d8..0237f423b6fb 100644 --- a/packages/apps-electron/src/renderer/remote-electron-store.spec.ts +++ b/packages/apps-electron/src/renderer/remote-electron-store.spec.ts @@ -39,8 +39,8 @@ describe('Remote Electron Store', () => { remoteStore.all(cb); await Promise.resolve(); - expect(cb).nthCalledWith(1, 1, 'a'); - expect(cb).nthCalledWith(2, 2, 'b'); + expect(cb).toHaveBeenNthCalledWith(1, 1, 'a'); + expect(cb).toHaveBeenNthCalledWith(2, 2, 'b'); }); }); @@ -52,8 +52,8 @@ describe('Remote Electron Store', () => { remoteStore.get('1', cb); await Promise.resolve(); - expect(accountStore.get).toBeCalledWith('1'); - expect(cb).toBeCalledWith('a'); + expect(accountStore.get).toHaveBeenCalledWith('1'); + expect(cb).toHaveBeenCalledWith('a'); }); it('calls callback with null if no accounts found', async () => { @@ -63,7 +63,7 @@ describe('Remote Electron Store', () => { remoteStore.get('1', cb); await Promise.resolve(); - expect(cb).toBeCalledWith(null); + expect(cb).toHaveBeenCalledWith(null); }); }); @@ -75,8 +75,8 @@ describe('Remote Electron Store', () => { remoteStore.remove('1', cb); await Promise.resolve(); - expect(accountStore.remove).toBeCalledWith('1'); - expect(cb).toBeCalledTimes(1); + expect(accountStore.remove).toHaveBeenCalledWith('1'); + expect(cb).toHaveBeenCalledTimes(1); }); }); @@ -88,8 +88,8 @@ describe('Remote Electron Store', () => { remoteStore.set('1', 'a' as unknown as KeyringJson, cb); await Promise.resolve(); - expect(accountStore.set).toBeCalledWith('1', 'a'); - expect(cb).toBeCalledTimes(1); + expect(accountStore.set).toHaveBeenCalledWith('1', 'a'); + expect(cb).toHaveBeenCalledTimes(1); }); }); }); diff --git a/packages/apps-electron/tsconfig.build.json b/packages/apps-electron/tsconfig.build.json index fc725e563d1c..f2a41e938a0d 100644 --- a/packages/apps-electron/tsconfig.build.json +++ b/packages/apps-electron/tsconfig.build.json @@ -7,5 +7,11 @@ /* Since this is a forced-by-electron-CJS-module, we have to switch this off */ "verbatimModuleSyntax": false }, - "references": [] + "exclude": [ + "webpack.*.cjs" + ], + "references": [ + { "path": "../apps/tsconfig.build.json" }, + { "path": "../react-components/tsconfig.build.json" } + ] } diff --git a/packages/apps-routing/package.json b/packages/apps-routing/package.json index d28dbcbe4647..da550b674a7d 100644 --- a/packages/apps-routing/package.json +++ b/packages/apps-routing/package.json @@ -1,18 +1,23 @@ { - "bugs": "https://github.com/polkadot-js/apps/issues", + "bugs": "https://github.com/Cardinal-Cryptography/azero-dev/issues", "engines": { - "node": ">=14" + "node": ">=16" }, - "homepage": "https://github.com/polkadot-js/apps/tree/master/packages/apps-routing#readme", + "homepage": "https://github.com/Cardinal-Cryptography/azero-dev/tree/master/packages/apps-routing#readme", "license": "Apache-2.0", "name": "@polkadot/apps-routing", "private": true, "repository": { "directory": "packages/apps-routing", "type": "git", - "url": "https://github.com/polkadot-js/apps.git" + "url": "https://github.com/Cardinal-Cryptography/azero-dev.git" }, "sideEffects": false, "type": "module", - "version": "0.127.2-2-x" + "version": "0.132.2-98-x", + "peerDependencies": { + "react": "*", + "react-dom": "*", + "react-is": "*" + } } diff --git a/packages/apps-routing/src/accounts.ts b/packages/apps-routing/src/accounts.ts index 3ac7d3d67ba3..c02b6c718811 100644 --- a/packages/apps-routing/src/accounts.ts +++ b/packages/apps-routing/src/accounts.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component, { useCounter } from '@polkadot/app-accounts'; @@ -15,7 +14,7 @@ export default function create (t: TFunction): Route { group: 'accounts', icon: 'users', name: 'accounts', - text: t('nav.accounts', 'Accounts', { ns: 'apps-routing' }), + text: t('nav.accounts', 'Accounts', { ns: 'apps-routing' }), useCounter }; } diff --git a/packages/apps-routing/src/addresses.ts b/packages/apps-routing/src/addresses.ts index a8c2f6531736..6fd18e719942 100644 --- a/packages/apps-routing/src/addresses.ts +++ b/packages/apps-routing/src/addresses.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-addresses'; @@ -15,6 +14,6 @@ export default function create (t: TFunction): Route { group: 'accounts', icon: 'address-card', name: 'addresses', - text: t('nav.addresses', 'Address book', { ns: 'apps-routing' }) + text: t('nav.addresses', 'Address book', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/alliance.ts b/packages/apps-routing/src/alliance.ts index 03709394f98e..ddf042178726 100644 --- a/packages/apps-routing/src/alliance.ts +++ b/packages/apps-routing/src/alliance.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component, { useCounter } from '@polkadot/app-alliance'; @@ -17,7 +16,7 @@ export default function create (t: TFunction): Route { group: 'governance', icon: 'people-group', name: 'alliance', - text: t('nav.alliance', 'Alliance', { ns: 'apps-routing' }), + text: t('nav.alliance', 'Alliance', { ns: 'apps-routing' }), useCounter }; } diff --git a/packages/apps-routing/src/assets.ts b/packages/apps-routing/src/assets.ts index 345309db6147..bfc0aa2cfcb9 100644 --- a/packages/apps-routing/src/assets.ts +++ b/packages/apps-routing/src/assets.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-assets'; @@ -18,6 +17,6 @@ export default function create (t: TFunction): Route { group: 'network', icon: 'shopping-basket', name: 'assets', - text: t('nav.assets', 'Assets', { ns: 'apps-routing' }) + text: t('nav.assets', 'Assets', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/bounties.ts b/packages/apps-routing/src/bounties.ts index 0ccd6139d6e0..91b391db75bc 100644 --- a/packages/apps-routing/src/bounties.ts +++ b/packages/apps-routing/src/bounties.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component, { useCounter } from '@polkadot/app-bounties'; @@ -17,7 +16,7 @@ export default function create (t: TFunction): Route { group: 'governance', icon: 'coins', name: 'bounties', - text: t('nav.bounties', 'Bounties', { ns: 'apps-routing' }), + text: t('nav.bounties', 'Bounties', { ns: 'apps-routing' }), useCounter }; } diff --git a/packages/apps-routing/src/calendar.ts b/packages/apps-routing/src/calendar.ts index 5824c9143d5d..245c6ce276a4 100644 --- a/packages/apps-routing/src/calendar.ts +++ b/packages/apps-routing/src/calendar.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-calendar'; @@ -15,6 +14,6 @@ export default function create (t: TFunction): Route { group: 'network', icon: 'calendar-alt', name: 'calendar', - text: t('nav.calendar', 'Event calendar', { ns: 'apps-routing' }) + text: t('nav.calendar', 'Event calendar', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/claims.ts b/packages/apps-routing/src/claims.ts index 2db963351557..51166cce66eb 100644 --- a/packages/apps-routing/src/claims.ts +++ b/packages/apps-routing/src/claims.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component, { useCounter } from '@polkadot/app-claims'; @@ -18,7 +17,7 @@ export default function create (t: TFunction): Route { group: 'accounts', icon: 'star', name: 'claims', - text: t('nav.claims', 'Claim Tokens', { ns: 'apps-routing' }), + text: t('nav.claims', 'Claim Tokens', { ns: 'apps-routing' }), useCounter }; } diff --git a/packages/apps-routing/src/collator.ts b/packages/apps-routing/src/collator.ts index 1942172c67bc..e9c3bf2da492 100644 --- a/packages/apps-routing/src/collator.ts +++ b/packages/apps-routing/src/collator.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-collator'; @@ -17,6 +16,6 @@ export default function create (t: TFunction): Route { group: 'network', icon: 'timeline', name: 'collators', - text: t('nav.collator', 'Collators', { ns: 'apps-routing' }) + text: t('nav.collator', 'Collators', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/contracts.ts b/packages/apps-routing/src/contracts.ts index f84b2c0839aa..04670a902894 100644 --- a/packages/apps-routing/src/contracts.ts +++ b/packages/apps-routing/src/contracts.ts @@ -1,9 +1,8 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; import type { ApiPromise } from '@polkadot/api'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-contracts'; import { settings } from '@polkadot/ui-settings'; @@ -41,6 +40,6 @@ export default function create (t: TFunction): Route { href, icon: 'compress', name: 'contracts', - text: t('nav.contracts', 'Contracts', { ns: 'apps-routing' }) + text: t('nav.contracts', 'Contracts', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/council.ts b/packages/apps-routing/src/council.ts index ba082bf2e670..fb19f5f74ee4 100644 --- a/packages/apps-routing/src/council.ts +++ b/packages/apps-routing/src/council.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component, { useCounter } from '@polkadot/app-council'; @@ -18,7 +17,7 @@ export default function create (t: TFunction): Route { group: 'governance', icon: 'building', name: 'council', - text: t('nav.council', 'Council', { ns: 'apps-routing' }), + text: t('nav.council', 'Council', { ns: 'apps-routing' }), useCounter }; } diff --git a/packages/apps-routing/src/democracy.ts b/packages/apps-routing/src/democracy.ts index b63d82e5a1a6..faffa9b275f4 100644 --- a/packages/apps-routing/src/democracy.ts +++ b/packages/apps-routing/src/democracy.ts @@ -1,9 +1,8 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; import type { ApiPromise } from '@polkadot/api'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component, { useCounter } from '@polkadot/app-democracy'; @@ -32,7 +31,7 @@ export default function create (t: TFunction): Route { group: 'governance', icon: 'calendar-check', name: 'democracy', - text: t('nav.democracy', 'Democracy', { ns: 'apps-routing' }), + text: t('nav.democracy', 'Democracy', { ns: 'apps-routing' }), useCounter }; } diff --git a/packages/apps-routing/src/explorer.ts b/packages/apps-routing/src/explorer.ts index 91f9cdd575bb..5103d361acc5 100644 --- a/packages/apps-routing/src/explorer.ts +++ b/packages/apps-routing/src/explorer.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-explorer'; @@ -15,6 +14,6 @@ export default function create (t: TFunction): Route { group: 'network', icon: 'braille', name: 'explorer', - text: t('nav.explorer', 'Explorer', { ns: 'apps-routing' }) + text: t('nav.explorer', 'Explorer', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/extrinsics.ts b/packages/apps-routing/src/extrinsics.ts index 7caa55767382..e15449c3ac82 100644 --- a/packages/apps-routing/src/extrinsics.ts +++ b/packages/apps-routing/src/extrinsics.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-extrinsics'; @@ -16,6 +15,6 @@ export default function create (t: TFunction): Route { group: 'developer', icon: 'envelope-open-text', name: 'extrinsics', - text: t('nav.extrinsics', 'Extrinsics', { ns: 'apps-routing' }) + text: t('nav.extrinsics', 'Extrinsics', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/fellowship.ts b/packages/apps-routing/src/fellowship.ts index f21a6be02645..970189a04f1b 100644 --- a/packages/apps-routing/src/fellowship.ts +++ b/packages/apps-routing/src/fellowship.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component, { useCounter } from '@polkadot/app-fellowship'; @@ -20,7 +19,7 @@ export default function create (t: TFunction): Route { group: 'governance', icon: 'people-arrows', name: 'fellowship', - text: t('nav.fellowship', 'Fellowship', { ns: 'apps-routing' }), + text: t('nav.fellowship', 'Fellowship', { ns: 'apps-routing' }), useCounter }; } diff --git a/packages/apps-routing/src/files.ts b/packages/apps-routing/src/files.ts index daa5eca1c51f..89d13ed2e313 100644 --- a/packages/apps-routing/src/files.ts +++ b/packages/apps-routing/src/files.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-files'; @@ -16,6 +15,6 @@ export default function create (t: TFunction): Route { group: 'developer', icon: 'file', name: 'files', - text: t('nav.files', 'Files (IPFS)', { ns: 'apps-routing' }) + text: t('nav.files', 'Files (IPFS)', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/gilt.ts b/packages/apps-routing/src/gilt.ts index f2e427ffcf4b..9cb591837ecc 100644 --- a/packages/apps-routing/src/gilt.ts +++ b/packages/apps-routing/src/gilt.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-gilt'; @@ -18,6 +17,6 @@ export default function create (t: TFunction): Route { group: 'network', icon: 'leaf', name: 'gilt', - text: t('nav.gilt', 'Gilt', { ns: 'apps-routing' }) + text: t('nav.gilt', 'Gilt', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/index.ts b/packages/apps-routing/src/index.ts index fc02c5421977..c82f30b7978c 100644 --- a/packages/apps-routing/src/index.ts +++ b/packages/apps-routing/src/index.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Routes } from './types.js'; +import type { Routes, TFunction } from './types.js'; import accounts from './accounts.js'; import addresses from './addresses.js'; @@ -23,6 +22,7 @@ import gilt from './gilt.js'; import js from './js.js'; import membership from './membership.js'; import nfts from './nfts.js'; +import nis from './nis.js'; import parachains from './parachains.js'; import poll from './poll.js'; import preimages from './preimages.js'; @@ -35,6 +35,7 @@ import settings from './settings.js'; import signing from './signing.js'; import society from './society.js'; import staking from './staking.js'; +import staking2 from './staking2.js'; import storage from './storage.js'; import sudo from './sudo.js'; import techcomm from './techcomm.js'; @@ -54,6 +55,7 @@ export default function create (t: TFunction): Routes { transfer(t), teleport(t), staking(t), + staking2(t), collator(t), // governance v2 referenda(t), @@ -72,10 +74,11 @@ export default function create (t: TFunction): Routes { bounties(t), // others parachains(t), - gilt(t), assets(t), nfts(t), society(t), + nis(t), + gilt(t), scheduler(t), calendar(t), contracts(t), diff --git a/packages/apps-routing/src/js.ts b/packages/apps-routing/src/js.ts index f382464fe4a7..fca4d0ea9290 100644 --- a/packages/apps-routing/src/js.ts +++ b/packages/apps-routing/src/js.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-js'; @@ -15,6 +14,6 @@ export default function create (t: TFunction): Route { group: 'developer', icon: 'code', name: 'js', - text: t('nav.js', 'JavaScript', { ns: 'apps-routing' }) + text: t('nav.js', 'JavaScript', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/membership.ts b/packages/apps-routing/src/membership.ts index 8dd645f81582..2584f1f77e1e 100644 --- a/packages/apps-routing/src/membership.ts +++ b/packages/apps-routing/src/membership.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component, { useCounter } from '@polkadot/app-membership'; @@ -18,7 +17,7 @@ export default function create (t: TFunction): Route { group: 'governance', icon: 'people-carry', name: 'membership', - text: t('nav.membership', 'Membership', { ns: 'apps-routing' }), + text: t('nav.membership', 'Membership', { ns: 'apps-routing' }), useCounter }; } diff --git a/packages/apps-routing/src/nfts.ts b/packages/apps-routing/src/nfts.ts index fe84b45665e4..68793e0895a4 100644 --- a/packages/apps-routing/src/nfts.ts +++ b/packages/apps-routing/src/nfts.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-nfts'; @@ -17,6 +16,6 @@ export default function create (t: TFunction): Route { group: 'network', icon: 'shopping-cart', name: 'nfts', - text: t('nav.nfts', 'NFTs', { ns: 'apps-routing' }) + text: t('nav.nfts', 'NFTs', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/nis.ts b/packages/apps-routing/src/nis.ts new file mode 100644 index 000000000000..73a69d66e1a6 --- /dev/null +++ b/packages/apps-routing/src/nis.ts @@ -0,0 +1,22 @@ +// Copyright 2017-2023 @polkadot/apps-routing authors & contributors +// SPDX-License-Identifier: Apache-2.0 + +import type { Route, TFunction } from './types.js'; + +import Component from '@polkadot/app-nis'; + +export default function create (t: TFunction): Route { + return { + Component, + display: { + needsApi: [ + 'tx.nis.placeBid', + 'query.proxy.proxies' + ] + }, + group: 'network', + icon: 'leaf', + name: 'nis', + text: t('nav.nis', 'Non-interactive Staking', { ns: 'apps-routing' }) + }; +} diff --git a/packages/apps-routing/src/parachains.ts b/packages/apps-routing/src/parachains.ts index f242ba55907d..76ec017566f5 100644 --- a/packages/apps-routing/src/parachains.ts +++ b/packages/apps-routing/src/parachains.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-parachains'; @@ -18,6 +17,6 @@ export default function create (t: TFunction): Route { group: 'network', icon: 'link', name: 'parachains', - text: t('nav.parachains', 'Parachains', { ns: 'apps-routing' }) + text: t('nav.parachains', 'Parachains', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/poll.ts b/packages/apps-routing/src/poll.ts index 177ceadc6f4b..769927e1e1ad 100644 --- a/packages/apps-routing/src/poll.ts +++ b/packages/apps-routing/src/poll.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-poll'; @@ -18,6 +17,6 @@ export default function create (t: TFunction): Route { group: 'governance', icon: 'podcast', name: 'poll', - text: t('nav.poll', 'Token poll', { ns: 'apps-routing' }) + text: t('nav.poll', 'Token poll', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/preimages.ts b/packages/apps-routing/src/preimages.ts index 7eeaf327b58b..ba2ae04374e1 100644 --- a/packages/apps-routing/src/preimages.ts +++ b/packages/apps-routing/src/preimages.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-preimages'; @@ -19,6 +18,6 @@ export default function create (t: TFunction): Route { group: 'governance', icon: 'panorama', name: 'preimages', - text: t('nav.preimages', 'Preimages', { ns: 'apps-routing' }) + text: t('nav.preimages', 'Preimages', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/ranked.ts b/packages/apps-routing/src/ranked.ts index ecc51fddee38..4719c9ad0f39 100644 --- a/packages/apps-routing/src/ranked.ts +++ b/packages/apps-routing/src/ranked.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component, { useCounter } from '@polkadot/app-ranked'; @@ -19,7 +18,7 @@ export default function create (t: TFunction): Route { group: 'governance', icon: 'people-arrows', name: 'ranked', - text: t('nav.ranked', 'Ranked collective', { ns: 'apps-routing' }), + text: t('nav.ranked', 'Ranked collective', { ns: 'apps-routing' }), useCounter }; } diff --git a/packages/apps-routing/src/referenda.ts b/packages/apps-routing/src/referenda.ts index 8d42e944a30e..27941dd7334b 100644 --- a/packages/apps-routing/src/referenda.ts +++ b/packages/apps-routing/src/referenda.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component, { useCounter } from '@polkadot/app-referenda'; @@ -19,7 +18,7 @@ export default function create (t: TFunction): Route { group: 'governance', icon: 'person-booth', name: 'referenda', - text: t('nav.referenda', 'Referenda', { ns: 'apps-routing' }), + text: t('nav.referenda', 'Referenda', { ns: 'apps-routing' }), useCounter }; } diff --git a/packages/apps-routing/src/rpc.ts b/packages/apps-routing/src/rpc.ts index d4f26faddadd..259b1b1586e0 100644 --- a/packages/apps-routing/src/rpc.ts +++ b/packages/apps-routing/src/rpc.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-rpc'; @@ -15,6 +14,6 @@ export default function create (t: TFunction): Route { group: 'developer', icon: 'network-wired', name: 'rpc', - text: t('nav.rpc', 'RPC calls', { ns: 'apps-routing' }) + text: t('nav.rpc', 'RPC calls', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/runtime.ts b/packages/apps-routing/src/runtime.ts index 4dfcd91f14b6..da4538a248ae 100644 --- a/packages/apps-routing/src/runtime.ts +++ b/packages/apps-routing/src/runtime.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-runtime'; @@ -15,6 +14,6 @@ export default function create (t: TFunction): Route { group: 'developer', icon: 'arrows-to-circle', name: 'runtime', - text: t('nav.runtime', 'Runtime calls', { ns: 'apps-routing' }) + text: t('nav.runtime', 'Runtime calls', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/scheduler.ts b/packages/apps-routing/src/scheduler.ts index 9ec45007c387..3319903ba0a8 100644 --- a/packages/apps-routing/src/scheduler.ts +++ b/packages/apps-routing/src/scheduler.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-scheduler'; @@ -17,6 +16,6 @@ export default function create (t: TFunction): Route { group: 'network', icon: 'clock', name: 'scheduler', - text: t('nav.scheduler', 'Scheduler', { ns: 'apps-routing' }) + text: t('nav.scheduler', 'Scheduler', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/settings.ts b/packages/apps-routing/src/settings.ts index 50e461c01d1e..7be5e0c133ef 100644 --- a/packages/apps-routing/src/settings.ts +++ b/packages/apps-routing/src/settings.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component, { useCounter } from '@polkadot/app-settings'; @@ -13,7 +12,7 @@ export default function create (t: TFunction): Route { group: 'settings', icon: 'cogs', name: 'settings', - text: t('nav.settings', 'Settings', { ns: 'apps-routing' }), + text: t('nav.settings', 'Settings', { ns: 'apps-routing' }), useCounter }; } diff --git a/packages/apps-routing/src/signing.ts b/packages/apps-routing/src/signing.ts index 536a731ece43..4e55c54f0dcd 100644 --- a/packages/apps-routing/src/signing.ts +++ b/packages/apps-routing/src/signing.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-signing'; @@ -16,6 +15,6 @@ export default function create (t: TFunction): Route { group: 'developer', icon: 'signature', name: 'signing', - text: t('nav.signing', 'Sign and verify', { ns: 'apps-routing' }) + text: t('nav.signing', 'Sign and verify', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/society.ts b/packages/apps-routing/src/society.ts index 9bf4d192fa14..321d9e468b12 100644 --- a/packages/apps-routing/src/society.ts +++ b/packages/apps-routing/src/society.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component, { useCounter } from '@polkadot/app-society'; @@ -18,7 +17,7 @@ export default function create (t: TFunction): Route { group: 'network', icon: 'hand-spock', name: 'society', - text: t('nav.society', 'Society', { ns: 'apps-routing' }), + text: t('nav.society', 'Society', { ns: 'apps-routing' }), useCounter }; } diff --git a/packages/apps-routing/src/staking.ts b/packages/apps-routing/src/staking.ts index 2caffb35c13b..184a574c141f 100644 --- a/packages/apps-routing/src/staking.ts +++ b/packages/apps-routing/src/staking.ts @@ -1,10 +1,9 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; import type { ApiPromise } from '@polkadot/api'; import type { PalletStakingExposure } from '@polkadot/types/lookup'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-staking'; import { ZERO_ACCOUNT } from '@polkadot/react-hooks/useWeight'; @@ -28,7 +27,17 @@ function needsApiCheck (api: ApiPromise): boolean { try { // we need to be able to bond - api.tx.staking.bond(ZERO_ACCOUNT, BN_ONE, { Account: ZERO_ACCOUNT }); + if (api.tx.staking.bond.meta.args.length === 3) { + // previous generation, controller account is required + // @ts-expect-error Previous generation + api.tx.staking.bond(ZERO_ACCOUNT, BN_ONE, { Account: ZERO_ACCOUNT }); + } else if (api.tx.staking.bond.meta.args.length === 2) { + // current, no controller account + api.tx.staking.bond(BN_ONE, { Account: ZERO_ACCOUNT }); + } else { + // unknown + return false; + } } catch { console.warn('Unable to create staking bond transaction, disabling staking route'); @@ -51,6 +60,6 @@ export default function create (t: TFunction): Route { group: 'network', icon: 'certificate', name: 'staking', - text: t('nav.staking', 'Staking', { ns: 'apps-routing' }) + text: t('nav.staking', 'Staking', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/staking2.ts b/packages/apps-routing/src/staking2.ts index c1f968f3286f..a18456610ef0 100644 --- a/packages/apps-routing/src/staking2.ts +++ b/packages/apps-routing/src/staking2.ts @@ -1,10 +1,9 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; import type { ApiPromise } from '@polkadot/api'; import type { PalletStakingExposure } from '@polkadot/types/lookup'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-staking2'; import { ZERO_ACCOUNT } from '@polkadot/react-hooks/useWeight'; @@ -28,7 +27,17 @@ function needsApiCheck (api: ApiPromise): boolean { try { // we need to be able to bond - api.tx.staking.bond(ZERO_ACCOUNT, BN_ONE, { Account: ZERO_ACCOUNT }); + if (api.tx.staking.bond.meta.args.length === 3) { + // previous generation, controller account is required + // @ts-expect-error Previous generation + api.tx.staking.bond(ZERO_ACCOUNT, BN_ONE, { Account: ZERO_ACCOUNT }); + } else if (api.tx.staking.bond.meta.args.length === 2) { + // current, no controller account + api.tx.staking.bond(BN_ONE, { Account: ZERO_ACCOUNT }); + } else { + // unknown + return false; + } } catch { console.warn('Unable to create staking bond transaction, disabling staking route'); @@ -53,6 +62,6 @@ export default function create (t: TFunction): Route { group: 'network', icon: 'certificate', name: 'test-staking', - text: t('nav.staking', 'Staking', { ns: 'apps-routing' }) + text: t('nav.staking', 'Staking', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/storage.ts b/packages/apps-routing/src/storage.ts index da62ef9ff583..b67e9f807be7 100644 --- a/packages/apps-routing/src/storage.ts +++ b/packages/apps-routing/src/storage.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-storage'; @@ -15,6 +14,6 @@ export default function create (t: TFunction): Route { group: 'developer', icon: 'database', name: 'chainstate', - text: t('nav.storage', 'Chain state', { ns: 'apps-routing' }) + text: t('nav.storage', 'Chain state', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/sudo.ts b/packages/apps-routing/src/sudo.ts index 60acdbb595ef..7937b1146134 100644 --- a/packages/apps-routing/src/sudo.ts +++ b/packages/apps-routing/src/sudo.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-sudo'; @@ -19,6 +18,6 @@ export default function create (t: TFunction): Route { group: 'developer', icon: 'unlock', name: 'sudo', - text: t('nav.sudo', 'Sudo', { ns: 'apps-routing' }) + text: t('nav.sudo', 'Sudo', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/techcomm.ts b/packages/apps-routing/src/techcomm.ts index 2c1b4b2886bb..11f07a4c27a6 100644 --- a/packages/apps-routing/src/techcomm.ts +++ b/packages/apps-routing/src/techcomm.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component, { useCounter } from '@polkadot/app-tech-comm'; @@ -19,7 +18,7 @@ export default function create (t: TFunction): Route { group: 'governance', icon: 'microchip', name: 'techcomm', - text: t('nav.tech-comm', 'Tech. comm.', { ns: 'apps-routing' }), + text: t('nav.tech-comm', 'Tech. comm.', { ns: 'apps-routing' }), useCounter }; } diff --git a/packages/apps-routing/src/teleport.ts b/packages/apps-routing/src/teleport.ts index 70d7ecabfd0a..0b1062515efc 100644 --- a/packages/apps-routing/src/teleport.ts +++ b/packages/apps-routing/src/teleport.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Modal from '@polkadot/app-parachains/Teleport'; @@ -11,9 +10,7 @@ export default function create (t: TFunction): Route { Component: Modal, Modal, display: { - // TODO We need to move to XCM v3 at some point, until such time we disable - // this functionality (we really should have kept it until later versions) - isHidden: true, + isHidden: false, needsAccounts: true, needsApi: [ [ @@ -30,6 +27,6 @@ export default function create (t: TFunction): Route { group: 'accounts', icon: 'share-square', name: 'teleport', - text: t('nav.teleport', 'Teleport', { ns: 'apps-routing' }) + text: t('nav.teleport', 'Teleport', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/transfer.ts b/packages/apps-routing/src/transfer.ts index d905c8c18a72..94c02bbcc36e 100644 --- a/packages/apps-routing/src/transfer.ts +++ b/packages/apps-routing/src/transfer.ts @@ -1,10 +1,9 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; -import Modal from '@polkadot/app-accounts/modals/Transfer'; +import { TransferModal as Modal } from '@polkadot/react-components'; export default function create (t: TFunction): Route { return { @@ -20,6 +19,6 @@ export default function create (t: TFunction): Route { group: 'accounts', icon: 'paper-plane', name: 'transfer', - text: t('nav.transfer', 'Transfer', { ns: 'apps-routing' }) + text: t('nav.transfer', 'Transfer', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/treasury.ts b/packages/apps-routing/src/treasury.ts index 7eb14540c105..dba823d9a57e 100644 --- a/packages/apps-routing/src/treasury.ts +++ b/packages/apps-routing/src/treasury.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component, { useCounter } from '@polkadot/app-treasury'; @@ -17,7 +16,7 @@ export default function create (t: TFunction): Route { group: 'governance', icon: 'gem', name: 'treasury', - text: t('nav.treasury', 'Treasury', { ns: 'apps-routing' }), + text: t('nav.treasury', 'Treasury', { ns: 'apps-routing' }), useCounter }; } diff --git a/packages/apps-routing/src/types.ts b/packages/apps-routing/src/types.ts index 37184f7726c1..15af65345662 100644 --- a/packages/apps-routing/src/types.ts +++ b/packages/apps-routing/src/types.ts @@ -2,6 +2,7 @@ // SPDX-License-Identifier: Apache-2.0 import type { IconName } from '@fortawesome/fontawesome-svg-core'; +import type React from 'react'; import type { ApiPromise } from '@polkadot/api'; import type { AppProps, BareProps } from '@polkadot/react-components/types'; @@ -36,3 +37,5 @@ export interface Route { } export type Routes = Route[]; + +export type TFunction = (key: string, textOrOptions?: string | { replace: Record }, options?: { ns: string }) => string; diff --git a/packages/apps-routing/src/utilities.ts b/packages/apps-routing/src/utilities.ts index 6277112e9498..151cdcfb2491 100644 --- a/packages/apps-routing/src/utilities.ts +++ b/packages/apps-routing/src/utilities.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-utilities'; @@ -15,6 +14,6 @@ export default function create (t: TFunction): Route { group: 'developer', icon: 'wrench', name: 'utilities', - text: t('nav.utilities', 'Utilities', { ns: 'apps-routing' }) + text: t('nav.utilities', 'Utilities', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/src/whitelist.ts b/packages/apps-routing/src/whitelist.ts index aa961793847b..1f3b1446a078 100644 --- a/packages/apps-routing/src/whitelist.ts +++ b/packages/apps-routing/src/whitelist.ts @@ -1,8 +1,7 @@ // Copyright 2017-2023 @polkadot/apps-routing authors & contributors // SPDX-License-Identifier: Apache-2.0 -import type { TFunction } from 'i18next'; -import type { Route } from './types.js'; +import type { Route, TFunction } from './types.js'; import Component from '@polkadot/app-whitelist'; @@ -18,6 +17,6 @@ export default function create (t: TFunction): Route { group: 'governance', icon: 'list-check', name: 'whitelist', - text: t('nav.whitelist', 'Whitelist', { ns: 'apps-routing' }) + text: t('nav.whitelist', 'Whitelist', { ns: 'apps-routing' }) }; } diff --git a/packages/apps-routing/tsconfig.build.json b/packages/apps-routing/tsconfig.build.json index da24d9f22599..a7b627bd03d9 100644 --- a/packages/apps-routing/tsconfig.build.json +++ b/packages/apps-routing/tsconfig.build.json @@ -5,5 +5,47 @@ "outDir": "./build", "rootDir": "./src" }, - "references": [] + "references": [ + { "path": "../page-accounts/tsconfig.build.json" }, + { "path": "../page-addresses/tsconfig.build.json" }, + { "path": "../page-alliance/tsconfig.build.json" }, + { "path": "../page-assets/tsconfig.build.json" }, + { "path": "../page-bounties/tsconfig.build.json" }, + { "path": "../page-calendar/tsconfig.build.json" }, + { "path": "../page-claims/tsconfig.build.json" }, + { "path": "../page-collator/tsconfig.build.json" }, + { "path": "../page-council/tsconfig.build.json" }, + { "path": "../page-democracy/tsconfig.build.json" }, + { "path": "../page-explorer/tsconfig.build.json" }, + { "path": "../page-extrinsics/tsconfig.build.json" }, + { "path": "../page-fellowship/tsconfig.build.json" }, + { "path": "../page-files/tsconfig.build.json" }, + { "path": "../page-gilt/tsconfig.build.json" }, + { "path": "../page-js/tsconfig.build.json" }, + { "path": "../page-membership/tsconfig.build.json" }, + { "path": "../page-nfts/tsconfig.build.json" }, + { "path": "../page-nis/tsconfig.build.json" }, + { "path": "../page-parachains/tsconfig.build.json" }, + { "path": "../page-poll/tsconfig.build.json" }, + { "path": "../page-preimages/tsconfig.build.json" }, + { "path": "../page-ranked/tsconfig.build.json" }, + { "path": "../page-referenda/tsconfig.build.json" }, + { "path": "../page-rpc/tsconfig.build.json" }, + { "path": "../page-runtime/tsconfig.build.json" }, + { "path": "../page-scheduler/tsconfig.build.json" }, + { "path": "../page-settings/tsconfig.build.json" }, + { "path": "../page-signing/tsconfig.build.json" }, + { "path": "../page-society/tsconfig.build.json" }, + { "path": "../page-staking/tsconfig.build.json" }, + { "path": "../page-staking2/tsconfig.build.json" }, + { "path": "../page-storage/tsconfig.build.json" }, + { "path": "../page-sudo/tsconfig.build.json" }, + { "path": "../page-tech-comm/tsconfig.build.json" }, + { "path": "../page-treasury/tsconfig.build.json" }, + { "path": "../page-utilities/tsconfig.build.json" }, + { "path": "../page-whitelist/tsconfig.build.json" }, + { "path": "../react-components/tsconfig.build.json" }, + { "path": "../react-hooks/tsconfig.build.json" }, + { "path": "../page-contracts/tsconfig.build.json" } + ] } diff --git a/packages/apps/package.json b/packages/apps/package.json index b2225760b44a..d8e1574e5def 100644 --- a/packages/apps/package.json +++ b/packages/apps/package.json @@ -1,32 +1,35 @@ { - "bugs": "https://github.com/polkadot-js/apps/issues", + "bugs": "https://github.com/Cardinal-Cryptography/azero-dev/issues", "engines": { - "node": ">=14" + "node": ">=16" }, - "homepage": "https://github.com/polkadot-js/apps/tree/master/packages/apps#readme", + "homepage": "https://github.com/Cardinal-Cryptography/azero-dev/tree/master/packages/apps#readme", "license": "Apache-2.0", "name": "@polkadot/apps", "private": true, "repository": { "directory": "packages/apps", "type": "git", - "url": "https://github.com/polkadot-js/apps.git" + "url": "https://github.com/Cardinal-Cryptography/azero-dev.git" }, "sideEffects": true, "type": "module", - "version": "0.127.2-2-x", + "version": "0.132.2-98-x", "dependencies": { - "@polkadot/apps-config": "^0.127.2-2-x", - "@polkadot/apps-routing": "^0.127.2-2-x", - "@polkadot/dev": "^0.72.43", - "@polkadot/react-api": "^0.127.2-2-x", - "@polkadot/react-components": "^0.127.2-2-x", - "@polkadot/react-hooks": "^0.127.2-2-x", - "@polkadot/react-params": "^0.127.2-2-x", - "@polkadot/react-query": "^0.127.2-2-x", - "@polkadot/react-signer": "^0.127.2-2-x", + "@polkadot/apps-config": "^0.132.2-98-x", + "@polkadot/apps-routing": "^0.132.2-98-x", + "@polkadot/dev": "^0.76.18", + "@polkadot/react-api": "^0.132.2-98-x", + "@polkadot/react-components": "^0.132.2-98-x", + "@polkadot/react-hooks": "^0.132.2-98-x", + "@polkadot/react-params": "^0.132.2-98-x", + "@polkadot/react-query": "^0.132.2-98-x", + "@polkadot/react-signer": "^0.132.2-98-x", "punycode": "^2.3.0", - "query-string": "^8.1.0" + "query-string": "^8.1.0", + "react": "^18.2.0", + "react-dom": "^18.2.0", + "react-is": "^18.2.0" }, "devDependencies": { "@types/punycode": "^2.1.0", @@ -34,16 +37,20 @@ "buffer": "^6.0.3", "copy-webpack-plugin": "^11.0.0", "crypto-browserify": "^3.12.0", - "css-loader": "^6.7.3", + "css-loader": "^6.8.1", "empty": "^0.10.1", - "html-webpack-plugin": "^5.5.1", + "html-webpack-plugin": "^5.5.3", "https-browserify": "^1.0.0", - "mini-css-extract-plugin": "^2.7.5", + "mini-css-extract-plugin": "^2.7.6", "os-browserify": "^0.3.0", "path-browserify": "^1.0.1", "process": "^0.11.10", "stream-browserify": "^3.0.0", "stream-http": "^3.2.0", - "ts-loader": "^9.4.2" + "ts-loader": "^9.4.4" + }, + "peerDependencies": { + "typescript": "*", + "webpack": "*" } } diff --git a/packages/apps/public/index.html b/packages/apps/public/index.html index 7f7d760d9b7a..eaf4fccead2a 100644 --- a/packages/apps/public/index.html +++ b/packages/apps/public/index.html @@ -2,23 +2,9 @@ - - - - - - - - - - - - - - - - - + + + <%= htmlWebpackPlugin.options.PAGE_TITLE %>