aboutsummaryrefslogtreecommitdiff
path: root/_includes/search/algolia-search-scripts.html
diff options
context:
space:
mode:
authorAndrew Lee <alee14498@gmail.com>2019-10-27 09:57:37 -0400
committerAndrew Lee <alee14498@gmail.com>2019-10-27 09:57:37 -0400
commite62e7bb6b14555c9bbe5d40d217103984f4f80e6 (patch)
tree21887d847dccacb47644eb6f74ce31326172303c /_includes/search/algolia-search-scripts.html
parent716ea6ed2b64c921a799d872a07bfbd53b2a3e58 (diff)
downloadpokeworld-website-e62e7bb6b14555c9bbe5d40d217103984f4f80e6.tar.gz
pokeworld-website-e62e7bb6b14555c9bbe5d40d217103984f4f80e6.tar.bz2
pokeworld-website-e62e7bb6b14555c9bbe5d40d217103984f4f80e6.zip
Rewrite progress
Diffstat (limited to '_includes/search/algolia-search-scripts.html')
-rw-r--r--_includes/search/algolia-search-scripts.html54
1 files changed, 54 insertions, 0 deletions
diff --git a/_includes/search/algolia-search-scripts.html b/_includes/search/algolia-search-scripts.html
new file mode 100644
index 0000000..a6bc9d2
--- /dev/null
+++ b/_includes/search/algolia-search-scripts.html
@@ -0,0 +1,54 @@
+<!-- Including InstantSearch.js library and styling -->
+<script src="https://cdn.jsdelivr.net/npm/instantsearch.js@2.3.3/dist/instantsearch.min.js"></script>
+<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/instantsearch.js@2.3.3/dist/instantsearch.min.css">
+<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/instantsearch.js@2.3.3/dist/instantsearch-theme-algolia.min.css">
+
+<script>
+// Instanciating InstantSearch.js with Algolia credentials
+const search = instantsearch({
+ appId: '{{ site.algolia.application_id }}',
+ apiKey: '{{ site.algolia.search_only_api_key }}',
+ indexName: '{{ site.algolia.index_name }}',
+ searchParameters: {
+ restrictSearchableAttributes: [
+ 'title',
+ 'content'
+ ]
+ }
+});
+
+const hitTemplate = function(hit) {
+ const url = hit.url;
+ const title = hit._highlightResult.title.value;
+ const content = hit._highlightResult.html.value;
+
+ return `
+ <div class="list__item">
+ <article class="archive__item" itemscope itemtype="https://schema.org/CreativeWork">
+ <h2 class="archive__item-title" itemprop="headline"><a href="{{ site.baseurl }}${url}">${title}</a></h2>
+ <div class="archive__item-excerpt" itemprop="description">${content}</div>
+ </article>
+ </div>
+ `;
+}
+
+// Adding searchbar and results widgets
+search.addWidget(
+ instantsearch.widgets.searchBox({
+ container: '.search-searchbar',
+ {% unless site.algolia.powered_by == false %}poweredBy: true,{% endunless %}
+ placeholder: '{{ site.data.ui-text[site.locale].search_placeholder_text | default: "Enter your search term..." }}'
+ })
+);
+search.addWidget(
+ instantsearch.widgets.hits({
+ container: '.search-hits',
+ templates: {
+ item: hitTemplate
+ }
+ })
+);
+
+// Starting the search
+search.start();
+</script>