Compare commits

..

No commits in common. "3e7968ab7fe8703dcb40522d6475b11c1d85b12a" and "0b84c0987e948bf41e766acfa8dc945f23fb27af" have entirely different histories.

8 changed files with 55 additions and 129 deletions

View File

@ -12,16 +12,13 @@ import { PerfilDiscotecaPage } from './perfil-discoteca/perfil-discoteca.page';
import { PromptEventoPage} from './prompt-evento/prompt-evento.page' import { PromptEventoPage} from './prompt-evento/prompt-evento.page'
import { GaleriamodalPageModule } from './galeriamodal/galeriamodal.module'; import { GaleriamodalPageModule } from './galeriamodal/galeriamodal.module';
import { MatMenuModule } from '@angular/material/menu'; import { MatMenuModule } from '@angular/material/menu';
import { MatCardModule } from '@angular/material/card';
import { LoginPage } from './login/login.page'; import { LoginPage } from './login/login.page';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; import { BrowserAnimationsModule } from '@angular/platform-browser/animations'
import { MatIconModule } from '@angular/material/icon';
@NgModule({ @NgModule({
declarations: [AppComponent, PerfilDiscotecaPage, PromptEventoPage, LoginPage], declarations: [AppComponent, PerfilDiscotecaPage, PromptEventoPage, LoginPage],
entryComponents: [], entryComponents: [],
imports: [BrowserModule, HttpClientModule, IonicModule.forRoot(), AppRoutingModule, ReactiveFormsModule, GaleriamodalPageModule, MatMenuModule, BrowserAnimationsModule, MatIconModule, MatCardModule], imports: [BrowserModule, HttpClientModule, IonicModule.forRoot(), AppRoutingModule, ReactiveFormsModule, GaleriamodalPageModule, MatMenuModule, BrowserAnimationsModule],
providers: [ providers: [
StatusBar, StatusBar,
SplashScreen, SplashScreen,

View File

@ -43,7 +43,7 @@ export class Discoteca {
this.descripcion = desc; this.descripcion = desc;
} }
getDescripcion(): string{ get Descripcion(): string{
return this.descripcion; return this.descripcion;
} }
} }

View File

@ -8,52 +8,11 @@
<ion-content [fullscreen]="true"> <ion-content [fullscreen]="true">
<div class='main'> <div class='fotoPerfil'>
<ion-grid> <ion-grid>
<ion-row> <ion-row>
<div class='fotoPerfil'>
<ion-img class="fotoPerfil" width="100%" height="100%" [src]='fotoSrc' alt='barraquinha'></ion-img> <ion-img class="fotoPerfil" width="100%" height="100%" [src]='fotoSrc' alt='barraquinha'></ion-img>
<div class="textoPie">{{nombre}}</div> <div class="textoPie">{{nombre}}</div>
</div>
</ion-row>
<ion-row>
<div class="menuBotones">
<button mat-icon-button [matMenuTriggerFor]="menu">
<ion-icon name="settings" class="settingsIcon"></ion-icon>
</button>
<mat-menu #menu="matMenu" xPositon="after" yPosition="above">
<button mat-menu-item>
<ion-icon name="image" slot="icon-only"></ion-icon>
<input type="file" (change)="loadImageFromDevice($event);cargarImagen()" id="file-input-perfil" accept="image/png, image/jpeg">
</button>
<button mat-menu-item (click)="enableEdit()" label="editar" [disabled]='editEnabled'>
<ion-icon name="create"></ion-icon>
</button>
<button mat-menu-item (click)="addEvento()">
<ion-icon name="add-circle-outline">
</ion-icon>
Añadir evento
</button>
</mat-menu>
</div>
</ion-row>
<ion-row>
<div id="botonesHidden1" class="botonesHidden">
<button (click)="saveEdit()" label="guardar" [disabled]='editDisabled' id="saveButton">
<ion-icon name="save"></ion-icon>
</button>
<button (click)="cancelEdit()" [disabled]='editDisabled' id="cancelButton">
Cancelar
</button>
</div>
</ion-row> </ion-row>
@ -66,17 +25,9 @@
<div [contentEditable]='editEnabled'>{{localizacion}}</div> <div [contentEditable]='editEnabled'>{{localizacion}}</div>
</div> </div>
</ion-col> </ion-col>
<ion-col> <ion-col>
<div> <div>{{descripcion}}</div>
<mat-card>
<mat-card-header>
Descripción
</mat-card-header>
<mat-card-content>
{{descripcion}}
</mat-card-content>
</mat-card>
</div>
</ion-col> </ion-col>
</ion-row> </ion-row>
@ -100,7 +51,6 @@
</ion-row> </ion-row>
<ion-row> <ion-row>
<ion-col size="12">
<div *ngIf="eventos.length>0" class="eventos"> <div *ngIf="eventos.length>0" class="eventos">
<ion-list> <ion-list>
<ion-item *ngFor="let evento of eventos" button (click)="mostrarEvento(evento)"> <ion-item *ngFor="let evento of eventos" button (click)="mostrarEvento(evento)">
@ -120,11 +70,39 @@
</ion-item> </ion-item>
</ion-list> </ion-list>
</div> </div>
</ion-col>
</ion-row> </ion-row>
<ion-row> <ion-row>
<button mat-icon-button [matMenuTriggerFor]="menu">
<ion-icon name="create"></ion-icon>
</button>
<mat-menu #menu="matMenu">
<button mat-menu-item [disabled]='editDisabled'>
<ion-icon name="image" slot="icon-only"></ion-icon>
<input type="file" (change)="loadImageFromDevice($event);cargarImagen()" id="file-input-perfil" accept="image/png, image/jpeg">
</button>
<button mat-menu-item (click)="enableEdit()" label="editar" [disabled]='editEnabled'>
<ion-icon name="create"></ion-icon>
</button>
<button mat-menu-item (click)="saveEdit()" label="guardar" [disabled]='editDisabled'>
<ion-icon name="save"></ion-icon>
</button>
<button mat-menu-item (click)="cancelEdit()" [disabled]='editDisabled'>
Cancelar
</button>
<button mat-menu-item (click)="addEvento()">
<ion-icon name="add-circle-outline">
</ion-icon>
Añadir evento
</button>
</mat-menu>
</ion-row> </ion-row>
</ion-grid> </ion-grid>
</div> </div>

View File

@ -6,20 +6,16 @@
} }
*{ *{
padding: 10px; padding: 5px;
display: block; display: block;
margin: auto;
} }
.main{
max-width: 800px;
max-height: auto;
margin: auto;
text-align: justify;
}
.fotoPerfil{ .fotoPerfil{
text-align: end; text-align: end;
max-width: 800px;
max-height: auto;
margin: auto;
} }
.textoPie{ .textoPie{
@ -39,8 +35,6 @@
float: left; float: left;
position: relative; position: relative;
margin: auto; margin: auto;
text-align: right;
padding-right: 50px;
} }
@ -49,14 +43,15 @@
} }
.galeria{ .galeria{
text-align: center;
padding: 30px; display: block;
max-width: 300px;
max-height: auto;
margin: auto; margin: auto;
} }
.botonesHidden{ .botonesHidden{
display: none; display: none;
padding: none;
} }
.botonesVisible{ .botonesVisible{
@ -64,21 +59,14 @@
} }
.eventos{ .eventos{
text-align: justify; display:block;
}
.evento{
max-width:fit-content;
} }
.evento:hover{ .evento:hover{
background-color: rgb(97, 97, 97); background-color: rgb(97, 97, 97);
} }
.eventoHeader{ .eventoHeader{
font-weight: bold; font-weight: bold;
float: left;
} }
.eventoDesc{ .eventoDesc{
@ -88,26 +76,3 @@
ion-slides { ion-slides {
height: 200px; height: 200px;
} }
mat-card-header{
text-align: right;
font-weight: bold;
}
button{
background-color: transparent;
}
.settingsIcon{
font-size: large;
background-color: white;
}
.menuBotones{
position: relative;
float: left;
bottom: 60px;
left: 20px;
}

View File

@ -5,6 +5,7 @@ import { AlertController } from '@ionic/angular';
import { ViewChild } from '@angular/core'; import { ViewChild } from '@angular/core';
import { Evento } from '../evento'; import { Evento } from '../evento';
import { Router } from '@angular/router'; import { Router } from '@angular/router';
import { MatMenuModule, MatMenuTrigger } from '@angular/material/menu';
import { THIS_EXPR } from '@angular/compiler/src/output/output_ast'; import { THIS_EXPR } from '@angular/compiler/src/output/output_ast';
import { GaleriamodalPage } from '../galeriamodal/galeriamodal.page'; import { GaleriamodalPage } from '../galeriamodal/galeriamodal.page';
import { stringify } from '@angular/compiler/src/util'; import { stringify } from '@angular/compiler/src/util';
@ -17,10 +18,10 @@ import { stringify } from '@angular/compiler/src/util';
export class PerfilDiscotecaPage implements OnInit { export class PerfilDiscotecaPage implements OnInit {
@ViewChild('IonSlides') slides: IonSlides; @ViewChild('IonSlides') slides: IonSlides;
@ViewChild('MatMenuTrigger') trigger: MatMenuTrigger;
nombre: string; nombre: string;
telefono: number; telefono: number;
localizacion: string; localizacion: string;
descripcion: string;
fotoSrc: string; fotoSrc: string;
fotoLoaded: string; fotoLoaded: string;
someURL: string; someURL: string;
@ -33,6 +34,7 @@ export class PerfilDiscotecaPage implements OnInit {
sliderOpts = { sliderOpts = {
slidesPerView: 1.5, slidesPerView: 1.5,
centeredSlides: true, centeredSlides: true,
spaceBetween: 20,
}; };
constructor(private tab1Service: Tab1Service, private router: Router, private modalController: ModalController) { constructor(private tab1Service: Tab1Service, private router: Router, private modalController: ModalController) {
@ -48,7 +50,6 @@ export class PerfilDiscotecaPage implements OnInit {
this.getTelefono(); this.getTelefono();
this.getLocalizacion(); this.getLocalizacion();
this.getEventos(); this.getEventos();
this.getDescripcion();
this.editDisabled="true"; this.editDisabled="true";
this.editEnabled="false"; this.editEnabled="false";
this.fotoSrc = '../assets/img/barraca.jpg'; this.fotoSrc = '../assets/img/barraca.jpg';
@ -74,10 +75,6 @@ export class PerfilDiscotecaPage implements OnInit {
this.eventos = this.tab1Service.getEventos(); this.eventos = this.tab1Service.getEventos();
} }
getDescripcion(): void{
this.descripcion = this.tab1Service.getDescripcion();
}
cargarImagen(){ cargarImagen(){
this.fotoSrc = this.someURL; this.fotoSrc = this.someURL;
} }
@ -122,14 +119,10 @@ export class PerfilDiscotecaPage implements OnInit {
let cajaDatos = document.getElementById("cajaDatos"); let cajaDatos = document.getElementById("cajaDatos");
cajaDatos.style.background="white"; cajaDatos.style.background="white";
cajaDatos.style.color="black"; cajaDatos.style.color="black";
cajaDatos.contentEditable = "true";
let botones = document.getElementById("botonesHidden1"); let botones = document.getElementById("botonesHidden1");
botones.style.display = "block"; botones.style.display = "block";
let saveButton = document.getElementById("saveButton") as HTMLButtonElement; botones = document.getElementById("botonesHidden2");
saveButton.disabled=false; botones.style.display = "block";
let cancelButton = document.getElementById("cancelButton") as HTMLButtonElement;
cancelButton.disabled=false;
@ -141,7 +134,6 @@ export class PerfilDiscotecaPage implements OnInit {
let cajaDatos = document.getElementById("cajaDatos"); let cajaDatos = document.getElementById("cajaDatos");
cajaDatos.style.background="inherit"; cajaDatos.style.background="inherit";
cajaDatos.style.color="inherit"; cajaDatos.style.color="inherit";
cajaDatos.contentEditable="false";
let botones = document.getElementById("botonesHidden1"); let botones = document.getElementById("botonesHidden1");
botones.style.display = "none"; botones.style.display = "none";
botones = document.getElementById("botonesHidden2"); botones = document.getElementById("botonesHidden2");

View File

@ -13,7 +13,7 @@
<input type="text" id="nombre" formControlName = "nombre"> <input type="text" id="nombre" formControlName = "nombre">
</label> </label>
<span <span
*ngIf="nombre?.errors?.required && (nombre.touched||submitted)"> *ngIf="nombre.errors.required && (nombre.touched||submitted)">
Tu evento necesita un nombre Tu evento necesita un nombre
</span> </span>
</ion-item> </ion-item>
@ -24,7 +24,7 @@
<ion-datetime displayFormat="DD/MM, HH:mm"placeholder="Elegir Fecha" formControlName="fecha"></ion-datetime> <ion-datetime displayFormat="DD/MM, HH:mm"placeholder="Elegir Fecha" formControlName="fecha"></ion-datetime>
</label> </label>
<span <span
*ngIf="fecha?.errors?.required && submitted"> *ngIf="fecha.errors.required && submitted">
Tu evento necesita una fecha Tu evento necesita una fecha
</span> </span>
</ion-item> </ion-item>
@ -36,7 +36,7 @@
<input type="number" formControlName = "precio1"><label>, </label><input type="number" formControlName = "precio2"> <input type="number" formControlName = "precio1"><label>, </label><input type="number" formControlName = "precio2">
</label> </label>
<span <span
*ngIf="precio1?.errors?.required && (precio1.touched||submitted)"> *ngIf="precio1.errors.required && (precio1.touched||submitted)">
Tu evento necesita un precio (puede ser 0) Tu evento necesita un precio (puede ser 0)
</span> </span>
</ion-item> </ion-item>
@ -47,7 +47,7 @@
<textarea formControlName = "descripcion" rows="10"></textarea> <textarea formControlName = "descripcion" rows="10"></textarea>
</label> </label>
<span <span
*ngIf="descripcion?.errors?.required && (descripcion.touched||submitted)"> *ngIf="descripcion.errors.required && (descripcion.touched||submitted)">
¡Dale una descripción a tu evento! ¡Dale una descripción a tu evento!
</span> </span>
</ion-item> </ion-item>

View File

@ -12,7 +12,6 @@ import { Router } from '@angular/router';
export class PromptEventoPage implements OnInit{ export class PromptEventoPage implements OnInit{
submitted = false; submitted = false;
editarEvento = false;
eventoForm = new FormGroup({ eventoForm = new FormGroup({
nombre: new FormControl('', Validators.required), nombre: new FormControl('', Validators.required),
fecha: new FormControl('', Validators.required), fecha: new FormControl('', Validators.required),

View File

@ -32,7 +32,6 @@ export class Tab1Service implements OnInit{
this.discoteca.setNombre('Barraca'); this.discoteca.setNombre('Barraca');
this.discoteca.setTelefono(666666666); this.discoteca.setTelefono(666666666);
this.discoteca.setLocalizacion('Calle del Barquillo'); this.discoteca.setLocalizacion('Calle del Barquillo');
this.discoteca.setDescripcion('Barraca es una discoteca inaugurada en 1965 que tuvo su gran auge en los años 80, cuando se consolidó como la discoteca de mayor importancia de la movida valenciana, durante la conocida Ruta Destroy.');
this.galeria = []; this.galeria = [];
this.initEventos(); this.initEventos();
this.editarEvento = false; this.editarEvento = false;
@ -53,10 +52,6 @@ export class Tab1Service implements OnInit{
return this.discoteca.getLocalizacion(); return this.discoteca.getLocalizacion();
} }
getDescripcion(): string{
return this.discoteca.getDescripcion();
}
getEventos(): Evento[]{ getEventos(): Evento[]{
return this.eventos; return this.eventos;
} }