24# added messages2
This commit is contained in:
parent
193eb7c8af
commit
ab903cb966
@ -57,7 +57,7 @@
|
||||
</button>
|
||||
<div class="dropdown-menu">
|
||||
<a class="dropdown-item" href="#">My jobs</a>
|
||||
<a class="dropdown-item" href="">You have {{ user.count_unread_messages }} message(s)</a>
|
||||
<a class="dropdown-item" href="{% url 'users:employer_messages' pk=user.pk %}">You have {{ user.count_unread_messages }} message(s)</a>
|
||||
<a class="dropdown-item" href="">My wish list</a>
|
||||
<a class="dropdown-item" href="{% url 'users:update_profile' pk=user.get_profile_id %}">Update profile</a>
|
||||
<a class="dropdown-item" href="">Change password</a>
|
||||
|
251
templates/users/employee-messages.html
Normal file
251
templates/users/employee-messages.html
Normal file
@ -0,0 +1,251 @@
|
||||
{% extends 'base.html' %}
|
||||
{% load static %}
|
||||
{% block content %}
|
||||
|
||||
<div class="hero-wrap js-fullheight" style="background-image: url('{% static 'images/bg_2.jpg' %}');" data-stellar-background-ratio="0.5">
|
||||
<div class="overlay"></div>
|
||||
<div class="container">
|
||||
<div class="row no-gutters slider-text js-fullheight align-items-center justify-content-start" data-scrollax-parent="true">
|
||||
<div class="col-xl-10 ftco-animate mb-5 pb-5" data-scrollax=" properties: { translateY: '70%' }">
|
||||
<p class="mb-4 mt-5 pt-5" data-scrollax="properties: { translateY: '30%', opacity: 1.6 }">We have <span class="number" data-number="850000">0</span> great job offers you deserve!</p>
|
||||
<h1 class="mb-5" data-scrollax="properties: { translateY: '30%', opacity: 1.6 }">Your Dream <br><span>Job is Waiting</span></h1>
|
||||
|
||||
<div class="ftco-search">
|
||||
<div class="row">
|
||||
<div class="col-md-12 nav-link-wrap">
|
||||
<div class="nav nav-pills text-center" id="v-pills-tab" role="tablist" aria-orientation="vertical">
|
||||
<a class="nav-link active mr-md-1" id="v-pills-1-tab" data-toggle="pill" href="#v-pills-1" role="tab" aria-controls="v-pills-1" aria-selected="true">Find a Job</a>
|
||||
|
||||
<a class="nav-link" id="v-pills-2-tab" data-toggle="pill" href="#v-pills-2" role="tab" aria-controls="v-pills-2" aria-selected="false">Find a Candidate</a>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-md-12 tab-wrap">
|
||||
|
||||
<div class="tab-content p-4" id="v-pills-tabContent">
|
||||
|
||||
<div class="tab-pane fade show active" id="v-pills-1" role="tabpanel" aria-labelledby="v-pills-nextgen-tab">
|
||||
<form action="{% url 'jobs:search' %}" class="search-job" method="get">
|
||||
<div class="row">
|
||||
<div class="col-md">
|
||||
<div class="form-group">
|
||||
<div class="form-field">
|
||||
<div class="icon"><span class="icon-briefcase"></span></div>
|
||||
<input type="text" name="job_title" class="form-control" placeholder="eg. Garphic. Web Developer">
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-md">
|
||||
<div class="form-group">
|
||||
<div class="form-field">
|
||||
<div class="select-wrap">
|
||||
<div class="icon"><span class="ion-ios-arrow-down"></span></div>
|
||||
<select name="job_type" id="" class="form-control">
|
||||
<option value="full_time">Full Time</option>
|
||||
<option value="part_time">Part Time</option>
|
||||
<option value="freelance">Freelance</option>
|
||||
<option value="internship">Internship</option>
|
||||
<option value="temporary">Temporary</option>
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-md">
|
||||
<div class="form-group">
|
||||
<div class="form-field">
|
||||
<div class="icon"><span class="icon-map-marker"></span></div>
|
||||
<input type="text" name="job_location" class="form-control" placeholder="Location">
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-md">
|
||||
<div class="form-group">
|
||||
<div class="form-field">
|
||||
<input type="submit" value="Search" class="form-control btn btn-primary">
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
|
||||
<div class="tab-pane fade" id="v-pills-2" role="tabpanel" aria-labelledby="v-pills-performance-tab">
|
||||
<form action="#" class="search-job">
|
||||
<div class="row">
|
||||
<div class="col-md">
|
||||
<div class="form-group">
|
||||
<div class="form-field">
|
||||
<div class="icon"><span class="icon-user"></span></div>
|
||||
<input type="text" class="form-control" placeholder="eg. Adam Scott">
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-md">
|
||||
<div class="form-group">
|
||||
<div class="form-field">
|
||||
<div class="select-wrap">
|
||||
<div class="icon"><span class="ion-ios-arrow-down"></span></div>
|
||||
<select name="" id="" class="form-control">
|
||||
<option value="">Category</option>
|
||||
<option value="">Full Time</option>
|
||||
<option value="">Part Time</option>
|
||||
<option value="">Freelance</option>
|
||||
<option value="">Internship</option>
|
||||
<option value="">Temporary</option>
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-md">
|
||||
<div class="form-group">
|
||||
<div class="form-field">
|
||||
<div class="icon"><span class="icon-map-marker"></span></div>
|
||||
<input type="text" class="form-control" placeholder="Location">
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-md">
|
||||
<div class="form-group">
|
||||
<div class="form-field">
|
||||
<input type="submit" value="Search" class="form-control btn btn-primary">
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<section class="ftco-section bg-light">
|
||||
<div class="container">
|
||||
<div class="row justify-content-center mb-5 pb-3">
|
||||
{% if user.is_employee %}
|
||||
<div class="col-md-7 heading-section text-center ftco-animate">
|
||||
<h2 class="mb-4"><span>Recent</span> messages</h2>
|
||||
<span class="subheading">You have {{ paginator.count }} messages</span>
|
||||
</div>
|
||||
</div>
|
||||
<div class="row">
|
||||
{% for job in jobs %}
|
||||
<div class="col-md-12 ftco-animate">
|
||||
<div class="job-post-item bg-white p-4 d-block d-md-flex align-items-center">
|
||||
|
||||
<div class="mb-4 mb-md-0 mr-5">
|
||||
<div class="job-post-item-header d-flex align-items-center">
|
||||
<h2 class="mr-3 text-black h4">{{ job.title }}</h2>
|
||||
<div class="badge-wrap">
|
||||
{% if job.job_type == 'full_time' %}
|
||||
<span class="bg-warning text-white badge py-2 px-3">Full Time</span>
|
||||
{% elif job.job_type == 'part_time'%}
|
||||
<span class="bg-info text-white badge py-2 px-3">Part Time</span>
|
||||
{% elif job.job_type == 'freelance'%}
|
||||
<span class="bg-primary text-white badge py-2 px-3">Freelance</span>
|
||||
{% elif job.job_type == 'internship'%}
|
||||
<span class="bg-secondary text-white badge py-2 px-3">Internship</span>
|
||||
{% elif job.job_type == 'temporary'%}
|
||||
<span class="bg-danger text-white badge py-2 px-3">Temporary</span>
|
||||
{% endif %}
|
||||
</div>
|
||||
</div>
|
||||
<div class="job-post-item-body d-block d-md-flex">
|
||||
<div class="mr-3"><span class="icon-layers"></span> <a href="#">{{ job.company }}</a></div>
|
||||
<div><span class="icon-my_location"></span> <span>{{ job.location }}</span></div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="ml-auto d-flex">
|
||||
<a href="{% url 'jobs:single_job' job.slug job.pk %}" class="btn btn-primary py-2 mr-1">Read message</a>
|
||||
</div>
|
||||
</div>
|
||||
</div> <!-- end -->
|
||||
{% endfor %}
|
||||
</div>
|
||||
<div class="row mt-5">
|
||||
{% if is_paginated %}
|
||||
<div class="col text-center">
|
||||
<div class="block-27">
|
||||
<ul>
|
||||
{% if page_obj.has_previous %}
|
||||
<li><a href="?page={{ page_obj.previous_page_number }}"><</a></li>
|
||||
{% else %}
|
||||
<li class="disabled"><span><</span></li>
|
||||
{% endif %}
|
||||
{% for i in paginator.page_range %}
|
||||
{% if page_obj.number == i %}
|
||||
<li class="active"><span>{{ i }}</span></li>
|
||||
{% else %}
|
||||
<li><a href="?page={{ i }}">{{ i }}</a></li>
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
{% if page_obj.has_next %}
|
||||
<li><a href="?page={{ page_obj.next_page_number }}">></a></li>
|
||||
{% else %}
|
||||
<li class="disabled"><span>></span></li>
|
||||
{% endif %}
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
{% endif %}
|
||||
</div>
|
||||
{% else %}
|
||||
<div class="row justify-content-center mb-5 pb-3">
|
||||
<div class="col-md-7 heading-section text-center ftco-animate">
|
||||
<h4>You are not an employee.</h4>
|
||||
</div>
|
||||
</div>
|
||||
{% endif %}
|
||||
</div>
|
||||
</section>
|
||||
|
||||
<section class="ftco-section ftco-counter img" id="section-counter" style="background-image: url(images/bg_1.jpg);" data-stellar-background-ratio="0.5">
|
||||
<div class="container">
|
||||
<div class="row justify-content-center">
|
||||
<div class="col-md-10">
|
||||
<div class="row">
|
||||
<div class="col-md-3 d-flex justify-content-center counter-wrap ftco-animate">
|
||||
<div class="block-18 text-center">
|
||||
<div class="text">
|
||||
<strong class="number" data-number="1350000">0</strong>
|
||||
<span>Jobs</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-md-3 d-flex justify-content-center counter-wrap ftco-animate">
|
||||
<div class="block-18 text-center">
|
||||
<div class="text">
|
||||
<strong class="number" data-number="40000">0</strong>
|
||||
<span>Members</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-md-3 d-flex justify-content-center counter-wrap ftco-animate">
|
||||
<div class="block-18 text-center">
|
||||
<div class="text">
|
||||
<strong class="number" data-number="30000">0</strong>
|
||||
<span>Resume</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="col-md-3 d-flex justify-content-center counter-wrap ftco-animate">
|
||||
<div class="block-18 text-center">
|
||||
<div class="text">
|
||||
<strong class="number" data-number="10500">0</strong>
|
||||
<span>Company</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</section>
|
||||
{% endblock %}
|
@ -9,4 +9,5 @@ urlpatterns = [
|
||||
path('update-profile/<int:pk>/', UserUpdateView.as_view(), name='update_profile'),
|
||||
path('employee-profile/<int:employee_id>/<int:job_id>/', EmployeeProfileView.as_view(), name='employee_profile'),
|
||||
path('employer-jobs/', EmployerPostedJobsView.as_view(), name='employer_jobs'),
|
||||
path('employee-messages/<int:pk>/', EmployeeMessagesView.as_view(), name='employer_messages'),
|
||||
]
|
||||
|
@ -93,3 +93,14 @@ class EmployerPostedJobsView(ListView):
|
||||
|
||||
def get_queryset(self):
|
||||
return Job.objects.filter(employer=self.request.user).order_by('-id')
|
||||
|
||||
|
||||
@method_decorator(login_required(login_url='/users/login'), name='dispatch')
|
||||
class EmployeeMessagesView(ListView):
|
||||
model = Job
|
||||
template_name = 'users/employee-messages.html'
|
||||
paginate_by = 5
|
||||
context_object_name = 'jobs'
|
||||
|
||||
def get_queryset(self):
|
||||
return Job.objects.filter(invites__isnull=False, invites__user_id=self.request.user).order_by('-invites')
|
||||
|
Loading…
Reference in New Issue
Block a user