@onepercentio/one-ui 0.22.0 → 0.22.2
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/WebpackConfigs/email-templates.js +18 -4
- package/dist/components/LavaLamp/v2/LavaLamp.js +55 -97
- package/dist/components/Spacing/Spacing.d.ts +2 -2
- package/dist/components/Spacing/Spacing.js +14 -3
- package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.d.ts +1 -1
- package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.js +4 -2
- package/dist/context/OneUIProvider.d.ts +5 -0
- package/dist/context/OneUIProvider.js +1 -1
- package/dist/hooks/useAsyncControl.d.ts +4 -0
- package/dist/hooks/useAsyncControl.js +1 -1
- package/dist/hooks/utility/useAsyncMemo.js +6 -2
- package/dist/models/Orbs.d.ts +35 -0
- package/dist/models/Orbs.js +85 -0
- package/dist/utility.d.js +1 -1
- package/package.json +1 -1
|
@@ -5,10 +5,14 @@ process.env.NODE_ENV =
|
|
|
5
5
|
: "production");
|
|
6
6
|
const Module = require("module").Module;
|
|
7
7
|
function resolveFromMainContext(module) {
|
|
8
|
-
|
|
8
|
+
try {
|
|
9
|
+
return Module._resolveFilename(module, require.main);
|
|
10
|
+
} catch (e) {
|
|
11
|
+
return require.resolve(resolve("node_modules", module));
|
|
12
|
+
}
|
|
9
13
|
}
|
|
10
14
|
const { join, relative, resolve } = require("path");
|
|
11
|
-
const HTMLPlugin = require
|
|
15
|
+
const HTMLPlugin = require(resolveFromMainContext("html-webpack-plugin"));
|
|
12
16
|
const {
|
|
13
17
|
writeFileSync,
|
|
14
18
|
readdirSync,
|
|
@@ -20,6 +24,7 @@ const {
|
|
|
20
24
|
const lodash = require("lodash");
|
|
21
25
|
const { findPathDeep } = require("deepdash")(lodash);
|
|
22
26
|
const chalk = require("chalk");
|
|
27
|
+
const { createRequire } = require("module");
|
|
23
28
|
|
|
24
29
|
function findAllStaticGeneration() {
|
|
25
30
|
const glob = require("glob");
|
|
@@ -42,8 +47,17 @@ function parseResultsrToEntries(results) {
|
|
|
42
47
|
let configGenerator;
|
|
43
48
|
async function loadGenerator() {
|
|
44
49
|
try {
|
|
45
|
-
configGenerator =
|
|
46
|
-
|
|
50
|
+
configGenerator = await (async () => {
|
|
51
|
+
try {
|
|
52
|
+
return require(resolve("./webpack-email-config-factory.js"));
|
|
53
|
+
} catch (e) {
|
|
54
|
+
return await import(resolve("./webpack-email-config-factory.js"));
|
|
55
|
+
}
|
|
56
|
+
})();
|
|
57
|
+
return await (configGenerator.default || configGenerator)(
|
|
58
|
+
resolve("."),
|
|
59
|
+
process.env.NODE_ENV
|
|
60
|
+
);
|
|
47
61
|
} catch (e) {
|
|
48
62
|
switch (e.code) {
|
|
49
63
|
case "MODULE_NOT_FOUND":
|
|
@@ -8,17 +8,11 @@ var _react = _interopRequireWildcard(require("react"));
|
|
|
8
8
|
var _useMergeRefs = _interopRequireDefault(require("../../../hooks/useMergeRefs"));
|
|
9
9
|
var _LavaLamp = _interopRequireWildcard(require("../LavaLamp.data"));
|
|
10
10
|
var _LavaLampModule = _interopRequireDefault(require("./LavaLamp.module.scss"));
|
|
11
|
+
var _Orbs = require("../../../models/Orbs");
|
|
11
12
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
12
13
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
13
14
|
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; }
|
|
14
15
|
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
15
|
-
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
|
16
|
-
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
|
17
|
-
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
18
|
-
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
|
19
|
-
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
|
20
|
-
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
21
|
-
function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
|
22
16
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
23
17
|
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
|
|
24
18
|
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|
@@ -64,31 +58,30 @@ function LavaLamp(_ref) {
|
|
|
64
58
|
// f means final
|
|
65
59
|
opts = {
|
|
66
60
|
orbCount: circlesConfig.length,
|
|
67
|
-
baseVel: Math.max(d.width * 0.
|
|
68
|
-
addedVel: Math.max(d.width * 0.
|
|
61
|
+
baseVel: Math.max(d.width * 0.001, 1),
|
|
62
|
+
addedVel: Math.max(d.width * 0.001, 1),
|
|
69
63
|
alphaThreshold: 200
|
|
70
64
|
},
|
|
71
65
|
orbs = [];
|
|
72
|
-
let
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
fctx.fillStyle = "#0000";
|
|
77
|
-
fctx.fillRect(0, 0, w, h);
|
|
78
|
-
for (var i = 0; i < orbs.length; i++) orbs[i].step();
|
|
79
|
-
var image = ctx.getImageData(0, 0, w, h),
|
|
80
|
-
data = new Uint8Array(image.data.buffer);
|
|
81
|
-
for (var i = 3; i < data.length; i += 4) data[i] /= data[i] < opts.alphaThreshold ? 6 : 1;
|
|
82
|
-
fctx.putImageData(image, 0, 0);
|
|
83
|
-
}
|
|
84
|
-
let BaseOrb = /*#__PURE__*/function () {
|
|
85
|
-
function BaseOrb() {
|
|
86
|
-
_classCallCheck(this, BaseOrb);
|
|
66
|
+
let CanvasOrbDrawer = /*#__PURE__*/function () {
|
|
67
|
+
function CanvasOrbDrawer(gradientRadius) {
|
|
68
|
+
_classCallCheck(this, CanvasOrbDrawer);
|
|
69
|
+
if (gradientRadius) this.gradient = this.newGradient(baseColor, gradientRadius);
|
|
87
70
|
}
|
|
88
|
-
_createClass(
|
|
71
|
+
_createClass(CanvasOrbDrawer, [{
|
|
72
|
+
key: "newGradient",
|
|
73
|
+
value: function newGradient(color, radius) {
|
|
74
|
+
const gradient = ctx.createRadialGradient(0, 0, 0, 0, 0, radius);
|
|
75
|
+
gradient.addColorStop(0, "".concat(color, "ff"));
|
|
76
|
+
gradient.addColorStop(0.8, "".concat(color, "cc"));
|
|
77
|
+
gradient.addColorStop(1, "".concat(color, "00"));
|
|
78
|
+
return gradient;
|
|
79
|
+
}
|
|
80
|
+
}, {
|
|
89
81
|
key: "oldDrawCircle",
|
|
90
82
|
value: function oldDrawCircle(x, y, radius) {
|
|
91
|
-
|
|
83
|
+
var _this$gradient;
|
|
84
|
+
ctx.fillStyle = (_this$gradient = this.gradient) !== null && _this$gradient !== void 0 ? _this$gradient : this.newGradient(baseColor, radius);
|
|
92
85
|
ctx.translate(x | 0, y | 0);
|
|
93
86
|
ctx.beginPath();
|
|
94
87
|
ctx.arc(0, 0, radius, 0, Math.PI * 2);
|
|
@@ -96,91 +89,56 @@ function LavaLamp(_ref) {
|
|
|
96
89
|
ctx.translate(-x | 0, -y | 0);
|
|
97
90
|
}
|
|
98
91
|
}, {
|
|
99
|
-
key: "
|
|
100
|
-
value: function
|
|
92
|
+
key: "drawOrb",
|
|
93
|
+
value: function drawOrb(x, y, radius) {
|
|
101
94
|
this.oldDrawCircle(x, y, radius);
|
|
102
95
|
}
|
|
103
96
|
}]);
|
|
104
|
-
return
|
|
97
|
+
return CanvasOrbDrawer;
|
|
105
98
|
}();
|
|
106
|
-
let
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
var radiant = Math.random() * Math.PI * 2,
|
|
122
|
-
vel = opts.baseVel + opts.addedVel * Math.random() | 0;
|
|
123
|
-
vel *= 0.2;
|
|
124
|
-
_this.vx = Math.cos(radiant) * vel;
|
|
125
|
-
_this.vy = Math.sin(radiant) * vel;
|
|
126
|
-
return _this;
|
|
127
|
-
}
|
|
128
|
-
_createClass(Orb, [{
|
|
129
|
-
key: "step",
|
|
130
|
-
value: function step() {
|
|
131
|
-
this.x += this.vx;
|
|
132
|
-
this.y += this.vy;
|
|
133
|
-
var radius = this.radius / 2;
|
|
134
|
-
if (this.x < -radius || this.x > w + radius) this.vx *= -1;
|
|
135
|
-
if (this.y < -radius || this.y > h + radius) this.vy *= -1;
|
|
136
|
-
this.drawCircle(this.x | 0, this.y | 0, this.radius);
|
|
99
|
+
let animFrame;
|
|
100
|
+
function anim() {
|
|
101
|
+
animFrame = window.requestAnimationFrame(anim);
|
|
102
|
+
ctx.clearRect(0, 0, w, h);
|
|
103
|
+
fctx.fillStyle = "#0000";
|
|
104
|
+
fctx.fillRect(0, 0, w, h);
|
|
105
|
+
for (var i = 0; i < orbs.length; i++) {
|
|
106
|
+
const thisOrb = orbs[i];
|
|
107
|
+
if (thisOrb instanceof _Orbs.Orb) {
|
|
108
|
+
thisOrb.step();
|
|
109
|
+
} else {
|
|
110
|
+
thisOrb.step(guideConfig.current.size, guideConfig.current.sizeIncrement, guideConfig.current.sizeTimestamp, guideConfig.current.posTimestamp, guideConfig.current, {
|
|
111
|
+
x: guideConfig.current.posIncrement[0],
|
|
112
|
+
y: guideConfig.current.posIncrement[1]
|
|
113
|
+
});
|
|
137
114
|
}
|
|
138
|
-
}]);
|
|
139
|
-
return Orb;
|
|
140
|
-
}(BaseOrb);
|
|
141
|
-
let GuideOrb = /*#__PURE__*/function (_BaseOrb2) {
|
|
142
|
-
_inherits(GuideOrb, _BaseOrb2);
|
|
143
|
-
var _super2 = _createSuper(GuideOrb);
|
|
144
|
-
function GuideOrb() {
|
|
145
|
-
_classCallCheck(this, GuideOrb);
|
|
146
|
-
return _super2.apply(this, arguments);
|
|
147
115
|
}
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
this.gradient = gradient;
|
|
161
|
-
const deltaTimePos = Date.now() - guideConfig.current.posTimestamp;
|
|
162
|
-
const deltaTimePosPercent = deltaTimePos > _LavaLamp.transitionPositionMs ? 1 : deltaTimePos * 100 / _LavaLamp.transitionPositionMs / 100;
|
|
163
|
-
const translateX = guideConfig.current.x - (guideConfig.current.posIncrement[0] - guideConfig.current.posIncrement[0] * deltaTimePosPercent);
|
|
164
|
-
this.lastX = translateX;
|
|
165
|
-
const translateY = guideConfig.current.y - (guideConfig.current.posIncrement[1] - guideConfig.current.posIncrement[1] * deltaTimePosPercent);
|
|
166
|
-
this.lastY = translateY;
|
|
167
|
-
this.drawCircle(translateX | 0, translateY | 0, radius);
|
|
168
|
-
}
|
|
169
|
-
}]);
|
|
170
|
-
return GuideOrb;
|
|
171
|
-
}(BaseOrb);
|
|
116
|
+
var image = ctx.getImageData(0, 0, w, h),
|
|
117
|
+
data = new Uint8Array(image.data.buffer);
|
|
118
|
+
for (var i = 3; i < data.length; i += 4) data[i] /= data[i] < opts.alphaThreshold ? 6 : 1;
|
|
119
|
+
fctx.putImageData(image, 0, 0);
|
|
120
|
+
}
|
|
121
|
+
function randomVelocity() {
|
|
122
|
+
return opts.baseVel + opts.addedVel * Math.random() | 0;
|
|
123
|
+
}
|
|
124
|
+
const orbBounds = {
|
|
125
|
+
width: w,
|
|
126
|
+
height: h
|
|
127
|
+
};
|
|
172
128
|
for (let circleConfig of circlesConfig) {
|
|
173
129
|
const radius = circleConfig.baseSize * 1.5;
|
|
174
130
|
const randomRadius = radius + radius / 2 * Math.random() | 0;
|
|
175
|
-
|
|
131
|
+
const drawerInstance = new CanvasOrbDrawer(randomRadius);
|
|
132
|
+
orbs.push(new _Orbs.Orb(drawerInstance, randomVelocity(), orbBounds, randomRadius));
|
|
176
133
|
}
|
|
177
|
-
const guideOrbInstance = new GuideOrb();
|
|
134
|
+
const guideOrbInstance = new _Orbs.GuideOrb(new CanvasOrbDrawer(), _LavaLamp.transitionPositionMs);
|
|
178
135
|
let guideOrbAutoInstance;
|
|
179
136
|
orbs.push(guideOrbInstance);
|
|
180
137
|
canvasRef.current.parentElement.onmouseleave = function () {
|
|
181
138
|
const indexOfGuide = orbs.indexOf(guideOrbInstance);
|
|
182
139
|
if (indexOfGuide !== -1) {
|
|
183
|
-
|
|
140
|
+
const drawerInstance = new CanvasOrbDrawer(guideOrbInstance.lastRadius);
|
|
141
|
+
guideOrbAutoInstance = new _Orbs.Orb(drawerInstance, randomVelocity(), orbBounds, guideOrbInstance.lastRadius);
|
|
184
142
|
guideOrbAutoInstance.radius = guideOrbInstance.lastRadius;
|
|
185
143
|
guideOrbAutoInstance.x = guideOrbInstance.lastX;
|
|
186
144
|
guideOrbAutoInstance.y = guideOrbInstance.lastY;
|
|
@@ -205,4 +163,4 @@ function LavaLamp(_ref) {
|
|
|
205
163
|
ref: canvasRef
|
|
206
164
|
}), /*#__PURE__*/_react.default.createElement("div", null, children));
|
|
207
165
|
}
|
|
208
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_useMergeRefs","_interopRequireDefault","_LavaLamp","_LavaLampModule","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","_typeof","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Symbol","iterator","constructor","_inherits","subClass","superClass","TypeError","create","value","writable","configurable","_setPrototypeOf","o","p","setPrototypeOf","bind","__proto__","_createSuper","Derived","hasNativeReflectConstruct","_isNativeReflectConstruct","_createSuperInternal","Super","_getPrototypeOf","result","NewTarget","Reflect","construct","arguments","apply","_possibleConstructorReturn","self","_assertThisInitialized","ReferenceError","sham","Proxy","Boolean","valueOf","e","getPrototypeOf","_classCallCheck","instance","Constructor","_defineProperties","target","props","i","length","descriptor","enumerable","_toPropertyKey","_createClass","protoProps","staticProps","arg","_toPrimitive","String","input","hint","prim","toPrimitive","undefined","res","Number","LavaLamp","_ref","className","children","guideConfig","useRef","size","sizeTimestamp","Date","now","sizeIncrement","x","y","posTimestamp","posIncrement","_useLavaLampSetup","useLavaLampSetup","current","_size","relativeTo","circlesConfig","d","_canvasRef","canvasRef","useMergeRefs","useEffect","fc","baseColor","getComputedStyle","getPropertyValue","c","document","createElement","w","width","h","height","ctx","getContext","fctx","opts","orbCount","baseVel","Math","max","addedVel","alphaThreshold","orbs","animFrame","anim","window","requestAnimationFrame","clearRect","fillStyle","fillRect","step","image","getImageData","data","Uint8Array","buffer","putImageData","BaseOrb","oldDrawCircle","radius","gradient","translate","beginPath","arc","PI","fill","drawCircle","Orb","_BaseOrb","_super","_this","random","color","createRadialGradient","addColorStop","concat","radiant","vel","vx","cos","vy","sin","GuideOrb","_BaseOrb2","_super2","deltaTime","deltaTimePercent","lastRadius","deltaTimePos","deltaTimePosPercent","transitionPositionMs","translateX","lastX","translateY","lastY","circleConfig","baseSize","randomRadius","push","guideOrbInstance","guideOrbAutoInstance","parentElement","onmouseleave","indexOfGuide","indexOf","splice","onmouseenter","cancelAnimationFrame","Styles","root","ref"],"sources":["../../../../src/components/LavaLamp/v2/LavaLamp.tsx"],"sourcesContent":["import React, { PropsWithChildren, useEffect, useMemo, useRef } from \"react\";\nimport useBreakpoint from \"../../../hooks/ui/useBreakpoint\";\nimport useMergeRefs from \"../../../hooks/useMergeRefs\";\nimport useLavaLampSetup, { transitionPositionMs } from \"../LavaLamp.data\";\nimport Styles from \"./LavaLamp.module.scss\";\n\nexport default function LavaLamp({\n  className,\n  children,\n}: PropsWithChildren<{ className: string }>) {\n  const guideConfig = useRef<{\n    x: number;\n    y: number;\n    posTimestamp: number;\n    posIncrement: [x: number, y: number];\n\n    size: number;\n    sizeTimestamp: number;\n    sizeIncrement: number;\n  }>({\n    size: 0,\n    sizeTimestamp: Date.now(),\n    sizeIncrement: 0,\n    x: 0,\n    y: 0,\n    posTimestamp: Date.now(),\n    posIncrement: [0, 0],\n  });\n  const { relativeTo, circlesConfig, d } = useLavaLampSetup(\n    (x, y) => {\n      guideConfig.current.posIncrement = [\n        x - guideConfig.current.x,\n        y - guideConfig.current.y,\n      ];\n      guideConfig.current.x = x;\n      guideConfig.current.y = y;\n      guideConfig.current.posTimestamp = Date.now();\n    },\n    (_size) => {\n      const size = _size * 1.2;\n      guideConfig.current.sizeIncrement =\n        guideConfig.current.size === 0 ? 0 : size - guideConfig.current.size;\n      guideConfig.current.size = size;\n      guideConfig.current.sizeTimestamp = Date.now();\n    }\n  );\n  const _canvasRef = useRef<HTMLCanvasElement>(null);\n  const canvasRef = useMergeRefs(\n    _canvasRef,\n    relativeTo as unknown as typeof _canvasRef\n  );\n  useEffect(() => {\n    if (!d) return;\n    const fc = canvasRef.current!;\n\n    const baseColor =\n      getComputedStyle(relativeTo.current!).getPropertyValue(\n        \"--digital-blue\"\n      ) || \"#000000\";\n\n    var c = document.createElement(\"canvas\"),\n      w = (c.width = fc.width = d.width),\n      h = (c.height = fc.height = d.height),\n      ctx = c.getContext(\"2d\")!,\n      fctx = fc.getContext(\"2d\")!, // f means final\n      opts = {\n        orbCount: circlesConfig.length,\n        baseVel: Math.max(d.width * 0.0010, 1),\n        addedVel: Math.max(d.width * 0.0010, 1),\n\n        alphaThreshold: 200,\n      },\n      orbs = [] as (Orb | GuideOrb)[];\n\n    let animFrame: number;\n    function anim() {\n      animFrame = window.requestAnimationFrame(anim);\n\n      ctx.clearRect(0, 0, w, h);\n      fctx.fillStyle = \"#0000\";\n      fctx.fillRect(0, 0, w, h);\n\n      for (var i = 0; i < orbs.length; i++) orbs[i].step();\n\n      var image = ctx.getImageData(0, 0, w, h),\n        data = new Uint8Array(image.data.buffer);\n\n      for (var i = 3; i < data.length; i += 4)\n        data[i] /= data[i] < opts.alphaThreshold ? 6 : 1;\n\n      fctx.putImageData(image, 0, 0);\n    }\n\n    class BaseOrb {\n      protected gradient!: CanvasGradient;\n\n      private oldDrawCircle(x: number, y: number, radius: number) {\n        ctx.fillStyle = this.gradient;\n        ctx.translate(x | 0, y | 0);\n        ctx.beginPath();\n        ctx.arc(0, 0, radius, 0, Math.PI * 2);\n        ctx.fill();\n        ctx.translate(-x | 0, -y | 0);\n      }\n      drawCircle(x: number, y: number, radius: number) {\n        this.oldDrawCircle(x, y, radius);\n      }\n    }\n\n    class Orb extends BaseOrb {\n      x: number;\n      y: number;\n      vx: number;\n      vy: number;\n      radius: number;\n\n      constructor(radius: number) {\n        super();\n        this.x = (Math.random() * w) | 0;\n        this.y = (Math.random() * h) | 0;\n        this.radius = radius;\n\n        var color = baseColor;\n        this.gradient = ctx.createRadialGradient(0, 0, 0, 0, 0, this.radius);\n        this.gradient.addColorStop(0, `${color}ff`);\n        this.gradient.addColorStop(0.8, `${color}cc`);\n        this.gradient.addColorStop(1, `${color}00`);\n\n        var radiant = Math.random() * Math.PI * 2,\n          vel = (opts.baseVel + opts.addedVel * Math.random()) | 0;\n\n        vel *= 0.2;\n\n        this.vx = Math.cos(radiant) * vel;\n        this.vy = Math.sin(radiant) * vel;\n      }\n      step() {\n        this.x += this.vx;\n        this.y += this.vy;\n\n        var radius = this.radius / 2;\n\n        if (this.x < -radius || this.x > w + radius) this.vx *= -1;\n\n        if (this.y < -radius || this.y > h + radius) this.vy *= -1;\n\n        this.drawCircle(this.x | 0, this.y | 0, this.radius);\n      }\n    }\n\n    class GuideOrb extends BaseOrb {\n      lastRadius!: number;\n      lastX!: number;\n      lastY!: number;\n      step() {\n        const deltaTime = Date.now() - guideConfig.current.sizeTimestamp;\n        const deltaTimePercent =\n          deltaTime > 250 ? 1 : (deltaTime * 100) / 250 / 100;\n\n        const radius =\n          guideConfig.current.size -\n          (guideConfig.current.sizeIncrement -\n            guideConfig.current.sizeIncrement * deltaTimePercent);\n\n        this.lastRadius = radius;\n\n        var color = baseColor;\n\n        const gradient = ctx.createRadialGradient(0, 0, 0, 0, 0, radius);\n        gradient.addColorStop(0, `${color}ff`);\n        gradient.addColorStop(0.8, `${color}cc`);\n        gradient.addColorStop(1, `${color}00`);\n        this.gradient = gradient;\n\n        const deltaTimePos = Date.now() - guideConfig.current.posTimestamp;\n        const deltaTimePosPercent =\n          deltaTimePos > transitionPositionMs\n            ? 1\n            : (deltaTimePos * 100) / transitionPositionMs / 100;\n\n        const translateX =\n          guideConfig.current.x -\n          (guideConfig.current.posIncrement[0] -\n            guideConfig.current.posIncrement[0] * deltaTimePosPercent);\n        this.lastX = translateX;\n        const translateY =\n          guideConfig.current.y -\n          (guideConfig.current.posIncrement[1] -\n            guideConfig.current.posIncrement[1] * deltaTimePosPercent);\n        this.lastY = translateY;\n\n        this.drawCircle(translateX | 0, translateY | 0, radius);\n      }\n    }\n\n    for (let circleConfig of circlesConfig) {\n      const radius = circleConfig.baseSize * 1.5;\n      const randomRadius = (radius + (radius / 2) * Math.random()) | 0;\n      orbs.push(new Orb(randomRadius));\n    }\n    const guideOrbInstance = new GuideOrb();\n    let guideOrbAutoInstance: Orb;\n    orbs.push(guideOrbInstance);\n\n    canvasRef.current!.parentElement!.onmouseleave = () => {\n      const indexOfGuide = orbs.indexOf(guideOrbInstance);\n      if (indexOfGuide !== -1) {\n        guideOrbAutoInstance = new Orb(guideOrbInstance.lastRadius);\n        guideOrbAutoInstance.radius = guideOrbInstance.lastRadius;\n        guideOrbAutoInstance.x = guideOrbInstance.lastX;\n        guideOrbAutoInstance.y = guideOrbInstance.lastY;\n        orbs.splice(indexOfGuide, 1);\n        orbs.push(guideOrbAutoInstance);\n      }\n    };\n    canvasRef.current!.parentElement!.onmouseenter = () => {\n      if (orbs.indexOf(guideOrbInstance) === -1) {\n        orbs.push(guideOrbInstance);\n        orbs.splice(orbs.indexOf(guideOrbAutoInstance), 1);\n      }\n    };\n\n    anim();\n\n    return () => {\n      window.cancelAnimationFrame(animFrame);\n    };\n  }, [circlesConfig]);\n\n  return (\n    <div className={`${className} ${Styles.root}`}>\n      <canvas ref={canvasRef} />\n      <div>{children}</div>\n    </div>\n  );\n}\n"],"mappings":"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"}
|
|
166
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_useMergeRefs","_interopRequireDefault","_LavaLamp","_LavaLampModule","_Orbs","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","_typeof","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Symbol","iterator","constructor","_classCallCheck","instance","Constructor","TypeError","_defineProperties","target","props","i","length","descriptor","enumerable","configurable","writable","_toPropertyKey","_createClass","protoProps","staticProps","arg","_toPrimitive","String","input","hint","prim","toPrimitive","undefined","res","Number","LavaLamp","_ref","className","children","guideConfig","useRef","size","sizeTimestamp","Date","now","sizeIncrement","x","y","posTimestamp","posIncrement","_useLavaLampSetup","useLavaLampSetup","current","_size","relativeTo","circlesConfig","d","_canvasRef","canvasRef","useMergeRefs","useEffect","fc","baseColor","getComputedStyle","getPropertyValue","c","document","createElement","w","width","h","height","ctx","getContext","fctx","opts","orbCount","baseVel","Math","max","addedVel","alphaThreshold","orbs","CanvasOrbDrawer","gradientRadius","gradient","newGradient","value","color","radius","createRadialGradient","addColorStop","concat","oldDrawCircle","_this$gradient","fillStyle","translate","beginPath","arc","PI","fill","drawOrb","animFrame","anim","window","requestAnimationFrame","clearRect","fillRect","thisOrb","Orb","step","image","getImageData","data","Uint8Array","buffer","putImageData","randomVelocity","random","orbBounds","circleConfig","baseSize","randomRadius","drawerInstance","push","guideOrbInstance","GuideOrb","transitionPositionMs","guideOrbAutoInstance","parentElement","onmouseleave","indexOfGuide","indexOf","lastRadius","lastX","lastY","splice","onmouseenter","cancelAnimationFrame","Styles","root","ref"],"sources":["../../../../src/components/LavaLamp/v2/LavaLamp.tsx"],"sourcesContent":["import React, { PropsWithChildren, useEffect, useMemo, useRef } from \"react\";\nimport useMergeRefs from \"../../../hooks/useMergeRefs\";\nimport useLavaLampSetup, { transitionPositionMs } from \"../LavaLamp.data\";\nimport Styles from \"./LavaLamp.module.scss\";\nimport { GuideOrb, Orb, OrbDrawer } from \"../../../models/Orbs\";\n\nexport default function LavaLamp({\n  className,\n  children,\n}: PropsWithChildren<{ className: string }>) {\n  const guideConfig = useRef<{\n    x: number;\n    y: number;\n    posTimestamp: number;\n    posIncrement: [x: number, y: number];\n\n    size: number;\n    sizeTimestamp: number;\n    sizeIncrement: number;\n  }>({\n    size: 0,\n    sizeTimestamp: Date.now(),\n    sizeIncrement: 0,\n    x: 0,\n    y: 0,\n    posTimestamp: Date.now(),\n    posIncrement: [0, 0],\n  });\n  const { relativeTo, circlesConfig, d } = useLavaLampSetup(\n    (x, y) => {\n      guideConfig.current.posIncrement = [\n        x - guideConfig.current.x,\n        y - guideConfig.current.y,\n      ];\n      guideConfig.current.x = x;\n      guideConfig.current.y = y;\n      guideConfig.current.posTimestamp = Date.now();\n    },\n    (_size) => {\n      const size = _size * 1.2;\n      guideConfig.current.sizeIncrement =\n        guideConfig.current.size === 0 ? 0 : size - guideConfig.current.size;\n      guideConfig.current.size = size;\n      guideConfig.current.sizeTimestamp = Date.now();\n    }\n  );\n  const _canvasRef = useRef<HTMLCanvasElement>(null);\n  const canvasRef = useMergeRefs(\n    _canvasRef,\n    relativeTo as unknown as typeof _canvasRef\n  );\n  useEffect(() => {\n    if (!d) return;\n    const fc = canvasRef.current!;\n\n    const baseColor =\n      getComputedStyle(relativeTo.current!).getPropertyValue(\n        \"--digital-blue\"\n      ) || \"#000000\";\n\n    var c = document.createElement(\"canvas\"),\n      w = (c.width = fc.width = d.width),\n      h = (c.height = fc.height = d.height),\n      ctx = c.getContext(\"2d\")!,\n      fctx = fc.getContext(\"2d\")!, // f means final\n      opts = {\n        orbCount: circlesConfig.length,\n        baseVel: Math.max(d.width * 0.001, 1),\n        addedVel: Math.max(d.width * 0.001, 1),\n\n        alphaThreshold: 200,\n      },\n      orbs = [] as (Orb | GuideOrb)[];\n    class CanvasOrbDrawer implements OrbDrawer {\n      protected gradient?: CanvasGradient;\n\n      private newGradient(color: string, radius: number) {\n        const gradient = ctx.createRadialGradient(0, 0, 0, 0, 0, radius);\n        gradient.addColorStop(0, `${color}ff`);\n        gradient.addColorStop(0.8, `${color}cc`);\n        gradient.addColorStop(1, `${color}00`);\n\n        return gradient;\n      }\n\n      private oldDrawCircle(x: number, y: number, radius: number) {\n        ctx.fillStyle = this.gradient ?? this.newGradient(baseColor, radius);\n        ctx.translate(x | 0, y | 0);\n        ctx.beginPath();\n        ctx.arc(0, 0, radius, 0, Math.PI * 2);\n        ctx.fill();\n        ctx.translate(-x | 0, -y | 0);\n      }\n      drawOrb(x: number, y: number, radius: number) {\n        this.oldDrawCircle(x, y, radius);\n      }\n\n      constructor(gradientRadius?: number) {\n        if (gradientRadius)\n          this.gradient = this.newGradient(baseColor, gradientRadius);\n      }\n    }\n\n    let animFrame: number;\n    function anim() {\n      animFrame = window.requestAnimationFrame(anim);\n\n      ctx.clearRect(0, 0, w, h);\n      fctx.fillStyle = \"#0000\";\n      fctx.fillRect(0, 0, w, h);\n\n      for (var i = 0; i < orbs.length; i++) {\n        const thisOrb = orbs[i];\n        if (thisOrb instanceof Orb) {\n          thisOrb.step();\n        } else {\n          thisOrb.step(\n            guideConfig.current!.size,\n            guideConfig.current!.sizeIncrement,\n            guideConfig.current!.sizeTimestamp,\n            guideConfig.current.posTimestamp,\n            guideConfig.current!,\n            {\n              x: guideConfig.current!.posIncrement[0],\n              y: guideConfig.current!.posIncrement[1],\n            }\n          );\n        }\n      }\n\n      var image = ctx.getImageData(0, 0, w, h),\n        data = new Uint8Array(image.data.buffer);\n\n      for (var i = 3; i < data.length; i += 4)\n        data[i] /= data[i] < opts.alphaThreshold ? 6 : 1;\n\n      fctx.putImageData(image, 0, 0);\n    }\n\n    function randomVelocity() {\n      return (opts.baseVel + opts.addedVel * Math.random()) | 0;\n    }\n    const orbBounds = { width: w, height: h };\n\n    for (let circleConfig of circlesConfig) {\n      const radius = circleConfig.baseSize * 1.5;\n      const randomRadius = (radius + (radius / 2) * Math.random()) | 0;\n      const drawerInstance = new CanvasOrbDrawer(randomRadius);\n      orbs.push(\n        new Orb(drawerInstance, randomVelocity(), orbBounds, randomRadius)\n      );\n    }\n    const guideOrbInstance = new GuideOrb(\n      new CanvasOrbDrawer(),\n      transitionPositionMs\n    );\n    let guideOrbAutoInstance: Orb;\n    orbs.push(guideOrbInstance);\n\n    canvasRef.current!.parentElement!.onmouseleave = () => {\n      const indexOfGuide = orbs.indexOf(guideOrbInstance);\n      if (indexOfGuide !== -1) {\n        const drawerInstance = new CanvasOrbDrawer(guideOrbInstance.lastRadius);\n        guideOrbAutoInstance = new Orb(\n          drawerInstance,\n          randomVelocity(),\n          orbBounds,\n          guideOrbInstance.lastRadius\n        );\n        guideOrbAutoInstance.radius = guideOrbInstance.lastRadius;\n        guideOrbAutoInstance.x = guideOrbInstance.lastX;\n        guideOrbAutoInstance.y = guideOrbInstance.lastY;\n        orbs.splice(indexOfGuide, 1);\n        orbs.push(guideOrbAutoInstance);\n      }\n    };\n    canvasRef.current!.parentElement!.onmouseenter = () => {\n      if (orbs.indexOf(guideOrbInstance) === -1) {\n        orbs.push(guideOrbInstance);\n        orbs.splice(orbs.indexOf(guideOrbAutoInstance), 1);\n      }\n    };\n\n    anim();\n\n    return () => {\n      window.cancelAnimationFrame(animFrame);\n    };\n  }, [circlesConfig]);\n\n  return (\n    <div className={`${className} ${Styles.root}`}>\n      <canvas ref={canvasRef} />\n      <div>{children}</div>\n    </div>\n  );\n}\n"],"mappings":"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"}
|
|
@@ -2,6 +2,6 @@ import React from "react";
|
|
|
2
2
|
/**
|
|
3
3
|
* A component to inject some spacing between component when required
|
|
4
4
|
**/
|
|
5
|
-
export default function Spacing({ size }: {
|
|
6
|
-
size:
|
|
5
|
+
export default function Spacing({ size, }: {
|
|
6
|
+
size: OnepercentUtility.UIElements.SpacingVariants | "stretch";
|
|
7
7
|
}): React.JSX.Element;
|
|
@@ -1,19 +1,30 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
3
4
|
Object.defineProperty(exports, "__esModule", {
|
|
4
5
|
value: true
|
|
5
6
|
});
|
|
6
7
|
exports.default = Spacing;
|
|
7
|
-
var _react =
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
9
|
var _SpacingModule = _interopRequireDefault(require("./Spacing.module.scss"));
|
|
10
|
+
var _OneUIProvider = require("../../context/OneUIProvider");
|
|
9
11
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
12
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
13
|
+
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; }
|
|
10
14
|
/**
|
|
11
15
|
* A component to inject some spacing between component when required
|
|
12
16
|
**/
|
|
13
17
|
function Spacing(_ref) {
|
|
14
18
|
let size = _ref.size;
|
|
19
|
+
const spacingClasses = (0, _OneUIProvider.useOneUIConfig)("component.spacing.variants", {
|
|
20
|
+
large: _SpacingModule.default.spacing_large,
|
|
21
|
+
small: _SpacingModule.default.spacing_small
|
|
22
|
+
});
|
|
23
|
+
const cls = (0, _react.useMemo)(function () {
|
|
24
|
+
return size === "stretch" ? _SpacingModule.default.spacing_stretch : spacingClasses[size];
|
|
25
|
+
}, [size]);
|
|
15
26
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
16
|
-
className: "".concat(_SpacingModule.default.spacing, " ").concat(
|
|
27
|
+
className: "".concat(_SpacingModule.default.spacing, " ").concat(cls)
|
|
17
28
|
});
|
|
18
29
|
}
|
|
19
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfU3BhY2luZ01vZHVsZSIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJfT25lVUlQcm92aWRlciIsIm9iaiIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiX2dldFJlcXVpcmVXaWxkY2FyZENhY2hlIiwibm9kZUludGVyb3AiLCJXZWFrTWFwIiwiY2FjaGVCYWJlbEludGVyb3AiLCJjYWNoZU5vZGVJbnRlcm9wIiwiX3R5cGVvZiIsImNhY2hlIiwiaGFzIiwiZ2V0IiwibmV3T2JqIiwiaGFzUHJvcGVydHlEZXNjcmlwdG9yIiwiT2JqZWN0IiwiZGVmaW5lUHJvcGVydHkiLCJnZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3IiLCJrZXkiLCJwcm90b3R5cGUiLCJoYXNPd25Qcm9wZXJ0eSIsImNhbGwiLCJkZXNjIiwic2V0IiwiU3BhY2luZyIsIl9yZWYiLCJzaXplIiwic3BhY2luZ0NsYXNzZXMiLCJ1c2VPbmVVSUNvbmZpZyIsImxhcmdlIiwiU3R5bGVzIiwic3BhY2luZ19sYXJnZSIsInNtYWxsIiwic3BhY2luZ19zbWFsbCIsImNscyIsInVzZU1lbW8iLCJzcGFjaW5nX3N0cmV0Y2giLCJjcmVhdGVFbGVtZW50IiwiY2xhc3NOYW1lIiwiY29uY2F0Iiwic3BhY2luZyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1NwYWNpbmcvU3BhY2luZy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IHVzZU1lbW8gfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBTdHlsZXMgZnJvbSBcIi4vU3BhY2luZy5tb2R1bGUuc2Nzc1wiO1xuaW1wb3J0IHsgdXNlT25lVUlDb25maWcgfSBmcm9tIFwiLi4vLi4vY29udGV4dC9PbmVVSVByb3ZpZGVyXCI7XG5cbi8qKlxuICogQSBjb21wb25lbnQgdG8gaW5qZWN0IHNvbWUgc3BhY2luZyBiZXR3ZWVuIGNvbXBvbmVudCB3aGVuIHJlcXVpcmVkXG4gKiovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBTcGFjaW5nKHtcbiAgc2l6ZSxcbn06IHtcbiAgc2l6ZTogT25lcGVyY2VudFV0aWxpdHkuVUlFbGVtZW50cy5TcGFjaW5nVmFyaWFudHMgfCBcInN0cmV0Y2hcIjtcbn0pIHtcbiAgY29uc3Qgc3BhY2luZ0NsYXNzZXMgPSB1c2VPbmVVSUNvbmZpZyhcImNvbXBvbmVudC5zcGFjaW5nLnZhcmlhbnRzXCIsIHtcbiAgICBsYXJnZTogU3R5bGVzLnNwYWNpbmdfbGFyZ2UsXG4gICAgc21hbGw6IFN0eWxlcy5zcGFjaW5nX3NtYWxsLFxuICB9KTtcblxuICBjb25zdCBjbHMgPSB1c2VNZW1vKFxuICAgICgpID0+IChzaXplID09PSBcInN0cmV0Y2hcIiA/IFN0eWxlcy5zcGFjaW5nX3N0cmV0Y2ggOiBzcGFjaW5nQ2xhc3Nlc1tzaXplXSksXG4gICAgW3NpemVdXG4gICk7XG5cbiAgcmV0dXJuIDxkaXYgY2xhc3NOYW1lPXtgJHtTdHlsZXMuc3BhY2luZ30gJHtjbHN9YH0gLz47XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHVCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxjQUFBLEdBQUFDLHNCQUFBLENBQUFGLE9BQUE7QUFDQSxJQUFBRyxjQUFBLEdBQUFILE9BQUE7QUFBNkQsU0FBQUUsdUJBQUFFLEdBQUEsV0FBQUEsR0FBQSxJQUFBQSxHQUFBLENBQUFDLFVBQUEsR0FBQUQsR0FBQSxLQUFBRSxPQUFBLEVBQUFGLEdBQUE7QUFBQSxTQUFBRyx5QkFBQUMsV0FBQSxlQUFBQyxPQUFBLGtDQUFBQyxpQkFBQSxPQUFBRCxPQUFBLFFBQUFFLGdCQUFBLE9BQUFGLE9BQUEsWUFBQUYsd0JBQUEsWUFBQUEseUJBQUFDLFdBQUEsV0FBQUEsV0FBQSxHQUFBRyxnQkFBQSxHQUFBRCxpQkFBQSxLQUFBRixXQUFBO0FBQUEsU0FBQVQsd0JBQUFLLEdBQUEsRUFBQUksV0FBQSxTQUFBQSxXQUFBLElBQUFKLEdBQUEsSUFBQUEsR0FBQSxDQUFBQyxVQUFBLFdBQUFELEdBQUEsUUFBQUEsR0FBQSxhQUFBUSxPQUFBLENBQUFSLEdBQUEseUJBQUFBLEdBQUEsNEJBQUFFLE9BQUEsRUFBQUYsR0FBQSxVQUFBUyxLQUFBLEdBQUFOLHdCQUFBLENBQUFDLFdBQUEsT0FBQUssS0FBQSxJQUFBQSxLQUFBLENBQUFDLEdBQUEsQ0FBQVYsR0FBQSxZQUFBUyxLQUFBLENBQUFFLEdBQUEsQ0FBQVgsR0FBQSxTQUFBWSxNQUFBLFdBQUFDLHFCQUFBLEdBQUFDLE1BQUEsQ0FBQUMsY0FBQSxJQUFBRCxNQUFBLENBQUFFLHdCQUFBLFdBQUFDLEdBQUEsSUFBQWpCLEdBQUEsUUFBQWlCLEdBQUEsa0JBQUFILE1BQUEsQ0FBQUksU0FBQSxDQUFBQyxjQUFBLENBQUFDLElBQUEsQ0FBQXBCLEdBQUEsRUFBQWlCLEdBQUEsU0FBQUksSUFBQSxHQUFBUixxQkFBQSxHQUFBQyxNQUFBLENBQUFFLHdCQUFBLENBQUFoQixHQUFBLEVBQUFpQixHQUFBLGNBQUFJLElBQUEsS0FBQUEsSUFBQSxDQUFBVixHQUFBLElBQUFVLElBQUEsQ0FBQUMsR0FBQSxLQUFBUixNQUFBLENBQUFDLGNBQUEsQ0FBQUgsTUFBQSxFQUFBSyxHQUFBLEVBQUFJLElBQUEsWUFBQVQsTUFBQSxDQUFBSyxHQUFBLElBQUFqQixHQUFBLENBQUFpQixHQUFBLFNBQUFMLE1BQUEsQ0FBQVYsT0FBQSxHQUFBRixHQUFBLE1BQUFTLEtBQUEsSUFBQUEsS0FBQSxDQUFBYSxHQUFBLENBQUF0QixHQUFBLEVBQUFZLE1BQUEsWUFBQUEsTUFBQTtBQUU3RDtBQUNBO0FBQ0E7QUFDZSxTQUFTVyxPQUFPQSxDQUFBQyxJQUFBLEVBSTVCO0VBQUEsSUFIREMsSUFBSSxHQUFBRCxJQUFBLENBQUpDLElBQUk7RUFJSixNQUFNQyxjQUFjLEdBQUcsSUFBQUMsNkJBQWMsRUFBQyw0QkFBNEIsRUFBRTtJQUNsRUMsS0FBSyxFQUFFQyxzQkFBTSxDQUFDQyxhQUFhO0lBQzNCQyxLQUFLLEVBQUVGLHNCQUFNLENBQUNHO0VBQ2hCLENBQUMsQ0FBQztFQUVGLE1BQU1DLEdBQUcsR0FBRyxJQUFBQyxjQUFPLEVBQ2pCO0lBQUEsT0FBT1QsSUFBSSxLQUFLLFNBQVMsR0FBR0ksc0JBQU0sQ0FBQ00sZUFBZSxHQUFHVCxjQUFjLENBQUNELElBQUksQ0FBQztFQUFBLENBQUMsRUFDMUUsQ0FBQ0EsSUFBSSxDQUNQLENBQUM7RUFFRCxvQkFBTy9CLE1BQUEsQ0FBQVEsT0FBQSxDQUFBa0MsYUFBQTtJQUFLQyxTQUFTLEtBQUFDLE1BQUEsQ0FBS1Qsc0JBQU0sQ0FBQ1UsT0FBTyxPQUFBRCxNQUFBLENBQUlMLEdBQUc7RUFBRyxDQUFFLENBQUM7QUFDdkQifQ==
|
|
@@ -9,7 +9,7 @@ export declare type WalletConnectionProps = PropsWithChildren<Omit<ReturnType<ty
|
|
|
9
9
|
wallet?: string;
|
|
10
10
|
connect: () => Promise<void>;
|
|
11
11
|
disconnect: () => void;
|
|
12
|
-
changeChainId: () => void
|
|
12
|
+
changeChainId: () => Promise<void>;
|
|
13
13
|
}>;
|
|
14
14
|
declare type Props = {
|
|
15
15
|
/**
|
|
@@ -96,7 +96,7 @@ function Content(_ref) {
|
|
|
96
96
|
} catch (e) {
|
|
97
97
|
switch (e.code) {
|
|
98
98
|
case 4902:
|
|
99
|
-
window.ethereum.request({
|
|
99
|
+
yield window.ethereum.request({
|
|
100
100
|
method: "wallet_addEthereumChain",
|
|
101
101
|
params: [{
|
|
102
102
|
chainId: "0x".concat(chain.id.toString(16).padStart(2, "0")),
|
|
@@ -109,6 +109,8 @@ function Content(_ref) {
|
|
|
109
109
|
}
|
|
110
110
|
}]
|
|
111
111
|
});
|
|
112
|
+
default:
|
|
113
|
+
throw e;
|
|
112
114
|
}
|
|
113
115
|
}
|
|
114
116
|
});
|
|
@@ -138,4 +140,4 @@ var _default = WalletConnectionWrapper;
|
|
|
138
140
|
exports.default = _default;
|
|
139
141
|
const BaseWalletConnectionWrapper = /*#__PURE__*/(0, _react.forwardRef)(_BaseWalletConnectionWrapper);
|
|
140
142
|
exports.BaseWalletConnectionWrapper = BaseWalletConnectionWrapper;
|
|
141
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_useWallet","_useAsyncControl","_interopRequireDefault","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","_typeof","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_slicedToArray","arr","i","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","TypeError","o","minLen","_arrayLikeToArray","n","toString","slice","constructor","name","Array","from","test","len","length","arr2","_i","Symbol","iterator","_s","_e","_x","_r","_arr","_n","_d","next","done","push","value","err","return","isArray","asyncGeneratorStep","gen","resolve","reject","_next","_throw","arg","info","error","Promise","then","_asyncToGenerator","fn","self","args","arguments","apply","undefined","_extends","assign","bind","target","source","_WalletConnectionWrapper","props","ref","createElement","UseWalletProvider","Content","compRef","createRef","_BaseWalletConnectionWrapper","_ref","ProviderUnavailable","ChainIdInvalid","chain","ProvidedContentWrapper","children","wallet","useWallet","connectionAsyncWrapper","useAsyncControl","connect","_ref2","process","localStorage","setItem","disconnect","reset","removeItem","useEffect","autoConnect","getItem","account","useImperativeHandle","_useState","useState","window","ethereum","_useState2","isProviderAvailable","isChainIdValid","useMemo","isConnected","chainId","id","changeChainId","_changeChainId","request","method","params","concat","padStart","e","code","chainName","rpcUrls","rpcUrl","blockExplorerUrls","explorerUrl","nativeCurrency","symbol","currency","decimals","ContentWrapper","Fragment","isConnectedAndValidChain","WalletConnectionWrapper","forwardRef","_default","exports","BaseWalletConnectionWrapper"],"sources":["../../../src/components/WalletConnectionWrapper/WalletConnectionWrapper.tsx"],"sourcesContent":["import React, {\n  createRef,\n  ForwardedRef,\n  forwardRef,\n  PropsWithChildren,\n  ReactElement,\n  ReactNode,\n  useEffect,\n  useImperativeHandle,\n  useMemo,\n  useState,\n} from \"react\";\nimport { useWallet, UseWalletProvider } from \"use-wallet\";\nimport useAsyncControl from \"../../hooks/useAsyncControl\";\n\nexport type WalletConnectionProps = PropsWithChildren<\n  Omit<ReturnType<typeof useAsyncControl>, \"process\"> & {\n    chainId?: number;\n    isChainIdValid: boolean | undefined;\n    isProviderAvailable: boolean;\n    isConnectedAndValidChain: boolean;\n    isConnected: boolean;\n    wallet?: string;\n\n    connect: () => Promise<void>;\n    disconnect: () => void;\n    changeChainId: () => void;\n  }\n>;\n\ntype Props = {\n  /**\n   * The chain id that the user is expected to connect to\n   */\n  chain?: {\n    id: number;\n    rpcUrl: string;\n    explorerUrl: string;\n    name: string;\n    currency: string;\n  };\n\n  /**\n   * When the user doesn't have a provider like metamask available\n   */\n  ProviderUnavailable?: React.FunctionComponent;\n\n  /**\n   * This is invoked when the chain ID is not available\n   */\n  ChainIdInvalid?: React.FunctionComponent<{\n    changeChainId: () => void;\n  }>;\n\n  /**\n   * This renders the content that is shown inside the wallet content\n   */\n  Content: (props: WalletConnectionProps) => ReactElement;\n};\nfunction _WalletConnectionWrapper(\n  props: PropsWithChildren<Props>,\n  ref: ForwardedRef<{\n    connect: () => Promise<void>;\n    disconnect: () => void;\n  }>\n) {\n  return (\n    <UseWalletProvider>\n      <Content compRef={ref || createRef()} {...props} />\n    </UseWalletProvider>\n  );\n}\n/**\n * This component handles a lot of cenarios when dealing with the wallet connection to different providers (ex: Metamask)\n **/\nfunction _BaseWalletConnectionWrapper(\n  props: Props & {\n    children?: any;\n  },\n  ref: ForwardedRef<{\n    connect: () => Promise<void>;\n    disconnect: () => void;\n  }>\n) {\n  return <Content compRef={ref || createRef()} {...props} />;\n}\n\nfunction Content({\n  ProviderUnavailable,\n  ChainIdInvalid,\n  chain,\n  Content: ProvidedContentWrapper,\n  compRef,\n  children,\n}: PropsWithChildren<\n  Props & {\n    compRef: ForwardedRef<{\n      connect: () => Promise<void>;\n      disconnect: () => void;\n    }>;\n  }\n>) {\n  const wallet = useWallet();\n  const connectionAsyncWrapper = useAsyncControl();\n  const connect = async () => {\n    await connectionAsyncWrapper.process(async () => {\n      await wallet.connect(\"injected\");\n      localStorage.setItem(\"auto_connect\", \"true\");\n    });\n  };\n  const disconnect = () => {\n    wallet.reset();\n    localStorage.removeItem(\"auto_connect\");\n  };\n  useEffect(() => {\n    const autoConnect = !!localStorage.getItem(\"auto_connect\");\n    if (autoConnect && !wallet.account) connect();\n  }, []);\n  useImperativeHandle(\n    compRef,\n    () => ({\n      connect,\n      disconnect,\n    }),\n    [wallet]\n  );\n  const [isProviderAvailable] = useState(() => !!window.ethereum);\n  /**\n   * true - Mostrar o conteudo (ex: form de transferencia)\n   * false - Mostrar o botão de trocar a chain\n   *\n   * undefined ???\n   */\n  const isChainIdValid = useMemo(\n    () =>\n      chain\n        ? wallet.isConnected()\n          ? wallet.chainId === chain.id\n          : true\n        : undefined,\n    [wallet, chain?.id]\n  );\n\n  async function changeChainId() {\n    try {\n      await window.ethereum!.request({\n        method: \"wallet_switchEthereumChain\",\n        params: [\n          {\n            chainId: `0x${chain!.id.toString(16).padStart(2, \"0\")}`,\n          },\n        ],\n      });\n    } catch (e: any) {\n      switch (e.code) {\n        case 4902:\n          window.ethereum!.request({\n            method: \"wallet_addEthereumChain\",\n            params: [\n              {\n                chainId: `0x${chain!.id.toString(16).padStart(2, \"0\")}`,\n                chainName: chain!.name,\n                rpcUrls: [chain!.rpcUrl],\n                blockExplorerUrls: [chain!.explorerUrl],\n                nativeCurrency: {\n                  symbol: chain!.currency,\n                  decimals: 18,\n                },\n              },\n            ],\n          });\n      }\n    }\n  }\n  const ContentWrapper = ProvidedContentWrapper as any;\n  return (\n    <>\n      {ProviderUnavailable && !isProviderAvailable && <ProviderUnavailable />}\n      {ChainIdInvalid && !isChainIdValid && (\n        <ChainIdInvalid changeChainId={changeChainId} />\n      )}\n      {\n        <ContentWrapper\n          {...connectionAsyncWrapper}\n          isChainIdValid={isChainIdValid}\n          isProviderAvailable={isProviderAvailable}\n          isConnectedAndValidChain={isChainIdValid && wallet.isConnected()}\n          connect={connect}\n          disconnect={disconnect}\n          changeChainId={changeChainId}\n          chainId={wallet.chainId}\n          isConnected={wallet.isConnected()}\n          wallet={wallet.account}\n        >\n          {children}\n        </ContentWrapper>\n      }\n    </>\n  );\n}\n\n/**\n * This component handles some cenarios when dealing with the wallet connection to different providers (ex: Metamask)\n **/\nconst WalletConnectionWrapper = forwardRef(_WalletConnectionWrapper);\nexport default WalletConnectionWrapper;\n\nexport const BaseWalletConnectionWrapper = forwardRef(\n  _BaseWalletConnectionWrapper\n);\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AAYA,IAAAC,UAAA,GAAAD,OAAA;AACA,IAAAE,gBAAA,GAAAC,sBAAA,CAAAH,OAAA;AAA0D,SAAAG,uBAAAC,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAAA,SAAAG,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAT,wBAAAK,GAAA,EAAAI,WAAA,SAAAA,WAAA,IAAAJ,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,aAAAQ,OAAA,CAAAR,GAAA,yBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAS,KAAA,GAAAN,wBAAA,CAAAC,WAAA,OAAAK,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAV,GAAA,YAAAS,KAAA,CAAAE,GAAA,CAAAX,GAAA,SAAAY,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAjB,GAAA,QAAAiB,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAApB,GAAA,EAAAiB,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAhB,GAAA,EAAAiB,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAjB,GAAA,CAAAiB,GAAA,SAAAL,MAAA,CAAAV,OAAA,GAAAF,GAAA,MAAAS,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAtB,GAAA,EAAAY,MAAA,YAAAA,MAAA;AAAA,SAAAW,eAAAC,GAAA,EAAAC,CAAA,WAAAC,eAAA,CAAAF,GAAA,KAAAG,qBAAA,CAAAH,GAAA,EAAAC,CAAA,KAAAG,2BAAA,CAAAJ,GAAA,EAAAC,CAAA,KAAAI,gBAAA;AAAA,SAAAA,iBAAA,cAAAC,SAAA;AAAA,SAAAF,4BAAAG,CAAA,EAAAC,MAAA,SAAAD,CAAA,qBAAAA,CAAA,sBAAAE,iBAAA,CAAAF,CAAA,EAAAC,MAAA,OAAAE,CAAA,GAAApB,MAAA,CAAAI,SAAA,CAAAiB,QAAA,CAAAf,IAAA,CAAAW,CAAA,EAAAK,KAAA,aAAAF,CAAA,iBAAAH,CAAA,CAAAM,WAAA,EAAAH,CAAA,GAAAH,CAAA,CAAAM,WAAA,CAAAC,IAAA,MAAAJ,CAAA,cAAAA,CAAA,mBAAAK,KAAA,CAAAC,IAAA,CAAAT,CAAA,OAAAG,CAAA,+DAAAO,IAAA,CAAAP,CAAA,UAAAD,iBAAA,CAAAF,CAAA,EAAAC,MAAA;AAAA,SAAAC,kBAAAT,GAAA,EAAAkB,GAAA,QAAAA,GAAA,YAAAA,GAAA,GAAAlB,GAAA,CAAAmB,MAAA,EAAAD,GAAA,GAAAlB,GAAA,CAAAmB,MAAA,WAAAlB,CAAA,MAAAmB,IAAA,OAAAL,KAAA,CAAAG,GAAA,GAAAjB,CAAA,GAAAiB,GAAA,EAAAjB,CAAA,IAAAmB,IAAA,CAAAnB,CAAA,IAAAD,GAAA,CAAAC,CAAA,UAAAmB,IAAA;AAAA,SAAAjB,sBAAAH,GAAA,EAAAC,CAAA,QAAAoB,EAAA,WAAArB,GAAA,gCAAAsB,MAAA,IAAAtB,GAAA,CAAAsB,MAAA,CAAAC,QAAA,KAAAvB,GAAA,4BAAAqB,EAAA,QAAAG,EAAA,EAAAC,EAAA,EAAAC,EAAA,EAAAC,EAAA,EAAAC,IAAA,OAAAC,EAAA,OAAAC,EAAA,iBAAAJ,EAAA,IAAAL,EAAA,GAAAA,EAAA,CAAAzB,IAAA,CAAAI,GAAA,GAAA+B,IAAA,QAAA9B,CAAA,QAAAX,MAAA,CAAA+B,EAAA,MAAAA,EAAA,UAAAQ,EAAA,uBAAAA,EAAA,IAAAL,EAAA,GAAAE,EAAA,CAAA9B,IAAA,CAAAyB,EAAA,GAAAW,IAAA,MAAAJ,IAAA,CAAAK,IAAA,CAAAT,EAAA,CAAAU,KAAA,GAAAN,IAAA,CAAAT,MAAA,KAAAlB,CAAA,GAAA4B,EAAA,iBAAAM,GAAA,IAAAL,EAAA,OAAAL,EAAA,GAAAU,GAAA,yBAAAN,EAAA,YAAAR,EAAA,CAAAe,MAAA,KAAAT,EAAA,GAAAN,EAAA,CAAAe,MAAA,IAAA9C,MAAA,CAAAqC,EAAA,MAAAA,EAAA,2BAAAG,EAAA,QAAAL,EAAA,aAAAG,IAAA;AAAA,SAAA1B,gBAAAF,GAAA,QAAAe,KAAA,CAAAsB,OAAA,CAAArC,GAAA,UAAAA,GAAA;AAAA,SAAAsC,mBAAAC,GAAA,EAAAC,OAAA,EAAAC,MAAA,EAAAC,KAAA,EAAAC,MAAA,EAAAlD,GAAA,EAAAmD,GAAA,cAAAC,IAAA,GAAAN,GAAA,CAAA9C,GAAA,EAAAmD,GAAA,OAAAV,KAAA,GAAAW,IAAA,CAAAX,KAAA,WAAAY,KAAA,IAAAL,MAAA,CAAAK,KAAA,iBAAAD,IAAA,CAAAb,IAAA,IAAAQ,OAAA,CAAAN,KAAA,YAAAa,OAAA,CAAAP,OAAA,CAAAN,KAAA,EAAAc,IAAA,CAAAN,KAAA,EAAAC,MAAA;AAAA,SAAAM,kBAAAC,EAAA,6BAAAC,IAAA,SAAAC,IAAA,GAAAC,SAAA,aAAAN,OAAA,WAAAP,OAAA,EAAAC,MAAA,QAAAF,GAAA,GAAAW,EAAA,CAAAI,KAAA,CAAAH,IAAA,EAAAC,IAAA,YAAAV,MAAAR,KAAA,IAAAI,kBAAA,CAAAC,GAAA,EAAAC,OAAA,EAAAC,MAAA,EAAAC,KAAA,EAAAC,MAAA,UAAAT,KAAA,cAAAS,OAAAR,GAAA,IAAAG,kBAAA,CAAAC,GAAA,EAAAC,OAAA,EAAAC,MAAA,EAAAC,KAAA,EAAAC,MAAA,WAAAR,GAAA,KAAAO,KAAA,CAAAa,SAAA;AAAA,SAAAC,SAAA,IAAAA,QAAA,GAAAlE,MAAA,CAAAmE,MAAA,GAAAnE,MAAA,CAAAmE,MAAA,CAAAC,IAAA,eAAAC,MAAA,aAAA1D,CAAA,MAAAA,CAAA,GAAAoD,SAAA,CAAAlC,MAAA,EAAAlB,CAAA,UAAA2D,MAAA,GAAAP,SAAA,CAAApD,CAAA,YAAAR,GAAA,IAAAmE,MAAA,QAAAtE,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAgE,MAAA,EAAAnE,GAAA,KAAAkE,MAAA,CAAAlE,GAAA,IAAAmE,MAAA,CAAAnE,GAAA,gBAAAkE,MAAA,YAAAH,QAAA,CAAAF,KAAA,OAAAD,SAAA;AA8C1D,SAASQ,wBAAwBA,CAC/BC,KAA+B,EAC/BC,GAGE,EACF;EACA,oBACE7F,MAAA,CAAAQ,OAAA,CAAAsF,aAAA,CAAC3F,UAAA,CAAA4F,iBAAiB,qBAChB/F,MAAA,CAAAQ,OAAA,CAAAsF,aAAA,CAACE,OAAO,EAAAV,QAAA;IAACW,OAAO,EAAEJ,GAAG,iBAAI,IAAAK,gBAAS,EAAC;EAAE,GAAKN,KAAK,CAAG,CACjC,CAAC;AAExB;AACA;AACA;AACA;AACA,SAASO,4BAA4BA,CACnCP,KAEC,EACDC,GAGE,EACF;EACA,oBAAO7F,MAAA,CAAAQ,OAAA,CAAAsF,aAAA,CAACE,OAAO,EAAAV,QAAA;IAACW,OAAO,EAAEJ,GAAG,iBAAI,IAAAK,gBAAS,EAAC;EAAE,GAAKN,KAAK,CAAG,CAAC;AAC5D;AAEA,SAASI,OAAOA,CAAAI,IAAA,EAcb;EAAA,IAbDC,mBAAmB,GAAAD,IAAA,CAAnBC,mBAAmB;IACnBC,cAAc,GAAAF,IAAA,CAAdE,cAAc;IACdC,KAAK,GAAAH,IAAA,CAALG,KAAK;IACIC,sBAAsB,GAAAJ,IAAA,CAA/BJ,OAAO;IACPC,OAAO,GAAAG,IAAA,CAAPH,OAAO;IACPQ,QAAQ,GAAAL,IAAA,CAARK,QAAQ;EASR,MAAMC,MAAM,GAAG,IAAAC,oBAAS,EAAC,CAAC;EAC1B,MAAMC,sBAAsB,GAAG,IAAAC,wBAAe,EAAC,CAAC;EAChD,MAAMC,OAAO;IAAA,IAAAC,KAAA,GAAAhC,iBAAA,CAAG,aAAY;MAC1B,MAAM6B,sBAAsB,CAACI,OAAO,eAAAjC,iBAAA,CAAC,aAAY;QAC/C,MAAM2B,MAAM,CAACI,OAAO,CAAC,UAAU,CAAC;QAChCG,YAAY,CAACC,OAAO,CAAC,cAAc,EAAE,MAAM,CAAC;MAC9C,CAAC,EAAC;IACJ,CAAC;IAAA,gBALKJ,OAAOA,CAAA;MAAA,OAAAC,KAAA,CAAA3B,KAAA,OAAAD,SAAA;IAAA;EAAA,GAKZ;EACD,MAAMgC,UAAU,GAAG,SAAbA,UAAUA,CAAA,EAAS;IACvBT,MAAM,CAACU,KAAK,CAAC,CAAC;IACdH,YAAY,CAACI,UAAU,CAAC,cAAc,CAAC;EACzC,CAAC;EACD,IAAAC,gBAAS,EAAC,YAAM;IACd,MAAMC,WAAW,GAAG,CAAC,CAACN,YAAY,CAACO,OAAO,CAAC,cAAc,CAAC;IAC1D,IAAID,WAAW,IAAI,CAACb,MAAM,CAACe,OAAO,EAAEX,OAAO,CAAC,CAAC;EAC/C,CAAC,EAAE,EAAE,CAAC;EACN,IAAAY,0BAAmB,EACjBzB,OAAO,EACP;IAAA,OAAO;MACLa,OAAO,EAAPA,OAAO;MACPK,UAAU,EAAVA;IACF,CAAC;EAAA,CAAC,EACF,CAACT,MAAM,CACT,CAAC;EACD,MAAAiB,SAAA,GAA8B,IAAAC,eAAQ,EAAC;MAAA,OAAM,CAAC,CAACC,MAAM,CAACC,QAAQ;IAAA,EAAC;IAAAC,UAAA,GAAAlG,cAAA,CAAA8F,SAAA;IAAxDK,mBAAmB,GAAAD,UAAA;EAC1B;AACF;AACA;AACA;AACA;AACA;EACE,MAAME,cAAc,GAAG,IAAAC,cAAO,EAC5B;IAAA,OACE3B,KAAK,GACDG,MAAM,CAACyB,WAAW,CAAC,CAAC,GAClBzB,MAAM,CAAC0B,OAAO,KAAK7B,KAAK,CAAC8B,EAAE,GAC3B,IAAI,GACNhD,SAAS;EAAA,GACf,CAACqB,MAAM,EAAEH,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAE8B,EAAE,CACpB,CAAC;EAAC,SAEaC,aAAaA,CAAA;IAAA,OAAAC,cAAA,CAAAnD,KAAA,OAAAD,SAAA;EAAA;EAAA,SAAAoD,eAAA;IAAAA,cAAA,GAAAxD,iBAAA,CAA5B,aAA+B;MAC7B,IAAI;QACF,MAAM8C,MAAM,CAACC,QAAQ,CAAEU,OAAO,CAAC;UAC7BC,MAAM,EAAE,4BAA4B;UACpCC,MAAM,EAAE,CACN;YACEN,OAAO,OAAAO,MAAA,CAAOpC,KAAK,CAAE8B,EAAE,CAAC5F,QAAQ,CAAC,EAAE,CAAC,CAACmG,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC;UACvD,CAAC;QAEL,CAAC,CAAC;MACJ,CAAC,CAAC,OAAOC,CAAM,EAAE;QACf,QAAQA,CAAC,CAACC,IAAI;UACZ,KAAK,IAAI;YACPjB,MAAM,CAACC,QAAQ,CAAEU,OAAO,CAAC;cACvBC,MAAM,EAAE,yBAAyB;cACjCC,MAAM,EAAE,CACN;gBACEN,OAAO,OAAAO,MAAA,CAAOpC,KAAK,CAAE8B,EAAE,CAAC5F,QAAQ,CAAC,EAAE,CAAC,CAACmG,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAE;gBACvDG,SAAS,EAAExC,KAAK,CAAE3D,IAAI;gBACtBoG,OAAO,EAAE,CAACzC,KAAK,CAAE0C,MAAM,CAAC;gBACxBC,iBAAiB,EAAE,CAAC3C,KAAK,CAAE4C,WAAW,CAAC;gBACvCC,cAAc,EAAE;kBACdC,MAAM,EAAE9C,KAAK,CAAE+C,QAAQ;kBACvBC,QAAQ,EAAE;gBACZ;cACF,CAAC;YAEL,CAAC,CAAC;QACN;MACF;IACF,CAAC;IAAA,OAAAhB,cAAA,CAAAnD,KAAA,OAAAD,SAAA;EAAA;EACD,MAAMqE,cAAc,GAAGhD,sBAA6B;EACpD,oBACExG,MAAA,CAAAQ,OAAA,CAAAsF,aAAA,CAAA9F,MAAA,CAAAQ,OAAA,CAAAiJ,QAAA,QACGpD,mBAAmB,IAAI,CAAC2B,mBAAmB,iBAAIhI,MAAA,CAAAQ,OAAA,CAAAsF,aAAA,CAACO,mBAAmB,MAAE,CAAC,EACtEC,cAAc,IAAI,CAAC2B,cAAc,iBAChCjI,MAAA,CAAAQ,OAAA,CAAAsF,aAAA,CAACQ,cAAc;IAACgC,aAAa,EAAEA;EAAc,CAAE,CAChD,eAECtI,MAAA,CAAAQ,OAAA,CAAAsF,aAAA,CAAC0D,cAAc,EAAAlE,QAAA,KACTsB,sBAAsB;IAC1BqB,cAAc,EAAEA,cAAe;IAC/BD,mBAAmB,EAAEA,mBAAoB;IACzC0B,wBAAwB,EAAEzB,cAAc,IAAIvB,MAAM,CAACyB,WAAW,CAAC,CAAE;IACjErB,OAAO,EAAEA,OAAQ;IACjBK,UAAU,EAAEA,UAAW;IACvBmB,aAAa,EAAEA,aAAc;IAC7BF,OAAO,EAAE1B,MAAM,CAAC0B,OAAQ;IACxBD,WAAW,EAAEzB,MAAM,CAACyB,WAAW,CAAC,CAAE;IAClCzB,MAAM,EAAEA,MAAM,CAACe;EAAQ,IAEtBhB,QACa,CAElB,CAAC;AAEP;;AAEA;AACA;AACA;AACA,MAAMkD,uBAAuB,gBAAG,IAAAC,iBAAU,EAACjE,wBAAwB,CAAC;AAAC,IAAAkE,QAAA,GACtDF,uBAAuB;AAAAG,OAAA,CAAAtJ,OAAA,GAAAqJ,QAAA;AAE/B,MAAME,2BAA2B,gBAAG,IAAAH,iBAAU,EACnDzD,4BACF,CAAC;AAAC2D,OAAA,CAAAC,2BAAA,GAAAA,2BAAA"}
|
|
143
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_useWallet","_useAsyncControl","_interopRequireDefault","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","_typeof","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_slicedToArray","arr","i","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","TypeError","o","minLen","_arrayLikeToArray","n","toString","slice","constructor","name","Array","from","test","len","length","arr2","_i","Symbol","iterator","_s","_e","_x","_r","_arr","_n","_d","next","done","push","value","err","return","isArray","asyncGeneratorStep","gen","resolve","reject","_next","_throw","arg","info","error","Promise","then","_asyncToGenerator","fn","self","args","arguments","apply","undefined","_extends","assign","bind","target","source","_WalletConnectionWrapper","props","ref","createElement","UseWalletProvider","Content","compRef","createRef","_BaseWalletConnectionWrapper","_ref","ProviderUnavailable","ChainIdInvalid","chain","ProvidedContentWrapper","children","wallet","useWallet","connectionAsyncWrapper","useAsyncControl","connect","_ref2","process","localStorage","setItem","disconnect","reset","removeItem","useEffect","autoConnect","getItem","account","useImperativeHandle","_useState","useState","window","ethereum","_useState2","isProviderAvailable","isChainIdValid","useMemo","isConnected","chainId","id","changeChainId","_changeChainId","request","method","params","concat","padStart","e","code","chainName","rpcUrls","rpcUrl","blockExplorerUrls","explorerUrl","nativeCurrency","symbol","currency","decimals","ContentWrapper","Fragment","isConnectedAndValidChain","WalletConnectionWrapper","forwardRef","_default","exports","BaseWalletConnectionWrapper"],"sources":["../../../src/components/WalletConnectionWrapper/WalletConnectionWrapper.tsx"],"sourcesContent":["import React, {\n  createRef,\n  ForwardedRef,\n  forwardRef,\n  PropsWithChildren,\n  ReactElement,\n  ReactNode,\n  useEffect,\n  useImperativeHandle,\n  useMemo,\n  useState,\n} from \"react\";\nimport { useWallet, UseWalletProvider } from \"use-wallet\";\nimport useAsyncControl from \"../../hooks/useAsyncControl\";\n\nexport type WalletConnectionProps = PropsWithChildren<\n  Omit<ReturnType<typeof useAsyncControl>, \"process\"> & {\n    chainId?: number;\n    isChainIdValid: boolean | undefined;\n    isProviderAvailable: boolean;\n    isConnectedAndValidChain: boolean;\n    isConnected: boolean;\n    wallet?: string;\n\n    connect: () => Promise<void>;\n    disconnect: () => void;\n    changeChainId: () => Promise<void>;\n  }\n>;\n\ntype Props = {\n  /**\n   * The chain id that the user is expected to connect to\n   */\n  chain?: {\n    id: number;\n    rpcUrl: string;\n    explorerUrl: string;\n    name: string;\n    currency: string;\n  };\n\n  /**\n   * When the user doesn't have a provider like metamask available\n   */\n  ProviderUnavailable?: React.FunctionComponent;\n\n  /**\n   * This is invoked when the chain ID is not available\n   */\n  ChainIdInvalid?: React.FunctionComponent<{\n    changeChainId: () => void;\n  }>;\n\n  /**\n   * This renders the content that is shown inside the wallet content\n   */\n  Content: (props: WalletConnectionProps) => ReactElement;\n};\nfunction _WalletConnectionWrapper(\n  props: PropsWithChildren<Props>,\n  ref: ForwardedRef<{\n    connect: () => Promise<void>;\n    disconnect: () => void;\n  }>\n) {\n  return (\n    <UseWalletProvider>\n      <Content compRef={ref || createRef()} {...props} />\n    </UseWalletProvider>\n  );\n}\n/**\n * This component handles a lot of cenarios when dealing with the wallet connection to different providers (ex: Metamask)\n **/\nfunction _BaseWalletConnectionWrapper(\n  props: Props & {\n    children?: any;\n  },\n  ref: ForwardedRef<{\n    connect: () => Promise<void>;\n    disconnect: () => void;\n  }>\n) {\n  return <Content compRef={ref || createRef()} {...props} />;\n}\n\nfunction Content({\n  ProviderUnavailable,\n  ChainIdInvalid,\n  chain,\n  Content: ProvidedContentWrapper,\n  compRef,\n  children,\n}: PropsWithChildren<\n  Props & {\n    compRef: ForwardedRef<{\n      connect: () => Promise<void>;\n      disconnect: () => void;\n    }>;\n  }\n>) {\n  const wallet = useWallet();\n  const connectionAsyncWrapper = useAsyncControl();\n  const connect = async () => {\n    await connectionAsyncWrapper.process(async () => {\n      await wallet.connect(\"injected\");\n      localStorage.setItem(\"auto_connect\", \"true\");\n    });\n  };\n  const disconnect = () => {\n    wallet.reset();\n    localStorage.removeItem(\"auto_connect\");\n  };\n  useEffect(() => {\n    const autoConnect = !!localStorage.getItem(\"auto_connect\");\n    if (autoConnect && !wallet.account) connect();\n  }, []);\n  useImperativeHandle(\n    compRef,\n    () => ({\n      connect,\n      disconnect,\n    }),\n    [wallet]\n  );\n  const [isProviderAvailable] = useState(() => !!window.ethereum);\n  /**\n   * true - Mostrar o conteudo (ex: form de transferencia)\n   * false - Mostrar o botão de trocar a chain\n   *\n   * undefined ???\n   */\n  const isChainIdValid = useMemo(\n    () =>\n      chain\n        ? wallet.isConnected()\n          ? wallet.chainId === chain.id\n          : true\n        : undefined,\n    [wallet, chain?.id]\n  );\n\n  async function changeChainId() {\n    try {\n      await window.ethereum!.request({\n        method: \"wallet_switchEthereumChain\",\n        params: [\n          {\n            chainId: `0x${chain!.id.toString(16).padStart(2, \"0\")}`,\n          },\n        ],\n      });\n    } catch (e: any) {\n      switch (e.code) {\n        case 4902:\n          await window.ethereum!.request({\n            method: \"wallet_addEthereumChain\",\n            params: [\n              {\n                chainId: `0x${chain!.id.toString(16).padStart(2, \"0\")}`,\n                chainName: chain!.name,\n                rpcUrls: [chain!.rpcUrl],\n                blockExplorerUrls: [chain!.explorerUrl],\n                nativeCurrency: {\n                  symbol: chain!.currency,\n                  decimals: 18,\n                },\n              },\n            ],\n          });\n        default:\n          throw e\n      }\n    }\n  }\n  const ContentWrapper = ProvidedContentWrapper as any;\n  return (\n    <>\n      {ProviderUnavailable && !isProviderAvailable && <ProviderUnavailable />}\n      {ChainIdInvalid && !isChainIdValid && (\n        <ChainIdInvalid changeChainId={changeChainId} />\n      )}\n      {\n        <ContentWrapper\n          {...connectionAsyncWrapper}\n          isChainIdValid={isChainIdValid}\n          isProviderAvailable={isProviderAvailable}\n          isConnectedAndValidChain={isChainIdValid && wallet.isConnected()}\n          connect={connect}\n          disconnect={disconnect}\n          changeChainId={changeChainId}\n          chainId={wallet.chainId}\n          isConnected={wallet.isConnected()}\n          wallet={wallet.account}\n        >\n          {children}\n        </ContentWrapper>\n      }\n    </>\n  );\n}\n\n/**\n * This component handles some cenarios when dealing with the wallet connection to different providers (ex: Metamask)\n **/\nconst WalletConnectionWrapper = forwardRef(_WalletConnectionWrapper);\nexport default WalletConnectionWrapper;\n\nexport const BaseWalletConnectionWrapper = forwardRef(\n  _BaseWalletConnectionWrapper\n);\n"],"mappings":"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"}
|
|
@@ -99,4 +99,4 @@ function useCurrentImageScale() {
|
|
|
99
99
|
const context = (0, _react.useContext)(Context);
|
|
100
100
|
return context.state.imageScale;
|
|
101
101
|
}
|
|
102
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_get","_interopRequireDefault","require","_merge","_cloneDeep","_react","_interopRequireWildcard","_useAdaptiveImage","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Symbol","iterator","constructor","Context","createContext","OneUIProvider","_ref","children","config","prevCtx","useContext","scale","useAdaptiveImage","mergedConfig","useMemo","merge","clone","state","imageScale","createElement","Provider","value","pathToJson","path","exampleConfig","arguments","length","undefined","split","slice","replace","concat","reduce","result","idx","arr","r","k","ErrorWrapper","originalObject","Proxy","_target","toPrimitive","filter","Boolean","join","e","pathJson","Error","JSON","stringify","useOneUIContext","context","process","env","NODE_ENV","useOneUIView","oneuiConfigPath","componentName","providedValue","useOneUIConfig","prop","defaultValue","val","endsWith","useCurrentImageScale"],"sources":["../../src/context/OneUIProvider.tsx"],"sourcesContent":["import get from \"lodash/get\";\nimport merge from \"lodash/merge\";\nimport clone from \"lodash/cloneDeep\";\nimport { Get } from \"type-fest\";\nimport React, { ComponentProps, ReactElement, ReactNode, useMemo } from \"react\";\nimport { createContext, PropsWithChildren, useContext } from \"react\";\nimport { FieldPath } from \"../type-utils\";\nimport useAdaptiveImage from \"../hooks/ui/useAdaptiveImage\";\nimport { ImageScales } from \"@muritavo/webpack-microfrontend-scripts/bin/types/ImageScales\";\nimport Button from \"../components/Button\";\nimport CheckBox from \"../components/CheckBox\";\nimport Radio from \"../components/Radio/Radio\";\nimport { FileInputViewProps } from \"../components/FileInput/View/View.types\";\nimport {\n  AnswerByField,\n  GenericFormFieldProps,\n} from \"../components/Form/v2/FormField/FormField.types\";\nimport { UploadTask } from \"firebase/storage\";\n\ntype DeepPartial<T> = {\n  [P in keyof T]?: NonNullable<T[P]> extends Function\n    ? T[P]\n    : DeepPartial<T[P]>;\n};\n\nexport type OneUIContextSpecs = {\n  component: {\n    collapsable: {\n      className: string;\n    };\n    form: {\n      titleVariant: OnepercentUtility.UIElements.TextVariants;\n      labelVariant: OnepercentUtility.UIElements.TextVariants;\n      /** Label shown when a field is optional */\n      optionalLabel: string;\n\n      /** Label shown when a required field was not provided */\n      requiredLabel: string;\n\n      onFileUpload(questionId: string, file: File): UploadTask;\n\n      extensions?: {\n        [K in OnepercentUtility.UIElements.FormExtension[\"fields\"][\"type\"]]: {\n          Input: (props: GenericFormFieldProps<K>) => ReactElement;\n          validator: (answer: AnswerByField<{ type: K }>) => {\n            isValid: boolean;\n            error?: string;\n          };\n        };\n      };\n    };\n    text?: {\n      className?: {\n        [k in React.ComponentProps<\n          typeof import(\"../components/Text\")[\"default\"]\n        >[\"type\"]]?: string;\n      };\n      htmlTag?: {\n        [k in React.ComponentProps<\n          typeof import(\"../components/Text\")[\"default\"]\n        >[\"type\"]]?: \"p\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\";\n      };\n    };\n    button?: {\n      className?: {\n        [k in NonNullable<\n          React.ComponentProps<\n            typeof import(\"../components/Button\")[\"default\"]\n          >[\"variant\"]\n        >]?: string;\n      };\n      Component?: (props: ComponentProps<typeof Button>) => ReactElement;\n    };\n    input: {\n      className: string;\n      border: boolean;\n    };\n    fileInput: {\n      View: (props: FileInputViewProps) => ReactElement;\n    };\n    passwordInput: {\n      iconSrc: {\n        passwordHidden: string;\n        passwordVisible: string;\n      };\n    };\n    asyncWrapper: {\n      LoadingComponent?: () => JSX.Element;\n      messages: {\n        error: {\n          title: string;\n          retryBtn: string;\n        };\n      };\n    };\n    select: {\n      StateIndicator: (props: { open: boolean }) => JSX.Element;\n      className?: {\n        dropdown?: string;\n        item?: string;\n        selectedItem?: string;\n      };\n    };\n    header: {\n      LogoImage: () => JSX.Element;\n      MoreOptions: ({ open }: { open: boolean }) => JSX.Element;\n    };\n    table: {\n      controls: {\n        PrevPage: ({ disabled }: { disabled: boolean }) => JSX.Element;\n        NextPage: ({ disabled }: { disabled: boolean }) => JSX.Element;\n      };\n    };\n    tooltip: {\n      className?: string;\n    };\n    adaptiveDialog: {\n      dialogClassName: string;\n      backdropClassName: string;\n      variant: {\n        [k in OnepercentUtility.UIElements.AdaptiveDialogVariants]: string;\n      };\n    };\n    adaptiveSidebar: {\n      className: string;\n      controlClassName: string;\n    };\n    checkbox: {\n      Component?: (props: ComponentProps<typeof CheckBox>) => ReactElement;\n    };\n    radio: {\n      Component?: (props: ComponentProps<typeof Radio>) => ReactElement;\n    };\n  };\n  hook: {\n    ui: {\n      usePaginationControls: {\n        LeftControl: () => ReactElement;\n        RightControl: () => ReactElement;\n        className?: string;\n      };\n    };\n  };\n  state: {\n    imageScale: ImageScales;\n  };\n};\n\ntype ContextConfigSpecs = DeepPartial<OneUIContextSpecs>;\n\nconst Context = createContext<ContextConfigSpecs>(null as any);\n\nexport default function OneUIProvider({\n  children,\n  config,\n}: PropsWithChildren<{ config: ContextConfigSpecs }>) {\n  const prevCtx = useContext(Context);\n  const scale = useAdaptiveImage();\n  const mergedConfig = useMemo(() => {\n    return merge(clone(prevCtx), config, {\n      state: {\n        imageScale: scale,\n      },\n    });\n  }, [prevCtx, config, scale]);\n\n  return <Context.Provider value={mergedConfig}>{children}</Context.Provider>;\n}\n\nfunction pathToJson(\n  path: string,\n  key?: string | Symbol,\n  exampleConfig = \"THE_MISSING_CONFIG\"\n) {\n  if (!key) {\n    key = path.split(\".\").slice(-1)[0];\n    path = path.replace(`.${key}`, \"\");\n  }\n\n  return path\n    .split(\".\")\n    .concat(key as string)\n    .reduce((result, key, idx, arr) => {\n      (arr.slice(0, idx).reduce((r, k) => (r as any)[k], result) as any)[key] =\n        idx === arr.length - 1 ? exampleConfig : {};\n      return result;\n    }, {});\n}\n\nfunction ErrorWrapper(\n  originalObject: any,\n  path: string = \"config\"\n): typeof Proxy {\n  return new Proxy(\n    typeof originalObject !== \"object\" ? {} : originalObject || {},\n    {\n      get(_target, key) {\n        if (key === Symbol.toPrimitive) {\n          return () => _target[key];\n        }\n        try {\n          const value = originalObject[key];\n          if (typeof value === \"undefined\") return undefined;\n          if (typeof value === \"object\")\n            return ErrorWrapper(value, [path, key].filter(Boolean).join(\".\"));\n          return value;\n        } catch (e) {\n          const pathJson = pathToJson(path, key);\n          throw new Error(\n            `A component is using the UI config ${[path, key].join(\".\")}.\n\nPlease define it using:\nimport OneUIProvider from \"@onepercent/one-ui/dist/context/OneUIProvider\";\n\n  ...\n${`<OneUIProvider config={${JSON.stringify(pathJson, null, 4)}}>\n...\n</OneUIProvider>`.replace(/[ ]/g, \"-\")}`\n          );\n        }\n      },\n    }\n  );\n}\n\nexport function useOneUIContext() {\n  const context = useContext(Context);\n\n  if (process.env.NODE_ENV === \"development\")\n    return ErrorWrapper(context) as unknown as OneUIContextSpecs;\n\n  return context as OneUIContextSpecs;\n}\n\nexport function useOneUIView<P extends FieldPath<OneUIContextSpecs>>(\n  oneuiConfigPath: P,\n  componentName: string\n) {\n  const providedValue = useOneUIConfig(oneuiConfigPath);\n  if (!providedValue) {\n    throw new Error(`The component ${componentName} requires a view to be set on OneUI initialization\n\nViews ready for use with this component shall be available at:\nimport SomeView from \"@onepercentio/one-ui/dist/components/${componentName}/View/SomeView\";\n    \nPlease define it using:\nimport OneUIProvider from \"@onepercentio/one-ui/dist/context/OneUIProvider\";\n\n  ...\n${`<OneUIProvider config={${JSON.stringify(\n  pathToJson(oneuiConfigPath, undefined, \"SomeView\"),\n  null,\n  4\n)}}>\n...\n</OneUIProvider>`.replace(/[ ]/g, \"-\")}`);\n  }\n\n  return providedValue;\n}\n\nexport function useOneUIConfig<\n  P extends FieldPath<OneUIContextSpecs>,\n  T extends Get<OneUIContextSpecs, P>\n>(prop: P, defaultValue?: T): NonNullable<Get<OneUIContextSpecs, P>> {\n  const context = useContext(Context);\n  if (process.env.NODE_ENV === \"development\") {\n    const val = useMemo(() => {\n      return get(context, prop);\n    }, [context, prop]);\n    if (\n      typeof val === \"string\" ||\n      typeof val === \"function\" ||\n      prop.endsWith(\".Component\") ||\n      prop.endsWith(\".View\")\n    )\n      return (val as any) || defaultValue;\n\n    if (typeof val === \"boolean\") return val as any;\n    return ErrorWrapper(val || defaultValue) as unknown as NonNullable<T>;\n  }\n  const value = useMemo(() => {\n    return get(context, prop);\n  }, [context, prop]);\n  return value || defaultValue;\n}\n\nexport function useCurrentImageScale() {\n  const context = useContext(Context);\n\n  return context.state!.imageScale!;\n}\n"],"mappings":"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"}
|
|
102
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_get","_interopRequireDefault","require","_merge","_cloneDeep","_react","_interopRequireWildcard","_useAdaptiveImage","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Symbol","iterator","constructor","Context","createContext","OneUIProvider","_ref","children","config","prevCtx","useContext","scale","useAdaptiveImage","mergedConfig","useMemo","merge","clone","state","imageScale","createElement","Provider","value","pathToJson","path","exampleConfig","arguments","length","undefined","split","slice","replace","concat","reduce","result","idx","arr","r","k","ErrorWrapper","originalObject","Proxy","_target","toPrimitive","filter","Boolean","join","e","pathJson","Error","JSON","stringify","useOneUIContext","context","process","env","NODE_ENV","useOneUIView","oneuiConfigPath","componentName","providedValue","useOneUIConfig","prop","defaultValue","val","endsWith","useCurrentImageScale"],"sources":["../../src/context/OneUIProvider.tsx"],"sourcesContent":["import get from \"lodash/get\";\nimport merge from \"lodash/merge\";\nimport clone from \"lodash/cloneDeep\";\nimport { Get } from \"type-fest\";\nimport React, { ComponentProps, ReactElement, ReactNode, useMemo } from \"react\";\nimport { createContext, PropsWithChildren, useContext } from \"react\";\nimport { FieldPath } from \"../type-utils\";\nimport useAdaptiveImage from \"../hooks/ui/useAdaptiveImage\";\nimport { ImageScales } from \"@muritavo/webpack-microfrontend-scripts/bin/types/ImageScales\";\nimport Button from \"../components/Button\";\nimport CheckBox from \"../components/CheckBox\";\nimport Radio from \"../components/Radio/Radio\";\nimport { FileInputViewProps } from \"../components/FileInput/View/View.types\";\nimport {\n  AnswerByField,\n  GenericFormFieldProps,\n} from \"../components/Form/v2/FormField/FormField.types\";\nimport { UploadTask } from \"firebase/storage\";\n\ntype DeepPartial<T> = {\n  [P in keyof T]?: NonNullable<T[P]> extends Function\n    ? T[P]\n    : DeepPartial<T[P]>;\n};\n\nexport type OneUIContextSpecs = {\n  component: {\n    spacing: {\n      variants: {\n        [k in OnepercentUtility.UIElements.SpacingVariants]: string;\n      };\n    };\n    collapsable: {\n      className: string;\n    };\n    form: {\n      titleVariant: OnepercentUtility.UIElements.TextVariants;\n      labelVariant: OnepercentUtility.UIElements.TextVariants;\n      /** Label shown when a field is optional */\n      optionalLabel: string;\n\n      /** Label shown when a required field was not provided */\n      requiredLabel: string;\n\n      onFileUpload(questionId: string, file: File): UploadTask;\n\n      extensions?: {\n        [K in OnepercentUtility.UIElements.FormExtension[\"fields\"][\"type\"]]: {\n          Input: (props: GenericFormFieldProps<K>) => ReactElement;\n          validator: (answer: AnswerByField<{ type: K }>) => {\n            isValid: boolean;\n            error?: string;\n          };\n        };\n      };\n    };\n    text?: {\n      className?: {\n        [k in React.ComponentProps<\n          typeof import(\"../components/Text\")[\"default\"]\n        >[\"type\"]]?: string;\n      };\n      htmlTag?: {\n        [k in React.ComponentProps<\n          typeof import(\"../components/Text\")[\"default\"]\n        >[\"type\"]]?: \"p\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\";\n      };\n    };\n    button?: {\n      className?: {\n        [k in NonNullable<\n          React.ComponentProps<\n            typeof import(\"../components/Button\")[\"default\"]\n          >[\"variant\"]\n        >]?: string;\n      };\n      Component?: (props: ComponentProps<typeof Button>) => ReactElement;\n    };\n    input: {\n      className: string;\n      border: boolean;\n    };\n    fileInput: {\n      View: (props: FileInputViewProps) => ReactElement;\n    };\n    passwordInput: {\n      iconSrc: {\n        passwordHidden: string;\n        passwordVisible: string;\n      };\n    };\n    asyncWrapper: {\n      LoadingComponent?: () => JSX.Element;\n      messages: {\n        error: {\n          title: string;\n          retryBtn: string;\n        };\n      };\n    };\n    select: {\n      StateIndicator: (props: { open: boolean }) => JSX.Element;\n      className?: {\n        dropdown?: string;\n        item?: string;\n        selectedItem?: string;\n      };\n    };\n    header: {\n      LogoImage: () => JSX.Element;\n      MoreOptions: ({ open }: { open: boolean }) => JSX.Element;\n    };\n    table: {\n      controls: {\n        PrevPage: ({ disabled }: { disabled: boolean }) => JSX.Element;\n        NextPage: ({ disabled }: { disabled: boolean }) => JSX.Element;\n      };\n    };\n    tooltip: {\n      className?: string;\n    };\n    adaptiveDialog: {\n      dialogClassName: string;\n      backdropClassName: string;\n      variant: {\n        [k in OnepercentUtility.UIElements.AdaptiveDialogVariants]: string;\n      };\n    };\n    adaptiveSidebar: {\n      className: string;\n      controlClassName: string;\n    };\n    checkbox: {\n      Component?: (props: ComponentProps<typeof CheckBox>) => ReactElement;\n    };\n    radio: {\n      Component?: (props: ComponentProps<typeof Radio>) => ReactElement;\n    };\n  };\n  hook: {\n    ui: {\n      usePaginationControls: {\n        LeftControl: () => ReactElement;\n        RightControl: () => ReactElement;\n        className?: string;\n      };\n    };\n  };\n  state: {\n    imageScale: ImageScales;\n  };\n};\n\ntype ContextConfigSpecs = DeepPartial<OneUIContextSpecs>;\n\nconst Context = createContext<ContextConfigSpecs>(null as any);\n\nexport default function OneUIProvider({\n  children,\n  config,\n}: PropsWithChildren<{ config: ContextConfigSpecs }>) {\n  const prevCtx = useContext(Context);\n  const scale = useAdaptiveImage();\n  const mergedConfig = useMemo(() => {\n    return merge(clone(prevCtx), config, {\n      state: {\n        imageScale: scale,\n      },\n    });\n  }, [prevCtx, config, scale]);\n\n  return <Context.Provider value={mergedConfig}>{children}</Context.Provider>;\n}\n\nfunction pathToJson(\n  path: string,\n  key?: string | Symbol,\n  exampleConfig = \"THE_MISSING_CONFIG\"\n) {\n  if (!key) {\n    key = path.split(\".\").slice(-1)[0];\n    path = path.replace(`.${key}`, \"\");\n  }\n\n  return path\n    .split(\".\")\n    .concat(key as string)\n    .reduce((result, key, idx, arr) => {\n      (arr.slice(0, idx).reduce((r, k) => (r as any)[k], result) as any)[key] =\n        idx === arr.length - 1 ? exampleConfig : {};\n      return result;\n    }, {});\n}\n\nfunction ErrorWrapper(\n  originalObject: any,\n  path: string = \"config\"\n): typeof Proxy {\n  return new Proxy(\n    typeof originalObject !== \"object\" ? {} : originalObject || {},\n    {\n      get(_target, key) {\n        if (key === Symbol.toPrimitive) {\n          return () => _target[key];\n        }\n        try {\n          const value = originalObject[key];\n          if (typeof value === \"undefined\") return undefined;\n          if (typeof value === \"object\")\n            return ErrorWrapper(value, [path, key].filter(Boolean).join(\".\"));\n          return value;\n        } catch (e) {\n          const pathJson = pathToJson(path, key);\n          throw new Error(\n            `A component is using the UI config ${[path, key].join(\".\")}.\n\nPlease define it using:\nimport OneUIProvider from \"@onepercent/one-ui/dist/context/OneUIProvider\";\n\n  ...\n${`<OneUIProvider config={${JSON.stringify(pathJson, null, 4)}}>\n...\n</OneUIProvider>`.replace(/[ ]/g, \"-\")}`\n          );\n        }\n      },\n    }\n  );\n}\n\nexport function useOneUIContext() {\n  const context = useContext(Context);\n\n  if (process.env.NODE_ENV === \"development\")\n    return ErrorWrapper(context) as unknown as OneUIContextSpecs;\n\n  return context as OneUIContextSpecs;\n}\n\nexport function useOneUIView<P extends FieldPath<OneUIContextSpecs>>(\n  oneuiConfigPath: P,\n  componentName: string\n) {\n  const providedValue = useOneUIConfig(oneuiConfigPath);\n  if (!providedValue) {\n    throw new Error(`The component ${componentName} requires a view to be set on OneUI initialization\n\nViews ready for use with this component shall be available at:\nimport SomeView from \"@onepercentio/one-ui/dist/components/${componentName}/View/SomeView\";\n    \nPlease define it using:\nimport OneUIProvider from \"@onepercentio/one-ui/dist/context/OneUIProvider\";\n\n  ...\n${`<OneUIProvider config={${JSON.stringify(\n  pathToJson(oneuiConfigPath, undefined, \"SomeView\"),\n  null,\n  4\n)}}>\n...\n</OneUIProvider>`.replace(/[ ]/g, \"-\")}`);\n  }\n\n  return providedValue;\n}\n\nexport function useOneUIConfig<\n  P extends FieldPath<OneUIContextSpecs>,\n  T extends Get<OneUIContextSpecs, P>\n>(prop: P, defaultValue?: T): NonNullable<Get<OneUIContextSpecs, P>> {\n  const context = useContext(Context);\n  if (process.env.NODE_ENV === \"development\") {\n    const val = useMemo(() => {\n      return get(context, prop);\n    }, [context, prop]);\n    if (\n      typeof val === \"string\" ||\n      typeof val === \"function\" ||\n      prop.endsWith(\".Component\") ||\n      prop.endsWith(\".View\")\n    )\n      return (val as any) || defaultValue;\n\n    if (typeof val === \"boolean\") return val as any;\n    return ErrorWrapper(val || defaultValue) as unknown as NonNullable<T>;\n  }\n  const value = useMemo(() => {\n    return get(context, prop);\n  }, [context, prop]);\n  return value || defaultValue;\n}\n\nexport function useCurrentImageScale() {\n  const context = useContext(Context);\n\n  return context.state!.imageScale!;\n}\n"],"mappings":"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"}
|
|
@@ -4,6 +4,10 @@ declare type Arr<X> = [X, React.Dispatch<SetStateAction<X>>];
|
|
|
4
4
|
export declare type FunctionMap = {
|
|
5
5
|
[f: string]: ((...args: any[]) => Promise<any>) | Object | Primitive;
|
|
6
6
|
};
|
|
7
|
+
export declare type Control<E extends any = any> = {
|
|
8
|
+
error?: E;
|
|
9
|
+
loading: boolean;
|
|
10
|
+
};
|
|
7
11
|
export declare function useRawAsynControl<E = any, F extends FunctionMap = {}>(functionsToWrap: F | undefined, [error, setError]: Arr<E | undefined>, [loading, setLoading]: Arr<boolean>): {
|
|
8
12
|
process: (asyncFn: () => Promise<any>) => Promise<any>;
|
|
9
13
|
loading: boolean;
|
|
@@ -87,4 +87,4 @@ function useAsyncControl(functionsToWrap) {
|
|
|
87
87
|
const loading = (0, _react.useState)(false);
|
|
88
88
|
return useRawAsynControl(functionsToWrap, error, loading);
|
|
89
89
|
}
|
|
90
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","obj","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","_typeof","String","input","hint","prim","Symbol","toPrimitive","undefined","res","call","TypeError","Number","asyncGeneratorStep","gen","resolve","reject","_next","_throw","info","error","done","Promise","then","_asyncToGenerator","fn","self","args","err","_slicedToArray","arr","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","o","minLen","_arrayLikeToArray","n","prototype","toString","slice","constructor","name","Array","from","test","len","arr2","_i","iterator","_s","_e","_x","_r","_arr","_n","_d","next","return","isArray","useRawAsynControl","functionsToWrap","_ref","_ref2","_ref3","setError","_ref4","loading","setLoading","_process","useCallback","_ref5","asyncFn","e","process","env","NODE_ENV","console","_x2","_Object$entries$reduc","entries","reduce","r","_ref6","_ref7","k","func","functionsToMemoize","other","_ref8","_ref9","v","useMemo","_len","_key","useAsyncControl","useState"],"sources":["../../src/hooks/useAsyncControl.ts"],"sourcesContent":["import { SetStateAction, useCallback, useMemo, useState } from \"react\";\nimport { Primitive } from \"type-fest\";\n\ntype Arr<X> = [X, React.Dispatch<SetStateAction<X>>];\nexport type FunctionMap = {\n  [f: string]: ((...args: any[]) => Promise<any>) | Object | Primitive;\n};\nexport function useRawAsynControl<E = any, F extends FunctionMap = {}>(\n  functionsToWrap: F | undefined,\n  [error, setError]: Arr<E | undefined>,\n  [loading, setLoading]: Arr<boolean>\n) {\n  const _process = useCallback(async (asyncFn: () => Promise<any>) => {\n    try {\n      setLoading(true);\n      setError(undefined);\n      return await asyncFn();\n    } catch (e) {\n      if (process.env.NODE_ENV === \"development\") console.error(e);\n      setError(e as E);\n      throw e;\n    } finally {\n      setLoading(false);\n    }\n  }, []);\n\n  const { functionsToMemoize, other } = Object.entries(\n    functionsToWrap || {}\n  ).reduce(\n    (r, [k, func]) => {\n      return {\n        ...r,\n        ...(typeof func === \"function\"\n          ? {\n              functionsToMemoize: {\n                ...r.functionsToMemoize,\n                [k]: func,\n              },\n            }\n          : {\n              other: {\n                ...r.other,\n                [k]: func,\n              },\n            }),\n      };\n    },\n    {\n      functionsToMemoize: {},\n      other: {},\n    } as {\n      functionsToMemoize: F;\n      other: F;\n    }\n  );\n\n  return {\n    process: _process,\n    loading,\n    error,\n    setError,\n    setLoading,\n    ...other,\n    ...Object.entries(functionsToMemoize).reduce(\n      (r, [k, v]) => ({\n        ...r,\n        [k]: useMemo(\n          () =>\n            (...args: any[]) =>\n              _process(() => (v as any)(...args)),\n          [v]\n        ),\n      }),\n      {} as F\n    ),\n  };\n}\n\nexport default function useAsyncControl<\n  E = any,\n  F extends {\n    [f: string]: ((...args: any[]) => Promise<any>) | Object | Primitive;\n  } = {}\n>(functionsToWrap?: F) {\n  const error = useState<E | Error>();\n  const loading = useState<boolean>(false);\n\n  return useRawAsynControl(functionsToWrap, error, loading);\n}\n"],"mappings":"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"}
|
|
90
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","obj","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","_typeof","String","input","hint","prim","Symbol","toPrimitive","undefined","res","call","TypeError","Number","asyncGeneratorStep","gen","resolve","reject","_next","_throw","info","error","done","Promise","then","_asyncToGenerator","fn","self","args","err","_slicedToArray","arr","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","o","minLen","_arrayLikeToArray","n","prototype","toString","slice","constructor","name","Array","from","test","len","arr2","_i","iterator","_s","_e","_x","_r","_arr","_n","_d","next","return","isArray","useRawAsynControl","functionsToWrap","_ref","_ref2","_ref3","setError","_ref4","loading","setLoading","_process","useCallback","_ref5","asyncFn","e","process","env","NODE_ENV","console","_x2","_Object$entries$reduc","entries","reduce","r","_ref6","_ref7","k","func","functionsToMemoize","other","_ref8","_ref9","v","useMemo","_len","_key","useAsyncControl","useState"],"sources":["../../src/hooks/useAsyncControl.ts"],"sourcesContent":["import { SetStateAction, useCallback, useMemo, useState } from \"react\";\nimport { Primitive } from \"type-fest\";\n\ntype Arr<X> = [X, React.Dispatch<SetStateAction<X>>];\nexport type FunctionMap = {\n  [f: string]: ((...args: any[]) => Promise<any>) | Object | Primitive;\n};\nexport type Control<E extends any = any> = {\n  error?: E;\n  loading: boolean;\n};\nexport function useRawAsynControl<E = any, F extends FunctionMap = {}>(\n  functionsToWrap: F | undefined,\n  [error, setError]: Arr<E | undefined>,\n  [loading, setLoading]: Arr<boolean>\n) {\n  const _process = useCallback(async (asyncFn: () => Promise<any>) => {\n    try {\n      setLoading(true);\n      setError(undefined);\n      return await asyncFn();\n    } catch (e) {\n      if (process.env.NODE_ENV === \"development\") console.error(e);\n      setError(e as E);\n      throw e;\n    } finally {\n      setLoading(false);\n    }\n  }, []);\n\n  const { functionsToMemoize, other } = Object.entries(\n    functionsToWrap || {}\n  ).reduce(\n    (r, [k, func]) => {\n      return {\n        ...r,\n        ...(typeof func === \"function\"\n          ? {\n              functionsToMemoize: {\n                ...r.functionsToMemoize,\n                [k]: func,\n              },\n            }\n          : {\n              other: {\n                ...r.other,\n                [k]: func,\n              },\n            }),\n      };\n    },\n    {\n      functionsToMemoize: {},\n      other: {},\n    } as {\n      functionsToMemoize: F;\n      other: F;\n    }\n  );\n\n  return {\n    process: _process,\n    loading,\n    error,\n    setError,\n    setLoading,\n    ...other,\n    ...Object.entries(functionsToMemoize).reduce(\n      (r, [k, v]) => ({\n        ...r,\n        [k]: useMemo(\n          () =>\n            (...args: any[]) =>\n              _process(() => (v as any)(...args)),\n          [v]\n        ),\n      }),\n      {} as F\n    ),\n  };\n}\n\nexport default function useAsyncControl<\n  E = any,\n  F extends {\n    [f: string]: ((...args: any[]) => Promise<any>) | Object | Primitive;\n  } = {}\n>(functionsToWrap?: F) {\n  const error = useState<E | Error>();\n  const loading = useState<boolean>(false);\n\n  return useRawAsynControl(functionsToWrap, error, loading);\n}\n"],"mappings":"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"}
|
|
@@ -28,10 +28,14 @@ function useAsyncMemo(funcToMemoize, depArr) {
|
|
|
28
28
|
memo = _useState2[0],
|
|
29
29
|
setMemo = _useState2[1];
|
|
30
30
|
(0, _react.useEffect)(function () {
|
|
31
|
-
process(funcToMemoize).then(
|
|
31
|
+
process(funcToMemoize).then(function (whatToStore) {
|
|
32
|
+
return setMemo(function () {
|
|
33
|
+
return whatToStore;
|
|
34
|
+
});
|
|
35
|
+
}).catch(function () {
|
|
32
36
|
return setMemo(null);
|
|
33
37
|
});
|
|
34
38
|
}, depArr);
|
|
35
39
|
return [memo, error];
|
|
36
40
|
}
|
|
37
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJyZXF1aXJlIiwiX3VzZUFzeW5jQ29udHJvbDIiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0Iiwib2JqIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJfc2xpY2VkVG9BcnJheSIsImFyciIsImkiLCJfYXJyYXlXaXRoSG9sZXMiLCJfaXRlcmFibGVUb0FycmF5TGltaXQiLCJfdW5zdXBwb3J0ZWRJdGVyYWJsZVRvQXJyYXkiLCJfbm9uSXRlcmFibGVSZXN0IiwiVHlwZUVycm9yIiwibyIsIm1pbkxlbiIsIl9hcnJheUxpa2VUb0FycmF5IiwibiIsIk9iamVjdCIsInByb3RvdHlwZSIsInRvU3RyaW5nIiwiY2FsbCIsInNsaWNlIiwiY29uc3RydWN0b3IiLCJuYW1lIiwiQXJyYXkiLCJmcm9tIiwidGVzdCIsImxlbiIsImxlbmd0aCIsImFycjIiLCJfaSIsIlN5bWJvbCIsIml0ZXJhdG9yIiwiX3MiLCJfZSIsIl94IiwiX3IiLCJfYXJyIiwiX24iLCJfZCIsIm5leHQiLCJkb25lIiwicHVzaCIsInZhbHVlIiwiZXJyIiwicmV0dXJuIiwiaXNBcnJheSIsInVzZUFzeW5jTWVtbyIsImZ1bmNUb01lbW9pemUiLCJkZXBBcnIiLCJfdXNlQXN5bmNDb250cm9sIiwidXNlQXN5bmNDb250cm9sIiwicHJvY2VzcyIsImVycm9yIiwiX3VzZVN0YXRlIiwidXNlU3RhdGUiLCJfdXNlU3RhdGUyIiwibWVtbyIsInNldE1lbW8iLCJ1c2VFZmZlY3QiLCJ0aGVuIiwid2hhdFRvU3RvcmUiLCJjYXRjaCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9ob29rcy91dGlsaXR5L3VzZUFzeW5jTWVtby50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdXNlQXN5bmNDb250cm9sIGZyb20gXCIuLi91c2VBc3luY0NvbnRyb2xcIjtcblxuLyoqXG4gKiBJdCBjYW4gYXNzdW1lIDMgc3RhdGVzXG4gKiBbdW5kZWZpbmVkXSA9IFRoZSBob29rIGhhcyBqdXN0IGluaXRpYWxpemVkLCBhbmQgd2lsbCBjYWxsIHRoZSBtZW1vaXplIGZ1bmN0aW9uXG4gKiBbVF0gPSBUaGUgaG9vayBpbml0aWFsaXplZCB0aGUgdmFsdWVcbiAqIFtudWxsLCBlcnJvcl0gPSBUaGUgaG9vayBmYWlsZWQgdG8gaW5pdGlhbGl6ZSBhbmQgdGhlIGVycm9yIGlzIGF2YWlsYWJsZVxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiB1c2VBc3luY01lbW88VD4oXG4gIGZ1bmNUb01lbW9pemU6ICgpID0+IFByb21pc2U8VD4sXG4gIGRlcEFycjogYW55W11cbik6IFtUIHwgdW5kZWZpbmVkIHwgbnVsbCwgYW55XSB7XG4gIGNvbnN0IHsgcHJvY2VzcywgZXJyb3IgfSA9IHVzZUFzeW5jQ29udHJvbCgpO1xuICBjb25zdCBbbWVtbywgc2V0TWVtb10gPSB1c2VTdGF0ZTxUIHwgbnVsbD4oKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIHByb2Nlc3MoZnVuY1RvTWVtb2l6ZSlcbiAgICAgIC50aGVuKCh3aGF0VG9TdG9yZSkgPT4gc2V0TWVtbygoKSA9PiB3aGF0VG9TdG9yZSkpXG4gICAgICAuY2F0Y2goKCkgPT4gc2V0TWVtbyhudWxsKSk7XG4gIH0sIGRlcEFycik7XG5cbiAgcmV0dXJuIFttZW1vLCBlcnJvcl07XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsT0FBQTtBQUNBLElBQUFDLGlCQUFBLEdBQUFDLHNCQUFBLENBQUFGLE9BQUE7QUFBaUQsU0FBQUUsdUJBQUFDLEdBQUEsV0FBQUEsR0FBQSxJQUFBQSxHQUFBLENBQUFDLFVBQUEsR0FBQUQsR0FBQSxLQUFBRSxPQUFBLEVBQUFGLEdBQUE7QUFBQSxTQUFBRyxlQUFBQyxHQUFBLEVBQUFDLENBQUEsV0FBQUMsZUFBQSxDQUFBRixHQUFBLEtBQUFHLHFCQUFBLENBQUFILEdBQUEsRUFBQUMsQ0FB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
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export interface OrbDrawer {
|
|
2
|
+
drawOrb(x: number, y: number, radius: number): void;
|
|
3
|
+
}
|
|
4
|
+
declare class BaseOrb {
|
|
5
|
+
protected drawer: OrbDrawer;
|
|
6
|
+
constructor(drawer: OrbDrawer);
|
|
7
|
+
}
|
|
8
|
+
export declare class Orb extends BaseOrb {
|
|
9
|
+
x: number;
|
|
10
|
+
y: number;
|
|
11
|
+
vx: number;
|
|
12
|
+
vy: number;
|
|
13
|
+
radius: number;
|
|
14
|
+
bounds: {
|
|
15
|
+
width: number;
|
|
16
|
+
height: number;
|
|
17
|
+
};
|
|
18
|
+
constructor(drawer: OrbDrawer, velocity: number, bounds: Orb["bounds"], radius: number);
|
|
19
|
+
step(): void;
|
|
20
|
+
}
|
|
21
|
+
export declare class GuideOrb extends BaseOrb {
|
|
22
|
+
lastRadius: number;
|
|
23
|
+
lastX: number;
|
|
24
|
+
lastY: number;
|
|
25
|
+
deflateDuration: number;
|
|
26
|
+
constructor(drawer: OrbDrawer, deflateDuration: number);
|
|
27
|
+
step(size: number, sizeToIncrease: number, lastSizeTimestamp: number, lastPositionTimestamp: number, currPos: {
|
|
28
|
+
x: number;
|
|
29
|
+
y: number;
|
|
30
|
+
}, moveBy: {
|
|
31
|
+
x: number;
|
|
32
|
+
y: number;
|
|
33
|
+
}): void;
|
|
34
|
+
}
|
|
35
|
+
export {};
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.Orb = exports.GuideOrb = void 0;
|
|
8
|
+
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
|
9
|
+
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
|
10
|
+
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
11
|
+
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
|
12
|
+
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
|
13
|
+
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
14
|
+
function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
|
15
|
+
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
|
|
16
|
+
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|
17
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
|
|
18
|
+
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
19
|
+
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
20
|
+
let BaseOrb = /*#__PURE__*/_createClass(function BaseOrb(drawer) {
|
|
21
|
+
_classCallCheck(this, BaseOrb);
|
|
22
|
+
this.drawer = drawer;
|
|
23
|
+
});
|
|
24
|
+
let Orb = /*#__PURE__*/function (_BaseOrb) {
|
|
25
|
+
_inherits(Orb, _BaseOrb);
|
|
26
|
+
var _super = _createSuper(Orb);
|
|
27
|
+
function Orb(drawer, velocity, bounds, radius) {
|
|
28
|
+
var _this;
|
|
29
|
+
_classCallCheck(this, Orb);
|
|
30
|
+
_this = _super.call(this, drawer);
|
|
31
|
+
_this.x = Math.random() * bounds.width | 0;
|
|
32
|
+
_this.y = Math.random() * bounds.height | 0;
|
|
33
|
+
_this.radius = radius;
|
|
34
|
+
_this.bounds = bounds;
|
|
35
|
+
var radiant = Math.random() * Math.PI * 2,
|
|
36
|
+
vel = velocity;
|
|
37
|
+
vel *= 0.2;
|
|
38
|
+
_this.vx = Math.cos(radiant) * vel;
|
|
39
|
+
_this.vy = Math.sin(radiant) * vel;
|
|
40
|
+
return _this;
|
|
41
|
+
}
|
|
42
|
+
_createClass(Orb, [{
|
|
43
|
+
key: "step",
|
|
44
|
+
value: function step() {
|
|
45
|
+
this.x += this.vx;
|
|
46
|
+
this.y += this.vy;
|
|
47
|
+
var radius = this.radius / 2;
|
|
48
|
+
if (this.x < -radius || this.x > this.bounds.width + radius) this.vx *= -1;
|
|
49
|
+
if (this.y < -radius || this.y > this.bounds.height + radius) this.vy *= -1;
|
|
50
|
+
this.drawer.drawOrb(this.x | 0, this.y | 0, this.radius);
|
|
51
|
+
}
|
|
52
|
+
}]);
|
|
53
|
+
return Orb;
|
|
54
|
+
}(BaseOrb);
|
|
55
|
+
exports.Orb = Orb;
|
|
56
|
+
let GuideOrb = /*#__PURE__*/function (_BaseOrb2) {
|
|
57
|
+
_inherits(GuideOrb, _BaseOrb2);
|
|
58
|
+
var _super2 = _createSuper(GuideOrb);
|
|
59
|
+
function GuideOrb(drawer, deflateDuration) {
|
|
60
|
+
var _this2;
|
|
61
|
+
_classCallCheck(this, GuideOrb);
|
|
62
|
+
_this2 = _super2.call(this, drawer);
|
|
63
|
+
_this2.deflateDuration = deflateDuration;
|
|
64
|
+
return _this2;
|
|
65
|
+
}
|
|
66
|
+
_createClass(GuideOrb, [{
|
|
67
|
+
key: "step",
|
|
68
|
+
value: function step(size, sizeToIncrease, lastSizeTimestamp, lastPositionTimestamp, currPos, moveBy) {
|
|
69
|
+
const deltaTime = Date.now() - lastSizeTimestamp;
|
|
70
|
+
const deltaTimePercent = deltaTime > 250 ? 1 : deltaTime * 100 / 250 / 100;
|
|
71
|
+
const radius = size - (sizeToIncrease - sizeToIncrease * deltaTimePercent);
|
|
72
|
+
this.lastRadius = radius;
|
|
73
|
+
const deltaTimePos = Date.now() - lastPositionTimestamp;
|
|
74
|
+
const deltaTimePosPercent = deltaTimePos > this.deflateDuration ? 1 : deltaTimePos * 100 / this.deflateDuration / 100;
|
|
75
|
+
const translateX = currPos.x - (moveBy.x - moveBy.x * deltaTimePosPercent);
|
|
76
|
+
this.lastX = translateX;
|
|
77
|
+
const translateY = currPos.y - (moveBy.y - moveBy.y * deltaTimePosPercent);
|
|
78
|
+
this.lastY = translateY;
|
|
79
|
+
this.drawer.drawOrb(translateX | 0, translateY | 0, radius);
|
|
80
|
+
}
|
|
81
|
+
}]);
|
|
82
|
+
return GuideOrb;
|
|
83
|
+
}(BaseOrb);
|
|
84
|
+
exports.GuideOrb = GuideOrb;
|
|
85
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["BaseOrb","_createClass","drawer","_classCallCheck","Orb","_BaseOrb","_inherits","_super","_createSuper","velocity","bounds","radius","_this","call","x","Math","random","width","y","height","radiant","PI","vel","vx","cos","vy","sin","key","value","step","drawOrb","exports","GuideOrb","_BaseOrb2","_super2","deflateDuration","_this2","size","sizeToIncrease","lastSizeTimestamp","lastPositionTimestamp","currPos","moveBy","deltaTime","Date","now","deltaTimePercent","lastRadius","deltaTimePos","deltaTimePosPercent","translateX","lastX","translateY","lastY"],"sources":["../../src/models/Orbs.ts"],"sourcesContent":["export interface OrbDrawer {\n  drawOrb(x: number, y: number, radius: number): void;\n}\n\nclass BaseOrb {\n  protected drawer: OrbDrawer;\n  constructor(drawer: OrbDrawer) {\n    this.drawer = drawer;\n  }\n}\n\nexport class Orb extends BaseOrb {\n  x: number;\n  y: number;\n  vx: number;\n  vy: number;\n  radius: number;\n  bounds: { width: number; height: number };\n\n  constructor(\n    drawer: OrbDrawer,\n    velocity: number,\n    bounds: Orb[\"bounds\"],\n    radius: number\n  ) {\n    super(drawer);\n    this.x = (Math.random() * bounds.width) | 0;\n    this.y = (Math.random() * bounds.height) | 0;\n    this.radius = radius;\n    this.bounds = bounds;\n\n    var radiant = Math.random() * Math.PI * 2,\n      vel = velocity;\n\n    vel *= 0.2;\n\n    this.vx = Math.cos(radiant) * vel;\n    this.vy = Math.sin(radiant) * vel;\n  }\n  step() {\n    this.x += this.vx;\n    this.y += this.vy;\n\n    var radius = this.radius / 2;\n\n    if (this.x < -radius || this.x > this.bounds.width + radius) this.vx *= -1;\n\n    if (this.y < -radius || this.y > this.bounds.height + radius) this.vy *= -1;\n\n    this.drawer.drawOrb(this.x | 0, this.y | 0, this.radius);\n  }\n}\n\nexport class GuideOrb extends BaseOrb {\n  lastRadius!: number;\n  lastX!: number;\n  lastY!: number;\n  deflateDuration: number;\n\n  constructor(drawer: OrbDrawer, deflateDuration: number) {\n    super(drawer);\n    this.deflateDuration = deflateDuration;\n  }\n\n  step(\n    size: number,\n    sizeToIncrease: number,\n    lastSizeTimestamp: number,\n    lastPositionTimestamp: number,\n    currPos: { x: number; y: number },\n    moveBy: {\n      x: number;\n      y: number;\n    }\n  ) {\n    const deltaTime = Date.now() - lastSizeTimestamp;\n    const deltaTimePercent =\n      deltaTime > 250 ? 1 : (deltaTime * 100) / 250 / 100;\n\n    const radius = size - (sizeToIncrease - sizeToIncrease * deltaTimePercent);\n\n    this.lastRadius = radius;\n\n    const deltaTimePos = Date.now() - lastPositionTimestamp;\n    const deltaTimePosPercent =\n      deltaTimePos > this.deflateDuration\n        ? 1\n        : (deltaTimePos * 100) / this.deflateDuration / 100;\n\n    const translateX = currPos.x - (moveBy.x - moveBy.x * deltaTimePosPercent);\n    this.lastX = translateX;\n    const translateY = currPos.y - (moveBy.y - moveBy.y * deltaTimePosPercent);\n    this.lastY = translateY;\n\n    this.drawer.drawOrb(translateX | 0, translateY | 0, radius);\n  }\n}\n"],"mappings":"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"}
|
package/dist/utility.d.js
CHANGED
|
@@ -15,4 +15,4 @@ let OnepercentUtility;
|
|
|
15
15
|
let UIElements;
|
|
16
16
|
(function (_UIElements) {})(UIElements || (UIElements = {}));
|
|
17
17
|
})(OnepercentUtility || (OnepercentUtility = {}));
|
|
18
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPbmVwZXJjZW50VXRpbGl0eSIsIl9PbmVwZXJjZW50VXRpbGl0eSIsIkFzeW5jUXVldWUiLCJfQXN5bmNRdWV1ZSIsIlVJRWxlbWVudHMiLCJfVUlFbGVtZW50cyJdLCJzb3VyY2VzIjpbIi4uL3NyYy91dGlsaXR5LmQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBUaGVzZSBhcmUgdHlwaW5ncyBtYWRlIHRvIHN1cHBvcnQgc2VwYXJhdGVkIGZ1bmN0aW9uIGFuZCBwcmV2ZW50IGV4Y2Vzc2l2ZSBHZW5lcmljcyB1c2FnZSBhY2Nyb3NzIHRoZSBhcHBsaWNhdGlvblxuICpcbiAqIFJlZGVjbGFyZSB0aGlzIG5hbWVzcGFjZSB3aXRoIHRoZSB1c2VmdWxsIHR5cGluZ3MgZm9yIHlvdXIgcHJvamVjdCBhbmQgZW5qb3kgaW50ZWxpc2Vuc2UgOilcbiAqL1xubmFtZXNwYWNlIE9uZXBlcmNlbnRVdGlsaXR5IHtcbiAgLyoqIFRoZSBpZHMgdXNlZCBieSB0aGUgdXNlU2hvcnRJbnRsIGhvb2tzICovXG4gIHR5cGUgSW50bElkcyA9IFwiZ2VuZXJpYy5pZFwiO1xuICAvKiogQSB0eXBlIGhpbnQgdG8gYmluZCB0aGUgTGlua1RvSWQgYWN0aW9uIGFuZCB0aGUgU2VjdGlvbkNvbnRhaW5lciBpZGVudGlmaWVyICovXG4gIHR5cGUgUGFnZVNlY3Rpb25zID0gXCJleGFtcGxlLXNlY3Rpb24tMVwiO1xuICAvKiogQSB0eXBlIGhpbnQgdG8gYXV0b2NvbXBsZXRlIGZ1bmN0aW9ucyByZWxhdGVkIHRvIHRoZSBBc3luY1Byb2Nlc3MgY29udGV4dCAqL1xuICBuYW1lc3BhY2UgQXN5bmNRdWV1ZSB7XG4gICAgLyoqIFRoZXNlIGFyZSB0aGUgcmVjb3ZlcnkgdHlwZXMgYXZhaWxhYmxlICovXG4gICAgdHlwZSBSZWNvdmVyeVR5cGVzID0ge1xuICAgICAgW1I6IHN0cmluZ106IGFueVtdO1xuICAgIH07XG5cbiAgICAvKiogVGhlc2UgYXJlIHRoZSBhdmFpbGFibGUgVUkgbW9kZWxzICovXG4gICAgdHlwZSBQcm9jZXNzZXMgPSB7XG4gICAgICBbayBpbiBcIndhaXRGb3JCdWlsZFwiXTogW3RoYXNoOiBzdHJpbmddO1xuICAgIH07XG4gIH1cbiAgLyoqIFRoZXNlIGFyZSB0aGUgZXh0ZW5zaWJsZSBwcm9wZXJ0aWVzIGZvciB0aGUgVUkgZWxlbWVudHMgKi9cbiAgbmFtZXNwYWNlIFVJRWxlbWVudHMge1xuICAgIHR5cGUgQWRhcHRpdmVEaWFsb2dWYXJpYW50cyA9IFwiZGVmYXVsdFwiO1xuICAgIHR5cGUgQnV0dG9uVmFyaWFudHMgPSBcInRyYW5zcGFyZW50XCIgfCBcImZpbGxlZFwiIHwgXCJvdXRsaW5lXCIgfCBcImxpbmtcIjtcbiAgICB0eXBlIFRleHRWYXJpYW50cyA9XG4gICAgICB8IFwidGl0bGVcIlxuICAgICAgfCBcImRlc2NyaXB0aW9uXCJcbiAgICAgIHwgXCJlcnJvclwiXG4gICAgICB8IFwiY2FwdGlvblwiXG4gICAgICB8IFwiaGlnaGxpZ2h0VGl0bGVcIlxuICAgICAgfCBcImhpZ2hsaWdodFwiXG4gICAgICB8IFwic3VidGl0bGVcIlxuICAgICAgfCBcImJvbGRUaXRsZVwiXG4gICAgICB8IFwibGlua1wiXG4gICAgICB8IFwiYm9sZFRpdGxlQmlnXCJcbiAgICAgIHwgXCJjb250ZW50XCI7XG4gICAgdHlwZSBTcGFjaW5nVmFyaWFudHMgPSBcImxhcmdlXCIgfCBcInNtYWxsXCI7XG4gICAgdHlwZSBUZXh0Q29sb3JzID0gXCJwcmltYXJ5XCIgfCBcImVycm9yXCIgfCB1bmRlZmluZWQ7XG4gICAgdHlwZSBGb3JtRXh0ZW5zaW9uID0ge1xuICAgICAgZmllbGRzOlxuICAgICAgICB8IHtcbiAgICAgICAgICAgIHR5cGU6IFwicGhvbmVcIjtcbiAgICAgICAgICAgIGNvdW50cnk6IHN0cmluZztcbiAgICAgICAgICB9XG4gICAgICAgIHwge1xuICAgICAgICAgICAgdHlwZTogXCJkYXRlXCI7XG4gICAgICAgICAgfTtcbiAgICAgIGZpZWxkQW5zd2VyOiB7XG4gICAgICAgIHBob25lOiBbXG4gICAgICAgICAgcGhvbmVOdW1iZXI6IHN0cmluZyxcbiAgICAgICAgICBpc1ZhbGlkOiBib29sZWFuLFxuICAgICAgICAgIGVycm9yOiBzdHJpbmcgfCB1bmRlZmluZWRcbiAgICAgICAgXTtcbiAgICAgIH07XG4gICAgfTtcbiAgfVxufVxuZGVjbGFyZSBtb2R1bGUgXCJ1c2Utd2FsbGV0XCIge1xuICBpbXBvcnQgKiBhcyBVc2VXYWxsZXQgZnJvbSBcInVzZS13YWxsZXRcIjtcbiAgZXhwb3J0IGNvbnN0IHVzZVdhbGxldDogdHlwZW9mIFVzZVdhbGxldFtcInVzZS13YWxsZXRcIl07XG4gIGV4cG9ydCBjb25zdCBVc2VXYWxsZXRQcm92aWRlcjogdHlwZW9mIFVzZVdhbGxldFtcIlVzZVdhbGxldFByb3ZpZGVyXCJdO1xufVxuXG5kZWNsYXJlIG1vZHVsZSBcIioubXA0XCIge1xuICBjb25zdCB2OiBzdHJpbmc7XG4gIGV4cG9ydCBkZWZhdWx0IHY7XG59XG4iXSwibWFwcGluZ3MiOiI7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUpBLElBQUFBLGlCQUFBO0FBQUEsV0FBQUMsa0JBQUE7RUFNRTtFQUVBO0VBRUE7RUFBQSxJQUFBQyxVQUFBO0VBQUEsV0FBQUMsV0FBQSxNQUNVRCxVQUFVLEtBQVZBLFVBQVU7RUFBQSxJQUFBRSxVQUFBO0VBQUEsV0FBQUMsV0FBQSxNQVlWRCxVQUFVLEtBQVZBLFVBQVU7QUFBQSxHQWxCWkosaUJBQWlCLEtBQWpCQSxpQkFBaUIifQ==
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@onepercentio/one-ui",
|
|
3
|
-
"version": "0.22.
|
|
3
|
+
"version": "0.22.2",
|
|
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>",
|