2020-01-03 08:49:47 +00:00
|
|
|
import {
|
|
|
|
|
ReduxActionErrorTypes,
|
2020-08-03 14:18:48 +00:00
|
|
|
ReduxActionTypes,
|
2024-08-06 14:52:22 +00:00
|
|
|
} from "ee/constants/ReduxActionConstants";
|
2024-08-22 04:19:30 +00:00
|
|
|
import type { UpdateUserRequest, VerifyTokenRequest } from "ee/api/UserApi";
|
2024-08-06 14:52:22 +00:00
|
|
|
import type { FeatureFlags } from "ee/entities/FeatureFlag";
|
2023-07-18 07:33:18 +00:00
|
|
|
import type {
|
2024-01-24 06:44:16 +00:00
|
|
|
ProductAlert,
|
2023-07-18 07:33:18 +00:00
|
|
|
ProductAlertConfig,
|
|
|
|
|
ProductAlertState,
|
|
|
|
|
} from "reducers/uiReducers/usersReducer";
|
2024-01-24 06:44:16 +00:00
|
|
|
import type { ApiResponse } from "api/ApiResponses";
|
2021-03-04 09:37:02 +00:00
|
|
|
|
Initialise comments (#3328)
* Initial scaffolding for comments CRUD APIs
* add actions
* add assets
* state management for existing comments and creating new
* add ui components
* add overlay comments wrapper to baseWidget
* add toggle comment mode button at editor header
* trigger tests
* Disallow commenting as someone else
* Add applicationId for comments
* lint
* Add overlay blacklist to prevent component interaction while adding comments
* Comment thread style updates
* Placeholder comment context menu
* Controlled comment thread visibility for making new comments visible by default
* Update comment type description
* Reset input on save
* Resolve comment thread button ui
* fix close on esc key, dont create new comment on outside click
* Submit on enter
* add emoji picker
* Attempt at adding a websocket server in Java
* CRUD APIs for comment threads
* Add API for getting all threads in application
* Move types to a separate file
* Initial commit for real time server (RTS)
* Add script to start RTS
* Fix position property
* Use create comment thread API
* Use add comment to thread API
* Add custom cursor
* Dispatch logout init on 401 errors
* Allow CORS for real time connection
* Add more logs to RTS
* Fix construction of MongoClient
* WIP: Real time comments
* Enable comments
* Minor updates
* Read backend API base URL from environment
* Escape to reset comments mode
* Set popover position as auto and boundary as scroll parent
* Disable warning
* Added permissions for comment threads
* Add resolved API for comment threads
* Migration to set commenting permission on existing apps
* Fix updates bringing the RTS down
* Show view latest button, scroll to bottom on creating a new comment
* Cleanup comment reducer
* Move to typescript for RTS
* Add missing server.ts and tsconfig files
* Resolve / unresolve comment
* Scaffold app comments
* Minor fixes: comment on top of all widgets, add toggle button at viewer header
* Reconnect socket on creating a new app, set connected status in store
* Retry socket connection flow
* Integration tests for comments with api mocks using msw
* Fix circular depependency
* rm file
* Minor cleanup and comments
* Minor refactors: move isScrolledToBottom to common hooks, decouple prevent interactions overlay from comments wrapper
* Use policies when pushing updates in RTS
* ENV var to set if comments are enabled
* Fix: check if editor/viewer is initialised before waiting for init action
* Add tests for comments reducer
* Revert "ENV var to set if comments are enabled"
This reverts commit 988efeaa69d378d943a387e1e73510334958adc5.
* Enable comments for users with appsmith email
* lint
* fix
* Try running a socket.io server inside backend
* Update comment reducer tests
* Init mentions within comments
* Fix comment thread updates with email rooms
* Minor fixes
* Refactors / review suggestions
* lint
* increase cache limit for builds
* Comment out tests for feature that's under development
* Add Dockerfile for RTS
* Fix policies missing for first comment in threads
* Use draftJS for comments input with mentions support
* fix fixtures
* Use thread's policies when querying for threads
* Update socket.io to v4
* Add support for richer body with mentions
* Update comment body type to RawDraftContentState
* fix stale method
* Fix mentions search
* Minor cleanups
* Comment context menu and thread UI updates
* revert: Scaffold app comments
* Yarn dependencies
* Delete comment using id api added
* Init app comments
* Add test for creating thread
* Api for delete comment with id
* Test comment creation response and policies
* Copy comment links
* Fix reset editor state
* Delete valid comment testcase added
* Delete comment TC : code refactor
* Don't allow creating comments with an empty body
* Pin comments WIP[]
* Ignore dependency-reduced-pom.xml files from VCS
* Cleanup of some dev-only files, for review
* Delete comment
* Update socket.io to v4 in RTS
* Pin and resolve comment thread object added in commentThread
* Pin and resolve comment thread object added in commentThread
* Update comment thread API
* Added creationTime and updationTime in comment thread response
* Added creationTime and updationTime in comment thread response
* Added human readable id to comment threads, fallback to username for null name in user document
* Refactor
* lint
* fix test, rm duplicate selector
* comment out saga used for dev
* CommentThread viewed status, username fallback for getName=null, username field added in pin & resolve status
* lint
* trigger tests
Co-authored-by: Shrikant Sharat Kandula <shrikant@appsmith.com>
Co-authored-by: Abhijeet <abhi.nagarnaik@gmail.com>
2021-04-29 10:33:51 +00:00
|
|
|
export const logoutUser = (payload?: { redirectURL: string }) => ({
|
2021-03-04 09:37:02 +00:00
|
|
|
type: ReduxActionTypes.LOGOUT_USER_INIT,
|
Initialise comments (#3328)
* Initial scaffolding for comments CRUD APIs
* add actions
* add assets
* state management for existing comments and creating new
* add ui components
* add overlay comments wrapper to baseWidget
* add toggle comment mode button at editor header
* trigger tests
* Disallow commenting as someone else
* Add applicationId for comments
* lint
* Add overlay blacklist to prevent component interaction while adding comments
* Comment thread style updates
* Placeholder comment context menu
* Controlled comment thread visibility for making new comments visible by default
* Update comment type description
* Reset input on save
* Resolve comment thread button ui
* fix close on esc key, dont create new comment on outside click
* Submit on enter
* add emoji picker
* Attempt at adding a websocket server in Java
* CRUD APIs for comment threads
* Add API for getting all threads in application
* Move types to a separate file
* Initial commit for real time server (RTS)
* Add script to start RTS
* Fix position property
* Use create comment thread API
* Use add comment to thread API
* Add custom cursor
* Dispatch logout init on 401 errors
* Allow CORS for real time connection
* Add more logs to RTS
* Fix construction of MongoClient
* WIP: Real time comments
* Enable comments
* Minor updates
* Read backend API base URL from environment
* Escape to reset comments mode
* Set popover position as auto and boundary as scroll parent
* Disable warning
* Added permissions for comment threads
* Add resolved API for comment threads
* Migration to set commenting permission on existing apps
* Fix updates bringing the RTS down
* Show view latest button, scroll to bottom on creating a new comment
* Cleanup comment reducer
* Move to typescript for RTS
* Add missing server.ts and tsconfig files
* Resolve / unresolve comment
* Scaffold app comments
* Minor fixes: comment on top of all widgets, add toggle button at viewer header
* Reconnect socket on creating a new app, set connected status in store
* Retry socket connection flow
* Integration tests for comments with api mocks using msw
* Fix circular depependency
* rm file
* Minor cleanup and comments
* Minor refactors: move isScrolledToBottom to common hooks, decouple prevent interactions overlay from comments wrapper
* Use policies when pushing updates in RTS
* ENV var to set if comments are enabled
* Fix: check if editor/viewer is initialised before waiting for init action
* Add tests for comments reducer
* Revert "ENV var to set if comments are enabled"
This reverts commit 988efeaa69d378d943a387e1e73510334958adc5.
* Enable comments for users with appsmith email
* lint
* fix
* Try running a socket.io server inside backend
* Update comment reducer tests
* Init mentions within comments
* Fix comment thread updates with email rooms
* Minor fixes
* Refactors / review suggestions
* lint
* increase cache limit for builds
* Comment out tests for feature that's under development
* Add Dockerfile for RTS
* Fix policies missing for first comment in threads
* Use draftJS for comments input with mentions support
* fix fixtures
* Use thread's policies when querying for threads
* Update socket.io to v4
* Add support for richer body with mentions
* Update comment body type to RawDraftContentState
* fix stale method
* Fix mentions search
* Minor cleanups
* Comment context menu and thread UI updates
* revert: Scaffold app comments
* Yarn dependencies
* Delete comment using id api added
* Init app comments
* Add test for creating thread
* Api for delete comment with id
* Test comment creation response and policies
* Copy comment links
* Fix reset editor state
* Delete valid comment testcase added
* Delete comment TC : code refactor
* Don't allow creating comments with an empty body
* Pin comments WIP[]
* Ignore dependency-reduced-pom.xml files from VCS
* Cleanup of some dev-only files, for review
* Delete comment
* Update socket.io to v4 in RTS
* Pin and resolve comment thread object added in commentThread
* Pin and resolve comment thread object added in commentThread
* Update comment thread API
* Added creationTime and updationTime in comment thread response
* Added creationTime and updationTime in comment thread response
* Added human readable id to comment threads, fallback to username for null name in user document
* Refactor
* lint
* fix test, rm duplicate selector
* comment out saga used for dev
* CommentThread viewed status, username fallback for getName=null, username field added in pin & resolve status
* lint
* trigger tests
Co-authored-by: Shrikant Sharat Kandula <shrikant@appsmith.com>
Co-authored-by: Abhijeet <abhi.nagarnaik@gmail.com>
2021-04-29 10:33:51 +00:00
|
|
|
payload,
|
2021-03-04 09:37:02 +00:00
|
|
|
});
|
2020-01-03 08:49:47 +00:00
|
|
|
|
2021-09-12 16:36:43 +00:00
|
|
|
export const logoutUserSuccess = (isEmptyInstance: boolean) => ({
|
2020-01-03 08:49:47 +00:00
|
|
|
type: ReduxActionTypes.LOGOUT_USER_SUCCESS,
|
2021-09-12 16:36:43 +00:00
|
|
|
payload: isEmptyInstance,
|
2020-01-03 08:49:47 +00:00
|
|
|
});
|
|
|
|
|
|
2024-07-31 15:41:28 +00:00
|
|
|
// TODO: Fix this the next time the file is edited
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
2020-01-03 08:49:47 +00:00
|
|
|
export const logoutUserError = (error: any) => ({
|
|
|
|
|
type: ReduxActionErrorTypes.LOGOUT_USER_ERROR,
|
|
|
|
|
payload: {
|
|
|
|
|
error,
|
|
|
|
|
},
|
|
|
|
|
});
|
2020-01-06 09:07:30 +00:00
|
|
|
|
|
|
|
|
export const verifyInviteSuccess = () => ({
|
|
|
|
|
type: ReduxActionTypes.VERIFY_INVITE_SUCCESS,
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
export const verifyInvite = (payload: VerifyTokenRequest) => ({
|
|
|
|
|
type: ReduxActionTypes.VERIFY_INVITE_INIT,
|
|
|
|
|
payload,
|
|
|
|
|
});
|
|
|
|
|
|
2024-07-31 15:41:28 +00:00
|
|
|
// TODO: Fix this the next time the file is edited
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
2020-01-06 09:07:30 +00:00
|
|
|
export const verifyInviteError = (error: any) => ({
|
|
|
|
|
type: ReduxActionErrorTypes.VERIFY_INVITE_ERROR,
|
|
|
|
|
payload: { error },
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
export const invitedUserSignupSuccess = () => ({
|
|
|
|
|
type: ReduxActionTypes.INVITED_USER_SIGNUP_SUCCESS,
|
|
|
|
|
});
|
|
|
|
|
|
2024-07-31 15:41:28 +00:00
|
|
|
// TODO: Fix this the next time the file is edited
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
2020-01-06 09:07:30 +00:00
|
|
|
export const invitedUserSignupError = (error: any) => ({
|
|
|
|
|
type: ReduxActionErrorTypes.INVITED_USER_SIGNUP_ERROR,
|
|
|
|
|
payload: {
|
|
|
|
|
error,
|
|
|
|
|
},
|
|
|
|
|
});
|
2021-03-04 09:37:02 +00:00
|
|
|
|
|
|
|
|
export const updateUserDetails = (payload: UpdateUserRequest) => ({
|
|
|
|
|
type: ReduxActionTypes.UPDATE_USER_DETAILS_INIT,
|
|
|
|
|
payload,
|
|
|
|
|
});
|
2021-05-20 12:03:08 +00:00
|
|
|
|
2023-04-28 20:00:15 +00:00
|
|
|
export const updateIntercomConsent = () => ({
|
|
|
|
|
type: ReduxActionTypes.UPDATE_USER_INTERCOM_CONSENT,
|
|
|
|
|
});
|
|
|
|
|
|
2021-05-20 12:03:08 +00:00
|
|
|
export const updatePhoto = (payload: {
|
|
|
|
|
file: File;
|
2021-12-02 05:56:41 +00:00
|
|
|
callback?: (id: string) => void;
|
2021-05-20 12:03:08 +00:00
|
|
|
}) => ({
|
|
|
|
|
type: ReduxActionTypes.UPLOAD_PROFILE_PHOTO,
|
|
|
|
|
payload,
|
|
|
|
|
});
|
|
|
|
|
|
2021-12-02 05:56:41 +00:00
|
|
|
export const removePhoto = (callback: (id: string) => void) => ({
|
2021-05-20 12:03:08 +00:00
|
|
|
type: ReduxActionTypes.REMOVE_PROFILE_PHOTO,
|
|
|
|
|
payload: { callback },
|
|
|
|
|
});
|
2021-06-02 09:56:22 +00:00
|
|
|
|
2021-12-02 05:56:41 +00:00
|
|
|
export const updatePhotoId = (payload: { photoId: string }) => ({
|
|
|
|
|
type: ReduxActionTypes.UPDATE_PHOTO_ID,
|
|
|
|
|
payload,
|
|
|
|
|
});
|
|
|
|
|
|
2022-06-15 15:37:41 +00:00
|
|
|
export const leaveWorkspace = (workspaceId: string) => {
|
2021-06-02 09:56:22 +00:00
|
|
|
return {
|
2022-06-15 15:37:41 +00:00
|
|
|
type: ReduxActionTypes.LEAVE_WORKSPACE_INIT,
|
2021-06-02 09:56:22 +00:00
|
|
|
payload: {
|
2022-06-15 15:37:41 +00:00
|
|
|
workspaceId,
|
2021-06-02 09:56:22 +00:00
|
|
|
},
|
|
|
|
|
};
|
|
|
|
|
};
|
2021-08-05 06:10:19 +00:00
|
|
|
|
2024-01-24 06:44:16 +00:00
|
|
|
export const fetchFeatureFlagsInit = (
|
|
|
|
|
featureFlags?: ApiResponse<FeatureFlags>,
|
|
|
|
|
) => ({
|
2021-08-05 06:10:19 +00:00
|
|
|
type: ReduxActionTypes.FETCH_FEATURE_FLAGS_INIT,
|
2024-01-24 06:44:16 +00:00
|
|
|
payload: {
|
|
|
|
|
featureFlags,
|
|
|
|
|
},
|
2021-08-05 06:10:19 +00:00
|
|
|
});
|
|
|
|
|
|
2022-04-07 17:57:32 +00:00
|
|
|
export const fetchFeatureFlagsSuccess = (payload: FeatureFlags) => ({
|
2021-08-05 06:10:19 +00:00
|
|
|
type: ReduxActionTypes.FETCH_FEATURE_FLAGS_SUCCESS,
|
2022-04-07 17:57:32 +00:00
|
|
|
payload,
|
2021-08-05 06:10:19 +00:00
|
|
|
});
|
|
|
|
|
|
2024-07-31 15:41:28 +00:00
|
|
|
// TODO: Fix this the next time the file is edited
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
2021-08-05 06:10:19 +00:00
|
|
|
export const fetchFeatureFlagsError = (error: any) => ({
|
|
|
|
|
type: ReduxActionErrorTypes.FETCH_FEATURE_FLAGS_ERROR,
|
|
|
|
|
payload: { error, show: false },
|
|
|
|
|
});
|
2023-07-18 07:33:18 +00:00
|
|
|
|
2024-01-24 06:44:16 +00:00
|
|
|
export const fetchProductAlertInit = (
|
|
|
|
|
productAlert?: ApiResponse<ProductAlert>,
|
|
|
|
|
) => ({
|
2023-07-18 07:33:18 +00:00
|
|
|
type: ReduxActionTypes.FETCH_PRODUCT_ALERT_INIT,
|
2024-01-24 06:44:16 +00:00
|
|
|
payload: {
|
|
|
|
|
productAlert,
|
|
|
|
|
},
|
2023-07-18 07:33:18 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
export const fetchProductAlertSuccess = (productAlert: ProductAlertState) => ({
|
|
|
|
|
type: ReduxActionTypes.FETCH_PRODUCT_ALERT_SUCCESS,
|
|
|
|
|
payload: productAlert,
|
|
|
|
|
});
|
|
|
|
|
|
2024-07-31 15:41:28 +00:00
|
|
|
// TODO: Fix this the next time the file is edited
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
2023-07-18 07:33:18 +00:00
|
|
|
export const fetchProductAlertFailure = (error: any) => ({
|
|
|
|
|
type: ReduxActionErrorTypes.FETCH_PRODUCT_ALERT_FAILED,
|
|
|
|
|
payload: { error, show: false },
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
export const updateProductAlertConfig = (config: ProductAlertConfig) => ({
|
|
|
|
|
type: ReduxActionTypes.UPDATE_PRODUCT_ALERT_CONFIG,
|
|
|
|
|
payload: config,
|
|
|
|
|
});
|