mirror of
https://github.com/iconify/iconify.git
synced 2025-01-28 17:48:27 +00:00
209 lines
4.5 KiB
JavaScript
209 lines
4.5 KiB
JavaScript
|
import { mount } from '@vue/test-utils';
|
||
|
import { Icon } from '../../dist/offline';
|
||
|
|
||
|
const iconData = {
|
||
|
body:
|
||
|
'<path d="M4 19h16v2H4zm5-4h11v2H9zm-5-4h16v2H4zm0-8h16v2H4zm5 4h11v2H9z" fill="currentColor"/>',
|
||
|
width: 24,
|
||
|
height: 24,
|
||
|
};
|
||
|
|
||
|
describe('Rotation', () => {
|
||
|
test('number', () => {
|
||
|
const Wrapper = {
|
||
|
components: { Icon },
|
||
|
template: `<Icon :icon="icon" :rotate="1" />`,
|
||
|
data() {
|
||
|
return {
|
||
|
icon: iconData,
|
||
|
};
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const wrapper = mount(Wrapper, {});
|
||
|
expect(wrapper.html().replace(/\s*\n\s*/g, '')).toEqual(
|
||
|
'<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" width="1em" height="1em" preserveAspectRatio="xMidYMid meet" viewBox="0 0 24 24"><g transform="rotate(90 12 12)"><path d="M4 19h16v2H4zm5-4h11v2H9zm-5-4h16v2H4zm0-8h16v2H4zm5 4h11v2H9z" fill="currentColor"></path></g></svg>'
|
||
|
);
|
||
|
});
|
||
|
|
||
|
test('string', () => {
|
||
|
const Wrapper = {
|
||
|
components: { Icon },
|
||
|
template: `<Icon :icon="icon" rotate="180deg" />`,
|
||
|
data() {
|
||
|
return {
|
||
|
icon: iconData,
|
||
|
};
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const wrapper = mount(Wrapper, {});
|
||
|
expect(wrapper.html()).toContain('<g transform="rotate(180 12 12)">');
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('Flip', () => {
|
||
|
test('boolean', () => {
|
||
|
const Wrapper = {
|
||
|
components: { Icon },
|
||
|
template: `<Icon :icon="icon" :hFlip="true" />`,
|
||
|
data() {
|
||
|
return {
|
||
|
icon: iconData,
|
||
|
};
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const wrapper = mount(Wrapper, {});
|
||
|
expect(wrapper.html()).toContain(
|
||
|
'<g transform="translate(24 0) scale(-1 1)">'
|
||
|
);
|
||
|
});
|
||
|
|
||
|
test('string', () => {
|
||
|
const Wrapper = {
|
||
|
components: { Icon },
|
||
|
template: `<Icon :icon="icon" flip="vertical" />`,
|
||
|
data() {
|
||
|
return {
|
||
|
icon: iconData,
|
||
|
};
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const wrapper = mount(Wrapper, {});
|
||
|
expect(wrapper.html()).toContain(
|
||
|
'<g transform="translate(0 24) scale(1 -1)">'
|
||
|
);
|
||
|
});
|
||
|
|
||
|
test('string and boolean', () => {
|
||
|
const Wrapper = {
|
||
|
components: { Icon },
|
||
|
template: `<Icon :icon="icon" flip="horizontal" :vFlip="true" />`,
|
||
|
data() {
|
||
|
return {
|
||
|
icon: iconData,
|
||
|
};
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const wrapper = mount(Wrapper, {});
|
||
|
expect(wrapper.html()).toContain('<g transform="rotate(180 12 12)">');
|
||
|
});
|
||
|
|
||
|
test('string for boolean attribute', () => {
|
||
|
const Wrapper = {
|
||
|
components: { Icon },
|
||
|
template: `<Icon :icon="icon" horizontal-flip="true" />`,
|
||
|
data() {
|
||
|
return {
|
||
|
icon: iconData,
|
||
|
};
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const wrapper = mount(Wrapper, {});
|
||
|
expect(wrapper.html()).toContain(
|
||
|
'<g transform="translate(24 0) scale(-1 1)">'
|
||
|
);
|
||
|
});
|
||
|
|
||
|
test('shorthand and boolean', () => {
|
||
|
// 'flip' is processed after 'hFlip', overwriting value
|
||
|
const Wrapper = {
|
||
|
components: { Icon },
|
||
|
template: `<Icon :icon="icon" flip="horizontal" :hFlip="false" />`,
|
||
|
data() {
|
||
|
return {
|
||
|
icon: iconData,
|
||
|
};
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const wrapper = mount(Wrapper, {});
|
||
|
expect(wrapper.html()).toContain(
|
||
|
'<g transform="translate(24 0) scale(-1 1)">'
|
||
|
);
|
||
|
});
|
||
|
|
||
|
test('shorthand and boolean as string', () => {
|
||
|
const Wrapper = {
|
||
|
components: { Icon },
|
||
|
template: `<Icon :icon="icon" flip="vertical" :horizontal-flip="true" />`,
|
||
|
data() {
|
||
|
return {
|
||
|
icon: iconData,
|
||
|
};
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const wrapper = mount(Wrapper, {});
|
||
|
expect(wrapper.html()).toContain('<g transform="rotate(180 12 12)">');
|
||
|
});
|
||
|
|
||
|
test('wrong case', () => {
|
||
|
const Wrapper = {
|
||
|
components: { Icon },
|
||
|
template: `<Icon :icon="icon" :vflip="true" />`,
|
||
|
data() {
|
||
|
return {
|
||
|
icon: iconData,
|
||
|
};
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const wrapper = mount(Wrapper, {});
|
||
|
expect(wrapper.html()).not.toContain('<g transform="');
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('Alignment and slice', () => {
|
||
|
test('vAlign and slice', () => {
|
||
|
const Wrapper = {
|
||
|
components: { Icon },
|
||
|
template: `<Icon :icon="icon" vAlign="top" :slice="true" />`,
|
||
|
data() {
|
||
|
return {
|
||
|
icon: iconData,
|
||
|
};
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const wrapper = mount(Wrapper, {});
|
||
|
expect(wrapper.html()).toContain(
|
||
|
'preserveAspectRatio="xMidYMin slice"'
|
||
|
);
|
||
|
});
|
||
|
|
||
|
test('string', () => {
|
||
|
const Wrapper = {
|
||
|
components: { Icon },
|
||
|
template: `<Icon :icon="icon" align="left bottom" />`,
|
||
|
data() {
|
||
|
return {
|
||
|
icon: iconData,
|
||
|
};
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const wrapper = mount(Wrapper, {});
|
||
|
expect(wrapper.html()).toContain('preserveAspectRatio="xMinYMax meet"');
|
||
|
});
|
||
|
|
||
|
test('aliases', () => {
|
||
|
const Wrapper = {
|
||
|
components: { Icon },
|
||
|
template: `<Icon :icon="icon" h-align="left" vertical-align="bottom" />`,
|
||
|
data() {
|
||
|
return {
|
||
|
icon: iconData,
|
||
|
};
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const wrapper = mount(Wrapper, {});
|
||
|
expect(wrapper.html()).toContain('preserveAspectRatio="xMinYMax meet"');
|
||
|
});
|
||
|
});
|