Added some sorting to the calendar. Using async! :)
This commit is contained in:
parent
62cdf35e60
commit
3917e0aeae
@ -25,7 +25,7 @@ for (var t = 0; t < calHandler.calendars.length;t++)
|
|||||||
});
|
});
|
||||||
*/
|
*/
|
||||||
|
|
||||||
for (const item of calHandler.calendars)
|
/* for (const item of calHandler.calendars)
|
||||||
calHandler.getAdvancedCalV3(item)
|
calHandler.getAdvancedCalV3(item)
|
||||||
.then((d) => {
|
.then((d) => {
|
||||||
'use strict';
|
'use strict';
|
||||||
@ -33,14 +33,14 @@ for (const item of calHandler.calendars)
|
|||||||
// cal.tomorrow = cal.tomorrow.concat(d.tomorrow);
|
// cal.tomorrow = cal.tomorrow.concat(d.tomorrow);
|
||||||
cal.week = cal.week.concat(d.week);
|
cal.week = cal.week.concat(d.week);
|
||||||
|
|
||||||
logger.info(cal);
|
console.dir(cal);
|
||||||
})
|
})
|
||||||
.catch((e) => {
|
.catch((e) => {
|
||||||
'use strict';
|
'use strict';
|
||||||
logger.error(e);
|
logger.error(e);
|
||||||
});
|
});*/
|
||||||
|
|
||||||
/*calHandler.getSimpleCalV3(
|
/* calHandler.getSimpleCalV3(
|
||||||
'http://www.pogdesign.co.uk/cat/download_ics/60cfdff469d0490545d33d7e3b5c0bcc')
|
'http://www.pogdesign.co.uk/cat/download_ics/60cfdff469d0490545d33d7e3b5c0bcc')
|
||||||
.then((d) => {
|
.then((d) => {
|
||||||
'use strict';
|
'use strict';
|
||||||
@ -53,7 +53,7 @@ for (const item of calHandler.calendars)
|
|||||||
logger.error(e);
|
logger.error(e);
|
||||||
});*/
|
});*/
|
||||||
|
|
||||||
/*calHandler.getAdvancedCalV3(calHandler.calendars[4])
|
/* calHandler.getAdvancedCalV3(calHandler.calendars[4])
|
||||||
.then((d) => {
|
.then((d) => {
|
||||||
'use strict';
|
'use strict';
|
||||||
// cal.today = cal.today.concat(d.today);
|
// cal.today = cal.today.concat(d.today);
|
||||||
@ -66,3 +66,36 @@ for (const item of calHandler.calendars)
|
|||||||
'use strict';
|
'use strict';
|
||||||
logger.error(e);
|
logger.error(e);
|
||||||
});*/
|
});*/
|
||||||
|
|
||||||
|
async function AsyncTest() {
|
||||||
|
|
||||||
|
function compare(a, b) {
|
||||||
|
if (a.ts < b.ts) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if (a.ts > b.ts) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
for (const item of calHandler.calendars)
|
||||||
|
await calHandler.getAdvancedCalV3(item)
|
||||||
|
.then((d) => {
|
||||||
|
'use strict';
|
||||||
|
// cal.today = cal.today.concat(d.today);
|
||||||
|
// cal.tomorrow = cal.tomorrow.concat(d.tomorrow);
|
||||||
|
cal.week = cal.week.concat(d.week);
|
||||||
|
|
||||||
|
// console.dir(cal);
|
||||||
|
})
|
||||||
|
.catch((e) => {
|
||||||
|
'use strict';
|
||||||
|
logger.error(e);
|
||||||
|
});
|
||||||
|
|
||||||
|
cal.week = cal.week.sort(compare);
|
||||||
|
console.log('COMPLETE!!');
|
||||||
|
console.log(cal.week);
|
||||||
|
}
|
||||||
|
|
||||||
|
AsyncTest();
|
||||||
|
File diff suppressed because one or more lines are too long
@ -8,7 +8,7 @@ const Sugar = require('sugar');
|
|||||||
|
|
||||||
Sugar.extend();
|
Sugar.extend();
|
||||||
|
|
||||||
logger.level = 'debug';
|
logger.level = 'error';
|
||||||
|
|
||||||
function processICAL(ical) {
|
function processICAL(ical) {
|
||||||
'use strict';
|
'use strict';
|
||||||
@ -139,7 +139,7 @@ function processICAL(ical) {
|
|||||||
newBlock = Object.assign({}, _workBlock);
|
newBlock = Object.assign({}, _workBlock);
|
||||||
newBlock.dtstart = new Date(_dstart);
|
newBlock.dtstart = new Date(_dstart);
|
||||||
newBlock.dtend = new Date(_dend);
|
newBlock.dtend = new Date(_dend);
|
||||||
logger.info(newBlock.dtstart.medium());
|
// logger.info(newBlock.dtstart.medium());
|
||||||
recurArray.push(newBlock);
|
recurArray.push(newBlock);
|
||||||
|
|
||||||
_dstart.advance({ 'year':1 });
|
_dstart.advance({ 'year':1 });
|
||||||
@ -162,7 +162,7 @@ function processICAL(ical) {
|
|||||||
newBlock = Object.assign({}, _workBlock);
|
newBlock = Object.assign({}, _workBlock);
|
||||||
newBlock.dtstart = new Date(_dstart);
|
newBlock.dtstart = new Date(_dstart);
|
||||||
newBlock.dtend = new Date(_dend);
|
newBlock.dtend = new Date(_dend);
|
||||||
logger.info(newBlock.dtstart.medium());
|
// logger.info(newBlock.dtstart.medium());
|
||||||
recurArray.push(newBlock);
|
recurArray.push(newBlock);
|
||||||
|
|
||||||
_dstart.addMonths(interval);
|
_dstart.addMonths(interval);
|
||||||
@ -193,7 +193,7 @@ function processICAL(ical) {
|
|||||||
newBlock = Object.assign({}, _workBlock);
|
newBlock = Object.assign({}, _workBlock);
|
||||||
newBlock.dtstart = new Date(_findSun).addMilliseconds(_workBlock.timeStartMS);
|
newBlock.dtstart = new Date(_findSun).addMilliseconds(_workBlock.timeStartMS);
|
||||||
newBlock.dtend = new Date(_findSun).addMilliseconds(_workBlock.timeEndMS);
|
newBlock.dtend = new Date(_findSun).addMilliseconds(_workBlock.timeEndMS);
|
||||||
logger.info(newBlock.dtstart.medium());
|
// logger.info(newBlock.dtstart.medium());
|
||||||
recurArray.push(newBlock);
|
recurArray.push(newBlock);
|
||||||
// all done, next.
|
// all done, next.
|
||||||
_dstart.reset('month').addDays(32);
|
_dstart.reset('month').addDays(32);
|
||||||
@ -216,7 +216,7 @@ function processICAL(ical) {
|
|||||||
newBlock = Object.assign({}, _workBlock);
|
newBlock = Object.assign({}, _workBlock);
|
||||||
newBlock.dtstart = new Date(_dstart);
|
newBlock.dtstart = new Date(_dstart);
|
||||||
newBlock.dtend = new Date(_dend);
|
newBlock.dtend = new Date(_dend);
|
||||||
logger.info(newBlock.dtstart.medium());
|
// logger.info(newBlock.dtstart.medium());
|
||||||
recurArray.push(newBlock);
|
recurArray.push(newBlock);
|
||||||
|
|
||||||
_dstart.addWeeks(interval);
|
_dstart.addWeeks(interval);
|
||||||
@ -224,7 +224,7 @@ function processICAL(ical) {
|
|||||||
}
|
}
|
||||||
while(_dstart < dateLimit);
|
while(_dstart < dateLimit);
|
||||||
}
|
}
|
||||||
|
|
||||||
return recurArray;
|
return recurArray;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -246,7 +246,8 @@ function processICAL(ical) {
|
|||||||
'combined': '',
|
'combined': '',
|
||||||
'recur': null,
|
'recur': null,
|
||||||
'timeStartMS': null,
|
'timeStartMS': null,
|
||||||
'timeEndMS': null
|
'timeEndMS': null,
|
||||||
|
'ts' : null
|
||||||
};
|
};
|
||||||
let alarmFlag = false, ws, blockStep;
|
let alarmFlag = false, ws, blockStep;
|
||||||
for (let step = 0; step < block.length; step++) {
|
for (let step = 0; step < block.length; step++) {
|
||||||
@ -320,7 +321,6 @@ function processICAL(ical) {
|
|||||||
workBlock.timeEnd = Sugar.Date(workBlock.dtend).format('{24hr}:{mm}:{ss}').raw;
|
workBlock.timeEnd = Sugar.Date(workBlock.dtend).format('{24hr}:{mm}:{ss}').raw;
|
||||||
workBlock.timeEndMS = ((workBlock.dtend.getHours() * 60 * 60 ) + (workBlock.dtend.getMinutes() * 60 ) + workBlock.dtend.getSeconds()) * 1000;
|
workBlock.timeEndMS = ((workBlock.dtend.getHours() * 60 * 60 ) + (workBlock.dtend.getMinutes() * 60 ) + workBlock.dtend.getSeconds()) * 1000;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (workBlock.dtstart !== null && workBlock.dtend !== null) {
|
if (workBlock.dtstart !== null && workBlock.dtend !== null) {
|
||||||
const elapsedTime = new Elapsed(workBlock.dtstart, workBlock.dtend);
|
const elapsedTime = new Elapsed(workBlock.dtstart, workBlock.dtend);
|
||||||
@ -372,13 +372,24 @@ function processICAL(ical) {
|
|||||||
if (Array.isArray(b))
|
if (Array.isArray(b))
|
||||||
logger.error('!returned an array...');
|
logger.error('!returned an array...');
|
||||||
else
|
else
|
||||||
if (b.dtstart !== null)
|
if (b.dtstart !== null) {
|
||||||
|
b.ts = b.dtstart.format('{X}');
|
||||||
workingBlock.push(b);
|
workingBlock.push(b);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
// logger.warn('We need to spread the recurrance!!');
|
// logger.warn('We need to spread the recurrance!!');
|
||||||
// logger.debug(b);
|
// logger.debug(b);
|
||||||
const recurBlocks = buildRecurranceArray(b);
|
let recurBlocks = buildRecurranceArray(b);
|
||||||
|
|
||||||
|
if (recurBlocks)
|
||||||
|
recurBlocks = recurBlocks.map((item) => {
|
||||||
|
if (item.dtstart)
|
||||||
|
item.ts = item.dtstart.format('{X}');
|
||||||
|
|
||||||
|
return item;
|
||||||
|
});
|
||||||
|
|
||||||
if (recurBlocks && recurBlocks.length > 0)
|
if (recurBlocks && recurBlocks.length > 0)
|
||||||
workingBlock = workingBlock.concat(recurBlocks);
|
workingBlock = workingBlock.concat(recurBlocks);
|
||||||
}
|
}
|
||||||
@ -519,7 +530,7 @@ module.exports = {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
catch (e) {
|
catch (e) {
|
||||||
console.log(e);
|
logger.error(e);
|
||||||
}
|
}
|
||||||
}, 'getSimpleCalV3': function(url) {
|
}, 'getSimpleCalV3': function(url) {
|
||||||
'use strict';
|
'use strict';
|
||||||
@ -549,7 +560,7 @@ module.exports = {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
catch (e) {
|
catch (e) {
|
||||||
console.log(e);
|
logger.error(e);
|
||||||
|
|
||||||
return reject(e);
|
return reject(e);
|
||||||
}
|
}
|
||||||
@ -591,7 +602,7 @@ module.exports = {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
catch (e) {
|
catch (e) {
|
||||||
console.log(e);
|
logger.error(e);
|
||||||
|
|
||||||
return reject(e);
|
return reject(e);
|
||||||
}
|
}
|
||||||
|
@ -325,7 +325,17 @@ module.exports = {
|
|||||||
this.refreshTrain();
|
this.refreshTrain();
|
||||||
this.refreshWeather();
|
this.refreshWeather();
|
||||||
},
|
},
|
||||||
'preLoadToday': function () {
|
'preLoadToday': async function () {
|
||||||
|
function compare(a, b) {
|
||||||
|
if (a.ts < b.ts) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if (a.ts > b.ts) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
module.exports.getTodayDate();
|
module.exports.getTodayDate();
|
||||||
todayCache.data.cal = { 'today': [], 'tomorrow': [], 'week': [] };
|
todayCache.data.cal = { 'today': [], 'tomorrow': [], 'week': [] };
|
||||||
weather.newDoGetWeather()
|
weather.newDoGetWeather()
|
||||||
@ -384,7 +394,7 @@ module.exports = {
|
|||||||
logger.error(e);
|
logger.error(e);
|
||||||
});
|
});
|
||||||
|
|
||||||
for (let t = 0; t < calHandler.calendars.length; t++)
|
/*for (let t = 0; t < calHandler.calendars.length; t++)
|
||||||
calHandler.getAdvancedCalV3(calHandler.calendars[t])
|
calHandler.getAdvancedCalV3(calHandler.calendars[t])
|
||||||
.then((d) => {
|
.then((d) => {
|
||||||
'use strict';
|
'use strict';
|
||||||
@ -395,7 +405,25 @@ module.exports = {
|
|||||||
.catch((e) => {
|
.catch((e) => {
|
||||||
'use strict';
|
'use strict';
|
||||||
logger.error(e);
|
logger.error(e);
|
||||||
});
|
});*/
|
||||||
|
|
||||||
|
for (const item of calHandler.calendars)
|
||||||
|
await calHandler.getAdvancedCalV3(item)
|
||||||
|
.then((d) => {
|
||||||
|
todayCache.data.cal.today = todayCache.data.cal.today.concat(d.today);
|
||||||
|
todayCache.data.cal.tomorrow = todayCache.data.cal.tomorrow.concat(d.tomorrow);
|
||||||
|
todayCache.data.cal.week = todayCache.data.cal.week.concat(d.week);
|
||||||
|
|
||||||
|
})
|
||||||
|
.catch((e) => {
|
||||||
|
'use strict';
|
||||||
|
logger.error(e);
|
||||||
|
});
|
||||||
|
|
||||||
|
console.log('>> SORT!!');
|
||||||
|
todayCache.data.cal.today = todayCache.data.cal.today.sort(compare);
|
||||||
|
todayCache.data.cal.tomorrow = todayCache.data.cal.tomorrow.sort(compare);
|
||||||
|
todayCache.data.cal.week = todayCache.data.cal.week.sort(compare);
|
||||||
|
|
||||||
swedishWord.getSwedishWord()
|
swedishWord.getSwedishWord()
|
||||||
.then((d) => {
|
.then((d) => {
|
||||||
|
Loading…
Reference in New Issue
Block a user