-
Notifications
You must be signed in to change notification settings - Fork 300
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add redux-bundler support for Electrode subapps (#1484)
* Integrate redux-bundler into subapp-pbundle * Use preact for jsx, render, and hydrate
- Loading branch information
1 parent
9c2c009
commit ceaa8b4
Showing
6 changed files
with
155 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
"use strict"; | ||
|
||
const { registerSubApp } = require("subapp-util"); | ||
|
||
const shared = require("../dist/shared"); | ||
|
||
module.exports = { | ||
reduxBundlerLoadSubApp: subapp => { | ||
const extras = { | ||
__redux: true | ||
}; | ||
|
||
if (!subapp.reduxCreateStore) { | ||
extras._genReduxCreateStore = "subapp"; | ||
extras.reduxCreateStore = shared.getReduxCreateStore(subapp); | ||
} | ||
|
||
return registerSubApp(Object.assign(extras, subapp)); | ||
} | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,73 @@ | ||
import { h, render, hydrate } from "preact"; | ||
import { loadSubApp } from "subapp-web"; | ||
import { Provider } from 'redux-bundler-preact'; | ||
import { setStoreContainer, getReduxCreateStore } from "./shared"; | ||
|
||
setStoreContainer(typeof window === 'undefined' ? global : window); | ||
|
||
// | ||
// client side function to start a subapp with redux-bundler support | ||
// | ||
export function reduxRenderStart(options) { | ||
const store = options._store || options.reduxCreateStore(options.initialState); | ||
const { Component } = options; | ||
|
||
if (options.serverSideRendering) { | ||
hydrate( | ||
<Provider store={store}> | ||
<Component /> | ||
</Provider>, | ||
options.element | ||
); | ||
} else { | ||
render( | ||
<Provider store={store}> | ||
<Component /> | ||
</Provider>, | ||
options.element | ||
); | ||
} | ||
|
||
return store; | ||
} | ||
|
||
let store; | ||
|
||
// | ||
// Load a subapp with redux-bundler support | ||
// info - the subapp's information | ||
// | ||
export function reduxBundlerLoadSubApp(info) { | ||
const renderStart = function(instance, element) { | ||
const initialState = instance._prepared || instance.initialState; | ||
const reduxCreateStore = instance.reduxCreateStore || this.info.reduxCreateStore; | ||
const Component = this.info.StartComponent || this.info.Component; | ||
|
||
const store = reduxRenderStart({ | ||
_store: instance._store, | ||
initialState, | ||
reduxCreateStore, | ||
Component, | ||
serverSideRendering: instance.serverSideRendering, | ||
element | ||
}); | ||
|
||
instance._store = store; | ||
return store; | ||
}; | ||
|
||
const extras = { | ||
__redux: true | ||
}; | ||
|
||
if (!info.reduxCreateStore) { | ||
extras._genReduxCreateStore = "subapp"; | ||
} | ||
|
||
return loadSubApp( | ||
Object.assign(extras, info, { | ||
reduxCreateStore: getReduxCreateStore(info) | ||
}), | ||
renderStart | ||
); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
const composeBundles = require("redux-bundler").composeBundles; | ||
|
||
// | ||
// - stores can be shared between subapps with reduxShareStore flag | ||
// - if it's true, then a common global store is used | ||
// - if it's a string, then it's use to name a store for sharing. | ||
// - otherwise subapp gets its own private store | ||
// - state sharing is made possible through named reducers | ||
// - each subapp must provide named reducers for states | ||
// - other subapps can then provide the same reducer under the same name | ||
// - all the reducers are then merged into a single object and then combined | ||
// - initial state handling follow these rules | ||
// - the first subapp that loads and initializes wins and all subapps load | ||
// after will use the initial state from it | ||
// - a top level initializer can be specified to do this | ||
// | ||
|
||
let shared = {}; | ||
|
||
function setStoreContainer(container) { | ||
shared = container; | ||
} | ||
|
||
function clearSharedStore() { | ||
delete shared.store; | ||
} | ||
|
||
function getSharedStore() { | ||
return shared.store; | ||
} | ||
|
||
function setSharedStore(store) { | ||
shared.store = store; | ||
} | ||
|
||
function getReduxCreateStore(info) { | ||
const bundles = info.reduxBundles || []; | ||
return function reduxCreateStore(initialState) { | ||
let store = getSharedStore(); | ||
if (store) { | ||
store.integrateBundles.apply(this, bundles); | ||
} else { | ||
store = composeBundles.apply(this, bundles)(initialState); | ||
setSharedStore(store); | ||
} | ||
return store; | ||
} | ||
} | ||
|
||
module.exports = { | ||
setStoreContainer, | ||
getReduxCreateStore, | ||
getSharedStore, | ||
setSharedStore, | ||
clearSharedStore | ||
}; |