( length: string | number, baseFontSize: number, baseLength: number, inheritedStyle: Record<string, string | number>, percentage = false )
| 63 | } |
| 64 | |
| 65 | export function lengthToNumber( |
| 66 | length: string | number, |
| 67 | baseFontSize: number, |
| 68 | baseLength: number, |
| 69 | inheritedStyle: Record<string, string | number>, |
| 70 | percentage = false |
| 71 | ): number | undefined { |
| 72 | if (typeof length === 'number') return length |
| 73 | |
| 74 | // Convert em and rem values to number (px), convert rad to deg. |
| 75 | try { |
| 76 | length = length.trim() |
| 77 | |
| 78 | // Not length: `1px/2px`, `1px 2px`, `1px, 2px`, `calc(1px)`. |
| 79 | if (/[ /\(,]/.test(length)) return |
| 80 | |
| 81 | // Just a number as string: '100' |
| 82 | if (length === String(+length)) return +length |
| 83 | |
| 84 | const parsed = new CssDimension(length) |
| 85 | if (parsed.type === 'length') { |
| 86 | switch (parsed.unit) { |
| 87 | case 'em': |
| 88 | return parsed.value * baseFontSize |
| 89 | case 'rem': |
| 90 | return parsed.value * 16 |
| 91 | case 'vw': |
| 92 | return ~~( |
| 93 | (parsed.value * (inheritedStyle._viewportWidth as number)) / |
| 94 | 100 |
| 95 | ) |
| 96 | case 'vh': |
| 97 | return ~~( |
| 98 | (parsed.value * (inheritedStyle._viewportHeight as number)) / |
| 99 | 100 |
| 100 | ) |
| 101 | default: |
| 102 | return parsed.value |
| 103 | } |
| 104 | } else if (parsed.type === 'angle') { |
| 105 | return calcDegree(length) |
| 106 | } else if (parsed.type === 'percentage') { |
| 107 | if (percentage) { |
| 108 | return (parsed.value / 100) * baseLength |
| 109 | } |
| 110 | } |
| 111 | } catch { |
| 112 | // Not a length unit, silently ignore. |
| 113 | } |
| 114 | } |
| 115 | |
| 116 | export function calcDegree(deg: string) { |
| 117 | const parsed = new CssDimension(deg) |
no test coverage detected
searching dependent graphs…