-
Notifications
You must be signed in to change notification settings - Fork 0
/
App.js
72 lines (65 loc) · 2.67 KB
/
App.js
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
import React, { useState, useEffect } from 'react';
import { Typography } from '@material-ui/core';
import wordsToNumbers from 'words-to-numbers';
import alanBtn from '@alan-ai/alan-sdk-web';
import logo from './images/logo.png';
import cheetah from './images/cheetah-logo.png';
import { NewsCards, Modal } from './components';
import useStyles from './styles';
const App = () => {
const [activeArticle, setActiveArticle] = useState(0);
const [newsArticles, setNewsArticles] = useState([]);
const [isOpen, setIsOpen] = useState(false);
const classes = useStyles();
useEffect(() => {
alanBtn({
key: '44f78b97e31b58cf13548ca4ca050b992e956eca572e1d8b807a3e2338fdd0dc/stage',
onCommand: ({ command, articles, number }) => {
if (command === 'newHeadlines') {
setNewsArticles(articles);
setActiveArticle(-1);
} else if (command === 'instructions') {
setIsOpen(true);
} else if (command === 'highlight') {
setActiveArticle((prevActiveArticle) => prevActiveArticle + 1);
} else if (command === 'open') {
const parsedNumber = number.length > 2 ? wordsToNumbers((number), { fuzzy: true }) : number;
const article = articles[parsedNumber - 1];
if (parsedNumber > articles.length) {
alanBtn().playText('Please try that again...');
} else if (article) {
window.open(article.url, '_blank');
alanBtn().playText('Opening...');
} else {
alanBtn().playText('Please try that again...');
}
}
},
});
}, []);
return (
<div>
<div className={classes.logoContainer}>
{newsArticles.length ? (
<div className={classes.infoContainer}>
<div className={classes.card}><Typography variant="h5" component="h2">Try saying: <br /><br />Open article number [4]</Typography></div>
<div className={classes.card}><Typography variant="h5" component="h2">Try saying: <br /><br />Go back</Typography></div>
</div>
) : null}
<img src={cheetah} className={classes.alanLogo} alt="logo" />
</div>
<NewsCards articles={newsArticles} activeArticle={activeArticle} />
<Modal isOpen={isOpen} setIsOpen={setIsOpen} />
{!newsArticles.length ? (
<div className={classes.footer}>
<Typography variant="body1" component="h2">
Created by
<a className={classes.link} href="https://naveen-g09.github.io/naveen/"> Naveen Gummella</a>
</Typography>
<img className={classes.image} src={logo} height="50px" alt="cheetah logo" />
</div>
) : null}
</div>
);
};
export default App;