multimediaobject
Version:
Multimediaobject library
209 lines (190 loc) • 11.2 kB
JavaScript
/* globals MultimediaObject */
import { prefixFor, getRandomInt } from '../../src/utils/utils';
import staticData from '../../src/config/data.static';
describe('MultimediaObject applyStyle', () => {
const style = {
position: 'absolute',
width: '15%',
height: '10%',
'background-size': 'contain',
'background-repeat': 'no-repeat',
'background-position': 'center',
'background-image': "url('')",
};
const ob = new MultimediaObject();
ob.applyStyle(style);
it('should have the style and _style set', () => {
expect(ob.style).toEqual(style);
expect(ob._style).toEqual(style);
});
const ob2 = new MultimediaObject();
const style2 = {
translateX: '10%',
translateY: '5em',
translateZ: '15',
scaleX: '1.2',
scaleY: '1',
rotate: '45',
};
const _refStyle2 = {
translateX: '10%',
translateY: '5em',
translateZ: '15px',
scaleX: '1.2',
scaleY: '1',
rotate: '45deg',
};
const refStyle2 = {
translateX: '10%',
translateY: '5em',
translateZ: '15px',
scaleX: '1.2',
scaleY: '1',
rotate: '45deg',
transform: 'translate3d(10%, 5em, 15px) rotateX(0deg) rotateY(0deg) rotateZ(45deg) skew(0deg, 0deg) scale(1.2, 1)',
};
ob2.applyStyle(style2, true);
it('should have processed transform properties in element.style', () => {
const prefix = prefixFor('transform');
expect(ob2.element.style[`${prefix}${prefix === '' ? 'transform' : 'Transform'}`]).toEqual(refStyle2.transform);
});
it('should have processed transform properties in _style and style but not applied transform string', () => {
expect(ob2._style).toEqual(_refStyle2);
expect(ob2.style).toEqual(_refStyle2);
});
const props = [{
translateX: null,
'translate-y': null,
'skew-x': null,
skewY: 10,
scaleY: '5vh',
scaleX: 10,
}, {
position: 'absolute',
marginLeft: 5,
padding: '5 10',
paddingLeft: 15,
float: 'left',
'font-family': 'Arial, sans',
outline: 'none',
zIndex: 10,
}, {
position: 'absolute',
marginLeft: '5%',
padding: '5em 10px',
paddingLeft: '15vh',
float: 'left',
'border-radius': 10,
'background-position': 'center top',
backgroundRepeat: 'no-repeat',
'background-color': '#ef50a2',
}, {
zIndex: 100,
margin: '0 auto',
}];
const refProps = [{
translateX: '0px',
'translate-y': '0px',
'skew-x': '0deg',
skewY: '10deg',
scaleY: '5',
scaleX: '10',
}, {
position: 'absolute',
marginLeft: '5px',
padding: '5 10',
paddingLeft: '15px',
float: 'left',
'font-family': 'Arial, sans',
outline: 'none',
zIndex: 10,
}, {
position: 'absolute',
marginLeft: '5%',
padding: '5em 10px',
paddingLeft: '15vh',
float: 'left',
'border-radius': '10px',
'background-position': 'center top',
backgroundRepeat: 'no-repeat',
'background-color': '#ef50a2',
}, {
zIndex: 100,
margin: '0 auto',
}];
props.forEach((propStyle, index) => {
const ob3 = new MultimediaObject();
ob3.applyStyle(propStyle);
for (const prop in propStyle) {
it(`should keep the right units if ${prop} = ${propStyle[prop]}`, () => {
expect(ob3._style[prop]).toEqual(refProps[index][prop]);
expect(ob3.style[prop]).toEqual(refProps[index][prop]);
});
}
});
const pxPropertiesArray = staticData.sets.pxProperties;
const degProperties = staticData.sets.degProperties;
const styleProperties = staticData.sets.styleProperties;
const globalObj = new MultimediaObject();
const globalStyle = {};
const globalUnitRefStyle = {};
pxPropertiesArray.forEach((prop) => {
const units = ['px', '%', 'em', 'vh', 'vw', '', ' auto'];
const styleObj = {};
units.forEach((unit, index) => {
const ob4 = new MultimediaObject();
const obValue = `10${unit}`;
const refValue = `10${index <= 4 ? unit : 'px'}`;
styleObj[prop] = obValue;
ob4.applyStyle(styleObj, true);
it(`should applyStyle with unit for propertie ${prop} and value ${obValue}`, () => {
expect(ob4._style[prop]).toEqual(refValue);
});
});
const refUnit = units[getRandomInt(0, 4)];
globalStyle[prop] = `10${refUnit}`;
globalUnitRefStyle[prop] = refUnit;
});
it('should have applied all properties correctly from a large object', () => {
globalObj.applyStyle(globalStyle);
expect(globalObj._style).toEqual(globalStyle);
});
degProperties.forEach((prop) => {
const units = ['deg', 'px', '%', 'em', 'vh', 'vw', '', ' auto'];
const styleObj = {};
units.forEach((unit) => {
const ob4 = new MultimediaObject();
const obValue = `10${unit}`;
styleObj[prop] = obValue;
ob4.applyStyle(styleObj, true);
it(`should applyStyle with correct unit 'deg' for propertie ${prop} and value ${obValue}`, () => {
expect(ob4._style[prop]).toEqual('10deg');
});
});
});
styleProperties.forEach((prop) => {
const units = ['deg', 'px', '%', 'em', 'vh', 'vw', '', ' auto', 'contain', 'test', 'cover'];
const styleObj = {};
units.forEach((unit) => {
const ob4 = new MultimediaObject();
const obValue = `10${unit}`;
styleObj[prop] = obValue;
ob4.applyStyle(styleObj, true);
it(`should applyStyle with what is set for propertie ${prop} and value ${obValue}`, () => {
expect(ob4._style[prop]).toEqual(obValue);
});
});
});
describe('with absoluteAssetURL', () => {
it('should replace {{absoluteAssetURL}}', () => {
const testob = new MultimediaObject();
window._s4mConfig = {};
window._s4mConfig.absoluteAssetURL = 'testURL';
testob.applyStyle({
'background-image': 'url({{absoluteAssetURL}}/test/images.jpg)',
});
expect(testob.element.style.backgroundImage).toContain('testURL/test/images.jpg');
expect(testob.style['background-image']).toEqual('url({{absoluteAssetURL}}/test/images.jpg)');
});
});
});