summaryrefslogtreecommitdiff
path: root/frontend/src/sagas/prefabs.js
diff options
context:
space:
mode:
authorGeorgios Andreadis <info@gandreadis.com>2020-07-29 17:45:18 +0200
committerFabian Mastenbroek <mail.fabianm@gmail.com>2020-08-24 19:48:47 +0200
commit780e81c5ea7bc5c7988ae2c49bc8e6808337ff25 (patch)
tree92de51eae02e26fdbf0a703320626c13115e7a58 /frontend/src/sagas/prefabs.js
parentceaddeb0f6927e0f99f7b140aba6a85dac0106fb (diff)
parentac5b33c83f38f9b2799c0f2a871b86052121e8ac (diff)
Merge pull request #18 from atlarge-research/prefabs_wip
Add support for prefabs
Diffstat (limited to 'frontend/src/sagas/prefabs.js')
-rw-r--r--frontend/src/sagas/prefabs.js15
1 files changed, 15 insertions, 0 deletions
diff --git a/frontend/src/sagas/prefabs.js b/frontend/src/sagas/prefabs.js
new file mode 100644
index 00000000..16cf3d62
--- /dev/null
+++ b/frontend/src/sagas/prefabs.js
@@ -0,0 +1,15 @@
+import { call, put, select } from 'redux-saga/effects'
+import { addToStore } from '../actions/objects'
+import { addPrefab } from '../api/routes/prefabs'
+import { getRackById } from './objects'
+
+export function* onAddPrefab(action) {
+ try {
+ const currentRackId = yield select((state) => state.objects.tile[state.interactionLevel.tileId].rackId)
+ const currentRackJson = yield getRackById(currentRackId, false)
+ const prefab = yield call(addPrefab, { name: action.name, rack: currentRackJson })
+ yield put(addToStore('prefab', prefab))
+ } catch (error) {
+ console.error(error)
+ }
+}