1
|
|
|
// BigBlueButton open source conferencing system - http://www.bigbluebutton.org/. |
2
|
|
|
// |
3
|
|
|
// Copyright (c) 2018 BigBlueButton Inc. and by respective authors (see below). |
4
|
|
|
// |
5
|
|
|
// This program is free software; you can redistribute it and/or modify it under the |
6
|
|
|
// terms of the GNU Lesser General Public License as published by the Free Software |
7
|
|
|
// Foundation; either version 3.0 of the License, or (at your option) any later |
8
|
|
|
// version. |
9
|
|
|
// |
10
|
|
|
// BigBlueButton is distributed in the hope that it will be useful, but WITHOUT ANY |
11
|
|
|
// WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A |
12
|
|
|
// PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. |
13
|
|
|
// |
14
|
|
|
// You should have received a copy of the GNU Lesser General Public License along |
15
|
|
|
// with BigBlueButton; if not, see <http://www.gnu.org/licenses/>. |
16
|
|
|
|
17
|
|
|
$(document).on('turbolinks:load', function(){ |
18
|
|
|
var controller = $("body").data('controller'); |
19
|
|
|
var action = $("body").data('action'); |
20
|
|
|
if ((controller == "admins" && action == "edit_user") || (controller == "users" && action == "edit")) { |
21
|
|
|
// Reset the value of the form element that allows the user to clear their avatar |
22
|
|
|
$("#clear-avatar").val("false") |
23
|
|
|
|
24
|
|
|
//Preview the image in the profile to the new image when a file is uploaded |
25
|
|
|
$("#user_avatar").change(function() { |
26
|
|
|
var reader = new FileReader(); |
|
|
|
|
27
|
|
|
|
28
|
|
|
reader.onload = function(e) { |
29
|
|
|
var file = e.target.result |
30
|
|
|
|
31
|
|
|
// Format of file is 'data:image/*;...' |
32
|
|
|
let colonLocation = file.indexOf(":") + 1 |
33
|
|
|
var incomingFileType = file.substr(colonLocation, file.indexOf(";")-colonLocation) |
34
|
|
|
|
35
|
|
|
// check to see that the incoming file type is accepted |
36
|
|
|
if (incomingFileType.startsWith("image/")) { |
37
|
|
|
$(".invalid-message").hide() |
38
|
|
|
|
39
|
|
|
// If its the first image they upload, remove the letter avatar and preview the image avatar |
40
|
|
|
if ($("#avatar-letter").length > 0) { |
41
|
|
|
$("#clear-avatar").val("false") |
42
|
|
|
|
43
|
|
|
document.getElementById("avatar-letter").outerHTML = "<img id='avatar-image' class='avatar avatar-xxl mr-5 mt-2'></img>" |
44
|
|
|
} |
45
|
|
|
|
46
|
|
|
$("#avatar-image").attr("src", file) |
47
|
|
|
} else { |
48
|
|
|
$(".invalid-message").show() |
49
|
|
|
$("#user_avatar").val("") |
50
|
|
|
} |
51
|
|
|
} |
52
|
|
|
|
53
|
|
|
reader.readAsDataURL(this.files[0]); |
54
|
|
|
}) |
55
|
|
|
|
56
|
|
|
// Preview the default avatar if the user clicks the remove image button |
57
|
|
|
$("#remove-image").click(function() { |
58
|
|
|
$("#clear-avatar").val("true") |
59
|
|
|
document.getElementById("avatar-image").outerHTML = "<span id='avatar-letter' class='avatar avatar-xxl mr-5 mt-2 bg-primary'>" + $("#remove-image").data("first") + "</span>" |
60
|
|
|
}) |
61
|
|
|
|
62
|
|
|
// Clear the role when the user clicks the x |
63
|
|
|
$(".clear-role").click(clearRole) |
64
|
|
|
|
65
|
|
|
// When the user selects an item in the dropdown add the role to the user |
66
|
|
|
$("#role-select-dropdown").change(function(data){ |
67
|
|
|
var dropdown = $("#role-select-dropdown"); |
68
|
|
|
var select_role_id = dropdown.val(); |
69
|
|
|
|
70
|
|
|
if(select_role_id){ |
71
|
|
|
// Disable the role in the dropdown |
72
|
|
|
var selected_role = dropdown.find('[value=\"' + select_role_id + '\"]'); |
73
|
|
|
selected_role.prop("disabled", true) |
74
|
|
|
|
75
|
|
|
// Add the role tag |
76
|
|
|
var tag_container = $("#role-tag-container"); |
77
|
|
|
tag_container.append("<span id=\"user-role-tag_" + select_role_id + "\" style=\"background-color:" + selected_role.data("colour") + ";\" class=\"tag user-role-tag\">" + |
78
|
|
|
selected_role.text() + "<a data-role-id=\"" + select_role_id + "\" class=\"tag-addon clear-role\"><i data-role-id=\"" + select_role_id + "\" class=\"fas fa-times\"></i></a></span>"); |
79
|
|
|
|
80
|
|
|
// Update the role ids input that gets submited on user update |
81
|
|
|
var role_ids = $("#user_role_ids").val() |
82
|
|
|
role_ids += " " + select_role_id |
83
|
|
|
$("#user_role_ids").val(role_ids) |
84
|
|
|
|
85
|
|
|
// Add the clear role function to the tag |
86
|
|
|
$("#user-role-tag_" + select_role_id).click(clearRole); |
87
|
|
|
|
88
|
|
|
// Reset the dropdown |
89
|
|
|
dropdown.val(null) |
90
|
|
|
} |
91
|
|
|
}) |
92
|
|
|
} |
93
|
|
|
}) |
94
|
|
|
|
95
|
|
|
// This function removes the specfied role from a user |
96
|
|
|
function clearRole(data){ |
97
|
|
|
// Get the role id |
98
|
|
|
var role_id = $(data.target).data("role-id"); |
99
|
|
|
var role_tag = $("#user-role-tag_" + role_id); |
100
|
|
|
|
101
|
|
|
// Remove the role tag |
102
|
|
|
$(role_tag).remove() |
103
|
|
|
|
104
|
|
|
// Update the role ids input |
105
|
|
|
var role_ids = $("#user_role_ids").val() |
106
|
|
|
var parsed_ids = role_ids.split(' ') |
107
|
|
|
|
108
|
|
|
var index = parsed_ids.indexOf(role_id.toString()); |
109
|
|
|
|
110
|
|
|
if (index > -1) { |
111
|
|
|
parsed_ids.splice(index, 1); |
112
|
|
|
} |
113
|
|
|
|
114
|
|
|
$("#user_role_ids").val(parsed_ids.join(' ')) |
115
|
|
|
|
116
|
|
|
// Enable the role in the role select dropdown |
117
|
|
|
var selected_role = $("#role-select-dropdown").find('[value=\"' + role_id + '\"]'); |
118
|
|
|
selected_role.prop("disabled", false) |
119
|
|
|
} |
This checks looks for references to variables that have not been declared. This is most likey a typographical error or a variable has been renamed.
To learn more about declaring variables in Javascript, see the MDN.