list mypolls on first page

This commit is contained in:
Baptiste Lemoine 2020-01-20 14:36:26 +01:00
parent 255205696b
commit 9ebd22536b
14 changed files with 136 additions and 84 deletions

View File

@ -2,48 +2,14 @@
* une option de date dans les sondages spéciaux * une option de date dans les sondages spéciaux
*/ */
import {environment} from "../../environments/environment"; import {environment} from "../../environments/environment";
import {mockMyPolls} from "./mocks/mockmypolls";
import {defaultAnswers, defaultDates, timeOfDay} from "./defaultConfigs";
export interface DateOption { export interface DateOption {
timeList: any; timeList: any;
literal: string; literal: string;
} }
export const timeOfDay = [{
timeList: [],
literal: 'matin'
},
{timeList: [], literal: 'midi'},
{timeList: [], literal: 'après-midi'},
{timeList: [], literal: 'soirée'}];
export const defaultDates = [
{
literal: `${new Date().getFullYear()}-${new Date().getMonth()}-${new Date().getDate()}`,
timeList: [{literal: 'matin'}, {literal: 'midi'}, {literal: 'soir'}]
},
{
literal: `${new Date().getFullYear()}-${new Date().getMonth()}-${new Date().getDate() + 1}`,
timeList: [{literal: 'matin'}, {literal: 'midi'}, {literal: 'soir'}]
},
{
literal: `${new Date().getFullYear()}-${new Date().getMonth()}-${new Date().getDate() + 2}`,
timeList: [{literal: 'matin'}, {literal: 'midi'}, {literal: 'soir'}]
}
];
export const defaultAnswers = [{
id: 0,
text: 'réponse de démo 1',
url: 'https://mastodon.cipherbliss.com/system/media_attachments/files/001/439/118/original/6fcf149bd902841b.png?1579471574',
},
{
id: 1,
text: 'réponse 2',
url: 'https://mastodon.cipherbliss.com/system/media_attachments/files/001/439/118/original/6fcf149bd902841b.png?1579471574',
},
{
id: 2,
text: 'la réponse D',
url: 'https://mastodon.cipherbliss.com/system/media_attachments/files/001/439/118/original/6fcf149bd902841b.png?1579471574',
}];
/** /**
* configuration of the poll, add new fields at will * configuration of the poll, add new fields at will
@ -51,15 +17,16 @@ export const defaultAnswers = [{
export class PollConfig { export class PollConfig {
expiracyDateDefaultInDays = 60; expiracyDateDefaultInDays = 60;
deletionDateAfterLastModification = 180; deletionDateAfterLastModification = 180;
step = 0; step: number = 0; // step in the progress of creating a poll
stepMax = 3; stepMax: number = 3; // step max in the progress of creating a poll
pollType = 'classic';// classic or date pollType: string = 'classic';// classic or date
title = 'titre'; title: string = 'titre';
description = 'ma description'; description: string = 'ma description';
myName = 'mon pseudo'; myName: string = 'mon pseudo';
myComment = 'wouah trop bien framadate!'; myComment: string = 'wouah trop bien framadate!';
isAdmin: boolean = false; isAdmin: boolean = false;
myEmail: string = ""; myEmail: string = "tktest@tktest.com";
myPolls: any = mockMyPolls;// list of retrieved polls from the backend api
// date specific poll, we have the choice to setup different hours (timeList) for all possible dates (dateList), or use the same hours for all dates // date specific poll, we have the choice to setup different hours (timeList) for all possible dates (dateList), or use the same hours for all dates
allowSeveralHours = 'false'; allowSeveralHours = 'false';
// access // access

View File

@ -0,0 +1,36 @@
export const timeOfDay = [{
timeList: [],
literal: 'matin'
},
{timeList: [], literal: 'midi'},
{timeList: [], literal: 'après-midi'},
{timeList: [], literal: 'soirée'}];
export const defaultDates = [
{
literal: `${new Date().getFullYear()}-${new Date().getMonth()}-${new Date().getDate()}`,
timeList: [{literal: 'matin'}, {literal: 'midi'}, {literal: 'soir'}]
},
{
literal: `${new Date().getFullYear()}-${new Date().getMonth()}-${new Date().getDate() + 1}`,
timeList: [{literal: 'matin'}, {literal: 'midi'}, {literal: 'soir'}]
},
{
literal: `${new Date().getFullYear()}-${new Date().getMonth()}-${new Date().getDate() + 2}`,
timeList: [{literal: 'matin'}, {literal: 'midi'}, {literal: 'soir'}]
}
];
export const defaultAnswers = [{
id: 0,
text: 'réponse de démo 1',
url: 'https://mastodon.cipherbliss.com/system/media_attachments/files/001/439/118/original/6fcf149bd902841b.png?1579471574',
},
{
id: 1,
text: 'réponse 2',
url: 'https://mastodon.cipherbliss.com/system/media_attachments/files/001/439/118/original/6fcf149bd902841b.png?1579471574',
},
{
id: 2,
text: 'la réponse D',
url: 'https://mastodon.cipherbliss.com/system/media_attachments/files/001/439/118/original/6fcf149bd902841b.png?1579471574',
}];

View File

@ -0,0 +1,23 @@
export const mockMyPolls =
[{
"id": 1,
"title": "blehehehe heh hehhe e",
"customUrl": null,
"description": "maaaaaaaaaaah",
"creationDate": {"date": "2020-01-20 14:21:16.270157", "timezone_type": 3, "timezone": "Europe/Paris"},
"expiracyDate": {"date": "2020-01-20 14:21:16.270178", "timezone_type": 3, "timezone": "Europe/Paris"},
"owner": null,
"kind": "text",
"allowedAnswers": ["yes"],
"modificationPolicy": "nobody",
"mailOnComment": null,
"mailOnVote": null,
"hideResults": null,
"showResultEvenIfPasswords": null,
"votes": {},
"stacksOfVotes": {},
"choices": {},
"comments": {},
"defaultExpiracyDaysFromNow": 60
}]
;

View File

@ -82,7 +82,7 @@
<br > <br >
<button <button
[routerLink]="'/step/resume'" [routerLink]="'/step/resume'"
class="btn btn--primary" class="btn btn--full btn--primary"
i18n i18n
> >
Voyons ce que ça donne Voyons ce que ça donne

View File

@ -1,24 +1,28 @@
<div class="container"> <div class="container" >
<section class="creation"> <section class="creation" >
<h1> <h1 >
{{"creation.title"|translate}} {{"creation.title"|translate}}
</h1> </h1 >
<p class="description margin-btm-x5" i18n> <p
class="description margin-btm-x5"
i18n >
{{"config.description"|translate}} {{"config.description"|translate}}
</p> </p >
<div class="btn-next"> <div class="btn-next" >
<button [routerLink]="'step/date'" class="btn btn--full btn--primary"> <button
[routerLink]="'step/date'"
class="btn btn--full btn--primary" >
{{"config.letsgo"|translate}} {{"config.letsgo"|translate}}
</button> </button >
</div> </div >
</section> </section >
<section class="recuperation"> <section class="recuperation" >
<h1 class="margin-top-x8"> <h1 class="margin-top-x8" >
{{"config.find_my_polls"|translate}} {{"config.find_my_polls"|translate}}
</h1> </h1 >
<form <form
(ngSubmit)="findMyPollsByEmail(config.myEmail)" (ngSubmit)="findMyPollsByEmail(config.myEmail)"
> >
@ -27,10 +31,12 @@
for="email" for="email"
i18n i18n
> >
<i class='fa fa-envelope' ></i >
{{"config.find_helper"|translate}} : {{"config.find_helper"|translate}} :
</label> </label >
<input <input
[(ngModel)]="config.myEmail" [(ngModel)]="config.myEmail"
class='input'
autofocus="autofocus" autofocus="autofocus"
id="email" id="email"
name="mail" name="mail"
@ -38,26 +44,43 @@
type="email" type="email"
/> />
<input <input
[disabled]="!config.myEmail" [disabled]="!config.myEmail || !config.myEmail.length"
[ngClass]="{'btn-primary': config.myEmail}" [ngClass]="{'btn--primary': config.myEmail}"
class="btn btn-block" class="btn btn--full"
i18n-value="'config.find_button'|translate" i18n-value="'config.find_button'|translate"
type="submit" type="submit"
/> />
</form> </form >
</section> </section >
<section class="list-my-polls" *ngIf="!config.loading"> <section
<ul class="poll-list" *ngFor="let poll of config.myPolls"> class="list-my-polls"
<li> poll</li> *ngIf="!config.loading" >
</ul> <h2 >
Mes Sondages trouvés:
</h2 >
<ul
class="poll-list"
*ngFor="let poll of config.myPolls ; index as i;trackBy trackFunction" >
<li >
<a href='{{poll.url}}' >
{{poll.title}}
<sub >
{{poll.description}}
</sub >
</a >
</li >
</ul >
<div class="no-polls" *ngIf="! config.myPolls || !config.myPolls.length"> <div
class="no-polls"
*ngIf="! config.myPolls || !config.myPolls.length" >
Aucun sondage. Aucun sondage.
</div> </div >
</section> </section >
<div class="loading" *ngIf="config.loading"> <div
<i class="fa fa-refresh fa-spin fa-3x fa-fw"></i> class="loading"
</div> *ngIf="config.loading" >
<i class="fa fa-refresh fa-spin fa-3x fa-fw" ></i >
</div >
</div >
</div>

View File

@ -11,6 +11,7 @@ export class CreateOrRetrieveComponent extends BaseComponent implements OnInit {
loadedMyPolls: boolean = false; loadedMyPolls: boolean = false;
constructor(public config: ConfigService) { constructor(public config: ConfigService) {
super(config); super(config);
} }
@ -30,4 +31,7 @@ export class CreateOrRetrieveComponent extends BaseComponent implements OnInit {
this.loadedMyPolls = true; this.loadedMyPolls = true;
} }
trackFunction(index: number, item: any): number {
return item.id;
};
} }

View File

@ -1,8 +1,8 @@
import {Component, OnInit} from '@angular/core'; import {Component, OnInit} from '@angular/core';
import {BaseComponent} from "../base-page/base.component"; import {BaseComponent} from "../base-page/base.component";
import {ConfigService} from "../../services/config.service"; import {ConfigService} from "../../services/config.service";
import {mockPoll3} from "../../config/mock-poll3"; import {mockPoll3} from "../../config/mocks/mock-poll3";
import {mockComments} from "../../config/mock-comments"; import {mockComments} from "../../config/mocks/mock-comments";
@Component({ @Component({
selector: 'framadate-poll-display', selector: 'framadate-poll-display',

View File

@ -1,5 +1,5 @@
import {Component, Input, OnInit} from '@angular/core'; import {Component, Input, OnInit} from '@angular/core';
import {mockComments} from "../../../config/mock-comments"; import {mockComments} from "../../../config/mocks/mock-comments";
@Component({ @Component({
selector: 'framadate-voting-comment', selector: 'framadate-voting-comment',

View File

@ -1,6 +1,6 @@
import {Component, Input, OnInit} from '@angular/core'; import {Component, Input, OnInit} from '@angular/core';
import {ConfigService} from "../../../services/config.service"; import {ConfigService} from "../../../services/config.service";
import {mockPoll3} from "../../../config/mock-poll3"; import {mockPoll3} from "../../../config/mocks/mock-poll3";
@Component({ @Component({
selector: 'framadate-voting-summary', selector: 'framadate-voting-summary',

View File

@ -1,10 +1,10 @@
import {Component, Inject, OnInit} from "@angular/core"; import {Component, Inject, OnInit} from "@angular/core";
import {Chart} from "chart.js"; import {Chart} from "chart.js";
import {DOCUMENT} from '@angular/common'; import {DOCUMENT} from '@angular/common';
import {mockGraphConfig} from "../config/mock-graph"; import {mockGraphConfig} from "../config/mocks/mock-graph";
import {graphOptions} from "../config/graph-canevas-options"; import {graphOptions} from "../config/graph-canevas-options";
import {ConfigService} from "../services/config.service"; import {ConfigService} from "../services/config.service";
import {mockPoll3} from "../config/mock-poll3"; import {mockPoll3} from "../config/mocks/mock-poll3";
@Component({ @Component({
selector: "framadate-poll-graphic", selector: "framadate-poll-graphic",

View File

@ -15,7 +15,6 @@ export class ConfigService extends PollConfig {
loading: boolean = false; loading: boolean = false;
baseHref: any = environment.baseApiHref; baseHref: any = environment.baseApiHref;
myPolls: any;// list of retrieved polls from the backend api
constructor(private http: HttpClient, constructor(private http: HttpClient,