Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

💻 Remove modal for make teacher as admin #5631

Merged
merged 17 commits into from
Jun 29, 2024
Merged
Show file tree
Hide file tree
Changes from 12 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
31 changes: 31 additions & 0 deletions static/js/admin.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34,4 +34,35 @@ export function initializeAdminUserPage(_options: InitializeAdminUsersPageOption
$('#hidden_page_input').attr('value', token);
$('#filterform').submit();
});
}

export function filter_admin() {
const params: Record<string, any> = {};

const filter = $('#admin_filter_category').val();
params['filter'] = filter;

if ($('#hidden_page_input').val()) {
params['page'] = $('#hidden_page_input').val();
}

switch (filter) {
case 'email':
case 'username':
params['substring'] = $('#email_filter_input').val();
break;
case 'language':
params['language'] = $('#language_filter_input').val();
break;
case 'keyword_language':
params['keyword_language'] = $('#keyword_language_filter_input').val();
break;
default:
params['start'] = $('#admin_start_date').val();
params['end'] = $('#admin_end_date').val();
break;
}

const queryString = Object.entries(params).map(([k, v]) => k + '=' + encodeURIComponent(v)).join('&');
window.open('?' + queryString, '_self');
}
31 changes: 0 additions & 31 deletions static/js/app.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1671,37 +1671,6 @@ export function select_profile_image(image: number) {
$('#image').val(image);
}

export function filter_admin() {
const params: Record<string, any> = {};

const filter = $('#admin_filter_category').val();
params['filter'] = filter;

if ($('#hidden_page_input').val()) {
params['page'] = $('#hidden_page_input').val();
}

switch (filter) {
case 'email':
case 'username':
params['substring'] = $('#email_filter_input').val();
break;
case 'language':
params['language'] = $('#language_filter_input').val();
break;
case 'keyword_language':
params['keyword_language'] = $('#keyword_language_filter_input').val();
break;
default:
params['start'] = $('#admin_start_date').val();
params['end'] = $('#admin_end_date').val();
break;
}

const queryString = Object.entries(params).map(([k, v]) => k + '=' + encodeURIComponent(v)).join('&');
window.open('?' + queryString, '_self');
}

export function hide_editor() {
$('#fold_in_toggle_container').hide();
$('#code_editor').toggle();
Expand Down
164 changes: 59 additions & 105 deletions static/js/appbundle.js
Original file line number Diff line number Diff line change
Expand Up @@ -60451,6 +60451,7 @@ ${o3}` : i3;
incrementDebugLine: () => incrementDebugLine,
initialize: () => initialize,
initializeActivity: () => initializeActivity,
initializeAdminUserPage: () => initializeAdminUserPage,
initializeApp: () => initializeApp,
initializeClassOverviewPage: () => initializeClassOverviewPage,
initializeCodePage: () => initializeCodePage,
Expand All @@ -60472,8 +60473,6 @@ ${o3}` : i3;
load_variables: () => load_variables,
logout: () => logout,
logs: () => logs,
markAsTeacher: () => markAsTeacher,
markSuperTeacher: () => markSuperTeacher,
modal: () => modal,
modalStepOne: () => modalStepOne,
preview_adventure: () => preview_adventure,
Expand Down Expand Up @@ -119271,51 +119270,6 @@ def note_with_error(value, err):
}
});
}
function markAsTeacher(checkbox, username, is_teacher, pending_request, by_super_teacher = false) {
$(checkbox).prop("checked", false);
let text = "Are you sure you want to remove " + username + " as a teacher?";
if (is_teacher) {
text = "Are you sure you want to make " + username + " a teacher?";
}
modal.confirm(text, async () => {
try {
await postNoResponse(by_super_teacher ? "/super-teacher/mark-as-teacher" : "/admin/mark-as-teacher", {
username,
is_teacher
});
location.reload();
} catch (e) {
console.error(e);
modal.notifyError(["Error when", is_teacher ? "marking" : "unmarking", "user", username, "as teacher"].join(" "));
}
}, async () => {
if (pending_request) {
await postJson("/admin/mark-as-teacher", {
username,
is_teacher: false
});
location.reload();
}
});
}
function markSuperTeacher(checkbox, username, is_super_teacher) {
let text = "Are you sure you want to make " + username + " a super teacher?";
if (is_super_teacher) {
text = "Are you sure you want to revoke super teacher privilege from " + username + "?";
}
modal.confirm(text, async () => {
try {
await postNoResponse("/admin/mark-super-teacher", {
username
});
location.reload();
} catch (e) {
console.error(e);
modal.notifyError(e);
$(checkbox).prop("checked", is_super_teacher);
}
}, () => $(checkbox).prop("checked", is_super_teacher));
}
function changeUserEmail(username, email) {
modal.prompt("Please enter the corrected email", email, async function(correctedEmail) {
if (correctedEmail === email)
Expand Down Expand Up @@ -120885,32 +120839,6 @@ def note_with_error(value, err):
$("#profile_image_" + image).addClass("border-2 border-blue-600");
$("#image").val(image);
}
function filter_admin() {
const params = {};
const filter = $("#admin_filter_category").val();
params["filter"] = filter;
if ($("#hidden_page_input").val()) {
params["page"] = $("#hidden_page_input").val();
}
switch (filter) {
case "email":
case "username":
params["substring"] = $("#email_filter_input").val();
break;
case "language":
params["language"] = $("#language_filter_input").val();
break;
case "keyword_language":
params["keyword_language"] = $("#keyword_language_filter_input").val();
break;
default:
params["start"] = $("#admin_start_date").val();
params["end"] = $("#admin_end_date").val();
break;
}
const queryString = Object.entries(params).map(([k, v]) => k + "=" + encodeURIComponent(v)).join("&");
window.open("?" + queryString, "_self");
}
function hide_editor() {
$("#fold_in_toggle_container").hide();
$("#code_editor").toggle();
Expand Down Expand Up @@ -121221,6 +121149,64 @@ def note_with_error(value, err):
});
});

// static/js/admin.ts
function initializeAdminUserPage(_options) {
$(".attribute").change(function() {
const attribute = $(this).attr("id");
if (!this.checked) {
$("#" + attribute + "_header").hide();
$("." + attribute + "_cell").hide();
} else {
$("#" + attribute + "_header").show();
$("." + attribute + "_cell").show();
}
});
$("#admin_filter_category").change(function() {
$(".filter_input").hide();
if ($("#admin_filter_category").val() == "email" || $("#admin_filter_category").val() == "username") {
$("#email_filter_input").show();
} else if ($("#admin_filter_category").val() == "language") {
$("#language_filter_input").show();
} else if ($("#admin_filter_category").val() == "keyword_language") {
$("#keyword_language_filter_input").show();
} else {
$("#date_filter_input").show();
}
});
$(".admin_pagination_btn").click(function(ev) {
var token = $(ev.target).data("page_token");
console.log(token);
$("#hidden_page_input").attr("value", token);
$("#filterform").submit();
});
}
function filter_admin() {
const params = {};
const filter = $("#admin_filter_category").val();
params["filter"] = filter;
if ($("#hidden_page_input").val()) {
params["page"] = $("#hidden_page_input").val();
}
switch (filter) {
case "email":
case "username":
params["substring"] = $("#email_filter_input").val();
break;
case "language":
params["language"] = $("#language_filter_input").val();
break;
case "keyword_language":
params["keyword_language"] = $("#keyword_language_filter_input").val();
break;
default:
params["start"] = $("#admin_start_date").val();
params["end"] = $("#admin_end_date").val();
break;
}
const queryString = Object.entries(params).map(([k, v]) => k + "=" + encodeURIComponent(v)).join("&");
window.open("?" + queryString, "_self");
}

// static/js/statistics.ts
if (registerables) {
Chart.register(...registerables);
Expand Down Expand Up @@ -121393,38 +121379,6 @@ def note_with_error(value, err):
}, 2e3);
}

// static/js/admin.ts
function initializeAdminUserPage(_options) {
$(".attribute").change(function() {
const attribute = $(this).attr("id");
if (!this.checked) {
$("#" + attribute + "_header").hide();
$("." + attribute + "_cell").hide();
} else {
$("#" + attribute + "_header").show();
$("." + attribute + "_cell").show();
}
});
$("#admin_filter_category").change(function() {
$(".filter_input").hide();
if ($("#admin_filter_category").val() == "email" || $("#admin_filter_category").val() == "username") {
$("#email_filter_input").show();
} else if ($("#admin_filter_category").val() == "language") {
$("#language_filter_input").show();
} else if ($("#admin_filter_category").val() == "keyword_language") {
$("#keyword_language_filter_input").show();
} else {
$("#date_filter_input").show();
}
});
$(".admin_pagination_btn").click(function(ev) {
var token = $(ev.target).data("page_token");
console.log(token);
$("#hidden_page_input").attr("value", token);
$("#filterform").submit();
});
}

// static/js/profile.ts
function initializeMyProfilePage(_options) {
autoSave("profile");
Expand Down
6 changes: 3 additions & 3 deletions static/js/appbundle.js.map

Large diffs are not rendered by default.

50 changes: 0 additions & 50 deletions static/js/auth.ts
Original file line number Diff line number Diff line change
Expand Up @@ -184,56 +184,6 @@ export function initializeFormSubmits() {

// *** Admin functionality ***

export function markAsTeacher(checkbox: any, username: string, is_teacher: boolean, pending_request: boolean, by_super_teacher = false) {
$(checkbox).prop('checked', false);
let text = "Are you sure you want to remove " + username + " as a teacher?";
if (is_teacher) {
text = "Are you sure you want to make " + username + " a teacher?";
}
modal.confirm (text, async () => {
try {
await postNoResponse(by_super_teacher ? '/super-teacher/mark-as-teacher' : '/admin/mark-as-teacher', {
username: username,
is_teacher: is_teacher,
});
location.reload();
} catch (e) {
console.error(e);
modal.notifyError(['Error when', is_teacher ? 'marking' : 'unmarking', 'user', username, 'as teacher'].join(' '));
}
}, async () => {
// If there is a pending request, we decline the modal -> remove the teacher request
if (pending_request) {
await postJson('/admin/mark-as-teacher', {
username: username,
is_teacher: false
});
location.reload();
}
});
}

export function markSuperTeacher(checkbox: any, username: string, is_super_teacher: boolean) {
let text = "Are you sure you want to make " + username + " a super teacher?";
if (is_super_teacher) {
text = "Are you sure you want to revoke super teacher privilege from " + username + "?";
}
modal.confirm (text, async () => {
try {
await postNoResponse('/admin/mark-super-teacher', {
username: username,
});
location.reload();
} catch (e: any) {
console.error(e);
modal.notifyError(e);
$(checkbox).prop('checked', is_super_teacher);
}
}, () => $(checkbox).prop('checked', is_super_teacher)
);
}


export function changeUserEmail(username: string, email: string) {
modal.prompt ('Please enter the corrected email', email, async function (correctedEmail) {
if (correctedEmail === email) return;
Expand Down
1 change: 0 additions & 1 deletion static/js/autosave.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,6 @@ export function autoSave(formId: string,
// If the event is not from a customEvent with is the element autosaved, we pass.
return
}

// Now we can simply trigger the submit event on the parent form element.
formElement.requestSubmit()

Expand Down
1 change: 1 addition & 0 deletions static/js/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
*/
import './htmx-integration';
export * from './modal';
export * from './admin';
Annelein marked this conversation as resolved.
Show resolved Hide resolved
export * from './app';
export * from './auth';
export * from './statistics';
Expand Down
24 changes: 20 additions & 4 deletions templates/admin/admin-users.html
Original file line number Diff line number Diff line change
Expand Up @@ -165,11 +165,27 @@ <h4 class="text-center">Total amount of shown users: {{ users|length }}</h4>
<td class="experience_cell hidden">{{user.prog_experience}}</td>
<td class="tags_cell text-center cursor-pointer"><span onclick="hedyApp.edit_user_tags('{{user.username}}');">✏️</span></td>
{% if user.teacher_request %}
<td class="teacher_cell text-center"><span class="fa-solid fa-circle-question cursor-pointer" onclick="hedyApp.markAsTeacher (this, '{{user.username}}', true, true)"></span></td>
{% else %}
<td class="teacher_cell text-center"><input type="checkbox" {% if user.is_teacher %}checked="checked"{% endif %} onclick="hedyApp.markAsTeacher (this, '{{user.username}}', {% if user.is_teacher %}false{% else %}true{% endif %}, false)"></td>
<td id="teacher_request_{{user.username}}" class="teacher_cell text-center">
<span class="fa-solid fa-circle-question cursor-pointer"
hx-trigger="click"
hx-get="/admin/mark-as-teacher/{{user.username}}"
_="on click
remove #teacher_request_{{user.username}}
then toggle .hidden on #is_teacher_{{user.username}}
then set #check_teacher_{{user.username}}.checked to true">
</span>
</td>
{% endif %}
<td class="teacher_cell text-center"><input type="checkbox" {% if user.is_super_teacher %}checked="checked"{% endif %} onclick="hedyApp.markSuperTeacher (this, '{{user.username}}', {% if user.is_super_teacher %}true{% else %}false{% endif %})"></td>
<td id="is_teacher_{{user.username}}" class="{% if user.teacher_request %}hidden{% endif %} teacher_cell text-center">
<input id="check_teacher_{{user.username}}" type="checkbox" {% if user.is_teacher %}checked{% endif %}
hx-trigger="click"
hx-get="/admin/mark-as-teacher/{{user.username}}">
</td>
<td class="teacher_cell text-center">
<input type="checkbox" {% if user.is_super_teacher %}checked="checked"{% endif %}
hx-trigger="click"
hx-get="/admin/mark-super-teacher/{{user.username}}">
</td>
<td class="verified_cell hidden">{{user.email_verified}}</td>
<td class="third_party_cell hidden text-center"><input type="checkbox" {% if user.third_party %}checked="checked"{% endif %} ></td>
</tr>
Expand Down
Loading
Loading