From b94a949617020fd57d67260fe4d809272205e965 Mon Sep 17 00:00:00 2001 From: Boris Sekachev <40690378+bsekachev@users.noreply.github.com> Date: Wed, 8 Apr 2020 10:45:31 +0300 Subject: [PATCH] React UI: Added message when share is empty or not mounted (#1373) * Added message when share is empty or not mounted * Updated changelog * Update CHANGELOG.md Co-authored-by: Nikita Manovich <40690625+nmanovic@users.noreply.github.com> --- CHANGELOG.md | 3 +- .../create-model-content.tsx | 24 +++++----- cvat-ui/src/components/feedback/feedback.tsx | 45 +++++++++---------- .../components/file-manager/file-manager.tsx | 35 ++++++++++----- .../src/components/file-manager/styles.scss | 6 +++ .../global-error-boundary.tsx | 3 +- cvat-ui/src/components/header/header.tsx | 26 ++++++----- cvat-ui/src/consts.ts | 18 ++++++++ 8 files changed, 98 insertions(+), 62 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index c0966b228f18..40b823f093db 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,7 +10,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - Dialog window with some helpful information about using filters - Ability to display a bitmap in the new UI - Button to reset colors settings (brightness, saturation, contrast) in the new UI -- Added option to display shape text always +- Option to display shape text always +- Dedicated message with clarifications when share is unmounted (https://github.com/opencv/cvat/pull/1373) ### Changed - Increase preview size of a task till 256, 256 on the server diff --git a/cvat-ui/src/components/create-model-page/create-model-content.tsx b/cvat-ui/src/components/create-model-page/create-model-content.tsx index 03efda5fff98..a320b805643f 100644 --- a/cvat-ui/src/components/create-model-page/create-model-content.tsx +++ b/cvat-ui/src/components/create-model-page/create-model-content.tsx @@ -3,20 +3,16 @@ // SPDX-License-Identifier: MIT import React from 'react'; - -import { - Row, - Col, - Icon, - Alert, - Button, - Tooltip, - message, - notification, -} from 'antd'; - +import { Row, Col } from 'antd/lib/grid'; +import Icon from 'antd/lib/icon'; +import Alert from 'antd/lib/alert'; +import Button from 'antd/lib/button'; +import Tooltip from 'antd/lib/tooltip'; +import message from 'antd/lib/message'; +import notification from 'antd/lib/notification'; import Text from 'antd/lib/typography/Text'; +import consts from 'consts'; import ConnectedFileManager, { FileManagerContainer, } from 'containers/file-manager/file-manager'; @@ -107,7 +103,7 @@ export default class CreateModelContent extends React.PureComponent { const status = modelCreatingStatus && modelCreatingStatus !== 'CREATED' ? modelCreatingStatus : ''; - const guideLink = 'https://github.com/opencv/cvat/blob/develop/cvat/apps/auto_annotation/README.md'; + const { AUTO_ANNOTATION_GUIDE_URL } = consts; return ( @@ -116,7 +112,7 @@ export default class CreateModelContent extends React.PureComponent { onClick={(): void => { // false positive // eslint-disable-next-line - window.open(guideLink, '_blank'); + window.open(AUTO_ANNOTATION_GUIDE_URL, '_blank'); }} type='question-circle' /> diff --git a/cvat-ui/src/components/feedback/feedback.tsx b/cvat-ui/src/components/feedback/feedback.tsx index b61ba1f549ec..cc1869c720c3 100644 --- a/cvat-ui/src/components/feedback/feedback.tsx +++ b/cvat-ui/src/components/feedback/feedback.tsx @@ -4,13 +4,10 @@ import './styles.scss'; import React from 'react'; - -import { - Button, - Icon, - Popover, -} from 'antd'; - +import Button from 'antd/lib/button'; +import Icon from 'antd/lib/icon'; +import Popover from 'antd/lib/popover'; +import Text from 'antd/lib/typography/Text'; import { FacebookShareButton, LinkedinShareButton, @@ -30,59 +27,59 @@ import { LinkedinIcon, } from 'react-share'; -import Text from 'antd/lib/typography/Text'; +import consts from 'consts'; function renderContent(): JSX.Element { - const githubURL = 'https://github.com/opencv/cvat'; - const githubImage = 'https://raw.githubusercontent.com/opencv/' - + 'cvat/develop/cvat/apps/documentation/static/documentation/images/cvat.jpg'; - const questionsURL = 'https://gitter.im/opencv-cvat/public'; - const feedbackURL = 'https://gitter.im/opencv-cvat/public'; + const { + GITHUB_URL, + GITHUB_IMAGE_URL, + GITTER_PUBLIC_URL, + } = consts; return ( <> Star us on - GitHub + GitHub
Leave a - feedback + feedback
- + - + - + - + - + - + - + - +

Do you need help? Contact us on - gitter + gitter ); diff --git a/cvat-ui/src/components/file-manager/file-manager.tsx b/cvat-ui/src/components/file-manager/file-manager.tsx index 98de269786cd..3e2f2551245e 100644 --- a/cvat-ui/src/components/file-manager/file-manager.tsx +++ b/cvat-ui/src/components/file-manager/file-manager.tsx @@ -4,17 +4,16 @@ import './styles.scss'; import React from 'react'; - -import { - Tabs, - Icon, - Input, - Upload, -} from 'antd'; - -import Tree, { AntTreeNode, TreeNodeNormal } from 'antd/lib/tree/Tree'; -import { RcFile } from 'antd/lib/upload'; +import Tabs from 'antd/lib/tabs'; +import Icon from 'antd/lib/icon'; +import Input from 'antd/lib/input'; import Text from 'antd/lib/typography/Text'; +import Paragraph from 'antd/lib/typography/Paragraph'; +import Upload, { RcFile } from 'antd/lib/upload'; +import Empty from 'antd/lib/empty'; +import Tree, { AntTreeNode, TreeNodeNormal } from 'antd/lib/tree/Tree'; + +import consts from 'consts'; export interface Files { local: File[]; @@ -148,6 +147,7 @@ export default class FileManager extends React.PureComponent { }); } + const { SHARE_MOUNT_GUIDE_URL } = consts; const { treeData } = this.props; const { expandedKeys, @@ -156,7 +156,7 @@ export default class FileManager extends React.PureComponent { return ( - { treeData.length + { treeData[0].children && treeData[0].children.length ? ( { > { renderTreeNodes(treeData) } - ) : No data found} + ) : ( +
+ + + Please, be sure you had + + mounted + + share before you built CVAT and the shared storage contains files + +
+ )}
); } diff --git a/cvat-ui/src/components/file-manager/styles.scss b/cvat-ui/src/components/file-manager/styles.scss index bff7e5a0c010..7c72d764f66f 100644 --- a/cvat-ui/src/components/file-manager/styles.scss +++ b/cvat-ui/src/components/file-manager/styles.scss @@ -10,3 +10,9 @@ max-height: 20em; overflow: auto; } + +.cvat-empty-share-tree { + > .ant-typography { + margin-top: 10px; + } +} diff --git a/cvat-ui/src/components/global-error-boundary/global-error-boundary.tsx b/cvat-ui/src/components/global-error-boundary/global-error-boundary.tsx index 3c132fd9f9bd..aeee46b76387 100644 --- a/cvat-ui/src/components/global-error-boundary/global-error-boundary.tsx +++ b/cvat-ui/src/components/global-error-boundary/global-error-boundary.tsx @@ -19,6 +19,7 @@ import ErrorStackParser from 'error-stack-parser'; import { resetAfterErrorAsync } from 'actions/boundaries-actions'; import { CombinedState } from 'reducers/interfaces'; import logger, { LogType } from 'cvat-logger'; +import consts from 'consts'; interface StateToProps { job: any | null; @@ -161,7 +162,7 @@ class GlobalErrorBoundary extends React.PureComponent {
  • Notify an administrator or submit the issue directly on - GitHub. + GitHub. Please, provide also:
    • Steps to reproduce the issue
    • diff --git a/cvat-ui/src/components/header/header.tsx b/cvat-ui/src/components/header/header.tsx index 1c114ae9a7a4..38925dbb834c 100644 --- a/cvat-ui/src/components/header/header.tsx +++ b/cvat-ui/src/components/header/header.tsx @@ -16,6 +16,7 @@ import Modal from 'antd/lib/modal'; import Text from 'antd/lib/typography/Text'; import { CVATLogo, AccountIcon } from 'icons'; +import consts from 'consts'; interface HeaderContainerProps { onLogout: () => void; @@ -60,12 +61,15 @@ function HeaderContainer(props: Props): JSX.Element { || installedTFAnnotation || installedTFSegmentation; - function aboutModal(): void { - const CHANGELOG = 'https://github.com/opencv/cvat/blob/develop/CHANGELOG.md'; - const LICENSE = 'https://github.com/opencv/cvat/blob/develop/LICENSE'; - const GITTER = 'https://gitter.im/opencv-cvat'; - const FORUM = 'https://software.intel.com/en-us/forums/intel-distribution-of-openvino-toolkit'; + const { + CHANGELOG_URL, + LICENSE_URL, + GITTER_URL, + FORUM_URL, + GITHUB_URL, + } = consts; + function aboutModal(): void { Modal.info({ title: `${toolName}`, content: ( @@ -106,10 +110,10 @@ function HeaderContainer(props: Props): JSX.Element {

      - {'What\'s new?'} - License - Need help? - Forum on Intel Developer Zone + {'What\'s new?'} + License + Need help? + Forum on Intel Developer Zone ), @@ -199,7 +203,9 @@ function HeaderContainer(props: Props): JSX.Element { type='link' onClick={ (): void => { - window.open('https://github.com/opencv/cvat', '_blank'); + // false positive + // eslint-disable-next-line security/detect-non-literal-fs-filename + window.open(GITHUB_URL, '_blank'); } } > diff --git a/cvat-ui/src/consts.ts b/cvat-ui/src/consts.ts index b5942c324240..dfece0490468 100644 --- a/cvat-ui/src/consts.ts +++ b/cvat-ui/src/consts.ts @@ -4,8 +4,26 @@ const UNDEFINED_ATTRIBUTE_VALUE = '__undefined__'; const NO_BREAK_SPACE = '\u00a0'; +const CHANGELOG_URL = 'https://github.com/opencv/cvat/blob/develop/CHANGELOG.md'; +const LICENSE_URL = 'https://github.com/opencv/cvat/blob/develop/LICENSE'; +const GITTER_URL = 'https://gitter.im/opencv-cvat'; +const GITTER_PUBLIC_URL = 'https://gitter.im/opencv-cvat/public'; +const FORUM_URL = 'https://software.intel.com/en-us/forums/intel-distribution-of-openvino-toolkit'; +const GITHUB_URL = 'https://github.com/opencv/cvat'; +const GITHUB_IMAGE_URL = 'https://raw.githubusercontent.com/opencv/cvat/develop/cvat/apps/documentation/static/documentation/images/cvat.jpg'; +const AUTO_ANNOTATION_GUIDE_URL = 'https://github.com/opencv/cvat/blob/develop/cvat/apps/auto_annotation/README.md'; +const SHARE_MOUNT_GUIDE_URL = 'https://github.com/opencv/cvat/blob/master/cvat/apps/documentation/installation.md#share-path'; export default { UNDEFINED_ATTRIBUTE_VALUE, NO_BREAK_SPACE, + CHANGELOG_URL, + LICENSE_URL, + GITTER_URL, + GITTER_PUBLIC_URL, + FORUM_URL, + GITHUB_URL, + GITHUB_IMAGE_URL, + AUTO_ANNOTATION_GUIDE_URL, + SHARE_MOUNT_GUIDE_URL, };