-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathwidget.tsx
47 lines (46 loc) · 2.46 KB
/
widget.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
import React from 'react'
import ReactDOM from 'react-dom'
import { Dropdown } from './Dropdown'
import { DropdownOptions } from './options'
import { extract } from './util'
export function initHook(args: any, mountLocation: string) {
if(typeof args !== 'object' && args !== null) args = {};
// Re-compose options with type safety checks and default values
const options: DropdownOptions = {
pageLanguage: extract(args, 'pageLanguage', 'en'),
siteName: extract(args, 'siteName', ''),
chunkSize: extract(args, 'chunkSize', 10),
attributionImageUrl: extract(args, 'attributionImageUrl', undefined),
logoImageUrl: extract(args, 'logoImageUrl', undefined),
preferredSupportedLanguages: extract(args, 'preferredSupportedLanguages', []),
intersectionThreshold: extract(args, 'intersectionThreshold', 0.0),
ignoreIntersection: extract(args, 'ignoreIntersection', false),
ignoreClasses: extract(args, 'ignoreClasses', []),
ignoreSelectors: extract(args, 'ignoreSelectors', []),
verboseOutput: extract(args, 'verboseOutput', false),
updateDocumentLanguageAttribute: extract(args, 'updateDocumentLanguageAttribute', false),
buttons: extract(args, 'buttons', []),
includedAttributes: extract(args, 'includedAttributes', ['title', 'placeholder', 'alt']),
endpoints: {
//supportedLanguages: 'http://wlinux.wsl:3000/api/v3/supportedLanguages',
//translate: 'http://wlinux.wsl:3000/api/v3/translate'
supportedLanguages: extract(args, ['endpoints', 'supportedLanguages'], 'https://google-translate-sample.vercel.app/api/legacy/supportedLanguages'),
updateTranslation: extract(args, ['endpoints', 'updateTranslation'], ''),
translate: extract(args, ['endpoints', 'translate'], 'https://google-translate-sample.vercel.app/api/legacy/translate')
}
};
// for debugging
console.log(options)
// Check if real endpoints were provided
if(options.endpoints.supportedLanguages === '') throw `Improper supportedLanguages endpoint provided: '${options.endpoints.supportedLanguages}'`;
if(options.endpoints.translate === '') throw `Improper translate endpoint provided: '${options.endpoints.translate}'`;
// Include the native language if it isn't already
if(! options.preferredSupportedLanguages.includes(options.pageLanguage)) {
options.preferredSupportedLanguages.push(options.pageLanguage)
}
// Render the component
ReactDOM.render(
<Dropdown options={options} />,
document.getElementById(mountLocation)
);
}