Compare commits

..

No commits in common. "0b19f848147464782222b097836e924ff41de791" and "37612ee218acc58fdf956f7ec48e775e7b854452" have entirely different histories.

9 changed files with 1154 additions and 1316 deletions

View File

@ -8,8 +8,9 @@ Now that there are now more than 900 of them, and it's as useful as ever! The we
### Planned updates
- Make answer choices closer by type
- Multiple forms visible in Flashdex
- Custom input answers for harder difficulty
- Pokémon type support
- Type weakness calculator
### Scripts

View File

@ -79,7 +79,7 @@
</article>
</div>
<footer>
<p>© 2012 - 2022 Pokétest 2.8</p>
<p>© 2012 - 2022 Pokétest 2.7</p>
</footer>
</body>
</html>

View File

@ -85,7 +85,7 @@
</div>
</article>
<footer>
<p>© 2012 - 2022 Pokétest 2.8</p>
<p>© 2012 - 2022 Pokétest 2.7</p>
</footer>
</div>
</body>

View File

@ -1,5 +1,5 @@
$(document).ready(function()
{
$(document).ready(function() {
/****** Generations ******/
var G1 = [1, 151];
var G2 = [152, 251];
@ -14,23 +14,19 @@ $(document).ready(function()
var GIGA = [959, 990];
var REG = [991, 1043];
var EXCEPTION = 990; // urshifu g-max
/************ GAME *************/
/*******************************/
// loading json file
$.getJSON('pokemon.json', function(pk)
{
var json = $.getJSON('pokemon.json', function(pk) {
$('article #container #game #loading').hide();
var pklist = pk;
$('article #container #flashdex_config .all').click(function()
{
if ($(this).hasClass("unselected"))
{
$('article #container #flashdex_config .all').click(function() {
if ($(this).hasClass("unselected")) {
for (i = 1; i < 10; ++i)
$('input[name="'+i+'g"]').prop('checked', true);
$('input[name="mega"]').prop('checked', true);
@ -38,9 +34,7 @@ $(document).ready(function()
$('input[name="gigantamax"]').prop('checked', true);
$(this).removeClass("unselected").addClass("selected");
$(this).text("Unselect all");
}
else
{
} else {
for (i = 1; i < 10; ++i)
$('input[name="'+i+'g"]').prop('checked', false);
$('input[name="mega"]').prop('checked', false);
@ -52,8 +46,8 @@ $(document).ready(function()
})
// start the game when clicking on start game
$('article #container .button input.start').click(function()
{
$('article #container .button input.start').click(function() {
$('article #container #game #loading').show();
$('article #container #game #flashdex').empty();
@ -65,8 +59,7 @@ $(document).ready(function()
$('article #container #game #flashdex').hide();
function getFormText(pkmn)
{
function getFormText(pkmn) {
if (pkmn["origin"] == "Kanto")
return '<span class="form RB"></span>'
else if (pkmn["origin"] == "Johto")
@ -87,203 +80,55 @@ $(document).ready(function()
return '<span class="form LA"></span>'
else if (pkmn["origin"] == "9G")
return '<span class="form SV"></span>'
else if (pkmn["form"] == "mega")
else if (pkmn["type"] == "mega")
return '<span class="form mega"></span>';
else if (pkmn["form"] == "giga")
else if (pkmn["type"] == "giga")
return '<span class="form giga"></span>';
return '';
}
function getFormattedNumber(num)
{
if (num > 905 && num < 909)
return "???";
function getFormattedNumber(num) {
if (num[0] == 'M' || num[0] == 'R' || num[0] == 'G')
return num.substring(1, num.length);
return num;
}
function getFormattedTypes(num) {
str = '<span class="types"><span class="'+num["type"][0]+'">'+num["type"][0]+'</span>';
if (num["type"][1])
str += '<span class="'+num["type"][1]+'">'+num["type"][1]+'</span>';
str += '</span>';
return str;
}
function getFormattedTypes(num, index)
{
str = '<span class="'+num["type"+index][0]+'">'+num["type"+index][0]+'</span>';
if (num["type"+index][1])
str += '<span class="'+num["type"+index][1]+'">'+num["type"+index][1]+'</span>';
return str;
}
function getFormattedSpriteButton(num)
{
if (num["sprite"] || num["origin"] == "Kanto")
return '<span class="button"><span class="left-arrow">⯇</span><span class="right-arrow">⯈</span></span>';
return '';
}
for (i in pokemon_generation_list)
{
for (i in pokemon_generation_list) {
$('article #container #game #flashdex').append(
'<div class="pokedex id_'+pklist.mn[pokemon_generation_list[i]]["num"]+'">'
+ '<span class="types">' + getFormattedTypes(pklist.mn[pokemon_generation_list[i]], '') + '</span>'
+ getFormattedSpriteButton(pklist.mn[pokemon_generation_list[i]], '')
+ getFormText(pklist.mn[pokemon_generation_list[i]]) // either gigantamax or mega-evolution
+ '<img src="pokemon/'+ imageType(pklist.mn[pokemon_generation_list[i]]) +'.png"/>'
+ '<img src="pokemon/'+ imageType((pklist.mn[pokemon_generation_list[i]]["num"])) +'.png"/>'
+ '<span class="name">' + '<strong>' + '#' + getFormattedNumber(pklist.mn[[pokemon_generation_list[i]]]["num"]) + '</strong> '
+ pklist.mn[[pokemon_generation_list[i]]][lang] + '</span>'
+ '</div>'
);
}
$('article #container #game #flashdex').waitForImages(function()
{
$('article #container #game #flashdex').waitForImages(function() {
$(this).show();
$('article #container #game #loading').hide();
});
function handleArtworks(origin, left)
{
function handleDefault()
{
var form = url.split('-')[1];
function generations() {
if (left)
{
if (form > 0)
form--;
else
form = pklist.mn[pokemon-1]["sprite"] - 1;
}
else
{
if (form < pklist.mn[pokemon-1]["sprite"] - 1)
form++;
else
form = 0;
}
var newUrl = 'pokemon/' + pokemon + '-' + form + '.png';
origin.parent().parent().find("img").attr('src', newUrl);
handleChangeType(form, pokemon-1)
}
function handleKanto()
{
var KantoForm = '';
for (var i = 0; i < originalUrl.length; i++)
{
if (originalUrl[i].match(/[A-Z]/))
KantoForm += originalUrl[i];
}
if (left)
{
if (KantoForm == "RG")
KantoForm = "RB"
else if (KantoForm == "RB")
KantoForm = "";
else
KantoForm = "RG";
}
else
{
if (KantoForm == "RB")
KantoForm = "RG"
else if (KantoForm == "RG")
KantoForm = "";
else
KantoForm = "RB";
}
var newUrl = 'pokemon/' + pokemon + KantoForm + '.png';
origin.parent().parent().find("img").attr('src', newUrl);
}
function handleException()
{
var form = url.split('-')[1];
if (form == 0)
form = 1;
else
form = 0;
var newUrl = 'pokemon/' + pokemonUrl + '-' + form + '.png';
origin.parent().parent().find("img").attr('src', newUrl);
handleChangeType(form, EXCEPTION-1)
}
function handleChangeType(form, num)
{
if (form != 0)
{
if (pklist.mn[num]["type"+form])
origin.parent().parent().find(".types").empty().append(getFormattedTypes(pklist.mn[num], form));
}
else
origin.parent().parent().find(".types").empty().append(getFormattedTypes(pklist.mn[num], ''));
}
var url = origin.parent().parent().find("img").attr('src');
var originalUrl = url;
url = url.split('/')[1];
url = url.split('.')[0];
var pokemonUrl = url.split('-')[0];
var pokemon = '';
for (var i = 0; i < pokemonUrl.length; i++)
{
if (pokemonUrl[i].match(/[0-9]/))
pokemon += pokemonUrl[i];
}
if (pokemonUrl == "G892")
handleException();
else if (pklist.mn[pokemon-1]["origin"] == "Kanto" && !pklist.mn[pokemon-1]["sprite"])
handleKanto();
else if (pklist.mn[pokemon-1]["sprite"])
handleDefault();
}
$('.left-arrow').click(function(e)
{
handleArtworks($(this), true);
});
$('.right-arrow').click(function(e)
{
handleArtworks($(this), false);
});
function generations()
{
// create the list of the different generations
function createGenerationList(name)
{
function createGenerationList(name) {
if ( $('article input[name="'+name+'"]').is(':checked') )
gen_list[gen_list.length] = name;
}
// create the list of all possible pokemons for selected options
function generatePokemonList()
{
function evaluateByGeneration(index, name, variable)
{
if (gen_list[index] == name)
{
function generatePokemonList() {
function evaluateByGeneration(index, name, variable) {
if (gen_list[index] == name) {
for (j = (variable[0] - 1); j <= (variable[1] - 1); j++)
pokemon_generation_list[pokemon_generation_list.length] = j;
}
}
if (gen_list.length > 0)
{
for (i in gen_list)
{
if (gen_list.length > 0) {
for (i in gen_list) {
evaluateByGeneration(i, "1g", G1); evaluateByGeneration(i, "2g", G2); evaluateByGeneration(i, "3g", G3);
evaluateByGeneration(i, "4g", G4); evaluateByGeneration(i, "5g", G5); evaluateByGeneration(i, "6g", G6);
evaluateByGeneration(i, "7g", G7); evaluateByGeneration(i, "8g", G8); evaluateByGeneration(i, "9g", G9);
@ -301,15 +146,44 @@ $(document).ready(function()
generatePokemonList();
}
// multiple artworks
function imageType(num)
{
//if (num["origin"] == "Kanto")
// return num["num"] + "RB";
if (num["sprite"])
return num["num"] + "-0";
return num["num"];
function imageType(result) {
var four_types = [351, 386, 585, 586, 676, 741, 800];
var three_types = [249, 250, 384, 412, 413, 718, 745, 898];
var two_types = [251, 252, 255, 258, 374, 387, 390, 393, 421, 422, 423, 487, 492, 495, 498, 501, 521, 550, 555,
592, 593, 641, 642, 643, 644, 645, 647, 648, 668, 678, 681, 720, 746, 774, 791, 792, 802, 849,
876, 877, 888, 889, 892, 905, "G892"];
function no_randomizer() {
if (result === 25)
return (result+'-9');
if (result === 666)
return (result+'-0');
if (result === 646)
return (result+'-0');
if (result === 479)
return (result+'-0');
for (a in four_types) {
if (four_types[a] == result)
return (result+'-0');
}
});
for (a in three_types) {
if (three_types[a] == result)
return (result+'-0');
}
for (a in two_types) {
if (two_types[a] == result)
return (result+'-0');
}
return result;
}
return no_randomizer(result);
}
});
});
});

View File

@ -141,7 +141,7 @@
</div>
</article>
<footer>
<p>© 2012 - 2022 Pokétest 2.8</p>
<p>© 2012 - 2022 Pokétest 2.7</p>
</footer>
</div>
<script>

@ -1 +1 @@
Subproject commit cafa98a3b0c530d30423c4d48ba266a1a0b2c7b4
Subproject commit 169163ed0057b273f8305de4827ccbd433efee5c

File diff suppressed because it is too large Load Diff

View File

@ -170,26 +170,36 @@ $(document).ready(function() {
// multiple artworks
function imageType(result)
{
function randomizer(result)
// TODO
var four_types = [351, 386, 585, 586, 676, 741, 800];
var three_types = [249, 250, 384, 412, 413, 718, 745, 898];
var two_types = [251, 252, 255, 258, 374, 387, 390, 393, 421, 422, 423, 487, 492, 495, 498, 501, 521, 550, 555,
592, 593, 641, 642, 643, 644, 645, 647, 648, 668, 678, 681, 720, 746, 774, 791, 792, 802, 849,
876, 877, 888, 889, 892, 905, "G892"];
function randomizer()
{
if (pk.mn[result]["sprite"])
return pklist.mn[result]["num"] + '-' + random(0, pk.mn[result]["sprite"] - 1);
else
{
if (pk.mn[result]["origin"] == "Kanto")
{
randomValue = random(0, 2);
if (randomValue == 0)
return pklist.mn[result]["num"];
else if (randomValue == 1)
return pklist.mn[result]["num"]+'RB';
else if (randomValue == 2)
return pklist.mn[result]["num"]+'RG';
if (result >= MEGA[0]) return (pklist.mn[result-1]["num"])
if (result === 25) return (result+'-'+random(0, 16));
if (result === 666) return (result+'-'+random(0, 20));
if (result === 646) return (result+'-'+random(0, 6));
if (result === 479) return (result+'-'+random(0, 5));
for (i in four_types) {
if (four_types[i] == result) return (result+'-'+random(0, 3));
}
return pklist.mn[result]["num"];
for (i in three_types) {
if (three_types[i] == result) return (result+'-'+random(0, 2));
}
for (i in two_types) {
if (two_types[i] == result) return (result+'-'+random(0, 1));
}
image_name = randomizer(result);
if (result > 151) return result;
if ((tmp = random(0, 2)) == 0) return result;
else if (tmp == 1) return (result+'RB');
else return (result+'RG');
}
image_name = randomizer(result+1);
image_memory = new Image();
image_memory.src = 'pokemon/' + image_name + '.png';
return image_name;
@ -229,7 +239,7 @@ $(document).ready(function() {
answer = pklist.mn[result][lang];
chooseOptions(result, lang);
imageType(result);
imageType(result + 1);
}
function game()

View File

@ -353,7 +353,7 @@ article #container.diploma #score {
}
#container #game #flashdex .pokedex {
width: 250px;
width: 250px; height: 285px;
border: 1px solid white;
padding: 10px;
margin: 10px;
@ -368,79 +368,32 @@ article #container.diploma #score {
height: 250px;
display: block;
margin: auto;
margin: 12px auto;
}
#game #flashdex .pokedex .button {
position: absolute;
bottom: 0;
left: 0;
margin: 8px;
background: white;
padding: 1.5px;
border-radius: 5px;
color: dimgray;
#game #flashdex .pokedex span.name {
text-align: center;
font-size: 1em;
display: block;
margin: auto; margin-top: 15px;
}
#game #flashdex .pokedex .left-arrow, #game #flashdex .pokedex .right-arrow {
cursor: pointer;
user-select: none;
}
#game #flashdex .pokedex span.form {
span.form {
display: block;
float: right;
width: 25px; height: 25px;
background-size: 25px 25px;
position: absolute;
right: 10px;
}
#game #flashdex .pokedex span.form.mega { background-image: url('img/icon_mega.png'); }
#game #flashdex .pokedex span.form.giga {
span.form.mega { background-image: url('img/icon_mega.png'); }
span.form.giga {
background-image: url('img/icon_giga.png'); background-color: white;
background-position: center; background-size:20px;
border-radius: 50%; border: 1px solid white;
}
#game #flashdex .pokedex span.types {
display: flex;
float: left;
margin-bottom: 12px;
}
#game #flashdex .pokedex span.types:after {
clear: both;
}
#game #flashdex .pokedex span.types span {
margin: 0px;
margin-right: 5px;
padding: 5px;
border-radius: 2px;
font-family: Sans-Serif;
font-weight: bold;
color: #fff;
font-size: 0.8rem;
}
#game #flashdex .pokedex span.types .Grass { background: #78C850; }
#game #flashdex .pokedex span.types .Poison { background: #A040A0; }
#game #flashdex .pokedex span.types .Fire { background: #F08030; }
#game #flashdex .pokedex span.types .Dragon { background: #7038F8; }
#game #flashdex .pokedex span.types .Flying { background: #A890F0; }
#game #flashdex .pokedex span.types .Water { background: #6890F0; }
#game #flashdex .pokedex span.types .Bug { background: #A8B820; }
#game #flashdex .pokedex span.types .Normal { background: #A8A878; }
#game #flashdex .pokedex span.types .Dark { background: #705848; }
#game #flashdex .pokedex span.types .Electric { background: #F8D030; }
#game #flashdex .pokedex span.types .Ground { background: #E0C068; }
#game #flashdex .pokedex span.types .Psychic { background: #F85888; }
#game #flashdex .pokedex span.types .Ice { background: #98D8D8; }
#game #flashdex .pokedex span.types .Steel { background: #B8B8D0; }
#game #flashdex .pokedex span.types .Fairy { background: #EE99AC; }
#game #flashdex .pokedex span.types .Fighting { background: #C03028; }
#game #flashdex .pokedex span.types .Rock { background: #B8A038; }
#game #flashdex .pokedex span.types .Ghost { background: #705898; }
/*** MOBILE ***/
@ -574,7 +527,8 @@ article #container.diploma #score {
/* flashdex */
#container #game #flashdex .pokedex { width: 230px; }
#container #game #flashdex .pokedex { width: 230px; height: 260px; }
#game #flashdex .pokedex img { height: 225px; }
#game #flashdex_config p { text-align: left; }
@ -586,10 +540,6 @@ article #container.diploma #score {
flex-wrap: wrap;
}
#game #flashdex .pokedex img {
height: 230px;
}
#game #flashdex_config .generation .gen {
display: block;
position: relative;