Files
SCM-Manager/scm-ui/ui-components/src/config/ConfigurationBinder.tsx

121 lines
4.4 KiB
TypeScript
Raw Normal View History

import React from "react";
import { binder } from "@scm-manager/ui-extensions";
import { NavLink } from "../navigation";
import { Route } from "react-router-dom";
import { translate } from "react-i18next";
import { Repository, Links, Link } from "@scm-manager/ui-types";
type GlobalRouteProps = {
url: string;
links: Links;
};
type RepositoryRouteProps = {
url: string;
repository: Repository;
};
class ConfigurationBinder {
2019-10-21 10:57:56 +02:00
i18nNamespace = "plugins";
navLink(to: string, labelI18nKey: string, t: any) {
return <NavLink to={to} label={t(labelI18nKey)} />;
}
route(path: string, Component: any) {
return <Route path={path} render={() => Component} exact />;
}
2019-10-21 10:57:56 +02:00
bindGlobal(to: string, labelI18nKey: string, linkName: string, ConfigurationComponent: any) {
// create predicate based on the link name of the index resource
// if the linkname is not available, the navigation link and the route are not bound to the extension points
const configPredicate = (props: any) => {
return props.links && props.links[linkName];
};
// create NavigationLink with translated label
const ConfigNavLink = translate(this.i18nNamespace)(({ t }) => {
return this.navLink("/admin/settings" + to, labelI18nKey, t);
});
// bind navigation link to extension point
binder.bind("admin.setting", ConfigNavLink, configPredicate);
// route for global configuration, passes the link from the index resource to component
2019-10-21 10:57:56 +02:00
const ConfigRoute = ({ url, links, ...additionalProps }: GlobalRouteProps) => {
const link = links[linkName];
if (link) {
return this.route(
url + "/settings" + to,
2019-10-21 10:57:56 +02:00
<ConfigurationComponent link={(link as Link).href} {...additionalProps} />
);
}
};
// bind config route to extension point
binder.bind("admin.route", ConfigRoute, configPredicate);
}
2019-10-21 10:57:56 +02:00
bindRepository(to: string, labelI18nKey: string, linkName: string, RepositoryComponent: any) {
// create predicate based on the link name of the current repository route
// if the linkname is not available, the navigation link and the route are not bound to the extension points
const repoPredicate = (props: any) => {
2019-10-21 10:57:56 +02:00
return props.repository && props.repository._links && props.repository._links[linkName];
};
// create NavigationLink with translated label
const RepoNavLink = translate(this.i18nNamespace)(({ t, url }) => {
return this.navLink(url + to, labelI18nKey, t);
});
// bind navigation link to extension point
binder.bind("repository.navigation", RepoNavLink, repoPredicate);
// route for global configuration, passes the current repository to component
2019-10-21 10:57:56 +02:00
const RepoRoute = ({ url, repository, ...additionalProps }: RepositoryRouteProps) => {
const link = repository._links[linkName];
if (link) {
return this.route(
url + to,
2019-10-21 10:57:56 +02:00
<RepositoryComponent repository={repository} link={(link as Link).href} {...additionalProps} />
);
}
};
// bind config route to extension point
binder.bind("repository.route", RepoRoute, repoPredicate);
}
2019-10-21 10:57:56 +02:00
bindRepositorySetting(to: string, labelI18nKey: string, linkName: string, RepositoryComponent: any) {
// create predicate based on the link name of the current repository route
// if the linkname is not available, the navigation link and the route are not bound to the extension points
const repoPredicate = (props: any) => {
2019-10-21 10:57:56 +02:00
return props.repository && props.repository._links && props.repository._links[linkName];
};
// create NavigationLink with translated label
const RepoNavLink = translate(this.i18nNamespace)(({ t, url }) => {
return this.navLink(url + "/settings" + to, labelI18nKey, t);
});
// bind navigation link to extension point
binder.bind("repository.setting", RepoNavLink, repoPredicate);
// route for global configuration, passes the current repository to component
2019-10-21 10:57:56 +02:00
const RepoRoute = ({ url, repository, ...additionalProps }: RepositoryRouteProps) => {
const link = repository._links[linkName];
if (link) {
return this.route(
url + "/settings" + to,
2019-10-21 10:57:56 +02:00
<RepositoryComponent repository={repository} link={(link as Link).href} {...additionalProps} />
);
}
};
// bind config route to extension point
binder.bind("repository.route", RepoRoute, repoPredicate);
}
}
export default new ConfigurationBinder();