{"version":3,"sources":["webpack/bootstrap","./src/Common/content-loader/common-content-loader.ts","./src/Common/logger/logger-log-level.enum.ts","./src/Common/logger/logger.ts","./src/Common/utilities/performance-check-utils/set-sources-downloaded-timing.ts","./src/InitialData/index.ts","./src/Common/utilities/performance-check-utils/performance-check-utils.ts"],"names":["installedModules","__webpack_require__","moduleId","exports","module","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","COMMON_CONTENT_LOADER_CLASSES","window","params","isPositionAbsolute","isOpaque","label","this","parentElement","container","document","body","createElement","labelText","className","enable","isEnabled","appendChild","containerClasses","push","join","getTemplate","CommonContentLoader","classList","add","setTimeout","disable","remove","textContent","parentNode","removeChild","setLabel","labelElement","innerHTML","error","content","fragment","createDocumentFragment","text","errorElement","description","errorDescriptionElement","timer","errorTimerElement","hasChildNodes","wrapperElement","progressElement","indeterminateElement","COMMON_LOGGER_LOG_LEVEL","initDate","Date","hashchange","previousErrors","Map","addEventListener","e","logErrorEvent","oldURL","newURL","timeStamp","log","message","level","currentDate","uptime","getTime","Level","Message","Error","time","startUTCTime","toUTCString","errorUTCTime","navigator","connection","downlink","effectiveType","type","language","platform","userAgent","location","href","errorEvent","isTrusted","returnValue","stack","isLastSameError","send","ERROR","newCount","set","http","XMLHttpRequest","open","setRequestHeader","JSON","stringify","win","performance","now","AppPerformance","timings","sourcesInitialized","console","info","setSourcesInitializedTiming","AppData","LogEnabled","initialLogger","isPerformanceCheckEnabled","IsPerformanceCheckEnabled","isAppPerformanceCreated","measures","onBeforeStateLoading","onSuccessStateLoading"],"mappings":"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","file":"initial.588054d80f273ad14d80.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/Authentication/\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","import {\n\tICommonContentLoader,\n\tICommonContentLoaderError,\n\tICommonContentLoaderParams,\n} from './interfaces/common-content-loader.interface';\n\nexport const COMMON_CONTENT_LOADER_CLASSES = {\n\tLOADER_CONTAINER: 'b-common_content_loader-container',\n\tPROGRESS_OVERLAY: 'b-common_content_loader-progress-overlay',\n\tPROGRESS_OVERLAY_ANIMATION_RUN_CLASS: 'b-common_content_loader-progress-overlay--run',\n\tPROGRESS_BODY_OVERFLOW: 'b-common_content_loader-body_overflow',\n\tPOSITION_ABSOLUTE: 'b-common_content_loader-progress-overlay--absolute',\n\tOPAQUE: 'b-common_content_loader-progress-overlay--opaque',\n\tPROGRESS_WRAPPER: 'b-common_content_loader-wrapper',\n\tPROGRESS_LABEL: 'b-common_content_loader-progress-label',\n\tPROGRESS_ELEMENT: 'b-common_content_loader-progress',\n\tPROGRESS_INDETERMINATE: 'b-common_content_loader-progress-indeterminate',\n\tLOADING_ERROR: 'b-common_content_loader-error',\n\tLOADING_ERROR_DESCRIPTION: 'b-common_content_loader-error_description',\n\tLOADING_ERROR_TIMER: 'b-common_content_loader-error_timer',\n};\n\nexport class CommonContentLoader implements ICommonContentLoader {\n\tprivate static body: HTMLElement = document.body;\n\n\tprivate readonly parentElement: HTMLElement;\n\tprivate readonly container: HTMLElement;\n\tprivate params: ICommonContentLoaderParams;\n\tprivate labelElement: HTMLElement;\n\tprivate wrapperElement: HTMLElement;\n\tprivate errorElement: HTMLElement;\n\tprivate errorDescriptionElement: HTMLElement;\n\tprivate errorTimerElement: HTMLElement;\n\tprivate isEnabled: boolean;\n\tprivate labelText: string;\n\n\tconstructor(params: ICommonContentLoaderParams = {\n\t\tisPositionAbsolute: false,\n\t\tisOpaque: false,\n\t\tlabel: '',\n\t}) {\n\t\tthis.params = params;\n\t\tthis.parentElement = this.params.container || document.body;\n\t\tthis.container = document.createElement('div');\n\t\tthis.labelText = this.params.label || '';\n\n\t\tif (!this.params.container) {\n\t\t\tthis.container.className = COMMON_CONTENT_LOADER_CLASSES.LOADER_CONTAINER;\n\t\t}\n\t}\n\n\tpublic enable() {\n\t\tif (this.isEnabled) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis.parentElement.appendChild(this.container);\n\n\t\tconst containerClasses = [\n\t\t\tCOMMON_CONTENT_LOADER_CLASSES.PROGRESS_OVERLAY,\n\t\t];\n\n\t\tif (this.params.isPositionAbsolute) {\n\t\t\tcontainerClasses.push(COMMON_CONTENT_LOADER_CLASSES.POSITION_ABSOLUTE);\n\t\t}\n\n\t\tif (this.params.isOpaque) {\n\t\t\tcontainerClasses.push(COMMON_CONTENT_LOADER_CLASSES.OPAQUE);\n\t\t}\n\n\t\tthis.container.className += ' ' + containerClasses.join(' ');\n\t\tthis.container.appendChild(this.getTemplate(this.labelText));\n\n\t\tif (!this.params.isPositionAbsolute) {\n\t\t\tCommonContentLoader.body.classList.add(COMMON_CONTENT_LOADER_CLASSES.PROGRESS_BODY_OVERFLOW);\n\t\t}\n\n\t\tsetTimeout(() => {\n\t\t\tthis.container.classList.add(COMMON_CONTENT_LOADER_CLASSES.PROGRESS_OVERLAY_ANIMATION_RUN_CLASS);\n\t\t});\n\n\t\tthis.isEnabled = true;\n\t}\n\n\tpublic disable() {\n\t\tif (!this.isEnabled) {\n\t\t\treturn;\n\t\t}\n\n\t\tthis.container.classList.remove(COMMON_CONTENT_LOADER_CLASSES.PROGRESS_OVERLAY);\n\t\tthis.container.classList.remove(COMMON_CONTENT_LOADER_CLASSES.POSITION_ABSOLUTE);\n\t\tthis.container.classList.remove(COMMON_CONTENT_LOADER_CLASSES.PROGRESS_OVERLAY_ANIMATION_RUN_CLASS);\n\t\tthis.container.textContent = '';\n\t\tthis.container.parentNode.removeChild(this.container);\n\n\t\tCommonContentLoader.body.classList.remove(COMMON_CONTENT_LOADER_CLASSES.PROGRESS_BODY_OVERFLOW);\n\n\t\tthis.isEnabled = false;\n\t}\n\n\tpublic setLabel(label) {\n\t\tthis.labelText = label;\n\n\t\tif (this.labelElement) {\n\t\t\tthis.labelElement.innerHTML = label;\n\t\t}\n\t}\n\n\tpublic error(content: ICommonContentLoaderError) {\n\t\tif (!this.isEnabled) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst fragment = document.createDocumentFragment();\n\n\t\tif (content.text) {\n\t\t\tif (!this.errorElement) {\n\t\t\t\tthis.errorElement = document.createElement('div');\n\t\t\t\tthis.errorElement.className = COMMON_CONTENT_LOADER_CLASSES.LOADING_ERROR;\n\n\t\t\t\tfragment.appendChild(this.errorElement);\n\t\t\t}\n\n\t\t\tthis.errorElement.innerHTML = content.text;\n\t\t}\n\n\t\tif (content.description) {\n\t\t\tif (!this.errorDescriptionElement) {\n\t\t\t\tthis.errorDescriptionElement = document.createElement('div');\n\t\t\t\tthis.errorDescriptionElement.className = COMMON_CONTENT_LOADER_CLASSES.LOADING_ERROR_DESCRIPTION;\n\n\t\t\t\tfragment.appendChild(this.errorDescriptionElement);\n\t\t\t}\n\n\t\t\tthis.errorDescriptionElement.innerHTML = content.description;\n\t\t}\n\n\t\tif (content.timer) {\n\t\t\tif (!this.errorTimerElement) {\n\t\t\t\tthis.errorTimerElement = document.createElement('div');\n\t\t\t\tthis.errorTimerElement.className = COMMON_CONTENT_LOADER_CLASSES.LOADING_ERROR_TIMER;\n\n\t\t\t\tfragment.appendChild(this.errorTimerElement);\n\t\t\t}\n\n\t\t\tthis.errorTimerElement.innerHTML = content.timer;\n\t\t}\n\n\t\tif (fragment.hasChildNodes()) {\n\t\t\tthis.container.appendChild(fragment);\n\t\t}\n\t}\n\n\tprivate getTemplate(label: string): DocumentFragment {\n\t\tconst fragment = document.createDocumentFragment();\n\n\t\tthis.wrapperElement = document.createElement('div');\n\t\tthis.labelElement = document.createElement('div');\n\t\tthis.labelElement.innerHTML = label;\n\n\t\tconst progressElement = document.createElement('div');\n\t\tconst indeterminateElement = document.createElement('div');\n\n\t\tthis.wrapperElement.className = COMMON_CONTENT_LOADER_CLASSES.PROGRESS_WRAPPER;\n\t\tthis.labelElement.className = COMMON_CONTENT_LOADER_CLASSES.PROGRESS_LABEL;\n\t\tprogressElement.className = COMMON_CONTENT_LOADER_CLASSES.PROGRESS_ELEMENT;\n\t\tindeterminateElement.className = COMMON_CONTENT_LOADER_CLASSES.PROGRESS_INDETERMINATE;\n\n\t\tprogressElement.appendChild(indeterminateElement);\n\n\t\tthis.wrapperElement.appendChild(this.labelElement);\n\t\tthis.wrapperElement.appendChild(progressElement);\n\n\t\tfragment.appendChild(this.wrapperElement);\n\n\t\treturn fragment;\n\t}\n}\n\n// tslint:disable-next-line:no-string-literal\nwindow['CommonContentLoader'] = CommonContentLoader;\n","export enum COMMON_LOGGER_LOG_LEVEL {\n\tFATAL = 'Fatal', // Something bad happened; application is going down\n\tERROR = 'Error', // Something failed; application may or may not continue\n\tWARN = 'Warn', // Something unexpected; application will continue\n\tINFO = 'Info', // Normal behavior like mail sent, user updated profile etc.\n\tDEBUG = 'Debug', // For debugging; executed query, user authenticated, session expired\n\tTRACE = 'Trace', // For trace debugging; begin method X, end method X,\n}\n","import { COMMON_LOGGER_LOG_LEVEL } from './logger-log-level.enum';\n\nconst COMMON_LOGGER_MAX_SAME_ERROR_COUNT = 3;\n\nexport interface ICommonLoggerHashchange {\n\toldURL: string,\n\tnewURL: string,\n\ttimeStamp: number,\n}\n\nexport interface ICommonLoggerLogError {\n\n\t// time markers\n\ttime: {\n\t\tstartUTCTime: string, // start app time in UTC Date string\n\t\terrorUTCTime: string, // error time in UTC Date string\n\t\tuptime: number, // uptime in ms before error\n\t},\n\n\t// window.navigator data\n\tnavigator: {\n\t\tconnection?: {\n\t\t\tdownlink: number,\n\t\t\teffectiveType: string,\n\t\t\ttype: string,\n\t\t},\n\t\tlanguage: string,\n\t\tplatform: string,\n\t\tuserAgent: string,\n\t},\n\n\t// window.location data\n\tlocation: {\n\t\thref: string,\n\t},\n\n\t// hashchange events history data\n\thashchange: ICommonLoggerHashchange[],\n\n\t// ErrorEvent data\n\terrorEvent?: {\n\t\tisTrusted: boolean,\n\t\tmessage: string,\n\t\ttimeStamp: number,\n\t\treturnValue: boolean,\n\t\tstack: string,\n\t\ttype: string,\n\t},\n\n\tisLastSameError: boolean, // limit same errors with COMMON_LOGGER_MAX_SAME_ERROR_COUNT\n}\n\nexport interface ICommonLoggerLog {\n\tLevel: COMMON_LOGGER_LOG_LEVEL,\n\tMessage: string,\n\tError: ICommonLoggerLogError,\n}\n\nexport class CommonLogger {\n\tprivate initDate = new Date();\n\tprivate hashchange: ICommonLoggerHashchange[] = [];\n\tprivate previousErrors: Map = new Map();\n\n\tconstructor() {\n\t\twindow.addEventListener('error', (e) => {\n\t\t\tthis.logErrorEvent(e);\n\t\t});\n\t\twindow.addEventListener('hashchange', (e) => {\n\t\t\tthis.hashchange.push({\n\t\t\t\toldURL: e.oldURL,\n\t\t\t\tnewURL: e.newURL,\n\t\t\t\ttimeStamp: e.timeStamp,\n\t\t\t});\n\t\t});\n\t}\n\n\tlog (\n\t\tmessage: string,\n\t\tlevel: COMMON_LOGGER_LOG_LEVEL,\n\t\te?: ErrorEvent,\n\t) {\n\t\tconst currentDate = new Date();\n\t\tconst uptime = currentDate.getTime() - this.initDate.getTime();\n\n\t\tconst log: ICommonLoggerLog = {\n\t\t\tLevel: level,\n\t\t\tMessage: message,\n\t\t\tError: {\n\t\t\t\ttime: {\n\t\t\t\t\tstartUTCTime: this.initDate.toUTCString(),\n\t\t\t\t\terrorUTCTime: currentDate.toUTCString(),\n\t\t\t\t\tuptime,\n\t\t\t\t},\n\t\t\t\tnavigator: window.navigator ? {\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\tconnection: window.navigator.connection ? {\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\tdownlink: window.navigator.connection.downlink,\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\teffectiveType: window.navigator.connection.effectiveType,\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\ttype: window.navigator.connection.type,\n\t\t\t\t\t} : null,\n\t\t\t\t\tlanguage: window.navigator.language,\n\t\t\t\t\tplatform: window.navigator.platform,\n\t\t\t\t\tuserAgent: window.navigator.userAgent,\n\t\t\t\t} : null,\n\t\t\t\tlocation: {\n\t\t\t\t\thref: window.location.href,\n\t\t\t\t},\n\t\t\t\thashchange: this.hashchange,\n\t\t\t\terrorEvent: e ? {\n\t\t\t\t\tisTrusted: e.isTrusted,\n\t\t\t\t\tmessage: e.message,\n\t\t\t\t\ttimeStamp: e.timeStamp,\n\t\t\t\t\treturnValue: e.returnValue,\n\t\t\t\t\tstack: e.error ? e.error.stack : null,\n\t\t\t\t\ttype: e.type,\n\t\t\t\t} : null,\n\t\t\t\tisLastSameError: false,\n\t\t\t},\n\t\t};\n\n\t\tthis.send(log);\n\t}\n\n\tlogErrorEvent (e: ErrorEvent) {\n\t\tthis.log(e.message, COMMON_LOGGER_LOG_LEVEL.ERROR, e);\n\t}\n\n\tprivate send (log: ICommonLoggerLog) {\n\t\tconst previousError = this.previousErrors.get(log.Message);\n\t\tconst newCount = (previousError || 0) + 1;\n\n\t\tthis.previousErrors.set(log.Message, newCount);\n\n\t\tif (newCount <= COMMON_LOGGER_MAX_SAME_ERROR_COUNT) {\n\t\t\tif (newCount === COMMON_LOGGER_MAX_SAME_ERROR_COUNT) {\n\t\t\t\tlog.Error.isLastSameError = true;\n\t\t\t}\n\n\t\t\tconst http = new XMLHttpRequest(); // for IE11\n\n\t\t\thttp.open('POST', 'api/Logs/Add', true);\n\t\t\thttp.setRequestHeader('Content-type', 'application/json');\n\t\t\thttp.send(JSON.stringify(log));\n\t\t}\n\t}\n}\n","import {\n\tisAppPerformanceCreated,\n\tisPerformanceCheckEnabled,\n} from '@CaseOne/Common/utilities/performance-check-utils/performance-check-utils';\n\nexport function setSourcesInitializedTiming (win: Window): void {\n\tif (isPerformanceCheckEnabled(win)) {\n\t\tconst time = win.performance.now();\n\n\t\tisAppPerformanceCreated(win);\n\t\twin.AppPerformance.timings.sourcesInitialized = time;\n\t\t// tslint:disable:no-console\n\t\tconsole.info(`Timing 'sourcesInitialized' is ${time}`);\n\t}\n}\n","import { CommonContentLoader } from '../Common/content-loader/common-content-loader';\nimport { CommonLogger } from '../Common/logger/logger';\nimport {\n\tsetSourcesInitializedTiming\n} from '@CaseOne/Common/utilities/performance-check-utils/set-sources-downloaded-timing';\n\ndeclare const HAS_INITIAL_LOADER: boolean;\n\nsetSourcesInitializedTiming(window);\n\nif (window.AppData && window.AppData.LogEnabled) {\n\twindow.initialLogger = new CommonLogger();\n}\n\nif (HAS_INITIAL_LOADER) {\n\twindow.initialLoader = new CommonContentLoader({\n\t\tisOpaque: true,\n\t});\n\twindow.initialLoader.enable();\n}\n","export function isPerformanceCheckEnabled (win: Window): boolean {\n\treturn !!win.AppData?.IsPerformanceCheckEnabled;\n}\n\nexport function isAppPerformanceCreated (win: Window): void {\n\twin.AppPerformance = window.AppPerformance || {\n\t\tmeasures: {},\n\t\ttimings: {\n\t\t\tsourcesInitialized: null,\n\t\t\tonBeforeStateLoading: null,\n\t\t\tonSuccessStateLoading: null,\n\t\t}\n\t};\n}\n"],"sourceRoot":"webpack:///"}