@rnaga/wp-next-ui 1.0.1

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.
Files changed (190) hide show
  1. package/Accordion.d.ts +4 -0
  2. package/Accordion.d.ts.map +1 -0
  3. package/Accordion.js +13 -0
  4. package/Accordions.d.ts +19 -0
  5. package/Accordions.d.ts.map +1 -0
  6. package/Accordions.js +39 -0
  7. package/Background.d.ts +5 -0
  8. package/Background.d.ts.map +1 -0
  9. package/Background.js +18 -0
  10. package/BadgeOnMouseOver.d.ts +12 -0
  11. package/BadgeOnMouseOver.d.ts.map +1 -0
  12. package/BadgeOnMouseOver.js +40 -0
  13. package/BasicMenuButton.d.ts +17 -0
  14. package/BasicMenuButton.d.ts.map +1 -0
  15. package/BasicMenuButton.js +61 -0
  16. package/Button.d.ts +10 -0
  17. package/Button.d.ts.map +1 -0
  18. package/Button.js +15 -0
  19. package/Card.d.ts +6 -0
  20. package/Card.d.ts.map +1 -0
  21. package/Card.js +13 -0
  22. package/CardImage.d.ts +10 -0
  23. package/CardImage.d.ts.map +1 -0
  24. package/CardImage.js +34 -0
  25. package/Checkbox.d.ts +6 -0
  26. package/Checkbox.d.ts.map +1 -0
  27. package/Checkbox.js +13 -0
  28. package/Chip.d.ts +10 -0
  29. package/Chip.d.ts.map +1 -0
  30. package/Chip.js +41 -0
  31. package/DateTimePicker.d.ts +6 -0
  32. package/DateTimePicker.d.ts.map +1 -0
  33. package/DateTimePicker.js +45 -0
  34. package/DraggableBox.d.ts +39 -0
  35. package/DraggableBox.d.ts.map +1 -0
  36. package/DraggableBox.js +171 -0
  37. package/Form.d.ts +4 -0
  38. package/Form.d.ts.map +1 -0
  39. package/Form.js +8 -0
  40. package/FormDataProvider.d.ts +5 -0
  41. package/FormDataProvider.d.ts.map +1 -0
  42. package/FormDataProvider.js +6 -0
  43. package/IconButtonDelete.d.ts +6 -0
  44. package/IconButtonDelete.d.ts.map +1 -0
  45. package/IconButtonDelete.js +14 -0
  46. package/Input.d.ts +14 -0
  47. package/Input.d.ts.map +1 -0
  48. package/Input.js +84 -0
  49. package/InputClickField.d.ts +13 -0
  50. package/InputClickField.d.ts.map +1 -0
  51. package/InputClickField.js +21 -0
  52. package/InputColor.d.ts +12 -0
  53. package/InputColor.d.ts.map +1 -0
  54. package/InputColor.js +141 -0
  55. package/InputMultiple.d.ts +15 -0
  56. package/InputMultiple.d.ts.map +1 -0
  57. package/InputMultiple.js +55 -0
  58. package/InputSearch.d.ts +7 -0
  59. package/InputSearch.d.ts.map +1 -0
  60. package/InputSearch.js +28 -0
  61. package/Link.d.ts +6 -0
  62. package/Link.d.ts.map +1 -0
  63. package/Link.js +15 -0
  64. package/LinkCopy.d.ts +6 -0
  65. package/LinkCopy.d.ts.map +1 -0
  66. package/LinkCopy.js +17 -0
  67. package/Loading.d.ts +7 -0
  68. package/Loading.d.ts.map +1 -0
  69. package/Loading.js +29 -0
  70. package/LoadingBox.d.ts +12 -0
  71. package/LoadingBox.d.ts.map +1 -0
  72. package/LoadingBox.js +30 -0
  73. package/MediaTag.d.ts +9 -0
  74. package/MediaTag.d.ts.map +1 -0
  75. package/MediaTag.js +19 -0
  76. package/Modal.d.ts +11 -0
  77. package/Modal.d.ts.map +1 -0
  78. package/Modal.js +65 -0
  79. package/ModalConfirm.d.ts +8 -0
  80. package/ModalConfirm.d.ts.map +1 -0
  81. package/ModalConfirm.js +58 -0
  82. package/PopperMenu.d.ts +7 -0
  83. package/PopperMenu.d.ts.map +1 -0
  84. package/PopperMenu.js +6 -0
  85. package/README.md +292 -0
  86. package/Select.d.ts +21 -0
  87. package/Select.d.ts.map +1 -0
  88. package/Select.js +23 -0
  89. package/SelectAutocomplete.d.ts +1208 -0
  90. package/SelectAutocomplete.d.ts.map +1 -0
  91. package/SelectAutocomplete.js +113 -0
  92. package/SelectMultiple.d.ts +16 -0
  93. package/SelectMultiple.d.ts.map +1 -0
  94. package/SelectMultiple.js +28 -0
  95. package/SelectWPPost.d.ts +17 -0
  96. package/SelectWPPost.d.ts.map +1 -0
  97. package/SelectWPPost.js +98 -0
  98. package/SelectWPTaxonomy.d.ts +9 -0
  99. package/SelectWPTaxonomy.d.ts.map +1 -0
  100. package/SelectWPTaxonomy.js +35 -0
  101. package/SelectWPTerm.d.ts +13 -0
  102. package/SelectWPTerm.d.ts.map +1 -0
  103. package/SelectWPTerm.js +92 -0
  104. package/SelectWPTerms.d.ts +27 -0
  105. package/SelectWPTerms.d.ts.map +1 -0
  106. package/SelectWPTerms.js +105 -0
  107. package/SelectWPUser.d.ts +16 -0
  108. package/SelectWPUser.d.ts.map +1 -0
  109. package/SelectWPUser.js +101 -0
  110. package/SortableList.d.ts +28 -0
  111. package/SortableList.d.ts.map +1 -0
  112. package/SortableList.js +195 -0
  113. package/Tabs.d.ts +17 -0
  114. package/Tabs.d.ts.map +1 -0
  115. package/Tabs.js +35 -0
  116. package/ThemeRegistry.d.ts +13 -0
  117. package/ThemeRegistry.d.ts.map +1 -0
  118. package/ThemeRegistry.js +36 -0
  119. package/Typography.d.ts +9 -0
  120. package/Typography.d.ts.map +1 -0
  121. package/Typography.js +12 -0
  122. package/Viewport.d.ts +6 -0
  123. package/Viewport.d.ts.map +1 -0
  124. package/Viewport.js +10 -0
  125. package/hooks/use-form-data.d.ts +39 -0
  126. package/hooks/use-form-data.d.ts.map +1 -0
  127. package/hooks/use-form-data.js +91 -0
  128. package/hooks/use-media-selector.d.ts +10 -0
  129. package/hooks/use-media-selector.d.ts.map +1 -0
  130. package/hooks/use-media-selector.js +33 -0
  131. package/hooks/use-mouse-move.d.ts +18 -0
  132. package/hooks/use-mouse-move.d.ts.map +1 -0
  133. package/hooks/use-mouse-move.js +112 -0
  134. package/hooks/use-scheme-toggle.d.ts +6 -0
  135. package/hooks/use-scheme-toggle.d.ts.map +1 -0
  136. package/hooks/use-scheme-toggle.js +16 -0
  137. package/hooks/use-viewport.d.ts +5 -0
  138. package/hooks/use-viewport.d.ts.map +1 -0
  139. package/hooks/use-viewport.js +9 -0
  140. package/list/ListGrid.d.ts +12 -0
  141. package/list/ListGrid.d.ts.map +1 -0
  142. package/list/ListGrid.js +15 -0
  143. package/list/ListTable.d.ts +43 -0
  144. package/list/ListTable.d.ts.map +1 -0
  145. package/list/ListTable.js +143 -0
  146. package/list/Pagination.d.ts +5 -0
  147. package/list/Pagination.d.ts.map +1 -0
  148. package/list/Pagination.js +24 -0
  149. package/list/index.d.ts +4 -0
  150. package/list/index.d.ts.map +1 -0
  151. package/list/index.js +3 -0
  152. package/media/MediaGridForm.d.ts +5 -0
  153. package/media/MediaGridForm.d.ts.map +1 -0
  154. package/media/MediaGridForm.js +128 -0
  155. package/media/MediaThumbnail.d.ts +4 -0
  156. package/media/MediaThumbnail.d.ts.map +1 -0
  157. package/media/MediaThumbnail.js +17 -0
  158. package/media/MediaUpload.d.ts +7 -0
  159. package/media/MediaUpload.d.ts.map +1 -0
  160. package/media/MediaUpload.js +76 -0
  161. package/media/index.d.ts +4 -0
  162. package/media/index.d.ts.map +1 -0
  163. package/media/index.js +3 -0
  164. package/media-selector/MediaSelectorList.d.ts +2 -0
  165. package/media-selector/MediaSelectorList.d.ts.map +1 -0
  166. package/media-selector/MediaSelectorList.js +43 -0
  167. package/media-selector/MediaSelectorPreview.d.ts +2 -0
  168. package/media-selector/MediaSelectorPreview.d.ts.map +1 -0
  169. package/media-selector/MediaSelectorPreview.js +80 -0
  170. package/media-selector/index.d.ts +2 -0
  171. package/media-selector/index.d.ts.map +1 -0
  172. package/media-selector/index.js +49 -0
  173. package/package.json +33 -0
  174. package/portal/Portal.d.ts +6 -0
  175. package/portal/Portal.d.ts.map +1 -0
  176. package/portal/Portal.js +7 -0
  177. package/portal/index.d.ts +3 -0
  178. package/portal/index.d.ts.map +1 -0
  179. package/portal/index.js +2 -0
  180. package/portal/use-portal.d.ts +4 -0
  181. package/portal/use-portal.d.ts.map +1 -0
  182. package/portal/use-portal.js +11 -0
  183. package/types/global-state.d.ts +27 -0
  184. package/types/hooks/filters.d.ts +20 -0
  185. package/types/hooks/index.d.ts +1 -0
  186. package/types/index.d.ts +3 -0
  187. package/types/wp-theme.d.ts +49 -0
  188. package/wp-theme/index.d.ts +3 -0
  189. package/wp-theme/index.d.ts.map +1 -0
  190. package/wp-theme/index.js +86 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectAutocomplete.d.ts","sourceRoot":"","sources":["../src/SelectAutocomplete.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,113 @@
1
+ import { createElement as _createElement } from "react";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { Autocomplete, ListItem, TextField, } from "@mui/material";
4
+ import { createContext, useContext, useMemo, useState, } from "react";
5
+ import { Typography } from "./Typography";
6
+ const Context = createContext({});
7
+ const sxSelectAutocomplete = (props) => {
8
+ const { size, sx } = props;
9
+ return {
10
+ p: "0.5px !important",
11
+ "& .MuiOutlinedInput-root": {
12
+ py: "0 !important",
13
+ fontSize: size == "medium" ? 14 : 12,
14
+ px: 1,
15
+ ...(sx ?? {}),
16
+ },
17
+ "& .MuiInputBase-input": {
18
+ cursor: "pointer",
19
+ height: size == "medium" ? 24 : 12,
20
+ },
21
+ "& .MuiOutlinedInput-notchedOutline": {
22
+ border: "none",
23
+ },
24
+ "& .MuiOutlinedInput-root .MuiAutocomplete-input": {
25
+ py: size == "medium" ? 0.5 : 0.3,
26
+ },
27
+ "& .MuiAutocomplete-tag": {
28
+ fontSize: size == "medium" ? 11 : 10,
29
+ },
30
+ //height: size == "medium" ? 32 : 24,
31
+ ...sx,
32
+ };
33
+ };
34
+ const SelectAutocompleteTextField = (props) => {
35
+ const { size, sx, params } = props;
36
+ return (_jsx(TextField, { ...params, size: size, sx: {
37
+ fontSize: size == "medium" ? 14 : 12,
38
+ border: (theme) => `1px solid ${theme.palette.grey[400]}`,
39
+ borderRadius: 1,
40
+ "&:focus-within": {
41
+ borderColor: (theme) => theme.palette.primary.main,
42
+ },
43
+ ...sx,
44
+ } }));
45
+ };
46
+ const RenderOption = (_props) => {
47
+ const { props, option, state, onChange, onBlur } = _props;
48
+ const { setItem, size, slotSxProps } = useContext(Context);
49
+ if (state.selected) {
50
+ return null;
51
+ }
52
+ return (_createElement(ListItem, { ...props, key: option.id, onClick: (e) => {
53
+ const item = {
54
+ label: option.label,
55
+ value: option.id,
56
+ };
57
+ onChange && onChange(`${item.value}`, item);
58
+ setItem(item);
59
+ // delegate to the original onClick
60
+ props?.onClick && props.onClick(e);
61
+ }, onBlur: (e) => {
62
+ onBlur &&
63
+ onBlur(`${option.id}`, { label: option.label, value: option.id });
64
+ // delegate to the original onBlur
65
+ props?.onBlur && props.onBlur(e);
66
+ } },
67
+ _jsx(Typography, { size: size, sx: {
68
+ ...slotSxProps?.options,
69
+ }, children: option.label })));
70
+ };
71
+ const Wrapper = (props) => {
72
+ const [item, setItem] = useState();
73
+ const { slotSxProps, size } = props;
74
+ return (_jsx(Context, { value: { item, setItem, size, slotSxProps }, children: props.children }));
75
+ };
76
+ export const SelectAutocomplete = (props) => {
77
+ const { slotProps, items, onChange, onBlur, size, value, disableClearable, sx, ...rest } = props;
78
+ const [item, setItem] = useState();
79
+ const currentValue = useMemo(() => {
80
+ if (!props.value) {
81
+ return undefined;
82
+ }
83
+ const item = items.find((item) => item.value == props.value);
84
+ return !item
85
+ ? undefined
86
+ : {
87
+ label: item.label,
88
+ id: `${item.value}`,
89
+ };
90
+ }, [value, items]);
91
+ return (_jsx(Wrapper, { ...props, children: _jsx(Autocomplete, { size: "small", value: currentValue ?? {
92
+ label: "",
93
+ id: "",
94
+ }, options: items.map((item) => ({
95
+ label: item.label,
96
+ id: `${item.value}`,
97
+ })), onBlur: () => {
98
+ onBlur && item && onBlur(`${item.value}`, item);
99
+ }, renderInput: (params) => (_jsx(SelectAutocompleteTextField, { params: params, size: size, sx: slotProps?.textField })), sx: sxSelectAutocomplete({
100
+ size: size ?? "small",
101
+ sx: slotProps?.input,
102
+ }), renderOption: (props, option, state) => {
103
+ return (_jsx(RenderOption, { props: props, option: option, state: state, onChange: onChange, onBlur: onBlur }, option.id));
104
+ }, disableClearable: (disableClearable === true
105
+ ? true
106
+ : value == null
107
+ ? true
108
+ : false), slotProps: slotProps, ...rest }) }));
109
+ };
110
+ SelectAutocomplete.sx = sxSelectAutocomplete;
111
+ SelectAutocomplete.TextField = SelectAutocompleteTextField;
112
+ SelectAutocomplete.RenderOption = RenderOption;
113
+ SelectAutocomplete.Wrapper = Wrapper;
@@ -0,0 +1,16 @@
1
+ import { type SlotSxProps } from "./SelectAutocomplete";
2
+ import { SyntheticEvent } from "react";
3
+ export type SelectMultipleItem = {
4
+ label: string;
5
+ id: string;
6
+ };
7
+ export declare const SelectMultiple: (props: {
8
+ items: SelectMultipleItem[];
9
+ value?: SelectMultipleItem[] | string[];
10
+ onChange: (values: SelectMultipleItem[], e: SyntheticEvent<Element, Event>) => void;
11
+ freeSolo?: boolean;
12
+ slotSxProps?: SlotSxProps;
13
+ size?: "small" | "medium";
14
+ limitTags?: number;
15
+ }) => import("react/jsx-runtime").JSX.Element;
16
+ //# sourceMappingURL=SelectMultiple.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectMultiple.d.ts","sourceRoot":"","sources":["../src/SelectMultiple.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAsB,KAAK,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC5E,OAAO,EAAE,cAAc,EAAW,MAAM,OAAO,CAAC;AAMhD,MAAM,MAAM,kBAAkB,GAAG;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,EAAE,EAAE,MAAM,CAAC;CACZ,CAAC;AAEF,eAAO,MAAM,cAAc,GAAI,OAAO;IACpC,KAAK,EAAE,kBAAkB,EAAE,CAAC;IAC5B,KAAK,CAAC,EAAE,kBAAkB,EAAE,GAAG,MAAM,EAAE,CAAC;IACxC,QAAQ,EAAE,CACR,MAAM,EAAE,kBAAkB,EAAE,EAC5B,CAAC,EAAE,cAAc,CAAC,OAAO,EAAE,KAAK,CAAC,KAC9B,IAAI,CAAC;IACV,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,IAAI,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,4CA8DA,CAAC"}
@@ -0,0 +1,28 @@
1
+ "use client";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { Autocomplete } from "@mui/material";
4
+ import { SelectAutocomplete } from "./SelectAutocomplete";
5
+ import { useMemo } from "react";
6
+ const sxSelectAutocomplete = SelectAutocomplete.sx;
7
+ const SelectAutocompleteTextField = SelectAutocomplete.TextField;
8
+ const RenderOption = SelectAutocomplete.RenderOption;
9
+ export const SelectMultiple = (props) => {
10
+ const { items, onChange, freeSolo = true, slotSxProps, size, limitTags = 2, } = props;
11
+ const value = useMemo(() => (props.value ?? []).map((item) => typeof item === "string" ? { label: item, id: item } : item), [props.value]);
12
+ return (_jsx(SelectAutocomplete.Wrapper, { size: size, slotSxProps: slotSxProps, children: _jsx(Autocomplete, { size: "small", multiple: true, limitTags: limitTags, options: items.map((item) => ({
13
+ label: item.label,
14
+ id: `${item.id}`,
15
+ })), value: value, onChange: (event, value) => {
16
+ onChange(value, event);
17
+ }, sx: sxSelectAutocomplete({
18
+ size: size ?? "small",
19
+ sx: { ...slotSxProps?.input },
20
+ }), renderInput: (params) => (_jsx(SelectAutocompleteTextField, { params: params, size: size, sx: slotSxProps?.textField })), renderOption: (props, option, state) => {
21
+ const id = typeof option === "string" ? option : option.id;
22
+ const label = typeof option === "string" ? option : option.label;
23
+ return (_jsx(RenderOption, { props: props, option: {
24
+ id,
25
+ label,
26
+ }, state: state }, id));
27
+ } }) }));
28
+ };
@@ -0,0 +1,17 @@
1
+ import type * as wpTypes from "@rnaga/wp-node/types";
2
+ import type * as wpCoreTypes from "@rnaga/wp-next-core/types";
3
+ import { type SlotSxProps } from "./SelectAutocomplete";
4
+ type FreeSolo = true | false;
5
+ type Value<T extends FreeSolo> = T extends true ? Pick<wpCoreTypes.actions.Posts[number], "ID" | "post_title"> : wpCoreTypes.actions.Posts[number];
6
+ export declare const SelectWPPost: <T extends FreeSolo = false>(props: {
7
+ onChange: (post: Value<T>) => any;
8
+ defaultValue?: number;
9
+ postArgs?: wpTypes.crud.CrudParameters<"post", "list">[0];
10
+ postOptions?: wpTypes.crud.CrudParameters<"post", "list">[1];
11
+ size?: "small" | "medium";
12
+ slotSxProps?: SlotSxProps;
13
+ freeSolo?: T;
14
+ }) => import("react/jsx-runtime").JSX.Element;
15
+ export declare const SelectFreeSoloWPPost: (props: Parameters<typeof SelectWPPost<true>>[0]) => import("react/jsx-runtime").JSX.Element;
16
+ export {};
17
+ //# sourceMappingURL=SelectWPPost.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectWPPost.d.ts","sourceRoot":"","sources":["../src/SelectWPPost.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAErD,OAAO,KAAK,KAAK,WAAW,MAAM,2BAA2B,CAAC;AAG9D,OAAO,EAAsB,KAAK,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAM5E,KAAK,QAAQ,GAAG,IAAI,GAAG,KAAK,CAAC;AAE7B,KAAK,KAAK,CAAC,CAAC,SAAS,QAAQ,IAAI,CAAC,SAAS,IAAI,GAC3C,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,IAAI,GAAG,YAAY,CAAC,GAC5D,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;AAEtC,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,QAAQ,GAAG,KAAK,EAAE,OAAO;IAC9D,QAAQ,EAAE,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC;IAClC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1D,WAAW,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7D,IAAI,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC;IAC1B,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,QAAQ,CAAC,EAAE,CAAC,CAAC;CACd,4CAkJA,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAC/B,OAAO,UAAU,CAAC,OAAO,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,4CAIhD,CAAC"}
@@ -0,0 +1,98 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useEffect, useState } from "react";
3
+ import { Autocomplete } from "@mui/material";
4
+ import { useServerActions } from "@rnaga/wp-next-core/client/hooks/use-server-actions";
5
+ import { Typography } from "./Typography";
6
+ import { SelectAutocomplete } from "./SelectAutocomplete";
7
+ const sxSelectAutocomplete = SelectAutocomplete.sx;
8
+ const SelectAutocompleteTextField = SelectAutocomplete.TextField;
9
+ const RenderOption = SelectAutocomplete.RenderOption;
10
+ export const SelectWPPost = (props) => {
11
+ const { onChange, defaultValue, postOptions, postArgs, slotSxProps, size, freeSolo = false, } = props;
12
+ const { actions, parse, safeParse } = useServerActions();
13
+ const [posts, setPosts] = useState();
14
+ const [currentPost, setCurrentPost] = useState();
15
+ const postTypes = postOptions?.postTypes ?? ["post"];
16
+ useEffect(() => {
17
+ (async () => {
18
+ let currentPost;
19
+ if (defaultValue) {
20
+ [currentPost] = ((await actions.post
21
+ .list({ include: [defaultValue], per_page: 1, ...postArgs }, { postTypes, ...postOptions })
22
+ .then(parse)) ?? [])[0];
23
+ setCurrentPost(currentPost);
24
+ }
25
+ const [posts] = await actions.post
26
+ .list({
27
+ exclude: defaultValue ? [defaultValue] : undefined,
28
+ ...postArgs,
29
+ }, { postTypes, ...postOptions })
30
+ .then(parse);
31
+ setPosts(currentPost ? [...posts, currentPost] : posts);
32
+ })();
33
+ }, []);
34
+ const handleSearch = async (value) => {
35
+ const response = await actions.post
36
+ .list({
37
+ search: value,
38
+ ...postArgs,
39
+ }, { postTypes, ...postOptions })
40
+ .then(safeParse);
41
+ if (!response.success) {
42
+ return;
43
+ }
44
+ setPosts(currentPost ? [...response.data, currentPost] : response.data);
45
+ };
46
+ const arePostsEqual = (a, b) => {
47
+ return a.ID === b.ID;
48
+ };
49
+ const getPostKey = (post) => `${Math.random()}-${post.ID}`;
50
+ if (!posts || (defaultValue && !currentPost)) {
51
+ return _jsx(Typography, { children: "Loading.." });
52
+ }
53
+ let value = currentPost;
54
+ if (freeSolo && !currentPost) {
55
+ value = {
56
+ ID: 0,
57
+ post_title: "",
58
+ };
59
+ }
60
+ return (_jsx(SelectAutocomplete.Wrapper, { size: size, slotSxProps: slotSxProps, children: _jsx(Autocomplete, { size: "small", freeSolo: freeSolo, disableClearable: true, value: value, onChange: (e, v) => {
61
+ const post = v;
62
+ console.log("onChange", v);
63
+ setCurrentPost(post);
64
+ onChange(post);
65
+ }, onInputChange: (event, value, reason) => {
66
+ if (freeSolo && typeof value === "string") {
67
+ const newValue = {
68
+ ID: 0,
69
+ post_title: value,
70
+ };
71
+ onChange(newValue);
72
+ setCurrentPost(newValue);
73
+ }
74
+ if (reason === "input") {
75
+ handleSearch(value);
76
+ }
77
+ }, getOptionKey: getPostKey, getOptionLabel: (option) => {
78
+ if (freeSolo && typeof option === "string") {
79
+ return option;
80
+ }
81
+ return typeof option !== "string" ? option.post_title : "";
82
+ },
83
+ // getOptionLabel={(option) => option.post_title}
84
+ isOptionEqualToValue: arePostsEqual, options: [...posts], renderInput: (params) => (_jsx(SelectAutocompleteTextField, { params: params, size: size, sx: slotSxProps?.textField })), sx: sxSelectAutocomplete({
85
+ size: size ?? "small",
86
+ sx: slotSxProps?.input,
87
+ }), renderOption: (props, option, state) => {
88
+ const postId = option.ID;
89
+ return (_jsx(RenderOption, { props: props, option: {
90
+ label: option.post_title,
91
+ id: `${postId}`,
92
+ }, state: state }, postId));
93
+ } }, `post-${defaultValue ?? 0}`) }));
94
+ };
95
+ export const SelectFreeSoloWPPost = (props) => {
96
+ const { freeSolo, ...rest } = props;
97
+ return _jsx(SelectWPPost, { ...rest, freeSolo: true });
98
+ };
@@ -0,0 +1,9 @@
1
+ import * as wpTypes from "@rnaga/wp-node/types";
2
+ import type * as wpCoreTypes from "@rnaga/wp-next-core/types";
3
+ export declare const SelectWPTaxonomy: (props: {
4
+ onClick: (taxonomy: wpCoreTypes.actions.Taxonomies[number]) => any;
5
+ onInit: (taxonomy: wpCoreTypes.actions.Taxonomies[number]) => any;
6
+ defaultValue: wpTypes.TaxonomyName;
7
+ size?: "small" | "medium";
8
+ }) => import("react/jsx-runtime").JSX.Element;
9
+ //# sourceMappingURL=SelectWPTaxonomy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectWPTaxonomy.d.ts","sourceRoot":"","sources":["../src/SelectWPTaxonomy.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAIhD,OAAO,KAAK,KAAK,WAAW,MAAM,2BAA2B,CAAC;AAK9D,eAAO,MAAM,gBAAgB,GAAI,OAAO;IACtC,OAAO,EAAE,CAAC,QAAQ,EAAE,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC;IACnE,MAAM,EAAE,CAAC,QAAQ,EAAE,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC;IAClE,YAAY,EAAE,OAAO,CAAC,YAAY,CAAC;IACnC,IAAI,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC;CAC3B,4CA6CA,CAAC"}
@@ -0,0 +1,35 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useEffect, useState } from "react";
3
+ import { useServerActions } from "@rnaga/wp-next-core/client/hooks/use-server-actions";
4
+ import { Select } from "./Select";
5
+ import { Typography } from "./Typography";
6
+ export const SelectWPTaxonomy = (props) => {
7
+ const { onClick, onInit, defaultValue, size } = props;
8
+ const { actions, parse } = useServerActions();
9
+ const [taxonomies, setTaxonomies] = useState();
10
+ useEffect(() => {
11
+ actions.term.taxonomies().then((response) => {
12
+ const [taxonomies] = parse(response);
13
+ setTaxonomies(taxonomies);
14
+ const defaultTaxonomy = taxonomies.find((taxonomy) => taxonomy.name == defaultValue);
15
+ defaultTaxonomy && onInit(defaultTaxonomy);
16
+ });
17
+ }, []);
18
+ if (!taxonomies) {
19
+ return _jsx(Typography, { children: "Loading..." });
20
+ }
21
+ return (_jsx(Select, { size: size, enum: taxonomies.map((taxonomy) => {
22
+ return {
23
+ label: taxonomy.name,
24
+ value: taxonomy.name,
25
+ };
26
+ }), value: defaultValue, onChange: (value) => {
27
+ console.log("Selected syntax:", value);
28
+ const index = taxonomies.findIndex((taxonomy) => taxonomy.name === value);
29
+ if (index === -1) {
30
+ console.error("Selected taxonomy not found:", value);
31
+ return;
32
+ }
33
+ onClick(taxonomies[index]);
34
+ } }));
35
+ };
@@ -0,0 +1,13 @@
1
+ import type * as wpCoreTypes from "@rnaga/wp-next-core/types";
2
+ import { type SlotSxProps } from "./SelectAutocomplete";
3
+ type FreeSolo = true | false;
4
+ type Value = Pick<wpCoreTypes.actions.Terms[number], "term_id" | "name">;
5
+ export declare const SelectWPTerm: <T extends FreeSolo = false>(props: {
6
+ taxonomy: wpCoreTypes.actions.Taxonomies[number]["name"];
7
+ onChange: (term: Value) => any;
8
+ defaultValue?: number;
9
+ size?: "small" | "medium";
10
+ slotSxProps?: SlotSxProps;
11
+ }) => import("react/jsx-runtime").JSX.Element;
12
+ export {};
13
+ //# sourceMappingURL=SelectWPTerm.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectWPTerm.d.ts","sourceRoot":"","sources":["../src/SelectWPTerm.tsx"],"names":[],"mappings":"AAOA,OAAO,KAAK,KAAK,WAAW,MAAM,2BAA2B,CAAC;AAG9D,OAAO,EAAsB,KAAK,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAM5E,KAAK,QAAQ,GAAG,IAAI,GAAG,KAAK,CAAC;AAE7B,KAAK,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,SAAS,GAAG,MAAM,CAAC,CAAC;AAEzE,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,QAAQ,GAAG,KAAK,EAAE,OAAO;IAC9D,QAAQ,EAAE,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC;IACzD,QAAQ,EAAE,CAAC,IAAI,EAAE,KAAK,KAAK,GAAG,CAAC;IAC/B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,IAAI,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC;IAC1B,WAAW,CAAC,EAAE,WAAW,CAAC;CAC3B,4CA+HA,CAAC"}
@@ -0,0 +1,92 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useEffect, useState } from "react";
3
+ import { Autocomplete } from "@mui/material";
4
+ import { useServerActions } from "@rnaga/wp-next-core/client/hooks/use-server-actions";
5
+ import { Typography } from "./Typography";
6
+ import { SelectAutocomplete } from "./SelectAutocomplete";
7
+ const sxSelectAutocomplete = SelectAutocomplete.sx;
8
+ const SelectAutocompleteTextField = SelectAutocomplete.TextField;
9
+ const RenderOption = SelectAutocomplete.RenderOption;
10
+ export const SelectWPTerm = (props) => {
11
+ const { taxonomy, onChange, defaultValue, slotSxProps, size } = props;
12
+ const { actions, parse, safeParse } = useServerActions();
13
+ const [terms, setTerms] = useState();
14
+ const [currentTerm, setCurrentTerm] = useState();
15
+ useEffect(() => {
16
+ (async () => {
17
+ let currentTerm;
18
+ if (defaultValue) {
19
+ [currentTerm] = ((await actions.term
20
+ .list(taxonomy, { include: [defaultValue], per_page: 1 })
21
+ .then(parse)) ?? [])[0];
22
+ setCurrentTerm(currentTerm);
23
+ }
24
+ const [terms] = await actions.term
25
+ .list(taxonomy, {
26
+ exclude: defaultValue ? [defaultValue] : undefined,
27
+ })
28
+ .then(parse);
29
+ setTerms(currentTerm ? [...terms, currentTerm] : terms);
30
+ })();
31
+ }, []);
32
+ const handleSearch = async (value) => {
33
+ const response = await actions.term
34
+ .list(taxonomy, {
35
+ search: value,
36
+ })
37
+ .then(safeParse);
38
+ if (!response.success) {
39
+ return;
40
+ }
41
+ setTerms(response.data);
42
+ };
43
+ const areTermsEqual = (a, b) => {
44
+ return a.term_id === b.term_id;
45
+ };
46
+ const getTermKey = (term) => `${Math.random()}-${term.term_id}`;
47
+ if (!terms || (defaultValue && !currentTerm)) {
48
+ return _jsx(Typography, { children: "Loading.." });
49
+ }
50
+ let value = currentTerm;
51
+ if (!currentTerm) {
52
+ value = {
53
+ term_id: 0,
54
+ name: "",
55
+ };
56
+ }
57
+ console.log("SelectWPTerm value", value, defaultValue);
58
+ return (_jsx(SelectAutocomplete.Wrapper, { size: size, slotSxProps: slotSxProps, children: _jsx(Autocomplete, { size: "small", disableClearable: true, value: value, onChange: (e, v) => {
59
+ const term = v;
60
+ console.log("onChange", v);
61
+ setCurrentTerm(term);
62
+ onChange(term);
63
+ }, onInputChange: (event, value, reason) => {
64
+ if (typeof value === "string") {
65
+ const newValue = {
66
+ term_id: 0,
67
+ name: value,
68
+ };
69
+ onChange(newValue);
70
+ setCurrentTerm(newValue);
71
+ }
72
+ if (reason === "input") {
73
+ handleSearch(value);
74
+ }
75
+ }, getOptionKey: getTermKey, getOptionLabel: (option) => {
76
+ if (typeof option === "string") {
77
+ return option;
78
+ }
79
+ return typeof option !== "string" ? option.name : "";
80
+ },
81
+ // getOptionLabel={(option) => option.name}
82
+ isOptionEqualToValue: areTermsEqual, options: [...terms], renderInput: (params) => (_jsx(SelectAutocompleteTextField, { params: params, size: size, sx: slotSxProps?.textField })), sx: sxSelectAutocomplete({
83
+ size: size ?? "small",
84
+ sx: slotSxProps?.input,
85
+ }), renderOption: (props, option, state) => {
86
+ const termId = option.term_id;
87
+ return (_jsx(RenderOption, { props: props, option: {
88
+ label: option.name,
89
+ id: `${termId}`,
90
+ }, state: state }, termId));
91
+ } }, `post-${defaultValue ?? 0}`) }));
92
+ };
@@ -0,0 +1,27 @@
1
+ import type * as wpCoreTypes from "@rnaga/wp-next-core/types";
2
+ import { type SlotSxProps } from "./SelectAutocomplete";
3
+ export declare const SelectWPTerms: (props: {
4
+ taxonomy: wpCoreTypes.actions.Taxonomies[number]["name"];
5
+ defaultValues?: number[];
6
+ excludeIds?: number[];
7
+ onChange: (values: Array<number | string>) => void;
8
+ freeSolo?: boolean;
9
+ slotSxProps?: SlotSxProps;
10
+ size?: "small" | "medium";
11
+ multiple?: boolean;
12
+ }) => import("react/jsx-runtime").JSX.Element;
13
+ export declare const SelectWPCategories: (props: {
14
+ onChange: (value: (string | number)[]) => void;
15
+ value: string | number[];
16
+ size?: "small" | "medium";
17
+ slotSxProps?: SlotSxProps;
18
+ freeSolo?: boolean;
19
+ }) => import("react/jsx-runtime").JSX.Element;
20
+ export declare const SelectWPTags: (props: {
21
+ onChange: (value: (string | number)[]) => void;
22
+ value: string | number[];
23
+ size?: "small" | "medium";
24
+ slotSxProps?: SlotSxProps;
25
+ freeSolo?: boolean;
26
+ }) => import("react/jsx-runtime").JSX.Element;
27
+ //# sourceMappingURL=SelectWPTerms.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectWPTerms.d.ts","sourceRoot":"","sources":["../src/SelectWPTerms.tsx"],"names":[],"mappings":"AAQA,OAAO,KAAK,KAAK,WAAW,MAAM,2BAA2B,CAAC;AAE9D,OAAO,EAAsB,KAAK,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAa5E,eAAO,MAAM,aAAa,GAAI,OAAO;IACnC,QAAQ,EAAE,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC;IACzD,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;IACzB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,QAAQ,EAAE,CAAC,MAAM,EAAE,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,KAAK,IAAI,CAAC;IACnD,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,IAAI,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC;IAC1B,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,4CAiJA,CAAC;AAsCF,eAAO,MAAM,kBAAkB,UA9BnB;IACN,QAAQ,EAAE,CAAC,KAAK,EAAE,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,KAAK,IAAI,CAAC;IAC/C,KAAK,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IACzB,IAAI,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC;IAC1B,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,4CAwB4D,CAAC;AAClE,eAAO,MAAM,YAAY,UA/Bb;IACN,QAAQ,EAAE,CAAC,KAAK,EAAE,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,KAAK,IAAI,CAAC;IAC/C,KAAK,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IACzB,IAAI,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC;IAC1B,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,4CAyBsD,CAAC"}
@@ -0,0 +1,105 @@
1
+ "use client";
2
+ import { Fragment as _Fragment, jsx as _jsx } from "react/jsx-runtime";
3
+ import { useEffect, useRef, useState } from "react";
4
+ import { Autocomplete, Chip } from "@mui/material";
5
+ import { useServerActions } from "@rnaga/wp-next-core/client/hooks/use-server-actions";
6
+ import { flat as flatHierarchy } from "@rnaga/wp-node/common/hierarchy";
7
+ import { SelectAutocomplete } from "./SelectAutocomplete";
8
+ const sxSelectAutocomplete = SelectAutocomplete.sx;
9
+ const SelectAutocompleteTextField = SelectAutocomplete.TextField;
10
+ const RenderOption = SelectAutocomplete.RenderOption;
11
+ export const SelectWPTerms = (props) => {
12
+ const { taxonomy, defaultValues = [], onChange, freeSolo = true, slotSxProps, excludeIds, size, } = props;
13
+ const { actions, safeParse, parse } = useServerActions();
14
+ const initialValues = useRef(defaultValues);
15
+ const [terms, setTerms] = useState([]);
16
+ const [defaultTerms, setDefaultTerms] = useState();
17
+ useEffect(() => {
18
+ const defaultTermIds = defaultValues.filter((id) => typeof id === "number");
19
+ let defaultTerms = [];
20
+ (async () => {
21
+ if (defaultTermIds.length > 0) {
22
+ [defaultTerms] = await actions.term
23
+ .list(taxonomy, { include: defaultTermIds })
24
+ .then(parse);
25
+ setDefaultTerms(defaultTerms);
26
+ }
27
+ const [terms] = await actions.term
28
+ .list(taxonomy, {
29
+ exclude: [defaultTermIds, ...(excludeIds || [])].flat(),
30
+ })
31
+ .then(parse);
32
+ const termHierarchy = flatHierarchy("terms", [...terms, ...defaultTerms]);
33
+ setTerms(termHierarchy);
34
+ })();
35
+ }, []);
36
+ const handleSearch = (value) => {
37
+ const termOptions = terms.filter((term) => typeof term !== "string");
38
+ const termStrings = terms.filter((term) => typeof term === "string");
39
+ const termIds = termOptions.map((term) => term.term_id);
40
+ actions.term
41
+ .list(taxonomy, {
42
+ search: value.length > 0 ? value : undefined,
43
+ exclude: [termIds, ...(excludeIds || [])].flat(),
44
+ })
45
+ .then((response) => {
46
+ const result = safeParse(response);
47
+ if (!result.success) {
48
+ return;
49
+ }
50
+ const termHierarchy = flatHierarchy("terms", [
51
+ ...result.data,
52
+ ...termOptions,
53
+ ]);
54
+ setTerms([...termHierarchy, ...termStrings]);
55
+ });
56
+ };
57
+ const getTermLabel = (term) => typeof term === "string"
58
+ ? term
59
+ : `${Array(term.depth).fill("-").join("")} ${term.name}`;
60
+ if (!terms || (initialValues.current.length > 0 && !defaultTerms)) {
61
+ return _jsx(_Fragment, { children: "Loading.." });
62
+ }
63
+ return (_jsx(SelectAutocomplete.Wrapper, { size: size, slotSxProps: slotSxProps, children: _jsx(Autocomplete, { size: "small", multiple: true, limitTags: 2, options: terms, defaultValue: defaultTerms, freeSolo: freeSolo, renderValue: (value, getItemProps) => {
64
+ return value.map((option, index) => {
65
+ const { key, ...props } = getItemProps({ index });
66
+ const label = typeof option === "string" ? option : option.name;
67
+ const chipKey = typeof option === "string" ? option : option.term_id;
68
+ return (_jsx(Chip, { label: label, ...props, sx: slotSxProps?.chip }, `${Math.random()}-${chipKey}`));
69
+ });
70
+ }, getOptionLabel: getTermLabel, isOptionEqualToValue: (term1, term2) => typeof term1 !== "string" &&
71
+ typeof term2 !== "string" &&
72
+ term1?.term_id === term2?.term_id, onInputChange: (event, value, reason) => {
73
+ reason === "input" && handleSearch(value);
74
+ }, onChange: (event, value) => {
75
+ onChange(value.map((v) => (typeof v === "string" ? v : v.term_id)));
76
+ }, sx: sxSelectAutocomplete({
77
+ size: size ?? "small",
78
+ sx: { ...slotSxProps?.input, height: "auto" },
79
+ }), renderInput: (params) => (_jsx(SelectAutocompleteTextField, { params: params, size: size, sx: slotSxProps?.textField })), renderOption: (props, option, state) => {
80
+ const termId = typeof option === "string" ? option : option.term_id;
81
+ return (_jsx(RenderOption, { props: props, option: {
82
+ label: getTermLabel(option),
83
+ id: `${termId}`,
84
+ }, state: state }, termId));
85
+ } }, `multiple-terms-${taxonomy}`) }));
86
+ };
87
+ const SelectMultipleTerms =
88
+ // eslint-disable-next-line react/display-name
89
+ (taxonomy) =>
90
+ // eslint-disable-next-line react/display-name
91
+ (props) => {
92
+ return (_jsx(SelectWPTerms, { size: props.size, taxonomy: taxonomy, defaultValues: !props.value
93
+ ? []
94
+ : Array.isArray(props.value)
95
+ ? props.value
96
+ : // If value is a string, split it by comma and convert to numbers
97
+ props.value
98
+ ?.split(",")
99
+ .map((v) => parseInt(v)), onChange: (values) => {
100
+ props.onChange(values);
101
+ //props.onChange(values.join(","));
102
+ }, freeSolo: props.freeSolo ?? false }));
103
+ };
104
+ export const SelectWPCategories = SelectMultipleTerms("category");
105
+ export const SelectWPTags = SelectMultipleTerms("post_tag");
@@ -0,0 +1,16 @@
1
+ import type * as wpTypes from "@rnaga/wp-node/types";
2
+ import type * as wpCoreTypes from "@rnaga/wp-next-core/types";
3
+ import { type SlotSxProps } from "./SelectAutocomplete";
4
+ type FreeSolo = true | false;
5
+ type Value<T extends FreeSolo> = T extends true ? Pick<wpCoreTypes.actions.Users[number], "ID" | "user_nicename"> : wpCoreTypes.actions.Users[number];
6
+ export declare const SelectWPUser: <T extends FreeSolo = false>(props: {
7
+ onChange: (user: Value<T>) => any;
8
+ defaultValue?: number;
9
+ blogId: number;
10
+ userArgs?: wpTypes.crud.CrudParameters<"user", "list">[0];
11
+ userOptions?: wpTypes.crud.CrudParameters<"user", "list">[1];
12
+ size?: "small" | "medium";
13
+ slotSxProps?: SlotSxProps;
14
+ }) => import("react/jsx-runtime").JSX.Element;
15
+ export {};
16
+ //# sourceMappingURL=SelectWPUser.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SelectWPUser.d.ts","sourceRoot":"","sources":["../src/SelectWPUser.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAErD,OAAO,KAAK,KAAK,WAAW,MAAM,2BAA2B,CAAC;AAG9D,OAAO,EAAsB,KAAK,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAM5E,KAAK,QAAQ,GAAG,IAAI,GAAG,KAAK,CAAC;AAE7B,KAAK,KAAK,CAAC,CAAC,SAAS,QAAQ,IAAI,CAAC,SAAS,IAAI,GAC3C,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,IAAI,GAAG,eAAe,CAAC,GAC/D,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;AActC,eAAO,MAAM,YAAY,GAAI,CAAC,SAAS,QAAQ,GAAG,KAAK,EAAE,OAAO;IAC9D,QAAQ,EAAE,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC;IAClC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1D,WAAW,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7D,IAAI,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC;IAC1B,WAAW,CAAC,EAAE,WAAW,CAAC;CAC3B,4CA2IA,CAAC"}