widget parameter support

Signed-off-by: Benny Samir Hierl <bennysamir@posteo.de>
This commit is contained in:
Benny Samir Hierl 2020-10-28 18:23:15 +01:00
parent 815c7f0331
commit 8bb641e6ee
No known key found for this signature in database
GPG key ID: 69DE3C3C097DB7F7

View file

@ -12,10 +12,24 @@ If the dial-in data of a meeting should not be recognized, the invitation can be
*****************************/
let timeformat = 'de-DE'
let countryCode = '+49'
let timeformat, countryCode
const listLimit = (config.widgetFamily == 'medium')? 1:5;
let widgetInputRAW = args.widgetParameter;
let widgetInput = null;
if (widgetInputRAW) {
widgetInput = widgetInputRAW.toString().split(';')
countryCode = widgetInput[0]
timeformat = widgetInput[1] || 'de-DE'
if (/^\+[\d]{1,3}$/.test(countryCode) === false) {
throw new Error('Invalid format of country code: ' + countryCode);
}
} else {
countryCode = '+49'
timeformat = 'de-DE'
}
const listLimit = (config.widgetFamily == 'medium') ? 1 : 5;
let iconColor;
if (Device.isUsingDarkAppearance()) {
@ -26,14 +40,15 @@ if (Device.isUsingDarkAppearance()) {
let now = new Date()
let end = new Date()
end.setHours(23,59,59,999);
end.setHours(23, 59, 59, 999);
const matchPatterns = {
skype: {
online: [
/Skype-Besprechung teilnehmen <(https?:\/\/[a-zA-Z0-9\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF./\-_]*)>/
],
phone: [
{number: /Per Telefon teilnehmen[\r\n\s]+.*<tel:(\+49[0-9%]+)>/, pin: /Konferenzkennung:[\s]([0-9]+)/}
{ number: /Per Telefon teilnehmen[\r\n\s]+.*<tel:(\+49[0-9%]+)>/, pin: /Konferenzkennung:[\s]([0-9]+)/ }
]
},
circuit: {
@ -41,7 +56,7 @@ const matchPatterns = {
/(https:\/\/eu\.yourcircuit\.com\/guest\?token=[\a-z0-9-]+)/
],
phone: [
{number: /Einwahlnummern[\r\n]*Deutschland[\r\n]*Deutsch[\r\n]*(\+49[0-9\s]+)/, pin: /PIN[\r\n]*([0-9\s]+)#/}
{ number: /Einwahlnummern[\r\n]*Deutschland[\r\n]*Deutsch[\r\n]*(\+49[0-9\s]+)/, pin: /PIN[\r\n]*([0-9\s]+)#/ }
]
},
msteams: {
@ -54,7 +69,7 @@ const matchPatterns = {
let upcomingRemoteMeeting = (await CalendarEvent.between(now, end)).map((event) => {
if (event.notes) {
for (const [key, value] of Object.entries(matchPatterns)) {
for (pattern of value.online || []) {
for (pattern of value.online || []) {
let m = event.notes.match(new RegExp(pattern, 'im'))
if (m && m[1]) {
event.dialInUrl = m[1]
@ -63,12 +78,12 @@ let upcomingRemoteMeeting = (await CalendarEvent.between(now, end)).map((event)
}
// Some Invitations contains multiple phone numbers with different Country Codes, why first all numbers will be collected and late the needed number with the given country code will be filtered out
let dialInNumbers = []
for (pattern of value.phone || []) {
for (pattern of value.phone || []) {
let numberMatch = event.notes.match(new RegExp(pattern.number, 'im'))
if (numberMatch && numberMatch[1]) {
let dialInNumber = numberMatch[1]
let pinMatch = event.notes.match(new RegExp(pattern.pin, 'im'))
if (pinMatch && pinMatch[1]) {
if (pinMatch && pinMatch[1]) {
dialInNumber += ',,' + pinMatch[1] + '#'
}
dialInNumbers.push(dialInNumber.replace(/%20|[\s\r\n]/g, ''))
@ -136,18 +151,18 @@ else if (nextUpcomingMeeting) {
if (nextUpcomingMeeting.dialInNumber) {
let phoneImage = rightStack.addImage(SFSymbol.named('phone').image)
phoneImage.imageSize = new Size(25,25)
phoneImage.imageSize = new Size(25, 25)
phoneImage.url = 'tel:' + nextUpcomingMeeting.dialInNumber
if (iconColor) {phoneImage.tintColor = new Color(iconColor)}
if (iconColor) { phoneImage.tintColor = new Color(iconColor) }
}
if (nextUpcomingMeeting.dialInUrl) {
rightStack.addSpacer(10)
let videoImage = rightStack.addImage(SFSymbol.named('video').image)
videoImage.imageSize = new Size(25,25)
videoImage.imageSize = new Size(25, 25)
videoImage.url = nextUpcomingMeeting.dialInUrl
videoImage.centerAlignImage()
if (iconColor) {videoImage.tintColor = new Color(iconColor)}
if (iconColor) { videoImage.tintColor = new Color(iconColor) }
}
rightStack.addSpacer()
widget.addSpacer()
@ -156,7 +171,7 @@ else if (nextUpcomingMeeting) {
upcomingMeetingStack.layoutVertically()
if (upComingMeetings && upComingMeetings.length > 0) {
let upComingText = upcomingMeetingStack.addText((upComingMeetings.length == 1)? 'Upcoming Remote Meeting':'Upcoming Remote Meetings')
let upComingText = upcomingMeetingStack.addText((upComingMeetings.length == 1) ? 'Upcoming Remote Meeting' : 'Upcoming Remote Meetings')
upComingText.font = Font.boldSystemFont(10)
upcomingMeetingStack.addSpacer(2)
}
@ -184,16 +199,16 @@ else if (nextUpcomingMeeting) {
if (upComingMeetings[i].dialInNumber) {
let phoneImage = rightColumn.addImage(SFSymbol.named('phone').image)
phoneImage.imageSize = new Size(15,15)
phoneImage.imageSize = new Size(15, 15)
phoneImage.url = 'tel:' + upComingMeetings[i].dialInNumber
if (iconColor) {phoneImage.tintColor = new Color(iconColor)}
if (iconColor) { phoneImage.tintColor = new Color(iconColor) }
}
if (upComingMeetings[i].dialInUrl) {
let videoImage = rightColumn.addImage(SFSymbol.named('video').image)
videoImage.imageSize = new Size(15,15)
videoImage.imageSize = new Size(15, 15)
videoImage.url = upComingMeetings[i].dialInUrl
if (iconColor) {videoImage.tintColor = new Color(iconColor)}
if (iconColor) { videoImage.tintColor = new Color(iconColor) }
}
}
widget.addSpacer(5)
@ -206,7 +221,7 @@ else if (nextUpcomingMeeting) {
widget.addSpacer()
}
if(!config.runsInWidget) {
if (!config.runsInWidget) {
await widget.presentLarge()
} else {
// Tell the system to show the widget.