2021-05-24 13:25:02 +03:00
|
|
|
import type { IconifyIcon } from '@iconify/types';
|
2021-09-20 23:53:49 +03:00
|
|
|
import { mergeIconData } from '../lib/icon/merge';
|
2021-05-24 13:25:02 +03:00
|
|
|
|
|
|
|
describe('Testing merging icon data', () => {
|
2022-06-20 23:43:01 +03:00
|
|
|
test('Nothing to merge', () => {
|
2021-05-24 13:25:02 +03:00
|
|
|
const icon: IconifyIcon = {
|
|
|
|
body: '<g />',
|
|
|
|
};
|
|
|
|
const expected: IconifyIcon = {
|
|
|
|
body: '<g />',
|
|
|
|
};
|
|
|
|
// Check hint manually: supposed to be IconifyIcon
|
|
|
|
const result = mergeIconData(icon, {});
|
2021-09-20 23:53:49 +03:00
|
|
|
expect(result).toEqual(expected);
|
2022-06-20 23:43:01 +03:00
|
|
|
});
|
2021-05-24 13:25:02 +03:00
|
|
|
|
2022-06-20 23:43:01 +03:00
|
|
|
test('Full icons', () => {
|
|
|
|
const icon: Required<IconifyIcon> = {
|
2021-05-24 13:25:02 +03:00
|
|
|
body: '<g />',
|
|
|
|
width: 24,
|
|
|
|
height: 24,
|
|
|
|
left: 0,
|
|
|
|
top: 0,
|
|
|
|
rotate: 0,
|
|
|
|
hFlip: false,
|
|
|
|
vFlip: false,
|
|
|
|
};
|
2022-06-20 23:43:01 +03:00
|
|
|
const expected: Required<IconifyIcon> = {
|
2021-05-24 13:25:02 +03:00
|
|
|
body: '<g />',
|
|
|
|
width: 24,
|
|
|
|
height: 24,
|
|
|
|
left: 0,
|
|
|
|
top: 0,
|
|
|
|
rotate: 0,
|
|
|
|
hFlip: false,
|
|
|
|
vFlip: false,
|
|
|
|
};
|
|
|
|
// Check hint manually: supposed to be Required<IconifyIcon>
|
2022-06-20 23:43:01 +03:00
|
|
|
const result = mergeIconData(icon, {});
|
|
|
|
expect(result).toEqual(expected);
|
|
|
|
});
|
2021-05-24 13:25:02 +03:00
|
|
|
|
2022-06-20 23:43:01 +03:00
|
|
|
test('Copy values', () => {
|
2021-05-24 13:25:02 +03:00
|
|
|
// Copy values
|
|
|
|
expect(
|
|
|
|
mergeIconData(
|
|
|
|
{
|
|
|
|
body: '<g />',
|
|
|
|
width: 24,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
height: 32,
|
|
|
|
}
|
|
|
|
)
|
2021-09-20 23:53:49 +03:00
|
|
|
).toEqual({
|
2021-05-24 13:25:02 +03:00
|
|
|
body: '<g />',
|
|
|
|
width: 24,
|
|
|
|
height: 32,
|
|
|
|
});
|
2022-06-20 23:43:01 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
test('Override values', () => {
|
|
|
|
expect(
|
|
|
|
mergeIconData(
|
|
|
|
{
|
|
|
|
body: '<g />',
|
|
|
|
width: 24,
|
|
|
|
height: 24,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
height: 32,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
).toEqual({
|
|
|
|
body: '<g />',
|
|
|
|
width: 24,
|
|
|
|
height: 32,
|
|
|
|
});
|
|
|
|
});
|
2021-05-24 13:25:02 +03:00
|
|
|
|
2022-06-20 23:43:01 +03:00
|
|
|
test('Override transformations', () => {
|
2021-05-24 13:25:02 +03:00
|
|
|
expect(
|
|
|
|
mergeIconData(
|
|
|
|
{
|
|
|
|
body: '<g />',
|
|
|
|
width: 24,
|
|
|
|
height: 24,
|
2022-06-20 23:43:01 +03:00
|
|
|
hFlip: true,
|
|
|
|
rotate: 3,
|
2021-05-24 13:25:02 +03:00
|
|
|
},
|
|
|
|
{
|
|
|
|
height: 32,
|
2022-06-20 23:43:01 +03:00
|
|
|
vFlip: true,
|
|
|
|
rotate: 2,
|
2021-05-24 13:25:02 +03:00
|
|
|
}
|
|
|
|
)
|
2021-09-20 23:53:49 +03:00
|
|
|
).toEqual({
|
2021-05-24 13:25:02 +03:00
|
|
|
body: '<g />',
|
|
|
|
width: 24,
|
|
|
|
height: 32,
|
2022-06-20 23:43:01 +03:00
|
|
|
hFlip: true,
|
|
|
|
vFlip: true,
|
|
|
|
rotate: 1,
|
2021-05-24 13:25:02 +03:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|