Skip to content

Latest commit

 

History

History
92 lines (64 loc) · 3.72 KB

README.md

File metadata and controls

92 lines (64 loc) · 3.72 KB

Please do not fork this repository.

JavaScript rocks!

Welcome to the Wizkids JavaScript test! The test is inspired by one of our products (AppWriter) which helps people with read/writing troubles by enabling them to read text out load and get word suggestions (predictions) while typing.

Predictions are word completions based on the input text, for example: If the input text is I like ca the predictions could be cars, cats and cake.

The test requires you to write a small web page and JavaScript that implements a small subset of AppWriter functionality. Please use modern JavaScript syntax (ES6)/HTML/CSS or a modern framework such as React, Vue or Angular but not jQuery*.

If you encounter any unexpected issues please contact us at srs AT wizkids.dk and we will get back to you ASAP.

* Please refrain from using autocomplete modules - we would like to see your ability to solve this rather than your ability to use third party modules.

Scope

We expect a simply structured HTML/CSS/JS project with good readability. Design and UX is not a major consideration - keeping it simple is fine.

We expect a well-versed front-ender to be able to complete the task within a few hours.

Tasks

1. Generate a token for use with the word predictions web service at https://services.lingapps.dk/misc/CSharpJSRocks.

2. Write a function that performs a web request to fetch word predictions.

See the "Word predictions web service description" section below for more info on how to use the web service.

3. Display the first 10 word predictions in HTML.

4. Add a <textarea> in your HTML and use the text value for the function you wrote in step #1.

The text should be based on the position of the caret inside the textarea, for example:

Hello, my name is J|ohn Doe and I like pie! 

The extracted text should be from the start of the <textarea> up to the caret, which in this example would be Hello, my name is J. The list of word predictions should be updated on either keyup or keypress (whichever you think is more appropriate).

5. Make your word predictions result clickable and insert the clicked prediction into the <textarea> on click.

The word prediction should be inserted into the <textarea> at the location of the caret.

6. (OPTIONAL) Emphasize the part of each word prediction that has already been written.

For example, using the text from step #3 Hello, my name is J the letter J should be emphasized in the predictions John, James and June:

John
James
June

7. Add your code in a Git project on GitHub and submit the link at https://services.lingapps.dk/misc/CSharpJSRocks.

(OPTIONAL, but strongly recommended) Also add a link to one of your JavaScript front-end projects (in which you've been a major contributor) - Git repository preferred.

Word predictions web service description

URL

https://services.lingapps.dk/misc/getPredictions

Authorization

Header: Authorization: Bearer [TOKEN] (token generated in task #1)

Parameters

  • locale: String, the language in which the predictions should be computed. Valid values are da-DK and en-GB.
  • text: String, the text from which to compute the predictions.

Response

JSON encoded array of strings ordered by prediction probability (descending), for example: ["cars", "cats", "cake"]

Example

Request

GET /misc/getPredictions?locale=en-GB&text=I%20like%20ca HTTP/1.1
Host: services.lingapps.dk
Authorization: Bearer MjAxOS0wMS0wMQ==.dGVzdEBleGFtcGxlLmNvbQ==.MjExMWMyYjdjZGY3YTU3MmU4MTA5OWY0MDgyMmM0OTk=
Connection: Close

Response

HTTP/1.1 200 OK
Content-Length: 34
Connection: close
Content-Type: application/json

[
    "cars",
    "cats",
    "cake"
]