You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
238 lines
16 KiB
238 lines
16 KiB
/******/ (() => { // webpackBootstrap
|
|
/******/ var __webpack_modules__ = ({
|
|
|
|
/***/ "./src/main/omutils.js":
|
|
/*!*****************************!*\
|
|
!*** ./src/main/omutils.js ***!
|
|
\*****************************/
|
|
/***/ ((module) => {
|
|
|
|
/* Licensed under the Apache License, Version 2.0 (the "License") http://www.apache.org/licenses/LICENSE-2.0 */
|
|
|
|
let options, alertId = 0;
|
|
|
|
function _init(_options) {
|
|
options = _options;
|
|
}
|
|
function _tmpl(tmplId, newId) {
|
|
return $(tmplId).clone().attr('id', newId || '');
|
|
}
|
|
function __alert(level, msg, autohideAfter) {
|
|
const holder = document.getElementById('alert-holder');
|
|
const curId = 'om-alert' + alertId++;
|
|
holder.insertAdjacentHTML('beforeend',
|
|
`<div id="${curId}" class="alert alert-${level} alert-dismissible fade show m-0" role="alert">${msg}
|
|
<button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="${holder.getAttribute('data-lbl-close')}"></button>
|
|
</div>`);
|
|
if (autohideAfter > 0) {
|
|
setTimeout(() => { bootstrap.Alert.getOrCreateInstance(`#${curId}`).close();}, autohideAfter);
|
|
}
|
|
}
|
|
function _error(msg, noAlert) {
|
|
if (typeof(msg) === 'object') {
|
|
msg = msg.name + ': ' + msg.message;
|
|
}
|
|
if (noAlert !== true) {
|
|
__alert('danger', msg, 20000);
|
|
}
|
|
return console.error(msg);
|
|
}
|
|
function _debugEnabled() {
|
|
return !!options && !!options.debug;
|
|
}
|
|
function _info() {
|
|
if (_debugEnabled()) {
|
|
console.info.apply(this, arguments);
|
|
}
|
|
}
|
|
function _log() {
|
|
if (_debugEnabled()) {
|
|
console.log.apply(this, arguments);
|
|
}
|
|
}
|
|
function _sendMessage(_m, _base) {
|
|
const base = _base || {}
|
|
, m = _m || {}
|
|
, msg = JSON.stringify(Object.assign({}, base, m));
|
|
Wicket.WebSocket.send(msg);
|
|
}
|
|
function _requestNotifyPermission(callback, elseCallback) {
|
|
if (typeof(Notification) !== 'undefined'
|
|
&& Notification.permission !== 'granted'
|
|
&& Notification.permission !== 'denied') {
|
|
function onRequest(permission) {
|
|
if (permission === 'granted') {
|
|
callback();
|
|
}
|
|
}
|
|
Promise.resolve(Notification.requestPermission()).then(onRequest);
|
|
} else {
|
|
_info('No notification API for this browser');
|
|
if (typeof(elseCallback) === 'function') {
|
|
elseCallback();
|
|
}
|
|
}
|
|
}
|
|
function _notify(msg, tag, elseCallback) {
|
|
if (typeof(Notification) !== 'undefined'
|
|
&& window === window.parent) {
|
|
function _newMessage() {
|
|
const opts = {
|
|
tag: tag
|
|
};
|
|
try {
|
|
new Notification(msg, opts);
|
|
} catch (e) {
|
|
console.error("Failed to create Notification" + e)
|
|
}
|
|
}
|
|
if (Notification.permission === 'granted') {
|
|
_newMessage();
|
|
} else {
|
|
_requestNotifyPermission(() => _newMessage());
|
|
}
|
|
} else {
|
|
_info('No notification API for this browser');
|
|
if (typeof(elseCallback) === 'function') {
|
|
elseCallback();
|
|
}
|
|
}
|
|
}
|
|
|
|
module.exports = {
|
|
init: _init
|
|
, tmpl: _tmpl
|
|
, debugEnabled: _debugEnabled
|
|
, enableDebug: function() {
|
|
if (!!options) {
|
|
options.debug = true;
|
|
}
|
|
}
|
|
, sendMessage: _sendMessage
|
|
, alert: __alert
|
|
, error: _error
|
|
, info: _info
|
|
, log: _log
|
|
, wbAction: function(_m) {
|
|
_sendMessage(_m, {area: 'room', type: 'wb'});
|
|
}
|
|
, roomAction: function(_m) {
|
|
_sendMessage(_m, {area: 'room', type: 'room'});
|
|
}
|
|
, setCssVar: function(key, val) {
|
|
document.querySelector('body').style.setProperty(key, val);
|
|
}
|
|
, ping: function() {
|
|
setTimeout(() => {
|
|
_sendMessage({type: 'ping'});
|
|
fetch('./ping', {cache: "no-store"});
|
|
}, 30000);
|
|
}
|
|
, notify: _notify
|
|
, requestNotifyPermission: _requestNotifyPermission
|
|
};
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./src/main/settings.js":
|
|
/*!******************************!*\
|
|
!*** ./src/main/settings.js ***!
|
|
\******************************/
|
|
/***/ ((module) => {
|
|
|
|
/* Licensed under the Apache License, Version 2.0 (the "License") http://www.apache.org/licenses/LICENSE-2.0 */
|
|
const key = 'openmeetings';
|
|
function _load() {
|
|
let s = {};
|
|
try {
|
|
s = JSON.parse(localStorage.getItem(key)) || s;
|
|
} catch (e) {
|
|
// no-op
|
|
}
|
|
return s;
|
|
}
|
|
function _save(s) {
|
|
const _s = JSON.stringify(s);
|
|
localStorage.setItem(key, _s);
|
|
return _s;
|
|
}
|
|
|
|
module.exports = {
|
|
isRtl: 'rtl' === document.querySelector('html').getAttribute('dir')
|
|
, load: _load
|
|
, save: _save
|
|
};
|
|
|
|
|
|
/***/ })
|
|
|
|
/******/ });
|
|
/************************************************************************/
|
|
/******/ // The module cache
|
|
/******/ var __webpack_module_cache__ = {};
|
|
/******/
|
|
/******/ // The require function
|
|
/******/ function __webpack_require__(moduleId) {
|
|
/******/ // Check if module is in cache
|
|
/******/ var cachedModule = __webpack_module_cache__[moduleId];
|
|
/******/ if (cachedModule !== undefined) {
|
|
/******/ return cachedModule.exports;
|
|
/******/ }
|
|
/******/ // Create a new module (and put it into the cache)
|
|
/******/ var module = __webpack_module_cache__[moduleId] = {
|
|
/******/ // no module.id needed
|
|
/******/ // no module.loaded needed
|
|
/******/ exports: {}
|
|
/******/ };
|
|
/******/
|
|
/******/ // Execute the module function
|
|
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
|
|
/******/
|
|
/******/ // Return the exports of the module
|
|
/******/ return module.exports;
|
|
/******/ }
|
|
/******/
|
|
/************************************************************************/
|
|
var __webpack_exports__ = {};
|
|
// This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.
|
|
(() => {
|
|
/*!***************************!*\
|
|
!*** ./src/main/index.js ***!
|
|
\***************************/
|
|
/* Licensed under the Apache License, Version 2.0 (the "License") http://www.apache.org/licenses/LICENSE-2.0 */
|
|
Wicket.BrowserInfo.collectExtraInfo = function(info) {
|
|
const l = window.location;
|
|
info.codebase = l.origin + l.pathname;
|
|
info.settings = Settings.load();
|
|
};
|
|
|
|
function _updateResize() {
|
|
const doc = document.documentElement;
|
|
doc.style.setProperty('--app-height', `${window.innerHeight}px`)
|
|
}
|
|
$(window).on('resize', _updateResize);
|
|
//initial resize
|
|
_updateResize();
|
|
|
|
Object.assign(window, {
|
|
Settings: __webpack_require__(/*! ./settings */ "./src/main/settings.js")
|
|
, OmUtil: __webpack_require__(/*! ./omutils */ "./src/main/omutils.js")
|
|
//Fix to move the close icon on top of the .ui-dialog-titlebar cause otherwise
|
|
// touch-events are broken and you won't be able to close the dialog
|
|
, fixJQueryUIDialogTouch: function(dialog) {
|
|
dialog.parent().find('.ui-dialog-titlebar-close').appendTo(dialog.parent());
|
|
}
|
|
, showBusyIndicator: function() {
|
|
$('#busy-indicator').show();
|
|
}
|
|
, hideBusyIndicator: function() {
|
|
$('#busy-indicator').hide();
|
|
}
|
|
});
|
|
|
|
})();
|
|
|
|
/******/ })()
|
|
;
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"main.js","mappings":";;;;;;;;;AAAA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc,MAAM,uBAAuB,OAAO,gDAAgD;AAClG,iFAAiF,sCAAsC;AACvH;AACA;AACA,qBAAqB,wCAAwC,MAAM,YAAY;AAC/E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,yBAAyB;AAC7C;AACA;AACA,oBAAoB,2BAA2B;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,aAAa;AAC9B,oBAAoB,kBAAkB;AACtC,GAAG;AACH;AACA;AACA;AACA;;;;;;;;;;;AC3HA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;;;;;;UCrBA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;;;;;ACtBA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,0CAA0C,mBAAmB;AAC7D;AACA;AACA;AACA;;AAEA;AACA,WAAW,mBAAO,CAAC,0CAAY;AAC/B,WAAW,mBAAO,CAAC,wCAAW;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC","sources":["webpack://om-frontend/./src/main/omutils.js","webpack://om-frontend/./src/main/settings.js","webpack://om-frontend/webpack/bootstrap","webpack://om-frontend/./src/main/index.js"],"sourcesContent":["/* Licensed under the Apache License, Version 2.0 (the \"License\") http://www.apache.org/licenses/LICENSE-2.0 */\n\nlet options, alertId = 0;\n\nfunction _init(_options) {\n\toptions = _options;\n}\nfunction _tmpl(tmplId, newId) {\n\treturn $(tmplId).clone().attr('id', newId || '');\n}\nfunction __alert(level, msg, autohideAfter) {\n\tconst holder = document.getElementById('alert-holder');\n\tconst curId = 'om-alert' + alertId++;\n\tholder.insertAdjacentHTML('beforeend',\n\t\t`<div id=\"${curId}\" class=\"alert alert-${level} alert-dismissible fade show m-0\" role=\"alert\">${msg}\n\t\t\t<button type=\"button\" class=\"btn-close\" data-bs-dismiss=\"alert\" aria-label=\"${holder.getAttribute('data-lbl-close')}\"></button>\n\t\t</div>`);\n\tif (autohideAfter > 0) {\n\t\tsetTimeout(() => { bootstrap.Alert.getOrCreateInstance(`#${curId}`).close();}, autohideAfter);\n\t}\n}\nfunction _error(msg, noAlert) {\n\tif (typeof(msg) === 'object') {\n\t\tmsg = msg.name + ': ' + msg.message;\n\t}\n\tif (noAlert !== true) {\n\t\t__alert('danger', msg, 20000);\n\t}\n\treturn console.error(msg);\n}\nfunction _debugEnabled() {\n\treturn !!options && !!options.debug;\n}\nfunction _info() {\n\tif (_debugEnabled()) {\n\t\tconsole.info.apply(this, arguments);\n\t}\n}\nfunction _log() {\n\tif (_debugEnabled()) {\n\t\tconsole.log.apply(this, arguments);\n\t}\n}\nfunction _sendMessage(_m, _base) {\n\tconst base = _base || {}\n\t\t, m = _m || {}\n\t\t, msg = JSON.stringify(Object.assign({}, base, m));\n\tWicket.WebSocket.send(msg);\n}\nfunction _requestNotifyPermission(callback, elseCallback) {\n\tif (typeof(Notification) !== 'undefined'\n\t\t&& Notification.permission !== 'granted'\n\t\t&& Notification.permission !== 'denied') {\n\t\tfunction onRequest(permission) {\n\t\t\tif (permission === 'granted') {\n\t\t\t\tcallback();\n\t\t\t}\n\t\t}\n\t\tPromise.resolve(Notification.requestPermission()).then(onRequest);\n\t} else {\n\t\t_info('No notification API for this browser');\n\t\tif (typeof(elseCallback) === 'function') {\n\t\t\telseCallback();\n\t\t}\n\t}\n}\nfunction _notify(msg, tag, elseCallback) {\n\tif (typeof(Notification) !== 'undefined'\n\t\t&& window === window.parent) {\n\t\tfunction _newMessage() {\n\t\t\tconst opts = {\n\t\t\t\t\ttag: tag\n\t\t\t\t};\n\t\t\ttry {\n\t\t\t\tnew Notification(msg, opts);\n\t\t\t} catch (e) {\n\t\t\t\tconsole.error(\"Failed to create Notification\" + e)\n\t\t\t}\n\t\t}\n\t\tif (Notification.permission === 'granted') {\n\t\t\t_newMessage();\n\t\t} else {\n\t\t\t_requestNotifyPermission(() => _newMessage());\n\t\t}\n\t} else {\n\t\t_info('No notification API for this browser');\n\t\tif (typeof(elseCallback) === 'function') {\n\t\t\telseCallback();\n\t\t}\n\t}\n}\n\nmodule.exports = {\n\tinit: _init\n\t, tmpl: _tmpl\n\t, debugEnabled: _debugEnabled\n\t, enableDebug: function() {\n\t\tif (!!options) {\n\t\t\toptions.debug = true;\n\t\t}\n\t}\n\t, sendMessage: _sendMessage\n\t, alert: __alert\n\t, error: _error\n\t, info: _info\n\t, log: _log\n\t, wbAction: function(_m) {\n\t\t_sendMessage(_m, {area: 'room', type: 'wb'});\n\t}\n\t, roomAction: function(_m) {\n\t\t_sendMessage(_m, {area: 'room', type: 'room'});\n\t}\n\t, setCssVar: function(key, val) {\n\t\tdocument.querySelector('body').style.setProperty(key, val);\n\t}\n\t, ping: function() {\n\t\tsetTimeout(() => {\n\t\t\t_sendMessage({type: 'ping'});\n\t\t\tfetch('./ping', {cache: \"no-store\"});\n\t\t}, 30000);\n\t}\n\t, notify: _notify\n\t, requestNotifyPermission: _requestNotifyPermission\n};\n","/* Licensed under the Apache License, Version 2.0 (the \"License\") http://www.apache.org/licenses/LICENSE-2.0 */\nconst key = 'openmeetings';\nfunction _load() {\n\tlet s = {};\n\ttry {\n\t\ts = JSON.parse(localStorage.getItem(key)) || s;\n\t} catch (e) {\n\t\t// no-op\n\t}\n\treturn s;\n}\nfunction _save(s) {\n\tconst _s = JSON.stringify(s);\n\tlocalStorage.setItem(key, _s);\n\treturn _s;\n}\n\nmodule.exports = {\n\tisRtl: 'rtl' === document.querySelector('html').getAttribute('dir')\n\t, load: _load\n\t, save: _save\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","/* Licensed under the Apache License, Version 2.0 (the \"License\") http://www.apache.org/licenses/LICENSE-2.0 */\nWicket.BrowserInfo.collectExtraInfo = function(info) {\n\tconst l = window.location;\n\tinfo.codebase = l.origin + l.pathname;\n\tinfo.settings = Settings.load();\n};\n\nfunction _updateResize() {\n\tconst doc = document.documentElement;\n\tdoc.style.setProperty('--app-height', `${window.innerHeight}px`)\n}\n$(window).on('resize', _updateResize);\n//initial resize\n_updateResize();\n\nObject.assign(window, {\n\tSettings: require('./settings')\n\t, OmUtil: require('./omutils')\n\t//Fix to move the close icon on top of the .ui-dialog-titlebar cause otherwise\n\t// touch-events are broken and you won't be able to close the dialog\n\t, fixJQueryUIDialogTouch: function(dialog) {\n\t\tdialog.parent().find('.ui-dialog-titlebar-close').appendTo(dialog.parent());\n\t}\n\t, showBusyIndicator: function() {\n\t\t$('#busy-indicator').show();\n\t}\n\t, hideBusyIndicator: function() {\n\t\t$('#busy-indicator').hide();\n\t}\n});\n"],"names":[],"sourceRoot":""}
|