fix: 修改物料登录组件

This commit is contained in:
NICE CODE BY DEV 2024-03-22 17:12:38 +08:00
parent 4fb21f0236
commit 51b793019d
8 changed files with 41 additions and 10 deletions

1
global.d.ts vendored
View File

@ -0,0 +1 @@
declare module '*.less';

View File

@ -1,5 +1,11 @@
# @zhst/material
## 0.7.1
### Patch Changes
- 添加登录 css 属性
## 0.7.0
### Minor Changes

View File

@ -1,6 +1,6 @@
{
"name": "@zhst/material",
"version": "0.7.0",
"version": "0.7.1",
"description": "物料库",
"keywords": [
"business",

View File

@ -5,6 +5,10 @@
import React, { FC } from 'react'
import { Button, Checkbox, Flex, Form, FormProps, Image, Input, theme } from 'antd';
import { HomeOutlined } from '@ant-design/icons';
import { isNumber } from '@zhst/func';
import './index.less'
const materialName = 'zhst-material-login'
const { useToken } = theme
@ -14,6 +18,8 @@ interface LoginProps {
rememberPassword?: boolean
imageUrl: string;
onFinish: FormProps['onFinish']
width?: string | number
height?: string | number
}
const Login: FC<LoginProps> = (props) => {
@ -22,13 +28,17 @@ const Login: FC<LoginProps> = (props) => {
onIconClick,
rememberPassword = true,
imageUrl,
width,
height,
onFinish
} = props
const [form] = Form.useForm();
const { token } = useToken()
console.log('width', width)
return (
<Flex>
<Flex className={materialName} style={{ width: isNumber(width) ? `${width}px` : width, height: isNumber(height) ? `${height}px` : height }}>
<Flex align='center' justify='center' style={{ position: 'relative', width: '40%', padding: `30px` }}>
<HomeOutlined
onClick={onIconClick}
@ -76,11 +86,12 @@ const Login: FC<LoginProps> = (props) => {
</Form>
</div>
</Flex>
<div style={{ width: '60%' }}>
<div style={{ width: '60%', height: '100%' }}>
<Image
style={{ width: '100%' }}
src={imageUrl}
width={'100%'}
height={'100%'}
preview={false}
fallback=""
/>

View File

@ -6,10 +6,11 @@ import bg1 from '../images/ai-suanfa.png'
const demo = () => {
return (
<div style={{ width: '100%', border: '1px solid #ccc' }}>
<div style={{ border: '1px solid #ccc' }}>
<Login
title='AI算法仓平台'
imageUrl={bg1}
height={'100vh'}
onFinish={val => console.log('val', val)}
/>
</div>

View File

@ -0,0 +1,5 @@
.zhst-material-login {
&::-webkit-scrollbar {
display: none;
}
}

View File

@ -32,6 +32,8 @@ slave.init({
| tokenKey | 从链接获取的登录校验字段 | string | token | - |
| showMsg | 是否显示“请先登录”提示框 | boolean | true | - |
| msgText | 提示框自定义文案 | string | 请先登录 | - |
| from | 来自哪个链接(可选) | string | - | - |
| to | 准备去的链接(可选) | string | - | - |
## slave 实例方法

View File

@ -15,6 +15,9 @@ export interface ISlaveConfig {
*/
tokenKey?: string;
showMsg?: boolean;
msgText?: string;
from?: string;
to?: string
}
class Slave {
@ -32,7 +35,10 @@ class Slave {
jumpToLogin = true,
jumpUrl,
tokenKey,
showMsg = true
showMsg = true,
msgText,
from,
to,
} = opt
// eslint-disable-next-line @typescript-eslint/no-unused-expressions
@ -40,13 +46,12 @@ class Slave {
this.token = _token
localStorage.setItem('ZHST_AUTH_TOKEN', _token as string)
this.checkEnv({ showMsg })
this.checkEnv({ showMsg, msgText })
if (jumpToLogin && jumpUrl && !_token) {
let jumpUrlObj = new URL(jumpUrl)
console.log('jumpUrlObj', jumpUrlObj, jumpUrl)
// 判断是否为同一个域,采用不同的跳转方式
if (jumpUrlObj.origin === location.origin) {
history.pushState('', '', jumpUrl)
} else {
@ -56,9 +61,9 @@ class Slave {
}
// 判端是否登录
checkEnv(_opt: { showMsg: boolean }) {
checkEnv(_opt: { showMsg: boolean, msgText?: string }) {
if (!this.token && _opt.showMsg) {
message.error('请先登录!')
message.error(_opt.msgText || '请先登录!')
return
}
}