feat(biz,meta,material): biz:新增 od 弹框、预警图片 od;meta:新增人脸碰撞模型组件、扫描组件、termial 组件;material:新增中心连接物料
This commit is contained in:
parent
91315d4a9f
commit
26ba0f7922
@ -51,10 +51,7 @@
|
||||
"prettier --parser=typescript --write"
|
||||
]
|
||||
},
|
||||
"dependencies": {
|
||||
"xterm": "^5.3.0",
|
||||
"xterm-addon-fit": "^0.8.0"
|
||||
},
|
||||
"dependencies": {},
|
||||
"devDependencies": {
|
||||
"@changesets/cli": "^2.27.1",
|
||||
"@commitlint/cli": "^17.1.2",
|
||||
|
@ -1,5 +1,18 @@
|
||||
# @zhst/biz
|
||||
|
||||
## 0.14.0
|
||||
|
||||
### Minor Changes
|
||||
|
||||
- biz:新增 od 弹框、预警图片 od;meta:新增人脸碰撞模型组件、扫描组件、termial 组件;material:新增中心连接物料
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- Updated dependencies
|
||||
- @zhst/meta@0.13.0
|
||||
- @zhst/hooks@0.9.1
|
||||
- @zhst/func@0.10.1
|
||||
|
||||
## 0.13.0
|
||||
|
||||
### Minor Changes
|
||||
|
File diff suppressed because one or more lines are too long
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@zhst/biz",
|
||||
"version": "0.13.0",
|
||||
"version": "0.14.0",
|
||||
"description": "业务库",
|
||||
"keywords": [
|
||||
"business",
|
||||
@ -47,6 +47,6 @@
|
||||
"antd": "^5.12.5",
|
||||
"classnames": "^2.5.1",
|
||||
"dayjs": "^1.11.10",
|
||||
"rc-util": "^5.38.1"
|
||||
"rc-util": "^5.38.1"
|
||||
}
|
||||
}
|
||||
|
@ -1,26 +1,47 @@
|
||||
// @ts-nocheck
|
||||
import React, { forwardRef, useImperativeHandle, useRef, useState, useEffect } from 'react'
|
||||
import { ConfigProvider, Descriptions, Modal, Tabs, Button, BigImagePreview, VideoPlayer } from '@zhst/meta';
|
||||
import {
|
||||
ConfigProvider,
|
||||
Descriptions,
|
||||
Modal,
|
||||
Tabs,
|
||||
Button,
|
||||
CropperImage,
|
||||
AttachImage,
|
||||
VideoPlayer,
|
||||
BtnGroup,
|
||||
RelatedImage
|
||||
} from '@zhst/meta';
|
||||
import classNames from 'classnames'
|
||||
import type { ModalProps, DescriptionsProps, TabsProps, VideoViewRef, ImgViewRef } from '@zhst/meta'
|
||||
import { get, isEmpty } from '@zhst/func';
|
||||
|
||||
|
||||
import './index.less'
|
||||
import type {
|
||||
ModalProps,
|
||||
DescriptionsProps,
|
||||
TabsProps,
|
||||
VideoViewRef,
|
||||
ImgViewRef,
|
||||
CompareImageProps,
|
||||
CropperImageProps,
|
||||
AttachImageProps,
|
||||
BtnGroupProps,
|
||||
ThemeConfig,
|
||||
RelatedImageProps
|
||||
} from '@zhst/meta'
|
||||
import { get, isEmpty, pick } from '@zhst/func';
|
||||
import Navigation from './components/navigation';
|
||||
import CombineImage from './components/CombineImage'
|
||||
import { BIG_IMAGE_DATA } from './mock'
|
||||
import './index.less'
|
||||
|
||||
const DescriptionsItem = Descriptions.Item
|
||||
|
||||
export const componentPrefix = 'zhst-image'
|
||||
|
||||
export type TAB_TYPE = 'COMPATER' | 'NORMAL' | 'VIDEO';
|
||||
export type TAB_TYPE = 'COMPATER' | 'NORMAL' | 'VIDEO'; // 对比图模式、场景图模式、视频模式
|
||||
export type MODEL_TYPE = 'VIDEO' | 'IMAGE';
|
||||
|
||||
export interface BigImageModalProps extends ModalProps {
|
||||
export interface BigImageModalProps {
|
||||
visible: boolean // 弹框显示隐藏
|
||||
activeTab?: TAB_TYPE // 当前 tab
|
||||
width?: number | string
|
||||
attributeList: {
|
||||
title: string;
|
||||
children: Pick<DescriptionsProps, 'items'>
|
||||
@ -30,18 +51,33 @@ export interface BigImageModalProps extends ModalProps {
|
||||
key: TAB_TYPE // !! TRACK 模式已废弃、新增:VIDEO 模式
|
||||
} // 导航栏列表
|
||||
}
|
||||
tabsProps?: TabsProps // tab菜单的透传
|
||||
dataSource: any
|
||||
imageData: any
|
||||
onCancel?: () => void
|
||||
|
||||
relatedData: any
|
||||
isRelated?: boolean
|
||||
isRelated?: boolean // 人脸碰撞功能打开
|
||||
|
||||
footer?: React.ReactNode
|
||||
showCarousel?: boolean
|
||||
|
||||
onTabChange?: (newVal?: TAB_TYPE, oldVal?: TAB_TYPE) => void
|
||||
onIndexChange?: (newVal?: number, oldVal?: number) => void
|
||||
transformPropFunc: (data: any) => void // 格式化数据方法
|
||||
|
||||
compareImageProps?: CompareImageProps
|
||||
modalProps?: ModalProps
|
||||
cropperImageProps?: CropperImageProps & {
|
||||
showEditTools?: boolean
|
||||
}
|
||||
showNavigation?: boolean // 是否展示箭头
|
||||
prevButtonProps?: any;
|
||||
onPrevButtonClick?: () => void;
|
||||
nextButtonProps?: any
|
||||
onNextButtonClick?: () => void;
|
||||
btnGroupProps?: BtnGroupProps;
|
||||
|
||||
descriptionsProps?: DescriptionsProps
|
||||
relatedImageProps?: RelatedImageProps
|
||||
|
||||
theme?: ThemeConfig
|
||||
children?: React.ReactNode
|
||||
}
|
||||
|
||||
interface BigModalRef {
|
||||
@ -52,7 +88,6 @@ interface BigModalRef {
|
||||
setActiveKey: (val: string) => void
|
||||
videoPlayerRef: VideoViewRef
|
||||
combineImageRef: any
|
||||
bigImagePreviewRef: ImgViewRef
|
||||
}
|
||||
|
||||
const initialStyle ={
|
||||
@ -63,79 +98,135 @@ const BigImageModal: React.FC<BigImageModalProps, BigModalRef> = forwardRef((pro
|
||||
const {
|
||||
// 配置
|
||||
title = '-',
|
||||
width,
|
||||
open,
|
||||
children,
|
||||
onCancel,
|
||||
activeTab,
|
||||
attributeList = [],
|
||||
isRelated = false,
|
||||
tabs = {},
|
||||
footer = null,
|
||||
showCarousel = true,
|
||||
// 数据
|
||||
dataSource = [], // 总数据源,只允许有一份
|
||||
imageData = [],
|
||||
relatedData = [],
|
||||
dataSource = {}, // 总数据源,只允许有一份
|
||||
// 事件
|
||||
onIndexChange,
|
||||
onTabChange,
|
||||
transformPropFunc
|
||||
compareImageProps,
|
||||
showNavigation,
|
||||
modalProps,
|
||||
cropperImageProps,
|
||||
prevButtonProps,
|
||||
onPrevButtonClick,
|
||||
onNextButtonClick,
|
||||
nextButtonProps,
|
||||
tabsProps,
|
||||
btnGroupProps,
|
||||
descriptionsProps,
|
||||
relatedImageProps,
|
||||
theme,
|
||||
} = props
|
||||
|
||||
const combineImageRef = useRef(null)
|
||||
const bigImagePreviewRef = useRef(null)
|
||||
const videoPlayerRef = useRef(null)
|
||||
const modalRef = useRef(null)
|
||||
|
||||
// ========================== 头切换 =========================
|
||||
const [tab, setTab] = useState<TAB_TYPE>(activeTab || get(tabsConfig, 'data[0].key'));
|
||||
const [tab, setTab] = useState<TAB_TYPE>(activeTab || get(tabsProps, 'data[0].key'));
|
||||
const [activeKey, setActiveKey] = useState<string>('related');
|
||||
|
||||
// ========================= 预览切换下标 =========================
|
||||
const [currentIndex, setCurrentIndex] = useState<number>(0)
|
||||
const [cropType, setCropType] = useState<'auto' | 'custom' | 'close'>('auto')
|
||||
const cropBtnDataSource = [
|
||||
{
|
||||
key: 'close',
|
||||
icon: 'icon-danchuangguanbi',
|
||||
title: '退出',
|
||||
},
|
||||
{
|
||||
key: 'auto',
|
||||
icon: 'icon-zidong',
|
||||
title: '智能框选',
|
||||
},
|
||||
{
|
||||
key: 'custom',
|
||||
icon: 'icon-shoudong',
|
||||
title: '手动框选',
|
||||
},
|
||||
];
|
||||
|
||||
const tabsConfig = !isEmpty(tabs) ? tabs : {
|
||||
data: [
|
||||
{
|
||||
label: '对比图模式',
|
||||
key: 'COMPATER',
|
||||
children: (
|
||||
<CombineImage
|
||||
ref={combineImageRef}
|
||||
data={dataSource[currentIndex] || {}}
|
||||
/>
|
||||
)
|
||||
},
|
||||
{
|
||||
label: '场景图模式',
|
||||
key: 'NORMAL',
|
||||
children: (
|
||||
<BigImagePreview
|
||||
ref={bigImagePreviewRef}
|
||||
height={'500px'}
|
||||
data={dataSource[currentIndex]}
|
||||
/>
|
||||
)
|
||||
}
|
||||
]
|
||||
const handleCropBtnClick = (v: string) => {
|
||||
setCropType(v)
|
||||
}
|
||||
|
||||
const defaultTabsProps: TabsProps = !isEmpty(tabs) ? tabs : {
|
||||
items: [
|
||||
{
|
||||
label: '对比图模式',
|
||||
key: 'COMPATER',
|
||||
children: (
|
||||
<CombineImage
|
||||
ref={combineImageRef}
|
||||
data={pick(dataSource, 'compaterImage', 'imgSummary', 'imageKey', 'score')}
|
||||
{...compareImageProps}
|
||||
/>
|
||||
)
|
||||
},
|
||||
{
|
||||
label: '场景图模式',
|
||||
key: 'NORMAL',
|
||||
children: (
|
||||
<div style={{ display: 'flex', justifyContent: 'center', width: '100%' }}>
|
||||
<div style={{ width: '85%', height: '500px' }}>
|
||||
<CropperImage
|
||||
type='rect'
|
||||
odList={get(dataSource, 'odRect', [])}
|
||||
{...cropperImageProps}
|
||||
>
|
||||
{!cropperImageProps?.editAble && (
|
||||
<>
|
||||
<AttachImage
|
||||
data={[
|
||||
{ label: '测试', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' }
|
||||
]}
|
||||
/>
|
||||
<div
|
||||
style={{
|
||||
position: 'absolute',
|
||||
right: '24px',
|
||||
bottom: '24px',
|
||||
fontSize: '18px',
|
||||
color: 'red',
|
||||
cursor: 'default'
|
||||
}}
|
||||
>{`人脸质量分:${(Number(cropperImageProps?.score) as number).toFixed(2)}`}</div>
|
||||
</>
|
||||
)}
|
||||
{cropperImageProps?.showEditTools && (
|
||||
<BtnGroup
|
||||
circle
|
||||
style={{
|
||||
position: 'absolute',
|
||||
top: 0,
|
||||
right: 0
|
||||
}}
|
||||
dataSource={cropBtnDataSource}
|
||||
onClick={handleCropBtnClick}
|
||||
selectKey={cropType}
|
||||
{...btnGroupProps}
|
||||
/>
|
||||
)}
|
||||
</CropperImage>
|
||||
</div>
|
||||
</div>
|
||||
)
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
|
||||
// TODO: 页面初始化
|
||||
useEffect(() => {
|
||||
(async () => {
|
||||
let data: any = {};
|
||||
// if (isRelated) {
|
||||
// data = await transformPropFunc(imageData[currentIndex]);
|
||||
// } else {
|
||||
// data = await transformPropFunc(dataSource[currentIndex]);
|
||||
// }
|
||||
// setAttributeList(get(data, 'attributeList', []));
|
||||
//防背推
|
||||
// if (currentIndex === latestSelectIndex.current) {
|
||||
// setSelectItem(data);
|
||||
// }
|
||||
})();
|
||||
}, [currentIndex, dataSource, imageData, isRelated]);
|
||||
}, [dataSource]);
|
||||
|
||||
// 暴露 ref 实例
|
||||
useImperativeHandle(ref, () => ({
|
||||
@ -147,18 +238,19 @@ const BigImageModal: React.FC<BigImageModalProps, BigModalRef> = forwardRef((pro
|
||||
setActiveKey,
|
||||
videoPlayerRef,
|
||||
combineImageRef,
|
||||
bigImagePreviewRef,
|
||||
}));
|
||||
|
||||
return (
|
||||
<Modal
|
||||
destroyOnClose
|
||||
width={width}
|
||||
open={open}
|
||||
ref={modalRef}
|
||||
footer={footer}
|
||||
className={componentPrefix}
|
||||
title={title}
|
||||
{...props}
|
||||
onCancel={onCancel}
|
||||
{...modalProps}
|
||||
>
|
||||
<div
|
||||
style={{
|
||||
@ -179,6 +271,7 @@ const BigImageModal: React.FC<BigImageModalProps, BigModalRef> = forwardRef((pro
|
||||
contentColor: 'rgba(0,0,0,0.88)',
|
||||
},
|
||||
},
|
||||
...theme
|
||||
}}
|
||||
>
|
||||
{attributeList.map(descriptions => (
|
||||
@ -191,6 +284,7 @@ const BigImageModal: React.FC<BigImageModalProps, BigModalRef> = forwardRef((pro
|
||||
}
|
||||
column={8}
|
||||
style={{ padding: '0 64px' }}
|
||||
{...descriptionsProps}
|
||||
>
|
||||
{descriptions?.children?.map(item => (
|
||||
<DescriptionsItem
|
||||
@ -218,70 +312,49 @@ const BigImageModal: React.FC<BigImageModalProps, BigModalRef> = forwardRef((pro
|
||||
})
|
||||
}}
|
||||
tabBarStyle={{ fontSize: '18px', fontWeight:'bold' }}
|
||||
items={tabsConfig.data}
|
||||
{...tabsConfig}
|
||||
{...defaultTabsProps}
|
||||
{...tabsProps}
|
||||
/>
|
||||
{/* --------------------------------- 视频播放模式 --------------------------------- */}
|
||||
{tab === 'VIDEO' && (
|
||||
<VideoPlayer ref={videoPlayerRef} url={dataSource[currentIndex]?.flvUrl} />
|
||||
<VideoPlayer ref={videoPlayerRef} url={dataSource?.flvUrl} />
|
||||
)}
|
||||
{/* 切换按钮组件 */}
|
||||
{/* ----------------------------------- 上一张按钮 ---------------------------------- */}
|
||||
<Navigation
|
||||
className={classNames(
|
||||
`${componentPrefix}-view-container__nav`,
|
||||
currentIndex <= 0 && `${componentPrefix}-view-container__nav--disabled`,
|
||||
prevButtonProps?.disabled && `${componentPrefix}-view-container__nav--disabled`,
|
||||
`${componentPrefix}-view-container__nav--left`
|
||||
)}
|
||||
show={isRelated ? (imageData.length > 1) : (dataSource.length > 1)}
|
||||
disabled={currentIndex <= 0}
|
||||
prev
|
||||
onClick={() => {
|
||||
setCurrentIndex((pre) => {
|
||||
onIndexChange?.(pre - 1, pre)
|
||||
return pre - 1
|
||||
});
|
||||
}}
|
||||
show={showNavigation}
|
||||
onClick={onPrevButtonClick}
|
||||
{...prevButtonProps}
|
||||
/>
|
||||
{/* ----------------------------------- 下一张按钮 ---------------------------------- */}
|
||||
<Navigation
|
||||
className={classNames(
|
||||
`${componentPrefix}-view-container__nav`,
|
||||
((currentIndex >= imageData.length - 1) || (currentIndex >= dataSource.length - 1)) && `${componentPrefix}-view-container__nav--disabled`,
|
||||
nextButtonProps?.disabled && `${componentPrefix}-view-container__nav--disabled`,
|
||||
`${componentPrefix}-view-container__nav--right`
|
||||
)}
|
||||
show={isRelated ? (imageData.length > 1) : (dataSource.length > 1)}
|
||||
disabled={((currentIndex >= imageData.length - 1) || (currentIndex >= dataSource.length - 1))}
|
||||
next
|
||||
onClick={async (e) => {
|
||||
setCurrentIndex((pre) => {
|
||||
onIndexChange?.(pre + 1, pre)
|
||||
return pre + 1
|
||||
});
|
||||
}}
|
||||
show={showNavigation}
|
||||
onClick={onNextButtonClick}
|
||||
{...nextButtonProps}
|
||||
/>
|
||||
{/* --------------------------------- 模型碰撞组件 --------------------------------- */}
|
||||
{/* {isRelated && (
|
||||
<div className="relatedWrapper">
|
||||
<Tabs
|
||||
className="relatedTabs"
|
||||
tabPosition={'left'}
|
||||
activeKey={activeKey}
|
||||
onChange={(key: string) => {
|
||||
setActiveKey(key);
|
||||
}}
|
||||
items={tabList.map((item) => {
|
||||
return {
|
||||
label: item.label,
|
||||
key: item.key,
|
||||
children: item.children,
|
||||
};
|
||||
})}
|
||||
{/* ----------------------------------- 人脸碰撞组件 ---------------------------------- */}
|
||||
{isRelated && (
|
||||
<div style={{ margin: '24px 0' }}>
|
||||
<RelatedImage
|
||||
{...relatedImageProps}
|
||||
/>
|
||||
</div>
|
||||
)} */}
|
||||
)}
|
||||
</div>
|
||||
</div>
|
||||
{children}
|
||||
</Modal>
|
||||
)
|
||||
})
|
||||
|
@ -1,22 +1,33 @@
|
||||
|
||||
import React, { FC, useRef, forwardRef, useImperativeHandle, useState } from 'react';
|
||||
import React, { FC, useRef, forwardRef, useImperativeHandle } from 'react';
|
||||
import { CompareImage, Flex, Score } from '@zhst/meta'
|
||||
|
||||
interface ComBineImageProps {
|
||||
data: {
|
||||
imgSummary: string;
|
||||
compaterImages: string[];
|
||||
compaterImage: string;
|
||||
imageKey: string;
|
||||
score: number;
|
||||
}
|
||||
prevDisable?: boolean;
|
||||
nextDisable?: boolean;
|
||||
onPre?: () => void;
|
||||
onNext?: () => void;
|
||||
openRoll?: boolean
|
||||
}
|
||||
|
||||
const ComBineImage: FC<ComBineImageProps> = forwardRef((props, ref) => {
|
||||
const { data } = props
|
||||
const { imgSummary, compaterImages = [] } = data
|
||||
const {
|
||||
data,
|
||||
prevDisable,
|
||||
nextDisable,
|
||||
onNext,
|
||||
onPre,
|
||||
openRoll
|
||||
} = props
|
||||
const { imgSummary, compaterImage, score } = data
|
||||
const targetImageRef = useRef(null)
|
||||
const compareImageRef = useRef(null)
|
||||
const [targetIndex, setTargetIndex] = useState(compaterImages.findIndex(_url => imgSummary === _url) || 0)
|
||||
|
||||
useImperativeHandle(ref, () => ({
|
||||
compareImageRef,
|
||||
@ -27,21 +38,21 @@ const ComBineImage: FC<ComBineImageProps> = forwardRef((props, ref) => {
|
||||
<Flex justify='space-evenly' align='center' style={{ padding:'0 32px' }}>
|
||||
<CompareImage
|
||||
ref={targetImageRef}
|
||||
preDisable={targetIndex === 0}
|
||||
nextDisable={targetIndex >= compaterImages.length - 1}
|
||||
onNext={() => setTargetIndex(targetIndex + 1)}
|
||||
onPre={() => setTargetIndex(targetIndex - 1)}
|
||||
preDisable={prevDisable}
|
||||
nextDisable={nextDisable}
|
||||
onNext={onNext}
|
||||
onPre={onPre}
|
||||
showScore={false}
|
||||
openRoll={!!compaterImages.length}
|
||||
url={compaterImages[targetIndex] || imgSummary}
|
||||
openRoll={openRoll}
|
||||
url={imgSummary}
|
||||
label="目标图"
|
||||
/>
|
||||
<Score score={data.score} />
|
||||
<Score score={score} />
|
||||
<CompareImage
|
||||
ref={compareImageRef}
|
||||
url={data.imageKey}
|
||||
url={compaterImage}
|
||||
openRoll={false}
|
||||
score={data.score}
|
||||
score={score}
|
||||
label="对比图"
|
||||
/>
|
||||
</Flex>
|
||||
|
@ -35,10 +35,10 @@
|
||||
}
|
||||
|
||||
&-prev {
|
||||
left: 20px;
|
||||
left: 12px;
|
||||
}
|
||||
|
||||
&-next {
|
||||
right: 20px;
|
||||
right: 12px;
|
||||
}
|
||||
}
|
||||
|
@ -11,6 +11,8 @@ const BigModal = (props: any) => {
|
||||
} = props
|
||||
const [visible, setVisible] = useState(true)
|
||||
const [dataSource, setDataSource] = useState(BIG_IMAGE_DATA)
|
||||
const [selectedItemKey, setSelectedItemKey] = useState()
|
||||
const [editAble, setEditAble] = useState(false)
|
||||
const modalRef = useRef(null)
|
||||
|
||||
useEffect(() => {
|
||||
@ -29,19 +31,30 @@ const BigModal = (props: any) => {
|
||||
footer={(
|
||||
<Space>
|
||||
<Button onClick={() => modalRef.current?.setTab('VIDEO')} >查看视频</Button>
|
||||
<Button onClick={() => modalRef.current?.bigImagePreviewRef.current.setShowCrop(true)} >编辑模式</Button>
|
||||
<Button onClick={() => modalRef.current?.bigImagePreviewRef.current.setShowCrop(false)} >取消编辑</Button>
|
||||
<Button onClick={() => modalRef.current?.setTab('COMPATER')} >对比图模式</Button>
|
||||
</Space>
|
||||
)}
|
||||
showNavigation
|
||||
open={visible}
|
||||
ref={modalRef}
|
||||
onCancel={() => setVisible(false)}
|
||||
dataSource={dataSource}
|
||||
imageData={dataSource}
|
||||
onIndexChange={(oldVal, newVal) => console.log(oldVal, newVal)}
|
||||
onTabChange={(oldVal, newVal) => console.log(oldVal, newVal)}
|
||||
onTabChange={(newVal, oldVal) => console.log(oldVal, newVal)}
|
||||
width={1098}
|
||||
attributeList={attributeList}
|
||||
cropperImageProps={{
|
||||
editAble,
|
||||
url: "https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png",
|
||||
score: 50,
|
||||
showEditTools: true
|
||||
}}
|
||||
btnGroupProps={{
|
||||
onClick: v => {
|
||||
v === 'custom' && setEditAble(true)
|
||||
v === 'close' && setEditAble(false)
|
||||
v === 'auto' && console.log('自动补点')
|
||||
}
|
||||
}}
|
||||
>
|
||||
</BigImageModal>
|
||||
</div>
|
||||
|
57
packages/biz/src/BigImageModal/demo/noDescription.tsx
Normal file
57
packages/biz/src/BigImageModal/demo/noDescription.tsx
Normal file
@ -0,0 +1,57 @@
|
||||
// @ts-nocheck
|
||||
import React, { useEffect, useRef, useState } from 'react';
|
||||
import { BigImageModal } from '@zhst/biz'
|
||||
import { Button, Space } from '@zhst/meta'
|
||||
import { BIG_IMAGE_DATA, attributeList } from '../mock'
|
||||
|
||||
|
||||
|
||||
const BigModal = (props: any) => {
|
||||
const {
|
||||
} = props
|
||||
const [visible, setVisible] = useState(false)
|
||||
const [dataSource, setDataSource] = useState(BIG_IMAGE_DATA)
|
||||
const [selectedItemKey, setSelectedItemKey] = useState()
|
||||
const [editAble, setEditAble] = useState(false)
|
||||
const modalRef = useRef(null)
|
||||
|
||||
useEffect(() => {
|
||||
console.log(modalRef.current)
|
||||
}, [modalRef.current?.currentIndex])
|
||||
|
||||
useEffect(() => {
|
||||
console.log(modalRef.current)
|
||||
}, [])
|
||||
|
||||
return (
|
||||
<div>
|
||||
<Button onClick={() => setVisible(true)} >查看大图</Button>
|
||||
<BigImageModal
|
||||
title="查看大图"
|
||||
showNavigation
|
||||
open={visible}
|
||||
ref={modalRef}
|
||||
onCancel={() => setVisible(false)}
|
||||
dataSource={dataSource}
|
||||
onTabChange={(newVal, oldVal) => console.log(oldVal, newVal)}
|
||||
width={1098}
|
||||
cropperImageProps={{
|
||||
editAble,
|
||||
url: "https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png",
|
||||
score: 50,
|
||||
showEditTools: true
|
||||
}}
|
||||
btnGroupProps={{
|
||||
onClick: v => {
|
||||
v === 'custom' && setEditAble(true)
|
||||
v === 'close' && setEditAble(false)
|
||||
v === 'auto' && console.log('自动补点')
|
||||
}
|
||||
}}
|
||||
>
|
||||
</BigImageModal>
|
||||
</div>
|
||||
)
|
||||
}
|
||||
|
||||
export default BigModal
|
59
packages/biz/src/BigImageModal/demo/withRelatedImage.tsx
Normal file
59
packages/biz/src/BigImageModal/demo/withRelatedImage.tsx
Normal file
@ -0,0 +1,59 @@
|
||||
// @ts-nocheck
|
||||
import React, { useEffect, useRef, useState } from 'react';
|
||||
import { BigImageModal } from '@zhst/biz'
|
||||
import { Button, Space } from '@zhst/meta'
|
||||
import { BIG_IMAGE_DATA, attributeList, RELATED_IMAGES } from '../mock'
|
||||
|
||||
const BigModal = (props: any) => {
|
||||
const {
|
||||
} = props
|
||||
const [visible, setVisible] = useState(false)
|
||||
const [dataSource, setDataSource] = useState(BIG_IMAGE_DATA)
|
||||
const [selectedItemKey, setSelectedItemKey] = useState()
|
||||
const [editAble, setEditAble] = useState(false)
|
||||
const modalRef = useRef(null)
|
||||
|
||||
return (
|
||||
<div>
|
||||
<Button onClick={() => setVisible(true)} >查看大图</Button>
|
||||
<BigImageModal
|
||||
title="查看大图"
|
||||
showNavigation
|
||||
open={visible}
|
||||
ref={modalRef}
|
||||
onCancel={() => setVisible(false)}
|
||||
dataSource={dataSource}
|
||||
onTabChange={(newVal, oldVal) => console.log(oldVal, newVal)}
|
||||
width={1098}
|
||||
attributeList={attributeList}
|
||||
cropperImageProps={{
|
||||
editAble,
|
||||
url: "https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png",
|
||||
score: 50,
|
||||
showEditTools: true
|
||||
}}
|
||||
btnGroupProps={{
|
||||
onClick: v => {
|
||||
v === 'custom' && setEditAble(true)
|
||||
v === 'close' && setEditAble(false)
|
||||
v === 'auto' && console.log('自动补点')
|
||||
}
|
||||
}}
|
||||
isRelated
|
||||
relatedImageProps={{
|
||||
carouselWidth: '900px',
|
||||
activeTab: 'related',
|
||||
selectedItemKey,
|
||||
data: RELATED_IMAGES,
|
||||
onCancel: () => console.log('取消关联'),
|
||||
onConnect: () => console.log('关联'),
|
||||
onTabChange: (newVal, oldVal) => console.log('tab切换', newVal, oldVal),
|
||||
onItemSelecteditem: (item) => setSelectedItemKey(item.key)
|
||||
}}
|
||||
>
|
||||
</BigImageModal>
|
||||
</div>
|
||||
)
|
||||
}
|
||||
|
||||
export default BigModal
|
@ -160,75 +160,6 @@
|
||||
}
|
||||
}
|
||||
|
||||
.zhst-image__carousel {
|
||||
position: relative;
|
||||
display: flex;
|
||||
width: 742px;
|
||||
height: 100px;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
border: 1px solid #f0f0f0;
|
||||
margin: 0 auto;
|
||||
background: #fafafa;
|
||||
border-radius: 2px;
|
||||
user-select: none;
|
||||
|
||||
&-container {
|
||||
width: (58px + 8px) * 10;
|
||||
}
|
||||
|
||||
&-item {
|
||||
display: flex;
|
||||
width: 58px + 8px;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
}
|
||||
|
||||
&-item-img {
|
||||
/* 尝试消除transform 副作用 */
|
||||
position: relative;
|
||||
z-index: 99;
|
||||
|
||||
// width: 58px;
|
||||
// height: 76px;
|
||||
display: flex;
|
||||
width: 66px;
|
||||
height: 84px;
|
||||
box-sizing: border-box;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
background: #fafafa;
|
||||
cursor: pointer;
|
||||
|
||||
/* 尝试消除transform 副作用 end */
|
||||
&--active {
|
||||
border: 2px solid #09f;
|
||||
border-radius: 1px;
|
||||
}
|
||||
|
||||
&>div {
|
||||
/* 尝试消除transform 副作用 */
|
||||
position: relative;
|
||||
z-index: 99;
|
||||
overflow: hidden;
|
||||
width: 58px;
|
||||
height: 76px;
|
||||
|
||||
/* 尝试消除transform 副作用 end */
|
||||
&>img {
|
||||
width: 58px;
|
||||
height: 76px;
|
||||
object-fit: contain;
|
||||
transition: all 0.2s;
|
||||
|
||||
&:hover {
|
||||
transform: scale(1.5);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
.zhst-image__trackmodel {
|
||||
&__panel {
|
||||
position: relative;
|
||||
@ -454,61 +385,3 @@
|
||||
}
|
||||
}
|
||||
|
||||
.relatedWrapper {
|
||||
width: 100%;
|
||||
height: 100px;
|
||||
padding: 0 30px;
|
||||
margin-bottom: 30px;
|
||||
box-sizing: border-box;
|
||||
|
||||
.relatedTabs {
|
||||
width: 100%;
|
||||
height: 100px;
|
||||
}
|
||||
|
||||
.relatedContent {
|
||||
width: 100%;
|
||||
height: 100px;
|
||||
display: flex;
|
||||
|
||||
.relatedPics {
|
||||
width: 742px;
|
||||
height: 100px;
|
||||
}
|
||||
|
||||
.disabled {
|
||||
color: rgba(0, 0, 0, 25%);
|
||||
}
|
||||
|
||||
.relatedBtn {
|
||||
flex: 1;
|
||||
font-size: 14px;
|
||||
color: #333;
|
||||
display: flex;
|
||||
align-items: flex-end;
|
||||
cursor: pointer;
|
||||
|
||||
&:hover {
|
||||
color: #09f;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
:global {
|
||||
.ant-tabs-left>.ant-tabs-content-holder>.ant-tabs-content>.ant-tabs-tabpane {
|
||||
padding-left: 16px;
|
||||
}
|
||||
|
||||
.ant-tabs-tab {
|
||||
padding: 8px 12px !important;
|
||||
text-align: right !important;
|
||||
}
|
||||
|
||||
.ant-tabs .ant-tabs-tab {
|
||||
font-size: 14px;
|
||||
font-weight: bold;
|
||||
text-align: right;
|
||||
justify-content: flex-end;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -8,9 +8,87 @@ demo:
|
||||
cols: 2
|
||||
---
|
||||
|
||||
|
||||
# 大图弹框
|
||||
## 大图弹框
|
||||
|
||||
<code src="./demo/index.tsx">基本</code>
|
||||
<code src="./demo/oldData.tsx">老数据版本</code>
|
||||
<code src="./demo/withRelatedImage.tsx">人脸碰撞模型</code>
|
||||
<code src="./demo/noDescription.tsx">不要描述</code>
|
||||
|
||||
### API
|
||||
|
||||
| 参数 | 说明 | 类型 | 默认值 | 版本 |
|
||||
| --- | --- | --- | --- | --- |
|
||||
| dataSource | 数据源 | DataProps | - | |
|
||||
| visible | 弹框显示隐藏 | boolean | - | |
|
||||
| activeTab | 模式 | 'COMPATER' 'NORMAL' 'VIDEO' | - | 对比图模式、场景图模式、视频模式 |
|
||||
| width | 宽度 | string number | - | |
|
||||
| attributeList | 图片列表 | IAttributeList | - | |
|
||||
| tabs | 图片列表 | DataProps | - | |
|
||||
| tabsProps | tab菜单的透传,参考 antd-tabs | TabsProps | - | |
|
||||
| onTabChange | tab切换 | (newVal?: TAB_TYPE, oldVal?: TAB_TYPE) => void | - | |
|
||||
| isRelated | 人脸碰撞功能 | boolean | - | |
|
||||
| footer | 底部dom | React.ReactNode | - | |
|
||||
| onCancel | 关闭弹框 | () => void | - | |
|
||||
| compareImageProps | 参考@zhst/meta-CompareImage | CompareImageProps | - | |
|
||||
| modalProps | 参考antd-Modal | ModalProps | - | |
|
||||
| cropperImageProps | 参考@zhst/meta-cropperImage | cropperImageProps | - | |
|
||||
| prevButtonProps | 上一页透传 | any | - | |
|
||||
| onPrevButtonClick | 上一页 | () => void | - | |
|
||||
| nextButtonProps | 下一页透传 | any | - | |
|
||||
| onNextButtonClick | 下一页 | () => void | - | |
|
||||
| btnGroupProps | 参考@zhst/meta-btnGroup | ModalProps | - | |
|
||||
| descriptionsProps | 参考antd-descriptions | ModalProps | - | |
|
||||
| relatedImageProps | 参考@zhst/meta-relatedImage | RelatedImageProps | - | |
|
||||
| theme | 参考antd-themeConfig | ThemeConfig | - | |
|
||||
| children | 参考antd-Modal | React.ReactNode | - | |
|
||||
|
||||
### IBigImageModalData
|
||||
|
||||
```js
|
||||
export interface IBigImageModalData {
|
||||
imageKey?: string // 目标图
|
||||
imgSummary?: string // 大图
|
||||
flvUrl?: string // 视频链接
|
||||
compaterImage?: string // 对比图
|
||||
odRect?: { // od 框数据
|
||||
"x": number
|
||||
"y": number
|
||||
"w": number
|
||||
"h": number
|
||||
[key: string]: string | number; // 拓展参数
|
||||
}[],
|
||||
attachImg?: { // 小图,只有在场景图模式生效(人脸、形体)
|
||||
"url": string
|
||||
"label": string
|
||||
[key: string]: string
|
||||
}[],
|
||||
score?: number | string // 人脸质量分
|
||||
showScore?: boolean // 人脸质量分
|
||||
cameraPosition?: string // 摄像头位置
|
||||
time?: string // 摄像头拍摄时间
|
||||
objects: { // 拓展参数、可以自由支配
|
||||
objectIndex: {
|
||||
[key: string]: any
|
||||
},
|
||||
objectType: string
|
||||
sourceObjectId: string
|
||||
level: number
|
||||
confidence: number
|
||||
infoOnSource: {
|
||||
[key: string]: any
|
||||
},
|
||||
qualityScore: number
|
||||
[key: string]: any
|
||||
}[]
|
||||
}
|
||||
```
|
||||
|
||||
### IAttributeList
|
||||
|
||||
```js
|
||||
type IAttributeList {
|
||||
title: string;
|
||||
children: Pick<DescriptionsProps, 'items'>
|
||||
}[]
|
||||
```
|
||||
|
||||
|
@ -11,268 +11,94 @@ export const IMAGE_DATA = {
|
||||
4,
|
||||
20
|
||||
],
|
||||
"dataSource": [
|
||||
{
|
||||
"objectId": "1742110565582518272",
|
||||
"condition": {
|
||||
"featureInfo": null,
|
||||
"featureData": "AAAAAAAAAAAAAAAAAAAAAAA==",
|
||||
"imageData": "",
|
||||
"alg": "VERSION_REID_HEAD_ATTR",
|
||||
"rect": {
|
||||
"x": 0.271875,
|
||||
"y": 0.32222223,
|
||||
"w": 0.2859375,
|
||||
"h": 0.67777777
|
||||
},
|
||||
"objectImageUrl": "singer-20240102/1/129529/1742047651878156288.jpg",
|
||||
"srcImageUrl": "singer-20240102/1/129529/1742047652511496192.jpg"
|
||||
},
|
||||
"score": 0.7163062,
|
||||
"timestamp": 1704186491979,
|
||||
"deviceId": "129533",
|
||||
"id": "129533",
|
||||
"name": "4楼门口过道人脸",
|
||||
"dirid": "0",
|
||||
"status": "1",
|
||||
"longitude": 120.125,
|
||||
"latitude": 30.280500411987305,
|
||||
"caseId": "0",
|
||||
"caseGroup": "",
|
||||
"isDeleted": "DEVICEMANAGER_BOOL_DEFAULT",
|
||||
"objectIndex": {
|
||||
"objectId": "1742110565582518272",
|
||||
"solutionId": "1",
|
||||
"deviceId": "129533",
|
||||
"fragmentId": "0"
|
||||
},
|
||||
"objectType": "OBJECT_TYPE_PEDESTRAIN",
|
||||
"isObjectTrack": true,
|
||||
"pathId": "1742110532019697664",
|
||||
"frameInfo": {
|
||||
"frameId": "0",
|
||||
"frameTimestamp": "1704186491979",
|
||||
"width": 0,
|
||||
"height": 0,
|
||||
"originWidth": 1920,
|
||||
"originHeight": 1080,
|
||||
"offsetTime": "24714687",
|
||||
"skipNumber": "0"
|
||||
},
|
||||
"level": 1,
|
||||
"bboxInFrame": {
|
||||
"x": 0.603125,
|
||||
"y": 0.3314815,
|
||||
"w": 0.0578125,
|
||||
"h": 0.2712963
|
||||
},
|
||||
"bboxExtInFrame": {
|
||||
"x": 0.546875,
|
||||
"y": 0.2638889,
|
||||
"w": 0.17135416,
|
||||
"h": 0.40648147
|
||||
},
|
||||
"objectImageKey": "",
|
||||
"objectExtImageKey": "http://10.0.0.7:30003/file/singer-20240102/1/129533/1742110565582518272.jpg",
|
||||
"frameImageKey": "http://10.0.0.7:30003/file/singer-20240102/1/129533/1742110565603489792.jpg",
|
||||
"confidence": 0.817271,
|
||||
"sourceObjectId": "1742110565603489792",
|
||||
"storeTimestamp": "0",
|
||||
"gbNumber": "",
|
||||
"qualityScore": 0,
|
||||
"subObjectCount": 1,
|
||||
"subObjectType": [
|
||||
"OBJECT_TYPE_FACE"
|
||||
],
|
||||
"subObjectIds": [
|
||||
"1742110532015503360"
|
||||
],
|
||||
"solutionId": "1",
|
||||
"fragmentId": "0",
|
||||
"contrastKey": "singer-20240102/1/129533/1742110565582518272.jpg",
|
||||
"compaterImages": [
|
||||
"http://10.0.0.7:30003/file/singer-20240102/1/129529/1742047651878156288.jpg"
|
||||
],
|
||||
"imgSummary": "singer-20240102/1/129533/1742110565582518272.jpg",
|
||||
"imageKey": "http://10.0.0.7:30003/file/singer-20240102/1/129533/1742110565582518272.jpg",
|
||||
"srcImageUrl": "http://10.0.0.7:30003/file/singer-20240102/1/129533/1742110565603489792.jpg",
|
||||
"algorithmVersion": "VERSION_REID_HEAD_ATTR",
|
||||
"cameraId": "129533",
|
||||
"cameraName": "4楼门口过道人脸"
|
||||
},
|
||||
{
|
||||
"objectId": "1742092680994764802",
|
||||
"condition": {
|
||||
"featureInfo": null,
|
||||
"featureData": "AAAAAAAAAAAAAAAAAAAAAAAAA==",
|
||||
"imageData": "",
|
||||
"alg": "VERSION_REID_HEAD_ATTR",
|
||||
"rect": {
|
||||
"x": 0.271875,
|
||||
"y": 0.32222223,
|
||||
"w": 0.2859375,
|
||||
"h": 0.67777777
|
||||
},
|
||||
"objectImageUrl": "singer-20240102/1/129529/1742047651878156288.jpg",
|
||||
"srcImageUrl": "singer-20240102/1/129529/1742047652511496192.jpg"
|
||||
},
|
||||
"score": 0.7007122,
|
||||
"timestamp": 1704182225679,
|
||||
"deviceId": "129533",
|
||||
"id": "129533",
|
||||
"name": "4楼门口过道人脸",
|
||||
"dirid": "0",
|
||||
"status": "1",
|
||||
"longitude": 120.125,
|
||||
"latitude": 30.280500411987305,
|
||||
"caseId": "0",
|
||||
"caseGroup": "",
|
||||
"isDeleted": "DEVICEMANAGER_BOOL_DEFAULT",
|
||||
"objectIndex": {
|
||||
"objectId": "1742092680994764802",
|
||||
"solutionId": "1",
|
||||
"deviceId": "129533",
|
||||
"fragmentId": "0"
|
||||
},
|
||||
"objectType": "OBJECT_TYPE_PEDESTRAIN",
|
||||
"isObjectTrack": true,
|
||||
"pathId": "1742092646219790337",
|
||||
"frameInfo": {
|
||||
"frameId": "0",
|
||||
"frameTimestamp": "1704182225679",
|
||||
"width": 0,
|
||||
"height": 0,
|
||||
"originWidth": 1920,
|
||||
"originHeight": 1080,
|
||||
"offsetTime": "20448387",
|
||||
"skipNumber": "0"
|
||||
},
|
||||
"level": 1,
|
||||
"bboxInFrame": {
|
||||
"x": 0.5265625,
|
||||
"y": 0.49537036,
|
||||
"w": 0.104166664,
|
||||
"h": 0.35833332
|
||||
},
|
||||
"bboxExtInFrame": {
|
||||
"x": 0.465625,
|
||||
"y": 0.40648147,
|
||||
"w": 0.22708334,
|
||||
"h": 0.537963
|
||||
},
|
||||
"objectImageKey": "",
|
||||
"objectExtImageKey": "http://10.0.0.7:30003/file/singer-20240102/1/129533/1742092680994764802.jpg",
|
||||
"frameImageKey": "http://10.0.0.7:30003/file/singer-20240102/1/129533/1742092681720379392.jpg",
|
||||
"confidence": 0.769764,
|
||||
"sourceObjectId": "1742092681720379392",
|
||||
"storeTimestamp": "0",
|
||||
"gbNumber": "",
|
||||
"qualityScore": 0,
|
||||
"subObjectCount": 0,
|
||||
"subObjectType": [],
|
||||
"subObjectIds": [],
|
||||
"solutionId": "1",
|
||||
"fragmentId": "0",
|
||||
"contrastKey": "singer-20240102/1/129533/1742092680994764802.jpg",
|
||||
"compaterImages": [
|
||||
"http://10.0.0.7:30003/file/singer-20240102/1/129529/1742047651878156288.jpg"
|
||||
],
|
||||
"imgSummary": "singer-20240102/1/129533/1742092680994764802.jpg",
|
||||
"imageKey": "http://10.0.0.7:30003/file/singer-20240102/1/129533/1742092680994764802.jpg",
|
||||
"srcImageUrl": "http://10.0.0.7:30003/file/singer-20240102/1/129533/1742092681720379392.jpg",
|
||||
"algorithmVersion": "VERSION_REID_HEAD_ATTR",
|
||||
"cameraId": "129533",
|
||||
"cameraName": "4楼门口过道人脸"
|
||||
},
|
||||
{
|
||||
"objectId": "1742092514409592832",
|
||||
"condition": {
|
||||
"featureInfo": null,
|
||||
"featureData": "AAAAAAAAAAAAAAAAAAAAAAAA==",
|
||||
"imageData": "",
|
||||
"alg": "VERSION_REID_HEAD_ATTR",
|
||||
"rect": {
|
||||
"x": 0.271875,
|
||||
"y": 0.32222223,
|
||||
"w": 0.2859375,
|
||||
"h": 0.67777777
|
||||
},
|
||||
"objectImageUrl": "singer-20240102/1/129529/1742047651878156288.jpg",
|
||||
"srcImageUrl": "singer-20240102/1/129529/1742047652511496192.jpg"
|
||||
},
|
||||
"score": 0.703765,
|
||||
"timestamp": 1704182186451,
|
||||
"deviceId": "129529",
|
||||
"id": "129529",
|
||||
"name": "4入口人脸",
|
||||
"dirid": "0",
|
||||
"status": "1",
|
||||
"longitude": 120.12100219726562,
|
||||
"latitude": 30.280099868774414,
|
||||
"caseId": "0",
|
||||
"caseGroup": "",
|
||||
"isDeleted": "DEVICEMANAGER_BOOL_DEFAULT",
|
||||
"objectIndex": {
|
||||
"objectId": "1742092514409592832",
|
||||
"solutionId": "1",
|
||||
"deviceId": "129529",
|
||||
"fragmentId": "0"
|
||||
},
|
||||
"objectType": "OBJECT_TYPE_PEDESTRAIN",
|
||||
"isObjectTrack": true,
|
||||
"pathId": "1742092482440607744",
|
||||
"frameInfo": {
|
||||
"frameId": "0",
|
||||
"frameTimestamp": "1704182186451",
|
||||
"width": 0,
|
||||
"height": 0,
|
||||
"originWidth": 2560,
|
||||
"originHeight": 1440,
|
||||
"offsetTime": "20409182",
|
||||
"skipNumber": "0"
|
||||
},
|
||||
"level": 1,
|
||||
"bboxInFrame": {
|
||||
"x": 0.6195313,
|
||||
"y": 0.24583334,
|
||||
"w": 0.09804688,
|
||||
"h": 0.41944444
|
||||
},
|
||||
"bboxExtInFrame": {
|
||||
"x": 0.53515625,
|
||||
"y": 0.14027777,
|
||||
"w": 0.26640624,
|
||||
"h": 0.63125
|
||||
},
|
||||
"objectImageKey": "",
|
||||
"objectExtImageKey": "http://10.0.0.7:30003/file/singer-20240102/1/129529/1742092514409592832.jpg",
|
||||
"frameImageKey": "http://10.0.0.7:30003/file/singer-20240102/1/129529/1742092515508500480.jpg",
|
||||
"confidence": 0.92494,
|
||||
"sourceObjectId": "1742092515508500480",
|
||||
"storeTimestamp": "0",
|
||||
"gbNumber": "",
|
||||
"qualityScore": 0,
|
||||
"subObjectCount": 1,
|
||||
"subObjectType": [
|
||||
"OBJECT_TYPE_FACE"
|
||||
],
|
||||
"subObjectIds": [
|
||||
"1742092482432219136"
|
||||
],
|
||||
"solutionId": "1",
|
||||
"fragmentId": "0",
|
||||
"contrastKey": "singer-20240102/1/129529/1742092514409592832.jpg",
|
||||
"compaterImages": [
|
||||
"http://10.0.0.7:30003/file/singer-20240102/1/129529/1742047651878156288.jpg"
|
||||
],
|
||||
"imgSummary": "singer-20240102/1/129529/1742092514409592832.jpg",
|
||||
"imageKey": "http://10.0.0.7:30003/file/singer-20240102/1/129529/1742092514409592832.jpg",
|
||||
"srcImageUrl": "http://10.0.0.7:30003/file/singer-20240102/1/129529/1742092515508500480.jpg",
|
||||
"algorithmVersion": "VERSION_REID_HEAD_ATTR",
|
||||
"cameraId": "129529",
|
||||
"cameraName": "4入口人脸"
|
||||
}
|
||||
],
|
||||
"dataSource": {
|
||||
"objectId": "1742110565582518272",
|
||||
"condition": {
|
||||
"featureInfo": null,
|
||||
"featureData": "AAAAAAAAAAAAAAAAAAAAAAA==",
|
||||
"imageData": "",
|
||||
"alg": "VERSION_REID_HEAD_ATTR",
|
||||
"rect": {
|
||||
"x": 0.271875,
|
||||
"y": 0.32222223,
|
||||
"w": 0.2859375,
|
||||
"h": 0.67777777
|
||||
},
|
||||
"objectImageUrl": "singer-20240102/1/129529/1742047651878156288.jpg",
|
||||
"srcImageUrl": "singer-20240102/1/129529/1742047652511496192.jpg"
|
||||
},
|
||||
"score": 0.7163062,
|
||||
"timestamp": 1704186491979,
|
||||
"deviceId": "129533",
|
||||
"id": "129533",
|
||||
"name": "4楼门口过道人脸",
|
||||
"dirid": "0",
|
||||
"status": "1",
|
||||
"longitude": 120.125,
|
||||
"latitude": 30.280500411987305,
|
||||
"caseId": "0",
|
||||
"caseGroup": "",
|
||||
"isDeleted": "DEVICEMANAGER_BOOL_DEFAULT",
|
||||
"objectIndex": {
|
||||
"objectId": "1742110565582518272",
|
||||
"solutionId": "1",
|
||||
"deviceId": "129533",
|
||||
"fragmentId": "0"
|
||||
},
|
||||
"objectType": "OBJECT_TYPE_PEDESTRAIN",
|
||||
"isObjectTrack": true,
|
||||
"pathId": "1742110532019697664",
|
||||
"frameInfo": {
|
||||
"frameId": "0",
|
||||
"frameTimestamp": "1704186491979",
|
||||
"width": 0,
|
||||
"height": 0,
|
||||
"originWidth": 1920,
|
||||
"originHeight": 1080,
|
||||
"offsetTime": "24714687",
|
||||
"skipNumber": "0"
|
||||
},
|
||||
"level": 1,
|
||||
"bboxInFrame": {
|
||||
"x": 0.603125,
|
||||
"y": 0.3314815,
|
||||
"w": 0.0578125,
|
||||
"h": 0.2712963
|
||||
},
|
||||
"bboxExtInFrame": {
|
||||
"x": 0.546875,
|
||||
"y": 0.2638889,
|
||||
"w": 0.17135416,
|
||||
"h": 0.40648147
|
||||
},
|
||||
"objectImageKey": "",
|
||||
"objectExtImageKey": "http://10.0.0.7:30003/file/singer-20240102/1/129533/1742110565582518272.jpg",
|
||||
"frameImageKey": "http://10.0.0.7:30003/file/singer-20240102/1/129533/1742110565603489792.jpg",
|
||||
"confidence": 0.817271,
|
||||
"sourceObjectId": "1742110565603489792",
|
||||
"storeTimestamp": "0",
|
||||
"gbNumber": "",
|
||||
"qualityScore": 0,
|
||||
"subObjectCount": 1,
|
||||
"subObjectType": [
|
||||
"OBJECT_TYPE_FACE"
|
||||
],
|
||||
"subObjectIds": [
|
||||
"1742110532015503360"
|
||||
],
|
||||
"solutionId": "1",
|
||||
"fragmentId": "0",
|
||||
"contrastKey": "singer-20240102/1/129533/1742110565582518272.jpg",
|
||||
"compaterImages": [
|
||||
"http://10.0.0.7:30003/file/singer-20240102/1/129529/1742047651878156288.jpg"
|
||||
],
|
||||
"imgSummary": "singer-20240102/1/129533/1742110565582518272.jpg",
|
||||
"imageKey": "http://10.0.0.7:30003/file/singer-20240102/1/129533/1742110565582518272.jpg",
|
||||
"srcImageUrl": "http://10.0.0.7:30003/file/singer-20240102/1/129533/1742110565603489792.jpg",
|
||||
"algorithmVersion": "VERSION_REID_HEAD_ATTR",
|
||||
"cameraId": "129533",
|
||||
"cameraName": "4楼门口过道人脸"
|
||||
},
|
||||
"isArchiveDetail": false,
|
||||
"ToolProps": {
|
||||
"renderVideoBtn": true,
|
||||
@ -281,163 +107,104 @@ export const IMAGE_DATA = {
|
||||
"specialTitle": ""
|
||||
}
|
||||
|
||||
export const BIG_IMAGE_DATA = [
|
||||
export const RELATED_IMAGES = [
|
||||
{ key: '123', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '22', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '22122333', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '2212243', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '224523433', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '224235453', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '245423', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '224233543', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '22452343', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '22323243', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '2236456', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '224563', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '24565423', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '245645623', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '2456435623', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' },
|
||||
{ key: '2323', url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png' }
|
||||
]
|
||||
|
||||
export const BIG_IMAGE_DATA = {
|
||||
imageKey: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png',
|
||||
imgSummary: "https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png",
|
||||
flvUrl: 'ws://10.0.0.120:9033/flv/HaikangNvr/45.flv?ip=10.0.2.103&stime=1712539148&etime=1712539168',
|
||||
compaterImage: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png',
|
||||
odRect: [
|
||||
{
|
||||
imageKey: 'http://10.0.0.120:30003/file/singer-20240110/1/5/1744894622934503424.jpg',
|
||||
imgSummary: "http://10.0.0.120:30003/file/singer-20240117/1/5/1747536346412488704.jpg",
|
||||
flvUrl: 'ws://10.0.0.120:9033/flv/Sip/34020000001310000301.flv?ip=10.0.0.120&stime=1704815972&etime=1704815992',
|
||||
compaterImages: [
|
||||
'http://10.0.0.120:30003/file/singer-20240117/1/5/1747536346412488704.jpg',
|
||||
"http://10.0.0.120:30003/file/public/public_20240117/file/dfdd3340-53c8-4dc4-9921-f13230aa0355.jpg"
|
||||
],
|
||||
odRect: {
|
||||
"x":0.5445312,
|
||||
"y":0.19166666,
|
||||
"w":0.08671875,
|
||||
"h":0.40138888
|
||||
},
|
||||
attachImg: [
|
||||
{
|
||||
"url": "http://10.0.0.120:30003/file/singer-20240110/1/5/1744894622695428096.jpg",
|
||||
"label": "形体"
|
||||
},{
|
||||
"url": "http://10.0.0.120:30003/file/singer-20240110/1/5/1744894588427964418.jpg",
|
||||
"label": "人脸"
|
||||
}
|
||||
],
|
||||
score: '0.6', // 人脸质量分
|
||||
showScore: true, // 人脸质量分
|
||||
cameraPosition: 'string', // 摄像头位置
|
||||
time: '2022-01-01', // 摄像头拍摄时间
|
||||
objects: [
|
||||
{
|
||||
"objectIndex": {
|
||||
"objectId": "1746832189053474816",
|
||||
"solutionId": "0",
|
||||
"deviceId": "0",
|
||||
"fragmentId": "0"
|
||||
},
|
||||
"objectType": "OBJECT_TYPE_PEDESTRAIN",
|
||||
"sourceObjectId": "0",
|
||||
"level": 0,
|
||||
"confidence": 0.881164,
|
||||
"frameInfo": {
|
||||
"frameId": "0",
|
||||
"frameTimestamp": "1705312223057",
|
||||
"width": 0,
|
||||
"height": 0,
|
||||
"originWidth": 0,
|
||||
"originHeight": 0,
|
||||
"offsetTime": "0",
|
||||
"skipNumber": "0"
|
||||
},
|
||||
"infoOnSource": {
|
||||
"bboxInFrame": {
|
||||
"bboxRatio": {
|
||||
"x": 0.61418945,
|
||||
"y": 0.34309354,
|
||||
"w": 0.067661405,
|
||||
"h": 0.34659258
|
||||
},
|
||||
},
|
||||
"countInSource": 0,
|
||||
"indexInSource": 0
|
||||
},
|
||||
"qualityScore": 0,
|
||||
}
|
||||
]
|
||||
id: '123',
|
||||
"x":0.5445312,
|
||||
"y":0.19166666,
|
||||
"w":0.08671875,
|
||||
"h":0.40138888
|
||||
},
|
||||
{
|
||||
imageKey: 'http://10.0.0.120:30003/file/singer-20240115/1/9/1746795581994436608.jpg',
|
||||
imgSummary: "http://10.0.0.120:30003/file/singer-20240117/1/5/1747536346412488704.jpg",
|
||||
odRect:{
|
||||
"x":0.553125,"y":0.29722223,"w":0.048958335,"h":0.2462963
|
||||
},
|
||||
attachImg: [
|
||||
{
|
||||
"url": "http://10.0.0.120:30003/file/singer-20240115/1/9/1746795581163964416.jpg","label": "形体"
|
||||
},{
|
||||
"url": "http://10.0.0.120:30003/file/singer-20240115/1/9/1746795546867140608.jpg",
|
||||
"label": "人脸"
|
||||
}
|
||||
],
|
||||
flvUrl: 'ws://10.0.0.120:9033/flv/HaikangNvr/34.flv?ip=10.0.2.103&stime=1705302394&etime=1705302414',
|
||||
score: 0.815207, // 人脸质量分
|
||||
showScore: true, // 人脸质量分
|
||||
cameraPosition: 'string', // 摄像头位置
|
||||
time: '2022-01-01', // 摄像头拍摄时间
|
||||
objects: [
|
||||
{
|
||||
"objectIndex": {
|
||||
"objectId": "1746816737430472704",
|
||||
"solutionId": "0",
|
||||
"deviceId": "0",
|
||||
"fragmentId": "0"
|
||||
},
|
||||
"objectType": "OBJECT_TYPE_PEDESTRAIN",
|
||||
"sourceObjectId": "0",
|
||||
"frameInfo": {
|
||||
"frameId": "0",
|
||||
"frameTimestamp": "1705308539109",
|
||||
"width": 0,
|
||||
"height": 0,
|
||||
"originWidth": 0,
|
||||
"originHeight": 0,
|
||||
"offsetTime": "0",
|
||||
"skipNumber": "0"
|
||||
},
|
||||
"infoOnSource": {
|
||||
"bboxInFrame": {
|
||||
"bboxRatio": {
|
||||
"x": 0.5519352,
|
||||
"y": 0.2965385,
|
||||
"w": 0.05185461,
|
||||
"h": 0.24698898
|
||||
},
|
||||
},
|
||||
"countInSource": 0,
|
||||
"indexInSource": 0
|
||||
},
|
||||
"qualityScore": 0,
|
||||
},
|
||||
{
|
||||
"objectIndex": {
|
||||
"objectId": "1746816737430472705",
|
||||
"solutionId": "0",
|
||||
"deviceId": "0",
|
||||
"fragmentId": "0"
|
||||
},
|
||||
"objectType": "OBJECT_TYPE_PEDESTRAIN",
|
||||
"sourceObjectId": "0",
|
||||
"level": 0,
|
||||
"confidence": 0.9310699,
|
||||
"frameInfo": {
|
||||
"frameId": "0",
|
||||
"frameTimestamp": "1705308539109",
|
||||
"width": 0,
|
||||
"height": 0,
|
||||
"originWidth": 0,
|
||||
"originHeight": 0,
|
||||
"offsetTime": "0",
|
||||
"skipNumber": "0"
|
||||
},
|
||||
"infoOnSource": {
|
||||
"bboxInFrame": {
|
||||
"bboxRatio": {
|
||||
"x": 0.58543766,
|
||||
"y": 0.3203356,
|
||||
"w": 0.052037954,
|
||||
"h": 0.2664015
|
||||
},
|
||||
},
|
||||
"countInSource": 0,
|
||||
"indexInSource": 0
|
||||
},
|
||||
"qualityScore": 0,
|
||||
}
|
||||
]
|
||||
"id": "123",
|
||||
"x": 0.5519352,
|
||||
"y": 0.2965385,
|
||||
"w": 0.05185461,
|
||||
"h": 0.24698898,
|
||||
},
|
||||
{
|
||||
"id": "456",
|
||||
"x": 0.58543766,
|
||||
"y": 0.3203356,
|
||||
"w": 0.052037954,
|
||||
"h": 0.2664015
|
||||
}
|
||||
]
|
||||
],
|
||||
attachImg: [
|
||||
{
|
||||
"url": "https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png",
|
||||
"label": "形体"
|
||||
},{
|
||||
"url": "https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png",
|
||||
"label": "人脸"
|
||||
}
|
||||
],
|
||||
score: '0.6', // 人脸质量分
|
||||
showScore: true, // 人脸质量分
|
||||
cameraPosition: 'string', // 摄像头位置
|
||||
time: '2022-01-01', // 摄像头拍摄时间
|
||||
objects: [
|
||||
{
|
||||
"objectIndex": {
|
||||
"objectId": "1746832189053474816",
|
||||
"solutionId": "0",
|
||||
"deviceId": "0",
|
||||
"fragmentId": "0"
|
||||
},
|
||||
"objectType": "OBJECT_TYPE_PEDESTRAIN",
|
||||
"sourceObjectId": "0",
|
||||
"level": 0,
|
||||
"confidence": 0.881164,
|
||||
"frameInfo": {
|
||||
"frameId": "0",
|
||||
"frameTimestamp": "1705312223057",
|
||||
"width": 0,
|
||||
"height": 0,
|
||||
"originWidth": 0,
|
||||
"originHeight": 0,
|
||||
"offsetTime": "0",
|
||||
"skipNumber": "0"
|
||||
},
|
||||
"infoOnSource": {
|
||||
"bboxInFrame": {
|
||||
"bboxRatio": {
|
||||
"x": 0.61418945,
|
||||
"y": 0.34309354,
|
||||
"w": 0.067661405,
|
||||
"h": 0.34659258
|
||||
},
|
||||
},
|
||||
"countInSource": 0,
|
||||
"indexInSource": 0
|
||||
},
|
||||
"qualityScore": 0,
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
export const attributeList = [
|
||||
{
|
||||
|
36
packages/biz/src/BigImageModal/util/interface.ts
Normal file
36
packages/biz/src/BigImageModal/util/interface.ts
Normal file
@ -0,0 +1,36 @@
|
||||
export interface IBigImageModalData {
|
||||
imageKey?: string // 目标图
|
||||
imgSummary?: string // 大图
|
||||
flvUrl?: string // 视频链接
|
||||
compaterImages?: string[] // 对比图
|
||||
odRect?: { // od 框数据
|
||||
"x": number
|
||||
"y": number
|
||||
"w": number
|
||||
"h": number
|
||||
[key: string]: string | number; // 拓展参数
|
||||
}[],
|
||||
attachImg?: { // 小图,只有在场景图模式生效(人脸、形体)
|
||||
"url": string
|
||||
"label": string
|
||||
[key: string]: string
|
||||
}[],
|
||||
score?: number | string // 人脸质量分
|
||||
showScore?: boolean // 人脸质量分
|
||||
cameraPosition?: string // 摄像头位置
|
||||
time?: string // 摄像头拍摄时间
|
||||
objects: { // 拓展参数、可以自由支配
|
||||
objectIndex: {
|
||||
[key: string]: any
|
||||
},
|
||||
objectType: string
|
||||
sourceObjectId: string
|
||||
level: number
|
||||
confidence: number
|
||||
infoOnSource: {
|
||||
[key: string]: any
|
||||
},
|
||||
qualityScore: number
|
||||
[key: string]: any
|
||||
}[]
|
||||
}
|
@ -25,7 +25,7 @@ export const VideoPlayerCard: React.FC<VideoPlayerCardProps> = (props) => {
|
||||
|
||||
const { ConfigContext } = ConfigProvider;
|
||||
const { getPrefixCls } = useContext(ConfigContext);
|
||||
const { prefixCls: customizePrefixCls, showType, imgSrc, videoSrc, cardProps, isWindowLoading, errorReasonText, size, title, handleCloseButtonClick, handleWindowClick, windowKey, selectedWindowKey = '' } = props;
|
||||
const { prefixCls: customizePrefixCls, showType, imageKey, videoSrc, cardProps, isWindowLoading, errorReasonText, size, title, handleCloseButtonClick, handleWindowClick, windowKey, selectedWindowKey = '' } = props;
|
||||
const componentName = getPrefixCls('biz-video-player-card', customizePrefixCls);
|
||||
const [cardContent, setCardContent] = useState<JSX.Element | null>(null);
|
||||
const { useToken } = theme
|
||||
|
@ -2,7 +2,6 @@ import React, { useState } from 'react';
|
||||
import { BoxSelectTree } from '@zhst/biz';
|
||||
import { treeData, boxDataSource } from './mock'
|
||||
import { Select, TreeProps, Modal, Checkbox } from 'antd';
|
||||
import { BOX_TYPE_LIST } from '../../utils/constants';
|
||||
|
||||
const { Option } = Select
|
||||
|
||||
@ -63,7 +62,10 @@ const demo = () => {
|
||||
}}
|
||||
style={{ width: '72px' }}
|
||||
>
|
||||
{BOX_TYPE_LIST.map(item => (
|
||||
{[
|
||||
{ value: '1', label: '盒子' },
|
||||
{ value: '2', label: '盒子组' }
|
||||
].map(item => (
|
||||
<Option value={item.value}>{item.label}</Option>
|
||||
))}
|
||||
</Select>
|
||||
|
@ -2,7 +2,6 @@ import React, { useState } from 'react';
|
||||
import { BoxSelectTree } from '@zhst/biz';
|
||||
import { Button, Select, TreeProps } from 'antd';
|
||||
import { FilterOutlined } from '@ant-design/icons';
|
||||
import { BOX_TYPE_LIST } from '../../utils/constants';
|
||||
import { treeData, boxDataSource } from './mock'
|
||||
|
||||
const { Option } = Select
|
||||
@ -42,7 +41,10 @@ const demo = () => {
|
||||
}}
|
||||
style={{ width: '72px' }}
|
||||
>
|
||||
{BOX_TYPE_LIST.map(item => (
|
||||
{[
|
||||
{ value: '1', label: '盒子' },
|
||||
{ value: '2', label: '盒子组' }
|
||||
].map(item => (
|
||||
<Option value={item.value}>{item.label}</Option>
|
||||
))}
|
||||
</Select>
|
||||
|
@ -1,4 +1,5 @@
|
||||
//@ts-nocheck
|
||||
// !! 不允许使用,只是拿来参考!!!!!
|
||||
import * as turf from '@turf/turf';
|
||||
import { getListTaskStatus, getCameraStatusFunc } from '../useTaskState';
|
||||
import Tree from '@common/components/CameraTree/Tree';
|
||||
|
@ -10,6 +10,8 @@ export { default as TreeTransferModal } from './treeTransferModal'
|
||||
export type { TreeTransferModalProps } from './treeTransferModal'
|
||||
export { default as WarningRecordCard } from './WarningRecordCard'
|
||||
export type { IRecord, WarningRecordCardProps } from './WarningRecordCard'
|
||||
export { default as OdModal } from './odModal'
|
||||
export type { ODModalProps } from './odModal'
|
||||
export type { ViewLargerImageModalRef, ViewLargerImageModalProps } from './ViewLargerImageModal'
|
||||
export { default as ViewLargerImageModal, useViewLargerImageModal } from './ViewLargerImageModal'
|
||||
export type { VideoPlayerCardProps } from './VideoPlayerCard'
|
||||
|
140
packages/biz/src/odModal/OdModal.tsx
Normal file
140
packages/biz/src/odModal/OdModal.tsx
Normal file
@ -0,0 +1,140 @@
|
||||
import React, { forwardRef, useContext, useImperativeHandle, useRef } from 'react';
|
||||
import { Button, Modal, ModalProps, Select, SelectProps, Space, theme } from 'antd';
|
||||
import { ConfigProvider, CropperImage, Scanner, CropperImageProps, CropperImageRefProps } from '@zhst/meta'
|
||||
import { IconFont } from '@zhst/icon'
|
||||
|
||||
export interface ODModalProps extends ModalProps {
|
||||
prefixCls?: string;
|
||||
open?: boolean; // 弹框显示
|
||||
editAble?: boolean;
|
||||
odWidth?: string;
|
||||
odHeight?: string;
|
||||
scanning?: boolean;
|
||||
url?: string;
|
||||
odList?: CropperImageProps['odList']
|
||||
|
||||
onTypeSelect?: SelectProps['onSelect'];
|
||||
selectOptions?: SelectProps['options']
|
||||
selectDefaultValue?: string | number;
|
||||
selectedType?: string | number;
|
||||
onHandSelect?: () => void;
|
||||
onAutoSelect?: () => void;
|
||||
onReset?: () => void;
|
||||
onOdSelect?: CropperImageProps['onShapeSelected']
|
||||
onCropEnd?: CropperImageProps['onCropEnd']
|
||||
onRotate?: () => void;
|
||||
handSelectDisable?: boolean;
|
||||
autoSelectDisable?: boolean;
|
||||
resetDisable?: boolean;
|
||||
selectTypeDisable?: boolean;
|
||||
showRotateButton?: boolean;
|
||||
|
||||
customButtons?: React.ReactNode
|
||||
modalProps?: ModalProps
|
||||
cropperImageProps?: CropperImageProps
|
||||
}
|
||||
|
||||
export interface ODModalRefProps {
|
||||
rotateTo?: (val: number) => void;
|
||||
}
|
||||
|
||||
const { ConfigContext } = ConfigProvider
|
||||
const { useToken } = theme
|
||||
|
||||
const ODModal = forwardRef<ODModalRefProps, ODModalProps>((props, ref) => {
|
||||
const {
|
||||
prefixCls: customizePrefixCls,
|
||||
open,
|
||||
title,
|
||||
editAble,
|
||||
scanning,
|
||||
okText,
|
||||
cancelText,
|
||||
url,
|
||||
odList,
|
||||
selectDefaultValue = 1,
|
||||
selectedType,
|
||||
selectOptions,
|
||||
odWidth = '470px',
|
||||
odHeight = '388px',
|
||||
onCancel,
|
||||
onOk,
|
||||
onAutoSelect,
|
||||
onHandSelect,
|
||||
onReset,
|
||||
onTypeSelect,
|
||||
onOdSelect,
|
||||
onCropEnd,
|
||||
onRotate,
|
||||
resetDisable,
|
||||
autoSelectDisable,
|
||||
handSelectDisable,
|
||||
selectTypeDisable,
|
||||
showRotateButton,
|
||||
customButtons,
|
||||
modalProps,
|
||||
cropperImageProps
|
||||
} = props
|
||||
const { getPrefixCls } = useContext(ConfigContext);
|
||||
const { token } = useToken()
|
||||
const cropperImageRef = useRef<CropperImageRefProps>(null)
|
||||
const componentName = getPrefixCls('od-modal', customizePrefixCls);
|
||||
|
||||
useImperativeHandle(ref, () => ({
|
||||
rotateTo: (val = 90) => {
|
||||
cropperImageRef.current?.rotateTo?.(val)
|
||||
}
|
||||
}))
|
||||
|
||||
return (
|
||||
<Modal
|
||||
title={title}
|
||||
open={open}
|
||||
cancelText={cancelText || "取消"}
|
||||
okText={okText || '确认'}
|
||||
onCancel={onCancel}
|
||||
onOk={onOk}
|
||||
{...modalProps}
|
||||
className={componentName}
|
||||
>
|
||||
<Space size={12} direction='vertical' align='center' style={{ textAlign: 'center' }}>
|
||||
<Scanner style={{ width: odWidth, height: odHeight }} visible={scanning}>
|
||||
<CropperImage
|
||||
type='rect'
|
||||
odList={odList}
|
||||
editAble={editAble}
|
||||
url={url}
|
||||
onShapeSelected={onOdSelect}
|
||||
onCropEnd={onCropEnd}
|
||||
showToast={editAble}
|
||||
ref={cropperImageRef}
|
||||
{...cropperImageProps}
|
||||
/>
|
||||
</Scanner>
|
||||
{customButtons ? (
|
||||
customButtons
|
||||
): (
|
||||
<Space size={1} align='center' style={{ textAlign: 'center' }}>
|
||||
<div>
|
||||
选中类型:
|
||||
<Select
|
||||
style={{ width: '90px' }}
|
||||
defaultValue={selectDefaultValue}
|
||||
value={selectedType}
|
||||
options={selectOptions}
|
||||
disabled={selectTypeDisable}
|
||||
onSelect={onTypeSelect}
|
||||
/>
|
||||
</div>
|
||||
<Button disabled={handSelectDisable} size='small' type="link" onClick={onHandSelect}><IconFont icon="icon-shoudongkuangxuan" /> 手动框选</Button>
|
||||
<Button disabled={autoSelectDisable} size='small' type="link" onClick={onAutoSelect}><IconFont icon="icon-zidong" /> 自动框选</Button>
|
||||
<Button disabled={resetDisable} size='small' type="link" onClick={onReset}><IconFont icon="icon-zhongzhi3" /> 重置</Button>
|
||||
{showRotateButton && <IconFont onIconClick={onRotate} styles={{ marginLeft: '6px' }} color={token.colorPrimary} icon="icon-xuanzhuan1" />}
|
||||
</Space>
|
||||
)}
|
||||
</Space>
|
||||
</Modal>
|
||||
);
|
||||
});
|
||||
|
||||
export default ODModal;
|
84
packages/biz/src/odModal/demo/basic.tsx
Normal file
84
packages/biz/src/odModal/demo/basic.tsx
Normal file
@ -0,0 +1,84 @@
|
||||
import React, { useState, useRef } from 'react';
|
||||
import { OdModal } from '@zhst/biz';
|
||||
import { CropperImageProps } from '@zhst/meta';
|
||||
import { Button } from 'antd';
|
||||
|
||||
const options = [
|
||||
{ value: 1, label: '形体' },
|
||||
{ value: 2, label: '非机动车' },
|
||||
]
|
||||
|
||||
const initialODList = [
|
||||
{
|
||||
"id": "123",
|
||||
"x": 0.5519352,
|
||||
"y": 0.2965385,
|
||||
"w": 0.05185461,
|
||||
"h": 0.24698898,
|
||||
selectAble: false,
|
||||
},
|
||||
{
|
||||
"id": "456",
|
||||
"x": 0.58543766,
|
||||
"y": 0.3203356,
|
||||
"w": 0.052037954,
|
||||
"h": 0.2664015
|
||||
}
|
||||
]
|
||||
|
||||
const demo = () => {
|
||||
const odModalRef = useRef(null)
|
||||
const [open, setOpen] = useState(true)
|
||||
const [scanning, setScanning] = useState(false)
|
||||
const [editAble, setEditable] = useState(false)
|
||||
const [paintType, setPaintType] = useState<'hand' | 'auto'>('auto')
|
||||
const [selectedType, setSelectedType] = useState(1)
|
||||
const [odList, setOdList] = useState<CropperImageProps['odList']>(initialODList)
|
||||
|
||||
return (
|
||||
<div style={{ width: '320px' }}>
|
||||
<Button onClick={() => setOpen(true)} >打开弹框</Button>
|
||||
<OdModal
|
||||
ref={odModalRef}
|
||||
open={open}
|
||||
scanning={scanning}
|
||||
title="请选择目标"
|
||||
url={'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png'}
|
||||
odList={odList}
|
||||
okText={scanning ? '关闭扫描' : '扫描'}
|
||||
onCancel={() => setOpen(false)}
|
||||
onOk={() => {
|
||||
setScanning(pre => !pre)
|
||||
}}
|
||||
editAble={editAble}
|
||||
selectOptions={options}
|
||||
selectedType={selectedType}
|
||||
onOdSelect={(id, _shapeData) => console.log('od', id, _shapeData)}
|
||||
onAutoSelect={() => {
|
||||
setEditable(false)
|
||||
setOdList(initialODList)
|
||||
setPaintType('auto')
|
||||
}}
|
||||
onHandSelect={() => {
|
||||
setEditable(true)
|
||||
setPaintType('hand')
|
||||
}}
|
||||
showRotateButton={paintType === 'hand'}
|
||||
selectTypeDisable={paintType === 'auto'}
|
||||
handSelectDisable={paintType === 'hand'}
|
||||
autoSelectDisable={paintType === 'auto'}
|
||||
onCropEnd={_cropData => console.log('结束绘制:', _cropData)}
|
||||
onReset={() => console.log('重置')}
|
||||
onRotate={() => console.log('旋转', odModalRef.current.rotateTo(90))}
|
||||
onTypeSelect={(val) => {
|
||||
if (val === 1) {
|
||||
|
||||
}
|
||||
setSelectedType(val)
|
||||
}}
|
||||
/>
|
||||
</div>
|
||||
);
|
||||
};
|
||||
|
||||
export default demo;
|
19
packages/biz/src/odModal/index.md
Normal file
19
packages/biz/src/odModal/index.md
Normal file
@ -0,0 +1,19 @@
|
||||
---
|
||||
category: Components
|
||||
title: OD 识别弹框
|
||||
toc: content
|
||||
demo:
|
||||
cols: 4
|
||||
group:
|
||||
title: 数据展示
|
||||
---
|
||||
|
||||
|
||||
## 代码演示
|
||||
|
||||
<code src="./demo/basic.tsx">基本用法</code>
|
||||
|
||||
## API
|
||||
|
||||
| 参数 | 说明 | 类型 | 默认值 | 版本 |
|
||||
| --- | --- | --- | --- | --- |
|
6
packages/biz/src/odModal/index.tsx
Normal file
6
packages/biz/src/odModal/index.tsx
Normal file
@ -0,0 +1,6 @@
|
||||
import OdModal from './OdModal';
|
||||
|
||||
|
||||
export type { ODModalProps } from './OdModal'
|
||||
|
||||
export default OdModal;
|
@ -1,7 +1,6 @@
|
||||
import React, { FC, useState } from 'react';
|
||||
import { Modal, ModalProps, Radio, RadioGroupProps, Select, SelectProps, TransferProps, TreeDataNode, TreeProps } from 'antd';
|
||||
import TreeTransfer from '../treeTransfer';
|
||||
import { ALL_LIST, BOX_TYPE_LIST } from '../utils/constants';
|
||||
|
||||
export interface TreeTransferModalProps {
|
||||
dataSource: TreeDataNode[]
|
||||
@ -62,13 +61,18 @@ const TreeTransferModal: FC<TreeTransferModalProps> = (props) => {
|
||||
}}
|
||||
style={{ marginLeft: '24px', padding: '20px 0' }}
|
||||
value={type}
|
||||
options={BOX_TYPE_LIST}
|
||||
options={[
|
||||
{ value: '1', label: '盒子' },
|
||||
{ value: '2', label: '盒子组' }
|
||||
]}
|
||||
{...radioProps}
|
||||
/>
|
||||
<Select
|
||||
defaultValue={''}
|
||||
style={{ marginLeft: 200, width: 150 }}
|
||||
options={ALL_LIST}
|
||||
options={[
|
||||
{ value: '', label: '全部' }
|
||||
]}
|
||||
onSelect={onSelect}
|
||||
{...selectProps}
|
||||
/>
|
||||
|
@ -1,3 +1,5 @@
|
||||
// !! 参考文件,后续会删除
|
||||
|
||||
export const OBJECT_GRNER_THRESHOLD = 0.8; //目标图判断性别阈值
|
||||
export const OBJECT_AGE_TYPE_THRESHOLD = 0.5; //目标图判断年龄段阈值
|
||||
export const MODE_KEY = 'test_mode';
|
||||
@ -13,25 +15,3 @@ export const GLOBAL_IS_BOX_VMS_SHOW = true; //是否展示盒子vms
|
||||
|
||||
export const BODY_SEARCH_THRESHOID = 0.45; //形体检索阈值
|
||||
export const RECORD_VERSION = '3.0.0'; //保存记录的版本号
|
||||
|
||||
export const DeviceTab = {
|
||||
EMPTY: 0,
|
||||
REAL_CAMERA: 1,
|
||||
PREPROCESS_CAMERA: 2, //摄像头列表
|
||||
TAG_CAMERA: 3, //预案列表
|
||||
HISTORY_VIDEO_GROUP: 4, //录像回放
|
||||
VIRTUAL_CAMERA: 5, //离线视频
|
||||
REAL_CAMERA_NOFACE: 6,
|
||||
REAL_CAMERA_ONLYFACE: 7,
|
||||
REAL_CAMERA_NOFACE_NOBOX_NODIRECONNECT: 8, // 只有普通摄像头,没有人脸、没有盒子、直连
|
||||
};
|
||||
|
||||
// 盒子 Tab 切换
|
||||
export const BOX_TYPE_LIST = [
|
||||
{ value: '1', label: '盒子' },
|
||||
{ value: '2', label: '盒子组' }
|
||||
]
|
||||
|
||||
export const ALL_LIST = [
|
||||
{ value: '', label: '全部' }
|
||||
]
|
||||
|
@ -1,5 +1,13 @@
|
||||
# @zhst/utils
|
||||
|
||||
## 0.10.1
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- biz:新增 od 弹框、预警图片 od;meta:新增人脸碰撞模型组件、扫描组件、termial 组件;material:新增中心连接物料
|
||||
- Updated dependencies
|
||||
- @zhst/request@0.10.1
|
||||
|
||||
## 0.10.0
|
||||
|
||||
### Minor Changes
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@zhst/func",
|
||||
"version": "0.10.0",
|
||||
"version": "0.10.1",
|
||||
"description": "函数合集",
|
||||
"keywords": [
|
||||
"hooks"
|
||||
|
@ -1,5 +1,13 @@
|
||||
# @zhst/hooks
|
||||
|
||||
## 0.9.1
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- biz:新增 od 弹框、预警图片 od;meta:新增人脸碰撞模型组件、扫描组件、termial 组件;material:新增中心连接物料
|
||||
- Updated dependencies
|
||||
- @zhst/func@0.10.1
|
||||
|
||||
## 0.9.0
|
||||
|
||||
### Minor Changes
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@zhst/hooks",
|
||||
"version": "0.9.0",
|
||||
"version": "0.9.1",
|
||||
"description": "hooks合集",
|
||||
"keywords": [
|
||||
"hooks"
|
||||
|
@ -1,5 +1,19 @@
|
||||
# @zhst/material
|
||||
|
||||
## 0.10.0
|
||||
|
||||
### Minor Changes
|
||||
|
||||
- biz:新增 od 弹框、预警图片 od;meta:新增人脸碰撞模型组件、扫描组件、termial 组件;material:新增中心连接物料
|
||||
|
||||
### Patch Changes
|
||||
|
||||
- Updated dependencies
|
||||
- @zhst/meta@0.13.0
|
||||
- @zhst/biz@0.14.0
|
||||
- @zhst/hooks@0.9.1
|
||||
- @zhst/func@0.10.1
|
||||
|
||||
## 0.9.0
|
||||
|
||||
### Minor Changes
|
||||
|
@ -1,129 +0,0 @@
|
||||
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
||||
import React, { forwardRef } from 'react';
|
||||
import { Flex, Image } from "antd";
|
||||
import theme from 'antd/es/theme';
|
||||
import { CropperImage } from '@zhst/meta';
|
||||
import { AlgorithmConfigImg, ErrorImage } from "../utils/base64Images";
|
||||
import AlgorithmTable from "./components/algorithmTable";
|
||||
import TimeTemplateTable from "./components/timeTemplateTable";
|
||||
var useToken = theme.useToken;
|
||||
var Title = function Title(props) {
|
||||
return /*#__PURE__*/React.createElement("h2", {
|
||||
style: {
|
||||
margin: '18px 16px',
|
||||
fontSize: '14px',
|
||||
color: 'rgba(0, 0, 0, 0.88)'
|
||||
}
|
||||
}, props.children);
|
||||
};
|
||||
var AlgorithmConfig = /*#__PURE__*/forwardRef(function (props) {
|
||||
var _props$algorithmTable = props.algorithmTableDataSource,
|
||||
algorithmTableDataSource = _props$algorithmTable === void 0 ? [] : _props$algorithmTable,
|
||||
_props$timeTemplateDa = props.timeTemplateDataSource,
|
||||
timeTemplateDataSource = _props$timeTemplateDa === void 0 ? [] : _props$timeTemplateDa,
|
||||
_props$boxList = props.boxList,
|
||||
boxList = _props$boxList === void 0 ? [] : _props$boxList,
|
||||
drawListener = props.drawListener,
|
||||
_props$cropperImagePr = props.cropperImageProps,
|
||||
cropperImageProps = _props$cropperImagePr === void 0 ? {} : _props$cropperImagePr,
|
||||
algorithmTableProps = props.algorithmTableProps,
|
||||
timeTemplateTableProps = props.timeTemplateTableProps,
|
||||
selectedKey = props.selectedKey,
|
||||
_props$type = props.type,
|
||||
type = _props$type === void 0 ? 'multiple' : _props$type,
|
||||
_props$rowKey = props.rowKey,
|
||||
rowKey = _props$rowKey === void 0 ? 'id' : _props$rowKey,
|
||||
onSelect = props.onSelect,
|
||||
_props$title = props.title,
|
||||
title = _props$title === void 0 ? '盒子名称' : _props$title;
|
||||
var _useToken = useToken(),
|
||||
token = _useToken.token;
|
||||
// @ts-ignore
|
||||
var cropType = cropperImageProps.type;
|
||||
|
||||
// useImperativeHandle(ref, () => ({
|
||||
// }))
|
||||
|
||||
return /*#__PURE__*/React.createElement(Flex, {
|
||||
style: {
|
||||
border: "1px solid ".concat(token.colorBorder),
|
||||
backgroundColor: token.colorBgBase
|
||||
}
|
||||
}, /*#__PURE__*/React.createElement("div", {
|
||||
title: title,
|
||||
style: {
|
||||
width: '13.9%'
|
||||
}
|
||||
}, /*#__PURE__*/React.createElement(Title, null, title), /*#__PURE__*/React.createElement("div", {
|
||||
style: {
|
||||
borderTop: "1px solid ".concat(token.colorBorder)
|
||||
}
|
||||
}, boxList.map(function (item) {
|
||||
return /*#__PURE__*/React.createElement("p", {
|
||||
key: item.id,
|
||||
onClick: function onClick() {
|
||||
return onSelect === null || onSelect === void 0 ? void 0 : onSelect(item.id, item);
|
||||
},
|
||||
style: {
|
||||
margin: 0,
|
||||
padding: "".concat(token.paddingXXS, "px ").concat(token.paddingLG, "px"),
|
||||
cursor: 'pointer',
|
||||
// @ts-ignore
|
||||
color: selectedKey === item[rowKey] ? token.colorPrimary : token.colorText,
|
||||
// @ts-ignore
|
||||
backgroundColor: selectedKey === item[rowKey] ? token.blue1 : token.colorBgBase,
|
||||
transition: '0cancelDraw.2s ease'
|
||||
}
|
||||
}, item.name);
|
||||
}))), /*#__PURE__*/React.createElement("div", {
|
||||
style: {
|
||||
boxSizing: 'border-box',
|
||||
width: '46.3%',
|
||||
textAlign: 'center',
|
||||
borderLeft: "1px solid ".concat(token.colorBorder),
|
||||
borderRight: "1px solid ".concat(token.colorBorder)
|
||||
}
|
||||
}, type === 'single' ? /*#__PURE__*/React.createElement(CropperImage, _extends({
|
||||
type: "line",
|
||||
onCropEnd: drawListener
|
||||
}, cropperImageProps)) : /*#__PURE__*/React.createElement("div", {
|
||||
style: {
|
||||
padding: '84px'
|
||||
}
|
||||
}, /*#__PURE__*/React.createElement(Image, {
|
||||
width: '62.5%',
|
||||
src: AlgorithmConfigImg,
|
||||
preview: false,
|
||||
fallback: ErrorImage
|
||||
}), /*#__PURE__*/React.createElement("h2", null, "\u8BF7\u8FDB\u884C\u6279\u91CF\u914D\u7F6E"), /*#__PURE__*/React.createElement("ul", {
|
||||
style: {
|
||||
display: 'inline-block',
|
||||
paddingLeft: 0,
|
||||
width: '51.8%',
|
||||
listStyle: 'none',
|
||||
textAlign: 'left',
|
||||
color: token.colorTextLabel
|
||||
}
|
||||
}, /*#__PURE__*/React.createElement("li", null, "\xB7 \u76D2\u5B50\u6279\u91CF\u914D\u7F6E\u4EC5\u652F\u6301\u540C\u578B\u53F7\u76D2\u5B50\uFF1B"), /*#__PURE__*/React.createElement("li", null, "\xB7 \u91C7\u53D6\u8986\u76D6\u5F0F\u66F4\u65B0\uFF0C\u4E0D\u4FDD\u7559\u539F\u6709\u914D\u7F6E\uFF0C\u4E14\u9884\u8B66\u68C0\u6D4B\u6846\u9ED8\u8BA4\u5168\u5C4F\u8303\u56F4\uFF1B"), /*#__PURE__*/React.createElement("li", null, "\xB7 \u4EBA\u6D41\u91CF\u7EDF\u8BA1\u9ED8\u8BA4\u68C0\u6D4B\u7EBF\u4E3A\u5C4F\u5E55\u4E2D\u592E\u6A2A\u5411\u7EBF\u6761\uFF0C\u4E14\u7BAD\u5934\u6307\u5411\u4E0B\u65B9\uFF1B"), /*#__PURE__*/React.createElement("li", null, "\xB7 \u4F18\u5148\u9009\u62E9\u62C9\u6D41\u6B63\u5E38\u7684\u6444\u50CF\u5934\u3002")))), /*#__PURE__*/React.createElement("div", {
|
||||
style: {
|
||||
width: '39.8%'
|
||||
}
|
||||
}, /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(Title, null, "\u65F6\u95F4\u6A21\u677F"), /*#__PURE__*/React.createElement("div", {
|
||||
style: {
|
||||
padding: "".concat(token.paddingMD, "px ").concat(token.paddingSM, "px"),
|
||||
borderTop: "1px solid ".concat(token.colorBorder),
|
||||
borderBottom: "1px solid ".concat(token.colorBorder)
|
||||
}
|
||||
}, /*#__PURE__*/React.createElement(TimeTemplateTable, _extends({
|
||||
dataSource: timeTemplateDataSource
|
||||
}, timeTemplateTableProps)))), /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(Title, null, "\u7B97\u6CD5\u5E94\u7528"), /*#__PURE__*/React.createElement("div", {
|
||||
style: {
|
||||
padding: "".concat(token.paddingMD, "px ").concat(token.paddingSM, "px"),
|
||||
borderTop: "1px solid ".concat(token.colorBorder)
|
||||
}
|
||||
}, /*#__PURE__*/React.createElement(AlgorithmTable, _extends({
|
||||
dataSource: algorithmTableDataSource,
|
||||
tableType: type
|
||||
}, algorithmTableProps))))));
|
||||
});
|
||||
export default AlgorithmConfig;
|
File diff suppressed because one or more lines are too long
@ -1,3 +0,0 @@
|
||||
import AlgorithmTable from './AlgorithmTable';
|
||||
export type { AlgorithmTableProps } from './AlgorithmTable';
|
||||
export default AlgorithmTable;
|
@ -1,2 +0,0 @@
|
||||
import AlgorithmTable from "./AlgorithmTable";
|
||||
export default AlgorithmTable;
|
@ -1,2 +0,0 @@
|
||||
import SchemaFormModal from "./schemaFormModal";
|
||||
export default SchemaFormModal;
|
@ -1,8 +0,0 @@
|
||||
import { FC } from 'react';
|
||||
import type { ModalFormProps } from '@ant-design/pro-components';
|
||||
export interface SchemaFormModalProps extends ModalFormProps {
|
||||
type: 'fire' | 'smoke' | 'traffic' | 'face' | 'destroy' | 'wander' | 'gather' | 'cameraBlock';
|
||||
}
|
||||
export declare const SCHEME_TYPE_LIST: Map<string, string>;
|
||||
declare const SchemaFormModal: FC<SchemaFormModalProps>;
|
||||
export default SchemaFormModal;
|
@ -1,128 +0,0 @@
|
||||
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
||||
import React from 'react';
|
||||
import { BetaSchemaForm } from '@ant-design/pro-components';
|
||||
import { Input, Space } from 'antd';
|
||||
export var SCHEME_TYPE_LIST = new Map([['fire', '火焰识别'], ['smoke', '烟雾识别'], ['traffic', '人流量统计'], ['face', '面部遮挡识别'], ['destroy', '人员破坏识别'], ['wander', '人员徘徊识别'], ['gather', '人员聚集识别'], ['cameraBlock', '摄像头遮挡识别']]);
|
||||
var SchemaFormModal = function SchemaFormModal(props) {
|
||||
var _props$type = props.type,
|
||||
type = _props$type === void 0 ? 'fire' : _props$type,
|
||||
onFinish = props.onFinish;
|
||||
var getColumnsByType = function getColumnsByType(type) {
|
||||
if (!type) return [];
|
||||
var arr = [];
|
||||
if (type === 'gather') {
|
||||
arr.push({
|
||||
title: '预警人数:',
|
||||
dataIndex: 'alarmMember',
|
||||
formItemProps: {
|
||||
rules: [{
|
||||
required: true,
|
||||
message: '此项为必填项'
|
||||
}]
|
||||
},
|
||||
renderFormItem: function renderFormItem() {
|
||||
return /*#__PURE__*/React.createElement(Space, null, /*#__PURE__*/React.createElement(Input, null), "\u4EBA\uFF083~10\uFF09");
|
||||
},
|
||||
width: 'm'
|
||||
});
|
||||
}
|
||||
if (type === 'cameraBlock') {
|
||||
arr.push({
|
||||
title: '遮挡百分比:',
|
||||
dataIndex: 'blockPercent',
|
||||
formItemProps: {
|
||||
rules: [{
|
||||
required: true,
|
||||
message: '此项为必填项'
|
||||
}]
|
||||
},
|
||||
renderFormItem: function renderFormItem() {
|
||||
return /*#__PURE__*/React.createElement(Space, null, /*#__PURE__*/React.createElement(Input, null), "%\uFF0830~80\uFF09");
|
||||
},
|
||||
width: 'm'
|
||||
});
|
||||
}
|
||||
if (type !== 'traffic') {
|
||||
arr.push({
|
||||
title: '最短持续时间:',
|
||||
dataIndex: 'minTime',
|
||||
formItemProps: {
|
||||
rules: [{
|
||||
required: true,
|
||||
message: '此项为必填项'
|
||||
}]
|
||||
},
|
||||
renderFormItem: function renderFormItem() {
|
||||
return /*#__PURE__*/React.createElement(Space, null, /*#__PURE__*/React.createElement(Input, null), "\u79D2\uFF082~10\uFF09");
|
||||
},
|
||||
width: 'm'
|
||||
});
|
||||
arr.push({
|
||||
title: '报警间隔时间:',
|
||||
dataIndex: 'alarmTime',
|
||||
formItemProps: {
|
||||
rules: [{
|
||||
required: true,
|
||||
message: '此项为必填项'
|
||||
}]
|
||||
},
|
||||
renderFormItem: function renderFormItem() {
|
||||
return /*#__PURE__*/React.createElement(Space, null, /*#__PURE__*/React.createElement(Input, null), "\u79D2\uFF0810~600\uFF09");
|
||||
},
|
||||
width: 'm'
|
||||
});
|
||||
} else if (type === 'traffic') {
|
||||
arr.push({
|
||||
title: '灵敏度:',
|
||||
dataIndex: 'sensitivity',
|
||||
formItemProps: {
|
||||
rules: [{
|
||||
required: true,
|
||||
message: '此项为必填项'
|
||||
}]
|
||||
},
|
||||
renderFormItem: function renderFormItem() {
|
||||
return /*#__PURE__*/React.createElement(Space, null, /*#__PURE__*/React.createElement(Input, null), "\uFF080~100\uFF09");
|
||||
},
|
||||
width: 'm'
|
||||
});
|
||||
}
|
||||
arr.push({
|
||||
title: '灵敏度:',
|
||||
dataIndex: 'sensitivity',
|
||||
formItemProps: {
|
||||
rules: [{
|
||||
required: true,
|
||||
message: '此项为必填项'
|
||||
}]
|
||||
},
|
||||
renderFormItem: function renderFormItem() {
|
||||
return /*#__PURE__*/React.createElement(Space, null, /*#__PURE__*/React.createElement(Input, null), "\uFF080~100\uFF09");
|
||||
},
|
||||
width: 'm'
|
||||
});
|
||||
return arr;
|
||||
};
|
||||
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(BetaSchemaForm, _extends({
|
||||
width: 600
|
||||
// @ts-ignore
|
||||
,
|
||||
title: SCHEME_TYPE_LIST.get(type),
|
||||
shouldUpdate: false,
|
||||
layoutType: "ModalForm",
|
||||
layout: "horizontal",
|
||||
labelCol: {
|
||||
span: 6
|
||||
},
|
||||
wrapperCol: {
|
||||
span: 18
|
||||
},
|
||||
preserve: false,
|
||||
modalProps: {
|
||||
destroyOnClose: true
|
||||
},
|
||||
onFinish: onFinish,
|
||||
columns: getColumnsByType(type)
|
||||
}, props)));
|
||||
};
|
||||
export default SchemaFormModal;
|
@ -1,8 +0,0 @@
|
||||
import React from 'react';
|
||||
import type { ParamsType, ProTableProps } from '@ant-design/pro-components';
|
||||
import { AnyObject } from 'antd/es/_util/type';
|
||||
export interface TimeTemplateTableProps<DataSource, Params extends ParamsType = ParamsType, ValueType = "text"> extends ProTableProps<DataSource, Params, ValueType> {
|
||||
onItemBlur?: (value?: number | string, id?: any, record?: any) => void;
|
||||
}
|
||||
declare const TimeTemplateTable: <DataSource extends AnyObject = AnyObject>(props: TimeTemplateTableProps<DataSource, ParamsType, "text">) => React.JSX.Element;
|
||||
export default TimeTemplateTable;
|
@ -1,47 +0,0 @@
|
||||
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
||||
import React from 'react';
|
||||
import { ProTable } from '@ant-design/pro-components';
|
||||
import { InputNumber } from 'antd';
|
||||
var TimeTemplateTable = function TimeTemplateTable(props) {
|
||||
var onItemBlur = props.onItemBlur;
|
||||
var columns = [{
|
||||
title: '模板名称',
|
||||
dataIndex: 'templateName'
|
||||
}, {
|
||||
title: '运行周期',
|
||||
dataIndex: 'runCycle'
|
||||
}, {
|
||||
title: '布控星期',
|
||||
dataIndex: 'arrangeDay'
|
||||
}, {
|
||||
title: '算力占用',
|
||||
dataIndex: 'powerOccupy'
|
||||
}, {
|
||||
title: '配置路数',
|
||||
key: 'option',
|
||||
valueType: 'option',
|
||||
render: function render(_, record) {
|
||||
return /*#__PURE__*/React.createElement(InputNumber, {
|
||||
value: record.lineNum,
|
||||
onBlur: function onBlur(e) {
|
||||
return onItemBlur === null || onItemBlur === void 0 ? void 0 : onItemBlur(e.target.value, record.id, record);
|
||||
},
|
||||
min: 0
|
||||
});
|
||||
}
|
||||
}];
|
||||
return /*#__PURE__*/React.createElement(ProTable, _extends({
|
||||
columns: columns,
|
||||
bordered: true,
|
||||
scroll: {
|
||||
y: 95
|
||||
},
|
||||
toolbar: undefined,
|
||||
rowKey: "id",
|
||||
search: false,
|
||||
options: false,
|
||||
pagination: false,
|
||||
dataSource: []
|
||||
}, props));
|
||||
};
|
||||
export default TimeTemplateTable;
|
@ -1,3 +0,0 @@
|
||||
import TimeTemplateTable from './TimeTemplateTable';
|
||||
export type { TimeTemplateTableProps } from './TimeTemplateTable';
|
||||
export default TimeTemplateTable;
|
@ -1,2 +0,0 @@
|
||||
import TimeTemplateTable from "./TimeTemplateTable";
|
||||
export default TimeTemplateTable;
|
@ -1,5 +0,0 @@
|
||||
import AlgorithmConfig from './algorithmConfig';
|
||||
export type { AlgorithmConfigProps, AlgorithmConfigRef } from './algorithmConfig';
|
||||
export type { AlgorithmTableProps } from './components/algorithmTable';
|
||||
export type { TimeTemplateTableProps } from './components/timeTemplateTable';
|
||||
export default AlgorithmConfig;
|
@ -1,2 +0,0 @@
|
||||
import AlgorithmConfig from "./algorithmConfig";
|
||||
export default AlgorithmConfig;
|
@ -1,8 +0,0 @@
|
||||
import { FC } from 'react';
|
||||
import { ModalProps } from "antd";
|
||||
import { AlgorithmConfigProps } from '../algorithmConfig/algorithmConfig';
|
||||
export interface AlgorithmConfigModalProps extends ModalProps {
|
||||
algorithmConfigProps: AlgorithmConfigProps;
|
||||
}
|
||||
declare const AlgorithmConfigModal: FC<AlgorithmConfigModalProps>;
|
||||
export default AlgorithmConfigModal;
|
@ -1,22 +0,0 @@
|
||||
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
||||
import React from 'react';
|
||||
import { ConfigProvider, Modal } from "antd";
|
||||
import AlgorithmConfig from "../algorithmConfig/algorithmConfig";
|
||||
var AlgorithmConfigModal = function AlgorithmConfigModal(props) {
|
||||
var algorithmConfigProps = props.algorithmConfigProps;
|
||||
return /*#__PURE__*/React.createElement(ConfigProvider, {
|
||||
theme: {
|
||||
components: {
|
||||
Modal: {
|
||||
headerBg: '#EFF2F4',
|
||||
footerBg: '#EFF2F4',
|
||||
contentBg: '#EFF2F4'
|
||||
}
|
||||
}
|
||||
}
|
||||
}, /*#__PURE__*/React.createElement(Modal, _extends({
|
||||
okText: "\u786E\u5B9A",
|
||||
cancelText: "\u53D6\u6D88"
|
||||
}, props), /*#__PURE__*/React.createElement(AlgorithmConfig, algorithmConfigProps)));
|
||||
};
|
||||
export default AlgorithmConfigModal;
|
@ -1,2 +0,0 @@
|
||||
import AlgorithmConfigModal from './algorithmConfigModal';
|
||||
export default AlgorithmConfigModal;
|
@ -1,2 +0,0 @@
|
||||
import AlgorithmConfigModal from "./algorithmConfigModal";
|
||||
export default AlgorithmConfigModal;
|
@ -1,7 +0,0 @@
|
||||
export { default as AlgorithmConfigModal } from "./algorithmConfigModal";
|
||||
export { default as AlgorithmConfig } from "./algorithmConfig";
|
||||
export { default as Login } from "./login";
|
||||
export { default as Password } from "./password";
|
||||
export { default as CenterLink } from "./centerLink";
|
||||
export { default as SchemaFormModal } from "./algorithmConfig/components/schemaFormModal";
|
||||
export * from 'rc-util';
|
@ -1,125 +0,0 @@
|
||||
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
||||
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
||||
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
||||
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
||||
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
||||
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
||||
/**
|
||||
* Created by jiangzhixiong on 2024/03/18
|
||||
*/
|
||||
|
||||
import React from 'react';
|
||||
import { Button, Checkbox, Flex, Form, Image, Input, theme } from 'antd';
|
||||
import { HomeOutlined } from '@ant-design/icons';
|
||||
import { isNumber } from '@zhst/func';
|
||||
import "./index.less";
|
||||
var materialName = 'zhst-material-login';
|
||||
var useToken = theme.useToken;
|
||||
var Login = function Login(props) {
|
||||
var title = props.title,
|
||||
onIconClick = props.onIconClick,
|
||||
_props$rememberPasswo = props.rememberPassword,
|
||||
rememberPassword = _props$rememberPasswo === void 0 ? true : _props$rememberPasswo,
|
||||
imageUrl = props.imageUrl,
|
||||
width = props.width,
|
||||
height = props.height,
|
||||
onFinish = props.onFinish;
|
||||
var _Form$useForm = Form.useForm(),
|
||||
_Form$useForm2 = _slicedToArray(_Form$useForm, 1),
|
||||
form = _Form$useForm2[0];
|
||||
var _useToken = useToken(),
|
||||
token = _useToken.token;
|
||||
console.log('width', width);
|
||||
return /*#__PURE__*/React.createElement(Flex, {
|
||||
className: materialName,
|
||||
style: {
|
||||
width: isNumber(width) ? "".concat(width, "px") : width,
|
||||
height: isNumber(height) ? "".concat(height, "px") : height
|
||||
}
|
||||
}, /*#__PURE__*/React.createElement(Flex, {
|
||||
align: "center",
|
||||
justify: "center",
|
||||
style: {
|
||||
position: 'relative',
|
||||
width: '40%',
|
||||
padding: "30px"
|
||||
}
|
||||
}, /*#__PURE__*/React.createElement(HomeOutlined, {
|
||||
onClick: onIconClick,
|
||||
style: {
|
||||
position: 'absolute',
|
||||
top: '30px',
|
||||
left: '30px',
|
||||
fontSize: "".concat(token.sizeLG, "px"),
|
||||
cursor: 'pointer'
|
||||
}
|
||||
}), /*#__PURE__*/React.createElement("div", {
|
||||
style: {
|
||||
width: '56%'
|
||||
}
|
||||
}, /*#__PURE__*/React.createElement("h2", {
|
||||
style: {
|
||||
margin: '30px 0',
|
||||
fontSize: '30px'
|
||||
}
|
||||
}, title), /*#__PURE__*/React.createElement(Form, {
|
||||
layout: "vertical",
|
||||
form: form,
|
||||
onFinish: onFinish
|
||||
}, /*#__PURE__*/React.createElement(Form.Item, {
|
||||
name: "account",
|
||||
label: "\u8D26\u53F7",
|
||||
rules: [{
|
||||
required: true,
|
||||
message: '请输入账号!'
|
||||
}]
|
||||
}, /*#__PURE__*/React.createElement(Input, {
|
||||
placeholder: "\u8BF7\u8F93\u5165\u8D26\u53F7",
|
||||
variant: "borderless",
|
||||
style: {
|
||||
border: 'none',
|
||||
borderBottom: '1px solid rgba(0, 0, 0, 0.06)'
|
||||
}
|
||||
})), /*#__PURE__*/React.createElement(Form.Item, {
|
||||
name: "password",
|
||||
label: "\u5BC6\u7801",
|
||||
rules: [{
|
||||
required: true,
|
||||
message: '请输入密码!'
|
||||
}]
|
||||
}, /*#__PURE__*/React.createElement(Input.Password, {
|
||||
placeholder: "\u8BF7\u8F93\u5165\u5BC6\u7801",
|
||||
variant: "borderless",
|
||||
style: {
|
||||
border: 'none',
|
||||
borderBottom: '1px solid rgba(0, 0, 0, 0.06)'
|
||||
}
|
||||
})), /*#__PURE__*/React.createElement(Form.Item, {
|
||||
style: {
|
||||
display: rememberPassword ? 'block' : 'none'
|
||||
}
|
||||
}, /*#__PURE__*/React.createElement(Form.Item, {
|
||||
name: "remember",
|
||||
valuePropName: "checked",
|
||||
noStyle: true
|
||||
}, /*#__PURE__*/React.createElement(Checkbox, null, "\u8BB0\u4F4F\u5BC6\u7801"))), /*#__PURE__*/React.createElement(Form.Item, null, /*#__PURE__*/React.createElement(Button, {
|
||||
block: true,
|
||||
type: "primary",
|
||||
htmlType: "submit"
|
||||
}, "\u767B\u5F55"))))), /*#__PURE__*/React.createElement("div", {
|
||||
style: {
|
||||
width: '60%',
|
||||
height: '100%'
|
||||
}
|
||||
}, /*#__PURE__*/React.createElement(Image, {
|
||||
style: {
|
||||
width: '100%'
|
||||
},
|
||||
src: imageUrl,
|
||||
width: '100%',
|
||||
height: '100%',
|
||||
preview: false,
|
||||
fallback: ""
|
||||
})));
|
||||
};
|
||||
export default Login;
|
Binary file not shown.
Before Width: | Height: | Size: 1024 KiB |
Binary file not shown.
Before Width: | Height: | Size: 921 KiB |
Binary file not shown.
Before Width: | Height: | Size: 845 KiB |
2
packages/material/es/login/index.d.ts
vendored
2
packages/material/es/login/index.d.ts
vendored
@ -1,2 +0,0 @@
|
||||
import Login from './Login';
|
||||
export default Login;
|
@ -1,2 +0,0 @@
|
||||
import Login from "./Login";
|
||||
export default Login;
|
11
packages/material/es/password/Password.d.ts
vendored
11
packages/material/es/password/Password.d.ts
vendored
@ -1,11 +0,0 @@
|
||||
/**
|
||||
* Created by jiangzhixiong on 2024/03/18
|
||||
*/
|
||||
import { FC } from 'react';
|
||||
import { FormProps } from 'antd';
|
||||
interface PasswordProps {
|
||||
onFinish: FormProps['onFinish'];
|
||||
onCancel: () => void;
|
||||
}
|
||||
declare const Password: FC<PasswordProps>;
|
||||
export default Password;
|
@ -1,101 +0,0 @@
|
||||
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
||||
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
||||
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
||||
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
||||
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
||||
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
||||
/**
|
||||
* Created by jiangzhixiong on 2024/03/18
|
||||
*/
|
||||
|
||||
import React from 'react';
|
||||
import { Button, Form, Input, Space } from 'antd';
|
||||
var Password = function Password(props) {
|
||||
var onFinish = props.onFinish,
|
||||
onCancel = props.onCancel;
|
||||
var _Form$useForm = Form.useForm(),
|
||||
_Form$useForm2 = _slicedToArray(_Form$useForm, 1),
|
||||
form = _Form$useForm2[0];
|
||||
return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("h2", {
|
||||
style: {
|
||||
marginTop: '0',
|
||||
fontSize: '20px'
|
||||
}
|
||||
}, "\u4FEE\u6539\u5BC6\u7801"), /*#__PURE__*/React.createElement(Form, {
|
||||
labelCol: {
|
||||
span: 4
|
||||
},
|
||||
wrapperCol: {
|
||||
span: 20
|
||||
},
|
||||
form: form,
|
||||
onFinish: onFinish
|
||||
}, /*#__PURE__*/React.createElement(Form.Item, {
|
||||
name: "password",
|
||||
label: "\u539F\u5BC6\u7801",
|
||||
rules: [{
|
||||
required: true,
|
||||
message: '请输入密码!'
|
||||
}]
|
||||
}, /*#__PURE__*/React.createElement(Input.Password, {
|
||||
variant: "borderless",
|
||||
style: {
|
||||
border: 'none',
|
||||
borderBottom: '1px solid rgba(0, 0, 0, 0.06)'
|
||||
}
|
||||
})), /*#__PURE__*/React.createElement(Form.Item, {
|
||||
name: "newPassword",
|
||||
label: "\u65B0\u5BC6\u7801",
|
||||
rules: [{
|
||||
required: true,
|
||||
message: '请输入新密码!'
|
||||
}]
|
||||
}, /*#__PURE__*/React.createElement(Input.Password, {
|
||||
variant: "borderless",
|
||||
style: {
|
||||
border: 'none',
|
||||
borderBottom: '1px solid rgba(0, 0, 0, 0.06)'
|
||||
}
|
||||
})), /*#__PURE__*/React.createElement(Form.Item, {
|
||||
name: "rePassword",
|
||||
label: "\u786E\u8BA4\u5BC6\u7801",
|
||||
dependencies: ['password'],
|
||||
rules: [{
|
||||
required: true,
|
||||
message: '请再次输入密码!'
|
||||
}, function (_ref) {
|
||||
var getFieldValue = _ref.getFieldValue;
|
||||
return {
|
||||
validator: function validator(_, value) {
|
||||
if (!value || getFieldValue('password') === value) {
|
||||
return Promise.resolve();
|
||||
}
|
||||
return Promise.reject(new Error('两次输入的密码不一致!'));
|
||||
}
|
||||
};
|
||||
}]
|
||||
}, /*#__PURE__*/React.createElement(Input.Password, {
|
||||
variant: "borderless",
|
||||
style: {
|
||||
border: 'none',
|
||||
borderBottom: '1px solid rgba(0, 0, 0, 0.06)'
|
||||
}
|
||||
})), /*#__PURE__*/React.createElement("div", {
|
||||
style: {
|
||||
textAlign: 'right'
|
||||
}
|
||||
}, /*#__PURE__*/React.createElement(Space, null, /*#__PURE__*/React.createElement(Button, {
|
||||
htmlType: "reset",
|
||||
onClick: onCancel,
|
||||
style: {
|
||||
width: '100px'
|
||||
}
|
||||
}, "\u53D6\u6D88"), /*#__PURE__*/React.createElement(Button, {
|
||||
type: "primary",
|
||||
htmlType: "submit",
|
||||
style: {
|
||||
width: '100px'
|
||||
}
|
||||
}, "\u786E\u8BA4")))));
|
||||
};
|
||||
export default Password;
|
2
packages/material/es/password/index.d.ts
vendored
2
packages/material/es/password/index.d.ts
vendored
@ -1,2 +0,0 @@
|
||||
import Password from './Password';
|
||||
export default Password;
|
@ -1,2 +0,0 @@
|
||||
import Password from "./Password";
|
||||
export default Password;
|
2
packages/material/es/utils/base64Images.d.ts
vendored
2
packages/material/es/utils/base64Images.d.ts
vendored
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
1
packages/material/es/utils/index.d.ts
vendored
1
packages/material/es/utils/index.d.ts
vendored
@ -1 +0,0 @@
|
||||
export declare const createAElement: (url: string, isBlank: boolean) => void;
|
@ -1,14 +0,0 @@
|
||||
// 可应用于页面跳转以及文件下载
|
||||
// 第一个参数:文件的下载路径/要跳转页面的路径(可携带参数)
|
||||
// 第二个参数:是否新打开一个页面,true为新开一个页面,false是在当前页面进行操作;
|
||||
export var createAElement = function createAElement(url, isBlank) {
|
||||
var newLink = document.createElement('a');
|
||||
newLink.className = 'create-link';
|
||||
newLink.href = url;
|
||||
if (isBlank) {
|
||||
newLink.target = '_blank';
|
||||
}
|
||||
document.body.appendChild(newLink);
|
||||
newLink.click();
|
||||
document.body.removeChild(newLink);
|
||||
};
|
1
packages/material/es/utils/types.d.ts
vendored
1
packages/material/es/utils/types.d.ts
vendored
@ -1 +0,0 @@
|
||||
export type AnyObject = Record<PropertyKey, any>;
|
@ -1 +0,0 @@
|
||||
export {};
|
@ -1,110 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/algorithmConfig/algorithmConfig.tsx
|
||||
var algorithmConfig_exports = {};
|
||||
__export(algorithmConfig_exports, {
|
||||
default: () => algorithmConfig_default
|
||||
});
|
||||
module.exports = __toCommonJS(algorithmConfig_exports);
|
||||
var import_react = __toESM(require("react"));
|
||||
var import_antd = require("antd");
|
||||
var import_theme = __toESM(require("antd/es/theme"));
|
||||
var import_meta = require("@zhst/meta");
|
||||
var import_base64Images = require("../utils/base64Images");
|
||||
var import_algorithmTable = __toESM(require("./components/algorithmTable"));
|
||||
var import_timeTemplateTable = __toESM(require("./components/timeTemplateTable"));
|
||||
var { useToken } = import_theme.default;
|
||||
var Title = (props) => /* @__PURE__ */ import_react.default.createElement("h2", { style: { margin: "18px 16px", fontSize: "14px", color: "rgba(0, 0, 0, 0.88)" } }, props.children);
|
||||
var AlgorithmConfig = (0, import_react.forwardRef)((props) => {
|
||||
const {
|
||||
algorithmTableDataSource = [],
|
||||
timeTemplateDataSource = [],
|
||||
boxList = [],
|
||||
drawListener,
|
||||
cropperImageProps = {},
|
||||
algorithmTableProps,
|
||||
timeTemplateTableProps,
|
||||
selectedKey,
|
||||
type = "multiple",
|
||||
rowKey = "id",
|
||||
onSelect,
|
||||
title = "盒子名称"
|
||||
} = props;
|
||||
const { token } = useToken();
|
||||
const { type: cropType } = cropperImageProps;
|
||||
return /* @__PURE__ */ import_react.default.createElement(import_antd.Flex, { style: { border: `1px solid ${token.colorBorder}`, backgroundColor: token.colorBgBase } }, /* @__PURE__ */ import_react.default.createElement("div", { title, style: { width: "13.9%" } }, /* @__PURE__ */ import_react.default.createElement(Title, null, title), /* @__PURE__ */ import_react.default.createElement("div", { style: { borderTop: `1px solid ${token.colorBorder}` } }, boxList.map((item) => {
|
||||
return /* @__PURE__ */ import_react.default.createElement(
|
||||
"p",
|
||||
{
|
||||
key: item.id,
|
||||
onClick: () => onSelect == null ? void 0 : onSelect(item.id, item),
|
||||
style: {
|
||||
margin: 0,
|
||||
padding: `${token.paddingXXS}px ${token.paddingLG}px`,
|
||||
cursor: "pointer",
|
||||
// @ts-ignore
|
||||
color: selectedKey === item[rowKey] ? token.colorPrimary : token.colorText,
|
||||
// @ts-ignore
|
||||
backgroundColor: selectedKey === item[rowKey] ? token.blue1 : token.colorBgBase,
|
||||
transition: "0cancelDraw.2s ease"
|
||||
}
|
||||
},
|
||||
item.name
|
||||
);
|
||||
}))), /* @__PURE__ */ import_react.default.createElement("div", { style: { boxSizing: "border-box", width: "46.3%", textAlign: "center", borderLeft: `1px solid ${token.colorBorder}`, borderRight: `1px solid ${token.colorBorder}` } }, type === "single" ? /* @__PURE__ */ import_react.default.createElement(
|
||||
import_meta.CropperImage,
|
||||
{
|
||||
type: "line",
|
||||
onCropEnd: drawListener,
|
||||
...cropperImageProps
|
||||
}
|
||||
) : /* @__PURE__ */ import_react.default.createElement("div", { style: { padding: "84px" } }, /* @__PURE__ */ import_react.default.createElement(
|
||||
import_antd.Image,
|
||||
{
|
||||
width: "62.5%",
|
||||
src: import_base64Images.AlgorithmConfigImg,
|
||||
preview: false,
|
||||
fallback: import_base64Images.ErrorImage
|
||||
}
|
||||
), /* @__PURE__ */ import_react.default.createElement("h2", null, "请进行批量配置"), /* @__PURE__ */ import_react.default.createElement("ul", { style: { display: "inline-block", paddingLeft: 0, width: "51.8%", listStyle: "none", textAlign: "left", color: token.colorTextLabel } }, /* @__PURE__ */ import_react.default.createElement("li", null, "· 盒子批量配置仅支持同型号盒子;"), /* @__PURE__ */ import_react.default.createElement("li", null, "· 采取覆盖式更新,不保留原有配置,且预警检测框默认全屏范围;"), /* @__PURE__ */ import_react.default.createElement("li", null, "· 人流量统计默认检测线为屏幕中央横向线条,且箭头指向下方;"), /* @__PURE__ */ import_react.default.createElement("li", null, "· 优先选择拉流正常的摄像头。")))), /* @__PURE__ */ import_react.default.createElement("div", { style: { width: "39.8%" } }, /* @__PURE__ */ import_react.default.createElement("div", null, /* @__PURE__ */ import_react.default.createElement(Title, null, "时间模板"), /* @__PURE__ */ import_react.default.createElement("div", { style: { padding: `${token.paddingMD}px ${token.paddingSM}px`, borderTop: `1px solid ${token.colorBorder}`, borderBottom: `1px solid ${token.colorBorder}` } }, /* @__PURE__ */ import_react.default.createElement(
|
||||
import_timeTemplateTable.default,
|
||||
{
|
||||
dataSource: timeTemplateDataSource,
|
||||
...timeTemplateTableProps
|
||||
}
|
||||
))), /* @__PURE__ */ import_react.default.createElement("div", null, /* @__PURE__ */ import_react.default.createElement(Title, null, "算法应用"), /* @__PURE__ */ import_react.default.createElement("div", { style: { padding: `${token.paddingMD}px ${token.paddingSM}px`, borderTop: `1px solid ${token.colorBorder}` } }, /* @__PURE__ */ import_react.default.createElement(
|
||||
import_algorithmTable.default,
|
||||
{
|
||||
dataSource: algorithmTableDataSource,
|
||||
tableType: type,
|
||||
...algorithmTableProps
|
||||
}
|
||||
)))));
|
||||
});
|
||||
var algorithmConfig_default = AlgorithmConfig;
|
@ -1,126 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/algorithmConfig/components/algorithmTable/AlgorithmTable.tsx
|
||||
var AlgorithmTable_exports = {};
|
||||
__export(AlgorithmTable_exports, {
|
||||
default: () => AlgorithmTable_default
|
||||
});
|
||||
module.exports = __toCommonJS(AlgorithmTable_exports);
|
||||
var import_react = __toESM(require("react"));
|
||||
var import_icons = require("@ant-design/icons");
|
||||
var import_pro_components = require("@ant-design/pro-components");
|
||||
var import_antd = require("antd");
|
||||
var import_theme = __toESM(require("antd/es/theme"));
|
||||
var import_schemaFormModal = __toESM(require("../schemaFormModal"));
|
||||
var { useToken } = import_theme.default;
|
||||
var AlgorithmTable = (props) => {
|
||||
const {
|
||||
onAddAlgorithm,
|
||||
onItemSwitch,
|
||||
onItemEdit,
|
||||
onItemDelete,
|
||||
onSortSelect,
|
||||
selectedKey,
|
||||
onDraw,
|
||||
tableType = "multiple",
|
||||
sortList = []
|
||||
} = props;
|
||||
const { token } = useToken();
|
||||
const columns = [
|
||||
{
|
||||
title: "算法名称",
|
||||
dataIndex: "templateName"
|
||||
},
|
||||
{
|
||||
title: "运行周期",
|
||||
dataIndex: "runCycle",
|
||||
valueType: "select",
|
||||
width: 80,
|
||||
valueEnum: {
|
||||
1: { text: "黑夜" },
|
||||
0: { text: "白天" }
|
||||
}
|
||||
},
|
||||
{
|
||||
title: "算力占用",
|
||||
dataIndex: "powerOccupy"
|
||||
},
|
||||
{
|
||||
title: "操作",
|
||||
key: "option",
|
||||
valueType: "option",
|
||||
fixed: true,
|
||||
render: (_DOM, record) => [
|
||||
/* @__PURE__ */ import_react.default.createElement(import_antd.Switch, { value: record.status, onChange: (_status) => onItemSwitch == null ? void 0 : onItemSwitch(_status, record.id, record) }),
|
||||
/* @__PURE__ */ import_react.default.createElement("a", { onClick: () => onDraw == null ? void 0 : onDraw(record.id, record), style: { display: tableType === "single" ? "block" : "none" }, href: "#" }, /* @__PURE__ */ import_react.default.createElement(import_icons.ImportOutlined, null)),
|
||||
/* @__PURE__ */ import_react.default.createElement(
|
||||
import_schemaFormModal.default,
|
||||
{
|
||||
type: record.templateType,
|
||||
onFinish: async (values) => onItemEdit == null ? void 0 : onItemEdit(values, record),
|
||||
trigger: /* @__PURE__ */ import_react.default.createElement("a", { href: "#" }, /* @__PURE__ */ import_react.default.createElement(import_icons.EditFilled, null))
|
||||
}
|
||||
),
|
||||
/* @__PURE__ */ import_react.default.createElement(
|
||||
import_antd.Popconfirm,
|
||||
{
|
||||
title: "确定删除吗?",
|
||||
onConfirm: () => onItemDelete == null ? void 0 : onItemDelete(record.id, record)
|
||||
},
|
||||
/* @__PURE__ */ import_react.default.createElement("a", { href: "#" }, /* @__PURE__ */ import_react.default.createElement(import_icons.DeleteFilled, null))
|
||||
)
|
||||
]
|
||||
}
|
||||
];
|
||||
return /* @__PURE__ */ import_react.default.createElement(
|
||||
import_pro_components.ProTable,
|
||||
{
|
||||
columns,
|
||||
bordered: true,
|
||||
scroll: { y: 240 },
|
||||
dataSource: [],
|
||||
headerTitle: /* @__PURE__ */ import_react.default.createElement(import_antd.Space, { size: 16 }, /* @__PURE__ */ import_react.default.createElement(
|
||||
import_antd.Select,
|
||||
{
|
||||
value: selectedKey,
|
||||
style: { width: 320 },
|
||||
onChange: onSortSelect,
|
||||
options: sortList
|
||||
}
|
||||
), /* @__PURE__ */ import_react.default.createElement(import_icons.PlusCircleFilled, { onClick: () => onAddAlgorithm == null ? void 0 : onAddAlgorithm(), style: { fontSize: "24px", color: token.colorPrimary, cursor: "pointer" } })),
|
||||
toolbar: void 0,
|
||||
rowKey: "id",
|
||||
search: false,
|
||||
options: false,
|
||||
pagination: false,
|
||||
...props
|
||||
}
|
||||
);
|
||||
};
|
||||
var AlgorithmTable_default = AlgorithmTable;
|
@ -1,3 +0,0 @@
|
||||
import AlgorithmTable from './AlgorithmTable';
|
||||
export type { AlgorithmTableProps } from './AlgorithmTable';
|
||||
export default AlgorithmTable;
|
@ -1,36 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/algorithmConfig/components/algorithmTable/index.tsx
|
||||
var algorithmTable_exports = {};
|
||||
__export(algorithmTable_exports, {
|
||||
default: () => algorithmTable_default
|
||||
});
|
||||
module.exports = __toCommonJS(algorithmTable_exports);
|
||||
var import_AlgorithmTable = __toESM(require("./AlgorithmTable"));
|
||||
var algorithmTable_default = import_AlgorithmTable.default;
|
@ -1,36 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/algorithmConfig/components/schemaFormModal/index.tsx
|
||||
var schemaFormModal_exports = {};
|
||||
__export(schemaFormModal_exports, {
|
||||
default: () => schemaFormModal_default
|
||||
});
|
||||
module.exports = __toCommonJS(schemaFormModal_exports);
|
||||
var import_schemaFormModal = __toESM(require("./schemaFormModal"));
|
||||
var schemaFormModal_default = import_schemaFormModal.default;
|
@ -1,8 +0,0 @@
|
||||
import { FC } from 'react';
|
||||
import type { ModalFormProps } from '@ant-design/pro-components';
|
||||
export interface SchemaFormModalProps extends ModalFormProps {
|
||||
type: 'fire' | 'smoke' | 'traffic' | 'face' | 'destroy' | 'wander' | 'gather' | 'cameraBlock';
|
||||
}
|
||||
export declare const SCHEME_TYPE_LIST: Map<string, string>;
|
||||
declare const SchemaFormModal: FC<SchemaFormModalProps>;
|
||||
export default SchemaFormModal;
|
@ -1,173 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/algorithmConfig/components/schemaFormModal/schemaFormModal.tsx
|
||||
var schemaFormModal_exports = {};
|
||||
__export(schemaFormModal_exports, {
|
||||
SCHEME_TYPE_LIST: () => SCHEME_TYPE_LIST,
|
||||
default: () => schemaFormModal_default
|
||||
});
|
||||
module.exports = __toCommonJS(schemaFormModal_exports);
|
||||
var import_react = __toESM(require("react"));
|
||||
var import_pro_components = require("@ant-design/pro-components");
|
||||
var import_antd = require("antd");
|
||||
var SCHEME_TYPE_LIST = /* @__PURE__ */ new Map([
|
||||
["fire", "火焰识别"],
|
||||
["smoke", "烟雾识别"],
|
||||
["traffic", "人流量统计"],
|
||||
["face", "面部遮挡识别"],
|
||||
["destroy", "人员破坏识别"],
|
||||
["wander", "人员徘徊识别"],
|
||||
["gather", "人员聚集识别"],
|
||||
["cameraBlock", "摄像头遮挡识别"]
|
||||
]);
|
||||
var SchemaFormModal = (props) => {
|
||||
const {
|
||||
type = "fire",
|
||||
onFinish
|
||||
} = props;
|
||||
const getColumnsByType = (type2) => {
|
||||
if (!type2)
|
||||
return [];
|
||||
let arr = [];
|
||||
if (type2 === "gather") {
|
||||
arr.push({
|
||||
title: "预警人数:",
|
||||
dataIndex: "alarmMember",
|
||||
formItemProps: {
|
||||
rules: [
|
||||
{
|
||||
required: true,
|
||||
message: "此项为必填项"
|
||||
}
|
||||
]
|
||||
},
|
||||
renderFormItem: () => /* @__PURE__ */ import_react.default.createElement(import_antd.Space, null, /* @__PURE__ */ import_react.default.createElement(import_antd.Input, null), "人(3~10)"),
|
||||
width: "m"
|
||||
});
|
||||
}
|
||||
if (type2 === "cameraBlock") {
|
||||
arr.push({
|
||||
title: "遮挡百分比:",
|
||||
dataIndex: "blockPercent",
|
||||
formItemProps: {
|
||||
rules: [
|
||||
{
|
||||
required: true,
|
||||
message: "此项为必填项"
|
||||
}
|
||||
]
|
||||
},
|
||||
renderFormItem: () => /* @__PURE__ */ import_react.default.createElement(import_antd.Space, null, /* @__PURE__ */ import_react.default.createElement(import_antd.Input, null), "%(30~80)"),
|
||||
width: "m"
|
||||
});
|
||||
}
|
||||
if (type2 !== "traffic") {
|
||||
arr.push({
|
||||
title: "最短持续时间:",
|
||||
dataIndex: "minTime",
|
||||
formItemProps: {
|
||||
rules: [
|
||||
{
|
||||
required: true,
|
||||
message: "此项为必填项"
|
||||
}
|
||||
]
|
||||
},
|
||||
renderFormItem: () => /* @__PURE__ */ import_react.default.createElement(import_antd.Space, null, /* @__PURE__ */ import_react.default.createElement(import_antd.Input, null), "秒(2~10)"),
|
||||
width: "m"
|
||||
});
|
||||
arr.push({
|
||||
title: "报警间隔时间:",
|
||||
dataIndex: "alarmTime",
|
||||
formItemProps: {
|
||||
rules: [
|
||||
{
|
||||
required: true,
|
||||
message: "此项为必填项"
|
||||
}
|
||||
]
|
||||
},
|
||||
renderFormItem: () => /* @__PURE__ */ import_react.default.createElement(import_antd.Space, null, /* @__PURE__ */ import_react.default.createElement(import_antd.Input, null), "秒(10~600)"),
|
||||
width: "m"
|
||||
});
|
||||
} else if (type2 === "traffic") {
|
||||
arr.push({
|
||||
title: "灵敏度:",
|
||||
dataIndex: "sensitivity",
|
||||
formItemProps: {
|
||||
rules: [
|
||||
{
|
||||
required: true,
|
||||
message: "此项为必填项"
|
||||
}
|
||||
]
|
||||
},
|
||||
renderFormItem: () => /* @__PURE__ */ import_react.default.createElement(import_antd.Space, null, /* @__PURE__ */ import_react.default.createElement(import_antd.Input, null), "(0~100)"),
|
||||
width: "m"
|
||||
});
|
||||
}
|
||||
arr.push({
|
||||
title: "灵敏度:",
|
||||
dataIndex: "sensitivity",
|
||||
formItemProps: {
|
||||
rules: [
|
||||
{
|
||||
required: true,
|
||||
message: "此项为必填项"
|
||||
}
|
||||
]
|
||||
},
|
||||
renderFormItem: () => /* @__PURE__ */ import_react.default.createElement(import_antd.Space, null, /* @__PURE__ */ import_react.default.createElement(import_antd.Input, null), "(0~100)"),
|
||||
width: "m"
|
||||
});
|
||||
return arr;
|
||||
};
|
||||
return /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(
|
||||
import_pro_components.BetaSchemaForm,
|
||||
{
|
||||
width: 600,
|
||||
title: SCHEME_TYPE_LIST.get(type),
|
||||
shouldUpdate: false,
|
||||
layoutType: "ModalForm",
|
||||
layout: "horizontal",
|
||||
labelCol: { span: 6 },
|
||||
wrapperCol: { span: 18 },
|
||||
preserve: false,
|
||||
modalProps: { destroyOnClose: true },
|
||||
onFinish,
|
||||
columns: getColumnsByType(type),
|
||||
...props
|
||||
}
|
||||
));
|
||||
};
|
||||
var schemaFormModal_default = SchemaFormModal;
|
||||
// Annotate the CommonJS export names for ESM import in node:
|
||||
0 && (module.exports = {
|
||||
SCHEME_TYPE_LIST
|
||||
});
|
@ -1,8 +0,0 @@
|
||||
import React from 'react';
|
||||
import type { ParamsType, ProTableProps } from '@ant-design/pro-components';
|
||||
import { AnyObject } from 'antd/es/_util/type';
|
||||
export interface TimeTemplateTableProps<DataSource, Params extends ParamsType = ParamsType, ValueType = "text"> extends ProTableProps<DataSource, Params, ValueType> {
|
||||
onItemBlur?: (value?: number | string, id?: any, record?: any) => void;
|
||||
}
|
||||
declare const TimeTemplateTable: <DataSource extends AnyObject = AnyObject>(props: TimeTemplateTableProps<DataSource, ParamsType, "text">) => React.JSX.Element;
|
||||
export default TimeTemplateTable;
|
@ -1,82 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/algorithmConfig/components/timeTemplateTable/TimeTemplateTable.tsx
|
||||
var TimeTemplateTable_exports = {};
|
||||
__export(TimeTemplateTable_exports, {
|
||||
default: () => TimeTemplateTable_default
|
||||
});
|
||||
module.exports = __toCommonJS(TimeTemplateTable_exports);
|
||||
var import_react = __toESM(require("react"));
|
||||
var import_pro_components = require("@ant-design/pro-components");
|
||||
var import_antd = require("antd");
|
||||
var TimeTemplateTable = (props) => {
|
||||
const {
|
||||
onItemBlur
|
||||
} = props;
|
||||
const columns = [
|
||||
{
|
||||
title: "模板名称",
|
||||
dataIndex: "templateName"
|
||||
},
|
||||
{
|
||||
title: "运行周期",
|
||||
dataIndex: "runCycle"
|
||||
},
|
||||
{
|
||||
title: "布控星期",
|
||||
dataIndex: "arrangeDay"
|
||||
},
|
||||
{
|
||||
title: "算力占用",
|
||||
dataIndex: "powerOccupy"
|
||||
},
|
||||
{
|
||||
title: "配置路数",
|
||||
key: "option",
|
||||
valueType: "option",
|
||||
render: (_, record) => /* @__PURE__ */ import_react.default.createElement(import_antd.InputNumber, { value: record.lineNum, onBlur: (e) => onItemBlur == null ? void 0 : onItemBlur(e.target.value, record.id, record), min: 0 })
|
||||
}
|
||||
];
|
||||
return /* @__PURE__ */ import_react.default.createElement(
|
||||
import_pro_components.ProTable,
|
||||
{
|
||||
columns,
|
||||
bordered: true,
|
||||
scroll: { y: 95 },
|
||||
toolbar: void 0,
|
||||
rowKey: "id",
|
||||
search: false,
|
||||
options: false,
|
||||
pagination: false,
|
||||
dataSource: [],
|
||||
...props
|
||||
}
|
||||
);
|
||||
};
|
||||
var TimeTemplateTable_default = TimeTemplateTable;
|
@ -1,3 +0,0 @@
|
||||
import TimeTemplateTable from './TimeTemplateTable';
|
||||
export type { TimeTemplateTableProps } from './TimeTemplateTable';
|
||||
export default TimeTemplateTable;
|
@ -1,36 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/algorithmConfig/components/timeTemplateTable/index.tsx
|
||||
var timeTemplateTable_exports = {};
|
||||
__export(timeTemplateTable_exports, {
|
||||
default: () => timeTemplateTable_default
|
||||
});
|
||||
module.exports = __toCommonJS(timeTemplateTable_exports);
|
||||
var import_TimeTemplateTable = __toESM(require("./TimeTemplateTable"));
|
||||
var timeTemplateTable_default = import_TimeTemplateTable.default;
|
@ -1,5 +0,0 @@
|
||||
import AlgorithmConfig from './algorithmConfig';
|
||||
export type { AlgorithmConfigProps, AlgorithmConfigRef } from './algorithmConfig';
|
||||
export type { AlgorithmTableProps } from './components/algorithmTable';
|
||||
export type { TimeTemplateTableProps } from './components/timeTemplateTable';
|
||||
export default AlgorithmConfig;
|
@ -1,36 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/algorithmConfig/index.tsx
|
||||
var algorithmConfig_exports = {};
|
||||
__export(algorithmConfig_exports, {
|
||||
default: () => algorithmConfig_default
|
||||
});
|
||||
module.exports = __toCommonJS(algorithmConfig_exports);
|
||||
var import_algorithmConfig = __toESM(require("./algorithmConfig"));
|
||||
var algorithmConfig_default = import_algorithmConfig.default;
|
@ -1,8 +0,0 @@
|
||||
import { FC } from 'react';
|
||||
import { ModalProps } from "antd";
|
||||
import { AlgorithmConfigProps } from '../algorithmConfig/algorithmConfig';
|
||||
export interface AlgorithmConfigModalProps extends ModalProps {
|
||||
algorithmConfigProps: AlgorithmConfigProps;
|
||||
}
|
||||
declare const AlgorithmConfigModal: FC<AlgorithmConfigModalProps>;
|
||||
export default AlgorithmConfigModal;
|
@ -1,71 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/algorithmConfigModal/algorithmConfigModal.tsx
|
||||
var algorithmConfigModal_exports = {};
|
||||
__export(algorithmConfigModal_exports, {
|
||||
default: () => algorithmConfigModal_default
|
||||
});
|
||||
module.exports = __toCommonJS(algorithmConfigModal_exports);
|
||||
var import_react = __toESM(require("react"));
|
||||
var import_antd = require("antd");
|
||||
var import_algorithmConfig = __toESM(require("../algorithmConfig/algorithmConfig"));
|
||||
var AlgorithmConfigModal = (props) => {
|
||||
const {
|
||||
algorithmConfigProps
|
||||
} = props;
|
||||
return /* @__PURE__ */ import_react.default.createElement(
|
||||
import_antd.ConfigProvider,
|
||||
{
|
||||
theme: {
|
||||
components: {
|
||||
Modal: {
|
||||
headerBg: "#EFF2F4",
|
||||
footerBg: "#EFF2F4",
|
||||
contentBg: "#EFF2F4"
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
/* @__PURE__ */ import_react.default.createElement(
|
||||
import_antd.Modal,
|
||||
{
|
||||
okText: "确定",
|
||||
cancelText: "取消",
|
||||
...props
|
||||
},
|
||||
/* @__PURE__ */ import_react.default.createElement(
|
||||
import_algorithmConfig.default,
|
||||
{
|
||||
...algorithmConfigProps
|
||||
}
|
||||
)
|
||||
)
|
||||
);
|
||||
};
|
||||
var algorithmConfigModal_default = AlgorithmConfigModal;
|
@ -1,2 +0,0 @@
|
||||
import AlgorithmConfigModal from './algorithmConfigModal';
|
||||
export default AlgorithmConfigModal;
|
@ -1,36 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/algorithmConfigModal/index.tsx
|
||||
var algorithmConfigModal_exports = {};
|
||||
__export(algorithmConfigModal_exports, {
|
||||
default: () => algorithmConfigModal_default
|
||||
});
|
||||
module.exports = __toCommonJS(algorithmConfigModal_exports);
|
||||
var import_algorithmConfigModal = __toESM(require("./algorithmConfigModal"));
|
||||
var algorithmConfigModal_default = import_algorithmConfigModal.default;
|
@ -1,57 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/index.tsx
|
||||
var src_exports = {};
|
||||
__export(src_exports, {
|
||||
AlgorithmConfig: () => import_algorithmConfig.default,
|
||||
AlgorithmConfigModal: () => import_algorithmConfigModal.default,
|
||||
CenterLink: () => import_centerLink.default,
|
||||
Login: () => import_login.default,
|
||||
Password: () => import_password.default,
|
||||
SchemaFormModal: () => import_schemaFormModal.default
|
||||
});
|
||||
module.exports = __toCommonJS(src_exports);
|
||||
var import_algorithmConfigModal = __toESM(require("./algorithmConfigModal"));
|
||||
var import_algorithmConfig = __toESM(require("./algorithmConfig"));
|
||||
var import_login = __toESM(require("./login"));
|
||||
var import_password = __toESM(require("./password"));
|
||||
var import_centerLink = __toESM(require("./centerLink"));
|
||||
var import_schemaFormModal = __toESM(require("./algorithmConfig/components/schemaFormModal"));
|
||||
__reExport(src_exports, require("rc-util"), module.exports);
|
||||
// Annotate the CommonJS export names for ESM import in node:
|
||||
0 && (module.exports = {
|
||||
AlgorithmConfig,
|
||||
AlgorithmConfigModal,
|
||||
CenterLink,
|
||||
Login,
|
||||
Password,
|
||||
SchemaFormModal,
|
||||
...require("rc-util")
|
||||
});
|
@ -1,110 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/login/Login.tsx
|
||||
var Login_exports = {};
|
||||
__export(Login_exports, {
|
||||
default: () => Login_default
|
||||
});
|
||||
module.exports = __toCommonJS(Login_exports);
|
||||
var import_react = __toESM(require("react"));
|
||||
var import_antd = require("antd");
|
||||
var import_icons = require("@ant-design/icons");
|
||||
var import_func = require("@zhst/func");
|
||||
var import_index = require("./index.less");
|
||||
var materialName = "zhst-material-login";
|
||||
var { useToken } = import_antd.theme;
|
||||
var Login = (props) => {
|
||||
const {
|
||||
title,
|
||||
onIconClick,
|
||||
rememberPassword = true,
|
||||
imageUrl,
|
||||
width,
|
||||
height,
|
||||
onFinish
|
||||
} = props;
|
||||
const [form] = import_antd.Form.useForm();
|
||||
const { token } = useToken();
|
||||
console.log("width", width);
|
||||
return /* @__PURE__ */ import_react.default.createElement(import_antd.Flex, { className: materialName, style: { width: (0, import_func.isNumber)(width) ? `${width}px` : width, height: (0, import_func.isNumber)(height) ? `${height}px` : height } }, /* @__PURE__ */ import_react.default.createElement(import_antd.Flex, { align: "center", justify: "center", style: { position: "relative", width: "40%", padding: `30px` } }, /* @__PURE__ */ import_react.default.createElement(
|
||||
import_icons.HomeOutlined,
|
||||
{
|
||||
onClick: onIconClick,
|
||||
style: {
|
||||
position: "absolute",
|
||||
top: "30px",
|
||||
left: "30px",
|
||||
fontSize: `${token.sizeLG}px`,
|
||||
cursor: "pointer"
|
||||
}
|
||||
}
|
||||
), /* @__PURE__ */ import_react.default.createElement("div", { style: { width: "56%" } }, /* @__PURE__ */ import_react.default.createElement("h2", { style: { margin: "30px 0", fontSize: "30px" } }, title), /* @__PURE__ */ import_react.default.createElement(
|
||||
import_antd.Form,
|
||||
{
|
||||
layout: "vertical",
|
||||
form,
|
||||
onFinish
|
||||
},
|
||||
/* @__PURE__ */ import_react.default.createElement(
|
||||
import_antd.Form.Item,
|
||||
{
|
||||
name: "account",
|
||||
label: "账号",
|
||||
rules: [
|
||||
{ required: true, message: "请输入账号!" }
|
||||
]
|
||||
},
|
||||
/* @__PURE__ */ import_react.default.createElement(import_antd.Input, { placeholder: "请输入账号", variant: "borderless", style: { border: "none", borderBottom: "1px solid rgba(0, 0, 0, 0.06)" } })
|
||||
),
|
||||
/* @__PURE__ */ import_react.default.createElement(
|
||||
import_antd.Form.Item,
|
||||
{
|
||||
name: "password",
|
||||
label: "密码",
|
||||
rules: [
|
||||
{ required: true, message: "请输入密码!" }
|
||||
]
|
||||
},
|
||||
/* @__PURE__ */ import_react.default.createElement(import_antd.Input.Password, { placeholder: "请输入密码", variant: "borderless", style: { border: "none", borderBottom: "1px solid rgba(0, 0, 0, 0.06)" } })
|
||||
),
|
||||
/* @__PURE__ */ import_react.default.createElement(import_antd.Form.Item, { style: { display: rememberPassword ? "block" : "none" } }, /* @__PURE__ */ import_react.default.createElement(import_antd.Form.Item, { name: "remember", valuePropName: "checked", noStyle: true }, /* @__PURE__ */ import_react.default.createElement(import_antd.Checkbox, null, "记住密码"))),
|
||||
/* @__PURE__ */ import_react.default.createElement(import_antd.Form.Item, null, /* @__PURE__ */ import_react.default.createElement(import_antd.Button, { block: true, type: "primary", htmlType: "submit" }, "登录"))
|
||||
))), /* @__PURE__ */ import_react.default.createElement("div", { style: { width: "60%", height: "100%" } }, /* @__PURE__ */ import_react.default.createElement(
|
||||
import_antd.Image,
|
||||
{
|
||||
style: { width: "100%" },
|
||||
src: imageUrl,
|
||||
width: "100%",
|
||||
height: "100%",
|
||||
preview: false,
|
||||
fallback: ""
|
||||
}
|
||||
)));
|
||||
};
|
||||
var Login_default = Login;
|
Binary file not shown.
Before Width: | Height: | Size: 1024 KiB |
Binary file not shown.
Before Width: | Height: | Size: 921 KiB |
Binary file not shown.
Before Width: | Height: | Size: 845 KiB |
2
packages/material/lib/login/index.d.ts
vendored
2
packages/material/lib/login/index.d.ts
vendored
@ -1,2 +0,0 @@
|
||||
import Login from './Login';
|
||||
export default Login;
|
@ -1,36 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/login/index.tsx
|
||||
var login_exports = {};
|
||||
__export(login_exports, {
|
||||
default: () => login_default
|
||||
});
|
||||
module.exports = __toCommonJS(login_exports);
|
||||
var import_Login = __toESM(require("./Login"));
|
||||
var login_default = import_Login.default;
|
11
packages/material/lib/password/Password.d.ts
vendored
11
packages/material/lib/password/Password.d.ts
vendored
@ -1,11 +0,0 @@
|
||||
/**
|
||||
* Created by jiangzhixiong on 2024/03/18
|
||||
*/
|
||||
import { FC } from 'react';
|
||||
import { FormProps } from 'antd';
|
||||
interface PasswordProps {
|
||||
onFinish: FormProps['onFinish'];
|
||||
onCancel: () => void;
|
||||
}
|
||||
declare const Password: FC<PasswordProps>;
|
||||
export default Password;
|
@ -1,96 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/password/Password.tsx
|
||||
var Password_exports = {};
|
||||
__export(Password_exports, {
|
||||
default: () => Password_default
|
||||
});
|
||||
module.exports = __toCommonJS(Password_exports);
|
||||
var import_react = __toESM(require("react"));
|
||||
var import_antd = require("antd");
|
||||
var Password = (props) => {
|
||||
const {
|
||||
onFinish,
|
||||
onCancel
|
||||
} = props;
|
||||
const [form] = import_antd.Form.useForm();
|
||||
return /* @__PURE__ */ import_react.default.createElement("div", null, /* @__PURE__ */ import_react.default.createElement("h2", { style: { marginTop: "0", fontSize: "20px" } }, "修改密码"), /* @__PURE__ */ import_react.default.createElement(
|
||||
import_antd.Form,
|
||||
{
|
||||
labelCol: { span: 4 },
|
||||
wrapperCol: { span: 20 },
|
||||
form,
|
||||
onFinish
|
||||
},
|
||||
/* @__PURE__ */ import_react.default.createElement(
|
||||
import_antd.Form.Item,
|
||||
{
|
||||
name: "password",
|
||||
label: "原密码",
|
||||
rules: [
|
||||
{ required: true, message: "请输入密码!" }
|
||||
]
|
||||
},
|
||||
/* @__PURE__ */ import_react.default.createElement(import_antd.Input.Password, { variant: "borderless", style: { border: "none", borderBottom: "1px solid rgba(0, 0, 0, 0.06)" } })
|
||||
),
|
||||
/* @__PURE__ */ import_react.default.createElement(
|
||||
import_antd.Form.Item,
|
||||
{
|
||||
name: "newPassword",
|
||||
label: "新密码",
|
||||
rules: [
|
||||
{ required: true, message: "请输入新密码!" }
|
||||
]
|
||||
},
|
||||
/* @__PURE__ */ import_react.default.createElement(import_antd.Input.Password, { variant: "borderless", style: { border: "none", borderBottom: "1px solid rgba(0, 0, 0, 0.06)" } })
|
||||
),
|
||||
/* @__PURE__ */ import_react.default.createElement(
|
||||
import_antd.Form.Item,
|
||||
{
|
||||
name: "rePassword",
|
||||
label: "确认密码",
|
||||
dependencies: ["password"],
|
||||
rules: [
|
||||
{ required: true, message: "请再次输入密码!" },
|
||||
({ getFieldValue }) => ({
|
||||
validator(_, value) {
|
||||
if (!value || getFieldValue("password") === value) {
|
||||
return Promise.resolve();
|
||||
}
|
||||
return Promise.reject(new Error("两次输入的密码不一致!"));
|
||||
}
|
||||
})
|
||||
]
|
||||
},
|
||||
/* @__PURE__ */ import_react.default.createElement(import_antd.Input.Password, { variant: "borderless", style: { border: "none", borderBottom: "1px solid rgba(0, 0, 0, 0.06)" } })
|
||||
),
|
||||
/* @__PURE__ */ import_react.default.createElement("div", { style: { textAlign: "right" } }, /* @__PURE__ */ import_react.default.createElement(import_antd.Space, null, /* @__PURE__ */ import_react.default.createElement(import_antd.Button, { htmlType: "reset", onClick: onCancel, style: { width: "100px" } }, "取消"), /* @__PURE__ */ import_react.default.createElement(import_antd.Button, { type: "primary", htmlType: "submit", style: { width: "100px" } }, "确认")))
|
||||
));
|
||||
};
|
||||
var Password_default = Password;
|
2
packages/material/lib/password/index.d.ts
vendored
2
packages/material/lib/password/index.d.ts
vendored
@ -1,2 +0,0 @@
|
||||
import Password from './Password';
|
||||
export default Password;
|
@ -1,36 +0,0 @@
|
||||
var __create = Object.create;
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __getProtoOf = Object.getPrototypeOf;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
||||
// If the importer is in node compatibility mode or this is not an ESM
|
||||
// file that has been converted to a CommonJS file using a Babel-
|
||||
// compatible transform (i.e. "__esModule" has not been set), then set
|
||||
// "default" to the CommonJS "module.exports" for node compatibility.
|
||||
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
||||
mod
|
||||
));
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/password/index.tsx
|
||||
var password_exports = {};
|
||||
__export(password_exports, {
|
||||
default: () => password_default
|
||||
});
|
||||
module.exports = __toCommonJS(password_exports);
|
||||
var import_Password = __toESM(require("./Password"));
|
||||
var password_default = import_Password.default;
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
1
packages/material/lib/utils/index.d.ts
vendored
1
packages/material/lib/utils/index.d.ts
vendored
@ -1 +0,0 @@
|
||||
export declare const createAElement: (url: string, isBlank: boolean) => void;
|
@ -1,39 +0,0 @@
|
||||
var __defProp = Object.defineProperty;
|
||||
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
||||
var __getOwnPropNames = Object.getOwnPropertyNames;
|
||||
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
||||
var __export = (target, all) => {
|
||||
for (var name in all)
|
||||
__defProp(target, name, { get: all[name], enumerable: true });
|
||||
};
|
||||
var __copyProps = (to, from, except, desc) => {
|
||||
if (from && typeof from === "object" || typeof from === "function") {
|
||||
for (let key of __getOwnPropNames(from))
|
||||
if (!__hasOwnProp.call(to, key) && key !== except)
|
||||
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
||||
}
|
||||
return to;
|
||||
};
|
||||
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
||||
|
||||
// src/utils/index.ts
|
||||
var utils_exports = {};
|
||||
__export(utils_exports, {
|
||||
createAElement: () => createAElement
|
||||
});
|
||||
module.exports = __toCommonJS(utils_exports);
|
||||
var createAElement = (url, isBlank) => {
|
||||
var newLink = document.createElement("a");
|
||||
newLink.className = "create-link";
|
||||
newLink.href = url;
|
||||
if (isBlank) {
|
||||
newLink.target = "_blank";
|
||||
}
|
||||
document.body.appendChild(newLink);
|
||||
newLink.click();
|
||||
document.body.removeChild(newLink);
|
||||
};
|
||||
// Annotate the CommonJS export names for ESM import in node:
|
||||
0 && (module.exports = {
|
||||
createAElement
|
||||
});
|
1
packages/material/lib/utils/types.d.ts
vendored
1
packages/material/lib/utils/types.d.ts
vendored
@ -1 +0,0 @@
|
||||
export type AnyObject = Record<PropertyKey, any>;
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user