@searchstax-inc/searchstudio-ux-react 0.2.4 → 0.2.6

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/README.md CHANGED
@@ -207,6 +207,17 @@ example of results widget initialization with minimum options
207
207
  ```
208
208
  <SearchstaxResultWidget
209
209
  afterLinkClick={afterLinkClick}
210
+ resultsPerPage={10}
211
+ renderMethod={'pagination'}
212
+ ></SearchstaxResultWidget>
213
+ ```
214
+
215
+ example of results widget initialization with minimum options for infinite scroll behavior
216
+ ```
217
+ <SearchstaxResultWidget
218
+ afterLinkClick={afterLinkClick}
219
+ resultsPerPage={10}
220
+ renderMethod={'infiniteScroll'}
210
221
  ></SearchstaxResultWidget>
211
222
  ```
212
223
 
@@ -370,6 +381,34 @@ function paginationTemplate(
370
381
  <SearchstaxPaginationWidget paginationTemplate={paginationTemplate}></SearchstaxPaginationWidget>
371
382
  ```
372
383
 
384
+ example of pagination widget for infinite scroll
385
+ ```
386
+ function infiniteScrollTemplate(
387
+ paginationData: IPaginationData | null,
388
+ nextPage: (event: React.MouseEvent<HTMLAnchorElement, MouseEvent>) => void
389
+ ) {
390
+ return (
391
+ <>
392
+ { paginationData &&
393
+ paginationData.isInfiniteScroll &&
394
+ paginationData?.totalResults !== 0 &&
395
+ !paginationData?.isLastPage && (
396
+ <a
397
+ className="searchstax-pagination-load-more"
398
+ onClick={(e) => {
399
+ nextPage(e);
400
+ }}
401
+ >
402
+ Show More &gt;
403
+ </a>
404
+ )}
405
+ </>
406
+ );
407
+ }
408
+
409
+ <SearchstaxPaginationWidget infiniteScrollTemplate={infiniteScrollTemplate}></SearchstaxPaginationWidget>
410
+ ```
411
+
373
412
  ### Facets Widget ###
374
413
 
375
414
  example of facets widget initialization with minimum options
@@ -752,7 +791,7 @@ function searchOverviewTemplate(
752
791
  ) {
753
792
  return (
754
793
  <>
755
- {searchFeedbackData && searchFeedbackData?.searchExecuted && searchFeedbackData?.totalResults && (
794
+ {searchFeedbackData && searchFeedbackData?.searchExecuted && searchFeedbackData?.totalResults > 0 && (
756
795
  <>
757
796
  Showing{" "}
758
797
  <b>
@@ -1,5 +1,6 @@
1
1
  import type { IPaginationData } from "@searchstax-inc/searchstudio-ux-js";
2
2
  declare function SearchstaxPaginationWidget(props: {
3
3
  paginationTemplate?: (paginationData: IPaginationData | null, nextPage: (event: React.MouseEvent<HTMLAnchorElement, MouseEvent>) => void, previousPage: (event: React.MouseEvent<HTMLAnchorElement, MouseEvent>) => void) => React.ReactElement;
4
+ infiniteScrollTemplate?: (paginationData: IPaginationData | null, nextPage: (event: React.MouseEvent<HTMLAnchorElement, MouseEvent>) => void) => React.ReactElement;
4
5
  }): import("react/jsx-runtime").JSX.Element;
5
6
  export default SearchstaxPaginationWidget;
@@ -1,6 +1,8 @@
1
1
  import type { ISearchstaxParsedResult, ISearchstaxSearchMetadata } from "@searchstax-inc/searchstudio-ux-js";
2
2
  declare function SearchstaxResultWidget(props: {
3
3
  afterLinkClick: (results: ISearchstaxParsedResult) => ISearchstaxParsedResult;
4
+ resultsPerPage?: number;
5
+ renderMethod?: "infiniteScroll" | "pagination";
4
6
  noResultTemplate?: (searchTerm: string, metaData: ISearchstaxSearchMetadata | null) => React.ReactElement;
5
7
  resultsTemplate?: (results: ISearchstaxParsedResult[], resultClicked: (result: ISearchstaxParsedResult, event: any) => any) => React.ReactElement;
6
8
  }): import("react/jsx-runtime").JSX.Element;