@devrev/meerkat-core 0.0.78 → 0.0.79
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/package.json
CHANGED
|
@@ -22,19 +22,10 @@ type MemberType = 'measures' | 'dimensions' | 'segments';
|
|
|
22
22
|
* Member identifier. Should satisfy to the following regexp: /^[a-zA-Z0-9_]+\.[a-zA-Z0-9_]+$/
|
|
23
23
|
*/
|
|
24
24
|
type Member = string;
|
|
25
|
-
/**
|
|
26
|
-
* Datetime member identifier. Should satisfy to the following
|
|
27
|
-
* regexp: /^[a-zA-Z0-9_]+\.[a-zA-Z0-9_]+(\.(second|minute|hour|day|week|month|year))?$/
|
|
28
|
-
*/
|
|
29
|
-
type TimeMember = string;
|
|
30
25
|
/**
|
|
31
26
|
* Filter operator string.
|
|
32
27
|
*/
|
|
33
28
|
type FilterOperator = 'equals' | 'notEquals' | 'contains' | 'notContains' | 'in' | 'notIn' | 'gt' | 'gte' | 'lt' | 'lte' | 'set' | 'notSet' | 'inDateRange' | 'notInDateRange' | 'onTheDate' | 'beforeDate' | 'afterDate' | 'measureFilter';
|
|
34
|
-
/**
|
|
35
|
-
* Time dimension granularity data type.
|
|
36
|
-
*/
|
|
37
|
-
type QueryTimeDimensionGranularity = 'quarter' | 'day' | 'month' | 'year' | 'week' | 'hour' | 'minute' | 'second';
|
|
38
29
|
/**
|
|
39
30
|
* Query order data type.
|
|
40
31
|
*/
|
|
@@ -63,14 +54,6 @@ type LogicalAndFilter = {
|
|
|
63
54
|
type LogicalOrFilter = {
|
|
64
55
|
or: (QueryFilter | LogicalAndFilter)[];
|
|
65
56
|
};
|
|
66
|
-
/**
|
|
67
|
-
* Query datetime dimention interface.
|
|
68
|
-
*/
|
|
69
|
-
interface QueryTimeDimension {
|
|
70
|
-
dimension: Member;
|
|
71
|
-
dateRange?: string[] | string;
|
|
72
|
-
granularity?: QueryTimeDimensionGranularity;
|
|
73
|
-
}
|
|
74
57
|
/**
|
|
75
58
|
* Join Edge data type.
|
|
76
59
|
*/
|
|
@@ -106,36 +89,11 @@ export declare const isJoinNode: (node: JoinNode | SingleNode) => node is JoinNo
|
|
|
106
89
|
type MeerkatQueryFilter = QueryFilter | LogicalAndFilter | LogicalOrFilter;
|
|
107
90
|
interface Query {
|
|
108
91
|
measures: Member[];
|
|
109
|
-
dimensions?:
|
|
92
|
+
dimensions?: Member[];
|
|
110
93
|
filters?: MeerkatQueryFilter[];
|
|
111
|
-
timeDimensions?: QueryTimeDimension[];
|
|
112
94
|
joinPaths?: JoinPath[];
|
|
113
|
-
segments?: Member[];
|
|
114
95
|
limit?: null | number;
|
|
115
96
|
offset?: number;
|
|
116
|
-
|
|
117
|
-
totalQuery?: boolean;
|
|
118
|
-
order?: any;
|
|
119
|
-
timezone?: string;
|
|
120
|
-
renewQuery?: boolean;
|
|
121
|
-
ungrouped?: boolean;
|
|
122
|
-
responseFormat?: ResultType;
|
|
123
|
-
}
|
|
124
|
-
/**
|
|
125
|
-
* Normalized filter interface.
|
|
126
|
-
*/
|
|
127
|
-
interface NormalizedQueryFilter extends QueryFilter {
|
|
128
|
-
dimension?: Member;
|
|
129
|
-
}
|
|
130
|
-
/**
|
|
131
|
-
* Normalized query interface.
|
|
132
|
-
*/
|
|
133
|
-
interface NormalizedQuery extends Query {
|
|
134
|
-
filters?: NormalizedQueryFilter[];
|
|
135
|
-
rowLimit?: null | number;
|
|
136
|
-
order?: [{
|
|
137
|
-
id: string;
|
|
138
|
-
desc: boolean;
|
|
139
|
-
}];
|
|
97
|
+
order?: Record<string, QueryOrderType>;
|
|
140
98
|
}
|
|
141
|
-
export { ApiScopes, ApiType, FilterOperator, JoinPath, LogicalAndFilter, LogicalOrFilter, MeerkatQueryFilter, Member, MemberType,
|
|
99
|
+
export { ApiScopes, ApiType, FilterOperator, JoinPath, LogicalAndFilter, LogicalOrFilter, MeerkatQueryFilter, Member, MemberType, Query, QueryFilter, QueryOrderType, QueryType, RequestType, ResultType };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../meerkat-core/src/types/cube-types/query.ts"],"sourcesContent":["/**\n * Request type data type.\n */\ntype RequestType = 'multi';\n\n/**\n * Result type data type.\n */\ntype ResultType = 'default' | 'compact';\n\n/**\n * API type data type.\n */\ntype ApiType = 'sql' | 'graphql' | 'rest' | 'ws' | 'stream';\n\n/**\n * Parsed query type data type.\n */\ntype QueryType = 'regularQuery' | 'compareDateRangeQuery' | 'blendingQuery';\n\n/**\n * String that represent query member type.\n */\ntype MemberType = 'measures' | 'dimensions' | 'segments';\n\n/**\n * Member identifier. Should satisfy to the following regexp: /^[a-zA-Z0-9_]+\\.[a-zA-Z0-9_]+$/\n */\ntype Member = string;\n\n
|
|
1
|
+
{"version":3,"sources":["../../../../../meerkat-core/src/types/cube-types/query.ts"],"sourcesContent":["/**\n * Request type data type.\n */\ntype RequestType = 'multi';\n\n/**\n * Result type data type.\n */\ntype ResultType = 'default' | 'compact';\n\n/**\n * API type data type.\n */\ntype ApiType = 'sql' | 'graphql' | 'rest' | 'ws' | 'stream';\n\n/**\n * Parsed query type data type.\n */\ntype QueryType = 'regularQuery' | 'compareDateRangeQuery' | 'blendingQuery';\n\n/**\n * String that represent query member type.\n */\ntype MemberType = 'measures' | 'dimensions' | 'segments';\n\n/**\n * Member identifier. Should satisfy to the following regexp: /^[a-zA-Z0-9_]+\\.[a-zA-Z0-9_]+$/\n */\ntype Member = string;\n\n\n/**\n * Filter operator string.\n */\ntype FilterOperator =\n | 'equals'\n | 'notEquals'\n | 'contains'\n | 'notContains'\n | 'in'\n | 'notIn'\n | 'gt'\n | 'gte'\n | 'lt'\n | 'lte'\n | 'set'\n | 'notSet'\n | 'inDateRange'\n | 'notInDateRange'\n | 'onTheDate'\n | 'beforeDate'\n | 'afterDate'\n | 'measureFilter';\n\n/**\n * Query order data type.\n */\ntype QueryOrderType = 'asc' | 'desc';\n\n/**\n * ApiScopes data type.\n */\ntype ApiScopes = 'graphql' | 'meta' | 'data' | 'jobs';\n\nexport type FilterType = 'BASE_FILTER' | 'PROJECTION_FILTER';\n\ninterface QueryFilter {\n member: Member;\n operator: FilterOperator;\n values?: string[];\n}\n\n/**\n * Query 'and'-filters type definition.\n */\ntype LogicalAndFilter = {\n and: (QueryFilter | { or: (QueryFilter | LogicalAndFilter)[] })[];\n};\n\n/**\n * Query 'or'-filters type definition.\n */\ntype LogicalOrFilter = {\n or: (QueryFilter | LogicalAndFilter)[];\n};\n\n\n/**\n * Join Edge data type.\n */\n\ninterface JoinNode {\n /**\n * Left node.\n */\n left: Member;\n\n /**\n * Right node.\n */\n right: Member;\n\n /**\n * On condition.\n */\n on: string;\n\n /**\n * Example\n * [\n * [\n * {\n * left: dim_ticket,\n * right: dim_user\n * on: 'created_by_id'\n * },\n * {\n * left : dim_user,\n * right: dim_user_role,\n * on: 'role_id'\n * }\n * ]\n * ]\n *\n *\n */\n}\n\n/**\n * Single node data type.\n * This is the case when there is no join. Just a single node.\n */\ninterface SingleNode {\n /**\n * Left node.\n */\n left: Member;\n}\n\ntype JoinPath = [JoinNode | SingleNode, ...JoinNode[]];\n\nexport const isJoinNode = (node: JoinNode | SingleNode): node is JoinNode => {\n return 'right' in node;\n};\n\n/**\n * Incoming network query data type.\n */\n\ntype MeerkatQueryFilter = QueryFilter | LogicalAndFilter | LogicalOrFilter;\n\ninterface Query {\n measures: Member[];\n dimensions?: Member[];\n filters?: MeerkatQueryFilter[];\n joinPaths?: JoinPath[];\n limit?: null | number;\n offset?: number;\n order?: Record<string, QueryOrderType>;\n}\n\n\nexport {\n ApiScopes,\n ApiType,\n FilterOperator,\n JoinPath,\n LogicalAndFilter,\n LogicalOrFilter,\n MeerkatQueryFilter,\n Member,\n MemberType,\n Query,\n QueryFilter,\n QueryOrderType,\n QueryType,\n RequestType,\n ResultType\n};\n"],"names":["isJoinNode","node"],"mappings":"AAAA;;CAEC;+BA2IYA;;;eAAAA;;;AAAN,MAAMA,aAAa,CAACC;IACzB,OAAO,WAAWA;AACpB"}
|