{ "version": 3, "sources": ["../../node_modules/react/cjs/react.production.min.js", "../../node_modules/react/index.js", "../../node_modules/scheduler/cjs/scheduler.production.min.js", "../../node_modules/scheduler/index.js", "../../node_modules/react-dom/cjs/react-dom.production.min.js", "../../node_modules/react-dom/index.js", "../../node_modules/react-dom/client.js", "../../node_modules/requires-port/index.js", "../../node_modules/querystringify/index.js", "../../node_modules/url-parse/index.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/webpack/universalModuleDefinition", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/external \"zlib\"", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/util/util.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/util/parseTM.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/util/parseDA.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/util/elementToString.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/util/dataSetToJS.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/util/createJPEGBasicOffsetTable.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/readTag.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/findEndOfEncapsulatedPixelData.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/findAndSetUNElementLength.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/byteArrayParser.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/dataSet.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/findItemDelimitationItem.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/readDicomElementImplicit.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/readSequenceItem.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/readSequenceElementImplicit.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/readSequenceElementExplicit.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/readDicomElementExplicit.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/parseDicomDataSet.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/alloc.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/version.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/bigEndianByteArrayParser.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/sharedCopy.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/byteStream.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/littleEndianByteArrayParser.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/readPart10Header.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/parseDicom.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/readEncapsulatedPixelDataFromFragments.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/readEncapsulatedImageFrame.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/readEncapsulatedPixelData.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/index.js", "../../node_modules/dicom-parser/dist/webpack:/dicomParser/webpack/bootstrap", "../../node_modules/domelementtype/lib/index.js", "../../node_modules/domhandler/lib/node.js", "../../node_modules/domhandler/lib/index.js", "../../node_modules/htmlparser2/node_modules/entities/lib/generated/generated/decode-data-html.ts", "../../node_modules/htmlparser2/node_modules/entities/lib/generated/generated/decode-data-xml.ts", "../../node_modules/htmlparser2/node_modules/entities/lib/decode_codepoint.ts", "../../node_modules/htmlparser2/node_modules/entities/lib/decode.ts", "../../node_modules/htmlparser2/lib/Tokenizer.ts", "../../node_modules/htmlparser2/lib/Parser.ts", "../../node_modules/dom-serializer/node_modules/entities/lib/generated/generated/decode-data-html.ts", "../../node_modules/dom-serializer/node_modules/entities/lib/generated/generated/decode-data-xml.ts", "../../node_modules/dom-serializer/node_modules/entities/lib/decode_codepoint.ts", "../../node_modules/dom-serializer/node_modules/entities/lib/decode.ts", "../../node_modules/dom-serializer/node_modules/entities/lib/generated/generated/encode-html.ts", "../../node_modules/dom-serializer/node_modules/entities/lib/escape.ts", "../../node_modules/dom-serializer/node_modules/entities/lib/encode.ts", "../../node_modules/dom-serializer/node_modules/entities/lib/index.ts", "../../node_modules/dom-serializer/lib/foreignNames.js", "../../node_modules/dom-serializer/lib/index.js", "../../node_modules/domutils/lib/stringify.ts", "../../node_modules/domutils/lib/traversal.ts", "../../node_modules/domutils/lib/manipulation.ts", "../../node_modules/domutils/lib/querying.ts", "../../node_modules/domutils/lib/legacy.ts", "../../node_modules/domutils/lib/helpers.ts", "../../node_modules/domutils/lib/feeds.ts", "../../node_modules/domutils/lib/index.ts", "../../node_modules/htmlparser2/lib/index.ts", "../../node_modules/html-dom-parser/src/server/utilities.ts", "../../node_modules/html-dom-parser/src/server/html-to-dom.ts", "../../node_modules/html-dom-parser/src/index.ts", "../../node_modules/react-property/lib/possibleStandardNamesOptimized.js", "../../node_modules/react-property/lib/index.js", "../../node_modules/inline-style-parser/index.js", "../../node_modules/style-to-object/src/index.ts", "../../node_modules/style-to-js/src/utilities.ts", "../../node_modules/style-to-js/src/index.ts", "../../node_modules/html-react-parser/lib/utilities.js", "../../node_modules/html-react-parser/lib/attributes-to-props.js", "../../node_modules/html-react-parser/lib/dom-to-react.js", "../../node_modules/html-react-parser/index.js", "../../node_modules/@babel/runtime/helpers/esm/extends.js", "../../node_modules/@emotion/memoize/dist/emotion-memoize.esm.js", "../../node_modules/@emotion/is-prop-valid/dist/emotion-is-prop-valid.esm.js", "../../node_modules/@emotion/sheet/dist/emotion-sheet.browser.esm.js", "../../node_modules/stylis/src/Enum.js", "../../node_modules/stylis/src/Utility.js", "../../node_modules/stylis/src/Tokenizer.js", "../../node_modules/stylis/src/Parser.js", "../../node_modules/stylis/src/Prefixer.js", "../../node_modules/stylis/src/Serializer.js", "../../node_modules/stylis/src/Middleware.js", "../../node_modules/stylis/index.js", "../../node_modules/@emotion/weak-memoize/dist/emotion-weak-memoize.esm.js", "../../node_modules/@emotion/cache/dist/emotion-cache.browser.esm.js", "../../node_modules/hoist-non-react-statics/node_modules/react-is/cjs/react-is.production.min.js", "../../node_modules/hoist-non-react-statics/node_modules/react-is/index.js", "../../node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js", "../../node_modules/@emotion/utils/dist/emotion-utils.browser.esm.js", "../../node_modules/@emotion/hash/dist/emotion-hash.esm.js", "../../node_modules/@emotion/unitless/dist/emotion-unitless.esm.js", "../../node_modules/@emotion/serialize/dist/emotion-serialize.browser.esm.js", "../../node_modules/@emotion/use-insertion-effect-with-fallbacks/dist/emotion-use-insertion-effect-with-fallbacks.browser.esm.js", "../../node_modules/@emotion/react/dist/emotion-element-c39617d8.browser.esm.js", "../../node_modules/@emotion/react/dist/emotion-react.browser.esm.js", "../../node_modules/@emotion/styled/base/dist/emotion-styled-base.browser.esm.js", "../../node_modules/prop-types/lib/ReactPropTypesSecret.js", "../../node_modules/prop-types/factoryWithThrowingShims.js", "../../node_modules/prop-types/index.js", "../../node_modules/react-dropdown-select/lib/components/ClickOutside.js", "../../node_modules/react-dropdown-select/lib/util.js", "../../node_modules/react-dropdown-select/lib/constants.js", "../../node_modules/react-dropdown-select/lib/components/Option.js", "../../node_modules/react-dropdown-select/lib/components/Input.js", "../../node_modules/react-dropdown-select/lib/components/Content.js", "../../node_modules/react-dropdown-select/lib/components/NoData.js", "../../node_modules/react-dropdown-select/lib/components/Item.js", "../../node_modules/react-dropdown-select/lib/components/Dropdown.js", "../../node_modules/react-dropdown-select/lib/components/Loading.js", "../../node_modules/react-dropdown-select/lib/components/Clear.js", "../../node_modules/react-dropdown-select/lib/components/Separator.js", "../../node_modules/react-dropdown-select/lib/components/DropdownHandle.js", "../../node_modules/react-dropdown-select/lib/index.js", "../../node_modules/react-modal/lib/helpers/tabbable.js", "../../node_modules/react-modal/lib/helpers/focusManager.js", "../../node_modules/react-modal/lib/helpers/scopeTab.js", "../../node_modules/warning/warning.js", "../../node_modules/exenv/index.js", "../../node_modules/react-modal/lib/helpers/safeHTMLElement.js", "../../node_modules/react-modal/lib/helpers/ariaAppHider.js", "../../node_modules/react-modal/lib/helpers/classList.js", "../../node_modules/react-modal/lib/helpers/portalOpenInstances.js", "../../node_modules/react-modal/lib/helpers/bodyTrap.js", "../../node_modules/react-modal/lib/components/ModalPortal.js", "../../node_modules/react-lifecycles-compat/react-lifecycles-compat.cjs.js", "../../node_modules/react-modal/lib/components/Modal.js", "../../node_modules/react-modal/lib/index.js", "../../node_modules/lodash/lodash.js", "../../node_modules/jszip/dist/jszip.min.js", "../../App/app-upload/Upload.tsx", "../../App/types/AbortError.ts", "../../App/util/io/Fetcher.ts", "../../App/network/fetchers/ResourcesFetcher.ts", "../../App/resources/ResourcesStore.ts", "../../App/network/fetchers/POW3Fetchers.ts", "../../node_modules/mobx/src/errors.ts", "../../node_modules/mobx/src/utils/global.ts", "../../node_modules/mobx/src/utils/utils.ts", "../../node_modules/mobx/src/api/decorators.ts", "../../node_modules/mobx/src/core/atom.ts", "../../node_modules/mobx/src/utils/comparer.ts", "../../node_modules/mobx/src/types/modifiers.ts", "../../node_modules/mobx/src/types/overrideannotation.ts", "../../node_modules/mobx/src/types/actionannotation.ts", "../../node_modules/mobx/src/types/flowannotation.ts", "../../node_modules/mobx/src/types/computedannotation.ts", "../../node_modules/mobx/src/types/observableannotation.ts", "../../node_modules/mobx/src/types/autoannotation.ts", "../../node_modules/mobx/src/api/observable.ts", "../../node_modules/mobx/src/api/computed.ts", "../../node_modules/mobx/src/core/action.ts", "../../node_modules/mobx/src/types/observablevalue.ts", "../../node_modules/mobx/src/core/computedvalue.ts", "../../node_modules/mobx/src/core/derivation.ts", "../../node_modules/mobx/src/core/globalstate.ts", "../../node_modules/mobx/src/core/observable.ts", "../../node_modules/mobx/src/core/reaction.ts", "../../node_modules/mobx/src/core/spy.ts", "../../node_modules/mobx/src/api/action.ts", "../../node_modules/mobx/src/api/autorun.ts", "../../node_modules/mobx/src/api/become-observed.ts", "../../node_modules/mobx/src/api/configure.ts", "../../node_modules/mobx/src/api/extendobservable.ts", "../../node_modules/mobx/src/api/extras.ts", "../../node_modules/mobx/src/api/flow.ts", "../../node_modules/mobx/src/api/intercept-read.ts", "../../node_modules/mobx/src/api/intercept.ts", "../../node_modules/mobx/src/api/iscomputed.ts", "../../node_modules/mobx/src/api/isobservable.ts", "../../node_modules/mobx/src/api/object-api.ts", "../../node_modules/mobx/src/api/observe.ts", "../../node_modules/mobx/src/api/tojs.ts", "../../node_modules/mobx/src/api/trace.ts", "../../node_modules/mobx/src/api/transaction.ts", "../../node_modules/mobx/src/api/when.ts", "../../node_modules/mobx/src/types/dynamicobject.ts", "../../node_modules/mobx/src/types/intercept-utils.ts", "../../node_modules/mobx/src/types/listen-utils.ts", "../../node_modules/mobx/src/api/makeObservable.ts", "../../node_modules/mobx/src/types/observablearray.ts", "../../node_modules/mobx/src/types/observablemap.ts", "../../node_modules/mobx/src/types/observableset.ts", "../../node_modules/mobx/src/types/observableobject.ts", "../../node_modules/mobx/src/types/legacyobservablearray.ts", "../../node_modules/mobx/src/types/type-utils.ts", "../../node_modules/mobx/src/utils/eq.ts", "../../node_modules/mobx/src/utils/iterable.ts", "../../node_modules/mobx/src/api/annotation.ts", "../../node_modules/mobx/src/mobx.ts", "../../App/util/cookies/cookie.ts", "../../App/util/local-storage/localStorage.ts", "../../App/util/local-storage/localStorageOrCookie.ts", "../../App/shared-components/header/news-menu/NewsMenuStore.ts", "../../App/shared-components/header/environment-selector/EnvironmentSelectorStore.ts", "../../App/util/functions/getBoundingClientRect.ts", "../../App/viewer/rendering/Point.ts", "../../App/shared-components/rich-tooltip/RichToolTipStore.ts", "../../App/shared-components/header/help-menu/about-us/AboutUsDialogStore.ts", "../../App/network/fetchers/HeartBeatFetcher.ts", "../../App/shared-components/window/local-storage/LocalStorage.ts", "../../App/shared-components/window/DefaultCurrentWindowStore.ts", "../../App/shared-components/window/document/CurrentDocumentStore.ts", "../../App/util/async/FireAndForget.ts", "../../App/shared-components/heartbeat/HeartBeatStore.ts", "../../App/shared-components/user/UserSessionStore.ts", "../../App/shared-components/product-info/ProductInfoStore.ts", "../../App/shared-components/cookie-banner/CookieSettingsStore.ts", "../../App/shared-components/header/help-menu/about-us/ThirdPartySoftwareStore.ts", "../../App/shared-components/AppStoresFactory.ts", "../../App/app-upload/UploadMasterComponent.tsx", "../../App/app-upload/content/UploadContentComponent.tsx", "../../node_modules/mobx-react-lite/src/utils/assertEnvironment.ts", "../../node_modules/mobx-react-lite/src/utils/reactBatchedUpdates.ts", "../../node_modules/mobx-react-lite/src/utils/observerBatching.ts", "../../node_modules/mobx-react-lite/src/useObserver.ts", "../../node_modules/mobx-react-lite/src/utils/printDebugValue.ts", "../../node_modules/mobx-react-lite/src/utils/UniversalFinalizationRegistry.ts", "../../node_modules/mobx-react-lite/src/utils/observerFinalizationRegistry.ts", "../../node_modules/mobx-react-lite/src/staticRendering.ts", "../../node_modules/mobx-react-lite/src/observer.ts", "../../node_modules/mobx-react-lite/src/ObserverComponent.ts", "../../node_modules/mobx-react-lite/src/useLocalObservable.ts", "../../node_modules/mobx-react-lite/src/useLocalStore.ts", "../../node_modules/mobx-react-lite/src/useAsObservableSource.ts", "../../node_modules/mobx-react-lite/src/index.ts", "../../node_modules/mobx-react/src/utils/utils.ts", "../../node_modules/mobx-react/src/observerClass.ts", "../../node_modules/mobx-react/src/observer.tsx", "../../node_modules/mobx-react/src/Provider.tsx", "../../node_modules/mobx-react/src/inject.ts", "../../node_modules/mobx-react/src/disposeOnUnmount.ts", "../../node_modules/mobx-react/src/propTypes.ts", "../../node_modules/mobx-react/src/index.ts", "../../App/app-upload/inject.ts", "../../App/app-upload/content/file-selection/FileSelectionComponent.tsx", "../../App/shared-components/inject.ts", "../../App/util/types/guid.ts", "../../App/app-upload/content/file-selection/selected-files/SelectedFilesComponent.tsx", "../../App/app-upload/content/file-selection/not-uploadable/NotUploadableFilesComponent.tsx", "../../App/app-upload/content/file/FileUploadComponent.tsx", "../../App/util/functions/humanizeFileSize.ts", "../../App/shared-components/rich-tooltip/RichToolTipComponent.tsx", "../../App/util/functions/nullOrUndefined.ts", "../../App/shared-components/progress-bar/ProgressBarComponent.tsx", "../../node_modules/js-base64/base64.mjs", "../../node_modules/tus-js-client/lib.esm/upload.js", "../../node_modules/tus-js-client/lib.esm/error.js", "../../node_modules/tus-js-client/lib.esm/logger.js", "../../node_modules/tus-js-client/lib.esm/uuid.js", "../../node_modules/tus-js-client/lib.esm/noopUrlStorage.js", "../../node_modules/tus-js-client/lib.esm/browser/urlStorage.js", "../../node_modules/tus-js-client/lib.esm/browser/httpStack.js", "../../node_modules/tus-js-client/lib.esm/browser/isReactNative.js", "../../node_modules/tus-js-client/lib.esm/browser/uriToBlob.js", "../../node_modules/tus-js-client/lib.esm/browser/sources/isCordova.js", "../../node_modules/tus-js-client/lib.esm/browser/sources/readAsByteArray.js", "../../node_modules/tus-js-client/lib.esm/browser/sources/FileSource.js", "../../node_modules/tus-js-client/lib.esm/browser/sources/StreamSource.js", "../../node_modules/tus-js-client/lib.esm/browser/fileReader.js", "../../node_modules/tus-js-client/lib.esm/browser/fileSignature.js", "../../node_modules/tus-js-client/lib.esm/browser/index.js", "../../App/app-upload/DicomFileReader.ts", "../../App/network/contracts/DicomDataSet.ts", "../../App/network/contracts/DicomTag.ts", "../../App/app-upload/DicomUploadTusFingerprintStore.ts", "../../App/app-upload/FileUpload.ts", "../../App/util/assertions/assertUnreachable.ts", "../../App/shared-components/static-notification/StaticNotificationComponent.tsx", "../../App/app-upload/content/DragAndDropComponent.tsx", "../../App/app-upload/content/verify-patient-study/PatientsUploadComponent.tsx", "../../App/app-upload/content/verify-patient-study/patient/PatientToUploadComponent.tsx", "../../node_modules/html-react-parser/index.mjs", "../../App/app-upload/content/verify-patient-study/study/StudyInUploadComponent.tsx", "../../App/app-upload/content/verify-patient-study/button-and-status-logic/UploadButtonLogicComponent.tsx", "../../App/app-upload/content/verify-patient-study/button-and-status-logic/status-and-progress/UploadProgressComponent.tsx", "../../App/app-upload/content/upload-code-and-source-selection/UploadCodeAndSourceSelectionComponent.tsx", "../../App/app-upload/content/upload-code-and-source-selection/UploadCodeAndSourceSelectionValidatedComponent.tsx", "../../App/app-upload/content/upload-code-and-source-selection/UploadCodeAndSourceSelectionInvalidatedComponent.tsx", "../../node_modules/src/index.tsx", "../../App/shared-components/floating-container/FloatingContainerComponent.tsx", "../../App/shared-components/AppComponent.tsx", "../../App/shared-components/header/HeaderComponent.tsx", "../../App/shared-components/header/language-selector/LanguageSelectorComponent.tsx", "../../App/shared-components/header/language-selector/LanguageSelectorItem.tsx", "../../App/shared-components/header/news-menu/NewsMenuComponent.tsx", "../../App/shared-components/header/environment-selector/EnvironmentSelectorComponent.tsx", "../../App/shared-components/header/help-menu/HelpMenuComponent.tsx", "../../App/shared-components/header/help-menu/about-us/AboutUsDialogComponent.tsx", "../../App/shared-components/modal-dialog/ModalDialogComponent.tsx", "../../App/shared-components/modal-dialog/elements/ModalDialogHeaderComponent.tsx", "../../App/shared-components/modal-dialog/elements/ModalDialogFooterComponent.tsx", "../../App/shared-components/modal-dialog/elements/ModalDialogBodyComponent.tsx", "../../App/shared-components/header/help-menu/about-us/ThirdPartySoftwareComponent.tsx", "../../App/shared-components/rich-tooltip/RichToolTipBaseComponent.tsx", "../../App/util/functions/delay.ts", "../../App/util/components/DocumentBodyPortalComponent.tsx", "../../App/shared-components/cookie-banner/CookieBannerComponent.tsx", "../../App/app-upload/AppUpload.ts", "../../App/app-upload/UploadStore.ts", "../../App/app-upload/PatientToUpload.ts", "../../node_modules/@babel/runtime/helpers/esm/typeof.js", "../../node_modules/date-fns/esm/_lib/toInteger/index.js", "../../node_modules/date-fns/esm/_lib/requiredArgs/index.js", "../../node_modules/date-fns/esm/toDate/index.js", "../../node_modules/date-fns/esm/addMilliseconds/index.js", "../../node_modules/date-fns/esm/_lib/defaultOptions/index.js", "../../node_modules/date-fns/esm/_lib/getTimezoneOffsetInMilliseconds/index.js", "../../node_modules/date-fns/esm/constants/index.js", "../../node_modules/date-fns/esm/isDate/index.js", "../../node_modules/date-fns/esm/isValid/index.js", "../../node_modules/date-fns/esm/subMilliseconds/index.js", "../../node_modules/date-fns/esm/_lib/getUTCDayOfYear/index.js", "../../node_modules/date-fns/esm/_lib/startOfUTCISOWeek/index.js", "../../node_modules/date-fns/esm/_lib/getUTCISOWeekYear/index.js", "../../node_modules/date-fns/esm/_lib/startOfUTCISOWeekYear/index.js", "../../node_modules/date-fns/esm/_lib/getUTCISOWeek/index.js", "../../node_modules/date-fns/esm/_lib/startOfUTCWeek/index.js", "../../node_modules/date-fns/esm/_lib/getUTCWeekYear/index.js", "../../node_modules/date-fns/esm/_lib/startOfUTCWeekYear/index.js", "../../node_modules/date-fns/esm/_lib/getUTCWeek/index.js", "../../node_modules/date-fns/esm/_lib/addLeadingZeros/index.js", "../../node_modules/date-fns/esm/_lib/format/lightFormatters/index.js", "../../node_modules/date-fns/esm/_lib/format/formatters/index.js", "../../node_modules/date-fns/esm/_lib/format/longFormatters/index.js", "../../node_modules/date-fns/esm/_lib/protectedTokens/index.js", "../../node_modules/date-fns/esm/locale/en-US/_lib/formatDistance/index.js", "../../node_modules/date-fns/esm/locale/_lib/buildFormatLongFn/index.js", "../../node_modules/date-fns/esm/locale/en-US/_lib/formatLong/index.js", "../../node_modules/date-fns/esm/locale/en-US/_lib/formatRelative/index.js", "../../node_modules/date-fns/esm/locale/_lib/buildLocalizeFn/index.js", "../../node_modules/date-fns/esm/locale/en-US/_lib/localize/index.js", "../../node_modules/date-fns/esm/locale/_lib/buildMatchFn/index.js", "../../node_modules/date-fns/esm/locale/_lib/buildMatchPatternFn/index.js", "../../node_modules/date-fns/esm/locale/en-US/_lib/match/index.js", "../../node_modules/date-fns/esm/locale/en-US/index.js", "../../node_modules/date-fns/esm/_lib/defaultLocale/index.js", "../../node_modules/date-fns/esm/format/index.js", "../../node_modules/date-fns/esm/_lib/assign/index.js", "../../node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js", "../../node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js", "../../node_modules/@babel/runtime/helpers/esm/createForOfIteratorHelper.js", "../../node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js", "../../node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js", "../../node_modules/@babel/runtime/helpers/esm/inherits.js", "../../node_modules/@babel/runtime/helpers/esm/getPrototypeOf.js", "../../node_modules/@babel/runtime/helpers/esm/isNativeReflectConstruct.js", "../../node_modules/@babel/runtime/helpers/esm/possibleConstructorReturn.js", "../../node_modules/@babel/runtime/helpers/esm/createSuper.js", "../../node_modules/@babel/runtime/helpers/esm/classCallCheck.js", "../../node_modules/@babel/runtime/helpers/esm/toPrimitive.js", "../../node_modules/@babel/runtime/helpers/esm/toPropertyKey.js", "../../node_modules/@babel/runtime/helpers/esm/createClass.js", "../../node_modules/@babel/runtime/helpers/esm/defineProperty.js", "../../node_modules/date-fns/esm/parse/_lib/Setter.js", "../../node_modules/date-fns/esm/parse/_lib/Parser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/EraParser.js", "../../node_modules/date-fns/esm/parse/_lib/constants.js", "../../node_modules/date-fns/esm/parse/_lib/utils.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/YearParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/LocalWeekYearParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/ISOWeekYearParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/ExtendedYearParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/QuarterParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/StandAloneQuarterParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/MonthParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/StandAloneMonthParser.js", "../../node_modules/date-fns/esm/_lib/setUTCWeek/index.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/LocalWeekParser.js", "../../node_modules/date-fns/esm/_lib/setUTCISOWeek/index.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/ISOWeekParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/DateParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/DayOfYearParser.js", "../../node_modules/date-fns/esm/_lib/setUTCDay/index.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/DayParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/LocalDayParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/StandAloneLocalDayParser.js", "../../node_modules/date-fns/esm/_lib/setUTCISODay/index.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/ISODayParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/AMPMParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/AMPMMidnightParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/DayPeriodParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/Hour1to12Parser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/Hour0to23Parser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/Hour0To11Parser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/Hour1To24Parser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/MinuteParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/SecondParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/FractionOfSecondParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/ISOTimezoneWithZParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/ISOTimezoneParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/TimestampSecondsParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/TimestampMillisecondsParser.js", "../../node_modules/date-fns/esm/parse/_lib/parsers/index.js", "../../node_modules/date-fns/esm/parse/index.js", "../../node_modules/date-fns/esm/parseISO/index.js", "../../App/util/date/parseDate.ts", "../../node_modules/date-fns/esm/_lib/isSameUTCWeek/index.js", "../../node_modules/date-fns/esm/locale/de/_lib/formatDistance/index.js", "../../node_modules/date-fns/esm/locale/de/_lib/formatLong/index.js", "../../node_modules/date-fns/esm/locale/de/_lib/formatRelative/index.js", "../../node_modules/date-fns/esm/locale/de/_lib/localize/index.js", "../../node_modules/date-fns/esm/locale/de/_lib/match/index.js", "../../node_modules/date-fns/esm/locale/de/index.js", "../../node_modules/date-fns/esm/locale/en-GB/_lib/formatLong/index.js", "../../node_modules/date-fns/esm/locale/en-GB/index.js", "../../node_modules/date-fns/esm/locale/es/_lib/formatDistance/index.js", "../../node_modules/date-fns/esm/locale/es/_lib/formatLong/index.js", "../../node_modules/date-fns/esm/locale/es/_lib/formatRelative/index.js", "../../node_modules/date-fns/esm/locale/es/_lib/localize/index.js", "../../node_modules/date-fns/esm/locale/es/_lib/match/index.js", "../../node_modules/date-fns/esm/locale/es/index.js", "../../node_modules/date-fns/esm/locale/fr/_lib/formatDistance/index.js", "../../node_modules/date-fns/esm/locale/fr/_lib/formatLong/index.js", "../../node_modules/date-fns/esm/locale/fr/_lib/formatRelative/index.js", "../../node_modules/date-fns/esm/locale/fr/_lib/localize/index.js", "../../node_modules/date-fns/esm/locale/fr/_lib/match/index.js", "../../node_modules/date-fns/esm/locale/fr/index.js", "../../node_modules/date-fns/esm/locale/it/_lib/formatDistance/index.js", "../../node_modules/date-fns/esm/locale/it/_lib/formatLong/index.js", "../../node_modules/date-fns/esm/locale/it/_lib/formatRelative/index.js", "../../node_modules/date-fns/esm/locale/it/_lib/localize/index.js", "../../node_modules/date-fns/esm/locale/it/_lib/match/index.js", "../../node_modules/date-fns/esm/locale/it/index.js", "../../node_modules/date-fns/esm/locale/nb/_lib/formatDistance/index.js", "../../node_modules/date-fns/esm/locale/nb/_lib/formatLong/index.js", "../../node_modules/date-fns/esm/locale/nb/_lib/formatRelative/index.js", "../../node_modules/date-fns/esm/locale/nb/_lib/localize/index.js", "../../node_modules/date-fns/esm/locale/nb/_lib/match/index.js", "../../node_modules/date-fns/esm/locale/nb/index.js", "../../node_modules/date-fns/esm/locale/nl/_lib/formatDistance/index.js", "../../node_modules/date-fns/esm/locale/nl/_lib/formatLong/index.js", "../../node_modules/date-fns/esm/locale/nl/_lib/formatRelative/index.js", "../../node_modules/date-fns/esm/locale/nl/_lib/localize/index.js", "../../node_modules/date-fns/esm/locale/nl/_lib/match/index.js", "../../node_modules/date-fns/esm/locale/nl/index.js", "../../node_modules/date-fns/esm/locale/pt-BR/_lib/formatDistance/index.js", "../../node_modules/date-fns/esm/locale/pt-BR/_lib/formatLong/index.js", "../../node_modules/date-fns/esm/locale/pt-BR/_lib/formatRelative/index.js", "../../node_modules/date-fns/esm/locale/pt-BR/_lib/localize/index.js", "../../node_modules/date-fns/esm/locale/pt-BR/_lib/match/index.js", "../../node_modules/date-fns/esm/locale/pt-BR/index.js", "../../App/util/date/distanceToNow.ts", "../../App/util/date/formatOrDefault.ts", "../../App/app-upload/StudyInUpload.ts", "../../App/util/regex/regex.ts", "../../App/util/assertions/throwError.ts", "../../App/util/functions/isNullOrWhiteSpace.ts", "../../App/util/functions/notNullOrUndefined.ts", "../../App/app-upload/content/upload-code-and-source-selection/UploadCodeAndSourceSelectionStore.ts", "../../App/network/fetchers/CodeAndSourceValidationFetcher.ts", "../../App/app-upload/PatientUploadCompleteCallbackStore.ts", "../../App/app-upload/network/domain/UploadSource.ts", "../../App/app-upload/network/mappers/UploadSourceMapper.ts", "../../App/app-upload/CurrentUploadSettingsStore.ts", "../../App/app-upload/AppUploadFactory.ts"], "sourcesContent": ["/**\n * @license React\n * react.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var l=Symbol.for(\"react.element\"),n=Symbol.for(\"react.portal\"),p=Symbol.for(\"react.fragment\"),q=Symbol.for(\"react.strict_mode\"),r=Symbol.for(\"react.profiler\"),t=Symbol.for(\"react.provider\"),u=Symbol.for(\"react.context\"),v=Symbol.for(\"react.forward_ref\"),w=Symbol.for(\"react.suspense\"),x=Symbol.for(\"react.memo\"),y=Symbol.for(\"react.lazy\"),z=Symbol.iterator;function A(a){if(null===a||\"object\"!==typeof a)return null;a=z&&a[z]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}\nvar B={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},C=Object.assign,D={};function E(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}E.prototype.isReactComponent={};\nE.prototype.setState=function(a,b){if(\"object\"!==typeof a&&\"function\"!==typeof a&&null!=a)throw Error(\"setState(...): takes an object of state variables to update or a function which returns an object of state variables.\");this.updater.enqueueSetState(this,a,b,\"setState\")};E.prototype.forceUpdate=function(a){this.updater.enqueueForceUpdate(this,a,\"forceUpdate\")};function F(){}F.prototype=E.prototype;function G(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}var H=G.prototype=new F;\nH.constructor=G;C(H,E.prototype);H.isPureReactComponent=!0;var I=Array.isArray,J=Object.prototype.hasOwnProperty,K={current:null},L={key:!0,ref:!0,__self:!0,__source:!0};\nfunction M(a,b,e){var d,c={},k=null,h=null;if(null!=b)for(d in void 0!==b.ref&&(h=b.ref),void 0!==b.key&&(k=\"\"+b.key),b)J.call(b,d)&&!L.hasOwnProperty(d)&&(c[d]=b[d]);var g=arguments.length-2;if(1===g)c.children=e;else if(1>>1,e=a[d];if(0>>1;dg(C,c))ng(x,C)?(a[d]=x,a[n]=c,d=n):(a[d]=C,a[m]=c,d=m);else if(ng(x,c))a[d]=x,a[n]=c,d=n;else break a}}return b}\nfunction g(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}if(\"object\"===typeof performance&&\"function\"===typeof performance.now){var l=performance;exports.unstable_now=function(){return l.now()}}else{var p=Date,q=p.now();exports.unstable_now=function(){return p.now()-q}}var r=[],t=[],u=1,v=null,y=3,z=!1,A=!1,B=!1,D=\"function\"===typeof setTimeout?setTimeout:null,E=\"function\"===typeof clearTimeout?clearTimeout:null,F=\"undefined\"!==typeof setImmediate?setImmediate:null;\n\"undefined\"!==typeof navigator&&void 0!==navigator.scheduling&&void 0!==navigator.scheduling.isInputPending&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function G(a){for(var b=h(t);null!==b;){if(null===b.callback)k(t);else if(b.startTime<=a)k(t),b.sortIndex=b.expirationTime,f(r,b);else break;b=h(t)}}function H(a){B=!1;G(a);if(!A)if(null!==h(r))A=!0,I(J);else{var b=h(t);null!==b&&K(H,b.startTime-a)}}\nfunction J(a,b){A=!1;B&&(B=!1,E(L),L=-1);z=!0;var c=y;try{G(b);for(v=h(r);null!==v&&(!(v.expirationTime>b)||a&&!M());){var d=v.callback;if(\"function\"===typeof d){v.callback=null;y=v.priorityLevel;var e=d(v.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?v.callback=e:v===h(r)&&k(r);G(b)}else k(r);v=h(r)}if(null!==v)var w=!0;else{var m=h(t);null!==m&&K(H,m.startTime-b);w=!1}return w}finally{v=null,y=c,z=!1}}var N=!1,O=null,L=-1,P=5,Q=-1;\nfunction M(){return exports.unstable_now()-Qa||125d?(a.sortIndex=c,f(t,a),null===h(r)&&a===h(t)&&(B?(E(L),L=-1):B=!0,K(H,c-d))):(a.sortIndex=e,f(r,a),A||z||(A=!0,I(J)));return a};\nexports.unstable_shouldYield=M;exports.unstable_wrapCallback=function(a){var b=y;return function(){var c=y;y=b;try{return a.apply(this,arguments)}finally{y=c}}};\n", "'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/scheduler.production.min.js');\n} else {\n module.exports = require('./cjs/scheduler.development.js');\n}\n", "/**\n * @license React\n * react-dom.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n/*\n Modernizr 3.0.0pre (Custom Build) | MIT\n*/\n'use strict';var aa=require(\"react\"),ca=require(\"scheduler\");function p(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;cb}return!1}function v(a,b,c,d,e,f,g){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f;this.removeEmptyString=g}var z={};\n\"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style\".split(\" \").forEach(function(a){z[a]=new v(a,0,!1,a,null,!1,!1)});[[\"acceptCharset\",\"accept-charset\"],[\"className\",\"class\"],[\"htmlFor\",\"for\"],[\"httpEquiv\",\"http-equiv\"]].forEach(function(a){var b=a[0];z[b]=new v(b,1,!1,a[1],null,!1,!1)});[\"contentEditable\",\"draggable\",\"spellCheck\",\"value\"].forEach(function(a){z[a]=new v(a,2,!1,a.toLowerCase(),null,!1,!1)});\n[\"autoReverse\",\"externalResourcesRequired\",\"focusable\",\"preserveAlpha\"].forEach(function(a){z[a]=new v(a,2,!1,a,null,!1,!1)});\"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope\".split(\" \").forEach(function(a){z[a]=new v(a,3,!1,a.toLowerCase(),null,!1,!1)});\n[\"checked\",\"multiple\",\"muted\",\"selected\"].forEach(function(a){z[a]=new v(a,3,!0,a,null,!1,!1)});[\"capture\",\"download\"].forEach(function(a){z[a]=new v(a,4,!1,a,null,!1,!1)});[\"cols\",\"rows\",\"size\",\"span\"].forEach(function(a){z[a]=new v(a,6,!1,a,null,!1,!1)});[\"rowSpan\",\"start\"].forEach(function(a){z[a]=new v(a,5,!1,a.toLowerCase(),null,!1,!1)});var ra=/[\\-:]([a-z])/g;function sa(a){return a[1].toUpperCase()}\n\"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height\".split(\" \").forEach(function(a){var b=a.replace(ra,\nsa);z[b]=new v(b,1,!1,a,null,!1,!1)});\"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type\".split(\" \").forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/1999/xlink\",!1,!1)});[\"xml:base\",\"xml:lang\",\"xml:space\"].forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/XML/1998/namespace\",!1,!1)});[\"tabIndex\",\"crossOrigin\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!1,!1)});\nz.xlinkHref=new v(\"xlinkHref\",1,!1,\"xlink:href\",\"http://www.w3.org/1999/xlink\",!0,!1);[\"src\",\"href\",\"action\",\"formAction\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!0,!0)});\nfunction ta(a,b,c,d){var e=z.hasOwnProperty(b)?z[b]:null;if(null!==e?0!==e.type:d||!(2h||e[g]!==f[h]){var k=\"\\n\"+e[g].replace(\" at new \",\" at \");a.displayName&&k.includes(\"\")&&(k=k.replace(\"\",a.displayName));return k}while(1<=g&&0<=h)}break}}}finally{Na=!1,Error.prepareStackTrace=c}return(a=a?a.displayName||a.name:\"\")?Ma(a):\"\"}\nfunction Pa(a){switch(a.tag){case 5:return Ma(a.type);case 16:return Ma(\"Lazy\");case 13:return Ma(\"Suspense\");case 19:return Ma(\"SuspenseList\");case 0:case 2:case 15:return a=Oa(a.type,!1),a;case 11:return a=Oa(a.type.render,!1),a;case 1:return a=Oa(a.type,!0),a;default:return\"\"}}\nfunction Qa(a){if(null==a)return null;if(\"function\"===typeof a)return a.displayName||a.name||null;if(\"string\"===typeof a)return a;switch(a){case ya:return\"Fragment\";case wa:return\"Portal\";case Aa:return\"Profiler\";case za:return\"StrictMode\";case Ea:return\"Suspense\";case Fa:return\"SuspenseList\"}if(\"object\"===typeof a)switch(a.$$typeof){case Ca:return(a.displayName||\"Context\")+\".Consumer\";case Ba:return(a._context.displayName||\"Context\")+\".Provider\";case Da:var b=a.render;a=a.displayName;a||(a=b.displayName||\nb.name||\"\",a=\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");return a;case Ga:return b=a.displayName||null,null!==b?b:Qa(a.type)||\"Memo\";case Ha:b=a._payload;a=a._init;try{return Qa(a(b))}catch(c){}}return null}\nfunction Ra(a){var b=a.type;switch(a.tag){case 24:return\"Cache\";case 9:return(b.displayName||\"Context\")+\".Consumer\";case 10:return(b._context.displayName||\"Context\")+\".Provider\";case 18:return\"DehydratedFragment\";case 11:return a=b.render,a=a.displayName||a.name||\"\",b.displayName||(\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");case 7:return\"Fragment\";case 5:return b;case 4:return\"Portal\";case 3:return\"Root\";case 6:return\"Text\";case 16:return Qa(b);case 8:return b===za?\"StrictMode\":\"Mode\";case 22:return\"Offscreen\";\ncase 12:return\"Profiler\";case 21:return\"Scope\";case 13:return\"Suspense\";case 19:return\"SuspenseList\";case 25:return\"TracingMarker\";case 1:case 0:case 17:case 2:case 14:case 15:if(\"function\"===typeof b)return b.displayName||b.name||null;if(\"string\"===typeof b)return b}return null}function Sa(a){switch(typeof a){case \"boolean\":case \"number\":case \"string\":case \"undefined\":return a;case \"object\":return a;default:return\"\"}}\nfunction Ta(a){var b=a.type;return(a=a.nodeName)&&\"input\"===a.toLowerCase()&&(\"checkbox\"===b||\"radio\"===b)}\nfunction Ua(a){var b=Ta(a)?\"checked\":\"value\",c=Object.getOwnPropertyDescriptor(a.constructor.prototype,b),d=\"\"+a[b];if(!a.hasOwnProperty(b)&&\"undefined\"!==typeof c&&\"function\"===typeof c.get&&\"function\"===typeof c.set){var e=c.get,f=c.set;Object.defineProperty(a,b,{configurable:!0,get:function(){return e.call(this)},set:function(a){d=\"\"+a;f.call(this,a)}});Object.defineProperty(a,b,{enumerable:c.enumerable});return{getValue:function(){return d},setValue:function(a){d=\"\"+a},stopTracking:function(){a._valueTracker=\nnull;delete a[b]}}}}function Va(a){a._valueTracker||(a._valueTracker=Ua(a))}function Wa(a){if(!a)return!1;var b=a._valueTracker;if(!b)return!0;var c=b.getValue();var d=\"\";a&&(d=Ta(a)?a.checked?\"true\":\"false\":a.value);a=d;return a!==c?(b.setValue(a),!0):!1}function Xa(a){a=a||(\"undefined\"!==typeof document?document:void 0);if(\"undefined\"===typeof a)return null;try{return a.activeElement||a.body}catch(b){return a.body}}\nfunction Ya(a,b){var c=b.checked;return A({},b,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=c?c:a._wrapperState.initialChecked})}function Za(a,b){var c=null==b.defaultValue?\"\":b.defaultValue,d=null!=b.checked?b.checked:b.defaultChecked;c=Sa(null!=b.value?b.value:c);a._wrapperState={initialChecked:d,initialValue:c,controlled:\"checkbox\"===b.type||\"radio\"===b.type?null!=b.checked:null!=b.value}}function ab(a,b){b=b.checked;null!=b&&ta(a,\"checked\",b,!1)}\nfunction bb(a,b){ab(a,b);var c=Sa(b.value),d=b.type;if(null!=c)if(\"number\"===d){if(0===c&&\"\"===a.value||a.value!=c)a.value=\"\"+c}else a.value!==\"\"+c&&(a.value=\"\"+c);else if(\"submit\"===d||\"reset\"===d){a.removeAttribute(\"value\");return}b.hasOwnProperty(\"value\")?cb(a,b.type,c):b.hasOwnProperty(\"defaultValue\")&&cb(a,b.type,Sa(b.defaultValue));null==b.checked&&null!=b.defaultChecked&&(a.defaultChecked=!!b.defaultChecked)}\nfunction db(a,b,c){if(b.hasOwnProperty(\"value\")||b.hasOwnProperty(\"defaultValue\")){var d=b.type;if(!(\"submit\"!==d&&\"reset\"!==d||void 0!==b.value&&null!==b.value))return;b=\"\"+a._wrapperState.initialValue;c||b===a.value||(a.value=b);a.defaultValue=b}c=a.name;\"\"!==c&&(a.name=\"\");a.defaultChecked=!!a._wrapperState.initialChecked;\"\"!==c&&(a.name=c)}\nfunction cb(a,b,c){if(\"number\"!==b||Xa(a.ownerDocument)!==a)null==c?a.defaultValue=\"\"+a._wrapperState.initialValue:a.defaultValue!==\"\"+c&&(a.defaultValue=\"\"+c)}var eb=Array.isArray;\nfunction fb(a,b,c,d){a=a.options;if(b){b={};for(var e=0;e\"+b.valueOf().toString()+\"\";for(b=mb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});\nfunction ob(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}\nvar pb={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,\nzoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},qb=[\"Webkit\",\"ms\",\"Moz\",\"O\"];Object.keys(pb).forEach(function(a){qb.forEach(function(b){b=b+a.charAt(0).toUpperCase()+a.substring(1);pb[b]=pb[a]})});function rb(a,b,c){return null==b||\"boolean\"===typeof b||\"\"===b?\"\":c||\"number\"!==typeof b||0===b||pb.hasOwnProperty(a)&&pb[a]?(\"\"+b).trim():b+\"px\"}\nfunction sb(a,b){a=a.style;for(var c in b)if(b.hasOwnProperty(c)){var d=0===c.indexOf(\"--\"),e=rb(c,b[c],d);\"float\"===c&&(c=\"cssFloat\");d?a.setProperty(c,e):a[c]=e}}var tb=A({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});\nfunction ub(a,b){if(b){if(tb[a]&&(null!=b.children||null!=b.dangerouslySetInnerHTML))throw Error(p(137,a));if(null!=b.dangerouslySetInnerHTML){if(null!=b.children)throw Error(p(60));if(\"object\"!==typeof b.dangerouslySetInnerHTML||!(\"__html\"in b.dangerouslySetInnerHTML))throw Error(p(61));}if(null!=b.style&&\"object\"!==typeof b.style)throw Error(p(62));}}\nfunction vb(a,b){if(-1===a.indexOf(\"-\"))return\"string\"===typeof b.is;switch(a){case \"annotation-xml\":case \"color-profile\":case \"font-face\":case \"font-face-src\":case \"font-face-uri\":case \"font-face-format\":case \"font-face-name\":case \"missing-glyph\":return!1;default:return!0}}var wb=null;function xb(a){a=a.target||a.srcElement||window;a.correspondingUseElement&&(a=a.correspondingUseElement);return 3===a.nodeType?a.parentNode:a}var yb=null,zb=null,Ab=null;\nfunction Bb(a){if(a=Cb(a)){if(\"function\"!==typeof yb)throw Error(p(280));var b=a.stateNode;b&&(b=Db(b),yb(a.stateNode,a.type,b))}}function Eb(a){zb?Ab?Ab.push(a):Ab=[a]:zb=a}function Fb(){if(zb){var a=zb,b=Ab;Ab=zb=null;Bb(a);if(b)for(a=0;a>>=0;return 0===a?32:31-(pc(a)/qc|0)|0}var rc=64,sc=4194304;\nfunction tc(a){switch(a&-a){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return a&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return a&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;\ndefault:return a}}function uc(a,b){var c=a.pendingLanes;if(0===c)return 0;var d=0,e=a.suspendedLanes,f=a.pingedLanes,g=c&268435455;if(0!==g){var h=g&~e;0!==h?d=tc(h):(f&=g,0!==f&&(d=tc(f)))}else g=c&~e,0!==g?d=tc(g):0!==f&&(d=tc(f));if(0===d)return 0;if(0!==b&&b!==d&&0===(b&e)&&(e=d&-d,f=b&-b,e>=f||16===e&&0!==(f&4194240)))return b;0!==(d&4)&&(d|=c&16);b=a.entangledLanes;if(0!==b)for(a=a.entanglements,b&=d;0c;c++)b.push(a);return b}\nfunction Ac(a,b,c){a.pendingLanes|=b;536870912!==b&&(a.suspendedLanes=0,a.pingedLanes=0);a=a.eventTimes;b=31-oc(b);a[b]=c}function Bc(a,b){var c=a.pendingLanes&~b;a.pendingLanes=b;a.suspendedLanes=0;a.pingedLanes=0;a.expiredLanes&=b;a.mutableReadLanes&=b;a.entangledLanes&=b;b=a.entanglements;var d=a.eventTimes;for(a=a.expirationTimes;0=be),ee=String.fromCharCode(32),fe=!1;\nfunction ge(a,b){switch(a){case \"keyup\":return-1!==$d.indexOf(b.keyCode);case \"keydown\":return 229!==b.keyCode;case \"keypress\":case \"mousedown\":case \"focusout\":return!0;default:return!1}}function he(a){a=a.detail;return\"object\"===typeof a&&\"data\"in a?a.data:null}var ie=!1;function je(a,b){switch(a){case \"compositionend\":return he(b);case \"keypress\":if(32!==b.which)return null;fe=!0;return ee;case \"textInput\":return a=b.data,a===ee&&fe?null:a;default:return null}}\nfunction ke(a,b){if(ie)return\"compositionend\"===a||!ae&&ge(a,b)?(a=nd(),md=ld=kd=null,ie=!1,a):null;switch(a){case \"paste\":return null;case \"keypress\":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=Je(c)}}function Le(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?Le(a,b.parentNode):\"contains\"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}\nfunction Me(){for(var a=window,b=Xa();b instanceof a.HTMLIFrameElement;){try{var c=\"string\"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=Xa(a.document)}return b}function Ne(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&(\"input\"===b&&(\"text\"===a.type||\"search\"===a.type||\"tel\"===a.type||\"url\"===a.type||\"password\"===a.type)||\"textarea\"===b||\"true\"===a.contentEditable)}\nfunction Oe(a){var b=Me(),c=a.focusedElem,d=a.selectionRange;if(b!==c&&c&&c.ownerDocument&&Le(c.ownerDocument.documentElement,c)){if(null!==d&&Ne(c))if(b=d.start,a=d.end,void 0===a&&(a=b),\"selectionStart\"in c)c.selectionStart=b,c.selectionEnd=Math.min(a,c.value.length);else if(a=(b=c.ownerDocument||document)&&b.defaultView||window,a.getSelection){a=a.getSelection();var e=c.textContent.length,f=Math.min(d.start,e);d=void 0===d.end?f:Math.min(d.end,e);!a.extend&&f>d&&(e=d,d=f,f=e);e=Ke(c,f);var g=Ke(c,\nd);e&&g&&(1!==a.rangeCount||a.anchorNode!==e.node||a.anchorOffset!==e.offset||a.focusNode!==g.node||a.focusOffset!==g.offset)&&(b=b.createRange(),b.setStart(e.node,e.offset),a.removeAllRanges(),f>d?(a.addRange(b),a.extend(g.node,g.offset)):(b.setEnd(g.node,g.offset),a.addRange(b)))}b=[];for(a=c;a=a.parentNode;)1===a.nodeType&&b.push({element:a,left:a.scrollLeft,top:a.scrollTop});\"function\"===typeof c.focus&&c.focus();for(c=0;c=document.documentMode,Qe=null,Re=null,Se=null,Te=!1;\nfunction Ue(a,b,c){var d=c.window===c?c.document:9===c.nodeType?c:c.ownerDocument;Te||null==Qe||Qe!==Xa(d)||(d=Qe,\"selectionStart\"in d&&Ne(d)?d={start:d.selectionStart,end:d.selectionEnd}:(d=(d.ownerDocument&&d.ownerDocument.defaultView||window).getSelection(),d={anchorNode:d.anchorNode,anchorOffset:d.anchorOffset,focusNode:d.focusNode,focusOffset:d.focusOffset}),Se&&Ie(Se,d)||(Se=d,d=oe(Re,\"onSelect\"),0Tf||(a.current=Sf[Tf],Sf[Tf]=null,Tf--)}function G(a,b){Tf++;Sf[Tf]=a.current;a.current=b}var Vf={},H=Uf(Vf),Wf=Uf(!1),Xf=Vf;function Yf(a,b){var c=a.type.contextTypes;if(!c)return Vf;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}\nfunction Zf(a){a=a.childContextTypes;return null!==a&&void 0!==a}function $f(){E(Wf);E(H)}function ag(a,b,c){if(H.current!==Vf)throw Error(p(168));G(H,b);G(Wf,c)}function bg(a,b,c){var d=a.stateNode;b=b.childContextTypes;if(\"function\"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in b))throw Error(p(108,Ra(a)||\"Unknown\",e));return A({},c,d)}\nfunction cg(a){a=(a=a.stateNode)&&a.__reactInternalMemoizedMergedChildContext||Vf;Xf=H.current;G(H,a);G(Wf,Wf.current);return!0}function dg(a,b,c){var d=a.stateNode;if(!d)throw Error(p(169));c?(a=bg(a,b,Xf),d.__reactInternalMemoizedMergedChildContext=a,E(Wf),E(H),G(H,a)):E(Wf);G(Wf,c)}var eg=null,fg=!1,gg=!1;function hg(a){null===eg?eg=[a]:eg.push(a)}function ig(a){fg=!0;hg(a)}\nfunction jg(){if(!gg&&null!==eg){gg=!0;var a=0,b=C;try{var c=eg;for(C=1;a>=g;e-=g;rg=1<<32-oc(b)+e|c<w?(x=u,u=null):x=u.sibling;var n=r(e,u,h[w],k);if(null===n){null===u&&(u=x);break}a&&u&&null===n.alternate&&b(e,u);g=f(n,g,w);null===m?l=n:m.sibling=n;m=n;u=x}if(w===h.length)return c(e,u),I&&tg(e,w),l;if(null===u){for(;ww?(x=m,m=null):x=m.sibling;var t=r(e,m,n.value,k);if(null===t){null===m&&(m=x);break}a&&m&&null===t.alternate&&b(e,m);g=f(t,g,w);null===u?l=t:u.sibling=t;u=t;m=x}if(n.done)return c(e,\nm),I&&tg(e,w),l;if(null===m){for(;!n.done;w++,n=h.next())n=q(e,n.value,k),null!==n&&(g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);I&&tg(e,w);return l}for(m=d(e,m);!n.done;w++,n=h.next())n=y(m,e,w,n.value,k),null!==n&&(a&&null!==n.alternate&&m.delete(null===n.key?w:n.key),g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);a&&m.forEach(function(a){return b(e,a)});I&&tg(e,w);return l}function J(a,d,f,h){\"object\"===typeof f&&null!==f&&f.type===ya&&null===f.key&&(f=f.props.children);if(\"object\"===typeof f&&null!==f){switch(f.$$typeof){case va:a:{for(var k=\nf.key,l=d;null!==l;){if(l.key===k){k=f.type;if(k===ya){if(7===l.tag){c(a,l.sibling);d=e(l,f.props.children);d.return=a;a=d;break a}}else if(l.elementType===k||\"object\"===typeof k&&null!==k&&k.$$typeof===Ha&&uh(k)===l.type){c(a,l.sibling);d=e(l,f.props);d.ref=sh(a,l,f);d.return=a;a=d;break a}c(a,l);break}else b(a,l);l=l.sibling}f.type===ya?(d=Ah(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=yh(f.type,f.key,f.props,null,a.mode,h),h.ref=sh(a,d,f),h.return=a,a=h)}return g(a);case wa:a:{for(l=f.key;null!==\nd;){if(d.key===l)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[]);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=d.sibling}d=zh(f,a.mode,h);d.return=a;a=d}return g(a);case Ha:return l=f._init,J(a,d,l(f._payload),h)}if(eb(f))return n(a,d,f,h);if(Ka(f))return t(a,d,f,h);th(a,f)}return\"string\"===typeof f&&\"\"!==f||\"number\"===typeof f?(f=\"\"+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f),d.return=a,a=d):\n(c(a,d),d=xh(f,a.mode,h),d.return=a,a=d),g(a)):c(a,d)}return J}var Bh=vh(!0),Ch=vh(!1),Dh={},Eh=Uf(Dh),Fh=Uf(Dh),Gh=Uf(Dh);function Hh(a){if(a===Dh)throw Error(p(174));return a}function Ih(a,b){G(Gh,b);G(Fh,a);G(Eh,Dh);a=b.nodeType;switch(a){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:lb(null,\"\");break;default:a=8===a?b.parentNode:b,b=a.namespaceURI||null,a=a.tagName,b=lb(b,a)}E(Eh);G(Eh,b)}function Jh(){E(Eh);E(Fh);E(Gh)}\nfunction Kh(a){Hh(Gh.current);var b=Hh(Eh.current);var c=lb(b,a.type);b!==c&&(G(Fh,a),G(Eh,c))}function Lh(a){Fh.current===a&&(E(Eh),E(Fh))}var M=Uf(0);\nfunction Mh(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||\"$?\"===c.data||\"$!\"===c.data))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.flags&128))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}var Nh=[];\nfunction Oh(){for(var a=0;ac?c:4;a(!0);var d=Qh.transition;Qh.transition={};try{a(!1),b()}finally{C=c,Qh.transition=d}}function Fi(){return di().memoizedState}\nfunction Gi(a,b,c){var d=lh(a);c={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,c);else if(c=Yg(a,b,c,d),null!==c){var e=L();mh(c,a,d,e);Ji(c,b,d)}}\nfunction ri(a,b,c){var d=lh(a),e={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,e);else{var f=a.alternate;if(0===a.lanes&&(null===f||0===f.lanes)&&(f=b.lastRenderedReducer,null!==f))try{var g=b.lastRenderedState,h=f(g,c);e.hasEagerState=!0;e.eagerState=h;if(He(h,g)){var k=b.interleaved;null===k?(e.next=e,Xg(b)):(e.next=k.next,k.next=e);b.interleaved=e;return}}catch(l){}finally{}c=Yg(a,b,e,d);null!==c&&(e=L(),mh(c,a,d,e),Ji(c,b,d))}}\nfunction Hi(a){var b=a.alternate;return a===N||null!==b&&b===N}function Ii(a,b){Th=Sh=!0;var c=a.pending;null===c?b.next=b:(b.next=c.next,c.next=b);a.pending=b}function Ji(a,b,c){if(0!==(c&4194240)){var d=b.lanes;d&=a.pendingLanes;c|=d;b.lanes=c;Cc(a,c)}}\nvar ai={readContext:Vg,useCallback:Q,useContext:Q,useEffect:Q,useImperativeHandle:Q,useInsertionEffect:Q,useLayoutEffect:Q,useMemo:Q,useReducer:Q,useRef:Q,useState:Q,useDebugValue:Q,useDeferredValue:Q,useTransition:Q,useMutableSource:Q,useSyncExternalStore:Q,useId:Q,unstable_isNewReconciler:!1},Yh={readContext:Vg,useCallback:function(a,b){ci().memoizedState=[a,void 0===b?null:b];return a},useContext:Vg,useEffect:vi,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return ti(4194308,\n4,yi.bind(null,b,a),c)},useLayoutEffect:function(a,b){return ti(4194308,4,a,b)},useInsertionEffect:function(a,b){return ti(4,2,a,b)},useMemo:function(a,b){var c=ci();b=void 0===b?null:b;a=a();c.memoizedState=[a,b];return a},useReducer:function(a,b,c){var d=ci();b=void 0!==c?c(b):b;d.memoizedState=d.baseState=b;a={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:a,lastRenderedState:b};d.queue=a;a=a.dispatch=Gi.bind(null,N,a);return[d.memoizedState,a]},useRef:function(a){var b=\nci();a={current:a};return b.memoizedState=a},useState:qi,useDebugValue:Ai,useDeferredValue:function(a){return ci().memoizedState=a},useTransition:function(){var a=qi(!1),b=a[0];a=Ei.bind(null,a[1]);ci().memoizedState=a;return[b,a]},useMutableSource:function(){},useSyncExternalStore:function(a,b,c){var d=N,e=ci();if(I){if(void 0===c)throw Error(p(407));c=c()}else{c=b();if(null===R)throw Error(p(349));0!==(Rh&30)||ni(d,b,c)}e.memoizedState=c;var f={value:c,getSnapshot:b};e.queue=f;vi(ki.bind(null,d,\nf,a),[a]);d.flags|=2048;li(9,mi.bind(null,d,f,c,b),void 0,null);return c},useId:function(){var a=ci(),b=R.identifierPrefix;if(I){var c=sg;var d=rg;c=(d&~(1<<32-oc(d)-1)).toString(32)+c;b=\":\"+b+\"R\"+c;c=Uh++;0\\x3c/script>\",a=a.removeChild(a.firstChild)):\n\"string\"===typeof d.is?a=g.createElement(c,{is:d.is}):(a=g.createElement(c),\"select\"===c&&(g=a,d.multiple?g.multiple=!0:d.size&&(g.size=d.size))):a=g.createElementNS(a,c);a[Of]=b;a[Pf]=d;Aj(a,b,!1,!1);b.stateNode=a;a:{g=vb(c,d);switch(c){case \"dialog\":D(\"cancel\",a);D(\"close\",a);e=d;break;case \"iframe\":case \"object\":case \"embed\":D(\"load\",a);e=d;break;case \"video\":case \"audio\":for(e=0;eHj&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304)}else{if(!d)if(a=Mh(g),null!==a){if(b.flags|=128,d=!0,c=a.updateQueue,null!==c&&(b.updateQueue=c,b.flags|=4),Ej(f,!0),null===f.tail&&\"hidden\"===f.tailMode&&!g.alternate&&!I)return S(b),null}else 2*B()-f.renderingStartTime>Hj&&1073741824!==c&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304);f.isBackwards?(g.sibling=b.child,b.child=g):(c=f.last,null!==c?c.sibling=g:b.child=g,f.last=g)}if(null!==f.tail)return b=f.tail,f.rendering=\nb,f.tail=b.sibling,f.renderingStartTime=B(),b.sibling=null,c=M.current,G(M,d?c&1|2:c&1),b;S(b);return null;case 22:case 23:return Ij(),d=null!==b.memoizedState,null!==a&&null!==a.memoizedState!==d&&(b.flags|=8192),d&&0!==(b.mode&1)?0!==(gj&1073741824)&&(S(b),b.subtreeFlags&6&&(b.flags|=8192)):S(b),null;case 24:return null;case 25:return null}throw Error(p(156,b.tag));}\nfunction Jj(a,b){wg(b);switch(b.tag){case 1:return Zf(b.type)&&$f(),a=b.flags,a&65536?(b.flags=a&-65537|128,b):null;case 3:return Jh(),E(Wf),E(H),Oh(),a=b.flags,0!==(a&65536)&&0===(a&128)?(b.flags=a&-65537|128,b):null;case 5:return Lh(b),null;case 13:E(M);a=b.memoizedState;if(null!==a&&null!==a.dehydrated){if(null===b.alternate)throw Error(p(340));Ig()}a=b.flags;return a&65536?(b.flags=a&-65537|128,b):null;case 19:return E(M),null;case 4:return Jh(),null;case 10:return Rg(b.type._context),null;case 22:case 23:return Ij(),\nnull;case 24:return null;default:return null}}var Kj=!1,U=!1,Lj=\"function\"===typeof WeakSet?WeakSet:Set,V=null;function Mj(a,b){var c=a.ref;if(null!==c)if(\"function\"===typeof c)try{c(null)}catch(d){W(a,b,d)}else c.current=null}function Nj(a,b,c){try{c()}catch(d){W(a,b,d)}}var Oj=!1;\nfunction Pj(a,b){Cf=dd;a=Me();if(Ne(a)){if(\"selectionStart\"in a)var c={start:a.selectionStart,end:a.selectionEnd};else a:{c=(c=a.ownerDocument)&&c.defaultView||window;var d=c.getSelection&&c.getSelection();if(d&&0!==d.rangeCount){c=d.anchorNode;var e=d.anchorOffset,f=d.focusNode;d=d.focusOffset;try{c.nodeType,f.nodeType}catch(F){c=null;break a}var g=0,h=-1,k=-1,l=0,m=0,q=a,r=null;b:for(;;){for(var y;;){q!==c||0!==e&&3!==q.nodeType||(h=g+e);q!==f||0!==d&&3!==q.nodeType||(k=g+d);3===q.nodeType&&(g+=\nq.nodeValue.length);if(null===(y=q.firstChild))break;r=q;q=y}for(;;){if(q===a)break b;r===c&&++l===e&&(h=g);r===f&&++m===d&&(k=g);if(null!==(y=q.nextSibling))break;q=r;r=q.parentNode}q=y}c=-1===h||-1===k?null:{start:h,end:k}}else c=null}c=c||{start:0,end:0}}else c=null;Df={focusedElem:a,selectionRange:c};dd=!1;for(V=b;null!==V;)if(b=V,a=b.child,0!==(b.subtreeFlags&1028)&&null!==a)a.return=b,V=a;else for(;null!==V;){b=V;try{var n=b.alternate;if(0!==(b.flags&1024))switch(b.tag){case 0:case 11:case 15:break;\ncase 1:if(null!==n){var t=n.memoizedProps,J=n.memoizedState,x=b.stateNode,w=x.getSnapshotBeforeUpdate(b.elementType===b.type?t:Lg(b.type,t),J);x.__reactInternalSnapshotBeforeUpdate=w}break;case 3:var u=b.stateNode.containerInfo;1===u.nodeType?u.textContent=\"\":9===u.nodeType&&u.documentElement&&u.removeChild(u.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(p(163));}}catch(F){W(b,b.return,F)}a=b.sibling;if(null!==a){a.return=b.return;V=a;break}V=b.return}n=Oj;Oj=!1;return n}\nfunction Qj(a,b,c){var d=b.updateQueue;d=null!==d?d.lastEffect:null;if(null!==d){var e=d=d.next;do{if((e.tag&a)===a){var f=e.destroy;e.destroy=void 0;void 0!==f&&Nj(b,c,f)}e=e.next}while(e!==d)}}function Rj(a,b){b=b.updateQueue;b=null!==b?b.lastEffect:null;if(null!==b){var c=b=b.next;do{if((c.tag&a)===a){var d=c.create;c.destroy=d()}c=c.next}while(c!==b)}}function Sj(a){var b=a.ref;if(null!==b){var c=a.stateNode;switch(a.tag){case 5:a=c;break;default:a=c}\"function\"===typeof b?b(a):b.current=a}}\nfunction Tj(a){var b=a.alternate;null!==b&&(a.alternate=null,Tj(b));a.child=null;a.deletions=null;a.sibling=null;5===a.tag&&(b=a.stateNode,null!==b&&(delete b[Of],delete b[Pf],delete b[of],delete b[Qf],delete b[Rf]));a.stateNode=null;a.return=null;a.dependencies=null;a.memoizedProps=null;a.memoizedState=null;a.pendingProps=null;a.stateNode=null;a.updateQueue=null}function Uj(a){return 5===a.tag||3===a.tag||4===a.tag}\nfunction Vj(a){a:for(;;){for(;null===a.sibling;){if(null===a.return||Uj(a.return))return null;a=a.return}a.sibling.return=a.return;for(a=a.sibling;5!==a.tag&&6!==a.tag&&18!==a.tag;){if(a.flags&2)continue a;if(null===a.child||4===a.tag)continue a;else a.child.return=a,a=a.child}if(!(a.flags&2))return a.stateNode}}\nfunction Wj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?8===c.nodeType?c.parentNode.insertBefore(a,b):c.insertBefore(a,b):(8===c.nodeType?(b=c.parentNode,b.insertBefore(a,c)):(b=c,b.appendChild(a)),c=c._reactRootContainer,null!==c&&void 0!==c||null!==b.onclick||(b.onclick=Bf));else if(4!==d&&(a=a.child,null!==a))for(Wj(a,b,c),a=a.sibling;null!==a;)Wj(a,b,c),a=a.sibling}\nfunction Xj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?c.insertBefore(a,b):c.appendChild(a);else if(4!==d&&(a=a.child,null!==a))for(Xj(a,b,c),a=a.sibling;null!==a;)Xj(a,b,c),a=a.sibling}var X=null,Yj=!1;function Zj(a,b,c){for(c=c.child;null!==c;)ak(a,b,c),c=c.sibling}\nfunction ak(a,b,c){if(lc&&\"function\"===typeof lc.onCommitFiberUnmount)try{lc.onCommitFiberUnmount(kc,c)}catch(h){}switch(c.tag){case 5:U||Mj(c,b);case 6:var d=X,e=Yj;X=null;Zj(a,b,c);X=d;Yj=e;null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?a.parentNode.removeChild(c):a.removeChild(c)):X.removeChild(c.stateNode));break;case 18:null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?Kf(a.parentNode,c):1===a.nodeType&&Kf(a,c),bd(a)):Kf(X,c.stateNode));break;case 4:d=X;e=Yj;X=c.stateNode.containerInfo;Yj=!0;\nZj(a,b,c);X=d;Yj=e;break;case 0:case 11:case 14:case 15:if(!U&&(d=c.updateQueue,null!==d&&(d=d.lastEffect,null!==d))){e=d=d.next;do{var f=e,g=f.destroy;f=f.tag;void 0!==g&&(0!==(f&2)?Nj(c,b,g):0!==(f&4)&&Nj(c,b,g));e=e.next}while(e!==d)}Zj(a,b,c);break;case 1:if(!U&&(Mj(c,b),d=c.stateNode,\"function\"===typeof d.componentWillUnmount))try{d.props=c.memoizedProps,d.state=c.memoizedState,d.componentWillUnmount()}catch(h){W(c,b,h)}Zj(a,b,c);break;case 21:Zj(a,b,c);break;case 22:c.mode&1?(U=(d=U)||null!==\nc.memoizedState,Zj(a,b,c),U=d):Zj(a,b,c);break;default:Zj(a,b,c)}}function bk(a){var b=a.updateQueue;if(null!==b){a.updateQueue=null;var c=a.stateNode;null===c&&(c=a.stateNode=new Lj);b.forEach(function(b){var d=ck.bind(null,a,b);c.has(b)||(c.add(b),b.then(d,d))})}}\nfunction dk(a,b){var c=b.deletions;if(null!==c)for(var d=0;de&&(e=g);d&=~f}d=e;d=B()-d;d=(120>d?120:480>d?480:1080>d?1080:1920>d?1920:3E3>d?3E3:4320>d?4320:1960*mk(d/1960))-d;if(10a?16:a;if(null===xk)var d=!1;else{a=xk;xk=null;yk=0;if(0!==(K&6))throw Error(p(331));var e=K;K|=4;for(V=a.current;null!==V;){var f=V,g=f.child;if(0!==(V.flags&16)){var h=f.deletions;if(null!==h){for(var k=0;kB()-gk?Lk(a,0):sk|=c);Ek(a,b)}function Zk(a,b){0===b&&(0===(a.mode&1)?b=1:(b=sc,sc<<=1,0===(sc&130023424)&&(sc=4194304)));var c=L();a=Zg(a,b);null!==a&&(Ac(a,b,c),Ek(a,c))}function vj(a){var b=a.memoizedState,c=0;null!==b&&(c=b.retryLane);Zk(a,c)}\nfunction ck(a,b){var c=0;switch(a.tag){case 13:var d=a.stateNode;var e=a.memoizedState;null!==e&&(c=e.retryLane);break;case 19:d=a.stateNode;break;default:throw Error(p(314));}null!==d&&d.delete(b);Zk(a,c)}var Wk;\nWk=function(a,b,c){if(null!==a)if(a.memoizedProps!==b.pendingProps||Wf.current)Ug=!0;else{if(0===(a.lanes&c)&&0===(b.flags&128))return Ug=!1,zj(a,b,c);Ug=0!==(a.flags&131072)?!0:!1}else Ug=!1,I&&0!==(b.flags&1048576)&&ug(b,ng,b.index);b.lanes=0;switch(b.tag){case 2:var d=b.type;jj(a,b);a=b.pendingProps;var e=Yf(b,H.current);Tg(b,c);e=Xh(null,b,d,a,e,c);var f=bi();b.flags|=1;\"object\"===typeof e&&null!==e&&\"function\"===typeof e.render&&void 0===e.$$typeof?(b.tag=1,b.memoizedState=null,b.updateQueue=\nnull,Zf(d)?(f=!0,cg(b)):f=!1,b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null,ah(b),e.updater=nh,b.stateNode=e,e._reactInternals=b,rh(b,d,a,c),b=kj(null,b,d,!0,f,c)):(b.tag=0,I&&f&&vg(b),Yi(null,b,e,c),b=b.child);return b;case 16:d=b.elementType;a:{jj(a,b);a=b.pendingProps;e=d._init;d=e(d._payload);b.type=d;e=b.tag=$k(d);a=Lg(d,a);switch(e){case 0:b=dj(null,b,d,a,c);break a;case 1:b=ij(null,b,d,a,c);break a;case 11:b=Zi(null,b,d,a,c);break a;case 14:b=aj(null,b,d,Lg(d.type,a),c);break a}throw Error(p(306,\nd,\"\"));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),dj(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),ij(a,b,d,e,c);case 3:a:{lj(b);if(null===a)throw Error(p(387));d=b.pendingProps;f=b.memoizedState;e=f.element;bh(a,b);gh(b,d,null,c);var g=b.memoizedState;d=g.element;if(f.isDehydrated)if(f={element:d,isDehydrated:!1,cache:g.cache,pendingSuspenseBoundaries:g.pendingSuspenseBoundaries,transitions:g.transitions},b.updateQueue.baseState=\nf,b.memoizedState=f,b.flags&256){e=Ki(Error(p(423)),b);b=mj(a,b,d,c,e);break a}else if(d!==e){e=Ki(Error(p(424)),b);b=mj(a,b,d,c,e);break a}else for(yg=Lf(b.stateNode.containerInfo.firstChild),xg=b,I=!0,zg=null,c=Ch(b,null,d,c),b.child=c;c;)c.flags=c.flags&-3|4096,c=c.sibling;else{Ig();if(d===e){b=$i(a,b,c);break a}Yi(a,b,d,c)}b=b.child}return b;case 5:return Kh(b),null===a&&Eg(b),d=b.type,e=b.pendingProps,f=null!==a?a.memoizedProps:null,g=e.children,Ef(d,e)?g=null:null!==f&&Ef(d,f)&&(b.flags|=32),\nhj(a,b),Yi(a,b,g,c),b.child;case 6:return null===a&&Eg(b),null;case 13:return pj(a,b,c);case 4:return Ih(b,b.stateNode.containerInfo),d=b.pendingProps,null===a?b.child=Bh(b,null,d,c):Yi(a,b,d,c),b.child;case 11:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),Zi(a,b,d,e,c);case 7:return Yi(a,b,b.pendingProps,c),b.child;case 8:return Yi(a,b,b.pendingProps.children,c),b.child;case 12:return Yi(a,b,b.pendingProps.children,c),b.child;case 10:a:{d=b.type._context;e=b.pendingProps;f=b.memoizedProps;\ng=e.value;G(Mg,d._currentValue);d._currentValue=g;if(null!==f)if(He(f.value,g)){if(f.children===e.children&&!Wf.current){b=$i(a,b,c);break a}}else for(f=b.child,null!==f&&(f.return=b);null!==f;){var h=f.dependencies;if(null!==h){g=f.child;for(var k=h.firstContext;null!==k;){if(k.context===d){if(1===f.tag){k=ch(-1,c&-c);k.tag=2;var l=f.updateQueue;if(null!==l){l=l.shared;var m=l.pending;null===m?k.next=k:(k.next=m.next,m.next=k);l.pending=k}}f.lanes|=c;k=f.alternate;null!==k&&(k.lanes|=c);Sg(f.return,\nc,b);h.lanes|=c;break}k=k.next}}else if(10===f.tag)g=f.type===b.type?null:f.child;else if(18===f.tag){g=f.return;if(null===g)throw Error(p(341));g.lanes|=c;h=g.alternate;null!==h&&(h.lanes|=c);Sg(g,c,b);g=f.sibling}else g=f.child;if(null!==g)g.return=f;else for(g=f;null!==g;){if(g===b){g=null;break}f=g.sibling;if(null!==f){f.return=g.return;g=f;break}g=g.return}f=g}Yi(a,b,e.children,c);b=b.child}return b;case 9:return e=b.type,d=b.pendingProps.children,Tg(b,c),e=Vg(e),d=d(e),b.flags|=1,Yi(a,b,d,c),\nb.child;case 14:return d=b.type,e=Lg(d,b.pendingProps),e=Lg(d.type,e),aj(a,b,d,e,c);case 15:return cj(a,b,b.type,b.pendingProps,c);case 17:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),jj(a,b),b.tag=1,Zf(d)?(a=!0,cg(b)):a=!1,Tg(b,c),ph(b,d,e),rh(b,d,e,c),kj(null,b,d,!0,a,c);case 19:return yj(a,b,c);case 22:return ej(a,b,c)}throw Error(p(156,b.tag));};function Gk(a,b){return ac(a,b)}\nfunction al(a,b,c,d){this.tag=a;this.key=c;this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null;this.index=0;this.ref=null;this.pendingProps=b;this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null;this.mode=d;this.subtreeFlags=this.flags=0;this.deletions=null;this.childLanes=this.lanes=0;this.alternate=null}function Bg(a,b,c,d){return new al(a,b,c,d)}function bj(a){a=a.prototype;return!(!a||!a.isReactComponent)}\nfunction $k(a){if(\"function\"===typeof a)return bj(a)?1:0;if(void 0!==a&&null!==a){a=a.$$typeof;if(a===Da)return 11;if(a===Ga)return 14}return 2}\nfunction wh(a,b){var c=a.alternate;null===c?(c=Bg(a.tag,b,a.key,a.mode),c.elementType=a.elementType,c.type=a.type,c.stateNode=a.stateNode,c.alternate=a,a.alternate=c):(c.pendingProps=b,c.type=a.type,c.flags=0,c.subtreeFlags=0,c.deletions=null);c.flags=a.flags&14680064;c.childLanes=a.childLanes;c.lanes=a.lanes;c.child=a.child;c.memoizedProps=a.memoizedProps;c.memoizedState=a.memoizedState;c.updateQueue=a.updateQueue;b=a.dependencies;c.dependencies=null===b?null:{lanes:b.lanes,firstContext:b.firstContext};\nc.sibling=a.sibling;c.index=a.index;c.ref=a.ref;return c}\nfunction yh(a,b,c,d,e,f){var g=2;d=a;if(\"function\"===typeof a)bj(a)&&(g=1);else if(\"string\"===typeof a)g=5;else a:switch(a){case ya:return Ah(c.children,e,f,b);case za:g=8;e|=8;break;case Aa:return a=Bg(12,c,b,e|2),a.elementType=Aa,a.lanes=f,a;case Ea:return a=Bg(13,c,b,e),a.elementType=Ea,a.lanes=f,a;case Fa:return a=Bg(19,c,b,e),a.elementType=Fa,a.lanes=f,a;case Ia:return qj(c,e,f,b);default:if(\"object\"===typeof a&&null!==a)switch(a.$$typeof){case Ba:g=10;break a;case Ca:g=9;break a;case Da:g=11;\nbreak a;case Ga:g=14;break a;case Ha:g=16;d=null;break a}throw Error(p(130,null==a?a:typeof a,\"\"));}b=Bg(g,c,b,e);b.elementType=a;b.type=d;b.lanes=f;return b}function Ah(a,b,c,d){a=Bg(7,a,d,b);a.lanes=c;return a}function qj(a,b,c,d){a=Bg(22,a,d,b);a.elementType=Ia;a.lanes=c;a.stateNode={isHidden:!1};return a}function xh(a,b,c){a=Bg(6,a,null,b);a.lanes=c;return a}\nfunction zh(a,b,c){b=Bg(4,null!==a.children?a.children:[],a.key,b);b.lanes=c;b.stateNode={containerInfo:a.containerInfo,pendingChildren:null,implementation:a.implementation};return b}\nfunction bl(a,b,c,d,e){this.tag=b;this.containerInfo=a;this.finishedWork=this.pingCache=this.current=this.pendingChildren=null;this.timeoutHandle=-1;this.callbackNode=this.pendingContext=this.context=null;this.callbackPriority=0;this.eventTimes=zc(0);this.expirationTimes=zc(-1);this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0;this.entanglements=zc(0);this.identifierPrefix=d;this.onRecoverableError=e;this.mutableSourceEagerHydrationData=\nnull}function cl(a,b,c,d,e,f,g,h,k){a=new bl(a,b,c,h,k);1===b?(b=1,!0===f&&(b|=8)):b=0;f=Bg(3,null,null,b);a.current=f;f.stateNode=a;f.memoizedState={element:d,isDehydrated:c,cache:null,transitions:null,pendingSuspenseBoundaries:null};ah(f);return a}function dl(a,b,c){var d=3= 2) {\n rest = rest.slice(2);\n }\n } else if (isSpecial(protocol)) {\n rest = match[4];\n } else if (protocol) {\n if (forwardSlashes) {\n rest = rest.slice(2);\n }\n } else if (slashesCount >= 2 && isSpecial(location.protocol)) {\n rest = match[4];\n }\n\n return {\n protocol: protocol,\n slashes: forwardSlashes || isSpecial(protocol),\n slashesCount: slashesCount,\n rest: rest\n };\n}\n\n/**\n * Resolve a relative URL pathname against a base URL pathname.\n *\n * @param {String} relative Pathname of the relative URL.\n * @param {String} base Pathname of the base URL.\n * @return {String} Resolved pathname.\n * @private\n */\nfunction resolve(relative, base) {\n if (relative === '') return base;\n\n var path = (base || '/').split('/').slice(0, -1).concat(relative.split('/'))\n , i = path.length\n , last = path[i - 1]\n , unshift = false\n , up = 0;\n\n while (i--) {\n if (path[i] === '.') {\n path.splice(i, 1);\n } else if (path[i] === '..') {\n path.splice(i, 1);\n up++;\n } else if (up) {\n if (i === 0) unshift = true;\n path.splice(i, 1);\n up--;\n }\n }\n\n if (unshift) path.unshift('');\n if (last === '.' || last === '..') path.push('');\n\n return path.join('/');\n}\n\n/**\n * The actual URL instance. Instead of returning an object we've opted-in to\n * create an actual constructor as it's much more memory efficient and\n * faster and it pleases my OCD.\n *\n * It is worth noting that we should not use `URL` as class name to prevent\n * clashes with the global URL instance that got introduced in browsers.\n *\n * @constructor\n * @param {String} address URL we want to parse.\n * @param {Object|String} [location] Location defaults for relative paths.\n * @param {Boolean|Function} [parser] Parser for the query string.\n * @private\n */\nfunction Url(address, location, parser) {\n address = trimLeft(address);\n address = address.replace(CRHTLF, '');\n\n if (!(this instanceof Url)) {\n return new Url(address, location, parser);\n }\n\n var relative, extracted, parse, instruction, index, key\n , instructions = rules.slice()\n , type = typeof location\n , url = this\n , i = 0;\n\n //\n // The following if statements allows this module two have compatibility with\n // 2 different API:\n //\n // 1. Node.js's `url.parse` api which accepts a URL, boolean as arguments\n // where the boolean indicates that the query string should also be parsed.\n //\n // 2. The `URL` interface of the browser which accepts a URL, object as\n // arguments. The supplied object will be used as default values / fall-back\n // for relative paths.\n //\n if ('object' !== type && 'string' !== type) {\n parser = location;\n location = null;\n }\n\n if (parser && 'function' !== typeof parser) parser = qs.parse;\n\n location = lolcation(location);\n\n //\n // Extract protocol information before running the instructions.\n //\n extracted = extractProtocol(address || '', location);\n relative = !extracted.protocol && !extracted.slashes;\n url.slashes = extracted.slashes || relative && location.slashes;\n url.protocol = extracted.protocol || location.protocol || '';\n address = extracted.rest;\n\n //\n // When the authority component is absent the URL starts with a path\n // component.\n //\n if (\n extracted.protocol === 'file:' && (\n extracted.slashesCount !== 2 || windowsDriveLetter.test(address)) ||\n (!extracted.slashes &&\n (extracted.protocol ||\n extracted.slashesCount < 2 ||\n !isSpecial(url.protocol)))\n ) {\n instructions[3] = [/(.*)/, 'pathname'];\n }\n\n for (; i < instructions.length; i++) {\n instruction = instructions[i];\n\n if (typeof instruction === 'function') {\n address = instruction(address, url);\n continue;\n }\n\n parse = instruction[0];\n key = instruction[1];\n\n if (parse !== parse) {\n url[key] = address;\n } else if ('string' === typeof parse) {\n index = parse === '@'\n ? address.lastIndexOf(parse)\n : address.indexOf(parse);\n\n if (~index) {\n if ('number' === typeof instruction[2]) {\n url[key] = address.slice(0, index);\n address = address.slice(index + instruction[2]);\n } else {\n url[key] = address.slice(index);\n address = address.slice(0, index);\n }\n }\n } else if ((index = parse.exec(address))) {\n url[key] = index[1];\n address = address.slice(0, index.index);\n }\n\n url[key] = url[key] || (\n relative && instruction[3] ? location[key] || '' : ''\n );\n\n //\n // Hostname, host and protocol should be lowercased so they can be used to\n // create a proper `origin`.\n //\n if (instruction[4]) url[key] = url[key].toLowerCase();\n }\n\n //\n // Also parse the supplied query string in to an object. If we're supplied\n // with a custom parser as function use that instead of the default build-in\n // parser.\n //\n if (parser) url.query = parser(url.query);\n\n //\n // If the URL is relative, resolve the pathname against the base URL.\n //\n if (\n relative\n && location.slashes\n && url.pathname.charAt(0) !== '/'\n && (url.pathname !== '' || location.pathname !== '')\n ) {\n url.pathname = resolve(url.pathname, location.pathname);\n }\n\n //\n // Default to a / for pathname if none exists. This normalizes the URL\n // to always have a /\n //\n if (url.pathname.charAt(0) !== '/' && isSpecial(url.protocol)) {\n url.pathname = '/' + url.pathname;\n }\n\n //\n // We should not add port numbers if they are already the default port number\n // for a given protocol. As the host also contains the port number we're going\n // override it with the hostname which contains no port number.\n //\n if (!required(url.port, url.protocol)) {\n url.host = url.hostname;\n url.port = '';\n }\n\n //\n // Parse down the `auth` for the username and password.\n //\n url.username = url.password = '';\n\n if (url.auth) {\n index = url.auth.indexOf(':');\n\n if (~index) {\n url.username = url.auth.slice(0, index);\n url.username = encodeURIComponent(decodeURIComponent(url.username));\n\n url.password = url.auth.slice(index + 1);\n url.password = encodeURIComponent(decodeURIComponent(url.password))\n } else {\n url.username = encodeURIComponent(decodeURIComponent(url.auth));\n }\n\n url.auth = url.password ? url.username +':'+ url.password : url.username;\n }\n\n url.origin = url.protocol !== 'file:' && isSpecial(url.protocol) && url.host\n ? url.protocol +'//'+ url.host\n : 'null';\n\n //\n // The href is just the compiled result.\n //\n url.href = url.toString();\n}\n\n/**\n * This is convenience method for changing properties in the URL instance to\n * insure that they all propagate correctly.\n *\n * @param {String} part Property we need to adjust.\n * @param {Mixed} value The newly assigned value.\n * @param {Boolean|Function} fn When setting the query, it will be the function\n * used to parse the query.\n * When setting the protocol, double slash will be\n * removed from the final url if it is true.\n * @returns {URL} URL instance for chaining.\n * @public\n */\nfunction set(part, value, fn) {\n var url = this;\n\n switch (part) {\n case 'query':\n if ('string' === typeof value && value.length) {\n value = (fn || qs.parse)(value);\n }\n\n url[part] = value;\n break;\n\n case 'port':\n url[part] = value;\n\n if (!required(value, url.protocol)) {\n url.host = url.hostname;\n url[part] = '';\n } else if (value) {\n url.host = url.hostname +':'+ value;\n }\n\n break;\n\n case 'hostname':\n url[part] = value;\n\n if (url.port) value += ':'+ url.port;\n url.host = value;\n break;\n\n case 'host':\n url[part] = value;\n\n if (port.test(value)) {\n value = value.split(':');\n url.port = value.pop();\n url.hostname = value.join(':');\n } else {\n url.hostname = value;\n url.port = '';\n }\n\n break;\n\n case 'protocol':\n url.protocol = value.toLowerCase();\n url.slashes = !fn;\n break;\n\n case 'pathname':\n case 'hash':\n if (value) {\n var char = part === 'pathname' ? '/' : '#';\n url[part] = value.charAt(0) !== char ? char + value : value;\n } else {\n url[part] = value;\n }\n break;\n\n case 'username':\n case 'password':\n url[part] = encodeURIComponent(value);\n break;\n\n case 'auth':\n var index = value.indexOf(':');\n\n if (~index) {\n url.username = value.slice(0, index);\n url.username = encodeURIComponent(decodeURIComponent(url.username));\n\n url.password = value.slice(index + 1);\n url.password = encodeURIComponent(decodeURIComponent(url.password));\n } else {\n url.username = encodeURIComponent(decodeURIComponent(value));\n }\n }\n\n for (var i = 0; i < rules.length; i++) {\n var ins = rules[i];\n\n if (ins[4]) url[ins[1]] = url[ins[1]].toLowerCase();\n }\n\n url.auth = url.password ? url.username +':'+ url.password : url.username;\n\n url.origin = url.protocol !== 'file:' && isSpecial(url.protocol) && url.host\n ? url.protocol +'//'+ url.host\n : 'null';\n\n url.href = url.toString();\n\n return url;\n}\n\n/**\n * Transform the properties back in to a valid and full URL string.\n *\n * @param {Function} stringify Optional query stringify function.\n * @returns {String} Compiled version of the URL.\n * @public\n */\nfunction toString(stringify) {\n if (!stringify || 'function' !== typeof stringify) stringify = qs.stringify;\n\n var query\n , url = this\n , host = url.host\n , protocol = url.protocol;\n\n if (protocol && protocol.charAt(protocol.length - 1) !== ':') protocol += ':';\n\n var result =\n protocol +\n ((url.protocol && url.slashes) || isSpecial(url.protocol) ? '//' : '');\n\n if (url.username) {\n result += url.username;\n if (url.password) result += ':'+ url.password;\n result += '@';\n } else if (url.password) {\n result += ':'+ url.password;\n result += '@';\n } else if (\n url.protocol !== 'file:' &&\n isSpecial(url.protocol) &&\n !host &&\n url.pathname !== '/'\n ) {\n //\n // Add back the empty userinfo, otherwise the original invalid URL\n // might be transformed into a valid one with `url.pathname` as host.\n //\n result += '@';\n }\n\n //\n // Trailing colon is removed from `url.host` when it is parsed. If it still\n // ends with a colon, then add back the trailing colon that was removed. This\n // prevents an invalid URL from being transformed into a valid one.\n //\n if (host[host.length - 1] === ':' || (port.test(url.hostname) && !url.port)) {\n host += ':';\n }\n\n result += host + url.pathname;\n\n query = 'object' === typeof url.query ? stringify(url.query) : url.query;\n if (query) result += '?' !== query.charAt(0) ? '?'+ query : query;\n\n if (url.hash) result += url.hash;\n\n return result;\n}\n\nUrl.prototype = { set: set, toString: toString };\n\n//\n// Expose the URL parser and some additional properties that might be useful for\n// others or testing.\n//\nUrl.extractProtocol = extractProtocol;\nUrl.location = lolcation;\nUrl.trimLeft = trimLeft;\nUrl.qs = qs;\n\nmodule.exports = Url;\n", "(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"zlib\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"dicom-parser\", [\"zlib\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"dicom-parser\"] = factory(require(\"zlib\"));\n\telse\n\t\troot[\"dicomParser\"] = factory(root[\"zlib\"]);\n})(this, function(__WEBPACK_EXTERNAL_MODULE__0__) {\nreturn ", "module.exports = __WEBPACK_EXTERNAL_MODULE__0__;", "const stringVrs = {\n AE: true,\n AS: true,\n AT: false,\n CS: true,\n DA: true,\n DS: true,\n DT: true,\n FL: false,\n FD: false,\n IS: true,\n LO: true,\n LT: true,\n OB: false,\n OD: false,\n OF: false,\n OW: false,\n PN: true,\n SH: true,\n SL: false,\n SQ: false,\n SS: false,\n ST: true,\n TM: true,\n UI: true,\n UL: false,\n UN: undefined, // dunno\n UR: true,\n US: false,\n UT: true\n};\n\n/**\n * Tests to see if vr is a string or not.\n * @param vr\n * @returns true if string, false it not string, undefined if unknown vr or UN type\n */\nconst isStringVr = (vr) => stringVrs[vr];\n\n/**\n * Tests to see if a given tag in the format xggggeeee is a private tag or not\n * @param tag\n * @returns {boolean}\n * @throws error if fourth character cannot be parsed\n */\nconst isPrivateTag = (tag) => {\n const lastGroupDigit = parseInt(tag[4], 16);\n if (isNaN(lastGroupDigit)) {\n throw 'dicomParser.isPrivateTag: cannot parse last character of group';\n }\n const groupIsOdd = (lastGroupDigit % 2) === 1;\n\n return groupIsOdd;\n};\n\n/**\n * Parses a PN formatted string into a javascript object with properties for givenName, familyName, middleName, prefix and suffix\n * @param personName a string in the PN VR format\n * @param index\n * @returns {*} javascript object with properties for givenName, familyName, middleName, prefix and suffix or undefined if no element or data\n */\nconst parsePN = (personName) => {\n if (personName === undefined) {\n return undefined;\n }\n const stringValues = personName.split('^');\n\n\n return {\n familyName: stringValues[0],\n givenName: stringValues[1],\n middleName: stringValues[2],\n prefix: stringValues[3],\n suffix: stringValues[4]\n };\n};\n\nexport {\n isStringVr,\n isPrivateTag,\n parsePN\n};\n", "/**\n * Parses a TM formatted string into a javascript object with properties for hours, minutes, seconds and fractionalSeconds\n * @param {string} time - a string in the TM VR format\n * @param {boolean} [validate] - true if an exception should be thrown if the date is invalid\n * @returns {*} javascript object with properties for hours, minutes, seconds and fractionalSeconds or undefined if no element or data. Missing fields are set to undefined\n */\nexport default function parseTM (time, validate) {\n if (time.length >= 2) { // must at least have HH\n // 0123456789\n // HHMMSS.FFFFFF\n const hh = parseInt(time.substring(0, 2), 10);\n const mm = time.length >= 4 ? parseInt(time.substring(2, 4), 10) : undefined;\n const ss = time.length >= 6 ? parseInt(time.substring(4, 6), 10) : undefined;\n\n const fractionalStr = time.length >= 8 ? time.substring(7, 13) : undefined;\n const ffffff = fractionalStr ? (parseInt(fractionalStr, 10) * Math.pow(10, 6 - fractionalStr.length)) : undefined;\n\n if (validate) {\n if ((isNaN(hh)) ||\n (mm !== undefined && isNaN(mm)) ||\n (ss !== undefined && isNaN(ss)) ||\n (ffffff !== undefined && isNaN(ffffff)) ||\n (hh < 0 || hh > 23) ||\n (mm && (mm < 0 || mm > 59)) ||\n (ss && (ss < 0 || ss > 59)) ||\n (ffffff && (ffffff < 0 || ffffff > 999999))) {\n throw `invalid TM '${time}'`;\n }\n }\n\n return {\n hours: hh,\n minutes: mm,\n seconds: ss,\n fractionalSeconds: ffffff\n };\n }\n\n if (validate) {\n throw `invalid TM '${time}'`;\n }\n\n return undefined;\n}\n", "// algorithm based on http://stackoverflow.com/questions/1433030/validate-number-of-days-in-a-given-month\nfunction daysInMonth (m, y) { // m is 0 indexed: 0-11\n switch (m) {\n case 2 :\n return (y % 4 == 0 && y % 100) || y % 400 == 0 ? 29 : 28;\n case 9 : case 4 : case 6 : case 11 :\n return 30;\n default :\n return 31;\n }\n}\n\nfunction isValidDate (d, m, y) {\n // make year is a number\n if (isNaN(y)) {\n return false;\n }\n\n return m > 0 && m <= 12 && d > 0 && d <= daysInMonth(m, y);\n}\n\n\n/**\n * Parses a DA formatted string into a Javascript object\n * @param {string} date a string in the DA VR format\n * @param {boolean} [validate] - true if an exception should be thrown if the date is invalid\n * @returns {*} Javascript object with properties year, month and day or undefined if not present or not 8 bytes long\n */\nexport default function parseDA (date, validate) {\n if (date && date.length === 8) {\n var yyyy = parseInt(date.substring(0, 4), 10);\n var mm = parseInt(date.substring(4, 6), 10);\n var dd = parseInt(date.substring(6, 8), 10);\n\n if (validate) {\n if (isValidDate(dd, mm, yyyy) !== true) {\n throw `invalid DA '${date}'`;\n }\n }\n\n return {\n year: yyyy,\n month: mm,\n day: dd\n };\n }\n if (validate) {\n throw `invalid DA '${date}'`;\n }\n\n return undefined;\n}\n", "import * as util from './util.js';\n\n/**\n * Converts an explicit VR element to a string or undefined if it is not possible to convert.\n * Throws an error if an implicit element is supplied\n * @param dataSet\n * @param element\n * @returns {*}\n */\nexport default function explicitElementToString (dataSet, element) {\n if (dataSet === undefined || element === undefined) {\n throw 'dicomParser.explicitElementToString: missing required parameters';\n }\n if (element.vr === undefined) {\n throw 'dicomParser.explicitElementToString: cannot convert implicit element to string';\n }\n var vr = element.vr;\n var tag = element.tag;\n\n var textResult;\n\n function multiElementToString (numItems, func) {\n var result = '';\n\n for (var i = 0; i < numItems; i++) {\n if (i !== 0) {\n result += '/';\n }\n result += func.call(dataSet, tag, i).toString();\n }\n\n return result;\n }\n\n if (util.isStringVr(vr) === true) {\n textResult = dataSet.string(tag);\n } else if (vr === 'AT') {\n var num = dataSet.uint32(tag);\n\n if (num === undefined) {\n return undefined;\n }\n if (num < 0) {\n num = 0xFFFFFFFF + num + 1;\n }\n\n return `x${num.toString(16).toUpperCase()}`;\n } else if (vr === 'US') {\n textResult = multiElementToString(element.length / 2, dataSet.uint16);\n } else if (vr === 'SS') {\n textResult = multiElementToString(element.length / 2, dataSet.int16);\n } else if (vr === 'UL') {\n textResult = multiElementToString(element.length / 4, dataSet.uint32);\n } else if (vr === 'SL') {\n textResult = multiElementToString(element.length / 4, dataSet.int32);\n } else if (vr === 'FD') {\n textResult = multiElementToString(element.length / 8, dataSet.double);\n } else if (vr === 'FL') {\n textResult = multiElementToString(element.length / 4, dataSet.float);\n }\n\n return textResult;\n}\n", "import explicitElementToString from './elementToString.js';\nimport * as util from './util.js';\n\n/**\n * converts an explicit dataSet to a javascript object\n * @param dataSet\n * @param options\n */\nexport default function explicitDataSetToJS (dataSet, options) {\n if (dataSet === undefined) {\n throw 'dicomParser.explicitDataSetToJS: missing required parameter dataSet';\n }\n\n options = options || {\n omitPrivateAttibutes: true, // true if private elements should be omitted\n maxElementLength: 128 // maximum element length to try and convert to string format\n };\n\n var result = {\n\n };\n\n for (var tag in dataSet.elements) {\n var element = dataSet.elements[tag];\n\n // skip this element if it a private element and our options specify that we should\n if (options.omitPrivateAttibutes === true && util.isPrivateTag(tag)) {\n continue;\n }\n\n if (element.items) {\n // handle sequences\n var sequenceItems = [];\n\n for (var i = 0; i < element.items.length; i++) {\n sequenceItems.push(explicitDataSetToJS(element.items[i].dataSet, options));\n }\n result[tag] = sequenceItems;\n } else {\n var asString;\n\n asString = undefined;\n if (element.length < options.maxElementLength) {\n asString = explicitElementToString(dataSet, element);\n }\n\n if (asString !== undefined) {\n result[tag] = asString;\n } else {\n result[tag] = {\n dataOffset: element.dataOffset,\n length: element.length\n };\n }\n }\n }\n\n return result;\n}\n", "// Each JPEG image has an end of image marker 0xFFD9\nfunction isEndOfImageMarker (dataSet, position) {\n return (dataSet.byteArray[position] === 0xFF &&\n dataSet.byteArray[position + 1] === 0xD9);\n}\n\nfunction isFragmentEndOfImage (dataSet, pixelDataElement, fragmentIndex) {\n var fragment = pixelDataElement.fragments[fragmentIndex];\n // Need to check the last two bytes and the last three bytes for marker since odd length\n // fragments are zero padded\n\n if (isEndOfImageMarker(dataSet, fragment.position + fragment.length - 2) ||\n isEndOfImageMarker(dataSet, fragment.position + fragment.length - 3)) {\n return true;\n }\n\n return false;\n}\n\nfunction findLastImageFrameFragmentIndex (dataSet, pixelDataElement, startFragment) {\n for (var fragmentIndex = startFragment; fragmentIndex < pixelDataElement.fragments.length; fragmentIndex++) {\n if (isFragmentEndOfImage(dataSet, pixelDataElement, fragmentIndex)) {\n return fragmentIndex;\n }\n }\n}\n\n/**\n * Creates a basic offset table by scanning fragments for JPEG start of image and end Of Image markers\n * @param {object} dataSet - the parsed dicom dataset\n * @param {object} pixelDataElement - the pixel data element\n * @param [fragments] - optional array of objects describing each fragment (offset, position, length)\n * @returns {Array} basic offset table (array of offsets to beginning of each frame)\n */\nexport default function createJPEGBasicOffsetTable (dataSet, pixelDataElement, fragments) {\n // Validate parameters\n if (dataSet === undefined) {\n throw 'dicomParser.createJPEGBasicOffsetTable: missing required parameter dataSet';\n }\n if (pixelDataElement === undefined) {\n throw 'dicomParser.createJPEGBasicOffsetTable: missing required parameter pixelDataElement';\n }\n if (pixelDataElement.tag !== 'x7fe00010') {\n throw 'dicomParser.createJPEGBasicOffsetTable: parameter \\'pixelDataElement\\' refers to non pixel data tag (expected tag = x7fe00010\\'';\n }\n if (pixelDataElement.encapsulatedPixelData !== true) {\n throw 'dicomParser.createJPEGBasicOffsetTable: parameter \\'pixelDataElement\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (pixelDataElement.hadUndefinedLength !== true) {\n throw 'dicomParser.createJPEGBasicOffsetTable: parameter \\'pixelDataElement\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (pixelDataElement.basicOffsetTable === undefined) {\n throw 'dicomParser.createJPEGBasicOffsetTable: parameter \\'pixelDataElement\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (pixelDataElement.fragments === undefined) {\n throw 'dicomParser.createJPEGBasicOffsetTable: parameter \\'pixelDataElement\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (pixelDataElement.fragments.length <= 0) {\n throw 'dicomParser.createJPEGBasicOffsetTable: parameter \\'pixelDataElement\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (fragments && fragments.length <= 0) {\n throw 'dicomParser.createJPEGBasicOffsetTable: parameter \\'fragments\\' must not be zero length';\n }\n\n // Default values\n fragments = fragments || pixelDataElement.fragments;\n\n var basicOffsetTable = [];\n\n var startFragmentIndex = 0;\n\n while (true) {\n // Add the offset for the start fragment\n basicOffsetTable.push(pixelDataElement.fragments[startFragmentIndex].offset);\n var endFragmentIndex = findLastImageFrameFragmentIndex(dataSet, pixelDataElement, startFragmentIndex);\n\n if (endFragmentIndex === undefined || endFragmentIndex === pixelDataElement.fragments.length - 1) {\n return basicOffsetTable;\n }\n startFragmentIndex = endFragmentIndex + 1;\n }\n}\n", "/**\n * Internal helper functions for parsing DICOM elements\n */\n\n/**\n * Reads a tag (group number and element number) from a byteStream\n * @param byteStream the byte stream to read from\n * @returns {string} the tag in format xggggeeee where gggg is the lowercase hex value of the group number\n * and eeee is the lower case hex value of the element number\n */\nexport default function readTag (byteStream) {\n if (byteStream === undefined) {\n throw 'dicomParser.readTag: missing required parameter \\'byteStream\\'';\n }\n\n const groupNumber = byteStream.readUint16() * 256 * 256;\n const elementNumber = byteStream.readUint16();\n const tag = `x${(`00000000${(groupNumber + elementNumber).toString(16)}`).substr(-8)}`;\n\n return tag;\n}\n", "import readTag from './readTag.js';\n\n/**\n * Internal helper functions for parsing DICOM elements\n */\n\n/**\n * Reads an encapsulated pixel data element and adds an array of fragments to the element\n * containing the offset and length of each fragment and any offsets from the basic offset\n * table\n * @param byteStream\n * @param element\n */\nexport default function findEndOfEncapsulatedElement (byteStream, element, warnings) {\n if (byteStream === undefined) {\n throw 'dicomParser.findEndOfEncapsulatedElement: missing required parameter \\'byteStream\\'';\n }\n\n if (element === undefined) {\n throw 'dicomParser.findEndOfEncapsulatedElement: missing required parameter \\'element\\'';\n }\n\n element.encapsulatedPixelData = true;\n element.basicOffsetTable = [];\n element.fragments = [];\n\n const basicOffsetTableItemTag = readTag(byteStream);\n\n if (basicOffsetTableItemTag !== 'xfffee000') {\n throw 'dicomParser.findEndOfEncapsulatedElement: basic offset table not found';\n }\n\n const basicOffsetTableItemlength = byteStream.readUint32();\n const numFragments = basicOffsetTableItemlength / 4;\n\n // Bad idea to not include the basic offset table, as it means writing the data out is inconsistent with reading it\n // but leave this for now. To fix later.\n for (let i = 0; i < numFragments; i++) {\n const offset = byteStream.readUint32();\n\n element.basicOffsetTable.push(offset);\n }\n\n const baseOffset = byteStream.position;\n\n while (byteStream.position < byteStream.byteArray.length) {\n const tag = readTag(byteStream);\n let length = byteStream.readUint32();\n\n if (tag === 'xfffee0dd') {\n byteStream.seek(length);\n element.length = byteStream.position - element.dataOffset;\n\n return;\n } else if (tag === 'xfffee000') {\n element.fragments.push({\n offset: byteStream.position - baseOffset - 8,\n position: byteStream.position,\n length\n });\n } else {\n if (warnings) {\n warnings.push(`unexpected tag ${tag} while searching for end of pixel data element with undefined length`);\n }\n\n if (length > byteStream.byteArray.length - byteStream.position) {\n // fix length\n length = byteStream.byteArray.length - byteStream.position;\n }\n\n element.fragments.push({\n offset: byteStream.position - baseOffset - 8,\n position: byteStream.position,\n length\n });\n\n byteStream.seek(length);\n element.length = byteStream.position - element.dataOffset;\n\n return;\n }\n\n byteStream.seek(length);\n }\n\n if (warnings) {\n warnings.push(`pixel data element ${element.tag} missing sequence delimiter tag xfffee0dd`);\n }\n}\n", "/**\n * Internal helper functions for parsing DICOM elements\n */\n\n/**\n * reads from the byte stream until it finds the magic number for the Sequence Delimitation\n * Item item and then sets the length of the element\n * @param byteStream\n * @param element\n */\nexport default function findAndSetUNElementLength (byteStream, element) {\n if (byteStream === undefined) {\n throw 'dicomParser.findAndSetUNElementLength: missing required parameter \\'byteStream\\'';\n }\n\n // group, element, length\n const itemDelimitationItemLength = 8;\n const maxPosition = byteStream.byteArray.length - itemDelimitationItemLength;\n\n while (byteStream.position <= maxPosition) {\n const groupNumber = byteStream.readUint16();\n\n if (groupNumber === 0xfffe) {\n const elementNumber = byteStream.readUint16();\n\n if (elementNumber === 0xe0dd) {\n // NOTE: It would be better to also check for the length to be 0 as part of the check above\n // but we will just log a warning for now\n const itemDelimiterLength = byteStream.readUint32();\n\n if (itemDelimiterLength !== 0) {\n byteStream.warnings(`encountered non zero length following item delimiter at position ${byteStream.position - 4} while reading element of undefined length with tag ${element.tag}`);\n }\n element.length = byteStream.position - element.dataOffset;\n\n return;\n }\n }\n }\n\n // No item delimitation item - silently set the length to the end\n // of the buffer and set the position past the end of the buffer\n element.length = byteStream.byteArray.length - element.dataOffset;\n byteStream.seek(byteStream.byteArray.length - byteStream.position);\n}\n", "/**\n * Internal helper functions common to parsing byte arrays of any type\n */\n\n/**\n * Reads a string of 8-bit characters from an array of bytes and advances\n * the position by length bytes. A null terminator will end the string\n * but will not affect advancement of the position. Trailing and leading\n * spaces are preserved (not trimmed)\n * @param byteArray the byteArray to read from\n * @param position the position in the byte array to read from\n * @param length the maximum number of bytes to parse\n * @returns {string} the parsed string\n * @throws error if buffer overread would occur\n * @access private\n */\nexport function readFixedString (byteArray, position, length) {\n if (length < 0) {\n throw 'dicomParser.readFixedString - length cannot be less than 0';\n }\n\n if (position + length > byteArray.length) {\n throw 'dicomParser.readFixedString: attempt to read past end of buffer';\n }\n\n var result = '';\n var byte;\n\n for (var i = 0; i < length; i++) {\n byte = byteArray[position + i];\n if (byte === 0) {\n position += length;\n\n return result;\n }\n result += String.fromCharCode(byte);\n }\n\n return result;\n}\n", "import { readFixedString } from './byteArrayParser.js';\n\n/**\n *\n * The DataSet class encapsulates a collection of DICOM Elements and provides various functions\n * to access the data in those elements\n *\n * Rules for handling padded spaces:\n * DS = Strip leading and trailing spaces\n * DT = Strip trailing spaces\n * IS = Strip leading and trailing spaces\n * PN = Strip trailing spaces\n * TM = Strip trailing spaces\n * AE = Strip leading and trailing spaces\n * CS = Strip leading and trailing spaces\n * SH = Strip leading and trailing spaces\n * LO = Strip leading and trailing spaces\n * LT = Strip trailing spaces\n * ST = Strip trailing spaces\n * UT = Strip trailing spaces\n *\n */\n\nfunction getByteArrayParser (element, defaultParser) {\n return (element.parser !== undefined ? element.parser : defaultParser);\n}\n\n/**\n * Constructs a new DataSet given byteArray and collection of elements\n * @param byteArrayParser\n * @param byteArray\n * @param elements\n * @constructor\n */\nexport default class DataSet {\n constructor (byteArrayParser, byteArray, elements) {\n this.byteArrayParser = byteArrayParser;\n this.byteArray = byteArray;\n this.elements = elements;\n }\n\n /**\n * Finds the element for tag and returns an unsigned int 16 if it exists and has data\n * @param tag The DICOM tag in the format xGGGGEEEE\n * @param index the index of the value in a multivalued element. Default is index 0 if not supplied\n * @returns {*} unsigned int 16 or undefined if the attribute is not present or has data of length 0\n */\n uint16 (tag, index) {\n var element = this.elements[tag];\n\n index = (index !== undefined) ? index : 0;\n if (element && element.length !== 0) {\n return getByteArrayParser(element, this.byteArrayParser).readUint16(this.byteArray, element.dataOffset + (index * 2));\n }\n\n return undefined;\n }\n\n /**\n * Finds the element for tag and returns an signed int 16 if it exists and has data\n * @param tag The DICOM tag in the format xGGGGEEEE\n * @param index the index of the value in a multivalued element. Default is index 0 if not supplied\n * @returns {*} signed int 16 or undefined if the attribute is not present or has data of length 0\n */\n int16 (tag, index) {\n var element = this.elements[tag];\n\n index = (index !== undefined) ? index : 0;\n if (element && element.length !== 0) {\n return getByteArrayParser(element, this.byteArrayParser).readInt16(this.byteArray, element.dataOffset + (index * 2));\n }\n\n return undefined;\n }\n\n /**\n * Finds the element for tag and returns an unsigned int 32 if it exists and has data\n * @param tag The DICOM tag in the format xGGGGEEEE\n * @param index the index of the value in a multivalued element. Default is index 0 if not supplied\n * @returns {*} unsigned int 32 or undefined if the attribute is not present or has data of length 0\n */\n uint32 (tag, index) {\n var element = this.elements[tag];\n\n index = (index !== undefined) ? index : 0;\n if (element && element.length !== 0) {\n return getByteArrayParser(element, this.byteArrayParser).readUint32(this.byteArray, element.dataOffset + (index * 4));\n }\n\n return undefined;\n }\n\n /**\n * Finds the element for tag and returns an signed int 32 if it exists and has data\n * @param tag The DICOM tag in the format xGGGGEEEE\n * @param index the index of the value in a multivalued element. Default is index 0 if not supplied\n * @returns {*} signed int 32 or undefined if the attribute is not present or has data of length 0\n */\n int32 (tag, index) {\n var element = this.elements[tag];\n\n index = (index !== undefined) ? index : 0;\n if (element && element.length !== 0) {\n return getByteArrayParser(element, this.byteArrayParser).readInt32(this.byteArray, element.dataOffset + (index * 4));\n }\n\n return undefined;\n }\n\n /**\n * Finds the element for tag and returns a 32 bit floating point number (VR=FL) if it exists and has data\n * @param tag The DICOM tag in the format xGGGGEEEE\n * @param index the index of the value in a multivalued element. Default is index 0 if not supplied\n * @returns {*} float or undefined if the attribute is not present or has data of length 0\n */\n float (tag, index) {\n var element = this.elements[tag];\n\n index = (index !== undefined) ? index : 0;\n if (element && element.length !== 0) {\n return getByteArrayParser(element, this.byteArrayParser).readFloat(this.byteArray, element.dataOffset + (index * 4));\n }\n\n return undefined;\n }\n\n /**\n * Finds the element for tag and returns a 64 bit floating point number (VR=FD) if it exists and has data\n * @param tag The DICOM tag in the format xGGGGEEEE\n * @param index the index of the value in a multivalued element. Default is index 0 if not supplied\n * @returns {*} float or undefined if the attribute is not present or doesn't has data of length 0\n */\n double (tag, index) {\n var element = this.elements[tag];\n\n index = (index !== undefined) ? index : 0;\n if (element && element.length !== 0) {\n return getByteArrayParser(element, this.byteArrayParser).readDouble(this.byteArray, element.dataOffset + (index * 8));\n }\n\n return undefined;\n }\n\n /**\n * Returns the number of string values for the element\n * @param tag The DICOM tag in the format xGGGGEEEE\n * @returns {*} the number of string values or undefined if the attribute is not present or has zero length data\n */\n numStringValues (tag) {\n var element = this.elements[tag];\n\n if (element && element.length > 0) {\n var fixedString = readFixedString(this.byteArray, element.dataOffset, element.length);\n var numMatching = fixedString.match(/\\\\/g);\n\n if (numMatching === null) {\n return 1;\n }\n\n return numMatching.length + 1;\n }\n\n return undefined;\n }\n\n /**\n * Returns a string for the element. If index is provided, the element is assumed to be\n * multi-valued and will return the component specified by index. Undefined is returned\n * if there is no component with the specified index, the element does not exist or is zero length.\n *\n * Use this function for VR types of AE, CS, SH and LO\n *\n * @param tag The DICOM tag in the format xGGGGEEEE\n * @param index the index of the desired value in a multi valued string or undefined for the entire string\n * @returns {*}\n */\n string (tag, index) {\n var element = this.elements[tag];\n\n if( element && element.Value ) return element.Value;\n \n if (element && element.length > 0) {\n var fixedString = readFixedString(this.byteArray, element.dataOffset, element.length);\n\n if (index >= 0) {\n var values = fixedString.split('\\\\');\n // trim trailing spaces\n\n return values[index].trim();\n }\n // trim trailing spaces\n return fixedString.trim();\n }\n\n return undefined;\n }\n\n /**\n * Returns a string with the leading spaces preserved and trailing spaces removed.\n *\n * Use this function to access data for VRs of type UT, ST and LT\n *\n * @param tag\n * @param index\n * @returns {*}\n */\n text (tag, index) {\n var element = this.elements[tag];\n\n if (element && element.length > 0) {\n var fixedString = readFixedString(this.byteArray, element.dataOffset, element.length);\n\n if (index >= 0) {\n var values = fixedString.split('\\\\');\n\n\n return values[index].replace(/ +$/, '');\n }\n\n return fixedString.replace(/ +$/, '');\n }\n\n return undefined;\n }\n\n /**\n * Parses a string to a float for the specified index in a multi-valued element. If index is not specified,\n * the first value in a multi-valued VR will be parsed if present.\n * @param tag The DICOM tag in the format xGGGGEEEE\n * @param index the index of the desired value in a multi valued string or undefined for the first value\n * @returns {*} a floating point number or undefined if not present or data not long enough\n */\n floatString (tag, index) {\n var element = this.elements[tag];\n\n if (element && element.length > 0) {\n index = (index !== undefined) ? index : 0;\n var value = this.string(tag, index);\n\n if (value !== undefined) {\n return parseFloat(value);\n }\n }\n\n return undefined;\n }\n\n /**\n * Parses a string to an integer for the specified index in a multi-valued element. If index is not specified,\n * the first value in a multi-valued VR will be parsed if present.\n * @param tag The DICOM tag in the format xGGGGEEEE\n * @param index the index of the desired value in a multi valued string or undefined for the first value\n * @returns {*} an integer or undefined if not present or data not long enough\n */\n intString (tag, index) {\n var element = this.elements[tag];\n\n if (element && element.length > 0) {\n index = (index !== undefined) ? index : 0;\n var value = this.string(tag, index);\n\n if (value !== undefined) {\n return parseInt(value);\n }\n }\n\n return undefined;\n }\n\n /**\n * Parses an element tag according to the 'AT' VR definition (VR=AT).\n * @param {String} A DICOM tag with in the format xGGGGEEEE.\n * @returns {String} A string representation of a data element tag or undefined if the field is not present or data is not long enough.\n */\n attributeTag (tag) {\n const element = this.elements[tag];\n\n if (element && element.length === 4) {\n const parser = getByteArrayParser(element, this.byteArrayParser).readUint16;\n const bytes = this.byteArray;\n const offset = element.dataOffset;\n\n return `x${(`00000000${(parser(bytes, offset) * 256 * 256 + parser(bytes, offset + 2)).toString(16)}`).substr(-8)}`;\n }\n\n return undefined;\n }\n}\n", "/**\n * Internal helper functions for parsing DICOM elements\n */\n\n/**\n * reads from the byte stream until it finds the magic numbers for the item delimitation item\n * and then sets the length of the element\n * @param byteStream\n * @param element\n */\nexport default function findItemDelimitationItemAndSetElementLength (byteStream, element) {\n if (byteStream === undefined) {\n throw 'dicomParser.readDicomElementImplicit: missing required parameter \\'byteStream\\'';\n }\n\n const itemDelimitationItemLength = 8; // group, element, length\n const maxPosition = byteStream.byteArray.length - itemDelimitationItemLength;\n\n while (byteStream.position <= maxPosition) {\n const groupNumber = byteStream.readUint16();\n\n if (groupNumber === 0xfffe) {\n const elementNumber = byteStream.readUint16();\n\n if (elementNumber === 0xe00d) {\n // NOTE: It would be better to also check for the length to be 0 as part of the check above\n // but we will just log a warning for now\n const itemDelimiterLength = byteStream.readUint32(); // the length\n\n if (itemDelimiterLength !== 0) {\n byteStream.warnings(`encountered non zero length following item delimiter at position ${byteStream.position - 4} while reading element of undefined length with tag ${element.tag}`);\n }\n\n element.length = byteStream.position - element.dataOffset;\n\n return;\n }\n }\n }\n\n // No item delimitation item - silently set the length to the end of the buffer and set the position past the end of the buffer\n element.length = byteStream.byteArray.length - element.dataOffset;\n byteStream.seek(byteStream.byteArray.length - byteStream.position);\n}\n", "import findItemDelimitationItemAndSetElementLength from './findItemDelimitationItem.js';\nimport readSequenceItemsImplicit from './readSequenceElementImplicit.js';\nimport readTag from './readTag.js';\nimport { isPrivateTag } from './util/util.js';\n\n/**\n * Internal helper functions for for parsing DICOM elements\n */\n\nconst isSequence = (element, byteStream) => {\n if (element.vr !== undefined) {\n return (element.vr === 'SQ');\n }\n\n if ((byteStream.position + 4) <= byteStream.byteArray.length) {\n const nextTag = readTag(byteStream);\n\n byteStream.seek(-4);\n\n // Item start tag (fffe,e000) or sequence delimiter (i.e. end of sequence) tag (0fffe,e0dd)\n // These are the tags that could potentially be found directly after a sequence start tag (the delimiter\n // is found in the case of an empty sequence). This is not 100% safe because a non-sequence item\n // could have data that has these bytes, but this is how to do it without a data dictionary.\n return (nextTag === 'xfffee000') || (nextTag === 'xfffee0dd');\n }\n\n byteStream.warnings.push('eof encountered before finding sequence item tag or sequence delimiter tag in peeking to determine VR');\n\n return false;\n};\n\nexport default function readDicomElementImplicit (byteStream, untilTag, vrCallback) {\n if (byteStream === undefined) {\n throw 'dicomParser.readDicomElementImplicit: missing required parameter \\'byteStream\\'';\n }\n\n const tag = readTag(byteStream);\n\n const element = {\n tag,\n vr: (vrCallback !== undefined ? vrCallback(tag) : undefined),\n length: byteStream.readUint32(),\n dataOffset: byteStream.position\n };\n\n if (element.length === 4294967295) {\n element.hadUndefinedLength = true;\n }\n\n if (element.tag === untilTag) {\n return element;\n }\n\n // always parse sequences with undefined lengths, since there's no other way to know how long they are.\n if (isSequence(element, byteStream) && (!isPrivateTag(element.tag) || element.hadUndefinedLength)) {\n // parse the sequence\n readSequenceItemsImplicit(byteStream, element, vrCallback);\n\n if (isPrivateTag(element.tag)) {\n element.items = undefined;\n }\n\n return element;\n }\n\n // if element is not a sequence and has undefined length, we have to\n // scan the data for a magic number to figure out when it ends.\n if (element.hadUndefinedLength) {\n findItemDelimitationItemAndSetElementLength(byteStream, element);\n\n return element;\n }\n\n // non sequence element with known length, skip over the data part\n byteStream.seek(element.length);\n\n return element;\n}\n", "import readTag from './readTag.js';\n\n/**\n * Internal helper functions for parsing DICOM elements\n */\n\n/**\n * Reads the tag and length of a sequence item and returns them as an object with the following properties\n * tag : string for the tag of this element in the format xggggeeee\n * length: the number of bytes in this item or 4294967295 if undefined\n * dataOffset: the offset into the byteStream of the data for this item\n * @param byteStream the byte\n * @returns {{tag: string, length: integer, dataOffset: integer}}\n */\nexport default function readSequenceItem (byteStream) {\n if (byteStream === undefined) {\n throw 'dicomParser.readSequenceItem: missing required parameter \\'byteStream\\'';\n }\n\n const element = {\n tag: readTag(byteStream),\n length: byteStream.readUint32(),\n dataOffset: byteStream.position\n };\n\n if (element.tag !== 'xfffee000') {\n throw `dicomParser.readSequenceItem: item tag (FFFE,E000) not found at offset ${byteStream.position}`;\n }\n\n return element;\n}\n", "import DataSet from './dataSet.js';\nimport readDicomElementImplicit from './readDicomElementImplicit.js';\nimport readSequenceItem from './readSequenceItem.js';\nimport readTag from './readTag.js';\nimport * as parseDicomDataSet from './parseDicomDataSet.js';\n\n/**\n * Internal helper functions for parsing DICOM elements\n */\n\nfunction readDicomDataSetImplicitUndefinedLength (byteStream, vrCallback) {\n const elements = {};\n\n while (byteStream.position < byteStream.byteArray.length) {\n const element = readDicomElementImplicit(byteStream, undefined, vrCallback);\n\n elements[element.tag] = element;\n\n // we hit an item delimiter tag, return the current offset to mark\n // the end of this sequence item\n if (element.tag === 'xfffee00d') {\n return new DataSet(byteStream.byteArrayParser, byteStream.byteArray, elements);\n }\n }\n\n // eof encountered - log a warning and return what we have for the element\n byteStream.warnings.push('eof encountered before finding sequence item delimiter in sequence item of undefined length');\n\n return new DataSet(byteStream.byteArrayParser, byteStream.byteArray, elements);\n}\n\nfunction readSequenceItemImplicit (byteStream, vrCallback) {\n const item = readSequenceItem(byteStream);\n\n if (item.length === 4294967295) {\n item.hadUndefinedLength = true;\n item.dataSet = readDicomDataSetImplicitUndefinedLength(byteStream, vrCallback);\n item.length = byteStream.position - item.dataOffset;\n } else {\n item.dataSet = new DataSet(byteStream.byteArrayParser, byteStream.byteArray, {});\n parseDicomDataSet.parseDicomDataSetImplicit(item.dataSet, byteStream, byteStream.position + item.length, { vrCallback });\n }\n\n return item;\n}\n\nfunction readSQElementUndefinedLengthImplicit (byteStream, element, vrCallback) {\n while ((byteStream.position + 4) <= byteStream.byteArray.length) {\n // end reading this sequence if the next tag is the sequence delimitation item\n const nextTag = readTag(byteStream);\n\n byteStream.seek(-4);\n\n if (nextTag === 'xfffee0dd') {\n // set the correct length\n element.length = byteStream.position - element.dataOffset;\n byteStream.seek(8);\n\n return element;\n }\n\n const item = readSequenceItemImplicit(byteStream, vrCallback);\n\n element.items.push(item);\n }\n\n byteStream.warnings.push('eof encountered before finding sequence delimiter in sequence of undefined length');\n element.length = byteStream.byteArray.length - element.dataOffset;\n}\n\nfunction readSQElementKnownLengthImplicit (byteStream, element, vrCallback) {\n const maxPosition = element.dataOffset + element.length;\n\n while (byteStream.position < maxPosition) {\n const item = readSequenceItemImplicit(byteStream, vrCallback);\n\n element.items.push(item);\n }\n}\n\n/**\n * Reads sequence items for an element in an implicit little endian byte stream\n * @param byteStream the implicit little endian byte stream\n * @param element the element to read the sequence items for\n * @param vrCallback an optional method that returns a VR string given a tag\n */\nexport default function readSequenceItemsImplicit (byteStream, element, vrCallback) {\n if (byteStream === undefined) {\n throw 'dicomParser.readSequenceItemsImplicit: missing required parameter \\'byteStream\\'';\n }\n\n if (element === undefined) {\n throw 'dicomParser.readSequenceItemsImplicit: missing required parameter \\'element\\'';\n }\n\n element.items = [];\n\n if (element.length === 4294967295) {\n readSQElementUndefinedLengthImplicit(byteStream, element, vrCallback);\n } else {\n readSQElementKnownLengthImplicit(byteStream, element, vrCallback);\n }\n}\n", "import DataSet from './dataSet.js';\nimport readDicomElementExplicit from './readDicomElementExplicit.js';\nimport readSequenceItem from './readSequenceItem.js';\nimport readTag from './readTag.js';\nimport * as parseDicomDataSet from './parseDicomDataSet.js';\n\n/**\n * Internal helper functions for parsing DICOM elements\n */\n\nfunction readDicomDataSetExplicitUndefinedLength (byteStream, warnings) {\n const elements = {};\n\n while (byteStream.position < byteStream.byteArray.length) {\n const element = readDicomElementExplicit(byteStream, warnings);\n\n elements[element.tag] = element;\n\n // we hit an item delimiter tag, return the current offset to mark\n // the end of this sequence item\n if (element.tag === 'xfffee00d') {\n return new DataSet(byteStream.byteArrayParser, byteStream.byteArray, elements);\n }\n }\n\n // eof encountered - log a warning and return what we have for the element\n warnings.push('eof encountered before finding item delimiter tag while reading sequence item of undefined length');\n\n return new DataSet(byteStream.byteArrayParser, byteStream.byteArray, elements);\n}\n\nfunction readSequenceItemExplicit (byteStream, warnings) {\n const item = readSequenceItem(byteStream);\n\n if (item.length === 4294967295) {\n item.hadUndefinedLength = true;\n item.dataSet = readDicomDataSetExplicitUndefinedLength(byteStream, warnings);\n item.length = byteStream.position - item.dataOffset;\n } else {\n item.dataSet = new DataSet(byteStream.byteArrayParser, byteStream.byteArray, {});\n parseDicomDataSet.parseDicomDataSetExplicit(item.dataSet, byteStream, byteStream.position + item.length);\n }\n\n return item;\n}\n\nfunction readSQElementUndefinedLengthExplicit (byteStream, element, warnings) {\n while ((byteStream.position + 4) <= byteStream.byteArray.length) {\n // end reading this sequence if the next tag is the sequence delimitation item\n const nextTag = readTag(byteStream);\n\n byteStream.seek(-4);\n if (nextTag === 'xfffee0dd') {\n // set the correct length\n element.length = byteStream.position - element.dataOffset;\n byteStream.seek(8);\n\n return element;\n }\n\n const item = readSequenceItemExplicit(byteStream, warnings);\n\n element.items.push(item);\n }\n\n warnings.push('eof encountered before finding sequence delimitation tag while reading sequence of undefined length');\n element.length = byteStream.position - element.dataOffset;\n}\n\nfunction readSQElementKnownLengthExplicit (byteStream, element, warnings) {\n const maxPosition = element.dataOffset + element.length;\n\n while (byteStream.position < maxPosition) {\n const item = readSequenceItemExplicit(byteStream, warnings);\n\n element.items.push(item);\n }\n}\n\nexport default function readSequenceItemsExplicit (byteStream, element, warnings) {\n if (byteStream === undefined) {\n throw 'dicomParser.readSequenceItemsExplicit: missing required parameter \\'byteStream\\'';\n }\n\n if (element === undefined) {\n throw 'dicomParser.readSequenceItemsExplicit: missing required parameter \\'element\\'';\n }\n\n element.items = [];\n\n if (element.length === 4294967295) {\n readSQElementUndefinedLengthExplicit(byteStream, element, warnings);\n } else {\n readSQElementKnownLengthExplicit(byteStream, element, warnings);\n }\n}\n", "import findEndOfEncapsulatedElement from './findEndOfEncapsulatedPixelData.js';\nimport findAndSetUNElementLength from './findAndSetUNElementLength.js';\nimport readSequenceItemsImplicit from './readSequenceElementImplicit.js';\nimport readTag from './readTag.js';\nimport findItemDelimitationItemAndSetElementLength from './findItemDelimitationItem.js';\nimport readSequenceItemsExplicit from './readSequenceElementExplicit.js';\n\n/**\n * Internal helper functions for for parsing DICOM elements\n */\n\nconst getDataLengthSizeInBytesForVR = (vr) => {\n if (vr === 'OB' ||\n vr === 'OD' ||\n vr === 'OL' ||\n vr === 'OW' ||\n vr === 'SQ' ||\n vr === 'OF' ||\n vr === 'UC' ||\n vr === 'UR' ||\n vr === 'UT' ||\n vr === 'UN') {\n return 4;\n }\n\n return 2;\n};\n\nexport default function readDicomElementExplicit (byteStream, warnings, untilTag) {\n if (byteStream === undefined) {\n throw 'dicomParser.readDicomElementExplicit: missing required parameter \\'byteStream\\'';\n }\n\n const element = {\n tag: readTag(byteStream),\n vr: byteStream.readFixedString(2)\n // length set below based on VR\n // dataOffset set below based on VR and size of length\n };\n\n const dataLengthSizeBytes = getDataLengthSizeInBytesForVR(element.vr);\n\n if (dataLengthSizeBytes === 2) {\n element.length = byteStream.readUint16();\n element.dataOffset = byteStream.position;\n } else {\n byteStream.seek(2);\n element.length = byteStream.readUint32();\n element.dataOffset = byteStream.position;\n }\n\n if (element.length === 4294967295) {\n element.hadUndefinedLength = true;\n }\n\n if (element.tag === untilTag) {\n return element;\n }\n\n // if VR is SQ, parse the sequence items\n if (element.vr === 'SQ') {\n readSequenceItemsExplicit(byteStream, element, warnings);\n\n return element;\n }\n\n if (element.length === 4294967295) {\n if (element.tag === 'x7fe00010') {\n findEndOfEncapsulatedElement(byteStream, element, warnings);\n\n return element;\n } else if (element.vr === 'UN') {\n readSequenceItemsImplicit(byteStream, element);\n\n return element;\n }\n\n findItemDelimitationItemAndSetElementLength(byteStream, element);\n\n return element;\n }\n\n byteStream.seek(element.length);\n\n return element;\n}\n", "import readDicomElementExplicit from './readDicomElementExplicit.js';\nimport readDicomElementImplicit from './readDicomElementImplicit.js';\n\n/**\n * Internal helper functions for parsing implicit and explicit DICOM data sets\n */\n\n/**\n * reads an explicit data set\n * @param byteStream the byte stream to read from\n * @param maxPosition the maximum position to read up to (optional - only needed when reading sequence items)\n */\nexport function parseDicomDataSetExplicit (dataSet, byteStream, maxPosition, options = {}) {\n maxPosition = (maxPosition === undefined) ? byteStream.byteArray.length : maxPosition;\n\n if (byteStream === undefined) {\n throw 'dicomParser.parseDicomDataSetExplicit: missing required parameter \\'byteStream\\'';\n }\n\n if (maxPosition < byteStream.position || maxPosition > byteStream.byteArray.length) {\n throw 'dicomParser.parseDicomDataSetExplicit: invalid value for parameter \\'maxP osition\\'';\n }\n\n const elements = dataSet.elements;\n\n while (byteStream.position < maxPosition) {\n const element = readDicomElementExplicit(byteStream, dataSet.warnings, options.untilTag);\n\n elements[element.tag] = element;\n if (element.tag === options.untilTag) {\n return;\n }\n }\n\n if (byteStream.position > maxPosition) {\n throw 'dicomParser:parseDicomDataSetExplicit: buffer overrun';\n }\n}\n\n/**\n * reads an implicit data set\n * @param byteStream the byte stream to read from\n * @param maxPosition the maximum position to read up to (optional - only needed when reading sequence items)\n */\nexport function parseDicomDataSetImplicit (dataSet, byteStream, maxPosition, options = {}) {\n maxPosition = (maxPosition === undefined) ? dataSet.byteArray.length : maxPosition;\n\n if (byteStream === undefined) {\n throw 'dicomParser.parseDicomDataSetImplicit: missing required parameter \\'byteStream\\'';\n }\n\n if (maxPosition < byteStream.position || maxPosition > byteStream.byteArray.length) {\n throw 'dicomParser.parseDicomDataSetImplicit: invalid value for parameter \\'maxPosition\\'';\n }\n\n const elements = dataSet.elements;\n\n while (byteStream.position < maxPosition) {\n const element = readDicomElementImplicit(byteStream, options.untilTag, options.vrCallback);\n\n elements[element.tag] = element;\n if (element.tag === options.untilTag) {\n return;\n }\n }\n}\n", "/**\n * Creates a new byteArray of the same type (Uint8Array or Buffer) of the specified length.\n * @param byteArray the underlying byteArray (either Uint8Array or Buffer)\n * @param length number of bytes of the Byte Array\n * @returns {object} Uint8Array or Buffer depending on the type of byteArray\n */\nexport default function alloc (byteArray, length) {\n if (typeof Buffer !== 'undefined' && byteArray instanceof Buffer) {\n return Buffer.alloc(length);\n } else if (byteArray instanceof Uint8Array) {\n return new Uint8Array(length);\n }\n throw 'dicomParser.alloc: unknown type for byteArray';\n}\n", "export default '1.8.12';\n", "/**\n * Internal helper functions for parsing different types from a big-endian byte array\n */\nexport default {\n\n /**\n *\n * Parses an unsigned int 16 from a big-endian byte array\n *\n * @param byteArray the byte array to read from\n * @param position the position in the byte array to read from\n * @returns {*} the parsed unsigned int 16\n * @throws error if buffer overread would occur\n * @access private\n */\n readUint16 (byteArray, position) {\n if (position < 0) {\n throw 'bigEndianByteArrayParser.readUint16: position cannot be less than 0';\n }\n if (position + 2 > byteArray.length) {\n throw 'bigEndianByteArrayParser.readUint16: attempt to read past end of buffer';\n }\n\n return (byteArray[position] << 8) + byteArray[position + 1];\n },\n\n /**\n *\n * Parses a signed int 16 from a big-endian byte array\n *\n * @param byteArray the byte array to read from\n * @param position the position in the byte array to read from\n * @returns {*} the parsed signed int 16\n * @throws error if buffer overread would occur\n * @access private\n */\n readInt16 (byteArray, position) {\n if (position < 0) {\n throw 'bigEndianByteArrayParser.readInt16: position cannot be less than 0';\n }\n if (position + 2 > byteArray.length) {\n throw 'bigEndianByteArrayParser.readInt16: attempt to read past end of buffer';\n }\n var int16 = (byteArray[position] << 8) + byteArray[position + 1];\n // fix sign\n\n if (int16 & 0x8000) {\n int16 = int16 - 0xFFFF - 1;\n }\n\n return int16;\n },\n\n /**\n * Parses an unsigned int 32 from a big-endian byte array\n *\n * @param byteArray the byte array to read from\n * @param position the position in the byte array to read from\n * @returns {*} the parsed unsigned int 32\n * @throws error if buffer overread would occur\n * @access private\n */\n readUint32 (byteArray, position) {\n if (position < 0) {\n throw 'bigEndianByteArrayParser.readUint32: position cannot be less than 0';\n }\n\n if (position + 4 > byteArray.length) {\n throw 'bigEndianByteArrayParser.readUint32: attempt to read past end of buffer';\n }\n\n var uint32 = (256 * (256 * (256 * byteArray[position] +\n byteArray[position + 1]) +\n byteArray[position + 2]) +\n byteArray[position + 3]);\n\n return uint32;\n },\n\n /**\n * Parses a signed int 32 from a big-endian byte array\n *\n * @param byteArray the byte array to read from\n * @param position the position in the byte array to read from\n * @returns {*} the parsed signed int 32\n * @throws error if buffer overread would occur\n * @access private\n */\n readInt32 (byteArray, position) {\n if (position < 0) {\n throw 'bigEndianByteArrayParser.readInt32: position cannot be less than 0';\n }\n\n if (position + 4 > byteArray.length) {\n throw 'bigEndianByteArrayParser.readInt32: attempt to read past end of buffer';\n }\n\n var int32 = ((byteArray[position] << 24) +\n (byteArray[position + 1] << 16) +\n (byteArray[position + 2] << 8) +\n byteArray[position + 3]);\n\n return int32;\n },\n\n /**\n * Parses 32-bit float from a big-endian byte array\n *\n * @param byteArray the byte array to read from\n * @param position the position in the byte array to read from\n * @returns {*} the parsed 32-bit float\n * @throws error if buffer overread would occur\n * @access private\n */\n readFloat (byteArray, position) {\n if (position < 0) {\n throw 'bigEndianByteArrayParser.readFloat: position cannot be less than 0';\n }\n\n if (position + 4 > byteArray.length) {\n throw 'bigEndianByteArrayParser.readFloat: attempt to read past end of buffer';\n }\n\n // I am sure there is a better way than this but this should be safe\n var byteArrayForParsingFloat = new Uint8Array(4);\n\n byteArrayForParsingFloat[3] = byteArray[position];\n byteArrayForParsingFloat[2] = byteArray[position + 1];\n byteArrayForParsingFloat[1] = byteArray[position + 2];\n byteArrayForParsingFloat[0] = byteArray[position + 3];\n var floatArray = new Float32Array(byteArrayForParsingFloat.buffer);\n\n\n return floatArray[0];\n },\n\n /**\n * Parses 64-bit float from a big-endian byte array\n *\n * @param byteArray the byte array to read from\n * @param position the position in the byte array to read from\n * @returns {*} the parsed 64-bit float\n * @throws error if buffer overread would occur\n * @access private\n */\n readDouble (byteArray, position) {\n if (position < 0) {\n throw 'bigEndianByteArrayParser.readDouble: position cannot be less than 0';\n }\n\n if (position + 8 > byteArray.length) {\n throw 'bigEndianByteArrayParser.readDouble: attempt to read past end of buffer';\n }\n\n // I am sure there is a better way than this but this should be safe\n var byteArrayForParsingFloat = new Uint8Array(8);\n\n byteArrayForParsingFloat[7] = byteArray[position];\n byteArrayForParsingFloat[6] = byteArray[position + 1];\n byteArrayForParsingFloat[5] = byteArray[position + 2];\n byteArrayForParsingFloat[4] = byteArray[position + 3];\n byteArrayForParsingFloat[3] = byteArray[position + 4];\n byteArrayForParsingFloat[2] = byteArray[position + 5];\n byteArrayForParsingFloat[1] = byteArray[position + 6];\n byteArrayForParsingFloat[0] = byteArray[position + 7];\n var floatArray = new Float64Array(byteArrayForParsingFloat.buffer);\n\n\n return floatArray[0];\n }\n};\n", "/**\n *\n * Internal helper function to create a shared copy of a byteArray\n *\n */\n\n/**\n * Creates a view of the underlying byteArray. The view is of the same type as the byteArray (e.g.\n * Uint8Array or Buffer) and shares the same underlying memory (changing one changes the other)\n * @param byteArray the underlying byteArray (either Uint8Array or Buffer)\n * @param byteOffset offset into the underlying byteArray to create the view of\n * @param length number of bytes in the view\n * @returns {object} Uint8Array or Buffer depending on the type of byteArray\n */\nexport default function sharedCopy (byteArray, byteOffset, length) {\n if (typeof Buffer !== 'undefined' && byteArray instanceof Buffer) {\n return byteArray.slice(byteOffset, byteOffset + length);\n } else if (byteArray instanceof Uint8Array) {\n return new Uint8Array(byteArray.buffer, byteArray.byteOffset + byteOffset, length);\n }\n throw 'dicomParser.from: unknown type for byteArray';\n}\n", "import sharedCopy from './sharedCopy.js';\nimport { readFixedString } from './byteArrayParser.js';\n\n/**\n *\n * Internal helper class to assist with parsing. Supports reading from a byte\n * stream contained in a Uint8Array. Example usage:\n *\n * var byteArray = new Uint8Array(32);\n * var byteStream = new dicomParser.ByteStream(dicomParser.littleEndianByteArrayParser, byteArray);\n *\n * */\n\n/**\n * Constructor for ByteStream objects.\n * @param byteArrayParser a parser for parsing the byte array\n * @param byteArray a Uint8Array containing the byte stream\n * @param position (optional) the position to start reading from. 0 if not specified\n * @constructor\n * @throws will throw an error if the byteArrayParser parameter is not present\n * @throws will throw an error if the byteArray parameter is not present or invalid\n * @throws will throw an error if the position parameter is not inside the byte array\n */\nexport default class ByteStream {\n constructor (byteArrayParser, byteArray, position) {\n if (byteArrayParser === undefined) {\n throw 'dicomParser.ByteStream: missing required parameter \\'byteArrayParser\\'';\n }\n if (byteArray === undefined) {\n throw 'dicomParser.ByteStream: missing required parameter \\'byteArray\\'';\n }\n if ((byteArray instanceof Uint8Array) === false &&\n ((typeof Buffer === 'undefined') ||\n (byteArray instanceof Buffer) === false)) {\n throw 'dicomParser.ByteStream: parameter byteArray is not of type Uint8Array or Buffer';\n }\n if (position < 0) {\n throw 'dicomParser.ByteStream: parameter \\'position\\' cannot be less than 0';\n }\n if (position >= byteArray.length) {\n throw 'dicomParser.ByteStream: parameter \\'position\\' cannot be greater than or equal to \\'byteArray\\' length';\n }\n this.byteArrayParser = byteArrayParser;\n this.byteArray = byteArray;\n this.position = position ? position : 0;\n this.warnings = []; // array of string warnings encountered while parsing\n }\n\n /**\n * Safely seeks through the byte stream. Will throw an exception if an attempt\n * is made to seek outside of the byte array.\n * @param offset the number of bytes to add to the position\n * @throws error if seek would cause position to be outside of the byteArray\n */\n seek (offset) {\n if (this.position + offset < 0) {\n throw 'dicomParser.ByteStream.prototype.seek: cannot seek to position < 0';\n }\n this.position += offset;\n }\n\n /**\n * Returns a new ByteStream object from the current position and of the requested number of bytes\n * @param numBytes the length of the byte array for the ByteStream to contain\n * @returns {dicomParser.ByteStream}\n * @throws error if buffer overread would occur\n */\n readByteStream (numBytes) {\n if (this.position + numBytes > this.byteArray.length) {\n throw 'dicomParser.ByteStream.prototype.readByteStream: readByteStream - buffer overread';\n }\n var byteArrayView = sharedCopy(this.byteArray, this.position, numBytes);\n\n this.position += numBytes;\n\n return new ByteStream(this.byteArrayParser, byteArrayView);\n }\n\n getSize() {\n return this.byteArray.length;\n }\n\n /**\n *\n * Parses an unsigned int 16 from a byte array and advances\n * the position by 2 bytes\n *\n * @returns {*} the parsed unsigned int 16\n * @throws error if buffer overread would occur\n */\n readUint16 () {\n var result = this.byteArrayParser.readUint16(this.byteArray, this.position);\n\n this.position += 2;\n\n return result;\n }\n\n /**\n * Parses an unsigned int 32 from a byte array and advances\n * the position by 2 bytes\n *\n * @returns {*} the parse unsigned int 32\n * @throws error if buffer overread would occur\n */\n readUint32 () {\n var result = this.byteArrayParser.readUint32(this.byteArray, this.position);\n\n this.position += 4;\n\n return result;\n }\n\n /**\n * Reads a string of 8-bit characters from an array of bytes and advances\n * the position by length bytes. A null terminator will end the string\n * but will not effect advancement of the position.\n * @param length the maximum number of bytes to parse\n * @returns {string} the parsed string\n * @throws error if buffer overread would occur\n */\n readFixedString (length) {\n var result = readFixedString(this.byteArray, this.position, length);\n\n this.position += length;\n\n return result;\n }\n}\n", "/**\n * Internal helper functions for parsing different types from a little-endian byte array\n */\n\nexport default {\n\n /**\n *\n * Parses an unsigned int 16 from a little-endian byte array\n *\n * @param byteArray the byte array to read from\n * @param position the position in the byte array to read from\n * @returns {*} the parsed unsigned int 16\n * @throws error if buffer overread would occur\n * @access private\n */\n readUint16 (byteArray, position) {\n if (position < 0) {\n throw 'littleEndianByteArrayParser.readUint16: position cannot be less than 0';\n }\n\n if (position + 2 > byteArray.length) {\n throw 'littleEndianByteArrayParser.readUint16: attempt to read past end of buffer';\n }\n\n return byteArray[position] + (byteArray[position + 1] * 256);\n },\n\n /**\n *\n * Parses a signed int 16 from a little-endian byte array\n *\n * @param byteArray the byte array to read from\n * @param position the position in the byte array to read from\n * @returns {*} the parsed signed int 16\n * @throws error if buffer overread would occur\n * @access private\n */\n readInt16 (byteArray, position) {\n if (position < 0) {\n throw 'littleEndianByteArrayParser.readInt16: position cannot be less than 0';\n }\n if (position + 2 > byteArray.length) {\n throw 'littleEndianByteArrayParser.readInt16: attempt to read past end of buffer';\n }\n\n let int16 = byteArray[position] + (byteArray[position + 1] << 8);\n\n // fix sign\n if (int16 & 0x8000) {\n int16 = int16 - 0xFFFF - 1;\n }\n\n return int16;\n },\n\n\n /**\n * Parses an unsigned int 32 from a little-endian byte array\n *\n * @param byteArray the byte array to read from\n * @param position the position in the byte array to read from\n * @returns {*} the parsed unsigned int 32\n * @throws error if buffer overread would occur\n * @access private\n */\n readUint32 (byteArray, position) {\n if (position < 0) {\n throw 'littleEndianByteArrayParser.readUint32: position cannot be less than 0';\n }\n\n if (position + 4 > byteArray.length) {\n throw 'littleEndianByteArrayParser.readUint32: attempt to read past end of buffer';\n }\n\n return (byteArray[position] +\n (byteArray[position + 1] * 256) +\n (byteArray[position + 2] * 256 * 256) +\n (byteArray[position + 3] * 256 * 256 * 256));\n },\n\n /**\n * Parses a signed int 32 from a little-endian byte array\n *\n * @param byteArray the byte array to read from\n * @param position the position in the byte array to read from\n * @returns {*} the parsed unsigned int 32\n * @throws error if buffer overread would occur\n * @access private\n */\n readInt32 (byteArray, position) {\n if (position < 0) {\n throw 'littleEndianByteArrayParser.readInt32: position cannot be less than 0';\n }\n\n if (position + 4 > byteArray.length) {\n throw 'littleEndianByteArrayParser.readInt32: attempt to read past end of buffer';\n }\n\n return (byteArray[position] +\n (byteArray[position + 1] << 8) +\n (byteArray[position + 2] << 16) +\n (byteArray[position + 3] << 24));\n },\n\n /**\n * Parses 32-bit float from a little-endian byte array\n *\n * @param byteArray the byte array to read from\n * @param position the position in the byte array to read from\n * @returns {*} the parsed 32-bit float\n * @throws error if buffer overread would occur\n * @access private\n */\n readFloat (byteArray, position) {\n if (position < 0) {\n throw 'littleEndianByteArrayParser.readFloat: position cannot be less than 0';\n }\n\n if (position + 4 > byteArray.length) {\n throw 'littleEndianByteArrayParser.readFloat: attempt to read past end of buffer';\n }\n\n // I am sure there is a better way than this but this should be safe\n const byteArrayForParsingFloat = new Uint8Array(4);\n\n byteArrayForParsingFloat[0] = byteArray[position];\n byteArrayForParsingFloat[1] = byteArray[position + 1];\n byteArrayForParsingFloat[2] = byteArray[position + 2];\n byteArrayForParsingFloat[3] = byteArray[position + 3];\n\n const floatArray = new Float32Array(byteArrayForParsingFloat.buffer);\n\n return floatArray[0];\n },\n\n /**\n * Parses 64-bit float from a little-endian byte array\n *\n * @param byteArray the byte array to read from\n * @param position the position in the byte array to read from\n * @returns {*} the parsed 64-bit float\n * @throws error if buffer overread would occur\n * @access private\n */\n readDouble (byteArray, position) {\n if (position < 0) {\n throw 'littleEndianByteArrayParser.readDouble: position cannot be less than 0';\n }\n\n if (position + 8 > byteArray.length) {\n throw 'littleEndianByteArrayParser.readDouble: attempt to read past end of buffer';\n }\n\n // I am sure there is a better way than this but this should be safe\n const byteArrayForParsingFloat = new Uint8Array(8);\n\n byteArrayForParsingFloat[0] = byteArray[position];\n byteArrayForParsingFloat[1] = byteArray[position + 1];\n byteArrayForParsingFloat[2] = byteArray[position + 2];\n byteArrayForParsingFloat[3] = byteArray[position + 3];\n byteArrayForParsingFloat[4] = byteArray[position + 4];\n byteArrayForParsingFloat[5] = byteArray[position + 5];\n byteArrayForParsingFloat[6] = byteArray[position + 6];\n byteArrayForParsingFloat[7] = byteArray[position + 7];\n\n const floatArray = new Float64Array(byteArrayForParsingFloat.buffer);\n\n return floatArray[0];\n }\n};\n", "import ByteStream from './byteStream.js';\nimport DataSet from './dataSet.js';\nimport littleEndianByteArrayParser from './littleEndianByteArrayParser.js';\nimport readDicomElementExplicit from './readDicomElementExplicit.js';\n\n/**\n * Parses a DICOM P10 byte array and returns a DataSet object with the parsed elements. If the options\n * argument is supplied and it contains the untilTag property, parsing will stop once that\n * tag is encoutered. This can be used to parse partial byte streams.\n *\n * @param byteArray the byte array\n * @param options Optional options values\n * TransferSyntaxUID: String to specify a default raw transfer syntax UID.\n * Use the LEI transfer syntax for raw files, or the provided one for SCP transfers.\n * @returns {DataSet}\n * @throws error if an error occurs while parsing. The exception object will contain a property dataSet with the\n * elements successfully parsed before the error.\n */\n\nexport default function readPart10Header (byteArray, options = {}) {\n if (byteArray === undefined) {\n throw 'dicomParser.readPart10Header: missing required parameter \\'byteArray\\'';\n }\n\n const { TransferSyntaxUID } = options;\n const littleEndianByteStream = new ByteStream(littleEndianByteArrayParser, byteArray);\n\n function readPrefix() {\n if (littleEndianByteStream.getSize() <= 132 && TransferSyntaxUID) {\n return false;\n }\n littleEndianByteStream.seek(128);\n const prefix = littleEndianByteStream.readFixedString(4);\n\n if (prefix !== 'DICM') {\n const { TransferSyntaxUID } = options || {};\n if (!TransferSyntaxUID) {\n throw 'dicomParser.readPart10Header: DICM prefix not found at location 132 - this is not a valid DICOM P10 file.';\n }\n littleEndianByteStream.seek(0);\n return false;\n }\n return true;\n }\n\n // main function here\n function readTheHeader() {\n // Per the DICOM standard, the header is always encoded in Explicit VR Little Endian (see PS3.10, section 7.1)\n // so use littleEndianByteStream throughout this method regardless of the transfer syntax\n const isPart10 = readPrefix();\n\n const warnings = [];\n const elements = {};\n\n if (!isPart10) {\n littleEndianByteStream.position = 0;\n const metaHeaderDataSet = {\n elements: { x00020010: { tag: 'x00020010', vr: 'UI', Value: TransferSyntaxUID } },\n warnings,\n };\n // console.log('Returning metaHeaderDataSet', metaHeaderDataSet);\n return metaHeaderDataSet;\n }\n\n while (littleEndianByteStream.position < littleEndianByteStream.byteArray.length) {\n const position = littleEndianByteStream.position;\n const element = readDicomElementExplicit(littleEndianByteStream, warnings);\n\n if (element.tag > 'x0002ffff') {\n littleEndianByteStream.position = position;\n break;\n }\n // Cache the littleEndianByteArrayParser for meta header elements, since the rest of the data set may be big endian\n // and this parser will be needed later if the meta header values are to be read.\n element.parser = littleEndianByteArrayParser;\n elements[element.tag] = element;\n }\n\n const metaHeaderDataSet = new DataSet(littleEndianByteStream.byteArrayParser, littleEndianByteStream.byteArray, elements);\n\n metaHeaderDataSet.warnings = littleEndianByteStream.warnings;\n metaHeaderDataSet.position = littleEndianByteStream.position;\n\n return metaHeaderDataSet;\n }\n\n // This is where we actually start parsing\n return readTheHeader();\n}\n", "import alloc from './alloc.js';\nimport bigEndianByteArrayParser from './bigEndianByteArrayParser.js';\nimport ByteStream from './byteStream.js';\nimport DataSet from './dataSet.js';\nimport littleEndianByteArrayParser from './littleEndianByteArrayParser.js';\nimport readPart10Header from './readPart10Header.js';\nimport sharedCopy from './sharedCopy.js';\nimport * as byteArrayParser from './byteArrayParser.js';\nimport * as parseDicomDataSet from './parseDicomDataSet.js';\n\n// LEE (Little Endian Explicit) is the transfer syntax used in dimse operations when there is a split\n// between the header and data.\nconst LEE = '1.2.840.10008.1.2.1';\n\n// LEI (Little Endian Implicit) is the transfer syntax in raw files\nconst LEI = '1.2.840.10008.1.2';\n\n// BEI (Big Endian Implicit) is deprecated, but needs special parse handling\nconst BEI = '1.2.840.10008.1.2.2';\n\n/**\n * Parses a DICOM P10 byte array and returns a DataSet object with the parsed elements.\n * If the options argument is supplied and it contains the untilTag property, parsing\n * will stop once that tag is encoutered. This can be used to parse partial byte streams.\n *\n * @param byteArray the byte array\n * @param options object to control parsing behavior (optional)\n * @returns {DataSet}\n * @throws error if an error occurs while parsing. The exception object will contain a\n * property dataSet with the elements successfully parsed before the error.\n */\n\nexport default function parseDicom(byteArray, options = {}) {\n if (byteArray === undefined) {\n throw new Error('dicomParser.parseDicom: missing required parameter \\'byteArray\\'');\n }\n\n \n const readTransferSyntax = (metaHeaderDataSet) => {\n if (metaHeaderDataSet.elements.x00020010 === undefined) {\n throw new Error('dicomParser.parseDicom: missing required meta header attribute 0002,0010');\n }\n\n const transferSyntaxElement = metaHeaderDataSet.elements.x00020010;\n return transferSyntaxElement && transferSyntaxElement.Value ||\n byteArrayParser.readFixedString(byteArray, transferSyntaxElement.dataOffset, transferSyntaxElement.length);\n }\n\n function isExplicit(transferSyntax) {\n // implicit little endian\n if (transferSyntax === '1.2.840.10008.1.2') {\n return false;\n }\n\n // all other transfer syntaxes should be explicit\n return true;\n }\n\n function getDataSetByteStream(transferSyntax, position) {\n // Detect whether we are inside a browser or Node.js\n const isNode = (Object.prototype.toString.call(typeof process !== 'undefined' ? process : 0) === '[object process]');\n\n if (transferSyntax === '1.2.840.10008.1.2.1.99') {\n // if an infalter callback is registered, use it\n if (options && options.inflater) {\n const fullByteArrayCallback = options.inflater(byteArray, position);\n\n return new ByteStream(littleEndianByteArrayParser, fullByteArrayCallback, 0);\n }\n // if running on node, use the zlib library to inflate\n // http://stackoverflow.com/questions/4224606/how-to-check-whether-a-script-is-running-under-node-js\n else if (isNode === true) {\n // inflate it\n const zlib = require('zlib');\n const deflatedBuffer = sharedCopy(byteArray, position, byteArray.length - position);\n const inflatedBuffer = zlib.inflateRawSync(deflatedBuffer);\n\n // create a single byte array with the full header bytes and the inflated bytes\n const fullByteArrayBuffer = alloc(byteArray, inflatedBuffer.length + position);\n\n byteArray.copy(fullByteArrayBuffer, 0, 0, position);\n inflatedBuffer.copy(fullByteArrayBuffer, position);\n\n return new ByteStream(littleEndianByteArrayParser, fullByteArrayBuffer, 0);\n }\n // if pako is defined - use it. This is the web browser path\n // https://github.com/nodeca/pako\n else if (typeof pako !== 'undefined') {\n // inflate it\n const deflated = byteArray.slice(position);\n const inflated = pako.inflateRaw(deflated);\n\n // create a single byte array with the full header bytes and the inflated bytes\n const fullByteArray = alloc(byteArray, inflated.length + position);\n\n fullByteArray.set(byteArray.slice(0, position), 0);\n fullByteArray.set(inflated, position);\n\n return new ByteStream(littleEndianByteArrayParser, fullByteArray, 0);\n }\n\n // throw exception since no inflater is available\n throw 'dicomParser.parseDicom: no inflater available to handle deflate transfer syntax';\n }\n\n // explicit big endian\n if (transferSyntax === BEI) {\n return new ByteStream(bigEndianByteArrayParser, byteArray, position);\n }\n\n // all other transfer syntaxes are little endian; only the pixel encoding differs\n // make a new stream so the metaheader warnings don't come along for the ride\n return new ByteStream(littleEndianByteArrayParser, byteArray, position);\n }\n\n function mergeDataSets(metaHeaderDataSet, instanceDataSet) {\n for (const propertyName in metaHeaderDataSet.elements) {\n if (metaHeaderDataSet.elements.hasOwnProperty(propertyName)) {\n instanceDataSet.elements[propertyName] = metaHeaderDataSet.elements[propertyName];\n }\n }\n\n if (metaHeaderDataSet.warnings !== undefined) {\n instanceDataSet.warnings = metaHeaderDataSet.warnings.concat(instanceDataSet.warnings);\n }\n\n return instanceDataSet;\n }\n\n function readDataSet(metaHeaderDataSet) {\n const transferSyntax = readTransferSyntax(metaHeaderDataSet);\n const explicit = isExplicit(transferSyntax);\n const dataSetByteStream = getDataSetByteStream(transferSyntax, metaHeaderDataSet.position);\n\n const elements = {};\n const dataSet = new DataSet(dataSetByteStream.byteArrayParser, dataSetByteStream.byteArray, elements);\n\n dataSet.warnings = dataSetByteStream.warnings;\n\n try {\n if (explicit) {\n parseDicomDataSet.parseDicomDataSetExplicit(dataSet, dataSetByteStream, dataSetByteStream.byteArray.length, options);\n } else {\n parseDicomDataSet.parseDicomDataSetImplicit(dataSet, dataSetByteStream, dataSetByteStream.byteArray.length, options);\n }\n } catch (e) {\n const ex = {\n exception: e,\n dataSet\n };\n\n throw ex;\n }\n\n return dataSet;\n }\n\n // main function here\n function parseTheByteStream() {\n const metaHeaderDataSet = readPart10Header(byteArray, options);\n const dataSet = readDataSet(metaHeaderDataSet);\n\n return mergeDataSets(metaHeaderDataSet, dataSet);\n }\n\n // This is where we actually start parsing\n return parseTheByteStream();\n}\n\nexport { LEI, LEE, BEI };", "import alloc from './alloc.js';\nimport ByteStream from './byteStream.js';\nimport readSequenceItem from './readSequenceItem.js';\nimport sharedCopy from './sharedCopy.js';\n\n/**\n * Functionality for extracting encapsulated pixel data\n */\n\nconst calculateBufferSize = (fragments, startFragment, numFragments) => {\n let bufferSize = 0;\n\n for (let i = startFragment; i < startFragment + numFragments; i++) {\n bufferSize += fragments[i].length;\n }\n\n return bufferSize;\n};\n\n/**\n * Returns the encapsulated pixel data from the specified fragments. Use this function when you know\n * the fragments you want to extract data from. See\n *\n * @param dataSet - the dataSet containing the encapsulated pixel data\n * @param pixelDataElement - the pixel data element (x7fe00010) to extract the fragment data from\n * @param startFragmentIndex - zero based index of the first fragment to extract from\n * @param [numFragments] - the number of fragments to extract from, default is 1\n * @param [fragments] - optional array of objects describing each fragment (offset, position, length)\n * @returns {object} byte array with the encapsulated pixel data\n */\nexport default function readEncapsulatedPixelDataFromFragments (dataSet, pixelDataElement, startFragmentIndex, numFragments, fragments) {\n // default values\n numFragments = numFragments || 1;\n fragments = fragments || pixelDataElement.fragments;\n\n // check parameters\n if (dataSet === undefined) {\n throw 'dicomParser.readEncapsulatedPixelDataFromFragments: missing required parameter \\'dataSet\\'';\n }\n if (pixelDataElement === undefined) {\n throw 'dicomParser.readEncapsulatedPixelDataFromFragments: missing required parameter \\'pixelDataElement\\'';\n }\n if (startFragmentIndex === undefined) {\n throw 'dicomParser.readEncapsulatedPixelDataFromFragments: missing required parameter \\'startFragmentIndex\\'';\n }\n if (numFragments === undefined) {\n throw 'dicomParser.readEncapsulatedPixelDataFromFragments: missing required parameter \\'numFragments\\'';\n }\n if (pixelDataElement.tag !== 'x7fe00010') {\n throw 'dicomParser.readEncapsulatedPixelDataFromFragments: parameter \\'pixelDataElement\\' refers to non pixel data tag (expected tag = x7fe00010';\n }\n if (pixelDataElement.encapsulatedPixelData !== true) {\n throw 'dicomParser.readEncapsulatedPixelDataFromFragments: parameter \\'pixelDataElement\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (pixelDataElement.hadUndefinedLength !== true) {\n throw 'dicomParser.readEncapsulatedPixelDataFromFragments: parameter \\'pixelDataElement\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (pixelDataElement.basicOffsetTable === undefined) {\n throw 'dicomParser.readEncapsulatedPixelDataFromFragments: parameter \\'pixelDataElement\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (pixelDataElement.fragments === undefined) {\n throw 'dicomParser.readEncapsulatedPixelDataFromFragments: parameter \\'pixelDataElement\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (pixelDataElement.fragments.length <= 0) {\n throw 'dicomParser.readEncapsulatedPixelDataFromFragments: parameter \\'pixelDataElement\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (startFragmentIndex < 0) {\n throw 'dicomParser.readEncapsulatedPixelDataFromFragments: parameter \\'startFragmentIndex\\' must be >= 0';\n }\n if (startFragmentIndex >= pixelDataElement.fragments.length) {\n throw 'dicomParser.readEncapsulatedPixelDataFromFragments: parameter \\'startFragmentIndex\\' must be < number of fragments';\n }\n if (numFragments < 1) {\n throw 'dicomParser.readEncapsulatedPixelDataFromFragments: parameter \\'numFragments\\' must be > 0';\n }\n if (startFragmentIndex + numFragments > pixelDataElement.fragments.length) {\n throw 'dicomParser.readEncapsulatedPixelDataFromFragments: parameter \\'startFragment\\' + \\'numFragments\\' < number of fragments';\n }\n\n // create byte stream on the data for this pixel data element\n const byteStream = new ByteStream(dataSet.byteArrayParser, dataSet.byteArray, pixelDataElement.dataOffset);\n\n // seek past the basic offset table (no need to parse it again since we already have)\n const basicOffsetTable = readSequenceItem(byteStream);\n\n if (basicOffsetTable.tag !== 'xfffee000') {\n throw 'dicomParser.readEncapsulatedPixelData: missing basic offset table xfffee000';\n }\n\n byteStream.seek(basicOffsetTable.length);\n\n const fragmentZeroPosition = byteStream.position;\n\n // tag + length\n const fragmentHeaderSize = 8;\n\n // if there is only one fragment, return a view on this array to avoid copying\n if (numFragments === 1) {\n return sharedCopy(byteStream.byteArray, fragmentZeroPosition + fragments[startFragmentIndex].offset + fragmentHeaderSize, fragments[startFragmentIndex].length);\n }\n\n // more than one fragment, combine all of the fragments into one buffer\n const bufferSize = calculateBufferSize(fragments, startFragmentIndex, numFragments);\n const pixelData = alloc(byteStream.byteArray, bufferSize);\n let pixelDataIndex = 0;\n\n for (let i = startFragmentIndex; i < startFragmentIndex + numFragments; i++) {\n let fragmentOffset = fragmentZeroPosition + fragments[i].offset + fragmentHeaderSize;\n\n for (let j = 0; j < fragments[i].length; j++) {\n pixelData[pixelDataIndex++] = byteStream.byteArray[fragmentOffset++];\n }\n }\n\n return pixelData;\n}\n", "import readEncapsulatedPixelDataFromFragments from './readEncapsulatedPixelDataFromFragments.js';\n\n/**\n * Functionality for extracting encapsulated pixel data\n */\n\nconst findFragmentIndexWithOffset = (fragments, offset) => {\n for (let i = 0; i < fragments.length; i++) {\n if (fragments[i].offset === offset) {\n return i;\n }\n }\n};\n\nconst calculateNumberOfFragmentsForFrame = (frameIndex, basicOffsetTable, fragments, startFragmentIndex) => {\n // special case for last frame\n if (frameIndex === basicOffsetTable.length - 1) {\n return fragments.length - startFragmentIndex;\n }\n\n // iterate through each fragment looking for the one matching the offset for the next frame\n const nextFrameOffset = basicOffsetTable[frameIndex + 1];\n\n for (let i = startFragmentIndex + 1; i < fragments.length; i++) {\n if (fragments[i].offset === nextFrameOffset) {\n return i - startFragmentIndex;\n }\n }\n\n throw 'dicomParser.calculateNumberOfFragmentsForFrame: could not find fragment with offset matching basic offset table';\n};\n\n/**\n * Returns the pixel data for the specified frame in an encapsulated pixel data element that has a non\n * empty basic offset table. Note that this function will fail if the basic offset table is empty - in that\n * case you need to determine which fragments map to which frames and read them using\n * readEncapsulatedPixelDataFromFragments(). Also see the function createJEPGBasicOffsetTable() to see\n * how a basic offset table can be created for JPEG images\n *\n * @param dataSet - the dataSet containing the encapsulated pixel data\n * @param pixelDataElement - the pixel data element (x7fe00010) to extract the frame from\n * @param frameIndex - the zero based frame index\n * @param [basicOffsetTable] - optional array of starting offsets for frames\n * @param [fragments] - optional array of objects describing each fragment (offset, position, length)\n * @returns {object} with the encapsulated pixel data\n */\nexport default function readEncapsulatedImageFrame (dataSet, pixelDataElement, frameIndex, basicOffsetTable, fragments) {\n // default parameters\n basicOffsetTable = basicOffsetTable || pixelDataElement.basicOffsetTable;\n fragments = fragments || pixelDataElement.fragments;\n\n // Validate parameters\n if (dataSet === undefined) {\n throw 'dicomParser.readEncapsulatedImageFrame: missing required parameter \\'dataSet\\'';\n }\n if (pixelDataElement === undefined) {\n throw 'dicomParser.readEncapsulatedImageFrame: missing required parameter \\'pixelDataElement\\'';\n }\n if (frameIndex === undefined) {\n throw 'dicomParser.readEncapsulatedImageFrame: missing required parameter \\'frameIndex\\'';\n }\n if (basicOffsetTable === undefined) {\n throw 'dicomParser.readEncapsulatedImageFrame: parameter \\'pixelDataElement\\' does not have basicOffsetTable';\n }\n if (pixelDataElement.tag !== 'x7fe00010') {\n throw 'dicomParser.readEncapsulatedImageFrame: parameter \\'pixelDataElement\\' refers to non pixel data tag (expected tag = x7fe00010)';\n }\n if (pixelDataElement.encapsulatedPixelData !== true) {\n throw 'dicomParser.readEncapsulatedImageFrame: parameter \\'pixelDataElement\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (pixelDataElement.hadUndefinedLength !== true) {\n throw 'dicomParser.readEncapsulatedImageFrame: parameter \\'pixelDataElement\\' refers to pixel data element that does not have undefined length';\n }\n if (pixelDataElement.fragments === undefined) {\n throw 'dicomParser.readEncapsulatedImageFrame: parameter \\'pixelDataElement\\' refers to pixel data element that does not have fragments';\n }\n if (basicOffsetTable.length === 0) {\n throw 'dicomParser.readEncapsulatedImageFrame: basicOffsetTable has zero entries';\n }\n if (frameIndex < 0) {\n throw 'dicomParser.readEncapsulatedImageFrame: parameter \\'frameIndex\\' must be >= 0';\n }\n if (frameIndex >= basicOffsetTable.length) {\n throw 'dicomParser.readEncapsulatedImageFrame: parameter \\'frameIndex\\' must be < basicOffsetTable.length';\n }\n\n // find starting fragment based on the offset for the frame in the basic offset table\n const offset = basicOffsetTable[frameIndex];\n const startFragmentIndex = findFragmentIndexWithOffset(fragments, offset);\n\n if (startFragmentIndex === undefined) {\n throw 'dicomParser.readEncapsulatedImageFrame: unable to find fragment that matches basic offset table entry';\n }\n\n // calculate the number of fragments for this frame\n const numFragments = calculateNumberOfFragmentsForFrame(frameIndex, basicOffsetTable, fragments, startFragmentIndex);\n\n // now extract the frame from the fragments\n return readEncapsulatedPixelDataFromFragments(dataSet, pixelDataElement, startFragmentIndex, numFragments, fragments);\n}\n", "import readEncapsulatedImageFrame from './readEncapsulatedImageFrame.js';\nimport readEncapsulatedPixelDataFromFragments from './readEncapsulatedPixelDataFromFragments.js';\n\n/**\n * Functionality for extracting encapsulated pixel data\n */\n\nlet deprecatedNoticeLogged = false;\n\n/**\n * Returns the pixel data for the specified frame in an encapsulated pixel data element. If no basic offset\n * table is present, it assumes that all fragments are for one frame. Note that this assumption/logic is not\n * valid for multi-frame instances so this function has been deprecated and will eventually be removed. Code\n * should be updated to use readEncapsulatedPixelDataFromFragments() or readEncapsulatedImageFrame()\n *\n * @deprecated since version 1.6 - use readEncapsulatedPixelDataFromFragments() or readEncapsulatedImageFrame()\n * @param dataSet - the dataSet containing the encapsulated pixel data\n * @param pixelDataElement - the pixel data element (x7fe00010) to extract the frame from\n * @param frame - the zero based frame index\n * @returns {object} with the encapsulated pixel data\n */\nexport default function readEncapsulatedPixelData (dataSet, pixelDataElement, frame) {\n if (!deprecatedNoticeLogged) {\n deprecatedNoticeLogged = true;\n\n if (console && console.log) {\n console.log('WARNING: dicomParser.readEncapsulatedPixelData() has been deprecated');\n }\n }\n\n if (dataSet === undefined) {\n throw 'dicomParser.readEncapsulatedPixelData: missing required parameter \\'dataSet\\'';\n }\n if (pixelDataElement === undefined) {\n throw 'dicomParser.readEncapsulatedPixelData: missing required parameter \\'element\\'';\n }\n if (frame === undefined) {\n throw 'dicomParser.readEncapsulatedPixelData: missing required parameter \\'frame\\'';\n }\n if (pixelDataElement.tag !== 'x7fe00010') {\n throw 'dicomParser.readEncapsulatedPixelData: parameter \\'element\\' refers to non pixel data tag (expected tag = x7fe00010)';\n }\n if (pixelDataElement.encapsulatedPixelData !== true) {\n throw 'dicomParser.readEncapsulatedPixelData: parameter \\'element\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (pixelDataElement.hadUndefinedLength !== true) {\n throw 'dicomParser.readEncapsulatedPixelData: parameter \\'element\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (pixelDataElement.basicOffsetTable === undefined) {\n throw 'dicomParser.readEncapsulatedPixelData: parameter \\'element\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (pixelDataElement.fragments === undefined) {\n throw 'dicomParser.readEncapsulatedPixelData: parameter \\'element\\' refers to pixel data element that does not have encapsulated pixel data';\n }\n if (frame < 0) {\n throw 'dicomParser.readEncapsulatedPixelData: parameter \\'frame\\' must be >= 0';\n }\n\n // If the basic offset table is not empty, we can extract the frame\n if (pixelDataElement.basicOffsetTable.length !== 0) {\n return readEncapsulatedImageFrame(dataSet, pixelDataElement, frame);\n }\n\n // No basic offset table, assume all fragments are for one frame - NOTE that this is NOT a valid\n // assumption but is the original behavior so we are keeping it for now\n return readEncapsulatedPixelDataFromFragments(dataSet, pixelDataElement, 0, pixelDataElement.fragments.length);\n}\n", "import {\n isStringVr,\n isPrivateTag,\n parsePN,\n parseTM,\n parseDA,\n explicitElementToString,\n explicitDataSetToJS,\n createJPEGBasicOffsetTable\n} from './util/index.js';\n\nimport { parseDicomDataSetExplicit, parseDicomDataSetImplicit } from './parseDicomDataSet.js';\nimport { readFixedString } from './byteArrayParser.js';\n\nimport alloc from './alloc.js';\nimport version from './version.js';\nimport bigEndianByteArrayParser from './bigEndianByteArrayParser.js';\nimport ByteStream from './byteStream.js';\nimport sharedCopy from './sharedCopy.js';\nimport DataSet from './dataSet.js';\nimport findAndSetUNElementLength from './findAndSetUNElementLength.js';\nimport findEndOfEncapsulatedElement from './findEndOfEncapsulatedPixelData.js';\nimport findItemDelimitationItemAndSetElementLength from './findItemDelimitationItem.js';\nimport littleEndianByteArrayParser from './littleEndianByteArrayParser.js';\nimport parseDicom, { LEI, LEE } from './parseDicom.js';\nimport readDicomElementExplicit from './readDicomElementExplicit.js';\nimport readDicomElementImplicit from './readDicomElementImplicit.js';\nimport readEncapsulatedImageFrame from './readEncapsulatedImageFrame.js';\nimport readEncapsulatedPixelData from './readEncapsulatedPixelData.js';\nimport readEncapsulatedPixelDataFromFragments from './readEncapsulatedPixelDataFromFragments.js';\nimport readPart10Header from './readPart10Header.js';\nimport readSequenceItemsExplicit from './readSequenceElementExplicit.js';\nimport readSequenceItemsImplicit from './readSequenceElementImplicit.js';\nimport readSequenceItem from './readSequenceItem.js';\nimport readTag from './readTag.js';\n\nconst dicomParser = {\n isStringVr,\n isPrivateTag,\n parsePN,\n parseTM,\n parseDA,\n explicitElementToString,\n explicitDataSetToJS,\n createJPEGBasicOffsetTable,\n parseDicomDataSetExplicit,\n parseDicomDataSetImplicit,\n readFixedString,\n alloc,\n version,\n bigEndianByteArrayParser,\n ByteStream,\n sharedCopy,\n DataSet,\n findAndSetUNElementLength,\n findEndOfEncapsulatedElement,\n findItemDelimitationItemAndSetElementLength,\n littleEndianByteArrayParser,\n parseDicom,\n readDicomElementExplicit,\n readDicomElementImplicit,\n readEncapsulatedImageFrame,\n readEncapsulatedPixelData,\n readEncapsulatedPixelDataFromFragments,\n readPart10Header,\n readSequenceItemsExplicit,\n readSequenceItemsImplicit,\n readSequenceItem,\n readTag,\n LEI,\n LEE,\n};\n\nexport {\n isStringVr,\n isPrivateTag,\n parsePN,\n parseTM,\n parseDA,\n explicitElementToString,\n explicitDataSetToJS,\n createJPEGBasicOffsetTable,\n parseDicomDataSetExplicit,\n parseDicomDataSetImplicit,\n readFixedString,\n alloc,\n version,\n bigEndianByteArrayParser,\n ByteStream,\n sharedCopy,\n DataSet,\n findAndSetUNElementLength,\n findEndOfEncapsulatedElement,\n findItemDelimitationItemAndSetElementLength,\n littleEndianByteArrayParser,\n parseDicom,\n readDicomElementExplicit,\n readDicomElementImplicit,\n readEncapsulatedImageFrame,\n readEncapsulatedPixelData,\n readEncapsulatedPixelDataFromFragments,\n readPart10Header,\n readSequenceItemsExplicit,\n readSequenceItemsImplicit,\n readSequenceItem,\n readTag\n};\n\nexport default dicomParser;\n", " \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 = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 1);\n", "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Doctype = exports.CDATA = exports.Tag = exports.Style = exports.Script = exports.Comment = exports.Directive = exports.Text = exports.Root = exports.isTag = exports.ElementType = void 0;\n/** Types of elements found in htmlparser2's DOM */\nvar ElementType;\n(function (ElementType) {\n /** Type for the root element of a document */\n ElementType[\"Root\"] = \"root\";\n /** Type for Text */\n ElementType[\"Text\"] = \"text\";\n /** Type for */\n ElementType[\"Directive\"] = \"directive\";\n /** Type for */\n ElementType[\"Comment\"] = \"comment\";\n /** Type for