@ls-stack/utils 1.7.0 → 1.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,11 @@
1
1
  type Interval = [number, number];
2
2
  declare function cyclicLerp(input: number, [inStart, inEnd]: Interval, [outStart, outEnd]: Interval): number;
3
- declare function interpolate(input: number, inputRange: number[], outputRange: number[], clamp?: boolean | 'start' | 'end'): number;
3
+ type InterpolateArgs = {
4
+ input: number;
5
+ in: number[];
6
+ out: number[];
7
+ clamp?: boolean | 'start' | 'end';
8
+ };
9
+ declare function interpolate({ input, in: inputRange, out, clamp, }: InterpolateArgs): number;
4
10
 
5
11
  export { cyclicLerp, interpolate };
@@ -21,16 +21,21 @@ function findRange(input, inputRange) {
21
21
  }
22
22
  return inputRange.length - 2;
23
23
  }
24
- function interpolate(input, inputRange, outputRange, clamp = true) {
24
+ function interpolate({
25
+ input,
26
+ in: inputRange,
27
+ out,
28
+ clamp = true
29
+ }) {
25
30
  invariant(
26
- inputRange.length === outputRange.length,
31
+ inputRange.length === out.length,
27
32
  "Ranges must have the same length"
28
33
  );
29
34
  const range = findRange(input, inputRange);
30
35
  const inStart = inputRange[range];
31
36
  const inEnd = inputRange[range + 1];
32
- const outStart = outputRange[range];
33
- const outEnd = outputRange[range + 1];
37
+ const outStart = out[range];
38
+ const outEnd = out[range + 1];
34
39
  const interpolatedValue = (input - inStart) / (inEnd - inStart) * (outEnd - outStart) + outStart;
35
40
  const outputIsAscending = outStart < outEnd;
36
41
  return clamp === "start" ? outputIsAscending ? clampMin(interpolatedValue, outStart) : clampMax(interpolatedValue, outStart) : clamp === "end" ? outputIsAscending ? clampMax(interpolatedValue, outEnd) : clampMin(interpolatedValue, outEnd) : clamp ? clampRange(interpolatedValue, outStart, outEnd) : interpolatedValue;
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/interpolate.ts"],"sourcesContent":["import { invariant } from './assertions';\nimport { clampMax, clampMin, clampRange } from './mathUtils';\n\ntype Interval = [number, number];\n\nfunction mod(n: number, m: number) {\n return ((n % m) + m) % m;\n}\n\nexport function cyclicLerp(\n input: number,\n [inStart, inEnd]: Interval,\n [outStart, outEnd]: Interval,\n) {\n return (\n mod((input - inStart) / (inEnd - inStart), 1) * (outEnd - outStart) +\n outStart\n );\n}\n\nfunction findRange(input: number, inputRange: number[]) {\n for (let i = 1; i < inputRange.length - 1; i++) {\n if (inputRange[i]! >= input) return i - 1;\n }\n\n return inputRange.length - 2;\n}\n\nexport function interpolate(\n input: number,\n inputRange: number[],\n outputRange: number[],\n clamp: boolean | 'start' | 'end' = true,\n) {\n invariant(\n inputRange.length === outputRange.length,\n 'Ranges must have the same length',\n );\n\n const range = findRange(input, inputRange);\n const inStart = inputRange[range]!;\n const inEnd = inputRange[range + 1]!;\n const outStart = outputRange[range]!;\n const outEnd = outputRange[range + 1]!;\n\n const interpolatedValue =\n ((input - inStart) / (inEnd - inStart)) * (outEnd - outStart) + outStart;\n\n const outputIsAscending = outStart < outEnd;\n\n return (\n clamp === 'start' ?\n outputIsAscending ? clampMin(interpolatedValue, outStart)\n : clampMax(interpolatedValue, outStart)\n : clamp === 'end' ?\n outputIsAscending ? clampMax(interpolatedValue, outEnd)\n : clampMin(interpolatedValue, outEnd)\n : clamp ? clampRange(interpolatedValue, outStart, outEnd)\n : interpolatedValue\n );\n}\n"],"mappings":";;;;;;;;;;AAKA,SAAS,IAAI,GAAW,GAAW;AACjC,UAAS,IAAI,IAAK,KAAK;AACzB;AAEO,SAAS,WACd,OACA,CAAC,SAAS,KAAK,GACf,CAAC,UAAU,MAAM,GACjB;AACA,SACE,KAAK,QAAQ,YAAY,QAAQ,UAAU,CAAC,KAAK,SAAS,YAC1D;AAEJ;AAEA,SAAS,UAAU,OAAe,YAAsB;AACtD,WAAS,IAAI,GAAG,IAAI,WAAW,SAAS,GAAG,KAAK;AAC9C,QAAI,WAAW,CAAC,KAAM;AAAO,aAAO,IAAI;AAAA,EAC1C;AAEA,SAAO,WAAW,SAAS;AAC7B;AAEO,SAAS,YACd,OACA,YACA,aACA,QAAmC,MACnC;AACA;AAAA,IACE,WAAW,WAAW,YAAY;AAAA,IAClC;AAAA,EACF;AAEA,QAAM,QAAQ,UAAU,OAAO,UAAU;AACzC,QAAM,UAAU,WAAW,KAAK;AAChC,QAAM,QAAQ,WAAW,QAAQ,CAAC;AAClC,QAAM,WAAW,YAAY,KAAK;AAClC,QAAM,SAAS,YAAY,QAAQ,CAAC;AAEpC,QAAM,qBACF,QAAQ,YAAY,QAAQ,YAAa,SAAS,YAAY;AAElE,QAAM,oBAAoB,WAAW;AAErC,SACE,UAAU,UACR,oBAAoB,SAAS,mBAAmB,QAAQ,IACtD,SAAS,mBAAmB,QAAQ,IACtC,UAAU,QACV,oBAAoB,SAAS,mBAAmB,MAAM,IACpD,SAAS,mBAAmB,MAAM,IACpC,QAAQ,WAAW,mBAAmB,UAAU,MAAM,IACtD;AAEN;","names":[]}
1
+ {"version":3,"sources":["../src/interpolate.ts"],"sourcesContent":["import { invariant } from './assertions';\nimport { clampMax, clampMin, clampRange } from './mathUtils';\n\ntype Interval = [number, number];\n\nfunction mod(n: number, m: number) {\n return ((n % m) + m) % m;\n}\n\nexport function cyclicLerp(\n input: number,\n [inStart, inEnd]: Interval,\n [outStart, outEnd]: Interval,\n) {\n return (\n mod((input - inStart) / (inEnd - inStart), 1) * (outEnd - outStart) +\n outStart\n );\n}\n\nfunction findRange(input: number, inputRange: number[]) {\n for (let i = 1; i < inputRange.length - 1; i++) {\n if (inputRange[i]! >= input) return i - 1;\n }\n\n return inputRange.length - 2;\n}\n\ntype InterpolateArgs = {\n input: number;\n in: number[];\n out: number[];\n clamp?: boolean | 'start' | 'end';\n};\n\nexport function interpolate({\n input,\n in: inputRange,\n out,\n clamp = true,\n}: InterpolateArgs): number {\n invariant(\n inputRange.length === out.length,\n 'Ranges must have the same length',\n );\n\n const range = findRange(input, inputRange);\n const inStart = inputRange[range]!;\n const inEnd = inputRange[range + 1]!;\n const outStart = out[range]!;\n const outEnd = out[range + 1]!;\n\n const interpolatedValue =\n ((input - inStart) / (inEnd - inStart)) * (outEnd - outStart) + outStart;\n\n const outputIsAscending = outStart < outEnd;\n\n return (\n clamp === 'start' ?\n outputIsAscending ? clampMin(interpolatedValue, outStart)\n : clampMax(interpolatedValue, outStart)\n : clamp === 'end' ?\n outputIsAscending ? clampMax(interpolatedValue, outEnd)\n : clampMin(interpolatedValue, outEnd)\n : clamp ? clampRange(interpolatedValue, outStart, outEnd)\n : interpolatedValue\n );\n}\n"],"mappings":";;;;;;;;;;AAKA,SAAS,IAAI,GAAW,GAAW;AACjC,UAAS,IAAI,IAAK,KAAK;AACzB;AAEO,SAAS,WACd,OACA,CAAC,SAAS,KAAK,GACf,CAAC,UAAU,MAAM,GACjB;AACA,SACE,KAAK,QAAQ,YAAY,QAAQ,UAAU,CAAC,KAAK,SAAS,YAC1D;AAEJ;AAEA,SAAS,UAAU,OAAe,YAAsB;AACtD,WAAS,IAAI,GAAG,IAAI,WAAW,SAAS,GAAG,KAAK;AAC9C,QAAI,WAAW,CAAC,KAAM;AAAO,aAAO,IAAI;AAAA,EAC1C;AAEA,SAAO,WAAW,SAAS;AAC7B;AASO,SAAS,YAAY;AAAA,EAC1B;AAAA,EACA,IAAI;AAAA,EACJ;AAAA,EACA,QAAQ;AACV,GAA4B;AAC1B;AAAA,IACE,WAAW,WAAW,IAAI;AAAA,IAC1B;AAAA,EACF;AAEA,QAAM,QAAQ,UAAU,OAAO,UAAU;AACzC,QAAM,UAAU,WAAW,KAAK;AAChC,QAAM,QAAQ,WAAW,QAAQ,CAAC;AAClC,QAAM,WAAW,IAAI,KAAK;AAC1B,QAAM,SAAS,IAAI,QAAQ,CAAC;AAE5B,QAAM,qBACF,QAAQ,YAAY,QAAQ,YAAa,SAAS,YAAY;AAElE,QAAM,oBAAoB,WAAW;AAErC,SACE,UAAU,UACR,oBAAoB,SAAS,mBAAmB,QAAQ,IACtD,SAAS,mBAAmB,QAAQ,IACtC,UAAU,QACV,oBAAoB,SAAS,mBAAmB,MAAM,IACpD,SAAS,mBAAmB,MAAM,IACpC,QAAQ,WAAW,mBAAmB,UAAU,MAAM,IACtD;AAEN;","names":[]}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@ls-stack/utils",
3
3
  "description": "Typescript utils",
4
- "version": "1.7.0",
4
+ "version": "1.8.0",
5
5
  "license": "MIT",
6
6
  "files": [
7
7
  "dist"