Commit 4c042246 authored by Cédric Moreau's avatar Cédric Moreau

[enh] Consultation d'un vendeur

parent b80f341d
......@@ -14,7 +14,7 @@ import {AnnounceService} from "../services/announce-service";
import {HomePage} from "../pages/home/home";
import {ProfilPage} from "../pages/profil/profil";
import {AccountPage} from "../pages/account/account";
import {AccountEditPage} from "../pages/account_edit/account_edit";
import {MyAnnouncesPage} from "../pages/my_announces/my_announces";
import {ItemDetailsPage} from "../pages/item-details/item-details";
import {ListPage} from "../pages/list/list";
......@@ -25,6 +25,7 @@ import {ImageModalPage} from "../pages/image-service/modal-page";
import {AnnouncePage} from "../pages/announce/announce";
import {AuthService} from "../services/auth-service";
import {AuthModal} from "../components/auth_modal/auth_modal";
import {AccountPage} from "../pages/account/account";
const appRoutes: Routes = [
{
......@@ -39,12 +40,12 @@ const appRoutes: Routes = [
},
{
path: 'mon_compte/creer',
component: AccountPage,
component: AccountEditPage,
data: { creation: true }
},
{
path: 'mon_compte/edit/:pub',
component: AccountPage
component: AccountEditPage
},
{
path: 'mes_annonces',
......@@ -63,6 +64,10 @@ const appRoutes: Routes = [
{
path: 'announce/:uuid',
component: AnnouncePage
},
{
path: 'account/:pub',
component: AccountPage
}
];
......@@ -71,10 +76,11 @@ const appRoutes: Routes = [
MyApp,
HomePage,
ProfilPage,
AccountPage,
AccountEditPage,
MyAnnouncesPage,
AnnounceEditPage,
AnnouncePage,
AccountPage,
ImageModalPage,
AuthModal,
ImageCropperComponent,
......@@ -94,7 +100,7 @@ const appRoutes: Routes = [
MyApp,
HomePage,
ProfilPage,
AccountPage,
AccountEditPage,
MyAnnouncesPage,
AnnounceEditPage,
ImageModalPage,
......
<ion-content padding>
<ion-row>
<ion-col col-12 col-sm-12 col-lg-8>
<h2 *ngIf="!accountService.acc.uuid">Création du compte ğchange</h2>
<h2 *ngIf="accountService.acc.uuid">Modification du compte ğchange</h2>
<form #accountForm="ngForm" >
<ion-list inset>
<ion-item>
<ion-label>UUID</ion-label>
<ion-input type="text" value="{{ accountService.acc.uuid }}" disabled></ion-input>
</ion-item>
<ion-item>
<ion-label>Pubkey</ion-label>
<ion-input type="text" value="{{ accountService.acc.pub }}" disabled></ion-input>
</ion-item>
<ion-item >
<ion-label>Nom public</ion-label>
<ion-input type="text"
required
minlength="10"
maxlength="100"
[(ngModel)]="accountService.acc.title"
name="title"
placeholder="Nom sur ğchange."
#title="ngModel"
></ion-input>
</ion-item>
<ion-label class="error" [hidden]="title.valid || (title.pristine && title.untouched)">
<span [hidden]="!title.errors || !title.errors.required">Ce champ est requis.</span>
<span [hidden]="!title.errors || !title.errors.minlength">Au moins 10 caractères.</span>
<span [hidden]="!title.errors || !title.errors.maxlength">Au plus 100 caractères.</span>
</ion-label>
<ion-item>
<ion-label>Description</ion-label>
<ion-textarea required
minlength="10"
maxlength="10000"
[(ngModel)]="accountService.acc.desc"
name="desc"
#desc="ngModel"
placeholder="Tapez votre texte ici."></ion-textarea>
</ion-item>
<ion-label class="error" [hidden]="desc.valid || (desc.pristine && desc.untouched)">
<span [hidden]="!desc.errors || !desc.errors.required">Ce champ est requis.</span>
<span [hidden]="!desc.errors || !desc.errors.minlength">Au moins 10 caractères.</span>
<span [hidden]="!desc.errors || !desc.errors.maxlength">Au plus 100 caractères.</span>
</ion-label>
<ion-item>
<ion-label>Adresse</ion-label>
<ion-input type="text"
required
minlength="4"
maxlength="100"
[(ngModel)]="accountService.acc.address"
name="address"
#address="ngModel"
placeholder="Exemple : « 10 rue de la Monnaie Libre, ... »"
></ion-input>
</ion-item>
<ion-label class="error" [hidden]="address.valid || (address.pristine && address.untouched)">
<span [hidden]="!address.errors || !address.errors.required">Ce champ est requis.</span>
<span [hidden]="!address.errors || !address.errors.minlength">Au moins 4 caractères.</span>
<span [hidden]="!address.errors || !address.errors.maxlength">Au plus 100 caractères.</span>
</ion-label>
<ion-item>
<ion-label>Liens</ion-label>
<ion-input type="text"
minlength="10"
maxlength="100"
[(ngModel)]="accountService.link"
name="link"
#link="ngModel"
placeholder="http://..." ></ion-input>
<button ion-button type="none" item-right (click)="accountService.ajouterLien(accountService.link)" [disabled]="!link.valid || !accountService.link">Ajouter</button>
</ion-item>
<ion-label class="error" [hidden]="link.valid || (link.pristine && link.untouched)">
<span [hidden]="!link.errors || !link.errors.minlength">Au moins 10 caractères.</span>
<span [hidden]="!link.errors || !link.errors.maxlength">Au plus 100 caractères.</span>
</ion-label>
<ion-item *ngFor="let lien of accountService.acc.links">
<ion-label>{{ lien }}</ion-label>
<button ion-button item-right color="danger" (click)="accountService.retirerLien(lien)">Retirer</button>
</ion-item>
<!--<h2>Document final généré, à signer</h2>-->
<!--<pre>{{ accountService.raw }}</pre>-->
</ion-list>
<button type="submit" ion-button [disabled]="!accountForm.form.valid" (click)="accountService.createOrModifyAccount(accountForm)" >Valider les modifications</button>
</form>
<ion-col col-12 col-sm-12 col-lg-6>
<h2>{{ accountService.acc.title }}</h2>
<pre>{{ accountService.acc.desc }}</pre>
<h3>Annonces</h3>
<ion-list id="home-list">
<button ion-item *ngFor="let a of announces" routerLink="/announce/{{ a.uuid }}">
<ion-avatar item-left>
<img *ngIf="a.thumbnail" src="{{ a.thumbnail }}">
<div class="nophoto" *ngIf="!a.thumbnail">
<ion-icon name="photos"></ion-icon>
</div>
</ion-avatar>
<h2>{{ a.title }}</h2>
<p>{{ a.desc }}</p>
<h3 clear item-right>{{ a.price }} Ğ1</h3>
</button>
</ion-list>
</ion-col>
</ion-row>
......
account {
announce {
textarea {
height: 200px;
border-left: 1px dashed #ddd !important;
padding-left: 15px !important;
}
.error {
background-color: #ffe0e0;
margin: 0px;
padding: 13px 8px 13px 12px;
}
.input-has-focus + .error {
background-color: #d9e4ff;
margin: 0px;
padding: 13px 8px 13px 12px;
img {
padding-right: 30px;
}
}
import {Component, OnInit} from "@angular/core";
import {AccountService} from "../../services/account-service";
import {ActivatedRoute} from "@angular/router";
import {LoginService} from "../../services/login-service";
import {ActivatedRoute} from "@angular/router";
import {AnnounceService} from "../../services/announce-service";
@Component({
selector: 'account',
selector: 'announce',
template: require('../../app/topbar.html') + require('./account.html')
})
export class AccountPage implements OnInit {
title:string = "Créer ou modifier mon compte"
title:string = "Consulter un vendeur"
announces:any
constructor(
private route: ActivatedRoute,
public loginService:LoginService,
public accountService:AccountService) {
public accountService:AccountService,
public announceService:AnnounceService) {
if (this.route.snapshot.data.creation) {
accountService.beginCreation(loginService.pub)
this.accountService.beginCreation(loginService.pub)
}
}
......@@ -26,6 +29,17 @@ export class AccountPage implements OnInit {
if (params['pub']) {
return this.accountService.getAccountInfos(params['pub'])
.then(res => this.accountService.acc = res.acc)
.then(() => {
return this.announceService.myAnnounces(this.accountService.acc.pub)
})
.then(res => {
this.announces = []
for (const a of res.announces) {
if (parseInt(a.stock)) {
this.announces.push(a)
}
}
})
}
});
}
......
<ion-content padding>
<ion-row>
<ion-col col-12 col-sm-12 col-lg-8>
<h2 *ngIf="!accountService.acc.uuid">Création du compte ğchange</h2>
<h2 *ngIf="accountService.acc.uuid">Modification du compte ğchange</h2>
<form #accountForm="ngForm" >
<ion-list inset>
<ion-item>
<ion-label>UUID</ion-label>
<ion-input type="text" value="{{ accountService.acc.uuid }}" disabled></ion-input>
</ion-item>
<ion-item>
<ion-label>Pubkey</ion-label>
<ion-input type="text" value="{{ accountService.acc.pub }}" disabled></ion-input>
</ion-item>
<ion-item >
<ion-label>Nom public</ion-label>
<ion-input type="text"
required
minlength="10"
maxlength="100"
[(ngModel)]="accountService.acc.title"
name="title"
placeholder="Nom sur ğchange."
#title="ngModel"
></ion-input>
</ion-item>
<ion-label class="error" [hidden]="title.valid || (title.pristine && title.untouched)">
<span [hidden]="!title.errors || !title.errors.required">Ce champ est requis.</span>
<span [hidden]="!title.errors || !title.errors.minlength">Au moins 10 caractères.</span>
<span [hidden]="!title.errors || !title.errors.maxlength">Au plus 100 caractères.</span>
</ion-label>
<ion-item>
<ion-label>Description</ion-label>
<ion-textarea required
minlength="10"
maxlength="10000"
[(ngModel)]="accountService.acc.desc"
name="desc"
#desc="ngModel"
placeholder="Tapez votre texte ici."></ion-textarea>
</ion-item>
<ion-label class="error" [hidden]="desc.valid || (desc.pristine && desc.untouched)">
<span [hidden]="!desc.errors || !desc.errors.required">Ce champ est requis.</span>
<span [hidden]="!desc.errors || !desc.errors.minlength">Au moins 10 caractères.</span>
<span [hidden]="!desc.errors || !desc.errors.maxlength">Au plus 100 caractères.</span>
</ion-label>
<ion-item>
<ion-label>Adresse</ion-label>
<ion-input type="text"
required
minlength="4"
maxlength="100"
[(ngModel)]="accountService.acc.address"
name="address"
#address="ngModel"
placeholder="Exemple : « 10 rue de la Monnaie Libre, ... »"
></ion-input>
</ion-item>
<ion-label class="error" [hidden]="address.valid || (address.pristine && address.untouched)">
<span [hidden]="!address.errors || !address.errors.required">Ce champ est requis.</span>
<span [hidden]="!address.errors || !address.errors.minlength">Au moins 4 caractères.</span>
<span [hidden]="!address.errors || !address.errors.maxlength">Au plus 100 caractères.</span>
</ion-label>
<ion-item>
<ion-label>Liens</ion-label>
<ion-input type="text"
minlength="10"
maxlength="100"
[(ngModel)]="accountService.link"
name="link"
#link="ngModel"
placeholder="http://..." ></ion-input>
<button ion-button type="none" item-right (click)="accountService.ajouterLien(accountService.link)" [disabled]="!link.valid || !accountService.link">Ajouter</button>
</ion-item>
<ion-label class="error" [hidden]="link.valid || (link.pristine && link.untouched)">
<span [hidden]="!link.errors || !link.errors.minlength">Au moins 10 caractères.</span>
<span [hidden]="!link.errors || !link.errors.maxlength">Au plus 100 caractères.</span>
</ion-label>
<ion-item *ngFor="let lien of accountService.acc.links">
<ion-label>{{ lien }}</ion-label>
<button ion-button item-right color="danger" (click)="accountService.retirerLien(lien)">Retirer</button>
</ion-item>
<!--<h2>Document final généré, à signer</h2>-->
<!--<pre>{{ accountService.raw }}</pre>-->
</ion-list>
<button type="submit" ion-button [disabled]="!accountForm.form.valid" (click)="accountService.createOrModifyAccount(accountForm)" >Valider les modifications</button>
</form>
</ion-col>
</ion-row>
</ion-content>
account_edit {
textarea {
height: 200px;
border-left: 1px dashed #ddd !important;
padding-left: 15px !important;
}
.error {
background-color: #ffe0e0;
margin: 0px;
padding: 13px 8px 13px 12px;
}
.input-has-focus + .error {
background-color: #d9e4ff;
margin: 0px;
padding: 13px 8px 13px 12px;
}
}
import {Component, OnInit} from "@angular/core";
import {AccountService} from "../../services/account-service";
import {ActivatedRoute} from "@angular/router";
import {LoginService} from "../../services/login-service";
@Component({
selector: 'account_edit',
template: require('../../app/topbar.html') + require('./account_edit.html')
})
export class AccountEditPage implements OnInit {
title:string = "Créer ou modifier mon compte"
constructor(
private route: ActivatedRoute,
public loginService:LoginService,
public accountService:AccountService) {
if (this.route.snapshot.data.creation) {
accountService.beginCreation(loginService.pub)
}
}
ngOnInit() {
this.route.params.subscribe(params => {
if (params['pub']) {
return this.accountService.getAccountInfos(params['pub'])
.then(res => this.accountService.acc = res.acc)
}
});
}
}
......@@ -14,9 +14,14 @@
{{ announceService.ann.stock }} unités disponibles.
</p>
<ng-container *ngIf="announceService.ann.pub == loginService.pub">
<button ion-button [routerLink]="['/announce/edit', announceService.ann.uuid]">Modifier votre annonce</button>
<ng-container *ngIf="announceService.ann.account">
<h3>Vendeur</h3>
<a class="author" [routerLink]="['/account/', announceService.ann.account.pub]">{{ announceService.ann.account.title }}</a>
</ng-container>
<p *ngIf="announceService.ann.pub == loginService.pub">
<button ion-button [routerLink]="['/announce/edit', announceService.ann.uuid]">Modifier votre annonce</button>
</p>
</ion-col>
</ion-row>
......
......@@ -10,7 +10,7 @@
<ion-icon name="photos"></ion-icon>
</div>
</ion-avatar>
<h2>{{ a.title }}</h2>
<h2>{{ a.title }}<span class="author">{{ a.account.title }}</span></h2>
<p>{{ a.desc }}</p>
<h3 clear item-right>{{ a.price }} Ğ1</h3>
</button>
......
......@@ -8,4 +8,9 @@ home {
ion-thumbnail img {
border-radius: 0 !important;
}
.author {
font-size: 13px;
color: #588fee;
}
}
......@@ -11,14 +11,7 @@ export class HomePage {
announces:Array<any>
constructor(private announceService:AnnounceService) {
this.announces = [{
title: "Ajout d'un tutoriel ğchange",
thumbnail: "",
desc: "ğchange est un nouvel outil développé pour faciliter le contact entre acheteurs et vendeurs dans la monnaie Ğ1.",
type: "Crowdfunding",
uuid: "a9fg8ef4-4897",
price: "112,00"
}]
this.announces = []
this.announceService.listAllAnnounces().then(announces => this.announces = announces.map(a => {
a.thumbnail = a.images[0]
return a
......
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