forked from ddrilling/asb_cloud_front
Текст в поле WellTreeSelector изменён на
Месторождение / Куст / Скважина
This commit is contained in:
parent
33ae4293cb
commit
997b701be4
@ -1,32 +1,33 @@
|
|||||||
import { TreeSelect } from 'antd'
|
import { TreeSelect } from 'antd'
|
||||||
import { useState, useEffect } from 'react'
|
import { DefaultValueType } from 'rc-tree-select/lib/interface'
|
||||||
|
import { useState, useEffect, ReactNode } from 'react'
|
||||||
import { useHistory, useRouteMatch } from 'react-router-dom'
|
import { useHistory, useRouteMatch } from 'react-router-dom'
|
||||||
import LoaderPortal from './LoaderPortal'
|
import LoaderPortal from './LoaderPortal'
|
||||||
import { DepositService } from '../services/api'
|
import { DepositService } from '../services/api'
|
||||||
import { invokeWebApiWrapperAsync } from './factory'
|
import { invokeWebApiWrapperAsync } from './factory'
|
||||||
import '../styles/wellTreeSelect.css'
|
import { WellIcon, WellIconState } from './icons'
|
||||||
import { WellIcon, WellIconState } from './icons/WellIcon'
|
|
||||||
import { ReactComponent as DepositIcon } from '../images/DepositIcon.svg'
|
import { ReactComponent as DepositIcon } from '../images/DepositIcon.svg'
|
||||||
import { ReactComponent as ClusterIcon } from '../images/ClusterIcon.svg'
|
import { ReactComponent as ClusterIcon } from '../images/ClusterIcon.svg'
|
||||||
import { DepositDto } from '../services/api'
|
import { DepositDto } from '../services/api'
|
||||||
import { RawDate } from '../utils/DateTimeUtils'
|
import { RawDate } from '../utils/DateTimeUtils'
|
||||||
|
import '../styles/wellTreeSelect.css'
|
||||||
|
|
||||||
export const getWellState = (idState?: number): WellIconState => idState === 1 ? 'active' : 'unknown'
|
export const getWellState = (idState?: number): WellIconState => idState === 1 ? 'active' : 'unknown'
|
||||||
export const checkIsWellOnline = (lastTelemetryDate?: RawDate): boolean => {
|
export const checkIsWellOnline = (lastTelemetryDate?: RawDate): boolean => {
|
||||||
if (!lastTelemetryDate) return false
|
if (!lastTelemetryDate || isNaN(+new Date(lastTelemetryDate))) return false
|
||||||
return Date.now() - +new Date(lastTelemetryDate) < 600_000
|
return Date.now() - +new Date(lastTelemetryDate) < 600_000
|
||||||
}
|
}
|
||||||
|
|
||||||
interface TreeNodeData {
|
export type TreeNodeData = {
|
||||||
title?: string | null
|
title?: string | null
|
||||||
key?: string
|
key?: string
|
||||||
value?: string
|
value?: DefaultValueType
|
||||||
icon?: React.ReactNode
|
icon?: ReactNode
|
||||||
children?: TreeNodeData[]
|
children?: TreeNodeData[]
|
||||||
}
|
}
|
||||||
|
|
||||||
export const WellTreeSelector = () => {
|
export const WellTreeSelector = () => {
|
||||||
const [wellsTree, setWellsTree] = useState<TreeNodeData[]>([])
|
const [wellsTree, setWellsTree] = useState<any>([]) // TODO: Исправить тип (необходимо разобраться с типом значения rc-select)
|
||||||
const [showLoader, setShowLoader] = useState<boolean>(false)
|
const [showLoader, setShowLoader] = useState<boolean>(false)
|
||||||
const history = useHistory()
|
const history = useHistory()
|
||||||
const routeMatch = useRouteMatch('/:route/:id')
|
const routeMatch = useRouteMatch('/:route/:id')
|
||||||
@ -38,17 +39,26 @@ export const WellTreeSelector = () => {
|
|||||||
const wellsTree: TreeNodeData[] = deposits.map(deposit =>({
|
const wellsTree: TreeNodeData[] = deposits.map(deposit =>({
|
||||||
title: deposit.caption,
|
title: deposit.caption,
|
||||||
key: `/deposit/${deposit.id}`,
|
key: `/deposit/${deposit.id}`,
|
||||||
value: `/deposit/${deposit.id}`,
|
value: {
|
||||||
|
value: `/deposit/${deposit.id}`,
|
||||||
|
label: deposit.caption,
|
||||||
|
},
|
||||||
icon: <DepositIcon width={24} height={24}/>,
|
icon: <DepositIcon width={24} height={24}/>,
|
||||||
children: deposit.clusters?.map(cluster => ({
|
children: deposit.clusters?.map(cluster => ({
|
||||||
title: cluster.caption,
|
title: cluster.caption,
|
||||||
key: `/cluster/${cluster.id}`,
|
key: `/cluster/${cluster.id}`,
|
||||||
value: `/cluster/${cluster.id}`,
|
value: {
|
||||||
|
value: `/cluster/${cluster.id}`,
|
||||||
|
label: `${deposit.caption} / ${cluster.caption}`,
|
||||||
|
},
|
||||||
icon: <ClusterIcon width={24} height={24}/>,
|
icon: <ClusterIcon width={24} height={24}/>,
|
||||||
children: cluster.wells?.map(well => ({
|
children: cluster.wells?.map(well => ({
|
||||||
title: well.caption,
|
title: well.caption,
|
||||||
key: `/well/${well.id}`,
|
key: `/well/${well.id}`,
|
||||||
value: `/well/${well.id}`,
|
value: {
|
||||||
|
value: `/well/${well.id}`,
|
||||||
|
label: `${deposit.caption} / ${cluster.caption} / ${well.caption}`
|
||||||
|
},
|
||||||
icon: <WellIcon
|
icon: <WellIcon
|
||||||
width={24}
|
width={24}
|
||||||
height={24}
|
height={24}
|
||||||
@ -72,6 +82,7 @@ export const WellTreeSelector = () => {
|
|||||||
return (
|
return (
|
||||||
<LoaderPortal show={showLoader}>
|
<LoaderPortal show={showLoader}>
|
||||||
<TreeSelect
|
<TreeSelect
|
||||||
|
labelInValue
|
||||||
treeIcon
|
treeIcon
|
||||||
className={'header-tree-select'}
|
className={'header-tree-select'}
|
||||||
bordered={false}
|
bordered={false}
|
||||||
|
Loading…
Reference in New Issue
Block a user