@onepercentio/one-ui 0.27.7 → 0.28.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.
@@ -0,0 +1,6 @@
1
+ import { ComponentProps } from "react";
2
+ import Input from "../Input";
3
+ export default function CurrencyInput({ value: amount, currency, onChange, placeholder, error, ...props }: Omit<ComponentProps<typeof Input>, 'onChange'> & {
4
+ currency: string;
5
+ onChange?: (formatted: string) => void;
6
+ }): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,6 @@
1
+ /// <reference types="react" />
2
+ export declare function useCurrencyInput(amount: string | undefined, currency: string, onChange?: (formattedCurrency: string) => void): {
3
+ inputRef: import("react").RefObject<HTMLInputElement | null>;
4
+ moneyFormat: string;
5
+ lastPosition: import("react").RefObject<number>;
6
+ };
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.useCurrencyInput = useCurrencyInput;
7
+ var _react = require("react");
8
+ var _formatters = require("../../utils/formatters");
9
+ function useCurrencyInput(amount, currency, onChange) {
10
+ const formatter = (0, _react.useMemo)(() => (0, _formatters.currencyFormatterFactory)(currency), []);
11
+ const number = (0, _react.useMemo)(() => Number((amount === null || amount === void 0 ? void 0 : amount.replace(/[^0-9]/g, "")) || 0) / 100, [amount]);
12
+ const moneyFormat = (0, _react.useMemo)(() => {
13
+ return formatter.format(number);
14
+ }, [number, formatter]);
15
+ const lastPosition = (0, _react.useRef)(0);
16
+ const inputRef = (0, _react.useRef)(null);
17
+ (0, _react.useLayoutEffect)(() => {
18
+ const el = inputRef.current;
19
+ const putCaretOn = el.value.length - lastPosition.current;
20
+ el.setSelectionRange(putCaretOn, putCaretOn);
21
+ onChange === null || onChange === void 0 ? void 0 : onChange(moneyFormat);
22
+ }, [moneyFormat]);
23
+ return {
24
+ inputRef,
25
+ moneyFormat,
26
+ lastPosition
27
+ };
28
+ }
29
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJyZXF1aXJlIiwiX2Zvcm1hdHRlcnMiLCJ1c2VDdXJyZW5jeUlucHV0IiwiYW1vdW50IiwiY3VycmVuY3kiLCJvbkNoYW5nZSIsImZvcm1hdHRlciIsInVzZU1lbW8iLCJjdXJyZW5jeUZvcm1hdHRlckZhY3RvcnkiLCJudW1iZXIiLCJOdW1iZXIiLCJyZXBsYWNlIiwibW9uZXlGb3JtYXQiLCJmb3JtYXQiLCJsYXN0UG9zaXRpb24iLCJ1c2VSZWYiLCJpbnB1dFJlZiIsInVzZUxheW91dEVmZmVjdCIsImVsIiwiY3VycmVudCIsInB1dENhcmV0T24iLCJ2YWx1ZSIsImxlbmd0aCIsInNldFNlbGVjdGlvblJhbmdlIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvQ3VycmVuY3lJbnB1dC9DdXJyZW5jeUlucHV0Lmhvb2sudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlTGF5b3V0RWZmZWN0LCB1c2VNZW1vLCB1c2VSZWYgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7IGN1cnJlbmN5Rm9ybWF0dGVyRmFjdG9yeSB9IGZyb20gXCIuLi8uLi91dGlscy9mb3JtYXR0ZXJzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VDdXJyZW5jeUlucHV0KFxuICBhbW91bnQ6IHN0cmluZyB8IHVuZGVmaW5lZCxcbiAgY3VycmVuY3k6IHN0cmluZyxcbiAgb25DaGFuZ2U/OiAoZm9ybWF0dGVkQ3VycmVuY3k6IHN0cmluZykgPT4gdm9pZFxuKSB7XG4gIGNvbnN0IGZvcm1hdHRlciA9IHVzZU1lbW8oKCkgPT4gY3VycmVuY3lGb3JtYXR0ZXJGYWN0b3J5KGN1cnJlbmN5KSwgW10pO1xuICBjb25zdCBudW1iZXIgPSB1c2VNZW1vKFxuICAgICgpID0+IE51bWJlcihhbW91bnQ/LnJlcGxhY2UoL1teMC05XS9nLCBcIlwiKSB8fCAwKSAvIDEwMCxcbiAgICBbYW1vdW50XVxuICApO1xuICBjb25zdCBtb25leUZvcm1hdCA9IHVzZU1lbW8oKCkgPT4ge1xuICAgIHJldHVybiBmb3JtYXR0ZXIuZm9ybWF0KG51bWJlcik7XG4gIH0sIFtudW1iZXIsIGZvcm1hdHRlcl0pO1xuXG4gIGNvbnN0IGxhc3RQb3NpdGlvbiA9IHVzZVJlZigwKTtcbiAgY29uc3QgaW5wdXRSZWYgPSB1c2VSZWY8SFRNTElucHV0RWxlbWVudD4obnVsbCk7XG4gIHVzZUxheW91dEVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgZWwgPSBpbnB1dFJlZi5jdXJyZW50ITtcbiAgICBjb25zdCBwdXRDYXJldE9uID0gZWwudmFsdWUubGVuZ3RoIC0gbGFzdFBvc2l0aW9uLmN1cnJlbnQ7XG4gICAgZWwuc2V0U2VsZWN0aW9uUmFuZ2UocHV0Q2FyZXRPbiwgcHV0Q2FyZXRPbik7XG5cbiAgICBvbkNoYW5nZT8uKG1vbmV5Rm9ybWF0KTtcbiAgfSwgW21vbmV5Rm9ybWF0XSk7XG5cbiAgcmV0dXJuIHtcbiAgICBpbnB1dFJlZixcbiAgICBtb25leUZvcm1hdCxcbiAgICBsYXN0UG9zaXRpb24sXG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsT0FBQTtBQUNBLElBQUFDLFdBQUEsR0FBQUQsT0FBQTtBQUVPLFNBQVNFLGdCQUFnQkEsQ0FDOUJDLE1BQTBCLEVBQzFCQyxRQUFnQixFQUNoQkMsUUFBOEMsRUFDOUM7RUFDQSxNQUFNQyxTQUFTLEdBQUcsSUFBQUMsY0FBTyxFQUFDLE1BQU0sSUFBQUMsb0NBQXdCLEVBQUNKLFFBQVEsQ0FBQyxFQUFFLEVBQUUsQ0FBQztFQUN2RSxNQUFNSyxNQUFNLEdBQUcsSUFBQUYsY0FBTyxFQUNwQixNQUFNRyxNQUFNLENBQUMsQ0FBQVAsTUFBTSxhQUFOQSxNQUFNLHVCQUFOQSxNQUFNLENBQUVRLE9BQU8sQ0FBQyxTQUFTLEVBQUUsRUFBRSxDQUFDLEtBQUksQ0FBQyxDQUFDLEdBQUcsR0FBRyxFQUN2RCxDQUFDUixNQUFNLENBQ1QsQ0FBQztFQUNELE1BQU1TLFdBQVcsR0FBRyxJQUFBTCxjQUFPLEVBQUMsTUFBTTtJQUNoQyxPQUFPRCxTQUFTLENBQUNPLE1BQU0sQ0FBQ0osTUFBTSxDQUFDO0VBQ2pDLENBQUMsRUFBRSxDQUFDQSxNQUFNLEVBQUVILFNBQVMsQ0FBQyxDQUFDO0VBRXZCLE1BQU1RLFlBQVksR0FBRyxJQUFBQyxhQUFNLEVBQUMsQ0FBQyxDQUFDO0VBQzlCLE1BQU1DLFFBQVEsR0FBRyxJQUFBRCxhQUFNLEVBQW1CLElBQUksQ0FBQztFQUMvQyxJQUFBRSxzQkFBZSxFQUFDLE1BQU07SUFDcEIsTUFBTUMsRUFBRSxHQUFHRixRQUFRLENBQUNHLE9BQVE7SUFDNUIsTUFBTUMsVUFBVSxHQUFHRixFQUFFLENBQUNHLEtBQUssQ0FBQ0MsTUFBTSxHQUFHUixZQUFZLENBQUNLLE9BQU87SUFDekRELEVBQUUsQ0FBQ0ssaUJBQWlCLENBQUNILFVBQVUsRUFBRUEsVUFBVSxDQUFDO0lBRTVDZixRQUFRLGFBQVJBLFFBQVEsdUJBQVJBLFFBQVEsQ0FBR08sV0FBVyxDQUFDO0VBQ3pCLENBQUMsRUFBRSxDQUFDQSxXQUFXLENBQUMsQ0FBQztFQUVqQixPQUFPO0lBQ0xJLFFBQVE7SUFDUkosV0FBVztJQUNYRTtFQUNGLENBQUM7QUFDSCJ9
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = CurrencyInput;
7
+ var _Input = _interopRequireDefault(require("../Input"));
8
+ var _CurrencyInput = require("./CurrencyInput.hook");
9
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
10
+ function CurrencyInput(_ref) {
11
+ let {
12
+ value: amount,
13
+ currency,
14
+ onChange,
15
+ placeholder,
16
+ error,
17
+ ...props
18
+ } = _ref;
19
+ const {
20
+ inputRef,
21
+ moneyFormat,
22
+ lastPosition
23
+ } = (0, _CurrencyInput.useCurrencyInput)(amount, currency, onChange);
24
+ return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(_Input.default, {
25
+ ref: inputRef,
26
+ placeholder: placeholder,
27
+ value: moneyFormat,
28
+ error: error,
29
+ onChange: _ref2 => {
30
+ let {
31
+ target: {
32
+ value,
33
+ selectionStart = value.length
34
+ }
35
+ } = _ref2;
36
+ const diffFromEndToStart = value.length - selectionStart;
37
+ lastPosition.current = diffFromEndToStart;
38
+ onChange === null || onChange === void 0 ? void 0 : onChange(value);
39
+ }
40
+ }));
41
+ }
42
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfSW5wdXQiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9DdXJyZW5jeUlucHV0Iiwib2JqIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJDdXJyZW5jeUlucHV0IiwiX3JlZiIsInZhbHVlIiwiYW1vdW50IiwiY3VycmVuY3kiLCJvbkNoYW5nZSIsInBsYWNlaG9sZGVyIiwiZXJyb3IiLCJwcm9wcyIsImlucHV0UmVmIiwibW9uZXlGb3JtYXQiLCJsYXN0UG9zaXRpb24iLCJ1c2VDdXJyZW5jeUlucHV0IiwiUmVhY3QiLCJjcmVhdGVFbGVtZW50IiwiRnJhZ21lbnQiLCJyZWYiLCJfcmVmMiIsInRhcmdldCIsInNlbGVjdGlvblN0YXJ0IiwibGVuZ3RoIiwiZGlmZkZyb21FbmRUb1N0YXJ0IiwiY3VycmVudCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0N1cnJlbmN5SW5wdXQvQ3VycmVuY3lJbnB1dC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50UHJvcHMgfSBmcm9tIFwicmVhY3RcIlxuaW1wb3J0IElucHV0IGZyb20gXCIuLi9JbnB1dFwiXG5pbXBvcnQgeyB1c2VDdXJyZW5jeUlucHV0IH0gZnJvbSBcIi4vQ3VycmVuY3lJbnB1dC5ob29rXCJcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gQ3VycmVuY3lJbnB1dCh7IHZhbHVlOiBhbW91bnQsIGN1cnJlbmN5LCBvbkNoYW5nZSwgcGxhY2Vob2xkZXIsIGVycm9yLCAuLi5wcm9wcyB9OiBPbWl0PENvbXBvbmVudFByb3BzPHR5cGVvZiBJbnB1dD4sICdvbkNoYW5nZSc+ICYgeyBjdXJyZW5jeTogc3RyaW5nLCBvbkNoYW5nZT86IChmb3JtYXR0ZWQ6IHN0cmluZykgPT4gdm9pZCB9KSB7XG4gICAgY29uc3QgeyBpbnB1dFJlZiwgbW9uZXlGb3JtYXQsIGxhc3RQb3NpdGlvbiB9ID0gdXNlQ3VycmVuY3lJbnB1dChhbW91bnQsIGN1cnJlbmN5LCBvbkNoYW5nZSlcbiAgICByZXR1cm4gKFxuICAgICAgICA8PlxuICAgICAgICAgICAgPElucHV0XG4gICAgICAgICAgICAgICAgcmVmPXtpbnB1dFJlZn1cbiAgICAgICAgICAgICAgICBwbGFjZWhvbGRlcj17cGxhY2Vob2xkZXJ9XG4gICAgICAgICAgICAgICAgdmFsdWU9e21vbmV5Rm9ybWF0fVxuICAgICAgICAgICAgICAgIGVycm9yPXtlcnJvciBhcyBzdHJpbmd9XG4gICAgICAgICAgICAgICAgZGF0YS10ZXN0aWQ9e3Byb3BzWydkYXRhLXRlc3RpZCddfVxuICAgICAgICAgICAgICAgIG9uQ2hhbmdlPXsoe1xuICAgICAgICAgICAgICAgICAgICB0YXJnZXQ6IHsgdmFsdWUsIHNlbGVjdGlvblN0YXJ0ID0gdmFsdWUubGVuZ3RoIH0sXG4gICAgICAgICAgICAgICAgfSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBjb25zdCBkaWZmRnJvbUVuZFRvU3RhcnQgPSB2YWx1ZS5sZW5ndGggLSBzZWxlY3Rpb25TdGFydCFcbiAgICAgICAgICAgICAgICAgICAgbGFzdFBvc2l0aW9uLmN1cnJlbnQgPSBkaWZmRnJvbUVuZFRvU3RhcnRcbiAgICAgICAgICAgICAgICAgICAgb25DaGFuZ2U/Lih2YWx1ZSlcbiAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgLz5cbiAgICAgICAgPC8+XG4gICAgKVxufSJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQ0EsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsY0FBQSxHQUFBRCxPQUFBO0FBQXVELFNBQUFELHVCQUFBRyxHQUFBLFdBQUFBLEdBQUEsSUFBQUEsR0FBQSxDQUFBQyxVQUFBLEdBQUFELEdBQUEsS0FBQUUsT0FBQSxFQUFBRixHQUFBO0FBRXhDLFNBQVNHLGFBQWFBLENBQUFDLElBQUEsRUFBcUw7RUFBQSxJQUFwTDtJQUFFQyxLQUFLLEVBQUVDLE1BQU07SUFBRUMsUUFBUTtJQUFFQyxRQUFRO0lBQUVDLFdBQVc7SUFBRUMsS0FBSztJQUFFLEdBQUdDO0VBQXFILENBQUMsR0FBQVAsSUFBQTtFQUNwTixNQUFNO0lBQUVRLFFBQVE7SUFBRUMsV0FBVztJQUFFQztFQUFhLENBQUMsR0FBRyxJQUFBQywrQkFBZ0IsRUFBQ1QsTUFBTSxFQUFFQyxRQUFRLEVBQUVDLFFBQVEsQ0FBQztFQUM1RixvQkFDSVEsS0FBQSxDQUFBQyxhQUFBLENBQUFELEtBQUEsQ0FBQUUsUUFBQSxxQkFDSUYsS0FBQSxDQUFBQyxhQUFBLENBQUNyQixNQUFBLENBQUFNLE9BQUs7SUFDRmlCLEdBQUcsRUFBRVAsUUFBUztJQUNkSCxXQUFXLEVBQUVBLFdBQVk7SUFDekJKLEtBQUssRUFBRVEsV0FBWTtJQUNuQkgsS0FBSyxFQUFFQSxLQUFnQjtJQUV2QkYsUUFBUSxFQUFFWSxLQUFBLElBRUo7TUFBQSxJQUZLO1FBQ1BDLE1BQU0sRUFBRTtVQUFFaEIsS0FBSztVQUFFaUIsY0FBYyxHQUFHakIsS0FBSyxDQUFDa0I7UUFBTztNQUNuRCxDQUFDLEdBQUFILEtBQUE7TUFDRyxNQUFNSSxrQkFBa0IsR0FBR25CLEtBQUssQ0FBQ2tCLE1BQU0sR0FBR0QsY0FBZTtNQUN6RFIsWUFBWSxDQUFDVyxPQUFPLEdBQUdELGtCQUFrQjtNQUN6Q2hCLFFBQVEsYUFBUkEsUUFBUSx1QkFBUkEsUUFBUSxDQUFHSCxLQUFLLENBQUM7SUFDckI7RUFBRSxDQUNMLENBQ0gsQ0FBQztBQUVYIn0=
@@ -0,0 +1 @@
1
+ export { default } from "./CurrencyInput";
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ Object.defineProperty(exports, "default", {
7
+ enumerable: true,
8
+ get: function () {
9
+ return _CurrencyInput.default;
10
+ }
11
+ });
12
+ var _CurrencyInput = _interopRequireDefault(require("./CurrencyInput"));
13
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfQ3VycmVuY3lJbnB1dCIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwib2JqIiwiX19lc01vZHVsZSIsImRlZmF1bHQiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9DdXJyZW5jeUlucHV0L2luZGV4LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBkZWZhdWx0IH0gZnJvbSBcIi4vQ3VycmVuY3lJbnB1dFwiIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBLElBQUFBLGNBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUF5QyxTQUFBRCx1QkFBQUUsR0FBQSxXQUFBQSxHQUFBLElBQUFBLEdBQUEsQ0FBQUMsVUFBQSxHQUFBRCxHQUFBLEtBQUFFLE9BQUEsRUFBQUYsR0FBQSJ9
@@ -17,7 +17,9 @@ declare const EmailInput: React.ForwardRefExoticComponent<Omit<Omit<{
17
17
  Icon?: React.ReactElement<unknown, string | React.JSXElementConstructor<any>> | undefined;
18
18
  onChange?: React.ChangeEventHandler<HTMLInputElement | HTMLTextAreaElement> | undefined;
19
19
  containerProps?: Omit<React.HTMLProps<HTMLDivElement>, "ref"> | undefined;
20
- } & Omit<React.HTMLProps<HTMLInputElement | HTMLTextAreaElement>, "ref" | "onChange"> & React.RefAttributes<any>, "onChange" | "value"> & {
20
+ value?: string | undefined;
21
+ 'data-testid'?: string | undefined;
22
+ } & Omit<React.HTMLProps<HTMLInputElement | HTMLTextAreaElement>, "ref" | "onChange" | "value"> & React.RefAttributes<any>, "onChange" | "value"> & {
21
23
  onChange: (email: string, isValid: boolean) => void;
22
24
  value: string;
23
25
  messages: {
@@ -13,7 +13,9 @@ export type InputProps = {
13
13
  Icon?: React.ReactElement;
14
14
  onChange?: ChangeEventHandler<HTMLInputElement | HTMLTextAreaElement>;
15
15
  containerProps?: Omit<React.HTMLProps<HTMLDivElement>, "ref">;
16
- } & Omit<React.HTMLProps<HTMLInputElement | HTMLTextAreaElement>, "ref" | "onChange">;
16
+ value?: string;
17
+ 'data-testid'?: string;
18
+ } & Omit<React.HTMLProps<HTMLInputElement | HTMLTextAreaElement>, "ref" | "onChange" | 'value'>;
17
19
  export declare enum InputTestIds {
18
20
  DISCLAIMER = "disclaimer",
19
21
  ERROR = "error"
@@ -35,5 +37,7 @@ declare const Input: React.ForwardRefExoticComponent<{
35
37
  Icon?: React.ReactElement<unknown, string | React.JSXElementConstructor<any>> | undefined;
36
38
  onChange?: React.ChangeEventHandler<HTMLInputElement | HTMLTextAreaElement> | undefined;
37
39
  containerProps?: Omit<React.HTMLProps<HTMLDivElement>, "ref"> | undefined;
38
- } & Omit<React.HTMLProps<HTMLInputElement | HTMLTextAreaElement>, "ref" | "onChange"> & React.RefAttributes<any>>;
40
+ value?: string | undefined;
41
+ 'data-testid'?: string | undefined;
42
+ } & Omit<React.HTMLProps<HTMLInputElement | HTMLTextAreaElement>, "ref" | "onChange" | "value"> & React.RefAttributes<any>>;
39
43
  export default Input;
@@ -93,4 +93,4 @@ exports.InputTestIds = InputTestIds;
93
93
  const Input = /*#__PURE__*/(0, _react.forwardRef)(_Input);
94
94
  var _default = Input;
95
95
  exports.default = _default;
96
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_OneUIProvider","_Text","_interopRequireDefault","_InputModule","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_Input","_ref","ref","error","placeholder","hideError","icon","Icon","autoFocus","disclaimer","multiline","decoration","border","propBorder","containerProps","className","localClassName","otherProps","useOneUIConfig","globalBorder","focused","setFocused","useState","inputRef","useRef","useImperativeHandle","current","shouldShowError","useMemo","useEffect","t","setTimeout","focus","clearTimeout","Component","withBorder","undefined","createElement","Styles","inputContainer","withIcon","rows","onFocus","e","onBlur","title","caption","type","InputTestIds","exports","Input","forwardRef","_default"],"sources":["../../../src/components/Input/Input.tsx"],"sourcesContent":["import React, {\n  ChangeEventHandler,\n  ComponentProps,\n  DetailedHTMLProps,\n  ForwardedRef,\n  forwardRef,\n  HTMLAttributes,\n  ReactElement,\n  useEffect,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { useOneUIConfig, useOneUIContext } from \"../../context/OneUIProvider\";\nimport Text from \"../Text\";\nimport Styles from \"./Input.module.scss\";\n\nexport type InputProps = {\n  decoration?: React.ReactElement | null;\n  error?: string | ReactElement;\n  hideError?: \"onfocus\";\n  placeholder?: string;\n  disclaimer?: string | ReactElement;\n  multiline?: number;\n  border?: boolean;\n  icon?: {\n    onClick?: () => void;\n  } & DetailedHTMLProps<React.ImgHTMLAttributes<HTMLImageElement>, any>;\n  Icon?: React.ReactElement;\n  onChange?: ChangeEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n  containerProps?: Omit<React.HTMLProps<HTMLDivElement>, \"ref\">;\n} & Omit<\n  React.HTMLProps<HTMLInputElement | HTMLTextAreaElement>,\n  \"ref\" | \"onChange\"\n>;\nfunction _Input(\n  {\n    error,\n    placeholder = \" \",\n    hideError,\n    icon,\n    Icon,\n    autoFocus,\n    disclaimer,\n    multiline,\n    decoration = null,\n    border: propBorder,\n    containerProps,\n    className: localClassName,\n    ...otherProps\n  }: InputProps,\n  ref: ForwardedRef<any>\n) {\n  const className = useOneUIConfig(\"component.input.className\");\n  const globalBorder = useOneUIConfig(\"component.input.border\");\n  const [focused, setFocused] = useState(false);\n  const inputRef = useRef<HTMLInputElement | HTMLTextAreaElement>(null);\n  useImperativeHandle(ref, () => inputRef.current, []);\n  const shouldShowError = useMemo(() => {\n    if (hideError === \"onfocus\") return !focused;\n    return !!error;\n  }, [focused, error, hideError]);\n  useEffect(() => {\n    if (autoFocus) {\n      const t = setTimeout(() => {\n        inputRef.current!.focus();\n      }, 500);\n      return () => clearTimeout(t);\n    }\n  }, [autoFocus]);\n  const Component = multiline ? \"textarea\" : \"input\";\n  const withBorder = useMemo(() => {\n    if (propBorder !== undefined) return propBorder;\n    return globalBorder;\n  }, [propBorder, globalBorder]);\n  return (\n    <div\n      className={`${Styles.inputContainer} ${\n        false ? Styles.withIcon : \"\"\n      } ${className} ${localClassName}`}\n      {...containerProps}\n    >\n      {decoration}\n      <Component\n        ref={inputRef as any}\n        placeholder={placeholder}\n        rows={multiline}\n        {...otherProps}\n        onFocus={(e) => {\n          setFocused(true);\n          if (otherProps.onFocus) otherProps.onFocus(e);\n        }}\n        onBlur={(e) => {\n          setFocused(false);\n          if (otherProps.onBlur) otherProps.onBlur(e);\n        }}\n      />\n      {withBorder && <div className={Styles.border} />}\n      {error && shouldShowError ? (\n        <Text\n          title={typeof error === \"string\" ? error : \"\"}\n          data-testid={InputTestIds.ERROR}\n          className={Styles.caption}\n          type=\"error\"\n        >\n          {error}\n        </Text>\n      ) : disclaimer ? (\n        <Text\n          title={typeof disclaimer === \"string\" ? disclaimer : \"\"}\n          type=\"caption\"\n          className={Styles.caption}\n          data-testid={InputTestIds.DISCLAIMER}\n        >\n          {disclaimer}\n        </Text>\n      ) : null}\n      {Icon && <div className={Styles.icon}>{Icon}</div>}\n      {icon && <img className={Styles.icon} {...icon} />}\n    </div>\n  );\n}\n\nexport enum InputTestIds {\n  DISCLAIMER = \"disclaimer\",\n  ERROR = \"error\",\n}\n\n/**\n * A transparent input with some prebuilt states common to the application\n **/\nconst Input = forwardRef(_Input);\nexport default Input;\n"],"mappings":"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"}
96
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_OneUIProvider","_Text","_interopRequireDefault","_InputModule","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_Input","_ref","ref","error","placeholder","hideError","icon","Icon","autoFocus","disclaimer","multiline","decoration","border","propBorder","containerProps","className","localClassName","otherProps","useOneUIConfig","globalBorder","focused","setFocused","useState","inputRef","useRef","useImperativeHandle","current","shouldShowError","useMemo","useEffect","t","setTimeout","focus","clearTimeout","Component","withBorder","undefined","createElement","Styles","inputContainer","withIcon","rows","onFocus","e","onBlur","title","caption","type","InputTestIds","exports","Input","forwardRef","_default"],"sources":["../../../src/components/Input/Input.tsx"],"sourcesContent":["import React, {\n  ChangeEventHandler,\n  ComponentProps,\n  DetailedHTMLProps,\n  ForwardedRef,\n  forwardRef,\n  HTMLAttributes,\n  ReactElement,\n  useEffect,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { useOneUIConfig, useOneUIContext } from \"../../context/OneUIProvider\";\nimport Text from \"../Text\";\nimport Styles from \"./Input.module.scss\";\n\nexport type InputProps = {\n  decoration?: React.ReactElement | null;\n  error?: string | ReactElement;\n  hideError?: \"onfocus\";\n  placeholder?: string;\n  disclaimer?: string | ReactElement;\n  multiline?: number;\n  border?: boolean;\n  icon?: {\n    onClick?: () => void;\n  } & DetailedHTMLProps<React.ImgHTMLAttributes<HTMLImageElement>, any>;\n  Icon?: React.ReactElement;\n  onChange?: ChangeEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n  containerProps?: Omit<React.HTMLProps<HTMLDivElement>, \"ref\">;\n  value?: string;\n  'data-testid'?: string;\n} & Omit<\n  React.HTMLProps<HTMLInputElement | HTMLTextAreaElement>,\n  \"ref\" | \"onChange\" | 'value'\n>;\nfunction _Input(\n  {\n    error,\n    placeholder = \" \",\n    hideError,\n    icon,\n    Icon,\n    autoFocus,\n    disclaimer,\n    multiline,\n    decoration = null,\n    border: propBorder,\n    containerProps,\n    className: localClassName,\n    ...otherProps\n  }: InputProps,\n  ref: ForwardedRef<any>\n) {\n  const className = useOneUIConfig(\"component.input.className\");\n  const globalBorder = useOneUIConfig(\"component.input.border\");\n  const [focused, setFocused] = useState(false);\n  const inputRef = useRef<HTMLInputElement | HTMLTextAreaElement>(null);\n  useImperativeHandle(ref, () => inputRef.current, []);\n  const shouldShowError = useMemo(() => {\n    if (hideError === \"onfocus\") return !focused;\n    return !!error;\n  }, [focused, error, hideError]);\n  useEffect(() => {\n    if (autoFocus) {\n      const t = setTimeout(() => {\n        inputRef.current!.focus();\n      }, 500);\n      return () => clearTimeout(t);\n    }\n  }, [autoFocus]);\n  const Component = multiline ? \"textarea\" : \"input\";\n  const withBorder = useMemo(() => {\n    if (propBorder !== undefined) return propBorder;\n    return globalBorder;\n  }, [propBorder, globalBorder]);\n  return (\n    <div\n      className={`${Styles.inputContainer} ${\n        false ? Styles.withIcon : \"\"\n      } ${className} ${localClassName}`}\n      {...containerProps}\n    >\n      {decoration}\n      <Component\n        ref={inputRef as any}\n        placeholder={placeholder}\n        rows={multiline}\n        {...otherProps}\n        onFocus={(e) => {\n          setFocused(true);\n          if (otherProps.onFocus) otherProps.onFocus(e);\n        }}\n        onBlur={(e) => {\n          setFocused(false);\n          if (otherProps.onBlur) otherProps.onBlur(e);\n        }}\n      />\n      {withBorder && <div className={Styles.border} />}\n      {error && shouldShowError ? (\n        <Text\n          title={typeof error === \"string\" ? error : \"\"}\n          data-testid={InputTestIds.ERROR}\n          className={Styles.caption}\n          type=\"error\"\n        >\n          {error}\n        </Text>\n      ) : disclaimer ? (\n        <Text\n          title={typeof disclaimer === \"string\" ? disclaimer : \"\"}\n          type=\"caption\"\n          className={Styles.caption}\n          data-testid={InputTestIds.DISCLAIMER}\n        >\n          {disclaimer}\n        </Text>\n      ) : null}\n      {Icon && <div className={Styles.icon}>{Icon}</div>}\n      {icon && <img className={Styles.icon} {...icon} />}\n    </div>\n  );\n}\n\nexport enum InputTestIds {\n  DISCLAIMER = \"disclaimer\",\n  ERROR = \"error\",\n}\n\n/**\n * A transparent input with some prebuilt states common to the application\n **/\nconst Input = forwardRef(_Input);\nexport default Input;\n"],"mappings":"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"}
@@ -40,7 +40,9 @@ declare const PasswordInput: React.ForwardRefExoticComponent<(({
40
40
  Icon?: React.ReactElement<unknown, string | React.JSXElementConstructor<any>> | undefined;
41
41
  onChange?: React.ChangeEventHandler<HTMLInputElement | HTMLTextAreaElement> | undefined;
42
42
  containerProps?: Omit<React.HTMLProps<HTMLDivElement>, "ref"> | undefined;
43
- } & Omit<React.HTMLProps<HTMLInputElement | HTMLTextAreaElement>, "ref" | "onChange"> & React.RefAttributes<any>, "ref" | "onChange" | "value">) & React.RefAttributes<{
43
+ value?: string | undefined;
44
+ 'data-testid'?: string | undefined;
45
+ } & Omit<React.HTMLProps<HTMLInputElement | HTMLTextAreaElement>, "ref" | "onChange" | "value"> & React.RefAttributes<any>, "ref" | "onChange" | "value">) & React.RefAttributes<{
44
46
  validatePassword: (pass: string) => boolean;
45
47
  }>>;
46
48
  export default PasswordInput;
@@ -0,0 +1,17 @@
1
+ /**
2
+ * A formatter to format to double decimal
3
+ */
4
+ export declare const currencyNumberFormatter: {
5
+ (value: number): string;
6
+ (value: number | bigint): string;
7
+ };
8
+ /**
9
+ * Instanciate a currency formatter
10
+ */
11
+ export declare const currencyFormatterFactory: (langCode: string, currency?: string) => Intl.NumberFormat | {
12
+ format: (num: number) => string;
13
+ formatToParts: (num: number) => {
14
+ type: string;
15
+ value: string | undefined;
16
+ }[];
17
+ };
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.currencyNumberFormatter = exports.currencyFormatterFactory = void 0;
7
+ /**
8
+ * A formatter to format to double decimal
9
+ */
10
+ const currencyNumberFormatter = new Intl.NumberFormat("pt-BR", {
11
+ minimumFractionDigits: 2,
12
+ maximumFractionDigits: 2
13
+ }).format;
14
+
15
+ /**
16
+ * Instanciate a currency formatter
17
+ */
18
+ exports.currencyNumberFormatter = currencyNumberFormatter;
19
+ const currencyFormatterFactory = (langCode, currency) => {
20
+ try {
21
+ return new Intl.NumberFormat(langCode, {
22
+ style: "currency",
23
+ currency: currency
24
+ });
25
+ } catch (e) {
26
+ const f = new Intl.NumberFormat(langCode, {
27
+ minimumFractionDigits: 2,
28
+ maximumFractionDigits: 2
29
+ });
30
+ return {
31
+ format: num => `${currency} ${currencyNumberFormatter(num)}`,
32
+ formatToParts: num => [{
33
+ type: "currency",
34
+ value: currency
35
+ }, {
36
+ type: "literal",
37
+ value: " "
38
+ }, ...f.formatToParts(num)]
39
+ };
40
+ }
41
+ };
42
+ exports.currencyFormatterFactory = currencyFormatterFactory;
43
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjdXJyZW5jeU51bWJlckZvcm1hdHRlciIsIkludGwiLCJOdW1iZXJGb3JtYXQiLCJtaW5pbXVtRnJhY3Rpb25EaWdpdHMiLCJtYXhpbXVtRnJhY3Rpb25EaWdpdHMiLCJmb3JtYXQiLCJleHBvcnRzIiwiY3VycmVuY3lGb3JtYXR0ZXJGYWN0b3J5IiwibGFuZ0NvZGUiLCJjdXJyZW5jeSIsInN0eWxlIiwiZSIsImYiLCJudW0iLCJmb3JtYXRUb1BhcnRzIiwidHlwZSIsInZhbHVlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL2Zvcm1hdHRlcnMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBBIGZvcm1hdHRlciB0byBmb3JtYXQgdG8gZG91YmxlIGRlY2ltYWxcbiAqL1xuZXhwb3J0IGNvbnN0IGN1cnJlbmN5TnVtYmVyRm9ybWF0dGVyID0gbmV3IEludGwuTnVtYmVyRm9ybWF0KFwicHQtQlJcIiwge1xuICBtaW5pbXVtRnJhY3Rpb25EaWdpdHM6IDIsXG4gIG1heGltdW1GcmFjdGlvbkRpZ2l0czogMixcbn0pLmZvcm1hdDtcblxuLyoqXG4gKiBJbnN0YW5jaWF0ZSBhIGN1cnJlbmN5IGZvcm1hdHRlclxuICovXG5leHBvcnQgY29uc3QgY3VycmVuY3lGb3JtYXR0ZXJGYWN0b3J5ID0gKFxuICBsYW5nQ29kZTogc3RyaW5nLFxuICBjdXJyZW5jeT86IHN0cmluZ1xuKSA9PiB7XG4gIHRyeSB7XG4gICAgcmV0dXJuIG5ldyBJbnRsLk51bWJlckZvcm1hdChsYW5nQ29kZSwge1xuICAgICAgc3R5bGU6IFwiY3VycmVuY3lcIixcbiAgICAgIGN1cnJlbmN5OiBjdXJyZW5jeSxcbiAgICB9KTtcbiAgfSBjYXRjaCAoZSkge1xuICAgIGNvbnN0IGYgPSBuZXcgSW50bC5OdW1iZXJGb3JtYXQobGFuZ0NvZGUsIHtcbiAgICAgIG1pbmltdW1GcmFjdGlvbkRpZ2l0czogMixcbiAgICAgIG1heGltdW1GcmFjdGlvbkRpZ2l0czogMixcbiAgICB9KTtcblxuICAgIHJldHVybiB7XG4gICAgICBmb3JtYXQ6IChudW06IG51bWJlcikgPT4gYCR7Y3VycmVuY3l9ICR7Y3VycmVuY3lOdW1iZXJGb3JtYXR0ZXIobnVtKX1gLFxuICAgICAgZm9ybWF0VG9QYXJ0czogKG51bTogbnVtYmVyKSA9PiBbXG4gICAgICAgIHsgdHlwZTogXCJjdXJyZW5jeVwiLCB2YWx1ZTogY3VycmVuY3kgfSxcbiAgICAgICAgeyB0eXBlOiBcImxpdGVyYWxcIiwgdmFsdWU6IFwiIFwiIH0sXG4gICAgICAgIC4uLmYuZm9ybWF0VG9QYXJ0cyhudW0pLFxuICAgICAgXSxcbiAgICB9O1xuICB9XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDTyxNQUFNQSx1QkFBdUIsR0FBRyxJQUFJQyxJQUFJLENBQUNDLFlBQVksQ0FBQyxPQUFPLEVBQUU7RUFDcEVDLHFCQUFxQixFQUFFLENBQUM7RUFDeEJDLHFCQUFxQixFQUFFO0FBQ3pCLENBQUMsQ0FBQyxDQUFDQyxNQUFNOztBQUVUO0FBQ0E7QUFDQTtBQUZBQyxPQUFBLENBQUFOLHVCQUFBLEdBQUFBLHVCQUFBO0FBR08sTUFBTU8sd0JBQXdCLEdBQUdBLENBQ3RDQyxRQUFnQixFQUNoQkMsUUFBaUIsS0FDZDtFQUNILElBQUk7SUFDRixPQUFPLElBQUlSLElBQUksQ0FBQ0MsWUFBWSxDQUFDTSxRQUFRLEVBQUU7TUFDckNFLEtBQUssRUFBRSxVQUFVO01BQ2pCRCxRQUFRLEVBQUVBO0lBQ1osQ0FBQyxDQUFDO0VBQ0osQ0FBQyxDQUFDLE9BQU9FLENBQUMsRUFBRTtJQUNWLE1BQU1DLENBQUMsR0FBRyxJQUFJWCxJQUFJLENBQUNDLFlBQVksQ0FBQ00sUUFBUSxFQUFFO01BQ3hDTCxxQkFBcUIsRUFBRSxDQUFDO01BQ3hCQyxxQkFBcUIsRUFBRTtJQUN6QixDQUFDLENBQUM7SUFFRixPQUFPO01BQ0xDLE1BQU0sRUFBR1EsR0FBVyxJQUFNLEdBQUVKLFFBQVMsSUFBR1QsdUJBQXVCLENBQUNhLEdBQUcsQ0FBRSxFQUFDO01BQ3RFQyxhQUFhLEVBQUdELEdBQVcsSUFBSyxDQUM5QjtRQUFFRSxJQUFJLEVBQUUsVUFBVTtRQUFFQyxLQUFLLEVBQUVQO01BQVMsQ0FBQyxFQUNyQztRQUFFTSxJQUFJLEVBQUUsU0FBUztRQUFFQyxLQUFLLEVBQUU7TUFBSSxDQUFDLEVBQy9CLEdBQUdKLENBQUMsQ0FBQ0UsYUFBYSxDQUFDRCxHQUFHLENBQUM7SUFFM0IsQ0FBQztFQUNIO0FBQ0YsQ0FBQztBQUFDUCxPQUFBLENBQUFDLHdCQUFBLEdBQUFBLHdCQUFBIn0=
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@onepercentio/one-ui",
3
- "version": "0.27.7",
3
+ "version": "0.28.0",
4
4
  "description": "A set of reusable components created through the development of Onepercent projects",
5
5
  "repository": "git@github.com:onepercentio/one-ui.git",
6
6
  "author": "Murilo Oliveira de Araujo <murilo.araujo@onepercent.io>",
@@ -1,17 +0,0 @@
1
- import { ReactElement } from "react";
2
- type Node = {
3
- /** Indicates how much that node should increase in relation to other nodes */
4
- grandeour: number;
5
- /** What to show on that node */
6
- cover: ReactElement;
7
- };
8
- export declare function calculateTargetIndex(nodesPosition: [x: number, y: number][], center: [x: number, y: number], clickedAt: [x: number, y: number]): number[];
9
- /**
10
- * Distributes circles representing the nodes and allows the user to navigate to said nodes through clicking
11
- **/
12
- export default function NodesNavigator({ nodes, currentNode, onClickNode, }: {
13
- nodes: Node[];
14
- currentNode: Node | null;
15
- onClickNode?: (n: Node) => void;
16
- }): import("react/jsx-runtime").JSX.Element;
17
- export {};
@@ -1,88 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.calculateTargetIndex = calculateTargetIndex;
7
- exports.default = NodesNavigator;
8
- var _react = _interopRequireWildcard(require("react"));
9
- var _NodesNavigatorModule = _interopRequireDefault(require("./NodesNavigator.module.scss"));
10
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
11
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
12
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
13
- function calculateTargetIndex(nodesPosition, center, clickedAt) {
14
- const counterClickedAt = [center[1] - clickedAt[1], center[0] - clickedAt[0]];
15
- const slope = (counterClickedAt[1] - center[1]) / (counterClickedAt[0] - center[0]);
16
- const inverseTan = Math.atan(slope);
17
- return [Math.sin(inverseTan), Math.cos(inverseTan)];
18
- }
19
-
20
- /**
21
- * Distributes circles representing the nodes and allows the user to navigate to said nodes through clicking
22
- **/
23
- function NodesNavigator(_ref) {
24
- let {
25
- nodes,
26
- currentNode,
27
- onClickNode
28
- } = _ref;
29
- const rootRef = (0, _react.useRef)(null);
30
- (0, _react.useEffect)(() => {
31
- if (!currentNode) return;
32
- const currentNodeEl = rootRef.current.children[nodes.indexOf(currentNode)];
33
- const style = currentNodeEl.style;
34
- style.transform = `translateX(0em) translateY(0em)`;
35
- }, [currentNode]);
36
- const [otherNodes, setOtherNodes] = (0, _react.useState)(() => {
37
- return nodes.filter(n => n !== currentNode);
38
- });
39
- const [nodesPosition, setNodesPosition] = (0, _react.useState)([]);
40
- (0, _react.useEffect)(() => {
41
- setNodesPosition(otherNodes.map((n, index) => {
42
- var angle = index * Math.PI / 3;
43
- return [Math.sin(angle), Math.cos(angle)];
44
- }));
45
- }, [otherNodes]);
46
- (0, _react.useEffect)(() => {
47
- if (otherNodes.length !== nodesPosition.length) return;
48
- const elements = rootRef.current.children;
49
- for (let node of otherNodes) {
50
- const idx = otherNodes.indexOf(node);
51
- const pos = nodesPosition[idx];
52
- const el = elements[idx];
53
- el.style.transform = `translateX(${pos[0] + "em"}) translateY(${pos[1] + "em"})`;
54
- }
55
- }, [nodesPosition]);
56
- return /*#__PURE__*/_react.default.createElement("div", {
57
- className: _NodesNavigatorModule.default.root,
58
- ref: rootRef
59
- }, otherNodes.map(n => /*#__PURE__*/_react.default.createElement("div", {
60
- key: nodes.indexOf(n),
61
- className: _NodesNavigatorModule.default.node,
62
- onClick: _ref2 => {
63
- let {
64
- clientX,
65
- clientY
66
- } = _ref2;
67
- const root = rootRef.current.getBoundingClientRect();
68
- const center = [root.left + root.width / 2, root.top + root.height / 2];
69
- const click = [clientX, clientY];
70
- const angle = 3 + Math.atan2(click[1] - center[1], click[0] - center[0]);
71
- const futureIndex = Math.round(angle / Math.PI * 3 - 1);
72
- console.log(futureIndex);
73
- setOtherNodes(prev => {
74
- prev.splice(futureIndex + 1, 0, currentNode);
75
- return [...prev.filter(a => a !== n)];
76
- });
77
- // console.log(angle);
78
- onClickNode === null || onClickNode === void 0 ? void 0 : onClickNode(n);
79
- }
80
- }, otherNodes.indexOf(n))), currentNode && /*#__PURE__*/_react.default.createElement("div", {
81
- key: nodes.indexOf(currentNode),
82
- className: _NodesNavigatorModule.default.node,
83
- onClick: () => {
84
- onClickNode === null || onClickNode === void 0 ? void 0 : onClickNode(currentNode);
85
- }
86
- }, "C"));
87
- }
88
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_NodesNavigatorModule","_interopRequireDefault","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","calculateTargetIndex","nodesPosition","center","clickedAt","counterClickedAt","slope","inverseTan","Math","atan","sin","cos","NodesNavigator","_ref","nodes","currentNode","onClickNode","rootRef","useRef","useEffect","currentNodeEl","current","children","indexOf","style","transform","otherNodes","setOtherNodes","useState","filter","n","setNodesPosition","map","index","angle","PI","length","elements","node","idx","pos","el","createElement","className","Styles","root","ref","onClick","_ref2","clientX","clientY","getBoundingClientRect","left","width","top","height","click","atan2","futureIndex","round","console","log","prev","splice","a"],"sources":["../../../src/components/NodesNavigator/NodesNavigator.tsx"],"sourcesContent":["import React, {\n  ReactElement,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport Styles from \"./NodesNavigator.module.scss\";\n\ntype Node = {\n  /** Indicates how much that node should increase in relation to other nodes */\n  grandeour: number;\n\n  /** What to show on that node */\n  cover: ReactElement;\n};\n\nexport function calculateTargetIndex(\n  nodesPosition: [x: number, y: number][],\n  center: [x: number, y: number],\n  clickedAt: [x: number, y: number]\n) {\n  const counterClickedAt = [center[1] - clickedAt[1], center[0] - clickedAt[0]];\n  const slope =\n    (counterClickedAt[1] - center[1]) / (counterClickedAt[0] - center[0]);\n\n  const inverseTan = Math.atan(slope);\n  return [Math.sin(inverseTan), Math.cos(inverseTan)];\n}\n\n/**\n * Distributes circles representing the nodes and allows the user to navigate to said nodes through clicking\n **/\nexport default function NodesNavigator({\n  nodes,\n  currentNode,\n  onClickNode,\n}: {\n  nodes: Node[];\n  currentNode: Node | null;\n  onClickNode?: (n: Node) => void;\n}) {\n  const rootRef = useRef<HTMLDivElement>(null);\n\n  useEffect(() => {\n    if (!currentNode) return;\n    const currentNodeEl = rootRef.current!.children[\n      nodes.indexOf(currentNode)\n    ] as HTMLDivElement;\n    const style = currentNodeEl.style;\n\n    style.transform = `translateX(0em) translateY(0em)`;\n  }, [currentNode]);\n\n  const [otherNodes, setOtherNodes] = useState(() => {\n    return nodes.filter((n) => n !== currentNode);\n  });\n  const [nodesPosition, setNodesPosition] = useState<\n    [tX: number, tY: number][]\n  >([]);\n\n  useEffect(() => {\n    setNodesPosition(\n      otherNodes.map((n, index) => {\n        var angle = (index * Math.PI) / 3;\n        return [Math.sin(angle), Math.cos(angle)];\n      })\n    );\n  }, [otherNodes]);\n\n  useEffect(() => {\n    if (otherNodes.length !== nodesPosition.length) return;\n    const elements = rootRef.current!.children;\n    for (let node of otherNodes) {\n      const idx = otherNodes.indexOf(node);\n      const pos = nodesPosition[idx];\n      const el = elements[idx] as HTMLDivElement;\n      el.style.transform = `translateX(${pos[0] + \"em\"}) translateY(${\n        pos[1] + \"em\"\n      })`;\n    }\n  }, [nodesPosition]);\n\n  return (\n    <div className={Styles.root} ref={rootRef}>\n      {otherNodes.map((n) => (\n        <div\n          key={nodes.indexOf(n)}\n          className={Styles.node}\n          onClick={({ clientX, clientY }) => {\n            const root = rootRef.current!.getBoundingClientRect();\n            const center = [\n              root.left + root.width / 2,\n              root.top + root.height / 2,\n            ];\n            const click = [clientX, clientY];\n            const angle =\n              3 + Math.atan2(click[1] - center[1], click[0] - center[0]);\n\n            const futureIndex = Math.round((angle / Math.PI) * 3 - 1);\n            console.log(futureIndex);\n            setOtherNodes((prev) => {\n              prev.splice(futureIndex + 1, 0, currentNode!);\n              return [...prev.filter((a) => a !== n)];\n            });\n            // console.log(angle);\n            onClickNode?.(n);\n          }}\n        >\n          {/* {n.cover} */}\n          {otherNodes.indexOf(n)}\n        </div>\n      ))}\n      {currentNode && (\n        <div\n          key={nodes.indexOf(currentNode)}\n          className={Styles.node}\n          onClick={() => {\n            onClickNode?.(currentNode!);\n          }}\n        >\n          {/* {n.cover} */}C\n        </div>\n      )}\n    </div>\n  );\n}\n"],"mappings":"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"}
@@ -1,19 +0,0 @@
1
- .root {
2
- background-color: red;
3
- width: 100%;
4
- height: 100%;
5
- position: relative;
6
- font-size: 72px;
7
- display: flex;
8
- align-items: center;
9
- justify-content: center;
10
- }
11
-
12
- .node {
13
- height: 1em;
14
- width: 1em;
15
- border-radius: 0.5em;
16
- overflow: hidden;
17
- position: absolute;
18
- transition: transform linear 2s;
19
- }
@@ -1 +0,0 @@
1
- export { default } from './NodesNavigator';
@@ -1,14 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- Object.defineProperty(exports, "default", {
7
- enumerable: true,
8
- get: function () {
9
- return _NodesNavigator.default;
10
- }
11
- });
12
- var _NodesNavigator = _interopRequireDefault(require("./NodesNavigator"));
13
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfTm9kZXNOYXZpZ2F0b3IiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIm9iaiIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0Il0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvTm9kZXNOYXZpZ2F0b3IvaW5kZXgudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IGRlZmF1bHQgfSBmcm9tICcuL05vZGVzTmF2aWdhdG9yJztcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBQSxJQUFBQSxlQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFBMkMsU0FBQUQsdUJBQUFFLEdBQUEsV0FBQUEsR0FBQSxJQUFBQSxHQUFBLENBQUFDLFVBQUEsR0FBQUQsR0FBQSxLQUFBRSxPQUFBLEVBQUFGLEdBQUEifQ==