const fs = require('fs'); const got = require('got'); const emoji = require('github-emoji'); const jsdom = require('jsdom').JSDOM, options = { resources: "usable" }; function convertToEmoji(text) { if (text == null) return; text = text.toString(); if (text.match(/(?<=:\s*).*?(?=\s*:)/gs) != null) { var str = text.match(/(?<=:\s*).*?(?=\s*:)/gs); str = str.filter(function (arr) { return /\S/.test(arr); }); for (i = 0; i < str.length; i++) { if (emoji.URLS[str[i]] != undefined) { var output = emoji.of(str[i]); var emojiImage = output.url.replace("assets-cdn.github", "github.githubassets"); text = text.replace(`:${str[i]}:`, ``); } } return text; } else { return text; } } let savedRepos = []; let savedForks = []; module.exports.updateHTML = (username, sort, order) => { //add data to assets/index.html jsdom.fromFile("./assets/index.html", options).then(function (dom) { let window = dom.window, document = window.document; (async () => { try { console.log("Building HTML/CSS/JS..."); var repos = await got(`https://api.github.com/users/${username}/repos?per_page=1200`); repos = JSON.parse(repos.body); for(var i = 0;i < repos.length;i++){ if(repos[i].fork == false){ repos[i].description = convertToEmoji(repos[i].description); savedRepos.push(repos[i]); } else { repos[i].description = convertToEmoji(repos[i].description); savedForks.push(repos[i]); } } var user = await got(`https://api.github.com/users/${username}`); user = JSON.parse(user.body); document.title = user.login; var icon = document.createElement("link"); icon.setAttribute("rel", "icon"); icon.setAttribute("href", user.avatar_url); icon.setAttribute("type", "image/png"); document.getElementsByTagName("head")[0].appendChild(icon); document.getElementById("profile_img").style.background = `url('${user.avatar_url}') center center` document.getElementById("username").innerHTML = `${user.name}@${user.login}`; //document.getElementById("github_link").href = `https://github.com/${user.login}`; document.getElementById("userbio").innerHTML = convertToEmoji(user.bio); document.getElementById("userbio").style.display = user.bio == null || !user.bio ? 'none' : 'block'; document.getElementById("about").innerHTML = `   ${user.company}   ${user.email}   ${user.blog}    ${user.location}    Available for hire`; //add data to config.json fs.readFile("./dist/config.json", function (err, data) { if (err) throw err; data = JSON.parse(data); data[0].username = user.login; data[0].name = user.name; data[0].userimg = user.avatar_url; fs.writeFile('./dist/config.json', JSON.stringify(data, null, ' '), function (err) { if (err) throw err; }); }); fs.writeFile('dist/index.html', '' + window.document.documentElement.outerHTML, function (error) { if (error) throw error; console.log("Build Complete"); process.exit(0) }); } catch (error) { console.log(error); } })(); }).catch(function (error) { console.log(error); }); } function populateHTML(type, sort, order, document){ let data = require('./dist/' + type + '.json'); let result = []; result = data.sort(GetSortOrder(sort, order)); if(result.length){ for(var i = 0;i < result.length;i++){ document.getElementById(type === 'repos' ? 'projects' : 'forks').innerHTML += `
${result[i].name}
${result[i].description}
  ${result[i].language}   ${result[i].stargazers_count}   ${result[i].forks_count}
`; } } } function GetSortOrder(prop, order) { return function(a, b) { if(typeof(a[prop]) === 'string'){ if (a[prop].toLowerCase() > b[prop].toLowerCase()) { return 1 * order; } else if (a[prop].toLowerCase() < b[prop].toLowerCase()) { return -1 * order; } } else { if (a[prop] > b[prop]) { return 1 * order; } else if (a[prop] < b[prop]) { return -1 * order; } } return 0; } }