@secretstache/wordpress-gutenberg 0.4.1 → 0.4.2
Sign up to get free protection for your applications and to get access to all the features.
package/package.json
CHANGED
@@ -1,16 +1,17 @@
|
|
1
1
|
import { Notice, Placeholder, Spinner } from '@wordpress/components';
|
2
2
|
|
3
|
-
const
|
4
|
-
|
5
|
-
|
3
|
+
const DEFAULT_EMPTY_RESOURCES_MESSAGE = 'No resources were found matching your criteria. Please try to adjust the query.';
|
4
|
+
const DEFAULT_EMPTY_SELECTION_MESSAGE = 'No items are selected. Please use the corresponding relationship field to populate this block.';
|
5
|
+
|
6
|
+
export const EmptyNotice = ({ message }) => (
|
6
7
|
<Notice status="info" isDismissible={false}>
|
7
8
|
<p>{message}</p>
|
8
9
|
</Notice>
|
9
10
|
);
|
10
11
|
|
11
|
-
const LoadingSpinner = () => <Spinner className="bc-spinner" />;
|
12
|
+
export const LoadingSpinner = () => <Spinner className="bc-spinner" />;
|
12
13
|
|
13
|
-
const PlaceholderContent = ({
|
14
|
+
export const PlaceholderContent = ({
|
14
15
|
icon = 'info-outline',
|
15
16
|
instructions = 'Please configure the block in the sidebar.',
|
16
17
|
...restProps
|
@@ -24,9 +25,11 @@ const PlaceholderContent = ({
|
|
24
25
|
|
25
26
|
export const ResourcesWrapper = ({
|
26
27
|
isLoading,
|
27
|
-
|
28
|
+
isEmptyResources,
|
29
|
+
isEmptySelection,
|
28
30
|
isPlaceholder,
|
29
|
-
|
31
|
+
emptyResourcesMessage,
|
32
|
+
emptySelectionMessage,
|
30
33
|
placeholderProps = {},
|
31
34
|
children,
|
32
35
|
}) => {
|
@@ -34,8 +37,12 @@ export const ResourcesWrapper = ({
|
|
34
37
|
return <LoadingSpinner />;
|
35
38
|
}
|
36
39
|
|
37
|
-
if (
|
38
|
-
return <EmptyNotice message={
|
40
|
+
if (isEmptySelection) {
|
41
|
+
return <EmptyNotice message={emptySelectionMessage || DEFAULT_EMPTY_SELECTION_MESSAGE} />;
|
42
|
+
}
|
43
|
+
|
44
|
+
if (isEmptyResources) {
|
45
|
+
return <EmptyNotice message={emptyResourcesMessage || DEFAULT_EMPTY_RESOURCES_MESSAGE} />;
|
39
46
|
}
|
40
47
|
|
41
48
|
if (isPlaceholder) {
|
@@ -5,8 +5,8 @@ export const useDataQuery = (config, dependencies = []) => {
|
|
5
5
|
postType,
|
6
6
|
curatedPostsIds,
|
7
7
|
|
8
|
-
|
9
|
-
|
8
|
+
taxonomySlug,
|
9
|
+
curatedTermsIds,
|
10
10
|
|
11
11
|
numberOfPosts = -1,
|
12
12
|
extraQueryArgs,
|
@@ -21,8 +21,8 @@ export const useDataQuery = (config, dependencies = []) => {
|
|
21
21
|
...extraQueryArgs,
|
22
22
|
};
|
23
23
|
|
24
|
-
if (
|
25
|
-
queryArgs[
|
24
|
+
if (taxonomySlug && curatedTermsIds?.length > 0) {
|
25
|
+
queryArgs[taxonomySlug] = curatedTermsIds.join(',');
|
26
26
|
}
|
27
27
|
|
28
28
|
if (curatedPostsIds?.length > 0) {
|
@@ -37,7 +37,7 @@ export const useDataQuery = (config, dependencies = []) => {
|
|
37
37
|
const postsToShow = select('core').getEntityRecords('postType', preparedPostType, queryArgs);
|
38
38
|
const isResolving = select('core/data').isResolving('core', 'getEntityRecords', ['postType', preparedPostType, queryArgs]);
|
39
39
|
|
40
|
-
const isEmpty = postsToShow !== null && postsToShow?.length === 0;
|
40
|
+
const isEmpty = (postsToShow !== null && postsToShow?.length === 0) || numberOfPosts === 0;
|
41
41
|
|
42
42
|
return {
|
43
43
|
postsToShow,
|