start to restyle share modal
This commit is contained in:
		
							parent
							
								
									fd284358c2
								
							
						
					
					
						commit
						d48d9349a8
					
				
					 8 changed files with 110 additions and 38 deletions
				
			
		
							
								
								
									
										47
									
								
								client/modules/IDE/components/CopyableInput.jsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								client/modules/IDE/components/CopyableInput.jsx
									
									
									
									
									
										Normal 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; | ||||||
|  | @ -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; | ||||||
|  |  | ||||||
|  | @ -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> | ||||||
|  |  | ||||||
							
								
								
									
										11
									
								
								client/styles/components/_copyable-input.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								client/styles/components/_copyable-input.scss
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,11 @@ | ||||||
|  | .copyable-input__value-container { | ||||||
|  |   position: relative; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .copyable-input__tooltip { | ||||||
|  |   position: absolute; | ||||||
|  |   top: 0; | ||||||
|  |   left: 0; | ||||||
|  |   bottom: 0; | ||||||
|  |   right: 0; | ||||||
|  | } | ||||||
|  | @ -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; | ||||||
| } | } | ||||||
|  | @ -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; | ||||||
| } | } | ||||||
|  | @ -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'; | ||||||
|  |  | ||||||
|  | @ -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", | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Cassie Tarakajian
						Cassie Tarakajian