@bigbinary/neeto-team-members-frontend 5.0.62 → 5.0.63
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/.ready +1 -1
- package/dist/ManageMember.js +5 -11
- package/dist/ManageMember.js.map +1 -1
- package/dist/{Permissions-LWRAefeb.js → Permissions-BVkx_S_F.js} +2 -2
- package/dist/Permissions-BVkx_S_F.js.map +1 -0
- package/dist/{Permissions-Bz0SmJzH.js → Permissions-DIdoAJlu.js} +2 -2
- package/dist/Permissions-DIdoAJlu.js.map +1 -0
- package/dist/Profile.js +4 -13
- package/dist/Profile.js.map +1 -1
- package/dist/{ProfileImage-BLnx0E90.js → ProfileImage-BjDA-txF.js} +2 -2
- package/dist/ProfileImage-BjDA-txF.js.map +1 -0
- package/dist/{ProfileImage-V240yfTY.js → ProfileImage-Ca02-i_d.js} +2 -2
- package/dist/ProfileImage-Ca02-i_d.js.map +1 -0
- package/dist/cjs/ManageMember.js +5 -11
- package/dist/cjs/ManageMember.js.map +1 -1
- package/dist/cjs/Profile.js +4 -14
- package/dist/cjs/Profile.js.map +1 -1
- package/dist/cjs/v2/Groups.js +1 -1
- package/dist/cjs/v2/Groups.js.map +1 -1
- package/dist/cjs/v2/ManageMember.js +2 -2
- package/dist/cjs/v2/MembersDropdown.js +1 -1
- package/dist/cjs/v2/MembersInvite.js +1 -1
- package/dist/cjs/v2/MembersInvite.js.map +1 -1
- package/dist/cjs/v2/Permissions.js +1 -1
- package/dist/cjs/v2/Profile.js +5 -13
- package/dist/cjs/v2/Profile.js.map +1 -1
- package/dist/cjs/v2/Roles.js +1 -1
- package/dist/cjs/v2/TeamMembers.js +2 -2
- package/dist/cjs/v2/TeamsDropdown.js +1 -1
- package/dist/cjs/v2/index.js +4 -4
- package/dist/{index-CBt9gCBK.js → index-81N6f9JN.js} +11 -17
- package/dist/index-81N6f9JN.js.map +1 -0
- package/dist/{index-BRgcqXVL.js → index-BVrpRWeD.js} +3 -3
- package/dist/index-BVrpRWeD.js.map +1 -0
- package/dist/{index-BFScwOib.js → index-Bk0TH8c8.js} +11 -17
- package/dist/index-Bk0TH8c8.js.map +1 -0
- package/dist/{index-BMb0DElQ.js → index-CVZHlIdE.js} +3 -3
- package/dist/index-CVZHlIdE.js.map +1 -0
- package/dist/v2/Groups.js +1 -1
- package/dist/v2/Groups.js.map +1 -1
- package/dist/v2/ManageMember.js +2 -2
- package/dist/v2/MembersDropdown.js +1 -1
- package/dist/v2/MembersInvite.js +1 -1
- package/dist/v2/MembersInvite.js.map +1 -1
- package/dist/v2/Permissions.js +1 -1
- package/dist/v2/Profile.js +6 -14
- package/dist/v2/Profile.js.map +1 -1
- package/dist/v2/Roles.js +1 -1
- package/dist/v2/TeamMembers.js +2 -2
- package/dist/v2/TeamsDropdown.js +1 -1
- package/dist/v2/index.js +4 -4
- package/package.json +5 -5
- package/dist/Permissions-Bz0SmJzH.js.map +0 -1
- package/dist/Permissions-LWRAefeb.js.map +0 -1
- package/dist/ProfileImage-BLnx0E90.js.map +0 -1
- package/dist/ProfileImage-V240yfTY.js.map +0 -1
- package/dist/index-BFScwOib.js.map +0 -1
- package/dist/index-BMb0DElQ.js.map +0 -1
- package/dist/index-BRgcqXVL.js.map +0 -1
- package/dist/index-CBt9gCBK.js.map +0 -1
package/dist/Profile.js
CHANGED
|
@@ -10,7 +10,6 @@ import _objectWithoutProperties from '@babel/runtime/helpers/objectWithoutProper
|
|
|
10
10
|
import _asyncToGenerator from '@babel/runtime/helpers/asyncToGenerator';
|
|
11
11
|
import _regeneratorRuntime from '@babel/runtime/regenerator';
|
|
12
12
|
import { NeetoTimezoneSelector, ianaTimezoneToHumanReadable } from '@bigbinary/neeto-time-zones';
|
|
13
|
-
import classnames from 'classnames';
|
|
14
13
|
import { findBy, noop, _findBy } from '@bigbinary/neeto-cist';
|
|
15
14
|
import { LANGUAGE_OPTIONS } from '@bigbinary/neeto-commons-frontend/constants';
|
|
16
15
|
import { useProfileImageUpload } from '@bigbinary/neeto-image-uploader-frontend/hooks';
|
|
@@ -91,13 +90,8 @@ var ChangeProfile = function ChangeProfile(_ref) {
|
|
|
91
90
|
countryId = _user$countryId === void 0 ? "" : _user$countryId,
|
|
92
91
|
_user$timeFormat = user.timeFormat,
|
|
93
92
|
timeFormat = _user$timeFormat === void 0 ? TIME_FORMAT_OPTIONS[0].value : _user$timeFormat,
|
|
94
|
-
_user$isOwner = user.isOwner,
|
|
95
|
-
isOwner = _user$isOwner === void 0 ? false : _user$isOwner,
|
|
96
|
-
_user$timezoneChangeE = user.timezoneChangeEnabled,
|
|
97
|
-
timezoneChangeEnabled = _user$timezoneChangeE === void 0 ? true : _user$timezoneChangeE,
|
|
98
93
|
_user$language = user.language,
|
|
99
94
|
language = _user$language === void 0 ? "" : _user$language;
|
|
100
|
-
var isTimezoneFieldDisabled = !isOwner && !timezoneChangeEnabled;
|
|
101
95
|
var setFieldValueRef = useRef(null);
|
|
102
96
|
var _useCountries = useCountries(),
|
|
103
97
|
countryDropdownOptions = _useCountries.countryDropdownOptions,
|
|
@@ -118,11 +112,10 @@ var ChangeProfile = function ChangeProfile(_ref) {
|
|
|
118
112
|
onChange: function onChange(_ref2) {
|
|
119
113
|
var main = _ref2.main;
|
|
120
114
|
return setFieldValueRef.current("timeZone", main);
|
|
121
|
-
}
|
|
122
|
-
disabled: isTimezoneFieldDisabled
|
|
115
|
+
}
|
|
123
116
|
});
|
|
124
117
|
}
|
|
125
|
-
}, [timeZone, timeFormat
|
|
118
|
+
}, [timeZone, timeFormat]);
|
|
126
119
|
var initialFormValues = {
|
|
127
120
|
firstName: firstName,
|
|
128
121
|
lastName: lastName,
|
|
@@ -287,11 +280,9 @@ var ChangeProfile = function ChangeProfile(_ref) {
|
|
|
287
280
|
required: true,
|
|
288
281
|
children: t("neetoTeamMembers.profile.inputs.label.timeZone")
|
|
289
282
|
}), /*#__PURE__*/jsx("div", {
|
|
283
|
+
className: "w-full grow",
|
|
290
284
|
"data-testid": "ntm-profile-time-zone-select",
|
|
291
|
-
ref: timezoneRef
|
|
292
|
-
className: classnames("w-full grow", {
|
|
293
|
-
"neeto-ui-bg-gray-100 pointer-events-none": isTimezoneFieldDisabled
|
|
294
|
-
})
|
|
285
|
+
ref: timezoneRef
|
|
295
286
|
})]
|
|
296
287
|
}), touched.timeZone && errors.timeZone && /*#__PURE__*/jsx(Typography, {
|
|
297
288
|
className: "neeto-ui-text-error-800",
|
package/dist/Profile.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Profile.js","sources":["../app/javascript/src/components/Profile/ChangeProfile.jsx","../app/javascript/src/components/Profile/hooks/useProfileUpdatePane.js","../app/javascript/src/components/Profile/utils.js","../app/javascript/src/components/Profile/Preview.jsx","../app/javascript/src/components/Profile/index.jsx"],"sourcesContent":["import { useCallback, useEffect, useRef } from \"react\";\n\nimport { NeetoTimezoneSelector } from \"@bigbinary/neeto-time-zones\";\nimport classNames from \"classnames\";\nimport { findBy, noop } from \"neetocist\";\nimport { LANGUAGE_OPTIONS } from \"neetocommons/constants\";\nimport { useProfileImageUpload } from \"neetoimageuploader\";\nimport { FormikPhoneNumberInput } from \"neetomolecules/PhoneNumber\";\nimport { Label, Pane, Spinner, Toastr, Typography } from \"neetoui\";\nimport { Input, Select, Form, ActionBlock } from \"neetoui/formik\";\nimport { isNotNil } from \"ramda\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { DATE_FORMAT_OPTIONS, TIME_FORMAT_OPTIONS } from \"common/constants\";\nimport {\n useUpdateProfileMutation,\n useFetchProfile,\n} from \"hooks/profile/useProfileApi\";\n\nimport { PROFILE_VALIDATION_SCHEMA } from \"./constants\";\nimport useCountries from \"./hooks/useCountries\";\nimport ProfileImage from \"./ProfileImage\";\n\nconst ChangeProfile = ({ onClose }) => {\n const { t } = useTranslation();\n\n const { uploadImage, isUploading } = useProfileImageUpload({\n uploadConfig: {\n folder: \"Auth\",\n customMetadata: { appName: \"neetoAuth\" },\n },\n });\n\n const handleUploadImage = image =>\n new Promise(resolve => {\n uploadImage(image, uploadedImageData => {\n resolve(uploadedImageData);\n });\n });\n\n const { data: { user = {} } = {}, isFetching: isFetchingUserDetails } =\n useFetchProfile();\n\n const {\n firstName = \"\",\n lastName = \"\",\n phonenumber = \"\",\n dateFormat = DATE_FORMAT_OPTIONS[0].value,\n timeZone = \"\",\n profileImageUrl = \"\",\n countryId = \"\",\n timeFormat = TIME_FORMAT_OPTIONS[0].value,\n isOwner = false,\n timezoneChangeEnabled = true,\n language = \"\",\n } = user;\n\n const isTimezoneFieldDisabled = !isOwner && !timezoneChangeEnabled;\n const setFieldValueRef = useRef(null);\n\n const {\n countryDropdownOptions,\n selectedCountryOption,\n isFetchingCountriesList,\n handleCountryChange = noop,\n } = useCountries();\n\n const { mutate: updateProfile, isPending: isUpdatingProfile } =\n useUpdateProfileMutation();\n\n const timezoneRef = useCallback(\n node => {\n if (isNotNil(node)) {\n new NeetoTimezoneSelector(node, {\n isTimeFormat24H: timeFormat === \"24h\",\n className: \"w-full z-10\",\n position: \"bottom\",\n initialValue: timeZone,\n onChange: ({ main }) => setFieldValueRef.current(\"timeZone\", main),\n disabled: isTimezoneFieldDisabled,\n });\n }\n },\n [timeZone, timeFormat, isTimezoneFieldDisabled]\n );\n\n const initialFormValues = {\n firstName,\n lastName,\n phonenumber: phonenumber ?? \"\",\n timeZone,\n dateFormat,\n timeFormat,\n language,\n avatar: { imageUrl: profileImageUrl, file: null },\n };\n\n const handleSubmit = async values => {\n try {\n let avatar = {};\n\n if (values.avatar.file === \"_destroy\") {\n avatar = { fileId: \"_destroy\", filePath: \"\", url: \"\" };\n } else if (values.avatar.file) {\n const { fileId, filePath, url } = await handleUploadImage(\n values.avatar.file\n );\n avatar = { fileId, filePath, url };\n }\n\n const { countryId: updatedCountryId, ...rest } = values;\n\n const payload = {\n ...rest,\n avatar,\n countryIdentifier:\n updatedCountryId !== countryId ? updatedCountryId : undefined,\n };\n\n updateProfile({ id: user.id, payload });\n } catch (error) {\n Toastr.error(error.message);\n }\n };\n\n useEffect(() => {\n const country = findBy({ value: countryId }, countryDropdownOptions);\n if (country) {\n handleCountryChange(country);\n }\n }, [countryId, countryDropdownOptions, handleCountryChange]);\n\n if (isUpdatingProfile || isFetchingCountriesList || isFetchingUserDetails) {\n return (\n <div className=\"flex h-full w-full items-center justify-center\">\n <Spinner />\n </div>\n );\n }\n\n return (\n <Form\n formProps={{ \"data-testid\": \"ntm-profile-form\" }}\n formikProps={{\n initialValues: initialFormValues,\n validationSchema: PROFILE_VALIDATION_SCHEMA,\n onSubmit: handleSubmit,\n }}\n >\n {({ setFieldValue, errors, touched }) => {\n setFieldValueRef.current = setFieldValue;\n\n return (\n <>\n <Pane.Body className=\"w-full\">\n <div className=\"w-full pb-6\">\n <ProfileImage />\n <div className=\"neeto-ui-border-gray-200 mt-4 w-full space-y-4 border-t pt-4\">\n <Input\n autoFocus\n required\n data-testid=\"profile-first-name-text-field\"\n label={t(\"neetoTeamMembers.profile.inputs.label.firstName\")}\n name=\"firstName\"\n type=\"text\"\n placeholder={t(\n \"neetoTeamMembers.profile.inputs.placeholder.firstName\"\n )}\n />\n <Input\n required\n data-testid=\"profile-last-name-text-field\"\n label={t(\"neetoTeamMembers.profile.inputs.label.lastName\")}\n name=\"lastName\"\n type=\"text\"\n placeholder={t(\n \"neetoTeamMembers.profile.inputs.placeholder.lastName\"\n )}\n />\n <FormikPhoneNumberInput\n data-testid=\"profile-phonenumber-text-field\"\n name=\"phonenumber\"\n label={t(\n \"neetoTeamMembers.profile.inputs.label.phonenumber\"\n )}\n />\n </div>\n <div className=\"neeto-ui-border-gray-200 mt-4 w-full space-y-4 border-t pt-4\">\n <Select\n required\n data-testid=\"ntm-profile-country-select\"\n label={t(\"neetoTeamMembers.profile.inputs.label.country\")}\n name=\"countryId\"\n options={countryDropdownOptions}\n value={selectedCountryOption}\n onChange={option => {\n const dependentFields = handleCountryChange(option);\n setFieldValue(\"dateFormat\", dependentFields?.dateFormat);\n setFieldValue(\"countryId\", option?.value);\n }}\n />\n <div className=\"space-y-2\">\n <Select\n required\n data-testid=\"ntm-language-select\"\n name=\"language\"\n options={LANGUAGE_OPTIONS}\n label={t(\n \"neetoTeamMembers.profile.inputs.label.language\"\n )}\n onChange={option => {\n setFieldValue(\"language\", option.value);\n }}\n />\n </div>\n <div className=\"space-y-2\">\n <div className=\"space-y-2\">\n <Label required>\n {t(\"neetoTeamMembers.profile.inputs.label.timeZone\")}\n </Label>\n <div\n data-testid=\"ntm-profile-time-zone-select\"\n ref={timezoneRef}\n className={classNames(\"w-full grow\", {\n \"neeto-ui-bg-gray-100 pointer-events-none\":\n isTimezoneFieldDisabled,\n })}\n />\n </div>\n {touched.timeZone && errors.timeZone && (\n <Typography\n className=\"neeto-ui-text-error-800\"\n lineHeight=\"none\"\n style=\"body3\"\n >\n {errors.timeZone}\n </Typography>\n )}\n </div>\n <Select\n required\n data-testid=\"ntm-time-format-select\"\n name=\"timeFormat\"\n options={TIME_FORMAT_OPTIONS}\n label={t(\n \"neetoTeamMembers.profile.inputs.label.preferredTimeFormat\"\n )}\n onChange={option => {\n setFieldValue(\"timeFormat\", option.value);\n }}\n />\n <div className=\"space-y-2\">\n <Select\n required\n data-testid=\"ntm-date-format-select\"\n name=\"dateFormat\"\n options={DATE_FORMAT_OPTIONS}\n label={t(\n \"neetoTeamMembers.profile.inputs.label.preferredDateFormat\"\n )}\n onChange={option => {\n setFieldValue(\"dateFormat\", option.value);\n }}\n />\n </div>\n </div>\n </div>\n </Pane.Body>\n <Pane.Footer>\n <ActionBlock\n isSubmitting={isUpdatingProfile || isUploading}\n cancelButtonProps={{\n \"data-testid\": \"ntm-profile-cancel-button\",\n onClick: onClose,\n }}\n submitButtonProps={{\n \"data-testid\": \"ntm-profile-submit-button\",\n }}\n />\n </Pane.Footer>\n </>\n );\n }}\n </Form>\n );\n};\n\nexport default ChangeProfile;\n","/* eslint-disable @bigbinary/neeto/ensure-zustand-stores-are-type-annotated */\nimport withImmutableActions from \"neetocommons/react-utils/withImmutableActions\";\nimport { create } from \"zustand\";\nimport { shallow } from \"zustand/shallow\";\n\nconst useProfileUpdateStore = create(\n withImmutableActions(set => ({\n isOpen: false,\n\n setIsOpen: arg => {\n if (typeof arg === \"function\") {\n set(state => ({ isOpen: arg(state.isOpen) }));\n } else {\n set({ isOpen: arg });\n }\n },\n }))\n);\n\nconst useProfileUpdatePaneState = () =>\n useProfileUpdateStore(\n ({ isOpen, setIsOpen }) => [isOpen, setIsOpen],\n shallow\n );\n\nexport default useProfileUpdatePaneState;\n","import { is, isNil, trim } from \"ramda\";\n\nexport const sanitizeValue = (value, defaultValue) =>\n isNil(value) || (is(String, value) && trim(value) === \"\")\n ? defaultValue\n : value;\n","import { memo } from \"react\";\n\nimport { ianaTimezoneToHumanReadable } from \"@bigbinary/neeto-time-zones\";\nimport { _findBy } from \"neetocist\";\nimport { LANGUAGE_OPTIONS } from \"neetocommons/constants\";\nimport { globalProps } from \"neetocommons/initializers\";\nimport { Crown } from \"neetoicons\";\nimport CopyToClipboardButton from \"neetomolecules/CopyToClipboardButton\";\nimport { Avatar, Button, Pane, Spinner, Typography } from \"neetoui\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { DATE_FORMAT_OPTIONS, TIME_FORMAT_OPTIONS } from \"common/constants\";\nimport { useFetchProfile } from \"hooks/profile/useProfileApi\";\n\nimport { MANAGE_BILLING_PATH } from \"./constants\";\nimport { sanitizeValue } from \"./utils\";\n\nconst Preview = () => {\n const { t } = useTranslation();\n\n const { data: { user = {} } = {}, isFetching: isFetchingUserDetails } =\n useFetchProfile();\n\n const sanitizedUser = {\n countryName: sanitizeValue(user.countryName, \"-\"),\n dateFormat: sanitizeValue(user.dateFormat, \"\"),\n email: sanitizeValue(user.email, \"-\"),\n firstName: sanitizeValue(user.firstName, \"-\"),\n lastName: sanitizeValue(user.lastName, \"-\"),\n language: sanitizeValue(user.language, \"-\"),\n phonenumber: sanitizeValue(user.phonenumber, \"-\"),\n profileImageUrl: sanitizeValue(user.profileImageUrl, \"\"),\n timeFormat: sanitizeValue(user.timeFormat, \"\"),\n timeZone: sanitizeValue(user.timeZone, \"Etc/UTC\"),\n };\n\n const {\n countryName,\n dateFormat,\n email,\n firstName,\n lastName,\n language,\n phonenumber,\n profileImageUrl,\n timeFormat,\n timeZone,\n } = sanitizedUser;\n\n const name = `${firstName} ${lastName}`.trim();\n const subscription = sanitizeValue(\n globalProps.user?.subscriptionPlan,\n t(\"neetoTeamMembers.common.free\")\n );\n\n const isHour12 = (timeFormat || TIME_FORMAT_OPTIONS[0].value) === \"12h\";\n\n const time = new Intl.DateTimeFormat(\"en-US\", {\n timeZone,\n hour: \"2-digit\",\n minute: \"2-digit\",\n hour12: isHour12,\n }).format(new Date());\n\n const timeZoneAbbreviation = new Intl.DateTimeFormat(\"en-US\", {\n timeZone,\n timeZoneName: \"short\",\n })\n .formatToParts(new Date())\n .find(part => part.type === \"timeZoneName\")?.value;\n\n if (isFetchingUserDetails) {\n return (\n <div className=\"flex h-full w-full items-center justify-center\">\n <Spinner />\n </div>\n );\n }\n\n return (\n <Pane.Body className=\"neeto-ui-bg-gray-50 w-full\">\n <div className=\"flex w-full flex-col gap-2\">\n <div className=\"neeto-ui-bg-white neeto-ui-rounded-md p-3\">\n <div className=\"flex items-center gap-3\">\n <Avatar size=\"large\" user={{ name, imageUrl: profileImageUrl }} />\n <div className=\"flex flex-col\">\n <Typography\n data-testid=\"profile-full-name-field\"\n style=\"h4\"\n weight=\"semibold\"\n >\n {name}\n </Typography>\n <div className=\"flex items-center gap-1\">\n <Typography\n className=\"neeto-ui-text-gray-600\"\n data-testid=\"profile-email-field\"\n style=\"body3\"\n >\n {email}\n </Typography>\n <CopyToClipboardButton\n size=\"small\"\n style=\"text\"\n value={email}\n />\n </div>\n </div>\n </div>\n </div>\n <div className=\"neeto-ui-bg-white neeto-ui-rounded-md p-3 divide-y divide-gray-100\">\n <div className=\"flex flex-col gap-1 pb-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.firstName\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-first-name-field\"\n style=\"body2\"\n >\n {firstName}\n </Typography>\n </div>\n <div className=\"flex flex-col gap-1 py-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.lastName\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-last-name-field\"\n style=\"body2\"\n >\n {lastName}\n </Typography>\n </div>\n <div className=\"flex flex-col gap-1 py-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.profile.inputs.label.phonenumber\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-phonenumber-field\"\n style=\"body2\"\n >\n {phonenumber}\n </Typography>\n </div>\n <div className=\"flex flex-col gap-1 py-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.country\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-country-field\"\n style=\"body2\"\n >\n {countryName}\n </Typography>\n </div>\n <div className=\"flex flex-col gap-1 py-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.language\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-preferred-language-field\"\n style=\"body2\"\n >\n {_findBy({ value: language }, LANGUAGE_OPTIONS)?.label || \"-\"}\n </Typography>\n </div>\n <div className=\"flex flex-col gap-1 py-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.timeZone\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-time-zone-field\"\n style=\"body2\"\n >\n {ianaTimezoneToHumanReadable(timeZone)}\n {timeZoneAbbreviation ? ` (${timeZoneAbbreviation})` : \"\"} {time}\n </Typography>\n </div>\n <div className=\"flex flex-col gap-1 py-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.preferredTimeFormat\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-preferred-time-format-field\"\n style=\"body2\"\n >\n {_findBy({ value: timeFormat }, TIME_FORMAT_OPTIONS)?.label ||\n \"-\"}\n </Typography>\n </div>\n <div className=\"flex flex-col gap-1 pt-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.preferredDateFormat\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-preferred-date-format-field\"\n style=\"body2\"\n >\n {_findBy({ value: dateFormat }, DATE_FORMAT_OPTIONS)?.label ||\n \"-\"}\n </Typography>\n </div>\n </div>\n <div className=\"neeto-ui-bg-white neeto-ui-rounded-md p-3\">\n <div className=\"flex items-center justify-between\">\n <div className=\"flex flex-col gap-1\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.currentPlan\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-subscription-type\"\n style=\"body2\"\n >\n {t(\"neetoTeamMembers.common.subscriptionType\", {\n subscription,\n })}\n </Typography>\n </div>\n <Button\n className=\"neeto-ui-rounded-full\"\n data-testid=\"profile-upgrade-button\"\n href={MANAGE_BILLING_PATH}\n icon={Crown}\n iconPosition=\"left\"\n label={t(\"neetoTeamMembers.buttons.upgrade\")}\n size=\"small\"\n style=\"primary\"\n />\n </div>\n </div>\n </div>\n </Pane.Body>\n );\n};\n\nexport default memo(Preview);\n","import { useState } from \"react\";\n\nimport { MenuHorizontal } from \"neetoicons\";\nimport { Dropdown, Pane, Typography } from \"neetoui\";\nimport { useTranslation } from \"react-i18next\";\n\nimport ChangeProfile from \"./ChangeProfile\";\nimport { MANAGE_BILLING_PATH, UPDATE_EMAIL_PATH } from \"./constants\";\nimport useProfileUpdatePaneState from \"./hooks/useProfileUpdatePane\";\nimport Preview from \"./Preview\";\nimport \"./styles.scss\";\n\nconst { Menu, MenuItem } = Dropdown;\n\nconst Profile = () => {\n const { t } = useTranslation();\n\n const [isOpen, setIsOpen] = useProfileUpdatePaneState();\n const [isEditMode, setIsEditMode] = useState(false);\n\n const onClose = () => {\n setIsOpen(false);\n setIsEditMode(false);\n };\n\n const enableEditMode = () => setIsEditMode(true);\n\n return (\n <div className=\"w-full\">\n <Pane {...{ isOpen, onClose }} className=\"neeto-ui-bg-gray-50 max-w-96\">\n <Pane.Header className=\"neeto-ui-bg-gray-50\">\n <div className=\"flex justify-between\">\n <Typography style=\"h2\" weight=\"semibold\">\n {t(\"neetoTeamMembers.profile.common.myProfile\")}\n </Typography>\n {!isEditMode && (\n <Dropdown buttonStyle=\"text\" icon={MenuHorizontal}>\n <Menu>\n <MenuItem.Button\n data-testid=\"edit-basic-info-menu-button\"\n onClick={enableEditMode}\n >\n {t(\"neetoTeamMembers.buttons.editBasicInfo\")}\n </MenuItem.Button>\n <MenuItem.Button\n data-testid=\"update-email-menu-button\"\n href={UPDATE_EMAIL_PATH}\n >\n {t(\"neetoTeamMembers.buttons.updateEmail\")}\n </MenuItem.Button>\n <MenuItem.Button\n data-testid=\"manage-billing-subscriptions-menu-button\"\n href={MANAGE_BILLING_PATH}\n >\n {t(\n \"neetoTeamMembers.buttons.manageBillingAndSubscriptions\"\n )}\n </MenuItem.Button>\n </Menu>\n </Dropdown>\n )}\n </div>\n </Pane.Header>\n {isEditMode ? <ChangeProfile {...{ onClose }} /> : <Preview />}\n </Pane>\n </div>\n );\n};\n\nexport default {\n Pane: Profile,\n usePaneState: useProfileUpdatePaneState,\n};\n"],"names":["ChangeProfile","_ref","onClose","_useTranslation","useTranslation","t","_useProfileImageUploa","useProfileImageUpload","uploadConfig","folder","customMetadata","appName","uploadImage","isUploading","handleUploadImage","image","Promise","resolve","uploadedImageData","_useFetchProfile","useFetchProfile","_useFetchProfile$data","data","_useFetchProfile$data2","_useFetchProfile$data3","user","isFetchingUserDetails","isFetching","_user$firstName","firstName","_user$lastName","lastName","_user$phonenumber","phonenumber","_user$dateFormat","dateFormat","DATE_FORMAT_OPTIONS","value","_user$timeZone","timeZone","_user$profileImageUrl","profileImageUrl","_user$countryId","countryId","_user$timeFormat","timeFormat","TIME_FORMAT_OPTIONS","_user$isOwner","isOwner","_user$timezoneChangeE","timezoneChangeEnabled","_user$language","language","isTimezoneFieldDisabled","setFieldValueRef","useRef","_useCountries","useCountries","countryDropdownOptions","selectedCountryOption","isFetchingCountriesList","_useCountries$handleC","handleCountryChange","noop","_useUpdateProfileMuta","useUpdateProfileMutation","updateProfile","mutate","isUpdatingProfile","isPending","timezoneRef","useCallback","node","isNotNil","NeetoTimezoneSelector","isTimeFormat24H","className","position","initialValue","onChange","_ref2","main","current","disabled","initialFormValues","avatar","imageUrl","file","handleSubmit","_ref3","_asyncToGenerator","_regeneratorRuntime","mark","_callee","values","_yield$handleUploadIm","fileId","filePath","url","updatedCountryId","rest","payload","wrap","_callee$","_context","prev","next","sent","_objectWithoutProperties","_excluded","_objectSpread","countryIdentifier","undefined","id","t0","Toastr","error","message","stop","_x","apply","arguments","useEffect","country","findBy","_jsx","children","Spinner","Form","formProps","formikProps","initialValues","validationSchema","PROFILE_VALIDATION_SCHEMA","onSubmit","_ref4","setFieldValue","errors","touched","_jsxs","_Fragment","Pane","Body","ProfileImage","Input","autoFocus","required","label","name","type","placeholder","FormikPhoneNumberInput","Select","options","option","dependentFields","LANGUAGE_OPTIONS","Label","ref","classNames","Typography","lineHeight","style","Footer","ActionBlock","isSubmitting","cancelButtonProps","onClick","submitButtonProps","useProfileUpdateStore","create","withImmutableActions","set","isOpen","setIsOpen","arg","state","useProfileUpdatePaneState","shallow","sanitizeValue","defaultValue","isNil","is","String","trim","Preview","_globalProps$user","_Intl$DateTimeFormat$","_findBy2","_findBy3","_findBy4","sanitizedUser","countryName","email","concat","subscription","globalProps","subscriptionPlan","isHour12","time","Intl","DateTimeFormat","hour","minute","hour12","format","Date","timeZoneAbbreviation","timeZoneName","formatToParts","find","part","Avatar","size","weight","CopyToClipboardButton","_findBy","ianaTimezoneToHumanReadable","Button","href","MANAGE_BILLING_PATH","icon","Crown","iconPosition","memo","Menu","Dropdown","MenuItem","Profile","_useProfileUpdatePane","_useProfileUpdatePane2","_slicedToArray","_useState","useState","_useState2","isEditMode","setIsEditMode","enableEditMode","Header","buttonStyle","MenuHorizontal","UPDATE_EMAIL_PATH","usePaneState"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Profile.js","sources":["../app/javascript/src/components/Profile/ChangeProfile.jsx","../app/javascript/src/components/Profile/hooks/useProfileUpdatePane.js","../app/javascript/src/components/Profile/utils.js","../app/javascript/src/components/Profile/Preview.jsx","../app/javascript/src/components/Profile/index.jsx"],"sourcesContent":["import { useCallback, useEffect, useRef } from \"react\";\n\nimport { NeetoTimezoneSelector } from \"@bigbinary/neeto-time-zones\";\nimport { findBy, noop } from \"neetocist\";\nimport { LANGUAGE_OPTIONS } from \"neetocommons/constants\";\nimport { useProfileImageUpload } from \"neetoimageuploader\";\nimport { FormikPhoneNumberInput } from \"neetomolecules/PhoneNumber\";\nimport { Label, Pane, Spinner, Toastr, Typography } from \"neetoui\";\nimport { Input, Select, Form, ActionBlock } from \"neetoui/formik\";\nimport { isNotNil } from \"ramda\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { DATE_FORMAT_OPTIONS, TIME_FORMAT_OPTIONS } from \"common/constants\";\nimport {\n useUpdateProfileMutation,\n useFetchProfile,\n} from \"hooks/profile/useProfileApi\";\n\nimport { PROFILE_VALIDATION_SCHEMA } from \"./constants\";\nimport useCountries from \"./hooks/useCountries\";\nimport ProfileImage from \"./ProfileImage\";\n\nconst ChangeProfile = ({ onClose }) => {\n const { t } = useTranslation();\n\n const { uploadImage, isUploading } = useProfileImageUpload({\n uploadConfig: {\n folder: \"Auth\",\n customMetadata: { appName: \"neetoAuth\" },\n },\n });\n\n const handleUploadImage = image =>\n new Promise(resolve => {\n uploadImage(image, uploadedImageData => {\n resolve(uploadedImageData);\n });\n });\n\n const { data: { user = {} } = {}, isFetching: isFetchingUserDetails } =\n useFetchProfile();\n\n const {\n firstName = \"\",\n lastName = \"\",\n phonenumber = \"\",\n dateFormat = DATE_FORMAT_OPTIONS[0].value,\n timeZone = \"\",\n profileImageUrl = \"\",\n countryId = \"\",\n timeFormat = TIME_FORMAT_OPTIONS[0].value,\n language = \"\",\n } = user;\n\n const setFieldValueRef = useRef(null);\n\n const {\n countryDropdownOptions,\n selectedCountryOption,\n isFetchingCountriesList,\n handleCountryChange = noop,\n } = useCountries();\n\n const { mutate: updateProfile, isPending: isUpdatingProfile } =\n useUpdateProfileMutation();\n\n const timezoneRef = useCallback(\n node => {\n if (isNotNil(node)) {\n new NeetoTimezoneSelector(node, {\n isTimeFormat24H: timeFormat === \"24h\",\n className: \"w-full z-10\",\n position: \"bottom\",\n initialValue: timeZone,\n onChange: ({ main }) => setFieldValueRef.current(\"timeZone\", main),\n });\n }\n },\n [timeZone, timeFormat]\n );\n\n const initialFormValues = {\n firstName,\n lastName,\n phonenumber: phonenumber ?? \"\",\n timeZone,\n dateFormat,\n timeFormat,\n language,\n avatar: { imageUrl: profileImageUrl, file: null },\n };\n\n const handleSubmit = async values => {\n try {\n let avatar = {};\n\n if (values.avatar.file === \"_destroy\") {\n avatar = { fileId: \"_destroy\", filePath: \"\", url: \"\" };\n } else if (values.avatar.file) {\n const { fileId, filePath, url } = await handleUploadImage(\n values.avatar.file\n );\n avatar = { fileId, filePath, url };\n }\n\n const { countryId: updatedCountryId, ...rest } = values;\n\n const payload = {\n ...rest,\n avatar,\n countryIdentifier:\n updatedCountryId !== countryId ? updatedCountryId : undefined,\n };\n\n updateProfile({ id: user.id, payload });\n } catch (error) {\n Toastr.error(error.message);\n }\n };\n\n useEffect(() => {\n const country = findBy({ value: countryId }, countryDropdownOptions);\n if (country) {\n handleCountryChange(country);\n }\n }, [countryId, countryDropdownOptions, handleCountryChange]);\n\n if (isUpdatingProfile || isFetchingCountriesList || isFetchingUserDetails) {\n return (\n <div className=\"flex h-full w-full items-center justify-center\">\n <Spinner />\n </div>\n );\n }\n\n return (\n <Form\n formProps={{ \"data-testid\": \"ntm-profile-form\" }}\n formikProps={{\n initialValues: initialFormValues,\n validationSchema: PROFILE_VALIDATION_SCHEMA,\n onSubmit: handleSubmit,\n }}\n >\n {({ setFieldValue, errors, touched }) => {\n setFieldValueRef.current = setFieldValue;\n\n return (\n <>\n <Pane.Body className=\"w-full\">\n <div className=\"w-full pb-6\">\n <ProfileImage />\n <div className=\"neeto-ui-border-gray-200 mt-4 w-full space-y-4 border-t pt-4\">\n <Input\n autoFocus\n required\n data-testid=\"profile-first-name-text-field\"\n label={t(\"neetoTeamMembers.profile.inputs.label.firstName\")}\n name=\"firstName\"\n type=\"text\"\n placeholder={t(\n \"neetoTeamMembers.profile.inputs.placeholder.firstName\"\n )}\n />\n <Input\n required\n data-testid=\"profile-last-name-text-field\"\n label={t(\"neetoTeamMembers.profile.inputs.label.lastName\")}\n name=\"lastName\"\n type=\"text\"\n placeholder={t(\n \"neetoTeamMembers.profile.inputs.placeholder.lastName\"\n )}\n />\n <FormikPhoneNumberInput\n data-testid=\"profile-phonenumber-text-field\"\n name=\"phonenumber\"\n label={t(\n \"neetoTeamMembers.profile.inputs.label.phonenumber\"\n )}\n />\n </div>\n <div className=\"neeto-ui-border-gray-200 mt-4 w-full space-y-4 border-t pt-4\">\n <Select\n required\n data-testid=\"ntm-profile-country-select\"\n label={t(\"neetoTeamMembers.profile.inputs.label.country\")}\n name=\"countryId\"\n options={countryDropdownOptions}\n value={selectedCountryOption}\n onChange={option => {\n const dependentFields = handleCountryChange(option);\n setFieldValue(\"dateFormat\", dependentFields?.dateFormat);\n setFieldValue(\"countryId\", option?.value);\n }}\n />\n <div className=\"space-y-2\">\n <Select\n required\n data-testid=\"ntm-language-select\"\n name=\"language\"\n options={LANGUAGE_OPTIONS}\n label={t(\n \"neetoTeamMembers.profile.inputs.label.language\"\n )}\n onChange={option => {\n setFieldValue(\"language\", option.value);\n }}\n />\n </div>\n <div className=\"space-y-2\">\n <div className=\"space-y-2\">\n <Label required>\n {t(\"neetoTeamMembers.profile.inputs.label.timeZone\")}\n </Label>\n <div\n className=\"w-full grow\"\n data-testid=\"ntm-profile-time-zone-select\"\n ref={timezoneRef}\n />\n </div>\n {touched.timeZone && errors.timeZone && (\n <Typography\n className=\"neeto-ui-text-error-800\"\n lineHeight=\"none\"\n style=\"body3\"\n >\n {errors.timeZone}\n </Typography>\n )}\n </div>\n <Select\n required\n data-testid=\"ntm-time-format-select\"\n name=\"timeFormat\"\n options={TIME_FORMAT_OPTIONS}\n label={t(\n \"neetoTeamMembers.profile.inputs.label.preferredTimeFormat\"\n )}\n onChange={option => {\n setFieldValue(\"timeFormat\", option.value);\n }}\n />\n <div className=\"space-y-2\">\n <Select\n required\n data-testid=\"ntm-date-format-select\"\n name=\"dateFormat\"\n options={DATE_FORMAT_OPTIONS}\n label={t(\n \"neetoTeamMembers.profile.inputs.label.preferredDateFormat\"\n )}\n onChange={option => {\n setFieldValue(\"dateFormat\", option.value);\n }}\n />\n </div>\n </div>\n </div>\n </Pane.Body>\n <Pane.Footer>\n <ActionBlock\n isSubmitting={isUpdatingProfile || isUploading}\n cancelButtonProps={{\n \"data-testid\": \"ntm-profile-cancel-button\",\n onClick: onClose,\n }}\n submitButtonProps={{\n \"data-testid\": \"ntm-profile-submit-button\",\n }}\n />\n </Pane.Footer>\n </>\n );\n }}\n </Form>\n );\n};\n\nexport default ChangeProfile;\n","/* eslint-disable @bigbinary/neeto/ensure-zustand-stores-are-type-annotated */\nimport withImmutableActions from \"neetocommons/react-utils/withImmutableActions\";\nimport { create } from \"zustand\";\nimport { shallow } from \"zustand/shallow\";\n\nconst useProfileUpdateStore = create(\n withImmutableActions(set => ({\n isOpen: false,\n\n setIsOpen: arg => {\n if (typeof arg === \"function\") {\n set(state => ({ isOpen: arg(state.isOpen) }));\n } else {\n set({ isOpen: arg });\n }\n },\n }))\n);\n\nconst useProfileUpdatePaneState = () =>\n useProfileUpdateStore(\n ({ isOpen, setIsOpen }) => [isOpen, setIsOpen],\n shallow\n );\n\nexport default useProfileUpdatePaneState;\n","import { is, isNil, trim } from \"ramda\";\n\nexport const sanitizeValue = (value, defaultValue) =>\n isNil(value) || (is(String, value) && trim(value) === \"\")\n ? defaultValue\n : value;\n","import { memo } from \"react\";\n\nimport { ianaTimezoneToHumanReadable } from \"@bigbinary/neeto-time-zones\";\nimport { _findBy } from \"neetocist\";\nimport { LANGUAGE_OPTIONS } from \"neetocommons/constants\";\nimport { globalProps } from \"neetocommons/initializers\";\nimport { Crown } from \"neetoicons\";\nimport CopyToClipboardButton from \"neetomolecules/CopyToClipboardButton\";\nimport { Avatar, Button, Pane, Spinner, Typography } from \"neetoui\";\nimport { useTranslation } from \"react-i18next\";\n\nimport { DATE_FORMAT_OPTIONS, TIME_FORMAT_OPTIONS } from \"common/constants\";\nimport { useFetchProfile } from \"hooks/profile/useProfileApi\";\n\nimport { MANAGE_BILLING_PATH } from \"./constants\";\nimport { sanitizeValue } from \"./utils\";\n\nconst Preview = () => {\n const { t } = useTranslation();\n\n const { data: { user = {} } = {}, isFetching: isFetchingUserDetails } =\n useFetchProfile();\n\n const sanitizedUser = {\n countryName: sanitizeValue(user.countryName, \"-\"),\n dateFormat: sanitizeValue(user.dateFormat, \"\"),\n email: sanitizeValue(user.email, \"-\"),\n firstName: sanitizeValue(user.firstName, \"-\"),\n lastName: sanitizeValue(user.lastName, \"-\"),\n language: sanitizeValue(user.language, \"-\"),\n phonenumber: sanitizeValue(user.phonenumber, \"-\"),\n profileImageUrl: sanitizeValue(user.profileImageUrl, \"\"),\n timeFormat: sanitizeValue(user.timeFormat, \"\"),\n timeZone: sanitizeValue(user.timeZone, \"Etc/UTC\"),\n };\n\n const {\n countryName,\n dateFormat,\n email,\n firstName,\n lastName,\n language,\n phonenumber,\n profileImageUrl,\n timeFormat,\n timeZone,\n } = sanitizedUser;\n\n const name = `${firstName} ${lastName}`.trim();\n const subscription = sanitizeValue(\n globalProps.user?.subscriptionPlan,\n t(\"neetoTeamMembers.common.free\")\n );\n\n const isHour12 = (timeFormat || TIME_FORMAT_OPTIONS[0].value) === \"12h\";\n\n const time = new Intl.DateTimeFormat(\"en-US\", {\n timeZone,\n hour: \"2-digit\",\n minute: \"2-digit\",\n hour12: isHour12,\n }).format(new Date());\n\n const timeZoneAbbreviation = new Intl.DateTimeFormat(\"en-US\", {\n timeZone,\n timeZoneName: \"short\",\n })\n .formatToParts(new Date())\n .find(part => part.type === \"timeZoneName\")?.value;\n\n if (isFetchingUserDetails) {\n return (\n <div className=\"flex h-full w-full items-center justify-center\">\n <Spinner />\n </div>\n );\n }\n\n return (\n <Pane.Body className=\"neeto-ui-bg-gray-50 w-full\">\n <div className=\"flex w-full flex-col gap-2\">\n <div className=\"neeto-ui-bg-white neeto-ui-rounded-md p-3\">\n <div className=\"flex items-center gap-3\">\n <Avatar size=\"large\" user={{ name, imageUrl: profileImageUrl }} />\n <div className=\"flex flex-col\">\n <Typography\n data-testid=\"profile-full-name-field\"\n style=\"h4\"\n weight=\"semibold\"\n >\n {name}\n </Typography>\n <div className=\"flex items-center gap-1\">\n <Typography\n className=\"neeto-ui-text-gray-600\"\n data-testid=\"profile-email-field\"\n style=\"body3\"\n >\n {email}\n </Typography>\n <CopyToClipboardButton\n size=\"small\"\n style=\"text\"\n value={email}\n />\n </div>\n </div>\n </div>\n </div>\n <div className=\"neeto-ui-bg-white neeto-ui-rounded-md p-3 divide-y divide-gray-100\">\n <div className=\"flex flex-col gap-1 pb-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.firstName\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-first-name-field\"\n style=\"body2\"\n >\n {firstName}\n </Typography>\n </div>\n <div className=\"flex flex-col gap-1 py-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.lastName\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-last-name-field\"\n style=\"body2\"\n >\n {lastName}\n </Typography>\n </div>\n <div className=\"flex flex-col gap-1 py-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.profile.inputs.label.phonenumber\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-phonenumber-field\"\n style=\"body2\"\n >\n {phonenumber}\n </Typography>\n </div>\n <div className=\"flex flex-col gap-1 py-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.country\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-country-field\"\n style=\"body2\"\n >\n {countryName}\n </Typography>\n </div>\n <div className=\"flex flex-col gap-1 py-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.language\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-preferred-language-field\"\n style=\"body2\"\n >\n {_findBy({ value: language }, LANGUAGE_OPTIONS)?.label || \"-\"}\n </Typography>\n </div>\n <div className=\"flex flex-col gap-1 py-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.timeZone\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-time-zone-field\"\n style=\"body2\"\n >\n {ianaTimezoneToHumanReadable(timeZone)}\n {timeZoneAbbreviation ? ` (${timeZoneAbbreviation})` : \"\"} {time}\n </Typography>\n </div>\n <div className=\"flex flex-col gap-1 py-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.preferredTimeFormat\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-preferred-time-format-field\"\n style=\"body2\"\n >\n {_findBy({ value: timeFormat }, TIME_FORMAT_OPTIONS)?.label ||\n \"-\"}\n </Typography>\n </div>\n <div className=\"flex flex-col gap-1 pt-3\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.preferredDateFormat\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-preferred-date-format-field\"\n style=\"body2\"\n >\n {_findBy({ value: dateFormat }, DATE_FORMAT_OPTIONS)?.label ||\n \"-\"}\n </Typography>\n </div>\n </div>\n <div className=\"neeto-ui-bg-white neeto-ui-rounded-md p-3\">\n <div className=\"flex items-center justify-between\">\n <div className=\"flex flex-col gap-1\">\n <Typography\n className=\"neeto-ui-text-gray-500\"\n style=\"body3\"\n weight=\"medium\"\n >\n {t(\"neetoTeamMembers.labels.currentPlan\")}\n </Typography>\n <Typography\n className=\"neeto-ui-text-black profile-preview-value\"\n data-testid=\"profile-subscription-type\"\n style=\"body2\"\n >\n {t(\"neetoTeamMembers.common.subscriptionType\", {\n subscription,\n })}\n </Typography>\n </div>\n <Button\n className=\"neeto-ui-rounded-full\"\n data-testid=\"profile-upgrade-button\"\n href={MANAGE_BILLING_PATH}\n icon={Crown}\n iconPosition=\"left\"\n label={t(\"neetoTeamMembers.buttons.upgrade\")}\n size=\"small\"\n style=\"primary\"\n />\n </div>\n </div>\n </div>\n </Pane.Body>\n );\n};\n\nexport default memo(Preview);\n","import { useState } from \"react\";\n\nimport { MenuHorizontal } from \"neetoicons\";\nimport { Dropdown, Pane, Typography } from \"neetoui\";\nimport { useTranslation } from \"react-i18next\";\n\nimport ChangeProfile from \"./ChangeProfile\";\nimport { MANAGE_BILLING_PATH, UPDATE_EMAIL_PATH } from \"./constants\";\nimport useProfileUpdatePaneState from \"./hooks/useProfileUpdatePane\";\nimport Preview from \"./Preview\";\nimport \"./styles.scss\";\n\nconst { Menu, MenuItem } = Dropdown;\n\nconst Profile = () => {\n const { t } = useTranslation();\n\n const [isOpen, setIsOpen] = useProfileUpdatePaneState();\n const [isEditMode, setIsEditMode] = useState(false);\n\n const onClose = () => {\n setIsOpen(false);\n setIsEditMode(false);\n };\n\n const enableEditMode = () => setIsEditMode(true);\n\n return (\n <div className=\"w-full\">\n <Pane {...{ isOpen, onClose }} className=\"neeto-ui-bg-gray-50 max-w-96\">\n <Pane.Header className=\"neeto-ui-bg-gray-50\">\n <div className=\"flex justify-between\">\n <Typography style=\"h2\" weight=\"semibold\">\n {t(\"neetoTeamMembers.profile.common.myProfile\")}\n </Typography>\n {!isEditMode && (\n <Dropdown buttonStyle=\"text\" icon={MenuHorizontal}>\n <Menu>\n <MenuItem.Button\n data-testid=\"edit-basic-info-menu-button\"\n onClick={enableEditMode}\n >\n {t(\"neetoTeamMembers.buttons.editBasicInfo\")}\n </MenuItem.Button>\n <MenuItem.Button\n data-testid=\"update-email-menu-button\"\n href={UPDATE_EMAIL_PATH}\n >\n {t(\"neetoTeamMembers.buttons.updateEmail\")}\n </MenuItem.Button>\n <MenuItem.Button\n data-testid=\"manage-billing-subscriptions-menu-button\"\n href={MANAGE_BILLING_PATH}\n >\n {t(\n \"neetoTeamMembers.buttons.manageBillingAndSubscriptions\"\n )}\n </MenuItem.Button>\n </Menu>\n </Dropdown>\n )}\n </div>\n </Pane.Header>\n {isEditMode ? <ChangeProfile {...{ onClose }} /> : <Preview />}\n </Pane>\n </div>\n );\n};\n\nexport default {\n Pane: Profile,\n usePaneState: useProfileUpdatePaneState,\n};\n"],"names":["ChangeProfile","_ref","onClose","_useTranslation","useTranslation","t","_useProfileImageUploa","useProfileImageUpload","uploadConfig","folder","customMetadata","appName","uploadImage","isUploading","handleUploadImage","image","Promise","resolve","uploadedImageData","_useFetchProfile","useFetchProfile","_useFetchProfile$data","data","_useFetchProfile$data2","_useFetchProfile$data3","user","isFetchingUserDetails","isFetching","_user$firstName","firstName","_user$lastName","lastName","_user$phonenumber","phonenumber","_user$dateFormat","dateFormat","DATE_FORMAT_OPTIONS","value","_user$timeZone","timeZone","_user$profileImageUrl","profileImageUrl","_user$countryId","countryId","_user$timeFormat","timeFormat","TIME_FORMAT_OPTIONS","_user$language","language","setFieldValueRef","useRef","_useCountries","useCountries","countryDropdownOptions","selectedCountryOption","isFetchingCountriesList","_useCountries$handleC","handleCountryChange","noop","_useUpdateProfileMuta","useUpdateProfileMutation","updateProfile","mutate","isUpdatingProfile","isPending","timezoneRef","useCallback","node","isNotNil","NeetoTimezoneSelector","isTimeFormat24H","className","position","initialValue","onChange","_ref2","main","current","initialFormValues","avatar","imageUrl","file","handleSubmit","_ref3","_asyncToGenerator","_regeneratorRuntime","mark","_callee","values","_yield$handleUploadIm","fileId","filePath","url","updatedCountryId","rest","payload","wrap","_callee$","_context","prev","next","sent","_objectWithoutProperties","_excluded","_objectSpread","countryIdentifier","undefined","id","t0","Toastr","error","message","stop","_x","apply","arguments","useEffect","country","findBy","_jsx","children","Spinner","Form","formProps","formikProps","initialValues","validationSchema","PROFILE_VALIDATION_SCHEMA","onSubmit","_ref4","setFieldValue","errors","touched","_jsxs","_Fragment","Pane","Body","ProfileImage","Input","autoFocus","required","label","name","type","placeholder","FormikPhoneNumberInput","Select","options","option","dependentFields","LANGUAGE_OPTIONS","Label","ref","Typography","lineHeight","style","Footer","ActionBlock","isSubmitting","cancelButtonProps","onClick","submitButtonProps","useProfileUpdateStore","create","withImmutableActions","set","isOpen","setIsOpen","arg","state","useProfileUpdatePaneState","shallow","sanitizeValue","defaultValue","isNil","is","String","trim","Preview","_globalProps$user","_Intl$DateTimeFormat$","_findBy2","_findBy3","_findBy4","sanitizedUser","countryName","email","concat","subscription","globalProps","subscriptionPlan","isHour12","time","Intl","DateTimeFormat","hour","minute","hour12","format","Date","timeZoneAbbreviation","timeZoneName","formatToParts","find","part","Avatar","size","weight","CopyToClipboardButton","_findBy","ianaTimezoneToHumanReadable","Button","href","MANAGE_BILLING_PATH","icon","Crown","iconPosition","memo","Menu","Dropdown","MenuItem","Profile","_useProfileUpdatePane","_useProfileUpdatePane2","_slicedToArray","_useState","useState","_useState2","isEditMode","setIsEditMode","enableEditMode","Header","buttonStyle","MenuHorizontal","UPDATE_EMAIL_PATH","usePaneState"],"mappings":"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"}
|
|
@@ -99,7 +99,7 @@ var ProfileImage = function ProfileImage() {
|
|
|
99
99
|
}
|
|
100
100
|
}), /*#__PURE__*/jsxRuntime.jsx(neetoAtoms.DropdownMenu, {
|
|
101
101
|
customTarget: /*#__PURE__*/jsxRuntime.jsx(neetoAtoms.Button, {
|
|
102
|
-
className: "absolute -bottom-1 -right-1
|
|
102
|
+
className: "absolute -bottom-1 -right-1 rounded-full",
|
|
103
103
|
icon: lucideReact.Pencil,
|
|
104
104
|
size: "icon-xs",
|
|
105
105
|
variant: "outline",
|
|
@@ -133,4 +133,4 @@ var ProfileImage = function ProfileImage() {
|
|
|
133
133
|
|
|
134
134
|
exports.ProfileImage = ProfileImage;
|
|
135
135
|
exports.useCountries = useCountries;
|
|
136
|
-
//# sourceMappingURL=ProfileImage-
|
|
136
|
+
//# sourceMappingURL=ProfileImage-BjDA-txF.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProfileImage-BjDA-txF.js","sources":["../app/javascript/src/v2/components/Profile/hooks/useCountries.js","../app/javascript/src/v2/components/Profile/ProfileImage.jsx"],"sourcesContent":["import { useCallback, useMemo, useState } from \"react\";\n\nimport { findById } from \"neetocist\";\n\nimport { useFetchCountries } from \"hooks/profile/useCountriesApi\";\n\nconst useCountries = () => {\n const [selectedCountryOption, setSelectedCountryOption] = useState(null);\n\n const { data: { countries = [] } = {}, isLoading } = useFetchCountries();\n\n const formatCountryOption = country => ({\n label: country?.name,\n value: country?.id,\n });\n\n const countryDropdownOptions = useMemo(\n () => countries.map(formatCountryOption),\n [countries]\n );\n\n const handleCountryChange = useCallback(\n countryOption => {\n setSelectedCountryOption(countryOption);\n\n const dependentFields = {};\n const selectedCountry = findById(countryOption.value, countries);\n\n dependentFields.dateFormat = selectedCountry.dateFormat;\n\n return dependentFields;\n },\n [countries]\n );\n\n return {\n countryDropdownOptions,\n selectedCountryOption,\n isFetchingCountriesList: isLoading,\n handleCountryChange,\n };\n};\n\nexport default useCountries;\n","/* eslint-disable @bigbinary/neeto/no-missing-localization */\n// v2 ProfileImage — placeholder, full implementation in Phase 3.5\n// Used by ManageMember for member avatar editing\nimport { useRef } from \"react\";\n\nimport { Avatar, Button, DropdownMenu } from \"@bigbinary/neeto-atoms\";\nimport { useField } from \"formik\";\nimport { Pencil } from \"lucide-react\";\nimport { globalProps } from \"neetocommons/v2/initializers\";\nimport { useTranslation } from \"react-i18next\";\nimport { toast } from \"sonner\";\n\nconst ProfileImage = () => {\n const { t } = useTranslation();\n const [field, , helpers] = useField(\"avatar\");\n const fileInputRef = useRef(null);\n\n const { imageUrl, file } = field.value || {};\n const displayUrl =\n file && file !== \"_destroy\" ? URL.createObjectURL(file) : imageUrl;\n\n const handleFileSelect = event => {\n const selectedFile = event.target.files[0];\n if (!selectedFile) return;\n\n const maxSize = 5 * 1024 * 1024;\n if (selectedFile.size > maxSize) {\n toast.error(\n t(\n \"neetoTeamMembers.common.fileSizeTooLarge\",\n \"File size must be less than 5MB\"\n )\n );\n\n return;\n }\n\n helpers.setValue({ imageUrl, file: selectedFile });\n };\n\n const handleRemove = () => {\n helpers.setValue({ imageUrl: \"\", file: \"_destroy\" });\n };\n\n return (\n <div className=\"flex items-center gap-4\">\n <div className=\"relative\">\n <Avatar\n size=\"xl\"\n user={{\n name: globalProps.user?.name,\n imageUrl: displayUrl,\n }}\n />\n <DropdownMenu\n customTarget={\n <Button\n className=\"absolute -bottom-1 -right-1 rounded-full\"\n icon={Pencil}\n size=\"icon-xs\"\n variant=\"outline\"\n aria-label={t(\n \"neetoTeamMembers.common.changeProfileImage\",\n \"Change profile image\"\n )}\n />\n }\n >\n <DropdownMenu.Menu>\n <DropdownMenu.MenuItem\n data-testid=\"profile-image-upload-button\"\n onClick={() => fileInputRef.current?.click()}\n >\n {t(\"neetoTeamMembers.common.upload\", \"Upload\")}\n </DropdownMenu.MenuItem>\n {displayUrl && (\n <DropdownMenu.MenuItem\n data-testid=\"profile-image-remove-button\"\n onClick={handleRemove}\n >\n {t(\"neetoTeamMembers.common.remove\")}\n </DropdownMenu.MenuItem>\n )}\n </DropdownMenu.Menu>\n </DropdownMenu>\n </div>\n <input\n accept=\"image/*\"\n className=\"hidden\"\n data-testid=\"profile-image-upload-file-field\"\n ref={fileInputRef}\n type=\"file\"\n onChange={handleFileSelect}\n />\n </div>\n );\n};\n\nexport default ProfileImage;\n"],"names":["useCountries","_useState","useState","_useState2","_slicedToArray","selectedCountryOption","setSelectedCountryOption","_useFetchCountries","useFetchCountries","_useFetchCountries$da","data","_useFetchCountries$da2","_useFetchCountries$da3","countries","isLoading","formatCountryOption","country","label","name","value","id","countryDropdownOptions","useMemo","map","handleCountryChange","useCallback","countryOption","dependentFields","selectedCountry","findById","dateFormat","isFetchingCountriesList","ProfileImage","_globalProps$user","_useTranslation","useTranslation","t","_useField","useField","_useField2","field","helpers","fileInputRef","useRef","_ref","imageUrl","file","displayUrl","URL","createObjectURL","handleFileSelect","event","selectedFile","target","files","maxSize","size","toast","error","setValue","handleRemove","_jsxs","className","children","_jsx","Avatar","user","globalProps","DropdownMenu","customTarget","Button","icon","Pencil","variant","Menu","MenuItem","onClick","_fileInputRef$current","current","click","accept","ref","type","onChange"],"mappings":"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"}
|
|
@@ -93,7 +93,7 @@ var ProfileImage = function ProfileImage() {
|
|
|
93
93
|
}
|
|
94
94
|
}), /*#__PURE__*/jsx(DropdownMenu, {
|
|
95
95
|
customTarget: /*#__PURE__*/jsx(Button, {
|
|
96
|
-
className: "absolute -bottom-1 -right-1
|
|
96
|
+
className: "absolute -bottom-1 -right-1 rounded-full",
|
|
97
97
|
icon: Pencil,
|
|
98
98
|
size: "icon-xs",
|
|
99
99
|
variant: "outline",
|
|
@@ -126,4 +126,4 @@ var ProfileImage = function ProfileImage() {
|
|
|
126
126
|
};
|
|
127
127
|
|
|
128
128
|
export { ProfileImage as P, useCountries as u };
|
|
129
|
-
//# sourceMappingURL=ProfileImage-
|
|
129
|
+
//# sourceMappingURL=ProfileImage-Ca02-i_d.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProfileImage-Ca02-i_d.js","sources":["../app/javascript/src/v2/components/Profile/hooks/useCountries.js","../app/javascript/src/v2/components/Profile/ProfileImage.jsx"],"sourcesContent":["import { useCallback, useMemo, useState } from \"react\";\n\nimport { findById } from \"neetocist\";\n\nimport { useFetchCountries } from \"hooks/profile/useCountriesApi\";\n\nconst useCountries = () => {\n const [selectedCountryOption, setSelectedCountryOption] = useState(null);\n\n const { data: { countries = [] } = {}, isLoading } = useFetchCountries();\n\n const formatCountryOption = country => ({\n label: country?.name,\n value: country?.id,\n });\n\n const countryDropdownOptions = useMemo(\n () => countries.map(formatCountryOption),\n [countries]\n );\n\n const handleCountryChange = useCallback(\n countryOption => {\n setSelectedCountryOption(countryOption);\n\n const dependentFields = {};\n const selectedCountry = findById(countryOption.value, countries);\n\n dependentFields.dateFormat = selectedCountry.dateFormat;\n\n return dependentFields;\n },\n [countries]\n );\n\n return {\n countryDropdownOptions,\n selectedCountryOption,\n isFetchingCountriesList: isLoading,\n handleCountryChange,\n };\n};\n\nexport default useCountries;\n","/* eslint-disable @bigbinary/neeto/no-missing-localization */\n// v2 ProfileImage — placeholder, full implementation in Phase 3.5\n// Used by ManageMember for member avatar editing\nimport { useRef } from \"react\";\n\nimport { Avatar, Button, DropdownMenu } from \"@bigbinary/neeto-atoms\";\nimport { useField } from \"formik\";\nimport { Pencil } from \"lucide-react\";\nimport { globalProps } from \"neetocommons/v2/initializers\";\nimport { useTranslation } from \"react-i18next\";\nimport { toast } from \"sonner\";\n\nconst ProfileImage = () => {\n const { t } = useTranslation();\n const [field, , helpers] = useField(\"avatar\");\n const fileInputRef = useRef(null);\n\n const { imageUrl, file } = field.value || {};\n const displayUrl =\n file && file !== \"_destroy\" ? URL.createObjectURL(file) : imageUrl;\n\n const handleFileSelect = event => {\n const selectedFile = event.target.files[0];\n if (!selectedFile) return;\n\n const maxSize = 5 * 1024 * 1024;\n if (selectedFile.size > maxSize) {\n toast.error(\n t(\n \"neetoTeamMembers.common.fileSizeTooLarge\",\n \"File size must be less than 5MB\"\n )\n );\n\n return;\n }\n\n helpers.setValue({ imageUrl, file: selectedFile });\n };\n\n const handleRemove = () => {\n helpers.setValue({ imageUrl: \"\", file: \"_destroy\" });\n };\n\n return (\n <div className=\"flex items-center gap-4\">\n <div className=\"relative\">\n <Avatar\n size=\"xl\"\n user={{\n name: globalProps.user?.name,\n imageUrl: displayUrl,\n }}\n />\n <DropdownMenu\n customTarget={\n <Button\n className=\"absolute -bottom-1 -right-1 rounded-full\"\n icon={Pencil}\n size=\"icon-xs\"\n variant=\"outline\"\n aria-label={t(\n \"neetoTeamMembers.common.changeProfileImage\",\n \"Change profile image\"\n )}\n />\n }\n >\n <DropdownMenu.Menu>\n <DropdownMenu.MenuItem\n data-testid=\"profile-image-upload-button\"\n onClick={() => fileInputRef.current?.click()}\n >\n {t(\"neetoTeamMembers.common.upload\", \"Upload\")}\n </DropdownMenu.MenuItem>\n {displayUrl && (\n <DropdownMenu.MenuItem\n data-testid=\"profile-image-remove-button\"\n onClick={handleRemove}\n >\n {t(\"neetoTeamMembers.common.remove\")}\n </DropdownMenu.MenuItem>\n )}\n </DropdownMenu.Menu>\n </DropdownMenu>\n </div>\n <input\n accept=\"image/*\"\n className=\"hidden\"\n data-testid=\"profile-image-upload-file-field\"\n ref={fileInputRef}\n type=\"file\"\n onChange={handleFileSelect}\n />\n </div>\n );\n};\n\nexport default ProfileImage;\n"],"names":["useCountries","_useState","useState","_useState2","_slicedToArray","selectedCountryOption","setSelectedCountryOption","_useFetchCountries","useFetchCountries","_useFetchCountries$da","data","_useFetchCountries$da2","_useFetchCountries$da3","countries","isLoading","formatCountryOption","country","label","name","value","id","countryDropdownOptions","useMemo","map","handleCountryChange","useCallback","countryOption","dependentFields","selectedCountry","findById","dateFormat","isFetchingCountriesList","ProfileImage","_globalProps$user","_useTranslation","useTranslation","t","_useField","useField","_useField2","field","helpers","fileInputRef","useRef","_ref","imageUrl","file","displayUrl","URL","createObjectURL","handleFileSelect","event","selectedFile","target","files","maxSize","size","toast","error","setValue","handleRemove","_jsxs","className","children","_jsx","Avatar","user","globalProps","DropdownMenu","customTarget","Button","icon","Pencil","variant","Menu","MenuItem","onClick","_fileInputRef$current","current","click","accept","ref","type","onChange"],"mappings":"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"}
|
package/dist/cjs/ManageMember.js
CHANGED
|
@@ -491,8 +491,7 @@ var NameInputs = reactUtils.withT(function (_ref) {
|
|
|
491
491
|
|
|
492
492
|
var ProfileSettings = function ProfileSettings(_ref) {
|
|
493
493
|
var member = _ref.member,
|
|
494
|
-
setFieldValue = _ref.setFieldValue
|
|
495
|
-
isTimezoneFieldDisabled = _ref.isTimezoneFieldDisabled;
|
|
494
|
+
setFieldValue = _ref.setFieldValue;
|
|
496
495
|
var _useTranslation = reactI18next.useTranslation(),
|
|
497
496
|
t = _useTranslation.t;
|
|
498
497
|
var setFieldValueRef = React.useRef(setFieldValue);
|
|
@@ -516,13 +515,12 @@ var ProfileSettings = function ProfileSettings(_ref) {
|
|
|
516
515
|
onChange: function onChange(_ref2) {
|
|
517
516
|
var main = _ref2.main;
|
|
518
517
|
return setFieldValueRef.current("timeZone", main);
|
|
519
|
-
}
|
|
520
|
-
disabled: isTimezoneFieldDisabled
|
|
518
|
+
}
|
|
521
519
|
});
|
|
522
520
|
return function () {
|
|
523
521
|
node.innerHTML = "";
|
|
524
522
|
};
|
|
525
|
-
}, [member.timeZone, member.timeFormat
|
|
523
|
+
}, [member.timeZone, member.timeFormat]);
|
|
526
524
|
React.useEffect(function () {
|
|
527
525
|
var country = neetoCist.findBy({
|
|
528
526
|
value: member.countryIdentifier
|
|
@@ -561,11 +559,9 @@ var ProfileSettings = function ProfileSettings(_ref) {
|
|
|
561
559
|
children: [/*#__PURE__*/jsxRuntime.jsx(Label__default.default, {
|
|
562
560
|
children: t("neetoTeamMembers.profile.inputs.label.timeZone")
|
|
563
561
|
}), /*#__PURE__*/jsxRuntime.jsx("div", {
|
|
562
|
+
className: "w-full grow",
|
|
564
563
|
"data-cy": "ntm-edit-member-timezone-select",
|
|
565
|
-
ref: timezoneContainerRef
|
|
566
|
-
className: classnames__default.default("w-full grow", {
|
|
567
|
-
"neeto-ui-bg-gray-100 pointer-events-none": isTimezoneFieldDisabled
|
|
568
|
-
})
|
|
564
|
+
ref: timezoneContainerRef
|
|
569
565
|
})]
|
|
570
566
|
}), /*#__PURE__*/jsxRuntime.jsx(Select__default.default, {
|
|
571
567
|
"data-cy": "ntm-edit-member-time-format-select",
|
|
@@ -617,7 +613,6 @@ var ManageMember = function ManageMember(_ref) {
|
|
|
617
613
|
}),
|
|
618
614
|
memberShowData = _useFetchMember.data,
|
|
619
615
|
isMemberDetailLoading = _useFetchMember.isLoading;
|
|
620
|
-
var isTimezoneFieldDisabled = selectedMember && memberShowData && !selectedMember.isOwner && !memberShowData.timezoneChangeEnabled;
|
|
621
616
|
var _useState3 = React.useState(RolesRadioGroup.FORM_PAGES.MAIN),
|
|
622
617
|
_useState4 = _slicedToArray__default.default(_useState3, 2),
|
|
623
618
|
currentPage = _useState4[0],
|
|
@@ -916,7 +911,6 @@ var ManageMember = function ManageMember(_ref) {
|
|
|
916
911
|
setCurrentPage: setCurrentPage,
|
|
917
912
|
innerRef: inputReference
|
|
918
913
|
}), selectedMember && /*#__PURE__*/jsxRuntime.jsx(ProfileSettings, {
|
|
919
|
-
isTimezoneFieldDisabled: isTimezoneFieldDisabled,
|
|
920
914
|
setFieldValue: setFieldValue,
|
|
921
915
|
member: _objectSpread(_objectSpread({}, selectedMember), {}, {
|
|
922
916
|
countryIdentifier: (_memberShowData$membe = memberShowData === null || memberShowData === void 0 || (_memberShowData$membe2 = memberShowData.member) === null || _memberShowData$membe2 === void 0 ? void 0 : _memberShowData$membe2.countryIdentifier) !== null && _memberShowData$membe !== void 0 ? _memberShowData$membe : selectedMember.countryIdentifier
|