About
DIVE is a spatial framework made by and optimized for Shopware. It can be used
directly integrated in a Shopware frontend such as Storefront or in any other
frontend you want to use it in, it is not tied to Shopware.
DIVE supplies your frontend application with all needed tooling to set up a
basic 3D application with event-based controls called "Actions". For further
information, see Getting started.
Installation
npm:
npm install @shopware-ag/dive
yarn:
yarn add @shopware-ag/dive
Formatter
DIVE uses Prettier as a preconfigured formatter.
Setup in Shopware
Don't forget to include DIVE in your webpack.config.js:
const path = require('path');
module.exports = () => {
return {
...
resolve: {
extensions: ['.ts', '.cjs', '.js'],
alias: {
three: path.resolve(__dirname, 'path/to/node_modules/three'),
"@shopware-ag/dive": path.resolve(__dirname, 'path/to/node_modules/@shopware-ag/dive'),
}
},
...
module: {
rules: [
...
{
test: /\.(js|ts)$/,
loader: 'swc-loader',
include: [
path.resolve(__dirname, 'path/to/node_modules/three'),
path.resolve(__dirname, 'path/to/node_modules/@shopware-ag/dive')
],
options: {
jsc: {
parser: {
syntax: 'typescript',
},
target: 'es2022',
},
},
},
...
],
}
};
};
Quick View
QuickView is used to quickly display your assets with as few lines of code as
possible. Simply call the static QuickView()
method (with your data-uri as a
parameter) to create an instance of DIVE with your asset to use in further code.
import { DIVE } from '@shopware-ag/dive';
const dive = DIVE.QuickView('your/asset/uri.glb');
const myCanvasWrapper = document.createElement('div');
myCanvasWrapper.appendChild(dive.Canvas);
Getting started
Import:
import { DIVE } from '@shopware-ag/dive';
Instantiate:
import { DIVE } from '@shopware-ag/dive';
const dive = new DIVE();
DIVE supplies your application with a HTMLCanvasElement that it uses as a render
target. After instantiating, you can use the supplied canvas within you frontend
code to attach it to your DOM.
const dive = new DIVE();
const myCanvasWrapper = document.createElement('div');
myCanvasWrapper.appendChild(dive.Canvas);
To interact with your newly created DIVE instance you have to perform actions
via DIVECommunication. For further information, see Actions.
const dive = new DIVE();
const myCanvasWrapper = document.createElement('div');
myCanvasWrapper.appendChild(dive.Canvas);
const com = dive.Communication;
com.PerformAction('SET_CAMERA_TRANSFORM', {
position: { x: 0, y: 2, z: 2 },
target: { x: 0, y: 0.5, z: 0 },
});
Actions
Actions symbolize the communication between frontend and 3D space. All actions
can be performed anywhere, no matter if you are in frontend or 3D.
In addition to the impact that specific actions have, every action can be
subscribed to.
const myCanvasWrapper = document.createElement('div');
const dive = new DIVE();
myCanvasWrapper.appendChild(dive.Canvas);
const com = dive.Communication;
com.Subscribe('SET_CAMERA_TRANSFORM', () => {
});
com.PerformAction('SET_CAMERA_TRANSFORM', {
position: { x: 0, y: 2, z: 2 },
target: { x: 0, y: 0.5, z: 0 },
});
Subscribing to an action returns a unsubscribe()
-callback that should be
executed when not needed anymore.
const myCanvasWrapper = document.createElement('div');
const dive = new DIVE();
myCanvasWrapper.appendChild(dive.Canvas);
const com = dive.Communication;
const unsubscribe = com.Subscribe('SET_CAMERA_TRANSFORM', () => {
});
com.PerformAction('SET_CAMERA_TRANSFORM', {
position: { x: 0, y: 2, z: 2 },
target: { x: 0, y: 0.5, z: 0 },
});
unsubscribe();
Actions (List)
In the following you find a list of all available actions to perform on
DIVECommunication class via
com.PerformAction()
.