# -*- coding: utf-8 -*- # import uuid from django.db import models from django.utils.translation import ugettext_lazy as _ class Label(models.Model): SYSTEM_CATEGORY = "S" USER_CATEGORY = "U" CATEGORY_CHOICES = ( ("S", _("System")), ("U", _("User")) ) id = models.UUIDField(default=uuid.uuid4, primary_key=True) name = models.CharField(max_length=128, verbose_name=_("Name")) value = models.CharField(max_length=128, verbose_name=_("Value")) category = models.CharField(max_length=128, choices=CATEGORY_CHOICES, default=USER_CATEGORY, verbose_name=_("Category")) is_active = models.BooleanField(default=True, verbose_name=_("Is active")) comment = models.TextField(blank=True, null=True, verbose_name=_("Comment")) date_created = models.DateTimeField( auto_now_add=True, null=True, blank=True, verbose_name=_('Date created') ) @classmethod def get_queryset_group_by_name(cls): names = cls.objects.values_list('name', flat=True) for name in names: yield name, cls.objects.filter(name=name) def __str__(self): return "{}:{}".format(self.name, self.value) class Meta: db_table = "assets_label" unique_together = [('name', 'value')]