Files
SCM-Manager/scm-ui/src/admin/containers/AdminDetails.js

93 lines
2.9 KiB
JavaScript
Raw Normal View History

2019-06-19 09:58:17 +02:00
// @flow
import React from "react";
2019-08-08 10:40:38 +02:00
import {connect} from "react-redux";
import injectSheet from "react-jss";
2019-08-08 10:40:38 +02:00
import {translate} from "react-i18next";
import classNames from "classnames";
2019-08-08 10:40:38 +02:00
import {Image, Loading, Subtitle, Title} from "@scm-manager/ui-components";
import {getAppVersion} from "../../modules/indexResource";
2019-06-19 09:58:17 +02:00
type Props = {
loading: boolean,
error: Error,
version: string,
// context props
classes: any,
2019-06-19 09:58:17 +02:00
t: string => string
};
const styles = {
boxShadow: {
2019-08-08 10:40:38 +02:00
boxShadow: "0 2px 3px rgba(40, 177, 232, 0.1), 0 0 0 2px rgb(40, 177, 232, 0.2)"
},
boxTitle: {
fontWeight: "500 !important"
}
};
2019-06-19 09:58:17 +02:00
class AdminDetails extends React.Component<Props> {
render() {
const { loading, classes, t } = this.props;
2019-06-19 09:58:17 +02:00
if (loading) {
return <Loading />;
}
2019-07-03 09:02:44 +02:00
return (
<>
<Title title={t("admin.info.currentAppVersion")} />
2019-07-03 09:02:44 +02:00
<Subtitle subtitle={this.props.version} />
<div className={classNames("box", classes.boxShadow)}>
<article className="media">
<div className="media-left">
2019-08-08 10:40:38 +02:00
<figure className="image is-96x96">
<Image
src="/images/iconCommunitySupport.png"
alt={t("admin.info.communityIconAlt")}
/>
</figure>
</div>
<div className="media-content">
<div className="content">
<h3 className={classes.boxTitle}>{t("admin.info.communityTitle")}</h3>
<p>{t("admin.info.communityInfo")}</p>
2019-08-08 10:40:38 +02:00
<a className="button is-info is-pulled-right" target="_blank" href="https://scm-manager.org/support/">{t("admin.info.communityButton")}</a>
</div>
</div>
</article>
</div>
<div className={classNames("box", classes.boxShadow)}>
<article className="media">
<div className="media-left">
2019-08-08 10:40:38 +02:00
<figure className="image is-96x96">
<Image
src="/images/iconEnterpriseSupport.png"
alt={t("admin.info.enterpriseIconAlt")}
/>
</figure>
</div>
<div className="media-content">
<div className="content">
<h3 className={classes.boxTitle}>{t("admin.info.enterpriseTitle")}</h3>
<p>{t("admin.info.enterpriseInfo")}<br /><strong>{t("admin.info.enterprisePartner")}</strong></p>
2019-08-08 10:40:38 +02:00
<a className="button is-info is-pulled-right is-normal" target="_blank" href={t("admin.info.enterpriseLink")}>{t("admin.info.enterpriseButton")}</a>
</div>
</div>
</article>
</div>
2019-07-03 09:02:44 +02:00
</>
);
2019-06-19 09:58:17 +02:00
}
}
const mapStateToProps = (state: any) => {
const version = getAppVersion(state);
return {
version
};
};
export default connect(mapStateToProps)(injectSheet(styles)(translate("admin")(AdminDetails)));