1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00
🦊 Minimalized version of MetaMask for my own personal use.
Go to file
Whymarrh Whitby c4a3d4ea82 Remove unneeded array cloning in getSendToAccounts selector
The use of `Object.entries` here to map the accounts into a new array effectively
produces a shallow clone of the array without guaranteeing the order of the original
array (as object iteration order is implementation-specific and variable). From MDN [1]:

> The **`Object.entries()`** method returns an array of a given object's own enumerable
> string-keyed property `[key, value]` pairs, in the same order as that provided by a
> `for...in` loop

And also:

> The ordering of the properties is the same as that given by looping over the
> property values of the object manually.

Both of which suggest that the iteration order is the same as `for...in`, which is to
say that it's not specified. [2] [3]

This changeset removes the cloning, keeping the shallow clone created the line before
which preserves the order of the items in the array.

  [1]:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/entries
  [2]:https://stackoverflow.com/a/5525820/1267663
  [3]:https://stackoverflow.com/a/30919039/1267663
2019-04-11 21:50:06 -02:30
.circleci ci: Add build:test Gulp task for e2e build 2019-03-29 11:13:39 -02:30
.github Update UI codeowners 2019-01-30 10:32:04 -03:30
.storybook
app feature: switch token pricing to CoinGecko API (#6424) 2019-04-10 18:37:15 -04:00
development Remove broken image walkthrough from metamaskbot comment 2019-03-29 12:39:43 -02:30
docs Added Chrome limited site access solution doc (#6422) 2019-04-10 22:56:47 -02:30
test Remove NoticeController (#6382) 2019-04-01 22:33:54 -02:30
ui Remove unneeded array cloning in getSendToAccounts selector 2019-04-11 21:50:06 -02:30
.babelrc build - babel - move config to babelrc (#6284) 2019-03-12 13:25:28 -02:30
.dockerignore
.editorconfig
.eslintignore mascara - remove from project (#6283) 2019-03-12 11:17:21 -02:30
.eslintrc ESLint fixes (#5775) 2018-11-16 14:54:55 -10:00
.gitattributes
.gitignore Add html reporter to test coverage output 2018-09-11 09:39:16 -07:00
.nvmrc Update Node minor version 2019-03-13 09:56:36 -02:30
.stylelintignore mascara - remove from project (#6283) 2019-03-12 11:17:21 -02:30
.stylelintrc
CHANGELOG.md Version 6.3.2 (#6418) 2019-04-08 11:22:23 -07:00
CONTRIBUTING.md update contributing.md 2018-07-05 17:52:26 -04:00
fonts
gentests.js fix gentests.js 2018-07-02 19:36:26 -04:00
gulpfile.js ci: Add build:test Gulp task for e2e build 2019-03-29 11:13:39 -02:30
images
ISSUE_TEMPLATE
LICENSE
MISSION.md
package-lock.json pin eth-contract-metadata to last commit hash (#6396) 2019-04-04 15:49:10 -03:00
package.json pin eth-contract-metadata to last commit hash (#6396) 2019-04-04 15:49:10 -03:00
README.md Remove outdated ui dev and ui mock docs 2019-02-20 14:18:46 -03:30
USER_AGREEMENT.md fix tos link; 2018-07-12 16:24:13 -04:00

MetaMask Browser Extension

Build Status Coverage Status Stories in Ready

You can find the latest version of MetaMask on our official website. For help using MetaMask, visit our User Support Site.

For up to the minute news, follow our Twitter or Medium pages.

To learn how to develop MetaMask-compatible applications, visit our Developer Docs.

To learn how to contribute to the MetaMask project itself, visit our Internal Docs.

Building locally

  • Install Node.js version 8 and the latest available npm@6
    • If you are using nvm (recommended) running nvm use will automatically choose the right node version for you.
    • If you install Node.js manually, ensure you're using npm@6
      • Install npm@6 using npm install -g npm@6
  • Install dependencies: npm install
    • If you have issues with node-sass compilation, try npm rebuild node-sass
  • Install gulp globally with npm install -g gulp-cli.
  • Build the project to the ./dist/ folder with gulp build.
  • Optionally, to rebuild on file changes, run gulp dev.
  • To package .zip files for distribution, run gulp zip, or run the full build & zip with gulp dist.

Uncompressed builds can be found in /dist, compressed builds can be found in /builds once they're built.

Contributing

You can read our internal docs here.

You can re-generate the docs locally by running npm run doc, and contributors can update the hosted docs by running npm run publish-docs.

Running Tests

Requires mocha installed. Run npm install -g mocha.

Then just run npm test.

You can also test with a continuously watching process, via npm run watch.

You can run the linter by itself with gulp lint.

Architecture

Architecture Diagram

Development

npm install
npm start

Build for Publishing

npm run dist

Writing Browser Tests

To write tests that will be run in the browser using QUnit, add your test files to test/integration/lib.

Other Docs