tailbone/tailbone/views/subdepartments.py
Lance Edgar 719e7c8441 Normalize naming of all traditional master views
such names should never use plural forms.  for now what plural forms were
previously in use, should still work.  ideally can remove those at some point
2021-01-28 16:32:25 -06:00

107 lines
3 KiB
Python

# -*- coding: utf-8; -*-
################################################################################
#
# Rattail -- Retail Software Framework
# Copyright © 2010-2021 Lance Edgar
#
# This file is part of Rattail.
#
# Rattail is free software: you can redistribute it and/or modify it under the
# terms of the GNU General Public License as published by the Free Software
# Foundation, either version 3 of the License, or (at your option) any later
# version.
#
# Rattail is distributed in the hope that it will be useful, but WITHOUT ANY
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
# details.
#
# You should have received a copy of the GNU General Public License along with
# Rattail. If not, see <http://www.gnu.org/licenses/>.
#
################################################################################
"""
Subdepartment Views
"""
from __future__ import unicode_literals, absolute_import
from rattail.db import model
from tailbone.db import Session
from tailbone.views import MasterView
class SubdepartmentView(MasterView):
"""
Master view for the Subdepartment class.
"""
model_class = model.Subdepartment
touchable = True
has_versions = True
grid_columns = [
'number',
'name',
'department',
]
mergeable = True
merge_additive_fields = [
'product_count',
]
merge_fields = merge_additive_fields + [
'uuid',
'number',
'name',
'department_number',
]
def configure_grid(self, g):
super(SubdepartmentView, self).configure_grid(g)
# name
g.filters['name'].default_active = True
g.filters['name'].default_verb = 'contains'
g.set_sort_defaults('name')
# department (name)
g.set_joiner('department', lambda q: q.outerjoin(model.Department))
g.set_sorter('department', model.Department.name)
g.set_filter('department', model.Department.name)
g.set_link('number')
g.set_link('name')
def configure_form(self, f):
super(SubdepartmentView, self).configure_form(f)
f.remove_field('products')
# TODO: figure out this dang department situation..
f.remove_field('department_uuid')
f.set_readonly('department')
def get_merge_data(self, subdept):
return {
'uuid': subdept.uuid,
'number': subdept.number,
'name': subdept.name,
'department_number': subdept.department.number if subdept.department else None,
'product_count': len(subdept.products),
}
def merge_objects(self, removing, keeping):
# merge products
for product in removing.products:
product.subdepartment = keeping
Session.delete(removing)
# TODO: deprecate / remove this
SubdepartmentsView = SubdepartmentView
def includeme(config):
SubdepartmentView.defaults(config)