Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Refactor deprecated antd Dropdown menus #6898

Merged
merged 39 commits into from
Mar 23, 2023
Merged
Show file tree
Hide file tree
Changes from 27 commits
Commits
Show all changes
39 commits
Select commit Hold shift + click to select a range
6072fcd
fix navbar Menu deprecatation warning (WIP)
hotzenklotz Feb 20, 2023
d1c9353
restored more navbar items (WIP)
hotzenklotz Feb 20, 2023
eb629d8
more navbar fixes
hotzenklotz Feb 20, 2023
29dff48
refactor FolderTree menu
hotzenklotz Feb 20, 2023
c987ebf
remove data-group-id attributes
hotzenklotz Feb 20, 2023
026c6de
updated changelog
hotzenklotz Feb 20, 2023
1f2d96c
makes changes compatible with antd v4.23.x
hotzenklotz Feb 21, 2023
218c4d2
Merge branch 'master' of github.com:scalableminds/webknossos into nav…
hotzenklotz Feb 21, 2023
3077818
fix linter
hotzenklotz Feb 21, 2023
1f8844e
applied PR feedback
hotzenklotz Feb 22, 2023
ef89a0e
Merge branch 'master' of github.com:scalableminds/webknossos into nav…
hotzenklotz Feb 22, 2023
6b9a901
more PR feedback
hotzenklotz Feb 22, 2023
5db33fb
Merge branch 'master' of github.com:scalableminds/webknossos into nav…
hotzenklotz Feb 22, 2023
87a5382
upgrade antd to v4.24.8
hotzenklotz Feb 21, 2023
434377d
updated changelog
hotzenklotz Feb 21, 2023
0bc7d59
Merge branch 'master' of github.com:scalableminds/webknossos into ant…
hotzenklotz Feb 22, 2023
8320f9d
Merge branch 'master' of github.com:scalableminds/webknossos into ant…
hotzenklotz Mar 2, 2023
8b776ec
apply PR feedback
hotzenklotz Mar 3, 2023
80af2d4
upgrade antd to v 4.28.x
hotzenklotz Feb 20, 2023
87d154b
refactor all occurances of <Dropdown menu>
hotzenklotz Feb 20, 2023
00285bc
changed more dropdown menus (WIP)
hotzenklotz Feb 21, 2023
ba1803e
more menu conversions (WIP)
hotzenklotz Feb 22, 2023
8f40925
more menu crazyiness (WIP)
hotzenklotz Feb 22, 2023
21e539d
upgrade antd to v 4.28.x
hotzenklotz Feb 20, 2023
d38ea55
restored context menu (WIP)
hotzenklotz Mar 3, 2023
0c4ac9e
restore layout menu
hotzenklotz Mar 3, 2023
bfe3fef
Merge branch 'master' of github.com:scalableminds/webknossos into dro…
hotzenklotz Mar 3, 2023
964fbb4
updated changelog
hotzenklotz Mar 6, 2023
d95cc01
restore context menu position styling
hotzenklotz Mar 6, 2023
17bcd86
Merge branch 'master' of github.com:scalableminds/webknossos into dro…
hotzenklotz Mar 13, 2023
2dc8aa1
fix typechecking
hotzenklotz Mar 13, 2023
0879f2e
Merge branch 'master' of github.com:scalableminds/webknossos into dro…
hotzenklotz Mar 20, 2023
0e3827b
applied PR feedback
hotzenklotz Mar 20, 2023
757f0f3
fix menu crash in dashboard
hotzenklotz Mar 20, 2023
e2e51ed
reactivated mapping warnings
hotzenklotz Mar 21, 2023
f9990b1
Merge branch 'master' of github.com:scalableminds/webknossos into dro…
hotzenklotz Mar 21, 2023
d289ba0
fix rules of hooks error in context menu
hotzenklotz Mar 22, 2023
e5686f2
Merge branch 'master' of github.com:scalableminds/webknossos into dro…
hotzenklotz Mar 23, 2023
5ea2eb9
applied PR feedback
hotzenklotz Mar 23, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
110 changes: 58 additions & 52 deletions frontend/javascripts/admin/task/task_annotation_view.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Dropdown, Menu, Modal } from "antd";
import { Dropdown, MenuProps, Modal } from "antd";
import {
EyeOutlined,
PlayCircleOutlined,
Expand Down Expand Up @@ -30,7 +30,6 @@ import Toast from "libs/toast";
import TransferTaskModal from "dashboard/transfer_task_modal";
import messages from "messages";
import { getVolumeDescriptors } from "oxalis/model/accessors/volumetracing_accessor";
const { Item } = Menu;
const { confirm } = Modal;
type OwnProps = {
task: APITask;
Expand Down Expand Up @@ -101,7 +100,7 @@ class TaskAnnotationView extends React.PureComponent<Props, State> {
}));
};

getDropdownMenu(annotation: APIAnnotation) {
getDropdownMenu(annotation: APIAnnotation): MenuProps {
let doesAnnotationNotBelongToActiveUser = true;

if (annotation.owner && this.props.activeUser) {
Expand All @@ -120,57 +119,64 @@ class TaskAnnotationView extends React.PureComponent<Props, State> {
Open
</React.Fragment>
);
return (
<Menu>
<Item key={`${annotation.id}-view`}>
<a href={`/annotations/Task/${annotation.id}`}>{label}</a>
</Item>

<Item
key={`${annotation.id}-transfer`}
onClick={() =>
return {
items: [
{
key: `${annotation.id}-view`,
label: <a href={`/annotations/Task/${annotation.id}`}>{label}</a>,
},
{
key: `${annotation.id}-transfer`,
onClick: () =>
this.setState({
currentAnnotation: annotation,
isTransferModalOpen: true,
})
}
>
<TeamOutlined />
Transfer
</Item>
<Item key={`${annotation.id}-download`}>
<AsyncLink
href="#"
onClick={() => {
const isVolumeIncluded = getVolumeDescriptors(annotation).length > 0;
return downloadAnnotation(annotation.id, "Task", isVolumeIncluded);
}}
icon={<DownloadOutlined />}
>
Download
</AsyncLink>
</Item>
<Item key={`${annotation.id}-reset`} onClick={() => this.resetAnnotation(annotation)}>
<RollbackOutlined />
Reset
</Item>
<Item key={`${annotation.id}-delete`} onClick={() => this.deleteAnnotation(annotation)}>
<DeleteOutlined />
Reset and Cancel
</Item>
{annotation.state === "Finished" ? (
<Item key={`${annotation.id}-reopen`} onClick={() => this.reOpenAnnotation(annotation)}>
<FolderOpenOutlined />
Reopen
</Item>
) : (
<Item key={`${annotation.id}-finish`} onClick={() => this.finishAnnotation(annotation)}>
<CheckCircleOutlined />
Finish
</Item>
)}
</Menu>
);
}),
icon: <TeamOutlined />,
label: "Transfer",
},
{
key: `${annotation.id}-download`,
label: (
<AsyncLink
href="#"
onClick={() => {
const isVolumeIncluded = getVolumeDescriptors(annotation).length > 0;
return downloadAnnotation(annotation.id, "Task", isVolumeIncluded);
}}
icon={<DownloadOutlined />}
>
Download
</AsyncLink>
),
},
{
key: `${annotation.id}-reset`,
onClick: () => this.resetAnnotation(annotation),
icon: <RollbackOutlined />,
label: "Reset",
},
{
key: `${annotation.id}-delete`,
onClick: () => this.deleteAnnotation(annotation),
icon: <DeleteOutlined />,
label: "Reset and Cancel",
},
annotation.state === "Finished"
? {
key: `${annotation.id}-reopen`,
onClick: () => this.reOpenAnnotation(annotation),
icon: <FolderOpenOutlined />,
label: "Reopen",
}
: {
key: `${annotation.id}-finish`,
onClick: () => this.finishAnnotation(annotation),
icon: <CheckCircleOutlined />,
label: "Finish",
},
],
};
}

render() {
Expand Down Expand Up @@ -206,7 +212,7 @@ class TaskAnnotationView extends React.PureComponent<Props, State> {
</span>
</td>
<td className="nowrap">
<Dropdown overlay={this.getDropdownMenu(annotation)} trigger={["click"]}>
<Dropdown menu={this.getDropdownMenu(annotation)} trigger={["click"]}>
<a className="ant-dropdown-link" href="#">
Actions <DownOutlined />
</a>
Expand Down
20 changes: 11 additions & 9 deletions frontend/javascripts/admin/task/task_search_form.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Form, Row, Dropdown, Menu, Col, Button, Input, Select } from "antd";
import { Form, Row, Dropdown, Col, Button, Input, Select } from "antd";
import { FormInstance } from "antd/lib/form";
import { DownloadOutlined, DownOutlined, RetweetOutlined } from "@ant-design/icons";
// @ts-expect-error ts-migrate(7016) FIXME: Could not find a declaration file for module '@sca... Remove this comment to see the full error message
Expand Down Expand Up @@ -276,14 +276,16 @@ class TaskSearchForm extends React.Component<Props, State> {
}}
>
<Dropdown
overlay={
<Menu onClick={() => this.handleSearchFormFinish(true)}>
<Menu.Item key="1">
<RetweetOutlined />
Show random subset
</Menu.Item>
</Menu>
}
menu={{
onClick: () => this.handleSearchFormFinish(true),
items: [
{
key: "1",
icon: <RetweetOutlined />,
label: "Show random subset",
},
],
}}
>
<Button
type="primary"
Expand Down
46 changes: 22 additions & 24 deletions frontend/javascripts/admin/voxelytics/task_list_view.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,14 +4,14 @@ import {
Input,
Row,
Col,
Menu,
Button,
Dropdown,
notification,
message,
Tag,
Tooltip,
Select,
MenuProps,
} from "antd";
import {
ClockCircleOutlined,
Expand Down Expand Up @@ -406,28 +406,26 @@ export default function TaskListView({

const colorHasher = new ColorHash({ lightness: [0.35, 0.5, 0.65] });

const overflowMenu = (
<Menu>
<Menu.Item key="1" onClick={copyAllArtifactPaths}>
Copy All Artifact Paths
</Menu.Item>
<Menu.Item key="2" onClick={downloadReportJSON}>
Download Report as JSON
</Menu.Item>
<Menu.Item key="3" onClick={downloadWorkflowYAML}>
Download Workflow YAML
</Menu.Item>
<Menu.Item key="4" onClick={downloadLog} disabled={singleRunId == null}>
{singleRunId == null ? (
<Tooltip title="Please select a specific run for log download.">
<div>Download Log</div>
</Tooltip>
) : (
"Download Log"
)}
</Menu.Item>
</Menu>
);
const overflowMenu: MenuProps = {
items: [
{ key: "1", onClick: copyAllArtifactPaths, label: "Copy All Artifact Paths" },
{ key: "2", onClick: downloadReportJSON, label: "Download Report as JSON" },
{ key: "3", onClick: downloadWorkflowYAML, label: "Download Workflow YAML" },
{
key: "4",
onClick: downloadLog,
disabled: singleRunId == null,
label:
singleRunId == null ? (
<Tooltip title="Please select a specific run for log download.">
<div>Download Log</div>
</Tooltip>
) : (
"Download Log"
),
},
],
};

const renderTaskGroupOrTask = (taskGroup: VoxelyticsTaskConfigWithHierarchy) => {
const taskInfo = aggregateTaskInfos(taskGroup, report.tasks, runId);
Expand Down Expand Up @@ -631,7 +629,7 @@ export default function TaskListView({
</Select.Option>
))}
</Select>
<Dropdown.Button overlay={overflowMenu} onClick={() => setExpandedTasks([])}>
<Dropdown.Button menu={overflowMenu} onClick={() => setExpandedTasks([])}>
Collapse All
</Dropdown.Button>
</div>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ import { clearCache, getDataset } from "admin/admin_rest_api";
import Toast from "libs/toast";
import messages from "messages";
import CreateExplorativeModal from "dashboard/advanced_dataset/create_explorative_modal";
import { Menu, Modal } from "antd";
import { MenuProps, Modal } from "antd";
const disabledStyle: React.CSSProperties = {
pointerEvents: "none",
color: "var(--ant-disabled)",
Expand Down Expand Up @@ -246,75 +246,70 @@ export function getDatasetActionContextMenu({
reloadDataset: (arg0: APIDatasetId) => Promise<void>;
datasets: APIDatasetCompact[];
hideContextMenu: () => void;
}) {
}): MenuProps {
if (datasets.length !== 1) {
return (
<Menu
onClick={hideContextMenu}
style={{
borderRadius: 6,
}}
mode="vertical"
>
<Menu.Item key="view" disabled>
No actions available.
</Menu.Item>
</Menu>
);
return {
onClick: hideContextMenu,
style: {
borderRadius: 6,
},
mode: "vertical",
items: [
{
key: "view",
disabled: true,
label: "No actions available.",
},
],
};
}
const dataset = datasets[0];

return (
<Menu
onClick={hideContextMenu}
style={{
borderRadius: 6,
}}
mode="vertical"
>
{dataset.isActive && (
<Menu.Item
key="view"
onClick={() => {
window.location.href = `/datasets/${dataset.owningOrganization}/${dataset.name}/view`;
}}
>
View
</Menu.Item>
)}
{dataset.isEditable && dataset.isActive ? (
<Menu.Item
key="edit"
onClick={() => {
window.location.href = `/datasets/${dataset.owningOrganization}/${dataset.name}/edit`;
}}
>
Open Settings
</Menu.Item>
) : null}

{dataset.isEditable && !dataset.isActive ? (
<Menu.Item
key="import"
onClick={() => {
window.location.href = `/datasets/${dataset.owningOrganization}/${dataset.name}/import`;
}}
>
Import
</Menu.Item>
) : null}
return {
onClick: hideContextMenu,
style: {
borderRadius: 6,
},
mode: "vertical",
items: [
dataset.isActive
? {
key: "view",
label: "View",
onClick: () => {
window.location.href = `/datasets/${dataset.owningOrganization}/${dataset.name}/view`;
},
}
: null,
dataset.isEditable && dataset.isActive
? {
key: "edit",
label: "Open Settings",
onClick: () => {
window.location.href = `/datasets/${dataset.owningOrganization}/${dataset.name}/edit`;
},
}
: null,

<Menu.Item
key="reload"
onClick={async () => {
dataset.isEditable && !dataset.isActive
? {
key: "import",
label: "Import",
onClick: () => {
window.location.href = `/datasets/${dataset.owningOrganization}/${dataset.name}/import`;
},
}
: null,
{
key: "reload",
label: "Reload",
onClick: async () => {
const fullDataset = await getDataset(dataset);
return dataset.isActive ? onClearCache(fullDataset, reloadDataset) : null;
}}
>
Reload
</Menu.Item>
</Menu>
);
},
},
],
};
}

export default withRouter<RouteComponentProps & Props, any>(DatasetActionView);
Loading