-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcontent.js
64 lines (56 loc) · 4.2 KB
/
content.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
/*
* Copyright (C) 2021 Sellers Industry
* distributed under the MIT License
*
* author: Evan Sellers <[email protected]>
* date: Tue Nov 30 2021
* file: content.js
* project: Moodle Custom Menu
* purpose: Edits HTML on page
*
*/
let optionsUrl = chrome.runtime.getURL( "/options.html" );
let image = ``;
let dummyFill = `
<div style='display: flex; color: white; padding: 0.25rem 1rem 0 0;'>
<div style="padding: 0.25rem 1rem 0 0; display: flex; align-items: center; justify-content: center;">
<img style="width: 35px;" src="${ image }">
</div>
<div>
<b>Custom Moodle Menu</b>
<br>
Add menu items through the extension <a href="${ optionsUrl }" target="blank" style="color: white; text-decoration: underline;">options</a>.
</div>
</div>`;
// Build Html for Sidebar
function buildHtmlDom( items ) {
let html = "<ul class='navbar-nav'>";
items.forEach( ( item, index ) => {
html += `
<li data-key="c-${index}" class="nav-item" role="none">
<a role="menuitem" class="nav-link" href="${ item[ "link" ] }" tabindex="-1" style="padding: 1rem;">
${ item[ "label" ] }
</a>
</li>`
});
return html + "</ul>";
}
// Inject Sidebar
function inject( htmlDom ) {
let menu = document.querySelector(".primary-navigation .navigation");
menu.innerHTML += htmlDom;
}
// Init
function init() {
document.querySelector(".primary-navigation .navigation ul").style["display"] = "none";
document.querySelector("#page-footer").innerHTML += "<p style='color:gray;text-align: center;padding: 0 1rem 0 1rem;margin:0;'>Moodle Custom Menu designed by <a href='https://sellersew.com' target='blank' style='color:grey;text-decoration:underline;'>Sellers LLC</a>";
document.querySelector("#page-footer").innerHTML += "<p style='color:grey;text-align:center;padding:0 1rem 2rem 1rem;font-size:0.6rem;margin:0;'>If you need wisdom, ask our generous God, and he will give it to you. He will not rebuke you for asking. - James 1:5</p>"
chrome.storage.sync.get( [ "items" ] , function( result ) {
if ( !result[ "items" ] || result[ "items" ].length == 0 ) {
inject( dummyFill );
} else {
inject( buildHtmlDom( result[ "items" ] ) );
}
});
}
init();