mirror of
https://framagit.org/framasoft/framadate/funky-framadate-front.git
synced 2023-08-25 13:53:14 +02:00
sync fetch stuff
This commit is contained in:
parent
9900e1ec97
commit
02995c8b3d
@ -5,7 +5,7 @@ import {RouterModule, Routes} from '@angular/router';
|
||||
const routes: Routes = [];
|
||||
|
||||
@NgModule({
|
||||
imports: [RouterModule.forRoot(routes, {useHash: true})],
|
||||
imports: [RouterModule.forRoot(routes, {useHash: true, anchorScrolling: 'enabled',})],
|
||||
exports: [RouterModule]
|
||||
})
|
||||
export class AppRoutingModule {
|
||||
|
@ -33,6 +33,7 @@ export class AppComponent {
|
||||
this.route.events.subscribe((event: any) => {
|
||||
this.scrollGoToTop();
|
||||
|
||||
console.log('event', event)
|
||||
if (event.url) {
|
||||
|
||||
const tab = event.url.split('/');
|
||||
|
@ -32,7 +32,7 @@ export class PollConfig {
|
||||
myComment: string = 'wouah trop bien framadate!';
|
||||
isAdmin: boolean = true;
|
||||
myEmail: string = "tktest@tktest.com";
|
||||
myPolls: any;// list of retrieved polls from the backend api
|
||||
myPolls: any = [];// 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
|
||||
allowSeveralHours = 'false';
|
||||
// access
|
||||
|
109
src/app/config/mocks/mock1.ts
Normal file
109
src/app/config/mocks/mock1.ts
Normal file
@ -0,0 +1,109 @@
|
||||
export const mockPoll1 = {
|
||||
"message": "your poll config",
|
||||
"data": {
|
||||
"id": 1,
|
||||
"title": "citron ou orange",
|
||||
"customUrl": null,
|
||||
"description": "votre sorbert préféré",
|
||||
"creationDate": {
|
||||
"date": "2020-01-22 14:28:19.000000",
|
||||
"timezone_type": 3,
|
||||
"timezone": "Europe/Paris"
|
||||
},
|
||||
"expiracyDate": {
|
||||
"date": "2020-01-22 14:28:19.000000",
|
||||
"timezone_type": 3,
|
||||
"timezone": "Europe/Paris"
|
||||
},
|
||||
"owner": {
|
||||
"__initializer__": {},
|
||||
"__cloner__": {},
|
||||
"__isInitialized__": false
|
||||
},
|
||||
"kind": "text",
|
||||
"allowedAnswers": [
|
||||
"yes"
|
||||
],
|
||||
"modificationPolicy": "nobody",
|
||||
"mailOnComment": null,
|
||||
"mailOnVote": true,
|
||||
"hideResults": null,
|
||||
"showResultEvenIfPasswords": null,
|
||||
"votes": {},
|
||||
"stacksOfVotes": {},
|
||||
"choices": {},
|
||||
"comments": {},
|
||||
"defaultExpiracyDaysFromNow": 60
|
||||
},
|
||||
"stacks_count": 2,
|
||||
"stacks": [
|
||||
{
|
||||
"id": 1,
|
||||
"pseudo": "voting_people_TEST",
|
||||
"creation_date": {
|
||||
"date": "2020-01-22 14:28:19.000000",
|
||||
"timezone_type": 3,
|
||||
"timezone": "Europe/Paris"
|
||||
},
|
||||
"votes": [
|
||||
{
|
||||
"id": 1,
|
||||
"vote_id": 1,
|
||||
"value": "yes",
|
||||
"choice_id": 1,
|
||||
"text": "orange"
|
||||
},
|
||||
{
|
||||
"id": 1,
|
||||
"vote_id": 2,
|
||||
"value": "yes",
|
||||
"choice_id": 2,
|
||||
"text": null
|
||||
}
|
||||
]
|
||||
},
|
||||
{
|
||||
"id": 2,
|
||||
"pseudo": "voting_people_TEST",
|
||||
"creation_date": {
|
||||
"date": "2020-01-22 14:28:19.000000",
|
||||
"timezone_type": 3,
|
||||
"timezone": "Europe/Paris"
|
||||
},
|
||||
"votes": [
|
||||
{
|
||||
"id": 2,
|
||||
"vote_id": 3,
|
||||
"value": "maybe",
|
||||
"choice_id": 1,
|
||||
"text": "orange"
|
||||
}
|
||||
]
|
||||
}
|
||||
],
|
||||
"choices_count": 2,
|
||||
"choices": [
|
||||
{
|
||||
"id": 1,
|
||||
"date": {
|
||||
"date": "2020-01-22 14:28:19.000000",
|
||||
"timezone_type": 3,
|
||||
"timezone": "Europe/Paris"
|
||||
},
|
||||
"text": "orange",
|
||||
"url": null
|
||||
},
|
||||
{
|
||||
"id": 2,
|
||||
"date": {
|
||||
"date": "2020-01-22 14:28:19.000000",
|
||||
"timezone_type": 3,
|
||||
"timezone": "Europe/Paris"
|
||||
},
|
||||
"text": "citron",
|
||||
"url": null
|
||||
}
|
||||
],
|
||||
"comments": [],
|
||||
"comments_count": 0
|
||||
};
|
@ -146,7 +146,7 @@
|
||||
(click)='config.addComment()' >
|
||||
<framadate-voting-comment
|
||||
[comment]="c"
|
||||
*ngFor="let c of comments " >
|
||||
*ngFor="let c of config.currentPoll.comments " >
|
||||
</framadate-voting-comment >
|
||||
</div >
|
||||
<div class="sharing" >
|
||||
@ -156,14 +156,14 @@
|
||||
<p
|
||||
class="nobold text-14"
|
||||
for="copyLink" >Pour partager le sondage, vous pouvez diffuser ce lien :
|
||||
<a href='{{config.urlPublic}}' >
|
||||
{{config.urlPublic}}
|
||||
<a href='{{config.currentPoll.urlPublic}}' >
|
||||
{{config.currentPoll.urlPublic}}
|
||||
</a >
|
||||
</p >
|
||||
<button
|
||||
class=" btn btn--primary btn--outline"
|
||||
[ngxClipboard]
|
||||
[cbContent]="config.urlPublic"
|
||||
[cbContent]="config.currentPoll.urlPublic"
|
||||
id="copyLink" >
|
||||
<i class='fa fa-copy' ></i >
|
||||
{{"admin.copy_link" |translate}}
|
||||
|
@ -2,7 +2,7 @@ import {Component, OnInit} from '@angular/core';
|
||||
import {BaseComponent} from "../base-page/base.component";
|
||||
import {ConfigService} from "../../services/config.service";
|
||||
import {mockComments} from "../../config/mocks/mock-comments";
|
||||
import {ActivatedRoute} from "@angular/router";
|
||||
import {ActivatedRoute, Router, RouterEvent} from "@angular/router";
|
||||
|
||||
@Component({
|
||||
selector: 'framadate-poll-display',
|
||||
@ -14,21 +14,37 @@ export class PollDisplayComponent extends BaseComponent implements OnInit {
|
||||
comments = mockComments;
|
||||
|
||||
constructor(public config: ConfigService,
|
||||
private router: Router,
|
||||
public activeRoute: ActivatedRoute) {
|
||||
super(config);
|
||||
|
||||
router.events.subscribe((val: RouterEvent) => {
|
||||
// see also
|
||||
console.log(this.activeRoute);
|
||||
if (val.url && !this.config.loading) {
|
||||
this.fetchPoll();
|
||||
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
ngOnInit() {
|
||||
this.config.currentPoll;
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
// fetch poll with its ID or slug.
|
||||
fetchPoll() {
|
||||
const id = this.activeRoute.snapshot.params.poll;
|
||||
const pollSlug = this.activeRoute.snapshot.params.pollSlug;
|
||||
if (id) {
|
||||
|
||||
if (id) {
|
||||
this.config.loading = true;
|
||||
// store it in the poll property here
|
||||
this.config.getPollById(id).subscribe(
|
||||
(res: any) => {
|
||||
console.log('res', res)
|
||||
this.config.pollId = id;
|
||||
this.config.currentPoll = res;
|
||||
this.config.loading = false;
|
||||
@ -38,8 +54,10 @@ export class PollDisplayComponent extends BaseComponent implements OnInit {
|
||||
}
|
||||
);
|
||||
} else if (pollSlug) {
|
||||
this.config.loading = true;
|
||||
this.config.getPollByURL(pollSlug).subscribe(
|
||||
(res: any) => {
|
||||
console.log('res', res)
|
||||
this.config.pollId = res.id;
|
||||
this.config.currentPoll = res;
|
||||
this.config.loading = false;
|
||||
@ -50,7 +68,6 @@ export class PollDisplayComponent extends BaseComponent implements OnInit {
|
||||
);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -1,7 +1,9 @@
|
||||
<div class="comment" >
|
||||
<span class="cname" >{{comment.pseudo}} </span >, le
|
||||
<span class="date padding-btm-x1" >{{comment.date}}</span >
|
||||
<span class="date padding-btm-x1" >{{comment.date.date | date:'medium'}}</span >
|
||||
<blockquote >
|
||||
<p class="text" >
|
||||
{{comment.text}}
|
||||
</p >
|
||||
</blockquote >
|
||||
</div >
|
||||
|
@ -4,7 +4,7 @@ import {DOCUMENT} from '@angular/common';
|
||||
import {mockGraphConfig} from "../config/mocks/mock-graph";
|
||||
import {graphOptions} from "../config/graph-canevas-options";
|
||||
import {ConfigService} from "../services/config.service";
|
||||
import {mockPoll3} from "../config/mocks/mock-poll3";
|
||||
import {mockPoll1} from "../config/mocks/mock1";
|
||||
|
||||
@Component({
|
||||
selector: "framadate-poll-graphic",
|
||||
@ -13,7 +13,7 @@ import {mockPoll3} from "../config/mocks/mock-poll3";
|
||||
})
|
||||
export class PollGraphicComponent implements OnInit {
|
||||
isColorblind: boolean = false;
|
||||
pollConfigRetrieved: any = mockPoll3;
|
||||
pollConfigRetrieved: any = mockPoll1;
|
||||
graphicConfig: any = mockGraphConfig;
|
||||
preferred: any = "rien";
|
||||
yesList: number[] = [];
|
||||
|
@ -4,9 +4,9 @@ import {HttpClient, HttpHeaders} from "@angular/common/http";
|
||||
import {environment} from "../../environments/environment";
|
||||
import {ConfirmationService, MessageService} from 'primeng/api';
|
||||
import {Router} from "@angular/router";
|
||||
import {mockPoll3} from "../config/mocks/mock-poll3";
|
||||
import {mockMyPolls} from "../config/mocks/mockmypolls";
|
||||
import {defaultAnswers, defaultDates, timeOfDay} from "../config/defaultConfigs";
|
||||
import {mockPoll1} from "../config/mocks/mock1";
|
||||
|
||||
/**
|
||||
* le service transverse à chaque page qui permet de syncroniser la configuration de sondage souhaitée
|
||||
@ -29,7 +29,7 @@ export class ConfigService extends PollConfig {
|
||||
// fill in mock values if we are not in production environment
|
||||
if (!environment.production) {
|
||||
console.info(' ######### framadate ######### we are not in production env, filling with mock values');
|
||||
this.currentPoll = mockPoll3;
|
||||
this.currentPoll = mockPoll1;
|
||||
this.myPolls = mockMyPolls;
|
||||
this.dateList = defaultDates;
|
||||
this.timeList = timeOfDay;
|
||||
@ -121,6 +121,8 @@ export class ConfigService extends PollConfig {
|
||||
dateList: this.dateList,
|
||||
timeList: this.timeList,
|
||||
answers: this.answers,
|
||||
expiracyDateDefaultInDays: this.expiracyDateDefaultInDays,
|
||||
deletionDateAfterLastModification: this.deletionDateAfterLastModification,
|
||||
};
|
||||
return jsonConfig
|
||||
}
|
||||
@ -181,6 +183,7 @@ export class ConfigService extends PollConfig {
|
||||
this.myEmail = email;
|
||||
|
||||
|
||||
this.todo('send email for real : TODO');
|
||||
this.loading = true;
|
||||
this.http.get(`${this.baseHref}/send-polls-to-user/${this.myEmail}`,
|
||||
this.makeHeaders(),
|
||||
@ -290,6 +293,9 @@ export class ConfigService extends PollConfig {
|
||||
this.currentPoll = res;
|
||||
this.pollId = res.pollId;
|
||||
this.loading = false;
|
||||
if (!this.myPolls) {
|
||||
this.myPolls = [];
|
||||
}
|
||||
this.myPolls.push(config);
|
||||
this.router.navigate(['step/end']);
|
||||
// TODO save new poll to localstorage
|
||||
@ -311,6 +317,7 @@ export class ConfigService extends PollConfig {
|
||||
if (!voteStack) {
|
||||
voteStack = {
|
||||
pseudo: this.myName,
|
||||
email: this.myEmail,
|
||||
answers: this.answers
|
||||
}
|
||||
}
|
||||
@ -362,7 +369,7 @@ export class ConfigService extends PollConfig {
|
||||
}
|
||||
}
|
||||
this.http.post(
|
||||
`${this.baseHref}/poll/${this.pollId}/comment`,
|
||||
`${this.baseHref}/poll/${this.currentPoll.id}/comment`,
|
||||
comment,
|
||||
this.makeHeaders())
|
||||
.subscribe((res: any) => {
|
||||
|
@ -74,6 +74,16 @@
|
||||
i18n >
|
||||
Sondage dessins animés
|
||||
</a >
|
||||
<a
|
||||
[routerLink]="'/vote/poll/id/4'"
|
||||
i18n >
|
||||
Sondage 4
|
||||
</a >
|
||||
<a
|
||||
[routerLink]="'/vote/poll/id/5'"
|
||||
i18n >
|
||||
Sondage 5
|
||||
</a >
|
||||
<a
|
||||
[routerLink]="'/graphic/toto'"
|
||||
[ngClass]="{'active': step == 'graphic'}"
|
||||
|
Loading…
x
Reference in New Issue
Block a user