.className_cxx1jim{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;-webkit-justify-content:center;justify-content:center;}.className_cxx1jim :not(:empty){padding:var(--space-4);}
.FieldActionContainerStyled_f13zd1yw>.form-field{-webkit-flex:1;-ms-flex:1;flex:1;}
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/home/runner/work/frontend/frontend/packages/tms/src/authentication/components/PhoneAuthSetupFieldSet.tsx"],"names":[".className_cxx1jim",".FieldActionContainerStyled_f13zd1yw"],"mappings":"AA4IeA;AA6CoBC","file":"/home/runner/work/frontend/frontend/packages/tms/src/authentication/components/PhoneAuthSetupFieldSet.tsx","sourcesContent":["import { useState, useCallback, useReducer } from \"react\";\nimport { css } from \"@linaria/core\";\nimport { styled } from \"@linaria/react\";\nimport { Alert, Button, Card, FieldSet, Flex, InputField, PhoneNumberField, Row } from \"@qargo/ui-kit\";\nimport useMultifactorAuthSetupHelper from \"authentication/MultifactorAuthSetupHelper\";\nimport { RECAPTCHA_VERIFIER_ID } from \"authentication/RecaptchaVerifierHelper\";\nimport MultifactorAuthenticationStoreContext from \"authorization/MultifactorAuthenticationStoreContext\";\nimport { logError } from \"core/utils/logger\";\nimport { t } from \"i18n/translate\";\nimport { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nconst PHONE_SETUP_STEPS = [\n\t\"PHONE_NUMBER_FORM\",\n\t\"VERIFY_CODE_FORM\",\n\t\"SUCCESS\"\n];\nconst phoneAuthSetupReducer = (state, action) => {\n\tswitch (action.type) {\n\t\tcase \"changed_phone_number\": {\n\t\t\treturn {\n\t\t\t\t...state,\n\t\t\t\tphoneNumber: action.phoneNumber\n\t\t\t};\n\t\t}\n\t\tcase \"changed_verification_code\": {\n\t\t\treturn {\n\t\t\t\t...state,\n\t\t\t\tverificationCode: action.verificationCode\n\t\t\t};\n\t\t}\n\t\tcase \"back\": {\n\t\t\tconst currentStepIndex = PHONE_SETUP_STEPS.indexOf(state.currentStep);\n\t\t\tif (currentStepIndex === 0 || currentStepIndex === -1) {\n\t\t\t\tlogError(\"Cannot go back from first step\");\n\t\t\t\treturn state;\n\t\t\t}\n\t\t\treturn {\n\t\t\t\t...state,\n\t\t\t\tcurrentStep: PHONE_SETUP_STEPS[currentStepIndex - 1],\n\t\t\t\tverificationCode: undefined\n\t\t\t};\n\t\t}\n\t\tcase \"next\": {\n\t\t\tconst currentStepIndex = PHONE_SETUP_STEPS.indexOf(state.currentStep);\n\t\t\tif (currentStepIndex === -1) {\n\t\t\t\tlogError(\"Invalid current step\");\n\t\t\t\treturn state;\n\t\t\t}\n\t\t\tif (currentStepIndex === PHONE_SETUP_STEPS.length - 1) {\n\t\t\t\tlogError(\"Cannot go next from last step\");\n\t\t\t\treturn state;\n\t\t\t}\n\t\t\treturn {\n\t\t\t\t...state,\n\t\t\t\tcurrentStep: PHONE_SETUP_STEPS[currentStepIndex + 1]\n\t\t\t};\n\t\t}\n\t}\n};\nconst PhoneAuthSetupFieldSet = () => {\n\tconst [loading, setLoading] = useState(false);\n\tconst [state, dispatch] = useReducer(phoneAuthSetupReducer, { currentStep: \"PHONE_NUMBER_FORM\" });\n\tconst { store } = MultifactorAuthenticationStoreContext.useContainer();\n\tconst setErrorMessage = store((state) => state.setErrorMessage);\n\tconst { enrollMfa, sendVerificationCode } = useMultifactorAuthSetupHelper();\n\tconst verificationCode = state.verificationCode;\n\tconst onSendVerificationCode = useCallback(async () => {\n\t\tsetLoading(true);\n\t\ttry {\n\t\t\tif (state.phoneNumber) {\n\t\t\t\tawait sendVerificationCode(state.phoneNumber);\n\t\t\t}\n\t\t\tdispatch({ type: \"next\" });\n\t\t} catch (error) {\n\t\t\tsetErrorMessage(error.message);\n\t\t} finally {\n\t\t\tsetLoading(false);\n\t\t}\n\t}, [\n\t\tsendVerificationCode,\n\t\tsetErrorMessage,\n\t\tstate.phoneNumber\n\t]);\n\tconst onVerifyCode = useCallback(async () => {\n\t\tsetLoading(true);\n\t\ttry {\n\t\t\tif (state.verificationCode) {\n\t\t\t\tawait enrollMfa(\"phone\", state.verificationCode);\n\t\t\t}\n\t\t\tdispatch({ type: \"next\" });\n\t\t} catch (error) {\n\t\t\tsetErrorMessage(error.message);\n\t\t} finally {\n\t\t\tsetLoading(false);\n\t\t}\n\t}, [\n\t\tenrollMfa,\n\t\tsetErrorMessage,\n\t\tstate.verificationCode\n\t]);\n\treturn /* @__PURE__ */ _jsxs(_Fragment, { children: [\n\t\tstate.currentStep === \"PHONE_NUMBER_FORM\" && /* @__PURE__ */ _jsxs(FieldSet, {\n\t\t\tlabel: \"2fa-phone-number\",\n\t\t\tchildren: [/* @__PURE__ */ _jsxs(Row, {\n\t\t\t\tblock: true,\n\t\t\t\tstacked: true,\n\t\t\t\tchildren: [\n\t\t\t\t\t/* @__PURE__ */ _jsx(Alert, {\n\t\t\t\t\t\tmessage: t(\"mfa.factors.phone.setup.info\"),\n\t\t\t\t\t\ttype: \"warning\"\n\t\t\t\t\t}),\n\t\t\t\t\t/* @__PURE__ */ _jsx(Card, { children: /* @__PURE__ */ _jsx(\"p\", { children: t(\"mfa.admin.setup.enterPhoneNumber\") }) }),\n\t\t\t\t\t/* @__PURE__ */ _jsx(Card, {\n\t\t\t\t\t\tloading: loading && !verificationCode,\n\t\t\t\t\t\tchildren: /* @__PURE__ */ _jsxs(FieldActionContainerStyled, {\n\t\t\t\t\t\t\tgap: \"small\",\n\t\t\t\t\t\t\tchildren: [/* @__PURE__ */ _jsx(PhoneNumberField, {\n\t\t\t\t\t\t\t\tlabel: t(\"common.fields.phone_number\"),\n\t\t\t\t\t\t\t\tname: \"phoneNumber\",\n\t\t\t\t\t\t\t\tonChange: (value) => dispatch({\n\t\t\t\t\t\t\t\t\tphoneNumber: value,\n\t\t\t\t\t\t\t\t\ttype: \"changed_phone_number\"\n\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\tonKeyDown: async (event) => {\n\t\t\t\t\t\t\t\t\tif (event.key === \"Enter\") {\n\t\t\t\t\t\t\t\t\t\tawait onSendVerificationCode();\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\trequired: true\n\t\t\t\t\t\t\t}), /* @__PURE__ */ _jsx(Button, {\n\t\t\t\t\t\t\t\tclassName: \"with-field-height\",\n\t\t\t\t\t\t\t\tdisabled: !state.phoneNumber,\n\t\t\t\t\t\t\t\tloading,\n\t\t\t\t\t\t\t\tonClick: onSendVerificationCode,\n\t\t\t\t\t\t\t\ttype: \"primary\",\n\t\t\t\t\t\t\t\tchildren: t(\"mfa.factors.phone.setup.sendCode\")\n\t\t\t\t\t\t\t})]\n\t\t\t\t\t\t})\n\t\t\t\t\t})\n\t\t\t\t]\n\t\t\t}), /* @__PURE__ */ _jsx(\"div\", {\n\t\t\t\tclassName: css`\n              display: flex;\n              justify-content: center;\n\n              :not(:empty) {\n                padding: var(--space-4);\n              }\n            `,\n\t\t\t\tid: RECAPTCHA_VERIFIER_ID\n\t\t\t})]\n\t\t}),\n\t\tstate.currentStep === \"VERIFY_CODE_FORM\" && /* @__PURE__ */ _jsx(FieldSet, {\n\t\t\tlabel: \"2fa-verify-code\",\n\t\t\tchildren: /* @__PURE__ */ _jsxs(Row, {\n\t\t\t\tblock: true,\n\t\t\t\tstacked: true,\n\t\t\t\tchildren: [/* @__PURE__ */ _jsx(Card, { children: /* @__PURE__ */ _jsx(\"p\", { children: t(\"mfa.admin.setup.enterVerificationCode\") }) }), /* @__PURE__ */ _jsx(Card, { children: /* @__PURE__ */ _jsxs(FieldActionContainerStyled, {\n\t\t\t\t\tgap: \"small\",\n\t\t\t\t\tchildren: [/* @__PURE__ */ _jsx(InputField, {\n\t\t\t\t\t\tlabel: t(\"mfa.fields.verification_code\"),\n\t\t\t\t\t\tname: \"verificationCode\",\n\t\t\t\t\t\tonChange: (event) => dispatch({\n\t\t\t\t\t\t\ttype: \"changed_verification_code\",\n\t\t\t\t\t\t\tverificationCode: event.target.value\n\t\t\t\t\t\t}),\n\t\t\t\t\t\tonKeyDown: async (event) => {\n\t\t\t\t\t\t\tif (event.key === \"Enter\") {\n\t\t\t\t\t\t\t\tawait onVerifyCode();\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t},\n\t\t\t\t\t\trequired: true\n\t\t\t\t\t}), /* @__PURE__ */ _jsx(Button, {\n\t\t\t\t\t\tclassName: \"with-field-height\",\n\t\t\t\t\t\tdisabled: !state.verificationCode,\n\t\t\t\t\t\tloading,\n\t\t\t\t\t\tonClick: onVerifyCode,\n\t\t\t\t\t\ttype: \"primary\",\n\t\t\t\t\t\tchildren: t(\"mfa.actions.verify\")\n\t\t\t\t\t})]\n\t\t\t\t}) })]\n\t\t\t})\n\t\t}),\n\t\tstate.currentStep === \"SUCCESS\" && /* @__PURE__ */ _jsx(Card, { children: /* @__PURE__ */ _jsx(\"p\", { children: t(\"mfa.factors.phone.setup.success\") }) })\n\t] });\n};\nconst FieldActionContainerStyled = styled(Flex)`\n  & > .form-field {\n    flex: 1;\n  }\n`;\nexport default PhoneAuthSetupFieldSet;\n"]}*/.FieldActionContainerStyled_f8x8a7e>.form-field{-webkit-flex:1;-ms-flex:1;flex:1;}
/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL2Zyb250ZW5kL2Zyb250ZW5kL3BhY2thZ2VzL3Rtcy9zcmMvYXV0aGVudGljYXRpb24vY29tcG9uZW50cy9Ub3RwQXV0aFNldHVwRmllbGRTZXQudHN4Il0sIm5hbWVzIjpbIi5GaWVsZEFjdGlvbkNvbnRhaW5lclN0eWxlZF9mOHg4YTdlIl0sIm1hcHBpbmdzIjoiQUFzSW1DQSIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay9mcm9udGVuZC9mcm9udGVuZC9wYWNrYWdlcy90bXMvc3JjL2F1dGhlbnRpY2F0aW9uL2NvbXBvbmVudHMvVG90cEF1dGhTZXR1cEZpZWxkU2V0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZUVmZmVjdCwgdXNlU3RhdGUsIHVzZUNhbGxiYWNrLCB1c2VSZWR1Y2VyIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgeyBzdHlsZWQgfSBmcm9tIFwiQGxpbmFyaWEvcmVhY3RcIjtcbmltcG9ydCB7IEJ1dHRvbiwgQ2FyZCwgRmxleCwgSW5wdXRGaWVsZCwgUm93IH0gZnJvbSBcIkBxYXJnby91aS1raXRcIjtcbmltcG9ydCB7IFFSQ29kZSB9IGZyb20gXCJyZWFjdC1xci1jb2RlXCI7XG5pbXBvcnQgQXV0aGVudGljYXRpb25Db250ZXh0IGZyb20gXCJhdXRoZW50aWNhdGlvbi9BdXRoZW50aWNhdGlvbkNvbnRleHRcIjtcbmltcG9ydCB1c2VNdWx0aWZhY3RvckF1dGhTZXR1cEhlbHBlciBmcm9tIFwiYXV0aGVudGljYXRpb24vTXVsdGlmYWN0b3JBdXRoU2V0dXBIZWxwZXJcIjtcbmltcG9ydCBNdWx0aWZhY3RvckF1dGhlbnRpY2F0aW9uU3RvcmVDb250ZXh0IGZyb20gXCJhdXRob3JpemF0aW9uL011bHRpZmFjdG9yQXV0aGVudGljYXRpb25TdG9yZUNvbnRleHRcIjtcbmltcG9ydCBUZXh0V2l0aENvcHkgZnJvbSBcImNvcmUvY29tcG9uZW50cy9UZXh0V2l0aENvcHlcIjtcbmltcG9ydCB7IGxvZ0Vycm9yIH0gZnJvbSBcImNvcmUvdXRpbHMvbG9nZ2VyXCI7XG5pbXBvcnQgeyB0IH0gZnJvbSBcImkxOG4vdHJhbnNsYXRlXCI7XG5pbXBvcnQgeyBqc3ggYXMgX2pzeCwgRnJhZ21lbnQgYXMgX0ZyYWdtZW50LCBqc3hzIGFzIF9qc3hzIH0gZnJvbSBcInJlYWN0L2pzeC1ydW50aW1lXCI7XG5jb25zdCBUT1RQX1NFVFVQX1NURVBTID0gW1wiUVJDT0RFX0ZPUk1cIiwgXCJTVUNDRVNTXCJdO1xuY29uc3QgdG90cEF1dGhSZWR1Y2VyID0gKHN0YXRlLCBhY3Rpb24pID0+IHtcblx0c3dpdGNoIChhY3Rpb24udHlwZSkge1xuXHRcdGNhc2UgXCJjaGFuZ2VkX3RvdHBfc2VjcmV0XCI6IHtcblx0XHRcdHJldHVybiB7XG5cdFx0XHRcdC4uLnN0YXRlLFxuXHRcdFx0XHR0b3RwU2VjcmV0OiBhY3Rpb24udG90cFNlY3JldFxuXHRcdFx0fTtcblx0XHR9XG5cdFx0Y2FzZSBcImNoYW5nZWRfdmVyaWZpY2F0aW9uX2NvZGVcIjoge1xuXHRcdFx0cmV0dXJuIHtcblx0XHRcdFx0Li4uc3RhdGUsXG5cdFx0XHRcdHZlcmlmaWNhdGlvbkNvZGU6IGFjdGlvbi52ZXJpZmljYXRpb25Db2RlXG5cdFx0XHR9O1xuXHRcdH1cblx0XHRjYXNlIFwiYmFja1wiOiB7XG5cdFx0XHRjb25zdCBjdXJyZW50U3RlcEluZGV4ID0gVE9UUF9TRVRVUF9TVEVQUy5pbmRleE9mKHN0YXRlLmN1cnJlbnRTdGVwKTtcblx0XHRcdGlmIChjdXJyZW50U3RlcEluZGV4ID09PSAwIHx8IGN1cnJlbnRTdGVwSW5kZXggPT09IC0xKSB7XG5cdFx0XHRcdGxvZ0Vycm9yKFwiQ2Fubm90IGdvIGJhY2sgZnJvbSBmaXJzdCBzdGVwXCIpO1xuXHRcdFx0XHRyZXR1cm4gc3RhdGU7XG5cdFx0XHR9XG5cdFx0XHRyZXR1cm4ge1xuXHRcdFx0XHQuLi5zdGF0ZSxcblx0XHRcdFx0Y3VycmVudFN0ZXA6IFRPVFBfU0VUVVBfU1RFUFNbY3VycmVudFN0ZXBJbmRleCAtIDFdLFxuXHRcdFx0XHR2ZXJpZmljYXRpb25Db2RlOiB1bmRlZmluZWRcblx0XHRcdH07XG5cdFx0fVxuXHRcdGNhc2UgXCJuZXh0XCI6IHtcblx0XHRcdGNvbnN0IGN1cnJlbnRTdGVwSW5kZXggPSBUT1RQX1NFVFVQX1NURVBTLmluZGV4T2Yoc3RhdGUuY3VycmVudFN0ZXApO1xuXHRcdFx0aWYgKGN1cnJlbnRTdGVwSW5kZXggPT09IC0xKSB7XG5cdFx0XHRcdGxvZ0Vycm9yKFwiSW52YWxpZCBjdXJyZW50IHN0ZXBcIik7XG5cdFx0XHRcdHJldHVybiBzdGF0ZTtcblx0XHRcdH1cblx0XHRcdGlmIChjdXJyZW50U3RlcEluZGV4ID09PSBUT1RQX1NFVFVQX1NURVBTLmxlbmd0aCAtIDEpIHtcblx0XHRcdFx0bG9nRXJyb3IoXCJDYW5ub3QgZ28gbmV4dCBmcm9tIGxhc3Qgc3RlcFwiKTtcblx0XHRcdFx0cmV0dXJuIHN0YXRlO1xuXHRcdFx0fVxuXHRcdFx0cmV0dXJuIHtcblx0XHRcdFx0Li4uc3RhdGUsXG5cdFx0XHRcdGN1cnJlbnRTdGVwOiBUT1RQX1NFVFVQX1NURVBTW2N1cnJlbnRTdGVwSW5kZXggKyAxXVxuXHRcdFx0fTtcblx0XHR9XG5cdH1cbn07XG5jb25zdCBUb3RwQXV0aFNldHVwRmllbGRTZXQgPSAoKSA9PiB7XG5cdGNvbnN0IFtzdGF0ZSwgZGlzcGF0Y2hdID0gdXNlUmVkdWNlcih0b3RwQXV0aFJlZHVjZXIsIHsgY3VycmVudFN0ZXA6IFwiUVJDT0RFX0ZPUk1cIiB9KTtcblx0Y29uc3QgeyBzdG9yZSB9ID0gTXVsdGlmYWN0b3JBdXRoZW50aWNhdGlvblN0b3JlQ29udGV4dC51c2VDb250YWluZXIoKTtcblx0Y29uc3Qgc2V0RXJyb3JNZXNzYWdlID0gc3RvcmUoKHN0YXRlKSA9PiBzdGF0ZS5zZXRFcnJvck1lc3NhZ2UpO1xuXHRjb25zdCB7IHVzZXIgfSA9IEF1dGhlbnRpY2F0aW9uQ29udGV4dC51c2VDb250YWluZXIoKTtcblx0Y29uc3QgeyBlbnJvbGxNZmEsIGdlbmVyYXRlVE9UUFNlY3JldCB9ID0gdXNlTXVsdGlmYWN0b3JBdXRoU2V0dXBIZWxwZXIoKTtcblx0Y29uc3QgW2xvYWRpbmcsIHNldExvYWRpbmddID0gdXNlU3RhdGUoZmFsc2UpO1xuXHRjb25zdCBnZW5lcmF0ZVRvdHBTZWNyZXQgPSB1c2VDYWxsYmFjayhhc3luYyAoKSA9PiB7XG5cdFx0c2V0TG9hZGluZyh0cnVlKTtcblx0XHR0cnkge1xuXHRcdFx0Y29uc3QgdG90cFNlY3JldCA9IGF3YWl0IGdlbmVyYXRlVE9UUFNlY3JldCgpO1xuXHRcdFx0ZGlzcGF0Y2goe1xuXHRcdFx0XHR0b3RwU2VjcmV0LFxuXHRcdFx0XHR0eXBlOiBcImNoYW5nZWRfdG90cF9zZWNyZXRcIlxuXHRcdFx0fSk7XG5cdFx0fSBjYXRjaCAoZXJyb3IpIHtcblx0XHRcdHNldEVycm9yTWVzc2FnZShlcnJvci5tZXNzYWdlKTtcblx0XHR9IGZpbmFsbHkge1xuXHRcdFx0c2V0TG9hZGluZyhmYWxzZSk7XG5cdFx0fVxuXHR9LCBbZ2VuZXJhdGVUT1RQU2VjcmV0LCBzZXRFcnJvck1lc3NhZ2VdKTtcblx0dXNlRWZmZWN0KCgpID0+IHtcblx0XHRnZW5lcmF0ZVRvdHBTZWNyZXQoKTtcblx0fSwgW2dlbmVyYXRlVG90cFNlY3JldF0pO1xuXHRjb25zdCBvbkVucm9sbFRvdHAgPSB1c2VDYWxsYmFjayhhc3luYyAoKSA9PiB7XG5cdFx0c2V0TG9hZGluZyh0cnVlKTtcblx0XHR0cnkge1xuXHRcdFx0aWYgKHN0YXRlLnZlcmlmaWNhdGlvbkNvZGUgJiYgc3RhdGUudG90cFNlY3JldCkge1xuXHRcdFx0XHRhd2FpdCBlbnJvbGxNZmEoXCJ0b3RwXCIsIHN0YXRlLnZlcmlmaWNhdGlvbkNvZGUsIHsgdG90cFNlY3JldDogc3RhdGUudG90cFNlY3JldCB9KTtcblx0XHRcdFx0ZGlzcGF0Y2goeyB0eXBlOiBcIm5leHRcIiB9KTtcblx0XHRcdH1cblx0XHR9IGNhdGNoIChlcnJvcikge1xuXHRcdFx0c2V0RXJyb3JNZXNzYWdlKGVycm9yLm1lc3NhZ2UpO1xuXHRcdH0gZmluYWxseSB7XG5cdFx0XHRzZXRMb2FkaW5nKGZhbHNlKTtcblx0XHR9XG5cdH0sIFtcblx0XHRlbnJvbGxNZmEsXG5cdFx0c2V0RXJyb3JNZXNzYWdlLFxuXHRcdHN0YXRlLnRvdHBTZWNyZXQsXG5cdFx0c3RhdGUudmVyaWZpY2F0aW9uQ29kZVxuXHRdKTtcblx0cmV0dXJuIC8qIEBfX1BVUkVfXyAqLyBfanN4cyhfRnJhZ21lbnQsIHsgY2hpbGRyZW46IFtzdGF0ZS5jdXJyZW50U3RlcCA9PT0gXCJRUkNPREVfRk9STVwiICYmIC8qIEBfX1BVUkVfXyAqLyBfanN4cyhSb3csIHtcblx0XHRibG9jazogdHJ1ZSxcblx0XHRzdGFja2VkOiB0cnVlLFxuXHRcdGNoaWxkcmVuOiBbLyogQF9fUFVSRV9fICovIF9qc3goQ2FyZCwgeyBjaGlsZHJlbjogLyogQF9fUFVSRV9fICovIF9qc3goXCJwXCIsIHsgY2hpbGRyZW46IHQoXCJtZmEuZmFjdG9ycy50b3RwLnNldHVwLmluZm9cIikgfSkgfSksIC8qIEBfX1BVUkVfXyAqLyBfanN4KENhcmQsIHtcblx0XHRcdGxvYWRpbmc6ICFzdGF0ZS50b3RwU2VjcmV0ICYmIGxvYWRpbmcsXG5cdFx0XHRjaGlsZHJlbjogLyogQF9fUFVSRV9fICovIF9qc3hzKEZsZXgsIHtcblx0XHRcdFx0YWxpZ246IFwiY2VudGVyXCIsXG5cdFx0XHRcdGRpcmVjdGlvbjogXCJjb2x1bW5cIixcblx0XHRcdFx0Z2FwOiBcIm5vcm1hbFwiLFxuXHRcdFx0XHRjaGlsZHJlbjogW3N0YXRlLnRvdHBTZWNyZXQgJiYgLyogQF9fUFVSRV9fICovIF9qc3hzKF9GcmFnbWVudCwgeyBjaGlsZHJlbjogWy8qIEBfX1BVUkVfXyAqLyBfanN4KFRleHRXaXRoQ29weSwgeyBsYWJlbDogc3RhdGUudG90cFNlY3JldC5zZWNyZXRLZXkgfSksIC8qIEBfX1BVUkVfXyAqLyBfanN4KFFSQ29kZSwgeyB2YWx1ZTogc3RhdGUudG90cFNlY3JldC5nZW5lcmF0ZVFyQ29kZVVybCh1c2VyLmVtYWlsLCBpbXBvcnQubWV0YS5lbnYuUFJPRCA/IFwiUWFyZ29cIiA6IFwiUWFyZ28gKFRlc3QpXCIpIH0pXSB9KSwgLyogQF9fUFVSRV9fICovIF9qc3hzKEZpZWxkQWN0aW9uQ29udGFpbmVyU3R5bGVkLCB7XG5cdFx0XHRcdFx0Z2FwOiBcInNtYWxsXCIsXG5cdFx0XHRcdFx0Y2hpbGRyZW46IFsvKiBAX19QVVJFX18gKi8gX2pzeChJbnB1dEZpZWxkLCB7XG5cdFx0XHRcdFx0XHRsYWJlbDogdChcIm1mYS5maWVsZHMudG9rZW5cIiksXG5cdFx0XHRcdFx0XHRuYW1lOiBcInZlcmlmaWNhdGlvbkNvZGVcIixcblx0XHRcdFx0XHRcdG9uQ2hhbmdlOiAoZXZlbnQpID0+IGRpc3BhdGNoKHtcblx0XHRcdFx0XHRcdFx0dHlwZTogXCJjaGFuZ2VkX3ZlcmlmaWNhdGlvbl9jb2RlXCIsXG5cdFx0XHRcdFx0XHRcdHZlcmlmaWNhdGlvbkNvZGU6IGV2ZW50LnRhcmdldC52YWx1ZVxuXHRcdFx0XHRcdFx0fSksXG5cdFx0XHRcdFx0XHRvbktleURvd246IGFzeW5jIChldmVudCkgPT4ge1xuXHRcdFx0XHRcdFx0XHRpZiAoZXZlbnQua2V5ID09PSBcIkVudGVyXCIpIHtcblx0XHRcdFx0XHRcdFx0XHRhd2FpdCBvbkVucm9sbFRvdHAoKTtcblx0XHRcdFx0XHRcdFx0fVxuXHRcdFx0XHRcdFx0fSxcblx0XHRcdFx0XHRcdHZhbHVlOiBzdGF0ZS52ZXJpZmljYXRpb25Db2RlXG5cdFx0XHRcdFx0fSksIC8qIEBfX1BVUkVfXyAqLyBfanN4KEJ1dHRvbiwge1xuXHRcdFx0XHRcdFx0Y2xhc3NOYW1lOiBcIndpdGgtZmllbGQtaGVpZ2h0XCIsXG5cdFx0XHRcdFx0XHRkaXNhYmxlZDogIXN0YXRlLnZlcmlmaWNhdGlvbkNvZGUsXG5cdFx0XHRcdFx0XHRsb2FkaW5nOiBsb2FkaW5nICYmICEhc3RhdGUudmVyaWZpY2F0aW9uQ29kZSxcblx0XHRcdFx0XHRcdG9uQ2xpY2s6IG9uRW5yb2xsVG90cCxcblx0XHRcdFx0XHRcdHR5cGU6IFwicHJpbWFyeVwiLFxuXHRcdFx0XHRcdFx0Y2hpbGRyZW46IHQoXCJtZmEuYWN0aW9ucy52ZXJpZnlcIilcblx0XHRcdFx0XHR9KV1cblx0XHRcdFx0fSldXG5cdFx0XHR9KVxuXHRcdH0pXVxuXHR9KSwgc3RhdGUuY3VycmVudFN0ZXAgPT09IFwiU1VDQ0VTU1wiICYmIC8qIEBfX1BVUkVfXyAqLyBfanN4KENhcmQsIHsgY2hpbGRyZW46IC8qIEBfX1BVUkVfXyAqLyBfanN4KFwicFwiLCB7IGNoaWxkcmVuOiB0KFwibWZhLmZhY3RvcnMudG90cC5zZXR1cC5zdWNjZXNzXCIpIH0pIH0pXSB9KTtcbn07XG5jb25zdCBGaWVsZEFjdGlvbkNvbnRhaW5lclN0eWxlZCA9IHN0eWxlZChGbGV4KWBcbiAgJiA+IC5mb3JtLWZpZWxkIHtcbiAgICBmbGV4OiAxO1xuICB9XG5gO1xuZXhwb3J0IGRlZmF1bHQgVG90cEF1dGhTZXR1cEZpZWxkU2V0O1xuIl19*/.className_c178xisc{width:100%;}
.className_c1u7cgpu{width:100%;}
.overlayClassName_or199nl .ant-dropdown-menu{max-height:80vh;overflow-y:auto;}
.narrowMenuClass_nv2iwwf{width:100vw;}
.qargoAdminClass_q2lgt6r{max-width:100vw;min-width:400px;}
.userMenuClass_ueg14t2{max-width:100vw;min-width:300px;}
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/home/runner/work/frontend/frontend/packages/tms/src/core/components/header/UserMenu.tsx"],"names":[".className_c178xisc",".className_c1u7cgpu",".overlayClassName_or199nl",".narrowMenuClass_nv2iwwf",".qargoAdminClass_q2lgt6r",".userMenuClass_ueg14t2"],"mappings":"AAwKeA;AAMCC;AAqCMC;AAwBEC;AAGAC;AAIFC","file":"/home/runner/work/frontend/frontend/packages/tms/src/core/components/header/UserMenu.tsx","sourcesContent":["import { useState } from \"react\";\nimport { css } from \"@linaria/core\";\nimport { Avatar, Button, Col, DropDown, DropDownMenuFakeItem, Menu, MenuDivider, MenuItem, Row, Switch, UserIcon, Text, Flex, SettingIcon, LogoutIcon, SubMenu } from \"@qargo/ui-kit\";\nimport classNames from \"classnames\";\nimport { Link } from \"react-router-dom\";\nimport AuditChangelogViewer from \"audit-logs/components/AuditChangelogViewer\";\nimport AuthenticationContext from \"authentication/AuthenticationContext\";\nimport MultiFactorAuthenticationOverview from \"authentication/MultiFactorAuthenticationSetupModal\";\nimport useAuthorizationHelper from \"authorization/AuthorizationHelper\";\nimport AvailableTenantsContext from \"authorization/AvailableTenantsContext\";\nimport TenantContext from \"authorization/TenantContext\";\nimport KeyboardShortcut from \"core/components/keyboard-shortcut/KeyboardShortcut\";\nimport useKeyPress from \"core/hooks/useKeyPress\";\nimport AppContext from \"core/providers/AppContext\";\nimport AppDataContext from \"core/providers/AppDataContext\";\nimport { prefixPathWithTenant } from \"core/routing/RouteHelper\";\nimport { addBreadcrumb } from \"core/utils/logger\";\nimport DebugWrapper from \"debug/components/DebugWrapper\";\nimport LocaleSelectField from \"forms/components/LocaleSelectField\";\nimport useModalFormHelper from \"forms/helpers/ModalFormHelper\";\nimport I18nContext from \"i18n/I18nContext\";\nimport LiveTranslationContext from \"i18n/LiveTranslationContext\";\nimport { t } from \"i18n/translate\";\nimport { userSettingsPath } from \"workflow/routes/WorkflowRouteHelper\";\nimport TextWithCopy from \"../TextWithCopy\";\nimport FeatureDiscoveryWrapper from \"../discovery/FeatureDiscoveryWrapper\";\nimport UserMenuImpersonation from \"./UserMenuImpersonation\";\nimport UserMenuSwitchTenant from \"./UserMenuSwitchTenant\";\nimport { useTranslationExportHelper } from \"./downloadTranslationsCsv\";\nimport { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nconst UserMenu = ({ afterTenantSwitch, extraRows, narrowDisplayMode = false, onLogout, popupMatchSelectWidth }) => {\n\tconst [auditLogOpen, setAuditLogOpen] = useState(false);\n\tconst { isDebugActive, protectTenants, setIsDebugActive, setProtectTenants } = AppContext.useContainer();\n\tconst { isOutlookClient } = AppDataContext.useContainer();\n\tconst modalProps = useModalFormHelper();\n\tconst { getJwt, user } = AuthenticationContext.useContainer();\n\tconst { activeTenant } = TenantContext.useContainer();\n\tconst { availableTenants } = AvailableTenantsContext.useContainer();\n\tconst { activeLocale, onChangeUserLocale } = I18nContext.useContainer();\n\tconst { liveTranslationsActive, liveTranslationsAvailable, setLiveTranslationsActive } = LiveTranslationContext.useContainer();\n\tconst { isUserQargoAdmin, userCompanyId, userHasQargoIOMail } = useAuthorizationHelper();\n\tconst { exportTranslations } = useTranslationExportHelper();\n\tconst auditLogShortcutAvailable = isUserQargoAdmin && isDebugActive;\n\tuseKeyPress(auditLogShortcutAvailable ? [{\n\t\tcallback: () => setAuditLogOpen((prev) => !prev),\n\t\tcombinationKeys: [\n\t\t\t\"meta\",\n\t\t\t\"shift\",\n\t\t\t\"h\"\n\t\t],\n\t\tkey: \"open-audit-log\"\n\t}] : []);\n\tconst hasQargoAdminRoleAssignment = availableTenants.some((tenant) => tenant.role && tenant.role === \"QARGO_ADMIN\");\n\tconst menu = /* @__PURE__ */ _jsxs(Menu, {\n\t\tclassName: classNames({\n\t\t\t[narrowMenuClass]: narrowDisplayMode,\n\t\t\t[qargoAdminClass]: !narrowDisplayMode && isUserQargoAdmin,\n\t\t\t[userMenuClass]: !narrowDisplayMode && !isUserQargoAdmin\n\t\t}),\n\t\tchildren: [\n\t\t\t/* @__PURE__ */ _jsx(DropDownMenuFakeItem, { children: /* @__PURE__ */ _jsx(\"div\", { children: user.email }) }),\n\t\t\tliveTranslationsAvailable && /* @__PURE__ */ _jsxs(_Fragment, { children: [/* @__PURE__ */ _jsx(MenuDivider, {}), /* @__PURE__ */ _jsx(DropDownMenuFakeItem, { children: /* @__PURE__ */ _jsxs(Row, {\n\t\t\t\tgutter: true,\n\t\t\t\tchildren: [/* @__PURE__ */ _jsx(Col, {\n\t\t\t\t\tflex: \"auto\",\n\t\t\t\t\tchildren: \"Live translations\"\n\t\t\t\t}), /* @__PURE__ */ _jsx(Col, { children: /* @__PURE__ */ _jsx(Switch, {\n\t\t\t\t\tchecked: liveTranslationsActive,\n\t\t\t\t\tdisabled: liveTranslationsActive,\n\t\t\t\t\tonClick: (value) => setLiveTranslationsActive(value)\n\t\t\t\t}) })]\n\t\t\t}) })] }),\n\t\t\tavailableTenants.length > 0 && /* @__PURE__ */ _jsxs(_Fragment, { children: [\n\t\t\t\t/* @__PURE__ */ _jsx(MenuDivider, {}),\n\t\t\t\t/* @__PURE__ */ _jsxs(DropDownMenuFakeItem, { children: [availableTenants.length === 1 && /* @__PURE__ */ _jsx(\"div\", { children: activeTenant.name }), availableTenants.length > 1 && /* @__PURE__ */ _jsxs(_Fragment, { children: [/* @__PURE__ */ _jsx(DebugWrapper, { jsonData: activeTenant }), /* @__PURE__ */ _jsx(UserMenuSwitchTenant, {\n\t\t\t\t\tafterTenantSwitch,\n\t\t\t\t\tcurrentCompanyId: userCompanyId,\n\t\t\t\t\tcurrentTenantId: activeTenant.row_id,\n\t\t\t\t\tcurrentTenantSlug: activeTenant.slug,\n\t\t\t\t\tpopupMatchSelectWidth,\n\t\t\t\t\tuserRole: user.active_tenant_default_role\n\t\t\t\t})] })] }),\n\t\t\t\thasQargoAdminRoleAssignment && /* @__PURE__ */ _jsx(DropDownMenuFakeItem, { children: /* @__PURE__ */ _jsx(UserMenuImpersonation, {}) }),\n\t\t\t\t(isUserQargoAdmin || userHasQargoIOMail) && /* @__PURE__ */ _jsxs(_Fragment, { children: [\n\t\t\t\t\t/* @__PURE__ */ _jsx(MenuDivider, {}),\n\t\t\t\t\t/* @__PURE__ */ _jsxs(DropDownMenuFakeItem, { children: [/* @__PURE__ */ _jsx(TextWithCopy, {\n\t\t\t\t\t\talwaysShow: true,\n\t\t\t\t\t\tgetValue: () => activeTenant.row_id,\n\t\t\t\t\t\tlabel: `Tenant id: ${activeTenant.row_id}`\n\t\t\t\t\t}), /* @__PURE__ */ _jsx(TextWithCopy, {\n\t\t\t\t\t\talwaysShow: true,\n\t\t\t\t\t\tgetValue: getJwt,\n\t\t\t\t\t\tlabel: \"Json web token (JWT)\"\n\t\t\t\t\t})] }),\n\t\t\t\t\t/* @__PURE__ */ _jsx(MenuDividerNoMargin, {}),\n\t\t\t\t\t/* @__PURE__ */ _jsx(MenuItem, {\n\t\t\t\t\t\tonClick: exportTranslations,\n\t\t\t\t\t\tchildren: /* @__PURE__ */ _jsx(Text, { children: \"Export translations\" })\n\t\t\t\t\t}),\n\t\t\t\t\t/* @__PURE__ */ _jsx(MenuDividerNoMargin, {}),\n\t\t\t\t\t/* @__PURE__ */ _jsxs(DropDownMenuFakeItem, { children: [/* @__PURE__ */ _jsxs(Flex, {\n\t\t\t\t\t\talign: \"center\",\n\t\t\t\t\t\tgap: \"small\",\n\t\t\t\t\t\tjustify: \"space-between\",\n\t\t\t\t\t\tchildren: [/* @__PURE__ */ _jsx(Text, { children: \"Debug tools\" }), /* @__PURE__ */ _jsx(Switch, {\n\t\t\t\t\t\t\tchecked: isDebugActive,\n\t\t\t\t\t\t\tonClick: (value) => {\n\t\t\t\t\t\t\t\tsetIsDebugActive(value);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tsize: \"small\"\n\t\t\t\t\t\t})]\n\t\t\t\t\t}), /* @__PURE__ */ _jsxs(Flex, {\n\t\t\t\t\t\talign: \"center\",\n\t\t\t\t\t\tgap: \"small\",\n\t\t\t\t\t\tjustify: \"space-between\",\n\t\t\t\t\t\tchildren: [/* @__PURE__ */ _jsx(Text, { children: \"Tenant protection\" }), /* @__PURE__ */ _jsx(Switch, {\n\t\t\t\t\t\t\tchecked: protectTenants,\n\t\t\t\t\t\t\tonClick: (value) => {\n\t\t\t\t\t\t\t\taddBreadcrumb(`Checking protect tenant switch.`, { value });\n\t\t\t\t\t\t\t\tsetProtectTenants(value);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tsize: \"small\"\n\t\t\t\t\t\t})]\n\t\t\t\t\t})] })\n\t\t\t\t] }),\n\t\t\t\tisUserQargoAdmin && /* @__PURE__ */ _jsxs(_Fragment, { children: [\n\t\t\t\t\tisDebugActive && /* @__PURE__ */ _jsxs(_Fragment, { children: [/* @__PURE__ */ _jsx(MenuDividerNoMargin, {}), /* @__PURE__ */ _jsx(MenuItem, {\n\t\t\t\t\t\tonClick: () => setAuditLogOpen(true),\n\t\t\t\t\t\tchildren: /* @__PURE__ */ _jsxs(Flex, {\n\t\t\t\t\t\t\talign: \"center\",\n\t\t\t\t\t\t\tgap: \"small\",\n\t\t\t\t\t\t\tjustify: \"space-between\",\n\t\t\t\t\t\t\tchildren: [/* @__PURE__ */ _jsx(Text, { children: t(\"auditLog.title\") }), /* @__PURE__ */ _jsx(KeyboardShortcut, { combinationKeys: [\n\t\t\t\t\t\t\t\t\"meta\",\n\t\t\t\t\t\t\t\t\"shift\",\n\t\t\t\t\t\t\t\t\"h\"\n\t\t\t\t\t\t\t] })]\n\t\t\t\t\t\t})\n\t\t\t\t\t})] }),\n\t\t\t\t\t/* @__PURE__ */ _jsx(MenuDividerNoMargin, {}),\n\t\t\t\t\t/* @__PURE__ */ _jsxs(SubMenu, {\n\t\t\t\t\t\ttitle: \"Links\",\n\t\t\t\t\t\tchildren: [\n\t\t\t\t\t\t\t/* @__PURE__ */ _jsx(MenuItem, { children: /* @__PURE__ */ _jsx(Link, {\n\t\t\t\t\t\t\t\tto: prefixPathWithTenant(\"icons\"),\n\t\t\t\t\t\t\t\tchildren: \"Icons\"\n\t\t\t\t\t\t\t}) }),\n\t\t\t\t\t\t\t/* @__PURE__ */ _jsx(MenuDividerNoMargin, {}),\n\t\t\t\t\t\t\t/* @__PURE__ */ _jsx(MenuItem, { children: /* @__PURE__ */ _jsx(Link, {\n\t\t\t\t\t\t\t\tto: prefixPathWithTenant(\"typography\"),\n\t\t\t\t\t\t\t\tchildren: \"Typography\"\n\t\t\t\t\t\t\t}) })\n\t\t\t\t\t\t]\n\t\t\t\t\t})\n\t\t\t\t] })\n\t\t\t] }),\n\t\t\t/* @__PURE__ */ _jsx(MenuDividerNoMargin, {}),\n\t\t\textraRows && /* @__PURE__ */ _jsxs(_Fragment, { children: [extraRows.map((row, index) => /* @__PURE__ */ _jsx(DropDownMenuFakeItem, { children: row }, index)), /* @__PURE__ */ _jsx(MenuDividerNoMargin, {})] }),\n\t\t\tisOutlookClient ? /* @__PURE__ */ _jsxs(_Fragment, { children: [/* @__PURE__ */ _jsx(DropDownMenuFakeItem, { children: /* @__PURE__ */ _jsx(LocaleSelectField, {\n\t\t\t\tallowClear: false,\n\t\t\t\tlabel: t(\"tenant.fields.locale\"),\n\t\t\t\tonChange: (value) => {\n\t\t\t\t\tonChangeUserLocale(value);\n\t\t\t\t},\n\t\t\t\tonlyShowTenantVisibleLocales: false,\n\t\t\t\tuiOnly: true,\n\t\t\t\tvalue: activeLocale\n\t\t\t}) }), /* @__PURE__ */ _jsx(MenuDividerNoMargin, {})] }) : /* @__PURE__ */ _jsxs(_Fragment, { children: [/* @__PURE__ */ _jsx(MenuItem, { children: /* @__PURE__ */ _jsx(FeatureDiscoveryWrapper, {\n\t\t\t\tclassName: css`\n                width: 100%;\n              `,\n\t\t\t\tfeatureKey: \"user-menu-mailbox-configuration\",\n\t\t\t\tincrementDiscoveryCounterOnClick: true,\n\t\t\t\tchildren: /* @__PURE__ */ _jsx(Link, {\n\t\t\t\t\tclassName: css`\n                  width: 100%;\n                `,\n\t\t\t\t\tto: userSettingsPath(),\n\t\t\t\t\tchildren: /* @__PURE__ */ _jsxs(Text, { children: [\n\t\t\t\t\t\t/* @__PURE__ */ _jsx(SettingIcon, {}),\n\t\t\t\t\t\t\"\\xA0\",\n\t\t\t\t\t\tt(\"user.settings._self\")\n\t\t\t\t\t] })\n\t\t\t\t})\n\t\t\t}) }), /* @__PURE__ */ _jsx(MenuDividerNoMargin, {})] }),\n\t\t\t/* @__PURE__ */ _jsx(MenuItem, {\n\t\t\t\tonClick: onLogout,\n\t\t\t\tchildren: /* @__PURE__ */ _jsxs(Text, {\n\t\t\t\t\tcolor: \"danger\",\n\t\t\t\t\tchildren: [\n\t\t\t\t\t\t/* @__PURE__ */ _jsx(LogoutIcon, {}),\n\t\t\t\t\t\t\"\\xA0\",\n\t\t\t\t\t\tt(\"authentication.signOut\")\n\t\t\t\t\t]\n\t\t\t\t})\n\t\t\t})\n\t\t]\n\t});\n\treturn /* @__PURE__ */ _jsxs(\"div\", {\n\t\tclassName: \"user-menu\",\n\t\tchildren: [\n\t\t\t/* @__PURE__ */ _jsx(MultiFactorAuthenticationOverview, { ...modalProps }),\n\t\t\tisDebugActive && isUserQargoAdmin && /* @__PURE__ */ _jsx(AuditChangelogViewer, {\n\t\t\t\tbuttonType: \"none\",\n\t\t\t\tdefaultActiveKey: \"technical\",\n\t\t\t\texternalOpen: auditLogOpen,\n\t\t\t\tonExternalOpenChange: setAuditLogOpen\n\t\t\t}),\n\t\t\t/* @__PURE__ */ _jsx(DropDown, {\n\t\t\t\talign: narrowDisplayMode ? { offset: [16, 4] } : undefined,\n\t\t\t\tdropdownRender: () => menu,\n\t\t\t\toverlayClassName: css`\n          .ant-dropdown-menu {\n            max-height: 80vh;\n            overflow-y: auto;\n          }\n        `,\n\t\t\t\tchildren: /* @__PURE__ */ _jsx(Button, {\n\t\t\t\t\ttype: \"link-inline\",\n\t\t\t\t\tchildren: /* @__PURE__ */ _jsx(FeatureDiscoveryWrapper, {\n\t\t\t\t\t\tfeatureKey: \"user-menu-mailbox-configuration\",\n\t\t\t\t\t\tinverse: true,\n\t\t\t\t\t\ttype: \"badge\",\n\t\t\t\t\t\tchildren: /* @__PURE__ */ _jsx(Avatar, {\n\t\t\t\t\t\t\tstyle: { backgroundColor: \"white\" },\n\t\t\t\t\t\t\tchildren: /* @__PURE__ */ _jsx(UserIcon, {})\n\t\t\t\t\t\t})\n\t\t\t\t\t})\n\t\t\t\t})\n\t\t\t})\n\t\t]\n\t});\n};\nconst MenuDividerNoMargin = () => /* @__PURE__ */ _jsx(MenuDivider, { style: { margin: 0 } });\nexport default UserMenu;\nconst narrowMenuClass = css`\n  width: 100vw;\n`;\nconst qargoAdminClass = css`\n  max-width: 100vw;\n  min-width: 400px;\n`;\nconst userMenuClass = css`\n  max-width: 100vw;\n  min-width: 300px;\n`;\n"]}*/