Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Seems to break immutable.js #18

Open
nickyhajal opened this issue Apr 18, 2016 · 18 comments
Open

Seems to break immutable.js #18

nickyhajal opened this issue Apr 18, 2016 · 18 comments

Comments

@nickyhajal
Copy link

Hi there,

I'm using Immutable.JS in my state and it seems that if I have electronEnhancer() in the renderer, I get the data fine as a basic object but it breaks Immutable's functions.

For example, getState().auth.toJS() works without the electronEnhancer but with it I get toJS is not a function.

@samiskin
Copy link
Owner

Unfortunately much of this library is dependent on the use of plain JavaScript objects, even though it really shouldn't. I'll likely have to do a few API-breaking changes so I'm going to put this off for a bit until I start working on a v0.4.0.

@hhff
Copy link

hhff commented Nov 16, 2016

Just hit this too! Let me know if there's anything I can do to help @samiskin !

@samiskin
Copy link
Owner

@hhff Unfortunately I likely won't be able to do significant work on this project for a while 😞, possibly until the very end of this year, but I'll always be open to PRs, so feel free to try implementing this on your own if its a pressing issue. I haven't used immutable.js in a real project before, only played around with it, so I'm not too sure what the challenges would entail.

I assume a cheap solution code-wise (but perhaps costly performance-wise) would be tailoring it specifically for immutable and just scattering toJS() and fromJS() calls everywhere. The main issue is that I'm not sure what the details of passing immutable structures through ipc is.

@arieldf
Copy link

arieldf commented Mar 15, 2017

@hhff @nickyhajal Any of you managed to get this working with Immutable? Any tips?

I have started to modify the codebase to see whether I'll manage. I'll keep you updated! We have a big project and need to move over to Immutable.

@hhff
Copy link

hhff commented Mar 15, 2017

@arieldf it's not possible I believe (without hacky rehydration stuff), as this project uses IPC to keep everything in sync. IPC can't transmit non-primitives.

@arieldf
Copy link

arieldf commented Mar 15, 2017

@hhff thanks for your quick response. Are there any alternatives that you are aware of?

@nickyhajal
Copy link
Author

The project I was using this on is currently on my back burner but here's how I got around it (not using redux-electron-store).

In the rendered window:

const store = configureStore(initialState);
store.subscribe(() => {
  const state = store.getState();
  ipcRenderer.send('state', {
    settings: state.settings.toJS(),
    auth: state.auth.toJS(),
  });
});

In the electron main.js

let state = {};
ipcMain.on('state', (ev, updatedState) => {
  state = updatedState;
  // do other stuff
});

This is obviously pretty basic but it worked for my needs. Hope it helps!

@arieldf
Copy link

arieldf commented Mar 15, 2017

Thanks for the response @nickyhajal - valuable input

@hhff
Copy link

hhff commented Mar 15, 2017

heck ya! that would work!

@samiskin
Copy link
Owner

samiskin commented Mar 15, 2017

Might be able to get it to work within this project using https://github.com/intelie/immutable-js-diff and https://github.com/intelie/immutable-js-patch

The core of this project is just that when an action happens, diff the state, send the diffs to the other processes, then apply the diff from the other processes.

Theres just a couple more optimization parts (the "filter" stuff) to not send updates to a window unless the window actually cares about that update.

@arieldf
Copy link

arieldf commented Mar 15, 2017

@samiskin thanks a lot for the suggestion. I'll revert when I manage to solve this

@arieldf
Copy link

arieldf commented Mar 17, 2017

@samiskin This could be a viable solution, but I did not successfully manage yet. When will the latest release be available on NPM? I would like to work with the latest code base. Thanks again

@arieldf
Copy link

arieldf commented Mar 17, 2017

@samiskin Ref. the above question, there is a second alternative which is to have the root state split between an immutable state-tree and a plain JS state-tree, where everything that should be in sync with main and renderer using this lib goes into the plain JS state. What would be the best practice to accomplish this with electron-redux-store? Basically I would like a different state/reducers in main and renderer, but with a plain JS state property in common that is equal.

@samiskin
Copy link
Owner

samiskin commented Mar 17, 2017

@arieldf It might be able to work if you just set the filter property on the renderer to ignore the immutable part of the state. Theres also an excludeUnfilteredState option you could set to true so that it wouldn't show any of the ipc-ified immutable objects in the renderer's state.

I'll try to publish to NPM sometime today

@arieldf
Copy link

arieldf commented Mar 17, 2017

Thanks for the input @samiskin!

UPDATE: using a different reducer and initial state in the main solved it

/////
I hope there is a small change to the code I can do so that this will indeed work as the below is what I get following the above (both for 0.4 and 0.6):

Doing as you proposed with the filter I get the following errors:
I. The previous state received by the reducer is of unexpected type. Expected argument to be an instance of Immutable.Collection or Immutable.Record with the following properties: ...
II. Uncaught TypeError: inputState.withMutations is not a function

adding the excludeUnfilteredState = true I get:
Uncaught Error: Values in the sink must be another object, function, or true
at keys.forEach (http://localhost:3000/dist/bundle.js:91146:13)
at Array.forEach (native)
at fillShape (http://localhost:3000/dist/bundle.js:91138:14)
at http://localhost:3000/dist/bundle.js:90950:51
at ../node_modules/redux/lib/applyMiddleware.js:38:19
at http://localhost:3000/dist/bundle.js:97030:211
at ../node_modules/redux/lib/applyMiddleware.js:38:19
at :1:5448
at Object.createStore (../node_modules/redux/lib/createStore.js:65:33)
at Object.configureStore [as default] (http://localhost:3000/dist/bundle.js:121161:25)

@samiskin
Copy link
Owner

@arieldf I published master under the beta tag. Going to try to add more tests soon and then publish to latest.

@initFabian
Copy link
Contributor

Was this issue ever resolved? I'm encountering the same same issue when using Record from immutableJS

@samiskin
Copy link
Owner

samiskin commented Feb 14, 2018

Nope never ended up being able to work on it. I haven't really used Immutable.js at all so I'm not too familiar on the best ways to handle it 😞 .

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants