@react-login-page/page10
v1.0.4
Published
Some `react` login pages, which can be used quickly after installation.
Downloads
27
Readme
@react-login-page/page10
Install
$ npm install @react-login-page/page10 --save
Usage
import React from 'react';
import Login from '@react-login-page/page10';
import LoginImg from '@react-login-page/page10/bg.png';
import LoginInnerBgImg from '@react-login-page/page10/inner-bg.jpg';
const Demo = () => (
<Login style={{ height: 690, backgroundImage: `url(${LoginImg})` }}>
<Login.InnerBox style={{ backgroundImage: `url(${LoginInnerBgImg})` }} />
<Login.InnerBox panel="signup" style={{ backgroundImage: `url(${LoginInnerBgImg})` }} />
</Login>
);
export default Demo;
Modify Controls
import React from 'react';
import LoginPage, {
Email,
Password,
InnerBox,
TitleSignup,
TitleLogin,
Submit,
Title,
Logo,
} from '@react-login-page/page10';
import LoginLogo from 'react-login-page/logo';
import LoginImg from '@react-login-page/page10/bg.png';
import LoginInnerBgImg from '@react-login-page/page10/inner-bg.jpg';
const Demo = () => (
<LoginPage
style={{ height: 690, backgroundImage: `url(${LoginImg})`, '--login-inner-image': `url("${LoginInnerBgImg}")` }}
>
<InnerBox style={{ backgroundImage: `url(${LoginInnerBgImg})` }} />
<InnerBox panel="signup" style={{ backgroundImage: `url(${LoginInnerBgImg})` }} />
<Title />
<TitleSignup>注册</TitleSignup>
<TitleLogin>登录</TitleLogin>
<Logo>
<LoginLogo />
</Logo>
<Email placeholder="请输入用户名" name="userUserName" />
<Password placeholder="请输入密码" name="userPassword" />
<Submit keyname="submit">提交</Submit>
<Submit keyname="reset">重置</Submit>
<Email panel="signup" placeholder="E-mail" keyname="e-mail" />
<Password panel="signup" placeholder="请输入密码" keyname="password" />
<Password panel="signup" placeholder="请输入确认密码" keyname="confirm-password" />
<Submit panel="signup" keyname="signup-submit">
注册
</Submit>
<Submit panel="signup" keyname="signup-reset">
重置
</Submit>
</LoginPage>
);
export default Demo;
Hide Controls
Use visible={false}
to hide controls.
import React from 'react';
import LoginPage, { Reset, Logo, Password, Footer } from '@react-login-page/page10';
import LoginLogo from 'react-login-page/logo-rect';
import LoginImg from '@react-login-page/page10/bg.png';
const Demo = () => (
<LoginPage style={{ height: 690, backgroundImage: `url(${LoginImg})` }}>
<Logo>
<LoginLogo />
</Logo>
<Password panel="signup" visible={false} keyname="confirm-password" />
<Password visible={false} />
<Footer>
Not a member? <a href="#">Sign up now</a>
</Footer>
</LoginPage>
);
export default Demo;
Add Controls
import React from 'react';
import LoginPage, { Reset, Submit, Title, Logo, Footer, Email, Password } from '@react-login-page/page10';
import LoginLogo from 'react-login-page/logo-rect';
import LoginImg from '@react-login-page/page10/bg.png';
const imgSrc =
'';
const Demo = () => {
const [data, setData] = React.useState({});
const handle = (even) => {
even.preventDefault();
const formData = new FormData(even.target);
const data = Object.fromEntries(formData);
setData({ ...data });
};
return (
<form onSubmit={handle}>
<LoginPage style={{ height: 990, '--login-inner-height': '580px', backgroundImage: `url(${LoginImg})` }}>
<Logo>
<LoginLogo />
</Logo>
<Title />
<Email keyname="subtitle" visible={false} index={0}>
欢迎登录页面
</Email>
{/* hide default Email field */}
<Email visible={false} />
<Email keyname="fields" index={3} placeholder="修改了 name 字段" />
<Email keyname="code" index={2} placeholder="验证码" label={<img src={imgSrc} height={38} />}>
xx
</Email>
<Email keyname="email_rule" visible={false} index={4}>
用户名规则
</Email>
<Password index={1} placeholder="密码" />
<Footer>
Not a member? <a href="#">Sign up now</a>
</Footer>
<Submit>登录</Submit>
<Email panel="signup" label="邮箱" type="email" placeholder="请输入邮箱" keyname="e-mail" />
<Password panel="signup" label="密码" placeholder="请输出密码" keyname="password" />
<Password panel="signup" label="确认密码" placeholder="请确认密码" keyname="confirm-password" />
<Submit keyname="signup-submit" panel="signup">
注册
</Submit>
<Footer panel="signup">
Not a member? <a href="#">Login now</a>
</Footer>
</LoginPage>
<pre>{JSON.stringify(data, null, 2)}</pre>
</form>
);
};
export default Demo;
Modify default control name
Modify the string that specifies the name
of the input control by default
- remove default
name=username
controls
<Email visible={false} />
- add
name=user
controls
<Email keyname="user" index={3} placeholder="修改了 name 字段" />
Modify Color Style
import React from 'react';
import Login from '@react-login-page/page10';
const css = {
'--login-bg': '#135344',
'--login-color': '#c4c3ca',
'--login-inner-height': '460px',
'--login-inner-bg': '#19725f',
'--login-input': '#c4c3ca',
'--login-input-bg': '#1f2029',
'--login-input-placeholder': '#49475d',
'--login-input-placeholder-active': '#53e3a6',
'--login-input-bg-hover': '#191821',
'--login-input-bg-focus': '#23222e',
'--login-input-shadow': '0 4px 8px 0 rgba(21,21,21,.2)',
'--login-btn': '#fff',
'--login-btn-bg': '#a7e245',
'--login-btn-focus': 'white',
'--login-btn-hover': '#53e3a6',
'--login-btn-active': '#1aa97d',
'--login-footer': '#ffffff99',
'--login-icon-color': '#ffeba7',
'--login-icon-toggle-color': '#b400ff',
};
const Demo = () => <Login style={{ height: 690, ...css }} />;
export default Demo;
Use css variables to override default color values
.login-page10 {
--login-bg: #1f2029;
--login-color: #c4c3ca;
--login-inner-height: 460px;
--login-inner-bg: #2a2b38;
--login-input: #c4c3ca;
--login-input-bg: #1f2029;
--login-input-placeholder: #49475d;
--login-input-placeholder-active: #53e3a6;
--login-input-bg-hover: #191821;
--login-input-bg-focus: #23222e;
--login-input-shadow: 0 4px 8px 0 rgba(21, 21, 21, 0.2);
--login-btn: #fff;
--login-btn-bg: #a7e245;
--login-btn-focus: white;
--login-btn-hover: #53e3a6;
--login-btn-active: #1aa97d;
--login-footer: #ffffff99;
--login-icon-color: #ffeba7;
--login-icon-toggle-color: #102770;
}
Custom CSS style overrides
.login-page10 section button:focus {
box-shadow: 0 0 0 2px rgba(0, 142, 240, 0.26);
}
.login-page10 section button:hover {
background-color: #0070bd;
}
.login-page10 section button:active {
background-color: #00528a;
}
Light & Dark Theme
[data-color-mode*='dark'] .login-page10,
.login-page10 {
--login-bg: #1f2029;
--login-color: #c4c3ca;
--login-inner-height: 460px;
--login-inner-bg: #2a2b38;
--login-input: #c4c3ca;
--login-input-bg: #1f2029;
--login-input-placeholder: #49475d;
--login-input-placeholder-active: #53e3a6;
--login-input-bg-hover: #191821;
--login-input-bg-focus: #23222e;
--login-input-shadow: 0 4px 8px 0 rgba(21, 21, 21, 0.2);
--login-btn: #fff;
--login-btn-bg: #a7e245;
--login-btn-focus: white;
--login-btn-hover: #53e3a6;
--login-btn-active: #1aa97d;
--login-footer: #ffffff99;
--login-icon-color: #ffeba7;
--login-icon-toggle-color: #102770;
}
[data-color-mode*='light'] .login-page10 {
--login-bg: #1f2029;
--login-color: #c4c3ca;
--login-inner-height: 460px;
--login-inner-bg: #2a2b38;
--login-input: #c4c3ca;
--login-input-bg: #1f2029;
--login-input-placeholder: #49475d;
--login-input-placeholder-active: #53e3a6;
--login-input-bg-hover: #191821;
--login-input-bg-focus: #23222e;
--login-input-shadow: 0 4px 8px 0 rgba(21, 21, 21, 0.2);
--login-btn: #fff;
--login-btn-bg: #a7e245;
--login-btn-focus: white;
--login-btn-hover: #53e3a6;
--login-btn-active: #1aa97d;
--login-footer: #ffffff99;
--login-icon-color: #ffeba7;
--login-icon-toggle-color: #102770;
}
API
Components be provided to modify control properties and perform other related functions.
import LoginPage from '@react-login-page/page10';
// buttons
import { Reset, Submit } from '@react-login-page/page10';
// blocks
import { Logo, InnerBox, Title, TitleLogin, TitleSignup, Footer } from '@react-login-page/page10';
// fields
import { Email, Password } from '@react-login-page/page10';
import LoginBgImg from '@react-login-page/page9/bg.png';
import LoginInnerBgImg from '@react-login-page/page9/inner-bg.jpg';
<LoginPage>
<Password index={2} />
</LoginPage>
// Define the order of `Password` controls
<Password index={2} />
// Hiding the `Password` control
<Password visible={false} />
// Add footer content
<Footer>
Not a member? <a href="#">Sign up now</a>
</Footer>
// Modify logo image
<Logo>⚛️</Logo>
<InnerBox style={{ backgroundImage: `url(${LoginInnerBgImg})` }} />
<InnerBox panel="signup" style={{ backgroundImage: `url(${LoginInnerBgImg})` }} />
// Signup Fields
<Email panel="signup" keyname="e-mail" />
<Password panel="signup" placeholder="Your Password" keyname="password" />
<Password panel="signup" placeholder="Confirm Password" keyname="confirm-password" />
<Submit panel="signup" keyname="signup-submit">
Signup
</Submit>
Use dot notation components.
import Login from '@react-login-page/page10';
<Login>
<Login.Password index={2} />
</Login>
// Define the order of `Password` controls
<Login.Password index={2} />
<Login.InnerBox style={{ backgroundImage: `url(${LoginInnerBgImg})` }} />
<Login.InnerBox panel="signup" style={{ backgroundImage: `url(${LoginInnerBgImg})` }} />
// Hiding the `Password` control
<Login.Password visible={false} />
// Add footer content
<Login.Footer>
Not a member? <a href="#">Sign up now</a>
</Login.Footer>
// Modify logo image
<Login.Logo>⚛️</Login.Logo>
// Signup Fields
<Login.Email panel="signup" keyname="e-mail" />
<Login.Password panel="signup" placeholder="Your Password" keyname="password" />
<Login.Password panel="signup" placeholder="Confirm Password" keyname="confirm-password" />
<Login.Submit panel="signup" keyname="signup-submit">
Signup
</Login.Submit>
Contributors
As always, thanks to our amazing contributors!
Made with contributors.
License
Licensed under the MIT License.