Ivan - Add articles in user dashboard [skip ci]

This commit is contained in:
Ivan Diaz 2016-12-03 20:26:57 -03:00
parent e676330334
commit 17f809aeca
7 changed files with 103 additions and 13 deletions

View File

@ -16,6 +16,7 @@ class ArticlesList extends React.Component {
static propTypes = { static propTypes = {
editable: React.PropTypes.bool, editable: React.PropTypes.bool,
articlePath: React.PropTypes.string,
loading: React.PropTypes.bool, loading: React.PropTypes.bool,
topics: React.PropTypes.array topics: React.PropTypes.array
}; };
@ -47,7 +48,11 @@ class ArticlesList extends React.Component {
{this.props.topics.map((topic, index) => { {this.props.topics.map((topic, index) => {
return ( return (
<div key={index}> <div key={index}>
<TopicViewer {...topic} editable={this.props.editable} onChange={this.retrieveArticles.bind(this)}/> <TopicViewer
{...topic}
editable={this.props.editable}
onChange={this.retrieveArticles.bind(this)}
articlePath={this.props.articlePath} />
<span className="articles-list__topic-separator" /> <span className="articles-list__topic-separator" />
</div> </div>
); );

View File

@ -45,11 +45,7 @@ class TopicViewer extends React.Component {
</div> </div>
<ul className="topic-viewer__list"> <ul className="topic-viewer__list">
{this.state.articles.map(this.renderArticleItem.bind(this))} {this.state.articles.map(this.renderArticleItem.bind(this))}
<li className="topic-viewer__list-item"> {(this.props.editable) ? this.renderAddNewArticle() : null}
<Button type="link" className="topic-viewer__add-item" onClick={() => ModalContainer.openModal(this.renderAddNewArticle())}>
{i18n('ADD_NEW_ARTICLE')}
</Button>
</li>
</ul> </ul>
</div> </div>
); );
@ -81,6 +77,16 @@ class TopicViewer extends React.Component {
); );
} }
renderAddNewArticle() {
return (
<li className="topic-viewer__list-item">
<Button type="link" className="topic-viewer__add-item" onClick={() => ModalContainer.openModal(this.renderAddNewArticleModal())}>
{i18n('ADD_NEW_ARTICLE')}
</Button>
</li>
);
}
renderEditModal() { renderEditModal() {
let props = { let props = {
topicId: this.props.id, topicId: this.props.id,
@ -96,7 +102,7 @@ class TopicViewer extends React.Component {
); );
} }
renderAddNewArticle() { renderAddNewArticleModal() {
let props = { let props = {
topicId: this.props.id, topicId: this.props.id,
position: this.props.articles.length, position: this.props.articles.length,

View File

@ -66,7 +66,7 @@ export default (
<Route path='create-ticket' component={DashboardCreateTicketPage}/> <Route path='create-ticket' component={DashboardCreateTicketPage}/>
<Route path='edit-profile' component={DashboardEditProfilePage}/> <Route path='edit-profile' component={DashboardEditProfilePage}/>
<Route path='article' component={DashboardArticlePage}/> <Route path='article/:articleId' component={DashboardArticlePage}/>
<Route path='ticket/:ticketNumber' component={DashboardTicketPage}/> <Route path='ticket/:ticketNumber' component={DashboardTicketPage}/>
</Route> </Route>
</Route> </Route>

View File

@ -1,14 +1,80 @@
import React from 'react'; import React from 'react';
import _ from 'lodash';
import {connect} from 'react-redux';
import ArticlesActions from 'actions/articles-actions';
import SessionStore from 'lib-app/session-store';
import i18n from 'lib-app/i18n';
import DateTransformer from 'lib-core/date-transformer';
import Header from 'core-components/header';
import Loading from 'core-components/loading';
class DashboardArticlePage extends React.Component { class DashboardArticlePage extends React.Component {
static propTypes = {
topics: React.PropTypes.array,
loading: React.PropTypes.bool
};
static defaultProps = {
topics: [],
loading: true
};
componentDidMount() {
if(SessionStore.getItem('topics')) {
this.props.dispatch(ArticlesActions.initArticles());
} else {
this.props.dispatch(ArticlesActions.retrieveArticles());
}
}
render() { render() {
return ( return (
<div> <div className="dashboard-article-page">
DASHBOARD ARTICLE {(this.props.loading) ? <Loading /> : this.renderContent()}
</div> </div>
); );
} }
renderContent() {
let article = this.findArticle();
return (article) ? this.renderArticlePreview(article) : i18n('ARTICLE_NOT_FOUND');
}
renderArticlePreview(article) {
return (
<div className="dashboard-article-page__article">
<Header title={article.title}/>
<div className="dashboard-article-page__article-content">
<div dangerouslySetInnerHTML={{__html: article.content}}/>
</div>
<div className="dashboard-article-page__last-edited">
{i18n('LAST_EDITED_IN', {date: DateTransformer.transformToString(article.lastEdited)})}
</div>
</div>
);
}
findArticle() {
let article = null;
_.forEach(this.props.topics, (topic) => {
if(!article) {
article = _.find(topic.articles, {id: this.props.params.articleId * 1});
}
});
return article;
}
} }
export default DashboardArticlePage; export default connect((store) => {
return {
topics: store.articles.topics,
loading: store.articles.loading
};
})(DashboardArticlePage);

View File

@ -0,0 +1,8 @@
.dashboard-article-page {
&__last-edited {
font-style: italic;
text-align: right;
margin-top: 20px;
}
}

View File

@ -1,11 +1,16 @@
import React from 'react'; import React from 'react';
import i18n from 'lib-app/i18n';
import ArticlesList from 'app-components/articles-list';
import Header from 'core-components/header';
class DashboardListArticlesPage extends React.Component { class DashboardListArticlesPage extends React.Component {
render() { render() {
return ( return (
<div> <div>
DASHBOARD ARTICLES LIST <Header title={i18n('LIST_ARTICLES')} description={i18n('LIST_ARTICLES_DESCRIPTION')}/>
<ArticlesList editable={false} articlePath="/dashboard/article/"/>
</div> </div>
); );
} }

View File

@ -42,7 +42,7 @@ export default {
'CUSTOM_RESPONSES': 'Custom Responses', 'CUSTOM_RESPONSES': 'Custom Responses',
'LIST_USERS': 'List Users', 'LIST_USERS': 'List Users',
'BAN_USERS': 'Ban Users', 'BAN_USERS': 'Ban Users',
'LIST_ARTICLES': 'List Articles', 'LIST_ARTICLES': 'Article List',
'STAFF_MEMBERS': 'Staff Members', 'STAFF_MEMBERS': 'Staff Members',
'DEPARTMENTS': 'Departments', 'DEPARTMENTS': 'Departments',
'SYSTEM_PREFERENCES': 'System Preferences', 'SYSTEM_PREFERENCES': 'System Preferences',