@devrev/meerkat-core 0.0.96 → 0.0.98
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/README.md +70 -6
- package/package.json +2 -2
- package/src/ast-builder/ast-builder.js +91 -0
- package/src/ast-builder/ast-builder.js.map +1 -0
- package/src/ast-deserializer/ast-deserializer.js +17 -0
- package/src/ast-deserializer/ast-deserializer.js.map +1 -0
- package/src/ast-serializer/ast-serializer.js +8 -0
- package/src/ast-serializer/ast-serializer.js.map +1 -0
- package/src/ast-validator/dimension-validator.js +49 -0
- package/src/ast-validator/dimension-validator.js.map +1 -0
- package/src/ast-validator/index.js +12 -0
- package/src/ast-validator/index.js.map +1 -0
- package/src/ast-validator/measure-validator.js +155 -0
- package/src/ast-validator/measure-validator.js.map +1 -0
- package/{ast-validator → src/ast-validator}/tests/test-data.js +692 -890
- package/src/ast-validator/tests/test-data.js.map +1 -0
- package/src/ast-validator/types.js +3 -0
- package/src/ast-validator/types.js.map +1 -0
- package/src/ast-validator/utils.js +24 -0
- package/src/ast-validator/utils.js.map +1 -0
- package/src/context-params/context-params-ast.js +42 -0
- package/src/context-params/context-params-ast.js.map +1 -0
- package/src/cube-filter-transformer/and/and.js +14 -0
- package/src/cube-filter-transformer/and/and.js.map +1 -0
- package/src/cube-filter-transformer/base-condition-builder/base-condition-builder.js +145 -0
- package/src/cube-filter-transformer/base-condition-builder/base-condition-builder.js.map +1 -0
- package/src/cube-filter-transformer/contains/contains.js +62 -0
- package/src/cube-filter-transformer/contains/contains.js.map +1 -0
- package/src/cube-filter-transformer/equals/equals-array.js +71 -0
- package/src/cube-filter-transformer/equals/equals-array.js.map +1 -0
- package/src/cube-filter-transformer/equals/equals.js +36 -0
- package/src/cube-filter-transformer/equals/equals.js.map +1 -0
- package/src/cube-filter-transformer/factory.js +120 -0
- package/src/cube-filter-transformer/factory.js.map +1 -0
- package/src/cube-filter-transformer/gt/gt.js +28 -0
- package/src/cube-filter-transformer/gt/gt.js.map +1 -0
- package/src/cube-filter-transformer/gte/gte.js +28 -0
- package/src/cube-filter-transformer/gte/gte.js.map +1 -0
- package/src/cube-filter-transformer/in/in.js +69 -0
- package/src/cube-filter-transformer/in/in.js.map +1 -0
- package/src/cube-filter-transformer/in-date-range/in-date-range.js +21 -0
- package/src/cube-filter-transformer/in-date-range/in-date-range.js.map +1 -0
- package/src/cube-filter-transformer/lt/lt.js +28 -0
- package/src/cube-filter-transformer/lt/lt.js.map +1 -0
- package/src/cube-filter-transformer/lte/lte.js +28 -0
- package/src/cube-filter-transformer/lte/lte.js.map +1 -0
- package/src/cube-filter-transformer/not/not.js +14 -0
- package/src/cube-filter-transformer/not/not.js.map +1 -0
- package/src/cube-filter-transformer/not-In-date-range/not-In-date-range.js +21 -0
- package/src/cube-filter-transformer/not-In-date-range/not-In-date-range.js.map +1 -0
- package/src/cube-filter-transformer/not-contains/not-contains.js +62 -0
- package/src/cube-filter-transformer/not-contains/not-contains.js.map +1 -0
- package/src/cube-filter-transformer/not-equals/not-equals-array.js +21 -0
- package/src/cube-filter-transformer/not-equals/not-equals-array.js.map +1 -0
- package/src/cube-filter-transformer/not-equals/not-equals.js +36 -0
- package/src/cube-filter-transformer/not-equals/not-equals.js.map +1 -0
- package/src/cube-filter-transformer/not-in/not-in.js +76 -0
- package/src/cube-filter-transformer/not-in/not-in.js.map +1 -0
- package/src/cube-filter-transformer/not-set/not-set.js +23 -0
- package/src/cube-filter-transformer/not-set/not-set.js.map +1 -0
- package/src/cube-filter-transformer/or/or.js +14 -0
- package/src/cube-filter-transformer/or/or.js.map +1 -0
- package/src/cube-filter-transformer/set/set.js +23 -0
- package/src/cube-filter-transformer/set/set.js.map +1 -0
- package/src/cube-group-by-transformer/cube-group-by-transformer.js +19 -0
- package/src/cube-group-by-transformer/cube-group-by-transformer.js.map +1 -0
- package/src/cube-limit-offset-transformer/cube-limit-offset-transformer.js +42 -0
- package/src/cube-limit-offset-transformer/cube-limit-offset-transformer.js.map +1 -0
- package/src/cube-measure-transformer/cube-measure-transformer.js +124 -0
- package/src/cube-measure-transformer/cube-measure-transformer.js.map +1 -0
- package/src/cube-order-by-transformer/cube-order-by-transformer.js +34 -0
- package/src/cube-order-by-transformer/cube-order-by-transformer.js.map +1 -0
- package/src/cube-to-duckdb/cube-filter-to-duckdb.js +3 -0
- package/src/cube-to-duckdb/cube-filter-to-duckdb.js.map +1 -0
- package/src/filter-params/filter-params-ast.js +114 -0
- package/src/filter-params/filter-params-ast.js.map +1 -0
- package/src/get-filter-params-sql/get-filter-params-sql.js +25 -0
- package/src/get-filter-params-sql/get-filter-params-sql.js.map +1 -0
- package/src/get-final-base-sql/get-final-base-sql.js +28 -0
- package/src/get-final-base-sql/get-final-base-sql.js.map +1 -0
- package/{get-wrapped-base-query-with-projections → src/get-wrapped-base-query-with-projections}/get-aliased-columns-from-filters.js +39 -64
- package/src/get-wrapped-base-query-with-projections/get-aliased-columns-from-filters.js.map +1 -0
- package/src/get-wrapped-base-query-with-projections/get-projection-clause.js +83 -0
- package/src/get-wrapped-base-query-with-projections/get-projection-clause.js.map +1 -0
- package/src/get-wrapped-base-query-with-projections/get-wrapped-base-query-with-projections.js +32 -0
- package/src/get-wrapped-base-query-with-projections/get-wrapped-base-query-with-projections.js.map +1 -0
- package/src/get-wrapped-base-query-with-projections/sql-expression-modifiers.js +32 -0
- package/src/get-wrapped-base-query-with-projections/sql-expression-modifiers.js.map +1 -0
- package/src/index.js +37 -0
- package/src/index.js.map +1 -0
- package/src/joins/joins.js +162 -0
- package/src/joins/joins.js.map +1 -0
- package/src/member-formatters/constants.js +6 -0
- package/src/member-formatters/constants.js.map +1 -0
- package/src/member-formatters/index.js +10 -0
- package/src/member-formatters/index.js.map +1 -0
- package/src/member-formatters/member-key-to-safe-key.js +9 -0
- package/src/member-formatters/member-key-to-safe-key.js.map +1 -0
- package/src/member-formatters/split-into-data-source-and-fields.js +10 -0
- package/src/member-formatters/split-into-data-source-and-fields.js.map +1 -0
- package/src/resolution/resolution.js +112 -0
- package/src/resolution/resolution.js.map +1 -0
- package/src/resolution/types.js +5 -0
- package/src/resolution/types.js.map +1 -0
- package/src/types/cube-types/index.js +6 -0
- package/src/types/cube-types/index.js.map +1 -0
- package/src/types/cube-types/query.js +8 -0
- package/src/types/cube-types/query.js.map +1 -0
- package/src/types/cube-types/table.js +3 -0
- package/src/types/cube-types/table.js.map +1 -0
- package/src/types/duckdb-serialization-types/index.js +11 -0
- package/src/types/duckdb-serialization-types/index.js.map +1 -0
- package/{types → src/types}/duckdb-serialization-types/serialization/Constraint.js +6 -19
- package/src/types/duckdb-serialization-types/serialization/Constraint.js.map +1 -0
- package/{types → src/types}/duckdb-serialization-types/serialization/CreateInfo.js +10 -29
- package/src/types/duckdb-serialization-types/serialization/CreateInfo.js.map +1 -0
- package/{types → src/types}/duckdb-serialization-types/serialization/Expression.js +6 -19
- package/src/types/duckdb-serialization-types/serialization/Expression.js.map +1 -0
- package/src/types/duckdb-serialization-types/serialization/LogicalOperator.js +28 -0
- package/src/types/duckdb-serialization-types/serialization/LogicalOperator.js.map +1 -0
- package/src/types/duckdb-serialization-types/serialization/MacroFunction.js +10 -0
- package/src/types/duckdb-serialization-types/serialization/MacroFunction.js.map +1 -0
- package/src/types/duckdb-serialization-types/serialization/Misc.js +3 -0
- package/src/types/duckdb-serialization-types/serialization/Misc.js.map +1 -0
- package/{types → src/types}/duckdb-serialization-types/serialization/Nodes.js +17 -45
- package/src/types/duckdb-serialization-types/serialization/Nodes.js.map +1 -0
- package/{types → src/types}/duckdb-serialization-types/serialization/ParseInfo.js +20 -54
- package/src/types/duckdb-serialization-types/serialization/ParseInfo.js.map +1 -0
- package/{types → src/types}/duckdb-serialization-types/serialization/ParsedExpression.js +6 -19
- package/src/types/duckdb-serialization-types/serialization/ParsedExpression.js.map +1 -0
- package/{types → src/types}/duckdb-serialization-types/serialization/QueryNode.js +8 -24
- package/src/types/duckdb-serialization-types/serialization/QueryNode.js.map +1 -0
- package/{types → src/types}/duckdb-serialization-types/serialization/ResultModifier.js +4 -9
- package/src/types/duckdb-serialization-types/serialization/ResultModifier.js.map +1 -0
- package/src/types/duckdb-serialization-types/serialization/Statement.js +3 -0
- package/src/types/duckdb-serialization-types/serialization/Statement.js.map +1 -0
- package/{types → src/types}/duckdb-serialization-types/serialization/TableFilter.js +4 -9
- package/src/types/duckdb-serialization-types/serialization/TableFilter.js.map +1 -0
- package/{types → src/types}/duckdb-serialization-types/serialization/TableRef.js +8 -24
- package/src/types/duckdb-serialization-types/serialization/TableRef.js.map +1 -0
- package/{types → src/types}/duckdb-serialization-types/serialization/Types.js +4 -9
- package/src/types/duckdb-serialization-types/serialization/Types.js.map +1 -0
- package/src/types/duckdb-serialization-types/serialization/example.js +109 -0
- package/src/types/duckdb-serialization-types/serialization/example.js.map +1 -0
- package/src/types/utils.js +69 -0
- package/src/types/utils.js.map +1 -0
- package/{utils → src/utils}/__fixtures__/joins.fixtures.js +228 -316
- package/src/utils/__fixtures__/joins.fixtures.js.map +1 -0
- package/src/utils/base-ast.js +49 -0
- package/src/utils/base-ast.js.map +1 -0
- package/src/utils/cube-filter-enrichment.js +53 -0
- package/src/utils/cube-filter-enrichment.js.map +1 -0
- package/{utils → src/utils}/cube-to-table-schema.js +25 -38
- package/src/utils/cube-to-table-schema.js.map +1 -0
- package/src/utils/cube-type-to-duckdb-type.js +12 -0
- package/src/utils/cube-type-to-duckdb-type.js.map +1 -0
- package/src/utils/find-in-table-schema.js +28 -0
- package/src/utils/find-in-table-schema.js.map +1 -0
- package/src/utils/get-column-names-from-ast.js +45 -0
- package/src/utils/get-column-names-from-ast.js.map +1 -0
- package/src/utils/get-possible-nodes.js +146 -0
- package/src/utils/get-possible-nodes.js.map +1 -0
- package/src/utils/get-type-info.js +34 -0
- package/src/utils/get-type-info.js.map +1 -0
- package/src/utils/is-array-member-type.js +8 -0
- package/src/utils/is-array-member-type.js.map +1 -0
- package/src/utils/key-from-measures-dimension.js +32 -0
- package/src/utils/key-from-measures-dimension.js.map +1 -0
- package/src/utils/meerkat-placeholder-replacer.js +10 -0
- package/src/utils/meerkat-placeholder-replacer.js.map +1 -0
- package/src/utils/modify-meerkat-filter.js +24 -0
- package/src/utils/modify-meerkat-filter.js.map +1 -0
- package/{utils → src/utils}/type-guards.js +10 -28
- package/src/utils/type-guards.js.map +1 -0
- package/ast-builder/ast-builder.js +0 -90
- package/ast-builder/ast-builder.js.map +0 -1
- package/ast-deserializer/ast-deserializer.js +0 -30
- package/ast-deserializer/ast-deserializer.js.map +0 -1
- package/ast-serializer/ast-serializer.js +0 -12
- package/ast-serializer/ast-serializer.js.map +0 -1
- package/ast-validator/dimension-validator.js +0 -54
- package/ast-validator/dimension-validator.js.map +0 -1
- package/ast-validator/index.js +0 -25
- package/ast-validator/index.js.map +0 -1
- package/ast-validator/measure-validator.js +0 -163
- package/ast-validator/measure-validator.js.map +0 -1
- package/ast-validator/tests/test-data.js.map +0 -1
- package/ast-validator/types.js +0 -3
- package/ast-validator/types.js.map +0 -1
- package/ast-validator/utils.js +0 -35
- package/ast-validator/utils.js.map +0 -1
- package/context-params/context-params-ast.js +0 -55
- package/context-params/context-params-ast.js.map +0 -1
- package/cube-filter-transformer/and/and.js +0 -18
- package/cube-filter-transformer/and/and.js.map +0 -1
- package/cube-filter-transformer/base-condition-builder/base-condition-builder.js +0 -160
- package/cube-filter-transformer/base-condition-builder/base-condition-builder.js.map +0 -1
- package/cube-filter-transformer/contains/contains.js +0 -71
- package/cube-filter-transformer/contains/contains.js.map +0 -1
- package/cube-filter-transformer/equals/equals-array.js +0 -77
- package/cube-filter-transformer/equals/equals-array.js.map +0 -1
- package/cube-filter-transformer/equals/equals.js +0 -37
- package/cube-filter-transformer/equals/equals.js.map +0 -1
- package/cube-filter-transformer/factory.js +0 -124
- package/cube-filter-transformer/factory.js.map +0 -1
- package/cube-filter-transformer/gt/gt.js +0 -30
- package/cube-filter-transformer/gt/gt.js.map +0 -1
- package/cube-filter-transformer/gte/gte.js +0 -30
- package/cube-filter-transformer/gte/gte.js.map +0 -1
- package/cube-filter-transformer/in/in.js +0 -78
- package/cube-filter-transformer/in/in.js.map +0 -1
- package/cube-filter-transformer/in-date-range/in-date-range.js +0 -24
- package/cube-filter-transformer/in-date-range/in-date-range.js.map +0 -1
- package/cube-filter-transformer/lt/lt.js +0 -30
- package/cube-filter-transformer/lt/lt.js.map +0 -1
- package/cube-filter-transformer/lte/lte.js +0 -30
- package/cube-filter-transformer/lte/lte.js.map +0 -1
- package/cube-filter-transformer/not/not.js +0 -18
- package/cube-filter-transformer/not/not.js.map +0 -1
- package/cube-filter-transformer/not-In-date-range/not-In-date-range.js +0 -24
- package/cube-filter-transformer/not-In-date-range/not-In-date-range.js.map +0 -1
- package/cube-filter-transformer/not-contains/not-contains.js +0 -71
- package/cube-filter-transformer/not-contains/not-contains.js.map +0 -1
- package/cube-filter-transformer/not-equals/not-equals-array.js +0 -26
- package/cube-filter-transformer/not-equals/not-equals-array.js.map +0 -1
- package/cube-filter-transformer/not-equals/not-equals.js +0 -37
- package/cube-filter-transformer/not-equals/not-equals.js.map +0 -1
- package/cube-filter-transformer/not-in/not-in.js +0 -85
- package/cube-filter-transformer/not-in/not-in.js.map +0 -1
- package/cube-filter-transformer/not-set/not-set.js +0 -27
- package/cube-filter-transformer/not-set/not-set.js.map +0 -1
- package/cube-filter-transformer/or/or.js +0 -18
- package/cube-filter-transformer/or/or.js.map +0 -1
- package/cube-filter-transformer/set/set.js +0 -27
- package/cube-filter-transformer/set/set.js.map +0 -1
- package/cube-group-by-transformer/cube-group-by-transformer.js +0 -25
- package/cube-group-by-transformer/cube-group-by-transformer.js.map +0 -1
- package/cube-limit-offset-transformer/cube-limit-offset-transformer.js +0 -42
- package/cube-limit-offset-transformer/cube-limit-offset-transformer.js.map +0 -1
- package/cube-measure-transformer/cube-measure-transformer.js +0 -127
- package/cube-measure-transformer/cube-measure-transformer.js.map +0 -1
- package/cube-order-by-transformer/cube-order-by-transformer.js +0 -39
- package/cube-order-by-transformer/cube-order-by-transformer.js.map +0 -1
- package/cube-to-duckdb/cube-filter-to-duckdb.js +0 -3
- package/cube-to-duckdb/cube-filter-to-duckdb.js.map +0 -1
- package/filter-params/filter-params-ast.js +0 -115
- package/filter-params/filter-params-ast.js.map +0 -1
- package/get-filter-params-sql/get-filter-params-sql.js +0 -28
- package/get-filter-params-sql/get-filter-params-sql.js.map +0 -1
- package/get-final-base-sql/get-final-base-sql.js +0 -30
- package/get-final-base-sql/get-final-base-sql.js.map +0 -1
- package/get-wrapped-base-query-with-projections/get-aliased-columns-from-filters.js.map +0 -1
- package/get-wrapped-base-query-with-projections/get-projection-clause.js +0 -87
- package/get-wrapped-base-query-with-projections/get-projection-clause.js.map +0 -1
- package/get-wrapped-base-query-with-projections/get-wrapped-base-query-with-projections.js +0 -33
- package/get-wrapped-base-query-with-projections/get-wrapped-base-query-with-projections.js.map +0 -1
- package/get-wrapped-base-query-with-projections/sql-expression-modifiers.js +0 -60
- package/get-wrapped-base-query-with-projections/sql-expression-modifiers.js.map +0 -1
- package/index.js +0 -66
- package/index.js.map +0 -1
- package/joins/joins.js +0 -170
- package/joins/joins.js.map +0 -1
- package/member-formatters/constants.js +0 -19
- package/member-formatters/constants.js.map +0 -1
- package/member-formatters/index.js +0 -23
- package/member-formatters/index.js.map +0 -1
- package/member-formatters/member-key-to-safe-key.js +0 -13
- package/member-formatters/member-key-to-safe-key.js.map +0 -1
- package/member-formatters/split-into-data-source-and-fields.js +0 -17
- package/member-formatters/split-into-data-source-and-fields.js.map +0 -1
- package/resolution/resolution.js +0 -128
- package/resolution/resolution.js.map +0 -1
- package/resolution/types.js +0 -10
- package/resolution/types.js.map +0 -1
- package/types/cube-types/index.d.js +0 -6
- package/types/cube-types/index.d.js.map +0 -1
- package/types/cube-types/index.js +0 -6
- package/types/cube-types/index.js.map +0 -1
- package/types/cube-types/query.d.js +0 -5
- package/types/cube-types/query.d.js.map +0 -1
- package/types/cube-types/query.js +0 -14
- package/types/cube-types/query.js.map +0 -1
- package/types/cube-types/table.d.js +0 -3
- package/types/cube-types/table.d.js.map +0 -1
- package/types/cube-types/table.js +0 -3
- package/types/cube-types/table.js.map +0 -1
- package/types/duckdb-serialization-types/index.d.js +0 -11
- package/types/duckdb-serialization-types/index.d.js.map +0 -1
- package/types/duckdb-serialization-types/index.js +0 -11
- package/types/duckdb-serialization-types/index.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/Constraint.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/CreateInfo.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/Expression.d.js +0 -3
- package/types/duckdb-serialization-types/serialization/Expression.d.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/Expression.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/LogicalOperator.js +0 -47
- package/types/duckdb-serialization-types/serialization/LogicalOperator.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/MacroFunction.js +0 -15
- package/types/duckdb-serialization-types/serialization/MacroFunction.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/Misc.d.js +0 -3
- package/types/duckdb-serialization-types/serialization/Misc.d.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/Misc.js +0 -3
- package/types/duckdb-serialization-types/serialization/Misc.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/Nodes.d.js +0 -3
- package/types/duckdb-serialization-types/serialization/Nodes.d.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/Nodes.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/ParseInfo.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/ParsedExpression.d.js +0 -3
- package/types/duckdb-serialization-types/serialization/ParsedExpression.d.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/ParsedExpression.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/QueryNode.d.js +0 -3
- package/types/duckdb-serialization-types/serialization/QueryNode.d.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/QueryNode.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/ResultModifier.d.js +0 -3
- package/types/duckdb-serialization-types/serialization/ResultModifier.d.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/ResultModifier.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/Statement.d.js +0 -3
- package/types/duckdb-serialization-types/serialization/Statement.d.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/Statement.js +0 -3
- package/types/duckdb-serialization-types/serialization/Statement.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/TableFilter.d.js +0 -3
- package/types/duckdb-serialization-types/serialization/TableFilter.d.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/TableFilter.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/TableRef.d.js +0 -3
- package/types/duckdb-serialization-types/serialization/TableRef.d.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/TableRef.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/Types.d.js +0 -3
- package/types/duckdb-serialization-types/serialization/Types.d.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/Types.js.map +0 -1
- package/types/duckdb-serialization-types/serialization/example.js +0 -131
- package/types/duckdb-serialization-types/serialization/example.js.map +0 -1
- package/types/utils.js +0 -108
- package/types/utils.js.map +0 -1
- package/utils/__fixtures__/joins.fixtures.js.map +0 -1
- package/utils/base-ast.js +0 -63
- package/utils/base-ast.js.map +0 -1
- package/utils/cube-filter-enrichment.js +0 -63
- package/utils/cube-filter-enrichment.js.map +0 -1
- package/utils/cube-to-table-schema.js.map +0 -1
- package/utils/cube-type-to-duckdb-type.js +0 -17
- package/utils/cube-type-to-duckdb-type.js.map +0 -1
- package/utils/find-in-table-schema.js +0 -40
- package/utils/find-in-table-schema.js.map +0 -1
- package/utils/get-column-names-from-ast.js +0 -45
- package/utils/get-column-names-from-ast.js.map +0 -1
- package/utils/get-possible-nodes.js +0 -152
- package/utils/get-possible-nodes.js.map +0 -1
- package/utils/get-type-info.js +0 -44
- package/utils/get-type-info.js.map +0 -1
- package/utils/is-array-member-type.js +0 -12
- package/utils/is-array-member-type.js.map +0 -1
- package/utils/key-from-measures-dimension.js +0 -35
- package/utils/key-from-measures-dimension.js.map +0 -1
- package/utils/meerkat-placeholder-replacer.js +0 -14
- package/utils/meerkat-placeholder-replacer.js.map +0 -1
- package/utils/modify-meerkat-filter.js +0 -30
- package/utils/modify-meerkat-filter.js.map +0 -1
- package/utils/type-guards.js.map +0 -1
|
@@ -1,56 +1,38 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
getAliasedColumnsFromFilters: function() {
|
|
10
|
-
return getAliasedColumnsFromFilters;
|
|
11
|
-
},
|
|
12
|
-
getDimensionProjection: function() {
|
|
13
|
-
return getDimensionProjection;
|
|
14
|
-
},
|
|
15
|
-
getFilterMeasureProjection: function() {
|
|
16
|
-
return getFilterMeasureProjection;
|
|
17
|
-
}
|
|
18
|
-
});
|
|
19
|
-
const _memberkeytosafekey = require("../member-formatters/member-key-to-safe-key");
|
|
20
|
-
const _splitintodatasourceandfields = require("../member-formatters/split-into-data-source-and-fields");
|
|
21
|
-
const _findintableschema = require("../utils/find-in-table-schema");
|
|
22
|
-
const _sqlexpressionmodifiers = require("./sql-expression-modifiers");
|
|
23
|
-
const getDimensionProjection = ({ key, tableSchema, modifiers, query })=>{
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getAliasedColumnsFromFilters = exports.getFilterMeasureProjection = exports.getDimensionProjection = void 0;
|
|
4
|
+
const member_key_to_safe_key_1 = require("../member-formatters/member-key-to-safe-key");
|
|
5
|
+
const split_into_data_source_and_fields_1 = require("../member-formatters/split-into-data-source-and-fields");
|
|
6
|
+
const find_in_table_schema_1 = require("../utils/find-in-table-schema");
|
|
7
|
+
const sql_expression_modifiers_1 = require("./sql-expression-modifiers");
|
|
8
|
+
const getDimensionProjection = ({ key, tableSchema, modifiers, query, }) => {
|
|
24
9
|
// Find the table access key
|
|
25
|
-
const [tableName, measureWithoutTable] = (0,
|
|
26
|
-
const foundMember = (0,
|
|
10
|
+
const [tableName, measureWithoutTable] = (0, split_into_data_source_and_fields_1.splitIntoDataSourceAndFields)(key);
|
|
11
|
+
const foundMember = (0, find_in_table_schema_1.findInDimensionSchema)(measureWithoutTable, tableSchema);
|
|
27
12
|
if (!foundMember || tableName !== tableSchema.name) {
|
|
28
13
|
// If the selected member is not found in the table schema or if it is already selected, continue.
|
|
29
14
|
// If the selected member is not from the current table, don't create an alias.
|
|
30
15
|
return {
|
|
31
16
|
sql: undefined,
|
|
32
17
|
foundMember: undefined,
|
|
33
|
-
aliasKey: undefined
|
|
18
|
+
aliasKey: undefined,
|
|
34
19
|
};
|
|
35
20
|
}
|
|
36
|
-
const modifiedSql = (0,
|
|
21
|
+
const modifiedSql = (0, sql_expression_modifiers_1.getModifiedSqlExpression)({
|
|
37
22
|
dimension: foundMember,
|
|
38
23
|
key: key,
|
|
39
24
|
modifiers: modifiers,
|
|
40
25
|
sqlExpression: foundMember.sql,
|
|
41
|
-
query
|
|
26
|
+
query,
|
|
42
27
|
});
|
|
43
|
-
const aliasKey = (0,
|
|
28
|
+
const aliasKey = (0, member_key_to_safe_key_1.memberKeyToSafeKey)(key);
|
|
44
29
|
// Add the alias key to the set. So we have a reference to all the previously selected members.
|
|
45
|
-
return {
|
|
46
|
-
sql: `${modifiedSql} AS ${aliasKey}`,
|
|
47
|
-
foundMember,
|
|
48
|
-
aliasKey
|
|
49
|
-
};
|
|
30
|
+
return { sql: `${modifiedSql} AS ${aliasKey}`, foundMember, aliasKey };
|
|
50
31
|
};
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
const
|
|
32
|
+
exports.getDimensionProjection = getDimensionProjection;
|
|
33
|
+
const getFilterMeasureProjection = ({ key, tableSchema, measures, }) => {
|
|
34
|
+
const [tableName, measureWithoutTable] = (0, split_into_data_source_and_fields_1.splitIntoDataSourceAndFields)(key);
|
|
35
|
+
const foundMember = (0, find_in_table_schema_1.findInMeasureSchema)(measureWithoutTable, tableSchema);
|
|
54
36
|
const isMeasure = measures.includes(key);
|
|
55
37
|
if (!foundMember || isMeasure || tableName !== tableSchema.name) {
|
|
56
38
|
// If the selected member is not found in the table schema or if it is already selected, continue.
|
|
@@ -59,71 +41,64 @@ const getFilterMeasureProjection = ({ key, tableSchema, measures })=>{
|
|
|
59
41
|
return {
|
|
60
42
|
sql: undefined,
|
|
61
43
|
foundMember: undefined,
|
|
62
|
-
aliasKey: undefined
|
|
44
|
+
aliasKey: undefined,
|
|
63
45
|
};
|
|
64
46
|
}
|
|
65
|
-
const aliasKey = (0,
|
|
66
|
-
return {
|
|
67
|
-
sql: `${key} AS ${aliasKey}`,
|
|
68
|
-
foundMember,
|
|
69
|
-
aliasKey
|
|
70
|
-
};
|
|
47
|
+
const aliasKey = (0, member_key_to_safe_key_1.memberKeyToSafeKey)(key);
|
|
48
|
+
return { sql: `${key} AS ${aliasKey}`, foundMember, aliasKey };
|
|
71
49
|
};
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
const
|
|
50
|
+
exports.getFilterMeasureProjection = getFilterMeasureProjection;
|
|
51
|
+
const getFilterProjections = ({ member, tableSchema, measures, query, }) => {
|
|
52
|
+
const [, memberWithoutTable] = (0, split_into_data_source_and_fields_1.splitIntoDataSourceAndFields)(member);
|
|
53
|
+
const isDimension = (0, find_in_table_schema_1.findInDimensionSchema)(memberWithoutTable, tableSchema);
|
|
75
54
|
if (isDimension) {
|
|
76
|
-
return getDimensionProjection({
|
|
55
|
+
return (0, exports.getDimensionProjection)({
|
|
77
56
|
key: member,
|
|
78
57
|
tableSchema,
|
|
79
58
|
modifiers: [],
|
|
80
|
-
query
|
|
59
|
+
query,
|
|
81
60
|
});
|
|
82
61
|
}
|
|
83
|
-
const isMeasure = (0,
|
|
62
|
+
const isMeasure = (0, find_in_table_schema_1.findInMeasureSchema)(memberWithoutTable, tableSchema);
|
|
84
63
|
if (isMeasure) {
|
|
85
|
-
return getFilterMeasureProjection({
|
|
86
|
-
key: member,
|
|
87
|
-
tableSchema,
|
|
88
|
-
measures
|
|
89
|
-
});
|
|
64
|
+
return (0, exports.getFilterMeasureProjection)({ key: member, tableSchema, measures });
|
|
90
65
|
}
|
|
91
66
|
return {
|
|
92
67
|
sql: undefined,
|
|
93
68
|
foundMember: undefined,
|
|
94
|
-
aliasKey: undefined
|
|
69
|
+
aliasKey: undefined,
|
|
95
70
|
};
|
|
96
71
|
};
|
|
97
|
-
const getAliasedColumnsFromFilters = ({ baseSql, meerkatFilters, tableSchema, aliasedColumnSet, query })=>{
|
|
72
|
+
const getAliasedColumnsFromFilters = ({ baseSql, meerkatFilters, tableSchema, aliasedColumnSet, query, }) => {
|
|
98
73
|
let sql = baseSql;
|
|
99
74
|
const { measures } = query;
|
|
100
|
-
meerkatFilters
|
|
75
|
+
meerkatFilters === null || meerkatFilters === void 0 ? void 0 : meerkatFilters.forEach((filter) => {
|
|
101
76
|
if ('and' in filter) {
|
|
102
77
|
// Traverse through the passed 'and' filters
|
|
103
|
-
sql += getAliasedColumnsFromFilters({
|
|
78
|
+
sql += (0, exports.getAliasedColumnsFromFilters)({
|
|
104
79
|
baseSql: '',
|
|
105
80
|
meerkatFilters: filter.and,
|
|
106
81
|
tableSchema,
|
|
107
82
|
aliasedColumnSet,
|
|
108
|
-
query
|
|
83
|
+
query,
|
|
109
84
|
});
|
|
110
85
|
}
|
|
111
86
|
if ('or' in filter) {
|
|
112
87
|
// Traverse through the passed 'or' filters
|
|
113
|
-
sql += getAliasedColumnsFromFilters({
|
|
88
|
+
sql += (0, exports.getAliasedColumnsFromFilters)({
|
|
114
89
|
baseSql: '',
|
|
115
90
|
tableSchema,
|
|
116
91
|
meerkatFilters: filter.or,
|
|
117
92
|
aliasedColumnSet,
|
|
118
|
-
query
|
|
93
|
+
query,
|
|
119
94
|
});
|
|
120
95
|
}
|
|
121
96
|
if ('member' in filter) {
|
|
122
|
-
const { aliasKey, foundMember, sql: memberSql } = getFilterProjections({
|
|
97
|
+
const { aliasKey, foundMember, sql: memberSql, } = getFilterProjections({
|
|
123
98
|
member: filter.member,
|
|
124
99
|
tableSchema,
|
|
125
100
|
measures,
|
|
126
|
-
query
|
|
101
|
+
query,
|
|
127
102
|
});
|
|
128
103
|
if (!foundMember || aliasedColumnSet.has(aliasKey)) {
|
|
129
104
|
// If the selected member is not found in the table schema or if it is already selected, continue.
|
|
@@ -138,5 +113,5 @@ const getAliasedColumnsFromFilters = ({ baseSql, meerkatFilters, tableSchema, al
|
|
|
138
113
|
});
|
|
139
114
|
return sql;
|
|
140
115
|
};
|
|
141
|
-
|
|
116
|
+
exports.getAliasedColumnsFromFilters = getAliasedColumnsFromFilters;
|
|
142
117
|
//# sourceMappingURL=get-aliased-columns-from-filters.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-aliased-columns-from-filters.js","sourceRoot":"","sources":["../../../../meerkat-core/src/get-wrapped-base-query-with-projections/get-aliased-columns-from-filters.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getProjectionClause = void 0;
|
|
4
|
+
const cube_measure_transformer_1 = require("../cube-measure-transformer/cube-measure-transformer");
|
|
5
|
+
const member_key_to_safe_key_1 = require("../member-formatters/member-key-to-safe-key");
|
|
6
|
+
const split_into_data_source_and_fields_1 = require("../member-formatters/split-into-data-source-and-fields");
|
|
7
|
+
const get_aliased_columns_from_filters_1 = require("./get-aliased-columns-from-filters");
|
|
8
|
+
const sql_expression_modifiers_1 = require("./sql-expression-modifiers");
|
|
9
|
+
const memberClauseAggregator = ({ member, aliasedColumnSet, acc, sql, }) => {
|
|
10
|
+
if (aliasedColumnSet.has(member) || !sql) {
|
|
11
|
+
return acc;
|
|
12
|
+
}
|
|
13
|
+
aliasedColumnSet.add(member);
|
|
14
|
+
acc.push(sql);
|
|
15
|
+
return acc;
|
|
16
|
+
};
|
|
17
|
+
const getProjectionClause = (query, tableSchema, aliasedColumnSet) => {
|
|
18
|
+
const { measures, dimensions = [] } = query;
|
|
19
|
+
const filteredDimensions = dimensions.filter((dimension) => {
|
|
20
|
+
const [dimensionDataSource] = (0, split_into_data_source_and_fields_1.splitIntoDataSourceAndFields)(dimension);
|
|
21
|
+
return dimensionDataSource === tableSchema.name;
|
|
22
|
+
});
|
|
23
|
+
const filteredMeasures = measures.filter((measure) => {
|
|
24
|
+
const [measureDataSource] = (0, split_into_data_source_and_fields_1.splitIntoDataSourceAndFields)(measure);
|
|
25
|
+
return measureDataSource === tableSchema.name;
|
|
26
|
+
});
|
|
27
|
+
const dimensionsProjectionsArr = filteredDimensions.reduce((acc, member, currentIndex, members) => {
|
|
28
|
+
const { sql: memberSql } = (0, get_aliased_columns_from_filters_1.getDimensionProjection)({
|
|
29
|
+
key: member,
|
|
30
|
+
tableSchema,
|
|
31
|
+
modifiers: sql_expression_modifiers_1.MODIFIERS,
|
|
32
|
+
query,
|
|
33
|
+
});
|
|
34
|
+
return memberClauseAggregator({
|
|
35
|
+
member: (0, member_key_to_safe_key_1.memberKeyToSafeKey)(member),
|
|
36
|
+
aliasedColumnSet,
|
|
37
|
+
acc,
|
|
38
|
+
currentIndex,
|
|
39
|
+
members,
|
|
40
|
+
sql: memberSql,
|
|
41
|
+
});
|
|
42
|
+
}, []);
|
|
43
|
+
const dimensionsProjections = dimensionsProjectionsArr.join(', ');
|
|
44
|
+
const measureProjectionsArr = filteredMeasures.reduce((acc, member, currentIndex, members) => {
|
|
45
|
+
const { sql: memberSql } = (0, get_aliased_columns_from_filters_1.getFilterMeasureProjection)({
|
|
46
|
+
key: member,
|
|
47
|
+
tableSchema,
|
|
48
|
+
measures,
|
|
49
|
+
});
|
|
50
|
+
return memberClauseAggregator({
|
|
51
|
+
member,
|
|
52
|
+
aliasedColumnSet,
|
|
53
|
+
acc,
|
|
54
|
+
currentIndex,
|
|
55
|
+
members,
|
|
56
|
+
sql: memberSql,
|
|
57
|
+
});
|
|
58
|
+
}, []);
|
|
59
|
+
const measureProjections = measureProjectionsArr.join(', ');
|
|
60
|
+
const usedMeasureObjects = tableSchema.measures.filter((measure) => {
|
|
61
|
+
return (measures.findIndex((key) => {
|
|
62
|
+
const [, keyWithoutTable] = (0, split_into_data_source_and_fields_1.splitIntoDataSourceAndFields)(key);
|
|
63
|
+
return keyWithoutTable === measure.name;
|
|
64
|
+
}) !== -1);
|
|
65
|
+
});
|
|
66
|
+
const columnsUsedInMeasures = (0, cube_measure_transformer_1.getAllColumnUsedInMeasures)(usedMeasureObjects, tableSchema);
|
|
67
|
+
let columnsUsedInMeasuresInProjection = '';
|
|
68
|
+
columnsUsedInMeasures.forEach((column, index) => {
|
|
69
|
+
const safeKey = (0, member_key_to_safe_key_1.memberKeyToSafeKey)(column);
|
|
70
|
+
columnsUsedInMeasuresInProjection += `${column} AS ${safeKey}`;
|
|
71
|
+
if (index !== columnsUsedInMeasures.length - 1) {
|
|
72
|
+
columnsUsedInMeasuresInProjection += ', ';
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
const combinedStr = [
|
|
76
|
+
dimensionsProjections,
|
|
77
|
+
measureProjections,
|
|
78
|
+
columnsUsedInMeasuresInProjection,
|
|
79
|
+
];
|
|
80
|
+
return combinedStr.filter((str) => str.length > 0).join(', ');
|
|
81
|
+
};
|
|
82
|
+
exports.getProjectionClause = getProjectionClause;
|
|
83
|
+
//# sourceMappingURL=get-projection-clause.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-projection-clause.js","sourceRoot":"","sources":["../../../../meerkat-core/src/get-wrapped-base-query-with-projections/get-projection-clause.ts"],"names":[],"mappings":"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"}
|
package/src/get-wrapped-base-query-with-projections/get-wrapped-base-query-with-projections.js
ADDED
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getWrappedBaseQueryWithProjections = void 0;
|
|
4
|
+
const cube_measure_transformer_1 = require("../cube-measure-transformer/cube-measure-transformer");
|
|
5
|
+
const get_aliased_columns_from_filters_1 = require("./get-aliased-columns-from-filters");
|
|
6
|
+
const get_projection_clause_1 = require("./get-projection-clause");
|
|
7
|
+
const getWrappedBaseQueryWithProjections = ({ baseQuery, tableSchema, query, }) => {
|
|
8
|
+
/*
|
|
9
|
+
* Im order to be able to filter on computed metric from a query, we need to project the computed metric in the base query.
|
|
10
|
+
* If theres filters supplied, we can safely return the original base query. Since nothing need to be projected and filtered in this case
|
|
11
|
+
*/
|
|
12
|
+
// Wrap the query into another 'SELECT * FROM (baseQuery) AS baseTable'' in order to project everything in the base query, and other computed metrics to be able to filter on them
|
|
13
|
+
const newBaseSql = `SELECT * FROM (${baseQuery}) AS ${tableSchema.name}`;
|
|
14
|
+
const aliasedColumnSet = new Set();
|
|
15
|
+
const memberProjections = (0, get_projection_clause_1.getProjectionClause)(query, tableSchema, aliasedColumnSet);
|
|
16
|
+
const aliasFromFilters = (0, get_aliased_columns_from_filters_1.getAliasedColumnsFromFilters)({
|
|
17
|
+
aliasedColumnSet,
|
|
18
|
+
baseSql: 'SELECT *',
|
|
19
|
+
// setting measures to empty array, since we don't want to project measures present in the filters in the base query
|
|
20
|
+
tableSchema: tableSchema,
|
|
21
|
+
query,
|
|
22
|
+
meerkatFilters: query.filters,
|
|
23
|
+
});
|
|
24
|
+
const formattedMemberProjection = memberProjections
|
|
25
|
+
? `, ${memberProjections}`
|
|
26
|
+
: '';
|
|
27
|
+
const finalAliasedColumnsClause = aliasFromFilters + formattedMemberProjection;
|
|
28
|
+
const sqlWithFilterProjects = (0, cube_measure_transformer_1.getSelectReplacedSql)(newBaseSql, finalAliasedColumnsClause);
|
|
29
|
+
return sqlWithFilterProjects;
|
|
30
|
+
};
|
|
31
|
+
exports.getWrappedBaseQueryWithProjections = getWrappedBaseQueryWithProjections;
|
|
32
|
+
//# sourceMappingURL=get-wrapped-base-query-with-projections.js.map
|
package/src/get-wrapped-base-query-with-projections/get-wrapped-base-query-with-projections.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-wrapped-base-query-with-projections.js","sourceRoot":"","sources":["../../../../meerkat-core/src/get-wrapped-base-query-with-projections/get-wrapped-base-query-with-projections.ts"],"names":[],"mappings":";;;AAAA,mGAA4F;AAE5F,yFAAkF;AAClF,mEAEiC;AAQ1B,MAAM,kCAAkC,GAAG,CAAC,EACjD,SAAS,EACT,WAAW,EACX,KAAK,GACoC,EAAE,EAAE;IAC7C;;;OAGG;IACH,kLAAkL;IAClL,MAAM,UAAU,GAAG,kBAAkB,SAAS,QAAQ,WAAW,CAAC,IAAI,EAAE,CAAC;IACzE,MAAM,gBAAgB,GAAG,IAAI,GAAG,EAAU,CAAC;IAE3C,MAAM,iBAAiB,GAAG,IAAA,2CAAmB,EAC3C,KAAK,EACL,WAAW,EACX,gBAAgB,CACjB,CAAC;IAEF,MAAM,gBAAgB,GAAG,IAAA,+DAA4B,EAAC;QACpD,gBAAgB;QAChB,OAAO,EAAE,UAAU;QACnB,oHAAoH;QACpH,WAAW,EAAE,WAAW;QACxB,KAAK;QACL,cAAc,EAAE,KAAK,CAAC,OAAO;KAC9B,CAAC,CAAC;IAEH,MAAM,yBAAyB,GAAG,iBAAiB;QACjD,CAAC,CAAC,KAAK,iBAAiB,EAAE;QAC1B,CAAC,CAAC,EAAE,CAAC;IAEP,MAAM,yBAAyB,GAC7B,gBAAgB,GAAG,yBAAyB,CAAC;IAE/C,MAAM,qBAAqB,GAAG,IAAA,+CAAoB,EAChD,UAAU,EACV,yBAAyB,CAC1B,CAAC;IACF,OAAO,qBAAqB,CAAC;AAC/B,CAAC,CAAC;AAxCW,QAAA,kCAAkC,sCAwC7C"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getModifiedSqlExpression = exports.MODIFIERS = exports.shouldUnnest = exports.arrayFieldUnNestModifier = void 0;
|
|
4
|
+
const is_array_member_type_1 = require("../utils/is-array-member-type");
|
|
5
|
+
const arrayFieldUnNestModifier = ({ sqlExpression }) => {
|
|
6
|
+
return `array[unnest(${sqlExpression})]`;
|
|
7
|
+
};
|
|
8
|
+
exports.arrayFieldUnNestModifier = arrayFieldUnNestModifier;
|
|
9
|
+
const shouldUnnest = ({ dimension, query }) => {
|
|
10
|
+
var _a;
|
|
11
|
+
const isArrayType = (0, is_array_member_type_1.isArrayTypeMember)(dimension.type);
|
|
12
|
+
const hasUnNestedGroupBy = (_a = dimension.modifier) === null || _a === void 0 ? void 0 : _a.shouldUnnestGroupBy;
|
|
13
|
+
return !!(isArrayType && hasUnNestedGroupBy && query.measures.length > 0);
|
|
14
|
+
};
|
|
15
|
+
exports.shouldUnnest = shouldUnnest;
|
|
16
|
+
exports.MODIFIERS = [{
|
|
17
|
+
name: 'shouldUnnestGroupBy',
|
|
18
|
+
matcher: exports.shouldUnnest,
|
|
19
|
+
modifier: exports.arrayFieldUnNestModifier
|
|
20
|
+
}];
|
|
21
|
+
const getModifiedSqlExpression = ({ sqlExpression, dimension, key, modifiers, query }) => {
|
|
22
|
+
let finalDimension = sqlExpression;
|
|
23
|
+
modifiers.forEach(({ modifier, matcher }) => {
|
|
24
|
+
const shouldModify = matcher({ sqlExpression: finalDimension, dimension, key, query });
|
|
25
|
+
if (shouldModify) {
|
|
26
|
+
finalDimension = modifier({ sqlExpression: finalDimension, dimension, key, query });
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
return finalDimension;
|
|
30
|
+
};
|
|
31
|
+
exports.getModifiedSqlExpression = getModifiedSqlExpression;
|
|
32
|
+
//# sourceMappingURL=sql-expression-modifiers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sql-expression-modifiers.js","sourceRoot":"","sources":["../../../../meerkat-core/src/get-wrapped-base-query-with-projections/sql-expression-modifiers.ts"],"names":[],"mappings":";;;AACA,wEAAkE;AAS3D,MAAM,wBAAwB,GAAG,CAAC,EAAE,aAAa,EAAqB,EAAU,EAAE;IACxF,OAAO,gBAAgB,aAAa,IAAI,CAAC;AAC1C,CAAC,CAAA;AAFY,QAAA,wBAAwB,4BAEpC;AAEM,MAAM,YAAY,GAAG,CAAC,EAAE,SAAS,EAAE,KAAK,EAAqB,EAAW,EAAE;;IAC/E,MAAM,WAAW,GAAI,IAAA,wCAAiB,EAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IACvD,MAAM,kBAAkB,GAAG,MAAA,SAAS,CAAC,QAAQ,0CAAE,mBAAmB,CAAC;IACnE,OAAO,CAAC,CAAC,CAAC,WAAW,IAAI,kBAAkB,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;AAC5E,CAAC,CAAA;AAJY,QAAA,YAAY,gBAIxB;AASY,QAAA,SAAS,GAAe,CAAC;QACpC,IAAI,EAAE,qBAAqB;QAC3B,OAAO,EAAE,oBAAY;QACrB,QAAQ,EAAE,gCAAwB;KACnC,CAAC,CAAA;AAGK,MAAM,wBAAwB,GAAG,CAAC,EAAE,aAAa,EAAE,SAAS,EAAE,GAAG,EAAE,SAAS,EAAE,KAAK,EAEzF,EAAE,EAAE;IACH,IAAI,cAAc,GAAW,aAAa,CAAC;IAC3C,SAAS,CAAC,OAAO,CAAC,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE,EAAE;QAC1C,MAAM,YAAY,GAAG,OAAO,CAAC,EAAE,aAAa,EAAE,cAAc,EAAE,SAAS,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC;QACvF,IAAI,YAAY,EAAE;YAChB,cAAc,GAAG,QAAQ,CAAC,EAAE,aAAa,EAAE,cAAc,EAAE,SAAS,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC;SACrF;IACH,CAAC,CAAC,CAAA;IACF,OAAO,cAAc,CAAC;AACxB,CAAC,CAAA;AAXY,QAAA,wBAAwB,4BAWpC"}
|
package/src/index.js
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.meerkatPlaceholderReplacer = exports.BASE_TABLE_NAME = exports.getWrappedBaseQueryWithProjections = exports.getFinalBaseSQL = exports.getFilterParamsSQL = exports.getFilterParamsAST = exports.detectAllFilterParamsFromSQL = exports.applyFilterParamsToBaseSQL = exports.detectApplyContextParamsToBaseSQL = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
tslib_1.__exportStar(require("./ast-builder/ast-builder"), exports);
|
|
6
|
+
tslib_1.__exportStar(require("./ast-deserializer/ast-deserializer"), exports);
|
|
7
|
+
tslib_1.__exportStar(require("./ast-serializer/ast-serializer"), exports);
|
|
8
|
+
tslib_1.__exportStar(require("./ast-validator"), exports);
|
|
9
|
+
var context_params_ast_1 = require("./context-params/context-params-ast");
|
|
10
|
+
Object.defineProperty(exports, "detectApplyContextParamsToBaseSQL", { enumerable: true, get: function () { return context_params_ast_1.detectApplyContextParamsToBaseSQL; } });
|
|
11
|
+
tslib_1.__exportStar(require("./cube-measure-transformer/cube-measure-transformer"), exports);
|
|
12
|
+
tslib_1.__exportStar(require("./cube-to-duckdb/cube-filter-to-duckdb"), exports);
|
|
13
|
+
var filter_params_ast_1 = require("./filter-params/filter-params-ast");
|
|
14
|
+
Object.defineProperty(exports, "applyFilterParamsToBaseSQL", { enumerable: true, get: function () { return filter_params_ast_1.applyFilterParamsToBaseSQL; } });
|
|
15
|
+
Object.defineProperty(exports, "detectAllFilterParamsFromSQL", { enumerable: true, get: function () { return filter_params_ast_1.detectAllFilterParamsFromSQL; } });
|
|
16
|
+
Object.defineProperty(exports, "getFilterParamsAST", { enumerable: true, get: function () { return filter_params_ast_1.getFilterParamsAST; } });
|
|
17
|
+
var get_filter_params_sql_1 = require("./get-filter-params-sql/get-filter-params-sql");
|
|
18
|
+
Object.defineProperty(exports, "getFilterParamsSQL", { enumerable: true, get: function () { return get_filter_params_sql_1.getFilterParamsSQL; } });
|
|
19
|
+
var get_final_base_sql_1 = require("./get-final-base-sql/get-final-base-sql");
|
|
20
|
+
Object.defineProperty(exports, "getFinalBaseSQL", { enumerable: true, get: function () { return get_final_base_sql_1.getFinalBaseSQL; } });
|
|
21
|
+
var get_wrapped_base_query_with_projections_1 = require("./get-wrapped-base-query-with-projections/get-wrapped-base-query-with-projections");
|
|
22
|
+
Object.defineProperty(exports, "getWrappedBaseQueryWithProjections", { enumerable: true, get: function () { return get_wrapped_base_query_with_projections_1.getWrappedBaseQueryWithProjections; } });
|
|
23
|
+
tslib_1.__exportStar(require("./joins/joins"), exports);
|
|
24
|
+
tslib_1.__exportStar(require("./member-formatters"), exports);
|
|
25
|
+
tslib_1.__exportStar(require("./resolution/resolution"), exports);
|
|
26
|
+
tslib_1.__exportStar(require("./resolution/types"), exports);
|
|
27
|
+
tslib_1.__exportStar(require("./types/cube-types/index"), exports);
|
|
28
|
+
tslib_1.__exportStar(require("./types/duckdb-serialization-types/index"), exports);
|
|
29
|
+
tslib_1.__exportStar(require("./types/utils"), exports);
|
|
30
|
+
var base_ast_1 = require("./utils/base-ast");
|
|
31
|
+
Object.defineProperty(exports, "BASE_TABLE_NAME", { enumerable: true, get: function () { return base_ast_1.BASE_TABLE_NAME; } });
|
|
32
|
+
tslib_1.__exportStar(require("./utils/cube-to-table-schema"), exports);
|
|
33
|
+
tslib_1.__exportStar(require("./utils/get-column-names-from-ast"), exports);
|
|
34
|
+
tslib_1.__exportStar(require("./utils/get-possible-nodes"), exports);
|
|
35
|
+
var meerkat_placeholder_replacer_1 = require("./utils/meerkat-placeholder-replacer");
|
|
36
|
+
Object.defineProperty(exports, "meerkatPlaceholderReplacer", { enumerable: true, get: function () { return meerkat_placeholder_replacer_1.meerkatPlaceholderReplacer; } });
|
|
37
|
+
//# sourceMappingURL=index.js.map
|
package/src/index.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../meerkat-core/src/index.ts"],"names":[],"mappings":";;;;AAAA,oEAA0C;AAC1C,8EAAoD;AACpD,0EAAgD;AAChD,0DAAgC;AAChC,0EAAwF;AAA/E,uIAAA,iCAAiC,OAAA;AAC1C,8FAAoE;AACpE,iFAAuD;AACvD,uEAI2C;AAHzC,+HAAA,0BAA0B,OAAA;AAC1B,iIAAA,4BAA4B,OAAA;AAC5B,uHAAA,kBAAkB,OAAA;AAEpB,uFAAmF;AAA1E,2HAAA,kBAAkB,OAAA;AAC3B,8EAA0E;AAAjE,qHAAA,eAAe,OAAA;AACxB,6IAAuI;AAA9H,6JAAA,kCAAkC,OAAA;AAC3C,wDAA8B;AAC9B,8DAAoC;AACpC,kEAAwC;AACxC,6DAAmC;AAEnC,mEAAyC;AACzC,mFAAyD;AACzD,wDAA8B;AAC9B,6CAAmD;AAA1C,2GAAA,eAAe,OAAA;AACxB,uEAA6C;AAC7C,4EAAkD;AAClD,qEAA2C;AAC3C,qFAAkF;AAAzE,0IAAA,0BAA0B,OAAA"}
|
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getCombinedTableSchema = exports.checkLoopInJoinPath = exports.createDirectedGraph = exports.generateSqlQuery = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const cube_types_1 = require("../types/cube-types");
|
|
6
|
+
function generateSqlQuery(path, tableSchemaSqlMap, directedGraph) {
|
|
7
|
+
if (path.length === 0) {
|
|
8
|
+
throw new Error('Invalid path, multiple data sources are present without a join path.');
|
|
9
|
+
}
|
|
10
|
+
const startingNode = path[0][0].left;
|
|
11
|
+
let query = `${tableSchemaSqlMap[startingNode]}`;
|
|
12
|
+
/**
|
|
13
|
+
* If the starting node is not a join node, then return the query as is.
|
|
14
|
+
* It means that the query is a single node query.
|
|
15
|
+
*/
|
|
16
|
+
if (!(0, cube_types_1.isJoinNode)(path[0][0])) {
|
|
17
|
+
return query;
|
|
18
|
+
}
|
|
19
|
+
const visitedNodes = new Map();
|
|
20
|
+
for (let i = 0; i < path.length; i++) {
|
|
21
|
+
if (path[i][0].left !== startingNode) {
|
|
22
|
+
throw new Error('Invalid path, starting node is not the same for all paths.');
|
|
23
|
+
}
|
|
24
|
+
for (let j = 0; j < path[i].length; j++) {
|
|
25
|
+
const currentEdge = path[i][j];
|
|
26
|
+
if (!(0, cube_types_1.isJoinNode)(currentEdge)) {
|
|
27
|
+
continue;
|
|
28
|
+
}
|
|
29
|
+
const visitedFrom = visitedNodes.get(currentEdge.right);
|
|
30
|
+
// If node is already visited from the same edge, continue to next iteration
|
|
31
|
+
if (visitedFrom && visitedFrom.left === currentEdge.left) {
|
|
32
|
+
continue;
|
|
33
|
+
}
|
|
34
|
+
// If node is already visited from a different edge, throw ambiguity error
|
|
35
|
+
if (visitedFrom) {
|
|
36
|
+
throw new Error(`Path ambiguity, node ${currentEdge.right} visited from different sources`);
|
|
37
|
+
}
|
|
38
|
+
// If visitedFrom is undefined, this is the first visit to the node
|
|
39
|
+
visitedNodes.set(currentEdge.right, currentEdge);
|
|
40
|
+
query += ` LEFT JOIN (${tableSchemaSqlMap[currentEdge.right]}) AS ${currentEdge.right} ON ${directedGraph[currentEdge.left][currentEdge.right][currentEdge.on]}`;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
return query;
|
|
44
|
+
}
|
|
45
|
+
exports.generateSqlQuery = generateSqlQuery;
|
|
46
|
+
const createDirectedGraph = (tableSchema, tableSchemaSqlMap) => {
|
|
47
|
+
const directedGraph = {};
|
|
48
|
+
function addEdge(table1, table2, joinOn, joinCondition) {
|
|
49
|
+
if (table1 === table2 ||
|
|
50
|
+
(directedGraph[table1] &&
|
|
51
|
+
directedGraph[table1][table2] &&
|
|
52
|
+
directedGraph[table1][table2][joinOn])) {
|
|
53
|
+
throw new Error('An invalid path was detected.');
|
|
54
|
+
}
|
|
55
|
+
if (!directedGraph[table1])
|
|
56
|
+
directedGraph[table1] = {};
|
|
57
|
+
if (!directedGraph[table1][table2])
|
|
58
|
+
directedGraph[table1][table2] = {};
|
|
59
|
+
directedGraph[table1][table2][joinOn] = joinCondition;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Iterate through the table schema and add the edges to the directed graph.
|
|
63
|
+
* The edges are added based on the join conditions provided in the table schema.
|
|
64
|
+
* The SQL is split by the '=' sign and the tables columns involved in the joins are extracted.
|
|
65
|
+
* The tables are then added as edges to the directed graph.
|
|
66
|
+
*/
|
|
67
|
+
tableSchema.forEach((schema) => {
|
|
68
|
+
var _a;
|
|
69
|
+
(_a = schema === null || schema === void 0 ? void 0 : schema.joins) === null || _a === void 0 ? void 0 : _a.forEach((join) => {
|
|
70
|
+
const tables = join.sql.split('=').map((str) => str.split('.')[0].trim());
|
|
71
|
+
const conditions = join.sql
|
|
72
|
+
.split('=')
|
|
73
|
+
.map((str) => str.split('.')[1].trim());
|
|
74
|
+
/**
|
|
75
|
+
* If the join SQL does not contain exactly 2 tables, then the join is invalid.
|
|
76
|
+
*/
|
|
77
|
+
if (tables.length !== 2) {
|
|
78
|
+
throw new Error(`Invalid join SQL: ${join.sql}`);
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* If the tables are the same, then the join is invalid.
|
|
82
|
+
*/
|
|
83
|
+
if (tables[0] === tables[1]) {
|
|
84
|
+
throw new Error(`Invalid join SQL: ${join.sql}`);
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* If the tables are not found in the table schema, then the join is invalid.
|
|
88
|
+
*/
|
|
89
|
+
if (tables[0] !== schema.name && tables[1] !== schema.name) {
|
|
90
|
+
throw new Error(`Table "${schema.name}" not found in provided join SQL: ${join.sql}`);
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Check if the tables are found in the table schema SQL map.
|
|
94
|
+
*/
|
|
95
|
+
if (!tableSchemaSqlMap[tables[0]] || !tableSchemaSqlMap[tables[1]]) {
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* If the table is the source table, then add the edge from the source to the target.
|
|
100
|
+
* Thus find which table is the source and which is the target and add the edge accordingly.
|
|
101
|
+
*/
|
|
102
|
+
if (tables[0] === schema.name) {
|
|
103
|
+
addEdge(tables[0], tables[1], conditions[0], join.sql);
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
addEdge(tables[1], tables[0], conditions[1], join.sql);
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
return directedGraph;
|
|
111
|
+
};
|
|
112
|
+
exports.createDirectedGraph = createDirectedGraph;
|
|
113
|
+
const checkLoopInJoinPath = (joinPath) => {
|
|
114
|
+
for (let i = 0; i < joinPath.length; i++) {
|
|
115
|
+
const visitedNodes = new Set();
|
|
116
|
+
const currentJoinPath = joinPath[i];
|
|
117
|
+
visitedNodes.add(currentJoinPath[0].left);
|
|
118
|
+
for (let j = 0; j < currentJoinPath.length; j++) {
|
|
119
|
+
const currentEdge = currentJoinPath[j];
|
|
120
|
+
if ((0, cube_types_1.isJoinNode)(currentEdge) && visitedNodes.has(currentEdge.right)) {
|
|
121
|
+
if (visitedNodes.has(currentEdge.right)) {
|
|
122
|
+
return true;
|
|
123
|
+
}
|
|
124
|
+
visitedNodes.add(currentEdge.right);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
return false;
|
|
129
|
+
};
|
|
130
|
+
exports.checkLoopInJoinPath = checkLoopInJoinPath;
|
|
131
|
+
const getCombinedTableSchema = (tableSchema, cubeQuery) => tslib_1.__awaiter(void 0, void 0, void 0, function* () {
|
|
132
|
+
if (tableSchema.length === 1) {
|
|
133
|
+
return tableSchema[0];
|
|
134
|
+
}
|
|
135
|
+
const tableSchemaSqlMap = tableSchema.reduce((acc, schema) => {
|
|
136
|
+
return Object.assign(Object.assign({}, acc), { [schema.name]: schema.sql });
|
|
137
|
+
}, {});
|
|
138
|
+
const directedGraph = (0, exports.createDirectedGraph)(tableSchema, tableSchemaSqlMap);
|
|
139
|
+
const hasLoop = (0, exports.checkLoopInJoinPath)(cubeQuery.joinPaths || []);
|
|
140
|
+
if (hasLoop) {
|
|
141
|
+
throw new Error(`A loop was detected in the joins. ${JSON.stringify(cubeQuery.joinPaths || [])}`);
|
|
142
|
+
}
|
|
143
|
+
const baseSql = generateSqlQuery(cubeQuery.joinPaths || [], tableSchemaSqlMap, directedGraph);
|
|
144
|
+
const combinedTableSchema = tableSchema.reduce((acc, schema) => {
|
|
145
|
+
return {
|
|
146
|
+
name: 'MEERKAT_GENERATED_TABLE',
|
|
147
|
+
sql: baseSql,
|
|
148
|
+
measures: [...acc.measures, ...schema.measures],
|
|
149
|
+
dimensions: [...acc.dimensions, ...schema.dimensions],
|
|
150
|
+
joins: [],
|
|
151
|
+
};
|
|
152
|
+
}, {
|
|
153
|
+
name: '',
|
|
154
|
+
sql: '',
|
|
155
|
+
measures: [],
|
|
156
|
+
dimensions: [],
|
|
157
|
+
joins: [],
|
|
158
|
+
});
|
|
159
|
+
return combinedTableSchema;
|
|
160
|
+
});
|
|
161
|
+
exports.getCombinedTableSchema = getCombinedTableSchema;
|
|
162
|
+
//# sourceMappingURL=joins.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"joins.js","sourceRoot":"","sources":["../../../../meerkat-core/src/joins/joins.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MEERKAT_OUTPUT_DELIMITER = exports.COLUMN_NAME_DELIMITER = void 0;
|
|
4
|
+
exports.COLUMN_NAME_DELIMITER = '.';
|
|
5
|
+
exports.MEERKAT_OUTPUT_DELIMITER = '__';
|
|
6
|
+
//# sourceMappingURL=constants.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../meerkat-core/src/member-formatters/constants.ts"],"names":[],"mappings":";;;AAAa,QAAA,qBAAqB,GAAG,GAAG,CAAC;AAC5B,QAAA,wBAAwB,GAAG,IAAI,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.splitIntoDataSourceAndFields = exports.memberKeyToSafeKey = exports.COLUMN_NAME_DELIMITER = void 0;
|
|
4
|
+
var constants_1 = require("./constants");
|
|
5
|
+
Object.defineProperty(exports, "COLUMN_NAME_DELIMITER", { enumerable: true, get: function () { return constants_1.COLUMN_NAME_DELIMITER; } });
|
|
6
|
+
var member_key_to_safe_key_1 = require("./member-key-to-safe-key");
|
|
7
|
+
Object.defineProperty(exports, "memberKeyToSafeKey", { enumerable: true, get: function () { return member_key_to_safe_key_1.memberKeyToSafeKey; } });
|
|
8
|
+
var split_into_data_source_and_fields_1 = require("./split-into-data-source-and-fields");
|
|
9
|
+
Object.defineProperty(exports, "splitIntoDataSourceAndFields", { enumerable: true, get: function () { return split_into_data_source_and_fields_1.splitIntoDataSourceAndFields; } });
|
|
10
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../meerkat-core/src/member-formatters/index.ts"],"names":[],"mappings":";;;AAAA,yCAAoD;AAA3C,kHAAA,qBAAqB,OAAA;AAC9B,mEAA8D;AAArD,4HAAA,kBAAkB,OAAA;AAC3B,yFAAmF;AAA1E,iJAAA,4BAA4B,OAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.memberKeyToSafeKey = void 0;
|
|
4
|
+
const constants_1 = require("./constants");
|
|
5
|
+
const memberKeyToSafeKey = (memberKey) => {
|
|
6
|
+
return memberKey.split(constants_1.COLUMN_NAME_DELIMITER).join(constants_1.MEERKAT_OUTPUT_DELIMITER);
|
|
7
|
+
};
|
|
8
|
+
exports.memberKeyToSafeKey = memberKeyToSafeKey;
|
|
9
|
+
//# sourceMappingURL=member-key-to-safe-key.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"member-key-to-safe-key.js","sourceRoot":"","sources":["../../../../meerkat-core/src/member-formatters/member-key-to-safe-key.ts"],"names":[],"mappings":";;;AAAA,2CAA8E;AAEvE,MAAM,kBAAkB,GAAG,CAAC,SAAiB,EAAE,EAAE;IACtD,OAAO,SAAS,CAAC,KAAK,CAAC,iCAAqB,CAAC,CAAC,IAAI,CAAC,oCAAwB,CAAC,CAAC;AAC/E,CAAC,CAAC;AAFW,QAAA,kBAAkB,sBAE7B"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.splitIntoDataSourceAndFields = void 0;
|
|
4
|
+
const constants_1 = require("./constants");
|
|
5
|
+
const splitIntoDataSourceAndFields = (member) => {
|
|
6
|
+
const [dataSource, ...fields] = member.split(constants_1.COLUMN_NAME_DELIMITER);
|
|
7
|
+
return [dataSource, fields.join(constants_1.COLUMN_NAME_DELIMITER)];
|
|
8
|
+
};
|
|
9
|
+
exports.splitIntoDataSourceAndFields = splitIntoDataSourceAndFields;
|
|
10
|
+
//# sourceMappingURL=split-into-data-source-and-fields.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"split-into-data-source-and-fields.js","sourceRoot":"","sources":["../../../../meerkat-core/src/member-formatters/split-into-data-source-and-fields.ts"],"names":[],"mappings":";;;AAAA,2CAAoD;AAE7C,MAAM,4BAA4B,GAAG,CAAC,MAAc,EAAE,EAAE;IAC7D,MAAM,CAAC,UAAU,EAAE,GAAG,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,iCAAqB,CAAC,CAAC;IACpE,OAAO,CAAC,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,iCAAqB,CAAC,CAAC,CAAC;AAC1D,CAAC,CAAC;AAHW,QAAA,4BAA4B,gCAGvC"}
|