UNPKG

multimediaobject

Version:
209 lines (190 loc) 11.2 kB
/* 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)'); }); }); });