start to restyle share modal

This commit is contained in:
Cassie Tarakajian 2017-10-30 14:38:41 -04:00
parent fd284358c2
commit d48d9349a8
8 changed files with 110 additions and 38 deletions

View file

@ -0,0 +1,47 @@
import React, { PropTypes } from 'react';
import Clipboard from 'clipboard';
class CopyableInput extends React.Component {
componentDidMount() {
this.clipboard = new Clipboard(this.input, {
target: () => this.input
});
}
componentWillUnmount() {
this.clipboard.destroy();
}
render() {
const {
label,
value
} = this.props;
return (
<div className="copyable-input">
<label className="copyable-input__label" htmlFor="copyable-input__value">{label}</label>
<div className="copyable-input__value-container">
<input
type="text"
className="copyable-input__value"
id="copyable-input__value"
value={value}
ref={(element) => { this.input = element; }}
/>
<span
className="copyable-input__tooltip tooltipped tooltipped-n"
aria-label="Copyied to Clipboard!"
>
</span>
</div>
</div>
);
}
}
CopyableInput.propTypes = {
label: PropTypes.string.isRequired,
value: PropTypes.string.isRequired
};
export default CopyableInput;

View file

@ -1,47 +1,40 @@
import React, { PropTypes } from 'react'; import React, { PropTypes } from 'react';
import CopyableInput from './CopyableInput';
function ShareModal(props) { class ShareModal extends React.PureComponent {
const { render() {
projectId, const {
ownerUsername projectId,
} = props; ownerUsername,
const hostname = window.location.origin; projectName
return ( } = this.props;
<div className="share-modal"> const hostname = window.location.origin;
<div className="share-modal__section"> return (
<label className="share-modal__label" htmlFor="share-modal__embed">Embed</label> <div className="share-modal">
<input <h3 className="share-modal__project-name">
type="text" {projectName}
className="share-modal__input" </h3>
id="share-modal__embed" <CopyableInput
label="Embed"
value={`<iframe src="${hostname}/embed/${projectId}"></iframe>`} value={`<iframe src="${hostname}/embed/${projectId}"></iframe>`}
/> />
</div> <CopyableInput
<div className="share-modal__section"> label="Fullscreen"
<label className="share-modal__label" htmlFor="share-modal__fullscreen">Fullscreen</label>
<input
type="text"
className="share-modal__input"
id="share-modal__fullscreen"
value={`${hostname}/full/${projectId}`} value={`${hostname}/full/${projectId}`}
/> />
</div> <CopyableInput
<div className="share-modal__section"> label="Edit"
<label className="share-modal__label" htmlFor="share-modal__edit">Edit</label>
<input
type="text"
className="share-modal__input"
id="share-modal__edit"
value={`${hostname}/${ownerUsername}/sketches/${projectId}`} value={`${hostname}/${ownerUsername}/sketches/${projectId}`}
/> />
</div> </div>
</div> );
); }
} }
ShareModal.propTypes = { ShareModal.propTypes = {
projectId: PropTypes.string.isRequired, projectId: PropTypes.string.isRequired,
ownerUsername: PropTypes.string.isRequired ownerUsername: PropTypes.string.isRequired,
projectName: PropTypes.string.isRequired
}; };
export default ShareModal; export default ShareModal;

View file

@ -477,12 +477,13 @@ class IDEView extends React.Component {
if (this.props.ide.shareModalVisible) { if (this.props.ide.shareModalVisible) {
return ( return (
<Overlay <Overlay
title="Share Sketch" title="Share This Sketch"
ariaLabel="share" ariaLabel="share"
closeOverlay={this.props.closeShareModal} closeOverlay={this.props.closeShareModal}
> >
<ShareModal <ShareModal
projectId={this.props.project.id} projectId={this.props.project.id}
projectName={this.props.project.name}
ownerUsername={this.props.project.owner.username} ownerUsername={this.props.project.owner.username}
/> />
</Overlay> </Overlay>

View file

@ -0,0 +1,11 @@
.copyable-input__value-container {
position: relative;
}
.copyable-input__tooltip {
position: absolute;
top: 0;
left: 0;
bottom: 0;
right: 0;
}

View file

@ -29,11 +29,15 @@
.overlay__header { .overlay__header {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
padding: #{40 / $base-font-size}rem #{20 / $base-font-size}rem #{30 / $base-font-size}rem #{20 / $base-font-size}rem; padding: #{30 / $base-font-size}rem #{20 / $base-font-size}rem #{30 / $base-font-size}rem #{20 / $base-font-size}rem;
flex: 1 0 auto; flex: 1 0 auto;
} }
.overlay__title {
font-size: #{21 / $base-font-size}rem;
}
.overlay__close-button { .overlay__close-button {
@include icon(); @include icon();
padding: #{12 / $base-font-size}rem #{16 / $base-font-size}rem; padding: #{3 / $base-font-size}rem 0;
} }

View file

@ -1,8 +1,14 @@
.share-modal { .share-modal {
padding: #{20 / $base-font-size}rem; padding: #{20 / $base-font-size}rem;
padding-top: 0;
width: #{500 / $base-font-size}rem; width: #{500 / $base-font-size}rem;
} }
.share-modal__project-name {
padding-bottom: #{20 / $base-font-size}rem;
font-size: #{16 / $base-font-size}rem;
}
.share-modal__header { .share-modal__header {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
@ -11,14 +17,20 @@
.share-modal__section { .share-modal__section {
width: 100%; width: 100%;
display: flex; display: flex;
align-items: center; flex-wrap: wrap;
padding: #{10 / $base-font-size}rem 0; padding: #{10 / $base-font-size}rem 0;
} }
.share-modal__label { .share-modal__label {
width: #{86 / $base-font-size}rem; width: 100%;
font-size: #{12 / $base-font-size}rem;
padding-bottom: #{3 / $base-font-size}rem;
@include themify() {
color: getThemifyVariable('inactive-text-color');
}
} }
.share-modal__input { .share-modal__input {
flex: 1; width: 100%;
font-size: #{16 / $base-font-size}rem;
} }

View file

@ -9,6 +9,7 @@
@import 'vendors/codemirror'; @import 'vendors/codemirror';
@import 'vendors/lint'; @import 'vendors/lint';
@import 'vendors/dropzone'; @import 'vendors/dropzone';
@import 'node_modules/primer-tooltips/build/build';
@import 'components/p5-light-codemirror-theme'; @import 'components/p5-light-codemirror-theme';
@import 'components/p5-dark-codemirror-theme'; @import 'components/p5-dark-codemirror-theme';
@ -37,6 +38,7 @@
@import 'components/share'; @import 'components/share';
@import 'components/asset-list'; @import 'components/asset-list';
@import 'components/keyboard-shortcuts'; @import 'components/keyboard-shortcuts';
@import 'components/copyable-input';
@import 'layout/ide'; @import 'layout/ide';
@import 'layout/fullscreen'; @import 'layout/fullscreen';

View file

@ -66,6 +66,7 @@
"body-parser": "^1.15.1", "body-parser": "^1.15.1",
"bson-objectid": "^1.1.4", "bson-objectid": "^1.1.4",
"classnames": "^2.2.5", "classnames": "^2.2.5",
"clipboard": "^1.7.1",
"codemirror": "^5.21.0", "codemirror": "^5.21.0",
"connect-mongo": "^1.2.0", "connect-mongo": "^1.2.0",
"cookie-parser": "^1.4.1", "cookie-parser": "^1.4.1",
@ -82,8 +83,8 @@
"file-type": "^3.8.0", "file-type": "^3.8.0",
"fs-promise": "^1.0.0", "fs-promise": "^1.0.0",
"htmlhint": "^0.9.13", "htmlhint": "^0.9.13",
"is_js": "^0.9.0",
"is-url": "^1.2.2", "is-url": "^1.2.2",
"is_js": "^0.9.0",
"js-beautify": "^1.6.4", "js-beautify": "^1.6.4",
"jsdom": "^9.8.3", "jsdom": "^9.8.3",
"jshint": "^2.9.4", "jshint": "^2.9.4",
@ -99,6 +100,7 @@
"passport-github": "^1.1.0", "passport-github": "^1.1.0",
"passport-local": "^1.0.0", "passport-local": "^1.0.0",
"pretty-bytes": "^3.0.1", "pretty-bytes": "^3.0.1",
"primer-tooltips": "^1.4.1",
"project-name-generator": "^2.1.3", "project-name-generator": "^2.1.3",
"pug": "^2.0.0-beta6", "pug": "^2.0.0-beta6",
"q": "^1.4.1", "q": "^1.4.1",