2
0
mirror of https://github.com/iconify/iconify.git synced 2025-01-23 15:18:38 +00:00

Simplify code to calculate dimensions in Utils

This commit is contained in:
Vjacheslav Trushkin 2022-05-20 23:32:47 +03:00
parent 49f4f67e44
commit 4f38f14ad5

View File

@ -133,7 +133,7 @@ export function iconToSVG(
if (rotation % 2 === 1) { if (rotation % 2 === 1) {
// Swap width/height and x/y for 90deg or 270deg rotation // Swap width/height and x/y for 90deg or 270deg rotation
if (box.left !== 0 || box.top !== 0) { if (box.left !== box.top) {
tempValue = box.left; tempValue = box.left;
box.left = box.top; box.left = box.top;
box.top = tempValue; box.top = tempValue;
@ -156,40 +156,35 @@ export function iconToSVG(
}); });
// Calculate dimensions // Calculate dimensions
let width, height; const customisationsWidth = customisations.width;
const customisationsHeight = customisations.height;
const boxWidth = box.width;
const boxHeight = box.height;
if (customisations.width === null && customisations.height === null) { let width, height;
// Set height to '1em', calculate width if (customisationsWidth === null) {
height = '1em'; // Width is not set: calculate width from height, default to '1em'
width = calculateSize(height, box.width / box.height); height =
} else if ( customisationsHeight === null
customisations.width !== null && ? '1em'
customisations.height !== null : customisationsHeight === 'auto'
) { ? boxHeight
// Values are set : customisationsHeight;
width = customisations.width; width = calculateSize(height, boxWidth / boxHeight);
height = customisations.height;
} else if (customisations.height !== null) {
// Height is set
height = customisations.height;
width = calculateSize(height, box.width / box.height);
} else { } else {
// Width is set // Width is set
width = customisations.width as number | string; width = customisationsWidth === 'auto' ? boxWidth : customisationsWidth;
height = calculateSize(width, box.height / box.width); height =
} customisationsHeight === null
? calculateSize(width, boxHeight / boxWidth)
// Check for 'auto' : customisationsHeight === 'auto'
if (width === 'auto') { ? boxHeight
width = box.width; : customisationsHeight;
}
if (height === 'auto') {
height = box.height;
} }
// Convert to string // Convert to string
width = typeof width === 'string' ? width : width.toString() + ''; width = typeof width === 'string' ? width : width.toString();
height = typeof height === 'string' ? height : height.toString() + ''; height = typeof height === 'string' ? height : height.toString();
// Result // Result
const result: IconifyIconBuildResult = { const result: IconifyIconBuildResult = {
@ -201,9 +196,9 @@ export function iconToSVG(
' ' + ' ' +
box.top.toString() + box.top.toString() +
' ' + ' ' +
box.width.toString() + boxWidth.toString() +
' ' + ' ' +
box.height.toString(), boxHeight.toString(),
}, },
body, body,
}; };