mirror of
https://github.com/status-im/spiff-arena.git
synced 2025-01-28 10:45:07 +00:00
Merge pull request #204 from sartography/feature/bypass_checks_for_save_as_draft
Feature/bypass checks for save as draft
This commit is contained in:
commit
5d80a17c1a
@ -428,8 +428,9 @@ def _task_submit_shared(
|
|||||||
|
|
||||||
if save_as_draft:
|
if save_as_draft:
|
||||||
task_model = _get_task_model_from_guid_or_raise(task_guid, process_instance_id)
|
task_model = _get_task_model_from_guid_or_raise(task_guid, process_instance_id)
|
||||||
|
ProcessInstanceService.update_form_task_data(processor, spiff_task, body, g.user)
|
||||||
json_data_dict = TaskService.update_task_data_on_task_model_and_return_dict_if_updated(
|
json_data_dict = TaskService.update_task_data_on_task_model_and_return_dict_if_updated(
|
||||||
task_model, body, "json_data_hash"
|
task_model, spiff_task.data, "json_data_hash"
|
||||||
)
|
)
|
||||||
if json_data_dict is not None:
|
if json_data_dict is not None:
|
||||||
TaskService.insert_or_update_json_data_dict(json_data_dict)
|
TaskService.insert_or_update_json_data_dict(json_data_dict)
|
||||||
|
@ -325,6 +325,21 @@ class ProcessInstanceService:
|
|||||||
|
|
||||||
cls.replace_file_data_with_digest_references(data, models)
|
cls.replace_file_data_with_digest_references(data, models)
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def update_form_task_data(
|
||||||
|
processor: ProcessInstanceProcessor,
|
||||||
|
spiff_task: SpiffTask,
|
||||||
|
data: dict[str, Any],
|
||||||
|
user: UserModel,
|
||||||
|
) -> None:
|
||||||
|
AuthorizationService.assert_user_can_complete_spiff_task(processor.process_instance_model.id, spiff_task, user)
|
||||||
|
ProcessInstanceService.save_file_data_and_replace_with_digest_references(
|
||||||
|
data,
|
||||||
|
processor.process_instance_model.id,
|
||||||
|
)
|
||||||
|
dot_dct = ProcessInstanceService.create_dot_dict(data)
|
||||||
|
spiff_task.update_data(dot_dct)
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def complete_form_task(
|
def complete_form_task(
|
||||||
processor: ProcessInstanceProcessor,
|
processor: ProcessInstanceProcessor,
|
||||||
@ -338,15 +353,7 @@ class ProcessInstanceService:
|
|||||||
Abstracted here because we need to do it multiple times when completing all tasks in
|
Abstracted here because we need to do it multiple times when completing all tasks in
|
||||||
a multi-instance task.
|
a multi-instance task.
|
||||||
"""
|
"""
|
||||||
AuthorizationService.assert_user_can_complete_spiff_task(processor.process_instance_model.id, spiff_task, user)
|
ProcessInstanceService.update_form_task_data(processor, spiff_task, data, user)
|
||||||
|
|
||||||
ProcessInstanceService.save_file_data_and_replace_with_digest_references(
|
|
||||||
data,
|
|
||||||
processor.process_instance_model.id,
|
|
||||||
)
|
|
||||||
|
|
||||||
dot_dct = ProcessInstanceService.create_dot_dict(data)
|
|
||||||
spiff_task.update_data(dot_dct)
|
|
||||||
# ProcessInstanceService.post_process_form(spiff_task) # some properties may update the data store.
|
# ProcessInstanceService.post_process_form(spiff_task) # some properties may update the data store.
|
||||||
processor.complete_task(spiff_task, human_task, user=user)
|
processor.complete_task(spiff_task, human_task, user=user)
|
||||||
|
|
||||||
|
@ -25,6 +25,10 @@ module.exports = {
|
|||||||
},
|
},
|
||||||
plugins: ['react', 'sonarjs', '@typescript-eslint'],
|
plugins: ['react', 'sonarjs', '@typescript-eslint'],
|
||||||
rules: {
|
rules: {
|
||||||
|
// according to https://github.com/typescript-eslint/typescript-eslint/issues/2621, You should turn off the eslint core rule and turn on the typescript-eslint rule
|
||||||
|
// but not sure which of the above "extends" statements is maybe bringing in eslint core
|
||||||
|
'no-shadow': 'off',
|
||||||
|
'@typescript-eslint/no-shadow': ['error'],
|
||||||
'jest/expect-expect': 'off',
|
'jest/expect-expect': 'off',
|
||||||
'react/jsx-no-bind': 'off',
|
'react/jsx-no-bind': 'off',
|
||||||
'jsx-a11y/no-autofocus': 'off',
|
'jsx-a11y/no-autofocus': 'off',
|
||||||
@ -37,7 +41,8 @@ module.exports = {
|
|||||||
'react/react-in-jsx-scope': 'off',
|
'react/react-in-jsx-scope': 'off',
|
||||||
'react/require-default-props': 'off',
|
'react/require-default-props': 'off',
|
||||||
'import/prefer-default-export': 'off',
|
'import/prefer-default-export': 'off',
|
||||||
'no-unused-vars': [
|
'no-unused-vars': 'off',
|
||||||
|
'@typescript-eslint/no-unused-vars': [
|
||||||
'error',
|
'error',
|
||||||
{
|
{
|
||||||
destructuredArrayIgnorePattern: '^_',
|
destructuredArrayIgnorePattern: '^_',
|
||||||
|
@ -29,6 +29,11 @@ class UnexpectedHumanTaskType extends Error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum FormSubmitType {
|
||||||
|
Default,
|
||||||
|
Draft,
|
||||||
|
}
|
||||||
|
|
||||||
export default function TaskShow() {
|
export default function TaskShow() {
|
||||||
const [task, setTask] = useState<ProcessInstanceTask | null>(null);
|
const [task, setTask] = useState<ProcessInstanceTask | null>(null);
|
||||||
const [userTasks] = useState(null);
|
const [userTasks] = useState(null);
|
||||||
@ -36,6 +41,9 @@ export default function TaskShow() {
|
|||||||
const navigate = useNavigate();
|
const navigate = useNavigate();
|
||||||
const [disabled, setDisabled] = useState(false);
|
const [disabled, setDisabled] = useState(false);
|
||||||
|
|
||||||
|
// save current form data so that we can avoid validations in certain situations
|
||||||
|
const [currentFormObject, setCurrentFormObject] = useState<any>({});
|
||||||
|
|
||||||
const { addError, removeError } = useAPIError();
|
const { addError, removeError } = useAPIError();
|
||||||
|
|
||||||
// eslint-disable-next-line sonarjs/no-duplicate-string
|
// eslint-disable-next-line sonarjs/no-duplicate-string
|
||||||
@ -87,14 +95,16 @@ export default function TaskShow() {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleFormSubmit = (formObject: any, event: any) => {
|
const handleFormSubmit = (
|
||||||
|
formObject: any,
|
||||||
|
_event: any,
|
||||||
|
submitType: FormSubmitType = FormSubmitType.Default
|
||||||
|
) => {
|
||||||
if (disabled) {
|
if (disabled) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const submitButtonId = event.nativeEvent.submitter.id;
|
|
||||||
let queryParams = '';
|
let queryParams = '';
|
||||||
console.log('submitButtonId', submitButtonId);
|
if (submitType === FormSubmitType.Draft) {
|
||||||
if (submitButtonId === 'save-as-draft-button') {
|
|
||||||
queryParams = '?save_as_draft=true';
|
queryParams = '?save_as_draft=true';
|
||||||
}
|
}
|
||||||
setDisabled(true);
|
setDisabled(true);
|
||||||
@ -200,6 +210,11 @@ export default function TaskShow() {
|
|||||||
return errors;
|
return errors;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const updateFormData = (formObject: any) => {
|
||||||
|
currentFormObject.formData = formObject.formData;
|
||||||
|
setCurrentFormObject(currentFormObject);
|
||||||
|
};
|
||||||
|
|
||||||
const formElement = () => {
|
const formElement = () => {
|
||||||
if (!task) {
|
if (!task) {
|
||||||
return null;
|
return null;
|
||||||
@ -250,10 +265,12 @@ export default function TaskShow() {
|
|||||||
} else if (task.type === 'User Task') {
|
} else if (task.type === 'User Task') {
|
||||||
saveAsDraftButton = (
|
saveAsDraftButton = (
|
||||||
<Button
|
<Button
|
||||||
type="submit"
|
|
||||||
id="save-as-draft-button"
|
id="save-as-draft-button"
|
||||||
disabled={disabled}
|
disabled={disabled}
|
||||||
kind="secondary"
|
kind="secondary"
|
||||||
|
onClick={() =>
|
||||||
|
handleFormSubmit(currentFormObject, null, FormSubmitType.Draft)
|
||||||
|
}
|
||||||
>
|
>
|
||||||
Save as draft
|
Save as draft
|
||||||
</Button>
|
</Button>
|
||||||
@ -287,7 +304,10 @@ export default function TaskShow() {
|
|||||||
schema={jsonSchema}
|
schema={jsonSchema}
|
||||||
uiSchema={formUiSchema}
|
uiSchema={formUiSchema}
|
||||||
validator={validator}
|
validator={validator}
|
||||||
|
onChange={updateFormData}
|
||||||
customValidate={customValidate}
|
customValidate={customValidate}
|
||||||
|
omitExtraData
|
||||||
|
liveOmit
|
||||||
>
|
>
|
||||||
{reactFragmentToHideSubmitButton}
|
{reactFragmentToHideSubmitButton}
|
||||||
</Form>
|
</Form>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user