@exodus/available-assets 4.1.0 → 5.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +20 -0
- package/index.js +2 -0
- package/package.json +8 -4
- package/plugins/index.js +32 -0
- package/redux/index.js +1 -1
- package/redux/selectors/all-with-parent-combined-network.js +14 -0
- package/redux/selectors/all-without-parent-combined-network.js +14 -0
- package/redux/selectors/get-combined-children-names.js +14 -0
- package/redux/selectors/get-combined-fallback.js +14 -0
- package/redux/selectors/get-has-assets-on-other-chains.js +14 -0
- package/redux/selectors/get.js +15 -0
- package/redux/selectors/index.js +12 -0
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,26 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
## [5.1.0](https://github.com/ExodusMovement/exodus-hydra/compare/@exodus/available-assets@5.0.0...@exodus/available-assets@5.1.0) (2023-08-25)
|
|
7
|
+
|
|
8
|
+
### Features
|
|
9
|
+
|
|
10
|
+
- add combined selectors to available-assets ([#3546](https://github.com/ExodusMovement/exodus-hydra/issues/3546)) ([0ed95c1](https://github.com/ExodusMovement/exodus-hydra/commit/0ed95c138add72efb920f1d4d8b4605c4a7aedc1))
|
|
11
|
+
|
|
12
|
+
## [5.0.0](https://github.com/ExodusMovement/exodus-hydra/compare/@exodus/available-assets@4.1.0...@exodus/available-assets@5.0.0) (2023-08-25)
|
|
13
|
+
|
|
14
|
+
### ⚠ BREAKING CHANGES
|
|
15
|
+
|
|
16
|
+
- remove store and actions from setup redux (#3575)
|
|
17
|
+
|
|
18
|
+
### Features
|
|
19
|
+
|
|
20
|
+
- add atom observer in available-assets plugin ([#3553](https://github.com/ExodusMovement/exodus-hydra/issues/3553)) ([26d769c](https://github.com/ExodusMovement/exodus-hydra/commit/26d769c0536d4c0f99b5ea4ca5a7f4123ba16d6f))
|
|
21
|
+
|
|
22
|
+
### Code Refactoring
|
|
23
|
+
|
|
24
|
+
- remove store and actions from setup redux ([#3575](https://github.com/ExodusMovement/exodus-hydra/issues/3575)) ([64fa4a6](https://github.com/ExodusMovement/exodus-hydra/commit/64fa4a6c2b69409a81ab140adbdf84646f1be73a))
|
|
25
|
+
|
|
6
26
|
## [4.1.0](https://github.com/ExodusMovement/exodus-hydra/compare/@exodus/available-assets@4.0.0...@exodus/available-assets@4.1.0) (2023-08-22)
|
|
7
27
|
|
|
8
28
|
### Features
|
package/index.js
CHANGED
|
@@ -4,6 +4,7 @@ import {
|
|
|
4
4
|
} from './atoms'
|
|
5
5
|
import availableAssetsModuleDefinition from './module'
|
|
6
6
|
import availableAssetsApiDefinition from './api'
|
|
7
|
+
import availableAssetsPluginDefinition from './plugins'
|
|
7
8
|
|
|
8
9
|
const availableAssets = () => ({
|
|
9
10
|
id: 'availableAssets',
|
|
@@ -15,6 +16,7 @@ const availableAssets = () => ({
|
|
|
15
16
|
{ definition: availableAssetNamesAtomDefinition },
|
|
16
17
|
{ definition: availableAssetNamesWithoutParentCombinedAtomDefinition },
|
|
17
18
|
{ definition: availableAssetsApiDefinition },
|
|
19
|
+
{ definition: availableAssetsPluginDefinition },
|
|
18
20
|
],
|
|
19
21
|
})
|
|
20
22
|
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@exodus/available-assets",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "5.1.0",
|
|
4
4
|
"description": "Tracks supported/available assets, i.e. assets that the user can potentially enable via the UI",
|
|
5
5
|
"license": "UNLICENSED",
|
|
6
6
|
"author": "Exodus Movement Inc.",
|
|
@@ -15,6 +15,7 @@
|
|
|
15
15
|
"atoms",
|
|
16
16
|
"api",
|
|
17
17
|
"redux",
|
|
18
|
+
"plugins",
|
|
18
19
|
"README.md",
|
|
19
20
|
"CHANGELOG.md",
|
|
20
21
|
"!**/__tests__/**"
|
|
@@ -30,20 +31,23 @@
|
|
|
30
31
|
"dependencies": {
|
|
31
32
|
"@exodus/atoms": "^5.5.0",
|
|
32
33
|
"@exodus/basic-utils": "^2.0.0",
|
|
34
|
+
"@exodus/core-selectors": "^1.5.0",
|
|
33
35
|
"@exodus/module": "^1.1.0",
|
|
34
36
|
"lodash": "^4.17.21",
|
|
35
37
|
"make-concurrent": "^5.3.0",
|
|
36
38
|
"reselect": "^4.1.8"
|
|
37
39
|
},
|
|
38
40
|
"devDependencies": {
|
|
41
|
+
"@exodus/assets": "^8.0.95",
|
|
39
42
|
"@exodus/assets-base": "^8.1.10",
|
|
40
|
-
"@exodus/assets-feature": "^1.
|
|
43
|
+
"@exodus/assets-feature": "^1.3.0",
|
|
44
|
+
"@exodus/combined-assets-meta": "^1.2.6-alpha-1",
|
|
41
45
|
"@exodus/enabled-assets": "^6.0.2",
|
|
42
|
-
"@exodus/redux-dependency-injection": "^
|
|
46
|
+
"@exodus/redux-dependency-injection": "^2.0.1",
|
|
43
47
|
"eslint": "^8.44.0",
|
|
44
48
|
"jest": "^29.1.2",
|
|
45
49
|
"jest-when": "^3.6.0",
|
|
46
50
|
"redux": "^4.2.1"
|
|
47
51
|
},
|
|
48
|
-
"gitHead": "
|
|
52
|
+
"gitHead": "bb8d559d9cc997cd5cb46cf351f1f89efa4f76e5"
|
|
49
53
|
}
|
package/plugins/index.js
ADDED
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { createAtomObserver } from '@exodus/atoms'
|
|
2
|
+
|
|
3
|
+
const createAvailableAssetsPlugin = ({ port, availableAssetNamesAtom }) => {
|
|
4
|
+
const availableAssetNamesAtomObserver = createAtomObserver({
|
|
5
|
+
port,
|
|
6
|
+
atom: availableAssetNamesAtom,
|
|
7
|
+
event: 'availableAssetNames',
|
|
8
|
+
})
|
|
9
|
+
availableAssetNamesAtomObserver.register()
|
|
10
|
+
|
|
11
|
+
const onLoad = () => {
|
|
12
|
+
availableAssetNamesAtomObserver.start()
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
const onStop = () => {
|
|
16
|
+
availableAssetNamesAtomObserver.unregister()
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
return {
|
|
20
|
+
onLoad,
|
|
21
|
+
onStop,
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
const availableAssetsPluginDefinition = {
|
|
26
|
+
id: 'availableAssetsPlugin',
|
|
27
|
+
type: 'plugin',
|
|
28
|
+
factory: createAvailableAssetsPlugin,
|
|
29
|
+
dependencies: ['port', 'availableAssetNamesAtom'],
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export default availableAssetsPluginDefinition
|
package/redux/index.js
CHANGED
|
@@ -7,7 +7,7 @@ const availableAssetsReduxDefinition = {
|
|
|
7
7
|
type: 'redux-module',
|
|
8
8
|
initialState,
|
|
9
9
|
eventReducers: {
|
|
10
|
-
|
|
10
|
+
availableAssetNames: (state, availableAssetNames) => ({
|
|
11
11
|
...state,
|
|
12
12
|
data: new Set(availableAssetNames),
|
|
13
13
|
}),
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { createWithParentCombinedNetworkAssetsSelector } from '@exodus/core-selectors/assets/networks'
|
|
2
|
+
|
|
3
|
+
const selectorFactory = (allAvailableAssetsSelector) =>
|
|
4
|
+
createWithParentCombinedNetworkAssetsSelector({
|
|
5
|
+
allAssetsSelector: allAvailableAssetsSelector,
|
|
6
|
+
})
|
|
7
|
+
|
|
8
|
+
const allWithParentCombinedNetworkSelectorDefinition = {
|
|
9
|
+
id: 'allWithParentCombinedNetwork',
|
|
10
|
+
selectorFactory,
|
|
11
|
+
dependencies: [{ selector: 'all' }],
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export default allWithParentCombinedNetworkSelectorDefinition
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { createWithoutParentCombinedNetworkAssetsSelector } from '@exodus/core-selectors/assets/networks'
|
|
2
|
+
|
|
3
|
+
const selectorFactory = (allAvailableAssetsSelector) =>
|
|
4
|
+
createWithoutParentCombinedNetworkAssetsSelector({
|
|
5
|
+
allAssetsSelector: allAvailableAssetsSelector,
|
|
6
|
+
})
|
|
7
|
+
|
|
8
|
+
const allWithoutParentCombinedNetworkSelectorDefinition = {
|
|
9
|
+
id: 'allWithoutParentCombinedNetwork',
|
|
10
|
+
selectorFactory,
|
|
11
|
+
dependencies: [{ selector: 'all' }],
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export default allWithoutParentCombinedNetworkSelectorDefinition
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { createCreateCombinedAssetChildrenNamesSelector } from '@exodus/core-selectors/assets/networks'
|
|
2
|
+
|
|
3
|
+
const selectorFactory = (allAvailableAssetsSelector) =>
|
|
4
|
+
createCreateCombinedAssetChildrenNamesSelector({
|
|
5
|
+
allAssetsSelector: allAvailableAssetsSelector,
|
|
6
|
+
})
|
|
7
|
+
|
|
8
|
+
const getCombinedChildrenNamesSelectorDefinition = {
|
|
9
|
+
id: 'getCombinedChildrenNames',
|
|
10
|
+
selectorFactory,
|
|
11
|
+
dependencies: [{ selector: 'all' }],
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export default getCombinedChildrenNamesSelectorDefinition
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { createGetCombinedAssetFallbackSelector } from '@exodus/core-selectors/assets/networks'
|
|
2
|
+
|
|
3
|
+
const selectorFactory = (allAvailableAssetsSelector) =>
|
|
4
|
+
createGetCombinedAssetFallbackSelector({
|
|
5
|
+
allAssetsSelector: allAvailableAssetsSelector,
|
|
6
|
+
})
|
|
7
|
+
|
|
8
|
+
const getCombinedFallbackSelectorDefinition = {
|
|
9
|
+
id: 'getCombinedFallback',
|
|
10
|
+
selectorFactory,
|
|
11
|
+
dependencies: [{ selector: 'all' }],
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export default getCombinedFallbackSelectorDefinition
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { createGetHasAssetsOnOtherChainsSelector } from '@exodus/core-selectors/assets/networks'
|
|
2
|
+
|
|
3
|
+
const selectorFactory = (allAvailableAssetsSelector) =>
|
|
4
|
+
createGetHasAssetsOnOtherChainsSelector({
|
|
5
|
+
allAssetsSelector: allAvailableAssetsSelector,
|
|
6
|
+
})
|
|
7
|
+
|
|
8
|
+
const getHasAssetsOnOtherChainsSelectorDefinition = {
|
|
9
|
+
id: 'getHasAssetsOnOtherChains',
|
|
10
|
+
selectorFactory,
|
|
11
|
+
dependencies: [{ selector: 'all' }],
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export default getHasAssetsOnOtherChainsSelectorDefinition
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { memoize } from 'lodash'
|
|
2
|
+
import { createSelector } from 'reselect'
|
|
3
|
+
|
|
4
|
+
const selectorFactory = (allAvailableAssetsSelector) =>
|
|
5
|
+
createSelector(allAvailableAssetsSelector, (allAvailableAssets) =>
|
|
6
|
+
memoize((assetName) => allAvailableAssets[assetName])
|
|
7
|
+
)
|
|
8
|
+
|
|
9
|
+
const getSelectorDefinition = {
|
|
10
|
+
id: 'get',
|
|
11
|
+
selectorFactory,
|
|
12
|
+
dependencies: [{ selector: 'all' }],
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export default getSelectorDefinition
|
package/redux/selectors/index.js
CHANGED
|
@@ -1,8 +1,20 @@
|
|
|
1
1
|
import allSelectorDefinition from './all'
|
|
2
2
|
import allForNetworkSelectorDefinition from './all-for-network'
|
|
3
|
+
import allWithParentCombinedNetworkSelectorDefinition from './all-with-parent-combined-network'
|
|
4
|
+
import allWithoutParentCombinedNetworkSelectorDefinition from './all-without-parent-combined-network'
|
|
5
|
+
import getCombinedChildrenNamesSelectorDefinition from './get-combined-children-names'
|
|
6
|
+
import getCombinedFallbackSelectorDefinition from './get-combined-fallback'
|
|
7
|
+
import getHasAssetsOnOtherChainsSelectorDefinition from './get-has-assets-on-other-chains'
|
|
8
|
+
import getSelectorDefinition from './get'
|
|
3
9
|
|
|
4
10
|
export default [
|
|
5
11
|
//
|
|
6
12
|
allSelectorDefinition,
|
|
7
13
|
allForNetworkSelectorDefinition,
|
|
14
|
+
allWithParentCombinedNetworkSelectorDefinition,
|
|
15
|
+
allWithoutParentCombinedNetworkSelectorDefinition,
|
|
16
|
+
getCombinedChildrenNamesSelectorDefinition,
|
|
17
|
+
getCombinedFallbackSelectorDefinition,
|
|
18
|
+
getHasAssetsOnOtherChainsSelectorDefinition,
|
|
19
|
+
getSelectorDefinition,
|
|
8
20
|
]
|