@nemigo/helpers 0.12.1 → 0.13.1

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.
package/dist/html.d.ts CHANGED
@@ -67,7 +67,7 @@ export type MouseBoardEvent = MouseEvent | TargetKeyboardEvent;
67
67
  *
68
68
  * @param call Коллбэк, принимающий позицию и метаданные о событии
69
69
  */
70
- export declare const ctxMenuHook: <N extends HTMLElement = HTMLDivElement>(call: (position: {
70
+ export declare const createCtxMenuHandler: <N extends HTMLElement = HTMLDivElement>(call: (position: {
71
71
  left: number;
72
72
  top: number;
73
73
  }, meta: {
@@ -78,8 +78,8 @@ export declare const ctxMenuHook: <N extends HTMLElement = HTMLDivElement>(call:
78
78
  event: MouseEvent;
79
79
  }) => void) => (e: MouseEvent | TargetKeyboardEvent<N>) => void;
80
80
  export declare const createClickHandlers: (singleClickHandler: (e: MouseEvent) => void, doubleClickHandler: (e: MouseEvent) => void, delay?: Timestamp) => {
81
- click: (e: MouseEvent) => void;
82
- dblclick: (e: MouseEvent) => void;
81
+ onclick: (e: MouseEvent) => void;
82
+ ondblclick: (e: MouseEvent) => void;
83
83
  };
84
84
  /**
85
85
  * Создаёт слушатель события на указанном элементе.
package/dist/html.js CHANGED
@@ -74,7 +74,7 @@ export const isKeyboardEvent = (e) => !!e.code;
74
74
  *
75
75
  * @param call Коллбэк, принимающий позицию и метаданные о событии
76
76
  */
77
- export const ctxMenuHook = (call) => preventStopHook((event) => {
77
+ export const createCtxMenuHandler = (call) => preventStopHook((event) => {
78
78
  if (isKeyboardEvent(event)) {
79
79
  const { x, y } = event.currentTarget.getBoundingClientRect();
80
80
  call({ left: x, top: y }, { isKeyboardEvent: true, event });
@@ -84,10 +84,10 @@ export const ctxMenuHook = (call) => preventStopHook((event) => {
84
84
  }
85
85
  });
86
86
  //...
87
- export const createClickHandlers = (singleClickHandler, doubleClickHandler, delay = 200) => {
87
+ export const createClickHandlers = (singleClickHandler, doubleClickHandler, delay = 75) => {
88
88
  let clickTimer = 0;
89
89
  let isDoubleClick = false;
90
- const click = (e) => {
90
+ const onclick = (e) => {
91
91
  e.preventDefault();
92
92
  if (clickTimer)
93
93
  return;
@@ -99,7 +99,7 @@ export const createClickHandlers = (singleClickHandler, doubleClickHandler, dela
99
99
  isDoubleClick = false;
100
100
  }, delay);
101
101
  };
102
- const dblclick = (e) => {
102
+ const ondblclick = (e) => {
103
103
  e.preventDefault();
104
104
  isDoubleClick = true;
105
105
  if (clickTimer) {
@@ -108,7 +108,7 @@ export const createClickHandlers = (singleClickHandler, doubleClickHandler, dela
108
108
  }
109
109
  doubleClickHandler(e);
110
110
  };
111
- return { click, dblclick };
111
+ return { onclick, ondblclick };
112
112
  };
113
113
  //...
114
114
  /**
@@ -43,13 +43,14 @@ export declare const mult: (...args: number[]) => number;
43
43
  * @returns {number} Значение, ограниченное диапазоном [min, max]
44
44
  */
45
45
  export declare const clamp: (v: number, min: number, max: number) => number;
46
+ export declare const toRadians: (deg: number) => number;
46
47
  /**
47
48
  * Линейная интерполяция между двумя числами
48
49
  *
49
- * @param {number} s - Начальное значение
50
- * @param {number} e - Конечное значение
50
+ * @param {number} a - Начальное значение
51
+ * @param {number} b - Конечное значение
51
52
  * @param {number} t - Весовой коэффициент, определяющий пропорцию между начальным и конечным значениями. Значение должно быть в диапазоне [0, 1]
52
53
  *
53
- * @returns {number} Результат линейной интерполяции между s и e при коэффициенте t
54
+ * @returns {number} Результат линейной интерполяции между a и b при коэффициенте t
54
55
  */
55
- export declare const lerp: (s: number, e: number, t: number) => number;
56
+ export declare const lerp: (a: number, b: number, t: number) => number;
@@ -49,13 +49,14 @@ export const mult = (...args) => toRound(args.reduce((acc, v) => acc * v, 1));
49
49
  */
50
50
  export const clamp = (v, min, max) => Math.max(Math.min(v, max), min);
51
51
  //...
52
+ export const toRadians = (deg) => (deg * Math.PI) / 180;
52
53
  /**
53
54
  * Линейная интерполяция между двумя числами
54
55
  *
55
- * @param {number} s - Начальное значение
56
- * @param {number} e - Конечное значение
56
+ * @param {number} a - Начальное значение
57
+ * @param {number} b - Конечное значение
57
58
  * @param {number} t - Весовой коэффициент, определяющий пропорцию между начальным и конечным значениями. Значение должно быть в диапазоне [0, 1]
58
59
  *
59
- * @returns {number} Результат линейной интерполяции между s и e при коэффициенте t
60
+ * @returns {number} Результат линейной интерполяции между a и b при коэффициенте t
60
61
  */
61
- export const lerp = (s, e, t) => s * (1 - t) + e * t;
62
+ export const lerp = (a, b, t) => a + (b - a) * t;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nemigo/helpers",
3
- "version": "0.12.1",
3
+ "version": "0.13.1",
4
4
  "private": false,
5
5
  "author": {
6
6
  "name": "Vlad Logvin",