nocobase/packages/plugins/workflow/src/client/style.tsx

312 lines
4.9 KiB
TypeScript
Raw Normal View History

import { css } from '@emotion/css';
export const workflowPageClass = css`
flex-grow: 1;
overflow: hidden;
display: flex;
flex-direction: column;
.workflow-toolbar {
display: flex;
align-items: center;
justify-content: space-between;
position: relative;
padding: 0.5rem 1rem;
background: #fff;
border-bottom: 1px solid #e7e7e7;
header {
display: flex;
align-items: center;
min-height: 2rem;
}
aside {
display: flex;
align-items: center;
gap: 0.5em;
}
.workflow-versions {
label {
margin-right: 0.5em;
}
}
}
.workflow-canvas {
flex-grow: 1;
overflow: auto;
width: 100%;
display: flex;
flex-direction: column;
align-items: center;
padding: 2em;
.end {
cursor: default;
&:hover {
box-shadow: 0 0.25em 0.5em rgba(0, 0, 0, 0.1);
}
}
}
`;
export const workflowVersionDropdownClass = css`
.ant-dropdown-menu-item {
.ant-dropdown-menu-title-content {
text-align: right;
time {
margin-left: 0.5rem;
color: #999;
font-size: 80%;
}
strong {
font-weight: normal;
}
> .enabled {
strong {
font-weight: bold;
}
}
> .unexecuted {
strong {
font-style: italic;
}
}
}
}
`;
export const branchBlockClass = css`
display: flex;
position: relative;
:before {
content: '';
position: absolute;
top: 0;
bottom: 0;
left: calc(50% - 0.5px);
width: 1px;
background-color: #f0f2f5;
}
`;
export const branchClass = css`
display: flex;
flex-direction: column;
align-items: center;
position: relative;
min-width: 20em;
padding: 0 2em;
.workflow-node-list {
flex-grow: 1;
}
.workflow-branch-lines {
position: absolute;
top: 0;
bottom: 0;
width: 1px;
background-color: #ddd;
}
:before,
:after {
content: '';
position: absolute;
height: 1px;
background-color: #ddd;
}
:before {
top: 0;
}
:after {
bottom: 0;
}
:not(:first-child):not(:last-child) {
:before,
:after {
left: 0;
width: 100%;
}
}
:last-child:not(:first-child) {
:before,
:after {
right: 50%;
width: 50%;
}
}
:first-child:not(:last-child) {
:before,
:after {
left: 50%;
width: 50%;
}
}
`;
export const nodeBlockClass = css`
flex-grow: 1;
flex-shrink: 0;
display: flex;
flex-direction: column;
align-items: center;
position: relative;
`;
export const nodeClass = css`
flex-shrink: 0;
display: flex;
flex-direction: column;
align-items: center;
`;
export const nodeCardClass = css`
position: relative;
width: 20em;
background: #fff;
padding: 1em;
box-shadow: 0 0.25em 0.5em rgba(0, 0, 0, 0.1);
border-radius: 0.5em;
cursor: pointer;
transition: box-shadow 0.3s ease;
&.configuring {
box-shadow: 0 0.25em 1em rgba(0, 100, 200, 0.25);
}
.workflow-node-remove-button {
position: absolute;
right: 0.5em;
top: 0.5em;
color: #999;
opacity: 0;
transition: opacity 0.3s ease;
&[disabled] {
display: none;
}
&:hover {
color: red;
}
}
> .workflow-node-job-button {
position: absolute;
top: 1rem;
right: 1rem;
}
.ant-input {
font-weight: bold;
&:not(:focus) {
transition: background-color 0.3s ease, border-color 0.3s ease;
border-color: #f7f7f7;
background-color: #f7f7f7;
&:not(:disabled):hover {
border-color: #eee;
background-color: #eee;
}
&:disabled:hover {
border-color: #f7f7f7;
}
}
}
.workflow-node-config-button {
padding: 0;
}
&:hover {
box-shadow: 0 0.25em 0.5em rgba(0, 0, 0, 0.25);
.workflow-node-remove-button {
opacity: 1;
}
}
`;
export const nodeJobButtonClass = css`
display: flex;
width: 1.25rem;
height: 1.25rem;
min-width: 1.25rem;
justify-content: center;
align-items: center;
font-size: 0.8em;
color: #fff;
&[type='button'] {
border: none;
}
.ant-tag {
padding: 0;
width: 100%;
line-height: 18px;
margin-right: 0;
border-radius: 50%;
text-align: center;
}
`;
export const nodeHeaderClass = css`
position: relative;
`;
export const nodeMetaClass = css`
margin-bottom: 0.5em;
.workflow-node-id {
color: #999;
&:before {
content: '#';
}
}
`;
export const nodeTitleClass = css`
display: flex;
align-items: center;
font-weight: normal;
.workflow-node-id {
color: #999;
}
`;
export const nodeSubtreeClass = css`
display: flex;
flex-direction: column-reverse;
align-items: center;
`;
export const addButtonClass = css`
flex-shrink: 0;
padding: 2em 0;
> .ant-btn {
&:disabled {
visibility: hidden;
}
}
`;