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

91 lines
2.0 KiB
JavaScript

describe('scale (option)', () => {
it('should be null be default', () => {
const image = window.createImage();
const viewer = new Viewer(image);
expect(viewer.options.scale).to.be.null;
});
it('should execute the `scale` hook function', (done) => {
const image = window.createImage();
const viewer = new Viewer(image, {
viewed() {
viewer.scale(-1);
},
scale(event) {
expect(event.type).to.equal('scale');
event.preventDefault();
viewer.hide(true);
done();
},
});
viewer.show();
});
it('should have expected properties in `event.detail`', (done) => {
const image = window.createImage();
const viewer = new Viewer(image, {
viewed() {
viewer.scale(-1);
},
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.show();
});
it('should not execute the `scaled` hook function when default prevented', (done) => {
const image = window.createImage();
const viewer = new Viewer(image, {
inline: true,
viewed() {
viewer.scale(-1);
},
scale(event) {
event.preventDefault();
setTimeout(() => {
viewer.hide(true);
done();
}, 350);
},
scaled() {
expect.fail(1, 0);
},
});
});
it('should execute the `scale` hook function in inline mode', (done) => {
const image = window.createImage();
new Viewer(image, {
inline: true,
viewed() {
this.viewer.scale(-1);
},
scale(event) {
expect(event.type).to.equal('scale');
done();
},
});
});
});