diff --git a/app/components/App.jsx b/app/components/App.jsx index 4ed4c9c46..1d217e0d3 100644 --- a/app/components/App.jsx +++ b/app/components/App.jsx @@ -12,7 +12,7 @@ import { createGlobalStyle } from 'styled-components' import AppPropTypes from 'app/utils/AppPropTypes'; import Header from 'app/components/modules/Header'; import Footer from 'app/components/modules/Footer'; -import AppReminder from 'app/components/elements/app/AppReminder' +import NewsPopups from 'app/components/elements/NewsPopups' import URLLoader from 'app/components/elements/app/URLLoader'; import TooltipManager from 'app/components/elements/common/TooltipManager'; import user from 'app/redux/User'; @@ -33,8 +33,6 @@ import { APP_ICON, VEST_TICKER, } from 'app/client_config'; import session from 'app/utils/session' import { loadGrayHideSettings } from 'app/utils/ContentAccess' -const APP_REMINDER_INTERVAL = 30*24*60*60*1000 - const GlobalStyle = createGlobalStyle` body { fill: currentColor; @@ -100,17 +98,6 @@ class App extends React.Component { } } - showAppReminder = () => { - if (process.env.IS_APP || typeof(localStorage) === 'undefined' - || location.pathname.startsWith('/submit')) { - return false - } - const now = Date.now() - let reminded = localStorage.getItem('app_reminder') || 0 - reminded = parseInt(reminded) - return !reminded || (now - reminded > APP_REMINDER_INTERVAL) - } - constructor(props) { super(props) if (process.env.BROWSER) { @@ -381,8 +368,6 @@ class App extends React.Component { const noHeader = isApp const noFooter = isApp || location.pathname.startsWith('/submit') - const reminder = this.showAppReminder() ? : null - return (
{children} {noFooter ? null :
} - {reminder} +
diff --git a/app/components/all.scss b/app/components/all.scss index d03054e88..aa90959f3 100644 --- a/app/components/all.scss +++ b/app/components/all.scss @@ -39,7 +39,7 @@ @import "./elements/VerticalMenu"; @import "./elements/VotesAndComments"; @import "./elements/Voting"; -@import "./elements/app/AppReminder"; +@import "./elements/NewsPopups"; @import "./elements/common/YoutubePlayer/YoutubePlayer"; @import "./elements/common/TelegramPlayer/TelegramPlayer"; @import "./elements/common/Button/index"; diff --git a/app/components/elements/NewsPopups.jsx b/app/components/elements/NewsPopups.jsx new file mode 100644 index 000000000..a153590bc --- /dev/null +++ b/app/components/elements/NewsPopups.jsx @@ -0,0 +1,179 @@ +import React from 'react' +import tt from 'counterpart' +import { connect } from 'react-redux' +import { api } from 'golos-lib-js' + +import CloseButton from 'react-foundation-components/lib/global/close-button' + +import user from 'app/redux/User' + +const APP_REMINDER_INTERVAL = 30*24*60*60*1000 + +class NewsPopups extends React.Component { + state = { + hidden: false, + hiddenNews: [] + } + + checkNews = async () => { + if (typeof(localStorage) === 'undefined') { + this.setState({ news: [] }) + return + } + try { + let news_read = localStorage.getItem('news_read') || '' + news_read = news_read.split(',') + if ($STM_Config.golos_news && $STM_Config.golos_news.account) { + const acc = $STM_Config.golos_news.account + const entries = await api.getBlogEntriesAsync(acc, 0, 5, ['fm-'], {}) + const news_to_load = [] + for (const post of entries) { + const { author, hashlink } = post + if (news_read.includes(hashlink)) { + continue + } + news_to_load.push({ + author, + hashlink + }) + } + if (news_to_load.length) { + const news = await api.getContentPreviewsAsync(news_to_load) + this.setState({ + news + }) + } else { + this.setState({ + news: [] + }) + } + } + } catch (err) { + console.error('NewsPopups', err) + this.setState({ + news: [] + }) + } + } + + componentDidMount() { + this.checkNews() + } + + hideMe = (i) => { + if (i) { + let { hiddenNews } = this.state + hiddenNews = [...hiddenNews] + hiddenNews.push(i) + this.setState({ + hiddenNews + }) + let news_read = localStorage.getItem('news_read') || '' + news_read = news_read.split(',') + news_read.push(i) + localStorage.setItem('news_read', news_read.join(',')) + return + } + const now = Date.now() + localStorage.setItem('app_reminder', now) + this.setState({ + hidden: true + }) + } + + openNew = (e, i, url) => { + e.preventDefault() + this.hideMe(i) + window.open(url, '_blank') + } + + showModal = (e) => { + e.preventDefault() + this.props.showModal() + this.hideMe() + } + + showAppReminder = () => { + if (process.env.IS_APP || typeof(localStorage) === 'undefined' + || location.pathname.startsWith('/submit')) { + return false + } + const now = Date.now() + let reminded = localStorage.getItem('app_reminder') || 0 + reminded = parseInt(reminded) + return !reminded || (now - reminded > APP_REMINDER_INTERVAL) + } + + render() { + const { news,hiddenNews } = this.state + + let appReminder = null + if (news && this.showAppReminder() && !this.state.hidden) { + appReminder = + { + e.stopPropagation() + this.hideMe() + }} + /> + {tt('app_reminder.text')} + + } + + let newItems = [] + if (news) { + let newCount = 0 + for (const ne of news) { + if (hiddenNews.includes(ne.hashlink)) { + continue + } + newCount++ + } + newCount -= 1 + for (const ne of news) { + if (hiddenNews.includes(ne.hashlink)) { + continue + } + let title = ne.title + if (title.length > 100) { + title = title.substring(0, 100) + '...' + } + let bottom = newCount * 65 + if (appReminder) { + bottom += 65 + } else { + bottom += 2 + } + newItems.push( this.openNew(e, ne.hashlink, ne.url)} target='_blank' rel='noopener noreferrer nofollow'> + + { + e.stopPropagation() + e.preventDefault() + this.hideMe(ne.hashlink) + }} + /> + {title} + + ) + --newCount + } + } + + return
+ {appReminder} + {newItems} +
+ } +} + +export default connect( + state => { + return {} + }, + dispatch => ({ + showModal: () => { + dispatch(user.actions.showAppDownload()) + } + }) +)(NewsPopups) diff --git a/app/components/elements/app/AppReminder.scss b/app/components/elements/NewsPopups.scss similarity index 95% rename from app/components/elements/app/AppReminder.scss rename to app/components/elements/NewsPopups.scss index 227071e5b..fe5c9b22a 100644 --- a/app/components/elements/app/AppReminder.scss +++ b/app/components/elements/NewsPopups.scss @@ -1,4 +1,4 @@ -.AppReminder { +.NewsPopups { @include themify($themes) { background-color: themed('modalReminder') !important; } diff --git a/app/components/elements/app/AppReminder.jsx b/app/components/elements/app/AppReminder.jsx deleted file mode 100644 index 7043fc288..000000000 --- a/app/components/elements/app/AppReminder.jsx +++ /dev/null @@ -1,53 +0,0 @@ -import React from 'react' -import tt from 'counterpart' -import { connect } from 'react-redux' - -import CloseButton from 'react-foundation-components/lib/global/close-button' - -import user from 'app/redux/User' - -class AppReminder extends React.Component { - state = { - hidden: false - } - - hideMe = () => { - const now = Date.now() - localStorage.setItem('app_reminder', now) - this.setState({ - hidden: true - }) - } - - showModal = (e) => { - e.preventDefault() - this.props.showModal() - this.hideMe() - } - - render() { - if (this.state.hidden) { - return null - } - return - { - e.stopPropagation() - this.hideMe() - }} - /> - {tt('app_reminder.text')} - - } -} - -export default connect( - state => { - return {} - }, - dispatch => ({ - showModal: () => { - dispatch(user.actions.showAppDownload()) - } - }) -)(AppReminder) diff --git a/config/default.json b/config/default.json index 3d0bc1949..cd6cab3be 100644 --- a/config/default.json +++ b/config/default.json @@ -58,6 +58,9 @@ "apidex_service": { "host": "https://api-dex.golos.app" }, + "golos_news": { + "account": "progolos" + }, "forums": { "white_list": ["fm-golostalk", "fm-prizmtalk", "fm-graphenetalks"], "fm-golostalk": {"domain": "golostalk.com"}, diff --git a/server/index.js b/server/index.js index 8ad28a7e7..c325c4a3e 100755 --- a/server/index.js +++ b/server/index.js @@ -46,6 +46,9 @@ global.$STM_Config = { wallet_service: config.get('wallet_service'), messenger_service: config.get('messenger_service'), apidex_service: config.get('apidex_service'), + golos_news: config.has('golos_news') ? config.get('golos_news') : { + account: 'progolos' + }, forums: config.get('forums'), blocked_users, blocked_posts,