updated the breadcrumb component and added a test for buttons in file dropdown
This commit is contained in:
parent
34c0b5d2a3
commit
5f22c0b910
|
@ -1,12 +1,12 @@
|
||||||
import { Link } from 'react-router-dom';
|
// @ts-ignore
|
||||||
import Breadcrumb from 'react-bootstrap/Breadcrumb';
|
import { Breadcrumb, BreadcrumbItem } from '@carbon/react';
|
||||||
import { BreadcrumbItem } from '../interfaces';
|
import { HotCrumbItem } from '../interfaces';
|
||||||
|
|
||||||
type OwnProps = {
|
type OwnProps = {
|
||||||
processModelId?: string;
|
processModelId?: string;
|
||||||
processGroupId?: string;
|
processGroupId?: string;
|
||||||
linkProcessModel?: boolean;
|
linkProcessModel?: boolean;
|
||||||
hotCrumbs?: BreadcrumbItem[];
|
hotCrumbs?: HotCrumbItem[];
|
||||||
};
|
};
|
||||||
|
|
||||||
export default function ProcessBreadcrumb({
|
export default function ProcessBreadcrumb({
|
||||||
|
@ -22,18 +22,20 @@ export default function ProcessBreadcrumb({
|
||||||
if (lastItem === undefined) {
|
if (lastItem === undefined) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
const lastCrumb = <Breadcrumb.Item active>{lastItem[0]}</Breadcrumb.Item>;
|
const lastCrumb = (
|
||||||
const leadingCrumbLinks = hotCrumbs.map((crumb) => {
|
<BreadcrumbItem isCurrentPage>{lastItem[0]}</BreadcrumbItem>
|
||||||
|
);
|
||||||
|
const leadingCrumbLinks = hotCrumbs.map((crumb: any) => {
|
||||||
const valueLabel = crumb[0];
|
const valueLabel = crumb[0];
|
||||||
const url = crumb[1];
|
const url = crumb[1];
|
||||||
return (
|
return (
|
||||||
<Breadcrumb.Item key={valueLabel} linkAs={Link} linkProps={{ to: url }}>
|
<BreadcrumbItem key={valueLabel} href={url}>
|
||||||
{valueLabel}
|
{valueLabel}
|
||||||
</Breadcrumb.Item>
|
</BreadcrumbItem>
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
return (
|
return (
|
||||||
<Breadcrumb>
|
<Breadcrumb noTrailingSlash>
|
||||||
{leadingCrumbLinks}
|
{leadingCrumbLinks}
|
||||||
{lastCrumb}
|
{lastCrumb}
|
||||||
</Breadcrumb>
|
</Breadcrumb>
|
||||||
|
@ -42,42 +44,38 @@ export default function ProcessBreadcrumb({
|
||||||
if (processModelId) {
|
if (processModelId) {
|
||||||
if (linkProcessModel) {
|
if (linkProcessModel) {
|
||||||
processModelBreadcrumb = (
|
processModelBreadcrumb = (
|
||||||
<Breadcrumb.Item
|
<BreadcrumbItem
|
||||||
linkAs={Link}
|
href={`/admin/process-models/${processGroupId}/${processModelId}`}
|
||||||
linkProps={{
|
|
||||||
to: `/admin/process-models/${processGroupId}/${processModelId}`,
|
|
||||||
}}
|
|
||||||
>
|
>
|
||||||
Process Model: {processModelId}
|
{`Process Model: ${processModelId}`}
|
||||||
</Breadcrumb.Item>
|
</BreadcrumbItem>
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
processModelBreadcrumb = (
|
processModelBreadcrumb = (
|
||||||
<Breadcrumb.Item active>
|
<BreadcrumbItem isCurrentPage>
|
||||||
Process Model: {processModelId}
|
{`Process Model: ${processModelId}`}
|
||||||
</Breadcrumb.Item>
|
</BreadcrumbItem>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
processGroupBreadcrumb = (
|
processGroupBreadcrumb = (
|
||||||
<Breadcrumb.Item
|
<BreadcrumbItem
|
||||||
linkAs={Link}
|
|
||||||
data-qa="process-group-breadcrumb-link"
|
data-qa="process-group-breadcrumb-link"
|
||||||
linkProps={{ to: `/admin/process-groups/${processGroupId}` }}
|
href={`/admin/process-groups/${processGroupId}`}
|
||||||
>
|
>
|
||||||
Process Group: {processGroupId}
|
{`Process Group: ${processGroupId}`}
|
||||||
</Breadcrumb.Item>
|
</BreadcrumbItem>
|
||||||
);
|
);
|
||||||
} else if (processGroupId) {
|
} else if (processGroupId) {
|
||||||
processGroupBreadcrumb = (
|
processGroupBreadcrumb = (
|
||||||
<Breadcrumb.Item active>Process Group: {processGroupId}</Breadcrumb.Item>
|
<BreadcrumbItem isCurrentPage>
|
||||||
|
{`Process Group: ${processGroupId}`}
|
||||||
|
</BreadcrumbItem>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Breadcrumb>
|
<Breadcrumb noTrailingSlash>
|
||||||
<Breadcrumb.Item linkAs={Link} linkProps={{ to: '/admin' }}>
|
<BreadcrumbItem href="/admin">Process Groups</BreadcrumbItem>
|
||||||
Process Groups
|
|
||||||
</Breadcrumb.Item>
|
|
||||||
{processGroupBreadcrumb}
|
{processGroupBreadcrumb}
|
||||||
{processModelBreadcrumb}
|
{processModelBreadcrumb}
|
||||||
</Breadcrumb>
|
</Breadcrumb>
|
||||||
|
|
|
@ -1,10 +1,22 @@
|
||||||
// @use '@carbon/react/scss/themes';
|
// @use '@carbon/react/scss/themes';
|
||||||
// @use '@carbon/react/scss/theme' with ($theme: themes.$g100);
|
// @use '@carbon/react/scss/theme' with ($theme: themes.$g100);
|
||||||
|
|
||||||
|
@use '@carbon/react/scss/theme' with
|
||||||
|
(
|
||||||
|
$theme: (
|
||||||
|
cds-link-text-color: #525252
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
@use '@carbon/react';
|
@use '@carbon/react';
|
||||||
@use '@carbon/styles';
|
@use '@carbon/styles';
|
||||||
// @include grid.flex-grid();
|
// @include grid.flex-grid();
|
||||||
|
|
||||||
|
@use '@carbon/colors';
|
||||||
// @use '@carbon/react/scss/colors';
|
// @use '@carbon/react/scss/colors';
|
||||||
|
@use '@carbon/react/scss/themes';
|
||||||
|
|
||||||
|
// var(--cds-link-text-color, var(--cds-link-primary, #0f62fe))
|
||||||
|
|
||||||
// site is mainly using white theme.
|
// site is mainly using white theme.
|
||||||
// header is mainly using g100
|
// header is mainly using g100
|
||||||
|
@ -13,3 +25,17 @@
|
||||||
// background-color: colors.$gray-100;
|
// background-color: colors.$gray-100;
|
||||||
color: white;
|
color: white;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.cds--breadcrumb-item a.cds--link:hover {
|
||||||
|
color: #525252;
|
||||||
|
}
|
||||||
|
.cds--breadcrumb-item a.cds--link:visited {
|
||||||
|
color: #525252;
|
||||||
|
}
|
||||||
|
.cds--breadcrumb-item a.cds--link:visited:hover {
|
||||||
|
color: #525252;
|
||||||
|
}
|
||||||
|
.cds--breadcrumb-item a.cds--link {
|
||||||
|
color: #525252;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@ export interface ProcessModel {
|
||||||
}
|
}
|
||||||
|
|
||||||
// tuple of display value and URL
|
// tuple of display value and URL
|
||||||
export type BreadcrumbItem = [displayValue: string, url?: string];
|
export type HotCrumbItem = [displayValue: string, url?: string];
|
||||||
|
|
||||||
export interface ErrorForDisplay {
|
export interface ErrorForDisplay {
|
||||||
message: string;
|
message: string;
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import { useContext, useEffect, useState } from 'react';
|
import { useContext, useEffect, useState } from 'react';
|
||||||
import { Link, useParams } from 'react-router-dom';
|
import { Link, useParams } from 'react-router-dom';
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
import { Button, Stack } from '@carbon/react';
|
import { Grid, Column, Dropdown, Button, Stack } from '@carbon/react';
|
||||||
import ProcessBreadcrumb from '../components/ProcessBreadcrumb';
|
import ProcessBreadcrumb from '../components/ProcessBreadcrumb';
|
||||||
import FileInput from '../components/FileInput';
|
import FileInput from '../components/FileInput';
|
||||||
import HttpService from '../services/HttpService';
|
import HttpService from '../services/HttpService';
|
||||||
|
@ -210,6 +210,54 @@ export default function ProcessModelShow() {
|
||||||
};
|
};
|
||||||
|
|
||||||
const processModelButtons = () => {
|
const processModelButtons = () => {
|
||||||
|
// <Button
|
||||||
|
// href={`/admin/process-models/${
|
||||||
|
// (processModel as any).process_group_id
|
||||||
|
// }/${(processModel as any).id}/files?file_type=dmn`}
|
||||||
|
// variant="success"
|
||||||
|
// >
|
||||||
|
// Add New DMN File
|
||||||
|
// </Button>
|
||||||
|
// <Button
|
||||||
|
// href={`/admin/process-models/${
|
||||||
|
// (processModel as any).process_group_id
|
||||||
|
// }/${(processModel as any).id}/form?file_ext=json`}
|
||||||
|
// variant="info"
|
||||||
|
// >
|
||||||
|
// Add New JSON File
|
||||||
|
// </Button>
|
||||||
|
// <Button
|
||||||
|
// href={`/admin/process-models/${
|
||||||
|
// (processModel as any).process_group_id
|
||||||
|
// }/${(processModel as any).id}/form?file_ext=md`}
|
||||||
|
// variant="info"
|
||||||
|
// >
|
||||||
|
// Add New Markdown File
|
||||||
|
// </Button>
|
||||||
|
const items = [
|
||||||
|
{
|
||||||
|
key1: (
|
||||||
|
<Grid>
|
||||||
|
<Column md={1}>
|
||||||
|
<Button
|
||||||
|
onClick={(e2: any) => console.log('e2', e2)}
|
||||||
|
variant="primary"
|
||||||
|
>
|
||||||
|
b1
|
||||||
|
</Button>
|
||||||
|
</Column>
|
||||||
|
<Column md={1}>
|
||||||
|
<Button
|
||||||
|
onClick={(e3: any) => console.log('e3', e3)}
|
||||||
|
variant="primary"
|
||||||
|
>
|
||||||
|
b2
|
||||||
|
</Button>
|
||||||
|
</Column>
|
||||||
|
</Grid>
|
||||||
|
),
|
||||||
|
},
|
||||||
|
];
|
||||||
return (
|
return (
|
||||||
<Stack orientation="horizontal" gap={3}>
|
<Stack orientation="horizontal" gap={3}>
|
||||||
<Button onClick={processInstanceCreateAndRun} variant="primary">
|
<Button onClick={processInstanceCreateAndRun} variant="primary">
|
||||||
|
@ -231,30 +279,15 @@ export default function ProcessModelShow() {
|
||||||
>
|
>
|
||||||
Add New BPMN File
|
Add New BPMN File
|
||||||
</Button>
|
</Button>
|
||||||
<Button
|
<Dropdown
|
||||||
href={`/admin/process-models/${
|
id="default"
|
||||||
(processModel as any).process_group_id
|
titleText="Dropdown label"
|
||||||
}/${(processModel as any).id}/files?file_type=dmn`}
|
helperText="This is some helper text"
|
||||||
variant="success"
|
label="Dropdown menu options"
|
||||||
>
|
items={items}
|
||||||
Add New DMN File
|
itemToString={(item: any) => (item ? item.key1 : '')}
|
||||||
</Button>
|
onChange={(e: any) => console.log('e', e)}
|
||||||
<Button
|
/>
|
||||||
href={`/admin/process-models/${
|
|
||||||
(processModel as any).process_group_id
|
|
||||||
}/${(processModel as any).id}/form?file_ext=json`}
|
|
||||||
variant="info"
|
|
||||||
>
|
|
||||||
Add New JSON File
|
|
||||||
</Button>
|
|
||||||
<Button
|
|
||||||
href={`/admin/process-models/${
|
|
||||||
(processModel as any).process_group_id
|
|
||||||
}/${(processModel as any).id}/form?file_ext=md`}
|
|
||||||
variant="info"
|
|
||||||
>
|
|
||||||
Add New Markdown File
|
|
||||||
</Button>
|
|
||||||
</Stack>
|
</Stack>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue