mirror of
https://github.com/vkaelin/LeagueStats.git
synced 2026-03-25 12:57:28 +00:00
Use post instead of get
This commit is contained in:
parent
0f534f4f8d
commit
8f91674a95
5 changed files with 80 additions and 29 deletions
|
|
@ -15,7 +15,7 @@
|
||||||
<div class="search">
|
<div class="search">
|
||||||
<div class="container">
|
<div class="container">
|
||||||
|
|
||||||
<form class="form-inline" id="changeName" method="GET">
|
<form class="form-inline" id="changeName" method="POST" action="api">
|
||||||
<input type="text" class="form-control mb-2 mr-sm-2" id="name" name="playerName" placeholder="Pseudo du Joueur">
|
<input type="text" class="form-control mb-2 mr-sm-2" id="name" name="playerName" placeholder="Pseudo du Joueur">
|
||||||
<button type="submit" class="btn btn-primary mb-2">Chercher</button>
|
<button type="submit" class="btn btn-primary mb-2">Chercher</button>
|
||||||
</form>
|
</form>
|
||||||
|
|
|
||||||
|
|
@ -9,6 +9,7 @@
|
||||||
"author": "kalane",
|
"author": "kalane",
|
||||||
"license": "ISC",
|
"license": "ISC",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"body-parser": "^1.18.3",
|
||||||
"express": "^4.16.4",
|
"express": "^4.16.4",
|
||||||
"request": "^2.88.0"
|
"request": "^2.88.0"
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,43 +1,35 @@
|
||||||
var championsId = { 266: "Aatrox", 103: "Ahri", 84: "Akali", 12: "Alistar", 32: "Amumu", 34: "Anivia", 1: "Annie", 22: "Ashe", 136: "AurelionSol", 268: "Azir", 432: "Bard", 53: "Blitzcrank", 63: "Brand", 201: "Braum", 51: "Caitlyn", 164: "Camille", 69: "Cassiopeia", 31: "Chogath", 42: "Corki", 122: "Darius", 131: "Diana", 119: "Draven", 36: "DrMundo", 245: "Ekko", 60: "Elise", 28: "Evelynn", 81: "Ezreal", 9: "Fiddlesticks", 114: "Fiora", 105: "Fizz", 3: "Galio", 41: "Gangplank", 86: "Garen", 150: "Gnar", 79: "Gragas", 104: "Graves", 120: "Hecarim", 74: "Heimerdinger", 420: "Illaoi", 39: "Irelia", 427: "Ivern", 40: "Janna", 59: "JarvanIV", 24: "Jax", 126: "Jayce", 202: "Jhin", 222: "Jinx", 145: "Kaisa", 429: "Kalista", 43: "Karma", 30: "Karthus", 38: "Kassadin", 55: "Katarina", 10: "Kayle", 141: "Kayn", 85: "Kennen", 121: "Khazix", 203: "Kindred", 240: "Kled", 96: "KogMaw", 7: "Leblanc", 64: "LeeSin", 89: "Leona", 127: "Lissandra", 236: "Lucian", 117: "Lulu", 99: "Lux", 54: "Malphite", 90: "Malzahar", 57: "Maokai", 11: "MasterYi", 21: "MissFortune", 62: "MonkeyKing", 82: "Mordekaiser", 25: "Morgana", 267: "Nami", 75: "Nasus", 111: "Nautilus", 76: "Nidalee", 56: "Nocturne", 20: "Nunu", 2: "Olaf", 61: "Orianna", 516: "Ornn", 80: "Pantheon", 78: "Poppy", 555: "Pyke", 133: "Quinn", 497: "Rakan", 33: "Rammus", 421: "RekSai", 58: "Renekton", 107: "Rengar", 92: "Riven", 68: "Rumble", 13: "Ryze", 113: "Sejuani", 35: "Shaco", 98: "Shen", 102: "Shyvana", 27: "Singed", 14: "Sion", 15: "Sivir", 72: "Skarner", 37: "Sona", 16: "Soraka", 50: "Swain", 134: "Syndra", 223: "TahmKench", 163: "Taliyah", 91: "Talon", 44: "Taric", 17: "Teemo", 412: "Thresh", 18: "Tristana", 48: "Trundle", 23: "Tryndamere", 4: "TwistedFate", 29: "Twitch", 77: "Udyr", 6: "Urgot", 110: "Varus", 67: "Vayne", 45: "Veigar", 161: "Velkoz", 254: "Vi", 112: "Viktor", 8: "Vladimir", 106: "Volibear", 19: "Warwick", 498: "Xayah", 101: "Xerath", 5: "XinZhao", 157: "Yasuo", 83: "Yorick", 154: "Zac", 238: "Zed", 115: "Ziggs", 26: "Zilean", 142: "Zoe", 143: "Zyra" };
|
var championsId = { 266: "Aatrox", 103: "Ahri", 84: "Akali", 12: "Alistar", 32: "Amumu", 34: "Anivia", 1: "Annie", 22: "Ashe", 136: "AurelionSol", 268: "Azir", 432: "Bard", 53: "Blitzcrank", 63: "Brand", 201: "Braum", 51: "Caitlyn", 164: "Camille", 69: "Cassiopeia", 31: "Chogath", 42: "Corki", 122: "Darius", 131: "Diana", 119: "Draven", 36: "DrMundo", 245: "Ekko", 60: "Elise", 28: "Evelynn", 81: "Ezreal", 9: "Fiddlesticks", 114: "Fiora", 105: "Fizz", 3: "Galio", 41: "Gangplank", 86: "Garen", 150: "Gnar", 79: "Gragas", 104: "Graves", 120: "Hecarim", 74: "Heimerdinger", 420: "Illaoi", 39: "Irelia", 427: "Ivern", 40: "Janna", 59: "JarvanIV", 24: "Jax", 126: "Jayce", 202: "Jhin", 222: "Jinx", 145: "Kaisa", 429: "Kalista", 43: "Karma", 30: "Karthus", 38: "Kassadin", 55: "Katarina", 10: "Kayle", 141: "Kayn", 85: "Kennen", 121: "Khazix", 203: "Kindred", 240: "Kled", 96: "KogMaw", 7: "Leblanc", 64: "LeeSin", 89: "Leona", 127: "Lissandra", 236: "Lucian", 117: "Lulu", 99: "Lux", 54: "Malphite", 90: "Malzahar", 57: "Maokai", 11: "MasterYi", 21: "MissFortune", 62: "MonkeyKing", 82: "Mordekaiser", 25: "Morgana", 267: "Nami", 75: "Nasus", 111: "Nautilus", 76: "Nidalee", 56: "Nocturne", 20: "Nunu", 2: "Olaf", 61: "Orianna", 516: "Ornn", 80: "Pantheon", 78: "Poppy", 555: "Pyke", 133: "Quinn", 497: "Rakan", 33: "Rammus", 421: "RekSai", 58: "Renekton", 107: "Rengar", 92: "Riven", 68: "Rumble", 13: "Ryze", 113: "Sejuani", 35: "Shaco", 98: "Shen", 102: "Shyvana", 27: "Singed", 14: "Sion", 15: "Sivir", 72: "Skarner", 37: "Sona", 16: "Soraka", 50: "Swain", 134: "Syndra", 223: "TahmKench", 163: "Taliyah", 91: "Talon", 44: "Taric", 17: "Teemo", 412: "Thresh", 18: "Tristana", 48: "Trundle", 23: "Tryndamere", 4: "TwistedFate", 29: "Twitch", 77: "Udyr", 6: "Urgot", 110: "Varus", 67: "Vayne", 45: "Veigar", 161: "Velkoz", 254: "Vi", 112: "Viktor", 8: "Vladimir", 106: "Volibear", 19: "Warwick", 498: "Xayah", 101: "Xerath", 5: "XinZhao", 157: "Yasuo", 83: "Yorick", 154: "Zac", 238: "Zed", 115: "Ziggs", 26: "Zilean", 142: "Zoe", 143: "Zyra" };
|
||||||
var req = new XMLHttpRequest();
|
var req = new XMLHttpRequest();
|
||||||
var url = '/api';
|
var url = '/api';
|
||||||
|
var params = 'playerName=Chil';
|
||||||
|
|
||||||
req.open('GET', url, true); // set this to POST if you would like
|
req.open('POST', url, true); // set this to POST if you would like
|
||||||
req.addEventListener('load', onLoad);
|
req.addEventListener('load', onLoad);
|
||||||
req.addEventListener('error', onError);
|
req.addEventListener('error', onError);
|
||||||
req.send();
|
req.setRequestHeader('Content-type', 'application/x-www-form-urlencoded');
|
||||||
|
req.send(params);
|
||||||
|
|
||||||
function onLoad() {
|
function onLoad() {
|
||||||
var response = this.responseText;
|
var response = this.responseText;
|
||||||
var parsedEntireResponse = JSON.parse(response);
|
var parsedEntireResponse = JSON.parse(response);
|
||||||
//console.log(parsedEntireResponse);
|
|
||||||
|
|
||||||
var userStats = parsedEntireResponse[0];
|
var userStats = parsedEntireResponse[0];
|
||||||
var rankedStats = JSON.parse(parsedEntireResponse[1]);
|
var rankedStats = JSON.parse(parsedEntireResponse[1]);
|
||||||
|
var soloQStats = rankedStats.length !== 0 ? (rankedStats[0].queueType == 'RANKED_SOLO_5x5' ? rankedStats[0] : rankedStats[1]) : false;
|
||||||
var matches = parsedEntireResponse[2];
|
var matches = parsedEntireResponse[2];
|
||||||
console.log(userStats);
|
//console.log(userStats);
|
||||||
console.log(rankedStats);
|
//console.log(rankedStats);
|
||||||
console.log(matches);
|
console.log(matches);
|
||||||
//console.log(rankedStats[0].playerOrTeamName);
|
console.log(soloQStats);
|
||||||
|
|
||||||
document.querySelector('.player__pp').style.background = 'url(https://cdn.valentinkaelin.ch/riot/profileicon/' + userStats.profileIconId + '.png) center/cover';
|
document.querySelector('.player__pp').style.background = 'url(https://cdn.valentinkaelin.ch/riot/profileicon/' + userStats.profileIconId + '.png) center/cover';
|
||||||
document.querySelector('.player__name').innerHTML = userStats.name;
|
document.querySelector('.player__name').innerHTML = userStats.name;
|
||||||
document.querySelector('.player__level').innerHTML = userStats.summonerLevel;
|
document.querySelector('.player__level').innerHTML = userStats.summonerLevel;
|
||||||
document.querySelector('.player__rank').innerHTML = rankedStats.length !== 0 ? rankedStats[0].tier + ' ' + rankedStats[0].rank : "Joueur non classé";
|
document.querySelector('.player__rank').innerHTML = soloQStats ? soloQStats.tier + ' ' + soloQStats.rank : "Joueur non classé";
|
||||||
|
|
||||||
var rankImgLink;
|
var rankImgLink = getRankImg(soloQStats);
|
||||||
if (rankedStats.length !== 0) {
|
|
||||||
if (rankedStats[0].tier != 'MASTER' && rankedStats[0].tier != 'CHALLENGER') {
|
|
||||||
rankImgLink = '/public/img/tier-icons/' + rankedStats[0].tier.toLowerCase() + '_' + rankedStats[0].rank.toLowerCase() + '.png';
|
|
||||||
} else {
|
|
||||||
rankImgLink = '/public/img/tier-icons/' + rankedStats[0].tier.toLowerCase() + '.png';
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
rankImgLink = '/public/img/tier-icons/provisional.png';
|
|
||||||
}
|
|
||||||
document.querySelector('.player__rank-img').style.background = 'url(' + rankImgLink + ') center/cover';
|
document.querySelector('.player__rank-img').style.background = 'url(' + rankImgLink + ') center/cover';
|
||||||
|
document.querySelector('.player__ratio').innerHTML = soloQStats ? soloQStats.wins + ' wins / ' + soloQStats.losses + ' losses' : "Joueur non classé";
|
||||||
document.querySelector('.player__ratio').innerHTML = rankedStats.length !== 0 ? rankedStats[0].wins + ' wins / ' + rankedStats[0].losses + ' losses' : "Joueur non classé";
|
|
||||||
|
|
||||||
|
|
||||||
var playerContainer = document.querySelector('.player');
|
var playerContainer = document.querySelector('.player');
|
||||||
|
|
@ -69,7 +61,25 @@ var changeName = document.querySelector('#changeName');
|
||||||
var nameToPick = document.querySelector('#name')
|
var nameToPick = document.querySelector('#name')
|
||||||
changeName.addEventListener('submit', function (e) {
|
changeName.addEventListener('submit', function (e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
url = '/api?' + nameToPick.value;
|
//url = '/api?' + nameToPick.value;
|
||||||
req.open('GET', url, true);
|
url = '/api';
|
||||||
req.send();
|
req.open('POST', url, true);
|
||||||
|
req.setRequestHeader('Content-type', 'application/x-www-form-urlencoded');
|
||||||
|
req.send('playerName=' + nameToPick.value);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the link of the rank image
|
||||||
|
* @param soloQStats : stats in soloQ of the player
|
||||||
|
*/
|
||||||
|
function getRankImg(soloQStats) {
|
||||||
|
if (soloQStats) {
|
||||||
|
if (soloQStats.tier != 'MASTER' && soloQStats.tier != 'CHALLENGER') {
|
||||||
|
return '/public/img/tier-icons/' + soloQStats.tier.toLowerCase() + '_' + soloQStats.rank.toLowerCase() + '.png';
|
||||||
|
} else {
|
||||||
|
return '/public/img/tier-icons/' + soloQStats.tier.toLowerCase() + '.png';
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return '/public/img/tier-icons/provisional.png';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -32,7 +32,22 @@
|
||||||
margin: 0 auto;
|
margin: 0 auto;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.list-matches {
|
||||||
|
list-style-type: none;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.list-matches li {
|
||||||
|
padding: 10px 0;
|
||||||
|
background: #F1F5F8;
|
||||||
|
}
|
||||||
|
|
||||||
|
.list-matches li:nth-child(2n) {
|
||||||
|
background: #DAE1E7;
|
||||||
|
}
|
||||||
|
|
||||||
.champion-icon {
|
.champion-icon {
|
||||||
width: 48px;
|
width: 48px;
|
||||||
height: 48px;
|
height: 48px;
|
||||||
|
margin-left: 5px;
|
||||||
}
|
}
|
||||||
29
server.js
29
server.js
|
|
@ -1,16 +1,22 @@
|
||||||
const express = require('express')
|
const express = require('express')
|
||||||
const request = require('request');
|
const request = require('request');
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
|
const bodyParser = require('body-parser');
|
||||||
|
|
||||||
const app = express()
|
const app = express()
|
||||||
app.set('port', (process.env.PORT || 5000))
|
app.set('port', (process.env.PORT || 5000))
|
||||||
|
|
||||||
const key = 'RGAPI-79f2b14e-a46e-4520-b7d8-475b8b89b9bc';
|
const key = 'RGAPI-5be8ff59-ab0b-48a8-a924-10984670a571';
|
||||||
//var id = 65362306;
|
|
||||||
var summonerID = 'HMOiIUvzYtfgPk5X53zWTeOZo52T-HYJQhwvhkPNh0BWxZ0';
|
var summonerID = 'HMOiIUvzYtfgPk5X53zWTeOZo52T-HYJQhwvhkPNh0BWxZ0';
|
||||||
var accountID = 'V1xNS14bjVeP54hg03JeMxkXJB29K4TfUMvijDB85nxbD4Y';
|
var accountID = 'V1xNS14bjVeP54hg03JeMxkXJB29K4TfUMvijDB85nxbD4Y';
|
||||||
var pseudo = 'Chil';
|
var pseudo = 'Chil';
|
||||||
|
|
||||||
|
/* To retrieve data of post request */
|
||||||
|
app.use( bodyParser.json() ); // to support JSON-encoded bodies
|
||||||
|
app.use(bodyParser.urlencoded({ // to support URL-encoded bodies
|
||||||
|
extended: true
|
||||||
|
}));
|
||||||
|
|
||||||
/* Homepage */
|
/* Homepage */
|
||||||
app.get('/', function (request, response) {
|
app.get('/', function (request, response) {
|
||||||
response.sendFile(path.join(__dirname, 'index.html'));
|
response.sendFile(path.join(__dirname, 'index.html'));
|
||||||
|
|
@ -53,6 +59,25 @@ app.get('/api', function (req, res) {
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
app.post('/api', function(req, res) {
|
||||||
|
console.log(req.body.playerName);
|
||||||
|
pseudo = req.body.playerName;
|
||||||
|
|
||||||
|
getAccountInfos(function (account) {
|
||||||
|
getRanked(function (ranked) {
|
||||||
|
getMatches(function(matches) {
|
||||||
|
var finalJSON = new Array();
|
||||||
|
finalJSON.push(account);
|
||||||
|
finalJSON.push(ranked);
|
||||||
|
finalJSON.push(matches);
|
||||||
|
res.send(finalJSON);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
app.get('/api', function (req, res) {
|
app.get('/api', function (req, res) {
|
||||||
var name = req.url.split('?')[1];
|
var name = req.url.split('?')[1];
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue