views
variable.views
¤
Classes¤
CustomCreateView
¤
Bases: URLMixin
, LoginRequiredMixin
, CreateView
Generic create view.
This view is used to create a new model object. The user must have the permission to create the object, otherwise a 403 error is returned.
The view includes a form with the object data, and the context includes the title of the view and the URL to the list view.
If provided, the foreign_key_fields
attribute is used to limit the queryset for
foreign key fields.
If successful, the view redirects to the detail view of the created object.
Users need to be logged in to access this view.
Attributes:
Name | Type | Description |
---|---|---|
template_name |
str
|
Template to be used. |
Functions¤
form_valid(form)
¤
Set the owner of the object to the current user.
This is done before saving the object to the database.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
form
|
ModelForm
|
Form with the object data. |
required |
Returns:
Name | Type | Description |
---|---|---|
HttpResponse |
HttpResponse
|
Redirect to the detail view of the created object. |
Source code in management/views.py
346 347 348 349 350 351 352 353 354 355 356 357 358 |
|
get_form_kwargs()
¤
Add the user to the form kwargs, so we can filter the options.
Source code in management/views.py
384 385 386 387 388 |
|
CustomDeleteView
¤
Bases: URLMixin
, LoginRequiredMixin
, DeleteView
Generic delete view.
This view is used to delete a model object. The user must have the permission to delete the object, otherwise a 403 error is returned. A confirmation page is shown with the related objects that will be deleted.
The permissions required to delete the object are app_label.delete_model_name
. For
example, the permission required to delete a DataImport
object would be
importing.delete_dataimport
.
If successful, the view redirects to the list view.
Users need to be logged in to access this view.
Attributes:
Name | Type | Description |
---|---|---|
template_name |
str
|
Template to be used. |
CustomDetailView
¤
Bases: URLMixin
, LoginRequiredMixin
, DetailView
Generic detail view.
This view is used to show the details of a model object. The user must have the permission to view the object, otherwise a 403 error is returned.
The view includes a form with the object data, and the context includes the URLs for the list, delete, and edit views.
The permissions required to view the object are app_label.view_model_name
. For
example, the permission required to view a DataImport
object would be
importing.view_dataimport
.
Users need to be logged in to access this view.
Attributes:
Name | Type | Description |
---|---|---|
template_name |
str
|
Template to be used. |
fields |
str
|
Fields to be shown in the form. |
Functions¤
get_inline()
¤
Return the inline data for the format.
If provided, this method should return a dictionary with the inline data to be shown in the detail view. The dictionary should have the following keys:
- title: Title of the inline data.
- header: List with the header of the table.
- objects: List with the objects to be shown in the table. Each object should be a list with the same length as the header.
Returns:
Type | Description |
---|---|
dict | None
|
dict | None: Inline data for the format. |
Source code in management/views.py
106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 |
|
CustomEditView
¤
Bases: URLMixin
, LoginRequiredMixin
, UpdateView
Generic edit view.
This view is used to edit a model object. The user must have the permission to edit the object, otherwise a 403 error is returned.
The view includes a form with the object data, and the context includes the title of the view and the URL to the list view.
The permissions required to edit the object are app_label.change_model_name
. For
example, the permission required to edit a DataImport
object would be
importing.change_dataimport
.
If successful or cancelled, the view redirects to the detail view of the created object.
Users need to be logged in to access this view.
Attributes:
Name | Type | Description |
---|---|---|
template_name |
str
|
Template to be used. |
Functions¤
get_form_kwargs()
¤
Add the user to the form kwargs, so we can filter the options.
Source code in management/views.py
284 285 286 287 288 |
|
CustomTableView
¤
Bases: URLMixin
, LoginRequiredMixin
, SingleTableMixin
, FilterView
This view is used to show a list of model objects.
The view includes a table with the objects, and the context includes the title of the view, the refresh URL, and the URL to create a new object.
The permissions required to view the objects are app_label.view_model_name
. For
example, the permission required to view a DataImport
object would be
importing.view_dataimport
.
If provided, the filter_class
attribute is used to create a filter form on top
of the table.
Users need to be logged in to access this view.
Attributes:
Name | Type | Description |
---|---|---|
model |
Model
|
Model to be used. |
table_class |
Table
|
Table class to be used. |
filterset_class |
FilterSet
|
Filter class to be used. If not provided, the model's default filter is used. |
template_name |
str
|
Template to be used. |
paginate_by |
int
|
Number of objects per page. |
show_refresh_btn |
bool
|
If True, a refresh url is included in the context. |
show_new_btn |
bool
|
If True, a create url is included in the context. |
Functions¤
get_filterset_class()
¤
Return the filter class for the view.
If no filter class is provided in the view, the default filter for the model is
used. The default filter is created by the FilterSet
class, and includes only
the 'visibility'.
Source code in management/views.py
191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 |
|
SensorInstallation
¤
Bases: PermissionsBase
Represents an installation of a Sensor at a Station, which measures a Variable.
It includes metadata for installation and finishing date, as well as state (active or not).
Attributes:
Name | Type | Description |
---|---|---|
sensorinstallation_id |
AutoField
|
Primary key. |
variable |
ForeignKey
|
Variable measured by the sensor. |
station |
ForeignKey
|
Station where the sensor is installed. |
sensor |
ForeignKey
|
Sensor used for the measurement. |
start_date |
DateField
|
Start date of the installation. |
end_date |
DateField
|
End date of the installation. |
state |
BooleanField
|
Is the sensor active? |
SensorInstallationCreateView
¤
SensorInstallationDeleteView
¤
SensorInstallationDetailView
¤
SensorInstallationEditView
¤
SensorInstallationFilter
¤
Bases: FilterSet
SensorInstallationListView
¤
SensorInstallationTable
¤
Bases: Table
Unit
¤
Bases: PermissionsBase
Unit of measurement with a name and a symbol.
Attributes:
Name | Type | Description |
---|---|---|
unit_id |
AutoField
|
Primary key. |
name |
CharField
|
Name of the unit, eg. meters per second. |
initials |
CharField
|
Symbol for the unit, eg. m/s. |
Functions¤
__str__()
¤
Return the string representation of the object.
Source code in variable/models.py
42 43 44 |
|
get_absolute_url()
¤
Get the absolute URL of the object.
Source code in variable/models.py
46 47 48 |
|
UnitCreateView
¤
UnitDeleteView
¤
UnitDetailView
¤
UnitEditView
¤
UnitListView
¤
UnitTable
¤
Bases: Table
Variable
¤
Bases: PermissionsBase
A variable with a physical meaning.
Such as precipitation, wind speed, wind direction, soil moisture, including the associated unit. It also includes metadata to help identify what is a reasonable value for the data, to flag outliers and to help with the validation process.
The nature of the variable can be one of the following:
- sum: Cumulative value over a period of time.
- average: Average value over a period of time.
- value: One-off value.
Attributes:
Name | Type | Description |
---|---|---|
variable_id |
AutoField
|
Primary key. |
variable_code |
CharField
|
Code of the variable, eg. airtemperature. |
name |
CharField
|
Human-readable name of the variable, eg. Air temperature. |
unit |
ForeignKey
|
Unit of the variable. |
maximum |
DecimalField
|
Maximum value allowed for the variable. |
minimum |
DecimalField
|
Minimum value allowed for the variable. |
diff_error |
DecimalField
|
If two sequential values in the time-series data of this variable differ by more than this value, the validation process can mark this with an error flag. |
outlier_limit |
DecimalField
|
The statistical deviation for defining outliers, in times the standard deviation (sigma). |
null_limit |
DecimalField
|
The max % of null values (missing, caused by e.g. equipment malfunction) allowed for hourly, daily, monthly data. Cumulative values are not deemed trustworthy if the number of missing values in a given period is greater than the null_limit. |
nature |
CharField
|
Nature of the variable, eg. if it represents a one-off value, the average over a period of time or the cumulative value over a period |
Attributes¤
is_cumulative: bool
property
¤
Return True if the nature of the variable is sum.
Functions¤
__str__()
¤
Return the string representation of the object.
Source code in variable/models.py
165 166 167 |
|
clean()
¤
Validate the model fields.
Source code in variable/models.py
173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 |
|
get_absolute_url()
¤
Get the absolute URL of the object.
Source code in variable/models.py
169 170 171 |
|
VariableCreateView
¤
VariableDeleteView
¤
VariableDetailView
¤
VariableEditView
¤
VariableFilter
¤
Bases: FilterSet
VariableListView
¤
VariableTable
¤
Bases: Table