2021-07-19 13:01:06 +01:00
|
|
|
import { Injectable } from '@angular/core';
|
|
|
|
|
import { eventSource } from '../models/agenda/eventSource';
|
|
|
|
|
import { SHA1, SHA256, AES, enc } from 'crypto-js'
|
|
|
|
|
import { LocalstoreService } from './localstore.service'
|
|
|
|
|
|
|
|
|
|
@Injectable({
|
|
|
|
|
providedIn: 'root'
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
export class CalendarService {
|
|
|
|
|
|
|
|
|
|
private _eventSource : eventSource[] = []
|
2021-07-20 08:51:29 +01:00
|
|
|
private keyName: string;
|
2021-07-19 13:01:06 +01:00
|
|
|
|
2021-07-20 08:51:29 +01:00
|
|
|
constructor(private localstoreService: LocalstoreService) {
|
2021-07-19 13:01:06 +01:00
|
|
|
|
2021-07-20 08:51:29 +01:00
|
|
|
this.keyName = (SHA1(this.constructor.name+ 'eventSource')).toString()
|
2021-07-19 13:01:06 +01:00
|
|
|
|
2021-07-20 08:51:29 +01:00
|
|
|
let restore = localstoreService.get(this.keyName, [])
|
2021-07-19 13:01:06 +01:00
|
|
|
|
|
|
|
|
setTimeout(()=>{
|
|
|
|
|
restore.forEach((element, eventIndex) => {
|
|
|
|
|
this._eventSource.push({
|
|
|
|
|
title: element.title,
|
|
|
|
|
startTime: new Date(element.startTime),
|
|
|
|
|
endTime: new Date(element.endTime),
|
|
|
|
|
allDay: element.allDay,
|
|
|
|
|
event: element.event,
|
|
|
|
|
calendarName: element.calendarName,
|
|
|
|
|
profile: element.profile,
|
|
|
|
|
id: element.id,
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
});
|
2021-07-20 08:51:29 +01:00
|
|
|
},10)
|
2021-07-19 13:01:06 +01:00
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ResetList(eventSource: eventSource[]) {
|
|
|
|
|
this._eventSource = eventSource
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
get eventSource() {
|
|
|
|
|
return this._eventSource
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
removeRange(rangeStartDate, rangeEndDate, profile) {
|
|
|
|
|
this._eventSource = this._eventSource.filter((e)=> {
|
|
|
|
|
if(new Date(rangeStartDate).getTime() <= new Date(e.startTime).getTime() &&
|
|
|
|
|
new Date(rangeEndDate).getTime() >= new Date(e.endTime).getTime() && e.profile == profile) {
|
|
|
|
|
return false
|
|
|
|
|
}
|
|
|
|
|
return true
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
pushEvent(eventsList, profile: 'pr' | 'md') {
|
|
|
|
|
|
|
|
|
|
let news = []
|
|
|
|
|
eventsList.forEach((element, eventIndex) => {
|
|
|
|
|
news.push({
|
|
|
|
|
title: element.Subject,
|
|
|
|
|
startTime: new Date(element.StartDate),
|
|
|
|
|
endTime: new Date(element.EndDate),
|
|
|
|
|
allDay: false,
|
|
|
|
|
event: element,
|
|
|
|
|
calendarName: element.CalendarName,
|
|
|
|
|
profile: profile,
|
|
|
|
|
id: element.EventId,
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
let instance = this._eventSource.concat(news)
|
|
|
|
|
|
|
|
|
|
const ids = instance.map(o => o.id)
|
|
|
|
|
const filtered = instance.filter(({id}, index) => !ids.includes(id, index + 1))
|
|
|
|
|
|
|
|
|
|
this._eventSource = (filtered)
|
|
|
|
|
|
2021-07-20 08:51:29 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
setTimeout(() => {
|
|
|
|
|
|
|
|
|
|
this.localstoreService.set(this.keyName, this._eventSource)
|
|
|
|
|
|
|
|
|
|
}, 10)
|
2021-07-19 13:01:06 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|