upload.js 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. import React from 'react';
  2. import ImmutablePropTypes from 'react-immutable-proptypes';
  3. import PropTypes from 'prop-types';
  4. import Motion from '../../ui/util/optional_motion';
  5. import spring from 'react-motion/lib/spring';
  6. import ImmutablePureComponent from 'react-immutable-pure-component';
  7. import { FormattedMessage } from 'react-intl';
  8. import Icon from 'mastodon/components/icon';
  9. export default class Upload extends ImmutablePureComponent {
  10. static contextTypes = {
  11. router: PropTypes.object,
  12. };
  13. static propTypes = {
  14. media: ImmutablePropTypes.map.isRequired,
  15. onUndo: PropTypes.func.isRequired,
  16. onOpenFocalPoint: PropTypes.func.isRequired,
  17. isEditingStatus: PropTypes.bool.isRequired,
  18. };
  19. handleUndoClick = e => {
  20. e.stopPropagation();
  21. this.props.onUndo(this.props.media.get('id'));
  22. }
  23. handleFocalPointClick = e => {
  24. e.stopPropagation();
  25. this.props.onOpenFocalPoint(this.props.media.get('id'));
  26. }
  27. render () {
  28. const { media, isEditingStatus } = this.props;
  29. const focusX = media.getIn(['meta', 'focus', 'x']);
  30. const focusY = media.getIn(['meta', 'focus', 'y']);
  31. const x = ((focusX / 2) + .5) * 100;
  32. const y = ((focusY / -2) + .5) * 100;
  33. return (
  34. <div className='compose-form__upload' tabIndex='0' role='button'>
  35. <Motion defaultStyle={{ scale: 0.8 }} style={{ scale: spring(1, { stiffness: 180, damping: 12 }) }}>
  36. {({ scale }) => (
  37. <div className='compose-form__upload-thumbnail' style={{ transform: `scale(${scale})`, backgroundImage: `url(${media.get('preview_url')})`, backgroundPosition: `${x}% ${y}%` }}>
  38. <div className='compose-form__upload__actions'>
  39. <button type='button' className='icon-button' onClick={this.handleUndoClick}><Icon id='times' /> <FormattedMessage id='upload_form.undo' defaultMessage='Delete' /></button>
  40. {!isEditingStatus && (<button type='button' className='icon-button' onClick={this.handleFocalPointClick}><Icon id='pencil' /> <FormattedMessage id='upload_form.edit' defaultMessage='Edit' /></button>)}
  41. </div>
  42. {(media.get('description') || '').length === 0 && (
  43. <div className='compose-form__upload__warning'>
  44. <button type='button' className='icon-button' onClick={this.handleFocalPointClick}><Icon id='info-circle' /> <FormattedMessage id='upload_form.description_missing' defaultMessage='No description added' /></button>
  45. </div>
  46. )}
  47. </div>
  48. )}
  49. </Motion>
  50. </div>
  51. );
  52. }
  53. }