@tamagui/web 1.74.16 → 1.74.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.
- package/dist/cjs/createComponent.js.map +1 -1
- package/dist/cjs/createComponent.native.js.map +1 -1
- package/dist/cjs/helpers/ThemeManager.js +18 -16
- package/dist/cjs/helpers/ThemeManager.js.map +1 -1
- package/dist/cjs/helpers/ThemeManager.native.js +18 -16
- package/dist/cjs/helpers/ThemeManager.native.js.map +1 -1
- package/dist/cjs/helpers/createShallowSetState.js +7 -2
- package/dist/cjs/helpers/createShallowSetState.js.map +1 -1
- package/dist/cjs/helpers/createShallowSetState.native.js +7 -2
- package/dist/cjs/helpers/createShallowSetState.native.js.map +1 -1
- package/dist/cjs/helpers/themeable.js +1 -1
- package/dist/cjs/helpers/themeable.js.map +1 -1
- package/dist/cjs/helpers/themeable.native.js +1 -1
- package/dist/cjs/helpers/themeable.native.js.map +1 -1
- package/dist/cjs/hooks/useTheme.js +18 -11
- package/dist/cjs/hooks/useTheme.js.map +2 -2
- package/dist/cjs/hooks/useTheme.native.js +21 -12
- package/dist/cjs/hooks/useTheme.native.js.map +2 -2
- package/dist/cjs/views/Theme.js +17 -29
- package/dist/cjs/views/Theme.js.map +1 -1
- package/dist/cjs/views/Theme.native.js +17 -29
- package/dist/cjs/views/Theme.native.js.map +1 -1
- package/dist/esm/createComponent.js.map +1 -1
- package/dist/esm/createComponent.native.js.map +1 -1
- package/dist/esm/helpers/ThemeManager.js +17 -16
- package/dist/esm/helpers/ThemeManager.js.map +1 -1
- package/dist/esm/helpers/ThemeManager.native.js +17 -16
- package/dist/esm/helpers/ThemeManager.native.js.map +1 -1
- package/dist/esm/helpers/createShallowSetState.js +6 -2
- package/dist/esm/helpers/createShallowSetState.js.map +1 -1
- package/dist/esm/helpers/createShallowSetState.native.js +6 -2
- package/dist/esm/helpers/createShallowSetState.native.js.map +1 -1
- package/dist/esm/helpers/themeable.js +1 -1
- package/dist/esm/helpers/themeable.js.map +1 -1
- package/dist/esm/helpers/themeable.native.js +1 -1
- package/dist/esm/helpers/themeable.native.js.map +1 -1
- package/dist/esm/hooks/useTheme.js +26 -10
- package/dist/esm/hooks/useTheme.js.map +2 -2
- package/dist/esm/hooks/useTheme.native.js +29 -11
- package/dist/esm/hooks/useTheme.native.js.map +2 -2
- package/dist/esm/views/Theme.js +14 -24
- package/dist/esm/views/Theme.js.map +1 -1
- package/dist/esm/views/Theme.native.js +14 -24
- package/dist/esm/views/Theme.native.js.map +1 -1
- package/package.json +9 -9
- package/src/createComponent.tsx +1 -2
- package/src/helpers/ThemeManager.tsx +22 -22
- package/src/helpers/createShallowSetState.tsx +7 -5
- package/src/helpers/themeable.tsx +1 -1
- package/src/hooks/useTheme.tsx +47 -10
- package/src/views/Theme.tsx +33 -29
- package/types/createComponent.d.ts.map +1 -1
- package/types/helpers/ThemeManager.d.ts +0 -1
- package/types/helpers/ThemeManager.d.ts.map +1 -1
- package/types/helpers/createShallowSetState.d.ts +1 -0
- package/types/helpers/createShallowSetState.d.ts.map +1 -1
- package/types/hooks/useTheme.d.ts +1 -0
- package/types/hooks/useTheme.d.ts.map +1 -1
- package/types/views/Theme.d.ts +0 -12
- package/types/views/Theme.d.ts.map +1 -1
package/src/views/Theme.tsx
CHANGED
|
@@ -121,26 +121,7 @@ export function useThemedChildren(
|
|
|
121
121
|
return elementsWithContext
|
|
122
122
|
}
|
|
123
123
|
|
|
124
|
-
|
|
125
|
-
if (!themeState.isNewTheme) return
|
|
126
|
-
// in order to provide currentColor, set color by default
|
|
127
|
-
const themeColor =
|
|
128
|
-
themeState.state?.theme && themeState.isNewTheme
|
|
129
|
-
? variableToString(themeState.state.theme.color)
|
|
130
|
-
: ''
|
|
131
|
-
const style = themeColor
|
|
132
|
-
? {
|
|
133
|
-
color: themeColor,
|
|
134
|
-
}
|
|
135
|
-
: undefined
|
|
136
|
-
let className = themeState.state?.className || ''
|
|
137
|
-
if (isRoot) {
|
|
138
|
-
className = className.replace('t_sub_theme', '')
|
|
139
|
-
}
|
|
140
|
-
return { style, className }
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
export function wrapThemeElements({
|
|
124
|
+
function wrapThemeElements({
|
|
144
125
|
children,
|
|
145
126
|
themeState,
|
|
146
127
|
forceClassName,
|
|
@@ -155,13 +136,15 @@ export function wrapThemeElements({
|
|
|
155
136
|
return children
|
|
156
137
|
}
|
|
157
138
|
|
|
158
|
-
const inverse = themeState.
|
|
139
|
+
const inverse = themeState.inversed
|
|
140
|
+
const requiresExtraWrapper = inverse != null || forceClassName
|
|
159
141
|
|
|
160
|
-
if (!themeState.isNewTheme && !
|
|
142
|
+
if (!themeState.isNewTheme && !requiresExtraWrapper) {
|
|
161
143
|
return <span className="_dsp_contents is_Theme">{children}</span>
|
|
162
144
|
}
|
|
163
145
|
|
|
164
|
-
const { className, style } =
|
|
146
|
+
const { className, style } = getThemeClassNameAndStyle(themeState, isRoot)
|
|
147
|
+
|
|
165
148
|
let themedChildren = (
|
|
166
149
|
<span className={`${className} _dsp_contents is_Theme`} style={style}>
|
|
167
150
|
{children}
|
|
@@ -169,14 +152,15 @@ export function wrapThemeElements({
|
|
|
169
152
|
)
|
|
170
153
|
|
|
171
154
|
// to prevent tree structure changes always render this if inverse is true or false
|
|
172
|
-
if (
|
|
155
|
+
if (requiresExtraWrapper) {
|
|
173
156
|
const name = themeState.state?.name || ''
|
|
157
|
+
const inverseClassName = name.startsWith('light')
|
|
158
|
+
? 't_light is_inversed'
|
|
159
|
+
: name.startsWith('dark')
|
|
160
|
+
? 't_dark is_inversed'
|
|
161
|
+
: ''
|
|
174
162
|
themedChildren = (
|
|
175
|
-
<span
|
|
176
|
-
className={`${
|
|
177
|
-
name.startsWith('light') ? 't_light' : name.startsWith('dark') ? 't_dark' : ''
|
|
178
|
-
} _dsp_contents ${inverse ? 'is_inversed' : ''}`}
|
|
179
|
-
>
|
|
163
|
+
<span className={`${inverse ? inverseClassName : ''} _dsp_contents`}>
|
|
180
164
|
{themedChildren}
|
|
181
165
|
</span>
|
|
182
166
|
)
|
|
@@ -184,3 +168,23 @@ export function wrapThemeElements({
|
|
|
184
168
|
|
|
185
169
|
return themedChildren
|
|
186
170
|
}
|
|
171
|
+
|
|
172
|
+
function getThemeClassNameAndStyle(themeState: ChangedThemeResponse, isRoot = false) {
|
|
173
|
+
// in order to provide currentColor, set color by default
|
|
174
|
+
const themeColor =
|
|
175
|
+
themeState.state?.theme && themeState.isNewTheme
|
|
176
|
+
? variableToString(themeState.state.theme.color)
|
|
177
|
+
: ''
|
|
178
|
+
|
|
179
|
+
const style = themeColor
|
|
180
|
+
? {
|
|
181
|
+
color: themeColor,
|
|
182
|
+
}
|
|
183
|
+
: undefined
|
|
184
|
+
|
|
185
|
+
let className = themeState.state?.className || ''
|
|
186
|
+
if (isRoot) {
|
|
187
|
+
className = className.replace('t_sub_theme', '')
|
|
188
|
+
}
|
|
189
|
+
return { style, className }
|
|
190
|
+
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createComponent.d.ts","sourceRoot":"","sources":["../src/createComponent.tsx"],"names":[],"mappings":"AAIA,OAAO,KAaN,MAAM,OAAO,CAAA;AAsBd,OAAO,EAEL,SAAS,EAKT,cAAc,EACd,UAAU,EACV,WAAW,EACX,UAAU,EACV,YAAY,EAEZ,gBAAgB,EAGhB,cAAc,EAEd,SAAS,
|
|
1
|
+
{"version":3,"file":"createComponent.d.ts","sourceRoot":"","sources":["../src/createComponent.tsx"],"names":[],"mappings":"AAIA,OAAO,KAaN,MAAM,OAAO,CAAA;AAsBd,OAAO,EAEL,SAAS,EAKT,cAAc,EACd,UAAU,EACV,WAAW,EACX,UAAU,EACV,YAAY,EAEZ,gBAAgB,EAGhB,cAAc,EAEd,SAAS,EAKV,MAAM,SAAS,CAAA;AAoBhB,eAAO,MAAM,QAAQ,eAAsB,CAAA;AA6D3C,wBAAgB,eAAe,CAC7B,kBAAkB,SAAS,UAAU,GAAG,SAAS,GAAG,EAAE,EACtD,GAAG,GAAG,cAAc,EACpB,SAAS,GAAG,KAAK,EACjB,YAAY,EAAE,YAAY,4DAysC3B;AAsBD,wBAAgB,QAAQ,CAAC,KAAK,EAAE;IAAE,QAAQ,CAAC,EAAE,GAAG,CAAA;CAAE,OAEjD;AAiBD,eAAO,MAAM,MAAM,0DAqCjB,CAAA;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IAC1B,KAAK,CAAC,EAAE,UAAU,CAAA;IAClB,SAAS,CAAC,EAAE,OAAO,GAAG,MAAM,CAAA;IAC5B,SAAS,CAAC,EAAE,cAAc,CAAA;IAC1B,SAAS,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IAC3B,KAAK,CAAC,EAAE,SAAS,CAAA;CAClB,CAAA;AAED,wBAAgB,cAAc,CAAC,KAAK,EAAE,mBAAmB,mBAiGxD"}
|
|
@@ -13,7 +13,6 @@ export type ThemeManagerState = {
|
|
|
13
13
|
theme?: ThemeParsed | null;
|
|
14
14
|
isComponent?: boolean;
|
|
15
15
|
className?: string;
|
|
16
|
-
inverse?: boolean;
|
|
17
16
|
scheme?: ColorScheme;
|
|
18
17
|
};
|
|
19
18
|
export declare function getHasThemeUpdatingProps(props: ThemeProps): string | boolean | undefined;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ThemeManager.d.ts","sourceRoot":"","sources":["../../src/helpers/ThemeManager.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AAE/D,KAAK,aAAa,GAAG,CACnB,IAAI,EAAE,MAAM,GAAG,IAAI,EACnB,YAAY,EAAE,YAAY,EAC1B,MAAM,EAAE,OAAO,KACZ,IAAI,CAAA;AAET,MAAM,MAAM,mBAAmB,GAAG;IAChC,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,aAAa,CAAC,EAAE,YAAY,GAAG,IAAI,CAAA;IACnC,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACpB,KAAK,CAAC,EAAE,GAAG,CAAA;IACX,KAAK,CAAC,EAAE,OAAO,CAAA;CAChB,CAAA;AAED,MAAM,MAAM,iBAAiB,GAAG;IAC9B,IAAI,EAAE,MAAM,CAAA;IACZ,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,KAAK,CAAC,EAAE,WAAW,GAAG,IAAI,CAAA;IAC1B,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,
|
|
1
|
+
{"version":3,"file":"ThemeManager.d.ts","sourceRoot":"","sources":["../../src/helpers/ThemeManager.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AAE/D,KAAK,aAAa,GAAG,CACnB,IAAI,EAAE,MAAM,GAAG,IAAI,EACnB,YAAY,EAAE,YAAY,EAC1B,MAAM,EAAE,OAAO,KACZ,IAAI,CAAA;AAET,MAAM,MAAM,mBAAmB,GAAG;IAChC,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,aAAa,CAAC,EAAE,YAAY,GAAG,IAAI,CAAA;IACnC,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACpB,KAAK,CAAC,EAAE,GAAG,CAAA;IACX,KAAK,CAAC,EAAE,OAAO,CAAA;CAChB,CAAA;AAED,MAAM,MAAM,iBAAiB,GAAG;IAC9B,IAAI,EAAE,MAAM,CAAA;IACZ,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,KAAK,CAAC,EAAE,WAAW,GAAG,IAAI,CAAA;IAC1B,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,CAAC,EAAE,WAAW,CAAA;CACrB,CAAA;AAID,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,UAAU,gCAEzD;AAID,qBAAa,YAAY;IAOd,KAAK,EAAE,UAAU;IAN1B,EAAE,SAAQ;IACV,cAAc,qBAA2B;IACzC,aAAa,EAAE,YAAY,GAAG,IAAI,CAAO;IACzC,KAAK,EAAE,iBAAiB,CAAa;gBAG5B,KAAK,GAAE,UAAe,EAC7B,aAAa,CAAC,EAAE,YAAY,GAAG,MAAM,GAAG,IAAI,GAAG,SAAS;IA0B1D,oBAAoB,CAClB,KAAK,GAAE,UAAU,GAAG;QAAE,UAAU,CAAC,EAAE,WAAW,CAAA;KAAqB,EACnE,YAAY,UAAO;IAgBrB,WAAW,CAAC,SAAS,EAAE,iBAAiB,EAAE,YAAY,UAAO;IAc7D,iBAAiB,CACf,KAAK,aAAa,EAClB,KAAK,GAAE,iBAAiB,GAAG,IAAiB,EAC5C,aAAa,sBAAqB;IAapC,oBAAoB,CAClB,SAAS,EAAE,iBAAiB,GAAG,IAAI,EACnC,KAAK,GAAE,iBAAiB,GAAG,IAAiB;IAQ9C,QAAQ,CAAC,KAAK,aAAa,EAAE,aAAa,sBAAqB;IAO/D,QAAQ,EAAE,GAAG,CAAC,MAAM,CAAC,GAAG,IAAI,CAAO;IACnC,IAAI,OAAO,gBAMV;IAED,MAAM,CAAC,MAAM,UAAQ;IAIrB,aAAa,CAAC,EAAE,EAAE,aAAa,EAAE,OAAO,CAAC,EAAE,MAAM;CAalD;AAiKD,KAAK,iBAAiB,GAAG,YAAY,GAAG,SAAS,CAAA;AAKjD,wBAAgB,WAAW,CAAC,YAAY,CAAC,EAAE,YAAY,GAAG,IAAI,uDAY7D"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
export declare function createShallowSetState<State extends Object>(setter: React.Dispatch<React.SetStateAction<State>>): (next: Partial<State>) => void;
|
|
3
3
|
export declare function mergeIfNotShallowEqual(prev: any, next: any): any;
|
|
4
|
+
export declare function isEqualShallow(prev: any, next: any): boolean;
|
|
4
5
|
//# sourceMappingURL=createShallowSetState.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createShallowSetState.d.ts","sourceRoot":"","sources":["../../src/helpers/createShallowSetState.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"createShallowSetState.d.ts","sourceRoot":"","sources":["../../src/helpers/createShallowSetState.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,wBAAgB,qBAAqB,CAAC,KAAK,SAAS,MAAM,EACxD,MAAM,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,UAErC,QAAQ,KAAK,CAAC,UAC7B;AAED,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,OAE1D;AAED,wBAAgB,cAAc,CAAC,IAAI,KAAA,EAAE,IAAI,KAAA,WAOxC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useTheme.d.ts","sourceRoot":"","sources":["../../src/hooks/useTheme.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"useTheme.d.ts","sourceRoot":"","sources":["../../src/hooks/useTheme.tsx"],"names":[],"mappings":"AAYA,OAAO,EAAE,QAAQ,EAAe,MAAM,mBAAmB,CAAA;AAGzD,OAAO,EACL,YAAY,EACZ,iBAAiB,EAElB,MAAM,yBAAyB,CAAA;AAEhC,OAAO,KAAK,EACV,SAAS,EACT,WAAW,EACX,UAAU,EACV,sBAAsB,EACtB,WAAW,EACX,kBAAkB,EACnB,MAAM,UAAU,CAAA;AAGjB,MAAM,MAAM,oBAAoB,GAAG;IACjC,KAAK,CAAC,EAAE,iBAAiB,CAAA;IACzB,YAAY,CAAC,EAAE,YAAY,GAAG,IAAI,CAAA;IAClC,UAAU,EAAE,OAAO,CAAA;IAGnB,QAAQ,CAAC,EAAE,IAAI,GAAG,OAAO,CAAA;IACzB,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB,CAAA;AAcD,MAAM,MAAM,aAAa,CAAC,GAAG,IAAI,GAAG,GAAG;IACrC;;;;;;;;;OASG;IACH,GAAG,EAAE,CACH,QAAQ,CAAC,EAAE,KAAK,KAEd,MAAM,GACN,CAAC,GAAG,SAAS,QAAQ,CAAC,MAAM,CAAC,CAAC,GAC1B,CAAC,SAAS,kBAAkB,GAC1B,GAAG,GACH,OAAO,CAAC,CAAC,EAAE,QAAQ,CAAC,GACtB,GAAG,SAAS,WAAW,GACvB,MAAM,GAAG,MAAM,GACf,OAAO,CAAC,CAAA;CACjB,CAAA;AAED,MAAM,MAAM,cAAc,GAAG;KAC1B,GAAG,IAAI,MAAM,WAAW,GAAG,aAAa,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;CAC5D,CAAA;AAED,eAAO,MAAM,QAAQ,WAAW,UAAU,mBAIzC,CAAA;AAED,eAAO,MAAM,iBAAiB,UACrB,sBAAsB,KAC5B,CAAC,oBAAoB,EAAE,WAAW,CAuDpC,CAAA;AAED,wBAAgB,eAAe,CAC7B,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,iBAAiB,EAC1C,KAAK,UAAQ,EACb,YAAY,CAAC,EAAE,YAAY,EAC3B,IAAI,CAAC,EAAE,MAAM,EAAE,EACf,KAAK,CAAC,EAAE,SAAS,GAChB,cAAc,CAmGhB;AAeD,eAAO,MAAM,mBAAmB,mBAA0B,CAAA;AAE1D,eAAO,MAAM,oBAAoB,UACxB,sBAAsB,2BAEtB,MAAM,EAAE,iBACA,MAAM,OAAO,GAAG,SAAS,KACvC,oBA8QF,CAAA"}
|
package/types/views/Theme.d.ts
CHANGED
|
@@ -3,16 +3,4 @@ import { ChangedThemeResponse } from '../hooks/useTheme';
|
|
|
3
3
|
import type { ThemeProps } from '../types';
|
|
4
4
|
export declare const Theme: React.ForwardRefExoticComponent<ThemeProps & React.RefAttributes<unknown>>;
|
|
5
5
|
export declare function useThemedChildren(themeState: ChangedThemeResponse, children: any, props: ThemeProps, isRoot?: boolean, avoidWrap?: boolean): any;
|
|
6
|
-
export declare function getThemeCNStyle(themeState: ChangedThemeResponse, isRoot?: boolean): {
|
|
7
|
-
style: {
|
|
8
|
-
color: string;
|
|
9
|
-
} | undefined;
|
|
10
|
-
className: string;
|
|
11
|
-
} | undefined;
|
|
12
|
-
export declare function wrapThemeElements({ children, themeState, forceClassName, isRoot, }: {
|
|
13
|
-
children?: React.ReactNode;
|
|
14
|
-
themeState: ChangedThemeResponse;
|
|
15
|
-
forceClassName?: boolean;
|
|
16
|
-
isRoot?: boolean;
|
|
17
|
-
}): string | number | boolean | React.ReactFragment | JSX.Element | null | undefined;
|
|
18
6
|
//# sourceMappingURL=Theme.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Theme.d.ts","sourceRoot":"","sources":["../../src/views/Theme.tsx"],"names":[],"mappings":"AACA,OAAO,KAQN,MAAM,OAAO,CAAA;AAId,OAAO,EAAE,oBAAoB,EAAwB,MAAM,mBAAmB,CAAA;AAC9E,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AAG1C,eAAO,MAAM,KAAK,4EAwChB,CAAA;AAIF,wBAAgB,iBAAiB,CAC/B,UAAU,EAAE,oBAAoB,EAChC,QAAQ,EAAE,GAAG,EACb,KAAK,EAAE,UAAU,EACjB,MAAM,UAAQ,EACd,SAAS,UAAQ,OAuDlB
|
|
1
|
+
{"version":3,"file":"Theme.d.ts","sourceRoot":"","sources":["../../src/views/Theme.tsx"],"names":[],"mappings":"AACA,OAAO,KAQN,MAAM,OAAO,CAAA;AAId,OAAO,EAAE,oBAAoB,EAAwB,MAAM,mBAAmB,CAAA;AAC9E,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AAG1C,eAAO,MAAM,KAAK,4EAwChB,CAAA;AAIF,wBAAgB,iBAAiB,CAC/B,UAAU,EAAE,oBAAoB,EAChC,QAAQ,EAAE,GAAG,EACb,KAAK,EAAE,UAAU,EACjB,MAAM,UAAQ,EACd,SAAS,UAAQ,OAuDlB"}
|