Comments (5)
ATM the readme is not in sync with the repo code. I think the npm version does not have the composeFactory method. If you check out the in-dev repo version, you can use composeFactory method. https://github.com/mobxjs/mobx-state-tree/blob/master/test/object.ts#L180 Let me know if your issue is solved! :)
from mobx-state-tree.
If I got it right the ComposedFactory
there merges the fields into the final instance:
{
width: 0, // from Box factory
height: 0, // from Box factory
color: "#FFFFFF" // from Color factory
}
But I would like to achieve this kind of composition:
{
boxProp: { width: 0, height: 0 }, // from Box factory
colorProp: { color: "#FFFFFF"} // from Color factory
}
from mobx-state-tree.
Uh, sorry I misread! You simply pass in the box type.
const BoxStore = createFactory({
masterBox: Box,
boxes: mapOf(Box),
...
If the masterBox can be null, you should use maybe(Box)
from mobx-state-tree.
const {createFactory, action, mapOf, referenceTo} = require("mobx-state-tree");
const Box = createFactory({
// props
name: "",
x: 0,
y: 0,
// computed prop
get width() {
return this.name.length * 15
},
// action
move: action(function(dx, dy) {
this.x += dx
this.y += dy
})
});
const BoxStore = createFactory({
masterBox: Box,
boxes: mapOf(Box),
selection: referenceTo("boxes/name"),
addBox: action(function(name) {
this.boxes.set(name, Box({ name, x: 100, y: 100}))
})
});
const boxStore = BoxStore();
boxStore.addBox("test");
boxStore.boxes.get("test").move(7, 3);
boxStore.masterBox.move(15, 10);
produces this:
.../mobx-state-tree-test/index.js:33
boxStore.masterBox.move(15, 10);
^
TypeError: Cannot read property 'move' of null
at Object.<anonymous> (.../mobx-state-tree-test/index.js:33:19)
at Module._compile (module.js:571:32)
at Object.Module._extensions..js (module.js:580:10)
at Module.load (module.js:488:32)
at tryModuleLoad (module.js:447:12)
at Function.Module._load (module.js:439:3)
at Module.runMain (module.js:605:10)
at run (bootstrap_node.js:418:7)
at startup (bootstrap_node.js:139:9)
at bootstrap_node.js:533:3
from mobx-state-tree.
As said before, that works in the git version, the npm one is'nt aligned :)
from mobx-state-tree.
Related Issues (20)
- RootStore type becomes "any" the moment we call a RootStore model action using yield on a child model action HOT 3
- Unintended behavior when creating new models with falsy first argument HOT 8
- detach can corrupt the identifierCache HOT 2
- Add tests and documentation for debug names in complex types
- Add tests and documentation for new parent argument to `types.optional` HOT 1
- Document how MST lazily creates objects HOT 1
- Use getTime() to check for Date equality HOT 8
- Remove Lerna config and lift MST sub-package up
- When observe() a MST node's primitive property, TypeScript get the wrong type of oldValue & newValue HOT 1
- Add safeMap utility (or something like it)
- Broken Map type in 5.3.0 HOT 8
- TypeError: 0, _mobx.defineProperty is not a function (it is undefined) HOT 4
- applySnapshot is slow HOT 1
- Unexpected error "Сannot finalize the creation of a node that is already dead" while applying snapshot HOT 16
- Linters do not recognize `fail` as a required import in library code HOT 4
- REST - create data with server side ID HOT 2
- Better documentation on action/view definitions and their impact on IDE introspection, navigation and refactoring HOT 2
- Missing docs for `types.lazy` HOT 2
- getMembers does not work as expected, behaviour change between 5.1.0 and 5.4.1 HOT 11
- Model constructor modifies descriptor object HOT 5
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from mobx-state-tree.