add new fields in the filters
This commit is contained in:
parent
5d8c26ade6
commit
ac535cc9b5
|
@ -50,11 +50,14 @@ from ereuse_devicehub.resources.device.models import (
|
||||||
Keyboard,
|
Keyboard,
|
||||||
Laptop,
|
Laptop,
|
||||||
MemoryCardReader,
|
MemoryCardReader,
|
||||||
|
Monitor,
|
||||||
Mouse,
|
Mouse,
|
||||||
Placeholder,
|
Placeholder,
|
||||||
|
Projector,
|
||||||
Server,
|
Server,
|
||||||
Smartphone,
|
Smartphone,
|
||||||
Tablet,
|
Tablet,
|
||||||
|
TelevisionSet,
|
||||||
)
|
)
|
||||||
from ereuse_devicehub.resources.documents.models import DataWipeDocument
|
from ereuse_devicehub.resources.documents.models import DataWipeDocument
|
||||||
from ereuse_devicehub.resources.enums import Severity
|
from ereuse_devicehub.resources.enums import Severity
|
||||||
|
@ -91,6 +94,13 @@ DEVICES = {
|
||||||
"HardDrives",
|
"HardDrives",
|
||||||
"SolidStageDrive",
|
"SolidStageDrive",
|
||||||
],
|
],
|
||||||
|
"Accessories": [
|
||||||
|
"All Accessories",
|
||||||
|
"Mouse",
|
||||||
|
"MemoryCardReader",
|
||||||
|
"SAI",
|
||||||
|
"Keyboard",
|
||||||
|
],
|
||||||
}
|
}
|
||||||
|
|
||||||
COMPUTERS = ['Desktop', 'Laptop', 'Server', 'Computer']
|
COMPUTERS = ['Desktop', 'Laptop', 'Server', 'Computer']
|
||||||
|
@ -98,6 +108,7 @@ COMPUTERS = ['Desktop', 'Laptop', 'Server', 'Computer']
|
||||||
MONITORS = ["ComputerMonitor", "Monitor", "TelevisionSet", "Projector"]
|
MONITORS = ["ComputerMonitor", "Monitor", "TelevisionSet", "Projector"]
|
||||||
MOBILE = ["Mobile", "Tablet", "Smartphone", "Cellphone"]
|
MOBILE = ["Mobile", "Tablet", "Smartphone", "Cellphone"]
|
||||||
STORAGE = ["HardDrive", "SolidStateDrive"]
|
STORAGE = ["HardDrive", "SolidStateDrive"]
|
||||||
|
ACCESSORIES = ["Mouse", "MemoryCardReader", "SAI", "Keyboard"]
|
||||||
|
|
||||||
|
|
||||||
class AdvancedSearchForm(FlaskForm):
|
class AdvancedSearchForm(FlaskForm):
|
||||||
|
@ -184,6 +195,9 @@ class FilterForm(FlaskForm):
|
||||||
elif "All DataStorage" == self.device_type:
|
elif "All DataStorage" == self.device_type:
|
||||||
filter_type = STORAGE
|
filter_type = STORAGE
|
||||||
|
|
||||||
|
elif "All Accessories" == self.device_type:
|
||||||
|
filter_type = ACCESSORIES
|
||||||
|
|
||||||
if filter_type:
|
if filter_type:
|
||||||
self.devices = self.devices.filter(Device.type.in_(filter_type))
|
self.devices = self.devices.filter(Device.type.in_(filter_type))
|
||||||
|
|
||||||
|
@ -371,6 +385,9 @@ class NewDeviceForm(FlaskForm):
|
||||||
"Tablet": Tablet,
|
"Tablet": Tablet,
|
||||||
"Cellphone": Cellphone,
|
"Cellphone": Cellphone,
|
||||||
"ComputerMonitor": ComputerMonitor,
|
"ComputerMonitor": ComputerMonitor,
|
||||||
|
"Monitor": Monitor,
|
||||||
|
"TelevisionSet": TelevisionSet,
|
||||||
|
"Projector": Projector,
|
||||||
"Mouse": Mouse,
|
"Mouse": Mouse,
|
||||||
"Keyboard": Keyboard,
|
"Keyboard": Keyboard,
|
||||||
"SAI": SAI,
|
"SAI": SAI,
|
||||||
|
|
|
@ -4,7 +4,11 @@ from teal.resource import Converters, Resource
|
||||||
|
|
||||||
from ereuse_devicehub.resources.device import schemas
|
from ereuse_devicehub.resources.device import schemas
|
||||||
from ereuse_devicehub.resources.device.models import Manufacturer
|
from ereuse_devicehub.resources.device.models import Manufacturer
|
||||||
from ereuse_devicehub.resources.device.views import DeviceView, DeviceMergeView, ManufacturerView
|
from ereuse_devicehub.resources.device.views import (
|
||||||
|
DeviceMergeView,
|
||||||
|
DeviceView,
|
||||||
|
ManufacturerView,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class DeviceDef(Resource):
|
class DeviceDef(Resource):
|
||||||
|
@ -13,7 +17,9 @@ class DeviceDef(Resource):
|
||||||
ID_CONVERTER = Converters.string
|
ID_CONVERTER = Converters.string
|
||||||
AUTH = False # We manage this at each view
|
AUTH = False # We manage this at each view
|
||||||
|
|
||||||
def __init__(self, app,
|
def __init__(
|
||||||
|
self,
|
||||||
|
app,
|
||||||
import_name=__name__,
|
import_name=__name__,
|
||||||
static_folder='static',
|
static_folder='static',
|
||||||
static_url_path=None,
|
static_url_path=None,
|
||||||
|
@ -22,16 +28,31 @@ class DeviceDef(Resource):
|
||||||
subdomain=None,
|
subdomain=None,
|
||||||
url_defaults=None,
|
url_defaults=None,
|
||||||
root_path=None,
|
root_path=None,
|
||||||
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
):
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
device_merge = DeviceMergeView.as_view('merge-devices', definition=self, auth=app.auth)
|
device_merge = DeviceMergeView.as_view(
|
||||||
|
'merge-devices', definition=self, auth=app.auth
|
||||||
|
)
|
||||||
|
|
||||||
if self.AUTH:
|
if self.AUTH:
|
||||||
device_merge = app.auth.requires_auth(device_merge)
|
device_merge = app.auth.requires_auth(device_merge)
|
||||||
|
|
||||||
path = '/<{value}:dev1_id>/merge/<{value}:dev2_id>'.format(value=self.ID_CONVERTER.value)
|
path = '/<{value}:dev1_id>/merge/<{value}:dev2_id>'.format(
|
||||||
|
value=self.ID_CONVERTER.value
|
||||||
|
)
|
||||||
|
|
||||||
# self.add_url_rule(path, view_func=device_merge, methods={'POST'})
|
# self.add_url_rule(path, view_func=device_merge, methods={'POST'})
|
||||||
|
|
||||||
|
@ -40,11 +61,31 @@ class ComputerDef(DeviceDef):
|
||||||
VIEW = None
|
VIEW = None
|
||||||
SCHEMA = schemas.Computer
|
SCHEMA = schemas.Computer
|
||||||
|
|
||||||
def __init__(self, app, import_name=__name__, static_folder=None, static_url_path=None,
|
def __init__(
|
||||||
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
self,
|
||||||
root_path=None, cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
app,
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
import_name=__name__,
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
static_folder=None,
|
||||||
|
static_url_path=None,
|
||||||
|
template_folder=None,
|
||||||
|
url_prefix=None,
|
||||||
|
subdomain=None,
|
||||||
|
url_defaults=None,
|
||||||
|
root_path=None,
|
||||||
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
|
):
|
||||||
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class DesktopDef(ComputerDef):
|
class DesktopDef(ComputerDef):
|
||||||
|
@ -66,11 +107,31 @@ class MonitorDef(DeviceDef):
|
||||||
VIEW = None
|
VIEW = None
|
||||||
SCHEMA = schemas.Monitor
|
SCHEMA = schemas.Monitor
|
||||||
|
|
||||||
def __init__(self, app, import_name=__name__, static_folder=None, static_url_path=None,
|
def __init__(
|
||||||
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
self,
|
||||||
root_path=None, cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
app,
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
import_name=__name__,
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
static_folder=None,
|
||||||
|
static_url_path=None,
|
||||||
|
template_folder=None,
|
||||||
|
url_prefix=None,
|
||||||
|
subdomain=None,
|
||||||
|
url_defaults=None,
|
||||||
|
root_path=None,
|
||||||
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
|
):
|
||||||
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class ComputerMonitorDef(MonitorDef):
|
class ComputerMonitorDef(MonitorDef):
|
||||||
|
@ -83,15 +144,40 @@ class TelevisionSetDef(MonitorDef):
|
||||||
SCHEMA = schemas.TelevisionSet
|
SCHEMA = schemas.TelevisionSet
|
||||||
|
|
||||||
|
|
||||||
|
class ProjectorDef(MonitorDef):
|
||||||
|
VIEW = None
|
||||||
|
SCHEMA = schemas.Projector
|
||||||
|
|
||||||
|
|
||||||
class MobileDef(DeviceDef):
|
class MobileDef(DeviceDef):
|
||||||
VIEW = None
|
VIEW = None
|
||||||
SCHEMA = schemas.Mobile
|
SCHEMA = schemas.Mobile
|
||||||
|
|
||||||
def __init__(self, app, import_name=__name__, static_folder=None, static_url_path=None,
|
def __init__(
|
||||||
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
self,
|
||||||
root_path=None, cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
app,
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
import_name=__name__,
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
static_folder=None,
|
||||||
|
static_url_path=None,
|
||||||
|
template_folder=None,
|
||||||
|
url_prefix=None,
|
||||||
|
subdomain=None,
|
||||||
|
url_defaults=None,
|
||||||
|
root_path=None,
|
||||||
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
|
):
|
||||||
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class SmartphoneDef(MobileDef):
|
class SmartphoneDef(MobileDef):
|
||||||
|
@ -113,11 +199,31 @@ class ComponentDef(DeviceDef):
|
||||||
VIEW = None
|
VIEW = None
|
||||||
SCHEMA = schemas.Component
|
SCHEMA = schemas.Component
|
||||||
|
|
||||||
def __init__(self, app, import_name=__name__, static_folder=None, static_url_path=None,
|
def __init__(
|
||||||
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
self,
|
||||||
root_path=None, cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
app,
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
import_name=__name__,
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
static_folder=None,
|
||||||
|
static_url_path=None,
|
||||||
|
template_folder=None,
|
||||||
|
url_prefix=None,
|
||||||
|
subdomain=None,
|
||||||
|
url_defaults=None,
|
||||||
|
root_path=None,
|
||||||
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
|
):
|
||||||
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class GraphicCardDef(ComponentDef):
|
class GraphicCardDef(ComponentDef):
|
||||||
|
@ -184,11 +290,31 @@ class ComputerAccessoryDef(DeviceDef):
|
||||||
VIEW = None
|
VIEW = None
|
||||||
SCHEMA = schemas.ComputerAccessory
|
SCHEMA = schemas.ComputerAccessory
|
||||||
|
|
||||||
def __init__(self, app, import_name=__name__, static_folder=None, static_url_path=None,
|
def __init__(
|
||||||
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
self,
|
||||||
root_path=None, cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
app,
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
import_name=__name__,
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
static_folder=None,
|
||||||
|
static_url_path=None,
|
||||||
|
template_folder=None,
|
||||||
|
url_prefix=None,
|
||||||
|
subdomain=None,
|
||||||
|
url_defaults=None,
|
||||||
|
root_path=None,
|
||||||
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
|
):
|
||||||
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class MouseDef(ComputerAccessoryDef):
|
class MouseDef(ComputerAccessoryDef):
|
||||||
|
@ -215,11 +341,31 @@ class NetworkingDef(DeviceDef):
|
||||||
VIEW = None
|
VIEW = None
|
||||||
SCHEMA = schemas.Networking
|
SCHEMA = schemas.Networking
|
||||||
|
|
||||||
def __init__(self, app, import_name=__name__, static_folder=None, static_url_path=None,
|
def __init__(
|
||||||
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
self,
|
||||||
root_path=None, cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
app,
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
import_name=__name__,
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
static_folder=None,
|
||||||
|
static_url_path=None,
|
||||||
|
template_folder=None,
|
||||||
|
url_prefix=None,
|
||||||
|
subdomain=None,
|
||||||
|
url_defaults=None,
|
||||||
|
root_path=None,
|
||||||
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
|
):
|
||||||
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class RouterDef(NetworkingDef):
|
class RouterDef(NetworkingDef):
|
||||||
|
@ -246,11 +392,31 @@ class PrinterDef(DeviceDef):
|
||||||
VIEW = None
|
VIEW = None
|
||||||
SCHEMA = schemas.Printer
|
SCHEMA = schemas.Printer
|
||||||
|
|
||||||
def __init__(self, app, import_name=__name__, static_folder=None, static_url_path=None,
|
def __init__(
|
||||||
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
self,
|
||||||
root_path=None, cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
app,
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
import_name=__name__,
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
static_folder=None,
|
||||||
|
static_url_path=None,
|
||||||
|
template_folder=None,
|
||||||
|
url_prefix=None,
|
||||||
|
subdomain=None,
|
||||||
|
url_defaults=None,
|
||||||
|
root_path=None,
|
||||||
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
|
):
|
||||||
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class LabelPrinterDef(PrinterDef):
|
class LabelPrinterDef(PrinterDef):
|
||||||
|
@ -262,11 +428,31 @@ class SoundDef(DeviceDef):
|
||||||
VIEW = None
|
VIEW = None
|
||||||
SCHEMA = schemas.Sound
|
SCHEMA = schemas.Sound
|
||||||
|
|
||||||
def __init__(self, app, import_name=__name__, static_folder=None, static_url_path=None,
|
def __init__(
|
||||||
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
self,
|
||||||
root_path=None, cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
app,
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
import_name=__name__,
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
static_folder=None,
|
||||||
|
static_url_path=None,
|
||||||
|
template_folder=None,
|
||||||
|
url_prefix=None,
|
||||||
|
subdomain=None,
|
||||||
|
url_defaults=None,
|
||||||
|
root_path=None,
|
||||||
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
|
):
|
||||||
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class MicrophoneDef(SoundDef):
|
class MicrophoneDef(SoundDef):
|
||||||
|
@ -278,11 +464,31 @@ class VideoDef(DeviceDef):
|
||||||
VIEW = None
|
VIEW = None
|
||||||
SCHEMA = schemas.Video
|
SCHEMA = schemas.Video
|
||||||
|
|
||||||
def __init__(self, app, import_name=__name__, static_folder=None, static_url_path=None,
|
def __init__(
|
||||||
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
self,
|
||||||
root_path=None, cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
app,
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
import_name=__name__,
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
static_folder=None,
|
||||||
|
static_url_path=None,
|
||||||
|
template_folder=None,
|
||||||
|
url_prefix=None,
|
||||||
|
subdomain=None,
|
||||||
|
url_defaults=None,
|
||||||
|
root_path=None,
|
||||||
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
|
):
|
||||||
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class VideoScalerDef(VideoDef):
|
class VideoScalerDef(VideoDef):
|
||||||
|
@ -299,11 +505,31 @@ class CookingDef(DeviceDef):
|
||||||
VIEW = None
|
VIEW = None
|
||||||
SCHEMA = schemas.Cooking
|
SCHEMA = schemas.Cooking
|
||||||
|
|
||||||
def __init__(self, app, import_name=__name__, static_folder=None, static_url_path=None,
|
def __init__(
|
||||||
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
self,
|
||||||
root_path=None, cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
app,
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
import_name=__name__,
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
static_folder=None,
|
||||||
|
static_url_path=None,
|
||||||
|
template_folder=None,
|
||||||
|
url_prefix=None,
|
||||||
|
subdomain=None,
|
||||||
|
url_defaults=None,
|
||||||
|
root_path=None,
|
||||||
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
|
):
|
||||||
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class Mixer(CookingDef):
|
class Mixer(CookingDef):
|
||||||
|
@ -315,11 +541,31 @@ class DIYAndGardeningDef(DeviceDef):
|
||||||
VIEW = None
|
VIEW = None
|
||||||
SCHEMA = schemas.DIYAndGardening
|
SCHEMA = schemas.DIYAndGardening
|
||||||
|
|
||||||
def __init__(self, app, import_name=__name__, static_folder=None, static_url_path=None,
|
def __init__(
|
||||||
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
self,
|
||||||
root_path=None, cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
app,
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
import_name=__name__,
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
static_folder=None,
|
||||||
|
static_url_path=None,
|
||||||
|
template_folder=None,
|
||||||
|
url_prefix=None,
|
||||||
|
subdomain=None,
|
||||||
|
url_defaults=None,
|
||||||
|
root_path=None,
|
||||||
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
|
):
|
||||||
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class DrillDef(DIYAndGardeningDef):
|
class DrillDef(DIYAndGardeningDef):
|
||||||
|
@ -331,22 +577,62 @@ class PackOfScrewdriversDef(DIYAndGardeningDef):
|
||||||
VIEW = None
|
VIEW = None
|
||||||
SCHEMA = schemas.PackOfScrewdrivers
|
SCHEMA = schemas.PackOfScrewdrivers
|
||||||
|
|
||||||
def __init__(self, app, import_name=__name__, static_folder=None, static_url_path=None,
|
def __init__(
|
||||||
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
self,
|
||||||
root_path=None, cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
app,
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
import_name=__name__,
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
static_folder=None,
|
||||||
|
static_url_path=None,
|
||||||
|
template_folder=None,
|
||||||
|
url_prefix=None,
|
||||||
|
subdomain=None,
|
||||||
|
url_defaults=None,
|
||||||
|
root_path=None,
|
||||||
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
|
):
|
||||||
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class HomeDef(DeviceDef):
|
class HomeDef(DeviceDef):
|
||||||
VIEW = None
|
VIEW = None
|
||||||
SCHEMA = schemas.Home
|
SCHEMA = schemas.Home
|
||||||
|
|
||||||
def __init__(self, app, import_name=__name__, static_folder=None, static_url_path=None,
|
def __init__(
|
||||||
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
self,
|
||||||
root_path=None, cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
app,
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
import_name=__name__,
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
static_folder=None,
|
||||||
|
static_url_path=None,
|
||||||
|
template_folder=None,
|
||||||
|
url_prefix=None,
|
||||||
|
subdomain=None,
|
||||||
|
url_defaults=None,
|
||||||
|
root_path=None,
|
||||||
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
|
):
|
||||||
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class DehumidifierDef(HomeDef):
|
class DehumidifierDef(HomeDef):
|
||||||
|
@ -363,11 +649,31 @@ class RecreationDef(DeviceDef):
|
||||||
VIEW = None
|
VIEW = None
|
||||||
SCHEMA = schemas.Recreation
|
SCHEMA = schemas.Recreation
|
||||||
|
|
||||||
def __init__(self, app, import_name=__name__, static_folder=None, static_url_path=None,
|
def __init__(
|
||||||
template_folder=None, url_prefix=None, subdomain=None, url_defaults=None,
|
self,
|
||||||
root_path=None, cli_commands: Iterable[Tuple[Callable, str or None]] = tuple()):
|
app,
|
||||||
super().__init__(app, import_name, static_folder, static_url_path, template_folder,
|
import_name=__name__,
|
||||||
url_prefix, subdomain, url_defaults, root_path, cli_commands)
|
static_folder=None,
|
||||||
|
static_url_path=None,
|
||||||
|
template_folder=None,
|
||||||
|
url_prefix=None,
|
||||||
|
subdomain=None,
|
||||||
|
url_defaults=None,
|
||||||
|
root_path=None,
|
||||||
|
cli_commands: Iterable[Tuple[Callable, str or None]] = tuple(),
|
||||||
|
):
|
||||||
|
super().__init__(
|
||||||
|
app,
|
||||||
|
import_name,
|
||||||
|
static_folder,
|
||||||
|
static_url_path,
|
||||||
|
template_folder,
|
||||||
|
url_prefix,
|
||||||
|
subdomain,
|
||||||
|
url_defaults,
|
||||||
|
root_path,
|
||||||
|
cli_commands,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class BikeDef(RecreationDef):
|
class BikeDef(RecreationDef):
|
||||||
|
|
|
@ -269,6 +269,10 @@ class TelevisionSet(Monitor):
|
||||||
__doc__ = m.TelevisionSet.__doc__
|
__doc__ = m.TelevisionSet.__doc__
|
||||||
|
|
||||||
|
|
||||||
|
class Projector(Monitor):
|
||||||
|
__doc__ = m.Projector.__doc__
|
||||||
|
|
||||||
|
|
||||||
class Mobile(Device):
|
class Mobile(Device):
|
||||||
__doc__ = m.Mobile.__doc__
|
__doc__ = m.Mobile.__doc__
|
||||||
|
|
||||||
|
|
|
@ -46,7 +46,13 @@
|
||||||
</optgroup>
|
</optgroup>
|
||||||
<optgroup label="Monitor">
|
<optgroup label="Monitor">
|
||||||
<option value="ComputerMonitor"
|
<option value="ComputerMonitor"
|
||||||
{% if form.type.data == 'Monitor' %} selected="selected"{% endif %}>Computer Monitor</option>
|
{% if form.type.data == 'ComputerMonitor' %} selected="selected"{% endif %}>Computer Monitor</option>
|
||||||
|
<option value="Monitor"
|
||||||
|
{% if form.type.data == 'Monitor' %} selected="selected"{% endif %}>Monitor</option>
|
||||||
|
<option value="TelevisionSet"
|
||||||
|
{% if form.type.data == 'TelevisionSet' %} selected="selected"{% endif %}>TelevisionSet</option>
|
||||||
|
<option value="Projector"
|
||||||
|
{% if form.type.data == 'Projector' %} selected="selected"{% endif %}>Projector</option>
|
||||||
</optgroup>
|
</optgroup>
|
||||||
<optgroup label="Mobile">
|
<optgroup label="Mobile">
|
||||||
<option value="Smartphone"
|
<option value="Smartphone"
|
||||||
|
|
Reference in New Issue