@platforma-sdk/model 1.58.3 → 1.58.9
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/dist/_virtual/_rolldown/runtime.cjs +43 -0
- package/dist/_virtual/_rolldown/runtime.js +18 -0
- package/dist/annotations/converter.cjs +15 -20
- package/dist/annotations/converter.cjs.map +1 -1
- package/dist/annotations/converter.d.ts +6 -2
- package/dist/annotations/converter.js +14 -18
- package/dist/annotations/converter.js.map +1 -1
- package/dist/annotations/index.cjs +1 -0
- package/dist/annotations/index.d.ts +2 -3
- package/dist/annotations/index.js +1 -0
- package/dist/annotations/types.d.ts +21 -16
- package/dist/bconfig/index.cjs +2 -0
- package/dist/bconfig/index.d.ts +5 -6
- package/dist/bconfig/index.js +2 -0
- package/dist/bconfig/lambdas.d.ts +52 -52
- package/dist/bconfig/normalization.cjs +13 -18
- package/dist/bconfig/normalization.cjs.map +1 -1
- package/dist/bconfig/normalization.d.ts +10 -6
- package/dist/bconfig/normalization.js +12 -16
- package/dist/bconfig/normalization.js.map +1 -1
- package/dist/bconfig/types.cjs +4 -3
- package/dist/bconfig/types.cjs.map +1 -1
- package/dist/bconfig/types.d.ts +10 -5
- package/dist/bconfig/types.js +4 -2
- package/dist/bconfig/types.js.map +1 -1
- package/dist/bconfig/util.d.ts +7 -4
- package/dist/bconfig/v3.d.ts +10 -6
- package/dist/block_api_v1.d.ts +62 -58
- package/dist/block_api_v2.d.ts +51 -47
- package/dist/block_api_v3.d.ts +33 -29
- package/dist/block_migrations.cjs +481 -413
- package/dist/block_migrations.cjs.map +1 -1
- package/dist/block_migrations.d.ts +258 -204
- package/dist/block_migrations.js +482 -408
- package/dist/block_migrations.js.map +1 -1
- package/dist/block_model.cjs +312 -343
- package/dist/block_model.cjs.map +1 -1
- package/dist/block_model.d.ts +143 -147
- package/dist/block_model.js +312 -341
- package/dist/block_model.js.map +1 -1
- package/dist/block_model_legacy.cjs +231 -255
- package/dist/block_model_legacy.cjs.map +1 -1
- package/dist/block_model_legacy.d.ts +108 -106
- package/dist/block_model_legacy.js +231 -253
- package/dist/block_model_legacy.js.map +1 -1
- package/dist/block_state_patch.d.ts +10 -10
- package/dist/block_state_util.cjs +15 -19
- package/dist/block_state_util.cjs.map +1 -1
- package/dist/block_state_util.d.ts +14 -13
- package/dist/block_state_util.js +15 -18
- package/dist/block_state_util.js.map +1 -1
- package/dist/block_storage.cjs +233 -238
- package/dist/block_storage.cjs.map +1 -1
- package/dist/block_storage.d.ts +62 -78
- package/dist/block_storage.js +234 -237
- package/dist/block_storage.js.map +1 -1
- package/dist/block_storage_callbacks.cjs +156 -195
- package/dist/block_storage_callbacks.cjs.map +1 -1
- package/dist/block_storage_callbacks.js +156 -192
- package/dist/block_storage_callbacks.js.map +1 -1
- package/dist/block_storage_facade.cjs +29 -85
- package/dist/block_storage_facade.cjs.map +1 -1
- package/dist/block_storage_facade.d.ts +83 -126
- package/dist/block_storage_facade.js +29 -83
- package/dist/block_storage_facade.js.map +1 -1
- package/dist/components/PFrameForGraphs.cjs +26 -24
- package/dist/components/PFrameForGraphs.cjs.map +1 -1
- package/dist/components/PFrameForGraphs.d.ts +12 -7
- package/dist/components/PFrameForGraphs.js +25 -22
- package/dist/components/PFrameForGraphs.js.map +1 -1
- package/dist/components/PlAnnotations/filter.d.ts +62 -79
- package/dist/components/PlAnnotations/filters_ui.cjs +135 -171
- package/dist/components/PlAnnotations/filters_ui.cjs.map +1 -1
- package/dist/components/PlAnnotations/filters_ui.d.ts +48 -46
- package/dist/components/PlAnnotations/filters_ui.js +135 -170
- package/dist/components/PlAnnotations/filters_ui.js.map +1 -1
- package/dist/components/PlAnnotations/index.d.ts +2 -3
- package/dist/components/PlDataTable/index.cjs +2 -0
- package/dist/components/PlDataTable/index.d.ts +3 -5
- package/dist/components/PlDataTable/index.js +2 -0
- package/dist/components/PlDataTable/labels.cjs +59 -81
- package/dist/components/PlDataTable/labels.cjs.map +1 -1
- package/dist/components/PlDataTable/labels.js +58 -79
- package/dist/components/PlDataTable/labels.js.map +1 -1
- package/dist/components/PlDataTable/state-migration.cjs +186 -144
- package/dist/components/PlDataTable/state-migration.cjs.map +1 -1
- package/dist/components/PlDataTable/state-migration.d.ts +85 -82
- package/dist/components/PlDataTable/state-migration.js +185 -142
- package/dist/components/PlDataTable/state-migration.js.map +1 -1
- package/dist/components/PlDataTable/table.cjs +172 -194
- package/dist/components/PlDataTable/table.cjs.map +1 -1
- package/dist/components/PlDataTable/table.d.ts +16 -12
- package/dist/components/PlDataTable/table.js +171 -192
- package/dist/components/PlDataTable/table.js.map +1 -1
- package/dist/components/PlDataTable/v4.d.ts +84 -119
- package/dist/components/PlDataTable/v5.d.ts +80 -103
- package/dist/components/PlMultiSequenceAlignment.cjs +27 -29
- package/dist/components/PlMultiSequenceAlignment.cjs.map +1 -1
- package/dist/components/PlMultiSequenceAlignment.d.ts +36 -27
- package/dist/components/PlMultiSequenceAlignment.js +26 -27
- package/dist/components/PlMultiSequenceAlignment.js.map +1 -1
- package/dist/components/PlSelectionModel.cjs +7 -6
- package/dist/components/PlSelectionModel.cjs.map +1 -1
- package/dist/components/PlSelectionModel.d.ts +10 -8
- package/dist/components/PlSelectionModel.js +7 -5
- package/dist/components/PlSelectionModel.js.map +1 -1
- package/dist/components/index.cjs +8 -0
- package/dist/components/index.d.ts +11 -6
- package/dist/components/index.js +8 -0
- package/dist/config/actions.cjs +138 -171
- package/dist/config/actions.cjs.map +1 -1
- package/dist/config/actions.d.ts +47 -47
- package/dist/config/actions.js +146 -178
- package/dist/config/actions.js.map +1 -1
- package/dist/config/actions_kinds.d.ts +114 -121
- package/dist/config/index.cjs +1 -0
- package/dist/config/index.d.ts +6 -7
- package/dist/config/index.js +1 -0
- package/dist/config/model.d.ts +131 -127
- package/dist/config/model_meta.d.ts +4 -1
- package/dist/config/type_engine.d.ts +22 -21
- package/dist/config/type_util.d.ts +12 -10
- package/dist/env_value.cjs +5 -6
- package/dist/env_value.cjs.map +1 -1
- package/dist/env_value.d.ts +4 -1
- package/dist/env_value.js +5 -5
- package/dist/env_value.js.map +1 -1
- package/dist/filters/converters/filterToQuery.cjs +273 -239
- package/dist/filters/converters/filterToQuery.cjs.map +1 -1
- package/dist/filters/converters/filterToQuery.d.ts +6 -2
- package/dist/filters/converters/filterToQuery.js +272 -237
- package/dist/filters/converters/filterToQuery.js.map +1 -1
- package/dist/filters/converters/filterUiToExpressionImpl.cjs +56 -85
- package/dist/filters/converters/filterUiToExpressionImpl.cjs.map +1 -1
- package/dist/filters/converters/filterUiToExpressionImpl.d.ts +8 -4
- package/dist/filters/converters/filterUiToExpressionImpl.js +55 -83
- package/dist/filters/converters/filterUiToExpressionImpl.js.map +1 -1
- package/dist/filters/converters/index.cjs +2 -0
- package/dist/filters/converters/index.d.ts +2 -3
- package/dist/filters/converters/index.js +2 -0
- package/dist/filters/distill.cjs +59 -50
- package/dist/filters/distill.cjs.map +1 -1
- package/dist/filters/distill.d.ts +6 -3
- package/dist/filters/distill.js +58 -48
- package/dist/filters/distill.js.map +1 -1
- package/dist/filters/index.cjs +4 -0
- package/dist/filters/index.d.ts +5 -4
- package/dist/filters/index.js +4 -0
- package/dist/filters/traverse.cjs +31 -40
- package/dist/filters/traverse.cjs.map +1 -1
- package/dist/filters/traverse.js +31 -39
- package/dist/filters/traverse.js.map +1 -1
- package/dist/filters/types.d.ts +10 -7
- package/dist/index.cjs +193 -187
- package/dist/index.d.ts +61 -28
- package/dist/index.js +49 -41
- package/dist/internal.cjs +48 -62
- package/dist/internal.cjs.map +1 -1
- package/dist/internal.js +49 -60
- package/dist/internal.js.map +1 -1
- package/dist/package.cjs +12 -0
- package/dist/package.cjs.map +1 -0
- package/dist/package.js +6 -0
- package/dist/package.js.map +1 -0
- package/dist/pframe.cjs +32 -37
- package/dist/pframe.cjs.map +1 -1
- package/dist/pframe.d.ts +14 -10
- package/dist/pframe.js +32 -35
- package/dist/pframe.js.map +1 -1
- package/dist/pframe_utils/axes.cjs +81 -114
- package/dist/pframe_utils/axes.cjs.map +1 -1
- package/dist/pframe_utils/axes.d.ts +10 -13
- package/dist/pframe_utils/axes.js +80 -112
- package/dist/pframe_utils/axes.js.map +1 -1
- package/dist/pframe_utils/columns.cjs +61 -81
- package/dist/pframe_utils/columns.cjs.map +1 -1
- package/dist/pframe_utils/columns.d.ts +15 -6
- package/dist/pframe_utils/columns.js +60 -79
- package/dist/pframe_utils/columns.js.map +1 -1
- package/dist/pframe_utils/index.cjs +232 -253
- package/dist/pframe_utils/index.cjs.map +1 -1
- package/dist/pframe_utils/index.d.ts +39 -35
- package/dist/pframe_utils/index.js +231 -251
- package/dist/pframe_utils/index.js.map +1 -1
- package/dist/platforma.d.ts +48 -46
- package/dist/plugin_handle.cjs +6 -14
- package/dist/plugin_handle.cjs.map +1 -1
- package/dist/plugin_handle.d.ts +20 -25
- package/dist/plugin_handle.js +6 -13
- package/dist/plugin_handle.js.map +1 -1
- package/dist/plugin_model.cjs +364 -163
- package/dist/plugin_model.cjs.map +1 -1
- package/dist/plugin_model.d.ts +280 -129
- package/dist/plugin_model.js +362 -163
- package/dist/plugin_model.js.map +1 -1
- package/dist/raw_globals.cjs +10 -22
- package/dist/raw_globals.cjs.map +1 -1
- package/dist/raw_globals.d.ts +8 -5
- package/dist/raw_globals.js +10 -20
- package/dist/raw_globals.js.map +1 -1
- package/dist/ref_util.cjs +14 -13
- package/dist/ref_util.cjs.map +1 -1
- package/dist/ref_util.d.ts +18 -12
- package/dist/ref_util.js +14 -11
- package/dist/ref_util.js.map +1 -1
- package/dist/render/accessor.cjs +213 -226
- package/dist/render/accessor.cjs.map +1 -1
- package/dist/render/accessor.d.ts +115 -120
- package/dist/render/accessor.js +212 -224
- package/dist/render/accessor.js.map +1 -1
- package/dist/render/api.cjs +478 -580
- package/dist/render/api.cjs.map +1 -1
- package/dist/render/api.d.ts +207 -209
- package/dist/render/api.js +476 -578
- package/dist/render/api.js.map +1 -1
- package/dist/render/future.cjs +28 -32
- package/dist/render/future.cjs.map +1 -1
- package/dist/render/future.d.ts +15 -11
- package/dist/render/future.js +28 -30
- package/dist/render/future.js.map +1 -1
- package/dist/render/index.cjs +8 -0
- package/dist/render/index.d.ts +10 -8
- package/dist/render/index.js +8 -0
- package/dist/render/internal.cjs +33 -29
- package/dist/render/internal.cjs.map +1 -1
- package/dist/render/internal.d.ts +78 -72
- package/dist/render/internal.js +29 -26
- package/dist/render/internal.js.map +1 -1
- package/dist/render/traversal_ops.d.ts +42 -43
- package/dist/render/util/axis_filtering.cjs +63 -86
- package/dist/render/util/axis_filtering.cjs.map +1 -1
- package/dist/render/util/axis_filtering.d.ts +10 -7
- package/dist/render/util/axis_filtering.js +63 -85
- package/dist/render/util/axis_filtering.js.map +1 -1
- package/dist/render/util/column_collection.cjs +266 -321
- package/dist/render/util/column_collection.cjs.map +1 -1
- package/dist/render/util/column_collection.d.ts +47 -47
- package/dist/render/util/column_collection.js +264 -319
- package/dist/render/util/column_collection.js.map +1 -1
- package/dist/render/util/index.cjs +4 -0
- package/dist/render/util/index.d.ts +4 -5
- package/dist/render/util/index.js +4 -0
- package/dist/render/util/label.cjs +129 -163
- package/dist/render/util/label.cjs.map +1 -1
- package/dist/render/util/label.d.ts +45 -46
- package/dist/render/util/label.js +128 -161
- package/dist/render/util/label.js.map +1 -1
- package/dist/render/util/pcolumn_data.cjs +315 -375
- package/dist/render/util/pcolumn_data.cjs.map +1 -1
- package/dist/render/util/pcolumn_data.d.ts +33 -32
- package/dist/render/util/pcolumn_data.js +314 -373
- package/dist/render/util/pcolumn_data.js.map +1 -1
- package/dist/render/util/pframe_upgraders.cjs +37 -42
- package/dist/render/util/pframe_upgraders.cjs.map +1 -1
- package/dist/render/util/pframe_upgraders.js +37 -41
- package/dist/render/util/pframe_upgraders.js.map +1 -1
- package/dist/render/util/split_selectors.d.ts +13 -9
- package/dist/version.cjs +6 -8
- package/dist/version.cjs.map +1 -1
- package/dist/version.d.ts +7 -4
- package/dist/version.js +5 -5
- package/dist/version.js.map +1 -1
- package/package.json +9 -3
- package/src/block_migrations.test.ts +184 -14
- package/src/block_migrations.ts +185 -30
- package/src/block_model.ts +111 -66
- package/src/block_storage.test.ts +147 -3
- package/src/block_storage.ts +43 -8
- package/src/block_storage_callbacks.ts +9 -4
- package/src/env_value.ts +0 -2
- package/src/filters/distill.ts +17 -6
- package/src/index.ts +12 -11
- package/src/internal.ts +0 -1
- package/src/platforma.ts +4 -4
- package/src/plugin_handle.ts +1 -1
- package/src/plugin_model.test.ts +217 -21
- package/src/plugin_model.ts +450 -55
- package/src/raw_globals.ts +0 -1
- package/dist/annotations/converter.d.ts.map +0 -1
- package/dist/annotations/index.d.ts.map +0 -1
- package/dist/annotations/types.d.ts.map +0 -1
- package/dist/bconfig/index.d.ts.map +0 -1
- package/dist/bconfig/lambdas.d.ts.map +0 -1
- package/dist/bconfig/normalization.d.ts.map +0 -1
- package/dist/bconfig/types.d.ts.map +0 -1
- package/dist/bconfig/util.d.ts.map +0 -1
- package/dist/bconfig/v3.d.ts.map +0 -1
- package/dist/block_api_v1.d.ts.map +0 -1
- package/dist/block_api_v2.d.ts.map +0 -1
- package/dist/block_api_v3.d.ts.map +0 -1
- package/dist/block_migrations.d.ts.map +0 -1
- package/dist/block_model.d.ts.map +0 -1
- package/dist/block_model_legacy.d.ts.map +0 -1
- package/dist/block_state_patch.d.ts.map +0 -1
- package/dist/block_state_util.d.ts.map +0 -1
- package/dist/block_storage.d.ts.map +0 -1
- package/dist/block_storage_callbacks.d.ts +0 -115
- package/dist/block_storage_callbacks.d.ts.map +0 -1
- package/dist/block_storage_facade.d.ts.map +0 -1
- package/dist/components/PFrameForGraphs.d.ts.map +0 -1
- package/dist/components/PlAnnotations/filter.d.ts.map +0 -1
- package/dist/components/PlAnnotations/filters_ui.d.ts.map +0 -1
- package/dist/components/PlAnnotations/index.d.ts.map +0 -1
- package/dist/components/PlAnnotations/types.d.ts +0 -3
- package/dist/components/PlAnnotations/types.d.ts.map +0 -1
- package/dist/components/PlDataTable/index.d.ts.map +0 -1
- package/dist/components/PlDataTable/labels.d.ts +0 -7
- package/dist/components/PlDataTable/labels.d.ts.map +0 -1
- package/dist/components/PlDataTable/state-migration.d.ts.map +0 -1
- package/dist/components/PlDataTable/table.d.ts.map +0 -1
- package/dist/components/PlDataTable/v4.d.ts.map +0 -1
- package/dist/components/PlDataTable/v5.d.ts.map +0 -1
- package/dist/components/PlMultiSequenceAlignment.d.ts.map +0 -1
- package/dist/components/PlSelectionModel.d.ts.map +0 -1
- package/dist/components/index.d.ts.map +0 -1
- package/dist/config/actions.d.ts.map +0 -1
- package/dist/config/actions_kinds.d.ts.map +0 -1
- package/dist/config/index.d.ts.map +0 -1
- package/dist/config/model.d.ts.map +0 -1
- package/dist/config/model_meta.d.ts.map +0 -1
- package/dist/config/type_engine.d.ts.map +0 -1
- package/dist/config/type_util.d.ts.map +0 -1
- package/dist/env_value.d.ts.map +0 -1
- package/dist/filters/converters/filterToQuery.d.ts.map +0 -1
- package/dist/filters/converters/filterUiToExpressionImpl.d.ts.map +0 -1
- package/dist/filters/converters/index.d.ts.map +0 -1
- package/dist/filters/distill.d.ts.map +0 -1
- package/dist/filters/index.d.ts.map +0 -1
- package/dist/filters/traverse.d.ts +0 -27
- package/dist/filters/traverse.d.ts.map +0 -1
- package/dist/filters/types.d.ts.map +0 -1
- package/dist/index.cjs.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/internal.d.ts +0 -36
- package/dist/internal.d.ts.map +0 -1
- package/dist/package.json.cjs +0 -6
- package/dist/package.json.cjs.map +0 -1
- package/dist/package.json.js +0 -4
- package/dist/package.json.js.map +0 -1
- package/dist/pframe.d.ts.map +0 -1
- package/dist/pframe_utils/axes.d.ts.map +0 -1
- package/dist/pframe_utils/columns.d.ts.map +0 -1
- package/dist/pframe_utils/index.d.ts.map +0 -1
- package/dist/pframe_utils/querySpec.d.ts +0 -2
- package/dist/pframe_utils/querySpec.d.ts.map +0 -1
- package/dist/platforma.d.ts.map +0 -1
- package/dist/plugin_handle.d.ts.map +0 -1
- package/dist/plugin_model.d.ts.map +0 -1
- package/dist/raw_globals.d.ts.map +0 -1
- package/dist/ref_util.d.ts.map +0 -1
- package/dist/render/accessor.d.ts.map +0 -1
- package/dist/render/api.d.ts.map +0 -1
- package/dist/render/future.d.ts.map +0 -1
- package/dist/render/index.d.ts.map +0 -1
- package/dist/render/internal.d.ts.map +0 -1
- package/dist/render/traversal_ops.d.ts.map +0 -1
- package/dist/render/util/axis_filtering.d.ts.map +0 -1
- package/dist/render/util/column_collection.d.ts.map +0 -1
- package/dist/render/util/index.d.ts.map +0 -1
- package/dist/render/util/label.d.ts.map +0 -1
- package/dist/render/util/pcolumn_data.d.ts.map +0 -1
- package/dist/render/util/pframe_upgraders.d.ts +0 -3
- package/dist/render/util/pframe_upgraders.d.ts.map +0 -1
- package/dist/render/util/split_selectors.d.ts.map +0 -1
- package/dist/version.d.ts.map +0 -1
|
@@ -1,48 +1,52 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
1
|
+
import { getAllRelatedColumns, getRelatedColumns } from "./columns.js";
|
|
2
|
+
import { AxisId, CanonicalizedJson, FindColumnsRequest, PColumnIdAndSpec, PColumnSpec, PFrameHandle, PObjectId, PTableRecordSingleValueFilterV2, ValueType } from "@milaboratories/pl-model-common";
|
|
3
|
+
|
|
4
|
+
//#region src/pframe_utils/index.d.ts
|
|
3
5
|
type PValue = string | number | null;
|
|
4
6
|
type SuggestionResponse = {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
7
|
+
values: {
|
|
8
|
+
value: string;
|
|
9
|
+
label: string;
|
|
10
|
+
}[];
|
|
11
|
+
overflow: boolean;
|
|
10
12
|
};
|
|
11
13
|
type SingleColumnData = {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
+
axesData: Record<string, PValue[]>;
|
|
15
|
+
data: PValue[];
|
|
14
16
|
};
|
|
15
|
-
type UniqueValuesResponse = {
|
|
16
|
-
|
|
17
|
-
|
|
17
|
+
type UniqueValuesResponse$1 = {
|
|
18
|
+
values: string[];
|
|
19
|
+
overflow: boolean;
|
|
18
20
|
};
|
|
19
21
|
type GetUniqueSourceValuesParams = {
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
22
|
+
columnId: PObjectId;
|
|
23
|
+
axisIdx?: number;
|
|
24
|
+
limit?: number;
|
|
25
|
+
searchQuery?: string;
|
|
26
|
+
searchQueryValue?: string;
|
|
25
27
|
};
|
|
26
28
|
type GetAxisUniqueValuesParams = {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
29
|
+
axisId: AxisId;
|
|
30
|
+
parentColumnIds: PObjectId[];
|
|
31
|
+
limit?: number;
|
|
32
|
+
filters?: PTableRecordSingleValueFilterV2[];
|
|
31
33
|
};
|
|
32
34
|
type GetColumnsFullParams = {
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
35
|
+
selectedSources: PObjectId[];
|
|
36
|
+
strictlyCompatible: boolean;
|
|
37
|
+
types?: ValueType[];
|
|
38
|
+
names?: string[];
|
|
39
|
+
annotations?: FindColumnsRequest["columnFilter"]["annotationValue"];
|
|
40
|
+
annotationsNotEmpty?: string[];
|
|
39
41
|
};
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
42
|
+
declare function getColumnSpecById(handle: PFrameHandle, id: PObjectId): Promise<PColumnSpec | null>;
|
|
43
|
+
declare function getSingleColumnData(handle: PFrameHandle, id: PObjectId, filters?: PTableRecordSingleValueFilterV2[]): Promise<SingleColumnData>;
|
|
44
|
+
declare function getColumnUniqueValues(handle: PFrameHandle, id: PObjectId, limit?: number, filters?: PTableRecordSingleValueFilterV2[]): Promise<UniqueValuesResponse$1>;
|
|
45
|
+
declare function getAxisUniqueValues(handle: PFrameHandle, params: GetAxisUniqueValuesParams): Promise<UniqueValuesResponse$1>;
|
|
46
|
+
declare function getRequestColumnsFromSelectedSources(handle: PFrameHandle, sources: PObjectId[]): Promise<AxisId[]>;
|
|
47
|
+
declare function getColumnsFull(handle: PFrameHandle, params: GetColumnsFullParams): Promise<PColumnIdAndSpec[]>;
|
|
48
|
+
declare function getColumnOrAxisValueLabelsId(handle: PFrameHandle, strAxisId: CanonicalizedJson<AxisId>): Promise<PObjectId | undefined>;
|
|
49
|
+
declare function getUniqueSourceValuesWithLabels(handle: PFrameHandle, params: GetUniqueSourceValuesParams): Promise<SuggestionResponse>;
|
|
50
|
+
//#endregion
|
|
51
|
+
export { getAxisUniqueValues, getColumnOrAxisValueLabelsId, getColumnSpecById, getColumnUniqueValues, getColumnsFull, getRequestColumnsFromSelectedSources, getSingleColumnData, getUniqueSourceValuesWithLabels };
|
|
48
52
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1,287 +1,267 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import
|
|
4
|
-
import '../render/util/label.js';
|
|
1
|
+
import { getAllRelatedColumns, getRelatedColumns } from "./columns.js";
|
|
2
|
+
import { Annotation, PColumnName, canonicalizeAxisId, getAxisId, pTableValue, readAnnotation } from "@milaboratories/pl-model-common";
|
|
3
|
+
import { flatten, uniq } from "es-toolkit";
|
|
5
4
|
|
|
6
|
-
|
|
7
|
-
const UNIQUE_VALUES_LIMIT =
|
|
8
|
-
// Helper functions
|
|
5
|
+
//#region src/pframe_utils/index.ts
|
|
6
|
+
const UNIQUE_VALUES_LIMIT = 1e6;
|
|
9
7
|
const sortValuesPredicate = (a, b) => a.label.localeCompare(b.label, "en", { numeric: true });
|
|
10
8
|
function convertColumnData(type, response, absentValue = null) {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
return res;
|
|
9
|
+
if (type === "String") return response.data;
|
|
10
|
+
const res = new Array(response.data.length);
|
|
11
|
+
for (let i = 0; i < response.data.length; i++) res[i] = pTableValue(response, i, {
|
|
12
|
+
absent: absentValue,
|
|
13
|
+
na: null
|
|
14
|
+
});
|
|
15
|
+
return res;
|
|
19
16
|
}
|
|
20
17
|
function createSearchFilter(columnId, substring) {
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
18
|
+
return {
|
|
19
|
+
type: "bySingleColumnV2",
|
|
20
|
+
column: {
|
|
21
|
+
type: "column",
|
|
22
|
+
id: columnId
|
|
23
|
+
},
|
|
24
|
+
predicate: {
|
|
25
|
+
operator: "StringIContains",
|
|
26
|
+
substring
|
|
27
|
+
}
|
|
28
|
+
};
|
|
32
29
|
}
|
|
33
30
|
function createAxisSearchFilter(axisSpec, substring) {
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
31
|
+
return {
|
|
32
|
+
type: "bySingleColumnV2",
|
|
33
|
+
column: {
|
|
34
|
+
type: "axis",
|
|
35
|
+
id: {
|
|
36
|
+
type: axisSpec.type,
|
|
37
|
+
name: axisSpec.name
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
predicate: {
|
|
41
|
+
operator: "StringIContains",
|
|
42
|
+
substring
|
|
43
|
+
}
|
|
44
|
+
};
|
|
48
45
|
}
|
|
49
46
|
function mapValuesToSuggestions(values) {
|
|
50
|
-
|
|
47
|
+
return values.map((v) => ({
|
|
48
|
+
value: String(v),
|
|
49
|
+
label: String(v)
|
|
50
|
+
})).sort(sortValuesPredicate);
|
|
51
51
|
}
|
|
52
52
|
function getPFrameDriver() {
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
if (typeof platforma.pFrameDriver === "undefined") {
|
|
57
|
-
throw new Error("PFrame driver is not available in the current Platforma instance");
|
|
58
|
-
}
|
|
59
|
-
return platforma.pFrameDriver;
|
|
53
|
+
if (typeof platforma === "undefined") throw new Error("Platforma instance is not available");
|
|
54
|
+
if (typeof platforma.pFrameDriver === "undefined") throw new Error("PFrame driver is not available in the current Platforma instance");
|
|
55
|
+
return platforma.pFrameDriver;
|
|
60
56
|
}
|
|
61
|
-
// Core functions
|
|
62
57
|
async function getColumnSpecById(handle, id) {
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
return null;
|
|
70
|
-
}
|
|
58
|
+
try {
|
|
59
|
+
return await getPFrameDriver().getColumnSpec(handle, id) ?? null;
|
|
60
|
+
} catch (err) {
|
|
61
|
+
console.error("PFrame: get single column error", err);
|
|
62
|
+
return null;
|
|
63
|
+
}
|
|
71
64
|
}
|
|
72
65
|
async function getSingleColumnData(handle, id, filters = []) {
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
}
|
|
66
|
+
try {
|
|
67
|
+
const response = await getPFrameDriver().calculateTableData(handle, {
|
|
68
|
+
src: {
|
|
69
|
+
type: "column",
|
|
70
|
+
column: id
|
|
71
|
+
},
|
|
72
|
+
filters,
|
|
73
|
+
sorting: []
|
|
74
|
+
});
|
|
75
|
+
const axes = response.filter((item) => item.spec.type === "axis");
|
|
76
|
+
const columns = response.filter((item) => item.spec.type === "column");
|
|
77
|
+
return {
|
|
78
|
+
axesData: axes.reduce((res, item) => {
|
|
79
|
+
const id = getAxisId(item.spec.spec);
|
|
80
|
+
res[canonicalizeAxisId(id)] = convertColumnData(id.type, item.data);
|
|
81
|
+
return res;
|
|
82
|
+
}, {}),
|
|
83
|
+
data: columns.length ? convertColumnData(columns[0].data.type, columns[0].data) : []
|
|
84
|
+
};
|
|
85
|
+
} catch (err) {
|
|
86
|
+
console.error("PFrame: calculateTableData error");
|
|
87
|
+
throw err;
|
|
88
|
+
}
|
|
97
89
|
}
|
|
98
90
|
async function getColumnUniqueValues(handle, id, limit = UNIQUE_VALUES_LIMIT, filters = []) {
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
console.error("PFrame: getUniqueValues for column error");
|
|
116
|
-
throw err;
|
|
117
|
-
}
|
|
91
|
+
const request = {
|
|
92
|
+
columnId: id,
|
|
93
|
+
filters,
|
|
94
|
+
limit
|
|
95
|
+
};
|
|
96
|
+
try {
|
|
97
|
+
const response = await getPFrameDriver().getUniqueValues(handle, request);
|
|
98
|
+
if (response.overflow) console.warn(`More than ${limit} values for ${id} column`);
|
|
99
|
+
return {
|
|
100
|
+
values: Array.from(response.values.data).map(String),
|
|
101
|
+
overflow: response.overflow
|
|
102
|
+
};
|
|
103
|
+
} catch (err) {
|
|
104
|
+
console.error("PFrame: getUniqueValues for column error");
|
|
105
|
+
throw err;
|
|
106
|
+
}
|
|
118
107
|
}
|
|
119
108
|
async function getAxisUniqueValues(handle, params) {
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
109
|
+
const { axisId, parentColumnIds, limit = UNIQUE_VALUES_LIMIT, filters = [] } = params;
|
|
110
|
+
const strAxisId = canonicalizeAxisId(axisId);
|
|
111
|
+
const parentsSpecs = (await Promise.all(parentColumnIds.map((p) => getColumnSpecById(handle, p)))).flatMap((spec, i) => spec != null && spec.kind === "PColumn" ? [[parentColumnIds[i], spec]] : []).filter(([_, spec]) => spec.axesSpec.some((axisSpec) => canonicalizeAxisId(getAxisId(axisSpec)) === strAxisId));
|
|
112
|
+
if (parentsSpecs.length === 0) {
|
|
113
|
+
console.warn("Axis unique values requested without parent columns");
|
|
114
|
+
return {
|
|
115
|
+
values: [],
|
|
116
|
+
overflow: false
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
try {
|
|
120
|
+
const responses = await Promise.all(parentsSpecs.map(([id]) => getPFrameDriver().getUniqueValues(handle, {
|
|
121
|
+
columnId: id,
|
|
122
|
+
axis: axisId,
|
|
123
|
+
filters,
|
|
124
|
+
limit
|
|
125
|
+
})));
|
|
126
|
+
const overflow = responses.some((r) => r.overflow);
|
|
127
|
+
return {
|
|
128
|
+
values: uniq(flatten(responses.map((r) => Array.from(r.values.data).map(String)))),
|
|
129
|
+
overflow
|
|
130
|
+
};
|
|
131
|
+
} catch (err) {
|
|
132
|
+
console.error("PFrame: getUniqueValues for axis error", err);
|
|
133
|
+
return {
|
|
134
|
+
values: [],
|
|
135
|
+
overflow: false
|
|
136
|
+
};
|
|
137
|
+
}
|
|
146
138
|
}
|
|
147
139
|
async function getRequestColumnsFromSelectedSources(handle, sources) {
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
}
|
|
155
|
-
return result;
|
|
140
|
+
const result = [];
|
|
141
|
+
for (const item of sources) {
|
|
142
|
+
const spec = await getColumnSpecById(handle, item);
|
|
143
|
+
if (spec?.kind === "PColumn") result.push(...spec.axesSpec.map((spec) => getAxisId(spec)));
|
|
144
|
+
}
|
|
145
|
+
return result;
|
|
156
146
|
}
|
|
157
147
|
async function getColumnsFull(handle, params) {
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
throw err;
|
|
179
|
-
}
|
|
148
|
+
const { selectedSources, strictlyCompatible, types, names, annotations, annotationsNotEmpty } = params;
|
|
149
|
+
try {
|
|
150
|
+
const request = {
|
|
151
|
+
columnFilter: {
|
|
152
|
+
type: types,
|
|
153
|
+
name: names,
|
|
154
|
+
annotationValue: annotations,
|
|
155
|
+
annotationPattern: annotationsNotEmpty?.reduce((res, v) => {
|
|
156
|
+
res[v] = ".+";
|
|
157
|
+
return res;
|
|
158
|
+
}, {})
|
|
159
|
+
},
|
|
160
|
+
compatibleWith: await getRequestColumnsFromSelectedSources(handle, selectedSources),
|
|
161
|
+
strictlyCompatible
|
|
162
|
+
};
|
|
163
|
+
return (await getPFrameDriver().findColumns(handle, request)).hits;
|
|
164
|
+
} catch (err) {
|
|
165
|
+
console.error("PFrame: findColumns error");
|
|
166
|
+
throw err;
|
|
167
|
+
}
|
|
180
168
|
}
|
|
181
169
|
async function getColumnOrAxisValueLabelsId(handle, strAxisId) {
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
});
|
|
190
|
-
return labelColumn?.columnId;
|
|
170
|
+
return (await getColumnsFull(handle, {
|
|
171
|
+
selectedSources: [],
|
|
172
|
+
strictlyCompatible: false,
|
|
173
|
+
names: [PColumnName.Label]
|
|
174
|
+
})).find(({ spec }) => {
|
|
175
|
+
return spec && spec.axesSpec.length === 1 && canonicalizeAxisId(spec.axesSpec[0]) === strAxisId;
|
|
176
|
+
})?.columnId;
|
|
191
177
|
}
|
|
192
178
|
function getDiscreteValuesFromAnnotation(columnSpec) {
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
179
|
+
const discreteValuesStr = readAnnotation(columnSpec, Annotation.DiscreteValues);
|
|
180
|
+
if (!discreteValuesStr) return;
|
|
181
|
+
try {
|
|
182
|
+
return {
|
|
183
|
+
values: JSON.parse(discreteValuesStr).map((v) => String(v)).map((v) => ({
|
|
184
|
+
value: v,
|
|
185
|
+
label: v
|
|
186
|
+
})).sort(sortValuesPredicate),
|
|
187
|
+
overflow: false
|
|
188
|
+
};
|
|
189
|
+
} catch {
|
|
190
|
+
console.error(`Parsing error: discrete values annotation ${discreteValuesStr}`);
|
|
191
|
+
return;
|
|
192
|
+
}
|
|
206
193
|
}
|
|
207
194
|
async function getAxisValuesWithLabels(handle, params) {
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
}
|
|
195
|
+
const { columnId, axisSpec, labelsColumnId, limit, searchQuery, searchQueryValue } = params;
|
|
196
|
+
const strAxisId = canonicalizeAxisId(getAxisId(axisSpec));
|
|
197
|
+
let filters = [];
|
|
198
|
+
if (labelsColumnId) {
|
|
199
|
+
if (searchQuery) filters = [createSearchFilter(labelsColumnId, searchQuery)];
|
|
200
|
+
if (searchQueryValue) filters = [createAxisSearchFilter(axisSpec, searchQueryValue)];
|
|
201
|
+
const { data: dataValues, axesData } = await getSingleColumnData(handle, labelsColumnId, filters);
|
|
202
|
+
const axisKeys = axesData[strAxisId];
|
|
203
|
+
const values = [];
|
|
204
|
+
for (let i = 0; i < Math.min(axisKeys.length, limit ?? axisKeys.length); i++) values.push({
|
|
205
|
+
value: String(axisKeys[i]),
|
|
206
|
+
label: String(dataValues[i])
|
|
207
|
+
});
|
|
208
|
+
values.sort(sortValuesPredicate);
|
|
209
|
+
return {
|
|
210
|
+
values,
|
|
211
|
+
overflow: !(limit === void 0 || axisKeys.length < limit)
|
|
212
|
+
};
|
|
213
|
+
} else {
|
|
214
|
+
const searchInLabelsOrValue = searchQuery ?? searchQueryValue;
|
|
215
|
+
if (searchInLabelsOrValue) filters = [createAxisSearchFilter(axisSpec, searchInLabelsOrValue)];
|
|
216
|
+
const response = await getAxisUniqueValues(handle, {
|
|
217
|
+
axisId: getAxisId(axisSpec),
|
|
218
|
+
parentColumnIds: [columnId],
|
|
219
|
+
limit,
|
|
220
|
+
filters
|
|
221
|
+
});
|
|
222
|
+
return {
|
|
223
|
+
values: mapValuesToSuggestions(response.values),
|
|
224
|
+
overflow: response.overflow
|
|
225
|
+
};
|
|
226
|
+
}
|
|
241
227
|
}
|
|
242
228
|
async function getColumnValuesWithLabels(handle, params) {
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
return { values, overflow: response.overflow };
|
|
229
|
+
const { columnId, limit, searchQuery, searchQueryValue } = params;
|
|
230
|
+
const searchInLabelsOrValue = searchQuery ?? searchQueryValue;
|
|
231
|
+
const response = await getColumnUniqueValues(handle, columnId, limit, searchInLabelsOrValue ? [createSearchFilter(columnId, searchInLabelsOrValue)] : []);
|
|
232
|
+
return {
|
|
233
|
+
values: mapValuesToSuggestions(response.values),
|
|
234
|
+
overflow: response.overflow
|
|
235
|
+
};
|
|
251
236
|
}
|
|
252
237
|
async function getUniqueSourceValuesWithLabels(handle, params) {
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
return getColumnValuesWithLabels(handle, {
|
|
279
|
-
columnId,
|
|
280
|
-
limit,
|
|
281
|
-
searchQuery,
|
|
282
|
-
searchQueryValue,
|
|
283
|
-
});
|
|
238
|
+
const { columnId, axisIdx, limit, searchQuery, searchQueryValue } = params;
|
|
239
|
+
const selectedSourceSpec = await getColumnSpecById(handle, columnId);
|
|
240
|
+
if (selectedSourceSpec == null || selectedSourceSpec.kind !== "PColumn") return {
|
|
241
|
+
values: [],
|
|
242
|
+
overflow: false
|
|
243
|
+
};
|
|
244
|
+
const discreteValues = getDiscreteValuesFromAnnotation(selectedSourceSpec);
|
|
245
|
+
if (discreteValues != null) return discreteValues;
|
|
246
|
+
if (axisIdx != null) {
|
|
247
|
+
const axisSpec = selectedSourceSpec.axesSpec[axisIdx];
|
|
248
|
+
return getAxisValuesWithLabels(handle, {
|
|
249
|
+
columnId,
|
|
250
|
+
axisSpec,
|
|
251
|
+
labelsColumnId: await getColumnOrAxisValueLabelsId(handle, canonicalizeAxisId(getAxisId(axisSpec))),
|
|
252
|
+
limit,
|
|
253
|
+
searchQuery,
|
|
254
|
+
searchQueryValue
|
|
255
|
+
});
|
|
256
|
+
}
|
|
257
|
+
return getColumnValuesWithLabels(handle, {
|
|
258
|
+
columnId,
|
|
259
|
+
limit,
|
|
260
|
+
searchQuery,
|
|
261
|
+
searchQueryValue
|
|
262
|
+
});
|
|
284
263
|
}
|
|
285
264
|
|
|
265
|
+
//#endregion
|
|
286
266
|
export { getAxisUniqueValues, getColumnOrAxisValueLabelsId, getColumnSpecById, getColumnUniqueValues, getColumnsFull, getRequestColumnsFromSelectedSources, getSingleColumnData, getUniqueSourceValuesWithLabels };
|
|
287
|
-
//# sourceMappingURL=index.js.map
|
|
267
|
+
//# sourceMappingURL=index.js.map
|