mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-01-12 10:34:17 +00:00
support process-groups in breadcrumb component
This commit is contained in:
parent
c6325303d4
commit
fcd5b431e2
@ -13,7 +13,7 @@ type OwnProps = {
|
|||||||
const explodeCrumb = (crumb: HotCrumbItem) => {
|
const explodeCrumb = (crumb: HotCrumbItem) => {
|
||||||
const url: string = crumb[1] || '';
|
const url: string = crumb[1] || '';
|
||||||
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
||||||
const [_unused, processModelId, link] = url.split(':');
|
const [endingUrlType, processModelId, link] = url.split(':');
|
||||||
const processModelIdSegments = splitProcessModelId(processModelId);
|
const processModelIdSegments = splitProcessModelId(processModelId);
|
||||||
const paths: string[] = [];
|
const paths: string[] = [];
|
||||||
const lastPathItem = processModelIdSegments.pop();
|
const lastPathItem = processModelIdSegments.pop();
|
||||||
@ -29,7 +29,12 @@ const explodeCrumb = (crumb: HotCrumbItem) => {
|
|||||||
}
|
}
|
||||||
);
|
);
|
||||||
if (link === 'link') {
|
if (link === 'link') {
|
||||||
const lastUrl = `/admin/process-models/${paths.join(':')}:${lastPathItem}`;
|
if (lastPathItem !== undefined) {
|
||||||
|
paths.push(lastPathItem);
|
||||||
|
}
|
||||||
|
const lastUrl = `/admin/${endingUrlType.replace('_', '-')}s/${paths.join(
|
||||||
|
':'
|
||||||
|
)}`;
|
||||||
breadcrumbItems.push(
|
breadcrumbItems.push(
|
||||||
<BreadcrumbItem key={lastPathItem} href={lastUrl}>
|
<BreadcrumbItem key={lastPathItem} href={lastUrl}>
|
||||||
{lastPathItem}
|
{lastPathItem}
|
||||||
@ -64,7 +69,7 @@ export default function ProcessBreadcrumb({
|
|||||||
</BreadcrumbItem>
|
</BreadcrumbItem>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if (url && url.startsWith('process_model:')) {
|
if (url && url.match(/^process_(model|group):/)) {
|
||||||
return explodeCrumb(crumb);
|
return explodeCrumb(crumb);
|
||||||
}
|
}
|
||||||
return (
|
return (
|
||||||
|
@ -24,7 +24,15 @@ export default function ProcessGroupEdit() {
|
|||||||
if (processGroup) {
|
if (processGroup) {
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ProcessBreadcrumb processGroupId={(processGroup as any).id} />
|
<ProcessBreadcrumb
|
||||||
|
hotCrumbs={[
|
||||||
|
['Process Groups', '/admin'],
|
||||||
|
[
|
||||||
|
`Process Group: ${processGroup.id}:link`,
|
||||||
|
`process_group:${processGroup.id}:link`,
|
||||||
|
],
|
||||||
|
]}
|
||||||
|
/>
|
||||||
<h2>Edit Process Group: {(processGroup as any).id}</h2>
|
<h2>Edit Process Group: {(processGroup as any).id}</h2>
|
||||||
<ProcessGroupForm
|
<ProcessGroupForm
|
||||||
mode="edit"
|
mode="edit"
|
||||||
|
@ -4,10 +4,11 @@ import { useParams } from 'react-router-dom';
|
|||||||
import ProcessBreadcrumb from '../components/ProcessBreadcrumb';
|
import ProcessBreadcrumb from '../components/ProcessBreadcrumb';
|
||||||
import HttpService from '../services/HttpService';
|
import HttpService from '../services/HttpService';
|
||||||
import ProcessModelForm from '../components/ProcessModelForm';
|
import ProcessModelForm from '../components/ProcessModelForm';
|
||||||
|
import { ProcessModel } from '../interfaces';
|
||||||
|
|
||||||
export default function ProcessModelEdit() {
|
export default function ProcessModelEdit() {
|
||||||
const params = useParams();
|
const params = useParams();
|
||||||
const [processModel, setProcessModel] = useState(null);
|
const [processModel, setProcessModel] = useState<ProcessModel | null>(null);
|
||||||
const processModelPath = `process-models/${params.process_model_id}`;
|
const processModelPath = `process-models/${params.process_model_id}`;
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
@ -20,6 +21,15 @@ export default function ProcessModelEdit() {
|
|||||||
if (processModel) {
|
if (processModel) {
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
|
<ProcessBreadcrumb
|
||||||
|
hotCrumbs={[
|
||||||
|
['Process Groups', '/admin'],
|
||||||
|
[
|
||||||
|
`Process Model: ${processModel.id}`,
|
||||||
|
`process_model:${processModel.id}:link`,
|
||||||
|
],
|
||||||
|
]}
|
||||||
|
/>
|
||||||
<ProcessBreadcrumb processGroupId={params.process_group_id} />
|
<ProcessBreadcrumb processGroupId={params.process_group_id} />
|
||||||
<h2>Edit Process Model: {(processModel as any).id}</h2>
|
<h2>Edit Process Model: {(processModel as any).id}</h2>
|
||||||
<ProcessModelForm
|
<ProcessModelForm
|
||||||
|
@ -16,7 +16,15 @@ export default function ProcessModelNew() {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ProcessBreadcrumb />
|
<ProcessBreadcrumb
|
||||||
|
hotCrumbs={[
|
||||||
|
['Process Groups', '/admin'],
|
||||||
|
[
|
||||||
|
`Process Group: ${params.process_group_id}`,
|
||||||
|
`process_group:${params.process_group_id}:link`,
|
||||||
|
],
|
||||||
|
]}
|
||||||
|
/>
|
||||||
<h2>Add Process Model</h2>
|
<h2>Add Process Model</h2>
|
||||||
<ProcessModelForm
|
<ProcessModelForm
|
||||||
mode="new"
|
mode="new"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user