Commit c521fd32 by Pedro Rolon

Se agregaron archivos correspondientes a ejercicios faltantes

parent 26a09b9c
# Especificaciones # Especificaciones
* Los puntos del ejercicio que requerían métodos están desarrollados dentro del archivo **js-e007.js** * Los puntos del ejercicio que requerían métodos están desarrollados dentro del archivo **js-e007.js**
* Dentro del mismo archivo también se encuentran métodos necesarios para el control de los archivos **html**. Estos métodos y los requeridos por los ejercicios se encuentran separados en dos secciones, indicados mediante comentarios dentro del archivo. * Dentro del mismo archivo también se encuentran métodos necesarios para el control de los archivos **html**. Estos métodos y los requeridos por los ejercicios se encuentran separados en dos secciones, indicados mediante comentarios dentro del archivo.
* * Algunos archivos **html** tienen sus propios scripts, en la carpeta **js**, donde están copiados algunos códigos del **js** principal, más las funciones necesarias para dicho **html**
\ No newline at end of file * El archivo **galaxia.html** corresponde a los ejercicios **8** y **9**
* El archivo **abmPlaneta.html** corresponde a los ejercicios **10**, **11**, **12**
* El archivo **planetas.html** corresponde a los ejercicios **13**, **14** y **15**
\ No newline at end of file
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<link rel="stylesheet" href="node_modules/bootstrap/dist/css/bootstrap.min.css">
<title>ABM Planeta</title>
</head>
<body class="container">
<h1>ABM Planeta</h1>
<hr>
<div id="alta" class="col-md-3 panel panel-default">
<h3>Agregar planeta</h3>
<hr>
ID Planeta: <input type="text" id="idPlanetaAlta">
<br>
ID Galaxia: <input type="text" id = "idGalaxiaAlta">
<br>
Nombre: <input type="text" id="nombrePlanetaAlta">
<br>
URL foto: <input type="text" id="fotoPlanetaAlta">
<br>
<button onclick="alta()" class="btn btn-primary">Agregar</button>
</div>
<div class="col-md-1"></div>
<div id="baja" class="col-md-3 panel panel-default">
<h3>Eliminar planeta</h3>
<hr>
Planeta: <select id="selectBaja">
</select>
<br>
<button onclick="baja()" class="btn btn-primary">Eliminar</button>
</div>
<div class="col-md-1"></div>
<div id="modificacion" class="col-md-3 panel panel-default">
<h3>Modificar planeta</h3>
<br>
ID Planeta: <select id= "selectModificacion" onchange="cargarValoresModificacion()" id=>
</select>
<br>
Nombre: <input type="text" id="nombrePlanetaModificacion">
<br>
ID Galaxia: <input type="text" id="idGalaxiaModificacion">
<br>
<button class="btn btn-primary" onclick="modificacion()">Modificar</button>
</div>
<script src="js/abmPlanetas.js"></script>
</body>
</html>
\ No newline at end of file
...@@ -7,7 +7,6 @@ ...@@ -7,7 +7,6 @@
<link rel="stylesheet" href="node_modules/bootstrap/dist/css/bootstrap.min.css"> <link rel="stylesheet" href="node_modules/bootstrap/dist/css/bootstrap.min.css">
<title>Astrobootcamp004</title> <title>Astrobootcamp004</title>
</head> </head>
<!--Background is setting in js script-->
<body class="container"> <body class="container">
<h1> <h1>
Galaxia Galaxia
...@@ -16,11 +15,11 @@ ...@@ -16,11 +15,11 @@
<div class="row"> <div class="row">
<select id="galaxiaSelect"> <select id="galaxiaSelect">
</select> </select>
<div id="informacionGalaxia" class="row" hidden="hidden"> <div id="informacionGalaxia" class="row container" hidden="hidden">
<span>Lista de planetas</span> <span>Lista de planetas</span>
<ul id="listaPlanetas"> <ul id="listaPlanetas">
<li>Saturno</li> <li>Saturno</li>
...@@ -28,7 +27,6 @@ ...@@ -28,7 +27,6 @@
</div> </div>
<button onclick="seleccionar()">Seleccionar</button>
<button onclick="mostrarDetalleGalaxia()">Detalle</button> <button onclick="mostrarDetalleGalaxia()">Detalle</button>
<script src="js-e007.js"></script> <script src="js-e007.js"></script>
......
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<link rel="stylesheet" href="../node_modules/bootstrap/dist/css/bootstrap.min.css">
<title>Galaxia</title>
</head>
<body class="container">
<h1>[nombre galaxia]</h1>
<hr>
<div id="informacion">
<span id="idGalaxia" class="col-md-2">idGalaxia</span>
<span id="tipoGalaxia" class="col-md-2">tipoGalaxia</span>
</div>
<div id="planetasGalaxia" class="col-md-2">
<ul>
<li>Saturno</li>
<li>Urano</li>
<li>Urano</li>
</ul>
</div>
</body>
</html>
\ No newline at end of file
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Page Title</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" type="text/css" media="screen" href="main.css" />
<script src="main.js"></script>
<link rel="stylesheet" href="node_modules/bootstrap/dist/css/bootstrap.min.css">
</head>
<body>
</body>
</html>
\ No newline at end of file
...@@ -8,12 +8,110 @@ class Galaxia{ ...@@ -8,12 +8,110 @@ class Galaxia{
} }
class Planeta{ class Planeta{
constructor(planeta_id, galexia_id, nombre, fotos){ //1. Escribir un metodo que permita agregar un nuevo planeta
constructor(planeta_id, galaxia_id, nombre, fotos){
this.planeta_id = planeta_id; this.planeta_id = planeta_id;
this.galaxia_id = galexia_id; this.galaxia_id = galaxia_id;
this.nombre = nombre; this.nombre = nombre;
this.fotos = fotos; this.fotos = fotos;
} }
//1. Escribir un metodo que permita agregar un nuevo planeta
agregar(planetas){
planeta = new Planeta(this.idPlaneta, this.idGalaxia, this.nombrePlaneta, this.fotosPlaneta);
planetas.push(planeta);
}
//3. Escribir un metodo que permita actualizar los datos de un planeta
actualizar(nuevoIdGalaxia, nuevoNombrePlaneta, nuevoFotosPlaneta){
this.galaxia_id = nuevoIdGalaxia;
this.nombre = nuevoNombrePlaneta;
this.fotos = nuevoFotosPlaneta;
}
//6. Escribir un metodo que devuelva la lista de lunas del planeta
getLunas(lunasParametro){
let lunass = [];
for(i=0; i<lunasParametro.length; i++){
if(lunasParametro[i].planeta_id==this.planeta_id){
lunass.push(lunasParametro[i]);
console.log(lunasParametro[i].nombre);
}
}
return lunass;
}
//4. Escribir un metodo para calcular la distancia de un planeta en relacion al Sol
distanciaAlSol(){
var str = this.nombre.toLowerCase();
if(str=="mercurio"){
return 5791000000;
}
else if(str=="venus"){
return 1082000000;
}
else if(str=="tierra"){
return 1496000000;
}
else if(str=="marte"){
return 2279000000;
}
else if(str=="jupiter"){
return 7785000000;
}
else if(str=="saturno"){
return 1434000000000;
}
else if(str=="urano"){
return 2871000000000;
}
else if(str=="neptuno"){
return 4495000000000;
}
}
//5. Escribir un metodo para calcular la distancia de un planeta en relacion a la tierra
distanciaATierra(planeta){
var str = this.nombre.toLowerCase();
if(str=="mercurio"){
return 77000000;
}
else if(str=="venus"){
return 40000000;
}
else if(str=="tierra"){
return 0;
}
else if(str=="marte"){
return 59000000;
}
else if(str=="jupiter"){
return 594000000;
}
else if(str=="saturno"){
return 15000000000;
}
else if(str=="urano"){
return 2720000000;
}
else if(str=="neptuno"){
return 43000000000;
}
}
//7. Escribir un metodo que devuelva las fotografias del planeta
getFotografias(){
return this.fotos;
}
//2. Escribir un metodo que permita borrar un planeta
borrar(listaPlanetas){
for(i=0; i<listaPlanetas.length; i++){
if(listaPlanetas[i].planeta_id == this.planeta_id){
console.log("Se eliminó " + planetas[i].nombre);
listaPlanetas.splice(i,1);
}
}
}
} }
class Luna{ class Luna{
...@@ -46,7 +144,6 @@ function borrarPlaneta(idPlaneta){ ...@@ -46,7 +144,6 @@ function borrarPlaneta(idPlaneta){
if(planetas[i].planeta_id == idPlaneta){ if(planetas[i].planeta_id == idPlaneta){
console.log("Se eliminó " + planetas[i].nombre); console.log("Se eliminó " + planetas[i].nombre);
planetas.splice(i,1); planetas.splice(i,1);
} }
} }
} }
...@@ -56,23 +153,11 @@ function actualizarDatosPlaneta(idPlaneta, nuevoIdGalaxia, nuevoNombrePlaneta, n ...@@ -56,23 +153,11 @@ function actualizarDatosPlaneta(idPlaneta, nuevoIdGalaxia, nuevoNombrePlaneta, n
for(i=0; i<planetas.length; i++){ for(i=0; i<planetas.length; i++){
if(planetas[i].planeta_id == idPlaneta){ if(planetas[i].planeta_id == idPlaneta){
console.log("Se actualiza " + planetas[i].nombre); console.log("Se actualiza " + planetas[i].nombre);
planetas[i].galaxia_id = nuevoIdGalaxia; planetas[i].actualizar(nuevoIdGalaxia, nuevoNombrePlaneta, nuevoFotosPlaneta);
planetas[i].nombre = nuevoNombrePlaneta;
planetas[i].fotos = nuevoFotosPlaneta;
} }
} }
} }
//4. Escribir un metodo para calcular la distancia de un planeta en relacion al Sol
function distanciaPlanetaSol(){
}
//5. Escribir un metodo para calcular la distancia de un planeta en relacion a la tierra
function distanciaPlanetaATierra(){
}
//6. Escribir un metodo que devuelva la lista de lunas del planeta //6. Escribir un metodo que devuelva la lista de lunas del planeta
function lunasDe(idPlaneta){ function lunasDe(idPlaneta){
let lunasDePlaneta = []; let lunasDePlaneta = [];
...@@ -100,8 +185,10 @@ function fotografias(idPlaneta){ ...@@ -100,8 +185,10 @@ function fotografias(idPlaneta){
//Devuelve una lista de los planetas correspondientes al id de //Devuelve una lista de los planetas correspondientes al id de
//la galaxia recibida //la galaxia recibida
function planetasDe(idGalaxia){ function planetasDe(idGalaxia){
let planetasDeGalaxia = [];
for(i=0; i<galaxias.length; i++){ let planetasDeGalaxia = [];
for(i=0; i<planetas.length; i++){
if(planetas[i].galaxia_id==idGalaxia){ if(planetas[i].galaxia_id==idGalaxia){
planetasDeGalaxia.push(planetas[i]); planetasDeGalaxia.push(planetas[i]);
//console.log(planetas[i]); //console.log(planetas[i]);
...@@ -143,6 +230,7 @@ function crearDatos(){ ...@@ -143,6 +230,7 @@ function crearDatos(){
lunas.push(luna); lunas.push(luna);
luna = new Luna("Encelado", 2, ["https://upload.wikimedia.org/wikipedia/commons/thumb/5/5f/Enceladusstripes_cassini.jpg/250px-Enceladusstripes_cassini.jpg", "https://static.scientificamerican.com/arabic/cache/file/531AF767-D9AC-4D9E-B13D2A5C98DEC186_source.jpg", "https://cdn.img.inosmi.ru/images/23704/25/237042551.jpg"]); luna = new Luna("Encelado", 2, ["https://upload.wikimedia.org/wikipedia/commons/thumb/5/5f/Enceladusstripes_cassini.jpg/250px-Enceladusstripes_cassini.jpg", "https://static.scientificamerican.com/arabic/cache/file/531AF767-D9AC-4D9E-B13D2A5C98DEC186_source.jpg", "https://cdn.img.inosmi.ru/images/23704/25/237042551.jpg"]);
lunas.push(luna);
} }
crearDatos(); crearDatos();
...@@ -185,13 +273,4 @@ function mostrarDetalleGalaxia(){ ...@@ -185,13 +273,4 @@ function mostrarDetalleGalaxia(){
} }
document.getElementById("informacionGalaxia").removeAttribute("hidden"); document.getElementById("informacionGalaxia").removeAttribute("hidden");
} }
\ No newline at end of file
//Esta función tiene que cambiar los datos mostrados en el detalle
//y cambiar el background!
function seleccionar(){
console.log("haciendo todo lo que dice la descripcion que hace este método");
}
//Crear un mapeo de clases de los planetas con los siguiente estructura
class Galaxia{
constructor(galaxia_id, nombre, tipo_galaxia){
this.galaxia_id = galaxia_id;
this.nombre = nombre;
this.tipo_galaxia = tipo_galaxia;
}
}
class Planeta{
//1. Escribir un metodo que permita agregar un nuevo planeta
constructor(planeta_id, galaxia_id, nombre, fotos){
this.planeta_id = planeta_id;
this.galaxia_id = galaxia_id;
this.nombre = nombre;
this.fotos = fotos;
}
//3. Escribir un metodo que permita actualizar los datos de un planeta
actualizar(nuevoIdGalaxia, nuevoNombrePlaneta){
this.galaxia_id = nuevoIdGalaxia;
this.nombre = nuevoNombrePlaneta;
}
//6. Escribir un metodo que devuelva la lista de lunas del planeta
getLunas(lunasParametro){
let lunass = [];
for(i=0; i<lunasParametro.length; i++){
if(lunasParametro[i].planeta_id==this.planeta_id){
lunass.push(lunasParametro[i]);
console.log(lunasParametro[i].nombre);
}
}
return lunass;
}
//4. Escribir un metodo para calcular la distancia de un planeta en relacion al Sol
distanciaAlSol(){
var str = this.nombre.toLowerCase();
if(str=="mercurio"){
return 5791000000;
}
else if(str=="venus"){
return 1082000000;
}
else if(str=="tierra"){
return 1496000000;
}
else if(str=="marte"){
return 2279000000;
}
else if(str=="jupiter"){
return 7785000000;
}
else if(str=="saturno"){
return 1434000000000;
}
else if(str=="urano"){
return 2871000000000;
}
else if(str=="neptuno"){
return 4495000000000;
}
}
//5. Escribir un metodo para calcular la distancia de un planeta en relacion a la tierra
distanciaATierra(planeta){
var str = this.nombre.toLowerCase();
if(str=="mercurio"){
return 77000000;
}
else if(str=="venus"){
return 40000000;
}
else if(str=="tierra"){
return 0;
}
else if(str=="marte"){
return 59000000;
}
else if(str=="jupiter"){
return 594000000;
}
else if(str=="saturno"){
return 15000000000;
}
else if(str=="urano"){
return 2720000000;
}
else if(str=="neptuno"){
return 43000000000;
}
}
//7. Escribir un metodo que devuelva las fotografias del planeta
getFotografias(){
return this.fotos;
}
}
class Luna{
constructor(nombre, planeta_id, fotos){
this.nombre = nombre;
this.planeta_id = planeta_id;
this.fotos = fotos;
}
}
//Lista de Galaxias
let galaxias = [];
//Lista de Planetas
let planetas = [];
//Lista de Lunas
let lunas = [];
//1. Escribir un metodo que permita agregar un nuevo planeta
function agregarPlaneta(idPlaneta, idGalaxia, nombrePlaneta, fotosPlaneta){
planeta = new Planeta(idPlaneta, idGalaxia, nombrePlaneta, fotosPlaneta);
planetas.push(planeta);
}
//2. Escribir un metodo que permita borrar un planeta
function borrarPlaneta(idPlaneta){
for(i=0; i<planetas.length; i++){
if(planetas[i].planeta_id == idPlaneta){
console.log("Se eliminó " + planetas[i].nombre);
planetas.splice(i,1);
}
}
}
//3. Escribir un metodo que permita actualizar los datos de un planeta
function actualizarDatosPlaneta(idPlaneta, nuevoIdGalaxia, nuevoNombrePlaneta, nuevoFotosPlaneta){
for(i=0; i<planetas.length; i++){
if(planetas[i].planeta_id == idPlaneta){
console.log("Se actualiza " + planetas[i].nombre);
planetas[i].actualizar(nuevoIdGalaxia, nuevoNombrePlaneta);
}
}
}
//6. Escribir un metodo que devuelva la lista de lunas del planeta
function lunasDe(idPlaneta){
let lunasDePlaneta = [];
for(i=0; i<lunas.length; i++){
if(lunas[i].planeta_id==idPlaneta){
lunasDePlaneta.push(lunas[i]);
console.log(lunas[i].nombre);
}
}
return lunasDePlaneta;
}
//7. Escribir un metodo que devuelva las fotografias del planeta
function fotografias(idPlaneta){
let fotogafiasDePlaneta = [];
for(i=0; i<lunas.length; i++){
if(planetas[i].planeta_id==idPlaneta){
fotografiasDePlaneta.push(planetas[i].fotos);
console.log(planetas[i].fotos);
}
}
return fotografiasDePlaneta;
}
//Devuelve una lista de los planetas correspondientes al id de
//la galaxia recibida
function planetasDe(idGalaxia){
let planetasDeGalaxia = [];
for(i=0; i<planetas.length; i++){
if(planetas[i].galaxia_id==idGalaxia){
planetasDeGalaxia.push(planetas[i]);
//console.log(planetas[i]);
}
}
return planetasDeGalaxia;
}
function crearDatos(){
//Se añaden las galaxias
let galaxia = new Galaxia(1, "Via Lactea", "Espiral");
galaxias.push(galaxia);
galaxia = new Galaxia(2, "Nube de Magallanes", "Eliptica");
galaxias.push(galaxia);
galaxia = new Galaxia(3, "Sculptor", "Esferoidal");
galaxias.push(galaxia);
agregarPlaneta(1, 1, "Tierra", ["https://www.caracteristicas.co/wp-content/uploads/2017/02/planeta-tierra-min-e1487870067631.jpg", "http://www.bodecor.com/image/cache/data/productos/JUEGOSEDUCATIVOS/6883636513p-500x500.jpg", "https://i2.wp.com/www.4vientos.net/wp-content/uploads/2018/03/TIERRA-PLANETA-AMANECER-1.jpg?resize=800%2C439"]);
agregarPlaneta(2, 1, "Saturno", ["https://upload.wikimedia.org/wikipedia/commons/thumb/c/c7/Saturn_during_Equinox.jpg/1200px-Saturn_during_Equinox.jpg","https://upload.wikimedia.org/wikipedia/commons/thumb/c/c7/Saturn_during_Equinox.jpg/1200px-Saturn_during_Equinox.jpg", "https://www.meteorologiaenred.com/wp-content/uploads/2018/08/Atm%C3%B3sfera-de-Saturno.jpg"]);
agregarPlaneta(3, 2, "Krypton", ["https://www.ecured.cu/images/thumb/c/cf/Krypton_%28planeta%29.jpg/260px-Krypton_%28planeta%29.jpg", "https://vignette.wikia.nocookie.net/starwars/images/d/d6/Toydaria-TCW.png/revision/latest?cb=20130506235119", "https://vignette.wikia.nocookie.net/supergirl/images/b/b5/Planet_Krypton.png/revision/latest?cb=20171206023736&path-prefix=es"]);
agregarPlaneta(4, 3, "Cybertron", ["https://upload.wikimedia.org/wikipedia/en/2/2d/MovieCybertron.jpg", "https://vignette.wikia.nocookie.net/michaelbaystransformers/images/c/cf/Movie_Cybertron.jpg/revision/latest?cb=20151108163309", "https://www.meme-arsenal.com/memes/c559b3b9e3d0a90b3c267b0a611a5f61.jpg"]);
let luna = new Luna("Luna", 1, ["https://upload.wikimedia.org/wikipedia/commons/thumb/d/dd/Full_Moon_Luc_Viatour.jpg/280px-Full_Moon_Luc_Viatour.jpg","https://upload.wikimedia.org/wikipedia/commons/thumb/d/d8/Ganymede_g1_true_2.jpg/270px-Ganymede_g1_true_2.jpg","https://images2.corriereobjects.it/methode_image/2017/01/11/Scienze/Foto%20Scienze%20-%20Trattate/AFP_JQ6DS-0002-kUPG-U43270811099596WNF-1224x916@Corriere-Web-Sezioni-593x443.jpg?v=20170111154027"]);
lunas.push(luna);
luna = new Luna("Titan", 2, ["https://www.muyinteresante.com.mx/wp-content/uploads/2018/05/httpstved-prod.adobecqms.netcontentdameditorialTelevisamexicomuyinteresantemxjuniorespacio170220titan.imgo_-770x528.jpg","https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTLEUZwBd52os9ND0Zwo7dxvl2IkePZMPCKsBjuGE2XRi28I_1J","https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTUv60cmCb7ABSLqdRrQdOT2p8X1jZAqGbQQwzt5rxB5ZUxUqYh"]);
lunas.push(luna);
luna = new Luna("Encelado", 2, ["https://upload.wikimedia.org/wikipedia/commons/thumb/5/5f/Enceladusstripes_cassini.jpg/250px-Enceladusstripes_cassini.jpg", "https://static.scientificamerican.com/arabic/cache/file/531AF767-D9AC-4D9E-B13D2A5C98DEC186_source.jpg", "https://cdn.img.inosmi.ru/images/23704/25/237042551.jpg"]);
lunas.push(luna);
}
crearDatos();
function cargarSelects(){
let planetaSelect = document.getElementById("selectBaja");
let selectModificacion = document.getElementById("selectModificacion");
while(planetaSelect.firstChild){
planetaSelect.removeChild(planetaSelect.firstChild);
selectModificacion.removeChild(selectModificacion.firstChild);
}
for(i=0; i<planetas.length; i++){
let option = document.createElement("option");
option.value = planetas[i].planeta_id;
option.innerHTML = planetas[i].nombre;
planetaSelect.appendChild(option);
let option2 = document.createElement("option");
option2.value = planetas[i].planeta_id;
option2.innerHTML = planetas[i].planeta_id;
selectModificacion.appendChild(option2);
}
}
cargarSelects();
function alta(){
let idPlaneta = document.getElementById("idPlanetaAlta").value;
let idGalaxia = document.getElementById("idGalaxiaAlta").value;
let nombrePlaneta = document.getElementById("nombrePlanetaAlta").value;
let fotoPlaneta = document.getElementById("fotoPlanetaAlta").value;
if(idPlaneta==""||idGalaxia==""||nombrePlaneta==""||fotoPlaneta==""){
alert("algún campo está vacío y eso no puede ser che memby");
return;
}
agregarPlaneta(idPlaneta, idGalaxia, nombrePlaneta, [fotoPlaneta]);
console.log(nombrePlaneta + " agregado!");
cargarSelects();
}
function baja(){
var planetaSelect = document.getElementById("selectBaja");
var idPlaneta = planetaSelect.options[planetaSelect.selectedIndex].value;
borrarPlaneta(idPlaneta);
console.log("se borró exitosamente mi gente");
console.log(planetas.length);
cargarSelects();
}
function modificacion(){
var planetaSelect = document.getElementById("selectModificacion");
var idPlaneta = planetaSelect.options[planetaSelect.selectedIndex].value;
var nuevoNombrePlaneta = document.getElementById("nombrePlanetaModificacion");
var nuevoIdGalaxia = document.getElementById("idGalaxiaModificacion");
for(i=0; i<planetas.length; i++){
if(planetas[i].planeta_id==idPlaneta){
planetas[i].actualizar(nuevoIdGalaxia, nuevoNombrePlaneta);
}
}
cargarSelects();
console.log("ejecutando funcion modificacion()");
}
function cargarValoresModificacion(){
var selectPlaneta = document.getElementById("selectModificacion");
var idPlaneta = selectPlaneta.options[selectPlaneta.selectedIndex].value;
var nombrePlaneta;
var idGalaxia;
for(i=0; i<planetas.length; i++){
if(planetas[i].planeta_id==idPlaneta){
nombrePlaneta = planetas[i].nombre;
idGalaxia = planetas[i].galaxia_id;
}
}
document.getElementById("nombrePlanetaModificacion").value=nombrePlaneta;
document.getElementById("idGalaxiaModificacion").value=idGalaxia;
}
\ No newline at end of file
//Crear un mapeo de clases de los planetas con los siguiente estructura
class Galaxia{
constructor(galaxia_id, nombre, tipo_galaxia){
this.galaxia_id = galaxia_id;
this.nombre = nombre;
this.tipo_galaxia = tipo_galaxia;
}
}
class Planeta{
//1. Escribir un metodo que permita agregar un nuevo planeta
constructor(planeta_id, galaxia_id, nombre, fotos){
this.planeta_id = planeta_id;
this.galaxia_id = galaxia_id;
this.nombre = nombre;
this.fotos = fotos;
}
//1. Escribir un metodo que permita agregar un nuevo planeta
agregar(planetas){
planeta = new Planeta(this.idPlaneta, this.idGalaxia, this.nombrePlaneta, this.fotosPlaneta);
planetas.push(planeta);
}
//3. Escribir un metodo que permita actualizar los datos de un planeta
actualizar(nuevoIdGalaxia, nuevoNombrePlaneta, nuevoFotosPlaneta){
this.galaxia_id = nuevoIdGalaxia;
this.nombre = nuevoNombrePlaneta;
this.fotos = nuevoFotosPlaneta;
}
//6. Escribir un metodo que devuelva la lista de lunas del planeta
getLunas(lunasParametro){
let lunass = [];
for(i=0; i<lunasParametro.length; i++){
if(lunasParametro[i].planeta_id==this.planeta_id){
lunass.push(lunasParametro[i]);
console.log(lunasParametro[i].nombre);
}
}
return lunass;
}
//4. Escribir un metodo para calcular la distancia de un planeta en relacion al Sol
distanciaAlSol(){
var str = this.nombre.toLowerCase();
if(str=="mercurio"){
return 5791000000;
}
else if(str=="venus"){
return 1082000000;
}
else if(str=="tierra"){
return 1496000000;
}
else if(str=="marte"){
return 2279000000;
}
else if(str=="jupiter"){
return 7785000000;
}
else if(str=="saturno"){
return 1434000000000;
}
else if(str=="urano"){
return 2871000000000;
}
else if(str=="neptuno"){
return 4495000000000;
}
}
//5. Escribir un metodo para calcular la distancia de un planeta en relacion a la tierra
distanciaATierra(planeta){
var str = this.nombre.toLowerCase();
if(str=="mercurio"){
return 77000000;
}
else if(str=="venus"){
return 40000000;
}
else if(str=="tierra"){
return 0;
}
else if(str=="marte"){
return 59000000;
}
else if(str=="jupiter"){
return 594000000;
}
else if(str=="saturno"){
return 15000000000;
}
else if(str=="urano"){
return 2720000000;
}
else if(str=="neptuno"){
return 43000000000;
}
}
//7. Escribir un metodo que devuelva las fotografias del planeta
getFotografias(){
return this.fotos;
}
//2. Escribir un metodo que permita borrar un planeta
borrar(listaPlanetas){
for(i=0; i<listaPlanetas.length; i++){
if(listaPlanetas[i].planeta_id == this.planeta_id){
console.log("Se eliminó " + planetas[i].nombre);
listaPlanetas.splice(i,1);
}
}
}
}
class Luna{
constructor(nombre, planeta_id, fotos){
this.nombre = nombre;
this.planeta_id = planeta_id;
this.fotos = fotos;
}
}
//Lista de Galaxias
let galaxias = [];
//Lista de Planetas
let planetas = [];
//Lista de Lunas
let lunas = [];
//1. Escribir un metodo que permita agregar un nuevo planeta
function agregarPlaneta(idPlaneta, idGalaxia, nombrePlaneta, fotosPlaneta){
planeta = new Planeta(idPlaneta, idGalaxia, nombrePlaneta, fotosPlaneta);
planetas.push(planeta);
}
//2. Escribir un metodo que permita borrar un planeta
function borrarPlaneta(idPlaneta){
for(i=0; i<planetas.length; i++){
if(planetas[i].planeta_id == idPlaneta){
console.log("Se eliminó " + planetas[i].nombre);
planetas.splice(i,1);
}
}
}
//3. Escribir un metodo que permita actualizar los datos de un planeta
function actualizarDatosPlaneta(idPlaneta, nuevoIdGalaxia, nuevoNombrePlaneta, nuevoFotosPlaneta){
for(i=0; i<planetas.length; i++){
if(planetas[i].planeta_id == idPlaneta){
console.log("Se actualiza " + planetas[i].nombre);
planetas[i].actualizar(nuevoIdGalaxia, nuevoNombrePlaneta, nuevoFotosPlaneta);
}
}
}
//6. Escribir un metodo que devuelva la lista de lunas del planeta
function lunasDe(idPlaneta){
let lunasDePlaneta = [];
for(i=0; i<lunas.length; i++){
if(lunas[i].planeta_id==idPlaneta){
lunasDePlaneta.push(lunas[i]);
console.log(lunas[i].nombre);
}
}
return lunasDePlaneta;
}
//7. Escribir un metodo que devuelva las fotografias del planeta
function fotografias(idPlaneta){
let fotogafiasDePlaneta = [];
for(i=0; i<lunas.length; i++){
if(planetas[i].planeta_id==idPlaneta){
fotografiasDePlaneta.push(planetas[i].fotos);
console.log(planetas[i].fotos);
}
}
return fotografiasDePlaneta;
}
//Devuelve una lista de los planetas correspondientes al id de
//la galaxia recibida
function planetasDe(idGalaxia){
let planetasDeGalaxia = [];
for(i=0; i<planetas.length; i++){
if(planetas[i].galaxia_id==idGalaxia){
planetasDeGalaxia.push(planetas[i]);
//console.log(planetas[i]);
}
}
return planetasDeGalaxia;
}
function crearDatos(){
//Se añaden las galaxias
let galaxia = new Galaxia(1, "Via Lactea", "Espiral");
galaxias.push(galaxia);
galaxia = new Galaxia(2, "Nube de Magallanes", "Eliptica");
galaxias.push(galaxia);
galaxia = new Galaxia(3, "Sculptor", "Esferoidal");
galaxias.push(galaxia);
agregarPlaneta(1, 1, "Tierra", ["https://www.caracteristicas.co/wp-content/uploads/2017/02/planeta-tierra-min-e1487870067631.jpg", "http://www.bodecor.com/image/cache/data/productos/JUEGOSEDUCATIVOS/6883636513p-500x500.jpg", "https://i2.wp.com/www.4vientos.net/wp-content/uploads/2018/03/TIERRA-PLANETA-AMANECER-1.jpg?resize=800%2C439"]);
agregarPlaneta(2, 1, "Saturno", ["https://upload.wikimedia.org/wikipedia/commons/thumb/c/c7/Saturn_during_Equinox.jpg/1200px-Saturn_during_Equinox.jpg","", "https://www.meteorologiaenred.com/wp-content/uploads/2018/08/Atm%C3%B3sfera-de-Saturno.jpg"]);
agregarPlaneta(3, 2, "Krypton", ["https://www.ecured.cu/images/thumb/c/cf/Krypton_%28planeta%29.jpg/260px-Krypton_%28planeta%29.jpg", "https://vignette.wikia.nocookie.net/starwars/images/d/d6/Toydaria-TCW.png/revision/latest?cb=20130506235119", "https://vignette.wikia.nocookie.net/supergirl/images/b/b5/Planet_Krypton.png/revision/latest?cb=20171206023736&path-prefix=es"]);
agregarPlaneta(4, 3, "Cybertron", ["https://upload.wikimedia.org/wikipedia/en/2/2d/MovieCybertron.jpg", "https://vignette.wikia.nocookie.net/michaelbaystransformers/images/c/cf/Movie_Cybertron.jpg/revision/latest?cb=20151108163309", "https://www.meme-arsenal.com/memes/c559b3b9e3d0a90b3c267b0a611a5f61.jpg"]);
let luna = new Luna("Luna", 1, ["https://upload.wikimedia.org/wikipedia/commons/thumb/d/dd/Full_Moon_Luc_Viatour.jpg/280px-Full_Moon_Luc_Viatour.jpg","https://upload.wikimedia.org/wikipedia/commons/thumb/d/d8/Ganymede_g1_true_2.jpg/270px-Ganymede_g1_true_2.jpg","https://images2.corriereobjects.it/methode_image/2017/01/11/Scienze/Foto%20Scienze%20-%20Trattate/AFP_JQ6DS-0002-kUPG-U43270811099596WNF-1224x916@Corriere-Web-Sezioni-593x443.jpg?v=20170111154027"]);
lunas.push(luna);
luna = new Luna("Titan", 2, ["https://www.muyinteresante.com.mx/wp-content/uploads/2018/05/httpstved-prod.adobecqms.netcontentdameditorialTelevisamexicomuyinteresantemxjuniorespacio170220titan.imgo_-770x528.jpg","https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTLEUZwBd52os9ND0Zwo7dxvl2IkePZMPCKsBjuGE2XRi28I_1J","https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTUv60cmCb7ABSLqdRrQdOT2p8X1jZAqGbQQwzt5rxB5ZUxUqYh"]);
lunas.push(luna);
luna = new Luna("Encelado", 2, ["https://upload.wikimedia.org/wikipedia/commons/thumb/5/5f/Enceladusstripes_cassini.jpg/250px-Enceladusstripes_cassini.jpg", "https://static.scientificamerican.com/arabic/cache/file/531AF767-D9AC-4D9E-B13D2A5C98DEC186_source.jpg", "https://cdn.img.inosmi.ru/images/23704/25/237042551.jpg"]);
lunas.push(luna);
}
crearDatos();
//Carga los botones de los planetas
function CargarBotones(){
let seccionBotones = document.getElementById("planetas");
let boton;
for(i=0; i<planetas.length; i++){
boton = document.createElement("button");
boton.id = "" + planetas[i].planeta_id;
boton.setAttribute("onclick", "mostrarDetalle("+planetas[i].planeta_id+")");
boton.innerHTML = planetas[i].nombre;
seccionBotones.appendChild(boton);
}
}
CargarBotones();
function mostrarDetalle(idPlaneta){
let listaLunas = document.getElementById("lunas");
let fotos = document.getElementById("fotos");
while(listaLunas.firstChild){
listaLunas.removeChild(listaLunas.firstChild);
}
while(fotos.firstChild){
fotos.removeChild(fotos.firstChild);
}
for(i=0; i<planetas.length; i++){
if(planetas[i].planeta_id==idPlaneta){
document.getElementById("nombre").innerHTML=planetas[i].nombre;
for(j=0; j<lunas.length; j++){
if(lunas[j].planeta_id==idPlaneta){
var luna = document.createElement("li");
luna.innerHTML = lunas[j].nombre;
listaLunas.appendChild(luna);
}
}
for(j=0; j<planetas.length; j++){
if(planetas[j].planeta_id==idPlaneta){
for(k=0; k<planetas[i].fotos.length; k++){
var foto = document.createElement("img");
foto.src=planetas[j].fotos[k];
foto.width = 250;
foto.width = 200;
fotos.appendChild(foto);
}
}
}
}
}
console.log("mostrado detalles de " + idPlaneta);
}
function buscar(){
var nombrePlaneta = document.getElementById("nombrePlanetaBuscador").value.toLowerCase();
let seccionBotones = document.getElementById("planetas");
let boton;
while(seccionBotones.firstChild){
seccionBotones.removeChild(seccionBotones.firstChild);
}
if(nombrePlaneta == ""){
CargarBotones();
return;
}
for(i=0; i<planetas.length; i++){
if(planetas[i].nombre.toLowerCase()== nombrePlaneta){
boton = document.createElement("button");
boton.id = "" + planetas[i].planeta_id;
boton.setAttribute("onclick", "mostrarDetalle("+planetas[i].planeta_id+")");
boton.innerHTML = planetas[i].nombre;
seccionBotones.appendChild(boton);
}
}
}
function cargarSelects(){
let galaxiaSelect = document.getElementById("selectGalaxia");
for(i=0; i<galaxias.length; i++){
let option = document.createElement("option");
option.value = galaxias[i].galaxia_id;
option.innerHTML = galaxias[i].nombre;
galaxiaSelect.appendChild(option);
}
}
cargarSelects();
function filtrarPlanetas(){
let galaxiaSelect = document.getElementById("selectGalaxia");
let idGalaxia = galaxiaSelect.options[galaxiaSelect.selectedIndex].value;
let seccionBotones = document.getElementById("planetas");
let boton;
while(seccionBotones.firstChild){
seccionBotones.removeChild(seccionBotones.firstChild);
}
for(i=0; i<planetas.length; i++){
if(planetas[i].galaxia_id==idGalaxia){
boton = document.createElement("button");
boton.id = "" + planetas[i].planeta_id;
boton.setAttribute("onclick", "mostrarDetalle("+planetas[i].planeta_id+")");
boton.innerHTML = planetas[i].nombre;
seccionBotones.appendChild(boton);
}
}
}
\ No newline at end of file
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<link rel="stylesheet" href="node_modules/bootstrap/dist/css/bootstrap.min.css">
<title>Planetas!</title>
</head>
<body class="container">
<h1>Planetas</h1>
<hr>
<div id="buscador" class="col-md-3">
buscador <input type="text" id="nombrePlanetaBuscador">
<br>
<button onclick="buscar()">Buscar</button>
</div>
<span class="col-md-1"></span>
<div id="filtro" class="col-md-3">
Filtro Galaxia <select id="selectGalaxia" onchange="filtrarPlanetas()"></select>
</div>
<hr>
<br>
<div id="planetas" class="row">
<h2>botones</h2>
</div>
<div id="informacion">
<h3 id="nombre"></h3>
<ul id="lunas">
</ul>
<div id="fotos">
</div>
</div>
<script src="js/planetas.js"></script>
</body>
</html>
\ No newline at end of file
class Galaxia{
constructor(galaxia_id, nombre, tipo_galaxia){
this.galaxia_id = galaxia_id;
this.nombre = nombre;
this.tipo_galaxia = tipo_galaxia;
}
}
let galaxias = [];
let galaxia = new Galaxia(1, "andromeda", "espiral");
galaxias.push(galaxia);
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment