function $parcel$export(e, n, v, s) { Object.defineProperty(e, n, {get: v, set: s, enumerable: true, configurable: true}); } $parcel$export(module.exports, "clamp", () => $ac8e4d4816275668$export$7d15b64cf5a3a4c4); $parcel$export(module.exports, "snapValueToStep", () => $ac8e4d4816275668$export$cb6e0bb50bc19463); $parcel$export(module.exports, "toFixedNumber", () => $ac8e4d4816275668$export$b6268554fba451f); /* * Copyright 2020 Adobe. All rights reserved. * This file is licensed to you under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. You may obtain a copy * of the License at http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software distributed under * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS * OF ANY KIND, either express or implied. See the License for the specific language * governing permissions and limitations under the License. */ /** * Takes a value and forces it to the closest min/max if it's outside. Also forces it to the closest valid step. */ function $ac8e4d4816275668$export$7d15b64cf5a3a4c4(value, min = -Infinity, max = Infinity) { let newValue = Math.min(Math.max(value, min), max); return newValue; } function $ac8e4d4816275668$export$e1a7b8e69ef6c52f(value, step) { let roundedValue = value; let precision = 0; let stepString = step.toString(); // Handle negative exponents in exponential notation (e.g., "1e-7" → precision 8) let eIndex = stepString.toLowerCase().indexOf('e-'); if (eIndex > 0) precision = Math.abs(Math.floor(Math.log10(Math.abs(step)))) + eIndex; else { let pointIndex = stepString.indexOf('.'); if (pointIndex >= 0) precision = stepString.length - pointIndex; } if (precision > 0) { let pow = Math.pow(10, precision); roundedValue = Math.round(roundedValue * pow) / pow; } return roundedValue; } function $ac8e4d4816275668$export$cb6e0bb50bc19463(value, min, max, step) { min = Number(min); max = Number(max); let remainder = (value - (isNaN(min) ? 0 : min)) % step; let snappedValue = $ac8e4d4816275668$export$e1a7b8e69ef6c52f(Math.abs(remainder) * 2 >= step ? value + Math.sign(remainder) * (step - Math.abs(remainder)) : value - remainder, step); if (!isNaN(min)) { if (snappedValue < min) snappedValue = min; else if (!isNaN(max) && snappedValue > max) snappedValue = min + Math.floor($ac8e4d4816275668$export$e1a7b8e69ef6c52f((max - min) / step, step)) * step; } else if (!isNaN(max) && snappedValue > max) snappedValue = Math.floor($ac8e4d4816275668$export$e1a7b8e69ef6c52f(max / step, step)) * step; // correct floating point behavior by rounding to step precision snappedValue = $ac8e4d4816275668$export$e1a7b8e69ef6c52f(snappedValue, step); return snappedValue; } function $ac8e4d4816275668$export$b6268554fba451f(value, digits, base = 10) { const pow = Math.pow(base, digits); return Math.round(value * pow) / pow; } //# sourceMappingURL=number.main.js.map