Vulcan/packages/nova-embedly/lib/components/ThumbnailURL.jsx
Comus Leong 464e20a96c eslint & clean up code, also fixed some bugs (#1515)
* [eslint] update eslint rules & add .eslintignore to ignore non-ready nova packages

* [clean-up] nova-voting

* [clean-up] [bug] nova-users: missing user parameter

* [clean-up] nova-users

* [clean-up] nova-subscribe

* [clean-up] nova-settings

* [clean-up] nova-rss

* [clean-up] [bug] nova-posts: correct UsersRemoveDeletePosts

* [clean-up] nova-posts

* [clean-up] nova-notifications

* [clean-up] [bug] nova-newsletter: no error.message on throw error

* [clean-up] nova-newsletter

* [clean-up] nova-lib

* [clean-up] nova-kadira

* [clean-up] nova-inject-data

* [clean-up] nova-getting-started

* [clean-up] nova-forms

* [clean-up] nova-events

* [clean-up] [bug] nova-embedly: no FlowRouter

* [clean-up] nova-embedly

* [clean-up] nova-email-templates

* [clean-up] nova-email

* [clean-up] nova-debug

* [clean-up] nova-core

* [clean-up] [bug] nova-comments: correct UsersRemoveDeleteComments

* [clean-up] nova-comments

* [clean-up] [bug] nova-cloudinary: use Telescope.settings.collection instand

* [clean-up] nova-cloudinary

* [clean-up] nova-categories

* [clean-up] nova-base-components

* [clean-up] nova-api

* [eslint] extends react recommended

* [clean-up] for jsx files

* [eslint] extends meteor recommended

* i forgot this one little change
2016-11-25 13:46:55 -05:00

76 lines
2 KiB
JavaScript

import Telescope from 'meteor/nova:lib';
import React, { PropTypes, Component } from 'react';
import { FormattedMessage } from 'react-intl';
// import Formsy from 'formsy-react';
import FRC from 'formsy-react-components';
const Input = FRC.Input;
class ThumbnailURL extends Component {
constructor(props) {
super(props);
this.clearThumbnail = this.clearThumbnail.bind(this);
this.showInput = this.showInput.bind(this);
this.state = {
showInput: false
};
}
clearThumbnail() {
this.context.updateCurrentValue("thumbnailUrl", "");
}
showInput() {
this.setState({
showInput: true
});
}
renderThumbnail() {
return (
<div>
<img
className="embedly-thumbnail"
src={this.props.value}
style={{
"width": 150,
"height": Telescope.settings.get('thumbnailHeight', 150) * 150 / Telescope.settings.get('thumbnailWidth', 150)
}}
/>
<a className="thumbnail-url-clear" onClick={this.clearThumbnail}><FormattedMessage id="posts.clear_thumbnail"/></a>
</div>
)
}
render() {
const {name, /* value, */ label} = this.props;
const inputType = this.state.showInput ? "text" : "hidden";
return (
<div className="form-group row">
<label className="control-label col-sm-3">{label}</label>
<div className="col-sm-9">
{this.props.value ? this.renderThumbnail() : null}
<Input layout="elementOnly" name={name} type={inputType} value={this.props.value} />
{!this.state.showInput ? <a className="thumbnail-show-input" onClick={this.showInput}><FormattedMessage id="posts.enter_thumbnail_url"/></a> : null}
</div>
</div>
)
}
}
ThumbnailURL.propTypes = {
name: React.PropTypes.string,
value: React.PropTypes.any,
label: React.PropTypes.string
}
ThumbnailURL.contextTypes = {
addToPrefilledValues: React.PropTypes.func,
updateCurrentValue: React.PropTypes.func,
deleteValue: React.PropTypes.func
}
export default ThumbnailURL;