mirror of
https://github.com/iconify/iconify.git
synced 2025-01-07 07:34:22 +00:00
101 lines
2.9 KiB
TypeScript
101 lines
2.9 KiB
TypeScript
import {
|
|
getCustomisations,
|
|
haveCustomisationsChanged,
|
|
defaultCustomisations,
|
|
} from '../src/attributes/customisations';
|
|
import { getInline } from '../src/attributes/inline';
|
|
import { cleanupGlobals, setupDOM } from './helpers';
|
|
|
|
describe('Testing customisations', () => {
|
|
afterEach(cleanupGlobals);
|
|
|
|
it('Get and compare customisations', () => {
|
|
// Setup DOM
|
|
const doc = setupDOM('').window.document;
|
|
|
|
// Create node, test default values
|
|
const node = doc.createElement('div');
|
|
const emptyCustomisations = getCustomisations(node);
|
|
expect(emptyCustomisations).toEqual(defaultCustomisations);
|
|
expect(getInline(node)).toBe(false);
|
|
expect(
|
|
haveCustomisationsChanged(
|
|
emptyCustomisations,
|
|
defaultCustomisations
|
|
)
|
|
).toBe(false);
|
|
|
|
// Test inline and height
|
|
node.innerHTML = '<span inline="true" height="1em"></span>';
|
|
let testNode = node.lastChild as HTMLSpanElement;
|
|
|
|
const test1 = getCustomisations(testNode);
|
|
expect(test1).toEqual({
|
|
...defaultCustomisations,
|
|
height: '1em',
|
|
});
|
|
expect(haveCustomisationsChanged(emptyCustomisations, test1)).toBe(
|
|
true
|
|
);
|
|
expect(getInline(testNode)).toBe(true);
|
|
|
|
// Test transformations
|
|
node.innerHTML = '<span flip="horizontal" rotate="2"></span>';
|
|
testNode = node.lastChild as HTMLSpanElement;
|
|
|
|
const test2 = getCustomisations(testNode);
|
|
expect(test2).toEqual({
|
|
...defaultCustomisations,
|
|
hFlip: true,
|
|
rotate: 2,
|
|
});
|
|
expect(haveCustomisationsChanged(emptyCustomisations, test2)).toBe(
|
|
true
|
|
);
|
|
expect(haveCustomisationsChanged(test1, test2)).toBe(true);
|
|
expect(getInline(testNode)).toBe(false);
|
|
|
|
// Dimensions, empty value
|
|
node.innerHTML = '<span width="auto" height=""></span>';
|
|
testNode = node.lastChild as HTMLSpanElement;
|
|
|
|
const test3 = getCustomisations(testNode);
|
|
expect(test3).toEqual({
|
|
...defaultCustomisations,
|
|
width: 'auto',
|
|
});
|
|
expect(haveCustomisationsChanged(test3, test2)).toBe(true);
|
|
expect(haveCustomisationsChanged(test1, test3)).toBe(true);
|
|
expect(haveCustomisationsChanged(test3, emptyCustomisations)).toBe(
|
|
true
|
|
);
|
|
expect(getInline(testNode)).toBe(false);
|
|
|
|
// preserveAspectRatio
|
|
node.innerHTML = '<span preserveAspectRatio="xMidYMid meet"></span>';
|
|
testNode = node.lastChild as HTMLSpanElement;
|
|
|
|
const test6 = getCustomisations(testNode);
|
|
expect(test6).toEqual({
|
|
...defaultCustomisations,
|
|
preserveAspectRatio: 'xMidYMid meet',
|
|
});
|
|
expect(haveCustomisationsChanged(test6, emptyCustomisations)).toBe(
|
|
true
|
|
);
|
|
|
|
node.innerHTML = '<span preserveaspectratio="xMidYMin slice"></span>';
|
|
testNode = node.lastChild as HTMLSpanElement;
|
|
|
|
const test7 = getCustomisations(testNode);
|
|
expect(test7).toEqual({
|
|
...defaultCustomisations,
|
|
preserveAspectRatio: 'xMidYMin slice',
|
|
});
|
|
expect(haveCustomisationsChanged(test7, emptyCustomisations)).toBe(
|
|
true
|
|
);
|
|
expect(haveCustomisationsChanged(test7, test6)).toBe(true);
|
|
});
|
|
});
|