abdul-react 0.0.34 → 0.0.36
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/ComponentProps/TreeNodeProps.d.ts +1 -0
- package/lib/_virtual/index10.js +2 -2
- package/lib/_virtual/index11.js +2 -2
- package/lib/assets/icons/mac_white_icon.svg.js +6 -0
- package/lib/assets/icons/mac_white_icon.svg.js.map +1 -0
- package/lib/assets/icons/maximize_livetesting.svg.js +6 -0
- package/lib/assets/icons/maximize_livetesting.svg.js.map +1 -0
- package/lib/assets/icons/minimize_tree.svg.js +6 -0
- package/lib/assets/icons/minimize_tree.svg.js.map +1 -0
- package/lib/assets/icons/timer_icon.svg.js +6 -0
- package/lib/assets/icons/timer_icon.svg.js.map +1 -0
- package/lib/assets/icons/view_access_icon.svg.js +1 -1
- package/lib/assets/icons/view_access_icon.svg.js.map +1 -1
- package/lib/assets/icons/windows_blue_icon.svg.js +6 -0
- package/lib/assets/icons/windows_blue_icon.svg.js.map +1 -0
- package/lib/components/AllProjectsDropdown/AllProjectsDropdown.js +53 -13
- package/lib/components/AllProjectsDropdown/AllProjectsDropdown.js.map +1 -1
- package/lib/components/AppHeader/AppHeader.js +36 -3
- package/lib/components/AppHeader/AppHeader.js.map +1 -1
- package/lib/components/AppHeader/types.d.ts +11 -0
- package/lib/components/ConditionalDropdown/ConditionalDropdown.js +17 -5
- package/lib/components/ConditionalDropdown/ConditionalDropdown.js.map +1 -1
- package/lib/components/ConditionalDropdown/OptionsDropdown.js +16 -6
- package/lib/components/ConditionalDropdown/OptionsDropdown.js.map +1 -1
- package/lib/components/ConditionalDropdown/types.d.ts +12 -0
- package/lib/components/CreateVariable/CreateVariableSlider.js +3 -2
- package/lib/components/CreateVariable/CreateVariableSlider.js.map +1 -1
- package/lib/components/CreateVariable/types.d.ts +3 -2
- package/lib/components/Drawer/Drawer.js +7 -4
- package/lib/components/Drawer/Drawer.js.map +1 -1
- package/lib/components/EditLabel/EditLabel.js +2 -2
- package/lib/components/EditLabel/EditLabel.js.map +1 -1
- package/lib/components/Editor/Editor.js +8 -3
- package/lib/components/Editor/Editor.js.map +1 -1
- package/lib/components/Editor/VariableDropdown.js +7 -7
- package/lib/components/Editor/VariableDropdown.js.map +1 -1
- package/lib/components/Editor/types.d.ts +8 -0
- package/lib/components/Excel/Data.d.ts +8 -60
- package/lib/components/Excel/Data.js +50 -18
- package/lib/components/Excel/Data.js.map +1 -1
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/ActiveCell.js +2 -0
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/ActiveCell.js.map +1 -1
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/Cell.js +2 -1
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/Cell.js.map +1 -1
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/ColumnIndicator.js +8 -9
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/ColumnIndicator.js.map +1 -1
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/DataEditor.js +45 -2
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/DataEditor.js.map +1 -1
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/RowIndicator.js +7 -6
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/RowIndicator.js.map +1 -1
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/actions.d.ts +17 -1
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/actions.js +21 -1
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/actions.js.map +1 -1
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/reducer.js +349 -38
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/reducer.js.map +1 -1
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/util.d.ts +4 -0
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/util.js +43 -1
- package/lib/components/Excel/ExcelFile/ExcelFileComponents/util.js.map +1 -1
- package/lib/components/Excel/Types.d.ts +2 -0
- package/lib/components/Excel/dataConversion.js +6 -2
- package/lib/components/Excel/dataConversion.js.map +1 -1
- package/lib/components/Icon/iconList.js +16 -6
- package/lib/components/Icon/iconList.js.map +1 -1
- package/lib/components/NLPInput/NlpInput.js +1 -1
- package/lib/components/NLPInput/components/NlpDropDown/NlpDropdown.js +1 -1
- package/lib/components/NLPInput/components/NlpDropDown/NlpDropdown.js.map +1 -1
- package/lib/components/Prompt/Prompt.js +2 -1
- package/lib/components/Prompt/Prompt.js.map +1 -1
- package/lib/components/SequentialConnectingBranch/SequentialConnectingBranch.js +14 -9
- package/lib/components/SequentialConnectingBranch/SequentialConnectingBranch.js.map +1 -1
- package/lib/components/StepsLandingTable/Components/StepGroupAccordions.js +92 -69
- package/lib/components/StepsLandingTable/Components/StepGroupAccordions.js.map +1 -1
- package/lib/components/StepsLandingTable/Components/StepInnerTable.d.ts +1 -1
- package/lib/components/StepsLandingTable/Components/StepInnerTable.js +187 -15
- package/lib/components/StepsLandingTable/Components/StepInnerTable.js.map +1 -1
- package/lib/components/StepsLandingTable/Components/StepTableMainRow.js +20 -4
- package/lib/components/StepsLandingTable/Components/StepTableMainRow.js.map +1 -1
- package/lib/components/StepsLandingTable/Components/Types.d.ts +6 -0
- package/lib/components/StepsLandingTable/StepLandingTable.js +7 -3
- package/lib/components/StepsLandingTable/StepLandingTable.js.map +1 -1
- package/lib/components/StepsLandingTable/types.d.ts +2 -0
- package/lib/components/Table/Table.js +184 -42
- package/lib/components/Table/Table.js.map +1 -1
- package/lib/components/TableWithAccordion/TableWithAccordion.js +4 -3
- package/lib/components/TableWithAccordion/TableWithAccordion.js.map +1 -1
- package/lib/components/variableSuggestionInputDropDown/OptionsDropdown.js +7 -5
- package/lib/components/variableSuggestionInputDropDown/OptionsDropdown.js.map +1 -1
- package/lib/components/variableSuggestionInputDropDown/VariableSuggestionInputDropDown.js +1 -1
- package/lib/index.cjs +1158 -254
- package/lib/index.cjs.map +1 -1
- package/lib/index.d.ts +30 -1
- package/lib/node_modules/js-beautify/js/src/css/beautifier.js +1 -1
- package/lib/node_modules/js-beautify/js/src/css/options.js +1 -1
- package/lib/node_modules/js-beautify/js/src/html/beautifier.js +1 -1
- package/lib/node_modules/js-beautify/js/src/html/index.js +1 -1
- package/lib/node_modules/js-beautify/js/src/html/options.js +1 -1
- package/lib/node_modules/js-beautify/js/src/html/tokenizer.js +1 -1
- package/lib/node_modules/js-beautify/js/src/javascript/index.js +1 -1
- package/lib/node_modules/js-beautify/js/src/javascript/options.js +1 -1
- package/lib/node_modules/js-beautify/js/src/javascript/tokenizer.js +1 -1
- package/lib/styles.css +1 -1
- package/lib/styles.css.map +1 -1
- package/package.json +1 -1
package/lib/index.cjs
CHANGED
|
@@ -426,7 +426,7 @@ const SvgNoAccessIcon = (props) => /* @__PURE__ */ React__namespace.createElemen
|
|
|
426
426
|
|
|
427
427
|
const SvgFullAccessIcon = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("path", { d: "M14.3023 1.71582C14.0651 1.7172 13.838 1.81245 13.6708 1.98077C13.6708 1.98077 9.91509 5.72922 7.63431 8.00848L6.02693 6.40109C5.67669 6.05175 5.1098 6.05175 4.75956 6.40109C4.41022 6.75132 4.41022 7.31822 4.75956 7.66845L7.00284 9.91173C7.35309 10.261 7.91995 10.261 8.2702 9.91173C10.3923 7.79041 14.9382 3.24814 14.9382 3.24814C15.2875 2.8979 15.2875 2.33101 14.9382 1.98077C14.7699 1.81138 14.5411 1.71603 14.3023 1.71582Z", fill: "currentColor" }), /* @__PURE__ */ React__namespace.createElement("path", { d: "M8.00172 1C4.14578 1.00003 1 4.14236 1 7.99832C1 11.8542 4.14578 15 8.00172 15C11.166 15 13.944 12.8676 14.763 9.8111C14.9214 9.22021 15 8.61007 15 7.99832C15 7.51546 14.6089 7.12387 14.1261 7.12323C13.6432 7.12387 13.2521 7.51546 13.2521 7.99832C13.2521 8.45716 13.1897 8.91556 13.071 9.35875C12.4548 11.6582 10.3823 13.2521 8.00172 13.2522C5.09163 13.2521 2.74786 10.9084 2.74786 7.99832C2.74786 5.08823 5.09162 2.74788 8.00172 2.74788C8.46061 2.74791 8.91551 2.81042 9.35875 2.92902C9.82555 3.05418 10.3054 2.77725 10.4306 2.31044C10.4307 2.31004 10.4308 2.3096 10.4309 2.30919C10.5561 1.84238 10.2791 1.36252 9.81234 1.23736C9.81192 1.23726 9.81152 1.23712 9.8111 1.23702C9.22011 1.07869 8.61357 1.00003 8.00172 1Z", fill: "currentColor" }));
|
|
428
428
|
|
|
429
|
-
const SvgViewAccessIcon = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 16
|
|
429
|
+
const SvgViewAccessIcon = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 16 12", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M14.8985 6.29701C13.5046 8.80023 10.861 10.3552 8.00093 10.3552C5.13896 10.3552 2.49546 8.80023 1.10149 6.29701C0.994127 6.10264 0.994127 5.89717 1.10149 5.70297C2.49546 3.19978 5.13896 1.64494 8.00093 1.64494C10.861 1.64494 13.5045 3.19978 14.8985 5.70297C15.0078 5.89717 15.0078 6.10264 14.8985 6.29701ZM15.789 5.20666C14.2154 2.38043 11.2313 0.624939 8.00093 0.624939C4.76871 0.624939 1.78457 2.38043 0.211039 5.20666C-0.0703464 5.71093 -0.0703464 6.28905 0.211039 6.79295C1.78457 9.61918 4.76871 11.375 8.00093 11.375C11.2313 11.375 14.2154 9.61918 15.789 6.79295C16.0703 6.28909 16.0703 5.71093 15.789 5.20666ZM8.00093 8.09231C9.15424 8.09231 10.0928 7.15375 10.0928 5.99991C10.0928 4.84606 9.15424 3.9075 8.00093 3.9075C6.84576 3.9075 5.9072 4.84606 5.9072 5.99991C5.9072 7.15375 6.8458 8.09231 8.00093 8.09231ZM8.00093 2.88749C6.28299 2.88749 4.8872 4.28386 4.8872 5.99994C4.8872 7.71639 6.28303 9.11218 8.00093 9.11218C9.71701 9.11218 11.1128 7.71636 11.1128 5.99994C11.1128 4.28386 9.71701 2.88749 8.00093 2.88749Z", fill: "currentColor" }));
|
|
430
430
|
|
|
431
431
|
const SvgHideAccessIcon = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 16 12", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M3.71305 9.66393C5.04428 10.4052 6.50768 10.7961 7.94891 10.7961H8.00016C9.00732 10.803 10.0251 10.6177 11.002 10.2561L12.2785 11.5326C12.3944 11.6486 12.5463 11.7067 12.6985 11.7067C12.8507 11.7067 13.0026 11.6486 13.1185 11.5326C13.3504 11.3008 13.3504 10.9248 13.1185 10.693L2.89276 0.467238C2.66089 0.235367 2.28496 0.235367 2.05308 0.467238C1.82121 0.699108 1.82121 1.07504 2.05308 1.30691L2.82682 2.08064C1.84059 2.78094 0.969356 3.67405 0.272807 4.70528C-0.0909357 5.24433 -0.0909357 5.94088 0.272807 6.48025C1.17123 7.81053 2.36089 8.91145 3.71274 9.66424L3.71305 9.66393ZM7.92234 7.17586C7.10986 7.13617 6.45644 6.48274 6.41675 5.67026L7.92234 7.17586ZM1.25716 5.36933C1.91277 4.39841 2.74182 3.56718 3.68024 2.93375L5.39333 4.64684C5.28583 4.94215 5.2274 5.26027 5.2274 5.59214C5.2274 7.12117 6.47144 8.36521 8.00047 8.36521C8.33234 8.36521 8.65045 8.30646 8.94576 8.19896L10.0629 9.31613C9.3995 9.50894 8.72233 9.60831 8.05203 9.60831H8.00484H7.99672C6.7408 9.61675 5.46083 9.27738 4.29117 8.62645C3.10119 7.96397 2.05215 6.9918 1.25779 5.81557C1.16623 5.67995 1.16623 5.50495 1.25779 5.36964L1.25716 5.36933ZM9.58103 5.47651L10.6163 6.51181C10.7179 6.224 10.7732 5.91463 10.7732 5.59245C10.7732 4.06342 9.52916 2.81938 8.00012 2.81938C7.67794 2.81938 7.36857 2.87469 7.08077 2.97625L8.11606 4.01154C8.89792 4.06842 9.52416 4.69465 9.58103 5.47651ZM12.2875 1.52096C13.6394 2.27376 14.8291 3.37468 15.7275 4.70497L15.7272 4.70465C16.0909 5.2437 16.0909 5.94025 15.7272 6.47931C15.0356 7.50335 14.1716 8.39114 13.1938 9.08925L12.341 8.23646C13.2706 7.60491 14.0922 6.77867 14.7431 5.81494C14.8347 5.67963 14.8347 5.50464 14.7431 5.36901C13.9488 4.19279 12.8997 3.22062 11.7097 2.55813C10.5401 1.90721 9.25854 1.5669 8.00419 1.57628H7.99606H7.94888C7.28764 1.57628 6.61953 1.67284 5.96485 1.86033L5.02393 0.919414C5.97673 0.570046 6.96796 0.3888 7.94888 0.3888H8.00013H8.05137C9.49291 0.3888 10.9563 0.779729 12.2875 1.52096Z", fill: "currentColor" }));
|
|
432
432
|
|
|
@@ -1936,11 +1936,11 @@ const SvgAdbShell = (props) => /* @__PURE__ */ React__namespace.createElement("s
|
|
|
1936
1936
|
|
|
1937
1937
|
const SvgUiInspector = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 16 16", fill: "currentColor", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M15.1663 8.33337V3.33337C15.1663 1.95271 14.047 0.833374 12.6663 0.833374C10.149 0.833374 5.85034 0.833374 3.33301 0.833374C1.95234 0.833374 0.833008 1.95271 0.833008 3.33337V12.6667C0.833008 14.0474 1.95234 15.1667 3.33301 15.1667H8.33301C8.60901 15.1667 8.83301 14.9427 8.83301 14.6667C8.83301 14.3907 8.60901 14.1667 8.33301 14.1667H3.33301C2.50434 14.1667 1.83301 13.4954 1.83301 12.6667V3.33337C1.83301 2.50471 2.50434 1.83337 3.33301 1.83337H12.6663C13.495 1.83337 14.1663 2.50471 14.1663 3.33337V8.33337C14.1663 8.60937 14.3903 8.83337 14.6663 8.83337C14.9423 8.83337 15.1663 8.60937 15.1663 8.33337Z", fill: "currentColor" }), /* @__PURE__ */ React__namespace.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M14.6663 4.16675H1.33301C1.05701 4.16675 0.833008 4.39075 0.833008 4.66675C0.833008 4.94275 1.05701 5.16675 1.33301 5.16675H14.6663C14.9423 5.16675 15.1663 4.94275 15.1663 4.66675C15.1663 4.39075 14.9423 4.16675 14.6663 4.16675Z", fill: "currentColor" }), /* @__PURE__ */ React__namespace.createElement("path", { d: "M8.5 3.5C8.77614 3.5 9 3.27614 9 3C9 2.72386 8.77614 2.5 8.5 2.5C8.22386 2.5 8 2.72386 8 3C8 3.27614 8.22386 3.5 8.5 3.5Z", fill: "currentColor" }), /* @__PURE__ */ React__namespace.createElement("path", { d: "M10.333 3.5C10.6092 3.5 10.833 3.27614 10.833 3C10.833 2.72386 10.6092 2.5 10.333 2.5C10.0569 2.5 9.83301 2.72386 9.83301 3C9.83301 3.27614 10.0569 3.5 10.333 3.5Z", fill: "currentColor" }), /* @__PURE__ */ React__namespace.createElement("path", { d: "M12.166 3.5C12.4422 3.5 12.666 3.27614 12.666 3C12.666 2.72386 12.4422 2.5 12.166 2.5C11.8899 2.5 11.666 2.72386 11.666 3C11.666 3.27614 11.8899 3.5 12.166 3.5Z", fill: "currentColor" }), /* @__PURE__ */ React__namespace.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M10.666 7.16675C8.73402 7.16675 7.16602 8.73475 7.16602 10.6667C7.16602 12.5987 8.73402 14.1667 10.666 14.1667C12.598 14.1667 14.166 12.5987 14.166 10.6667C14.166 8.73475 12.598 7.16675 10.666 7.16675ZM10.666 8.16675C12.046 8.16675 13.166 9.28675 13.166 10.6667C13.166 12.0467 12.046 13.1667 10.666 13.1667C9.28602 13.1667 8.16602 12.0467 8.16602 10.6667C8.16602 9.28675 9.28602 8.16675 10.666 8.16675Z", fill: "currentColor" }), /* @__PURE__ */ React__namespace.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M12.6465 13.3534L14.3132 15.0201C14.5078 15.2154 14.8252 15.2154 15.0198 15.0201C15.2152 14.8254 15.2152 14.5081 15.0198 14.3134L13.3532 12.6467C13.1585 12.4514 12.8412 12.4514 12.6465 12.6467C12.4512 12.8414 12.4512 13.1587 12.6465 13.3534Z", fill: "currentColor" }));
|
|
1938
1938
|
|
|
1939
|
-
const
|
|
1939
|
+
const SvgTimerIcon = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("path", { d: "M14.9827 3.53063L13.3034 1.85125C13.0593 1.60716 12.6635 1.60716 12.4195 1.85125C12.1754 2.09534 12.1754 2.49106 12.4195 2.73513L12.8172 3.13287L12.0015 3.94856C10.9397 3.06275 9.64867 2.528 8.27148 2.40353V1.25H8.83398C9.17917 1.25 9.45898 0.970187 9.45898 0.625C9.45898 0.279813 9.17917 0 8.83398 0H6.45898C6.1138 0 5.83398 0.279813 5.83398 0.625C5.83398 0.970187 6.1138 1.25 6.45898 1.25H7.02148V2.40353C3.59261 2.71341 0.833984 5.59275 0.833984 9.1875C0.833984 12.9526 3.88089 16 7.64648 16C11.4115 16 14.459 12.9531 14.459 9.1875C14.459 7.57778 13.9041 6.05356 12.8854 4.83244L13.7011 4.01675L14.0989 4.4145C14.3429 4.65856 14.7386 4.65859 14.9827 4.4145C15.2268 4.17044 15.2268 3.77472 14.9827 3.53063ZM7.64648 14.75C4.57933 14.75 2.08398 12.2547 2.08398 9.1875C2.08398 6.12034 4.57933 3.625 7.64648 3.625C10.7136 3.625 13.209 6.12034 13.209 9.1875C13.209 12.2547 10.7137 14.75 7.64648 14.75ZM10.8941 9.1875C10.8941 9.53269 10.6143 9.8125 10.2691 9.8125H7.64652C7.30133 9.8125 7.02152 9.53269 7.02152 9.1875V5.51016C7.02152 5.16497 7.30133 4.88516 7.64652 4.88516C7.9917 4.88516 8.27152 5.16497 8.27152 5.51016V8.5625H10.2691C10.6143 8.5625 10.8941 8.84231 10.8941 9.1875Z", fill: "white" }));
|
|
1940
1940
|
|
|
1941
|
-
const
|
|
1941
|
+
const SvgMaximizeLivetesting = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 18 18", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("path", { d: "M16.418 0.900391C16.463 0.900408 16.5078 0.904749 16.5508 0.913086H16.5518C16.5655 0.915934 16.578 0.919968 16.5869 0.922852C16.5974 0.926251 16.6025 0.928007 16.6084 0.929688L16.6787 0.952148L16.6777 0.953125L16.7432 0.985352L16.7637 0.996094C16.772 1.00039 16.7831 1.00675 16.7949 1.01465C16.87 1.06446 16.9347 1.12881 16.9844 1.20312C16.9925 1.21517 16.9986 1.22697 17.0029 1.23535L17.0127 1.25488L17.0137 1.25586C17.0204 1.26803 17.0362 1.29485 17.0469 1.32031L17.0479 1.32129C17.0582 1.34671 17.0655 1.37669 17.0693 1.38965L17.0859 1.44824V1.44922C17.0942 1.49237 17.0996 1.53688 17.0996 1.58203V5.07227C17.0996 5.44854 16.7946 5.75475 16.418 5.75488C16.0416 5.75488 15.7363 5.44866 15.7363 5.07227V3.22656L11.6631 7.2998C11.5301 7.43308 11.3559 7.49993 11.1816 7.5C11.0508 7.5 10.9192 7.4628 10.8057 7.3877L10.6992 7.2998C10.4332 7.03353 10.4331 6.6021 10.6992 6.33594L14.7715 2.26367H12.9268C12.5505 2.26364 12.2452 1.95831 12.2451 1.58203C12.2451 1.20566 12.5504 0.900419 12.9268 0.900391H16.418Z", fill: "white", stroke: "white", strokeWidth: 0.2 }), /* @__PURE__ */ React__namespace.createElement("path", { d: "M6.33594 10.6995C6.60181 10.4333 7.03381 10.4335 7.2998 10.6995C7.56606 10.9657 7.56606 11.3971 7.2998 11.6633L3.22656 15.7366H5.07227C5.44866 15.7366 5.75488 16.0418 5.75488 16.4182C5.75475 16.7945 5.44857 17.0999 5.07227 17.0999H1.58203C1.53681 17.0999 1.49193 17.0949 1.44824 17.0862V17.0852C1.42485 17.0806 1.39347 17.0707 1.38965 17.0696C1.37703 17.0659 1.34651 17.0584 1.32129 17.0481L1.32031 17.0471C1.29496 17.0364 1.26737 17.0202 1.25586 17.0139V17.0129C1.24872 17.0093 1.22091 16.9966 1.20312 16.9846C1.16572 16.9597 1.13109 16.9312 1.09961 16.8997L1.01465 16.7961C1.00656 16.7841 1.00042 16.7724 0.996094 16.7639L0.986328 16.7444C0.979286 16.7317 0.963078 16.7051 0.952148 16.679V16.678C0.941952 16.653 0.934497 16.6238 0.930664 16.6106L0.913086 16.55L0.914062 16.5491C0.90563 16.5062 0.900408 16.4626 0.900391 16.4182V12.927C0.900419 12.5507 1.20533 12.2454 1.58203 12.2454C1.95863 12.2455 2.26364 12.5507 2.26367 12.927V14.7717L6.33594 10.6995Z", fill: "white", stroke: "white", strokeWidth: 0.2 }), /* @__PURE__ */ React__namespace.createElement("path", { d: "M5.07227 0.900391C5.44866 0.900391 5.75488 1.20564 5.75488 1.58203C5.75477 1.95833 5.44859 2.26367 5.07227 2.26367H3.22754L7.2998 6.33594C7.56593 6.6022 7.56602 7.03359 7.2998 7.2998C7.1667 7.43257 6.99228 7.4989 6.81836 7.49902C6.64404 7.49902 6.46894 7.43281 6.33594 7.2998L2.26367 3.22754V5.07227C2.26367 5.44855 1.95865 5.75477 1.58203 5.75488C1.20532 5.75488 0.900391 5.44863 0.900391 5.07227V1.58203C0.900391 1.5371 0.905435 1.49264 0.914062 1.44922C0.918491 1.42575 0.929166 1.3946 0.930664 1.38965L0.952148 1.32129V1.32031C0.96291 1.29466 0.979683 1.26797 0.986328 1.25586V1.25488C0.989195 1.24976 0.990971 1.24535 0.996094 1.23535C1.00039 1.22696 1.00649 1.21525 1.01465 1.20312C1.03947 1.16593 1.06801 1.13123 1.09961 1.09961L1.2041 1.01465C1.22329 1.00182 1.25315 0.987348 1.25684 0.985352L1.25781 0.984375C1.26587 0.980073 1.29557 0.963447 1.32031 0.953125C1.34656 0.942156 1.37716 0.933567 1.39062 0.929688H1.3916C1.39739 0.928029 1.40179 0.926199 1.41211 0.922852C1.42101 0.919966 1.43338 0.91597 1.44727 0.913086H1.44922C1.49235 0.904811 1.53692 0.900391 1.58203 0.900391H5.07227Z", fill: "white", stroke: "white", strokeWidth: 0.2 }), /* @__PURE__ */ React__namespace.createElement("path", { d: "M10.6992 10.6995C10.9655 10.4332 11.3978 10.4332 11.6641 10.6995L15.7363 14.7717V12.927C15.7365 12.5508 16.0417 12.2454 16.418 12.2454C16.7946 12.2454 17.0994 12.5508 17.0996 12.927V16.4182C17.0996 16.4634 17.0952 16.5079 17.0869 16.551V16.552L17.0693 16.6106L17.0479 16.679C17.0368 16.7053 17.0206 16.7328 17.0137 16.7454C17.0108 16.7506 17.0088 16.7543 17.0039 16.7639C16.9996 16.7723 16.9923 16.7833 16.9844 16.7952L16.9854 16.7961C16.9356 16.8707 16.8712 16.9357 16.7959 16.9856C16.7767 16.9984 16.7471 17.0128 16.7432 17.0149L16.7422 17.0139C16.7302 17.0206 16.7043 17.0376 16.6797 17.0481H16.6787C16.6532 17.0585 16.6217 17.065 16.6094 17.0686L16.6104 17.0696C16.6065 17.0707 16.5743 17.0827 16.5508 17.0872L16.5498 17.0862C16.5066 17.0947 16.4626 17.0999 16.418 17.0999H12.9268C12.5505 17.0997 12.2451 16.7945 12.2451 16.4182C12.2451 16.042 12.5505 15.7368 12.9268 15.7366H14.7715L10.6992 11.6643C10.433 11.3981 10.433 10.9657 10.6992 10.6995Z", fill: "white", stroke: "white", strokeWidth: 0.2 }));
|
|
1942
1942
|
|
|
1943
|
-
const
|
|
1943
|
+
const SvgMacWhiteIcon = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 14 18", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("path", { d: "M6.90345 4.81948C7.79923 4.81948 8.58506 4.4701 9.26091 3.77134C9.93677 3.07257 10.2747 2.26003 10.2747 1.33372C10.2747 1.23198 10.2667 1.08741 10.2506 0.9C10.1326 0.916063 10.0441 0.92945 9.98506 0.940159C9.15901 1.05796 8.43218 1.46222 7.80459 2.15294C7.17701 2.84368 6.86323 3.5826 6.86323 4.36972C6.86323 4.46073 6.87663 4.61067 6.90345 4.81948ZM10.1138 17.1C10.7521 17.1 11.4575 16.6636 12.2299 15.7908C13.0023 14.918 13.5923 13.8927 14 12.7147C12.482 11.9329 11.723 10.8112 11.723 9.34937C11.723 8.12856 12.3372 7.08444 13.5655 6.21701C12.7126 5.15146 11.5862 4.61868 10.1862 4.61868C9.59616 4.61868 9.0571 4.70703 8.56897 4.88373L8.26323 4.99618L7.85287 5.15681C7.58467 5.25855 7.34061 5.30943 7.12069 5.30943C6.94904 5.30943 6.72374 5.25052 6.44483 5.13272L6.13103 5.00421L5.83334 4.88373C5.39884 4.70168 4.93218 4.61065 4.43334 4.61065C3.0977 4.61065 2.02491 5.06043 1.21494 5.95999C0.404976 6.85954 0 8.04556 0 9.51804C0 11.5902 0.649037 13.5045 1.94713 15.2607C2.84828 16.4869 3.67165 17.1 4.41724 17.1C4.73372 17.1 5.04751 17.0384 5.35862 16.9153L5.75287 16.7546L6.06668 16.6422C6.50652 16.4869 6.91149 16.4093 7.2816 16.4093C7.67318 16.4093 8.12376 16.5083 8.63334 16.7064L8.88276 16.8028C9.40305 17.0009 9.81342 17.1 10.1138 17.1Z", fill: "white" }));
|
|
1944
1944
|
|
|
1945
1945
|
const SvgAzureIcon = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 36 28", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("path", { d: "M19.6227 0L9.30269 8.97083L0.499817 24.8156H8.43836L19.6227 0ZM20.9952 2.09862L16.5914 14.5423L25.0344 25.1781L8.65282 28H35.4998L20.9952 2.09862Z", fill: "#0072C6" }));
|
|
1946
1946
|
|
|
@@ -1948,6 +1948,8 @@ const SvgOktaIcon = (props) => /* @__PURE__ */ React__namespace.createElement("s
|
|
|
1948
1948
|
|
|
1949
1949
|
const SvgGenerateCommand = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("path", { d: "M11.9999 9.3335H10.6666V6.66683H11.9999C13.4726 6.66683 14.6666 5.47283 14.6666 4.00016C14.6666 2.5275 13.4726 1.3335 11.9999 1.3335C10.5271 1.3335 9.33325 2.5275 9.33325 4.00016V5.3335H6.66658V4.00016C6.66658 2.5275 5.47259 1.3335 3.99992 1.3335C2.52725 1.3335 1.33325 2.5275 1.33325 4.00016C1.33325 5.47283 2.52725 6.66683 3.99992 6.66683H5.33325V9.3335H3.99992C2.52725 9.3335 1.33325 10.5275 1.33325 12.0002C1.33325 13.4728 2.52725 14.6668 3.99992 14.6668C5.47275 14.6668 6.66658 13.4728 6.66658 12.0002V10.6668H9.33325V11.9968L9.33309 12.0002C9.33309 13.4728 10.5271 14.6668 11.9998 14.6668C13.4724 14.6668 14.6664 13.4728 14.6664 12.0002C14.6664 10.5275 13.4726 9.33383 11.9999 9.3335ZM11.9999 2.66683C12.3535 2.66683 12.6927 2.80731 12.9427 3.05735C13.1928 3.3074 13.3333 3.64654 13.3333 4.00016C13.3333 4.35378 13.1928 4.69292 12.9427 4.94297C12.6927 5.19302 12.3535 5.3335 11.9999 5.3335H10.6666V4.00016C10.6666 3.64654 10.8071 3.3074 11.0571 3.05735C11.3072 2.80731 11.6463 2.66683 11.9999 2.66683ZM2.66659 4.00016C2.66659 3.64654 2.80706 3.3074 3.05711 3.05735C3.30716 2.80731 3.6463 2.66683 3.99992 2.66683C4.35354 2.66683 4.69268 2.80731 4.94273 3.05735C5.19278 3.3074 5.33325 3.64654 5.33325 4.00016V5.3335H3.99992C3.26359 5.3335 2.66659 4.73633 2.66659 4.00016ZM3.99992 13.3335C3.6463 13.3335 3.30716 13.193 3.05711 12.943C2.80706 12.6929 2.66659 12.3538 2.66659 12.0002C2.66659 11.6465 2.80706 11.3074 3.05711 11.0574C3.30716 10.8073 3.6463 10.6668 3.99992 10.6668H5.33325V12.0002C5.33325 12.3538 5.19278 12.6929 4.94273 12.943C4.69268 13.193 4.35354 13.3335 3.99992 13.3335ZM6.66658 9.3335V6.66683H9.33325V9.3335H6.66658ZM11.9999 13.3335C11.6463 13.3335 11.3072 13.193 11.0571 12.943C10.8071 12.6929 10.6666 12.3538 10.6666 12.0002V10.6668H11.9998C12.3534 10.6668 12.6925 10.8073 12.9426 11.0573C13.1926 11.3073 13.3331 11.6465 13.3332 12.0001C13.3332 12.3537 13.1927 12.6928 12.9427 12.9429C12.6927 13.193 12.3535 13.3335 11.9999 13.3335Z", fill: "#301349" }));
|
|
1950
1950
|
|
|
1951
|
+
const SvgWindowsBlueIcon = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 16 15", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("path", { d: "M16 15L8 14V8H16V15ZM7 8V13.875L0 13V8H7ZM7 7H0V2L7 1.125V7ZM16 7H8V1L16 0V7Z", fill: "#00BCD4" }));
|
|
1952
|
+
|
|
1951
1953
|
const SvgCopyIconFilled = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 25 23", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("g", { clipPath: "url(#clip0_2166_3137)" }, /* @__PURE__ */ React__namespace.createElement("path", { d: "M0.303711 4.54669C0.303711 2.33755 2.09457 0.546692 4.30371 0.546692H20.0762C22.2853 0.546692 24.0762 2.33755 24.0762 4.54669V18.3067C24.0762 20.5158 22.2853 22.3067 20.0762 22.3067H4.30371C2.09458 22.3067 0.303711 20.5158 0.303711 18.3067V4.54669Z", fill: "#F7ECF8" }), /* @__PURE__ */ React__namespace.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M10.7828 5.69026C10.43 6.04306 10.1876 6.67337 10.1876 7.86153V7.88218H11.6534C12.9943 7.88218 14.1343 8.14561 14.9195 8.93087C15.7048 9.71613 15.9682 10.8561 15.9682 12.197V13.6628H15.9889C17.177 13.6628 17.8073 13.4204 18.1601 13.0676C18.5129 12.7148 18.7553 12.0845 18.7553 10.8964V7.86153C18.7553 6.67337 18.5129 6.04306 18.1601 5.69026C17.8073 5.33745 17.177 5.09508 15.9889 5.09508H12.954C11.7659 5.09508 11.1356 5.33745 10.7828 5.69026ZM15.9682 15.2112H15.9889C17.3297 15.2112 18.4698 14.9478 19.255 14.1625C20.0403 13.3773 20.3037 12.2372 20.3037 10.8964V7.86153C20.3037 6.52066 20.0403 5.38064 19.255 4.59538C18.4698 3.81013 17.3297 3.54669 15.9889 3.54669H12.954C11.6132 3.54669 10.4731 3.81013 9.68789 4.59538C8.90263 5.38064 8.63919 6.52066 8.63919 7.86153V7.88218H8.61855C7.27768 7.88218 6.13766 8.14561 5.3524 8.93087C4.56714 9.71613 4.30371 10.8561 4.30371 12.197V15.2319C4.30371 16.5727 4.56714 17.7127 5.3524 18.498C6.13766 19.2833 7.27768 19.5467 8.61855 19.5467H11.6534C12.9943 19.5467 14.1343 19.2833 14.9195 18.498C15.7048 17.7127 15.9682 16.5727 15.9682 15.2319V15.2112ZM14.4198 12.197C14.4198 11.0089 14.1775 10.3785 13.8247 10.0257C13.4719 9.67294 12.8415 9.43056 11.6534 9.43056H8.61855C7.43039 9.43056 6.80008 9.67294 6.44728 10.0257C6.09447 10.3785 5.8521 11.0089 5.8521 12.197V15.2319C5.8521 16.42 6.09447 17.0503 6.44728 17.4031C6.80008 17.7559 7.43039 17.9983 8.61855 17.9983H11.6534C12.8415 17.9983 13.4719 17.7559 13.8247 17.4031C14.1775 17.0503 14.4198 16.42 14.4198 15.2319V12.197Z", fill: "#71347B" })), /* @__PURE__ */ React__namespace.createElement("defs", null, /* @__PURE__ */ React__namespace.createElement("clipPath", { id: "clip0_2166_3137" }, /* @__PURE__ */ React__namespace.createElement("path", { d: "M0.303711 4.54669C0.303711 2.33755 2.09457 0.546692 4.30371 0.546692H20.0762C22.2853 0.546692 24.0762 2.33755 24.0762 4.54669V18.3067C24.0762 20.5158 22.2853 22.3067 20.0762 22.3067H4.30371C2.09458 22.3067 0.303711 20.5158 0.303711 18.3067V4.54669Z", fill: "white" }))));
|
|
1952
1954
|
|
|
1953
1955
|
const SvgGenerateCommandLogo = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("path", { d: "M0 7C0 3.13401 3.13401 0 7 0H17C20.866 0 24 3.13401 24 7V17C24 20.866 20.866 24 17 24H7C3.13401 24 0 20.866 0 17V7Z", fill: "#F7EBFF" }), /* @__PURE__ */ React__namespace.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M5.78395 5.78395C6.71109 4.8568 8.10069 4.5 9.9 4.5H14.1C15.8993 4.5 17.2889 4.8568 18.2161 5.78395C19.1432 6.71109 19.5 8.10069 19.5 9.9V14.1C19.5 15.8993 19.1432 17.2889 18.2161 18.2161C17.2889 19.1432 15.8993 19.5 14.1 19.5H9.9C8.10069 19.5 6.71109 19.1432 5.78395 18.2161C4.8568 17.2889 4.5 15.8993 4.5 14.1V9.9C4.5 8.10069 4.8568 6.71109 5.78395 5.78395ZM6.49105 6.49105C5.8432 7.13891 5.5 8.19931 5.5 9.9V14.1C5.5 15.8007 5.8432 16.8611 6.49105 17.5089C7.13891 18.1568 8.19931 18.5 9.9 18.5H14.1C15.8007 18.5 16.8611 18.1568 17.5089 17.5089C18.1568 16.8611 18.5 15.8007 18.5 14.1V9.9C18.5 8.19931 18.1568 7.13891 17.5089 6.49105C16.8611 5.8432 15.8007 5.5 14.1 5.5H9.9C8.19931 5.5 7.13891 5.8432 6.49105 6.49105Z", fill: "#71347B" }), /* @__PURE__ */ React__namespace.createElement("path", { d: "M11.6367 12.0586V14.2734C11.5534 14.3802 11.4219 14.4961 11.2422 14.6211C11.0651 14.7461 10.8333 14.8542 10.5469 14.9453C10.2604 15.0339 9.90885 15.0781 9.49219 15.0781C9.13021 15.0781 8.79948 15.0182 8.5 14.8984C8.20052 14.776 7.94271 14.5977 7.72656 14.3633C7.51042 14.1289 7.34375 13.8424 7.22656 13.5039C7.10938 13.1654 7.05078 12.7786 7.05078 12.3438V11.9688C7.05078 11.5339 7.10547 11.1471 7.21484 10.8086C7.32682 10.4701 7.48568 10.1836 7.69141 9.94922C7.89974 9.71484 8.14844 9.53646 8.4375 9.41406C8.72917 9.29167 9.05469 9.23047 9.41406 9.23047C9.89583 9.23047 10.2917 9.3099 10.6016 9.46875C10.9141 9.6276 11.1536 9.84635 11.3203 10.125C11.487 10.401 11.5911 10.7188 11.6328 11.0781H10.5859C10.5573 10.8802 10.5 10.707 10.4141 10.5586C10.3281 10.4076 10.2057 10.2904 10.0469 10.207C9.89062 10.1211 9.6875 10.0781 9.4375 10.0781C9.22656 10.0781 9.04036 10.1198 8.87891 10.2031C8.71745 10.2865 8.58203 10.4076 8.47266 10.5664C8.36328 10.7253 8.27995 10.9219 8.22266 11.1562C8.16797 11.3906 8.14062 11.6589 8.14062 11.9609V12.3438C8.14062 12.6484 8.17188 12.9193 8.23438 13.1562C8.29688 13.3906 8.38672 13.5885 8.50391 13.75C8.6237 13.9089 8.77083 14.0299 8.94531 14.1133C9.1224 14.194 9.32292 14.2344 9.54688 14.2344C9.75 14.2344 9.91797 14.2174 10.0508 14.1836C10.1862 14.1471 10.2943 14.1042 10.375 14.0547C10.4557 14.0052 10.5182 13.957 10.5625 13.9102V12.8438H9.43359V12.0586H11.6367ZM15.9805 13.1289H17.0547C17.026 13.5091 16.9206 13.8464 16.7383 14.1406C16.556 14.4323 16.3021 14.6615 15.9766 14.8281C15.651 14.9948 15.2565 15.0781 14.793 15.0781C14.4362 15.0781 14.1146 15.0156 13.8281 14.8906C13.5443 14.763 13.3008 14.582 13.0977 14.3477C12.8971 14.1107 12.7435 13.8268 12.6367 13.4961C12.5299 13.1628 12.4766 12.7891 12.4766 12.375V11.9414C12.4766 11.5273 12.5312 11.1536 12.6406 10.8203C12.75 10.487 12.9062 10.2031 13.1094 9.96875C13.3151 9.73177 13.5612 9.54948 13.8477 9.42188C14.1367 9.29427 14.4596 9.23047 14.8164 9.23047C15.2799 9.23047 15.6719 9.31641 15.9922 9.48828C16.3125 9.65755 16.5612 9.89062 16.7383 10.1875C16.9154 10.4844 17.0221 10.8255 17.0586 11.2109H15.9844C15.9635 10.9714 15.9115 10.7682 15.8281 10.6016C15.7474 10.4349 15.625 10.3086 15.4609 10.2227C15.2995 10.1341 15.0846 10.0898 14.8164 10.0898C14.6081 10.0898 14.4245 10.1289 14.2656 10.207C14.1094 10.2852 13.9792 10.4023 13.875 10.5586C13.7708 10.7122 13.6927 10.9049 13.6406 11.1367C13.5885 11.3659 13.5625 11.6315 13.5625 11.9336V12.375C13.5625 12.6641 13.5859 12.9232 13.6328 13.1523C13.6797 13.3815 13.7526 13.5755 13.8516 13.7344C13.9505 13.8932 14.0781 14.0143 14.2344 14.0977C14.3906 14.181 14.5768 14.2227 14.793 14.2227C15.056 14.2227 15.2695 14.181 15.4336 14.0977C15.6003 14.0143 15.7266 13.8919 15.8125 13.7305C15.901 13.569 15.957 13.3685 15.9805 13.1289Z", fill: "#71347B" }));
|
|
@@ -1978,6 +1980,14 @@ const SvgRealmeIcon = (props) => /* @__PURE__ */ React__namespace.createElement(
|
|
|
1978
1980
|
|
|
1979
1981
|
const SvgVivoIcon = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 16 5", fill: "none", xmlns: "http://www.w3.org/2000/svg", xmlnsXlink: "http://www.w3.org/1999/xlink", ...props }, /* @__PURE__ */ React__namespace.createElement("rect", { y: 0.784546, width: 16, height: 4, fill: "url(#pattern0_6138_26160)" }), /* @__PURE__ */ React__namespace.createElement("defs", null, /* @__PURE__ */ React__namespace.createElement("pattern", { id: "pattern0_6138_26160", patternContentUnits: "objectBoundingBox", width: 1, height: 1 }, /* @__PURE__ */ React__namespace.createElement("use", { xlinkHref: "#image0_6138_26160", transform: "matrix(0.0078125 0 0 0.03125 0 -0.03125)" })), /* @__PURE__ */ React__namespace.createElement("image", { id: "image0_6138_26160", width: 128, height: 34, preserveAspectRatio: "none", xlinkHref: "" })));
|
|
1980
1982
|
|
|
1983
|
+
const SvgMinimizeTree = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M0.257713 8.62399C-0.0859044 8.28038 -0.0859044 7.71952 0.257713 7.37591L6.98841 0.645442C7.33256 0.301292 7.89238 0.301292 8.23649 0.645442L8.61298 1.02193C8.95743 1.36638 8.95751 1.9259 8.61302 2.27043L3.5072 7.37575C3.16267 7.72021 3.16267 8.27985 3.5072 8.6243L8.61298 13.7297C8.95751 14.0741 8.95747 14.6336 8.61294 14.9781L8.23646 15.3546C7.89284 15.6982 7.33198 15.6982 6.98837 15.3546L0.257713 8.62399ZM14.1172 15.3547C14.4612 15.6987 15.0216 15.6986 15.3655 15.3547L15.742 14.9782C16.0858 14.6344 16.0859 14.0735 15.742 13.7297L10.6365 8.6243C10.292 8.27981 10.292 7.72025 10.6365 7.37575L15.742 2.2704C16.086 1.92647 16.086 1.36581 15.742 1.02189L15.3656 0.645404C15.0214 0.301292 14.4614 0.301254 14.1173 0.645404L7.98445 6.77842C6.26412 5.0598 6.69928 5.49564 7.9832 6.77968L7.38701 7.37591C7.04316 7.71975 7.0432 8.28019 7.38701 8.62403L14.1172 15.3547Z", fill: "#71347B" }));
|
|
1984
|
+
|
|
1985
|
+
const SvgRecord = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("g", { clipPath: "url(#clip0_20310_13972)" }, /* @__PURE__ */ React__namespace.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M8 0C3.5875 0 0 3.5875 0 8C0 12.4125 3.5875 16 8 16C12.4125 16 16 12.4125 16 8C16 3.5875 12.4125 0 8 0ZM5.03125 6.20312H3.78125C3.64375 6.20312 3.53125 6.31563 3.53125 6.45312V8.22812V9.54375C3.53125 9.68125 3.64375 9.79375 3.78125 9.79375C3.91875 9.79375 4.03125 9.68125 4.03125 9.54375V8.47812H4.425L5.34375 9.65C5.39375 9.7125 5.46563 9.74687 5.54063 9.74687C5.59375 9.74687 5.65 9.72813 5.69375 9.69375C5.80312 9.60938 5.82188 9.45 5.7375 9.34375L5.05937 8.48125C5.675 8.46562 6.16875 7.9625 6.16875 7.34375C6.17188 6.71562 5.65938 6.20312 5.03125 6.20312ZM7.30625 6.70312V7.75H9.09375C9.23125 7.75 9.34375 7.8625 9.34375 8C9.34375 8.1375 9.23125 8.25 9.09375 8.25H7.30625V9.29688H9.09375C9.23125 9.29688 9.34375 9.40938 9.34375 9.54688C9.34375 9.68437 9.23125 9.79688 9.09375 9.79688H7.05312C6.91563 9.79688 6.80312 9.68437 6.80312 9.54688V6.45312C6.80312 6.31563 6.91563 6.20312 7.05312 6.20312H9.09375C9.23125 6.20312 9.34375 6.31563 9.34375 6.45312C9.34375 6.59062 9.23125 6.70312 9.09375 6.70312H7.30625ZM10.4312 7.325V8.67188C10.4312 9.01562 10.7094 9.29375 11.0531 9.29375H11.35C11.6875 9.29375 11.9656 9.01875 11.9719 8.68437C11.975 8.54688 12.0875 8.43437 12.2281 8.4375C12.3656 8.44063 12.475 8.55313 12.475 8.69375C12.4625 9.3 11.9594 9.79375 11.3531 9.79375H11.0562C10.4375 9.79375 9.93437 9.29062 9.93437 8.67188V7.325C9.93437 6.70625 10.4375 6.20312 11.0562 6.20312H11.3531C11.9594 6.20312 12.4625 6.69688 12.475 7.30312C12.4781 7.44062 12.3687 7.55625 12.2281 7.55937C12.0875 7.5625 11.975 7.45312 11.9719 7.3125C11.9656 6.975 11.6875 6.70312 11.35 6.70312H11.0531C10.7094 6.70312 10.4312 6.98438 10.4312 7.325ZM5.03125 7.98125H4.03125V6.70625H5.03125C5.38438 6.70625 5.66875 6.99062 5.66875 7.34375C5.66875 7.69375 5.38438 7.98125 5.03125 7.98125Z", fill: "currentColor" })), /* @__PURE__ */ React__namespace.createElement("defs", null, /* @__PURE__ */ React__namespace.createElement("clipPath", { id: "clip0_20310_13972" }, /* @__PURE__ */ React__namespace.createElement("rect", { width: 16, height: 16, fill: "white" }))));
|
|
1986
|
+
|
|
1987
|
+
const SvgAddElement = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("rect", { width: 16, height: 16, rx: 8, fill: "#F7EBFF" }), /* @__PURE__ */ React__namespace.createElement("path", { d: "M8 2C4.6863 2 2 4.68627 2 8C2 11.3137 4.6863 14 8 14C11.3137 14 14 11.3137 14 8C14 4.68627 11.3137 2 8 2ZM10.0537 11.15H5.94644V4.85002H9.97758V6.35024H7.67444V7.27779H9.74365V8.70142H7.67444V9.64463H10.0538L10.0537 11.15Z", fill: "currentColor" }), /* @__PURE__ */ React__namespace.createElement("mask", { id: "path-3-outside-1_20264_6770", maskUnits: "userSpaceOnUse", x: 2.80005, y: 5.2002, width: 6, height: 6, fill: "black" }, /* @__PURE__ */ React__namespace.createElement("rect", { fill: "white", x: 2.80005, y: 5.2002, width: 6, height: 6 }), /* @__PURE__ */ React__namespace.createElement("path", { d: "M5.89966 7.2002C5.89966 7.61441 6.23544 7.9502 6.64966 7.9502H7.04956C7.24291 7.9502 7.39966 8.10694 7.39966 8.30029C7.39966 8.49365 7.24291 8.65039 7.04956 8.65039H6.64966C6.23544 8.65039 5.89966 8.98618 5.89966 9.40039V10.1006C5.89966 10.2662 5.76543 10.4004 5.59985 10.4004C5.43428 10.4004 5.30005 10.2662 5.30005 10.1006V9.40039C5.30005 8.98618 4.96426 8.65039 4.55005 8.65039H4.15015C3.95679 8.65039 3.80005 8.49365 3.80005 8.30029C3.80005 8.10694 3.95679 7.9502 4.15015 7.9502H4.55005C4.96426 7.9502 5.30005 7.61441 5.30005 7.2002V6.5C5.30005 6.33442 5.43428 6.2002 5.59985 6.2002C5.76543 6.2002 5.89966 6.33442 5.89966 6.5V7.2002Z" })), /* @__PURE__ */ React__namespace.createElement("path", { d: "M5.89966 7.2002C5.89966 7.61441 6.23544 7.9502 6.64966 7.9502H7.04956C7.24291 7.9502 7.39966 8.10694 7.39966 8.30029C7.39966 8.49365 7.24291 8.65039 7.04956 8.65039H6.64966C6.23544 8.65039 5.89966 8.98618 5.89966 9.40039V10.1006C5.89966 10.2662 5.76543 10.4004 5.59985 10.4004C5.43428 10.4004 5.30005 10.2662 5.30005 10.1006V9.40039C5.30005 8.98618 4.96426 8.65039 4.55005 8.65039H4.15015C3.95679 8.65039 3.80005 8.49365 3.80005 8.30029C3.80005 8.10694 3.95679 7.9502 4.15015 7.9502H4.55005C4.96426 7.9502 5.30005 7.61441 5.30005 7.2002V6.5C5.30005 6.33442 5.43428 6.2002 5.59985 6.2002C5.76543 6.2002 5.89966 6.33442 5.89966 6.5V7.2002Z", fill: "#F7EBFF" }), /* @__PURE__ */ React__namespace.createElement("path", { d: "M6.64966 7.9502V8.4502H7.04956V7.9502V7.4502H6.64966V7.9502ZM7.04956 8.65039V8.15039H6.64966V8.65039V9.15039H7.04956V8.65039ZM5.89966 9.40039H5.39966V10.1006H5.89966H6.39966V9.40039H5.89966ZM5.30005 10.1006H5.80005V9.40039H5.30005H4.80005V10.1006H5.30005ZM4.55005 8.65039V8.15039H4.15015V8.65039V9.15039H4.55005V8.65039ZM4.15015 7.9502V8.4502H4.55005V7.9502V7.4502H4.15015V7.9502ZM5.30005 7.2002H5.80005V6.5H5.30005H4.80005V7.2002H5.30005ZM5.89966 6.5H5.39966V7.2002H5.89966H6.39966V6.5H5.89966ZM5.59985 6.2002V6.7002C5.48929 6.7002 5.39966 6.61056 5.39966 6.5H5.89966H6.39966C6.39966 6.05828 6.04157 5.7002 5.59985 5.7002V6.2002ZM5.30005 6.5H5.80005C5.80005 6.61056 5.71042 6.7002 5.59985 6.7002V6.2002V5.7002C5.15813 5.7002 4.80005 6.05828 4.80005 6.5H5.30005ZM4.55005 7.9502V8.4502C5.2404 8.4502 5.80005 7.89055 5.80005 7.2002H5.30005H4.80005C4.80005 7.33827 4.68812 7.4502 4.55005 7.4502V7.9502ZM3.80005 8.30029H4.30005C4.30005 8.38308 4.23294 8.4502 4.15015 8.4502V7.9502V7.4502C3.68065 7.4502 3.30005 7.8308 3.30005 8.30029H3.80005ZM4.15015 8.65039V8.15039C4.23294 8.15039 4.30005 8.2175 4.30005 8.30029H3.80005H3.30005C3.30005 8.76979 3.68065 9.15039 4.15015 9.15039V8.65039ZM5.30005 9.40039H5.80005C5.80005 8.71003 5.2404 8.15039 4.55005 8.15039V8.65039V9.15039C4.68812 9.15039 4.80005 9.26232 4.80005 9.40039H5.30005ZM5.59985 10.4004V9.90039C5.71042 9.90039 5.80005 9.99002 5.80005 10.1006H5.30005H4.80005C4.80005 10.5423 5.15813 10.9004 5.59985 10.9004V10.4004ZM5.89966 10.1006H5.39966C5.39966 9.99002 5.48929 9.90039 5.59985 9.90039V10.4004V10.9004C6.04157 10.9004 6.39966 10.5423 6.39966 10.1006H5.89966ZM6.64966 8.65039V8.15039C5.9593 8.15039 5.39966 8.71003 5.39966 9.40039H5.89966H6.39966C6.39966 9.26232 6.51159 9.15039 6.64966 9.15039V8.65039ZM7.39966 8.30029H6.89966C6.89966 8.2175 6.96677 8.15039 7.04956 8.15039V8.65039V9.15039C7.51906 9.15039 7.89966 8.76979 7.89966 8.30029H7.39966ZM7.04956 7.9502V8.4502C6.96677 8.4502 6.89966 8.38308 6.89966 8.30029H7.39966H7.89966C7.89966 7.8308 7.51906 7.4502 7.04956 7.4502V7.9502ZM6.64966 7.9502V7.4502C6.51159 7.4502 6.39966 7.33827 6.39966 7.2002H5.89966H5.39966C5.39966 7.89055 5.9593 8.4502 6.64966 8.4502V7.9502Z", fill: "currentColor", mask: "url(#path-3-outside-1_20264_6770)" }));
|
|
1988
|
+
|
|
1989
|
+
const SvgElementSlider = (props) => /* @__PURE__ */ React__namespace.createElement("svg", { width: "1em", height: "1em", viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props }, /* @__PURE__ */ React__namespace.createElement("rect", { width: 16, height: 16, rx: 8, fill: "#F7EBFF" }), /* @__PURE__ */ React__namespace.createElement("path", { d: "M7.99994 2C4.68623 2 1.99994 4.68627 1.99994 8C1.99994 11.3137 4.68623 14 7.99994 14C11.3136 14 13.9999 11.3137 13.9999 8C13.9999 4.68627 11.3136 2 7.99994 2Z", fill: "currentColor" }), /* @__PURE__ */ React__namespace.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M9.05737 4.3999C9.1964 4.3999 9.30911 4.50735 9.30911 4.6399V5.2399H9.58604C9.8067 5.2399 10.0133 5.24651 10.2027 5.27201C10.6976 5.32459 11.0802 5.47008 11.3176 5.81369C11.5406 6.13661 11.6 6.58969 11.6 7.1599V8.8399C11.6 9.41011 11.5406 9.8632 11.3176 10.1861C11.0802 10.5297 10.6976 10.6752 10.2027 10.7278C10.0133 10.7533 9.8067 10.7599 9.58604 10.7599H9.30911V11.3599C9.30911 11.4925 9.1964 11.5999 9.05737 11.5999C8.91833 11.5999 8.80562 11.4925 8.80562 11.3599V4.6399C8.80562 4.50735 8.91833 4.3999 9.05737 4.3999ZM9.30911 10.2799H9.58604C9.80085 10.2799 9.98062 10.2732 10.1355 10.2521L10.1435 10.2511C10.5736 10.2059 10.7782 10.0942 10.897 9.92213C11.0308 9.72845 11.0965 9.40537 11.0965 8.8399V7.1599C11.0965 6.59443 11.0308 6.27136 10.897 6.07768C10.7782 5.9056 10.5736 5.79391 10.1435 5.7487L10.1355 5.74773C9.98062 5.72663 9.80085 5.7199 9.58604 5.7199H9.30911V10.2799ZM6.41401 5.7199C6.1992 5.7199 6.01945 5.72663 5.86456 5.74773L5.85655 5.7487C5.42643 5.79391 5.22188 5.9056 5.10301 6.07768C4.96923 6.27136 4.90352 6.59443 4.90352 7.1599V8.8399C4.90352 9.40537 4.96923 9.72845 5.10301 9.92212C5.22188 10.0942 5.42643 10.2059 5.85655 10.2511L5.86456 10.2521C6.01945 10.2732 6.1992 10.2799 6.41401 10.2799H7.65463C7.79367 10.2799 7.90638 10.3874 7.90638 10.5199C7.90638 10.6525 7.79367 10.7599 7.65463 10.7599H6.41401C6.19335 10.7599 5.98678 10.7533 5.79737 10.7278C5.30248 10.6752 4.91986 10.5297 4.68251 10.1861C4.45944 9.8632 4.40002 9.41011 4.40002 8.8399V7.1599C4.40002 6.58969 4.45944 6.13661 4.68251 5.81368C4.91986 5.47008 5.30249 5.32459 5.79738 5.27201C5.98679 5.24651 6.19335 5.2399 6.41401 5.2399H7.63349C7.77252 5.2399 7.88523 5.34735 7.88523 5.4799C7.88523 5.61245 7.77252 5.7199 7.63349 5.7199H6.41401Z", fill: "white" }), /* @__PURE__ */ React__namespace.createElement("path", { d: "M6.51232 7.20682V7.71802H7.37707V8.19322H6.51232V8.74762H7.49036V9.24082H5.86658V6.71362H7.49036V7.20682H6.51232Z", fill: "white" }));
|
|
1990
|
+
|
|
1981
1991
|
let Components = {};
|
|
1982
1992
|
Components['success'] = SvgSuccess;
|
|
1983
1993
|
Components['setting_icon'] = SvgSettingIcon;
|
|
@@ -2445,9 +2455,9 @@ Components['huawei_icon'] = SvgHuaweiIcon;
|
|
|
2445
2455
|
Components['amazon_icon'] = SvgAmazonIcon;
|
|
2446
2456
|
Components['scripts'] = SvgScripts;
|
|
2447
2457
|
Components['dialog_info'] = SvgDialogInfo;
|
|
2448
|
-
Components['
|
|
2449
|
-
Components['
|
|
2450
|
-
Components['
|
|
2458
|
+
Components['timer_icon'] = SvgTimerIcon;
|
|
2459
|
+
Components['maximize_livetesting'] = SvgMaximizeLivetesting;
|
|
2460
|
+
Components['mac_white_icon'] = SvgMacWhiteIcon;
|
|
2451
2461
|
Components['ADB_Shell'] = SvgAdbShell; // Newly Added icon
|
|
2452
2462
|
Components['UI_Inspector'] = SvgUiInspector; // Newly Added icon
|
|
2453
2463
|
Components['azure_icon'] = SvgAzureIcon; // Newly Added icon
|
|
@@ -2468,6 +2478,11 @@ Components['motorola_icon'] = SvgMotorolaIcon; // Newly Added icon
|
|
|
2468
2478
|
Components['oppo_icon'] = SvgOppoIcon; // Newly Added icon
|
|
2469
2479
|
Components['realme_icon'] = SvgRealmeIcon; // Newly Added icon
|
|
2470
2480
|
Components['vivo_icon'] = SvgVivoIcon; // Newly Added icon
|
|
2481
|
+
Components['windows_blue_icon'] = SvgWindowsBlueIcon;
|
|
2482
|
+
Components['minimize_tree'] = SvgMinimizeTree;
|
|
2483
|
+
Components['record'] = SvgRecord;
|
|
2484
|
+
Components['add_element'] = SvgAddElement;
|
|
2485
|
+
Components['element_slider'] = SvgElementSlider;
|
|
2471
2486
|
|
|
2472
2487
|
const Icon = /*#__PURE__*/React.forwardRef(({
|
|
2473
2488
|
name,
|
|
@@ -3063,13 +3078,15 @@ const Drawer = ({
|
|
|
3063
3078
|
}), _isExpanded && jsxRuntime.jsx(Tooltip, {
|
|
3064
3079
|
title: isExpanded ? 'Minimize' : 'Maximize',
|
|
3065
3080
|
placement: "bottom",
|
|
3066
|
-
children: jsxRuntime.jsx("
|
|
3081
|
+
children: jsxRuntime.jsx("div", {
|
|
3067
3082
|
className: "ff-expand-collapse-button",
|
|
3068
3083
|
onClick: toggleExpand,
|
|
3069
3084
|
children: jsxRuntime.jsx(Icon, {
|
|
3070
|
-
name: isExpanded ? '
|
|
3085
|
+
name: isExpanded ? 'maximize_tree' : 'minimize_tree',
|
|
3071
3086
|
height: 16,
|
|
3072
|
-
width: 16
|
|
3087
|
+
width: 16,
|
|
3088
|
+
hoverEffect: true,
|
|
3089
|
+
cursorType: "pointer"
|
|
3073
3090
|
})
|
|
3074
3091
|
})
|
|
3075
3092
|
}), isBackButtonVisible && (backButtonIcon || jsxRuntime.jsx(Tooltip, {
|
|
@@ -3094,7 +3111,8 @@ const Drawer = ({
|
|
|
3094
3111
|
onClick: onCloseIconClick || onClose,
|
|
3095
3112
|
height: 16,
|
|
3096
3113
|
width: 16,
|
|
3097
|
-
color: "var(--tabs-label-active-color)"
|
|
3114
|
+
color: "var(--tabs-label-active-color)",
|
|
3115
|
+
cursorType: "pointer"
|
|
3098
3116
|
})
|
|
3099
3117
|
})
|
|
3100
3118
|
})]
|
|
@@ -12788,6 +12806,9 @@ var DNDSortable = /*#__PURE__*/Object.freeze({
|
|
|
12788
12806
|
verticalListSortingStrategy: verticalListSortingStrategy
|
|
12789
12807
|
});
|
|
12790
12808
|
|
|
12809
|
+
// Add these constants near the top of the file
|
|
12810
|
+
const DEFAULT_ROW_HEIGHT = 50; // Estimated row height
|
|
12811
|
+
const BUFFER_SIZE = 5; // Number of extra rows to render above/below visible area
|
|
12791
12812
|
const getColumnLeftPosition = (index, columns, freezeColumns) => {
|
|
12792
12813
|
if (index === 0) return '0px';
|
|
12793
12814
|
// Calculate cumulative width of all previous columns including padding
|
|
@@ -12824,7 +12845,9 @@ const SortableRow = ({
|
|
|
12824
12845
|
isRowCheckBoxDisable,
|
|
12825
12846
|
isRowDisabled = true,
|
|
12826
12847
|
freezeColumns,
|
|
12827
|
-
displayCard
|
|
12848
|
+
displayCard,
|
|
12849
|
+
updateRowHeight,
|
|
12850
|
+
index
|
|
12828
12851
|
}) => {
|
|
12829
12852
|
const {
|
|
12830
12853
|
attributes,
|
|
@@ -12836,6 +12859,13 @@ const SortableRow = ({
|
|
|
12836
12859
|
id: row?._id || row?.id,
|
|
12837
12860
|
disabled: row.disabled || !!editMode
|
|
12838
12861
|
});
|
|
12862
|
+
const rowRef = React.useRef(null);
|
|
12863
|
+
React.useEffect(() => {
|
|
12864
|
+
if (rowRef.current && updateRowHeight) {
|
|
12865
|
+
const height = rowRef.current.getBoundingClientRect().height;
|
|
12866
|
+
updateRowHeight(index, height);
|
|
12867
|
+
}
|
|
12868
|
+
}, [index, updateRowHeight]);
|
|
12839
12869
|
const style = {
|
|
12840
12870
|
transform: CSS.Transform.toString(transform),
|
|
12841
12871
|
transition
|
|
@@ -12856,7 +12886,7 @@ const SortableRow = ({
|
|
|
12856
12886
|
style: {
|
|
12857
12887
|
position: isFrozen ? 'sticky' : 'static',
|
|
12858
12888
|
left: isFrozen ? getColumnLeftPosition(index, columns, freezeColumns) : 'auto',
|
|
12859
|
-
zIndex: isFrozen ?
|
|
12889
|
+
zIndex: isFrozen ? 99 : 'auto',
|
|
12860
12890
|
backgroundColor: isFrozen ? 'var(--input-label-bg-color)' : 'transparent',
|
|
12861
12891
|
width: column.width ? `${column.width}px` : 'auto',
|
|
12862
12892
|
padding: '7px 8px',
|
|
@@ -12944,6 +12974,104 @@ const Table$1 = ({
|
|
|
12944
12974
|
freezeColumns
|
|
12945
12975
|
}) => {
|
|
12946
12976
|
const observerRef = React.useRef(null);
|
|
12977
|
+
// Add virtualization state
|
|
12978
|
+
const containerRef = React.useRef(null);
|
|
12979
|
+
const setContainerRef = node => {
|
|
12980
|
+
// 1. Set internal ref
|
|
12981
|
+
containerRef.current = node;
|
|
12982
|
+
// 2. Handle forwarded ref
|
|
12983
|
+
if (tableRef) {
|
|
12984
|
+
if (typeof tableRef === 'function') {
|
|
12985
|
+
// Handle callback refs
|
|
12986
|
+
tableRef(node);
|
|
12987
|
+
} else if (typeof tableRef === 'object' && 'current' in tableRef) {
|
|
12988
|
+
// Handle mutable ref objects only
|
|
12989
|
+
tableRef.current = node;
|
|
12990
|
+
}
|
|
12991
|
+
// Read-only RefObjects are safely ignored
|
|
12992
|
+
}
|
|
12993
|
+
};
|
|
12994
|
+
const [scrollTop, setScrollTop] = React.useState(0);
|
|
12995
|
+
const [containerHeight, setContainerHeight] = React.useState(0);
|
|
12996
|
+
const [rowHeights, setRowHeights] = React.useState([]);
|
|
12997
|
+
// Initialize container height and row heights
|
|
12998
|
+
React.useEffect(() => {
|
|
12999
|
+
if (containerRef.current) {
|
|
13000
|
+
setContainerHeight(containerRef.current.clientHeight);
|
|
13001
|
+
}
|
|
13002
|
+
// Initialize with estimated heights
|
|
13003
|
+
setRowHeights(new Array(data.length).fill(DEFAULT_ROW_HEIGHT));
|
|
13004
|
+
}, [data]);
|
|
13005
|
+
// Handle scroll events
|
|
13006
|
+
const handleScroll = React.useCallback(e => {
|
|
13007
|
+
setScrollTop(e.currentTarget.scrollTop);
|
|
13008
|
+
}, []);
|
|
13009
|
+
// Update row height callback
|
|
13010
|
+
const updateRowHeight = React.useCallback((index, height) => {
|
|
13011
|
+
setRowHeights(prev => {
|
|
13012
|
+
const newHeights = [...prev];
|
|
13013
|
+
if (index < newHeights.length) {
|
|
13014
|
+
const currentHeight = newHeights[index] ?? DEFAULT_ROW_HEIGHT; // Fallback
|
|
13015
|
+
if (Math.abs(currentHeight - height) > 1) {
|
|
13016
|
+
newHeights[index] = height;
|
|
13017
|
+
return newHeights;
|
|
13018
|
+
}
|
|
13019
|
+
}
|
|
13020
|
+
return prev;
|
|
13021
|
+
});
|
|
13022
|
+
}, []);
|
|
13023
|
+
// Calculate visible rows
|
|
13024
|
+
const calculateVisibleRows = () => {
|
|
13025
|
+
let startIndex = 0;
|
|
13026
|
+
let endIndex = data.length - 1;
|
|
13027
|
+
let paddingTop = 0;
|
|
13028
|
+
let paddingBottom = 0;
|
|
13029
|
+
if (rowHeights.length === data.length && containerHeight > 0) {
|
|
13030
|
+
// Calculate based on actual row heights
|
|
13031
|
+
let cumulativeHeight = 0;
|
|
13032
|
+
// Find start index
|
|
13033
|
+
for (let i = 0; i < data.length; i++) {
|
|
13034
|
+
if (cumulativeHeight <= scrollTop) {
|
|
13035
|
+
startIndex = i;
|
|
13036
|
+
}
|
|
13037
|
+
cumulativeHeight += rowHeights[i] || DEFAULT_ROW_HEIGHT;
|
|
13038
|
+
}
|
|
13039
|
+
// Find end index
|
|
13040
|
+
cumulativeHeight = 0;
|
|
13041
|
+
for (let i = 0; i < data.length; i++) {
|
|
13042
|
+
cumulativeHeight += rowHeights[i] || DEFAULT_ROW_HEIGHT;
|
|
13043
|
+
if (cumulativeHeight >= scrollTop + containerHeight && endIndex === data.length - 1) {
|
|
13044
|
+
endIndex = i;
|
|
13045
|
+
break;
|
|
13046
|
+
}
|
|
13047
|
+
}
|
|
13048
|
+
// Apply buffer
|
|
13049
|
+
startIndex = Math.max(0, startIndex - BUFFER_SIZE);
|
|
13050
|
+
endIndex = Math.min(data.length - 1, endIndex + BUFFER_SIZE);
|
|
13051
|
+
// Calculate padding
|
|
13052
|
+
paddingTop = rowHeights.slice(0, startIndex).reduce((sum, height) => sum + height, 0);
|
|
13053
|
+
paddingBottom = rowHeights.slice(endIndex + 1).reduce((sum, height) => sum + height, 0);
|
|
13054
|
+
} else {
|
|
13055
|
+
// Fallback to estimated calculation
|
|
13056
|
+
startIndex = Math.max(0, Math.floor(scrollTop / DEFAULT_ROW_HEIGHT) - BUFFER_SIZE);
|
|
13057
|
+
endIndex = Math.min(data.length - 1, startIndex + Math.ceil(containerHeight / DEFAULT_ROW_HEIGHT) + BUFFER_SIZE);
|
|
13058
|
+
paddingTop = startIndex * DEFAULT_ROW_HEIGHT;
|
|
13059
|
+
paddingBottom = (data.length - endIndex - 1) * DEFAULT_ROW_HEIGHT;
|
|
13060
|
+
}
|
|
13061
|
+
return {
|
|
13062
|
+
startIndex,
|
|
13063
|
+
endIndex,
|
|
13064
|
+
paddingTop,
|
|
13065
|
+
paddingBottom,
|
|
13066
|
+
visibleRows: data.slice(startIndex, endIndex + 1)
|
|
13067
|
+
};
|
|
13068
|
+
};
|
|
13069
|
+
const {
|
|
13070
|
+
startIndex,
|
|
13071
|
+
paddingTop,
|
|
13072
|
+
paddingBottom,
|
|
13073
|
+
visibleRows
|
|
13074
|
+
} = calculateVisibleRows();
|
|
12947
13075
|
let frozenWidth = 0;
|
|
12948
13076
|
if (freezeColumns) {
|
|
12949
13077
|
frozenWidth = calculateFrozenWidth(columns, freezeColumns);
|
|
@@ -13000,6 +13128,43 @@ const Table$1 = ({
|
|
|
13000
13128
|
if (oldIndex === -1 || newIndex === -1) return;
|
|
13001
13129
|
if (onDragEnd) onDragEnd(oldIndex, newIndex);
|
|
13002
13130
|
};
|
|
13131
|
+
const renderRow = (row, absoluteIndex) => {
|
|
13132
|
+
const isOpen = getAccordionStatus(row?.id || row?._id || row?.scriptId);
|
|
13133
|
+
if (editMode === row._id || editMode === row.id) {
|
|
13134
|
+
return jsxRuntime.jsx("tr", {
|
|
13135
|
+
className: "edit-row",
|
|
13136
|
+
children: jsxRuntime.jsx("td", {
|
|
13137
|
+
colSpan: columns.length,
|
|
13138
|
+
style: {
|
|
13139
|
+
padding: '0px'
|
|
13140
|
+
},
|
|
13141
|
+
children: /*#__PURE__*/React.isValidElement(editComponent) && /*#__PURE__*/React.cloneElement(editComponent, {
|
|
13142
|
+
rowData: row,
|
|
13143
|
+
rowIndex: absoluteIndex + 1
|
|
13144
|
+
})
|
|
13145
|
+
})
|
|
13146
|
+
}, `edit-${row._id}`);
|
|
13147
|
+
}
|
|
13148
|
+
return jsxRuntime.jsx(SortableRow, {
|
|
13149
|
+
row: row,
|
|
13150
|
+
index: absoluteIndex,
|
|
13151
|
+
serialNumber: absoluteIndex + 1,
|
|
13152
|
+
columns: columns,
|
|
13153
|
+
tableBodyRowClass: tableBodyRowClass,
|
|
13154
|
+
handleOnclick: handleOnclick,
|
|
13155
|
+
tableDataTextColor: tableDataTextColor,
|
|
13156
|
+
withCheckbox: withCheckbox,
|
|
13157
|
+
onSelectClick: onSelectClick,
|
|
13158
|
+
draggable: draggable,
|
|
13159
|
+
isAccordionOpen: isOpen,
|
|
13160
|
+
accordionContent: accordionContent,
|
|
13161
|
+
isRowCheckBoxDisable: isRowCheckBoxDisable,
|
|
13162
|
+
isRowDisabled: isRowDisabled,
|
|
13163
|
+
freezeColumns: freezeColumns,
|
|
13164
|
+
frozenWidth: frozenWidth,
|
|
13165
|
+
updateRowHeight: updateRowHeight
|
|
13166
|
+
});
|
|
13167
|
+
};
|
|
13003
13168
|
return jsxRuntime.jsx(DndContext, {
|
|
13004
13169
|
collisionDetection: closestCorners,
|
|
13005
13170
|
onDragEnd: handleDragEnd,
|
|
@@ -13008,8 +13173,11 @@ const Table$1 = ({
|
|
|
13008
13173
|
items: data?.map(row => row._id || row.id),
|
|
13009
13174
|
strategy: verticalListSortingStrategy,
|
|
13010
13175
|
children: jsxRuntime.jsxs("div", {
|
|
13176
|
+
ref: setContainerRef,
|
|
13011
13177
|
style: {
|
|
13012
|
-
height
|
|
13178
|
+
height,
|
|
13179
|
+
overflow: 'auto',
|
|
13180
|
+
position: 'relative',
|
|
13013
13181
|
scrollbarWidth: draggable ? 'none' : 'auto',
|
|
13014
13182
|
'--frozen-column-width': freezeColumns ? `${frozenWidth}px` : '0px'
|
|
13015
13183
|
},
|
|
@@ -13018,7 +13186,7 @@ const Table$1 = ({
|
|
|
13018
13186
|
'ff-table-fixed-header': withFixedHeader,
|
|
13019
13187
|
'ff-table-container--border-radius': borderWithRadius
|
|
13020
13188
|
}, className),
|
|
13021
|
-
|
|
13189
|
+
onScroll: handleScroll,
|
|
13022
13190
|
children: [jsxRuntime.jsxs("table", {
|
|
13023
13191
|
className: "ff-table-container",
|
|
13024
13192
|
cellSpacing: 0,
|
|
@@ -13077,46 +13245,38 @@ const Table$1 = ({
|
|
|
13077
13245
|
})
|
|
13078
13246
|
})
|
|
13079
13247
|
}), jsxRuntime.jsxs("tbody", {
|
|
13248
|
+
className: "ff-fixed-header-table",
|
|
13080
13249
|
children: [jsxRuntime.jsx("tr", {
|
|
13081
|
-
id: "ff-table-first-node"
|
|
13082
|
-
|
|
13083
|
-
|
|
13250
|
+
id: "ff-table-first-node",
|
|
13251
|
+
style: {
|
|
13252
|
+
display: 'none'
|
|
13253
|
+
}
|
|
13254
|
+
}), paddingTop > 0 && jsxRuntime.jsx("tr", {
|
|
13255
|
+
children: jsxRuntime.jsx("td", {
|
|
13256
|
+
style: {
|
|
13257
|
+
height: paddingTop,
|
|
13258
|
+
padding: 0
|
|
13259
|
+
},
|
|
13260
|
+
colSpan: columns.length
|
|
13261
|
+
})
|
|
13262
|
+
}), visibleRows.map((row, index) => {
|
|
13263
|
+
const absoluteIndex = startIndex + index;
|
|
13084
13264
|
return jsxRuntime.jsx(React.Fragment, {
|
|
13085
|
-
children:
|
|
13086
|
-
|
|
13087
|
-
|
|
13088
|
-
|
|
13089
|
-
|
|
13090
|
-
|
|
13091
|
-
|
|
13092
|
-
|
|
13093
|
-
|
|
13094
|
-
|
|
13095
|
-
children: editMode && /*#__PURE__*/React.isValidElement(editComponent) && /*#__PURE__*/React.cloneElement(editComponent, {
|
|
13096
|
-
rowData: row,
|
|
13097
|
-
rowIndex: index + 1
|
|
13098
|
-
})
|
|
13099
|
-
})
|
|
13100
|
-
}, row?._id || index) : jsxRuntime.jsx(SortableRow, {
|
|
13101
|
-
row: row,
|
|
13102
|
-
serialNumber: index + 1,
|
|
13103
|
-
columns: columns,
|
|
13104
|
-
tableBodyRowClass: tableBodyRowClass,
|
|
13105
|
-
handleOnclick: handleOnclick,
|
|
13106
|
-
tableDataTextColor: tableDataTextColor,
|
|
13107
|
-
withCheckbox: withCheckbox,
|
|
13108
|
-
onSelectClick: onSelectClick,
|
|
13109
|
-
draggable: draggable,
|
|
13110
|
-
isAccordionOpen: isOpen,
|
|
13111
|
-
accordionContent: accordionContent,
|
|
13112
|
-
isRowCheckBoxDisable: isRowCheckBoxDisable,
|
|
13113
|
-
isRowDisabled: isRowDisabled,
|
|
13114
|
-
freezeColumns: freezeColumns,
|
|
13115
|
-
frozenWidth: frozenWidth
|
|
13116
|
-
})
|
|
13117
|
-
}, row?._id || index);
|
|
13265
|
+
children: renderRow(row, absoluteIndex)
|
|
13266
|
+
}, row._id || absoluteIndex);
|
|
13267
|
+
}), paddingBottom > 0 && jsxRuntime.jsx("tr", {
|
|
13268
|
+
children: jsxRuntime.jsx("td", {
|
|
13269
|
+
style: {
|
|
13270
|
+
height: paddingBottom,
|
|
13271
|
+
padding: 0
|
|
13272
|
+
},
|
|
13273
|
+
colSpan: columns.length
|
|
13274
|
+
})
|
|
13118
13275
|
}), jsxRuntime.jsx("tr", {
|
|
13119
|
-
id: "ff-table-last-node"
|
|
13276
|
+
id: "ff-table-last-node",
|
|
13277
|
+
style: {
|
|
13278
|
+
display: 'none'
|
|
13279
|
+
}
|
|
13120
13280
|
})]
|
|
13121
13281
|
})]
|
|
13122
13282
|
}), data?.length <= 0 && jsxRuntime.jsx("div", {
|
|
@@ -17978,7 +18138,7 @@ const EditLabel = ({
|
|
|
17978
18138
|
return window;
|
|
17979
18139
|
};
|
|
17980
18140
|
React.useEffect(() => {
|
|
17981
|
-
if (!containerRef.current) return;
|
|
18141
|
+
if (!containerRef.current || !isEditing) return;
|
|
17982
18142
|
const scrollableParent = getScrollableParent(containerRef.current);
|
|
17983
18143
|
const handleScroll = () => {
|
|
17984
18144
|
handleCancel();
|
|
@@ -17989,7 +18149,7 @@ const EditLabel = ({
|
|
|
17989
18149
|
return () => {
|
|
17990
18150
|
scrollableParent.removeEventListener('scroll', handleScroll);
|
|
17991
18151
|
};
|
|
17992
|
-
}, []);
|
|
18152
|
+
}, [isEditing]);
|
|
17993
18153
|
React.useEffect(() => {
|
|
17994
18154
|
if (value) {
|
|
17995
18155
|
setText(value);
|
|
@@ -31101,27 +31261,55 @@ const AllProjectsDropdown = ({
|
|
|
31101
31261
|
disabled = false
|
|
31102
31262
|
}) => {
|
|
31103
31263
|
const [showOptions, setShowOptions] = React.useState(false);
|
|
31264
|
+
const [showClicked, setShowClicked] = React.useState(false);
|
|
31104
31265
|
const [selectedOptions, setSelectedOptions] = React.useState(selectedOption);
|
|
31105
31266
|
const optionsRef = React.useRef(null);
|
|
31106
31267
|
const [optionsList, setOptionsList] = React.useState(options);
|
|
31107
31268
|
const [closeTimeout, setCloseTimeout] = React.useState(null);
|
|
31269
|
+
const containerRef = React.useRef(null);
|
|
31270
|
+
const [searchValue, setSearchValue] = React.useState('');
|
|
31271
|
+
const [isSecondClickFromOtherTab, setIsSecondClickFromOtherTab] = React.useState(selected);
|
|
31108
31272
|
React.useEffect(() => {
|
|
31109
31273
|
if (optionsList !== options) {
|
|
31110
31274
|
setOptionsList(options);
|
|
31111
31275
|
}
|
|
31112
31276
|
}, [options]);
|
|
31277
|
+
React.useEffect(() => {
|
|
31278
|
+
if (!selected) {
|
|
31279
|
+
setIsSecondClickFromOtherTab(false);
|
|
31280
|
+
}
|
|
31281
|
+
}, [selected]);
|
|
31113
31282
|
React.useEffect(() => {
|
|
31114
31283
|
if (selectedOption) {
|
|
31115
31284
|
setSelectedOptions(selectedOption);
|
|
31116
31285
|
}
|
|
31117
31286
|
}, [selectedOption]);
|
|
31118
31287
|
const closeOptions = () => {
|
|
31119
|
-
|
|
31120
|
-
|
|
31121
|
-
|
|
31288
|
+
if (showOptions) {
|
|
31289
|
+
setShowOptions(false);
|
|
31290
|
+
}
|
|
31122
31291
|
};
|
|
31123
31292
|
const handleMouseEnter = () => {
|
|
31124
|
-
if (!disabled)
|
|
31293
|
+
if (!disabled) {
|
|
31294
|
+
setShowOptions(true);
|
|
31295
|
+
}
|
|
31296
|
+
if (!disabled && !selected) {
|
|
31297
|
+
setShowOptions(true);
|
|
31298
|
+
}
|
|
31299
|
+
};
|
|
31300
|
+
const handleClick = () => {
|
|
31301
|
+
if (!disabled) {
|
|
31302
|
+
if (showOptions) {
|
|
31303
|
+
setShowOptions(false);
|
|
31304
|
+
}
|
|
31305
|
+
if (!isSecondClickFromOtherTab) {
|
|
31306
|
+
setIsSecondClickFromOtherTab(true);
|
|
31307
|
+
} else {
|
|
31308
|
+
setShowClicked(!showClicked);
|
|
31309
|
+
}
|
|
31310
|
+
}
|
|
31311
|
+
setSearchValue('');
|
|
31312
|
+
setOptionsList(options);
|
|
31125
31313
|
};
|
|
31126
31314
|
const handleMouseLeave = () => {
|
|
31127
31315
|
if (!disabled) {
|
|
@@ -31145,8 +31333,9 @@ const AllProjectsDropdown = ({
|
|
|
31145
31333
|
setSearchValue('');
|
|
31146
31334
|
setOptionsList(options);
|
|
31147
31335
|
}
|
|
31336
|
+
setShowClicked(false);
|
|
31337
|
+
setShowOptions(false);
|
|
31148
31338
|
};
|
|
31149
|
-
const [searchValue, setSearchValue] = React.useState('');
|
|
31150
31339
|
const handleSearch = query => {
|
|
31151
31340
|
if (!disabled) {
|
|
31152
31341
|
setSearchValue(query);
|
|
@@ -31164,11 +31353,13 @@ const AllProjectsDropdown = ({
|
|
|
31164
31353
|
}
|
|
31165
31354
|
}
|
|
31166
31355
|
};
|
|
31167
|
-
useClickOutside(optionsRef,
|
|
31356
|
+
useClickOutside(optionsRef, () => setShowClicked(false), [containerRef]);
|
|
31168
31357
|
return jsxRuntime.jsxs("div", {
|
|
31169
31358
|
className: classNames('ff-all-project', {
|
|
31170
31359
|
'ff-all-project--disabled': disabled
|
|
31171
31360
|
}),
|
|
31361
|
+
ref: containerRef,
|
|
31362
|
+
onClick: handleClick,
|
|
31172
31363
|
onMouseEnter: handleMouseEnter,
|
|
31173
31364
|
onMouseLeave: handleMouseLeave,
|
|
31174
31365
|
children: [jsxRuntime.jsx("div", {
|
|
@@ -31186,23 +31377,26 @@ const AllProjectsDropdown = ({
|
|
|
31186
31377
|
className: classNames('projects-label'),
|
|
31187
31378
|
onClick: onMenuClick,
|
|
31188
31379
|
children: selectedOptions.label.length <= 12 ? selectedOptions.label : truncateText(selectedOptions?.label, 12)
|
|
31189
|
-
}), jsxRuntime.
|
|
31380
|
+
}), jsxRuntime.jsxs("div", {
|
|
31190
31381
|
className: classNames('label-icon'),
|
|
31191
|
-
children: jsxRuntime.jsx(
|
|
31192
|
-
|
|
31382
|
+
children: [jsxRuntime.jsx("div", {
|
|
31383
|
+
className: "icon-click-layer"
|
|
31384
|
+
}), jsxRuntime.jsx(Icon, {
|
|
31385
|
+
name: showOptions || showClicked ? 'arrows_top_icon' : 'arrows_down_icon',
|
|
31193
31386
|
color: disabled ? 'var(--disabled-icon-color)' : 'var(--primary-icon-color)',
|
|
31194
31387
|
height: 8,
|
|
31195
31388
|
width: 8,
|
|
31196
31389
|
hoverEffect: false
|
|
31197
|
-
})
|
|
31390
|
+
})]
|
|
31198
31391
|
})]
|
|
31199
31392
|
})
|
|
31200
|
-
}), showOptions && !disabled && jsxRuntime.jsxs("div", {
|
|
31393
|
+
}), (showOptions || showClicked) && !disabled && jsxRuntime.jsxs("div", {
|
|
31201
31394
|
className: classNames('ff-projects-dropdown'),
|
|
31202
31395
|
ref: optionsRef,
|
|
31203
31396
|
onMouseEnter: dropDownMouseEnter,
|
|
31204
31397
|
children: [jsxRuntime.jsx("div", {
|
|
31205
31398
|
className: "ff-dropdown-search-container",
|
|
31399
|
+
onClick: e => e.stopPropagation(),
|
|
31206
31400
|
children: jsxRuntime.jsx(Search, {
|
|
31207
31401
|
onSearch: handleSearch,
|
|
31208
31402
|
value: searchValue,
|
|
@@ -31217,7 +31411,10 @@ const AllProjectsDropdown = ({
|
|
|
31217
31411
|
}), jsxRuntime.jsx("div", {
|
|
31218
31412
|
className: classNames('option-card'),
|
|
31219
31413
|
children: optionsList.map((option, index) => index === 0 && jsxRuntime.jsxs("div", {
|
|
31220
|
-
onClick:
|
|
31414
|
+
onClick: e => {
|
|
31415
|
+
e.stopPropagation();
|
|
31416
|
+
handleSelectOption(option);
|
|
31417
|
+
},
|
|
31221
31418
|
className: classNames('ff-projects-options', {
|
|
31222
31419
|
['ff-selected-option']: selectedOption.label === option.label,
|
|
31223
31420
|
['ff-option-disabled']: disabled
|
|
@@ -31244,7 +31441,10 @@ const AllProjectsDropdown = ({
|
|
|
31244
31441
|
}), jsxRuntime.jsx("div", {
|
|
31245
31442
|
className: classNames('option-card', `${optionsList.length > 4 ? 'scroll' : ''}`),
|
|
31246
31443
|
children: optionsList.map((option, index) => index > 0 && jsxRuntime.jsxs("div", {
|
|
31247
|
-
onClick:
|
|
31444
|
+
onClick: e => {
|
|
31445
|
+
e.stopPropagation();
|
|
31446
|
+
handleSelectOption(option);
|
|
31447
|
+
},
|
|
31248
31448
|
className: classNames('ff-projects-options', {
|
|
31249
31449
|
['ff-selected-option']: selectedOption.label === option.label,
|
|
31250
31450
|
['ff-option-disabled']: disabled
|
|
@@ -31624,7 +31824,9 @@ const AppHeader = ({
|
|
|
31624
31824
|
disabled = false,
|
|
31625
31825
|
isClient = false,
|
|
31626
31826
|
hideNavbar = false,
|
|
31627
|
-
scriptId
|
|
31827
|
+
scriptId,
|
|
31828
|
+
centerInfoItems = [],
|
|
31829
|
+
rightButtons = []
|
|
31628
31830
|
}) => {
|
|
31629
31831
|
const hiddenMenuRef = React.useRef(null);
|
|
31630
31832
|
const hiddenQuickMenuRef = React.useRef(null);
|
|
@@ -31777,7 +31979,9 @@ const AppHeader = ({
|
|
|
31777
31979
|
children: leftContent
|
|
31778
31980
|
})]
|
|
31779
31981
|
}), jsxRuntime.jsxs("div", {
|
|
31780
|
-
className:
|
|
31982
|
+
className: classNames('ff-app-header-nav-bar', {
|
|
31983
|
+
'ff-app-header-nav-bar--with-center-info': !checkEmpty(centerInfoItems) && !checkEmpty(rightButtons)
|
|
31984
|
+
}),
|
|
31781
31985
|
style: {
|
|
31782
31986
|
width: width,
|
|
31783
31987
|
visibility: checkEmpty(appHeaderMenuItems) && projectDetails?.id === 'All Projects' || hideNavbar ? 'hidden' : 'visible',
|
|
@@ -31785,7 +31989,36 @@ const AppHeader = ({
|
|
|
31785
31989
|
zIndex: 1
|
|
31786
31990
|
},
|
|
31787
31991
|
ref: menuContainerRef,
|
|
31788
|
-
children: [
|
|
31992
|
+
children: [jsxRuntime.jsx("div", {
|
|
31993
|
+
className: classNames('ff-app-header-center-info', {
|
|
31994
|
+
'ff-app-header-center-info--no-right': checkEmpty(rightButtons)
|
|
31995
|
+
}),
|
|
31996
|
+
children: centerInfoItems.map((item, idx) => jsxRuntime.jsxs("div", {
|
|
31997
|
+
className: "ff-app-header-center-info-item",
|
|
31998
|
+
children: [jsxRuntime.jsx(Icon, {
|
|
31999
|
+
name: item.iconName
|
|
32000
|
+
}), jsxRuntime.jsx(Typography, {
|
|
32001
|
+
children: item.label
|
|
32002
|
+
})]
|
|
32003
|
+
}, idx))
|
|
32004
|
+
}), !checkEmpty(rightButtons) && jsxRuntime.jsx("div", {
|
|
32005
|
+
className: "ff-app-header-right-buttons",
|
|
32006
|
+
children: rightButtons.map((btn, index) => jsxRuntime.jsxs("button", {
|
|
32007
|
+
className: "ff-app-header-right-button",
|
|
32008
|
+
style: {
|
|
32009
|
+
color: btn.color,
|
|
32010
|
+
backgroundColor: btn.backgroundColor
|
|
32011
|
+
},
|
|
32012
|
+
onClick: btn.onClick,
|
|
32013
|
+
children: [btn.iconName && jsxRuntime.jsx(Icon, {
|
|
32014
|
+
name: btn.iconName
|
|
32015
|
+
}), jsxRuntime.jsx(Typography, {
|
|
32016
|
+
fontSize: 10,
|
|
32017
|
+
fontWeight: "semi-bold",
|
|
32018
|
+
children: btn.label
|
|
32019
|
+
})]
|
|
32020
|
+
}, index))
|
|
32021
|
+
}), projectArrayList && !checkEmpty(projectArrayList) && jsxRuntime.jsx("div", {
|
|
31789
32022
|
children: jsxRuntime.jsx(AllProjectsDropdown, {
|
|
31790
32023
|
onClick: handleProjectMenuClick,
|
|
31791
32024
|
options: projectArrayList,
|
|
@@ -34891,7 +35124,7 @@ const NlpDropdown = ({
|
|
|
34891
35124
|
const updateDropdownPosition = () => {
|
|
34892
35125
|
let dropdownContainerHeight;
|
|
34893
35126
|
if (checkEmpty(options)) {
|
|
34894
|
-
dropdownContainerHeight = optionHeight + 2 * dropDownWrapperPadding;
|
|
35127
|
+
dropdownContainerHeight = 5 * optionHeight + 2 * dropDownWrapperPadding;
|
|
34895
35128
|
} else if (options.length > 0) {
|
|
34896
35129
|
dropdownContainerHeight = 5 * optionHeight + 2 * dropDownWrapperPadding;
|
|
34897
35130
|
} else {
|
|
@@ -35604,7 +35837,7 @@ const NlpInput = ({
|
|
|
35604
35837
|
}),
|
|
35605
35838
|
style: {
|
|
35606
35839
|
zIndex: optionZIndex,
|
|
35607
|
-
paddingLeft: '
|
|
35840
|
+
paddingLeft: '32px'
|
|
35608
35841
|
},
|
|
35609
35842
|
onFocus: () => handleSelectAction('FOCUS_INPUT'),
|
|
35610
35843
|
onChange: onSelectInputChange,
|
|
@@ -36293,6 +36526,7 @@ const SequentialConnectingBranch = ({
|
|
|
36293
36526
|
return Object.fromEntries(Object.entries(obj).filter(([key]) => !key.includes(substring)));
|
|
36294
36527
|
};
|
|
36295
36528
|
const filteredDataSetValues = removeKeysContainingSubstring(dataSetValues, 'Id');
|
|
36529
|
+
const showBranchPoint = readOnly && !isMachineInstances || !readOnly && isMachineInstances || !readOnly && !isMachineInstances;
|
|
36296
36530
|
return jsxRuntime.jsx(EnvironmentVariableMapsContext.Provider, {
|
|
36297
36531
|
value: environmentVariableMaps,
|
|
36298
36532
|
children: jsxRuntime.jsxs("div", {
|
|
@@ -36319,16 +36553,16 @@ const SequentialConnectingBranch = ({
|
|
|
36319
36553
|
'ff-select-branch-arrow': isMachineInstances,
|
|
36320
36554
|
'ff-select-branch-arrow-down': !isMachineInstances
|
|
36321
36555
|
}),
|
|
36322
|
-
children: [jsxRuntime.jsx("div", {
|
|
36556
|
+
children: [showBranchPoint && jsxRuntime.jsx("div", {
|
|
36323
36557
|
className: "ff-select-branch-point"
|
|
36324
36558
|
}), jsxRuntime.jsxs("div", {
|
|
36325
36559
|
className: "ff-select-branch-arrow",
|
|
36326
|
-
children: [jsxRuntime.jsx("div", {
|
|
36560
|
+
children: [!readOnly && jsxRuntime.jsx("div", {
|
|
36327
36561
|
className: "ff-branch-arrow-wrapper",
|
|
36328
36562
|
children: isMachineInstances && jsxRuntime.jsx("div", {
|
|
36329
36563
|
className: "ff-branch-arrow"
|
|
36330
36564
|
})
|
|
36331
|
-
}), isMachineInstances && jsxRuntime.jsx(jsxRuntime.Fragment, {
|
|
36565
|
+
}), isMachineInstances && !readOnly && jsxRuntime.jsx(jsxRuntime.Fragment, {
|
|
36332
36566
|
children: jsxRuntime.jsx(Button$1, {
|
|
36333
36567
|
variant: "tertiary",
|
|
36334
36568
|
label: scriptType === 'Manual' ? '+ Machine' : '+ Environment',
|
|
@@ -36381,12 +36615,16 @@ const SequentialConnectingBranch = ({
|
|
|
36381
36615
|
children: "Data Set List"
|
|
36382
36616
|
})]
|
|
36383
36617
|
})
|
|
36384
|
-
}), !readOnly && jsxRuntime.jsx(
|
|
36385
|
-
|
|
36386
|
-
|
|
36387
|
-
|
|
36388
|
-
|
|
36389
|
-
|
|
36618
|
+
}), !readOnly && jsxRuntime.jsx(Tooltip, {
|
|
36619
|
+
title: "Delete",
|
|
36620
|
+
placement: "bottom",
|
|
36621
|
+
children: jsxRuntime.jsx(Icon, {
|
|
36622
|
+
name: "delete",
|
|
36623
|
+
className: "ff-run-delete-icon",
|
|
36624
|
+
color: "var(--ff-connecting-branch-delete-color)",
|
|
36625
|
+
onClick: onDeleteMachineInstance,
|
|
36626
|
+
hoverEffect: true
|
|
36627
|
+
})
|
|
36390
36628
|
})]
|
|
36391
36629
|
})]
|
|
36392
36630
|
})]
|
|
@@ -37145,10 +37383,12 @@ const ADD_COLUMN_RIGHT = 'ADD_COLUMN_RIGHT';
|
|
|
37145
37383
|
const DELETE_ROW = 'DELETE_ROW';
|
|
37146
37384
|
const DELETE_COLUMN = 'DELETE_COLUMN';
|
|
37147
37385
|
const SET_ROW_HEIGHT = 'SET_ROW_HEIGHT';
|
|
37386
|
+
const SET_COLUMN_WIDTH = 'SET_COLUMN_WIDTH';
|
|
37148
37387
|
const SET_COLUMN_POSITION = 'SET_COLUMN_POSITION';
|
|
37149
37388
|
const SET_AUTO_FILL = 'SET_AUTO_FILL';
|
|
37150
37389
|
const SET_EDITABLE = 'SET_EDITABLE';
|
|
37151
37390
|
const ON_MOUSE_UP = 'ON_MOUSE_UP';
|
|
37391
|
+
const BATCH_RESIZE = 'BATCH_RESIZE';
|
|
37152
37392
|
function onMouseUp(point) {
|
|
37153
37393
|
return {
|
|
37154
37394
|
type: ON_MOUSE_UP,
|
|
@@ -37182,6 +37422,15 @@ function setRowHeight(row, height) {
|
|
|
37182
37422
|
}
|
|
37183
37423
|
};
|
|
37184
37424
|
}
|
|
37425
|
+
function setColumnWidth(column, width) {
|
|
37426
|
+
return {
|
|
37427
|
+
type: SET_COLUMN_WIDTH,
|
|
37428
|
+
payload: {
|
|
37429
|
+
column,
|
|
37430
|
+
width
|
|
37431
|
+
}
|
|
37432
|
+
};
|
|
37433
|
+
}
|
|
37185
37434
|
function setColumnPosition(column, width) {
|
|
37186
37435
|
return {
|
|
37187
37436
|
type: SET_COLUMN_POSITION,
|
|
@@ -37459,6 +37708,15 @@ function view$1() {
|
|
|
37459
37708
|
type: VIEW
|
|
37460
37709
|
};
|
|
37461
37710
|
}
|
|
37711
|
+
function batchResize(rows, columns) {
|
|
37712
|
+
return {
|
|
37713
|
+
type: BATCH_RESIZE,
|
|
37714
|
+
payload: {
|
|
37715
|
+
rows,
|
|
37716
|
+
columns
|
|
37717
|
+
}
|
|
37718
|
+
};
|
|
37719
|
+
}
|
|
37462
37720
|
function blur$1() {
|
|
37463
37721
|
return {
|
|
37464
37722
|
type: BLUR
|
|
@@ -38353,6 +38611,48 @@ function getMatrixDimensions(matrixData) {
|
|
|
38353
38611
|
columnCount
|
|
38354
38612
|
};
|
|
38355
38613
|
}
|
|
38614
|
+
const textMeasurementCache = new Map();
|
|
38615
|
+
const getFontString = cell => {
|
|
38616
|
+
const style = cell?.style || {};
|
|
38617
|
+
const fontWeight = style.fontWeight || 'normal';
|
|
38618
|
+
const fontStyle = style.fontStyle || 'normal';
|
|
38619
|
+
const fontSize = style.fontSize || '11px';
|
|
38620
|
+
const fontFamily = style.fontFamily || 'Times New Roman';
|
|
38621
|
+
return `${fontStyle} ${fontWeight} ${fontSize} ${fontFamily}`;
|
|
38622
|
+
};
|
|
38623
|
+
const measureText = (text, font) => {
|
|
38624
|
+
const cacheKey = `${text}|${font}`;
|
|
38625
|
+
if (textMeasurementCache.has(cacheKey)) {
|
|
38626
|
+
return textMeasurementCache.get(cacheKey);
|
|
38627
|
+
}
|
|
38628
|
+
const canvas = document.createElement('canvas');
|
|
38629
|
+
const context = canvas.getContext('2d');
|
|
38630
|
+
if (!context) {
|
|
38631
|
+
// Fallback calculation
|
|
38632
|
+
const fallbackWidth = text.length * 8;
|
|
38633
|
+
textMeasurementCache.set(cacheKey, fallbackWidth);
|
|
38634
|
+
return fallbackWidth;
|
|
38635
|
+
}
|
|
38636
|
+
context.font = font;
|
|
38637
|
+
const lines = text.split('\n');
|
|
38638
|
+
let maxWidth = 0;
|
|
38639
|
+
lines.forEach(line => {
|
|
38640
|
+
const metrics = context.measureText(line);
|
|
38641
|
+
maxWidth = Math.max(maxWidth, metrics.width);
|
|
38642
|
+
});
|
|
38643
|
+
textMeasurementCache.set(cacheKey, maxWidth);
|
|
38644
|
+
return maxWidth;
|
|
38645
|
+
};
|
|
38646
|
+
const resizeDebounceTimers = new Map();
|
|
38647
|
+
const debouncedResize = (key, callback, delay = 100) => {
|
|
38648
|
+
if (resizeDebounceTimers.has(key)) {
|
|
38649
|
+
clearTimeout(resizeDebounceTimers.get(key));
|
|
38650
|
+
}
|
|
38651
|
+
resizeDebounceTimers.set(key, setTimeout(() => {
|
|
38652
|
+
callback();
|
|
38653
|
+
resizeDebounceTimers.delete(key);
|
|
38654
|
+
}, delay));
|
|
38655
|
+
};
|
|
38356
38656
|
|
|
38357
38657
|
const FORMULA_VALUE_PREFIX = '=';
|
|
38358
38658
|
/** Returns whether given value is a formula */
|
|
@@ -39902,9 +40202,59 @@ function reducer(state, action) {
|
|
|
39902
40202
|
} = action.payload;
|
|
39903
40203
|
const selectedRange = state.selected.toRange(state.model.data);
|
|
39904
40204
|
const updatedData = applyFontSize(state.model.data, selectedRange, value, state.editable);
|
|
40205
|
+
const updatedModel = new Model(state.model.createFormulaParser, updatedData);
|
|
40206
|
+
// Auto-resize all rows and columns on initial load
|
|
40207
|
+
let newRowDimensions = {
|
|
40208
|
+
...state.rowDimensions
|
|
40209
|
+
};
|
|
40210
|
+
let newColumnDimensions = {
|
|
40211
|
+
...state.columnDimensions
|
|
40212
|
+
};
|
|
40213
|
+
// Auto-resize all rows
|
|
40214
|
+
updatedData.forEach((rowData, rowIndex) => {
|
|
40215
|
+
let maxHeight = 32; // Default row height
|
|
40216
|
+
rowData.forEach((cell, _colIndex) => {
|
|
40217
|
+
if (cell && cell.value) {
|
|
40218
|
+
const fontSize = cell.style?.fontSize ? parseInt(cell.style.fontSize.toString().replace('px', '')) : 11;
|
|
40219
|
+
const lineHeight = Math.max(fontSize * 1.2, 18);
|
|
40220
|
+
const lines = String(cell.value).split('\n').length;
|
|
40221
|
+
const cellHeight = lineHeight * lines + 10;
|
|
40222
|
+
maxHeight = Math.max(Number(cell?.style?.height) ?? maxHeight, cellHeight);
|
|
40223
|
+
}
|
|
40224
|
+
});
|
|
40225
|
+
newRowDimensions[rowIndex] = {
|
|
40226
|
+
...(newRowDimensions[rowIndex] || {
|
|
40227
|
+
top: 0,
|
|
40228
|
+
height: 32
|
|
40229
|
+
}),
|
|
40230
|
+
height: maxHeight
|
|
40231
|
+
};
|
|
40232
|
+
});
|
|
40233
|
+
// Auto-resize all columns
|
|
40234
|
+
const columnCount = updatedData[0] ? updatedData[0].length : 0;
|
|
40235
|
+
for (let col = 0; col < columnCount; col++) {
|
|
40236
|
+
let maxWidth = 100; // Default column width
|
|
40237
|
+
updatedData.forEach((rowData, _rowIndex) => {
|
|
40238
|
+
const cell = rowData[col];
|
|
40239
|
+
if (cell && cell.value && !['file'].includes(cell?.inputType?.type ?? 'text')) {
|
|
40240
|
+
const font = getFontString(cell);
|
|
40241
|
+
const textWidth = measureText(String(cell.value), font) + 20;
|
|
40242
|
+
maxWidth = Math.max(Number(cell?.style?.width) ?? maxWidth, textWidth);
|
|
40243
|
+
}
|
|
40244
|
+
});
|
|
40245
|
+
newColumnDimensions[col] = {
|
|
40246
|
+
...(newColumnDimensions[col] || {
|
|
40247
|
+
left: 0,
|
|
40248
|
+
width: 100
|
|
40249
|
+
}),
|
|
40250
|
+
width: maxWidth
|
|
40251
|
+
};
|
|
40252
|
+
}
|
|
39905
40253
|
return {
|
|
39906
40254
|
...state,
|
|
39907
|
-
model:
|
|
40255
|
+
model: updatedModel,
|
|
40256
|
+
rowDimensions: newRowDimensions,
|
|
40257
|
+
columnDimensions: newColumnDimensions
|
|
39908
40258
|
};
|
|
39909
40259
|
}
|
|
39910
40260
|
case FONT_FAMILY:
|
|
@@ -39993,11 +40343,61 @@ function reducer(state, action) {
|
|
|
39993
40343
|
} = action.payload;
|
|
39994
40344
|
const nextActive = state.active && has$1(state.active, data) ? state.active : null;
|
|
39995
40345
|
const nextSelected = state.selected.normalizeTo(data);
|
|
40346
|
+
const updatedModel = new Model(state.model.createFormulaParser, data);
|
|
40347
|
+
// Auto-resize all rows and columns on initial load
|
|
40348
|
+
let newRowDimensions = {
|
|
40349
|
+
...state.rowDimensions
|
|
40350
|
+
};
|
|
40351
|
+
let newColumnDimensions = {
|
|
40352
|
+
...state.columnDimensions
|
|
40353
|
+
};
|
|
40354
|
+
// Auto-resize all rows
|
|
40355
|
+
data.forEach((rowData, rowIndex) => {
|
|
40356
|
+
let maxHeight = 32; // Default row height
|
|
40357
|
+
rowData.forEach((cell, _colIndex) => {
|
|
40358
|
+
if (cell && cell.value) {
|
|
40359
|
+
const fontSize = cell.style?.fontSize ? parseInt(cell.style.fontSize.toString().replace('px', '')) : 11;
|
|
40360
|
+
const lineHeight = Math.max(fontSize * 1.2, 18);
|
|
40361
|
+
const lines = String(cell.value).split('\n').length;
|
|
40362
|
+
const cellHeight = lineHeight * lines + 10;
|
|
40363
|
+
maxHeight = Math.max(Number(cell?.style?.height) ?? maxHeight, cellHeight);
|
|
40364
|
+
}
|
|
40365
|
+
});
|
|
40366
|
+
newRowDimensions[rowIndex] = {
|
|
40367
|
+
...(newRowDimensions[rowIndex] || {
|
|
40368
|
+
top: 0,
|
|
40369
|
+
height: 32
|
|
40370
|
+
}),
|
|
40371
|
+
height: maxHeight
|
|
40372
|
+
};
|
|
40373
|
+
});
|
|
40374
|
+
// Auto-resize all columns
|
|
40375
|
+
const columnCount = data[0] ? data[0].length : 0;
|
|
40376
|
+
for (let col = 0; col < columnCount; col++) {
|
|
40377
|
+
let maxWidth = 100; // Default column width
|
|
40378
|
+
data.forEach((rowData, _rowIndex) => {
|
|
40379
|
+
const cell = rowData[col];
|
|
40380
|
+
if (cell && cell.value && !['file'].includes(cell?.inputType?.type ?? 'text')) {
|
|
40381
|
+
const font = getFontString(cell);
|
|
40382
|
+
const textWidth = measureText(String(cell.value), font) + 20;
|
|
40383
|
+
maxWidth = Math.max(Number(cell?.style?.width) ?? maxWidth, textWidth);
|
|
40384
|
+
}
|
|
40385
|
+
});
|
|
40386
|
+
newColumnDimensions[col] = {
|
|
40387
|
+
...(newColumnDimensions[col] || {
|
|
40388
|
+
left: 0,
|
|
40389
|
+
width: 100
|
|
40390
|
+
}),
|
|
40391
|
+
width: maxWidth
|
|
40392
|
+
};
|
|
40393
|
+
}
|
|
39996
40394
|
return {
|
|
39997
40395
|
...state,
|
|
39998
|
-
model:
|
|
40396
|
+
model: updatedModel,
|
|
39999
40397
|
active: nextActive,
|
|
40000
|
-
selected: nextSelected
|
|
40398
|
+
selected: nextSelected,
|
|
40399
|
+
rowDimensions: newRowDimensions,
|
|
40400
|
+
columnDimensions: newColumnDimensions
|
|
40001
40401
|
};
|
|
40002
40402
|
}
|
|
40003
40403
|
case SET_CREATE_FORMULA_PARSER:
|
|
@@ -40114,9 +40514,64 @@ function reducer(state, action) {
|
|
|
40114
40514
|
if (isActiveReadOnly(state) || !state.editable) {
|
|
40115
40515
|
return state;
|
|
40116
40516
|
}
|
|
40517
|
+
const updatedModel = updateCellValue(state.model, active, cellData);
|
|
40518
|
+
// Only auto-resize if the cell value actually changed
|
|
40519
|
+
const previousCell = get$1(active, state.model.data);
|
|
40520
|
+
const valueChanged = previousCell?.value !== cellData.value;
|
|
40521
|
+
let newRowDimensions = {
|
|
40522
|
+
...state.rowDimensions
|
|
40523
|
+
};
|
|
40524
|
+
let newColumnDimensions = {
|
|
40525
|
+
...state.columnDimensions
|
|
40526
|
+
};
|
|
40527
|
+
if (valueChanged) {
|
|
40528
|
+
debouncedResize(`resize-${active.row}-${active.column}`, () => {
|
|
40529
|
+
// Auto-resize row
|
|
40530
|
+
const rowData = updatedModel.data[active.row] || [];
|
|
40531
|
+
let maxRowHeight = 32; // Default row height
|
|
40532
|
+
// Only check this row's cells for height calculation
|
|
40533
|
+
rowData.forEach((cell, _colIndex) => {
|
|
40534
|
+
if (cell && cell.value) {
|
|
40535
|
+
const fontSize = cell.style?.fontSize ? parseInt(cell.style.fontSize.toString().replace('px', '')) : 11;
|
|
40536
|
+
const lineHeight = Math.max(fontSize * 1.2, 18);
|
|
40537
|
+
const lines = String(cell.value).split('\n').length;
|
|
40538
|
+
const cellHeight = lineHeight * lines + 10;
|
|
40539
|
+
maxRowHeight = Math.max(Number(cell?.style?.height) ?? maxRowHeight, cellHeight);
|
|
40540
|
+
}
|
|
40541
|
+
});
|
|
40542
|
+
newRowDimensions[active.row] = {
|
|
40543
|
+
...(newRowDimensions[active.row] || {
|
|
40544
|
+
top: 0,
|
|
40545
|
+
height: 32
|
|
40546
|
+
}),
|
|
40547
|
+
height: maxRowHeight
|
|
40548
|
+
};
|
|
40549
|
+
// Auto-resize column
|
|
40550
|
+
let maxColWidth = 100; // Default column width
|
|
40551
|
+
// Only check this column's cells for width calculation
|
|
40552
|
+
updatedModel.data.forEach((rowData, _rowIndex) => {
|
|
40553
|
+
const cell = rowData[active.column];
|
|
40554
|
+
if (cell && cell.value && !['file'].includes(cell?.inputType?.type ?? 'text')) {
|
|
40555
|
+
const font = getFontString(cell);
|
|
40556
|
+
const textWidth = measureText(String(cell.value), font) + 20;
|
|
40557
|
+
maxColWidth = Math.max(Number(cell?.style?.width) ?? maxColWidth, textWidth);
|
|
40558
|
+
}
|
|
40559
|
+
});
|
|
40560
|
+
newColumnDimensions[active.column] = {
|
|
40561
|
+
...(newColumnDimensions[active.column] || {
|
|
40562
|
+
left: 0,
|
|
40563
|
+
width: 100
|
|
40564
|
+
}),
|
|
40565
|
+
width: maxColWidth
|
|
40566
|
+
};
|
|
40567
|
+
}, 300 // 300ms delay
|
|
40568
|
+
);
|
|
40569
|
+
}
|
|
40117
40570
|
return {
|
|
40118
40571
|
...state,
|
|
40119
|
-
model:
|
|
40572
|
+
model: updatedModel,
|
|
40573
|
+
rowDimensions: newRowDimensions,
|
|
40574
|
+
columnDimensions: newColumnDimensions,
|
|
40120
40575
|
lastChanged: active
|
|
40121
40576
|
};
|
|
40122
40577
|
}
|
|
@@ -40126,28 +40581,61 @@ function reducer(state, action) {
|
|
|
40126
40581
|
point,
|
|
40127
40582
|
dimensions
|
|
40128
40583
|
} = action.payload;
|
|
40129
|
-
|
|
40130
|
-
|
|
40131
|
-
|
|
40132
|
-
|
|
40133
|
-
|
|
40134
|
-
|
|
40135
|
-
...
|
|
40136
|
-
|
|
40137
|
-
|
|
40138
|
-
|
|
40139
|
-
|
|
40140
|
-
|
|
40584
|
+
let newState = {
|
|
40585
|
+
...state
|
|
40586
|
+
};
|
|
40587
|
+
let updatedData = state.model.data;
|
|
40588
|
+
const cell = get$1(point, updatedData) || EmptyCell;
|
|
40589
|
+
const newStyle = {
|
|
40590
|
+
...cell.style
|
|
40591
|
+
};
|
|
40592
|
+
let styleChanged = false;
|
|
40593
|
+
if (dimensions.width !== undefined) {
|
|
40594
|
+
newStyle.width = dimensions.width;
|
|
40595
|
+
styleChanged = true;
|
|
40596
|
+
}
|
|
40597
|
+
if (dimensions.height !== undefined) {
|
|
40598
|
+
newStyle.height = dimensions.height;
|
|
40599
|
+
styleChanged = true;
|
|
40600
|
+
}
|
|
40601
|
+
if (styleChanged) {
|
|
40602
|
+
const newCell = {
|
|
40603
|
+
...cell,
|
|
40604
|
+
style: newStyle
|
|
40605
|
+
};
|
|
40606
|
+
updatedData = set$1(point, newCell, updatedData);
|
|
40607
|
+
}
|
|
40608
|
+
const updatedModel = new Model(state.model.createFormulaParser, updatedData);
|
|
40609
|
+
// Update column dimensions if width/left provided
|
|
40610
|
+
if (dimensions.width !== undefined && dimensions.left !== undefined) {
|
|
40611
|
+
newState = {
|
|
40612
|
+
...newState,
|
|
40613
|
+
columnDimensions: {
|
|
40614
|
+
...state.columnDimensions,
|
|
40615
|
+
[point.column]: {
|
|
40616
|
+
left: dimensions.left,
|
|
40617
|
+
width: dimensions.width
|
|
40618
|
+
}
|
|
40141
40619
|
}
|
|
40142
|
-
}
|
|
40143
|
-
|
|
40144
|
-
|
|
40145
|
-
|
|
40146
|
-
|
|
40147
|
-
|
|
40620
|
+
};
|
|
40621
|
+
}
|
|
40622
|
+
// Update row dimensions if height/top provided
|
|
40623
|
+
if (dimensions.top !== undefined && dimensions.height !== undefined) {
|
|
40624
|
+
newState = {
|
|
40625
|
+
...newState,
|
|
40626
|
+
rowDimensions: {
|
|
40627
|
+
...state.rowDimensions,
|
|
40628
|
+
[point.row]: {
|
|
40629
|
+
top: dimensions.top,
|
|
40630
|
+
height: dimensions.height
|
|
40631
|
+
}
|
|
40148
40632
|
}
|
|
40149
|
-
}
|
|
40150
|
-
}
|
|
40633
|
+
};
|
|
40634
|
+
}
|
|
40635
|
+
return {
|
|
40636
|
+
...newState,
|
|
40637
|
+
model: updatedModel
|
|
40638
|
+
}; // Include updated model
|
|
40151
40639
|
}
|
|
40152
40640
|
case COPY:
|
|
40153
40641
|
case CUT:
|
|
@@ -40277,9 +40765,36 @@ function reducer(state, action) {
|
|
|
40277
40765
|
{
|
|
40278
40766
|
return view(state);
|
|
40279
40767
|
}
|
|
40768
|
+
// In reducer.ts, update the CLEAR action for better performance
|
|
40280
40769
|
case CLEAR:
|
|
40281
40770
|
{
|
|
40282
|
-
|
|
40771
|
+
const selectedRange = state.selected.toRange(state.model.data);
|
|
40772
|
+
if (!selectedRange || !state.editable) {
|
|
40773
|
+
return state;
|
|
40774
|
+
}
|
|
40775
|
+
let updatedData = state.model.data;
|
|
40776
|
+
const commit = [];
|
|
40777
|
+
// Track which rows and columns were cleared
|
|
40778
|
+
const clearedRows = new Set();
|
|
40779
|
+
const clearedColumns = new Set();
|
|
40780
|
+
for (const point of selectedRange) {
|
|
40781
|
+
const cell = get$1(point, updatedData) || null;
|
|
40782
|
+
commit.push({
|
|
40783
|
+
prevCell: cell,
|
|
40784
|
+
nextCell: null
|
|
40785
|
+
});
|
|
40786
|
+
updatedData = set$1(point, EmptyCell, updatedData);
|
|
40787
|
+
// Track cleared rows and columns
|
|
40788
|
+
clearedRows.add(point.row);
|
|
40789
|
+
clearedColumns.add(point.column);
|
|
40790
|
+
}
|
|
40791
|
+
const updatedModel = new Model(state.model.createFormulaParser, updatedData);
|
|
40792
|
+
// Use batch resize for better performance
|
|
40793
|
+
return reducer({
|
|
40794
|
+
...state,
|
|
40795
|
+
model: updatedModel,
|
|
40796
|
+
lastCommit: commit
|
|
40797
|
+
}, batchResize(Array.from(clearedRows), Array.from(clearedColumns)));
|
|
40283
40798
|
}
|
|
40284
40799
|
case BLUR:
|
|
40285
40800
|
{
|
|
@@ -40325,23 +40840,56 @@ function reducer(state, action) {
|
|
|
40325
40840
|
}
|
|
40326
40841
|
return state;
|
|
40327
40842
|
}
|
|
40328
|
-
case
|
|
40843
|
+
case SET_COLUMN_WIDTH:
|
|
40329
40844
|
{
|
|
40330
40845
|
const {
|
|
40331
|
-
|
|
40332
|
-
|
|
40846
|
+
column,
|
|
40847
|
+
width
|
|
40333
40848
|
} = action.payload;
|
|
40334
|
-
const prevDimensions = state.
|
|
40335
|
-
|
|
40849
|
+
const prevDimensions = state.columnDimensions[column] || {
|
|
40850
|
+
left: 0};
|
|
40851
|
+
// Narrow first
|
|
40852
|
+
if (!state.model.data) {
|
|
40853
|
+
return {
|
|
40854
|
+
...state,
|
|
40855
|
+
columnDimensions: {
|
|
40856
|
+
...state.columnDimensions,
|
|
40857
|
+
[column]: {
|
|
40858
|
+
left: prevDimensions.left,
|
|
40859
|
+
width
|
|
40860
|
+
}
|
|
40861
|
+
}
|
|
40862
|
+
};
|
|
40863
|
+
}
|
|
40864
|
+
let updatedData = state.model.data ?? [];
|
|
40865
|
+
for (let r = 0; r < updatedData.length; r++) {
|
|
40866
|
+
if (updatedData[r] && updatedData?.[r]?.length > column) {
|
|
40867
|
+
const point = {
|
|
40868
|
+
row: r,
|
|
40869
|
+
column
|
|
40870
|
+
};
|
|
40871
|
+
const cell = get$1(point, updatedData) ?? EmptyCell;
|
|
40872
|
+
const newCell = {
|
|
40873
|
+
...cell,
|
|
40874
|
+
style: {
|
|
40875
|
+
...(cell.style ?? {}),
|
|
40876
|
+
width
|
|
40877
|
+
}
|
|
40878
|
+
};
|
|
40879
|
+
updatedData = set$1(point, newCell, updatedData);
|
|
40880
|
+
}
|
|
40881
|
+
}
|
|
40882
|
+
const updatedModel = new Model(state.model.createFormulaParser, updatedData);
|
|
40336
40883
|
return {
|
|
40337
40884
|
...state,
|
|
40338
|
-
|
|
40339
|
-
...state.
|
|
40340
|
-
[
|
|
40341
|
-
|
|
40342
|
-
|
|
40885
|
+
columnDimensions: {
|
|
40886
|
+
...state.columnDimensions,
|
|
40887
|
+
[column]: {
|
|
40888
|
+
left: prevDimensions.left,
|
|
40889
|
+
width
|
|
40343
40890
|
}
|
|
40344
|
-
}
|
|
40891
|
+
},
|
|
40892
|
+
model: updatedModel
|
|
40345
40893
|
};
|
|
40346
40894
|
}
|
|
40347
40895
|
case SET_COLUMN_POSITION:
|
|
@@ -40479,6 +41027,69 @@ function reducer(state, action) {
|
|
|
40479
41027
|
...commit(changes)
|
|
40480
41028
|
};
|
|
40481
41029
|
}
|
|
41030
|
+
case BATCH_RESIZE:
|
|
41031
|
+
{
|
|
41032
|
+
const {
|
|
41033
|
+
rows,
|
|
41034
|
+
columns
|
|
41035
|
+
} = action.payload;
|
|
41036
|
+
const {
|
|
41037
|
+
model,
|
|
41038
|
+
rowDimensions,
|
|
41039
|
+
columnDimensions
|
|
41040
|
+
} = state;
|
|
41041
|
+
let newRowDimensions = {
|
|
41042
|
+
...rowDimensions
|
|
41043
|
+
};
|
|
41044
|
+
let newColumnDimensions = {
|
|
41045
|
+
...columnDimensions
|
|
41046
|
+
};
|
|
41047
|
+
// Resize specified rows
|
|
41048
|
+
rows.forEach(row => {
|
|
41049
|
+
const rowData = model.data[row] || [];
|
|
41050
|
+
let maxHeight = 32;
|
|
41051
|
+
rowData.forEach((cell, _colIndex) => {
|
|
41052
|
+
if (cell && cell.value) {
|
|
41053
|
+
const fontSize = cell.style?.fontSize ? parseInt(cell.style.fontSize.toString().replace('px', '')) : 11;
|
|
41054
|
+
const lineHeight = Math.max(fontSize * 1.2, 18);
|
|
41055
|
+
const lines = String(cell.value).split('\n').length;
|
|
41056
|
+
const cellHeight = lineHeight * lines + 10;
|
|
41057
|
+
maxHeight = Math.max(Number(cell?.style?.height) ?? maxHeight, cellHeight);
|
|
41058
|
+
}
|
|
41059
|
+
});
|
|
41060
|
+
newRowDimensions[row] = {
|
|
41061
|
+
...(newRowDimensions[row] || {
|
|
41062
|
+
top: 0,
|
|
41063
|
+
height: 32
|
|
41064
|
+
}),
|
|
41065
|
+
height: maxHeight
|
|
41066
|
+
};
|
|
41067
|
+
});
|
|
41068
|
+
// Resize specified columns
|
|
41069
|
+
columns.forEach(col => {
|
|
41070
|
+
let maxWidth = 100;
|
|
41071
|
+
model.data.forEach((rowData, _rowIndex) => {
|
|
41072
|
+
const cell = rowData[col];
|
|
41073
|
+
if (cell && cell.value && !['file'].includes(cell?.inputType?.type ?? 'text')) {
|
|
41074
|
+
const font = getFontString(cell);
|
|
41075
|
+
const textWidth = measureText(String(cell.value), font) + 20;
|
|
41076
|
+
maxWidth = Math.max(Number(cell?.style?.width) ?? maxWidth, textWidth);
|
|
41077
|
+
}
|
|
41078
|
+
});
|
|
41079
|
+
newColumnDimensions[col] = {
|
|
41080
|
+
...(newColumnDimensions[col] || {
|
|
41081
|
+
left: 0,
|
|
41082
|
+
width: 100
|
|
41083
|
+
}),
|
|
41084
|
+
width: maxWidth
|
|
41085
|
+
};
|
|
41086
|
+
});
|
|
41087
|
+
return {
|
|
41088
|
+
...state,
|
|
41089
|
+
rowDimensions: newRowDimensions,
|
|
41090
|
+
columnDimensions: newColumnDimensions
|
|
41091
|
+
};
|
|
41092
|
+
}
|
|
40482
41093
|
default:
|
|
40483
41094
|
throw new Error('Unknown action');
|
|
40484
41095
|
}
|
|
@@ -41831,8 +42442,7 @@ const ColumnIndicator = ({
|
|
|
41831
42442
|
const dispatch = useDispatch();
|
|
41832
42443
|
const excelData = useSelector(state => state.model.data);
|
|
41833
42444
|
const activeCell = useSelector(state => state.active);
|
|
41834
|
-
const minColumnWidth = minimumColumnWidth;
|
|
41835
|
-
const columnWidth = useSelector(state => state.columnDimensions[column]?.width || minColumnWidth);
|
|
42445
|
+
const minColumnWidth = minimumColumnWidth ?? 100;
|
|
41836
42446
|
const matrixData = useSelector(state => state.model.data);
|
|
41837
42447
|
const {
|
|
41838
42448
|
columnCount
|
|
@@ -41861,6 +42471,7 @@ const ColumnIndicator = ({
|
|
|
41861
42471
|
return value;
|
|
41862
42472
|
});
|
|
41863
42473
|
};
|
|
42474
|
+
const columnWidth = useSelector(state => state.columnDimensions[column]?.width ?? minColumnWidth);
|
|
41864
42475
|
const options = React.useMemo(() => {
|
|
41865
42476
|
const checkVisible = cell?.contextDisable?.['Delete Column'] && isCellDataChanged();
|
|
41866
42477
|
return [{
|
|
@@ -41901,15 +42512,17 @@ const ColumnIndicator = ({
|
|
|
41901
42512
|
disable: false
|
|
41902
42513
|
}] : [])];
|
|
41903
42514
|
}, [selectedColumn, cell, addColumnLeft, addColumnRight, deleteColumn, minColumnWidth, columnCount, maxColLimit, disableDeleteOption, onAddColumn, onDeleteColumn, column, isCellDataChanged]);
|
|
42515
|
+
const MIN_COLUMN_WIDTH = minimumColumnWidth || 100;
|
|
41904
42516
|
const onMouseDrag = React__namespace.useCallback((event, isRight) => {
|
|
41905
42517
|
const getTargetColumn = isRight ? column - 1 : column;
|
|
41906
42518
|
const targetColumn = Math.max(getTargetColumn, 0);
|
|
41907
42519
|
onSelect(targetColumn, event.shiftKey);
|
|
41908
42520
|
const startX = event.clientX;
|
|
41909
|
-
const initialWidth = columnWidth;
|
|
42521
|
+
const initialWidth = Number(columnWidth);
|
|
41910
42522
|
const onMouseMove = moveEvent => {
|
|
41911
|
-
const
|
|
41912
|
-
|
|
42523
|
+
const delta = moveEvent.clientX - startX;
|
|
42524
|
+
const newWidth = Math.max(MIN_COLUMN_WIDTH, initialWidth + delta);
|
|
42525
|
+
dispatch(setColumnWidth(targetColumn, newWidth));
|
|
41913
42526
|
};
|
|
41914
42527
|
const onMouseUp = () => {
|
|
41915
42528
|
document.removeEventListener('mousemove', onMouseMove);
|
|
@@ -41946,9 +42559,6 @@ const ColumnIndicator = ({
|
|
|
41946
42559
|
className: classNames('ff-spreadsheet-header', {
|
|
41947
42560
|
'ff-spreadsheet-header--selected': selected
|
|
41948
42561
|
}),
|
|
41949
|
-
style: {
|
|
41950
|
-
minWidth: `${columnWidth}px`
|
|
41951
|
-
},
|
|
41952
42562
|
onClick: handleClick,
|
|
41953
42563
|
onContextMenu: contextClick,
|
|
41954
42564
|
tabIndex: 0,
|
|
@@ -42074,6 +42684,7 @@ const RowIndicator = ({
|
|
|
42074
42684
|
disable: false
|
|
42075
42685
|
}] : [])];
|
|
42076
42686
|
}, [selectedRow, row]);
|
|
42687
|
+
const MIN_ROW_HEIGHT = 32;
|
|
42077
42688
|
const handleMouseDrag = React__namespace.useCallback((event, isUp) => {
|
|
42078
42689
|
const getTargetRow = isUp ? row : row - 1;
|
|
42079
42690
|
const targetRow = Math.max(getTargetRow, 0);
|
|
@@ -42081,17 +42692,17 @@ const RowIndicator = ({
|
|
|
42081
42692
|
const startY = event.clientY;
|
|
42082
42693
|
const initialHeight = rowHeight;
|
|
42083
42694
|
const onMouseMove = moveEvent => {
|
|
42084
|
-
const
|
|
42695
|
+
const delta = moveEvent.clientY - startY;
|
|
42696
|
+
const newHeight = Math.max(MIN_ROW_HEIGHT, initialHeight + delta);
|
|
42085
42697
|
dispatch(setRowHeight(targetRow, newHeight));
|
|
42086
42698
|
};
|
|
42087
42699
|
const onMouseUp = () => {
|
|
42088
42700
|
document.removeEventListener('mousemove', onMouseMove);
|
|
42089
42701
|
document.removeEventListener('mouseup', onMouseUp);
|
|
42090
|
-
dispatch(dragEnd());
|
|
42702
|
+
dispatch(dragEnd()); // only at end
|
|
42091
42703
|
};
|
|
42092
42704
|
document.addEventListener('mousemove', onMouseMove);
|
|
42093
42705
|
document.addEventListener('mouseup', onMouseUp);
|
|
42094
|
-
dispatch(dragEnd());
|
|
42095
42706
|
}, [rowHeight, row]);
|
|
42096
42707
|
const activate$1 = React__namespace.useCallback(point => dispatch(activate(point)), [dispatch]);
|
|
42097
42708
|
const handleClick = React__namespace.useCallback(event => {
|
|
@@ -42132,7 +42743,7 @@ const RowIndicator = ({
|
|
|
42132
42743
|
}), jsxRuntime.jsx("div", {
|
|
42133
42744
|
className: "drag-row-selector drag-row-down",
|
|
42134
42745
|
onMouseDown: e => handleMouseDrag(e, true),
|
|
42135
|
-
onDoubleClick: () => dispatch(setRowHeight(row,
|
|
42746
|
+
onDoubleClick: () => dispatch(setRowHeight(row, rowHeight)),
|
|
42136
42747
|
onClick: () => activate$1({
|
|
42137
42748
|
row,
|
|
42138
42749
|
column: -1
|
|
@@ -42140,7 +42751,7 @@ const RowIndicator = ({
|
|
|
42140
42751
|
}), jsxRuntime.jsx("div", {
|
|
42141
42752
|
className: "drag-row-selector drag-row-up",
|
|
42142
42753
|
onMouseDown: e => handleMouseDrag(e, false),
|
|
42143
|
-
onDoubleClick: () => dispatch(setRowHeight(row,
|
|
42754
|
+
onDoubleClick: () => dispatch(setRowHeight(row, rowHeight)),
|
|
42144
42755
|
onClick: () => activate$1({
|
|
42145
42756
|
row,
|
|
42146
42757
|
column: -1
|
|
@@ -42207,13 +42818,14 @@ const Cell = ({
|
|
|
42207
42818
|
const root = rootRef.current;
|
|
42208
42819
|
if (!root) return;
|
|
42209
42820
|
const updateDimensions = () => {
|
|
42821
|
+
if (dragging) return;
|
|
42210
42822
|
setCellDimensions(point, getOffsetRect(root));
|
|
42211
42823
|
};
|
|
42212
42824
|
updateDimensions();
|
|
42213
42825
|
const observer = new ResizeObserver(updateDimensions);
|
|
42214
42826
|
observer.observe(root);
|
|
42215
42827
|
return () => observer.disconnect();
|
|
42216
|
-
}, [setCellDimensions, point]);
|
|
42828
|
+
}, [setCellDimensions, point, dragging]);
|
|
42217
42829
|
if (data && data.DataViewer) {
|
|
42218
42830
|
DataViewer = data.DataViewer;
|
|
42219
42831
|
}
|
|
@@ -42354,21 +42966,64 @@ const DataEditor = ({
|
|
|
42354
42966
|
}
|
|
42355
42967
|
});
|
|
42356
42968
|
}, [onChange, cell]);
|
|
42969
|
+
const handleKeyDown = React__namespace.useCallback(event => {
|
|
42970
|
+
if (event.key === 'Delete' || event.key === 'Backspace') {
|
|
42971
|
+
event.stopPropagation();
|
|
42972
|
+
requestAnimationFrame(() => {
|
|
42973
|
+
if (inputRef.current) {
|
|
42974
|
+
const textarea = inputRef.current;
|
|
42975
|
+
textarea.style.height = 'auto';
|
|
42976
|
+
textarea.style.height = `${textarea.scrollHeight}px`;
|
|
42977
|
+
}
|
|
42978
|
+
});
|
|
42979
|
+
}
|
|
42980
|
+
if (event.key === 'Enter' && event.altKey) {
|
|
42981
|
+
event.preventDefault();
|
|
42982
|
+
event.stopPropagation();
|
|
42983
|
+
const textarea = event.currentTarget;
|
|
42984
|
+
const {
|
|
42985
|
+
selectionStart,
|
|
42986
|
+
selectionEnd,
|
|
42987
|
+
value
|
|
42988
|
+
} = textarea;
|
|
42989
|
+
const newValue = value.substring(0, selectionStart) + '\n' + value.substring(selectionEnd);
|
|
42990
|
+
onChange({
|
|
42991
|
+
...cell,
|
|
42992
|
+
value: newValue,
|
|
42993
|
+
style: cell?.style,
|
|
42994
|
+
inputType: cell?.inputType ?? {
|
|
42995
|
+
type: 'text'
|
|
42996
|
+
}
|
|
42997
|
+
});
|
|
42998
|
+
requestAnimationFrame(() => {
|
|
42999
|
+
textarea.selectionStart = textarea.selectionEnd = selectionStart + 1;
|
|
43000
|
+
textarea.style.height = 'auto';
|
|
43001
|
+
textarea.style.height = `${textarea.scrollHeight}px`;
|
|
43002
|
+
});
|
|
43003
|
+
}
|
|
43004
|
+
}, [onChange, cell]);
|
|
42357
43005
|
React__namespace.useEffect(() => {
|
|
42358
43006
|
if (inputRef.current) {
|
|
42359
43007
|
moveCursorToEnd(inputRef.current);
|
|
42360
43008
|
}
|
|
42361
|
-
}, [
|
|
43009
|
+
}, []);
|
|
42362
43010
|
const value = cell?.value ?? '';
|
|
42363
43011
|
return jsxRuntime.jsx("div", {
|
|
42364
43012
|
className: "ff-spreadsheet-data-editor",
|
|
42365
43013
|
children: jsxRuntime.jsx("textarea", {
|
|
42366
43014
|
className: "ff-spreadsheet-cell-textarea",
|
|
42367
43015
|
style: {
|
|
42368
|
-
...cell?.style
|
|
43016
|
+
...cell?.style,
|
|
43017
|
+
width: '100%',
|
|
43018
|
+
height: '100%',
|
|
43019
|
+
borderTop: '',
|
|
43020
|
+
borderBottom: '',
|
|
43021
|
+
borderLeft: '',
|
|
43022
|
+
borderRight: ''
|
|
42369
43023
|
},
|
|
42370
43024
|
ref: inputRef,
|
|
42371
43025
|
onChange: handleChange,
|
|
43026
|
+
onKeyDown: handleKeyDown,
|
|
42372
43027
|
value: value,
|
|
42373
43028
|
autoFocus: true,
|
|
42374
43029
|
disabled: cell?.readOnly
|
|
@@ -42837,6 +43492,8 @@ const ActiveCell = props => {
|
|
|
42837
43492
|
className: "ff-spreadsheet-cell-textarea",
|
|
42838
43493
|
style: {
|
|
42839
43494
|
...cell?.style,
|
|
43495
|
+
height: '100%',
|
|
43496
|
+
width: '100%',
|
|
42840
43497
|
textDecoration: cell?.style?.textDecoration === 'underline' ? 'underline' : 'none',
|
|
42841
43498
|
backgroundColor: isDragged ? '#1e161f00' : cell?.style?.backgroundColor,
|
|
42842
43499
|
pointerEvents: 'none',
|
|
@@ -43068,7 +43725,9 @@ function convertStyleToFrontend(backendStyle) {
|
|
|
43068
43725
|
borderBottom: borderBottom,
|
|
43069
43726
|
borderLeft: borderLeft,
|
|
43070
43727
|
textAlign: getTextAlignment(backendStyle.alignment.horizontal),
|
|
43071
|
-
alignContent: getTextAlignment(backendStyle.alignment.vertical)
|
|
43728
|
+
alignContent: getTextAlignment(backendStyle.alignment.vertical),
|
|
43729
|
+
height: backendStyle.height ?? 32,
|
|
43730
|
+
width: backendStyle.width ?? 150
|
|
43072
43731
|
};
|
|
43073
43732
|
}
|
|
43074
43733
|
const getBorderStyle = border => {
|
|
@@ -43104,7 +43763,9 @@ const convertStyleToBackend = frontendStyle => {
|
|
|
43104
43763
|
horizontal: getTextAlignmentBack(frontendStyle.textAlign),
|
|
43105
43764
|
vertical: getTextAlignmentBack(frontendStyle.alignContent),
|
|
43106
43765
|
wrapText: false
|
|
43107
|
-
}
|
|
43766
|
+
},
|
|
43767
|
+
width: frontendStyle.width || 150,
|
|
43768
|
+
height: frontendStyle.height || 32
|
|
43108
43769
|
};
|
|
43109
43770
|
};
|
|
43110
43771
|
|
|
@@ -48278,7 +48939,7 @@ const VariableDropdown = ({
|
|
|
48278
48939
|
dropdownPosition,
|
|
48279
48940
|
position = 'relative',
|
|
48280
48941
|
width,
|
|
48281
|
-
height = '
|
|
48942
|
+
height = '160px',
|
|
48282
48943
|
zIndex = 9999
|
|
48283
48944
|
}) => {
|
|
48284
48945
|
const VARIABLE_ICON_MAP = {
|
|
@@ -48308,12 +48969,12 @@ const VariableDropdown = ({
|
|
|
48308
48969
|
return 212;
|
|
48309
48970
|
}
|
|
48310
48971
|
// Calculate item height based on width type
|
|
48311
|
-
const itemHeight =
|
|
48972
|
+
const itemHeight = 32;
|
|
48312
48973
|
const renderItem = index => {
|
|
48313
48974
|
const option = optionsList[index];
|
|
48314
48975
|
if (!option) return null;
|
|
48315
48976
|
return jsxRuntime.jsx("div", {
|
|
48316
|
-
className:
|
|
48977
|
+
className: 'ff-variable-data',
|
|
48317
48978
|
onMouseDown: () => onSelectVariable(option),
|
|
48318
48979
|
children: width.endsWith('px') ? jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
48319
48980
|
children: [jsxRuntime.jsx(Tooltip, {
|
|
@@ -48329,8 +48990,8 @@ const VariableDropdown = ({
|
|
|
48329
48990
|
})
|
|
48330
48991
|
}), jsxRuntime.jsx(Icon, {
|
|
48331
48992
|
name: getVariableIcon(option),
|
|
48332
|
-
height:
|
|
48333
|
-
width:
|
|
48993
|
+
height: 24,
|
|
48994
|
+
width: 24,
|
|
48334
48995
|
hoverEffect: true
|
|
48335
48996
|
})]
|
|
48336
48997
|
}) : jsxRuntime.jsx(DynamicWidthTooltip, {
|
|
@@ -48355,8 +49016,8 @@ const VariableDropdown = ({
|
|
|
48355
49016
|
totalCount: optionsList.length,
|
|
48356
49017
|
itemContent: renderItem,
|
|
48357
49018
|
style: {
|
|
48358
|
-
height
|
|
48359
|
-
fontSize:
|
|
49019
|
+
height,
|
|
49020
|
+
fontSize: '12px'
|
|
48360
49021
|
},
|
|
48361
49022
|
overscan: 10,
|
|
48362
49023
|
fixedItemHeight: itemHeight
|
|
@@ -48999,10 +49660,11 @@ const OptionsDropdown$1 = ({
|
|
|
48999
49660
|
return jsxRuntime.jsx("div", {
|
|
49000
49661
|
className: "ff-variable-option",
|
|
49001
49662
|
onMouseDown: () => onSelectVariable(option),
|
|
49002
|
-
children: jsxRuntime.jsx(
|
|
49003
|
-
|
|
49004
|
-
|
|
49005
|
-
|
|
49663
|
+
children: jsxRuntime.jsx(Tooltip, {
|
|
49664
|
+
title: isTextTruncated(option?.name, truncateTextValue, 'pixel') ? option?.name : '',
|
|
49665
|
+
children: jsxRuntime.jsx(Typography, {
|
|
49666
|
+
children: truncateText(option?.name, truncateTextValue, 'pixel')
|
|
49667
|
+
})
|
|
49006
49668
|
})
|
|
49007
49669
|
}, option?.id);
|
|
49008
49670
|
}) : jsxRuntime.jsx("div", {
|
|
@@ -49028,7 +49690,7 @@ const VariableSuggestionInputDropDown = /*#__PURE__*/React.forwardRef(({
|
|
|
49028
49690
|
handleClearInput,
|
|
49029
49691
|
value = '',
|
|
49030
49692
|
dropdownWidth = '100%',
|
|
49031
|
-
dropdownHeight = '
|
|
49693
|
+
dropdownHeight = '160px',
|
|
49032
49694
|
isHash = false,
|
|
49033
49695
|
isOnlyHash = false,
|
|
49034
49696
|
dataFiles = [],
|
|
@@ -49302,7 +49964,8 @@ const CreateVariableSlider = ({
|
|
|
49302
49964
|
handleSubmit,
|
|
49303
49965
|
mode = 'create',
|
|
49304
49966
|
disabled,
|
|
49305
|
-
dataFiles = []
|
|
49967
|
+
dataFiles = [],
|
|
49968
|
+
truncateTextValue = 34
|
|
49306
49969
|
}) => {
|
|
49307
49970
|
const [error, setError] = React.useState(false);
|
|
49308
49971
|
const [helperText, setHelperText] = React.useState('');
|
|
@@ -49438,7 +50101,7 @@ const CreateVariableSlider = ({
|
|
|
49438
50101
|
isHash: true,
|
|
49439
50102
|
isOnlyHash: true,
|
|
49440
50103
|
zIndex: 99999,
|
|
49441
|
-
truncateTextValue:
|
|
50104
|
+
truncateTextValue: truncateTextValue,
|
|
49442
50105
|
dataFiles: dataFiles,
|
|
49443
50106
|
dropdownWidth: "100%",
|
|
49444
50107
|
setHashInputValue: setHashInputValue,
|
|
@@ -49574,8 +50237,8 @@ const TableWithAccordion = ({
|
|
|
49574
50237
|
children: [jsxRuntime.jsx("div", {
|
|
49575
50238
|
className: "ff-display-flex",
|
|
49576
50239
|
children: jsxRuntime.jsx(Tooltip, {
|
|
49577
|
-
title: row.disable ? row?.disableInfoMessage : '',
|
|
49578
|
-
placement:
|
|
50240
|
+
title: row.disable ? row?.disableInfoMessage : typeof row.title === 'string' && isTextTruncated(row.title, tableMeta[0]?.width, 'pixel') ? row.title : '',
|
|
50241
|
+
placement: "bottom-start",
|
|
49579
50242
|
children: jsxRuntime.jsxs("div", {
|
|
49580
50243
|
className: `accordion-header ${row.disable && 'accordion-header--disabled'}`,
|
|
49581
50244
|
children: [jsxRuntime.jsx("div", {
|
|
@@ -49583,7 +50246,7 @@ const TableWithAccordion = ({
|
|
|
49583
50246
|
children: jsxRuntime.jsx("span", {
|
|
49584
50247
|
children: jsxRuntime.jsx(Typography, {
|
|
49585
50248
|
children: jsxRuntime.jsx(HighlightText, {
|
|
49586
|
-
text: row.title,
|
|
50249
|
+
text: truncateText(row.title, tableMeta[0]?.width, 'pixel'),
|
|
49587
50250
|
highlight: highlightText
|
|
49588
50251
|
})
|
|
49589
50252
|
})
|
|
@@ -50062,7 +50725,7 @@ const Prompt = /*#__PURE__*/React.forwardRef(({
|
|
|
50062
50725
|
additionalIconName,
|
|
50063
50726
|
additionIconToolTip,
|
|
50064
50727
|
onAdditionalIconClick
|
|
50065
|
-
}) => {
|
|
50728
|
+
}, ref) => {
|
|
50066
50729
|
const containerRef = React.useRef(null);
|
|
50067
50730
|
useKeyboardActions([{
|
|
50068
50731
|
key: 'Enter',
|
|
@@ -50099,6 +50762,7 @@ const Prompt = /*#__PURE__*/React.forwardRef(({
|
|
|
50099
50762
|
disabled: checkEmpty(value)
|
|
50100
50763
|
})
|
|
50101
50764
|
}), jsxRuntime.jsx("input", {
|
|
50765
|
+
ref: ref,
|
|
50102
50766
|
className: "ff-prompt-input",
|
|
50103
50767
|
type: "text",
|
|
50104
50768
|
placeholder: placeholder,
|
|
@@ -63932,11 +64596,13 @@ var jsExports = requireJs();
|
|
|
63932
64596
|
const Editor = /*#__PURE__*/React.forwardRef(({
|
|
63933
64597
|
width = '100%',
|
|
63934
64598
|
height = '100%',
|
|
64599
|
+
VariableDropdownHeight = '160px',
|
|
63935
64600
|
readOnly = false,
|
|
63936
64601
|
value = '',
|
|
63937
64602
|
handleChange,
|
|
63938
64603
|
setValue,
|
|
63939
64604
|
variableOptionsList = [],
|
|
64605
|
+
addForloopPrefix = false,
|
|
63940
64606
|
language = 'json',
|
|
63941
64607
|
theme = 'light',
|
|
63942
64608
|
isRequisiteType = false,
|
|
@@ -63986,7 +64652,10 @@ const Editor = /*#__PURE__*/React.forwardRef(({
|
|
|
63986
64652
|
varRef.current = columnIndex;
|
|
63987
64653
|
}
|
|
63988
64654
|
filterVarRef.current = currentLineContent.slice(varRef.current + 1, columnIndex);
|
|
63989
|
-
const filteredVariable = variableOptionsList.filter(e =>
|
|
64655
|
+
const filteredVariable = variableOptionsList.filter(e => {
|
|
64656
|
+
const variableName = e.type === '_startforloop' && addForloopPrefix ? `FLV_for:${e.name}` : e.name;
|
|
64657
|
+
return variableName.toLowerCase().includes(filterVarRef.current?.toLowerCase());
|
|
64658
|
+
});
|
|
63990
64659
|
if (filteredVariable.length) {
|
|
63991
64660
|
setFilteredVariableOptions(filteredVariable);
|
|
63992
64661
|
} else {
|
|
@@ -64010,7 +64679,7 @@ const Editor = /*#__PURE__*/React.forwardRef(({
|
|
|
64010
64679
|
let dropdownTop = top;
|
|
64011
64680
|
let dropdownLeft = left;
|
|
64012
64681
|
if (dropdownTop + dropdownHeight > editorHeight - dropdownHeight + 100) {
|
|
64013
|
-
dropdownTop -= Math.floor(dropdownHeight / 2) + dropdownHeight
|
|
64682
|
+
dropdownTop -= Math.floor(dropdownHeight / 2) + dropdownHeight - 25;
|
|
64014
64683
|
} else {
|
|
64015
64684
|
dropdownTop -= 5;
|
|
64016
64685
|
}
|
|
@@ -64269,7 +64938,7 @@ const Editor = /*#__PURE__*/React.forwardRef(({
|
|
|
64269
64938
|
}), showDropdown && dropdownPosition && showVariableDropdown && jsxRuntime.jsx(VariableDropdown, {
|
|
64270
64939
|
position: "absolute",
|
|
64271
64940
|
width: "300px",
|
|
64272
|
-
height:
|
|
64941
|
+
height: VariableDropdownHeight,
|
|
64273
64942
|
optionsList: filteredVariableOptions,
|
|
64274
64943
|
onSelectVariable: handleSelectVariable,
|
|
64275
64944
|
dropdownPosition: dropdownPosition
|
|
@@ -66960,7 +67629,10 @@ const OptionsDropdown = ({
|
|
|
66960
67629
|
filteredOptions = [],
|
|
66961
67630
|
position = 'relative',
|
|
66962
67631
|
width = '300px',
|
|
66963
|
-
zIndex = 1000
|
|
67632
|
+
zIndex = 1000,
|
|
67633
|
+
height = '160px',
|
|
67634
|
+
truncateTextValue = 34,
|
|
67635
|
+
isTruncateText = false
|
|
66964
67636
|
}) => {
|
|
66965
67637
|
return jsxRuntime.jsxs("div", {
|
|
66966
67638
|
className: classNames('ff-variable-dropdown', position),
|
|
@@ -66972,16 +67644,21 @@ const OptionsDropdown = ({
|
|
|
66972
67644
|
} : {
|
|
66973
67645
|
width,
|
|
66974
67646
|
zIndex,
|
|
66975
|
-
height:
|
|
67647
|
+
height: height
|
|
66976
67648
|
},
|
|
66977
67649
|
children: [filteredOptions?.map(option => {
|
|
67650
|
+
const displayText = isTruncateText ? truncateText(option?.name, truncateTextValue, 'pixel') : option?.name;
|
|
67651
|
+
const shouldShowTooltip = isTruncateText ? isTextTruncated(option?.name, truncateTextValue, 'pixel') : false;
|
|
66978
67652
|
return jsxRuntime.jsx("div", {
|
|
66979
67653
|
className: "ff-variable-option",
|
|
66980
67654
|
onClick: () => onSelectVariable(option),
|
|
66981
|
-
children: jsxRuntime.jsx(
|
|
66982
|
-
|
|
66983
|
-
|
|
66984
|
-
|
|
67655
|
+
children: isTruncateText ? jsxRuntime.jsx(Tooltip, {
|
|
67656
|
+
title: shouldShowTooltip ? option?.name : '',
|
|
67657
|
+
children: jsxRuntime.jsx(Typography, {
|
|
67658
|
+
children: displayText
|
|
67659
|
+
})
|
|
67660
|
+
}) : jsxRuntime.jsx(Typography, {
|
|
67661
|
+
children: displayText
|
|
66985
67662
|
})
|
|
66986
67663
|
}, option?.id);
|
|
66987
67664
|
}), filteredOptions?.length === 0 && jsxRuntime.jsx("div", {
|
|
@@ -67000,6 +67677,7 @@ const ConditionalDropdown = /*#__PURE__*/React.forwardRef(({
|
|
|
67000
67677
|
hashInputValue = '',
|
|
67001
67678
|
setHashInputValue,
|
|
67002
67679
|
variableList = [],
|
|
67680
|
+
addForloopPrefix = false,
|
|
67003
67681
|
placeholder = 'Enter text',
|
|
67004
67682
|
onChange,
|
|
67005
67683
|
onCreateVariableClick,
|
|
@@ -67019,7 +67697,9 @@ const ConditionalDropdown = /*#__PURE__*/React.forwardRef(({
|
|
|
67019
67697
|
onFocus,
|
|
67020
67698
|
onBlur,
|
|
67021
67699
|
readOnly = false,
|
|
67022
|
-
height = '
|
|
67700
|
+
height = '160px',
|
|
67701
|
+
truncateTextValue = 34,
|
|
67702
|
+
isTruncateText = false,
|
|
67023
67703
|
...props
|
|
67024
67704
|
}, ref) => {
|
|
67025
67705
|
const [showDropdown, setShowDropdown] = React.useState(false);
|
|
@@ -67147,7 +67827,10 @@ const ConditionalDropdown = /*#__PURE__*/React.forwardRef(({
|
|
|
67147
67827
|
searchString = '';
|
|
67148
67828
|
}
|
|
67149
67829
|
if (searchString) {
|
|
67150
|
-
const isInVariableList = variableList.some(file =>
|
|
67830
|
+
const isInVariableList = variableList.some(file => {
|
|
67831
|
+
const searchableName = file.type === '_startforloop' && addForloopPrefix ? `FLV_for:${file.name}` : file.name;
|
|
67832
|
+
return searchableName.toLowerCase().includes(searchString.toLowerCase());
|
|
67833
|
+
});
|
|
67151
67834
|
if (!isInVariableList) {
|
|
67152
67835
|
showDropdown = false;
|
|
67153
67836
|
searchString = '';
|
|
@@ -67216,7 +67899,7 @@ const ConditionalDropdown = /*#__PURE__*/React.forwardRef(({
|
|
|
67216
67899
|
className: "ff-password-icon",
|
|
67217
67900
|
children: jsxRuntime.jsx(Icon, {
|
|
67218
67901
|
onClick: togglePasswordVisibility,
|
|
67219
|
-
name: showPassword ? '
|
|
67902
|
+
name: !showPassword ? 'view_access_icon' : 'hide_access_icon',
|
|
67220
67903
|
width: 16,
|
|
67221
67904
|
height: 16,
|
|
67222
67905
|
hoverEffect: true
|
|
@@ -67235,7 +67918,10 @@ const ConditionalDropdown = /*#__PURE__*/React.forwardRef(({
|
|
|
67235
67918
|
}), result?.showDropdown && isFocused && jsxRuntime.jsx(VariableDropdown, {
|
|
67236
67919
|
position: "absolute",
|
|
67237
67920
|
width: dropdownWidth,
|
|
67238
|
-
optionsList: variableList.filter(file =>
|
|
67921
|
+
optionsList: variableList.filter(file => {
|
|
67922
|
+
const searchableName = file.type === '_startforloop' && addForloopPrefix ? `FLV_for:${file.name}` : file.name;
|
|
67923
|
+
return searchableName.toLowerCase().includes(result?.searchString.toLowerCase());
|
|
67924
|
+
}),
|
|
67239
67925
|
onSelectVariable: handleDropdownClick,
|
|
67240
67926
|
height: height
|
|
67241
67927
|
}), showDropdown && (isHash || onlyDropdown) && jsxRuntime.jsx(OptionsDropdown, {
|
|
@@ -67243,7 +67929,10 @@ const ConditionalDropdown = /*#__PURE__*/React.forwardRef(({
|
|
|
67243
67929
|
width: dropdownWidth,
|
|
67244
67930
|
filteredOptions: filteredOptions,
|
|
67245
67931
|
zIndex: 2000,
|
|
67246
|
-
onSelectVariable: handleDropdownClick
|
|
67932
|
+
onSelectVariable: handleDropdownClick,
|
|
67933
|
+
height: height,
|
|
67934
|
+
isTruncateText: isTruncateText,
|
|
67935
|
+
truncateTextValue: truncateTextValue
|
|
67247
67936
|
})]
|
|
67248
67937
|
});
|
|
67249
67938
|
});
|
|
@@ -80904,84 +81593,107 @@ const StepGroupAccordions = /*#__PURE__*/React.memo(({
|
|
|
80904
81593
|
handleStepGroupExpand,
|
|
80905
81594
|
isStepGroupExpanded,
|
|
80906
81595
|
isViewPrivilegeMode,
|
|
80907
|
-
columns = []
|
|
81596
|
+
columns = [],
|
|
81597
|
+
parentIndex,
|
|
81598
|
+
updateRowHeight
|
|
80908
81599
|
}) => {
|
|
81600
|
+
const rowRefs = React.useRef([]);
|
|
80909
81601
|
const typeSet = new Set(['Group', 'PRE', 'POST', 'Script']);
|
|
80910
81602
|
const getPadding = type => typeSet.has(type) ? '6px 8px' : '7px 8px';
|
|
80911
81603
|
const indent = level + 8;
|
|
81604
|
+
// Measure and report height when expanded
|
|
81605
|
+
React.useEffect(() => {
|
|
81606
|
+
if (!updateRowHeight) return;
|
|
81607
|
+
let totalHeight = 0;
|
|
81608
|
+
rowRefs.current.forEach(ref => {
|
|
81609
|
+
if (ref) {
|
|
81610
|
+
totalHeight += ref.getBoundingClientRect().height;
|
|
81611
|
+
}
|
|
81612
|
+
});
|
|
81613
|
+
if (totalHeight > 0) {
|
|
81614
|
+
updateRowHeight(parentIndex ?? 0, totalHeight);
|
|
81615
|
+
}
|
|
81616
|
+
}, [data, updateRowHeight, parentIndex, isStepGroupExpanded]);
|
|
80912
81617
|
return jsxRuntime.jsx(jsxRuntime.Fragment, {
|
|
80913
|
-
children: data?.map(item =>
|
|
80914
|
-
|
|
80915
|
-
|
|
80916
|
-
|
|
80917
|
-
|
|
80918
|
-
|
|
80919
|
-
|
|
80920
|
-
|
|
80921
|
-
|
|
80922
|
-
|
|
80923
|
-
children: ViewComponent && jsxRuntime.jsx(ViewComponent, {})
|
|
80924
|
-
})
|
|
80925
|
-
})
|
|
80926
|
-
}) : jsxRuntime.jsx("tr", {
|
|
80927
|
-
children: columns.map((col, idx) => jsxRuntime.jsx("td", {
|
|
80928
|
-
style: {
|
|
80929
|
-
maxWidth: col.width,
|
|
80930
|
-
padding: getPadding(item.type)
|
|
80931
|
-
},
|
|
80932
|
-
children: jsxRuntime.jsxs(Typography, {
|
|
80933
|
-
as: "div",
|
|
80934
|
-
className: "ff-data-checkbox-container",
|
|
80935
|
-
children: [jsxRuntime.jsxs("div", {
|
|
80936
|
-
className: "ff-data-checkbox-container-content",
|
|
81618
|
+
children: data?.map((item, itemIndex) => {
|
|
81619
|
+
const absoluteIndex = parentIndex ?? 0 + itemIndex + 1;
|
|
81620
|
+
return jsxRuntime.jsxs(React.Fragment, {
|
|
81621
|
+
children: [viewModeId === item?.stepId ? jsxRuntime.jsx("tr", {
|
|
81622
|
+
ref: el => rowRefs.current[itemIndex] = el,
|
|
81623
|
+
className: "steps-edit-row",
|
|
81624
|
+
id: "getInFocus",
|
|
81625
|
+
children: jsxRuntime.jsx("td", {
|
|
81626
|
+
colSpan: columnCount,
|
|
81627
|
+
children: jsxRuntime.jsx("div", {
|
|
80937
81628
|
style: {
|
|
80938
|
-
marginLeft:
|
|
80939
|
-
},
|
|
80940
|
-
onClick: () => {
|
|
80941
|
-
const isClickable = idx === 0 && !item?.displayName?.includes('End') && !item?.isDisabled;
|
|
80942
|
-
if (isClickable) handleClick?.({
|
|
80943
|
-
...item,
|
|
80944
|
-
tableType
|
|
80945
|
-
});
|
|
81629
|
+
marginLeft: `${indent}px`
|
|
80946
81630
|
},
|
|
80947
|
-
children:
|
|
81631
|
+
children: ViewComponent && jsxRuntime.jsx(ViewComponent, {})
|
|
81632
|
+
})
|
|
81633
|
+
})
|
|
81634
|
+
}) : jsxRuntime.jsx("tr", {
|
|
81635
|
+
ref: el => rowRefs.current[itemIndex] = el,
|
|
81636
|
+
children: columns.map((col, idx) => jsxRuntime.jsx("td", {
|
|
81637
|
+
style: {
|
|
81638
|
+
maxWidth: col.width,
|
|
81639
|
+
padding: getPadding(item.type)
|
|
81640
|
+
},
|
|
81641
|
+
children: jsxRuntime.jsxs(Typography, {
|
|
81642
|
+
as: "div",
|
|
81643
|
+
className: "ff-data-checkbox-container",
|
|
81644
|
+
children: [jsxRuntime.jsxs("div", {
|
|
81645
|
+
className: "ff-data-checkbox-container-content",
|
|
80948
81646
|
style: {
|
|
80949
|
-
|
|
80950
|
-
}
|
|
80951
|
-
|
|
80952
|
-
|
|
80953
|
-
|
|
80954
|
-
|
|
80955
|
-
|
|
80956
|
-
|
|
80957
|
-
|
|
80958
|
-
|
|
80959
|
-
|
|
80960
|
-
|
|
80961
|
-
|
|
80962
|
-
|
|
80963
|
-
onClick: () => handleStepGroupExpand?.({
|
|
81647
|
+
marginLeft: idx === 0 ? `${indent}px` : 0
|
|
81648
|
+
},
|
|
81649
|
+
onClick: () => {
|
|
81650
|
+
const isClickable = idx === 0 && !item?.displayName?.includes('End') && !item?.isDisabled;
|
|
81651
|
+
if (isClickable) handleClick?.({
|
|
81652
|
+
...item,
|
|
81653
|
+
tableType
|
|
81654
|
+
});
|
|
81655
|
+
},
|
|
81656
|
+
children: [!isViewPrivilegeMode && idx === 0 && jsxRuntime.jsx("div", {
|
|
81657
|
+
style: {
|
|
81658
|
+
padding: '4px 18px'
|
|
81659
|
+
}
|
|
81660
|
+
}), prepareData({
|
|
80964
81661
|
...item,
|
|
80965
|
-
|
|
81662
|
+
marginLeft: indent
|
|
81663
|
+
}, col)]
|
|
81664
|
+
}), idx === 0 && ['Group', 'PRE', 'POST', 'Script'].includes(item.type) && jsxRuntime.jsx("div", {
|
|
81665
|
+
className: `ff-accordion-arrow ${isStepGroupExpanded?.(item.stepId) ? 'expanded' : ''}`,
|
|
81666
|
+
children: jsxRuntime.jsx(Icon, {
|
|
81667
|
+
name: "arrow_right",
|
|
81668
|
+
color: isStepGroupExpanded?.(item.stepId) ? 'var(--brand-color)' : 'var(--default-color)',
|
|
81669
|
+
className: "steps-arrow-svg",
|
|
81670
|
+
width: 12,
|
|
81671
|
+
height: 12,
|
|
81672
|
+
onClick: () => handleStepGroupExpand?.({
|
|
81673
|
+
...item,
|
|
81674
|
+
tableType
|
|
81675
|
+
})
|
|
80966
81676
|
})
|
|
80967
|
-
})
|
|
80968
|
-
})
|
|
80969
|
-
})
|
|
80970
|
-
},
|
|
80971
|
-
|
|
80972
|
-
|
|
80973
|
-
|
|
80974
|
-
|
|
80975
|
-
|
|
80976
|
-
|
|
80977
|
-
|
|
80978
|
-
|
|
80979
|
-
|
|
80980
|
-
|
|
80981
|
-
|
|
80982
|
-
|
|
80983
|
-
|
|
80984
|
-
|
|
81677
|
+
})]
|
|
81678
|
+
})
|
|
81679
|
+
}, `${item.stepId}-${idx}`))
|
|
81680
|
+
}), isStepGroupExpanded?.(item.stepId) && jsxRuntime.jsx(StepGroupAccordions, {
|
|
81681
|
+
data: item.data,
|
|
81682
|
+
level: indent,
|
|
81683
|
+
columnCount: columnCount,
|
|
81684
|
+
viewModeId: viewModeId,
|
|
81685
|
+
ViewComponent: ViewComponent,
|
|
81686
|
+
handleClick: handleClick,
|
|
81687
|
+
tableType: tableType,
|
|
81688
|
+
handleStepGroupExpand: handleStepGroupExpand,
|
|
81689
|
+
isStepGroupExpanded: isStepGroupExpanded,
|
|
81690
|
+
isViewPrivilegeMode: isViewPrivilegeMode,
|
|
81691
|
+
columns: columns,
|
|
81692
|
+
parentIndex: absoluteIndex,
|
|
81693
|
+
updateRowHeight: updateRowHeight
|
|
81694
|
+
})]
|
|
81695
|
+
}, item.stepId);
|
|
81696
|
+
})
|
|
80985
81697
|
});
|
|
80986
81698
|
});
|
|
80987
81699
|
StepGroupAccordions.displayName = 'StepGroupAccordions';
|
|
@@ -81006,8 +81718,11 @@ const StepTableMainRow = ({
|
|
|
81006
81718
|
dataLength,
|
|
81007
81719
|
stepPartialSelect,
|
|
81008
81720
|
isViewPrivilegeMode,
|
|
81009
|
-
isClientSide
|
|
81721
|
+
isClientSide,
|
|
81722
|
+
updateRowHeight,
|
|
81723
|
+
rowId
|
|
81010
81724
|
}) => {
|
|
81725
|
+
const rowRef = React.useRef(null);
|
|
81011
81726
|
const isDisabled = React.useMemo(() => row?.isDisabled || (dataLength ?? 0) <= 1 || row.isSpecialNlp, [row, dataLength]);
|
|
81012
81727
|
let serialNumber = (indexNumber + 1).toString();
|
|
81013
81728
|
const {
|
|
@@ -81025,6 +81740,13 @@ const StepTableMainRow = ({
|
|
|
81025
81740
|
transition
|
|
81026
81741
|
}), [transform, transition]);
|
|
81027
81742
|
const key = row?._id || row?.stepId;
|
|
81743
|
+
// Measure row height and report to parent
|
|
81744
|
+
React.useEffect(() => {
|
|
81745
|
+
if (rowRef.current && updateRowHeight) {
|
|
81746
|
+
const height = rowRef.current.getBoundingClientRect().height;
|
|
81747
|
+
updateRowHeight(indexNumber, height);
|
|
81748
|
+
}
|
|
81749
|
+
}, [row, updateRowHeight, indexNumber, isStepGroupExpanded?.(row?.stepId)]);
|
|
81028
81750
|
const getPadding = index => {
|
|
81029
81751
|
if (isViewPrivilegeMode || isClientSide) {
|
|
81030
81752
|
if (['Group', 'PRE', 'POST', 'Script'].includes(row.type) && index === 0) {
|
|
@@ -81075,7 +81797,11 @@ const StepTableMainRow = ({
|
|
|
81075
81797
|
});
|
|
81076
81798
|
return jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
81077
81799
|
children: [jsxRuntime.jsx("tr", {
|
|
81078
|
-
|
|
81800
|
+
"data-rowid": rowId,
|
|
81801
|
+
ref: el => {
|
|
81802
|
+
rowRef.current = el;
|
|
81803
|
+
setNodeRef(el);
|
|
81804
|
+
},
|
|
81079
81805
|
style: style,
|
|
81080
81806
|
className: classNames(tableBodyRowClass, {
|
|
81081
81807
|
'disabled-inner-row': isDisabled
|
|
@@ -81119,7 +81845,9 @@ const StepTableMainRow = ({
|
|
|
81119
81845
|
isStepGroupExpanded: isStepGroupExpanded,
|
|
81120
81846
|
level: row?.marginLeft,
|
|
81121
81847
|
isViewPrivilegeMode: isViewPrivilegeMode,
|
|
81122
|
-
columns: columns
|
|
81848
|
+
columns: columns,
|
|
81849
|
+
parentIndex: indexNumber,
|
|
81850
|
+
updateRowHeight: updateRowHeight
|
|
81123
81851
|
})]
|
|
81124
81852
|
});
|
|
81125
81853
|
};
|
|
@@ -81156,14 +81884,156 @@ const StepInnerTable = ({
|
|
|
81156
81884
|
isStepGroupExpanded,
|
|
81157
81885
|
stepPartialSelect,
|
|
81158
81886
|
isViewPrivilegeMode,
|
|
81159
|
-
isClientSide
|
|
81887
|
+
isClientSide,
|
|
81888
|
+
highlightKey,
|
|
81889
|
+
onHighlightComplete
|
|
81160
81890
|
}) => {
|
|
81161
81891
|
const observerRef = React.useRef(null);
|
|
81892
|
+
const containerRef = React.useRef(null);
|
|
81893
|
+
const [scrollTop, setScrollTop] = React.useState(0);
|
|
81894
|
+
const [containerHeight, setContainerHeight] = React.useState(0);
|
|
81895
|
+
const [rowHeights, setRowHeights] = React.useState([]);
|
|
81896
|
+
const [focusRowId, setFocusRowId] = React.useState(null);
|
|
81897
|
+
const buffer = 5;
|
|
81898
|
+
const estimatedRowHeight = 50;
|
|
81899
|
+
const scrollTopBeforeReset = React.useRef(0); // Add this ref
|
|
81162
81900
|
React.useEffect(() => {
|
|
81163
|
-
|
|
81901
|
+
if (containerRef.current) {
|
|
81902
|
+
setContainerHeight(containerRef.current.clientHeight);
|
|
81903
|
+
}
|
|
81904
|
+
const fullData = appendNewRow(data, AddNlp ?? {});
|
|
81905
|
+
setRowHeights(prev => {
|
|
81906
|
+
const next = [...prev];
|
|
81907
|
+
while (next.length < fullData.length) next.push(estimatedRowHeight);
|
|
81908
|
+
if (next.length > fullData.length) next.length = fullData.length;
|
|
81909
|
+
return next;
|
|
81910
|
+
});
|
|
81911
|
+
}, [data, AddNlp]);
|
|
81912
|
+
React.useEffect(() => {
|
|
81913
|
+
if (scrollTopBeforeReset.current > 0 && containerRef.current) {
|
|
81914
|
+
containerRef.current.scrollTop = scrollTopBeforeReset.current;
|
|
81915
|
+
scrollTopBeforeReset.current = 0;
|
|
81916
|
+
}
|
|
81917
|
+
}, [rowHeights]);
|
|
81918
|
+
// Track focus row for edit/new rows
|
|
81919
|
+
React.useEffect(() => {
|
|
81920
|
+
// Prioritize highlightKey over other states
|
|
81921
|
+
if (!checkEmpty(highlightKey)) {
|
|
81922
|
+
setFocusRowId(highlightKey);
|
|
81923
|
+
} else if (editMode) {
|
|
81924
|
+
setFocusRowId(editMode);
|
|
81925
|
+
} else if (AddNlp && Object.keys(AddNlp).length > 0) {
|
|
81926
|
+
const newRow = appendNewRow(data, AddNlp).find(row => row.isNew);
|
|
81927
|
+
if (newRow) {
|
|
81928
|
+
setFocusRowId(newRow.stepId || 'new-row');
|
|
81929
|
+
}
|
|
81930
|
+
} else {
|
|
81931
|
+
setFocusRowId(null);
|
|
81932
|
+
}
|
|
81933
|
+
}, [editMode, AddNlp, data, highlightKey]);
|
|
81934
|
+
// Update scroll effect
|
|
81935
|
+
React.useEffect(() => {
|
|
81936
|
+
if (focusRowId && containerRef.current) {
|
|
81937
|
+
const timer = setTimeout(() => {
|
|
81938
|
+
const focusElement = containerRef.current?.querySelector(`[data-rowid="${focusRowId}"]`);
|
|
81939
|
+
if (focusElement) {
|
|
81940
|
+
focusElement.scrollIntoView({
|
|
81941
|
+
behavior: 'smooth',
|
|
81942
|
+
block: 'nearest'
|
|
81943
|
+
});
|
|
81944
|
+
// ADD THIS: Reset highlight after scroll completes
|
|
81945
|
+
setTimeout(() => {
|
|
81946
|
+
if (!checkEmpty(highlightKey)) {
|
|
81947
|
+
onHighlightComplete?.();
|
|
81948
|
+
}
|
|
81949
|
+
}, 300); // Match scroll duration
|
|
81950
|
+
}
|
|
81951
|
+
}, 100);
|
|
81952
|
+
return () => clearTimeout(timer);
|
|
81953
|
+
}
|
|
81954
|
+
return undefined;
|
|
81955
|
+
}, [focusRowId, rowHeights, highlightKey, onHighlightComplete]);
|
|
81956
|
+
// Handle scroll
|
|
81957
|
+
const handleScroll = e => {
|
|
81958
|
+
setScrollTop(e.currentTarget.scrollTop);
|
|
81959
|
+
};
|
|
81960
|
+
// Update row height callback
|
|
81961
|
+
const updateRowHeight = React.useCallback((index, height) => {
|
|
81962
|
+
setRowHeights(prev => {
|
|
81963
|
+
const newHeights = [...prev];
|
|
81964
|
+
if (index < newHeights.length && newHeights[index] !== height) {
|
|
81965
|
+
newHeights[index] = height;
|
|
81966
|
+
return newHeights;
|
|
81967
|
+
}
|
|
81968
|
+
return prev;
|
|
81969
|
+
});
|
|
81970
|
+
}, []);
|
|
81971
|
+
// Calculate visible rows
|
|
81972
|
+
const fullData = appendNewRow(data, AddNlp ?? {});
|
|
81973
|
+
const totalRows = fullData.length;
|
|
81974
|
+
let startIndex = 0;
|
|
81975
|
+
let endIndex = totalRows - 1;
|
|
81976
|
+
let paddingTop = 0;
|
|
81977
|
+
let paddingBottom = 0;
|
|
81978
|
+
if (rowHeights.length === totalRows && containerHeight > 0) {
|
|
81979
|
+
let cumulativeHeight = 0;
|
|
81980
|
+
// Find start index
|
|
81981
|
+
for (let i = 0; i < totalRows; i++) {
|
|
81982
|
+
if (cumulativeHeight <= scrollTop) {
|
|
81983
|
+
startIndex = i;
|
|
81984
|
+
}
|
|
81985
|
+
cumulativeHeight += rowHeights[i] ?? 0;
|
|
81986
|
+
}
|
|
81987
|
+
// Find end index
|
|
81988
|
+
cumulativeHeight = 0;
|
|
81989
|
+
for (let i = 0; i < totalRows; i++) {
|
|
81990
|
+
cumulativeHeight += rowHeights[i] ?? 0;
|
|
81991
|
+
if (cumulativeHeight >= scrollTop + containerHeight && endIndex === totalRows - 1) {
|
|
81992
|
+
endIndex = i;
|
|
81993
|
+
break;
|
|
81994
|
+
}
|
|
81995
|
+
}
|
|
81996
|
+
// Apply buffer
|
|
81997
|
+
startIndex = Math.max(0, startIndex - buffer);
|
|
81998
|
+
endIndex = Math.min(totalRows - 1, endIndex + buffer);
|
|
81999
|
+
// Expand range to include focus row if needed
|
|
82000
|
+
if (focusRowId) {
|
|
82001
|
+
const focusIndex = fullData.findIndex(row => row.stepId === focusRowId || row.isNew && focusRowId === 'new-row');
|
|
82002
|
+
if (focusIndex >= 0) {
|
|
82003
|
+
if (focusIndex < startIndex) {
|
|
82004
|
+
startIndex = focusIndex;
|
|
82005
|
+
} else if (focusIndex > endIndex) {
|
|
82006
|
+
endIndex = focusIndex;
|
|
82007
|
+
}
|
|
82008
|
+
}
|
|
82009
|
+
}
|
|
82010
|
+
// Calculate padding
|
|
82011
|
+
paddingTop = rowHeights.slice(0, startIndex).reduce((sum, height) => sum + height, 0);
|
|
82012
|
+
paddingBottom = rowHeights.slice(endIndex + 1).reduce((sum, height) => sum + height, 0);
|
|
82013
|
+
} else {
|
|
82014
|
+
// Fallback to estimated virtualization
|
|
82015
|
+
startIndex = Math.max(0, Math.floor(scrollTop / estimatedRowHeight) - buffer);
|
|
82016
|
+
endIndex = Math.min(totalRows - 1, startIndex + Math.ceil(containerHeight / estimatedRowHeight) + buffer);
|
|
82017
|
+
// Expand range to include focus row if needed
|
|
82018
|
+
if (focusRowId) {
|
|
82019
|
+
const focusIndex = fullData.findIndex(row => row.stepId === focusRowId || row.isNew && focusRowId === 'new-row');
|
|
82020
|
+
if (focusIndex >= 0) {
|
|
82021
|
+
if (focusIndex < startIndex) {
|
|
82022
|
+
startIndex = focusIndex;
|
|
82023
|
+
} else if (focusIndex > endIndex) {
|
|
82024
|
+
endIndex = focusIndex;
|
|
82025
|
+
}
|
|
82026
|
+
}
|
|
82027
|
+
}
|
|
82028
|
+
paddingTop = startIndex * estimatedRowHeight;
|
|
82029
|
+
paddingBottom = (totalRows - endIndex - 1) * estimatedRowHeight;
|
|
82030
|
+
}
|
|
82031
|
+
const visibleRows = fullData.slice(startIndex, endIndex + 1);
|
|
82032
|
+
// Infinite scroll observer
|
|
82033
|
+
React.useEffect(() => {
|
|
82034
|
+
const scrollContainer = containerRef.current;
|
|
81164
82035
|
const firstNode = document.getElementById('ff-table-first-node');
|
|
81165
82036
|
const lastNode = document.getElementById('ff-table-last-node');
|
|
81166
|
-
// Exit early if data is empty or elements are missing
|
|
81167
82037
|
if (!scrollContainer || !firstNode || !lastNode || !data?.length) {
|
|
81168
82038
|
return;
|
|
81169
82039
|
}
|
|
@@ -81182,7 +82052,6 @@ const StepInnerTable = ({
|
|
|
81182
82052
|
observerRef.current.observe(firstNode);
|
|
81183
82053
|
observerRef.current.observe(lastNode);
|
|
81184
82054
|
return () => {
|
|
81185
|
-
// Cleanup observer
|
|
81186
82055
|
observerRef.current?.disconnect();
|
|
81187
82056
|
};
|
|
81188
82057
|
}, [data, loadMore]);
|
|
@@ -81221,15 +82090,18 @@ const StepInnerTable = ({
|
|
|
81221
82090
|
items: data?.map(row => row._id || row.stepId),
|
|
81222
82091
|
strategy: verticalListSortingStrategy,
|
|
81223
82092
|
children: jsxRuntime.jsxs("div", {
|
|
82093
|
+
ref: containerRef,
|
|
81224
82094
|
style: {
|
|
81225
82095
|
height: height,
|
|
81226
|
-
position: 'relative'
|
|
82096
|
+
position: 'relative',
|
|
82097
|
+
overflow: 'auto'
|
|
81227
82098
|
},
|
|
81228
82099
|
id: "ff-table-scroll-container",
|
|
81229
82100
|
className: classNames(className, {
|
|
81230
82101
|
'ff-fixed-header-steps-table': withFixedHeader,
|
|
81231
82102
|
'steps-border-borderRadius': borderWithRadius
|
|
81232
82103
|
}),
|
|
82104
|
+
onScroll: handleScroll,
|
|
81233
82105
|
children: [jsxRuntime.jsxs("table", {
|
|
81234
82106
|
className: classNames(`ff-table-steps`),
|
|
81235
82107
|
cellSpacing: 0,
|
|
@@ -81246,30 +82118,45 @@ const StepInnerTable = ({
|
|
|
81246
82118
|
}), jsxRuntime.jsxs("tbody", {
|
|
81247
82119
|
className: "ff-steps-tbody",
|
|
81248
82120
|
children: [jsxRuntime.jsx("tr", {
|
|
81249
|
-
id: "ff-table-first-node"
|
|
81250
|
-
|
|
82121
|
+
id: "ff-table-first-node",
|
|
82122
|
+
style: {
|
|
82123
|
+
display: 'none'
|
|
82124
|
+
}
|
|
82125
|
+
}), paddingTop > 0 && jsxRuntime.jsx("tr", {
|
|
82126
|
+
children: jsxRuntime.jsx("td", {
|
|
82127
|
+
style: {
|
|
82128
|
+
height: paddingTop,
|
|
82129
|
+
padding: 0
|
|
82130
|
+
},
|
|
82131
|
+
colSpan: columns.length
|
|
82132
|
+
})
|
|
82133
|
+
}), visibleRows.map((row, index) => {
|
|
82134
|
+
const absoluteIndex = startIndex + index;
|
|
81251
82135
|
const isEdit = editMode === row.stepId;
|
|
81252
82136
|
const isEditOrNew = isEdit || row.isNew;
|
|
82137
|
+
const isFocusRow = isEdit && row.stepId === focusRowId || row.isNew && focusRowId === 'new-row';
|
|
81253
82138
|
const renderEditableRow = () => jsxRuntime.jsxs("tr", {
|
|
81254
82139
|
className: "steps-edit-row",
|
|
81255
|
-
id:
|
|
82140
|
+
id: isFocusRow ? 'getInFocus' : undefined,
|
|
82141
|
+
"data-rowid": row.stepId || 'new-row',
|
|
81256
82142
|
children: [isEdit && /*#__PURE__*/React.isValidElement(editComponent) && jsxRuntime.jsx("td", {
|
|
81257
82143
|
colSpan: columns.length,
|
|
81258
82144
|
children: /*#__PURE__*/React.cloneElement(editComponent, {
|
|
81259
82145
|
rowData: row,
|
|
81260
|
-
rowIndex:
|
|
82146
|
+
rowIndex: absoluteIndex + 1
|
|
81261
82147
|
})
|
|
81262
82148
|
}), row.isNew && !isEdit && /*#__PURE__*/React.isValidElement(NlpComponent) && jsxRuntime.jsx("td", {
|
|
81263
82149
|
colSpan: columns.length,
|
|
81264
82150
|
children: /*#__PURE__*/React.cloneElement(NlpComponent, {
|
|
81265
|
-
rowIndex:
|
|
82151
|
+
rowIndex: absoluteIndex,
|
|
81266
82152
|
rowData: row
|
|
81267
82153
|
})
|
|
81268
82154
|
})]
|
|
81269
|
-
}, row.stepId ||
|
|
82155
|
+
}, row.stepId || absoluteIndex);
|
|
81270
82156
|
const renderSortableRow = () => jsxRuntime.jsx(StepTableMainRow$1, {
|
|
82157
|
+
rowId: row.stepId,
|
|
81271
82158
|
row: row,
|
|
81272
|
-
indexNumber:
|
|
82159
|
+
indexNumber: absoluteIndex,
|
|
81273
82160
|
columns: columns,
|
|
81274
82161
|
tableBodyRowClass: tableBodyRowClass,
|
|
81275
82162
|
handleOnclick: handleOnclick,
|
|
@@ -81287,11 +82174,23 @@ const StepInnerTable = ({
|
|
|
81287
82174
|
dataLength: data?.length,
|
|
81288
82175
|
stepPartialSelect: stepPartialSelect,
|
|
81289
82176
|
isViewPrivilegeMode: isViewPrivilegeMode,
|
|
81290
|
-
isClientSide: isClientSide
|
|
82177
|
+
isClientSide: isClientSide,
|
|
82178
|
+
updateRowHeight: updateRowHeight
|
|
81291
82179
|
});
|
|
81292
82180
|
return isEditOrNew ? renderEditableRow() : renderSortableRow();
|
|
82181
|
+
}), paddingBottom > 0 && jsxRuntime.jsx("tr", {
|
|
82182
|
+
children: jsxRuntime.jsx("td", {
|
|
82183
|
+
style: {
|
|
82184
|
+
height: paddingBottom,
|
|
82185
|
+
padding: 0
|
|
82186
|
+
},
|
|
82187
|
+
colSpan: columns.length
|
|
82188
|
+
})
|
|
81293
82189
|
}), jsxRuntime.jsx("tr", {
|
|
81294
|
-
id: "ff-table-last-node"
|
|
82190
|
+
id: "ff-table-last-node",
|
|
82191
|
+
style: {
|
|
82192
|
+
display: 'none'
|
|
82193
|
+
}
|
|
81295
82194
|
})]
|
|
81296
82195
|
})]
|
|
81297
82196
|
}), data?.length <= 0 && jsxRuntime.jsx("div", {
|
|
@@ -81878,7 +82777,9 @@ const StepLandingTable = /*#__PURE__*/React.forwardRef(({
|
|
|
81878
82777
|
isViewPrivilegeMode = false,
|
|
81879
82778
|
defaultExpanded = 'Steps',
|
|
81880
82779
|
isHeaderRequired = true,
|
|
81881
|
-
isClientSide = false
|
|
82780
|
+
isClientSide = false,
|
|
82781
|
+
highlightKey,
|
|
82782
|
+
onHighlightComplete
|
|
81882
82783
|
}, ref) => {
|
|
81883
82784
|
const [ViewComponent, setViewComponent] = React.useState(null);
|
|
81884
82785
|
const [viewModeId, setViewModeId] = React.useState(null);
|
|
@@ -81986,6 +82887,8 @@ const StepLandingTable = /*#__PURE__*/React.forwardRef(({
|
|
|
81986
82887
|
const getAccordionTableContent = rows => {
|
|
81987
82888
|
if (rows.title === 'Steps' && !isViewPrivilegeMode) {
|
|
81988
82889
|
return jsxRuntime.jsx(StepInnerTable, {
|
|
82890
|
+
onHighlightComplete: onHighlightComplete,
|
|
82891
|
+
highlightKey: highlightKey,
|
|
81989
82892
|
draggable: true,
|
|
81990
82893
|
columns: tableMeta,
|
|
81991
82894
|
onDragEnd: onDragEnd,
|
|
@@ -82015,6 +82918,8 @@ const StepLandingTable = /*#__PURE__*/React.forwardRef(({
|
|
|
82015
82918
|
});
|
|
82016
82919
|
} else {
|
|
82017
82920
|
return jsxRuntime.jsx(StepInnerTable, {
|
|
82921
|
+
onHighlightComplete: onHighlightComplete,
|
|
82922
|
+
highlightKey: highlightKey,
|
|
82018
82923
|
editMode: editMode,
|
|
82019
82924
|
withCheckbox: !isViewPrivilegeMode,
|
|
82020
82925
|
editComponent: editComponent,
|
|
@@ -82058,7 +82963,6 @@ const StepLandingTable = /*#__PURE__*/React.forwardRef(({
|
|
|
82058
82963
|
}
|
|
82059
82964
|
}));
|
|
82060
82965
|
React.useEffect(() => {
|
|
82061
|
-
scrollToView('getInFocus');
|
|
82062
82966
|
if (!checkEmpty(AddNlp)) {
|
|
82063
82967
|
setViewComponent(() => null);
|
|
82064
82968
|
setViewModeId(null);
|