{"version":3,"file":"static/js/index.cf29010f.js","sources":["webpack://@jotforminc/inbox/../../libs/decryption-worker/src/CorsWorker.js","webpack://@jotforminc/inbox/../../libs/apploaders/src/Circle/index.js","webpack://@jotforminc/inbox/../../libs/placeholder/src/WorkflowStatus.js","webpack://@jotforminc/inbox/../../libs/preview/src/hocs/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/ViewWithAlignment/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/Label/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/LabelWithAlignment/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/AnswerWithAlignment/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/Imageline/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/Hypertext/index.js","webpack://@jotforminc/inbox/../../libs/fileuploadfield/src/components/FileUploadField/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/fields/Address/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/utils/styled.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/fields/Appointment/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/AssigneeLine/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/AssigneeList/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/ImageList/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/CommaList/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/OptionItem/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/OptionList/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/Checkbox/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/CheckboxList/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/fields/Fileupload/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/Line/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/Emoji/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/components/Tableview/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/fields/Matrix/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/fields/Rating/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/fields/Sheetbox/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/fields/Textarea/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/fields/Payments/StyledComponents.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/fields/Submission/SubmittedVia/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/fields/Submission/Thread/index.js","webpack://@jotforminc/inbox/../../libs/answer-fields/src/fields/UserInfo/index.js","webpack://@jotforminc/inbox/../../libs/signature/src/sc/scSignature.js","webpack://@jotforminc/inbox/../../libs/workflow-components/src/SubmissionThread/scModal.js","webpack://@jotforminc/inbox/../../libs/user-list/src/styles/index.js","webpack://@jotforminc/inbox/../../libs/workflow-components/src/components/IndependentReassign.js","webpack://@jotforminc/inbox/../../libs/enterprise-components/src/components/Cover/StyledElements.tsx","webpack://@jotforminc/inbox/../../libs/enterprise-components/src/components/Image/StyledElements.tsx","webpack://@jotforminc/inbox/../../libs/workflow-components/src/SubmissionThread/EntryTypes.js","webpack://@jotforminc/inbox/../../libs/workflow-components/src/components/WorkflowStatus.js","webpack://@jotforminc/inbox/../../libs/workflow-components/src/SubmissionThread/SubThreadToggle.js","webpack://@jotforminc/inbox/../../libs/search-filter/src/components/IconRenderer.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/sc/scIndex.js","webpack://@jotforminc/inbox/../../libs/date-picker/src/index.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/components/Dropdown.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/sc/scSettings.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/sc/scAssigneeList.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/components/ResourcePicker.js","webpack://@jotforminc/inbox/../../libs/email-input/src/styles/index.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/components/AvatarHolder.js","webpack://@jotforminc/inbox/../../libs/dropdown-with-extra-elements/src/components/OptionRenderer.js","webpack://@jotforminc/inbox/../../libs/dropdown-with-extra-elements/src/components/ContainerRenderer.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/components/DropdownWithDetails.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/sc/scRevokeAccess.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/sc/scUserList.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/containers/sections/InviteByAppPrefill.js","webpack://@jotforminc/inbox/../../libs/schedule-panel/src/components/Dropdown.js","webpack://@jotforminc/inbox/../../libs/schedule-panel/src/scIndex.js","webpack://@jotforminc/inbox/../../libs/schedule-panel/src/components/Toggle.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/sc/scScheduleReminder.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/sc/scSharedWithNoOne.js","webpack://@jotforminc/inbox/../../libs/enterprise-promotions-share-panel/src/components/CollaborationModal/CollaborationModal.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/sc/scGenerateNewLink.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/components/SettingsButton.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/sc/scAccessType.js","webpack://@jotforminc/inbox/../../libs/share-panel/src/sc/scInvitePredefinedUsersSection.js","webpack://@jotforminc/inbox/../../libs/workflow-components/src/SubmissionThread/ActionLayout.js","webpack://@jotforminc/inbox/../../libs/workflow-components/src/components/ErrorAction.js","webpack://@jotforminc/inbox/../../libs/workflow-components/src/components/MultipleApprovalTakeOver.js","webpack://@jotforminc/inbox/../../libs/workflow-components/src/containers/WorkflowActions.js","webpack://@jotforminc/inbox/../../libs/apploaders/src/Inbox/index.js","webpack://@jotforminc/inbox/../../libs/agent-components/src/components/History.js","webpack://@jotforminc/inbox/./src/components/Tags/index.js","webpack://@jotforminc/inbox/../../libs/workflow-components/src/components/WorkflowButton.js","webpack://@jotforminc/inbox/../../libs/message/src/components/index.js","webpack://@jotforminc/inbox/../../libs/loading/src/components/Spinner.js","webpack://@jotforminc/inbox/./src/contexts/TagSuggestions.js","webpack://@jotforminc/inbox/./src/components/SubmissionTags/index.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/FormPicker/FormItem/styled.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/PortalPicker/defaults/scPortalOption.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/PortalPicker/defaults/PortalOption.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/FormPicker/CheckBox.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/ResourcePicker/items/Sheet/index.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/ResourcePicker/items/Reports/index.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/ResourcePicker/items/Approval/index.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/ResourcePicker/items/Sign/styles.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/ResourcePicker/items/Sign/index.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/ResourcePicker/items/Board/index.js","webpack://@jotforminc/inbox/../../libs/smart-list/src/components/SmartList/ControlBar/scControlBar.js","webpack://@jotforminc/inbox/../../libs/smart-list/src/components/SmartList/ControlBar/CheckBox.js","webpack://@jotforminc/inbox/../../libs/smart-list/src/components/SmartList/ControlBar/Dropdown.js","webpack://@jotforminc/inbox/../../libs/smart-list/src/components/SmartList/index.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/FormPicker/FormList/index.js","webpack://@jotforminc/inbox/../../libs/picker-modal/src/styles/ScRB.js","webpack://@jotforminc/inbox/../../libs/header-components/src/components/Navigation/ScPickerModal.js","webpack://@jotforminc/inbox/../../libs/header-components/src/components/Navigation/ScButton.js","webpack://@jotforminc/inbox/../../libs/enterprise-components/src/components/CreateNewTeamModal/CreateTeamButton.tsx","webpack://@jotforminc/inbox/./src/contexts/Assistant/constants.js","webpack://@jotforminc/inbox/./src/contexts/Assistant/index.js","webpack://@jotforminc/inbox/../../libs/apploaders/src/Container/index.js","webpack://@jotforminc/inbox/../../libs/common-button/src/components/Button.js","webpack://@jotforminc/inbox/../../libs/form-common/src/appointment.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Range.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Rating.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Slider.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Spinner.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Textarea.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Textbox.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Widget.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/helpers/ProductContainer.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Autocomp.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Appointment.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Pagebreak.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/JotCaptcha.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/ReCaptcha.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/HCaptcha.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Checkbox.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Timev2.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Datetime.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Dropdown.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Email.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/FilepickerIO.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Fullname.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Head.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Hidden.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Inline.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Location.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Matrix.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/helpers/PaypalSPBButtons.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Radio.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Time.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/fields/Imagechoice.js","webpack://@jotforminc/inbox/../../libs/form-fields/src/helpers/PaypalCommercePlatform.js","webpack://@jotforminc/inbox/../../libs/loading/src/components/Loading.js","webpack://@jotforminc/inbox/../../libs/login-flow/src/components/Password/scPassword.js","webpack://@jotforminc/inbox/../../libs/pie-timer/src/sc/scPieTimer.js","webpack://@jotforminc/inbox/../../libs/two-factor-settings/src/components/styled.js","webpack://@jotforminc/inbox/../../libs/two-factor-settings/src/sc/scTwoFactorSettings.js","webpack://@jotforminc/inbox/../../libs/option-group/src/components/StyledComponents.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/PortalPicker/defaults/scPortalItem.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/PortalPicker/defaults/PortalItemDefaults/TitleRenderer.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/PortalPicker/defaults/PortalItemDefaults/DescriptionRenderer.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/PortalPicker/defaults/PortalItemDefaults/ItemContentRenderer.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/PortalPicker/defaults/PortalItemDefaults/IconRenderer.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/PortalPicker/defaults/PortalItemDefaults/commonCss.js","webpack://@jotforminc/inbox/../../libs/resource-picker/src/components/PortalPicker/defaults/SmallPortalItem.js","webpack://@jotforminc/inbox/../../libs/styled-modal/src/components/StyledModal/styled.js","webpack://@jotforminc/inbox/../../libs/toggle/src/index.js","webpack://@jotforminc/inbox/../../libs/tracking/src/utils/TrackingManager.ts"],"sourcesContent":["import { UnavailableClass } from './UnavailableClass';\nconst WorkerSafe = window.Worker || UnavailableClass;\n/**\n * A Worker that can be run on a different origin by respecting CORS\n * By default, a Worker constructor that uses an url as its parameters ignores CORS\n * and fails on a different origin.\n * This way we can run web worker on scripts served by a CDN\n *\n * @see https://github.com/webpack/webpack/discussions/14648#discussioncomment-7844340\n */ export class CorsWorker extends WorkerSafe {\n constructor(url, options){\n const absoluteUrl = new URL(url, window.location.href).toString();\n const workerSource = `\\\n const urlString = ${JSON.stringify(absoluteUrl)}\n const originURL = new URL(urlString)\n const isValidUrl = (urlString) => { \n try { return Boolean(new URL(urlString, originURL)) } catch(e){ return false } \n }\n const originalImportScripts = self.importScripts\n self.importScripts = (url) => {\n /** NOTE: 1 */\n if (url.startsWith(\"blob:\") && isValidUrl(url.replace(\"blob:\", \"\"))){\n const urlWithoutBlob = url.replace(\"blob:\", \"\")\n const { pathname } = new URL(urlWithoutBlob, originURL)\n url = pathname && pathname.substring(1) /** NOTE: 2 */\n } else if (url.startsWith(\"/static/js/\") && originURL.pathname.startsWith(\"/\")) { /** NOTE: 3 */\n url = originURL.pathname.split(\"/\").slice(0, -3).join(\"/\") + url;\n }\n originalImportScripts.call(self, new URL(url, originURL).toString())\n }\n importScripts(urlString);\n`;\n const blob = new window.Blob([\n workerSource\n ], {\n type: 'application/javascript'\n });\n const objectURL = URL.createObjectURL(blob);\n super(objectURL, options);\n URL.revokeObjectURL(objectURL);\n }\n}\n","/* eslint-disable react/prop-types */ import { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport Styled from 'styled-components';\nimport Container from '../Container';\nexport const LoaderSvg = Styled.svg`\nwidth: 100%;\nheight: 100%;\n.circle {\n fill: none;\n stroke-linecap: round;\n stroke-linejoin: round;\n stroke-width: 10px;\n stroke-dasharray: 140px;\n stroke-dashoffset: 139px;\n transform: rotate(180deg);\n}\n.c1 {\n animation-name: circleAnim1, color;\n animation-fill-mode: backwards;\n animation-duration: 1.5s, 6s;\n transform-origin: center;\n animation-direction: normal;\n animation-iteration-count: infinite;\n animation-timing-function: cubic-bezier(0.21, 0.09, 0.48, 0.65), ease-out;\n}\n\n@keyframes circleAnim1 {\n 0% { stroke-dashoffset: 139px; }\n 50% {\n stroke-dashoffset: 30px;\n transform: rotate(400deg);\n }\n 100% {\n stroke-dashoffset: 140px;\n transform: rotate(900deg);\n }\n}\n@keyframes color {\n 0% { stroke: #0099ff; }\n 24.9% { stroke: #0099ff; }\n 25% {\n stroke: #ff6100;\n }\n 49.9% {\n stroke: #ff6100;\n }\n 50% {\n stroke: #ffb629;\n }\n 74.9% {\n stroke: #ffb629;\n }\n 75% {\n stroke: #e4ebfc;\n }\n 100% { stroke: #e4ebfc; }\n}\n`;\nconst Loader = ({ size, className })=>{\n return /*#__PURE__*/ _jsx(Container, {\n size: size,\n className: className,\n children: /*#__PURE__*/ _jsx(LoaderSvg, {\n style: {\n overflow: 'visible'\n },\n width: \"60\",\n height: \"60\",\n viewBox: \"0 0 60 60\",\n children: /*#__PURE__*/ _jsx(\"circle\", {\n className: \"circle c1\",\n cx: \"30\",\n cy: \"30\",\n r: \"20.87\",\n stroke: \"#0099ff\"\n })\n })\n });\n};\nexport default Loader;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { _ as _object_without_properties } from \"@swc/helpers/_/_object_without_properties\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport styled from 'styled-components';\nimport classNames from 'classnames';\nimport Placeholder from './PlaceHolder';\nconst StyledWorkflowStatus = styled.div`\n .jfPlaceholder {\n &-row {\n height: 14px;\n\n &.forShort {\n width: 72.5%;\n }\n\n &.forLong {\n margin-top: 10px;\n }\n }\n }\n`;\nconst WorkflowStatus = (_param)=>{\n var { className } = _param, props = _object_without_properties(_param, [\n \"className\"\n ]);\n return /*#__PURE__*/ _jsxs(StyledWorkflowStatus, _object_spread_props(_object_spread({\n className: classNames('jfPlaceholder-wrapper', className)\n }, props), {\n children: [\n /*#__PURE__*/ _jsx(\"div\", {\n className: \"jfPlaceholder-row forShort\",\n children: /*#__PURE__*/ _jsx(Placeholder, {\n animated: true\n })\n }),\n /*#__PURE__*/ _jsx(\"div\", {\n className: \"jfPlaceholder-row forLong\",\n children: /*#__PURE__*/ _jsx(Placeholder, {\n animated: true\n })\n })\n ]\n }));\n};\nWorkflowStatus.propTypes = {\n className: PropTypes.string\n};\nWorkflowStatus.defaultProps = {\n className: ''\n};\nexport default WorkflowStatus;\n","/* eslint-disable max-len */ import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_without_properties } from \"@swc/helpers/_/_object_without_properties\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React, { useState, useEffect } from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport Preview from '../components/Preview';\nconst getDisplayName = (WrappedComponent)=>WrappedComponent.displayName || WrappedComponent.name || 'Component';\nconst StyledPreviewWrapper = Styled.div`\n .clickableImageWrapper {\n cursor: pointer;\n border-radius: 4px;\n border: 1px solid #D9DAE4;\n overflow: hidden;\n transition: .3s ease-in;\n cursor: pointer;\n position: relative;\n height: 80px;\n\n &::before,\n &::after {\n content: '';\n position: absolute;\n opacity: 0;\n visibility: hidden;\n pointer-events: none;\n transition: .2s ease-in;\n }\n\n &::before {\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n background-color: rgba(0, 0, 0, 0.4);\n z-index: 2;\n }\n\n &::after {\n content: \"\";\n top: 50%;\n left: 50%;\n width: 29px;\n height: 29px;\n transform: translate(-50%, -50%);\n background-image: url(\"data:image/svg+xml,%3Csvg width='29' height='29' viewBox='0 0 29 29' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='14.75' cy='14.6748' r='14' fill='%23121C48' fill-opacity='0.64'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M8.99573 19.5229C8.99573 19.337 8.99579 19.2315 8.99573 19.126C8.99526 18.3094 9.00063 17.4927 8.99164 16.6762C8.98744 16.293 8.7308 16.0422 8.37583 16.0407C8.0166 16.0392 7.75558 16.2888 7.75418 16.6673C7.74875 18.1255 7.7484 19.5837 7.75435 21.042C7.75593 21.4273 7.99052 21.6677 8.37233 21.6695C9.83072 21.6766 11.2892 21.6762 12.7476 21.6704C13.1241 21.669 13.3852 21.4025 13.3847 21.0562C13.3841 20.6939 13.1216 20.4349 12.7264 20.4319C11.9001 20.4254 11.0736 20.4296 10.2471 20.4294C10.1548 20.4293 10.0624 20.4294 9.97001 20.4294C9.93856 20.3865 9.90705 20.3436 9.87554 20.3008C9.97059 20.2512 10.0849 20.2211 10.1577 20.1491C10.9664 19.3492 11.769 18.5431 12.5727 17.7382C12.9918 17.3186 13.418 16.9057 13.826 16.4756C14.1538 16.1299 14.0329 15.5936 13.6039 15.4486C13.3145 15.3509 13.0824 15.4548 12.8702 15.6681C11.6769 16.8672 10.4771 18.0597 9.27904 19.254C9.2051 19.3278 9.12761 19.398 8.99573 19.5229ZM20.3851 9.81163C20.4254 9.84449 20.4657 9.87742 20.506 9.91034C20.506 10.8245 20.5022 11.7387 20.5077 12.6529C20.5101 13.0551 20.7623 13.3137 21.1273 13.3124C21.4909 13.3112 21.7453 13.0502 21.7465 12.6499C21.7511 11.2198 21.7512 9.78968 21.7466 8.3596C21.7451 7.91082 21.5096 7.67901 21.0584 7.67772C19.6406 7.67381 18.2225 7.67381 16.8046 7.67784C16.3823 7.67901 16.1161 7.93177 16.1213 8.30362C16.1264 8.67874 16.3881 8.91761 16.8148 8.91989C17.6403 8.92427 18.4658 8.92088 19.2914 8.92205C19.3732 8.92217 19.455 8.93151 19.5368 8.93658L19.6122 9.03868C19.5204 9.09338 19.4125 9.13197 19.339 9.20523C18.1691 10.3721 17.0033 11.5433 15.8376 12.7145C15.7556 12.7969 15.6713 12.8801 15.6055 12.9751C15.369 13.3165 15.4985 13.7314 15.8827 13.8874C16.2035 14.0177 16.4402 13.88 16.6612 13.6583C17.8486 12.4675 19.04 11.2809 20.2256 10.0884C20.2982 10.0154 20.3329 9.90474 20.3851 9.81163Z' fill='white'/%3E%3C/svg%3E%0A\");\n background-repeat: no-repeat;\n background-position: center;\n transition-delay: .1s;\n z-index: 3;\n }\n\n &:hover {\n border-color: #4277ff;\n\n &::before,\n &::after {\n opacity: 1;\n visibility: visible;\n }\n }\n }\n`;\nconst withPreview = (WrappedComponent)=>{\n const WithPreview = (props)=>{\n const { clickableImageSelector } = props, otherProps = _object_without_properties(props, [\n \"clickableImageSelector\"\n ]);\n const [activePreviewIndex, setActivePreviewIndex] = useState(false);\n const [files, setFiles] = useState([]);\n const prepareFile = (url = '')=>{\n const fileName = url.split('/').pop().split('?')[0];\n const fileUrl = url.replace('#', '%23');\n return {\n fileName,\n fileUrl,\n previewUrl: fileUrl\n };\n };\n const prepareFiles = (allImages)=>{\n const preparedFiles = allImages.map((image)=>prepareFile(image.src));\n setFiles(preparedFiles);\n };\n const handleClick = (i)=>setActivePreviewIndex(i);\n useEffect(()=>{\n const previewContent = document.querySelector('#preview-content');\n if (!previewContent) {\n const newPreviewContentEl = document.createElement('div');\n newPreviewContentEl.id = 'preview-content';\n document.body.appendChild(newPreviewContentEl);\n }\n const allImages = clickableImageSelector ? Array.from(document.querySelectorAll(clickableImageSelector)) : [];\n prepareFiles(allImages);\n allImages.forEach((image, i)=>{\n image.parentNode.classList.add('clickableImageWrapper');\n image.addEventListener('click', ()=>handleClick(i));\n });\n return ()=>{\n allImages.forEach((image, i)=>{\n image.removeEventListener('click', ()=>handleClick(i));\n });\n };\n }, []);\n return /*#__PURE__*/ _jsxs(StyledPreviewWrapper, {\n children: [\n /*#__PURE__*/ _jsx(WrappedComponent, _object_spread({}, otherProps)),\n activePreviewIndex !== false && /*#__PURE__*/ _jsx(Preview, {\n files: files,\n initialFileIndex: activePreviewIndex,\n onClose: ()=>setActivePreviewIndex(false),\n isPreviewContextMenuOpened: false,\n togglePreviewContextMenu: (f)=>f\n })\n ]\n });\n };\n WithPreview.propTypes = {\n clickableImageSelector: PropTypes.string\n };\n WithPreview.defaultProps = {\n clickableImageSelector: ''\n };\n WithPreview.displayName = `Preview(${getDisplayName(WrappedComponent)})`;\n return WithPreview;\n};\nexport default withPreview;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_without_properties } from \"@swc/helpers/_/_object_without_properties\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport View from '../View';\nconst ViewWithAlignment = Styled((_param)=>{\n var { direction } = _param, props = _object_without_properties(_param, [\n \"direction\"\n ]);\n return /*#__PURE__*/ _jsx(View, _object_spread({}, props));\n})`\n display: flex;\n flex-direction: ${({ direction })=>direction};`;\nViewWithAlignment.propTypes = {\n direction: PropTypes.string\n};\nViewWithAlignment.defaultProps = {\n direction: 'column'\n};\nexport default ViewWithAlignment;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { _ as _object_without_properties } from \"@swc/helpers/_/_object_without_properties\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport isEqual from 'lodash/isEqual';\nimport View from '../View';\nimport Text from '../Text';\nimport { nl2br, stripHTML } from '../../utils';\nimport { isNative } from '../../utils/environment';\nconst LabelText = Styled(Text)`\n font-size: 20px;\n letter-spacing: .25px;\n font-weight: 600;\n`;\nclass Label extends React.Component {\n componentDidUpdate(prevProps) {\n if (!isEqual(prevProps.textStyle, this.props.textStyle)) {\n this.wrappedLabelText = Styled((props)=>/*#__PURE__*/ _jsx(LabelText, _object_spread({}, props)))`${this.props.textStyle}`;\n }\n }\n render() {\n const _this_props = this.props, { label, textProps, textStyle, allowHTML, childLabels } = _this_props, props = _object_without_properties(_this_props, [\n \"label\",\n \"textProps\",\n \"textStyle\",\n \"allowHTML\",\n \"childLabels\"\n ]);\n const WrappedLabelText = this.wrappedLabelText;\n const isValid = label !== '' && label.length > 0; // required for native\n const prettyLabel = isNative() ? stripHTML(label) : nl2br(stripHTML(label));\n return /*#__PURE__*/ _jsxs(View, _object_spread_props(_object_spread({}, props), {\n children: [\n isValid && label && /*#__PURE__*/ _jsx(WrappedLabelText, _object_spread_props(_object_spread({}, textProps), {\n children: allowHTML ? label : prettyLabel\n })),\n childLabels && childLabels\n ]\n }));\n }\n constructor(props){\n super(props);\n const { textStyle } = this.props;\n // In order to prevent unnecessary re-renders caused by ref changes on WrappedLabelText caused by calling Styled(...) on each render.\n this.wrappedLabelText = Styled((styledProps)=>/*#__PURE__*/ _jsx(LabelText, _object_spread({}, styledProps)))`${textStyle}`;\n // If you are willing to change this logic, you may break inline-edit on PDF-Editor. Remember, everything is connected.\n }\n}\nLabel.propTypes = {\n label: PropTypes.string,\n textProps: PropTypes.shape({}),\n allowHTML: PropTypes.bool,\n childLabels: PropTypes.arrayOf(PropTypes.shape({})),\n textStyle: PropTypes.string\n};\nLabel.defaultProps = {\n label: '',\n textProps: {},\n allowHTML: false,\n childLabels: [],\n textStyle: ''\n};\nexport default Label;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { _ as _object_without_properties } from \"@swc/helpers/_/_object_without_properties\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport Label from '../Label';\nconst LabelWithAlignment = Styled((_param)=>{\n var { direction, flexBasis } = _param, props = _object_without_properties(_param, [\n \"direction\",\n \"flexBasis\"\n ]);\n return /*#__PURE__*/ _jsx(Label, _object_spread_props(_object_spread({}, props), {\n textStyle: `word-break: ${direction !== 'column' ? 'break-all' : 'initial'}`\n }));\n})`\n flex: ${({ direction, flexBasis })=>{\n return direction === 'column' ? 'auto' : `0 0 ${flexBasis}`;\n}};\n margin: ${({ direction })=>{\n return direction === 'column' ? '0 0 10px 0' : '0 10px 0 0';\n}};\n `;\nLabelWithAlignment.propTypes = {\n direction: PropTypes.string,\n flexBasis: PropTypes.string\n};\nLabelWithAlignment.defaultProps = {\n direction: 'column',\n flexBasis: '40%'\n};\nexport default LabelWithAlignment;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_without_properties } from \"@swc/helpers/_/_object_without_properties\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport Answer from '../Answer';\nconst AnswerWithAlignment = Styled((_param)=>{\n var { direction, flexBasis } = _param, props = _object_without_properties(_param, [\n \"direction\",\n \"flexBasis\"\n ]);\n return /*#__PURE__*/ _jsx(Answer, _object_spread({}, props));\n})`\n flex: ${({ direction, flexBasis })=>{\n return direction === 'column' ? 'auto' : `0 0 ${flexBasis}`;\n}};`;\nAnswerWithAlignment.propTypes = {\n direction: PropTypes.string,\n flexBasis: PropTypes.string\n};\nAnswerWithAlignment.defaultProps = {\n direction: 'column',\n flexBasis: '60%'\n};\nexport default AnswerWithAlignment;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { _ as _object_without_properties } from \"@swc/helpers/_/_object_without_properties\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport View from '../View';\nimport Text from '../Text';\nimport Image from '../Image';\n// import Baseline from '../Baseline';\nimport { isBrowser } from '../../utils/environment';\nconst StyledText = Styled(Text)`\n text-align: center;\n`;\nconst StyledImageLine = Styled(View)`\n background-color: ${({ backgroundColor })=>backgroundColor};\n`;\nconst StyledImage = Styled((props)=>/*#__PURE__*/ _jsx(Image, _object_spread({}, props)))`\n max-width: 200px;\n`;\nclass ImageLine extends React.Component {\n render() {\n const _this_props = this.props, { label, value, imageLabel, valueContainerProps, imageContainerProps, backgroundColor, optimizeImage, noCache, noImgPlaceholder } = _this_props, props = _object_without_properties(_this_props, [\n \"label\",\n \"value\",\n \"imageLabel\",\n \"valueContainerProps\",\n \"imageContainerProps\",\n \"backgroundColor\",\n \"optimizeImage\",\n \"noCache\",\n \"noImgPlaceholder\"\n ]);\n const imageUrl = ()=>{\n const imageSource = noImgPlaceholder ? value : value || 'https://www.jotform.com/images/image_placeholder.png';\n const baseUrl = isBrowser() ? window.location.origin : global.baseURL.baseURL;\n if (noCache) {\n const url = new URL(imageSource, baseUrl);\n url.searchParams.set('nc', 1);\n return url.toString();\n }\n return imageSource;\n };\n const _imgURL = imageUrl();\n return /*#__PURE__*/ _jsxs(StyledImageLine, _object_spread_props(_object_spread({}, props), {\n children: [\n /*#__PURE__*/ _jsx(View, _object_spread_props(_object_spread({}, valueContainerProps), {\n children: _imgURL && /*#__PURE__*/ _jsx(StyledImage, _object_spread({\n alt: label,\n src: imageUrl()\n }, imageContainerProps))\n })),\n imageLabel && /*#__PURE__*/ _jsx(StyledText, {\n children: imageLabel\n })\n ]\n }));\n }\n}\nImageLine.propTypes = {\n label: PropTypes.string,\n value: PropTypes.string,\n imageLabel: PropTypes.string,\n backgroundColor: PropTypes.string,\n valueContainerProps: PropTypes.shape({}),\n imageContainerProps: PropTypes.shape({}),\n optimizeImage: PropTypes.bool,\n noCache: PropTypes.bool,\n noImgPlaceholder: PropTypes.bool\n};\nImageLine.defaultProps = {\n label: '',\n value: '',\n imageLabel: '',\n backgroundColor: null,\n valueContainerProps: {},\n imageContainerProps: {},\n optimizeImage: false,\n noCache: false,\n noImgPlaceholder: false\n};\nexport default ImageLine;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { _ as _object_without_properties } from \"@swc/helpers/_/_object_without_properties\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nconst StyledAnchor = Styled.a`\n pointer-events: all;\n`;\nconst Hypertext = (props)=>{\n const { children } = props, remainingProps = _object_without_properties(props, [\n \"children\"\n ]);\n return /*#__PURE__*/ _jsx(StyledAnchor, _object_spread_props(_object_spread({}, remainingProps), {\n children: children\n }));\n};\nHypertext.propTypes = {\n children: PropTypes.node\n};\nHypertext.defaultProps = {\n children: {}\n};\nexport default Hypertext;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport { createElement as _createElement } from \"react\";\nimport React, { useEffect, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport Styled from 'styled-components';\nimport { Preview, SVG } from '@jotforminc/preview';\nimport { FileUtils } from '@jotforminc/upload-fields';\nimport { View, Hypertext, Baseline, Imageline, Text as SimpleText } from '@jotforminc/answer-fields';\nimport '../../styles/index.scss';\nconst ViewWrap = Styled(View)`\n display: flex;\n flex-wrap: wrap;\n`;\nconst HalfView = Styled(View)`\n width: 50%;\n`;\nconst FileUploadField = ({ text, answer, labelProps, answerProps, answerWrapperProps, baselineProps, showFileNameAsText, showImageHyperlink, imagePropsArray, filePropsArray, direction, containerProps, fileNameProps })=>{\n const [activePreviewIndex, updateActivePreviewIndex] = useState(false);\n const imgPropsArray = imagePropsArray || [];\n const fileProps = filePropsArray || [];\n const { className: classes } = baselineProps;\n const files = FileUtils.prepareFiles(answer, true);\n useEffect(()=>{\n const previewContent = document.querySelector('#preview-content');\n if (!previewContent) {\n const newPreviewContentEl = document.createElement('div');\n newPreviewContentEl.id = 'preview-content';\n document.body.appendChild(newPreviewContentEl);\n }\n }, []);\n return /*#__PURE__*/ _jsx(Baseline, _object_spread_props(_object_spread({\n label: text,\n labelContainerProps: labelProps,\n answerWrapperProps: answerWrapperProps,\n direction: direction\n }, baselineProps), {\n className: classNames('jfFileUploadField', classes),\n children: /*#__PURE__*/ _jsxs(ViewWrap, _object_spread_props(_object_spread({}, containerProps), {\n children: [\n answer && answer.map((uploadedUrl, answerIndex)=>{\n const { fileUrl: encodedRequestUrl, fileName: filename, extension, iconType, isImageFile } = files[answerIndex];\n return(// eslint-disable-next-line react/no-array-index-key\n /*#__PURE__*/ _createElement(HalfView, _object_spread_props(_object_spread({}, answerProps, fileProps[answerIndex]), {\n key: answerIndex.toString(),\n children: [\n /*#__PURE__*/ _jsx(\"div\", {\n className: \"jfFileUploadField-image\",\n onClick: ()=>updateActivePreviewIndex(answerIndex),\n onKeyDown: null,\n children: isImageFile || uploadedUrl.match(/^blob:/) ? /*#__PURE__*/ _jsx(Imageline, _object_spread({\n label: filename,\n value: encodedRequestUrl\n }, imgPropsArray[answerIndex]), `${filename}`) : /*#__PURE__*/ _jsx(\"div\", {\n className: \"noImage flex-center\",\n children: /*#__PURE__*/ _jsxs(\"div\", {\n className: \"fileHolder\",\n children: [\n /*#__PURE__*/ _jsx(SVG, {\n name: iconType,\n className: \"noImage-icon flex-center\"\n }),\n /*#__PURE__*/ _jsx(\"span\", {\n className: \"fileType flex-center\",\n children: extension\n })\n ]\n })\n })\n }),\n showImageHyperlink && /*#__PURE__*/ _jsx(Hypertext, {\n href: FileUtils.getUploadUrl(encodedRequestUrl),\n children: filename\n }, `hypertext_${filename}`),\n showFileNameAsText && !showImageHyperlink && /*#__PURE__*/ _jsx(SimpleText, _object_spread_props(_object_spread({}, fileNameProps, fileProps[answerIndex]), {\n children: filename\n }), `simpletext_${filename}`)\n ]\n })));\n }),\n activePreviewIndex !== false && /*#__PURE__*/ _jsx(Preview, {\n files: files,\n initialFileIndex: activePreviewIndex,\n onClose: ()=>updateActivePreviewIndex(false),\n isPreviewContextMenuOpened: false,\n togglePreviewContextMenu: (f)=>f\n })\n ]\n }))\n }));\n};\nFileUploadField.propTypes = {\n text: PropTypes.string,\n answer: PropTypes.oneOfType([\n PropTypes.arrayOf(PropTypes.string),\n PropTypes.shape({})\n ]),\n labelProps: PropTypes.shape({}),\n answerProps: PropTypes.shape({}),\n answerWrapperProps: PropTypes.shape({}),\n baselineProps: PropTypes.shape({\n className: PropTypes.string\n }),\n containerProps: PropTypes.shape({}),\n imagePropsArray: PropTypes.instanceOf(Array),\n fileNameProps: PropTypes.oneOfType([\n PropTypes.shape({}),\n PropTypes.array\n ]),\n filePropsArray: PropTypes.instanceOf(Array),\n showImageHyperlink: PropTypes.bool,\n showFileNameAsText: PropTypes.bool,\n direction: PropTypes.string\n};\nFileUploadField.defaultProps = {\n text: '',\n answer: [\n ''\n ],\n labelProps: {},\n answerProps: {},\n answerWrapperProps: {},\n baselineProps: {},\n containerProps: {},\n imagePropsArray: [],\n fileNameProps: [],\n filePropsArray: [],\n showImageHyperlink: true,\n showFileNameAsText: false,\n direction: 'column'\n};\nexport default FileUploadField;\n","import { _ as _define_property } from \"@swc/helpers/_/_define_property\";\nimport { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nimport React, { Component } from 'react';\nimport Geocode from 'react-geocode';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport { t } from '@jotforminc/translation';\nimport Text from '../../components/Text';\nimport Baseline from '../../components/Baseline';\nimport { stripHTML } from '../../utils';\nimport View from '../../components/View';\nimport Image from '../../components/Image';\nconst EmptyResult = Styled(View)`\n display: flex;\n background-color: #F3F3FE;\n min-height: 74px;\n padding: 16px;\n border-radius: 4px;\n margin-right: 82px;\n`;\nconst StyledText = Styled(Text)`\n color: ${({ color })=>color};\n font-weight: ${({ fontWeight })=>fontWeight};\n font-size: 14px;\n line-height: 20px;\n`;\nconst ImageView = Styled(View)`\n display: flex;\n flex-direction: column;\n align-items: start;\n justify-content: flex-start;\n padding-right: 18px;\n flex-shrink: 0;\n`;\nclass Address extends Component {\n componentDidMount() {\n const { showMap, answer } = this.props;\n if (showMap && answer) {\n this.handleMapLinks();\n }\n }\n componentDidUpdate(prevProps) {\n const { showMap, answer } = this.props;\n if (showMap && answer && (prevProps.answer !== answer || prevProps.showMap !== showMap)) {\n this.handleMapLinks();\n }\n }\n render() {\n const { text, answer: { addr_line1: AnswerLine1, addr_line2: AnswerLine2, city: AnswerCity, state: AnswerState, postal: AnswerPostal, country: AnswerCountry }, labelProps, answerProps, answerWrapperProps, baselineProps, direction, showMap } = this.props;\n const { mapLink, largerMapLink, emptyResult } = this.state;\n return /*#__PURE__*/ _jsx(Baseline, _object_spread_props(_object_spread({\n label: text,\n labelContainerProps: labelProps,\n answerWrapperProps: answerWrapperProps,\n direction: direction\n }, baselineProps), {\n children: /*#__PURE__*/ _jsxs(_Fragment, {\n children: [\n this.streetLine(AnswerLine1, AnswerLine2, answerProps),\n this.cityLine(AnswerCity, AnswerState, AnswerPostal, answerProps),\n this.countryLine(AnswerCountry, answerProps),\n showMap && mapLink && largerMapLink && /*#__PURE__*/ _jsxs(\"div\", {\n className: \"jfAnswer-answer forMapContainer\",\n children: [\n /*#__PURE__*/ _jsx(\"div\", {\n className: \"jfAnswer-answer forMap\",\n children: /*#__PURE__*/ _jsx(\"iframe\", {\n title: \"map\",\n width: \"300\",\n height: \"250\",\n frameBorder: \"0\",\n scrolling: \"no\",\n marginHeight: \"0\",\n marginWidth: \"0\",\n src: mapLink,\n style: {\n border: '1px solid black'\n }\n })\n }),\n /*#__PURE__*/ _jsx(\"div\", {\n className: \"jfAnswer-answer forLink\",\n children: /*#__PURE__*/ _jsx(\"a\", {\n target: \"_blank\",\n href: largerMapLink,\n style: {\n color: '#0000FF',\n textAlign: 'left'\n },\n children: \"View Larger Map\"\n })\n })\n ]\n }),\n showMap && emptyResult && /*#__PURE__*/ _jsxs(EmptyResult, {\n children: [\n /*#__PURE__*/ _jsx(ImageView, {\n children: /*#__PURE__*/ _jsx(Image, {\n src: \"https://cdn.jotfor.ms/assets/img/uncategorized/exclamation-triangle.svg\",\n style: {\n width: 24,\n height: 24\n }\n })\n }),\n /*#__PURE__*/ _jsxs(View, {\n children: [\n /*#__PURE__*/ _jsx(StyledText, {\n style: {\n marginBottom: 4\n },\n color: \"#343C6A\",\n fontWeight: \"700\",\n children: t('Couldn\\'t find the address')\n }),\n /*#__PURE__*/ _jsx(StyledText, {\n color: \"#6C73A8\",\n fontWeight: \"400\",\n children: t('It looks like the provided address is invalid.')\n })\n ]\n })\n ]\n })\n ]\n })\n }));\n }\n constructor(props){\n super(props), _define_property(this, \"handleMapLinks\", ()=>{\n const address = Object.values(this.props.answer).reduce((prev, next)=>`${prev} ${next}`);\n if (address.trim().length === 0) {\n this.setState({\n emptyResult: false,\n mapLink: '',\n largerMapLink: ''\n });\n return;\n }\n Geocode.setApiKey('AIzaSyAO3hx_Mq0AGel9wULuOY5f35KRzFnklOM');\n Geocode.fromAddress(address).then((response)=>{\n const { lat: latitude, lng: longitude } = response.results[0].geometry.location;\n // Calculate for zoom level\n const north = latitude + 0.04;\n const south = latitude - 0.04;\n const west = longitude + 0.08;\n const east = longitude - 0.08;\n const link = `https://www.openstreetmap.org/export/embed.html?bbox=${east}%2C${south}%2C${west}%2C${north}&layer=transportmap&marker=${latitude}%2C${longitude}`;\n const largerLink = `https://maps.google.com/maps?q=${latitude},+${longitude}`;\n this.setState({\n mapLink: link,\n largerMapLink: largerLink,\n emptyResult: false\n });\n }, (error)=>{\n if (error.message.indexOf('ZERO_RESULTS') === -1) {\n console.error(error);\n } else {\n this.setState({\n emptyResult: true,\n mapLink: '',\n largerMapLink: ''\n });\n }\n });\n }), _define_property(this, \"concatArgumentsWithComma\", (...args)=>{\n return args.reduce((acc, arg)=>{\n if (!arg) return acc;\n if (!acc) return arg;\n return `${acc}, ${arg}`;\n }, '');\n }), _define_property(this, \"streetLine\", (street1, street2, textProps)=>{\n if (!street1 && !street2) return null;\n const streetLine = this.concatArgumentsWithComma(street1, street2);\n return streetLine ? /*#__PURE__*/ _jsx(Text, _object_spread_props(_object_spread({}, textProps), {\n children: stripHTML(streetLine)\n })) : null;\n }), _define_property(this, \"cityLine\", (city, state, postalCode, textProps)=>{\n if (!city && !state && !postalCode) return null;\n const cityLine = this.concatArgumentsWithComma(city, state, postalCode);\n return cityLine ? /*#__PURE__*/ _jsx(Text, _object_spread_props(_object_spread({}, textProps), {\n children: stripHTML(cityLine)\n })) : null;\n }), _define_property(this, \"countryLine\", (country, textProps)=>{\n return country ? /*#__PURE__*/ _jsx(Text, _object_spread_props(_object_spread({}, textProps), {\n children: stripHTML(country)\n })) : null;\n });\n this.state = {\n mapLink: '',\n largerMapLink: '',\n emptyResult: false\n };\n }\n}\nAddress.propTypes = {\n text: PropTypes.string,\n answer: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.shape({\n addr_line1: PropTypes.string,\n addr_line2: PropTypes.string,\n city: PropTypes.string,\n state: PropTypes.string,\n postal: PropTypes.string,\n country: PropTypes.string\n })\n ]),\n labelProps: PropTypes.shape({}),\n answerProps: PropTypes.shape({}),\n answerWrapperProps: PropTypes.shape({}),\n baselineProps: PropTypes.shape({}),\n direction: PropTypes.string,\n showMap: PropTypes.bool\n};\nAddress.defaultProps = {\n text: '',\n answer: {\n addr_line1: '',\n addr_line2: '',\n city: '',\n state: '',\n postal: '',\n country: ''\n },\n labelProps: {},\n answerProps: {},\n answerWrapperProps: {},\n baselineProps: {},\n direction: 'column',\n showMap: false\n};\nexport default Address;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport Styled from 'styled-components';\nconst styled = (Component)=>{\n return (tags, ...others)=>{\n return Styled((props)=>/*#__PURE__*/ _jsx(Component, _object_spread({}, props)))`\n ${tags}\n ${others}\n `;\n };\n};\nexport default styled;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport moment from 'moment-timezone';\nimport Text from '../../components/Text';\nimport Baseline from '../../components/Baseline';\nimport Styled from '../../utils/styled';\nconst TimezoneText = Styled(Text)`\n font-size: 13px;\n letter-spacing: 0.1px;\n color: #8894ac;\n`;\nclass Appointment extends React.Component {\n getAnswerDate() {\n const { answer, timezone, showTimezone, timeFormat, submissionDate, isNewAppointment, locale } = this.props;\n const { date: dateStr, duration } = answer;\n if (locale) {\n moment.locale(locale);\n }\n const serverTimeZone = 'America/New_York';\n const newAppointment = true || window.location.href.includes('useAppointmentFix') || isNewAppointment;\n if (!dateStr) {\n return '';\n }\n let dateObject = newAppointment ? moment.tz(dateStr, serverTimeZone) : moment(dateStr);\n if (!dateObject.isValid()) {\n return '';\n }\n if (timezone) {\n if (newAppointment) {\n dateObject = dateObject.clone().tz(timezone);\n } else {\n const defaultOffset = submissionDate ? moment(submissionDate).tz(serverTimeZone).utcOffset() : moment.tz(serverTimeZone).utcOffset();\n const timezoneOffset = submissionDate ? moment(submissionDate).tz(timezone).utcOffset() : moment.tz(timezone).utcOffset();\n const changedOffset = timezoneOffset - defaultOffset;\n dateObject = dateObject.clone().add(changedOffset, 'minutes');\n }\n }\n const endDate = dateObject.clone().add(duration, 'minutes');\n const answerTimeFormat = timeFormat === 'AM/PM' ? 'h:mm A' : 'HH:mm';\n return /*#__PURE__*/ _jsxs(_Fragment, {\n children: [\n dateObject.clone().format(`dddd, MMM DD, Y ${answerTimeFormat}`),\n ' - ',\n endDate.format(answerTimeFormat),\n ' ',\n /*#__PURE__*/ _jsx(TimezoneText, {\n children: showTimezone && `- ${timezone} Time`\n })\n ]\n });\n }\n render() {\n const { text, labelProps, answerProps, answerWrapperProps, baselineProps, direction } = this.props;\n const answer = this.getAnswerDate();\n return /*#__PURE__*/ _jsx(Baseline, _object_spread_props(_object_spread({\n label: text,\n labelContainerProps: labelProps,\n answerWrapperProps: answerWrapperProps,\n direction: direction\n }, baselineProps), {\n children: answer ? /*#__PURE__*/ _jsx(Text, _object_spread_props(_object_spread({}, answerProps), {\n children: answer\n })) : null\n }));\n }\n}\nAppointment.propTypes = {\n text: PropTypes.string,\n answer: PropTypes.string,\n timezone: PropTypes.string,\n timeFormat: PropTypes.string,\n submissionDate: PropTypes.string,\n labelProps: PropTypes.shape({}),\n answerProps: PropTypes.shape({}),\n answerWrapperProps: PropTypes.shape({}),\n baselineProps: PropTypes.shape({}),\n dateFormat: PropTypes.shape({}),\n direction: PropTypes.string,\n showTimezone: PropTypes.bool,\n isNewAppointment: PropTypes.bool\n};\nAppointment.defaultProps = {\n text: '',\n answer: '',\n timezone: '',\n timeFormat: '24 Hour',\n submissionDate: '',\n labelProps: {},\n answerProps: {},\n answerWrapperProps: {},\n baselineProps: {},\n dateFormat: 'mm-dd-yyyy',\n direction: 'column',\n showTimezone: false,\n isNewAppointment: false\n};\nexport default Appointment;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { _ as _object_without_properties } from \"@swc/helpers/_/_object_without_properties\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport { EmojiRendererWithoutLazy } from '@jotforminc/icon-selector';\nimport View from '../View';\nimport Text from '../Text';\nimport Image from '../Image';\n// import Baseline from '../Baseline';\nconst StyledTextHolder = Styled(View)`\n display: flex;\n flex: 1;\n flex-direction: column;\n text-align: left;\n overflow: hidden;\n`;\nconst StyleSubText = Styled(Text)`\n text-overflow: ellipsis;\n white-space: nowrap;\n overflow: hidden;\n opacity: .6;\n`;\nconst StyledText = Styled(Text)`\n text-overflow: ellipsis;\n white-space: nowrap;\n overflow: hidden;\n`;\nconst StyledImageLine = Styled(View)`\n background-color: ${({ backgroundColor })=>backgroundColor};\n display: inline-flex !important;\n align-items: center;\n padding: 10px;\n border: 1px solid #C8CEED;\n border-radius: 90px;\n`;\nconst StyledImage = Styled((props)=>/*#__PURE__*/ _jsx(Image, _object_spread({}, props)))`\n display: block;\n flex: 0;\n max-width: 36px;\n max-height: 36px;\n margin-right: 8px;\n border-radius: 50%;\n object-fit: cover;\n background-color: #b9bbd2;\n flex-shrink: 1;\n`;\nclass AssigneeLine extends React.Component {\n render() {\n const _this_props = this.props, { label, subLabel, value, imageLabel, valueContainerProps, imageContainerProps, backgroundColor, optimizeImage, showSubLabel, teamAvatarID } = _this_props, props = _object_without_properties(_this_props, [\n \"label\",\n \"subLabel\",\n \"value\",\n \"imageLabel\",\n \"valueContainerProps\",\n \"imageContainerProps\",\n \"backgroundColor\",\n \"optimizeImage\",\n \"showSubLabel\",\n \"teamAvatarID\"\n ]);\n const imageSource = value || 'https://cdn.jotfor.ms/assets/img/v4/avatar/Podo-Guest.png';\n return /*#__PURE__*/ _jsxs(StyledImageLine, _object_spread_props(_object_spread({}, props), {\n children: [\n /*#__PURE__*/ _jsx(View, _object_spread_props(_object_spread({}, valueContainerProps), {\n children: teamAvatarID ? /*#__PURE__*/ _jsx(EmojiRendererWithoutLazy, {\n id: teamAvatarID,\n size: 12\n }) : /*#__PURE__*/ _jsx(StyledImage, _object_spread({\n alt: label,\n src: imageSource\n }, imageContainerProps))\n })),\n /*#__PURE__*/ _jsxs(StyledTextHolder, {\n children: [\n imageLabel && /*#__PURE__*/ _jsx(StyledText, {\n children: imageLabel\n }),\n showSubLabel && subLabel && /*#__PURE__*/ _jsx(StyleSubText, {\n children: subLabel\n })\n ]\n })\n ]\n }));\n }\n}\nAssigneeLine.propTypes = {\n label: PropTypes.string,\n subLabel: PropTypes.string,\n value: PropTypes.string,\n imageLabel: PropTypes.string,\n backgroundColor: PropTypes.string,\n valueContainerProps: PropTypes.shape({}),\n imageContainerProps: PropTypes.shape({}),\n optimizeImage: PropTypes.bool,\n showSubLabel: PropTypes.bool\n};\nAssigneeLine.defaultProps = {\n label: '',\n subLabel: '',\n value: '',\n imageLabel: '',\n backgroundColor: null,\n valueContainerProps: {},\n imageContainerProps: {},\n optimizeImage: false,\n showSubLabel: true\n};\nexport default AssigneeLine;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport Styled from 'styled-components';\nimport View from '../View';\nimport AssigneeItem from '../AssigneeItem';\nimport { mapAnswerItems, justifyContentPicker } from '../../utils';\nimport { ListPropTypes } from '../../constants/schemas';\nconst ViewWrap = Styled(View)`\n display: flex;\n flex-wrap: wrap;\n justify-content: ${({ alignment })=>justifyContentPicker(alignment)};\n gap: 12px;\n`;\nconst AssigneeList = ({ items, itemProps, containerProps })=>/*#__PURE__*/ _jsx(ViewWrap, _object_spread_props(_object_spread({}, containerProps), {\n children: mapAnswerItems(AssigneeItem, items, itemProps)\n }));\nAssigneeList.propTypes = ListPropTypes.schema;\nAssigneeList.defaultProps = ListPropTypes.default;\nexport default AssigneeList;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport Styled from 'styled-components';\nimport View from '../View';\nimport ImageItem from '../ImageItem';\nimport { mapAnswerItems, justifyContentPicker } from '../../utils';\nimport { ListPropTypes } from '../../constants/schemas';\nconst ViewWrap = Styled(View)`\n display: flex;\n flex-wrap: wrap;\n justify-content: ${({ alignment })=>justifyContentPicker(alignment)};\n`;\nconst ImageList = ({ items, itemProps, containerProps })=>/*#__PURE__*/ _jsx(ViewWrap, _object_spread_props(_object_spread({}, containerProps), {\n children: mapAnswerItems(ImageItem, items, itemProps)\n }));\nImageList.propTypes = ListPropTypes.schema;\nImageList.defaultProps = ListPropTypes.default;\nexport default ImageList;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport Styled from 'styled-components';\nimport View from '../View';\nimport { mapAnswerItems, justifyContentPicker } from '../../utils';\nimport { ListPropTypes } from '../../constants/schemas';\nconst ViewWrap = Styled(View)`\n display: flex;\n flex-flow: row wrap;\n justify-content: ${({ alignment })=>justifyContentPicker(alignment)};\n`;\nconst ViewChild = Styled(View)`\n text-decoration: ${({ checked })=>checked !== undefined && !checked ? 'line-through' : 'none'};\n &:not(:last-of-type):after {\n content: ', ';\n white-space: pre;\n }\n`;\nconst CommaList = ({ items, itemProps, containerProps })=>/*#__PURE__*/ _jsx(ViewWrap, _object_spread_props(_object_spread({}, containerProps), {\n children: mapAnswerItems(ViewChild, items, itemProps)\n }));\nCommaList.propTypes = ListPropTypes.schema;\nCommaList.defaultProps = ListPropTypes.default;\nexport default CommaList;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_without_properties } from \"@swc/helpers/_/_object_without_properties\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport Text from '../Text';\nconst OptionItem = Styled((_param)=>{\n var { backgroundColor, checked, color } = _param, remainingProps = _object_without_properties(_param, [\n \"backgroundColor\",\n \"checked\",\n \"color\"\n ]);\n return /*#__PURE__*/ _jsx(Text, _object_spread({}, remainingProps));\n})`\n background-color: ${({ backgroundColor })=>backgroundColor || '#E3E8F3'};\n padding: 8px 24px;\n font-size: 16px;\n font-weight: 200;\n margin-right: 12px;\n margin-bottom: 12px;\n border-radius: 3px;\n opacity: ${({ checked })=>checked ? 1 : 0.5};\n`;\nOptionItem.propTypes = {\n color: PropTypes.string,\n checked: PropTypes.bool\n};\nOptionItem.defaultProps = {\n color: '#E3E8F3',\n checked: true\n};\nexport default OptionItem;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport Styled from 'styled-components';\nimport View from '../View';\nimport OptionItem from '../OptionItem';\nimport { mapAnswerItems, justifyContentPicker } from '../../utils';\nimport { ListPropTypes } from '../../constants/schemas';\nconst ViewWrap = Styled(View)`\n display: flex;\n flex-wrap: wrap;\n justify-content: ${({ alignment })=>justifyContentPicker(alignment)};\n`;\nconst OptionList = ({ items, itemProps, containerProps })=>/*#__PURE__*/ _jsx(ViewWrap, _object_spread_props(_object_spread({}, containerProps), {\n children: mapAnswerItems(OptionItem, items, itemProps)\n }));\nOptionList.propTypes = ListPropTypes.schema;\nOptionList.defaultProps = ListPropTypes.default;\nexport default OptionList;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React, { Component } from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from '../../utils/styled';\nimport View from '../View';\nimport Image from '../Image';\nconst StyledImage = Styled((props)=>/*#__PURE__*/ _jsx(Image, _object_spread({}, props)))`\n width: 12px;\n height: 12px;\n display: inline-block;\n vertical-align: text-bottom;\n outline: 1px solid #b8b8b8;\n border-color: #b8b8b8;\n border-width: 1;\n`;\nconst StyledView = Styled(View)`\n width: 12px;\n height: 12px;\n min-width: 12px;\n display: inline-block;\n vertical-align: text-bottom;\n box-shadow: 0 0 0 1px #b0b0b0;\n border-color: #b0b0b0;\n border-width: 1;\n`;\nclass Checkbox extends Component {\n handleToggle() {\n const { interactive } = this.props;\n const { checked } = this.state;\n if (!interactive) {\n return false;\n }\n const { handleChange } = this.props;\n this.setState({\n checked: !checked\n }, ()=>handleChange(!checked));\n }\n render() {\n const { checked } = this.state;\n return checked ? /*#__PURE__*/ _jsx(StyledImage, {\n className: \"js-checked-option\",\n onClick: this.handleToggle,\n src: \"https://cdn.jotfor.ms/assets/img/submission/check_icon.png\"\n }) : /*#__PURE__*/ _jsx(StyledView, {\n onClick: this.handleToggle\n });\n }\n constructor(props){\n super(props);\n this.state = {\n checked: props.checked\n };\n this.handleToggle = this.handleToggle.bind(this);\n }\n}\nCheckbox.propTypes = {\n interactive: PropTypes.bool,\n checked: PropTypes.bool,\n handleChange: PropTypes.func\n};\nCheckbox.defaultProps = {\n checked: false,\n interactive: true,\n handleChange: (f)=>f\n};\nexport default Checkbox;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { _ as _object_without_properties } from \"@swc/helpers/_/_object_without_properties\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React from 'react';\nimport Styled from 'styled-components';\nimport View from '../View';\nimport Text from '../Text';\nimport Checkbox from '../Checkbox';\nimport { ListPropTypes } from '../../constants/schemas';\nimport { mapAnswerItems } from '../../utils';\nconst ViewWrap = Styled(View)`\n text-align: ${({ alignment })=>alignment};\n`;\nconst CheckbowWrapper = Styled(View)`\n display: inline-block;\n`;\nconst CheckboxContainer = Styled(View)`\n display: flex;\n align-items: center;\n flex-flow: row nowrap;\n margin: 10px 15px 10px 0;\n`;\nconst CheckboxLabel = Styled(Text)`\n margin-left: 10px;\n`;\nconst CheckboxView = (_param)=>{\n var { checked } = _param, props = _object_without_properties(_param, [\n \"checked\"\n ]);\n return /*#__PURE__*/ _jsx(CheckbowWrapper, {\n children: /*#__PURE__*/ _jsxs(CheckboxContainer, {\n children: [\n /*#__PURE__*/ _jsx(Checkbox, {\n interactive: false,\n checked: checked !== undefined ? checked : true\n }),\n /*#__PURE__*/ _jsx(CheckboxLabel, _object_spread({}, props))\n ]\n })\n });\n};\nconst CheckboxList = ({ items, itemProps, containerProps })=>/*#__PURE__*/ _jsx(ViewWrap, _object_spread_props(_object_spread({}, containerProps), {\n children: mapAnswerItems(CheckboxView, items, itemProps)\n }));\nCheckboxList.propTypes = ListPropTypes.schema;\nCheckboxList.defaultProps = ListPropTypes.default;\nexport default CheckboxList;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { createElement as _createElement } from \"react\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport { FileUtils } from '@jotforminc/upload-fields';\nimport View from '../../components/View';\nimport Hypertext from '../../components/Hypertext';\nimport Baseline from '../../components/Baseline';\nimport Imageline from '../../components/Imageline';\nimport SimpleText from '../../components/Text';\nconst ViewWrap = Styled(View)`\n display: flex;\n flex-wrap: wrap;\n`;\nconst HalfView = Styled(View)`\n width: 50%;\n`;\nclass Fileupload extends React.Component {\n encodeRequestUrl(url) {\n return url.replace('#', '%23');\n }\n render() {\n const { text, answer, labelProps, answerProps, answerWrapperProps, baselineProps, showFileNameAsText, showImageHyperlink, imagePropsArray, filePropsArray, direction, containerProps, fileNameProps, hideImageLine, useEncodeURI } = this.props;\n const imgPropsArray = imagePropsArray || [];\n const fileProps = filePropsArray || [];\n return /*#__PURE__*/ _jsx(Baseline, _object_spread_props(_object_spread({\n label: text,\n labelContainerProps: labelProps,\n answerWrapperProps: answerWrapperProps,\n direction: direction\n }, baselineProps), {\n children: /*#__PURE__*/ _jsx(ViewWrap, _object_spread_props(_object_spread({}, containerProps), {\n children: answer ? answer.map((uploadedUrl, answerIndex)=>{\n const encodedRequestUrl = useEncodeURI ? encodeURI(uploadedUrl) : this.encodeRequestUrl(uploadedUrl);\n const filename = FileUtils.getFileName(uploadedUrl);\n if (FileUtils.isImageFile(filename) || uploadedUrl.match(/^blob:/)) {\n return(// eslint-disable-next-line react/no-array-index-key\n /*#__PURE__*/ _createElement(HalfView, _object_spread_props(_object_spread({}, answerProps, fileProps[answerIndex]), {\n key: answerIndex.toString(),\n children: [\n !hideImageLine && /*#__PURE__*/ _jsx(Imageline, _object_spread({\n label: filename,\n value: encodedRequestUrl\n }, imgPropsArray[answerIndex]), `${filename}`),\n showImageHyperlink ? /*#__PURE__*/ _jsx(Hypertext, {\n href: FileUtils.getUploadUrl(encodedRequestUrl),\n children: filename\n }, `hypertext_${filename}`) : null,\n showFileNameAsText && !showImageHyperlink ? /*#__PURE__*/ _jsx(SimpleText, _object_spread_props(_object_spread({}, fileNameProps, fileProps[answerIndex]), {\n children: filename\n }), `simpletext_${filename}`) : null\n ]\n })));\n }\n return showFileNameAsText ? /*#__PURE__*/ _jsx(SimpleText, _object_spread_props(_object_spread({}, answerProps, fileProps[answerIndex]), {\n children: filename\n }), `simpletext_showastext_${filename}`) : /*#__PURE__*/ _jsx(Hypertext, _object_spread_props(_object_spread({\n href: encodedRequestUrl\n }, fileProps[answerIndex], answerProps), {\n children: filename\n }), `hypertext_showastext_${filename}`);\n }) : null\n }))\n }));\n }\n}\nFileupload.propTypes = {\n text: PropTypes.string,\n answer: PropTypes.oneOfType([\n PropTypes.arrayOf(PropTypes.string),\n PropTypes.shape({})\n ]),\n labelProps: PropTypes.shape({}),\n answerProps: PropTypes.shape({}),\n answerWrapperProps: PropTypes.shape({}),\n baselineProps: PropTypes.shape({}),\n containerProps: PropTypes.shape({}),\n imagePropsArray: PropTypes.instanceOf(Array),\n fileNameProps: PropTypes.oneOfType([\n PropTypes.shape({}),\n PropTypes.array\n ]),\n filePropsArray: PropTypes.instanceOf(Array),\n showImageHyperlink: PropTypes.bool,\n showFileNameAsText: PropTypes.bool,\n hideImageLine: PropTypes.bool,\n direction: PropTypes.string,\n useEncodeURI: PropTypes.bool\n};\nFileupload.defaultProps = {\n text: '',\n answer: [\n ''\n ],\n labelProps: {},\n answerProps: {},\n answerWrapperProps: {},\n baselineProps: {},\n containerProps: {},\n imagePropsArray: [],\n fileNameProps: [],\n filePropsArray: [],\n showImageHyperlink: true,\n showFileNameAsText: false,\n hideImageLine: false,\n direction: 'column',\n useEncodeURI: false\n};\nexport default Fileupload;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { _ as _object_without_properties } from \"@swc/helpers/_/_object_without_properties\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React from 'react';\nimport { string, shape, oneOfType } from 'prop-types';\nimport Styled from 'styled-components';\nimport View from '../View';\nimport Text from '../Text';\nconst Sublabel = Styled(View)`\n color: #C0C1C3;\n font-size: 14px;\n font-weight: 100;\n`;\nconst Subtext = Styled(View)`\n font-size: 16px;\n padding-top: 8px;\n font-weight: 100;\n`;\nconst StyledView = Styled(View)`\n padding-bottom: 15px;\n`;\nconst Line = (_param)=>{\n var { label, value, labelContainerProps, valueContainerProps, labelProps } = _param, props = _object_without_properties(_param, [\n \"label\",\n \"value\",\n \"labelContainerProps\",\n \"valueContainerProps\",\n \"labelProps\"\n ]);\n return /*#__PURE__*/ _jsxs(StyledView, _object_spread_props(_object_spread({\n className: \"lineWrapper\"\n }, props), {\n children: [\n !!label && /*#__PURE__*/ _jsx(Sublabel, _object_spread_props(_object_spread({\n className: \"labelWrapper\"\n }, labelContainerProps), {\n children: /*#__PURE__*/ _jsx(Text, _object_spread_props(_object_spread({}, labelProps), {\n children: label\n }))\n })),\n /*#__PURE__*/ _jsx(Subtext, _object_spread_props(_object_spread({\n className: \"answerWrapper\"\n }, valueContainerProps), {\n children: typeof value === 'string' ? /*#__PURE__*/ _jsx(Text, _object_spread_props(_object_spread({}, labelProps), {\n children: value\n })) : /*#__PURE__*/ _jsx(View, {\n children: value\n })\n }))\n ]\n }));\n};\nLine.propTypes = {\n label: string,\n value: oneOfType([\n string,\n shape({})\n ]),\n labelContainerProps: shape({}),\n valueContainerProps: shape({})\n};\nLine.defaultProps = {\n label: '',\n value: '',\n labelContainerProps: {},\n valueContainerProps: {}\n};\nexport default Line;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport Image from '../Image';\nconst EmojiImage = Styled((props)=>/*#__PURE__*/ _jsx(Image, _object_spread({}, props)))`\n width: 18px;\n height: 18px;\n display: inline-block;\n vertical-align: text-bottom;\n`;\nconst Emoji = ({ score })=>/*#__PURE__*/ _jsx(EmojiImage, {\n src: `https://cdn.jotfor.ms/assets/img/submission/emoji_${score || 1}.png`\n });\nEmoji.propTypes = {\n score: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.number\n ])\n};\nEmoji.defaultProps = {\n score: 1\n};\nexport default Emoji;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { _ as _object_without_properties } from \"@swc/helpers/_/_object_without_properties\";\nimport { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nimport React, { Component, Fragment } from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport memoize from 'lodash/memoize';\nimport { transpose as transposeArray, fixTableHeader, sanitizeHTML } from '../../utils';\nimport View from '../View';\nimport Text from '../Text';\nconst themeDark = '#F2F3FE';\nconst themeLight = '#fff';\nconst themeBorder = '#E5E6EF';\nconst themeHeaderColor = '#2A2F54';\nconst memoizedTranspose = memoize(transposeArray);\nconst ColumnOrientedView = Styled((props)=>/*#__PURE__*/ _jsx(\"table\", _object_spread({\n cellPadding: \"0\",\n cellSpacing: \"0\"\n }, props)))`\n table-layout: fixed;\n width: 100%;\n text-align: center;\n border-collapse: collapse;\n border-radius: 6px;\n overflow: hidden;\n box-shadow: 0 0 0 1px ${themeBorder};\n word-break: break-word;\n hyphens: auto;\n`;\nconst RowOrientedView = Styled.div`\n box-shadow: 0 0 0 1px ${themeBorder};\n border-radius: 6px;\n`;\nconst Thead = Styled.thead`\n th {\n border-bottom: 1px solid ${themeBorder};\n }\n`;\nconst Tbody = Styled.tbody`\n`;\nconst TableHeader = Styled.th`\n font-size: 11px;\n border: none;\n font-weight: bold;\n padding: 6px;\n color: ${({ isDeleted })=>{\n return isDeleted ? '#FFF' : themeHeaderColor;\n}};\n background: ${({ isDeleted })=>{\n return isDeleted ? '#FF3737' : themeDark;\n}};\n`;\nconst EmptyHeader = Styled((props)=>/*#__PURE__*/ _jsx(TableHeader, _object_spread({}, props)))``;\nconst TableData = Styled.td`\n font-size: 11px;\n border:none;\n padding: 6px;\n background: ${themeLight};\n color: ${themeHeaderColor};\n`;\nconst RowHeader = Styled.th`\n font-size: 11px;\n border:none;\n padding: 6px;\n text-align: left;\n font-weight: bold;\n background: ${themeDark};\n color: ${themeHeaderColor};\n`;\nconst Row = Styled.tr`\n &:not(:first-of-type) {\n td, th {\n border-top: 1px solid ${themeBorder};\n }\n }\n`;\nconst StyledRow = Styled(View)`\n display: flex;\n flex-flow: row;\n\n &:not(:first-of-type) {\n td, th {\n border-top: 1px solid ${themeBorder};\n }\n }\n`;\nconst StyledQuestion = Styled(Text)`\n padding: 6px 8px;\n font-size: 10pt;\n width: 49.8%;\n overflow: hidden;\n text-overflow: ellipsis;\n font-weight: bold;\n background-color: ${themeDark};\n text-align: left;\n`;\nconst StyledAnswer = Styled(Text)`\n padding: 6px;\n font-size: 10pt;\n width: 49.8%;\n font-weight: 200;\n overflow: hidden;\n text-overflow: ellipsis;\n background-color: ${themeLight};\n text-align: left;\n`;\nclass Tableview extends Component {\n get columns() {\n const { rows, transpose, columns } = this.props;\n return !transpose ? columns : rows;\n }\n get rows() {\n const { rows, transpose, columns } = this.props;\n return !transpose ? rows : columns;\n }\n get tableData() {\n const { transpose, tableData } = this.props;\n return !transpose ? tableData : memoizedTranspose(tableData);\n }\n get isRowsExist() {\n const { transpose, orientation } = this.props;\n return (orientation !== 'row' || !transpose) && this.rows.length !== 0;\n }\n renderCell({ key, data, props }) {\n if (data && typeof data === 'string') {\n return /*#__PURE__*/ _jsx(TableData, _object_spread_props(_object_spread({}, props), {\n dangerouslySetInnerHTML: {\n __html: sanitizeHTML(data)\n }\n }), `cell_${key}`);\n }\n const emptyData = props.emptyCellStyle === 'line' ? '-' : '';\n const cellData = data || emptyData;\n return /*#__PURE__*/ _jsx(TableData, _object_spread_props(_object_spread({}, props), {\n children: cellData\n }), `cell_${key}`);\n }\n renderColumnHeaderCell({ key, data, props = {} }) {\n const fixedHeader = fixTableHeader(data);\n return typeof fixedHeader === 'string' ? /*#__PURE__*/ _jsx(TableHeader, _object_spread({\n dangerouslySetInnerHTML: {\n __html: sanitizeHTML(fixedHeader)\n }\n }, props), `columnHeaderCell_${key}`) : /*#__PURE__*/ _jsx(TableHeader, _object_spread_props(_object_spread({}, props), {\n children: fixedHeader\n }), `columnHeaderCell_${key}`);\n }\n renderColumnHeaders() {\n const { name, headerProps, showRowHeader } = this.props;\n let key = 0;\n return this.columns.length !== 0 && /*#__PURE__*/ _jsx(Row, {\n children: [\n showRowHeader && this.isRowsExist ? /*#__PURE__*/ _jsx(EmptyHeader, _object_spread({}, headerProps), `emptyHeaderCell_${name}`) : null,\n ...this.columns.map((data)=>this.renderColumnHeaderCell({\n key: `${name}_${key++}`,\n data,\n props: headerProps\n }))\n ]\n });\n }\n renderRowHeaderCell({ key, data, props }) {\n return typeof data === 'string' ? /*#__PURE__*/ _jsx(RowHeader, _object_spread({\n dangerouslySetInnerHTML: {\n __html: sanitizeHTML(data)\n }\n }, props), `rowHeaderCell_${key}`) : /*#__PURE__*/ _jsx(RowHeader, _object_spread_props(_object_spread({}, props), {\n children: data\n }), `rowHeaderCell_${key}`);\n }\n renderRow({ key, rowData, header, containerStyle, headerProps, answerProps }) {\n const { showAll, columns } = this.props;\n if (answerProps.hideEmptyRow && (!rowData.length || rowData.filter((data)=>data).length < 1)) return;\n const cells = rowData && Array.isArray(rowData) && rowData.reduce((acc, data, index)=>{\n if (!showAll && !data) return acc;\n const cellData = data && !showAll ? columns[index] : data;\n return [\n ...acc,\n this.renderCell({\n key: `${key}_${index}`,\n data: cellData,\n props: answerProps\n })\n ];\n }, []);\n if (!showAll && !cells.length) {\n cells.push(this.renderCell({\n data: null,\n props: answerProps\n }));\n }\n return /*#__PURE__*/ _jsxs(Row, _object_spread_props(_object_spread({}, containerStyle), {\n children: [\n (typeof header === 'string' || header) && this.renderRowHeaderCell({\n key,\n data: header,\n props: headerProps\n }),\n cells\n ]\n }), `row_${key}`);\n }\n renderRows() {\n const { name, containerStyle, headerProps, answerProps, showRowHeader } = this.props;\n return this.tableData.map((rowData, index)=>this.renderRow({\n key: `${name}_${index}`,\n rowData,\n containerStyle,\n header: this.isRowsExist && showRowHeader && this.rows[index],\n headerProps,\n answerProps\n }));\n }\n renderColumnOrientedView() {\n const _this_props = this.props, { tableComponent: TableComponent, showColumnHeader, showAll, transpose, tableData, columns, rows, orientation, containerStyle, headerProps, answerProps } = _this_props, props // rest\n = _object_without_properties(_this_props, [\n \"tableComponent\",\n \"showColumnHeader\",\n \"showAll\",\n \"transpose\",\n \"tableData\",\n \"columns\",\n \"rows\",\n \"orientation\",\n \"containerStyle\",\n \"headerProps\",\n \"answerProps\"\n ]);\n return /*#__PURE__*/ _jsxs(TableComponent, _object_spread_props(_object_spread({}, props), {\n children: [\n showAll && showColumnHeader && /*#__PURE__*/ _jsx(Thead, {\n children: this.renderColumnHeaders()\n }),\n /*#__PURE__*/ _jsx(Tbody, {\n children: this.renderRows()\n })\n ]\n }));\n }\n renderRowOrientedHeaderCell(data, _param) {\n var { className: rowHeaderClassName } = _param, props = _object_without_properties(_param, [\n \"className\"\n ]);\n const className = `rowOriented-row-header${rowHeaderClassName ? ` ${rowHeaderClassName}` : ''}`;\n return typeof data === 'string' ? /*#__PURE__*/ _jsx(StyledQuestion, _object_spread_props(_object_spread({\n className: className\n }, props), {\n dangerouslySetInnerHTML: {\n __html: sanitizeHTML(data)\n }\n })) : /*#__PURE__*/ _jsx(StyledQuestion, _object_spread_props(_object_spread({\n className: className\n }, props), {\n children: data\n }));\n }\n renderRowOrientedAnswerCell(data, _param) {\n var { className: answerClassName } = _param, props = _object_without_properties(_param, [\n \"className\"\n ]);\n const className = `rowOriented-row-answer${answerClassName ? ` ${answerClassName}` : ''}`;\n return typeof data === 'string' ? /*#__PURE__*/ _jsx(StyledAnswer, _object_spread({\n className: className,\n dangerouslySetInnerHTML: {\n __html: sanitizeHTML(data)\n }\n }, props)) : /*#__PURE__*/ _jsx(StyledAnswer, _object_spread_props(_object_spread({\n className: className\n }, props), {\n children: data\n }));\n }\n renderRowOrientedView() {\n const { name, rows, transpose, tableData, answerProps, containerStyle, headerProps } = this.props;\n let key = 0;\n return /*#__PURE__*/ _jsx(RowOrientedView, {\n children: !transpose ? rows.map((row, index)=>/*#__PURE__*/ _jsxs(StyledRow, _object_spread_props(_object_spread({}, containerStyle), {\n children: [\n row && this.renderRowOrientedHeaderCell(row, headerProps),\n this.renderRowOrientedAnswerCell(tableData[index], answerProps)\n ]\n }), `${name}_${row}_${key++}`)) : /*#__PURE__*/ _jsxs(_Fragment, {\n children: [\n this.renderColumnHeaders(),\n this.renderRow({\n key: `${name}_0`,\n rowData: tableData,\n answerProps\n })\n ]\n })\n });\n }\n render() {\n const { orientation, columns, tableComponent } = this.props;\n if (tableComponent !== ColumnOrientedView) {\n return this.renderColumnOrientedView();\n }\n switch(orientation){\n case 'row':\n return this.renderRowOrientedView();\n case 'column':\n default:\n return columns.length === 0 ? this.renderRowOrientedView() : this.renderColumnOrientedView();\n }\n }\n constructor(props){\n super(props);\n // Bindings\n this.renderRows = this.renderRows.bind(this);\n this.renderColumnHeaders = this.renderColumnHeaders.bind(this);\n this.renderRowOrientedView = this.renderRowOrientedView.bind(this);\n this.renderColumnOrientedView = this.renderColumnOrientedView.bind(this);\n }\n}\nconst cellPropTypes = [\n PropTypes.arrayOf(PropTypes.string),\n PropTypes.string,\n PropTypes.number,\n PropTypes.node\n];\nTableview.propTypes = {\n name: PropTypes.string,\n orientation: PropTypes.string,\n rows: PropTypes.arrayOf(PropTypes.string),\n columns: PropTypes.arrayOf(PropTypes.oneOfType(cellPropTypes)),\n tableData: PropTypes.arrayOf(PropTypes.oneOfType(cellPropTypes)),\n answerProps: PropTypes.shape(),\n containerStyle: PropTypes.shape(),\n headerProps: PropTypes.shape(),\n transpose: PropTypes.bool,\n rowProps: PropTypes.shape({}),\n tableComponent: PropTypes.oneOfType([\n PropTypes.element,\n PropTypes.object\n ]),\n showAll: PropTypes.bool,\n showRowHeader: PropTypes.bool,\n showColumnHeader: PropTypes.bool\n};\nTableview.defaultProps = {\n name: '',\n rows: [],\n columns: [],\n tableData: [],\n orientation: 'column',\n answerProps: {},\n containerStyle: {},\n headerProps: {},\n transpose: false,\n rowProps: {},\n tableComponent: ColumnOrientedView,\n showAll: true,\n showRowHeader: true,\n showColumnHeader: true\n};\nexport default Tableview;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nimport React, { Component, Fragment } from 'react';\nimport PropTypes from 'prop-types';\nimport { safeJSONParse } from '@jotforminc/utils';\nimport Text from '../../components/Text';\nimport Styled from '../../utils/styled';\nimport Image from '../../components/Image';\nimport Emoji from '../../components/Emoji';\nimport Baseline from '../../components/Baseline';\nimport Tableview from '../../components/Tableview';\nimport withMatrixProps from '../../hocs/Matrix';\nimport { ROW_BASED_MATRIX_TYPES } from '../../constants';\nimport { stripHTML } from '../../utils';\nconst StyledImage = Styled((props)=>/*#__PURE__*/ _jsx(Image, _object_spread({}, props)))`\n width: 12px;\n height: 12px;\n display: inline-block;\n vertical-align: text-bottom;\n`;\nconst EmojiText = Styled(Text)`\n display: inline-block;\n text-indent: 5px;\n`;\nconst StyledCheckboxImage = /*#__PURE__*/ _jsx(StyledImage, {\n src: \"//cdn.jotfor.ms/assets/img/submission/check_icon.png\"\n});\nconst StyledRadioActiveImage = /*#__PURE__*/ _jsx(StyledImage, {\n src: \"//cdn.jotfor.ms/assets/img/submission/Radio_Active.svg\"\n});\nclass Matrix extends Component {\n get orientation() {\n const { orientation, showAll } = this.props;\n return showAll ? 'column' : orientation;\n }\n get normalizedColumns() {\n const { orientation, columns, normalizedAnswer, isDynamic } = this.props;\n const sanitizedColumns = isDynamic ? columns.map((column)=>column.text) : columns.map((column)=>stripHTML(column));\n // Row oriented matrixes do not need any normalization\n if (orientation !== 'column') {\n return sanitizedColumns;\n }\n // Trying to get maximum number of sanitizedColumns by parsing answer data in case any column removed\n const maxAnswerLength = normalizedAnswer.reduce((prev, curr)=>Array.isArray(curr) ? Math.max(curr.length, prev) : prev, 1);\n // This case indicates that really a column removed. Therefore we are appending 'delete column' dummy sanitizedColumns\n if (sanitizedColumns.length < maxAnswerLength) {\n const dummyDeletedColumns = [\n ...Array(maxAnswerLength - sanitizedColumns.length)\n ].map(()=>'Deleted Column');\n return sanitizedColumns.concat(dummyDeletedColumns);\n }\n return sanitizedColumns;\n }\n get columns() {\n const { showAll, toggleOptions, inputType, emojiArray, columns } = this.props;\n if (inputType === 'Yes No') {\n return toggleOptions;\n }\n if (inputType === 'Emoji Slider') {\n return emojiArray.map((column)=>/*#__PURE__*/ _jsx(Emoji, {\n score: column\n }));\n }\n if (showAll) {\n switch(inputType){\n case 'Yes No':\n return toggleOptions;\n case 'Emoji Slider':\n return emojiArray.map((column)=>/*#__PURE__*/ _jsx(Emoji, {\n score: column\n }));\n case 'Dynamic':\n return columns.map(({ text })=>text);\n default:\n break;\n }\n }\n return this.normalizedColumns;\n }\n get columnnHeaderProps() {\n const { columnnHeaderProps, columns } = this.props;\n // If deleted column does not exist\n if (columns.length === this.columns.length) {\n return columnnHeaderProps;\n }\n return this.columns.map((_, index)=>_object_spread({\n isDeleted: index >= columns.length\n }, columnnHeaderProps[index] || {}));\n }\n sanitizeAnswer(ans) {\n return Array.isArray(ans) ? ans.map((answer)=>stripHTML(answer)) : stripHTML(ans);\n }\n get tableData() {\n const { answer, inputType, rows, dcolumns, emojiArray, normalizedAnswer, toggleOptions: [yesOption, noOption] = [], useDcols } = this.props;\n // Data of row based matrixes need to be converted into arrays if intended orientation is column\n if (ROW_BASED_MATRIX_TYPES.indexOf(inputType) > -1 && this.orientation === 'column') {\n if (inputType === 'Yes No') {\n return rows.map((_, index)=>this.columns.map((column)=>column === yesOption && normalizedAnswer[index] || column === noOption && !normalizedAnswer[index] ? StyledCheckboxImage : null));\n }\n if (inputType === 'Emoji Slider') {\n return rows.map((row)=>this.columns.map((_, index)=>answer[row] && parseInt(answer[row], 10) === emojiArray[index] ? StyledCheckboxImage : null));\n }\n if (!useDcols && (inputType === 'Slider' || inputType === 'Radio Button')) {\n return rows.map((_, index)=>this.columns.map((column)=>{\n const strippedHtml = stripHTML(normalizedAnswer[index]);\n const normalized = strippedHtml || normalizedAnswer[index];\n const newNormalized = typeof normalized === 'string' ? normalized.replace(/\\\\/g, '') : normalized;\n const isSelected = (newNormalized || newNormalized === 0) && (this.checkHasOnlyEmptyColumn() ? newNormalized === 1 : newNormalized.toString().trim() === column.toString().trim());\n return isSelected ? StyledRadioActiveImage : null;\n }));\n }\n }\n if (inputType === 'Emoji Slider') {\n return normalizedAnswer.map((rowAnswer)=>/*#__PURE__*/ _jsxs(_Fragment, {\n children: [\n /*#__PURE__*/ _jsx(Emoji, {\n score: rowAnswer\n }),\n /*#__PURE__*/ _jsx(EmojiText, {\n children: `(${emojiArray.indexOf(rowAnswer) + 1}/${emojiArray.length})`\n })\n ]\n }));\n }\n if (inputType === 'Yes No') {\n return normalizedAnswer.map((rowAnswer)=>rowAnswer ? yesOption : noOption);\n }\n if (useDcols || inputType === 'Dynamic') {\n return rows.map((_, index)=>safeJSONParse(dcolumns, dcolumns, true).map((column, i)=>{\n const ans = Array.isArray(normalizedAnswer[index]) ? normalizedAnswer[index][i] : '';\n if (!ans) return ans;\n if (this.orientation === 'row') return ans;\n if (column.type === 'Radio Button') return StyledRadioActiveImage;\n if (column.type === 'Check Box') return StyledCheckboxImage;\n if (column.type === 'Slider') return StyledCheckboxImage;\n return ans;\n }));\n }\n if (inputType === 'Check Box') {\n return rows.map((_, index)=>this.columns.map((column)=>{\n const ans = normalizedAnswer[index] && !Array.isArray(normalizedAnswer[index]) ? normalizedAnswer[index].toString() : normalizedAnswer[index];\n const strippedAns = this.sanitizeAnswer(ans);\n const isSelected = strippedAns && (this.checkHasOnlyEmptyColumn() ? strippedAns.includes('1') : strippedAns.includes(column));\n return isSelected ? StyledCheckboxImage : null;\n }));\n }\n return normalizedAnswer;\n }\n checkHasOnlyEmptyColumn() {\n return this.columns.length === 1 && this.columns[0] === '';\n }\n render() {\n const { text, rows, transpose, labelProps, answerProps, answerWrapperProps, baselineProps, sublabelProps, containerStyle, direction } = this.props;\n return /*#__PURE__*/ _jsx(Baseline, _object_spread_props(_object_spread({\n label: text,\n labelContainerProps: labelProps,\n answerWrapperProps: answerWrapperProps,\n direction: direction\n }, baselineProps), {\n children: /*#__PURE__*/ _jsx(Tableview, {\n name: text,\n rows: rows,\n transpose: transpose,\n tableData: this.tableData,\n columns: this.columns,\n orientation: this.orientation,\n containerStyle: containerStyle,\n headerProps: sublabelProps,\n answerProps: answerProps,\n columnnHeaderProps: this.columnnHeaderProps\n })\n }));\n }\n}\nconst cellDataPropTypes = [\n PropTypes.string,\n PropTypes.number,\n PropTypes.bool\n];\nMatrix.propTypes = {\n rows: PropTypes.arrayOf(PropTypes.string),\n columns: PropTypes.arrayOf(PropTypes.string),\n dcolumns: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.object\n ]),\n text: PropTypes.string,\n normalizedAnswer: PropTypes.arrayOf(PropTypes.oneOfType([\n ...cellDataPropTypes,\n PropTypes.arrayOf(cellDataPropTypes)\n ])),\n emojiArray: PropTypes.arrayOf(PropTypes.number),\n toggleOptions: PropTypes.arrayOf(PropTypes.string),\n labelProps: PropTypes.shape({}),\n answerProps: PropTypes.shape({}),\n answerWrapperProps: PropTypes.shape({}),\n baselineProps: PropTypes.shape({}),\n sublabelProps: PropTypes.shape({}),\n containerStyle: PropTypes.shape({}),\n columnnHeaderProps: PropTypes.arrayOf(PropTypes.shape({})),\n transpose: PropTypes.bool,\n orientation: PropTypes.oneOf([\n 'row',\n 'column'\n ]),\n answer: PropTypes.oneOfType([\n PropTypes.bool,\n PropTypes.shape({}),\n PropTypes.arrayOf(PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.number\n ]))\n ]),\n inputType: PropTypes.string,\n showAll: PropTypes.bool,\n direction: PropTypes.string,\n isDynamic: PropTypes.bool,\n useDcols: PropTypes.bool\n};\nMatrix.defaultProps = {\n rows: [],\n text: '',\n normalizedAnswer: [],\n dcolumns: '',\n emojiArray: [],\n toggleOptions: [\n 'Yes',\n 'No'\n ],\n labelProps: {},\n answerProps: {},\n answerWrapperProps: {},\n baselineProps: {},\n sublabelProps: {},\n containerStyle: {},\n columnnHeaderProps: [],\n columns: [],\n transpose: false,\n orientation: 'column',\n answer: {},\n inputType: '',\n showAll: false,\n direction: 'column',\n isDynamic: false,\n useDcols: false\n};\nexport default withMatrixProps(Matrix);\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React, { Component } from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport Image from '../../components/Image';\nimport Baseline from '../../components/Baseline';\nimport { generateNumberArray } from '../../utils';\nconst StyledImage = Styled((props)=>/*#__PURE__*/ _jsx(Image, _object_spread({}, props)))`\n width: 18px;\n height: 18px;\n margin-right: 5px;\n display: inline-block;\n vertical-align: text-bottom;\n`;\nclass Rating extends Component {\n get iconSources() {\n switch(this.props.starStyle){\n case 'Stars':\n return [\n 'https://cdn.jotfor.ms/assets/img/submission/rating_star_icon_rated.png',\n 'https://cdn.jotfor.ms/assets/img/submission/rating_star_icon_not_rated.png'\n ];\n case 'Stars 2':\n return [\n 'https://cdn.jotfor.ms/assets/img/default-theme/star-rating/star2_v2.png',\n 'https://cdn.jotfor.ms/assets/img/submission/rating_star_icon_not_rated.png'\n ];\n case 'Hearts':\n return [\n 'https://cdn.jotfor.ms/assets/img/submission/heart_active.svg',\n 'https://cdn.jotfor.ms/assets/img/submission/heart_normal.svg'\n ];\n case 'Light Bulps':\n return [\n 'https://cdn.jotfor.ms/assets/img/default-theme/star-rating/bulp_v2.png',\n 'https://cdn.jotfor.ms/assets/img/default-theme/star-rating/bulp_v2_not_rated.png'\n ];\n case 'Lightnings':\n return [\n 'https://cdn.jotfor.ms/assets/img/default-theme/star-rating/lightning_v2.png',\n 'https://cdn.jotfor.ms/assets/img/default-theme/star-rating/lightning_v2_not_rated.png'\n ];\n case 'Flags':\n return [\n 'https://cdn.jotfor.ms/assets/img/default-theme/star-rating/flag_v2.png',\n 'https://cdn.jotfor.ms/assets/img/default-theme/star-rating/flag_v2_not_rated.png'\n ];\n case 'Shields':\n return [\n 'https://cdn.jotfor.ms/assets/img/default-theme/star-rating/shield_v2.png',\n 'https://cdn.jotfor.ms/assets/img/default-theme/star-rating/shield_v2_not_rated.png'\n ];\n case 'Pluses':\n return [\n 'https://cdn.jotfor.ms/assets/img/default-theme/star-rating/plus_v2.png',\n 'https://cdn.jotfor.ms/assets/img/default-theme/star-rating/plus_v2_not_rated.png'\n ];\n default:\n return [\n 'https://cdn.jotfor.ms/assets/img/submission/rating_star_icon_rated.png',\n 'https://cdn.jotfor.ms/assets/img/submission/rating_star_icon_not_rated.png'\n ];\n }\n }\n getStarCounts() {\n const { answer, stars } = this.props;\n const filledStars = parseInt(answer, 10) ? parseInt(answer, 10) : 0;\n const emptyStars = parseInt(stars - answer, 10) > -1 ? parseInt(stars - answer, 10) : 0;\n return {\n filledStars,\n emptyStars\n };\n }\n renderSingleIcon(star) {\n const { name, answer, answerProps, scaleFrom = 1 } = this.props;\n // Decide whether star is filled or not based on answer data\n const isFilled = star + 1 <= answer - scaleFrom + 1;\n // Prepare icon props\n const key = `${name}_${isFilled ? 'filled' : 'empty'}_${star}`;\n const src = isFilled ? this.iconSources[0] : this.iconSources[1];\n const className = `${isFilled ? 'isFilled' : 'isEmpty'} ${answerProps.className || ''}`;\n return /*#__PURE__*/ _jsx(StyledImage, _object_spread({\n src: src,\n className: className\n }, answerProps), key);\n }\n renderRating() {\n const { stars } = this.props;\n const raitingArray = generateNumberArray(stars);\n return raitingArray.map(this.renderSingleIcon);\n }\n render() {\n const { text, labelProps, direction, answerWrapperProps, baselineProps } = this.props;\n return /*#__PURE__*/ _jsx(Baseline, _object_spread_props(_object_spread({\n label: text,\n labelContainerProps: labelProps,\n answerWrapperProps: answerWrapperProps,\n direction: direction\n }, baselineProps), {\n children: this.renderRating()\n }));\n }\n constructor(props){\n super(props);\n this.renderRating = this.renderRating.bind(this);\n this.renderSingleIcon = this.renderSingleIcon.bind(this);\n }\n}\nRating.propTypes = {\n name: PropTypes.string,\n text: PropTypes.string,\n answer: PropTypes.string,\n stars: PropTypes.string,\n labelProps: PropTypes.shape({}),\n answerProps: PropTypes.shape({}),\n answerWrapperProps: PropTypes.shape({}),\n baselineProps: PropTypes.shape({}),\n starStyle: PropTypes.oneOf([\n 'Stars',\n 'Stars 2',\n 'Hearts',\n 'Light Bulps',\n 'Lightnings',\n 'Flags',\n 'Shields',\n 'Pluses'\n ]),\n direction: PropTypes.string\n};\nRating.defaultProps = {\n name: '',\n text: '',\n answer: '',\n stars: '5',\n labelProps: {},\n answerProps: {},\n answerWrapperProps: {},\n baselineProps: {},\n starStyle: 'Stars',\n direction: 'column'\n};\nexport default Rating;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React, { PureComponent } from 'react';\nimport Styled from 'styled-components';\nimport PropTypes from 'prop-types';\nimport Baseline from '../../components/Baseline';\nconst SheetboxCellContainer = Styled.div`\n display: table-cell;\n vertical-align: middle;\n width: 100%;\n`;\nconst SheetboxWrapper = Styled.div`\n text-align: center;\n line-height: 1;\n font-size: 16px;\n`;\nconst SheetboxInput = Styled.input`\n display: none;\n\n &:checked + label {\n border-color: #54B45C;\n background-color: #F0FFF1;\n background-image: url(https://cdn.jotfor.ms/assets/img/submission/sheetbox_check_icon.png);\n }\n`;\nconst SheetboxCustomInput = Styled.label`\n display: inline-block;\n width: 1.125em;\n height: 1.125em;\n border: 2px solid #D3D6EC;\n background-position: center;\n border-radius: 3px;\n background-size: 0.625em;\n background-repeat: no-repeat;\n cursor: pointer;\n`;\nclass Sheetbox extends PureComponent {\n render() {\n const { answer, id, onChange, text, answerWrapperProps, labelProps, direction, baselineProps } = this.props;\n return /*#__PURE__*/ _jsx(Baseline, _object_spread_props(_object_spread({\n label: text,\n answerWrapperProps: answerWrapperProps,\n labelContainerProps: labelProps,\n direction: direction\n }, baselineProps), {\n children: /*#__PURE__*/ _jsx(SheetboxCellContainer, {\n children: /*#__PURE__*/ _jsxs(SheetboxWrapper, {\n children: [\n /*#__PURE__*/ _jsx(SheetboxInput, {\n id: id,\n type: \"checkbox\",\n checked: answer === '1',\n onChange: onChange\n }),\n /*#__PURE__*/ _jsx(SheetboxCustomInput, {\n htmlFor: id\n })\n ]\n })\n })\n }));\n }\n}\nSheetbox.propTypes = {\n answer: PropTypes.string,\n onChange: PropTypes.func,\n id: PropTypes.string\n};\nSheetbox.defaultProps = {\n answer: '0',\n onChange: ()=>{},\n id: ''\n};\nexport default Sheetbox;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport unescape from 'lodash/unescape';\n// Note: if u change unescape in here, please change also mobile side. (index.native.jsx)\nimport Text from '../../components/Text';\nimport Baseline from '../../components/Baseline';\nimport { sanitizeHTML, replaceUrlsWithAnchors } from '../../utils';\nconst StyledText = Styled(Text)`\n white-space: pre-wrap;\n`;\nclass Textarea extends React.Component {\n render() {\n const { text, answer, labelProps, answerProps, answerWrapperProps, baselineProps, direction, wysiwyg, mde } = this.props;\n const isHTMLAnswerAllowed = wysiwyg === 'Enable' || mde === 'Yes';\n const sanitizedAnswer = isHTMLAnswerAllowed && sanitizeHTML(answer);\n const replacedText = replaceUrlsWithAnchors(sanitizedAnswer);\n const Child = isHTMLAnswerAllowed ? /*#__PURE__*/ _jsx(StyledText, _object_spread({\n dangerouslySetInnerHTML: {\n __html: replacedText || unescape(sanitizedAnswer)\n },\n noSanitize: replacedText\n }, answerProps)) : /*#__PURE__*/ _jsx(StyledText, _object_spread_props(_object_spread({}, answerProps), {\n children: answer\n }));\n return /*#__PURE__*/ _jsx(Baseline, _object_spread_props(_object_spread({\n label: text,\n labelContainerProps: labelProps,\n answerWrapperProps: answerWrapperProps,\n direction: direction\n }, baselineProps), {\n children: Child\n }));\n }\n}\nTextarea.propTypes = {\n answer: PropTypes.string,\n labelProps: PropTypes.shape({}),\n text: PropTypes.string,\n answerProps: PropTypes.shape({}),\n answerWrapperProps: PropTypes.shape({}),\n baselineProps: PropTypes.shape({}),\n direction: PropTypes.string,\n wysiwyg: PropTypes.string,\n mde: PropTypes.string\n};\nTextarea.defaultProps = {\n answer: '',\n labelProps: {},\n text: '',\n answerProps: {},\n answerWrapperProps: {},\n baselineProps: {},\n direction: 'column',\n wysiwyg: 'Disable',\n mde: 'No'\n};\nexport default Textarea;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport Text from '../../components/Text';\nimport View from '../../components/View';\nimport Styled from '../../utils/styled';\nimport Imageline from '../../components/Imageline';\nconst StyledView = Styled(View)`\n border-bottom: 1px solid #C2C3C4;\n display: flex;\n flex-direction: column;\n padding-bottom: 12px;\n margin-top: 12px;\n page-break-inside: avoid;\n`;\nconst ProductView = Styled(View)`\n padding: 15px 0;\n border-bottom: 1px solid #C2C3C4;\n display: flex;\n page-break-inside: avoid;\n`;\nconst ProductName = Styled(Text)`\n font-weight: bold;\n color: #18152C;\n`;\nconst ProductPeriod = Styled(Text)`\n font-weight: bold;\n color: #18152C;\n`;\nconst ProductPrice = Styled(Text)`\n flex-shrink: 1;\n font-weight: bold;\n`;\nconst ProductImage = Styled(Text)`\n flex-shrink: 1;\n min-width: 100px;\n`;\nconst ProductOptions = Styled(View)`\n flex-direction: column;\n`;\nconst ProductDetails = Styled(View)`\n flex-grow: 1;\n padding: 0 15px;\n line-height: 1.5em;\n`;\nconst HeaderText = Styled(Text)`\n font-weight: bold;\n`;\nconst PriceView = Styled(View)`\n display: flex;\n margin-bottom: 12px;\n`;\nconst PriceLabel = Styled(Text)`\n flex-grow: 1;\n`;\nconst PriceText = Styled(Text)`\n flex-shrink: 1;\n`;\nconst PriceDetailsView = Styled(View)`\n margin: 12px 0;\n font-weight: bold;\n display: flex;\n flex-direction: column;\n border-bottom: 1px solid #C2C3C4;\n`;\nconst PaymentImageText = Styled(Text)`\n padding: 41px 5px;\n background-color: #CEF1FE;\n width: 100%;\n max-width: 100px;\n text-align: center;\n overflow: hidden;\n text-overflow: ellipsis;\n`;\nconst PayerView = Styled(View)`\n border-bottom: 1px solid #C2C3C4;\n display: flex;\n flex-direction: column;\n padding-bottom: 12px;\n margin-top: 12px;\n page-break-inside: avoid;\n`;\nconst PayerViewTitle = Styled(Text)`\n font-weight: bold;\n`;\nconst ProductImageline = Styled((props)=>/*#__PURE__*/ _jsx(Imageline, _object_spread({}, props)))`\n text-align: center;\n`;\n// Sheets\nconst SheetsProductView = Styled(View)`\n ${({ isPreview })=>isPreview ? `display: table;\n width: 100%;\n & + & {\n padding-top: 12px;\n margin-top: 12px;\n border-top: 1px solid rgba(209, 212, 228, 0.5);\n }` : `display: inline-table;\n height: 26px;\n border-radius: 4px;\n padding: 0 4px;\n margin-right: 6px;`}\n`;\nconst SheetsProductName = Styled(Text)`\n display: inline-table;\n vertical-align: middle;\n color: #18152C;\n line-height: 26px;\n ${({ isPreview })=>isPreview && 'font-family: \"Circular Std Medium\", \"Work Sans SemiBold\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;'}\n`;\nconst SheetsProductDetails = Styled(View)`\n display: table-cell;\n vertical-align: middle;\n padding-right: 20px;\n white-space: normal;\n`;\nconst SheetsPriceView = Styled(View)`\n display: table;\n width: 100%;\n table-layout: fixed;\n`;\nconst SheetsPriceLabel = Styled(Text)`\n display: table-cell;\n vertical-align: middle;\n`;\nconst SheetsPriceText = Styled(Text)`\n display: table-cell;\n vertical-align: middle;\n text-align: right;\n font-size: 18px;\n font-family: \"Circular Std Medium\", \"Work Sans SemiBold\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n`;\nconst SheetsPriceDetailsView = Styled(View)`\n display: block;\n text-decoration: none;\n border-top: 1px solid rgba(209, 212, 228, 0.5);\n text-transform: uppercase;\n padding-top: 12px;\n margin-top: 16px;\n`;\nconst SheetsPayerView = Styled(View)`\n display: block;\n padding-top: 16px;\n position: relative;\n margin-top: 12px;\n border-top: 1px solid rgba(209, 212, 228, 0.5);\n`;\nconst SheetsPayerViewTitle = Styled(Text)`\n font-family: \"Circular Std Medium\", \"Work Sans SemiBold\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n font-size: 17px;\n margin-bottom: 6px;\n\n & ~ * {\n color: #51585D;\n font-size: 15px;\n }\n`;\nconst SheetsProductOptions = Styled(Text)`\n color: #51585D;\n font-size: 14px;\n & > div {\n float: left;\n width: 100%;\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n }\n`;\nconst SheetsProductPrice = Styled(Text)`\n display: table-cell;\n vertical-align: middle;\n white-space: nowrap;\n text-align: right;\n width: 1px;\n`;\nconst SheetsProductImageline = Styled((props)=>/*#__PURE__*/ _jsx(Imageline, _object_spread({}, props)))`\n display: table-cell;\n vertical-align: middle;\n font-size: 0;\n ${({ isPreview })=>isPreview ? `height: 60px;\n width: 60px;\n border: 1px solid #D5D9EC;\n border-radius: 4px;\n overflow: hidden;\n & + div {\n padding-left: 14px;\n }` : `width: 20px;\n height: 20px;\n & + div {\n padding-left: 6px;\n }\n & > div {\n display: inherit;\n vertical-align: middle;\n width: 20px;\n height: 20px;\n border-radius: 4px;\n overflow: hidden;\n background-color: #fff;\n }`}\n`;\nconst SheetsPaymentImageText = Styled(Text)`\n display: table-cell;\n vertical-align: middle;\n ${({ isPreview })=>isPreview ? `width: 1px;\n white-space: nowrap;\n padding: 30px 10px;\n border-radius: 4px;\n font-size: 18px;\n font-family: \"Circular Std Medium\", \"Work Sans SemiBold\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n & + div {\n padding: 0 0 0 14px;\n display: table-cell;\n }` : `padding: 0 4px;\n & + div {\n padding: 0 4px;\n display: none;\n }\n `}\n`;\nexport const defaultsMap = {\n StyledView,\n ProductView,\n ProductName,\n ProductPeriod,\n ProductPrice,\n ProductImage,\n ProductOptions,\n ProductDetails,\n HeaderText,\n PriceLabel,\n PriceText,\n PriceDetailsView,\n PaymentImageText,\n PriceView,\n ProductImageline,\n PayerView,\n PayerViewTitle\n};\nexport const sheetsMap = _object_spread_props(_object_spread({}, defaultsMap), {\n ProductView: SheetsProductView,\n ProductImageline: SheetsProductImageline,\n ProductName: SheetsProductName,\n PriceView: SheetsPriceView,\n PriceLabel: SheetsPriceLabel,\n PriceText: SheetsPriceText,\n ProductDetails: SheetsProductDetails,\n PriceDetailsView: SheetsPriceDetailsView,\n PayerView: SheetsPayerView,\n PayerViewTitle: SheetsPayerViewTitle,\n ProductOptions: SheetsProductOptions,\n ProductPrice: SheetsProductPrice,\n PaymentImageText: SheetsPaymentImageText\n});\nexport function getStyledComponent(appName) {\n switch(appName){\n case 'sheets':\n return sheetsMap;\n default:\n return defaultsMap;\n }\n}\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { isBrightColor } from '@jotforminc/utils';\nimport Styled from 'styled-components';\nimport List from '../../../components/List';\nimport Baseline from '../../../components/Baseline';\nconst getAnswer = (answer)=>{\n const keys = [\n 'title'\n ];\n return keys.reduce((acc, curr)=>{\n if (acc === '' && answer[curr]) {\n // eslint-disable-next-line no-param-reassign\n acc = answer[curr];\n }\n return acc;\n }, '');\n};\nconst getIconProps = (props)=>{\n const { appIconColor, appIconType, appIconURL, appIconBackground } = props;\n return {\n iconColor: appIconColor,\n type: appIconType,\n url: appIconURL,\n backgroundColor: appIconBackground\n };\n};\nconst SubmittedVia = ({ answer, labelProps, answerProps, answerWrapperProps, label, direction, baselineProps, containerProps })=>{\n const { PortalItemRenderer = null } = answerProps;\n const icon = getIconProps(answer);\n const portalItemProps = _object_spread_props(_object_spread({}, answer), {\n icon\n });\n const StyledPortalItemRenderer = Styled.div`\n color: ${isBrightColor(answer.appIconBackground) ? '#2B3245' : '#FFF'};\n background-color: ${answer.appIconBackground};\n padding: 6px;\n border: 1px solid #E3E5F5;\n font-size: 14px;\n font-weight: 500;\n border-radius: 4px;\n width: fit-content;\n max-width: 400px;\n\n * { font-size: 14px; }\n & > div:only-child { padding-right: 4px; }\n .jfIconSVG-wrapper svg { padding: 0; }\n `;\n const normalizedAnswer = getAnswer(answer);\n const hasAnswer = (normalizedAnswer === null || normalizedAnswer === void 0 ? void 0 : normalizedAnswer.length) > 0;\n return /*#__PURE__*/ _jsx(Baseline, _object_spread_props(_object_spread({\n label: label,\n labelContainerProps: labelProps,\n answerWrapperProps: answerWrapperProps,\n direction: direction\n }, baselineProps), {\n children: hasAnswer && (PortalItemRenderer ? /*#__PURE__*/ _jsx(StyledPortalItemRenderer, {\n children: /*#__PURE__*/ _jsx(PortalItemRenderer, _object_spread({}, portalItemProps))\n }) : /*#__PURE__*/ _jsx(List, {\n type: \"option\",\n showAll: false,\n allItems: [\n normalizedAnswer\n ],\n items: [\n normalizedAnswer\n ],\n itemProps: answerProps,\n containerProps: containerProps\n }))\n }));\n};\nSubmittedVia.propTypes = {\n answer: PropTypes.string,\n label: PropTypes.string,\n labelProps: PropTypes.shape({}),\n answerProps: PropTypes.shape({}),\n answerWrapperProps: PropTypes.shape({}),\n direction: PropTypes.string,\n baselineProps: PropTypes.shape({}),\n containerProps: PropTypes.shape({})\n};\nSubmittedVia.defaultProps = {\n baselineProps: {},\n answer: '',\n label: 'Source App',\n labelProps: {},\n answerProps: {},\n answerWrapperProps: {},\n direction: 'column',\n containerProps: {}\n};\nexport default SubmittedVia;\n","/* eslint-disable max-len */ import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Styled from 'styled-components';\nimport { t } from '@jotforminc/translation';\nimport Baseline from '../../../components/Baseline';\nimport Tableview from '../../../components/Tableview';\nimport ThreadAction from './ThreadAction';\nimport ThreadActor from './ThreadActor';\nimport ThreadDate from './ThreadDate';\nimport { LocaleTypes } from '../../../constants/schemas';\nconst StyledTableview = Styled(Tableview)`\n thead {\n th {\n text-align: left;\n border-bottom: 1px solid #E5E6EF;\n background-color: #EDEEF7;\n padding: 12px;\n\n &:not(:last-of-type) {\n border-right: 1px solid #DFDEE7;\n }\n }\n }\n\n tbody {\n td {\n background-color: #FAFAFD;\n\n &:not(:last-of-type).isAnswer {\n border-right: 1px solid #E5E6EF;\n }\n }\n }\n\n .stAnswer {\n &-team {\n display: flex;\n align-items: center;\n font-size: 12px;\n line-height: 14px;\n color: #0A1551;\n margin-top: 6px;\n\n &-name {\n display: flex;\n align-items: center;\n font-size: 12px;\n margin-top: 6px;\n font-weight: 500;\n\n svg {\n width: 15px;\n height: 15px;\n margin-right: 4px;\n }\n }\n\n .sb-customIcon {\n width: 14px;\n height: 14px;\n margin-right: 4px;\n\n > span > span {\n font-size: 11px !important;\n widh: 14px;\n height: 14px;\n display: inline-block;\n }\n }\n }\n\n &-action {\n line-height: 1.5;\n margin: 9px 6px;\n\n &-text {\n &.isComment {\n width: 100%;\n }\n\n &.isOutcome {\n display: inline-block;\n padding: 6px 12px;\n margin: 4px auto 4px 0;\n border-radius: 4px;\n }\n }\n\n &-image {\n &.isSignature {\n margin-top: 8px;\n max-height: 42px;\n display: block;\n }\n }\n\n &-pill {\n background-color: #F3F3FE;\n color: #6C73A8;\n border-radius: 10px;\n display: inline-flex;\n align-items: center;\n font-size: 12px;\n padding: 2px 6px 2px 4px;\n gap: 4px;\n margin-top: 6px;\n margin-bottom: 6px;\n \n &:before {\n content: \"\";\n width: 16px;\n height: 16px;\n background-image: url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='17' height='16' fill='none'%3E%3Cpath fill='%236C73A8' fill-rule='evenodd' d='M12.06 4.027a2.476 2.476 0 0 1 0 3.502l-.888.889a.667.667 0 1 0 .942.942l.89-.888a3.81 3.81 0 0 0-5.388-5.388l-.889.89a.667.667 0 1 0 .943.942l.889-.889a2.476 2.476 0 0 1 3.502 0Zm-6.666 6.666a.667.667 0 0 1 0-.942L9.84 5.306a.667.667 0 0 1 .943.943l-4.445 4.444a.667.667 0 0 1-.943 0Zm-1.28-2.222a2.476 2.476 0 0 0 3.502 3.502l.89-.89a.667.667 0 1 1 .942.944l-.889.889a3.81 3.81 0 0 1-5.387-5.388l.889-.889a.667.667 0 0 1 .943.943l-.89.89Z' clip-rule='evenodd'/%3E%3C/svg%3E\"); background-repeat: no-repeat;\n background-position: center;\n background-size: 16px;\n }\n }\n }\n\n &-date {\n padding: 0 6px;\n }\n\n &-actor {\n display: flex;\n margin: 9px 3px;\n align-items: center;\n\n .sb-customIcon {\n > span > span {\n font-size: 16px !important;\n }\n }\n\n &-avatar {\n min-width: 36px;\n max-width: 36px;\n min-height: 36px;\n max-height: 36px;\n flex-shrink: 1;\n border-radius: 50%;\n overflow: hidden;\n background-color: #5E74E6;\n box-shadow: 0 0 0 1px #fff, 0 0 0 3px #dcdff0;\n position: relative;\n\n &-image {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n background-repeat: no-repeat;\n\n &.isUser {\n background-size: cover;\n }\n\n &.isSystem {\n background-image: url(\"data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%23fff' d='M5.906 3.633h8.182v3.636H5.906z'/%3E%3Cpath d='M3.18 13.635V9.09h13.636v4.545' stroke='%23fff' stroke-width='1.7' stroke-linejoin='round'/%3E%3Cpath stroke='%23fff' stroke-width='1.7' d='M9.83 13.637V9.09'/%3E%3Ccircle cx='3.17898' cy='14.0969' r='2.27273' fill='%23fff'/%3E%3Ccircle cx='16.8157' cy='14.0969' r='2.27273' fill='%23fff'/%3E%3Cpath fill='%23fff' d='M7.723 11.824h4.545v4.546H7.723z'/%3E%3C/svg%3E\");\n background-position: center;\n }\n\n &.isGroup {\n background-image: url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='13' fill='none'%3E%3Cpath fill='%23fff' fill-rule='evenodd' d='M3.08.922a1.77 1.77 0 1 0 0 3.54 1.77 1.77 0 0 0 0-3.54ZM7 3.282a2.36 2.36 0 1 0 0 4.72 2.36 2.36 0 0 0 0-4.72Zm0 5.31c-2.176 0-4.13 1.49-4.13 3.541 0 .326.264.59.59.59h7.08a.59.59 0 0 0 .59-.59c0-2.051-1.954-3.54-4.13-3.54ZM10.75.923a1.77 1.77 0 1 0 0 3.54 1.77 1.77 0 0 0 0-3.54Zm-7.29 4.835a.59.59 0 0 0-.766-.544C1.462 5.6.51 6.672.51 8.003c0 .326.264.59.59.59h2.51a.59.59 0 0 0 .484-.928 3.52 3.52 0 0 1-.632-1.908Zm7.844-.544a.59.59 0 0 0-.767.544 3.52 3.52 0 0 1-.632 1.908.59.59 0 0 0 .484.928h2.51a.59.59 0 0 0 .59-.59c0-1.331-.952-2.403-2.185-2.79Z' clip-rule='evenodd'/%3E%3C/svg%3E\");\n background-position: center;\n background-size: 20px;\n background-color: #6C73A8;\n }\n svg {\n height: unset !important;\n width: unset !important;\n stroke: none !important;\n }\n }\n }\n\n &-info {\n flex-grow: 1;\n margin-left: 12px;\n display: flex;\n justify-content: center;\n flex-direction: column;\n line-height: 1.5;\n }\n }\n }\n`;\nconst SubmissionThread = ({ answer, text, labelProps, answerWrapperProps, direction, transpose, baselineProps, orientation, containerStyle, sublabelProps, answerProps, columnnHeaderProps, dateFormat, locale, amPmHour, showAvatars, showAssigneeEmail, showComments, showSignature, showIP, userTimeZone, customTableProps })=>{\n const columns = [\n t('Actor'),\n t('Actions'),\n t('Date')\n ];\n const tableData = React.useMemo(()=>answer.map((rowData)=>{\n var _action_details;\n const { action, actor, ip, date } = rowData;\n if (action === null || action === void 0 ? void 0 : (_action_details = action.details) === null || _action_details === void 0 ? void 0 : _action_details.notRequired) {\n return null;\n }\n return [\n /*#__PURE__*/ _jsx(ThreadActor, _object_spread_props(_object_spread({}, actor), {\n showAvatars: showAvatars,\n showAssigneeEmail: showAssigneeEmail\n })),\n /*#__PURE__*/ _jsx(ThreadAction, _object_spread_props(_object_spread({}, action), {\n actor: actor,\n showComments: showComments,\n showSignature: showSignature\n })),\n /*#__PURE__*/ _jsx(ThreadDate, {\n date: date,\n ip: ip,\n dateFormat: dateFormat,\n locale: locale,\n amPmHour: amPmHour,\n showIP: showIP,\n userTimeZone: userTimeZone\n })\n ];\n }), [\n answer,\n dateFormat,\n locale,\n amPmHour,\n showAvatars,\n showAssigneeEmail,\n userTimeZone\n ]);\n return /*#__PURE__*/ _jsx(Baseline, _object_spread_props(_object_spread({\n label: text,\n labelContainerProps: labelProps,\n answerWrapperProps: answerWrapperProps,\n direction: direction\n }, baselineProps), {\n children: /*#__PURE__*/ _jsx(StyledTableview, _object_spread({\n name: text,\n rows: [],\n tableData: tableData,\n columns: columns,\n orientation: orientation,\n containerStyle: containerStyle,\n headerProps: sublabelProps,\n answerProps: answerProps,\n transpose: transpose,\n columnnHeaderProps: columnnHeaderProps\n }, customTableProps))\n }));\n};\nSubmissionThread.propTypes = {\n answer: PropTypes.arrayOf(PropTypes.shape({})),\n text: PropTypes.string,\n columns: PropTypes.arrayOf(PropTypes.string),\n labelProps: PropTypes.shape({}),\n answerProps: PropTypes.shape({}),\n answerWrapperProps: PropTypes.shape({}),\n baselineProps: PropTypes.shape({}),\n sublabelProps: PropTypes.shape({}),\n containerStyle: PropTypes.shape({}),\n columnnHeaderProps: PropTypes.arrayOf(PropTypes.shape({})),\n transpose: PropTypes.bool,\n orientation: PropTypes.oneOf([\n 'row',\n 'column'\n ]),\n direction: PropTypes.string,\n dateFormat: PropTypes.string,\n userTimeZone: PropTypes.string,\n locale: LocaleTypes.schema,\n amPmHour: PropTypes.bool,\n showAvatars: PropTypes.bool,\n showAssigneeName: PropTypes.bool,\n showAssigneeEmail: PropTypes.bool,\n showComments: PropTypes.bool,\n showSignature: PropTypes.bool,\n showIP: PropTypes.bool,\n showDate: PropTypes.bool,\n customTableProps: PropTypes.object\n};\nSubmissionThread.defaultProps = {\n text: '',\n labelProps: {},\n answerProps: {},\n answerWrapperProps: {},\n baselineProps: {},\n sublabelProps: {},\n containerStyle: {},\n columnnHeaderProps: [],\n columns: [],\n transpose: false,\n orientation: 'column',\n answer: [],\n userTimeZone: '',\n direction: 'column',\n dateFormat: 'MMM D, YYYY HH:mm',\n locale: LocaleTypes.default,\n amPmHour: false,\n showAvatars: PropTypes.bool,\n showAssigneeName: true,\n showAssigneeEmail: true,\n showComments: true,\n showSignature: true,\n showIP: true,\n showDate: true,\n customTableProps: {}\n};\nexport default SubmissionThread;\n","import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport styled from 'styled-components';\nimport Baseline from '../../components/Baseline';\nimport AssigneeLine from '../../components/AssigneeLine';\nconst ScAssigneeLine = styled(AssigneeLine)`\n border-radius: 14px !important;\n padding: 5px 6px !important;\n img {\n width: 18px !important;\n height: 18px !important;\n }\n`;\nconst UserInfo = ({ text, answer, labelProps, answerProps, answerWrapperProps, containerProps, baselineProps, direction })=>{\n const { name, avatarUrl, email } = answer;\n return /*#__PURE__*/ _jsx(Baseline, _object_spread_props(_object_spread({\n label: text,\n labelContainerProps: labelProps,\n answerWrapperProps: answerWrapperProps,\n direction: direction\n }, baselineProps), {\n children: /*#__PURE__*/ _jsx(\"div\", _object_spread_props(_object_spread({}, containerProps), {\n children: /*#__PURE__*/ _jsx(ScAssigneeLine, _object_spread({\n label: name || email,\n imageLabel: name || email,\n value: avatarUrl\n }, answerProps))\n }))\n }));\n};\nUserInfo.propTypes = {\n text: PropTypes.string,\n answer: PropTypes.shape({\n name: PropTypes.string,\n email: PropTypes.string,\n avatarUrl: PropTypes.string\n }),\n labelProps: PropTypes.shape({}),\n answerProps: PropTypes.oneOfType([\n PropTypes.shape({}),\n PropTypes.array\n ]),\n answerWrapperProps: PropTypes.shape({}),\n baselineProps: PropTypes.shape({}),\n containerProps: PropTypes.shape({}),\n direction: PropTypes.string\n};\nUserInfo.defaultProps = {\n text: '',\n answer: {},\n labelProps: {},\n answerProps: [],\n answerWrapperProps: {},\n baselineProps: {},\n containerProps: {},\n direction: 'column'\n};\nexport default UserInfo;\n","import Styled from 'styled-components';\n// eslint-disable-next-line\nconst signHere = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGZpbGw9Im5vbmUiIHZpZXdCb3g9IjAgMCAyMDAgNDMiPgogIDxwYXRoIHN0cm9rZT0iI0RGRTNFRCIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIiBzdHJva2Utd2lkdGg9IjEuNSIgZD0iTTEgMzguNjAyYzExLjI0NiAzLjE5NyAyMi4xODItLjk5IDMxLjUwOC03LjE3MiA0LjkzMi0zLjI3IDkuODI2LTcuMTgzIDEyLjgyNS0xMi4zNDEgMS4xOTUtMi4wNTcgMi42NTYtNS42MjYtMS4xMDYtNS42NTgtNC4wOTMtLjAzNC03LjE0IDMuNjYyLTguNjY4IDcuMDIyLTIuMTkgNC44MTktMi4yNjggMTAuNTI2LjQwNyAxNS4xNyAyLjUzMSA0LjM5NSA2Ljc3OCA2LjQ3NCAxMS44NDUgNS42MiA1LjI5My0uODkzIDkuOTItNC41MDggMTMuNzY1LTcuOTg2YTQwLjcxNCA0MC43MTQgMCAwIDAgMy45NjYtNC4wOTNjLjE0Mi0uMTcuNjQyLTEuMDA2Ljk2Ni0xLjA2NC4xMi0uMDIxLjI5OCAzLjY0My4zMyAzLjg0My4yODggMS43OSAxLjE5MSAzLjgwNiAzLjMwNSAzLjg2NyAyLjY5LjA3OCA0Ljk0LTIuMTcyIDYuNzUtMy44My42MS0uNTU5IDIuNTUtMy4yNDEgMy41ODMtMy4yNDEuNDI1IDAgMS4yNDkgMi4xNDMgMS40MzcgMi40MjggMi40ODQgMy43NjQgNi4xMzIgMi40MDEgOC45Ni0uMjM4LjUyLS40ODUgMy4zMDUtNC4zNjcgNC40MzYtMy42NjcuOTExLjU2MyAxLjMxMyAxLjg5MyAxLjc4IDIuNzc4Ljc2IDEuNDQxIDEuNzIyIDIuNDY4IDMuMzMgMy4wMDQgMy40OTMgMS4xNjYgNy4yNjEtMi4xMDIgMTAuODAzLTIuMTAyIDEuMDMzIDAgMS41NjEuNTY4IDIuMTEgMS4zNTEuNzQ5IDEuMDY4IDEuNTIxIDEuODEzIDIuODczIDIuMTAzIDQuMTg4Ljg5OCA3LjYxNy0zLjA3NyAxMS42NjctMi43MjggMS4xODEuMTAxIDIuMDYzIDEuMjkyIDIuOTQ5IDEuOTI3IDEuNzg4IDEuMjggMy45MzggMi4xNjcgNi4xMjcgMi40NzggMy41MDkuNDk5IDcuMDI3LS4xNjIgMTAuNDQ3LS45IDUuOTA1LTEuMjc3IDExLjc1Mi0yLjc5OSAxNy42NjctNC4wMzEiLz4KICA8ZyBmaWxsPSIjREZFM0VEIiBjbGlwLXBhdGg9InVybCgjYSkiPgogICAgPHBhdGggZD0iTTE5Ni41MTQgMTcuNjU3IDE4NC40OTEgMy4xM2EuNjY1LjY2NSAwIDAgMC0uOTM4LS4wODlsLTIuOTA1IDIuNDA1YS42NjYuNjY2IDAgMCAwLS4wODkuOTM4bDEyLjAyMyAxNC41MjZhLjY2NC42NjQgMCAwIDAgLjQ1MS4yMzkuNjY2LjY2NiAwIDAgMCAuNDg4LS4xNWwyLjkwNS0yLjQwNWEuNjY2LjY2NiAwIDAgMCAuMDg4LS45Mzh6bS0xNS4wNzctOC4xMjEtMTAuNTgyIDIuODY5YS42NjYuNjY2IDAgMCAwLS40NzIuNDhsLTQuMjI4IDE2Ljc5NSA3LjgyLTYuNDcyYTMuMzQgMy4zNCAwIDAgMSAuODE1LTQuMTM3IDMuMzM3IDMuMzM3IDAgMCAxIDQuNjkzLjQ0MiAzLjMzOCAzLjMzOCAwIDAgMS0uNDQyIDQuNjk0IDMuMzIyIDMuMzIyIDAgMCAxLTIuNDM4Ljc1IDMuMzM1IDMuMzM1IDAgMCAxLTEuNzc4LS43MjFsLTcuODIgNi40NzEgMTcuMjg5LTEuMDE0YS42NjguNjY4IDAgMCAwIC41NjEtLjM3NGw0Ljc5Ni05Ljg1OS04LjIxNC05LjkyNHoiLz4KICA8L2c+CiAgPGRlZnM+CiAgICA8Y2xpcFBhdGggaWQ9ImEiPgogICAgICA8cGF0aCBmaWxsPSIjZmZmIiBkPSJNMTY3LjU3MyAwaDMydjMyaC0zMnoiIHRyYW5zZm9ybT0icm90YXRlKDUuMzg2IDE2Ny41NzMgMCkiLz4KICAgIDwvY2xpcFBhdGg+CiAgPC9kZWZzPgo8L3N2Zz4=';\nexport const ScMainContainer = Styled.div`\n text-align: center;\n [data-uikit-modal-container=\"true\"] & { padding: 12px 24px; }\n`;\nexport const ScFooter = Styled.div`\n display: flex;\n justify-content: space-between;\n`;\nexport const ScHeader = Styled.div`\n color: #2c3345;\n font-size: 18px;\n font-weight: 600;\n display: flex;\n align-items: center;\n svg {\n width: 18px; height: 16px;\n flex: 0 0 18px;\n margin-right: 8px;\n }\n`;\nexport const ScTitle = Styled.div`\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n`;\nexport const ScTypingInput = Styled.input`\n width: 100%;\n border: none;\n appearance: none;\n font-size: 48px;\n outline: none;\n padding: 0;\n text-align: center;\n line-height: 152px;\n border-bottom: 2px solid #979797;\n &:invalid { background: url(${signHere}) no-repeat center/65%; }\n`;\nexport const ScCanvas = Styled.div`\n ${({ mode })=>mode === 'type' && 'opacity: 0; position: absolute; left: -9999px; pointer-events: none;'}\n text-align: right;\n canvas {\n display: inline-block;\n ${({ emptyCanvas })=>emptyCanvas && `background: url(${signHere}) no-repeat center/65%;`}\n border-bottom: 2px solid #979797;\n }\n`;\nexport const ScTypeSwitcher = Styled.div`\n button {\n border: 1px solid #2e69ff;\n padding: .3em 1em;\n margin: 0;\n transition: background-color .1s, color .1s;\n &:first-child {\n border-radius: 4px 0 0 4px;\n border-width: 1px 0 1px 1px;\n }\n &:last-child {\n border-radius: 0 4px 4px 0;\n border-width: 1px 1px 1px 0;\n }\n }\n`;\nexport const ScColorSelection = Styled.div`\n display: flex;\n align-items: center;\n ${({ mode })=>mode === 'draw' && 'padding-top: 12px;'}\n span { color: #4a5265; }\n`;\nexport const ScModal = Styled.div`\n background-color: #fefefe;\n border-radius: 4px;\n width: 100%;\n .header-content {\n width: 80%;\n padding-left: 24px;\n }\n [data-sc=\"footer\"] { padding: 12px 24px; }\n`;\nexport const ScColorSelectionInput = Styled.input`\n position: relative;\n appearance: none;\n margin: 0 0 0 16px;\n background-color: ${({ value })=>value};\n width: 14px; height: 14px;\n border-radius: 50%;\n outline: none;\n cursor: pointer;\n &:before {\n content: '';\n position: absolute;\n width: 100%; height: 100%;\n top: 0; left: 0;\n transform: scale(1.1);\n border-radius: 50%;\n box-shadow: none;\n transition: box-shadow .2s;\n }\n &:checked:before {\n box-shadow: 0 0 0 2px rgba(46, 105, 255, .8);\n }\n`;\nexport const ScSettingsContainer = Styled.div`\n width: 100%;\n display: flex;\n justify-content: space-between;\n ${({ mode })=>mode === 'type' && 'padding-top: 12px;'}\n button:not(.clearButton) {\n display: flex;\n align-items: center;\n white-space: nowrap;\n img {\n width: 10px; height: 6px;\n margin-left: 12px;\n }\n }\n button.clearButton {\n background-color: transparent;\n color: #8894ab;\n padding: 0;\n }\n ul {\n border-radius: 4px;\n overflow: hidden;\n box-shadow: 0 2px 9px 0 rgba(76, 72, 72, .3);\n &, li {\n list-style: none;\n padding: 0;\n margin: 0;\n }\n div {\n background-color: #fff;\n font-size: 24px;\n cursor: pointer;\n padding: 8px 12px;\n white-space: nowrap;\n transition: background-color .2s;\n &:hover { background-color: #f5f5f5; }\n &[data-selected=\"true\"] { background-color: #efeff0; }\n }\n }\n`;\nexport const ScButtonCont = Styled.div`\n position: relative;\n`;\nexport const ScButton = Styled.button`\n appearance: none;\n border: none;\n outline: none;\n cursor: pointer;\n border-radius: 4px;\n font-size: 1em;\n padding: 16px 32px;\n background-color: #ececec;\n color: #4c5467;\n text-transform: capitalize;\n &.dropdownButton {\n padding: 12px 16px;\n img {\n transform: rotateX(${({ opened })=>opened ? '180deg' : '0'});\n transition: transform .2s;\n }\n }\n &.isGray { background-color: #fff; color: #2e69ff; }\n &.isBlue { background-color: #2e69ff; color: #fff; }\n &.isBlue:disabled { background-color: #2e69ff88; cursor: auto; }\n`;\n","/* eslint-disable max-len */ import styled, { css } from 'styled-components';\nconst commonStyles = css`\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n text-rendering: optimizeLegibility;\n font-size: 16px;\n`;\nexport const ScBox = styled.div`\n box-sizing: border-box;\n background-color: #ffffff;\n border-radius: 4px;\n margin: auto auto;\n height: 100%;\n width: 560px;\n // box-shadow: 0 2px 7px 0 rgba(0, 0, 0, 0.5);\n border: 1px solid #D8DAE9;\n display: flex;\n flex-direction: column;\n position: relative;\n\n > div { flex: 1 1 auto; min-height: 0; }\n\n @media screen and (max-width: 480px) {\n border-radius: 0;\n }\n`;\nexport const ScHeader = styled.div`\n display: flex;\n align-items: center;\n height: 75px;\n padding: 0 1.625rem;\n border-bottom: 1px solid #EDEEF5;\n \n > svg {\n margin-right: 14px;\n height: 100%;\n width: 100%;\n max-width: 20px;\n max-height: 20px;\n\n [fill~=\"#fff\"] {\n fill: #141E46;\n }\n \n [stroke~=\"#fff\"] {\n stroke: #141E46;\n }\n }\n \n > span {\n font-family: 'Circular Std Medium', 'Circular Std Book', sans-serif;\n font-weight: 500; \n font-size: 20px;\n line-height: 25px;\n \n color: #141E46;\n }\n \n && { flex: 0 0 auto; }\n`;\nexport const ScBody = styled.div`\n padding: 1.125rem 1.625rem;\n display: flex;\n flex-direction: column;\n overflow-y: auto;\n overflow-x: hidden;\n \n > span {\n font-size: 16px;\n line-height: 25px;\n color: #121C48;\n margin-bottom: 16px;\n display: inline-block;\n }\n\n .isErrored {\n .wmApproval {\n &-task {\n &-outcome {\n padding-bottom: 3em;\n margin-bottom: -2.25em;\n }\n }\n\n &-error {\n margin-top: -0.75em !important;\n text-align: right;\n padding-top: .5em;\n }\n }\n }\n \n .wmApproval{\n &-task {\n display: flex;\n flex-direction: column;\n flex: 1;\n \n &-container {\n flex: 1;\n }\n \n &-comment {\n flex: 1;\n\n &-title {\n display: none;\n }\n \n &-textarea {\n height: 20vh;\n min-height: 120px;\n max-height: 200px;\n\n &-wrapper {\n margin-bottom: 1.125rem;\n } \n }\n }\n \n &-outcome {\n display: flex;\n justify-content: flex-end;\n flex-wrap: wrap; \n \n border-top: 1px solid #EDEEF5;\n padding: 1rem 1.625rem;\n background-color: #F8F8FB;\n margin: -1rem -1.625rem;\n margin-top: 0;\n position: relative;\n z-index: 1;\n \n @media screen and (max-width: 480px) {\n flex-direction: column;\n align-items: stretch;\n margin-top: auto;\n }\n \n &-button {\n &,\n &:last-of-type{\n margin: 0.125rem\n }\n \n @media screen and (max-width: 480px) {\n margin: 0 0 12px;\n \n &:last-of-type {\n margin: 0;\n }\n }\n }\n }\n }\n }\n`;\nexport const ScFooter = styled.div`\n border-top: 1px solid #eaebf2;\n min-height: 30px;\n padding: 12px 27px 21px;\n\n && { flex: 0 0 auto; }\n\n @media screen and (max-width: 480px) {\n padding: 9px 18px;\n }\n`;\nexport const ScOverlay = styled.div`\n * { box-sizing: border-box; }\n ${commonStyles};\n font-family: \"Circular Std Book\", Circular, -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\n position: fixed;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n z-index: 7002; \n background-color: rgba(39, 41, 55, 0.61);\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n\n :not(:last-child) {\n display: none;\n }\n\n & > div {\n ${(p)=>p.isFullScreen ? css`\n width: 100%;\n height: 100%;\n ` : css`\n width: 96%;\n max-width: 770px;\n max-height: 80vh;\n // min-height: 424px;\n `};\n display: flex;\n overflow: visible;\n }\n\n ${(p)=>p.isFullScreen && css`\n ${ScBox} { border-radius: 0; }\n `};\n\n @media screen and (max-width: 480px), (max-height: 480px) {\n overflow: auto;\n display: block;\n\n & > div {\n max-height: none;\n height: 100%;\n width: 100%;\n margin: 0;\n max-width: none;\n\n > div > div:empty {\n display: none;\n }\n }\n }\n`;\n","import Styled from 'styled-components';\nexport const ScSuggestions = Styled.div`\n font-size: 16px;\n line-height: 1em;\n border-radius: 4px;\n box-shadow: 0 2px 7px 0 rgba(0, 0, 0, 0.5);\n background-color: #fff;\n width: clamp(320px, 100%, 640px);\n padding: .375em 0;\n height: 260px;\n overflow-x: hidden;\n\n .suggestion {\n display: flex;\n align-items: center;\n padding: .75em 1.25em;\n position: relative;\n cursor: pointer;\n transition: background-color .15s;\n\n &-email-container {\n display: flex;\n justify-content: flex-start;\n margin-right: 10px;\n }\n\n &-email {\n text-overflow: ellipsis;\n width: 16em;\n overflow: hidden;\n white-space: nowrap;\n }\n\n &-info {\n font-size: .875em;\n color: #2c3345;\n color: #6a6e8f;\n flex: 1 1 auto;\n position: relative;\n }\n\n &-teamlist {\n background-color: #2b3245;\n border-radius: 0.25em;\n z-index: 1;\n width: auto;\n position: absolute;\n right: -10em;\n }\n\n &-teamitem {\n background-color: #2b3245;\n color: #abadb4;\n padding: 0.5em 0.6875em;\n text-align: left;\n display: flex;\n right: 0em;\n width: 14.0625em;\n z-index: 1;\n }\n\n &-avatar {\n flex: 0 0 32px;\n height: 32px;\n border: 2px solid #fff;\n border-radius: 50%;\n overflow: hidden;\n font-size: .75em;\n margin-right: 1em;\n\n div {\n height: 100%;\n line-height: 32px;\n color: #fff;\n text-align: center;\n font-weight: 500;\n background-color: #b9bbd2;\n background-repeat: no-repeat;\n background-size: cover;\n text-transform: uppercase;\n }\n }\n .expand-list {\n background-color: #EBEDF3;\n color: #2C3345;\n border-radius: 1em;\n text-align: center;\n width: 5em;\n height: 1.5em;\n white-space: nowrap;\n margin-left: 2em;\n\n &:hover {\n background-color: rgba(84, 180, 92, 0.1);\n }\n }\n\n & + .suggestion:before {\n content: \"\";\n display: block;\n height: 1px;\n right: 1em;\n left: 1em;\n position: absolute;\n top: 0;\n background-color: #eaebf2;\n }\n\n &:hover {\n background-color: rgba(84, 180, 92, 0.1);\n }\n } \n`;\nexport const ScList = Styled.div`\n .suggestion {\n display: flex;\n align-items: center;\n position: relative;\n cursor: default;\n\n &-teamlist {\n background-color: #2b3245;\n border-radius: 0.25em;\n z-index: 1;\n width: auto;\n position: absolute;\n top: -1em;\n right: -10em ;\n max-height: 40em;\n overflow-y: scroll;\n }\n\n &-info {\n font-size: .875em;\n color: white;\n flex: 1 1 auto;\n position: relative;\n max-width: 13em;\n }\n\n\n &-email {\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n color: #A9AACB;\n }\n\n &-teamitem {\n background-color: #2b3245;\n color: #abadb4;\n padding: 0.5em 0.6875em;\n text-align: left;\n display: flex;\n right: 0em;\n width: 16em;\n z-index: 1;\n border-radius: 1em;\n }\n\n &-avatar {\n flex: 0 0 32px;\n height: 32px;\n border: 2px solid #fff;\n border-radius: 50%;\n overflow: hidden;\n font-size: .75em;\n margin-right: 1em;\n\n div {\n height: 100%;\n line-height: 32px;\n color: #fff;\n text-align: center;\n font-weight: 500;\n background-color: #b9bbd2;\n background-repeat: no-repeat;\n background-size: cover;\n text-transform: uppercase;\n }\n }\n\n &:after {\n border: 0.3125em solid transparent;\n border-bottom-color: #000;\n bottom: 1em;\n content: \" \";\n left: -3em;\n margin-left: -0.3125em;\n position: absolute;\n }\n`;\n","import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nimport React, { useState, useEffect } from 'react';\nimport styled from 'styled-components';\nimport { bool, func, number, shape, string } from 'prop-types';\nimport classNames from 'classnames';\nimport { EmailDropdown } from '@jotforminc/email-wizards';\nimport SingleEmailInput from '@jotforminc/single-email-input';\nimport { isEmail } from '@jotforminc/utils';\nimport { isEnterprise as isEnterpriseEnv } from '@jotforminc/enterprise-utils';\nimport { Button } from '@jotforminc/magnet';\nimport { t } from '@jotforminc/translation';\nimport { layer, reassignTask } from '../api';\nconst MAX_REASSIGN_LIMIT = 3;\nconst DropdownWrapper = styled.div`\n--wizard-body-padding: 0 42px;\n--wizard-label-color: #23283a;\n--wizard-item-margin: 21px 0 42px;\n--wizard-item-padding: 21px 0;\n\n--input-color: #23283a;\n--input-background-color: #fff;\n--input-option-background-color-hover: #f3f8fe;\n--input-option-background-color-selected: #e7f1ff;\n--input-option-background-color-bullet-hover: #cee2fd;\n--input-option-background-color-bullet-selected: #5e74e6;\n--input-border-color: #d8dae9;\n--input-border-hover-color: #b7bbd7;\n--input-border-focus-color: #5e74e6;\n--input-border-error-color: #fc8291;\n--input-placeholder-color: #8d8fa8;\n\ninput[type=\"search\"] {\n margin: -1px 26px;\n width: calc(100% - 52px);\n}\n\nul {\n margin: 0 1.625rem;\n max-height: 35vh;\n overflow-y: auto;\n}\n`;\nconst WorkflowReassign = ({ taskID, onRenew, recordEvent, isHIPAA, fromError, isReassignDisabled, displayReassignCount, isReassignLimitReached, teamInfo })=>{\n const [message, setMessage] = useState('');\n const [assigneeEmail, setAssigneeEmail] = useState('');\n const [error, setError] = useState(false);\n const [isMessageVisible, setMessageVisibility] = useState(false);\n const [loading, setLoading] = useState(false);\n const [enterpriseUsers, setEnterpriseUsers] = useState([]);\n const [enterpriseUserList, setEnterpriseUserList] = useState([]);\n const isEnterprise = isEnterpriseEnv();\n useEffect(()=>{\n if (isEnterprise) {\n layer.get('users?bypass=1').then((users)=>{\n setEnterpriseUsers(users);\n const userList = users.filter(({ email })=>email).map(({ email })=>({\n value: email,\n text: email\n }));\n setEnterpriseUserList(userList);\n });\n }\n }, []);\n const handleEmailChange = ({ value = '' } = {})=>{\n setAssigneeEmail(value.trim());\n };\n const handleEmailDropdownChange = ([{ value = '' } = {}])=>{\n setAssigneeEmail(value.trim());\n };\n const handleMessageButtonClick = ()=>{\n recordEvent('toggleReassignMessage', 'workflow');\n setMessageVisibility(!isMessageVisible);\n setMessage('');\n };\n const handleMessageChange = ({ target: { value } })=>{\n setMessage(value);\n };\n const validateInput = ()=>{\n if (assigneeEmail === '') {\n setError('*Add an email address');\n return false;\n }\n const isValidEmail = isEmail(assigneeEmail);\n if (!isValidEmail) {\n setError('*Invalid email address');\n return false;\n }\n const regex = /\\+/;\n if (regex.test(assigneeEmail)) {\n setError(\"*You can't use + on emails\");\n return false;\n }\n setError('');\n return true;\n };\n const onReassignClick = async ()=>{\n if (!validateInput()) return;\n const action = fromError ? 'WF-Error-Reassigned' : 'WF-ParticipantReassigned';\n recordEvent(action, 'workflow');\n setLoading(true);\n try {\n const result = await reassignTask(taskID, teamInfo, {\n message,\n assigneeEmail\n });\n if (result) onRenew();\n if (!result) setError('something went wrong');\n setLoading(false);\n } catch (e) {\n setError('something went wrong');\n setLoading(false);\n }\n };\n const randomId = `assignee_${Math.random().toString(36).substring(2)}`;\n return /*#__PURE__*/ _jsxs(_Fragment, {\n children: [\n /*#__PURE__*/ _jsx(\"span\", {\n children: \"You can reassign this task to another approver by entering an email address below.\"\n }),\n /*#__PURE__*/ _jsxs(\"span\", {\n children: [\n \"You can reassign the same task only three times.\",\n /*#__PURE__*/ _jsx(\"div\", {\n className: classNames('wmApproval-reassign-count', {\n isReassignLimitReached\n }),\n children: ` Assigned ${displayReassignCount} of ${MAX_REASSIGN_LIMIT} times.`\n })\n ]\n }),\n /*#__PURE__*/ _jsxs(\"div\", {\n className: \"wmApproval-task\",\n children: [\n /*#__PURE__*/ _jsxs(\"div\", {\n className: classNames('wmApproval-task-comment-textarea-wrapper', {\n isReassignDisabled,\n hasError: error\n }),\n children: [\n isEnterprise && isHIPAA ? /*#__PURE__*/ _jsx(DropdownWrapper, {\n children: /*#__PURE__*/ _jsx(EmailDropdown, {\n value: [\n {\n value: assigneeEmail\n }\n ],\n options: enterpriseUserList,\n onChange: handleEmailDropdownChange,\n filterable: true,\n textInputPlaceholder: \"Search...\"\n })\n }) : /*#__PURE__*/ _jsx(SingleEmailInput, {\n className: \"wmApproval-task-comment isSingleEmailInput\",\n style: {\n background: '#FFFFFF',\n border: '1px solid #D8DAE9',\n borderRadius: 4,\n padding: 10,\n fontSize: 14,\n lineHeight: '18px',\n color: '#8D8FA8'\n },\n placeholder: \"example@example.com\",\n value: assigneeEmail,\n onChange: handleEmailChange,\n questions: [],\n userList: enterpriseUsers,\n inputProps: {\n id: randomId,\n className: 'section-ln-content-input',\n placeholder: 'example@example.com'\n },\n suggestionProps: {\n preventClickDefault: true\n },\n popoverProps: {\n usePortal: false\n }\n }),\n error ? /*#__PURE__*/ _jsx(\"div\", {\n style: {\n color: '#F43B57',\n fontSize: '14px',\n marginBottom: '4px',\n marginTop: '6px'\n },\n children: error\n }) : null,\n isMessageVisible ? /*#__PURE__*/ _jsx(\"textarea\", {\n className: \"wmApproval-task-comment\",\n value: message,\n placeholder: \"Write your message here.\",\n onChange: handleMessageChange,\n style: {\n background: '#FFFFFF',\n border: '1px solid #D8DAE9',\n borderRadius: 4,\n padding: 10,\n marginTop: 10,\n fontSize: 14,\n lineHeight: '18px',\n minHeight: 100,\n resize: 'vertical',\n color: '#8D8FA8'\n }\n }) : null,\n /*#__PURE__*/ _jsx(\"button\", {\n className: \"addMessage\",\n type: \"button\",\n onClick: handleMessageButtonClick,\n style: {\n color: '#5E74E6',\n backgroundColor: 'transparent',\n border: 'none',\n marginTop: 4,\n alignSelf: 'flex-start',\n cursor: 'pointer',\n padding: 0\n },\n children: `${!isMessageVisible ? 'Add' : 'Discard'} Message`\n })\n ]\n }),\n /*#__PURE__*/ _jsx(\"div\", {\n className: \"wmApproval-task-outcome\",\n children: /*#__PURE__*/ _jsx(Button, {\n colorStyle: \"forms\",\n loader: loading,\n disabled: isReassignDisabled,\n onClick: onReassignClick,\n children: t('Reassign')\n })\n })\n ]\n })\n ]\n });\n};\nWorkflowReassign.propTypes = {\n onRenew: func.isRequired,\n taskID: string.isRequired,\n recordEvent: func,\n isHIPAA: bool,\n fromError: bool,\n isReassignDisabled: bool,\n displayReassignCount: number,\n isReassignLimitReached: bool,\n teamInfo: shape({\n disableTeamPrefix: bool,\n teamID: string\n })\n};\nWorkflowReassign.defaultProps = {\n recordEvent: (f)=>f,\n isHIPAA: false,\n fromError: false,\n isReassignDisabled: false,\n displayReassignCount: 0,\n isReassignLimitReached: false,\n teamInfo: {}\n};\nexport default WorkflowReassign;\n","/* eslint-disable max-len */ import styled from 'styled-components';\nexport const CustomizationWrapper = styled.div`\n background: #FFFFFF;\n max-width: 350px;\n width: 100%;\n border-radius: 4px;\n background: #FFFFFF;\n border: 1px solid #B2B4CC;\n box-shadow: 4px 4px 4px rgba(0, 0, 0, 0.08);\n\n &.cover {\n max-width: 485px;\n width: 100%;\n\n // FIXME: This is a hack to fix the width of the cover\n .content-fileupload .imageUpload .tabContent .galleryWrapper > div .prevUploads-list .prevUploads-listItem {\n width: 100%;\n height: auto;\n border-radius: 4px;\n aspect-ratio: 16 / 9;\n\n img {\n height: 100% !important;\n }\n }\n }\n\n .heading {\n height: 40px;\n font-size: 14px;\n line-height: 18px;\n font-weight: 600;\n color: #2E3345;\n padding: 12px 16px;\n }\n\n .content-heading {\n align-self: flex-start;\n color: #141E46;\n font-weight: 500;\n margin-bottom: 8px;\n position: relative;\n\n &.centering {\n align-self: center;\n margin: 0;\n }\n }\n\n .content-option-colorpicker {\n position: relative;\n\n input {\n background: #FFFFFF;\n border: 1px solid #B2B4CC;\n border-radius: 4px;\n color: #333A71;\n font-size: 14px;\n line-height: 18px;\n padding: 8px 32px 8px 8px;\n\n html[dir=\"rtl\"] & {\n padding: 8px 43px 8px 8px;\n }\n }\n .jfColors-picker {\n position: absolute;\n top: 6px;\n right: 6px;\n width: 24px;\n height: 24px;\n border-radius: 2px;\n\n &:before {\n content: '';\n width: 1px;\n height: 34px;\n background-color: #B2B4CC;\n display: block;\n position: absolute;\n right: 30px;\n top: -5px;\n }\n }\n }\n\n .content {\n .content-wrapper {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: 12px 16px;\n width: 100%;\n\n &.col {\n flex-direction: column;\n\n input {width: 100%}\n }\n }\n\n .double-wrapper {\n display: flex;\n justify-content: space-between;\n align-items: center; \n flex: 1 0 auto;\n flex-wrap: wrap;\n z-index: 5;\n position: relative;\n\n &.midSize {\n max-width: 70%;\n\n @media (max-width: 768px) {\n max-width: 100%;\n }\n }\n\n .col {\n width: 50%;\n }\n }\n\n .forBody {\n @media screen and (max-width: 600px) {\n max-height: 35vh;\n }\n\n @media screen and (max-height: 568px) {\n max-height: 20vh;\n }\n }\n }\n\n .content-fileupload {\n width: 100%;\n border: 1px solid #B2B4CC;\n border-radius: 4px;\n\n div[data-tabid=\"unsplash\"] {\n .prevUploads-listItem {\n height: auto;\n cursor: pointer;\n\n img {\n width: 100%;\n max-height: 100% !important;\n aspect-ratio: 16 / 9;\n object-fit: cover;\n }\n\n p {\n margin: 0;\n padding: 0;\n width: 100%;\n font-size: 10px;\n color: #999;\n overflow: hidden;\n height: 12px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n\n a {\n color: inherit;\n margin-left: 2px;\n }\n }\n }\n }\n\n .imageUpload {\n .tabMenu {\n border-bottom: 1px solid #B2B4CC\n }\n \n .tabMenu-inner-link {\n padding: 6px 0;\n font-size: 12px;\n color: #333A71;\n border-bottom-width: 2px;\n border-right: 1px solid #B2B4CC;\n display: grid;\n place-items: center;\n line-height: 1;\n\n &:last-of-type {\n border-right: none;\n }\n\n &.is-active {\n border-bottom-color: #18235C;\n border-bottom-width: 2px;\n }\n }\n\n .tabUnsplash {\n width: 100%;\n display: flex;\n justify-content: center;\n align-items: center;\n\n svg {\n margin-right: 4px;\n }\n }\n\n .tabContent {\n padding: 12px 8px;\n max-height: 300px;\n overflow: auto;\n min-width: 314px;\n\n .galleryWrapper {\n > div {\n color: #9FA0B9;\n font-size: 12px;\n line-height: 16px;\n font-weight: 600;\n text-align: left;\n margin-bottom: 16px;\n\n .prevUploads-list {\n border: none;\n padding: 0;\n margin: 6px auto 24px;\n min-height: auto;\n max-height: auto;\n display: flex;\n flex-wrap: wrap;\n gap: 8px;\n padding: 4px;\n\n @media (max-width: 768px) {\n gap: 1vw;\n }\n\n .prevUploads-listItem {\n width: 48px;\n height: 48px;\n border-radius: 50%;\n overflow: hidden;\n display: flex;\n margin: 5px;\n cursor: pointer;\n margin: 0;\n\n img {\n width: 100%;\n height: 100% !important;\n object-fit: cover;\n }\n }\n }\n }\n }\n\n div[data-tabid=\"upload\"] {\n label.fileUploadLabel {\n background-color: #0099FF;\n }\n .fileUpload {\n min-height: 135px;\n\n &-verticalAlign-text {\n color: #9FA0B9;\n font-size: 12px;\n line-height: 16px;\n margin-top: 8px;\n }\n }\n }\n\n div[data-tabid=\"unsplash\"] {\n .prevUploads-list {\n border: none;\n overflow: auto;\n margin: 0;\n padding: 0;\n\n display: grid;\n grid-gap: 8px;\n grid-template-columns: repeat(auto-fit, minmax(102px, 1fr));\n margin-top: 12px;\n\n .prevUploads-listItem {\n width: 100%;\n max-width: 100%;\n float: initial;\n overflow: initial;\n margin: initial;\n }\n }\n\n .searchBox {\n background-color: #F5F6FE;\n border: 1px solid #C8CEED;\n border-radius: 4px;\n font-size: 14px;\n line-height: 18px;\n }\n }\n\n div[data-tabid=\"link\"] {\n label {\n display: flex;\n\n input {\n background: #F5F6FE;\n border: 1px solid #C8CEED;\n border-radius: 4px;\n color: #797EA8;\n }\n }\n\n .line {\n margin-top: 12px;\n display: flex;\n align-items: center;\n justify-content: flex-end;\n\n a.btn {\n background-color: #0099FF;\n border-radius: 4px;\n line-height: 1.5;\n\n display: flex;\n align-items: center;\n justify-content: center;\n }\n }\n }\n }\n }\n }\n\n .withBorder {\n border-bottom: 1px solid rgba(225, 226, 236, 0.7);\n }\n\n .jfTabs-body {\n padding: 0;\n }\n\n .icon-selector-wizard {\n padding: 0;\n\n svg {\n fill: #18235C;\n }\n }\n\n .icon-tab-wrapper {\n width: 100%;\n\n .jfTabs {\n border: 1px solid #B2B4CC;\n border-radius: 4px;\n }\n\n .forTabs { \n z-index: 4;\n\n .jfTabs-tabs {\n min-height: 32px;\n height: 32px;\n border-bottom: 1px solid #B2B4CC;\n\n &-button {\n color: #333A71;\n font-size: 12px;\n line-height: 16px;\n border-right: 1px solid #B2B4CC;\n\n &:last-of-type {\n border-right: none;\n }\n }\n }\n }\n\n .forBody {\n .iconSelectorPanel {\n .tabMenu {\n background-color: #F3F3FE;\n display: flex;\n justify-content: space-around;\n align-items: center;\n padding: 8px;\n\n .tabMenu-link.is-active {\n position: relative;\n\n &:after {\n content: \"\";\n position: absolute;\n width: 100%;\n height: 2px;\n background-color: #0061FF;\n bottom: -7px;\n left: 0;\n }\n }\n\n input {\n margin: 0;\n background-color: #FFF !important;\n color: #797EA8;\n background-position: 5%;\n padding: .625em .625em .625em 40px;\n }\n\n a {\n cursor: pointer;\n\n svg {\n fill: #797EA8;\n }\n }\n }\n\n .tabContent {\n .SeachIconWrapper {\n input {\n margin: 0;\n padding: 8px 0 8px 36px;\n background-color: transparent !important;\n color: #797EA8;\n background-position: 12px center;\n border-bottom: 1px solid #E1E2EC;\n border-radius: 0 !important;\n }\n }\n .LogoIconsWrapper {\n .content-item-wrapper {\n border-radius: 50%;\n }\n .content-item-label {\n border-radius: 50%;\n\n &:hover {\n background-color: #7698EF;\n\n svg {\n fill: #B4C8FC;\n }\n }\n }\n }\n }\n }\n .emoji-mart {\n button:not(.emoji-mart-search-icon) {\n border: none;\n padding: 8px;\n }\n\n &-search-icon {\n padding: 0 4px 0 0;\n border: none;\n min-height: auto;\n }\n\n &-category-label {\n color: #9FA0B9;\n font-size: 12px;\n line-height: 16px;\n font-weight: 600;\n text-align: left;\n }\n }\n }\n }\n`;\nexport const CoverWrapper = styled.div`\n display: flex;\n height: 100%;\n width: 100%;\n\n .teamCardWrapper &:hover {\n .teamcover .teamcover-container {\n transform: translateY(-100px);\n }\n\n .teamcover-bg::before {\n background: initial;\n }\n\n .teamcover-container {\n bottom: 8px;\n }\n .teamName {\n margin-top: 8px;\n }\n \n .teamMembers-count-normal {\n display: none\n }\n .teamMembers-count-hover {\n display: block;\n }\n }\n\n @media screen and (max-width: 768px) {\n position: relative;\n z-index: 0;\n\n .isMyaccount & {\n position: relative;\n z-index: 20;\n }\n }\n\n body.jfWizard--isVisible:not(.jfWizard--isModalView) & {\n display: none;\n }\n\n .teamcover {\n width: 100%;\n min-height: 200px;\n text-align: center;\n\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n\n position: relative;\n // overflow: hidden;\n transition: all .2s;\n\n &-container {\n position: relative;\n z-index: 10;\n width: 100%;\n display: flex;\n flex-direction: column;\n }\n\n &-imageCropper {\n position: relative;\n\n .wrapper {\n height: 200px;\n position: relative;\n }\n \n .wrapperButtons {\n display: flex;\n align-items: center;\n justify-content: flex-end;\n height: 51px;\n\n position: absolute;\n right: 0;\n bottom: 4px;\n background: #FFFFFF61;\n padding: 8px;\n border-radius: 4px;\n \n button {\n cursor: pointer;\n transition: .2s all ease;\n margin: 0;\n padding: 0;\n border: none;\n outline: none;\n font-family: inherit;\n border-radius: 4px;\n width: 72px;\n height: 28px;\n font-size: 12px;\n }\n .wrapperCancel {\n background-color: #dddfe9;\n color: #23283a;\n margin-right: 12px;\n }\n .wrapperSave {\n background-color: #4573e3;\n color: #fff;\n margin-right: 15px;\n }\n }\n\n &-info {\n position: absolute;\n z-index: 10;\n color: #141E46;\n top: 50%;\n background: rgba(255, 255, 255, 0.8);\n padding: 8px;\n border-radius: 4px;\n left: 50%;\n margin: -16px 0 0 -96px;\n pointer-events: none;\n }\n }\n\n &-avatar {\n position: relative;\n background-color: transparent;\n border: none;\n width: 64px;\n margin: 0 auto;\n\n &-wrapper {\n width: 64px;\n height: 64px;\n border: 2px solid #fff;\n border-radius: 50%;\n overflow: hidden;\n margin: 0 auto;\n padding: 0;\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n \n img {\n object-fit: cover;\n height: 100%;\n width: 100%;\n }\n \n &.hasBgColor {\n // padding: 12px;\n }\n \n .jfIconSVG-wrapper {\n width: 100%;\n height: 100%;\n padding: 12px;\n }\n \n .emoji-mart-emoji {\n // transform: scale(.7);\n width: 100%;\n display: flex;\n justify-content: center;\n align-items: center;\n \n span {\n font-size: 40px;\n align-self: center;\n display: flex;\n justify-content: center;\n align-items: center;\n //margin: 2px 0 0 0;\n } \n \n .emoji-mart-search {\n .emoji-mart-search-icon {\n //padding: 0 4px 0 0 !important; // FIXME\n }\n }\n }\n } \n \n img {\n width: 100%;\n background-size: cover;\n height: 100%;\n }\n \n &-edit {\n position: absolute;\n width: 24px;\n height: 24px;\n background-color: #D3DCEF;\n border-radius: 50%;\n padding: 4px;\n right: -2px;\n bottom: -2px;\n filter: drop-shadow(0px 4px 4px rgba(0, 0, 0, 0.25)); \n }\n \n .hoverSettingButton {\n opacity: 1;\n transition: all .1s ease;\n }\n \n &:hover {\n .hoverSettingButton {\n opacity: 1;\n }\n }\n }\n\n &-name {\n color: #fff;\n font-weight: 600;\n font-size: 24px;\n line-height: 30px;\n margin: 8px 0 0 0;\n word-break: break-all;\n }\n\n &-members {\n position: absolute;\n top: 0;\n right: 12px;\n z-index: 15;\n display: flex;\n justify-content: center;\n align-items: center;\n\n html[dir=\"rtl\"] & {\n right: initial;\n left: 12px;\n }\n }\n\n &-btnset {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n z-index: 1;\n width: 100%;\n height: 100%;\n display: flex;\n justify-content: flex-end;\n align-items: flex-end;\n padding: 12px;\n\n & > * {\n margin-left: 4px;\n }\n\n .teamSettingsButton {\n padding: 4px;\n border-radius: 4px;\n background: rgba(255, 255, 255, 0.8);\n width: 24px;\n height: 24px;\n cursor: pointer;\n transition: background .2s ease;\n z-index: 2;\n order: 2;\n \n &:hover + .teamcover-btnset-customization {\n opacity: 1;\n visibility: visible;\n transform: translate(0, 0);\n }\n }\n\n &-customization {\n display: flex;\n background-color: rgba(255, 255, 255, 0.8);\n border-radius: 4px;\n border: none;\n transition: background-color .2s ease;\n\n order: 1;\n\n button {\n display: flex;\n justify-content: center;\n align-items: center;\n\n border: none;\n background-color: transparent;\n padding: 4px 8px;\n color: #141E46;\n font-weight: 500;\n font-size: 12px;\n line-height: 16px;\n border-right: 1px solid #141E46;\n\n &:last-of-type {\n border-right: none;\n }\n\n svg {\n width: 12px;\n margin-right: 4px;\n\n html[dir=\"rtl\"] & {\n margin-right: 0px;\n margin-left: 4px;\n }\n }\n }\n }\n }\n\n &-bg {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n right: 0;\n bottom: 0;\n z-index: 0;\n border: none;\n margin: 0;\n padding: 0;\n overflow: hidden;\n\n &::before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n background: linear-gradient(180deg, rgba(159, 160, 185, 0.6) 0%, rgba(159, 160, 185, 0) 123.33%);\n mix-blend-mode: multiply;\n }\n\n &-wrapper {\n position: relative;\n top: 0;\n left: 0;\n transition: background .3s ease;\n width: 100%;\n height: 100%;\n display: flex;\n overflow: hidden;\n }\n\n &-img {\n max-width: 100%;\n max-height: 100%;\n margin: auto;\n position: absolute;\n inset: 0;\n z-index: 1;\n will-change: transform; \n width: 100%;\n height: 100%;\n object-fit: cover;\n }\n }\n\n &-invite {\n margin-left: auto;\n display: flex;\n align-items: center;\n justify-content: flex-start;\n margin: 12px 0 12px auto;\n\n ul {\n display: flex;\n\n li {\n position: relative;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n margin-left: -6px;\n \n img {\n width: 100%;\n object-fit: cover;\n height: 100%;\n }\n\n button {\n border: none;\n width: 100%;\n height: 100%;\n color: #6F76A7;\n background-color: #E2E6F9;\n display: flex;\n margin: 0;\n padding: 0;\n justify-content: center;\n align-items: center;\n\n width: 32px;\n height: 32px;\n overflow: hidden;\n border-radius: 50%;\n border: 1px solid rgb(200, 206, 237);\n }\n\n .jfTooltipNew-body {\n span {\n display: block;\n margin-bottom: 8px;\n text-align: left;\n\n &:nth-child(1) {\n color: #fff;\n font-size: 15px;\n font-weight: 500;\n }\n &:nth-child(2) {\n color: #a9aacb;\n }\n &:nth-child(3) {\n background-color: #404b6b;\n border-radius: 30px;\n color: #f3f7ff;\n font-size: 12px;\n padding: 8px 16px;\n align-self: flex-start;\n margin-bottom: 0;\n white-space: nowrap;\n }\n }\n }\n }\n }\n\n > button {\n background: rgba(255, 255, 255, 0.8);\n padding: 4px 12px;\n border-radius: 4px;\n border: none;\n color: #141E46;\n font-weight: 500;\n line-height: 24px;\n font-size: 12px;\n transition: background .2s ease;\n margin-left: 8px;\n\n html[dir=\"rtl\"] & {\n margin-left: 0;\n margin-right: 8px;\n }\n\n &:hover {\n background: rgba(255, 255, 255, 1);\n } \n }\n }\n\n &-cta {\n background: #0A1551;\n border-radius: 4px;\n border: none;\n color: #FFF;\n padding: 6px;\n line-height: 22px;\n }\n\n &-select {\n display: flex;\n justify-content: center;\n align-items: flex-start;\n\n label {\n color: #141E46;\n font-size: 16px;\n line-height: 21px;\n margin-right: 12px;\n }\n\n select {\n background: #E3E5F5;\n border-radius: 4px;\n }\n }\n\n &-wrapper {\n z-index: 7;\n width: 100%;\n\n [data-popper-placement] {\n z-index: 7;\n }\n\n &.isEditable {\n z-index: 8;\n .teamcover-bg {\n border-top-left-radius: 8px;\n border-top-right-radius: 8px;\n }\n }\n }\n }\n`;\n","/* eslint-disable max-len */ import styled from 'styled-components';\nexport const centerer = `\n display: flex;\n align-items: center;\n justify-content: center;\n`;\nexport const AvatarWrapper = styled.div`\n .jfIconSVG-wrapper {\n ${centerer}\n padding: 8px;\n\n > div {\n ${centerer}\n }\n }\n`;\n","/* eslint-disable max-lines */ /* eslint-disable camelcase */ import { _ as _object_spread } from \"@swc/helpers/_/_object_spread\";\nimport { _ as _object_spread_props } from \"@swc/helpers/_/_object_spread_props\";\nvar _window;\nimport { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nimport React, { useState, useEffect, useRef } from 'react';\nimport { array, shape, string } from 'prop-types';\nimport DOMPurify from 'dompurify';\nimport { rgba } from 'polished';\nimport classNames from 'classnames';\nimport { Portal } from '@jotforminc/uikit';\nimport Tracking from '@jotforminc/tracking';\nimport { IconPencilToSquare, IconFormCheckFilled, IconEnvelopeClosedFilled } from '@jotforminc/svg-icons';\nimport { Unsupported, Preview } from '@jotforminc/preview';\nimport { t, translationRenderer } from '@jotforminc/translation';\nimport { handleCustomNavigation, safeJSONParse, escapeHTML } from '@jotforminc/utils';\nimport { WorkflowStatus } from '@jotforminc/placeholder';\nimport { SingleSubmissionViewWithButton, fetchQuestions, fetchSubmission, SingleSubmissionButtonContext } from '@jotforminc/single-submission-buttons';\nimport { getAllIntegrationsDetails } from '@jotforminc/integration-constants';\nimport IconAssignFormWF from '../assets/iconAssignFormFlow.svg';\nimport { decodeHTML, stripHTML } from '../utils';\nimport ApprovalOptions from '../components/ApprovalOptions';\nimport AvatarGroupWithPanel from '../components/AvatarGroupWithPanel';\nimport { isTeamApproval } from '../utils/helper';\nexport const INTEGRATION_DETAILS = getAllIntegrationsDetails();\nconst isWorkflowReleased = (_window = window) === null || _window === void 0 ? void 0 : _window.isWorkflowReleased;\nconst getElementName = (type, subType)=>{\n // eslint-disable-next-line default-case\n switch(true){\n case type === 'workflow_assign_form':\n return 'Form';\n case type === 'workflow_approval' && subType && subType === 'workflow_approval_with_sign':\n return 'Approve & Sign';\n case type === 'workflow_approval':\n return 'Approval';\n }\n};\nconst getUsers = (actionDetails)=>{\n const { newAssigneeEmail, newAssigneeUser } = actionDetails;\n const { previousAssigneeEmail, previousAssigneeUser } = actionDetails;\n return {\n next: _object_spread_props(_object_spread({}, newAssigneeUser), {\n name: (newAssigneeUser === null || newAssigneeUser === void 0 ? void 0 : newAssigneeUser.name) || newAssigneeEmail\n }),\n prev: _object_spread_props(_object_spread({}, previousAssigneeUser), {\n name: (previousAssigneeUser === null || previousAssigneeUser === void 0 ? void 0 : previousAssigneeUser.name) || previousAssigneeEmail\n })\n };\n};\nconst getAssignee = (actionDetails)=>{\n const { assigneeUser } = actionDetails;\n return assigneeUser;\n};\nconst getSystemUser = ()=>{\n return {\n name: 'Notification',\n avatarUrl: \"data:image/svg+xml,%3Csvg width='40' height='40' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%23fff' d='M15.5 13h9v4h-9z'/%3E%3Cpath d='M12.5 24v-5h15v5' stroke='%23fff' stroke-width='1.7' stroke-linejoin='round'/%3E%3Cpath stroke='%23fff' stroke-width='1.7' d='M19.9 24v-5'/%3E%3Ccircle cx='12.5' cy='24.5' r='2.5' fill='%23fff'/%3E%3Ccircle cx='27.5' cy='24.5' r='2.5' fill='%23fff'/%3E%3Cpath fill='%23fff' d='M17.5 22h5v5h-5z'/%3E%3C/svg%3E\",\n isSystem: true\n };\n};\nconst getGroupApproverUser = ()=>{\n return {\n name: 'Group Approval',\n avatarUrl: \"data:image/svg+xml,%3Csvg width='40' height='40' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%23fff' d='M15.5 13h9v4h-9z'/%3E%3Cpath d='M12.5 24v-5h15v5' stroke='%23fff' stroke-width='1.7' stroke-linejoin='round'/%3E%3Cpath stroke='%23fff' stroke-width='1.7' d='M19.9 24v-5'/%3E%3Ccircle cx='12.5' cy='24.5' r='2.5' fill='%23fff'/%3E%3Ccircle cx='27.5' cy='24.5' r='2.5' fill='%23fff'/%3E%3Cpath fill='%23fff' d='M17.5 22h5v5h-5z'/%3E%3C/svg%3E\",\n isSystem: true\n };\n};\nconst getTerminate = ()=>{\n return {\n name: 'Terminate',\n avatarUrl: \"data:image/svg+xml,%3Csvg width='44' height='44' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='22' cy='22' r='22' fill='%23C90909'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M17 13.667A3.333 3.333 0 0 0 13.667 17v10A3.333 3.333 0 0 0 17 30.333h10A3.333 3.333 0 0 0 30.333 27V17A3.333 3.333 0 0 0 27 13.667H17Z' fill='%23fff'/%3E%3C/svg%3E\" // eslint-disable-line\n };\n};\nconst getGroupTeamApproverUser = (team)=>{\n return {\n name: team === null || team === void 0 ? void 0 : team.teamName,\n isSystem: true,\n team\n };\n};\nconst entryPropTypes = {\n actionDetails: shape({}),\n user: shape({})\n};\nexport const statusTexts = {\n APPROVE: 'Approved',\n DENY: 'Denied',\n EXPIRE: 'Expired',\n AUTO: 'Automatically Finished',\n ESCALATE: 'Escalated',\n REASSIGN: 'Reassigned',\n CANCEL: 'Canceled',\n CUSTOM_EMAIL: 'Email Sent',\n REPLY: 'Replied',\n RESTART: 'Restarted',\n TASK: 'Waiting',\n REQUEST_MORE_INFO: 'Requested more info',\n EDIT_SUBMISSION: 'Edit submission',\n ASSIGN_FORM_SUBMISSION: 'Form Submitted',\n ASSIGN_FORM_NOTIFICATION_MAIL: 'Form Assigned',\n MULTIPLE_APPROVAL_MAIL: 'Group Approval',\n REMINDER: 'Reminder'\n};\nconst WFCategoryName = ({ actionDetails: { type } })=>/*#__PURE__*/ _jsxs(\"span\", {\n className: classNames('category', 'workflow', type === null || type === void 0 ? void 0 : type.toLowerCase()),\n children: [\n /*#__PURE__*/ _jsx(IconFormCheckFilled, {\n className: \"iconCategoryWF w-4 h-4\"\n }),\n isWorkflowReleased ? t('Workflow') : t('Approval Flow')\n ]\n });\nWFCategoryName.propTypes = {\n actionDetails: shape({}).isRequired\n};\nconst WFNewSubmissionCategoryName = ({ actionDetails: { type } })=>/*#__PURE__*/ _jsxs(\"span\", {\n className: classNames('category', 'workflow', type === null || type === void 0 ? void 0 : type.toLowerCase()),\n children: [\n /*#__PURE__*/ _jsx(IconAssignFormWF, {\n width: \"15\",\n height: \"20\",\n className: \"iconCategoryWF\",\n style: {\n marginTop: '-3px'\n }\n }),\n t('New Submission')\n ]\n });\nWFNewSubmissionCategoryName.propTypes = {\n actionDetails: shape({}).isRequired\n};\nconst WFCategoryLoadingName = ()=>/*#__PURE__*/ _jsx(\"span\", {\n className: classNames('category', 'workflow', ''),\n children: /*#__PURE__*/ _jsx(\"div\", {\n style: {\n maxWidth: '275px'\n },\n children: /*#__PURE__*/ _jsx(WorkflowStatus, {})\n })\n });\nWFCategoryLoadingName.propTypes = {};\nconst EditSubmisisonCategoryName = ({ actionDetails: { type } })=>/*#__PURE__*/ _jsxs(\"span\", {\n className: classNames('category', 'workflow', type === null || type === void 0 ? void 0 : type.toLowerCase()),\n children: [\n /*#__PURE__*/ _jsx(IconPencilToSquare, {\n className: \"iconCategoryWF w-4 h-4\"\n }),\n t('Edit Submission')\n ]\n });\nEditSubmisisonCategoryName.propTypes = {\n actionDetails: shape({}).isRequired\n};\nconst EmailCategoryName = ({ actionType, actionDetails: { type } })=>/*#__PURE__*/ _jsxs(\"span\", {\n className: classNames('category', 'email', type === null || type === void 0 ? void 0 : type.toLowerCase()),\n children: [\n /*#__PURE__*/ _jsx(IconEnvelopeClosedFilled, {\n className: \"iconCategoryEmail\"\n }),\n t(actionType.toLowerCase())\n ]\n });\nEmailCategoryName.propTypes = {\n actionType: string.isRequired,\n actionDetails: shape({}).isRequired\n};\nconst ReplyEntry = ({ actionDetails })=>{\n var _ref_current;\n const { body } = actionDetails;\n const ref = useRef();\n const sanitizedBody = DOMPurify.sanitize(body);\n const [quotationCollapsed, setQuotationCollapsed] = useState(true);\n const [showButton, setShowButton] = useState(ref === null || ref === void 0 ? void 0 : (_ref_current = ref.current) === null || _ref_current === void 0 ? void 0 : _ref_current.querySelector('.quotationWrapper'));\n const handleExpand = ()=>setQuotationCollapsed(!quotationCollapsed);\n useEffect(()=>{\n var _ref_current;\n setShowButton(ref === null || ref === void 0 ? void 0 : (_ref_current = ref.current) === null || _ref_current === void 0 ? void 0 : _ref_current.querySelector('.quotationWrapper'));\n }, [\n body\n ]);\n return /*#__PURE__*/ _jsxs(_Fragment, {\n children: [\n /*#__PURE__*/ _jsx(\"div\", {\n ref: ref,\n className: classNames('mail-wrapper', {\n quotationCollapsed\n }),\n dangerouslySetInnerHTML: {\n __html: sanitizedBody\n }\n }),\n /*#__PURE__*/ _jsx(\"div\", {\n className: classNames('quotationButtons', 'noText'),\n children: showButton ? /*#__PURE__*/ _jsx(\"button\", {\n className: \"showSubmission\",\n type: \"button\",\n onClick: handleExpand,\n children: `Show ${quotationCollapsed ? 'more' : 'less'} `\n }) : null\n })\n ]\n });\n};\nReplyEntry.Name = EmailCategoryName;\nReplyEntry.propTypes = _object_spread({}, entryPropTypes);\nReplyEntry.Status = ({ actionDetails: { subject, to } })=>{\n return /*#__PURE__*/ _jsxs(_Fragment, {\n children: [\n /*#__PURE__*/ _jsx(\"div\", {\n className: classNames('description'),\n dangerouslySetInnerHTML: {\n __html: t(`\n {subject}\n `).replace(/{subject}/g, escapeHTML(subject))\n }\n }),\n /*#__PURE__*/ _jsx(\"div\", {\n className: classNames('extra'),\n children: /*#__PURE__*/ _jsx(\"span\", {\n children: t('to: {to}').replace(/{to}/g, to)\n })\n })\n ]\n });\n};\nReplyEntry.Status.propTypes = {\n actionDetails: shape({}).isRequired\n};\nReplyEntry.Attachment = ({ actionDetails: { attachments } })=>{\n const [fileIndex, setFileIndex] = useState(0);\n const [previewVisibility, setPreviewVisibility] = useState(false);\n let uploadUrls = attachments && JSON.parse(attachments);\n if (Array.isArray(uploadUrls)) {\n uploadUrls = uploadUrls.map((uploadUrl)=>{\n var _fullName_split_pop, _fullName_split;\n const hiddenExtensions = [\n 'JPEG',\n 'PNG',\n 'GIF',\n 'JPG',\n 'DOCX'\n ];\n const fullName = /[^/]*$/.exec(uploadUrl)[0];\n const extension = fullName === null || fullName === void 0 ? void 0 : (_fullName_split = fullName.split('.')) === null || _fullName_split === void 0 ? void 0 : (_fullName_split_pop = _fullName_split.pop()) === null || _fullName_split_pop === void 0 ? void 0 : _fullName_split_pop.toUpperCase();\n return {\n description: '',\n fileName: fullName,\n fileThumbnailUrl: uploadUrl,\n fileUrl: uploadUrl,\n previewUrl: uploadUrl,\n size: '',\n extension,\n isHidden: hiddenExtensions.indexOf(extension) > -1\n };\n });\n return /*#__PURE__*/ _jsxs(\"div\", {\n className: \"entry-attachment-container\",\n children: [\n uploadUrls.map(({ fileName, extension, isHidden }, i)=>{\n return /*#__PURE__*/ _jsxs(\"button\", {\n className: \"entry-attachment-item\",\n type: \"button\",\n onClick: ()=>{\n setFileIndex(i);\n setPreviewVisibility(true);\n },\n children: [\n /*#__PURE__*/ _jsx(\"div\", {\n className: \"extension-icon\",\n children: /*#__PURE__*/ _jsx(Unsupported, {\n isHidden: isHidden,\n extension: extension\n })\n }),\n /*#__PURE__*/ _jsx(\"span\", {\n className: \"fileName\",\n children: fileName\n })\n ]\n });\n }),\n previewVisibility && /*#__PURE__*/ _jsx(Preview, {\n files: uploadUrls,\n fixDomainURL: false,\n initialFileIndex: fileIndex,\n onClose: ()=>setPreviewVisibility(false)\n })\n ]\n });\n }\n return null;\n};\nReplyEntry.Attachment.propTypes = ReplyEntry.Status.propTypes;\nconst ForwardEntry = (props)=>/*#__PURE__*/ _jsx(ReplyEntry, _object_spread({}, props));\nForwardEntry.Name = EmailCategoryName;\nForwardEntry.Status = ReplyEntry.Status;\nForwardEntry.Attachment = ReplyEntry.Attachment;\nForwardEntry.propTypes = _object_spread({}, entryPropTypes);\nconst AssignEntry = ({ user, actionDetails })=>{\n const { name, email } = user;\n const assignerID = name || email;\n const { assigneeName, assigneeEmail } = actionDetails;\n const assigneeID = email === assigneeEmail ? assignerID : assigneeName || assigneeEmail;\n return /*#__PURE__*/ _jsx(\"div\", {\n children: translationRenderer('[1[{assignerID}]] [2[assigned]] this submission to [3[{assigneeID}]]')({\n renderer1: ()=>/*#__PURE__*/ _jsx(_Fragment, {\n children: assignerID\n }),\n renderer2: (text)=>/*#__PURE__*/ _jsx(\"strong\", {\n children: text\n }),\n renderer3: ()=>/*#__PURE__*/ _jsx(\"strong\", {\n children: assigneeID\n })\n })\n });\n};\nAssignEntry.propTypes = _object_spread({}, entryPropTypes);\nconst ReAssignEntry = ({ actionDetails })=>{\n const { comment } = actionDetails;\n return comment ? /*#__PURE__*/ _jsx(\"div\", {\n className: \"comment\",\n children: comment\n }) : null;\n};\nReAssignEntry.propTypes = _object_spread({}, entryPropTypes);\nReAssignEntry.Name = WFCategoryName;\nReAssignEntry.Status = ({ actionDetails })=>{\n // const { name, email } = user;\n // const assignerID = name || email;\n const { // newAssigneeName,\n newAssigneeEmail, newAssigneeUser: { name: assigneeName } } = actionDetails;\n // const assigneeID = email === newAssigneeEmail ? (\n // assignerID\n // ) : (newAssigneeName || newAssigneeEmail);\n return /*#__PURE__*/ _jsx(_Fragment, {\n children: /*#__PURE__*/ _jsx(\"div\", {\n className: classNames('description'),\n children: translationRenderer('[1[Reassigned]] to [2[{user}]]')({\n renderer1: (text)=>/*#__PURE__*/ _jsx(\"span\", {\n className: \"badge reassign\",\n children: text\n }),\n renderer2: ()=>/*#__PURE__*/ _jsx(\"span\", {\n className: \"text username\",\n children: assigneeName || newAssigneeEmail\n })\n })\n })\n });\n};\nReAssignEntry.Status.propTypes = _object_spread({}, entryPropTypes);\nReAssignEntry.PopoverDescription = ({ actionDetails })=>{\n const { newAssigneeEmail, newAssigneeUser: { name: assigneeName } } = actionDetails;\n return t('to: {user}.').replace(/{user}/g, assigneeName || newAssigneeEmail);\n};\nReAssignEntry.PopoverDescription.propTypes = _object_spread({}, entryPropTypes);\nconst requestMoreInfoEntry = {};\nrequestMoreInfoEntry.propTypes = _object_spread({}, entryPropTypes);\nrequestMoreInfoEntry.Name = WFCategoryName;\nrequestMoreInfoEntry.Status = ({ actionDetails })=>{\n const { assigneeUser = {}, assigneeEmail = '' } = actionDetails;\n const { name, email } = assigneeUser;\n return /*#__PURE__*/ _jsx(_Fragment, {\n children: /*#__PURE__*/ _jsx(\"div\", {\n className: classNames('description'),\n children: translationRenderer('[1[Requested more info]] from [2[{userDetails}]]')({\n renderer1: (text)=>/*#__PURE__*/ _jsx(\"span\", {\n className: \"badge requestMoreInfo\",\n children: text\n }),\n renderer2: ()=>/*#__PURE__*/ _jsx(\"span\", {\n className: \"text username\",\n children: name || email || assigneeEmail\n })\n })\n })\n });\n};\nrequestMoreInfoEntry.Status.propTypes = _object_spread({}, entryPropTypes);\nrequestMoreInfoEntry.Attachment = ({ actionDetails })=>{\n const { attachments } = actionDetails;\n const [fileIndex, setFileIndex] = useState(0);\n const [previewVisibility, setPreviewVisibility] = useState(false);\n let uploadUrls = attachments && JSON.parse(attachments);\n if (!attachments || !uploadUrls || (uploadUrls === null || uploadUrls === void 0 ? void 0 : uploadUrls.length) === 0) {\n return null;\n }\n if (Array.isArray(uploadUrls)) {\n uploadUrls = uploadUrls.map((uploadUrl)=>{\n var _fullName_split_pop, _fullName_split;\n const hiddenExtensions = [\n 'JPEG',\n 'PNG',\n 'GIF',\n 'JPG',\n 'DOCX'\n ];\n const fullName = /[^/]*$/.exec(uploadUrl)[0];\n const extension = fullName === null || fullName === void 0 ? void 0 : (_fullName_split = fullName.split('.')) === null || _fullName_split === void 0 ? void 0 : (_fullName_split_pop = _fullName_split.pop()) === null || _fullName_split_pop === void 0 ? void 0 : _fullName_split_pop.toUpperCase();\n return {\n description: '',\n fileName: fullName,\n fileThumbnailUrl: uploadUrl,\n fileUrl: uploadUrl,\n previewUrl: uploadUrl,\n size: '',\n extension,\n isHidden: hiddenExtensions.indexOf(extension) > -1\n };\n });\n return /*#__PURE__*/ _jsxs(\"div\", {\n className: \"entry-attachment-container\",\n children: [\n uploadUrls.map(({ fileName, extension, isHidden }, i)=>{\n return /*#__PURE__*/ _jsxs(\"button\", {\n className: \"entry-attachment-item\",\n type: \"button\",\n onClick: ()=>{\n setFileIndex(i);\n setPreviewVisibility(true);\n },\n children: [\n /*#__PURE__*/ _jsx(\"div\", {\n className: \"extension-icon\",\n children: /*#__PURE__*/ _jsx(Unsupported, {\n isHidden: isHidden,\n extension: extension,\n isNew: true\n })\n }),\n /*#__PURE__*/ _jsx(\"span\", {\n className: \"fileName\",\n children: fileName\n })\n ]\n });\n }),\n previewVisibility && /*#__PURE__*/ _jsx(Preview, {\n files: uploadUrls,\n fixDomainURL: false,\n initialFileIndex: fileIndex,\n onClose: ()=>setPreviewVisibility(false)\n })\n ]\n });\n }\n return null;\n};\nrequestMoreInfoEntry.Attachment.propTypes = _object_spread({}, entryPropTypes);\nconst undoLoadingEntry = {};\nundoLoadingEntry.propTypes = {};\nundoLoadingEntry.Name = WFCategoryName;\nundoLoadingEntry.Status = ()=>{\n return /*#__PURE__*/ _jsx(\"div\", {\n style: {\n maxWidth: '275px',\n marginLeft: '70px'\n },\n children: /*#__PURE__*/ _jsx(WorkflowStatus, {})\n });\n};\nundoLoadingEntry.Status.propTypes = _object_spread({}, entryPropTypes);\nconst mockApproveDenyEntry = ({ actionDetails, user })=>{\n const { comment, signature } = actionDetails;\n return /*#__PURE__*/ _jsx(_Fragment, {\n children: (user === null || user === void 0 ? void 0 : user.username) === '!workflow_system' ? null //