onUpdateSettingField("stateless", value)}
+ onChange={(value) => updateSettingsField("stateless", value)}
/>
@@ -145,9 +165,9 @@ function TestScenarioDrawerSettingsPanel({
onUpdateSettingField("skipFromBuild", value)}
+ onChange={(value) => updateSettingsField("skipFromBuild", value)}
/>
diff --git a/packages/scesim-editor/src/externalModels/TestScenarioEditorDependenciesContext.tsx b/packages/scesim-editor/src/externalModels/TestScenarioEditorDependenciesContext.tsx
new file mode 100644
index 00000000000..b74b9447f3d
--- /dev/null
+++ b/packages/scesim-editor/src/externalModels/TestScenarioEditorDependenciesContext.tsx
@@ -0,0 +1,64 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import * as React from "react";
+import { useContext, useMemo } from "react";
+import {
+ OnRequestExternalModelsAvailableToInclude,
+ OnRequestExternalModelByPath,
+ ExternalDmnsIndex,
+} from "../TestScenarioEditor";
+
+export interface TestScenarioEditorExternalModelsContextType {
+ onRequestExternalModelByPath?: OnRequestExternalModelByPath;
+ onRequestExternalModelsAvailableToInclude?: OnRequestExternalModelsAvailableToInclude;
+ externalModelsByNamespace?: ExternalDmnsIndex;
+}
+
+const TestScenarioEditorExternalModelsContext = React.createContext(
+ {} as any
+);
+
+export function useExternalModels() {
+ return useContext(TestScenarioEditorExternalModelsContext);
+}
+
+export function TestScenarioEditorExternalModelsContextProvider(
+ _props: React.PropsWithChildren
+) {
+ const { children, ...props } = _props;
+
+ const value = useMemo(() => {
+ return {
+ externalModelsByNamespace: props.externalModelsByNamespace,
+ onRequestExternalModelByPath: props.onRequestExternalModelByPath,
+ onRequestExternalModelsAvailableToInclude: props.onRequestExternalModelsAvailableToInclude,
+ };
+ }, [
+ props.externalModelsByNamespace,
+ props.onRequestExternalModelByPath,
+ props.onRequestExternalModelsAvailableToInclude,
+ ]);
+
+ return (
+
+ {children}
+
+ );
+}
diff --git a/packages/runtime-tools-task-console-webapp/src/env/Env.ts b/packages/scesim-editor/src/hook/useEffectAfterFirstRender.ts
similarity index 65%
rename from packages/runtime-tools-task-console-webapp/src/env/Env.ts
rename to packages/scesim-editor/src/hook/useEffectAfterFirstRender.ts
index 449d6e97419..df84f4b1ae9 100644
--- a/packages/runtime-tools-task-console-webapp/src/env/Env.ts
+++ b/packages/scesim-editor/src/hook/useEffectAfterFirstRender.ts
@@ -17,20 +17,16 @@
* under the License.
*/
-import { ENV_FILE_PATH } from "./EnvConstants";
-import { EnvJson } from "./EnvJson";
+import { useEffect, useRef } from "react";
-export async function initEnv() {
- return fetch(ENV_FILE_PATH)
- .then(async (response) => {
- if (!response.ok) {
- throw new Error(`Failed to fetch ${ENV_FILE_PATH}: ${response.statusText}`);
- }
+export function useEffectAfterFirstRender(effect: Parameters[0], b: React.DependencyList) {
+ const didMountRef = useRef(false);
- const envJson = await response.json();
- return envJson as EnvJson;
- })
- .catch((e) => {
- console.error(e);
- });
+ useEffect(() => {
+ if (didMountRef.current) {
+ return effect();
+ }
+ didMountRef.current = true;
+ // eslint-disable-next-line react-hooks/exhaustive-deps
+ }, b);
}
diff --git a/packages/scesim-editor/src/i18n/TestScenarioEditorI18n.ts b/packages/scesim-editor/src/i18n/TestScenarioEditorI18n.ts
index be68682f4d4..1eaebb8771b 100644
--- a/packages/scesim-editor/src/i18n/TestScenarioEditorI18n.ts
+++ b/packages/scesim-editor/src/i18n/TestScenarioEditorI18n.ts
@@ -115,6 +115,12 @@ interface TestScenarioEditorDictionary extends ReferenceDictionary {
title: string;
};
};
+ errorFallBack: {
+ title: string;
+ body: string;
+ lastActionButton: string;
+ fileIssueHref: string;
+ };
sidebar: {
cheatSheetTooltip: string;
dataSelectorTooltip: string;
diff --git a/packages/scesim-editor/src/i18n/locales/en.ts b/packages/scesim-editor/src/i18n/locales/en.ts
index 72de8ce02cc..888f1e2b871 100644
--- a/packages/scesim-editor/src/i18n/locales/en.ts
+++ b/packages/scesim-editor/src/i18n/locales/en.ts
@@ -137,6 +137,12 @@ export const en: TestScenarioEditorI18n = {
title: "Settings",
},
},
+ errorFallBack: {
+ title: "An unexpected error happened",
+ body: "This is a bug. Please consider reporting it so the DMN Editor can continue improving. See the details below.",
+ lastActionButton: "Try undoing last action",
+ fileIssueHref: "File an issue",
+ },
sidebar: {
cheatSheetTooltip: "CheatSheet: Useful information for Test Scenario Usage",
dataSelectorTooltip: "Selector: It provides a tool to edit your Scenarios",
diff --git a/packages/scesim-editor/src/mutations/addColumn.ts b/packages/scesim-editor/src/mutations/addColumn.ts
new file mode 100644
index 00000000000..ab5a22bf7a3
--- /dev/null
+++ b/packages/scesim-editor/src/mutations/addColumn.ts
@@ -0,0 +1,183 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import _ from "lodash";
+import { v4 as uuid } from "uuid";
+
+import {
+ SceSim__FactMappingType,
+ SceSim__FactMappingValuesTypes,
+} from "@kie-tools/scesim-marshaller/dist/schemas/scesim-1_8/ts-gen/types";
+import { InsertRowColumnsDirection } from "@kie-tools/boxed-expression-component/dist/api/BeeTable";
+
+export function addColumn({
+ beforeIndex,
+ factMappings,
+ factMappingValues,
+ insertDirection,
+ isInstance,
+ selectedColumnFactMappingIndex,
+}: {
+ beforeIndex: number;
+ factMappings: SceSim__FactMappingType[];
+ factMappingValues: SceSim__FactMappingValuesTypes[];
+ insertDirection: InsertRowColumnsDirection;
+ isInstance: boolean;
+ selectedColumnFactMappingIndex: number;
+}) {
+ const selectedColumnFactMapping = factMappings[selectedColumnFactMappingIndex];
+ const targetColumnIndex = determineNewColumnTargetIndex(
+ factMappings,
+ insertDirection,
+ isInstance,
+ selectedColumnFactMappingIndex,
+ selectedColumnFactMapping
+ );
+
+ const instanceDefaultNames = factMappings
+ .filter((factMapping) => factMapping.factAlias!.__$$text.startsWith("INSTANCE-"))
+ .map((factMapping) => factMapping.factAlias!.__$$text);
+
+ const isNewInstance = isInstance || selectedColumnFactMapping.factIdentifier.className?.__$$text === "java.lang.Void";
+
+ const newFactMapping = {
+ className: { __$$text: "java.lang.Void" },
+ columnWidth: { __$$text: 150 },
+ expressionAlias: { __$$text: "PROPERTY" },
+ expressionElements: isNewInstance
+ ? undefined
+ : {
+ ExpressionElement: [
+ {
+ step: {
+ __$$text: selectedColumnFactMapping.expressionElements!.ExpressionElement![0].step.__$$text,
+ },
+ },
+ ],
+ },
+ expressionIdentifier: {
+ name: { __$$text: `_${uuid()}`.toLocaleUpperCase() },
+ type: { __$$text: selectedColumnFactMapping.expressionIdentifier.type!.__$$text },
+ },
+ factAlias: {
+ __$$text: isNewInstance
+ ? getNextAvailablePrefixedName(instanceDefaultNames, "INSTANCE")
+ : selectedColumnFactMapping.factAlias.__$$text,
+ },
+ factIdentifier: {
+ name: {
+ __$$text: isNewInstance
+ ? getNextAvailablePrefixedName(instanceDefaultNames, "INSTANCE")
+ : selectedColumnFactMapping.factIdentifier.name!.__$$text,
+ },
+ className: {
+ __$$text: isNewInstance ? "java.lang.Void" : selectedColumnFactMapping.factIdentifier.className!.__$$text,
+ },
+ },
+ factMappingValueType: { __$$text: "NOT_EXPRESSION" },
+ };
+
+ factMappings.splice(targetColumnIndex, 0, newFactMapping);
+
+ factMappingValues.forEach((scenario) => {
+ scenario.factMappingValues.FactMappingValue!.splice(beforeIndex + 1, 0, {
+ expressionIdentifier: {
+ name: { __$$text: newFactMapping.expressionIdentifier.name.__$$text },
+ type: { __$$text: newFactMapping.expressionIdentifier.type.__$$text },
+ },
+ factIdentifier: {
+ name: { __$$text: newFactMapping.factIdentifier.name.__$$text },
+ className: { __$$text: newFactMapping.factIdentifier.className.__$$text },
+ },
+ rawValue: { __$$text: "", "@_class": "string" },
+ });
+ });
+}
+
+/* It determines in which index position a column should be added. In case of a field, the new column index is simply
+ in the right or in the left of the selected column. In case of a new instance, it's required to find the first column
+ index outside the selected Instance group. */
+const determineNewColumnTargetIndex = (
+ factMappings: SceSim__FactMappingType[],
+ insertDirection: InsertRowColumnsDirection,
+ isInstance: boolean,
+ selectedColumnIndex: number,
+ selectedFactMapping: SceSim__FactMappingType
+) => {
+ const groupType = selectedFactMapping.expressionIdentifier.type!.__$$text;
+ const instanceName = selectedFactMapping.factIdentifier.name!.__$$text;
+ const instanceType = selectedFactMapping.factIdentifier.className!.__$$text;
+
+ if (!isInstance) {
+ if (insertDirection === InsertRowColumnsDirection.AboveOrRight) {
+ return selectedColumnIndex + 1;
+ } else {
+ return selectedColumnIndex;
+ }
+ }
+
+ let newColumnTargetColumn = -1;
+
+ if (insertDirection === InsertRowColumnsDirection.AboveOrRight) {
+ for (let i = selectedColumnIndex; i < factMappings.length; i++) {
+ const currentFM = factMappings[i];
+ if (
+ currentFM.expressionIdentifier.type!.__$$text === groupType &&
+ currentFM.factIdentifier.name?.__$$text === instanceName &&
+ currentFM.factIdentifier.className?.__$$text === instanceType
+ ) {
+ if (i == factMappings.length - 1) {
+ newColumnTargetColumn = i + 1;
+ }
+ } else {
+ newColumnTargetColumn = i;
+ break;
+ }
+ }
+ } else {
+ for (let i = selectedColumnIndex; i >= 0; i--) {
+ const currentFM = factMappings[i];
+
+ if (
+ currentFM.expressionIdentifier.type!.__$$text === groupType &&
+ currentFM.factIdentifier.name?.__$$text === instanceName &&
+ currentFM.factIdentifier.className?.__$$text === instanceType
+ ) {
+ if (i == 0) {
+ newColumnTargetColumn = 0;
+ }
+ } else {
+ newColumnTargetColumn = i + 1;
+ break;
+ }
+ }
+ }
+
+ return newColumnTargetColumn;
+};
+
+const getNextAvailablePrefixedName = (
+ names: string[],
+ namePrefix: string,
+ lastIndex: number = names.length
+): string => {
+ const candidate = `${namePrefix}-${lastIndex + 1}`;
+ const elemWithCandidateName = names.indexOf(candidate);
+ return elemWithCandidateName >= 0 ? getNextAvailablePrefixedName(names, namePrefix, lastIndex + 1) : candidate;
+};
diff --git a/packages/scesim-editor/src/mutations/addRow.ts b/packages/scesim-editor/src/mutations/addRow.ts
new file mode 100644
index 00000000000..65887921b4e
--- /dev/null
+++ b/packages/scesim-editor/src/mutations/addRow.ts
@@ -0,0 +1,56 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import {
+ SceSim__FactMappingType,
+ SceSim__FactMappingValuesTypes,
+} from "@kie-tools/scesim-marshaller/dist/schemas/scesim-1_8/ts-gen/types";
+
+export function addRow({
+ beforeIndex,
+ factMappings,
+ factMappingValues,
+}: {
+ beforeIndex: number;
+ factMappings: SceSim__FactMappingType[];
+ factMappingValues: SceSim__FactMappingValuesTypes[];
+}) {
+ /* Creating a new Scenario (Row) composed by a list of FactMappingValues. The list order is not relevant. */
+ const factMappingValuesItems = factMappings.map((factMapping) => {
+ return {
+ expressionIdentifier: {
+ name: { __$$text: factMapping.expressionIdentifier.name!.__$$text },
+ type: { __$$text: factMapping.expressionIdentifier.type!.__$$text },
+ },
+ factIdentifier: {
+ name: { __$$text: factMapping.factIdentifier.name!.__$$text },
+ className: { __$$text: factMapping.factIdentifier.className!.__$$text },
+ },
+ rawValue: { __$$text: "", "@_class": "string" },
+ };
+ });
+
+ const newScenario = {
+ factMappingValues: {
+ FactMappingValue: factMappingValuesItems,
+ },
+ };
+
+ factMappingValues.splice(beforeIndex, 0, newScenario);
+}
diff --git a/packages/scesim-editor/src/mutations/deleteColumn.ts b/packages/scesim-editor/src/mutations/deleteColumn.ts
new file mode 100644
index 00000000000..07137ff667d
--- /dev/null
+++ b/packages/scesim-editor/src/mutations/deleteColumn.ts
@@ -0,0 +1,87 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import _, { isNumber } from "lodash";
+import {
+ SceSim__FactMappingType,
+ SceSim__FactMappingValuesTypes,
+} from "@kie-tools/scesim-marshaller/dist/schemas/scesim-1_8/ts-gen/types";
+
+export function deleteColumn({
+ factMappingIndexToRemove,
+ factMappings,
+ factMappingValues,
+ isBackground,
+ isInstance,
+ selectedColumnIndex,
+}: {
+ factMappingIndexToRemove: number;
+ factMappings: SceSim__FactMappingType[];
+ factMappingValues: SceSim__FactMappingValuesTypes[];
+ isBackground: boolean;
+ isInstance: boolean;
+ selectedColumnIndex: number;
+}): {
+ deletedFactMappingIndexs: number[];
+} {
+ /* Retriving the FactMapping (Column) to be removed). If the user selected a single column, it finds the exact
+ FactMapping to delete. If the user selected an instance (group of columns), it retrives all the FactMappings
+ that belongs to the the instance group */
+ const factMappingToRemove = factMappings[factMappingIndexToRemove];
+ const groupType = factMappingToRemove.expressionIdentifier.type!.__$$text;
+ const instanceName = factMappingToRemove.factIdentifier.name!.__$$text;
+ const instanceType = factMappingToRemove.factIdentifier.className!.__$$text;
+
+ const allFactMappingWithIndexesToRemove = isInstance
+ ? factMappings
+ .map((factMapping, index) => {
+ if (
+ factMapping.expressionIdentifier.type!.__$$text === groupType &&
+ factMapping.factIdentifier.name?.__$$text === instanceName &&
+ factMapping.factIdentifier.className?.__$$text === instanceType
+ ) {
+ return { factMappingIndex: index, factMapping: factMapping };
+ } else {
+ return {};
+ }
+ })
+ .filter((item) => isNumber(item.factMappingIndex))
+ : [{ factMappingIndex: selectedColumnIndex + (isBackground ? 0 : 1), factMapping: factMappingToRemove }];
+
+ factMappings.splice(allFactMappingWithIndexesToRemove[0].factMappingIndex!, allFactMappingWithIndexesToRemove.length);
+
+ factMappingValues.forEach((rowData) => {
+ allFactMappingWithIndexesToRemove.forEach((itemToRemove) => {
+ const factMappingValueColumnIndexToRemove = rowData.factMappingValues.FactMappingValue!.findIndex(
+ (factMappingValue) =>
+ factMappingValue.factIdentifier.name?.__$$text === itemToRemove.factMapping!.factIdentifier.name?.__$$text &&
+ factMappingValue.factIdentifier.className?.__$$text ===
+ itemToRemove.factMapping!.factIdentifier.className?.__$$text &&
+ factMappingValue.expressionIdentifier.name?.__$$text ===
+ itemToRemove.factMapping!.expressionIdentifier.name?.__$$text &&
+ factMappingValue.expressionIdentifier.type?.__$$text ===
+ itemToRemove.factMapping!.expressionIdentifier.type?.__$$text
+ );
+
+ rowData.factMappingValues.FactMappingValue!.splice(factMappingValueColumnIndexToRemove, 1);
+ });
+ });
+
+ return { deletedFactMappingIndexs: allFactMappingWithIndexesToRemove.flatMap((item) => item.factMappingIndex!) };
+}
diff --git a/packages/runtime-tools-task-console-webapp/src/components/styles.css b/packages/scesim-editor/src/mutations/deleteRow.ts
similarity index 68%
rename from packages/runtime-tools-task-console-webapp/src/components/styles.css
rename to packages/scesim-editor/src/mutations/deleteRow.ts
index 4d205ff2d35..26f14903a7d 100644
--- a/packages/runtime-tools-task-console-webapp/src/components/styles.css
+++ b/packages/scesim-editor/src/mutations/deleteRow.ts
@@ -1,4 +1,4 @@
-/**
+/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
@@ -7,7 +7,7 @@
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
- * http://www.apache.org/licenses/LICENSE-2.0
+ * http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
@@ -16,10 +16,15 @@
* specific language governing permissions and limitations
* under the License.
*/
-.kogito-task-console__full-size {
- height: 100%;
-}
-.kogito-task-console__task-details-page {
- margin-top: 21px;
+import { SceSim__FactMappingValuesTypes } from "@kie-tools/scesim-marshaller/dist/schemas/scesim-1_8/ts-gen/types";
+
+export function deleteRow({
+ rowIndex,
+ factMappingValues,
+}: {
+ rowIndex: number;
+ factMappingValues: SceSim__FactMappingValuesTypes[];
+}) {
+ factMappingValues.splice(rowIndex, 1);
}
diff --git a/packages/scesim-editor/src/mutations/duplicateRow.ts b/packages/scesim-editor/src/mutations/duplicateRow.ts
new file mode 100644
index 00000000000..268da3f826f
--- /dev/null
+++ b/packages/scesim-editor/src/mutations/duplicateRow.ts
@@ -0,0 +1,41 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import { SceSim__FactMappingValuesTypes } from "@kie-tools/scesim-marshaller/dist/schemas/scesim-1_8/ts-gen/types";
+
+export function dupliacteRow({
+ rowIndex,
+ factMappingValues,
+}: {
+ rowIndex: number;
+ factMappingValues: SceSim__FactMappingValuesTypes[];
+}) {
+ /* It simply clones a Scenario (Row) and adds it in a current-cloned Scenario list */
+ const factMappingValuesItems = JSON.parse(
+ JSON.stringify(factMappingValues[rowIndex].factMappingValues.FactMappingValue)
+ );
+
+ const newScenario = {
+ factMappingValues: {
+ FactMappingValue: factMappingValuesItems,
+ },
+ };
+
+ factMappingValues.splice(rowIndex, 0, newScenario);
+}
diff --git a/packages/scesim-editor/src/mutations/updateCell.ts b/packages/scesim-editor/src/mutations/updateCell.ts
new file mode 100644
index 00000000000..3a984fb32c7
--- /dev/null
+++ b/packages/scesim-editor/src/mutations/updateCell.ts
@@ -0,0 +1,52 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import {
+ SceSim__FactMappingType,
+ SceSim__FactMappingValuesTypes,
+} from "@kie-tools/scesim-marshaller/dist/schemas/scesim-1_8/ts-gen/types";
+
+export function updateCell({
+ columnIndex,
+ factMappings,
+ factMappingValuesTypes,
+ rowIndex,
+ value,
+}: {
+ columnIndex: number;
+ factMappings: SceSim__FactMappingType[];
+ factMappingValuesTypes: SceSim__FactMappingValuesTypes[];
+ rowIndex: number;
+ value: any;
+}) {
+ /* To update the related FactMappingValue, it compares every FactMappingValue associated with the Scenario (Row)
+ that contains the cell with the FactMapping (Column) fields factIdentifier and expressionIdentifier */
+ const factMapping = factMappings[columnIndex];
+ const factMappingValues = factMappingValuesTypes[rowIndex].factMappingValues.FactMappingValue!;
+
+ const factMappingValueToUpdateIndex = factMappingValues.findIndex(
+ (factMappingValue) =>
+ factMappingValue.factIdentifier.name?.__$$text === factMapping!.factIdentifier.name?.__$$text &&
+ factMappingValue.factIdentifier.className?.__$$text === factMapping!.factIdentifier.className?.__$$text &&
+ factMappingValue.expressionIdentifier.name?.__$$text === factMapping!.expressionIdentifier.name?.__$$text &&
+ factMappingValue.expressionIdentifier.type?.__$$text === factMapping!.expressionIdentifier.type?.__$$text
+ );
+ const factMappingValueToUpdate = factMappingValues[factMappingValueToUpdateIndex];
+ factMappingValueToUpdate.rawValue = { __$$text: value };
+}
diff --git a/packages/scesim-editor/src/mutations/updateColumn.ts b/packages/scesim-editor/src/mutations/updateColumn.ts
new file mode 100644
index 00000000000..081e78de4c4
--- /dev/null
+++ b/packages/scesim-editor/src/mutations/updateColumn.ts
@@ -0,0 +1,84 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import _ from "lodash";
+import {
+ SceSim__FactMappingType,
+ SceSim__FactMappingValuesTypes,
+} from "@kie-tools/scesim-marshaller/dist/schemas/scesim-1_8/ts-gen/types";
+
+export function updateColumn({
+ className,
+ expressionAlias,
+ expressionElementsSteps,
+ expressionIdentifierName,
+ expressionIdentifierType,
+ factMappings,
+ factMappingValuesTypes,
+ factMappingValueType,
+ factClassName,
+ factIdentifierClassName,
+ factIdentifierName,
+ factName,
+ selectedColumnIndex,
+}: {
+ className: string;
+ expressionAlias: string;
+ expressionElementsSteps: string[];
+ expressionIdentifierName: string | undefined;
+ expressionIdentifierType: string | undefined;
+ factMappings: SceSim__FactMappingType[];
+ factMappingValuesTypes: SceSim__FactMappingValuesTypes[];
+ factMappingValueType: "EXPRESSION" | "NOT_EXPRESSION";
+ factClassName: string;
+ factIdentifierClassName: string | undefined;
+ factIdentifierName: string | undefined;
+ factName: string;
+ selectedColumnIndex: number;
+}): { updatedFactMapping: SceSim__FactMappingType } {
+ const factMappingToUpdate = factMappings[selectedColumnIndex];
+ factMappingToUpdate.className = { __$$text: className };
+ factMappingToUpdate.factAlias = { __$$text: factName };
+ factMappingToUpdate.factIdentifier.className = { __$$text: factClassName };
+ factMappingToUpdate.factIdentifier.name = { __$$text: factName };
+ factMappingToUpdate.factMappingValueType = { __$$text: factMappingValueType };
+ factMappingToUpdate.expressionAlias = { __$$text: expressionAlias };
+ factMappingToUpdate.expressionElements = {
+ ExpressionElement: expressionElementsSteps.map((ee) => {
+ return { step: { __$$text: ee } };
+ }),
+ };
+
+ factMappingValuesTypes.forEach((fmv) => {
+ const factMappingValues = fmv.factMappingValues.FactMappingValue!;
+ const factMappingValueToUpdateIndex = factMappingValues.findIndex(
+ (factMappingValue) =>
+ factMappingValue.factIdentifier.name?.__$$text === factIdentifierName &&
+ factMappingValue.factIdentifier.className?.__$$text === factIdentifierClassName &&
+ factMappingValue.expressionIdentifier.name?.__$$text === expressionIdentifierName &&
+ factMappingValue.expressionIdentifier.type?.__$$text === expressionIdentifierType
+ );
+ const factMappingValueToUpdate = factMappingValues[factMappingValueToUpdateIndex];
+ factMappingValueToUpdate.factIdentifier.className = { __$$text: factClassName };
+ factMappingValueToUpdate.factIdentifier.name = { __$$text: factName };
+ //factMappingValueToUpdate.rawValue = { __$$text: update.value }, //TODO 2 related see kie-issues#1514
+ });
+
+ return { updatedFactMapping: JSON.parse(JSON.stringify(factMappingToUpdate)) };
+}
diff --git a/packages/runtime-tools-task-console-webapp/src/env/EnvJson.ts b/packages/scesim-editor/src/mutations/updateColumnWidth.ts
similarity index 60%
rename from packages/runtime-tools-task-console-webapp/src/env/EnvJson.ts
rename to packages/scesim-editor/src/mutations/updateColumnWidth.ts
index c87128556a1..8a59346ad03 100644
--- a/packages/runtime-tools-task-console-webapp/src/env/EnvJson.ts
+++ b/packages/scesim-editor/src/mutations/updateColumnWidth.ts
@@ -17,13 +17,22 @@
* under the License.
*/
-import { KogitoConsolesKeycloakEnv } from "@kie-tools/runtime-tools-components/dist/utils/KeycloakClient";
+import { SceSim__FactMappingType } from "@kie-tools/scesim-marshaller/dist/schemas/scesim-1_8/ts-gen/types";
-export interface EnvJson extends KogitoConsolesKeycloakEnv {
- RUNTIME_TOOLS_TASK_CONSOLE_KOGITO_ENV_MODE: "DEV" | "PROD";
- RUNTIME_TOOLS_TASK_CONSOLE_KOGITO_APP_NAME: string;
- RUNTIME_TOOLS_TASK_CONSOLE_KOGITO_APP_VERSION: string;
- RUNTIME_TOOLS_TASK_CONSOLE_KOGITO_TASK_STATES_LIST: string;
- RUNTIME_TOOLS_TASK_CONSOLE_KOGITO_TASK_ACTIVE_STATES_LIST: string;
- RUNTIME_TOOLS_TASK_CONSOLE_DATA_INDEX_ENDPOINT: string;
+export function updateColumnWidth({
+ factMappings,
+ columnIndex,
+ newWidth,
+ oldWidth,
+}: {
+ factMappings: SceSim__FactMappingType[];
+ columnIndex: number;
+ newWidth: number | undefined;
+ oldWidth: number | undefined;
+}) {
+ if (newWidth && oldWidth !== newWidth) {
+ factMappings[columnIndex].columnWidth = {
+ __$$text: newWidth,
+ };
+ }
}
diff --git a/packages/scesim-editor/src/reactExt/ErrorBoundary.tsx b/packages/scesim-editor/src/reactExt/ErrorBoundary.tsx
deleted file mode 100644
index e61f50af242..00000000000
--- a/packages/scesim-editor/src/reactExt/ErrorBoundary.tsx
+++ /dev/null
@@ -1,62 +0,0 @@
-/*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
-
-import * as React from "react";
-import { ErrorInfo } from "react";
-
-interface State {
- hasError: boolean;
-}
-
-interface Props {
- children: React.ReactNode;
- error: React.ReactNode;
- setError?: React.Dispatch;
-}
-
-export class ErrorBoundary extends React.Component {
- constructor(props: any) {
- super(props);
- this.state = { hasError: false };
- }
-
- public reset() {
- this.props.setError?.(null);
- this.setState({ hasError: false });
- }
-
- public componentDidCatch(error: Error, errorInfo: ErrorInfo) {
- this.props.setError?.(error);
- console.error(error);
- }
-
- public render() {
- if (this.state.hasError) {
- return this.props.error;
- }
-
- return this.props.children;
- }
-
- public static getDerivedStateFromError(error: Error) {
- return { hasError: true };
- }
-}
-
-export default ErrorBoundary;
diff --git a/packages/scesim-editor/src/sidebar/TestScenarioSideBarMenu.tsx b/packages/scesim-editor/src/sidebar/TestScenarioSideBarMenu.tsx
index df9671c6bb9..de41743c500 100644
--- a/packages/scesim-editor/src/sidebar/TestScenarioSideBarMenu.tsx
+++ b/packages/scesim-editor/src/sidebar/TestScenarioSideBarMenu.tsx
@@ -27,25 +27,32 @@ import CogIcon from "@patternfly/react-icons/dist/esm/icons/cog-icon";
import EditIcon from "@patternfly/react-icons/dist/esm/icons/edit-alt-icon";
import InfoIcon from "@patternfly/react-icons/dist/esm/icons/info-icon";
-import { TestScenarioEditorDock } from "../TestScenarioEditor";
import { useTestScenarioEditorI18n } from "../i18n";
+import { TestScenarioEditorDock } from "../store/TestScenarioEditorStore";
+import { useTestScenarioEditorStore, useTestScenarioEditorStoreApi } from "../store/TestScenarioStoreContext";
import "./TestScenarioSideBarMenu.css";
-function TestScenarioSideBarMenu({
- onSideBarButtonClicked,
- selectedSideBarMenuItem,
-}: {
- onSideBarButtonClicked: (selected: TestScenarioEditorDock) => void;
- selectedSideBarMenuItem: { isOpen: boolean; selected: TestScenarioEditorDock };
-}) {
+function TestScenarioSideBarMenu() {
const { i18n } = useTestScenarioEditorI18n();
+ const navigation = useTestScenarioEditorStore((state) => state.navigation);
+ const testScenarioEditorStoreApi = useTestScenarioEditorStoreApi();
const isSelectedMenuItem = useCallback(
(item: TestScenarioEditorDock) => {
- return selectedSideBarMenuItem.isOpen && selectedSideBarMenuItem.selected === item;
+ return navigation.dock.isOpen && navigation.dock.selected === item;
},
- [selectedSideBarMenuItem]
+ [navigation.dock]
+ );
+
+ const updateSelectedDock = useCallback(
+ (selected: TestScenarioEditorDock) => {
+ testScenarioEditorStoreApi.setState((state) => {
+ state.navigation.dock.isOpen = true;
+ state.navigation.dock.selected = selected;
+ });
+ },
+ [testScenarioEditorStoreApi]
);
return (
@@ -58,7 +65,7 @@ function TestScenarioSideBarMenu({
: "kie-scesim-editor-side-bar-menu--button"
}
variant="plain"
- onClick={() => onSideBarButtonClicked(TestScenarioEditorDock.DATA_OBJECT)}
+ onClick={() => updateSelectedDock(TestScenarioEditorDock.DATA_OBJECT)}
icon={}
/>
@@ -70,7 +77,7 @@ function TestScenarioSideBarMenu({
: "kie-scesim-editor-side-bar-menu--button"
}
icon={}
- onClick={() => onSideBarButtonClicked(TestScenarioEditorDock.CHEATSHEET)}
+ onClick={() => updateSelectedDock(TestScenarioEditorDock.CHEATSHEET)}
variant="plain"
/>
@@ -82,7 +89,7 @@ function TestScenarioSideBarMenu({
: "kie-scesim-editor-side-bar-menu--button"
}
icon={
}
- onClick={() => onSideBarButtonClicked(TestScenarioEditorDock.SETTINGS)}
+ onClick={() => updateSelectedDock(TestScenarioEditorDock.SETTINGS)}
variant="plain"
/>
diff --git a/packages/scesim-editor/src/store/ComputedStateCache.ts b/packages/scesim-editor/src/store/ComputedStateCache.ts
new file mode 100644
index 00000000000..400595c931b
--- /dev/null
+++ b/packages/scesim-editor/src/store/ComputedStateCache.ts
@@ -0,0 +1,96 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+export type TypeOrReturnType
= T extends (...args: any[]) => any ? ReturnType : T;
+
+export type CacheEntry = {
+ value: TypeOrReturnType | undefined;
+ dependencies: readonly any[];
+};
+
+export type Cache = {
+ [K in keyof T]: CacheEntry;
+};
+
+let r: number = 0;
+
+export class ComputedStateCache> {
+ private readonly cache: Cache;
+
+ constructor(initialValues: Cache) {
+ this.cache = { ...initialValues };
+ }
+
+ public cached(
+ key: K,
+ delegate: (...dependencies: D) => TypeOrReturnType,
+ dependencies: D
+ ): TypeOrReturnType {
+ r++;
+
+ const cachedDeps = this.cache[key]?.dependencies ?? [];
+
+ let depsAreEqual = cachedDeps.length === dependencies.length;
+ if (depsAreEqual) {
+ for (let i = 0; i < cachedDeps.length; i++) {
+ if (!Object.is(cachedDeps[i], dependencies[i])) {
+ depsAreEqual = false;
+ }
+ }
+ }
+
+ if (depsAreEqual) {
+ return this.cache[key].value!;
+ }
+
+ const v = delegate(...dependencies);
+ this.cache[key].dependencies = dependencies;
+ this.cache[key].value = v;
+ return v;
+ }
+
+ public cachedData(
+ key: K,
+ delegate: (...data: Y) => TypeOrReturnType,
+ data: Y,
+ dependencies: D
+ ): TypeOrReturnType {
+ r++;
+
+ const cachedDeps = this.cache[key]?.dependencies ?? [];
+
+ let depsAreEqual = cachedDeps.length === dependencies.length;
+ if (depsAreEqual) {
+ for (let i = 0; i < cachedDeps.length; i++) {
+ if (!Object.is(cachedDeps[i], dependencies[i])) {
+ depsAreEqual = false;
+ }
+ }
+ }
+
+ if (depsAreEqual) {
+ return this.cache[key].value!;
+ }
+
+ const v = delegate(...data);
+ this.cache[key].dependencies = dependencies;
+ this.cache[key].value = v;
+ return v;
+ }
+}
diff --git a/packages/scesim-editor/src/store/TestScenarioEditorStore.ts b/packages/scesim-editor/src/store/TestScenarioEditorStore.ts
new file mode 100644
index 00000000000..7be9d3f10ec
--- /dev/null
+++ b/packages/scesim-editor/src/store/TestScenarioEditorStore.ts
@@ -0,0 +1,164 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import { SceSimModel } from "@kie-tools/scesim-marshaller";
+import { enableMapSet } from "immer";
+import { create } from "zustand";
+import { immer } from "zustand/middleware/immer";
+
+import { SceSim__FactMappingType } from "@kie-tools/scesim-marshaller/dist/schemas/scesim-1_8/ts-gen/types";
+
+import { ComputedStateCache } from "./ComputedStateCache";
+import { computeTestScenarioDataObjects } from "./computed/computeTestScenarioDataObjects";
+
+enableMapSet(); // Necessary because `Computed` has a lot of Maps and Sets.
+
+export enum TestScenarioEditorDock {
+ CHEATSHEET,
+ DATA_OBJECT,
+ SETTINGS,
+}
+
+export enum TestScenarioEditorTab {
+ BACKGROUND,
+ SIMULATION,
+}
+
+export type TestScenarioAlert = {
+ enabled: boolean;
+ message?: string;
+ variant: "success" | "danger" | "warning" | "info" | "default";
+};
+
+export type TestScenarioDataObject = {
+ id: string;
+ children?: TestScenarioDataObject[];
+ customBadgeContent?: string;
+ isSimpleTypeFact?: boolean;
+ name: string;
+};
+
+export type TestScenarioSelectedColumnMetaData = {
+ factMapping: SceSim__FactMappingType;
+ index: number;
+ isBackground: boolean;
+};
+
+export interface State {
+ computed: (s: State) => Computed;
+ dispatch: (s: State) => Dispatch;
+ navigation: {
+ dock: {
+ isOpen: boolean;
+ selected: TestScenarioEditorDock;
+ };
+ tab: TestScenarioEditorTab;
+ };
+ scesim: { model: SceSimModel };
+ table: {
+ background: {
+ selectedColumn: TestScenarioSelectedColumnMetaData | null;
+ };
+ simulation: {
+ selectedColumn: TestScenarioSelectedColumnMetaData | null;
+ };
+ };
+}
+
+// Read this to understand why we need computed as part of the store.
+// https://github.com/pmndrs/zustand/issues/132#issuecomment-1120467721
+export type Computed = {
+ getTestScenarioDataObjects(): TestScenarioDataObject[];
+};
+
+export type Dispatch = {
+ scesim: {
+ reset: () => void;
+ };
+ table: {
+ updateSelectedColumn: (columnMetadata: TestScenarioSelectedColumnMetaData | null) => void;
+ };
+};
+
+export const defaultStaticState = (): Omit => ({
+ navigation: {
+ dock: {
+ isOpen: true,
+ selected: TestScenarioEditorDock.DATA_OBJECT,
+ },
+ tab: TestScenarioEditorTab.SIMULATION,
+ },
+ table: {
+ background: {
+ selectedColumn: null,
+ },
+ simulation: {
+ selectedColumn: null,
+ },
+ },
+});
+
+export function createTestScenarioEditorStore(model: SceSimModel, computedCache: ComputedStateCache) {
+ console.trace("[TestScenarioEditorStore] Creating store with above model and empty cache ");
+ console.trace(model);
+
+ const { ...defaultState } = defaultStaticState();
+ return create(
+ immer(() => ({
+ ...defaultState,
+ scesim: {
+ model: model,
+ },
+ dispatch(state: State) {
+ return {
+ scesim: {
+ reset: () => {
+ state.navigation.tab = TestScenarioEditorTab.SIMULATION;
+ state.navigation.dock.isOpen = true;
+ state.navigation.dock.selected = TestScenarioEditorDock.DATA_OBJECT;
+ state.table.background.selectedColumn = null;
+ state.table.simulation.selectedColumn = null;
+ },
+ },
+ table: {
+ updateSelectedColumn: (columnMetadata: TestScenarioSelectedColumnMetaData) => {
+ if (state.navigation.tab === TestScenarioEditorTab.BACKGROUND) {
+ state.table.background.selectedColumn = columnMetadata;
+ } else {
+ state.table.simulation.selectedColumn = columnMetadata;
+ }
+ },
+ },
+ };
+ },
+ computed(state: State) {
+ return {
+ getTestScenarioDataObjects: () => {
+ return computedCache.cachedData(
+ "getTestScenarioDataObjects",
+ computeTestScenarioDataObjects,
+ [state.scesim.model.ScenarioSimulationModel.simulation.scesimModelDescriptor.factMappings.FactMapping],
+ [state.scesim.model.ScenarioSimulationModel.settings.type]
+ );
+ },
+ };
+ },
+ }))
+ );
+}
diff --git a/packages/scesim-editor/src/store/TestScenarioStoreContext.ts b/packages/scesim-editor/src/store/TestScenarioStoreContext.ts
new file mode 100644
index 00000000000..f910fc424dc
--- /dev/null
+++ b/packages/scesim-editor/src/store/TestScenarioStoreContext.ts
@@ -0,0 +1,47 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import { createContext, useContext } from "react";
+import { StoreApi, UseBoundStore } from "zustand";
+import { WithImmer } from "zustand/middleware/immer";
+import { useStoreWithEqualityFn } from "zustand/traditional";
+import { State } from "./TestScenarioEditorStore";
+
+type ExtractState = StoreApi extends { getState: () => infer T } ? T : never;
+
+export type StoreApiType = UseBoundStore>>;
+
+export const TestScenarioEditorStoreApiContext = createContext({} as any);
+
+export function useTestScenarioEditorStore(
+ selector: (state: State) => StateSlice,
+ equalityFn?: (a: StateSlice, b: StateSlice) => boolean
+) {
+ const store = useContext(TestScenarioEditorStoreApiContext);
+
+ if (store === null) {
+ throw new Error("Can't use Test Scenario Editor Store outside of the TestScenarioEditor component.");
+ }
+
+ return useStoreWithEqualityFn(store, selector, equalityFn);
+}
+
+export function useTestScenarioEditorStoreApi() {
+ return useContext(TestScenarioEditorStoreApiContext);
+}
diff --git a/packages/scesim-editor/src/store/computed/computeTestScenarioDataObjects.ts b/packages/scesim-editor/src/store/computed/computeTestScenarioDataObjects.ts
new file mode 100644
index 00000000000..228f4b1fbe8
--- /dev/null
+++ b/packages/scesim-editor/src/store/computed/computeTestScenarioDataObjects.ts
@@ -0,0 +1,80 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import { Computed, State, TestScenarioDataObject } from "../TestScenarioEditorStore";
+
+export function computeTestScenarioDataObjects(
+ factMappings: State["scesim"]["model"]["ScenarioSimulationModel"]["simulation"]["scesimModelDescriptor"]["factMappings"]["FactMapping"]
+) {
+ /* To create the Data Object arrays we need an external source, in details: */
+ /* DMN Data: Retrieving DMN type from linked DMN file */
+ /* Java classes: Retrieving Java classes info from the user projects */
+ /* At this time, none of the above are supported */
+ /* Therefore, it tries to retrieve these info from the SCESIM file, if are present */
+
+ /* Retriving Data Object from the scesim file.
+ That makes sense for previously created scesim files */
+
+ const factsMappings = factMappings ?? [];
+ const dataObjects: TestScenarioDataObject[] = [];
+
+ /* The first two FactMapping are related to the "Number" and "Description" columns.
+ If those columns only are present, no Data Objects can be detected in the scesim file */
+ for (let i = 2; i < factsMappings.length; i++) {
+ if (factsMappings[i].className!.__$$text === "java.lang.Void") {
+ continue;
+ }
+ const factID = factsMappings[i].expressionElements!.ExpressionElement![0].step.__$$text;
+ const dataObject = dataObjects.find((value) => value.id === factID);
+ const isSimpleTypeFact = factsMappings[i].expressionElements!.ExpressionElement!.length === 1;
+ const propertyID = isSimpleTypeFact //POTENTIAL BUG
+ ? factsMappings[i].expressionElements!.ExpressionElement![0].step.__$$text.concat(".")
+ : factsMappings[i]
+ .expressionElements!.ExpressionElement!.map((expressionElement) => expressionElement.step.__$$text)
+ .join(".");
+ const propertyName = isSimpleTypeFact
+ ? "value"
+ : factsMappings[i].expressionElements!.ExpressionElement!.slice(-1)[0].step.__$$text;
+ if (dataObject) {
+ if (!dataObject.children?.some((value) => value.id === propertyID)) {
+ dataObject.children!.push({
+ id: propertyID,
+ customBadgeContent: factsMappings[i].className.__$$text,
+ isSimpleTypeFact: isSimpleTypeFact,
+ name: propertyName,
+ });
+ }
+ } else {
+ dataObjects.push({
+ id: factID,
+ name: factsMappings[i].factAlias!.__$$text,
+ customBadgeContent: factsMappings[i].factIdentifier!.className!.__$$text,
+ children: [
+ {
+ id: propertyID,
+ name: propertyName,
+ customBadgeContent: factsMappings[i].className.__$$text,
+ },
+ ],
+ });
+ }
+ }
+
+ return dataObjects;
+}
diff --git a/packages/scesim-editor/src/common/TestScenarioCommonConstants.ts b/packages/scesim-editor/src/store/computed/initial.ts
similarity index 76%
rename from packages/scesim-editor/src/common/TestScenarioCommonConstants.ts
rename to packages/scesim-editor/src/store/computed/initial.ts
index 55edecff712..ce228895c2a 100644
--- a/packages/scesim-editor/src/common/TestScenarioCommonConstants.ts
+++ b/packages/scesim-editor/src/store/computed/initial.ts
@@ -17,9 +17,12 @@
* under the License.
*/
-export const EMPTY_TYPE = "java.lang.Void";
+import { Cache } from "../ComputedStateCache";
+import { Computed } from "../TestScenarioEditorStore";
-export enum TEST_SCENARIO_EXPRESSION_TYPE {
- EXPRESSION,
- NOT_EXPRESSION,
-}
+export const INITIAL_COMPUTED_CACHE: Cache = {
+ getTestScenarioDataObjects: {
+ value: undefined,
+ dependencies: [],
+ },
+};
diff --git a/packages/scesim-editor/src/table/TestScenarioTable.tsx b/packages/scesim-editor/src/table/TestScenarioTable.tsx
index 32ec8ae704d..14a83ff5289 100644
--- a/packages/scesim-editor/src/table/TestScenarioTable.tsx
+++ b/packages/scesim-editor/src/table/TestScenarioTable.tsx
@@ -21,17 +21,7 @@ import * as React from "react";
import { useCallback, useMemo } from "react";
import * as ReactTable from "react-table";
-import _, { isNumber } from "lodash";
-import { v4 as uuid } from "uuid";
-
-import {
- SceSim__backgroundDatasType,
- SceSim__backgroundType,
- SceSim__FactMappingType,
- SceSim__FactMappingValuesTypes,
- SceSim__scenariosType,
- SceSim__simulationType,
-} from "@kie-tools/scesim-marshaller/dist/schemas/scesim-1_8/ts-gen/types";
+import _ from "lodash";
import {
BeeTableContextMenuAllowedOperationsConditions,
@@ -47,30 +37,32 @@ import {
getColumnsAtLastLevel,
} from "@kie-tools/boxed-expression-component/dist/table/BeeTable";
-import { SceSimModel } from "@kie-tools/scesim-marshaller";
+import {
+ SceSim__backgroundDatasType,
+ SceSim__backgroundType,
+ SceSim__FactMappingType,
+ SceSim__scenariosType,
+ SceSim__simulationType,
+} from "@kie-tools/scesim-marshaller/dist/schemas/scesim-1_8/ts-gen/types";
import { useTestScenarioEditorI18n } from "../i18n";
-import { TestScenarioSelectedColumnMetaData, TestScenarioType } from "../TestScenarioEditor";
+import { useTestScenarioEditorStore, useTestScenarioEditorStoreApi } from "../store/TestScenarioStoreContext";
+import { addColumn } from "../mutations/addColumn";
+import { deleteColumn } from "../mutations/deleteColumn";
import "./TestScenarioTable.css";
-import {
- retrieveFactMappingValueIndexByIdentifiers,
- retrieveModelDescriptor,
- retrieveRowsDataFromModel,
-} from "../common/TestScenarioCommonFunctions";
+import { addRow } from "../mutations/addRow";
+import { deleteRow } from "../mutations/deleteRow";
+import { dupliacteRow } from "../mutations/duplicateRow";
+import { updateCell } from "../mutations/updateCell";
+import { updateColumnWidth } from "../mutations/updateColumnWidth";
function TestScenarioTable({
- assetType,
tableData,
scrollableParentRef,
- updateSelectedColumnMetaData,
- updateTestScenarioModel,
}: {
- assetType: string;
tableData: SceSim__simulationType | SceSim__backgroundType;
scrollableParentRef: React.RefObject;
- updateSelectedColumnMetaData: React.Dispatch>;
- updateTestScenarioModel: React.Dispatch>;
}) {
enum TestScenarioTableColumnHeaderGroup {
EXPECT = "expect-header",
@@ -89,6 +81,9 @@ function TestScenarioTable({
type ROWTYPE = any; // FIXME: https://github.com/apache/incubator-kie-issues/issues/169
const { i18n } = useTestScenarioEditorI18n();
+ const testScenarioEditorStoreApi = useTestScenarioEditorStoreApi();
+ const settingsModel = useTestScenarioEditorStore((state) => state.scesim.model.ScenarioSimulationModel.settings);
+ const testScenarioType = settingsModel.type?.__$$text.toUpperCase();
/** BACKGROUND TABLE MANAGMENT */
@@ -119,71 +114,33 @@ function TestScenarioTable({
const determineDataTypeLabel = useCallback(
(dataType: string) => {
let dataTypeLabel = dataType;
- if (assetType === TestScenarioType[TestScenarioType.RULE]) {
+ if (testScenarioType === "RULE") {
dataTypeLabel = dataTypeLabel.split(".").pop() ?? dataTypeLabel;
}
return dataTypeLabel.endsWith("Void") ? "" : dataTypeLabel;
},
- [assetType]
+ [testScenarioType]
);
/* It updates any column width change in the Model */
const setColumnWidth = useCallback(
(inputIndex: number) => (newWidthAction: React.SetStateAction) => {
- updateTestScenarioModel((prevState) => {
- const oldWidth = retrieveModelDescriptor(prevState.ScenarioSimulationModel, isBackground).factMappings
- .FactMapping![inputIndex].columnWidth?.__$$text;
+ testScenarioEditorStoreApi.setState((state) => {
+ const factMappings = isBackground
+ ? state.scesim.model.ScenarioSimulationModel.background.scesimModelDescriptor.factMappings.FactMapping!
+ : state.scesim.model.ScenarioSimulationModel.simulation.scesimModelDescriptor.factMappings.FactMapping!;
+ const oldWidth = factMappings[inputIndex].columnWidth?.__$$text;
const newWidth = typeof newWidthAction === "function" ? newWidthAction(oldWidth) : newWidthAction;
- let model = prevState;
- if (newWidth && oldWidth !== newWidth) {
- /* Cloning the FactMapping list and updating the new width */
- const deepClonedFactMappings: SceSim__FactMappingType[] = JSON.parse(
- JSON.stringify(
- retrieveModelDescriptor(prevState.ScenarioSimulationModel, isBackground).factMappings.FactMapping
- )
- );
- const factMappingToUpdate = deepClonedFactMappings[inputIndex];
-
- if (factMappingToUpdate.columnWidth?.__$$text) {
- factMappingToUpdate.columnWidth.__$$text = newWidth;
- } else {
- factMappingToUpdate.columnWidth = {
- __$$text: newWidth,
- };
- }
-
- model = {
- ScenarioSimulationModel: {
- ...prevState.ScenarioSimulationModel,
- simulation: {
- ...prevState.ScenarioSimulationModel.simulation,
- scesimModelDescriptor: {
- factMappings: {
- FactMapping: isBackground
- ? prevState.ScenarioSimulationModel.simulation.scesimModelDescriptor.factMappings.FactMapping
- : deepClonedFactMappings,
- },
- },
- },
- background: {
- ...prevState.ScenarioSimulationModel.background,
- scesimModelDescriptor: {
- factMappings: {
- FactMapping: isBackground
- ? deepClonedFactMappings
- : prevState.ScenarioSimulationModel.background.scesimModelDescriptor.factMappings.FactMapping,
- },
- },
- },
- },
- };
- }
-
- return model;
+ updateColumnWidth({
+ factMappings: factMappings,
+ columnIndex: inputIndex,
+ newWidth: newWidth,
+ oldWidth: oldWidth,
+ });
});
},
- [isBackground, updateTestScenarioModel]
+ [isBackground, testScenarioEditorStoreApi]
);
/* It determines the column data based on the given FactMapping (Scesim column representation).
@@ -244,7 +201,7 @@ function TestScenarioTable({
| | +--------------------------------+-----+----------------------------------+-----+
| # | | givenInstance (given-instance) | ... | expectGroup (expect-instance) | ... |
| | +----------------+---------------+-----+----------------------------------+-----+
- | | | field (given) | field (given)| ... | field (expect) | field (expect)| ... |
+ | | | field (given) | field (given) | ... | field (expect) | field (expect)| ... |
+---+---------------+----------------+---------------+-----+-----------------+----------------+-----+
Every section has its related groupType in the rounded brackets, that are crucial to determine
the correct context menu behavior (adding/removing an instance requires a different logic than
@@ -507,140 +464,25 @@ function TestScenarioTable({
const onCellUpdates = useCallback(
(cellUpdates: BeeTableCellUpdate[]) => {
cellUpdates.forEach((update) => {
- updateTestScenarioModel((prevState) => {
- /* To update the related FactMappingValue, it compares every FactMappingValue associated with the Scenario (Row)
- that contains the cell with the FactMapping (Column) fields factIdentifier and expressionIdentifier */
- const factMapping = retrieveModelDescriptor(prevState.ScenarioSimulationModel, isBackground).factMappings
- .FactMapping![update.columnIndex + columnIndexStart];
-
- const deepClonedRowsData: SceSim__FactMappingValuesTypes[] = JSON.parse(
- JSON.stringify(retrieveRowsDataFromModel(prevState.ScenarioSimulationModel, isBackground))
- );
- const factMappingValues = deepClonedRowsData[update.rowIndex].factMappingValues.FactMappingValue!;
- const newFactMappingValues = [...factMappingValues];
-
- const factMappingValueToUpdateIndex = retrieveFactMappingValueIndexByIdentifiers(
- newFactMappingValues,
- factMapping.factIdentifier,
- factMapping.expressionIdentifier
- );
- const factMappingValueToUpdate = factMappingValues[factMappingValueToUpdateIndex];
-
- if (factMappingValueToUpdate.rawValue) {
- factMappingValueToUpdate.rawValue!.__$$text = update.value;
- } else {
- newFactMappingValues[factMappingValueToUpdateIndex] = {
- ...factMappingValueToUpdate,
- rawValue: {
- __$$text: update.value,
- },
- };
- }
-
- deepClonedRowsData[update.rowIndex].factMappingValues.FactMappingValue = newFactMappingValues;
-
- return {
- ScenarioSimulationModel: {
- ...prevState.ScenarioSimulationModel,
- simulation: {
- ...prevState.ScenarioSimulationModel.simulation,
- scesimData: {
- Scenario: isBackground
- ? prevState.ScenarioSimulationModel.simulation.scesimData.Scenario
- : deepClonedRowsData,
- },
- },
- background: {
- ...prevState.ScenarioSimulationModel.background,
- scesimData: {
- BackgroundData: isBackground
- ? deepClonedRowsData
- : prevState.ScenarioSimulationModel.background.scesimData.BackgroundData,
- },
- },
- },
- };
+ testScenarioEditorStoreApi.setState((state) => {
+ const factMappings = isBackground
+ ? state.scesim.model.ScenarioSimulationModel.background.scesimModelDescriptor.factMappings.FactMapping!
+ : state.scesim.model.ScenarioSimulationModel.simulation.scesimModelDescriptor.factMappings.FactMapping!;
+ const factMappingValuesTypes = isBackground
+ ? state.scesim.model.ScenarioSimulationModel.background.scesimData.BackgroundData!
+ : state.scesim.model.ScenarioSimulationModel.simulation.scesimData.Scenario!;
+
+ updateCell({
+ columnIndex: update.columnIndex + columnIndexStart,
+ factMappings: factMappings,
+ factMappingValuesTypes: factMappingValuesTypes,
+ rowIndex: update.rowIndex,
+ value: update.value,
+ });
});
});
},
- [columnIndexStart, isBackground, updateTestScenarioModel]
- );
-
- const getNextAvailablePrefixedName = useCallback(
- (names: string[], namePrefix: string, lastIndex: number = names.length): string => {
- const candidate = `${namePrefix}-${lastIndex + 1}`;
- const elemWithCandidateName = names.indexOf(candidate);
- return elemWithCandidateName >= 0 ? getNextAvailablePrefixedName(names, namePrefix, lastIndex + 1) : candidate;
- },
- []
- );
-
- /* It determines in which index position a column should be added. In case of a field, the new column index
- is simply in the right or in the left of the selected column. In case of a new instance, it's required to
- find the first column index outside the selected Instance group. */
- const determineNewColumnTargetIndex = useCallback(
- (
- factMappings: SceSim__FactMappingType[],
- insertDirection: InsertRowColumnsDirection,
- selectedColumnIndex: number,
- selectedColumnGroupType: string,
- selectedFactMapping: SceSim__FactMappingType
- ) => {
- const groupType = selectedFactMapping.expressionIdentifier.type!.__$$text;
- const instanceName = selectedFactMapping.factIdentifier.name!.__$$text;
- const instanceType = selectedFactMapping.factIdentifier.className!.__$$text;
-
- if (
- selectedColumnGroupType === TestScenarioTableColumnFieldGroup.EXPECT ||
- selectedColumnGroupType === TestScenarioTableColumnFieldGroup.GIVEN
- ) {
- if (insertDirection === InsertRowColumnsDirection.AboveOrRight) {
- return selectedColumnIndex + 1;
- } else {
- return selectedColumnIndex;
- }
- }
-
- let newColumnTargetColumn = -1;
-
- if (insertDirection === InsertRowColumnsDirection.AboveOrRight) {
- for (let i = selectedColumnIndex; i < factMappings.length; i++) {
- const currentFM = factMappings[i];
- if (
- currentFM.expressionIdentifier.type!.__$$text === groupType &&
- currentFM.factIdentifier.name?.__$$text === instanceName &&
- currentFM.factIdentifier.className?.__$$text === instanceType
- ) {
- if (i == factMappings.length - 1) {
- newColumnTargetColumn = i + 1;
- }
- } else {
- newColumnTargetColumn = i;
- break;
- }
- }
- } else {
- for (let i = selectedColumnIndex; i >= 0; i--) {
- const currentFM = factMappings[i];
-
- if (
- currentFM.expressionIdentifier.type!.__$$text === groupType &&
- currentFM.factIdentifier.name?.__$$text === instanceName &&
- currentFM.factIdentifier.className?.__$$text === instanceType
- ) {
- if (i == 0) {
- newColumnTargetColumn = 0;
- }
- } else {
- newColumnTargetColumn = i + 1;
- break;
- }
- }
- }
-
- return newColumnTargetColumn;
- },
- [TestScenarioTableColumnFieldGroup]
+ [columnIndexStart, isBackground, testScenarioEditorStoreApi]
);
/**
@@ -687,143 +529,48 @@ function TestScenarioTable({
columnsCount: number;
insertDirection: InsertRowColumnsDirection;
}) => {
- /* GIVEN and EXPECTED column types can be added only */
- if (TestScenarioTableColumnFieldGroup.OTHER === args.groupType) {
+ /* GIVEN and EXPECTED of FIELD and INSTANCE column types can be added only */
+ if (
+ TestScenarioTableColumnFieldGroup.OTHER === args.groupType ||
+ TestScenarioTableColumnHeaderGroup.EXPECT === args.groupType ||
+ TestScenarioTableColumnHeaderGroup.GIVEN === args.groupType
+ ) {
+ console.error("Can't add a " + args.groupType + " type column.");
return;
}
const isInstance =
args.groupType === TestScenarioTableColumnInstanceGroup.EXPECT ||
args.groupType === TestScenarioTableColumnInstanceGroup.GIVEN;
- updateTestScenarioModel((prevState) => {
- const factMappingList = retrieveModelDescriptor(prevState.ScenarioSimulationModel, isBackground).factMappings
- .FactMapping!;
- const selectedColumnIndex = determineSelectedColumnIndex(factMappingList, args.currentIndex, isInstance);
-
- /* Creating the new FactMapping based on the original selected column's FactMapping */
- const selectedColumnFactMapping = factMappingList[selectedColumnIndex];
- const targetColumnIndex = determineNewColumnTargetIndex(
- factMappingList,
- args.insertDirection,
- selectedColumnIndex,
- args.groupType,
- selectedColumnFactMapping
- );
-
- const instanceDefaultNames = factMappingList
- .filter((factMapping) => factMapping.factAlias!.__$$text.startsWith("INSTANCE-"))
- .map((factMapping) => factMapping.factAlias!.__$$text);
-
- const isNewInstance =
- isInstance || selectedColumnFactMapping.factIdentifier.className?.__$$text === "java.lang.Void";
-
- const newFactMapping = {
- className: { __$$text: "java.lang.Void" },
- columnWidth: { __$$text: 150 },
- expressionAlias: { __$$text: "PROPERTY" },
- expressionElements: isNewInstance
- ? undefined
- : {
- ExpressionElement: [
- {
- step: {
- __$$text: selectedColumnFactMapping.expressionElements!.ExpressionElement![0].step.__$$text,
- },
- },
- ],
- },
- expressionIdentifier: {
- name: { __$$text: `_${uuid()}`.toLocaleUpperCase() },
- type: { __$$text: selectedColumnFactMapping.expressionIdentifier.type!.__$$text },
- },
- factAlias: {
- __$$text: isNewInstance
- ? getNextAvailablePrefixedName(instanceDefaultNames, "INSTANCE")
- : selectedColumnFactMapping.factAlias.__$$text,
- },
- factIdentifier: {
- name: {
- __$$text: isNewInstance
- ? getNextAvailablePrefixedName(instanceDefaultNames, "INSTANCE")
- : selectedColumnFactMapping.factIdentifier.name!.__$$text,
- },
- className: {
- __$$text: isNewInstance ? "java.lang.Void" : selectedColumnFactMapping.factIdentifier.className!.__$$text,
- },
- },
- factMappingValueType: { __$$text: "NOT_EXPRESSION" },
- };
-
- /* Cloning the FactMapping list and putting the new one in the user defined index */
- const deepClonedFactMappings = JSON.parse(
- JSON.stringify(
- retrieveModelDescriptor(prevState.ScenarioSimulationModel, isBackground).factMappings.FactMapping
- )
+ testScenarioEditorStoreApi.setState((state) => {
+ const factMappings = isBackground
+ ? state.scesim.model.ScenarioSimulationModel.background.scesimModelDescriptor.factMappings.FactMapping!
+ : state.scesim.model.ScenarioSimulationModel.simulation.scesimModelDescriptor.factMappings.FactMapping!;
+ const factMappingValues = isBackground
+ ? state.scesim.model.ScenarioSimulationModel.background.scesimData.BackgroundData!
+ : state.scesim.model.ScenarioSimulationModel.simulation.scesimData.Scenario!;
+ const selectedColumnFactMappingIndex = determineSelectedColumnIndex(
+ factMappings,
+ args.currentIndex,
+ isInstance
);
- deepClonedFactMappings.splice(targetColumnIndex, 0, newFactMapping);
- /* Creating and adding a new FactMappingValue (cell) in every row, as a consequence of the new FactMapping (column)
- we're going to introduce. The FactMappingValue will be linked with its related FactMapping via expressionIdentifier
- and factIdentier data. That means, the column index of new FactMappingValue could be different in other Scenario (rows) */
- const deepClonedRowsData: SceSim__FactMappingValuesTypes[] = JSON.parse(
- JSON.stringify(retrieveRowsDataFromModel(prevState.ScenarioSimulationModel, isBackground))
- );
- deepClonedRowsData.forEach((scenario) => {
- scenario.factMappingValues.FactMappingValue!.splice(args.beforeIndex + 1, 0, {
- expressionIdentifier: {
- name: { __$$text: newFactMapping.expressionIdentifier.name.__$$text },
- type: { __$$text: newFactMapping.expressionIdentifier.type.__$$text },
- },
- factIdentifier: {
- name: { __$$text: newFactMapping.factIdentifier.name.__$$text },
- className: { __$$text: newFactMapping.factIdentifier.className.__$$text },
- },
- rawValue: { __$$text: "", "@_class": "string" },
- });
+ addColumn({
+ beforeIndex: args.beforeIndex,
+ factMappings: factMappings,
+ factMappingValues: factMappingValues,
+ isInstance: isInstance,
+ insertDirection: args.insertDirection,
+ selectedColumnFactMappingIndex: selectedColumnFactMappingIndex,
});
-
- return {
- ScenarioSimulationModel: {
- ...prevState.ScenarioSimulationModel,
- simulation: {
- scesimModelDescriptor: {
- factMappings: {
- FactMapping: isBackground
- ? prevState.ScenarioSimulationModel.simulation.scesimModelDescriptor.factMappings.FactMapping
- : deepClonedFactMappings,
- },
- },
- scesimData: {
- Scenario: isBackground
- ? prevState.ScenarioSimulationModel.simulation.scesimData.Scenario
- : deepClonedRowsData,
- },
- },
- background: {
- scesimModelDescriptor: {
- factMappings: {
- FactMapping: isBackground
- ? deepClonedFactMappings
- : prevState.ScenarioSimulationModel.background.scesimModelDescriptor.factMappings.FactMapping,
- },
- },
- scesimData: {
- BackgroundData: isBackground
- ? deepClonedRowsData
- : prevState.ScenarioSimulationModel.background.scesimData.BackgroundData,
- },
- },
- },
- };
});
},
[
- determineNewColumnTargetIndex,
determineSelectedColumnIndex,
- getNextAvailablePrefixedName,
isBackground,
- updateTestScenarioModel,
+ testScenarioEditorStoreApi,
TestScenarioTableColumnFieldGroup,
+ TestScenarioTableColumnHeaderGroup,
TestScenarioTableColumnInstanceGroup,
]
);
@@ -833,127 +580,54 @@ function TestScenarioTable({
*/
const onColumnDeleted = useCallback(
(args: { columnIndex: number; groupType: string }) => {
- updateTestScenarioModel((prevState) => {
- const isInstance =
- args.groupType === TestScenarioTableColumnInstanceGroup.EXPECT ||
- args.groupType === TestScenarioTableColumnInstanceGroup.GIVEN;
-
- const factMappings = retrieveModelDescriptor(prevState.ScenarioSimulationModel, isBackground).factMappings
- .FactMapping!;
- const columnIndexToRemove = determineSelectedColumnIndex(factMappings, args.columnIndex + 1, isInstance);
-
- /* Retriving the FactMapping (Column) to be removed). If the user selected a single column, it finds the exact
- FactMapping to delete. If the user selected an instance (group of columns), it retrives all the FactMappings
- that belongs to the the instance group */
- const factMappingToRemove = factMappings[columnIndexToRemove];
- const groupType = factMappingToRemove.expressionIdentifier.type!.__$$text;
- const instanceName = factMappingToRemove.factIdentifier.name!.__$$text;
- const instanceType = factMappingToRemove.factIdentifier.className!.__$$text;
-
- const allFactMappingWithIndexesToRemove = isInstance
- ? factMappings
- .map((factMapping, index) => {
- if (
- factMapping.expressionIdentifier.type!.__$$text === groupType &&
- factMapping.factIdentifier.name?.__$$text === instanceName &&
- factMapping.factIdentifier.className?.__$$text === instanceType
- ) {
- return { factMappingIndex: index, factMapping: factMapping };
- } else {
- return {};
- }
- })
- .filter((item) => isNumber(item.factMappingIndex))
- : [{ factMappingIndex: args.columnIndex + columnIndexStart, factMapping: factMappingToRemove }];
-
- /* Cloning the FactMappings list (Columns) and and removing the FactMapping (Column) at given index */
- const deepClonedFactMappings = JSON.parse(
- JSON.stringify(
- retrieveModelDescriptor(prevState.ScenarioSimulationModel, isBackground).factMappings.FactMapping
- )
- );
- deepClonedFactMappings.splice(
- allFactMappingWithIndexesToRemove[0].factMappingIndex,
- allFactMappingWithIndexesToRemove.length
- );
-
- /* Cloning the Scenario List (Rows) and finding the Cell(s) to remove accordingly to the factMapping data of
- the removed columns */
- const deepClonedRowsData: SceSim__FactMappingValuesTypes[] = JSON.parse(
- JSON.stringify(retrieveRowsDataFromModel(prevState.ScenarioSimulationModel, isBackground) ?? [])
- );
- deepClonedRowsData.forEach((rowData) => {
- allFactMappingWithIndexesToRemove.forEach((itemToRemove) => {
- const factMappingValueColumnIndexToRemove = retrieveFactMappingValueIndexByIdentifiers(
- rowData.factMappingValues.FactMappingValue!,
- itemToRemove.factMapping!.factIdentifier,
- itemToRemove.factMapping!.expressionIdentifier
- )!;
-
- return {
- factMappingValues: {
- FactMappingValue: rowData.factMappingValues.FactMappingValue!.splice(
- factMappingValueColumnIndexToRemove,
- 1
- ),
- },
- };
- });
+ /* GIVEN and EXPECTED of FIELD and INSTANCE column types can be deleted only */
+ if (
+ TestScenarioTableColumnFieldGroup.OTHER === args.groupType ||
+ TestScenarioTableColumnHeaderGroup.EXPECT === args.groupType ||
+ TestScenarioTableColumnHeaderGroup.GIVEN === args.groupType
+ ) {
+ console.error("Can't delete a " + args.groupType + " type column.");
+ return;
+ }
+ const isInstance =
+ args.groupType === TestScenarioTableColumnInstanceGroup.EXPECT ||
+ args.groupType === TestScenarioTableColumnInstanceGroup.GIVEN;
+ testScenarioEditorStoreApi.setState((state) => {
+ const factMappings = isBackground
+ ? state.scesim.model.ScenarioSimulationModel.background.scesimModelDescriptor.factMappings.FactMapping!
+ : state.scesim.model.ScenarioSimulationModel.simulation.scesimModelDescriptor.factMappings.FactMapping!;
+ const factMappingValues = isBackground
+ ? state.scesim.model.ScenarioSimulationModel.background.scesimData.BackgroundData!
+ : state.scesim.model.ScenarioSimulationModel.simulation.scesimData.Scenario!;
+ const factMappingIndexToRemove = determineSelectedColumnIndex(factMappings, args.columnIndex + 1, isInstance);
+
+ const { deletedFactMappingIndexs } = deleteColumn({
+ factMappingIndexToRemove: factMappingIndexToRemove,
+ factMappings: factMappings,
+ factMappingValues: factMappingValues,
+ isBackground: isBackground,
+ isInstance: isInstance,
+ selectedColumnIndex: args.columnIndex,
});
/** Updating the selectedColumn. When deleting, BEETable automatically shifts the selected cell in the left */
- const firstIndexOnTheLeft = Math.min(
- ...allFactMappingWithIndexesToRemove.map((item) => item.factMappingIndex!)
- );
+ const firstIndexOnTheLeft = Math.min(...deletedFactMappingIndexs);
const selectedColumnIndex = firstIndexOnTheLeft > 0 ? firstIndexOnTheLeft - 1 : 0;
- updateSelectedColumnMetaData({
- factMapping: JSON.parse(JSON.stringify(deepClonedFactMappings[selectedColumnIndex])),
+
+ state.dispatch(state).table.updateSelectedColumn({
+ factMapping: JSON.parse(JSON.stringify(factMappings[selectedColumnIndex])),
index: firstIndexOnTheLeft,
- isBackground,
+ isBackground: isBackground,
});
-
- return {
- ScenarioSimulationModel: {
- ...prevState.ScenarioSimulationModel,
- simulation: {
- scesimModelDescriptor: {
- factMappings: {
- FactMapping: isBackground
- ? prevState.ScenarioSimulationModel.simulation.scesimModelDescriptor.factMappings.FactMapping
- : deepClonedFactMappings,
- },
- },
- scesimData: {
- Scenario: isBackground
- ? prevState.ScenarioSimulationModel.simulation.scesimData.Scenario
- : deepClonedRowsData,
- },
- },
- background: {
- scesimModelDescriptor: {
- factMappings: {
- FactMapping: isBackground
- ? deepClonedFactMappings
- : prevState.ScenarioSimulationModel.background.scesimModelDescriptor.factMappings.FactMapping,
- },
- },
- scesimData: {
- BackgroundData: isBackground
- ? deepClonedRowsData
- : prevState.ScenarioSimulationModel.background.scesimData.BackgroundData,
- },
- },
- },
- };
});
},
[
- updateTestScenarioModel,
- TestScenarioTableColumnInstanceGroup,
- isBackground,
determineSelectedColumnIndex,
- columnIndexStart,
- updateSelectedColumnMetaData,
+ isBackground,
+ testScenarioEditorStoreApi,
+ TestScenarioTableColumnFieldGroup,
+ TestScenarioTableColumnHeaderGroup,
+ TestScenarioTableColumnInstanceGroup,
]
);
@@ -965,50 +639,15 @@ function TestScenarioTable({
if (isBackground) {
throw new Error("Impossible state. Background table can have a single row only");
}
- updateTestScenarioModel((prevState) => {
- /* Creating a new Scenario (Row) composed by a list of FactMappingValues. The list order is not relevant. */
+ testScenarioEditorStoreApi.setState((state) => {
const factMappings =
- prevState.ScenarioSimulationModel.simulation.scesimModelDescriptor.factMappings.FactMapping ?? [];
- const factMappingValuesItems = factMappings.map((factMapping) => {
- return {
- expressionIdentifier: {
- name: { __$$text: factMapping.expressionIdentifier.name!.__$$text },
- type: { __$$text: factMapping.expressionIdentifier.type!.__$$text },
- },
- factIdentifier: {
- name: { __$$text: factMapping.factIdentifier.name!.__$$text },
- className: { __$$text: factMapping.factIdentifier.className!.__$$text },
- },
- rawValue: { __$$text: "", "@_class": "string" },
- };
- });
+ state.scesim.model.ScenarioSimulationModel.simulation.scesimModelDescriptor.factMappings.FactMapping!;
+ const factMappingValues = state.scesim.model.ScenarioSimulationModel.simulation.scesimData.Scenario!;
- const newScenario = {
- factMappingValues: {
- FactMappingValue: factMappingValuesItems,
- },
- };
-
- /* Cloning che current Scenario List and adding thew new Scenario previously created */
- const deepClonedScenarios = JSON.parse(
- JSON.stringify(prevState.ScenarioSimulationModel.simulation.scesimData.Scenario)
- );
- deepClonedScenarios.splice(args.beforeIndex, 0, newScenario);
-
- return {
- ScenarioSimulationModel: {
- ...prevState.ScenarioSimulationModel,
- simulation: {
- ...prevState.ScenarioSimulationModel.simulation,
- scesimData: {
- Scenario: deepClonedScenarios,
- },
- },
- },
- };
+ addRow({ beforeIndex: args.beforeIndex, factMappings: factMappings, factMappingValues: factMappingValues });
});
},
- [isBackground, updateTestScenarioModel]
+ [isBackground, testScenarioEditorStoreApi]
);
/**
@@ -1019,28 +658,13 @@ function TestScenarioTable({
if (isBackground) {
throw new Error("Impossible state. Background table can have a single row only");
}
- updateTestScenarioModel((prevState) => {
- /* Just updating the Scenario List (Rows) cloning the current List and removing the row at the given rowIndex */
- const deepClonedScenarios = JSON.parse(
- JSON.stringify(prevState.ScenarioSimulationModel.simulation.scesimData.Scenario ?? [])
- );
- deepClonedScenarios.splice(args.rowIndex, 1);
-
- return {
- ScenarioSimulationModel: {
- ...prevState.ScenarioSimulationModel,
- simulation: {
- ...prevState.ScenarioSimulationModel.simulation,
- scesimData: {
- ...prevState.ScenarioSimulationModel.simulation.scesimData,
- Scenario: deepClonedScenarios,
- },
- },
- },
- };
+ testScenarioEditorStoreApi.setState((state) => {
+ const factMappingValues = state.scesim.model.ScenarioSimulationModel.simulation.scesimData.Scenario!;
+
+ deleteRow({ rowIndex: args.rowIndex, factMappingValues: factMappingValues });
});
},
- [isBackground, updateTestScenarioModel]
+ [isBackground, testScenarioEditorStoreApi]
);
/**
@@ -1051,41 +675,13 @@ function TestScenarioTable({
if (isBackground) {
throw new Error("Impossible state. Background table can have a single row only");
}
- updateTestScenarioModel((prevState) => {
- /* It simply clones a Scenario (Row) and adds it in a current-cloned Scenario list */
- const clonedFactMappingValues = JSON.parse(
- JSON.stringify(
- prevState.ScenarioSimulationModel.simulation.scesimData.Scenario![args.rowIndex].factMappingValues
- .FactMappingValue
- )
- );
+ testScenarioEditorStoreApi.setState((state) => {
+ const factMappingValues = state.scesim.model.ScenarioSimulationModel.simulation.scesimData.Scenario!;
- const factMappingValues = {
- factMappingValues: {
- FactMappingValue: clonedFactMappingValues,
- },
- };
-
- const deepClonedScenarios = JSON.parse(
- JSON.stringify(prevState.ScenarioSimulationModel.simulation.scesimData.Scenario ?? [])
- );
- deepClonedScenarios.splice(args.rowIndex, 0, factMappingValues);
-
- return {
- ScenarioSimulationModel: {
- ...prevState.ScenarioSimulationModel,
- simulation: {
- ...prevState.ScenarioSimulationModel.simulation,
- scesimData: {
- ...prevState.ScenarioSimulationModel.simulation.scesimData,
- Scenario: deepClonedScenarios,
- },
- },
- },
- };
+ dupliacteRow({ rowIndex: args.rowIndex, factMappingValues: factMappingValues });
});
},
- [isBackground, updateTestScenarioModel]
+ [isBackground, testScenarioEditorStoreApi]
);
/**
@@ -1093,9 +689,11 @@ function TestScenarioTable({
*/
const onDataCellClick = useCallback(
(_columnID: string) => {
- updateSelectedColumnMetaData(null);
+ testScenarioEditorStoreApi.setState((state) => {
+ state.dispatch(state).table.updateSelectedColumn(null);
+ });
},
- [updateSelectedColumnMetaData]
+ [testScenarioEditorStoreApi]
);
const onHeaderClick = useCallback(
@@ -1105,7 +703,9 @@ function TestScenarioTable({
columnKey == TestScenarioTableColumnHeaderGroup.EXPECT ||
columnKey == TestScenarioTableColumnHeaderGroup.GIVEN
) {
- updateSelectedColumnMetaData(null);
+ testScenarioEditorStoreApi.setState((state) => {
+ state.dispatch(state).table.updateSelectedColumn(null);
+ });
return;
}
@@ -1123,25 +723,23 @@ function TestScenarioTable({
selectedInstanceGroup?.columns[0].dataType === ""
) {
const propertyID = selectedInstanceGroup?.columns[0].id;
- let selectedFactMapping;
- let selectedFactIndex;
- if (propertyID) {
- selectedFactMapping = modelDescriptor.factMappings.FactMapping!.find(
- (factMapping) => factMapping.expressionIdentifier.name?.__$$text === propertyID
- );
- selectedFactIndex = selectedFactMapping
- ? modelDescriptor.factMappings.FactMapping!.indexOf(selectedFactMapping!)
- : -1;
- }
- const selectedColumnMetaData = {
- factMapping: JSON.parse(JSON.stringify(selectedFactMapping)),
- index: selectedFactIndex ?? -1,
- isBackground: isBackground,
- };
-
- updateSelectedColumnMetaData(selectedColumnMetaData);
+ const selectedFactMapping = modelDescriptor.factMappings.FactMapping!.find(
+ (factMapping) => factMapping.expressionIdentifier.name?.__$$text === propertyID
+ );
+ const selectedFactIndex = selectedFactMapping
+ ? modelDescriptor.factMappings.FactMapping!.indexOf(selectedFactMapping!)
+ : -1;
+ testScenarioEditorStoreApi.setState((state) => {
+ state.dispatch(state).table.updateSelectedColumn({
+ factMapping: JSON.parse(JSON.stringify(selectedFactMapping)),
+ index: selectedFactIndex ?? -1,
+ isBackground: isBackground,
+ });
+ });
} else {
- updateSelectedColumnMetaData(null);
+ testScenarioEditorStoreApi.setState((state) => {
+ state.dispatch(state).table.updateSelectedColumn(null);
+ });
}
return;
}
@@ -1153,13 +751,13 @@ function TestScenarioTable({
? modelDescriptor.factMappings.FactMapping!.indexOf(selectedFactMapping!)
: -1;
- const selectedColumnMetaData = {
- factMapping: JSON.parse(JSON.stringify(selectedFactMapping)),
- index: selectedFactIndex ?? -1,
- isBackground: isBackground,
- };
-
- updateSelectedColumnMetaData(selectedColumnMetaData ?? null);
+ testScenarioEditorStoreApi.setState((state) => {
+ state.dispatch(state).table.updateSelectedColumn({
+ factMapping: JSON.parse(JSON.stringify(selectedFactMapping)),
+ index: selectedFactIndex ?? -1,
+ isBackground: isBackground,
+ });
+ });
},
[
TestScenarioTableColumnFieldGroup,
@@ -1167,7 +765,7 @@ function TestScenarioTable({
isBackground,
tableColumns.instancesGroup,
tableData,
- updateSelectedColumnMetaData,
+ testScenarioEditorStoreApi,
]
);
diff --git a/packages/scesim-editor/stories/dev/DevWebApp.stories.tsx b/packages/scesim-editor/stories/dev/DevWebApp.stories.tsx
index 9d17767d2bf..580fe83116e 100644
--- a/packages/scesim-editor/stories/dev/DevWebApp.stories.tsx
+++ b/packages/scesim-editor/stories/dev/DevWebApp.stories.tsx
@@ -17,112 +17,149 @@
* under the License.
*/
-import React, { useCallback, useRef, useState, useEffect } from "react";
+import React, { useCallback, useMemo, useRef, useState } from "react";
import type { Meta, StoryObj } from "@storybook/react";
-import { SceSimEditorWrapper, SceSimEditorWrapperProps } from "../scesimEditorStoriesWrapper";
-import { Button, Flex, FlexItem, Page, PageSection } from "@patternfly/react-core/dist/js";
-import { TestScenarioEditorRef } from "../../src/TestScenarioEditor";
-import { SceSimMarshaller } from "../../../scesim-marshaller/src/index";
-import { SceSimModel, getMarshaller } from "@kie-tools/scesim-marshaller";
-import { emptySceSim } from "../misc/empty/Empty.stories";
-import { isOldEnoughDrl } from "../useCases/IsOldEnoughRule.stories";
-import { trafficViolationDmn } from "../useCases/TrafficViolationDmn.stories";
-import { useArgs } from "@storybook/preview-api";
-
+import "@patternfly/react-core/dist/styles/base.css";
+import { Button } from "@patternfly/react-core/dist/js/components/Button";
+import { Flex, FlexItem } from "@patternfly/react-core/dist/js/layouts/Flex";
+import { Page, PageSection } from "@patternfly/react-core/dist/js/components/Page";
+import { Stack, StackItem } from "@patternfly/react-core/dist/js";
+import { SceSimMarshaller, SceSimModel, getMarshaller } from "@kie-tools/scesim-marshaller";
+import {
+ ExternalDmnsIndex,
+ OnRequestExternalModelByPath,
+ OnRequestExternalModelsAvailableToInclude,
+ OnRequestToJumpToPath,
+ OnSceSimModelChange,
+ TestScenarioEditorProps,
+} from "../../src/TestScenarioEditor";
+import { SceSimEditorWrapper } from "../scesimEditorStoriesWrapper";
+import { emptyFileName, emptySceSim } from "../misc/empty/Empty.stories";
+import { isOldEnoughDrl, isOldEnoughDrlFileName } from "../useCases/IsOldEnoughRule.stories";
+import { trafficViolationDmn, trafficViolationDmnFileName } from "../useCases/TrafficViolationDmn.stories";
+import { availableModelsByPath } from "../examples/AvailableDMNModels";
import "./DevWebApp.css";
-type DevWebAppProps = SceSimEditorWrapperProps;
-
-function DevWebApp(props: DevWebAppProps) {
- const ref = useRef(null);
- const [args, updateArgs] = useArgs();
-
- const [state, setState] = useState<{ marshaller: SceSimMarshaller; stack: SceSimModel[]; pointer: number }>(() => {
+function DevWebApp(props: TestScenarioEditorProps) {
+ const [fileName, setFileName] = useState("Untitled.scesim");
+ const [state, setState] = useState<{
+ marshaller: SceSimMarshaller;
+ pointer: number;
+ stack: SceSimModel[];
+ }>(() => {
const emptySceSimMarshaller = getMarshaller(emptySceSim);
return {
marshaller: emptySceSimMarshaller,
- stack: [emptySceSimMarshaller.parser.parse()],
pointer: 0,
+ stack: [emptySceSimMarshaller.parser.parse()],
};
});
- const onSelectModel = useCallback((newModel) => {
- const model = getMarshaller(newModel).parser.parse();
- setState((prev) => {
- const newStack = prev.stack.slice(0, prev.pointer + 1);
- return {
- ...prev,
- stack: [...newStack, model],
- pointer: newStack.length,
- };
- });
+ const currentModel = state.stack[state.pointer];
+ const downloadRef = useRef(null);
+ const isUndoEnabled = state.pointer > 0;
+ const isRedoEnabled = state.pointer !== state.stack.length - 1;
+
+ const copyAsXml = useCallback(() => {
+ navigator.clipboard.writeText(state.marshaller.builder.build(currentModel));
+ }, [currentModel, state.marshaller.builder]);
+
+ const downloadAsXml = useCallback(() => {
+ if (downloadRef.current) {
+ const fileBlob = new Blob([state.marshaller.builder.build(currentModel)], { type: "text/xml" });
+ downloadRef.current.download = fileName ?? `scesim-test-${makeid(10)}.scesim`;
+ downloadRef.current.href = URL.createObjectURL(fileBlob);
+ downloadRef.current.click();
+ }
+ }, [currentModel, fileName, state.marshaller.builder]);
+
+ // TODO Unmarshall here the DMN
+ const externalModelsByNamespace = useMemo(() => {
+ return currentModel.ScenarioSimulationModel.settings.dmnNamespace?.__$$text, {} as ExternalDmnsIndex;
+ }, [currentModel.ScenarioSimulationModel.settings.dmnNamespace]);
+
+ const onDragOver = useCallback((e: React.DragEvent) => {
+ e.preventDefault(); // Necessary to disable the browser's default 'onDrop' handling.
}, []);
const onDrop = useCallback((e: React.DragEvent) => {
+ console.log("Test Scenario Editor :: Dev webapp :: File(s) dropped! Opening it.");
+
e.preventDefault(); // Necessary to disable the browser's default 'onDrop' handling.
if (e.dataTransfer.items) {
// Use DataTransferItemList interface to access the file(s)
[...e.dataTransfer.items].forEach((item, i) => {
if (item.kind === "file") {
- const fileName = item.getAsFile()?.name;
const reader = new FileReader();
- reader.addEventListener("load", ({ target }) =>
- ref.current?.setContent(fileName ?? "", target?.result as string)
- );
+ setFileName(item.getAsFile()?.name);
+ reader.addEventListener("load", ({ target }) => {
+ const marshaller = getMarshaller(target?.result as string);
+ setState({
+ marshaller,
+ pointer: 0,
+ stack: [marshaller.parser.parse()],
+ });
+ });
reader.readAsText(item.getAsFile() as any);
}
});
}
}, []);
- const onDragOver = useCallback((e: React.DragEvent) => {
- e.preventDefault(); // Necessary to disable the browser's default 'onDrop' handling.
+ const onModelChange = useCallback((model) => {
+ setState((prev) => {
+ const newStack = prev.stack.slice(0, prev.pointer + 1);
+ return {
+ ...prev,
+ stack: [...newStack, model],
+ pointer: newStack.length,
+ };
+ });
+ }, []);
+
+ const onRequestToJumpToPath = useCallback((path) => {
+ alert("A request to open this file: " + path);
+ }, []);
+
+ const onSelectModel = useCallback(
+ (newModel, fileName) => {
+ onModelChange(getMarshaller(newModel).parser.parse());
+ setFileName(fileName);
+ },
+ [onModelChange]
+ );
+
+ const redo = useCallback(() => {
+ setState((prev) => ({ ...prev, pointer: Math.min(prev.stack.length - 1, prev.pointer + 1) }));
}, []);
const reset = useCallback(() => {
const marshaller = getMarshaller(emptySceSim);
setState({
marshaller,
- stack: [marshaller.parser.parse()],
pointer: 0,
+ stack: [marshaller.parser.parse()],
});
}, []);
- const currentModel = state.stack[state.pointer];
-
- const downloadRef = useRef(null);
- const downloadAsXml = useCallback(() => {
- if (downloadRef.current) {
- const fileBlob = new Blob([state.marshaller.builder.build(currentModel)], { type: "text/xml" });
- downloadRef.current.download = `scesim-${makeid(10)}.scesim`;
- downloadRef.current.href = URL.createObjectURL(fileBlob);
- downloadRef.current.click();
- }
- }, [currentModel, state.marshaller.builder]);
-
- const copyAsXml = useCallback(() => {
- navigator.clipboard.writeText(state.marshaller.builder.build(currentModel));
- }, [currentModel, state.marshaller.builder]);
+ const undo = useCallback(() => {
+ setState((prev) => ({ ...prev, pointer: Math.max(0, prev.pointer - 1) }));
+ }, []);
- useEffect(() => {
- updateArgs({ content: state.marshaller.builder.build(state.stack[state.stack.length - 1]) });
- }, [state.marshaller.builder, state.stack, updateArgs]);
+ const onRequestExternalModelByPath = useCallback(async (path) => {
+ return availableModelsByPath[path] ?? null;
+ }, []);
- useEffect(() => {
- onSelectModel(args.content);
- }, [args.content, onSelectModel]);
+ const onRequestExternalModelsAvailableToInclude = useCallback(async () => {
+ return Object.keys(availableModelsByPath);
+ }, []);
return (
- <>
-
-
-
+
+
+
+
Test Scenario Editor :: Dev WebApp
@@ -130,38 +167,76 @@ function DevWebApp(props: DevWebAppProps) {
(Drag & drop a file anywhere to open it)
+
+
+
+
-
+
-
+
+
+
+ |
+
-
+
|
-
+
-
+
-
+
-
-
-
-
- {SceSimEditorWrapper({
- pathRelativeToTheWorkspaceRoot: "dev.scesim",
- content: state.marshaller.builder.build(state.stack[state.stack.length - 1]),
- })}
-
-
-
- >
+
+
+
+
+
+
+ {SceSimEditorWrapper({
+ issueTrackerHref: props.issueTrackerHref,
+ externalModelsByNamespace: externalModelsByNamespace,
+ model: currentModel,
+ onModelChange: onModelChange,
+ onRequestExternalModelsAvailableToInclude: onRequestExternalModelsAvailableToInclude,
+ onRequestExternalModelByPath: onRequestExternalModelByPath,
+ onRequestToJumpToPath: onRequestToJumpToPath,
+ openFileNormalizedPosixPathRelativeToTheWorkspaceRoot: fileName,
+ })}
+
+
);
}
@@ -177,18 +252,19 @@ function makeid(length: number) {
return result;
}
-const meta: Meta = {
+const meta: Meta = {
title: "Dev/Web App",
component: DevWebApp,
};
export default meta;
-type Story = StoryObj;
+type Story = StoryObj;
export const WebApp: Story = {
render: (args) => DevWebApp(args),
args: {
- pathRelativeToTheWorkspaceRoot: "dev.scesim",
- content: emptySceSim,
+ issueTrackerHref: "https://github.com/apache/incubator-kie-issues/issues/new",
+ model: getMarshaller(emptySceSim).parser.parse(),
+ openFileNormalizedPosixPathRelativeToTheWorkspaceRoot: "Untitled.scesim",
},
};
diff --git a/packages/scesim-editor/stories/examples/AvailableDMNModels.ts b/packages/scesim-editor/stories/examples/AvailableDMNModels.ts
index 315e2451ebc..70d8fbb5f44 100644
--- a/packages/scesim-editor/stories/examples/AvailableDMNModels.ts
+++ b/packages/scesim-editor/stories/examples/AvailableDMNModels.ts
@@ -17,17 +17,19 @@
* under the License.
*/
-import { DmnLatestModel, getMarshaller } from "@kie-tools/dmn-marshaller";
+import * as TestScenarioEditor from "../../src/TestScenarioEditor";
+import { getMarshaller } from "@kie-tools/dmn-marshaller";
+import { normalize } from "@kie-tools/dmn-marshaller/dist/normalization/normalize";
import { LOAN_PRE_QUALIFICATION, TRAFFIC_VIOLATION } from "./ExternalDmnModels";
-export const loanPreQualification = getMarshaller(LOAN_PRE_QUALIFICATION, { upgradeTo: "latest" }).parser.parse();
-export const trafficViolationModel = getMarshaller(TRAFFIC_VIOLATION, { upgradeTo: "latest" }).parser.parse();
+export const loanPreQualification = normalize(
+ getMarshaller(LOAN_PRE_QUALIFICATION, { upgradeTo: "latest" }).parser.parse()
+);
+export const trafficViolationModel = normalize(
+ getMarshaller(TRAFFIC_VIOLATION, { upgradeTo: "latest" }).parser.parse()
+);
-export const avaiableModels: {
- model: DmnLatestModel;
- normalizedPosixPathRelativeToTheOpenFile: string;
- svg: string;
-}[] = [
+export const avaiableModels: TestScenarioEditor.ExternalDmn[] = [
{
model: loanPreQualification,
svg: "",
@@ -40,19 +42,12 @@ export const avaiableModels: {
},
];
-// export const availableModelsByPath: Record = Object.values(avaiableModels).reduce(
-// (acc, v) => {
-// acc[v.normalizedPosixPathRelativeToTheOpenFile] = v;
-// return acc;
-// },
-// {} as Record
-// );
-
-// export const modelsByNamespace = Object.values(avaiableModels).reduce((acc, v) => {
-// if (v.type === "dmn") {
-// acc[v.model.definitions["@_namespace"]] = v;
-// } else if (v.type === "pmml") {
-// acc[getPmmlNamespace({ normalizedPosixPathRelativeToTheOpenFile: v.normalizedPosixPathRelativeToTheOpenFile })] = v;
-// }
-// return acc;
-// }, {} as DmnEditor.ExternalModelsIndex);
+export const availableModelsByPath: Record = Object.values(
+ avaiableModels
+).reduce(
+ (acc, v) => {
+ acc[v.normalizedPosixPathRelativeToTheOpenFile] = v;
+ return acc;
+ },
+ {} as Record
+);
diff --git a/packages/scesim-editor/stories/misc/empty/Empty.stories.tsx b/packages/scesim-editor/stories/misc/empty/Empty.stories.tsx
index af7a17fc235..7aa0696d501 100644
--- a/packages/scesim-editor/stories/misc/empty/Empty.stories.tsx
+++ b/packages/scesim-editor/stories/misc/empty/Empty.stories.tsx
@@ -18,11 +18,13 @@
*/
import type { Meta, StoryObj } from "@storybook/react";
-import { SceSimEditorWrapper, SceSimEditorWrapperProps } from "../../scesimEditorStoriesWrapper";
+import { getMarshaller } from "@kie-tools/scesim-marshaller";
import { TestScenarioEditor } from "../../../src/TestScenarioEditor";
+import { SceSimEditorWrapper, StorybookTestScenarioEditorProps } from "../../scesimEditorStoriesWrapper";
+export const emptyFileName = "Untitled.scesim";
export const emptySceSim = `
-
+
@@ -180,12 +182,16 @@ const meta: Meta<{}> = {
};
export default meta;
-type Story = StoryObj;
+type Story = StoryObj;
+
+const marshaller = getMarshaller(emptySceSim);
+const model = marshaller.parser.parse();
export const Empty: Story = {
render: (args) => SceSimEditorWrapper(args),
args: {
- pathRelativeToTheWorkspaceRoot: "empty.scesim",
- content: emptySceSim,
+ model: marshaller.parser.parse(),
+ openFileNormalizedPosixPathRelativeToTheWorkspaceRoot: emptyFileName,
+ xml: marshaller.builder.build(model),
},
};
diff --git a/packages/scesim-editor/stories/scesimEditor/SceSimEditor.mdx b/packages/scesim-editor/stories/scesimEditor/SceSimEditor.mdx
index 33f1a2e32a8..c253f319b3f 100644
--- a/packages/scesim-editor/stories/scesimEditor/SceSimEditor.mdx
+++ b/packages/scesim-editor/stories/scesimEditor/SceSimEditor.mdx
@@ -17,9 +17,9 @@
import { Meta } from "@storybook/blocks";
-
+
-# SceSim Editor
+# Test Scenario Editor
Before deploying them into a production environment, test scenarios enable you to validate the functionality of
- Business rules and business rule data (for rules-based test scenarios)
diff --git a/packages/scesim-editor/stories/scesimEditorStoriesWrapper.tsx b/packages/scesim-editor/stories/scesimEditorStoriesWrapper.tsx
index 656adba6208..802302e52ca 100644
--- a/packages/scesim-editor/stories/scesimEditorStoriesWrapper.tsx
+++ b/packages/scesim-editor/stories/scesimEditorStoriesWrapper.tsx
@@ -18,25 +18,68 @@
*/
import * as React from "react";
-import { useEffect, useRef } from "react";
-import { TestScenarioEditor, TestScenarioEditorRef } from "../src/TestScenarioEditor";
+import { useCallback, useEffect, useMemo, useRef, useState } from "react";
+import { useArgs } from "@storybook/preview-api";
+import { diff } from "deep-object-diff";
+import { SceSimModel, getMarshaller } from "@kie-tools/scesim-marshaller";
+import { TestScenarioEditor, TestScenarioEditorProps, TestScenarioEditorRef } from "../src/TestScenarioEditor";
+import { EMPTY_ONE_EIGHT } from "../src/resources/EmptyScesimFile";
-export interface SceSimEditorWrapperProps {
- pathRelativeToTheWorkspaceRoot: string;
- content: string;
-}
+export type StorybookTestScenarioEditorProps = TestScenarioEditorProps & { xml: string };
-export function SceSimEditorWrapper(props: SceSimEditorWrapperProps) {
+export function SceSimEditorWrapper(props: Partial) {
+ const [args, updateArgs] = useArgs();
+ const argsCopy = useRef(args);
const ref = useRef(null);
+ const [modelArgs, setModelArgs] = useState(args.model);
+ const model = useMemo(() => props?.model ?? modelArgs, [modelArgs, props?.model]);
+
+ const onModelChange = useMemo(
+ () => (props?.onModelChange ? props.onModelChange : setModelArgs),
+ [props?.onModelChange]
+ );
useEffect(() => {
- /* Simulating a call from "Foundation" code */
- ref.current?.setContent(props.pathRelativeToTheWorkspaceRoot, props.content);
- }, [ref, props.content, props.pathRelativeToTheWorkspaceRoot]);
+ if (Object.keys(diff(argsCopy.current.model, model)).length !== 0) {
+ updateArgs({
+ ...argsCopy.current,
+ model: model,
+ xml: getMarshaller(EMPTY_ONE_EIGHT).builder.build(model),
+ });
+ }
+ }, [updateArgs, model]);
+
+ useEffect(() => {
+ if (Object.keys(diff(argsCopy.current, args)).length === 0) {
+ return;
+ }
+ argsCopy.current = args;
+ if (Object.keys(diff(args.model, model)).length === 0) {
+ return;
+ }
+ onModelChange(args.model);
+ }, [args, model, onModelChange]);
+
+ const onModelDebounceStateChanged = useCallback(() => {
+ console.debug("[scesimEditorStoriesWrapper] Model Debounce state");
+ }, []);
return (
-
-
-
+
);
}
diff --git a/packages/scesim-editor/stories/useCases/IsOldEnoughRule.stories.tsx b/packages/scesim-editor/stories/useCases/IsOldEnoughRule.stories.tsx
index 86592e1a75d..0aa060b7715 100644
--- a/packages/scesim-editor/stories/useCases/IsOldEnoughRule.stories.tsx
+++ b/packages/scesim-editor/stories/useCases/IsOldEnoughRule.stories.tsx
@@ -19,9 +19,11 @@
import React from "react";
import type { Meta, StoryObj } from "@storybook/react";
+import { getMarshaller } from "@kie-tools/scesim-marshaller";
import { TestScenarioEditor } from "../../src/TestScenarioEditor";
-import { SceSimEditorWrapper, SceSimEditorWrapperProps } from "../scesimEditorStoriesWrapper";
+import { SceSimEditorWrapper, StorybookTestScenarioEditorProps } from "../scesimEditorStoriesWrapper";
+export const isOldEnoughDrlFileName = "IsOldEnough.scesim";
export const isOldEnoughDrl = `
@@ -394,12 +396,16 @@ const meta: Meta<{}> = {
};
export default meta;
-type Story = StoryObj;
+type Story = StoryObj;
+
+const marshaller = getMarshaller(isOldEnoughDrl);
+const model = marshaller.parser.parse();
export const IsOldEnough: Story = {
- render: (args) => SceSimEditorWrapper(args),
args: {
- pathRelativeToTheWorkspaceRoot: "isOldEnough.scesim",
- content: isOldEnoughDrl,
+ model: marshaller.parser.parse(),
+ xml: marshaller.builder.build(model),
+ openFileNormalizedPosixPathRelativeToTheWorkspaceRoot: isOldEnoughDrlFileName,
},
+ render: (args) => SceSimEditorWrapper(args),
};
diff --git a/packages/scesim-editor/stories/useCases/TrafficViolationDmn.stories.tsx b/packages/scesim-editor/stories/useCases/TrafficViolationDmn.stories.tsx
index 031704f4650..58856b5432a 100644
--- a/packages/scesim-editor/stories/useCases/TrafficViolationDmn.stories.tsx
+++ b/packages/scesim-editor/stories/useCases/TrafficViolationDmn.stories.tsx
@@ -19,9 +19,11 @@
import React from "react";
import type { Meta, StoryObj } from "@storybook/react";
+import { getMarshaller } from "@kie-tools/scesim-marshaller";
import { TestScenarioEditor } from "../../src/TestScenarioEditor";
-import { SceSimEditorWrapper, SceSimEditorWrapperProps } from "../scesimEditorStoriesWrapper";
+import { SceSimEditorWrapper, StorybookTestScenarioEditorProps } from "../scesimEditorStoriesWrapper";
+export const trafficViolationDmnFileName = "TrafficViolation.scesim";
export const trafficViolationDmn = `
@@ -796,12 +798,16 @@ const meta: Meta<{}> = {
};
export default meta;
-type Story = StoryObj;
+type Story = StoryObj;
+
+const marshaller = getMarshaller(trafficViolationDmn);
+const model = marshaller.parser.parse();
export const TrafficViolation: Story = {
render: (args) => SceSimEditorWrapper(args),
args: {
- pathRelativeToTheWorkspaceRoot: "trafficViolation.scesim",
- content: trafficViolationDmn,
+ model: marshaller.parser.parse(),
+ openFileNormalizedPosixPathRelativeToTheWorkspaceRoot: trafficViolationDmnFileName,
+ xml: marshaller.builder.build(model),
},
};
diff --git a/packages/scesim-editor/tests-e2e/__screenshots__/Google-Chrome/misc/emptyExpression/create-a-new-test-scenario.png b/packages/scesim-editor/tests-e2e/__screenshots__/Google-Chrome/misc/emptyExpression/create-a-new-test-scenario.png
index 97f6e8b3d07..4334ab5e3a3 100644
Binary files a/packages/scesim-editor/tests-e2e/__screenshots__/Google-Chrome/misc/emptyExpression/create-a-new-test-scenario.png and b/packages/scesim-editor/tests-e2e/__screenshots__/Google-Chrome/misc/emptyExpression/create-a-new-test-scenario.png differ
diff --git a/packages/scesim-editor/tests-e2e/__screenshots__/chromium/misc/emptyExpression/create-a-new-test-scenario.png b/packages/scesim-editor/tests-e2e/__screenshots__/chromium/misc/emptyExpression/create-a-new-test-scenario.png
index e85c3f76dec..7cd45f75364 100644
Binary files a/packages/scesim-editor/tests-e2e/__screenshots__/chromium/misc/emptyExpression/create-a-new-test-scenario.png and b/packages/scesim-editor/tests-e2e/__screenshots__/chromium/misc/emptyExpression/create-a-new-test-scenario.png differ
diff --git a/packages/scesim-editor/tests-e2e/__screenshots__/webkit/misc/emptyExpression/create-a-new-test-scenario.png b/packages/scesim-editor/tests-e2e/__screenshots__/webkit/misc/emptyExpression/create-a-new-test-scenario.png
index 30c67fbe4bf..caa7de3b78b 100644
Binary files a/packages/scesim-editor/tests-e2e/__screenshots__/webkit/misc/emptyExpression/create-a-new-test-scenario.png and b/packages/scesim-editor/tests-e2e/__screenshots__/webkit/misc/emptyExpression/create-a-new-test-scenario.png differ
diff --git a/packages/scesim-marshaller/src/schemas/scesim-1_8/SceSim.xsd b/packages/scesim-marshaller/src/schemas/scesim-1_8/SceSim.xsd
index 6f5ebe95ae7..efa8b3b494e 100644
--- a/packages/scesim-marshaller/src/schemas/scesim-1_8/SceSim.xsd
+++ b/packages/scesim-marshaller/src/schemas/scesim-1_8/SceSim.xsd
@@ -1,3 +1,20 @@
+
+
> src/main/resources/application.properties \
- && mvn clean package -B -ntp \
+ && mvn clean package -B \
&& rm -rf target/
diff --git a/packages/serverless-logic-web-tools-swf-dev-mode-image/Containerfile b/packages/serverless-logic-web-tools-swf-dev-mode-image/Containerfile
index 1038ffd3cc4..461cab7af48 100644
--- a/packages/serverless-logic-web-tools-swf-dev-mode-image/Containerfile
+++ b/packages/serverless-logic-web-tools-swf-dev-mode-image/Containerfile
@@ -34,7 +34,6 @@ RUN chown kogito /home/kogito/.m2 && \
mvn clean package \
quarkus:go-offline \
-B \
- -ntp \
-s /home/kogito/.m2/settings.xml \
-Dmaven.test.skip \
-Dmaven.repo.local=/home/kogito/.m2/repository \
diff --git a/packages/serverless-logic-web-tools-swf-dev-mode-image/entrypoint.sh b/packages/serverless-logic-web-tools-swf-dev-mode-image/entrypoint.sh
index 1b98d1080b6..6695bbf1449 100644
--- a/packages/serverless-logic-web-tools-swf-dev-mode-image/entrypoint.sh
+++ b/packages/serverless-logic-web-tools-swf-dev-mode-image/entrypoint.sh
@@ -26,7 +26,7 @@ cd /tmp/app/serverless-logic-web-tools-swf-deployment-quarkus-app
mvn quarkus:dev \
-nsu \
- -ntp \
+ -B \
-o \
-s /home/kogito/.m2/settings.xml \
-Ddebug=false \
diff --git a/packages/sonataflow-builder-image/test-resources/tests/features/sonataflow-builder.feature b/packages/sonataflow-builder-image/test-resources/tests/features/sonataflow-builder.feature
index a4e1bdfcf6b..fefd17bc48f 100644
--- a/packages/sonataflow-builder-image/test-resources/tests/features/sonataflow-builder.feature
+++ b/packages/sonataflow-builder-image/test-resources/tests/features/sonataflow-builder.feature
@@ -12,7 +12,6 @@ Feature: Serverless Workflow builder images
| wait | 480 |
| request_method | GET |
| expected_status_code | 200 |
- And container log should contain --no-transfer-progress
And container log should contain -Duser.home=/home/kogito
And container log should match regex Installed features:.*kogito-serverless-workflow
And container log should match regex Installed features:.*kie-addon-knative-eventing-extension
diff --git a/packages/sonataflow-dev-app/package.json b/packages/sonataflow-dev-app/package.json
index 879b4c2a131..f3aa1eb76db 100644
--- a/packages/sonataflow-dev-app/package.json
+++ b/packages/sonataflow-dev-app/package.json
@@ -28,7 +28,7 @@
"babel-jest": "^25.5.1",
"body-parser": "^1.20.3",
"cors": "^2.8.5",
- "express": "^4.21.0",
+ "express": "^4.21.1",
"express-rate-limit": "^7.4.0",
"graphql": "14.3.1",
"jest": "^29.7.0",
diff --git a/packages/sonataflow-devmode-image/resources/modules/sonataflow/devmode/build-config/module.yaml b/packages/sonataflow-devmode-image/resources/modules/sonataflow/devmode/build-config/module.yaml
index 0309962fee2..5b271764932 100644
--- a/packages/sonataflow-devmode-image/resources/modules/sonataflow/devmode/build-config/module.yaml
+++ b/packages/sonataflow-devmode-image/resources/modules/sonataflow/devmode/build-config/module.yaml
@@ -27,7 +27,7 @@ envs:
- name: QUARKUS_EXTENSIONS
# NOTE: If you change the QUARKUS_EXTENSIONS value remember to update the scripts/logic/build-quarkus-app.sh too!
# Follow up issue to remove KOGITO_VERSION: https://issues.redhat.com/browse/KOGITO-9270
- value: org.apache.kie.sonataflow:sonataflow-quarkus:${KOGITO_VERSION},org.kie:kie-addons-quarkus-knative-eventing:${KOGITO_VERSION},smallrye-health,org.apache.kie.sonataflow:sonataflow-quarkus-devui:${SONATAFLOW_QUARKUS_DEVUI_VERSION},org.kie:kie-addons-quarkus-source-files:${KOGITO_VERSION},org.kie:kie-addons-quarkus-process-management:${KOGITO_VERSION},org.kie:kogito-addons-quarkus-jobs-service-embedded:${KOGITO_VERSION},org.kie:kogito-addons-quarkus-data-index-inmemory:${KOGITO_VERSION},org.kie:kogito-addons-quarkus-microprofile-config-service-catalog:${KOGITO_VERSION},org.kie:kie-addons-quarkus-kubernetes:${KOGITO_VERSION},org.kie:kogito-addons-quarkus-knative-serving:${KOGITO_VERSION}
+ value: org.apache.kie.sonataflow:sonataflow-quarkus:${KOGITO_VERSION},org.kie:kie-addons-quarkus-knative-eventing:${KOGITO_VERSION},smallrye-health,org.apache.kie.sonataflow:sonataflow-quarkus-devui:${SONATAFLOW_QUARKUS_DEVUI_VERSION},org.kie:kie-addons-quarkus-source-files:${KOGITO_VERSION},org.kie:kie-addons-quarkus-process-management:${KOGITO_VERSION},org.kie:kogito-addons-quarkus-jobs-service-embedded:${KOGITO_VERSION},org.kie:kogito-addons-quarkus-data-index-inmemory:${KOGITO_VERSION},org.kie:kogito-addons-quarkus-microprofile-config-service-catalog:${KOGITO_VERSION},org.kie:kie-addons-quarkus-kubernetes:${KOGITO_VERSION},org.kie:kogito-addons-quarkus-knative-serving:${KOGITO_VERSION},org.kie:kie-addons-quarkus-monitoring-prometheus:${KOGITO_VERSION},org.kie:kie-addons-quarkus-monitoring-sonataflow:${KOGITO_VERSION}
execute:
- script: configure
diff --git a/packages/sonataflow-devmode-image/test-resources/tests/features/sonataflow-devmode.feature b/packages/sonataflow-devmode-image/test-resources/tests/features/sonataflow-devmode.feature
index 7ba91ee955e..f9abddb709d 100644
--- a/packages/sonataflow-devmode-image/test-resources/tests/features/sonataflow-devmode.feature
+++ b/packages/sonataflow-devmode-image/test-resources/tests/features/sonataflow-devmode.feature
@@ -12,7 +12,6 @@ Feature: Serverless Workflow devmode images
| wait | 480 |
| request_method | GET |
| expected_status_code | 200 |
- And container log should contain --no-transfer-progress
And container log should contain -Duser.home=/home/kogito -o
And container log should contain -Dquarkus.test.continuous-testing=disabled
And container log should match regex Installed features:.*kogito-serverless-workflow
diff --git a/packages/sonataflow-image-common/resources/Makefile b/packages/sonataflow-image-common/resources/Makefile
index 834de6f6efc..7f72573fb18 100644
--- a/packages/sonataflow-image-common/resources/Makefile
+++ b/packages/sonataflow-image-common/resources/Makefile
@@ -66,12 +66,6 @@ _create_e2e_dir:
rm -rf ../dist-tests-e2e
mkdir ../dist-tests-e2e
-# Pull kogito-apps repo and build the target kogito-apps depending on the `KOGITO_IMAGE_NAME`s
-# Required for kogito-apps images only
-.PHONY build-kogito-app: _build_kogito_app
-_build_kogito_app:
- scripts/build-kogito-apps-components.sh ${KOGITO_IMAGE_NAME} ${KOGITO_VERSION} ${KOGITO_APPS_TARGET_URI};
-
# Trigger the image tests
.PHONY test-image: _create_e2e_dir _check_kogito_image_name _test_image
_test_image:
diff --git a/packages/sonataflow-image-common/resources/modules/kogito-maven/common/added/configure-maven.sh b/packages/sonataflow-image-common/resources/modules/kogito-maven/common/added/configure-maven.sh
index b2b41b7cba4..8b0334342b4 100644
--- a/packages/sonataflow-image-common/resources/modules/kogito-maven/common/added/configure-maven.sh
+++ b/packages/sonataflow-image-common/resources/modules/kogito-maven/common/added/configure-maven.sh
@@ -127,7 +127,7 @@ function configure_mirrors() {
function configure_maven_download_output() {
if [ "${MAVEN_DOWNLOAD_OUTPUT}" != "true" ]; then
- export MAVEN_ARGS_APPEND="${MAVEN_ARGS_APPEND} --no-transfer-progress"
+ export MAVEN_ARGS_APPEND="${MAVEN_ARGS_APPEND}"
fi
}
diff --git a/packages/sonataflow-image-common/resources/modules/kogito-maven/common/maven/maven-m2-repo-via-http-settings.xml.envsubst b/packages/sonataflow-image-common/resources/modules/kogito-maven/common/maven/maven-m2-repo-via-http-settings.xml.envsubst
index e85c5fc1703..ad8a808e6c8 100644
--- a/packages/sonataflow-image-common/resources/modules/kogito-maven/common/maven/maven-m2-repo-via-http-settings.xml.envsubst
+++ b/packages/sonataflow-image-common/resources/modules/kogito-maven/common/maven/maven-m2-repo-via-http-settings.xml.envsubst
@@ -34,74 +34,101 @@
true
never
+ ignore
true
never
+ ignore
-
-
-
-
- kie-tools--maven-m2-repo-via-http
- KIE Tools :: Maven M2 Repo via HTTP
- http://$M2_REPO_VIA_HTTP_URL_WITHOUT_PROTOCOL/
- default
+
+ apache.snapshots
+ Apache Snapshot Repository
+ https://repository.apache.org/snapshots
- true
- never
+ false
true
never
-
-
-
-
-
- kogito-images
-
+
+
+ central
+ Central Repository
+ https://repo.maven.apache.org/maven2
+
+ false
+
+
apache-public-repository-group
Apache Public Repository Group
- https://repository.apache.org/content/groups/public/
+ https://repo.maven.apache.org/maven2
default
- true
+ false
never
- true
+ false
+ never
+
+
+
+ jboss-public-repository-group
+ JBOSS Public Repository Group
+ https://repo.maven.apache.org/maven2
+ default
+
+ false
+ never
+
+
+ false
never
-
+
+ kie-tools--maven-m2-repo-via-http
+ KIE Tools :: Maven M2 Repo via HTTP
+ http://$M2_REPO_VIA_HTTP_URL_WITHOUT_PROTOCOL/
+ default
+
+ true
+ never
+ ignore
+
+
+ true
+ never
+ ignore
+
+
apache-public-repository-group
Apache Public Repository Group
https://repository.apache.org/content/groups/public/
default
- true
+ false
never
- true
+ false
never
-
+
- kogito-images
- kie-tools--maven-m2-repo-via-http-allowed-profile
+ kie-tools--maven-m2-repo-via-http-allowed-profile
diff --git a/packages/sonataflow-image-common/resources/modules/kogito-maven/tests/bats/maven-settings.bats b/packages/sonataflow-image-common/resources/modules/kogito-maven/common/tests/bats/maven-settings.bats
similarity index 98%
rename from packages/sonataflow-image-common/resources/modules/kogito-maven/tests/bats/maven-settings.bats
rename to packages/sonataflow-image-common/resources/modules/kogito-maven/common/tests/bats/maven-settings.bats
index 66fb2363532..a986a92642a 100644
--- a/packages/sonataflow-image-common/resources/modules/kogito-maven/tests/bats/maven-settings.bats
+++ b/packages/sonataflow-image-common/resources/modules/kogito-maven/common/tests/bats/maven-settings.bats
@@ -20,13 +20,13 @@
# imports
-source $BATS_TEST_DIRNAME/../../common/added/configure-maven.sh
+source $BATS_TEST_DIRNAME/../../added/configure-maven.sh
setup() {
export KOGITO_HOME=$BATS_TMPDIR/maven
mkdir -p ${KOGITO_HOME}/.m2/
- cp $BATS_TEST_DIRNAME/../../common/maven/settings.xml ${KOGITO_HOME}/.m2/
+ cp $BATS_TEST_DIRNAME/../../maven/settings.xml ${KOGITO_HOME}/.m2/
export MAVEN_SETTINGS_PATH="${KOGITO_HOME}/.m2/settings.xml"
}
@@ -163,16 +163,6 @@ function _generate_random_id() {
[ "${expected}" = "${result}" ]
}
-@test "test maven download output logs when MAVEN_DOWNLOAD_OUTPUT is not true" {
- prepareEnv
- configure_maven_download_output
- expected=" --no-transfer-progress"
- result="${MAVEN_ARGS_APPEND}"
- echo "expected=${expected}"
- echo "result=${result}"
- [ "${expected}" = "${result}" ]
-}
-
@test "test maven download output logs when MAVEN_DOWNLOAD_OUTPUT is true" {
prepareEnv
MAVEN_DOWNLOAD_OUTPUT="true"
diff --git a/packages/sonataflow-image-common/resources/modules/sonataflow/common/scripts/added/add-extension.sh b/packages/sonataflow-image-common/resources/modules/sonataflow/common/scripts/added/add-extension.sh
index fcce1f5ae26..dc4ab3e7928 100755
--- a/packages/sonataflow-image-common/resources/modules/sonataflow/common/scripts/added/add-extension.sh
+++ b/packages/sonataflow-image-common/resources/modules/sonataflow/common/scripts/added/add-extension.sh
@@ -42,7 +42,7 @@ fi
"${MAVEN_HOME}"/bin/mvn -B ${MAVEN_ARGS_APPEND} \
-nsu \
- -ntp \
+ -B \
-s "${MAVEN_SETTINGS_PATH}" \
-DplatformVersion="${QUARKUS_PLATFORM_VERSION}" \
-Dextensions="${extensions}" \
diff --git a/packages/sonataflow-image-common/resources/modules/sonataflow/common/scripts/added/build-app.sh b/packages/sonataflow-image-common/resources/modules/sonataflow/common/scripts/added/build-app.sh
index 0cd6311d6fc..d91ceed6ea2 100755
--- a/packages/sonataflow-image-common/resources/modules/sonataflow/common/scripts/added/build-app.sh
+++ b/packages/sonataflow-image-common/resources/modules/sonataflow/common/scripts/added/build-app.sh
@@ -59,7 +59,7 @@ cd ${KOGITO_HOME}/serverless-workflow-project
"${MAVEN_HOME}"/bin/mvn -B ${MAVEN_ARGS_APPEND} \
-nsu \
- -ntp \
+ -B \
-s "${MAVEN_SETTINGS_PATH}" \
-DskipTests \
-Dquarkus.container-image.build=false \
diff --git a/packages/sonataflow-image-common/resources/modules/sonataflow/common/scripts/added/create-app.sh b/packages/sonataflow-image-common/resources/modules/sonataflow/common/scripts/added/create-app.sh
index 3534ca868cf..5dedc599f2d 100755
--- a/packages/sonataflow-image-common/resources/modules/sonataflow/common/scripts/added/create-app.sh
+++ b/packages/sonataflow-image-common/resources/modules/sonataflow/common/scripts/added/create-app.sh
@@ -36,7 +36,7 @@ source "${script_dir_path}"/configure-jvm-mvn.sh
"${MAVEN_HOME}"/bin/mvn -B ${MAVEN_ARGS_APPEND} \
-nsu \
- -ntp \
+ -B \
-s "${MAVEN_SETTINGS_PATH}" \
io.quarkus.platform:quarkus-maven-plugin:"${QUARKUS_PLATFORM_VERSION}":create ${QUARKUS_CREATE_ARGS} \
-DprojectGroupId="${PROJECT_GROUP_ID}" \
@@ -131,7 +131,7 @@ fi
# https://maven.apache.org/plugins/maven-dependency-plugin/go-offline-mojo.html
"${MAVEN_HOME}"/bin/mvn -B ${MAVEN_ARGS_APPEND} \
-nsu \
- -ntp \
+ -B \
-s "${MAVEN_SETTINGS_PATH}" \
-DskipTests=true \
-Dmaven.javadoc.skip=true \
@@ -140,6 +140,6 @@ fi
# clean up
"${MAVEN_HOME}"/bin/mvn -B ${MAVEN_ARGS_APPEND} \
-nsu \
- -ntp \
+ -B \
-s "${MAVEN_SETTINGS_PATH}" \
clean
diff --git a/packages/sonataflow-image-common/resources/scripts/README.md b/packages/sonataflow-image-common/resources/scripts/README.md
index 34a4fcd0c85..589ecacfae8 100644
--- a/packages/sonataflow-image-common/resources/scripts/README.md
+++ b/packages/sonataflow-image-common/resources/scripts/README.md
@@ -63,10 +63,6 @@ Usage:
- `--quarkus-version`: Sets the Quarkus version
- `--kogito-version`: Sets the Kogito version
-## Build Kogito Apps Components
-
-The [build-kogito-apps-components.sh](build-kogito-apps-components.sh) script pulls and build the target Kogito Apps application, e.g., Data Index. Required to build Kogito Services images in any flavour.
-
## Setup Maven
The [setup-maven.sh](setup-maven.sh) script configures the internal image Maven repository such as adding new repositories, setup other profiles and so on.
diff --git a/packages/sonataflow-image-common/resources/scripts/common.py b/packages/sonataflow-image-common/resources/scripts/common.py
index 30cbdc44c93..35ce2c44462 100644
--- a/packages/sonataflow-image-common/resources/scripts/common.py
+++ b/packages/sonataflow-image-common/resources/scripts/common.py
@@ -268,7 +268,7 @@ def update_label_value_in_file(filename, label_name, label_value):
:param label_name: label name to update
:param label_value: value to set
"""
- print("Updating {0} label {1} with value {2}".format(filename, label_name, label_value))
+ print(f"Updating {filename} label {label_name} with value {label_value}")
try:
with open(filename) as yaml_file:
data = yaml_loader().load(yaml_file)
@@ -281,7 +281,7 @@ def update_label_value_in_file(filename, label_name, label_value):
raise
-def update_label_value_in_data(data, label_name, label_value, ignore_empty = False):
+def update_label_value_in_data(data, label_name, label_value, ignore_empty=False):
"""
Update label value in data dict if exists
:param data: dict to update
@@ -296,7 +296,7 @@ def update_label_value_in_data(data, label_name, label_value, ignore_empty = Fal
if ignore_empty:
if 'labels' not in data:
data['labels'] = []
- data['labels'] += [ dict(name=label_name, value=label_value) ]
+ data['labels'] += [dict(name=label_name, value=label_value)]
elif 'labels' in data:
for _, label in enumerate(data['labels'], start=0):
if label['name'] == label_name:
diff --git a/packages/sonataflow-image-common/resources/scripts/setup-maven.sh b/packages/sonataflow-image-common/resources/scripts/setup-maven.sh
index 78be682dfe7..d2cf3751a94 100755
--- a/packages/sonataflow-image-common/resources/scripts/setup-maven.sh
+++ b/packages/sonataflow-image-common/resources/scripts/setup-maven.sh
@@ -48,26 +48,6 @@ configure
export MAVEN_OPTIONS="${MAVEN_OPTIONS} -s ${maven_settings_path}"
-# Add NPM registry if needed
-if [ ! -z "${NPM_REGISTRY_URL}" ]; then
- echo "enabling npm repository: ${NPM_REGISTRY_URL}"
- npm_profile="\
-\
-internal-npm-registry\
-\
-${NPM_REGISTRY_URL}\
-http://download.devel.redhat.com/rcm-guest/staging/rhba/dist/yarn/\
-http://download.devel.redhat.com/rcm-guest/staging/rhba/dist/node/\
-http://download.devel.redhat.com/rcm-guest/staging/rhba/dist/npm/\
-http://download.devel.redhat.com/rcm-guest/staging/rhba/dist/pnpm/\
-\
-\
-"
- sed -i.bak -E "s|()|\1\n${npm_profile}|" "${MAVEN_SETTINGS_PATH}"
- sed -i.bak -E "s|()|\1\ninternal-npm-registry|" "${MAVEN_SETTINGS_PATH}"
-
- rm -rf "${MAVEN_SETTINGS_PATH}/*.bak"
-fi
cat "${maven_settings_path}"
diff --git a/packages/sonataflow-operator/test/testdata/platform/noservices/preview/ephemeral/02-sonataflow_platform.yaml b/packages/sonataflow-operator/test/testdata/platform/noservices/preview/ephemeral/02-sonataflow_platform.yaml
index 7d7a0c7834d..82235f4cd1a 100644
--- a/packages/sonataflow-operator/test/testdata/platform/noservices/preview/ephemeral/02-sonataflow_platform.yaml
+++ b/packages/sonataflow-operator/test/testdata/platform/noservices/preview/ephemeral/02-sonataflow_platform.yaml
@@ -26,7 +26,7 @@ spec:
template:
buildArgs:
- name: QUARKUS_EXTENSION
- value: org.kie.kogito:kogito-addons-quarkus-jobs-knative-eventing:999-20240912-SNAPSHOT
+ value: org.kie.kogito:kogito-addons-quarkus-jobs-knative-eventing:999-20241016-SNAPSHOT
config:
strategyOptions:
KanikoBuildCacheEnabled: "true"
diff --git a/packages/sonataflow-operator/test/testdata/platform/services/dev/ephemeral/02-sonataflow_platform.yaml b/packages/sonataflow-operator/test/testdata/platform/services/dev/ephemeral/02-sonataflow_platform.yaml
index b191414226d..fd925ab2b08 100644
--- a/packages/sonataflow-operator/test/testdata/platform/services/dev/ephemeral/02-sonataflow_platform.yaml
+++ b/packages/sonataflow-operator/test/testdata/platform/services/dev/ephemeral/02-sonataflow_platform.yaml
@@ -26,7 +26,7 @@ spec:
template:
buildArgs:
- name: QUARKUS_EXTENSION
- value: org.kie.kogito:kogito-addons-quarkus-jobs-knative-eventing:999-20240912-SNAPSHOT
+ value: org.kie.kogito:kogito-addons-quarkus-jobs-knative-eventing:999-20241016-SNAPSHOT
config:
strategyOptions:
KanikoBuildCacheEnabled: "true"
diff --git a/packages/sonataflow-operator/test/testdata/platform/services/dev/postgreSQL/02-sonataflow_platform.yaml b/packages/sonataflow-operator/test/testdata/platform/services/dev/postgreSQL/02-sonataflow_platform.yaml
index ef4f112e9e4..f5d695d1bae 100644
--- a/packages/sonataflow-operator/test/testdata/platform/services/dev/postgreSQL/02-sonataflow_platform.yaml
+++ b/packages/sonataflow-operator/test/testdata/platform/services/dev/postgreSQL/02-sonataflow_platform.yaml
@@ -26,7 +26,7 @@ spec:
template:
buildArgs:
- name: QUARKUS_EXTENSIONS
- value: org.kie.kogito:kogito-addons-quarkus-jobs-knative-eventing:999-20240912-SNAPSHOT
+ value: org.kie.kogito:kogito-addons-quarkus-jobs-knative-eventing:999-20241016-SNAPSHOT
services:
dataIndex:
enabled: false
diff --git a/packages/sonataflow-operator/test/testdata/platform/services/preview/cluster-wide-ephemeral/02-sonataflow_platform.yaml b/packages/sonataflow-operator/test/testdata/platform/services/preview/cluster-wide-ephemeral/02-sonataflow_platform.yaml
index 7e915e2cd76..904419541ce 100644
--- a/packages/sonataflow-operator/test/testdata/platform/services/preview/cluster-wide-ephemeral/02-sonataflow_platform.yaml
+++ b/packages/sonataflow-operator/test/testdata/platform/services/preview/cluster-wide-ephemeral/02-sonataflow_platform.yaml
@@ -26,7 +26,7 @@ spec:
template:
buildArgs:
- name: QUARKUS_EXTENSION
- value: org.kie.kogito:kogito-addons-quarkus-jobs-knative-eventing:999-20240912-SNAPSHOT
+ value: org.kie.kogito:kogito-addons-quarkus-jobs-knative-eventing:999-20241016-SNAPSHOT
config:
strategyOptions:
KanikoBuildCacheEnabled: "true"
diff --git a/packages/sonataflow-operator/test/testdata/platform/services/preview/ephemeral-data-index/02-sonataflow_platform.yaml b/packages/sonataflow-operator/test/testdata/platform/services/preview/ephemeral-data-index/02-sonataflow_platform.yaml
index 7c1d15d02de..8d0a11a74c6 100644
--- a/packages/sonataflow-operator/test/testdata/platform/services/preview/ephemeral-data-index/02-sonataflow_platform.yaml
+++ b/packages/sonataflow-operator/test/testdata/platform/services/preview/ephemeral-data-index/02-sonataflow_platform.yaml
@@ -26,7 +26,7 @@ spec:
template:
buildArgs:
- name: QUARKUS_EXTENSION
- value: org.kie.kogito:kogito-addons-quarkus-jobs-knative-eventing:999-20240912-SNAPSHOT
+ value: org.kie.kogito:kogito-addons-quarkus-jobs-knative-eventing:999-20241016-SNAPSHOT
config:
strategyOptions:
KanikoBuildCacheEnabled: "true"
diff --git a/packages/sonataflow-operator/test/testdata/platform/services/preview/ephemeral-job-service/02-sonataflow_platform.yaml b/packages/sonataflow-operator/test/testdata/platform/services/preview/ephemeral-job-service/02-sonataflow_platform.yaml
index 735b2c4150d..cb119bb6d3e 100644
--- a/packages/sonataflow-operator/test/testdata/platform/services/preview/ephemeral-job-service/02-sonataflow_platform.yaml
+++ b/packages/sonataflow-operator/test/testdata/platform/services/preview/ephemeral-job-service/02-sonataflow_platform.yaml
@@ -25,7 +25,7 @@ spec:
template:
buildArgs:
- name: QUARKUS_EXTENSION
- value: org.kie.kogito:kogito-addons-quarkus-jobs-knative-eventing:999-20240912-SNAPSHOT
+ value: org.kie.kogito:kogito-addons-quarkus-jobs-knative-eventing:999-20241016-SNAPSHOT
config:
strategyOptions:
KanikoBuildCacheEnabled: "true"
diff --git a/packages/sonataflow-operator/test/testdata/workflow/persistence/by_service/02-sonataflow_platform.yaml b/packages/sonataflow-operator/test/testdata/workflow/persistence/by_service/02-sonataflow_platform.yaml
index 73f61014068..a9cc3847d80 100644
--- a/packages/sonataflow-operator/test/testdata/workflow/persistence/by_service/02-sonataflow_platform.yaml
+++ b/packages/sonataflow-operator/test/testdata/workflow/persistence/by_service/02-sonataflow_platform.yaml
@@ -26,7 +26,7 @@ spec:
template:
buildArgs:
- name: QUARKUS_EXTENSIONS
- value: org.kie:kie-addons-quarkus-persistence-jdbc:999-20240912-SNAPSHOT,io.quarkus:quarkus-jdbc-postgresql:3.8.6,io.quarkus:quarkus-agroal:3.8.6
+ value: org.kie:kie-addons-quarkus-persistence-jdbc:999-20241016-SNAPSHOT,io.quarkus:quarkus-jdbc-postgresql:3.8.6,io.quarkus:quarkus-agroal:3.8.6
config:
strategyOptions:
KanikoBuildCacheEnabled: "true"
diff --git a/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_overwritten_by_service/02-sonataflow_platform.yaml b/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_overwritten_by_service/02-sonataflow_platform.yaml
index 49d9a7ae895..f10df872ac4 100644
--- a/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_overwritten_by_service/02-sonataflow_platform.yaml
+++ b/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_overwritten_by_service/02-sonataflow_platform.yaml
@@ -36,7 +36,7 @@ spec:
template:
buildArgs:
- name: QUARKUS_EXTENSIONS
- value: org.kie:kie-addons-quarkus-persistence-jdbc:999-20240912-SNAPSHOT,io.quarkus:quarkus-jdbc-postgresql:3.8.6,io.quarkus:quarkus-agroal:3.8.6
+ value: org.kie:kie-addons-quarkus-persistence-jdbc:999-20241016-SNAPSHOT,io.quarkus:quarkus-jdbc-postgresql:3.8.6,io.quarkus:quarkus-agroal:3.8.6
config:
strategyOptions:
KanikoBuildCacheEnabled: "true"
diff --git a/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_with_di_and_js_services/02-sonataflow_platform.yaml b/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_with_di_and_js_services/02-sonataflow_platform.yaml
index 4003263627c..8f23dbc2090 100644
--- a/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_with_di_and_js_services/02-sonataflow_platform.yaml
+++ b/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_with_di_and_js_services/02-sonataflow_platform.yaml
@@ -36,7 +36,7 @@ spec:
template:
buildArgs:
- name: QUARKUS_EXTENSIONS
- value: org.kie:kie-addons-quarkus-persistence-jdbc:999-20240912-SNAPSHOT,io.quarkus:quarkus-jdbc-postgresql:3.8.6,io.quarkus:quarkus-agroal:3.8.6
+ value: org.kie:kie-addons-quarkus-persistence-jdbc:999-20241016-SNAPSHOT,io.quarkus:quarkus-jdbc-postgresql:3.8.6,io.quarkus:quarkus-agroal:3.8.6
config:
strategyOptions:
KanikoBuildCacheEnabled: "true"
diff --git a/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_with_no_persistence_required/02-sonataflow_platform.yaml b/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_with_no_persistence_required/02-sonataflow_platform.yaml
index db0fb8d8284..ee47d71bbb0 100644
--- a/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_with_no_persistence_required/02-sonataflow_platform.yaml
+++ b/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_with_no_persistence_required/02-sonataflow_platform.yaml
@@ -36,7 +36,7 @@ spec:
template:
buildArgs:
- name: QUARKUS_EXTENSIONS
- value: org.kie:kie-addons-quarkus-persistence-jdbc:999-20240912-SNAPSHOT,io.quarkus:quarkus-jdbc-postgresql:3.8.6,io.quarkus:quarkus-agroal:3.8.6
+ value: org.kie:kie-addons-quarkus-persistence-jdbc:999-20241016-SNAPSHOT,io.quarkus:quarkus-jdbc-postgresql:3.8.6,io.quarkus:quarkus-agroal:3.8.6
config:
strategyOptions:
KanikoBuildCacheEnabled: "true"
diff --git a/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_without_di_and_js_services/02-sonataflow_platform.yaml b/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_without_di_and_js_services/02-sonataflow_platform.yaml
index db0fb8d8284..ee47d71bbb0 100644
--- a/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_without_di_and_js_services/02-sonataflow_platform.yaml
+++ b/packages/sonataflow-operator/test/testdata/workflow/persistence/from_platform_without_di_and_js_services/02-sonataflow_platform.yaml
@@ -36,7 +36,7 @@ spec:
template:
buildArgs:
- name: QUARKUS_EXTENSIONS
- value: org.kie:kie-addons-quarkus-persistence-jdbc:999-20240912-SNAPSHOT,io.quarkus:quarkus-jdbc-postgresql:3.8.6,io.quarkus:quarkus-agroal:3.8.6
+ value: org.kie:kie-addons-quarkus-persistence-jdbc:999-20241016-SNAPSHOT,io.quarkus:quarkus-jdbc-postgresql:3.8.6,io.quarkus:quarkus-agroal:3.8.6
config:
strategyOptions:
KanikoBuildCacheEnabled: "true"
diff --git a/packages/storybook-base/src/config/baseConfig.ts b/packages/storybook-base/src/config/baseConfig.ts
index 7af3802d885..384d9fe0f3a 100644
--- a/packages/storybook-base/src/config/baseConfig.ts
+++ b/packages/storybook-base/src/config/baseConfig.ts
@@ -60,7 +60,9 @@ export const baseConfig: (
path.dirname(require.resolve("@storybook/addon-webpack5-compiler-babel/package.json")),
],
webpackFinal: async (config) => {
- return merge(config, common);
+ // Preserve Storybook output configurations
+ const commonConfig = { ...common, output: undefined };
+ return merge(config, commonConfig);
},
};
};
diff --git a/packages/stunner-editors/errai-ui/src/test/resources/less.jar b/packages/stunner-editors/errai-ui/src/test/resources/less.jar
deleted file mode 100644
index cdce000cd1d..00000000000
Binary files a/packages/stunner-editors/errai-ui/src/test/resources/less.jar and /dev/null differ
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index 563135ff025..2b56e36c473 100644
--- a/pnpm-lock.yaml
+++ b/pnpm-lock.yaml
@@ -325,9 +325,6 @@ importers:
'@kie-tools/kogito-management-console':
specifier: workspace:*
version: link:../../packages/kogito-management-console
- '@kie-tools/kogito-task-console':
- specifier: workspace:*
- version: link:../../packages/kogito-task-console
'@kie-tools/root-env':
specifier: workspace:*
version: link:../../packages/root-env
@@ -1555,8 +1552,8 @@ importers:
specifier: ^2.8.5
version: 2.8.5
express:
- specifier: ^4.21.0
- version: 4.21.0
+ specifier: ^4.21.1
+ version: 4.21.1
node-fetch:
specifier: ^3.3.1
version: 3.3.1
@@ -3332,8 +3329,8 @@ importers:
specifier: '>=17.0.2 <19.0.0'
version: 17.0.2(react@17.0.2)
react-error-boundary:
- specifier: ^4.0.11
- version: 4.0.12(react@17.0.2)
+ specifier: ^4.0.13
+ version: 4.0.13(react@17.0.2)
reactflow:
specifier: ^11.8.3
version: 11.10.1(@types/react@17.0.21)(immer@10.0.3(patch_hash=utu5oov26wz5mjuays57tp3ybu))(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
@@ -6402,6 +6399,9 @@ importers:
packages/kogito-data-index-ephemeral-image:
devDependencies:
+ '@kie-tools/maven-base':
+ specifier: workspace:*
+ version: link:../maven-base
'@kie-tools/python-venv':
specifier: workspace:*
version: link:../python-venv
@@ -6426,6 +6426,9 @@ importers:
packages/kogito-data-index-postgresql-image:
devDependencies:
+ '@kie-tools/maven-base':
+ specifier: workspace:*
+ version: link:../maven-base
'@kie-tools/python-venv':
specifier: workspace:*
version: link:../python-venv
@@ -6450,6 +6453,9 @@ importers:
packages/kogito-jit-runner-image:
devDependencies:
+ '@kie-tools/maven-base':
+ specifier: workspace:*
+ version: link:../maven-base
'@kie-tools/python-venv':
specifier: workspace:*
version: link:../python-venv
@@ -6474,6 +6480,9 @@ importers:
packages/kogito-jobs-service-allinone-image:
devDependencies:
+ '@kie-tools/maven-base':
+ specifier: workspace:*
+ version: link:../maven-base
'@kie-tools/python-venv':
specifier: workspace:*
version: link:../python-venv
@@ -6498,6 +6507,9 @@ importers:
packages/kogito-jobs-service-ephemeral-image:
devDependencies:
+ '@kie-tools/maven-base':
+ specifier: workspace:*
+ version: link:../maven-base
'@kie-tools/python-venv':
specifier: workspace:*
version: link:../python-venv
@@ -6522,6 +6534,9 @@ importers:
packages/kogito-jobs-service-postgresql-image:
devDependencies:
+ '@kie-tools/maven-base':
+ specifier: workspace:*
+ version: link:../maven-base
'@kie-tools/python-venv':
specifier: workspace:*
version: link:../python-venv
@@ -6568,30 +6583,6 @@ importers:
specifier: ^1.1.2
version: 1.1.2
- packages/kogito-task-console:
- devDependencies:
- '@kie-tools/image-builder':
- specifier: workspace:*
- version: link:../image-builder
- '@kie-tools/image-env-to-json':
- specifier: workspace:*
- version: link:../image-env-to-json
- '@kie-tools/root-env':
- specifier: workspace:*
- version: link:../root-env
- '@kie-tools/runtime-tools-task-console-webapp':
- specifier: workspace:*
- version: link:../runtime-tools-task-console-webapp
- rimraf:
- specifier: ^3.0.2
- version: 3.0.2
- run-script-os:
- specifier: ^1.1.6
- version: 1.1.6
- ts-json-schema-generator:
- specifier: ^1.1.2
- version: 1.1.2
-
packages/kubernetes-bridge:
dependencies:
'@kie-tools/cors-proxy-api':
@@ -6644,8 +6635,6 @@ importers:
specifier: ^1.1.6
version: 1.1.6
- packages/maven-config-setup-helper: {}
-
packages/maven-m2-repo-via-http-image:
devDependencies:
'@kie-tools/image-builder':
@@ -7624,9 +7613,6 @@ importers:
'@kie-tools/kogito-management-console':
specifier: workspace:*
version: link:../kogito-management-console
- '@kie-tools/kogito-task-console':
- specifier: workspace:*
- version: link:../kogito-task-console
devDependencies:
'@kie-tools/root-env':
specifier: workspace:*
@@ -7740,6 +7726,12 @@ importers:
'@graphql-codegen/typescript-react-apollo':
specifier: ^3.3.7
version: 3.3.7(encoding@0.1.13)(graphql-tag@2.12.6(graphql@14.3.1))(graphql@14.3.1)
+ '@kie-tools-core/envelope':
+ specifier: workspace:*
+ version: link:../envelope
+ '@kie-tools-core/envelope-bus':
+ specifier: workspace:*
+ version: link:../envelope-bus
'@kie-tools-core/webpack-base':
specifier: workspace:*
version: link:../webpack-base
@@ -7766,7 +7758,7 @@ importers:
version: 5.3.3
apollo-server-express:
specifier: ^3.13.0
- version: 3.13.0(encoding@0.1.13)(express@4.21.0)(graphql@14.3.1)
+ version: 3.13.0(encoding@0.1.13)(express@4.21.1)(graphql@14.3.1)
body-parser:
specifier: ^1.20.3
version: 1.20.3
@@ -7789,8 +7781,8 @@ importers:
specifier: ^5.0.1
version: 5.0.1(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
express:
- specifier: ^4.21.0
- version: 4.21.0
+ specifier: ^4.21.1
+ version: 4.21.1
file-loader:
specifier: ^6.2.0
version: 6.2.0(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
@@ -8031,7 +8023,7 @@ importers:
version: 8.3.0
apollo-server-express:
specifier: ^3.13.0
- version: 3.13.0(encoding@0.1.13)(express@4.21.0)(graphql@14.3.1)
+ version: 3.13.0(encoding@0.1.13)(express@4.21.1)(graphql@14.3.1)
body-parser:
specifier: ^1.20.3
version: 1.20.3
@@ -8054,8 +8046,8 @@ importers:
specifier: ^5.0.1
version: 5.0.1(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
express:
- specifier: ^4.21.0
- version: 4.21.0
+ specifier: ^4.21.1
+ version: 4.21.1
file-loader:
specifier: ^6.2.0
version: 6.2.0(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
@@ -8112,7 +8104,7 @@ importers:
version: 8.0.0(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
swagger-ui-express:
specifier: ^5.0.0
- version: 5.0.0(express@4.21.0)
+ version: 5.0.0(express@4.21.1)
ts-loader:
specifier: ^9.4.2
version: 9.4.2(typescript@5.5.3)(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
@@ -9067,229 +9059,6 @@ importers:
specifier: ^5.5.3
version: 5.5.3
- packages/runtime-tools-task-console-webapp:
- dependencies:
- '@kie-tools-core/envelope':
- specifier: workspace:*
- version: link:../envelope
- '@kie-tools-core/envelope-bus':
- specifier: workspace:*
- version: link:../envelope-bus
- '@kie-tools-core/react-hooks':
- specifier: workspace:*
- version: link:../react-hooks
- '@kie-tools/runtime-tools-components':
- specifier: workspace:*
- version: link:../runtime-tools-components
- '@kie-tools/runtime-tools-process-enveloped-components':
- specifier: workspace:*
- version: link:../runtime-tools-process-enveloped-components
- '@kie-tools/runtime-tools-process-gateway-api':
- specifier: workspace:*
- version: link:../runtime-tools-process-gateway-api
- '@kie-tools/runtime-tools-process-webapp-components':
- specifier: workspace:*
- version: link:../runtime-tools-process-webapp-components
- '@kie-tools/runtime-tools-shared-enveloped-components':
- specifier: workspace:*
- version: link:../runtime-tools-shared-enveloped-components
- '@kie-tools/runtime-tools-shared-gateway-api':
- specifier: workspace:*
- version: link:../runtime-tools-shared-gateway-api
- '@kie-tools/runtime-tools-shared-webapp-components':
- specifier: workspace:*
- version: link:../runtime-tools-shared-webapp-components
- '@patternfly/patternfly':
- specifier: ^4.224.2
- version: 4.224.2
- '@patternfly/react-core':
- specifier: ^4.276.6
- version: 4.276.6(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
- '@patternfly/react-icons':
- specifier: ^4.93.6
- version: 4.93.6(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
- apollo-cache-inmemory:
- specifier: 1.6.6
- version: 1.6.6(graphql@14.3.1)
- apollo-client:
- specifier: 2.6.10
- version: 2.6.10(graphql@14.3.1)
- apollo-link-context:
- specifier: ^1.0.20
- version: 1.0.20(graphql@14.3.1)
- apollo-link-error:
- specifier: 1.1.13
- version: 1.1.13(graphql@14.3.1)
- apollo-link-http:
- specifier: 1.5.17
- version: 1.5.17(graphql@14.3.1)
- axios:
- specifier: ^1.7.4
- version: 1.7.4
- graphql:
- specifier: 14.3.1
- version: 14.3.1
- history:
- specifier: ^4.9.0
- version: 4.10.1
- lodash:
- specifier: ^4.17.21
- version: 4.17.21
- moment:
- specifier: ^2.29.4
- version: 2.29.4
- react:
- specifier: ^17.0.2
- version: 17.0.2
- react-dom:
- specifier: ^17.0.2
- version: 17.0.2(react@17.0.2)
- react-router:
- specifier: ^5.3.4
- version: 5.3.4(react@17.0.2)
- react-router-dom:
- specifier: ^5.3.4
- version: 5.3.4(react@17.0.2)
- devDependencies:
- '@babel/core':
- specifier: ^7.16.0
- version: 7.23.9
- '@babel/preset-env':
- specifier: ^7.16.0
- version: 7.23.9(@babel/core@7.23.9)
- '@babel/preset-react':
- specifier: ^7.16.0
- version: 7.22.15(@babel/core@7.23.9)
- '@graphql-codegen/add':
- specifier: ^3.2.3
- version: 3.2.3(graphql@14.3.1)
- '@graphql-codegen/cli':
- specifier: ^2.16.5
- version: 2.16.5(@babel/core@7.23.9)(@swc/core@1.3.92)(@types/node@22.5.2)(encoding@0.1.13)(enquirer@2.4.1)(graphql@14.3.1)(typescript@5.5.3)
- '@graphql-codegen/introspection':
- specifier: ^2.2.3
- version: 2.2.3(encoding@0.1.13)(graphql@14.3.1)
- '@graphql-codegen/typescript':
- specifier: ^2.8.8
- version: 2.8.8(encoding@0.1.13)(graphql@14.3.1)
- '@graphql-codegen/typescript-operations':
- specifier: ^2.5.13
- version: 2.5.13(encoding@0.1.13)(graphql@14.3.1)
- '@graphql-codegen/typescript-react-apollo':
- specifier: ^3.3.7
- version: 3.3.7(encoding@0.1.13)(graphql-tag@2.12.6(graphql@14.3.1))(graphql@14.3.1)
- '@kie-tools-core/webpack-base':
- specifier: workspace:*
- version: link:../webpack-base
- '@kie-tools/eslint':
- specifier: workspace:*
- version: link:../eslint
- '@kie-tools/root-env':
- specifier: workspace:*
- version: link:../root-env
- '@kie-tools/tsconfig':
- specifier: workspace:*
- version: link:../tsconfig
- '@types/react':
- specifier: ^17.0.6
- version: 17.0.21
- '@types/react-dom':
- specifier: ^17.0.5
- version: 17.0.8
- '@types/react-router':
- specifier: ^5.1.20
- version: 5.1.20
- '@types/react-router-dom':
- specifier: ^5.3.3
- version: 5.3.3
- apollo-server-express:
- specifier: ^3.13.0
- version: 3.13.0(encoding@0.1.13)(express@4.21.0)(graphql@14.3.1)
- concurrently:
- specifier: ^8.2.2
- version: 8.2.2
- copy-webpack-plugin:
- specifier: ^11.0.0
- version: 11.0.0(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
- cors:
- specifier: ^2.8.5
- version: 2.8.5
- css-loader:
- specifier: ^5.2.6
- version: 5.2.7(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
- css-minimizer-webpack-plugin:
- specifier: ^5.0.1
- version: 5.0.1(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
- express:
- specifier: ^4.21.0
- version: 4.21.0
- file-loader:
- specifier: ^6.2.0
- version: 6.2.0(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
- html-webpack-plugin:
- specifier: ^5.3.2
- version: 5.5.3(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
- https-browserify:
- specifier: ^1.0.0
- version: 1.0.0
- identity-obj-proxy:
- specifier: ^3.0.0
- version: 3.0.0
- mini-css-extract-plugin:
- specifier: ^2.7.6
- version: 2.8.1(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
- nodemon:
- specifier: ^3.1.4
- version: 3.1.4
- rimraf:
- specifier: ^3.0.2
- version: 3.0.2
- sass-loader:
- specifier: ^12.3.0
- version: 12.4.0(sass@1.77.6)(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
- stream-http:
- specifier: ^3.2.0
- version: 3.2.0
- style-loader:
- specifier: ^2.0.0
- version: 2.0.0(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
- svg-url-loader:
- specifier: ^8.0.0
- version: 8.0.0(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
- ts-loader:
- specifier: ^9.4.2
- version: 9.4.2(typescript@5.5.3)(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
- tsconfig-paths-webpack-plugin:
- specifier: ^3.5.2
- version: 3.5.2
- typescript:
- specifier: ^5.5.3
- version: 5.5.3
- url:
- specifier: ^0.11.3
- version: 0.11.3
- url-loader:
- specifier: ^4.1.1
- version: 4.1.1(file-loader@6.2.0(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0)))(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0))
- uuid:
- specifier: ^8.3.2
- version: 8.3.2
- waait:
- specifier: ^1.0.5
- version: 1.0.5
- webpack:
- specifier: ^5.94.0
- version: 5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0)
- webpack-cli:
- specifier: ^4.10.0
- version: 4.10.0(webpack-dev-server@4.15.1)(webpack@5.94.0)
- webpack-dev-server:
- specifier: ^4.15.1
- version: 4.15.1(webpack-cli@4.10.0)(webpack@5.94.0)
- webpack-merge:
- specifier: ^5.9.0
- version: 5.9.0
-
packages/scesim-editor:
dependencies:
'@kie-tools-core/i18n':
@@ -9301,6 +9070,9 @@ importers:
'@kie-tools/boxed-expression-component':
specifier: workspace:*
version: link:../boxed-expression-component
+ '@kie-tools/dmn-marshaller':
+ specifier: workspace:*
+ version: link:../dmn-marshaller
'@kie-tools/i18n-common-dictionary':
specifier: workspace:*
version: link:../i18n-common-dictionary
@@ -9316,6 +9088,9 @@ importers:
'@patternfly/react-styles':
specifier: ^4.92.6
version: 4.92.6
+ immer:
+ specifier: ^10.0.3
+ version: 10.0.3(patch_hash=utu5oov26wz5mjuays57tp3ybu)
lodash:
specifier: ^4.17.21
version: 4.17.21
@@ -9331,6 +9106,9 @@ importers:
uuid:
specifier: ^8.3.2
version: 8.3.2
+ zustand:
+ specifier: ^4.4.2
+ version: 4.4.2(patch_hash=7tws22nsyaxzkdpquvgytzpdve)(@types/react@17.0.21)(immer@10.0.3(patch_hash=utu5oov26wz5mjuays57tp3ybu))(react@17.0.2)
devDependencies:
'@babel/core':
specifier: ^7.16.0
@@ -9404,9 +9182,15 @@ importers:
cross-env:
specifier: ^7.0.3
version: 7.0.3
+ deep-object-diff:
+ specifier: ^1.1.9
+ version: 1.1.9
file-loader:
specifier: ^6.2.0
version: 6.2.0(webpack@5.94.0(webpack-cli@4.10.0))
+ react-error-boundary:
+ specifier: ^4.0.13
+ version: 4.0.13(react@17.0.2)
rimraf:
specifier: ^3.0.2
version: 3.0.2
@@ -9432,6 +9216,85 @@ importers:
specifier: ^5.9.0
version: 5.9.0
+ packages/scesim-editor-envelope:
+ dependencies:
+ '@kie-tools-core/editor':
+ specifier: workspace:*
+ version: link:../editor
+ '@kie-tools-core/envelope':
+ specifier: workspace:*
+ version: link:../envelope
+ '@kie-tools-core/envelope-bus':
+ specifier: workspace:*
+ version: link:../envelope-bus
+ '@kie-tools-core/keyboard-shortcuts':
+ specifier: workspace:*
+ version: link:../keyboard-shortcuts
+ '@kie-tools-core/notifications':
+ specifier: workspace:*
+ version: link:../notifications
+ '@kie-tools-core/react-hooks':
+ specifier: workspace:*
+ version: link:../react-hooks
+ '@kie-tools-core/workspace':
+ specifier: workspace:*
+ version: link:../workspace
+ '@kie-tools/boxed-expression-component':
+ specifier: workspace:*
+ version: link:../boxed-expression-component
+ '@kie-tools/dmn-marshaller':
+ specifier: workspace:*
+ version: link:../dmn-marshaller
+ '@kie-tools/scesim-editor':
+ specifier: workspace:*
+ version: link:../scesim-editor
+ '@kie-tools/scesim-marshaller':
+ specifier: workspace:*
+ version: link:../scesim-marshaller
+ '@kie-tools/xml-parser-ts':
+ specifier: workspace:*
+ version: link:../xml-parser-ts
+ '@patternfly/react-core':
+ specifier: ^4.276.6
+ version: 4.276.6(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
+ react:
+ specifier: '>=17.0.2 <19.0.0'
+ version: 17.0.2
+ react-dom:
+ specifier: '>=17.0.2 <19.0.0'
+ version: 17.0.2(react@17.0.2)
+ devDependencies:
+ '@babel/core':
+ specifier: ^7.16.0
+ version: 7.24.9
+ '@babel/preset-env':
+ specifier: ^7.16.0
+ version: 7.24.7(@babel/core@7.24.9)
+ '@babel/preset-react':
+ specifier: ^7.16.0
+ version: 7.22.15(@babel/core@7.24.9)
+ '@kie-tools/eslint':
+ specifier: workspace:*
+ version: link:../eslint
+ '@kie-tools/root-env':
+ specifier: workspace:*
+ version: link:../root-env
+ '@kie-tools/tsconfig':
+ specifier: workspace:*
+ version: link:../tsconfig
+ '@types/react':
+ specifier: ^17.0.6
+ version: 17.0.21
+ '@types/react-dom':
+ specifier: ^17.0.5
+ version: 17.0.8
+ rimraf:
+ specifier: ^3.0.2
+ version: 3.0.2
+ typescript:
+ specifier: ^5.5.3
+ version: 5.5.3
+
packages/scesim-marshaller:
dependencies:
'@kie-tools/xml-parser-ts':
@@ -11333,7 +11196,7 @@ importers:
version: link:../root-env
apollo-server-express:
specifier: ^3.13.0
- version: 3.13.0(encoding@0.1.13)(express@4.21.0)(graphql@14.3.1)
+ version: 3.13.0(encoding@0.1.13)(express@4.21.1)(graphql@14.3.1)
babel-jest:
specifier: ^25.5.1
version: 25.5.1(@babel/core@7.24.9)
@@ -11344,11 +11207,11 @@ importers:
specifier: ^2.8.5
version: 2.8.5
express:
- specifier: ^4.21.0
- version: 4.21.0
+ specifier: ^4.21.1
+ version: 4.21.1
express-rate-limit:
specifier: ^7.4.0
- version: 7.4.0(express@4.21.0)
+ version: 7.4.0(express@4.21.1)
graphql:
specifier: 14.3.1
version: 14.3.1
@@ -11363,7 +11226,7 @@ importers:
version: 3.1.4
swagger-ui-express:
specifier: ^5.0.0
- version: 5.0.0(express@4.21.0)
+ version: 5.0.0(express@4.21.1)
uuid:
specifier: ^8.3.2
version: 8.3.2
@@ -14501,6 +14364,7 @@ packages:
'@babel/plugin-proposal-async-generator-functions@7.16.8':
resolution: {integrity: sha512-71YHIvMuiuqWJQkebWJtdhQTfd4Q4mF76q2IX37uZPkG9+olBxsX+rH1vkhFto4UeJZ9dPY2s+mDvhDm1u2BGQ==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-async-generator-functions instead.
peerDependencies:
'@babel/core': ^7.0.0-0
@@ -14514,6 +14378,7 @@ packages:
'@babel/plugin-proposal-class-properties@7.16.7':
resolution: {integrity: sha512-IobU0Xme31ewjYOShSIqd/ZGM/r/cuOz2z0MDbNrhF5FW+ZVgi0f2lyeoj9KFPDOAqsYxmLWZte1WOwlvY9aww==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-class-properties instead.
peerDependencies:
'@babel/core': ^7.0.0-0
@@ -14527,6 +14392,7 @@ packages:
'@babel/plugin-proposal-class-static-block@7.17.6':
resolution: {integrity: sha512-X/tididvL2zbs7jZCeeRJ8167U/+Ac135AM6jCAx6gYXDUviZV5Ku9UDvWS2NCuWlFjIRXklYhwo6HhAC7ETnA==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-class-static-block instead.
peerDependencies:
'@babel/core': ^7.12.0
@@ -14540,6 +14406,7 @@ packages:
'@babel/plugin-proposal-dynamic-import@7.16.7':
resolution: {integrity: sha512-I8SW9Ho3/8DRSdmDdH3gORdyUuYnk1m4cMxUAdu5oy4n3OfN8flDEH+d60iG7dUfi0KkYwSvoalHzzdRzpWHTg==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-dynamic-import instead.
peerDependencies:
'@babel/core': ^7.0.0-0
@@ -14553,6 +14420,7 @@ packages:
'@babel/plugin-proposal-export-namespace-from@7.16.7':
resolution: {integrity: sha512-ZxdtqDXLRGBL64ocZcs7ovt71L3jhC1RGSyR996svrCi3PYqHNkb3SwPJCs8RIzD86s+WPpt2S73+EHCGO+NUA==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-export-namespace-from instead.
peerDependencies:
'@babel/core': ^7.0.0-0
@@ -14566,6 +14434,7 @@ packages:
'@babel/plugin-proposal-json-strings@7.16.7':
resolution: {integrity: sha512-lNZ3EEggsGY78JavgbHsK9u5P3pQaW7k4axlgFLYkMd7UBsiNahCITShLjNQschPyjtO6dADrL24757IdhBrsQ==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-json-strings instead.
peerDependencies:
'@babel/core': ^7.0.0-0
@@ -14579,6 +14448,7 @@ packages:
'@babel/plugin-proposal-logical-assignment-operators@7.16.7':
resolution: {integrity: sha512-K3XzyZJGQCr00+EtYtrDjmwX7o7PLK6U9bi1nCwkQioRFVUv6dJoxbQjtWVtP+bCPy82bONBKG8NPyQ4+i6yjg==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-logical-assignment-operators instead.
peerDependencies:
'@babel/core': ^7.0.0-0
@@ -14592,30 +14462,35 @@ packages:
'@babel/plugin-proposal-nullish-coalescing-operator@7.16.7':
resolution: {integrity: sha512-aUOrYU3EVtjf62jQrCj63pYZ7k6vns2h/DQvHPWGmsJRYzWXZ6/AsfgpiRy6XiuIDADhJzP2Q9MwSMKauBQ+UQ==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-nullish-coalescing-operator instead.
peerDependencies:
'@babel/core': ^7.0.0-0
'@babel/plugin-proposal-nullish-coalescing-operator@7.18.6':
resolution: {integrity: sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-nullish-coalescing-operator instead.
peerDependencies:
'@babel/core': ^7.0.0-0
'@babel/plugin-proposal-numeric-separator@7.16.7':
resolution: {integrity: sha512-vQgPMknOIgiuVqbokToyXbkY/OmmjAzr/0lhSIbG/KmnzXPGwW/AdhdKpi+O4X/VkWiWjnkKOBiqJrTaC98VKw==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-numeric-separator instead.
peerDependencies:
'@babel/core': ^7.0.0-0
'@babel/plugin-proposal-numeric-separator@7.18.6':
resolution: {integrity: sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-numeric-separator instead.
peerDependencies:
'@babel/core': ^7.0.0-0
'@babel/plugin-proposal-object-rest-spread@7.17.3':
resolution: {integrity: sha512-yuL5iQA/TbZn+RGAfxQXfi7CNLmKi1f8zInn4IgobuCWcAb7i+zj4TYzQ9l8cEzVyJ89PDGuqxK1xZpUDISesw==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-object-rest-spread instead.
peerDependencies:
'@babel/core': ^7.0.0-0
@@ -14629,6 +14504,7 @@ packages:
'@babel/plugin-proposal-optional-catch-binding@7.16.7':
resolution: {integrity: sha512-eMOH/L4OvWSZAE1VkHbr1vckLG1WUcHGJSLqqQwl2GaUqG6QjddvrOaTUMNYiv77H5IKPMZ9U9P7EaHwvAShfA==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-optional-catch-binding instead.
peerDependencies:
'@babel/core': ^7.0.0-0
@@ -14642,6 +14518,7 @@ packages:
'@babel/plugin-proposal-optional-chaining@7.16.7':
resolution: {integrity: sha512-eC3xy+ZrUcBtP7x+sq62Q/HYd674pPTb/77XZMb5wbDPGWIdUbSr4Agr052+zaUPSb+gGRnjxXfKFvx5iMJ+DA==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-optional-chaining instead.
peerDependencies:
'@babel/core': ^7.0.0-0
@@ -14655,6 +14532,7 @@ packages:
'@babel/plugin-proposal-private-methods@7.16.11':
resolution: {integrity: sha512-F/2uAkPlXDr8+BHpZvo19w3hLFKge+k75XUprE6jaqKxjGkSYcK+4c+bup5PdW/7W/Rpjwql7FTVEDW+fRAQsw==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-private-methods instead.
peerDependencies:
'@babel/core': ^7.0.0-0
@@ -14668,6 +14546,7 @@ packages:
'@babel/plugin-proposal-private-property-in-object@7.16.7':
resolution: {integrity: sha512-rMQkjcOFbm+ufe3bTZLyOfsOUOxyvLXZJCTARhJr+8UMSoZmqTe1K1BgkFcrW37rAchWg57yI69ORxiWvUINuQ==}
engines: {node: '>=6.9.0'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-private-property-in-object instead.
peerDependencies:
'@babel/core': ^7.0.0-0
@@ -14687,6 +14566,7 @@ packages:
'@babel/plugin-proposal-unicode-property-regex@7.16.7':
resolution: {integrity: sha512-QRK0YI/40VLhNVGIjRNAAQkEHws0cswSdFFjpFyt943YmJIU1da9uW63Iu6NFV6CxTZW5eTDCrwZUstBWgp/Rg==}
engines: {node: '>=4'}
+ deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-unicode-property-regex instead.
peerDependencies:
'@babel/core': ^7.0.0-0
@@ -16940,6 +16820,7 @@ packages:
'@humanwhocodes/config-array@0.11.13':
resolution: {integrity: sha512-JSBDMiDKSzQVngfRjOdFXgFfklaXI4K9nLF49Auh21lmBWRLIK3+xTErTWD4KU54pb6coM6ESE7Awz/FNU3zgQ==}
engines: {node: '>=10.10.0'}
+ deprecated: Use @eslint/config-array instead
'@humanwhocodes/module-importer@1.0.1':
resolution: {integrity: sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==}
@@ -16951,6 +16832,7 @@ packages:
'@humanwhocodes/object-schema@2.0.1':
resolution: {integrity: sha512-dvuCeX5fC9dXgJn9t+X5atfmgQAzUOWqS1254Gh0m6i8wKd10ebXkfNKiRK+1GWi/yTvvLDHpoxLr0xxxeslWw==}
+ deprecated: Use @eslint/object-schema instead
'@inquirer/checkbox@2.4.5':
resolution: {integrity: sha512-+YlCyS6JBWeZugIvReh/YL5HJcowlklz5RykQuYKQfgWQeCJh5Us0nWcRddvIVkjmYa0I/8bwWioSLu850J8sA==}
@@ -17182,6 +17064,7 @@ packages:
'@koa/router@10.1.1':
resolution: {integrity: sha512-ORNjq5z4EmQPriKbR0ER3k4Gh7YGNhWDL7JBW+8wXDrHLbWYKYSJaOJ9aN06npF5tbTxe2JBOsurpJDAvjiXKw==}
engines: {node: '>= 8.0.0'}
+ deprecated: '**IMPORTANT 10x+ PERFORMANCE UPGRADE**: Please upgrade to v12.0.1+ as we have fixed an issue with debuglog causing 10x slower router benchmark performance, see https://github.com/koajs/router/pull/173'
'@kubernetes-models/apimachinery@1.1.0':
resolution: {integrity: sha512-DvCNeou3+M5ESJluVs8daVp7g03/hWnwXHou9Se8qNRZpqH6lQHvRjXy6HWSqBV9fKZOnWcOExmkUPQGbVIa6A==}
@@ -17345,6 +17228,7 @@ packages:
'@npmcli/move-file@1.1.2':
resolution: {integrity: sha512-1SUf/Cg2GzGDyaf15aR9St9TWlb+XvbZXWpDx8YKs7MLzMH/BCeopv+y9vzrzgkfykCGuWOlSu3mZhj2+FQcrg==}
engines: {node: '>=10'}
+ deprecated: This functionality has been moved to @npmcli/fs
'@npmcli/node-gyp@3.0.0':
resolution: {integrity: sha512-gp8pRXC2oOxu0DUE1/M3bYtb1b3/DbJ5aM113+XJBgfXdussRAsX0YOrOhdd8WvnAR6auDBvJomGAkLKA5ydxA==}
@@ -20134,6 +20018,7 @@ packages:
abab@2.0.5:
resolution: {integrity: sha512-9IK9EadsbHo6jLWIpxpR6pL0sazTXV6+SQv25ZB+F7Bj9mJNaOc4nCRabwd5M/JwmUa8idz6Eci6eKfJryPs6Q==}
+ deprecated: Use your platform's native atob() and btoa() methods instead
abab@2.0.6:
resolution: {integrity: sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA==}
@@ -20461,6 +20346,7 @@ packages:
are-we-there-yet@2.0.0:
resolution: {integrity: sha512-Ci/qENmwHnsYo9xKIcUJN5LeDKdJ6R1Z1j9V/J5wyq8nh/mYPEpIKJbBZXtZjG04HiK7zV/p6Vs9952MrMeUIw==}
engines: {node: '>=10'}
+ deprecated: This package is no longer supported.
arg@2.0.0:
resolution: {integrity: sha512-XxNTUzKnz1ctK3ZIcI2XUPlD96wbHP2nGqkPKpvk/HNRlPveYrXIVSTk9m3LcqOgDPg3B1nMvdV/K8wZd7PG4w==}
@@ -21615,6 +21501,10 @@ packages:
resolution: {integrity: sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw==}
engines: {node: '>= 0.6'}
+ cookie@0.7.1:
+ resolution: {integrity: sha512-6DnInpx7SJ2AK3+CTUE/ZM0vWTUboZCegxhC2xiIydHR9jNuTAASBrfEpHhiGOZw/nX51bHt6YQl8jsGo4y/0w==}
+ engines: {node: '>= 0.6'}
+
cookiejar@2.1.4:
resolution: {integrity: sha512-LDx6oHrK+PhzLKJU9j5S7/Y3jM/mUHvD/DeI1WQmJn652iPC5Y4TBzC9l+5OMOXlyTTA+SmVUPm0HQUwpD5Jqw==}
@@ -23008,6 +22898,7 @@ packages:
eslint@8.52.0:
resolution: {integrity: sha512-zh/JHnaixqHZsolRB/w9/02akBk9EPrOs9JwcTP2ek7yL5bVvXuRariiaAjjoJ5DvuwQ1WAE/HsMz+w17YgBCg==}
engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0}
+ deprecated: This version is no longer supported. Please see https://eslint.org/version-support for other options.
hasBin: true
espree@9.6.1:
@@ -23133,8 +23024,8 @@ packages:
resolution: {integrity: sha512-5T6nhjsT+EOMzuck8JjBHARTHfMht0POzlA60WV2pMD3gyXw2LZnZ+ueGdNxG+0calOJcWKbpFcuzLZ91YWq9Q==}
engines: {node: '>= 0.10.0'}
- express@4.21.0:
- resolution: {integrity: sha512-VqcNGcj/Id5ZT1LZ/cfihi3ttTn+NJmkli2eZADigjq29qTlWi/hAQ43t/VLPq8+UX06FCEx3ByOYet6ZFblng==}
+ express@4.21.1:
+ resolution: {integrity: sha512-YSFlK1Ee0/GC8QaO91tHcDxJiE/X4FbpAyQWkxAvG6AXCuR65YzK8ua6D9hvi/TzUfZMpc+BwuM1IPw8fmQBiQ==}
engines: {node: '>= 0.10.0'}
extend-shallow@2.0.1:
@@ -23313,7 +23204,7 @@ packages:
webpack: ^5.0.0
filename-reserved-regex@2.0.0:
- resolution: {integrity: sha1-q/c9+rc10EVECr/qLZHzieu/oik=}
+ resolution: {integrity: sha512-lc1bnsSr4L4Bdif8Xb/qrtokGbq5zlsms/CYH8PP+WtCkGNF65DPiQY8vG3SakEdRn8Dlnm+gW/qWKKjS5sZzQ==}
engines: {node: '>=4'}
filenamify@4.3.0:
@@ -23563,6 +23454,7 @@ packages:
gauge@4.0.0:
resolution: {integrity: sha512-F8sU45yQpjQjxKkm1UOAhf0U/O0aFt//Fl7hsrNVto+patMHjs7dPI9mFOGUKbhrgKm0S3EjW3scMFuQmWSROw==}
engines: {node: ^12.13.0 || ^14.15.0 || >=16}
+ deprecated: This package is no longer supported.
gensync@1.0.0-beta.2:
resolution: {integrity: sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==}
@@ -23684,6 +23576,7 @@ packages:
glob@7.2.0:
resolution: {integrity: sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==}
+ deprecated: Glob versions prior to v9 are no longer supported
glob@7.2.3:
resolution: {integrity: sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==}
@@ -23898,7 +23791,7 @@ packages:
resolution: {integrity: sha512-H/vuk5TEEVZwrR0lp2zed9OCo1uAILMlx0JEMgC26rzyJJ3N1v6XkwHHXJQdR2doSjcGPM6OKPYoJgf0plJ11Q==}
heatmap.js@2.0.5:
- resolution: {integrity: sha1-Rm07hlE/XUkRKknSVwCrJzAUkVM=}
+ resolution: {integrity: sha512-CG2gYFP5Cv9IQCXEg3ZRxnJDyAilhWnQlAuHYGuWVzv6mFtQelS1bR9iN80IyDmFECbFPbg6I0LR5uAFHgCthw==}
hexoid@1.0.0:
resolution: {integrity: sha512-QFLV0taWQOZtvIRIAdBChesmogZrtuXvVWsFHZTk2SU+anspqZ2vMnoLg7IE1+Uk16N19APic1BuF8bC8c2m5g==}
@@ -25784,12 +25677,6 @@ packages:
resolution: {integrity: sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==}
engines: {node: '>=4'}
- mini-css-extract-plugin@2.8.1:
- resolution: {integrity: sha512-/1HDlyFRxWIZPI1ZpgqlZ8jMw/1Dp/dl3P0L1jtZ+zVcHqwPhGwaJwKL00WVgfnBy6PWCde9W65or7IIETImuA==}
- engines: {node: '>= 12.13.0'}
- peerDependencies:
- webpack: ^5.0.0
-
mini-css-extract-plugin@2.9.0:
resolution: {integrity: sha512-Zs1YsZVfemekSZG+44vBsYTLQORkPMwnlv+aehcxK/NLKC+EGhDB39/YePYYqx/sTk6NnYpuqikhSn7+JIevTA==}
engines: {node: '>= 12.13.0'}
@@ -26275,6 +26162,7 @@ packages:
npmlog@6.0.0:
resolution: {integrity: sha512-03ppFRGlsyUaQFbGC2C8QWJN/C/K7PsfyD9aQdhVKAQIH4sQBc8WASqFBP7O+Ut4d2oo5LoeoboB3cGdBZSp6Q==}
engines: {node: ^12.13.0 || ^14.15.0 || >=16}
+ deprecated: This package is no longer supported.
nth-check@2.0.1:
resolution: {integrity: sha512-it1vE95zF6dTT9lBsYbxvqh0Soy4SPowchj0UBGj/V6cTPnXXtQOPUbhZ6CmGzAD/rW22LQK6E96pcdJXk4A4w==}
@@ -27282,6 +27170,7 @@ packages:
puppeteer@13.1.2:
resolution: {integrity: sha512-ozVM8Tdg0patMtm/xAr3Uh7rQ28vBpbTHLP+ECmoAxG/s4PKrVLN764H/poLux7Ln77jHThOd8OBJj5mTuA6Iw==}
engines: {node: '>=10.18.1'}
+ deprecated: < 22.8.2 is no longer supported
pure-color@1.3.0:
resolution: {integrity: sha512-QFADYnsVoBMw1srW7OVKEYjG+MbIa49s54w1MA1EDY6r2r/sTcKKYqRX1f4GYvnXP7eN/Pe9HFcX+hwzmrXRHA==}
@@ -27299,6 +27188,10 @@ packages:
q@1.5.1:
resolution: {integrity: sha512-kV/CThkXo6xyFEZUugw/+pIOywXcDbFYgSct5cT3gqlbkBE1SJdwy6UQoZvodiWF/ckQLZyDE/Bu1M6gVu5lVw==}
engines: {node: '>=0.6.0', teleport: '>=0.2.0'}
+ deprecated: |-
+ You or someone you depend on is using Q, the JavaScript Promise library that gave JavaScript developers strong feelings about promises. They can almost certainly migrate to the native JavaScript promise now. Thank you literally everyone for joining me in this bet against the odds. Be excellent to each other.
+
+ (For a CapTP with native promises, see @endo/eventual-send and @endo/captp)
qjobs@1.2.0:
resolution: {integrity: sha512-8YOJEHtxpySA3fFDyCRxA+UUV+fA+rTWnuWvylOK/NCjhY+b4ocCtmu8TtsWb+mYeU+GCHf/S66KZF/AsteKHg==}
@@ -27378,6 +27271,7 @@ packages:
rdk@6.5.0:
resolution: {integrity: sha512-Jrv4YFVH07JI03wxwsQhosypdyqOHirzNU0pfmteIfylhSpaIi8VnAp3MbznD3/ZKZyt6YRj0kMtQopTwIxMUw==}
+ deprecated: 'deprecated: use reablocks instead'
peerDependencies:
react: '>=16'
react-dom: '>=16'
@@ -27490,8 +27384,8 @@ packages:
peerDependencies:
react: '>=16.13.1'
- react-error-boundary@4.0.12:
- resolution: {integrity: sha512-kJdxdEYlb7CPC1A0SeUY38cHpjuu6UkvzKiAmqmOFL21VRfMhOcWxTCBgLVCO0VEMh9JhFNcVaXlV4/BTpiwOA==}
+ react-error-boundary@4.0.13:
+ resolution: {integrity: sha512-b6PwbdSv8XeOSYvjt8LpgpKrZ0yGdtZokYwkwV2wlcZbxgopHX/hgPl5VgpnoVOWd868n1hktM8Qm4b+02MiLQ==}
peerDependencies:
react: '>=16.13.1'
@@ -28070,6 +27964,7 @@ packages:
right-pad@1.0.1:
resolution: {integrity: sha512-bYBjgxmkvTAfgIYy328fmkwhp39v8lwVgWhhrzxPV3yHtcSqyYKe9/XOhvW48UFjATg3VuJbpsp5822ACNvkmw==}
engines: {node: '>= 0.10'}
+ deprecated: Please use String.prototype.padEnd() over this package.
rimraf@2.5.4:
resolution: {integrity: sha512-Lw7SHMjssciQb/rRz7JyPIy9+bbUshEucPoLRvWqy09vC5zQixl8Uet+Zl+SROBB/JMWHJRdCk1qdxNWHNMvlQ==}
@@ -28083,6 +27978,7 @@ packages:
rimraf@2.7.1:
resolution: {integrity: sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==}
+ deprecated: Rimraf versions prior to v4 are no longer supported
hasBin: true
rimraf@3.0.2:
@@ -28465,6 +28361,7 @@ packages:
sinon@11.1.1:
resolution: {integrity: sha512-ZSSmlkSyhUWbkF01Z9tEbxZLF/5tRC9eojCdFh33gtQaP7ITQVaMWQHGuFM7Cuf/KEfihuh1tTl3/ABju3AQMg==}
+ deprecated: 16.1.1
sirv@2.0.4:
resolution: {integrity: sha512-94Bdh3cC2PKrbgSOUqTiGPWVZeSiXfKOVZNJniWoqrWrRkB1CJzBU3NEbiTsPcYy1lDsANA/THzS+9WBiy5nfQ==}
@@ -28899,7 +28796,7 @@ packages:
superagent@7.1.6:
resolution: {integrity: sha512-gZkVCQR1gy/oUXr+kxJMLDjla434KmSOKbx5iGD30Ql+AkJQ/YlPKECJy2nhqOsHLjGHzoDTXNSjhnvWhzKk7g==}
engines: {node: '>=6.4.0 <13 || >=14'}
- deprecated: Please downgrade to v7.1.5 if you need IE/ActiveXObject support OR upgrade to v8.0.0 as we no longer support IE and published an incorrect patch version (see https://github.com/visionmedia/superagent/issues/1731)
+ deprecated: Please upgrade to v9.0.0+ as we have fixed a public vulnerability with formidable dependency. Note that v9.0.0+ requires Node.js v14.18.0+. See https://github.com/ladjs/superagent/pull/1800 for insight. This project is supported and maintained by the team at Forward Email @ https://forwardemail.net
supports-color@5.5.0:
resolution: {integrity: sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==}
@@ -29029,7 +28926,7 @@ packages:
engines: {node: '>=0.8.0'}
temp@0.4.0:
- resolution: {integrity: sha1-ZxrWPVe+D+nXKUZks/xABjZnimA=}
+ resolution: {integrity: sha512-IsFisGgDKk7qzK9erMIkQe/XwiSUdac7z3wYOsjcLkhPBy3k1SlvLoIh2dAHIlEpgA971CgguMrx9z8fFg7tSA==}
engines: {'0': node >=0.4.0}
temp@0.8.4:
@@ -29243,7 +29140,7 @@ packages:
engines: {node: '>=0.6'}
trim-repeated@1.0.0:
- resolution: {integrity: sha1-42RqLqTokTEr9+rObPsFOAvAHCE=}
+ resolution: {integrity: sha512-pkonvlKk8/ZuR0D5tLW8ljt5I8kmxp2XKymhepUeOdCEfKpZaktSArkLHZt76OB1ZvO9bssUsDty4SWhLvZpLg==}
engines: {node: '>=0.10.0'}
truncate-utf8-bytes@1.0.2:
@@ -29478,6 +29375,7 @@ packages:
uid-number@0.0.6:
resolution: {integrity: sha512-c461FXIljswCuscZn67xq9PpszkPT6RjheWFQTgCyabJrTUozElanb0YEqv2UGgk247YpcJkFBuSGNvBlpXM9w==}
+ deprecated: This package is no longer supported.
umask@1.1.0:
resolution: {integrity: sha512-lE/rxOhmiScJu9L6RTNVgB/zZbF+vGC0/p6D3xnkAePI2o0sMyFG966iR5Ki50OI/0mNi2yaRnxfLsPmEZF/JA==}
@@ -30558,7 +30456,7 @@ snapshots:
dependencies:
'@ampproject/remapping': 2.3.0
'@angular-devkit/architect': 0.1801.3(chokidar@3.6.0)
- '@angular-devkit/build-webpack': 0.1801.3(chokidar@3.6.0)(webpack-dev-server@5.0.4(webpack@5.94.0))(webpack@5.92.1(esbuild@0.21.5))
+ '@angular-devkit/build-webpack': 0.1801.3(chokidar@3.6.0)(webpack-dev-server@5.0.4(webpack@5.92.1(esbuild@0.21.5)))(webpack@5.92.1(esbuild@0.21.5))
'@angular-devkit/core': 18.1.3(chokidar@3.6.0)
'@angular/build': 18.1.3(@angular/compiler-cli@18.1.3(@angular/compiler@18.1.3(@angular/core@18.1.3(rxjs@7.5.2)(zone.js@0.14.8)))(typescript@5.5.3))(@types/node@22.5.2)(chokidar@3.6.0)(less@4.2.0)(postcss@8.4.38)(stylus@0.59.0)(terser@5.29.2)(typescript@5.5.3)
'@angular/compiler-cli': 18.1.3(@angular/compiler@18.1.3(@angular/core@18.1.3(rxjs@7.5.2)(zone.js@0.14.8)))(typescript@5.5.3)
@@ -30644,7 +30542,7 @@ snapshots:
- utf-8-validate
- webpack-cli
- '@angular-devkit/build-webpack@0.1801.3(chokidar@3.6.0)(webpack-dev-server@5.0.4(webpack@5.94.0))(webpack@5.92.1(esbuild@0.21.5))':
+ '@angular-devkit/build-webpack@0.1801.3(chokidar@3.6.0)(webpack-dev-server@5.0.4(webpack@5.92.1(esbuild@0.21.5)))(webpack@5.92.1(esbuild@0.21.5))':
dependencies:
'@angular-devkit/architect': 0.1801.3(chokidar@3.6.0)
rxjs: 7.8.1
@@ -31040,7 +30938,7 @@ snapshots:
'@babel/core': 7.24.9
'@babel/generator': 7.23.6
'@babel/parser': 7.23.9
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@babel/traverse': 7.23.9
'@babel/types': 7.23.9
babel-preset-fbjs: 3.4.0(@babel/core@7.24.9)
@@ -36642,7 +36540,7 @@ snapshots:
'@babel/helper-split-export-declaration': 7.22.6
'@babel/parser': 7.23.9
'@babel/types': 7.23.9
- debug: 4.3.5
+ debug: 4.3.6
globals: 11.12.0
transitivePeerDependencies:
- supports-color
@@ -39420,15 +39318,15 @@ snapshots:
'@radix-ui/number@1.0.1':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/primitive@1.0.1':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/react-arrow@1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
react: 17.0.2
react-dom: 17.0.2(react@17.0.2)
@@ -39438,7 +39336,7 @@ snapshots:
'@radix-ui/react-collection@1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/react-compose-refs': 1.0.1(@types/react@17.0.21)(react@17.0.2)
'@radix-ui/react-context': 1.0.1(@types/react@17.0.21)(react@17.0.2)
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
@@ -39451,28 +39349,28 @@ snapshots:
'@radix-ui/react-compose-refs@1.0.1(@types/react@17.0.21)(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
react: 17.0.2
optionalDependencies:
'@types/react': 17.0.21
'@radix-ui/react-context@1.0.1(@types/react@17.0.21)(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
react: 17.0.2
optionalDependencies:
'@types/react': 17.0.21
'@radix-ui/react-direction@1.0.1(@types/react@17.0.21)(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
react: 17.0.2
optionalDependencies:
'@types/react': 17.0.21
'@radix-ui/react-dismissable-layer@1.0.4(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/primitive': 1.0.1
'@radix-ui/react-compose-refs': 1.0.1(@types/react@17.0.21)(react@17.0.2)
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
@@ -39486,14 +39384,14 @@ snapshots:
'@radix-ui/react-focus-guards@1.0.1(@types/react@17.0.21)(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
react: 17.0.2
optionalDependencies:
'@types/react': 17.0.21
'@radix-ui/react-focus-scope@1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/react-compose-refs': 1.0.1(@types/react@17.0.21)(react@17.0.2)
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
'@radix-ui/react-use-callback-ref': 1.0.1(@types/react@17.0.21)(react@17.0.2)
@@ -39505,7 +39403,7 @@ snapshots:
'@radix-ui/react-id@1.0.1(@types/react@17.0.21)(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/react-use-layout-effect': 1.0.1(@types/react@17.0.21)(react@17.0.2)
react: 17.0.2
optionalDependencies:
@@ -39513,7 +39411,7 @@ snapshots:
'@radix-ui/react-popper@1.1.2(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@floating-ui/react-dom': 2.0.2(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
'@radix-ui/react-arrow': 1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
'@radix-ui/react-compose-refs': 1.0.1(@types/react@17.0.21)(react@17.0.2)
@@ -39532,7 +39430,7 @@ snapshots:
'@radix-ui/react-portal@1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
react: 17.0.2
react-dom: 17.0.2(react@17.0.2)
@@ -39542,7 +39440,7 @@ snapshots:
'@radix-ui/react-primitive@1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/react-slot': 1.0.2(@types/react@17.0.21)(react@17.0.2)
react: 17.0.2
react-dom: 17.0.2(react@17.0.2)
@@ -39552,7 +39450,7 @@ snapshots:
'@radix-ui/react-roving-focus@1.0.4(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/primitive': 1.0.1
'@radix-ui/react-collection': 1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
'@radix-ui/react-compose-refs': 1.0.1(@types/react@17.0.21)(react@17.0.2)
@@ -39570,7 +39468,7 @@ snapshots:
'@radix-ui/react-select@1.2.2(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/number': 1.0.1
'@radix-ui/primitive': 1.0.1
'@radix-ui/react-collection': 1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
@@ -39600,7 +39498,7 @@ snapshots:
'@radix-ui/react-separator@1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
react: 17.0.2
react-dom: 17.0.2(react@17.0.2)
@@ -39610,7 +39508,7 @@ snapshots:
'@radix-ui/react-slot@1.0.2(@types/react@17.0.21)(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/react-compose-refs': 1.0.1(@types/react@17.0.21)(react@17.0.2)
react: 17.0.2
optionalDependencies:
@@ -39618,7 +39516,7 @@ snapshots:
'@radix-ui/react-toggle-group@1.0.4(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/primitive': 1.0.1
'@radix-ui/react-context': 1.0.1(@types/react@17.0.21)(react@17.0.2)
'@radix-ui/react-direction': 1.0.1(@types/react@17.0.21)(react@17.0.2)
@@ -39634,7 +39532,7 @@ snapshots:
'@radix-ui/react-toggle@1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/primitive': 1.0.1
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
'@radix-ui/react-use-controllable-state': 1.0.1(@types/react@17.0.21)(react@17.0.2)
@@ -39646,7 +39544,7 @@ snapshots:
'@radix-ui/react-toolbar@1.0.4(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/primitive': 1.0.1
'@radix-ui/react-context': 1.0.1(@types/react@17.0.21)(react@17.0.2)
'@radix-ui/react-direction': 1.0.1(@types/react@17.0.21)(react@17.0.2)
@@ -39662,14 +39560,14 @@ snapshots:
'@radix-ui/react-use-callback-ref@1.0.1(@types/react@17.0.21)(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
react: 17.0.2
optionalDependencies:
'@types/react': 17.0.21
'@radix-ui/react-use-controllable-state@1.0.1(@types/react@17.0.21)(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/react-use-callback-ref': 1.0.1(@types/react@17.0.21)(react@17.0.2)
react: 17.0.2
optionalDependencies:
@@ -39677,7 +39575,7 @@ snapshots:
'@radix-ui/react-use-escape-keydown@1.0.3(@types/react@17.0.21)(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/react-use-callback-ref': 1.0.1(@types/react@17.0.21)(react@17.0.2)
react: 17.0.2
optionalDependencies:
@@ -39685,21 +39583,21 @@ snapshots:
'@radix-ui/react-use-layout-effect@1.0.1(@types/react@17.0.21)(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
react: 17.0.2
optionalDependencies:
'@types/react': 17.0.21
'@radix-ui/react-use-previous@1.0.1(@types/react@17.0.21)(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
react: 17.0.2
optionalDependencies:
'@types/react': 17.0.21
'@radix-ui/react-use-rect@1.0.1(@types/react@17.0.21)(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/rect': 1.0.1
react: 17.0.2
optionalDependencies:
@@ -39707,7 +39605,7 @@ snapshots:
'@radix-ui/react-use-size@1.0.1(@types/react@17.0.21)(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/react-use-layout-effect': 1.0.1(@types/react@17.0.21)(react@17.0.2)
react: 17.0.2
optionalDependencies:
@@ -39715,7 +39613,7 @@ snapshots:
'@radix-ui/react-visually-hidden@1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@17.0.8)(@types/react@17.0.21)(react-dom@17.0.2(react@17.0.2))(react@17.0.2)
react: 17.0.2
react-dom: 17.0.2(react@17.0.2)
@@ -39725,7 +39623,7 @@ snapshots:
'@radix-ui/rect@1.0.1':
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
'@reactflow/background@11.3.6(@types/react@17.0.21)(immer@10.0.3(patch_hash=utu5oov26wz5mjuays57tp3ybu))(react-dom@17.0.2(react@17.0.2))(react@17.0.2)':
dependencies:
@@ -40335,7 +40233,7 @@ snapshots:
ejs: 3.1.9
esbuild: 0.18.20
esbuild-plugin-alias: 0.2.1
- express: 4.21.0
+ express: 4.21.1
find-cache-dir: 3.3.1
fs-extra: 11.2.0
process: 0.11.10
@@ -40357,7 +40255,7 @@ snapshots:
ejs: 3.1.9
esbuild: 0.18.20
esbuild-plugin-alias: 0.2.1
- express: 4.21.0
+ express: 4.21.1
find-cache-dir: 3.3.1
fs-extra: 11.2.0
process: 0.11.10
@@ -40379,7 +40277,7 @@ snapshots:
ejs: 3.1.9
esbuild: 0.18.20
esbuild-plugin-alias: 0.2.1
- express: 4.21.0
+ express: 4.21.1
find-cache-dir: 3.3.1
fs-extra: 11.2.0
process: 0.11.10
@@ -40416,7 +40314,7 @@ snapshots:
case-sensitive-paths-webpack-plugin: 2.4.0
constants-browserify: 1.0.0
css-loader: 6.7.1(webpack@5.94.0(@swc/core@1.3.92)(esbuild@0.18.20))
- express: 4.21.0
+ express: 4.21.1
fork-ts-checker-webpack-plugin: 8.0.0(typescript@5.5.3)(webpack@5.94.0(@swc/core@1.3.92)(esbuild@0.18.20))
fs-extra: 11.1.1
html-webpack-plugin: 5.5.3(webpack@5.94.0(@swc/core@1.3.92)(esbuild@0.18.20))
@@ -40476,7 +40374,7 @@ snapshots:
case-sensitive-paths-webpack-plugin: 2.4.0
constants-browserify: 1.0.0
css-loader: 6.7.1(webpack@5.94.0(@swc/core@1.3.92)(esbuild@0.18.20)(webpack-cli@4.10.0))
- express: 4.21.0
+ express: 4.21.1
fork-ts-checker-webpack-plugin: 8.0.0(typescript@5.5.3)(webpack@5.94.0(@swc/core@1.3.92)(esbuild@0.18.20)(webpack-cli@4.10.0))
fs-extra: 11.1.1
html-webpack-plugin: 5.5.3(webpack@5.94.0(@swc/core@1.3.92)(esbuild@0.18.20)(webpack-cli@4.10.0))
@@ -40529,7 +40427,7 @@ snapshots:
constants-browserify: 1.0.0
css-loader: 6.7.1(webpack@5.94.0(@swc/core@1.3.92)(esbuild@0.18.20)(webpack-cli@4.10.0))
es-module-lexer: 1.4.1
- express: 4.21.0
+ express: 4.21.1
fork-ts-checker-webpack-plugin: 8.0.0(typescript@5.5.3)(webpack@5.94.0(@swc/core@1.3.92)(esbuild@0.18.20)(webpack-cli@4.10.0))
fs-extra: 11.1.1
html-webpack-plugin: 5.5.3(webpack@5.94.0(@swc/core@1.3.92)(esbuild@0.18.20)(webpack-cli@4.10.0))
@@ -40579,7 +40477,7 @@ snapshots:
constants-browserify: 1.0.0
css-loader: 6.7.1(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0(webpack-bundle-analyzer@4.10.2)(webpack-dev-server@4.15.1)(webpack@5.94.0)))
es-module-lexer: 1.4.1
- express: 4.21.0
+ express: 4.21.1
fork-ts-checker-webpack-plugin: 8.0.0(typescript@5.5.3)(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0(webpack-bundle-analyzer@4.10.2)(webpack-dev-server@4.15.1)(webpack@5.94.0)))
fs-extra: 11.1.1
html-webpack-plugin: 5.5.3(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0(webpack-bundle-analyzer@4.10.2)(webpack-dev-server@4.15.1)(webpack@5.94.0)))
@@ -40629,7 +40527,7 @@ snapshots:
constants-browserify: 1.0.0
css-loader: 6.7.1(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0(webpack-dev-server@4.15.1)(webpack@5.94.0)))
es-module-lexer: 1.4.1
- express: 4.21.0
+ express: 4.21.1
fork-ts-checker-webpack-plugin: 8.0.0(typescript@5.5.3)(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0(webpack-dev-server@4.15.1)(webpack@5.94.0)))
fs-extra: 11.1.1
html-webpack-plugin: 5.5.3(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0(webpack-dev-server@4.15.1)(webpack@5.94.0)))
@@ -40672,7 +40570,7 @@ snapshots:
'@storybook/client-logger': 7.6.13
'@storybook/core-events': 7.6.13
'@storybook/global': 5.0.0
- qs: 6.11.2
+ qs: 6.13.0
telejson: 7.2.0
tiny-invariant: 1.3.1
@@ -40699,7 +40597,7 @@ snapshots:
detect-indent: 6.1.0
envinfo: 7.8.1
execa: 5.1.1
- express: 4.21.0
+ express: 4.21.1
find-up: 5.0.0
fs-extra: 11.1.1
get-npm-tarball-url: 2.0.3
@@ -40748,7 +40646,7 @@ snapshots:
detect-indent: 6.1.0
envinfo: 7.8.1
execa: 5.1.1
- express: 4.21.0
+ express: 4.21.1
find-up: 5.0.0
fs-extra: 11.1.1
get-npm-tarball-url: 2.0.3
@@ -40797,7 +40695,7 @@ snapshots:
detect-indent: 6.1.0
envinfo: 7.8.1
execa: 5.1.1
- express: 4.21.0
+ express: 4.21.1
find-up: 5.0.0
fs-extra: 11.1.1
get-npm-tarball-url: 2.0.3
@@ -41040,7 +40938,7 @@ snapshots:
cli-table3: 0.6.1
compression: 1.7.4
detect-port: 1.5.1
- express: 4.21.0
+ express: 4.21.1
fs-extra: 11.2.0
globby: 11.1.0
ip: 2.0.0
@@ -41089,7 +40987,7 @@ snapshots:
cli-table3: 0.6.1
compression: 1.7.4
detect-port: 1.5.1
- express: 4.21.0
+ express: 4.21.1
fs-extra: 11.2.0
globby: 11.1.0
ip: 2.0.0
@@ -41138,7 +41036,7 @@ snapshots:
cli-table3: 0.6.1
compression: 1.7.4
detect-port: 1.5.1
- express: 4.21.0
+ express: 4.21.1
fs-extra: 11.2.0
globby: 11.1.0
ip: 2.0.0
@@ -41847,7 +41745,7 @@ snapshots:
dependencies:
'@storybook/client-logger': 7.6.13
memoizerific: 1.11.3
- qs: 6.11.2
+ qs: 6.13.0
'@storybook/store@7.4.6':
dependencies:
@@ -43619,7 +43517,7 @@ snapshots:
agentkeepalive@4.1.4:
dependencies:
- debug: 4.3.4
+ debug: 4.3.6
depd: 1.1.2
humanize-ms: 1.2.1
transitivePeerDependencies:
@@ -43858,7 +43756,7 @@ snapshots:
dependencies:
graphql: 14.3.1
- apollo-server-express@3.13.0(encoding@0.1.13)(express@4.21.0)(graphql@14.3.1):
+ apollo-server-express@3.13.0(encoding@0.1.13)(express@4.21.1)(graphql@14.3.1):
dependencies:
'@types/accepts': 1.3.7
'@types/body-parser': 1.19.2
@@ -43870,7 +43768,7 @@ snapshots:
apollo-server-types: 3.8.0(encoding@0.1.13)(graphql@14.3.1)
body-parser: 1.20.3
cors: 2.8.5
- express: 4.21.0
+ express: 4.21.1
graphql: 14.3.1
parseurl: 1.3.3
transitivePeerDependencies:
@@ -44389,7 +44287,7 @@ snapshots:
babel-plugin-macros@2.8.0:
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
cosmiconfig: 6.0.0
resolve: 1.22.8
@@ -45802,6 +45700,8 @@ snapshots:
cookie@0.6.0: {}
+ cookie@0.7.1: {}
+
cookiejar@2.1.4: {}
cookies@0.8.0:
@@ -46670,7 +46570,7 @@ snapshots:
date-fns@2.30.0:
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
date-format@4.0.3: {}
@@ -46821,7 +46721,7 @@ snapshots:
object-keys: 1.1.1
object.assign: 4.1.5
regexp.prototype.flags: 1.5.2
- side-channel: 1.0.4
+ side-channel: 1.0.6
which-boxed-primitive: 1.0.2
which-collection: 1.0.1
which-typed-array: 1.1.15
@@ -47016,7 +46916,7 @@ snapshots:
dom-helpers@5.2.0:
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
csstype: 3.0.11
dom-serialize@2.2.1:
@@ -47945,9 +47845,9 @@ snapshots:
exponential-backoff@3.1.1: {}
- express-rate-limit@7.4.0(express@4.21.0):
+ express-rate-limit@7.4.0(express@4.21.1):
dependencies:
- express: 4.21.0
+ express: 4.21.1
express@4.19.2:
dependencies:
@@ -47985,14 +47885,14 @@ snapshots:
transitivePeerDependencies:
- supports-color
- express@4.21.0:
+ express@4.21.1:
dependencies:
accepts: 1.3.8
array-flatten: 1.1.1
body-parser: 1.20.3
content-disposition: 0.5.4
content-type: 1.0.5
- cookie: 0.6.0
+ cookie: 0.7.1
cookie-signature: 1.0.6
debug: 2.6.9
depd: 2.0.0
@@ -48530,7 +48430,7 @@ snapshots:
dezalgo: 1.0.4
hexoid: 1.0.0
once: 1.4.0
- qs: 6.11.2
+ qs: 6.13.0
forwarded@0.2.0: {}
@@ -49066,7 +48966,7 @@ snapshots:
history@5.3.0:
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
hmac-drbg@1.0.1:
dependencies:
@@ -49520,7 +49420,7 @@ snapshots:
dependencies:
es-errors: 1.3.0
hasown: 2.0.2
- side-channel: 1.0.4
+ side-channel: 1.0.6
internmap@1.0.1: {}
@@ -51913,12 +51813,6 @@ snapshots:
min-indent@1.0.1: {}
- mini-css-extract-plugin@2.8.1(webpack@5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0)):
- dependencies:
- schema-utils: 4.2.0
- tapable: 2.2.1
- webpack: 5.94.0(@swc/core@1.3.92)(webpack-cli@4.10.0)
-
mini-css-extract-plugin@2.9.0(webpack@5.92.1(esbuild@0.21.5)):
dependencies:
schema-utils: 4.2.0
@@ -53668,7 +53562,7 @@ snapshots:
qs@6.10.4:
dependencies:
- side-channel: 1.0.4
+ side-channel: 1.0.6
qs@6.11.0:
dependencies:
@@ -53890,7 +53784,7 @@ snapshots:
dependencies:
'@babel/core': 7.24.9
'@babel/generator': 7.23.6
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
ast-types: 0.14.2
commander: 2.20.3
doctrine: 3.0.0
@@ -53963,9 +53857,9 @@ snapshots:
'@babel/runtime': 7.23.6
react: 17.0.2
- react-error-boundary@4.0.12(react@17.0.2):
+ react-error-boundary@4.0.13(react@17.0.2):
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
react: 17.0.2
react-fast-compare@2.0.4: {}
@@ -54420,11 +54314,11 @@ snapshots:
regenerator-transform@0.15.1:
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
regenerator-transform@0.15.2:
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
regex-not@1.0.2:
dependencies:
@@ -54468,7 +54362,7 @@ snapshots:
relay-runtime@12.0.0(encoding@0.1.13):
dependencies:
- '@babel/runtime': 7.23.6
+ '@babel/runtime': 7.24.7
fbjs: 3.0.2(encoding@0.1.13)
invariant: 2.2.4
transitivePeerDependencies:
@@ -55272,7 +55166,7 @@ snapshots:
socks-proxy-agent@6.1.1:
dependencies:
agent-base: 6.0.2
- debug: 4.3.4
+ debug: 4.3.6
socks: 2.6.1
transitivePeerDependencies:
- supports-color
@@ -55739,7 +55633,7 @@ snapshots:
formidable: 2.1.1
methods: 1.1.2
mime: 2.6.0
- qs: 6.11.2
+ qs: 6.13.0
readable-stream: 3.6.0
semver: 7.5.4
transitivePeerDependencies:
@@ -55798,9 +55692,9 @@ snapshots:
swagger-ui-dist@5.11.2: {}
- swagger-ui-express@5.0.0(express@4.21.0):
+ swagger-ui-express@5.0.0(express@4.21.1):
dependencies:
- express: 4.21.0
+ express: 4.21.1
swagger-ui-dist: 5.11.2
swap-case@2.0.2:
@@ -57742,7 +57636,7 @@ snapshots:
compression: 1.7.4
connect-history-api-fallback: 2.0.0
default-gateway: 6.0.3
- express: 4.21.0
+ express: 4.21.1
graceful-fs: 4.2.11
html-entities: 2.5.2
http-proxy-middleware: 2.0.6(@types/express@4.17.21)
diff --git a/repo/MANUAL.md b/repo/MANUAL.md
index 5e8f1cf340d..f283ede6f04 100644
--- a/repo/MANUAL.md
+++ b/repo/MANUAL.md
@@ -198,7 +198,7 @@ A few scripts are available for general purpose usage on `kie-tools`. They're bu
- [sparse-checkout](../scripts/sparse-checkout/README.md): Partially clone `kie-tools` and work on a subset of its packages.
- Mostly used by our automations
- [check-junit-report-results](../scripts/check-junit-report-results/README.md): Checks JUnit XML files to see if tests failed. Used on our CI.
- - [update-kogito-version](../scripts/update-kogito-version/README.md): Updates the version of Kogito Maven dependencies. (E.g., `999-20240912-SNAPSHOT`, `999-SNAPSHOT` or `10.0.0`)
+ - [update-kogito-version](../scripts/update-kogito-version/README.md): Updates the version of Kogito Maven dependencies. (E.g., `999-20241016-SNAPSHOT`, `999-SNAPSHOT` or `10.0.0`)
- [update-stream-name](../scripts/update-stream-name/README.md): Updates this repo's stream name. (E.g., `main` or `10.0.x`)
- [update-version](../scripts/update-version/README.md): Updates this repo's version (E.g., `0.0.0` or `10.0.999`)
diff --git a/repo/graph.dot b/repo/graph.dot
index 0ddae736b2b..46b184fa133 100644
--- a/repo/graph.dot
+++ b/repo/graph.dot
@@ -25,7 +25,6 @@ digraph G {
"@kie-tools/jbpm-quarkus-devui" [ color = "black", fontcolor = "black", style = "dashed, rounded" ];
"@kie-tools-examples/jbpm-compact-architecture-example" [ color = "orange", fontcolor = "orange", style = "dashed, rounded" ];
"@kie-tools/kogito-management-console" [ color = "black", fontcolor = "black", style = "dashed, rounded" ];
- "@kie-tools/kogito-task-console" [ color = "black", fontcolor = "black", style = "dashed, rounded" ];
"@kie-tools-examples/ping-pong-view" [ color = "orange", fontcolor = "orange", style = "dashed, rounded" ];
"@kie-tools-core/envelope" [ color = "purple", fontcolor = "purple", style = "rounded" ];
"@kie-tools-examples/ping-pong-view-angular" [ color = "orange", fontcolor = "orange", style = "dashed, rounded" ];
@@ -149,7 +148,6 @@ digraph G {
"@kie/kogito-jobs-service-ephemeral-image" [ color = "black", fontcolor = "black", style = "dashed, rounded" ];
"@kie/kogito-jobs-service-postgresql-image" [ color = "black", fontcolor = "black", style = "dashed, rounded" ];
"@kie-tools/runtime-tools-management-console-webapp" [ color = "blue", fontcolor = "blue", style = "rounded" ];
- "@kie-tools/runtime-tools-task-console-webapp" [ color = "blue", fontcolor = "blue", style = "rounded" ];
"@kie-tools-core/kubernetes-bridge" [ color = "purple", fontcolor = "purple", style = "rounded" ];
"@kie-tools-core/workspace" [ color = "purple", fontcolor = "purple", style = "rounded" ];
"@kie-tools/unitables-dmn" [ color = "blue", fontcolor = "blue", style = "rounded" ];
@@ -168,6 +166,7 @@ digraph G {
"@kie-tools/runtime-tools-swf-webapp-components" [ color = "blue", fontcolor = "blue", style = "rounded" ];
"@kie-tools/scesim-editor" [ color = "blue", fontcolor = "blue", style = "rounded" ];
"@kie-tools/scesim-marshaller" [ color = "blue", fontcolor = "blue", style = "rounded" ];
+ "@kie-tools/scesim-editor-envelope" [ color = "blue", fontcolor = "blue", style = "rounded" ];
"@kie-tools/serverless-logic-web-tools" [ color = "black", fontcolor = "black", style = "dashed, rounded" ];
"@kie-tools/text-editor" [ color = "blue", fontcolor = "blue", style = "rounded" ];
"@kie-tools/yard-editor" [ color = "blue", fontcolor = "blue", style = "rounded" ];
@@ -226,7 +225,6 @@ digraph G {
"@kie-tools-examples/drools-process-usertasks-quarkus-example" -> "@kie-tools/jbpm-quarkus-devui" [ style = "solid", color = "orange" ];
"@kie-tools-examples/jbpm-compact-architecture-example" -> "@kie-tools/jbpm-quarkus-devui" [ style = "solid", color = "orange" ];
"@kie-tools-examples/jbpm-compact-architecture-example" -> "@kie-tools/kogito-management-console" [ style = "dashed", color = "orange" ];
- "@kie-tools-examples/jbpm-compact-architecture-example" -> "@kie-tools/kogito-task-console" [ style = "dashed", color = "orange" ];
"@kie-tools-examples/ping-pong-view" -> "@kie-tools-core/envelope" [ style = "solid", color = "orange" ];
"@kie-tools-examples/ping-pong-view-angular" -> "@kie-tools-examples/ping-pong-view" [ style = "solid", color = "orange" ];
"@kie-tools-examples/ping-pong-view-react" -> "@kie-tools-examples/ping-pong-view" [ style = "solid", color = "orange" ];
@@ -445,18 +443,21 @@ digraph G {
"@kie-tools/kie-sandbox-webapp-image" -> "@kie-tools/image-builder" [ style = "dashed", color = "black" ];
"@kie-tools/kn-plugin-workflow" -> "@kie-tools/sonataflow-operator" [ style = "dashed", color = "black" ];
"@kie/kogito-base-builder-image" -> "@kie-tools/sonataflow-image-common" [ style = "dashed", color = "black" ];
+ "@kie/kogito-data-index-ephemeral-image" -> "@kie-tools/maven-base" [ style = "dashed", color = "black" ];
"@kie/kogito-data-index-ephemeral-image" -> "@kie-tools/sonataflow-image-common" [ style = "dashed", color = "black" ];
+ "@kie/kogito-data-index-postgresql-image" -> "@kie-tools/maven-base" [ style = "dashed", color = "black" ];
"@kie/kogito-data-index-postgresql-image" -> "@kie-tools/sonataflow-image-common" [ style = "dashed", color = "black" ];
+ "@kie/kogito-jit-runner-image" -> "@kie-tools/maven-base" [ style = "dashed", color = "black" ];
"@kie/kogito-jit-runner-image" -> "@kie-tools/sonataflow-image-common" [ style = "dashed", color = "black" ];
+ "@kie/kogito-jobs-service-allinone-image" -> "@kie-tools/maven-base" [ style = "dashed", color = "black" ];
"@kie/kogito-jobs-service-allinone-image" -> "@kie-tools/sonataflow-image-common" [ style = "dashed", color = "black" ];
+ "@kie/kogito-jobs-service-ephemeral-image" -> "@kie-tools/maven-base" [ style = "dashed", color = "black" ];
"@kie/kogito-jobs-service-ephemeral-image" -> "@kie-tools/sonataflow-image-common" [ style = "dashed", color = "black" ];
+ "@kie/kogito-jobs-service-postgresql-image" -> "@kie-tools/maven-base" [ style = "dashed", color = "black" ];
"@kie/kogito-jobs-service-postgresql-image" -> "@kie-tools/sonataflow-image-common" [ style = "dashed", color = "black" ];
"@kie-tools/kogito-management-console" -> "@kie-tools/image-builder" [ style = "dashed", color = "black" ];
"@kie-tools/kogito-management-console" -> "@kie-tools/image-env-to-json" [ style = "dashed", color = "black" ];
"@kie-tools/kogito-management-console" -> "@kie-tools/runtime-tools-management-console-webapp" [ style = "dashed", color = "black" ];
- "@kie-tools/kogito-task-console" -> "@kie-tools/image-builder" [ style = "dashed", color = "black" ];
- "@kie-tools/kogito-task-console" -> "@kie-tools/image-env-to-json" [ style = "dashed", color = "black" ];
- "@kie-tools/kogito-task-console" -> "@kie-tools/runtime-tools-task-console-webapp" [ style = "dashed", color = "black" ];
"@kie-tools-core/kubernetes-bridge" -> "@kie-tools/cors-proxy-api" [ style = "solid", color = "purple" ];
"@kie-tools/maven-base" -> "@kie-tools/root-env" [ style = "dashed", color = "black" ];
"@kie-tools/maven-m2-repo-via-http-image" -> "@kie-tools/image-builder" [ style = "dashed", color = "black" ];
@@ -499,7 +500,6 @@ digraph G {
"@kie-tools/runtime-tools-components" -> "@kie-tools/runtime-tools-shared-gateway-api" [ style = "solid", color = "blue" ];
"@kie-tools/runtime-tools-components" -> "@kie-tools/uniforms-patternfly" [ style = "solid", color = "blue" ];
"@kie-tools/runtime-tools-consoles-helm-chart" -> "@kie-tools/kogito-management-console" [ style = "solid", color = "black" ];
- "@kie-tools/runtime-tools-consoles-helm-chart" -> "@kie-tools/kogito-task-console" [ style = "solid", color = "black" ];
"@kie-tools/runtime-tools-management-console-webapp" -> "@kie-tools/runtime-tools-process-webapp-components" [ style = "solid", color = "blue" ];
"@kie-tools/runtime-tools-management-console-webapp" -> "@kie-tools/runtime-tools-shared-webapp-components" [ style = "solid", color = "blue" ];
"@kie-tools/runtime-tools-process-dev-ui-webapp" -> "@kie-tools/runtime-tools-process-webapp-components" [ style = "solid", color = "blue" ];
@@ -523,11 +523,11 @@ digraph G {
"@kie-tools/runtime-tools-swf-gateway-api" -> "@kie-tools/runtime-tools-shared-gateway-api" [ style = "solid", color = "blue" ];
"@kie-tools/runtime-tools-swf-gateway-api" -> "@kie-tools/jest-base" [ style = "dashed", color = "blue" ];
"@kie-tools/runtime-tools-swf-webapp-components" -> "@kie-tools/runtime-tools-swf-enveloped-components" [ style = "solid", color = "blue" ];
- "@kie-tools/runtime-tools-task-console-webapp" -> "@kie-tools-core/react-hooks" [ style = "solid", color = "blue" ];
- "@kie-tools/runtime-tools-task-console-webapp" -> "@kie-tools/runtime-tools-process-webapp-components" [ style = "solid", color = "blue" ];
- "@kie-tools/runtime-tools-task-console-webapp" -> "@kie-tools/runtime-tools-shared-webapp-components" [ style = "solid", color = "blue" ];
"@kie-tools/scesim-editor" -> "@kie-tools/boxed-expression-component" [ style = "solid", color = "blue" ];
"@kie-tools/scesim-editor" -> "@kie-tools/scesim-marshaller" [ style = "solid", color = "blue" ];
+ "@kie-tools/scesim-editor-envelope" -> "@kie-tools-core/editor" [ style = "solid", color = "blue" ];
+ "@kie-tools/scesim-editor-envelope" -> "@kie-tools-core/react-hooks" [ style = "solid", color = "blue" ];
+ "@kie-tools/scesim-editor-envelope" -> "@kie-tools/scesim-editor" [ style = "solid", color = "blue" ];
"@kie-tools/scesim-marshaller" -> "@kie-tools/xml-parser-ts-codegen" [ style = "dashed", color = "blue" ];
"@kie-tools/serverless-logic-web-tools" -> "@kie-tools-core/kubernetes-bridge" [ style = "solid", color = "black" ];
"@kie-tools/serverless-logic-web-tools" -> "@kie-tools-core/workspaces-git-fs" [ style = "solid", color = "black" ];
diff --git a/repo/graph.json b/repo/graph.json
index f5b94a13645..3e1949c32b0 100644
--- a/repo/graph.json
+++ b/repo/graph.json
@@ -34,11 +34,9 @@
{ "id": "@kie-tools/runtime-tools-process-dev-ui-webapp" },
{ "id": "@kie-tools-examples/jbpm-compact-architecture-example" },
{ "id": "@kie-tools/kogito-management-console" },
- { "id": "@kie-tools/kogito-task-console" },
{ "id": "@kie-tools/image-builder" },
{ "id": "@kie-tools/image-env-to-json" },
{ "id": "@kie-tools/runtime-tools-management-console-webapp" },
- { "id": "@kie-tools/runtime-tools-task-console-webapp" },
{ "id": "@kie-tools-examples/ping-pong-view" },
{ "id": "@kie-tools-core/envelope-bus" },
{ "id": "@kie-tools-examples/ping-pong-view-angular" },
@@ -176,6 +174,7 @@
{ "id": "@kie-tools/runtime-tools-swf-webapp-components" },
{ "id": "@kie-tools/scesim-editor" },
{ "id": "@kie-tools/scesim-marshaller" },
+ { "id": "@kie-tools/scesim-editor-envelope" },
{ "id": "@kie-tools/serverless-logic-web-tools" },
{ "id": "@kie-tools/text-editor" },
{ "id": "@kie-tools/yard-editor" },
@@ -440,11 +439,6 @@
"target": "@kie-tools/kogito-management-console",
"weight": 1
},
- {
- "source": "@kie-tools-examples/jbpm-compact-architecture-example",
- "target": "@kie-tools/kogito-task-console",
- "weight": 1
- },
{
"source": "@kie-tools/kogito-management-console",
"target": "@kie-tools/image-builder",
@@ -460,21 +454,6 @@
"target": "@kie-tools/runtime-tools-management-console-webapp",
"weight": 1
},
- {
- "source": "@kie-tools/kogito-task-console",
- "target": "@kie-tools/image-builder",
- "weight": 1
- },
- {
- "source": "@kie-tools/kogito-task-console",
- "target": "@kie-tools/image-env-to-json",
- "weight": 1
- },
- {
- "source": "@kie-tools/kogito-task-console",
- "target": "@kie-tools/runtime-tools-task-console-webapp",
- "weight": 1
- },
{
"source": "@kie-tools/image-builder",
"target": "@kie-tools/tsconfig",
@@ -505,21 +484,6 @@
"target": "@kie-tools/runtime-tools-shared-webapp-components",
"weight": 1
},
- {
- "source": "@kie-tools/runtime-tools-task-console-webapp",
- "target": "@kie-tools-core/react-hooks",
- "weight": 1
- },
- {
- "source": "@kie-tools/runtime-tools-task-console-webapp",
- "target": "@kie-tools/runtime-tools-process-webapp-components",
- "weight": 1
- },
- {
- "source": "@kie-tools/runtime-tools-task-console-webapp",
- "target": "@kie-tools/runtime-tools-shared-webapp-components",
- "weight": 1
- },
{
"source": "@kie-tools-examples/ping-pong-view",
"target": "@kie-tools-core/envelope",
@@ -1955,21 +1919,41 @@
"target": "@kie-tools/sonataflow-quarkus-devui",
"weight": 1
},
+ {
+ "source": "@kie/kogito-data-index-ephemeral-image",
+ "target": "@kie-tools/maven-base",
+ "weight": 1
+ },
{
"source": "@kie/kogito-data-index-ephemeral-image",
"target": "@kie-tools/sonataflow-image-common",
"weight": 1
},
+ {
+ "source": "@kie/kogito-data-index-postgresql-image",
+ "target": "@kie-tools/maven-base",
+ "weight": 1
+ },
{
"source": "@kie/kogito-data-index-postgresql-image",
"target": "@kie-tools/sonataflow-image-common",
"weight": 1
},
+ {
+ "source": "@kie/kogito-jobs-service-ephemeral-image",
+ "target": "@kie-tools/maven-base",
+ "weight": 1
+ },
{
"source": "@kie/kogito-jobs-service-ephemeral-image",
"target": "@kie-tools/sonataflow-image-common",
"weight": 1
},
+ {
+ "source": "@kie/kogito-jobs-service-postgresql-image",
+ "target": "@kie-tools/maven-base",
+ "weight": 1
+ },
{
"source": "@kie/kogito-jobs-service-postgresql-image",
"target": "@kie-tools/sonataflow-image-common",
@@ -1990,11 +1974,21 @@
"target": "@kie-tools/root-env",
"weight": 1
},
+ {
+ "source": "@kie/kogito-jit-runner-image",
+ "target": "@kie-tools/maven-base",
+ "weight": 1
+ },
{
"source": "@kie/kogito-jit-runner-image",
"target": "@kie-tools/sonataflow-image-common",
"weight": 1
},
+ {
+ "source": "@kie/kogito-jobs-service-allinone-image",
+ "target": "@kie-tools/maven-base",
+ "weight": 1
+ },
{
"source": "@kie/kogito-jobs-service-allinone-image",
"target": "@kie-tools/sonataflow-image-common",
@@ -2060,11 +2054,6 @@
"target": "@kie-tools/kogito-management-console",
"weight": 1
},
- {
- "source": "@kie-tools/runtime-tools-consoles-helm-chart",
- "target": "@kie-tools/kogito-task-console",
- "weight": 1
- },
{
"source": "@kie-tools/runtime-tools-process-enveloped-components",
"target": "@kie-tools/runtime-tools-process-gateway-api",
@@ -2150,6 +2139,21 @@
"target": "@kie-tools/xml-parser-ts-codegen",
"weight": 1
},
+ {
+ "source": "@kie-tools/scesim-editor-envelope",
+ "target": "@kie-tools-core/editor",
+ "weight": 1
+ },
+ {
+ "source": "@kie-tools/scesim-editor-envelope",
+ "target": "@kie-tools-core/react-hooks",
+ "weight": 1
+ },
+ {
+ "source": "@kie-tools/scesim-editor-envelope",
+ "target": "@kie-tools/scesim-editor",
+ "weight": 1
+ },
{
"source": "@kie-tools/serverless-logic-web-tools",
"target": "@kie-tools-core/kubernetes-bridge",
@@ -2661,7 +2665,6 @@
["@kie/kogito-jobs-service-ephemeral-image", "packages/kogito-jobs-service-ephemeral-image"],
["@kie/kogito-jobs-service-postgresql-image", "packages/kogito-jobs-service-postgresql-image"],
["@kie-tools/kogito-management-console", "packages/kogito-management-console"],
- ["@kie-tools/kogito-task-console", "packages/kogito-task-console"],
["@kie-tools-core/kubernetes-bridge", "packages/kubernetes-bridge"],
["@kie-tools/maven-base", "packages/maven-base"],
["@kie-tools/maven-m2-repo-via-http-image", "packages/maven-m2-repo-via-http-image"],
@@ -2690,8 +2693,8 @@
["@kie-tools/runtime-tools-swf-enveloped-components", "packages/runtime-tools-swf-enveloped-components"],
["@kie-tools/runtime-tools-swf-gateway-api", "packages/runtime-tools-swf-gateway-api"],
["@kie-tools/runtime-tools-swf-webapp-components", "packages/runtime-tools-swf-webapp-components"],
- ["@kie-tools/runtime-tools-task-console-webapp", "packages/runtime-tools-task-console-webapp"],
["@kie-tools/scesim-editor", "packages/scesim-editor"],
+ ["@kie-tools/scesim-editor-envelope", "packages/scesim-editor-envelope"],
["@kie-tools/scesim-marshaller", "packages/scesim-marshaller"],
["@kie-tools/serverless-logic-web-tools", "packages/serverless-logic-web-tools"],
[