@microsoft/teams-js 2.0.0-beta.4-dev.10 → 2.0.0-beta.4-dev.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"MicrosoftTeams.min.js","mappings":"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","sources":["webpack://microsoftTeams/webpack/universalModuleDefinition","webpack://microsoftTeams/../../node_modules/uuid/index.js","webpack://microsoftTeams/../../node_modules/uuid/lib/bytesToUuid.js","webpack://microsoftTeams/../../node_modules/uuid/lib/rng-browser.js","webpack://microsoftTeams/../../node_modules/uuid/v1.js","webpack://microsoftTeams/../../node_modules/uuid/v4.js","webpack://microsoftTeams/./node_modules/debug/src/browser.js","webpack://microsoftTeams/./node_modules/debug/src/common.js","webpack://microsoftTeams/./node_modules/ms/index.js","webpack://microsoftTeams/webpack/bootstrap","webpack://microsoftTeams/webpack/runtime/define property getters","webpack://microsoftTeams/webpack/runtime/hasOwnProperty shorthand","webpack://microsoftTeams/webpack/runtime/make namespace object","webpack://microsoftTeams/./src/internal/constants.ts","webpack://microsoftTeams/./src/public/constants.ts","webpack://microsoftTeams/./src/internal/globalVars.ts","webpack://microsoftTeams/./src/public/interfaces.ts","webpack://microsoftTeams/./src/internal/utils.ts","webpack://microsoftTeams/./src/internal/internalAPIs.ts","webpack://microsoftTeams/./src/public/runtime.ts","webpack://microsoftTeams/./src/private/logs.ts","webpack://microsoftTeams/./src/public/authentication.ts","webpack://microsoftTeams/./src/public/menus.ts","webpack://microsoftTeams/./src/public/teamsAPIs.ts","webpack://microsoftTeams/./src/public/app.ts","webpack://microsoftTeams/./src/public/pages.ts","webpack://microsoftTeams/./src/private/privateAPIs.ts","webpack://microsoftTeams/./src/internal/telemetry.ts","webpack://microsoftTeams/./src/internal/handlers.ts","webpack://microsoftTeams/./src/internal/communication.ts","webpack://microsoftTeams/./src/private/bot.ts","webpack://microsoftTeams/./src/private/interfaces.ts","webpack://microsoftTeams/./src/private/chat.ts","webpack://microsoftTeams/./src/public/appInstallDialog.ts","webpack://microsoftTeams/./src/public/appWindow.ts","webpack://microsoftTeams/./src/public/dialog.ts","webpack://microsoftTeams/./src/internal/mediaUtil.ts","webpack://microsoftTeams/./src/public/media.ts","webpack://microsoftTeams/./src/public/location.ts","webpack://microsoftTeams/./src/public/meeting.ts","webpack://microsoftTeams/./src/public/monetization.ts","webpack://microsoftTeams/./src/public/calendar.ts","webpack://microsoftTeams/./src/public/mail.ts","webpack://microsoftTeams/./src/public/people.ts","webpack://microsoftTeams/./src/public/video.ts","webpack://microsoftTeams/./src/public/sharing.ts","webpack://microsoftTeams/./src/public/stageView.ts","webpack://microsoftTeams/./src/public/call.ts","webpack://microsoftTeams/./src/public/appInitialization.ts","webpack://microsoftTeams/./src/public/settings.ts","webpack://microsoftTeams/./src/public/tasks.ts","webpack://microsoftTeams/./src/private/files.ts","webpack://microsoftTeams/./src/private/legacy.ts","webpack://microsoftTeams/./src/private/meetingRoom.ts","webpack://microsoftTeams/./src/private/notifications.ts","webpack://microsoftTeams/./src/private/remoteCamera.ts","webpack://microsoftTeams/./src/private/appEntity.ts","webpack://microsoftTeams/./src/private/teams.ts","webpack://microsoftTeams/./src/public/publicAPIs.ts","webpack://microsoftTeams/./src/public/navigation.ts"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"microsoftTeams\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"microsoftTeams\"] = factory();\n\telse\n\t\troot[\"microsoftTeams\"] = factory();\n})(self, function() {\nreturn ","var v1 = require('./v1');\nvar v4 = require('./v4');\n\nvar uuid = v4;\nuuid.v1 = v1;\nuuid.v4 = v4;\n\nmodule.exports = uuid;\n","/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\nvar byteToHex = [];\nfor (var i = 0; i < 256; ++i) {\n byteToHex[i] = (i + 0x100).toString(16).substr(1);\n}\n\nfunction bytesToUuid(buf, offset) {\n var i = offset || 0;\n var bth = byteToHex;\n // join used to fix memory issue caused by concatenation: https://bugs.chromium.org/p/v8/issues/detail?id=3175#c4\n return ([\n bth[buf[i++]], bth[buf[i++]],\n bth[buf[i++]], bth[buf[i++]], '-',\n bth[buf[i++]], bth[buf[i++]], '-',\n bth[buf[i++]], bth[buf[i++]], '-',\n bth[buf[i++]], bth[buf[i++]], '-',\n bth[buf[i++]], bth[buf[i++]],\n bth[buf[i++]], bth[buf[i++]],\n bth[buf[i++]], bth[buf[i++]]\n ]).join('');\n}\n\nmodule.exports = bytesToUuid;\n","// Unique ID creation requires a high quality random # generator. In the\n// browser this is a little complicated due to unknown quality of Math.random()\n// and inconsistent support for the `crypto` API. We do the best we can via\n// feature-detection\n\n// getRandomValues needs to be invoked in a context where \"this\" is a Crypto\n// implementation. Also, find the complete implementation of crypto on IE11.\nvar getRandomValues = (typeof(crypto) != 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto)) ||\n (typeof(msCrypto) != 'undefined' && typeof window.msCrypto.getRandomValues == 'function' && msCrypto.getRandomValues.bind(msCrypto));\n\nif (getRandomValues) {\n // WHATWG crypto RNG - http://wiki.whatwg.org/wiki/Crypto\n var rnds8 = new Uint8Array(16); // eslint-disable-line no-undef\n\n module.exports = function whatwgRNG() {\n getRandomValues(rnds8);\n return rnds8;\n };\n} else {\n // Math.random()-based (RNG)\n //\n // If all else fails, use Math.random(). It's fast, but is of unspecified\n // quality.\n var rnds = new Array(16);\n\n module.exports = function mathRNG() {\n for (var i = 0, r; i < 16; i++) {\n if ((i & 0x03) === 0) r = Math.random() * 0x100000000;\n rnds[i] = r >>> ((i & 0x03) << 3) & 0xff;\n }\n\n return rnds;\n };\n}\n","var rng = require('./lib/rng');\nvar bytesToUuid = require('./lib/bytesToUuid');\n\n// **`v1()` - Generate time-based UUID**\n//\n// Inspired by https://github.com/LiosK/UUID.js\n// and http://docs.python.org/library/uuid.html\n\nvar _nodeId;\nvar _clockseq;\n\n// Previous uuid creation time\nvar _lastMSecs = 0;\nvar _lastNSecs = 0;\n\n// See https://github.com/uuidjs/uuid for API details\nfunction v1(options, buf, offset) {\n var i = buf && offset || 0;\n var b = buf || [];\n\n options = options || {};\n var node = options.node || _nodeId;\n var clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq;\n\n // node and clockseq need to be initialized to random values if they're not\n // specified. We do this lazily to minimize issues related to insufficient\n // system entropy. See #189\n if (node == null || clockseq == null) {\n var seedBytes = rng();\n if (node == null) {\n // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)\n node = _nodeId = [\n seedBytes[0] | 0x01,\n seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]\n ];\n }\n if (clockseq == null) {\n // Per 4.2.2, randomize (14 bit) clockseq\n clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff;\n }\n }\n\n // UUID timestamps are 100 nano-second units since the Gregorian epoch,\n // (1582-10-15 00:00). JSNumbers aren't precise enough for this, so\n // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'\n // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.\n var msecs = options.msecs !== undefined ? options.msecs : new Date().getTime();\n\n // Per 4.2.1.2, use count of uuid's generated during the current clock\n // cycle to simulate higher resolution clock\n var nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1;\n\n // Time since last uuid creation (in msecs)\n var dt = (msecs - _lastMSecs) + (nsecs - _lastNSecs)/10000;\n\n // Per 4.2.1.2, Bump clockseq on clock regression\n if (dt < 0 && options.clockseq === undefined) {\n clockseq = clockseq + 1 & 0x3fff;\n }\n\n // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new\n // time interval\n if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {\n nsecs = 0;\n }\n\n // Per 4.2.1.2 Throw error if too many uuids are requested\n if (nsecs >= 10000) {\n throw new Error('uuid.v1(): Can\\'t create more than 10M uuids/sec');\n }\n\n _lastMSecs = msecs;\n _lastNSecs = nsecs;\n _clockseq = clockseq;\n\n // Per 4.1.4 - Convert from unix epoch to Gregorian epoch\n msecs += 12219292800000;\n\n // `time_low`\n var tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;\n b[i++] = tl >>> 24 & 0xff;\n b[i++] = tl >>> 16 & 0xff;\n b[i++] = tl >>> 8 & 0xff;\n b[i++] = tl & 0xff;\n\n // `time_mid`\n var tmh = (msecs / 0x100000000 * 10000) & 0xfffffff;\n b[i++] = tmh >>> 8 & 0xff;\n b[i++] = tmh & 0xff;\n\n // `time_high_and_version`\n b[i++] = tmh >>> 24 & 0xf | 0x10; // include version\n b[i++] = tmh >>> 16 & 0xff;\n\n // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)\n b[i++] = clockseq >>> 8 | 0x80;\n\n // `clock_seq_low`\n b[i++] = clockseq & 0xff;\n\n // `node`\n for (var n = 0; n < 6; ++n) {\n b[i + n] = node[n];\n }\n\n return buf ? buf : bytesToUuid(b);\n}\n\nmodule.exports = v1;\n","var rng = require('./lib/rng');\nvar bytesToUuid = require('./lib/bytesToUuid');\n\nfunction v4(options, buf, offset) {\n var i = buf && offset || 0;\n\n if (typeof(options) == 'string') {\n buf = options === 'binary' ? new Array(16) : null;\n options = null;\n }\n options = options || {};\n\n var rnds = options.random || (options.rng || rng)();\n\n // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n rnds[6] = (rnds[6] & 0x0f) | 0x40;\n rnds[8] = (rnds[8] & 0x3f) | 0x80;\n\n // Copy bytes to buffer, if provided\n if (buf) {\n for (var ii = 0; ii < 16; ++ii) {\n buf[i + ii] = rnds[ii];\n }\n }\n\n return buf || bytesToUuid(rnds);\n}\n\nmodule.exports = v4;\n","/* eslint-env browser */\n\n/**\n * This is the web browser implementation of `debug()`.\n */\n\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = localstorage();\nexports.destroy = (() => {\n\tlet warned = false;\n\n\treturn () => {\n\t\tif (!warned) {\n\t\t\twarned = true;\n\t\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t\t}\n\t};\n})();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n\t'#0000CC',\n\t'#0000FF',\n\t'#0033CC',\n\t'#0033FF',\n\t'#0066CC',\n\t'#0066FF',\n\t'#0099CC',\n\t'#0099FF',\n\t'#00CC00',\n\t'#00CC33',\n\t'#00CC66',\n\t'#00CC99',\n\t'#00CCCC',\n\t'#00CCFF',\n\t'#3300CC',\n\t'#3300FF',\n\t'#3333CC',\n\t'#3333FF',\n\t'#3366CC',\n\t'#3366FF',\n\t'#3399CC',\n\t'#3399FF',\n\t'#33CC00',\n\t'#33CC33',\n\t'#33CC66',\n\t'#33CC99',\n\t'#33CCCC',\n\t'#33CCFF',\n\t'#6600CC',\n\t'#6600FF',\n\t'#6633CC',\n\t'#6633FF',\n\t'#66CC00',\n\t'#66CC33',\n\t'#9900CC',\n\t'#9900FF',\n\t'#9933CC',\n\t'#9933FF',\n\t'#99CC00',\n\t'#99CC33',\n\t'#CC0000',\n\t'#CC0033',\n\t'#CC0066',\n\t'#CC0099',\n\t'#CC00CC',\n\t'#CC00FF',\n\t'#CC3300',\n\t'#CC3333',\n\t'#CC3366',\n\t'#CC3399',\n\t'#CC33CC',\n\t'#CC33FF',\n\t'#CC6600',\n\t'#CC6633',\n\t'#CC9900',\n\t'#CC9933',\n\t'#CCCC00',\n\t'#CCCC33',\n\t'#FF0000',\n\t'#FF0033',\n\t'#FF0066',\n\t'#FF0099',\n\t'#FF00CC',\n\t'#FF00FF',\n\t'#FF3300',\n\t'#FF3333',\n\t'#FF3366',\n\t'#FF3399',\n\t'#FF33CC',\n\t'#FF33FF',\n\t'#FF6600',\n\t'#FF6633',\n\t'#FF9900',\n\t'#FF9933',\n\t'#FFCC00',\n\t'#FFCC33'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\n// eslint-disable-next-line complexity\nfunction useColors() {\n\t// NB: In an Electron preload script, document will be defined but not fully\n\t// initialized. Since we know we're in Chrome, we'll just detect this case\n\t// explicitly\n\tif (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n\t\treturn true;\n\t}\n\n\t// Internet Explorer and Edge do not support colors.\n\tif (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n\t\treturn false;\n\t}\n\n\t// Is webkit? http://stackoverflow.com/a/16459606/376773\n\t// document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n\treturn (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n\t\t// Is firebug? http://stackoverflow.com/a/398120/376773\n\t\t(typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n\t\t// Is firefox >= v31?\n\t\t// https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/) && parseInt(RegExp.$1, 10) >= 31) ||\n\t\t// Double check webkit in userAgent just in case we are in a worker\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\targs[0] = (this.useColors ? '%c' : '') +\n\t\tthis.namespace +\n\t\t(this.useColors ? ' %c' : ' ') +\n\t\targs[0] +\n\t\t(this.useColors ? '%c ' : ' ') +\n\t\t'+' + module.exports.humanize(this.diff);\n\n\tif (!this.useColors) {\n\t\treturn;\n\t}\n\n\tconst c = 'color: ' + this.color;\n\targs.splice(1, 0, c, 'color: inherit');\n\n\t// The final \"%c\" is somewhat tricky, because there could be other\n\t// arguments passed either before or after the %c, so we need to\n\t// figure out the correct index to insert the CSS into\n\tlet index = 0;\n\tlet lastC = 0;\n\targs[0].replace(/%[a-zA-Z%]/g, match => {\n\t\tif (match === '%%') {\n\t\t\treturn;\n\t\t}\n\t\tindex++;\n\t\tif (match === '%c') {\n\t\t\t// We only are interested in the *last* %c\n\t\t\t// (the user may have provided their own)\n\t\t\tlastC = index;\n\t\t}\n\t});\n\n\targs.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.debug()` when available.\n * No-op when `console.debug` is not a \"function\".\n * If `console.debug` is not available, falls back\n * to `console.log`.\n *\n * @api public\n */\nexports.log = console.debug || console.log || (() => {});\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\ttry {\n\t\tif (namespaces) {\n\t\t\texports.storage.setItem('debug', namespaces);\n\t\t} else {\n\t\t\texports.storage.removeItem('debug');\n\t\t}\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n\tlet r;\n\ttry {\n\t\tr = exports.storage.getItem('debug');\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n\n\t// If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n\tif (!r && typeof process !== 'undefined' && 'env' in process) {\n\t\tr = process.env.DEBUG;\n\t}\n\n\treturn r;\n}\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n\ttry {\n\t\t// TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n\t\t// The Browser also has localStorage in the global context.\n\t\treturn localStorage;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nformatters.j = function (v) {\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch (error) {\n\t\treturn '[UnexpectedJSONParseError]: ' + error.message;\n\t}\n};\n","\n/**\n * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n */\n\nfunction setup(env) {\n\tcreateDebug.debug = createDebug;\n\tcreateDebug.default = createDebug;\n\tcreateDebug.coerce = coerce;\n\tcreateDebug.disable = disable;\n\tcreateDebug.enable = enable;\n\tcreateDebug.enabled = enabled;\n\tcreateDebug.humanize = require('ms');\n\tcreateDebug.destroy = destroy;\n\n\tObject.keys(env).forEach(key => {\n\t\tcreateDebug[key] = env[key];\n\t});\n\n\t/**\n\t* The currently active debug mode names, and names to skip.\n\t*/\n\n\tcreateDebug.names = [];\n\tcreateDebug.skips = [];\n\n\t/**\n\t* Map of special \"%n\" handling functions, for the debug \"format\" argument.\n\t*\n\t* Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n\t*/\n\tcreateDebug.formatters = {};\n\n\t/**\n\t* Selects a color for a debug namespace\n\t* @param {String} namespace The namespace string for the debug instance to be colored\n\t* @return {Number|String} An ANSI color code for the given namespace\n\t* @api private\n\t*/\n\tfunction selectColor(namespace) {\n\t\tlet hash = 0;\n\n\t\tfor (let i = 0; i < namespace.length; i++) {\n\t\t\thash = ((hash << 5) - hash) + namespace.charCodeAt(i);\n\t\t\thash |= 0; // Convert to 32bit integer\n\t\t}\n\n\t\treturn createDebug.colors[Math.abs(hash) % createDebug.colors.length];\n\t}\n\tcreateDebug.selectColor = selectColor;\n\n\t/**\n\t* Create a debugger with the given `namespace`.\n\t*\n\t* @param {String} namespace\n\t* @return {Function}\n\t* @api public\n\t*/\n\tfunction createDebug(namespace) {\n\t\tlet prevTime;\n\t\tlet enableOverride = null;\n\t\tlet namespacesCache;\n\t\tlet enabledCache;\n\n\t\tfunction debug(...args) {\n\t\t\t// Disabled?\n\t\t\tif (!debug.enabled) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst self = debug;\n\n\t\t\t// Set `diff` timestamp\n\t\t\tconst curr = Number(new Date());\n\t\t\tconst ms = curr - (prevTime || curr);\n\t\t\tself.diff = ms;\n\t\t\tself.prev = prevTime;\n\t\t\tself.curr = curr;\n\t\t\tprevTime = curr;\n\n\t\t\targs[0] = createDebug.coerce(args[0]);\n\n\t\t\tif (typeof args[0] !== 'string') {\n\t\t\t\t// Anything else let's inspect with %O\n\t\t\t\targs.unshift('%O');\n\t\t\t}\n\n\t\t\t// Apply any `formatters` transformations\n\t\t\tlet index = 0;\n\t\t\targs[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => {\n\t\t\t\t// If we encounter an escaped % then don't increase the array index\n\t\t\t\tif (match === '%%') {\n\t\t\t\t\treturn '%';\n\t\t\t\t}\n\t\t\t\tindex++;\n\t\t\t\tconst formatter = createDebug.formatters[format];\n\t\t\t\tif (typeof formatter === 'function') {\n\t\t\t\t\tconst val = args[index];\n\t\t\t\t\tmatch = formatter.call(self, val);\n\n\t\t\t\t\t// Now we need to remove `args[index]` since it's inlined in the `format`\n\t\t\t\t\targs.splice(index, 1);\n\t\t\t\t\tindex--;\n\t\t\t\t}\n\t\t\t\treturn match;\n\t\t\t});\n\n\t\t\t// Apply env-specific formatting (colors, etc.)\n\t\t\tcreateDebug.formatArgs.call(self, args);\n\n\t\t\tconst logFn = self.log || createDebug.log;\n\t\t\tlogFn.apply(self, args);\n\t\t}\n\n\t\tdebug.namespace = namespace;\n\t\tdebug.useColors = createDebug.useColors();\n\t\tdebug.color = createDebug.selectColor(namespace);\n\t\tdebug.extend = extend;\n\t\tdebug.destroy = createDebug.destroy; // XXX Temporary. Will be removed in the next major release.\n\n\t\tObject.defineProperty(debug, 'enabled', {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: false,\n\t\t\tget: () => {\n\t\t\t\tif (enableOverride !== null) {\n\t\t\t\t\treturn enableOverride;\n\t\t\t\t}\n\t\t\t\tif (namespacesCache !== createDebug.namespaces) {\n\t\t\t\t\tnamespacesCache = createDebug.namespaces;\n\t\t\t\t\tenabledCache = createDebug.enabled(namespace);\n\t\t\t\t}\n\n\t\t\t\treturn enabledCache;\n\t\t\t},\n\t\t\tset: v => {\n\t\t\t\tenableOverride = v;\n\t\t\t}\n\t\t});\n\n\t\t// Env-specific initialization logic for debug instances\n\t\tif (typeof createDebug.init === 'function') {\n\t\t\tcreateDebug.init(debug);\n\t\t}\n\n\t\treturn debug;\n\t}\n\n\tfunction extend(namespace, delimiter) {\n\t\tconst newDebug = createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace);\n\t\tnewDebug.log = this.log;\n\t\treturn newDebug;\n\t}\n\n\t/**\n\t* Enables a debug mode by namespaces. This can include modes\n\t* separated by a colon and wildcards.\n\t*\n\t* @param {String} namespaces\n\t* @api public\n\t*/\n\tfunction enable(namespaces) {\n\t\tcreateDebug.save(namespaces);\n\t\tcreateDebug.namespaces = namespaces;\n\n\t\tcreateDebug.names = [];\n\t\tcreateDebug.skips = [];\n\n\t\tlet i;\n\t\tconst split = (typeof namespaces === 'string' ? namespaces : '').split(/[\\s,]+/);\n\t\tconst len = split.length;\n\n\t\tfor (i = 0; i < len; i++) {\n\t\t\tif (!split[i]) {\n\t\t\t\t// ignore empty strings\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tnamespaces = split[i].replace(/\\*/g, '.*?');\n\n\t\t\tif (namespaces[0] === '-') {\n\t\t\t\tcreateDebug.skips.push(new RegExp('^' + namespaces.substr(1) + '$'));\n\t\t\t} else {\n\t\t\t\tcreateDebug.names.push(new RegExp('^' + namespaces + '$'));\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t* Disable debug output.\n\t*\n\t* @return {String} namespaces\n\t* @api public\n\t*/\n\tfunction disable() {\n\t\tconst namespaces = [\n\t\t\t...createDebug.names.map(toNamespace),\n\t\t\t...createDebug.skips.map(toNamespace).map(namespace => '-' + namespace)\n\t\t].join(',');\n\t\tcreateDebug.enable('');\n\t\treturn namespaces;\n\t}\n\n\t/**\n\t* Returns true if the given mode name is enabled, false otherwise.\n\t*\n\t* @param {String} name\n\t* @return {Boolean}\n\t* @api public\n\t*/\n\tfunction enabled(name) {\n\t\tif (name[name.length - 1] === '*') {\n\t\t\treturn true;\n\t\t}\n\n\t\tlet i;\n\t\tlet len;\n\n\t\tfor (i = 0, len = createDebug.skips.length; i < len; i++) {\n\t\t\tif (createDebug.skips[i].test(name)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\tfor (i = 0, len = createDebug.names.length; i < len; i++) {\n\t\t\tif (createDebug.names[i].test(name)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t* Convert regexp to namespace\n\t*\n\t* @param {RegExp} regxep\n\t* @return {String} namespace\n\t* @api private\n\t*/\n\tfunction toNamespace(regexp) {\n\t\treturn regexp.toString()\n\t\t\t.substring(2, regexp.toString().length - 2)\n\t\t\t.replace(/\\.\\*\\?$/, '*');\n\t}\n\n\t/**\n\t* Coerce `val`.\n\t*\n\t* @param {Mixed} val\n\t* @return {Mixed}\n\t* @api private\n\t*/\n\tfunction coerce(val) {\n\t\tif (val instanceof Error) {\n\t\t\treturn val.stack || val.message;\n\t\t}\n\t\treturn val;\n\t}\n\n\t/**\n\t* XXX DO NOT USE. This is a temporary stub function.\n\t* XXX It WILL be removed in the next major release.\n\t*/\n\tfunction destroy() {\n\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t}\n\n\tcreateDebug.enable(createDebug.load());\n\n\treturn createDebug;\n}\n\nmodule.exports = setup;\n","/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function(val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isFinite(val)) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (msAbs >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (msAbs >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (msAbs >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n var isPlural = msAbs >= n * 1.5;\n return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","declare const PACKAGE_VERSION: string;\r\nexport const version = PACKAGE_VERSION;\r\n\r\n/**\r\n * @hidden\r\n * The client version when all SDK APIs started to check platform compatibility for the APIs was 1.6.0.\r\n * Modified to 2.0.1 which is hightest till now so that if any client doesn't pass version in initialize function, it will be set to highest.\r\n * Mobile clients are passing versions, hence will be applicable to web and desktop clients only.\r\n *\r\n * @internal\r\n */\r\nexport const defaultSDKVersionForCompatCheck = '2.0.1';\r\n\r\n/**\r\n * @hidden\r\n * This is the client version when selectMedia API - VideoAndImage is supported on mobile.\r\n *\r\n * @internal\r\n */\r\nexport const videoAndImageMediaAPISupportVersion = '2.0.2';\r\n\r\n/**\r\n * This is the client version when selectMedia API - Video with non-full screen mode is supported on mobile.\r\n */\r\nexport const nonFullScreenVideoModeAPISupportVersion = '2.0.3';\r\n\r\n/**\r\n * This is the client version when selectMedia API - ImageOutputFormats is supported on mobile.\r\n */\r\nexport const imageOutputFormatsAPISupportVersion = '2.0.4';\r\n\r\n/**\r\n * @hidden\r\n * Minimum required client supported version for {@link getUserJoinedTeams} to be supported on {@link HostClientType.android}\r\n *\r\n * @internal\r\n */\r\nexport const getUserJoinedTeamsSupportedAndroidClientVersion = '2.0.1';\r\n\r\n/**\r\n * @hidden\r\n * This is the client version when location APIs (getLocation and showLocation) are supported.\r\n *\r\n * @internal\r\n */\r\nexport const locationAPIsRequiredVersion = '1.9.0';\r\n\r\n/**\r\n * @hidden\r\n * This is the client version when people picker API is supported on mobile.\r\n *\r\n * @internal\r\n */\r\nexport const peoplePickerRequiredVersion = '2.0.0';\r\n\r\n/**\r\n * @hidden\r\n * This is the client version when captureImage API is supported on mobile.\r\n *\r\n * @internal\r\n */\r\nexport const captureImageMobileSupportVersion = '1.7.0';\r\n\r\n/**\r\n * @hidden\r\n * This is the client version when media APIs are supported on all three platforms ios, android and web.\r\n *\r\n * @internal\r\n */\r\nexport const mediaAPISupportVersion = '1.8.0';\r\n\r\n/**\r\n * @hidden\r\n * This is the client version when getMedia API is supported via Callbacks on all three platforms ios, android and web.\r\n *\r\n * @internal\r\n */\r\nexport const getMediaCallbackSupportVersion = '2.0.0';\r\n\r\n/**\r\n * @hidden\r\n * This is the client version when scanBarCode API is supported on mobile.\r\n *\r\n * @internal\r\n */\r\nexport const scanBarCodeAPIMobileSupportVersion = '1.9.0';\r\n\r\n/**\r\n * @hidden\r\n * List of supported Host origins\r\n *\r\n * @internal\r\n */\r\nexport const validOrigins = [\r\n 'teams.microsoft.com',\r\n 'teams.microsoft.us',\r\n 'gov.teams.microsoft.us',\r\n 'dod.teams.microsoft.us',\r\n 'int.teams.microsoft.com',\r\n 'teams.live.com',\r\n 'devspaces.skype.com',\r\n 'ssauth.skype.com',\r\n 'local.teams.live.com', // local development\r\n 'local.teams.live.com:8080', // local development\r\n 'local.teams.office.com', // local development\r\n 'local.teams.office.com:8080', // local development\r\n 'msft.spoppe.com',\r\n '*.sharepoint.com',\r\n '*.sharepoint-df.com',\r\n '*.sharepointonline.com',\r\n 'outlook.office.com',\r\n 'outlook-sdf.office.com',\r\n '*.teams.microsoft.com',\r\n 'www.office.com',\r\n 'word.office.com',\r\n 'excel.office.com',\r\n 'powerpoint.office.com',\r\n 'www.officeppe.com',\r\n '*.www.office.com',\r\n];\r\n\r\n/**\r\n * @hidden\r\n * USer specified message origins should satisfy this test\r\n *\r\n * @internal\r\n */\r\nexport const userOriginUrlValidationRegExp = /^https:\\/\\//;\r\n","export enum HostClientType {\r\n desktop = 'desktop',\r\n web = 'web',\r\n android = 'android',\r\n ios = 'ios',\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link teamsRoomsWindows} instead.\r\n */\r\n rigel = 'rigel',\r\n surfaceHub = 'surfaceHub',\r\n teamsRoomsWindows = 'teamsRoomsWindows',\r\n teamsRoomsAndroid = 'teamsRoomsAndroid',\r\n teamsPhones = 'teamsPhones',\r\n teamsDisplays = 'teamsDisplays',\r\n}\r\n\r\nexport enum HostName {\r\n office = 'Office',\r\n outlook = 'Outlook',\r\n orange = 'Orange',\r\n teams = 'Teams',\r\n}\r\n\r\n// Ensure these declarations stay in sync with the framework.\r\nexport enum FrameContexts {\r\n settings = 'settings',\r\n content = 'content',\r\n authentication = 'authentication',\r\n remove = 'remove',\r\n task = 'task',\r\n sidePanel = 'sidePanel',\r\n stage = 'stage',\r\n meetingStage = 'meetingStage',\r\n}\r\n\r\n/**\r\n * Indicates the team type, currently used to distinguish between different team\r\n * types in Office 365 for Education (team types 1, 2, 3, and 4).\r\n */\r\nexport enum TeamType {\r\n Standard = 0,\r\n Edu = 1,\r\n Class = 2,\r\n Plc = 3,\r\n Staff = 4,\r\n}\r\n\r\n/**\r\n * Indicates the various types of roles of a user in a team.\r\n */\r\nexport enum UserTeamRole {\r\n Admin = 0,\r\n User = 1,\r\n Guest = 2,\r\n}\r\n\r\n/**\r\n * Dialog module dimension enum\r\n */\r\nexport enum DialogDimension {\r\n Large = 'large',\r\n Medium = 'medium',\r\n Small = 'small',\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link DialogDimension} instead.\r\n */\r\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\r\nexport import TaskModuleDimension = DialogDimension;\r\n\r\n/**\r\n * The type of the channel with which the content is associated.\r\n */\r\nexport enum ChannelType {\r\n Regular = 'Regular',\r\n Private = 'Private',\r\n Shared = 'Shared',\r\n}\r\n","import { FrameContexts } from '../public';\r\nexport class GlobalVars {\r\n public static initializeCalled = false;\r\n public static initializeCompleted = false;\r\n public static additionalValidOrigins: string[] = [];\r\n public static initializePromise: Promise<void>;\r\n public static isFramelessWindow = false;\r\n public static frameContext: FrameContexts;\r\n public static hostClientType: string;\r\n public static clientSupportedSDKVersion: string;\r\n public static printCapabilityEnabled = false;\r\n}\r\n","/* eslint-disable @typescript-eslint/no-explicit-any*/\r\n\r\nimport { ChannelType, DialogDimension, HostClientType, HostName, TeamType, UserTeamRole } from './constants';\r\nimport { FrameContexts } from './constants';\r\n\r\n/**\r\n * Represents information about tabs for an app\r\n *\r\n * @alpha\r\n */\r\nexport interface TabInformation {\r\n teamTabs: TabInstance[];\r\n}\r\n\r\n/**\r\n * Represents information about a tab instance\r\n */\r\nexport interface TabInstance {\r\n /**\r\n * The name of the tab\r\n */\r\n tabName: string;\r\n\r\n /**\r\n * @internal\r\n * @protected\r\n */\r\n internalTabInstanceId?: string;\r\n\r\n /**\r\n * Last viewed time of this tab. null means unknown\r\n */\r\n lastViewUnixEpochTime?: string;\r\n\r\n /**\r\n * The developer-defined unique ID for the entity this content points to.\r\n */\r\n entityId?: string;\r\n\r\n /**\r\n * The Microsoft Teams ID for the channel with which the content is associated.\r\n */\r\n channelId?: string;\r\n\r\n /**\r\n * The name for the channel with which the content is associated.\r\n */\r\n channelName?: string;\r\n\r\n /**\r\n * Is this tab in a favorite channel?\r\n */\r\n channelIsFavorite?: boolean;\r\n\r\n /**\r\n * The Microsoft Teams ID for the team with which the content is associated.\r\n */\r\n teamId?: string;\r\n\r\n /**\r\n * The name for the team with which the content is associated.\r\n */\r\n teamName?: string;\r\n\r\n /**\r\n * Is this tab in a favorite team?\r\n */\r\n teamIsFavorite?: boolean;\r\n\r\n /**\r\n * The Office 365 group ID for the team with which the content is associated.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n groupId?: string;\r\n\r\n /**\r\n * Content URL of this tab\r\n */\r\n url?: string;\r\n\r\n /**\r\n * Website URL of this tab\r\n */\r\n websiteUrl?: string;\r\n}\r\n\r\n/**\r\n * Indicates information about the tab instance for filtering purposes.\r\n */\r\nexport interface TabInstanceParameters {\r\n /**\r\n * Flag allowing to select favorite channels only\r\n */\r\n favoriteChannelsOnly?: boolean;\r\n\r\n /**\r\n * Flag allowing to select favorite teams only\r\n */\r\n favoriteTeamsOnly?: boolean;\r\n}\r\n\r\n/**\r\n * Represents Team Information\r\n */\r\nexport interface TeamInformation {\r\n /**\r\n * Id of the team\r\n */\r\n teamId: string;\r\n\r\n /**\r\n * Team display name\r\n */\r\n teamName: string;\r\n\r\n /**\r\n * Team description\r\n */\r\n teamDescription?: string;\r\n\r\n /**\r\n * Thumbnail Uri\r\n */\r\n thumbnailUri?: string;\r\n\r\n /**\r\n * The Office 365 group ID for the team with which the content is associated.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n groupId?: string;\r\n\r\n /**\r\n * Role of current user in the team\r\n */\r\n userTeamRole?: UserTeamRole;\r\n\r\n /**\r\n * The type of the team.\r\n */\r\n teamType?: TeamType;\r\n\r\n /**\r\n * The locked status of the team\r\n */\r\n isTeamLocked?: boolean;\r\n\r\n /**\r\n * The archived status of the team\r\n */\r\n isTeamArchived?: boolean;\r\n}\r\n\r\n/**\r\n * Represents OS locale info used for formatting date and time data\r\n */\r\nexport interface LocaleInfo {\r\n platform: 'windows' | 'macos';\r\n regionalFormat: string;\r\n shortDate: string;\r\n longDate: string;\r\n shortTime: string;\r\n longTime: string;\r\n}\r\n\r\n/**\r\n * Allowed user file open preferences\r\n */\r\nexport enum FileOpenPreference {\r\n Inline = 'inline',\r\n Desktop = 'desktop',\r\n Web = 'web',\r\n}\r\n\r\nexport interface Context {\r\n /**\r\n * @hidden\r\n * The Office 365 group ID for the team with which the content is associated.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n groupId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The Microsoft Teams ID for the team with which the content is associated.\r\n */\r\n teamId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The name for the team with which the content is associated.\r\n */\r\n teamName?: string;\r\n\r\n /**\r\n * @hidden\r\n * The Microsoft Teams ID for the channel with which the content is associated.\r\n */\r\n channelId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The name for the channel with which the content is associated.\r\n */\r\n channelName?: string;\r\n\r\n /**\r\n * @hidden\r\n * The type of the channel with which the content is associated.\r\n */\r\n channelType?: ChannelType;\r\n\r\n /**\r\n * @hidden\r\n * The developer-defined unique ID for the entity this content points to.\r\n */\r\n entityId: string;\r\n\r\n /**\r\n * @hidden\r\n * The developer-defined unique ID for the sub-entity this content points to.\r\n * This field should be used to restore to a specific state within an entity,\r\n * such as scrolling to or activating a specific piece of content.\r\n */\r\n subEntityId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The current locale that the user has configured for the app formatted as\r\n * languageId-countryId (for example, en-us).\r\n */\r\n locale: string;\r\n\r\n /**\r\n * @hidden\r\n * More detailed locale info from the user's OS if available. Can be used together with\r\n * the @microsoft/globe NPM package to ensure your app respects the user's OS date and\r\n * time format configuration\r\n */\r\n osLocaleInfo?: LocaleInfo;\r\n\r\n /**\r\n * @hidden\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link loginHint} or {@link userPrincipalName} instead.\r\n * The UPN of the current user.\r\n * Because a malicious party can run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n upn?: string;\r\n\r\n /**\r\n * @hidden\r\n * The Azure AD tenant ID of the current user.\r\n * Because a malicious party can run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n tid?: string;\r\n\r\n /**\r\n * @hidden\r\n * The current UI theme.\r\n */\r\n theme?: string;\r\n\r\n /**\r\n * @hidden\r\n * Indication whether the tab is in full-screen mode.\r\n */\r\n isFullScreen?: boolean;\r\n\r\n /**\r\n * @hidden\r\n * The type of the team.\r\n */\r\n teamType?: TeamType;\r\n\r\n /**\r\n * @hidden\r\n * The root SharePoint site associated with the team.\r\n */\r\n teamSiteUrl?: string;\r\n\r\n /**\r\n * @hidden\r\n * The domain of the root SharePoint site associated with the team.\r\n */\r\n teamSiteDomain?: string;\r\n\r\n /**\r\n * @hidden\r\n * The relative path to the SharePoint site associated with the team.\r\n */\r\n teamSitePath?: string;\r\n\r\n /**\r\n * @hidden\r\n * The tenant ID of the host team.\r\n */\r\n hostTeamTenantId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The AAD group ID of the host team.\r\n */\r\n hostTeamGroupId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The relative path to the SharePoint folder associated with the channel.\r\n */\r\n channelRelativeUrl?: string;\r\n\r\n /**\r\n * @hidden\r\n * Unique ID for the current Teams session for use in correlating telemetry data.\r\n */\r\n sessionId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The user's role in the team.\r\n * Because a malicious party can run your content in a browser, this value should\r\n * be used only as a hint as to the user's role, and never as proof of her role.\r\n */\r\n userTeamRole?: UserTeamRole;\r\n\r\n /**\r\n * @hidden\r\n * The Microsoft Teams ID for the chat with which the content is associated.\r\n */\r\n chatId?: string;\r\n\r\n /**\r\n * @hidden\r\n * A value suitable for use as a login_hint when authenticating with Azure AD.\r\n * Because a malicious party can run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n loginHint?: string;\r\n\r\n /**\r\n * @hidden\r\n * The UPN of the current user. This may be an externally-authenticated UPN (e.g., guest users).\r\n * Because a malicious party run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n userPrincipalName?: string;\r\n\r\n /**\r\n * @hidden\r\n * The Azure AD object id of the current user.\r\n * Because a malicious party run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n userObjectId?: string;\r\n\r\n /**\r\n * @hidden\r\n * Indicates whether team is archived.\r\n * Apps should use this as a signal to prevent any changes to content associated with archived teams.\r\n */\r\n isTeamArchived?: boolean;\r\n\r\n /**\r\n * @hidden\r\n * The name of the host client. Possible values are: Office, Orange, Outlook, Teams\r\n */\r\n hostName?: HostName;\r\n\r\n /**\r\n * @hidden\r\n * The type of the host client. Possible values are : android, ios, web, desktop, rigel (deprecated, use teamsRoomsWindows instead),\r\n * teamsRoomsWindows, teamsRoomsAndroid, teamsPhones, teamsDisplays\r\n */\r\n hostClientType?: HostClientType;\r\n\r\n /**\r\n * @hidden\r\n * The context where tab url is loaded (content, task, setting, remove, sidePanel)\r\n */\r\n frameContext?: FrameContexts;\r\n\r\n /**\r\n * @hidden\r\n * SharePoint context. This is only available when hosted in SharePoint.\r\n */\r\n sharepoint?: any;\r\n\r\n /**\r\n * @hidden\r\n * The type of license for the current users tenant.\r\n */\r\n tenantSKU?: string;\r\n\r\n /**\r\n * @hidden\r\n * The license type for the current user.\r\n */\r\n userLicenseType?: string;\r\n\r\n /**\r\n * @hidden\r\n * The ID of the parent message from which this task module was launched.\r\n * This is only available in task modules launched from bot cards.\r\n */\r\n parentMessageId?: string;\r\n\r\n /**\r\n * @hidden\r\n * Current ring ID\r\n */\r\n ringId?: string;\r\n\r\n /**\r\n * @hidden\r\n * Unique ID for the current session for use in correlating telemetry data.\r\n */\r\n appSessionId?: string;\r\n\r\n /**\r\n * @hidden\r\n * ID for the current visible app which is different for across cached sessions. Used for correlating telemetry data``\r\n */\r\n appLaunchId?: string;\r\n\r\n /**\r\n * @hidden\r\n * Represents whether calling is allowed for the current logged in User\r\n */\r\n isCallingAllowed?: boolean;\r\n\r\n /**\r\n * @hidden\r\n * Represents whether PSTN calling is allowed for the current logged in User\r\n */\r\n isPSTNCallingAllowed?: boolean;\r\n\r\n /**\r\n * @hidden\r\n * Meeting Id used by tab when running in meeting context\r\n */\r\n meetingId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The OneNote section ID that is linked to the channel.\r\n */\r\n defaultOneNoteSectionId?: string;\r\n\r\n /**\r\n * @hidden\r\n * Indication whether the tab is in a pop out window\r\n */\r\n isMultiWindow?: boolean;\r\n\r\n /**\r\n * @hidden\r\n * Personal app icon y coordinate position\r\n */\r\n appIconPosition?: number;\r\n\r\n /**\r\n * @hidden\r\n * Source origin from where the tab is opened\r\n */\r\n sourceOrigin?: string;\r\n\r\n /**\r\n * @hidden\r\n * Time when the user clicked on the tab\r\n */\r\n userClickTime?: number;\r\n\r\n /**\r\n * @hidden\r\n * Team Template ID if there was a Team Template associated with the creation of the team.\r\n */\r\n teamTemplateId?: string;\r\n\r\n /**\r\n * @hidden\r\n * Where the user prefers the file to be opened from by default during file open\r\n */\r\n userFileOpenPreference?: FileOpenPreference;\r\n\r\n /**\r\n * @hidden\r\n * The address book name of the current user.\r\n */\r\n userDisplayName?: string;\r\n\r\n /**\r\n * @hidden\r\n * Teamsite ID, aka sharepoint site id.\r\n */\r\n teamSiteId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The SharePoint my site domain associated with the user.\r\n */\r\n mySiteDomain?: string;\r\n\r\n /**\r\n * @hidden\r\n * The SharePoint relative path to the current users mysite\r\n */\r\n mySitePath?: string;\r\n}\r\n\r\nexport interface DeepLinkParameters {\r\n /**\r\n * The developer-defined unique ID for the sub-entity to which this deep link points in the current entity.\r\n * This field should be used to restore to a specific state within an entity, such as scrolling to or activating a specific piece of content.\r\n */\r\n subEntityId: string;\r\n\r\n /**\r\n * The label for the sub-entity that should be displayed when the deep link is rendered in a client.\r\n */\r\n subEntityLabel: string;\r\n\r\n /**\r\n * The fallback URL to which to navigate the user if the client cannot render the page.\r\n * This URL should lead directly to the sub-entity.\r\n */\r\n subEntityWebUrl?: string;\r\n}\r\n\r\nexport interface DialogInfo {\r\n /**\r\n * The url to be rendered in the webview/iframe.\r\n */\r\n url?: string;\r\n\r\n /**\r\n * JSON defining an adaptive card.\r\n */\r\n card?: string;\r\n\r\n /**\r\n * The requested height of the webview/iframe.\r\n */\r\n height?: DialogDimension | number;\r\n\r\n /**\r\n * The requested width of the webview/iframe.\r\n */\r\n width?: DialogDimension | number;\r\n\r\n /**\r\n * Title of the task module.\r\n */\r\n title?: string;\r\n\r\n /**\r\n * If client doesnt support the URL, the URL that needs to be opened in the browser.\r\n */\r\n fallbackUrl?: string;\r\n\r\n /**\r\n * Specifies a bot ID to send the result of the user's interaction with the task module.\r\n * If specified, the bot will receive a task/complete invoke event with a JSON object\r\n * in the event payload.\r\n */\r\n completionBotId?: string;\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link DialogInfo} instead.\r\n */\r\nexport type TaskInfo = DialogInfo;\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n *\r\n * @internal\r\n */\r\nexport interface OpenConversationRequest {\r\n /**\r\n * @hidden\r\n * The Id of the subEntity where the conversation is taking place\r\n */\r\n subEntityId: string;\r\n\r\n /**\r\n * @hidden\r\n * The title of the conversation\r\n */\r\n title: string;\r\n\r\n /**\r\n * @hidden\r\n * The Id of the conversation. This is optional and should be specified whenever a previous conversation about a specific sub-entity has already been started before\r\n */\r\n conversationId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The Id of the channel. This is optional and should be specified whenever a conversation is started or opened in a personal app scope\r\n */\r\n channelId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The entity Id of the tab\r\n */\r\n entityId: string;\r\n\r\n /**\r\n * @hidden\r\n * A function that is called once the conversation Id has been created\r\n */\r\n onStartConversation?: (conversationResponse: ConversationResponse) => void;\r\n\r\n /**\r\n * @hidden\r\n * A function that is called if the pane is closed\r\n */\r\n onCloseConversation?: (conversationResponse: ConversationResponse) => void;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n *\r\n * @internal\r\n */\r\nexport interface ConversationResponse {\r\n /**\r\n * @hidden\r\n * The Id of the subEntity where the conversation is taking place\r\n */\r\n subEntityId: string;\r\n\r\n /**\r\n * @hidden\r\n * The Id of the conversation. This is optional and should be specified whenever a previous conversation about a specific sub-entity has already been started before\r\n */\r\n conversationId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The Id of the channel. This is optional and should be specified whenever a conversation is started or opened in a personal app scope\r\n */\r\n channelId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The entity Id of the tab\r\n */\r\n entityId?: string;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs.\r\n *\r\n * @internal\r\n */\r\nexport interface LoadContext {\r\n /**\r\n * @hidden\r\n * The entity that is requested to be loaded\r\n */\r\n entityId: string;\r\n\r\n /**\r\n * @hidden\r\n * The content URL that is requested to be loaded\r\n */\r\n contentUrl: string;\r\n}\r\n\r\nexport interface FrameInfo {\r\n /**\r\n * The current URL that needs to be used in the iframe if the tab is reloaded\r\n */\r\n contentUrl: string;\r\n\r\n /**\r\n * The current URL that needs to be used for opening the website when the user clicks on 'Go to website'\r\n */\r\n websiteUrl: string;\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link FrameInfo} instead.\r\n */\r\nexport type FrameContext = FrameInfo;\r\n\r\nexport interface SdkError {\r\n /**\r\n error code\r\n */\r\n errorCode: ErrorCode;\r\n /**\r\n Optional description for the error. This may contain useful information for web-app developers.\r\n This string will not be localized and is not for end-user consumption. \r\n App should not depend on the string content. The exact value may change. This is only for debugging purposes.\r\n */\r\n message?: string;\r\n}\r\n\r\nexport enum ErrorCode {\r\n /**\r\n * API not supported in the current platform.\r\n */\r\n NOT_SUPPORTED_ON_PLATFORM = 100,\r\n /**\r\n * Internal error encountered while performing the required operation.\r\n */\r\n INTERNAL_ERROR = 500,\r\n /**\r\n * API is not supported in the current context\r\n */\r\n NOT_SUPPORTED_IN_CURRENT_CONTEXT = 501,\r\n /**\r\n Permissions denied by user\r\n */\r\n PERMISSION_DENIED = 1000,\r\n /**\r\n * Network issue\r\n */\r\n NETWORK_ERROR = 2000,\r\n /**\r\n * Underlying hardware doesn't support the capability\r\n */\r\n NO_HW_SUPPORT = 3000,\r\n /**\r\n * One or more arguments are invalid\r\n */\r\n INVALID_ARGUMENTS = 4000,\r\n /**\r\n * User is not authorized for this operation\r\n */\r\n UNAUTHORIZED_USER_OPERATION = 5000,\r\n /**\r\n * Could not complete the operation due to insufficient resources\r\n */\r\n INSUFFICIENT_RESOURCES = 6000,\r\n /**\r\n * Platform throttled the request because of API was invoked too frequently\r\n */\r\n THROTTLE = 7000,\r\n /**\r\n * User aborted the operation\r\n */\r\n USER_ABORT = 8000,\r\n /**\r\n * Could not complete the operation in the given time interval\r\n */\r\n OPERATION_TIMED_OUT = 8001,\r\n /**\r\n * Platform code is old and doesn't implement this API\r\n */\r\n OLD_PLATFORM = 9000,\r\n /**\r\n * The file specified was not found on the given location\r\n */\r\n FILE_NOT_FOUND = 404,\r\n /**\r\n * The return value is too big and has exceeded our size boundries\r\n */\r\n SIZE_EXCEEDED = 10000,\r\n}\r\n","/* eslint-disable @typescript-eslint/ban-types */\r\n/* eslint-disable @typescript-eslint/no-unused-vars */\r\nimport * as uuid from 'uuid';\r\n\r\nimport { GlobalVars } from '../internal/globalVars';\r\nimport { SdkError } from '../public/interfaces';\r\nimport { pages } from '../public/pages';\r\nimport { validOrigins } from './constants';\r\n\r\n/**\r\n * @param pattern - reference pattern\r\n * @param host - candidate string\r\n * @returns returns true if host matches pre-know valid pattern\r\n *\r\n * @example\r\n * validateHostAgainstPattern('*.teams.microsoft.com', 'subdomain.teams.microsoft.com') returns true\r\n * validateHostAgainstPattern('teams.microsoft.com', 'team.microsoft.com') returns false\r\n *\r\n * @internal\r\n */\r\nfunction validateHostAgainstPattern(pattern: string, host: string): boolean {\r\n if (pattern.substring(0, 2) === '*.') {\r\n const suffix = pattern.substring(1);\r\n if (\r\n host.length > suffix.length &&\r\n host.split('.').length === suffix.split('.').length &&\r\n host.substring(host.length - suffix.length) === suffix\r\n ) {\r\n return true;\r\n }\r\n } else if (pattern === host) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**@internal */\r\nexport function validateOrigin(messageOrigin: URL): boolean {\r\n // Check whether the url is in the pre-known allowlist or supplied by user\r\n if (messageOrigin.protocol !== 'https:') {\r\n return false;\r\n }\r\n const messageOriginHost = messageOrigin.host;\r\n\r\n if (validOrigins.some(pattern => validateHostAgainstPattern(pattern, messageOriginHost))) {\r\n return true;\r\n }\r\n\r\n for (const domainOrPattern of GlobalVars.additionalValidOrigins) {\r\n const pattern = domainOrPattern.substring(0, 8) === 'https://' ? domainOrPattern.substring(8) : domainOrPattern;\r\n if (validateHostAgainstPattern(pattern, messageOriginHost)) {\r\n return true;\r\n }\r\n }\r\n\r\n return false;\r\n}\r\n\r\n/**@internal */\r\nexport function getGenericOnCompleteHandler(errorMessage?: string): (success: boolean, reason?: string) => void {\r\n return (success: boolean, reason: string): void => {\r\n if (!success) {\r\n throw new Error(errorMessage ? errorMessage : reason);\r\n }\r\n };\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Compares SDK versions.\r\n *\r\n * @param v1 - first version\r\n * @param v2 - second version\r\n * @returns NaN in case inputs are not in right format\r\n * -1 if v1 < v2\r\n * 1 if v1 > v2\r\n * 0 otherwise\r\n * @example\r\n * compareSDKVersions('1.2', '1.2.0') returns 0\r\n * compareSDKVersions('1.2a', '1.2b') returns NaN\r\n * compareSDKVersions('1.2', '1.3') returns -1\r\n * compareSDKVersions('2.0', '1.3.2') returns 1\r\n * compareSDKVersions('2.0', 2.0) returns NaN\r\n *\r\n * @internal\r\n */\r\nexport function compareSDKVersions(v1: string, v2: string): number {\r\n if (typeof v1 !== 'string' || typeof v2 !== 'string') {\r\n return NaN;\r\n }\r\n\r\n const v1parts = v1.split('.');\r\n const v2parts = v2.split('.');\r\n\r\n function isValidPart(x: string): boolean {\r\n // input has to have one or more digits\r\n // For ex - returns true for '11', false for '1a1', false for 'a', false for '2b'\r\n return /^\\d+$/.test(x);\r\n }\r\n\r\n if (!v1parts.every(isValidPart) || !v2parts.every(isValidPart)) {\r\n return NaN;\r\n }\r\n\r\n // Make length of both parts equal\r\n while (v1parts.length < v2parts.length) {\r\n v1parts.push('0');\r\n }\r\n while (v2parts.length < v1parts.length) {\r\n v2parts.push('0');\r\n }\r\n\r\n for (let i = 0; i < v1parts.length; ++i) {\r\n if (Number(v1parts[i]) == Number(v2parts[i])) {\r\n continue;\r\n } else if (Number(v1parts[i]) > Number(v2parts[i])) {\r\n return 1;\r\n } else {\r\n return -1;\r\n }\r\n }\r\n return 0;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Generates a GUID\r\n *\r\n * @internal\r\n */\r\nexport function generateGUID(): string {\r\n return uuid.v4();\r\n}\r\n\r\nexport function deepFreeze<T extends object>(obj: T): T {\r\n Object.keys(obj).forEach(prop => {\r\n if (typeof obj[prop] === 'object') {\r\n deepFreeze(obj[prop]);\r\n }\r\n });\r\n return Object.freeze(obj);\r\n}\r\n\r\n/**\r\n * @hidden\r\n * The following type definitions will be used in the\r\n * utility functions below, which help in transforming the\r\n * promises to support callbacks for backward compatibility\r\n *\r\n * @internal\r\n */\r\nexport type ErrorResultCallback<T> = (err?: SdkError, result?: T) => void;\r\nexport type ErrorResultNullCallback<T> = (err: SdkError | null, result: T | null) => void;\r\nexport type ErrorBooleanResultCallback = (err?: SdkError, result?: boolean) => void;\r\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\r\nexport type InputFunction<T> = (...args: any[]) => Promise<T>;\r\nexport type ResultCallback<T> = (result?: T) => void;\r\nexport type SdkErrorCallback = ResultCallback<SdkError | null>;\r\n\r\n/**\r\n * This utility function is used when the result of the promise is same as the result in the callback.\r\n * @param funcHelper\r\n * @param callback\r\n * @param args\r\n * @returns\r\n *\r\n * @internal\r\n */\r\nexport function callCallbackWithErrorOrResultFromPromiseAndReturnPromise<T>(\r\n funcHelper: InputFunction<T>,\r\n callback?: ErrorResultCallback<T>,\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n ...args: any[]\r\n): Promise<T> {\r\n const p = funcHelper(...args);\r\n p.then((result: T) => {\r\n if (callback) {\r\n callback(undefined, result);\r\n }\r\n }).catch((e: SdkError) => {\r\n if (callback) {\r\n callback(e);\r\n }\r\n });\r\n return p;\r\n}\r\n\r\n/**\r\n * This utility function is used when the return type of the promise is usually void and\r\n * the result in the callback is a boolean type (true for success and false for error)\r\n * @param funcHelper\r\n * @param callback\r\n * @param args\r\n * @returns\r\n * @internal\r\n */\r\nexport function callCallbackWithErrorOrBooleanFromPromiseAndReturnPromise<T>(\r\n funcHelper: InputFunction<T>,\r\n callback?: ErrorBooleanResultCallback,\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n ...args: any[]\r\n): Promise<T> {\r\n const p = funcHelper(...args);\r\n p.then(() => {\r\n if (callback) {\r\n callback(undefined, true);\r\n }\r\n }).catch((e: SdkError) => {\r\n if (callback) {\r\n callback(e, false);\r\n }\r\n });\r\n return p;\r\n}\r\n\r\n/**\r\n * This utility function is called when the callback has only Error/SdkError as the primary argument.\r\n * @param funcHelper\r\n * @param callback\r\n * @param args\r\n * @returns\r\n * @internal\r\n */\r\nexport function callCallbackWithSdkErrorFromPromiseAndReturnPromise<T>(\r\n funcHelper: InputFunction<T>,\r\n callback?: SdkErrorCallback,\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n ...args: any[]\r\n): Promise<T> {\r\n const p = funcHelper(...args);\r\n p.then(() => {\r\n if (callback) {\r\n callback(null);\r\n }\r\n }).catch((e: SdkError) => {\r\n if (callback) {\r\n callback(e);\r\n }\r\n });\r\n return p;\r\n}\r\n\r\n/**\r\n * This utility function is used when the result of the promise is same as the result in the callback.\r\n * @param funcHelper\r\n * @param callback\r\n * @param args\r\n * @returns\r\n *\r\n * @internal\r\n */\r\nexport function callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<T>(\r\n funcHelper: InputFunction<T>,\r\n callback?: ErrorResultNullCallback<T>,\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n ...args: any[]\r\n): Promise<T> {\r\n const p = funcHelper(...args);\r\n p.then((result: T) => {\r\n if (callback) {\r\n callback(null, result);\r\n }\r\n }).catch((e: SdkError) => {\r\n if (callback) {\r\n callback(e, null);\r\n }\r\n });\r\n return p;\r\n}\r\n\r\n/**\r\n * A helper function to add a timeout to an asynchronous operation.\r\n *\r\n * @param action Action to wrap the timeout around\r\n * @param timeoutInMs Timeout period in milliseconds\r\n * @param timeoutError Error to reject the promise with if timeout elapses before the action completed\r\n * @returns A promise which resolves to the result of provided action or rejects with a provided timeout error\r\n * if the initial action didn't complete within provided timeout.\r\n *\r\n * @internal\r\n */\r\nexport function runWithTimeout<TResult, TError>(\r\n action: () => Promise<TResult>,\r\n timeoutInMs: number,\r\n timeoutError: TError,\r\n): Promise<TResult> {\r\n return new Promise((resolve, reject) => {\r\n const timeoutHandle = setTimeout(reject, timeoutInMs, timeoutError);\r\n action()\r\n .then(result => {\r\n clearTimeout(timeoutHandle);\r\n resolve(result);\r\n })\r\n .catch(error => {\r\n clearTimeout(timeoutHandle);\r\n reject(error);\r\n });\r\n });\r\n}\r\n\r\nexport function createTeamsAppLink(params: pages.NavigateToAppParams): string {\r\n const url = new URL(\r\n 'https://teams.microsoft.com/l/entity/' +\r\n encodeURIComponent(params.appId) +\r\n '/' +\r\n encodeURIComponent(params.pageId),\r\n );\r\n\r\n if (params.webUrl) {\r\n url.searchParams.append('webUrl', params.webUrl);\r\n }\r\n if (params.channelId || params.subPageId) {\r\n url.searchParams.append('context', JSON.stringify({ channelId: params.channelId, subEntityId: params.subPageId }));\r\n }\r\n return url.toString();\r\n}\r\n","import { HostClientType } from '../public/constants';\r\nimport { ErrorCode, SdkError } from '../public/interfaces';\r\nimport { defaultSDKVersionForCompatCheck, userOriginUrlValidationRegExp } from './constants';\r\nimport { GlobalVars } from './globalVars';\r\nimport { compareSDKVersions } from './utils';\r\n\r\n/** @internal */\r\nexport function ensureInitialized(...expectedFrameContexts: string[]): void {\r\n if (!GlobalVars.initializeCalled) {\r\n throw new Error('The library has not yet been initialized');\r\n }\r\n\r\n if (GlobalVars.frameContext && expectedFrameContexts && expectedFrameContexts.length > 0) {\r\n let found = false;\r\n for (let i = 0; i < expectedFrameContexts.length; i++) {\r\n if (expectedFrameContexts[i] === GlobalVars.frameContext) {\r\n found = true;\r\n break;\r\n }\r\n }\r\n\r\n if (!found) {\r\n throw new Error(\r\n `This call is only allowed in following contexts: ${JSON.stringify(expectedFrameContexts)}. ` +\r\n `Current context: \"${GlobalVars.frameContext}\".`,\r\n );\r\n }\r\n }\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Checks whether the platform has knowledge of this API by doing a comparison\r\n * on API required version and platform supported version of the SDK\r\n *\r\n * @param requiredVersion - SDK version required by the API\r\n *\r\n * @internal\r\n */\r\nexport function isCurrentSDKVersionAtLeast(requiredVersion: string = defaultSDKVersionForCompatCheck): boolean {\r\n const value = compareSDKVersions(GlobalVars.clientSupportedSDKVersion, requiredVersion);\r\n if (isNaN(value)) {\r\n return false;\r\n }\r\n return value >= 0;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Helper function to identify if host client is either android or ios\r\n *\r\n * @internal\r\n */\r\nexport function isHostClientMobile(): boolean {\r\n return GlobalVars.hostClientType == HostClientType.android || GlobalVars.hostClientType == HostClientType.ios;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Helper function which indicates if current API is supported on mobile or not.\r\n * @throws SdkError if host client is not android/ios or if the requiredVersion is not\r\n * supported by platform or not. Null is returned in case of success.\r\n *\r\n * @internal\r\n */\r\nexport function throwExceptionIfMobileApiIsNotSupported(\r\n requiredVersion: string = defaultSDKVersionForCompatCheck,\r\n): void {\r\n if (!isHostClientMobile()) {\r\n const notSupportedError: SdkError = { errorCode: ErrorCode.NOT_SUPPORTED_ON_PLATFORM };\r\n throw notSupportedError;\r\n } else if (!isCurrentSDKVersionAtLeast(requiredVersion)) {\r\n const oldPlatformError: SdkError = { errorCode: ErrorCode.OLD_PLATFORM };\r\n throw oldPlatformError;\r\n }\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Processes the valid origins specifuied by the user, de-duplicates and converts them into a regexp\r\n * which is used later for message source/origin validation\r\n *\r\n * @internal\r\n */\r\nexport function processAdditionalValidOrigins(validMessageOrigins: string[]): void {\r\n let combinedOriginUrls = GlobalVars.additionalValidOrigins.concat(\r\n validMessageOrigins.filter((_origin: string) => {\r\n return typeof _origin === 'string' && userOriginUrlValidationRegExp.test(_origin);\r\n }),\r\n );\r\n const dedupUrls: { [url: string]: boolean } = {};\r\n combinedOriginUrls = combinedOriginUrls.filter(_originUrl => {\r\n if (dedupUrls[_originUrl]) {\r\n return false;\r\n }\r\n dedupUrls[_originUrl] = true;\r\n return true;\r\n });\r\n GlobalVars.additionalValidOrigins = combinedOriginUrls;\r\n}\r\n","/* eslint-disable @typescript-eslint/ban-types */\r\n\r\nimport { deepFreeze } from '../internal/utils';\r\nexport interface IRuntime {\r\n readonly apiVersion: number;\r\n readonly isLegacyTeams?: boolean;\r\n readonly supports: {\r\n readonly appInstallDialog?: {};\r\n readonly appEntity?: {};\r\n readonly bot?: {};\r\n readonly calendar?: {};\r\n readonly call?: {};\r\n readonly chat?: {};\r\n readonly dialog?: {};\r\n readonly files?: {};\r\n readonly location?: {};\r\n readonly logs?: {};\r\n readonly mail?: {};\r\n readonly media?: {};\r\n readonly meeting?: {};\r\n readonly meetingRoom?: {};\r\n readonly menus?: {};\r\n readonly monetization?: {};\r\n readonly notifications?: {};\r\n readonly pages?: {\r\n readonly appButton?: {};\r\n readonly tabs?: {};\r\n readonly config?: {};\r\n readonly backStack?: {};\r\n readonly fullTrust?: {};\r\n };\r\n readonly people?: {};\r\n readonly remoteCamera?: {};\r\n readonly sharing?: {};\r\n readonly teams?: {\r\n readonly fullTrust?: {};\r\n };\r\n readonly teamsCore?: {};\r\n readonly video?: {};\r\n };\r\n}\r\n\r\nexport let runtime: IRuntime = {\r\n apiVersion: 1,\r\n supports: {\r\n appInstallDialog: undefined,\r\n bot: undefined,\r\n calendar: undefined,\r\n call: undefined,\r\n chat: undefined,\r\n dialog: undefined,\r\n location: undefined,\r\n logs: undefined,\r\n mail: undefined,\r\n media: undefined,\r\n meeting: undefined,\r\n meetingRoom: undefined,\r\n menus: undefined,\r\n monetization: undefined,\r\n notifications: undefined,\r\n pages: {\r\n appButton: undefined,\r\n tabs: undefined,\r\n config: undefined,\r\n backStack: undefined,\r\n fullTrust: undefined,\r\n },\r\n people: undefined,\r\n remoteCamera: undefined,\r\n sharing: undefined,\r\n teams: {\r\n fullTrust: undefined,\r\n },\r\n teamsCore: undefined,\r\n video: undefined,\r\n },\r\n};\r\n\r\nexport const teamsRuntimeConfig: IRuntime = {\r\n apiVersion: 1,\r\n isLegacyTeams: true,\r\n supports: {\r\n appInstallDialog: {},\r\n appEntity: {},\r\n bot: {},\r\n call: {},\r\n chat: {},\r\n dialog: {},\r\n files: {},\r\n location: {},\r\n logs: {},\r\n media: {},\r\n meeting: {},\r\n meetingRoom: {},\r\n menus: {},\r\n monetization: {},\r\n notifications: {},\r\n pages: {\r\n appButton: {},\r\n tabs: {},\r\n config: {},\r\n backStack: {},\r\n fullTrust: {},\r\n },\r\n people: {},\r\n remoteCamera: {},\r\n sharing: {},\r\n teams: {\r\n fullTrust: {},\r\n },\r\n teamsCore: {},\r\n video: {},\r\n },\r\n};\r\n\r\nexport function applyRuntimeConfig(runtimeConfig: IRuntime): void {\r\n runtime = deepFreeze(runtimeConfig);\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { registerHandler, removeHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { runtime } from '../public/runtime';\r\n\r\n/**\r\n * @hidden\r\n * Namespace to interact with the logging part of the SDK.\r\n * This object is used to send the app logs on demand to the host client\r\n *\r\n * Hide from docs\r\n *\r\n * @internal\r\n */\r\nexport namespace logs {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Registers a handler for getting app log\r\n *\r\n * @param handler - The handler to invoke to get the app log\r\n */\r\n export function registerGetLogHandler(handler: () => string): void {\r\n ensureInitialized();\r\n\r\n if (handler) {\r\n registerHandler('log.request', () => {\r\n const log: string = handler();\r\n sendMessageToParent('log.receive', [log]);\r\n });\r\n } else {\r\n removeHandler('log.request');\r\n }\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.logs ? true : false;\r\n }\r\n}\r\n","import {\r\n Communication,\r\n sendMessageEventToChild,\r\n sendMessageToParent,\r\n sendMessageToParentAsync,\r\n waitForMessageQueue,\r\n} from '../internal/communication';\r\nimport { GlobalVars } from '../internal/globalVars';\r\nimport { registerHandler, removeHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts, HostClientType } from './constants';\r\n\r\n/**\r\n * Namespace to interact with the authentication-specific part of the SDK.\r\n *\r\n * This object is used for starting or completing authentication flows.\r\n *\r\n * @beta\r\n */\r\nexport namespace authentication {\r\n let authHandlers: { success: (string) => void; fail: (string) => void };\r\n let authWindowMonitor: number;\r\n\r\n export function initialize(): void {\r\n registerHandler('authentication.authenticate.success', handleSuccess, false);\r\n registerHandler('authentication.authenticate.failure', handleFailure, false);\r\n }\r\n\r\n let authParams: AuthenticateParameters;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1.\r\n *\r\n * Registers the authentication Communication.handlers\r\n *\r\n * @param authenticateParameters - A set of values that configure the authentication pop-up.\r\n */\r\n export function registerAuthenticationHandlers(authenticateParameters: AuthenticateParameters): void {\r\n authParams = authenticateParameters;\r\n }\r\n\r\n /**\r\n * Initiates an authentication request, which opens a new window with the specified settings.\r\n *\r\n * @param authenticateParameters - The parameters for the authentication request. It is a required parameter since v2 upgrade\r\n *\r\n * @returns Promise that will be fulfilled with the result from the authentication pop-up if successful.\r\n *\r\n * @throws if the authentication request fails or is canceled by the user.\r\n *\r\n */\r\n export function authenticate(authenticateParameters: AuthenticatePopUpParameters): Promise<string>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link authentication.authenticate authentication.authenticate(authenticateParameters: AuthenticatePopUpParameters): Promise\\<string\\>} instead.\r\n *\r\n * Initiates an authentication request, which opens a new window with the specified settings.\r\n *\r\n * @param authenticateParameters - The parameters for the authentication request.\r\n *\r\n */\r\n export function authenticate(authenticateParameters?: AuthenticateParameters): void;\r\n export function authenticate(authenticateParameters?: AuthenticateParameters): Promise<string> {\r\n const isDifferentParamsInCall: boolean = authenticateParameters !== undefined;\r\n const authenticateParams: AuthenticateParameters = isDifferentParamsInCall ? authenticateParameters : authParams;\r\n if (!authenticateParams) {\r\n throw new Error('No parameters are provided for authentication');\r\n }\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.settings,\r\n FrameContexts.remove,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n return authenticateHelper(authenticateParams)\r\n .then((value: string) => {\r\n try {\r\n if (authenticateParams && authenticateParams.successCallback) {\r\n authenticateParams.successCallback(value);\r\n return '';\r\n }\r\n return value;\r\n } finally {\r\n if (!isDifferentParamsInCall) {\r\n authParams = null;\r\n }\r\n }\r\n })\r\n .catch((err: Error) => {\r\n try {\r\n if (authenticateParams && authenticateParams.failureCallback) {\r\n authenticateParams.failureCallback(err.message);\r\n return '';\r\n }\r\n throw err;\r\n } finally {\r\n if (!isDifferentParamsInCall) {\r\n authParams = null;\r\n }\r\n }\r\n });\r\n }\r\n\r\n function authenticateHelper(authenticateParameters: AuthenticateParameters): Promise<string> {\r\n return new Promise<string>((resolve, reject) => {\r\n if (\r\n GlobalVars.hostClientType === HostClientType.desktop ||\r\n GlobalVars.hostClientType === HostClientType.android ||\r\n GlobalVars.hostClientType === HostClientType.ios ||\r\n GlobalVars.hostClientType === HostClientType.rigel ||\r\n GlobalVars.hostClientType === HostClientType.teamsRoomsWindows ||\r\n GlobalVars.hostClientType === HostClientType.teamsRoomsAndroid ||\r\n GlobalVars.hostClientType === HostClientType.teamsPhones ||\r\n GlobalVars.hostClientType === HostClientType.teamsDisplays\r\n ) {\r\n // Convert any relative URLs into absolute URLs before sending them over to the parent window.\r\n const link = document.createElement('a');\r\n link.href = authenticateParameters.url;\r\n // Ask the parent window to open an authentication window with the parameters provided by the caller.\r\n resolve(\r\n sendMessageToParentAsync<[boolean, string]>('authentication.authenticate', [\r\n link.href,\r\n authenticateParameters.width,\r\n authenticateParameters.height,\r\n authenticateParameters.isExternal,\r\n ]).then(([success, response]: [boolean, string]) => {\r\n if (success) {\r\n return response;\r\n } else {\r\n throw new Error(response);\r\n }\r\n }),\r\n );\r\n } else {\r\n // Open an authentication window with the parameters provided by the caller.\r\n authHandlers = {\r\n success: resolve,\r\n fail: reject,\r\n };\r\n openAuthenticationWindow(authenticateParameters);\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * Requests an Azure AD token to be issued on behalf of the app. The token is acquired from the cache\r\n * if it is not expired. Otherwise a request is sent to Azure AD to obtain a new token.\r\n *\r\n * @param authTokenRequest - An optional set of values that configure the token request.\r\n *\r\n * @returns Promise that will be fulfilled with the token if successful.\r\n */\r\n export function getAuthToken(authTokenRequest?: AuthTokenRequestParameters): Promise<string>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link authentication.getAuthToken authentication.getAuthToken(authTokenRequest: AuthTokenRequestParameters): Promise\\<string\\>} instead.\r\n *\r\n * Requests an Azure AD token to be issued on behalf of the app. The token is acquired from the cache\r\n * if it is not expired. Otherwise a request is sent to Azure AD to obtain a new token.\r\n *\r\n * @param authTokenRequest - An optional set of values that configure the token request.\r\n * It contains callbacks to call in case of success/failure\r\n */\r\n export function getAuthToken(authTokenRequest?: AuthTokenRequest): void;\r\n export function getAuthToken(authTokenRequest?: AuthTokenRequest): Promise<string> {\r\n ensureInitialized();\r\n return getAuthTokenHelper(authTokenRequest)\r\n .then((value: string) => {\r\n if (authTokenRequest && authTokenRequest.successCallback) {\r\n authTokenRequest.successCallback(value);\r\n return '';\r\n }\r\n return value;\r\n })\r\n .catch((err: Error) => {\r\n if (authTokenRequest && authTokenRequest.failureCallback) {\r\n authTokenRequest.failureCallback(err.message);\r\n return '';\r\n }\r\n throw err;\r\n });\r\n }\r\n\r\n function getAuthTokenHelper(authTokenRequest?: AuthTokenRequest): Promise<string> {\r\n return new Promise<[boolean, string]>(resolve => {\r\n resolve(\r\n sendMessageToParentAsync('authentication.getAuthToken', [\r\n authTokenRequest?.resources,\r\n authTokenRequest?.claims,\r\n authTokenRequest?.silent,\r\n ]),\r\n );\r\n }).then(([success, result]: [boolean, string]) => {\r\n if (success) {\r\n return result;\r\n } else {\r\n throw new Error(result);\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Requests the decoded Azure AD user identity on behalf of the app.\r\n *\r\n * @returns Promise that resolves with the {@link UserProfile}.\r\n *\r\n * @internal\r\n */\r\n export function getUser(): Promise<UserProfile>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link authentication.getUser authentication.getUser(): Promise\\<UserProfile\\>} instead.\r\n *\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Requests the decoded Azure AD user identity on behalf of the app.\r\n *\r\n * @param userRequest - It passes success/failure callbacks in the userRequest object(deprecated)\r\n * @internal\r\n */\r\n export function getUser(userRequest: UserRequest): void;\r\n export function getUser(userRequest?: UserRequest): Promise<UserProfile> {\r\n ensureInitialized();\r\n return getUserHelper()\r\n .then((value: UserProfile) => {\r\n if (userRequest && userRequest.successCallback) {\r\n userRequest.successCallback(value);\r\n return null;\r\n }\r\n return value;\r\n })\r\n .catch((err: Error) => {\r\n if (userRequest && userRequest.failureCallback) {\r\n userRequest.failureCallback(err.message);\r\n return null;\r\n }\r\n throw err;\r\n });\r\n }\r\n\r\n function getUserHelper(): Promise<UserProfile> {\r\n return new Promise<[boolean, UserProfile | string]>(resolve => {\r\n resolve(sendMessageToParentAsync('authentication.getUser'));\r\n }).then(([success, result]: [boolean, UserProfile | string]) => {\r\n if (success) {\r\n return result as UserProfile;\r\n } else {\r\n throw new Error(result as string);\r\n }\r\n });\r\n }\r\n\r\n function closeAuthenticationWindow(): void {\r\n // Stop monitoring the authentication window\r\n stopAuthenticationWindowMonitor();\r\n // Try to close the authentication window and clear all properties associated with it\r\n try {\r\n if (Communication.childWindow) {\r\n Communication.childWindow.close();\r\n }\r\n } finally {\r\n Communication.childWindow = null;\r\n Communication.childOrigin = null;\r\n }\r\n }\r\n\r\n function openAuthenticationWindow(authenticateParameters: AuthenticateParameters): void {\r\n // Close the previously opened window if we have one\r\n closeAuthenticationWindow();\r\n // Start with a sensible default size\r\n let width = authenticateParameters.width || 600;\r\n let height = authenticateParameters.height || 400;\r\n // Ensure that the new window is always smaller than our app's window so that it never fully covers up our app\r\n width = Math.min(width, Communication.currentWindow.outerWidth - 400);\r\n height = Math.min(height, Communication.currentWindow.outerHeight - 200);\r\n // Convert any relative URLs into absolute URLs before sending them over to the parent window\r\n const link = document.createElement('a');\r\n link.href = authenticateParameters.url.replace('{oauthRedirectMethod}', 'web');\r\n // We are running in the browser, so we need to center the new window ourselves\r\n let left: number =\r\n typeof Communication.currentWindow.screenLeft !== 'undefined'\r\n ? Communication.currentWindow.screenLeft\r\n : Communication.currentWindow.screenX;\r\n let top: number =\r\n typeof Communication.currentWindow.screenTop !== 'undefined'\r\n ? Communication.currentWindow.screenTop\r\n : Communication.currentWindow.screenY;\r\n left += Communication.currentWindow.outerWidth / 2 - width / 2;\r\n top += Communication.currentWindow.outerHeight / 2 - height / 2;\r\n // Open a child window with a desired set of standard browser features\r\n Communication.childWindow = Communication.currentWindow.open(\r\n link.href,\r\n '_blank',\r\n 'toolbar=no, location=yes, status=no, menubar=no, scrollbars=yes, top=' +\r\n top +\r\n ', left=' +\r\n left +\r\n ', width=' +\r\n width +\r\n ', height=' +\r\n height,\r\n );\r\n if (Communication.childWindow) {\r\n // Start monitoring the authentication window so that we can detect if it gets closed before the flow completes\r\n startAuthenticationWindowMonitor();\r\n } else {\r\n // If we failed to open the window, fail the authentication flow\r\n handleFailure('FailedToOpenWindow');\r\n }\r\n }\r\n\r\n function stopAuthenticationWindowMonitor(): void {\r\n if (authWindowMonitor) {\r\n clearInterval(authWindowMonitor);\r\n authWindowMonitor = 0;\r\n }\r\n removeHandler('initialize');\r\n removeHandler('navigateCrossDomain');\r\n }\r\n\r\n function startAuthenticationWindowMonitor(): void {\r\n // Stop the previous window monitor if one is running\r\n stopAuthenticationWindowMonitor();\r\n // Create an interval loop that\r\n // - Notifies the caller of failure if it detects that the authentication window is closed\r\n // - Keeps pinging the authentication window while it is open to re-establish\r\n // contact with any pages along the authentication flow that need to communicate\r\n // with us\r\n authWindowMonitor = Communication.currentWindow.setInterval(() => {\r\n if (!Communication.childWindow || Communication.childWindow.closed) {\r\n handleFailure('CancelledByUser');\r\n } else {\r\n const savedChildOrigin = Communication.childOrigin;\r\n try {\r\n Communication.childOrigin = '*';\r\n sendMessageEventToChild('ping');\r\n } finally {\r\n Communication.childOrigin = savedChildOrigin;\r\n }\r\n }\r\n }, 100);\r\n // Set up an initialize-message handler that gives the authentication window its frame context\r\n registerHandler('initialize', () => {\r\n return [FrameContexts.authentication, GlobalVars.hostClientType];\r\n });\r\n // Set up a navigateCrossDomain message handler that blocks cross-domain re-navigation attempts\r\n // in the authentication window. We could at some point choose to implement this method via a call to\r\n // authenticationWindow.location.href = url; however, we would first need to figure out how to\r\n // validate the URL against the tab's list of valid domains.\r\n registerHandler('navigateCrossDomain', () => {\r\n return false;\r\n });\r\n }\r\n\r\n /**\r\n * Notifies the frame that initiated this authentication request that the request was successful.\r\n *\r\n * @remarks\r\n * This function is usable only on the authentication window.\r\n * This call causes the authentication window to be closed.\r\n *\r\n * @param result - Specifies a result for the authentication. If specified, the frame that initiated the authentication pop-up receives this value in its callback.\r\n * @param callbackUrl - Specifies the url to redirect back to if the client is Win32 Outlook.\r\n */\r\n export function notifySuccess(result?: string, callbackUrl?: string): void {\r\n redirectIfWin32Outlook(callbackUrl, 'result', result);\r\n ensureInitialized(FrameContexts.authentication);\r\n sendMessageToParent('authentication.authenticate.success', [result]);\r\n // Wait for the message to be sent before closing the window\r\n waitForMessageQueue(Communication.parentWindow, () => setTimeout(() => Communication.currentWindow.close(), 200));\r\n }\r\n\r\n /**\r\n * Notifies the frame that initiated this authentication request that the request failed.\r\n *\r\n * @remarks\r\n * This function is usable only on the authentication window.\r\n * This call causes the authentication window to be closed.\r\n *\r\n * @param result - Specifies a result for the authentication. If specified, the frame that initiated the authentication pop-up receives this value in its callback.\r\n * @param callbackUrl - Specifies the url to redirect back to if the client is Win32 Outlook.\r\n */\r\n export function notifyFailure(reason?: string, callbackUrl?: string): void {\r\n redirectIfWin32Outlook(callbackUrl, 'reason', reason);\r\n ensureInitialized(FrameContexts.authentication);\r\n sendMessageToParent('authentication.authenticate.failure', [reason]);\r\n // Wait for the message to be sent before closing the window\r\n waitForMessageQueue(Communication.parentWindow, () => setTimeout(() => Communication.currentWindow.close(), 200));\r\n }\r\n\r\n function handleSuccess(result?: string): void {\r\n try {\r\n if (authHandlers) {\r\n authHandlers.success(result);\r\n }\r\n } finally {\r\n authHandlers = null;\r\n closeAuthenticationWindow();\r\n }\r\n }\r\n\r\n function handleFailure(reason?: string): void {\r\n try {\r\n if (authHandlers) {\r\n authHandlers.fail(new Error(reason));\r\n }\r\n } finally {\r\n authHandlers = null;\r\n closeAuthenticationWindow();\r\n }\r\n }\r\n\r\n /**\r\n * Validates that the callbackUrl param is a valid connector url, appends the result/reason and authSuccess/authFailure as URL fragments and redirects the window\r\n * @param callbackUrl - the connectors url to redirect to\r\n * @param key - \"result\" in case of success and \"reason\" in case of failure\r\n * @param value - the value of the passed result/reason parameter\r\n */\r\n function redirectIfWin32Outlook(callbackUrl?: string, key?: string, value?: string): void {\r\n if (callbackUrl) {\r\n const link = document.createElement('a');\r\n link.href = decodeURIComponent(callbackUrl);\r\n if (\r\n link.host &&\r\n link.host !== window.location.host &&\r\n link.host === 'outlook.office.com' &&\r\n link.search.indexOf('client_type=Win32_Outlook') > -1\r\n ) {\r\n if (key && key === 'result') {\r\n if (value) {\r\n link.href = updateUrlParameter(link.href, 'result', value);\r\n }\r\n Communication.currentWindow.location.assign(updateUrlParameter(link.href, 'authSuccess', ''));\r\n }\r\n if (key && key === 'reason') {\r\n if (value) {\r\n link.href = updateUrlParameter(link.href, 'reason', value);\r\n }\r\n Communication.currentWindow.location.assign(updateUrlParameter(link.href, 'authFailure', ''));\r\n }\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Appends either result or reason as a fragment to the 'callbackUrl'\r\n * @param uri - the url to modify\r\n * @param key - the fragment key\r\n * @param value - the fragment value\r\n */\r\n function updateUrlParameter(uri: string, key: string, value: string): string {\r\n const i = uri.indexOf('#');\r\n let hash = i === -1 ? '#' : uri.substr(i);\r\n hash = hash + '&' + key + (value !== '' ? '=' + value : '');\r\n uri = i === -1 ? uri : uri.substr(0, i);\r\n return uri + hash;\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1.\r\n */\r\n export interface LegacyCallBacks {\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1.\r\n * A function that is called if the request succeeds.\r\n */\r\n successCallback?: (result: string) => void;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1.\r\n * A function that is called if the request fails, with the reason for the failure.\r\n */\r\n failureCallback?: (reason: string) => void;\r\n }\r\n\r\n export interface AuthenticatePopUpParameters {\r\n /**\r\n * The URL for the authentication pop-up.\r\n */\r\n url: string;\r\n /**\r\n * The preferred width for the pop-up. This value can be ignored if outside the acceptable bounds.\r\n */\r\n width?: number;\r\n /**\r\n * The preferred height for the pop-up. This value can be ignored if outside the acceptable bounds.\r\n */\r\n height?: number;\r\n /**\r\n * The flag which indicates whether the auth page should be opened in an external browser. This flag has no effect on the web client.\r\n */\r\n isExternal?: boolean;\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link AuthenticatePopUpParameters} instead.\r\n */\r\n export type AuthenticateParameters = AuthenticatePopUpParameters & LegacyCallBacks;\r\n\r\n export interface AuthTokenRequestParameters {\r\n /**\r\n * An optional list of resource for which to acquire the access token; only used for full trust apps.\r\n */\r\n resources?: string[];\r\n /**\r\n * An optional list of claims which to pass to AAD when requesting the access token.\r\n */\r\n claims?: string[];\r\n /**\r\n * An optional flag indicating whether to attempt the token acquisition silently or allow a prompt to be shown.\r\n */\r\n silent?: boolean;\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link AuthTokenRequestParameters} instead.\r\n */\r\n export type AuthTokenRequest = AuthTokenRequestParameters & LegacyCallBacks;\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n *\r\n * @internal\r\n */\r\n export interface UserProfile {\r\n /**\r\n * @hidden\r\n * The intended recipient of the token. The application that receives the token must verify that the audience\r\n * value is correct and reject any tokens intended for a different audience.\r\n */\r\n aud: string;\r\n /**\r\n * @hidden\r\n * Identifies how the subject of the token was authenticated.\r\n */\r\n amr: string[];\r\n /**\r\n * @hidden\r\n * Stores the time at which the token was issued. It is often used to measure token freshness.\r\n */\r\n iat: number;\r\n /**\r\n * @hidden\r\n * Identifies the security token service (STS) that constructs and returns the token. In the tokens that Azure AD\r\n * returns, the issuer is sts.windows.net. The GUID in the issuer claim value is the tenant ID of the Azure AD\r\n * directory. The tenant ID is an immutable and reliable identifier of the directory.\r\n */\r\n iss: string;\r\n /**\r\n * @hidden\r\n * Provides the last name, surname, or family name of the user as defined in the Azure AD user object.\r\n */\r\n family_name: string;\r\n /**\r\n * @hidden\r\n * Provides the first or \"given\" name of the user, as set on the Azure AD user object.\r\n */\r\n given_name: string;\r\n /**\r\n * @hidden\r\n * Provides a human-readable value that identifies the subject of the token. This value is not guaranteed to\r\n * be unique within a tenant and is designed to be used only for display purposes.\r\n */\r\n unique_name: string;\r\n /**\r\n * @hidden\r\n * Contains a unique identifier of an object in Azure AD. This value is immutable and cannot be reassigned or\r\n * reused. Use the object ID to identify an object in queries to Azure AD.\r\n */\r\n oid: string;\r\n /**\r\n * @hidden\r\n * Identifies the principal about which the token asserts information, such as the user of an application.\r\n * This value is immutable and cannot be reassigned or reused, so it can be used to perform authorization\r\n * checks safely. Because the subject is always present in the tokens the Azure AD issues, we recommended\r\n * using this value in a general-purpose authorization system.\r\n */\r\n sub: string;\r\n /**\r\n * @hidden\r\n * An immutable, non-reusable identifier that identifies the directory tenant that issued the token. You can\r\n * use this value to access tenant-specific directory resources in a multitenant application. For example,\r\n * you can use this value to identify the tenant in a call to the Graph API.\r\n */\r\n tid: string;\r\n /**\r\n * @hidden\r\n * Defines the end of the time interval within which a token is valid. The service that validates the token\r\n * should verify that the current date is within the token lifetime; otherwise it should reject the token. The\r\n * service might allow for up to five minutes beyond the token lifetime to account for any differences in clock\r\n * time (\"time skew\") between Azure AD and the service.\r\n */\r\n exp: number;\r\n /**\r\n * @hidden\r\n * Defines the start of the time interval within which a token is valid. The service that validates the token\r\n * should verify that the current date is within the token lifetime; otherwise it should reject the token. The\r\n * service might allow for up to five minutes beyond the token lifetime to account for any differences in clock\r\n * time (\"time skew\") between Azure AD and the service.\r\n */\r\n nbf: number;\r\n /**\r\n * @hidden\r\n * Stores the user name of the user principal.\r\n */\r\n upn: string;\r\n /**\r\n * @hidden\r\n * Stores the version number of the token.\r\n */\r\n ver: string;\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1.\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * @internal\r\n */\r\n export interface UserRequest {\r\n /**\r\n * A function that is called if the token request succeeds, with the resulting token.\r\n */\r\n successCallback?: (user: UserProfile) => void;\r\n /**\r\n * A function that is called if the token request fails, with the reason for the failure.\r\n */\r\n failureCallback?: (reason: string) => void;\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { runtime } from '../public/runtime';\r\n\r\n/**\r\n * Namespace to interact with the menu-specific part of the SDK.\r\n * This object is used to show View Configuration, Action Menu and Navigation Bar Menu.\r\n */\r\nexport namespace menus {\r\n /**\r\n * @hidden\r\n * Represents information about item in View Configuration.\r\n */\r\n export interface ViewConfiguration {\r\n /**\r\n * @hidden\r\n * Unique identifier of view.\r\n */\r\n id: string;\r\n /**\r\n * @hidden\r\n * Display title of the view.\r\n */\r\n title: string;\r\n /**\r\n * @hidden\r\n * Additional information for accessibility.\r\n */\r\n contentDescription?: string;\r\n }\r\n\r\n /**\r\n * Defines how a menu item should appear in the NavBar.\r\n */\r\n export enum DisplayMode {\r\n /**\r\n * Only place this item in the NavBar if there's room for it.\r\n * If there's no room, item is shown in the overflow menu.\r\n */\r\n ifRoom = 0,\r\n /**\r\n * Never place this item in the NavBar.\r\n * The item would always be shown in NavBar's overflow menu.\r\n */\r\n overflowOnly = 1,\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Represents information about menu item for Action Menu and Navigation Bar Menu.\r\n */\r\n export class MenuItem {\r\n /**\r\n * @hidden\r\n * Unique identifier for the menu item.\r\n */\r\n public id: string;\r\n /**\r\n * @hidden\r\n * Display title of the menu item.\r\n */\r\n public title: string;\r\n /**\r\n * @hidden\r\n * Display icon of the menu item. The icon value must be a string having SVG icon content.\r\n */\r\n public icon: string;\r\n /**\r\n * @hidden\r\n * Selected state display icon of the menu item. The icon value must be a string having SVG icon content.\r\n */\r\n public iconSelected?: string;\r\n /**\r\n * @hidden\r\n * Additional information for accessibility.\r\n */\r\n public contentDescription?: string;\r\n /**\r\n * @hidden\r\n * State of the menu item\r\n */\r\n public enabled = true;\r\n /**\r\n * @hidden\r\n * Interface to show list of items on selection of menu item.\r\n */\r\n public viewData?: ViewData;\r\n /**\r\n * @hidden\r\n * Whether the menu item is selected or not\r\n */\r\n public selected = false;\r\n /**\r\n * The Display Mode of the menu item.\r\n * Default Behaviour would be DisplayMode.ifRoom if null.\r\n * Refer {@link DisplayMode}\r\n */\r\n public displayMode?: DisplayMode;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Represents information about view to show on Navigation Bar Menu item selection\r\n */\r\n export interface ViewData {\r\n /**\r\n * @hidden\r\n * Display header title of the item list.\r\n */\r\n listTitle?: string;\r\n /**\r\n * @hidden\r\n * Type of the menu item.\r\n */\r\n listType: MenuListType;\r\n /**\r\n * @hidden\r\n * Array of MenuItem. Icon value will be required for all items in the list.\r\n */\r\n listItems: MenuItem[];\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Represents information about type of list to display in Navigation Bar Menu.\r\n */\r\n export enum MenuListType {\r\n dropDown = 'dropDown',\r\n popOver = 'popOver',\r\n }\r\n let navBarMenuItemPressHandler: (id: string) => boolean;\r\n let actionMenuItemPressHandler: (id: string) => boolean;\r\n let viewConfigItemPressHandler: (id: string) => boolean;\r\n\r\n export function initialize(): void {\r\n registerHandler('navBarMenuItemPress', handleNavBarMenuItemPress, false);\r\n registerHandler('actionMenuItemPress', handleActionMenuItemPress, false);\r\n registerHandler('setModuleView', handleViewConfigItemPress, false);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers list of view configurations and it's handler.\r\n * Handler is responsible for listening selection of View Configuration.\r\n *\r\n * @param viewConfig - List of view configurations. Minimum 1 value is required.\r\n * @param handler - The handler to invoke when the user selects view configuration.\r\n */\r\n export function setUpViews(viewConfig: ViewConfiguration[], handler: (id: string) => boolean): void {\r\n ensureInitialized();\r\n viewConfigItemPressHandler = handler;\r\n sendMessageToParent('setUpViews', [viewConfig]);\r\n }\r\n\r\n function handleViewConfigItemPress(id: string): void {\r\n if (!viewConfigItemPressHandler || !viewConfigItemPressHandler(id)) {\r\n ensureInitialized();\r\n sendMessageToParent('viewConfigItemPress', [id]);\r\n }\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Used to set menu items on the Navigation Bar. If icon is available, icon will be shown, otherwise title will be shown.\r\n *\r\n * @param items List of MenuItems for Navigation Bar Menu.\r\n * @param handler The handler to invoke when the user selects menu item.\r\n */\r\n export function setNavBarMenu(items: MenuItem[], handler: (id: string) => boolean): void {\r\n ensureInitialized();\r\n navBarMenuItemPressHandler = handler;\r\n sendMessageToParent('setNavBarMenu', [items]);\r\n }\r\n\r\n function handleNavBarMenuItemPress(id: string): void {\r\n if (!navBarMenuItemPressHandler || !navBarMenuItemPressHandler(id)) {\r\n ensureInitialized();\r\n sendMessageToParent('handleNavBarMenuItemPress', [id]);\r\n }\r\n }\r\n\r\n export interface ActionMenuParameters {\r\n /**\r\n * @hidden\r\n * Display title for Action Menu\r\n */\r\n title: string;\r\n /**\r\n * @hidden\r\n * List of MenuItems for Action Menu\r\n */\r\n items: MenuItem[];\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Used to show Action Menu.\r\n *\r\n * @param params - Parameters for Menu Parameters\r\n * @param handler - The handler to invoke when the user selects menu item.\r\n */\r\n export function showActionMenu(params: ActionMenuParameters, handler: (id: string) => boolean): void {\r\n ensureInitialized();\r\n actionMenuItemPressHandler = handler;\r\n sendMessageToParent('showActionMenu', [params]);\r\n }\r\n\r\n function handleActionMenuItemPress(id: string): void {\r\n if (!actionMenuItemPressHandler || !actionMenuItemPressHandler(id)) {\r\n ensureInitialized();\r\n sendMessageToParent('handleActionMenuItemPress', [id]);\r\n }\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.menus ? true : false;\r\n }\r\n}\r\n","import { GlobalVars } from '../internal/globalVars';\r\nimport * as Handlers from '../internal/handlers'; // Conflict with some names\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { LoadContext } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * Namespace containing the set of APIs that support Teams-specific functionalities.\r\n *\r\n * @alpha\r\n */\r\n\r\nexport namespace teamsCore {\r\n /**\r\n * Enable print capability to support printing page using Ctrl+P and cmd+P\r\n */\r\n export function enablePrintCapability(): void {\r\n if (!GlobalVars.printCapabilityEnabled) {\r\n GlobalVars.printCapabilityEnabled = true;\r\n ensureInitialized();\r\n // adding ctrl+P and cmd+P handler\r\n document.addEventListener('keydown', (event: KeyboardEvent) => {\r\n if ((event.ctrlKey || event.metaKey) && event.keyCode === 80) {\r\n print();\r\n event.cancelBubble = true;\r\n event.preventDefault();\r\n event.stopImmediatePropagation();\r\n }\r\n });\r\n }\r\n }\r\n\r\n /**\r\n * default print handler\r\n */\r\n export function print(): void {\r\n window.print();\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers a handler to be called when the page has been requested to load.\r\n *\r\n * @param handler - The handler to invoke when the page is loaded.\r\n *\r\n * @internal\r\n */\r\n export function registerOnLoadHandler(handler: (context: LoadContext) => void): void {\r\n ensureInitialized();\r\n Handlers.registerOnLoadHandler(handler);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers a handler to be called before the page is unloaded.\r\n *\r\n * @param handler - The handler to invoke before the page is unloaded. If this handler returns true the page should\r\n * invoke the readyToUnload function provided to it once it's ready to be unloaded.\r\n *\r\n * @internal\r\n */\r\n export function registerBeforeUnloadHandler(handler: (readyToUnload: () => void) => boolean): void {\r\n ensureInitialized();\r\n Handlers.registerBeforeUnloadHandler(handler);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.teamsCore ? true : false;\r\n }\r\n}\r\n","/* eslint-disable @typescript-eslint/no-empty-function */\r\n/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\r\n/* eslint-disable @typescript-eslint/no-explicit-any */\r\n\r\nimport {\r\n Communication,\r\n initializeCommunication,\r\n sendAndHandleStatusAndReason as send,\r\n sendAndUnwrap,\r\n sendMessageToParent,\r\n uninitializeCommunication,\r\n} from '../internal/communication';\r\nimport { defaultSDKVersionForCompatCheck, version } from '../internal/constants';\r\nimport { GlobalVars } from '../internal/globalVars';\r\nimport * as Handlers from '../internal/handlers'; // Conflict with some names\r\nimport { ensureInitialized, processAdditionalValidOrigins } from '../internal/internalAPIs';\r\nimport { compareSDKVersions, runWithTimeout } from '../internal/utils';\r\nimport { logs } from '../private/logs';\r\nimport { initializePrivateApis } from '../private/privateAPIs';\r\nimport { authentication } from './authentication';\r\nimport { ChannelType, FrameContexts, HostClientType, HostName, TeamType, UserTeamRole } from './constants';\r\nimport { Context as LegacyContext, FileOpenPreference, LocaleInfo } from './interfaces';\r\nimport { menus } from './menus';\r\nimport { pages } from './pages';\r\nimport { applyRuntimeConfig, IRuntime, teamsRuntimeConfig } from './runtime';\r\nimport { teamsCore } from './teamsAPIs';\r\n\r\n/**\r\n * Namespace to interact with app initialization and lifecycle.\r\n *\r\n * @beta\r\n */\r\nexport namespace app {\r\n // ::::::::::::::::::::::: MicrosoftTeams client SDK public API ::::::::::::::::::::\r\n\r\n export const Messages = {\r\n AppLoaded: 'appInitialization.appLoaded',\r\n Success: 'appInitialization.success',\r\n Failure: 'appInitialization.failure',\r\n ExpectedFailure: 'appInitialization.expectedFailure',\r\n };\r\n\r\n export enum FailedReason {\r\n AuthFailed = 'AuthFailed',\r\n Timeout = 'Timeout',\r\n Other = 'Other',\r\n }\r\n\r\n export enum ExpectedFailureReason {\r\n PermissionError = 'PermissionError',\r\n NotFound = 'NotFound',\r\n Throttling = 'Throttling',\r\n Offline = 'Offline',\r\n Other = 'Other',\r\n }\r\n\r\n export interface IFailedRequest {\r\n reason: FailedReason;\r\n message?: string;\r\n }\r\n\r\n export interface IExpectedFailureRequest {\r\n reason: ExpectedFailureReason;\r\n message?: string;\r\n }\r\n\r\n export interface AppInfo {\r\n /**\r\n * The current locale that the user has configured for the app formatted as\r\n * languageId-countryId (for example, en-us).\r\n */\r\n locale: string;\r\n\r\n /**\r\n * The current UI theme.\r\n */\r\n theme: string;\r\n\r\n /**\r\n * Unique ID for the current session for use in correlating telemetry data.\r\n */\r\n sessionId: string;\r\n\r\n /**\r\n * Info of the host\r\n */\r\n host: AppHostInfo;\r\n\r\n /**\r\n * More detailed locale info from the user's OS if available. Can be used together with\r\n * the @microsoft/globe NPM package to ensure your app respects the user's OS date and\r\n * time format configuration\r\n */\r\n osLocaleInfo?: LocaleInfo;\r\n /**\r\n * Personal app icon y coordinate position\r\n */\r\n iconPositionVertical?: number;\r\n\r\n /**\r\n * Time when the user clicked on the tab\r\n */\r\n userClickTime?: number;\r\n\r\n /**\r\n * The ID of the parent message from which this task module was launched.\r\n * This is only available in task modules launched from bot cards.\r\n */\r\n parentMessageId?: string;\r\n\r\n /**\r\n * Where the user prefers the file to be opened from by default during file open\r\n */\r\n userFileOpenPreference?: FileOpenPreference;\r\n\r\n /**\r\n * ID for the current visible app which is different for across cached sessions. Used for correlating telemetry data.\r\n */\r\n appLaunchId?: string;\r\n }\r\n\r\n export interface AppHostInfo {\r\n /**\r\n * The name of the host client. Possible values are: Office, Orange, Outlook, Teams\r\n */\r\n name: HostName;\r\n\r\n /**\r\n * The type of the host client. Possible values are : android, ios, web, desktop, rigel\r\n */\r\n clientType: HostClientType;\r\n\r\n /**\r\n * Unique ID for the current Host session for use in correlating telemetry data.\r\n */\r\n sessionId: string;\r\n\r\n /**\r\n * Current ring ID\r\n */\r\n ringId?: string;\r\n }\r\n\r\n export interface ChannelInfo {\r\n /**\r\n * The Microsoft Teams ID for the channel with which the content is associated.\r\n */\r\n id: string;\r\n\r\n /**\r\n * The name for the channel with which the content is associated.\r\n */\r\n displayName?: string;\r\n\r\n /**\r\n * The relative path to the SharePoint folder associated with the channel.\r\n */\r\n relativeUrl?: string;\r\n\r\n /**\r\n * The type of the channel with which the content is associated.\r\n */\r\n membershipType?: ChannelType;\r\n\r\n /**\r\n * The OneNote section ID that is linked to the channel.\r\n */\r\n defaultOneNoteSectionId?: string;\r\n\r\n /**\r\n * The tenant ID of the team which owns the channel.\r\n */\r\n ownerTenantId?: string;\r\n\r\n /**\r\n * The AAD group ID of the team which owns the channel.\r\n */\r\n ownerGroupId?: string;\r\n }\r\n\r\n export interface ChatInfo {\r\n /**\r\n * The Microsoft Teams ID for the chat with which the content is associated.\r\n */\r\n id: string;\r\n }\r\n\r\n export interface MeetingInfo {\r\n /**\r\n * Meeting Id used by tab when running in meeting context\r\n */\r\n id: string;\r\n }\r\n\r\n export interface PageInfo {\r\n /**\r\n * The developer-defined unique ID for the page this content points to.\r\n */\r\n id: string;\r\n\r\n /**\r\n * The context where page url is loaded (content, task, setting, remove, sidePanel)\r\n */\r\n frameContext: FrameContexts;\r\n\r\n /**\r\n * The developer-defined unique ID for the sub-page this content points to.\r\n * This field should be used to restore to a specific state within a page,\r\n * such as scrolling to or activating a specific piece of content.\r\n */\r\n subPageId?: string;\r\n\r\n /**\r\n * Indication whether the page is in full-screen mode.\r\n */\r\n isFullScreen?: boolean;\r\n\r\n /**\r\n * Indication whether the page is in a pop out window\r\n */\r\n isMultiWindow?: boolean;\r\n\r\n /**\r\n * Source origin from where the page is opened\r\n */\r\n sourceOrigin?: string;\r\n }\r\n\r\n export interface TeamInfo {\r\n /**\r\n * The Microsoft Teams ID for the team with which the content is associated.\r\n */\r\n internalId: string;\r\n\r\n /**\r\n * The name for the team with which the content is associated.\r\n */\r\n displayName?: string;\r\n\r\n /**\r\n * The type of the team.\r\n */\r\n type?: TeamType;\r\n\r\n /**\r\n * The Office 365 group ID for the team with which the content is associated.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n groupId?: string;\r\n\r\n /**\r\n * Indicates whether team is archived.\r\n * Apps should use this as a signal to prevent any changes to content associated with archived teams.\r\n */\r\n isArchived?: boolean;\r\n\r\n /**\r\n * Team Template ID if there was a Team Template associated with the creation of the team.\r\n */\r\n templateId?: string;\r\n\r\n /**\r\n * The user's role in the team.\r\n * Because a malicious party can run your content in a browser, this value should\r\n * be used only as a hint as to the user's role, and never as proof of her role.\r\n */\r\n userRole?: UserTeamRole;\r\n }\r\n\r\n export interface UserInfo {\r\n /**\r\n * The Azure AD object id of the current user.\r\n * Because a malicious party run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n id: string;\r\n\r\n /**\r\n * The address book name of the current user.\r\n */\r\n displayName?: string;\r\n\r\n /**\r\n * Represents whether calling is allowed for the current logged in User\r\n */\r\n isCallingAllowed?: boolean;\r\n\r\n /**\r\n * Represents whether PSTN calling is allowed for the current logged in User\r\n */\r\n isPSTNCallingAllowed?: boolean;\r\n\r\n /**\r\n * The license type for the current user.\r\n */\r\n licenseType?: string;\r\n\r\n /**\r\n * A value suitable for use as a login_hint when authenticating with Azure AD.\r\n * Because a malicious party can run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n loginHint?: string;\r\n\r\n /**\r\n * The UPN of the current user. This may be an externally-authenticated UPN (e.g., guest users).\r\n * Because a malicious party run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n userPrincipalName?: string;\r\n\r\n /**\r\n * The tenant related info of the current user.\r\n */\r\n tenant?: TenantInfo;\r\n }\r\n\r\n export interface TenantInfo {\r\n /**\r\n * The Azure AD tenant ID of the current user.\r\n * Because a malicious party can run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n id: string;\r\n\r\n /**\r\n * The type of license for the current users tenant.\r\n */\r\n teamsSku?: string;\r\n }\r\n\r\n export interface SharePointSiteInfo {\r\n /**\r\n * The root SharePoint site associated with the team.\r\n */\r\n teamSiteUrl?: string;\r\n\r\n /**\r\n * The domain of the root SharePoint site associated with the team.\r\n */\r\n teamSiteDomain?: string;\r\n\r\n /**\r\n * The relative path to the SharePoint site associated with the team.\r\n */\r\n teamSitePath?: string;\r\n\r\n /**\r\n * Teamsite ID, aka sharepoint site id.\r\n */\r\n teamSiteId?: string;\r\n\r\n /**\r\n * The SharePoint my site domain associated with the user.\r\n */\r\n mySiteDomain?: string;\r\n\r\n /**\r\n * The SharePoint relative path to the current users mysite\r\n */\r\n mySitePath?: string;\r\n }\r\n\r\n /**\r\n * Represents structure of the context message received\r\n */\r\n export interface Context {\r\n /**\r\n * Info of the app\r\n */\r\n app: AppInfo;\r\n\r\n /**\r\n * Info of the current page of App\r\n */\r\n page: PageInfo;\r\n\r\n /**\r\n * Info of the user\r\n */\r\n user?: UserInfo;\r\n\r\n /**\r\n * Info of the Microsoft Teams channel\r\n */\r\n channel?: ChannelInfo;\r\n\r\n /**\r\n * Info of the Microsoft Teams chat\r\n */\r\n chat?: ChatInfo;\r\n\r\n /**\r\n * Info of the Microsoft Teams meeting\r\n */\r\n meeting?: MeetingInfo;\r\n\r\n /**\r\n * SharePoint context. This is only available when hosted in SharePoint.\r\n */\r\n sharepoint?: any;\r\n\r\n /**\r\n * Info of the sharePoint site associated with the team.\r\n */\r\n sharePointSite?: SharePointSiteInfo;\r\n\r\n /**\r\n * Info of the Microsoft Teams team\r\n */\r\n team?: TeamInfo;\r\n }\r\n\r\n /**\r\n * Checks whether the Teams client SDK has been initialized.\r\n * @returns whether the Teams client SDK has been initialized.\r\n */\r\n export function isInitialized(): boolean {\r\n return GlobalVars.initializeCalled;\r\n }\r\n\r\n /**\r\n * Gets the Frame Context that the App is running in. {@see FrameContexts} for the list of possible values.\r\n * @returns the Frame Context.\r\n */\r\n export function getFrameContext(): FrameContexts {\r\n return GlobalVars.frameContext;\r\n }\r\n\r\n /**\r\n * Number of milliseconds we'll give the initialization call to return before timing it out\r\n */\r\n const initializationTimeoutInMs = 5000;\r\n\r\n /**\r\n * Initializes the library.\r\n *\r\n * @remarks\r\n * This must be called before any other SDK calls\r\n * but after the frame is loaded successfully.\r\n *\r\n * @param validMessageOrigins - Optionally specify a list of cross frame message origins. They must have\r\n * https: protocol otherwise they will be ignored. Example: https:www.example.com\r\n * @returns Promise that will be fulfilled when initialization has completed, or rejected if the initialization fails or times out\r\n */\r\n export function initialize(validMessageOrigins?: string[]): Promise<void> {\r\n return runWithTimeout(\r\n () => initializeHelper(validMessageOrigins),\r\n initializationTimeoutInMs,\r\n new Error('SDK initialization timed out.'),\r\n );\r\n }\r\n\r\n function initializeHelper(validMessageOrigins?: string[]): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n // Independent components might not know whether the SDK is initialized so might call it to be safe.\r\n // Just no-op if that happens to make it easier to use.\r\n if (!GlobalVars.initializeCalled) {\r\n GlobalVars.initializeCalled = true;\r\n\r\n Handlers.initializeHandlers();\r\n GlobalVars.initializePromise = initializeCommunication(validMessageOrigins).then(\r\n ({ context, clientType, runtimeConfig, clientSupportedSDKVersion = defaultSDKVersionForCompatCheck }) => {\r\n GlobalVars.frameContext = context;\r\n GlobalVars.hostClientType = clientType;\r\n GlobalVars.clientSupportedSDKVersion = clientSupportedSDKVersion;\r\n\r\n // Temporary workaround while the Host is updated with the new argument order.\r\n // For now, we might receive any of these possibilities:\r\n // - `runtimeConfig` in `runtimeConfig` and `clientSupportedSDKVersion` in `clientSupportedSDKVersion`.\r\n // - `runtimeConfig` in `clientSupportedSDKVersion` and `clientSupportedSDKVersion` in `runtimeConfig`.\r\n // - `clientSupportedSDKVersion` in `runtimeConfig` and no `clientSupportedSDKVersion`.\r\n // This code supports any of these possibilities\r\n\r\n // Teams AppHost won't provide this runtime config\r\n // so we assume that if we don't have it, we must be running in Teams.\r\n // After Teams updates its client code, we can remove this default code.\r\n try {\r\n const givenRuntimeConfig: IRuntime = JSON.parse(runtimeConfig);\r\n // Check that givenRuntimeConfig is a valid instance of IRuntimeConfig\r\n if (!givenRuntimeConfig || !givenRuntimeConfig.apiVersion) {\r\n throw new Error('Received runtime config is invalid');\r\n }\r\n runtimeConfig && applyRuntimeConfig(givenRuntimeConfig);\r\n } catch (e) {\r\n if (e instanceof SyntaxError) {\r\n try {\r\n // if the given runtime config was actually meant to be a SDK version, store it as such.\r\n // TODO: This is a temporary workaround to allow Teams to store clientSupportedSDKVersion even when\r\n // it doesn't provide the runtimeConfig. After Teams updates its client code, we should\r\n // remove this feature.\r\n if (!isNaN(compareSDKVersions(runtimeConfig, defaultSDKVersionForCompatCheck))) {\r\n GlobalVars.clientSupportedSDKVersion = runtimeConfig;\r\n }\r\n const givenRuntimeConfig: IRuntime = JSON.parse(clientSupportedSDKVersion);\r\n clientSupportedSDKVersion && applyRuntimeConfig(givenRuntimeConfig);\r\n } catch (e) {\r\n if (e instanceof SyntaxError) {\r\n applyRuntimeConfig(teamsRuntimeConfig);\r\n } else {\r\n throw e;\r\n }\r\n }\r\n } else {\r\n // If it's any error that's not a JSON parsing error, we want the program to fail.\r\n throw e;\r\n }\r\n }\r\n\r\n GlobalVars.initializeCompleted = true;\r\n },\r\n );\r\n\r\n authentication.initialize();\r\n menus.initialize();\r\n pages.config.initialize();\r\n initializePrivateApis();\r\n }\r\n\r\n // Handle additional valid message origins if specified\r\n if (Array.isArray(validMessageOrigins)) {\r\n processAdditionalValidOrigins(validMessageOrigins);\r\n }\r\n\r\n resolve(GlobalVars.initializePromise);\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Undocumented function used to set a mock window for unit tests\r\n *\r\n * @internal\r\n */\r\n export function _initialize(hostWindow: any): void {\r\n Communication.currentWindow = hostWindow;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Undocumented function used to clear state between unit tests\r\n *\r\n * @internal\r\n */\r\n export function _uninitialize(): void {\r\n if (!GlobalVars.initializeCalled) {\r\n return;\r\n }\r\n\r\n if (GlobalVars.frameContext) {\r\n registerOnThemeChangeHandler(null);\r\n pages.backStack.registerBackButtonHandler(null);\r\n pages.registerFullScreenHandler(null);\r\n teamsCore.registerBeforeUnloadHandler(null);\r\n teamsCore.registerOnLoadHandler(null);\r\n logs.registerGetLogHandler(null);\r\n }\r\n\r\n if (GlobalVars.frameContext === FrameContexts.settings) {\r\n pages.config.registerOnSaveHandler(null);\r\n }\r\n\r\n if (GlobalVars.frameContext === FrameContexts.remove) {\r\n pages.config.registerOnRemoveHandler(null);\r\n }\r\n\r\n GlobalVars.initializeCalled = false;\r\n GlobalVars.initializeCompleted = false;\r\n GlobalVars.initializePromise = null;\r\n GlobalVars.additionalValidOrigins = [];\r\n GlobalVars.frameContext = null;\r\n GlobalVars.hostClientType = null;\r\n GlobalVars.isFramelessWindow = false;\r\n\r\n uninitializeCommunication();\r\n }\r\n\r\n /**\r\n * Retrieves the current context the frame is running in.\r\n *\r\n * @returns Promise that will resolve with the {@link Context} object.\r\n */\r\n export function getContext(): Promise<app.Context> {\r\n return new Promise<LegacyContext>(resolve => {\r\n ensureInitialized();\r\n resolve(sendAndUnwrap('getContext'));\r\n }).then(legacyContext => transformLegacyContextToAppContext(legacyContext)); // converts globalcontext to app.context\r\n }\r\n\r\n /**\r\n * Notifies the frame that app has loaded and to hide the loading indicator if one is shown.\r\n */\r\n export function notifyAppLoaded(): void {\r\n ensureInitialized();\r\n sendMessageToParent(Messages.AppLoaded, [version]);\r\n }\r\n\r\n /**\r\n * Notifies the frame that app initialization is successful and is ready for user interaction.\r\n */\r\n export function notifySuccess(): void {\r\n ensureInitialized();\r\n sendMessageToParent(Messages.Success, [version]);\r\n }\r\n\r\n /**\r\n * Notifies the frame that app initialization has failed and to show an error page in its place.\r\n */\r\n export function notifyFailure(appInitializationFailedRequest: IFailedRequest): void {\r\n ensureInitialized();\r\n sendMessageToParent(Messages.Failure, [\r\n appInitializationFailedRequest.reason,\r\n appInitializationFailedRequest.message,\r\n ]);\r\n }\r\n\r\n /**\r\n * Notifies the frame that app initialized with some expected errors.\r\n */\r\n export function notifyExpectedFailure(expectedFailureRequest: IExpectedFailureRequest): void {\r\n ensureInitialized();\r\n sendMessageToParent(Messages.ExpectedFailure, [expectedFailureRequest.reason, expectedFailureRequest.message]);\r\n }\r\n\r\n /**\r\n * Registers a handler for theme changes.\r\n *\r\n * @remarks\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the user changes their theme.\r\n */\r\n export function registerOnThemeChangeHandler(handler: (theme: string) => void): void {\r\n ensureInitialized();\r\n Handlers.registerOnThemeChangeHandler(handler);\r\n }\r\n\r\n /**\r\n * open link API.\r\n *\r\n * @param deepLink - deep link.\r\n * @returns Promise that will be fulfilled when the operation has completed\r\n */\r\n export function openLink(deepLink: string): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.settings,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n resolve(send('executeDeepLink', deepLink));\r\n });\r\n }\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Transforms the Legacy Context object received from Messages to the structured app.Context object\r\n *\r\n * @internal\r\n */\r\nfunction transformLegacyContextToAppContext(legacyContext: LegacyContext): app.Context {\r\n const context: app.Context = {\r\n app: {\r\n locale: legacyContext.locale,\r\n sessionId: legacyContext.appSessionId ? legacyContext.appSessionId : '',\r\n theme: legacyContext.theme ? legacyContext.theme : 'default',\r\n iconPositionVertical: legacyContext.appIconPosition,\r\n osLocaleInfo: legacyContext.osLocaleInfo,\r\n parentMessageId: legacyContext.parentMessageId,\r\n userClickTime: legacyContext.userClickTime,\r\n userFileOpenPreference: legacyContext.userFileOpenPreference,\r\n host: {\r\n name: legacyContext.hostName ? legacyContext.hostName : HostName.teams,\r\n clientType: legacyContext.hostClientType ? legacyContext.hostClientType : HostClientType.web,\r\n sessionId: legacyContext.sessionId ? legacyContext.sessionId : '',\r\n ringId: legacyContext.ringId,\r\n },\r\n appLaunchId: legacyContext.appLaunchId,\r\n },\r\n page: {\r\n id: legacyContext.entityId,\r\n frameContext: legacyContext.frameContext ? legacyContext.frameContext : GlobalVars.frameContext,\r\n subPageId: legacyContext.subEntityId,\r\n isFullScreen: legacyContext.isFullScreen,\r\n isMultiWindow: legacyContext.isMultiWindow,\r\n sourceOrigin: legacyContext.sourceOrigin,\r\n },\r\n user: {\r\n id: legacyContext.userObjectId,\r\n displayName: legacyContext.userDisplayName,\r\n isCallingAllowed: legacyContext.isCallingAllowed,\r\n isPSTNCallingAllowed: legacyContext.isPSTNCallingAllowed,\r\n licenseType: legacyContext.userLicenseType,\r\n loginHint: legacyContext.loginHint,\r\n userPrincipalName: legacyContext.userPrincipalName,\r\n tenant: legacyContext.tid\r\n ? {\r\n id: legacyContext.tid,\r\n teamsSku: legacyContext.tenantSKU,\r\n }\r\n : undefined,\r\n },\r\n channel: legacyContext.channelId\r\n ? {\r\n id: legacyContext.channelId,\r\n displayName: legacyContext.channelName,\r\n relativeUrl: legacyContext.channelRelativeUrl,\r\n membershipType: legacyContext.channelType,\r\n defaultOneNoteSectionId: legacyContext.defaultOneNoteSectionId,\r\n ownerGroupId: legacyContext.hostTeamGroupId,\r\n ownerTenantId: legacyContext.hostTeamTenantId,\r\n }\r\n : undefined,\r\n chat: legacyContext.chatId\r\n ? {\r\n id: legacyContext.chatId,\r\n }\r\n : undefined,\r\n meeting: legacyContext.meetingId\r\n ? {\r\n id: legacyContext.meetingId,\r\n }\r\n : undefined,\r\n sharepoint: legacyContext.sharepoint,\r\n team: legacyContext.teamId\r\n ? {\r\n internalId: legacyContext.teamId,\r\n displayName: legacyContext.teamName,\r\n type: legacyContext.teamType,\r\n groupId: legacyContext.groupId,\r\n templateId: legacyContext.teamTemplateId,\r\n isArchived: legacyContext.isTeamArchived,\r\n userRole: legacyContext.userTeamRole,\r\n }\r\n : undefined,\r\n sharePointSite:\r\n legacyContext.teamSiteUrl ||\r\n legacyContext.teamSiteDomain ||\r\n legacyContext.teamSitePath ||\r\n legacyContext.mySitePath ||\r\n legacyContext.mySiteDomain\r\n ? {\r\n teamSiteUrl: legacyContext.teamSiteUrl,\r\n teamSiteDomain: legacyContext.teamSiteDomain,\r\n teamSitePath: legacyContext.teamSitePath,\r\n teamSiteId: legacyContext.teamSiteId,\r\n mySitePath: legacyContext.mySitePath,\r\n mySiteDomain: legacyContext.mySiteDomain,\r\n }\r\n : undefined,\r\n };\r\n\r\n return context;\r\n}\r\n","import {\r\n sendAndHandleStatusAndReason as send,\r\n sendAndHandleStatusAndReasonWithDefaultError as sendAndDefaultError,\r\n sendAndUnwrap,\r\n sendMessageToParent,\r\n} from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { createTeamsAppLink } from '../internal/utils';\r\nimport { app } from './app';\r\nimport { FrameContexts } from './constants';\r\nimport { DeepLinkParameters, FrameInfo, TabInformation, TabInstance, TabInstanceParameters } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * Navigation specific part of the SDK.\r\n *\r\n * @beta\r\n */\r\nexport namespace pages {\r\n /**\r\n * Return focus to the host. Will move focus forward or backward based on where the app container falls in\r\n * the F6/Tab accessiblity loop in the host.\r\n * @param navigateForward - Determines the direction to focus in host.\r\n */\r\n export function returnFocus(navigateForward?: boolean): void {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n sendMessageToParent('returnFocus', [navigateForward]);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers a handler when focus needs to be passed from teams to the place of choice on app.\r\n *\r\n * @param handler - The handler to invoked by the app when they want the focus to be in the place of their choice.\r\n *\r\n * @internal\r\n */\r\n export function registerFocusEnterHandler(handler: (navigateForward: boolean) => void): void {\r\n ensureInitialized();\r\n registerHandler('focusEnter', handler);\r\n }\r\n\r\n export function setCurrentFrame(frameInfo: FrameInfo): void {\r\n ensureInitialized(FrameContexts.content);\r\n sendMessageToParent('setFrameContext', [frameInfo]);\r\n }\r\n\r\n export function initializeWithFrameContext(\r\n frameInfo: FrameInfo,\r\n callback?: () => void,\r\n validMessageOrigins?: string[],\r\n ): void {\r\n app.initialize(validMessageOrigins).then(() => callback && callback());\r\n setCurrentFrame(frameInfo);\r\n }\r\n\r\n export interface InstanceConfig {\r\n /**\r\n * A suggested display name for the new content.\r\n * In the settings for an existing instance being updated, this call has no effect.\r\n */\r\n suggestedDisplayName?: string;\r\n /**\r\n * Sets the URL to use for the content of this instance.\r\n */\r\n contentUrl: string;\r\n /**\r\n * Sets the URL for the removal configuration experience.\r\n */\r\n removeUrl?: string;\r\n /**\r\n * Sets the URL to use for the external link to view the underlying resource in a browser.\r\n */\r\n websiteUrl?: string;\r\n /**\r\n * The developer-defined unique ID for the entity to which this content points.\r\n */\r\n entityId?: string;\r\n }\r\n\r\n /**\r\n * Gets the config for the current instance.\r\n * @returns Promise that resolves with the {@link InstanceConfig} object.\r\n */\r\n export function getConfig(): Promise<InstanceConfig> {\r\n return new Promise<InstanceConfig>(resolve => {\r\n ensureInitialized(FrameContexts.content, FrameContexts.settings, FrameContexts.remove, FrameContexts.sidePanel);\r\n resolve(sendAndUnwrap('settings.getSettings'));\r\n });\r\n }\r\n\r\n /**\r\n * Navigates the frame to a new cross-domain URL. The domain of this URL must match at least one of the\r\n * valid domains specified in the validDomains block of the manifest; otherwise, an exception will be\r\n * thrown. This function needs to be used only when navigating the frame to a URL in a different domain\r\n * than the current one in a way that keeps the app informed of the change and allows the SDK to\r\n * continue working.\r\n * @param url - The URL to navigate the frame to.\r\n * @returns Promise that resolves when the navigation has completed.\r\n */\r\n export function navigateCrossDomain(url: string): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.settings,\r\n FrameContexts.remove,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n\r\n const errorMessage =\r\n 'Cross-origin navigation is only supported for URLs matching the pattern registered in the manifest.';\r\n resolve(sendAndDefaultError('navigateCrossDomain', errorMessage, url));\r\n });\r\n }\r\n\r\n /**\r\n * Navigate to the given App ID and Page ID, with optional parameters for a WebURL (if the app cannot\r\n * be navigated to, such as if it is not installed), Channel ID (for apps installed as a channel tab), and\r\n * Sub-page ID (for navigating to specific content within the page). This is equivalent to navigating to\r\n * a deep link with the above data, but does not require the app to build a URL or worry about different\r\n * deep link formats for different hosts.\r\n * @param params Parameters for the navigation\r\n * @returns a promise that will resolve if the navigation was successful\r\n */\r\n export function navigateToApp(params: NavigateToAppParams): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.settings,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n if (runtime.isLegacyTeams) {\r\n resolve(send('executeDeepLink', createTeamsAppLink(params)));\r\n } else {\r\n resolve(send('pages.navigateToApp', params));\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * Shares a deep link that a user can use to navigate back to a specific state in this page.\r\n *\r\n * @param deepLinkParameters - ID and label for the link and fallback URL.\r\n */\r\n export function shareDeepLink(deepLinkParameters: DeepLinkParameters): void {\r\n ensureInitialized(FrameContexts.content, FrameContexts.sidePanel, FrameContexts.meetingStage);\r\n\r\n sendMessageToParent('shareDeepLink', [\r\n deepLinkParameters.subEntityId,\r\n deepLinkParameters.subEntityLabel,\r\n deepLinkParameters.subEntityWebUrl,\r\n ]);\r\n }\r\n\r\n /**\r\n * Registers a handler for changes from or to full-screen view for a tab.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n * @param handler - The handler to invoke when the user toggles full-screen view for a tab.\r\n */\r\n export function registerFullScreenHandler(handler: (isFullScreen: boolean) => void): void {\r\n ensureInitialized();\r\n registerHandler('fullScreenChange', handler);\r\n }\r\n\r\n /**\r\n * Checks if page capability is supported currently\r\n */\r\n export function isSupported(): boolean {\r\n return runtime.supports.pages ? true : false;\r\n }\r\n\r\n /**\r\n * Parameters for the NavigateToApp API\r\n */\r\n export interface NavigateToAppParams {\r\n /**\r\n * ID of the App to navigate to\r\n */\r\n appId: string;\r\n\r\n /**\r\n * Developer-defined ID of the Page to navigate to within the app (Formerly EntityID)\r\n */\r\n pageId: string;\r\n\r\n /**\r\n * Optional URL to open if the navigation cannot be completed within the host\r\n */\r\n webUrl?: string;\r\n\r\n /**\r\n * Optional developer-defined ID describing the content to navigate to within the Page. This will be passed\r\n * back to the App via the Context object.\r\n */\r\n subPageId?: string;\r\n\r\n /**\r\n * Optional ID of the Teams Channel where the app should be opened\r\n */\r\n channelId?: string;\r\n }\r\n\r\n /**\r\n * Namespace to interact with the teams specific part of the SDK.\r\n */\r\n export namespace tabs {\r\n /**\r\n * Navigates the hosted app to the specified tab instance.\r\n * @param tabInstance The tab instance to navigate to.\r\n * @returns Promise that resolves when the navigation has completed.\r\n */\r\n export function navigateToTab(tabInstance: TabInstance): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized();\r\n const errorMessage = 'Invalid internalTabInstanceId and/or channelId were/was provided';\r\n resolve(sendAndDefaultError('navigateToTab', errorMessage, tabInstance));\r\n });\r\n }\r\n /**\r\n * Allows an app to retrieve for this user tabs that are owned by this app.\r\n * If no TabInstanceParameters are passed, the app defaults to favorite teams and favorite channels.\r\n * @param tabInstanceParameters OPTIONAL Flags that specify whether to scope call to favorite teams or channels.\r\n * @returns Promise that resolves with the {@link TabInformation}.\r\n */\r\n export function getTabInstances(tabInstanceParameters?: TabInstanceParameters): Promise<TabInformation> {\r\n return new Promise<TabInformation>(resolve => {\r\n ensureInitialized();\r\n resolve(sendAndUnwrap('getTabInstances', tabInstanceParameters));\r\n });\r\n }\r\n\r\n /**\r\n * Allows an app to retrieve the most recently used tabs for this user.\r\n * @param tabInstanceParameters OPTIONAL Ignored, kept for future use\r\n * @returns Promise that resolves with the {@link TabInformation}.\r\n */\r\n export function getMruTabInstances(tabInstanceParameters?: TabInstanceParameters): Promise<TabInformation> {\r\n return new Promise<TabInformation>(resolve => {\r\n ensureInitialized();\r\n resolve(sendAndUnwrap('getMruTabInstances', tabInstanceParameters));\r\n });\r\n }\r\n\r\n /**\r\n * Checks if pages.tabs capability is supported currently\r\n */\r\n export function isSupported(): boolean {\r\n return runtime.supports.pages ? (runtime.supports.pages.tabs ? true : false) : false;\r\n }\r\n }\r\n /**\r\n * Namespace to interact with the config-specific part of the SDK.\r\n * This object is usable only on the config frame.\r\n */\r\n export namespace config {\r\n let saveHandler: (evt: SaveEvent) => void;\r\n let removeHandler: (evt: RemoveEvent) => void;\r\n\r\n export function initialize(): void {\r\n registerHandler('settings.save', handleSave, false);\r\n registerHandler('settings.remove', handleRemove, false);\r\n }\r\n\r\n /**\r\n * Sets the validity state for the config.\r\n * The initial value is false, so the user cannot save the config until this is called with true.\r\n * @param validityState Indicates whether the save or remove button is enabled for the user.\r\n */\r\n export function setValidityState(validityState: boolean): void {\r\n ensureInitialized(FrameContexts.settings, FrameContexts.remove);\r\n sendMessageToParent('settings.setValidityState', [validityState]);\r\n }\r\n\r\n /**\r\n * Sets the config for the current instance.\r\n * This is an asynchronous operation; calls to getConfig are not guaranteed to reflect the changed state.\r\n * @param instanceConfig The desired config for this instance.\r\n * @returns Promise that resolves when the operation has completed.\r\n */\r\n export function setConfig(instanceConfig: InstanceConfig): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(FrameContexts.content, FrameContexts.settings, FrameContexts.sidePanel);\r\n resolve(send('settings.setSettings', instanceConfig));\r\n });\r\n }\r\n\r\n /**\r\n * Registers a handler for when the user attempts to save the settings. This handler should be used\r\n * to create or update the underlying resource powering the content.\r\n * The object passed to the handler must be used to notify whether to proceed with the save.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n * @param handler The handler to invoke when the user selects the save button.\r\n */\r\n export function registerOnSaveHandler(handler: (evt: SaveEvent) => void): void {\r\n ensureInitialized(FrameContexts.settings);\r\n saveHandler = handler;\r\n handler && sendMessageToParent('registerHandler', ['save']);\r\n }\r\n\r\n /**\r\n * Registers a handler for user attempts to remove content. This handler should be used\r\n * to remove the underlying resource powering the content.\r\n * The object passed to the handler must be used to indicate whether to proceed with the removal.\r\n * Only one handler may be registered at a time. Subsequent registrations will override the first.\r\n * @param handler The handler to invoke when the user selects the remove button.\r\n */\r\n export function registerOnRemoveHandler(handler: (evt: RemoveEvent) => void): void {\r\n ensureInitialized(FrameContexts.remove, FrameContexts.settings);\r\n removeHandler = handler;\r\n handler && sendMessageToParent('registerHandler', ['remove']);\r\n }\r\n\r\n function handleSave(result?: SaveParameters): void {\r\n const saveEvent = new SaveEventImpl(result);\r\n if (saveHandler) {\r\n saveHandler(saveEvent);\r\n } else {\r\n // If no handler is registered, we assume success.\r\n saveEvent.notifySuccess();\r\n }\r\n }\r\n\r\n /**\r\n * Registers a handler for when the user reconfigurated tab\r\n * @param handler The handler to invoke when the user click on Settings.\r\n */\r\n export function registerChangeConfigHandler(handler: () => void): void {\r\n ensureInitialized(FrameContexts.content);\r\n registerHandler('changeSettings', handler);\r\n }\r\n\r\n export interface SaveEvent {\r\n /**\r\n * Object containing properties passed as arguments to the settings.save event.\r\n */\r\n result: SaveParameters;\r\n /**\r\n * Indicates that the underlying resource has been created and the config can be saved.\r\n */\r\n notifySuccess(): void;\r\n /**\r\n * Indicates that creation of the underlying resource failed and that the config cannot be saved.\r\n * @param reason Specifies a reason for the failure. If provided, this string is displayed to the user; otherwise a generic error is displayed.\r\n */\r\n notifyFailure(reason?: string): void;\r\n }\r\n\r\n export interface RemoveEvent {\r\n /**\r\n * Indicates that the underlying resource has been removed and the content can be removed.\r\n */\r\n notifySuccess(): void;\r\n /**\r\n * Indicates that removal of the underlying resource failed and that the content cannot be removed.\r\n * @param reason Specifies a reason for the failure. If provided, this string is displayed to the user; otherwise a generic error is displayed.\r\n */\r\n notifyFailure(reason?: string): void;\r\n }\r\n\r\n export interface SaveParameters {\r\n /**\r\n * Connector's webhook Url returned as arguments to settings.save event as part of user clicking on Save\r\n */\r\n webhookUrl?: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs, since this class is not directly used.\r\n */\r\n class SaveEventImpl implements SaveEvent {\r\n public notified = false;\r\n public result: SaveParameters;\r\n public constructor(result?: SaveParameters) {\r\n this.result = result ? result : {};\r\n }\r\n public notifySuccess(): void {\r\n this.ensureNotNotified();\r\n sendMessageToParent('settings.save.success');\r\n this.notified = true;\r\n }\r\n public notifyFailure(reason?: string): void {\r\n this.ensureNotNotified();\r\n sendMessageToParent('settings.save.failure', [reason]);\r\n this.notified = true;\r\n }\r\n private ensureNotNotified(): void {\r\n if (this.notified) {\r\n throw new Error('The SaveEvent may only notify success or failure once.');\r\n }\r\n }\r\n }\r\n\r\n function handleRemove(): void {\r\n const removeEvent = new RemoveEventImpl();\r\n if (removeHandler) {\r\n removeHandler(removeEvent);\r\n } else {\r\n // If no handler is registered, we assume success.\r\n removeEvent.notifySuccess();\r\n }\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs, since this class is not directly used.\r\n */\r\n class RemoveEventImpl implements RemoveEvent {\r\n public notified = false;\r\n\r\n public notifySuccess(): void {\r\n this.ensureNotNotified();\r\n sendMessageToParent('settings.remove.success');\r\n this.notified = true;\r\n }\r\n\r\n public notifyFailure(reason?: string): void {\r\n this.ensureNotNotified();\r\n sendMessageToParent('settings.remove.failure', [reason]);\r\n this.notified = true;\r\n }\r\n\r\n private ensureNotNotified(): void {\r\n if (this.notified) {\r\n throw new Error('The removeEvent may only notify success or failure once.');\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Checks if pages.config capability is supported currently\r\n */\r\n export function isSupported(): boolean {\r\n return runtime.supports.pages ? (runtime.supports.pages.config ? true : false) : false;\r\n }\r\n }\r\n\r\n /**\r\n * Namespace to interact with the back-stack part of the SDK.\r\n */\r\n export namespace backStack {\r\n let backButtonPressHandler: () => boolean;\r\n\r\n export function _initialize(): void {\r\n registerHandler('backButtonPress', handleBackButtonPress, false);\r\n }\r\n\r\n /**\r\n * Navigates back in the hosted app. See registerBackButtonHandler for more information on when\r\n * it's appropriate to use this method.\r\n * @returns Promise that resolves when the navigation has completed.\r\n */\r\n export function navigateBack(): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized();\r\n const errorMessage = 'Back navigation is not supported in the current client or context.';\r\n resolve(sendAndDefaultError('navigateBack', errorMessage));\r\n });\r\n }\r\n\r\n /**\r\n * Registers a handler for user presses of the Team client's back button. Experiences that maintain an internal\r\n * navigation stack should use this handler to navigate the user back within their frame. If an app finds\r\n * that after running its back button handler it cannot handle the event it should call the navigateBack\r\n * method to ask the Teams client to handle it instead.\r\n * @param handler The handler to invoke when the user presses their Team client's back button.\r\n */\r\n export function registerBackButtonHandler(handler: () => boolean): void {\r\n backButtonPressHandler = handler;\r\n handler && sendMessageToParent('registerHandler', ['backButton']);\r\n }\r\n\r\n function handleBackButtonPress(): void {\r\n if (!backButtonPressHandler || !backButtonPressHandler()) {\r\n navigateBack();\r\n }\r\n }\r\n\r\n /**\r\n * Checks if pages.backStack capability is supported currently\r\n */\r\n export function isSupported(): boolean {\r\n return runtime.supports.pages ? (runtime.supports.pages.backStack ? true : false) : false;\r\n }\r\n }\r\n\r\n export namespace fullTrust {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Place the tab into full-screen mode.\r\n */\r\n export function enterFullscreen(): void {\r\n ensureInitialized(FrameContexts.content);\r\n sendMessageToParent('enterFullscreen', []);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Reverts the tab into normal-screen mode.\r\n */\r\n export function exitFullscreen(): void {\r\n ensureInitialized(FrameContexts.content);\r\n sendMessageToParent('exitFullscreen', []);\r\n }\r\n /**\r\n * Checks if pages.fullTrust capability is supported currently\r\n */\r\n export function isSupported(): boolean {\r\n return runtime.supports.pages ? (runtime.supports.pages.fullTrust ? true : false) : false;\r\n }\r\n }\r\n\r\n /**\r\n * Namespace to interact with the app button part of the SDK.\r\n */\r\n export namespace appButton {\r\n /**\r\n * Registers a handler for clicking the app button.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n * @param handler - The handler to invoke when the personal app button is clicked in the app bar.\r\n */\r\n export function onClick(handler: () => void): void {\r\n ensureInitialized(FrameContexts.content);\r\n registerHandler('appButtonClick', handler);\r\n }\r\n\r\n /**\r\n * Registers a handler for entering hover of the app button.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n * @param handler - The handler to invoke when entering hover of the personal app button in the app bar.\r\n */\r\n export function onHoverEnter(handler: () => void): void {\r\n ensureInitialized(FrameContexts.content);\r\n registerHandler('appButtonHoverEnter', handler);\r\n }\r\n\r\n /**\r\n * Registers a handler for exiting hover of the app button.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n * @param handler - The handler to invoke when exiting hover of the personal app button in the app bar.\r\n */\r\n export function onHoverLeave(handler: () => void): void {\r\n ensureInitialized(FrameContexts.content);\r\n registerHandler('appButtonHoverLeave', handler);\r\n }\r\n\r\n /**\r\n * Checks if pages.appButton capability is supported currently\r\n */\r\n export function isSupported(): boolean {\r\n return runtime.supports.pages ? (runtime.supports.pages.appButton ? true : false) : false;\r\n }\r\n }\r\n}\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\n\r\nimport { Communication, sendMessageEventToChild, sendMessageToParent } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { getGenericOnCompleteHandler } from '../internal/utils';\r\nimport { UserSettingTypes } from './interfaces';\r\n\r\n/**\r\n * @internal\r\n */\r\nexport function initializePrivateApis(): void {\r\n //Keeping this API for any future usage, wherein privateAPIs need to be initialized\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Upload a custom App manifest directly to both team and personal scopes.\r\n * This method works just for the first party Apps.\r\n *\r\n * @internal\r\n */\r\nexport function uploadCustomApp(manifestBlob: Blob, onComplete?: (status: boolean, reason?: string) => void): void {\r\n ensureInitialized();\r\n\r\n sendMessageToParent('uploadCustomApp', [manifestBlob], onComplete ? onComplete : getGenericOnCompleteHandler());\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Internal use only\r\n * Sends a custom action MessageRequest to Teams or parent window\r\n *\r\n * @param actionName - Specifies name of the custom action to be sent\r\n * @param args - Specifies additional arguments passed to the action\r\n * @param callback - Optionally specify a callback to receive response parameters from the parent\r\n * @returns id of sent message\r\n *\r\n * @internal\r\n */\r\nexport function sendCustomMessage(\r\n actionName: string,\r\n // tslint:disable-next-line:no-any\r\n args?: any[],\r\n // tslint:disable-next-line:no-any\r\n callback?: (...args: any[]) => void,\r\n): void {\r\n ensureInitialized();\r\n\r\n sendMessageToParent(actionName, args, callback);\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Internal use only\r\n * Sends a custom action MessageEvent to a child iframe/window, only if you are not using auth popup.\r\n * Otherwise it will go to the auth popup (which becomes the child)\r\n *\r\n * @param actionName - Specifies name of the custom action to be sent\r\n * @param args - Specifies additional arguments passed to the action\r\n * @returns id of sent message\r\n *\r\n * @internal\r\n */\r\nexport function sendCustomEvent(\r\n actionName: string,\r\n // tslint:disable-next-line:no-any\r\n args?: any[],\r\n): void {\r\n ensureInitialized();\r\n\r\n //validate childWindow\r\n if (!Communication.childWindow) {\r\n throw new Error('The child window has not yet been initialized or is not present');\r\n }\r\n sendMessageEventToChild(actionName, args);\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Internal use only\r\n * Adds a handler for an action sent by a child window or parent window\r\n *\r\n * @param actionName - Specifies name of the action message to handle\r\n * @param customHandler - The callback to invoke when the action message is received. The return value is sent to the child\r\n *\r\n * @internal\r\n */\r\nexport function registerCustomHandler(\r\n actionName: string,\r\n customHandler: (\r\n // tslint:disable-next-line:no-any\r\n ...args: any[]\r\n ) => any[],\r\n): void {\r\n ensureInitialized();\r\n registerHandler(actionName, (...args: any[]) => {\r\n return customHandler.apply(this, args);\r\n });\r\n}\r\n\r\n/**\r\n * @hidden\r\n * register a handler to be called when a user setting changes. The changed setting type & value is provided in the callback.\r\n *\r\n * @param settingTypes - List of user setting changes to subscribe\r\n * @param handler - When a subscribed setting is updated this handler is called\r\n *\r\n * @internal\r\n */\r\nexport function registerUserSettingsChangeHandler(\r\n settingTypes: UserSettingTypes[],\r\n handler: (settingType: UserSettingTypes, value: any) => void,\r\n): void {\r\n ensureInitialized();\r\n\r\n registerHandler('userSettingsChange', handler, true, [settingTypes]);\r\n}\r\n","import { debug as registerLogger, Debugger } from 'debug';\r\n\r\nconst topLevelLogger = registerLogger('teamsJs');\r\n\r\n/**\r\n * @internal\r\n *\r\n * Returns a logger for a given namespace, within the pre-defined top-level teamsJs namespace\r\n */\r\nexport function getLogger(namespace: string): Debugger {\r\n return topLevelLogger.extend(namespace);\r\n}\r\n","/* eslint-disable @typescript-eslint/ban-types */\r\n\r\nimport { LoadContext } from '../public';\r\nimport { pages } from '../public/pages';\r\nimport { Communication, sendMessageEventToChild, sendMessageToParent } from './communication';\r\nimport { getLogger } from './telemetry';\r\n\r\nconst handlersLogger = getLogger('handlers');\r\n\r\n/** @internal */\r\nclass HandlersPrivate {\r\n public static handlers: {\r\n [func: string]: Function;\r\n } = {};\r\n public static themeChangeHandler: (theme: string) => void;\r\n public static loadHandler: (context: LoadContext) => void;\r\n public static beforeUnloadHandler: (readyToUnload: () => void) => boolean;\r\n}\r\n\r\n/** @internal */\r\nexport function initializeHandlers(): void {\r\n // ::::::::::::::::::::MicrosoftTeams SDK Internal :::::::::::::::::\r\n HandlersPrivate.handlers['themeChange'] = handleThemeChange;\r\n HandlersPrivate.handlers['load'] = handleLoad;\r\n HandlersPrivate.handlers['beforeUnload'] = handleBeforeUnload;\r\n pages.backStack._initialize();\r\n}\r\n\r\nconst callHandlerLogger = handlersLogger.extend('callHandler');\r\n/** @internal */\r\nexport function callHandler(name: string, args?: unknown[]): [true, unknown] | [false, undefined] {\r\n const handler = HandlersPrivate.handlers[name];\r\n if (handler) {\r\n callHandlerLogger('Invoking the registered handler for message %s with arguments %o', name, args);\r\n const result = handler.apply(this, args);\r\n return [true, result];\r\n } else {\r\n callHandlerLogger('Handler for action message %s not found.', name);\r\n return [false, undefined];\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport function registerHandler(name: string, handler: Function, sendMessage = true, args: unknown[] = []): void {\r\n if (handler) {\r\n HandlersPrivate.handlers[name] = handler;\r\n sendMessage && sendMessageToParent('registerHandler', [name, ...args]);\r\n } else {\r\n delete HandlersPrivate.handlers[name];\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport function removeHandler(name: string): void {\r\n delete HandlersPrivate.handlers[name];\r\n}\r\n\r\n/** @internal */\r\nexport function registerOnThemeChangeHandler(handler: (theme: string) => void): void {\r\n HandlersPrivate.themeChangeHandler = handler;\r\n handler && sendMessageToParent('registerHandler', ['themeChange']);\r\n}\r\n\r\n/** @internal */\r\nexport function handleThemeChange(theme: string): void {\r\n if (HandlersPrivate.themeChangeHandler) {\r\n HandlersPrivate.themeChangeHandler(theme);\r\n }\r\n\r\n if (Communication.childWindow) {\r\n sendMessageEventToChild('themeChange', [theme]);\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport function registerOnLoadHandler(handler: (context: LoadContext) => void): void {\r\n HandlersPrivate.loadHandler = handler;\r\n handler && sendMessageToParent('registerHandler', ['load']);\r\n}\r\n\r\n/** @internal */\r\nfunction handleLoad(context: LoadContext): void {\r\n if (HandlersPrivate.loadHandler) {\r\n HandlersPrivate.loadHandler(context);\r\n }\r\n\r\n if (Communication.childWindow) {\r\n sendMessageEventToChild('load', [context]);\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport function registerBeforeUnloadHandler(handler: (readyToUnload: () => void) => boolean): void {\r\n HandlersPrivate.beforeUnloadHandler = handler;\r\n handler && sendMessageToParent('registerHandler', ['beforeUnload']);\r\n}\r\n\r\n/** @internal */\r\nfunction handleBeforeUnload(): void {\r\n const readyToUnload = (): void => {\r\n sendMessageToParent('readyToUnload', []);\r\n };\r\n\r\n if (!HandlersPrivate.beforeUnloadHandler || !HandlersPrivate.beforeUnloadHandler(readyToUnload)) {\r\n readyToUnload();\r\n }\r\n}\r\n","/* eslint-disable @typescript-eslint/ban-types */\r\n/* eslint-disable @typescript-eslint/no-explicit-any */\r\n\r\nimport { FrameContexts } from '../public/constants';\r\nimport { SdkError } from '../public/interfaces';\r\nimport { version } from './constants';\r\nimport { GlobalVars } from './globalVars';\r\nimport { callHandler } from './handlers';\r\nimport { DOMMessageEvent, ExtendedWindow, MessageRequest, MessageResponse } from './interfaces';\r\nimport { getLogger } from './telemetry';\r\nimport { validateOrigin } from './utils';\r\n\r\nconst communicationLogger = getLogger('communication');\r\n\r\n/**@internal */\r\nexport class Communication {\r\n public static currentWindow: Window | any;\r\n public static parentOrigin: string;\r\n public static parentWindow: Window | any;\r\n public static childWindow: Window;\r\n public static childOrigin: string;\r\n}\r\n\r\n/**@internal */\r\nclass CommunicationPrivate {\r\n public static parentMessageQueue: MessageRequest[] = [];\r\n public static childMessageQueue: MessageRequest[] = [];\r\n public static nextMessageId = 0;\r\n public static callbacks: {\r\n [id: number]: Function; // (arg1, arg2, ...etc) => void\r\n } = {};\r\n public static promiseCallbacks: {\r\n [id: number]: Function; // (args[]) => void\r\n } = {};\r\n public static messageListener: Function;\r\n}\r\n\r\n/**@internal */\r\ninterface InitializeResponse {\r\n context: FrameContexts;\r\n clientType: string;\r\n runtimeConfig: string;\r\n clientSupportedSDKVersion: string;\r\n}\r\n\r\n/**@internal */\r\nexport function initializeCommunication(validMessageOrigins: string[] | undefined): Promise<InitializeResponse> {\r\n // Listen for messages post to our window\r\n CommunicationPrivate.messageListener = (evt: DOMMessageEvent): void => processMessage(evt);\r\n\r\n // If we are in an iframe, our parent window is the one hosting us (i.e., window.parent); otherwise,\r\n // it's the window that opened us (i.e., window.opener)\r\n Communication.currentWindow = Communication.currentWindow || window;\r\n Communication.parentWindow =\r\n Communication.currentWindow.parent !== Communication.currentWindow.self\r\n ? Communication.currentWindow.parent\r\n : Communication.currentWindow.opener;\r\n\r\n // Listen to messages from the parent or child frame.\r\n // Frameless windows will only receive this event from child frames and if validMessageOrigins is passed.\r\n if (Communication.parentWindow || validMessageOrigins) {\r\n Communication.currentWindow.addEventListener('message', CommunicationPrivate.messageListener, false);\r\n }\r\n\r\n if (!Communication.parentWindow) {\r\n const extendedWindow = (Communication.currentWindow as unknown) as ExtendedWindow;\r\n if (extendedWindow.nativeInterface) {\r\n GlobalVars.isFramelessWindow = true;\r\n extendedWindow.onNativeMessage = handleParentMessage;\r\n } else {\r\n // at this point we weren't able to find a parent to talk to, no way initialization will succeed\r\n return Promise.reject(new Error('Initialization Failed. No Parent window found.'));\r\n }\r\n }\r\n\r\n try {\r\n // Send the initialized message to any origin, because at this point we most likely don't know the origin\r\n // of the parent window, and this message contains no data that could pose a security risk.\r\n Communication.parentOrigin = '*';\r\n return sendMessageToParentAsync<[FrameContexts, string, string, string]>('initialize', [version]).then(\r\n ([context, clientType, runtimeConfig, clientSupportedSDKVersion]: [FrameContexts, string, string, string]) => {\r\n return { context, clientType, runtimeConfig, clientSupportedSDKVersion };\r\n },\r\n );\r\n } finally {\r\n Communication.parentOrigin = null;\r\n }\r\n}\r\n\r\n/**@internal */\r\nexport function uninitializeCommunication(): void {\r\n Communication.currentWindow.removeEventListener('message', CommunicationPrivate.messageListener, false);\r\n\r\n Communication.parentWindow = null;\r\n Communication.parentOrigin = null;\r\n Communication.childWindow = null;\r\n Communication.childOrigin = null;\r\n CommunicationPrivate.parentMessageQueue = [];\r\n CommunicationPrivate.childMessageQueue = [];\r\n CommunicationPrivate.nextMessageId = 0;\r\n CommunicationPrivate.callbacks = {};\r\n}\r\n\r\n/**@internal */\r\nexport function sendAndUnwrap<T>(actionName: string, ...args: any[]): Promise<T> {\r\n return sendMessageToParentAsync(actionName, args).then(([result]: [T]) => result);\r\n}\r\n\r\nexport function sendAndHandleStatusAndReason(actionName: string, ...args: any[]): Promise<void> {\r\n return sendMessageToParentAsync(actionName, args).then(([status, reason]: [boolean, string]) => {\r\n if (!status) {\r\n throw new Error(reason);\r\n }\r\n });\r\n}\r\n\r\n/**@internal */\r\nexport function sendAndHandleStatusAndReasonWithDefaultError(\r\n actionName: string,\r\n defaultError: string,\r\n ...args: any[]\r\n): Promise<void> {\r\n return sendMessageToParentAsync(actionName, args).then(([status, reason]: [boolean, string]) => {\r\n if (!status) {\r\n throw new Error(reason ? reason : defaultError);\r\n }\r\n });\r\n}\r\n\r\n/**@internal */\r\nexport function sendAndHandleSdkError<T>(actionName: string, ...args: any[]): Promise<T> {\r\n return sendMessageToParentAsync(actionName, args).then(([error, result]: [SdkError, T]) => {\r\n if (error) {\r\n throw error;\r\n }\r\n return result;\r\n });\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Send a message to parent. Uses nativeInterface on mobile to communicate with parent context\r\n *\r\n * @internal\r\n */\r\nexport function sendMessageToParentAsync<T>(actionName: string, args: any[] = undefined): Promise<T> {\r\n return new Promise(resolve => {\r\n const request = sendMessageToParentHelper(actionName, args);\r\n resolve(waitForResponse<T>(request.id));\r\n });\r\n}\r\n\r\n/**@internal */\r\nfunction waitForResponse<T>(requestId: number): Promise<T> {\r\n return new Promise<T>(resolve => {\r\n CommunicationPrivate.promiseCallbacks[requestId] = resolve;\r\n });\r\n}\r\n\r\n/**@internal */\r\nexport function sendMessageToParent(actionName: string, callback?: Function): void;\r\n\r\n/**\r\n * @hidden\r\n * Send a message to parent. Uses nativeInterface on mobile to communicate with parent context\r\n *\r\n * @internal\r\n */\r\nexport function sendMessageToParent(actionName: string, args: any[], callback?: Function): void;\r\n\r\n/**@internal */\r\nexport function sendMessageToParent(actionName: string, argsOrCallback?: any[] | Function, callback?: Function): void {\r\n let args: any[] | undefined;\r\n if (argsOrCallback instanceof Function) {\r\n callback = argsOrCallback;\r\n } else if (argsOrCallback instanceof Array) {\r\n args = argsOrCallback;\r\n }\r\n\r\n const request = sendMessageToParentHelper(actionName, args);\r\n if (callback) {\r\n CommunicationPrivate.callbacks[request.id] = callback;\r\n }\r\n}\r\n\r\nconst sendMessageToParentHelperLogger = communicationLogger.extend('sendMessageToParentHelper');\r\n\r\n/**@internal */\r\nfunction sendMessageToParentHelper(actionName: string, args: any[]): MessageRequest {\r\n const logger = sendMessageToParentHelperLogger;\r\n\r\n const targetWindow = Communication.parentWindow;\r\n const request = createMessageRequest(actionName, args);\r\n\r\n logger('Message %i information: %o', request.id, { actionName, args });\r\n\r\n if (GlobalVars.isFramelessWindow) {\r\n if (Communication.currentWindow && Communication.currentWindow.nativeInterface) {\r\n logger('Sending message %i to parent via framelessPostMessage interface', request.id);\r\n (Communication.currentWindow as ExtendedWindow).nativeInterface.framelessPostMessage(JSON.stringify(request));\r\n }\r\n } else {\r\n const targetOrigin = getTargetOrigin(targetWindow);\r\n\r\n // If the target window isn't closed and we already know its origin, send the message right away; otherwise,\r\n // queue the message and send it after the origin is established\r\n if (targetWindow && targetOrigin) {\r\n logger('Sending message %i to parent via postMessage', request.id);\r\n targetWindow.postMessage(request, targetOrigin);\r\n } else {\r\n logger('Adding message %i to parent message queue', request.id);\r\n getTargetMessageQueue(targetWindow).push(request);\r\n }\r\n }\r\n return request;\r\n}\r\n\r\n/**@internal */\r\nexport function processMessage(evt: DOMMessageEvent): void {\r\n // Process only if we received a valid message\r\n if (!evt || !evt.data || typeof evt.data !== 'object') {\r\n return;\r\n }\r\n\r\n // Process only if the message is coming from a different window and a valid origin\r\n // valid origins are either a pre-known\r\n const messageSource = evt.source || (evt.originalEvent && evt.originalEvent.source);\r\n const messageOrigin = evt.origin || (evt.originalEvent && evt.originalEvent.origin);\r\n if (!shouldProcessMessage(messageSource, messageOrigin)) {\r\n return;\r\n }\r\n\r\n // Update our parent and child relationships based on this message\r\n updateRelationships(messageSource, messageOrigin);\r\n\r\n // Handle the message\r\n if (messageSource === Communication.parentWindow) {\r\n handleParentMessage(evt);\r\n } else if (messageSource === Communication.childWindow) {\r\n handleChildMessage(evt);\r\n }\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Validates the message source and origin, if it should be processed\r\n *\r\n * @internal\r\n */\r\nexport function shouldProcessMessage(messageSource: Window, messageOrigin: string): boolean {\r\n // Process if message source is a different window and if origin is either in\r\n // Teams' pre-known whitelist or supplied as valid origin by user during initialization\r\n if (Communication.currentWindow && messageSource === Communication.currentWindow) {\r\n return false;\r\n } else if (\r\n Communication.currentWindow &&\r\n Communication.currentWindow.location &&\r\n messageOrigin &&\r\n messageOrigin === Communication.currentWindow.location.origin\r\n ) {\r\n return true;\r\n } else {\r\n return validateOrigin(new URL(messageOrigin));\r\n }\r\n}\r\n\r\n/**@internal */\r\nfunction updateRelationships(messageSource: Window, messageOrigin: string): void {\r\n // Determine whether the source of the message is our parent or child and update our\r\n // window and origin pointer accordingly\r\n // For frameless windows (i.e mobile), there is no parent frame, so the message must be from the child.\r\n if (\r\n !GlobalVars.isFramelessWindow &&\r\n (!Communication.parentWindow || Communication.parentWindow.closed || messageSource === Communication.parentWindow)\r\n ) {\r\n Communication.parentWindow = messageSource;\r\n Communication.parentOrigin = messageOrigin;\r\n } else if (\r\n !Communication.childWindow ||\r\n Communication.childWindow.closed ||\r\n messageSource === Communication.childWindow\r\n ) {\r\n Communication.childWindow = messageSource;\r\n Communication.childOrigin = messageOrigin;\r\n }\r\n\r\n // Clean up pointers to closed parent and child windows\r\n if (Communication.parentWindow && Communication.parentWindow.closed) {\r\n Communication.parentWindow = null;\r\n Communication.parentOrigin = null;\r\n }\r\n if (Communication.childWindow && Communication.childWindow.closed) {\r\n Communication.childWindow = null;\r\n Communication.childOrigin = null;\r\n }\r\n\r\n // If we have any messages in our queue, send them now\r\n flushMessageQueue(Communication.parentWindow);\r\n flushMessageQueue(Communication.childWindow);\r\n}\r\n\r\nconst handleParentMessageLogger = communicationLogger.extend('handleParentMessage');\r\n\r\n/**@internal */\r\nfunction handleParentMessage(evt: DOMMessageEvent): void {\r\n const logger = handleParentMessageLogger;\r\n\r\n if ('id' in evt.data && typeof evt.data.id === 'number') {\r\n // Call any associated Communication.callbacks\r\n const message = evt.data as MessageResponse;\r\n const callback = CommunicationPrivate.callbacks[message.id];\r\n logger('Received a response from parent for message %i', message.id);\r\n if (callback) {\r\n logger('Invoking the registered callback for message %i with arguments %o', message.id, message.args);\r\n callback.apply(null, [...message.args, message.isPartialResponse]);\r\n\r\n // Remove the callback to ensure that the callback is called only once and to free up memory if response is a complete response\r\n if (!isPartialResponse(evt)) {\r\n logger('Removing registered callback for message %i', message.id);\r\n delete CommunicationPrivate.callbacks[message.id];\r\n }\r\n }\r\n const promiseCallback = CommunicationPrivate.promiseCallbacks[message.id];\r\n if (promiseCallback) {\r\n logger('Invoking the registered promise callback for message %i with arguments %o', message.id, message.args);\r\n promiseCallback(message.args);\r\n\r\n logger('Removing registered promise callback for message %i', message.id);\r\n delete CommunicationPrivate.promiseCallbacks[message.id];\r\n }\r\n } else if ('func' in evt.data && typeof evt.data.func === 'string') {\r\n // Delegate the request to the proper handler\r\n const message = evt.data as MessageRequest;\r\n logger('Received an action message %s from parent', message.func);\r\n callHandler(message.func, message.args);\r\n } else {\r\n logger('Received an unknown message: %O', evt);\r\n }\r\n}\r\n\r\n/**@internal */\r\nfunction isPartialResponse(evt: DOMMessageEvent): boolean {\r\n return evt.data.isPartialResponse === true;\r\n}\r\n\r\n/**@internal */\r\nfunction handleChildMessage(evt: DOMMessageEvent): void {\r\n if ('id' in evt.data && 'func' in evt.data) {\r\n // Try to delegate the request to the proper handler, if defined\r\n const message = evt.data as MessageRequest;\r\n const [called, result] = callHandler(message.func, message.args);\r\n if (called && typeof result !== 'undefined') {\r\n sendMessageResponseToChild(message.id, Array.isArray(result) ? result : [result]);\r\n } else {\r\n // No handler, proxy to parent\r\n // tslint:disable-next-line:no-any\r\n sendMessageToParent(message.func, message.args, (...args: any[]): void => {\r\n if (Communication.childWindow) {\r\n const isPartialResponse = args.pop();\r\n sendMessageResponseToChild(message.id, args, isPartialResponse);\r\n }\r\n });\r\n }\r\n }\r\n}\r\n\r\n/**@internal */\r\nfunction getTargetMessageQueue(targetWindow: Window): MessageRequest[] {\r\n return targetWindow === Communication.parentWindow\r\n ? CommunicationPrivate.parentMessageQueue\r\n : targetWindow === Communication.childWindow\r\n ? CommunicationPrivate.childMessageQueue\r\n : [];\r\n}\r\n\r\n/**@internal */\r\nfunction getTargetOrigin(targetWindow: Window): string {\r\n return targetWindow === Communication.parentWindow\r\n ? Communication.parentOrigin\r\n : targetWindow === Communication.childWindow\r\n ? Communication.childOrigin\r\n : null;\r\n}\r\n\r\nconst flushMessageQueueLogger = communicationLogger.extend('flushMessageQueue');\r\n/**@internal */\r\nfunction flushMessageQueue(targetWindow: Window | any): void {\r\n const targetOrigin = getTargetOrigin(targetWindow);\r\n const targetMessageQueue = getTargetMessageQueue(targetWindow);\r\n const target = targetWindow == Communication.parentWindow ? 'parent' : 'child';\r\n while (targetWindow && targetOrigin && targetMessageQueue.length > 0) {\r\n const request = targetMessageQueue.shift();\r\n flushMessageQueueLogger('Flushing message %i from ' + target + ' message queue via postMessage.', request.id);\r\n targetWindow.postMessage(request, targetOrigin);\r\n }\r\n}\r\n\r\n/**@internal */\r\nexport function waitForMessageQueue(targetWindow: Window, callback: () => void): void {\r\n const messageQueueMonitor = Communication.currentWindow.setInterval(() => {\r\n if (getTargetMessageQueue(targetWindow).length === 0) {\r\n clearInterval(messageQueueMonitor);\r\n callback();\r\n }\r\n }, 100);\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Send a response to child for a message request that was from child\r\n *\r\n * @internal\r\n */\r\nfunction sendMessageResponseToChild(\r\n id: number,\r\n // tslint:disable-next-line:no-any\r\n args?: any[],\r\n isPartialResponse?: boolean,\r\n): void {\r\n const targetWindow = Communication.childWindow;\r\n const response = createMessageResponse(id, args, isPartialResponse);\r\n const targetOrigin = getTargetOrigin(targetWindow);\r\n if (targetWindow && targetOrigin) {\r\n targetWindow.postMessage(response, targetOrigin);\r\n }\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Send a custom message object that can be sent to child window,\r\n * instead of a response message to a child\r\n *\r\n * @internal\r\n */\r\nexport function sendMessageEventToChild(\r\n actionName: string,\r\n // tslint:disable-next-line: no-any\r\n args?: any[],\r\n): void {\r\n const targetWindow = Communication.childWindow;\r\n const customEvent = createMessageEvent(actionName, args);\r\n const targetOrigin = getTargetOrigin(targetWindow);\r\n\r\n // If the target window isn't closed and we already know its origin, send the message right away; otherwise,\r\n // queue the message and send it after the origin is established\r\n if (targetWindow && targetOrigin) {\r\n targetWindow.postMessage(customEvent, targetOrigin);\r\n } else {\r\n getTargetMessageQueue(targetWindow).push(customEvent);\r\n }\r\n}\r\n\r\n/**@internal */\r\n// tslint:disable-next-line:no-any\r\nfunction createMessageRequest(func: string, args: any[]): MessageRequest {\r\n return {\r\n id: CommunicationPrivate.nextMessageId++,\r\n func: func,\r\n timestamp: Date.now(),\r\n args: args || [],\r\n };\r\n}\r\n\r\n/**@internal */\r\n// tslint:disable-next-line:no-any\r\nfunction createMessageResponse(id: number, args: any[], isPartialResponse: boolean): MessageResponse {\r\n return {\r\n id: id,\r\n args: args || [],\r\n isPartialResponse,\r\n };\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Creates a message object without any id, used for custom actions being sent to child frame/window\r\n *\r\n * @internal\r\n */\r\n// tslint:disable-next-line:no-any\r\nfunction createMessageEvent(func: string, args: any[]): MessageRequest {\r\n return {\r\n func: func,\r\n args: args || [],\r\n };\r\n}\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\n\r\nimport { sendMessageToParent } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { runtime } from '../public/runtime';\r\n\r\n/**\r\n * @hidden\r\n * Namespace to interact with bots using the SDK.\r\n *\r\n * @alpha\r\n */\r\nexport namespace bot {\r\n /**\r\n * @hidden\r\n * Hide from docs until release.\r\n * ------\r\n * Sends query to bot in order to retrieve data.\r\n *\r\n * @param botRequest - query to send to bot.\r\n * @param onSuccess - callback to invoke when data is retrieved from bot\r\n * @param onError - callback to invoke should an error occur\r\n */\r\n export function sendQuery(\r\n botRequest: QueryRequest,\r\n onSuccess?: (data: QueryResponse) => void,\r\n onError?: (error: string) => void,\r\n ): void {\r\n ensureInitialized();\r\n\r\n sendMessageToParent('bot.executeQuery', [botRequest], (success: boolean, response: string | QueryResponse) => {\r\n if (success) {\r\n onSuccess(response as QueryResponse);\r\n } else {\r\n onError(response as string);\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs until release.\r\n * -----\r\n * Retrieves list of support commands from bot\r\n *\r\n * @param onSuccess - callback to invoke when data is retrieved from bot\r\n * @param onError - callback to invoke should an error occur\r\n */\r\n export function getSupportedCommands(\r\n onSuccess?: (response: Command[]) => void,\r\n onError?: (error: string) => void,\r\n ): void {\r\n ensureInitialized();\r\n\r\n sendMessageToParent('bot.getSupportedCommands', (success: boolean, response: string | Command[]) => {\r\n if (success) {\r\n onSuccess(response as Command[]);\r\n } else {\r\n onError(response as string);\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs until release.\r\n * -----\r\n * Authenticates a user for json tab\r\n *\r\n * @param authRequest - callback to invoke when data is retrieved from bot\r\n * @param onSuccess - callback to invoke when user is authenticated\r\n * @param onError - callback to invoke should an error occur\r\n */\r\n export function authenticate(\r\n authRequest: AuthQueryRequest,\r\n onSuccess?: (results: Results) => void,\r\n onError?: (error: string) => void,\r\n ): void {\r\n ensureInitialized();\r\n\r\n sendMessageToParent('bot.authenticate', [authRequest], (success: boolean, response: string | Results) => {\r\n if (success) {\r\n onSuccess(response as Results);\r\n } else {\r\n onError(response as string);\r\n }\r\n });\r\n }\r\n\r\n export interface QueryRequest {\r\n /**\r\n * @hidden\r\n * Query to search for\r\n */\r\n query: string;\r\n commandId?: string;\r\n option?: {\r\n skip: number;\r\n count: number;\r\n };\r\n }\r\n\r\n export interface Results {\r\n attachments: Attachment[];\r\n layout: any;\r\n botId: string;\r\n }\r\n\r\n export interface Auth {\r\n url: string;\r\n title: string;\r\n }\r\n\r\n export type ResponseType = 'Results' | 'Auth';\r\n interface Response<T extends ResponseType> {\r\n type: T;\r\n }\r\n export interface ResultResponse extends Response<'Results'> {\r\n data: Results;\r\n }\r\n export interface AuthResponse extends Response<'Auth'> {\r\n data: Auth;\r\n }\r\n export type QueryResponse = ResultResponse | AuthResponse;\r\n\r\n export interface AuthQueryRequest extends QueryRequest {\r\n url: string;\r\n }\r\n\r\n export interface Attachment {\r\n card: any;\r\n previewCard: any;\r\n previewRawPayload: any;\r\n rawPayload: any;\r\n }\r\n\r\n export interface Command {\r\n title: string;\r\n id: string;\r\n initialRun: boolean;\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.bot ? true : false;\r\n }\r\n}\r\n","import { FileOpenPreference, TeamInformation } from '../public/interfaces';\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Information about all members in a chat\r\n *\r\n * @alpha\r\n */\r\nexport interface ChatMembersInformation {\r\n members: ThreadMember[];\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Information about a chat member\r\n *\r\n * @alpha\r\n */\r\nexport interface ThreadMember {\r\n /**\r\n * @hidden\r\n * The member's user principal name in the current tenant.\r\n */\r\n upn: string;\r\n}\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport enum NotificationTypes {\r\n fileDownloadStart = 'fileDownloadStart',\r\n fileDownloadComplete = 'fileDownloadComplete',\r\n}\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport interface ShowNotificationParameters {\r\n message: string;\r\n notificationType: NotificationTypes;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * @alpha\r\n */\r\nexport enum ViewerActionTypes {\r\n view = 'view',\r\n edit = 'edit',\r\n editNew = 'editNew',\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * User setting changes that can be subscribed to,\r\n * @alpha\r\n */\r\nexport enum UserSettingTypes {\r\n /**\r\n * @hidden\r\n * Use this key to subscribe to changes in user's file open preference\r\n */\r\n fileOpenPreference = 'fileOpenPreference',\r\n /**\r\n * @hidden\r\n * Use this key to subscribe to theme changes\r\n */\r\n theme = 'theme',\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * @alpha\r\n */\r\nexport interface FilePreviewParameters {\r\n /**\r\n * @hidden\r\n * The developer-defined unique ID for the file.\r\n */\r\n entityId: string;\r\n\r\n /**\r\n * @hidden\r\n * The display name of the file.\r\n */\r\n title: string;\r\n\r\n /**\r\n * @hidden\r\n * An optional description of the file.\r\n */\r\n description?: string;\r\n\r\n /**\r\n * @hidden\r\n * The file extension; e.g. pptx, docx, etc.\r\n */\r\n type: string;\r\n\r\n /**\r\n * @hidden\r\n * A url to the source of the file, used to open the content in the user's default browser\r\n */\r\n objectUrl: string;\r\n\r\n /**\r\n * @hidden\r\n * Optional; an alternate self-authenticating url used to preview the file in Mobile clients and offer it for download by the user\r\n */\r\n downloadUrl?: string;\r\n\r\n /**\r\n * @hidden\r\n * Optional; an alternate url optimized for previewing the file in web and desktop clients\r\n */\r\n webPreviewUrl?: string;\r\n\r\n /**\r\n * @hidden\r\n * Optional; an alternate url that allows editing of the file in web and desktop clients\r\n */\r\n webEditUrl?: string;\r\n\r\n /**\r\n * @hidden\r\n * Optional; the base url of the site where the file is hosted\r\n */\r\n baseUrl?: string;\r\n\r\n /**\r\n * @hidden\r\n * Deprecated; prefer using viewerAction instead\r\n * Optional; indicates whether the file should be opened in edit mode\r\n */\r\n editFile?: boolean;\r\n\r\n /**\r\n * @hidden\r\n * Optional; the developer-defined unique ID for the sub-entity to return to when the file stage closes.\r\n * This field should be used to restore to a specific state within an entity, such as scrolling to or activating a specific piece of content.\r\n */\r\n subEntityId?: string;\r\n\r\n /**\r\n * @hidden\r\n * Optional; indicates the mode in which file should be opened. Takes precedence over edit mode.\r\n */\r\n viewerAction?: ViewerActionTypes;\r\n\r\n /**\r\n * @hidden\r\n * Optional; indicates how user prefers to open the file\r\n */\r\n fileOpenPreference?: FileOpenPreference;\r\n\r\n /**\r\n * Optional; id required to enable conversation button in files. Will be channel id in case file is shared in a channel or the chat id in p2p chat case.\r\n */\r\n conversationId?: string;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Query parameters used when fetching team information\r\n * @alpha\r\n */\r\nexport interface TeamInstanceParameters {\r\n /**\r\n * @hidden\r\n * Flag allowing to select favorite teams only\r\n */\r\n favoriteTeamsOnly?: boolean;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Information on userJoined Teams\r\n * @alpha\r\n */\r\nexport interface UserJoinedTeamsInformation {\r\n /**\r\n * @hidden\r\n * List of team information\r\n */\r\n userJoinedTeams: TeamInformation[];\r\n}\r\n","import {\r\n sendAndHandleStatusAndReason as sendAndHandleError,\r\n sendAndUnwrap,\r\n sendMessageToParent,\r\n} from '../internal/communication';\r\nimport { registerHandler, removeHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from '../public/constants';\r\nimport { OpenConversationRequest } from '../public/interfaces';\r\nimport { runtime } from '../public/runtime';\r\nimport { ChatMembersInformation } from './interfaces';\r\n\r\n/**\r\n * @hidden\r\n * Namespace to interact with the conversational subEntities inside the tab\r\n *\r\n * @alpha\r\n */\r\nexport namespace chat {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------------\r\n * Allows the user to start or continue a conversation with each subentity inside the tab\r\n *\r\n * @returns Promise resolved upon completion\r\n */\r\n export function openConversation(openConversationRequest: OpenConversationRequest): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n const sendPromise = sendAndHandleError('conversations.openConversation', {\r\n title: openConversationRequest.title,\r\n subEntityId: openConversationRequest.subEntityId,\r\n conversationId: openConversationRequest.conversationId,\r\n channelId: openConversationRequest.channelId,\r\n entityId: openConversationRequest.entityId,\r\n });\r\n if (openConversationRequest.onStartConversation) {\r\n registerHandler(\r\n 'startConversation',\r\n (subEntityId: string, conversationId: string, channelId: string, entityId: string) =>\r\n openConversationRequest.onStartConversation({\r\n subEntityId,\r\n conversationId,\r\n channelId,\r\n entityId,\r\n }),\r\n );\r\n }\r\n if (openConversationRequest.onCloseConversation) {\r\n registerHandler(\r\n 'closeConversation',\r\n (subEntityId: string, conversationId?: string, channelId?: string, entityId?: string) =>\r\n openConversationRequest.onCloseConversation({\r\n subEntityId,\r\n conversationId,\r\n channelId,\r\n entityId,\r\n }),\r\n );\r\n }\r\n resolve(sendPromise);\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------------\r\n * Allows the user to close the conversation in the right pane\r\n */\r\n export function closeConversation(): void {\r\n ensureInitialized(FrameContexts.content);\r\n sendMessageToParent('conversations.closeConversation');\r\n removeHandler('startConversation');\r\n removeHandler('closeConversation');\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Allows an app to retrieve information of all chat members\r\n * Because a malicious party run your content in a browser, this value should\r\n * be used only as a hint as to who the members are and never as proof of membership.\r\n *\r\n * @param callback The callback to invoke when the {@link ChatMembersInformation} object is retrieved.\r\n * @returns Promise resolved with information on all chat members\r\n *\r\n * @internal\r\n */\r\n export function getChatMembers(): Promise<ChatMembersInformation> {\r\n return new Promise<ChatMembersInformation>(resolve => {\r\n ensureInitialized();\r\n resolve(sendAndUnwrap('getChatMembers'));\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.chat ? true : false;\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from './constants';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace appInstallDialog {\r\n export interface OpenAppInstallDialogParams {\r\n appId: string;\r\n }\r\n\r\n export function openAppInstallDialog(openAPPInstallDialogParams: OpenAppInstallDialogParams): Promise<void> {\r\n return new Promise(resolve => {\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.settings,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n if (!isSupported()) {\r\n throw new Error('Not supported');\r\n }\r\n sendMessageToParent('appInstallDialog.openAppInstallDialog', [openAPPInstallDialogParams]);\r\n resolve();\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.appInstallDialog ? true : false;\r\n }\r\n}\r\n","/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\r\n/* eslint-disable @typescript-eslint/no-explicit-any */\r\n/* eslint-disable @typescript-eslint/ban-types */\r\n\r\nimport { sendAndHandleStatusAndReason as send } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from './constants';\r\n/**\r\n * @alpha\r\n */\r\nexport interface IAppWindow {\r\n /**\r\n * Send a message to the AppWindow.\r\n * @param message - The message to send\r\n * @returns Promise that will be fulfilled when the AppWindow posts back a response\r\n */\r\n postMessage(message: any): Promise<void>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link IAppWindow.postMessage IAppWindow.postMessage(message: any): Promise\\<void\\>} instead.\r\n * @param message - The message to send\r\n * @param onComplete - The deprecated way of invoking a callback to know if the postMessage has been success/failed.\r\n */\r\n postMessage(message: any, onComplete?: (status: boolean, reason?: string) => void): void;\r\n\r\n /**\r\n * Add a listener that will be called when an event is received from this AppWindow.\r\n *\r\n * @param type - The event to listen to. Currently the only supported type is 'message'.\r\n * @param listener - The listener that will be called\r\n */\r\n addEventListener(type: string, listener: Function): void;\r\n}\r\n\r\nexport class ChildAppWindow implements IAppWindow {\r\n /**\r\n * Send a message to the AppWindow.\r\n * @param message - The message to send\r\n * @returns Promise that will be fulfilled when the AppWindow posts back a response\r\n */\r\n public postMessage(message: any): Promise<void>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link ChildAppWindow.postMessage ChildAppWindow.postMessage(message: any): Promise\\<void\\>} instead.\r\n * @param message - The message to send\r\n * @param onComplete - The deprecated way of invoking a callback to know if the postMessage has been success/failed.\r\n */\r\n public postMessage(message: any, onComplete: (status: boolean, reason?: string) => void): void;\r\n public postMessage(message: any, onComplete?: (status: boolean, reason?: string) => void): Promise<void> {\r\n ensureInitialized();\r\n return this.postMessageHelper(message)\r\n .then(() => {\r\n if (onComplete) {\r\n onComplete(true);\r\n }\r\n })\r\n .catch((err: Error) => {\r\n if (onComplete) {\r\n onComplete(false, err.message);\r\n return;\r\n }\r\n throw err;\r\n });\r\n }\r\n public postMessageHelper(message: any): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n resolve(send('messageForChild', message));\r\n });\r\n }\r\n\r\n public addEventListener(type: string, listener: (message: any) => void): void {\r\n if (type === 'message') {\r\n registerHandler('messageForParent', listener);\r\n }\r\n }\r\n}\r\n\r\nexport class ParentAppWindow implements IAppWindow {\r\n private static _instance: ParentAppWindow;\r\n public static get Instance(): IAppWindow {\r\n // Do you need arguments? Make it a regular method instead.\r\n return this._instance || (this._instance = new this());\r\n }\r\n\r\n /**\r\n * Send a message to the AppWindow.\r\n * @param message - The message to send\r\n * @returns Promise that will be fulfilled when the AppWindow posts back a response\r\n */\r\n public postMessage(message: any): Promise<void>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link ParentAppWindow.postMessage ParentAppWindow.postMessage(message: any): Promise\\<void\\>} instead.\r\n * @param message - The message to send\r\n * @param onComplete - The deprecated way of invoking a callback to know if the postMessage has been success/failed.\r\n */\r\n public postMessage(message: any, onComplete: (status: boolean, reason?: string) => void): void;\r\n public postMessage(message: any, onComplete?: (status: boolean, reason?: string) => void): Promise<void> {\r\n ensureInitialized(FrameContexts.task);\r\n return this.postMessageHelper(message)\r\n .then(() => {\r\n if (onComplete) {\r\n onComplete(true);\r\n }\r\n })\r\n .catch((err: Error) => {\r\n if (onComplete) {\r\n onComplete(false, err.message);\r\n return;\r\n }\r\n throw err;\r\n });\r\n }\r\n public postMessageHelper(message: any): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n resolve(send('messageForParent', message));\r\n });\r\n }\r\n\r\n public addEventListener(type: string, listener: (message: any) => void): void {\r\n if (type === 'message') {\r\n registerHandler('messageForChild', listener);\r\n }\r\n }\r\n}\r\n","/* eslint-disable @typescript-eslint/ban-types */\r\n/* eslint-disable @typescript-eslint/no-unused-vars */\r\n\r\nimport { sendMessageToParent } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { ChildAppWindow, IAppWindow } from './appWindow';\r\nimport { FrameContexts } from './constants';\r\nimport { DialogInfo } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * Namespace to interact with the dialog module-specific part of the SDK.\r\n *\r\n * @remarks\r\n * This object is usable only on the content frame.\r\n *\r\n * @beta\r\n */\r\nexport namespace dialog {\r\n /**\r\n * Allows an app to open the dialog module.\r\n *\r\n * @param dialogInfo - An object containing the parameters of the dialog module\r\n * @param submitHandler - Handler to call when the task module is completed\r\n */\r\n export function open(\r\n dialogInfo: DialogInfo,\r\n submitHandler?: (err: string, result: string | object) => void,\r\n ): IAppWindow {\r\n ensureInitialized(FrameContexts.content, FrameContexts.sidePanel, FrameContexts.meetingStage);\r\n\r\n sendMessageToParent('tasks.startTask', [dialogInfo], submitHandler);\r\n return new ChildAppWindow();\r\n }\r\n\r\n /**\r\n * Update height/width dialog info properties.\r\n *\r\n * @param dialogInfo - An object containing width and height properties\r\n */\r\n export function resize(dialogInfo: DialogInfo): void {\r\n ensureInitialized(FrameContexts.content, FrameContexts.sidePanel, FrameContexts.task, FrameContexts.meetingStage);\r\n const { width, height, ...extra } = dialogInfo;\r\n\r\n if (!Object.keys(extra).length) {\r\n sendMessageToParent('tasks.updateTask', [dialogInfo]);\r\n } else {\r\n throw new Error('resize requires a dialogInfo argument containing only width and height');\r\n }\r\n }\r\n\r\n /**\r\n * Submit the dialog module.\r\n *\r\n * @param result - Contains the result to be sent to the bot or the app. Typically a JSON object or a serialized version of it\r\n * @param appIds - Helps to validate that the call originates from the same appId as the one that invoked the task module\r\n */\r\n export function submit(result?: string | object, appIds?: string | string[]): void {\r\n ensureInitialized(FrameContexts.content, FrameContexts.sidePanel, FrameContexts.task, FrameContexts.meetingStage);\r\n\r\n // Send tasks.completeTask instead of tasks.submitTask message for backward compatibility with Mobile clients\r\n sendMessageToParent('tasks.completeTask', [result, Array.isArray(appIds) ? appIds : [appIds]]);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.dialog ? true : false;\r\n }\r\n}\r\n","import { media } from '../public/media';\r\nimport { people } from '../public/people';\r\nimport {\r\n imageOutputFormatsAPISupportVersion,\r\n nonFullScreenVideoModeAPISupportVersion,\r\n videoAndImageMediaAPISupportVersion,\r\n} from './constants';\r\nimport { throwExceptionIfMobileApiIsNotSupported } from './internalAPIs';\r\n\r\n/**\r\n * @hidden\r\n * Helper function to create a blob from media chunks based on their sequence\r\n *\r\n * @internal\r\n */\r\nexport function createFile(assembleAttachment: media.AssembleAttachment[], mimeType: string): Blob {\r\n if (assembleAttachment == null || mimeType == null || assembleAttachment.length <= 0) {\r\n return null;\r\n }\r\n let file: Blob;\r\n let sequence = 1;\r\n assembleAttachment.sort((a, b) => (a.sequence > b.sequence ? 1 : -1));\r\n assembleAttachment.forEach(item => {\r\n if (item.sequence == sequence) {\r\n if (file) {\r\n file = new Blob([file, item.file], { type: mimeType });\r\n } else {\r\n file = new Blob([item.file], { type: mimeType });\r\n }\r\n sequence++;\r\n }\r\n });\r\n return file;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Helper function to convert Media chunks into another object type which can be later assemebled\r\n * Converts base 64 encoded string to byte array and then into an array of blobs\r\n *\r\n * @internal\r\n */\r\nexport function decodeAttachment(attachment: media.MediaChunk, mimeType: string): media.AssembleAttachment {\r\n if (attachment == null || mimeType == null) {\r\n return null;\r\n }\r\n const decoded = atob(attachment.chunk);\r\n const byteNumbers = new Array(decoded.length);\r\n for (let i = 0; i < decoded.length; i++) {\r\n byteNumbers[i] = decoded.charCodeAt(i);\r\n }\r\n const byteArray = new Uint8Array(byteNumbers);\r\n const blob: Blob = new Blob([byteArray], { type: mimeType });\r\n const assemble: media.AssembleAttachment = {\r\n sequence: attachment.chunkSequence,\r\n file: blob,\r\n };\r\n return assemble;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Function throws an SdkError if the media call is not supported on current mobile version, else undefined.\r\n * @throws an SdkError if the media call is not supported\r\n * @internal\r\n */\r\nexport function throwExceptionIfMediaCallIsNotSupportedOnMobile(mediaInputs: media.MediaInputs): void {\r\n if (isMediaCallForVideoAndImageInputs(mediaInputs)) {\r\n throwExceptionIfMobileApiIsNotSupported(videoAndImageMediaAPISupportVersion);\r\n } else if (isMediaCallForNonFullScreenVideoMode(mediaInputs)) {\r\n throwExceptionIfMobileApiIsNotSupported(nonFullScreenVideoModeAPISupportVersion);\r\n } else if (isMediaCallForImageOutputFormats(mediaInputs)) {\r\n throwExceptionIfMobileApiIsNotSupported(imageOutputFormatsAPISupportVersion);\r\n }\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Function returns true if the app has registered to listen to video controller events, else false.\r\n *\r\n * @internal\r\n */\r\nexport function isVideoControllerRegistered(mediaInputs: media.MediaInputs): boolean {\r\n if (\r\n mediaInputs.mediaType == media.MediaType.Video &&\r\n mediaInputs.videoProps &&\r\n mediaInputs.videoProps.videoController\r\n ) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Returns true if the mediaInput params are valid and false otherwise\r\n *\r\n * @internal\r\n */\r\nexport function validateSelectMediaInputs(mediaInputs: media.MediaInputs): boolean {\r\n if (mediaInputs == null || mediaInputs.maxMediaCount > 10) {\r\n return false;\r\n }\r\n return true;\r\n}\r\n\r\n/**\r\n * Returns true if the mediaInput params are called for mediatype Image and contains Image outputs formats, false otherwise\r\n */\r\nexport function isMediaCallForImageOutputFormats(mediaInputs: media.MediaInputs): boolean {\r\n if (mediaInputs?.mediaType == media.MediaType.Image && mediaInputs?.imageProps?.imageOutputFormats) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Returns true if the mediaInput params are called for mediatype VideoAndImage and false otherwise\r\n *\r\n * @internal\r\n */\r\nexport function isMediaCallForVideoAndImageInputs(mediaInputs: media.MediaInputs): boolean {\r\n if (mediaInputs && (mediaInputs.mediaType == media.MediaType.VideoAndImage || mediaInputs.videoAndImageProps)) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Returns true if the mediaInput params are called for non-full screen video mode and false otherwise\r\n *\r\n * @internal\r\n */\r\nexport function isMediaCallForNonFullScreenVideoMode(mediaInputs: media.MediaInputs): boolean {\r\n if (\r\n mediaInputs &&\r\n mediaInputs.mediaType == media.MediaType.Video &&\r\n mediaInputs.videoProps &&\r\n !mediaInputs.videoProps.isFullScreenMode\r\n ) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Returns true if the get Media params are valid and false otherwise\r\n *\r\n * @internal\r\n */\r\nexport function validateGetMediaInputs(mimeType: string, format: media.FileFormat, content: string): boolean {\r\n if (mimeType == null || format == null || format != media.FileFormat.ID || content == null) {\r\n return false;\r\n }\r\n return true;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Returns true if the view images param is valid and false otherwise\r\n *\r\n * @internal\r\n */\r\nexport function validateViewImagesInput(uriList: media.ImageUri[]): boolean {\r\n if (uriList == null || uriList.length <= 0 || uriList.length > 10) {\r\n return false;\r\n }\r\n return true;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Returns true if the scan barcode param is valid and false otherwise\r\n *\r\n * @internal\r\n */\r\nexport function validateScanBarCodeInput(barCodeConfig: media.BarCodeConfig): boolean {\r\n if (barCodeConfig) {\r\n if (\r\n barCodeConfig.timeOutIntervalInSec === null ||\r\n barCodeConfig.timeOutIntervalInSec <= 0 ||\r\n barCodeConfig.timeOutIntervalInSec > 60\r\n ) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Returns true if the people picker params are valid and false otherwise\r\n *\r\n * @internal\r\n */\r\nexport function validatePeoplePickerInput(peoplePickerInputs: people.PeoplePickerInputs): boolean {\r\n if (peoplePickerInputs) {\r\n if (peoplePickerInputs.title) {\r\n if (typeof peoplePickerInputs.title !== 'string') {\r\n return false;\r\n }\r\n }\r\n\r\n if (peoplePickerInputs.setSelected) {\r\n if (typeof peoplePickerInputs.setSelected !== 'object') {\r\n return false;\r\n }\r\n }\r\n\r\n if (peoplePickerInputs.openOrgWideSearchInChatOrChannel) {\r\n if (typeof peoplePickerInputs.openOrgWideSearchInChatOrChannel !== 'boolean') {\r\n return false;\r\n }\r\n }\r\n if (peoplePickerInputs.singleSelect) {\r\n if (typeof peoplePickerInputs.singleSelect !== 'boolean') {\r\n return false;\r\n }\r\n }\r\n }\r\n return true;\r\n}\r\n","/* eslint-disable @typescript-eslint/explicit-member-accessibility */\r\n\r\nimport { sendAndHandleSdkError, sendMessageToParent, sendMessageToParentAsync } from '../internal/communication';\r\nimport {\r\n captureImageMobileSupportVersion,\r\n getMediaCallbackSupportVersion,\r\n mediaAPISupportVersion,\r\n nonFullScreenVideoModeAPISupportVersion,\r\n scanBarCodeAPIMobileSupportVersion,\r\n} from '../internal/constants';\r\nimport { GlobalVars } from '../internal/globalVars';\r\nimport { registerHandler, removeHandler } from '../internal/handlers';\r\nimport {\r\n ensureInitialized,\r\n isCurrentSDKVersionAtLeast,\r\n throwExceptionIfMobileApiIsNotSupported,\r\n} from '../internal/internalAPIs';\r\nimport {\r\n createFile,\r\n decodeAttachment,\r\n isVideoControllerRegistered,\r\n throwExceptionIfMediaCallIsNotSupportedOnMobile,\r\n validateGetMediaInputs,\r\n validateScanBarCodeInput,\r\n validateSelectMediaInputs,\r\n validateViewImagesInput,\r\n} from '../internal/mediaUtil';\r\nimport {\r\n callCallbackWithErrorOrResultFromPromiseAndReturnPromise,\r\n callCallbackWithSdkErrorFromPromiseAndReturnPromise,\r\n generateGUID,\r\n InputFunction,\r\n} from '../internal/utils';\r\nimport { FrameContexts, HostClientType } from './constants';\r\nimport { ErrorCode, SdkError } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace media {\r\n /**\r\n * Enum for file formats supported\r\n */\r\n export enum FileFormat {\r\n Base64 = 'base64',\r\n ID = 'id',\r\n }\r\n\r\n /**\r\n * File object that can be used to represent image or video or audio\r\n */\r\n export class File {\r\n /**\r\n * Content of the file. When format is Base64, this is the base64 content\r\n * When format is ID, this is id mapping to the URI\r\n * When format is base64 and app needs to use this directly in HTML tags, it should convert this to dataUrl.\r\n */\r\n public content: string;\r\n\r\n /**\r\n * Format of the content\r\n */\r\n public format: FileFormat;\r\n\r\n /**\r\n * Size of the file in KB\r\n */\r\n public size: number;\r\n\r\n /**\r\n * MIME type. This can be used for constructing a dataUrl, if needed.\r\n */\r\n public mimeType: string;\r\n\r\n /**\r\n * Optional: Name of the file\r\n */\r\n public name?: string;\r\n }\r\n\r\n /**\r\n * Launch camera, capture image or choose image from gallery and return the images as a File[] object\r\n *\r\n * @remarks\r\n * Note: Currently we support getting one File through this API, i.e. the file arrays size will be one.\r\n * Note: For desktop, this API is not supported. Promise will be rejected with ErrorCode.NotSupported.\r\n *\r\n * @returns A promise resolved with a collection of @see File objects or rejected with an @see SdkError\r\n */\r\n export function captureImage(): Promise<File[]>;\r\n /**\r\n * Launch camera, capture image or choose image from gallery and return the images as a File[] object\r\n *\r\n * @param callback - Callback to invoke when the image is captured.\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link media.captureImage media.captureImage(): Promise\\<File[]\\>} instead.\r\n *\r\n * @remarks\r\n * Note: Currently we support getting one File through this API, i.e. the file arrays size will be one.\r\n * Note: For desktop, this API is not supported. Callback will be resolved with ErrorCode.NotSupported.\r\n *\r\n */\r\n export function captureImage(callback: (error?: SdkError, files?: File[]) => void): void;\r\n export function captureImage(callback?: (error?: SdkError, files?: File[]) => void): Promise<File[]> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n\r\n const wrappedFunction: InputFunction<File[]> = () =>\r\n new Promise<File[]>(resolve => {\r\n if (!GlobalVars.isFramelessWindow) {\r\n throw { errorCode: ErrorCode.NOT_SUPPORTED_ON_PLATFORM };\r\n }\r\n\r\n if (!isCurrentSDKVersionAtLeast(captureImageMobileSupportVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n\r\n resolve(sendAndHandleSdkError('captureImage'));\r\n });\r\n\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise<File[]>(wrappedFunction, callback);\r\n }\r\n\r\n /**\r\n * Media object returned by the select Media API\r\n */\r\n export class Media extends File {\r\n constructor(that: Media = null) {\r\n super();\r\n if (that) {\r\n this.content = that.content;\r\n this.format = that.format;\r\n this.mimeType = that.mimeType;\r\n this.name = that.name;\r\n this.preview = that.preview;\r\n this.size = that.size;\r\n }\r\n }\r\n\r\n /**\r\n * A preview of the file which is a lightweight representation.\r\n * In case of images this will be a thumbnail/compressed image in base64 encoding.\r\n */\r\n public preview: string;\r\n\r\n /**\r\n * Gets the media in chunks irrespective of size, these chunks are assembled and sent back to the webapp as file/blob\r\n *\r\n * @returns A promise resolved with the @see Blob or rejected with a @see SdkError\r\n */\r\n public getMedia(): Promise<Blob>;\r\n /**\r\n * Gets the media in chunks irrespective of size, these chunks are assembled and sent back to the webapp as file/blob\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link media.Media.getMedia media.Media.getMedia(): Promise\\<Blob\\>} instead.\r\n *\r\n * @param callback - returns blob of media\r\n */\r\n public getMedia(callback: (error: SdkError, blob: Blob) => void): void;\r\n public getMedia(callback?: (error: SdkError, blob: Blob) => void): Promise<Blob> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n\r\n const wrappedFunction: InputFunction<Blob> = () =>\r\n new Promise<Blob>(resolve => {\r\n if (!isCurrentSDKVersionAtLeast(mediaAPISupportVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n if (!validateGetMediaInputs(this.mimeType, this.format, this.content)) {\r\n throw { errorCode: ErrorCode.INVALID_ARGUMENTS };\r\n }\r\n // Call the new get media implementation via callbacks if the client version is greater than or equal to '2.0.0'\r\n if (isCurrentSDKVersionAtLeast(getMediaCallbackSupportVersion)) {\r\n resolve(this.getMediaViaCallback());\r\n } else {\r\n resolve(this.getMediaViaHandler());\r\n }\r\n });\r\n\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise<Blob>(wrappedFunction, callback);\r\n }\r\n\r\n private getMediaViaCallback(): Promise<Blob> {\r\n return new Promise<Blob>((resolve, reject) => {\r\n const helper: MediaHelper = {\r\n mediaMimeType: this.mimeType,\r\n assembleAttachment: [],\r\n };\r\n const localUriId = [this.content];\r\n sendMessageToParent('getMedia', localUriId, (mediaResult: MediaResult) => {\r\n if (mediaResult && mediaResult.error) {\r\n reject(mediaResult.error);\r\n } else if (!mediaResult || !mediaResult.mediaChunk) {\r\n reject({ errorCode: ErrorCode.INTERNAL_ERROR, message: 'data received is null' });\r\n } else if (mediaResult.mediaChunk.chunkSequence <= 0) {\r\n const file = createFile(helper.assembleAttachment, helper.mediaMimeType);\r\n resolve(file);\r\n } else {\r\n // Keep pushing chunks into assemble attachment\r\n const assemble: AssembleAttachment = decodeAttachment(mediaResult.mediaChunk, helper.mediaMimeType);\r\n helper.assembleAttachment.push(assemble);\r\n }\r\n });\r\n });\r\n }\r\n\r\n private getMediaViaHandler(): Promise<Blob> {\r\n return new Promise<Blob>((resolve, reject) => {\r\n const actionName = generateGUID();\r\n const helper: MediaHelper = {\r\n mediaMimeType: this.mimeType,\r\n assembleAttachment: [],\r\n };\r\n const params = [actionName, this.content];\r\n this.content && sendMessageToParent('getMedia', params);\r\n\r\n registerHandler('getMedia' + actionName, (response: string) => {\r\n try {\r\n const mediaResult: MediaResult = JSON.parse(response);\r\n if (mediaResult.error) {\r\n reject(mediaResult.error);\r\n removeHandler('getMedia' + actionName);\r\n } else if (!mediaResult || !mediaResult.mediaChunk) {\r\n reject({ errorCode: ErrorCode.INTERNAL_ERROR, message: 'data received is null' });\r\n removeHandler('getMedia' + actionName);\r\n } else if (mediaResult.mediaChunk.chunkSequence <= 0) {\r\n // If the chunksequence number is less than equal to 0 implies EOF\r\n // create file/blob when all chunks have arrived and we get 0/-1 as chunksequence number\r\n const file = createFile(helper.assembleAttachment, helper.mediaMimeType);\r\n resolve(file);\r\n removeHandler('getMedia' + actionName);\r\n } else {\r\n // Keep pushing chunks into assemble attachment\r\n const assemble: AssembleAttachment = decodeAttachment(mediaResult.mediaChunk, helper.mediaMimeType);\r\n helper.assembleAttachment.push(assemble);\r\n }\r\n } catch (err) {\r\n // catch JSON.parse() errors\r\n reject({ errorCode: ErrorCode.INTERNAL_ERROR, message: 'Error parsing the response: ' + response });\r\n }\r\n });\r\n });\r\n }\r\n }\r\n\r\n /**\r\n * Input parameter supplied to the select Media API\r\n */\r\n export interface MediaInputs {\r\n /**\r\n * Only one media type can be selected at a time\r\n */\r\n mediaType: MediaType;\r\n\r\n /**\r\n * max limit of media allowed to be selected in one go, current max limit is 10 set by office lens.\r\n */\r\n maxMediaCount: number;\r\n\r\n /**\r\n * Additional properties for customization of select media - Image in mobile devices\r\n */\r\n imageProps?: ImageProps;\r\n\r\n /**\r\n * Additional properties for customization of select media - Video in mobile devices\r\n */\r\n videoProps?: VideoProps;\r\n\r\n /**\r\n * Additional properties for customization of select media - VideoAndImage in mobile devices\r\n */\r\n videoAndImageProps?: VideoAndImageProps;\r\n\r\n /**\r\n * Additional properties for audio capture flows.\r\n */\r\n audioProps?: AudioProps;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * All properties common to Image and Video Props\r\n */\r\n interface MediaProps {\r\n /**\r\n * @hidden\r\n * Optional; Lets the developer specify the media source, more than one can be specified.\r\n * Default value is both camera and gallery\r\n */\r\n sources?: Source[];\r\n\r\n /**\r\n * @hidden\r\n * Optional; Specify in which mode the camera will be opened.\r\n * Default value is Photo\r\n */\r\n startMode?: CameraStartMode;\r\n\r\n /**\r\n * @hidden\r\n * Optional; indicate if user is allowed to move between front and back camera\r\n * Default value is true\r\n */\r\n cameraSwitcher?: boolean;\r\n }\r\n\r\n /**\r\n * All properties in ImageProps are optional and have default values in the platform\r\n */\r\n export interface ImageProps extends MediaProps {\r\n /**\r\n * Optional; indicate if inking on the selected Image is allowed or not\r\n * Default value is true\r\n */\r\n ink?: boolean;\r\n\r\n /**\r\n * Optional; indicate if putting text stickers on the selected Image is allowed or not\r\n * Default value is true\r\n */\r\n textSticker?: boolean;\r\n\r\n /**\r\n * Optional; indicate if image filtering mode is enabled on the selected image\r\n * Default value is false\r\n */\r\n enableFilter?: boolean;\r\n\r\n /**\r\n * Optional; Lets the developer specify the image output formats, more than one can be specified.\r\n * Default value is Image.\r\n */\r\n imageOutputFormats?: ImageOutputFormats[];\r\n }\r\n\r\n /**\r\n * All properties in VideoProps are optional and have default values in the platform\r\n */\r\n export interface VideoProps extends MediaProps {\r\n /**\r\n * Optional; the maximum duration in seconds after which the recording should terminate automatically.\r\n * Default value is defined by the platform serving the API.\r\n */\r\n maxDuration?: number;\r\n\r\n /**\r\n * Optional; to determine if the video capturing flow needs to be launched\r\n * in Full Screen Mode (Lens implementation) or PictureInPicture Mode (Native implementation).\r\n * Default value is true, indicating video will always launch in Full Screen Mode via lens.\r\n */\r\n isFullScreenMode?: boolean;\r\n\r\n /**\r\n * Optional; controls the visibility of stop button in PictureInPicture Mode.\r\n * Default value is true, indicating the user will be able to stop the video.\r\n */\r\n isStopButtonVisible?: boolean;\r\n\r\n /**\r\n * Optional; setting VideoController will register your app to listen to the lifecycle events during the video capture flow.\r\n * Your app can also dynamically control the experience while capturing the video by notifying the host client.\r\n */\r\n videoController?: VideoController;\r\n }\r\n\r\n /**\r\n * All properties in VideoAndImageProps are optional and have default values in the platform\r\n */\r\n export interface VideoAndImageProps extends ImageProps, VideoProps {}\r\n\r\n /**\r\n * All properties in AudioProps are optional and have default values in the platform\r\n */\r\n export interface AudioProps {\r\n /**\r\n * Optional; the maximum duration in minutes after which the recording should terminate automatically\r\n * Default value is defined by the platform serving the API.\r\n */\r\n maxDuration?: number;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Base class which holds the callback and notifies events to the host client\r\n */\r\n abstract class MediaController<T> {\r\n protected controllerCallback: T;\r\n\r\n public constructor(controllerCallback: T) {\r\n this.controllerCallback = controllerCallback;\r\n }\r\n\r\n protected abstract getMediaType(): MediaType;\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * This function will be implemented by the respective media class which holds the logic\r\n * of specific events that needs to be notified to the app.\r\n * @param mediaEvent indicates the event signed by the host client to the app\r\n */\r\n protected abstract notifyEventToApp(mediaEvent: MediaControllerEvent): void;\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n *\r\n * Function to notify the host client to programatically control the experience\r\n * @param mediaEvent indicates what the event that needs to be signaled to the host client\r\n * @returns A promise resolved promise\r\n */\r\n protected notifyEventToHost(mediaEvent: MediaControllerEvent): Promise<void>;\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link media.MediaController.notifyEventToHost media.MediaController.notifyEventToHost(mediaEvent: MediaControllerEvent): Promise\\<void\\>} instead.\r\n *\r\n * Function to notify the host client to programatically control the experience\r\n * @param mediaEvent indicates what the event that needs to be signaled to the host client\r\n * Optional; @param callback is used to send app if host client has successfully handled the notification event or not\r\n */\r\n protected notifyEventToHost(mediaEvent: MediaControllerEvent, callback?: (err?: SdkError) => void): void;\r\n protected notifyEventToHost(mediaEvent: MediaControllerEvent, callback?: (err?: SdkError) => void): Promise<void> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n\r\n try {\r\n throwExceptionIfMobileApiIsNotSupported(nonFullScreenVideoModeAPISupportVersion);\r\n } catch (err) {\r\n const wrappedRejectedErrorFn: InputFunction<void> = () => Promise.reject(err);\r\n\r\n return callCallbackWithSdkErrorFromPromiseAndReturnPromise(wrappedRejectedErrorFn, callback);\r\n }\r\n\r\n const params: MediaControllerParam = {\r\n mediaType: this.getMediaType(),\r\n mediaControllerEvent: mediaEvent,\r\n };\r\n\r\n const wrappedFunction = (): Promise<void> =>\r\n new Promise(resolve => resolve(sendAndHandleSdkError('media.controller', [params])));\r\n\r\n return callCallbackWithSdkErrorFromPromiseAndReturnPromise(wrappedFunction, callback);\r\n }\r\n\r\n /**\r\n * Function to programatically stop the ongoing media event\r\n *\r\n * @returns A resolved promise\r\n * */\r\n public stop(): Promise<void>;\r\n /**\r\n *\r\n * Function to programatically stop the ongoing media event\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link media.MediaController.stop media.MediaController.stop(): Promise\\<void\\>} instead.\r\n *\r\n * Optional; @param callback is used to send app if host client has successfully stopped the event or not\r\n */\r\n public stop(callback?: (err?: SdkError) => void): void;\r\n public stop(callback?: (err?: SdkError) => void): Promise<void> {\r\n return Promise.resolve(this.notifyEventToHost(MediaControllerEvent.StopRecording, callback));\r\n }\r\n }\r\n\r\n /**\r\n * Callback which will register your app to listen to lifecycle events during the video capture flow\r\n */\r\n export interface VideoControllerCallback {\r\n onRecordingStarted(): void;\r\n onRecordingStopped?(): void;\r\n }\r\n\r\n /**\r\n * VideoController class is used to communicate between the app and the host client during the video capture flow\r\n */\r\n export class VideoController extends MediaController<VideoControllerCallback> {\r\n protected getMediaType(): MediaType {\r\n return MediaType.Video;\r\n }\r\n\r\n public notifyEventToApp(mediaEvent: MediaControllerEvent): void {\r\n switch (mediaEvent) {\r\n case MediaControllerEvent.StartRecording:\r\n this.controllerCallback.onRecordingStarted();\r\n break;\r\n // TODO - Should discuss whether this function should be required\r\n case MediaControllerEvent.StopRecording:\r\n this.controllerCallback.onRecordingStopped && this.controllerCallback.onRecordingStopped();\r\n break;\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Events which are used to communicate between the app and the host client during the media recording flow\r\n */\r\n export enum MediaControllerEvent {\r\n StartRecording = 1,\r\n StopRecording = 2,\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Interface with relevant info to send communication from the app to the host client\r\n */\r\n interface MediaControllerParam {\r\n /**\r\n * List of team information\r\n */\r\n mediaType: media.MediaType;\r\n\r\n /**\r\n * List of team information\r\n */\r\n mediaControllerEvent: MediaControllerEvent;\r\n }\r\n\r\n /**\r\n * The modes in which camera can be launched in select Media API\r\n */\r\n export enum CameraStartMode {\r\n Photo = 1,\r\n Document = 2,\r\n Whiteboard = 3,\r\n BusinessCard = 4,\r\n }\r\n\r\n /**\r\n * Specifies the image source\r\n */\r\n export enum Source {\r\n Camera = 1,\r\n Gallery = 2,\r\n }\r\n\r\n /**\r\n * Specifies the type of Media\r\n */\r\n export enum MediaType {\r\n Image = 1,\r\n Video = 2,\r\n VideoAndImage = 3,\r\n Audio = 4,\r\n }\r\n\r\n /**\r\n * Input for view images API\r\n */\r\n export interface ImageUri {\r\n value: string;\r\n type: ImageUriType;\r\n }\r\n\r\n /**\r\n * ID contains a mapping for content uri on platform's side, URL is generic\r\n */\r\n export enum ImageUriType {\r\n ID = 1,\r\n URL = 2,\r\n }\r\n\r\n /**\r\n * Specifies the image output formats.\r\n */\r\n export enum ImageOutputFormats {\r\n IMAGE = 1,\r\n PDF = 2,\r\n }\r\n\r\n /**\r\n * Media chunks an output of getMedia API from platform\r\n */\r\n export interface MediaChunk {\r\n /**\r\n * Base 64 data for the requested uri\r\n */\r\n chunk: string;\r\n\r\n /**\r\n * chunk sequence number\r\n */\r\n chunkSequence: number;\r\n }\r\n\r\n /**\r\n * Output of getMedia API from platform\r\n */\r\n export interface MediaResult {\r\n /**\r\n * error encountered in getMedia API\r\n */\r\n error: SdkError;\r\n\r\n /**\r\n * Media chunk which will be assemebled and converted into a blob\r\n */\r\n mediaChunk: MediaChunk;\r\n }\r\n\r\n /**\r\n * Helper object to assembled media chunks\r\n */\r\n export interface AssembleAttachment {\r\n sequence: number;\r\n file: Blob;\r\n }\r\n\r\n /**\r\n * Helper class for assembling media\r\n */\r\n interface MediaHelper {\r\n mediaMimeType: string;\r\n assembleAttachment: AssembleAttachment[];\r\n }\r\n\r\n /**\r\n * Select an attachment using camera/gallery\r\n *\r\n * @param mediaInputs - The input params to customize the media to be selected\r\n * @returns A promise resolved with an array of media data or rejected with an @see SdkError\r\n */\r\n export function selectMedia(mediaInputs: MediaInputs): Promise<Media[]>;\r\n /**\r\n * Select an attachment using camera/gallery\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link media.selectMedia media.selectMedia(mediaInputs: MediaInputs): Promise\\<Media[]\\>} instead.\r\n *\r\n * @param mediaInputs - The input params to customize the media to be selected\r\n * @param callback - The callback to invoke after fetching the media\r\n */\r\n export function selectMedia(mediaInputs: MediaInputs, callback: (error: SdkError, attachments: Media[]) => void);\r\n export function selectMedia(\r\n mediaInputs: MediaInputs,\r\n callback?: (error?: SdkError, attachments?: Media[]) => void,\r\n ): Promise<Media[]> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n\r\n const wrappedFunction: InputFunction<Media[]> = () =>\r\n new Promise<[SdkError, Media[], MediaControllerEvent]>(resolve => {\r\n if (!isCurrentSDKVersionAtLeast(mediaAPISupportVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n throwExceptionIfMediaCallIsNotSupportedOnMobile(mediaInputs);\r\n\r\n if (!validateSelectMediaInputs(mediaInputs)) {\r\n throw { errorCode: ErrorCode.INVALID_ARGUMENTS };\r\n }\r\n\r\n const params = [mediaInputs];\r\n // What comes back from native at attachments would just be objects and will be missing getMedia method on them.\r\n resolve(sendMessageToParentAsync<[SdkError, Media[], MediaControllerEvent]>('selectMedia', params));\r\n }).then(([err, localAttachments, mediaEvent]: [SdkError, Media[], MediaControllerEvent]) => {\r\n // MediaControllerEvent response is used to notify the app about events and is a partial response to selectMedia\r\n if (mediaEvent) {\r\n if (isVideoControllerRegistered(mediaInputs)) {\r\n mediaInputs.videoProps.videoController.notifyEventToApp(mediaEvent);\r\n }\r\n return [];\r\n }\r\n\r\n // Media Attachments are final response to selectMedia\r\n if (!localAttachments) {\r\n throw err;\r\n }\r\n const mediaArray: Media[] = [];\r\n for (const attachment of localAttachments) {\r\n mediaArray.push(new Media(attachment));\r\n }\r\n return mediaArray;\r\n });\r\n\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise<Media[]>(wrappedFunction, callback);\r\n }\r\n\r\n /**\r\n * View images using native image viewer\r\n *\r\n * @param uriList - list of URIs for images to be viewed - can be content URI or server URL. Supports up to 10 Images in a single call\r\n * @returns A promise resolved when the viewing action is completed or rejected with an @see SdkError\r\n */\r\n export function viewImages(uriList: ImageUri[]): Promise<void>;\r\n /**\r\n * View images using native image viewer\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link media.viewImages media.viewImages(uriList: ImageUri[]): Promise\\<void\\>} instead.\r\n *\r\n * @param uriList - list of URIs for images to be viewed - can be content URI or server URL. Supports up to 10 Images in a single call\r\n * @param callback - returns back error if encountered, returns null in case of success\r\n */\r\n export function viewImages(uriList: ImageUri[], callback: (error?: SdkError) => void);\r\n export function viewImages(uriList: ImageUri[], callback?: (error?: SdkError) => void): Promise<void> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n\r\n const wrappedFunction: InputFunction<void> = () =>\r\n new Promise<void>(resolve => {\r\n if (!isCurrentSDKVersionAtLeast(mediaAPISupportVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n if (!validateViewImagesInput(uriList)) {\r\n throw { errorCode: ErrorCode.INVALID_ARGUMENTS };\r\n }\r\n\r\n resolve(sendAndHandleSdkError('viewImages', uriList));\r\n });\r\n\r\n return callCallbackWithSdkErrorFromPromiseAndReturnPromise<void>(wrappedFunction, callback);\r\n }\r\n\r\n /**\r\n * Barcode configuration supplied to scanBarCode API to customize barcode scanning experience in mobile\r\n * All properties in BarCodeConfig are optional and have default values in the platform\r\n */\r\n export interface BarCodeConfig {\r\n /**\r\n * Optional; Lets the developer specify the scan timeout interval in seconds\r\n * Default value is 30 seconds and max allowed value is 60 seconds\r\n */\r\n timeOutIntervalInSec?: number;\r\n }\r\n\r\n /**\r\n * Scan Barcode/QRcode using camera\r\n *\r\n * @remarks\r\n * Note: For desktop and web, this API is not supported. Callback will be resolved with ErrorCode.NotSupported.\r\n *\r\n * @param config - optional input configuration to customize the barcode scanning experience\r\n * @returns A promise resolved with the barcode data or rejected with an @see SdkError\r\n */\r\n export function scanBarCode(config?: BarCodeConfig): Promise<string>;\r\n /**\r\n * Scan Barcode/QRcode using camera\r\n *\r\n * @remarks\r\n * Note: For desktop and web, this API is not supported. Callback will be resolved with ErrorCode.NotSupported.\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link media.scanBarCode media.scanBarCode(config?: BarCodeConfig): Promise\\<string\\>} instead.\r\n *\r\n * @param callback - callback to invoke after scanning the barcode\r\n * @param config - optional input configuration to customize the barcode scanning experience\r\n */\r\n export function scanBarCode(callback: (error: SdkError, decodedText: string) => void, config?: BarCodeConfig);\r\n export function scanBarCode(\r\n callbackOrConfig?: ((error: SdkError, decodedText: string) => void) | BarCodeConfig,\r\n configMaybe?: BarCodeConfig,\r\n ): Promise<string> {\r\n let callback: (error: SdkError, decodedText: string) => void | undefined;\r\n let config: BarCodeConfig | undefined;\r\n\r\n // Because the callback isn't the second parameter in the original v1 method we need to\r\n // do a bit of trickery to see which of the two ways were used to call into\r\n // the flow and if the first parameter is a callback (v1) or a config object (v2)\r\n\r\n if (callbackOrConfig === undefined) {\r\n // no first parameter - the second one might be a config, definitely no callback\r\n config = configMaybe;\r\n } else {\r\n if (typeof callbackOrConfig === 'object') {\r\n // the first parameter is an object - it's the config! No callback.\r\n config = callbackOrConfig;\r\n } else {\r\n // otherwise, it's a function, so a callback. The second parameter might be a callback\r\n callback = callbackOrConfig;\r\n config = configMaybe;\r\n }\r\n }\r\n\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n\r\n const wrappedFunction: InputFunction<string> = () =>\r\n new Promise<string>(resolve => {\r\n if (\r\n GlobalVars.hostClientType === HostClientType.desktop ||\r\n GlobalVars.hostClientType === HostClientType.web ||\r\n GlobalVars.hostClientType === HostClientType.rigel ||\r\n GlobalVars.hostClientType === HostClientType.teamsRoomsWindows ||\r\n GlobalVars.hostClientType === HostClientType.teamsRoomsAndroid ||\r\n GlobalVars.hostClientType === HostClientType.teamsPhones ||\r\n GlobalVars.hostClientType === HostClientType.teamsDisplays\r\n ) {\r\n throw { errorCode: ErrorCode.NOT_SUPPORTED_ON_PLATFORM };\r\n }\r\n\r\n if (!isCurrentSDKVersionAtLeast(scanBarCodeAPIMobileSupportVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n\r\n if (!validateScanBarCodeInput(config)) {\r\n throw { errorCode: ErrorCode.INVALID_ARGUMENTS };\r\n }\r\n\r\n resolve(sendAndHandleSdkError('media.scanBarCode', config));\r\n });\r\n\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise<string>(wrappedFunction, callback);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.media ? true : false;\r\n }\r\n}\r\n","import { sendAndHandleSdkError as sendAndHandleError } from '../internal/communication';\r\nimport { locationAPIsRequiredVersion } from '../internal/constants';\r\nimport { ensureInitialized, isCurrentSDKVersionAtLeast } from '../internal/internalAPIs';\r\nimport {\r\n callCallbackWithErrorOrBooleanFromPromiseAndReturnPromise,\r\n callCallbackWithErrorOrResultFromPromiseAndReturnPromise,\r\n} from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\nimport { ErrorCode, SdkError } from './interfaces';\r\nimport { runtime } from './runtime';\r\n/**\r\n * @alpha\r\n */\r\nexport namespace location {\r\n export interface LocationProps {\r\n /**\r\n whether user can alter location or not\r\n if false, user will be shown current location \r\n and wouldn't be allowed to alter it\r\n */\r\n allowChooseLocation: boolean;\r\n /**\r\n whether selected location should be shown to user on map or not.\r\n If allowChooseLocation is true, this parameter will be ignored by platform.\r\n If allowChooseLocation is false, and this parameter is not provided, default \r\n value will be false.\r\n */\r\n showMap?: boolean;\r\n }\r\n\r\n export interface Location {\r\n /**\r\n Latitude of the location\r\n */\r\n latitude: number;\r\n /**\r\n Longitude of the location\r\n */\r\n longitude: number;\r\n /**\r\n Accuracy of the coordinates captured\r\n */\r\n accuracy?: number;\r\n /**\r\n Time stamp when the location was captured\r\n */\r\n timestamp?: number;\r\n }\r\n\r\n /**\r\n * Fetches current user coordinates or allows user to choose location on map\r\n *\r\n * @param props {@link LocationProps} - Specifying how the location request is handled\r\n * @returns Promise that will be fulfilled when the operation has completed\r\n */\r\n export function getLocation(props: LocationProps): Promise<Location>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link location.getLocation location.getLocation(props: LocationProps): Promise\\<Location\\>} instead.\r\n * @param props {@link LocationProps} - Specifying how the location request is handled\r\n * @param callback - Callback to invoke when current user location is fetched\r\n */\r\n export function getLocation(props: LocationProps, callback: (error: SdkError, location: Location) => void): void;\r\n export function getLocation(\r\n props: LocationProps,\r\n callback?: (error: SdkError, location: Location) => void,\r\n ): Promise<Location> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise<Location>(getLocationHelper, callback, props);\r\n }\r\n\r\n function getLocationHelper(props: LocationProps): Promise<Location> {\r\n return new Promise<Location>(resolve => {\r\n if (!isCurrentSDKVersionAtLeast(locationAPIsRequiredVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n if (!props) {\r\n throw { errorCode: ErrorCode.INVALID_ARGUMENTS };\r\n }\r\n resolve(sendAndHandleError('location.getLocation', props));\r\n });\r\n }\r\n\r\n /**\r\n * Shows the location on map corresponding to the given coordinates\r\n *\r\n * @param location {@link Location} - which needs to be shown on map\r\n * @returns Promise that will be fulfilled when the operation has completed\r\n */\r\n export function showLocation(location: Location): Promise<void>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link location.showLocation location.showLocation(location: Location): Promise\\<void\\>} instead.\r\n * Shows the location on map corresponding to the given coordinates\r\n * @param location {@link Location} - which needs to be shown on map\r\n * @param callback - Callback to invoke when the location is opened on map\r\n */\r\n export function showLocation(location: Location, callback: (error: SdkError, status: boolean) => void): void;\r\n export function showLocation(\r\n location: Location,\r\n callback?: (error: SdkError, status: boolean) => void,\r\n ): Promise<void> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n return callCallbackWithErrorOrBooleanFromPromiseAndReturnPromise<void>(showLocationHelper, callback, location);\r\n }\r\n\r\n export function showLocationHelper(location: Location): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n if (!isCurrentSDKVersionAtLeast(locationAPIsRequiredVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n if (!location) {\r\n throw { errorCode: ErrorCode.INVALID_ARGUMENTS };\r\n }\r\n resolve(sendAndHandleError('location.showLocation', location));\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.location ? true : false;\r\n }\r\n}\r\n","import { sendAndHandleSdkError } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport {\r\n callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise,\r\n callCallbackWithSdkErrorFromPromiseAndReturnPromise,\r\n} from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\nimport { SdkError } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace meeting {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * Data structure to represent a meeting details.\r\n *\r\n * @internal\r\n */\r\n export interface IMeetingDetails {\r\n /**\r\n * @hidden\r\n * details object\r\n */\r\n details: IDetails;\r\n /**\r\n * @hidden\r\n * conversation object\r\n */\r\n conversation: IConversation;\r\n /**\r\n * @hidden\r\n * organizer object\r\n */\r\n organizer: IOrganizer;\r\n }\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * Data structure to represent details.\r\n *\r\n * @internal\r\n */\r\n export interface IDetails {\r\n /**\r\n * @hidden\r\n * Scheduled start time of the meeting\r\n */\r\n scheduledStartTime: string;\r\n /**\r\n * @hidden\r\n * Scheduled end time of the meeting\r\n */\r\n scheduledEndTime: string;\r\n /**\r\n * @hidden\r\n * url to join the current meeting\r\n */\r\n joinUrl?: string;\r\n /**\r\n * @hidden\r\n * meeting title name of the meeting\r\n */\r\n title?: string;\r\n /**\r\n * @hidden\r\n * type of the meeting\r\n */\r\n type?: MeetingType;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * Data structure to represent a conversation object.\r\n *\r\n * @internal\r\n */\r\n export interface IConversation {\r\n /**\r\n * @hidden\r\n * conversation id of the meeting\r\n */\r\n id: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * Data structure to represent an organizer object.\r\n *\r\n * @internal\r\n */\r\n export interface IOrganizer {\r\n /**\r\n * @hidden\r\n * organizer id of the meeting\r\n */\r\n id?: string;\r\n /**\r\n * @hidden\r\n * tenant id of the meeting\r\n */\r\n tenantId?: string;\r\n }\r\n\r\n export interface LiveStreamState {\r\n /**\r\n * indicates whether meeting is streaming\r\n */\r\n isStreaming: boolean;\r\n\r\n /**\r\n * error object in case there is a failure\r\n */\r\n error?: {\r\n /** error code from the streaming service, e.g. IngestionFailure */\r\n code: string;\r\n /** detailed error message string */\r\n message?: string;\r\n };\r\n }\r\n\r\n export interface IAppContentStageSharingState {\r\n /**\r\n * indicates whether app is currently being shared to stage\r\n */\r\n isAppSharing: boolean;\r\n }\r\n\r\n export interface IAppContentStageSharingCapabilities {\r\n /**\r\n * indicates whether app has permission to share contents to meeting stage\r\n */\r\n doesAppHaveSharePermission: boolean;\r\n }\r\n\r\n export enum MeetingType {\r\n Unknown = 'Unknown',\r\n Adhoc = 'Adhoc',\r\n Scheduled = 'Scheduled',\r\n Recurring = 'Recurring',\r\n Broadcast = 'Broadcast',\r\n MeetNow = 'MeetNow',\r\n }\r\n\r\n /**\r\n * Allows an app to get the incoming audio speaker setting for the meeting user\r\n *\r\n * @remarks\r\n * error can either contain an error of type SdkError, incase of an error, or null when fetch is successful\r\n * result can either contain the true/false value, incase of a successful fetch or null when the fetching fails\r\n *\r\n * @returns Promise result where true means incoming audio is muted and false means incoming audio is unmuted\r\n */\r\n export function getIncomingClientAudioState(): Promise<boolean>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.getIncomingClientAudioState meeting.getIncomingClientAudioState(): Promise\\<boolean\\>} instead.\r\n *\r\n * Allows an app to get the incoming audio speaker setting for the meeting user\r\n *\r\n * @param callback - Callback contains 2 parameters, error and result.\r\n * error can either contain an error of type SdkError, incase of an error, or null when fetch is successful\r\n * result can either contain the true/false value, incase of a successful fetch or null when the fetching fails\r\n * result: True means incoming audio is muted and false means incoming audio is unmuted\r\n */\r\n export function getIncomingClientAudioState(callback: (error: SdkError | null, result: boolean | null) => void): void;\r\n export function getIncomingClientAudioState(\r\n callback?: (error: SdkError | null, result: boolean | null) => void,\r\n ): Promise<boolean> {\r\n ensureInitialized(FrameContexts.sidePanel, FrameContexts.meetingStage);\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<boolean>(\r\n getIncomingClientAudioStateHelper,\r\n callback,\r\n );\r\n }\r\n\r\n function getIncomingClientAudioStateHelper(): Promise<boolean> {\r\n return new Promise<boolean>(resolve => {\r\n resolve(sendAndHandleSdkError('getIncomingClientAudioState'));\r\n });\r\n }\r\n\r\n /**\r\n * Allows an app to toggle the incoming audio speaker setting for the meeting user from mute to unmute or vice-versa\r\n *\r\n * @remarks\r\n * error can either contain an error of type SdkError, incase of an error, or null when toggle is successful\r\n * result can either contain the true/false value, incase of a successful toggle or null when the toggling fails\r\n *\r\n * @returns Promise result where true means incoming audio is muted and false means incoming audio is unmuted or rejected promise containing SdkError details\r\n */\r\n export function toggleIncomingClientAudio(): Promise<boolean>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.toggleIncomingClientAudio meeting.toggleIncomingClientAudio(): Promise\\<boolean\\>} instead.\r\n *\r\n * @param callback - Callback contains 2 parameters, error and result.\r\n * error can either contain an error of type SdkError, incase of an error, or null when toggle is successful\r\n * result can either contain the true/false value, incase of a successful toggle or null when the toggling fails\r\n * result: True means incoming audio is muted and false means incoming audio is unmuted\r\n */\r\n export function toggleIncomingClientAudio(callback: (error: SdkError | null, result: boolean | null) => void): void;\r\n export function toggleIncomingClientAudio(\r\n callback?: (error: SdkError | null, result: boolean | null) => void,\r\n ): Promise<boolean> {\r\n ensureInitialized(FrameContexts.sidePanel, FrameContexts.meetingStage);\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<boolean>(\r\n toggleIncomingClientAudioHelper,\r\n callback,\r\n );\r\n }\r\n\r\n function toggleIncomingClientAudioHelper(): Promise<boolean> {\r\n return new Promise<boolean>(resolve => {\r\n resolve(sendAndHandleSdkError('toggleIncomingClientAudio'));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Allows an app to get the meeting details for the meeting\r\n *\r\n * @returns Promise containing the meeting details in IMeetingDetails form or rejected promise containing SdkError details\r\n *\r\n * @internal\r\n */\r\n export function getMeetingDetails(): Promise<IMeetingDetails>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.getMeetingDetails meeting.getMeetingDetails(): Promise\\<IMeetingDetails\\>} instead.\r\n *\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Allows an app to get the meeting details for the meeting\r\n *\r\n * @param callback - Callback contains 2 parameters, error and meetingDetails.\r\n * error can either contain an error of type SdkError, incase of an error, or null when get is successful\r\n * result can either contain a IMeetingDetails value, incase of a successful get or null when the get fails\r\n *\r\n * @internal\r\n */\r\n export function getMeetingDetails(\r\n callback: (error: SdkError | null, meetingDetails: IMeetingDetails | null) => void,\r\n ): void;\r\n export function getMeetingDetails(\r\n callback?: (error: SdkError | null, meetingDetails: IMeetingDetails | null) => void,\r\n ): Promise<IMeetingDetails> {\r\n ensureInitialized(\r\n FrameContexts.sidePanel,\r\n FrameContexts.meetingStage,\r\n FrameContexts.settings,\r\n FrameContexts.content,\r\n );\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<IMeetingDetails>(\r\n getMeetingDetailsHelper,\r\n callback,\r\n );\r\n }\r\n\r\n function getMeetingDetailsHelper(): Promise<IMeetingDetails> {\r\n return new Promise<IMeetingDetails>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.getMeetingDetails'));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Allows an app to get the authentication token for the anonymous or guest user in the meeting\r\n *\r\n * @returns Promise containing the token or rejected promise containing SdkError details\r\n *\r\n * @internal\r\n */\r\n export function getAuthenticationTokenForAnonymousUser(): Promise<string>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.getAuthenticationTokenForAnonymousUser meeting.getAuthenticationTokenForAnonymousUser(): Promise\\<string\\>} instead.\r\n *\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Allows an app to get the authentication token for the anonymous or guest user in the meeting\r\n * @param callback - Callback contains 2 parameters, error and authenticationTokenOfAnonymousUser.\r\n * error can either contain an error of type SdkError, incase of an error, or null when get is successful\r\n * authenticationTokenOfAnonymousUser can either contain a string value, incase of a successful get or null when the get fails\r\n *\r\n * @internal\r\n */\r\n export function getAuthenticationTokenForAnonymousUser(\r\n callback: (error: SdkError | null, authenticationTokenOfAnonymousUser: string | null) => void,\r\n ): void;\r\n export function getAuthenticationTokenForAnonymousUser(\r\n callback?: (error: SdkError | null, authenticationTokenOfAnonymousUser: string | null) => void,\r\n ): Promise<string> {\r\n ensureInitialized(FrameContexts.sidePanel, FrameContexts.meetingStage);\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<string>(\r\n getAuthenticationTokenForAnonymousUserHelper,\r\n callback,\r\n );\r\n }\r\n\r\n function getAuthenticationTokenForAnonymousUserHelper(): Promise<string> {\r\n return new Promise<string>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.getAuthenticationTokenForAnonymousUser'));\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.meeting ? true : false;\r\n }\r\n\r\n /**\r\n * Allows an app to get the state of the live stream in the current meeting\r\n *\r\n * @returns Promise containing the LiveStreamState value or rejected promise containing SdkError details\r\n */\r\n export function getLiveStreamState(): Promise<LiveStreamState>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.getLiveStreamState meeting.getLiveStreamState(): Promise\\<LiveStreamState\\>} instead.\r\n *\r\n * Allows an app to get the state of the live stream in the current meeting\r\n *\r\n * @param callback - Callback contains 2 parameters: error and liveStreamState.\r\n * error can either contain an error of type SdkError, in case of an error, or null when get is successful\r\n * liveStreamState can either contain a LiveStreamState value, or null when operation fails\r\n */\r\n export function getLiveStreamState(\r\n callback: (error: SdkError | null, liveStreamState: LiveStreamState | null) => void,\r\n ): void;\r\n export function getLiveStreamState(\r\n callback?: (error: SdkError | null, liveStreamState: LiveStreamState | null) => void,\r\n ): Promise<LiveStreamState> {\r\n ensureInitialized();\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<LiveStreamState>(\r\n getLiveStreamStateHelper,\r\n callback,\r\n );\r\n }\r\n\r\n function getLiveStreamStateHelper(): Promise<LiveStreamState> {\r\n return new Promise<LiveStreamState>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.getLiveStreamState'));\r\n });\r\n }\r\n\r\n /**\r\n * Allows an app to request the live streaming be started at the given streaming url\r\n *\r\n * @remarks\r\n * Use getLiveStreamState or registerLiveStreamChangedHandler to get updates on the live stream state\r\n *\r\n * @param streamUrl - the url to the stream resource\r\n * @param streamKey - the key to the stream resource\r\n * @returns Promise that will be resolved when the operation has completed or rejected with SdkError value\r\n */\r\n export function requestStartLiveStreaming(streamUrl: string, streamKey?: string): Promise<void>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.requestStartLiveStreaming meeting.requestStartLiveStreaming(streamUrl: string, streamKey?: string): Promise\\<void\\>} instead.\r\n *\r\n * Allows an app to request the live streaming be started at the given streaming url\r\n *\r\n * @param streamUrl - The url to the stream resource\r\n * @param streamKey - The key to the stream resource\r\n * @param callback - Callback contains error parameter which can be of type SdkError in case of an error, or null when operation is successful\r\n *\r\n * Use getLiveStreamState or registerLiveStreamChangedHandler to get updates on the live stream state\r\n */\r\n export function requestStartLiveStreaming(\r\n callback: (error: SdkError | null) => void,\r\n streamUrl: string,\r\n streamKey?: string,\r\n ): Promise<void>;\r\n /**\r\n * @hidden\r\n * This function is the overloaded implementation of requestStartLiveStreaming.\r\n * Since the method signatures of the v1 callback and v2 promise differ in the type of the first parameter,\r\n * we need to do an extra check to know the typeof the @param1 to set the proper arguments of the utility function.\r\n * @param param1\r\n * @param param2\r\n * @param param3\r\n * @returns Promise that will be resolved when the operation has completed or rejected with SdkError value\r\n */\r\n export function requestStartLiveStreaming(\r\n param1: string | ((error: SdkError | null) => void),\r\n param2?: string,\r\n param3?: string,\r\n ): Promise<void> {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n let streamUrl: string;\r\n let streamKey: string;\r\n let callback: (error: SdkError | null) => void;\r\n if (typeof param1 === 'function') {\r\n // Legacy code, with callbacks.\r\n [callback, streamUrl, streamKey] = [param1, param2, param3];\r\n } else if (typeof param1 === 'string') {\r\n [streamUrl, streamKey] = [param1, param2];\r\n }\r\n return callCallbackWithSdkErrorFromPromiseAndReturnPromise(\r\n requestStartLiveStreamingHelper,\r\n callback,\r\n streamUrl,\r\n streamKey,\r\n );\r\n }\r\n\r\n function requestStartLiveStreamingHelper(streamUrl: string, streamKey?: string): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.requestStartLiveStreaming', streamUrl, streamKey));\r\n });\r\n }\r\n\r\n /**\r\n * Allows an app to request the live streaming be stopped at the given streaming url\r\n *\r\n * @remarks\r\n * Use getLiveStreamState or registerLiveStreamChangedHandler to get updates on the live stream state\r\n *\r\n * @returns Promise that will be resolved when the operation has completed or rejected with SdkError value\r\n */\r\n export function requestStopLiveStreaming(): Promise<void>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.requestStopLiveStreaming meeting.requestStopLiveStreaming(): Promise\\<void\\>} instead.\r\n *\r\n * Allows an app to request the live streaming be stopped at the given streaming url\r\n * @param callback - Callback contains error parameter which can be of type SdkError in case of an error, or null when operation is successful\r\n *\r\n * Use getLiveStreamState or registerLiveStreamChangedHandler to get updates on the live stream state\r\n */\r\n export function requestStopLiveStreaming(callback: (error: SdkError | null) => void): void;\r\n export function requestStopLiveStreaming(callback?: (error: SdkError | null) => void): Promise<void> {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n return callCallbackWithSdkErrorFromPromiseAndReturnPromise(requestStopLiveStreamingHelper, callback);\r\n }\r\n\r\n function requestStopLiveStreamingHelper(): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.requestStopLiveStreaming'));\r\n });\r\n }\r\n\r\n /**\r\n * Registers a handler for changes to the live stream.\r\n *\r\n * @remarks\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the live stream state changes\r\n */\r\n export function registerLiveStreamChangedHandler(handler: (liveStreamState: LiveStreamState) => void): void {\r\n if (!handler) {\r\n throw new Error('[register live stream changed handler] Handler cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n registerHandler('meeting.liveStreamChanged', handler);\r\n }\r\n\r\n /**\r\n * Allows an app to share contents in the meeting\r\n *\r\n * @param appContentUrl - appContentUrl is the input URL which needs to be shared on to the stage\r\n * @returns Promise resolved indicating whether or not the share was successful or rejected with SdkError value\r\n */\r\n export function shareAppContentToStage(appContentUrl: string): Promise<boolean>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.shareAppContentToStage meeting.shareAppContentToStage(appContentUrl: string): Promise\\<boolean\\>} instead.\r\n *\r\n * Allows an app to share contents in the meeting\r\n *\r\n * @param callback - Callback contains 2 parameters, error and result.\r\n * error can either contain an error of type SdkError, incase of an error, or null when share is successful\r\n * result can either contain a true value, incase of a successful share or null when the share fails\r\n * @param appContentUrl - is the input URL which needs to be shared on to the stage\r\n */\r\n export function shareAppContentToStage(\r\n callback: (error: SdkError | null, result: boolean | null) => void,\r\n appContentUrl: string,\r\n ): void;\r\n /**\r\n * This function is the overloaded implementation of shareAppContentToStage.\r\n * Since the method signatures of the v1 callback and v2 promise differ in the type of the first parameter,\r\n * we need to do an extra check to know the typeof the @param1 to set the proper arguments of the utility function.\r\n * @param param1\r\n * @param param2\r\n * @returns Promise resolved indicating whether or not the share was successful or rejected with SdkError value\r\n */\r\n export function shareAppContentToStage(\r\n param1: string | ((error: SdkError | null, result: boolean | null) => void),\r\n param2?: string,\r\n ): Promise<boolean> {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n let appContentUrl: string;\r\n let callback: (error: SdkError | null, result: boolean | null) => void;\r\n if (typeof param1 === 'function') {\r\n // Legacy callback\r\n [callback, appContentUrl] = [param1, param2];\r\n } else {\r\n appContentUrl = param1;\r\n }\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<boolean>(\r\n shareAppContentToStageHelper,\r\n callback,\r\n appContentUrl,\r\n );\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Helper method to generate and return a promise for shareAppContentToStage\r\n * @param appContentUrl\r\n * @returns\r\n */\r\n function shareAppContentToStageHelper(appContentUrl: string): Promise<boolean> {\r\n return new Promise<boolean>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.shareAppContentToStage', appContentUrl));\r\n });\r\n }\r\n\r\n /**\r\n * Provides information related to app's in-meeting sharing capabilities\r\n *\r\n * @returns Promise resolved with sharing capability details or rejected with SdkError value\r\n */\r\n export function getAppContentStageSharingCapabilities(): Promise<IAppContentStageSharingCapabilities>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.getAppContentStageSharingCapabilities meeting.getAppContentStageSharingCapabilities(): Promise\\<IAppContentStageSharingCapabilities\\>} instead.\r\n *\r\n * Provides information related to app's in-meeting sharing capabilities\r\n *\r\n * @param callback - Callback contains 2 parameters, error and result.\r\n * error can either contain an error of type SdkError (error indication), or null (non-error indication)\r\n * appContentStageSharingCapabilities can either contain an IAppContentStageSharingCapabilities object\r\n * (indication of successful retrieval), or null (indication of failed retrieval)\r\n */\r\n export function getAppContentStageSharingCapabilities(\r\n callback: (\r\n error: SdkError | null,\r\n appContentStageSharingCapabilities: IAppContentStageSharingCapabilities | null,\r\n ) => void,\r\n ): void;\r\n export function getAppContentStageSharingCapabilities(\r\n callback?: (\r\n error: SdkError | null,\r\n appContentStageSharingCapabilities: IAppContentStageSharingCapabilities | null,\r\n ) => void,\r\n ): Promise<IAppContentStageSharingCapabilities> {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<IAppContentStageSharingCapabilities>(\r\n getAppContentStageSharingCapabilitiesHelper,\r\n callback,\r\n );\r\n }\r\n\r\n /**\r\n * @hidden\r\n * @returns\r\n */\r\n function getAppContentStageSharingCapabilitiesHelper(): Promise<IAppContentStageSharingCapabilities> {\r\n return new Promise<IAppContentStageSharingCapabilities>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.getAppContentStageSharingCapabilities'));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs.\r\n * ------------------------------------------\r\n * Terminates current stage sharing session in meeting\r\n *\r\n * @returns Promise resolved indicating whether or not sharing successfully stopped or rejected with SdkError value\r\n */\r\n export function stopSharingAppContentToStage(): Promise<boolean>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.stopSharingAppContentToStage meeting.stopSharingAppContentToStage(): Promise\\<boolean\\>} instead.\r\n *\r\n * @hidden\r\n * Hide from docs.\r\n * ------------------------------------------\r\n * Terminates current stage sharing session in meeting\r\n * @param callback Callback contains 2 parameters, error and result.\r\n * error can either contain an error of type SdkError (error indication), or null (non-error indication)\r\n * result can either contain a true boolean value (successful termination), or null (unsuccessful fetch)\r\n * @internal\r\n */\r\n export function stopSharingAppContentToStage(\r\n callback: (error: SdkError | null, result: boolean | null) => void,\r\n ): void;\r\n export function stopSharingAppContentToStage(\r\n callback?: (error: SdkError | null, result: boolean | null) => void,\r\n ): Promise<boolean> {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<boolean>(\r\n stopSharingAppContentToStageHelper,\r\n callback,\r\n );\r\n }\r\n\r\n /**\r\n * @hidden\r\n * @returns\r\n */\r\n function stopSharingAppContentToStageHelper(): Promise<boolean> {\r\n return new Promise<boolean>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.stopSharingAppContentToStage'));\r\n });\r\n }\r\n\r\n /**\r\n * Provides information related to current stage sharing state for app\r\n *\r\n * @returns Promise resolved to the App Content Stage Sharing State, or rejected with SdkError value\r\n */\r\n export function getAppContentStageSharingState(): Promise<IAppContentStageSharingState>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.getAppContentStageSharingState meeting.getAppContentStageSharingState(): Promise\\<IAppContentStageSharingState\\>} instead.\r\n *\r\n * Provides information related to current stage sharing state for app\r\n * @param callback - Callback contains 2 parameters, error and result.\r\n * error can either contain an error of type SdkError (error indication), or null (non-error indication)\r\n * appContentStageSharingState can either contain an IAppContentStageSharingState object\r\n * (indication of successful retrieval), or null (indication of failed retrieval)\r\n */\r\n export function getAppContentStageSharingState(\r\n callback: (error: SdkError | null, appContentStageSharingState: IAppContentStageSharingState | null) => void,\r\n ): void;\r\n export function getAppContentStageSharingState(\r\n callback?: (error: SdkError | null, appContentStageSharingState: IAppContentStageSharingState | null) => void,\r\n ): Promise<IAppContentStageSharingState> {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<IAppContentStageSharingState>(\r\n getAppContentStageSharingStateHelper,\r\n callback,\r\n );\r\n }\r\n\r\n function getAppContentStageSharingStateHelper(): Promise<IAppContentStageSharingState> {\r\n return new Promise<IAppContentStageSharingState>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.getAppContentStageSharingState'));\r\n });\r\n }\r\n}\r\n","import { sendAndHandleSdkError } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise, InputFunction } from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\nimport { SdkError } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace monetization {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * Data structure to represent a subscription plan.\r\n *\r\n * @internal\r\n */\r\n export interface PlanInfo {\r\n /**\r\n * @hidden\r\n * plan id\r\n */\r\n planId: string;\r\n /**\r\n * @hidden\r\n * term of the plan\r\n */\r\n term: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * Open dialog to start user's purchase experience\r\n *\r\n * @param planInfo optional parameter. It contains info of the subscription plan pushed to users.\r\n * error can either contain an error of type SdkError, incase of an error, or null when get is successful\r\n * @returns Promise that will be resolved when the operation has completed or rejected with SdkError value\r\n *\r\n * @internal\r\n */\r\n export function openPurchaseExperience(planInfo?: PlanInfo): Promise<void>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link monetization.openPurchaseExperience monetization.openPurchaseExperience(planInfo?: PlanInfo): Promise\\<void\\>} instead.\r\n *\r\n * @hidden\r\n * Hide from docs\r\n * Open dialog to start user's purchase experience\r\n *\r\n * @param callback Callback contains 1 parameters, error.\r\n * @param planInfo optional parameter. It contains info of the subscription plan pushed to users.\r\n * error can either contain an error of type SdkError, incase of an error, or null when get is successful\r\n *\r\n * @internal\r\n */\r\n export function openPurchaseExperience(callback: (error: SdkError | null) => void, planInfo?: PlanInfo): void;\r\n /**\r\n * @hidden\r\n * This function is the overloaded implementation of openPurchaseExperience.\r\n * Since the method signatures of the v1 callback and v2 promise differ in the type of the first parameter,\r\n * we need to do an extra check to know the typeof the @param1 to set the proper arguments of the utility function.\r\n * @param param1\r\n * @param param2\r\n * @returns Promise that will be resolved when the operation has completed or rejected with SdkError value\r\n */\r\n export function openPurchaseExperience(\r\n param1: ((error: SdkError | null) => void) | PlanInfo | undefined,\r\n param2?: PlanInfo,\r\n ): Promise<void> {\r\n let callback: (error: SdkError | null) => void;\r\n let planInfo: PlanInfo;\r\n if (typeof param1 === 'function') {\r\n callback = param1;\r\n planInfo = param2;\r\n } else {\r\n planInfo = param1;\r\n }\r\n const wrappedFunction: InputFunction<void> = () => {\r\n return new Promise<void>(resolve => {\r\n resolve(sendAndHandleSdkError('monetization.openPurchaseExperience', planInfo));\r\n });\r\n };\r\n\r\n ensureInitialized(FrameContexts.content);\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise(wrappedFunction, callback);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.monetization ? true : false;\r\n }\r\n}\r\n","import { sendAndHandleStatusAndReason as sendAndHandleError } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from './constants';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace calendar {\r\n export function openCalendarItem(openCalendarItemParams: OpenCalendarItemParams): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n if (!isSupported()) {\r\n throw new Error('Not supported');\r\n }\r\n\r\n if (!openCalendarItemParams.itemId || !openCalendarItemParams.itemId.trim()) {\r\n throw new Error('Must supply an itemId to openCalendarItem');\r\n }\r\n\r\n resolve(sendAndHandleError('calendar.openCalendarItem', openCalendarItemParams));\r\n });\r\n }\r\n export function composeMeeting(composeMeetingParams: ComposeMeetingParams): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n if (!isSupported()) {\r\n throw new Error('Not supported');\r\n }\r\n\r\n resolve(sendAndHandleError('calendar.composeMeeting', composeMeetingParams));\r\n });\r\n }\r\n export function isSupported(): boolean {\r\n return runtime.supports.calendar ? true : false;\r\n }\r\n\r\n export interface OpenCalendarItemParams {\r\n itemId: string;\r\n }\r\n\r\n export interface ComposeMeetingParams {\r\n attendees?: string[];\r\n startTime?: string;\r\n endTime?: string;\r\n subject?: string;\r\n content?: string;\r\n }\r\n}\r\n","import { sendAndHandleStatusAndReason as sendAndHandleError } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from './constants';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace mail {\r\n export function openMailItem(openMailItemParams: OpenMailItemParams): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n if (!isSupported()) {\r\n throw new Error('Not supported');\r\n }\r\n\r\n if (!openMailItemParams.itemId || !openMailItemParams.itemId.trim()) {\r\n throw new Error('Must supply an itemId to openMailItem');\r\n }\r\n\r\n resolve(sendAndHandleError('mail.openMailItem', openMailItemParams));\r\n });\r\n }\r\n\r\n export function composeMail(composeMailParams: ComposeMailParams): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n if (!isSupported()) {\r\n throw new Error('Not supported');\r\n }\r\n\r\n resolve(sendAndHandleError('mail.composeMail', composeMailParams));\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.mail ? true : false;\r\n }\r\n\r\n export interface OpenMailItemParams {\r\n itemId: string;\r\n }\r\n\r\n export enum ComposeMailType {\r\n New = 'new',\r\n Reply = 'reply',\r\n ReplyAll = 'replyAll',\r\n Forward = 'forward',\r\n }\r\n\r\n /**\r\n * Base of a discriminated union between compose scenarios.\r\n */\r\n interface ComposeMailBase<T extends ComposeMailType> {\r\n type: T;\r\n }\r\n /**\r\n * Interfaces for each type.\r\n */\r\n export interface ComposeNewParams extends ComposeMailBase<ComposeMailType.New> {\r\n toRecipients?: string[];\r\n ccRecipients?: string[];\r\n bccRecipients?: string[];\r\n subject?: string;\r\n message?: string;\r\n }\r\n export interface ComposeReplyOrForwardParams<T extends ComposeMailType> extends ComposeMailBase<T> {\r\n itemid: string;\r\n }\r\n\r\n export type ComposeMailParams =\r\n | ComposeNewParams\r\n | ComposeReplyOrForwardParams<ComposeMailType.Reply>\r\n | ComposeReplyOrForwardParams<ComposeMailType.ReplyAll>\r\n | ComposeReplyOrForwardParams<ComposeMailType.Forward>;\r\n}\r\n","import { sendAndHandleSdkError as sendAndHandleError } from '../internal/communication';\r\nimport { peoplePickerRequiredVersion } from '../internal/constants';\r\nimport { ensureInitialized, isCurrentSDKVersionAtLeast } from '../internal/internalAPIs';\r\nimport { validatePeoplePickerInput } from '../internal/mediaUtil';\r\nimport { callCallbackWithErrorOrResultFromPromiseAndReturnPromise } from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\nimport { ErrorCode, SdkError } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace people {\r\n /**\r\n * Launches a people picker and allows the user to select one or more people from the list\r\n * If the app is added to personal app scope the people picker launched is org wide and if the app is added to a chat/channel, people picker launched is also limited to the members of chat/channel\r\n \r\n * @param callback - Returns list of JSON object of type PeoplePickerResult which consists of AAD IDs, display names and emails of the selected users\r\n * @param peoplePickerInputs - Input parameters to launch customized people picker\r\n * @returns Promise that will be fulfilled when the operation has completed\r\n */\r\n export function selectPeople(peoplePickerInputs?: PeoplePickerInputs): Promise<PeoplePickerResult[]>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link people.selectPeople people.selectPeople(peoplePickerInputs?: PeoplePickerInputs): Promise\\<PeoplePickerResult[]\\>} instead.\r\n *\r\n * Launches a people picker and allows the user to select one or more people from the list\r\n * If the app is added to personal app scope the people picker launched is org wide and if the app is added to a chat/channel, people picker launched is also limited to the members of chat/channel\r\n \r\n * @param callback - Returns list of JSON object of type PeoplePickerResult which consists of AAD IDs, display names and emails of the selected users\r\n * @param peoplePickerInputs - Input parameters to launch customized people picker\r\n */\r\n export function selectPeople(\r\n callback: (error: SdkError, people: PeoplePickerResult[]) => void,\r\n peoplePickerInputs?: PeoplePickerInputs,\r\n ): void;\r\n /**\r\n * @hidden\r\n * This function is the overloaded implementation of selectPeople.\r\n * Since the method signatures of the v1 callback and v2 promise differ in the type of the first parameter,\r\n * we need to do an extra check to know the typeof the @param1 to set the proper arguments of the utility function.\r\n * @param param1\r\n * @param param2\r\n * @returns Promise of Array of PeoplePickerResult objects.\r\n */\r\n export function selectPeople(\r\n param1: PeoplePickerInputs | ((error: SdkError, people: PeoplePickerResult[]) => void) | undefined,\r\n param2?: PeoplePickerInputs,\r\n ): Promise<PeoplePickerResult[]> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task, FrameContexts.settings);\r\n\r\n let callback: (error: SdkError, people: PeoplePickerResult[]) => void;\r\n let peoplePickerInputs: PeoplePickerInputs;\r\n\r\n if (typeof param1 === 'function') {\r\n [callback, peoplePickerInputs] = [param1, param2];\r\n } else {\r\n peoplePickerInputs = param1;\r\n }\r\n\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise<PeoplePickerResult[]>(\r\n selectPeopleHelper,\r\n callback,\r\n peoplePickerInputs,\r\n );\r\n }\r\n\r\n function selectPeopleHelper(peoplePickerInputs?: PeoplePickerInputs): Promise<PeoplePickerResult[]> {\r\n return new Promise<PeoplePickerResult[]>(resolve => {\r\n if (!isCurrentSDKVersionAtLeast(peoplePickerRequiredVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n\r\n if (!validatePeoplePickerInput(peoplePickerInputs)) {\r\n throw { errorCode: ErrorCode.INVALID_ARGUMENTS };\r\n }\r\n\r\n resolve(sendAndHandleError('people.selectPeople', peoplePickerInputs));\r\n });\r\n }\r\n\r\n /**\r\n * Input parameter supplied to the People Picker API\r\n */\r\n export interface PeoplePickerInputs {\r\n /**\r\n * Optional; Set title for the people picker\r\n * Default value is \"Select people\" for multiselect and \"Select a person\" for single select\r\n */\r\n title?: string;\r\n\r\n /**\r\n * Optional; AAD ids of the users to be pre-populated in the search box of people picker control\r\n * If single select is enabled this value, only the first user in the list will be pre-populated\r\n * Default value is null\r\n */\r\n setSelected?: string[];\r\n\r\n /**\r\n * Optional; launches the people picker in org wide scope even if the app is added to a chat or channel\r\n * Default value is false\r\n */\r\n openOrgWideSearchInChatOrChannel?: boolean;\r\n\r\n /**\r\n * Optional; launches the people picker for which only 1 person can be selected\r\n * Default value is false\r\n */\r\n singleSelect?: boolean;\r\n }\r\n\r\n /**\r\n * Output user object of people picker API\r\n */\r\n export interface PeoplePickerResult {\r\n /**\r\n * user object Id (also known as aad id) of the selected user\r\n */\r\n objectId: string;\r\n\r\n /**\r\n * Optional; display name of the selected user\r\n */\r\n displayName?: string;\r\n\r\n /**\r\n * Optional; email of the selected user\r\n */\r\n email?: string;\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.people ? true : false;\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from './constants';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * Namespace to video extensibility of the SDK.\r\n *\r\n * @alpha\r\n *\r\n */\r\nexport namespace video {\r\n /**\r\n * Represents a video frame.\r\n */\r\n export interface VideoFrame {\r\n /**\r\n * Video frame width.\r\n */\r\n width: number;\r\n /**\r\n * Video frame height.\r\n */\r\n height: number;\r\n /**\r\n * Video frame buffer\r\n */\r\n data: Uint8ClampedArray;\r\n /**\r\n * NV12 luma stride, valid only when video frame format is NV12\r\n */\r\n lumaStride?: number;\r\n /**\r\n * NV12 chroma stride, valid only when video frame format is NV12\r\n */\r\n chromaStride?: number;\r\n /**\r\n * RGB stride, valid only when video frame format is RGB\r\n */\r\n stride?: number;\r\n }\r\n\r\n /**\r\n * Video frame format enum, currently only support NV12\r\n */\r\n export enum VideoFrameFormat {\r\n NV12,\r\n }\r\n\r\n /**\r\n * Video frame configuration supplied to Teams to customize the generated video frame parameters, like format.\r\n */\r\n export interface VideoFrameConfig {\r\n /**\r\n * video format\r\n */\r\n format: VideoFrameFormat;\r\n }\r\n\r\n /**\r\n * Video effect change type enum\r\n */\r\n export enum EffectChangeType {\r\n /**\r\n * current video effect changed.\r\n */\r\n EffectChanged,\r\n /**\r\n * disable the video effect\r\n */\r\n EffectDisabled,\r\n }\r\n\r\n /**\r\n * Video frame call back function definition\r\n */\r\n export type VideoFrameCallback = (\r\n frame: VideoFrame,\r\n notifyVideoFrameProcessed: () => void,\r\n notifyError: (errorMessage: string) => void,\r\n ) => void;\r\n\r\n /**\r\n * Video effect change call back function definition\r\n */\r\n export type VideoEffectCallBack = (effectId: string | undefined) => void;\r\n\r\n /**\r\n * register to read the video frames in Permissions section.\r\n */\r\n export function registerForVideoFrame(frameCallback: VideoFrameCallback, config: VideoFrameConfig): void {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n registerHandler('video.newVideoFrame', (videoFrame: VideoFrame) => {\r\n if (videoFrame !== undefined) {\r\n frameCallback(videoFrame, notifyVideoFrameProcessed, notifyError);\r\n }\r\n });\r\n sendMessageToParent('video.registerForVideoFrame', [config]);\r\n }\r\n\r\n /**\r\n * video extension should call this to notify Teams Client current selected effect parameter changed.\r\n * If it's pre-meeting, Teams client will call videoEffectCallback immediately then use the videoEffect.\r\n * in-meeting scenario, we will call videoEffectCallback when apply button clicked.\r\n *\r\n * @param effectChangeType - the effect change type.\r\n * @param effectId - Newly selected effect id.\r\n */\r\n export function notifySelectedVideoEffectChanged(\r\n effectChangeType: EffectChangeType,\r\n effectId: string | undefined,\r\n ): void {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n sendMessageToParent('video.videoEffectChanged', [effectChangeType, effectId]);\r\n }\r\n\r\n /**\r\n * Register the video effect callback, Teams client uses this to notify the video extension the new video effect will by applied.\r\n */\r\n export function registerForVideoEffect(callback: VideoEffectCallBack): void {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n registerHandler('video.effectParameterChange', callback);\r\n }\r\n\r\n /**\r\n * sending notification to Teams client finished the video frame processing, now Teams client can render this video frame\r\n * or pass the video frame to next one in video pipeline.\r\n */\r\n function notifyVideoFrameProcessed(): void {\r\n sendMessageToParent('video.videoFrameProcessed');\r\n }\r\n\r\n /**\r\n * sending error notification to Teams client.\r\n */\r\n function notifyError(errorMessage: string): void {\r\n sendMessageToParent('video.notifyError', [errorMessage]);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.video ? true : false;\r\n }\r\n} //end of video namespace\r\n","import { sendAndHandleSdkError } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { callCallbackWithSdkErrorFromPromiseAndReturnPromise, InputFunction } from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\nimport { ErrorCode, SdkError } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace sharing {\r\n export const SharingAPIMessages = {\r\n shareWebContent: 'sharing.shareWebContent',\r\n };\r\n\r\n // More types can be added as we expand share capability\r\n type ContentType = 'URL';\r\n\r\n interface IBaseSharedContent {\r\n type: ContentType;\r\n }\r\n\r\n // More types can be added as we expand share capability\r\n export type IShareRequestContentType = IURLContent;\r\n\r\n export interface IShareRequest<T> {\r\n content: T[];\r\n }\r\n\r\n export interface IURLContent extends IBaseSharedContent {\r\n type: 'URL';\r\n\r\n /**\r\n * Required URL\r\n */\r\n url: string;\r\n\r\n /**\r\n * Default initial message text\r\n */\r\n message?: string;\r\n\r\n /**\r\n * Show URL preview, defaults to true\r\n */\r\n preview?: boolean;\r\n }\r\n\r\n /**\r\n * Feature is under development\r\n * Opens a share dialog for web content\r\n *\r\n * @param shareWebContentRequest - web content info\r\n * @returns Promise that will be fulfilled when the operation has completed\r\n */\r\n export function shareWebContent(shareWebContentRequest: IShareRequest<IShareRequestContentType>): Promise<void>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link sharing.shareWebContent sharing.shareWebContent(shareWebContentRequest: IShareRequest\\<IShareRequestContentType\\>): Promise\\<void\\>} instead.\r\n *\r\n * Feature is under development\r\n * Opens a share dialog for web content\r\n *\r\n * @param shareWebContentRequest - web content info\r\n * @param callback - optional callback\r\n */\r\n export function shareWebContent(\r\n shareWebContentRequest: IShareRequest<IShareRequestContentType>,\r\n callback: (err?: SdkError) => void,\r\n ): void;\r\n export function shareWebContent(\r\n shareWebContentRequest: IShareRequest<IShareRequestContentType>,\r\n callback?: (err?: SdkError) => void,\r\n ): Promise<void> {\r\n // validate the given input (synchronous check)\r\n try {\r\n validateNonEmptyContent(shareWebContentRequest);\r\n validateTypeConsistency(shareWebContentRequest);\r\n validateContentForSupportedTypes(shareWebContentRequest);\r\n } catch (err) {\r\n //return the error via callback(v1) or rejected promise(v2)\r\n const wrappedFunction: InputFunction<void> = () => Promise.reject(err);\r\n return callCallbackWithSdkErrorFromPromiseAndReturnPromise(wrappedFunction, callback);\r\n }\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n return callCallbackWithSdkErrorFromPromiseAndReturnPromise(shareWebContentHelper, callback, shareWebContentRequest);\r\n }\r\n\r\n function shareWebContentHelper(shareWebContentRequest: IShareRequest<IShareRequestContentType>): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n resolve(sendAndHandleSdkError(SharingAPIMessages.shareWebContent, shareWebContentRequest));\r\n });\r\n }\r\n\r\n /**\r\n * Functions for validating the shareRequest input parameter\r\n */\r\n function validateNonEmptyContent(shareRequest: IShareRequest<IShareRequestContentType>): void {\r\n if (!(shareRequest && shareRequest.content && shareRequest.content.length)) {\r\n const err: SdkError = {\r\n errorCode: ErrorCode.INVALID_ARGUMENTS,\r\n message: 'Shared content is missing',\r\n };\r\n throw err;\r\n }\r\n }\r\n\r\n function validateTypeConsistency(shareRequest: IShareRequest<IShareRequestContentType>): void {\r\n let err: SdkError;\r\n if (shareRequest.content.some(item => !item.type)) {\r\n err = {\r\n errorCode: ErrorCode.INVALID_ARGUMENTS,\r\n message: 'Shared content type cannot be undefined',\r\n };\r\n throw err;\r\n }\r\n if (shareRequest.content.some(item => item.type !== shareRequest.content[0].type)) {\r\n err = {\r\n errorCode: ErrorCode.INVALID_ARGUMENTS,\r\n message: 'Shared content must be of the same type',\r\n };\r\n throw err;\r\n }\r\n }\r\n\r\n function validateContentForSupportedTypes(shareRequest: IShareRequest<IShareRequestContentType>): void {\r\n let err: SdkError;\r\n if (shareRequest.content[0].type === 'URL') {\r\n if (shareRequest.content.some(item => !item.url)) {\r\n err = {\r\n errorCode: ErrorCode.INVALID_ARGUMENTS,\r\n message: 'URLs are required for URL content types',\r\n };\r\n throw err;\r\n }\r\n } else {\r\n err = {\r\n errorCode: ErrorCode.INVALID_ARGUMENTS,\r\n message: 'Content type is unsupported',\r\n };\r\n throw err;\r\n }\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.sharing ? true : false;\r\n }\r\n}\r\n","import { sendAndHandleSdkError } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { callCallbackWithErrorOrResultFromPromiseAndReturnPromise } from '../internal/utils';\r\nimport { SdkError } from '../public';\r\nimport { FrameContexts } from './constants';\r\n\r\n/**\r\n * Namespace to interact with the stage view specific part of the SDK.\r\n */\r\nexport namespace stageView {\r\n /**\r\n * Parameters to open a stage view.\r\n */\r\n export interface StageViewParams {\r\n /**\r\n * The application ID of the Teams application to be opened.\r\n */\r\n appId: string;\r\n\r\n /**\r\n * The URL of the content to display.\r\n */\r\n contentUrl: string;\r\n\r\n /**\r\n * The chat or channel ID.\r\n */\r\n threadId: string;\r\n\r\n /**\r\n * The title to give the stage view.\r\n */\r\n title: string;\r\n\r\n /**\r\n * The Teams app website URL.\r\n */\r\n websiteUrl?: string;\r\n\r\n /**\r\n * The entity ID of the Teams app content being opened.\r\n */\r\n entityId?: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Feature is under development\r\n *\r\n * Opens a stage view to display a Teams app\r\n * @param stageViewParams The parameters to pass into the stage view.\r\n *\r\n */\r\n export function open(stageViewParams: StageViewParams): Promise<void>;\r\n /**\r\n * @hidden\r\n * Feature is under development\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link stageView.open stageView.open(): Promise\\<void\\>} instead.\r\n *\r\n * Opens a stage view to display a Teams app\r\n * @param stageViewParams The parameters to pass into the stage view.\r\n * Optional; @param callback Callback that will be triggered once the stage view is closed.\r\n * The callback takes as an argument an SdkError in case something happened (i.e.\r\n * no permissions to execute the API)\r\n */\r\n export function open(stageViewParams: StageViewParams, callback?: (sdkError?: SdkError) => void): void;\r\n export function open(stageViewParams: StageViewParams, callback?: (sdkError?: SdkError) => void): Promise<void> {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!stageViewParams) {\r\n throw new Error('[stageView.open] Stage view params cannot be null');\r\n }\r\n const wrappedFunction = (): Promise<void> =>\r\n new Promise(resolve => resolve(sendAndHandleSdkError('stageView.open', stageViewParams)));\r\n\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise(wrappedFunction, callback);\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from './constants';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace call {\r\n export enum CallModalities {\r\n Unknown = 'unknown',\r\n Audio = 'audio',\r\n Video = 'video',\r\n VideoBasedScreenSharing = 'videoBasedScreenSharing',\r\n Data = 'data',\r\n }\r\n\r\n export interface StartCallParams {\r\n // comma-separated list of user IDs representing the participants of the call.\r\n // Currently the User ID field supports the Azure AD UserPrincipalName,\r\n // typically an email address, or in case of a PSTN call, it supports a pstn\r\n // mri 4:<phonenumber>.\r\n targets: string[];\r\n // List of modalities for the call. Defaults to [“audio”].\r\n requestedModalities?: CallModalities[];\r\n // An optional parameter that informs about the source of the deep link\r\n source?: string;\r\n }\r\n\r\n /**\r\n * Starts a call with other users\r\n *\r\n * @param startCallParams - Parameters for the call\r\n * @returns If the call is accepted\r\n */\r\n export function startCall(startCallParams: StartCallParams): Promise<boolean> {\r\n return new Promise(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n if (!isSupported()) {\r\n throw new Error('Not supported');\r\n }\r\n return sendMessageToParent('call.startCall', [startCallParams], resolve);\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.call ? true : false;\r\n }\r\n}\r\n","import { app } from './app';\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app} namespace instead.\r\n */\r\nexport namespace appInitialization {\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.Messages} instead.\r\n */\r\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n export import Messages = app.Messages;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.FailedReason} instead.\r\n */\r\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n export import FailedReason = app.FailedReason;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.ExpectedFailureReason} instead.\r\n */\r\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n export import ExpectedFailureReason = app.ExpectedFailureReason;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.IFailedRequest} instead.\r\n */\r\n export import IFailedRequest = app.IFailedRequest;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.IExpectedFailureRequest} instead.\r\n */\r\n export import IExpectedFailureRequest = app.IExpectedFailureRequest;\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.notifyAppLoaded app.notifyAppLoaded(): void} instead.\r\n * Notifies the frame that app has loaded and to hide the loading indicator if one is shown.\r\n */\r\n export function notifyAppLoaded(): void {\r\n app.notifyAppLoaded();\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.notifySuccess app.notifySuccess(): void} instead.\r\n * Notifies the frame that app initialization is successful and is ready for user interaction.\r\n */\r\n export function notifySuccess(): void {\r\n app.notifySuccess();\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.notifyFailure app.notifyFailure(appInitializationFailedRequest: IFailedRequest): void} instead.\r\n * Notifies the frame that app initialization has failed and to show an error page in its place.\r\n */\r\n export function notifyFailure(appInitializationFailedRequest: IFailedRequest): void {\r\n app.notifyFailure(appInitializationFailedRequest);\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.notifyExpectedFailure app.notifyExpectedFailure(expectedFailureRequest: IExpectedFailureRequest): void} instead.\r\n * Notifies the frame that app initialized with some expected errors.\r\n */\r\n export function notifyExpectedFailure(expectedFailureRequest: IExpectedFailureRequest): void {\r\n app.notifyExpectedFailure(expectedFailureRequest);\r\n }\r\n}\r\n","import { ensureInitialized } from '../internal/internalAPIs';\r\nimport { getGenericOnCompleteHandler } from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\nimport { pages } from './pages';\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config} namespace instead.\r\n *\r\n * Namespace to interact with the settings-specific part of the SDK.\r\n * This object is usable only on the settings frame.\r\n */\r\nexport namespace settings {\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.Config} instead.\r\n * @remarks\r\n * Renamed to config in pages.Config\r\n */\r\n export import Settings = pages.InstanceConfig;\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.SaveEvent} instead.\r\n * @remarks\r\n * See pages.SaveEvent\r\n */\r\n export import SaveEvent = pages.config.SaveEvent;\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.RemoveEvent} instead.\r\n * @remarks\r\n * See pages.RemoveEvent\r\n */\r\n export import RemoveEvent = pages.config.RemoveEvent;\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.SaveParameters} instead.\r\n * @remarks\r\n * See pages.SaveParameters\r\n */\r\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n export import SaveParameters = pages.config.SaveParameters;\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.setValidityState pages.config.setValidityState(validityState: boolean): void} instead.\r\n *\r\n * Sets the validity state for the settings.\r\n * The initial value is false, so the user cannot save the settings until this is called with true.\r\n *\r\n * @param validityState - Indicates whether the save or remove button is enabled for the user.\r\n */\r\n export function setValidityState(validityState: boolean): void {\r\n pages.config.setValidityState(validityState);\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.getConfig pages.config.getConfig(): Promise\\<Config\\>} instead.\r\n *\r\n * Gets the settings for the current instance.\r\n *\r\n * @param callback - The callback to invoke when the {@link Settings} object is retrieved.\r\n */\r\n export function getSettings(callback: (instanceSettings: Settings) => void): void {\r\n ensureInitialized(FrameContexts.content, FrameContexts.settings, FrameContexts.remove, FrameContexts.sidePanel);\r\n pages.getConfig().then((config: pages.InstanceConfig) => {\r\n callback(config);\r\n });\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.setConfig pages.config.setConfig(instanceSettings: Config): Promise\\<void\\>} instead.\r\n *\r\n * Sets the settings for the current instance.\r\n * This is an asynchronous operation; calls to getSettings are not guaranteed to reflect the changed state.\r\n *\r\n * @param - Set the desired settings for this instance.\r\n */\r\n export function setSettings(\r\n instanceSettings: Settings,\r\n onComplete?: (status: boolean, reason?: string) => void,\r\n ): void {\r\n ensureInitialized(FrameContexts.content, FrameContexts.settings, FrameContexts.sidePanel);\r\n onComplete = onComplete ? onComplete : getGenericOnCompleteHandler();\r\n pages.config\r\n .setConfig(instanceSettings)\r\n .then(() => {\r\n onComplete(true);\r\n })\r\n .catch((error: Error) => {\r\n onComplete(false, error.message);\r\n });\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.registerOnSaveHandler pages.config.registerOnSaveHandler(handler: (evt: SaveEvent) => void): void} instead.\r\n *\r\n * Registers a handler for when the user attempts to save the settings. This handler should be used\r\n * to create or update the underlying resource powering the content.\r\n * The object passed to the handler must be used to notify whether to proceed with the save.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the user selects the save button.\r\n */\r\n export function registerOnSaveHandler(handler: (evt: SaveEvent) => void): void {\r\n pages.config.registerOnSaveHandler(handler);\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.registerOnRemoveHandler pages.config.registerOnRemoveHandler(handler: (evt: RemoveEvent) => void): void} instead.\r\n *\r\n * Registers a handler for user attempts to remove content. This handler should be used\r\n * to remove the underlying resource powering the content.\r\n * The object passed to the handler must be used to indicate whether to proceed with the removal.\r\n * Only one handler may be registered at a time. Subsequent registrations will override the first.\r\n *\r\n * @param handler - The handler to invoke when the user selects the remove button.\r\n */\r\n export function registerOnRemoveHandler(handler: (evt: RemoveEvent) => void): void {\r\n pages.config.registerOnRemoveHandler(handler);\r\n }\r\n}\r\n","/* eslint-disable @typescript-eslint/ban-types */\r\n\r\nimport { IAppWindow } from './appWindow';\r\nimport { TaskModuleDimension } from './constants';\r\nimport { dialog } from './dialog';\r\nimport { TaskInfo } from './interfaces';\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link dialog} namespace instead.\r\n *\r\n * Namespace to interact with the task module-specific part of the SDK.\r\n * This object is usable only on the content frame.\r\n * The tasks namespace will be deprecated. Please use dialog for future developments.\r\n */\r\nexport namespace tasks {\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link dialog.open dialog.open(dialogInfo: DialogInfo, submitHandler?: (err: string, result: string) => void): IAppWindow} instead.\r\n *\r\n * Allows an app to open the task module.\r\n *\r\n * @param taskInfo - An object containing the parameters of the task module\r\n * @param submitHandler - Handler to call when the task module is completed\r\n */\r\n export function startTask(\r\n taskInfo: TaskInfo,\r\n submitHandler?: (err: string, result: string | object) => void,\r\n ): IAppWindow {\r\n return dialog.open(getDialogInfoFromTaskInfo(taskInfo), submitHandler);\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link dialog.resize dialog.resize(dialogInfo: DialogInfo): void} instead.\r\n *\r\n * Update height/width task info properties.\r\n *\r\n * @param taskInfo - An object containing width and height properties\r\n */\r\n export function updateTask(taskInfo: TaskInfo): void {\r\n dialog.resize(taskInfo);\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link dialog.submit dialog.submit(result?: string | object, appIds?: string | string[]): void} instead.\r\n *\r\n * Submit the task module.\r\n *\r\n * @param result - Contains the result to be sent to the bot or the app. Typically a JSON object or a serialized version of it\r\n * @param appIds - Helps to validate that the call originates from the same appId as the one that invoked the task module\r\n */\r\n export function submitTask(result?: string | object, appIds?: string | string[]): void {\r\n dialog.submit(result, appIds);\r\n }\r\n\r\n function getDialogInfoFromTaskInfo(taskInfo: TaskInfo): TaskInfo {\r\n const dialogHeight =\r\n taskInfo.height && typeof taskInfo.height !== 'number'\r\n ? getDialogDimensionFromTaskModuleDimension(taskInfo.height)\r\n : (taskInfo.height as number);\r\n const dialogWidth =\r\n taskInfo.width && typeof taskInfo.width !== 'number'\r\n ? getDialogDimensionFromTaskModuleDimension(taskInfo.width)\r\n : (taskInfo.width as number);\r\n const dialogInfo: TaskInfo = {\r\n url: taskInfo.url,\r\n card: taskInfo.card,\r\n height: dialogHeight,\r\n width: dialogWidth,\r\n title: taskInfo.title,\r\n fallbackUrl: taskInfo.fallbackUrl,\r\n completionBotId: taskInfo.completionBotId,\r\n };\r\n return dialogInfo;\r\n }\r\n\r\n function getDialogDimensionFromTaskModuleDimension(taskModuleDimension: TaskModuleDimension): TaskModuleDimension {\r\n if (taskModuleDimension === TaskModuleDimension.Large) {\r\n return TaskModuleDimension.Large;\r\n } else if (taskModuleDimension === TaskModuleDimension.Medium) {\r\n return TaskModuleDimension.Medium;\r\n } else {\r\n return TaskModuleDimension.Small;\r\n }\r\n }\r\n}\r\n","import {\r\n sendAndHandleSdkError as sendAndHandleError,\r\n sendMessageToParent,\r\n sendMessageToParentAsync,\r\n} from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FileOpenPreference, FrameContexts, SdkError } from '../public';\r\nimport { runtime } from '../public/runtime';\r\nimport { FilePreviewParameters } from './interfaces';\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Namespace to interact with the files specific part of the SDK.\r\n *\r\n * @alpha\r\n */\r\nexport namespace files {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Cloud storage providers registered with Microsoft Teams\r\n */\r\n export enum CloudStorageProvider {\r\n Dropbox = 'DROPBOX',\r\n Box = 'BOX',\r\n Sharefile = 'SHAREFILE',\r\n GoogleDrive = 'GOOGLEDRIVE',\r\n Egnyte = 'EGNYTE',\r\n SharePoint = 'SharePoint',\r\n }\r\n interface IWopiThumbnail {\r\n size: number;\r\n url: string;\r\n }\r\n\r\n interface IWopiService {\r\n name: string;\r\n description: string;\r\n thumbnails: IWopiThumbnail[];\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n *\r\n * External third-party cloud storages providers interface\r\n */\r\n export interface IExternalProvider extends IWopiService {\r\n providerType: CloudStorageProviderType;\r\n providerCode: CloudStorageProvider;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Cloud storage provider type enums\r\n */\r\n export enum CloudStorageProviderType {\r\n Sharepoint = 0,\r\n WopiIntegration,\r\n Google,\r\n OneDrive,\r\n Recent,\r\n Aggregate,\r\n FileSystem, // Used for Downloaded files on Desktop\r\n Search, // Used by P2P files with OSearch\r\n AllFiles, // Used by P2P files with AllFiles API\r\n SharedWithMe,\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Cloud storage folder interface\r\n */\r\n export interface CloudStorageFolder {\r\n /**\r\n * @hidden\r\n * ID of the cloud storage folder\r\n */\r\n id: string;\r\n /**\r\n * @hidden\r\n * Display Name/Title of the cloud storage folder\r\n */\r\n title: string;\r\n /**\r\n * @hidden\r\n * ID of the cloud storage folder in the provider\r\n */\r\n folderId: string;\r\n /**\r\n * @hidden\r\n * Type of the cloud storage folder provider integration\r\n */\r\n providerType: CloudStorageProviderType;\r\n /**\r\n * @hidden\r\n * Code of the supported cloud storage folder provider\r\n */\r\n providerCode: CloudStorageProvider;\r\n /**\r\n * @hidden\r\n * Display name of the owner of the cloud storage folder provider\r\n */\r\n ownerDisplayName: string;\r\n /**\r\n * @hidden\r\n * Sharepoint specific siteURL of the folder\r\n */\r\n siteUrl?: string;\r\n /**\r\n * @hidden\r\n * Sharepoint specific serverRelativeUrl of the folder\r\n */\r\n serverRelativeUrl?: string;\r\n /**\r\n * @hidden\r\n * Sharepoint specific libraryType of the folder\r\n */\r\n libraryType?: string;\r\n /**\r\n * @hidden\r\n * Sharepoint specific accessType of the folder\r\n */\r\n accessType?: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Cloud storage item interface\r\n */\r\n export interface CloudStorageFolderItem {\r\n /**\r\n * @hidden\r\n * ID of the item in the provider\r\n */\r\n id: string;\r\n /**\r\n * @hidden\r\n * Display name/title\r\n */\r\n title: string;\r\n /**\r\n * @hidden\r\n * Key to differentiate files and subdirectory\r\n */\r\n isSubdirectory: boolean;\r\n /**\r\n * @hidden\r\n * File extension\r\n */\r\n type: string;\r\n /**\r\n * @hidden\r\n * Last modifed time of the item\r\n */\r\n lastModifiedTime: string;\r\n /**\r\n * @hidden\r\n * Display size of the items in bytes\r\n */\r\n size: number;\r\n /**\r\n * @hidden\r\n * URL of the file\r\n */\r\n objectUrl: string;\r\n /**\r\n * @hidden\r\n * Temporary access token for the item\r\n */\r\n accessToken?: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Files entity user interface\r\n */\r\n export interface IFilesEntityUser {\r\n /**\r\n * User name.\r\n */\r\n displayName: string;\r\n /**\r\n * User email.\r\n */\r\n email: string;\r\n\r\n /**\r\n * User MRI.\r\n */\r\n mri: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Special Document Library enum\r\n */\r\n export enum SpecialDocumentLibraryType {\r\n ClassMaterials = 'classMaterials',\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Document Library Access enum\r\n */\r\n export enum DocumentLibraryAccessType {\r\n Readonly = 'readonly',\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * SharePoint file interface\r\n */\r\n export interface ISharePointFile {\r\n siteId?: string;\r\n siteUrl: string;\r\n objectId: string;\r\n objectUrl: string;\r\n openInWindowFileUrl: string;\r\n title: string;\r\n isFolder: boolean;\r\n serverRelativeUrl: string;\r\n lastModifiedByUser: IFilesEntityUser;\r\n lastModifiedTime: string;\r\n sentByUser: IFilesEntityUser;\r\n createdByUser: IFilesEntityUser;\r\n createdTime: string;\r\n size: number;\r\n type: string;\r\n spItemUrl?: string;\r\n libraryType?: SpecialDocumentLibraryType;\r\n accessType?: DocumentLibraryAccessType;\r\n etag?: string;\r\n remoteItem?: string;\r\n listUrl?: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Download status enum\r\n */\r\n export enum FileDownloadStatus {\r\n Downloaded = 'Downloaded',\r\n Downloading = 'Downloading',\r\n Failed = 'Failed',\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Download Files interface\r\n */\r\n export interface IFileItem {\r\n /**\r\n * ID of the file metadata\r\n */\r\n objectId?: string;\r\n /**\r\n * Path of the file\r\n */\r\n path?: string;\r\n /**\r\n * Size of the file in bytes\r\n */\r\n sizeInBytes?: number;\r\n /**\r\n * Download status\r\n */\r\n status?: FileDownloadStatus;\r\n /**\r\n * Download timestamp\r\n */\r\n timestamp: Date;\r\n /**\r\n * File name\r\n */\r\n title: string;\r\n /**\r\n * Type of file i.e. the file extension.\r\n */\r\n extension: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Gets a list of cloud storage folders added to the channel\r\n *\r\n * @param channelId - ID of the channel whose cloud storage folders should be retrieved\r\n */\r\n export function getCloudStorageFolders(channelId: string): Promise<CloudStorageFolder[]> {\r\n return new Promise<CloudStorageFolder[]>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!channelId || channelId.length === 0) {\r\n throw new Error('[files.getCloudStorageFolders] channelId name cannot be null or empty');\r\n }\r\n\r\n resolve(sendAndHandleError('files.getCloudStorageFolders', channelId));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Initiates the add cloud storage folder flow\r\n * @param channelId - ID of the channel to add cloud storage folder\r\n */\r\n export function addCloudStorageFolder(channelId: string): Promise<[boolean, CloudStorageFolder[]]> {\r\n return new Promise<[SdkError, boolean, CloudStorageFolder[]]>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!channelId || channelId.length === 0) {\r\n throw new Error('[files.addCloudStorageFolder] channelId name cannot be null or empty');\r\n }\r\n\r\n resolve(sendMessageToParentAsync('files.addCloudStorageFolder', [channelId]));\r\n }).then(([error, isFolderAdded, folders]: [SdkError, boolean, CloudStorageFolder[]]) => {\r\n if (error) {\r\n throw error;\r\n }\r\n const result: [boolean, CloudStorageFolder[]] = [isFolderAdded, folders];\r\n return result;\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Deletes a cloud storage folder from channel\r\n *\r\n * @param channelId - ID of the channel where folder is to be deleted\r\n * @param folderToDelete - cloud storage folder to be deleted\r\n */\r\n export function deleteCloudStorageFolder(channelId: string, folderToDelete: CloudStorageFolder): Promise<boolean> {\r\n return new Promise<boolean>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!channelId) {\r\n throw new Error('[files.deleteCloudStorageFolder] channelId name cannot be null or empty');\r\n }\r\n if (!folderToDelete) {\r\n throw new Error('[files.deleteCloudStorageFolder] folderToDelete cannot be null or empty');\r\n }\r\n\r\n resolve(sendAndHandleError('files.deleteCloudStorageFolder', channelId, folderToDelete));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Fetches the contents of a Cloud storage folder (CloudStorageFolder) / sub directory\r\n *\r\n * @param folder - Cloud storage folder (CloudStorageFolder) / sub directory (CloudStorageFolderItem)\r\n * @param providerCode - Code of the cloud storage folder provider\r\n */\r\n export function getCloudStorageFolderContents(\r\n folder: CloudStorageFolder | CloudStorageFolderItem,\r\n providerCode: CloudStorageProvider,\r\n ): Promise<CloudStorageFolderItem[]> {\r\n return new Promise<CloudStorageFolderItem[]>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!folder || !providerCode) {\r\n throw new Error('[files.getCloudStorageFolderContents] folder/providerCode name cannot be null or empty');\r\n }\r\n\r\n if ('isSubdirectory' in folder && !folder.isSubdirectory) {\r\n throw new Error('[files.getCloudStorageFolderContents] provided folder is not a subDirectory');\r\n }\r\n\r\n resolve(sendAndHandleError('files.getCloudStorageFolderContents', folder, providerCode));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Open a cloud storage file in teams\r\n *\r\n * @param file - cloud storage file that should be opened\r\n * @param providerCode - Code of the cloud storage folder provider\r\n * @param fileOpenPreference - Whether file should be opened in web/inline\r\n */\r\n export function openCloudStorageFile(\r\n file: CloudStorageFolderItem,\r\n providerCode: CloudStorageProvider,\r\n fileOpenPreference?: FileOpenPreference.Web | FileOpenPreference.Inline,\r\n ): void {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!file || !providerCode) {\r\n throw new Error('[files.openCloudStorageFile] file/providerCode cannot be null or empty');\r\n }\r\n\r\n if (file.isSubdirectory) {\r\n throw new Error('[files.openCloudStorageFile] provided file is a subDirectory');\r\n }\r\n\r\n sendMessageToParent('files.openCloudStorageFile', [file, providerCode, fileOpenPreference]);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Opens a client-friendly preview of the specified file.\r\n *\r\n * @param file - The file to preview.\r\n */\r\n export function openFilePreview(filePreviewParameters: FilePreviewParameters): void {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n const params = [\r\n filePreviewParameters.entityId,\r\n filePreviewParameters.title,\r\n filePreviewParameters.description,\r\n filePreviewParameters.type,\r\n filePreviewParameters.objectUrl,\r\n filePreviewParameters.downloadUrl,\r\n filePreviewParameters.webPreviewUrl,\r\n filePreviewParameters.webEditUrl,\r\n filePreviewParameters.baseUrl,\r\n filePreviewParameters.editFile,\r\n filePreviewParameters.subEntityId,\r\n filePreviewParameters.viewerAction,\r\n filePreviewParameters.fileOpenPreference,\r\n filePreviewParameters.conversationId,\r\n ];\r\n\r\n sendMessageToParent('openFilePreview', params);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Allow 1st party apps to call this function to get the external\r\n * third party cloud storage accounts that the tenant supports\r\n * @param excludeAddedProviders: return a list of support third party\r\n * cloud storages that hasn't been added yet.\r\n */\r\n export function getExternalProviders(excludeAddedProviders = false): Promise<IExternalProvider[]> {\r\n return new Promise<IExternalProvider[]>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n resolve(sendAndHandleError('files.getExternalProviders', excludeAddedProviders));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Allow 1st party apps to call this function to move files\r\n * among SharePoint and third party cloud storages.\r\n */\r\n export function copyMoveFiles(\r\n selectedFiles: CloudStorageFolderItem[] | ISharePointFile[],\r\n providerCode: CloudStorageProvider,\r\n destinationFolder: CloudStorageFolderItem | ISharePointFile,\r\n destinationProviderCode: CloudStorageProvider,\r\n isMove = false,\r\n ): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n if (!selectedFiles || selectedFiles.length === 0) {\r\n throw new Error('[files.copyMoveFiles] selectedFiles cannot be null or empty');\r\n }\r\n if (!providerCode) {\r\n throw new Error('[files.copyMoveFiles] providerCode cannot be null or empty');\r\n }\r\n if (!destinationFolder) {\r\n throw new Error('[files.copyMoveFiles] destinationFolder cannot be null or empty');\r\n }\r\n if (!destinationProviderCode) {\r\n throw new Error('[files.copyMoveFiles] destinationProviderCode cannot be null or empty');\r\n }\r\n\r\n resolve(\r\n sendAndHandleError(\r\n 'files.copyMoveFiles',\r\n selectedFiles,\r\n providerCode,\r\n destinationFolder,\r\n destinationProviderCode,\r\n isMove,\r\n ),\r\n );\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.files ? true : false;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Gets list of downloads for current user\r\n * @param callback Callback that will be triggered post downloads load\r\n */\r\n export function getFileDownloads(callback: (error?: SdkError, files?: IFileItem[]) => void): void {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!callback) {\r\n throw new Error('[files.getFileDownloads] Callback cannot be null');\r\n }\r\n\r\n sendMessageToParent('files.getFileDownloads', [], callback);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Open download preference folder\r\n */\r\n export function openDownloadFolder(): void {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n sendMessageToParent('files.openDownloadFolder', []);\r\n }\r\n}\r\n","import { sendAndUnwrap } from '../internal/communication';\r\nimport { getUserJoinedTeamsSupportedAndroidClientVersion } from '../internal/constants';\r\nimport { GlobalVars } from '../internal/globalVars';\r\nimport { ensureInitialized, isCurrentSDKVersionAtLeast } from '../internal/internalAPIs';\r\nimport { HostClientType } from '../public/constants';\r\nimport { ErrorCode, SdkError } from '../public/interfaces';\r\nimport { runtime } from '../public/runtime';\r\nimport { TeamInstanceParameters, UserJoinedTeamsInformation } from './interfaces';\r\n\r\n/**\r\n * @internal\r\n */\r\nexport namespace legacy {\r\n export namespace fullTrust {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Allows an app to retrieve information of all user joined teams\r\n *\r\n * @param teamInstanceParameters - OPTIONAL Flags that specify whether to scope call to favorite teams\r\n * @returns Promise resolved containing information about the user joined teams or rejected with error\r\n */\r\n export function getUserJoinedTeams(\r\n teamInstanceParameters?: TeamInstanceParameters,\r\n ): Promise<UserJoinedTeamsInformation> {\r\n return new Promise<UserJoinedTeamsInformation>(resolve => {\r\n ensureInitialized();\r\n\r\n if (\r\n (GlobalVars.hostClientType === HostClientType.android ||\r\n GlobalVars.hostClientType === HostClientType.teamsRoomsAndroid ||\r\n GlobalVars.hostClientType === HostClientType.teamsPhones ||\r\n GlobalVars.hostClientType === HostClientType.teamsDisplays) &&\r\n !isCurrentSDKVersionAtLeast(getUserJoinedTeamsSupportedAndroidClientVersion)\r\n ) {\r\n const oldPlatformError: SdkError = { errorCode: ErrorCode.OLD_PLATFORM };\r\n throw new Error(JSON.stringify(oldPlatformError));\r\n }\r\n\r\n resolve(sendAndUnwrap('getUserJoinedTeams', teamInstanceParameters));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Allows an app to get the configuration setting value\r\n *\r\n * @param key - The key for the config setting\r\n * @returns Promise resolved containing the value for the provided config setting or rejected with error\r\n */\r\n export function getConfigSetting(key: string): Promise<string> {\r\n return new Promise<string>(resolve => {\r\n ensureInitialized();\r\n resolve(sendAndUnwrap('getConfigSetting', key));\r\n });\r\n }\r\n\r\n /**\r\n * Checks if teams.fullTrust capability is supported currently\r\n */\r\n export function isSupported(): boolean {\r\n return runtime.supports.teams ? (runtime.supports.teams.fullTrust ? true : false) : false;\r\n }\r\n }\r\n}\r\n","import { sendAndHandleSdkError } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { runtime } from '../public/runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace meetingRoom {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Data structure to represent a meeting room.\r\n */\r\n export interface MeetingRoomInfo {\r\n /**\r\n * @hidden\r\n * Endpoint id of the meeting room.\r\n */\r\n endpointId: string;\r\n /**\r\n * @hidden\r\n * Device name of the meeting room.\r\n */\r\n deviceName: string;\r\n /**\r\n * @hidden\r\n * Client type of the meeting room.\r\n */\r\n clientType: string;\r\n /**\r\n * @hidden\r\n * Client version of the meeting room.\r\n */\r\n clientVersion: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Type of Media control capabilities of a meeting room.\r\n */\r\n type MediaControls = 'toggleMute' | 'toggleCamera' | 'toggleCaptions' | 'volume';\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Types of Stage Layout control capabilities of a meeting room.\r\n */\r\n\r\n type StageLayoutControls =\r\n | 'showVideoGallery'\r\n | 'showContent'\r\n | 'showContent'\r\n | 'showVideoGalleryAndContent'\r\n | 'showLargeGallery'\r\n | 'showTogether';\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Types of Meeting Control capabilities of a meeting room.\r\n */\r\n\r\n type MeetingControls = 'leaveMeeting';\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Types of Stage Layout State of a meeting room.\r\n */\r\n\r\n type StageLayoutStates = 'Gallery' | 'Content + gallery' | 'Content' | 'Large gallery' | 'Together mode';\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Data structure to represent capabilities of a meeting room.\r\n */\r\n export interface MeetingRoomCapability {\r\n /**\r\n * @hidden\r\n * Media control capabilities, value can be \"toggleMute\", \"toggleCamera\", \"toggleCaptions\", \"volume\".\r\n */\r\n mediaControls: MediaControls[];\r\n /**\r\n * @hidden\r\n * Main stage layout control capabilities, value can be \"showVideoGallery\", \"showContent\", \"showVideoGalleryAndContent\", \"showLargeGallery\", \"showTogether\".\r\n */\r\n stageLayoutControls: StageLayoutControls[];\r\n /**\r\n * @hidden\r\n * Meeting control capabilities, value can be \"leaveMeeting\".\r\n */\r\n meetingControls: MeetingControls[];\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Data structure to represent states of a meeting room.\r\n */\r\n export interface MeetingRoomState {\r\n /**\r\n * @hidden\r\n * Current mute state, true: mute, false: unmute.\r\n */\r\n toggleMute: boolean;\r\n /**\r\n * @hidden\r\n * Current camera state, true: camera on, false: camera off.\r\n */\r\n toggleCamera: boolean;\r\n /**\r\n * @hidden\r\n * Current captions state, true: captions on, false: captions off.\r\n */\r\n toggleCaptions: boolean;\r\n /**\r\n * @hidden\r\n * Current main stage layout state, value can be one of \"Gallery\", \"Content + gallery\", \"Content\", \"Large gallery\" and \"Together mode\".\r\n */\r\n stageLayout: StageLayoutStates;\r\n /**\r\n * @hidden\r\n * Current leaveMeeting state, true: leave, false: no-op.\r\n */\r\n leaveMeeting: boolean;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Fetch the meeting room info that paired with current client.\r\n *\r\n * @returns Promise resolved with meeting room info or rejected with SdkError value\r\n */\r\n export function getPairedMeetingRoomInfo(): Promise<MeetingRoomInfo> {\r\n return new Promise<MeetingRoomInfo>(resolve => {\r\n ensureInitialized();\r\n resolve(sendAndHandleSdkError('meetingRoom.getPairedMeetingRoomInfo'));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Send a command to paired meeting room.\r\n *\r\n * @param commandName The command name.\r\n * @returns Promise resolved upon completion or rejected with SdkError value\r\n */\r\n export function sendCommandToPairedMeetingRoom(commandName: string): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n if (!commandName || commandName.length == 0) {\r\n throw new Error('[meetingRoom.sendCommandToPairedMeetingRoom] Command name cannot be null or empty');\r\n }\r\n ensureInitialized();\r\n resolve(sendAndHandleSdkError('meetingRoom.sendCommandToPairedMeetingRoom', commandName));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Registers a handler for meeting room capabilities update.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler The handler to invoke when the capabilities of meeting room update.\r\n */\r\n export function registerMeetingRoomCapabilitiesUpdateHandler(\r\n handler: (capabilities: MeetingRoomCapability) => void,\r\n ): void {\r\n if (!handler) {\r\n throw new Error('[meetingRoom.registerMeetingRoomCapabilitiesUpdateHandler] Handler cannot be null');\r\n }\r\n ensureInitialized();\r\n registerHandler('meetingRoom.meetingRoomCapabilitiesUpdate', (capabilities: MeetingRoomCapability) => {\r\n ensureInitialized();\r\n handler(capabilities);\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * Registers a handler for meeting room states update.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler The handler to invoke when the states of meeting room update.\r\n */\r\n export function registerMeetingRoomStatesUpdateHandler(handler: (states: MeetingRoomState) => void): void {\r\n if (!handler) {\r\n throw new Error('[meetingRoom.registerMeetingRoomStatesUpdateHandler] Handler cannot be null');\r\n }\r\n ensureInitialized();\r\n registerHandler('meetingRoom.meetingRoomStatesUpdate', (states: MeetingRoomState) => {\r\n ensureInitialized();\r\n handler(states);\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.meetingRoom ? true : false;\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from '../public/constants';\r\nimport { runtime } from '../public/runtime';\r\nimport { ShowNotificationParameters } from './interfaces';\r\n\r\nexport namespace notifications {\r\n /**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * display notification API.\r\n *\r\n * @param message - Notification message.\r\n * @param notificationType - Notification type\r\n *\r\n * @internal\r\n */\r\n export function showNotification(showNotificationParameters: ShowNotificationParameters): void {\r\n ensureInitialized(FrameContexts.content);\r\n sendMessageToParent('notifications.showNotification', [showNotificationParameters]);\r\n }\r\n export function isSupported(): boolean {\r\n return runtime.supports.notifications ? true : false;\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from '../public/constants';\r\nimport { SdkError } from '../public/interfaces';\r\nimport { runtime } from '../public/runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace remoteCamera {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Data structure to represent patricipant details needed to request control of camera.\r\n */\r\n export interface Participant {\r\n /**\r\n * @hidden\r\n * Id of participant.\r\n */\r\n id: string;\r\n /**\r\n * @hidden\r\n * Display name of participant.\r\n */\r\n displayName?: string;\r\n /**\r\n * @hidden\r\n * Active indicates whether the participant's device is actively being controlled.\r\n */\r\n active?: boolean;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Enum used to indicate possible camera control commands.\r\n */\r\n export enum ControlCommand {\r\n Reset = 'Reset',\r\n ZoomIn = 'ZoomIn',\r\n ZoomOut = 'ZoomOut',\r\n PanLeft = 'PanLeft',\r\n PanRight = 'PanRight',\r\n TiltUp = 'TiltUp',\r\n TiltDown = 'TiltDown',\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Data structure to indicate the current state of the device.\r\n */\r\n export interface DeviceState {\r\n /**\r\n * @hidden\r\n * All operation are available to apply.\r\n */\r\n available: boolean;\r\n /**\r\n * @hidden\r\n * Either camera doesnt support to get state or It unable to apply command.\r\n */\r\n error: boolean;\r\n /**\r\n * @hidden\r\n * Reset max out or already applied. Client Disable Reset.\r\n */\r\n reset: boolean;\r\n /**\r\n * @hidden\r\n * ZoomIn maxed out.\r\n */\r\n zoomIn: boolean;\r\n /**\r\n * @hidden\r\n * ZoomOut maxed out.\r\n */\r\n zoomOut: boolean;\r\n /**\r\n * @hidden\r\n * PanLeft reached max left.\r\n */\r\n panLeft: boolean;\r\n /**\r\n * @hidden\r\n * PanRight reached max right.\r\n */\r\n panRight: boolean;\r\n /**\r\n * @hidden\r\n * TiltUp reached top.\r\n */\r\n tiltUp: boolean;\r\n /**\r\n * @hidden\r\n * TiltDown reached bottom.\r\n */\r\n tiltDown: boolean;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Enum used to indicate the reason for the error.\r\n */\r\n export enum ErrorReason {\r\n CommandResetError,\r\n CommandZoomInError,\r\n CommandZoomOutError,\r\n CommandPanLeftError,\r\n CommandPanRightError,\r\n CommandTiltUpError,\r\n CommandTiltDownError,\r\n SendDataError,\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Data structure to indicate the status of the current session.\r\n */\r\n export interface SessionStatus {\r\n /**\r\n * @hidden\r\n * Whether the far-end user is controlling a device.\r\n */\r\n inControl: boolean;\r\n /**\r\n * @hidden\r\n * Reason the control session was terminated.\r\n */\r\n terminatedReason?: SessionTerminatedReason;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Enum used to indicate the reason the session was terminated.\r\n */\r\n export enum SessionTerminatedReason {\r\n None,\r\n ControlDenied,\r\n ControlNoResponse,\r\n ControlBusy,\r\n AckTimeout,\r\n ControlTerminated,\r\n ControllerTerminated,\r\n DataChannelError,\r\n ControllerCancelled,\r\n ControlDisabled,\r\n ControlTerminatedToAllowOtherController,\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Fetch a list of the participants with controllable-cameras in a meeting.\r\n *\r\n * @param callback - Callback contains 2 parameters, error and participants.\r\n * error can either contain an error of type SdkError, incase of an error, or null when fetch is successful\r\n * participants can either contain an array of Participant objects, incase of a successful fetch or null when it fails\r\n * participants: object that contains an array of participants with controllable-cameras\r\n */\r\n export function getCapableParticipants(\r\n callback: (error: SdkError | null, participants: Participant[] | null) => void,\r\n ): void {\r\n if (!callback) {\r\n throw new Error('[remoteCamera.getCapableParticipants] Callback cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n sendMessageToParent('remoteCamera.getCapableParticipants', callback);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Request control of a participant's camera.\r\n *\r\n * @param participant - Participant specifies the participant to send the request for camera control.\r\n * @param callback - Callback contains 2 parameters, error and requestResponse.\r\n * error can either contain an error of type SdkError, incase of an error, or null when fetch is successful\r\n * requestResponse can either contain the true/false value, incase of a successful request or null when it fails\r\n * requestResponse: True means request was accepted and false means request was denied\r\n */\r\n export function requestControl(\r\n participant: Participant,\r\n callback: (error: SdkError | null, requestResponse: boolean | null) => void,\r\n ): void {\r\n if (!participant) {\r\n throw new Error('[remoteCamera.requestControl] Participant cannot be null');\r\n }\r\n if (!callback) {\r\n throw new Error('[remoteCamera.requestControl] Callback cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n sendMessageToParent('remoteCamera.requestControl', [participant], callback);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Send control command to the participant's camera.\r\n *\r\n * @param ControlCommand - ControlCommand specifies the command for controling the camera.\r\n * @param callback - Callback to invoke when the command response returns.\r\n */\r\n export function sendControlCommand(ControlCommand: ControlCommand, callback: (error: SdkError | null) => void): void {\r\n if (!ControlCommand) {\r\n throw new Error('[remoteCamera.sendControlCommand] ControlCommand cannot be null');\r\n }\r\n if (!callback) {\r\n throw new Error('[remoteCamera.sendControlCommand] Callback cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n sendMessageToParent('remoteCamera.sendControlCommand', [ControlCommand], callback);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Terminate the remote session\r\n *\r\n * @param callback - Callback to invoke when the command response returns.\r\n */\r\n export function terminateSession(callback: (error: SdkError | null) => void): void {\r\n if (!callback) {\r\n throw new Error('[remoteCamera.terminateSession] Callback cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n sendMessageToParent('remoteCamera.terminateSession', callback);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers a handler for change in participants with controllable-cameras.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the list of participants with controllable-cameras changes.\r\n */\r\n export function registerOnCapableParticipantsChangeHandler(\r\n handler: (participantChange: Participant[]) => void,\r\n ): void {\r\n if (!handler) {\r\n throw new Error('[remoteCamera.registerOnCapableParticipantsChangeHandler] Handler cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n registerHandler('remoteCamera.capableParticipantsChange', handler);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers a handler for error.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when there is an error from the camera handler.\r\n */\r\n export function registerOnErrorHandler(handler: (error: ErrorReason) => void): void {\r\n if (!handler) {\r\n throw new Error('[remoteCamera.registerOnErrorHandler] Handler cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n registerHandler('remoteCamera.handlerError', handler);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers a handler for device state change.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the controlled device changes state.\r\n */\r\n export function registerOnDeviceStateChangeHandler(handler: (deviceStateChange: DeviceState) => void): void {\r\n if (!handler) {\r\n throw new Error('[remoteCamera.registerOnDeviceStateChangeHandler] Handler cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n registerHandler('remoteCamera.deviceStateChange', handler);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers a handler for session status change.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the current session status changes.\r\n */\r\n export function registerOnSessionStatusChangeHandler(handler: (sessionStatusChange: SessionStatus) => void): void {\r\n if (!handler) {\r\n throw new Error('[remoteCamera.registerOnSessionStatusChangeHandler] Handler cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n registerHandler('remoteCamera.sessionStatusChange', handler);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.remoteCamera ? true : false;\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts, SdkError } from '../public';\r\nimport { runtime } from '../public/runtime';\r\n/**\r\n * @hidden\r\n * Namespace to interact with the application entities specific part of the SDK.\r\n *\r\n * @alpha\r\n */\r\nexport namespace appEntity {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Information on an app entity\r\n *\r\n * @alpha\r\n */\r\n export interface AppEntity {\r\n /**\r\n * @hidden\r\n * App ID of the application\r\n */\r\n appId: string;\r\n\r\n /**\r\n * @hidden\r\n * URL for the application's icon\r\n */\r\n appIconUrl: string;\r\n\r\n /**\r\n * @hidden\r\n * Content URL for the app entity\r\n */\r\n contentUrl: string;\r\n\r\n /**\r\n * @hidden\r\n * The display name for the app entity\r\n */\r\n displayName: string;\r\n\r\n /**\r\n * @hidden\r\n * Website URL for the app entity. It is meant to be opened by the user in a browser.\r\n */\r\n websiteUrl: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Open the Tab Gallery and retrieve the app entity\r\n * @param threadId ID of the thread where the app entity will be created\r\n * @param categories A list of app categories that will be displayed in the opened tab gallery\r\n * @param subEntityId An object that will be made available to the application being configured\r\n * through the Teams Context's subEntityId field.\r\n * @param callback Callback that will be triggered once the app entity information is available.\r\n * The callback takes two arguments: an SdkError in case something happened (i.e.\r\n * no permissions to execute the API) and the app entity configuration, if available\r\n *\r\n * @alpha\r\n */\r\n export function selectAppEntity(\r\n threadId: string,\r\n categories: string[],\r\n subEntityId: string,\r\n callback: (sdkError?: SdkError, appEntity?: AppEntity) => void,\r\n ): void {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!threadId || threadId.length == 0) {\r\n throw new Error('[appEntity.selectAppEntity] threadId name cannot be null or empty');\r\n }\r\n\r\n if (!callback) {\r\n throw new Error('[appEntity.selectAppEntity] Callback cannot be null');\r\n }\r\n\r\n sendMessageToParent('appEntity.selectAppEntity', [threadId, categories, subEntityId], callback);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.appEntity ? true : false;\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from '../public/constants';\r\nimport { SdkError } from '../public/interfaces';\r\nimport { runtime } from '../public/runtime';\r\n\r\n/**\r\n * @hidden\r\n * Namespace to interact with the `teams` specific part of the SDK.\r\n * ------\r\n * Hide from docs\r\n *\r\n * @internal\r\n */\r\nexport namespace teams {\r\n export enum ChannelType {\r\n Regular = 0,\r\n Private = 1,\r\n Shared = 2,\r\n }\r\n\r\n export interface ChannelInfo {\r\n siteUrl: string;\r\n objectId: string;\r\n folderRelativeUrl: string;\r\n displayName: string;\r\n channelType: ChannelType;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Get a list of channels belong to a Team\r\n *\r\n * @param groupId - a team's objectId\r\n */\r\n export function getTeamChannels(groupId: string, callback: (error: SdkError, channels: ChannelInfo[]) => void): void {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!groupId) {\r\n throw new Error('[teams.getTeamChannels] groupId cannot be null or empty');\r\n }\r\n\r\n if (!callback) {\r\n throw new Error('[teams.getTeamChannels] Callback cannot be null');\r\n }\r\n\r\n sendMessageToParent('teams.getTeamChannels', [groupId], callback);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Allow 1st party apps to call this function when they receive migrated errors to inform the Hub/Host to refresh the siteurl\r\n * when site admin renames siteurl.\r\n *\r\n * @param threadId - ID of the thread where the app entity will be created; if threadId is not\r\n * provided, the threadId from route params will be used.\r\n */\r\n export function refreshSiteUrl(threadId: string, callback: (error: SdkError) => void): void {\r\n ensureInitialized();\r\n\r\n if (!threadId) {\r\n throw new Error('[teams.refreshSiteUrl] threadId cannot be null or empty');\r\n }\r\n\r\n if (!callback) {\r\n throw new Error('[teams.refreshSiteUrl] Callback cannot be null');\r\n }\r\n\r\n sendMessageToParent('teams.refreshSiteUrl', [threadId], callback);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.teams ? true : false;\r\n }\r\n}\r\n","import { ensureInitialized } from '../internal/internalAPIs';\r\nimport { getGenericOnCompleteHandler } from '../internal/utils';\r\nimport { app } from './app';\r\nimport { FrameContexts } from './constants';\r\nimport {\r\n Context,\r\n DeepLinkParameters,\r\n FrameContext,\r\n LoadContext,\r\n TabInformation,\r\n TabInstanceParameters,\r\n} from './interfaces';\r\nimport { pages } from './pages';\r\nimport { teamsCore } from './teamsAPIs';\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.initialize app.initialize(validMessageOrigins?: string[]): Promise\\<void\\>} instead.\r\n *\r\n * Initializes the library. This must be called before any other SDK calls\r\n * but after the frame is loaded successfully.\r\n * @param callback - Optionally specify a callback to invoke when Teams SDK has successfully initialized\r\n * @param validMessageOrigins - Optionally specify a list of cross frame message origins. There must have\r\n * https: protocol otherwise they will be ignored. Example: https://www.example.com\r\n */\r\nexport function initialize(callback?: () => void, validMessageOrigins?: string[]): void {\r\n app.initialize(validMessageOrigins).then(() => {\r\n if (callback) {\r\n callback();\r\n }\r\n });\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app._initialize app._initialize(hostWindow: any): void} instead.\r\n *\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Undocumented function used to set a mock window for unit tests\r\n *\r\n * @internal\r\n */\r\n// eslint-disable-next-line\r\nexport function _initialize(hostWindow: any): void {\r\n app._initialize(hostWindow);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app._uninitialize app._uninitialize(): void} instead.\r\n *\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Undocumented function used to clear state between unit tests\r\n *\r\n * @internal\r\n */\r\nexport function _uninitialize(): void {\r\n app._uninitialize();\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link teamsCore.enablePrintCapability teamsCore.enablePrintCapability(): void} instead.\r\n *\r\n * Enable print capability to support printing page using Ctrl+P and cmd+P\r\n */\r\nexport function enablePrintCapability(): void {\r\n teamsCore.enablePrintCapability();\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link teamsCore.print teamsCore.print(): void} instead.\r\n *\r\n * Default print handler\r\n */\r\nexport function print(): void {\r\n teamsCore.print();\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.getContext app.getContext(): Promise\\<app.Context\\>} instead.\r\n *\r\n * Retrieves the current context the frame is running in.\r\n *\r\n * @param callback - The callback to invoke when the {@link Context} object is retrieved.\r\n */\r\nexport function getContext(callback: (context: Context) => void): void {\r\n ensureInitialized();\r\n app.getContext().then((context: app.Context) => {\r\n if (callback) {\r\n callback(transformAppContextToLegacyContext(context));\r\n }\r\n });\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.registerOnThemeChangeHandler app.registerOnThemeChangeHandler(handler: (theme: string) => void): void} instead.\r\n *\r\n * Registers a handler for theme changes.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the user changes their theme.\r\n */\r\nexport function registerOnThemeChangeHandler(handler: (theme: string) => void): void {\r\n app.registerOnThemeChangeHandler(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.registerFullScreenHandler pages.registerFullScreenHandler(handler: (isFullScreen: boolean) => void): void} instead.\r\n *\r\n * Registers a handler for changes from or to full-screen view for a tab.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the user toggles full-screen view for a tab.\r\n */\r\nexport function registerFullScreenHandler(handler: (isFullScreen: boolean) => void): void {\r\n pages.registerFullScreenHandler(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.appButton.onClick pages.appButton.onClick(handler: () => void): void} instead.\r\n *\r\n * Registers a handler for clicking the app button.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the personal app button is clicked in the app bar.\r\n */\r\nexport function registerAppButtonClickHandler(handler: () => void): void {\r\n pages.appButton.onClick(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.appButton.onHoverEnter pages.appButton.onHoverEnter(handler: () => void): void} instead.\r\n *\r\n * Registers a handler for entering hover of the app button.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when entering hover of the personal app button in the app bar.\r\n */\r\nexport function registerAppButtonHoverEnterHandler(handler: () => void): void {\r\n pages.appButton.onHoverEnter(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.appButton.onHoverLeave pages.appButton.onHoverLeave(handler: () => void): void} instead.\r\n *\r\n * Registers a handler for exiting hover of the app button.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n * @param handler - The handler to invoke when exiting hover of the personal app button in the app bar.\r\n *\r\n */\r\nexport function registerAppButtonHoverLeaveHandler(handler: () => void): void {\r\n pages.appButton.onHoverLeave(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.backStack.registerBackButtonHandler pages.backStack.registerBackButtonHandler(handler: () => boolean): void} instead.\r\n *\r\n * Registers a handler for user presses of the Team client's back button. Experiences that maintain an internal\r\n * navigation stack should use this handler to navigate the user back within their frame. If an app finds\r\n * that after running its back button handler it cannot handle the event it should call the navigateBack\r\n * method to ask the Teams client to handle it instead.\r\n *\r\n * @param handler - The handler to invoke when the user presses their Team client's back button.\r\n */\r\nexport function registerBackButtonHandler(handler: () => boolean): void {\r\n pages.backStack.registerBackButtonHandler(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link teamsCore.registerOnLoadHandler teamsCore.registerOnLoadHandler(handler: (context: LoadContext) => void): void} instead.\r\n *\r\n * @hidden\r\n * Registers a handler to be called when the page has been requested to load.\r\n *\r\n * @param handler - The handler to invoke when the page is loaded.\r\n */\r\nexport function registerOnLoadHandler(handler: (context: LoadContext) => void): void {\r\n teamsCore.registerOnLoadHandler(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link teamsCore.registerBeforeUnloadHandler teamsCore.registerBeforeUnloadHandler(handler: (readyToUnload: () => void) => boolean): void} instead.\r\n *\r\n * @hidden\r\n * Registers a handler to be called before the page is unloaded.\r\n *\r\n * @param handler - The handler to invoke before the page is unloaded. If this handler returns true the page should\r\n * invoke the readyToUnload function provided to it once it's ready to be unloaded.\r\n */\r\nexport function registerBeforeUnloadHandler(handler: (readyToUnload: () => void) => boolean): void {\r\n teamsCore.registerBeforeUnloadHandler(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link pages.registerFocusEnterHandler pages.registerFocusEnterHandler(handler: (navigateForward: boolean) => void): void} instead.\r\n *\r\n * @hidden\r\n * Registers a handler when focus needs to be passed from teams to the place of choice on app.\r\n *\r\n * @param handler - The handler to invoked by the app when they want the focus to be in the place of their choice.\r\n */\r\nexport function registerFocusEnterHandler(handler: (navigateForward: boolean) => boolean): void {\r\n pages.registerFocusEnterHandler(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.registerChangeConfigHandler pages.config.registerChangeConfigHandler(handler: () => void): void} instead.\r\n *\r\n * Registers a handler for when the user reconfigurated tab.\r\n *\r\n * @param handler - The handler to invoke when the user click on Settings.\r\n */\r\nexport function registerEnterSettingsHandler(handler: () => void): void {\r\n pages.config.registerChangeConfigHandler(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.tabs.getTabInstances pages.tabs.getTabInstances(tabInstanceParameters?: TabInstanceParameters): Promise\\<TabInformation\\>} instead.\r\n *\r\n * Allows an app to retrieve for this user tabs that are owned by this app.\r\n * If no TabInstanceParameters are passed, the app defaults to favorite teams and favorite channels.\r\n *\r\n * @param callback - The callback to invoke when the {@link TabInstanceParameters} object is retrieved.\r\n * @param tabInstanceParameters - OPTIONAL Flags that specify whether to scope call to favorite teams or channels.\r\n */\r\nexport function getTabInstances(\r\n callback: (tabInfo: TabInformation) => void,\r\n tabInstanceParameters?: TabInstanceParameters,\r\n): void {\r\n ensureInitialized();\r\n pages.tabs.getTabInstances(tabInstanceParameters).then((tabInfo: TabInformation) => {\r\n callback(tabInfo);\r\n });\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.tabs.getMruTabInstances pages.tabs.getMruTabInstances(tabInstanceParameters?: TabInstanceParameters): Promise\\<TabInformation\\>} instead.\r\n *\r\n * Allows an app to retrieve the most recently used tabs for this user.\r\n *\r\n * @param callback - The callback to invoke when the {@link TabInformation} object is retrieved.\r\n * @param tabInstanceParameters - OPTIONAL Ignored, kept for future use\r\n */\r\nexport function getMruTabInstances(\r\n callback: (tabInfo: TabInformation) => void,\r\n tabInstanceParameters?: TabInstanceParameters,\r\n): void {\r\n ensureInitialized();\r\n pages.tabs.getMruTabInstances(tabInstanceParameters).then((tabInfo: TabInformation) => {\r\n callback(tabInfo);\r\n });\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link pages.shareDeepLink pages.shareDeepLink(deepLinkParameters: DeepLinkParameters): void} instead.\r\n *\r\n * Shares a deep link that a user can use to navigate back to a specific state in this page.\r\n *\r\n * @param deepLinkParameters - ID and label for the link and fallback URL.\r\n */\r\nexport function shareDeepLink(deepLinkParameters: DeepLinkParameters): void {\r\n pages.shareDeepLink(deepLinkParameters);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link app.openLink core.openLink(deepLink: string): Promise\\<void\\>} instead.\r\n *\r\n * Execute deep link API.\r\n *\r\n * @param deepLink - deep link.\r\n */\r\nexport function executeDeepLink(deepLink: string, onComplete?: (status: boolean, reason?: string) => void): void {\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.settings,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n onComplete = onComplete ? onComplete : getGenericOnCompleteHandler();\r\n app\r\n .openLink(deepLink)\r\n .then(() => {\r\n onComplete(true);\r\n })\r\n .catch((err: Error) => {\r\n onComplete(false, err.message);\r\n });\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.setCurrentFrame pages.setCurrentFrame(frameInfo: FrameInfo): void} instead.\r\n *\r\n * Set the current Frame Context\r\n *\r\n * @param frameContext - FrameContext information to be set\r\n */\r\nexport function setFrameContext(frameContext: FrameContext): void {\r\n pages.setCurrentFrame(frameContext);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.initializeWithFrameContext pages.initializeWithFrameContext(frameInfo: FrameInfo, callback?: () => void, validMessageOrigins?: string[],): void} instead.\r\n *\r\n * Initilize with FrameContext\r\n *\r\n * @param frameContext - FrameContext information to be set\r\n * @param callback - The optional callback to be invoked be invoked after initilizing the frame context\r\n * @param validMessageOrigins - Optionally specify a list of cross frame message origins.\r\n * They must have https: protocol otherwise they will be ignored. Example: https:www.example.com\r\n */\r\nexport function initializeWithFrameContext(\r\n frameContext: FrameContext,\r\n callback?: () => void,\r\n validMessageOrigins?: string[],\r\n): void {\r\n pages.initializeWithFrameContext(frameContext, callback, validMessageOrigins);\r\n}\r\n\r\n/**\r\n * Transforms the app.Context object received to TeamsJS Context\r\n */\r\nfunction transformAppContextToLegacyContext(appContext: app.Context): Context {\r\n const context: Context = {\r\n // app\r\n locale: appContext.app.locale,\r\n appSessionId: appContext.app.sessionId,\r\n theme: appContext.app.theme,\r\n appIconPosition: appContext.app.iconPositionVertical,\r\n osLocaleInfo: appContext.app.osLocaleInfo,\r\n parentMessageId: appContext.app.parentMessageId,\r\n userClickTime: appContext.app.userClickTime,\r\n userFileOpenPreference: appContext.app.userFileOpenPreference,\r\n appLaunchId: appContext.app.appLaunchId,\r\n\r\n // app.host\r\n hostClientType: appContext.app.host.clientType,\r\n sessionId: appContext.app.host.sessionId,\r\n ringId: appContext.app.host.ringId,\r\n\r\n // page\r\n entityId: appContext.page.id,\r\n frameContext: appContext.page.frameContext,\r\n subEntityId: appContext.page.subPageId,\r\n isFullScreen: appContext.page.isFullScreen,\r\n isMultiWindow: appContext.page.isMultiWindow,\r\n sourceOrigin: appContext.page.sourceOrigin,\r\n\r\n // user\r\n userObjectId: appContext.user !== undefined ? appContext.user.id : undefined,\r\n isCallingAllowed: appContext.user !== undefined ? appContext.user.isCallingAllowed : undefined,\r\n isPSTNCallingAllowed: appContext.user !== undefined ? appContext.user.isPSTNCallingAllowed : undefined,\r\n userLicenseType: appContext.user !== undefined ? appContext.user.licenseType : undefined,\r\n loginHint: appContext.user !== undefined ? appContext.user.loginHint : undefined,\r\n userPrincipalName: appContext.user !== undefined ? appContext.user.userPrincipalName : undefined,\r\n\r\n // user.tenant\r\n tid:\r\n appContext.user !== undefined\r\n ? appContext.user.tenant !== undefined\r\n ? appContext.user.tenant.id\r\n : undefined\r\n : undefined,\r\n tenantSKU:\r\n appContext.user !== undefined\r\n ? appContext.user.tenant !== undefined\r\n ? appContext.user.tenant.teamsSku\r\n : undefined\r\n : undefined,\r\n\r\n // channel\r\n channelId: appContext.channel !== undefined ? appContext.channel.id : undefined,\r\n channelName: appContext.channel !== undefined ? appContext.channel.displayName : undefined,\r\n channelRelativeUrl: appContext.channel !== undefined ? appContext.channel.relativeUrl : undefined,\r\n channelType: appContext.channel !== undefined ? appContext.channel.membershipType : undefined,\r\n defaultOneNoteSectionId: appContext.channel !== undefined ? appContext.channel.defaultOneNoteSectionId : undefined,\r\n hostTeamGroupId: appContext.channel !== undefined ? appContext.channel.ownerGroupId : undefined,\r\n hostTeamTenantId: appContext.channel !== undefined ? appContext.channel.ownerTenantId : undefined,\r\n\r\n // chat\r\n chatId: appContext.chat !== undefined ? appContext.chat.id : undefined,\r\n\r\n // meeting\r\n meetingId: appContext.meeting !== undefined ? appContext.meeting.id : undefined,\r\n\r\n // sharepoint\r\n sharepoint: appContext.sharepoint,\r\n\r\n // team\r\n teamId: appContext.team !== undefined ? appContext.team.internalId : undefined,\r\n teamName: appContext.team !== undefined ? appContext.team.displayName : undefined,\r\n teamType: appContext.team !== undefined ? appContext.team.type : undefined,\r\n groupId: appContext.team !== undefined ? appContext.team.groupId : undefined,\r\n teamTemplateId: appContext.team !== undefined ? appContext.team.templateId : undefined,\r\n isTeamArchived: appContext.team !== undefined ? appContext.team.isArchived : undefined,\r\n userTeamRole: appContext.team !== undefined ? appContext.team.userRole : undefined,\r\n\r\n // sharepointSite\r\n teamSiteUrl: appContext.sharePointSite !== undefined ? appContext.sharePointSite.teamSiteUrl : undefined,\r\n teamSiteDomain: appContext.sharePointSite !== undefined ? appContext.sharePointSite.teamSiteDomain : undefined,\r\n teamSitePath: appContext.sharePointSite !== undefined ? appContext.sharePointSite.teamSitePath : undefined,\r\n teamSiteId: appContext.sharePointSite !== undefined ? appContext.sharePointSite.teamSiteId : undefined,\r\n mySitePath: appContext.sharePointSite !== undefined ? appContext.sharePointSite.mySitePath : undefined,\r\n mySiteDomain: appContext.sharePointSite !== undefined ? appContext.sharePointSite.mySiteDomain : undefined,\r\n };\r\n\r\n return context;\r\n}\r\n","import { ensureInitialized } from '../internal/internalAPIs';\r\nimport { getGenericOnCompleteHandler } from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\nimport { TabInstance } from './interfaces';\r\nimport { pages } from './pages';\r\n/**\r\n * Navigation specific part of the SDK.\r\n */\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.returnFocus pages.returnFocus(navigateForward?: boolean): void} instead.\r\n *\r\n * Return focus to the main Teams app. Will focus search bar if navigating foward and app bar if navigating back.\r\n *\r\n * @param navigateForward - Determines the direction to focus in teams app.\r\n */\r\nexport function returnFocus(navigateForward?: boolean): void {\r\n pages.returnFocus(navigateForward);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.tabs.navigateToTab pages.tabs.navigateToTab(tabInstance: TabInstance): Promise\\<void\\>} instead.\r\n *\r\n * Navigates the Microsoft Teams app to the specified tab instance.\r\n *\r\n * @param tabInstance - The tab instance to navigate to.\r\n * @param onComplete - The callback to invoke when the action is complete.\r\n */\r\nexport function navigateToTab(tabInstance: TabInstance, onComplete?: (status: boolean, reason?: string) => void): void {\r\n ensureInitialized();\r\n onComplete = onComplete ? onComplete : getGenericOnCompleteHandler();\r\n pages.tabs\r\n .navigateToTab(tabInstance)\r\n .then(() => {\r\n onComplete(true);\r\n })\r\n .catch((error: Error) => {\r\n onComplete(false, error.message);\r\n });\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.navigateCrossDomain pages.navigateCrossDomain(url: string): Promise\\<void\\>} instead.\r\n *\r\n * Navigates the frame to a new cross-domain URL. The domain of this URL must match at least one of the\r\n * valid domains specified in the validDomains block of the manifest; otherwise, an exception will be\r\n * thrown. This function needs to be used only when navigating the frame to a URL in a different domain\r\n * than the current one in a way that keeps the app informed of the change and allows the SDK to\r\n * continue working.\r\n *\r\n * @param url - The URL to navigate the frame to.\r\n * @param onComplete - The callback to invoke when the action is complete.\r\n */\r\nexport function navigateCrossDomain(url: string, onComplete?: (status: boolean, reason?: string) => void): void {\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.settings,\r\n FrameContexts.remove,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n onComplete = onComplete ? onComplete : getGenericOnCompleteHandler();\r\n pages\r\n .navigateCrossDomain(url)\r\n .then(() => {\r\n onComplete(true);\r\n })\r\n .catch((error: Error) => {\r\n onComplete(false, error.message);\r\n });\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.backStack.navigateBack pages.backStack.navigateBack(): Promise\\<void\\>} instead.\r\n *\r\n * Navigates back in the Teams client.\r\n * See registerBackButtonHandler for more information on when it's appropriate to use this method.\r\n *\r\n * @param onComplete - The callback to invoke when the action is complete.\r\n */\r\nexport function navigateBack(onComplete?: (status: boolean, reason?: string) => void): void {\r\n ensureInitialized();\r\n onComplete = onComplete ? onComplete : getGenericOnCompleteHandler();\r\n pages.backStack\r\n .navigateBack()\r\n .then(() => {\r\n onComplete(true);\r\n })\r\n .catch((error: Error) => {\r\n onComplete(false, error.message);\r\n });\r\n}\r\n"],"names":["root","factory","exports","module","define","amd","self","v1","v4","uuid","byteToHex","i","toString","substr","buf","offset","bth","join","getRandomValues","crypto","bind","window","msCrypto","rnds8","Uint8Array","rnds","Array","r","Math","random","_nodeId","_clockseq","rng","bytesToUuid","_lastMSecs","_lastNSecs","options","b","node","clockseq","undefined","seedBytes","msecs","Date","getTime","nsecs","dt","Error","tl","tmh","n","ii","formatArgs","args","this","useColors","namespace","humanize","diff","c","color","splice","index","lastC","replace","match","save","namespaces","storage","setItem","removeItem","error","load","getItem","process","env","DEBUG","type","__nwjs","navigator","userAgent","toLowerCase","document","documentElement","style","WebkitAppearance","console","firebug","exception","table","parseInt","RegExp","$1","localStorage","localstorage","destroy","warned","warn","colors","log","debug","formatters","j","v","JSON","stringify","message","createDebug","prevTime","namespacesCache","enabledCache","enableOverride","enabled","curr","Number","ms","prev","coerce","unshift","format","formatter","val","call","apply","selectColor","extend","Object","defineProperty","enumerable","configurable","get","set","init","delimiter","newDebug","toNamespace","regexp","substring","length","default","stack","disable","names","map","skips","enable","split","len","push","name","test","keys","forEach","key","hash","charCodeAt","abs","s","m","h","d","parse","str","String","exec","parseFloat","fmtShort","msAbs","round","fmtLong","plural","isPlural","isFinite","long","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","definition","o","obj","prop","prototype","hasOwnProperty","Symbol","toStringTag","value","HostClientType","HostName","FrameContexts","TeamType","UserTeamRole","DialogDimension","version","defaultSDKVersionForCompatCheck","nonFullScreenVideoModeAPISupportVersion","locationAPIsRequiredVersion","mediaAPISupportVersion","validOrigins","userOriginUrlValidationRegExp","initializeCalled","initializeCompleted","additionalValidOrigins","isFramelessWindow","printCapabilityEnabled","ChannelType","FileOpenPreference","ErrorCode","TaskModuleDimension","validateHostAgainstPattern","pattern","host","suffix","validateOrigin","messageOrigin","protocol","messageOriginHost","some","GlobalVars","domainOrPattern","getGenericOnCompleteHandler","errorMessage","success","reason","compareSDKVersions","v2","NaN","v1parts","v2parts","isValidPart","x","every","generateGUID","deepFreeze","freeze","callCallbackWithErrorOrResultFromPromiseAndReturnPromise","funcHelper","callback","p","then","result","catch","e","callCallbackWithErrorOrBooleanFromPromiseAndReturnPromise","callCallbackWithSdkErrorFromPromiseAndReturnPromise","callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise","runWithTimeout","action","timeoutInMs","timeoutError","Promise","resolve","reject","timeoutHandle","setTimeout","clearTimeout","createTeamsAppLink","params","url","URL","encodeURIComponent","appId","pageId","webUrl","searchParams","append","channelId","subPageId","subEntityId","ensureInitialized","frameContext","expectedFrameContexts","found","isCurrentSDKVersionAtLeast","requiredVersion","clientSupportedSDKVersion","isNaN","isHostClientMobile","hostClientType","android","ios","throwExceptionIfMobileApiIsNotSupported","errorCode","NOT_SUPPORTED_ON_PLATFORM","OLD_PLATFORM","processAdditionalValidOrigins","validMessageOrigins","combinedOriginUrls","concat","filter","_origin","dedupUrls","_originUrl","logs","authentication","menus","teamsCore","pages","runtime","apiVersion","supports","appInstallDialog","bot","calendar","chat","dialog","location","mail","media","meeting","meetingRoom","monetization","notifications","appButton","tabs","config","backStack","fullTrust","people","remoteCamera","sharing","teams","video","teamsRuntimeConfig","isLegacyTeams","appEntity","files","applyRuntimeConfig","runtimeConfig","uploadCustomApp","manifestBlob","onComplete","sendMessageToParent","sendCustomMessage","actionName","sendCustomEvent","Communication","childWindow","sendMessageEventToChild","registerCustomHandler","customHandler","registerHandler","registerUserSettingsChangeHandler","settingTypes","handler","transformLegacyContextToAppContext","legacyContext","app","locale","sessionId","appSessionId","theme","iconPositionVertical","appIconPosition","osLocaleInfo","parentMessageId","userClickTime","userFileOpenPreference","hostName","clientType","web","ringId","appLaunchId","page","id","entityId","isFullScreen","isMultiWindow","sourceOrigin","user","userObjectId","displayName","userDisplayName","isCallingAllowed","isPSTNCallingAllowed","licenseType","userLicenseType","loginHint","userPrincipalName","tenant","tid","teamsSku","tenantSKU","channel","channelName","relativeUrl","channelRelativeUrl","membershipType","channelType","defaultOneNoteSectionId","ownerGroupId","hostTeamGroupId","ownerTenantId","hostTeamTenantId","chatId","meetingId","sharepoint","team","teamId","internalId","teamName","teamType","groupId","templateId","teamTemplateId","isArchived","isTeamArchived","userRole","userTeamRole","sharePointSite","teamSiteUrl","teamSiteDomain","teamSitePath","mySitePath","mySiteDomain","teamSiteId","registerGetLogHandler","removeHandler","isSupported","authHandlers","authWindowMonitor","authParams","authenticateHelper","authenticateParameters","desktop","rigel","teamsRoomsWindows","teamsRoomsAndroid","teamsPhones","teamsDisplays","link","createElement","href","sendMessageToParentAsync","width","height","isExternal","response","fail","openAuthenticationWindow","getAuthTokenHelper","authTokenRequest","resources","claims","silent","getUserHelper","closeAuthenticationWindow","stopAuthenticationWindowMonitor","close","childOrigin","min","currentWindow","outerWidth","outerHeight","left","screenLeft","screenX","top","screenTop","screenY","open","startAuthenticationWindowMonitor","handleFailure","clearInterval","setInterval","closed","savedChildOrigin","handleSuccess","redirectIfWin32Outlook","callbackUrl","decodeURIComponent","search","indexOf","updateUrlParameter","assign","uri","initialize","registerAuthenticationHandlers","authenticate","isDifferentParamsInCall","authenticateParams","content","sidePanel","settings","remove","task","stage","meetingStage","successCallback","err","failureCallback","getAuthToken","getUser","userRequest","notifySuccess","waitForMessageQueue","parentWindow","notifyFailure","DisplayMode","navBarMenuItemPressHandler","actionMenuItemPressHandler","viewConfigItemPressHandler","selected","handleViewConfigItemPress","handleNavBarMenuItemPress","handleActionMenuItemPress","MenuItem","MenuListType","setUpViews","viewConfig","setNavBarMenu","items","showActionMenu","print","enablePrintCapability","addEventListener","event","ctrlKey","metaKey","keyCode","cancelBubble","preventDefault","stopImmediatePropagation","registerOnLoadHandler","registerBeforeUnloadHandler","Messages","AppLoaded","Success","Failure","ExpectedFailure","FailedReason","ExpectedFailureReason","isInitialized","getFrameContext","initializeHelper","initializePromise","initializeCommunication","context","givenRuntimeConfig","SyntaxError","isArray","registerOnThemeChangeHandler","_initialize","hostWindow","_uninitialize","registerBackButtonHandler","registerFullScreenHandler","registerOnSaveHandler","registerOnRemoveHandler","uninitializeCommunication","getContext","sendAndUnwrap","notifyAppLoaded","appInitializationFailedRequest","notifyExpectedFailure","expectedFailureRequest","openLink","deepLink","setCurrentFrame","frameInfo","returnFocus","navigateForward","registerFocusEnterHandler","initializeWithFrameContext","getConfig","navigateCrossDomain","navigateToApp","shareDeepLink","deepLinkParameters","subEntityLabel","subEntityWebUrl","navigateToTab","tabInstance","getTabInstances","tabInstanceParameters","getMruTabInstances","saveHandler","handleSave","saveEvent","SaveEventImpl","handleRemove","setValidityState","validityState","setConfig","instanceConfig","registerChangeConfigHandler","notified","ensureNotNotified","removeEvent","RemoveEventImpl","backButtonPressHandler","navigateBack","handleBackButtonPress","enterFullscreen","exitFullscreen","onClick","onHoverEnter","onHoverLeave","topLevelLogger","getLogger","handlersLogger","handlers","initializeHandlers","HandlersPrivate","handleThemeChange","handleLoad","handleBeforeUnload","callHandlerLogger","callHandler","sendMessage","themeChangeHandler","loadHandler","beforeUnloadHandler","readyToUnload","communicationLogger","parentMessageQueue","childMessageQueue","nextMessageId","callbacks","promiseCallbacks","CommunicationPrivate","messageListener","evt","processMessage","parent","opener","extendedWindow","nativeInterface","onNativeMessage","handleParentMessage","parentOrigin","removeEventListener","sendAndHandleStatusAndReason","status","sendAndHandleStatusAndReasonWithDefaultError","defaultError","sendAndHandleSdkError","waitForResponse","sendMessageToParentHelper","requestId","argsOrCallback","Function","request","sendMessageToParentHelperLogger","logger","targetWindow","createMessageRequest","framelessPostMessage","targetOrigin","getTargetOrigin","postMessage","getTargetMessageQueue","data","messageSource","source","originalEvent","origin","shouldProcessMessage","updateRelationships","handleChildMessage","flushMessageQueue","handleParentMessageLogger","isPartialResponse","promiseCallback","func","called","sendMessageResponseToChild","pop","NotificationTypes","ViewerActionTypes","UserSettingTypes","flushMessageQueueLogger","targetMessageQueue","target","shift","messageQueueMonitor","createMessageResponse","customEvent","createMessageEvent","timestamp","now","sendQuery","botRequest","onSuccess","onError","getSupportedCommands","authRequest","openConversation","openConversationRequest","sendPromise","title","conversationId","onStartConversation","onCloseConversation","closeConversation","getChatMembers","openAppInstallDialog","openAPPInstallDialogParams","postMessageHelper","listener","_instance","createFile","assembleAttachment","mimeType","file","sequence","sort","a","item","Blob","decodeAttachment","attachment","decoded","atob","chunk","byteNumbers","byteArray","blob","chunkSequence","throwExceptionIfMediaCallIsNotSupportedOnMobile","mediaInputs","isMediaCallForVideoAndImageInputs","isMediaCallForNonFullScreenVideoMode","isMediaCallForImageOutputFormats","isVideoControllerRegistered","mediaType","MediaType","Video","videoProps","videoController","validateSelectMediaInputs","maxMediaCount","Image","imageProps","imageOutputFormats","VideoAndImage","videoAndImageProps","isFullScreenMode","validateGetMediaInputs","FileFormat","ID","validateViewImagesInput","uriList","validateScanBarCodeInput","barCodeConfig","timeOutIntervalInSec","validatePeoplePickerInput","peoplePickerInputs","setSelected","openOrgWideSearchInChatOrChannel","singleSelect","dialogInfo","submitHandler","ChildAppWindow","resize","extra","submit","appIds","stageView","appInitialization","tasks","legacy","transformAppContextToLegacyContext","registerAppButtonClickHandler","registerAppButtonHoverEnterHandler","registerAppButtonHoverLeaveHandler","registerEnterSettingsHandler","tabInfo","executeDeepLink","setFrameContext","appContext","File","captureImage","that","preview","size","getMedia","INVALID_ARGUMENTS","getMediaViaCallback","getMediaViaHandler","helper","mediaMimeType","mediaResult","mediaChunk","assemble","INTERNAL_ERROR","Media","MediaControllerEvent","getMediaType","notifyEventToApp","mediaEvent","StartRecording","controllerCallback","onRecordingStarted","StopRecording","onRecordingStopped","notifyEventToHost","mediaControllerEvent","stop","VideoController","CameraStartMode","Source","ImageUriType","ImageOutputFormats","selectMedia","localAttachments","mediaArray","viewImages","scanBarCode","callbackOrConfig","configMaybe","getLocationHelper","props","showLocationHelper","getLocation","showLocation","getIncomingClientAudioStateHelper","toggleIncomingClientAudioHelper","getMeetingDetailsHelper","getAuthenticationTokenForAnonymousUserHelper","getLiveStreamStateHelper","requestStartLiveStreamingHelper","streamUrl","streamKey","requestStopLiveStreamingHelper","shareAppContentToStageHelper","appContentUrl","getAppContentStageSharingCapabilitiesHelper","stopSharingAppContentToStageHelper","getAppContentStageSharingStateHelper","MeetingType","getIncomingClientAudioState","toggleIncomingClientAudio","getMeetingDetails","getAuthenticationTokenForAnonymousUser","getLiveStreamState","requestStartLiveStreaming","param1","param2","param3","requestStopLiveStreaming","registerLiveStreamChangedHandler","shareAppContentToStage","getAppContentStageSharingCapabilities","stopSharingAppContentToStage","getAppContentStageSharingState","openPurchaseExperience","planInfo","openCalendarItem","openCalendarItemParams","itemId","trim","composeMeeting","composeMeetingParams","openMailItem","openMailItemParams","composeMail","composeMailParams","ComposeMailType","selectPeopleHelper","selectPeople","notifyVideoFrameProcessed","notifyError","VideoFrameFormat","EffectChangeType","registerForVideoFrame","frameCallback","videoFrame","notifySelectedVideoEffectChanged","effectChangeType","effectId","registerForVideoEffect","shareWebContentHelper","shareWebContentRequest","SharingAPIMessages","shareWebContent","validateNonEmptyContent","shareRequest","validateTypeConsistency","validateContentForSupportedTypes","stageViewParams","CallModalities","startCall","startCallParams","getSettings","setSettings","instanceSettings","getDialogInfoFromTaskInfo","taskInfo","dialogHeight","getDialogDimensionFromTaskModuleDimension","dialogWidth","card","fallbackUrl","completionBotId","taskModuleDimension","Large","Medium","Small","startTask","updateTask","submitTask","CloudStorageProvider","CloudStorageProviderType","SpecialDocumentLibraryType","DocumentLibraryAccessType","FileDownloadStatus","getCloudStorageFolders","addCloudStorageFolder","isFolderAdded","folders","deleteCloudStorageFolder","folderToDelete","getCloudStorageFolderContents","folder","providerCode","isSubdirectory","openCloudStorageFile","fileOpenPreference","openFilePreview","filePreviewParameters","description","objectUrl","downloadUrl","webPreviewUrl","webEditUrl","baseUrl","editFile","viewerAction","getExternalProviders","excludeAddedProviders","copyMoveFiles","selectedFiles","destinationFolder","destinationProviderCode","isMove","getFileDownloads","openDownloadFolder","getUserJoinedTeams","teamInstanceParameters","oldPlatformError","getConfigSetting","getPairedMeetingRoomInfo","sendCommandToPairedMeetingRoom","commandName","registerMeetingRoomCapabilitiesUpdateHandler","capabilities","registerMeetingRoomStatesUpdateHandler","states","showNotification","showNotificationParameters","ControlCommand","ErrorReason","SessionTerminatedReason","getCapableParticipants","requestControl","participant","sendControlCommand","terminateSession","registerOnCapableParticipantsChangeHandler","registerOnErrorHandler","registerOnDeviceStateChangeHandler","registerOnSessionStatusChangeHandler","selectAppEntity","threadId","categories","getTeamChannels","refreshSiteUrl"],"sourceRoot":""}
1
+ {"version":3,"file":"MicrosoftTeams.min.js","mappings":"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","sources":["webpack://microsoftTeams/webpack/universalModuleDefinition","webpack://microsoftTeams/../../node_modules/uuid/index.js","webpack://microsoftTeams/../../node_modules/uuid/lib/bytesToUuid.js","webpack://microsoftTeams/../../node_modules/uuid/lib/rng-browser.js","webpack://microsoftTeams/../../node_modules/uuid/v1.js","webpack://microsoftTeams/../../node_modules/uuid/v4.js","webpack://microsoftTeams/./node_modules/debug/src/browser.js","webpack://microsoftTeams/./node_modules/debug/src/common.js","webpack://microsoftTeams/./node_modules/ms/index.js","webpack://microsoftTeams/webpack/bootstrap","webpack://microsoftTeams/webpack/runtime/define property getters","webpack://microsoftTeams/webpack/runtime/hasOwnProperty shorthand","webpack://microsoftTeams/webpack/runtime/make namespace object","webpack://microsoftTeams/./src/internal/constants.ts","webpack://microsoftTeams/./src/public/constants.ts","webpack://microsoftTeams/./src/internal/globalVars.ts","webpack://microsoftTeams/./src/public/interfaces.ts","webpack://microsoftTeams/./src/internal/utils.ts","webpack://microsoftTeams/./src/internal/internalAPIs.ts","webpack://microsoftTeams/./src/public/runtime.ts","webpack://microsoftTeams/./src/private/logs.ts","webpack://microsoftTeams/./src/public/authentication.ts","webpack://microsoftTeams/./src/public/menus.ts","webpack://microsoftTeams/./src/public/teamsAPIs.ts","webpack://microsoftTeams/./src/public/app.ts","webpack://microsoftTeams/./src/public/pages.ts","webpack://microsoftTeams/./src/private/privateAPIs.ts","webpack://microsoftTeams/./src/internal/telemetry.ts","webpack://microsoftTeams/./src/internal/handlers.ts","webpack://microsoftTeams/./src/internal/communication.ts","webpack://microsoftTeams/./src/private/bot.ts","webpack://microsoftTeams/./src/private/interfaces.ts","webpack://microsoftTeams/./src/private/chat.ts","webpack://microsoftTeams/./src/public/appInstallDialog.ts","webpack://microsoftTeams/./src/public/appWindow.ts","webpack://microsoftTeams/./src/public/dialog.ts","webpack://microsoftTeams/./src/internal/mediaUtil.ts","webpack://microsoftTeams/./src/public/media.ts","webpack://microsoftTeams/./src/public/location.ts","webpack://microsoftTeams/./src/public/meeting.ts","webpack://microsoftTeams/./src/public/monetization.ts","webpack://microsoftTeams/./src/public/calendar.ts","webpack://microsoftTeams/./src/public/mail.ts","webpack://microsoftTeams/./src/public/people.ts","webpack://microsoftTeams/./src/public/video.ts","webpack://microsoftTeams/./src/public/sharing.ts","webpack://microsoftTeams/./src/public/stageView.ts","webpack://microsoftTeams/./src/public/call.ts","webpack://microsoftTeams/./src/public/appInitialization.ts","webpack://microsoftTeams/./src/public/settings.ts","webpack://microsoftTeams/./src/public/tasks.ts","webpack://microsoftTeams/./src/private/files.ts","webpack://microsoftTeams/./src/private/legacy.ts","webpack://microsoftTeams/./src/private/meetingRoom.ts","webpack://microsoftTeams/./src/private/notifications.ts","webpack://microsoftTeams/./src/private/remoteCamera.ts","webpack://microsoftTeams/./src/private/appEntity.ts","webpack://microsoftTeams/./src/private/teams.ts","webpack://microsoftTeams/./src/public/publicAPIs.ts","webpack://microsoftTeams/./src/public/navigation.ts"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"microsoftTeams\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"microsoftTeams\"] = factory();\n\telse\n\t\troot[\"microsoftTeams\"] = factory();\n})(self, function() {\nreturn ","var v1 = require('./v1');\nvar v4 = require('./v4');\n\nvar uuid = v4;\nuuid.v1 = v1;\nuuid.v4 = v4;\n\nmodule.exports = uuid;\n","/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\nvar byteToHex = [];\nfor (var i = 0; i < 256; ++i) {\n byteToHex[i] = (i + 0x100).toString(16).substr(1);\n}\n\nfunction bytesToUuid(buf, offset) {\n var i = offset || 0;\n var bth = byteToHex;\n // join used to fix memory issue caused by concatenation: https://bugs.chromium.org/p/v8/issues/detail?id=3175#c4\n return ([\n bth[buf[i++]], bth[buf[i++]],\n bth[buf[i++]], bth[buf[i++]], '-',\n bth[buf[i++]], bth[buf[i++]], '-',\n bth[buf[i++]], bth[buf[i++]], '-',\n bth[buf[i++]], bth[buf[i++]], '-',\n bth[buf[i++]], bth[buf[i++]],\n bth[buf[i++]], bth[buf[i++]],\n bth[buf[i++]], bth[buf[i++]]\n ]).join('');\n}\n\nmodule.exports = bytesToUuid;\n","// Unique ID creation requires a high quality random # generator. In the\n// browser this is a little complicated due to unknown quality of Math.random()\n// and inconsistent support for the `crypto` API. We do the best we can via\n// feature-detection\n\n// getRandomValues needs to be invoked in a context where \"this\" is a Crypto\n// implementation. Also, find the complete implementation of crypto on IE11.\nvar getRandomValues = (typeof(crypto) != 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto)) ||\n (typeof(msCrypto) != 'undefined' && typeof window.msCrypto.getRandomValues == 'function' && msCrypto.getRandomValues.bind(msCrypto));\n\nif (getRandomValues) {\n // WHATWG crypto RNG - http://wiki.whatwg.org/wiki/Crypto\n var rnds8 = new Uint8Array(16); // eslint-disable-line no-undef\n\n module.exports = function whatwgRNG() {\n getRandomValues(rnds8);\n return rnds8;\n };\n} else {\n // Math.random()-based (RNG)\n //\n // If all else fails, use Math.random(). It's fast, but is of unspecified\n // quality.\n var rnds = new Array(16);\n\n module.exports = function mathRNG() {\n for (var i = 0, r; i < 16; i++) {\n if ((i & 0x03) === 0) r = Math.random() * 0x100000000;\n rnds[i] = r >>> ((i & 0x03) << 3) & 0xff;\n }\n\n return rnds;\n };\n}\n","var rng = require('./lib/rng');\nvar bytesToUuid = require('./lib/bytesToUuid');\n\n// **`v1()` - Generate time-based UUID**\n//\n// Inspired by https://github.com/LiosK/UUID.js\n// and http://docs.python.org/library/uuid.html\n\nvar _nodeId;\nvar _clockseq;\n\n// Previous uuid creation time\nvar _lastMSecs = 0;\nvar _lastNSecs = 0;\n\n// See https://github.com/uuidjs/uuid for API details\nfunction v1(options, buf, offset) {\n var i = buf && offset || 0;\n var b = buf || [];\n\n options = options || {};\n var node = options.node || _nodeId;\n var clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq;\n\n // node and clockseq need to be initialized to random values if they're not\n // specified. We do this lazily to minimize issues related to insufficient\n // system entropy. See #189\n if (node == null || clockseq == null) {\n var seedBytes = rng();\n if (node == null) {\n // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)\n node = _nodeId = [\n seedBytes[0] | 0x01,\n seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]\n ];\n }\n if (clockseq == null) {\n // Per 4.2.2, randomize (14 bit) clockseq\n clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff;\n }\n }\n\n // UUID timestamps are 100 nano-second units since the Gregorian epoch,\n // (1582-10-15 00:00). JSNumbers aren't precise enough for this, so\n // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'\n // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.\n var msecs = options.msecs !== undefined ? options.msecs : new Date().getTime();\n\n // Per 4.2.1.2, use count of uuid's generated during the current clock\n // cycle to simulate higher resolution clock\n var nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1;\n\n // Time since last uuid creation (in msecs)\n var dt = (msecs - _lastMSecs) + (nsecs - _lastNSecs)/10000;\n\n // Per 4.2.1.2, Bump clockseq on clock regression\n if (dt < 0 && options.clockseq === undefined) {\n clockseq = clockseq + 1 & 0x3fff;\n }\n\n // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new\n // time interval\n if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {\n nsecs = 0;\n }\n\n // Per 4.2.1.2 Throw error if too many uuids are requested\n if (nsecs >= 10000) {\n throw new Error('uuid.v1(): Can\\'t create more than 10M uuids/sec');\n }\n\n _lastMSecs = msecs;\n _lastNSecs = nsecs;\n _clockseq = clockseq;\n\n // Per 4.1.4 - Convert from unix epoch to Gregorian epoch\n msecs += 12219292800000;\n\n // `time_low`\n var tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;\n b[i++] = tl >>> 24 & 0xff;\n b[i++] = tl >>> 16 & 0xff;\n b[i++] = tl >>> 8 & 0xff;\n b[i++] = tl & 0xff;\n\n // `time_mid`\n var tmh = (msecs / 0x100000000 * 10000) & 0xfffffff;\n b[i++] = tmh >>> 8 & 0xff;\n b[i++] = tmh & 0xff;\n\n // `time_high_and_version`\n b[i++] = tmh >>> 24 & 0xf | 0x10; // include version\n b[i++] = tmh >>> 16 & 0xff;\n\n // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)\n b[i++] = clockseq >>> 8 | 0x80;\n\n // `clock_seq_low`\n b[i++] = clockseq & 0xff;\n\n // `node`\n for (var n = 0; n < 6; ++n) {\n b[i + n] = node[n];\n }\n\n return buf ? buf : bytesToUuid(b);\n}\n\nmodule.exports = v1;\n","var rng = require('./lib/rng');\nvar bytesToUuid = require('./lib/bytesToUuid');\n\nfunction v4(options, buf, offset) {\n var i = buf && offset || 0;\n\n if (typeof(options) == 'string') {\n buf = options === 'binary' ? new Array(16) : null;\n options = null;\n }\n options = options || {};\n\n var rnds = options.random || (options.rng || rng)();\n\n // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n rnds[6] = (rnds[6] & 0x0f) | 0x40;\n rnds[8] = (rnds[8] & 0x3f) | 0x80;\n\n // Copy bytes to buffer, if provided\n if (buf) {\n for (var ii = 0; ii < 16; ++ii) {\n buf[i + ii] = rnds[ii];\n }\n }\n\n return buf || bytesToUuid(rnds);\n}\n\nmodule.exports = v4;\n","/* eslint-env browser */\n\n/**\n * This is the web browser implementation of `debug()`.\n */\n\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = localstorage();\nexports.destroy = (() => {\n\tlet warned = false;\n\n\treturn () => {\n\t\tif (!warned) {\n\t\t\twarned = true;\n\t\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t\t}\n\t};\n})();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n\t'#0000CC',\n\t'#0000FF',\n\t'#0033CC',\n\t'#0033FF',\n\t'#0066CC',\n\t'#0066FF',\n\t'#0099CC',\n\t'#0099FF',\n\t'#00CC00',\n\t'#00CC33',\n\t'#00CC66',\n\t'#00CC99',\n\t'#00CCCC',\n\t'#00CCFF',\n\t'#3300CC',\n\t'#3300FF',\n\t'#3333CC',\n\t'#3333FF',\n\t'#3366CC',\n\t'#3366FF',\n\t'#3399CC',\n\t'#3399FF',\n\t'#33CC00',\n\t'#33CC33',\n\t'#33CC66',\n\t'#33CC99',\n\t'#33CCCC',\n\t'#33CCFF',\n\t'#6600CC',\n\t'#6600FF',\n\t'#6633CC',\n\t'#6633FF',\n\t'#66CC00',\n\t'#66CC33',\n\t'#9900CC',\n\t'#9900FF',\n\t'#9933CC',\n\t'#9933FF',\n\t'#99CC00',\n\t'#99CC33',\n\t'#CC0000',\n\t'#CC0033',\n\t'#CC0066',\n\t'#CC0099',\n\t'#CC00CC',\n\t'#CC00FF',\n\t'#CC3300',\n\t'#CC3333',\n\t'#CC3366',\n\t'#CC3399',\n\t'#CC33CC',\n\t'#CC33FF',\n\t'#CC6600',\n\t'#CC6633',\n\t'#CC9900',\n\t'#CC9933',\n\t'#CCCC00',\n\t'#CCCC33',\n\t'#FF0000',\n\t'#FF0033',\n\t'#FF0066',\n\t'#FF0099',\n\t'#FF00CC',\n\t'#FF00FF',\n\t'#FF3300',\n\t'#FF3333',\n\t'#FF3366',\n\t'#FF3399',\n\t'#FF33CC',\n\t'#FF33FF',\n\t'#FF6600',\n\t'#FF6633',\n\t'#FF9900',\n\t'#FF9933',\n\t'#FFCC00',\n\t'#FFCC33'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\n// eslint-disable-next-line complexity\nfunction useColors() {\n\t// NB: In an Electron preload script, document will be defined but not fully\n\t// initialized. Since we know we're in Chrome, we'll just detect this case\n\t// explicitly\n\tif (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n\t\treturn true;\n\t}\n\n\t// Internet Explorer and Edge do not support colors.\n\tif (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n\t\treturn false;\n\t}\n\n\t// Is webkit? http://stackoverflow.com/a/16459606/376773\n\t// document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n\treturn (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n\t\t// Is firebug? http://stackoverflow.com/a/398120/376773\n\t\t(typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n\t\t// Is firefox >= v31?\n\t\t// https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/) && parseInt(RegExp.$1, 10) >= 31) ||\n\t\t// Double check webkit in userAgent just in case we are in a worker\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\targs[0] = (this.useColors ? '%c' : '') +\n\t\tthis.namespace +\n\t\t(this.useColors ? ' %c' : ' ') +\n\t\targs[0] +\n\t\t(this.useColors ? '%c ' : ' ') +\n\t\t'+' + module.exports.humanize(this.diff);\n\n\tif (!this.useColors) {\n\t\treturn;\n\t}\n\n\tconst c = 'color: ' + this.color;\n\targs.splice(1, 0, c, 'color: inherit');\n\n\t// The final \"%c\" is somewhat tricky, because there could be other\n\t// arguments passed either before or after the %c, so we need to\n\t// figure out the correct index to insert the CSS into\n\tlet index = 0;\n\tlet lastC = 0;\n\targs[0].replace(/%[a-zA-Z%]/g, match => {\n\t\tif (match === '%%') {\n\t\t\treturn;\n\t\t}\n\t\tindex++;\n\t\tif (match === '%c') {\n\t\t\t// We only are interested in the *last* %c\n\t\t\t// (the user may have provided their own)\n\t\t\tlastC = index;\n\t\t}\n\t});\n\n\targs.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.debug()` when available.\n * No-op when `console.debug` is not a \"function\".\n * If `console.debug` is not available, falls back\n * to `console.log`.\n *\n * @api public\n */\nexports.log = console.debug || console.log || (() => {});\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\ttry {\n\t\tif (namespaces) {\n\t\t\texports.storage.setItem('debug', namespaces);\n\t\t} else {\n\t\t\texports.storage.removeItem('debug');\n\t\t}\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n\tlet r;\n\ttry {\n\t\tr = exports.storage.getItem('debug');\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n\n\t// If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n\tif (!r && typeof process !== 'undefined' && 'env' in process) {\n\t\tr = process.env.DEBUG;\n\t}\n\n\treturn r;\n}\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n\ttry {\n\t\t// TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n\t\t// The Browser also has localStorage in the global context.\n\t\treturn localStorage;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nformatters.j = function (v) {\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch (error) {\n\t\treturn '[UnexpectedJSONParseError]: ' + error.message;\n\t}\n};\n","\n/**\n * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n */\n\nfunction setup(env) {\n\tcreateDebug.debug = createDebug;\n\tcreateDebug.default = createDebug;\n\tcreateDebug.coerce = coerce;\n\tcreateDebug.disable = disable;\n\tcreateDebug.enable = enable;\n\tcreateDebug.enabled = enabled;\n\tcreateDebug.humanize = require('ms');\n\tcreateDebug.destroy = destroy;\n\n\tObject.keys(env).forEach(key => {\n\t\tcreateDebug[key] = env[key];\n\t});\n\n\t/**\n\t* The currently active debug mode names, and names to skip.\n\t*/\n\n\tcreateDebug.names = [];\n\tcreateDebug.skips = [];\n\n\t/**\n\t* Map of special \"%n\" handling functions, for the debug \"format\" argument.\n\t*\n\t* Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n\t*/\n\tcreateDebug.formatters = {};\n\n\t/**\n\t* Selects a color for a debug namespace\n\t* @param {String} namespace The namespace string for the debug instance to be colored\n\t* @return {Number|String} An ANSI color code for the given namespace\n\t* @api private\n\t*/\n\tfunction selectColor(namespace) {\n\t\tlet hash = 0;\n\n\t\tfor (let i = 0; i < namespace.length; i++) {\n\t\t\thash = ((hash << 5) - hash) + namespace.charCodeAt(i);\n\t\t\thash |= 0; // Convert to 32bit integer\n\t\t}\n\n\t\treturn createDebug.colors[Math.abs(hash) % createDebug.colors.length];\n\t}\n\tcreateDebug.selectColor = selectColor;\n\n\t/**\n\t* Create a debugger with the given `namespace`.\n\t*\n\t* @param {String} namespace\n\t* @return {Function}\n\t* @api public\n\t*/\n\tfunction createDebug(namespace) {\n\t\tlet prevTime;\n\t\tlet enableOverride = null;\n\t\tlet namespacesCache;\n\t\tlet enabledCache;\n\n\t\tfunction debug(...args) {\n\t\t\t// Disabled?\n\t\t\tif (!debug.enabled) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst self = debug;\n\n\t\t\t// Set `diff` timestamp\n\t\t\tconst curr = Number(new Date());\n\t\t\tconst ms = curr - (prevTime || curr);\n\t\t\tself.diff = ms;\n\t\t\tself.prev = prevTime;\n\t\t\tself.curr = curr;\n\t\t\tprevTime = curr;\n\n\t\t\targs[0] = createDebug.coerce(args[0]);\n\n\t\t\tif (typeof args[0] !== 'string') {\n\t\t\t\t// Anything else let's inspect with %O\n\t\t\t\targs.unshift('%O');\n\t\t\t}\n\n\t\t\t// Apply any `formatters` transformations\n\t\t\tlet index = 0;\n\t\t\targs[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => {\n\t\t\t\t// If we encounter an escaped % then don't increase the array index\n\t\t\t\tif (match === '%%') {\n\t\t\t\t\treturn '%';\n\t\t\t\t}\n\t\t\t\tindex++;\n\t\t\t\tconst formatter = createDebug.formatters[format];\n\t\t\t\tif (typeof formatter === 'function') {\n\t\t\t\t\tconst val = args[index];\n\t\t\t\t\tmatch = formatter.call(self, val);\n\n\t\t\t\t\t// Now we need to remove `args[index]` since it's inlined in the `format`\n\t\t\t\t\targs.splice(index, 1);\n\t\t\t\t\tindex--;\n\t\t\t\t}\n\t\t\t\treturn match;\n\t\t\t});\n\n\t\t\t// Apply env-specific formatting (colors, etc.)\n\t\t\tcreateDebug.formatArgs.call(self, args);\n\n\t\t\tconst logFn = self.log || createDebug.log;\n\t\t\tlogFn.apply(self, args);\n\t\t}\n\n\t\tdebug.namespace = namespace;\n\t\tdebug.useColors = createDebug.useColors();\n\t\tdebug.color = createDebug.selectColor(namespace);\n\t\tdebug.extend = extend;\n\t\tdebug.destroy = createDebug.destroy; // XXX Temporary. Will be removed in the next major release.\n\n\t\tObject.defineProperty(debug, 'enabled', {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: false,\n\t\t\tget: () => {\n\t\t\t\tif (enableOverride !== null) {\n\t\t\t\t\treturn enableOverride;\n\t\t\t\t}\n\t\t\t\tif (namespacesCache !== createDebug.namespaces) {\n\t\t\t\t\tnamespacesCache = createDebug.namespaces;\n\t\t\t\t\tenabledCache = createDebug.enabled(namespace);\n\t\t\t\t}\n\n\t\t\t\treturn enabledCache;\n\t\t\t},\n\t\t\tset: v => {\n\t\t\t\tenableOverride = v;\n\t\t\t}\n\t\t});\n\n\t\t// Env-specific initialization logic for debug instances\n\t\tif (typeof createDebug.init === 'function') {\n\t\t\tcreateDebug.init(debug);\n\t\t}\n\n\t\treturn debug;\n\t}\n\n\tfunction extend(namespace, delimiter) {\n\t\tconst newDebug = createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace);\n\t\tnewDebug.log = this.log;\n\t\treturn newDebug;\n\t}\n\n\t/**\n\t* Enables a debug mode by namespaces. This can include modes\n\t* separated by a colon and wildcards.\n\t*\n\t* @param {String} namespaces\n\t* @api public\n\t*/\n\tfunction enable(namespaces) {\n\t\tcreateDebug.save(namespaces);\n\t\tcreateDebug.namespaces = namespaces;\n\n\t\tcreateDebug.names = [];\n\t\tcreateDebug.skips = [];\n\n\t\tlet i;\n\t\tconst split = (typeof namespaces === 'string' ? namespaces : '').split(/[\\s,]+/);\n\t\tconst len = split.length;\n\n\t\tfor (i = 0; i < len; i++) {\n\t\t\tif (!split[i]) {\n\t\t\t\t// ignore empty strings\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tnamespaces = split[i].replace(/\\*/g, '.*?');\n\n\t\t\tif (namespaces[0] === '-') {\n\t\t\t\tcreateDebug.skips.push(new RegExp('^' + namespaces.substr(1) + '$'));\n\t\t\t} else {\n\t\t\t\tcreateDebug.names.push(new RegExp('^' + namespaces + '$'));\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t* Disable debug output.\n\t*\n\t* @return {String} namespaces\n\t* @api public\n\t*/\n\tfunction disable() {\n\t\tconst namespaces = [\n\t\t\t...createDebug.names.map(toNamespace),\n\t\t\t...createDebug.skips.map(toNamespace).map(namespace => '-' + namespace)\n\t\t].join(',');\n\t\tcreateDebug.enable('');\n\t\treturn namespaces;\n\t}\n\n\t/**\n\t* Returns true if the given mode name is enabled, false otherwise.\n\t*\n\t* @param {String} name\n\t* @return {Boolean}\n\t* @api public\n\t*/\n\tfunction enabled(name) {\n\t\tif (name[name.length - 1] === '*') {\n\t\t\treturn true;\n\t\t}\n\n\t\tlet i;\n\t\tlet len;\n\n\t\tfor (i = 0, len = createDebug.skips.length; i < len; i++) {\n\t\t\tif (createDebug.skips[i].test(name)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\tfor (i = 0, len = createDebug.names.length; i < len; i++) {\n\t\t\tif (createDebug.names[i].test(name)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t* Convert regexp to namespace\n\t*\n\t* @param {RegExp} regxep\n\t* @return {String} namespace\n\t* @api private\n\t*/\n\tfunction toNamespace(regexp) {\n\t\treturn regexp.toString()\n\t\t\t.substring(2, regexp.toString().length - 2)\n\t\t\t.replace(/\\.\\*\\?$/, '*');\n\t}\n\n\t/**\n\t* Coerce `val`.\n\t*\n\t* @param {Mixed} val\n\t* @return {Mixed}\n\t* @api private\n\t*/\n\tfunction coerce(val) {\n\t\tif (val instanceof Error) {\n\t\t\treturn val.stack || val.message;\n\t\t}\n\t\treturn val;\n\t}\n\n\t/**\n\t* XXX DO NOT USE. This is a temporary stub function.\n\t* XXX It WILL be removed in the next major release.\n\t*/\n\tfunction destroy() {\n\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t}\n\n\tcreateDebug.enable(createDebug.load());\n\n\treturn createDebug;\n}\n\nmodule.exports = setup;\n","/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function(val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isFinite(val)) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (msAbs >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (msAbs >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (msAbs >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n var isPlural = msAbs >= n * 1.5;\n return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","declare const PACKAGE_VERSION: string;\r\nexport const version = PACKAGE_VERSION;\r\n\r\n/**\r\n * @hidden\r\n * The client version when all SDK APIs started to check platform compatibility for the APIs was 1.6.0.\r\n * Modified to 2.0.1 which is hightest till now so that if any client doesn't pass version in initialize function, it will be set to highest.\r\n * Mobile clients are passing versions, hence will be applicable to web and desktop clients only.\r\n *\r\n * @internal\r\n */\r\nexport const defaultSDKVersionForCompatCheck = '2.0.1';\r\n\r\n/**\r\n * @hidden\r\n * This is the client version when selectMedia API - VideoAndImage is supported on mobile.\r\n *\r\n * @internal\r\n */\r\nexport const videoAndImageMediaAPISupportVersion = '2.0.2';\r\n\r\n/**\r\n * This is the client version when selectMedia API - Video with non-full screen mode is supported on mobile.\r\n */\r\nexport const nonFullScreenVideoModeAPISupportVersion = '2.0.3';\r\n\r\n/**\r\n * This is the client version when selectMedia API - ImageOutputFormats is supported on mobile.\r\n */\r\nexport const imageOutputFormatsAPISupportVersion = '2.0.4';\r\n\r\n/**\r\n * @hidden\r\n * Minimum required client supported version for {@link getUserJoinedTeams} to be supported on {@link HostClientType.android}\r\n *\r\n * @internal\r\n */\r\nexport const getUserJoinedTeamsSupportedAndroidClientVersion = '2.0.1';\r\n\r\n/**\r\n * @hidden\r\n * This is the client version when location APIs (getLocation and showLocation) are supported.\r\n *\r\n * @internal\r\n */\r\nexport const locationAPIsRequiredVersion = '1.9.0';\r\n\r\n/**\r\n * @hidden\r\n * This is the client version when people picker API is supported on mobile.\r\n *\r\n * @internal\r\n */\r\nexport const peoplePickerRequiredVersion = '2.0.0';\r\n\r\n/**\r\n * @hidden\r\n * This is the client version when captureImage API is supported on mobile.\r\n *\r\n * @internal\r\n */\r\nexport const captureImageMobileSupportVersion = '1.7.0';\r\n\r\n/**\r\n * @hidden\r\n * This is the client version when media APIs are supported on all three platforms ios, android and web.\r\n *\r\n * @internal\r\n */\r\nexport const mediaAPISupportVersion = '1.8.0';\r\n\r\n/**\r\n * @hidden\r\n * This is the client version when getMedia API is supported via Callbacks on all three platforms ios, android and web.\r\n *\r\n * @internal\r\n */\r\nexport const getMediaCallbackSupportVersion = '2.0.0';\r\n\r\n/**\r\n * @hidden\r\n * This is the client version when scanBarCode API is supported on mobile.\r\n *\r\n * @internal\r\n */\r\nexport const scanBarCodeAPIMobileSupportVersion = '1.9.0';\r\n\r\n/**\r\n * @hidden\r\n * List of supported Host origins\r\n *\r\n * @internal\r\n */\r\nexport const validOrigins = [\r\n 'teams.microsoft.com',\r\n 'teams.microsoft.us',\r\n 'gov.teams.microsoft.us',\r\n 'dod.teams.microsoft.us',\r\n 'int.teams.microsoft.com',\r\n 'teams.live.com',\r\n 'devspaces.skype.com',\r\n 'ssauth.skype.com',\r\n 'local.teams.live.com', // local development\r\n 'local.teams.live.com:8080', // local development\r\n 'local.teams.office.com', // local development\r\n 'local.teams.office.com:8080', // local development\r\n 'msft.spoppe.com',\r\n '*.sharepoint.com',\r\n '*.sharepoint-df.com',\r\n '*.sharepointonline.com',\r\n 'outlook.office.com',\r\n 'outlook-sdf.office.com',\r\n '*.teams.microsoft.com',\r\n 'www.office.com',\r\n 'word.office.com',\r\n 'excel.office.com',\r\n 'powerpoint.office.com',\r\n 'www.officeppe.com',\r\n '*.www.office.com',\r\n];\r\n\r\n/**\r\n * @hidden\r\n * USer specified message origins should satisfy this test\r\n *\r\n * @internal\r\n */\r\nexport const userOriginUrlValidationRegExp = /^https:\\/\\//;\r\n","export enum HostClientType {\r\n desktop = 'desktop',\r\n web = 'web',\r\n android = 'android',\r\n ios = 'ios',\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link teamsRoomsWindows} instead.\r\n */\r\n rigel = 'rigel',\r\n surfaceHub = 'surfaceHub',\r\n teamsRoomsWindows = 'teamsRoomsWindows',\r\n teamsRoomsAndroid = 'teamsRoomsAndroid',\r\n teamsPhones = 'teamsPhones',\r\n teamsDisplays = 'teamsDisplays',\r\n}\r\n\r\nexport enum HostName {\r\n office = 'Office',\r\n outlook = 'Outlook',\r\n orange = 'Orange',\r\n teams = 'Teams',\r\n}\r\n\r\n// Ensure these declarations stay in sync with the framework.\r\nexport enum FrameContexts {\r\n settings = 'settings',\r\n content = 'content',\r\n authentication = 'authentication',\r\n remove = 'remove',\r\n task = 'task',\r\n sidePanel = 'sidePanel',\r\n stage = 'stage',\r\n meetingStage = 'meetingStage',\r\n}\r\n\r\n/**\r\n * Indicates the team type, currently used to distinguish between different team\r\n * types in Office 365 for Education (team types 1, 2, 3, and 4).\r\n */\r\nexport enum TeamType {\r\n Standard = 0,\r\n Edu = 1,\r\n Class = 2,\r\n Plc = 3,\r\n Staff = 4,\r\n}\r\n\r\n/**\r\n * Indicates the various types of roles of a user in a team.\r\n */\r\nexport enum UserTeamRole {\r\n Admin = 0,\r\n User = 1,\r\n Guest = 2,\r\n}\r\n\r\n/**\r\n * Dialog module dimension enum\r\n */\r\nexport enum DialogDimension {\r\n Large = 'large',\r\n Medium = 'medium',\r\n Small = 'small',\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link DialogDimension} instead.\r\n */\r\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\r\nexport import TaskModuleDimension = DialogDimension;\r\n\r\n/**\r\n * The type of the channel with which the content is associated.\r\n */\r\nexport enum ChannelType {\r\n Regular = 'Regular',\r\n Private = 'Private',\r\n Shared = 'Shared',\r\n}\r\n","import { FrameContexts } from '../public';\r\nexport class GlobalVars {\r\n public static initializeCalled = false;\r\n public static initializeCompleted = false;\r\n public static additionalValidOrigins: string[] = [];\r\n public static initializePromise: Promise<void>;\r\n public static isFramelessWindow = false;\r\n public static frameContext: FrameContexts;\r\n public static hostClientType: string;\r\n public static clientSupportedSDKVersion: string;\r\n public static printCapabilityEnabled = false;\r\n}\r\n","/* eslint-disable @typescript-eslint/no-explicit-any*/\r\n\r\nimport { ChannelType, DialogDimension, HostClientType, HostName, TeamType, UserTeamRole } from './constants';\r\nimport { FrameContexts } from './constants';\r\n\r\n/**\r\n * Represents information about tabs for an app\r\n *\r\n * @alpha\r\n */\r\nexport interface TabInformation {\r\n teamTabs: TabInstance[];\r\n}\r\n\r\n/**\r\n * Represents information about a tab instance\r\n */\r\nexport interface TabInstance {\r\n /**\r\n * The name of the tab\r\n */\r\n tabName: string;\r\n\r\n /**\r\n * @internal\r\n * @protected\r\n */\r\n internalTabInstanceId?: string;\r\n\r\n /**\r\n * Last viewed time of this tab. null means unknown\r\n */\r\n lastViewUnixEpochTime?: string;\r\n\r\n /**\r\n * The developer-defined unique ID for the entity this content points to.\r\n */\r\n entityId?: string;\r\n\r\n /**\r\n * The Microsoft Teams ID for the channel with which the content is associated.\r\n */\r\n channelId?: string;\r\n\r\n /**\r\n * The name for the channel with which the content is associated.\r\n */\r\n channelName?: string;\r\n\r\n /**\r\n * Is this tab in a favorite channel?\r\n */\r\n channelIsFavorite?: boolean;\r\n\r\n /**\r\n * The Microsoft Teams ID for the team with which the content is associated.\r\n */\r\n teamId?: string;\r\n\r\n /**\r\n * The name for the team with which the content is associated.\r\n */\r\n teamName?: string;\r\n\r\n /**\r\n * Is this tab in a favorite team?\r\n */\r\n teamIsFavorite?: boolean;\r\n\r\n /**\r\n * The Office 365 group ID for the team with which the content is associated.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n groupId?: string;\r\n\r\n /**\r\n * Content URL of this tab\r\n */\r\n url?: string;\r\n\r\n /**\r\n * Website URL of this tab\r\n */\r\n websiteUrl?: string;\r\n}\r\n\r\n/**\r\n * Indicates information about the tab instance for filtering purposes.\r\n */\r\nexport interface TabInstanceParameters {\r\n /**\r\n * Flag allowing to select favorite channels only\r\n */\r\n favoriteChannelsOnly?: boolean;\r\n\r\n /**\r\n * Flag allowing to select favorite teams only\r\n */\r\n favoriteTeamsOnly?: boolean;\r\n}\r\n\r\n/**\r\n * Represents Team Information\r\n */\r\nexport interface TeamInformation {\r\n /**\r\n * Id of the team\r\n */\r\n teamId: string;\r\n\r\n /**\r\n * Team display name\r\n */\r\n teamName: string;\r\n\r\n /**\r\n * Team description\r\n */\r\n teamDescription?: string;\r\n\r\n /**\r\n * Thumbnail Uri\r\n */\r\n thumbnailUri?: string;\r\n\r\n /**\r\n * The Office 365 group ID for the team with which the content is associated.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n groupId?: string;\r\n\r\n /**\r\n * Role of current user in the team\r\n */\r\n userTeamRole?: UserTeamRole;\r\n\r\n /**\r\n * The type of the team.\r\n */\r\n teamType?: TeamType;\r\n\r\n /**\r\n * The locked status of the team\r\n */\r\n isTeamLocked?: boolean;\r\n\r\n /**\r\n * The archived status of the team\r\n */\r\n isTeamArchived?: boolean;\r\n}\r\n\r\n/**\r\n * Represents OS locale info used for formatting date and time data\r\n */\r\nexport interface LocaleInfo {\r\n platform: 'windows' | 'macos';\r\n regionalFormat: string;\r\n shortDate: string;\r\n longDate: string;\r\n shortTime: string;\r\n longTime: string;\r\n}\r\n\r\n/**\r\n * Allowed user file open preferences\r\n */\r\nexport enum FileOpenPreference {\r\n Inline = 'inline',\r\n Desktop = 'desktop',\r\n Web = 'web',\r\n}\r\n\r\nexport interface Context {\r\n /**\r\n * @hidden\r\n * The Office 365 group ID for the team with which the content is associated.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n groupId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The Microsoft Teams ID for the team with which the content is associated.\r\n */\r\n teamId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The name for the team with which the content is associated.\r\n */\r\n teamName?: string;\r\n\r\n /**\r\n * @hidden\r\n * The Microsoft Teams ID for the channel with which the content is associated.\r\n */\r\n channelId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The name for the channel with which the content is associated.\r\n */\r\n channelName?: string;\r\n\r\n /**\r\n * @hidden\r\n * The type of the channel with which the content is associated.\r\n */\r\n channelType?: ChannelType;\r\n\r\n /**\r\n * @hidden\r\n * The developer-defined unique ID for the entity this content points to.\r\n */\r\n entityId: string;\r\n\r\n /**\r\n * @hidden\r\n * The developer-defined unique ID for the sub-entity this content points to.\r\n * This field should be used to restore to a specific state within an entity,\r\n * such as scrolling to or activating a specific piece of content.\r\n */\r\n subEntityId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The current locale that the user has configured for the app formatted as\r\n * languageId-countryId (for example, en-us).\r\n */\r\n locale: string;\r\n\r\n /**\r\n * @hidden\r\n * More detailed locale info from the user's OS if available. Can be used together with\r\n * the @microsoft/globe NPM package to ensure your app respects the user's OS date and\r\n * time format configuration\r\n */\r\n osLocaleInfo?: LocaleInfo;\r\n\r\n /**\r\n * @hidden\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link loginHint} or {@link userPrincipalName} instead.\r\n * The UPN of the current user.\r\n * Because a malicious party can run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n upn?: string;\r\n\r\n /**\r\n * @hidden\r\n * The Azure AD tenant ID of the current user.\r\n * Because a malicious party can run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n tid?: string;\r\n\r\n /**\r\n * @hidden\r\n * The current UI theme.\r\n */\r\n theme?: string;\r\n\r\n /**\r\n * @hidden\r\n * Indication whether the tab is in full-screen mode.\r\n */\r\n isFullScreen?: boolean;\r\n\r\n /**\r\n * @hidden\r\n * The type of the team.\r\n */\r\n teamType?: TeamType;\r\n\r\n /**\r\n * @hidden\r\n * The root SharePoint site associated with the team.\r\n */\r\n teamSiteUrl?: string;\r\n\r\n /**\r\n * @hidden\r\n * The domain of the root SharePoint site associated with the team.\r\n */\r\n teamSiteDomain?: string;\r\n\r\n /**\r\n * @hidden\r\n * The relative path to the SharePoint site associated with the team.\r\n */\r\n teamSitePath?: string;\r\n\r\n /**\r\n * @hidden\r\n * The tenant ID of the host team.\r\n */\r\n hostTeamTenantId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The AAD group ID of the host team.\r\n */\r\n hostTeamGroupId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The relative path to the SharePoint folder associated with the channel.\r\n */\r\n channelRelativeUrl?: string;\r\n\r\n /**\r\n * @hidden\r\n * Unique ID for the current Teams session for use in correlating telemetry data.\r\n */\r\n sessionId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The user's role in the team.\r\n * Because a malicious party can run your content in a browser, this value should\r\n * be used only as a hint as to the user's role, and never as proof of her role.\r\n */\r\n userTeamRole?: UserTeamRole;\r\n\r\n /**\r\n * @hidden\r\n * The Microsoft Teams ID for the chat with which the content is associated.\r\n */\r\n chatId?: string;\r\n\r\n /**\r\n * @hidden\r\n * A value suitable for use as a login_hint when authenticating with Azure AD.\r\n * Because a malicious party can run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n loginHint?: string;\r\n\r\n /**\r\n * @hidden\r\n * The UPN of the current user. This may be an externally-authenticated UPN (e.g., guest users).\r\n * Because a malicious party run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n userPrincipalName?: string;\r\n\r\n /**\r\n * @hidden\r\n * The Azure AD object id of the current user.\r\n * Because a malicious party run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n userObjectId?: string;\r\n\r\n /**\r\n * @hidden\r\n * Indicates whether team is archived.\r\n * Apps should use this as a signal to prevent any changes to content associated with archived teams.\r\n */\r\n isTeamArchived?: boolean;\r\n\r\n /**\r\n * @hidden\r\n * The name of the host client. Possible values are: Office, Orange, Outlook, Teams\r\n */\r\n hostName?: HostName;\r\n\r\n /**\r\n * @hidden\r\n * The type of the host client. Possible values are : android, ios, web, desktop, rigel (deprecated, use teamsRoomsWindows instead),\r\n * teamsRoomsWindows, teamsRoomsAndroid, teamsPhones, teamsDisplays\r\n */\r\n hostClientType?: HostClientType;\r\n\r\n /**\r\n * @hidden\r\n * The context where tab url is loaded (content, task, setting, remove, sidePanel)\r\n */\r\n frameContext?: FrameContexts;\r\n\r\n /**\r\n * @hidden\r\n * SharePoint context. This is only available when hosted in SharePoint.\r\n */\r\n sharepoint?: any;\r\n\r\n /**\r\n * @hidden\r\n * The type of license for the current users tenant.\r\n */\r\n tenantSKU?: string;\r\n\r\n /**\r\n * @hidden\r\n * The license type for the current user.\r\n */\r\n userLicenseType?: string;\r\n\r\n /**\r\n * @hidden\r\n * The ID of the parent message from which this task module was launched.\r\n * This is only available in task modules launched from bot cards.\r\n */\r\n parentMessageId?: string;\r\n\r\n /**\r\n * @hidden\r\n * Current ring ID\r\n */\r\n ringId?: string;\r\n\r\n /**\r\n * @hidden\r\n * Unique ID for the current session for use in correlating telemetry data.\r\n */\r\n appSessionId?: string;\r\n\r\n /**\r\n * @hidden\r\n * ID for the current visible app which is different for across cached sessions. Used for correlating telemetry data``\r\n */\r\n appLaunchId?: string;\r\n\r\n /**\r\n * @hidden\r\n * Represents whether calling is allowed for the current logged in User\r\n */\r\n isCallingAllowed?: boolean;\r\n\r\n /**\r\n * @hidden\r\n * Represents whether PSTN calling is allowed for the current logged in User\r\n */\r\n isPSTNCallingAllowed?: boolean;\r\n\r\n /**\r\n * @hidden\r\n * Meeting Id used by tab when running in meeting context\r\n */\r\n meetingId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The OneNote section ID that is linked to the channel.\r\n */\r\n defaultOneNoteSectionId?: string;\r\n\r\n /**\r\n * @hidden\r\n * Indication whether the tab is in a pop out window\r\n */\r\n isMultiWindow?: boolean;\r\n\r\n /**\r\n * @hidden\r\n * Personal app icon y coordinate position\r\n */\r\n appIconPosition?: number;\r\n\r\n /**\r\n * @hidden\r\n * Source origin from where the tab is opened\r\n */\r\n sourceOrigin?: string;\r\n\r\n /**\r\n * @hidden\r\n * Time when the user clicked on the tab\r\n */\r\n userClickTime?: number;\r\n\r\n /**\r\n * @hidden\r\n * Team Template ID if there was a Team Template associated with the creation of the team.\r\n */\r\n teamTemplateId?: string;\r\n\r\n /**\r\n * @hidden\r\n * Where the user prefers the file to be opened from by default during file open\r\n */\r\n userFileOpenPreference?: FileOpenPreference;\r\n\r\n /**\r\n * @hidden\r\n * The address book name of the current user.\r\n */\r\n userDisplayName?: string;\r\n\r\n /**\r\n * @hidden\r\n * Teamsite ID, aka sharepoint site id.\r\n */\r\n teamSiteId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The SharePoint my site domain associated with the user.\r\n */\r\n mySiteDomain?: string;\r\n\r\n /**\r\n * @hidden\r\n * The SharePoint relative path to the current users mysite\r\n */\r\n mySitePath?: string;\r\n}\r\n\r\nexport interface DeepLinkParameters {\r\n /**\r\n * The developer-defined unique ID for the sub-entity to which this deep link points in the current entity.\r\n * This field should be used to restore to a specific state within an entity, such as scrolling to or activating a specific piece of content.\r\n */\r\n subEntityId: string;\r\n\r\n /**\r\n * The label for the sub-entity that should be displayed when the deep link is rendered in a client.\r\n */\r\n subEntityLabel: string;\r\n\r\n /**\r\n * The fallback URL to which to navigate the user if the client cannot render the page.\r\n * This URL should lead directly to the sub-entity.\r\n */\r\n subEntityWebUrl?: string;\r\n}\r\n\r\nexport interface DialogInfo {\r\n /**\r\n * The url to be rendered in the webview/iframe.\r\n */\r\n url?: string;\r\n\r\n /**\r\n * JSON defining an adaptive card.\r\n */\r\n card?: string;\r\n\r\n /**\r\n * The requested height of the webview/iframe.\r\n */\r\n height?: DialogDimension | number;\r\n\r\n /**\r\n * The requested width of the webview/iframe.\r\n */\r\n width?: DialogDimension | number;\r\n\r\n /**\r\n * Title of the task module.\r\n */\r\n title?: string;\r\n\r\n /**\r\n * If client doesnt support the URL, the URL that needs to be opened in the browser.\r\n */\r\n fallbackUrl?: string;\r\n\r\n /**\r\n * Specifies a bot ID to send the result of the user's interaction with the task module.\r\n * If specified, the bot will receive a task/complete invoke event with a JSON object\r\n * in the event payload.\r\n */\r\n completionBotId?: string;\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link DialogInfo} instead.\r\n */\r\nexport type TaskInfo = DialogInfo;\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n *\r\n * @internal\r\n */\r\nexport interface OpenConversationRequest {\r\n /**\r\n * @hidden\r\n * The Id of the subEntity where the conversation is taking place\r\n */\r\n subEntityId: string;\r\n\r\n /**\r\n * @hidden\r\n * The title of the conversation\r\n */\r\n title: string;\r\n\r\n /**\r\n * @hidden\r\n * The Id of the conversation. This is optional and should be specified whenever a previous conversation about a specific sub-entity has already been started before\r\n */\r\n conversationId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The Id of the channel. This is optional and should be specified whenever a conversation is started or opened in a personal app scope\r\n */\r\n channelId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The entity Id of the tab\r\n */\r\n entityId: string;\r\n\r\n /**\r\n * @hidden\r\n * A function that is called once the conversation Id has been created\r\n */\r\n onStartConversation?: (conversationResponse: ConversationResponse) => void;\r\n\r\n /**\r\n * @hidden\r\n * A function that is called if the pane is closed\r\n */\r\n onCloseConversation?: (conversationResponse: ConversationResponse) => void;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n *\r\n * @internal\r\n */\r\nexport interface ConversationResponse {\r\n /**\r\n * @hidden\r\n * The Id of the subEntity where the conversation is taking place\r\n */\r\n subEntityId: string;\r\n\r\n /**\r\n * @hidden\r\n * The Id of the conversation. This is optional and should be specified whenever a previous conversation about a specific sub-entity has already been started before\r\n */\r\n conversationId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The Id of the channel. This is optional and should be specified whenever a conversation is started or opened in a personal app scope\r\n */\r\n channelId?: string;\r\n\r\n /**\r\n * @hidden\r\n * The entity Id of the tab\r\n */\r\n entityId?: string;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs.\r\n *\r\n * @internal\r\n */\r\nexport interface LoadContext {\r\n /**\r\n * @hidden\r\n * The entity that is requested to be loaded\r\n */\r\n entityId: string;\r\n\r\n /**\r\n * @hidden\r\n * The content URL that is requested to be loaded\r\n */\r\n contentUrl: string;\r\n}\r\n\r\nexport interface FrameInfo {\r\n /**\r\n * The current URL that needs to be used in the iframe if the tab is reloaded\r\n */\r\n contentUrl: string;\r\n\r\n /**\r\n * The current URL that needs to be used for opening the website when the user clicks on 'Go to website'\r\n */\r\n websiteUrl: string;\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link FrameInfo} instead.\r\n */\r\nexport type FrameContext = FrameInfo;\r\n\r\nexport interface SdkError {\r\n /**\r\n error code\r\n */\r\n errorCode: ErrorCode;\r\n /**\r\n Optional description for the error. This may contain useful information for web-app developers.\r\n This string will not be localized and is not for end-user consumption. \r\n App should not depend on the string content. The exact value may change. This is only for debugging purposes.\r\n */\r\n message?: string;\r\n}\r\n\r\nexport enum ErrorCode {\r\n /**\r\n * API not supported in the current platform.\r\n */\r\n NOT_SUPPORTED_ON_PLATFORM = 100,\r\n /**\r\n * Internal error encountered while performing the required operation.\r\n */\r\n INTERNAL_ERROR = 500,\r\n /**\r\n * API is not supported in the current context\r\n */\r\n NOT_SUPPORTED_IN_CURRENT_CONTEXT = 501,\r\n /**\r\n Permissions denied by user\r\n */\r\n PERMISSION_DENIED = 1000,\r\n /**\r\n * Network issue\r\n */\r\n NETWORK_ERROR = 2000,\r\n /**\r\n * Underlying hardware doesn't support the capability\r\n */\r\n NO_HW_SUPPORT = 3000,\r\n /**\r\n * One or more arguments are invalid\r\n */\r\n INVALID_ARGUMENTS = 4000,\r\n /**\r\n * User is not authorized for this operation\r\n */\r\n UNAUTHORIZED_USER_OPERATION = 5000,\r\n /**\r\n * Could not complete the operation due to insufficient resources\r\n */\r\n INSUFFICIENT_RESOURCES = 6000,\r\n /**\r\n * Platform throttled the request because of API was invoked too frequently\r\n */\r\n THROTTLE = 7000,\r\n /**\r\n * User aborted the operation\r\n */\r\n USER_ABORT = 8000,\r\n /**\r\n * Could not complete the operation in the given time interval\r\n */\r\n OPERATION_TIMED_OUT = 8001,\r\n /**\r\n * Platform code is old and doesn't implement this API\r\n */\r\n OLD_PLATFORM = 9000,\r\n /**\r\n * The file specified was not found on the given location\r\n */\r\n FILE_NOT_FOUND = 404,\r\n /**\r\n * The return value is too big and has exceeded our size boundries\r\n */\r\n SIZE_EXCEEDED = 10000,\r\n}\r\n","/* eslint-disable @typescript-eslint/ban-types */\r\n/* eslint-disable @typescript-eslint/no-unused-vars */\r\nimport * as uuid from 'uuid';\r\n\r\nimport { GlobalVars } from '../internal/globalVars';\r\nimport { SdkError } from '../public/interfaces';\r\nimport { pages } from '../public/pages';\r\nimport { validOrigins } from './constants';\r\n\r\n/**\r\n * @param pattern - reference pattern\r\n * @param host - candidate string\r\n * @returns returns true if host matches pre-know valid pattern\r\n *\r\n * @example\r\n * validateHostAgainstPattern('*.teams.microsoft.com', 'subdomain.teams.microsoft.com') returns true\r\n * validateHostAgainstPattern('teams.microsoft.com', 'team.microsoft.com') returns false\r\n *\r\n * @internal\r\n */\r\nfunction validateHostAgainstPattern(pattern: string, host: string): boolean {\r\n if (pattern.substring(0, 2) === '*.') {\r\n const suffix = pattern.substring(1);\r\n if (\r\n host.length > suffix.length &&\r\n host.split('.').length === suffix.split('.').length &&\r\n host.substring(host.length - suffix.length) === suffix\r\n ) {\r\n return true;\r\n }\r\n } else if (pattern === host) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**@internal */\r\nexport function validateOrigin(messageOrigin: URL): boolean {\r\n // Check whether the url is in the pre-known allowlist or supplied by user\r\n if (messageOrigin.protocol !== 'https:') {\r\n return false;\r\n }\r\n const messageOriginHost = messageOrigin.host;\r\n\r\n if (validOrigins.some(pattern => validateHostAgainstPattern(pattern, messageOriginHost))) {\r\n return true;\r\n }\r\n\r\n for (const domainOrPattern of GlobalVars.additionalValidOrigins) {\r\n const pattern = domainOrPattern.substring(0, 8) === 'https://' ? domainOrPattern.substring(8) : domainOrPattern;\r\n if (validateHostAgainstPattern(pattern, messageOriginHost)) {\r\n return true;\r\n }\r\n }\r\n\r\n return false;\r\n}\r\n\r\n/**@internal */\r\nexport function getGenericOnCompleteHandler(errorMessage?: string): (success: boolean, reason?: string) => void {\r\n return (success: boolean, reason: string): void => {\r\n if (!success) {\r\n throw new Error(errorMessage ? errorMessage : reason);\r\n }\r\n };\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Compares SDK versions.\r\n *\r\n * @param v1 - first version\r\n * @param v2 - second version\r\n * @returns NaN in case inputs are not in right format\r\n * -1 if v1 < v2\r\n * 1 if v1 > v2\r\n * 0 otherwise\r\n * @example\r\n * compareSDKVersions('1.2', '1.2.0') returns 0\r\n * compareSDKVersions('1.2a', '1.2b') returns NaN\r\n * compareSDKVersions('1.2', '1.3') returns -1\r\n * compareSDKVersions('2.0', '1.3.2') returns 1\r\n * compareSDKVersions('2.0', 2.0) returns NaN\r\n *\r\n * @internal\r\n */\r\nexport function compareSDKVersions(v1: string, v2: string): number {\r\n if (typeof v1 !== 'string' || typeof v2 !== 'string') {\r\n return NaN;\r\n }\r\n\r\n const v1parts = v1.split('.');\r\n const v2parts = v2.split('.');\r\n\r\n function isValidPart(x: string): boolean {\r\n // input has to have one or more digits\r\n // For ex - returns true for '11', false for '1a1', false for 'a', false for '2b'\r\n return /^\\d+$/.test(x);\r\n }\r\n\r\n if (!v1parts.every(isValidPart) || !v2parts.every(isValidPart)) {\r\n return NaN;\r\n }\r\n\r\n // Make length of both parts equal\r\n while (v1parts.length < v2parts.length) {\r\n v1parts.push('0');\r\n }\r\n while (v2parts.length < v1parts.length) {\r\n v2parts.push('0');\r\n }\r\n\r\n for (let i = 0; i < v1parts.length; ++i) {\r\n if (Number(v1parts[i]) == Number(v2parts[i])) {\r\n continue;\r\n } else if (Number(v1parts[i]) > Number(v2parts[i])) {\r\n return 1;\r\n } else {\r\n return -1;\r\n }\r\n }\r\n return 0;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Generates a GUID\r\n *\r\n * @internal\r\n */\r\nexport function generateGUID(): string {\r\n return uuid.v4();\r\n}\r\n\r\nexport function deepFreeze<T extends object>(obj: T): T {\r\n Object.keys(obj).forEach(prop => {\r\n if (typeof obj[prop] === 'object') {\r\n deepFreeze(obj[prop]);\r\n }\r\n });\r\n return Object.freeze(obj);\r\n}\r\n\r\n/**\r\n * @hidden\r\n * The following type definitions will be used in the\r\n * utility functions below, which help in transforming the\r\n * promises to support callbacks for backward compatibility\r\n *\r\n * @internal\r\n */\r\nexport type ErrorResultCallback<T> = (err?: SdkError, result?: T) => void;\r\nexport type ErrorResultNullCallback<T> = (err: SdkError | null, result: T | null) => void;\r\nexport type ErrorBooleanResultCallback = (err?: SdkError, result?: boolean) => void;\r\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\r\nexport type InputFunction<T> = (...args: any[]) => Promise<T>;\r\nexport type ResultCallback<T> = (result?: T) => void;\r\nexport type SdkErrorCallback = ResultCallback<SdkError | null>;\r\n\r\n/**\r\n * This utility function is used when the result of the promise is same as the result in the callback.\r\n * @param funcHelper\r\n * @param callback\r\n * @param args\r\n * @returns\r\n *\r\n * @internal\r\n */\r\nexport function callCallbackWithErrorOrResultFromPromiseAndReturnPromise<T>(\r\n funcHelper: InputFunction<T>,\r\n callback?: ErrorResultCallback<T>,\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n ...args: any[]\r\n): Promise<T> {\r\n const p = funcHelper(...args);\r\n p.then((result: T) => {\r\n if (callback) {\r\n callback(undefined, result);\r\n }\r\n }).catch((e: SdkError) => {\r\n if (callback) {\r\n callback(e);\r\n }\r\n });\r\n return p;\r\n}\r\n\r\n/**\r\n * This utility function is used when the return type of the promise is usually void and\r\n * the result in the callback is a boolean type (true for success and false for error)\r\n * @param funcHelper\r\n * @param callback\r\n * @param args\r\n * @returns\r\n * @internal\r\n */\r\nexport function callCallbackWithErrorOrBooleanFromPromiseAndReturnPromise<T>(\r\n funcHelper: InputFunction<T>,\r\n callback?: ErrorBooleanResultCallback,\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n ...args: any[]\r\n): Promise<T> {\r\n const p = funcHelper(...args);\r\n p.then(() => {\r\n if (callback) {\r\n callback(undefined, true);\r\n }\r\n }).catch((e: SdkError) => {\r\n if (callback) {\r\n callback(e, false);\r\n }\r\n });\r\n return p;\r\n}\r\n\r\n/**\r\n * This utility function is called when the callback has only Error/SdkError as the primary argument.\r\n * @param funcHelper\r\n * @param callback\r\n * @param args\r\n * @returns\r\n * @internal\r\n */\r\nexport function callCallbackWithSdkErrorFromPromiseAndReturnPromise<T>(\r\n funcHelper: InputFunction<T>,\r\n callback?: SdkErrorCallback,\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n ...args: any[]\r\n): Promise<T> {\r\n const p = funcHelper(...args);\r\n p.then(() => {\r\n if (callback) {\r\n callback(null);\r\n }\r\n }).catch((e: SdkError) => {\r\n if (callback) {\r\n callback(e);\r\n }\r\n });\r\n return p;\r\n}\r\n\r\n/**\r\n * This utility function is used when the result of the promise is same as the result in the callback.\r\n * @param funcHelper\r\n * @param callback\r\n * @param args\r\n * @returns\r\n *\r\n * @internal\r\n */\r\nexport function callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<T>(\r\n funcHelper: InputFunction<T>,\r\n callback?: ErrorResultNullCallback<T>,\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n ...args: any[]\r\n): Promise<T> {\r\n const p = funcHelper(...args);\r\n p.then((result: T) => {\r\n if (callback) {\r\n callback(null, result);\r\n }\r\n }).catch((e: SdkError) => {\r\n if (callback) {\r\n callback(e, null);\r\n }\r\n });\r\n return p;\r\n}\r\n\r\n/**\r\n * A helper function to add a timeout to an asynchronous operation.\r\n *\r\n * @param action Action to wrap the timeout around\r\n * @param timeoutInMs Timeout period in milliseconds\r\n * @param timeoutError Error to reject the promise with if timeout elapses before the action completed\r\n * @returns A promise which resolves to the result of provided action or rejects with a provided timeout error\r\n * if the initial action didn't complete within provided timeout.\r\n *\r\n * @internal\r\n */\r\nexport function runWithTimeout<TResult, TError>(\r\n action: () => Promise<TResult>,\r\n timeoutInMs: number,\r\n timeoutError: TError,\r\n): Promise<TResult> {\r\n return new Promise((resolve, reject) => {\r\n const timeoutHandle = setTimeout(reject, timeoutInMs, timeoutError);\r\n action()\r\n .then(result => {\r\n clearTimeout(timeoutHandle);\r\n resolve(result);\r\n })\r\n .catch(error => {\r\n clearTimeout(timeoutHandle);\r\n reject(error);\r\n });\r\n });\r\n}\r\n\r\nexport function createTeamsAppLink(params: pages.NavigateToAppParams): string {\r\n const url = new URL(\r\n 'https://teams.microsoft.com/l/entity/' +\r\n encodeURIComponent(params.appId) +\r\n '/' +\r\n encodeURIComponent(params.pageId),\r\n );\r\n\r\n if (params.webUrl) {\r\n url.searchParams.append('webUrl', params.webUrl);\r\n }\r\n if (params.channelId || params.subPageId) {\r\n url.searchParams.append('context', JSON.stringify({ channelId: params.channelId, subEntityId: params.subPageId }));\r\n }\r\n return url.toString();\r\n}\r\n","import { HostClientType } from '../public/constants';\r\nimport { ErrorCode, SdkError } from '../public/interfaces';\r\nimport { defaultSDKVersionForCompatCheck, userOriginUrlValidationRegExp } from './constants';\r\nimport { GlobalVars } from './globalVars';\r\nimport { compareSDKVersions } from './utils';\r\n\r\n/** @internal */\r\nexport function ensureInitialized(...expectedFrameContexts: string[]): void {\r\n if (!GlobalVars.initializeCalled) {\r\n throw new Error('The library has not yet been initialized');\r\n }\r\n\r\n if (GlobalVars.frameContext && expectedFrameContexts && expectedFrameContexts.length > 0) {\r\n let found = false;\r\n for (let i = 0; i < expectedFrameContexts.length; i++) {\r\n if (expectedFrameContexts[i] === GlobalVars.frameContext) {\r\n found = true;\r\n break;\r\n }\r\n }\r\n\r\n if (!found) {\r\n throw new Error(\r\n `This call is only allowed in following contexts: ${JSON.stringify(expectedFrameContexts)}. ` +\r\n `Current context: \"${GlobalVars.frameContext}\".`,\r\n );\r\n }\r\n }\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Checks whether the platform has knowledge of this API by doing a comparison\r\n * on API required version and platform supported version of the SDK\r\n *\r\n * @param requiredVersion - SDK version required by the API\r\n *\r\n * @internal\r\n */\r\nexport function isCurrentSDKVersionAtLeast(requiredVersion: string = defaultSDKVersionForCompatCheck): boolean {\r\n const value = compareSDKVersions(GlobalVars.clientSupportedSDKVersion, requiredVersion);\r\n if (isNaN(value)) {\r\n return false;\r\n }\r\n return value >= 0;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Helper function to identify if host client is either android or ios\r\n *\r\n * @internal\r\n */\r\nexport function isHostClientMobile(): boolean {\r\n return GlobalVars.hostClientType == HostClientType.android || GlobalVars.hostClientType == HostClientType.ios;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Helper function which indicates if current API is supported on mobile or not.\r\n * @throws SdkError if host client is not android/ios or if the requiredVersion is not\r\n * supported by platform or not. Null is returned in case of success.\r\n *\r\n * @internal\r\n */\r\nexport function throwExceptionIfMobileApiIsNotSupported(\r\n requiredVersion: string = defaultSDKVersionForCompatCheck,\r\n): void {\r\n if (!isHostClientMobile()) {\r\n const notSupportedError: SdkError = { errorCode: ErrorCode.NOT_SUPPORTED_ON_PLATFORM };\r\n throw notSupportedError;\r\n } else if (!isCurrentSDKVersionAtLeast(requiredVersion)) {\r\n const oldPlatformError: SdkError = { errorCode: ErrorCode.OLD_PLATFORM };\r\n throw oldPlatformError;\r\n }\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Processes the valid origins specifuied by the user, de-duplicates and converts them into a regexp\r\n * which is used later for message source/origin validation\r\n *\r\n * @internal\r\n */\r\nexport function processAdditionalValidOrigins(validMessageOrigins: string[]): void {\r\n let combinedOriginUrls = GlobalVars.additionalValidOrigins.concat(\r\n validMessageOrigins.filter((_origin: string) => {\r\n return typeof _origin === 'string' && userOriginUrlValidationRegExp.test(_origin);\r\n }),\r\n );\r\n const dedupUrls: { [url: string]: boolean } = {};\r\n combinedOriginUrls = combinedOriginUrls.filter(_originUrl => {\r\n if (dedupUrls[_originUrl]) {\r\n return false;\r\n }\r\n dedupUrls[_originUrl] = true;\r\n return true;\r\n });\r\n GlobalVars.additionalValidOrigins = combinedOriginUrls;\r\n}\r\n","/* eslint-disable @typescript-eslint/ban-types */\r\n\r\nimport { deepFreeze } from '../internal/utils';\r\nexport interface IRuntime {\r\n readonly apiVersion: number;\r\n readonly isLegacyTeams?: boolean;\r\n readonly supports: {\r\n readonly appInstallDialog?: {};\r\n readonly appEntity?: {};\r\n readonly bot?: {};\r\n readonly calendar?: {};\r\n readonly call?: {};\r\n readonly chat?: {};\r\n readonly dialog?: {};\r\n readonly files?: {};\r\n readonly location?: {};\r\n readonly logs?: {};\r\n readonly mail?: {};\r\n readonly media?: {};\r\n readonly meeting?: {};\r\n readonly meetingRoom?: {};\r\n readonly menus?: {};\r\n readonly monetization?: {};\r\n readonly notifications?: {};\r\n readonly pages?: {\r\n readonly appButton?: {};\r\n readonly tabs?: {};\r\n readonly config?: {};\r\n readonly backStack?: {};\r\n readonly fullTrust?: {};\r\n };\r\n readonly people?: {};\r\n readonly remoteCamera?: {};\r\n readonly sharing?: {};\r\n readonly teams?: {\r\n readonly fullTrust?: {};\r\n };\r\n readonly teamsCore?: {};\r\n readonly video?: {};\r\n };\r\n}\r\n\r\nexport let runtime: IRuntime = {\r\n apiVersion: 1,\r\n supports: {\r\n appInstallDialog: undefined,\r\n bot: undefined,\r\n calendar: undefined,\r\n call: undefined,\r\n chat: undefined,\r\n dialog: undefined,\r\n location: undefined,\r\n logs: undefined,\r\n mail: undefined,\r\n media: undefined,\r\n meeting: undefined,\r\n meetingRoom: undefined,\r\n menus: undefined,\r\n monetization: undefined,\r\n notifications: undefined,\r\n pages: {\r\n appButton: undefined,\r\n tabs: undefined,\r\n config: undefined,\r\n backStack: undefined,\r\n fullTrust: undefined,\r\n },\r\n people: undefined,\r\n remoteCamera: undefined,\r\n sharing: undefined,\r\n teams: {\r\n fullTrust: undefined,\r\n },\r\n teamsCore: undefined,\r\n video: undefined,\r\n },\r\n};\r\n\r\nexport const teamsRuntimeConfig: IRuntime = {\r\n apiVersion: 1,\r\n isLegacyTeams: true,\r\n supports: {\r\n appInstallDialog: {},\r\n appEntity: {},\r\n bot: {},\r\n call: {},\r\n chat: {},\r\n dialog: {},\r\n files: {},\r\n location: {},\r\n logs: {},\r\n media: {},\r\n meeting: {},\r\n meetingRoom: {},\r\n menus: {},\r\n monetization: {},\r\n notifications: {},\r\n pages: {\r\n appButton: {},\r\n tabs: {},\r\n config: {},\r\n backStack: {},\r\n fullTrust: {},\r\n },\r\n people: {},\r\n remoteCamera: {},\r\n sharing: {},\r\n teams: {\r\n fullTrust: {},\r\n },\r\n teamsCore: {},\r\n video: {},\r\n },\r\n};\r\n\r\nexport function applyRuntimeConfig(runtimeConfig: IRuntime): void {\r\n runtime = deepFreeze(runtimeConfig);\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { registerHandler, removeHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { runtime } from '../public/runtime';\r\n\r\n/**\r\n * @hidden\r\n * Namespace to interact with the logging part of the SDK.\r\n * This object is used to send the app logs on demand to the host client\r\n *\r\n * Hide from docs\r\n *\r\n * @internal\r\n */\r\nexport namespace logs {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Registers a handler for getting app log\r\n *\r\n * @param handler - The handler to invoke to get the app log\r\n */\r\n export function registerGetLogHandler(handler: () => string): void {\r\n ensureInitialized();\r\n\r\n if (handler) {\r\n registerHandler('log.request', () => {\r\n const log: string = handler();\r\n sendMessageToParent('log.receive', [log]);\r\n });\r\n } else {\r\n removeHandler('log.request');\r\n }\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.logs ? true : false;\r\n }\r\n}\r\n","import {\r\n Communication,\r\n sendMessageEventToChild,\r\n sendMessageToParent,\r\n sendMessageToParentAsync,\r\n waitForMessageQueue,\r\n} from '../internal/communication';\r\nimport { GlobalVars } from '../internal/globalVars';\r\nimport { registerHandler, removeHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts, HostClientType } from './constants';\r\n\r\n/**\r\n * Namespace to interact with the authentication-specific part of the SDK.\r\n *\r\n * This object is used for starting or completing authentication flows.\r\n *\r\n * @beta\r\n */\r\nexport namespace authentication {\r\n let authHandlers: { success: (string) => void; fail: (string) => void };\r\n let authWindowMonitor: number;\r\n\r\n export function initialize(): void {\r\n registerHandler('authentication.authenticate.success', handleSuccess, false);\r\n registerHandler('authentication.authenticate.failure', handleFailure, false);\r\n }\r\n\r\n let authParams: AuthenticateParameters;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1.\r\n *\r\n * Registers the authentication Communication.handlers\r\n *\r\n * @param authenticateParameters - A set of values that configure the authentication pop-up.\r\n */\r\n export function registerAuthenticationHandlers(authenticateParameters: AuthenticateParameters): void {\r\n authParams = authenticateParameters;\r\n }\r\n\r\n /**\r\n * Initiates an authentication request, which opens a new window with the specified settings.\r\n *\r\n * @param authenticateParameters - The parameters for the authentication request. It is a required parameter since v2 upgrade\r\n *\r\n * @returns Promise that will be fulfilled with the result from the authentication pop-up if successful.\r\n *\r\n * @throws if the authentication request fails or is canceled by the user.\r\n *\r\n */\r\n export function authenticate(authenticateParameters: AuthenticatePopUpParameters): Promise<string>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link authentication.authenticate authentication.authenticate(authenticateParameters: AuthenticatePopUpParameters): Promise\\<string\\>} instead.\r\n *\r\n * Initiates an authentication request, which opens a new window with the specified settings.\r\n *\r\n * @param authenticateParameters - The parameters for the authentication request.\r\n *\r\n */\r\n export function authenticate(authenticateParameters?: AuthenticateParameters): void;\r\n export function authenticate(authenticateParameters?: AuthenticateParameters): Promise<string> {\r\n const isDifferentParamsInCall: boolean = authenticateParameters !== undefined;\r\n const authenticateParams: AuthenticateParameters = isDifferentParamsInCall ? authenticateParameters : authParams;\r\n if (!authenticateParams) {\r\n throw new Error('No parameters are provided for authentication');\r\n }\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.settings,\r\n FrameContexts.remove,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n return authenticateHelper(authenticateParams)\r\n .then((value: string) => {\r\n try {\r\n if (authenticateParams && authenticateParams.successCallback) {\r\n authenticateParams.successCallback(value);\r\n return '';\r\n }\r\n return value;\r\n } finally {\r\n if (!isDifferentParamsInCall) {\r\n authParams = null;\r\n }\r\n }\r\n })\r\n .catch((err: Error) => {\r\n try {\r\n if (authenticateParams && authenticateParams.failureCallback) {\r\n authenticateParams.failureCallback(err.message);\r\n return '';\r\n }\r\n throw err;\r\n } finally {\r\n if (!isDifferentParamsInCall) {\r\n authParams = null;\r\n }\r\n }\r\n });\r\n }\r\n\r\n function authenticateHelper(authenticateParameters: AuthenticateParameters): Promise<string> {\r\n return new Promise<string>((resolve, reject) => {\r\n if (\r\n GlobalVars.hostClientType === HostClientType.desktop ||\r\n GlobalVars.hostClientType === HostClientType.android ||\r\n GlobalVars.hostClientType === HostClientType.ios ||\r\n GlobalVars.hostClientType === HostClientType.rigel ||\r\n GlobalVars.hostClientType === HostClientType.teamsRoomsWindows ||\r\n GlobalVars.hostClientType === HostClientType.teamsRoomsAndroid ||\r\n GlobalVars.hostClientType === HostClientType.teamsPhones ||\r\n GlobalVars.hostClientType === HostClientType.teamsDisplays\r\n ) {\r\n // Convert any relative URLs into absolute URLs before sending them over to the parent window.\r\n const link = document.createElement('a');\r\n link.href = authenticateParameters.url;\r\n // Ask the parent window to open an authentication window with the parameters provided by the caller.\r\n resolve(\r\n sendMessageToParentAsync<[boolean, string]>('authentication.authenticate', [\r\n link.href,\r\n authenticateParameters.width,\r\n authenticateParameters.height,\r\n authenticateParameters.isExternal,\r\n ]).then(([success, response]: [boolean, string]) => {\r\n if (success) {\r\n return response;\r\n } else {\r\n throw new Error(response);\r\n }\r\n }),\r\n );\r\n } else {\r\n // Open an authentication window with the parameters provided by the caller.\r\n authHandlers = {\r\n success: resolve,\r\n fail: reject,\r\n };\r\n openAuthenticationWindow(authenticateParameters);\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * Requests an Azure AD token to be issued on behalf of the app. The token is acquired from the cache\r\n * if it is not expired. Otherwise a request is sent to Azure AD to obtain a new token.\r\n *\r\n * @param authTokenRequest - An optional set of values that configure the token request.\r\n *\r\n * @returns Promise that will be fulfilled with the token if successful.\r\n */\r\n export function getAuthToken(authTokenRequest?: AuthTokenRequestParameters): Promise<string>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link authentication.getAuthToken authentication.getAuthToken(authTokenRequest: AuthTokenRequestParameters): Promise\\<string\\>} instead.\r\n *\r\n * Requests an Azure AD token to be issued on behalf of the app. The token is acquired from the cache\r\n * if it is not expired. Otherwise a request is sent to Azure AD to obtain a new token.\r\n *\r\n * @param authTokenRequest - An optional set of values that configure the token request.\r\n * It contains callbacks to call in case of success/failure\r\n */\r\n export function getAuthToken(authTokenRequest?: AuthTokenRequest): void;\r\n export function getAuthToken(authTokenRequest?: AuthTokenRequest): Promise<string> {\r\n ensureInitialized();\r\n return getAuthTokenHelper(authTokenRequest)\r\n .then((value: string) => {\r\n if (authTokenRequest && authTokenRequest.successCallback) {\r\n authTokenRequest.successCallback(value);\r\n return '';\r\n }\r\n return value;\r\n })\r\n .catch((err: Error) => {\r\n if (authTokenRequest && authTokenRequest.failureCallback) {\r\n authTokenRequest.failureCallback(err.message);\r\n return '';\r\n }\r\n throw err;\r\n });\r\n }\r\n\r\n function getAuthTokenHelper(authTokenRequest?: AuthTokenRequest): Promise<string> {\r\n return new Promise<[boolean, string]>(resolve => {\r\n resolve(\r\n sendMessageToParentAsync('authentication.getAuthToken', [\r\n authTokenRequest?.resources,\r\n authTokenRequest?.claims,\r\n authTokenRequest?.silent,\r\n ]),\r\n );\r\n }).then(([success, result]: [boolean, string]) => {\r\n if (success) {\r\n return result;\r\n } else {\r\n throw new Error(result);\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Requests the decoded Azure AD user identity on behalf of the app.\r\n *\r\n * @returns Promise that resolves with the {@link UserProfile}.\r\n *\r\n * @internal\r\n */\r\n export function getUser(): Promise<UserProfile>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link authentication.getUser authentication.getUser(): Promise\\<UserProfile\\>} instead.\r\n *\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Requests the decoded Azure AD user identity on behalf of the app.\r\n *\r\n * @param userRequest - It passes success/failure callbacks in the userRequest object(deprecated)\r\n * @internal\r\n */\r\n export function getUser(userRequest: UserRequest): void;\r\n export function getUser(userRequest?: UserRequest): Promise<UserProfile> {\r\n ensureInitialized();\r\n return getUserHelper()\r\n .then((value: UserProfile) => {\r\n if (userRequest && userRequest.successCallback) {\r\n userRequest.successCallback(value);\r\n return null;\r\n }\r\n return value;\r\n })\r\n .catch((err: Error) => {\r\n if (userRequest && userRequest.failureCallback) {\r\n userRequest.failureCallback(err.message);\r\n return null;\r\n }\r\n throw err;\r\n });\r\n }\r\n\r\n function getUserHelper(): Promise<UserProfile> {\r\n return new Promise<[boolean, UserProfile | string]>(resolve => {\r\n resolve(sendMessageToParentAsync('authentication.getUser'));\r\n }).then(([success, result]: [boolean, UserProfile | string]) => {\r\n if (success) {\r\n return result as UserProfile;\r\n } else {\r\n throw new Error(result as string);\r\n }\r\n });\r\n }\r\n\r\n function closeAuthenticationWindow(): void {\r\n // Stop monitoring the authentication window\r\n stopAuthenticationWindowMonitor();\r\n // Try to close the authentication window and clear all properties associated with it\r\n try {\r\n if (Communication.childWindow) {\r\n Communication.childWindow.close();\r\n }\r\n } finally {\r\n Communication.childWindow = null;\r\n Communication.childOrigin = null;\r\n }\r\n }\r\n\r\n function openAuthenticationWindow(authenticateParameters: AuthenticateParameters): void {\r\n // Close the previously opened window if we have one\r\n closeAuthenticationWindow();\r\n // Start with a sensible default size\r\n let width = authenticateParameters.width || 600;\r\n let height = authenticateParameters.height || 400;\r\n // Ensure that the new window is always smaller than our app's window so that it never fully covers up our app\r\n width = Math.min(width, Communication.currentWindow.outerWidth - 400);\r\n height = Math.min(height, Communication.currentWindow.outerHeight - 200);\r\n // Convert any relative URLs into absolute URLs before sending them over to the parent window\r\n const link = document.createElement('a');\r\n link.href = authenticateParameters.url.replace('{oauthRedirectMethod}', 'web');\r\n // We are running in the browser, so we need to center the new window ourselves\r\n let left: number =\r\n typeof Communication.currentWindow.screenLeft !== 'undefined'\r\n ? Communication.currentWindow.screenLeft\r\n : Communication.currentWindow.screenX;\r\n let top: number =\r\n typeof Communication.currentWindow.screenTop !== 'undefined'\r\n ? Communication.currentWindow.screenTop\r\n : Communication.currentWindow.screenY;\r\n left += Communication.currentWindow.outerWidth / 2 - width / 2;\r\n top += Communication.currentWindow.outerHeight / 2 - height / 2;\r\n // Open a child window with a desired set of standard browser features\r\n Communication.childWindow = Communication.currentWindow.open(\r\n link.href,\r\n '_blank',\r\n 'toolbar=no, location=yes, status=no, menubar=no, scrollbars=yes, top=' +\r\n top +\r\n ', left=' +\r\n left +\r\n ', width=' +\r\n width +\r\n ', height=' +\r\n height,\r\n );\r\n if (Communication.childWindow) {\r\n // Start monitoring the authentication window so that we can detect if it gets closed before the flow completes\r\n startAuthenticationWindowMonitor();\r\n } else {\r\n // If we failed to open the window, fail the authentication flow\r\n handleFailure('FailedToOpenWindow');\r\n }\r\n }\r\n\r\n function stopAuthenticationWindowMonitor(): void {\r\n if (authWindowMonitor) {\r\n clearInterval(authWindowMonitor);\r\n authWindowMonitor = 0;\r\n }\r\n removeHandler('initialize');\r\n removeHandler('navigateCrossDomain');\r\n }\r\n\r\n function startAuthenticationWindowMonitor(): void {\r\n // Stop the previous window monitor if one is running\r\n stopAuthenticationWindowMonitor();\r\n // Create an interval loop that\r\n // - Notifies the caller of failure if it detects that the authentication window is closed\r\n // - Keeps pinging the authentication window while it is open to re-establish\r\n // contact with any pages along the authentication flow that need to communicate\r\n // with us\r\n authWindowMonitor = Communication.currentWindow.setInterval(() => {\r\n if (!Communication.childWindow || Communication.childWindow.closed) {\r\n handleFailure('CancelledByUser');\r\n } else {\r\n const savedChildOrigin = Communication.childOrigin;\r\n try {\r\n Communication.childOrigin = '*';\r\n sendMessageEventToChild('ping');\r\n } finally {\r\n Communication.childOrigin = savedChildOrigin;\r\n }\r\n }\r\n }, 100);\r\n // Set up an initialize-message handler that gives the authentication window its frame context\r\n registerHandler('initialize', () => {\r\n return [FrameContexts.authentication, GlobalVars.hostClientType];\r\n });\r\n // Set up a navigateCrossDomain message handler that blocks cross-domain re-navigation attempts\r\n // in the authentication window. We could at some point choose to implement this method via a call to\r\n // authenticationWindow.location.href = url; however, we would first need to figure out how to\r\n // validate the URL against the tab's list of valid domains.\r\n registerHandler('navigateCrossDomain', () => {\r\n return false;\r\n });\r\n }\r\n\r\n /**\r\n * Notifies the frame that initiated this authentication request that the request was successful.\r\n *\r\n * @remarks\r\n * This function is usable only on the authentication window.\r\n * This call causes the authentication window to be closed.\r\n *\r\n * @param result - Specifies a result for the authentication. If specified, the frame that initiated the authentication pop-up receives this value in its callback.\r\n * @param callbackUrl - Specifies the url to redirect back to if the client is Win32 Outlook.\r\n */\r\n export function notifySuccess(result?: string, callbackUrl?: string): void {\r\n redirectIfWin32Outlook(callbackUrl, 'result', result);\r\n ensureInitialized(FrameContexts.authentication);\r\n sendMessageToParent('authentication.authenticate.success', [result]);\r\n // Wait for the message to be sent before closing the window\r\n waitForMessageQueue(Communication.parentWindow, () => setTimeout(() => Communication.currentWindow.close(), 200));\r\n }\r\n\r\n /**\r\n * Notifies the frame that initiated this authentication request that the request failed.\r\n *\r\n * @remarks\r\n * This function is usable only on the authentication window.\r\n * This call causes the authentication window to be closed.\r\n *\r\n * @param result - Specifies a result for the authentication. If specified, the frame that initiated the authentication pop-up receives this value in its callback.\r\n * @param callbackUrl - Specifies the url to redirect back to if the client is Win32 Outlook.\r\n */\r\n export function notifyFailure(reason?: string, callbackUrl?: string): void {\r\n redirectIfWin32Outlook(callbackUrl, 'reason', reason);\r\n ensureInitialized(FrameContexts.authentication);\r\n sendMessageToParent('authentication.authenticate.failure', [reason]);\r\n // Wait for the message to be sent before closing the window\r\n waitForMessageQueue(Communication.parentWindow, () => setTimeout(() => Communication.currentWindow.close(), 200));\r\n }\r\n\r\n function handleSuccess(result?: string): void {\r\n try {\r\n if (authHandlers) {\r\n authHandlers.success(result);\r\n }\r\n } finally {\r\n authHandlers = null;\r\n closeAuthenticationWindow();\r\n }\r\n }\r\n\r\n function handleFailure(reason?: string): void {\r\n try {\r\n if (authHandlers) {\r\n authHandlers.fail(new Error(reason));\r\n }\r\n } finally {\r\n authHandlers = null;\r\n closeAuthenticationWindow();\r\n }\r\n }\r\n\r\n /**\r\n * Validates that the callbackUrl param is a valid connector url, appends the result/reason and authSuccess/authFailure as URL fragments and redirects the window\r\n * @param callbackUrl - the connectors url to redirect to\r\n * @param key - \"result\" in case of success and \"reason\" in case of failure\r\n * @param value - the value of the passed result/reason parameter\r\n */\r\n function redirectIfWin32Outlook(callbackUrl?: string, key?: string, value?: string): void {\r\n if (callbackUrl) {\r\n const link = document.createElement('a');\r\n link.href = decodeURIComponent(callbackUrl);\r\n if (\r\n link.host &&\r\n link.host !== window.location.host &&\r\n link.host === 'outlook.office.com' &&\r\n link.search.indexOf('client_type=Win32_Outlook') > -1\r\n ) {\r\n if (key && key === 'result') {\r\n if (value) {\r\n link.href = updateUrlParameter(link.href, 'result', value);\r\n }\r\n Communication.currentWindow.location.assign(updateUrlParameter(link.href, 'authSuccess', ''));\r\n }\r\n if (key && key === 'reason') {\r\n if (value) {\r\n link.href = updateUrlParameter(link.href, 'reason', value);\r\n }\r\n Communication.currentWindow.location.assign(updateUrlParameter(link.href, 'authFailure', ''));\r\n }\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Appends either result or reason as a fragment to the 'callbackUrl'\r\n * @param uri - the url to modify\r\n * @param key - the fragment key\r\n * @param value - the fragment value\r\n */\r\n function updateUrlParameter(uri: string, key: string, value: string): string {\r\n const i = uri.indexOf('#');\r\n let hash = i === -1 ? '#' : uri.substr(i);\r\n hash = hash + '&' + key + (value !== '' ? '=' + value : '');\r\n uri = i === -1 ? uri : uri.substr(0, i);\r\n return uri + hash;\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1.\r\n */\r\n export interface LegacyCallBacks {\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1.\r\n * A function that is called if the request succeeds.\r\n */\r\n successCallback?: (result: string) => void;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1.\r\n * A function that is called if the request fails, with the reason for the failure.\r\n */\r\n failureCallback?: (reason: string) => void;\r\n }\r\n\r\n export interface AuthenticatePopUpParameters {\r\n /**\r\n * The URL for the authentication pop-up.\r\n */\r\n url: string;\r\n /**\r\n * The preferred width for the pop-up. This value can be ignored if outside the acceptable bounds.\r\n */\r\n width?: number;\r\n /**\r\n * The preferred height for the pop-up. This value can be ignored if outside the acceptable bounds.\r\n */\r\n height?: number;\r\n /**\r\n * The flag which indicates whether the auth page should be opened in an external browser. This flag has no effect on the web client.\r\n */\r\n isExternal?: boolean;\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link AuthenticatePopUpParameters} instead.\r\n */\r\n export type AuthenticateParameters = AuthenticatePopUpParameters & LegacyCallBacks;\r\n\r\n export interface AuthTokenRequestParameters {\r\n /**\r\n * An optional list of resource for which to acquire the access token; only used for full trust apps.\r\n */\r\n resources?: string[];\r\n /**\r\n * An optional list of claims which to pass to AAD when requesting the access token.\r\n */\r\n claims?: string[];\r\n /**\r\n * An optional flag indicating whether to attempt the token acquisition silently or allow a prompt to be shown.\r\n */\r\n silent?: boolean;\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link AuthTokenRequestParameters} instead.\r\n */\r\n export type AuthTokenRequest = AuthTokenRequestParameters & LegacyCallBacks;\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n *\r\n * @internal\r\n */\r\n export interface UserProfile {\r\n /**\r\n * @hidden\r\n * The intended recipient of the token. The application that receives the token must verify that the audience\r\n * value is correct and reject any tokens intended for a different audience.\r\n */\r\n aud: string;\r\n /**\r\n * @hidden\r\n * Identifies how the subject of the token was authenticated.\r\n */\r\n amr: string[];\r\n /**\r\n * @hidden\r\n * Stores the time at which the token was issued. It is often used to measure token freshness.\r\n */\r\n iat: number;\r\n /**\r\n * @hidden\r\n * Identifies the security token service (STS) that constructs and returns the token. In the tokens that Azure AD\r\n * returns, the issuer is sts.windows.net. The GUID in the issuer claim value is the tenant ID of the Azure AD\r\n * directory. The tenant ID is an immutable and reliable identifier of the directory.\r\n */\r\n iss: string;\r\n /**\r\n * @hidden\r\n * Provides the last name, surname, or family name of the user as defined in the Azure AD user object.\r\n */\r\n family_name: string;\r\n /**\r\n * @hidden\r\n * Provides the first or \"given\" name of the user, as set on the Azure AD user object.\r\n */\r\n given_name: string;\r\n /**\r\n * @hidden\r\n * Provides a human-readable value that identifies the subject of the token. This value is not guaranteed to\r\n * be unique within a tenant and is designed to be used only for display purposes.\r\n */\r\n unique_name: string;\r\n /**\r\n * @hidden\r\n * Contains a unique identifier of an object in Azure AD. This value is immutable and cannot be reassigned or\r\n * reused. Use the object ID to identify an object in queries to Azure AD.\r\n */\r\n oid: string;\r\n /**\r\n * @hidden\r\n * Identifies the principal about which the token asserts information, such as the user of an application.\r\n * This value is immutable and cannot be reassigned or reused, so it can be used to perform authorization\r\n * checks safely. Because the subject is always present in the tokens the Azure AD issues, we recommended\r\n * using this value in a general-purpose authorization system.\r\n */\r\n sub: string;\r\n /**\r\n * @hidden\r\n * An immutable, non-reusable identifier that identifies the directory tenant that issued the token. You can\r\n * use this value to access tenant-specific directory resources in a multitenant application. For example,\r\n * you can use this value to identify the tenant in a call to the Graph API.\r\n */\r\n tid: string;\r\n /**\r\n * @hidden\r\n * Defines the end of the time interval within which a token is valid. The service that validates the token\r\n * should verify that the current date is within the token lifetime; otherwise it should reject the token. The\r\n * service might allow for up to five minutes beyond the token lifetime to account for any differences in clock\r\n * time (\"time skew\") between Azure AD and the service.\r\n */\r\n exp: number;\r\n /**\r\n * @hidden\r\n * Defines the start of the time interval within which a token is valid. The service that validates the token\r\n * should verify that the current date is within the token lifetime; otherwise it should reject the token. The\r\n * service might allow for up to five minutes beyond the token lifetime to account for any differences in clock\r\n * time (\"time skew\") between Azure AD and the service.\r\n */\r\n nbf: number;\r\n /**\r\n * @hidden\r\n * Stores the user name of the user principal.\r\n */\r\n upn: string;\r\n /**\r\n * @hidden\r\n * Stores the version number of the token.\r\n */\r\n ver: string;\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1.\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * @internal\r\n */\r\n export interface UserRequest {\r\n /**\r\n * A function that is called if the token request succeeds, with the resulting token.\r\n */\r\n successCallback?: (user: UserProfile) => void;\r\n /**\r\n * A function that is called if the token request fails, with the reason for the failure.\r\n */\r\n failureCallback?: (reason: string) => void;\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { runtime } from '../public/runtime';\r\n\r\n/**\r\n * Namespace to interact with the menu-specific part of the SDK.\r\n * This object is used to show View Configuration, Action Menu and Navigation Bar Menu.\r\n */\r\nexport namespace menus {\r\n /**\r\n * @hidden\r\n * Represents information about item in View Configuration.\r\n */\r\n export interface ViewConfiguration {\r\n /**\r\n * @hidden\r\n * Unique identifier of view.\r\n */\r\n id: string;\r\n /**\r\n * @hidden\r\n * Display title of the view.\r\n */\r\n title: string;\r\n /**\r\n * @hidden\r\n * Additional information for accessibility.\r\n */\r\n contentDescription?: string;\r\n }\r\n\r\n /**\r\n * Defines how a menu item should appear in the NavBar.\r\n */\r\n export enum DisplayMode {\r\n /**\r\n * Only place this item in the NavBar if there's room for it.\r\n * If there's no room, item is shown in the overflow menu.\r\n */\r\n ifRoom = 0,\r\n /**\r\n * Never place this item in the NavBar.\r\n * The item would always be shown in NavBar's overflow menu.\r\n */\r\n overflowOnly = 1,\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Represents information about menu item for Action Menu and Navigation Bar Menu.\r\n */\r\n export class MenuItem {\r\n /**\r\n * @hidden\r\n * Unique identifier for the menu item.\r\n */\r\n public id: string;\r\n /**\r\n * @hidden\r\n * Display title of the menu item.\r\n */\r\n public title: string;\r\n /**\r\n * @hidden\r\n * Display icon of the menu item. The icon value must be a string having SVG icon content.\r\n */\r\n public icon: string;\r\n /**\r\n * @hidden\r\n * Selected state display icon of the menu item. The icon value must be a string having SVG icon content.\r\n */\r\n public iconSelected?: string;\r\n /**\r\n * @hidden\r\n * Additional information for accessibility.\r\n */\r\n public contentDescription?: string;\r\n /**\r\n * @hidden\r\n * State of the menu item\r\n */\r\n public enabled = true;\r\n /**\r\n * @hidden\r\n * Interface to show list of items on selection of menu item.\r\n */\r\n public viewData?: ViewData;\r\n /**\r\n * @hidden\r\n * Whether the menu item is selected or not\r\n */\r\n public selected = false;\r\n /**\r\n * The Display Mode of the menu item.\r\n * Default Behaviour would be DisplayMode.ifRoom if null.\r\n * Refer {@link DisplayMode}\r\n */\r\n public displayMode?: DisplayMode;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Represents information about view to show on Navigation Bar Menu item selection\r\n */\r\n export interface ViewData {\r\n /**\r\n * @hidden\r\n * Display header title of the item list.\r\n */\r\n listTitle?: string;\r\n /**\r\n * @hidden\r\n * Type of the menu item.\r\n */\r\n listType: MenuListType;\r\n /**\r\n * @hidden\r\n * Array of MenuItem. Icon value will be required for all items in the list.\r\n */\r\n listItems: MenuItem[];\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Represents information about type of list to display in Navigation Bar Menu.\r\n */\r\n export enum MenuListType {\r\n dropDown = 'dropDown',\r\n popOver = 'popOver',\r\n }\r\n let navBarMenuItemPressHandler: (id: string) => boolean;\r\n let actionMenuItemPressHandler: (id: string) => boolean;\r\n let viewConfigItemPressHandler: (id: string) => boolean;\r\n\r\n export function initialize(): void {\r\n registerHandler('navBarMenuItemPress', handleNavBarMenuItemPress, false);\r\n registerHandler('actionMenuItemPress', handleActionMenuItemPress, false);\r\n registerHandler('setModuleView', handleViewConfigItemPress, false);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers list of view configurations and it's handler.\r\n * Handler is responsible for listening selection of View Configuration.\r\n *\r\n * @param viewConfig - List of view configurations. Minimum 1 value is required.\r\n * @param handler - The handler to invoke when the user selects view configuration.\r\n */\r\n export function setUpViews(viewConfig: ViewConfiguration[], handler: (id: string) => boolean): void {\r\n ensureInitialized();\r\n viewConfigItemPressHandler = handler;\r\n sendMessageToParent('setUpViews', [viewConfig]);\r\n }\r\n\r\n function handleViewConfigItemPress(id: string): void {\r\n if (!viewConfigItemPressHandler || !viewConfigItemPressHandler(id)) {\r\n ensureInitialized();\r\n sendMessageToParent('viewConfigItemPress', [id]);\r\n }\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Used to set menu items on the Navigation Bar. If icon is available, icon will be shown, otherwise title will be shown.\r\n *\r\n * @param items List of MenuItems for Navigation Bar Menu.\r\n * @param handler The handler to invoke when the user selects menu item.\r\n */\r\n export function setNavBarMenu(items: MenuItem[], handler: (id: string) => boolean): void {\r\n ensureInitialized();\r\n navBarMenuItemPressHandler = handler;\r\n sendMessageToParent('setNavBarMenu', [items]);\r\n }\r\n\r\n function handleNavBarMenuItemPress(id: string): void {\r\n if (!navBarMenuItemPressHandler || !navBarMenuItemPressHandler(id)) {\r\n ensureInitialized();\r\n sendMessageToParent('handleNavBarMenuItemPress', [id]);\r\n }\r\n }\r\n\r\n export interface ActionMenuParameters {\r\n /**\r\n * @hidden\r\n * Display title for Action Menu\r\n */\r\n title: string;\r\n /**\r\n * @hidden\r\n * List of MenuItems for Action Menu\r\n */\r\n items: MenuItem[];\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Used to show Action Menu.\r\n *\r\n * @param params - Parameters for Menu Parameters\r\n * @param handler - The handler to invoke when the user selects menu item.\r\n */\r\n export function showActionMenu(params: ActionMenuParameters, handler: (id: string) => boolean): void {\r\n ensureInitialized();\r\n actionMenuItemPressHandler = handler;\r\n sendMessageToParent('showActionMenu', [params]);\r\n }\r\n\r\n function handleActionMenuItemPress(id: string): void {\r\n if (!actionMenuItemPressHandler || !actionMenuItemPressHandler(id)) {\r\n ensureInitialized();\r\n sendMessageToParent('handleActionMenuItemPress', [id]);\r\n }\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.menus ? true : false;\r\n }\r\n}\r\n","import { GlobalVars } from '../internal/globalVars';\r\nimport * as Handlers from '../internal/handlers'; // Conflict with some names\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { LoadContext } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * Namespace containing the set of APIs that support Teams-specific functionalities.\r\n *\r\n * @alpha\r\n */\r\n\r\nexport namespace teamsCore {\r\n /**\r\n * Enable print capability to support printing page using Ctrl+P and cmd+P\r\n */\r\n export function enablePrintCapability(): void {\r\n if (!GlobalVars.printCapabilityEnabled) {\r\n GlobalVars.printCapabilityEnabled = true;\r\n ensureInitialized();\r\n // adding ctrl+P and cmd+P handler\r\n document.addEventListener('keydown', (event: KeyboardEvent) => {\r\n if ((event.ctrlKey || event.metaKey) && event.keyCode === 80) {\r\n print();\r\n event.cancelBubble = true;\r\n event.preventDefault();\r\n event.stopImmediatePropagation();\r\n }\r\n });\r\n }\r\n }\r\n\r\n /**\r\n * default print handler\r\n */\r\n export function print(): void {\r\n window.print();\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers a handler to be called when the page has been requested to load.\r\n *\r\n * @param handler - The handler to invoke when the page is loaded.\r\n *\r\n * @internal\r\n */\r\n export function registerOnLoadHandler(handler: (context: LoadContext) => void): void {\r\n ensureInitialized();\r\n Handlers.registerOnLoadHandler(handler);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers a handler to be called before the page is unloaded.\r\n *\r\n * @param handler - The handler to invoke before the page is unloaded. If this handler returns true the page should\r\n * invoke the readyToUnload function provided to it once it's ready to be unloaded.\r\n *\r\n * @internal\r\n */\r\n export function registerBeforeUnloadHandler(handler: (readyToUnload: () => void) => boolean): void {\r\n ensureInitialized();\r\n Handlers.registerBeforeUnloadHandler(handler);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.teamsCore ? true : false;\r\n }\r\n}\r\n","/* eslint-disable @typescript-eslint/no-empty-function */\r\n/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\r\n/* eslint-disable @typescript-eslint/no-explicit-any */\r\n\r\nimport {\r\n Communication,\r\n initializeCommunication,\r\n sendAndHandleStatusAndReason as send,\r\n sendAndUnwrap,\r\n sendMessageToParent,\r\n uninitializeCommunication,\r\n} from '../internal/communication';\r\nimport { defaultSDKVersionForCompatCheck, version } from '../internal/constants';\r\nimport { GlobalVars } from '../internal/globalVars';\r\nimport * as Handlers from '../internal/handlers'; // Conflict with some names\r\nimport { ensureInitialized, processAdditionalValidOrigins } from '../internal/internalAPIs';\r\nimport { compareSDKVersions, runWithTimeout } from '../internal/utils';\r\nimport { logs } from '../private/logs';\r\nimport { initializePrivateApis } from '../private/privateAPIs';\r\nimport { authentication } from './authentication';\r\nimport { ChannelType, FrameContexts, HostClientType, HostName, TeamType, UserTeamRole } from './constants';\r\nimport { Context as LegacyContext, FileOpenPreference, LocaleInfo } from './interfaces';\r\nimport { menus } from './menus';\r\nimport { pages } from './pages';\r\nimport { applyRuntimeConfig, IRuntime, teamsRuntimeConfig } from './runtime';\r\nimport { teamsCore } from './teamsAPIs';\r\n\r\n/**\r\n * Namespace to interact with app initialization and lifecycle.\r\n *\r\n * @beta\r\n */\r\nexport namespace app {\r\n // ::::::::::::::::::::::: MicrosoftTeams client SDK public API ::::::::::::::::::::\r\n\r\n export const Messages = {\r\n AppLoaded: 'appInitialization.appLoaded',\r\n Success: 'appInitialization.success',\r\n Failure: 'appInitialization.failure',\r\n ExpectedFailure: 'appInitialization.expectedFailure',\r\n };\r\n\r\n export enum FailedReason {\r\n AuthFailed = 'AuthFailed',\r\n Timeout = 'Timeout',\r\n Other = 'Other',\r\n }\r\n\r\n export enum ExpectedFailureReason {\r\n PermissionError = 'PermissionError',\r\n NotFound = 'NotFound',\r\n Throttling = 'Throttling',\r\n Offline = 'Offline',\r\n Other = 'Other',\r\n }\r\n\r\n export interface IFailedRequest {\r\n reason: FailedReason;\r\n message?: string;\r\n }\r\n\r\n export interface IExpectedFailureRequest {\r\n reason: ExpectedFailureReason;\r\n message?: string;\r\n }\r\n\r\n export interface AppInfo {\r\n /**\r\n * The current locale that the user has configured for the app formatted as\r\n * languageId-countryId (for example, en-us).\r\n */\r\n locale: string;\r\n\r\n /**\r\n * The current UI theme.\r\n */\r\n theme: string;\r\n\r\n /**\r\n * Unique ID for the current session for use in correlating telemetry data.\r\n */\r\n sessionId: string;\r\n\r\n /**\r\n * Info of the host\r\n */\r\n host: AppHostInfo;\r\n\r\n /**\r\n * More detailed locale info from the user's OS if available. Can be used together with\r\n * the @microsoft/globe NPM package to ensure your app respects the user's OS date and\r\n * time format configuration\r\n */\r\n osLocaleInfo?: LocaleInfo;\r\n /**\r\n * Personal app icon y coordinate position\r\n */\r\n iconPositionVertical?: number;\r\n\r\n /**\r\n * Time when the user clicked on the tab\r\n */\r\n userClickTime?: number;\r\n\r\n /**\r\n * The ID of the parent message from which this task module was launched.\r\n * This is only available in task modules launched from bot cards.\r\n */\r\n parentMessageId?: string;\r\n\r\n /**\r\n * Where the user prefers the file to be opened from by default during file open\r\n */\r\n userFileOpenPreference?: FileOpenPreference;\r\n\r\n /**\r\n * ID for the current visible app which is different for across cached sessions. Used for correlating telemetry data.\r\n */\r\n appLaunchId?: string;\r\n }\r\n\r\n export interface AppHostInfo {\r\n /**\r\n * The name of the host client. Possible values are: Office, Orange, Outlook, Teams\r\n */\r\n name: HostName;\r\n\r\n /**\r\n * The type of the host client. Possible values are : android, ios, web, desktop, rigel\r\n */\r\n clientType: HostClientType;\r\n\r\n /**\r\n * Unique ID for the current Host session for use in correlating telemetry data.\r\n */\r\n sessionId: string;\r\n\r\n /**\r\n * Current ring ID\r\n */\r\n ringId?: string;\r\n }\r\n\r\n export interface ChannelInfo {\r\n /**\r\n * The Microsoft Teams ID for the channel with which the content is associated.\r\n */\r\n id: string;\r\n\r\n /**\r\n * The name for the channel with which the content is associated.\r\n */\r\n displayName?: string;\r\n\r\n /**\r\n * The relative path to the SharePoint folder associated with the channel.\r\n */\r\n relativeUrl?: string;\r\n\r\n /**\r\n * The type of the channel with which the content is associated.\r\n */\r\n membershipType?: ChannelType;\r\n\r\n /**\r\n * The OneNote section ID that is linked to the channel.\r\n */\r\n defaultOneNoteSectionId?: string;\r\n\r\n /**\r\n * The tenant ID of the team which owns the channel.\r\n */\r\n ownerTenantId?: string;\r\n\r\n /**\r\n * The AAD group ID of the team which owns the channel.\r\n */\r\n ownerGroupId?: string;\r\n }\r\n\r\n export interface ChatInfo {\r\n /**\r\n * The Microsoft Teams ID for the chat with which the content is associated.\r\n */\r\n id: string;\r\n }\r\n\r\n export interface MeetingInfo {\r\n /**\r\n * Meeting Id used by tab when running in meeting context\r\n */\r\n id: string;\r\n }\r\n\r\n export interface PageInfo {\r\n /**\r\n * The developer-defined unique ID for the page this content points to.\r\n */\r\n id: string;\r\n\r\n /**\r\n * The context where page url is loaded (content, task, setting, remove, sidePanel)\r\n */\r\n frameContext: FrameContexts;\r\n\r\n /**\r\n * The developer-defined unique ID for the sub-page this content points to.\r\n * This field should be used to restore to a specific state within a page,\r\n * such as scrolling to or activating a specific piece of content.\r\n */\r\n subPageId?: string;\r\n\r\n /**\r\n * Indication whether the page is in full-screen mode.\r\n */\r\n isFullScreen?: boolean;\r\n\r\n /**\r\n * Indication whether the page is in a pop out window\r\n */\r\n isMultiWindow?: boolean;\r\n\r\n /**\r\n * Source origin from where the page is opened\r\n */\r\n sourceOrigin?: string;\r\n }\r\n\r\n export interface TeamInfo {\r\n /**\r\n * The Microsoft Teams ID for the team with which the content is associated.\r\n */\r\n internalId: string;\r\n\r\n /**\r\n * The name for the team with which the content is associated.\r\n */\r\n displayName?: string;\r\n\r\n /**\r\n * The type of the team.\r\n */\r\n type?: TeamType;\r\n\r\n /**\r\n * The Office 365 group ID for the team with which the content is associated.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n groupId?: string;\r\n\r\n /**\r\n * Indicates whether team is archived.\r\n * Apps should use this as a signal to prevent any changes to content associated with archived teams.\r\n */\r\n isArchived?: boolean;\r\n\r\n /**\r\n * Team Template ID if there was a Team Template associated with the creation of the team.\r\n */\r\n templateId?: string;\r\n\r\n /**\r\n * The user's role in the team.\r\n * Because a malicious party can run your content in a browser, this value should\r\n * be used only as a hint as to the user's role, and never as proof of her role.\r\n */\r\n userRole?: UserTeamRole;\r\n }\r\n\r\n export interface UserInfo {\r\n /**\r\n * The Azure AD object id of the current user.\r\n * Because a malicious party run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n id: string;\r\n\r\n /**\r\n * The address book name of the current user.\r\n */\r\n displayName?: string;\r\n\r\n /**\r\n * Represents whether calling is allowed for the current logged in User\r\n */\r\n isCallingAllowed?: boolean;\r\n\r\n /**\r\n * Represents whether PSTN calling is allowed for the current logged in User\r\n */\r\n isPSTNCallingAllowed?: boolean;\r\n\r\n /**\r\n * The license type for the current user.\r\n */\r\n licenseType?: string;\r\n\r\n /**\r\n * A value suitable for use as a login_hint when authenticating with Azure AD.\r\n * Because a malicious party can run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n loginHint?: string;\r\n\r\n /**\r\n * The UPN of the current user. This may be an externally-authenticated UPN (e.g., guest users).\r\n * Because a malicious party run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n userPrincipalName?: string;\r\n\r\n /**\r\n * The tenant related info of the current user.\r\n */\r\n tenant?: TenantInfo;\r\n }\r\n\r\n export interface TenantInfo {\r\n /**\r\n * The Azure AD tenant ID of the current user.\r\n * Because a malicious party can run your content in a browser, this value should\r\n * be used only as a hint as to who the user is and never as proof of identity.\r\n * This field is available only when the identity permission is requested in the manifest.\r\n */\r\n id: string;\r\n\r\n /**\r\n * The type of license for the current users tenant.\r\n */\r\n teamsSku?: string;\r\n }\r\n\r\n export interface SharePointSiteInfo {\r\n /**\r\n * The root SharePoint site associated with the team.\r\n */\r\n teamSiteUrl?: string;\r\n\r\n /**\r\n * The domain of the root SharePoint site associated with the team.\r\n */\r\n teamSiteDomain?: string;\r\n\r\n /**\r\n * The relative path to the SharePoint site associated with the team.\r\n */\r\n teamSitePath?: string;\r\n\r\n /**\r\n * Teamsite ID, aka sharepoint site id.\r\n */\r\n teamSiteId?: string;\r\n\r\n /**\r\n * The SharePoint my site domain associated with the user.\r\n */\r\n mySiteDomain?: string;\r\n\r\n /**\r\n * The SharePoint relative path to the current users mysite\r\n */\r\n mySitePath?: string;\r\n }\r\n\r\n /**\r\n * Represents structure of the context message received\r\n */\r\n export interface Context {\r\n /**\r\n * Info of the app\r\n */\r\n app: AppInfo;\r\n\r\n /**\r\n * Info of the current page of App\r\n */\r\n page: PageInfo;\r\n\r\n /**\r\n * Info of the user\r\n */\r\n user?: UserInfo;\r\n\r\n /**\r\n * Info of the Microsoft Teams channel\r\n */\r\n channel?: ChannelInfo;\r\n\r\n /**\r\n * Info of the Microsoft Teams chat\r\n */\r\n chat?: ChatInfo;\r\n\r\n /**\r\n * Info of the Microsoft Teams meeting\r\n */\r\n meeting?: MeetingInfo;\r\n\r\n /**\r\n * SharePoint context. This is only available when hosted in SharePoint.\r\n */\r\n sharepoint?: any;\r\n\r\n /**\r\n * Info of the sharePoint site associated with the team.\r\n */\r\n sharePointSite?: SharePointSiteInfo;\r\n\r\n /**\r\n * Info of the Microsoft Teams team\r\n */\r\n team?: TeamInfo;\r\n }\r\n\r\n /**\r\n * Checks whether the Teams client SDK has been initialized.\r\n * @returns whether the Teams client SDK has been initialized.\r\n */\r\n export function isInitialized(): boolean {\r\n return GlobalVars.initializeCalled;\r\n }\r\n\r\n /**\r\n * Gets the Frame Context that the App is running in. {@see FrameContexts} for the list of possible values.\r\n * @returns the Frame Context.\r\n */\r\n export function getFrameContext(): FrameContexts {\r\n return GlobalVars.frameContext;\r\n }\r\n\r\n /**\r\n * Number of milliseconds we'll give the initialization call to return before timing it out\r\n */\r\n const initializationTimeoutInMs = 5000;\r\n\r\n /**\r\n * Initializes the library.\r\n *\r\n * @remarks\r\n * This must be called before any other SDK calls\r\n * but after the frame is loaded successfully.\r\n *\r\n * @param validMessageOrigins - Optionally specify a list of cross frame message origins. They must have\r\n * https: protocol otherwise they will be ignored. Example: https:www.example.com\r\n * @returns Promise that will be fulfilled when initialization has completed, or rejected if the initialization fails or times out\r\n */\r\n export function initialize(validMessageOrigins?: string[]): Promise<void> {\r\n return runWithTimeout(\r\n () => initializeHelper(validMessageOrigins),\r\n initializationTimeoutInMs,\r\n new Error('SDK initialization timed out.'),\r\n );\r\n }\r\n\r\n function initializeHelper(validMessageOrigins?: string[]): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n // Independent components might not know whether the SDK is initialized so might call it to be safe.\r\n // Just no-op if that happens to make it easier to use.\r\n if (!GlobalVars.initializeCalled) {\r\n GlobalVars.initializeCalled = true;\r\n\r\n Handlers.initializeHandlers();\r\n GlobalVars.initializePromise = initializeCommunication(validMessageOrigins).then(\r\n ({ context, clientType, runtimeConfig, clientSupportedSDKVersion = defaultSDKVersionForCompatCheck }) => {\r\n GlobalVars.frameContext = context;\r\n GlobalVars.hostClientType = clientType;\r\n GlobalVars.clientSupportedSDKVersion = clientSupportedSDKVersion;\r\n\r\n // Temporary workaround while the Host is updated with the new argument order.\r\n // For now, we might receive any of these possibilities:\r\n // - `runtimeConfig` in `runtimeConfig` and `clientSupportedSDKVersion` in `clientSupportedSDKVersion`.\r\n // - `runtimeConfig` in `clientSupportedSDKVersion` and `clientSupportedSDKVersion` in `runtimeConfig`.\r\n // - `clientSupportedSDKVersion` in `runtimeConfig` and no `clientSupportedSDKVersion`.\r\n // This code supports any of these possibilities\r\n\r\n // Teams AppHost won't provide this runtime config\r\n // so we assume that if we don't have it, we must be running in Teams.\r\n // After Teams updates its client code, we can remove this default code.\r\n try {\r\n const givenRuntimeConfig: IRuntime = JSON.parse(runtimeConfig);\r\n // Check that givenRuntimeConfig is a valid instance of IRuntimeConfig\r\n if (!givenRuntimeConfig || !givenRuntimeConfig.apiVersion) {\r\n throw new Error('Received runtime config is invalid');\r\n }\r\n runtimeConfig && applyRuntimeConfig(givenRuntimeConfig);\r\n } catch (e) {\r\n if (e instanceof SyntaxError) {\r\n try {\r\n // if the given runtime config was actually meant to be a SDK version, store it as such.\r\n // TODO: This is a temporary workaround to allow Teams to store clientSupportedSDKVersion even when\r\n // it doesn't provide the runtimeConfig. After Teams updates its client code, we should\r\n // remove this feature.\r\n if (!isNaN(compareSDKVersions(runtimeConfig, defaultSDKVersionForCompatCheck))) {\r\n GlobalVars.clientSupportedSDKVersion = runtimeConfig;\r\n }\r\n const givenRuntimeConfig: IRuntime = JSON.parse(clientSupportedSDKVersion);\r\n clientSupportedSDKVersion && applyRuntimeConfig(givenRuntimeConfig);\r\n } catch (e) {\r\n if (e instanceof SyntaxError) {\r\n applyRuntimeConfig(teamsRuntimeConfig);\r\n } else {\r\n throw e;\r\n }\r\n }\r\n } else {\r\n // If it's any error that's not a JSON parsing error, we want the program to fail.\r\n throw e;\r\n }\r\n }\r\n\r\n GlobalVars.initializeCompleted = true;\r\n },\r\n );\r\n\r\n authentication.initialize();\r\n menus.initialize();\r\n pages.config.initialize();\r\n initializePrivateApis();\r\n }\r\n\r\n // Handle additional valid message origins if specified\r\n if (Array.isArray(validMessageOrigins)) {\r\n processAdditionalValidOrigins(validMessageOrigins);\r\n }\r\n\r\n resolve(GlobalVars.initializePromise);\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Undocumented function used to set a mock window for unit tests\r\n *\r\n * @internal\r\n */\r\n export function _initialize(hostWindow: any): void {\r\n Communication.currentWindow = hostWindow;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Undocumented function used to clear state between unit tests\r\n *\r\n * @internal\r\n */\r\n export function _uninitialize(): void {\r\n if (!GlobalVars.initializeCalled) {\r\n return;\r\n }\r\n\r\n if (GlobalVars.frameContext) {\r\n registerOnThemeChangeHandler(null);\r\n pages.backStack.registerBackButtonHandler(null);\r\n pages.registerFullScreenHandler(null);\r\n teamsCore.registerBeforeUnloadHandler(null);\r\n teamsCore.registerOnLoadHandler(null);\r\n logs.registerGetLogHandler(null);\r\n }\r\n\r\n if (GlobalVars.frameContext === FrameContexts.settings) {\r\n pages.config.registerOnSaveHandler(null);\r\n }\r\n\r\n if (GlobalVars.frameContext === FrameContexts.remove) {\r\n pages.config.registerOnRemoveHandler(null);\r\n }\r\n\r\n GlobalVars.initializeCalled = false;\r\n GlobalVars.initializeCompleted = false;\r\n GlobalVars.initializePromise = null;\r\n GlobalVars.additionalValidOrigins = [];\r\n GlobalVars.frameContext = null;\r\n GlobalVars.hostClientType = null;\r\n GlobalVars.isFramelessWindow = false;\r\n\r\n uninitializeCommunication();\r\n }\r\n\r\n /**\r\n * Retrieves the current context the frame is running in.\r\n *\r\n * @returns Promise that will resolve with the {@link Context} object.\r\n */\r\n export function getContext(): Promise<app.Context> {\r\n return new Promise<LegacyContext>(resolve => {\r\n ensureInitialized();\r\n resolve(sendAndUnwrap('getContext'));\r\n }).then(legacyContext => transformLegacyContextToAppContext(legacyContext)); // converts globalcontext to app.context\r\n }\r\n\r\n /**\r\n * Notifies the frame that app has loaded and to hide the loading indicator if one is shown.\r\n */\r\n export function notifyAppLoaded(): void {\r\n ensureInitialized();\r\n sendMessageToParent(Messages.AppLoaded, [version]);\r\n }\r\n\r\n /**\r\n * Notifies the frame that app initialization is successful and is ready for user interaction.\r\n */\r\n export function notifySuccess(): void {\r\n ensureInitialized();\r\n sendMessageToParent(Messages.Success, [version]);\r\n }\r\n\r\n /**\r\n * Notifies the frame that app initialization has failed and to show an error page in its place.\r\n */\r\n export function notifyFailure(appInitializationFailedRequest: IFailedRequest): void {\r\n ensureInitialized();\r\n sendMessageToParent(Messages.Failure, [\r\n appInitializationFailedRequest.reason,\r\n appInitializationFailedRequest.message,\r\n ]);\r\n }\r\n\r\n /**\r\n * Notifies the frame that app initialized with some expected errors.\r\n */\r\n export function notifyExpectedFailure(expectedFailureRequest: IExpectedFailureRequest): void {\r\n ensureInitialized();\r\n sendMessageToParent(Messages.ExpectedFailure, [expectedFailureRequest.reason, expectedFailureRequest.message]);\r\n }\r\n\r\n /**\r\n * Registers a handler for theme changes.\r\n *\r\n * @remarks\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the user changes their theme.\r\n */\r\n export function registerOnThemeChangeHandler(handler: (theme: string) => void): void {\r\n ensureInitialized();\r\n Handlers.registerOnThemeChangeHandler(handler);\r\n }\r\n\r\n /**\r\n * open link API.\r\n *\r\n * @param deepLink - deep link.\r\n * @returns Promise that will be fulfilled when the operation has completed\r\n */\r\n export function openLink(deepLink: string): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.settings,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n resolve(send('executeDeepLink', deepLink));\r\n });\r\n }\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Transforms the Legacy Context object received from Messages to the structured app.Context object\r\n *\r\n * @internal\r\n */\r\nfunction transformLegacyContextToAppContext(legacyContext: LegacyContext): app.Context {\r\n const context: app.Context = {\r\n app: {\r\n locale: legacyContext.locale,\r\n sessionId: legacyContext.appSessionId ? legacyContext.appSessionId : '',\r\n theme: legacyContext.theme ? legacyContext.theme : 'default',\r\n iconPositionVertical: legacyContext.appIconPosition,\r\n osLocaleInfo: legacyContext.osLocaleInfo,\r\n parentMessageId: legacyContext.parentMessageId,\r\n userClickTime: legacyContext.userClickTime,\r\n userFileOpenPreference: legacyContext.userFileOpenPreference,\r\n host: {\r\n name: legacyContext.hostName ? legacyContext.hostName : HostName.teams,\r\n clientType: legacyContext.hostClientType ? legacyContext.hostClientType : HostClientType.web,\r\n sessionId: legacyContext.sessionId ? legacyContext.sessionId : '',\r\n ringId: legacyContext.ringId,\r\n },\r\n appLaunchId: legacyContext.appLaunchId,\r\n },\r\n page: {\r\n id: legacyContext.entityId,\r\n frameContext: legacyContext.frameContext ? legacyContext.frameContext : GlobalVars.frameContext,\r\n subPageId: legacyContext.subEntityId,\r\n isFullScreen: legacyContext.isFullScreen,\r\n isMultiWindow: legacyContext.isMultiWindow,\r\n sourceOrigin: legacyContext.sourceOrigin,\r\n },\r\n user: {\r\n id: legacyContext.userObjectId,\r\n displayName: legacyContext.userDisplayName,\r\n isCallingAllowed: legacyContext.isCallingAllowed,\r\n isPSTNCallingAllowed: legacyContext.isPSTNCallingAllowed,\r\n licenseType: legacyContext.userLicenseType,\r\n loginHint: legacyContext.loginHint,\r\n userPrincipalName: legacyContext.userPrincipalName,\r\n tenant: legacyContext.tid\r\n ? {\r\n id: legacyContext.tid,\r\n teamsSku: legacyContext.tenantSKU,\r\n }\r\n : undefined,\r\n },\r\n channel: legacyContext.channelId\r\n ? {\r\n id: legacyContext.channelId,\r\n displayName: legacyContext.channelName,\r\n relativeUrl: legacyContext.channelRelativeUrl,\r\n membershipType: legacyContext.channelType,\r\n defaultOneNoteSectionId: legacyContext.defaultOneNoteSectionId,\r\n ownerGroupId: legacyContext.hostTeamGroupId,\r\n ownerTenantId: legacyContext.hostTeamTenantId,\r\n }\r\n : undefined,\r\n chat: legacyContext.chatId\r\n ? {\r\n id: legacyContext.chatId,\r\n }\r\n : undefined,\r\n meeting: legacyContext.meetingId\r\n ? {\r\n id: legacyContext.meetingId,\r\n }\r\n : undefined,\r\n sharepoint: legacyContext.sharepoint,\r\n team: legacyContext.teamId\r\n ? {\r\n internalId: legacyContext.teamId,\r\n displayName: legacyContext.teamName,\r\n type: legacyContext.teamType,\r\n groupId: legacyContext.groupId,\r\n templateId: legacyContext.teamTemplateId,\r\n isArchived: legacyContext.isTeamArchived,\r\n userRole: legacyContext.userTeamRole,\r\n }\r\n : undefined,\r\n sharePointSite:\r\n legacyContext.teamSiteUrl ||\r\n legacyContext.teamSiteDomain ||\r\n legacyContext.teamSitePath ||\r\n legacyContext.mySitePath ||\r\n legacyContext.mySiteDomain\r\n ? {\r\n teamSiteUrl: legacyContext.teamSiteUrl,\r\n teamSiteDomain: legacyContext.teamSiteDomain,\r\n teamSitePath: legacyContext.teamSitePath,\r\n teamSiteId: legacyContext.teamSiteId,\r\n mySitePath: legacyContext.mySitePath,\r\n mySiteDomain: legacyContext.mySiteDomain,\r\n }\r\n : undefined,\r\n };\r\n\r\n return context;\r\n}\r\n","import {\r\n sendAndHandleStatusAndReason as send,\r\n sendAndHandleStatusAndReasonWithDefaultError as sendAndDefaultError,\r\n sendAndUnwrap,\r\n sendMessageToParent,\r\n} from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { createTeamsAppLink } from '../internal/utils';\r\nimport { app } from './app';\r\nimport { FrameContexts } from './constants';\r\nimport { DeepLinkParameters, FrameInfo, TabInformation, TabInstance, TabInstanceParameters } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * Navigation specific part of the SDK.\r\n *\r\n * @beta\r\n */\r\nexport namespace pages {\r\n /**\r\n * Return focus to the host. Will move focus forward or backward based on where the app container falls in\r\n * the F6/Tab accessiblity loop in the host.\r\n * @param navigateForward - Determines the direction to focus in host.\r\n */\r\n export function returnFocus(navigateForward?: boolean): void {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n sendMessageToParent('returnFocus', [navigateForward]);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers a handler when focus needs to be passed from teams to the place of choice on app.\r\n *\r\n * @param handler - The handler to invoked by the app when they want the focus to be in the place of their choice.\r\n *\r\n * @internal\r\n */\r\n export function registerFocusEnterHandler(handler: (navigateForward: boolean) => void): void {\r\n ensureInitialized();\r\n registerHandler('focusEnter', handler);\r\n }\r\n\r\n export function setCurrentFrame(frameInfo: FrameInfo): void {\r\n ensureInitialized(FrameContexts.content);\r\n sendMessageToParent('setFrameContext', [frameInfo]);\r\n }\r\n\r\n export function initializeWithFrameContext(\r\n frameInfo: FrameInfo,\r\n callback?: () => void,\r\n validMessageOrigins?: string[],\r\n ): void {\r\n app.initialize(validMessageOrigins).then(() => callback && callback());\r\n setCurrentFrame(frameInfo);\r\n }\r\n\r\n export interface InstanceConfig {\r\n /**\r\n * A suggested display name for the new content.\r\n * In the settings for an existing instance being updated, this call has no effect.\r\n */\r\n suggestedDisplayName?: string;\r\n /**\r\n * Sets the URL to use for the content of this instance.\r\n */\r\n contentUrl: string;\r\n /**\r\n * Sets the URL for the removal configuration experience.\r\n */\r\n removeUrl?: string;\r\n /**\r\n * Sets the URL to use for the external link to view the underlying resource in a browser.\r\n */\r\n websiteUrl?: string;\r\n /**\r\n * The developer-defined unique ID for the entity to which this content points.\r\n */\r\n entityId?: string;\r\n }\r\n\r\n /**\r\n * Gets the config for the current instance.\r\n * @returns Promise that resolves with the {@link InstanceConfig} object.\r\n */\r\n export function getConfig(): Promise<InstanceConfig> {\r\n return new Promise<InstanceConfig>(resolve => {\r\n ensureInitialized(FrameContexts.content, FrameContexts.settings, FrameContexts.remove, FrameContexts.sidePanel);\r\n resolve(sendAndUnwrap('settings.getSettings'));\r\n });\r\n }\r\n\r\n /**\r\n * Navigates the frame to a new cross-domain URL. The domain of this URL must match at least one of the\r\n * valid domains specified in the validDomains block of the manifest; otherwise, an exception will be\r\n * thrown. This function needs to be used only when navigating the frame to a URL in a different domain\r\n * than the current one in a way that keeps the app informed of the change and allows the SDK to\r\n * continue working.\r\n * @param url - The URL to navigate the frame to.\r\n * @returns Promise that resolves when the navigation has completed.\r\n */\r\n export function navigateCrossDomain(url: string): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.settings,\r\n FrameContexts.remove,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n\r\n const errorMessage =\r\n 'Cross-origin navigation is only supported for URLs matching the pattern registered in the manifest.';\r\n resolve(sendAndDefaultError('navigateCrossDomain', errorMessage, url));\r\n });\r\n }\r\n\r\n /**\r\n * Navigate to the given App ID and Page ID, with optional parameters for a WebURL (if the app cannot\r\n * be navigated to, such as if it is not installed), Channel ID (for apps installed as a channel tab), and\r\n * Sub-page ID (for navigating to specific content within the page). This is equivalent to navigating to\r\n * a deep link with the above data, but does not require the app to build a URL or worry about different\r\n * deep link formats for different hosts.\r\n * @param params Parameters for the navigation\r\n * @returns a promise that will resolve if the navigation was successful\r\n */\r\n export function navigateToApp(params: NavigateToAppParams): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.settings,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n if (runtime.isLegacyTeams) {\r\n resolve(send('executeDeepLink', createTeamsAppLink(params)));\r\n } else {\r\n resolve(send('pages.navigateToApp', params));\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * Shares a deep link that a user can use to navigate back to a specific state in this page.\r\n *\r\n * @param deepLinkParameters - ID and label for the link and fallback URL.\r\n */\r\n export function shareDeepLink(deepLinkParameters: DeepLinkParameters): void {\r\n ensureInitialized(FrameContexts.content, FrameContexts.sidePanel, FrameContexts.meetingStage);\r\n\r\n sendMessageToParent('shareDeepLink', [\r\n deepLinkParameters.subEntityId,\r\n deepLinkParameters.subEntityLabel,\r\n deepLinkParameters.subEntityWebUrl,\r\n ]);\r\n }\r\n\r\n /**\r\n * Registers a handler for changes from or to full-screen view for a tab.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n * @param handler - The handler to invoke when the user toggles full-screen view for a tab.\r\n */\r\n export function registerFullScreenHandler(handler: (isFullScreen: boolean) => void): void {\r\n ensureInitialized();\r\n registerHandler('fullScreenChange', handler);\r\n }\r\n\r\n /**\r\n * Checks if page capability is supported currently\r\n */\r\n export function isSupported(): boolean {\r\n return runtime.supports.pages ? true : false;\r\n }\r\n\r\n /**\r\n * Parameters for the NavigateToApp API\r\n */\r\n export interface NavigateToAppParams {\r\n /**\r\n * ID of the App to navigate to\r\n */\r\n appId: string;\r\n\r\n /**\r\n * Developer-defined ID of the Page to navigate to within the app (Formerly EntityID)\r\n */\r\n pageId: string;\r\n\r\n /**\r\n * Optional URL to open if the navigation cannot be completed within the host\r\n */\r\n webUrl?: string;\r\n\r\n /**\r\n * Optional developer-defined ID describing the content to navigate to within the Page. This will be passed\r\n * back to the App via the Context object.\r\n */\r\n subPageId?: string;\r\n\r\n /**\r\n * Optional ID of the Teams Channel where the app should be opened\r\n */\r\n channelId?: string;\r\n }\r\n\r\n /**\r\n * Namespace to interact with the teams specific part of the SDK.\r\n */\r\n export namespace tabs {\r\n /**\r\n * Navigates the hosted app to the specified tab instance.\r\n * @param tabInstance The tab instance to navigate to.\r\n * @returns Promise that resolves when the navigation has completed.\r\n */\r\n export function navigateToTab(tabInstance: TabInstance): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized();\r\n const errorMessage = 'Invalid internalTabInstanceId and/or channelId were/was provided';\r\n resolve(sendAndDefaultError('navigateToTab', errorMessage, tabInstance));\r\n });\r\n }\r\n /**\r\n * Allows an app to retrieve for this user tabs that are owned by this app.\r\n * If no TabInstanceParameters are passed, the app defaults to favorite teams and favorite channels.\r\n * @param tabInstanceParameters OPTIONAL Flags that specify whether to scope call to favorite teams or channels.\r\n * @returns Promise that resolves with the {@link TabInformation}.\r\n */\r\n export function getTabInstances(tabInstanceParameters?: TabInstanceParameters): Promise<TabInformation> {\r\n return new Promise<TabInformation>(resolve => {\r\n ensureInitialized();\r\n resolve(sendAndUnwrap('getTabInstances', tabInstanceParameters));\r\n });\r\n }\r\n\r\n /**\r\n * Allows an app to retrieve the most recently used tabs for this user.\r\n * @param tabInstanceParameters OPTIONAL Ignored, kept for future use\r\n * @returns Promise that resolves with the {@link TabInformation}.\r\n */\r\n export function getMruTabInstances(tabInstanceParameters?: TabInstanceParameters): Promise<TabInformation> {\r\n return new Promise<TabInformation>(resolve => {\r\n ensureInitialized();\r\n resolve(sendAndUnwrap('getMruTabInstances', tabInstanceParameters));\r\n });\r\n }\r\n\r\n /**\r\n * Checks if pages.tabs capability is supported currently\r\n */\r\n export function isSupported(): boolean {\r\n return runtime.supports.pages ? (runtime.supports.pages.tabs ? true : false) : false;\r\n }\r\n }\r\n /**\r\n * Namespace to interact with the config-specific part of the SDK.\r\n * This object is usable only on the config frame.\r\n */\r\n export namespace config {\r\n let saveHandler: (evt: SaveEvent) => void;\r\n let removeHandler: (evt: RemoveEvent) => void;\r\n\r\n export function initialize(): void {\r\n registerHandler('settings.save', handleSave, false);\r\n registerHandler('settings.remove', handleRemove, false);\r\n }\r\n\r\n /**\r\n * Sets the validity state for the config.\r\n * The initial value is false, so the user cannot save the config until this is called with true.\r\n * @param validityState Indicates whether the save or remove button is enabled for the user.\r\n */\r\n export function setValidityState(validityState: boolean): void {\r\n ensureInitialized(FrameContexts.settings, FrameContexts.remove);\r\n sendMessageToParent('settings.setValidityState', [validityState]);\r\n }\r\n\r\n /**\r\n * Sets the config for the current instance.\r\n * This is an asynchronous operation; calls to getConfig are not guaranteed to reflect the changed state.\r\n * @param instanceConfig The desired config for this instance.\r\n * @returns Promise that resolves when the operation has completed.\r\n */\r\n export function setConfig(instanceConfig: InstanceConfig): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(FrameContexts.content, FrameContexts.settings, FrameContexts.sidePanel);\r\n resolve(send('settings.setSettings', instanceConfig));\r\n });\r\n }\r\n\r\n /**\r\n * Registers a handler for when the user attempts to save the settings. This handler should be used\r\n * to create or update the underlying resource powering the content.\r\n * The object passed to the handler must be used to notify whether to proceed with the save.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n * @param handler The handler to invoke when the user selects the save button.\r\n */\r\n export function registerOnSaveHandler(handler: (evt: SaveEvent) => void): void {\r\n ensureInitialized(FrameContexts.settings);\r\n saveHandler = handler;\r\n handler && sendMessageToParent('registerHandler', ['save']);\r\n }\r\n\r\n /**\r\n * Registers a handler for user attempts to remove content. This handler should be used\r\n * to remove the underlying resource powering the content.\r\n * The object passed to the handler must be used to indicate whether to proceed with the removal.\r\n * Only one handler may be registered at a time. Subsequent registrations will override the first.\r\n * @param handler The handler to invoke when the user selects the remove button.\r\n */\r\n export function registerOnRemoveHandler(handler: (evt: RemoveEvent) => void): void {\r\n ensureInitialized(FrameContexts.remove, FrameContexts.settings);\r\n removeHandler = handler;\r\n handler && sendMessageToParent('registerHandler', ['remove']);\r\n }\r\n\r\n function handleSave(result?: SaveParameters): void {\r\n const saveEvent = new SaveEventImpl(result);\r\n if (saveHandler) {\r\n saveHandler(saveEvent);\r\n } else {\r\n // If no handler is registered, we assume success.\r\n saveEvent.notifySuccess();\r\n }\r\n }\r\n\r\n /**\r\n * Registers a handler for when the user reconfigurated tab\r\n * @param handler The handler to invoke when the user click on Settings.\r\n */\r\n export function registerChangeConfigHandler(handler: () => void): void {\r\n ensureInitialized(FrameContexts.content);\r\n registerHandler('changeSettings', handler);\r\n }\r\n\r\n export interface SaveEvent {\r\n /**\r\n * Object containing properties passed as arguments to the settings.save event.\r\n */\r\n result: SaveParameters;\r\n /**\r\n * Indicates that the underlying resource has been created and the config can be saved.\r\n */\r\n notifySuccess(): void;\r\n /**\r\n * Indicates that creation of the underlying resource failed and that the config cannot be saved.\r\n * @param reason Specifies a reason for the failure. If provided, this string is displayed to the user; otherwise a generic error is displayed.\r\n */\r\n notifyFailure(reason?: string): void;\r\n }\r\n\r\n export interface RemoveEvent {\r\n /**\r\n * Indicates that the underlying resource has been removed and the content can be removed.\r\n */\r\n notifySuccess(): void;\r\n /**\r\n * Indicates that removal of the underlying resource failed and that the content cannot be removed.\r\n * @param reason Specifies a reason for the failure. If provided, this string is displayed to the user; otherwise a generic error is displayed.\r\n */\r\n notifyFailure(reason?: string): void;\r\n }\r\n\r\n export interface SaveParameters {\r\n /**\r\n * Connector's webhook Url returned as arguments to settings.save event as part of user clicking on Save\r\n */\r\n webhookUrl?: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs, since this class is not directly used.\r\n */\r\n class SaveEventImpl implements SaveEvent {\r\n public notified = false;\r\n public result: SaveParameters;\r\n public constructor(result?: SaveParameters) {\r\n this.result = result ? result : {};\r\n }\r\n public notifySuccess(): void {\r\n this.ensureNotNotified();\r\n sendMessageToParent('settings.save.success');\r\n this.notified = true;\r\n }\r\n public notifyFailure(reason?: string): void {\r\n this.ensureNotNotified();\r\n sendMessageToParent('settings.save.failure', [reason]);\r\n this.notified = true;\r\n }\r\n private ensureNotNotified(): void {\r\n if (this.notified) {\r\n throw new Error('The SaveEvent may only notify success or failure once.');\r\n }\r\n }\r\n }\r\n\r\n function handleRemove(): void {\r\n const removeEvent = new RemoveEventImpl();\r\n if (removeHandler) {\r\n removeHandler(removeEvent);\r\n } else {\r\n // If no handler is registered, we assume success.\r\n removeEvent.notifySuccess();\r\n }\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs, since this class is not directly used.\r\n */\r\n class RemoveEventImpl implements RemoveEvent {\r\n public notified = false;\r\n\r\n public notifySuccess(): void {\r\n this.ensureNotNotified();\r\n sendMessageToParent('settings.remove.success');\r\n this.notified = true;\r\n }\r\n\r\n public notifyFailure(reason?: string): void {\r\n this.ensureNotNotified();\r\n sendMessageToParent('settings.remove.failure', [reason]);\r\n this.notified = true;\r\n }\r\n\r\n private ensureNotNotified(): void {\r\n if (this.notified) {\r\n throw new Error('The removeEvent may only notify success or failure once.');\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Checks if pages.config capability is supported currently\r\n */\r\n export function isSupported(): boolean {\r\n return runtime.supports.pages ? (runtime.supports.pages.config ? true : false) : false;\r\n }\r\n }\r\n\r\n /**\r\n * Namespace to interact with the back-stack part of the SDK.\r\n */\r\n export namespace backStack {\r\n let backButtonPressHandler: () => boolean;\r\n\r\n export function _initialize(): void {\r\n registerHandler('backButtonPress', handleBackButtonPress, false);\r\n }\r\n\r\n /**\r\n * Navigates back in the hosted app. See registerBackButtonHandler for more information on when\r\n * it's appropriate to use this method.\r\n * @returns Promise that resolves when the navigation has completed.\r\n */\r\n export function navigateBack(): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized();\r\n const errorMessage = 'Back navigation is not supported in the current client or context.';\r\n resolve(sendAndDefaultError('navigateBack', errorMessage));\r\n });\r\n }\r\n\r\n /**\r\n * Registers a handler for user presses of the Team client's back button. Experiences that maintain an internal\r\n * navigation stack should use this handler to navigate the user back within their frame. If an app finds\r\n * that after running its back button handler it cannot handle the event it should call the navigateBack\r\n * method to ask the Teams client to handle it instead.\r\n * @param handler The handler to invoke when the user presses their Team client's back button.\r\n */\r\n export function registerBackButtonHandler(handler: () => boolean): void {\r\n backButtonPressHandler = handler;\r\n handler && sendMessageToParent('registerHandler', ['backButton']);\r\n }\r\n\r\n function handleBackButtonPress(): void {\r\n if (!backButtonPressHandler || !backButtonPressHandler()) {\r\n navigateBack();\r\n }\r\n }\r\n\r\n /**\r\n * Checks if pages.backStack capability is supported currently\r\n */\r\n export function isSupported(): boolean {\r\n return runtime.supports.pages ? (runtime.supports.pages.backStack ? true : false) : false;\r\n }\r\n }\r\n\r\n export namespace fullTrust {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Place the tab into full-screen mode.\r\n */\r\n export function enterFullscreen(): void {\r\n ensureInitialized(FrameContexts.content);\r\n sendMessageToParent('enterFullscreen', []);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Reverts the tab into normal-screen mode.\r\n */\r\n export function exitFullscreen(): void {\r\n ensureInitialized(FrameContexts.content);\r\n sendMessageToParent('exitFullscreen', []);\r\n }\r\n /**\r\n * Checks if pages.fullTrust capability is supported currently\r\n */\r\n export function isSupported(): boolean {\r\n return runtime.supports.pages ? (runtime.supports.pages.fullTrust ? true : false) : false;\r\n }\r\n }\r\n\r\n /**\r\n * Namespace to interact with the app button part of the SDK.\r\n */\r\n export namespace appButton {\r\n /**\r\n * Registers a handler for clicking the app button.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n * @param handler - The handler to invoke when the personal app button is clicked in the app bar.\r\n */\r\n export function onClick(handler: () => void): void {\r\n ensureInitialized(FrameContexts.content);\r\n registerHandler('appButtonClick', handler);\r\n }\r\n\r\n /**\r\n * Registers a handler for entering hover of the app button.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n * @param handler - The handler to invoke when entering hover of the personal app button in the app bar.\r\n */\r\n export function onHoverEnter(handler: () => void): void {\r\n ensureInitialized(FrameContexts.content);\r\n registerHandler('appButtonHoverEnter', handler);\r\n }\r\n\r\n /**\r\n * Registers a handler for exiting hover of the app button.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n * @param handler - The handler to invoke when exiting hover of the personal app button in the app bar.\r\n */\r\n export function onHoverLeave(handler: () => void): void {\r\n ensureInitialized(FrameContexts.content);\r\n registerHandler('appButtonHoverLeave', handler);\r\n }\r\n\r\n /**\r\n * Checks if pages.appButton capability is supported currently\r\n */\r\n export function isSupported(): boolean {\r\n return runtime.supports.pages ? (runtime.supports.pages.appButton ? true : false) : false;\r\n }\r\n }\r\n}\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\n\r\nimport { Communication, sendMessageEventToChild, sendMessageToParent } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { getGenericOnCompleteHandler } from '../internal/utils';\r\nimport { UserSettingTypes } from './interfaces';\r\n\r\n/**\r\n * @internal\r\n */\r\nexport function initializePrivateApis(): void {\r\n //Keeping this API for any future usage, wherein privateAPIs need to be initialized\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Upload a custom App manifest directly to both team and personal scopes.\r\n * This method works just for the first party Apps.\r\n *\r\n * @internal\r\n */\r\nexport function uploadCustomApp(manifestBlob: Blob, onComplete?: (status: boolean, reason?: string) => void): void {\r\n ensureInitialized();\r\n\r\n sendMessageToParent('uploadCustomApp', [manifestBlob], onComplete ? onComplete : getGenericOnCompleteHandler());\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Internal use only\r\n * Sends a custom action MessageRequest to Teams or parent window\r\n *\r\n * @param actionName - Specifies name of the custom action to be sent\r\n * @param args - Specifies additional arguments passed to the action\r\n * @param callback - Optionally specify a callback to receive response parameters from the parent\r\n * @returns id of sent message\r\n *\r\n * @internal\r\n */\r\nexport function sendCustomMessage(\r\n actionName: string,\r\n // tslint:disable-next-line:no-any\r\n args?: any[],\r\n // tslint:disable-next-line:no-any\r\n callback?: (...args: any[]) => void,\r\n): void {\r\n ensureInitialized();\r\n\r\n sendMessageToParent(actionName, args, callback);\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Internal use only\r\n * Sends a custom action MessageEvent to a child iframe/window, only if you are not using auth popup.\r\n * Otherwise it will go to the auth popup (which becomes the child)\r\n *\r\n * @param actionName - Specifies name of the custom action to be sent\r\n * @param args - Specifies additional arguments passed to the action\r\n * @returns id of sent message\r\n *\r\n * @internal\r\n */\r\nexport function sendCustomEvent(\r\n actionName: string,\r\n // tslint:disable-next-line:no-any\r\n args?: any[],\r\n): void {\r\n ensureInitialized();\r\n\r\n //validate childWindow\r\n if (!Communication.childWindow) {\r\n throw new Error('The child window has not yet been initialized or is not present');\r\n }\r\n sendMessageEventToChild(actionName, args);\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Internal use only\r\n * Adds a handler for an action sent by a child window or parent window\r\n *\r\n * @param actionName - Specifies name of the action message to handle\r\n * @param customHandler - The callback to invoke when the action message is received. The return value is sent to the child\r\n *\r\n * @internal\r\n */\r\nexport function registerCustomHandler(\r\n actionName: string,\r\n customHandler: (\r\n // tslint:disable-next-line:no-any\r\n ...args: any[]\r\n ) => any[],\r\n): void {\r\n ensureInitialized();\r\n registerHandler(actionName, (...args: any[]) => {\r\n return customHandler.apply(this, args);\r\n });\r\n}\r\n\r\n/**\r\n * @hidden\r\n * register a handler to be called when a user setting changes. The changed setting type & value is provided in the callback.\r\n *\r\n * @param settingTypes - List of user setting changes to subscribe\r\n * @param handler - When a subscribed setting is updated this handler is called\r\n *\r\n * @internal\r\n */\r\nexport function registerUserSettingsChangeHandler(\r\n settingTypes: UserSettingTypes[],\r\n handler: (settingType: UserSettingTypes, value: any) => void,\r\n): void {\r\n ensureInitialized();\r\n\r\n registerHandler('userSettingsChange', handler, true, [settingTypes]);\r\n}\r\n","import { debug as registerLogger, Debugger } from 'debug';\r\n\r\nconst topLevelLogger = registerLogger('teamsJs');\r\n\r\n/**\r\n * @internal\r\n *\r\n * Returns a logger for a given namespace, within the pre-defined top-level teamsJs namespace\r\n */\r\nexport function getLogger(namespace: string): Debugger {\r\n return topLevelLogger.extend(namespace);\r\n}\r\n","/* eslint-disable @typescript-eslint/ban-types */\r\n\r\nimport { LoadContext } from '../public';\r\nimport { pages } from '../public/pages';\r\nimport { Communication, sendMessageEventToChild, sendMessageToParent } from './communication';\r\nimport { getLogger } from './telemetry';\r\n\r\nconst handlersLogger = getLogger('handlers');\r\n\r\n/** @internal */\r\nclass HandlersPrivate {\r\n public static handlers: {\r\n [func: string]: Function;\r\n } = {};\r\n public static themeChangeHandler: (theme: string) => void;\r\n public static loadHandler: (context: LoadContext) => void;\r\n public static beforeUnloadHandler: (readyToUnload: () => void) => boolean;\r\n}\r\n\r\n/** @internal */\r\nexport function initializeHandlers(): void {\r\n // ::::::::::::::::::::MicrosoftTeams SDK Internal :::::::::::::::::\r\n HandlersPrivate.handlers['themeChange'] = handleThemeChange;\r\n HandlersPrivate.handlers['load'] = handleLoad;\r\n HandlersPrivate.handlers['beforeUnload'] = handleBeforeUnload;\r\n pages.backStack._initialize();\r\n}\r\n\r\nconst callHandlerLogger = handlersLogger.extend('callHandler');\r\n/** @internal */\r\nexport function callHandler(name: string, args?: unknown[]): [true, unknown] | [false, undefined] {\r\n const handler = HandlersPrivate.handlers[name];\r\n if (handler) {\r\n callHandlerLogger('Invoking the registered handler for message %s with arguments %o', name, args);\r\n const result = handler.apply(this, args);\r\n return [true, result];\r\n } else {\r\n callHandlerLogger('Handler for action message %s not found.', name);\r\n return [false, undefined];\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport function registerHandler(name: string, handler: Function, sendMessage = true, args: unknown[] = []): void {\r\n if (handler) {\r\n HandlersPrivate.handlers[name] = handler;\r\n sendMessage && sendMessageToParent('registerHandler', [name, ...args]);\r\n } else {\r\n delete HandlersPrivate.handlers[name];\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport function removeHandler(name: string): void {\r\n delete HandlersPrivate.handlers[name];\r\n}\r\n\r\n/** @internal */\r\nexport function registerOnThemeChangeHandler(handler: (theme: string) => void): void {\r\n HandlersPrivate.themeChangeHandler = handler;\r\n handler && sendMessageToParent('registerHandler', ['themeChange']);\r\n}\r\n\r\n/** @internal */\r\nexport function handleThemeChange(theme: string): void {\r\n if (HandlersPrivate.themeChangeHandler) {\r\n HandlersPrivate.themeChangeHandler(theme);\r\n }\r\n\r\n if (Communication.childWindow) {\r\n sendMessageEventToChild('themeChange', [theme]);\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport function registerOnLoadHandler(handler: (context: LoadContext) => void): void {\r\n HandlersPrivate.loadHandler = handler;\r\n handler && sendMessageToParent('registerHandler', ['load']);\r\n}\r\n\r\n/** @internal */\r\nfunction handleLoad(context: LoadContext): void {\r\n if (HandlersPrivate.loadHandler) {\r\n HandlersPrivate.loadHandler(context);\r\n }\r\n\r\n if (Communication.childWindow) {\r\n sendMessageEventToChild('load', [context]);\r\n }\r\n}\r\n\r\n/** @internal */\r\nexport function registerBeforeUnloadHandler(handler: (readyToUnload: () => void) => boolean): void {\r\n HandlersPrivate.beforeUnloadHandler = handler;\r\n handler && sendMessageToParent('registerHandler', ['beforeUnload']);\r\n}\r\n\r\n/** @internal */\r\nfunction handleBeforeUnload(): void {\r\n const readyToUnload = (): void => {\r\n sendMessageToParent('readyToUnload', []);\r\n };\r\n\r\n if (!HandlersPrivate.beforeUnloadHandler || !HandlersPrivate.beforeUnloadHandler(readyToUnload)) {\r\n readyToUnload();\r\n }\r\n}\r\n","/* eslint-disable @typescript-eslint/ban-types */\r\n/* eslint-disable @typescript-eslint/no-explicit-any */\r\n\r\nimport { FrameContexts } from '../public/constants';\r\nimport { SdkError } from '../public/interfaces';\r\nimport { version } from './constants';\r\nimport { GlobalVars } from './globalVars';\r\nimport { callHandler } from './handlers';\r\nimport { DOMMessageEvent, ExtendedWindow, MessageRequest, MessageResponse } from './interfaces';\r\nimport { getLogger } from './telemetry';\r\nimport { validateOrigin } from './utils';\r\n\r\nconst communicationLogger = getLogger('communication');\r\n\r\n/**@internal */\r\nexport class Communication {\r\n public static currentWindow: Window | any;\r\n public static parentOrigin: string;\r\n public static parentWindow: Window | any;\r\n public static childWindow: Window;\r\n public static childOrigin: string;\r\n}\r\n\r\n/**@internal */\r\nclass CommunicationPrivate {\r\n public static parentMessageQueue: MessageRequest[] = [];\r\n public static childMessageQueue: MessageRequest[] = [];\r\n public static nextMessageId = 0;\r\n public static callbacks: {\r\n [id: number]: Function; // (arg1, arg2, ...etc) => void\r\n } = {};\r\n public static promiseCallbacks: {\r\n [id: number]: Function; // (args[]) => void\r\n } = {};\r\n public static messageListener: Function;\r\n}\r\n\r\n/**@internal */\r\ninterface InitializeResponse {\r\n context: FrameContexts;\r\n clientType: string;\r\n runtimeConfig: string;\r\n clientSupportedSDKVersion: string;\r\n}\r\n\r\n/**@internal */\r\nexport function initializeCommunication(validMessageOrigins: string[] | undefined): Promise<InitializeResponse> {\r\n // Listen for messages post to our window\r\n CommunicationPrivate.messageListener = (evt: DOMMessageEvent): void => processMessage(evt);\r\n\r\n // If we are in an iframe, our parent window is the one hosting us (i.e., window.parent); otherwise,\r\n // it's the window that opened us (i.e., window.opener)\r\n Communication.currentWindow = Communication.currentWindow || window;\r\n Communication.parentWindow =\r\n Communication.currentWindow.parent !== Communication.currentWindow.self\r\n ? Communication.currentWindow.parent\r\n : Communication.currentWindow.opener;\r\n\r\n // Listen to messages from the parent or child frame.\r\n // Frameless windows will only receive this event from child frames and if validMessageOrigins is passed.\r\n if (Communication.parentWindow || validMessageOrigins) {\r\n Communication.currentWindow.addEventListener('message', CommunicationPrivate.messageListener, false);\r\n }\r\n\r\n if (!Communication.parentWindow) {\r\n const extendedWindow = (Communication.currentWindow as unknown) as ExtendedWindow;\r\n if (extendedWindow.nativeInterface) {\r\n GlobalVars.isFramelessWindow = true;\r\n extendedWindow.onNativeMessage = handleParentMessage;\r\n } else {\r\n // at this point we weren't able to find a parent to talk to, no way initialization will succeed\r\n return Promise.reject(new Error('Initialization Failed. No Parent window found.'));\r\n }\r\n }\r\n\r\n try {\r\n // Send the initialized message to any origin, because at this point we most likely don't know the origin\r\n // of the parent window, and this message contains no data that could pose a security risk.\r\n Communication.parentOrigin = '*';\r\n return sendMessageToParentAsync<[FrameContexts, string, string, string]>('initialize', [version]).then(\r\n ([context, clientType, runtimeConfig, clientSupportedSDKVersion]: [FrameContexts, string, string, string]) => {\r\n return { context, clientType, runtimeConfig, clientSupportedSDKVersion };\r\n },\r\n );\r\n } finally {\r\n Communication.parentOrigin = null;\r\n }\r\n}\r\n\r\n/**@internal */\r\nexport function uninitializeCommunication(): void {\r\n Communication.currentWindow.removeEventListener('message', CommunicationPrivate.messageListener, false);\r\n\r\n Communication.parentWindow = null;\r\n Communication.parentOrigin = null;\r\n Communication.childWindow = null;\r\n Communication.childOrigin = null;\r\n CommunicationPrivate.parentMessageQueue = [];\r\n CommunicationPrivate.childMessageQueue = [];\r\n CommunicationPrivate.nextMessageId = 0;\r\n CommunicationPrivate.callbacks = {};\r\n}\r\n\r\n/**@internal */\r\nexport function sendAndUnwrap<T>(actionName: string, ...args: any[]): Promise<T> {\r\n return sendMessageToParentAsync(actionName, args).then(([result]: [T]) => result);\r\n}\r\n\r\nexport function sendAndHandleStatusAndReason(actionName: string, ...args: any[]): Promise<void> {\r\n return sendMessageToParentAsync(actionName, args).then(([status, reason]: [boolean, string]) => {\r\n if (!status) {\r\n throw new Error(reason);\r\n }\r\n });\r\n}\r\n\r\n/**@internal */\r\nexport function sendAndHandleStatusAndReasonWithDefaultError(\r\n actionName: string,\r\n defaultError: string,\r\n ...args: any[]\r\n): Promise<void> {\r\n return sendMessageToParentAsync(actionName, args).then(([status, reason]: [boolean, string]) => {\r\n if (!status) {\r\n throw new Error(reason ? reason : defaultError);\r\n }\r\n });\r\n}\r\n\r\n/**@internal */\r\nexport function sendAndHandleSdkError<T>(actionName: string, ...args: any[]): Promise<T> {\r\n return sendMessageToParentAsync(actionName, args).then(([error, result]: [SdkError, T]) => {\r\n if (error) {\r\n throw error;\r\n }\r\n return result;\r\n });\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Send a message to parent. Uses nativeInterface on mobile to communicate with parent context\r\n *\r\n * @internal\r\n */\r\nexport function sendMessageToParentAsync<T>(actionName: string, args: any[] = undefined): Promise<T> {\r\n return new Promise(resolve => {\r\n const request = sendMessageToParentHelper(actionName, args);\r\n resolve(waitForResponse<T>(request.id));\r\n });\r\n}\r\n\r\n/**@internal */\r\nfunction waitForResponse<T>(requestId: number): Promise<T> {\r\n return new Promise<T>(resolve => {\r\n CommunicationPrivate.promiseCallbacks[requestId] = resolve;\r\n });\r\n}\r\n\r\n/**@internal */\r\nexport function sendMessageToParent(actionName: string, callback?: Function): void;\r\n\r\n/**\r\n * @hidden\r\n * Send a message to parent. Uses nativeInterface on mobile to communicate with parent context\r\n *\r\n * @internal\r\n */\r\nexport function sendMessageToParent(actionName: string, args: any[], callback?: Function): void;\r\n\r\n/**@internal */\r\nexport function sendMessageToParent(actionName: string, argsOrCallback?: any[] | Function, callback?: Function): void {\r\n let args: any[] | undefined;\r\n if (argsOrCallback instanceof Function) {\r\n callback = argsOrCallback;\r\n } else if (argsOrCallback instanceof Array) {\r\n args = argsOrCallback;\r\n }\r\n\r\n const request = sendMessageToParentHelper(actionName, args);\r\n if (callback) {\r\n CommunicationPrivate.callbacks[request.id] = callback;\r\n }\r\n}\r\n\r\nconst sendMessageToParentHelperLogger = communicationLogger.extend('sendMessageToParentHelper');\r\n\r\n/**@internal */\r\nfunction sendMessageToParentHelper(actionName: string, args: any[]): MessageRequest {\r\n const logger = sendMessageToParentHelperLogger;\r\n\r\n const targetWindow = Communication.parentWindow;\r\n const request = createMessageRequest(actionName, args);\r\n\r\n logger('Message %i information: %o', request.id, { actionName, args });\r\n\r\n if (GlobalVars.isFramelessWindow) {\r\n if (Communication.currentWindow && Communication.currentWindow.nativeInterface) {\r\n logger('Sending message %i to parent via framelessPostMessage interface', request.id);\r\n (Communication.currentWindow as ExtendedWindow).nativeInterface.framelessPostMessage(JSON.stringify(request));\r\n }\r\n } else {\r\n const targetOrigin = getTargetOrigin(targetWindow);\r\n\r\n // If the target window isn't closed and we already know its origin, send the message right away; otherwise,\r\n // queue the message and send it after the origin is established\r\n if (targetWindow && targetOrigin) {\r\n logger('Sending message %i to parent via postMessage', request.id);\r\n targetWindow.postMessage(request, targetOrigin);\r\n } else {\r\n logger('Adding message %i to parent message queue', request.id);\r\n getTargetMessageQueue(targetWindow).push(request);\r\n }\r\n }\r\n return request;\r\n}\r\n\r\n/**@internal */\r\nexport function processMessage(evt: DOMMessageEvent): void {\r\n // Process only if we received a valid message\r\n if (!evt || !evt.data || typeof evt.data !== 'object') {\r\n return;\r\n }\r\n\r\n // Process only if the message is coming from a different window and a valid origin\r\n // valid origins are either a pre-known\r\n const messageSource = evt.source || (evt.originalEvent && evt.originalEvent.source);\r\n const messageOrigin = evt.origin || (evt.originalEvent && evt.originalEvent.origin);\r\n if (!shouldProcessMessage(messageSource, messageOrigin)) {\r\n return;\r\n }\r\n\r\n // Update our parent and child relationships based on this message\r\n updateRelationships(messageSource, messageOrigin);\r\n\r\n // Handle the message\r\n if (messageSource === Communication.parentWindow) {\r\n handleParentMessage(evt);\r\n } else if (messageSource === Communication.childWindow) {\r\n handleChildMessage(evt);\r\n }\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Validates the message source and origin, if it should be processed\r\n *\r\n * @internal\r\n */\r\nexport function shouldProcessMessage(messageSource: Window, messageOrigin: string): boolean {\r\n // Process if message source is a different window and if origin is either in\r\n // Teams' pre-known whitelist or supplied as valid origin by user during initialization\r\n if (Communication.currentWindow && messageSource === Communication.currentWindow) {\r\n return false;\r\n } else if (\r\n Communication.currentWindow &&\r\n Communication.currentWindow.location &&\r\n messageOrigin &&\r\n messageOrigin === Communication.currentWindow.location.origin\r\n ) {\r\n return true;\r\n } else {\r\n return validateOrigin(new URL(messageOrigin));\r\n }\r\n}\r\n\r\n/**@internal */\r\nfunction updateRelationships(messageSource: Window, messageOrigin: string): void {\r\n // Determine whether the source of the message is our parent or child and update our\r\n // window and origin pointer accordingly\r\n // For frameless windows (i.e mobile), there is no parent frame, so the message must be from the child.\r\n if (\r\n !GlobalVars.isFramelessWindow &&\r\n (!Communication.parentWindow || Communication.parentWindow.closed || messageSource === Communication.parentWindow)\r\n ) {\r\n Communication.parentWindow = messageSource;\r\n Communication.parentOrigin = messageOrigin;\r\n } else if (\r\n !Communication.childWindow ||\r\n Communication.childWindow.closed ||\r\n messageSource === Communication.childWindow\r\n ) {\r\n Communication.childWindow = messageSource;\r\n Communication.childOrigin = messageOrigin;\r\n }\r\n\r\n // Clean up pointers to closed parent and child windows\r\n if (Communication.parentWindow && Communication.parentWindow.closed) {\r\n Communication.parentWindow = null;\r\n Communication.parentOrigin = null;\r\n }\r\n if (Communication.childWindow && Communication.childWindow.closed) {\r\n Communication.childWindow = null;\r\n Communication.childOrigin = null;\r\n }\r\n\r\n // If we have any messages in our queue, send them now\r\n flushMessageQueue(Communication.parentWindow);\r\n flushMessageQueue(Communication.childWindow);\r\n}\r\n\r\nconst handleParentMessageLogger = communicationLogger.extend('handleParentMessage');\r\n\r\n/**@internal */\r\nfunction handleParentMessage(evt: DOMMessageEvent): void {\r\n const logger = handleParentMessageLogger;\r\n\r\n if ('id' in evt.data && typeof evt.data.id === 'number') {\r\n // Call any associated Communication.callbacks\r\n const message = evt.data as MessageResponse;\r\n const callback = CommunicationPrivate.callbacks[message.id];\r\n logger('Received a response from parent for message %i', message.id);\r\n if (callback) {\r\n logger('Invoking the registered callback for message %i with arguments %o', message.id, message.args);\r\n callback.apply(null, [...message.args, message.isPartialResponse]);\r\n\r\n // Remove the callback to ensure that the callback is called only once and to free up memory if response is a complete response\r\n if (!isPartialResponse(evt)) {\r\n logger('Removing registered callback for message %i', message.id);\r\n delete CommunicationPrivate.callbacks[message.id];\r\n }\r\n }\r\n const promiseCallback = CommunicationPrivate.promiseCallbacks[message.id];\r\n if (promiseCallback) {\r\n logger('Invoking the registered promise callback for message %i with arguments %o', message.id, message.args);\r\n promiseCallback(message.args);\r\n\r\n logger('Removing registered promise callback for message %i', message.id);\r\n delete CommunicationPrivate.promiseCallbacks[message.id];\r\n }\r\n } else if ('func' in evt.data && typeof evt.data.func === 'string') {\r\n // Delegate the request to the proper handler\r\n const message = evt.data as MessageRequest;\r\n logger('Received an action message %s from parent', message.func);\r\n callHandler(message.func, message.args);\r\n } else {\r\n logger('Received an unknown message: %O', evt);\r\n }\r\n}\r\n\r\n/**@internal */\r\nfunction isPartialResponse(evt: DOMMessageEvent): boolean {\r\n return evt.data.isPartialResponse === true;\r\n}\r\n\r\n/**@internal */\r\nfunction handleChildMessage(evt: DOMMessageEvent): void {\r\n if ('id' in evt.data && 'func' in evt.data) {\r\n // Try to delegate the request to the proper handler, if defined\r\n const message = evt.data as MessageRequest;\r\n const [called, result] = callHandler(message.func, message.args);\r\n if (called && typeof result !== 'undefined') {\r\n sendMessageResponseToChild(message.id, Array.isArray(result) ? result : [result]);\r\n } else {\r\n // No handler, proxy to parent\r\n // tslint:disable-next-line:no-any\r\n sendMessageToParent(message.func, message.args, (...args: any[]): void => {\r\n if (Communication.childWindow) {\r\n const isPartialResponse = args.pop();\r\n sendMessageResponseToChild(message.id, args, isPartialResponse);\r\n }\r\n });\r\n }\r\n }\r\n}\r\n\r\n/**@internal */\r\nfunction getTargetMessageQueue(targetWindow: Window): MessageRequest[] {\r\n return targetWindow === Communication.parentWindow\r\n ? CommunicationPrivate.parentMessageQueue\r\n : targetWindow === Communication.childWindow\r\n ? CommunicationPrivate.childMessageQueue\r\n : [];\r\n}\r\n\r\n/**@internal */\r\nfunction getTargetOrigin(targetWindow: Window): string {\r\n return targetWindow === Communication.parentWindow\r\n ? Communication.parentOrigin\r\n : targetWindow === Communication.childWindow\r\n ? Communication.childOrigin\r\n : null;\r\n}\r\n\r\nconst flushMessageQueueLogger = communicationLogger.extend('flushMessageQueue');\r\n/**@internal */\r\nfunction flushMessageQueue(targetWindow: Window | any): void {\r\n const targetOrigin = getTargetOrigin(targetWindow);\r\n const targetMessageQueue = getTargetMessageQueue(targetWindow);\r\n const target = targetWindow == Communication.parentWindow ? 'parent' : 'child';\r\n while (targetWindow && targetOrigin && targetMessageQueue.length > 0) {\r\n const request = targetMessageQueue.shift();\r\n flushMessageQueueLogger('Flushing message %i from ' + target + ' message queue via postMessage.', request.id);\r\n targetWindow.postMessage(request, targetOrigin);\r\n }\r\n}\r\n\r\n/**@internal */\r\nexport function waitForMessageQueue(targetWindow: Window, callback: () => void): void {\r\n const messageQueueMonitor = Communication.currentWindow.setInterval(() => {\r\n if (getTargetMessageQueue(targetWindow).length === 0) {\r\n clearInterval(messageQueueMonitor);\r\n callback();\r\n }\r\n }, 100);\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Send a response to child for a message request that was from child\r\n *\r\n * @internal\r\n */\r\nfunction sendMessageResponseToChild(\r\n id: number,\r\n // tslint:disable-next-line:no-any\r\n args?: any[],\r\n isPartialResponse?: boolean,\r\n): void {\r\n const targetWindow = Communication.childWindow;\r\n const response = createMessageResponse(id, args, isPartialResponse);\r\n const targetOrigin = getTargetOrigin(targetWindow);\r\n if (targetWindow && targetOrigin) {\r\n targetWindow.postMessage(response, targetOrigin);\r\n }\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Send a custom message object that can be sent to child window,\r\n * instead of a response message to a child\r\n *\r\n * @internal\r\n */\r\nexport function sendMessageEventToChild(\r\n actionName: string,\r\n // tslint:disable-next-line: no-any\r\n args?: any[],\r\n): void {\r\n const targetWindow = Communication.childWindow;\r\n const customEvent = createMessageEvent(actionName, args);\r\n const targetOrigin = getTargetOrigin(targetWindow);\r\n\r\n // If the target window isn't closed and we already know its origin, send the message right away; otherwise,\r\n // queue the message and send it after the origin is established\r\n if (targetWindow && targetOrigin) {\r\n targetWindow.postMessage(customEvent, targetOrigin);\r\n } else {\r\n getTargetMessageQueue(targetWindow).push(customEvent);\r\n }\r\n}\r\n\r\n/**@internal */\r\n// tslint:disable-next-line:no-any\r\nfunction createMessageRequest(func: string, args: any[]): MessageRequest {\r\n return {\r\n id: CommunicationPrivate.nextMessageId++,\r\n func: func,\r\n timestamp: Date.now(),\r\n args: args || [],\r\n };\r\n}\r\n\r\n/**@internal */\r\n// tslint:disable-next-line:no-any\r\nfunction createMessageResponse(id: number, args: any[], isPartialResponse: boolean): MessageResponse {\r\n return {\r\n id: id,\r\n args: args || [],\r\n isPartialResponse,\r\n };\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Creates a message object without any id, used for custom actions being sent to child frame/window\r\n *\r\n * @internal\r\n */\r\n// tslint:disable-next-line:no-any\r\nfunction createMessageEvent(func: string, args: any[]): MessageRequest {\r\n return {\r\n func: func,\r\n args: args || [],\r\n };\r\n}\r\n","/* eslint-disable @typescript-eslint/no-explicit-any */\r\n\r\nimport { sendMessageToParent } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { runtime } from '../public/runtime';\r\n\r\n/**\r\n * @hidden\r\n * Namespace to interact with bots using the SDK.\r\n *\r\n * @alpha\r\n */\r\nexport namespace bot {\r\n /**\r\n * @hidden\r\n * Hide from docs until release.\r\n * ------\r\n * Sends query to bot in order to retrieve data.\r\n *\r\n * @param botRequest - query to send to bot.\r\n * @param onSuccess - callback to invoke when data is retrieved from bot\r\n * @param onError - callback to invoke should an error occur\r\n */\r\n export function sendQuery(\r\n botRequest: QueryRequest,\r\n onSuccess?: (data: QueryResponse) => void,\r\n onError?: (error: string) => void,\r\n ): void {\r\n ensureInitialized();\r\n\r\n sendMessageToParent('bot.executeQuery', [botRequest], (success: boolean, response: string | QueryResponse) => {\r\n if (success) {\r\n onSuccess(response as QueryResponse);\r\n } else {\r\n onError(response as string);\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs until release.\r\n * -----\r\n * Retrieves list of support commands from bot\r\n *\r\n * @param onSuccess - callback to invoke when data is retrieved from bot\r\n * @param onError - callback to invoke should an error occur\r\n */\r\n export function getSupportedCommands(\r\n onSuccess?: (response: Command[]) => void,\r\n onError?: (error: string) => void,\r\n ): void {\r\n ensureInitialized();\r\n\r\n sendMessageToParent('bot.getSupportedCommands', (success: boolean, response: string | Command[]) => {\r\n if (success) {\r\n onSuccess(response as Command[]);\r\n } else {\r\n onError(response as string);\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs until release.\r\n * -----\r\n * Authenticates a user for json tab\r\n *\r\n * @param authRequest - callback to invoke when data is retrieved from bot\r\n * @param onSuccess - callback to invoke when user is authenticated\r\n * @param onError - callback to invoke should an error occur\r\n */\r\n export function authenticate(\r\n authRequest: AuthQueryRequest,\r\n onSuccess?: (results: Results) => void,\r\n onError?: (error: string) => void,\r\n ): void {\r\n ensureInitialized();\r\n\r\n sendMessageToParent('bot.authenticate', [authRequest], (success: boolean, response: string | Results) => {\r\n if (success) {\r\n onSuccess(response as Results);\r\n } else {\r\n onError(response as string);\r\n }\r\n });\r\n }\r\n\r\n export interface QueryRequest {\r\n /**\r\n * @hidden\r\n * Query to search for\r\n */\r\n query: string;\r\n commandId?: string;\r\n option?: {\r\n skip: number;\r\n count: number;\r\n };\r\n }\r\n\r\n export interface Results {\r\n attachments: Attachment[];\r\n layout: any;\r\n botId: string;\r\n }\r\n\r\n export interface Auth {\r\n url: string;\r\n title: string;\r\n }\r\n\r\n export type ResponseType = 'Results' | 'Auth';\r\n interface Response<T extends ResponseType> {\r\n type: T;\r\n }\r\n export interface ResultResponse extends Response<'Results'> {\r\n data: Results;\r\n }\r\n export interface AuthResponse extends Response<'Auth'> {\r\n data: Auth;\r\n }\r\n export type QueryResponse = ResultResponse | AuthResponse;\r\n\r\n export interface AuthQueryRequest extends QueryRequest {\r\n url: string;\r\n }\r\n\r\n export interface Attachment {\r\n card: any;\r\n previewCard: any;\r\n previewRawPayload: any;\r\n rawPayload: any;\r\n }\r\n\r\n export interface Command {\r\n title: string;\r\n id: string;\r\n initialRun: boolean;\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.bot ? true : false;\r\n }\r\n}\r\n","import { FileOpenPreference, TeamInformation } from '../public/interfaces';\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Information about all members in a chat\r\n *\r\n * @alpha\r\n */\r\nexport interface ChatMembersInformation {\r\n members: ThreadMember[];\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Information about a chat member\r\n *\r\n * @alpha\r\n */\r\nexport interface ThreadMember {\r\n /**\r\n * @hidden\r\n * The member's user principal name in the current tenant.\r\n */\r\n upn: string;\r\n}\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport enum NotificationTypes {\r\n fileDownloadStart = 'fileDownloadStart',\r\n fileDownloadComplete = 'fileDownloadComplete',\r\n}\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport interface ShowNotificationParameters {\r\n message: string;\r\n notificationType: NotificationTypes;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * @alpha\r\n */\r\nexport enum ViewerActionTypes {\r\n view = 'view',\r\n edit = 'edit',\r\n editNew = 'editNew',\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * User setting changes that can be subscribed to,\r\n * @alpha\r\n */\r\nexport enum UserSettingTypes {\r\n /**\r\n * @hidden\r\n * Use this key to subscribe to changes in user's file open preference\r\n */\r\n fileOpenPreference = 'fileOpenPreference',\r\n /**\r\n * @hidden\r\n * Use this key to subscribe to theme changes\r\n */\r\n theme = 'theme',\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * @alpha\r\n */\r\nexport interface FilePreviewParameters {\r\n /**\r\n * @hidden\r\n * The developer-defined unique ID for the file.\r\n */\r\n entityId: string;\r\n\r\n /**\r\n * @hidden\r\n * The display name of the file.\r\n */\r\n title: string;\r\n\r\n /**\r\n * @hidden\r\n * An optional description of the file.\r\n */\r\n description?: string;\r\n\r\n /**\r\n * @hidden\r\n * The file extension; e.g. pptx, docx, etc.\r\n */\r\n type: string;\r\n\r\n /**\r\n * @hidden\r\n * A url to the source of the file, used to open the content in the user's default browser\r\n */\r\n objectUrl: string;\r\n\r\n /**\r\n * @hidden\r\n * Optional; an alternate self-authenticating url used to preview the file in Mobile clients and offer it for download by the user\r\n */\r\n downloadUrl?: string;\r\n\r\n /**\r\n * @hidden\r\n * Optional; an alternate url optimized for previewing the file in web and desktop clients\r\n */\r\n webPreviewUrl?: string;\r\n\r\n /**\r\n * @hidden\r\n * Optional; an alternate url that allows editing of the file in web and desktop clients\r\n */\r\n webEditUrl?: string;\r\n\r\n /**\r\n * @hidden\r\n * Optional; the base url of the site where the file is hosted\r\n */\r\n baseUrl?: string;\r\n\r\n /**\r\n * @hidden\r\n * Deprecated; prefer using viewerAction instead\r\n * Optional; indicates whether the file should be opened in edit mode\r\n */\r\n editFile?: boolean;\r\n\r\n /**\r\n * @hidden\r\n * Optional; the developer-defined unique ID for the sub-entity to return to when the file stage closes.\r\n * This field should be used to restore to a specific state within an entity, such as scrolling to or activating a specific piece of content.\r\n */\r\n subEntityId?: string;\r\n\r\n /**\r\n * @hidden\r\n * Optional; indicates the mode in which file should be opened. Takes precedence over edit mode.\r\n */\r\n viewerAction?: ViewerActionTypes;\r\n\r\n /**\r\n * @hidden\r\n * Optional; indicates how user prefers to open the file\r\n */\r\n fileOpenPreference?: FileOpenPreference;\r\n\r\n /**\r\n * Optional; id required to enable conversation button in files. Will be channel id in case file is shared in a channel or the chat id in p2p chat case.\r\n */\r\n conversationId?: string;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Query parameters used when fetching team information\r\n * @alpha\r\n */\r\nexport interface TeamInstanceParameters {\r\n /**\r\n * @hidden\r\n * Flag allowing to select favorite teams only\r\n */\r\n favoriteTeamsOnly?: boolean;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Information on userJoined Teams\r\n * @alpha\r\n */\r\nexport interface UserJoinedTeamsInformation {\r\n /**\r\n * @hidden\r\n * List of team information\r\n */\r\n userJoinedTeams: TeamInformation[];\r\n}\r\n","import {\r\n sendAndHandleStatusAndReason as sendAndHandleError,\r\n sendAndUnwrap,\r\n sendMessageToParent,\r\n} from '../internal/communication';\r\nimport { registerHandler, removeHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from '../public/constants';\r\nimport { OpenConversationRequest } from '../public/interfaces';\r\nimport { runtime } from '../public/runtime';\r\nimport { ChatMembersInformation } from './interfaces';\r\n\r\n/**\r\n * @hidden\r\n * Namespace to interact with the conversational subEntities inside the tab\r\n *\r\n * @alpha\r\n */\r\nexport namespace chat {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------------\r\n * Allows the user to start or continue a conversation with each subentity inside the tab\r\n *\r\n * @returns Promise resolved upon completion\r\n */\r\n export function openConversation(openConversationRequest: OpenConversationRequest): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n const sendPromise = sendAndHandleError('conversations.openConversation', {\r\n title: openConversationRequest.title,\r\n subEntityId: openConversationRequest.subEntityId,\r\n conversationId: openConversationRequest.conversationId,\r\n channelId: openConversationRequest.channelId,\r\n entityId: openConversationRequest.entityId,\r\n });\r\n if (openConversationRequest.onStartConversation) {\r\n registerHandler(\r\n 'startConversation',\r\n (subEntityId: string, conversationId: string, channelId: string, entityId: string) =>\r\n openConversationRequest.onStartConversation({\r\n subEntityId,\r\n conversationId,\r\n channelId,\r\n entityId,\r\n }),\r\n );\r\n }\r\n if (openConversationRequest.onCloseConversation) {\r\n registerHandler(\r\n 'closeConversation',\r\n (subEntityId: string, conversationId?: string, channelId?: string, entityId?: string) =>\r\n openConversationRequest.onCloseConversation({\r\n subEntityId,\r\n conversationId,\r\n channelId,\r\n entityId,\r\n }),\r\n );\r\n }\r\n resolve(sendPromise);\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------------\r\n * Allows the user to close the conversation in the right pane\r\n */\r\n export function closeConversation(): void {\r\n ensureInitialized(FrameContexts.content);\r\n sendMessageToParent('conversations.closeConversation');\r\n removeHandler('startConversation');\r\n removeHandler('closeConversation');\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Allows an app to retrieve information of all chat members\r\n * Because a malicious party run your content in a browser, this value should\r\n * be used only as a hint as to who the members are and never as proof of membership.\r\n *\r\n * @param callback The callback to invoke when the {@link ChatMembersInformation} object is retrieved.\r\n * @returns Promise resolved with information on all chat members\r\n *\r\n * @internal\r\n */\r\n export function getChatMembers(): Promise<ChatMembersInformation> {\r\n return new Promise<ChatMembersInformation>(resolve => {\r\n ensureInitialized();\r\n resolve(sendAndUnwrap('getChatMembers'));\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.chat ? true : false;\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from './constants';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace appInstallDialog {\r\n export interface OpenAppInstallDialogParams {\r\n appId: string;\r\n }\r\n\r\n export function openAppInstallDialog(openAPPInstallDialogParams: OpenAppInstallDialogParams): Promise<void> {\r\n return new Promise(resolve => {\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.settings,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n if (!isSupported()) {\r\n throw new Error('Not supported');\r\n }\r\n sendMessageToParent('appInstallDialog.openAppInstallDialog', [openAPPInstallDialogParams]);\r\n resolve();\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.appInstallDialog ? true : false;\r\n }\r\n}\r\n","/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\r\n/* eslint-disable @typescript-eslint/no-explicit-any */\r\n/* eslint-disable @typescript-eslint/ban-types */\r\n\r\nimport { sendMessageToParent } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { getGenericOnCompleteHandler } from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\n/**\r\n * @alpha\r\n */\r\nexport interface IAppWindow {\r\n /**\r\n * Send a message to the AppWindow.\r\n *\r\n * @param message - The message to send\r\n * @param onComplete - The callback to know if the postMessage has been success/failed.\r\n */\r\n postMessage(message: any, onComplete?: (status: boolean, reason?: string) => void): void;\r\n\r\n /**\r\n * Add a listener that will be called when an event is received from this AppWindow.\r\n *\r\n * @param type - The event to listen to. Currently the only supported type is 'message'.\r\n * @param listener - The listener that will be called\r\n */\r\n addEventListener(type: string, listener: Function): void;\r\n}\r\n\r\nexport class ChildAppWindow implements IAppWindow {\r\n /**\r\n * Send a message to the ChildAppWindow.\r\n *\r\n * @param message - The message to send\r\n * @param onComplete - The callback to know if the postMessage has been success/failed.\r\n */\r\n public postMessage(message: any, onComplete?: (status: boolean, reason?: string) => void): void {\r\n ensureInitialized();\r\n sendMessageToParent('messageForChild', [message], onComplete ? onComplete : getGenericOnCompleteHandler());\r\n }\r\n /**\r\n * Add a listener that will be called when an event is received from the ChildAppWindow.\r\n *\r\n * @param type - The event to listen to. Currently the only supported type is 'message'.\r\n * @param listener - The listener that will be called\r\n */\r\n public addEventListener(type: string, listener: (message: any) => void): void {\r\n if (type === 'message') {\r\n registerHandler('messageForParent', listener);\r\n }\r\n }\r\n}\r\n\r\nexport class ParentAppWindow implements IAppWindow {\r\n private static _instance: ParentAppWindow;\r\n public static get Instance(): IAppWindow {\r\n // Do you need arguments? Make it a regular method instead.\r\n return this._instance || (this._instance = new this());\r\n }\r\n\r\n /**\r\n * Send a message to the ParentAppWindow.\r\n *\r\n * @param message - The message to send\r\n * @param onComplete - The callback to know if the postMessage has been success/failed.\r\n */\r\n public postMessage(message: any, onComplete?: (status: boolean, reason?: string) => void): void {\r\n ensureInitialized(FrameContexts.task);\r\n sendMessageToParent('messageForParent', [message], onComplete ? onComplete : getGenericOnCompleteHandler());\r\n }\r\n\r\n /**\r\n * Add a listener that will be called when an event is received from the ParentAppWindow.\r\n *\r\n * @param type - The event to listen to. Currently the only supported type is 'message'.\r\n * @param listener - The listener that will be called\r\n */\r\n public addEventListener(type: string, listener: (message: any) => void): void {\r\n if (type === 'message') {\r\n registerHandler('messageForChild', listener);\r\n }\r\n }\r\n}\r\n","/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\r\n/* eslint-disable @typescript-eslint/ban-types */\r\n/* eslint-disable @typescript-eslint/no-unused-vars */\r\n\r\nimport { sendMessageToParent } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { getGenericOnCompleteHandler } from '../internal/utils';\r\nimport { ChildAppWindow, IAppWindow } from './appWindow';\r\nimport { FrameContexts } from './constants';\r\nimport { DialogInfo } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * Namespace to interact with the dialog module-specific part of the SDK.\r\n *\r\n * @remarks\r\n * This object is usable only on the content frame.\r\n *\r\n * @beta\r\n */\r\nexport namespace dialog {\r\n /**\r\n * Allows an app to open the dialog module.\r\n *\r\n * @param dialogInfo - An object containing the parameters of the dialog module\r\n * @param submitHandler - Handler to call when the task module is completed\r\n */\r\n export function open(\r\n dialogInfo: DialogInfo,\r\n submitHandler?: (err: string, result: string | object) => void,\r\n ): IAppWindow {\r\n ensureInitialized(FrameContexts.content, FrameContexts.sidePanel, FrameContexts.meetingStage);\r\n\r\n sendMessageToParent('tasks.startTask', [dialogInfo], submitHandler);\r\n return new ChildAppWindow();\r\n }\r\n\r\n /**\r\n * Update height/width dialog info properties.\r\n *\r\n * @param dialogInfo - An object containing width and height properties\r\n */\r\n export function resize(dialogInfo: DialogInfo): void {\r\n ensureInitialized(FrameContexts.content, FrameContexts.sidePanel, FrameContexts.task, FrameContexts.meetingStage);\r\n const { width, height, ...extra } = dialogInfo;\r\n\r\n if (!Object.keys(extra).length) {\r\n sendMessageToParent('tasks.updateTask', [dialogInfo]);\r\n } else {\r\n throw new Error('resize requires a dialogInfo argument containing only width and height');\r\n }\r\n }\r\n\r\n /**\r\n * Submit the dialog module.\r\n *\r\n * @param result - Contains the result to be sent to the bot or the app. Typically a JSON object or a serialized version of it\r\n * @param appIds - Helps to validate that the call originates from the same appId as the one that invoked the task module\r\n */\r\n export function submit(result?: string | object, appIds?: string | string[]): void {\r\n ensureInitialized(FrameContexts.content, FrameContexts.sidePanel, FrameContexts.task, FrameContexts.meetingStage);\r\n\r\n // Send tasks.completeTask instead of tasks.submitTask message for backward compatibility with Mobile clients\r\n sendMessageToParent('tasks.completeTask', [result, Array.isArray(appIds) ? appIds : [appIds]]);\r\n }\r\n\r\n /**\r\n * Send message to the parent from dialog\r\n *\r\n * @param message - The message to send\r\n * @param onComplete - The callback to know if the message to parent has been success/failed.\r\n */\r\n export function sendMessageToParentFromDialog(\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n message: any,\r\n onComplete?: (status: boolean, reason?: string) => void,\r\n ): void {\r\n ensureInitialized(FrameContexts.task);\r\n sendMessageToParent('messageForParent', [message], onComplete ? onComplete : getGenericOnCompleteHandler());\r\n }\r\n\r\n /**\r\n * Fucntion to call when an event is received from the Parent\r\n *\r\n * @param type - The event to listen to. Currently the only supported type is 'message'.\r\n * @param listener - listener - The listener that will be called.\r\n */\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n export function registerOnMessageFromParent(listener: (message: any) => void): void {\r\n ensureInitialized();\r\n registerHandler('messageForChild', listener);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.dialog ? true : false;\r\n }\r\n}\r\n","import { media } from '../public/media';\r\nimport { people } from '../public/people';\r\nimport {\r\n imageOutputFormatsAPISupportVersion,\r\n nonFullScreenVideoModeAPISupportVersion,\r\n videoAndImageMediaAPISupportVersion,\r\n} from './constants';\r\nimport { throwExceptionIfMobileApiIsNotSupported } from './internalAPIs';\r\n\r\n/**\r\n * @hidden\r\n * Helper function to create a blob from media chunks based on their sequence\r\n *\r\n * @internal\r\n */\r\nexport function createFile(assembleAttachment: media.AssembleAttachment[], mimeType: string): Blob {\r\n if (assembleAttachment == null || mimeType == null || assembleAttachment.length <= 0) {\r\n return null;\r\n }\r\n let file: Blob;\r\n let sequence = 1;\r\n assembleAttachment.sort((a, b) => (a.sequence > b.sequence ? 1 : -1));\r\n assembleAttachment.forEach(item => {\r\n if (item.sequence == sequence) {\r\n if (file) {\r\n file = new Blob([file, item.file], { type: mimeType });\r\n } else {\r\n file = new Blob([item.file], { type: mimeType });\r\n }\r\n sequence++;\r\n }\r\n });\r\n return file;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Helper function to convert Media chunks into another object type which can be later assemebled\r\n * Converts base 64 encoded string to byte array and then into an array of blobs\r\n *\r\n * @internal\r\n */\r\nexport function decodeAttachment(attachment: media.MediaChunk, mimeType: string): media.AssembleAttachment {\r\n if (attachment == null || mimeType == null) {\r\n return null;\r\n }\r\n const decoded = atob(attachment.chunk);\r\n const byteNumbers = new Array(decoded.length);\r\n for (let i = 0; i < decoded.length; i++) {\r\n byteNumbers[i] = decoded.charCodeAt(i);\r\n }\r\n const byteArray = new Uint8Array(byteNumbers);\r\n const blob: Blob = new Blob([byteArray], { type: mimeType });\r\n const assemble: media.AssembleAttachment = {\r\n sequence: attachment.chunkSequence,\r\n file: blob,\r\n };\r\n return assemble;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Function throws an SdkError if the media call is not supported on current mobile version, else undefined.\r\n * @throws an SdkError if the media call is not supported\r\n * @internal\r\n */\r\nexport function throwExceptionIfMediaCallIsNotSupportedOnMobile(mediaInputs: media.MediaInputs): void {\r\n if (isMediaCallForVideoAndImageInputs(mediaInputs)) {\r\n throwExceptionIfMobileApiIsNotSupported(videoAndImageMediaAPISupportVersion);\r\n } else if (isMediaCallForNonFullScreenVideoMode(mediaInputs)) {\r\n throwExceptionIfMobileApiIsNotSupported(nonFullScreenVideoModeAPISupportVersion);\r\n } else if (isMediaCallForImageOutputFormats(mediaInputs)) {\r\n throwExceptionIfMobileApiIsNotSupported(imageOutputFormatsAPISupportVersion);\r\n }\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Function returns true if the app has registered to listen to video controller events, else false.\r\n *\r\n * @internal\r\n */\r\nexport function isVideoControllerRegistered(mediaInputs: media.MediaInputs): boolean {\r\n if (\r\n mediaInputs.mediaType == media.MediaType.Video &&\r\n mediaInputs.videoProps &&\r\n mediaInputs.videoProps.videoController\r\n ) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Returns true if the mediaInput params are valid and false otherwise\r\n *\r\n * @internal\r\n */\r\nexport function validateSelectMediaInputs(mediaInputs: media.MediaInputs): boolean {\r\n if (mediaInputs == null || mediaInputs.maxMediaCount > 10) {\r\n return false;\r\n }\r\n return true;\r\n}\r\n\r\n/**\r\n * Returns true if the mediaInput params are called for mediatype Image and contains Image outputs formats, false otherwise\r\n */\r\nexport function isMediaCallForImageOutputFormats(mediaInputs: media.MediaInputs): boolean {\r\n if (mediaInputs?.mediaType == media.MediaType.Image && mediaInputs?.imageProps?.imageOutputFormats) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Returns true if the mediaInput params are called for mediatype VideoAndImage and false otherwise\r\n *\r\n * @internal\r\n */\r\nexport function isMediaCallForVideoAndImageInputs(mediaInputs: media.MediaInputs): boolean {\r\n if (mediaInputs && (mediaInputs.mediaType == media.MediaType.VideoAndImage || mediaInputs.videoAndImageProps)) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Returns true if the mediaInput params are called for non-full screen video mode and false otherwise\r\n *\r\n * @internal\r\n */\r\nexport function isMediaCallForNonFullScreenVideoMode(mediaInputs: media.MediaInputs): boolean {\r\n if (\r\n mediaInputs &&\r\n mediaInputs.mediaType == media.MediaType.Video &&\r\n mediaInputs.videoProps &&\r\n !mediaInputs.videoProps.isFullScreenMode\r\n ) {\r\n return true;\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Returns true if the get Media params are valid and false otherwise\r\n *\r\n * @internal\r\n */\r\nexport function validateGetMediaInputs(mimeType: string, format: media.FileFormat, content: string): boolean {\r\n if (mimeType == null || format == null || format != media.FileFormat.ID || content == null) {\r\n return false;\r\n }\r\n return true;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Returns true if the view images param is valid and false otherwise\r\n *\r\n * @internal\r\n */\r\nexport function validateViewImagesInput(uriList: media.ImageUri[]): boolean {\r\n if (uriList == null || uriList.length <= 0 || uriList.length > 10) {\r\n return false;\r\n }\r\n return true;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Returns true if the scan barcode param is valid and false otherwise\r\n *\r\n * @internal\r\n */\r\nexport function validateScanBarCodeInput(barCodeConfig: media.BarCodeConfig): boolean {\r\n if (barCodeConfig) {\r\n if (\r\n barCodeConfig.timeOutIntervalInSec === null ||\r\n barCodeConfig.timeOutIntervalInSec <= 0 ||\r\n barCodeConfig.timeOutIntervalInSec > 60\r\n ) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n}\r\n\r\n/**\r\n * @hidden\r\n * Returns true if the people picker params are valid and false otherwise\r\n *\r\n * @internal\r\n */\r\nexport function validatePeoplePickerInput(peoplePickerInputs: people.PeoplePickerInputs): boolean {\r\n if (peoplePickerInputs) {\r\n if (peoplePickerInputs.title) {\r\n if (typeof peoplePickerInputs.title !== 'string') {\r\n return false;\r\n }\r\n }\r\n\r\n if (peoplePickerInputs.setSelected) {\r\n if (typeof peoplePickerInputs.setSelected !== 'object') {\r\n return false;\r\n }\r\n }\r\n\r\n if (peoplePickerInputs.openOrgWideSearchInChatOrChannel) {\r\n if (typeof peoplePickerInputs.openOrgWideSearchInChatOrChannel !== 'boolean') {\r\n return false;\r\n }\r\n }\r\n if (peoplePickerInputs.singleSelect) {\r\n if (typeof peoplePickerInputs.singleSelect !== 'boolean') {\r\n return false;\r\n }\r\n }\r\n }\r\n return true;\r\n}\r\n","/* eslint-disable @typescript-eslint/explicit-member-accessibility */\r\n\r\nimport { sendAndHandleSdkError, sendMessageToParent, sendMessageToParentAsync } from '../internal/communication';\r\nimport {\r\n captureImageMobileSupportVersion,\r\n getMediaCallbackSupportVersion,\r\n mediaAPISupportVersion,\r\n nonFullScreenVideoModeAPISupportVersion,\r\n scanBarCodeAPIMobileSupportVersion,\r\n} from '../internal/constants';\r\nimport { GlobalVars } from '../internal/globalVars';\r\nimport { registerHandler, removeHandler } from '../internal/handlers';\r\nimport {\r\n ensureInitialized,\r\n isCurrentSDKVersionAtLeast,\r\n throwExceptionIfMobileApiIsNotSupported,\r\n} from '../internal/internalAPIs';\r\nimport {\r\n createFile,\r\n decodeAttachment,\r\n isVideoControllerRegistered,\r\n throwExceptionIfMediaCallIsNotSupportedOnMobile,\r\n validateGetMediaInputs,\r\n validateScanBarCodeInput,\r\n validateSelectMediaInputs,\r\n validateViewImagesInput,\r\n} from '../internal/mediaUtil';\r\nimport {\r\n callCallbackWithErrorOrResultFromPromiseAndReturnPromise,\r\n callCallbackWithSdkErrorFromPromiseAndReturnPromise,\r\n generateGUID,\r\n InputFunction,\r\n} from '../internal/utils';\r\nimport { FrameContexts, HostClientType } from './constants';\r\nimport { ErrorCode, SdkError } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace media {\r\n /**\r\n * Enum for file formats supported\r\n */\r\n export enum FileFormat {\r\n Base64 = 'base64',\r\n ID = 'id',\r\n }\r\n\r\n /**\r\n * File object that can be used to represent image or video or audio\r\n */\r\n export class File {\r\n /**\r\n * Content of the file. When format is Base64, this is the base64 content\r\n * When format is ID, this is id mapping to the URI\r\n * When format is base64 and app needs to use this directly in HTML tags, it should convert this to dataUrl.\r\n */\r\n public content: string;\r\n\r\n /**\r\n * Format of the content\r\n */\r\n public format: FileFormat;\r\n\r\n /**\r\n * Size of the file in KB\r\n */\r\n public size: number;\r\n\r\n /**\r\n * MIME type. This can be used for constructing a dataUrl, if needed.\r\n */\r\n public mimeType: string;\r\n\r\n /**\r\n * Optional: Name of the file\r\n */\r\n public name?: string;\r\n }\r\n\r\n /**\r\n * Launch camera, capture image or choose image from gallery and return the images as a File[] object\r\n *\r\n * @remarks\r\n * Note: Currently we support getting one File through this API, i.e. the file arrays size will be one.\r\n * Note: For desktop, this API is not supported. Promise will be rejected with ErrorCode.NotSupported.\r\n *\r\n * @returns A promise resolved with a collection of @see File objects or rejected with an @see SdkError\r\n */\r\n export function captureImage(): Promise<File[]>;\r\n /**\r\n * Launch camera, capture image or choose image from gallery and return the images as a File[] object\r\n *\r\n * @param callback - Callback to invoke when the image is captured.\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link media.captureImage media.captureImage(): Promise\\<File[]\\>} instead.\r\n *\r\n * @remarks\r\n * Note: Currently we support getting one File through this API, i.e. the file arrays size will be one.\r\n * Note: For desktop, this API is not supported. Callback will be resolved with ErrorCode.NotSupported.\r\n *\r\n */\r\n export function captureImage(callback: (error?: SdkError, files?: File[]) => void): void;\r\n export function captureImage(callback?: (error?: SdkError, files?: File[]) => void): Promise<File[]> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n\r\n const wrappedFunction: InputFunction<File[]> = () =>\r\n new Promise<File[]>(resolve => {\r\n if (!GlobalVars.isFramelessWindow) {\r\n throw { errorCode: ErrorCode.NOT_SUPPORTED_ON_PLATFORM };\r\n }\r\n\r\n if (!isCurrentSDKVersionAtLeast(captureImageMobileSupportVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n\r\n resolve(sendAndHandleSdkError('captureImage'));\r\n });\r\n\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise<File[]>(wrappedFunction, callback);\r\n }\r\n\r\n /**\r\n * Media object returned by the select Media API\r\n */\r\n export class Media extends File {\r\n constructor(that: Media = null) {\r\n super();\r\n if (that) {\r\n this.content = that.content;\r\n this.format = that.format;\r\n this.mimeType = that.mimeType;\r\n this.name = that.name;\r\n this.preview = that.preview;\r\n this.size = that.size;\r\n }\r\n }\r\n\r\n /**\r\n * A preview of the file which is a lightweight representation.\r\n * In case of images this will be a thumbnail/compressed image in base64 encoding.\r\n */\r\n public preview: string;\r\n\r\n /**\r\n * Gets the media in chunks irrespective of size, these chunks are assembled and sent back to the webapp as file/blob\r\n *\r\n * @returns A promise resolved with the @see Blob or rejected with a @see SdkError\r\n */\r\n public getMedia(): Promise<Blob>;\r\n /**\r\n * Gets the media in chunks irrespective of size, these chunks are assembled and sent back to the webapp as file/blob\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link media.Media.getMedia media.Media.getMedia(): Promise\\<Blob\\>} instead.\r\n *\r\n * @param callback - returns blob of media\r\n */\r\n public getMedia(callback: (error: SdkError, blob: Blob) => void): void;\r\n public getMedia(callback?: (error: SdkError, blob: Blob) => void): Promise<Blob> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n\r\n const wrappedFunction: InputFunction<Blob> = () =>\r\n new Promise<Blob>(resolve => {\r\n if (!isCurrentSDKVersionAtLeast(mediaAPISupportVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n if (!validateGetMediaInputs(this.mimeType, this.format, this.content)) {\r\n throw { errorCode: ErrorCode.INVALID_ARGUMENTS };\r\n }\r\n // Call the new get media implementation via callbacks if the client version is greater than or equal to '2.0.0'\r\n if (isCurrentSDKVersionAtLeast(getMediaCallbackSupportVersion)) {\r\n resolve(this.getMediaViaCallback());\r\n } else {\r\n resolve(this.getMediaViaHandler());\r\n }\r\n });\r\n\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise<Blob>(wrappedFunction, callback);\r\n }\r\n\r\n private getMediaViaCallback(): Promise<Blob> {\r\n return new Promise<Blob>((resolve, reject) => {\r\n const helper: MediaHelper = {\r\n mediaMimeType: this.mimeType,\r\n assembleAttachment: [],\r\n };\r\n const localUriId = [this.content];\r\n sendMessageToParent('getMedia', localUriId, (mediaResult: MediaResult) => {\r\n if (mediaResult && mediaResult.error) {\r\n reject(mediaResult.error);\r\n } else if (!mediaResult || !mediaResult.mediaChunk) {\r\n reject({ errorCode: ErrorCode.INTERNAL_ERROR, message: 'data received is null' });\r\n } else if (mediaResult.mediaChunk.chunkSequence <= 0) {\r\n const file = createFile(helper.assembleAttachment, helper.mediaMimeType);\r\n resolve(file);\r\n } else {\r\n // Keep pushing chunks into assemble attachment\r\n const assemble: AssembleAttachment = decodeAttachment(mediaResult.mediaChunk, helper.mediaMimeType);\r\n helper.assembleAttachment.push(assemble);\r\n }\r\n });\r\n });\r\n }\r\n\r\n private getMediaViaHandler(): Promise<Blob> {\r\n return new Promise<Blob>((resolve, reject) => {\r\n const actionName = generateGUID();\r\n const helper: MediaHelper = {\r\n mediaMimeType: this.mimeType,\r\n assembleAttachment: [],\r\n };\r\n const params = [actionName, this.content];\r\n this.content && sendMessageToParent('getMedia', params);\r\n\r\n registerHandler('getMedia' + actionName, (response: string) => {\r\n try {\r\n const mediaResult: MediaResult = JSON.parse(response);\r\n if (mediaResult.error) {\r\n reject(mediaResult.error);\r\n removeHandler('getMedia' + actionName);\r\n } else if (!mediaResult || !mediaResult.mediaChunk) {\r\n reject({ errorCode: ErrorCode.INTERNAL_ERROR, message: 'data received is null' });\r\n removeHandler('getMedia' + actionName);\r\n } else if (mediaResult.mediaChunk.chunkSequence <= 0) {\r\n // If the chunksequence number is less than equal to 0 implies EOF\r\n // create file/blob when all chunks have arrived and we get 0/-1 as chunksequence number\r\n const file = createFile(helper.assembleAttachment, helper.mediaMimeType);\r\n resolve(file);\r\n removeHandler('getMedia' + actionName);\r\n } else {\r\n // Keep pushing chunks into assemble attachment\r\n const assemble: AssembleAttachment = decodeAttachment(mediaResult.mediaChunk, helper.mediaMimeType);\r\n helper.assembleAttachment.push(assemble);\r\n }\r\n } catch (err) {\r\n // catch JSON.parse() errors\r\n reject({ errorCode: ErrorCode.INTERNAL_ERROR, message: 'Error parsing the response: ' + response });\r\n }\r\n });\r\n });\r\n }\r\n }\r\n\r\n /**\r\n * Input parameter supplied to the select Media API\r\n */\r\n export interface MediaInputs {\r\n /**\r\n * Only one media type can be selected at a time\r\n */\r\n mediaType: MediaType;\r\n\r\n /**\r\n * max limit of media allowed to be selected in one go, current max limit is 10 set by office lens.\r\n */\r\n maxMediaCount: number;\r\n\r\n /**\r\n * Additional properties for customization of select media - Image in mobile devices\r\n */\r\n imageProps?: ImageProps;\r\n\r\n /**\r\n * Additional properties for customization of select media - Video in mobile devices\r\n */\r\n videoProps?: VideoProps;\r\n\r\n /**\r\n * Additional properties for customization of select media - VideoAndImage in mobile devices\r\n */\r\n videoAndImageProps?: VideoAndImageProps;\r\n\r\n /**\r\n * Additional properties for audio capture flows.\r\n */\r\n audioProps?: AudioProps;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * All properties common to Image and Video Props\r\n */\r\n interface MediaProps {\r\n /**\r\n * @hidden\r\n * Optional; Lets the developer specify the media source, more than one can be specified.\r\n * Default value is both camera and gallery\r\n */\r\n sources?: Source[];\r\n\r\n /**\r\n * @hidden\r\n * Optional; Specify in which mode the camera will be opened.\r\n * Default value is Photo\r\n */\r\n startMode?: CameraStartMode;\r\n\r\n /**\r\n * @hidden\r\n * Optional; indicate if user is allowed to move between front and back camera\r\n * Default value is true\r\n */\r\n cameraSwitcher?: boolean;\r\n }\r\n\r\n /**\r\n * All properties in ImageProps are optional and have default values in the platform\r\n */\r\n export interface ImageProps extends MediaProps {\r\n /**\r\n * Optional; indicate if inking on the selected Image is allowed or not\r\n * Default value is true\r\n */\r\n ink?: boolean;\r\n\r\n /**\r\n * Optional; indicate if putting text stickers on the selected Image is allowed or not\r\n * Default value is true\r\n */\r\n textSticker?: boolean;\r\n\r\n /**\r\n * Optional; indicate if image filtering mode is enabled on the selected image\r\n * Default value is false\r\n */\r\n enableFilter?: boolean;\r\n\r\n /**\r\n * Optional; Lets the developer specify the image output formats, more than one can be specified.\r\n * Default value is Image.\r\n */\r\n imageOutputFormats?: ImageOutputFormats[];\r\n }\r\n\r\n /**\r\n * All properties in VideoProps are optional and have default values in the platform\r\n */\r\n export interface VideoProps extends MediaProps {\r\n /**\r\n * Optional; the maximum duration in seconds after which the recording should terminate automatically.\r\n * Default value is defined by the platform serving the API.\r\n */\r\n maxDuration?: number;\r\n\r\n /**\r\n * Optional; to determine if the video capturing flow needs to be launched\r\n * in Full Screen Mode (Lens implementation) or PictureInPicture Mode (Native implementation).\r\n * Default value is true, indicating video will always launch in Full Screen Mode via lens.\r\n */\r\n isFullScreenMode?: boolean;\r\n\r\n /**\r\n * Optional; controls the visibility of stop button in PictureInPicture Mode.\r\n * Default value is true, indicating the user will be able to stop the video.\r\n */\r\n isStopButtonVisible?: boolean;\r\n\r\n /**\r\n * Optional; setting VideoController will register your app to listen to the lifecycle events during the video capture flow.\r\n * Your app can also dynamically control the experience while capturing the video by notifying the host client.\r\n */\r\n videoController?: VideoController;\r\n }\r\n\r\n /**\r\n * All properties in VideoAndImageProps are optional and have default values in the platform\r\n */\r\n export interface VideoAndImageProps extends ImageProps, VideoProps {}\r\n\r\n /**\r\n * All properties in AudioProps are optional and have default values in the platform\r\n */\r\n export interface AudioProps {\r\n /**\r\n * Optional; the maximum duration in minutes after which the recording should terminate automatically\r\n * Default value is defined by the platform serving the API.\r\n */\r\n maxDuration?: number;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Base class which holds the callback and notifies events to the host client\r\n */\r\n abstract class MediaController<T> {\r\n protected controllerCallback: T;\r\n\r\n public constructor(controllerCallback: T) {\r\n this.controllerCallback = controllerCallback;\r\n }\r\n\r\n protected abstract getMediaType(): MediaType;\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * This function will be implemented by the respective media class which holds the logic\r\n * of specific events that needs to be notified to the app.\r\n * @param mediaEvent indicates the event signed by the host client to the app\r\n */\r\n protected abstract notifyEventToApp(mediaEvent: MediaControllerEvent): void;\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n *\r\n * Function to notify the host client to programatically control the experience\r\n * @param mediaEvent indicates what the event that needs to be signaled to the host client\r\n * @returns A promise resolved promise\r\n */\r\n protected notifyEventToHost(mediaEvent: MediaControllerEvent): Promise<void>;\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link media.MediaController.notifyEventToHost media.MediaController.notifyEventToHost(mediaEvent: MediaControllerEvent): Promise\\<void\\>} instead.\r\n *\r\n * Function to notify the host client to programatically control the experience\r\n * @param mediaEvent indicates what the event that needs to be signaled to the host client\r\n * Optional; @param callback is used to send app if host client has successfully handled the notification event or not\r\n */\r\n protected notifyEventToHost(mediaEvent: MediaControllerEvent, callback?: (err?: SdkError) => void): void;\r\n protected notifyEventToHost(mediaEvent: MediaControllerEvent, callback?: (err?: SdkError) => void): Promise<void> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n\r\n try {\r\n throwExceptionIfMobileApiIsNotSupported(nonFullScreenVideoModeAPISupportVersion);\r\n } catch (err) {\r\n const wrappedRejectedErrorFn: InputFunction<void> = () => Promise.reject(err);\r\n\r\n return callCallbackWithSdkErrorFromPromiseAndReturnPromise(wrappedRejectedErrorFn, callback);\r\n }\r\n\r\n const params: MediaControllerParam = {\r\n mediaType: this.getMediaType(),\r\n mediaControllerEvent: mediaEvent,\r\n };\r\n\r\n const wrappedFunction = (): Promise<void> =>\r\n new Promise(resolve => resolve(sendAndHandleSdkError('media.controller', [params])));\r\n\r\n return callCallbackWithSdkErrorFromPromiseAndReturnPromise(wrappedFunction, callback);\r\n }\r\n\r\n /**\r\n * Function to programatically stop the ongoing media event\r\n *\r\n * @returns A resolved promise\r\n * */\r\n public stop(): Promise<void>;\r\n /**\r\n *\r\n * Function to programatically stop the ongoing media event\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link media.MediaController.stop media.MediaController.stop(): Promise\\<void\\>} instead.\r\n *\r\n * Optional; @param callback is used to send app if host client has successfully stopped the event or not\r\n */\r\n public stop(callback?: (err?: SdkError) => void): void;\r\n public stop(callback?: (err?: SdkError) => void): Promise<void> {\r\n return Promise.resolve(this.notifyEventToHost(MediaControllerEvent.StopRecording, callback));\r\n }\r\n }\r\n\r\n /**\r\n * Callback which will register your app to listen to lifecycle events during the video capture flow\r\n */\r\n export interface VideoControllerCallback {\r\n onRecordingStarted(): void;\r\n onRecordingStopped?(): void;\r\n }\r\n\r\n /**\r\n * VideoController class is used to communicate between the app and the host client during the video capture flow\r\n */\r\n export class VideoController extends MediaController<VideoControllerCallback> {\r\n protected getMediaType(): MediaType {\r\n return MediaType.Video;\r\n }\r\n\r\n public notifyEventToApp(mediaEvent: MediaControllerEvent): void {\r\n switch (mediaEvent) {\r\n case MediaControllerEvent.StartRecording:\r\n this.controllerCallback.onRecordingStarted();\r\n break;\r\n // TODO - Should discuss whether this function should be required\r\n case MediaControllerEvent.StopRecording:\r\n this.controllerCallback.onRecordingStopped && this.controllerCallback.onRecordingStopped();\r\n break;\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Events which are used to communicate between the app and the host client during the media recording flow\r\n */\r\n export enum MediaControllerEvent {\r\n StartRecording = 1,\r\n StopRecording = 2,\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Interface with relevant info to send communication from the app to the host client\r\n */\r\n interface MediaControllerParam {\r\n /**\r\n * List of team information\r\n */\r\n mediaType: media.MediaType;\r\n\r\n /**\r\n * List of team information\r\n */\r\n mediaControllerEvent: MediaControllerEvent;\r\n }\r\n\r\n /**\r\n * The modes in which camera can be launched in select Media API\r\n */\r\n export enum CameraStartMode {\r\n Photo = 1,\r\n Document = 2,\r\n Whiteboard = 3,\r\n BusinessCard = 4,\r\n }\r\n\r\n /**\r\n * Specifies the image source\r\n */\r\n export enum Source {\r\n Camera = 1,\r\n Gallery = 2,\r\n }\r\n\r\n /**\r\n * Specifies the type of Media\r\n */\r\n export enum MediaType {\r\n Image = 1,\r\n Video = 2,\r\n VideoAndImage = 3,\r\n Audio = 4,\r\n }\r\n\r\n /**\r\n * Input for view images API\r\n */\r\n export interface ImageUri {\r\n value: string;\r\n type: ImageUriType;\r\n }\r\n\r\n /**\r\n * ID contains a mapping for content uri on platform's side, URL is generic\r\n */\r\n export enum ImageUriType {\r\n ID = 1,\r\n URL = 2,\r\n }\r\n\r\n /**\r\n * Specifies the image output formats.\r\n */\r\n export enum ImageOutputFormats {\r\n IMAGE = 1,\r\n PDF = 2,\r\n }\r\n\r\n /**\r\n * Media chunks an output of getMedia API from platform\r\n */\r\n export interface MediaChunk {\r\n /**\r\n * Base 64 data for the requested uri\r\n */\r\n chunk: string;\r\n\r\n /**\r\n * chunk sequence number\r\n */\r\n chunkSequence: number;\r\n }\r\n\r\n /**\r\n * Output of getMedia API from platform\r\n */\r\n export interface MediaResult {\r\n /**\r\n * error encountered in getMedia API\r\n */\r\n error: SdkError;\r\n\r\n /**\r\n * Media chunk which will be assemebled and converted into a blob\r\n */\r\n mediaChunk: MediaChunk;\r\n }\r\n\r\n /**\r\n * Helper object to assembled media chunks\r\n */\r\n export interface AssembleAttachment {\r\n sequence: number;\r\n file: Blob;\r\n }\r\n\r\n /**\r\n * Helper class for assembling media\r\n */\r\n interface MediaHelper {\r\n mediaMimeType: string;\r\n assembleAttachment: AssembleAttachment[];\r\n }\r\n\r\n /**\r\n * Select an attachment using camera/gallery\r\n *\r\n * @param mediaInputs - The input params to customize the media to be selected\r\n * @returns A promise resolved with an array of media data or rejected with an @see SdkError\r\n */\r\n export function selectMedia(mediaInputs: MediaInputs): Promise<Media[]>;\r\n /**\r\n * Select an attachment using camera/gallery\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link media.selectMedia media.selectMedia(mediaInputs: MediaInputs): Promise\\<Media[]\\>} instead.\r\n *\r\n * @param mediaInputs - The input params to customize the media to be selected\r\n * @param callback - The callback to invoke after fetching the media\r\n */\r\n export function selectMedia(mediaInputs: MediaInputs, callback: (error: SdkError, attachments: Media[]) => void);\r\n export function selectMedia(\r\n mediaInputs: MediaInputs,\r\n callback?: (error?: SdkError, attachments?: Media[]) => void,\r\n ): Promise<Media[]> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n\r\n const wrappedFunction: InputFunction<Media[]> = () =>\r\n new Promise<[SdkError, Media[], MediaControllerEvent]>(resolve => {\r\n if (!isCurrentSDKVersionAtLeast(mediaAPISupportVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n throwExceptionIfMediaCallIsNotSupportedOnMobile(mediaInputs);\r\n\r\n if (!validateSelectMediaInputs(mediaInputs)) {\r\n throw { errorCode: ErrorCode.INVALID_ARGUMENTS };\r\n }\r\n\r\n const params = [mediaInputs];\r\n // What comes back from native at attachments would just be objects and will be missing getMedia method on them.\r\n resolve(sendMessageToParentAsync<[SdkError, Media[], MediaControllerEvent]>('selectMedia', params));\r\n }).then(([err, localAttachments, mediaEvent]: [SdkError, Media[], MediaControllerEvent]) => {\r\n // MediaControllerEvent response is used to notify the app about events and is a partial response to selectMedia\r\n if (mediaEvent) {\r\n if (isVideoControllerRegistered(mediaInputs)) {\r\n mediaInputs.videoProps.videoController.notifyEventToApp(mediaEvent);\r\n }\r\n return [];\r\n }\r\n\r\n // Media Attachments are final response to selectMedia\r\n if (!localAttachments) {\r\n throw err;\r\n }\r\n const mediaArray: Media[] = [];\r\n for (const attachment of localAttachments) {\r\n mediaArray.push(new Media(attachment));\r\n }\r\n return mediaArray;\r\n });\r\n\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise<Media[]>(wrappedFunction, callback);\r\n }\r\n\r\n /**\r\n * View images using native image viewer\r\n *\r\n * @param uriList - list of URIs for images to be viewed - can be content URI or server URL. Supports up to 10 Images in a single call\r\n * @returns A promise resolved when the viewing action is completed or rejected with an @see SdkError\r\n */\r\n export function viewImages(uriList: ImageUri[]): Promise<void>;\r\n /**\r\n * View images using native image viewer\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link media.viewImages media.viewImages(uriList: ImageUri[]): Promise\\<void\\>} instead.\r\n *\r\n * @param uriList - list of URIs for images to be viewed - can be content URI or server URL. Supports up to 10 Images in a single call\r\n * @param callback - returns back error if encountered, returns null in case of success\r\n */\r\n export function viewImages(uriList: ImageUri[], callback: (error?: SdkError) => void);\r\n export function viewImages(uriList: ImageUri[], callback?: (error?: SdkError) => void): Promise<void> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n\r\n const wrappedFunction: InputFunction<void> = () =>\r\n new Promise<void>(resolve => {\r\n if (!isCurrentSDKVersionAtLeast(mediaAPISupportVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n if (!validateViewImagesInput(uriList)) {\r\n throw { errorCode: ErrorCode.INVALID_ARGUMENTS };\r\n }\r\n\r\n resolve(sendAndHandleSdkError('viewImages', uriList));\r\n });\r\n\r\n return callCallbackWithSdkErrorFromPromiseAndReturnPromise<void>(wrappedFunction, callback);\r\n }\r\n\r\n /**\r\n * Barcode configuration supplied to scanBarCode API to customize barcode scanning experience in mobile\r\n * All properties in BarCodeConfig are optional and have default values in the platform\r\n */\r\n export interface BarCodeConfig {\r\n /**\r\n * Optional; Lets the developer specify the scan timeout interval in seconds\r\n * Default value is 30 seconds and max allowed value is 60 seconds\r\n */\r\n timeOutIntervalInSec?: number;\r\n }\r\n\r\n /**\r\n * Scan Barcode/QRcode using camera\r\n *\r\n * @remarks\r\n * Note: For desktop and web, this API is not supported. Callback will be resolved with ErrorCode.NotSupported.\r\n *\r\n * @param config - optional input configuration to customize the barcode scanning experience\r\n * @returns A promise resolved with the barcode data or rejected with an @see SdkError\r\n */\r\n export function scanBarCode(config?: BarCodeConfig): Promise<string>;\r\n /**\r\n * Scan Barcode/QRcode using camera\r\n *\r\n * @remarks\r\n * Note: For desktop and web, this API is not supported. Callback will be resolved with ErrorCode.NotSupported.\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link media.scanBarCode media.scanBarCode(config?: BarCodeConfig): Promise\\<string\\>} instead.\r\n *\r\n * @param callback - callback to invoke after scanning the barcode\r\n * @param config - optional input configuration to customize the barcode scanning experience\r\n */\r\n export function scanBarCode(callback: (error: SdkError, decodedText: string) => void, config?: BarCodeConfig);\r\n export function scanBarCode(\r\n callbackOrConfig?: ((error: SdkError, decodedText: string) => void) | BarCodeConfig,\r\n configMaybe?: BarCodeConfig,\r\n ): Promise<string> {\r\n let callback: (error: SdkError, decodedText: string) => void | undefined;\r\n let config: BarCodeConfig | undefined;\r\n\r\n // Because the callback isn't the second parameter in the original v1 method we need to\r\n // do a bit of trickery to see which of the two ways were used to call into\r\n // the flow and if the first parameter is a callback (v1) or a config object (v2)\r\n\r\n if (callbackOrConfig === undefined) {\r\n // no first parameter - the second one might be a config, definitely no callback\r\n config = configMaybe;\r\n } else {\r\n if (typeof callbackOrConfig === 'object') {\r\n // the first parameter is an object - it's the config! No callback.\r\n config = callbackOrConfig;\r\n } else {\r\n // otherwise, it's a function, so a callback. The second parameter might be a callback\r\n callback = callbackOrConfig;\r\n config = configMaybe;\r\n }\r\n }\r\n\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n\r\n const wrappedFunction: InputFunction<string> = () =>\r\n new Promise<string>(resolve => {\r\n if (\r\n GlobalVars.hostClientType === HostClientType.desktop ||\r\n GlobalVars.hostClientType === HostClientType.web ||\r\n GlobalVars.hostClientType === HostClientType.rigel ||\r\n GlobalVars.hostClientType === HostClientType.teamsRoomsWindows ||\r\n GlobalVars.hostClientType === HostClientType.teamsRoomsAndroid ||\r\n GlobalVars.hostClientType === HostClientType.teamsPhones ||\r\n GlobalVars.hostClientType === HostClientType.teamsDisplays\r\n ) {\r\n throw { errorCode: ErrorCode.NOT_SUPPORTED_ON_PLATFORM };\r\n }\r\n\r\n if (!isCurrentSDKVersionAtLeast(scanBarCodeAPIMobileSupportVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n\r\n if (!validateScanBarCodeInput(config)) {\r\n throw { errorCode: ErrorCode.INVALID_ARGUMENTS };\r\n }\r\n\r\n resolve(sendAndHandleSdkError('media.scanBarCode', config));\r\n });\r\n\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise<string>(wrappedFunction, callback);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.media ? true : false;\r\n }\r\n}\r\n","import { sendAndHandleSdkError as sendAndHandleError } from '../internal/communication';\r\nimport { locationAPIsRequiredVersion } from '../internal/constants';\r\nimport { ensureInitialized, isCurrentSDKVersionAtLeast } from '../internal/internalAPIs';\r\nimport {\r\n callCallbackWithErrorOrBooleanFromPromiseAndReturnPromise,\r\n callCallbackWithErrorOrResultFromPromiseAndReturnPromise,\r\n} from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\nimport { ErrorCode, SdkError } from './interfaces';\r\nimport { runtime } from './runtime';\r\n/**\r\n * @alpha\r\n */\r\nexport namespace location {\r\n export interface LocationProps {\r\n /**\r\n whether user can alter location or not\r\n if false, user will be shown current location \r\n and wouldn't be allowed to alter it\r\n */\r\n allowChooseLocation: boolean;\r\n /**\r\n whether selected location should be shown to user on map or not.\r\n If allowChooseLocation is true, this parameter will be ignored by platform.\r\n If allowChooseLocation is false, and this parameter is not provided, default \r\n value will be false.\r\n */\r\n showMap?: boolean;\r\n }\r\n\r\n export interface Location {\r\n /**\r\n Latitude of the location\r\n */\r\n latitude: number;\r\n /**\r\n Longitude of the location\r\n */\r\n longitude: number;\r\n /**\r\n Accuracy of the coordinates captured\r\n */\r\n accuracy?: number;\r\n /**\r\n Time stamp when the location was captured\r\n */\r\n timestamp?: number;\r\n }\r\n\r\n /**\r\n * Fetches current user coordinates or allows user to choose location on map\r\n *\r\n * @param props {@link LocationProps} - Specifying how the location request is handled\r\n * @returns Promise that will be fulfilled when the operation has completed\r\n */\r\n export function getLocation(props: LocationProps): Promise<Location>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link location.getLocation location.getLocation(props: LocationProps): Promise\\<Location\\>} instead.\r\n * @param props {@link LocationProps} - Specifying how the location request is handled\r\n * @param callback - Callback to invoke when current user location is fetched\r\n */\r\n export function getLocation(props: LocationProps, callback: (error: SdkError, location: Location) => void): void;\r\n export function getLocation(\r\n props: LocationProps,\r\n callback?: (error: SdkError, location: Location) => void,\r\n ): Promise<Location> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise<Location>(getLocationHelper, callback, props);\r\n }\r\n\r\n function getLocationHelper(props: LocationProps): Promise<Location> {\r\n return new Promise<Location>(resolve => {\r\n if (!isCurrentSDKVersionAtLeast(locationAPIsRequiredVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n if (!props) {\r\n throw { errorCode: ErrorCode.INVALID_ARGUMENTS };\r\n }\r\n resolve(sendAndHandleError('location.getLocation', props));\r\n });\r\n }\r\n\r\n /**\r\n * Shows the location on map corresponding to the given coordinates\r\n *\r\n * @param location {@link Location} - which needs to be shown on map\r\n * @returns Promise that will be fulfilled when the operation has completed\r\n */\r\n export function showLocation(location: Location): Promise<void>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link location.showLocation location.showLocation(location: Location): Promise\\<void\\>} instead.\r\n * Shows the location on map corresponding to the given coordinates\r\n * @param location {@link Location} - which needs to be shown on map\r\n * @param callback - Callback to invoke when the location is opened on map\r\n */\r\n export function showLocation(location: Location, callback: (error: SdkError, status: boolean) => void): void;\r\n export function showLocation(\r\n location: Location,\r\n callback?: (error: SdkError, status: boolean) => void,\r\n ): Promise<void> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task);\r\n return callCallbackWithErrorOrBooleanFromPromiseAndReturnPromise<void>(showLocationHelper, callback, location);\r\n }\r\n\r\n export function showLocationHelper(location: Location): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n if (!isCurrentSDKVersionAtLeast(locationAPIsRequiredVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n if (!location) {\r\n throw { errorCode: ErrorCode.INVALID_ARGUMENTS };\r\n }\r\n resolve(sendAndHandleError('location.showLocation', location));\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.location ? true : false;\r\n }\r\n}\r\n","import { sendAndHandleSdkError } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport {\r\n callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise,\r\n callCallbackWithSdkErrorFromPromiseAndReturnPromise,\r\n} from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\nimport { SdkError } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace meeting {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * Data structure to represent a meeting details.\r\n *\r\n * @internal\r\n */\r\n export interface IMeetingDetails {\r\n /**\r\n * @hidden\r\n * details object\r\n */\r\n details: IDetails;\r\n /**\r\n * @hidden\r\n * conversation object\r\n */\r\n conversation: IConversation;\r\n /**\r\n * @hidden\r\n * organizer object\r\n */\r\n organizer: IOrganizer;\r\n }\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * Data structure to represent details.\r\n *\r\n * @internal\r\n */\r\n export interface IDetails {\r\n /**\r\n * @hidden\r\n * Scheduled start time of the meeting\r\n */\r\n scheduledStartTime: string;\r\n /**\r\n * @hidden\r\n * Scheduled end time of the meeting\r\n */\r\n scheduledEndTime: string;\r\n /**\r\n * @hidden\r\n * url to join the current meeting\r\n */\r\n joinUrl?: string;\r\n /**\r\n * @hidden\r\n * meeting title name of the meeting\r\n */\r\n title?: string;\r\n /**\r\n * @hidden\r\n * type of the meeting\r\n */\r\n type?: MeetingType;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * Data structure to represent a conversation object.\r\n *\r\n * @internal\r\n */\r\n export interface IConversation {\r\n /**\r\n * @hidden\r\n * conversation id of the meeting\r\n */\r\n id: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * Data structure to represent an organizer object.\r\n *\r\n * @internal\r\n */\r\n export interface IOrganizer {\r\n /**\r\n * @hidden\r\n * organizer id of the meeting\r\n */\r\n id?: string;\r\n /**\r\n * @hidden\r\n * tenant id of the meeting\r\n */\r\n tenantId?: string;\r\n }\r\n\r\n export interface LiveStreamState {\r\n /**\r\n * indicates whether meeting is streaming\r\n */\r\n isStreaming: boolean;\r\n\r\n /**\r\n * error object in case there is a failure\r\n */\r\n error?: {\r\n /** error code from the streaming service, e.g. IngestionFailure */\r\n code: string;\r\n /** detailed error message string */\r\n message?: string;\r\n };\r\n }\r\n\r\n export interface IAppContentStageSharingState {\r\n /**\r\n * indicates whether app is currently being shared to stage\r\n */\r\n isAppSharing: boolean;\r\n }\r\n\r\n export interface IAppContentStageSharingCapabilities {\r\n /**\r\n * indicates whether app has permission to share contents to meeting stage\r\n */\r\n doesAppHaveSharePermission: boolean;\r\n }\r\n\r\n export enum MeetingType {\r\n Unknown = 'Unknown',\r\n Adhoc = 'Adhoc',\r\n Scheduled = 'Scheduled',\r\n Recurring = 'Recurring',\r\n Broadcast = 'Broadcast',\r\n MeetNow = 'MeetNow',\r\n }\r\n\r\n /**\r\n * Allows an app to get the incoming audio speaker setting for the meeting user\r\n *\r\n * @remarks\r\n * error can either contain an error of type SdkError, incase of an error, or null when fetch is successful\r\n * result can either contain the true/false value, incase of a successful fetch or null when the fetching fails\r\n *\r\n * @returns Promise result where true means incoming audio is muted and false means incoming audio is unmuted\r\n */\r\n export function getIncomingClientAudioState(): Promise<boolean>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.getIncomingClientAudioState meeting.getIncomingClientAudioState(): Promise\\<boolean\\>} instead.\r\n *\r\n * Allows an app to get the incoming audio speaker setting for the meeting user\r\n *\r\n * @param callback - Callback contains 2 parameters, error and result.\r\n * error can either contain an error of type SdkError, incase of an error, or null when fetch is successful\r\n * result can either contain the true/false value, incase of a successful fetch or null when the fetching fails\r\n * result: True means incoming audio is muted and false means incoming audio is unmuted\r\n */\r\n export function getIncomingClientAudioState(callback: (error: SdkError | null, result: boolean | null) => void): void;\r\n export function getIncomingClientAudioState(\r\n callback?: (error: SdkError | null, result: boolean | null) => void,\r\n ): Promise<boolean> {\r\n ensureInitialized(FrameContexts.sidePanel, FrameContexts.meetingStage);\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<boolean>(\r\n getIncomingClientAudioStateHelper,\r\n callback,\r\n );\r\n }\r\n\r\n function getIncomingClientAudioStateHelper(): Promise<boolean> {\r\n return new Promise<boolean>(resolve => {\r\n resolve(sendAndHandleSdkError('getIncomingClientAudioState'));\r\n });\r\n }\r\n\r\n /**\r\n * Allows an app to toggle the incoming audio speaker setting for the meeting user from mute to unmute or vice-versa\r\n *\r\n * @remarks\r\n * error can either contain an error of type SdkError, incase of an error, or null when toggle is successful\r\n * result can either contain the true/false value, incase of a successful toggle or null when the toggling fails\r\n *\r\n * @returns Promise result where true means incoming audio is muted and false means incoming audio is unmuted or rejected promise containing SdkError details\r\n */\r\n export function toggleIncomingClientAudio(): Promise<boolean>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.toggleIncomingClientAudio meeting.toggleIncomingClientAudio(): Promise\\<boolean\\>} instead.\r\n *\r\n * @param callback - Callback contains 2 parameters, error and result.\r\n * error can either contain an error of type SdkError, incase of an error, or null when toggle is successful\r\n * result can either contain the true/false value, incase of a successful toggle or null when the toggling fails\r\n * result: True means incoming audio is muted and false means incoming audio is unmuted\r\n */\r\n export function toggleIncomingClientAudio(callback: (error: SdkError | null, result: boolean | null) => void): void;\r\n export function toggleIncomingClientAudio(\r\n callback?: (error: SdkError | null, result: boolean | null) => void,\r\n ): Promise<boolean> {\r\n ensureInitialized(FrameContexts.sidePanel, FrameContexts.meetingStage);\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<boolean>(\r\n toggleIncomingClientAudioHelper,\r\n callback,\r\n );\r\n }\r\n\r\n function toggleIncomingClientAudioHelper(): Promise<boolean> {\r\n return new Promise<boolean>(resolve => {\r\n resolve(sendAndHandleSdkError('toggleIncomingClientAudio'));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Allows an app to get the meeting details for the meeting\r\n *\r\n * @returns Promise containing the meeting details in IMeetingDetails form or rejected promise containing SdkError details\r\n *\r\n * @internal\r\n */\r\n export function getMeetingDetails(): Promise<IMeetingDetails>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.getMeetingDetails meeting.getMeetingDetails(): Promise\\<IMeetingDetails\\>} instead.\r\n *\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Allows an app to get the meeting details for the meeting\r\n *\r\n * @param callback - Callback contains 2 parameters, error and meetingDetails.\r\n * error can either contain an error of type SdkError, incase of an error, or null when get is successful\r\n * result can either contain a IMeetingDetails value, incase of a successful get or null when the get fails\r\n *\r\n * @internal\r\n */\r\n export function getMeetingDetails(\r\n callback: (error: SdkError | null, meetingDetails: IMeetingDetails | null) => void,\r\n ): void;\r\n export function getMeetingDetails(\r\n callback?: (error: SdkError | null, meetingDetails: IMeetingDetails | null) => void,\r\n ): Promise<IMeetingDetails> {\r\n ensureInitialized(\r\n FrameContexts.sidePanel,\r\n FrameContexts.meetingStage,\r\n FrameContexts.settings,\r\n FrameContexts.content,\r\n );\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<IMeetingDetails>(\r\n getMeetingDetailsHelper,\r\n callback,\r\n );\r\n }\r\n\r\n function getMeetingDetailsHelper(): Promise<IMeetingDetails> {\r\n return new Promise<IMeetingDetails>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.getMeetingDetails'));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Allows an app to get the authentication token for the anonymous or guest user in the meeting\r\n *\r\n * @returns Promise containing the token or rejected promise containing SdkError details\r\n *\r\n * @internal\r\n */\r\n export function getAuthenticationTokenForAnonymousUser(): Promise<string>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.getAuthenticationTokenForAnonymousUser meeting.getAuthenticationTokenForAnonymousUser(): Promise\\<string\\>} instead.\r\n *\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Allows an app to get the authentication token for the anonymous or guest user in the meeting\r\n * @param callback - Callback contains 2 parameters, error and authenticationTokenOfAnonymousUser.\r\n * error can either contain an error of type SdkError, incase of an error, or null when get is successful\r\n * authenticationTokenOfAnonymousUser can either contain a string value, incase of a successful get or null when the get fails\r\n *\r\n * @internal\r\n */\r\n export function getAuthenticationTokenForAnonymousUser(\r\n callback: (error: SdkError | null, authenticationTokenOfAnonymousUser: string | null) => void,\r\n ): void;\r\n export function getAuthenticationTokenForAnonymousUser(\r\n callback?: (error: SdkError | null, authenticationTokenOfAnonymousUser: string | null) => void,\r\n ): Promise<string> {\r\n ensureInitialized(FrameContexts.sidePanel, FrameContexts.meetingStage);\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<string>(\r\n getAuthenticationTokenForAnonymousUserHelper,\r\n callback,\r\n );\r\n }\r\n\r\n function getAuthenticationTokenForAnonymousUserHelper(): Promise<string> {\r\n return new Promise<string>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.getAuthenticationTokenForAnonymousUser'));\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.meeting ? true : false;\r\n }\r\n\r\n /**\r\n * Allows an app to get the state of the live stream in the current meeting\r\n *\r\n * @returns Promise containing the LiveStreamState value or rejected promise containing SdkError details\r\n */\r\n export function getLiveStreamState(): Promise<LiveStreamState>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.getLiveStreamState meeting.getLiveStreamState(): Promise\\<LiveStreamState\\>} instead.\r\n *\r\n * Allows an app to get the state of the live stream in the current meeting\r\n *\r\n * @param callback - Callback contains 2 parameters: error and liveStreamState.\r\n * error can either contain an error of type SdkError, in case of an error, or null when get is successful\r\n * liveStreamState can either contain a LiveStreamState value, or null when operation fails\r\n */\r\n export function getLiveStreamState(\r\n callback: (error: SdkError | null, liveStreamState: LiveStreamState | null) => void,\r\n ): void;\r\n export function getLiveStreamState(\r\n callback?: (error: SdkError | null, liveStreamState: LiveStreamState | null) => void,\r\n ): Promise<LiveStreamState> {\r\n ensureInitialized();\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<LiveStreamState>(\r\n getLiveStreamStateHelper,\r\n callback,\r\n );\r\n }\r\n\r\n function getLiveStreamStateHelper(): Promise<LiveStreamState> {\r\n return new Promise<LiveStreamState>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.getLiveStreamState'));\r\n });\r\n }\r\n\r\n /**\r\n * Allows an app to request the live streaming be started at the given streaming url\r\n *\r\n * @remarks\r\n * Use getLiveStreamState or registerLiveStreamChangedHandler to get updates on the live stream state\r\n *\r\n * @param streamUrl - the url to the stream resource\r\n * @param streamKey - the key to the stream resource\r\n * @returns Promise that will be resolved when the operation has completed or rejected with SdkError value\r\n */\r\n export function requestStartLiveStreaming(streamUrl: string, streamKey?: string): Promise<void>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.requestStartLiveStreaming meeting.requestStartLiveStreaming(streamUrl: string, streamKey?: string): Promise\\<void\\>} instead.\r\n *\r\n * Allows an app to request the live streaming be started at the given streaming url\r\n *\r\n * @param streamUrl - The url to the stream resource\r\n * @param streamKey - The key to the stream resource\r\n * @param callback - Callback contains error parameter which can be of type SdkError in case of an error, or null when operation is successful\r\n *\r\n * Use getLiveStreamState or registerLiveStreamChangedHandler to get updates on the live stream state\r\n */\r\n export function requestStartLiveStreaming(\r\n callback: (error: SdkError | null) => void,\r\n streamUrl: string,\r\n streamKey?: string,\r\n ): Promise<void>;\r\n /**\r\n * @hidden\r\n * This function is the overloaded implementation of requestStartLiveStreaming.\r\n * Since the method signatures of the v1 callback and v2 promise differ in the type of the first parameter,\r\n * we need to do an extra check to know the typeof the @param1 to set the proper arguments of the utility function.\r\n * @param param1\r\n * @param param2\r\n * @param param3\r\n * @returns Promise that will be resolved when the operation has completed or rejected with SdkError value\r\n */\r\n export function requestStartLiveStreaming(\r\n param1: string | ((error: SdkError | null) => void),\r\n param2?: string,\r\n param3?: string,\r\n ): Promise<void> {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n let streamUrl: string;\r\n let streamKey: string;\r\n let callback: (error: SdkError | null) => void;\r\n if (typeof param1 === 'function') {\r\n // Legacy code, with callbacks.\r\n [callback, streamUrl, streamKey] = [param1, param2, param3];\r\n } else if (typeof param1 === 'string') {\r\n [streamUrl, streamKey] = [param1, param2];\r\n }\r\n return callCallbackWithSdkErrorFromPromiseAndReturnPromise(\r\n requestStartLiveStreamingHelper,\r\n callback,\r\n streamUrl,\r\n streamKey,\r\n );\r\n }\r\n\r\n function requestStartLiveStreamingHelper(streamUrl: string, streamKey?: string): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.requestStartLiveStreaming', streamUrl, streamKey));\r\n });\r\n }\r\n\r\n /**\r\n * Allows an app to request the live streaming be stopped at the given streaming url\r\n *\r\n * @remarks\r\n * Use getLiveStreamState or registerLiveStreamChangedHandler to get updates on the live stream state\r\n *\r\n * @returns Promise that will be resolved when the operation has completed or rejected with SdkError value\r\n */\r\n export function requestStopLiveStreaming(): Promise<void>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.requestStopLiveStreaming meeting.requestStopLiveStreaming(): Promise\\<void\\>} instead.\r\n *\r\n * Allows an app to request the live streaming be stopped at the given streaming url\r\n * @param callback - Callback contains error parameter which can be of type SdkError in case of an error, or null when operation is successful\r\n *\r\n * Use getLiveStreamState or registerLiveStreamChangedHandler to get updates on the live stream state\r\n */\r\n export function requestStopLiveStreaming(callback: (error: SdkError | null) => void): void;\r\n export function requestStopLiveStreaming(callback?: (error: SdkError | null) => void): Promise<void> {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n return callCallbackWithSdkErrorFromPromiseAndReturnPromise(requestStopLiveStreamingHelper, callback);\r\n }\r\n\r\n function requestStopLiveStreamingHelper(): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.requestStopLiveStreaming'));\r\n });\r\n }\r\n\r\n /**\r\n * Registers a handler for changes to the live stream.\r\n *\r\n * @remarks\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the live stream state changes\r\n */\r\n export function registerLiveStreamChangedHandler(handler: (liveStreamState: LiveStreamState) => void): void {\r\n if (!handler) {\r\n throw new Error('[register live stream changed handler] Handler cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n registerHandler('meeting.liveStreamChanged', handler);\r\n }\r\n\r\n /**\r\n * Allows an app to share contents in the meeting\r\n *\r\n * @param appContentUrl - appContentUrl is the input URL which needs to be shared on to the stage\r\n * @returns Promise resolved indicating whether or not the share was successful or rejected with SdkError value\r\n */\r\n export function shareAppContentToStage(appContentUrl: string): Promise<boolean>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.shareAppContentToStage meeting.shareAppContentToStage(appContentUrl: string): Promise\\<boolean\\>} instead.\r\n *\r\n * Allows an app to share contents in the meeting\r\n *\r\n * @param callback - Callback contains 2 parameters, error and result.\r\n * error can either contain an error of type SdkError, incase of an error, or null when share is successful\r\n * result can either contain a true value, incase of a successful share or null when the share fails\r\n * @param appContentUrl - is the input URL which needs to be shared on to the stage\r\n */\r\n export function shareAppContentToStage(\r\n callback: (error: SdkError | null, result: boolean | null) => void,\r\n appContentUrl: string,\r\n ): void;\r\n /**\r\n * This function is the overloaded implementation of shareAppContentToStage.\r\n * Since the method signatures of the v1 callback and v2 promise differ in the type of the first parameter,\r\n * we need to do an extra check to know the typeof the @param1 to set the proper arguments of the utility function.\r\n * @param param1\r\n * @param param2\r\n * @returns Promise resolved indicating whether or not the share was successful or rejected with SdkError value\r\n */\r\n export function shareAppContentToStage(\r\n param1: string | ((error: SdkError | null, result: boolean | null) => void),\r\n param2?: string,\r\n ): Promise<boolean> {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n let appContentUrl: string;\r\n let callback: (error: SdkError | null, result: boolean | null) => void;\r\n if (typeof param1 === 'function') {\r\n // Legacy callback\r\n [callback, appContentUrl] = [param1, param2];\r\n } else {\r\n appContentUrl = param1;\r\n }\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<boolean>(\r\n shareAppContentToStageHelper,\r\n callback,\r\n appContentUrl,\r\n );\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Helper method to generate and return a promise for shareAppContentToStage\r\n * @param appContentUrl\r\n * @returns\r\n */\r\n function shareAppContentToStageHelper(appContentUrl: string): Promise<boolean> {\r\n return new Promise<boolean>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.shareAppContentToStage', appContentUrl));\r\n });\r\n }\r\n\r\n /**\r\n * Provides information related to app's in-meeting sharing capabilities\r\n *\r\n * @returns Promise resolved with sharing capability details or rejected with SdkError value\r\n */\r\n export function getAppContentStageSharingCapabilities(): Promise<IAppContentStageSharingCapabilities>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.getAppContentStageSharingCapabilities meeting.getAppContentStageSharingCapabilities(): Promise\\<IAppContentStageSharingCapabilities\\>} instead.\r\n *\r\n * Provides information related to app's in-meeting sharing capabilities\r\n *\r\n * @param callback - Callback contains 2 parameters, error and result.\r\n * error can either contain an error of type SdkError (error indication), or null (non-error indication)\r\n * appContentStageSharingCapabilities can either contain an IAppContentStageSharingCapabilities object\r\n * (indication of successful retrieval), or null (indication of failed retrieval)\r\n */\r\n export function getAppContentStageSharingCapabilities(\r\n callback: (\r\n error: SdkError | null,\r\n appContentStageSharingCapabilities: IAppContentStageSharingCapabilities | null,\r\n ) => void,\r\n ): void;\r\n export function getAppContentStageSharingCapabilities(\r\n callback?: (\r\n error: SdkError | null,\r\n appContentStageSharingCapabilities: IAppContentStageSharingCapabilities | null,\r\n ) => void,\r\n ): Promise<IAppContentStageSharingCapabilities> {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<IAppContentStageSharingCapabilities>(\r\n getAppContentStageSharingCapabilitiesHelper,\r\n callback,\r\n );\r\n }\r\n\r\n /**\r\n * @hidden\r\n * @returns\r\n */\r\n function getAppContentStageSharingCapabilitiesHelper(): Promise<IAppContentStageSharingCapabilities> {\r\n return new Promise<IAppContentStageSharingCapabilities>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.getAppContentStageSharingCapabilities'));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs.\r\n * ------------------------------------------\r\n * Terminates current stage sharing session in meeting\r\n *\r\n * @returns Promise resolved indicating whether or not sharing successfully stopped or rejected with SdkError value\r\n */\r\n export function stopSharingAppContentToStage(): Promise<boolean>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.stopSharingAppContentToStage meeting.stopSharingAppContentToStage(): Promise\\<boolean\\>} instead.\r\n *\r\n * @hidden\r\n * Hide from docs.\r\n * ------------------------------------------\r\n * Terminates current stage sharing session in meeting\r\n * @param callback Callback contains 2 parameters, error and result.\r\n * error can either contain an error of type SdkError (error indication), or null (non-error indication)\r\n * result can either contain a true boolean value (successful termination), or null (unsuccessful fetch)\r\n * @internal\r\n */\r\n export function stopSharingAppContentToStage(\r\n callback: (error: SdkError | null, result: boolean | null) => void,\r\n ): void;\r\n export function stopSharingAppContentToStage(\r\n callback?: (error: SdkError | null, result: boolean | null) => void,\r\n ): Promise<boolean> {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<boolean>(\r\n stopSharingAppContentToStageHelper,\r\n callback,\r\n );\r\n }\r\n\r\n /**\r\n * @hidden\r\n * @returns\r\n */\r\n function stopSharingAppContentToStageHelper(): Promise<boolean> {\r\n return new Promise<boolean>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.stopSharingAppContentToStage'));\r\n });\r\n }\r\n\r\n /**\r\n * Provides information related to current stage sharing state for app\r\n *\r\n * @returns Promise resolved to the App Content Stage Sharing State, or rejected with SdkError value\r\n */\r\n export function getAppContentStageSharingState(): Promise<IAppContentStageSharingState>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link meeting.getAppContentStageSharingState meeting.getAppContentStageSharingState(): Promise\\<IAppContentStageSharingState\\>} instead.\r\n *\r\n * Provides information related to current stage sharing state for app\r\n * @param callback - Callback contains 2 parameters, error and result.\r\n * error can either contain an error of type SdkError (error indication), or null (non-error indication)\r\n * appContentStageSharingState can either contain an IAppContentStageSharingState object\r\n * (indication of successful retrieval), or null (indication of failed retrieval)\r\n */\r\n export function getAppContentStageSharingState(\r\n callback: (error: SdkError | null, appContentStageSharingState: IAppContentStageSharingState | null) => void,\r\n ): void;\r\n export function getAppContentStageSharingState(\r\n callback?: (error: SdkError | null, appContentStageSharingState: IAppContentStageSharingState | null) => void,\r\n ): Promise<IAppContentStageSharingState> {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise<IAppContentStageSharingState>(\r\n getAppContentStageSharingStateHelper,\r\n callback,\r\n );\r\n }\r\n\r\n function getAppContentStageSharingStateHelper(): Promise<IAppContentStageSharingState> {\r\n return new Promise<IAppContentStageSharingState>(resolve => {\r\n resolve(sendAndHandleSdkError('meeting.getAppContentStageSharingState'));\r\n });\r\n }\r\n}\r\n","import { sendAndHandleSdkError } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise, InputFunction } from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\nimport { SdkError } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace monetization {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * Data structure to represent a subscription plan.\r\n *\r\n * @internal\r\n */\r\n export interface PlanInfo {\r\n /**\r\n * @hidden\r\n * plan id\r\n */\r\n planId: string;\r\n /**\r\n * @hidden\r\n * term of the plan\r\n */\r\n term: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * Open dialog to start user's purchase experience\r\n *\r\n * @param planInfo optional parameter. It contains info of the subscription plan pushed to users.\r\n * error can either contain an error of type SdkError, incase of an error, or null when get is successful\r\n * @returns Promise that will be resolved when the operation has completed or rejected with SdkError value\r\n *\r\n * @internal\r\n */\r\n export function openPurchaseExperience(planInfo?: PlanInfo): Promise<void>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link monetization.openPurchaseExperience monetization.openPurchaseExperience(planInfo?: PlanInfo): Promise\\<void\\>} instead.\r\n *\r\n * @hidden\r\n * Hide from docs\r\n * Open dialog to start user's purchase experience\r\n *\r\n * @param callback Callback contains 1 parameters, error.\r\n * @param planInfo optional parameter. It contains info of the subscription plan pushed to users.\r\n * error can either contain an error of type SdkError, incase of an error, or null when get is successful\r\n *\r\n * @internal\r\n */\r\n export function openPurchaseExperience(callback: (error: SdkError | null) => void, planInfo?: PlanInfo): void;\r\n /**\r\n * @hidden\r\n * This function is the overloaded implementation of openPurchaseExperience.\r\n * Since the method signatures of the v1 callback and v2 promise differ in the type of the first parameter,\r\n * we need to do an extra check to know the typeof the @param1 to set the proper arguments of the utility function.\r\n * @param param1\r\n * @param param2\r\n * @returns Promise that will be resolved when the operation has completed or rejected with SdkError value\r\n */\r\n export function openPurchaseExperience(\r\n param1: ((error: SdkError | null) => void) | PlanInfo | undefined,\r\n param2?: PlanInfo,\r\n ): Promise<void> {\r\n let callback: (error: SdkError | null) => void;\r\n let planInfo: PlanInfo;\r\n if (typeof param1 === 'function') {\r\n callback = param1;\r\n planInfo = param2;\r\n } else {\r\n planInfo = param1;\r\n }\r\n const wrappedFunction: InputFunction<void> = () => {\r\n return new Promise<void>(resolve => {\r\n resolve(sendAndHandleSdkError('monetization.openPurchaseExperience', planInfo));\r\n });\r\n };\r\n\r\n ensureInitialized(FrameContexts.content);\r\n return callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise(wrappedFunction, callback);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.monetization ? true : false;\r\n }\r\n}\r\n","import { sendAndHandleStatusAndReason as sendAndHandleError } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from './constants';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace calendar {\r\n export function openCalendarItem(openCalendarItemParams: OpenCalendarItemParams): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n if (!isSupported()) {\r\n throw new Error('Not supported');\r\n }\r\n\r\n if (!openCalendarItemParams.itemId || !openCalendarItemParams.itemId.trim()) {\r\n throw new Error('Must supply an itemId to openCalendarItem');\r\n }\r\n\r\n resolve(sendAndHandleError('calendar.openCalendarItem', openCalendarItemParams));\r\n });\r\n }\r\n export function composeMeeting(composeMeetingParams: ComposeMeetingParams): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n if (!isSupported()) {\r\n throw new Error('Not supported');\r\n }\r\n\r\n resolve(sendAndHandleError('calendar.composeMeeting', composeMeetingParams));\r\n });\r\n }\r\n export function isSupported(): boolean {\r\n return runtime.supports.calendar ? true : false;\r\n }\r\n\r\n export interface OpenCalendarItemParams {\r\n itemId: string;\r\n }\r\n\r\n export interface ComposeMeetingParams {\r\n attendees?: string[];\r\n startTime?: string;\r\n endTime?: string;\r\n subject?: string;\r\n content?: string;\r\n }\r\n}\r\n","import { sendAndHandleStatusAndReason as sendAndHandleError } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from './constants';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace mail {\r\n export function openMailItem(openMailItemParams: OpenMailItemParams): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n if (!isSupported()) {\r\n throw new Error('Not supported');\r\n }\r\n\r\n if (!openMailItemParams.itemId || !openMailItemParams.itemId.trim()) {\r\n throw new Error('Must supply an itemId to openMailItem');\r\n }\r\n\r\n resolve(sendAndHandleError('mail.openMailItem', openMailItemParams));\r\n });\r\n }\r\n\r\n export function composeMail(composeMailParams: ComposeMailParams): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n if (!isSupported()) {\r\n throw new Error('Not supported');\r\n }\r\n\r\n resolve(sendAndHandleError('mail.composeMail', composeMailParams));\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.mail ? true : false;\r\n }\r\n\r\n export interface OpenMailItemParams {\r\n itemId: string;\r\n }\r\n\r\n export enum ComposeMailType {\r\n New = 'new',\r\n Reply = 'reply',\r\n ReplyAll = 'replyAll',\r\n Forward = 'forward',\r\n }\r\n\r\n /**\r\n * Base of a discriminated union between compose scenarios.\r\n */\r\n interface ComposeMailBase<T extends ComposeMailType> {\r\n type: T;\r\n }\r\n /**\r\n * Interfaces for each type.\r\n */\r\n export interface ComposeNewParams extends ComposeMailBase<ComposeMailType.New> {\r\n toRecipients?: string[];\r\n ccRecipients?: string[];\r\n bccRecipients?: string[];\r\n subject?: string;\r\n message?: string;\r\n }\r\n export interface ComposeReplyOrForwardParams<T extends ComposeMailType> extends ComposeMailBase<T> {\r\n itemid: string;\r\n }\r\n\r\n export type ComposeMailParams =\r\n | ComposeNewParams\r\n | ComposeReplyOrForwardParams<ComposeMailType.Reply>\r\n | ComposeReplyOrForwardParams<ComposeMailType.ReplyAll>\r\n | ComposeReplyOrForwardParams<ComposeMailType.Forward>;\r\n}\r\n","import { sendAndHandleSdkError as sendAndHandleError } from '../internal/communication';\r\nimport { peoplePickerRequiredVersion } from '../internal/constants';\r\nimport { ensureInitialized, isCurrentSDKVersionAtLeast } from '../internal/internalAPIs';\r\nimport { validatePeoplePickerInput } from '../internal/mediaUtil';\r\nimport { callCallbackWithErrorOrResultFromPromiseAndReturnPromise } from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\nimport { ErrorCode, SdkError } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace people {\r\n /**\r\n * Launches a people picker and allows the user to select one or more people from the list\r\n * If the app is added to personal app scope the people picker launched is org wide and if the app is added to a chat/channel, people picker launched is also limited to the members of chat/channel\r\n \r\n * @param callback - Returns list of JSON object of type PeoplePickerResult which consists of AAD IDs, display names and emails of the selected users\r\n * @param peoplePickerInputs - Input parameters to launch customized people picker\r\n * @returns Promise that will be fulfilled when the operation has completed\r\n */\r\n export function selectPeople(peoplePickerInputs?: PeoplePickerInputs): Promise<PeoplePickerResult[]>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link people.selectPeople people.selectPeople(peoplePickerInputs?: PeoplePickerInputs): Promise\\<PeoplePickerResult[]\\>} instead.\r\n *\r\n * Launches a people picker and allows the user to select one or more people from the list\r\n * If the app is added to personal app scope the people picker launched is org wide and if the app is added to a chat/channel, people picker launched is also limited to the members of chat/channel\r\n \r\n * @param callback - Returns list of JSON object of type PeoplePickerResult which consists of AAD IDs, display names and emails of the selected users\r\n * @param peoplePickerInputs - Input parameters to launch customized people picker\r\n */\r\n export function selectPeople(\r\n callback: (error: SdkError, people: PeoplePickerResult[]) => void,\r\n peoplePickerInputs?: PeoplePickerInputs,\r\n ): void;\r\n /**\r\n * @hidden\r\n * This function is the overloaded implementation of selectPeople.\r\n * Since the method signatures of the v1 callback and v2 promise differ in the type of the first parameter,\r\n * we need to do an extra check to know the typeof the @param1 to set the proper arguments of the utility function.\r\n * @param param1\r\n * @param param2\r\n * @returns Promise of Array of PeoplePickerResult objects.\r\n */\r\n export function selectPeople(\r\n param1: PeoplePickerInputs | ((error: SdkError, people: PeoplePickerResult[]) => void) | undefined,\r\n param2?: PeoplePickerInputs,\r\n ): Promise<PeoplePickerResult[]> {\r\n ensureInitialized(FrameContexts.content, FrameContexts.task, FrameContexts.settings);\r\n\r\n let callback: (error: SdkError, people: PeoplePickerResult[]) => void;\r\n let peoplePickerInputs: PeoplePickerInputs;\r\n\r\n if (typeof param1 === 'function') {\r\n [callback, peoplePickerInputs] = [param1, param2];\r\n } else {\r\n peoplePickerInputs = param1;\r\n }\r\n\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise<PeoplePickerResult[]>(\r\n selectPeopleHelper,\r\n callback,\r\n peoplePickerInputs,\r\n );\r\n }\r\n\r\n function selectPeopleHelper(peoplePickerInputs?: PeoplePickerInputs): Promise<PeoplePickerResult[]> {\r\n return new Promise<PeoplePickerResult[]>(resolve => {\r\n if (!isCurrentSDKVersionAtLeast(peoplePickerRequiredVersion)) {\r\n throw { errorCode: ErrorCode.OLD_PLATFORM };\r\n }\r\n\r\n if (!validatePeoplePickerInput(peoplePickerInputs)) {\r\n throw { errorCode: ErrorCode.INVALID_ARGUMENTS };\r\n }\r\n\r\n resolve(sendAndHandleError('people.selectPeople', peoplePickerInputs));\r\n });\r\n }\r\n\r\n /**\r\n * Input parameter supplied to the People Picker API\r\n */\r\n export interface PeoplePickerInputs {\r\n /**\r\n * Optional; Set title for the people picker\r\n * Default value is \"Select people\" for multiselect and \"Select a person\" for single select\r\n */\r\n title?: string;\r\n\r\n /**\r\n * Optional; AAD ids of the users to be pre-populated in the search box of people picker control\r\n * If single select is enabled this value, only the first user in the list will be pre-populated\r\n * Default value is null\r\n */\r\n setSelected?: string[];\r\n\r\n /**\r\n * Optional; launches the people picker in org wide scope even if the app is added to a chat or channel\r\n * Default value is false\r\n */\r\n openOrgWideSearchInChatOrChannel?: boolean;\r\n\r\n /**\r\n * Optional; launches the people picker for which only 1 person can be selected\r\n * Default value is false\r\n */\r\n singleSelect?: boolean;\r\n }\r\n\r\n /**\r\n * Output user object of people picker API\r\n */\r\n export interface PeoplePickerResult {\r\n /**\r\n * user object Id (also known as aad id) of the selected user\r\n */\r\n objectId: string;\r\n\r\n /**\r\n * Optional; display name of the selected user\r\n */\r\n displayName?: string;\r\n\r\n /**\r\n * Optional; email of the selected user\r\n */\r\n email?: string;\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.people ? true : false;\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from './constants';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * Namespace to video extensibility of the SDK.\r\n *\r\n * @alpha\r\n *\r\n */\r\nexport namespace video {\r\n /**\r\n * Represents a video frame.\r\n */\r\n export interface VideoFrame {\r\n /**\r\n * Video frame width.\r\n */\r\n width: number;\r\n /**\r\n * Video frame height.\r\n */\r\n height: number;\r\n /**\r\n * Video frame buffer\r\n */\r\n data: Uint8ClampedArray;\r\n /**\r\n * NV12 luma stride, valid only when video frame format is NV12\r\n */\r\n lumaStride?: number;\r\n /**\r\n * NV12 chroma stride, valid only when video frame format is NV12\r\n */\r\n chromaStride?: number;\r\n /**\r\n * RGB stride, valid only when video frame format is RGB\r\n */\r\n stride?: number;\r\n }\r\n\r\n /**\r\n * Video frame format enum, currently only support NV12\r\n */\r\n export enum VideoFrameFormat {\r\n NV12,\r\n }\r\n\r\n /**\r\n * Video frame configuration supplied to Teams to customize the generated video frame parameters, like format.\r\n */\r\n export interface VideoFrameConfig {\r\n /**\r\n * video format\r\n */\r\n format: VideoFrameFormat;\r\n }\r\n\r\n /**\r\n * Video effect change type enum\r\n */\r\n export enum EffectChangeType {\r\n /**\r\n * current video effect changed.\r\n */\r\n EffectChanged,\r\n /**\r\n * disable the video effect\r\n */\r\n EffectDisabled,\r\n }\r\n\r\n /**\r\n * Video frame call back function definition\r\n */\r\n export type VideoFrameCallback = (\r\n frame: VideoFrame,\r\n notifyVideoFrameProcessed: () => void,\r\n notifyError: (errorMessage: string) => void,\r\n ) => void;\r\n\r\n /**\r\n * Video effect change call back function definition\r\n */\r\n export type VideoEffectCallBack = (effectId: string | undefined) => void;\r\n\r\n /**\r\n * register to read the video frames in Permissions section.\r\n */\r\n export function registerForVideoFrame(frameCallback: VideoFrameCallback, config: VideoFrameConfig): void {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n registerHandler('video.newVideoFrame', (videoFrame: VideoFrame) => {\r\n if (videoFrame !== undefined) {\r\n frameCallback(videoFrame, notifyVideoFrameProcessed, notifyError);\r\n }\r\n });\r\n sendMessageToParent('video.registerForVideoFrame', [config]);\r\n }\r\n\r\n /**\r\n * video extension should call this to notify Teams Client current selected effect parameter changed.\r\n * If it's pre-meeting, Teams client will call videoEffectCallback immediately then use the videoEffect.\r\n * in-meeting scenario, we will call videoEffectCallback when apply button clicked.\r\n *\r\n * @param effectChangeType - the effect change type.\r\n * @param effectId - Newly selected effect id.\r\n */\r\n export function notifySelectedVideoEffectChanged(\r\n effectChangeType: EffectChangeType,\r\n effectId: string | undefined,\r\n ): void {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n sendMessageToParent('video.videoEffectChanged', [effectChangeType, effectId]);\r\n }\r\n\r\n /**\r\n * Register the video effect callback, Teams client uses this to notify the video extension the new video effect will by applied.\r\n */\r\n export function registerForVideoEffect(callback: VideoEffectCallBack): void {\r\n ensureInitialized(FrameContexts.sidePanel);\r\n registerHandler('video.effectParameterChange', callback);\r\n }\r\n\r\n /**\r\n * sending notification to Teams client finished the video frame processing, now Teams client can render this video frame\r\n * or pass the video frame to next one in video pipeline.\r\n */\r\n function notifyVideoFrameProcessed(): void {\r\n sendMessageToParent('video.videoFrameProcessed');\r\n }\r\n\r\n /**\r\n * sending error notification to Teams client.\r\n */\r\n function notifyError(errorMessage: string): void {\r\n sendMessageToParent('video.notifyError', [errorMessage]);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.video ? true : false;\r\n }\r\n} //end of video namespace\r\n","import { sendAndHandleSdkError } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { callCallbackWithSdkErrorFromPromiseAndReturnPromise, InputFunction } from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\nimport { ErrorCode, SdkError } from './interfaces';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace sharing {\r\n export const SharingAPIMessages = {\r\n shareWebContent: 'sharing.shareWebContent',\r\n };\r\n\r\n // More types can be added as we expand share capability\r\n type ContentType = 'URL';\r\n\r\n interface IBaseSharedContent {\r\n type: ContentType;\r\n }\r\n\r\n // More types can be added as we expand share capability\r\n export type IShareRequestContentType = IURLContent;\r\n\r\n export interface IShareRequest<T> {\r\n content: T[];\r\n }\r\n\r\n export interface IURLContent extends IBaseSharedContent {\r\n type: 'URL';\r\n\r\n /**\r\n * Required URL\r\n */\r\n url: string;\r\n\r\n /**\r\n * Default initial message text\r\n */\r\n message?: string;\r\n\r\n /**\r\n * Show URL preview, defaults to true\r\n */\r\n preview?: boolean;\r\n }\r\n\r\n /**\r\n * Feature is under development\r\n * Opens a share dialog for web content\r\n *\r\n * @param shareWebContentRequest - web content info\r\n * @returns Promise that will be fulfilled when the operation has completed\r\n */\r\n export function shareWebContent(shareWebContentRequest: IShareRequest<IShareRequestContentType>): Promise<void>;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link sharing.shareWebContent sharing.shareWebContent(shareWebContentRequest: IShareRequest\\<IShareRequestContentType\\>): Promise\\<void\\>} instead.\r\n *\r\n * Feature is under development\r\n * Opens a share dialog for web content\r\n *\r\n * @param shareWebContentRequest - web content info\r\n * @param callback - optional callback\r\n */\r\n export function shareWebContent(\r\n shareWebContentRequest: IShareRequest<IShareRequestContentType>,\r\n callback: (err?: SdkError) => void,\r\n ): void;\r\n export function shareWebContent(\r\n shareWebContentRequest: IShareRequest<IShareRequestContentType>,\r\n callback?: (err?: SdkError) => void,\r\n ): Promise<void> {\r\n // validate the given input (synchronous check)\r\n try {\r\n validateNonEmptyContent(shareWebContentRequest);\r\n validateTypeConsistency(shareWebContentRequest);\r\n validateContentForSupportedTypes(shareWebContentRequest);\r\n } catch (err) {\r\n //return the error via callback(v1) or rejected promise(v2)\r\n const wrappedFunction: InputFunction<void> = () => Promise.reject(err);\r\n return callCallbackWithSdkErrorFromPromiseAndReturnPromise(wrappedFunction, callback);\r\n }\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n return callCallbackWithSdkErrorFromPromiseAndReturnPromise(shareWebContentHelper, callback, shareWebContentRequest);\r\n }\r\n\r\n function shareWebContentHelper(shareWebContentRequest: IShareRequest<IShareRequestContentType>): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n resolve(sendAndHandleSdkError(SharingAPIMessages.shareWebContent, shareWebContentRequest));\r\n });\r\n }\r\n\r\n /**\r\n * Functions for validating the shareRequest input parameter\r\n */\r\n function validateNonEmptyContent(shareRequest: IShareRequest<IShareRequestContentType>): void {\r\n if (!(shareRequest && shareRequest.content && shareRequest.content.length)) {\r\n const err: SdkError = {\r\n errorCode: ErrorCode.INVALID_ARGUMENTS,\r\n message: 'Shared content is missing',\r\n };\r\n throw err;\r\n }\r\n }\r\n\r\n function validateTypeConsistency(shareRequest: IShareRequest<IShareRequestContentType>): void {\r\n let err: SdkError;\r\n if (shareRequest.content.some(item => !item.type)) {\r\n err = {\r\n errorCode: ErrorCode.INVALID_ARGUMENTS,\r\n message: 'Shared content type cannot be undefined',\r\n };\r\n throw err;\r\n }\r\n if (shareRequest.content.some(item => item.type !== shareRequest.content[0].type)) {\r\n err = {\r\n errorCode: ErrorCode.INVALID_ARGUMENTS,\r\n message: 'Shared content must be of the same type',\r\n };\r\n throw err;\r\n }\r\n }\r\n\r\n function validateContentForSupportedTypes(shareRequest: IShareRequest<IShareRequestContentType>): void {\r\n let err: SdkError;\r\n if (shareRequest.content[0].type === 'URL') {\r\n if (shareRequest.content.some(item => !item.url)) {\r\n err = {\r\n errorCode: ErrorCode.INVALID_ARGUMENTS,\r\n message: 'URLs are required for URL content types',\r\n };\r\n throw err;\r\n }\r\n } else {\r\n err = {\r\n errorCode: ErrorCode.INVALID_ARGUMENTS,\r\n message: 'Content type is unsupported',\r\n };\r\n throw err;\r\n }\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.sharing ? true : false;\r\n }\r\n}\r\n","import { sendAndHandleSdkError } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { callCallbackWithErrorOrResultFromPromiseAndReturnPromise } from '../internal/utils';\r\nimport { SdkError } from '../public';\r\nimport { FrameContexts } from './constants';\r\n\r\n/**\r\n * Namespace to interact with the stage view specific part of the SDK.\r\n */\r\nexport namespace stageView {\r\n /**\r\n * Parameters to open a stage view.\r\n */\r\n export interface StageViewParams {\r\n /**\r\n * The application ID of the Teams application to be opened.\r\n */\r\n appId: string;\r\n\r\n /**\r\n * The URL of the content to display.\r\n */\r\n contentUrl: string;\r\n\r\n /**\r\n * The chat or channel ID.\r\n */\r\n threadId: string;\r\n\r\n /**\r\n * The title to give the stage view.\r\n */\r\n title: string;\r\n\r\n /**\r\n * The Teams app website URL.\r\n */\r\n websiteUrl?: string;\r\n\r\n /**\r\n * The entity ID of the Teams app content being opened.\r\n */\r\n entityId?: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Feature is under development\r\n *\r\n * Opens a stage view to display a Teams app\r\n * @param stageViewParams The parameters to pass into the stage view.\r\n *\r\n */\r\n export function open(stageViewParams: StageViewParams): Promise<void>;\r\n /**\r\n * @hidden\r\n * Feature is under development\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link stageView.open stageView.open(): Promise\\<void\\>} instead.\r\n *\r\n * Opens a stage view to display a Teams app\r\n * @param stageViewParams The parameters to pass into the stage view.\r\n * Optional; @param callback Callback that will be triggered once the stage view is closed.\r\n * The callback takes as an argument an SdkError in case something happened (i.e.\r\n * no permissions to execute the API)\r\n */\r\n export function open(stageViewParams: StageViewParams, callback?: (sdkError?: SdkError) => void): void;\r\n export function open(stageViewParams: StageViewParams, callback?: (sdkError?: SdkError) => void): Promise<void> {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!stageViewParams) {\r\n throw new Error('[stageView.open] Stage view params cannot be null');\r\n }\r\n const wrappedFunction = (): Promise<void> =>\r\n new Promise(resolve => resolve(sendAndHandleSdkError('stageView.open', stageViewParams)));\r\n\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise(wrappedFunction, callback);\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from './constants';\r\nimport { runtime } from './runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace call {\r\n export enum CallModalities {\r\n Unknown = 'unknown',\r\n Audio = 'audio',\r\n Video = 'video',\r\n VideoBasedScreenSharing = 'videoBasedScreenSharing',\r\n Data = 'data',\r\n }\r\n\r\n export interface StartCallParams {\r\n // comma-separated list of user IDs representing the participants of the call.\r\n // Currently the User ID field supports the Azure AD UserPrincipalName,\r\n // typically an email address, or in case of a PSTN call, it supports a pstn\r\n // mri 4:<phonenumber>.\r\n targets: string[];\r\n // List of modalities for the call. Defaults to [“audio”].\r\n requestedModalities?: CallModalities[];\r\n // An optional parameter that informs about the source of the deep link\r\n source?: string;\r\n }\r\n\r\n /**\r\n * Starts a call with other users\r\n *\r\n * @param startCallParams - Parameters for the call\r\n * @returns If the call is accepted\r\n */\r\n export function startCall(startCallParams: StartCallParams): Promise<boolean> {\r\n return new Promise(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n if (!isSupported()) {\r\n throw new Error('Not supported');\r\n }\r\n return sendMessageToParent('call.startCall', [startCallParams], resolve);\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.call ? true : false;\r\n }\r\n}\r\n","import { app } from './app';\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app} namespace instead.\r\n */\r\nexport namespace appInitialization {\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.Messages} instead.\r\n */\r\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n export import Messages = app.Messages;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.FailedReason} instead.\r\n */\r\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n export import FailedReason = app.FailedReason;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.ExpectedFailureReason} instead.\r\n */\r\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n export import ExpectedFailureReason = app.ExpectedFailureReason;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.IFailedRequest} instead.\r\n */\r\n export import IFailedRequest = app.IFailedRequest;\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.IExpectedFailureRequest} instead.\r\n */\r\n export import IExpectedFailureRequest = app.IExpectedFailureRequest;\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.notifyAppLoaded app.notifyAppLoaded(): void} instead.\r\n * Notifies the frame that app has loaded and to hide the loading indicator if one is shown.\r\n */\r\n export function notifyAppLoaded(): void {\r\n app.notifyAppLoaded();\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.notifySuccess app.notifySuccess(): void} instead.\r\n * Notifies the frame that app initialization is successful and is ready for user interaction.\r\n */\r\n export function notifySuccess(): void {\r\n app.notifySuccess();\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.notifyFailure app.notifyFailure(appInitializationFailedRequest: IFailedRequest): void} instead.\r\n * Notifies the frame that app initialization has failed and to show an error page in its place.\r\n */\r\n export function notifyFailure(appInitializationFailedRequest: IFailedRequest): void {\r\n app.notifyFailure(appInitializationFailedRequest);\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.notifyExpectedFailure app.notifyExpectedFailure(expectedFailureRequest: IExpectedFailureRequest): void} instead.\r\n * Notifies the frame that app initialized with some expected errors.\r\n */\r\n export function notifyExpectedFailure(expectedFailureRequest: IExpectedFailureRequest): void {\r\n app.notifyExpectedFailure(expectedFailureRequest);\r\n }\r\n}\r\n","import { ensureInitialized } from '../internal/internalAPIs';\r\nimport { getGenericOnCompleteHandler } from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\nimport { pages } from './pages';\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config} namespace instead.\r\n *\r\n * Namespace to interact with the settings-specific part of the SDK.\r\n * This object is usable only on the settings frame.\r\n */\r\nexport namespace settings {\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.Config} instead.\r\n * @remarks\r\n * Renamed to config in pages.Config\r\n */\r\n export import Settings = pages.InstanceConfig;\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.SaveEvent} instead.\r\n * @remarks\r\n * See pages.SaveEvent\r\n */\r\n export import SaveEvent = pages.config.SaveEvent;\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.RemoveEvent} instead.\r\n * @remarks\r\n * See pages.RemoveEvent\r\n */\r\n export import RemoveEvent = pages.config.RemoveEvent;\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.SaveParameters} instead.\r\n * @remarks\r\n * See pages.SaveParameters\r\n */\r\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n export import SaveParameters = pages.config.SaveParameters;\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.setValidityState pages.config.setValidityState(validityState: boolean): void} instead.\r\n *\r\n * Sets the validity state for the settings.\r\n * The initial value is false, so the user cannot save the settings until this is called with true.\r\n *\r\n * @param validityState - Indicates whether the save or remove button is enabled for the user.\r\n */\r\n export function setValidityState(validityState: boolean): void {\r\n pages.config.setValidityState(validityState);\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.getConfig pages.config.getConfig(): Promise\\<Config\\>} instead.\r\n *\r\n * Gets the settings for the current instance.\r\n *\r\n * @param callback - The callback to invoke when the {@link Settings} object is retrieved.\r\n */\r\n export function getSettings(callback: (instanceSettings: Settings) => void): void {\r\n ensureInitialized(FrameContexts.content, FrameContexts.settings, FrameContexts.remove, FrameContexts.sidePanel);\r\n pages.getConfig().then((config: pages.InstanceConfig) => {\r\n callback(config);\r\n });\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.setConfig pages.config.setConfig(instanceSettings: Config): Promise\\<void\\>} instead.\r\n *\r\n * Sets the settings for the current instance.\r\n * This is an asynchronous operation; calls to getSettings are not guaranteed to reflect the changed state.\r\n *\r\n * @param - Set the desired settings for this instance.\r\n */\r\n export function setSettings(\r\n instanceSettings: Settings,\r\n onComplete?: (status: boolean, reason?: string) => void,\r\n ): void {\r\n ensureInitialized(FrameContexts.content, FrameContexts.settings, FrameContexts.sidePanel);\r\n onComplete = onComplete ? onComplete : getGenericOnCompleteHandler();\r\n pages.config\r\n .setConfig(instanceSettings)\r\n .then(() => {\r\n onComplete(true);\r\n })\r\n .catch((error: Error) => {\r\n onComplete(false, error.message);\r\n });\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.registerOnSaveHandler pages.config.registerOnSaveHandler(handler: (evt: SaveEvent) => void): void} instead.\r\n *\r\n * Registers a handler for when the user attempts to save the settings. This handler should be used\r\n * to create or update the underlying resource powering the content.\r\n * The object passed to the handler must be used to notify whether to proceed with the save.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the user selects the save button.\r\n */\r\n export function registerOnSaveHandler(handler: (evt: SaveEvent) => void): void {\r\n pages.config.registerOnSaveHandler(handler);\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.registerOnRemoveHandler pages.config.registerOnRemoveHandler(handler: (evt: RemoveEvent) => void): void} instead.\r\n *\r\n * Registers a handler for user attempts to remove content. This handler should be used\r\n * to remove the underlying resource powering the content.\r\n * The object passed to the handler must be used to indicate whether to proceed with the removal.\r\n * Only one handler may be registered at a time. Subsequent registrations will override the first.\r\n *\r\n * @param handler - The handler to invoke when the user selects the remove button.\r\n */\r\n export function registerOnRemoveHandler(handler: (evt: RemoveEvent) => void): void {\r\n pages.config.registerOnRemoveHandler(handler);\r\n }\r\n}\r\n","/* eslint-disable @typescript-eslint/ban-types */\r\n\r\nimport { IAppWindow } from './appWindow';\r\nimport { TaskModuleDimension } from './constants';\r\nimport { dialog } from './dialog';\r\nimport { TaskInfo } from './interfaces';\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link dialog} namespace instead.\r\n *\r\n * Namespace to interact with the task module-specific part of the SDK.\r\n * This object is usable only on the content frame.\r\n * The tasks namespace will be deprecated. Please use dialog for future developments.\r\n */\r\nexport namespace tasks {\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link dialog.open dialog.open(dialogInfo: DialogInfo, submitHandler?: (err: string, result: string) => void): IAppWindow} instead.\r\n *\r\n * Allows an app to open the task module.\r\n *\r\n * @param taskInfo - An object containing the parameters of the task module\r\n * @param submitHandler - Handler to call when the task module is completed\r\n */\r\n export function startTask(\r\n taskInfo: TaskInfo,\r\n submitHandler?: (err: string, result: string | object) => void,\r\n ): IAppWindow {\r\n return dialog.open(getDialogInfoFromTaskInfo(taskInfo), submitHandler);\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link dialog.resize dialog.resize(dialogInfo: DialogInfo): void} instead.\r\n *\r\n * Update height/width task info properties.\r\n *\r\n * @param taskInfo - An object containing width and height properties\r\n */\r\n export function updateTask(taskInfo: TaskInfo): void {\r\n dialog.resize(taskInfo);\r\n }\r\n\r\n /**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link dialog.submit dialog.submit(result?: string | object, appIds?: string | string[]): void} instead.\r\n *\r\n * Submit the task module.\r\n *\r\n * @param result - Contains the result to be sent to the bot or the app. Typically a JSON object or a serialized version of it\r\n * @param appIds - Helps to validate that the call originates from the same appId as the one that invoked the task module\r\n */\r\n export function submitTask(result?: string | object, appIds?: string | string[]): void {\r\n dialog.submit(result, appIds);\r\n }\r\n\r\n function getDialogInfoFromTaskInfo(taskInfo: TaskInfo): TaskInfo {\r\n const dialogHeight =\r\n taskInfo.height && typeof taskInfo.height !== 'number'\r\n ? getDialogDimensionFromTaskModuleDimension(taskInfo.height)\r\n : (taskInfo.height as number);\r\n const dialogWidth =\r\n taskInfo.width && typeof taskInfo.width !== 'number'\r\n ? getDialogDimensionFromTaskModuleDimension(taskInfo.width)\r\n : (taskInfo.width as number);\r\n const dialogInfo: TaskInfo = {\r\n url: taskInfo.url,\r\n card: taskInfo.card,\r\n height: dialogHeight,\r\n width: dialogWidth,\r\n title: taskInfo.title,\r\n fallbackUrl: taskInfo.fallbackUrl,\r\n completionBotId: taskInfo.completionBotId,\r\n };\r\n return dialogInfo;\r\n }\r\n\r\n function getDialogDimensionFromTaskModuleDimension(taskModuleDimension: TaskModuleDimension): TaskModuleDimension {\r\n if (taskModuleDimension === TaskModuleDimension.Large) {\r\n return TaskModuleDimension.Large;\r\n } else if (taskModuleDimension === TaskModuleDimension.Medium) {\r\n return TaskModuleDimension.Medium;\r\n } else {\r\n return TaskModuleDimension.Small;\r\n }\r\n }\r\n}\r\n","import {\r\n sendAndHandleSdkError as sendAndHandleError,\r\n sendMessageToParent,\r\n sendMessageToParentAsync,\r\n} from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { callCallbackWithErrorOrResultFromPromiseAndReturnPromise } from '../internal/utils';\r\nimport { FileOpenPreference, FrameContexts, SdkError } from '../public';\r\nimport { runtime } from '../public/runtime';\r\nimport { FilePreviewParameters } from './interfaces';\r\n\r\n/**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Namespace to interact with the files specific part of the SDK.\r\n *\r\n * @alpha\r\n */\r\nexport namespace files {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Cloud storage providers registered with Microsoft Teams\r\n */\r\n export enum CloudStorageProvider {\r\n Dropbox = 'DROPBOX',\r\n Box = 'BOX',\r\n Sharefile = 'SHAREFILE',\r\n GoogleDrive = 'GOOGLEDRIVE',\r\n Egnyte = 'EGNYTE',\r\n SharePoint = 'SharePoint',\r\n }\r\n interface IWopiThumbnail {\r\n size: number;\r\n url: string;\r\n }\r\n\r\n interface IWopiService {\r\n name: string;\r\n description: string;\r\n thumbnails: IWopiThumbnail[];\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n *\r\n * External third-party cloud storages providers interface\r\n */\r\n export interface IExternalProvider extends IWopiService {\r\n providerType: CloudStorageProviderType;\r\n providerCode: CloudStorageProvider;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Cloud storage provider type enums\r\n */\r\n export enum CloudStorageProviderType {\r\n Sharepoint = 0,\r\n WopiIntegration,\r\n Google,\r\n OneDrive,\r\n Recent,\r\n Aggregate,\r\n FileSystem, // Used for Downloaded files on Desktop\r\n Search, // Used by P2P files with OSearch\r\n AllFiles, // Used by P2P files with AllFiles API\r\n SharedWithMe,\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Cloud storage folder interface\r\n */\r\n export interface CloudStorageFolder {\r\n /**\r\n * @hidden\r\n * ID of the cloud storage folder\r\n */\r\n id: string;\r\n /**\r\n * @hidden\r\n * Display Name/Title of the cloud storage folder\r\n */\r\n title: string;\r\n /**\r\n * @hidden\r\n * ID of the cloud storage folder in the provider\r\n */\r\n folderId: string;\r\n /**\r\n * @hidden\r\n * Type of the cloud storage folder provider integration\r\n */\r\n providerType: CloudStorageProviderType;\r\n /**\r\n * @hidden\r\n * Code of the supported cloud storage folder provider\r\n */\r\n providerCode: CloudStorageProvider;\r\n /**\r\n * @hidden\r\n * Display name of the owner of the cloud storage folder provider\r\n */\r\n ownerDisplayName: string;\r\n /**\r\n * @hidden\r\n * Sharepoint specific siteURL of the folder\r\n */\r\n siteUrl?: string;\r\n /**\r\n * @hidden\r\n * Sharepoint specific serverRelativeUrl of the folder\r\n */\r\n serverRelativeUrl?: string;\r\n /**\r\n * @hidden\r\n * Sharepoint specific libraryType of the folder\r\n */\r\n libraryType?: string;\r\n /**\r\n * @hidden\r\n * Sharepoint specific accessType of the folder\r\n */\r\n accessType?: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Cloud storage item interface\r\n */\r\n export interface CloudStorageFolderItem {\r\n /**\r\n * @hidden\r\n * ID of the item in the provider\r\n */\r\n id: string;\r\n /**\r\n * @hidden\r\n * Display name/title\r\n */\r\n title: string;\r\n /**\r\n * @hidden\r\n * Key to differentiate files and subdirectory\r\n */\r\n isSubdirectory: boolean;\r\n /**\r\n * @hidden\r\n * File extension\r\n */\r\n type: string;\r\n /**\r\n * @hidden\r\n * Last modifed time of the item\r\n */\r\n lastModifiedTime: string;\r\n /**\r\n * @hidden\r\n * Display size of the items in bytes\r\n */\r\n size: number;\r\n /**\r\n * @hidden\r\n * URL of the file\r\n */\r\n objectUrl: string;\r\n /**\r\n * @hidden\r\n * Temporary access token for the item\r\n */\r\n accessToken?: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Files entity user interface\r\n */\r\n export interface IFilesEntityUser {\r\n /**\r\n * User name.\r\n */\r\n displayName: string;\r\n /**\r\n * User email.\r\n */\r\n email: string;\r\n\r\n /**\r\n * User MRI.\r\n */\r\n mri: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Special Document Library enum\r\n */\r\n export enum SpecialDocumentLibraryType {\r\n ClassMaterials = 'classMaterials',\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Document Library Access enum\r\n */\r\n export enum DocumentLibraryAccessType {\r\n Readonly = 'readonly',\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * SharePoint file interface\r\n */\r\n export interface ISharePointFile {\r\n siteId?: string;\r\n siteUrl: string;\r\n objectId: string;\r\n objectUrl: string;\r\n openInWindowFileUrl: string;\r\n title: string;\r\n isFolder: boolean;\r\n serverRelativeUrl: string;\r\n lastModifiedByUser: IFilesEntityUser;\r\n lastModifiedTime: string;\r\n sentByUser: IFilesEntityUser;\r\n createdByUser: IFilesEntityUser;\r\n createdTime: string;\r\n size: number;\r\n type: string;\r\n spItemUrl?: string;\r\n libraryType?: SpecialDocumentLibraryType;\r\n accessType?: DocumentLibraryAccessType;\r\n etag?: string;\r\n remoteItem?: string;\r\n listUrl?: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Download status enum\r\n */\r\n export enum FileDownloadStatus {\r\n Downloaded = 'Downloaded',\r\n Downloading = 'Downloading',\r\n Failed = 'Failed',\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n *\r\n * Download Files interface\r\n */\r\n export interface IFileItem {\r\n /**\r\n * ID of the file metadata\r\n */\r\n objectId?: string;\r\n /**\r\n * Path of the file\r\n */\r\n path?: string;\r\n /**\r\n * Size of the file in bytes\r\n */\r\n sizeInBytes?: number;\r\n /**\r\n * Download status\r\n */\r\n status?: FileDownloadStatus;\r\n /**\r\n * Download timestamp\r\n */\r\n timestamp: Date;\r\n /**\r\n * File name\r\n */\r\n title: string;\r\n /**\r\n * Type of file i.e. the file extension.\r\n */\r\n extension: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Gets a list of cloud storage folders added to the channel\r\n *\r\n * @param channelId - ID of the channel whose cloud storage folders should be retrieved\r\n */\r\n export function getCloudStorageFolders(channelId: string): Promise<CloudStorageFolder[]> {\r\n return new Promise<CloudStorageFolder[]>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!channelId || channelId.length === 0) {\r\n throw new Error('[files.getCloudStorageFolders] channelId name cannot be null or empty');\r\n }\r\n\r\n resolve(sendAndHandleError('files.getCloudStorageFolders', channelId));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Initiates the add cloud storage folder flow\r\n * @param channelId - ID of the channel to add cloud storage folder\r\n */\r\n export function addCloudStorageFolder(channelId: string): Promise<[boolean, CloudStorageFolder[]]> {\r\n return new Promise<[SdkError, boolean, CloudStorageFolder[]]>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!channelId || channelId.length === 0) {\r\n throw new Error('[files.addCloudStorageFolder] channelId name cannot be null or empty');\r\n }\r\n\r\n resolve(sendMessageToParentAsync('files.addCloudStorageFolder', [channelId]));\r\n }).then(([error, isFolderAdded, folders]: [SdkError, boolean, CloudStorageFolder[]]) => {\r\n if (error) {\r\n throw error;\r\n }\r\n const result: [boolean, CloudStorageFolder[]] = [isFolderAdded, folders];\r\n return result;\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Deletes a cloud storage folder from channel\r\n *\r\n * @param channelId - ID of the channel where folder is to be deleted\r\n * @param folderToDelete - cloud storage folder to be deleted\r\n */\r\n export function deleteCloudStorageFolder(channelId: string, folderToDelete: CloudStorageFolder): Promise<boolean> {\r\n return new Promise<boolean>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!channelId) {\r\n throw new Error('[files.deleteCloudStorageFolder] channelId name cannot be null or empty');\r\n }\r\n if (!folderToDelete) {\r\n throw new Error('[files.deleteCloudStorageFolder] folderToDelete cannot be null or empty');\r\n }\r\n\r\n resolve(sendAndHandleError('files.deleteCloudStorageFolder', channelId, folderToDelete));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Fetches the contents of a Cloud storage folder (CloudStorageFolder) / sub directory\r\n *\r\n * @param folder - Cloud storage folder (CloudStorageFolder) / sub directory (CloudStorageFolderItem)\r\n * @param providerCode - Code of the cloud storage folder provider\r\n */\r\n export function getCloudStorageFolderContents(\r\n folder: CloudStorageFolder | CloudStorageFolderItem,\r\n providerCode: CloudStorageProvider,\r\n ): Promise<CloudStorageFolderItem[]> {\r\n return new Promise<CloudStorageFolderItem[]>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!folder || !providerCode) {\r\n throw new Error('[files.getCloudStorageFolderContents] folder/providerCode name cannot be null or empty');\r\n }\r\n\r\n if ('isSubdirectory' in folder && !folder.isSubdirectory) {\r\n throw new Error('[files.getCloudStorageFolderContents] provided folder is not a subDirectory');\r\n }\r\n\r\n resolve(sendAndHandleError('files.getCloudStorageFolderContents', folder, providerCode));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Open a cloud storage file in teams\r\n *\r\n * @param file - cloud storage file that should be opened\r\n * @param providerCode - Code of the cloud storage folder provider\r\n * @param fileOpenPreference - Whether file should be opened in web/inline\r\n */\r\n export function openCloudStorageFile(\r\n file: CloudStorageFolderItem,\r\n providerCode: CloudStorageProvider,\r\n fileOpenPreference?: FileOpenPreference.Web | FileOpenPreference.Inline,\r\n ): void {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!file || !providerCode) {\r\n throw new Error('[files.openCloudStorageFile] file/providerCode cannot be null or empty');\r\n }\r\n\r\n if (file.isSubdirectory) {\r\n throw new Error('[files.openCloudStorageFile] provided file is a subDirectory');\r\n }\r\n\r\n sendMessageToParent('files.openCloudStorageFile', [file, providerCode, fileOpenPreference]);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Opens a client-friendly preview of the specified file.\r\n *\r\n * @param file - The file to preview.\r\n */\r\n export function openFilePreview(filePreviewParameters: FilePreviewParameters): void {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n const params = [\r\n filePreviewParameters.entityId,\r\n filePreviewParameters.title,\r\n filePreviewParameters.description,\r\n filePreviewParameters.type,\r\n filePreviewParameters.objectUrl,\r\n filePreviewParameters.downloadUrl,\r\n filePreviewParameters.webPreviewUrl,\r\n filePreviewParameters.webEditUrl,\r\n filePreviewParameters.baseUrl,\r\n filePreviewParameters.editFile,\r\n filePreviewParameters.subEntityId,\r\n filePreviewParameters.viewerAction,\r\n filePreviewParameters.fileOpenPreference,\r\n filePreviewParameters.conversationId,\r\n ];\r\n\r\n sendMessageToParent('openFilePreview', params);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Allow 1st party apps to call this function to get the external\r\n * third party cloud storage accounts that the tenant supports\r\n * @param excludeAddedProviders: return a list of support third party\r\n * cloud storages that hasn't been added yet.\r\n */\r\n export function getExternalProviders(excludeAddedProviders = false): Promise<IExternalProvider[]> {\r\n return new Promise<IExternalProvider[]>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n resolve(sendAndHandleError('files.getExternalProviders', excludeAddedProviders));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Allow 1st party apps to call this function to move files\r\n * among SharePoint and third party cloud storages.\r\n */\r\n export function copyMoveFiles(\r\n selectedFiles: CloudStorageFolderItem[] | ISharePointFile[],\r\n providerCode: CloudStorageProvider,\r\n destinationFolder: CloudStorageFolderItem | ISharePointFile,\r\n destinationProviderCode: CloudStorageProvider,\r\n isMove = false,\r\n ): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n ensureInitialized(FrameContexts.content);\r\n if (!selectedFiles || selectedFiles.length === 0) {\r\n throw new Error('[files.copyMoveFiles] selectedFiles cannot be null or empty');\r\n }\r\n if (!providerCode) {\r\n throw new Error('[files.copyMoveFiles] providerCode cannot be null or empty');\r\n }\r\n if (!destinationFolder) {\r\n throw new Error('[files.copyMoveFiles] destinationFolder cannot be null or empty');\r\n }\r\n if (!destinationProviderCode) {\r\n throw new Error('[files.copyMoveFiles] destinationProviderCode cannot be null or empty');\r\n }\r\n\r\n resolve(\r\n sendAndHandleError(\r\n 'files.copyMoveFiles',\r\n selectedFiles,\r\n providerCode,\r\n destinationFolder,\r\n destinationProviderCode,\r\n isMove,\r\n ),\r\n );\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.files ? true : false;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Gets list of downloads for current user\r\n * @param callback Callback that will be triggered post downloads load\r\n */\r\n export function getFileDownloads(): Promise<IFileItem[]>;\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n *\r\n * @deprecated\r\n * As of 2.0.0-beta.4, please use {@link file.getFileDownloads file.getFileDownloads(): Promise\\<IFileItem[]\\>} instead.\r\n * Gets list of downloads for current user\r\n * @param callback Callback that will be triggered post downloads load\r\n */\r\n export function getFileDownloads(callback: (error?: SdkError, files?: IFileItem[]) => void): void;\r\n export function getFileDownloads(callback?: (error?: SdkError, files?: IFileItem[]) => void): Promise<IFileItem[]> {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n const wrappedFunction = (): Promise<IFileItem[]> =>\r\n new Promise(resolve => resolve(sendAndHandleError('files.getFileDownloads', [])));\r\n\r\n return callCallbackWithErrorOrResultFromPromiseAndReturnPromise(wrappedFunction, callback);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Open download preference folder\r\n */\r\n export function openDownloadFolder(): void {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n sendMessageToParent('files.openDownloadFolder', []);\r\n }\r\n}\r\n","import { sendAndUnwrap } from '../internal/communication';\r\nimport { getUserJoinedTeamsSupportedAndroidClientVersion } from '../internal/constants';\r\nimport { GlobalVars } from '../internal/globalVars';\r\nimport { ensureInitialized, isCurrentSDKVersionAtLeast } from '../internal/internalAPIs';\r\nimport { HostClientType } from '../public/constants';\r\nimport { ErrorCode, SdkError } from '../public/interfaces';\r\nimport { runtime } from '../public/runtime';\r\nimport { TeamInstanceParameters, UserJoinedTeamsInformation } from './interfaces';\r\n\r\n/**\r\n * @internal\r\n */\r\nexport namespace legacy {\r\n export namespace fullTrust {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Allows an app to retrieve information of all user joined teams\r\n *\r\n * @param teamInstanceParameters - OPTIONAL Flags that specify whether to scope call to favorite teams\r\n * @returns Promise resolved containing information about the user joined teams or rejected with error\r\n */\r\n export function getUserJoinedTeams(\r\n teamInstanceParameters?: TeamInstanceParameters,\r\n ): Promise<UserJoinedTeamsInformation> {\r\n return new Promise<UserJoinedTeamsInformation>(resolve => {\r\n ensureInitialized();\r\n\r\n if (\r\n (GlobalVars.hostClientType === HostClientType.android ||\r\n GlobalVars.hostClientType === HostClientType.teamsRoomsAndroid ||\r\n GlobalVars.hostClientType === HostClientType.teamsPhones ||\r\n GlobalVars.hostClientType === HostClientType.teamsDisplays) &&\r\n !isCurrentSDKVersionAtLeast(getUserJoinedTeamsSupportedAndroidClientVersion)\r\n ) {\r\n const oldPlatformError: SdkError = { errorCode: ErrorCode.OLD_PLATFORM };\r\n throw new Error(JSON.stringify(oldPlatformError));\r\n }\r\n\r\n resolve(sendAndUnwrap('getUserJoinedTeams', teamInstanceParameters));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Allows an app to get the configuration setting value\r\n *\r\n * @param key - The key for the config setting\r\n * @returns Promise resolved containing the value for the provided config setting or rejected with error\r\n */\r\n export function getConfigSetting(key: string): Promise<string> {\r\n return new Promise<string>(resolve => {\r\n ensureInitialized();\r\n resolve(sendAndUnwrap('getConfigSetting', key));\r\n });\r\n }\r\n\r\n /**\r\n * Checks if teams.fullTrust capability is supported currently\r\n */\r\n export function isSupported(): boolean {\r\n return runtime.supports.teams ? (runtime.supports.teams.fullTrust ? true : false) : false;\r\n }\r\n }\r\n}\r\n","import { sendAndHandleSdkError } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { runtime } from '../public/runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace meetingRoom {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Data structure to represent a meeting room.\r\n */\r\n export interface MeetingRoomInfo {\r\n /**\r\n * @hidden\r\n * Endpoint id of the meeting room.\r\n */\r\n endpointId: string;\r\n /**\r\n * @hidden\r\n * Device name of the meeting room.\r\n */\r\n deviceName: string;\r\n /**\r\n * @hidden\r\n * Client type of the meeting room.\r\n */\r\n clientType: string;\r\n /**\r\n * @hidden\r\n * Client version of the meeting room.\r\n */\r\n clientVersion: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Type of Media control capabilities of a meeting room.\r\n */\r\n type MediaControls = 'toggleMute' | 'toggleCamera' | 'toggleCaptions' | 'volume';\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Types of Stage Layout control capabilities of a meeting room.\r\n */\r\n\r\n type StageLayoutControls =\r\n | 'showVideoGallery'\r\n | 'showContent'\r\n | 'showContent'\r\n | 'showVideoGalleryAndContent'\r\n | 'showLargeGallery'\r\n | 'showTogether';\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Types of Meeting Control capabilities of a meeting room.\r\n */\r\n\r\n type MeetingControls = 'leaveMeeting';\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Types of Stage Layout State of a meeting room.\r\n */\r\n\r\n type StageLayoutStates = 'Gallery' | 'Content + gallery' | 'Content' | 'Large gallery' | 'Together mode';\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Data structure to represent capabilities of a meeting room.\r\n */\r\n export interface MeetingRoomCapability {\r\n /**\r\n * @hidden\r\n * Media control capabilities, value can be \"toggleMute\", \"toggleCamera\", \"toggleCaptions\", \"volume\".\r\n */\r\n mediaControls: MediaControls[];\r\n /**\r\n * @hidden\r\n * Main stage layout control capabilities, value can be \"showVideoGallery\", \"showContent\", \"showVideoGalleryAndContent\", \"showLargeGallery\", \"showTogether\".\r\n */\r\n stageLayoutControls: StageLayoutControls[];\r\n /**\r\n * @hidden\r\n * Meeting control capabilities, value can be \"leaveMeeting\".\r\n */\r\n meetingControls: MeetingControls[];\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Data structure to represent states of a meeting room.\r\n */\r\n export interface MeetingRoomState {\r\n /**\r\n * @hidden\r\n * Current mute state, true: mute, false: unmute.\r\n */\r\n toggleMute: boolean;\r\n /**\r\n * @hidden\r\n * Current camera state, true: camera on, false: camera off.\r\n */\r\n toggleCamera: boolean;\r\n /**\r\n * @hidden\r\n * Current captions state, true: captions on, false: captions off.\r\n */\r\n toggleCaptions: boolean;\r\n /**\r\n * @hidden\r\n * Current main stage layout state, value can be one of \"Gallery\", \"Content + gallery\", \"Content\", \"Large gallery\" and \"Together mode\".\r\n */\r\n stageLayout: StageLayoutStates;\r\n /**\r\n * @hidden\r\n * Current leaveMeeting state, true: leave, false: no-op.\r\n */\r\n leaveMeeting: boolean;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Fetch the meeting room info that paired with current client.\r\n *\r\n * @returns Promise resolved with meeting room info or rejected with SdkError value\r\n */\r\n export function getPairedMeetingRoomInfo(): Promise<MeetingRoomInfo> {\r\n return new Promise<MeetingRoomInfo>(resolve => {\r\n ensureInitialized();\r\n resolve(sendAndHandleSdkError('meetingRoom.getPairedMeetingRoomInfo'));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Send a command to paired meeting room.\r\n *\r\n * @param commandName The command name.\r\n * @returns Promise resolved upon completion or rejected with SdkError value\r\n */\r\n export function sendCommandToPairedMeetingRoom(commandName: string): Promise<void> {\r\n return new Promise<void>(resolve => {\r\n if (!commandName || commandName.length == 0) {\r\n throw new Error('[meetingRoom.sendCommandToPairedMeetingRoom] Command name cannot be null or empty');\r\n }\r\n ensureInitialized();\r\n resolve(sendAndHandleSdkError('meetingRoom.sendCommandToPairedMeetingRoom', commandName));\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Registers a handler for meeting room capabilities update.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler The handler to invoke when the capabilities of meeting room update.\r\n */\r\n export function registerMeetingRoomCapabilitiesUpdateHandler(\r\n handler: (capabilities: MeetingRoomCapability) => void,\r\n ): void {\r\n if (!handler) {\r\n throw new Error('[meetingRoom.registerMeetingRoomCapabilitiesUpdateHandler] Handler cannot be null');\r\n }\r\n ensureInitialized();\r\n registerHandler('meetingRoom.meetingRoomCapabilitiesUpdate', (capabilities: MeetingRoomCapability) => {\r\n ensureInitialized();\r\n handler(capabilities);\r\n });\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * Registers a handler for meeting room states update.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler The handler to invoke when the states of meeting room update.\r\n */\r\n export function registerMeetingRoomStatesUpdateHandler(handler: (states: MeetingRoomState) => void): void {\r\n if (!handler) {\r\n throw new Error('[meetingRoom.registerMeetingRoomStatesUpdateHandler] Handler cannot be null');\r\n }\r\n ensureInitialized();\r\n registerHandler('meetingRoom.meetingRoomStatesUpdate', (states: MeetingRoomState) => {\r\n ensureInitialized();\r\n handler(states);\r\n });\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.meetingRoom ? true : false;\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from '../public/constants';\r\nimport { runtime } from '../public/runtime';\r\nimport { ShowNotificationParameters } from './interfaces';\r\n\r\nexport namespace notifications {\r\n /**\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * display notification API.\r\n *\r\n * @param message - Notification message.\r\n * @param notificationType - Notification type\r\n *\r\n * @internal\r\n */\r\n export function showNotification(showNotificationParameters: ShowNotificationParameters): void {\r\n ensureInitialized(FrameContexts.content);\r\n sendMessageToParent('notifications.showNotification', [showNotificationParameters]);\r\n }\r\n export function isSupported(): boolean {\r\n return runtime.supports.notifications ? true : false;\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { registerHandler } from '../internal/handlers';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from '../public/constants';\r\nimport { SdkError } from '../public/interfaces';\r\nimport { runtime } from '../public/runtime';\r\n\r\n/**\r\n * @alpha\r\n */\r\nexport namespace remoteCamera {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Data structure to represent patricipant details needed to request control of camera.\r\n */\r\n export interface Participant {\r\n /**\r\n * @hidden\r\n * Id of participant.\r\n */\r\n id: string;\r\n /**\r\n * @hidden\r\n * Display name of participant.\r\n */\r\n displayName?: string;\r\n /**\r\n * @hidden\r\n * Active indicates whether the participant's device is actively being controlled.\r\n */\r\n active?: boolean;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Enum used to indicate possible camera control commands.\r\n */\r\n export enum ControlCommand {\r\n Reset = 'Reset',\r\n ZoomIn = 'ZoomIn',\r\n ZoomOut = 'ZoomOut',\r\n PanLeft = 'PanLeft',\r\n PanRight = 'PanRight',\r\n TiltUp = 'TiltUp',\r\n TiltDown = 'TiltDown',\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Data structure to indicate the current state of the device.\r\n */\r\n export interface DeviceState {\r\n /**\r\n * @hidden\r\n * All operation are available to apply.\r\n */\r\n available: boolean;\r\n /**\r\n * @hidden\r\n * Either camera doesnt support to get state or It unable to apply command.\r\n */\r\n error: boolean;\r\n /**\r\n * @hidden\r\n * Reset max out or already applied. Client Disable Reset.\r\n */\r\n reset: boolean;\r\n /**\r\n * @hidden\r\n * ZoomIn maxed out.\r\n */\r\n zoomIn: boolean;\r\n /**\r\n * @hidden\r\n * ZoomOut maxed out.\r\n */\r\n zoomOut: boolean;\r\n /**\r\n * @hidden\r\n * PanLeft reached max left.\r\n */\r\n panLeft: boolean;\r\n /**\r\n * @hidden\r\n * PanRight reached max right.\r\n */\r\n panRight: boolean;\r\n /**\r\n * @hidden\r\n * TiltUp reached top.\r\n */\r\n tiltUp: boolean;\r\n /**\r\n * @hidden\r\n * TiltDown reached bottom.\r\n */\r\n tiltDown: boolean;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Enum used to indicate the reason for the error.\r\n */\r\n export enum ErrorReason {\r\n CommandResetError,\r\n CommandZoomInError,\r\n CommandZoomOutError,\r\n CommandPanLeftError,\r\n CommandPanRightError,\r\n CommandTiltUpError,\r\n CommandTiltDownError,\r\n SendDataError,\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Data structure to indicate the status of the current session.\r\n */\r\n export interface SessionStatus {\r\n /**\r\n * @hidden\r\n * Whether the far-end user is controlling a device.\r\n */\r\n inControl: boolean;\r\n /**\r\n * @hidden\r\n * Reason the control session was terminated.\r\n */\r\n terminatedReason?: SessionTerminatedReason;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Enum used to indicate the reason the session was terminated.\r\n */\r\n export enum SessionTerminatedReason {\r\n None,\r\n ControlDenied,\r\n ControlNoResponse,\r\n ControlBusy,\r\n AckTimeout,\r\n ControlTerminated,\r\n ControllerTerminated,\r\n DataChannelError,\r\n ControllerCancelled,\r\n ControlDisabled,\r\n ControlTerminatedToAllowOtherController,\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Fetch a list of the participants with controllable-cameras in a meeting.\r\n *\r\n * @param callback - Callback contains 2 parameters, error and participants.\r\n * error can either contain an error of type SdkError, incase of an error, or null when fetch is successful\r\n * participants can either contain an array of Participant objects, incase of a successful fetch or null when it fails\r\n * participants: object that contains an array of participants with controllable-cameras\r\n */\r\n export function getCapableParticipants(\r\n callback: (error: SdkError | null, participants: Participant[] | null) => void,\r\n ): void {\r\n if (!callback) {\r\n throw new Error('[remoteCamera.getCapableParticipants] Callback cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n sendMessageToParent('remoteCamera.getCapableParticipants', callback);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Request control of a participant's camera.\r\n *\r\n * @param participant - Participant specifies the participant to send the request for camera control.\r\n * @param callback - Callback contains 2 parameters, error and requestResponse.\r\n * error can either contain an error of type SdkError, incase of an error, or null when fetch is successful\r\n * requestResponse can either contain the true/false value, incase of a successful request or null when it fails\r\n * requestResponse: True means request was accepted and false means request was denied\r\n */\r\n export function requestControl(\r\n participant: Participant,\r\n callback: (error: SdkError | null, requestResponse: boolean | null) => void,\r\n ): void {\r\n if (!participant) {\r\n throw new Error('[remoteCamera.requestControl] Participant cannot be null');\r\n }\r\n if (!callback) {\r\n throw new Error('[remoteCamera.requestControl] Callback cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n sendMessageToParent('remoteCamera.requestControl', [participant], callback);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Send control command to the participant's camera.\r\n *\r\n * @param ControlCommand - ControlCommand specifies the command for controling the camera.\r\n * @param callback - Callback to invoke when the command response returns.\r\n */\r\n export function sendControlCommand(ControlCommand: ControlCommand, callback: (error: SdkError | null) => void): void {\r\n if (!ControlCommand) {\r\n throw new Error('[remoteCamera.sendControlCommand] ControlCommand cannot be null');\r\n }\r\n if (!callback) {\r\n throw new Error('[remoteCamera.sendControlCommand] Callback cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n sendMessageToParent('remoteCamera.sendControlCommand', [ControlCommand], callback);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Terminate the remote session\r\n *\r\n * @param callback - Callback to invoke when the command response returns.\r\n */\r\n export function terminateSession(callback: (error: SdkError | null) => void): void {\r\n if (!callback) {\r\n throw new Error('[remoteCamera.terminateSession] Callback cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n sendMessageToParent('remoteCamera.terminateSession', callback);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers a handler for change in participants with controllable-cameras.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the list of participants with controllable-cameras changes.\r\n */\r\n export function registerOnCapableParticipantsChangeHandler(\r\n handler: (participantChange: Participant[]) => void,\r\n ): void {\r\n if (!handler) {\r\n throw new Error('[remoteCamera.registerOnCapableParticipantsChangeHandler] Handler cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n registerHandler('remoteCamera.capableParticipantsChange', handler);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers a handler for error.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when there is an error from the camera handler.\r\n */\r\n export function registerOnErrorHandler(handler: (error: ErrorReason) => void): void {\r\n if (!handler) {\r\n throw new Error('[remoteCamera.registerOnErrorHandler] Handler cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n registerHandler('remoteCamera.handlerError', handler);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers a handler for device state change.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the controlled device changes state.\r\n */\r\n export function registerOnDeviceStateChangeHandler(handler: (deviceStateChange: DeviceState) => void): void {\r\n if (!handler) {\r\n throw new Error('[remoteCamera.registerOnDeviceStateChangeHandler] Handler cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n registerHandler('remoteCamera.deviceStateChange', handler);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Registers a handler for session status change.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the current session status changes.\r\n */\r\n export function registerOnSessionStatusChangeHandler(handler: (sessionStatusChange: SessionStatus) => void): void {\r\n if (!handler) {\r\n throw new Error('[remoteCamera.registerOnSessionStatusChangeHandler] Handler cannot be null');\r\n }\r\n ensureInitialized(FrameContexts.sidePanel);\r\n registerHandler('remoteCamera.sessionStatusChange', handler);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.remoteCamera ? true : false;\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts, SdkError } from '../public';\r\nimport { runtime } from '../public/runtime';\r\n/**\r\n * @hidden\r\n * Namespace to interact with the application entities specific part of the SDK.\r\n *\r\n * @alpha\r\n */\r\nexport namespace appEntity {\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Information on an app entity\r\n *\r\n * @alpha\r\n */\r\n export interface AppEntity {\r\n /**\r\n * @hidden\r\n * App ID of the application\r\n */\r\n appId: string;\r\n\r\n /**\r\n * @hidden\r\n * URL for the application's icon\r\n */\r\n appIconUrl: string;\r\n\r\n /**\r\n * @hidden\r\n * Content URL for the app entity\r\n */\r\n contentUrl: string;\r\n\r\n /**\r\n * @hidden\r\n * The display name for the app entity\r\n */\r\n displayName: string;\r\n\r\n /**\r\n * @hidden\r\n * Website URL for the app entity. It is meant to be opened by the user in a browser.\r\n */\r\n websiteUrl: string;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * --------\r\n * Open the Tab Gallery and retrieve the app entity\r\n * @param threadId ID of the thread where the app entity will be created\r\n * @param categories A list of app categories that will be displayed in the opened tab gallery\r\n * @param subEntityId An object that will be made available to the application being configured\r\n * through the Teams Context's subEntityId field.\r\n * @param callback Callback that will be triggered once the app entity information is available.\r\n * The callback takes two arguments: an SdkError in case something happened (i.e.\r\n * no permissions to execute the API) and the app entity configuration, if available\r\n *\r\n * @alpha\r\n */\r\n export function selectAppEntity(\r\n threadId: string,\r\n categories: string[],\r\n subEntityId: string,\r\n callback: (sdkError?: SdkError, appEntity?: AppEntity) => void,\r\n ): void {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!threadId || threadId.length == 0) {\r\n throw new Error('[appEntity.selectAppEntity] threadId name cannot be null or empty');\r\n }\r\n\r\n if (!callback) {\r\n throw new Error('[appEntity.selectAppEntity] Callback cannot be null');\r\n }\r\n\r\n sendMessageToParent('appEntity.selectAppEntity', [threadId, categories, subEntityId], callback);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.appEntity ? true : false;\r\n }\r\n}\r\n","import { sendMessageToParent } from '../internal/communication';\r\nimport { ensureInitialized } from '../internal/internalAPIs';\r\nimport { FrameContexts } from '../public/constants';\r\nimport { SdkError } from '../public/interfaces';\r\nimport { runtime } from '../public/runtime';\r\n\r\n/**\r\n * @hidden\r\n * Namespace to interact with the `teams` specific part of the SDK.\r\n * ------\r\n * Hide from docs\r\n *\r\n * @internal\r\n */\r\nexport namespace teams {\r\n export enum ChannelType {\r\n Regular = 0,\r\n Private = 1,\r\n Shared = 2,\r\n }\r\n\r\n export interface ChannelInfo {\r\n siteUrl: string;\r\n objectId: string;\r\n folderRelativeUrl: string;\r\n displayName: string;\r\n channelType: ChannelType;\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Hide from docs\r\n * ------\r\n * Get a list of channels belong to a Team\r\n *\r\n * @param groupId - a team's objectId\r\n */\r\n export function getTeamChannels(groupId: string, callback: (error: SdkError, channels: ChannelInfo[]) => void): void {\r\n ensureInitialized(FrameContexts.content);\r\n\r\n if (!groupId) {\r\n throw new Error('[teams.getTeamChannels] groupId cannot be null or empty');\r\n }\r\n\r\n if (!callback) {\r\n throw new Error('[teams.getTeamChannels] Callback cannot be null');\r\n }\r\n\r\n sendMessageToParent('teams.getTeamChannels', [groupId], callback);\r\n }\r\n\r\n /**\r\n * @hidden\r\n * Allow 1st party apps to call this function when they receive migrated errors to inform the Hub/Host to refresh the siteurl\r\n * when site admin renames siteurl.\r\n *\r\n * @param threadId - ID of the thread where the app entity will be created; if threadId is not\r\n * provided, the threadId from route params will be used.\r\n */\r\n export function refreshSiteUrl(threadId: string, callback: (error: SdkError) => void): void {\r\n ensureInitialized();\r\n\r\n if (!threadId) {\r\n throw new Error('[teams.refreshSiteUrl] threadId cannot be null or empty');\r\n }\r\n\r\n if (!callback) {\r\n throw new Error('[teams.refreshSiteUrl] Callback cannot be null');\r\n }\r\n\r\n sendMessageToParent('teams.refreshSiteUrl', [threadId], callback);\r\n }\r\n\r\n export function isSupported(): boolean {\r\n return runtime.supports.teams ? true : false;\r\n }\r\n}\r\n","import { ensureInitialized } from '../internal/internalAPIs';\r\nimport { getGenericOnCompleteHandler } from '../internal/utils';\r\nimport { app } from './app';\r\nimport { FrameContexts } from './constants';\r\nimport {\r\n Context,\r\n DeepLinkParameters,\r\n FrameContext,\r\n LoadContext,\r\n TabInformation,\r\n TabInstanceParameters,\r\n} from './interfaces';\r\nimport { pages } from './pages';\r\nimport { teamsCore } from './teamsAPIs';\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.initialize app.initialize(validMessageOrigins?: string[]): Promise\\<void\\>} instead.\r\n *\r\n * Initializes the library. This must be called before any other SDK calls\r\n * but after the frame is loaded successfully.\r\n * @param callback - Optionally specify a callback to invoke when Teams SDK has successfully initialized\r\n * @param validMessageOrigins - Optionally specify a list of cross frame message origins. There must have\r\n * https: protocol otherwise they will be ignored. Example: https://www.example.com\r\n */\r\nexport function initialize(callback?: () => void, validMessageOrigins?: string[]): void {\r\n app.initialize(validMessageOrigins).then(() => {\r\n if (callback) {\r\n callback();\r\n }\r\n });\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app._initialize app._initialize(hostWindow: any): void} instead.\r\n *\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Undocumented function used to set a mock window for unit tests\r\n *\r\n * @internal\r\n */\r\n// eslint-disable-next-line\r\nexport function _initialize(hostWindow: any): void {\r\n app._initialize(hostWindow);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app._uninitialize app._uninitialize(): void} instead.\r\n *\r\n * @hidden\r\n * Hide from docs.\r\n * ------\r\n * Undocumented function used to clear state between unit tests\r\n *\r\n * @internal\r\n */\r\nexport function _uninitialize(): void {\r\n app._uninitialize();\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link teamsCore.enablePrintCapability teamsCore.enablePrintCapability(): void} instead.\r\n *\r\n * Enable print capability to support printing page using Ctrl+P and cmd+P\r\n */\r\nexport function enablePrintCapability(): void {\r\n teamsCore.enablePrintCapability();\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link teamsCore.print teamsCore.print(): void} instead.\r\n *\r\n * Default print handler\r\n */\r\nexport function print(): void {\r\n teamsCore.print();\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.getContext app.getContext(): Promise\\<app.Context\\>} instead.\r\n *\r\n * Retrieves the current context the frame is running in.\r\n *\r\n * @param callback - The callback to invoke when the {@link Context} object is retrieved.\r\n */\r\nexport function getContext(callback: (context: Context) => void): void {\r\n ensureInitialized();\r\n app.getContext().then((context: app.Context) => {\r\n if (callback) {\r\n callback(transformAppContextToLegacyContext(context));\r\n }\r\n });\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link app.registerOnThemeChangeHandler app.registerOnThemeChangeHandler(handler: (theme: string) => void): void} instead.\r\n *\r\n * Registers a handler for theme changes.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the user changes their theme.\r\n */\r\nexport function registerOnThemeChangeHandler(handler: (theme: string) => void): void {\r\n app.registerOnThemeChangeHandler(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.registerFullScreenHandler pages.registerFullScreenHandler(handler: (isFullScreen: boolean) => void): void} instead.\r\n *\r\n * Registers a handler for changes from or to full-screen view for a tab.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the user toggles full-screen view for a tab.\r\n */\r\nexport function registerFullScreenHandler(handler: (isFullScreen: boolean) => void): void {\r\n pages.registerFullScreenHandler(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.appButton.onClick pages.appButton.onClick(handler: () => void): void} instead.\r\n *\r\n * Registers a handler for clicking the app button.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when the personal app button is clicked in the app bar.\r\n */\r\nexport function registerAppButtonClickHandler(handler: () => void): void {\r\n pages.appButton.onClick(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.appButton.onHoverEnter pages.appButton.onHoverEnter(handler: () => void): void} instead.\r\n *\r\n * Registers a handler for entering hover of the app button.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n *\r\n * @param handler - The handler to invoke when entering hover of the personal app button in the app bar.\r\n */\r\nexport function registerAppButtonHoverEnterHandler(handler: () => void): void {\r\n pages.appButton.onHoverEnter(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.appButton.onHoverLeave pages.appButton.onHoverLeave(handler: () => void): void} instead.\r\n *\r\n * Registers a handler for exiting hover of the app button.\r\n * Only one handler can be registered at a time. A subsequent registration replaces an existing registration.\r\n * @param handler - The handler to invoke when exiting hover of the personal app button in the app bar.\r\n *\r\n */\r\nexport function registerAppButtonHoverLeaveHandler(handler: () => void): void {\r\n pages.appButton.onHoverLeave(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.backStack.registerBackButtonHandler pages.backStack.registerBackButtonHandler(handler: () => boolean): void} instead.\r\n *\r\n * Registers a handler for user presses of the Team client's back button. Experiences that maintain an internal\r\n * navigation stack should use this handler to navigate the user back within their frame. If an app finds\r\n * that after running its back button handler it cannot handle the event it should call the navigateBack\r\n * method to ask the Teams client to handle it instead.\r\n *\r\n * @param handler - The handler to invoke when the user presses their Team client's back button.\r\n */\r\nexport function registerBackButtonHandler(handler: () => boolean): void {\r\n pages.backStack.registerBackButtonHandler(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link teamsCore.registerOnLoadHandler teamsCore.registerOnLoadHandler(handler: (context: LoadContext) => void): void} instead.\r\n *\r\n * @hidden\r\n * Registers a handler to be called when the page has been requested to load.\r\n *\r\n * @param handler - The handler to invoke when the page is loaded.\r\n */\r\nexport function registerOnLoadHandler(handler: (context: LoadContext) => void): void {\r\n teamsCore.registerOnLoadHandler(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link teamsCore.registerBeforeUnloadHandler teamsCore.registerBeforeUnloadHandler(handler: (readyToUnload: () => void) => boolean): void} instead.\r\n *\r\n * @hidden\r\n * Registers a handler to be called before the page is unloaded.\r\n *\r\n * @param handler - The handler to invoke before the page is unloaded. If this handler returns true the page should\r\n * invoke the readyToUnload function provided to it once it's ready to be unloaded.\r\n */\r\nexport function registerBeforeUnloadHandler(handler: (readyToUnload: () => void) => boolean): void {\r\n teamsCore.registerBeforeUnloadHandler(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link pages.registerFocusEnterHandler pages.registerFocusEnterHandler(handler: (navigateForward: boolean) => void): void} instead.\r\n *\r\n * @hidden\r\n * Registers a handler when focus needs to be passed from teams to the place of choice on app.\r\n *\r\n * @param handler - The handler to invoked by the app when they want the focus to be in the place of their choice.\r\n */\r\nexport function registerFocusEnterHandler(handler: (navigateForward: boolean) => boolean): void {\r\n pages.registerFocusEnterHandler(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.config.registerChangeConfigHandler pages.config.registerChangeConfigHandler(handler: () => void): void} instead.\r\n *\r\n * Registers a handler for when the user reconfigurated tab.\r\n *\r\n * @param handler - The handler to invoke when the user click on Settings.\r\n */\r\nexport function registerEnterSettingsHandler(handler: () => void): void {\r\n pages.config.registerChangeConfigHandler(handler);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.tabs.getTabInstances pages.tabs.getTabInstances(tabInstanceParameters?: TabInstanceParameters): Promise\\<TabInformation\\>} instead.\r\n *\r\n * Allows an app to retrieve for this user tabs that are owned by this app.\r\n * If no TabInstanceParameters are passed, the app defaults to favorite teams and favorite channels.\r\n *\r\n * @param callback - The callback to invoke when the {@link TabInstanceParameters} object is retrieved.\r\n * @param tabInstanceParameters - OPTIONAL Flags that specify whether to scope call to favorite teams or channels.\r\n */\r\nexport function getTabInstances(\r\n callback: (tabInfo: TabInformation) => void,\r\n tabInstanceParameters?: TabInstanceParameters,\r\n): void {\r\n ensureInitialized();\r\n pages.tabs.getTabInstances(tabInstanceParameters).then((tabInfo: TabInformation) => {\r\n callback(tabInfo);\r\n });\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.tabs.getMruTabInstances pages.tabs.getMruTabInstances(tabInstanceParameters?: TabInstanceParameters): Promise\\<TabInformation\\>} instead.\r\n *\r\n * Allows an app to retrieve the most recently used tabs for this user.\r\n *\r\n * @param callback - The callback to invoke when the {@link TabInformation} object is retrieved.\r\n * @param tabInstanceParameters - OPTIONAL Ignored, kept for future use\r\n */\r\nexport function getMruTabInstances(\r\n callback: (tabInfo: TabInformation) => void,\r\n tabInstanceParameters?: TabInstanceParameters,\r\n): void {\r\n ensureInitialized();\r\n pages.tabs.getMruTabInstances(tabInstanceParameters).then((tabInfo: TabInformation) => {\r\n callback(tabInfo);\r\n });\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link pages.shareDeepLink pages.shareDeepLink(deepLinkParameters: DeepLinkParameters): void} instead.\r\n *\r\n * Shares a deep link that a user can use to navigate back to a specific state in this page.\r\n *\r\n * @param deepLinkParameters - ID and label for the link and fallback URL.\r\n */\r\nexport function shareDeepLink(deepLinkParameters: DeepLinkParameters): void {\r\n pages.shareDeepLink(deepLinkParameters);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.3, please use {@link app.openLink core.openLink(deepLink: string): Promise\\<void\\>} instead.\r\n *\r\n * Execute deep link API.\r\n *\r\n * @param deepLink - deep link.\r\n */\r\nexport function executeDeepLink(deepLink: string, onComplete?: (status: boolean, reason?: string) => void): void {\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.settings,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n onComplete = onComplete ? onComplete : getGenericOnCompleteHandler();\r\n app\r\n .openLink(deepLink)\r\n .then(() => {\r\n onComplete(true);\r\n })\r\n .catch((err: Error) => {\r\n onComplete(false, err.message);\r\n });\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.setCurrentFrame pages.setCurrentFrame(frameInfo: FrameInfo): void} instead.\r\n *\r\n * Set the current Frame Context\r\n *\r\n * @param frameContext - FrameContext information to be set\r\n */\r\nexport function setFrameContext(frameContext: FrameContext): void {\r\n pages.setCurrentFrame(frameContext);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.initializeWithFrameContext pages.initializeWithFrameContext(frameInfo: FrameInfo, callback?: () => void, validMessageOrigins?: string[],): void} instead.\r\n *\r\n * Initilize with FrameContext\r\n *\r\n * @param frameContext - FrameContext information to be set\r\n * @param callback - The optional callback to be invoked be invoked after initilizing the frame context\r\n * @param validMessageOrigins - Optionally specify a list of cross frame message origins.\r\n * They must have https: protocol otherwise they will be ignored. Example: https:www.example.com\r\n */\r\nexport function initializeWithFrameContext(\r\n frameContext: FrameContext,\r\n callback?: () => void,\r\n validMessageOrigins?: string[],\r\n): void {\r\n pages.initializeWithFrameContext(frameContext, callback, validMessageOrigins);\r\n}\r\n\r\n/**\r\n * Transforms the app.Context object received to TeamsJS Context\r\n */\r\nfunction transformAppContextToLegacyContext(appContext: app.Context): Context {\r\n const context: Context = {\r\n // app\r\n locale: appContext.app.locale,\r\n appSessionId: appContext.app.sessionId,\r\n theme: appContext.app.theme,\r\n appIconPosition: appContext.app.iconPositionVertical,\r\n osLocaleInfo: appContext.app.osLocaleInfo,\r\n parentMessageId: appContext.app.parentMessageId,\r\n userClickTime: appContext.app.userClickTime,\r\n userFileOpenPreference: appContext.app.userFileOpenPreference,\r\n appLaunchId: appContext.app.appLaunchId,\r\n\r\n // app.host\r\n hostClientType: appContext.app.host.clientType,\r\n sessionId: appContext.app.host.sessionId,\r\n ringId: appContext.app.host.ringId,\r\n\r\n // page\r\n entityId: appContext.page.id,\r\n frameContext: appContext.page.frameContext,\r\n subEntityId: appContext.page.subPageId,\r\n isFullScreen: appContext.page.isFullScreen,\r\n isMultiWindow: appContext.page.isMultiWindow,\r\n sourceOrigin: appContext.page.sourceOrigin,\r\n\r\n // user\r\n userObjectId: appContext.user !== undefined ? appContext.user.id : undefined,\r\n isCallingAllowed: appContext.user !== undefined ? appContext.user.isCallingAllowed : undefined,\r\n isPSTNCallingAllowed: appContext.user !== undefined ? appContext.user.isPSTNCallingAllowed : undefined,\r\n userLicenseType: appContext.user !== undefined ? appContext.user.licenseType : undefined,\r\n loginHint: appContext.user !== undefined ? appContext.user.loginHint : undefined,\r\n userPrincipalName: appContext.user !== undefined ? appContext.user.userPrincipalName : undefined,\r\n\r\n // user.tenant\r\n tid:\r\n appContext.user !== undefined\r\n ? appContext.user.tenant !== undefined\r\n ? appContext.user.tenant.id\r\n : undefined\r\n : undefined,\r\n tenantSKU:\r\n appContext.user !== undefined\r\n ? appContext.user.tenant !== undefined\r\n ? appContext.user.tenant.teamsSku\r\n : undefined\r\n : undefined,\r\n\r\n // channel\r\n channelId: appContext.channel !== undefined ? appContext.channel.id : undefined,\r\n channelName: appContext.channel !== undefined ? appContext.channel.displayName : undefined,\r\n channelRelativeUrl: appContext.channel !== undefined ? appContext.channel.relativeUrl : undefined,\r\n channelType: appContext.channel !== undefined ? appContext.channel.membershipType : undefined,\r\n defaultOneNoteSectionId: appContext.channel !== undefined ? appContext.channel.defaultOneNoteSectionId : undefined,\r\n hostTeamGroupId: appContext.channel !== undefined ? appContext.channel.ownerGroupId : undefined,\r\n hostTeamTenantId: appContext.channel !== undefined ? appContext.channel.ownerTenantId : undefined,\r\n\r\n // chat\r\n chatId: appContext.chat !== undefined ? appContext.chat.id : undefined,\r\n\r\n // meeting\r\n meetingId: appContext.meeting !== undefined ? appContext.meeting.id : undefined,\r\n\r\n // sharepoint\r\n sharepoint: appContext.sharepoint,\r\n\r\n // team\r\n teamId: appContext.team !== undefined ? appContext.team.internalId : undefined,\r\n teamName: appContext.team !== undefined ? appContext.team.displayName : undefined,\r\n teamType: appContext.team !== undefined ? appContext.team.type : undefined,\r\n groupId: appContext.team !== undefined ? appContext.team.groupId : undefined,\r\n teamTemplateId: appContext.team !== undefined ? appContext.team.templateId : undefined,\r\n isTeamArchived: appContext.team !== undefined ? appContext.team.isArchived : undefined,\r\n userTeamRole: appContext.team !== undefined ? appContext.team.userRole : undefined,\r\n\r\n // sharepointSite\r\n teamSiteUrl: appContext.sharePointSite !== undefined ? appContext.sharePointSite.teamSiteUrl : undefined,\r\n teamSiteDomain: appContext.sharePointSite !== undefined ? appContext.sharePointSite.teamSiteDomain : undefined,\r\n teamSitePath: appContext.sharePointSite !== undefined ? appContext.sharePointSite.teamSitePath : undefined,\r\n teamSiteId: appContext.sharePointSite !== undefined ? appContext.sharePointSite.teamSiteId : undefined,\r\n mySitePath: appContext.sharePointSite !== undefined ? appContext.sharePointSite.mySitePath : undefined,\r\n mySiteDomain: appContext.sharePointSite !== undefined ? appContext.sharePointSite.mySiteDomain : undefined,\r\n };\r\n\r\n return context;\r\n}\r\n","import { ensureInitialized } from '../internal/internalAPIs';\r\nimport { getGenericOnCompleteHandler } from '../internal/utils';\r\nimport { FrameContexts } from './constants';\r\nimport { TabInstance } from './interfaces';\r\nimport { pages } from './pages';\r\n/**\r\n * Navigation specific part of the SDK.\r\n */\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.returnFocus pages.returnFocus(navigateForward?: boolean): void} instead.\r\n *\r\n * Return focus to the main Teams app. Will focus search bar if navigating foward and app bar if navigating back.\r\n *\r\n * @param navigateForward - Determines the direction to focus in teams app.\r\n */\r\nexport function returnFocus(navigateForward?: boolean): void {\r\n pages.returnFocus(navigateForward);\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.tabs.navigateToTab pages.tabs.navigateToTab(tabInstance: TabInstance): Promise\\<void\\>} instead.\r\n *\r\n * Navigates the Microsoft Teams app to the specified tab instance.\r\n *\r\n * @param tabInstance - The tab instance to navigate to.\r\n * @param onComplete - The callback to invoke when the action is complete.\r\n */\r\nexport function navigateToTab(tabInstance: TabInstance, onComplete?: (status: boolean, reason?: string) => void): void {\r\n ensureInitialized();\r\n onComplete = onComplete ? onComplete : getGenericOnCompleteHandler();\r\n pages.tabs\r\n .navigateToTab(tabInstance)\r\n .then(() => {\r\n onComplete(true);\r\n })\r\n .catch((error: Error) => {\r\n onComplete(false, error.message);\r\n });\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.navigateCrossDomain pages.navigateCrossDomain(url: string): Promise\\<void\\>} instead.\r\n *\r\n * Navigates the frame to a new cross-domain URL. The domain of this URL must match at least one of the\r\n * valid domains specified in the validDomains block of the manifest; otherwise, an exception will be\r\n * thrown. This function needs to be used only when navigating the frame to a URL in a different domain\r\n * than the current one in a way that keeps the app informed of the change and allows the SDK to\r\n * continue working.\r\n *\r\n * @param url - The URL to navigate the frame to.\r\n * @param onComplete - The callback to invoke when the action is complete.\r\n */\r\nexport function navigateCrossDomain(url: string, onComplete?: (status: boolean, reason?: string) => void): void {\r\n ensureInitialized(\r\n FrameContexts.content,\r\n FrameContexts.sidePanel,\r\n FrameContexts.settings,\r\n FrameContexts.remove,\r\n FrameContexts.task,\r\n FrameContexts.stage,\r\n FrameContexts.meetingStage,\r\n );\r\n onComplete = onComplete ? onComplete : getGenericOnCompleteHandler();\r\n pages\r\n .navigateCrossDomain(url)\r\n .then(() => {\r\n onComplete(true);\r\n })\r\n .catch((error: Error) => {\r\n onComplete(false, error.message);\r\n });\r\n}\r\n\r\n/**\r\n * @deprecated\r\n * As of 2.0.0-beta.1, please use {@link pages.backStack.navigateBack pages.backStack.navigateBack(): Promise\\<void\\>} instead.\r\n *\r\n * Navigates back in the Teams client.\r\n * See registerBackButtonHandler for more information on when it's appropriate to use this method.\r\n *\r\n * @param onComplete - The callback to invoke when the action is complete.\r\n */\r\nexport function navigateBack(onComplete?: (status: boolean, reason?: string) => void): void {\r\n ensureInitialized();\r\n onComplete = onComplete ? onComplete : getGenericOnCompleteHandler();\r\n pages.backStack\r\n .navigateBack()\r\n .then(() => {\r\n onComplete(true);\r\n })\r\n .catch((error: Error) => {\r\n onComplete(false, error.message);\r\n });\r\n}\r\n"],"names":["root","factory","exports","module","define","amd","self","v1","v4","uuid","byteToHex","i","toString","substr","buf","offset","bth","join","getRandomValues","crypto","bind","window","msCrypto","rnds8","Uint8Array","rnds","Array","r","Math","random","_nodeId","_clockseq","rng","bytesToUuid","_lastMSecs","_lastNSecs","options","b","node","clockseq","undefined","seedBytes","msecs","Date","getTime","nsecs","dt","Error","tl","tmh","n","ii","formatArgs","args","this","useColors","namespace","humanize","diff","c","color","splice","index","lastC","replace","match","save","namespaces","storage","setItem","removeItem","error","load","getItem","process","env","DEBUG","type","__nwjs","navigator","userAgent","toLowerCase","document","documentElement","style","WebkitAppearance","console","firebug","exception","table","parseInt","RegExp","$1","localStorage","localstorage","destroy","warned","warn","colors","log","debug","formatters","j","v","JSON","stringify","message","createDebug","prevTime","namespacesCache","enabledCache","enableOverride","enabled","curr","Number","ms","prev","coerce","unshift","format","formatter","val","call","apply","selectColor","extend","Object","defineProperty","enumerable","configurable","get","set","init","delimiter","newDebug","toNamespace","regexp","substring","length","default","stack","disable","names","map","skips","enable","split","len","push","name","test","keys","forEach","key","hash","charCodeAt","abs","s","m","h","d","parse","str","String","exec","parseFloat","fmtShort","msAbs","round","fmtLong","plural","isPlural","isFinite","long","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","definition","o","obj","prop","prototype","hasOwnProperty","Symbol","toStringTag","value","HostClientType","HostName","FrameContexts","TeamType","UserTeamRole","DialogDimension","version","defaultSDKVersionForCompatCheck","nonFullScreenVideoModeAPISupportVersion","locationAPIsRequiredVersion","mediaAPISupportVersion","validOrigins","userOriginUrlValidationRegExp","initializeCalled","initializeCompleted","additionalValidOrigins","isFramelessWindow","printCapabilityEnabled","ChannelType","FileOpenPreference","ErrorCode","TaskModuleDimension","validateHostAgainstPattern","pattern","host","suffix","validateOrigin","messageOrigin","protocol","messageOriginHost","some","GlobalVars","domainOrPattern","getGenericOnCompleteHandler","errorMessage","success","reason","compareSDKVersions","v2","NaN","v1parts","v2parts","isValidPart","x","every","generateGUID","deepFreeze","freeze","callCallbackWithErrorOrResultFromPromiseAndReturnPromise","funcHelper","callback","p","then","result","catch","e","callCallbackWithErrorOrBooleanFromPromiseAndReturnPromise","callCallbackWithSdkErrorFromPromiseAndReturnPromise","callCallbackWithErrorOrResultOrNullFromPromiseAndReturnPromise","runWithTimeout","action","timeoutInMs","timeoutError","Promise","resolve","reject","timeoutHandle","setTimeout","clearTimeout","createTeamsAppLink","params","url","URL","encodeURIComponent","appId","pageId","webUrl","searchParams","append","channelId","subPageId","subEntityId","ensureInitialized","frameContext","expectedFrameContexts","found","isCurrentSDKVersionAtLeast","requiredVersion","clientSupportedSDKVersion","isNaN","isHostClientMobile","hostClientType","android","ios","throwExceptionIfMobileApiIsNotSupported","errorCode","NOT_SUPPORTED_ON_PLATFORM","OLD_PLATFORM","processAdditionalValidOrigins","validMessageOrigins","combinedOriginUrls","concat","filter","_origin","dedupUrls","_originUrl","logs","authentication","menus","teamsCore","pages","runtime","apiVersion","supports","appInstallDialog","bot","calendar","chat","dialog","location","mail","media","meeting","meetingRoom","monetization","notifications","appButton","tabs","config","backStack","fullTrust","people","remoteCamera","sharing","teams","video","teamsRuntimeConfig","isLegacyTeams","appEntity","files","applyRuntimeConfig","runtimeConfig","uploadCustomApp","manifestBlob","onComplete","sendMessageToParent","sendCustomMessage","actionName","sendCustomEvent","Communication","childWindow","sendMessageEventToChild","registerCustomHandler","customHandler","registerHandler","registerUserSettingsChangeHandler","settingTypes","handler","transformLegacyContextToAppContext","legacyContext","app","locale","sessionId","appSessionId","theme","iconPositionVertical","appIconPosition","osLocaleInfo","parentMessageId","userClickTime","userFileOpenPreference","hostName","clientType","web","ringId","appLaunchId","page","id","entityId","isFullScreen","isMultiWindow","sourceOrigin","user","userObjectId","displayName","userDisplayName","isCallingAllowed","isPSTNCallingAllowed","licenseType","userLicenseType","loginHint","userPrincipalName","tenant","tid","teamsSku","tenantSKU","channel","channelName","relativeUrl","channelRelativeUrl","membershipType","channelType","defaultOneNoteSectionId","ownerGroupId","hostTeamGroupId","ownerTenantId","hostTeamTenantId","chatId","meetingId","sharepoint","team","teamId","internalId","teamName","teamType","groupId","templateId","teamTemplateId","isArchived","isTeamArchived","userRole","userTeamRole","sharePointSite","teamSiteUrl","teamSiteDomain","teamSitePath","mySitePath","mySiteDomain","teamSiteId","registerGetLogHandler","removeHandler","isSupported","authHandlers","authWindowMonitor","authParams","authenticateHelper","authenticateParameters","desktop","rigel","teamsRoomsWindows","teamsRoomsAndroid","teamsPhones","teamsDisplays","link","createElement","href","sendMessageToParentAsync","width","height","isExternal","response","fail","openAuthenticationWindow","getAuthTokenHelper","authTokenRequest","resources","claims","silent","getUserHelper","closeAuthenticationWindow","stopAuthenticationWindowMonitor","close","childOrigin","min","currentWindow","outerWidth","outerHeight","left","screenLeft","screenX","top","screenTop","screenY","open","startAuthenticationWindowMonitor","handleFailure","clearInterval","setInterval","closed","savedChildOrigin","handleSuccess","redirectIfWin32Outlook","callbackUrl","decodeURIComponent","search","indexOf","updateUrlParameter","assign","uri","initialize","registerAuthenticationHandlers","authenticate","isDifferentParamsInCall","authenticateParams","content","sidePanel","settings","remove","task","stage","meetingStage","successCallback","err","failureCallback","getAuthToken","getUser","userRequest","notifySuccess","waitForMessageQueue","parentWindow","notifyFailure","DisplayMode","navBarMenuItemPressHandler","actionMenuItemPressHandler","viewConfigItemPressHandler","selected","handleViewConfigItemPress","handleNavBarMenuItemPress","handleActionMenuItemPress","MenuItem","MenuListType","setUpViews","viewConfig","setNavBarMenu","items","showActionMenu","print","enablePrintCapability","addEventListener","event","ctrlKey","metaKey","keyCode","cancelBubble","preventDefault","stopImmediatePropagation","registerOnLoadHandler","registerBeforeUnloadHandler","Messages","AppLoaded","Success","Failure","ExpectedFailure","FailedReason","ExpectedFailureReason","isInitialized","getFrameContext","initializeHelper","initializePromise","initializeCommunication","context","givenRuntimeConfig","SyntaxError","isArray","registerOnThemeChangeHandler","_initialize","hostWindow","_uninitialize","registerBackButtonHandler","registerFullScreenHandler","registerOnSaveHandler","registerOnRemoveHandler","uninitializeCommunication","getContext","sendAndUnwrap","notifyAppLoaded","appInitializationFailedRequest","notifyExpectedFailure","expectedFailureRequest","openLink","deepLink","setCurrentFrame","frameInfo","returnFocus","navigateForward","registerFocusEnterHandler","initializeWithFrameContext","getConfig","navigateCrossDomain","navigateToApp","shareDeepLink","deepLinkParameters","subEntityLabel","subEntityWebUrl","navigateToTab","tabInstance","getTabInstances","tabInstanceParameters","getMruTabInstances","saveHandler","handleSave","saveEvent","SaveEventImpl","handleRemove","setValidityState","validityState","setConfig","instanceConfig","registerChangeConfigHandler","notified","ensureNotNotified","removeEvent","RemoveEventImpl","backButtonPressHandler","navigateBack","handleBackButtonPress","enterFullscreen","exitFullscreen","onClick","onHoverEnter","onHoverLeave","topLevelLogger","getLogger","handlersLogger","handlers","initializeHandlers","HandlersPrivate","handleThemeChange","handleLoad","handleBeforeUnload","callHandlerLogger","callHandler","sendMessage","themeChangeHandler","loadHandler","beforeUnloadHandler","readyToUnload","communicationLogger","parentMessageQueue","childMessageQueue","nextMessageId","callbacks","promiseCallbacks","CommunicationPrivate","messageListener","evt","processMessage","parent","opener","extendedWindow","nativeInterface","onNativeMessage","handleParentMessage","parentOrigin","removeEventListener","sendAndHandleStatusAndReason","status","sendAndHandleStatusAndReasonWithDefaultError","defaultError","sendAndHandleSdkError","waitForResponse","sendMessageToParentHelper","requestId","argsOrCallback","Function","request","sendMessageToParentHelperLogger","logger","targetWindow","createMessageRequest","framelessPostMessage","targetOrigin","getTargetOrigin","postMessage","getTargetMessageQueue","data","messageSource","source","originalEvent","origin","shouldProcessMessage","updateRelationships","handleChildMessage","flushMessageQueue","handleParentMessageLogger","isPartialResponse","promiseCallback","func","called","sendMessageResponseToChild","pop","NotificationTypes","ViewerActionTypes","UserSettingTypes","flushMessageQueueLogger","targetMessageQueue","target","shift","messageQueueMonitor","createMessageResponse","customEvent","createMessageEvent","timestamp","now","sendQuery","botRequest","onSuccess","onError","getSupportedCommands","authRequest","openConversation","openConversationRequest","sendPromise","title","conversationId","onStartConversation","onCloseConversation","closeConversation","getChatMembers","openAppInstallDialog","openAPPInstallDialogParams","listener","_instance","createFile","assembleAttachment","mimeType","file","sequence","sort","a","item","Blob","decodeAttachment","attachment","decoded","atob","chunk","byteNumbers","byteArray","blob","chunkSequence","throwExceptionIfMediaCallIsNotSupportedOnMobile","mediaInputs","isMediaCallForVideoAndImageInputs","isMediaCallForNonFullScreenVideoMode","isMediaCallForImageOutputFormats","isVideoControllerRegistered","mediaType","MediaType","Video","videoProps","videoController","validateSelectMediaInputs","maxMediaCount","Image","imageProps","imageOutputFormats","VideoAndImage","videoAndImageProps","isFullScreenMode","validateGetMediaInputs","FileFormat","ID","validateViewImagesInput","uriList","validateScanBarCodeInput","barCodeConfig","timeOutIntervalInSec","validatePeoplePickerInput","peoplePickerInputs","setSelected","openOrgWideSearchInChatOrChannel","singleSelect","dialogInfo","submitHandler","ChildAppWindow","resize","extra","submit","appIds","sendMessageToParentFromDialog","registerOnMessageFromParent","stageView","appInitialization","tasks","legacy","transformAppContextToLegacyContext","registerAppButtonClickHandler","registerAppButtonHoverEnterHandler","registerAppButtonHoverLeaveHandler","registerEnterSettingsHandler","tabInfo","executeDeepLink","setFrameContext","appContext","File","captureImage","that","preview","size","getMedia","INVALID_ARGUMENTS","getMediaViaCallback","getMediaViaHandler","helper","mediaMimeType","mediaResult","mediaChunk","assemble","INTERNAL_ERROR","Media","MediaControllerEvent","getMediaType","notifyEventToApp","mediaEvent","StartRecording","controllerCallback","onRecordingStarted","StopRecording","onRecordingStopped","notifyEventToHost","mediaControllerEvent","stop","VideoController","CameraStartMode","Source","ImageUriType","ImageOutputFormats","selectMedia","localAttachments","mediaArray","viewImages","scanBarCode","callbackOrConfig","configMaybe","getLocationHelper","props","showLocationHelper","getLocation","showLocation","getIncomingClientAudioStateHelper","toggleIncomingClientAudioHelper","getMeetingDetailsHelper","getAuthenticationTokenForAnonymousUserHelper","getLiveStreamStateHelper","requestStartLiveStreamingHelper","streamUrl","streamKey","requestStopLiveStreamingHelper","shareAppContentToStageHelper","appContentUrl","getAppContentStageSharingCapabilitiesHelper","stopSharingAppContentToStageHelper","getAppContentStageSharingStateHelper","MeetingType","getIncomingClientAudioState","toggleIncomingClientAudio","getMeetingDetails","getAuthenticationTokenForAnonymousUser","getLiveStreamState","requestStartLiveStreaming","param1","param2","param3","requestStopLiveStreaming","registerLiveStreamChangedHandler","shareAppContentToStage","getAppContentStageSharingCapabilities","stopSharingAppContentToStage","getAppContentStageSharingState","openPurchaseExperience","planInfo","openCalendarItem","openCalendarItemParams","itemId","trim","composeMeeting","composeMeetingParams","openMailItem","openMailItemParams","composeMail","composeMailParams","ComposeMailType","selectPeopleHelper","selectPeople","notifyVideoFrameProcessed","notifyError","VideoFrameFormat","EffectChangeType","registerForVideoFrame","frameCallback","videoFrame","notifySelectedVideoEffectChanged","effectChangeType","effectId","registerForVideoEffect","shareWebContentHelper","shareWebContentRequest","SharingAPIMessages","shareWebContent","validateNonEmptyContent","shareRequest","validateTypeConsistency","validateContentForSupportedTypes","stageViewParams","CallModalities","startCall","startCallParams","getSettings","setSettings","instanceSettings","getDialogInfoFromTaskInfo","taskInfo","dialogHeight","getDialogDimensionFromTaskModuleDimension","dialogWidth","card","fallbackUrl","completionBotId","taskModuleDimension","Large","Medium","Small","startTask","updateTask","submitTask","CloudStorageProvider","CloudStorageProviderType","SpecialDocumentLibraryType","DocumentLibraryAccessType","FileDownloadStatus","getCloudStorageFolders","addCloudStorageFolder","isFolderAdded","folders","deleteCloudStorageFolder","folderToDelete","getCloudStorageFolderContents","folder","providerCode","isSubdirectory","openCloudStorageFile","fileOpenPreference","openFilePreview","filePreviewParameters","description","objectUrl","downloadUrl","webPreviewUrl","webEditUrl","baseUrl","editFile","viewerAction","getExternalProviders","excludeAddedProviders","copyMoveFiles","selectedFiles","destinationFolder","destinationProviderCode","isMove","getFileDownloads","openDownloadFolder","getUserJoinedTeams","teamInstanceParameters","oldPlatformError","getConfigSetting","getPairedMeetingRoomInfo","sendCommandToPairedMeetingRoom","commandName","registerMeetingRoomCapabilitiesUpdateHandler","capabilities","registerMeetingRoomStatesUpdateHandler","states","showNotification","showNotificationParameters","ControlCommand","ErrorReason","SessionTerminatedReason","getCapableParticipants","requestControl","participant","sendControlCommand","terminateSession","registerOnCapableParticipantsChangeHandler","registerOnErrorHandler","registerOnDeviceStateChangeHandler","registerOnSessionStatusChangeHandler","selectAppEntity","threadId","categories","getTeamChannels","refreshSiteUrl"],"sourceRoot":""}