<div class="contrain" id="js-constrain"></div>





















<!-- ABOUT LINK -->
<style> .what:hover { cursor: pointer; opacity: .75; } .what {display: block;width: 28px;height: 28px;position: fixed;right: 20px;bottom: 20px;background-size: 100% 100%; background-image: url();}</style><a href="http://mojs.io/tutorials/burst/" class="what" title="tutorial" target="_blank"></a>
<!-- ABOUT LINK -->
body, html {
  padding: 0;
  margin:  0;
  width: 100%;
  height: 100%;
  // overflow: hidden;
}

body {
  background: rgba(241, 226, 215, 0.2);
  background: #777;
  position: relative;
  background: #EA485C;
}
const COLORS = {
  RED:      '#FD5061',
  YELLOW:   '#FFCEA5',
  BLACK:    '#29363B',
  WHITE:    'white',
  VINOUS:   '#A50710'
}

const DURATION = 500;
const CNT = 10;
const PARENT_H = 50;
const BURST_R = 75;
const SHIFT = 300;

const makeDust = (dir = -1) => {
  
  const parent = new mojs.Shape({
    left: 0,  top: 0,
    width:        200,
    height:       50,
    radius:       0,
    x:            { 0 : dir*SHIFT  },
    duration:     1.2*DURATION,
    isShowStart:  true,
    isTimelineLess: true,
    isForce3d:    true
  });

  parent.el.style['overflow'] = 'hidden';

  const burst = new mojs.Burst({
    parent:   parent.el,
    count:    CNT,
    top:      PARENT_H + BURST_R,
    degree:   90,
    radius:   BURST_R,
    angle:    ( dir === -1) ? { [-90] : 40 } : { [0] : -130 },
    children: {
      fill:       'white',
      delay:      ( dir === -1 )
                      ? `stagger(${DURATION}, -${DURATION/CNT})`
                      : `stagger(${DURATION/CNT})`,
      radius:     'rand(8, 25)',
      direction:  -1,
      isSwirl:    true,
      isForce3d: true
    }
  });

  const fadeBurst = new mojs.Burst({
    parent:     parent.el,
    count:      2,
    degree:     0,
    angle:      -1*dir*75,
    radius:     { 0 : 100 },
    top:        '90%',
    timeline:   { delay: .8*DURATION },
    children: {
      fill: 'white',
      pathScale: [ .65, 1 ],
      radius: 'rand(12, 15)',
      direction: [ dir, -1*dir ],
      isSwirl:    true,
      isForce3d: true
    }
  }); 

  const timeline = new mojs.Timeline();
  timeline.add( parent, burst, fadeBurst );

  return { parent, timeline };
}

const circle = new mojs.Shape({
  left: 0, top: 0,
  strokeWidth: 10,
  fill:     'none',
  radius:   150,
  scale:    { 0 : 1 },
  opacity:  { 1: 0 },
  shape:    'circle',
  stroke:   'white',
  strokeWidth: 10,
  fill:     'none',
  duration: 1.5*DURATION,
  isForce3d: true,
  isTimelineLess: true,
});

const cloud = new mojs.Burst({
  left: 0, top: 0,
  radius:   { 4: 49 },
  angle:    45,
  count:    12,
  children: {
    radius:       10,
    fill:         'white',
    scale:        { 1: 0, easing: 'sin.in' },
    pathScale:    [ .7, null ],
    degreeShift:  [ 13, null ],
    duration:     [ 500, 700 ],
    isShowEnd:    false,
    isForce3d:    true
  }
});

const burst = new mojs.Burst({
  left: 0, top: 0,
  radius: { 0: 280 },
  count: 2,
  angle: 90,
  children: {
    shape: 'rect',
    fill: COLORS.VINOUS ,
    radius: 15,
    duration: DURATION,
    isForce3d: true
  }
});

const burst2 = new mojs.Burst({
  left: 0, top: 0,
  count:    5,
  radius:   { 0: 150 },
  angle:    90,
  children: {
    shape:    'line',
    stroke:   COLORS.VINOUS,
    strokeWidth: 5,
    strokeLinecap: 'round',
    radius:   25,
    // angle:    {  0: 360  },
    scale:    1,
    scaleX:   { 1: 0 },
    duration: DURATION,
    isForce3d: true
  }
});

const dust1 = makeDust(-1);
const dust2 = makeDust(1);

const timeline = new mojs.Timeline();
timeline
  .add( dust1.timeline, dust2.timeline )
  .add( circle, cloud, burst, burst2 )

document.addEventListener( 'click', function (e) {
  const x = e.pageX,
        y = e.pageY;
  
  const coords = { x, y };
  circle.tune(coords); cloud.tune(coords);
  burst.tune(coords); burst2.tune(coords);
  dust1.parent.tune({ x: { [x] : x - SHIFT }, y });
  dust2.parent.tune({ x: { [x] : x + SHIFT }, y });
  timeline.replay();
});

// new MojsPlayer({ add: timeline, isPlaying: true, isRepeat: true });
View Compiled

External CSS

This Pen doesn't use any external CSS resources.

External JavaScript

  1. https://cdn.jsdelivr.net/mojs/0.265.6/mo.min.js
  2. https://cdn.jsdelivr.net/mojs-player/0.43.15/mojs-player.min.js