@netfoundry/docusaurus-theme 0.2.1 → 0.2.3
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/src/components/Alert/Alert.js +51 -6
- package/dist/src/components/Alert/Alert.js.map +7 -1
- package/dist/src/components/Alert/index.js +29 -2
- package/dist/src/components/Alert/index.js.map +7 -1
- package/dist/src/components/CodeBlock/CodeBlock.js +53 -7
- package/dist/src/components/CodeBlock/CodeBlock.js.map +7 -1
- package/dist/src/components/CodeBlock/index.js +29 -2
- package/dist/src/components/CodeBlock/index.js.map +7 -1
- package/dist/src/components/Common/Common.js +59 -16
- package/dist/src/components/Common/Common.js.map +7 -1
- package/dist/src/components/Common/Logos.js +92 -6
- package/dist/src/components/Common/Logos.js.map +7 -1
- package/dist/src/components/Common/index.js +25 -3
- package/dist/src/components/Common/index.js.map +7 -1
- package/dist/src/components/NetFoundry/Divider/Divider.js +46 -5
- package/dist/src/components/NetFoundry/Divider/Divider.js.map +7 -1
- package/dist/src/components/NetFoundry/Divider/index.js +23 -2
- package/dist/src/components/NetFoundry/Divider/index.js.map +7 -1
- package/dist/src/components/NetFoundry/index.js +23 -2
- package/dist/src/components/NetFoundry/index.js.map +7 -1
- package/dist/src/components/NetFoundryFooter/NetFoundryFooter.d.ts +2 -21
- package/dist/src/components/NetFoundryFooter/NetFoundryFooter.d.ts.map +1 -1
- package/dist/src/components/NetFoundryFooter/NetFoundryFooter.js +115 -58
- package/dist/src/components/NetFoundryFooter/NetFoundryFooter.js.map +7 -1
- package/dist/src/components/NetFoundryFooter/defaults.js +50 -23
- package/dist/src/components/NetFoundryFooter/defaults.js.map +7 -1
- package/dist/src/components/NetFoundryFooter/index.js +23 -2
- package/dist/src/components/NetFoundryFooter/index.js.map +7 -1
- package/dist/src/components/NetFoundryFooter/types.d.ts +27 -0
- package/dist/src/components/NetFoundryFooter/types.d.ts.map +1 -0
- package/dist/src/components/NetFoundryFooter/types.js +53 -0
- package/dist/src/components/NetFoundryFooter/types.js.map +7 -0
- package/dist/src/components/NetFoundryHighlight/NetFoundryHighlight.js +32 -5
- package/dist/src/components/NetFoundryHighlight/NetFoundryHighlight.js.map +7 -1
- package/dist/src/components/NetFoundryHighlight/index.js +29 -2
- package/dist/src/components/NetFoundryHighlight/index.js.map +7 -1
- package/dist/src/components/NetFoundryHorizontalSection/NetFoundryHorizontalSection.js +52 -7
- package/dist/src/components/NetFoundryHorizontalSection/NetFoundryHorizontalSection.js.map +7 -1
- package/dist/src/components/NetFoundryHorizontalSection/index.js +29 -2
- package/dist/src/components/NetFoundryHorizontalSection/index.js.map +7 -1
- package/dist/src/components/NetFoundryLayout/NetFoundryLayout.js +111 -34
- package/dist/src/components/NetFoundryLayout/NetFoundryLayout.js.map +7 -1
- package/dist/src/components/NetFoundryLayout/index.js +23 -2
- package/dist/src/components/NetFoundryLayout/index.js.map +7 -1
- package/dist/src/components/NetFoundryNavbarItems/NetFoundryNavbarItems.js +40 -13
- package/dist/src/components/NetFoundryNavbarItems/NetFoundryNavbarItems.js.map +7 -1
- package/dist/src/components/NetFoundryNavbarItems/index.js +29 -2
- package/dist/src/components/NetFoundryNavbarItems/index.js.map +7 -1
- package/dist/src/components/OsTabs/OsTabs.js +53 -17
- package/dist/src/components/OsTabs/OsTabs.js.map +7 -1
- package/dist/src/components/OsTabs/index.js +29 -2
- package/dist/src/components/OsTabs/index.js.map +7 -1
- package/dist/src/components/ProductSearch/ProductSearch.js +243 -122
- package/dist/src/components/ProductSearch/ProductSearch.js.map +7 -1
- package/dist/src/components/ProductSearch/index.js +42 -4
- package/dist/src/components/ProductSearch/index.js.map +7 -1
- package/dist/src/components/StarUs/StarUs.js +45 -6
- package/dist/src/components/StarUs/StarUs.js.map +7 -1
- package/dist/src/components/StarUs/index.js +39 -2
- package/dist/src/components/StarUs/index.js.map +7 -1
- package/dist/src/components/index.js +45 -13
- package/dist/src/components/index.js.map +7 -1
- package/dist/src/config.d.ts +9 -0
- package/dist/src/config.d.ts.map +1 -0
- package/dist/src/config.js +34 -0
- package/dist/src/config.js.map +7 -0
- package/dist/src/css-modules.d.js +2 -0
- package/dist/src/css-modules.d.js.map +7 -0
- package/dist/src/docusaurus-envhelper.js +111 -64
- package/dist/src/docusaurus-envhelper.js.map +7 -1
- package/dist/src/docusaurus-plugins/index.js +35 -8
- package/dist/src/docusaurus-plugins/index.js.map +7 -1
- package/dist/src/docusaurus-plugins/logger.js +66 -38
- package/dist/src/docusaurus-plugins/logger.js.map +7 -1
- package/dist/src/docusaurus-plugins/remarkCodeSections.js +127 -94
- package/dist/src/docusaurus-plugins/remarkCodeSections.js.map +7 -1
- package/dist/src/docusaurus-plugins/remarkReplaceMetaUrl.js +50 -22
- package/dist/src/docusaurus-plugins/remarkReplaceMetaUrl.js.map +7 -1
- package/dist/src/docusaurus-plugins/remarkScopedPath.js +78 -46
- package/dist/src/docusaurus-plugins/remarkScopedPath.js.map +7 -1
- package/dist/src/docusaurus-plugins/remarkYamlTable.js +84 -49
- package/dist/src/docusaurus-plugins/remarkYamlTable.js.map +7 -1
- package/dist/src/docusaurus-plugins/remarkYouTube.js +65 -42
- package/dist/src/docusaurus-plugins/remarkYouTube.js.map +7 -1
- package/dist/src/docusaurus-plugins/timedPlugin.js +42 -15
- package/dist/src/docusaurus-plugins/timedPlugin.js.map +7 -1
- package/dist/src/docusaurus.d.js +2 -0
- package/dist/src/docusaurus.d.js.map +7 -0
- package/dist/src/index.js +63 -36
- package/dist/src/index.js.map +7 -1
- package/dist/src/node.js +23 -7
- package/dist/src/node.js.map +7 -1
- package/dist/src/options.js +17 -2
- package/dist/src/options.js.map +7 -1
- package/dist/src/plugins.js +23 -7
- package/dist/src/plugins.js.map +7 -1
- package/dist/src/ui.js +25 -8
- package/dist/src/ui.js.map +7 -1
- package/dist/src/version.js +29 -2
- package/dist/src/version.js.map +7 -1
- package/dist/theme/BlogPostPage/Metadata.js +35 -2
- package/dist/theme/BlogPostPage/Metadata.js.map +7 -1
- package/dist/theme/BlogPostPage/StructuredData.js +35 -2
- package/dist/theme/BlogPostPage/StructuredData.js.map +7 -1
- package/dist/theme/BlogPostPage/index.js +98 -24
- package/dist/theme/BlogPostPage/index.js.map +7 -1
- package/dist/theme/DocSearch/index.js +95 -27
- package/dist/theme/DocSearch/index.js.map +7 -1
- package/dist/theme/Layout/index.js +81 -35
- package/dist/theme/Layout/index.js.map +7 -1
- package/dist/theme/Navbar/Content/index.js +69 -26
- package/dist/theme/Navbar/Content/index.js.map +7 -1
- package/dist/theme/Navbar/Logo/index.js +88 -39
- package/dist/theme/Navbar/Logo/index.js.map +7 -1
- package/dist/theme/OsTabs/index.js +50 -19
- package/dist/theme/OsTabs/index.js.map +7 -1
- package/dist/theme/SearchBar/index.js +89 -34
- package/dist/theme/SearchBar/index.js.map +7 -1
- package/package.json +11 -25
- package/css/layout.css +0 -14
- package/css/legacy.css +0 -2313
- package/css/tabs-v1-gradient.css +0 -92
- package/css/tabs-v2-glass.css +0 -116
- package/css/tabs-v3-minimal.css +0 -86
- package/css/tabs-v4-segmented.css +0 -85
- package/css/tabs-v5-neon.css +0 -99
- package/css/tabs-v6-neumorphic.css +0 -89
- package/css/tabs-v7-brutalist.css +0 -81
- package/css/tabs-v8-float.css +0 -114
- package/css/tabs-v9-line.css +0 -104
- package/css/theme.css +0 -72
- package/css/vars-dark.css +0 -7
- package/css/vars.css +0 -8
|
@@ -1,18 +1,54 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
var OsTabs_exports = {};
|
|
30
|
+
__export(OsTabs_exports, {
|
|
31
|
+
OsTabs: () => OsTabs
|
|
32
|
+
});
|
|
33
|
+
module.exports = __toCommonJS(OsTabs_exports);
|
|
34
|
+
var import_jsx_runtime = require("react/jsx-runtime");
|
|
35
|
+
var import_react = require("react");
|
|
36
|
+
var import_Tabs = __toESM(require("@theme/Tabs"));
|
|
37
|
+
var import_react_device_detect = require("react-device-detect");
|
|
38
|
+
function OsTabs(props) {
|
|
39
|
+
const [defaultValue, setDefaultValue] = (0, import_react.useState)(null);
|
|
40
|
+
(0, import_react.useEffect)(() => {
|
|
41
|
+
const tabs = ["iOS", "Android", "Mac OS", "Windows", "Linux"];
|
|
42
|
+
if (tabs.includes(import_react_device_detect.osName)) {
|
|
43
|
+
setDefaultValue(import_react_device_detect.osName);
|
|
44
|
+
} else {
|
|
45
|
+
setDefaultValue("Windows");
|
|
46
|
+
}
|
|
47
|
+
}, []);
|
|
48
|
+
return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_jsx_runtime.Fragment, { children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_Tabs.default, { ...props, defaultValue: defaultValue ?? void 0, children: props.children }) });
|
|
17
49
|
}
|
|
18
|
-
|
|
50
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
51
|
+
0 && (module.exports = {
|
|
52
|
+
OsTabs
|
|
53
|
+
});
|
|
54
|
+
//# sourceMappingURL=OsTabs.js.map
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/OsTabs/OsTabs.tsx"],
|
|
4
|
+
"sourcesContent": ["import React, {useState, useEffect, ReactNode, JSX} from 'react';\r\nimport OriginalTabs from '@theme/Tabs';\r\nimport { osName } from 'react-device-detect';\r\nimport type { ComponentProps } from 'react';\r\n\r\n\r\nexport type OsTabsProps = ComponentProps<typeof OriginalTabs>;\r\n\r\nexport function OsTabs(props: OsTabsProps): JSX.Element {\r\n const [defaultValue, setDefaultValue] = useState<string | null>(null);\r\n\r\n useEffect(() => {\r\n const tabs = ['iOS', 'Android', 'Mac OS', 'Windows', 'Linux'];\r\n if (tabs.includes(osName)) {\r\n setDefaultValue(osName);\r\n } else {\r\n setDefaultValue('Windows');\r\n }\r\n }, []);\r\n\r\n return (\r\n <>\r\n <OriginalTabs {...props} defaultValue={defaultValue ?? undefined}>\r\n {props.children}\r\n </OriginalTabs>\r\n {/* Uncomment the following line to debug the detected and selected values */}\r\n {/* <h2>detected={osName}, selected={defaultValue}</h2> */}\r\n </>\r\n );\r\n}"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAqBQ;AArBR,mBAAyD;AACzD,kBAAyB;AACzB,iCAAuB;AAMhB,SAAS,OAAO,OAAiC;AACpD,QAAM,CAAC,cAAc,eAAe,QAAI,uBAAwB,IAAI;AAEpE,8BAAU,MAAM;AACZ,UAAM,OAAO,CAAC,OAAO,WAAW,UAAU,WAAW,OAAO;AAC5D,QAAI,KAAK,SAAS,iCAAM,GAAG;AACvB,sBAAgB,iCAAM;AAAA,IAC1B,OAAO;AACH,sBAAgB,SAAS;AAAA,IAC7B;AAAA,EACJ,GAAG,CAAC,CAAC;AAEL,SACI,2EACI,sDAAC,YAAAA,SAAA,EAAc,GAAG,OAAO,cAAc,gBAAgB,QAClD,gBAAM,UACX,GAGJ;AAER;",
|
|
6
|
+
"names": ["OriginalTabs"]
|
|
7
|
+
}
|
|
@@ -1,2 +1,29 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var OsTabs_exports = {};
|
|
20
|
+
__export(OsTabs_exports, {
|
|
21
|
+
OsTabs: () => import_OsTabs.OsTabs
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(OsTabs_exports);
|
|
24
|
+
var import_OsTabs = require("./OsTabs");
|
|
25
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
26
|
+
0 && (module.exports = {
|
|
27
|
+
OsTabs
|
|
28
|
+
});
|
|
29
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/OsTabs/index.ts"],
|
|
4
|
+
"sourcesContent": ["export { OsTabs } from './OsTabs';\nexport type { OsTabsProps } from './OsTabs';"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAAuB;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -1,140 +1,261 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
var ProductSearch_exports = {};
|
|
30
|
+
__export(ProductSearch_exports, {
|
|
31
|
+
default: () => ProductSearch
|
|
32
|
+
});
|
|
33
|
+
module.exports = __toCommonJS(ProductSearch_exports);
|
|
34
|
+
var import_jsx_runtime = require("react/jsx-runtime");
|
|
35
|
+
var import_react = require("react");
|
|
36
|
+
var import_react_instantsearch = require("react-instantsearch");
|
|
37
|
+
var import_routers = require("instantsearch.js/es/lib/routers");
|
|
38
|
+
var import_stateMappings = require("instantsearch.js/es/lib/stateMappings");
|
|
39
|
+
var import_lite = require("algoliasearch/lite");
|
|
40
|
+
var import_ProductSearch = __toESM(require("./ProductSearch.module.css"));
|
|
41
|
+
var import_clsx = __toESM(require("clsx"));
|
|
10
42
|
function getUrl(h) {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
h.url_without_variables ||
|
|
15
|
-
"#") + (h.anchor ? `#${h.anchor}` : ""));
|
|
43
|
+
return toRelative(
|
|
44
|
+
(typeof h.url === "string" && h.url || Array.isArray(h.url) && h.url[0] || h.url_without_anchor || h.url_without_variables || "#") + (h.anchor ? `#${h.anchor}` : "")
|
|
45
|
+
);
|
|
16
46
|
}
|
|
17
47
|
function toRelative(href) {
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
}
|
|
48
|
+
try {
|
|
49
|
+
const u = new URL(href, typeof window !== "undefined" ? window.location.origin : "http://localhost");
|
|
50
|
+
return u.pathname + u.search + u.hash;
|
|
51
|
+
} catch {
|
|
52
|
+
return href.startsWith("/") ? href : `/${href}`;
|
|
53
|
+
}
|
|
25
54
|
}
|
|
26
55
|
function shortUrl(h) {
|
|
27
|
-
|
|
56
|
+
return toRelative(getUrl(h));
|
|
28
57
|
}
|
|
29
58
|
function titleFrom(h) {
|
|
30
|
-
|
|
31
|
-
h.hierarchy?.lvl2 ||
|
|
32
|
-
h.hierarchy?.lvl1 ||
|
|
33
|
-
h.hierarchy?.lvl0 ||
|
|
34
|
-
shortUrl(h));
|
|
59
|
+
return h.title || h.hierarchy?.lvl2 || h.hierarchy?.lvl1 || h.hierarchy?.lvl0 || shortUrl(h);
|
|
35
60
|
}
|
|
36
61
|
function ProductBadge({ p }) {
|
|
37
|
-
|
|
62
|
+
return p ? /* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { className: `${import_ProductSearch.default.badge} ${import_ProductSearch.default[`p_${p}`]}`, children: p }) : null;
|
|
38
63
|
}
|
|
39
|
-
/** Configure-based filter (no remount, reliable) */
|
|
40
64
|
function ProductFilter({ product }) {
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
65
|
+
(0, import_react_instantsearch.useConfigure)({
|
|
66
|
+
facetFilters: product ? [[`docusaurus_tag:docs-${product}-current`]] : []
|
|
67
|
+
});
|
|
68
|
+
return null;
|
|
45
69
|
}
|
|
46
|
-
/** Group by section (lvl0), then by page (no duplicate “Learn”) */
|
|
47
70
|
function GroupedHits() {
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
71
|
+
const { hits } = (0, import_react_instantsearch.useHits)();
|
|
72
|
+
const sections = /* @__PURE__ */ new Map();
|
|
73
|
+
for (const h of hits) {
|
|
74
|
+
const lvl0 = h.hierarchy?.lvl0 || "Other";
|
|
75
|
+
const page = h.url_without_anchor || (typeof h.url === "string" ? h.url.split("#")[0] : "") || "";
|
|
76
|
+
const byPage = sections.get(lvl0) || /* @__PURE__ */ new Map();
|
|
77
|
+
const g = byPage.get(page) || { header: titleFrom(h), url: page || getUrl(h), lvl0, items: [] };
|
|
78
|
+
g.items.push(h);
|
|
79
|
+
byPage.set(page, g);
|
|
80
|
+
sections.set(lvl0, byPage);
|
|
81
|
+
}
|
|
82
|
+
return /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: import_ProductSearch.default.groupList, children: [...sections.entries()].map(([lvl0, byPage]) => /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className: import_ProductSearch.default.section, children: [
|
|
83
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: import_ProductSearch.default.sectionHeader, children: lvl0 }),
|
|
84
|
+
[...byPage.values()].map((g) => /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className: import_ProductSearch.default.group, children: [
|
|
85
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className: import_ProductSearch.default.groupHeaderRow, children: [
|
|
86
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)("a", { href: toRelative(g.url), className: import_ProductSearch.default.groupHeader, children: g.header }),
|
|
87
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(ProductBadge, { p: g.items[0].product })
|
|
88
|
+
] }),
|
|
89
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: import_ProductSearch.default.groupSnips, children: g.items.slice(0, 3).map((h, i) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: import_ProductSearch.default.snippet, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react_instantsearch.Snippet, { attribute: "content", hit: h }) }, i)) }),
|
|
90
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: import_ProductSearch.default.groupUrl, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("a", { href: getUrl(g.items[0]), children: shortUrl(g.items[0]) }) })
|
|
91
|
+
] }, g.url))
|
|
92
|
+
] }, lvl0)) });
|
|
63
93
|
}
|
|
64
94
|
function QueryWatcher({ onChange }) {
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
95
|
+
const { query } = (0, import_react_instantsearch.useSearchBox)();
|
|
96
|
+
(0, import_react.useEffect)(() => onChange(query.trim().length >= 2), [query, onChange]);
|
|
97
|
+
return null;
|
|
68
98
|
}
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
},
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
99
|
+
function ProductSearch({
|
|
100
|
+
appId,
|
|
101
|
+
apiKey,
|
|
102
|
+
indexName,
|
|
103
|
+
products = ["frontdoor", "openziti", "onprem", "zlan", "zrok"],
|
|
104
|
+
extraContainerClasses = []
|
|
105
|
+
}) {
|
|
106
|
+
const [product, setProduct] = (0, import_react.useState)("");
|
|
107
|
+
const [searchLongEnough, setSearchLongEnough] = (0, import_react.useState)(false);
|
|
108
|
+
(0, import_react.useEffect)(() => {
|
|
109
|
+
if (typeof window === "undefined") return;
|
|
110
|
+
const p = new URLSearchParams(window.location.search).get("product") || "";
|
|
111
|
+
setProduct(p);
|
|
112
|
+
}, []);
|
|
113
|
+
(0, import_react.useEffect)(() => {
|
|
114
|
+
if (typeof window === "undefined") return;
|
|
115
|
+
const u = new URL(window.location.href);
|
|
116
|
+
if (product) u.searchParams.set("product", product);
|
|
117
|
+
else u.searchParams.delete("product");
|
|
118
|
+
window.history.replaceState({}, "", u);
|
|
119
|
+
}, [product]);
|
|
120
|
+
const base = (0, import_react.useMemo)(() => (0, import_lite.liteClient)(appId, apiKey), [appId, apiKey]);
|
|
121
|
+
const searchClient = (0, import_react.useMemo)(
|
|
122
|
+
() => ({
|
|
123
|
+
...base,
|
|
124
|
+
search(requests) {
|
|
125
|
+
const allShort = requests.every(
|
|
126
|
+
(r) => (r.params?.query ?? "").length < 2
|
|
127
|
+
);
|
|
128
|
+
if (allShort) {
|
|
129
|
+
return Promise.resolve({
|
|
130
|
+
results: requests.map(() => ({
|
|
131
|
+
hits: [],
|
|
132
|
+
nbHits: 0,
|
|
133
|
+
page: 0,
|
|
134
|
+
nbPages: 0,
|
|
135
|
+
processingTimeMS: 0,
|
|
136
|
+
params: "",
|
|
137
|
+
query: "",
|
|
138
|
+
exhaustiveNbHits: false
|
|
139
|
+
}))
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
return base.search(requests);
|
|
143
|
+
}
|
|
144
|
+
}),
|
|
145
|
+
[base, product]
|
|
146
|
+
);
|
|
147
|
+
return /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: import_ProductSearch.default.wrap, children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
|
|
148
|
+
import_react_instantsearch.InstantSearch,
|
|
149
|
+
{
|
|
150
|
+
searchClient,
|
|
151
|
+
indexName,
|
|
152
|
+
routing: {
|
|
153
|
+
router: (0, import_routers.history)({ writeDelay: 300 }),
|
|
154
|
+
stateMapping: (0, import_stateMappings.singleIndex)(indexName)
|
|
155
|
+
},
|
|
156
|
+
children: [
|
|
157
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(QueryWatcher, { onChange: setSearchLongEnough }),
|
|
158
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className: import_ProductSearch.default.topbar, children: [
|
|
159
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
160
|
+
import_react_instantsearch.SearchBox,
|
|
161
|
+
{
|
|
162
|
+
onKeyUp: (e) => {
|
|
163
|
+
setSearchLongEnough(e.currentTarget.value.length > 1);
|
|
164
|
+
},
|
|
165
|
+
autoFocus: true,
|
|
166
|
+
classNames: { input: import_ProductSearch.default.searchInput },
|
|
167
|
+
placeholder: "Enter your search criteria here"
|
|
108
168
|
}
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
169
|
+
),
|
|
170
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className: import_ProductSearch.default.pills, children: [
|
|
171
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
172
|
+
"button",
|
|
173
|
+
{
|
|
174
|
+
className: `${import_ProductSearch.default.pill} ${!product ? import_ProductSearch.default.active : ""}`,
|
|
175
|
+
onClick: () => searchLongEnough && setProduct(""),
|
|
176
|
+
disabled: !searchLongEnough,
|
|
177
|
+
children: "All"
|
|
178
|
+
}
|
|
179
|
+
),
|
|
180
|
+
products.map((p) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
181
|
+
"button",
|
|
182
|
+
{
|
|
183
|
+
className: `${import_ProductSearch.default.pill} ${product === p ? import_ProductSearch.default.active : ""}`,
|
|
184
|
+
onClick: () => searchLongEnough && setProduct(p),
|
|
185
|
+
disabled: !searchLongEnough,
|
|
186
|
+
children: p
|
|
187
|
+
},
|
|
188
|
+
p
|
|
189
|
+
))
|
|
190
|
+
] })
|
|
191
|
+
] }),
|
|
192
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
193
|
+
import_react_instantsearch.Configure,
|
|
194
|
+
{
|
|
195
|
+
hitsPerPage: 20,
|
|
196
|
+
attributesToRetrieve: [
|
|
197
|
+
"url",
|
|
198
|
+
"url_without_anchor",
|
|
199
|
+
"url_without_variables",
|
|
200
|
+
"anchor",
|
|
201
|
+
"hierarchy",
|
|
202
|
+
"product",
|
|
203
|
+
"content",
|
|
204
|
+
"title"
|
|
205
|
+
],
|
|
206
|
+
attributesToHighlight: [
|
|
207
|
+
"title",
|
|
208
|
+
"hierarchy.lvl1",
|
|
209
|
+
"hierarchy.lvl2",
|
|
210
|
+
"content"
|
|
211
|
+
],
|
|
212
|
+
attributesToSnippet: ["content:15"],
|
|
213
|
+
snippetEllipsisText: "\u2026",
|
|
214
|
+
distinct: true
|
|
215
|
+
}
|
|
216
|
+
),
|
|
217
|
+
searchLongEnough && /* @__PURE__ */ (0, import_jsx_runtime.jsx)(ProductFilter, { product }),
|
|
218
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className: (0, import_clsx.default)(import_ProductSearch.default.container, extraContainerClasses), children: [
|
|
219
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className: import_ProductSearch.default.results, children: [
|
|
220
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: import_ProductSearch.default.meta, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react_instantsearch.Stats, {}) }),
|
|
221
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: import_ProductSearch.default.grid, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(GroupedHits, {}) }),
|
|
222
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
223
|
+
import_react_instantsearch.Pagination,
|
|
224
|
+
{
|
|
225
|
+
showFirst: false,
|
|
226
|
+
showLast: false,
|
|
227
|
+
classNames: {
|
|
228
|
+
root: import_ProductSearch.default.pagination,
|
|
229
|
+
list: import_ProductSearch.default.pageList,
|
|
230
|
+
item: import_ProductSearch.default.pageItem,
|
|
231
|
+
selectedItem: import_ProductSearch.default.pageItemSelected,
|
|
232
|
+
disabledItem: import_ProductSearch.default.pageItemDisabled,
|
|
233
|
+
link: import_ProductSearch.default.pageLink
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
)
|
|
237
|
+
] }),
|
|
238
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className: import_ProductSearch.default.footer, children: [
|
|
239
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className: import_ProductSearch.default.kbdRow, children: [
|
|
240
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsxs)("span", { children: [
|
|
241
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)("kbd", { children: "\u21B5" }),
|
|
242
|
+
" open"
|
|
243
|
+
] }),
|
|
244
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsxs)("span", { children: [
|
|
245
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)("kbd", { children: "\u2191" }),
|
|
246
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)("kbd", { children: "\u2193" }),
|
|
247
|
+
" navigate"
|
|
248
|
+
] }),
|
|
249
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsxs)("span", { children: [
|
|
250
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)("kbd", { children: "esc" }),
|
|
251
|
+
" close"
|
|
252
|
+
] })
|
|
253
|
+
] }),
|
|
254
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react_instantsearch.PoweredBy, {})
|
|
255
|
+
] })
|
|
256
|
+
] })
|
|
257
|
+
]
|
|
258
|
+
}
|
|
259
|
+
) });
|
|
139
260
|
}
|
|
140
|
-
//# sourceMappingURL=ProductSearch.js.map
|
|
261
|
+
//# sourceMappingURL=ProductSearch.js.map
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/components/ProductSearch/ProductSearch.tsx"],
|
|
4
|
+
"sourcesContent": ["// src/components/ProductSearch.tsx\r\nimport React, { useEffect, useMemo, useState } from \"react\";\r\nimport {\r\n InstantSearch,\r\n SearchBox,\r\n Pagination,\r\n Snippet,\r\n Configure,\r\n Stats,\r\n PoweredBy,\r\n useHits,\r\n useConfigure,\r\n useSearchBox,\r\n} from \"react-instantsearch\";\r\nimport { history } from \"instantsearch.js/es/lib/routers\";\r\nimport { singleIndex } from \"instantsearch.js/es/lib/stateMappings\";\r\nimport { liteClient as algoliasearch } from \"algoliasearch/lite\";\r\nimport styles from \"./ProductSearch.module.css\";\r\nimport clsx from \"clsx\";\r\n\r\ntype HitRec = {\r\n url?: string | string[];\r\n url_without_anchor?: string;\r\n url_without_variables?: string;\r\n anchor?: string;\r\n hierarchy?: { lvl0?: string; lvl1?: string; lvl2?: string };\r\n product?: string;\r\n content?: string;\r\n title?: string;\r\n};\r\n\r\ntype Props = {\r\n appId: string;\r\n apiKey: string;\r\n indexName: string;\r\n products?: string[];\r\n extraContainerClasses?: string[];\r\n};\r\n\r\nfunction getUrl(h: HitRec): string {\r\n return toRelative(\r\n ((typeof h.url === \"string\" && h.url) ||\r\n (Array.isArray(h.url) && h.url[0]) ||\r\n h.url_without_anchor ||\r\n h.url_without_variables ||\r\n \"#\") + (h.anchor ? `#${h.anchor}` : \"\")\r\n );\r\n}\r\nfunction toRelative(href: string): string {\r\n try {\r\n const u = new URL(href, typeof window !== \"undefined\" ? window.location.origin : \"http://localhost\");\r\n return u.pathname + u.search + u.hash;\r\n } catch {\r\n return href.startsWith(\"/\") ? href : `/${href}`;\r\n }\r\n}\r\nfunction shortUrl(h: HitRec): string {\r\n return toRelative(getUrl(h));\r\n}\r\nfunction titleFrom(h: HitRec): string {\r\n return (\r\n h.title ||\r\n h.hierarchy?.lvl2 ||\r\n h.hierarchy?.lvl1 ||\r\n h.hierarchy?.lvl0 ||\r\n shortUrl(h)\r\n );\r\n}\r\nfunction ProductBadge({ p }: { p?: string }) {\r\n return p ? (\r\n <span className={`${styles.badge} ${styles[`p_${p}`]}`}>{p}</span>\r\n ) : null;\r\n}\r\n\r\n/** Configure-based filter (no remount, reliable) */\r\nfunction ProductFilter({ product }: { product: string }) {\r\n useConfigure({\r\n facetFilters: product ? [[`docusaurus_tag:docs-${product}-current`]] : [],\r\n });\r\n return null;\r\n}\r\n\r\n/** Group by section (lvl0), then by page (no duplicate \u201CLearn\u201D) */\r\nfunction GroupedHits() {\r\n const { hits } = useHits<HitRec>();\r\n const sections = new Map<\r\n string,\r\n Map<string, { header: string; url: string; lvl0?: string; items: HitRec[] }>\r\n >();\r\n\r\n for (const h of hits) {\r\n const lvl0 = h.hierarchy?.lvl0 || \"Other\";\r\n const page =\r\n h.url_without_anchor ||\r\n (typeof h.url === \"string\" ? h.url.split(\"#\")[0] : \"\") ||\r\n \"\";\r\n\r\n const byPage = sections.get(lvl0) || new Map();\r\n const g =\r\n byPage.get(page) ||\r\n { header: titleFrom(h), url: page || getUrl(h), lvl0, items: [] };\r\n\r\n g.items.push(h);\r\n byPage.set(page, g);\r\n sections.set(lvl0, byPage);\r\n }\r\n\r\n return (\r\n <div className={styles.groupList}>\r\n {[...sections.entries()].map(([lvl0, byPage]) => (\r\n <div key={lvl0} className={styles.section}>\r\n <div className={styles.sectionHeader}>{lvl0}</div>\r\n {[...byPage.values()].map((g) => (\r\n <div key={g.url} className={styles.group}>\r\n <div className={styles.groupHeaderRow}>\r\n <a href={toRelative(g.url)} className={styles.groupHeader}>\r\n {g.header}\r\n </a>\r\n <ProductBadge p={g.items[0].product} />\r\n </div>\r\n <div className={styles.groupSnips}>\r\n {g.items.slice(0, 3).map((h, i) => (\r\n <div key={i} className={styles.snippet}>\r\n <Snippet attribute=\"content\" hit={h as any} />\r\n </div>\r\n ))}\r\n </div>\r\n <div className={styles.groupUrl}>\r\n <a href={getUrl(g.items[0])}>{shortUrl(g.items[0])}</a>\r\n </div>\r\n </div>\r\n ))}\r\n </div>\r\n ))}\r\n </div>\r\n );\r\n}\r\n\r\nfunction QueryWatcher({ onChange }: { onChange: (ok: boolean) => void }) {\r\n const { query } = useSearchBox();\r\n useEffect(() => onChange(query.trim().length >= 2), [query, onChange]);\r\n return null;\r\n}\r\n\r\nexport default function ProductSearch({\r\n appId,\r\n apiKey,\r\n indexName,\r\n products = [\"frontdoor\", \"openziti\", \"onprem\", \"zlan\", \"zrok\"],\r\n extraContainerClasses = [],\r\n }: Props) {\r\n // read initial pill from ?product= for back/forward + shareable URLs\r\n const [product, setProduct] = useState<string>(\"\");\r\n const [searchLongEnough, setSearchLongEnough] = useState<boolean>(false);\r\n\r\n useEffect(() => {\r\n if (typeof window === \"undefined\") return;\r\n const p = new URLSearchParams(window.location.search).get(\"product\") || \"\";\r\n setProduct(p);\r\n }, []);\r\n useEffect(() => {\r\n if (typeof window === \"undefined\") return;\r\n const u = new URL(window.location.href);\r\n if (product) u.searchParams.set(\"product\", product);\r\n else u.searchParams.delete(\"product\");\r\n window.history.replaceState({}, \"\", u);\r\n }, [product]);\r\n\r\n const base = useMemo(() => algoliasearch(appId, apiKey), [appId, apiKey]);\r\n\r\n // Gate only when no query AND no pill active (prevents \u201Cfreeze\u201D on pill-only)\r\n const searchClient = useMemo(\r\n () => ({\r\n ...base,\r\n search(requests: any[]) {\r\n const allShort = requests.every(\r\n (r: any) => (r.params?.query ?? \"\").length < 2\r\n );\r\n if (allShort) { // block ALL searches until query >= 2\r\n return Promise.resolve({\r\n results: requests.map(() => ({\r\n hits: [],\r\n nbHits: 0,\r\n page: 0,\r\n nbPages: 0,\r\n processingTimeMS: 0,\r\n params: \"\",\r\n query: \"\",\r\n exhaustiveNbHits: false,\r\n })),\r\n });\r\n }\r\n return (base as any).search(requests);\r\n },\r\n }),\r\n [base, product]\r\n );\r\n\r\n return (\r\n <div className={styles.wrap}>\r\n <InstantSearch\r\n searchClient={searchClient}\r\n indexName={indexName}\r\n routing={{\r\n router: history({ writeDelay: 300 }),\r\n stateMapping: singleIndex(indexName),\r\n } as any}\r\n >\r\n <QueryWatcher onChange={setSearchLongEnough} />\r\n <div className={styles.topbar}>\r\n <SearchBox\r\n onKeyUp={(e: React.KeyboardEvent<HTMLInputElement>) => {\r\n setSearchLongEnough((e.currentTarget as HTMLInputElement).value.length > 1);\r\n }}\r\n autoFocus\r\n classNames={{ input: styles.searchInput }}\r\n placeholder=\"Enter your search criteria here\"\r\n />\r\n <div className={styles.pills}>\r\n <button\r\n className={`${styles.pill} ${!product ? styles.active : \"\"}`}\r\n onClick={() => searchLongEnough && setProduct(\"\")}\r\n disabled={!searchLongEnough}\r\n >\r\n All\r\n </button>\r\n {products.map((p) => (\r\n <button\r\n key={p}\r\n className={`${styles.pill} ${product === p ? styles.active : \"\"}`}\r\n onClick={() => searchLongEnough && setProduct(p)}\r\n disabled={!searchLongEnough}\r\n >\r\n {p}\r\n </button>\r\n ))}\r\n </div>\r\n </div>\r\n\r\n {/* static config */}\r\n <Configure\r\n hitsPerPage={20}\r\n attributesToRetrieve={[\r\n \"url\",\r\n \"url_without_anchor\",\r\n \"url_without_variables\",\r\n \"anchor\",\r\n \"hierarchy\",\r\n \"product\",\r\n \"content\",\r\n \"title\",\r\n ]}\r\n attributesToHighlight={[\r\n \"title\",\r\n \"hierarchy.lvl1\",\r\n \"hierarchy.lvl2\",\r\n \"content\",\r\n ]}\r\n attributesToSnippet={[\"content:15\"]}\r\n snippetEllipsisText=\"\u2026\"\r\n distinct\r\n />\r\n\r\n {searchLongEnough && <ProductFilter product={product} />}\r\n\r\n <div className={clsx(styles.container, extraContainerClasses)}>\r\n <div className={styles.results}>\r\n <div className={styles.meta}>\r\n <Stats />\r\n </div>\r\n <div className={styles.grid}>\r\n <GroupedHits />\r\n </div>\r\n <Pagination\r\n showFirst={false}\r\n showLast={false}\r\n classNames={{\r\n root: styles.pagination,\r\n list: styles.pageList,\r\n item: styles.pageItem,\r\n selectedItem: styles.pageItemSelected,\r\n disabledItem: styles.pageItemDisabled,\r\n link: styles.pageLink,\r\n }}\r\n />\r\n </div>\r\n <div className={styles.footer}>\r\n <div className={styles.kbdRow}>\r\n <span>\r\n <kbd>\u21B5</kbd> open\r\n </span>\r\n <span>\r\n <kbd>\u2191</kbd>\r\n <kbd>\u2193</kbd> navigate\r\n </span>\r\n <span>\r\n <kbd>esc</kbd> close\r\n </span>\r\n </div>\r\n <PoweredBy />\r\n </div>\r\n </div>\r\n </InstantSearch>\r\n </div>\r\n );\r\n}\r\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["styles", "algoliasearch", "clsx"]
|
|
7
|
+
}
|