2016-07-03 16:45:13 +00:00
|
|
|
import React from 'react';
|
2016-06-12 11:32:46 +00:00
|
|
|
import AutocompleteProvider from './AutocompleteProvider';
|
|
|
|
import Q from 'q';
|
|
|
|
import 'whatwg-fetch';
|
|
|
|
|
2016-07-03 16:45:13 +00:00
|
|
|
import {TextualCompletion} from './Components';
|
|
|
|
|
2016-06-21 10:16:20 +00:00
|
|
|
const DDG_REGEX = /\/ddg\s+(.+)$/g;
|
2016-07-03 16:45:13 +00:00
|
|
|
const REFERRER = 'vector';
|
2016-06-12 11:32:46 +00:00
|
|
|
|
2016-06-20 08:22:55 +00:00
|
|
|
let instance = null;
|
|
|
|
|
2016-06-12 11:32:46 +00:00
|
|
|
export default class DuckDuckGoProvider extends AutocompleteProvider {
|
2016-06-21 10:16:20 +00:00
|
|
|
constructor() {
|
|
|
|
super(DDG_REGEX);
|
|
|
|
}
|
|
|
|
|
2016-06-12 11:32:46 +00:00
|
|
|
static getQueryUri(query: String) {
|
2016-07-04 20:07:01 +00:00
|
|
|
return `https://api.duckduckgo.com/?q=${encodeURIComponent(query)}`
|
2016-07-03 16:45:13 +00:00
|
|
|
+ `&format=json&no_redirect=1&no_html=1&t=${encodeURIComponent(REFERRER)}`;
|
2016-06-12 11:32:46 +00:00
|
|
|
}
|
|
|
|
|
2016-06-21 10:16:20 +00:00
|
|
|
getCompletions(query: string, selection: {start: number, end: number}) {
|
2016-07-03 16:45:13 +00:00
|
|
|
let {command, range} = this.getCurrentCommand(query, selection);
|
|
|
|
if (!query || !command) {
|
2016-06-12 11:32:46 +00:00
|
|
|
return Q.when([]);
|
2016-07-03 16:45:13 +00:00
|
|
|
}
|
2016-06-12 11:32:46 +00:00
|
|
|
|
2016-06-21 10:16:20 +00:00
|
|
|
return fetch(DuckDuckGoProvider.getQueryUri(command[1]), {
|
2016-07-03 16:45:13 +00:00
|
|
|
method: 'GET',
|
2016-06-16 23:28:09 +00:00
|
|
|
})
|
|
|
|
.then(response => response.json())
|
|
|
|
.then(json => {
|
|
|
|
let results = json.Results.map(result => {
|
|
|
|
return {
|
2016-07-03 16:45:13 +00:00
|
|
|
completion: result.Text,
|
|
|
|
component: (
|
|
|
|
<TextualCompletion
|
|
|
|
title={result.Text}
|
|
|
|
description={result.Result} />
|
|
|
|
),
|
|
|
|
range,
|
2016-06-16 23:28:09 +00:00
|
|
|
};
|
|
|
|
});
|
2016-07-03 16:45:13 +00:00
|
|
|
if (json.Answer) {
|
2016-06-16 23:28:09 +00:00
|
|
|
results.unshift({
|
2016-07-03 16:45:13 +00:00
|
|
|
completion: json.Answer,
|
|
|
|
component: (
|
|
|
|
<TextualCompletion
|
|
|
|
title={json.Answer}
|
|
|
|
description={json.AnswerType} />
|
|
|
|
),
|
|
|
|
range,
|
2016-06-16 23:28:09 +00:00
|
|
|
});
|
|
|
|
}
|
2016-07-03 16:45:13 +00:00
|
|
|
if (json.RelatedTopics && json.RelatedTopics.length > 0) {
|
2016-06-16 23:28:09 +00:00
|
|
|
results.unshift({
|
2016-07-03 16:45:13 +00:00
|
|
|
completion: json.RelatedTopics[0].Text,
|
|
|
|
component: (
|
|
|
|
<TextualCompletion
|
|
|
|
title={json.RelatedTopics[0].Text} />
|
|
|
|
),
|
|
|
|
range,
|
2016-06-16 23:28:09 +00:00
|
|
|
});
|
|
|
|
}
|
2016-07-03 16:45:13 +00:00
|
|
|
if (json.AbstractText) {
|
2016-06-16 23:28:09 +00:00
|
|
|
results.unshift({
|
2016-07-03 16:45:13 +00:00
|
|
|
completion: json.AbstractText,
|
|
|
|
component: (
|
|
|
|
<TextualCompletion
|
|
|
|
title={json.AbstractText} />
|
|
|
|
),
|
|
|
|
range,
|
2016-06-16 23:28:09 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
return results;
|
2016-06-12 11:32:46 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
getName() {
|
2016-08-17 11:57:19 +00:00
|
|
|
return '🔍 Results from DuckDuckGo';
|
2016-06-12 11:32:46 +00:00
|
|
|
}
|
2016-06-20 08:22:55 +00:00
|
|
|
|
|
|
|
static getInstance(): DuckDuckGoProvider {
|
2016-07-03 16:45:13 +00:00
|
|
|
if (instance == null) {
|
2016-06-20 08:22:55 +00:00
|
|
|
instance = new DuckDuckGoProvider();
|
2016-07-03 16:45:13 +00:00
|
|
|
}
|
2016-06-20 08:22:55 +00:00
|
|
|
return instance;
|
|
|
|
}
|
2016-08-22 19:06:31 +00:00
|
|
|
|
|
|
|
renderCompletions(completions: [React.Component]): ?React.Component {
|
|
|
|
return <div className="mx_Autocomplete_Completion_container_block">
|
|
|
|
{completions}
|
|
|
|
</div>;
|
|
|
|
}
|
2016-06-12 11:32:46 +00:00
|
|
|
}
|