2020-05-22 06:36:24 +00:00
|
|
|
// @flow
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Extracts the fqn part from a path, where fqn represents
|
|
|
|
* tenant/roomName.
|
|
|
|
*
|
|
|
|
* @param {string} path - The URL path.
|
|
|
|
* @returns {string}
|
|
|
|
*/
|
|
|
|
export function extractFqnFromPath(path: string) {
|
|
|
|
const parts = path.split('/');
|
|
|
|
const len = parts.length;
|
|
|
|
|
|
|
|
return parts.length > 2 ? `${parts[len - 2]}/${parts[len - 1]}` : '';
|
|
|
|
}
|
2020-12-11 10:16:58 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the url used for fetching dynamic branding.
|
|
|
|
*
|
|
|
|
* @param {Object} state - The state of the app.
|
|
|
|
* @returns {string}
|
|
|
|
*/
|
|
|
|
export function getDynamicBrandingUrl(state: Object) {
|
|
|
|
const { dynamicBrandingUrl } = state['features/base/config'];
|
|
|
|
|
|
|
|
if (dynamicBrandingUrl) {
|
|
|
|
return dynamicBrandingUrl;
|
|
|
|
}
|
|
|
|
|
|
|
|
const baseUrl = state['features/base/config'].brandingDataUrl;
|
|
|
|
const fqn = extractFqnFromPath(state['features/base/connection'].locationURL.pathname);
|
|
|
|
|
|
|
|
if (baseUrl && fqn) {
|
|
|
|
return `${baseUrl}?conferenceFqn=${encodeURIComponent(fqn)}`;
|
|
|
|
}
|
|
|
|
}
|
2021-05-24 07:17:40 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Selector used for getting the load state of the dynamic branding data.
|
|
|
|
*
|
|
|
|
* @param {Object} state - Global state of the app.
|
|
|
|
* @returns {boolean}
|
|
|
|
*/
|
|
|
|
export function isDynamicBrandingDataLoaded(state: Object) {
|
|
|
|
return state['features/dynamic-branding'].customizationReady;
|
|
|
|
}
|