Module preprocessor.report_parameters

Classes

class ParameterConstraint (options: List[ParameterOption] | None = None, min_value: int | float | None = None, max_value: int | float | None = None, datetime_format: str | None = None, code_systems: List[str] = None)

Represents the constraints for a specific report query parameter.

Class variables

var code_systems : List[str]

For what code systems are to be used by the parameter field.

var datetime_format : str | None

For date type parameters, defines the format of the date.

var max_value : int | float | None

For int or float type parameters, defines maximum allowable value for the query parameter.

var min_value : int | float | None

For int or float type parameters, defines minimum allowable value for the query parameter.

var options : List[ParameterOption] | None

Optional list of allowable query parameter values.

Static methods

def from_dict(kvs: dict | list | str | int | float | bool | None, *, infer_missing=False) -> ~A
def from_json(s: str | bytes | bytearray, *, parse_float=None, parse_int=None, parse_constant=None, infer_missing=False, **kw) -> ~A
def schema(*, infer_missing: bool = False, only=None, exclude=(), many: bool = False, context=None, load_only=(), dump_only=(), partial: bool = False, unknown=None) -> dataclasses_json.mm.SchemaF[~A]

Methods

def to_dict(self, encode_json=False) -> Dict[str, dict | list | str | int | float | bool | None]
def to_json(self, *, skipkeys: bool = False, ensure_ascii: bool = True, check_circular: bool = True, allow_nan: bool = True, indent: int | str | None = None, separators: Tuple[str, str] = None, default: Callable = None, sort_keys: bool = False, **kw) -> str
class ParameterOption (value: str | float | int, display: str = '', desc: str = '')

Represents a specific allowable option for a parameter.

Class variables

var desc : str

Description of this parameter option.

var display : str

Display for this value, what consumers of this report will see.

var value : str | float | int

Allowed parameter value inserted into the query template.

Static methods

def from_dict(kvs: dict | list | str | int | float | bool | None, *, infer_missing=False) -> ~A
def from_json(s: str | bytes | bytearray, *, parse_float=None, parse_int=None, parse_constant=None, infer_missing=False, **kw) -> ~A
def schema(*, infer_missing: bool = False, only=None, exclude=(), many: bool = False, context=None, load_only=(), dump_only=(), partial: bool = False, unknown=None) -> dataclasses_json.mm.SchemaF[~A]

Methods

def to_dict(self, encode_json=False) -> Dict[str, dict | list | str | int | float | bool | None]
def to_json(self, *, skipkeys: bool = False, ensure_ascii: bool = True, check_circular: bool = True, allow_nan: bool = True, indent: int | str | None = None, separators: Tuple[str, str] = None, default: Callable = None, sort_keys: bool = False, **kw) -> str
class ReportParameter (constraint: ParameterConstraint = None, name: str = '', display: str = '', description: str = '', required: bool = True, param_type: str = 'string', default_value: int | float | str | None = None)

Represents a configurable parameter defined in the query template.

Use the provided static create methods for creating report parameters: * create_string * create_float * create_int * create_datetime * create_code

A ReportParameter's name can later be used in a report query template as a replaceable value. For example, in the template: select item, cost from {{table}} A parameter named "table" could be replace by as String parameter which has possible values of "usa_prices", "canadian_prices" to allow unique reports to be generated from each country.

Optional parameters can also be defined using required=False. In this case, the template can use the mustache conditional format to handle these undefined values, e.g.: SELECT desc, cost FROM orders {{#cat}}WHERE category={{cat}}{{/cat}} or SELECT desc, cost FROM orders WHERE category={{#cat}}{{cat}}{{/cat}}{{^cat}}default{{/cat}}

Class variables

var constraintParameterConstraint

ParameterConstraint representing the constraints for this report parameter.

var default_value : int | float | str | None

(Optional) Value to use if not required or specified by the user.

var description : str

Description of this report parameter. Can be much longer than the name.

var display : str

Name for this report parameter for display to consumers.

var name : str

Name of this report parameter, which is also the token to use in the query template.

var param_type : str

The type of the parameter, one of: "string", "string_list", "float", "integer", "datetime", or "code".

var required : bool

Is this parameter required? If not and the user doesn't specify the value will be blank.

Static methods

def create_code(name: str, display: str, systems: str | List[str], description: str | None = None, required: bool | None = True, comparison_column: str | None = None) -> ReportParameter

Create a report parameter consisting of predefined codes.

A "code" parameter is a special parameter similar to string_list that is tied to a table on the Router which holds predefined code values and their descriptions. In the UI, the user is able to select one or more codes from the table easily to fill in this parameter.

The Roter code table segregates them by "system". For example, one set of codes might represent procedures based on the ICD-10 system while another set of codes might be medications based on the RxNorm system. The user of code parameter with systems=["rxnorm"] could type "aspirin" to see the drug codes for various types of aspirin. The user of code parameter with systems=["icd9_cm", "icd10_cm"] could type into the UI field "heart" to see diagnostic codes for various heart diseases.

The query template must include a specific set of tags that allow correctly expanding a list of user-inputted codes. These are the tags: {{param_name}} (this is the name parameters) is the parent tag for the entire section replicated for each code-list entry. {{_VALUE}} is the child tag where individual list entries will be placed. {{_FIRST}} (optional) which will be automatically Truthy exactly only for the first of the user-selected codes. {{_LAST}} (optional) which will be automatically Truthy exactly only for the last of the user-selected codes.

For example, a query_template for an SQL query may look like this ... {{#codes}} {{#_FIRST}} WHERE {{/_FIRST}} {{^_FIRST}} OR {{/_FIRST}} codeColumn = {{_VALUE}} {{/codes}} ... where the _first tag is used to change the keyword for the first code.

For another example, a query_template for elasticsearch may look like this ... {{#codes}} { "match": { "ICDcodesColumn": { "query": "{{_VALUE}}", "operator": "OR" } } } {{^_LAST}} , {{/_LAST}} {{/codes}} ... where the _last tag is used to generate valid json without trailing comma.

Args

name : str
Name of the field in the template. Must match the field to be replaced in the query template.
display : str
One-line prompt shown for this field in the UI.
system : str or List[str]
The name of the code system(s) represented by this parameter. This can be a single string or a list of strings. When multiple systems are provided, the user will be able to select from any of the systems when running the report. Currently supported: "icd9_cm", "icd10_cm", "icd9_pcs", "icd10_pcs", "cpt", "snomed"
description : str
Optional. Detailed description when displayed in the UI.
required : bool
Is the user required to specify this parameter? If not it can be left blank. A template can handle blank values specially using something like this in the template: {{#name}}…use {{name}}…{{/name}} and/or {{^name}}…no value provided…{{/name}}
comparison_column : str, optional
This parameter has been deprecated. Please refer to the documentation to understand the new system.

Raises

ValueError
Systems must contain a string or list of strings
ValueError
System names must be strings.
ValueError
System name can only contain alphanumerics, dashes, periods, underscores or colons.
ValueError
The comparison_column parameter has been deprecated as the code parameter behavior changed. This value should now be a part of your template. Please refer to the documentation for details.

Returns

ReportParameter
New ReportParameter representing the supplied code field.
def create_datetime(name: str, display: str, datetime_format: str, description: str | None = None, min_value: str | None = None, max_value: str | None = None, default_value: str | None = None, options: List[ParameterOption] | List[str] | None = None, required: bool | None = True) -> ReportParameter

Create a report parameter for a datetime field.

This defines what values should be allowed for this field when the report is run.

Args

name : str
Name of the field in the template. Must match the field to be replaced in the query template.
display : str
One-line prompt shown for this field in the UI.
datetime_format : str
Format of the datetime provided in strftime format. Example: %Y-%m-%d See formatting codes at https://docs.python.org/3/library/datetime.html#strftime-and-strptime-format-codes
description : str
Optional. Detailed description when displayed in the UI.
min_value : str, optional
Represents the minimum allowed value for the query parameter. A value of "now" will be replaced with the current date and time when the report is run. Required if options is not supplied.
max_value : str, optional
Represents the maximum allowed value for the query parameter. A value of "now" will be replaced with the current date and time when the report is run. Required if options is not supplied.
default_value : Optional[str]
The value this field should default to when showing a form to the user. A value of "now" will be replaced with the current date and time when the report is run.
options : list, optional
List of possible parameter values for this field when running the report. If supplied, min and max should not be defined.
required : bool
Is the user required to specify this parameter? If not it can be left blank. A template can handle blank values specially using something like this in the template: {{#name}}…use {{name}}…{{/name}} and/or {{^name}}…no value provided…{{/name}}

Raises

ValueError
min_value must be less than max_value.
ValueError
Must supply min_value and max_value for a datetime parameter without options.
ValueError
Must supply datetime_format for a datetime parameter.
ValueError
If options are populated, must supply at least one option.
ValueError
Invalid option type, must be a str or ParameterOption.
ValueError
The default_value cannot be less than min_value.
ValueError
The default_value cannot be more than max_value.

Returns

ReportParameter
New ReportParameter representing the supplied date field.
def create_float(name: str, display: str, description: str | None = None, min_value: float | None = None, max_value: float | None = None, default_value: float | None = None, options: List[ParameterOption] | List[float] | None = None, required: bool | None = True) -> ReportParameter

Create a report parameter for a float field.

This defines what values should be allowed for this field when the report is run.

Args

name : str
Name of the field in the template. Must match the field to be replaced in the query template.
display : str
One-line prompt shown for this field in the UI.
description : str
Optional. Detailed description when displayed in the UI.
min_value : float, optional
Represents the minimum allowed value for the query parameter. Required if not populating options.
max_value : float, optional
Represents the maximum allowed value for the query parameter. Required if not populating options.
options : list, optional
List of possible parameter values for this field when running the report. If supplied, you cannot also specify a min or max value.
default_value : Optional[float]
The value this field should default to when showing a form to the user.
required : bool
Is the user required to specify this parameter? If not it can be left blank. A template can handle blank values specially using something like this in the template: {{#name}}…use {{name}}…{{/name}} and/or {{^name}}…no value provided…{{/name}}

Raises

Exception
When specifying 'options', do not specify a minimum or maximum value.
Exception
Must supply at least one option.
Exception
Invalid option type, must be a float or ParameterOption
Exception
If default_value is specified, it must be one of the values in options
Exception
Minimum value must be less than maximum.
Exception
The default_value cannot be less than min_value.
Exception
The default_value cannot be more than max_value.

Returns

ReportParameter
New ReportParameter representing the supplied float field.
def create_int(name: str, display: str, description: str | None = None, min_value: int | None = None, max_value: int | None = None, default_value: int | None = None, options: List[ParameterOption] | List[int] | None = None, required: bool | None = True) -> ReportParameter

Creates a report parameter for an integer field.

This defines what values should be allowed for this field when the report is run.

Args

name : str
Name of the field in the template. Must match the field to be replaced in the query template.
display : str
One-line prompt shown for this field in the UI.
description : str
Optional. Detailed description when displayed in the UI.
min_value : int, optional
Represents the minimum allowed value for the query parameter. Required if not populating options.
max_value : int, optional
Represents the maximum allowed value for the query parameter. Required if not populating options.
options : list, optional
List of possible parameter values for this field when running the report. If supplied, you cannot also specify a min or max value.
default_value : Optional[int]
The value this field should default to when showing a form to the user.
required : bool
Is the user required to specify this parameter? If not it can be left blank. A template can handle blank values specially using something like this in the template: {{#name}}…use {{name}}…{{/name}} and/or {{^name}}…no value provided…{{/name}}

Raises

Exception
When specifying 'options', do not specify a minimum or maximum value.
Exception
Must supply at least one option.
Exception
Invalid option type, must be an int or ParameterOption
Exception
If default_value is specified, it must be one of the values in options.
Exception
Minimum value must be less than maximum.
Exception
The default_value cannot be less than min_value.
Exception
The default_value cannot be more than max_value.

Returns

ReportParameter
New ReportParameter representing the supplied integer field.
def create_string(name: str, display: str, options: List[ParameterOption], description: str | None = None, default_value: str | None = None, required: bool | None = True) -> ReportParameter

Creates a report parameter for a string field.

This defines what values should be allowed for this field when the report is run.

Args

name : str
Name of the field in the template. Must match the field to be replaced in the query template.
display : str
One-line prompt shown for this field in the UI.
description : str
Optional. Detailed description when displayed in the UI.
options
List of possible parameter values for this field when running the report.
default_value
The value this field should default to when showing a form to the user.
required : bool
Is the user required to specify this parameter? If not it can be left blank. A template can handle blank values specially using something like this in the template: {{#name}}…use {{name}}…{{/name}} and/or {{^name}}…no value provided…{{/name}}

Raises

Exception
Must supply option for a string parameter.
Exception
Invalid option type, must be a str or ParameterOption.
Exception
If specified, the default_value must not be blank.
Exception
If default_value is specified, it must be one of the values in options.

Returns

ReportParameter
New ReportParameter representing the supplied string field.
def create_string_list(name: str, display: str, description: str | None = None, default_value: str | List[str] | None = None, required: bool | None = True) -> ReportParameter

Creates a report parameter for a free-form list of strings field.

The parameter only accepts alphanumeric "phrases" separated by commas. As a freeform, be vigilant about how it's being used in the report template.

The query template must include a specific set of tags that allow correctly expanding a list of user-enteres values. These are the tags: {{param_name}} (this is the name parameters) is the parent tag for the entire section replicated for each list entry. {{_VALUE}} is the child tag where individual list entries will be placed. {{_FIRST}} (optional) which will be automatically Truthy exactly only for the first of the user-entered values. {{_LAST}} (optional) which will be automatically Truthy exactly only for the last of the user-entered values.

End-user values will be provided as a nested context to mustache/chevron. For example, end-user typing ["medicine 1", "medicine 2"] for {{med}} will be expanded into the following context: "med": [ {"_VALUE": "medicine 1", "_FIRST": True, "_LAST": False} {"_VALUE": "medicine 2", "_FIRST": False, "_LAST": True} ]

An appropriate template to handle this could be: ... WHERE {{#med}} medcol = '{{_VALUE}}' {{^_LAST}} OR {{/_LAST}} {{/med}} ... which when populated with the above values would become ... WHERE medcol = 'medicine 1' OR medcol = 'medicine 2' ...

Args

name : str
Name of the field in the template. Must match the field to be replaced in the query template.
display : str
One-line prompt shown for this field in the UI.
description : str
Optional. Detailed description when displayed in the UI.
default_value
The value this field should default to when showing a form to the user and/or if required and left blank.
required : bool
Is the user required to specify this parameter? If not it can be left blank. A template can handle blank values specially using something like this in the template: {{#name}}…use {{_VALUE}}…{{/name}} and/or {{^name}}…no value provided…{{/name}}

Raises

Exception
If specified, the default_value must not be blank.

Returns

ReportParameter
New ReportParameter representing the supplied string field.
def from_dict(kvs: dict | list | str | int | float | bool | None, *, infer_missing=False) -> ~A
def from_json(s: str | bytes | bytearray, *, parse_float=None, parse_int=None, parse_constant=None, infer_missing=False, **kw) -> ~A
def schema(*, infer_missing: bool = False, only=None, exclude=(), many: bool = False, context=None, load_only=(), dump_only=(), partial: bool = False, unknown=None) -> dataclasses_json.mm.SchemaF[~A]

Methods

def to_dict(self, encode_json=False) -> Dict[str, dict | list | str | int | float | bool | None]
def to_json(self, *, skipkeys: bool = False, ensure_ascii: bool = True, check_circular: bool = True, allow_nan: bool = True, indent: int | str | None = None, separators: Tuple[str, str] = None, default: Callable = None, sort_keys: bool = False, **kw) -> str