mirror of
https://github.com/ThisIsBenny/iOS-Widgets.git
synced 2025-06-07 05:57:41 +00:00
widget parameter support
Signed-off-by: Benny Samir Hierl <bennysamir@posteo.de>
This commit is contained in:
parent
815c7f0331
commit
8bb641e6ee
1 changed files with 57 additions and 42 deletions
|
@ -12,8 +12,22 @@ If the dial-in data of a meeting should not be recognized, the invitation can be
|
||||||
|
|
||||||
*****************************/
|
*****************************/
|
||||||
|
|
||||||
let timeformat = 'de-DE'
|
let timeformat, countryCode
|
||||||
let countryCode = '+49'
|
|
||||||
|
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;
|
const listLimit = (config.widgetFamily == 'medium') ? 1 : 5;
|
||||||
|
|
||||||
|
@ -27,6 +41,7 @@ if (Device.isUsingDarkAppearance()) {
|
||||||
let now = new Date()
|
let now = new Date()
|
||||||
let end = new Date()
|
let end = new Date()
|
||||||
end.setHours(23, 59, 59, 999);
|
end.setHours(23, 59, 59, 999);
|
||||||
|
|
||||||
const matchPatterns = {
|
const matchPatterns = {
|
||||||
skype: {
|
skype: {
|
||||||
online: [
|
online: [
|
||||||
|
@ -54,7 +69,7 @@ const matchPatterns = {
|
||||||
let upcomingRemoteMeeting = (await CalendarEvent.between(now, end)).map((event) => {
|
let upcomingRemoteMeeting = (await CalendarEvent.between(now, end)).map((event) => {
|
||||||
if (event.notes) {
|
if (event.notes) {
|
||||||
for (const [key, value] of Object.entries(matchPatterns)) {
|
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'))
|
let m = event.notes.match(new RegExp(pattern, 'im'))
|
||||||
if (m && m[1]) {
|
if (m && m[1]) {
|
||||||
event.dialInUrl = 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
|
// 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 = []
|
let dialInNumbers = []
|
||||||
for (pattern of value.phone || []) {
|
for (pattern of value.phone || []) {
|
||||||
let numberMatch = event.notes.match(new RegExp(pattern.number, 'im'))
|
let numberMatch = event.notes.match(new RegExp(pattern.number, 'im'))
|
||||||
if (numberMatch && numberMatch[1]) {
|
if (numberMatch && numberMatch[1]) {
|
||||||
let dialInNumber = numberMatch[1]
|
let dialInNumber = numberMatch[1]
|
||||||
let pinMatch = event.notes.match(new RegExp(pattern.pin, 'im'))
|
let pinMatch = event.notes.match(new RegExp(pattern.pin, 'im'))
|
||||||
if (pinMatch && pinMatch[1]) {
|
if (pinMatch && pinMatch[1]) {
|
||||||
dialInNumber += ',,' + pinMatch[1] + '#'
|
dialInNumber += ',,' + pinMatch[1] + '#'
|
||||||
}
|
}
|
||||||
dialInNumbers.push(dialInNumber.replace(/%20|[\s\r\n]/g, ''))
|
dialInNumbers.push(dialInNumber.replace(/%20|[\s\r\n]/g, ''))
|
||||||
|
|
Loading…
Add table
Reference in a new issue