mirror of
https://github.com/elyby/accounts-frontend.git
synced 2024-12-27 15:30:37 +05:30
Стилизована 404 страница
This commit is contained in:
parent
ac425431ed
commit
ae01d2dd10
@ -135,6 +135,10 @@
|
||||
"components.profile.twoFactorAuth": "Двухфактарная аўтэнтыфікацыя",
|
||||
"components.userbar.login": "Уваход",
|
||||
"components.userbar.register": "Рэгістрацыя",
|
||||
"pages.404.homePage": "галоўную старонку",
|
||||
"pages.404.nothingHere": "Што бы вы не шукалі, гэта не тут",
|
||||
"pages.404.returnToTheHomePage": "Спрабуйце вярнуцца на {link}",
|
||||
"pages.404.title": "Старонка не знойдзена",
|
||||
"pages.root.siteName": "Ёly.by",
|
||||
"pages.rules.elyAccountsAsService": "{name} як сэрвіс",
|
||||
"pages.rules.elyAccountsAsService1": "Мы не гарантуем які-небудзь працэнт часу бесперабойнай работы гэтага сэрвісу.",
|
||||
|
@ -135,6 +135,10 @@
|
||||
"components.profile.twoFactorAuth": "Two factor auth",
|
||||
"components.userbar.login": "Sign in",
|
||||
"components.userbar.register": "Join",
|
||||
"pages.404.homePage": "main page",
|
||||
"pages.404.nothingHere": "This is not a place that you are looking for",
|
||||
"pages.404.returnToTheHomePage": "Try to go back to the {link}",
|
||||
"pages.404.title": "Page not found",
|
||||
"pages.root.siteName": "Ely.by",
|
||||
"pages.rules.elyAccountsAsService": "{name} as service",
|
||||
"pages.rules.elyAccountsAsService1": "We don't have any guarantee about fault free work time of this service.",
|
||||
|
@ -134,6 +134,10 @@
|
||||
"pages.root.siteName": "Ely.by",
|
||||
"components.profile.projectRules": "regras do projeto",
|
||||
"components.userbar.register": "Entrar",
|
||||
"pages.404.homePage": "",
|
||||
"pages.404.nothingHere": "",
|
||||
"pages.404.returnToTheHomePage": "",
|
||||
"pages.404.title": "",
|
||||
"pages.rules.elyAccountsAsService": "{name} como servi\u00e7o",
|
||||
"pages.rules.elyAccountsAsService2": "N\u00f3s n\u00e3o somos respons\u00e1veis por atrasos e sal\u00e1rio perdido como o resultado da inatividade de nosso servi\u00e7o.",
|
||||
"components.userbar.login": "Logar",
|
||||
|
@ -135,6 +135,10 @@
|
||||
"components.profile.twoFactorAuth": "Двухфакторная аутентификация",
|
||||
"components.userbar.login": "Вход",
|
||||
"components.userbar.register": "Регистрация",
|
||||
"pages.404.homePage": "главную страницу",
|
||||
"pages.404.nothingHere": "Что бы вы не искали, это не здесь.",
|
||||
"pages.404.returnToTheHomePage": "Попробуйте вернуться на {link}",
|
||||
"pages.404.title": "Страница не найдена",
|
||||
"pages.root.siteName": "Ely.by",
|
||||
"pages.rules.elyAccountsAsService": "{name} как сервис",
|
||||
"pages.rules.elyAccountsAsService1": "Мы не гарантируем какой-либо процент времени бесперебойной работы этого сервиса.",
|
||||
|
@ -135,6 +135,10 @@
|
||||
"components.profile.twoFactorAuth": "Двофакторна аутентифікація",
|
||||
"components.userbar.login": "Вхід",
|
||||
"components.userbar.register": "Реєстрація",
|
||||
"pages.404.homePage": "",
|
||||
"pages.404.nothingHere": "",
|
||||
"pages.404.returnToTheHomePage": "",
|
||||
"pages.404.title": "",
|
||||
"pages.root.siteName": "Ely.by",
|
||||
"pages.rules.elyAccountsAsService": "{name} як сервіс",
|
||||
"pages.rules.elyAccountsAsService1": "Ми не гарантуємо безперебійної роботи цього сервісу.",
|
||||
|
202
src/pages/404/404.scss
Normal file
202
src/pages/404/404.scss
Normal file
@ -0,0 +1,202 @@
|
||||
@import "~components/ui/fonts.scss";
|
||||
|
||||
// Original: http://codepen.io/vanderlanth/pen/rxpNMY
|
||||
|
||||
.page {
|
||||
margin: 80px auto 0;
|
||||
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
flex-direction: column;
|
||||
}
|
||||
|
||||
.loading {
|
||||
width: 200px;
|
||||
height: 100px;
|
||||
margin-bottom: 50px;
|
||||
position: relative;
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
align-items: flex-end;
|
||||
animation: loadStab 1s ease-out infinite;
|
||||
}
|
||||
|
||||
.cube {
|
||||
width: 50px;
|
||||
height: 50px;
|
||||
background: white;
|
||||
animation: cubeRotate 1s ease-out infinite;
|
||||
}
|
||||
|
||||
.road {
|
||||
position: absolute;
|
||||
width: 100%;
|
||||
height: 1px;
|
||||
background: white;
|
||||
left: 0;
|
||||
bottom: 0;
|
||||
animation: roadStab 1s ease-out infinite;
|
||||
}
|
||||
|
||||
@keyframes cubeRotate {
|
||||
0% {transform: rotate(0deg) translate3D(0, 0, 0);}
|
||||
65% {transform: rotate(45deg) translate3D(0, -13px, 0);}
|
||||
90% {transform: rotate(70deg) translate3D(0, -8px, 0);}
|
||||
100% {transform: rotate(90deg) translate3D(0, 0, 0);}
|
||||
}
|
||||
|
||||
@keyframes roadStab {
|
||||
0% {transform: translate3D(0, 0, 0);}
|
||||
60% {transform: translate3D(0, 2px, 0);}
|
||||
90% {transform: translate3D(0, 4px, 0);}
|
||||
100% {transform: translate3D(0, 0, 0);}
|
||||
}
|
||||
|
||||
@keyframes loadStab {
|
||||
0% {transform: translate3D(0, 0, 0);}
|
||||
60% {transform: translate3D(0, -2px, 0);}
|
||||
95% {transform: translate3D(0, -2px, 0);}
|
||||
100% {transform: translate3D(0, 0, 0);}
|
||||
}
|
||||
|
||||
//------------------ MOUNTAINS ---------------------
|
||||
|
||||
.rocks {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
position: absolute;
|
||||
bottom: -50px;
|
||||
left: 0;
|
||||
overflow: hidden;
|
||||
animation: roadStab 1s ease-out infinite;
|
||||
}
|
||||
|
||||
@mixin rock($rockName, $bottom, $delay) {
|
||||
.#{$rockName} {
|
||||
position: absolute;
|
||||
border-left: 2px solid transparent;
|
||||
border-right: 2px solid transparent;
|
||||
border-bottom: 4px solid white;
|
||||
bottom: $bottom;
|
||||
right: -2%;
|
||||
animation: rockTravelling 10s $delay ease-out infinite;
|
||||
}
|
||||
}
|
||||
|
||||
@include rock('rockOne', 23px, 0s);
|
||||
@include rock('rockTwo', 40px, 2s);
|
||||
@include rock('rockThree', 30px, 6s);
|
||||
@include rock('rockFour', 10px, 4s);
|
||||
@include rock('rockFive', 18px, 8s);
|
||||
|
||||
@keyframes rockTravelling {
|
||||
0% {right: -2%;}
|
||||
10% {right: 8%;}
|
||||
20% {right: 18%;}
|
||||
30% {right: 29%;}
|
||||
40% {right: 40%;}
|
||||
50% {right: 51%;}
|
||||
60% {right: 62%;}
|
||||
70% {right: 72%;}
|
||||
80% {right: 82%;}
|
||||
90% {right: 92%;}
|
||||
100% {right: 102%;}
|
||||
}
|
||||
|
||||
//------------------ CLOUDS ---------------------
|
||||
|
||||
.clouds {
|
||||
width: 200%;
|
||||
height: 200%;
|
||||
animation: roadStab 1s ease-out infinite,
|
||||
cloudStab 1s ease-out infinite;
|
||||
position: absolute;
|
||||
bottom: -50px;
|
||||
left: -50%;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.cloud {
|
||||
position: absolute;
|
||||
will-change: animation;
|
||||
|
||||
background-image: url('./cloud.svg');
|
||||
background-size: cover;
|
||||
}
|
||||
|
||||
.cloudOne {
|
||||
composes: cloud;
|
||||
|
||||
top: 5px;
|
||||
width: 100px;
|
||||
height: 32px;
|
||||
animation: cloudTravelling 16s linear infinite;
|
||||
}
|
||||
|
||||
.cloudTwo {
|
||||
composes: cloud;
|
||||
|
||||
top: 65px;
|
||||
right: -30%;
|
||||
width: 50px;
|
||||
height: 16px;
|
||||
animation: cloudTravelling 21s 5s linear infinite;
|
||||
}
|
||||
|
||||
.cloudThree {
|
||||
composes: cloud;
|
||||
|
||||
top: 40px;
|
||||
right: -30%;
|
||||
width: 70px;
|
||||
height: 22px;
|
||||
animation: cloudTravelling 26s 11s linear infinite;
|
||||
}
|
||||
|
||||
@keyframes cloudTravelling {
|
||||
0% {right: -30%;}
|
||||
100% {right: 110%;}
|
||||
}
|
||||
|
||||
@keyframes cloudStab {
|
||||
0% {transform: translate3D(0, 0, 0);}
|
||||
60% {transform: translate3D(0, 2px, 0);}
|
||||
85% {transform: translate3D(0, 2px, 0);}
|
||||
100% {transform: translate3D(0, 0, 0);}
|
||||
}
|
||||
|
||||
%text {
|
||||
font-family: $font-family-title;
|
||||
text-align: center;
|
||||
padding: 0 10px;
|
||||
line-height: 1.2;
|
||||
}
|
||||
|
||||
.text {
|
||||
@extend %text;
|
||||
|
||||
font-size: 24px;
|
||||
margin-top: 25px;
|
||||
color: #666;
|
||||
}
|
||||
|
||||
.subText {
|
||||
@extend %text;
|
||||
|
||||
font-size: 16px;
|
||||
margin-top: 5px;
|
||||
color: #9a9a9a;
|
||||
|
||||
a {
|
||||
color: #666;
|
||||
border-bottom: 1px dotted #666;
|
||||
text-decoration: none;
|
||||
transition: .25s;
|
||||
|
||||
&:hover {
|
||||
border-bottom-color: #777;
|
||||
color: #777;
|
||||
}
|
||||
}
|
||||
}
|
6
src/pages/404/PageNotFound.intl.json
Normal file
6
src/pages/404/PageNotFound.intl.json
Normal file
@ -0,0 +1,6 @@
|
||||
{
|
||||
"title": "Page not found",
|
||||
"nothingHere": "This is not a place that you are looking for",
|
||||
"returnToTheHomePage": "Try to go back to the {link}",
|
||||
"homePage": "main page"
|
||||
}
|
@ -1,7 +1,57 @@
|
||||
import React from 'react';
|
||||
|
||||
import { FooterMenu } from 'components/footerMenu';
|
||||
|
||||
import { Link } from 'react-router';
|
||||
import { FormattedMessage as Message } from 'react-intl';
|
||||
import Helmet from 'react-helmet';
|
||||
|
||||
import styles from './404.scss';
|
||||
import messages from './PageNotFound.intl.json';
|
||||
|
||||
import profileStyles from 'pages/profile/profile.scss';
|
||||
|
||||
export default function PageNotFound() {
|
||||
return (
|
||||
<h1>Sorry, but the thing you are looking for is definitely not here :(</h1>
|
||||
<div className={styles.page}>
|
||||
<Message {...messages.title}>
|
||||
{(pageTitle) => (
|
||||
<Helmet title={pageTitle} />
|
||||
)}
|
||||
</Message>
|
||||
|
||||
<div className={styles.loading}>
|
||||
<div className={styles.cube}/>
|
||||
<div className={styles.road}/>
|
||||
<div className={styles.rocks}>
|
||||
<span className={styles.rockOne}/>
|
||||
<span className={styles.rockTwo}/>
|
||||
<span className={styles.rockThree}/>
|
||||
<span className={styles.rockFour}/>
|
||||
<span className={styles.rockFive}/>
|
||||
</div>
|
||||
<div className={styles.clouds}>
|
||||
<span className={styles.cloudOne}/>
|
||||
<span className={styles.cloudTwo}/>
|
||||
<span className={styles.cloudThree}/>
|
||||
</div>
|
||||
</div>
|
||||
<p className={styles.text}>
|
||||
<Message {...messages.nothingHere} />
|
||||
</p>
|
||||
<p className={styles.subText}>
|
||||
<Message {...messages.returnToTheHomePage} values={{
|
||||
link: (
|
||||
<Link to="/">
|
||||
<Message {...messages.homePage} />
|
||||
</Link>
|
||||
)
|
||||
}} />
|
||||
</p>
|
||||
|
||||
<div className={profileStyles.footer}>
|
||||
<FooterMenu />
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
4
src/pages/404/cloud.svg
Normal file
4
src/pages/404/cloud.svg
Normal file
@ -0,0 +1,4 @@
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<svg width="100px" height="32px" viewBox="0 0 100 32" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
||||
<path d="M26.0667904,10.4823748 L60.6679035,10.4823748 L57.3747681,10.4823748 C54.4805195,10.4823748 52.1335807,12.8293135 52.1335807,15.7235622 C52.1335807,18.6178108 54.4805195,20.9647495 57.3747681,20.9647495 L60.6679035,20.9647495 L26.0667904,20.9647495 L32.6994434,20.9647495 C35.593692,20.9647495 37.9406308,18.6178108 37.9406308,15.7235622 C37.9406308,12.8293135 35.593692,10.4823748 32.6994434,10.4823748 L26.0667904,10.4823748 L26.0667904,10.4823748 Z M0,26.2059369 C0,23.3116883 2.34693878,20.9647495 5.24118738,20.9647495 L69.7124304,20.9647495 C72.606679,20.9647495 74.9536178,23.3116883 74.9536178,26.2059369 C74.9536178,29.1001855 72.606679,31.4471243 69.7124304,31.4471243 L5.24118738,31.4471243 C2.34693878,31.4471243 0,29.1001855 0,26.2059369 L0,26.2059369 Z M16.7903525,5.24118738 C16.7903525,2.34693878 19.1372913,0 22.0315399,0 L94.7588126,0 C97.6530612,0 100,2.34693878 100,5.24118738 C100,8.13543599 97.6530612,10.4823748 94.7588126,10.4823748 L22.0315399,10.4823748 C19.1372913,10.4823748 16.7903525,8.13543599 16.7903525,5.24118738 L16.7903525,5.24118738 Z" id="Shape" stroke="none" fill="#FFFFFF" fill-rule="evenodd"></path>
|
||||
</svg>
|
After Width: | Height: | Size: 1.3 KiB |
Loading…
Reference in New Issue
Block a user