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
					
				
					 3 changed files with 86 additions and 73 deletions
				
			
		| 
						 | 
				
			
			@ -2,7 +2,7 @@
 | 
			
		|||
################################################################################
 | 
			
		||||
#
 | 
			
		||||
#  Rattail -- Retail Software Framework
 | 
			
		||||
#  Copyright © 2010-2018 Lance Edgar
 | 
			
		||||
#  Copyright © 2010-2019 Lance Edgar
 | 
			
		||||
#
 | 
			
		||||
#  This file is part of Rattail.
 | 
			
		||||
#
 | 
			
		||||
| 
						 | 
				
			
			@ -28,9 +28,9 @@ from __future__ import unicode_literals, absolute_import
 | 
			
		|||
 | 
			
		||||
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
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -87,40 +87,83 @@ class ProfilesView(MasterView):
 | 
			
		|||
                except NotImplementedError:
 | 
			
		||||
                    pass
 | 
			
		||||
 | 
			
		||||
    def make_printer_settings_form(self, profile, printer):
 | 
			
		||||
        schema = colander.Schema()
 | 
			
		||||
 | 
			
		||||
def printer_settings(request):
 | 
			
		||||
    uuid = request.matchdict['uuid']
 | 
			
		||||
    profile = Session.query(model.LabelProfile).get(uuid) if uuid else None
 | 
			
		||||
    if not profile:
 | 
			
		||||
        return HTTPFound(location=request.route_url('labelprofiles'))
 | 
			
		||||
        for name, label in printer.required_settings.items():
 | 
			
		||||
            node = colander.SchemaNode(colander.String(),
 | 
			
		||||
                                       name=name,
 | 
			
		||||
                                       title=label,
 | 
			
		||||
                                       default=profile.get_printer_setting(name))
 | 
			
		||||
            schema.add(node)
 | 
			
		||||
 | 
			
		||||
    read_profile = HTTPFound(location=request.route_url(
 | 
			
		||||
            'labelprofiles.view', uuid=profile.uuid))
 | 
			
		||||
        form = forms.Form(schema=schema, request=self.request,
 | 
			
		||||
                          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)
 | 
			
		||||
    if not printer:
 | 
			
		||||
        request.session.flash("Label profile \"%s\" does not have a functional "
 | 
			
		||||
                              "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
 | 
			
		||||
        form.insert_before(schema.children[0].name, 'label_profile')
 | 
			
		||||
        form.set_readonly('label_profile')
 | 
			
		||||
        form.set_renderer('label_profile', lambda p, f: p.description)
 | 
			
		||||
 | 
			
		||||
    if request.method == 'POST':
 | 
			
		||||
        for setting in printer.required_settings:
 | 
			
		||||
            if setting in request.POST:
 | 
			
		||||
                profile.save_printer_setting(setting, request.POST[setting])
 | 
			
		||||
        return read_profile
 | 
			
		||||
        form.insert_after('label_profile', 'printer_spec')
 | 
			
		||||
        form.set_readonly('printer_spec')
 | 
			
		||||
        form.set_renderer('printer_spec', lambda p, f: p.printer_spec)
 | 
			
		||||
 | 
			
		||||
    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):
 | 
			
		||||
    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…
	
	Add table
		Add a link
		
	
		Reference in a new issue