@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.
- package/dist/components/CurrencyInput/CurrencyInput.d.ts +6 -0
- package/dist/components/CurrencyInput/CurrencyInput.hook.d.ts +6 -0
- package/dist/components/CurrencyInput/CurrencyInput.hook.js +29 -0
- package/dist/components/CurrencyInput/CurrencyInput.js +42 -0
- package/dist/components/CurrencyInput/index.d.ts +1 -0
- package/dist/components/CurrencyInput/index.js +14 -0
- package/dist/components/EmailInput/EmailInput.d.ts +3 -1
- package/dist/components/Input/Input.d.ts +6 -2
- package/dist/components/Input/Input.js +1 -1
- package/dist/components/PasswordInput/PasswordInput.d.ts +3 -1
- package/dist/utils/formatters.d.ts +17 -0
- package/dist/utils/formatters.js +43 -0
- package/package.json +1 -1
- package/dist/components/NodesNavigator/NodesNavigator.d.ts +0 -17
- package/dist/components/NodesNavigator/NodesNavigator.js +0 -88
- package/dist/components/NodesNavigator/NodesNavigator.module.scss +0 -19
- package/dist/components/NodesNavigator/index.d.ts +0 -1
- package/dist/components/NodesNavigator/index.js +0 -14
|
@@ -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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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.
|
|
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==
|