diff --git a/src/assets/stylesheets/scene-ui.scss b/src/assets/stylesheets/scene-ui.scss index aa9a809de55b22e1d36abd51a6a9e9b7fe7c82ab..99f3ddae3255817ec0d7ad22e2bd15a4fa6d9a7f 100644 --- a/src/assets/stylesheets/scene-ui.scss +++ b/src/assets/stylesheets/scene-ui.scss @@ -91,6 +91,12 @@ :local(.attribution) { font-size: 1.0em; white-space: wrap; + + a { + font-size: 0.8em; + color: black; + pointer-events: auto; + } } :local(.screenshot) { diff --git a/src/react-components/scene-ui.js b/src/react-components/scene-ui.js index cb724d21b5cac27bc15807e4e80a82b13d94e50a..168c6d517c68ee4f3520c2ea7fb770c45417eb1d 100644 --- a/src/react-components/scene-ui.js +++ b/src/react-components/scene-ui.js @@ -23,7 +23,7 @@ class SceneUI extends Component { sceneId: PropTypes.string, sceneName: PropTypes.string, sceneDescription: PropTypes.string, - sceneAttribution: PropTypes.string, + sceneAttributions: PropTypes.object, sceneScreenshotURL: PropTypes.string }; @@ -77,6 +77,47 @@ class SceneUI extends Component { tweetText )}`; + let attributions; + + const toAttributionSpan = a => { + if (a.url) { + const source = a.url.indexOf("sketchfab.com") + ? "on Sketchfab" + : a.url.indexOf("poly.google.com") + ? "on Google Poly" + : ""; + + return ( + <span key={a.url}> + <a href={a.url} target="_blank" rel="noopener noreferrer"> + {a.name} by {a.author} {source} + </a> + </span> + ); + } else { + return ( + <span key={`${a.name} ${a.author}`}> + {a.name} by {a.author} + </span> + ); + } + }; + + if (this.props.sceneAttributions) { + if (!this.props.sceneAttributions.extras) { + attributions = ( + <span> + <span>by {this.props.sceneAttributions.creator}</span> + <br /> + {this.props.sceneAttributions.content && this.props.sceneAttributions.content.map(toAttributionSpan)} + </span> + ); + } else { + // Legacy + attributions = <span>{this.props.sceneAttributions.extras}</span>; + } + } + return ( <IntlProvider locale={lang} messages={messages}> <div className={styles.ui}> @@ -115,7 +156,7 @@ class SceneUI extends Component { </div> <div className={styles.info}> <div className={styles.name}>{this.props.sceneName}</div> - <div className={styles.attribution}>{this.props.sceneAttribution}</div> + <div className={styles.attribution}>{attributions}</div> </div> <div className={styles.spoke}> <div className={styles.madeWith}>made with</div> diff --git a/src/scene.js b/src/scene.js index 6f2f0732d0da231b0bebef56b8ce526326aa5ea4..4172e624771d7fbd3ca5ce217052023ed113c930 100644 --- a/src/scene.js +++ b/src/scene.js @@ -102,7 +102,7 @@ const onReady = async () => { remountUI({ sceneName: sceneInfo.name, sceneDescription: sceneInfo.description, - sceneAttribution: sceneInfo.attribution, + sceneAttributions: sceneInfo.attributions, sceneScreenshotURL: sceneInfo.screenshot_url }); };