@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.
- package/Accordion.d.ts +4 -0
- package/Accordion.d.ts.map +1 -0
- package/Accordion.js +13 -0
- package/Accordions.d.ts +19 -0
- package/Accordions.d.ts.map +1 -0
- package/Accordions.js +39 -0
- package/Background.d.ts +5 -0
- package/Background.d.ts.map +1 -0
- package/Background.js +18 -0
- package/BadgeOnMouseOver.d.ts +12 -0
- package/BadgeOnMouseOver.d.ts.map +1 -0
- package/BadgeOnMouseOver.js +40 -0
- package/BasicMenuButton.d.ts +17 -0
- package/BasicMenuButton.d.ts.map +1 -0
- package/BasicMenuButton.js +61 -0
- package/Button.d.ts +10 -0
- package/Button.d.ts.map +1 -0
- package/Button.js +15 -0
- package/Card.d.ts +6 -0
- package/Card.d.ts.map +1 -0
- package/Card.js +13 -0
- package/CardImage.d.ts +10 -0
- package/CardImage.d.ts.map +1 -0
- package/CardImage.js +34 -0
- package/Checkbox.d.ts +6 -0
- package/Checkbox.d.ts.map +1 -0
- package/Checkbox.js +13 -0
- package/Chip.d.ts +10 -0
- package/Chip.d.ts.map +1 -0
- package/Chip.js +41 -0
- package/DateTimePicker.d.ts +6 -0
- package/DateTimePicker.d.ts.map +1 -0
- package/DateTimePicker.js +45 -0
- package/DraggableBox.d.ts +39 -0
- package/DraggableBox.d.ts.map +1 -0
- package/DraggableBox.js +171 -0
- package/Form.d.ts +4 -0
- package/Form.d.ts.map +1 -0
- package/Form.js +8 -0
- package/FormDataProvider.d.ts +5 -0
- package/FormDataProvider.d.ts.map +1 -0
- package/FormDataProvider.js +6 -0
- package/IconButtonDelete.d.ts +6 -0
- package/IconButtonDelete.d.ts.map +1 -0
- package/IconButtonDelete.js +14 -0
- package/Input.d.ts +14 -0
- package/Input.d.ts.map +1 -0
- package/Input.js +84 -0
- package/InputClickField.d.ts +13 -0
- package/InputClickField.d.ts.map +1 -0
- package/InputClickField.js +21 -0
- package/InputColor.d.ts +12 -0
- package/InputColor.d.ts.map +1 -0
- package/InputColor.js +141 -0
- package/InputMultiple.d.ts +15 -0
- package/InputMultiple.d.ts.map +1 -0
- package/InputMultiple.js +55 -0
- package/InputSearch.d.ts +7 -0
- package/InputSearch.d.ts.map +1 -0
- package/InputSearch.js +28 -0
- package/Link.d.ts +6 -0
- package/Link.d.ts.map +1 -0
- package/Link.js +15 -0
- package/LinkCopy.d.ts +6 -0
- package/LinkCopy.d.ts.map +1 -0
- package/LinkCopy.js +17 -0
- package/Loading.d.ts +7 -0
- package/Loading.d.ts.map +1 -0
- package/Loading.js +29 -0
- package/LoadingBox.d.ts +12 -0
- package/LoadingBox.d.ts.map +1 -0
- package/LoadingBox.js +30 -0
- package/MediaTag.d.ts +9 -0
- package/MediaTag.d.ts.map +1 -0
- package/MediaTag.js +19 -0
- package/Modal.d.ts +11 -0
- package/Modal.d.ts.map +1 -0
- package/Modal.js +65 -0
- package/ModalConfirm.d.ts +8 -0
- package/ModalConfirm.d.ts.map +1 -0
- package/ModalConfirm.js +58 -0
- package/PopperMenu.d.ts +7 -0
- package/PopperMenu.d.ts.map +1 -0
- package/PopperMenu.js +6 -0
- package/README.md +292 -0
- package/Select.d.ts +21 -0
- package/Select.d.ts.map +1 -0
- package/Select.js +23 -0
- package/SelectAutocomplete.d.ts +1208 -0
- package/SelectAutocomplete.d.ts.map +1 -0
- package/SelectAutocomplete.js +113 -0
- package/SelectMultiple.d.ts +16 -0
- package/SelectMultiple.d.ts.map +1 -0
- package/SelectMultiple.js +28 -0
- package/SelectWPPost.d.ts +17 -0
- package/SelectWPPost.d.ts.map +1 -0
- package/SelectWPPost.js +98 -0
- package/SelectWPTaxonomy.d.ts +9 -0
- package/SelectWPTaxonomy.d.ts.map +1 -0
- package/SelectWPTaxonomy.js +35 -0
- package/SelectWPTerm.d.ts +13 -0
- package/SelectWPTerm.d.ts.map +1 -0
- package/SelectWPTerm.js +92 -0
- package/SelectWPTerms.d.ts +27 -0
- package/SelectWPTerms.d.ts.map +1 -0
- package/SelectWPTerms.js +105 -0
- package/SelectWPUser.d.ts +16 -0
- package/SelectWPUser.d.ts.map +1 -0
- package/SelectWPUser.js +101 -0
- package/SortableList.d.ts +28 -0
- package/SortableList.d.ts.map +1 -0
- package/SortableList.js +195 -0
- package/Tabs.d.ts +17 -0
- package/Tabs.d.ts.map +1 -0
- package/Tabs.js +35 -0
- package/ThemeRegistry.d.ts +13 -0
- package/ThemeRegistry.d.ts.map +1 -0
- package/ThemeRegistry.js +36 -0
- package/Typography.d.ts +9 -0
- package/Typography.d.ts.map +1 -0
- package/Typography.js +12 -0
- package/Viewport.d.ts +6 -0
- package/Viewport.d.ts.map +1 -0
- package/Viewport.js +10 -0
- package/hooks/use-form-data.d.ts +39 -0
- package/hooks/use-form-data.d.ts.map +1 -0
- package/hooks/use-form-data.js +91 -0
- package/hooks/use-media-selector.d.ts +10 -0
- package/hooks/use-media-selector.d.ts.map +1 -0
- package/hooks/use-media-selector.js +33 -0
- package/hooks/use-mouse-move.d.ts +18 -0
- package/hooks/use-mouse-move.d.ts.map +1 -0
- package/hooks/use-mouse-move.js +112 -0
- package/hooks/use-scheme-toggle.d.ts +6 -0
- package/hooks/use-scheme-toggle.d.ts.map +1 -0
- package/hooks/use-scheme-toggle.js +16 -0
- package/hooks/use-viewport.d.ts +5 -0
- package/hooks/use-viewport.d.ts.map +1 -0
- package/hooks/use-viewport.js +9 -0
- package/list/ListGrid.d.ts +12 -0
- package/list/ListGrid.d.ts.map +1 -0
- package/list/ListGrid.js +15 -0
- package/list/ListTable.d.ts +43 -0
- package/list/ListTable.d.ts.map +1 -0
- package/list/ListTable.js +143 -0
- package/list/Pagination.d.ts +5 -0
- package/list/Pagination.d.ts.map +1 -0
- package/list/Pagination.js +24 -0
- package/list/index.d.ts +4 -0
- package/list/index.d.ts.map +1 -0
- package/list/index.js +3 -0
- package/media/MediaGridForm.d.ts +5 -0
- package/media/MediaGridForm.d.ts.map +1 -0
- package/media/MediaGridForm.js +128 -0
- package/media/MediaThumbnail.d.ts +4 -0
- package/media/MediaThumbnail.d.ts.map +1 -0
- package/media/MediaThumbnail.js +17 -0
- package/media/MediaUpload.d.ts +7 -0
- package/media/MediaUpload.d.ts.map +1 -0
- package/media/MediaUpload.js +76 -0
- package/media/index.d.ts +4 -0
- package/media/index.d.ts.map +1 -0
- package/media/index.js +3 -0
- package/media-selector/MediaSelectorList.d.ts +2 -0
- package/media-selector/MediaSelectorList.d.ts.map +1 -0
- package/media-selector/MediaSelectorList.js +43 -0
- package/media-selector/MediaSelectorPreview.d.ts +2 -0
- package/media-selector/MediaSelectorPreview.d.ts.map +1 -0
- package/media-selector/MediaSelectorPreview.js +80 -0
- package/media-selector/index.d.ts +2 -0
- package/media-selector/index.d.ts.map +1 -0
- package/media-selector/index.js +49 -0
- package/package.json +33 -0
- package/portal/Portal.d.ts +6 -0
- package/portal/Portal.d.ts.map +1 -0
- package/portal/Portal.js +7 -0
- package/portal/index.d.ts +3 -0
- package/portal/index.d.ts.map +1 -0
- package/portal/index.js +2 -0
- package/portal/use-portal.d.ts +4 -0
- package/portal/use-portal.d.ts.map +1 -0
- package/portal/use-portal.js +11 -0
- package/types/global-state.d.ts +27 -0
- package/types/hooks/filters.d.ts +20 -0
- package/types/hooks/index.d.ts +1 -0
- package/types/index.d.ts +3 -0
- package/types/wp-theme.d.ts +49 -0
- package/wp-theme/index.d.ts +3 -0
- package/wp-theme/index.d.ts.map +1 -0
- 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"}
|
package/SelectWPPost.js
ADDED
|
@@ -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"}
|
package/SelectWPTerm.js
ADDED
|
@@ -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"}
|
package/SelectWPTerms.js
ADDED
|
@@ -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"}
|