@os-team/profile 1.2.1 → 1.2.2
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/@types/emotion.d.js +1 -0
- package/dist/@types/i18next.d.js +1 -0
- package/dist/@types/relay.d.js +0 -0
- package/dist/{types/components → components}/profile/ProfileButton.d.ts +1 -1
- package/dist/components/profile/ProfileButton.d.ts.map +1 -0
- package/dist/components/profile/ProfileButton.js +9 -0
- package/dist/components/profile/ProfileConfigContext.d.ts.map +1 -0
- package/dist/{esm/components → components}/profile/ProfileConfigContext.js +1 -2
- package/dist/components/profile/ProfileContext.d.ts.map +1 -0
- package/dist/{esm/components → components}/profile/ProfileContext.js +1 -2
- package/dist/{types/components → components}/profile/ProfileDrawer.d.ts +2 -2
- package/dist/components/profile/ProfileDrawer.d.ts.map +1 -0
- package/dist/components/profile/ProfileDrawer.js +28 -0
- package/dist/{types/components → components}/profile/ProfileDrawerContent.d.ts +7 -0
- package/dist/components/profile/ProfileDrawerContent.d.ts.map +1 -0
- package/dist/{esm/components → components}/profile/ProfileDrawerContent.js +66 -41
- package/dist/{types/components → components}/profile/ProfileNavigationItem.d.ts +1 -1
- package/dist/components/profile/ProfileNavigationItem.d.ts.map +1 -0
- package/dist/{esm/components → components}/profile/ProfileNavigationItem.js +8 -7
- package/dist/components/profile/ProfileUpdateNameModal.d.ts.map +1 -0
- package/dist/{esm/components → components}/profile/ProfileUpdateNameModal.js +38 -31
- package/dist/components/profile/ProfileUpdatePasswordModal.d.ts.map +1 -0
- package/dist/{esm/components → components}/profile/ProfileUpdatePasswordModal.js +40 -33
- package/dist/components/profile/ProtectedWrapper.d.ts.map +1 -0
- package/dist/{esm/components → components}/profile/ProtectedWrapper.js +19 -14
- package/dist/{types/components → components}/profile/UserAvatar.d.ts +1 -1
- package/dist/components/profile/UserAvatar.d.ts.map +1 -0
- package/dist/{esm/components → components}/profile/UserAvatar.js +7 -6
- package/dist/{types/components → components}/profile/UserAvatarAddon.d.ts +1 -1
- package/dist/components/profile/UserAvatarAddon.d.ts.map +1 -0
- package/dist/components/profile/UserAvatarAddon.js +50 -0
- package/dist/{types/components → components}/profile/__generated__/ProfileDrawerContentSignOutMutation.graphql.d.ts +5 -0
- package/dist/components/profile/__generated__/ProfileDrawerContentSignOutMutation.graphql.d.ts.map +1 -0
- package/dist/{esm/components → components}/profile/__generated__/ProfileDrawerContentSignOutMutation.graphql.js +2 -3
- package/dist/{types/components → components}/profile/__generated__/ProfileDrawerContentUpdateAvatarMutation.graphql.d.ts +5 -0
- package/dist/components/profile/__generated__/ProfileDrawerContentUpdateAvatarMutation.graphql.d.ts.map +1 -0
- package/dist/{esm/components → components}/profile/__generated__/ProfileDrawerContentUpdateAvatarMutation.graphql.js +2 -3
- package/dist/{types/components → components}/profile/__generated__/ProfileUpdateNameModalMutation.graphql.d.ts +5 -0
- package/dist/components/profile/__generated__/ProfileUpdateNameModalMutation.graphql.d.ts.map +1 -0
- package/dist/{esm/components → components}/profile/__generated__/ProfileUpdateNameModalMutation.graphql.js +2 -3
- package/dist/{types/components → components}/profile/__generated__/ProfileUpdatePasswordModalMutation.graphql.d.ts +5 -0
- package/dist/components/profile/__generated__/ProfileUpdatePasswordModalMutation.graphql.d.ts.map +1 -0
- package/dist/{esm/components → components}/profile/__generated__/ProfileUpdatePasswordModalMutation.graphql.js +2 -3
- package/dist/{types/components → components}/profile/__generated__/ProtectedWrapperQuery.graphql.d.ts +5 -0
- package/dist/components/profile/__generated__/ProtectedWrapperQuery.graphql.d.ts.map +1 -0
- package/dist/{esm/components → components}/profile/__generated__/ProtectedWrapperQuery.graphql.js +2 -3
- package/dist/{types/components → components}/session/SessionDrawer.d.ts +1 -1
- package/dist/components/session/SessionDrawer.d.ts.map +1 -0
- package/dist/components/session/SessionDrawer.js +45 -0
- package/dist/components/session/SessionDrawerContent.d.ts.map +1 -0
- package/dist/{esm/components → components}/session/SessionDrawerContent.js +12 -10
- package/dist/{types/components → components}/session/SessionList.d.ts +5 -5
- package/dist/components/session/SessionList.d.ts.map +1 -0
- package/dist/{esm/components → components}/session/SessionList.js +33 -17
- package/dist/{types/components → components}/session/SessionListItem.d.ts +9 -9
- package/dist/components/session/SessionListItem.d.ts.map +1 -0
- package/dist/{esm/components → components}/session/SessionListItem.js +37 -19
- package/dist/components/session/SessionListSkeleton.d.ts.map +1 -0
- package/dist/components/session/SessionListSkeleton.js +43 -0
- package/dist/{types/components → components}/session/__generated__/SessionDrawerContentQuery.graphql.d.ts +5 -0
- package/dist/components/session/__generated__/SessionDrawerContentQuery.graphql.d.ts.map +1 -0
- package/dist/{esm/components → components}/session/__generated__/SessionDrawerContentQuery.graphql.js +2 -3
- package/dist/{types/components → components}/session/__generated__/SessionListDestroyAllOtherSessionsMutation.graphql.d.ts +5 -0
- package/dist/components/session/__generated__/SessionListDestroyAllOtherSessionsMutation.graphql.d.ts.map +1 -0
- package/dist/{esm/components → components}/session/__generated__/SessionListDestroyAllOtherSessionsMutation.graphql.js +2 -3
- package/dist/{types/components → components}/session/__generated__/SessionListItemDestroySessionMutation.graphql.d.ts +5 -0
- package/dist/components/session/__generated__/SessionListItemDestroySessionMutation.graphql.d.ts.map +1 -0
- package/dist/{esm/components → components}/session/__generated__/SessionListItemDestroySessionMutation.graphql.js +2 -3
- package/dist/{types/components → components}/session/__generated__/SessionListItem_session.graphql.d.ts +5 -0
- package/dist/components/session/__generated__/SessionListItem_session.graphql.d.ts.map +1 -0
- package/dist/{esm/components → components}/session/__generated__/SessionListItem_session.graphql.js +2 -3
- package/dist/{types/components → components}/session/__generated__/SessionListRefetchQuery.graphql.d.ts +5 -0
- package/dist/components/session/__generated__/SessionListRefetchQuery.graphql.d.ts.map +1 -0
- package/dist/{esm/components → components}/session/__generated__/SessionListRefetchQuery.graphql.js +2 -3
- package/dist/{types/components → components}/session/__generated__/SessionList_sessions.graphql.d.ts +5 -0
- package/dist/components/session/__generated__/SessionList_sessions.graphql.d.ts.map +1 -0
- package/dist/{esm/components → components}/session/__generated__/SessionList_sessions.graphql.js +2 -3
- package/dist/{types/components → components}/session/formatDate.d.ts +1 -1
- package/dist/components/session/formatDate.d.ts.map +1 -0
- package/dist/{esm/components → components}/session/formatDate.js +1 -2
- package/dist/components/session/getLastSeen.d.ts +3 -0
- package/dist/components/session/getLastSeen.d.ts.map +1 -0
- package/dist/{esm/components → components}/session/getLastSeen.js +1 -2
- package/dist/{types/components → components}/shared/ButtonUpdate.d.ts +1 -1
- package/dist/components/shared/ButtonUpdate.d.ts.map +1 -0
- package/dist/{esm/components → components}/shared/ButtonUpdate.js +6 -3
- package/dist/components/shared/ErrorResult.d.ts.map +1 -0
- package/dist/{esm/components → components}/shared/ErrorResult.js +4 -4
- package/dist/components/shared/FormError.d.ts.map +1 -0
- package/dist/{esm/components → components}/shared/FormError.js +6 -5
- package/dist/components/shared/MainLoader.d.ts.map +1 -0
- package/dist/{esm/components → components}/shared/MainLoader.js +5 -3
- package/dist/{types/components → components}/shared/icons/AndroidIcon.d.ts +1 -1
- package/dist/components/shared/icons/AndroidIcon.d.ts.map +1 -0
- package/dist/components/shared/icons/AndroidIcon.js +12 -0
- package/dist/{types/components → components}/shared/icons/AppleIcon.d.ts +1 -1
- package/dist/components/shared/icons/AppleIcon.d.ts.map +1 -0
- package/dist/components/shared/icons/AppleIcon.js +12 -0
- package/dist/{types/components → components}/shared/icons/BrowserIcon.d.ts +1 -1
- package/dist/components/shared/icons/BrowserIcon.d.ts.map +1 -0
- package/dist/components/shared/icons/BrowserIcon.js +12 -0
- package/dist/{types/components → components}/shared/icons/ProfileIcon.d.ts +1 -1
- package/dist/components/shared/icons/ProfileIcon.d.ts.map +1 -0
- package/dist/components/shared/icons/ProfileIcon.js +12 -0
- package/dist/{types/components → components}/shared/icons/UnknownDeviceIcon.d.ts +1 -1
- package/dist/components/shared/icons/UnknownDeviceIcon.d.ts.map +1 -0
- package/dist/components/shared/icons/UnknownDeviceIcon.js +12 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +14 -0
- package/dist/utils/getError.d.ts.map +1 -0
- package/dist/{esm/utils → utils}/getError.js +1 -2
- package/dist/utils/getUserFullName.d.ts.map +1 -0
- package/dist/{esm/utils → utils}/getUserFullName.js +1 -2
- package/dist/{types/utils → utils}/handleFormErrors.d.ts +1 -1
- package/dist/utils/handleFormErrors.d.ts.map +1 -0
- package/dist/{esm/utils → utils}/handleFormErrors.js +1 -2
- package/package.json +50 -56
- package/src/@types/react-app-env.d.ts +3 -0
- package/src/App.tsx +42 -0
- package/src/AppRouter.tsx +12 -0
- package/src/components/ErrorResult.tsx +23 -0
- package/src/components/Layout.tsx +70 -0
- package/src/components/MainLoader.tsx +22 -0
- package/src/components/icons/HomeIcon.tsx +12 -0
- package/src/i18next.ts +34 -0
- package/src/index.tsx +6 -0
- package/src/lib/@types/emotion.d.ts +7 -0
- package/src/lib/@types/i18next.d.ts +12 -0
- package/src/lib/@types/relay.d.ts +3 -0
- package/src/lib/components/profile/ProfileButton.tsx +8 -0
- package/src/lib/components/profile/ProfileConfigContext.ts +16 -0
- package/src/lib/components/profile/ProfileContext.ts +20 -0
- package/src/lib/components/profile/ProfileDrawer.tsx +31 -0
- package/src/lib/components/profile/ProfileDrawerContent.tsx +276 -0
- package/src/lib/components/profile/ProfileNavigationItem.tsx +36 -0
- package/src/lib/components/profile/ProfileUpdateNameModal.tsx +117 -0
- package/src/lib/components/profile/ProfileUpdatePasswordModal.tsx +129 -0
- package/src/lib/components/profile/ProtectedWrapper.tsx +81 -0
- package/src/lib/components/profile/UserAvatar.tsx +23 -0
- package/src/lib/components/profile/UserAvatarAddon.tsx +62 -0
- package/src/lib/components/profile/__generated__/ProfileDrawerContentSignOutMutation.graphql.ts +74 -0
- package/src/lib/components/profile/__generated__/ProfileDrawerContentUpdateAvatarMutation.graphql.ts +100 -0
- package/src/lib/components/profile/__generated__/ProfileUpdateNameModalMutation.graphql.ts +124 -0
- package/src/lib/components/profile/__generated__/ProfileUpdatePasswordModalMutation.graphql.ts +93 -0
- package/src/lib/components/profile/__generated__/ProtectedWrapperQuery.graphql.ts +106 -0
- package/src/lib/components/session/SessionDrawer.tsx +50 -0
- package/src/lib/components/session/SessionDrawerContent.tsx +34 -0
- package/src/lib/components/session/SessionList.tsx +138 -0
- package/src/lib/components/session/SessionListItem.tsx +318 -0
- package/src/lib/components/session/SessionListSkeleton.tsx +48 -0
- package/src/lib/components/session/__generated__/SessionDrawerContentQuery.graphql.ts +181 -0
- package/src/lib/components/session/__generated__/SessionListDestroyAllOtherSessionsMutation.graphql.ts +74 -0
- package/src/lib/components/session/__generated__/SessionListItemDestroySessionMutation.graphql.ts +92 -0
- package/src/lib/components/session/__generated__/SessionListItem_session.graphql.ts +154 -0
- package/src/lib/components/session/__generated__/SessionListRefetchQuery.graphql.ts +181 -0
- package/src/lib/components/session/__generated__/SessionList_sessions.graphql.ts +83 -0
- package/src/lib/components/session/formatDate.ts +21 -0
- package/{dist/cjs/components/session/getLastSeen.js → src/lib/components/session/getLastSeen.ts} +9 -9
- package/src/lib/components/shared/ButtonUpdate.tsx +10 -0
- package/src/lib/components/shared/ErrorResult.tsx +28 -0
- package/src/lib/components/shared/FormError.tsx +11 -0
- package/src/lib/components/shared/MainLoader.tsx +22 -0
- package/src/lib/components/shared/icons/AndroidIcon.tsx +12 -0
- package/src/lib/components/shared/icons/AppleIcon.tsx +12 -0
- package/src/lib/components/shared/icons/BrowserIcon.tsx +12 -0
- package/src/lib/components/shared/icons/ProfileIcon.tsx +12 -0
- package/src/lib/components/shared/icons/UnknownDeviceIcon.tsx +14 -0
- package/{dist/esm/index.js → src/lib/index.ts} +1 -1
- package/src/lib/utils/getError.ts +101 -0
- package/src/lib/utils/getUserFullName.ts +14 -0
- package/src/lib/utils/handleFormErrors.ts +16 -0
- package/src/pages/HomePage.tsx +11 -0
- package/src/schema.graphql +2494 -0
- package/src/utils/createRelayEnvironment.ts +22 -0
- package/src/utils/getError.ts +101 -0
- package/dist/cjs/@types/emotion.d.js +0 -4
- package/dist/cjs/@types/emotion.d.js.map +0 -1
- package/dist/cjs/@types/i18next.d.js +0 -4
- package/dist/cjs/@types/i18next.d.js.map +0 -1
- package/dist/cjs/components/profile/ProfileButton.js +0 -16
- package/dist/cjs/components/profile/ProfileButton.js.map +0 -1
- package/dist/cjs/components/profile/ProfileConfigContext.js +0 -17
- package/dist/cjs/components/profile/ProfileConfigContext.js.map +0 -1
- package/dist/cjs/components/profile/ProfileContext.js +0 -18
- package/dist/cjs/components/profile/ProfileContext.js.map +0 -1
- package/dist/cjs/components/profile/ProfileDrawer.js +0 -35
- package/dist/cjs/components/profile/ProfileDrawer.js.map +0 -1
- package/dist/cjs/components/profile/ProfileDrawerContent.js +0 -167
- package/dist/cjs/components/profile/ProfileDrawerContent.js.map +0 -1
- package/dist/cjs/components/profile/ProfileNavigationItem.js +0 -35
- package/dist/cjs/components/profile/ProfileNavigationItem.js.map +0 -1
- package/dist/cjs/components/profile/ProfileUpdateNameModal.js +0 -106
- package/dist/cjs/components/profile/ProfileUpdateNameModal.js.map +0 -1
- package/dist/cjs/components/profile/ProfileUpdatePasswordModal.js +0 -106
- package/dist/cjs/components/profile/ProfileUpdatePasswordModal.js.map +0 -1
- package/dist/cjs/components/profile/ProtectedWrapper.js +0 -54
- package/dist/cjs/components/profile/ProtectedWrapper.js.map +0 -1
- package/dist/cjs/components/profile/UserAvatar.js +0 -42
- package/dist/cjs/components/profile/UserAvatar.js.map +0 -1
- package/dist/cjs/components/profile/UserAvatarAddon.js +0 -41
- package/dist/cjs/components/profile/UserAvatarAddon.js.map +0 -1
- package/dist/cjs/components/profile/__generated__/ProfileDrawerContentSignOutMutation.graphql.js +0 -63
- package/dist/cjs/components/profile/__generated__/ProfileDrawerContentSignOutMutation.graphql.js.map +0 -1
- package/dist/cjs/components/profile/__generated__/ProfileDrawerContentUpdateAvatarMutation.graphql.js +0 -78
- package/dist/cjs/components/profile/__generated__/ProfileDrawerContentUpdateAvatarMutation.graphql.js.map +0 -1
- package/dist/cjs/components/profile/__generated__/ProfileUpdateNameModalMutation.graphql.js +0 -95
- package/dist/cjs/components/profile/__generated__/ProfileUpdateNameModalMutation.graphql.js.map +0 -1
- package/dist/cjs/components/profile/__generated__/ProfileUpdatePasswordModalMutation.graphql.js +0 -72
- package/dist/cjs/components/profile/__generated__/ProfileUpdatePasswordModalMutation.graphql.js.map +0 -1
- package/dist/cjs/components/profile/__generated__/ProtectedWrapperQuery.graphql.js +0 -87
- package/dist/cjs/components/profile/__generated__/ProtectedWrapperQuery.graphql.js.map +0 -1
- package/dist/cjs/components/session/SessionDrawer.js +0 -46
- package/dist/cjs/components/session/SessionDrawer.js.map +0 -1
- package/dist/cjs/components/session/SessionDrawerContent.js +0 -39
- package/dist/cjs/components/session/SessionDrawerContent.js.map +0 -1
- package/dist/cjs/components/session/SessionList.js +0 -73
- package/dist/cjs/components/session/SessionList.js.map +0 -1
- package/dist/cjs/components/session/SessionListItem.js +0 -150
- package/dist/cjs/components/session/SessionListItem.js.map +0 -1
- package/dist/cjs/components/session/SessionListSkeleton.js +0 -31
- package/dist/cjs/components/session/SessionListSkeleton.js.map +0 -1
- package/dist/cjs/components/session/__generated__/SessionDrawerContentQuery.graphql.js +0 -154
- package/dist/cjs/components/session/__generated__/SessionDrawerContentQuery.graphql.js.map +0 -1
- package/dist/cjs/components/session/__generated__/SessionListDestroyAllOtherSessionsMutation.graphql.js +0 -63
- package/dist/cjs/components/session/__generated__/SessionListDestroyAllOtherSessionsMutation.graphql.js.map +0 -1
- package/dist/cjs/components/session/__generated__/SessionListItemDestroySessionMutation.graphql.js +0 -72
- package/dist/cjs/components/session/__generated__/SessionListItemDestroySessionMutation.graphql.js.map +0 -1
- package/dist/cjs/components/session/__generated__/SessionListItem_session.graphql.js +0 -118
- package/dist/cjs/components/session/__generated__/SessionListItem_session.graphql.js.map +0 -1
- package/dist/cjs/components/session/__generated__/SessionListRefetchQuery.graphql.js +0 -154
- package/dist/cjs/components/session/__generated__/SessionListRefetchQuery.graphql.js.map +0 -1
- package/dist/cjs/components/session/__generated__/SessionList_sessions.graphql.js +0 -65
- package/dist/cjs/components/session/__generated__/SessionList_sessions.graphql.js.map +0 -1
- package/dist/cjs/components/session/formatDate.js +0 -19
- package/dist/cjs/components/session/formatDate.js.map +0 -1
- package/dist/cjs/components/session/getLastSeen.js.map +0 -1
- package/dist/cjs/components/shared/ButtonUpdate.js +0 -18
- package/dist/cjs/components/shared/ButtonUpdate.js.map +0 -1
- package/dist/cjs/components/shared/ErrorResult.js +0 -31
- package/dist/cjs/components/shared/ErrorResult.js.map +0 -1
- package/dist/cjs/components/shared/FormError.js +0 -21
- package/dist/cjs/components/shared/FormError.js.map +0 -1
- package/dist/cjs/components/shared/MainLoader.js +0 -17
- package/dist/cjs/components/shared/MainLoader.js.map +0 -1
- package/dist/cjs/components/shared/icons/AndroidIcon.js +0 -18
- package/dist/cjs/components/shared/icons/AndroidIcon.js.map +0 -1
- package/dist/cjs/components/shared/icons/AppleIcon.js +0 -18
- package/dist/cjs/components/shared/icons/AppleIcon.js.map +0 -1
- package/dist/cjs/components/shared/icons/BrowserIcon.js +0 -18
- package/dist/cjs/components/shared/icons/BrowserIcon.js.map +0 -1
- package/dist/cjs/components/shared/icons/ProfileIcon.js +0 -18
- package/dist/cjs/components/shared/icons/ProfileIcon.js.map +0 -1
- package/dist/cjs/components/shared/icons/UnknownDeviceIcon.js +0 -18
- package/dist/cjs/components/shared/icons/UnknownDeviceIcon.js.map +0 -1
- package/dist/cjs/index.js +0 -142
- package/dist/cjs/index.js.map +0 -1
- package/dist/cjs/utils/getError.js +0 -59
- package/dist/cjs/utils/getError.js.map +0 -1
- package/dist/cjs/utils/getUserFullName.js +0 -19
- package/dist/cjs/utils/getUserFullName.js.map +0 -1
- package/dist/cjs/utils/handleFormErrors.js +0 -25
- package/dist/cjs/utils/handleFormErrors.js.map +0 -1
- package/dist/esm/@types/emotion.d.js +0 -2
- package/dist/esm/@types/emotion.d.js.map +0 -1
- package/dist/esm/@types/i18next.d.js +0 -2
- package/dist/esm/@types/i18next.d.js.map +0 -1
- package/dist/esm/components/profile/ProfileButton.js +0 -9
- package/dist/esm/components/profile/ProfileButton.js.map +0 -1
- package/dist/esm/components/profile/ProfileConfigContext.js.map +0 -1
- package/dist/esm/components/profile/ProfileContext.js.map +0 -1
- package/dist/esm/components/profile/ProfileDrawer.js +0 -25
- package/dist/esm/components/profile/ProfileDrawer.js.map +0 -1
- package/dist/esm/components/profile/ProfileDrawerContent.js.map +0 -1
- package/dist/esm/components/profile/ProfileNavigationItem.js.map +0 -1
- package/dist/esm/components/profile/ProfileUpdateNameModal.js.map +0 -1
- package/dist/esm/components/profile/ProfileUpdatePasswordModal.js.map +0 -1
- package/dist/esm/components/profile/ProtectedWrapper.js.map +0 -1
- package/dist/esm/components/profile/UserAvatar.js.map +0 -1
- package/dist/esm/components/profile/UserAvatarAddon.js +0 -47
- package/dist/esm/components/profile/UserAvatarAddon.js.map +0 -1
- package/dist/esm/components/profile/__generated__/ProfileDrawerContentSignOutMutation.graphql.js.map +0 -1
- package/dist/esm/components/profile/__generated__/ProfileDrawerContentUpdateAvatarMutation.graphql.js.map +0 -1
- package/dist/esm/components/profile/__generated__/ProfileUpdateNameModalMutation.graphql.js.map +0 -1
- package/dist/esm/components/profile/__generated__/ProfileUpdatePasswordModalMutation.graphql.js.map +0 -1
- package/dist/esm/components/profile/__generated__/ProtectedWrapperQuery.graphql.js.map +0 -1
- package/dist/esm/components/session/SessionDrawer.js +0 -39
- package/dist/esm/components/session/SessionDrawer.js.map +0 -1
- package/dist/esm/components/session/SessionDrawerContent.js.map +0 -1
- package/dist/esm/components/session/SessionList.js.map +0 -1
- package/dist/esm/components/session/SessionListItem.js.map +0 -1
- package/dist/esm/components/session/SessionListSkeleton.js +0 -31
- package/dist/esm/components/session/SessionListSkeleton.js.map +0 -1
- package/dist/esm/components/session/__generated__/SessionDrawerContentQuery.graphql.js.map +0 -1
- package/dist/esm/components/session/__generated__/SessionListDestroyAllOtherSessionsMutation.graphql.js.map +0 -1
- package/dist/esm/components/session/__generated__/SessionListItemDestroySessionMutation.graphql.js.map +0 -1
- package/dist/esm/components/session/__generated__/SessionListItem_session.graphql.js.map +0 -1
- package/dist/esm/components/session/__generated__/SessionListRefetchQuery.graphql.js.map +0 -1
- package/dist/esm/components/session/__generated__/SessionList_sessions.graphql.js.map +0 -1
- package/dist/esm/components/session/formatDate.js.map +0 -1
- package/dist/esm/components/session/getLastSeen.js.map +0 -1
- package/dist/esm/components/shared/ButtonUpdate.js.map +0 -1
- package/dist/esm/components/shared/ErrorResult.js.map +0 -1
- package/dist/esm/components/shared/FormError.js.map +0 -1
- package/dist/esm/components/shared/MainLoader.js.map +0 -1
- package/dist/esm/components/shared/icons/AndroidIcon.js +0 -11
- package/dist/esm/components/shared/icons/AndroidIcon.js.map +0 -1
- package/dist/esm/components/shared/icons/AppleIcon.js +0 -11
- package/dist/esm/components/shared/icons/AppleIcon.js.map +0 -1
- package/dist/esm/components/shared/icons/BrowserIcon.js +0 -11
- package/dist/esm/components/shared/icons/BrowserIcon.js.map +0 -1
- package/dist/esm/components/shared/icons/ProfileIcon.js +0 -11
- package/dist/esm/components/shared/icons/ProfileIcon.js.map +0 -1
- package/dist/esm/components/shared/icons/UnknownDeviceIcon.js +0 -11
- package/dist/esm/components/shared/icons/UnknownDeviceIcon.js.map +0 -1
- package/dist/esm/index.js.map +0 -1
- package/dist/esm/utils/getError.js.map +0 -1
- package/dist/esm/utils/getUserFullName.js.map +0 -1
- package/dist/esm/utils/handleFormErrors.js.map +0 -1
- package/dist/types/components/profile/ProfileButton.d.ts.map +0 -1
- package/dist/types/components/profile/ProfileConfigContext.d.ts.map +0 -1
- package/dist/types/components/profile/ProfileContext.d.ts.map +0 -1
- package/dist/types/components/profile/ProfileDrawer.d.ts.map +0 -1
- package/dist/types/components/profile/ProfileDrawerContent.d.ts.map +0 -1
- package/dist/types/components/profile/ProfileNavigationItem.d.ts.map +0 -1
- package/dist/types/components/profile/ProfileUpdateNameModal.d.ts.map +0 -1
- package/dist/types/components/profile/ProfileUpdatePasswordModal.d.ts.map +0 -1
- package/dist/types/components/profile/ProtectedWrapper.d.ts.map +0 -1
- package/dist/types/components/profile/UserAvatar.d.ts.map +0 -1
- package/dist/types/components/profile/UserAvatarAddon.d.ts.map +0 -1
- package/dist/types/components/profile/__generated__/ProfileDrawerContentSignOutMutation.graphql.d.ts.map +0 -1
- package/dist/types/components/profile/__generated__/ProfileDrawerContentUpdateAvatarMutation.graphql.d.ts.map +0 -1
- package/dist/types/components/profile/__generated__/ProfileUpdateNameModalMutation.graphql.d.ts.map +0 -1
- package/dist/types/components/profile/__generated__/ProfileUpdatePasswordModalMutation.graphql.d.ts.map +0 -1
- package/dist/types/components/profile/__generated__/ProtectedWrapperQuery.graphql.d.ts.map +0 -1
- package/dist/types/components/session/SessionDrawer.d.ts.map +0 -1
- package/dist/types/components/session/SessionDrawerContent.d.ts.map +0 -1
- package/dist/types/components/session/SessionList.d.ts.map +0 -1
- package/dist/types/components/session/SessionListItem.d.ts.map +0 -1
- package/dist/types/components/session/SessionListSkeleton.d.ts.map +0 -1
- package/dist/types/components/session/__generated__/SessionDrawerContentQuery.graphql.d.ts.map +0 -1
- package/dist/types/components/session/__generated__/SessionListDestroyAllOtherSessionsMutation.graphql.d.ts.map +0 -1
- package/dist/types/components/session/__generated__/SessionListItemDestroySessionMutation.graphql.d.ts.map +0 -1
- package/dist/types/components/session/__generated__/SessionListItem_session.graphql.d.ts.map +0 -1
- package/dist/types/components/session/__generated__/SessionListRefetchQuery.graphql.d.ts.map +0 -1
- package/dist/types/components/session/__generated__/SessionList_sessions.graphql.d.ts.map +0 -1
- package/dist/types/components/session/formatDate.d.ts.map +0 -1
- package/dist/types/components/session/getLastSeen.d.ts +0 -3
- package/dist/types/components/session/getLastSeen.d.ts.map +0 -1
- package/dist/types/components/shared/ButtonUpdate.d.ts.map +0 -1
- package/dist/types/components/shared/ErrorResult.d.ts.map +0 -1
- package/dist/types/components/shared/FormError.d.ts.map +0 -1
- package/dist/types/components/shared/MainLoader.d.ts.map +0 -1
- package/dist/types/components/shared/icons/AndroidIcon.d.ts.map +0 -1
- package/dist/types/components/shared/icons/AppleIcon.d.ts.map +0 -1
- package/dist/types/components/shared/icons/BrowserIcon.d.ts.map +0 -1
- package/dist/types/components/shared/icons/ProfileIcon.d.ts.map +0 -1
- package/dist/types/components/shared/icons/UnknownDeviceIcon.d.ts.map +0 -1
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/utils/getError.d.ts.map +0 -1
- package/dist/types/utils/getUserFullName.d.ts.map +0 -1
- package/dist/types/utils/handleFormErrors.d.ts.map +0 -1
- /package/dist/{types/components → components}/profile/ProfileConfigContext.d.ts +0 -0
- /package/dist/{types/components → components}/profile/ProfileContext.d.ts +0 -0
- /package/dist/{types/components → components}/profile/ProfileUpdateNameModal.d.ts +0 -0
- /package/dist/{types/components → components}/profile/ProfileUpdatePasswordModal.d.ts +0 -0
- /package/dist/{types/components → components}/profile/ProtectedWrapper.d.ts +0 -0
- /package/dist/{types/components → components}/session/SessionDrawerContent.d.ts +0 -0
- /package/dist/{types/components → components}/session/SessionListSkeleton.d.ts +0 -0
- /package/dist/{types/components → components}/shared/ErrorResult.d.ts +0 -0
- /package/dist/{types/components → components}/shared/FormError.d.ts +0 -0
- /package/dist/{types/components → components}/shared/MainLoader.d.ts +0 -0
- /package/dist/{types/index.d.ts → index.d.ts} +0 -0
- /package/dist/{types/utils → utils}/getError.d.ts +0 -0
- /package/dist/{types/utils → utils}/getUserFullName.d.ts +0 -0
|
@@ -0,0 +1,318 @@
|
|
|
1
|
+
import React, { useCallback, useMemo } from 'react';
|
|
2
|
+
import graphql from 'babel-plugin-relay/macro';
|
|
3
|
+
import { useFragment, useMutation } from 'react-relay';
|
|
4
|
+
import styled from '@emotion/styled';
|
|
5
|
+
import { useTranslation } from 'react-i18next';
|
|
6
|
+
import pluralForms from '@os-team/plural-forms';
|
|
7
|
+
import { Button, message } from '@os-design/core';
|
|
8
|
+
import {
|
|
9
|
+
ellipsisStyles,
|
|
10
|
+
horizontalPaddingStyles,
|
|
11
|
+
transitionStyles,
|
|
12
|
+
} from '@os-design/styles';
|
|
13
|
+
import { clr, type Color } from '@os-design/theming';
|
|
14
|
+
import { isTouchDevice, omitEmotionProps, useSwipe } from '@os-design/utils';
|
|
15
|
+
import { SignOut } from '@os-design/icons';
|
|
16
|
+
import { css } from '@emotion/react';
|
|
17
|
+
import { type SessionListItem_session$key } from './__generated__/SessionListItem_session.graphql';
|
|
18
|
+
import getLastSeen from './getLastSeen';
|
|
19
|
+
import formatDate from './formatDate';
|
|
20
|
+
import { type SessionListItemDestroySessionMutation } from './__generated__/SessionListItemDestroySessionMutation.graphql';
|
|
21
|
+
import UnknownDeviceIcon from '../shared/icons/UnknownDeviceIcon';
|
|
22
|
+
import BrowserIcon from '../shared/icons/BrowserIcon';
|
|
23
|
+
import AppleIcon from '../shared/icons/AppleIcon';
|
|
24
|
+
import AndroidIcon from '../shared/icons/AndroidIcon';
|
|
25
|
+
|
|
26
|
+
const sessionListItemFragment = graphql`
|
|
27
|
+
fragment SessionListItem_session on SessionPayload {
|
|
28
|
+
id
|
|
29
|
+
isApp
|
|
30
|
+
browserName
|
|
31
|
+
browserVersion
|
|
32
|
+
osName
|
|
33
|
+
osVersion
|
|
34
|
+
deviceType
|
|
35
|
+
deviceName
|
|
36
|
+
deviceManufacturer
|
|
37
|
+
deviceBrand
|
|
38
|
+
deviceModel
|
|
39
|
+
ip
|
|
40
|
+
country
|
|
41
|
+
city
|
|
42
|
+
lastSeenAt
|
|
43
|
+
}
|
|
44
|
+
`;
|
|
45
|
+
|
|
46
|
+
interface SessionListItemProps {
|
|
47
|
+
sessionKey: SessionListItem_session$key;
|
|
48
|
+
hideLastSeenAt?: boolean;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
export const Container = styled.div`
|
|
52
|
+
display: flex;
|
|
53
|
+
position: relative;
|
|
54
|
+
padding: 0.5em 0;
|
|
55
|
+
overflow: hidden;
|
|
56
|
+
|
|
57
|
+
&:not(:last-of-type) {
|
|
58
|
+
border-bottom: 1px solid ${(p) => clr(p.theme.listItemColorBorder)};
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
@media (hover: hover) {
|
|
62
|
+
// Hide actions by default
|
|
63
|
+
& > nav {
|
|
64
|
+
opacity: 0;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
// Display actions either on focus, or on hover
|
|
68
|
+
&:hover,
|
|
69
|
+
&:focus-within {
|
|
70
|
+
& > nav {
|
|
71
|
+
opacity: 1;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
${horizontalPaddingStyles()};
|
|
77
|
+
`;
|
|
78
|
+
|
|
79
|
+
const Info = styled.div`
|
|
80
|
+
font-size: ${(p) => p.theme.sizes.small}em;
|
|
81
|
+
${ellipsisStyles};
|
|
82
|
+
`;
|
|
83
|
+
|
|
84
|
+
export const Content = styled.div`
|
|
85
|
+
flex: 1;
|
|
86
|
+
overflow: hidden;
|
|
87
|
+
`;
|
|
88
|
+
|
|
89
|
+
const Title = styled(Info)`
|
|
90
|
+
font-weight: 500;
|
|
91
|
+
`;
|
|
92
|
+
|
|
93
|
+
const LastSeen = styled(Info)`
|
|
94
|
+
color: ${(p) => clr(p.theme.inputColorPlaceholder)};
|
|
95
|
+
`;
|
|
96
|
+
|
|
97
|
+
const hasSwipeStyles = (p) =>
|
|
98
|
+
p.hasSwipe &&
|
|
99
|
+
css`
|
|
100
|
+
transform: translateX(100%);
|
|
101
|
+
${transitionStyles('transform')(p)};
|
|
102
|
+
`;
|
|
103
|
+
|
|
104
|
+
const openedStyles = (p) =>
|
|
105
|
+
p.opened &&
|
|
106
|
+
css`
|
|
107
|
+
transform: translateX(0);
|
|
108
|
+
`;
|
|
109
|
+
|
|
110
|
+
interface ActionsProps {
|
|
111
|
+
hasSwipe: boolean;
|
|
112
|
+
opened: boolean;
|
|
113
|
+
}
|
|
114
|
+
const Actions = styled(
|
|
115
|
+
'nav',
|
|
116
|
+
omitEmotionProps('hasSwipe', 'opened')
|
|
117
|
+
)<ActionsProps>`
|
|
118
|
+
position: absolute;
|
|
119
|
+
top: 0;
|
|
120
|
+
right: 0;
|
|
121
|
+
bottom: 0;
|
|
122
|
+
|
|
123
|
+
display: flex;
|
|
124
|
+
align-items: center;
|
|
125
|
+
|
|
126
|
+
background: linear-gradient(
|
|
127
|
+
to right,
|
|
128
|
+
${(p) => clr([...p.theme.colorBg.slice(0, 3), 0] as Color)},
|
|
129
|
+
${(p) => clr(p.theme.colorBg)}
|
|
130
|
+
${(p) => p.theme.listItemActionsPaddingLeft}em
|
|
131
|
+
);
|
|
132
|
+
|
|
133
|
+
${hasSwipeStyles};
|
|
134
|
+
${openedStyles};
|
|
135
|
+
${horizontalPaddingStyles('right')};
|
|
136
|
+
`;
|
|
137
|
+
|
|
138
|
+
export const IconContainer = styled.div`
|
|
139
|
+
display: flex;
|
|
140
|
+
justify-content: center;
|
|
141
|
+
align-items: center;
|
|
142
|
+
margin-right: 0.6em;
|
|
143
|
+
`;
|
|
144
|
+
|
|
145
|
+
interface IconProps {
|
|
146
|
+
bgColor: string;
|
|
147
|
+
}
|
|
148
|
+
export const Icon = styled('div', omitEmotionProps('bgColor'))<IconProps>`
|
|
149
|
+
font-size: 1.4em;
|
|
150
|
+
width: 1.3em;
|
|
151
|
+
height: 1.3em;
|
|
152
|
+
|
|
153
|
+
svg {
|
|
154
|
+
height: 1.3em;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
display: flex;
|
|
158
|
+
justify-content: center;
|
|
159
|
+
align-items: center;
|
|
160
|
+
|
|
161
|
+
border-radius: ${(p) => p.theme.borderRadius}em;
|
|
162
|
+
background-color: ${(p) => p.bgColor};
|
|
163
|
+
color: hsl(0, 0%, 100%);
|
|
164
|
+
`;
|
|
165
|
+
|
|
166
|
+
const nameVersionToString = (
|
|
167
|
+
name?: string | null,
|
|
168
|
+
version?: string | null
|
|
169
|
+
): string | null => {
|
|
170
|
+
if (!name) return null;
|
|
171
|
+
return `${name}${version ? ` ${version}` : ''}`;
|
|
172
|
+
};
|
|
173
|
+
|
|
174
|
+
const mergeInfo = (...args: Array<string | null | undefined>): string | null =>
|
|
175
|
+
args.filter((item) => item !== null && item !== undefined).join(', ') || null;
|
|
176
|
+
|
|
177
|
+
const SessionListItem: React.FC<SessionListItemProps> = ({
|
|
178
|
+
sessionKey,
|
|
179
|
+
hideLastSeenAt,
|
|
180
|
+
}) => {
|
|
181
|
+
const session = useFragment(sessionListItemFragment, sessionKey);
|
|
182
|
+
const { t, i18n } = useTranslation(['profile']);
|
|
183
|
+
const touchDevice = useMemo(() => isTouchDevice(), []);
|
|
184
|
+
const { opened, handlers } = useSwipe();
|
|
185
|
+
|
|
186
|
+
const browser = useMemo(
|
|
187
|
+
() => nameVersionToString(session.browserName, session.browserVersion),
|
|
188
|
+
[session.browserName, session.browserVersion]
|
|
189
|
+
);
|
|
190
|
+
|
|
191
|
+
const os = useMemo(
|
|
192
|
+
() => nameVersionToString(session.osName, session.osVersion),
|
|
193
|
+
[session.osName, session.osVersion]
|
|
194
|
+
);
|
|
195
|
+
|
|
196
|
+
const deviceBrandModel = useMemo(() => {
|
|
197
|
+
const arr = [session.deviceBrand, session.deviceModel];
|
|
198
|
+
// Include the manufacturer name only if it does not equal to the brand name.
|
|
199
|
+
// For example, it allows to avoid "Apple Apple iPhone 6".
|
|
200
|
+
if (session.deviceManufacturer !== session.deviceBrand) {
|
|
201
|
+
arr.unshift(session.deviceManufacturer);
|
|
202
|
+
}
|
|
203
|
+
return arr.filter((item) => item !== null).join(' ') || null;
|
|
204
|
+
}, [session.deviceBrand, session.deviceManufacturer, session.deviceModel]);
|
|
205
|
+
|
|
206
|
+
const title = useMemo(() => {
|
|
207
|
+
let deviceType = (session.deviceType || 'unknown').toLowerCase();
|
|
208
|
+
if (browser) deviceType = 'browser';
|
|
209
|
+
return `${
|
|
210
|
+
t('profile:sessions.deviceType', { returnObjects: true })[deviceType]
|
|
211
|
+
}${session.deviceName ? ` ${session.deviceName}` : ''}`;
|
|
212
|
+
}, [browser, session.deviceName, session.deviceType, t]);
|
|
213
|
+
|
|
214
|
+
const deviceInfo = useMemo(
|
|
215
|
+
() =>
|
|
216
|
+
session.isApp ? mergeInfo(deviceBrandModel, os) : mergeInfo(browser, os),
|
|
217
|
+
[browser, deviceBrandModel, os, session.isApp]
|
|
218
|
+
);
|
|
219
|
+
|
|
220
|
+
const ip = useMemo(() => {
|
|
221
|
+
if (!session.ip) return null;
|
|
222
|
+
const location = mergeInfo(session.city, session.country);
|
|
223
|
+
return `${session.ip}${location ? ` (${location})` : ''}`;
|
|
224
|
+
}, [session.city, session.country, session.ip]);
|
|
225
|
+
|
|
226
|
+
const lastSeen = useMemo(() => {
|
|
227
|
+
const lsa = getLastSeen(session.lastSeenAt);
|
|
228
|
+
if (!lsa) {
|
|
229
|
+
return `${t('profile:sessions.lastSeenOn')} ${formatDate(
|
|
230
|
+
session.lastSeenAt,
|
|
231
|
+
t,
|
|
232
|
+
i18n.language
|
|
233
|
+
)}`;
|
|
234
|
+
}
|
|
235
|
+
return `${t('profile:sessions.lastSeen')} ${lsa[0]} ${pluralForms({
|
|
236
|
+
language: i18n.language,
|
|
237
|
+
forms: t(`profile:sessions.${lsa[1]}`, { returnObjects: true }),
|
|
238
|
+
number: lsa[0],
|
|
239
|
+
})} ${t('profile:sessions.ago')}`;
|
|
240
|
+
}, [i18n.language, session.lastSeenAt, t]);
|
|
241
|
+
|
|
242
|
+
const [iconComponent, iconColor] = useMemo(() => {
|
|
243
|
+
if (browser) return [<BrowserIcon key='icon' />, 'hsl(30, 60%, 50%)'];
|
|
244
|
+
if (session.isApp) {
|
|
245
|
+
if (session.osName === 'iOS' || session.osName === 'iPhone OS') {
|
|
246
|
+
return [<AppleIcon key='icon' />, 'hsl(0, 0%, 50%)'];
|
|
247
|
+
}
|
|
248
|
+
if (session.osName === 'Android')
|
|
249
|
+
return [<AndroidIcon key='icon' />, 'hsl(150, 60%, 50%)'];
|
|
250
|
+
}
|
|
251
|
+
return [<UnknownDeviceIcon key='icon' />, 'hsl(5, 60%, 50%)'];
|
|
252
|
+
}, [browser, session.isApp, session.osName]);
|
|
253
|
+
|
|
254
|
+
const [commitDestroySession, loadingDestroySession] =
|
|
255
|
+
useMutation<SessionListItemDestroySessionMutation>(graphql`
|
|
256
|
+
mutation SessionListItemDestroySessionMutation(
|
|
257
|
+
$input: DestroySessionInput!
|
|
258
|
+
) {
|
|
259
|
+
destroySession(input: $input) {
|
|
260
|
+
ok
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
`);
|
|
264
|
+
|
|
265
|
+
const destroySession = useCallback(() => {
|
|
266
|
+
commitDestroySession({
|
|
267
|
+
variables: {
|
|
268
|
+
input: {
|
|
269
|
+
id: session.id,
|
|
270
|
+
},
|
|
271
|
+
},
|
|
272
|
+
updater: (store) => {
|
|
273
|
+
// Delete the session from the store
|
|
274
|
+
const rootRP = store.getRoot();
|
|
275
|
+
const sessionsRP = rootRP
|
|
276
|
+
.getLinkedRecords('sessions')
|
|
277
|
+
?.filter((item) => item.getDataID() !== session.id);
|
|
278
|
+
if (!sessionsRP) return;
|
|
279
|
+
rootRP.setLinkedRecords(sessionsRP, 'sessions');
|
|
280
|
+
},
|
|
281
|
+
onError: (error) => {
|
|
282
|
+
message.error(error.message);
|
|
283
|
+
},
|
|
284
|
+
onCompleted: () => {
|
|
285
|
+
message.success(t('profile:sessions.destroyed'));
|
|
286
|
+
},
|
|
287
|
+
});
|
|
288
|
+
}, [commitDestroySession, session.id, t]);
|
|
289
|
+
|
|
290
|
+
return (
|
|
291
|
+
<Container {...handlers}>
|
|
292
|
+
<IconContainer>
|
|
293
|
+
<Icon bgColor={iconColor}>{iconComponent}</Icon>
|
|
294
|
+
</IconContainer>
|
|
295
|
+
|
|
296
|
+
<Content>
|
|
297
|
+
<Title>{title}</Title>
|
|
298
|
+
{deviceInfo && <Info>{deviceInfo}</Info>}
|
|
299
|
+
{ip && <Info>{ip}</Info>}
|
|
300
|
+
{!hideLastSeenAt && <LastSeen>{lastSeen}</LastSeen>}
|
|
301
|
+
</Content>
|
|
302
|
+
|
|
303
|
+
<Actions hasSwipe={touchDevice} opened={opened}>
|
|
304
|
+
<Button
|
|
305
|
+
type='ghost'
|
|
306
|
+
wide='never'
|
|
307
|
+
size='small'
|
|
308
|
+
loading={loadingDestroySession}
|
|
309
|
+
onClick={destroySession}
|
|
310
|
+
>
|
|
311
|
+
<SignOut />
|
|
312
|
+
</Button>
|
|
313
|
+
</Actions>
|
|
314
|
+
</Container>
|
|
315
|
+
);
|
|
316
|
+
};
|
|
317
|
+
|
|
318
|
+
export default SessionListItem;
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useTranslation } from 'react-i18next';
|
|
3
|
+
import { Skeleton } from '@os-design/core';
|
|
4
|
+
import styled from '@emotion/styled';
|
|
5
|
+
import { Container, Content, IconContainer } from './SessionListItem';
|
|
6
|
+
import { Title, List } from './SessionList';
|
|
7
|
+
|
|
8
|
+
const IconSkeleton = styled(Skeleton)`
|
|
9
|
+
width: 1.82em;
|
|
10
|
+
height: 1.82em;
|
|
11
|
+
`;
|
|
12
|
+
|
|
13
|
+
const ContainerSkeleton = styled(Container)`
|
|
14
|
+
padding: 0.8em 0;
|
|
15
|
+
`;
|
|
16
|
+
|
|
17
|
+
const TitleSkeleton = styled(Skeleton)`
|
|
18
|
+
height: ${(p) => p.theme.sizes.small}em;
|
|
19
|
+
`;
|
|
20
|
+
|
|
21
|
+
const InfoSkeleton = styled(TitleSkeleton)`
|
|
22
|
+
margin-top: 0.3em;
|
|
23
|
+
`;
|
|
24
|
+
|
|
25
|
+
const SessionListSkeleton: React.FC = () => {
|
|
26
|
+
const { t } = useTranslation(['profile']);
|
|
27
|
+
|
|
28
|
+
return (
|
|
29
|
+
<>
|
|
30
|
+
<Title>{t('profile:sessions.current')}</Title>
|
|
31
|
+
<List>
|
|
32
|
+
<ContainerSkeleton>
|
|
33
|
+
<IconContainer>
|
|
34
|
+
<IconSkeleton />
|
|
35
|
+
</IconContainer>
|
|
36
|
+
|
|
37
|
+
<Content>
|
|
38
|
+
<TitleSkeleton width='50%' />
|
|
39
|
+
<InfoSkeleton />
|
|
40
|
+
<InfoSkeleton width='90%' />
|
|
41
|
+
</Content>
|
|
42
|
+
</ContainerSkeleton>
|
|
43
|
+
</List>
|
|
44
|
+
</>
|
|
45
|
+
);
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
export default SessionListSkeleton;
|
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @generated SignedSource<<64df87dd058f26f9e4849449241ada0f>>
|
|
3
|
+
* @lightSyntaxTransform
|
|
4
|
+
* @nogrep
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
/* tslint:disable */
|
|
8
|
+
/* eslint-disable */
|
|
9
|
+
// @ts-nocheck
|
|
10
|
+
|
|
11
|
+
import { ConcreteRequest } from 'relay-runtime';
|
|
12
|
+
import { FragmentRefs } from "relay-runtime";
|
|
13
|
+
export type SessionDrawerContentQuery$variables = Record<PropertyKey, never>;
|
|
14
|
+
export type SessionDrawerContentQuery$data = {
|
|
15
|
+
readonly " $fragmentSpreads": FragmentRefs<"SessionList_sessions">;
|
|
16
|
+
};
|
|
17
|
+
export type SessionDrawerContentQuery = {
|
|
18
|
+
response: SessionDrawerContentQuery$data;
|
|
19
|
+
variables: SessionDrawerContentQuery$variables;
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
const node: ConcreteRequest = {
|
|
23
|
+
"fragment": {
|
|
24
|
+
"argumentDefinitions": [],
|
|
25
|
+
"kind": "Fragment",
|
|
26
|
+
"metadata": null,
|
|
27
|
+
"name": "SessionDrawerContentQuery",
|
|
28
|
+
"selections": [
|
|
29
|
+
{
|
|
30
|
+
"args": null,
|
|
31
|
+
"kind": "FragmentSpread",
|
|
32
|
+
"name": "SessionList_sessions"
|
|
33
|
+
}
|
|
34
|
+
],
|
|
35
|
+
"type": "Query",
|
|
36
|
+
"abstractKey": null
|
|
37
|
+
},
|
|
38
|
+
"kind": "Request",
|
|
39
|
+
"operation": {
|
|
40
|
+
"argumentDefinitions": [],
|
|
41
|
+
"kind": "Operation",
|
|
42
|
+
"name": "SessionDrawerContentQuery",
|
|
43
|
+
"selections": [
|
|
44
|
+
{
|
|
45
|
+
"alias": null,
|
|
46
|
+
"args": null,
|
|
47
|
+
"concreteType": "SessionPayload",
|
|
48
|
+
"kind": "LinkedField",
|
|
49
|
+
"name": "sessions",
|
|
50
|
+
"plural": true,
|
|
51
|
+
"selections": [
|
|
52
|
+
{
|
|
53
|
+
"alias": null,
|
|
54
|
+
"args": null,
|
|
55
|
+
"kind": "ScalarField",
|
|
56
|
+
"name": "id",
|
|
57
|
+
"storageKey": null
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
"alias": null,
|
|
61
|
+
"args": null,
|
|
62
|
+
"kind": "ScalarField",
|
|
63
|
+
"name": "current",
|
|
64
|
+
"storageKey": null
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
"alias": null,
|
|
68
|
+
"args": null,
|
|
69
|
+
"kind": "ScalarField",
|
|
70
|
+
"name": "lastSeenAt",
|
|
71
|
+
"storageKey": null
|
|
72
|
+
},
|
|
73
|
+
{
|
|
74
|
+
"alias": null,
|
|
75
|
+
"args": null,
|
|
76
|
+
"kind": "ScalarField",
|
|
77
|
+
"name": "isApp",
|
|
78
|
+
"storageKey": null
|
|
79
|
+
},
|
|
80
|
+
{
|
|
81
|
+
"alias": null,
|
|
82
|
+
"args": null,
|
|
83
|
+
"kind": "ScalarField",
|
|
84
|
+
"name": "browserName",
|
|
85
|
+
"storageKey": null
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
"alias": null,
|
|
89
|
+
"args": null,
|
|
90
|
+
"kind": "ScalarField",
|
|
91
|
+
"name": "browserVersion",
|
|
92
|
+
"storageKey": null
|
|
93
|
+
},
|
|
94
|
+
{
|
|
95
|
+
"alias": null,
|
|
96
|
+
"args": null,
|
|
97
|
+
"kind": "ScalarField",
|
|
98
|
+
"name": "osName",
|
|
99
|
+
"storageKey": null
|
|
100
|
+
},
|
|
101
|
+
{
|
|
102
|
+
"alias": null,
|
|
103
|
+
"args": null,
|
|
104
|
+
"kind": "ScalarField",
|
|
105
|
+
"name": "osVersion",
|
|
106
|
+
"storageKey": null
|
|
107
|
+
},
|
|
108
|
+
{
|
|
109
|
+
"alias": null,
|
|
110
|
+
"args": null,
|
|
111
|
+
"kind": "ScalarField",
|
|
112
|
+
"name": "deviceType",
|
|
113
|
+
"storageKey": null
|
|
114
|
+
},
|
|
115
|
+
{
|
|
116
|
+
"alias": null,
|
|
117
|
+
"args": null,
|
|
118
|
+
"kind": "ScalarField",
|
|
119
|
+
"name": "deviceName",
|
|
120
|
+
"storageKey": null
|
|
121
|
+
},
|
|
122
|
+
{
|
|
123
|
+
"alias": null,
|
|
124
|
+
"args": null,
|
|
125
|
+
"kind": "ScalarField",
|
|
126
|
+
"name": "deviceManufacturer",
|
|
127
|
+
"storageKey": null
|
|
128
|
+
},
|
|
129
|
+
{
|
|
130
|
+
"alias": null,
|
|
131
|
+
"args": null,
|
|
132
|
+
"kind": "ScalarField",
|
|
133
|
+
"name": "deviceBrand",
|
|
134
|
+
"storageKey": null
|
|
135
|
+
},
|
|
136
|
+
{
|
|
137
|
+
"alias": null,
|
|
138
|
+
"args": null,
|
|
139
|
+
"kind": "ScalarField",
|
|
140
|
+
"name": "deviceModel",
|
|
141
|
+
"storageKey": null
|
|
142
|
+
},
|
|
143
|
+
{
|
|
144
|
+
"alias": null,
|
|
145
|
+
"args": null,
|
|
146
|
+
"kind": "ScalarField",
|
|
147
|
+
"name": "ip",
|
|
148
|
+
"storageKey": null
|
|
149
|
+
},
|
|
150
|
+
{
|
|
151
|
+
"alias": null,
|
|
152
|
+
"args": null,
|
|
153
|
+
"kind": "ScalarField",
|
|
154
|
+
"name": "country",
|
|
155
|
+
"storageKey": null
|
|
156
|
+
},
|
|
157
|
+
{
|
|
158
|
+
"alias": null,
|
|
159
|
+
"args": null,
|
|
160
|
+
"kind": "ScalarField",
|
|
161
|
+
"name": "city",
|
|
162
|
+
"storageKey": null
|
|
163
|
+
}
|
|
164
|
+
],
|
|
165
|
+
"storageKey": null
|
|
166
|
+
}
|
|
167
|
+
]
|
|
168
|
+
},
|
|
169
|
+
"params": {
|
|
170
|
+
"cacheID": "cc7ef83584759c724bbad21b528477c2",
|
|
171
|
+
"id": null,
|
|
172
|
+
"metadata": {},
|
|
173
|
+
"name": "SessionDrawerContentQuery",
|
|
174
|
+
"operationKind": "query",
|
|
175
|
+
"text": "query SessionDrawerContentQuery {\n ...SessionList_sessions\n}\n\nfragment SessionListItem_session on SessionPayload {\n id\n isApp\n browserName\n browserVersion\n osName\n osVersion\n deviceType\n deviceName\n deviceManufacturer\n deviceBrand\n deviceModel\n ip\n country\n city\n lastSeenAt\n}\n\nfragment SessionList_sessions on Query {\n sessions {\n id\n current\n lastSeenAt\n ...SessionListItem_session\n }\n}\n"
|
|
176
|
+
}
|
|
177
|
+
};
|
|
178
|
+
|
|
179
|
+
(node as any).hash = "1643ac6b9bd324d389dab9011e55b1ba";
|
|
180
|
+
|
|
181
|
+
export default node;
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @generated SignedSource<<2218d8fc90b51a497af7a28a79b5b1cf>>
|
|
3
|
+
* @lightSyntaxTransform
|
|
4
|
+
* @nogrep
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
/* tslint:disable */
|
|
8
|
+
/* eslint-disable */
|
|
9
|
+
// @ts-nocheck
|
|
10
|
+
|
|
11
|
+
import { ConcreteRequest } from 'relay-runtime';
|
|
12
|
+
export type SessionListDestroyAllOtherSessionsMutation$variables = Record<PropertyKey, never>;
|
|
13
|
+
export type SessionListDestroyAllOtherSessionsMutation$data = {
|
|
14
|
+
readonly destroyAllOtherSessions: {
|
|
15
|
+
readonly ok: boolean;
|
|
16
|
+
};
|
|
17
|
+
};
|
|
18
|
+
export type SessionListDestroyAllOtherSessionsMutation = {
|
|
19
|
+
response: SessionListDestroyAllOtherSessionsMutation$data;
|
|
20
|
+
variables: SessionListDestroyAllOtherSessionsMutation$variables;
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
const node: ConcreteRequest = (function(){
|
|
24
|
+
var v0 = [
|
|
25
|
+
{
|
|
26
|
+
"alias": null,
|
|
27
|
+
"args": null,
|
|
28
|
+
"concreteType": "StatusPayload",
|
|
29
|
+
"kind": "LinkedField",
|
|
30
|
+
"name": "destroyAllOtherSessions",
|
|
31
|
+
"plural": false,
|
|
32
|
+
"selections": [
|
|
33
|
+
{
|
|
34
|
+
"alias": null,
|
|
35
|
+
"args": null,
|
|
36
|
+
"kind": "ScalarField",
|
|
37
|
+
"name": "ok",
|
|
38
|
+
"storageKey": null
|
|
39
|
+
}
|
|
40
|
+
],
|
|
41
|
+
"storageKey": null
|
|
42
|
+
}
|
|
43
|
+
];
|
|
44
|
+
return {
|
|
45
|
+
"fragment": {
|
|
46
|
+
"argumentDefinitions": [],
|
|
47
|
+
"kind": "Fragment",
|
|
48
|
+
"metadata": null,
|
|
49
|
+
"name": "SessionListDestroyAllOtherSessionsMutation",
|
|
50
|
+
"selections": (v0/*: any*/),
|
|
51
|
+
"type": "Mutation",
|
|
52
|
+
"abstractKey": null
|
|
53
|
+
},
|
|
54
|
+
"kind": "Request",
|
|
55
|
+
"operation": {
|
|
56
|
+
"argumentDefinitions": [],
|
|
57
|
+
"kind": "Operation",
|
|
58
|
+
"name": "SessionListDestroyAllOtherSessionsMutation",
|
|
59
|
+
"selections": (v0/*: any*/)
|
|
60
|
+
},
|
|
61
|
+
"params": {
|
|
62
|
+
"cacheID": "c6f556336ccb31f27b1c2f13c2ea9c06",
|
|
63
|
+
"id": null,
|
|
64
|
+
"metadata": {},
|
|
65
|
+
"name": "SessionListDestroyAllOtherSessionsMutation",
|
|
66
|
+
"operationKind": "mutation",
|
|
67
|
+
"text": "mutation SessionListDestroyAllOtherSessionsMutation {\n destroyAllOtherSessions {\n ok\n }\n}\n"
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
})();
|
|
71
|
+
|
|
72
|
+
(node as any).hash = "016b6b5e7ae228f7df552d97fa43bd40";
|
|
73
|
+
|
|
74
|
+
export default node;
|