@1money/component-ui 0.0.17 → 0.0.18

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.
@@ -102,7 +102,9 @@
102
102
  "Bash(grep -B5 -A 20 \"type MiddlewareData\\\\|interface MiddlewareData\" /Users/derrick/Desktop/1money/1money-components-ui/node_modules/.pnpm/@floating-ui+core@*/node_modules/@floating-ui/core/dist/floating-ui.core.d.ts)",
103
103
  "Bash(grep:*)",
104
104
  "mcp__figma-dev-mode-mcp-server__get_variable_defs",
105
- "Bash(gh api *)"
105
+ "Bash(gh api *)",
106
+ "Bash(cp /Users/wali/1Money/1money-react-ui/src/components/Loading/lottie-pure.json /Users/wali/1Money/1money-components-ui/src/components/Spinner/lottie-pure.json)",
107
+ "Bash(cp /Users/wali/1Money/1money-react-ui/src/components/Loading/lottie-pattern.json /Users/wali/1Money/1money-components-ui/src/components/Spinner/lottie-pattern.json)"
106
108
  ]
107
109
  }
108
110
  }
@@ -1,5 +1,33 @@
1
1
  'use client';
2
2
 
3
+ import _regeneratorRuntime from "@babel/runtime/regenerator";
4
+ var __awaiter = this && this.__awaiter || function (thisArg, _arguments, P, generator) {
5
+ function adopt(value) {
6
+ return value instanceof P ? value : new P(function (resolve) {
7
+ resolve(value);
8
+ });
9
+ }
10
+ return new (P || (P = Promise))(function (resolve, reject) {
11
+ function fulfilled(value) {
12
+ try {
13
+ step(generator.next(value));
14
+ } catch (e) {
15
+ reject(e);
16
+ }
17
+ }
18
+ function rejected(value) {
19
+ try {
20
+ step(generator["throw"](value));
21
+ } catch (e) {
22
+ reject(e);
23
+ }
24
+ }
25
+ function step(result) {
26
+ result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);
27
+ }
28
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
29
+ });
30
+ };
3
31
  var __rest = this && this.__rest || function (s, e) {
4
32
  var t = {};
5
33
  for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
@@ -9,12 +37,53 @@ var __rest = this && this.__rest || function (s, e) {
9
37
  return t;
10
38
  };
11
39
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
12
- import { memo } from 'react';
13
- import { Logo, LogoBg } from '../Icons/Logo';
40
+ import { memo, useEffect, useId, useRef } from 'react';
14
41
  import { Typography } from '../Typography';
15
42
  import classnames, { joinCls } from '../../utils/classnames';
43
+ import lottiePureJson from './lottie-pure.json';
16
44
  import './style';
17
45
  var DEFAULT_SIZE = 32;
46
+ var BG_LOGO_RATIO = 2 / 3;
47
+ var BrandBgCircle = function BrandBgCircle(_ref) {
48
+ var size = _ref.size,
49
+ className = _ref.className;
50
+ var rawId = useId();
51
+ var gradId = "spinner-bg-".concat(rawId.replace(/[^a-zA-Z0-9]/g, ''));
52
+ return _jsxs("svg", {
53
+ width: size,
54
+ height: size,
55
+ viewBox: "0 0 56 57",
56
+ className: className,
57
+ "aria-hidden": "true",
58
+ children: [_jsx("circle", {
59
+ cx: "28",
60
+ cy: "28.75",
61
+ r: "28",
62
+ fill: "url(#".concat(gradId, ")")
63
+ }), _jsx("defs", {
64
+ children: _jsxs("radialGradient", {
65
+ id: gradId,
66
+ cx: "0",
67
+ cy: "0",
68
+ r: "1",
69
+ gradientUnits: "userSpaceOnUse",
70
+ gradientTransform: "translate(-34.9085 92.6678) rotate(-45.6594) scale(108.853 103.698)",
71
+ children: [_jsx("stop", {
72
+ stopColor: "#073387"
73
+ }), _jsx("stop", {
74
+ offset: "0.216852",
75
+ stopColor: "#90A8CF"
76
+ }), _jsx("stop", {
77
+ offset: "0.567103",
78
+ stopColor: "#CBD6E8"
79
+ }), _jsx("stop", {
80
+ offset: "1",
81
+ stopColor: "#F9F9F9"
82
+ })]
83
+ })
84
+ })]
85
+ });
86
+ };
18
87
  export var Spinner = function Spinner(props) {
19
88
  var className = props.className,
20
89
  style = props.style,
@@ -28,16 +97,77 @@ export var Spinner = function Spinner(props) {
28
97
  body = props.body,
29
98
  rest = __rest(props, ["className", "style", "prefixCls", "type", "size", "title", "body"]);
30
99
  var classes = classnames(prefixCls);
31
- if (type === 'brand' || type === 'brand-bg') {
100
+ var lottieRef = useRef(null);
101
+ var isBrand = type === 'brand' || type === 'brand-bg';
102
+ useEffect(function () {
103
+ if (!isBrand || !lottieRef.current) return;
104
+ var instance = null;
105
+ var destroyed = false;
106
+ (function () {
107
+ return __awaiter(void 0, void 0, void 0, /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
108
+ var lottie;
109
+ return _regeneratorRuntime.wrap(function _callee$(_context) {
110
+ while (1) switch (_context.prev = _context.next) {
111
+ case 0:
112
+ _context.next = 2;
113
+ return import('lottie-web');
114
+ case 2:
115
+ lottie = _context.sent["default"];
116
+ if (!(destroyed || !lottieRef.current)) {
117
+ _context.next = 5;
118
+ break;
119
+ }
120
+ return _context.abrupt("return");
121
+ case 5:
122
+ instance = lottie.loadAnimation({
123
+ container: lottieRef.current,
124
+ renderer: 'svg',
125
+ loop: true,
126
+ autoplay: true,
127
+ animationData: lottiePureJson
128
+ });
129
+ case 6:
130
+ case "end":
131
+ return _context.stop();
132
+ }
133
+ }, _callee);
134
+ }));
135
+ })();
136
+ return function () {
137
+ destroyed = true;
138
+ if (instance) {
139
+ instance.destroy();
140
+ instance = null;
141
+ }
142
+ };
143
+ }, [isBrand]);
144
+ if (isBrand) {
32
145
  var hasBg = type === 'brand-bg';
146
+ var lottieSize = hasBg ? size * BG_LOGO_RATIO : size;
147
+ var lottieStyle = {
148
+ width: lottieSize,
149
+ height: lottieSize
150
+ };
33
151
  return _jsxs("div", Object.assign({}, rest, {
34
152
  className: classes(void 0, joinCls(classes('brand'), hasBg && classes('brand-bg'), className)),
35
- children: [hasBg ? _jsx(LogoBg, {
36
- size: size,
37
- className: joinCls(classes('logo-bg'), classes('spin'))
38
- }) : _jsx(Logo, {
39
- size: size,
40
- className: joinCls(classes('logo'), classes('spin'))
153
+ children: [hasBg ? _jsxs("div", {
154
+ className: classes('icon-wrap'),
155
+ style: {
156
+ width: size,
157
+ height: size
158
+ },
159
+ children: [_jsx(BrandBgCircle, {
160
+ size: size,
161
+ className: classes('bg')
162
+ }), _jsx("div", {
163
+ ref: lottieRef,
164
+ className: classes('lottie'),
165
+ style: lottieStyle
166
+ })]
167
+ }) : _jsx("div", {
168
+ ref: lottieRef,
169
+ className: classes('lottie'),
170
+ style: lottieStyle
41
171
  }), (title || body) && _jsxs("div", {
42
172
  className: classes('content'),
43
173
  children: [title && (hasBg ? _jsx(Typography.Headline, {
@@ -81,4 +211,4 @@ export var Spinner = function Spinner(props) {
81
211
  }));
82
212
  };
83
213
  export default /*#__PURE__*/memo(Spinner);
84
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["components/src/components/Spinner/Spinner.tsx","components/Spinner/Spinner.js"],"names":["__rest","s","e","t","p","Object","prototype","hasOwnProperty","call","indexOf","getOwnPropertySymbols","i","length","propertyIsEnumerable","jsx","_jsx","jsxs","_jsxs","memo","Logo","LogoBg","Typography","classnames","joinCls","DEFAULT_SIZE","Spinner","props","className","style","_props$prefixCls","prefixCls","_props$type","type","_props$size","size","title","body","rest","classes","hasBg","assign","children","Headline","color","Body","role","width","height","viewBox","cx","cy","r","fill","strokeWidth"],"mappings":"AAAA,YAAY;;ACCZ,IAAIA,MAAM,GAAI,IAAI,IAAI,IAAI,CAACA,MAAM,IAAK,UAAUC,CAAC,EAAEC,CAAC,EAAE;EAClD,IAAIC,CAAC,GAAG,CAAC,CAAC;EACV,KAAK,IAAIC,CAAC,IAAIH,CAAC,EAAE,IAAII,MAAM,CAACC,SAAS,CAACC,cAAc,CAACC,IAAI,CAACP,CAAC,EAAEG,CAAC,CAAC,IAAIF,CAAC,CAACO,OAAO,CAACL,CAAC,CAAC,GAAG,CAAC,EAC/ED,CAAC,CAACC,CAAC,CAAC,GAAGH,CAAC,CAACG,CAAC,CAAC;EACf,IAAIH,CAAC,IAAI,IAAI,IAAI,OAAOI,MAAM,CAACK,qBAAqB,KAAK,UAAU,EAC/D,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEP,CAAC,GAAGC,MAAM,CAACK,qBAAqB,CAACT,CAAC,CAAC,EAAEU,CAAC,GAAGP,CAAC,CAACQ,MAAM,EAAED,CAAC,EAAE,EAAE;IACpE,IAAIT,CAAC,CAACO,OAAO,CAACL,CAAC,CAACO,CAAC,CAAC,CAAC,GAAG,CAAC,IAAIN,MAAM,CAACC,SAAS,CAACO,oBAAoB,CAACL,IAAI,CAACP,CAAC,EAAEG,CAAC,CAACO,CAAC,CAAC,CAAC,EAC1ER,CAAC,CAACC,CAAC,CAACO,CAAC,CAAC,CAAC,GAAGV,CAAC,CAACG,CAAC,CAACO,CAAC,CAAC,CAAC;EACzB;EACJ,OAAOR,CAAC;AACZ,CAAC;AACD,SAASW,GAAG,IAAIC,IAAI,EAAEC,IAAI,IAAIC,KAAK,QAAQ,mBAAmB;ADX9D,SAASC,IAAI,QAAQ,OAAO;AAC5B,SAASC,IAAI,EAAEC,MAAM,QAAQ,eAAe;AAC5C,SAASC,UAAU,QAAQ,eAAe;AAC1C,OAAOC,UAAU,IAAIC,OAAO,QAAQ,wBAAwB;AAI5D,OAAO,SAAS;AAEhB,IAAMC,YAAY,GAAG,EAAE;AAEvB,OAAO,IAAMC,OAAO,GAAqB,SAA5BA,OAAOA,CAAqBC,KAAK,EAAG;EAC/C,IACEC,SAAS,GAQPD,KAAK,CARPC,SAAS;IACTC,KAAK,GAOHF,KAAK,CAPPE,KAAK;IAAAC,gBAAA,GAOHH,KAAK,CANPI,SAAS;IAATA,SAAS,GAAAD,gBAAA,cAAG,SAAS,GAAAA,gBAAA;IAAAE,WAAA,GAMnBL,KAAK,CALPM,IAAI;IAAJA,IAAI,GAAAD,WAAA,cAAG,SAAS,GAAAA,WAAA;IAAAE,WAAA,GAKdP,KAAK,CAJPQ,IAAI;IAAJA,IAAI,GAAAD,WAAA,cAAGT,YAAY,GAAAS,WAAA;IACnBE,KAAK,GAGHT,KAAK,CAHPS,KAAK;IACLC,IAAI,GAEFV,KAAK,CAFPU,IAAI;IACDC,IAAI,GAAArC,MAAA,CACL0B,KAAK,EATH,CAAA,WAAA,EAAA,OAAA,EAAA,WAAA,EAAA,MAAA,EAAA,MAAA,EAAA,OAAA,EAAA,MAAA,CASL,CAAQ;EACT,IAAMY,OAAO,GAAGhB,UAAU,CAACQ,SAAS,CAAC;EAErC,IAAIE,IAAI,KAAK,OAAO,IAAIA,IAAI,KAAK,UAAU,EAAE;IAC3C,IAAMO,KAAK,GAAGP,IAAI,KAAK,UAAU;IAEjC,OACEf,KAAA,CAAA,KAAA,EAAAZ,MAAA,CAAAmC,MAAA,CAAA,CAAA,CAAA,EAASH,IAAI,EAAA;MAAEV,SAAS,EAAEW,OAAO,CAAC,KAAK,CAAC,EAAEf,OAAO,CAACe,OAAO,CAAC,OAAO,CAAC,EAAEC,KAAK,IAAID,OAAO,CAAC,UAAU,CAAC,EAAEX,SAAS,CAAC,CAAC;MAAAc,QAAA,EAAA,CAC1GF,KAAK,GACFxB,IAAA,CAACK,MAAM,EAAA;QAACc,IAAI,EAAEA,IAAI;QAAEP,SAAS,EAAEJ,OAAO,CAACe,OAAO,CAAC,SAAS,CAAC,EAAEA,OAAO,CAAC,MAAM,CAAC;MAAC,CAAA,CAAI,GAC/EvB,IAAA,CAACI,IAAI,EAAA;QAACe,IAAI,EAAEA,IAAI;QAAEP,SAAS,EAAEJ,OAAO,CAACe,OAAO,CAAC,MAAM,CAAC,EAAEA,OAAO,CAAC,MAAM,CAAC;MAAC,CAAA,CAAI,EAE7E,CAACH,KAAK,IAAIC,IAAI,KACbnB,KAAA,CAAA,KAAA,EAAA;QAAKU,SAAS,EAAEW,OAAO,CAAC,SAAS,CAAC;QAAAG,QAAA,EAAA,CAC/BN,KAAK,KACJI,KAAK,GACDxB,IAAA,CAACM,UAAU,CAACqB,QAAQ,EAAA;UAACR,IAAI,EAAC,IAAI;UAACS,KAAK,EAAC,SAAS;UAAChB,SAAS,EAAEW,OAAO,CAAC,OAAO,CAAC;UAAAG,QAAA,EAAGN;QAAK,CAAA,CAAuB,GACzGpB,IAAA,CAACM,UAAU,CAACuB,IAAI,EAAA;UAACV,IAAI,EAAC,IAAI;UAACS,KAAK,EAAC,kBAAkB;UAAChB,SAAS,EAAEW,OAAO,CAAC,OAAO,CAAC;UAAAG,QAAA,EAAGN;QAAK,CAAA,CAAmB,CAC/G,EACAC,IAAI,IACHrB,IAAA,CAACM,UAAU,CAACuB,IAAI,EAAA;UAACV,IAAI,EAAC,IAAI;UAACS,KAAK,EAAC,kBAAkB;UAAChB,SAAS,EAAEW,OAAO,CAAC,MAAM,CAAC;UAAAG,QAAA,EAC3EL;QAAI,CAAA,CAER;MAAA,CAAA,CAEJ;IAAA,CAAA,CAAA,CACG;EAEV;EAEA,OACErB,IAAA,CAAA,KAAA,EAAAV,MAAA,CAAAmC,MAAA,CAAA,CAAA,CAAA,EACMH,IAAI,EAAA;IACRQ,IAAI,EAAC,aAAa;IAClBlB,SAAS,EAAEW,OAAO,CAAC,KAAK,CAAC,EAAEX,SAAS,CAAC;IACrCC,KAAK,EAAAvB,MAAA,CAAAmC,MAAA,CAAA;MAAIM,KAAK,EAAEZ,IAAI;MAAEa,MAAM,EAAEb;IAAI,CAAA,EAAKN,KAAK,CAAA;IAAAa,QAAA,EAE5C1B,IAAA,CAAA,KAAA,EAAA;MAAKY,SAAS,EAAEW,OAAO,CAAC,QAAQ,CAAC;MAAEU,OAAO,EAAC,WAAW;MAAAP,QAAA,EACpD1B,IAAA,CAAA,QAAA,EAAA;QACEY,SAAS,EAAEW,OAAO,CAAC,MAAM,CAAC;QAC1BW,EAAE,EAAC,IAAI;QACPC,EAAE,EAAC,IAAI;QACPC,CAAC,EAAC,IAAI;QACNC,IAAI,EAAC,MAAM;QACXC,WAAW,EAAC;MAAG,CAAA;IACf,CAAA;EACE,CAAA,CAAA,CACF;AAEV,CAAC;AAED,4BAAenC,IAAI,CAACO,OAAO,CAAC","file":"components/Spinner/Spinner.js","sourcesContent":[null,"'use client';\nvar __rest = (this && this.__rest) || function (s, e) {\n    var t = {};\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n        t[p] = s[p];\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n                t[p[i]] = s[p[i]];\n        }\n    return t;\n};\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport { memo } from 'react';\nimport { Logo, LogoBg } from '../Icons/Logo';\nimport { Typography } from '../Typography';\nimport classnames, { joinCls } from '../../utils/classnames';\nimport './style';\nconst DEFAULT_SIZE = 32;\nexport const Spinner = props => {\n    const { className, style, prefixCls = 'spinner', type = 'default', size = DEFAULT_SIZE, title, body } = props, rest = __rest(props, [\"className\", \"style\", \"prefixCls\", \"type\", \"size\", \"title\", \"body\"]);\n    const classes = classnames(prefixCls);\n    if (type === 'brand' || type === 'brand-bg') {\n        const hasBg = type === 'brand-bg';\n        return (_jsxs(\"div\", Object.assign({}, rest, { className: classes(void 0, joinCls(classes('brand'), hasBg && classes('brand-bg'), className)), children: [hasBg\n                    ? _jsx(LogoBg, { size: size, className: joinCls(classes('logo-bg'), classes('spin')) })\n                    : _jsx(Logo, { size: size, className: joinCls(classes('logo'), classes('spin')) }), (title || body) && (_jsxs(\"div\", { className: classes('content'), children: [title && (hasBg\n                            ? _jsx(Typography.Headline, { size: \"sm\", color: \"default\", className: classes('title'), children: title })\n                            : _jsx(Typography.Body, { size: \"md\", color: \"default-tertiary\", className: classes('title'), children: title })), body && (_jsx(Typography.Body, { size: \"md\", color: \"default-tertiary\", className: classes('body'), children: body }))] }))] })));\n    }\n    return (_jsx(\"div\", Object.assign({}, rest, { role: \"progressbar\", className: classes(void 0, className), style: Object.assign({ width: size, height: size }, style), children: _jsx(\"svg\", { className: classes('circle'), viewBox: \"0 0 50 50\", children: _jsx(\"circle\", { className: classes('path'), cx: \"25\", cy: \"25\", r: \"20\", fill: \"none\", strokeWidth: \"4\" }) }) })));\n};\nexport default memo(Spinner);"],"sourceRoot":"../../../../../../../../../src"}
214
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["components/src/components/Spinner/Spinner.tsx","components/Spinner/Spinner.js"],"names":["_regeneratorRuntime","__awaiter","thisArg","_arguments","P","generator","adopt","value","resolve","Promise","reject","fulfilled","step","next","e","rejected","result","done","then","apply","__rest","s","t","p","Object","prototype","hasOwnProperty","call","indexOf","getOwnPropertySymbols","i","length","propertyIsEnumerable","jsx","_jsx","jsxs","_jsxs","memo","useEffect","useId","useRef","Typography","classnames","joinCls","lottiePureJson","DEFAULT_SIZE","BG_LOGO_RATIO","BrandBgCircle","_ref","size","className","rawId","gradId","concat","replace","width","height","viewBox","children","cx","cy","r","fill","id","gradientUnits","gradientTransform","stopColor","offset","Spinner","props","style","_props$prefixCls","prefixCls","_props$type","type","_props$size","title","body","rest","classes","lottieRef","isBrand","current","instance","destroyed","mark","_callee","lottie","wrap","_callee$","_context","prev","sent","abrupt","loadAnimation","container","renderer","loop","autoplay","animationData","stop","destroy","hasBg","lottieSize","lottieStyle","assign","ref","Headline","color","Body","role","strokeWidth"],"mappings":"AAAA,YAAY;;AAAC,OAAAA,mBAAA;ACCb,IAAIC,SAAS,GAAI,IAAI,IAAI,IAAI,CAACA,SAAS,IAAK,UAAUC,OAAO,EAAEC,UAAU,EAAEC,CAAC,EAAEC,SAAS,EAAE;EACrF,SAASC,KAAKA,CAACC,KAAK,EAAE;IAAE,OAAOA,KAAK,YAAYH,CAAC,GAAGG,KAAK,GAAG,IAAIH,CAAC,CAAC,UAAUI,OAAO,EAAE;MAAEA,OAAO,CAACD,KAAK,CAAC;IAAE,CAAC,CAAC;EAAE;EAC3G,OAAO,KAAKH,CAAC,KAAKA,CAAC,GAAGK,OAAO,CAAC,EAAE,UAAUD,OAAO,EAAEE,MAAM,EAAE;IACvD,SAASC,SAASA,CAACJ,KAAK,EAAE;MAAE,IAAI;QAAEK,IAAI,CAACP,SAAS,CAACQ,IAAI,CAACN,KAAK,CAAC,CAAC;MAAE,CAAC,CAAC,OAAOO,CAAC,EAAE;QAAEJ,MAAM,CAACI,CAAC,CAAC;MAAE;IAAE;IAC1F,SAASC,QAAQA,CAACR,KAAK,EAAE;MAAE,IAAI;QAAEK,IAAI,CAACP,SAAS,CAAC,OAAO,CAAC,CAACE,KAAK,CAAC,CAAC;MAAE,CAAC,CAAC,OAAOO,CAAC,EAAE;QAAEJ,MAAM,CAACI,CAAC,CAAC;MAAE;IAAE;IAC7F,SAASF,IAAIA,CAACI,MAAM,EAAE;MAAEA,MAAM,CAACC,IAAI,GAAGT,OAAO,CAACQ,MAAM,CAACT,KAAK,CAAC,GAAGD,KAAK,CAACU,MAAM,CAACT,KAAK,CAAC,CAACW,IAAI,CAACP,SAAS,EAAEI,QAAQ,CAAC;IAAE;IAC7GH,IAAI,CAAC,CAACP,SAAS,GAAGA,SAAS,CAACc,KAAK,CAACjB,OAAO,EAAEC,UAAU,IAAI,EAAE,CAAC,EAAEU,IAAI,CAAC,CAAC,CAAC;EACzE,CAAC,CAAC;AACN,CAAC;AACD,IAAIO,MAAM,GAAI,IAAI,IAAI,IAAI,CAACA,MAAM,IAAK,UAAUC,CAAC,EAAEP,CAAC,EAAE;EAClD,IAAIQ,CAAC,GAAG,CAAC,CAAC;EACV,KAAK,IAAIC,CAAC,IAAIF,CAAC,EAAE,IAAIG,MAAM,CAACC,SAAS,CAACC,cAAc,CAACC,IAAI,CAACN,CAAC,EAAEE,CAAC,CAAC,IAAIT,CAAC,CAACc,OAAO,CAACL,CAAC,CAAC,GAAG,CAAC,EAC/ED,CAAC,CAACC,CAAC,CAAC,GAAGF,CAAC,CAACE,CAAC,CAAC;EACf,IAAIF,CAAC,IAAI,IAAI,IAAI,OAAOG,MAAM,CAACK,qBAAqB,KAAK,UAAU,EAC/D,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEP,CAAC,GAAGC,MAAM,CAACK,qBAAqB,CAACR,CAAC,CAAC,EAAES,CAAC,GAAGP,CAAC,CAACQ,MAAM,EAAED,CAAC,EAAE,EAAE;IACpE,IAAIhB,CAAC,CAACc,OAAO,CAACL,CAAC,CAACO,CAAC,CAAC,CAAC,GAAG,CAAC,IAAIN,MAAM,CAACC,SAAS,CAACO,oBAAoB,CAACL,IAAI,CAACN,CAAC,EAAEE,CAAC,CAACO,CAAC,CAAC,CAAC,EAC1ER,CAAC,CAACC,CAAC,CAACO,CAAC,CAAC,CAAC,GAAGT,CAAC,CAACE,CAAC,CAACO,CAAC,CAAC,CAAC;EACzB;EACJ,OAAOR,CAAC;AACZ,CAAC;AACD,SAASW,GAAG,IAAIC,IAAI,EAAEC,IAAI,IAAIC,KAAK,QAAQ,mBAAmB;ADpB9D,SAASC,IAAI,EAAEC,SAAS,EAAEC,KAAK,EAAEC,MAAM,QAAQ,OAAO;AACtD,SAASC,UAAU,QAAQ,eAAe;AAC1C,OAAOC,UAAU,IAAIC,OAAO,QAAQ,wBAAwB;AAC5D,OAAOC,cAAc,MAAM,oBAAoB;AAK/C,OAAO,SAAS;AAEhB,IAAMC,YAAY,GAAG,EAAE;AACvB,IAAMC,aAAa,GAAG,CAAC,GAAG,CAAC;AAO3B,IAAMC,aAAa,GAA2B,SAAxCA,aAAaA,CAAAC,IAAA,EAAmD;EAAA,IAArBC,IAAI,GAAAD,IAAA,CAAJC,IAAI;IAAEC,SAAS,GAAAF,IAAA,CAATE,SAAS;EAC9D,IAAMC,KAAK,GAAGZ,KAAK,CAAA,CAAE;EACrB,IAAMa,MAAM,iBAAAC,MAAA,CAAiBF,KAAK,CAACG,OAAO,CAAC,eAAe,EAAE,EAAE,CAAC,CAAE;EACjE,OACElB,KAAA,CAAA,KAAA,EAAA;IAAKmB,KAAK,EAAEN,IAAI;IAAEO,MAAM,EAAEP,IAAI;IAAEQ,OAAO,EAAC,WAAW;IAACP,SAAS,EAAEA,SAAS;IAAA,aAAA,EAAc,MAAM;IAAAQ,QAAA,EAAA,CAC1FxB,IAAA,CAAA,QAAA,EAAA;MAAQyB,EAAE,EAAC,IAAI;MAACC,EAAE,EAAC,OAAO;MAACC,CAAC,EAAC,IAAI;MAACC,IAAI,UAAAT,MAAA,CAAUD,MAAM;IAAG,CAAA,CAAI,EAC7DlB,IAAA,CAAA,MAAA,EAAA;MAAAwB,QAAA,EACEtB,KAAA,CAAA,gBAAA,EAAA;QACE2B,EAAE,EAAEX,MAAM;QACVO,EAAE,EAAC,GAAG;QACNC,EAAE,EAAC,GAAG;QACNC,CAAC,EAAC,GAAG;QACLG,aAAa,EAAC,gBAAgB;QAC9BC,iBAAiB,EAAC,qEAAqE;QAAAP,QAAA,EAAA,CAEvFxB,IAAA,CAAA,MAAA,EAAA;UAAMgC,SAAS,EAAC;QAAS,CAAA,CAAG,EAC5BhC,IAAA,CAAA,MAAA,EAAA;UAAMiC,MAAM,EAAC,UAAU;UAACD,SAAS,EAAC;QAAS,CAAA,CAAG,EAC9ChC,IAAA,CAAA,MAAA,EAAA;UAAMiC,MAAM,EAAC,UAAU;UAACD,SAAS,EAAC;QAAS,CAAA,CAAG,EAC9ChC,IAAA,CAAA,MAAA,EAAA;UAAMiC,MAAM,EAAC,GAAG;UAACD,SAAS,EAAC;QAAS,CAAA,CAAG;MAAA,CAAA;IACxB,CAAA,CACZ;EAAA,CAAA,CACH;AAEV,CAAC;AAED,OAAO,IAAME,OAAO,GAAqB,SAA5BA,OAAOA,CAAqBC,KAAK,EAAG;EAC/C,IACEnB,SAAS,GAQPmB,KAAK,CARPnB,SAAS;IACToB,KAAK,GAOHD,KAAK,CAPPC,KAAK;IAAAC,gBAAA,GAOHF,KAAK,CANPG,SAAS;IAATA,SAAS,GAAAD,gBAAA,cAAG,SAAS,GAAAA,gBAAA;IAAAE,WAAA,GAMnBJ,KAAK,CALPK,IAAI;IAAJA,IAAI,GAAAD,WAAA,cAAG,SAAS,GAAAA,WAAA;IAAAE,WAAA,GAKdN,KAAK,CAJPpB,IAAI;IAAJA,IAAI,GAAA0B,WAAA,cAAG9B,YAAY,GAAA8B,WAAA;IACnBC,KAAK,GAGHP,KAAK,CAHPO,KAAK;IACLC,IAAI,GAEFR,KAAK,CAFPQ,IAAI;IACDC,IAAI,GAAA1D,MAAA,CACLiD,KAAK,EATH,CAAA,WAAA,EAAA,OAAA,EAAA,WAAA,EAAA,MAAA,EAAA,MAAA,EAAA,OAAA,EAAA,MAAA,CASL,CAAQ;EACT,IAAMU,OAAO,GAAGrC,UAAU,CAAC8B,SAAS,CAAC;EACrC,IAAMQ,SAAS,GAAGxC,MAAM,CAAiB,IAAI,CAAC;EAC9C,IAAMyC,OAAO,GAAGP,IAAI,KAAK,OAAO,IAAIA,IAAI,KAAK,UAAU;EAEvDpC,SAAS,CAAC,YAAK;IACb,IAAI,CAAC2C,OAAO,IAAI,CAACD,SAAS,CAACE,OAAO,EAAE;IAEpC,IAAIC,QAAQ,GAAyB,IAAI;IACzC,IAAIC,SAAS,GAAG,KAAK;IACrB,CAAC;MAAA,OAAWnF,SAAA,CAAA,KAAA,CAAA,EAAA,KAAA,CAAA,EAAA,KAAA,CAAA,eAAAD,mBAAA,CAAAqF,IAAA,CAAA,SAAAC,QAAA;QAAA,IAAAC,MAAA;QAAA,OAAAvF,mBAAA,CAAAwF,IAAA,UAAAC,SAAAC,QAAA;UAAA,kBAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAA7E,IAAA;YAAA;cAAA6E,QAAA,CAAA7E,IAAA;cACM,OAAM,MAAM,CAAC,YAAY,CAAC;YAAA;cAApC0E,MAAM,GAAAG,QAAA,CAAAE,IAAA;cAAA,MACRR,SAAS,IAAI,CAACJ,SAAS,CAACE,OAAO;gBAAAQ,QAAA,CAAA7E,IAAA;gBAAA;cAAA;cAAA,OAAA6E,QAAA,CAAAG,MAAA;YAAA;cACnCV,QAAQ,GAAGI,MAAM,CAACO,aAAa,CAAC;gBAC9BC,SAAS,EAAEf,SAAS,CAACE,OAAO;gBAC5Bc,QAAQ,EAAE,KAAK;gBACfC,IAAI,EAAE,IAAI;gBACVC,QAAQ,EAAE,IAAI;gBACdC,aAAa,EAAEvD;cClBX,CDmBL,CAAC;YAAC;YAAA;cAAA,OAAA8C,QAAA,CAAAU,IAAA;UAAA;QAAA,GAAAd,OAAA;MAAA,CACJ,EAAA;IAAA,GAAC,CAAE;IAEJ,OAAO,YAAK;MACVF,SAAS,GAAG,IAAI;MAChB,IAAID,QAAQ,EAAE;QACZA,QAAQ,CAACkB,OAAO,CAAA,CAAE;QAClBlB,QAAQ,GAAG,IAAI;MACjB;IACF,CAAC;EACH,CAAC,EAAE,CAACF,OAAO,CAAC,CAAC;EAEb,IAAIA,OAAO,EAAE;IACX,IAAMqB,KAAK,GAAG5B,IAAI,KAAK,UAAU;IACjC,IAAM6B,UAAU,GAAGD,KAAK,GAAGrD,IAAI,GAAGH,aAAa,GAAGG,IAAI;IACtD,IAAMuD,WAAW,GAAkB;MAAEjD,KAAK,EAAEgD,UAAU;MAAE/C,MAAM,EAAE+C;IAAU,CAAE;IAE5E,OACEnE,KAAA,CAAA,KAAA,EAAAZ,MAAA,CAAAiF,MAAA,CAAA,CAAA,CAAA,EAAS3B,IAAI,EAAA;MAAE5B,SAAS,EAAE6B,OAAO,CAAC,KAAK,CAAC,EAAEpC,OAAO,CAACoC,OAAO,CAAC,OAAO,CAAC,EAAEuB,KAAK,IAAIvB,OAAO,CAAC,UAAU,CAAC,EAAE7B,SAAS,CAAC,CAAC;MAAAQ,QAAA,EAAA,CAC1G4C,KAAK,GACJlE,KAAA,CAAA,KAAA,EAAA;QAAKc,SAAS,EAAE6B,OAAO,CAAC,WAAW,CAAC;QAAET,KAAK,EAAE;UAAEf,KAAK,EAAEN,IAAI;UAAEO,MAAM,EAAEP;QAAI,CAAE;QAAAS,QAAA,EAAA,CACxExB,IAAA,CAACa,aAAa,EAAA;UAACE,IAAI,EAAEA,IAAI;UAAEC,SAAS,EAAE6B,OAAO,CAAC,IAAI;QAAC,CAAA,CAAI,EACvD7C,IAAA,CAAA,KAAA,EAAA;UAAKwE,GAAG,EAAE1B,SAAS;UAAE9B,SAAS,EAAE6B,OAAO,CAAC,QAAQ,CAAC;UAAET,KAAK,EAAEkC;QAAW,CAAA,CAAI;MAAA,CAAA,CACrE,GAENtE,IAAA,CAAA,KAAA,EAAA;QAAKwE,GAAG,EAAE1B,SAAS;QAAE9B,SAAS,EAAE6B,OAAO,CAAC,QAAQ,CAAC;QAAET,KAAK,EAAEkC;MAAW,CAAA,CACtE,EACA,CAAC5B,KAAK,IAAIC,IAAI,KACbzC,KAAA,CAAA,KAAA,EAAA;QAAKc,SAAS,EAAE6B,OAAO,CAAC,SAAS,CAAC;QAAArB,QAAA,EAAA,CAC/BkB,KAAK,KACJ0B,KAAK,GACDpE,IAAA,CAACO,UAAU,CAACkE,QAAQ,EAAA;UAAC1D,IAAI,EAAC,IAAI;UAAC2D,KAAK,EAAC,SAAS;UAAC1D,SAAS,EAAE6B,OAAO,CAAC,OAAO,CAAC;UAAArB,QAAA,EAAGkB;QAAK,CAAA,CAAuB,GACzG1C,IAAA,CAACO,UAAU,CAACoE,IAAI,EAAA;UAAC5D,IAAI,EAAC,IAAI;UAAC2D,KAAK,EAAC,kBAAkB;UAAC1D,SAAS,EAAE6B,OAAO,CAAC,OAAO,CAAC;UAAArB,QAAA,EAAGkB;QAAK,CAAA,CAAmB,CAC/G,EACAC,IAAI,IACH3C,IAAA,CAACO,UAAU,CAACoE,IAAI,EAAA;UAAC5D,IAAI,EAAC,IAAI;UAAC2D,KAAK,EAAC,kBAAkB;UAAC1D,SAAS,EAAE6B,OAAO,CAAC,MAAM,CAAC;UAAArB,QAAA,EAC3EmB;QAAI,CAAA,CAER;MAAA,CAAA,CAEJ;IAAA,CAAA,CAAA,CACG;EAEV;EAEA,OACE3C,IAAA,CAAA,KAAA,EAAAV,MAAA,CAAAiF,MAAA,CAAA,CAAA,CAAA,EACM3B,IAAI,EAAA;IACRgC,IAAI,EAAC,aAAa;IAClB5D,SAAS,EAAE6B,OAAO,CAAC,KAAK,CAAC,EAAE7B,SAAS,CAAC;IACrCoB,KAAK,EAAA9C,MAAA,CAAAiF,MAAA,CAAA;MAAIlD,KAAK,EAAEN,IAAI;MAAEO,MAAM,EAAEP;IAAI,CAAA,EAAKqB,KAAK,CAAA;IAAAZ,QAAA,EAE5CxB,IAAA,CAAA,KAAA,EAAA;MAAKgB,SAAS,EAAE6B,OAAO,CAAC,QAAQ,CAAC;MAAEtB,OAAO,EAAC,WAAW;MAAAC,QAAA,EACpDxB,IAAA,CAAA,QAAA,EAAA;QACEgB,SAAS,EAAE6B,OAAO,CAAC,MAAM,CAAC;QAC1BpB,EAAE,EAAC,IAAI;QACPC,EAAE,EAAC,IAAI;QACPC,CAAC,EAAC,IAAI;QACNC,IAAI,EAAC,MAAM;QACXiD,WAAW,EAAC;MAAG,CAAA;IACf,CAAA;EACE,CAAA,CAAA,CACF;AAEV,CAAC;AAED,4BAAe1E,IAAI,CAAC+B,OAAO,CAAC","file":"components/Spinner/Spinner.js","sourcesContent":[null,"'use client';\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nvar __rest = (this && this.__rest) || function (s, e) {\n    var t = {};\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n        t[p] = s[p];\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n                t[p[i]] = s[p[i]];\n        }\n    return t;\n};\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport { memo, useEffect, useId, useRef } from 'react';\nimport { Typography } from '../Typography';\nimport classnames, { joinCls } from '../../utils/classnames';\nimport lottiePureJson from './lottie-pure.json';\nimport './style';\nconst DEFAULT_SIZE = 32;\nconst BG_LOGO_RATIO = 2 / 3;\nconst BrandBgCircle = ({ size, className }) => {\n    const rawId = useId();\n    const gradId = `spinner-bg-${rawId.replace(/[^a-zA-Z0-9]/g, '')}`;\n    return (_jsxs(\"svg\", { width: size, height: size, viewBox: \"0 0 56 57\", className: className, \"aria-hidden\": \"true\", children: [_jsx(\"circle\", { cx: \"28\", cy: \"28.75\", r: \"28\", fill: `url(#${gradId})` }), _jsx(\"defs\", { children: _jsxs(\"radialGradient\", { id: gradId, cx: \"0\", cy: \"0\", r: \"1\", gradientUnits: \"userSpaceOnUse\", gradientTransform: \"translate(-34.9085 92.6678) rotate(-45.6594) scale(108.853 103.698)\", children: [_jsx(\"stop\", { stopColor: \"#073387\" }), _jsx(\"stop\", { offset: \"0.216852\", stopColor: \"#90A8CF\" }), _jsx(\"stop\", { offset: \"0.567103\", stopColor: \"#CBD6E8\" }), _jsx(\"stop\", { offset: \"1\", stopColor: \"#F9F9F9\" })] }) })] }));\n};\nexport const Spinner = props => {\n    const { className, style, prefixCls = 'spinner', type = 'default', size = DEFAULT_SIZE, title, body } = props, rest = __rest(props, [\"className\", \"style\", \"prefixCls\", \"type\", \"size\", \"title\", \"body\"]);\n    const classes = classnames(prefixCls);\n    const lottieRef = useRef(null);\n    const isBrand = type === 'brand' || type === 'brand-bg';\n    useEffect(() => {\n        if (!isBrand || !lottieRef.current)\n            return;\n        let instance = null;\n        let destroyed = false;\n        (() => __awaiter(void 0, void 0, void 0, function* () {\n            const lottie = (yield import('lottie-web')).default;\n            if (destroyed || !lottieRef.current)\n                return;\n            instance = lottie.loadAnimation({\n                container: lottieRef.current,\n                renderer: 'svg',\n                loop: true,\n                autoplay: true,\n                animationData: lottiePureJson,\n            });\n        }))();\n        return () => {\n            destroyed = true;\n            if (instance) {\n                instance.destroy();\n                instance = null;\n            }\n        };\n    }, [isBrand]);\n    if (isBrand) {\n        const hasBg = type === 'brand-bg';\n        const lottieSize = hasBg ? size * BG_LOGO_RATIO : size;\n        const lottieStyle = { width: lottieSize, height: lottieSize };\n        return (_jsxs(\"div\", Object.assign({}, rest, { className: classes(void 0, joinCls(classes('brand'), hasBg && classes('brand-bg'), className)), children: [hasBg ? (_jsxs(\"div\", { className: classes('icon-wrap'), style: { width: size, height: size }, children: [_jsx(BrandBgCircle, { size: size, className: classes('bg') }), _jsx(\"div\", { ref: lottieRef, className: classes('lottie'), style: lottieStyle })] })) : (_jsx(\"div\", { ref: lottieRef, className: classes('lottie'), style: lottieStyle })), (title || body) && (_jsxs(\"div\", { className: classes('content'), children: [title && (hasBg\n                            ? _jsx(Typography.Headline, { size: \"sm\", color: \"default\", className: classes('title'), children: title })\n                            : _jsx(Typography.Body, { size: \"md\", color: \"default-tertiary\", className: classes('title'), children: title })), body && (_jsx(Typography.Body, { size: \"md\", color: \"default-tertiary\", className: classes('body'), children: body }))] }))] })));\n    }\n    return (_jsx(\"div\", Object.assign({}, rest, { role: \"progressbar\", className: classes(void 0, className), style: Object.assign({ width: size, height: size }, style), children: _jsx(\"svg\", { className: classes('circle'), viewBox: \"0 0 50 50\", children: _jsx(\"circle\", { className: classes('path'), cx: \"25\", cy: \"25\", r: \"20\", fill: \"none\", strokeWidth: \"4\" }) }) })));\n};\nexport default memo(Spinner);"],"sourceRoot":"../../../../../../../../../src"}
@@ -1 +1 @@
1
- @keyframes om-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes om-dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.om-component-ui-spinner{display:inline-flex;align-items:center;justify-content:center;color:var(--om-icon-brand,#073387)}.om-component-ui-spinner-circle{width:100%;height:100%;animation:om-spin 2s linear infinite}.om-component-ui-spinner-path{animation:om-dash 1.5s ease-in-out infinite;stroke:currentcolor;stroke-linecap:round}.om-component-ui-spinner-spin{animation:om-spin 1s linear infinite}.om-component-ui-spinner-brand{display:flex;flex-direction:column;gap:var(--om-spacing-200,8px);align-items:center}.om-component-ui-spinner-brand.om-component-ui-spinner-brand-bg{gap:var(--om-spacing-600,24px);border-radius:var(--om-radius-600,24px)}.om-component-ui-spinner-logo{color:var(--om-icon-brand,#073387)}.om-component-ui-spinner-content{display:flex;flex-direction:column;gap:var(--om-spacing-100,4px);align-items:center;white-space:nowrap}.om-component-ui-spinner-body,.om-component-ui-spinner-title{text-align:center}
1
+ @keyframes om-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes om-dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.om-component-ui-spinner{display:inline-flex;align-items:center;justify-content:center;color:var(--om-icon-brand,#073387)}.om-component-ui-spinner-circle{width:100%;height:100%;animation:om-spin 2s linear infinite}.om-component-ui-spinner-path{animation:om-dash 1.5s ease-in-out infinite;stroke:currentcolor;stroke-linecap:round}.om-component-ui-spinner-brand{display:flex;flex-direction:column;gap:var(--om-spacing-200,8px);align-items:center}.om-component-ui-spinner-brand.om-component-ui-spinner-brand-bg{gap:var(--om-spacing-600,24px);border-radius:var(--om-radius-600,24px)}.om-component-ui-spinner-lottie{display:block;flex-shrink:0}.om-component-ui-spinner-icon-wrap{position:relative;flex-shrink:0}.om-component-ui-spinner-icon-wrap .om-component-ui-spinner-bg{display:block;width:100%;height:100%}.om-component-ui-spinner-icon-wrap .om-component-ui-spinner-lottie{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.om-component-ui-spinner-content{display:flex;flex-direction:column;gap:var(--om-spacing-100,4px);align-items:center;white-space:nowrap}.om-component-ui-spinner-body,.om-component-ui-spinner-title{text-align:center}