mirror of
https://github.com/dscalzi/HeliosLauncher.git
synced 2025-01-21 18:32:12 -08:00
Move landing media buttons to their own component.
The media buttons can either open a link or perform an action. TODO: Convert CSS from px to rem.
This commit is contained in:
parent
e86992a7ee
commit
6a04ef0f62
@ -288,6 +288,7 @@ class Application extends React.Component<InternalApplicationProps, ApplicationS
|
||||
|
||||
// Pick a background id.
|
||||
this.bkid = Math.floor((Math.random() * (await readdir(join(__static, 'images', 'backgrounds'))).length))
|
||||
this.bkid = 3 // TEMP
|
||||
|
||||
const endLoad = () => {
|
||||
// TODO determine correct view
|
||||
@ -310,11 +311,11 @@ class Application extends React.Component<InternalApplicationProps, ApplicationS
|
||||
// console.log(serverStatus)
|
||||
// }
|
||||
// })
|
||||
this.props.pushGenericOverlay({
|
||||
title: 'Test Title 2',
|
||||
description: 'Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt.',
|
||||
dismissible: true
|
||||
})
|
||||
// this.props.pushGenericOverlay({
|
||||
// title: 'Test Title 2',
|
||||
// description: 'Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt.',
|
||||
// dismissible: true
|
||||
// })
|
||||
// this.props.pushGenericOverlay({
|
||||
// title: 'Test Title IMPORTANT',
|
||||
// description: 'Test Description',
|
||||
|
@ -297,14 +297,6 @@
|
||||
flex-direction: column;
|
||||
}
|
||||
|
||||
/* Container object which wraps an icon to ensure fluid transitions. */
|
||||
.mediaContainer {
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
height: 27px;
|
||||
}
|
||||
|
||||
/* Divider bar between the external and internal icons. */
|
||||
.mediaDivider {
|
||||
height: 1px;
|
||||
@ -313,122 +305,6 @@
|
||||
margin: 10px 0;
|
||||
}
|
||||
|
||||
/* Social media icon shared styles. */
|
||||
.mediaSVG {
|
||||
fill: #ffffff;
|
||||
height: 12px;
|
||||
transition: 0.25s ease;
|
||||
cursor: pointer;
|
||||
height: 12px;
|
||||
width: 25px;
|
||||
}
|
||||
.mediaSVG:hover,
|
||||
.mediaURL:focus .mediaSVG,
|
||||
.mediaSVG:active {
|
||||
height: 20px;
|
||||
}
|
||||
|
||||
/* Social media URL shared styles. */
|
||||
.mediaURL {
|
||||
outline: none;
|
||||
}
|
||||
|
||||
/* Internal media button shared styles. */
|
||||
.mediaButton {
|
||||
background: none;
|
||||
border: none;
|
||||
padding: 0;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
outline: none;
|
||||
}
|
||||
|
||||
#settingsMediaContainer {
|
||||
position: relative;
|
||||
}
|
||||
|
||||
/* Settings icon colors. */
|
||||
#settingsSVG {
|
||||
stroke: #ffffff;
|
||||
height: 15px;
|
||||
}
|
||||
.mediaButton:hover #settingsSVG,
|
||||
.mediaButton:focus #settingsSVG,
|
||||
.mediaButton:active #settingsSVG {
|
||||
height: 23px;
|
||||
}
|
||||
|
||||
/* Settings tooltip styles. */
|
||||
#settingsTooltip {
|
||||
visibility: hidden;
|
||||
opacity: 0;
|
||||
width: 75px;
|
||||
height: 20px;
|
||||
background-color: rgba(0, 0, 0, 0.75);
|
||||
text-align: center;
|
||||
border-radius: 4px;
|
||||
position: absolute;
|
||||
z-index: 1;
|
||||
right: 130%;
|
||||
font-size: 12px;
|
||||
line-height: 20px;
|
||||
transition: visibility 0s linear 0.25s, opacity 0.25s ease;
|
||||
}
|
||||
#settingsTooltip::after {
|
||||
content: " ";
|
||||
position: absolute;
|
||||
top: 50%;
|
||||
left: 100%;
|
||||
margin-top: -5px;
|
||||
border-width: 5px;
|
||||
border-style: solid;
|
||||
border-color: transparent transparent transparent rgba(0, 0, 0, 0.75);
|
||||
}
|
||||
.mediaButton:hover #settingsTooltip,
|
||||
.mediaButton:focus #settingsTooltip,
|
||||
.mediaButton:active #settingsTooltip {
|
||||
visibility: visible;
|
||||
opacity: 1;
|
||||
transition-delay:0s;
|
||||
}
|
||||
|
||||
/* Twitter icon colors. */
|
||||
#twitterSVG:hover,
|
||||
#twitterURL:focus #twitterSVG {
|
||||
fill: #1da1f2;
|
||||
}
|
||||
#twitterSVG:active {
|
||||
fill: #1b8dd4;
|
||||
}
|
||||
|
||||
/* Instagram icon colors. */
|
||||
#instagramSVG:hover,
|
||||
#instagramURL:focus #instagramSVG {
|
||||
fill: url('#instaFill')
|
||||
/*fill: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285AEB 90%); */
|
||||
}
|
||||
#instagramSVG:active {
|
||||
fill: url('#instaFill')
|
||||
}
|
||||
|
||||
/* Youtube icon colors. */
|
||||
#youtubeSVG:hover,
|
||||
#youtubeURL:focus #youtubeSVG {
|
||||
fill: #f00;
|
||||
}
|
||||
#youtubeSVG:active {
|
||||
fill: #ea0202;
|
||||
}
|
||||
|
||||
/* Discord icon colors. */
|
||||
#discordSVG:hover,
|
||||
#discordURL:focus #discordSVG {
|
||||
fill: #7288d9;
|
||||
}
|
||||
#discordSVG:active {
|
||||
fill: #657ac4;
|
||||
}
|
||||
|
||||
/*******************************************************************************
|
||||
* *
|
||||
* Landing View (Bottom Styles) *
|
||||
|
@ -11,6 +11,7 @@ import { MojangStatus, MojangStatusColor } from 'common/mojang/rest/internal/Moj
|
||||
import { MojangRestAPI } from 'common/mojang/rest/MojangRestAPI'
|
||||
import { LoggerUtil } from 'common/logging/loggerutil'
|
||||
|
||||
import { MediaButton, MediaButtonType } from './mediabutton/MediaButton'
|
||||
import News from '../news/News'
|
||||
|
||||
import './Landing.css'
|
||||
@ -137,6 +138,55 @@ class Landing extends React.Component<InternalLandingProps, LandingState> {
|
||||
}
|
||||
}
|
||||
|
||||
private readonly mediaButtons = [
|
||||
{
|
||||
href: 'https://github.com/dscalzi/HeliosLauncher',
|
||||
type: MediaButtonType.LINK,
|
||||
disabled: false
|
||||
},
|
||||
{
|
||||
href: '#',
|
||||
type: MediaButtonType.TWITTER,
|
||||
disabled: true
|
||||
},
|
||||
{
|
||||
href: '#',
|
||||
type: MediaButtonType.INSTAGRAM,
|
||||
disabled: true
|
||||
},
|
||||
{
|
||||
href: '#',
|
||||
type: MediaButtonType.YOUTUBE,
|
||||
disabled: true
|
||||
},
|
||||
{
|
||||
href: 'https://discord.gg/zNWUXdt',
|
||||
type: MediaButtonType.DISCORD,
|
||||
disabled: false,
|
||||
tooltip: 'Discord'
|
||||
}
|
||||
]
|
||||
|
||||
private getExternalMediaButtons = (): JSX.Element[] => {
|
||||
const ret: JSX.Element[] = []
|
||||
for(const { href, type, disabled, tooltip } of this.mediaButtons) {
|
||||
ret.push(
|
||||
<MediaButton
|
||||
key={`${type.toLowerCase()}LandingButton`}
|
||||
href={href}
|
||||
type={type}
|
||||
disabled={disabled}
|
||||
tooltip={tooltip}
|
||||
/>
|
||||
)
|
||||
}
|
||||
return ret
|
||||
}
|
||||
|
||||
private onSettingsClick = async (): Promise<void> => {
|
||||
console.log('Settings clicked')
|
||||
}
|
||||
|
||||
/* Render */
|
||||
|
||||
render(): JSX.Element {
|
||||
@ -162,74 +212,15 @@ class Landing extends React.Component<InternalLandingProps, LandingState> {
|
||||
</div>
|
||||
<div id="mediaContent">
|
||||
<div id="internalMedia">
|
||||
<div className="mediaContainer" id="settingsMediaContainer">
|
||||
<button className="mediaButton" id="settingsMediaButton">
|
||||
<svg id="settingsSVG" className="mediaSVG" viewBox="0 0 141.36 137.43">
|
||||
<path d="M70.70475616319865,83.36934004916053 a15.320781354859122,15.320781354859122 0 1 1 14.454501310561755,-15.296030496450625 A14.850515045097694,14.850515045097694 0 0 1 70.70475616319865,83.36934004916053 M123.25082856443602,55.425620905968366 h-12.375429204248078 A45.54157947163293,45.54157947163293 0 0 0 107.21227231573047,46.243052436416285 l8.613298726156664,-9.108315894326587 a9.727087354538993,9.727087354538993 0 0 0 0,-13.167456673319956 l-3.465120177189462,-3.6631270444574313 a8.489544434114185,8.489544434114185 0 0 0 -12.375429204248078,0 l-8.613298726156664,9.108315894326587 A40.442902639482725,40.442902639482725 0 0 0 81.99114759747292,25.427580514871032 V12.532383284044531 a9.108315894326587,9.108315894326587 0 0 0 -8.811305593424633,-9.306322761594556 h-4.950171681699231 a9.108315894326587,9.108315894326587 0 0 0 -8.811305593424633,9.306322761594556 v12.895197230826497 a40.17064319698927,40.17064319698927 0 0 0 -9.331073620003052,4.0591407789933704 l-8.613298726156664,-9.108315894326587 a8.489544434114185,8.489544434114185 0 0 0 -12.375429204248078,0 L25.58394128451018,23.967279868769744 a9.727087354538993,9.727087354538993 0 0 0 0,13.167456673319956 L34.19724001066683,46.243052436416285 a45.07131316187151,45.07131316187151 0 0 0 -3.6631270444574313,9.083565035918088 h-12.375429204248078 a9.083565035918088,9.083565035918088 0 0 0 -8.811305593424633,9.306322761594556 v5.197680265784193 a9.108315894326587,9.108315894326587 0 0 0 8.811305593424633,9.306322761594556 h11.979415469712139 a45.69008462208391,45.69008462208391 0 0 0 4.0591407789933704,10.642869115653347 l-8.613298726156664,9.108315894326587 a9.727087354538993,9.727087354538993 0 0 0 0,13.167456673319956 l3.465120177189462,3.6631270444574313 a8.489544434114185,8.489544434114185 0 0 0 12.375429204248078,0 l8.613298726156664,-9.108315894326587 a40.49240435629971,40.49240435629971 0 0 0 9.331073620003052,4.0591407789933704 v12.895197230826497 a9.083565035918088,9.083565035918088 0 0 0 8.811305593424633,9.306322761594556 h4.950171681699231 A9.083565035918088,9.083565035918088 0 0 0 81.99114759747292,123.68848839660077 V110.79329116577425 a40.78941465720167,40.78941465720167 0 0 0 9.331073620003052,-4.0591407789933704 l8.613298726156664,9.108315894326587 a8.489544434114185,8.489544434114185 0 0 0 12.375429204248078,0 l3.465120177189462,-3.6631270444574313 a9.727087354538993,9.727087354538993 0 0 0 0,-13.167456673319956 l-8.613298726156664,-9.108315894326587 a45.665333763675406,45.665333763675406 0 0 0 4.034389920584874,-10.642869115653347 h12.004166328120636 a9.108315894326587,9.108315894326587 0 0 0 8.811305593424633,-9.306322761594556 v-5.197680265784193 a9.083565035918088,9.083565035918088 0 0 0 -8.811305593424633,-9.306322761594556 " id="svg_3" className=""/>
|
||||
</svg>
|
||||
<div id="settingsTooltip">Settings</div>
|
||||
</button>
|
||||
</div>
|
||||
<MediaButton
|
||||
type={MediaButtonType.SETTINGS}
|
||||
action={this.onSettingsClick}
|
||||
tooltip="Settings"
|
||||
/>
|
||||
</div>
|
||||
<div className="mediaDivider"></div>
|
||||
<div id="externalMedia">
|
||||
<div className="mediaContainer">
|
||||
<a href="https://github.com/dscalZi/HeliosLauncher" className="mediaURL" id="linkURL">
|
||||
<svg id="linkSVG" className="mediaSVG" viewBox="35.34 34.3575 70.68 68.71500">
|
||||
<g>
|
||||
<path d="M75.37,65.51a3.85,3.85,0,0,0-1.73.42,8.22,8.22,0,0,1,.94,3.76A8.36,8.36,0,0,1,66.23,78H46.37a8.35,8.35,0,1,1,0-16.7h9.18a21.51,21.51,0,0,1,6.65-8.72H46.37a17.07,17.07,0,1,0,0,34.15H66.23A17,17,0,0,0,82.77,65.51Z"/>
|
||||
<path d="M66,73.88a3.85,3.85,0,0,0,1.73-.42,8.22,8.22,0,0,1-.94-3.76,8.36,8.36,0,0,1,8.35-8.35H95A8.35,8.35,0,1,1,95,78H85.8a21.51,21.51,0,0,1-6.65,8.72H95a17.07,17.07,0,0,0,0-34.15H75.13A17,17,0,0,0,58.59,73.88Z"/>
|
||||
</g>
|
||||
</svg>
|
||||
</a>
|
||||
</div>
|
||||
<div className="mediaContainer">
|
||||
<a href="#" className="mediaURL" id="twitterURL" {...{disabled: true}}>
|
||||
<svg id="twitterSVG" className="mediaSVG" viewBox="0 0 5000 4060" preserveAspectRatio="xMidYMid meet">
|
||||
<g>
|
||||
<path d="M1210 4048 c-350 -30 -780 -175 -1124 -378 -56 -33 -86 -57 -86 -68 0 -16 7 -17 83 -9 114 12 349 1 493 -22 295 -49 620 -180 843 -341 l54 -38 -49 -7 c-367 -49 -660 -256 -821 -582 -30 -61 -53 -120 -51 -130 3 -16 12 -17 73 -13 97 7 199 5 270 -4 l60 -9 -65 -22 c-341 -117 -609 -419 -681 -769 -18 -88 -26 -226 -13 -239 4 -3 32 7 63 22 68 35 198 77 266 86 28 4 58 9 68 12 10 2 -22 -34 -72 -82 -240 -232 -353 -532 -321 -852 15 -149 79 -347 133 -418 16 -20 17 -19 49 20 377 455 913 795 1491 945 160 41 346 74 485 86 l82 7 -7 -59 c-5 -33 -7 -117 -6 -189 2 -163 31 -286 103 -430 141 -285 422 -504 708 -550 112 -19 333 -19 442 0 180 30 335 108 477 239 l58 54 95 -24 c143 -36 286 -89 427 -160 70 -35 131 -60 135 -56 19 19 -74 209 -151 312 -50 66 -161 178 -216 217 l-30 22 73 -14 c111 -21 257 -63 353 -101 99 -39 99 -39 99 -19 0 57 -237 326 -412 468 l-88 71 6 51 c4 28 1 130 -5 226 -30 440 -131 806 -333 1202 -380 745 -1036 1277 -1823 1477 -243 62 -430 81 -786 78 -134 0 -291 -5 -349 -10z"/>
|
||||
</g>
|
||||
</svg>
|
||||
</a>
|
||||
</div>
|
||||
<div className="mediaContainer">
|
||||
<a href="#" className="mediaURL" id="instagramURL" {...{disabled: true}}>
|
||||
<svg id="instagramSVG" className="mediaSVG" viewBox="0 0 5040 5040">
|
||||
<defs>
|
||||
<radialGradient id="instaFill" cx="30%" cy="107%" r="150%">
|
||||
<stop offset="0%" stopColor="#fdf497"/>
|
||||
<stop offset="5%" stopColor="#fdf497"/>
|
||||
<stop offset="45%" stopColor="#fd5949"/>
|
||||
<stop offset="60%" stopColor="#d6249f"/>
|
||||
<stop offset="90%" stopColor="#285AEB"/>
|
||||
</radialGradient>
|
||||
</defs>
|
||||
<g>
|
||||
<path d="M1390 5024 c-163 -9 -239 -19 -315 -38 -281 -70 -477 -177 -660 -361 -184 -184 -292 -380 -361 -660 -43 -171 -53 -456 -53 -1445 0 -989 10 -1274 53 -1445 69 -280 177 -476 361 -660 184 -184 380 -292 660 -361 171 -43 456 -53 1445 -53 989 0 1274 10 1445 53 280 69 476 177 660 361 184 184 292 380 361 660 43 171 53 456 53 1445 0 989 -10 1274 -53 1445 -69 280 -177 476 -361 660 -184 184 -380 292 -660 361 -174 44 -454 53 -1470 52 -599 0 -960 -5 -1105 -14z m2230 -473 c58 -6 141 -18 185 -27 397 -78 638 -318 719 -714 37 -183 41 -309 41 -1290 0 -981 -4 -1107 -41 -1290 -81 -395 -319 -633 -714 -714 -183 -37 -309 -41 -1290 -41 -981 0 -1107 4 -1290 41 -397 81 -636 322 -714 719 -33 166 -38 296 -43 1100 -5 796 3 1203 27 1380 67 489 338 758 830 825 47 7 162 15 255 20 250 12 1907 4 2035 -9z"/>
|
||||
<path d="M2355 3819 c-307 -42 -561 -172 -780 -400 -244 -253 -359 -543 -359 -899 0 -361 116 -648 367 -907 262 -269 563 -397 937 -397 374 0 675 128 937 397 251 259 367 546 367 907 0 361 -116 648 -367 907 -197 203 -422 326 -690 378 -101 20 -317 27 -412 14z m400 -509 c275 -88 470 -284 557 -560 20 -65 23 -95 23 -230 0 -135 -3 -165 -23 -230 -88 -278 -284 -474 -562 -562 -65 -20 -95 -23 -230 -23 -135 0 -165 3 -230 23 -278 88 -474 284 -562 562 -20 65 -23 95 -23 230 0 135 3 165 23 230 73 230 219 403 427 507 134 67 212 83 390 79 111 -3 155 -8 210 -26z"/>
|
||||
<path d="M3750 1473 c-29 -11 -66 -38 -106 -77 -70 -71 -94 -126 -94 -221 0 -95 24 -150 94 -221 72 -71 126 -94 225 -94 168 0 311 143 311 311 0 99 -23 154 -94 225 -43 42 -76 66 -110 77 -61 21 -166 21 -226 0z"/>
|
||||
</g>
|
||||
</svg>
|
||||
</a>
|
||||
</div>
|
||||
<div className="mediaContainer">
|
||||
<a href="#" className="mediaURL" id="youtubeURL" {...{disabled: true}}>
|
||||
<svg id="youtubeSVG" className="mediaSVG" viewBox="35.34 34.3575 70.68 68.71500">
|
||||
<g>
|
||||
<path d="M84.8,69.52,65.88,79.76V59.27Zm23.65.59c0-5.14-.79-17.63-3.94-20.57S99,45.86,73.37,45.86s-28,.73-31.14,3.68S38.29,65,38.29,70.11s.79,17.63,3.94,20.57,5.52,3.68,31.14,3.68,28-.74,31.14-3.68,3.94-15.42,3.94-20.57"/>
|
||||
</g>
|
||||
</svg>
|
||||
</a>
|
||||
</div>
|
||||
<div className="mediaContainer">
|
||||
<a href="https://discord.gg/zNWUXdt" className="mediaURL" id="discordURL">
|
||||
<svg id="discordSVG" className="mediaSVG" viewBox="35.34 34.3575 70.68 68.71500">
|
||||
<g>
|
||||
<path d="M81.23,78.48a6.14,6.14,0,1,1,6.14-6.14,6.14,6.14,0,0,1-6.14,6.14M60,78.48a6.14,6.14,0,1,1,6.14-6.14A6.14,6.14,0,0,1,60,78.48M104.41,73c-.92-7.7-8.24-22.9-8.24-22.9A43,43,0,0,0,88,45.59a17.88,17.88,0,0,0-8.38-1.27l-.13,1.06a23.52,23.52,0,0,1,5.8,1.95,87.59,87.59,0,0,1,8.17,4.87s-10.32-5.63-22.27-5.63a51.32,51.32,0,0,0-23.2,5.63,87.84,87.84,0,0,1,8.17-4.87,23.57,23.57,0,0,1,5.8-1.95l-.13-1.06a17.88,17.88,0,0,0-8.38,1.27,42.84,42.84,0,0,0-8.21,4.56S37.87,65.35,37,73s-.37,11.54-.37,11.54,4.22,5.68,9.9,7.14,7.7,1.47,7.7,1.47l3.75-4.68a21.22,21.22,0,0,1-4.65-2A24.47,24.47,0,0,1,47.93,82S61.16,88.4,70.68,88.4c10,0,22.75-6.44,22.75-6.44a24.56,24.56,0,0,1-5.35,4.56,21.22,21.22,0,0,1-4.65,2l3.75,4.68s2,0,7.7-1.47,9.89-7.14,9.89-7.14.55-3.85-.37-11.54"/>
|
||||
</g>
|
||||
</svg>
|
||||
</a>
|
||||
</div>
|
||||
{this.getExternalMediaButtons()}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
131
src/renderer/components/landing/mediabutton/MediaButton.css
Normal file
131
src/renderer/components/landing/mediabutton/MediaButton.css
Normal file
@ -0,0 +1,131 @@
|
||||
/* Container object which wraps an icon to ensure fluid transitions. */
|
||||
.mediaContainer {
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
height: 27px;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
/* Social media icon shared styles. */
|
||||
.mediaSVG {
|
||||
fill: #ffffff;
|
||||
height: 12px;
|
||||
transition: 0.25s ease;
|
||||
cursor: pointer;
|
||||
height: 12px;
|
||||
width: 25px;
|
||||
}
|
||||
.mediaSVG:hover,
|
||||
.mediaURL:focus .mediaSVG,
|
||||
.mediaSVG:active {
|
||||
height: 20px;
|
||||
}
|
||||
|
||||
/* Social media URL shared styles. */
|
||||
.mediaURL {
|
||||
outline: none;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
}
|
||||
|
||||
/* Internal media button shared styles. */
|
||||
.mediaButton {
|
||||
background: none;
|
||||
border: none;
|
||||
padding: 0;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
outline: none;
|
||||
}
|
||||
|
||||
/* Twitter icon colors. */
|
||||
.twitterSVG:hover,
|
||||
.twitterURL:focus .twitterSVG {
|
||||
fill: #1da1f2;
|
||||
}
|
||||
.twitterSVG:active {
|
||||
fill: #1b8dd4;
|
||||
}
|
||||
|
||||
/* Instagram icon colors. */
|
||||
.instagramSVG:hover,
|
||||
.instagramURL:focus .instagramSVG {
|
||||
fill: url('#instaFill')
|
||||
/*fill: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285AEB 90%); */
|
||||
}
|
||||
.instagramSVG:active {
|
||||
fill: url('#instaFill')
|
||||
}
|
||||
|
||||
/* Youtube icon colors. */
|
||||
.youtubeSVG:hover,
|
||||
.youtubeURL:focus .youtubeSVG {
|
||||
fill: #f00;
|
||||
}
|
||||
.youtubeSVG:active {
|
||||
fill: #ea0202;
|
||||
}
|
||||
|
||||
/* Discord icon colors. */
|
||||
.discordSVG:hover,
|
||||
.discordURL:focus .discordSVG {
|
||||
fill: #7288d9;
|
||||
}
|
||||
.discordSVG:active {
|
||||
fill: #657ac4;
|
||||
}
|
||||
|
||||
/* Settings icon colors. */
|
||||
.settingsSVG {
|
||||
stroke: #ffffff;
|
||||
height: 15px;
|
||||
}
|
||||
.mediaButton:hover .settingsSVG,
|
||||
.mediaButton:focus .settingsSVG,
|
||||
.mediaButton:active .settingsSVG {
|
||||
height: 23px;
|
||||
}
|
||||
|
||||
.mediaTooltip {
|
||||
visibility: hidden;
|
||||
opacity: 0;
|
||||
width: 75px;
|
||||
height: 20px;
|
||||
background-color: rgba(0, 0, 0, 0.75);
|
||||
text-align: center;
|
||||
border-radius: 4px;
|
||||
position: absolute;
|
||||
z-index: 1;
|
||||
right: 130%;
|
||||
font-size: 12px;
|
||||
line-height: 20px;
|
||||
transition: visibility 0s linear 0.25s, opacity 0.25s ease;
|
||||
color: #fff;
|
||||
}
|
||||
.mediaTooltip::after {
|
||||
content: " ";
|
||||
position: absolute;
|
||||
top: 50%;
|
||||
left: 100%;
|
||||
margin-top: -5px;
|
||||
border-width: 5px;
|
||||
border-style: solid;
|
||||
border-color: transparent transparent transparent rgba(0, 0, 0, 0.75);
|
||||
}
|
||||
|
||||
.mediaURL:hover .mediaTooltip,
|
||||
.mediaURL:focus .mediaTooltip,
|
||||
.mediaURL:active .mediaTooltip {
|
||||
visibility: visible;
|
||||
opacity: 1;
|
||||
transition-delay:0s;
|
||||
}
|
||||
|
||||
.mediaButton:hover .mediaTooltip,
|
||||
.mediaButton:focus .mediaTooltip,
|
||||
.mediaButton:active .mediaTooltip {
|
||||
visibility: visible;
|
||||
opacity: 1;
|
||||
transition-delay:0s;
|
||||
}
|
169
src/renderer/components/landing/mediabutton/MediaButton.tsx
Normal file
169
src/renderer/components/landing/mediabutton/MediaButton.tsx
Normal file
@ -0,0 +1,169 @@
|
||||
import { LoggerUtil } from 'common/logging/loggerutil'
|
||||
import * as React from 'react'
|
||||
|
||||
import './MediaButton.css'
|
||||
|
||||
// Pass href to render with an anchor.
|
||||
// Pass action to render with a button.
|
||||
|
||||
export interface MediaButtonProps {
|
||||
type: MediaButtonType
|
||||
href?: string
|
||||
action?: () => Promise<void>
|
||||
disabled?: boolean
|
||||
tooltip?: string
|
||||
}
|
||||
|
||||
export enum MediaButtonType {
|
||||
LINK = 'LINK',
|
||||
TWITTER = 'TWITTER',
|
||||
INSTAGRAM = 'INSTAGRAM',
|
||||
YOUTUBE = 'YOUTUBE',
|
||||
DISCORD = 'DISCORD',
|
||||
SETTINGS = 'SETTINGS'
|
||||
}
|
||||
|
||||
export class MediaButton extends React.Component<MediaButtonProps> {
|
||||
|
||||
private readonly logger = LoggerUtil.getLogger('MediaButton')
|
||||
|
||||
private getSVGClassName = (type: MediaButtonType): string => {
|
||||
return `${type.toLowerCase()}SVG`
|
||||
}
|
||||
|
||||
private getAnchorClassName = (type: MediaButtonType): string => {
|
||||
return `${type.toLowerCase()}URL`
|
||||
}
|
||||
|
||||
private getButtonClassName = (type: MediaButtonType): string => {
|
||||
return `${type.toLowerCase()}MediaButton`
|
||||
}
|
||||
|
||||
private readonly mediaContentMap: {[key in MediaButtonType]: JSX.Element} = {
|
||||
[MediaButtonType.LINK]: (
|
||||
<svg className={`mediaSVG ${this.getSVGClassName(MediaButtonType.LINK)}`} viewBox="35.34 34.3575 70.68 68.71500">
|
||||
<g>
|
||||
<path d="M75.37,65.51a3.85,3.85,0,0,0-1.73.42,8.22,8.22,0,0,1,.94,3.76A8.36,8.36,0,0,1,66.23,78H46.37a8.35,8.35,0,1,1,0-16.7h9.18a21.51,21.51,0,0,1,6.65-8.72H46.37a17.07,17.07,0,1,0,0,34.15H66.23A17,17,0,0,0,82.77,65.51Z"/>
|
||||
<path d="M66,73.88a3.85,3.85,0,0,0,1.73-.42,8.22,8.22,0,0,1-.94-3.76,8.36,8.36,0,0,1,8.35-8.35H95A8.35,8.35,0,1,1,95,78H85.8a21.51,21.51,0,0,1-6.65,8.72H95a17.07,17.07,0,0,0,0-34.15H75.13A17,17,0,0,0,58.59,73.88Z"/>
|
||||
</g>
|
||||
</svg>
|
||||
),
|
||||
[MediaButtonType.TWITTER]: (
|
||||
<svg className={`mediaSVG ${this.getSVGClassName(MediaButtonType.TWITTER)}`} viewBox="0 0 5000 4060" preserveAspectRatio="xMidYMid meet">
|
||||
<g>
|
||||
<path d="M1210 4048 c-350 -30 -780 -175 -1124 -378 -56 -33 -86 -57 -86 -68 0 -16 7 -17 83 -9 114 12 349 1 493 -22 295 -49 620 -180 843 -341 l54 -38 -49 -7 c-367 -49 -660 -256 -821 -582 -30 -61 -53 -120 -51 -130 3 -16 12 -17 73 -13 97 7 199 5 270 -4 l60 -9 -65 -22 c-341 -117 -609 -419 -681 -769 -18 -88 -26 -226 -13 -239 4 -3 32 7 63 22 68 35 198 77 266 86 28 4 58 9 68 12 10 2 -22 -34 -72 -82 -240 -232 -353 -532 -321 -852 15 -149 79 -347 133 -418 16 -20 17 -19 49 20 377 455 913 795 1491 945 160 41 346 74 485 86 l82 7 -7 -59 c-5 -33 -7 -117 -6 -189 2 -163 31 -286 103 -430 141 -285 422 -504 708 -550 112 -19 333 -19 442 0 180 30 335 108 477 239 l58 54 95 -24 c143 -36 286 -89 427 -160 70 -35 131 -60 135 -56 19 19 -74 209 -151 312 -50 66 -161 178 -216 217 l-30 22 73 -14 c111 -21 257 -63 353 -101 99 -39 99 -39 99 -19 0 57 -237 326 -412 468 l-88 71 6 51 c4 28 1 130 -5 226 -30 440 -131 806 -333 1202 -380 745 -1036 1277 -1823 1477 -243 62 -430 81 -786 78 -134 0 -291 -5 -349 -10z"/>
|
||||
</g>
|
||||
</svg>
|
||||
),
|
||||
[MediaButtonType.INSTAGRAM]: (
|
||||
<svg className={`mediaSVG ${this.getSVGClassName(MediaButtonType.INSTAGRAM)}`} viewBox="0 0 5040 5040">
|
||||
<defs>
|
||||
<radialGradient id="instaFill" cx="30%" cy="107%" r="150%">
|
||||
<stop offset="0%" stopColor="#fdf497"/>
|
||||
<stop offset="5%" stopColor="#fdf497"/>
|
||||
<stop offset="45%" stopColor="#fd5949"/>
|
||||
<stop offset="60%" stopColor="#d6249f"/>
|
||||
<stop offset="90%" stopColor="#285AEB"/>
|
||||
</radialGradient>
|
||||
</defs>
|
||||
<g>
|
||||
<path d="M1390 5024 c-163 -9 -239 -19 -315 -38 -281 -70 -477 -177 -660 -361 -184 -184 -292 -380 -361 -660 -43 -171 -53 -456 -53 -1445 0 -989 10 -1274 53 -1445 69 -280 177 -476 361 -660 184 -184 380 -292 660 -361 171 -43 456 -53 1445 -53 989 0 1274 10 1445 53 280 69 476 177 660 361 184 184 292 380 361 660 43 171 53 456 53 1445 0 989 -10 1274 -53 1445 -69 280 -177 476 -361 660 -184 184 -380 292 -660 361 -174 44 -454 53 -1470 52 -599 0 -960 -5 -1105 -14z m2230 -473 c58 -6 141 -18 185 -27 397 -78 638 -318 719 -714 37 -183 41 -309 41 -1290 0 -981 -4 -1107 -41 -1290 -81 -395 -319 -633 -714 -714 -183 -37 -309 -41 -1290 -41 -981 0 -1107 4 -1290 41 -397 81 -636 322 -714 719 -33 166 -38 296 -43 1100 -5 796 3 1203 27 1380 67 489 338 758 830 825 47 7 162 15 255 20 250 12 1907 4 2035 -9z"/>
|
||||
<path d="M2355 3819 c-307 -42 -561 -172 -780 -400 -244 -253 -359 -543 -359 -899 0 -361 116 -648 367 -907 262 -269 563 -397 937 -397 374 0 675 128 937 397 251 259 367 546 367 907 0 361 -116 648 -367 907 -197 203 -422 326 -690 378 -101 20 -317 27 -412 14z m400 -509 c275 -88 470 -284 557 -560 20 -65 23 -95 23 -230 0 -135 -3 -165 -23 -230 -88 -278 -284 -474 -562 -562 -65 -20 -95 -23 -230 -23 -135 0 -165 3 -230 23 -278 88 -474 284 -562 562 -20 65 -23 95 -23 230 0 135 3 165 23 230 73 230 219 403 427 507 134 67 212 83 390 79 111 -3 155 -8 210 -26z"/>
|
||||
<path d="M3750 1473 c-29 -11 -66 -38 -106 -77 -70 -71 -94 -126 -94 -221 0 -95 24 -150 94 -221 72 -71 126 -94 225 -94 168 0 311 143 311 311 0 99 -23 154 -94 225 -43 42 -76 66 -110 77 -61 21 -166 21 -226 0z"/>
|
||||
</g>
|
||||
</svg>
|
||||
),
|
||||
[MediaButtonType.YOUTUBE]: (
|
||||
<svg className={`mediaSVG ${this.getSVGClassName(MediaButtonType.YOUTUBE)}`} viewBox="35.34 34.3575 70.68 68.71500">
|
||||
<g>
|
||||
<path d="M84.8,69.52,65.88,79.76V59.27Zm23.65.59c0-5.14-.79-17.63-3.94-20.57S99,45.86,73.37,45.86s-28,.73-31.14,3.68S38.29,65,38.29,70.11s.79,17.63,3.94,20.57,5.52,3.68,31.14,3.68,28-.74,31.14-3.68,3.94-15.42,3.94-20.57"/>
|
||||
</g>
|
||||
</svg>
|
||||
),
|
||||
[MediaButtonType.DISCORD]: (
|
||||
<svg className={`mediaSVG ${this.getSVGClassName(MediaButtonType.DISCORD)}`} viewBox="35.34 34.3575 70.68 68.71500">
|
||||
<g>
|
||||
<path d="M81.23,78.48a6.14,6.14,0,1,1,6.14-6.14,6.14,6.14,0,0,1-6.14,6.14M60,78.48a6.14,6.14,0,1,1,6.14-6.14A6.14,6.14,0,0,1,60,78.48M104.41,73c-.92-7.7-8.24-22.9-8.24-22.9A43,43,0,0,0,88,45.59a17.88,17.88,0,0,0-8.38-1.27l-.13,1.06a23.52,23.52,0,0,1,5.8,1.95,87.59,87.59,0,0,1,8.17,4.87s-10.32-5.63-22.27-5.63a51.32,51.32,0,0,0-23.2,5.63,87.84,87.84,0,0,1,8.17-4.87,23.57,23.57,0,0,1,5.8-1.95l-.13-1.06a17.88,17.88,0,0,0-8.38,1.27,42.84,42.84,0,0,0-8.21,4.56S37.87,65.35,37,73s-.37,11.54-.37,11.54,4.22,5.68,9.9,7.14,7.7,1.47,7.7,1.47l3.75-4.68a21.22,21.22,0,0,1-4.65-2A24.47,24.47,0,0,1,47.93,82S61.16,88.4,70.68,88.4c10,0,22.75-6.44,22.75-6.44a24.56,24.56,0,0,1-5.35,4.56,21.22,21.22,0,0,1-4.65,2l3.75,4.68s2,0,7.7-1.47,9.89-7.14,9.89-7.14.55-3.85-.37-11.54"/>
|
||||
</g>
|
||||
</svg>
|
||||
),
|
||||
[MediaButtonType.SETTINGS]: (
|
||||
<svg className={`mediaSVG ${this.getSVGClassName(MediaButtonType.SETTINGS)}`} viewBox="0 0 141.36 137.43">
|
||||
<path d="M70.70475616319865,83.36934004916053 a15.320781354859122,15.320781354859122 0 1 1 14.454501310561755,-15.296030496450625 A14.850515045097694,14.850515045097694 0 0 1 70.70475616319865,83.36934004916053 M123.25082856443602,55.425620905968366 h-12.375429204248078 A45.54157947163293,45.54157947163293 0 0 0 107.21227231573047,46.243052436416285 l8.613298726156664,-9.108315894326587 a9.727087354538993,9.727087354538993 0 0 0 0,-13.167456673319956 l-3.465120177189462,-3.6631270444574313 a8.489544434114185,8.489544434114185 0 0 0 -12.375429204248078,0 l-8.613298726156664,9.108315894326587 A40.442902639482725,40.442902639482725 0 0 0 81.99114759747292,25.427580514871032 V12.532383284044531 a9.108315894326587,9.108315894326587 0 0 0 -8.811305593424633,-9.306322761594556 h-4.950171681699231 a9.108315894326587,9.108315894326587 0 0 0 -8.811305593424633,9.306322761594556 v12.895197230826497 a40.17064319698927,40.17064319698927 0 0 0 -9.331073620003052,4.0591407789933704 l-8.613298726156664,-9.108315894326587 a8.489544434114185,8.489544434114185 0 0 0 -12.375429204248078,0 L25.58394128451018,23.967279868769744 a9.727087354538993,9.727087354538993 0 0 0 0,13.167456673319956 L34.19724001066683,46.243052436416285 a45.07131316187151,45.07131316187151 0 0 0 -3.6631270444574313,9.083565035918088 h-12.375429204248078 a9.083565035918088,9.083565035918088 0 0 0 -8.811305593424633,9.306322761594556 v5.197680265784193 a9.108315894326587,9.108315894326587 0 0 0 8.811305593424633,9.306322761594556 h11.979415469712139 a45.69008462208391,45.69008462208391 0 0 0 4.0591407789933704,10.642869115653347 l-8.613298726156664,9.108315894326587 a9.727087354538993,9.727087354538993 0 0 0 0,13.167456673319956 l3.465120177189462,3.6631270444574313 a8.489544434114185,8.489544434114185 0 0 0 12.375429204248078,0 l8.613298726156664,-9.108315894326587 a40.49240435629971,40.49240435629971 0 0 0 9.331073620003052,4.0591407789933704 v12.895197230826497 a9.083565035918088,9.083565035918088 0 0 0 8.811305593424633,9.306322761594556 h4.950171681699231 A9.083565035918088,9.083565035918088 0 0 0 81.99114759747292,123.68848839660077 V110.79329116577425 a40.78941465720167,40.78941465720167 0 0 0 9.331073620003052,-4.0591407789933704 l8.613298726156664,9.108315894326587 a8.489544434114185,8.489544434114185 0 0 0 12.375429204248078,0 l3.465120177189462,-3.6631270444574313 a9.727087354538993,9.727087354538993 0 0 0 0,-13.167456673319956 l-8.613298726156664,-9.108315894326587 a45.665333763675406,45.665333763675406 0 0 0 4.034389920584874,-10.642869115653347 h12.004166328120636 a9.108315894326587,9.108315894326587 0 0 0 8.811305593424633,-9.306322761594556 v-5.197680265784193 a9.083565035918088,9.083565035918088 0 0 0 -8.811305593424633,-9.306322761594556 " id="svg_3" className=""/>
|
||||
</svg>
|
||||
)
|
||||
}
|
||||
|
||||
private blurOnClick = (): void => {
|
||||
if(document.activeElement instanceof HTMLElement) {
|
||||
document.activeElement.blur()
|
||||
}
|
||||
}
|
||||
|
||||
private handleButtonClick = (action: () => Promise<void>): () => Promise<void> => {
|
||||
return async () => {
|
||||
this.blurOnClick()
|
||||
try {
|
||||
await action()
|
||||
} catch(err) {
|
||||
this.logger.error('Uncaught error in media button action.', err)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private renderTooltip = (): JSX.Element => {
|
||||
if(this.props.tooltip) {
|
||||
return <div className="mediaTooltip">{this.props.tooltip}</div>
|
||||
} else {
|
||||
return <></>
|
||||
}
|
||||
}
|
||||
|
||||
private renderContent = (): JSX.Element => {
|
||||
|
||||
const internalContent: JSX.Element = (
|
||||
<>
|
||||
{this.mediaContentMap[this.props.type]}
|
||||
{this.renderTooltip()}
|
||||
</>
|
||||
)
|
||||
|
||||
if(this.props.href) {
|
||||
// Render anchor
|
||||
return (
|
||||
<a
|
||||
onClick={this.blurOnClick}
|
||||
href={this.props.href}
|
||||
className={`mediaURL ${this.getAnchorClassName(this.props.type)}`}
|
||||
{...(this.props.disabled ? {disabled: true} : {})}
|
||||
>
|
||||
{internalContent}
|
||||
</a>
|
||||
)
|
||||
} else if(this.props.action) {
|
||||
// Render button
|
||||
return (
|
||||
<button
|
||||
className={`mediaButton ${this.getButtonClassName(this.props.type)}`}
|
||||
onClick={this.handleButtonClick(this.props.action)}
|
||||
{...(this.props.disabled ? {disabled: true} : {})}
|
||||
>
|
||||
{internalContent}
|
||||
</button>
|
||||
)
|
||||
} else {
|
||||
return <>
|
||||
No Content
|
||||
</>
|
||||
}
|
||||
}
|
||||
|
||||
render(): JSX.Element {
|
||||
return <>
|
||||
<div className="mediaContainer">
|
||||
{this.renderContent()}
|
||||
</div>
|
||||
</>
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in New Issue
Block a user