Source code for stoqlib.domain.payment.category
# -*- coding: utf-8 -*-
# vi:si:et:sw=4:sts=4:ts=4
##
## Copyright (C) 2008-2013 Async Open Source <http://www.async.com.br>
## All rights reserved
##
## This program is free software; you can redistribute it and/or modify
## it under the terms of the GNU Lesser General Public License as published by
## the Free Software Foundation; either version 2 of the License, or
## (at your option) any later version.
##
## This program 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 Lesser General Public License for more details.
##
## You should have received a copy of the GNU Lesser General Public License
## along with this program; if not, write to the Free Software
## Foundation, Inc., or visit: http://www.gnu.org/.
##
## Author(s): Stoq Team <stoq-devel@async.com.br>
##
"""Payment category, user defined grouping of payments
"""
# pylint: enable=E1101
from zope.interface import implementer
from stoqlib.database.properties import EnumCol, UnicodeCol
from stoqlib.domain.base import Domain
from stoqlib.domain.interfaces import IDescribable
@implementer(IDescribable)
[docs]class PaymentCategory(Domain):
"""I am a payment category.
I contain a name and a color
"""
__storm_table__ = 'payment_category'
#: for outgoing payments (payable application)
TYPE_PAYABLE = u'payable'
#: for incoming payments (receivable application)
TYPE_RECEIVABLE = u'receivable'
#: category name
name = UnicodeCol()
#: category color, like #ff0000 for red.
color = UnicodeCol()
#: category type, payable or receivable
category_type = EnumCol(allow_none=False, default=TYPE_PAYABLE)
#
# IDescribable implementation
#
def get_description(self):
return self.name
@classmethod
[docs] def get_by_type(cls, store, category_type):
"""Fetches a list of PaymentCategories given a category type
:param store: a store
:param category_type: TYPE_PAYABLE or TYPE_RECEIVABLE
:rseturns: a sequence of PaymentCategory ordered by name
"""
return store.find(cls, category_type=category_type).order_by(
PaymentCategory.name)