mirror of
https://github.com/apache/superset.git
synced 2024-09-19 12:09:42 -04:00
e2a429b0c8
* add support for adhoc columns to api and sqla model * fix some types * fix duplicates in column names * fix more lint * fix schema and dedup * clean up some logic * first pass at fixing viz.py * Add frontend support for adhoc columns * Add title edit * Fix showing custom title * Use column name as default value in sql editor * fix: Adds a loading message when needed in the Select component (#16531) * fix(tests): make parquet select deterministic with order by (#16570) * bump emotion to help with cache clobbering (#16559) * fix: Support Jinja template functions in global async queries (#16412) * Support Jinja template functions in async queries * Pylint * Add tests for async tasks * Remove redundant has_request_context check * fix: impersonate user label/tooltip (#16573) * docs: update for small typos (#16568) * feat: Add Aurora Data API engine spec (#16535) * feat: Add Aurora Data API engine spec * Fix lint * refactor: sql_json view endpoint: encapsulate ctas parameters (#16548) * refactor sql_json view endpoint: encapsulate ctas parameters * fix failed tests * fix failed tests and ci issues * refactor sql_json view endpoint: separate concern into ad hod method (#16595) * feat: Experimental cross-filter plugins (#16594) * fix:fix get permission function * feat: add cross filter chart in charts gallery under FF * chore(deps): bump superset-ui to 0.18.2 (#16601) * update type guard references * fix imports * update series_columns schema * Add changes that got lost in rebase * Use current columns name or expression as sql editor init value * add integration test and do minor fixes * Bump superset-ui * fix linting issue * bump superset-ui to 0.18.22 * resolve merge conflict * lint * fix select filter infinite loop * bump superset-ui to 0.18.23 * Fix auto setting column popover title * Enable adhoc columns only if UX_BETA enabled * put back removed test * Move popover height and width to constants * Refactor big ternary expression Co-authored-by: Kamil Gabryjelski <kamil.gabryjelski@gmail.com> Co-authored-by: Michael S. Molina <70410625+michael-s-molina@users.noreply.github.com> Co-authored-by: Elizabeth Thompson <eschutho@gmail.com> Co-authored-by: Rob DiCiuccio <rob.diciuccio@gmail.com> Co-authored-by: Beto Dealmeida <roberto@dealmeida.net> Co-authored-by: joeADSP <75027008+joeADSP@users.noreply.github.com> Co-authored-by: ofekisr <35701650+ofekisr@users.noreply.github.com> Co-authored-by: simcha90 <56388545+simcha90@users.noreply.github.com>
100 lines
2.8 KiB
Python
100 lines
2.8 KiB
Python
# Licensed to the Apache Software Foundation (ASF) under one
|
|
# or more contributor license agreements. See the NOTICE file
|
|
# distributed with this work for additional information
|
|
# regarding copyright ownership. The ASF licenses this file
|
|
# to you under the Apache License, Version 2.0 (the
|
|
# "License"); you may not use this file except in compliance
|
|
# with the License. You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing,
|
|
# software distributed under the License is distributed on an
|
|
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
# KIND, either express or implied. See the License for the
|
|
# specific language governing permissions and limitations
|
|
# under the License.
|
|
from datetime import datetime
|
|
from typing import (
|
|
Any,
|
|
Callable,
|
|
Dict,
|
|
List,
|
|
Optional,
|
|
Sequence,
|
|
Tuple,
|
|
TYPE_CHECKING,
|
|
Union,
|
|
)
|
|
|
|
from flask import Flask
|
|
from flask_caching import Cache
|
|
from typing_extensions import Literal, TypedDict
|
|
from werkzeug.wrappers import Response
|
|
|
|
if TYPE_CHECKING:
|
|
from superset.utils.core import GenericDataType
|
|
|
|
|
|
class LegacyMetric(TypedDict):
|
|
label: Optional[str]
|
|
|
|
|
|
class AdhocMetricColumn(TypedDict, total=False):
|
|
column_name: Optional[str]
|
|
description: Optional[str]
|
|
expression: Optional[str]
|
|
filterable: bool
|
|
groupby: bool
|
|
id: int
|
|
is_dttm: bool
|
|
python_date_format: Optional[str]
|
|
type: str
|
|
type_generic: "GenericDataType"
|
|
verbose_name: Optional[str]
|
|
|
|
|
|
class AdhocMetric(TypedDict, total=False):
|
|
aggregate: str
|
|
column: Optional[AdhocMetricColumn]
|
|
expressionType: Literal["SIMPLE", "SQL"]
|
|
hasCustomLabel: Optional[bool]
|
|
label: Optional[str]
|
|
sqlExpression: Optional[str]
|
|
|
|
|
|
class AdhocColumn(TypedDict, total=False):
|
|
hasCustomLabel: Optional[bool]
|
|
label: Optional[str]
|
|
sqlExpression: Optional[str]
|
|
|
|
|
|
CacheConfig = Union[Callable[[Flask], Cache], Dict[str, Any]]
|
|
DbapiDescriptionRow = Tuple[
|
|
str, str, Optional[str], Optional[str], Optional[int], Optional[int], bool
|
|
]
|
|
DbapiDescription = Union[List[DbapiDescriptionRow], Tuple[DbapiDescriptionRow, ...]]
|
|
DbapiResult = Sequence[Union[List[Any], Tuple[Any, ...]]]
|
|
FilterValue = Union[bool, datetime, float, int, str]
|
|
FilterValues = Union[FilterValue, List[FilterValue], Tuple[FilterValue]]
|
|
FormData = Dict[str, Any]
|
|
Granularity = Union[str, Dict[str, Union[str, float]]]
|
|
Column = Union[AdhocColumn, str]
|
|
Metric = Union[AdhocMetric, str]
|
|
OrderBy = Tuple[Metric, bool]
|
|
QueryObjectDict = Dict[str, Any]
|
|
VizData = Optional[Union[List[Any], Dict[Any, Any]]]
|
|
VizPayload = Dict[str, Any]
|
|
|
|
# Flask response.
|
|
Base = Union[bytes, str]
|
|
Status = Union[int, str]
|
|
Headers = Dict[str, Any]
|
|
FlaskResponse = Union[
|
|
Response,
|
|
Base,
|
|
Tuple[Base, Status],
|
|
Tuple[Base, Status, Headers],
|
|
Tuple[Response, Status],
|
|
]
|