Merge pull request #291 from pateljannat/jobs-improvement
This commit is contained in:
@@ -9,10 +9,10 @@
|
|||||||
"field_order": [
|
"field_order": [
|
||||||
"job_title",
|
"job_title",
|
||||||
"location",
|
"location",
|
||||||
|
"disabled",
|
||||||
"column_break_5",
|
"column_break_5",
|
||||||
"type",
|
"type",
|
||||||
"status",
|
"status",
|
||||||
"job_opportunity_status",
|
|
||||||
"section_break_6",
|
"section_break_6",
|
||||||
"description",
|
"description",
|
||||||
"company_details_section",
|
"company_details_section",
|
||||||
@@ -51,19 +51,12 @@
|
|||||||
"reqd": 1
|
"reqd": 1
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"default": "Pending",
|
"default": "Open",
|
||||||
"fieldname": "status",
|
"fieldname": "status",
|
||||||
"fieldtype": "Select",
|
"fieldtype": "Select",
|
||||||
"in_list_view": 1,
|
"in_list_view": 1,
|
||||||
"in_standard_filter": 1,
|
"in_standard_filter": 1,
|
||||||
"label": "Status",
|
"label": "Status",
|
||||||
"options": "Pending\nApproved\nRejected"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"default": "Open",
|
|
||||||
"fieldname": "job_opportunity_status",
|
|
||||||
"fieldtype": "Select",
|
|
||||||
"label": "Job Opportunity Status",
|
|
||||||
"options": "Open\nClosed"
|
"options": "Open\nClosed"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -109,11 +102,17 @@
|
|||||||
"fieldtype": "Data",
|
"fieldtype": "Data",
|
||||||
"label": "Application Form Link",
|
"label": "Application Form Link",
|
||||||
"reqd": 1
|
"reqd": 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"default": "0",
|
||||||
|
"fieldname": "disabled",
|
||||||
|
"fieldtype": "Check",
|
||||||
|
"label": "Disabled"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"index_web_pages_for_search": 1,
|
"index_web_pages_for_search": 1,
|
||||||
"links": [],
|
"links": [],
|
||||||
"modified": "2021-12-30 12:10:08.849547",
|
"modified": "2022-01-11 14:56:42.509351",
|
||||||
"modified_by": "Administrator",
|
"modified_by": "Administrator",
|
||||||
"module": "Job",
|
"module": "Job",
|
||||||
"name": "Job Opportunity",
|
"name": "Job Opportunity",
|
||||||
|
|||||||
@@ -1,8 +1,30 @@
|
|||||||
# Copyright (c) 2021, Frappe and contributors
|
# Copyright (c) 2021, Frappe and contributors
|
||||||
# For license information, please see license.txt
|
# For license information, please see license.txt
|
||||||
|
|
||||||
# import frappe
|
import frappe
|
||||||
from frappe.model.document import Document
|
from frappe.model.document import Document
|
||||||
|
from frappe.utils.user import get_system_managers
|
||||||
|
from frappe import _
|
||||||
|
from frappe.utils import get_link_to_form
|
||||||
|
|
||||||
class JobOpportunity(Document):
|
class JobOpportunity(Document):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
@frappe.whitelist()
|
||||||
|
def report(job, reason):
|
||||||
|
system_managers = get_system_managers(only_name=True)
|
||||||
|
user = frappe.db.get_value("User", frappe.session.user, "full_name")
|
||||||
|
subject = _("User {0} has reported the job post {1}").format(user, job)
|
||||||
|
args = {
|
||||||
|
"job": job,
|
||||||
|
"job_url": get_link_to_form("Job Opportunity", job),
|
||||||
|
"user": user,
|
||||||
|
"reason": reason
|
||||||
|
}
|
||||||
|
frappe.sendmail(
|
||||||
|
recipients = system_managers,
|
||||||
|
subject=subject,
|
||||||
|
header=[subject, "green"],
|
||||||
|
template = "job_report",
|
||||||
|
args=args,
|
||||||
|
now=True)
|
||||||
|
|||||||
0
school/job/doctype/job_settings/__init__.py
Normal file
0
school/job/doctype/job_settings/__init__.py
Normal file
8
school/job/doctype/job_settings/job_settings.js
Normal file
8
school/job/doctype/job_settings/job_settings.js
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
// Copyright (c) 2022, Frappe and contributors
|
||||||
|
// For license information, please see license.txt
|
||||||
|
|
||||||
|
frappe.ui.form.on('Job Settings', {
|
||||||
|
// refresh: function(frm) {
|
||||||
|
|
||||||
|
// }
|
||||||
|
});
|
||||||
42
school/job/doctype/job_settings/job_settings.json
Normal file
42
school/job/doctype/job_settings/job_settings.json
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
{
|
||||||
|
"actions": [],
|
||||||
|
"allow_rename": 1,
|
||||||
|
"creation": "2022-01-10 17:16:46.598673",
|
||||||
|
"doctype": "DocType",
|
||||||
|
"editable_grid": 1,
|
||||||
|
"engine": "InnoDB",
|
||||||
|
"field_order": [
|
||||||
|
"allow_posting"
|
||||||
|
],
|
||||||
|
"fields": [
|
||||||
|
{
|
||||||
|
"default": "0",
|
||||||
|
"fieldname": "allow_posting",
|
||||||
|
"fieldtype": "Check",
|
||||||
|
"label": "Allow Job Posting From Website"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"index_web_pages_for_search": 1,
|
||||||
|
"issingle": 1,
|
||||||
|
"links": [],
|
||||||
|
"modified": "2022-01-10 18:45:26.646438",
|
||||||
|
"modified_by": "Administrator",
|
||||||
|
"module": "Job",
|
||||||
|
"name": "Job Settings",
|
||||||
|
"owner": "Administrator",
|
||||||
|
"permissions": [
|
||||||
|
{
|
||||||
|
"create": 1,
|
||||||
|
"delete": 1,
|
||||||
|
"email": 1,
|
||||||
|
"print": 1,
|
||||||
|
"read": 1,
|
||||||
|
"role": "System Manager",
|
||||||
|
"share": 1,
|
||||||
|
"write": 1
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"sort_field": "modified",
|
||||||
|
"sort_order": "DESC",
|
||||||
|
"states": []
|
||||||
|
}
|
||||||
8
school/job/doctype/job_settings/job_settings.py
Normal file
8
school/job/doctype/job_settings/job_settings.py
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
# Copyright (c) 2022, Frappe and contributors
|
||||||
|
# For license information, please see license.txt
|
||||||
|
|
||||||
|
# import frappe
|
||||||
|
from frappe.model.document import Document
|
||||||
|
|
||||||
|
class JobSettings(Document):
|
||||||
|
pass
|
||||||
8
school/job/doctype/job_settings/test_job_settings.py
Normal file
8
school/job/doctype/job_settings/test_job_settings.py
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
# Copyright (c) 2022, Frappe and Contributors
|
||||||
|
# See license.txt
|
||||||
|
|
||||||
|
# import frappe
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
class TestJobSettings(unittest.TestCase):
|
||||||
|
pass
|
||||||
@@ -63,9 +63,8 @@ input[type=checkbox] {
|
|||||||
text-align: center;
|
text-align: center;
|
||||||
letter-spacing: 0.011em;
|
letter-spacing: 0.011em;
|
||||||
text-transform: uppercase;
|
text-transform: uppercase;
|
||||||
color: #2C5477;
|
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
box-shadow: 0px 5px 10px rgb(0 0 0 / 10%);
|
box-shadow: var(--shadow-base);
|
||||||
}
|
}
|
||||||
|
|
||||||
.dark-pills {
|
.dark-pills {
|
||||||
@@ -119,9 +118,7 @@ input[type=checkbox] {
|
|||||||
|
|
||||||
.card-heading {
|
.card-heading {
|
||||||
font-weight: 600;
|
font-weight: 600;
|
||||||
font-size: 1.5rem;
|
font-size: var(--text-3xl);
|
||||||
line-height: 156%;
|
|
||||||
letter-spacing: -0.014em;
|
|
||||||
color: var(--text-color-dark);
|
color: var(--text-color-dark);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1478,20 +1475,30 @@ pre {
|
|||||||
|
|
||||||
.job-card {
|
.job-card {
|
||||||
display: flex;
|
display: flex;
|
||||||
justify-content: space-between;
|
|
||||||
align-items: center;
|
|
||||||
padding-right: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.job-card-info {
|
|
||||||
padding: 2rem 1rem 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.job-description-section {
|
|
||||||
padding: 1rem;
|
padding: 1rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.company-logo {
|
.job-card-info {
|
||||||
background-position: left;
|
flex: 1;
|
||||||
background-size: 88px;
|
}
|
||||||
|
|
||||||
|
.company-logo {
|
||||||
|
background-position: center;
|
||||||
|
background-size: 37px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.job-card-parent {
|
||||||
|
display: grid;
|
||||||
|
row-gap: 1rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.job-card-logo-section {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
align-items: flex-end;
|
||||||
|
justify-content: space-between;
|
||||||
|
}
|
||||||
|
|
||||||
|
.job-detail-card {
|
||||||
|
flex-direction: column;
|
||||||
}
|
}
|
||||||
|
|||||||
6
school/templates/emails/job_report.html
Normal file
6
school/templates/emails/job_report.html
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
{% set job_link = "<a href='" + job_url + "'>" + job + "</a>" %}
|
||||||
|
|
||||||
|
<p>{{ _("Hey,") }}</p>
|
||||||
|
<p>{{ _("{0} has reported a job post for the following reason.").format(user) }}</p>
|
||||||
|
<p>" {{ reason }} "</p>
|
||||||
|
<p>{{ _("Please take appropriate action at {0}").format(job_url) }}</p>
|
||||||
21
school/templates/job_card.html
Normal file
21
school/templates/job_card.html
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
<div class="job-card">
|
||||||
|
<div class="job-card-info">
|
||||||
|
<div class="d-flex mb-3">
|
||||||
|
<div class="course-card-pills">{{ _(job.type) }}</div>
|
||||||
|
<div class="course-card-pills">{{ job.location }}</div>
|
||||||
|
</div>
|
||||||
|
<div class="card-heading">{{ _(job.job_title) }}</div>
|
||||||
|
<div class="mt-1">
|
||||||
|
<a class="dark-links" href="{{ job.company_website }}">{{ job.company_name }}</a>
|
||||||
|
</div>
|
||||||
|
{% if show_edit_link and job.owner == frappe.session.user %}
|
||||||
|
<a href="/job-opportunity?name={{ job.name }}">Edit</a>
|
||||||
|
{% endif %}
|
||||||
|
</div>
|
||||||
|
<div class="job-card-logo-section">
|
||||||
|
<div class="small">Posted on: {{ frappe.utils.format_date(job.creation, "medium") }}</div>
|
||||||
|
<div class="avatar avatar-medium" title="{{ job.company_name}}">
|
||||||
|
<span class="avatar-frame company-logo" style="background-image: url( {{ job.company_logo | urlencode }} );"></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
@@ -1,5 +1,4 @@
|
|||||||
{% extends "templates/base.html" %}
|
{% extends "templates/base.html" %}
|
||||||
{% from "www/hackathons/macros/card.html" import null_card %}
|
|
||||||
{% block title %}{{ _('Community') }}{% endblock %}
|
{% block title %}{{ _('Community') }}{% endblock %}
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
{% extends "templates/base.html" %}
|
{% extends "templates/base.html" %}
|
||||||
{% from "www/hackathons/macros/card.html" import null_card %}
|
|
||||||
{% block title %}{{ 'Courses' }}{% endblock %}
|
{% block title %}{{ 'Courses' }}{% endblock %}
|
||||||
{% block head_include %}
|
{% block head_include %}
|
||||||
<style>
|
<style>
|
||||||
|
|||||||
@@ -1,34 +1,36 @@
|
|||||||
{% extends "templates/base.html" %}
|
{% extends "templates/base.html" %}
|
||||||
{% from "www/hackathons/macros/card.html" import null_card %}
|
|
||||||
{% block title %}{{ _('Job Openings') }}{% endblock %}
|
{% block title %}{{ _('Job Openings') }}{% endblock %}
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
|
{% set allow_posting = frappe.db.get_single_value("Job Settings", "allow_posting") %}
|
||||||
<div class="common-page-style">
|
<div class="common-page-style">
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<a class="button is-primary pull-right" href="/job-opportunity">{{ _("Post a Job") }}</a>
|
|
||||||
|
{% if allow_posting and jobs | length %}
|
||||||
|
<a class="button is-primary pull-right" href="/job-opportunity?new=1">{{ _("Post a Job") }}</a>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
<div class="course-home-headings">{{ _("Job Openings") }}</div>
|
<div class="course-home-headings">{{ _("Job Openings") }}</div>
|
||||||
<div class="cards-parent">
|
{% if jobs | length %}
|
||||||
|
<div class="job-card-parent">
|
||||||
{% for job in jobs %}
|
{% for job in jobs %}
|
||||||
<div class="common-card-style course-card">
|
<div class="common-card-style course-card">
|
||||||
<div class="job-card">
|
{% set show_edit_link = False %}
|
||||||
<div>
|
{% include "school/templates/job_card.html" %}
|
||||||
<div class="course-tags">
|
|
||||||
<div class="course-card-pills">{{ _(job.type) }}</div>
|
|
||||||
<div class="course-card-pills">{{ job.location }}</div>
|
|
||||||
</div>
|
|
||||||
<div class="job-card-info">
|
|
||||||
<div class="bold-title">{{ _(job.job_title) }}</div>
|
|
||||||
<small>{{ job.company_name }}</small>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="avatar avatar-large" title="{{ job.company_name}}">
|
|
||||||
<span class="avatar-frame company-logo" style="background-image: url( {{ job.company_logo | urlencode }} );"></span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<a class="stretched-link" href="/jobs/{{ job.name }}"></a>
|
<a class="stretched-link" href="/jobs/{{ job.name }}"></a>
|
||||||
</div>
|
</div>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</div>
|
</div>
|
||||||
|
{% else %}
|
||||||
|
<div class="empty-state text-center">
|
||||||
|
<img class="icon icon-xl" src="/assets/frappe/icons/timeless/message.svg">
|
||||||
|
<div class="course-home-headings mt-4 mb-0" style="color: inherit;"> {{ _("No open jobs") }} </div>
|
||||||
|
<div class="small mb-6"> {{ _("There are no job openings at present.") }} </div>
|
||||||
|
{% if allow_posting %}
|
||||||
|
<a class="button is-secondary dark-links m-auto" href="/job-opportunity?new=1">{{ _("Post a Job") }}</a>
|
||||||
|
{% endif %}
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|||||||
@@ -3,12 +3,12 @@ import frappe
|
|||||||
def get_context(context):
|
def get_context(context):
|
||||||
context.jobs = frappe.get_all("Job Opportunity",
|
context.jobs = frappe.get_all("Job Opportunity",
|
||||||
{
|
{
|
||||||
"status": "Approved",
|
"status": "Open",
|
||||||
"job_opportunity_status": "Open"
|
"disabled": False
|
||||||
},
|
},
|
||||||
[
|
[
|
||||||
"job_title", "location", "type", "company_name",
|
"job_title", "location", "type", "company_name",
|
||||||
"company_logo", "name"
|
"company_logo", "name", "creation"
|
||||||
],
|
],
|
||||||
order_by="creation desc")
|
order_by="creation desc")
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
{% extends "templates/base.html" %}
|
{% extends "templates/base.html" %}
|
||||||
{% from "www/hackathons/macros/card.html" import null_card %}
|
|
||||||
{% block title %}{{ _(job.job_title) }}{% endblock %}
|
{% block title %}{{ _(job.job_title) }}{% endblock %}
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
@@ -7,26 +6,54 @@
|
|||||||
<div class="common-page-style">
|
<div class="common-page-style">
|
||||||
<div class="container">
|
<div class="container">
|
||||||
{{ BreadCrumb(job) }}
|
{{ BreadCrumb(job) }}
|
||||||
<div class="common-card-style thread-card">
|
<div class="common-card-style job-detail-card">
|
||||||
<div class="job-card">
|
{% set show_edit_link = True %}
|
||||||
<div>
|
{% include "school/templates/job_card.html" %}
|
||||||
<span class="course-tags">
|
<div class="p-4">
|
||||||
<div class="course-card-pills">{{ _(job.type) }}</div>
|
|
||||||
<div class="course-card-pills">{{ job.location }}</div>
|
|
||||||
</span>
|
|
||||||
<div class="job-card-info">
|
|
||||||
<div class="card-heading">{{ _(job.job_title) }}</div>
|
|
||||||
<a class="dark-links" href="{{ job.company_website }}">{{ job.company_name }}</a>
|
|
||||||
<div class="small mt-1">Posted On: {{ frappe.utils.format_date(job.creation, "medium") }}</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="avatar avatar-large" title="{{ job.company_name}}">
|
|
||||||
<span class="avatar-frame company-logo" style="background-image: url( {{ job.company_logo | urlencode }} );"></span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="job-description-section">
|
|
||||||
<div>{{ _(job.description) }}</div>
|
<div>{{ _(job.description) }}</div>
|
||||||
<a class="button is-primary mt-5" href="{{ job.application_link }}">{{ _("Apply Now") }}</a>
|
<div class="d-flex justify-content-between mt-5">
|
||||||
|
{% if frappe.session.user != "Guest" %}
|
||||||
|
<a class="button is-primary" href="{{ job.application_link }}">{{ _("Apply Now") }}</a>
|
||||||
|
<div class="button is-secondary" id="report">{{ _("Report this post") }}</div>
|
||||||
|
{% else %}
|
||||||
|
<a class="button is-secondary dark-links" href="/login?redirect-to=/jobs/{{ job.name }}">Login to apply for this job.</a>
|
||||||
|
{% endif %}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="modal fade report-modal" id="report-modal" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel"
|
||||||
|
aria-hidden="true">
|
||||||
|
<div class="modal-dialog" role="document">
|
||||||
|
<div class="modal-content">
|
||||||
|
<div class="modal-header">
|
||||||
|
<div class="font-weight-bold">{{ _("Report this Post") }}</div>
|
||||||
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
|
||||||
|
<span aria-hidden="true">×</span>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
<div class="modal-body">
|
||||||
|
<form class="review-form" id="review-form">
|
||||||
|
<div class="form-group">
|
||||||
|
<div class="clearfix">
|
||||||
|
<label class="control-label reqd" style="padding-right: 0px;">{{ _("Reason for reporting") }}</label>
|
||||||
|
</div>
|
||||||
|
<div class="control-input-wrapper">
|
||||||
|
<div class="control-input">
|
||||||
|
<textarea type="text" autocomplete="off" class="input-with-feedback form-control report-field"
|
||||||
|
data-fieldtype="Text" data-fieldname="feedback_comments" placeholder="" style="height: 200px;"
|
||||||
|
spellcheck="false"></textarea>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<p class="error-field muted-text"></p>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<div class="button submit-review is-primary" data-job="{{ job.name }}" id="submit-report">
|
||||||
|
Report</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
28
school/www/jobs/job.js
Normal file
28
school/www/jobs/job.js
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
frappe.ready(() => {
|
||||||
|
$("#report").click((e) => {
|
||||||
|
open_report_dialog(e);
|
||||||
|
});
|
||||||
|
|
||||||
|
$("#submit-report").click((e) => {
|
||||||
|
report(e);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
const open_report_dialog = (e) => {
|
||||||
|
e.preventDefault();
|
||||||
|
$("#report-modal").modal("show");
|
||||||
|
};
|
||||||
|
|
||||||
|
const report = (e) => {
|
||||||
|
frappe.call({
|
||||||
|
method: "school.job.doctype.job_opportunity.job_opportunity.report",
|
||||||
|
args: {
|
||||||
|
"job": $(e.currentTarget).data("job"),
|
||||||
|
"reason": $(".report-field").val()
|
||||||
|
},
|
||||||
|
callback: (data) => {
|
||||||
|
$(".report-modal").modal("hide");
|
||||||
|
frappe.msgprint(__("Thanks for informing us about this post. The admin will look into it and take an appropriate action soon."))
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user