viewerjs/test/specs/events/scale.spec.js
2020-12-06 16:37:11 +08:00

86 lines
2.0 KiB
JavaScript

describe('scale (event)', () => {
it('should trigger the `scale` event', (done) => {
const image = window.createImage();
let viewer;
image.addEventListener('viewed', () => {
viewer.scale(-1);
});
image.addEventListener('scale', (event) => {
expect(event.type).to.equal('scale');
event.preventDefault();
viewer.hide(true);
done();
});
viewer = new Viewer(image);
viewer.show();
});
it('should have expected properties in `event.detail`', (done) => {
const image = window.createImage();
let viewer;
image.addEventListener('viewed', () => {
viewer.scale(-1);
});
image.addEventListener('scale', (event) => {
const { detail } = event;
expect(detail).to.be.an('object').that.has.all.keys('scaleX', 'scaleY', 'oldScaleX', 'oldScaleY');
expect(detail.scaleX).to.be.a('number');
expect(detail.scaleY).to.be.a('number');
expect(detail.oldScaleX).to.be.a('number');
expect(detail.oldScaleY).to.be.a('number');
event.preventDefault();
viewer.hide(true);
done();
});
viewer = new Viewer(image);
viewer.show();
});
it('should not trigger the `scaled` event when default prevented', (done) => {
const image = window.createImage();
let viewer;
image.addEventListener('viewed', () => {
viewer.scale(-1);
});
image.addEventListener('scale', (event) => {
event.preventDefault();
viewer.hide(true);
done();
});
image.addEventListener('scaled', () => {
expect.fail(1, 0);
});
viewer = new Viewer(image);
viewer.show();
});
it('should trigger the `scale` event in inline mode', (done) => {
const image = window.createImage();
let viewer;
image.addEventListener('viewed', () => {
viewer.scale(-1);
});
image.addEventListener('scale', (event) => {
expect(event.type).to.equal('scale');
done();
});
viewer = new Viewer(image, {
inline: true,
});
});
});