send stack of votes button linked to api

This commit is contained in:
tykayn 2021-04-28 14:33:41 +02:00 committed by Baptiste Lemoine
parent 3abef619c8
commit 7a83beae8e
6 changed files with 45 additions and 6 deletions

View File

@ -2,9 +2,12 @@ export class Vote {
public choice_id: number = 0; public choice_id: number = 0;
public value: string = ''; // valeur de réponse public value: string = ''; // valeur de réponse
constructor(choice_id?) { constructor(choice_id?, value?) {
if (choice_id) { if (choice_id) {
this.choice_id = choice_id; this.choice_id = choice_id;
} }
if (value) {
this.value = value;
}
} }
} }

View File

@ -8,6 +8,7 @@ import { HttpClient, HttpHeaders } from '@angular/common/http';
import { Subscription } from 'rxjs'; import { Subscription } from 'rxjs';
import { ToastService } from './toast.service'; import { ToastService } from './toast.service';
import { LoaderService } from './loader.service'; import { LoaderService } from './loader.service';
import { Stack } from '../models/stack.model';
const apiVersion = environment.api.versionToUse; const apiVersion = environment.api.versionToUse;
const currentApiRoutes = environment.api.version[apiVersion]; const currentApiRoutes = environment.api.version[apiVersion];
@ -30,8 +31,11 @@ export class ApiService {
private readonly usersEndpoint = apiEndpoints.users.name; private readonly usersEndpoint = apiEndpoints.users.name;
private readonly usersPollsEndpoint = apiEndpoints.users.polls.name; private readonly usersPollsEndpoint = apiEndpoints.users.polls.name;
private readonly usersPollsSendEmailEndpoint = apiEndpoints.users.polls.sendEmail.name; private readonly usersPollsSendEmailEndpoint = apiEndpoints.users.polls.sendEmail.name;
private baseHref: string;
constructor(private http: HttpClient, private loader: LoaderService, private toastService: ToastService) { constructor(private http: HttpClient, private loader: LoaderService, private toastService: ToastService) {
this.baseHref = apiBaseHref;
this.axiosInstance = axios.create({ baseURL: apiBaseHref }); this.axiosInstance = axios.create({ baseURL: apiBaseHref });
this.axiosInstance.defaults.timeout = 2500; this.axiosInstance.defaults.timeout = 2500;
this.axiosInstance.defaults.headers.post['Content-Type'] = 'application/json'; this.axiosInstance.defaults.headers.post['Content-Type'] = 'application/json';
@ -91,9 +95,9 @@ export class ApiService {
public async createPoll(poll: Poll): Promise<Subscription> { public async createPoll(poll: Poll): Promise<Subscription> {
// this.loader.setStatus(true); // this.loader.setStatus(true);
console.log('createPoll config', poll); console.log('createPoll config', poll);
const baseHref = this.useDevLocalServer ? 'http://localhost:8000' : apiBaseHref;
return this.axiosInstance.post( return this.axiosInstance.post(
`${baseHref}${currentApiRoutes['api_new_poll']}`, `${this.baseHref}${currentApiRoutes['api_new_poll']}`,
poll, poll,
ApiService.makeHeaders() ApiService.makeHeaders()
); );
@ -108,6 +112,24 @@ export class ApiService {
// } // }
} }
/**
* send a new vote stack
* @param poll
* @param vote_stack
*/
public async sendVoteStackOfPoll(poll: Poll, vote_stack: Stack) {
// api_new_vote_stack POST ANY ANY /api/v1/poll/{id}/answer
console.log('vote_stack', vote_stack);
console.log('this.baseHref', this.baseHref);
try {
return await this.axiosInstance.post(`${this.pollsEndpoint}/${poll.custom_url}/answer`, vote_stack);
} catch (error) {
ApiService.handleError(error);
}
}
////////// //////////
// READ // // READ //

View File

@ -6,6 +6,7 @@ import { Theme } from '../enums/theme.enum';
import { Stack } from '../models/stack.model'; import { Stack } from '../models/stack.model';
import { Choice } from '../models/choice.model'; import { Choice } from '../models/choice.model';
import { Vote } from '../models/vote.model'; import { Vote } from '../models/vote.model';
import { environment } from '../../../environments/environment';
@Injectable({ @Injectable({
providedIn: 'root', providedIn: 'root',
@ -27,9 +28,13 @@ export class StorageService {
this.vote_stack.votes = []; this.vote_stack.votes = [];
for (let choice of choices_list) { for (let choice of choices_list) {
if (environment.autofill) {
this.vote_stack.votes.push(new Vote(choice.id, 'yes'));
} else {
this.vote_stack.votes.push(new Vote(choice.id)); this.vote_stack.votes.push(new Vote(choice.id));
} }
} }
}
toggleAnswer(choice_id: number, value: string) { toggleAnswer(choice_id: number, value: string) {
for (let vote of this.vote_stack.votes) { for (let vote of this.vote_stack.votes) {

View File

@ -8,6 +8,7 @@ import { DateService } from '../../core/services/date.service';
import { PollUtilities } from '../old-stuff/config/PollUtilities'; import { PollUtilities } from '../old-stuff/config/PollUtilities';
import { Comment } from '../../core/models/comment.model'; import { Comment } from '../../core/models/comment.model';
import { StorageService } from '../../core/services/storage.service'; import { StorageService } from '../../core/services/storage.service';
import { ApiService } from '../../core/services/api.service';
@Component({ @Component({
selector: 'app-consultation', selector: 'app-consultation',
@ -35,6 +36,7 @@ export class ConsultationComponent implements OnInit, OnDestroy {
private utils: PollUtilities, private utils: PollUtilities,
private _Activatedroute: ActivatedRoute, private _Activatedroute: ActivatedRoute,
public storageService: StorageService, public storageService: StorageService,
public api: ApiService,
public pollService: PollService, public pollService: PollService,
public dateService: DateService, public dateService: DateService,
private modalService: ModalService private modalService: ModalService
@ -72,12 +74,16 @@ export class ConsultationComponent implements OnInit, OnDestroy {
} }
} }
updateVote(myVoteStack: boolean) { updateVote() {
alert('TODO'); alert('TODO');
} }
addVoteStack() { addVoteStack() {
alert('TODO'); this.api.sendVoteStackOfPoll(this.poll, this.storageService.vote_stack).then((resp) => {
console.log('resp', resp);
this.api.getPollBySlug(this.poll.custom_url);
});
} }
/** /**

View File

@ -12,6 +12,7 @@ const apiV1 = {
export const environment = { export const environment = {
production: true, production: true,
autofill: true,
appTitle: 'FramaDate Funky', appTitle: 'FramaDate Funky',
appVersion: '2.1.0', appVersion: '2.1.0',
appLogo: 'assets/img/logo.png', appLogo: 'assets/img/logo.png',

View File

@ -10,12 +10,14 @@ const apiV1 = {
baseHref: 'http://localhost:8000/api/v1', baseHref: 'http://localhost:8000/api/v1',
api_new_poll: '/poll/', api_new_poll: '/poll/',
api_get_poll: '/poll/{id}', api_get_poll: '/poll/{id}',
api_new_vote_stack: '/poll/{id}/answer',
'api_test-mail-poll': '/api/v1/poll/mail/test-mail-poll/{emailChoice}', 'api_test-mail-poll': '/api/v1/poll/mail/test-mail-poll/{emailChoice}',
'app.swagger': '/api/doc.json', 'app.swagger': '/api/doc.json',
}; };
export const environment = { export const environment = {
production: false, production: false,
autofill: true,
appTitle: 'FramaDate Funky', appTitle: 'FramaDate Funky',
appVersion: '2.1.0', appVersion: '2.1.0',
appLogo: 'assets/img/logo.png', appLogo: 'assets/img/logo.png',