Enhance language selection (#538)

* Enhance language selection

* remove top/left margin to limit unusable canvas area

Co-authored-by: David Luzar <luzar.david@gmail.com>
This commit is contained in:
Faustino Kialungila 2020-01-24 19:10:44 +01:00 committed by GitHub
parent ee68af0fd3
commit 54f9c296b5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 43 additions and 44 deletions

View File

@ -10,23 +10,18 @@ export function LanguageList<T>({
currentLanguage: string; currentLanguage: string;
}) { }) {
return ( return (
<ul> <React.Fragment>
{languages.map((language, idx) => ( <select
<li className="language-select"
key={idx} onChange={({ target }) => onClick(target.value)}
className={currentLanguage === language.lng ? "current" : ""} value={currentLanguage}
>
<a
href="/"
onClick={e => {
onClick(language.lng);
e.preventDefault();
}}
> >
{languages.map(language => (
<option key={language.lng} value={language.lng}>
{language.label} {language.label}
</a> </option>
</li>
))} ))}
</ul> </select>
</React.Fragment>
); );
} }

View File

@ -1309,7 +1309,6 @@ export class App extends React.Component<any, AppState> {
document.documentElement.style.cursor = hitElement ? "move" : ""; document.documentElement.style.cursor = hitElement ? "move" : "";
}} }}
/> />
<div className="langBox">
<LanguageList <LanguageList
onClick={lng => { onClick={lng => {
i18n.changeLanguage(lng); i18n.changeLanguage(lng);
@ -1318,7 +1317,6 @@ export class App extends React.Component<any, AppState> {
currentLanguage={parseDetectedLang(i18n.language)} currentLanguage={parseDetectedLang(i18n.language)}
/> />
</div> </div>
</div>
); );
} }

View File

@ -184,29 +184,35 @@ button {
} }
} }
.langBox { .language-select {
position: absolute; position: absolute;
right: 0; right: 0;
bottom: 0; bottom: 0;
min-width: 5.5rem;
height: 2rem;
margin-bottom: 0.5em;
margin-right: 0.5em; margin-right: 0.5em;
ul { padding: 0.5em;
margin: 0; background-color: #e9ecef;
padding: 0; border-radius: var(--space-factor);
} border: none;
ul > li {
list-style: none;
display: inline-block;
padding: 4px;
}
li > a,
li > a:visited {
text-decoration: none;
color: gray;
font-size: 0.8em; font-size: 0.8em;
outline: none;
appearance: none;
background-image: url("https://free-use.s3-us-west-2.amazonaws.com/up-sort.svg");
background-repeat: no-repeat;
background-position: right 0.7em top 50%, 0 0;
background-size: 0.65em auto, 100%;
&:focus {
box-shadow: 0 0 0 2px #a5d8ff;
} }
li.current > a,
li.current > a:visited { &:hover {
color: black; background-color: #ced4da;
text-decoration: underline; }
&:active {
background-color: #ced4da;
} }
} }