API

Use the API for advanced control over the images, spins and videos in Sirv Media Viewer.

Global API

Method Parameters Description
Sirv.start (selector or element) Starts Sirv instance(s) by DOM query selector, or by HTML element
Sirv.stop (selector or element) Stops Sirv instance(s) by DOM query selector, or by HTML element
Sirv.on (event name) Attach an event handler for Sirv event
Sirv.off (event name) Remove an event handler
Sirv.getInstance (selector or element) Get viewer or lazy image instance by DOM query selector, or by HTML element
Sirv.viewer.getInstance (selector or element) Get viewer instance by DOM query selector, or by HTML element
Sirv.lazyImage.getInstance (selector or element) Get lazy image instance by DOM query selector, or by HTML element

Example code:

<script>
// Start all Sirv instances on the page:
Sirv.start();

// Start Sirv instances that match the provided selector:
Sirv.start('.product-view .Sirv');

// Attach event handler
Sirv.on('viewer:beforeSlideIn', (nextItem) => {
    console
.log(nextItem);
});
</script>

Viewer API

Method Parameters Description
isReady Check if a viewer instance is ready
isFullscreen Check if a viewer instance is in fullscreen
fullscreen Switch to full screen mode
next Switch to next item
prev Switch to previous item
jump (index or item id) Switch to a particular item by index or by id (data-id)
play (delay) Start viewer autoplay. If the delay argument is passed, it will override the slide.delay setting.
pause Pause viewer autoplay
items (filters) Get viewer items. Filters: { enabled: true } - only enabled items; { enabled: false } - only disabled items.
itemsCount (filters) Get the number of viewer items. Filters: { enabled: true } - only enabled items; { enabled: false } - only disabled items.
child (index or item id) Get reference to a particular item by index or by id (data-id)
enableItem (index or item id) Enable a particular item by index or by id (data-id)
disableItem (index or item id) Disable a particular item by index or by id (data-id)
insertItem (DOM element, index) Add item to the viewer at specified index. If index omitted, add item to the end.
removeItem (index or item id) Remove item from the viewer by index or by id (data-id)
enableGroup (name of group or array from names) Enable a particular group by group name (data-group)
disableGroup (name of group or array from names) Disable a particular group by group name (data-group)
switchGroup (name of group or array from names) Disable enabled groups and enable particular group
sortItems (array from component names or empty) Sort slides by itemsOrder option or array from component names

Example script to replace one gallery with another:

<script>
 
// Check if viewer with `id="my-viewer"` is ready:
 
Sirv.viewer.getInstance('#my-viewer').isReady();

 
// Switch to the next item:
 
Sirv.viewer.getInstance('#my-viewer').next();

 
// Disable (exclude) 4th item in the viewer:
 
Sirv.viewer.getInstance('#my-viewer').disableItem(3);
</script>

Example script to pause a slide on hover:

<script>
 
// Pause on entry:
  document
.querySelector('#slideshow').addEventListener('mouseenter', () => { Sirv.viewer.getInstance('#slideshow').pause(); });
 
 
// Play on exit:
  document
.querySelector('#slideshow').addEventListener('mouseleave', () => { Sirv.viewer.getInstance('#slideshow').play(); });
</script>

Example script to show/hide items in a gallery:

<script>
 
// Hide items in the "color-navy" group
 
Sirv.getInstance('#example-viewer-1').disableGroup('color-navy');
 
 
// Show items from the "color-brown" and "size-m" groups
 
Sirv.getInstance('#example-viewer-1').enableGroup(['color-brown', 'size-m']);
 
 
// Show items from the "color-yellow" group and hide all other items
 
Sirv.getInstance('#example-viewer-1').switchGroup('color-yellow');
</script>

Spin API

Method Parameters Description
isInitialized Check if Spin instance is initialized
isReady Check if Spin instance is ready
play (duration, type) Start auto-spin rotation
pause Stop autospin
rotate (columns, [rows]) Rotate by X number of frames on X-axis and/or Y-axis
rotateX (frames) Rotate by X number of frames on X-axis
rotateY (frames) Rotate by X number of frames on Y-axis
jumpRows (row) Jump to a specific row
jumpCols (column) Jump to a specific column
zoomIn Zoom in to current frame
zoomOut Zoom out of current frame
isZoomed Check if the current frame is zoomed
currentFrame Get current frame: {rows: XX, cols: XX}

Example script to rotate the spin:

<script>
// Check if Spin component spin is initialized:
Sirv.getInstance('#my-viewer-id').child(2).spin.isInitialized();

// Check if Spin component is ready:
Sirv.getInstance('.product-view .Sirv').child('spin-item').spin.isReady();

// Start rotate of spin:
Sirv.getInstance('#my-viewer-id').child(2).spin.play(3600, 'row');
</script>

Zoom API

Method Parameters Description
isReady Check if Zoom instance ready
isZoomed Check if image is zoomed in
zoomIn Zoom in to image.
zoomOut Zoom out of image

Example code:

<script>
// Check if component zoom is ready:
Sirv.getInstance('#my-viewer').child(3).zoom.isReady();

// Zoom in to image:
Sirv.getInstance('.product-view .Sirv').child('zoom-item').zoom.zoomIn();
</script>

Video API

Method Parameters Description
isReady Check if video instance is ready

Example code:

<script>
// Check if Video component is ready:
Sirv.viewer.getInstance('#my-viewer').child('video-item').video.isReady();
</script>

Model API

Method Parameters Description
getMaterial name or number Choose a material from your model
createTexture (uri, type) Apply a new texture from an image URL

Each material in the model has a number, with the first material being number 0.

Material instance API

Method Parameters Description
setColor number 0.00 to 1.00 for r, g, b, opacity Set color of a particular material in the model e.g. [r(0.54), g(0.17), b(0.63), a(0.26)]
setTexture name or null Choose a texture name or clear the texture with null
setMetallicFactor number 0.00 to 1.00 Set metallic factor of a particular material in the model
setRoughnessFactor number 0.00 to 1.00 Set roughness factor of a particular material in the model
setMetallicTexture name or null Choose a metallic texture name or clear the texture with null

Example code:

<script>
// Set color of one material and metallic factor of another material:
const model = Sirv.viewer.getInstance('#my-viewer').child('model-item').model;
model
.getMaterial(0).setColor('#abf0c4');
model
.getMaterial(2).setMetallicFactor(0.74);
</script>

Image API

Method Parameters Description
isReady Check if image instance is ready
resize Force image resize

Example code:

<script>
// Check if Image component is ready:
Sirv.viewer.getInstance('#my-viewer').child('image-item').image.isReady();

// Force image resize:
Sirv.viewer.getInstance('#my-viewer').child(4).image.resize();
</script>

Lazy image API

Method Parameters Description
isReady Check if lazy image instance is ready
resize Force image resize

Example code:

<script>
// Check if Lazy Image is ready:
Sirv.lazyimage.getInstance('#my-lazy-image').isReady();

// Force image resize:
Sirv.lazyimage.getInstance('#my-lazy-image').resize();
</script>

Hotspots API

Method Parameters Description
.add(hotspotSettings) hotspotSettings (JSON | Array<JSON>) Add hotspot(s) and settings
.remove(index) index (number) Remove one hotspot
.removeAll() Remove all hotspots
.enable(index) index (number) Enable a particular hotspot
.disable(index) index (number) Disable a particular hotspot
.list() List all hotspots
.setVisibility(index) index (number) Show/hide message popup or tooltip

Example code to hide hotspots in fullscreen:

<script>
const disableHotspots = (hotspotsApi) => {
  hotspotsApi
.list().forEach((node, index) => hotspotsApi.disable(index));
};

const enableHotspots = (hotspotsApi) => {
  hotspotsApi
.list().forEach((node, index) => hotspotsApi.enable(index));
};

Sirv.on('viewer:fullscreenIn', (e) => {
  e
.items().forEach(item => {
   
const componentApi = item[item.component];
   
if (componentApi.hotspots && componentApi.isReady()) {
      disableHotspots
(componentApi.hotspots);
   
}
 
});
});

Sirv.on('viewer:fullscreenOut', (e) => {
  e
.items().forEach(item => {
   
const componentApi = item[item.component];
   
if (componentApi.hotspots && componentApi.isReady()) {
      enableHotspots
(componentApi.hotspots);
   
}
 
});
});

Sirv.on('spin:ready', (e) => {
 
if (e.parent().parent().isFullscreen() && e.hotspots) {
    disableHotspots
(e.hotspots);
 
}
});
</script>

Was this article helpful?

Array

Get help from a Sirv expert

help ukraine help ukraine Powered by Ukrainian determination and British ingenuity

How can you support Ukraine