@react-login-page/page8
TypeScript icon, indicating that this package has built-in type declarations

1.0.4 • Public • Published

@react-login-page/page8

Buy me a coffee npm version Downloads

login-page

Install

$ npm install @react-login-page/page8 --save

Usage

import React from 'react';
import Login from '@react-login-page/page8';

const Demo = () => <Login style={{ height: 690 }} />;

export default Demo;

Modify Controls

import React from 'react';
import LoginPage, { Username, Password, TitleSignup, TitleLogin, Submit, Title, Logo } from '@react-login-page/page8';
import LoginLogo from 'react-login-page/logo';

const styles = { height: 690 };

const Demo = () => (
  <div style={styles}>
    <LoginPage>
      <Title />
      <TitleSignup>注册</TitleSignup>
      <TitleLogin>登录</TitleLogin>
      <Logo>
        <LoginLogo />
      </Logo>
      <Username label="用户名" placeholder="请输入用户名" name="userUserName" />
      <Password label="密码" placeholder="请输入密码" name="userPassword" />
      <Submit keyname="submit">提交</Submit>
      <Submit keyname="reset">重置</Submit>

      <Username panel="signup" label="邮箱" placeholder="E-mail" keyname="e-mail" />
      <Password panel="signup" label="密码" placeholder="请输入密码" keyname="password" />
      <Password panel="signup" label="确认密码" placeholder="请输入确认密码" keyname="confirm-password" />
      <Submit panel="signup" keyname="signup-submit">
        注册
      </Submit>
      <Submit panel="signup" keyname="signup-reset">
        重置
      </Submit>
    </LoginPage>
  </div>
);

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/page8';
import LoginLogo from 'react-login-page/logo-rect';

const Demo = () => (
  <LoginPage style={{ height: 690 }}>
    <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, Logo, Footer, Username, Password, Input } from '@react-login-page/page8';
import LoginLogo from 'react-login-page/logo-rect';

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 }}>
        <Logo>
          <LoginLogo />
        </Logo>
        <Username keyname="subtitle" visible={false} index={0}>
          欢迎登录页面
        </Username>
        {/* hide default username field */}
        <Username visible={false} />
        <Username keyname="fields" index={3} label="字段" placeholder="修改了 name 字段" />
        <Username keyname="code" index={2} label="验证码">
          <img src={imgSrc} height={38} />
        </Username>
        <Username keyname="username_rule" visible={false} index={4}>
          用户名规则
        </Username>
        <Password index={1} />
        <Input name="phone" index={2} placeholder="Phone number">
          <img src={imgSrc} height={38} />
        </Input>
        <Footer>
          Not a member? <a href="#">Sign up now</a>
        </Footer>
        <Submit>登录</Submit>

        <Username 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>
      </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

  1. remove default name=username controls
<Username visible={false} />
  1. add name=user controls
<Username keyname="user" index={3} placeholder="修改了 name 字段" />

Modify Color Style

import React from 'react';
import Login from '@react-login-page/page8';

const css = {
  '--login-bg': '#5941a2',
  '--login-color': '#fff',
  '--login-label': '#a1b4b4',
  '--login-tab': '#999',
  '--login-input': '#3b4465',
  '--login-input-bg': '#eef9fe',
  '--login-input-placeholder': '#cecece',
  '--login-input-placeholder-active': '#53e3a6',
  '--login-input-border': '#cddbef',
  '--login-input-bg-hover': 'rgba(255, 255, 255, 0.4)',
  '--login-btn': '#fff',
  '--login-btn-bg': '#5941a2',
  '--login-btn-focus': 'white',
  '--login-btn-hover': '#9579e7',
  '--login-btn-active': '#6544ca',
  '--login-footer': '#ffffff99',
  '--login-animation-start': '#e2d7f1',
  '--login-animation-end': '#fff',
};

const Demo = () => <Login style={{ height: 690, ...css }} />;

export default Demo;

Use css variables to override default color values

.login-page7 {
  --login-bg: #3b4465;
  --login-color: #fff;
  --login-label: #a1b4b4;
  --login-tab: #999;
  --login-input: #3b4465;
  --login-input-bg: #eef9fe;
  --login-input-placeholder: #cecece;
  --login-input-placeholder-active: #53e3a6;
  --login-input-border: #cddbef;
  --login-input-bg-hover: rgba(255, 255, 255, 0.4);
  --login-btn: #fff;
  --login-btn-bg: #a7e245;
  --login-btn-focus: white;
  --login-btn-hover: #53e3a6;
  --login-btn-active: #1aa97d;
  --login-footer: #ffffff99;
  --login-animation-start: #d7e7f1;
  --login-animation-end: #fff;
}

Custom CSS style overrides

.login-page7 section button:focus {
  box-shadow: 0 0 0 2px rgba(0, 142, 240, 0.26);
}
.login-page7 section button:hover {
  background-color: #0070bd;
}
.login-page7 section button:active {
  background-color: #00528a;
}

Light & Dark Theme

[data-color-mode*='dark'] .login-page8,
.login-page8 {
  --login-bg: #3b4465;
  --login-color: #fff;
  --login-label: #a1b4b4;
  --login-tab: #999;
  --login-input: #3b4465;
  --login-input-bg: #eef9fe;
  --login-input-placeholder: #cecece;
  --login-input-placeholder-active: #53e3a6;
  --login-input-border: #cddbef;
  --login-input-bg-hover: rgba(255, 255, 255, 0.4);
  --login-btn: #fff;
  --login-btn-bg: #a7e245;
  --login-btn-focus: white;
  --login-btn-hover: #53e3a6;
  --login-btn-active: #1aa97d;
  --login-footer: #ffffff99;
  --login-animation-start: #d7e7f1;
  --login-animation-end: #fff;
}
[data-color-mode*='light'] .login-page8 {
  --login-bg: #3b4465;
  --login-color: #fff;
  --login-label: #a1b4b4;
  --login-tab: #999;
  --login-input: #3b4465;
  --login-input-bg: #eef9fe;
  --login-input-placeholder: #cecece;
  --login-input-placeholder-active: #53e3a6;
  --login-input-border: #cddbef;
  --login-input-bg-hover: rgba(255, 255, 255, 0.4);
  --login-btn: #fff;
  --login-btn-bg: #a7e245;
  --login-btn-focus: white;
  --login-btn-hover: #53e3a6;
  --login-btn-active: #1aa97d;
  --login-footer: #ffffff99;
  --login-animation-start: #d7e7f1;
  --login-animation-end: #fff;
}

API

Components be provided to modify control properties and perform other related functions.

import LoginPage from '@react-login-page/page8';
// buttons
import { Reset, Submit } from '@react-login-page/page8';
// blocks
import { Logo, Title, TitleLogin, TitleSignup, Footer } from '@react-login-page/page8';
// fields
import { Username, Password } from '@react-login-page/page8';
// Basic Components
import { Button, Input } from '@react-login-page/page8';
// or
import { Button, Input } from 'react-login-page';

<LoginPage>
  <Password index={2} />
</LoginPage>

<Input name="phone" index={1} placeholder="Phone number">
  <img src="..." height={38} />
</Input>

// 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>

// Signup Fields
<Username panel="signup" label="E-mail" type="email" placeholder="E-mail" keyname="e-mail" />
<Password panel="signup" label="Password" placeholder="Password" keyname="password" />
<Password panel="signup" label="Confirm Password" placeholder="Confirm Password" keyname="confirm-password" />
<Submit keyname="signup-submit" panel="signup">Signup</Submit>

Use dot notation components.

import Login from '@react-login-page/page8';

<Login>
  <Login.Password index={2} />
</Login>

// Define the order of `Password` controls
<Login.Password index={2} />

// 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.Username panel="signup" label="E-mail" type="email" placeholder="E-mail" keyname="e-mail" />
<Login.Password panel="signup" label="Password" placeholder="Password" keyname="password" />
<Login.Password panel="signup" label="Confirm Password" placeholder="Confirm Password" keyname="confirm-password" />
<Login.Submit keyname="signup-submit" panel="signup">Signup</Login.Submit>

Contributors

As always, thanks to our amazing contributors!

Made with contributors.

License

Licensed under the MIT License.

Package Sidebar

Install

npm i @react-login-page/page8

Weekly Downloads

4

Version

1.0.4

License

MIT

Unpacked Size

97.2 kB

Total Files

50

Last publish

Collaborators

  • uiwjs
  • wcjiang