framadate-responsive/src/app/config/PollConfig.ts

90 lines
3.4 KiB
TypeScript
Raw Normal View History

/**
* une option de date dans les sondages spéciaux
*/
2020-04-11 16:16:25 +02:00
import {environment} from '../../environments/environment';
import {DateChoice, defaultAnswers, otherDefaultDates, PollAnswer} from './defaultConfigs';
export interface DateOption {
timeList: any;
2019-08-12 14:40:33 +02:00
literal: string;
2020-01-24 11:15:38 +01:00
date_object?: object;
}
const baseConfigValues = {
2020-04-11 16:16:25 +02:00
pollType: 'dates',
title: '',
description: '',
myName: '',
myEmail: '',
};
2019-11-15 15:19:42 +01:00
/**
2019-08-10 17:41:01 +02:00
* configuration of the poll, add new fields at will
*/
export class PollConfig {
menuVisible = true;
2019-11-23 15:35:27 +01:00
expiracyDateDefaultInDays = 60;
2020-01-16 11:46:31 +01:00
deletionDateAfterLastModification = 180;
2020-04-11 16:16:25 +02:00
step = 0; // step in the progress of creating a poll
stepMax = 3; // step max in the progress of creating a poll
pollType = 'dates';// classic or dates
2020-04-11 16:16:25 +02:00
title: string = environment.production ? '' : 'titre';
description: string = environment.production ? '' : 'ma description';
myName: string = environment.production ? '' : 'mon pseudo';
myComment: string = environment.production ? '' : 'wouah trop bien framadate!';
isAdmin: boolean = !environment.production;
myVoteStack: any;
myTempVoteStack = 0;
2020-04-11 16:16:25 +02:00
myEmail: string = environment.production ? '' : 'tktest@tktest.com';
2020-01-22 16:49:15 +01:00
myPolls: any = [];// list of retrieved polls from the backend api
2020-04-11 16:16:25 +02:00
/*
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 = 'true';
// access
visibility = 'link_only'; // visible to anyone with the link:
voteChoices = 'only_yes'; // possible answers to a vote choice: only "yes", "yes, maybe, no"
creationDate = new Date();
2019-11-23 15:35:27 +01:00
expirationDate = ''; // expiracy date
voteStackId = null; // id of the vote stack to update
2019-12-04 12:45:50 +01:00
pollId = null; // id of the current poll when created. data given by the backend api
2020-01-23 14:23:07 +01:00
pollSlug = null; // id of the current poll when created. data given by the backend api
currentPoll; // current poll selected with createPoll or getPoll of ConfigService
passwordAccess = 0;
password = '';
customUrl = ''; // custom slug in the url, must be unique
customUrlIsUnique = null; // given by the backend
2020-01-23 16:47:53 +01:00
urlSlugPublic = null;
2020-04-11 16:16:25 +02:00
urlPublic = environment.production ? '' : environment.baseHref + '/#/poll/id/4';
urlAdmin = environment.baseHref + '/#/admin/d65es45fd45sdf45sd345f312sdf31sgfd345';
2020-02-04 12:51:18 +01:00
adminKey = ''; // key to change config of the poll
owner_modifier_token = ''; // key to change a vote stack
2020-04-11 16:16:25 +02:00
canModifyAnswers = true;// bool for the frontend selector
whoModifiesAnswers = 'everybody';// everybody, self, nobody (= just admin)
whoCanChangeAnswers = 'everybody';// everybody, self, nobody (= just admin)
2020-02-13 17:41:36 +01:00
dateList: any = otherDefaultDates; // sets of days as strings, config to set identical time for days in a special days poll
timeList: DateChoice[] = otherDefaultDates; // ranges of time expressed as strings
answers: PollAnswer[] = defaultAnswers;
// front end choices
themeChoices: string[] = ['light-watermelon', 'dark-crystal', 'hot-covid'];
2020-04-11 16:16:25 +02:00
themeSelected = 0;
themeClass = 'theme-light-watermelon';
// modals
2020-04-11 16:16:25 +02:00
displayConfirmVoteModalAdmin = false;
2019-08-10 17:41:01 +02:00
resetConfig() {
const self = this;
Object.keys(baseConfigValues).forEach((key) => {
self[key] = baseConfigValues[key];
2020-04-11 16:16:25 +02:00
});
}
}