@ytsaurus/ui 1.13.1 → 1.14.0
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/build/cjs/shared/yt-types.d.ts +6 -0
- package/build/cjs/ui/common/yt-api-init.js +3 -1
- package/build/cjs/ui/common/yt-api-init.js.map +1 -1
- package/build/cjs/ui/constants/scheduling/index.d.ts +6 -7
- package/build/cjs/ui/constants/scheduling/index.js +7 -8
- package/build/cjs/ui/constants/scheduling/index.js.map +1 -1
- package/build/cjs/ui/pages/components/tabs/node/NodePage.js +1 -4
- package/build/cjs/ui/pages/components/tabs/node/NodePage.js.map +1 -1
- package/build/cjs/ui/pages/components/tabs/nodes/NodeCard/NodeCard.js +12 -16
- package/build/cjs/ui/pages/components/tabs/nodes/NodeCard/NodeCard.js.map +1 -1
- package/build/cjs/ui/pages/operations/OperationDetail/tabs/details/Runtime/Runtime.js +2 -5
- package/build/cjs/ui/pages/operations/OperationDetail/tabs/details/Runtime/Runtime.js.map +1 -1
- package/build/cjs/ui/pages/operations/OperationsList/OperationsListToolbar/OperationsListToolbar.js +1 -5
- package/build/cjs/ui/pages/operations/OperationsList/OperationsListToolbar/OperationsListToolbar.js.map +1 -1
- package/build/cjs/ui/pages/operations/selectors.d.ts +8 -7
- package/build/cjs/ui/pages/query-tracker/module/queries_list/selectors.d.ts +32 -28
- package/build/cjs/ui/pages/query-tracker/module/query/selectors.d.ts +8 -7
- package/build/cjs/ui/pages/query-tracker/module/settings/selector.d.ts +8 -7
- package/build/cjs/ui/pages/scheduling/Alerts.js +1 -1
- package/build/cjs/ui/pages/scheduling/Alerts.js.map +1 -1
- package/build/cjs/ui/pages/scheduling/Content/Content.js +2 -2
- package/build/cjs/ui/pages/scheduling/Content/Content.js.map +1 -1
- package/build/cjs/ui/pages/scheduling/Content/{SchedulingOperationsUpdater.d.ts → SchedulingExpandedPoolsUpdater.d.ts} +2 -2
- package/build/cjs/ui/pages/scheduling/Content/{SchedulingOperationsUpdater.js → SchedulingExpandedPoolsUpdater.js} +7 -8
- package/build/cjs/ui/pages/scheduling/Content/SchedulingExpandedPoolsUpdater.js.map +1 -0
- package/build/cjs/ui/pages/scheduling/Content/SchedulingResources.js +4 -3
- package/build/cjs/ui/pages/scheduling/Content/SchedulingResources.js.map +1 -1
- package/build/cjs/ui/pages/scheduling/Content/controls/ShareUsageBar.js +1 -1
- package/build/cjs/ui/pages/scheduling/Content/controls/ShareUsageBar.js.map +1 -1
- package/build/cjs/ui/pages/scheduling/Content/tabs/Details/Details.js +13 -8
- package/build/cjs/ui/pages/scheduling/Content/tabs/Details/Details.js.map +1 -1
- package/build/cjs/ui/pages/scheduling/Content/tabs/Overview/Overview.d.ts +12 -10
- package/build/cjs/ui/pages/scheduling/Content/tabs/Overview/Overview.js +30 -21
- package/build/cjs/ui/pages/scheduling/Content/tabs/Overview/Overview.js.map +1 -1
- package/build/cjs/ui/pages/scheduling/Content/tabs/SchedulingOperationsError/SchedulingOperationsError.js +2 -2
- package/build/cjs/ui/pages/scheduling/Content/tabs/SchedulingOperationsError/SchedulingOperationsError.js.map +1 -1
- package/build/cjs/ui/pages/scheduling/Content/tabs/ScherdulingOperataionsLoader/SchedulingOperationsLoader.js +2 -2
- package/build/cjs/ui/pages/scheduling/Content/tabs/ScherdulingOperataionsLoader/SchedulingOperationsLoader.js.map +1 -1
- package/build/cjs/ui/pages/scheduling/PoolQoutaEditor/PoolQuotaEditor.d.ts +0 -1
- package/build/cjs/ui/pages/scheduling/PoolQoutaEditor/PoolQuotaEditor.js +1 -3
- package/build/cjs/ui/pages/scheduling/PoolQoutaEditor/PoolQuotaEditor.js.map +1 -1
- package/build/cjs/ui/pages/scheduling/Scheduling/PoolEditorDialog/PoolEditorDialog.d.ts +24 -0
- package/build/cjs/ui/pages/scheduling/Scheduling/PoolEditorDialog/PoolEditorDialog.js +8 -19
- package/build/cjs/ui/pages/scheduling/Scheduling/PoolEditorDialog/PoolEditorDialog.js.map +1 -1
- package/build/cjs/ui/pages/scheduling/Scheduling/Scheduling.js +29 -48
- package/build/cjs/ui/pages/scheduling/Scheduling/Scheduling.js.map +1 -1
- package/build/cjs/ui/pages/scheduling/Scheduling/SchedulingTopRowContent.js +8 -4
- package/build/cjs/ui/pages/scheduling/Scheduling/SchedulingTopRowContent.js.map +1 -1
- package/build/cjs/ui/rum/rum-wrap-api.d.ts +95 -53
- package/build/cjs/ui/rum/rum-wrap-api.js +59 -56
- package/build/cjs/ui/rum/rum-wrap-api.js.map +1 -1
- package/build/cjs/ui/store/actions/components/node/node.js +6 -29
- package/build/cjs/ui/store/actions/components/node/node.js.map +1 -1
- package/build/cjs/ui/store/actions/operations/detail.js +1 -1
- package/build/cjs/ui/store/actions/operations/detail.js.map +1 -1
- package/build/cjs/ui/store/actions/scheduling/create-pool-dialog.js +3 -3
- package/build/cjs/ui/store/actions/scheduling/create-pool-dialog.js.map +1 -1
- package/build/cjs/ui/store/actions/scheduling/expanded-pools.d.ts +15 -0
- package/build/cjs/ui/store/actions/scheduling/expanded-pools.js +377 -0
- package/build/cjs/ui/store/actions/scheduling/expanded-pools.js.map +1 -0
- package/build/cjs/ui/store/actions/scheduling/scheduling-ts.d.ts +15 -1
- package/build/cjs/ui/store/actions/scheduling/scheduling-ts.js +226 -10
- package/build/cjs/ui/store/actions/scheduling/scheduling-ts.js.map +1 -1
- package/build/cjs/ui/store/actions/scheduling/scheduling.d.ts +1 -32
- package/build/cjs/ui/store/actions/scheduling/scheduling.js +12 -250
- package/build/cjs/ui/store/actions/scheduling/scheduling.js.map +1 -1
- package/build/cjs/ui/store/reducers/components/node/node.d.ts +0 -2
- package/build/cjs/ui/store/reducers/components/node/node.js +2 -5
- package/build/cjs/ui/store/reducers/components/node/node.js.map +1 -1
- package/build/cjs/ui/store/reducers/index.d.ts +9 -7
- package/build/cjs/ui/store/reducers/index.js +3 -4
- package/build/cjs/ui/store/reducers/index.js.map +1 -1
- package/build/cjs/ui/store/reducers/scheduling/expanded-pools.d.ts +28 -0
- package/build/cjs/ui/store/reducers/scheduling/{scheduling-operations.js → expanded-pools.js} +10 -8
- package/build/cjs/ui/store/reducers/scheduling/expanded-pools.js.map +1 -0
- package/build/cjs/ui/store/reducers/scheduling/index.d.ts +5 -93
- package/build/cjs/ui/store/reducers/scheduling/index.js +10 -136
- package/build/cjs/ui/store/reducers/scheduling/index.js.map +1 -1
- package/build/cjs/ui/store/reducers/scheduling/scheduling.d.ts +100 -0
- package/build/cjs/ui/store/reducers/scheduling/scheduling.js +139 -0
- package/build/cjs/ui/store/reducers/scheduling/scheduling.js.map +1 -0
- package/build/cjs/ui/store/reducers/scheduling/url-mapping.d.ts +13 -2
- package/build/cjs/ui/store/reducers/scheduling/url-mapping.js +31 -26
- package/build/cjs/ui/store/reducers/scheduling/url-mapping.js.map +1 -1
- package/build/cjs/ui/store/selectors/accounts/account-usage.d.ts +64 -56
- package/build/cjs/ui/store/selectors/accounts/accounts-ts.d.ts +64 -56
- package/build/cjs/ui/store/selectors/chaos_cell_bundles/index.d.ts +88 -77
- package/build/cjs/ui/store/selectors/chyt/index.d.ts +56 -49
- package/build/cjs/ui/store/selectors/components/node/memory.d.ts +56 -49
- package/build/cjs/ui/store/selectors/components/node-maintenance-modal.d.ts +1712 -13
- package/build/cjs/ui/store/selectors/components/nodes/node-card.d.ts +8 -7
- package/build/cjs/ui/store/selectors/components/nodes/nodes/data.d.ts +16 -14
- package/build/cjs/ui/store/selectors/components/nodes/nodes/predicates.d.ts +48 -42
- package/build/cjs/ui/store/selectors/components/versions/versions_v2-ts.d.ts +859 -9
- package/build/cjs/ui/store/selectors/components/versions/versions_v2.d.ts +40 -35
- package/build/cjs/ui/store/selectors/global/index.d.ts +116 -102
- package/build/cjs/ui/store/selectors/global/index.js +2 -3
- package/build/cjs/ui/store/selectors/global/index.js.map +1 -1
- package/build/cjs/ui/store/selectors/global/supported-features.d.ts +48 -42
- package/build/cjs/ui/store/selectors/modals/errors.d.ts +8 -7
- package/build/cjs/ui/store/selectors/navigation/content/document.d.ts +8 -7
- package/build/cjs/ui/store/selectors/navigation/content/replicated-table.d.ts +24 -21
- package/build/cjs/ui/store/selectors/navigation/content/table-mount-config.d.ts +8 -7
- package/build/cjs/ui/store/selectors/navigation/content/table-ts.d.ts +32 -28
- package/build/cjs/ui/store/selectors/navigation/content/table.d.ts +56 -49
- package/build/cjs/ui/store/selectors/navigation/modals/attributes-editor.d.ts +24 -21
- package/build/cjs/ui/store/selectors/navigation/modals/remote-copy-modal.d.ts +8 -7
- package/build/cjs/ui/store/selectors/navigation/navigation.d.ts +16 -14
- package/build/cjs/ui/store/selectors/navigation/tabs/access-log.d.ts +8 -7
- package/build/cjs/ui/store/selectors/navigation/tabs/annotation.d.ts +8 -7
- package/build/cjs/ui/store/selectors/navigation/tabs/consumer.d.ts +8 -7
- package/build/cjs/ui/store/selectors/navigation/tabs/locks.d.ts +16 -14
- package/build/cjs/ui/store/selectors/navigation/tabs/queue.d.ts +16 -14
- package/build/cjs/ui/store/selectors/navigation/tabs/tablet-errors.d.ts +8 -7
- package/build/cjs/ui/store/selectors/operations/index.d.ts +96 -84
- package/build/cjs/ui/store/selectors/operations/jobs-monitor.d.ts +32 -28
- package/build/cjs/ui/store/selectors/operations/operation.d.ts +939 -79
- package/build/cjs/ui/store/selectors/operations/operation.js +2 -17
- package/build/cjs/ui/store/selectors/operations/operation.js.map +1 -1
- package/build/cjs/ui/store/selectors/operations/operations-list.d.ts +24 -21
- package/build/cjs/ui/store/selectors/operations/statistics-v2.d.ts +64 -56
- package/build/cjs/ui/store/selectors/scheduling/attributes-to-filter.d.ts +876 -0
- package/build/cjs/ui/store/selectors/scheduling/attributes-to-filter.js +75 -0
- package/build/cjs/ui/store/selectors/scheduling/attributes-to-filter.js.map +1 -0
- package/build/cjs/ui/store/selectors/scheduling/create-pool-dialog.d.ts +8 -7
- package/build/cjs/ui/store/selectors/scheduling/create-pool-dialog.js +3 -3
- package/build/cjs/ui/store/selectors/scheduling/create-pool-dialog.js.map +1 -1
- package/build/cjs/ui/store/selectors/scheduling/{scheduling-operations.d.ts → expanded-pools.d.ts} +14 -14
- package/build/cjs/ui/store/selectors/scheduling/expanded-pools.js +35 -0
- package/build/cjs/ui/store/selectors/scheduling/expanded-pools.js.map +1 -0
- package/build/cjs/ui/store/selectors/scheduling/index.d.ts +8 -7
- package/build/cjs/ui/store/selectors/scheduling/index.js +3 -3
- package/build/cjs/ui/store/selectors/scheduling/index.js.map +1 -1
- package/build/cjs/ui/store/selectors/scheduling/monitor.js +1 -1
- package/build/cjs/ui/store/selectors/scheduling/monitor.js.map +1 -1
- package/build/cjs/ui/store/selectors/scheduling/scheduling-pools.d.ts +2552 -3
- package/build/cjs/ui/store/selectors/scheduling/scheduling-pools.js +10 -18
- package/build/cjs/ui/store/selectors/scheduling/scheduling-pools.js.map +1 -1
- package/build/cjs/ui/store/selectors/scheduling/scheduling-ts.d.ts +4291 -45
- package/build/cjs/ui/store/selectors/scheduling/scheduling.d.ts +13739 -149
- package/build/cjs/ui/store/selectors/scheduling/scheduling.js +35 -30
- package/build/cjs/ui/store/selectors/scheduling/scheduling.js.map +1 -1
- package/build/cjs/ui/store/selectors/tablet_cell_bundles/index.d.ts +120 -105
- package/build/cjs/ui/store/selectors/thor/support.d.ts +4294 -86
- package/build/cjs/ui/store/selectors/thor/support.js +76 -138
- package/build/cjs/ui/store/selectors/thor/support.js.map +1 -1
- package/build/cjs/ui/store/selectors/thor/support.spec.js +163 -68
- package/build/cjs/ui/store/selectors/thor/support.spec.js.map +1 -1
- package/build/cjs/ui/store/window-store.js +2 -2
- package/build/cjs/ui/store/window-store.js.map +1 -1
- package/build/cjs/ui/utils/batch.d.ts +54 -0
- package/build/cjs/ui/utils/batch.js +27 -0
- package/build/cjs/ui/utils/batch.js.map +1 -0
- package/build/cjs/ui/utils/scheduling/pool-child.d.ts +1 -1
- package/build/cjs/ui/utils/scheduling/pool-child.js +20 -9
- package/build/cjs/ui/utils/scheduling/pool-child.js.map +1 -1
- package/build/cjs/ui/utils/scheduling/scheduling.d.ts +2 -6
- package/build/cjs/ui/utils/scheduling/scheduling.js +3 -3
- package/build/cjs/ui/utils/scheduling/scheduling.js.map +1 -1
- package/build/cjs/ui/utils/utils.d.ts +3 -2
- package/build/cjs/ui/utils/utils.js +17 -9
- package/build/cjs/ui/utils/utils.js.map +1 -1
- package/build/esm/shared/yt-types.d.ts +6 -0
- package/build/esm/ui/common/yt-api-init.js +4 -2
- package/build/esm/ui/common/yt-api-init.js.map +1 -1
- package/build/esm/ui/constants/scheduling/index.d.ts +6 -7
- package/build/esm/ui/constants/scheduling/index.js +6 -7
- package/build/esm/ui/constants/scheduling/index.js.map +1 -1
- package/build/esm/ui/pages/components/tabs/node/NodePage.js +1 -4
- package/build/esm/ui/pages/components/tabs/node/NodePage.js.map +1 -1
- package/build/esm/ui/pages/components/tabs/nodes/NodeCard/NodeCard.js +12 -16
- package/build/esm/ui/pages/components/tabs/nodes/NodeCard/NodeCard.js.map +1 -1
- package/build/esm/ui/pages/operations/OperationDetail/tabs/details/Runtime/Runtime.js +3 -6
- package/build/esm/ui/pages/operations/OperationDetail/tabs/details/Runtime/Runtime.js.map +1 -1
- package/build/esm/ui/pages/operations/OperationsList/OperationsListToolbar/OperationsListToolbar.js +1 -5
- package/build/esm/ui/pages/operations/OperationsList/OperationsListToolbar/OperationsListToolbar.js.map +1 -1
- package/build/esm/ui/pages/operations/selectors.d.ts +8 -7
- package/build/esm/ui/pages/query-tracker/module/queries_list/selectors.d.ts +32 -28
- package/build/esm/ui/pages/query-tracker/module/query/selectors.d.ts +8 -7
- package/build/esm/ui/pages/query-tracker/module/settings/selector.d.ts +8 -7
- package/build/esm/ui/pages/scheduling/Alerts.js +1 -1
- package/build/esm/ui/pages/scheduling/Alerts.js.map +1 -1
- package/build/esm/ui/pages/scheduling/Content/Content.js +2 -2
- package/build/esm/ui/pages/scheduling/Content/Content.js.map +1 -1
- package/build/esm/ui/pages/scheduling/Content/{SchedulingOperationsUpdater.d.ts → SchedulingExpandedPoolsUpdater.d.ts} +2 -2
- package/build/esm/ui/pages/scheduling/Content/SchedulingExpandedPoolsUpdater.js +15 -0
- package/build/esm/ui/pages/scheduling/Content/SchedulingExpandedPoolsUpdater.js.map +1 -0
- package/build/esm/ui/pages/scheduling/Content/SchedulingResources.js +4 -3
- package/build/esm/ui/pages/scheduling/Content/SchedulingResources.js.map +1 -1
- package/build/esm/ui/pages/scheduling/Content/controls/ShareUsageBar.js +1 -1
- package/build/esm/ui/pages/scheduling/Content/controls/ShareUsageBar.js.map +1 -1
- package/build/esm/ui/pages/scheduling/Content/tabs/Details/Details.js +14 -9
- package/build/esm/ui/pages/scheduling/Content/tabs/Details/Details.js.map +1 -1
- package/build/esm/ui/pages/scheduling/Content/tabs/Overview/Overview.d.ts +12 -10
- package/build/esm/ui/pages/scheduling/Content/tabs/Overview/Overview.js +27 -18
- package/build/esm/ui/pages/scheduling/Content/tabs/Overview/Overview.js.map +1 -1
- package/build/esm/ui/pages/scheduling/Content/tabs/SchedulingOperationsError/SchedulingOperationsError.js +1 -1
- package/build/esm/ui/pages/scheduling/Content/tabs/SchedulingOperationsError/SchedulingOperationsError.js.map +1 -1
- package/build/esm/ui/pages/scheduling/Content/tabs/ScherdulingOperataionsLoader/SchedulingOperationsLoader.js +1 -1
- package/build/esm/ui/pages/scheduling/Content/tabs/ScherdulingOperataionsLoader/SchedulingOperationsLoader.js.map +1 -1
- package/build/esm/ui/pages/scheduling/PoolQoutaEditor/PoolQuotaEditor.d.ts +0 -1
- package/build/esm/ui/pages/scheduling/PoolQoutaEditor/PoolQuotaEditor.js +1 -3
- package/build/esm/ui/pages/scheduling/PoolQoutaEditor/PoolQuotaEditor.js.map +1 -1
- package/build/esm/ui/pages/scheduling/Scheduling/PoolEditorDialog/PoolEditorDialog.d.ts +24 -0
- package/build/esm/ui/pages/scheduling/Scheduling/PoolEditorDialog/PoolEditorDialog.js +8 -19
- package/build/esm/ui/pages/scheduling/Scheduling/PoolEditorDialog/PoolEditorDialog.js.map +1 -1
- package/build/esm/ui/pages/scheduling/Scheduling/Scheduling.js +26 -45
- package/build/esm/ui/pages/scheduling/Scheduling/Scheduling.js.map +1 -1
- package/build/esm/ui/pages/scheduling/Scheduling/SchedulingTopRowContent.js +6 -2
- package/build/esm/ui/pages/scheduling/Scheduling/SchedulingTopRowContent.js.map +1 -1
- package/build/esm/ui/rum/rum-wrap-api.d.ts +95 -53
- package/build/esm/ui/rum/rum-wrap-api.js +58 -55
- package/build/esm/ui/rum/rum-wrap-api.js.map +1 -1
- package/build/esm/ui/store/actions/components/node/node.js +6 -28
- package/build/esm/ui/store/actions/components/node/node.js.map +1 -1
- package/build/esm/ui/store/actions/operations/detail.js +1 -1
- package/build/esm/ui/store/actions/operations/detail.js.map +1 -1
- package/build/esm/ui/store/actions/scheduling/create-pool-dialog.js +2 -2
- package/build/esm/ui/store/actions/scheduling/create-pool-dialog.js.map +1 -1
- package/build/esm/ui/store/actions/scheduling/expanded-pools.d.ts +15 -0
- package/build/esm/ui/store/actions/scheduling/expanded-pools.js +363 -0
- package/build/esm/ui/store/actions/scheduling/expanded-pools.js.map +1 -0
- package/build/esm/ui/store/actions/scheduling/scheduling-ts.d.ts +15 -1
- package/build/esm/ui/store/actions/scheduling/scheduling-ts.js +221 -13
- package/build/esm/ui/store/actions/scheduling/scheduling-ts.js.map +1 -1
- package/build/esm/ui/store/actions/scheduling/scheduling.d.ts +1 -32
- package/build/esm/ui/store/actions/scheduling/scheduling.js +16 -247
- package/build/esm/ui/store/actions/scheduling/scheduling.js.map +1 -1
- package/build/esm/ui/store/reducers/components/node/node.d.ts +0 -2
- package/build/esm/ui/store/reducers/components/node/node.js +2 -5
- package/build/esm/ui/store/reducers/components/node/node.js.map +1 -1
- package/build/esm/ui/store/reducers/index.d.ts +9 -7
- package/build/esm/ui/store/reducers/index.js +3 -4
- package/build/esm/ui/store/reducers/index.js.map +1 -1
- package/build/esm/ui/store/reducers/scheduling/expanded-pools.d.ts +28 -0
- package/build/esm/ui/store/reducers/scheduling/{scheduling-operations.js → expanded-pools.js} +11 -9
- package/build/esm/ui/store/reducers/scheduling/expanded-pools.js.map +1 -0
- package/build/esm/ui/store/reducers/scheduling/index.d.ts +5 -93
- package/build/esm/ui/store/reducers/scheduling/index.js +9 -135
- package/build/esm/ui/store/reducers/scheduling/index.js.map +1 -1
- package/build/esm/ui/store/reducers/scheduling/scheduling.d.ts +100 -0
- package/build/esm/ui/store/reducers/scheduling/scheduling.js +132 -0
- package/build/esm/ui/store/reducers/scheduling/scheduling.js.map +1 -0
- package/build/esm/ui/store/reducers/scheduling/url-mapping.d.ts +13 -2
- package/build/esm/ui/store/reducers/scheduling/url-mapping.js +19 -14
- package/build/esm/ui/store/reducers/scheduling/url-mapping.js.map +1 -1
- package/build/esm/ui/store/selectors/accounts/account-usage.d.ts +64 -56
- package/build/esm/ui/store/selectors/accounts/accounts-ts.d.ts +64 -56
- package/build/esm/ui/store/selectors/chaos_cell_bundles/index.d.ts +88 -77
- package/build/esm/ui/store/selectors/chyt/index.d.ts +56 -49
- package/build/esm/ui/store/selectors/components/node/memory.d.ts +56 -49
- package/build/esm/ui/store/selectors/components/node-maintenance-modal.d.ts +1712 -13
- package/build/esm/ui/store/selectors/components/nodes/node-card.d.ts +8 -7
- package/build/esm/ui/store/selectors/components/nodes/nodes/data.d.ts +16 -14
- package/build/esm/ui/store/selectors/components/nodes/nodes/predicates.d.ts +48 -42
- package/build/esm/ui/store/selectors/components/versions/versions_v2-ts.d.ts +859 -9
- package/build/esm/ui/store/selectors/components/versions/versions_v2.d.ts +40 -35
- package/build/esm/ui/store/selectors/global/index.d.ts +116 -102
- package/build/esm/ui/store/selectors/global/index.js +2 -3
- package/build/esm/ui/store/selectors/global/index.js.map +1 -1
- package/build/esm/ui/store/selectors/global/supported-features.d.ts +48 -42
- package/build/esm/ui/store/selectors/modals/errors.d.ts +8 -7
- package/build/esm/ui/store/selectors/navigation/content/document.d.ts +8 -7
- package/build/esm/ui/store/selectors/navigation/content/replicated-table.d.ts +24 -21
- package/build/esm/ui/store/selectors/navigation/content/table-mount-config.d.ts +8 -7
- package/build/esm/ui/store/selectors/navigation/content/table-ts.d.ts +32 -28
- package/build/esm/ui/store/selectors/navigation/content/table.d.ts +56 -49
- package/build/esm/ui/store/selectors/navigation/modals/attributes-editor.d.ts +24 -21
- package/build/esm/ui/store/selectors/navigation/modals/remote-copy-modal.d.ts +8 -7
- package/build/esm/ui/store/selectors/navigation/navigation.d.ts +16 -14
- package/build/esm/ui/store/selectors/navigation/tabs/access-log.d.ts +8 -7
- package/build/esm/ui/store/selectors/navigation/tabs/annotation.d.ts +8 -7
- package/build/esm/ui/store/selectors/navigation/tabs/consumer.d.ts +8 -7
- package/build/esm/ui/store/selectors/navigation/tabs/locks.d.ts +16 -14
- package/build/esm/ui/store/selectors/navigation/tabs/queue.d.ts +16 -14
- package/build/esm/ui/store/selectors/navigation/tabs/tablet-errors.d.ts +8 -7
- package/build/esm/ui/store/selectors/operations/index.d.ts +96 -84
- package/build/esm/ui/store/selectors/operations/jobs-monitor.d.ts +32 -28
- package/build/esm/ui/store/selectors/operations/operation.d.ts +939 -79
- package/build/esm/ui/store/selectors/operations/operation.js +2 -17
- package/build/esm/ui/store/selectors/operations/operation.js.map +1 -1
- package/build/esm/ui/store/selectors/operations/operations-list.d.ts +24 -21
- package/build/esm/ui/store/selectors/operations/statistics-v2.d.ts +64 -56
- package/build/esm/ui/store/selectors/scheduling/attributes-to-filter.d.ts +876 -0
- package/build/esm/ui/store/selectors/scheduling/attributes-to-filter.js +68 -0
- package/build/esm/ui/store/selectors/scheduling/attributes-to-filter.js.map +1 -0
- package/build/esm/ui/store/selectors/scheduling/create-pool-dialog.d.ts +8 -7
- package/build/esm/ui/store/selectors/scheduling/create-pool-dialog.js +3 -3
- package/build/esm/ui/store/selectors/scheduling/create-pool-dialog.js.map +1 -1
- package/build/esm/ui/store/selectors/scheduling/{scheduling-operations.d.ts → expanded-pools.d.ts} +14 -14
- package/build/esm/ui/store/selectors/scheduling/{scheduling-operations.js → expanded-pools.js} +13 -10
- package/build/esm/ui/store/selectors/scheduling/expanded-pools.js.map +1 -0
- package/build/esm/ui/store/selectors/scheduling/index.d.ts +8 -7
- package/build/esm/ui/store/selectors/scheduling/index.js +3 -3
- package/build/esm/ui/store/selectors/scheduling/index.js.map +1 -1
- package/build/esm/ui/store/selectors/scheduling/monitor.js +1 -1
- package/build/esm/ui/store/selectors/scheduling/monitor.js.map +1 -1
- package/build/esm/ui/store/selectors/scheduling/scheduling-pools.d.ts +2552 -3
- package/build/esm/ui/store/selectors/scheduling/scheduling-pools.js +11 -19
- package/build/esm/ui/store/selectors/scheduling/scheduling-pools.js.map +1 -1
- package/build/esm/ui/store/selectors/scheduling/scheduling-ts.d.ts +4291 -45
- package/build/esm/ui/store/selectors/scheduling/scheduling.d.ts +13739 -149
- package/build/esm/ui/store/selectors/scheduling/scheduling.js +34 -29
- package/build/esm/ui/store/selectors/scheduling/scheduling.js.map +1 -1
- package/build/esm/ui/store/selectors/tablet_cell_bundles/index.d.ts +120 -105
- package/build/esm/ui/store/selectors/thor/support.d.ts +4294 -86
- package/build/esm/ui/store/selectors/thor/support.js +73 -134
- package/build/esm/ui/store/selectors/thor/support.js.map +1 -1
- package/build/esm/ui/store/selectors/thor/support.spec.js +164 -69
- package/build/esm/ui/store/selectors/thor/support.spec.js.map +1 -1
- package/build/esm/ui/store/window-store.js +1 -1
- package/build/esm/ui/store/window-store.js.map +1 -1
- package/build/esm/ui/utils/batch.d.ts +54 -0
- package/build/esm/ui/utils/batch.js +19 -0
- package/build/esm/ui/utils/batch.js.map +1 -0
- package/build/esm/ui/utils/scheduling/pool-child.d.ts +1 -1
- package/build/esm/ui/utils/scheduling/pool-child.js +20 -9
- package/build/esm/ui/utils/scheduling/pool-child.js.map +1 -1
- package/build/esm/ui/utils/scheduling/scheduling.d.ts +2 -6
- package/build/esm/ui/utils/scheduling/scheduling.js +3 -3
- package/build/esm/ui/utils/scheduling/scheduling.js.map +1 -1
- package/build/esm/ui/utils/utils.d.ts +3 -2
- package/build/esm/ui/utils/utils.js +17 -9
- package/build/esm/ui/utils/utils.js.map +1 -1
- package/dist/public/build/assets-manifest.json +7 -7
- package/dist/public/build/js/main.64fccb27.js +3 -0
- package/dist/public/build/js/{main.4eb01db4.js.map → main.64fccb27.js.map} +1 -1
- package/dist/public/build/js/{runtime.9491563b.js → runtime.fd8cf219.js} +2 -2
- package/dist/public/build/js/{runtime.9491563b.js.map → runtime.fd8cf219.js.map} +1 -1
- package/dist/public/build/manifest.json +4 -4
- package/package.json +2 -2
- package/build/cjs/ui/pages/scheduling/Content/SchedulingOperationsUpdater.js.map +0 -1
- package/build/cjs/ui/store/actions/scheduling/scheduling-operations.d.ts +0 -15
- package/build/cjs/ui/store/actions/scheduling/scheduling-operations.js +0 -280
- package/build/cjs/ui/store/actions/scheduling/scheduling-operations.js.map +0 -1
- package/build/cjs/ui/store/reducers/scheduling/scheduling-operations.d.ts +0 -19
- package/build/cjs/ui/store/reducers/scheduling/scheduling-operations.js.map +0 -1
- package/build/cjs/ui/store/selectors/scheduling/scheduling-operations.js +0 -32
- package/build/cjs/ui/store/selectors/scheduling/scheduling-operations.js.map +0 -1
- package/build/esm/ui/pages/scheduling/Content/SchedulingOperationsUpdater.js +0 -16
- package/build/esm/ui/pages/scheduling/Content/SchedulingOperationsUpdater.js.map +0 -1
- package/build/esm/ui/store/actions/scheduling/scheduling-operations.d.ts +0 -15
- package/build/esm/ui/store/actions/scheduling/scheduling-operations.js +0 -267
- package/build/esm/ui/store/actions/scheduling/scheduling-operations.js.map +0 -1
- package/build/esm/ui/store/reducers/scheduling/scheduling-operations.d.ts +0 -19
- package/build/esm/ui/store/reducers/scheduling/scheduling-operations.js.map +0 -1
- package/build/esm/ui/store/selectors/scheduling/scheduling-operations.js.map +0 -1
- package/dist/public/build/js/main.4eb01db4.js +0 -3
- /package/dist/public/build/js/{main.4eb01db4.js.LICENSE.txt → main.64fccb27.js.LICENSE.txt} +0 -0
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["_yt","_interopRequireDefault","require","_ypath","_detail","_selectors","_detail2","_utils","_utils2","_list","_index","_uikit","_cancelHelper","_rumWrapApi","_jobsMonitor","obj","__esModule","default","toaster","Toaster","operationDetailsRequests","CancelHelper","getIsEphemeral","_ref","_ref2","_slicedToArray","operationAttributes","userTransactionAlive","treesInfo","ypath","get","trees","_keys","poolPaths","_values","_mapValues","infoPerTree","tree","concat","getValue","requests","_map","path","command","parameters","orchidAttributes","ytApiV3Id","executeBatch","YTApiId","operationIsEphemeral","then","data","_ref3","error","output","getNumberDeprecated","code","yt","codes","NODE_DOES_NOT_EXIST","res","_reduce","poolInfo","index","pool","isEphemeral","getBoolean","_defineProperty","Promise","all","loadIntermediateResourceUsage","operation","callback","dispatch","outputTransaction","type","LOAD_RESOURCE_USAGE","REQUEST","operationIntermediateResourceUsage","resources","SUCCESS","FAILURE","CANCELLED","getOperation","id","getState","isAlias","isOperationId","params","Object","assign","include_scheduler","output_format","TYPED_OUTPUT_FORMAT","operation_alias","operation_id","GET_OPERATION","ytApiV3","checkUserTransaction","_ref4","_ref5","preparedAttributes","prepareAttributes","DetailedOperationSelector","dispatchOperationSuccess","inIntermediateState","getJobsMonitoringDescriptors","_getState","operations","isFirstLoading","detail","loaded","add","name","autoHiding","title","content","message","actions","label","onClick","showErrorPopup","details"],"sources":["detail.js"],"sourcesContent":["import yt from '@ytsaurus/javascript-wrapper/lib/yt';\nimport _ from 'lodash';\nimport ypath from '../../../common/thor/ypath';\n\nimport {GET_OPERATION, LOAD_RESOURCE_USAGE} from '../../../constants/operations/detail';\nimport {DetailedOperationSelector} from '../../../pages/operations/selectors';\nimport {checkUserTransaction} from '../../../utils/operations/detail';\nimport {prepareAttributes} from '../../../utils';\nimport {showErrorPopup} from '../../../utils/utils';\nimport {isOperationId} from '../../../utils/operations/list';\nimport {TYPED_OUTPUT_FORMAT} from '../../../constants/index';\nimport {Toaster} from '@gravity-ui/uikit';\nimport CancelHelper from '../../../utils/cancel-helper';\nimport {YTApiId, ytApiV3, ytApiV3Id} from '../../../rum/rum-wrap-api';\nimport {getJobsMonitoringDescriptors} from '../../../store/actions/operations/jobs-monitor';\n\nconst toaster = new Toaster();\nconst operationDetailsRequests = new CancelHelper();\n\nfunction getIsEphemeral([operationAttributes, userTransactionAlive]) {\n const treesInfo = ypath.get(\n operationAttributes,\n '/runtime_parameters/scheduling_options_per_pool_tree',\n );\n const trees = _.keys(treesInfo);\n const poolPaths = _.values(\n _.mapValues(\n treesInfo,\n (infoPerTree, tree) =>\n `${tree}/fair_share_info/pools/${ypath.getValue(\n infoPerTree,\n '/pool',\n )}/is_ephemeral`,\n ),\n );\n const requests = _.map(poolPaths, (path) => {\n return {\n command: 'get',\n parameters: {\n path: '//sys/scheduler/orchid/scheduler/scheduling_info_per_pool_tree/' + path,\n },\n };\n });\n const orchidAttributes = ytApiV3Id\n .executeBatch(YTApiId.operationIsEphemeral, {requests})\n .then((data) => {\n return _.map(data, ({error, output}) => {\n if (error) {\n if (ypath.getNumberDeprecated(error.code) === yt.codes.NODE_DOES_NOT_EXIST) {\n return true;\n }\n return false;\n }\n return output;\n });\n })\n .then((res) => {\n return _.reduce(\n res,\n (res, poolInfo, index) => {\n const tree = trees[index];\n const pool = ypath.getValue(treesInfo[tree], '/pool');\n const isEphemeral = ypath.getBoolean(poolInfo);\n\n res[tree] = {\n [pool]: {isEphemeral},\n };\n\n return res;\n },\n {},\n );\n });\n\n return Promise.all([operationAttributes, userTransactionAlive, orchidAttributes]);\n}\n\nfunction loadIntermediateResourceUsage(operation, callback) {\n return (dispatch) => {\n const outputTransaction = ypath.get(operation, '/@output_transaction_id');\n\n if (outputTransaction && outputTransaction !== '0-0-0-0') {\n dispatch({type: LOAD_RESOURCE_USAGE.REQUEST});\n\n return ytApiV3Id\n .get(YTApiId.operationIntermediateResourceUsage, {\n path: '#' + outputTransaction + '/@resource_usage',\n })\n .then((resources) => {\n callback();\n dispatch({\n type: LOAD_RESOURCE_USAGE.SUCCESS,\n data: {resources},\n });\n })\n .catch(() => {\n callback();\n dispatch({type: LOAD_RESOURCE_USAGE.FAILURE});\n });\n } else {\n callback();\n dispatch({type: LOAD_RESOURCE_USAGE.CANCELLED});\n }\n };\n}\n\nexport function getOperation(id) {\n return (dispatch, getState) => {\n const isAlias = !isOperationId(id);\n\n const params = Object.assign(\n {\n include_scheduler: true,\n output_format: TYPED_OUTPUT_FORMAT,\n },\n isAlias ? {operation_alias: id} : {operation_id: id},\n );\n\n dispatch({type: GET_OPERATION.REQUEST, data: {isAlias, id}});\n\n return ytApiV3\n .getOperation(params, operationDetailsRequests)\n .then(checkUserTransaction)\n .then(getIsEphemeral)\n .then(([operationAttributes, userTransactionAlive, orchidAttributes]) => {\n const preparedAttributes = prepareAttributes(operationAttributes);\n const operation = new DetailedOperationSelector(\n preparedAttributes,\n operationAttributes,\n orchidAttributes,\n );\n\n const dispatchOperationSuccess = () => {\n dispatch({\n type: GET_OPERATION.SUCCESS,\n data: {operation, userTransactionAlive},\n });\n };\n\n if (operation.inIntermediateState()) {\n dispatch(loadIntermediateResourceUsage(operation, dispatchOperationSuccess));\n } else {\n dispatchOperationSuccess();\n }\n\n dispatch(getJobsMonitoringDescriptors(id));\n })\n .catch((error) => {\n const {operations} = getState();\n const isFirstLoading = !operations.detail.loaded;\n\n if (error.code !== yt.codes.CANCELLED) {\n if (!isFirstLoading) {\n toaster.add({\n name: 'get operation',\n autoHiding: false,\n type: 'error',\n title: 'Failed to load operation',\n content: error.message,\n actions: [\n {\n label: ' view',\n onClick: () => showErrorPopup(error),\n },\n ],\n });\n }\n\n dispatch({\n type: GET_OPERATION.FAILURE,\n data: {\n message: `Error occured when loading operation \"${id}\"`,\n details: error,\n },\n });\n }\n });\n };\n}\n"],"mappings":";;;;;;;;;;;;;AAAA,IAAAA,GAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEA,IAAAC,MAAA,GAAAF,sBAAA,CAAAC,OAAA;AAEA,IAAAE,OAAA,GAAAF,OAAA;AACA,IAAAG,UAAA,GAAAH,OAAA;AACA,IAAAI,QAAA,GAAAJ,OAAA;AACA,IAAAK,MAAA,GAAAL,OAAA;AACA,IAAAM,OAAA,GAAAN,OAAA;AACA,IAAAO,KAAA,GAAAP,OAAA;AACA,IAAAQ,MAAA,GAAAR,OAAA;AACA,IAAAS,MAAA,GAAAT,OAAA;AACA,IAAAU,aAAA,GAAAX,sBAAA,CAAAC,OAAA;AACA,IAAAW,WAAA,GAAAX,OAAA;AACA,IAAAY,YAAA,GAAAZ,OAAA;AAA2F,SAAAD,uBAAAc,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAE3F,IAAMG,OAAO,GAAG,IAAIC,cAAO,CAAC,CAAC;AAC7B,IAAMC,wBAAwB,GAAG,IAAIC,qBAAY,CAAC,CAAC;AAEnD,SAASC,cAAcA,CAAAC,IAAA,EAA8C;EAAA,IAAAC,KAAA,OAAAC,uBAAA,EAAAF,IAAA;IAA5CG,mBAAmB,GAAAF,KAAA;IAAEG,oBAAoB,GAAAH,KAAA;EAC9D,IAAMI,SAAS,GAAGC,cAAK,CAACC,GAAG,CACvBJ,mBAAmB,EACnB,sDACJ,CAAC;EACD,IAAMK,KAAK,GAAG,IAAAC,cAAA,EAAOJ,SAAS,CAAC;EAC/B,IAAMK,SAAS,GAAG,IAAAC,gBAAA,EACd,IAAAC,mBAAA,EACIP,SAAS,EACT,UAACQ,WAAW,EAAEC,IAAI;IAAA,UAAAC,MAAA,CACXD,IAAI,6BAAAC,MAAA,CAA0BT,cAAK,CAACU,QAAQ,CAC3CH,WAAW,EACX,OACJ,CAAC;EAAA,CACT,CACJ,CAAC;EACD,IAAMI,QAAQ,GAAG,IAAAC,aAAA,EAAMR,SAAS,EAAE,UAACS,IAAI,EAAK;IACxC,OAAO;MACHC,OAAO,EAAE,KAAK;MACdC,UAAU,EAAE;QACRF,IAAI,EAAE,iEAAiE,GAAGA;MAC9E;IACJ,CAAC;EACL,CAAC,CAAC;EACF,IAAMG,gBAAgB,GAAGC,qBAAS,CAC7BC,YAAY,CAACC,mBAAO,CAACC,oBAAoB,EAAE;IAACT,QAAQ,EAARA;EAAQ,CAAC,CAAC,CACtDU,IAAI,CAAC,UAACC,IAAI,EAAK;IACZ,OAAO,IAAAV,aAAA,EAAMU,IAAI,EAAE,UAAAC,KAAA,EAAqB;MAAA,IAAnBC,KAAK,GAAAD,KAAA,CAALC,KAAK;QAAEC,MAAM,GAAAF,KAAA,CAANE,MAAM;MAC9B,IAAID,KAAK,EAAE;QACP,IAAIxB,cAAK,CAAC0B,mBAAmB,CAACF,KAAK,CAACG,IAAI,CAAC,KAAKC,WAAE,CAACC,KAAK,CAACC,mBAAmB,EAAE;UACxE,OAAO,IAAI;QACf;QACA,OAAO,KAAK;MAChB;MACA,OAAOL,MAAM;IACjB,CAAC,CAAC;EACN,CAAC,CAAC,CACDJ,IAAI,CAAC,UAACU,GAAG,EAAK;IACX,OAAO,IAAAC,gBAAA,EACHD,GAAG,EACH,UAACA,GAAG,EAAEE,QAAQ,EAAEC,KAAK,EAAK;MACtB,IAAM1B,IAAI,GAAGN,KAAK,CAACgC,KAAK,CAAC;MACzB,IAAMC,IAAI,GAAGnC,cAAK,CAACU,QAAQ,CAACX,SAAS,CAACS,IAAI,CAAC,EAAE,OAAO,CAAC;MACrD,IAAM4B,WAAW,GAAGpC,cAAK,CAACqC,UAAU,CAACJ,QAAQ,CAAC;MAE9CF,GAAG,CAACvB,IAAI,CAAC,OAAA8B,wBAAA,MACJH,IAAI,EAAG;QAACC,WAAW,EAAXA;MAAW,CAAC,CACxB;MAED,OAAOL,GAAG;IACd,CAAC,EACD,CAAC,CACL,CAAC;EACL,CAAC,CAAC;EAEN,OAAOQ,OAAO,CAACC,GAAG,CAAC,CAAC3C,mBAAmB,EAAEC,oBAAoB,EAAEkB,gBAAgB,CAAC,CAAC;AACrF;AAEA,SAASyB,6BAA6BA,CAACC,SAAS,EAAEC,QAAQ,EAAE;EACxD,OAAO,UAACC,QAAQ,EAAK;IACjB,IAAMC,iBAAiB,GAAG7C,cAAK,CAACC,GAAG,CAACyC,SAAS,EAAE,yBAAyB,CAAC;IAEzE,IAAIG,iBAAiB,IAAIA,iBAAiB,KAAK,SAAS,EAAE;MACtDD,QAAQ,CAAC;QAACE,IAAI,EAAEC,2BAAmB,CAACC;MAAO,CAAC,CAAC;MAE7C,OAAO/B,qBAAS,CACXhB,GAAG,CAACkB,mBAAO,CAAC8B,kCAAkC,EAAE;QAC7CpC,IAAI,EAAE,GAAG,GAAGgC,iBAAiB,GAAG;MACpC,CAAC,CAAC,CACDxB,IAAI,CAAC,UAAC6B,SAAS,EAAK;QACjBP,QAAQ,CAAC,CAAC;QACVC,QAAQ,CAAC;UACLE,IAAI,EAAEC,2BAAmB,CAACI,OAAO;UACjC7B,IAAI,EAAE;YAAC4B,SAAS,EAATA;UAAS;QACpB,CAAC,CAAC;MACN,CAAC,CAAC,SACI,CAAC,YAAM;QACTP,QAAQ,CAAC,CAAC;QACVC,QAAQ,CAAC;UAACE,IAAI,EAAEC,2BAAmB,CAACK;QAAO,CAAC,CAAC;MACjD,CAAC,CAAC;IACV,CAAC,MAAM;MACHT,QAAQ,CAAC,CAAC;MACVC,QAAQ,CAAC;QAACE,IAAI,EAAEC,2BAAmB,CAACM;MAAS,CAAC,CAAC;IACnD;EACJ,CAAC;AACL;AAEO,SAASC,YAAYA,CAACC,EAAE,EAAE;EAC7B,OAAO,UAACX,QAAQ,EAAEY,QAAQ,EAAK;IAC3B,IAAMC,OAAO,GAAG,CAAC,IAAAC,mBAAa,EAACH,EAAE,CAAC;IAElC,IAAMI,MAAM,GAAGC,MAAM,CAACC,MAAM,CACxB;MACIC,iBAAiB,EAAE,IAAI;MACvBC,aAAa,EAAEC;IACnB,CAAC,EACDP,OAAO,GAAG;MAACQ,eAAe,EAAEV;IAAE,CAAC,GAAG;MAACW,YAAY,EAAEX;IAAE,CACvD,CAAC;IAEDX,QAAQ,CAAC;MAACE,IAAI,EAAEqB,qBAAa,CAACnB,OAAO;MAAE1B,IAAI,EAAE;QAACmC,OAAO,EAAPA,OAAO;QAAEF,EAAE,EAAFA;MAAE;IAAC,CAAC,CAAC;IAE5D,OAAOa,mBAAO,CACTd,YAAY,CAACK,MAAM,EAAEpE,wBAAwB,CAAC,CAC9C8B,IAAI,CAACgD,6BAAoB,CAAC,CAC1BhD,IAAI,CAAC5B,cAAc,CAAC,CACpB4B,IAAI,CAAC,UAAAiD,KAAA,EAAmE;MAAA,IAAAC,KAAA,OAAA3E,uBAAA,EAAA0E,KAAA;QAAjEzE,mBAAmB,GAAA0E,KAAA;QAAEzE,oBAAoB,GAAAyE,KAAA;QAAEvD,gBAAgB,GAAAuD,KAAA;MAC/D,IAAMC,kBAAkB,GAAG,IAAAC,wBAAiB,EAAC5E,mBAAmB,CAAC;MACjE,IAAM6C,SAAS,GAAG,IAAIgC,oCAAyB,CAC3CF,kBAAkB,EAClB3E,mBAAmB,EACnBmB,gBACJ,CAAC;MAED,IAAM2D,wBAAwB,GAAG,SAA3BA,wBAAwBA,CAAA,EAAS;QACnC/B,QAAQ,CAAC;UACLE,IAAI,EAAEqB,qBAAa,CAAChB,OAAO;UAC3B7B,IAAI,EAAE;YAACoB,SAAS,EAATA,SAAS;YAAE5C,oBAAoB,EAApBA;UAAoB;QAC1C,CAAC,CAAC;MACN,CAAC;MAED,IAAI4C,SAAS,CAACkC,mBAAmB,CAAC,CAAC,EAAE;QACjChC,QAAQ,CAACH,6BAA6B,CAACC,SAAS,EAAEiC,wBAAwB,CAAC,CAAC;MAChF,CAAC,MAAM;QACHA,wBAAwB,CAAC,CAAC;MAC9B;MAEA/B,QAAQ,CAAC,IAAAiC,yCAA4B,EAACtB,EAAE,CAAC,CAAC;IAC9C,CAAC,CAAC,SACI,CAAC,UAAC/B,KAAK,EAAK;MACd,IAAAsD,SAAA,GAAqBtB,QAAQ,CAAC,CAAC;QAAxBuB,UAAU,GAAAD,SAAA,CAAVC,UAAU;MACjB,IAAMC,cAAc,GAAG,CAACD,UAAU,CAACE,MAAM,CAACC,MAAM;MAEhD,IAAI1D,KAAK,CAACG,IAAI,KAAKC,WAAE,CAACC,KAAK,CAACwB,SAAS,EAAE;QACnC,IAAI,CAAC2B,cAAc,EAAE;UACjB3F,OAAO,CAAC8F,GAAG,CAAC;YACRC,IAAI,EAAE,eAAe;YACrBC,UAAU,EAAE,KAAK;YACjBvC,IAAI,EAAE,OAAO;YACbwC,KAAK,EAAE,0BAA0B;YACjCC,OAAO,EAAE/D,KAAK,CAACgE,OAAO;YACtBC,OAAO,EAAE,CACL;cACIC,KAAK,EAAE,OAAO;cACdC,OAAO,EAAE,SAAAA,QAAA;gBAAA,OAAM,IAAAC,sBAAc,EAACpE,KAAK,CAAC;cAAA;YACxC,CAAC;UAET,CAAC,CAAC;QACN;QAEAoB,QAAQ,CAAC;UACLE,IAAI,EAAEqB,qBAAa,CAACf,OAAO;UAC3B9B,IAAI,EAAE;YACFkE,OAAO,4CAAA/E,MAAA,CAA2C8C,EAAE,OAAG;YACvDsC,OAAO,EAAErE;UACb;QACJ,CAAC,CAAC;MACN;IACJ,CAAC,CAAC;EACV,CAAC;AACL"}
|
1
|
+
{"version":3,"names":["_yt","_interopRequireDefault","require","_ypath","_detail","_selectors","_detail2","_utils","_utils2","_list","_index","_uikit","_cancelHelper","_rumWrapApi","_jobsMonitor","obj","__esModule","default","toaster","Toaster","operationDetailsRequests","CancelHelper","getIsEphemeral","_ref","_ref2","_slicedToArray","operationAttributes","userTransactionAlive","treesInfo","ypath","get","trees","_keys","poolPaths","_values","_mapValues","infoPerTree","tree","concat","getValue","requests","_map","path","command","parameters","orchidAttributes","ytApiV3Id","executeBatch","YTApiId","operationIsEphemeral","then","data","_ref3","error","output","getNumberDeprecated","code","yt","codes","NODE_DOES_NOT_EXIST","res","_reduce","poolInfo","index","pool","isEphemeral","getBoolean","_defineProperty","Promise","all","loadIntermediateResourceUsage","operation","callback","dispatch","outputTransaction","type","LOAD_RESOURCE_USAGE","REQUEST","operationIntermediateResourceUsage","resources","SUCCESS","FAILURE","CANCELLED","getOperation","id","getState","isAlias","isOperationId","params","Object","assign","include_scheduler","output_format","TYPED_OUTPUT_FORMAT","operation_alias","operation_id","GET_OPERATION","ytApiV3","checkUserTransaction","_ref4","_ref5","preparedAttributes","prepareAttributes","DetailedOperationSelector","dispatchOperationSuccess","inIntermediateState","getJobsMonitoringDescriptors","_getState","operations","isFirstLoading","detail","loaded","add","name","autoHiding","title","content","message","actions","label","onClick","showErrorPopup","details"],"sources":["detail.js"],"sourcesContent":["import yt from '@ytsaurus/javascript-wrapper/lib/yt';\nimport _ from 'lodash';\nimport ypath from '../../../common/thor/ypath';\n\nimport {GET_OPERATION, LOAD_RESOURCE_USAGE} from '../../../constants/operations/detail';\nimport {DetailedOperationSelector} from '../../../pages/operations/selectors';\nimport {checkUserTransaction} from '../../../utils/operations/detail';\nimport {prepareAttributes} from '../../../utils';\nimport {showErrorPopup} from '../../../utils/utils';\nimport {isOperationId} from '../../../utils/operations/list';\nimport {TYPED_OUTPUT_FORMAT} from '../../../constants/index';\nimport {Toaster} from '@gravity-ui/uikit';\nimport CancelHelper from '../../../utils/cancel-helper';\nimport {YTApiId, ytApiV3, ytApiV3Id} from '../../../rum/rum-wrap-api';\nimport {getJobsMonitoringDescriptors} from '../../../store/actions/operations/jobs-monitor';\n\nconst toaster = new Toaster();\nconst operationDetailsRequests = new CancelHelper();\n\nfunction getIsEphemeral([operationAttributes, userTransactionAlive]) {\n const treesInfo = ypath.get(\n operationAttributes,\n '/runtime_parameters/scheduling_options_per_pool_tree',\n );\n const trees = _.keys(treesInfo);\n const poolPaths = _.values(\n _.mapValues(\n treesInfo,\n (infoPerTree, tree) =>\n `${tree}/fair_share_info/pools/${ypath.getValue(\n infoPerTree,\n '/pool',\n )}/is_ephemeral`,\n ),\n );\n const requests = _.map(poolPaths, (path) => {\n return {\n command: 'get',\n parameters: {\n path: '//sys/scheduler/orchid/scheduler/pool_trees/' + path,\n },\n };\n });\n const orchidAttributes = ytApiV3Id\n .executeBatch(YTApiId.operationIsEphemeral, {requests})\n .then((data) => {\n return _.map(data, ({error, output}) => {\n if (error) {\n if (ypath.getNumberDeprecated(error.code) === yt.codes.NODE_DOES_NOT_EXIST) {\n return true;\n }\n return false;\n }\n return output;\n });\n })\n .then((res) => {\n return _.reduce(\n res,\n (res, poolInfo, index) => {\n const tree = trees[index];\n const pool = ypath.getValue(treesInfo[tree], '/pool');\n const isEphemeral = ypath.getBoolean(poolInfo);\n\n res[tree] = {\n [pool]: {isEphemeral},\n };\n\n return res;\n },\n {},\n );\n });\n\n return Promise.all([operationAttributes, userTransactionAlive, orchidAttributes]);\n}\n\nfunction loadIntermediateResourceUsage(operation, callback) {\n return (dispatch) => {\n const outputTransaction = ypath.get(operation, '/@output_transaction_id');\n\n if (outputTransaction && outputTransaction !== '0-0-0-0') {\n dispatch({type: LOAD_RESOURCE_USAGE.REQUEST});\n\n return ytApiV3Id\n .get(YTApiId.operationIntermediateResourceUsage, {\n path: '#' + outputTransaction + '/@resource_usage',\n })\n .then((resources) => {\n callback();\n dispatch({\n type: LOAD_RESOURCE_USAGE.SUCCESS,\n data: {resources},\n });\n })\n .catch(() => {\n callback();\n dispatch({type: LOAD_RESOURCE_USAGE.FAILURE});\n });\n } else {\n callback();\n dispatch({type: LOAD_RESOURCE_USAGE.CANCELLED});\n }\n };\n}\n\nexport function getOperation(id) {\n return (dispatch, getState) => {\n const isAlias = !isOperationId(id);\n\n const params = Object.assign(\n {\n include_scheduler: true,\n output_format: TYPED_OUTPUT_FORMAT,\n },\n isAlias ? {operation_alias: id} : {operation_id: id},\n );\n\n dispatch({type: GET_OPERATION.REQUEST, data: {isAlias, id}});\n\n return ytApiV3\n .getOperation(params, operationDetailsRequests)\n .then(checkUserTransaction)\n .then(getIsEphemeral)\n .then(([operationAttributes, userTransactionAlive, orchidAttributes]) => {\n const preparedAttributes = prepareAttributes(operationAttributes);\n const operation = new DetailedOperationSelector(\n preparedAttributes,\n operationAttributes,\n orchidAttributes,\n );\n\n const dispatchOperationSuccess = () => {\n dispatch({\n type: GET_OPERATION.SUCCESS,\n data: {operation, userTransactionAlive},\n });\n };\n\n if (operation.inIntermediateState()) {\n dispatch(loadIntermediateResourceUsage(operation, dispatchOperationSuccess));\n } else {\n dispatchOperationSuccess();\n }\n\n dispatch(getJobsMonitoringDescriptors(id));\n })\n .catch((error) => {\n const {operations} = getState();\n const isFirstLoading = !operations.detail.loaded;\n\n if (error.code !== yt.codes.CANCELLED) {\n if (!isFirstLoading) {\n toaster.add({\n name: 'get operation',\n autoHiding: false,\n type: 'error',\n title: 'Failed to load operation',\n content: error.message,\n actions: [\n {\n label: ' view',\n onClick: () => showErrorPopup(error),\n },\n ],\n });\n }\n\n dispatch({\n type: GET_OPERATION.FAILURE,\n data: {\n message: `Error occured when loading operation \"${id}\"`,\n details: error,\n },\n });\n }\n });\n };\n}\n"],"mappings":"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"}
|
@@ -10,7 +10,7 @@ var _scheduling = require("../../../constants/scheduling");
|
|
10
10
|
var _yt = _interopRequireDefault(require("@ytsaurus/javascript-wrapper/lib/yt"));
|
11
11
|
var _scheduling2 = require("../../../utils/scheduling");
|
12
12
|
var _utils = require("../../../utils/utils");
|
13
|
-
var
|
13
|
+
var _schedulingTs = require("./scheduling-ts");
|
14
14
|
var _global = require("../../selectors/global");
|
15
15
|
var _aclApi = require("../../../utils/acl/acl-api");
|
16
16
|
var _acl = require("../../../constants/acl");
|
@@ -61,7 +61,7 @@ function createPool(values) {
|
|
61
61
|
responsible: values.responsible
|
62
62
|
});
|
63
63
|
return waitWhilePoolIsReady(values).then(function () {
|
64
|
-
dispatch((0,
|
64
|
+
dispatch((0, _schedulingTs.loadSchedulingData)());
|
65
65
|
});
|
66
66
|
})["catch"](function (error) {
|
67
67
|
if ((error === null || error === void 0 ? void 0 : error.code) === _yt.default.codes.CANCELLED) {
|
@@ -102,7 +102,7 @@ function waitWhilePoolIsReady(_ref) {
|
|
102
102
|
return new Promise(function (resolve, reject) {
|
103
103
|
setTimeout(function () {
|
104
104
|
_yt.default.v3.exists({
|
105
|
-
path: "//sys/scheduler/orchid/scheduler/
|
105
|
+
path: "//sys/scheduler/orchid/scheduler/pool_trees/".concat(tree, "/fair_share_info/pools/").concat(name)
|
106
106
|
}).then(function (res) {
|
107
107
|
if (res) {
|
108
108
|
return resolve(true);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireDefault","require","_scheduling","_yt","_scheduling2","_utils","_scheduling3","_global","_aclApi","_acl","_Link","_rumWrapApi","_config","_jsxRuntime","obj","__esModule","default","fetchCreatePoolDialogTreeItems","currentTree","dispatch","ytApiV3Id","get","YTApiId","getPoolTrees","path","concat","then","treeItems","type","CREATE_POOL_DIALOG_TREE_ITEMS_SUCCESS","data","createPool","values","getState","abcService","cluster","getCluster","wrapApiPromiseByToaster","yt","v3","create","attributes","Object","assign","name","parent_name","parent","pool_tree","tree","value","abc","prepareAbcService","toasterName","successContent","errorContent","timeout","updateAcl","idmKind","IdmObjectType","POOL","poolTree","responsible","waitWhilePoolIsReady","loadSchedulingData","error","code","codes","CANCELLED","CREATE_POOL_DIALOG_TREE_CREATE_FAILURE","Promise","reject","_createAdminReqTicket","createAdminReqTicketUrl","createUrl","url","queue","CHECK_REDINESS_TIMEOUT","MAX_POOL_REDINESS_TIMEOUT","TIMEOUT_ERROR","message","_jsxs","children","_Fragment","_jsx","Link","_ref","startedAt","arguments","length","undefined","startedTime","Date","now","diff","resolve","setTimeout","exists","res"],"sources":["create-pool-dialog.tsx"],"sourcesContent":["import React from 'react';\nimport {ThunkAction} from 'redux-thunk';\nimport {RootState} from '../../reducers';\nimport {\n CreatePoolDialogAction,\n CreatePoolDialogState,\n} from '../../reducers/scheduling/create-pool-dialog';\nimport {\n CREATE_POOL_DIALOG_TREE_CREATE_FAILURE,\n CREATE_POOL_DIALOG_TREE_ITEMS_SUCCESS,\n} from '../../../constants/scheduling';\n// @ts-ignore\nimport yt from '@ytsaurus/javascript-wrapper/lib/yt';\nimport {prepareAbcService} from '../../../utils/scheduling';\nimport {wrapApiPromiseByToaster} from '../../../utils/utils';\nimport {loadSchedulingData} from './scheduling';\nimport {FIX_MY_TYPE} from '../../../types';\nimport {getCluster} from '../../selectors/global';\nimport {updateAcl} from '../../../utils/acl/acl-api';\nimport {IdmObjectType} from '../../../constants/acl';\nimport Link from '../../../components/Link/Link';\nimport {YTApiId, ytApiV3Id} from '../../../rum/rum-wrap-api';\nimport {createAdminReqTicketUrl} from '../../../config';\n\ntype CreatePoolDialogThunkAction<R = any> = ThunkAction<\n R,\n RootState,\n unknown,\n CreatePoolDialogAction\n>;\n\nexport function fetchCreatePoolDialogTreeItems(currentTree: string): CreatePoolDialogThunkAction {\n return (dispatch) => {\n return ytApiV3Id\n .get(YTApiId.getPoolTrees, {path: `//sys/pool_trees/${currentTree}`})\n .then((treeItems: CreatePoolDialogState['treeItems']) => {\n dispatch({\n type: CREATE_POOL_DIALOG_TREE_ITEMS_SUCCESS,\n data: {currentTree, treeItems},\n });\n });\n };\n}\n\nexport function createPool(values: FIX_MY_TYPE): CreatePoolDialogThunkAction {\n return (dispatch, getState) => {\n const {abcService} = values;\n const cluster = getCluster(getState()) as string;\n\n return wrapApiPromiseByToaster(\n yt.v3.create({\n type: 'scheduler_pool',\n attributes: Object.assign(\n {\n name: values.name,\n parent_name: values.parent,\n pool_tree: values.tree,\n },\n !abcService || !abcService.value\n ? {}\n : {\n abc: prepareAbcService(abcService),\n },\n ),\n }),\n {\n toasterName: `create_${values.name}`,\n successContent: `Successfully created ${values.name}. Please wait.`,\n errorContent: `'${values.name}' pool creation failed`,\n timeout: 10000,\n },\n )\n .then(() => {\n updateAcl(cluster, values.name, {\n idmKind: IdmObjectType.POOL,\n poolTree: values.tree,\n responsible: values.responsible,\n });\n\n return waitWhilePoolIsReady(values).then(() => {\n dispatch(loadSchedulingData());\n });\n })\n .catch((error) => {\n if (error?.code === yt.codes.CANCELLED) {\n return;\n }\n\n dispatch({\n type: CREATE_POOL_DIALOG_TREE_CREATE_FAILURE,\n data: error,\n });\n\n return Promise.reject(error);\n });\n };\n}\n\nconst {url: createUrl, queue} = createAdminReqTicketUrl();\n\nconst CHECK_REDINESS_TIMEOUT = 1500;\nconst MAX_POOL_REDINESS_TIMEOUT = 10 * 1000; // the value is provided by @renadeen\nconst TIMEOUT_ERROR = {\n message: (\n <div>\n The pool was not appeared in orchidea in 10 seconds.\n {createUrl ? (\n <>\n Please fill a ticket for <Link url={createUrl}>{queue}</Link>\n </>\n ) : (\n \"Please report it to the cluster's support team.\"\n )}\n .\n </div>\n ),\n};\n\nfunction waitWhilePoolIsReady({name, tree}: {name: string; tree: string}, startedAt = 0) {\n const startedTime = startedAt || Date.now();\n const diff = Date.now() - startedTime;\n if (diff > MAX_POOL_REDINESS_TIMEOUT) {\n return Promise.resolve();\n }\n\n return new Promise((resolve, reject) => {\n setTimeout(() => {\n yt.v3\n .exists({\n path: `//sys/scheduler/orchid/scheduler/scheduling_info_per_pool_tree/${tree}/fair_share_info/pools/${name}`,\n })\n .then((res: boolean) => {\n if (res) {\n return resolve(true);\n } else {\n return resolve(waitWhilePoolIsReady({name, tree}, startedTime));\n }\n })\n .catch((error: unknown) => {\n if (error !== TIMEOUT_ERROR) {\n return resolve(waitWhilePoolIsReady({name, tree}, startedTime));\n }\n\n return reject(error);\n });\n }, CHECK_REDINESS_TIMEOUT);\n });\n}\n"],"mappings":"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"}
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_scheduling","_yt","_scheduling2","_utils","_schedulingTs","_global","_aclApi","_acl","_Link","_rumWrapApi","_config","_jsxRuntime","obj","__esModule","default","fetchCreatePoolDialogTreeItems","currentTree","dispatch","ytApiV3Id","get","YTApiId","getPoolTrees","path","concat","then","treeItems","type","CREATE_POOL_DIALOG_TREE_ITEMS_SUCCESS","data","createPool","values","getState","abcService","cluster","getCluster","wrapApiPromiseByToaster","yt","v3","create","attributes","Object","assign","name","parent_name","parent","pool_tree","tree","value","abc","prepareAbcService","toasterName","successContent","errorContent","timeout","updateAcl","idmKind","IdmObjectType","POOL","poolTree","responsible","waitWhilePoolIsReady","loadSchedulingData","error","code","codes","CANCELLED","CREATE_POOL_DIALOG_TREE_CREATE_FAILURE","Promise","reject","_createAdminReqTicket","createAdminReqTicketUrl","createUrl","url","queue","CHECK_REDINESS_TIMEOUT","MAX_POOL_REDINESS_TIMEOUT","TIMEOUT_ERROR","message","_jsxs","children","_Fragment","_jsx","Link","_ref","startedAt","arguments","length","undefined","startedTime","Date","now","diff","resolve","setTimeout","exists","res"],"sources":["create-pool-dialog.tsx"],"sourcesContent":["import React from 'react';\nimport {ThunkAction} from 'redux-thunk';\nimport {RootState} from '../../reducers';\nimport {\n CreatePoolDialogAction,\n CreatePoolDialogState,\n} from '../../reducers/scheduling/create-pool-dialog';\nimport {\n CREATE_POOL_DIALOG_TREE_CREATE_FAILURE,\n CREATE_POOL_DIALOG_TREE_ITEMS_SUCCESS,\n} from '../../../constants/scheduling';\n// @ts-ignore\nimport yt from '@ytsaurus/javascript-wrapper/lib/yt';\nimport {prepareAbcService} from '../../../utils/scheduling';\nimport {wrapApiPromiseByToaster} from '../../../utils/utils';\nimport {loadSchedulingData} from './scheduling-ts';\nimport {FIX_MY_TYPE} from '../../../types';\nimport {getCluster} from '../../selectors/global';\nimport {updateAcl} from '../../../utils/acl/acl-api';\nimport {IdmObjectType} from '../../../constants/acl';\nimport Link from '../../../components/Link/Link';\nimport {YTApiId, ytApiV3Id} from '../../../rum/rum-wrap-api';\nimport {createAdminReqTicketUrl} from '../../../config';\n\ntype CreatePoolDialogThunkAction<R = any> = ThunkAction<\n R,\n RootState,\n unknown,\n CreatePoolDialogAction\n>;\n\nexport function fetchCreatePoolDialogTreeItems(currentTree: string): CreatePoolDialogThunkAction {\n return (dispatch) => {\n return ytApiV3Id\n .get(YTApiId.getPoolTrees, {path: `//sys/pool_trees/${currentTree}`})\n .then((treeItems: CreatePoolDialogState['treeItems']) => {\n dispatch({\n type: CREATE_POOL_DIALOG_TREE_ITEMS_SUCCESS,\n data: {currentTree, treeItems},\n });\n });\n };\n}\n\nexport function createPool(values: FIX_MY_TYPE): CreatePoolDialogThunkAction {\n return (dispatch, getState) => {\n const {abcService} = values;\n const cluster = getCluster(getState()) as string;\n\n return wrapApiPromiseByToaster(\n yt.v3.create({\n type: 'scheduler_pool',\n attributes: Object.assign(\n {\n name: values.name,\n parent_name: values.parent,\n pool_tree: values.tree,\n },\n !abcService || !abcService.value\n ? {}\n : {\n abc: prepareAbcService(abcService),\n },\n ),\n }),\n {\n toasterName: `create_${values.name}`,\n successContent: `Successfully created ${values.name}. Please wait.`,\n errorContent: `'${values.name}' pool creation failed`,\n timeout: 10000,\n },\n )\n .then(() => {\n updateAcl(cluster, values.name, {\n idmKind: IdmObjectType.POOL,\n poolTree: values.tree,\n responsible: values.responsible,\n });\n\n return waitWhilePoolIsReady(values).then(() => {\n dispatch(loadSchedulingData());\n });\n })\n .catch((error) => {\n if (error?.code === yt.codes.CANCELLED) {\n return;\n }\n\n dispatch({\n type: CREATE_POOL_DIALOG_TREE_CREATE_FAILURE,\n data: error,\n });\n\n return Promise.reject(error);\n });\n };\n}\n\nconst {url: createUrl, queue} = createAdminReqTicketUrl();\n\nconst CHECK_REDINESS_TIMEOUT = 1500;\nconst MAX_POOL_REDINESS_TIMEOUT = 10 * 1000; // the value is provided by @renadeen\nconst TIMEOUT_ERROR = {\n message: (\n <div>\n The pool was not appeared in orchidea in 10 seconds.\n {createUrl ? (\n <>\n Please fill a ticket for <Link url={createUrl}>{queue}</Link>\n </>\n ) : (\n \"Please report it to the cluster's support team.\"\n )}\n .\n </div>\n ),\n};\n\nfunction waitWhilePoolIsReady({name, tree}: {name: string; tree: string}, startedAt = 0) {\n const startedTime = startedAt || Date.now();\n const diff = Date.now() - startedTime;\n if (diff > MAX_POOL_REDINESS_TIMEOUT) {\n return Promise.resolve();\n }\n\n return new Promise((resolve, reject) => {\n setTimeout(() => {\n yt.v3\n .exists({\n path: `//sys/scheduler/orchid/scheduler/pool_trees/${tree}/fair_share_info/pools/${name}`,\n })\n .then((res: boolean) => {\n if (res) {\n return resolve(true);\n } else {\n return resolve(waitWhilePoolIsReady({name, tree}, startedTime));\n }\n })\n .catch((error: unknown) => {\n if (error !== TIMEOUT_ERROR) {\n return resolve(waitWhilePoolIsReady({name, tree}, startedTime));\n }\n\n return reject(error);\n });\n }, CHECK_REDINESS_TIMEOUT);\n });\n}\n"],"mappings":"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"}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
import { ThunkAction } from 'redux-thunk';
|
2
|
+
import { RootState } from '../../reducers';
|
3
|
+
import { ExpandedPoolsAction } from '../../reducers/scheduling/expanded-pools';
|
4
|
+
import { SchedulingAction } from '../../../store/reducers/scheduling/scheduling';
|
5
|
+
type ExpandedPoolsThunkAction = ThunkAction<any, RootState, any, ExpandedPoolsAction | SchedulingAction>;
|
6
|
+
export declare function loadExpandedPools(tree: string): ExpandedPoolsThunkAction;
|
7
|
+
export declare function setExpandedPool(poolName: string, expanded: boolean): ExpandedPoolsThunkAction;
|
8
|
+
export declare function resetExpandedPools(tree: string): ExpandedPoolsThunkAction;
|
9
|
+
export declare function getSchedulingOperationsCount(): ThunkAction<number, RootState, any, any>;
|
10
|
+
export declare function getPoolPathsByName(poolName: string): ThunkAction<{
|
11
|
+
fullPath: string;
|
12
|
+
orchidPath: string;
|
13
|
+
}, RootState, unknown, any>;
|
14
|
+
export declare function setLoadAllOperations(loadAll: boolean): ExpandedPoolsThunkAction;
|
15
|
+
export {};
|
@@ -0,0 +1,377 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.getPoolPathsByName = getPoolPathsByName;
|
7
|
+
exports.getSchedulingOperationsCount = getSchedulingOperationsCount;
|
8
|
+
exports.loadExpandedPools = loadExpandedPools;
|
9
|
+
exports.resetExpandedPools = resetExpandedPools;
|
10
|
+
exports.setExpandedPool = setExpandedPool;
|
11
|
+
exports.setLoadAllOperations = setLoadAllOperations;
|
12
|
+
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
13
|
+
var _toPropertyKey2 = _interopRequireDefault(require("@babel/runtime/helpers/toPropertyKey"));
|
14
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
15
|
+
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
16
|
+
var _reduce2 = _interopRequireDefault(require("lodash/reduce"));
|
17
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
18
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
19
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
20
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
21
|
+
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
22
|
+
var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper"));
|
23
|
+
var _wrapNativeSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/wrapNativeSuper"));
|
24
|
+
var _uikit = require("@gravity-ui/uikit");
|
25
|
+
var _rumWrapApi = require("../../../rum/rum-wrap-api");
|
26
|
+
var _utils = require("../../../utils/utils");
|
27
|
+
var _batch = require("../../../utils/batch");
|
28
|
+
var _scheduling = require("../../../constants/scheduling");
|
29
|
+
var _scheduling2 = require("../../selectors/scheduling/scheduling");
|
30
|
+
var _expandedPools = require("../../selectors/scheduling/expanded-pools");
|
31
|
+
var _empty = require("../../../constants/empty");
|
32
|
+
var _schedulingPools = require("../../selectors/scheduling/scheduling-pools");
|
33
|
+
var _support = require("../../../store/selectors/thor/support");
|
34
|
+
var _cancelHelper = _interopRequireWildcard(require("../../../utils/cancel-helper"));
|
35
|
+
var _scheduling3 = require("../../../utils/scheduling/scheduling");
|
36
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
37
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
38
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
39
|
+
var cancelHelper = new _cancelHelper.default();
|
40
|
+
var POOL_FIELDS_TO_LOAD = ['accumulated_resource_ratio_volume', 'accumulated_resource_volume', 'demand_ratio', 'detailed_fair_share', 'dominant_resource', 'estimated_burst_usage_duration_sec', 'fair_share_ratio', 'fifo_index', 'integral_guarantee_type', 'is_ephemeral', 'max_operation_count', 'max_running_operation_count', 'max_share_ratio', 'min_share_ratio', 'mode', 'operation_count', 'parent', 'pool_operation_count', 'child_pool_count', 'resource_demand', 'resource_limits', 'resource_usage', 'promised_fair_share_resources', 'running_operation_count', 'specified_burst_guarantee_resources', 'specified_resource_flow', 'starvation_status', 'starving', 'strong_guarantee_resources', 'usage_ratio', 'weight', 'abc'];
|
41
|
+
var POOL_TREE_GET_ATTRS = ['integral_guarantees', 'weight', 'max_operation_count', 'max_running_operation_count', 'strong_guarantee_resources', 'resource_limits', 'forbid_immediate_operations', 'create_ephemeral_subpools', 'fifo_sort_parameters', 'config', 'folder_id'];
|
42
|
+
var EmptyFullPath = /*#__PURE__*/function (_Error) {
|
43
|
+
(0, _inherits2.default)(EmptyFullPath, _Error);
|
44
|
+
var _super = (0, _createSuper2.default)(EmptyFullPath);
|
45
|
+
function EmptyFullPath() {
|
46
|
+
(0, _classCallCheck2.default)(this, EmptyFullPath);
|
47
|
+
return _super.apply(this, arguments);
|
48
|
+
}
|
49
|
+
return (0, _createClass2.default)(EmptyFullPath);
|
50
|
+
}( /*#__PURE__*/(0, _wrapNativeSuper2.default)(Error));
|
51
|
+
function loadExpandedPools(tree) {
|
52
|
+
return function (dispatch, getState) {
|
53
|
+
var pool = (0, _scheduling2.getPool)(getState());
|
54
|
+
if (!tree) {
|
55
|
+
return undefined;
|
56
|
+
}
|
57
|
+
if (pool === _scheduling.ROOT_POOL_NAME) {
|
58
|
+
return dispatch(loadExpandedOperationsAndPools(tree));
|
59
|
+
} else {
|
60
|
+
return _rumWrapApi.ytApiV3Id.executeBatch(_rumWrapApi.YTApiId.schedulingPoolFullPath, {
|
61
|
+
requests: [{
|
62
|
+
command: 'get',
|
63
|
+
parameters: {
|
64
|
+
path: "//sys/scheduler/orchid/scheduler/pool_trees/".concat(tree, "/pools/").concat(pool),
|
65
|
+
fields: ['is_ephemeral', 'full_path']
|
66
|
+
}
|
67
|
+
}]
|
68
|
+
}).then(function (_ref) {
|
69
|
+
var _ref2 = (0, _slicedToArray2.default)(_ref, 1),
|
70
|
+
output = _ref2[0].output;
|
71
|
+
var _ref3 = output !== null && output !== void 0 ? output : {},
|
72
|
+
full_path = _ref3.full_path,
|
73
|
+
is_ephemeral = _ref3.is_ephemeral;
|
74
|
+
if (!full_path) {
|
75
|
+
throw new EmptyFullPath();
|
76
|
+
} else {
|
77
|
+
dispatch(addFullPathToExpandedPoolsNoLoad(tree, full_path, is_ephemeral));
|
78
|
+
dispatch(loadExpandedOperationsAndPools(tree));
|
79
|
+
}
|
80
|
+
})["catch"](function (e) {
|
81
|
+
if (e instanceof EmptyFullPath) {
|
82
|
+
dispatch({
|
83
|
+
type: _scheduling.CHANGE_POOL,
|
84
|
+
data: {
|
85
|
+
pool: _scheduling.ROOT_POOL_NAME
|
86
|
+
}
|
87
|
+
});
|
88
|
+
/**
|
89
|
+
* We don't need to call `dispatch(loadExpandedOperationsAndPools(tree))` after `CHANGE_POOL`.
|
90
|
+
* The call will be triggered by SchedulingExpandedPoolsUpdater.
|
91
|
+
*/
|
92
|
+
// dispatch(loadExpandedOperationsAndPools(tree));
|
93
|
+
} else {
|
94
|
+
new _uikit.Toaster().add({
|
95
|
+
name: 'schedulingPoolFullPath',
|
96
|
+
type: 'error',
|
97
|
+
title: ''
|
98
|
+
});
|
99
|
+
}
|
100
|
+
});
|
101
|
+
}
|
102
|
+
};
|
103
|
+
}
|
104
|
+
function loadExpandedOperationsAndPools(tree) {
|
105
|
+
return function (dispatch, getState) {
|
106
|
+
var _getSchedulingOperati;
|
107
|
+
var state = getState();
|
108
|
+
var loadAll = (0, _expandedPools.getExpandedPoolsLoadAll)(state);
|
109
|
+
var expandedPools = loadAll ? new Map() : (_getSchedulingOperati = (0, _expandedPools.getSchedulingOperationsExpandedPools)(state)[tree]) !== null && _getSchedulingOperati !== void 0 ? _getSchedulingOperati : new Map();
|
110
|
+
var expandedPoolNames = (0, _toConsumableArray2.default)(expandedPools.keys());
|
111
|
+
var operationsExpandedPools = (0, _toConsumableArray2.default)(expandedPoolNames);
|
112
|
+
var operationsRequests = [];
|
113
|
+
if (loadAll) {
|
114
|
+
operationsRequests.push((0, _batch.makeGet)("//sys/scheduler/orchid/scheduler/pool_trees/".concat(tree, "/fair_share_info/operations")));
|
115
|
+
} else {
|
116
|
+
var prefix = "//sys/scheduler/orchid/scheduler/pool_trees/".concat(tree, "/operations_by_pool");
|
117
|
+
operationsExpandedPools.forEach(function (item) {
|
118
|
+
operationsRequests.push((0, _batch.makeGet)("".concat(prefix, "/").concat(item)));
|
119
|
+
});
|
120
|
+
}
|
121
|
+
var loadAllPools = loadAll || !(0, _support.isSupportedSchedulingChildrenByPool)(state);
|
122
|
+
var poolsRequests = [];
|
123
|
+
var poolsChildrenRequests = [];
|
124
|
+
var poolsCypressDataRequests = [];
|
125
|
+
var poolsExpandedPools = -1 !== expandedPoolNames.indexOf(_scheduling.ROOT_POOL_NAME) ? expandedPoolNames : [_scheduling.ROOT_POOL_NAME].concat((0, _toConsumableArray2.default)(expandedPoolNames));
|
126
|
+
if (loadAllPools) {
|
127
|
+
poolsRequests.push((0, _batch.makeGet)("//sys/scheduler/orchid/scheduler/pool_trees/".concat(tree, "/pools"), {
|
128
|
+
fields: POOL_FIELDS_TO_LOAD
|
129
|
+
}));
|
130
|
+
poolsCypressDataRequests.push((0, _batch.makeGet)("//sys/pool_trees/".concat(tree), {
|
131
|
+
attributes: POOL_TREE_GET_ATTRS
|
132
|
+
}));
|
133
|
+
} else {
|
134
|
+
poolsExpandedPools.forEach(function (pool) {
|
135
|
+
var _expandedPools$get;
|
136
|
+
poolsRequests.push((0, _batch.makeGet)("//sys/scheduler/orchid/scheduler/pool_trees/".concat(tree, "/pools/").concat(pool), {
|
137
|
+
fields: POOL_FIELDS_TO_LOAD
|
138
|
+
}));
|
139
|
+
poolsChildrenRequests.push((0, _batch.makeGet)("//sys/scheduler/orchid/scheduler/pool_trees/".concat(tree, "/child_pools_by_pool/").concat(pool), {
|
140
|
+
fields: POOL_FIELDS_TO_LOAD
|
141
|
+
}));
|
142
|
+
var _ref4 = (_expandedPools$get = expandedPools.get(pool)) !== null && _expandedPools$get !== void 0 ? _expandedPools$get : {},
|
143
|
+
parentPoolPath = _ref4.parentPoolPath,
|
144
|
+
isEphemeral = _ref4.isEphemeral;
|
145
|
+
var cypressDataPath = parentPoolPath ? "//sys/pool_trees/".concat(tree, "/").concat(parentPoolPath, "/").concat(pool) : "//sys/pool_trees/".concat(tree, "/").concat(pool);
|
146
|
+
if (pool === _scheduling.ROOT_POOL_NAME || !isEphemeral) {
|
147
|
+
poolsCypressDataRequests.push((0, _batch.makeList)(pool === _scheduling.ROOT_POOL_NAME ? "//sys/pool_trees/".concat(tree) : cypressDataPath, {
|
148
|
+
attributes: POOL_TREE_GET_ATTRS
|
149
|
+
}));
|
150
|
+
}
|
151
|
+
});
|
152
|
+
}
|
153
|
+
cancelHelper.removeAllRequests();
|
154
|
+
dispatch({
|
155
|
+
type: _scheduling.SCHEDULING_EXPANDED_POOLS_REQUEST
|
156
|
+
});
|
157
|
+
return Promise.all([operationsRequests.length ? _rumWrapApi.ytApiV3Id.executeBatch(_rumWrapApi.YTApiId.schedulingLoadOperationsPerPool, {
|
158
|
+
parameters: {
|
159
|
+
requests: operationsRequests
|
160
|
+
},
|
161
|
+
cancellation: cancelHelper.saveCancelToken
|
162
|
+
}) : Promise.resolve([]), loadAllPools ? _rumWrapApi.ytApiV3Id.executeBatch(_rumWrapApi.YTApiId.schedulingLoadPoolsAll, {
|
163
|
+
parameters: {
|
164
|
+
requests: poolsRequests
|
165
|
+
},
|
166
|
+
cancellation: cancelHelper.saveCancelToken
|
167
|
+
}) : _rumWrapApi.ytApiV3Id.executeBatch(_rumWrapApi.YTApiId.schedulingLoadPoolsPerPool, {
|
168
|
+
parameters: {
|
169
|
+
requests: poolsRequests
|
170
|
+
},
|
171
|
+
cancellation: cancelHelper.saveCancelToken
|
172
|
+
}), loadAllPools ? Promise.resolve([]) : _rumWrapApi.ytApiV3Id.executeBatch(_rumWrapApi.YTApiId.schedulingLoadChildrenPerPool, {
|
173
|
+
parameters: {
|
174
|
+
requests: poolsChildrenRequests
|
175
|
+
},
|
176
|
+
cancellation: cancelHelper.saveCancelToken
|
177
|
+
}), !poolsCypressDataRequests.length ? Promise.resolve([]) : _rumWrapApi.ytApiV3Id.executeBatch(_rumWrapApi.YTApiId.schedulingLoadCypressDataPerPool, {
|
178
|
+
parameters: {
|
179
|
+
requests: poolsCypressDataRequests
|
180
|
+
},
|
181
|
+
cancellation: cancelHelper.saveCancelToken
|
182
|
+
})]).then(function (_ref5) {
|
183
|
+
var _error$inner_errors;
|
184
|
+
var _ref6 = (0, _slicedToArray2.default)(_ref5, 4),
|
185
|
+
operationsResults = _ref6[0],
|
186
|
+
poolsResults = _ref6[1],
|
187
|
+
poolsChildrenResults = _ref6[2],
|
188
|
+
poolsCypressData = _ref6[3];
|
189
|
+
var error = {
|
190
|
+
message: 'Failed to load expanded pools'
|
191
|
+
};
|
192
|
+
var _splitBatchResults = (0, _utils.splitBatchResults)(operationsResults, error),
|
193
|
+
operations = _splitBatchResults.results;
|
194
|
+
var rawOperations = (0, _reduce2.default)(operations, function (acc, data) {
|
195
|
+
return Object.assign(acc, data);
|
196
|
+
}, {});
|
197
|
+
var rawPools = {};
|
198
|
+
var cypressData = {};
|
199
|
+
if (loadAllPools) {
|
200
|
+
var _splitBatchResults2 = (0, _utils.splitBatchResults)(poolsResults, error),
|
201
|
+
pools = _splitBatchResults2.results;
|
202
|
+
var _ref7 = pools !== null && pools !== void 0 ? pools : [],
|
203
|
+
_ref8 = (0, _slicedToArray2.default)(_ref7, 1),
|
204
|
+
_ref8$ = _ref8[0],
|
205
|
+
value = _ref8$ === void 0 ? {} : _ref8$;
|
206
|
+
Object.assign(rawPools, value);
|
207
|
+
var _splitBatchResults3 = (0, _utils.splitBatchResults)(poolsCypressData, error),
|
208
|
+
_splitBatchResults3$r = (0, _slicedToArray2.default)(_splitBatchResults3.results, 1),
|
209
|
+
data = _splitBatchResults3$r[0];
|
210
|
+
Object.assign(cypressData, (0, _scheduling3.flattenAttributes)(data));
|
211
|
+
} else {
|
212
|
+
var _splitBatchResults4 = (0, _utils.splitBatchResults)(poolsResults, error),
|
213
|
+
_pools = _splitBatchResults4.results,
|
214
|
+
resultIndices = _splitBatchResults4.resultIndices;
|
215
|
+
_pools.forEach(function (poolInfo, index) {
|
216
|
+
var name = poolsExpandedPools[resultIndices[index]];
|
217
|
+
rawPools[name] = poolInfo;
|
218
|
+
});
|
219
|
+
var _splitBatchResults5 = (0, _utils.splitBatchResults)(poolsChildrenResults, error),
|
220
|
+
poolChildren = _splitBatchResults5.results;
|
221
|
+
poolChildren.forEach(function (children) {
|
222
|
+
Object.assign(rawPools, children);
|
223
|
+
});
|
224
|
+
var _splitBatchResults6 = (0, _utils.splitBatchResults)(poolsCypressData, error),
|
225
|
+
cypressDataChildrenPerPool = _splitBatchResults6.results;
|
226
|
+
cypressDataChildrenPerPool.forEach(function (poolChildrenCypressData) {
|
227
|
+
poolChildrenCypressData.forEach(function (item) {
|
228
|
+
cypressData[item.$value] = item;
|
229
|
+
});
|
230
|
+
});
|
231
|
+
}
|
232
|
+
dispatch({
|
233
|
+
type: _scheduling.SCHEDULING_EXPANDED_POOLS_SUCCESS,
|
234
|
+
data: {
|
235
|
+
expandedPoolsTree: tree,
|
236
|
+
rawOperations: Object.keys(rawOperations).length ? rawOperations : _empty.EMPTY_OBJECT,
|
237
|
+
rawPools: Object.keys(rawPools).length ? rawPools : _empty.EMPTY_OBJECT,
|
238
|
+
flattenCypressData: Object.keys(cypressData).length ? cypressData : _empty.EMPTY_OBJECT
|
239
|
+
}
|
240
|
+
});
|
241
|
+
if ((_error$inner_errors = error.inner_errors) !== null && _error$inner_errors !== void 0 && _error$inner_errors.length) {
|
242
|
+
throw error;
|
243
|
+
}
|
244
|
+
})["catch"](function (error) {
|
245
|
+
if (!(0, _cancelHelper.isCancelled)(error)) {
|
246
|
+
dispatch({
|
247
|
+
type: _scheduling.SCHEDULING_EXPANDED_POOLS_FAILURE,
|
248
|
+
data: {
|
249
|
+
error: error
|
250
|
+
}
|
251
|
+
});
|
252
|
+
}
|
253
|
+
});
|
254
|
+
};
|
255
|
+
}
|
256
|
+
function setExpandedPool(poolName, expanded) {
|
257
|
+
return function (dispatch, getState) {
|
258
|
+
var state = getState();
|
259
|
+
var tree = (0, _scheduling2.getTree)(getState());
|
260
|
+
var expandedPools = (0, _expandedPools.getSchedulingOperationsExpandedPools)(state);
|
261
|
+
var poolsByName = (0, _schedulingPools.getSchedulingPoolsMapByName)(state);
|
262
|
+
var treeExpandedPools = new Map(expandedPools[tree]);
|
263
|
+
if (expanded) {
|
264
|
+
var expandedPoolInfo = calcExpandedPoolInfo(poolName, poolsByName);
|
265
|
+
treeExpandedPools.set(poolName, expandedPoolInfo);
|
266
|
+
} else {
|
267
|
+
treeExpandedPools["delete"](poolName);
|
268
|
+
}
|
269
|
+
dispatch(updateExpandedPoolNoLoad(tree, treeExpandedPools));
|
270
|
+
dispatch(loadExpandedPools(tree));
|
271
|
+
};
|
272
|
+
}
|
273
|
+
function addFullPathToExpandedPoolsNoLoad(tree,
|
274
|
+
/**
|
275
|
+
* elements of the array should have the same format as `//sys/scheduler/orchid/scheduler/pool_trees/${tree}/pools/${pool}/full_path`
|
276
|
+
*/
|
277
|
+
fullPath, isEphemeral) {
|
278
|
+
return function (dispatch, getState) {
|
279
|
+
var state = getState();
|
280
|
+
var oldExpandedPools = (0, _expandedPools.getSchedulingOperationsExpandedPools)(state);
|
281
|
+
var treeExpandedPools = new Map(oldExpandedPools[tree]);
|
282
|
+
|
283
|
+
/**
|
284
|
+
* `fullPath` value starts from `/`, example: `/mypool/child/subchild`
|
285
|
+
* so we have to use `.slice(1)` to remove first empty string
|
286
|
+
*/
|
287
|
+
var parts = fullPath.split('/').slice(1);
|
288
|
+
for (var i = 0; i < parts.length; ++i) {
|
289
|
+
var poolName = parts[i];
|
290
|
+
var parentPoolPath = parts.slice(0, i).join('/');
|
291
|
+
treeExpandedPools.set(poolName, {
|
292
|
+
parentPoolPath: parentPoolPath,
|
293
|
+
isEphemeral: isEphemeral
|
294
|
+
});
|
295
|
+
}
|
296
|
+
dispatch(updateExpandedPoolNoLoad(tree, treeExpandedPools));
|
297
|
+
};
|
298
|
+
}
|
299
|
+
function updateExpandedPoolNoLoad(tree, treeExpandedPools) {
|
300
|
+
return function (dispatch, getState) {
|
301
|
+
var oldExpandedPools = (0, _expandedPools.getSchedulingOperationsExpandedPools)(getState());
|
302
|
+
var expandedPools = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, oldExpandedPools), {}, (0, _defineProperty2.default)({}, tree, treeExpandedPools));
|
303
|
+
dispatch({
|
304
|
+
type: _scheduling.SCHEDULING_EXPANDED_POOLS_PARTITION,
|
305
|
+
data: {
|
306
|
+
expandedPools: expandedPools
|
307
|
+
}
|
308
|
+
});
|
309
|
+
};
|
310
|
+
}
|
311
|
+
function resetExpandedPools(tree) {
|
312
|
+
return function (dispatch, getState) {
|
313
|
+
if (!tree) {
|
314
|
+
return;
|
315
|
+
}
|
316
|
+
var state = getState();
|
317
|
+
var _getSchedulingOperati2 = (0, _expandedPools.getSchedulingOperationsExpandedPools)(state),
|
318
|
+
old = _getSchedulingOperati2[tree],
|
319
|
+
rest = (0, _objectWithoutProperties2.default)(_getSchedulingOperati2, [tree].map(_toPropertyKey2.default));
|
320
|
+
if (old !== null && old !== void 0 && old.size) {
|
321
|
+
dispatch({
|
322
|
+
type: _scheduling.SCHEDULING_EXPANDED_POOLS_PARTITION,
|
323
|
+
data: {
|
324
|
+
expandedPools: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, rest), {}, (0, _defineProperty2.default)({}, tree, new Map()))
|
325
|
+
}
|
326
|
+
});
|
327
|
+
}
|
328
|
+
};
|
329
|
+
}
|
330
|
+
function getSchedulingOperationsCount() {
|
331
|
+
return function (_dispatch, getState) {
|
332
|
+
var state = getState();
|
333
|
+
var tree = (0, _schedulingPools.getSchedulingPoolsMapByName)(state);
|
334
|
+
var root = tree[_scheduling.ROOT_POOL_NAME];
|
335
|
+
return (root === null || root === void 0 ? void 0 : root.operationCount) || 0;
|
336
|
+
};
|
337
|
+
}
|
338
|
+
function getPoolPathsByName(poolName) {
|
339
|
+
return function (_dispatch, getState) {
|
340
|
+
var state = getState();
|
341
|
+
var pools = (0, _scheduling2.getPools)(state);
|
342
|
+
var tree = (0, _scheduling2.getTree)(state);
|
343
|
+
return {
|
344
|
+
fullPath: (0, _scheduling2.calculatePoolPath)(poolName, pools, tree),
|
345
|
+
orchidPath: "//sys/scheduler/orchid/scheduler/pool_trees/".concat(tree, "/fair_share_info/pools/").concat(poolName)
|
346
|
+
};
|
347
|
+
};
|
348
|
+
}
|
349
|
+
function setLoadAllOperations(loadAll) {
|
350
|
+
return function (dispatch, getState) {
|
351
|
+
var state = getState();
|
352
|
+
dispatch({
|
353
|
+
type: _scheduling.SCHEDULING_EXPANDED_POOLS_PARTITION,
|
354
|
+
data: {
|
355
|
+
loadAll: loadAll
|
356
|
+
}
|
357
|
+
});
|
358
|
+
var tree = (0, _scheduling2.getTree)(state);
|
359
|
+
dispatch(loadExpandedPools(tree));
|
360
|
+
};
|
361
|
+
}
|
362
|
+
function calcExpandedPoolInfo(poolName, poolsByName) {
|
363
|
+
var _data;
|
364
|
+
var data = poolsByName[poolName];
|
365
|
+
var isEphemeral = (_data = data) === null || _data === void 0 ? void 0 : _data.isEphemeral;
|
366
|
+
var res = '';
|
367
|
+
while ((_data2 = data) !== null && _data2 !== void 0 && _data2.parent && data.parent !== _scheduling.ROOT_POOL_NAME) {
|
368
|
+
var _data2;
|
369
|
+
res = res ? "".concat(data.parent, "/").concat(res) : data.parent;
|
370
|
+
data = poolsByName[data.parent];
|
371
|
+
}
|
372
|
+
return {
|
373
|
+
parentPoolPath: res,
|
374
|
+
isEphemeral: isEphemeral
|
375
|
+
};
|
376
|
+
}
|
377
|
+
// #sourceMappingURL=expanded-pools.js.map
|