Merge branch 'master' of https://github.com/horilla-opensource/horilla
This commit is contained in:
@@ -117,6 +117,13 @@ class HorillaModel(models.Model):
|
||||
objects = models.Manager()
|
||||
is_active = models.BooleanField(default=True, verbose_name=_("Is Active"))
|
||||
|
||||
@property
|
||||
def get_created_at_date(self):
|
||||
"""
|
||||
get_created_at_date
|
||||
"""
|
||||
return self.created_at.date()
|
||||
|
||||
class Meta:
|
||||
"""
|
||||
Meta class for HorillaModel
|
||||
|
||||
@@ -0,0 +1,54 @@
|
||||
import re
|
||||
|
||||
from base.methods import eval_validate
|
||||
from base.models import *
|
||||
from employee.models import *
|
||||
|
||||
|
||||
def get_next_badge_id():
|
||||
"""
|
||||
This method is used to generate badge id
|
||||
"""
|
||||
from base.context_processors import get_initial_prefix
|
||||
from employee.methods.methods import get_ordered_badge_ids
|
||||
|
||||
prefix = get_initial_prefix(None)["get_initial_prefix"]
|
||||
data = get_ordered_badge_ids()
|
||||
result = []
|
||||
try:
|
||||
for sublist in data:
|
||||
for item in sublist:
|
||||
if isinstance(item, str) and item.lower().startswith(prefix.lower()):
|
||||
# Find the index of the item in the sublist
|
||||
index = sublist.index(item)
|
||||
# Check if there is a next item in the sublist
|
||||
if index + 1 < len(sublist):
|
||||
result = sublist[index + 1]
|
||||
result = re.findall(r"[a-zA-Z]+|\d+|[^a-zA-Z\d\s]", result)
|
||||
|
||||
if result:
|
||||
prefix = []
|
||||
incremented = False
|
||||
for item in reversed(result):
|
||||
total_letters = len(item)
|
||||
total_zero_leads = 0
|
||||
for letter in item:
|
||||
if letter == "0":
|
||||
total_zero_leads = total_zero_leads + 1
|
||||
continue
|
||||
break
|
||||
|
||||
if total_zero_leads:
|
||||
item = item[total_zero_leads:]
|
||||
if isinstance(item, list):
|
||||
item = item[-1]
|
||||
if not incremented and isinstance(eval_validate(str(item)), int):
|
||||
item = int(item) + 1
|
||||
incremented = True
|
||||
if isinstance(item, int):
|
||||
item = "{:0{}d}".format(item, total_letters)
|
||||
prefix.insert(0, str(item))
|
||||
prefix = "".join(prefix)
|
||||
except Exception as e:
|
||||
prefix = get_initial_prefix(None)["get_initial_prefix"]
|
||||
return prefix
|
||||
|
||||
Reference in New Issue
Block a user