IntegrationsZendeskHelp center

Add AI Search to your Zendesk help center

What is Zendesk

Zendesk is a customer service solution for handling support tickets.

Get an API key

  1. Go to the Inkeep Dashboard
  2. Select your project under Projects
  3. Go to the Integrations tab
  4. Click on Create integration
  5. Select Web
  6. Provide a Name.
  7. Specify a URL for where this integration will be used.
  8. For production API keys, leave Enforce referrer URL checked.
  9. Click on Create
  10. Click the Example < /> button to get your API key and view suggested settings

For local or staging API keys, see here.

Connect the script

  1. Click the Zendesk Products in the top bar, then select Guide
  2. Navigate to Guide Admin
  3. Click Customize on the theme you want to edit
  4. Click Edit code. Which will open theme code editor

In the templates section, find the document_head.hbs file and paste the code below:

<script
  id="inkeep-script"
  type="module"
  src="https://cdn.jsdelivr.net/npm/@inkeep/cxkit-js@0.5/dist/embed.js"
  defer
></script>

Creating the container

Add a container for the widget:

  1. Open the home_page.hbs and section_page.hbs files
  2. Add an element with the ID - inkeepSearchBarNav and inkeepSearchBarHero
  3. Apply the below before -> after changes to home_page.hbs:
<!-- other code -->
<section id="main-content" class="section hero">
  <div class="hero-inner">
    <h2 class="visibility-hidden">{{ t 'search' }}</h2>
    <svg
      xmlns="http://www.w3.org/2000/svg"
      width="12"
      height="12"
      focusable="false"
      viewBox="0 0 12 12"
      class="search-icon"
      aria-hidden="true"
    >
      <circle cx="4.5" cy="4.5" r="4" fill="none" stroke="currentColor" />
      <path stroke="currentColor" stroke-linecap="round" d="M11 11L7.5 7.5" />
    </svg>
    {{search submit=false instant=settings.instant_search class='search
    search-full'}}
  </div>
</section>
<!-- other code -->
<section id="main-content" class="section hero">
  <div class="hero-inner">
    <div id="inkeepSearchBarHero"></div>
  </div>
</section>
  1. Apply the below before -> after changes to section_page.hbs:
<!-- other code -->
<div class="sub-nav">
  {{breadcrumbs}}
  <div class="search-container">
    <svg
      xmlns="http://www.w3.org/2000/svg"
      width="12"
      height="12"
      focusable="false"
      viewBox="0 0 12 12"
      class="search-icon"
      aria-hidden="true"
    >
      <circle cx="4.5" cy="4.5" r="4" fill="none" stroke="currentColor" />
      <path stroke="currentColor" stroke-linecap="round" d="M11 11L7.5 7.5" />
    </svg>
    {{search scoped=settings.scoped_kb_search submit=false}}
  </div>
</div>
<!-- other code -->
<div class="sub-nav">
  {{breadcrumbs}}
  <div class="search-container">
    <div id="inkeepSearchBarNav"></div>
  </div>
</div>
  1. Click Publish

Custom CSS

Zendesk allows you to add a custom css file to the assets directory:

  1. Create an inkeep-styles.css stylesheet and paste in the below::
inkeep-styles.css
[data-theme="light"] .ikp-search-bar__button {
  background: white;
  border-radius: 6px;
  width: 100%;
}
  1. In the theme code editor, click Add
  2. Click on Asset
  3. Upload the created css file

Initialize the widget

Next, go back to the header.hbs file and add the following code at the end of the file:

<script type="text/javascript" defer>
  const inkeepScript = document.getElementById("inkeep-script");
 
  // configure and initialize the widget
  const addInkeepWidget = (targetElementId) => {
    const inkeepStyles = "{{asset 'inkeep-styles.css'}}"; // <--- replace with provide template string (if different)
    const inkeepWidget = Inkeep.SearchBar(targetElementId, {
      baseSettings: {
        apiKey: "INKEEP_API_KEY", // required
        primaryBrandColor: "#26D6FF", // your brand color, widget color scheme is derived from this
        organizationDisplayName: "Inkeep",
        // ...optional settings
        theme: {
          styles: [
            {
              key: "main",
              type: "link",
              value: inkeepStyles,
            },
          ],
        },
      },
      modalSettings: {
        // optional settings
      },
      searchSettings: {
        // optional settings
      },
      aiChatSettings: {
        // optional settings
        aiAssistantAvatar: "https://mydomain.com/mylogo", // use your own ai assistant avatar
        exampleQuestions: [
          "Example question 1?",
          "Example question 2?",
          "Example question 3?",
        ],
      },
    });
  };
 
  inkeepScript.addEventListener("load", () => {
    if (document.body) {
      const navSearchBarContainer =
        document.getElementById("inkeepSearchBarNav");
      const heroSearchBarContainer = document.getElementById(
        "inkeepSearchBarHero"
      );
 
      navSearchBarContainer && addInkeepWidget("#inkeepSearchBarNav"); // initialize the nav SearchBar widget
      heroSearchBarContainer && addInkeepWidget("#inkeepSearchBarHero"); // initialize the hero SearchBar widget
    }
  });
</script>

Different styles between hero and nav bar

You can conditionally apply different stylesheets to the navigation bar or hero search bar.

// ...
 
const inkeepSearchBarNavStyles = "{{asset 'inkeep-styles.css'}}"; // <--- should match the uploaded file
const inkeepSearchBarHeroStyles = "{{asset 'inkeep-hero-styles.css'}}"; // <--- should match the uploaded file
 
const getStyles = (targetElementId) => {
  return {
    key: `style-${targetElementId}`,
    type: "link",
    value:
      targetElementId === "inkeepSearchBarHero"
        ? inkeepSearchBarHeroStyles
        : inkeepSearchBarNavStyles,
  };
};
 
const inkeepWidget = Inkeep.SearchBar(targetElementId, {
  baseSettings: {
    apiKey: "INKEEP_API_KEY", // required
    primaryBrandColor: "#26D6FF", // your brand color, widget color scheme is derived from this
    organizationDisplayName: "Inkeep",
    // ...optional settings
    theme: {
      styles: getStyles(targetElementId),
    },
  },
  modalSettings: {
    // optional settings
  },
  searchSettings: {
    // optional settings
  },
  aiChatSettings: {
    // optional settings
    aiAssistantAvatar: "https://mydomain.com/mylogo", // use your own ai assistant avatar
    exampleQuestions: [
      "Example question 1?",
      "Example question 2?",
      "Example question 3?",
    ],
  },
});
// ...

Save custom code

Click on the Publish. Navigate to your web application to make sure the widget is installed correctly.

For a full list of customizations, check out the Search Bar documentation.

On this page