1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
5 import * as React from "react";
6 import { Dialog, DialogActions, Button, StyleRulesCallback, WithStyles, withStyles, CardHeader, Tab, Tabs } from '@material-ui/core';
7 import { withDialog } from "~/store/dialog/with-dialog";
8 import { COLLECTION_WEBDAV_S3_DIALOG_NAME, WebDavS3InfoDialogData } from '~/store/collections/collection-info-actions';
9 import { WithDialogProps } from '~/store/dialog/with-dialog';
10 import { compose } from 'redux';
11 import { DetailsAttribute } from "~/components/details-attribute/details-attribute";
13 type CssRules = 'details';
15 const styles: StyleRulesCallback<CssRules> = theme => ({
17 marginLeft: theme.spacing.unit * 3,
18 marginRight: theme.spacing.unit * 3,
22 interface TabPanelData {
23 children: React.ReactElement<any>[];
28 function TabPanel(props: TabPanelData) {
29 const { children, value, index } = props;
34 hidden={value !== index}
35 id={`simple-tabpanel-${index}`}
36 aria-labelledby={`simple-tab-${index}`}
38 {value === index && children}
43 export const WebDavS3InfoDialog = compose(
44 withDialog(COLLECTION_WEBDAV_S3_DIALOG_NAME),
47 (props: WithDialogProps<WebDavS3InfoDialogData> & WithStyles<CssRules>) => {
48 if (!props.data.downloadUrl) { return null; }
53 if (props.data.collectionsUrl.indexOf("*") > -1) {
54 const withuuid = props.data.collectionsUrl.replace("*", props.data.uuid);
55 winDav = new URL(withuuid);
56 cyberDav = new URL(withuuid);
58 winDav = new URL(props.data.downloadUrl);
59 cyberDav = new URL(props.data.downloadUrl);
60 winDav.pathname = `/by_id/${props.data.uuid}/`;
61 cyberDav.pathname = `/by_id/${props.data.uuid}/`;
64 cyberDav.protocol = { "http:": "dav:", "https:": "davs:" }[cyberDav.protocol];
66 const s3endpoint = new URL(props.data.collectionsUrl.replace(/\/\*(--[^.]+)?\./, "/"));
68 const sp = props.data.token.split("/");
71 if (sp.length === 3 && sp[0] === "v2" && props.data.homeCluster === props.data.localCluster) {
75 tokenUuid = props.data.token.replace(/\//g, "_");
76 tokenSecret = tokenUuid;
79 const supportsWebdav = (props.data.uuid.indexOf("-4zz18-") === 5);
81 let activeTab = props.data.activeTab;
82 if (!supportsWebdav) {
89 onClose={props.closeDialog}
90 style={{ alignSelf: 'stretch' }}>
92 title={`Open as Network Folder or S3 Bucket`} />
93 <div className={props.classes.details} >
94 <Tabs value={activeTab} onChange={props.data.setActiveTab}>
95 {supportsWebdav && <Tab value={0} key="cyberduck" label="Cyberduck/Mountain Duck or Gnome Files" />}
96 {supportsWebdav && <Tab value={1} key="windows" label="Windows or MacOS" />}
97 <Tab value={2} key="s3" label="S3 bucket" />
100 <TabPanel index={0} value={activeTab}>
104 label='Internet address'
105 value={<a href={winDav.toString()}>{winDav.toString()}</a>}
106 copyValue={winDav.toString()} />
110 value={props.data.username}
111 copyValue={props.data.username} />
115 value={props.data.token}
116 copyValue={props.data.token} />
120 <li>Open File Explorer</li>
121 <li>Click on "This PC", then go to Computer → Add a Network Location</li>
122 <li>Click Next, then choose "Add a custom network location", then click Next</li>
128 <li>Click Go → Connect to server</li>
132 <TabPanel index={1} value={activeTab}>
135 value={<a href={cyberDav.toString()}>{cyberDav.toString()}</a>}
136 copyValue={cyberDav.toString()} />
140 value={props.data.username}
141 copyValue={props.data.username} />
145 value={props.data.token}
146 copyValue={props.data.token} />
151 <li>Select +Other Locations</li>
152 <li>Connect to Server → Enter server address</li>
157 <TabPanel index={2} value={activeTab}>
160 value={s3endpoint.host}
161 copyValue={s3endpoint.host} />
165 value={props.data.uuid}
166 copyValue={props.data.uuid} />
171 copyValue={tokenUuid} />
176 copyValue={tokenSecret} />
185 onClick={props.closeDialog}>