PageRenderTime 66ms CodeModel.GetById 31ms RepoModel.GetById 0ms app.codeStats 0ms

/duckduckhack/spice/spice_overview.md

https://gitlab.com/Guy1394/duckduckgo-documentation
Markdown | 64 lines | 36 code | 28 blank | 0 comment | 0 complexity | 29886fccc83d9f55dda3ec6787cdc77a MD5 | raw file
  1. ## Spice Overview
  2. **If you have questions, [request an invite to our Slack team](mailto:QuackSlack@duckduckgo.com?subject=AddMe) and we'll be happy to chat!**
  3. Spice Instant Answers are triggered by a backend Perl component that then calls the JSON API of an upstream service. The API response is wrapped in a JavaScript function call. You, the Instant Answer author, define this callback function and handle the API's response on the client side, generating the display from the data returned by the API.
  4. ## Spice API Criteria
  5. With millions of search queries triggering Instant Answers every day, it's important to choose APIs wisely. There are several criteria for APIs used in Spice Instant Answers.
  6. First, the technical constraints:
  7. - APIs called by Spice Instant Answers **must use the JSON or JSONP formats**. We do not support the use of XML (it's coming soon though!), HTML, or plain text responses.
  8. - APIs should respond to requests in **less than one second** (< 1s).
  9. - Avoid **static JSON files**. These often have large payloads and require heavy local processing. Not sure? [Talk to us about your idea](mailto:open@duckduckgo.com).
  10. Next, API reliability:
  11. - APIs used should be **reliable**. Pick sources that will be most likely be around and accurate for the foreseeable future.
  12. - APIs created by contributors solely for the purpose of an Instant Answer cannot be accepted.
  13. Finally, credibility:
  14. - APIs used should represent the **most credible source** for the information. This means it should draw upon the preferred data source of the relevant community. Look for posts and sources like [these](https://duck.co/forum/thread/37/great-resources-for-instant-answer-ideas) which have been suggested by others.
  15. - APIs must have the appropriate permissions or rights to serve their information.
  16. If you're not sure about whether the API you'd like to use fits these criteria, we're happy to help figure it out. Email us over at [open@duckduckgo.com](mailto:open@duckduckgo.com).
  17. ## Spice Frontend
  18. The Spice frontend is the code that is triggered by the Perl backend for your spice Instant Answer. It mainly consists of a function (the Spice "callback" function) that takes a JSON formatted, API response as its input and uses the data to display a Spice result at the top of the DuckDuckGo search results page.
  19. ## Spice Templates
  20. In order to display the result, the Spice callback function needs to specify a template, which will determine how the result looks. There are several built-in templates to choose from and you are able to choose whichever template works best for the given data and desired output.
  21. ## Third-Party Libraries
  22. Aside from HTML and CSS, the Spice frontend also utilizes the following third-party libraries:
  23. - [jQuery](https://jquery.org) v1.10.2
  24. - and [Handlebars](http://handlebarsjs.com) v1.3.0
  25. If you're not already familiar with Handlebars, *please* read the [Handlebars documentation](http://handlebarsjs.com) before continuing on. Don't worry if you don't fully understand how to use Handlebars, the examples will explain everything. You should, at the very least, familiarize yourself with Handlebars concepts and terminology before moving on. It should only take a few minutes to read!
  26. <!-- /summary -->
  27. Likewise, using jQuery is not required for making a Spice Instant Answer. But, it does offer certain benefits, such as cross-browser compatible implementations of various JavaScript functions. For example, jQuery's `$.each()` should be used in place of the native `Array.prototype.forEach()`, as it does **not** work in IE 6,7,8.
  28. Later, we will walk you through several examples, ranging from simple to complex, which will explain how to use templates and make your Instant Answers look awesome :)
  29. ## Spice Files
  30. A typical Spice Instant Answer requires several files to function properly.
  31. - The Perl files go in the **lib** directory: `lib/DDG/Spice/InstantAnswerName.pm`
  32. - The frontend files (JS, Handlebars, CSS) discussed later go in the **share** directory: `share/spice/instant_answer_name/`
  33. **\*\*Note** : The file and folder names must adhere to our naming conventions (covered later) in order for everything to function properly.
  34. ## Let Us Know What You're Working On
  35. **Before you start coding your new Instant Answer, let us know your plans.** By involving us early we can provide guidance and potentially save you a lot of time and effort.
  36. Email us at [open@duckduckgo.com](mailto:open@duckduckgo.com) with what idea you're working on and how you're thinking of going about it.