|
|
|
@ -3,6 +3,7 @@ from django.contrib.auth.models import AbstractBaseUser, BaseUserManager
|
|
|
|
|
from django.contrib.auth.models import User
|
|
|
|
|
from skyonnadmin.models import InternalTeam
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class CustomUserManager(BaseUserManager):
|
|
|
|
|
def create_user(self, phone, password=None, **extra_fields):
|
|
|
|
|
if not phone:
|
|
|
|
@ -69,26 +70,26 @@ class CustomUser(AbstractBaseUser):
|
|
|
|
|
|
|
|
|
|
class JobPosting(models.Model):
|
|
|
|
|
Client = models.CharField(max_length=100, null=True, blank=True)
|
|
|
|
|
JobID = models.CharField(max_length=100,null=True)
|
|
|
|
|
Location = models.CharField(max_length=255,null=True)
|
|
|
|
|
SPOC = models.CharField(max_length=255,null=True)
|
|
|
|
|
JobID = models.CharField(max_length=100, null=True)
|
|
|
|
|
Location = models.CharField(max_length=255, null=True)
|
|
|
|
|
SPOC = models.CharField(max_length=255, null=True)
|
|
|
|
|
SPOC2 = models.CharField(max_length=255, blank=True, null=True)
|
|
|
|
|
NoOfPosting = models.IntegerField(null=True)
|
|
|
|
|
StartDate = models.DateField(null=True)
|
|
|
|
|
CloseDate = models.DateField(null=True)
|
|
|
|
|
|
|
|
|
|
BudgetMin = models.CharField(max_length=20,null=True)
|
|
|
|
|
timePeriod = models.CharField(max_length=20,null=True,blank=True)
|
|
|
|
|
minAmount = models.CharField(max_length=20,null=True)
|
|
|
|
|
maxAmount = models.CharField(max_length=20,null=True)
|
|
|
|
|
BudgetMin = models.CharField(max_length=20, null=True)
|
|
|
|
|
timePeriod = models.CharField(max_length=20, null=True, blank=True)
|
|
|
|
|
minAmount = models.CharField(max_length=20, null=True)
|
|
|
|
|
maxAmount = models.CharField(max_length=20, null=True)
|
|
|
|
|
|
|
|
|
|
Qualification = models.CharField(max_length=100,null=True)
|
|
|
|
|
Header = models.CharField(max_length=255,null=True)
|
|
|
|
|
Qualification = models.CharField(max_length=100, null=True)
|
|
|
|
|
Header = models.CharField(max_length=255, null=True)
|
|
|
|
|
JobDescription = models.TextField(null=True)
|
|
|
|
|
Experience_in_Yrs = models.CharField(max_length=50,null=True)
|
|
|
|
|
Experience_in_Yrs = models.CharField(max_length=50, null=True)
|
|
|
|
|
SpecialInstructions = models.TextField(blank=True, null=True)
|
|
|
|
|
JD = models.FileField(upload_to='JD/', null= True)
|
|
|
|
|
slice_JD = models.CharField(max_length=255,null=True)
|
|
|
|
|
JD = models.FileField(upload_to='JD/', null=True)
|
|
|
|
|
slice_JD = models.CharField(max_length=255, null=True)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# class SPOC(models.Model):
|
|
|
|
@ -98,18 +99,19 @@ class JobPosting(models.Model):
|
|
|
|
|
# return self.name
|
|
|
|
|
|
|
|
|
|
class Message(models.Model):
|
|
|
|
|
message_id = models.CharField(unique=True,max_length=255, null=True)
|
|
|
|
|
sender = models.ForeignKey(InternalTeam, related_name='sent_messages',to_field='Email1', on_delete=models.CASCADE)
|
|
|
|
|
message_id = models.CharField(unique=True, max_length=255, null=True)
|
|
|
|
|
sender = models.ForeignKey(InternalTeam, related_name='sent_messages', to_field='Email1', on_delete=models.CASCADE)
|
|
|
|
|
recipient = models.ManyToManyField(InternalTeam, related_name='received_messages')
|
|
|
|
|
subject = models.CharField(max_length=255)
|
|
|
|
|
body = models.TextField()
|
|
|
|
|
is_read = models.BooleanField(default=False)
|
|
|
|
|
sent_at = models.DateTimeField(auto_now_add=True)
|
|
|
|
|
sender_fullname = models.CharField(max_length=255,null=True)
|
|
|
|
|
recipient_fullname = models.CharField(max_length=255,null=True)
|
|
|
|
|
reply_to = models.ForeignKey('self',null=True,blank=True,on_delete=models.CASCADE,related_name='replies', to_field='message_id')
|
|
|
|
|
sender_fullname = models.CharField(max_length=255, null=True)
|
|
|
|
|
recipient_fullname = models.CharField(max_length=255, null=True)
|
|
|
|
|
reply_to = models.ForeignKey('self', null=True, blank=True, on_delete=models.CASCADE, related_name='replies',
|
|
|
|
|
to_field='message_id')
|
|
|
|
|
is_trashed = models.BooleanField(default=False)
|
|
|
|
|
attachment = models.FileField(upload_to='attachment/',null=True,blank=True)
|
|
|
|
|
attachment = models.FileField(upload_to='attachment/', null=True, blank=True)
|
|
|
|
|
seen_time = models.DateTimeField(null=True, blank=True)
|
|
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
@ -118,18 +120,20 @@ class Message(models.Model):
|
|
|
|
|
class Meta:
|
|
|
|
|
ordering = ['-sent_at']
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class MessageStatus(models.Model):
|
|
|
|
|
message = models.ForeignKey(Message, on_delete=models.CASCADE, to_field='message_id', related_name='status')
|
|
|
|
|
user = models.ForeignKey(InternalTeam, on_delete=models.CASCADE, to_field='Email1', null=True)
|
|
|
|
|
is_read = models.BooleanField(default=False)
|
|
|
|
|
seen_time = models.DateTimeField(null=True, blank=True)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class FileDownload(models.Model):
|
|
|
|
|
# Reference to the message containing the attachment
|
|
|
|
|
message = models.ForeignKey(Message, on_delete=models.CASCADE,to_field='message_id', related_name='downloads')
|
|
|
|
|
user = models.ForeignKey(InternalTeam, on_delete=models.CASCADE,to_field='Email1',null=True)
|
|
|
|
|
message = models.ForeignKey(Message, on_delete=models.CASCADE, to_field='message_id', related_name='downloads')
|
|
|
|
|
user = models.ForeignKey(InternalTeam, on_delete=models.CASCADE, to_field='Email1', null=True)
|
|
|
|
|
first_downloaded = models.DateTimeField(auto_now_add=True)
|
|
|
|
|
last_downloaded = models.DateTimeField(auto_now=True)
|
|
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
|
return f"Download details for message_id: {self.message.message_id}"
|
|
|
|
|
return f"Download details for message_id: {self.message.message_id}"
|
|
|
|
|