import { compose } from 'redux';
import { DetailsAttribute } from "~/components/details-attribute/details-attribute";
-type CssRules = 'details';
+export type CssRules = 'details';
const styles: StyleRulesCallback<CssRules> = theme => ({
details: {
} else {
winDav = new URL(props.data.downloadUrl);
cyberDav = new URL(props.data.downloadUrl);
- winDav.pathname = `/by_id/${props.data.uuid}/`;
- cyberDav.pathname = `/by_id/${props.data.uuid}/`;
+ winDav.pathname = `/by_id/${props.data.uuid}`;
+ cyberDav.pathname = `/by_id/${props.data.uuid}`;
}
- cyberDav.protocol = { "http:": "dav:", "https:": "davs:" }[cyberDav.protocol];
+ cyberDav.username = props.data.username;
+ const cyberDavStr = "dav" + cyberDav.toString().slice(4);
const s3endpoint = new URL(props.data.collectionsUrl.replace(/\/\*(--[^.]+)?\./, "/"));
const sp = props.data.token.split("/");
let tokenUuid;
let tokenSecret;
- if (sp.length === 3 && sp[0] === "v2" && props.data.homeCluster === props.data.localCluster) {
+ if (sp.length === 3 && sp[0] === "v2" && sp[1].slice(0, 5) === props.data.localCluster) {
tokenUuid = sp[1];
tokenSecret = sp[2];
} else {
tokenSecret = tokenUuid;
}
+ const supportsWebdav = (props.data.uuid.indexOf("-4zz18-") === 5);
+
+ let activeTab = props.data.activeTab;
+ if (!supportsWebdav) {
+ activeTab = 2;
+ }
+
return <Dialog
open={props.open}
maxWidth="md"
<CardHeader
title={`Open as Network Folder or S3 Bucket`} />
<div className={props.classes.details} >
- <Tabs value={props.data.activeTab} onChange={props.data.setActiveTab}>
- <Tab key="cyberduck" label="Cyberduck/Mountain Duck or Gnome Files" />
- <Tab key="windows" label="Windows or MacOS" />
- <Tab key="s3" label="S3 bucket" />
+ <Tabs value={activeTab} onChange={props.data.setActiveTab}>
+ {supportsWebdav && <Tab value={0} key="cyberduck" label="Cyberduck/Mountain Duck or Gnome Files" />}
+ {supportsWebdav && <Tab value={1} key="windows" label="Windows or MacOS" />}
+ <Tab value={2} key="s3" label="S3 bucket" />
</Tabs>
- <TabPanel index={1} value={props.data.activeTab}>
+ <TabPanel index={1} value={activeTab}>
<h2>Settings</h2>
<DetailsAttribute
label='Internet address'
- value={<a href={winDav.toString()}>{winDav.toString()}</a>}
+ value={<a href={winDav.toString()} target="_blank">{winDav.toString()}</a>}
copyValue={winDav.toString()} />
<DetailsAttribute
</ol>
</TabPanel>
- <TabPanel index={0} value={props.data.activeTab}>
+ <TabPanel index={0} value={activeTab}>
<DetailsAttribute
label='Server'
- value={<a href={cyberDav.toString()}>{cyberDav.toString()}</a>}
- copyValue={cyberDav.toString()} />
+ value={<a href={cyberDavStr} target="_blank">{cyberDavStr}</a>}
+ copyValue={cyberDavStr} />
<DetailsAttribute
label='Username'
</TabPanel>
- <TabPanel index={2} value={props.data.activeTab}>
+ <TabPanel index={2} value={activeTab}>
<DetailsAttribute
label='Endpoint'
value={s3endpoint.host}