Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
25 changes: 12 additions & 13 deletions ProcessMaker/Http/Controllers/Api/ProcessController.php
Original file line number Diff line number Diff line change
Expand Up @@ -483,6 +483,7 @@ public function update(Request $request, Process $process)
$lastVersion = $process->getDraftOrPublishedLatestVersion();
$process->bpmn = $lastVersion->bpmn;
$process->alternative = $lastVersion->alternative;
$process->stages = $lastVersion->stages;

$rules = Process::rules($process);
if (!$request->has('name')) {
Expand Down Expand Up @@ -2066,24 +2067,22 @@ public function saveStages(Request $request, Process $process)
$stages = $request->input('stages');

if ($alternative === 'B') {

// Get or create alternative B version
$alternativeVersion = ProcessVersion::where('process_id', $process->id)
ProcessVersion::where('process_id', $process->id)
->where('alternative', 'B')
->first();

// Save stages to alternative B version
$alternativeVersion->stages = $stages;
$alternativeVersion->save();

return new ApiCollection($alternativeVersion->stages);
->update([
'stages' => $stages,
]);
} else {
// Save stages to main process (alternative A)
ProcessVersion::where('process_id', $process->id)
->where('alternative', 'A')
->update([
'stages' => $stages,
]);
$process->stages = $stages;
$process->save();

return new ApiCollection($process->stages);
}

return new ApiCollection($stages);
}

/**
Expand Down
10 changes: 10 additions & 0 deletions ProcessMaker/Traits/HasVersioning.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
use ProcessMaker\Models\Process;
use ProcessMaker\Models\ProcessMakerModel;
use ProcessMaker\Models\ProcessRequest;
use ProcessMaker\Models\ProcessVersion;

trait HasVersioning
{
Expand Down Expand Up @@ -77,10 +78,19 @@ public function saveVersion()
public function saveDraft(string $alternative = null)
{
$attributes = $this->getModelAttributes();

$attributes['draft'] = true;
if ($this->hasAlternative()) {
$alternative = $alternative ?: $this->alternative;
$attributes['alternative'] = $alternative;

$processVersion = ProcessVersion::where('process_id', $this->id)
->where('alternative', $attributes['alternative'])
->where('draft', 1)
->first();
if ($processVersion) {
$attributes['stages'] = $processVersion->stages;
}
}

return $this->versions()->updateOrCreate(
Expand Down
1 change: 1 addition & 0 deletions resources/js/processes/modeler/components/ModelerApp.vue
Original file line number Diff line number Diff line change
Expand Up @@ -173,6 +173,7 @@ export default {
},
},
mounted() {
window.$modelerApp = this;
ProcessMaker.$modeler = this.$refs.modeler;
window.ProcessMaker.EventBus.$emit("modeler-app-init", this);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,10 @@ const getHighlightedNode = () => getModeler().highlightedNode;

const getDefinition = () => getHighlightedNode().definition;

const saveProcess = () => {
window.$modelerApp?.autosaveApiCall?.();
}

const getConfigFromDefinition = (definition) => {
let config = {};
try {
Expand Down Expand Up @@ -146,18 +150,22 @@ const removeStageToFlow = () => {
const onChange = (stages) => {
updateStagesForAllFlowConfigs(stages);
saveStagesToApi(stages);
saveProcess();
};

const onUpdate = (stages, index, val, Oldal) => {
updateStagesForAllFlowConfigs(stages);
saveProcess();
};

const onRemove = (stages, index, removed) => {
removeStageInAllFlowConfig(removed);
saveProcess();
};

const onClickCheckbox = (stage) => {
applyStageToFlow(stage);
saveProcess();
};

const onClickSelected = (stage) => {
Expand Down
Loading