feat: emails tab
This commit is contained in:
@@ -2479,3 +2479,7 @@ select {
|
|||||||
.questions-table .row-index {
|
.questions-table .row-index {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.text-color {
|
||||||
|
color: var(--text-color);
|
||||||
|
}
|
||||||
@@ -75,14 +75,6 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{% if is_moderator %}
|
|
||||||
<div class="mt-4">
|
|
||||||
<button class="btn btn-secondary btn-sm btn-email">
|
|
||||||
{{ _("Email to Students") }}
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
{% endif %}
|
|
||||||
|
|
||||||
{% if batch_info.custom_component %}
|
{% if batch_info.custom_component %}
|
||||||
<div class="mt-4">
|
<div class="mt-4">
|
||||||
{{ batch_info.custom_component }}
|
{{ batch_info.custom_component }}
|
||||||
@@ -140,6 +132,15 @@
|
|||||||
</span>
|
</span>
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
|
<li class="nav-item">
|
||||||
|
<a class="nav-link" data-toggle="tab" href="#emails">
|
||||||
|
{{ _("Emails") }}
|
||||||
|
<span class="course-list-count">
|
||||||
|
{{ batch_emails | length }}
|
||||||
|
</span>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
{% if batch_students | length and (is_moderator or is_student) %}
|
{% if batch_students | length and (is_moderator or is_student) %}
|
||||||
@@ -192,6 +193,10 @@
|
|||||||
<div class="tab-pane" id="assessments" role="tabpanel" aria-labelledby="assessments">
|
<div class="tab-pane" id="assessments" role="tabpanel" aria-labelledby="assessments">
|
||||||
{{ AssessmentsSection(batch_info) }}
|
{{ AssessmentsSection(batch_info) }}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="tab-pane" id="emails" role="tabpanel" aria-labelledby="emails">
|
||||||
|
{{ EmailsSection() }}
|
||||||
|
</div>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
{% if batch_students | length and (is_moderator or is_student or is_evaluator) %}
|
{% if batch_students | length and (is_moderator or is_student or is_evaluator) %}
|
||||||
@@ -376,6 +381,41 @@
|
|||||||
</article>
|
</article>
|
||||||
{% endmacro %}
|
{% endmacro %}
|
||||||
|
|
||||||
|
|
||||||
|
{% macro EmailsSection() %}
|
||||||
|
<div class="my-4">
|
||||||
|
<button class="btn btn-secondary btn-sm btn-email">
|
||||||
|
{{ _("Email to Students") }}
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
{% for email in batch_emails %}
|
||||||
|
<div class="frappe-card mb-5">
|
||||||
|
<div class="flex justify-between m-1">
|
||||||
|
<span class="text-color flex">
|
||||||
|
<span class="margin-right">
|
||||||
|
{% set member = frappe.db.get_value("User", email.sender, ["full_name", "username", "name", "user_image"], as_dict=1) %}
|
||||||
|
{{ widgets.Avatar(member=member, avatar_class="avatar-small") }}
|
||||||
|
</span>
|
||||||
|
<span>
|
||||||
|
{{ member.full_name }}
|
||||||
|
<div class="text-muted">
|
||||||
|
<span class="frappe-timestamp" data-timestamp="{{ email.communication_date }}" title="{{ communication_date }}">
|
||||||
|
{{ frappe.utils.pretty_date(email.communication_date) }}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</span>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<div class="ml-10">
|
||||||
|
{{ email.content }}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{% endfor %}
|
||||||
|
</div>
|
||||||
|
{% endmacro %}
|
||||||
|
|
||||||
|
|
||||||
{% macro AssessmentList(assessments) %}
|
{% macro AssessmentList(assessments) %}
|
||||||
{% if assessments | length %}
|
{% if assessments | length %}
|
||||||
<div class="form-grid">
|
<div class="form-grid">
|
||||||
|
|||||||
@@ -843,6 +843,9 @@ const send_email_to_students = (students, values) => {
|
|||||||
message: __("Email sent successfully"),
|
message: __("Email sent successfully"),
|
||||||
indicator: "green",
|
indicator: "green",
|
||||||
});
|
});
|
||||||
|
setTimeout(() => {
|
||||||
|
window.location.reload();
|
||||||
|
}, 2000);
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -71,6 +71,13 @@ def get_context(context):
|
|||||||
)
|
)
|
||||||
context.course_name_list = [course.course for course in context.batch_courses]
|
context.course_name_list = [course.course for course in context.batch_courses]
|
||||||
context.assessments = get_assessments(batch_name)
|
context.assessments = get_assessments(batch_name)
|
||||||
|
context.batch_emails = frappe.get_all(
|
||||||
|
"Communication",
|
||||||
|
filters={"reference_doctype": "LMS Batch", "reference_name": batch_name},
|
||||||
|
fields=["subject", "content", "recipients", "cc", "communication_date", "sender"],
|
||||||
|
order_by="communication_date desc",
|
||||||
|
)
|
||||||
|
|
||||||
context.batch_students = get_class_student_details(
|
context.batch_students = get_class_student_details(
|
||||||
batch_students, batch_courses, context.assessments
|
batch_students, batch_courses, context.assessments
|
||||||
)
|
)
|
||||||
|
|||||||
Reference in New Issue
Block a user