Refactor "edit printer settings" view for Label Profile
for sake of Buefy, but it was definitely using some old form patterns...
This commit is contained in:
parent
a37b0229a0
commit
5907973d42
|
@ -37,6 +37,7 @@ from sqlalchemy.ext.associationproxy import AssociationProxy, ASSOCIATION_PROXY
|
||||||
|
|
||||||
from rattail.time import localtime
|
from rattail.time import localtime
|
||||||
from rattail.util import prettify, pretty_boolean, pretty_hours, pretty_quantity
|
from rattail.util import prettify, pretty_boolean, pretty_hours, pretty_quantity
|
||||||
|
from rattail.core import UNSPECIFIED
|
||||||
|
|
||||||
import colander
|
import colander
|
||||||
import deform
|
import deform
|
||||||
|
@ -338,7 +339,7 @@ class Form(object):
|
||||||
auto_disable_cancel = True
|
auto_disable_cancel = True
|
||||||
|
|
||||||
def __init__(self, fields=None, schema=None, request=None, mobile=False, readonly=False, readonly_fields=[],
|
def __init__(self, fields=None, schema=None, request=None, mobile=False, readonly=False, readonly_fields=[],
|
||||||
model_instance=None, model_class=None, nodes={}, enums={}, labels={}, renderers=None,
|
model_instance=None, model_class=None, appstruct=UNSPECIFIED, nodes={}, enums={}, labels={}, renderers=None,
|
||||||
hidden={}, widgets={}, defaults={}, validators={}, required={}, helptext={}, focus_spec=None,
|
hidden={}, widgets={}, defaults={}, validators={}, required={}, helptext={}, focus_spec=None,
|
||||||
action_url=None, cancel_url=None, use_buefy=None):
|
action_url=None, cancel_url=None, use_buefy=None):
|
||||||
|
|
||||||
|
@ -358,6 +359,7 @@ class Form(object):
|
||||||
self.model_class = type(self.model_instance)
|
self.model_class = type(self.model_instance)
|
||||||
if self.model_class and self.fields is None:
|
if self.model_class and self.fields is None:
|
||||||
self.set_fields(self.make_fields())
|
self.set_fields(self.make_fields())
|
||||||
|
self.appstruct = appstruct
|
||||||
self.nodes = nodes or {}
|
self.nodes = nodes or {}
|
||||||
self.enums = enums or {}
|
self.enums = enums or {}
|
||||||
self.labels = labels or {}
|
self.labels = labels or {}
|
||||||
|
@ -706,7 +708,12 @@ class Form(object):
|
||||||
|
|
||||||
# get initial form values from model instance
|
# get initial form values from model instance
|
||||||
kwargs = {}
|
kwargs = {}
|
||||||
if self.model_instance:
|
# TODO: ugh, this is necessary to avoid some logic
|
||||||
|
# which assumes a ColanderAlchemy schema i think?
|
||||||
|
if self.appstruct is not UNSPECIFIED:
|
||||||
|
if self.appstruct:
|
||||||
|
kwargs['appstruct'] = self.appstruct
|
||||||
|
elif self.model_instance:
|
||||||
if self.model_class:
|
if self.model_class:
|
||||||
kwargs['appstruct'] = schema.dictify(self.model_instance)
|
kwargs['appstruct'] = schema.dictify(self.model_instance)
|
||||||
else:
|
else:
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
## -*- coding: utf-8 -*-
|
## -*- coding: utf-8; -*-
|
||||||
<%inherit file="/base.mako" />
|
<%inherit file="/form.mako" />
|
||||||
|
|
||||||
<%def name="title()">Printer Settings</%def>
|
<%def name="title()">Printer Settings</%def>
|
||||||
|
|
||||||
|
@ -9,42 +9,5 @@
|
||||||
<li>${h.link_to("Edit this Label Profile", url('labelprofiles.edit', uuid=profile.uuid))}</li>
|
<li>${h.link_to("Edit this Label Profile", url('labelprofiles.edit', uuid=profile.uuid))}</li>
|
||||||
</%def>
|
</%def>
|
||||||
|
|
||||||
<div class="form-wrapper">
|
|
||||||
|
|
||||||
<ul class="context-menu">
|
${parent.body()}
|
||||||
${self.context_menu_items()}
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
<div class="form">
|
|
||||||
|
|
||||||
<div class="field-wrapper">
|
|
||||||
<label>Label Profile</label>
|
|
||||||
<div class="field">${profile.description}</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="field-wrapper">
|
|
||||||
<label>Printer Spec</label>
|
|
||||||
<div class="field">${profile.printer_spec}</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
${h.form(request.current_route_url())}
|
|
||||||
${h.csrf_token(request)}
|
|
||||||
|
|
||||||
% for name, display in printer.required_settings.items():
|
|
||||||
<div class="field-wrapper">
|
|
||||||
<label for="${name}">${display}</label>
|
|
||||||
<div class="field">
|
|
||||||
${h.text(name, value=profile.get_printer_setting(name))}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
% endfor
|
|
||||||
|
|
||||||
<div class="buttons">
|
|
||||||
${h.submit('update', "Update")}
|
|
||||||
<button type="button" onclick="location.href = '${url('labelprofiles.view', uuid=profile.uuid)}';">Cancel</button>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
${h.end_form()}
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
################################################################################
|
################################################################################
|
||||||
#
|
#
|
||||||
# Rattail -- Retail Software Framework
|
# Rattail -- Retail Software Framework
|
||||||
# Copyright © 2010-2018 Lance Edgar
|
# Copyright © 2010-2019 Lance Edgar
|
||||||
#
|
#
|
||||||
# This file is part of Rattail.
|
# This file is part of Rattail.
|
||||||
#
|
#
|
||||||
|
@ -28,9 +28,9 @@ from __future__ import unicode_literals, absolute_import
|
||||||
|
|
||||||
from rattail.db import model
|
from rattail.db import model
|
||||||
|
|
||||||
from pyramid.httpexceptions import HTTPFound
|
import colander
|
||||||
|
|
||||||
from tailbone.db import Session
|
from tailbone import forms
|
||||||
from tailbone.views import MasterView
|
from tailbone.views import MasterView
|
||||||
|
|
||||||
|
|
||||||
|
@ -87,40 +87,83 @@ class ProfilesView(MasterView):
|
||||||
except NotImplementedError:
|
except NotImplementedError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
def make_printer_settings_form(self, profile, printer):
|
||||||
|
schema = colander.Schema()
|
||||||
|
|
||||||
def printer_settings(request):
|
for name, label in printer.required_settings.items():
|
||||||
uuid = request.matchdict['uuid']
|
node = colander.SchemaNode(colander.String(),
|
||||||
profile = Session.query(model.LabelProfile).get(uuid) if uuid else None
|
name=name,
|
||||||
if not profile:
|
title=label,
|
||||||
return HTTPFound(location=request.route_url('labelprofiles'))
|
default=profile.get_printer_setting(name))
|
||||||
|
schema.add(node)
|
||||||
|
|
||||||
read_profile = HTTPFound(location=request.route_url(
|
form = forms.Form(schema=schema, request=self.request,
|
||||||
'labelprofiles.view', uuid=profile.uuid))
|
model_instance=profile,
|
||||||
|
# TODO: ugh, this is necessary to avoid some logic
|
||||||
|
# which assumes a ColanderAlchemy schema i think?
|
||||||
|
appstruct=None)
|
||||||
|
form.cancel_url = self.get_action_url('view', profile)
|
||||||
|
|
||||||
printer = profile.get_printer(request.rattail_config)
|
form.insert_before(schema.children[0].name, 'label_profile')
|
||||||
if not printer:
|
form.set_readonly('label_profile')
|
||||||
request.session.flash("Label profile \"%s\" does not have a functional "
|
form.set_renderer('label_profile', lambda p, f: p.description)
|
||||||
"printer spec." % profile)
|
|
||||||
return read_profile
|
|
||||||
if not printer.required_settings:
|
|
||||||
request.session.flash("Printer class for label profile \"%s\" does not "
|
|
||||||
"require any settings." % profile)
|
|
||||||
return read_profile
|
|
||||||
|
|
||||||
if request.method == 'POST':
|
form.insert_after('label_profile', 'printer_spec')
|
||||||
for setting in printer.required_settings:
|
form.set_readonly('printer_spec')
|
||||||
if setting in request.POST:
|
form.set_renderer('printer_spec', lambda p, f: p.printer_spec)
|
||||||
profile.save_printer_setting(setting, request.POST[setting])
|
|
||||||
return read_profile
|
|
||||||
|
|
||||||
return {'profile': profile, 'printer': printer}
|
return form
|
||||||
|
|
||||||
|
def printer_settings(self):
|
||||||
|
"""
|
||||||
|
View for editing extended Printer Settings, for a given Label Profile.
|
||||||
|
"""
|
||||||
|
profile = self.get_instance()
|
||||||
|
read_profile = self.redirect(self.get_action_url('view', profile))
|
||||||
|
|
||||||
|
printer = profile.get_printer(self.rattail_config)
|
||||||
|
if not printer:
|
||||||
|
msg = "Label profile \"{}\" does not have a functional printer spec.".format(profile)
|
||||||
|
self.request.session.flash(msg)
|
||||||
|
return read_profile
|
||||||
|
if not printer.required_settings:
|
||||||
|
msg = "Printer class for label profile \"{}\" does not require any settings.".format(profile)
|
||||||
|
self.request.session.flash(msg)
|
||||||
|
return read_profile
|
||||||
|
|
||||||
|
form = self.make_printer_settings_form(profile, printer)
|
||||||
|
|
||||||
|
# TODO: should use form.validate() here
|
||||||
|
if self.request.method == 'POST':
|
||||||
|
for setting in printer.required_settings:
|
||||||
|
if setting in self.request.POST:
|
||||||
|
profile.save_printer_setting(setting, self.request.POST[setting])
|
||||||
|
return read_profile
|
||||||
|
|
||||||
|
return self.render_to_response('printer', {
|
||||||
|
'form': form,
|
||||||
|
'dform': form.make_deform_form(),
|
||||||
|
'profile': profile,
|
||||||
|
'printer': printer,
|
||||||
|
})
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def defaults(cls, config):
|
||||||
|
cls._defaults(config)
|
||||||
|
cls._labelprofile_defaults(config)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def _labelprofile_defaults(cls, config):
|
||||||
|
route_prefix = cls.get_route_prefix()
|
||||||
|
url_prefix = cls.get_url_prefix()
|
||||||
|
permission_prefix = cls.get_permission_prefix()
|
||||||
|
model_key = cls.get_model_key()
|
||||||
|
|
||||||
|
# edit printer settings
|
||||||
|
config.add_route('{}.printer_settings'.format(route_prefix), '{}/{{{}}}/printer'.format(url_prefix, model_key))
|
||||||
|
config.add_view(cls, attr='printer_settings', route_name='{}.printer_settings'.format(route_prefix),
|
||||||
|
permission='{}.edit'.format(permission_prefix))
|
||||||
|
|
||||||
|
|
||||||
def includeme(config):
|
def includeme(config):
|
||||||
ProfilesView.defaults(config)
|
ProfilesView.defaults(config)
|
||||||
|
|
||||||
# edit printer settings
|
|
||||||
config.add_route('labelprofiles.printer_settings', '/labels/profiles/{uuid}/printer')
|
|
||||||
config.add_view(printer_settings, route_name='labelprofiles.printer_settings',
|
|
||||||
renderer='/labels/profiles/printer.mako',
|
|
||||||
permission='labelprofiles.edit')
|
|
||||||
|
|
Loading…
Reference in a new issue