@ynput/ayon-frontend-shared 0.2.33 → 0.2.35
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/DetailsPanel.cjs.js +1 -1
- package/dist/DetailsPanel.es.js +26 -22
- package/dist/DetailsPanel.es.js.map +1 -1
- package/dist/Feed.cjs.js +1 -1
- package/dist/Feed.es.js +20 -15
- package/dist/Feed.es.js.map +1 -1
- package/dist/Views.cjs.js.map +1 -1
- package/dist/Views.es.js.map +1 -1
- package/dist/_virtual/attach-listener.cjs.js +2 -0
- package/dist/_virtual/attach-listener.cjs.js.map +1 -0
- package/dist/_virtual/attach-listener.es.js +5 -0
- package/dist/_virtual/attach-listener.es.js.map +1 -0
- package/dist/_virtual/attach-shared-listeners.cjs.js +2 -0
- package/dist/_virtual/attach-shared-listeners.cjs.js.map +1 -0
- package/dist/_virtual/attach-shared-listeners.es.js +5 -0
- package/dist/_virtual/attach-shared-listeners.es.js.map +1 -0
- package/dist/_virtual/constants.cjs.js +2 -0
- package/dist/_virtual/constants.cjs.js.map +1 -0
- package/dist/_virtual/constants.es.js +5 -0
- package/dist/_virtual/constants.es.js.map +1 -0
- package/dist/_virtual/create-or-join.cjs.js +2 -0
- package/dist/_virtual/create-or-join.cjs.js.map +1 -0
- package/dist/_virtual/create-or-join.es.js +5 -0
- package/dist/_virtual/create-or-join.es.js.map +1 -0
- package/dist/_virtual/get-url.cjs.js +2 -0
- package/dist/_virtual/get-url.cjs.js.map +1 -0
- package/dist/_virtual/get-url.es.js +5 -0
- package/dist/_virtual/get-url.es.js.map +1 -0
- package/dist/_virtual/globals.cjs.js +2 -0
- package/dist/_virtual/globals.cjs.js.map +1 -0
- package/dist/_virtual/globals.es.js +5 -0
- package/dist/_virtual/globals.es.js.map +1 -0
- package/dist/_virtual/heartbeat.cjs.js +2 -0
- package/dist/_virtual/heartbeat.cjs.js.map +1 -0
- package/dist/_virtual/heartbeat.es.js +5 -0
- package/dist/_virtual/heartbeat.es.js.map +1 -0
- package/dist/_virtual/index.cjs.js +1 -1
- package/dist/_virtual/index.cjs10.js +1 -1
- package/dist/_virtual/index.cjs11.js +2 -0
- package/dist/_virtual/index.cjs11.js.map +1 -0
- package/dist/_virtual/index.cjs12.js +2 -0
- package/dist/_virtual/index.cjs12.js.map +1 -0
- package/dist/_virtual/index.cjs2.js +1 -1
- package/dist/_virtual/index.cjs3.js +1 -1
- package/dist/_virtual/index.cjs4.js +1 -1
- package/dist/_virtual/index.cjs6.js +1 -1
- package/dist/_virtual/index.cjs8.js +1 -1
- package/dist/_virtual/index.cjs9.js +1 -1
- package/dist/_virtual/index.es.js +5 -4
- package/dist/_virtual/index.es10.js +5 -5
- package/dist/_virtual/index.es11.js +8 -0
- package/dist/_virtual/index.es11.js.map +1 -0
- package/dist/_virtual/index.es12.js +8 -0
- package/dist/_virtual/index.es12.js.map +1 -0
- package/dist/_virtual/index.es2.js +2 -2
- package/dist/_virtual/index.es3.js +5 -2
- package/dist/_virtual/index.es3.js.map +1 -1
- package/dist/_virtual/index.es4.js +2 -5
- package/dist/_virtual/index.es4.js.map +1 -1
- package/dist/_virtual/index.es6.js +5 -5
- package/dist/_virtual/index.es8.js +4 -4
- package/dist/_virtual/index.es9.js +2 -5
- package/dist/_virtual/index.es9.js.map +1 -1
- package/dist/_virtual/manage-subscribers.cjs.js +2 -0
- package/dist/_virtual/manage-subscribers.cjs.js.map +1 -0
- package/dist/_virtual/manage-subscribers.es.js +5 -0
- package/dist/_virtual/manage-subscribers.es.js.map +1 -0
- package/dist/_virtual/proxy.cjs.js +2 -0
- package/dist/_virtual/proxy.cjs.js.map +1 -0
- package/dist/_virtual/proxy.es.js +5 -0
- package/dist/_virtual/proxy.es.js.map +1 -0
- package/dist/_virtual/socket-io.cjs.js +2 -0
- package/dist/_virtual/socket-io.cjs.js.map +1 -0
- package/dist/_virtual/socket-io.es.js +5 -0
- package/dist/_virtual/socket-io.es.js.map +1 -0
- package/dist/_virtual/use-event-source.cjs.js +2 -0
- package/dist/_virtual/use-event-source.cjs.js.map +1 -0
- package/dist/_virtual/use-event-source.es.js +5 -0
- package/dist/_virtual/use-event-source.es.js.map +1 -0
- package/dist/_virtual/use-socket-io.cjs.js +2 -0
- package/dist/_virtual/use-socket-io.cjs.js.map +1 -0
- package/dist/_virtual/use-socket-io.es.js +5 -0
- package/dist/_virtual/use-socket-io.es.js.map +1 -0
- package/dist/_virtual/use-websocket.cjs.js +2 -0
- package/dist/_virtual/use-websocket.cjs.js.map +1 -0
- package/dist/_virtual/use-websocket.es.js +5 -0
- package/dist/_virtual/use-websocket.es.js.map +1 -0
- package/dist/_virtual/util.cjs.js +2 -0
- package/dist/_virtual/util.cjs.js.map +1 -0
- package/dist/_virtual/util.es.js +5 -0
- package/dist/_virtual/util.es.js.map +1 -0
- package/dist/api.cjs.js +1 -1
- package/dist/api.es.js +234 -226
- package/dist/api.es.js.map +1 -1
- package/dist/components.cjs.js +1 -1
- package/dist/components.es.js +60 -56
- package/dist/components.es.js.map +1 -1
- package/dist/context.cjs.js +1 -1
- package/dist/context.es.js +17 -13
- package/dist/context.es.js.map +1 -1
- package/dist/index.cjs.js +1 -1
- package/dist/index.es.js +13 -9
- package/dist/index.es.js.map +1 -1
- package/dist/node_modules/match-sorter/dist/match-sorter.esm.cjs.js +1 -1
- package/dist/node_modules/match-sorter/dist/match-sorter.esm.es.js +1 -1
- package/dist/node_modules/parse-numeric-range/index.cjs.js +1 -1
- package/dist/node_modules/parse-numeric-range/index.es.js +1 -1
- package/dist/node_modules/react-use-websocket/dist/index.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/index.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/index.es.js +36 -0
- package/dist/node_modules/react-use-websocket/dist/index.es.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/attach-listener.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/lib/attach-listener.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/attach-listener.es.js +79 -0
- package/dist/node_modules/react-use-websocket/dist/lib/attach-listener.es.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/attach-shared-listeners.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/lib/attach-shared-listeners.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/attach-shared-listeners.es.js +72 -0
- package/dist/node_modules/react-use-websocket/dist/lib/attach-shared-listeners.es.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/constants.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/lib/constants.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/constants.es.js +32 -0
- package/dist/node_modules/react-use-websocket/dist/lib/constants.es.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/create-or-join.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/lib/create-or-join.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/create-or-join.es.js +53 -0
- package/dist/node_modules/react-use-websocket/dist/lib/create-or-join.es.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/get-url.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/lib/get-url.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/get-url.es.js +144 -0
- package/dist/node_modules/react-use-websocket/dist/lib/get-url.es.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/globals.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/lib/globals.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/globals.es.js +19 -0
- package/dist/node_modules/react-use-websocket/dist/lib/globals.es.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/heartbeat.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/lib/heartbeat.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/heartbeat.es.js +35 -0
- package/dist/node_modules/react-use-websocket/dist/lib/heartbeat.es.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/manage-subscribers.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/lib/manage-subscribers.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/manage-subscribers.es.js +36 -0
- package/dist/node_modules/react-use-websocket/dist/lib/manage-subscribers.es.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/proxy.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/lib/proxy.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/proxy.es.js +24 -0
- package/dist/node_modules/react-use-websocket/dist/lib/proxy.es.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/socket-io.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/lib/socket-io.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/socket-io.es.js +39 -0
- package/dist/node_modules/react-use-websocket/dist/lib/socket-io.es.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/use-event-source.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/lib/use-event-source.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/use-event-source.es.js +51 -0
- package/dist/node_modules/react-use-websocket/dist/lib/use-event-source.es.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/use-socket-io.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/lib/use-socket-io.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/use-socket-io.es.js +54 -0
- package/dist/node_modules/react-use-websocket/dist/lib/use-socket-io.es.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/use-websocket.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/lib/use-websocket.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/use-websocket.es.js +198 -0
- package/dist/node_modules/react-use-websocket/dist/lib/use-websocket.es.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/util.cjs.js +2 -0
- package/dist/node_modules/react-use-websocket/dist/lib/util.cjs.js.map +1 -0
- package/dist/node_modules/react-use-websocket/dist/lib/util.es.js +21 -0
- package/dist/node_modules/react-use-websocket/dist/lib/util.es.js.map +1 -0
- package/dist/node_modules/rehype/node_modules/unified/lib/index.cjs.js +1 -1
- package/dist/node_modules/rehype/node_modules/unified/lib/index.cjs.js.map +1 -1
- package/dist/node_modules/rehype/node_modules/unified/lib/index.es.js +2 -2
- package/dist/node_modules/rehype/node_modules/vfile/lib/index.cjs.js +1 -1
- package/dist/node_modules/rehype/node_modules/vfile/lib/index.cjs.js.map +1 -1
- package/dist/node_modules/rehype/node_modules/vfile/lib/index.es.js +1 -1
- package/dist/node_modules/rehype-parse/lib/index.cjs.js +1 -1
- package/dist/node_modules/rehype-parse/lib/index.cjs.js.map +1 -1
- package/dist/node_modules/rehype-parse/lib/index.es.js +1 -1
- package/dist/node_modules/rehype-prism-plus/dist/index.es.cjs.js +1 -1
- package/dist/node_modules/rehype-prism-plus/dist/index.es.es.js +1 -1
- package/dist/node_modules/remove-accents/index.cjs.js +1 -1
- package/dist/node_modules/remove-accents/index.es.js +1 -1
- package/dist/shared/node_modules/prop-types/index.cjs.js +1 -1
- package/dist/shared/node_modules/prop-types/index.es.js +1 -1
- package/dist/shared/node_modules/react-is/index.cjs.js +1 -1
- package/dist/shared/node_modules/react-is/index.es.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/CSSTransition.cjs.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/CSSTransition.cjs.js.map +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/CSSTransition.es.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/Transition.cjs.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/Transition.cjs.js.map +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/Transition.es.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/utils/PropTypes.cjs.js +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/utils/PropTypes.cjs.js.map +1 -1
- package/dist/shared/node_modules/react-transition-group/esm/utils/PropTypes.es.js +1 -1
- package/dist/shared/src/api/base/client.cjs.js +1 -1
- package/dist/shared/src/api/base/client.cjs.js.map +1 -1
- package/dist/shared/src/api/base/client.es.js +12 -10
- package/dist/shared/src/api/base/client.es.js.map +1 -1
- package/dist/shared/src/api/generated/entityLists.cjs.js +1 -1
- package/dist/shared/src/api/generated/entityLists.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/entityLists.es.js +4 -1
- package/dist/shared/src/api/generated/entityLists.es.js.map +1 -1
- package/dist/shared/src/api/generated/graphql.cjs.js +10 -7
- package/dist/shared/src/api/generated/graphql.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/graphql.es.js +15 -12
- package/dist/shared/src/api/generated/graphql.es.js.map +1 -1
- package/dist/shared/src/api/generated/projects.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/projects.es.js.map +1 -1
- package/dist/shared/src/api/generated/views.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/views.es.js.map +1 -1
- package/dist/shared/src/api/queries/activities/getActivities.cjs.js +1 -1
- package/dist/shared/src/api/queries/activities/getActivities.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/activities/getActivities.es.js +71 -60
- package/dist/shared/src/api/queries/activities/getActivities.es.js.map +1 -1
- package/dist/shared/src/api/queries/activities/getCategories.cjs.js +1 -1
- package/dist/shared/src/api/queries/activities/getCategories.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/activities/getCategories.es.js +11 -6
- package/dist/shared/src/api/queries/activities/getCategories.es.js.map +1 -1
- package/dist/shared/src/api/queries/activities/updateActivities.cjs.js +1 -1
- package/dist/shared/src/api/queries/activities/updateActivities.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/activities/updateActivities.es.js +1 -1
- package/dist/shared/src/api/queries/activities/updateActivities.es.js.map +1 -1
- package/dist/shared/src/api/queries/activities/updateReaction.cjs.js +1 -1
- package/dist/shared/src/api/queries/activities/updateReaction.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/activities/updateReaction.es.js +1 -1
- package/dist/shared/src/api/queries/activities/updateReaction.es.js.map +1 -1
- package/dist/shared/src/api/queries/activities/util/activityRealtimeHandler.cjs.js +2 -0
- package/dist/shared/src/api/queries/activities/util/activityRealtimeHandler.cjs.js.map +1 -0
- package/dist/shared/src/api/queries/activities/util/activityRealtimeHandler.es.js +144 -0
- package/dist/shared/src/api/queries/activities/util/activityRealtimeHandler.es.js.map +1 -0
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js +1 -1
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js +4 -3
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js.map +1 -1
- package/dist/shared/src/api/queries/entities/updateEntity.cjs.js +1 -1
- package/dist/shared/src/api/queries/entities/updateEntity.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entities/updateEntity.es.js +31 -30
- package/dist/shared/src/api/queries/entities/updateEntity.es.js.map +1 -1
- package/dist/shared/src/api/queries/entityLists/getLists.cjs.js +1 -1
- package/dist/shared/src/api/queries/entityLists/getLists.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entityLists/getLists.es.js +68 -68
- package/dist/shared/src/api/queries/entityLists/getLists.es.js.map +1 -1
- package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js +1 -1
- package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entityLists/updateLists.es.js +47 -49
- package/dist/shared/src/api/queries/entityLists/updateLists.es.js.map +1 -1
- package/dist/shared/src/api/queries/overview/updateOverview.cjs.js +1 -1
- package/dist/shared/src/api/queries/overview/updateOverview.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/overview/updateOverview.es.js +7 -6
- package/dist/shared/src/api/queries/overview/updateOverview.es.js.map +1 -1
- package/dist/shared/src/api/queries/users/getUsers.cjs.js +2 -2
- package/dist/shared/src/api/queries/users/getUsers.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/users/getUsers.es.js +38 -33
- package/dist/shared/src/api/queries/users/getUsers.es.js.map +1 -1
- package/dist/shared/src/api/queries/users/guests.cjs.js +2 -0
- package/dist/shared/src/api/queries/users/guests.cjs.js.map +1 -0
- package/dist/shared/src/api/queries/users/guests.es.js +60 -0
- package/dist/shared/src/api/queries/users/guests.es.js.map +1 -0
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js +1 -1
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js +3 -2
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js +4 -2
- package/dist/shared/src/components/DetailsPanelAttributes/components/RenderFieldWidget.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/BorderedSection.cjs.js +4 -4
- package/dist/shared/src/components/DetailsPanelDetails/BorderedSection.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/BorderedSection.es.js +36 -35
- package/dist/shared/src/components/DetailsPanelDetails/BorderedSection.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.cjs.js +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.es.js +4 -2
- package/dist/shared/src/components/DetailsPanelDetails/DescriptionSection.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.cjs.js +2 -2
- package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.es.js +3 -2
- package/dist/shared/src/components/DetailsPanelDetails/DetailsPanelDetails.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityData.cjs.js +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityData.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityData.es.js +3 -2
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityData.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.cjs.js +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.es.js +3 -2
- package/dist/shared/src/components/DetailsPanelDetails/hooks/useEntityEditing.es.js.map +1 -1
- package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.cjs.js +1 -1
- package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.cjs.js.map +1 -1
- package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.es.js +30 -26
- package/dist/shared/src/components/EntityPanelUploader/EntityPanelUploader.es.js.map +1 -1
- package/dist/shared/src/components/EntityPath/SegmentProvider.cjs.js +1 -1
- package/dist/shared/src/components/EntityPath/SegmentProvider.cjs.js.map +1 -1
- package/dist/shared/src/components/EntityPath/SegmentProvider.es.js +3 -2
- package/dist/shared/src/components/EntityPath/SegmentProvider.es.js.map +1 -1
- package/dist/shared/src/components/Feedback/FeedbackContext.cjs.js +1 -1
- package/dist/shared/src/components/Feedback/FeedbackContext.cjs.js.map +1 -1
- package/dist/shared/src/components/Feedback/FeedbackContext.es.js +5 -4
- package/dist/shared/src/components/Feedback/FeedbackContext.es.js.map +1 -1
- package/dist/shared/src/components/LinksManager/AddNewLinks.cjs.js +1 -1
- package/dist/shared/src/components/LinksManager/AddNewLinks.cjs.js.map +1 -1
- package/dist/shared/src/components/LinksManager/AddNewLinks.es.js +6 -2
- package/dist/shared/src/components/LinksManager/AddNewLinks.es.js.map +1 -1
- package/dist/shared/src/components/LinksManager/LinkManagerItem.cjs.js +1 -1
- package/dist/shared/src/components/LinksManager/LinkManagerItem.cjs.js.map +1 -1
- package/dist/shared/src/components/LinksManager/LinkManagerItem.es.js +3 -2
- package/dist/shared/src/components/LinksManager/LinkManagerItem.es.js.map +1 -1
- package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.cjs.js +1 -1
- package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.cjs.js.map +1 -1
- package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.es.js +6 -2
- package/dist/shared/src/components/LinksManager/hooks/useUpdateLinks.es.js.map +1 -1
- package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.cjs.js +1 -1
- package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.cjs.js.map +1 -1
- package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.es.js +39 -38
- package/dist/shared/src/components/ListAttributeForm/ListAttributeForm.es.js.map +1 -1
- package/dist/shared/src/components/Powerpack/PowerpackButton.cjs.js +2 -2
- package/dist/shared/src/components/Powerpack/PowerpackButton.cjs.js.map +1 -1
- package/dist/shared/src/components/Powerpack/PowerpackButton.es.js +3 -2
- package/dist/shared/src/components/Powerpack/PowerpackButton.es.js.map +1 -1
- package/dist/shared/src/components/Powerpack/PowerpackDialog.cjs.js +1 -1
- package/dist/shared/src/components/Powerpack/PowerpackDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/Powerpack/PowerpackDialog.es.js +6 -2
- package/dist/shared/src/components/Powerpack/PowerpackDialog.es.js.map +1 -1
- package/dist/shared/src/components/Powerpack/RequiredAddonVersion.cjs.js +9 -0
- package/dist/shared/src/components/Powerpack/RequiredAddonVersion.cjs.js.map +1 -0
- package/dist/shared/src/components/Powerpack/RequiredAddonVersion.es.js +30 -0
- package/dist/shared/src/components/Powerpack/RequiredAddonVersion.es.js.map +1 -0
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js +1 -1
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js +8 -4
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/RowHeightSettings.cjs.js +1 -1
- package/dist/shared/src/components/ProjectTableSettings/RowHeightSettings.cjs.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/RowHeightSettings.es.js +6 -2
- package/dist/shared/src/components/ProjectTableSettings/RowHeightSettings.es.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js +1 -1
- package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.cjs.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js +19 -21
- package/dist/shared/src/components/ProjectTableSettings/TableSettingsFallback.es.js.map +1 -1
- package/dist/shared/src/components/QuillListStyles/QuillListStyles.cjs.js +1 -0
- package/dist/shared/src/components/QuillListStyles/QuillListStyles.cjs.js.map +1 -1
- package/dist/shared/src/components/QuillListStyles/QuillListStyles.es.js +1 -0
- package/dist/shared/src/components/QuillListStyles/QuillListStyles.es.js.map +1 -1
- package/dist/shared/src/components/RefreshToast/RefreshToast.cjs.js +2 -0
- package/dist/shared/src/components/RefreshToast/RefreshToast.cjs.js.map +1 -0
- package/dist/shared/src/components/RefreshToast/RefreshToast.es.js +10 -0
- package/dist/shared/src/components/RefreshToast/RefreshToast.es.js.map +1 -0
- package/dist/shared/src/components/RenameForm/RenameForm.cjs.js +2 -2
- package/dist/shared/src/components/RenameForm/RenameForm.cjs.js.map +1 -1
- package/dist/shared/src/components/RenameForm/RenameForm.es.js +6 -2
- package/dist/shared/src/components/RenameForm/RenameForm.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js +1 -1
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js +3 -2
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js +6 -2
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js +7 -3
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js +1 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js +6 -2
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.cjs.js +1 -1
- package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.es.js +3 -2
- package/dist/shared/src/components/ReviewablesList/useReviewablesUpload.es.js.map +1 -1
- package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.cjs.js +1 -1
- package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.cjs.js.map +1 -1
- package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js +3 -2
- package/dist/shared/src/components/SearchFilter/useBuildFilterOptions.es.js.map +1 -1
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.cjs.js +4 -4
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.cjs.js.map +1 -1
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.es.js +3 -2
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.es.js.map +1 -1
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js +1 -1
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js +6 -2
- package/dist/shared/src/components/SimpleFormDialog/SimpleFormDialog.es.js.map +1 -1
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.cjs.js +1 -1
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.cjs.js.map +1 -1
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.es.js +6 -5
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.es.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js +1 -1
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.cjs.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js +6 -2
- package/dist/shared/src/components/VersionUploader/components/UploadVersionForm.es.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.cjs.js +1 -1
- package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.cjs.js.map +1 -1
- package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.es.js +5 -4
- package/dist/shared/src/components/VersionUploader/context/VersionUploadContext.es.js.map +1 -1
- package/dist/shared/src/components/Watchers/Watchers.cjs.js +1 -1
- package/dist/shared/src/components/Watchers/Watchers.cjs.js.map +1 -1
- package/dist/shared/src/components/Watchers/Watchers.es.js +3 -2
- package/dist/shared/src/components/Watchers/Watchers.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js +1 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js +6 -2
- package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/Actions.cjs.js +1 -1
- package/dist/shared/src/containers/Actions/Actions.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/Actions.es.js +4 -2
- package/dist/shared/src/containers/Actions/Actions.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js +1 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js +6 -2
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js +130 -119
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js +6 -2
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js +49 -46
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js +7 -3
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js +4 -2
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedContextWrapper.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedContextWrapper.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedContextWrapper.es.js +4 -2
- package/dist/shared/src/containers/DetailsPanel/FeedContextWrapper.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.es.js +5 -2
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js +1 -1
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js +3 -2
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.cjs.js +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.cjs.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.es.js +6 -2
- package/dist/shared/src/containers/EntityPickerDialog/EntityPickerDialog.es.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.cjs.js +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.es.js +6 -2
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTable.es.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.cjs.js +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.cjs.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.es.js +6 -2
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableHeader.es.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.cjs.js +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.cjs.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.es.js +6 -2
- package/dist/shared/src/containers/EntityPickerDialog/components/EntityTypeTableSearch.es.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.cjs.js +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.cjs.js.map +1 -1
- package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.es.js +4 -2
- package/dist/shared/src/containers/EntityPickerDialog/hooks/useGetEntityPickerData.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/Feed.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/Feed.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/Feed.es.js +99 -102
- package/dist/shared/src/containers/Feed/Feed.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/Feed.styled.cjs.js +4 -4
- package/dist/shared/src/containers/Feed/Feed.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/Feed.styled.es.js +8 -7
- package/dist/shared/src/containers/Feed/Feed.styled.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.cjs.js +2 -2
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.es.js +42 -39
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.cjs.js +5 -4
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.es.js +38 -18
- package/dist/shared/src/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.es.js +128 -121
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.styled.cjs.js +6 -2
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.styled.es.js +9 -5
- package/dist/shared/src/containers/Feed/components/ActivityComment/ActivityComment.styled.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityHeader/ActivityHeader.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityHeader/ActivityHeader.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityHeader/ActivityHeader.es.js +28 -28
- package/dist/shared/src/containers/Feed/components/ActivityHeader/ActivityHeader.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.es.js +7 -6
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.cjs.js +2 -2
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.es.js +267 -248
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.styled.cjs.js +67 -12
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.styled.es.js +69 -14
- package/dist/shared/src/containers/Feed/components/CommentInput/CommentInput.styled.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.es.js +13 -10
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.es.js +6 -5
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.es.js +34 -31
- package/dist/shared/src/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/FileUploadCard/FileUploadCard.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/FileUploadCard/FileUploadCard.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/FileUploadCard/FileUploadCard.es.js +63 -51
- package/dist/shared/src/containers/Feed/components/FileUploadCard/FileUploadCard.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/FilesGrid/FilesGrid.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/FilesGrid/FilesGrid.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/FilesGrid/FilesGrid.es.js +35 -31
- package/dist/shared/src/containers/Feed/components/FilesGrid/FilesGrid.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/FilesGrid/FilesGrid.styled.cjs.js +1 -0
- package/dist/shared/src/containers/Feed/components/FilesGrid/FilesGrid.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/FilesGrid/FilesGrid.styled.es.js +3 -2
- package/dist/shared/src/containers/Feed/components/FilesGrid/FilesGrid.styled.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.es.js +27 -42
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ReactionContainer/Reactions.styled.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.es.js +4 -2
- package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/context/FeedContext.es.js +33 -30
- package/dist/shared/src/containers/Feed/context/FeedContext.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js +1 -1
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js +3 -2
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js +75 -71
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js +45 -41
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.es.js +6 -2
- package/dist/shared/src/containers/ProjectTreeTable/components/ColumnHeaderMenu.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js +6 -2
- package/dist/shared/src/containers/ProjectTreeTable/components/GroupSettingsFallback.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.es.js +6 -2
- package/dist/shared/src/containers/ProjectTreeTable/context/CellEditingProvider.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js +11 -10
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js +27 -23
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsProvider.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.es.js +3 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.es.js +7 -5
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildGroupByTableData.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js +4 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useBuildProjectDataTable.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js +6 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCellContextMenu.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.es.js +6 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useCheckSelectedCellsVisible.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.es.js +6 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useColumnGroupBy.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js +3 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useFetchOverviewData.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js +6 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetGroupedFields.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.es.js +3 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useGetTaskGroups.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js +6 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useKeyboardNavigation.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.es.js +6 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useMoveEntities.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.es.js +6 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/usePasteLinks.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.es.js +4 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useProjectTableModules.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js +6 -2
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useQueryFilters.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js +17 -13
- package/dist/shared/src/containers/ProjectTreeTable/utils/cellUtils.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/BooleanWidget.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/BooleanWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/BooleanWidget.es.js +7 -7
- package/dist/shared/src/containers/ProjectTreeTable/widgets/BooleanWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js +5 -3
- package/dist/shared/src/containers/ProjectTreeTable/widgets/CellWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.es.js +8 -4
- package/dist/shared/src/containers/ProjectTreeTable/widgets/LinksWidget.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.es.js +6 -2
- package/dist/shared/src/containers/ProjectTreeTable/widgets/NameWidget.es.js.map +1 -1
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js +1 -1
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js.map +1 -1
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js +6 -2
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js.map +1 -1
- package/dist/shared/src/containers/SimpleTable/SimpleTable.cjs.js +1 -1
- package/dist/shared/src/containers/SimpleTable/SimpleTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/SimpleTable/SimpleTable.es.js +37 -33
- package/dist/shared/src/containers/SimpleTable/SimpleTable.es.js.map +1 -1
- package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.cjs.js +1 -1
- package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.es.js +4 -2
- package/dist/shared/src/containers/Views/ViewsDialogContainer/ViewsDialogContainer.es.js.map +1 -1
- package/dist/shared/src/containers/Views/ViewsMenuContainer/ViewsMenuContainer.cjs.js +1 -1
- package/dist/shared/src/containers/Views/ViewsMenuContainer/ViewsMenuContainer.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/ViewsMenuContainer/ViewsMenuContainer.es.js +3 -2
- package/dist/shared/src/containers/Views/ViewsMenuContainer/ViewsMenuContainer.es.js.map +1 -1
- package/dist/shared/src/containers/Views/context/ViewsContext.cjs.js +1 -1
- package/dist/shared/src/containers/Views/context/ViewsContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/context/ViewsContext.es.js +6 -4
- package/dist/shared/src/containers/Views/context/ViewsContext.es.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.cjs.js +1 -1
- package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.es.js +4 -2
- package/dist/shared/src/containers/Views/hooks/useBuildViewMenuItems.es.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.cjs.js +1 -1
- package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.es.js +4 -2
- package/dist/shared/src/containers/Views/hooks/useSaveViewFromCurrent.es.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useSelectedView.cjs.js +1 -1
- package/dist/shared/src/containers/Views/hooks/useSelectedView.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useSelectedView.es.js +3 -2
- package/dist/shared/src/containers/Views/hooks/useSelectedView.es.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useViewsMutations.cjs.js +1 -1
- package/dist/shared/src/containers/Views/hooks/useViewsMutations.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/hooks/useViewsMutations.es.js +3 -2
- package/dist/shared/src/containers/Views/hooks/useViewsMutations.es.js.map +1 -1
- package/dist/shared/src/containers/Views/utils/viewUpdateHelper.cjs.js +1 -1
- package/dist/shared/src/containers/Views/utils/viewUpdateHelper.cjs.js.map +1 -1
- package/dist/shared/src/containers/Views/utils/viewUpdateHelper.es.js +3 -2
- package/dist/shared/src/containers/Views/utils/viewUpdateHelper.es.js.map +1 -1
- package/dist/shared/src/context/AddonContext.cjs.js.map +1 -1
- package/dist/shared/src/context/AddonContext.es.js.map +1 -1
- package/dist/shared/src/context/AddonProjectContext.cjs.js +1 -1
- package/dist/shared/src/context/AddonProjectContext.cjs.js.map +1 -1
- package/dist/shared/src/context/AddonProjectContext.es.js +28 -13
- package/dist/shared/src/context/AddonProjectContext.es.js.map +1 -1
- package/dist/shared/src/context/DetailsPanelContext.cjs.js +1 -1
- package/dist/shared/src/context/DetailsPanelContext.cjs.js.map +1 -1
- package/dist/shared/src/context/DetailsPanelContext.es.js +63 -59
- package/dist/shared/src/context/DetailsPanelContext.es.js.map +1 -1
- package/dist/shared/src/context/PowerpackContext.cjs.js +1 -1
- package/dist/shared/src/context/PowerpackContext.cjs.js.map +1 -1
- package/dist/shared/src/context/PowerpackContext.es.js +31 -21
- package/dist/shared/src/context/PowerpackContext.es.js.map +1 -1
- package/dist/shared/src/context/RemoteModulesContext.cjs.js +1 -1
- package/dist/shared/src/context/RemoteModulesContext.cjs.js.map +1 -1
- package/dist/shared/src/context/RemoteModulesContext.es.js +5 -4
- package/dist/shared/src/context/RemoteModulesContext.es.js.map +1 -1
- package/dist/shared/src/context/WebsocketContext.cjs.js +2 -0
- package/dist/shared/src/context/WebsocketContext.cjs.js.map +1 -0
- package/dist/shared/src/context/WebsocketContext.es.js +309 -0
- package/dist/shared/src/context/WebsocketContext.es.js.map +1 -0
- package/dist/shared/src/hooks/useActionTriggers.cjs.js +1 -1
- package/dist/shared/src/hooks/useActionTriggers.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useActionTriggers.es.js +3 -2
- package/dist/shared/src/hooks/useActionTriggers.es.js.map +1 -1
- package/dist/shared/src/hooks/useEntityUpdate.cjs.js +1 -1
- package/dist/shared/src/hooks/useEntityUpdate.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useEntityUpdate.es.js +4 -2
- package/dist/shared/src/hooks/useEntityUpdate.es.js.map +1 -1
- package/dist/shared/src/hooks/useHierarchyTable.cjs.js +1 -1
- package/dist/shared/src/hooks/useHierarchyTable.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useHierarchyTable.es.js +3 -2
- package/dist/shared/src/hooks/useHierarchyTable.es.js.map +1 -1
- package/dist/shared/src/hooks/useScopedStatuses.cjs.js +1 -1
- package/dist/shared/src/hooks/useScopedStatuses.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useScopedStatuses.es.js +5 -4
- package/dist/shared/src/hooks/useScopedStatuses.es.js.map +1 -1
- package/dist/shared/src/hooks/useUserProjectConfig.cjs.js +1 -1
- package/dist/shared/src/hooks/useUserProjectConfig.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useUserProjectConfig.es.js +3 -2
- package/dist/shared/src/hooks/useUserProjectConfig.es.js.map +1 -1
- package/dist/src/components/Menu/MenuComponents/Menu.cjs.js +1 -1
- package/dist/src/components/Menu/MenuComponents/Menu.cjs.js.map +1 -1
- package/dist/src/components/Menu/MenuComponents/Menu.es.js +3 -2
- package/dist/src/components/Menu/MenuComponents/Menu.es.js.map +1 -1
- package/dist/src/components/Menu/MenuComponents/MenuItem.cjs.js +1 -1
- package/dist/src/components/Menu/MenuComponents/MenuItem.cjs.js.map +1 -1
- package/dist/src/components/Menu/MenuComponents/MenuItem.es.js +7 -6
- package/dist/src/components/Menu/MenuComponents/MenuItem.es.js.map +1 -1
- package/dist/src/components/Menu/MenuComponents/MenuList.cjs.js +1 -1
- package/dist/src/components/Menu/MenuComponents/MenuList.cjs.js.map +1 -1
- package/dist/src/components/Menu/MenuComponents/MenuList.es.js +11 -10
- package/dist/src/components/Menu/MenuComponents/MenuList.es.js.map +1 -1
- package/dist/types/api/generated/entityLists.d.ts +2 -0
- package/dist/types/api/generated/graphql.d.ts +5 -2
- package/dist/types/api/generated/projects.d.ts +4 -4
- package/dist/types/api/generated/views.d.ts +9 -3
- package/dist/types/api/queries/activities/getActivities.d.ts +1 -1
- package/dist/types/api/queries/activities/index.d.ts +0 -1
- package/dist/types/api/queries/activities/util/activityRealtimeHandler.d.ts +40 -0
- package/dist/types/api/queries/index.d.ts +1 -0
- package/dist/types/api/queries/users/getUsers.d.ts +132 -0
- package/dist/types/api/queries/users/guests.d.ts +453 -0
- package/dist/types/api/queries/users/index.d.ts +1 -0
- package/dist/types/components/Powerpack/RequiredAddonVersion.d.ts +12 -0
- package/dist/types/components/Powerpack/index.d.ts +1 -0
- package/dist/types/components/RefreshToast/RefreshToast.d.ts +1 -0
- package/dist/types/components/RefreshToast/index.d.ts +1 -0
- package/dist/types/components/index.d.ts +2 -0
- package/dist/types/containers/DetailsPanel/DetailsPanel.d.ts +2 -1
- package/dist/types/containers/DetailsPanel/FeedContextWrapper.d.ts +1 -1
- package/dist/types/containers/DetailsPanel/FeedWrapper.d.ts +1 -1
- package/dist/types/containers/Feed/Feed.d.ts +2 -2
- package/dist/types/containers/Feed/components/ActivityCategorySelect/ActivityCategorySelect.d.ts +5 -0
- package/dist/types/containers/Feed/components/ActivityCategorySelect/CategoryDropdownItem.d.ts +6 -4
- package/dist/types/containers/Feed/components/ActivityCategorySelect/index.d.ts +2 -0
- package/dist/types/containers/Feed/components/CommentMentionSelect/CommentMentionSelect.d.ts +2 -1
- package/dist/types/containers/Feed/components/FileUploadCard/FileUploadCard.d.ts +2 -1
- package/dist/types/containers/Feed/components/FilesGrid/FilesGrid.d.ts +6 -2
- package/dist/types/containers/Feed/components/ReactionContainer/Reactions.d.ts +2 -1
- package/dist/types/containers/Feed/components/ReactionContainer/Reactions.styled.d.ts +1 -1
- package/dist/types/containers/Feed/context/FeedContext.d.ts +1 -0
- package/dist/types/containers/ProjectTreeTable/widgets/BooleanWidget.d.ts +1 -0
- package/dist/types/containers/Views/index.d.ts +4 -1
- package/dist/types/context/AddonContext.d.ts +1 -0
- package/dist/types/context/AddonProjectContext.d.ts +6 -1
- package/dist/types/context/DetailsPanelContext.d.ts +6 -0
- package/dist/types/context/PowerpackContext.d.ts +1 -1
- package/dist/types/context/WebsocketContext.d.ts +21 -0
- package/dist/types/context/index.d.ts +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("lodash");require("react-toastify");require("uuid");const F=require("../../../../util/pubsub.cjs.js"),S=require("../getActivities.cjs.js"),P=c=>c?c.includes("* [ ]")||c.includes("* [x]"):!1,Q=async(c,{updateCachedData:R,cacheDataLoaded:U,cacheEntryRemoved:j,dispatch:m,getCacheEntry:D})=>{console.log("[Activity RT] Setting up real-time handler for query args:",c);let g;try{await U,console.log("[Activity RT] Cache data loaded, handler is ready");const f=async(d,o)=>{var k,I,x;console.log("[Activity RT] Received message:",{topic:d,message:o});const n=(k=o.summary)==null?void 0:k.activity_id;if(!n){console.warn("[Activity RT] Activity message missing activity_id",o);return}const w=o.project,a=(((I=o.summary)==null?void 0:I.references)||[]).filter(t=>t.reference_type==="origin").map(t=>t.entity_id);console.log("[Activity RT] Extracted data:",{activityId:n,projectName:w,entityIds:a});const A=Array.isArray(c.entityIds)?c.entityIds:[c.entityIds],b=A.some(t=>a.includes(t));if(console.log("[Activity RT] Relevance check:",{queryEntityIds:A,entityIds:a,isRelevant:b,hasQueryEntityIds:A.length>0}),!b&&A.length>0){console.log("[Activity RT] Activity not relevant to this cache, skipping");return}const u=(x=o.summary)==null?void 0:x.activity_type;if(!u){console.warn("[Activity RT] Activity message missing activity_type",o);return}if(console.log("[Activity RT] Activity type:",u),d==="activity.deleted"){console.log("[Activity RT] Handling deletion for activity:",n),R(t=>{var r;if(!t||!t.pages){console.warn("[Activity RT] No draft or pages found for deletion");return}let v=!1;for(const s of t.pages){const e=(r=s.activities)==null?void 0:r.findIndex(l=>l.activityId===n);e!==-1&&(console.log("[Activity RT] Deleting activity at index:",e),s.activities.splice(e,1),v=!0)}console.log(v?"[Activity RT] Activity deleted successfully":"[Activity RT] Activity not found in cache for deletion")});return}console.log("[Activity RT] Fetching activity data from server");try{const t=await m(S.getActivitiesGQLApi.endpoints.GetActivitiesById.initiate({projectName:w,activityIds:[n],entityIds:a},{forceRefetch:!0}));if(console.log("[Activity RT] Fetch result:",t),"error"in t&&t.error)throw console.error("[Activity RT] Error fetching activity:",t.error),new Error("Failed to fetch activity");const r=t.data,s=(r==null?void 0:r.activities)||[];if(console.log("[Activity RT] Fetched activities:",{count:s.length,activities:s}),s.length===0){console.warn("[Activity RT] No activities found for activity_id",n);return}const e=s[0];console.log("[Activity RT] New activity data:",e);const l=[u];if(u==="comment"){const i=e==null?void 0:e.body,y=P(i||"");console.log("[Activity RT] Comment checklist check:",{hasChecklist:y,body:i}),y&&l.push("checklist")}console.log("[Activity RT] Activity types for filtering:",l);const p=c.activityTypes,T=Array.isArray(p)?p:p?[p]:[],C=T.length===0||T.some(i=>l.includes(i));if(console.log("[Activity RT] Activity type relevance check:",{queryActivityTypes:T,activityTypes:l,isActivityTypeRelevant:C}),!C){console.log("[Activity RT] Activity type not relevant to this cache, skipping");return}console.log("[Activity RT] Updating cache"),R(i=>{var E,_,q;if(!i||!i.pages){console.warn("[Activity RT] No draft or pages found for update");return}console.log("[Activity RT] Current cache state:",{pageCount:i.pages.length,firstPageActivityCount:(_=(E=i.pages[0])==null?void 0:E.activities)==null?void 0:_.length});let y=!1;for(const N of i.pages){const h=(q=N.activities)==null?void 0:q.findIndex(G=>G.activityId===n);if(h!==-1){console.log("[Activity RT] Updating existing activity at index:",h),N.activities[h]=e,y=!0;break}}!y&&d==="activity.created"?(console.log("[Activity RT] Adding new activity to first page"),i.pages.length>0&&i.pages[0].activities?(i.pages[0].activities.unshift(e),console.log("[Activity RT] Activity added. New count:",i.pages[0].activities.length)):console.warn("[Activity RT] Cannot add activity: no pages or activities array")):y?console.log("[Activity RT] Activity updated successfully"):console.log("[Activity RT] Activity not found and topic is not creation:",d)}),console.log("[Activity RT] Cache update complete")}catch(t){console.error("[Activity RT] Error fetching activity data for real-time update:",t),console.log("[Activity RT] Invalidating cache tags for entities:",a),m(S.getActivitiesGQLApi.util.invalidateTags(a.map(v=>({type:"entityActivities",id:v}))))}};g=F.subscribe(["activity"],f),console.log("[Activity RT] Subscribed to activity topic with token:",g)}catch(f){console.error("[Activity RT] Error in activity real-time handler setup:",f)}await j,console.log("[Activity RT] Cache entry removed, cleaning up"),g&&(console.log("[Activity RT] Unsubscribing from activity topic"),F.unsubscribe(g))};exports.handleActivityRealtimeUpdates=Q;
|
|
2
|
+
//# sourceMappingURL=activityRealtimeHandler.cjs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activityRealtimeHandler.cjs.js","sources":["../../../../../../../src/api/queries/activities/util/activityRealtimeHandler.ts"],"sourcesContent":["import { PubSub } from '@shared/util'\nimport { ActivitiesResult } from './activitiesHelpers'\nimport type { GetActivitiesQueryVariables } from '@shared/api'\nimport { getActivitiesGQLApi as gqlApi } from '../getActivities'\nimport { ThunkDispatch, UnknownAction } from '@reduxjs/toolkit'\nimport { FeedActivity } from '../types'\n\nexport type ActivityMessage = {\n topic: string\n project: string\n user: string\n createdAt: string\n updatedAt: string\n id: string\n status: string\n summary?: {\n activity_id: string\n activity_type: string\n references: {\n entity_id: string\n entity_type: string\n reference_type: string\n }[]\n }\n}\n\ntype InfiniteDataDraft = {\n pages: ActivitiesResult[]\n}\n\ntype CacheLifecycleApi = {\n updateCachedData: (updateRecipe: (draft: InfiniteDataDraft) => void) => void\n cacheDataLoaded: Promise<unknown>\n cacheEntryRemoved: Promise<void>\n dispatch: ThunkDispatch<unknown, unknown, UnknownAction>\n getCacheEntry: () => { data?: InfiniteDataDraft }\n}\n\n/**\n * Checks if a comment body contains a checklist\n */\nconst bodyHasChecklist = (body: string): boolean => {\n if (!body) return false\n return body.includes('* [ ]') || body.includes('* [x]')\n}\n\n/**\n * Handles real-time activity updates for the infinite query cache\n */\nexport const handleActivityRealtimeUpdates = async (\n queryArg: Omit<GetActivitiesQueryVariables, 'last' | 'first' | 'cursor'> & { filter?: string },\n {\n updateCachedData,\n cacheDataLoaded,\n cacheEntryRemoved,\n dispatch,\n getCacheEntry,\n }: CacheLifecycleApi,\n) => {\n console.log('[Activity RT] Setting up real-time handler for query args:', queryArg)\n let token: string | undefined\n\n try {\n // Wait for the initial query to resolve before proceeding\n await cacheDataLoaded\n console.log('[Activity RT] Cache data loaded, handler is ready')\n\n const handlePubSub = async (topic: string, message: ActivityMessage) => {\n console.log('[Activity RT] Received message:', { topic, message })\n\n const activityId = message.summary?.activity_id\n if (!activityId) {\n console.warn('[Activity RT] Activity message missing activity_id', message)\n return\n }\n\n const projectName = message.project\n const references = message.summary?.references || []\n const entityIds = references\n .filter((reference) => reference.reference_type === 'origin')\n .map((reference) => reference.entity_id)\n\n console.log('[Activity RT] Extracted data:', { activityId, projectName, entityIds })\n\n // Check if this activity is relevant to the current cache\n const queryEntityIds = Array.isArray(queryArg.entityIds)\n ? queryArg.entityIds\n : [queryArg.entityIds]\n\n const isRelevant = queryEntityIds.some((qId) => entityIds.includes(qId))\n console.log('[Activity RT] Relevance check:', {\n queryEntityIds,\n entityIds,\n isRelevant,\n hasQueryEntityIds: queryEntityIds.length > 0,\n })\n\n if (!isRelevant && queryEntityIds.length > 0) {\n console.log('[Activity RT] Activity not relevant to this cache, skipping')\n return\n }\n\n const activityType = message.summary?.activity_type\n if (!activityType) {\n console.warn('[Activity RT] Activity message missing activity_type', message)\n return\n }\n\n console.log('[Activity RT] Activity type:', activityType)\n\n // Handle deletion\n if (topic === 'activity.deleted') {\n console.log('[Activity RT] Handling deletion for activity:', activityId)\n updateCachedData((draft) => {\n if (!draft || !draft.pages) {\n console.warn('[Activity RT] No draft or pages found for deletion')\n return\n }\n\n let deleted = false\n for (const page of draft.pages) {\n const index = page.activities?.findIndex(\n (activity) => activity.activityId === activityId,\n )\n if (index !== -1) {\n console.log('[Activity RT] Deleting activity at index:', index)\n page.activities.splice(index, 1)\n deleted = true\n }\n }\n\n if (deleted) {\n console.log('[Activity RT] Activity deleted successfully')\n } else {\n console.log('[Activity RT] Activity not found in cache for deletion')\n }\n })\n return\n }\n\n // Handle creation and updates\n console.log('[Activity RT] Fetching activity data from server')\n try {\n // Fetch the updated activity data using the enhanced endpoint\n // The GetActivitiesById endpoint is enhanced to return ActivitiesResult via transformResponse\n const result = await dispatch(\n gqlApi.endpoints.GetActivitiesById.initiate(\n {\n projectName,\n activityIds: [activityId],\n entityIds,\n },\n {\n forceRefetch: true, // Always fetch fresh data\n },\n ),\n )\n\n console.log('[Activity RT] Fetch result:', result)\n\n // Check if we have an error\n if ('error' in result && result.error) {\n console.error('[Activity RT] Error fetching activity:', result.error)\n throw new Error('Failed to fetch activity')\n }\n\n // The transformResponse in enhanceActivitiesApi converts GetActivitiesByIdQuery to ActivitiesResult\n // TypeScript doesn't see this transformation, so we cast through unknown\n const unknownData: unknown = result.data\n const res = unknownData as ActivitiesResult\n const newActivities = res?.activities || []\n console.log('[Activity RT] Fetched activities:', {\n count: newActivities.length,\n activities: newActivities,\n })\n\n if (newActivities.length === 0) {\n console.warn('[Activity RT] No activities found for activity_id', activityId)\n return\n }\n\n const newActivity: FeedActivity = newActivities[0]\n console.log('[Activity RT] New activity data:', newActivity)\n\n // Determine activity types to check against\n const activityTypes = [activityType]\n if (activityType === 'comment') {\n const body = newActivity?.body\n const hasChecklist = bodyHasChecklist(body || '')\n console.log('[Activity RT] Comment checklist check:', { hasChecklist, body })\n if (hasChecklist) {\n activityTypes.push('checklist')\n }\n }\n\n console.log('[Activity RT] Activity types for filtering:', activityTypes)\n\n // Check if this activity type is relevant to the query\n const queryActivityTypes = queryArg.activityTypes\n const queryActivityTypesArray = Array.isArray(queryActivityTypes)\n ? queryActivityTypes\n : queryActivityTypes\n ? [queryActivityTypes]\n : []\n const isActivityTypeRelevant =\n queryActivityTypesArray.length === 0 ||\n queryActivityTypesArray.some((type: string) => activityTypes.includes(type))\n\n console.log('[Activity RT] Activity type relevance check:', {\n queryActivityTypes: queryActivityTypesArray,\n activityTypes,\n isActivityTypeRelevant,\n })\n\n if (!isActivityTypeRelevant) {\n console.log('[Activity RT] Activity type not relevant to this cache, skipping')\n return\n }\n\n // Update the cache\n console.log('[Activity RT] Updating cache')\n updateCachedData((draft) => {\n if (!draft || !draft.pages) {\n console.warn('[Activity RT] No draft or pages found for update')\n return\n }\n\n console.log('[Activity RT] Current cache state:', {\n pageCount: draft.pages.length,\n firstPageActivityCount: draft.pages[0]?.activities?.length,\n })\n\n // Check if activity already exists in any page\n let existingActivityFound = false\n for (const page of draft.pages) {\n const index = page.activities?.findIndex(\n (activity) => activity.activityId === activityId,\n )\n if (index !== -1) {\n // Update existing activity\n console.log('[Activity RT] Updating existing activity at index:', index)\n page.activities[index] = newActivity\n existingActivityFound = true\n break\n }\n }\n\n // If it's a new activity (topic is 'activity.created'), add it to the first page\n if (!existingActivityFound && topic === 'activity.created') {\n console.log('[Activity RT] Adding new activity to first page')\n if (draft.pages.length > 0 && draft.pages[0].activities) {\n // Add to the beginning of the first page (most recent activities first)\n // Since we're using reverse chronological order (last: N), prepend to the beginning\n draft.pages[0].activities.unshift(newActivity)\n console.log(\n '[Activity RT] Activity added. New count:',\n draft.pages[0].activities.length,\n )\n } else {\n console.warn('[Activity RT] Cannot add activity: no pages or activities array')\n }\n } else if (!existingActivityFound) {\n console.log('[Activity RT] Activity not found and topic is not creation:', topic)\n } else {\n console.log('[Activity RT] Activity updated successfully')\n }\n })\n\n console.log('[Activity RT] Cache update complete')\n } catch (error) {\n console.error('[Activity RT] Error fetching activity data for real-time update:', error)\n\n // Invalidate the cache for these entities to trigger a refetch\n console.log('[Activity RT] Invalidating cache tags for entities:', entityIds)\n dispatch(\n gqlApi.util.invalidateTags(\n entityIds.map((entityId) => ({ type: 'entityActivities', id: entityId })),\n ),\n )\n }\n }\n\n // Subscribe to activity topic\n token = PubSub.subscribe(['activity'], handlePubSub)\n console.log('[Activity RT] Subscribed to activity topic with token:', token)\n } catch (error) {\n console.error('[Activity RT] Error in activity real-time handler setup:', error)\n // no-op in case `cacheEntryRemoved` resolves before `cacheDataLoaded`\n }\n\n // Wait for cache entry to be removed\n await cacheEntryRemoved\n console.log('[Activity RT] Cache entry removed, cleaning up')\n\n // Cleanup: unsubscribe from PubSub\n if (token) {\n console.log('[Activity RT] Unsubscribing from activity topic')\n PubSub.unsubscribe(token)\n }\n}\n"],"names":["bodyHasChecklist","body","handleActivityRealtimeUpdates","queryArg","updateCachedData","cacheDataLoaded","cacheEntryRemoved","dispatch","getCacheEntry","token","handlePubSub","topic","message","activityId","_a","projectName","entityIds","_b","reference","queryEntityIds","isRelevant","qId","activityType","_c","draft","deleted","page","index","activity","result","gqlApi","res","newActivities","newActivity","activityTypes","hasChecklist","queryActivityTypes","queryActivityTypesArray","isActivityTypeRelevant","type","existingActivityFound","error","entityId","PubSub"],"mappings":"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"}
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
import "lodash";
|
|
2
|
+
import "react-toastify";
|
|
3
|
+
import "uuid";
|
|
4
|
+
import S from "../../../../util/pubsub.es.js";
|
|
5
|
+
import { getActivitiesGQLApi as U } from "../getActivities.es.js";
|
|
6
|
+
const G = (c) => c ? c.includes("* [ ]") || c.includes("* [x]") : !1, K = async (c, {
|
|
7
|
+
updateCachedData: R,
|
|
8
|
+
cacheDataLoaded: P,
|
|
9
|
+
cacheEntryRemoved: j,
|
|
10
|
+
dispatch: m,
|
|
11
|
+
getCacheEntry: H
|
|
12
|
+
}) => {
|
|
13
|
+
console.log("[Activity RT] Setting up real-time handler for query args:", c);
|
|
14
|
+
let g;
|
|
15
|
+
try {
|
|
16
|
+
await P, console.log("[Activity RT] Cache data loaded, handler is ready");
|
|
17
|
+
const f = async (d, o) => {
|
|
18
|
+
var k, I, x;
|
|
19
|
+
console.log("[Activity RT] Received message:", { topic: d, message: o });
|
|
20
|
+
const n = (k = o.summary) == null ? void 0 : k.activity_id;
|
|
21
|
+
if (!n) {
|
|
22
|
+
console.warn("[Activity RT] Activity message missing activity_id", o);
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
const w = o.project, a = (((I = o.summary) == null ? void 0 : I.references) || []).filter((t) => t.reference_type === "origin").map((t) => t.entity_id);
|
|
26
|
+
console.log("[Activity RT] Extracted data:", { activityId: n, projectName: w, entityIds: a });
|
|
27
|
+
const A = Array.isArray(c.entityIds) ? c.entityIds : [c.entityIds], b = A.some((t) => a.includes(t));
|
|
28
|
+
if (console.log("[Activity RT] Relevance check:", {
|
|
29
|
+
queryEntityIds: A,
|
|
30
|
+
entityIds: a,
|
|
31
|
+
isRelevant: b,
|
|
32
|
+
hasQueryEntityIds: A.length > 0
|
|
33
|
+
}), !b && A.length > 0) {
|
|
34
|
+
console.log("[Activity RT] Activity not relevant to this cache, skipping");
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
const p = (x = o.summary) == null ? void 0 : x.activity_type;
|
|
38
|
+
if (!p) {
|
|
39
|
+
console.warn("[Activity RT] Activity message missing activity_type", o);
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
if (console.log("[Activity RT] Activity type:", p), d === "activity.deleted") {
|
|
43
|
+
console.log("[Activity RT] Handling deletion for activity:", n), R((t) => {
|
|
44
|
+
var r;
|
|
45
|
+
if (!t || !t.pages) {
|
|
46
|
+
console.warn("[Activity RT] No draft or pages found for deletion");
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
let v = !1;
|
|
50
|
+
for (const s of t.pages) {
|
|
51
|
+
const e = (r = s.activities) == null ? void 0 : r.findIndex(
|
|
52
|
+
(l) => l.activityId === n
|
|
53
|
+
);
|
|
54
|
+
e !== -1 && (console.log("[Activity RT] Deleting activity at index:", e), s.activities.splice(e, 1), v = !0);
|
|
55
|
+
}
|
|
56
|
+
console.log(v ? "[Activity RT] Activity deleted successfully" : "[Activity RT] Activity not found in cache for deletion");
|
|
57
|
+
});
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
console.log("[Activity RT] Fetching activity data from server");
|
|
61
|
+
try {
|
|
62
|
+
const t = await m(
|
|
63
|
+
U.endpoints.GetActivitiesById.initiate(
|
|
64
|
+
{
|
|
65
|
+
projectName: w,
|
|
66
|
+
activityIds: [n],
|
|
67
|
+
entityIds: a
|
|
68
|
+
},
|
|
69
|
+
{
|
|
70
|
+
forceRefetch: !0
|
|
71
|
+
// Always fetch fresh data
|
|
72
|
+
}
|
|
73
|
+
)
|
|
74
|
+
);
|
|
75
|
+
if (console.log("[Activity RT] Fetch result:", t), "error" in t && t.error)
|
|
76
|
+
throw console.error("[Activity RT] Error fetching activity:", t.error), new Error("Failed to fetch activity");
|
|
77
|
+
const r = t.data, s = (r == null ? void 0 : r.activities) || [];
|
|
78
|
+
if (console.log("[Activity RT] Fetched activities:", {
|
|
79
|
+
count: s.length,
|
|
80
|
+
activities: s
|
|
81
|
+
}), s.length === 0) {
|
|
82
|
+
console.warn("[Activity RT] No activities found for activity_id", n);
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
const e = s[0];
|
|
86
|
+
console.log("[Activity RT] New activity data:", e);
|
|
87
|
+
const l = [p];
|
|
88
|
+
if (p === "comment") {
|
|
89
|
+
const i = e == null ? void 0 : e.body, y = G(i || "");
|
|
90
|
+
console.log("[Activity RT] Comment checklist check:", { hasChecklist: y, body: i }), y && l.push("checklist");
|
|
91
|
+
}
|
|
92
|
+
console.log("[Activity RT] Activity types for filtering:", l);
|
|
93
|
+
const u = c.activityTypes, T = Array.isArray(u) ? u : u ? [u] : [], C = T.length === 0 || T.some((i) => l.includes(i));
|
|
94
|
+
if (console.log("[Activity RT] Activity type relevance check:", {
|
|
95
|
+
queryActivityTypes: T,
|
|
96
|
+
activityTypes: l,
|
|
97
|
+
isActivityTypeRelevant: C
|
|
98
|
+
}), !C) {
|
|
99
|
+
console.log("[Activity RT] Activity type not relevant to this cache, skipping");
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
console.log("[Activity RT] Updating cache"), R((i) => {
|
|
103
|
+
var E, _, N;
|
|
104
|
+
if (!i || !i.pages) {
|
|
105
|
+
console.warn("[Activity RT] No draft or pages found for update");
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
console.log("[Activity RT] Current cache state:", {
|
|
109
|
+
pageCount: i.pages.length,
|
|
110
|
+
firstPageActivityCount: (_ = (E = i.pages[0]) == null ? void 0 : E.activities) == null ? void 0 : _.length
|
|
111
|
+
});
|
|
112
|
+
let y = !1;
|
|
113
|
+
for (const F of i.pages) {
|
|
114
|
+
const h = (N = F.activities) == null ? void 0 : N.findIndex(
|
|
115
|
+
(D) => D.activityId === n
|
|
116
|
+
);
|
|
117
|
+
if (h !== -1) {
|
|
118
|
+
console.log("[Activity RT] Updating existing activity at index:", h), F.activities[h] = e, y = !0;
|
|
119
|
+
break;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
!y && d === "activity.created" ? (console.log("[Activity RT] Adding new activity to first page"), i.pages.length > 0 && i.pages[0].activities ? (i.pages[0].activities.unshift(e), console.log(
|
|
123
|
+
"[Activity RT] Activity added. New count:",
|
|
124
|
+
i.pages[0].activities.length
|
|
125
|
+
)) : console.warn("[Activity RT] Cannot add activity: no pages or activities array")) : y ? console.log("[Activity RT] Activity updated successfully") : console.log("[Activity RT] Activity not found and topic is not creation:", d);
|
|
126
|
+
}), console.log("[Activity RT] Cache update complete");
|
|
127
|
+
} catch (t) {
|
|
128
|
+
console.error("[Activity RT] Error fetching activity data for real-time update:", t), console.log("[Activity RT] Invalidating cache tags for entities:", a), m(
|
|
129
|
+
U.util.invalidateTags(
|
|
130
|
+
a.map((v) => ({ type: "entityActivities", id: v }))
|
|
131
|
+
)
|
|
132
|
+
);
|
|
133
|
+
}
|
|
134
|
+
};
|
|
135
|
+
g = S.subscribe(["activity"], f), console.log("[Activity RT] Subscribed to activity topic with token:", g);
|
|
136
|
+
} catch (f) {
|
|
137
|
+
console.error("[Activity RT] Error in activity real-time handler setup:", f);
|
|
138
|
+
}
|
|
139
|
+
await j, console.log("[Activity RT] Cache entry removed, cleaning up"), g && (console.log("[Activity RT] Unsubscribing from activity topic"), S.unsubscribe(g));
|
|
140
|
+
};
|
|
141
|
+
export {
|
|
142
|
+
K as handleActivityRealtimeUpdates
|
|
143
|
+
};
|
|
144
|
+
//# sourceMappingURL=activityRealtimeHandler.es.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activityRealtimeHandler.es.js","sources":["../../../../../../../src/api/queries/activities/util/activityRealtimeHandler.ts"],"sourcesContent":["import { PubSub } from '@shared/util'\nimport { ActivitiesResult } from './activitiesHelpers'\nimport type { GetActivitiesQueryVariables } from '@shared/api'\nimport { getActivitiesGQLApi as gqlApi } from '../getActivities'\nimport { ThunkDispatch, UnknownAction } from '@reduxjs/toolkit'\nimport { FeedActivity } from '../types'\n\nexport type ActivityMessage = {\n topic: string\n project: string\n user: string\n createdAt: string\n updatedAt: string\n id: string\n status: string\n summary?: {\n activity_id: string\n activity_type: string\n references: {\n entity_id: string\n entity_type: string\n reference_type: string\n }[]\n }\n}\n\ntype InfiniteDataDraft = {\n pages: ActivitiesResult[]\n}\n\ntype CacheLifecycleApi = {\n updateCachedData: (updateRecipe: (draft: InfiniteDataDraft) => void) => void\n cacheDataLoaded: Promise<unknown>\n cacheEntryRemoved: Promise<void>\n dispatch: ThunkDispatch<unknown, unknown, UnknownAction>\n getCacheEntry: () => { data?: InfiniteDataDraft }\n}\n\n/**\n * Checks if a comment body contains a checklist\n */\nconst bodyHasChecklist = (body: string): boolean => {\n if (!body) return false\n return body.includes('* [ ]') || body.includes('* [x]')\n}\n\n/**\n * Handles real-time activity updates for the infinite query cache\n */\nexport const handleActivityRealtimeUpdates = async (\n queryArg: Omit<GetActivitiesQueryVariables, 'last' | 'first' | 'cursor'> & { filter?: string },\n {\n updateCachedData,\n cacheDataLoaded,\n cacheEntryRemoved,\n dispatch,\n getCacheEntry,\n }: CacheLifecycleApi,\n) => {\n console.log('[Activity RT] Setting up real-time handler for query args:', queryArg)\n let token: string | undefined\n\n try {\n // Wait for the initial query to resolve before proceeding\n await cacheDataLoaded\n console.log('[Activity RT] Cache data loaded, handler is ready')\n\n const handlePubSub = async (topic: string, message: ActivityMessage) => {\n console.log('[Activity RT] Received message:', { topic, message })\n\n const activityId = message.summary?.activity_id\n if (!activityId) {\n console.warn('[Activity RT] Activity message missing activity_id', message)\n return\n }\n\n const projectName = message.project\n const references = message.summary?.references || []\n const entityIds = references\n .filter((reference) => reference.reference_type === 'origin')\n .map((reference) => reference.entity_id)\n\n console.log('[Activity RT] Extracted data:', { activityId, projectName, entityIds })\n\n // Check if this activity is relevant to the current cache\n const queryEntityIds = Array.isArray(queryArg.entityIds)\n ? queryArg.entityIds\n : [queryArg.entityIds]\n\n const isRelevant = queryEntityIds.some((qId) => entityIds.includes(qId))\n console.log('[Activity RT] Relevance check:', {\n queryEntityIds,\n entityIds,\n isRelevant,\n hasQueryEntityIds: queryEntityIds.length > 0,\n })\n\n if (!isRelevant && queryEntityIds.length > 0) {\n console.log('[Activity RT] Activity not relevant to this cache, skipping')\n return\n }\n\n const activityType = message.summary?.activity_type\n if (!activityType) {\n console.warn('[Activity RT] Activity message missing activity_type', message)\n return\n }\n\n console.log('[Activity RT] Activity type:', activityType)\n\n // Handle deletion\n if (topic === 'activity.deleted') {\n console.log('[Activity RT] Handling deletion for activity:', activityId)\n updateCachedData((draft) => {\n if (!draft || !draft.pages) {\n console.warn('[Activity RT] No draft or pages found for deletion')\n return\n }\n\n let deleted = false\n for (const page of draft.pages) {\n const index = page.activities?.findIndex(\n (activity) => activity.activityId === activityId,\n )\n if (index !== -1) {\n console.log('[Activity RT] Deleting activity at index:', index)\n page.activities.splice(index, 1)\n deleted = true\n }\n }\n\n if (deleted) {\n console.log('[Activity RT] Activity deleted successfully')\n } else {\n console.log('[Activity RT] Activity not found in cache for deletion')\n }\n })\n return\n }\n\n // Handle creation and updates\n console.log('[Activity RT] Fetching activity data from server')\n try {\n // Fetch the updated activity data using the enhanced endpoint\n // The GetActivitiesById endpoint is enhanced to return ActivitiesResult via transformResponse\n const result = await dispatch(\n gqlApi.endpoints.GetActivitiesById.initiate(\n {\n projectName,\n activityIds: [activityId],\n entityIds,\n },\n {\n forceRefetch: true, // Always fetch fresh data\n },\n ),\n )\n\n console.log('[Activity RT] Fetch result:', result)\n\n // Check if we have an error\n if ('error' in result && result.error) {\n console.error('[Activity RT] Error fetching activity:', result.error)\n throw new Error('Failed to fetch activity')\n }\n\n // The transformResponse in enhanceActivitiesApi converts GetActivitiesByIdQuery to ActivitiesResult\n // TypeScript doesn't see this transformation, so we cast through unknown\n const unknownData: unknown = result.data\n const res = unknownData as ActivitiesResult\n const newActivities = res?.activities || []\n console.log('[Activity RT] Fetched activities:', {\n count: newActivities.length,\n activities: newActivities,\n })\n\n if (newActivities.length === 0) {\n console.warn('[Activity RT] No activities found for activity_id', activityId)\n return\n }\n\n const newActivity: FeedActivity = newActivities[0]\n console.log('[Activity RT] New activity data:', newActivity)\n\n // Determine activity types to check against\n const activityTypes = [activityType]\n if (activityType === 'comment') {\n const body = newActivity?.body\n const hasChecklist = bodyHasChecklist(body || '')\n console.log('[Activity RT] Comment checklist check:', { hasChecklist, body })\n if (hasChecklist) {\n activityTypes.push('checklist')\n }\n }\n\n console.log('[Activity RT] Activity types for filtering:', activityTypes)\n\n // Check if this activity type is relevant to the query\n const queryActivityTypes = queryArg.activityTypes\n const queryActivityTypesArray = Array.isArray(queryActivityTypes)\n ? queryActivityTypes\n : queryActivityTypes\n ? [queryActivityTypes]\n : []\n const isActivityTypeRelevant =\n queryActivityTypesArray.length === 0 ||\n queryActivityTypesArray.some((type: string) => activityTypes.includes(type))\n\n console.log('[Activity RT] Activity type relevance check:', {\n queryActivityTypes: queryActivityTypesArray,\n activityTypes,\n isActivityTypeRelevant,\n })\n\n if (!isActivityTypeRelevant) {\n console.log('[Activity RT] Activity type not relevant to this cache, skipping')\n return\n }\n\n // Update the cache\n console.log('[Activity RT] Updating cache')\n updateCachedData((draft) => {\n if (!draft || !draft.pages) {\n console.warn('[Activity RT] No draft or pages found for update')\n return\n }\n\n console.log('[Activity RT] Current cache state:', {\n pageCount: draft.pages.length,\n firstPageActivityCount: draft.pages[0]?.activities?.length,\n })\n\n // Check if activity already exists in any page\n let existingActivityFound = false\n for (const page of draft.pages) {\n const index = page.activities?.findIndex(\n (activity) => activity.activityId === activityId,\n )\n if (index !== -1) {\n // Update existing activity\n console.log('[Activity RT] Updating existing activity at index:', index)\n page.activities[index] = newActivity\n existingActivityFound = true\n break\n }\n }\n\n // If it's a new activity (topic is 'activity.created'), add it to the first page\n if (!existingActivityFound && topic === 'activity.created') {\n console.log('[Activity RT] Adding new activity to first page')\n if (draft.pages.length > 0 && draft.pages[0].activities) {\n // Add to the beginning of the first page (most recent activities first)\n // Since we're using reverse chronological order (last: N), prepend to the beginning\n draft.pages[0].activities.unshift(newActivity)\n console.log(\n '[Activity RT] Activity added. New count:',\n draft.pages[0].activities.length,\n )\n } else {\n console.warn('[Activity RT] Cannot add activity: no pages or activities array')\n }\n } else if (!existingActivityFound) {\n console.log('[Activity RT] Activity not found and topic is not creation:', topic)\n } else {\n console.log('[Activity RT] Activity updated successfully')\n }\n })\n\n console.log('[Activity RT] Cache update complete')\n } catch (error) {\n console.error('[Activity RT] Error fetching activity data for real-time update:', error)\n\n // Invalidate the cache for these entities to trigger a refetch\n console.log('[Activity RT] Invalidating cache tags for entities:', entityIds)\n dispatch(\n gqlApi.util.invalidateTags(\n entityIds.map((entityId) => ({ type: 'entityActivities', id: entityId })),\n ),\n )\n }\n }\n\n // Subscribe to activity topic\n token = PubSub.subscribe(['activity'], handlePubSub)\n console.log('[Activity RT] Subscribed to activity topic with token:', token)\n } catch (error) {\n console.error('[Activity RT] Error in activity real-time handler setup:', error)\n // no-op in case `cacheEntryRemoved` resolves before `cacheDataLoaded`\n }\n\n // Wait for cache entry to be removed\n await cacheEntryRemoved\n console.log('[Activity RT] Cache entry removed, cleaning up')\n\n // Cleanup: unsubscribe from PubSub\n if (token) {\n console.log('[Activity RT] Unsubscribing from activity topic')\n PubSub.unsubscribe(token)\n }\n}\n"],"names":["bodyHasChecklist","body","handleActivityRealtimeUpdates","queryArg","updateCachedData","cacheDataLoaded","cacheEntryRemoved","dispatch","getCacheEntry","token","handlePubSub","topic","message","activityId","_a","projectName","entityIds","_b","reference","queryEntityIds","isRelevant","qId","activityType","_c","draft","deleted","page","index","activity","result","gqlApi","res","newActivities","newActivity","activityTypes","hasChecklist","queryActivityTypes","queryActivityTypesArray","isActivityTypeRelevant","type","existingActivityFound","error","entityId","PubSub"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("../../base/client.cjs.js");require("../../generated/graphql.cjs.js");require("../../generated/graphqlLinks.cjs.js");require("../../generated/access.cjs.js");require("../../generated/actions.cjs.js");require("../../generated/activityFeed.cjs.js");require("../../generated/addons.cjs.js");require("../../generated/anatomy.cjs.js");require("../../generated/attributes.cjs.js");require("../../generated/authentication.cjs.js");require("../../generated/bundles.cjs.js");require("../../generated/configuration.cjs.js");require("../../generated/desktop.cjs.js");require("../../generated/entityLists.cjs.js");require("../../generated/events.cjs.js");require("../../generated/files.cjs.js");require("../../generated/folders.cjs.js");require("../../generated/inbox.cjs.js");require("../../generated/links.cjs.js");require("../../generated/market.cjs.js");require("../../generated/onboarding.cjs.js");require("../../generated/operations.cjs.js");require("../../generated/products.cjs.js");require("../../generated/projectDashboard.cjs.js");require("../../generated/projects.cjs.js");require("../../generated/reviewables.cjs.js");require("../../generated/services.cjs.js");require("../../generated/system.cjs.js");require("../../generated/tasks.cjs.js");require("../../generated/teams.cjs.js");require("../../generated/thumbnails.cjs.js");require("../../generated/uRIs.cjs.js");require("../../generated/users.cjs.js");require("../../generated/versions.cjs.js");require("../../generated/workfiles.cjs.js");require("../../generated/ynputCloud.cjs.js");require("../../generated/grouping.cjs.js");require("../../generated/views.cjs.js");require("../actions/getActions.cjs.js");require("../activities/getActivities.cjs.js");require("../activities/updateActivities.cjs.js");require("../activities/updateReaction.cjs.js");require("../activities/getMentions.cjs.js");require("../activities/getCategories.cjs.js");require("../addons/getAddons.cjs.js");require("../addons/updateAddons.cjs.js");require("../attributes/getAttributes.cjs.js");require("../attributes/updateAttributes.cjs.js");require("../authentication/getAuthentication.cjs.js");require("../cloud/cloud.cjs.js");require("./getEntity.cjs.js");require("./getEntityPanel.cjs.js");require("./updateEntity.cjs.js");require("../entityLists/getLists.cjs.js");require("../entityLists/updateLists.cjs.js");require("../entityLists/getListsAttributes.cjs.js");require("../entityLists/updateListsAttributes.cjs.js");require("../entityLists/listFolders.cjs.js");require("../folders/getFolders.cjs.js");require("../grouping/getGrouping.cjs.js");require("../links/updateLinks.cjs.js");require("../links/getLinks.cjs.js");require("../links/getEntityLinks.cjs.js");const s=require("../overview/getOverview.cjs.js");require("../overview/updateOverview.cjs.js");require("../permissions/getPermissions.cjs.js");require("../products/createProduct.cjs.js");require("../project/getProject.cjs.js");require("../project/updateProject.cjs.js");require("../review/getReview.cjs.js");require("../review/updateReview.cjs.js");require("../share/share.cjs.js");require("../system/getSystem.cjs.js");require("../userDashboard/getUserDashboard.cjs.js");require("../users/getUsers.cjs.js");require("../users/updateUsers.cjs.js");require("../versions/updateVersions.cjs.js");require("../views/getViews.cjs.js");require("../views/updateViews.cjs.js");require("../watchers/getWatchers.cjs.js");const P=["task","version","folder","representation"],D=({entity:a,entityType:R,projectName:u})=>{var d,n,o,l,
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("../../base/client.cjs.js");require("../../generated/graphql.cjs.js");require("../../generated/graphqlLinks.cjs.js");require("../../generated/access.cjs.js");require("../../generated/actions.cjs.js");require("../../generated/activityFeed.cjs.js");require("../../generated/addons.cjs.js");require("../../generated/anatomy.cjs.js");require("../../generated/attributes.cjs.js");require("../../generated/authentication.cjs.js");require("../../generated/bundles.cjs.js");require("../../generated/configuration.cjs.js");require("../../generated/desktop.cjs.js");require("../../generated/entityLists.cjs.js");require("../../generated/events.cjs.js");require("../../generated/files.cjs.js");require("../../generated/folders.cjs.js");require("../../generated/inbox.cjs.js");require("../../generated/links.cjs.js");require("../../generated/market.cjs.js");require("../../generated/onboarding.cjs.js");require("../../generated/operations.cjs.js");require("../../generated/products.cjs.js");require("../../generated/projectDashboard.cjs.js");require("../../generated/projects.cjs.js");require("../../generated/reviewables.cjs.js");require("../../generated/services.cjs.js");require("../../generated/system.cjs.js");require("../../generated/tasks.cjs.js");require("../../generated/teams.cjs.js");require("../../generated/thumbnails.cjs.js");require("../../generated/uRIs.cjs.js");require("../../generated/users.cjs.js");require("../../generated/versions.cjs.js");require("../../generated/workfiles.cjs.js");require("../../generated/ynputCloud.cjs.js");require("../../generated/grouping.cjs.js");require("../../generated/views.cjs.js");require("../actions/getActions.cjs.js");require("../activities/getActivities.cjs.js");require("../activities/updateActivities.cjs.js");require("../activities/updateReaction.cjs.js");require("../activities/getMentions.cjs.js");require("../activities/getCategories.cjs.js");require("../addons/getAddons.cjs.js");require("../addons/updateAddons.cjs.js");require("../attributes/getAttributes.cjs.js");require("../attributes/updateAttributes.cjs.js");require("../authentication/getAuthentication.cjs.js");require("../cloud/cloud.cjs.js");require("./getEntity.cjs.js");require("./getEntityPanel.cjs.js");require("./updateEntity.cjs.js");require("../entityLists/getLists.cjs.js");require("../entityLists/updateLists.cjs.js");require("../entityLists/getListsAttributes.cjs.js");require("../entityLists/updateListsAttributes.cjs.js");require("../entityLists/listFolders.cjs.js");require("../folders/getFolders.cjs.js");require("../grouping/getGrouping.cjs.js");require("../links/updateLinks.cjs.js");require("../links/getLinks.cjs.js");require("../links/getEntityLinks.cjs.js");const s=require("../overview/getOverview.cjs.js");require("../overview/updateOverview.cjs.js");require("../permissions/getPermissions.cjs.js");require("../products/createProduct.cjs.js");require("../project/getProject.cjs.js");require("../project/updateProject.cjs.js");require("../review/getReview.cjs.js");require("../review/updateReview.cjs.js");require("../share/share.cjs.js");require("../system/getSystem.cjs.js");require("../userDashboard/getUserDashboard.cjs.js");require("../users/getUsers.cjs.js");require("../users/updateUsers.cjs.js");require("../users/guests.cjs.js");require("../versions/updateVersions.cjs.js");require("../views/getViews.cjs.js");require("../views/updateViews.cjs.js");require("../watchers/getWatchers.cjs.js");const P=["task","version","folder","representation"],D=({entity:a,entityType:R,projectName:u})=>{var d,n,o,q,l,p,b,v,c,A,m,y,h,f,T,g,k,w,I;switch(R){case"task":const r=a;return{entityType:"task",entitySubType:r.taskType,projectName:u,id:r.id,name:r.name,label:r.label,tags:r.tags,status:r.status,updatedAt:r.updatedAt,createdAt:r.createdAt,attrib:s.parseAllAttribs(r.allAttrib),hasReviewables:r.hasReviewables,thumbnailId:r.thumbnailId,path:(((d=r.folder)==null?void 0:d.path)||"")+"/"+r.name,folder:r.folder,task:{id:r.id,name:r.name,label:r.label,assignees:r.assignees,taskType:r.taskType},product:void 0,version:(q=(o=(n=r.versions)==null?void 0:n.edges)==null?void 0:o[0])==null?void 0:q.node};case"version":const e=a;return{entityType:"version",entitySubType:void 0,projectName:u,id:e.id,name:e.name,label:void 0,tags:e.tags,status:e.status,updatedAt:e.updatedAt,createdAt:e.createdAt,attrib:s.parseAllAttribs(e.allAttrib),hasReviewables:e.hasReviewables,thumbnailId:e.thumbnailId,path:(((p=(l=e.product)==null?void 0:l.folder)==null?void 0:p.path)||"")+"/"+e.product.name+"/"+e.name,folder:(b=e.product)==null?void 0:b.folder,task:e.task??void 0,product:{id:(v=e.product)==null?void 0:v.id,name:(c=e.product)==null?void 0:c.name,productType:(A=e.product)==null?void 0:A.productType,latestVersion:e.product.latestVersion},version:{version:e.version,id:e.id,name:e.name,updatedAt:e.updatedAt,createdAt:e.createdAt,productId:e.product.id},representations:((y=(m=e.representations)==null?void 0:m.edges)==null?void 0:y.map(S=>S.node))||[]};case"folder":const t=a;return{entityType:"folder",entitySubType:t.folderType,projectName:u,id:t.id,name:t.name,label:t.label,tags:t.tags,status:t.status,updatedAt:t.updatedAt,createdAt:t.createdAt,attrib:s.parseAllAttribs(t.allAttrib),hasReviewables:t.hasReviewables,thumbnailId:t.thumbnailId,path:t.path||"",folder:{id:t.id,name:t.name,label:t.label,folderType:t.folderType},product:void 0,version:void 0,representations:void 0};case"representation":const i=a;return{entityType:"representation",entitySubType:void 0,projectName:u,id:i.id,name:i.name,label:void 0,tags:i.tags,status:i.status,updatedAt:i.updatedAt,createdAt:i.createdAt,attrib:s.parseAllAttribs(i.allAttrib),hasReviewables:void 0,thumbnailId:void 0,path:(((T=(f=(h=i.version)==null?void 0:h.product)==null?void 0:f.folder)==null?void 0:T.path)||"")+"/"+(((k=(g=i.version)==null?void 0:g.product)==null?void 0:k.name)||"")+"/"+((w=i.version)==null?void 0:w.version)+"/"+i.name,version:i.version,product:i.version.product,task:i.version.task||void 0,folder:(I=i.version.product)==null?void 0:I.folder,representations:void 0}}};exports.detailsPanelEntityTypes=P;exports.transformDetailsPanelQueriesData=D;
|
|
2
2
|
//# sourceMappingURL=transformDetailsPanelData.cjs.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transformDetailsPanelData.cjs.js","sources":["../../../../../../src/api/queries/entities/transformDetailsPanelData.ts"],"sourcesContent":["import {\n DetailsPanelFolderFragmentFragment,\n DetailsPanelProductFragmentFragment,\n DetailsPanelRepresentationFragmentFragment,\n DetailsPanelTaskFragmentFragment,\n DetailsPanelVersionFragmentFragment,\n GetDetailsPanelFolderQuery,\n GetDetailsPanelRepresentationQuery,\n GetDetailsPanelTaskQuery,\n GetDetailsPanelVersionQuery,\n} from '@shared/api/generated'\nimport { parseAllAttribs } from '@shared/api'\n\ntype DetailsPanelTask = NonNullable<GetDetailsPanelTaskQuery['project']['task']>\ntype DetailsPanelRepresentation = NonNullable<\n GetDetailsPanelRepresentationQuery['project']['representation']\n>\ntype DetailsPanelVersion = NonNullable<GetDetailsPanelVersionQuery['project']['version']>\ntype DetailsPanelFolder = NonNullable<GetDetailsPanelFolderQuery['project']['folder']>\n\nexport const detailsPanelEntityTypes = ['task', 'version', 'folder', 'representation'] as const\nexport type DetailsPanelEntityType = (typeof detailsPanelEntityTypes)[number]\n\ntype TransformEntityDataArgs = {\n entity: DetailsPanelRepresentation | DetailsPanelTask | DetailsPanelVersion | DetailsPanelFolder\n entityType: DetailsPanelEntityType\n projectName: string\n}\n\ntype NullableString = string | null | undefined\n\n// return type\nexport type DetailsPanelEntityData = {\n id: string\n name: string\n label: NullableString\n tags: string[]\n status: string\n updatedAt: string\n createdAt: string\n attrib: Record<string, string | number>\n hasReviewables?: boolean\n thumbnailId?: string | null | undefined\n path: string\n // extra metadata\n entityType: string\n entitySubType?: string\n projectName: string\n // type specific\n task?: DetailsPanelTaskFragmentFragment\n folder?: DetailsPanelFolderFragmentFragment\n product?: DetailsPanelProductFragmentFragment\n version?: DetailsPanelVersionFragmentFragment\n representations?: DetailsPanelRepresentationFragmentFragment[]\n}\n\n// takes the data from different entity types and returns a single data model\nexport const transformDetailsPanelQueriesData = ({\n entity,\n entityType,\n projectName,\n}: TransformEntityDataArgs): DetailsPanelEntityData => {\n switch (entityType) {\n case 'task':\n const task = entity as DetailsPanelTask\n return {\n entityType: 'task',\n entitySubType: task.taskType,\n projectName: projectName,\n id: task.id,\n name: task.name,\n label: task.label,\n tags: task.tags,\n status: task.status,\n updatedAt: task.updatedAt,\n createdAt: task.createdAt,\n attrib: parseAllAttribs(task.allAttrib),\n hasReviewables: task.hasReviewables,\n thumbnailId: task.thumbnailId,\n path: (task.folder?.path || '') + '/' + task.name,\n folder: task.folder,\n task: {\n id: task.id,\n name: task.name,\n label: task.label,\n assignees: task.assignees,\n taskType: task.taskType,\n },\n product: undefined,\n version: task.versions?.edges?.[0]?.node,\n }\n case 'version':\n const version = entity as DetailsPanelVersion\n return {\n entityType: 'version',\n entitySubType: undefined,\n projectName: projectName,\n id: version.id,\n name: version.name,\n label: undefined,\n tags: version.tags,\n status: version.status,\n updatedAt: version.updatedAt,\n createdAt: version.createdAt,\n attrib: parseAllAttribs(version.allAttrib),\n hasReviewables: version.hasReviewables,\n thumbnailId: version.thumbnailId,\n path:\n (version.product?.folder?.path || '') + '/' + version.product.name + '/' + version.name,\n folder: version.product?.folder,\n task: version.task ?? undefined,\n product: {\n id: version.product?.id,\n name: version.product?.name,\n productType: version.product?.productType,\n latestVersion: version.product.latestVersion,\n },\n version: {\n version: version.version,\n id: version.id,\n name: version.name,\n updatedAt: version.updatedAt,\n createdAt: version.createdAt,\n productId: version.product.id,\n },\n representations: version.representations?.edges?.map((edge) => edge.node) || [],\n }\n case 'folder':\n const folder = entity as DetailsPanelFolder\n return {\n entityType: 'folder',\n entitySubType: folder.folderType,\n projectName: projectName,\n id: folder.id,\n name: folder.name,\n label: folder.label,\n tags: folder.tags,\n status: folder.status,\n updatedAt: folder.updatedAt,\n createdAt: folder.createdAt,\n attrib: parseAllAttribs(folder.allAttrib),\n hasReviewables: folder.hasReviewables,\n thumbnailId: folder.thumbnailId,\n path: folder.path || '',\n folder: {\n id: folder.id,\n name: folder.name,\n label: folder.label,\n folderType: folder.folderType,\n },\n product: undefined,\n version: undefined,\n representations: undefined,\n }\n case 'representation':\n const representation = entity as DetailsPanelRepresentation\n return {\n entityType: 'representation',\n entitySubType: undefined,\n projectName: projectName,\n id: representation.id,\n name: representation.name,\n label: undefined,\n tags: representation.tags,\n status: representation.status,\n updatedAt: representation.updatedAt,\n createdAt: representation.createdAt,\n attrib: parseAllAttribs(representation.allAttrib),\n hasReviewables: undefined,\n thumbnailId: undefined,\n path:\n (representation.version?.product?.folder?.path || '') +\n '/' +\n (representation.version?.product?.name || '') +\n '/' +\n representation.version?.version +\n '/' +\n representation.name,\n version: representation.version,\n product: representation.version.product,\n task: representation.version.task || undefined,\n folder: representation.version.product?.folder,\n representations: undefined,\n }\n }\n}\n"],"names":["detailsPanelEntityTypes","transformDetailsPanelQueriesData","entity","entityType","projectName","task","parseAllAttribs","_a","_d","_c","_b","version","_f","_e","_g","_h","_i","_j","_l","_k","edge","folder","representation","_o","_n","_m","_q","_p","_r","_s"],"mappings":"
|
|
1
|
+
{"version":3,"file":"transformDetailsPanelData.cjs.js","sources":["../../../../../../src/api/queries/entities/transformDetailsPanelData.ts"],"sourcesContent":["import {\n DetailsPanelFolderFragmentFragment,\n DetailsPanelProductFragmentFragment,\n DetailsPanelRepresentationFragmentFragment,\n DetailsPanelTaskFragmentFragment,\n DetailsPanelVersionFragmentFragment,\n GetDetailsPanelFolderQuery,\n GetDetailsPanelRepresentationQuery,\n GetDetailsPanelTaskQuery,\n GetDetailsPanelVersionQuery,\n} from '@shared/api/generated'\nimport { parseAllAttribs } from '@shared/api'\n\ntype DetailsPanelTask = NonNullable<GetDetailsPanelTaskQuery['project']['task']>\ntype DetailsPanelRepresentation = NonNullable<\n GetDetailsPanelRepresentationQuery['project']['representation']\n>\ntype DetailsPanelVersion = NonNullable<GetDetailsPanelVersionQuery['project']['version']>\ntype DetailsPanelFolder = NonNullable<GetDetailsPanelFolderQuery['project']['folder']>\n\nexport const detailsPanelEntityTypes = ['task', 'version', 'folder', 'representation'] as const\nexport type DetailsPanelEntityType = (typeof detailsPanelEntityTypes)[number]\n\ntype TransformEntityDataArgs = {\n entity: DetailsPanelRepresentation | DetailsPanelTask | DetailsPanelVersion | DetailsPanelFolder\n entityType: DetailsPanelEntityType\n projectName: string\n}\n\ntype NullableString = string | null | undefined\n\n// return type\nexport type DetailsPanelEntityData = {\n id: string\n name: string\n label: NullableString\n tags: string[]\n status: string\n updatedAt: string\n createdAt: string\n attrib: Record<string, string | number>\n hasReviewables?: boolean\n thumbnailId?: string | null | undefined\n path: string\n // extra metadata\n entityType: string\n entitySubType?: string\n projectName: string\n // type specific\n task?: DetailsPanelTaskFragmentFragment\n folder?: DetailsPanelFolderFragmentFragment\n product?: DetailsPanelProductFragmentFragment\n version?: DetailsPanelVersionFragmentFragment\n representations?: DetailsPanelRepresentationFragmentFragment[]\n}\n\n// takes the data from different entity types and returns a single data model\nexport const transformDetailsPanelQueriesData = ({\n entity,\n entityType,\n projectName,\n}: TransformEntityDataArgs): DetailsPanelEntityData => {\n switch (entityType) {\n case 'task':\n const task = entity as DetailsPanelTask\n return {\n entityType: 'task',\n entitySubType: task.taskType,\n projectName: projectName,\n id: task.id,\n name: task.name,\n label: task.label,\n tags: task.tags,\n status: task.status,\n updatedAt: task.updatedAt,\n createdAt: task.createdAt,\n attrib: parseAllAttribs(task.allAttrib),\n hasReviewables: task.hasReviewables,\n thumbnailId: task.thumbnailId,\n path: (task.folder?.path || '') + '/' + task.name,\n folder: task.folder,\n task: {\n id: task.id,\n name: task.name,\n label: task.label,\n assignees: task.assignees,\n taskType: task.taskType,\n },\n product: undefined,\n version: task.versions?.edges?.[0]?.node,\n }\n case 'version':\n const version = entity as DetailsPanelVersion\n return {\n entityType: 'version',\n entitySubType: undefined,\n projectName: projectName,\n id: version.id,\n name: version.name,\n label: undefined,\n tags: version.tags,\n status: version.status,\n updatedAt: version.updatedAt,\n createdAt: version.createdAt,\n attrib: parseAllAttribs(version.allAttrib),\n hasReviewables: version.hasReviewables,\n thumbnailId: version.thumbnailId,\n path:\n (version.product?.folder?.path || '') + '/' + version.product.name + '/' + version.name,\n folder: version.product?.folder,\n task: version.task ?? undefined,\n product: {\n id: version.product?.id,\n name: version.product?.name,\n productType: version.product?.productType,\n latestVersion: version.product.latestVersion,\n },\n version: {\n version: version.version,\n id: version.id,\n name: version.name,\n updatedAt: version.updatedAt,\n createdAt: version.createdAt,\n productId: version.product.id,\n },\n representations: version.representations?.edges?.map((edge) => edge.node) || [],\n }\n case 'folder':\n const folder = entity as DetailsPanelFolder\n return {\n entityType: 'folder',\n entitySubType: folder.folderType,\n projectName: projectName,\n id: folder.id,\n name: folder.name,\n label: folder.label,\n tags: folder.tags,\n status: folder.status,\n updatedAt: folder.updatedAt,\n createdAt: folder.createdAt,\n attrib: parseAllAttribs(folder.allAttrib),\n hasReviewables: folder.hasReviewables,\n thumbnailId: folder.thumbnailId,\n path: folder.path || '',\n folder: {\n id: folder.id,\n name: folder.name,\n label: folder.label,\n folderType: folder.folderType,\n },\n product: undefined,\n version: undefined,\n representations: undefined,\n }\n case 'representation':\n const representation = entity as DetailsPanelRepresentation\n return {\n entityType: 'representation',\n entitySubType: undefined,\n projectName: projectName,\n id: representation.id,\n name: representation.name,\n label: undefined,\n tags: representation.tags,\n status: representation.status,\n updatedAt: representation.updatedAt,\n createdAt: representation.createdAt,\n attrib: parseAllAttribs(representation.allAttrib),\n hasReviewables: undefined,\n thumbnailId: undefined,\n path:\n (representation.version?.product?.folder?.path || '') +\n '/' +\n (representation.version?.product?.name || '') +\n '/' +\n representation.version?.version +\n '/' +\n representation.name,\n version: representation.version,\n product: representation.version.product,\n task: representation.version.task || undefined,\n folder: representation.version.product?.folder,\n representations: undefined,\n }\n }\n}\n"],"names":["detailsPanelEntityTypes","transformDetailsPanelQueriesData","entity","entityType","projectName","task","parseAllAttribs","_a","_d","_c","_b","version","_f","_e","_g","_h","_i","_j","_l","_k","edge","folder","representation","_o","_n","_m","_q","_p","_r","_s"],"mappings":"k8GAoBO,MAAMA,EAA0B,CAAC,OAAQ,UAAW,SAAU,gBAAgB,EAqCxEC,EAAmC,CAAC,CAC/C,OAAAC,EACA,WAAAC,EACA,YAAAC,CACF,IAAuD,2CACrD,OAAQD,EAAY,CAClB,IAAK,OACH,MAAME,EAAOH,EACN,MAAA,CACL,WAAY,OACZ,cAAeG,EAAK,SACpB,YAAAD,EACA,GAAIC,EAAK,GACT,KAAMA,EAAK,KACX,MAAOA,EAAK,MACZ,KAAMA,EAAK,KACX,OAAQA,EAAK,OACb,UAAWA,EAAK,UAChB,UAAWA,EAAK,UAChB,OAAQC,EAAAA,gBAAgBD,EAAK,SAAS,EACtC,eAAgBA,EAAK,eACrB,YAAaA,EAAK,YAClB,QAAOE,EAAAF,EAAK,SAAL,YAAAE,EAAa,OAAQ,IAAM,IAAMF,EAAK,KAC7C,OAAQA,EAAK,OACb,KAAM,CACJ,GAAIA,EAAK,GACT,KAAMA,EAAK,KACX,MAAOA,EAAK,MACZ,UAAWA,EAAK,UAChB,SAAUA,EAAK,QACjB,EACA,QAAS,OACT,SAASG,GAAAC,GAAAC,EAAAL,EAAK,WAAL,YAAAK,EAAe,QAAf,YAAAD,EAAuB,KAAvB,YAAAD,EAA2B,IACtC,EACF,IAAK,UACH,MAAMG,EAAUT,EACT,MAAA,CACL,WAAY,UACZ,cAAe,OACf,YAAAE,EACA,GAAIO,EAAQ,GACZ,KAAMA,EAAQ,KACd,MAAO,OACP,KAAMA,EAAQ,KACd,OAAQA,EAAQ,OAChB,UAAWA,EAAQ,UACnB,UAAWA,EAAQ,UACnB,OAAQL,EAAAA,gBAAgBK,EAAQ,SAAS,EACzC,eAAgBA,EAAQ,eACxB,YAAaA,EAAQ,YACrB,QACGC,GAAAC,EAAAF,EAAQ,UAAR,YAAAE,EAAiB,SAAjB,YAAAD,EAAyB,OAAQ,IAAM,IAAMD,EAAQ,QAAQ,KAAO,IAAMA,EAAQ,KACrF,QAAQG,EAAAH,EAAQ,UAAR,YAAAG,EAAiB,OACzB,KAAMH,EAAQ,MAAQ,OACtB,QAAS,CACP,IAAII,EAAAJ,EAAQ,UAAR,YAAAI,EAAiB,GACrB,MAAMC,EAAAL,EAAQ,UAAR,YAAAK,EAAiB,KACvB,aAAaC,EAAAN,EAAQ,UAAR,YAAAM,EAAiB,YAC9B,cAAeN,EAAQ,QAAQ,aACjC,EACA,QAAS,CACP,QAASA,EAAQ,QACjB,GAAIA,EAAQ,GACZ,KAAMA,EAAQ,KACd,UAAWA,EAAQ,UACnB,UAAWA,EAAQ,UACnB,UAAWA,EAAQ,QAAQ,EAC7B,EACA,kBAAiBO,GAAAC,EAAAR,EAAQ,kBAAR,YAAAQ,EAAyB,QAAzB,YAAAD,EAAgC,IAAKE,GAASA,EAAK,QAAS,CAAA,CAC/E,EACF,IAAK,SACH,MAAMC,EAASnB,EACR,MAAA,CACL,WAAY,SACZ,cAAemB,EAAO,WACtB,YAAAjB,EACA,GAAIiB,EAAO,GACX,KAAMA,EAAO,KACb,MAAOA,EAAO,MACd,KAAMA,EAAO,KACb,OAAQA,EAAO,OACf,UAAWA,EAAO,UAClB,UAAWA,EAAO,UAClB,OAAQf,EAAAA,gBAAgBe,EAAO,SAAS,EACxC,eAAgBA,EAAO,eACvB,YAAaA,EAAO,YACpB,KAAMA,EAAO,MAAQ,GACrB,OAAQ,CACN,GAAIA,EAAO,GACX,KAAMA,EAAO,KACb,MAAOA,EAAO,MACd,WAAYA,EAAO,UACrB,EACA,QAAS,OACT,QAAS,OACT,gBAAiB,MACnB,EACF,IAAK,iBACH,MAAMC,EAAiBpB,EAChB,MAAA,CACL,WAAY,iBACZ,cAAe,OACf,YAAAE,EACA,GAAIkB,EAAe,GACnB,KAAMA,EAAe,KACrB,MAAO,OACP,KAAMA,EAAe,KACrB,OAAQA,EAAe,OACvB,UAAWA,EAAe,UAC1B,UAAWA,EAAe,UAC1B,OAAQhB,EAAAA,gBAAgBgB,EAAe,SAAS,EAChD,eAAgB,OAChB,YAAa,OACb,QACGC,GAAAC,GAAAC,EAAAH,EAAe,UAAf,YAAAG,EAAwB,UAAxB,YAAAD,EAAiC,SAAjC,YAAAD,EAAyC,OAAQ,IAClD,OACCG,GAAAC,EAAAL,EAAe,UAAf,YAAAK,EAAwB,UAAxB,YAAAD,EAAiC,OAAQ,IAC1C,MACAE,EAAAN,EAAe,UAAf,YAAAM,EAAwB,SACxB,IACAN,EAAe,KACjB,QAASA,EAAe,QACxB,QAASA,EAAe,QAAQ,QAChC,KAAMA,EAAe,QAAQ,MAAQ,OACrC,QAAQO,EAAAP,EAAe,QAAQ,UAAvB,YAAAO,EAAgC,OACxC,gBAAiB,MACnB,CAAA,CAEN"}
|
|
@@ -74,11 +74,12 @@ import "../system/getSystem.es.js";
|
|
|
74
74
|
import "../userDashboard/getUserDashboard.es.js";
|
|
75
75
|
import "../users/getUsers.es.js";
|
|
76
76
|
import "../users/updateUsers.es.js";
|
|
77
|
+
import "../users/guests.es.js";
|
|
77
78
|
import "../versions/updateVersions.es.js";
|
|
78
79
|
import "../views/getViews.es.js";
|
|
79
80
|
import "../views/updateViews.es.js";
|
|
80
81
|
import "../watchers/getWatchers.es.js";
|
|
81
|
-
const
|
|
82
|
+
const ee = ["task", "version", "folder", "representation"], re = ({
|
|
82
83
|
entity: o,
|
|
83
84
|
entityType: S,
|
|
84
85
|
projectName: p
|
|
@@ -201,7 +202,7 @@ const te = ["task", "version", "folder", "representation"], ee = ({
|
|
|
201
202
|
}
|
|
202
203
|
};
|
|
203
204
|
export {
|
|
204
|
-
|
|
205
|
-
|
|
205
|
+
ee as detailsPanelEntityTypes,
|
|
206
|
+
re as transformDetailsPanelQueriesData
|
|
206
207
|
};
|
|
207
208
|
//# sourceMappingURL=transformDetailsPanelData.es.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transformDetailsPanelData.es.js","sources":["../../../../../../src/api/queries/entities/transformDetailsPanelData.ts"],"sourcesContent":["import {\n DetailsPanelFolderFragmentFragment,\n DetailsPanelProductFragmentFragment,\n DetailsPanelRepresentationFragmentFragment,\n DetailsPanelTaskFragmentFragment,\n DetailsPanelVersionFragmentFragment,\n GetDetailsPanelFolderQuery,\n GetDetailsPanelRepresentationQuery,\n GetDetailsPanelTaskQuery,\n GetDetailsPanelVersionQuery,\n} from '@shared/api/generated'\nimport { parseAllAttribs } from '@shared/api'\n\ntype DetailsPanelTask = NonNullable<GetDetailsPanelTaskQuery['project']['task']>\ntype DetailsPanelRepresentation = NonNullable<\n GetDetailsPanelRepresentationQuery['project']['representation']\n>\ntype DetailsPanelVersion = NonNullable<GetDetailsPanelVersionQuery['project']['version']>\ntype DetailsPanelFolder = NonNullable<GetDetailsPanelFolderQuery['project']['folder']>\n\nexport const detailsPanelEntityTypes = ['task', 'version', 'folder', 'representation'] as const\nexport type DetailsPanelEntityType = (typeof detailsPanelEntityTypes)[number]\n\ntype TransformEntityDataArgs = {\n entity: DetailsPanelRepresentation | DetailsPanelTask | DetailsPanelVersion | DetailsPanelFolder\n entityType: DetailsPanelEntityType\n projectName: string\n}\n\ntype NullableString = string | null | undefined\n\n// return type\nexport type DetailsPanelEntityData = {\n id: string\n name: string\n label: NullableString\n tags: string[]\n status: string\n updatedAt: string\n createdAt: string\n attrib: Record<string, string | number>\n hasReviewables?: boolean\n thumbnailId?: string | null | undefined\n path: string\n // extra metadata\n entityType: string\n entitySubType?: string\n projectName: string\n // type specific\n task?: DetailsPanelTaskFragmentFragment\n folder?: DetailsPanelFolderFragmentFragment\n product?: DetailsPanelProductFragmentFragment\n version?: DetailsPanelVersionFragmentFragment\n representations?: DetailsPanelRepresentationFragmentFragment[]\n}\n\n// takes the data from different entity types and returns a single data model\nexport const transformDetailsPanelQueriesData = ({\n entity,\n entityType,\n projectName,\n}: TransformEntityDataArgs): DetailsPanelEntityData => {\n switch (entityType) {\n case 'task':\n const task = entity as DetailsPanelTask\n return {\n entityType: 'task',\n entitySubType: task.taskType,\n projectName: projectName,\n id: task.id,\n name: task.name,\n label: task.label,\n tags: task.tags,\n status: task.status,\n updatedAt: task.updatedAt,\n createdAt: task.createdAt,\n attrib: parseAllAttribs(task.allAttrib),\n hasReviewables: task.hasReviewables,\n thumbnailId: task.thumbnailId,\n path: (task.folder?.path || '') + '/' + task.name,\n folder: task.folder,\n task: {\n id: task.id,\n name: task.name,\n label: task.label,\n assignees: task.assignees,\n taskType: task.taskType,\n },\n product: undefined,\n version: task.versions?.edges?.[0]?.node,\n }\n case 'version':\n const version = entity as DetailsPanelVersion\n return {\n entityType: 'version',\n entitySubType: undefined,\n projectName: projectName,\n id: version.id,\n name: version.name,\n label: undefined,\n tags: version.tags,\n status: version.status,\n updatedAt: version.updatedAt,\n createdAt: version.createdAt,\n attrib: parseAllAttribs(version.allAttrib),\n hasReviewables: version.hasReviewables,\n thumbnailId: version.thumbnailId,\n path:\n (version.product?.folder?.path || '') + '/' + version.product.name + '/' + version.name,\n folder: version.product?.folder,\n task: version.task ?? undefined,\n product: {\n id: version.product?.id,\n name: version.product?.name,\n productType: version.product?.productType,\n latestVersion: version.product.latestVersion,\n },\n version: {\n version: version.version,\n id: version.id,\n name: version.name,\n updatedAt: version.updatedAt,\n createdAt: version.createdAt,\n productId: version.product.id,\n },\n representations: version.representations?.edges?.map((edge) => edge.node) || [],\n }\n case 'folder':\n const folder = entity as DetailsPanelFolder\n return {\n entityType: 'folder',\n entitySubType: folder.folderType,\n projectName: projectName,\n id: folder.id,\n name: folder.name,\n label: folder.label,\n tags: folder.tags,\n status: folder.status,\n updatedAt: folder.updatedAt,\n createdAt: folder.createdAt,\n attrib: parseAllAttribs(folder.allAttrib),\n hasReviewables: folder.hasReviewables,\n thumbnailId: folder.thumbnailId,\n path: folder.path || '',\n folder: {\n id: folder.id,\n name: folder.name,\n label: folder.label,\n folderType: folder.folderType,\n },\n product: undefined,\n version: undefined,\n representations: undefined,\n }\n case 'representation':\n const representation = entity as DetailsPanelRepresentation\n return {\n entityType: 'representation',\n entitySubType: undefined,\n projectName: projectName,\n id: representation.id,\n name: representation.name,\n label: undefined,\n tags: representation.tags,\n status: representation.status,\n updatedAt: representation.updatedAt,\n createdAt: representation.createdAt,\n attrib: parseAllAttribs(representation.allAttrib),\n hasReviewables: undefined,\n thumbnailId: undefined,\n path:\n (representation.version?.product?.folder?.path || '') +\n '/' +\n (representation.version?.product?.name || '') +\n '/' +\n representation.version?.version +\n '/' +\n representation.name,\n version: representation.version,\n product: representation.version.product,\n task: representation.version.task || undefined,\n folder: representation.version.product?.folder,\n representations: undefined,\n }\n }\n}\n"],"names":["detailsPanelEntityTypes","transformDetailsPanelQueriesData","entity","entityType","projectName","task","parseAllAttribs","_a","_d","_c","_b","version","_f","_e","_g","_h","_i","_j","_l","_k","edge","folder","representation","_o","_n","_m","_q","_p","_r","_s"],"mappings":"
|
|
1
|
+
{"version":3,"file":"transformDetailsPanelData.es.js","sources":["../../../../../../src/api/queries/entities/transformDetailsPanelData.ts"],"sourcesContent":["import {\n DetailsPanelFolderFragmentFragment,\n DetailsPanelProductFragmentFragment,\n DetailsPanelRepresentationFragmentFragment,\n DetailsPanelTaskFragmentFragment,\n DetailsPanelVersionFragmentFragment,\n GetDetailsPanelFolderQuery,\n GetDetailsPanelRepresentationQuery,\n GetDetailsPanelTaskQuery,\n GetDetailsPanelVersionQuery,\n} from '@shared/api/generated'\nimport { parseAllAttribs } from '@shared/api'\n\ntype DetailsPanelTask = NonNullable<GetDetailsPanelTaskQuery['project']['task']>\ntype DetailsPanelRepresentation = NonNullable<\n GetDetailsPanelRepresentationQuery['project']['representation']\n>\ntype DetailsPanelVersion = NonNullable<GetDetailsPanelVersionQuery['project']['version']>\ntype DetailsPanelFolder = NonNullable<GetDetailsPanelFolderQuery['project']['folder']>\n\nexport const detailsPanelEntityTypes = ['task', 'version', 'folder', 'representation'] as const\nexport type DetailsPanelEntityType = (typeof detailsPanelEntityTypes)[number]\n\ntype TransformEntityDataArgs = {\n entity: DetailsPanelRepresentation | DetailsPanelTask | DetailsPanelVersion | DetailsPanelFolder\n entityType: DetailsPanelEntityType\n projectName: string\n}\n\ntype NullableString = string | null | undefined\n\n// return type\nexport type DetailsPanelEntityData = {\n id: string\n name: string\n label: NullableString\n tags: string[]\n status: string\n updatedAt: string\n createdAt: string\n attrib: Record<string, string | number>\n hasReviewables?: boolean\n thumbnailId?: string | null | undefined\n path: string\n // extra metadata\n entityType: string\n entitySubType?: string\n projectName: string\n // type specific\n task?: DetailsPanelTaskFragmentFragment\n folder?: DetailsPanelFolderFragmentFragment\n product?: DetailsPanelProductFragmentFragment\n version?: DetailsPanelVersionFragmentFragment\n representations?: DetailsPanelRepresentationFragmentFragment[]\n}\n\n// takes the data from different entity types and returns a single data model\nexport const transformDetailsPanelQueriesData = ({\n entity,\n entityType,\n projectName,\n}: TransformEntityDataArgs): DetailsPanelEntityData => {\n switch (entityType) {\n case 'task':\n const task = entity as DetailsPanelTask\n return {\n entityType: 'task',\n entitySubType: task.taskType,\n projectName: projectName,\n id: task.id,\n name: task.name,\n label: task.label,\n tags: task.tags,\n status: task.status,\n updatedAt: task.updatedAt,\n createdAt: task.createdAt,\n attrib: parseAllAttribs(task.allAttrib),\n hasReviewables: task.hasReviewables,\n thumbnailId: task.thumbnailId,\n path: (task.folder?.path || '') + '/' + task.name,\n folder: task.folder,\n task: {\n id: task.id,\n name: task.name,\n label: task.label,\n assignees: task.assignees,\n taskType: task.taskType,\n },\n product: undefined,\n version: task.versions?.edges?.[0]?.node,\n }\n case 'version':\n const version = entity as DetailsPanelVersion\n return {\n entityType: 'version',\n entitySubType: undefined,\n projectName: projectName,\n id: version.id,\n name: version.name,\n label: undefined,\n tags: version.tags,\n status: version.status,\n updatedAt: version.updatedAt,\n createdAt: version.createdAt,\n attrib: parseAllAttribs(version.allAttrib),\n hasReviewables: version.hasReviewables,\n thumbnailId: version.thumbnailId,\n path:\n (version.product?.folder?.path || '') + '/' + version.product.name + '/' + version.name,\n folder: version.product?.folder,\n task: version.task ?? undefined,\n product: {\n id: version.product?.id,\n name: version.product?.name,\n productType: version.product?.productType,\n latestVersion: version.product.latestVersion,\n },\n version: {\n version: version.version,\n id: version.id,\n name: version.name,\n updatedAt: version.updatedAt,\n createdAt: version.createdAt,\n productId: version.product.id,\n },\n representations: version.representations?.edges?.map((edge) => edge.node) || [],\n }\n case 'folder':\n const folder = entity as DetailsPanelFolder\n return {\n entityType: 'folder',\n entitySubType: folder.folderType,\n projectName: projectName,\n id: folder.id,\n name: folder.name,\n label: folder.label,\n tags: folder.tags,\n status: folder.status,\n updatedAt: folder.updatedAt,\n createdAt: folder.createdAt,\n attrib: parseAllAttribs(folder.allAttrib),\n hasReviewables: folder.hasReviewables,\n thumbnailId: folder.thumbnailId,\n path: folder.path || '',\n folder: {\n id: folder.id,\n name: folder.name,\n label: folder.label,\n folderType: folder.folderType,\n },\n product: undefined,\n version: undefined,\n representations: undefined,\n }\n case 'representation':\n const representation = entity as DetailsPanelRepresentation\n return {\n entityType: 'representation',\n entitySubType: undefined,\n projectName: projectName,\n id: representation.id,\n name: representation.name,\n label: undefined,\n tags: representation.tags,\n status: representation.status,\n updatedAt: representation.updatedAt,\n createdAt: representation.createdAt,\n attrib: parseAllAttribs(representation.allAttrib),\n hasReviewables: undefined,\n thumbnailId: undefined,\n path:\n (representation.version?.product?.folder?.path || '') +\n '/' +\n (representation.version?.product?.name || '') +\n '/' +\n representation.version?.version +\n '/' +\n representation.name,\n version: representation.version,\n product: representation.version.product,\n task: representation.version.task || undefined,\n folder: representation.version.product?.folder,\n representations: undefined,\n }\n }\n}\n"],"names":["detailsPanelEntityTypes","transformDetailsPanelQueriesData","entity","entityType","projectName","task","parseAllAttribs","_a","_d","_c","_b","version","_f","_e","_g","_h","_i","_j","_l","_k","edge","folder","representation","_o","_n","_m","_q","_p","_r","_s"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const w=require("./getEntity.cjs.js");require("../actions/getActions.cjs.js");require("../activities/getActivities.cjs.js");require("../activities/updateActivities.cjs.js");require("../activities/updateReaction.cjs.js");require("../activities/getMentions.cjs.js");require("../activities/getCategories.cjs.js");require("../addons/getAddons.cjs.js");require("../addons/updateAddons.cjs.js");require("../attributes/getAttributes.cjs.js");require("../attributes/updateAttributes.cjs.js");require("../authentication/getAuthentication.cjs.js");require("../cloud/cloud.cjs.js");const G=require("./getEntityPanel.cjs.js");require("../../base/client.cjs.js");require("../../generated/graphql.cjs.js");require("../../generated/graphqlLinks.cjs.js");require("../../generated/access.cjs.js");require("../../generated/actions.cjs.js");require("../../generated/activityFeed.cjs.js");require("../../generated/addons.cjs.js");require("../../generated/anatomy.cjs.js");require("../../generated/attributes.cjs.js");require("../../generated/authentication.cjs.js");require("../../generated/bundles.cjs.js");require("../../generated/configuration.cjs.js");require("../../generated/desktop.cjs.js");require("../../generated/entityLists.cjs.js");require("../../generated/events.cjs.js");require("../../generated/files.cjs.js");require("../../generated/folders.cjs.js");require("../../generated/inbox.cjs.js");require("../../generated/links.cjs.js");require("../../generated/market.cjs.js");require("../../generated/onboarding.cjs.js");require("../../generated/operations.cjs.js");require("../../generated/products.cjs.js");require("../../generated/projectDashboard.cjs.js");require("../../generated/projects.cjs.js");require("../../generated/reviewables.cjs.js");require("../../generated/services.cjs.js");require("../../generated/system.cjs.js");require("../../generated/tasks.cjs.js");require("../../generated/teams.cjs.js");require("../../generated/thumbnails.cjs.js");require("../../generated/uRIs.cjs.js");require("../../generated/users.cjs.js");require("../../generated/versions.cjs.js");require("../../generated/workfiles.cjs.js");require("../../generated/ynputCloud.cjs.js");require("../../generated/grouping.cjs.js");require("../../generated/views.cjs.js");require("../entityLists/getLists.cjs.js");require("../entityLists/updateLists.cjs.js");require("../entityLists/getListsAttributes.cjs.js");require("../entityLists/updateListsAttributes.cjs.js");require("../entityLists/listFolders.cjs.js");require("../folders/getFolders.cjs.js");require("../grouping/getGrouping.cjs.js");require("../links/updateLinks.cjs.js");require("../links/getLinks.cjs.js");require("../links/getEntityLinks.cjs.js");require("../overview/getOverview.cjs.js");const x=require("../overview/updateOverview.cjs.js");require("../permissions/getPermissions.cjs.js");require("../products/createProduct.cjs.js");require("../project/getProject.cjs.js");require("../project/updateProject.cjs.js");require("../review/getReview.cjs.js");require("../review/updateReview.cjs.js");require("../share/share.cjs.js");require("../system/getSystem.cjs.js");const T=require("../userDashboard/getUserDashboard.cjs.js");require("../users/getUsers.cjs.js");require("../users/updateUsers.cjs.js");require("../versions/updateVersions.cjs.js");require("../views/getViews.cjs.js");require("../views/updateViews.cjs.js");require("../watchers/getWatchers.cjs.js");const H=require("react-toastify"),F=({assignees:b=[],projects:d=[]},{newAssignees:e,taskId:s,data:n,taskData:l},{dispatch:a})=>{let v=!1;return[a(T.dashboardQueries.util.updateQueryData("GetKanban",{projects:d,assignees:b},f=>{var h,r;const g=f.findIndex(t=>t.id===s);let u={...n};if((h=n==null?void 0:n.attrib)!=null&&h.priority){const{priority:t}=u.attrib;u={...u,priority:t}}if((r=n==null?void 0:n.attrib)!=null&&r.endDate){const{endDate:t}=u.attrib;u={...u,dueDate:t},delete u.attrib.endDate}if(g===-1)l?f.push(l):v=!1;else if(v=!0,!(e==null?void 0:e.some(c=>b.includes(c)))&&e)f.splice(g,1);else{const c={...f[g],...u};f[g]=c}})),v]},L=({operations:b=[],state:d,dispatch:e,entityType:s})=>{const n=b.map(a=>({type:"progress",id:a.id}));let l=w.default.util.selectInvalidatedBy(d,n);if(!l.length)return[];try{return l.map(v=>e(w.default.util.updateQueryData(v.endpointName,v.originalArgs,o=>{var f,g;for(const u of b){const h=u.id,r=u.data;if(s==="task"){const t=(f=u.meta)==null?void 0:f.folderId,c=o.find(i=>i.id===t);if(!c)throw new Error("Patching progress view: folder not found");const k=(g=c.tasks)==null?void 0:g.find(i=>i.id===h);if(!k)throw new Error("Patching progress view: task not found");const y={...k,...r},p={...c,tasks:c.tasks.map(i=>i.id===h?y:i)},S=o.findIndex(i=>i.id===t);o[S]=p}else if(s==="folder"){const t=o.find(p=>p.id===h);if(!t)throw new Error("Patching progress view: folder not found");let c={...r};if(r.name&&t.path){const p=t.path.split("/");p[p.length-1]=r.name,c.path=p.join("/")}const k={...t,...c},y=o.findIndex(p=>p.id===h);o[y]=k}}})))}catch(a){return console.error(a),e(w.default.util.invalidateTags(n)),[]}},O=w.default.injectEndpoints({endpoints:b=>({updateEntity:b.mutation({query:({projectName:d,entityId:e,data:s,entityType:n})=>({url:`/api/projects/${d}/${n}s/${e}`,method:"PATCH",body:s}),async onQueryStarted({projectName:d,entityId:e,data:s,currentAssignees:n,entityType:l},{dispatch:a,queryFulfilled:v,getState:o}){var t,c,k,y,p,S;const f=o(),g=[];let u=[];if(l==="task"){const i=((t=o().dashboard)==null?void 0:t.selectedProjects)||[],E=((c=o().dashboard)==null?void 0:c.tasks.assignees)||[],Q=((k=o().dashboard)==null?void 0:k.tasks.assigneesFilter)==="me",m=s.assignees,j=Q?[(y=o().user)==null?void 0:y.name]:E,B=[...new Set([...n,...m||[]])].some(q=>j.includes(q)),K=i.some(q=>q===d);if(B&&K){const[q,P]=F({assignees:j,projects:i},{newAssignees:m,taskId:e,data:s},{dispatch:a});P&&g.push(q),P||T.getKanbanTasks({projects:[d],taskIds:[e]},a).then(D=>{let A=D.find(R=>R.id===e);A&&(A={...A,assignees:m},F({assignees:j,projects:i},{newAssignees:m,taskId:e,taskData:A},{dispatch:a}))})}const M=[{type:"task",id:e}];if(m!=null&&m.length){const q=new Set(n),P=new Set(m),D=[...q].filter(I=>!P.has(I)),A=[...P].filter(I=>!q.has(I)),$=[...new Set([...D,...A])].map(I=>({type:"kanban",id:"user-"+I+"-project-"+d}));M.push(...$),a(T.dashboardQueries.util.invalidateTags([{type:"watchers",id:e}]))}let N=T.dashboardQueries.util.selectInvalidatedBy(f,M),U=[];for(const q of N){const[P,D]=F({assignees:q.originalArgs.assignees,projects:q.originalArgs.projects},{newAssignees:m,taskId:e,data:s},{dispatch:a});D?g.push(P):U.push(q)}const C={projects:i,assignees:j};U=U.filter(q=>JSON.stringify(q.originalArgs)!==JSON.stringify(C));const J=N.map(q=>({type:"kanban",id:JSON.stringify(q.originalArgs)}));u.push(...J)}const h=[{type:"entities",id:e}],r=w.default.util.selectInvalidatedBy(f,h);for(const i of r){let E=a(G.detailsPanelQueries.util.updateQueryData("getEntitiesDetailsPanel",i.originalArgs,Q=>{for(const m of Q)x.patchDetailsPanelEntity([{entityId:e,data:s,entityType:l}],m)}));g.push(E)}try{await v,u.length&&a(T.dashboardQueries.util.invalidateTags(u))}catch(i){console.error("error updating "+l,i),H.toast.error(((S=(p=i==null?void 0:i.error)==null?void 0:p.data)==null?void 0:S.detail)||"Failed to update task"),g.forEach(E=>E==null?void 0:E.undo())}}}),updateEntities:b.mutation({async queryFn({operations:d=[],entityType:e},{dispatch:s,getState:n}){try{const l=n(),a=[];for(const{projectName:r,data:t,id:c,currentAssignees:k=[]}of d){const y=s(O.endpoints.updateEntity.initiate({projectName:r,entityId:c,data:t,entityType:e,currentAssignees:k}));a.push(y)}let v=[];(e==="task"||e==="folder")&&(v=L({operations:d,state:l,dispatch:s,entityType:e}));const o=[],f=d.map(r=>({...r,entityId:r.id}));if((e==="task"||e==="folder")&&(e==="task"&&x.patchOverviewTasks(f,{state:l,dispatch:s},o),e==="folder"&&(x.patchOverviewFolders(f,{state:l,dispatch:s},o),console.log("invalidate overview folders"),s(w.default.util.invalidateTags([{type:"folder",id:"LIST"}])),s(w.default.util.invalidateTags(f.map(r=>({type:"overviewTask",id:r.entityId})))))),(await Promise.allSettled(a)).some(r=>{var t;return(t=r.value)==null?void 0:t.error}))throw s(w.default.util.invalidateTags(d.map(r=>({type:"kanBanTask",id:r.id})))),v.forEach(r=>r==null?void 0:r.undo()),o.forEach(r=>r==null?void 0:r.undo()),"Failed to update some tasks";const h=[];return h.length&&s(w.default.util.invalidateTags(h)),{data:d}}catch(l){return console.error(l),{error:l}}},invalidatesTags:(d,e,{operations:s})=>[...s.map(n=>({id:n.id,type:"review"}))]})}),overrideExisting:!0}),{useUpdateEntitiesMutation:V,useUpdateEntityMutation:W}=O;exports.entitiesQueries=O;exports.useUpdateEntitiesMutation=V;exports.useUpdateEntityMutation=W;
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const w=require("./getEntity.cjs.js");require("../actions/getActions.cjs.js");require("../activities/getActivities.cjs.js");require("../activities/updateActivities.cjs.js");require("../activities/updateReaction.cjs.js");require("../activities/getMentions.cjs.js");require("../activities/getCategories.cjs.js");require("../addons/getAddons.cjs.js");require("../addons/updateAddons.cjs.js");require("../attributes/getAttributes.cjs.js");require("../attributes/updateAttributes.cjs.js");require("../authentication/getAuthentication.cjs.js");require("../cloud/cloud.cjs.js");const G=require("./getEntityPanel.cjs.js");require("../../base/client.cjs.js");require("../../generated/graphql.cjs.js");require("../../generated/graphqlLinks.cjs.js");require("../../generated/access.cjs.js");require("../../generated/actions.cjs.js");require("../../generated/activityFeed.cjs.js");require("../../generated/addons.cjs.js");require("../../generated/anatomy.cjs.js");require("../../generated/attributes.cjs.js");require("../../generated/authentication.cjs.js");require("../../generated/bundles.cjs.js");require("../../generated/configuration.cjs.js");require("../../generated/desktop.cjs.js");require("../../generated/entityLists.cjs.js");require("../../generated/events.cjs.js");require("../../generated/files.cjs.js");require("../../generated/folders.cjs.js");require("../../generated/inbox.cjs.js");require("../../generated/links.cjs.js");require("../../generated/market.cjs.js");require("../../generated/onboarding.cjs.js");require("../../generated/operations.cjs.js");require("../../generated/products.cjs.js");require("../../generated/projectDashboard.cjs.js");require("../../generated/projects.cjs.js");require("../../generated/reviewables.cjs.js");require("../../generated/services.cjs.js");require("../../generated/system.cjs.js");require("../../generated/tasks.cjs.js");require("../../generated/teams.cjs.js");require("../../generated/thumbnails.cjs.js");require("../../generated/uRIs.cjs.js");require("../../generated/users.cjs.js");require("../../generated/versions.cjs.js");require("../../generated/workfiles.cjs.js");require("../../generated/ynputCloud.cjs.js");require("../../generated/grouping.cjs.js");require("../../generated/views.cjs.js");require("../entityLists/getLists.cjs.js");require("../entityLists/updateLists.cjs.js");require("../entityLists/getListsAttributes.cjs.js");require("../entityLists/updateListsAttributes.cjs.js");require("../entityLists/listFolders.cjs.js");require("../folders/getFolders.cjs.js");require("../grouping/getGrouping.cjs.js");require("../links/updateLinks.cjs.js");require("../links/getLinks.cjs.js");require("../links/getEntityLinks.cjs.js");require("../overview/getOverview.cjs.js");const x=require("../overview/updateOverview.cjs.js");require("../permissions/getPermissions.cjs.js");require("../products/createProduct.cjs.js");require("../project/getProject.cjs.js");require("../project/updateProject.cjs.js");require("../review/getReview.cjs.js");require("../review/updateReview.cjs.js");require("../share/share.cjs.js");require("../system/getSystem.cjs.js");const T=require("../userDashboard/getUserDashboard.cjs.js");require("../users/getUsers.cjs.js");require("../users/updateUsers.cjs.js");require("../users/guests.cjs.js");require("../versions/updateVersions.cjs.js");require("../views/getViews.cjs.js");require("../views/updateViews.cjs.js");require("../watchers/getWatchers.cjs.js");const H=require("react-toastify"),F=({assignees:b=[],projects:d=[]},{newAssignees:e,taskId:s,data:n,taskData:l},{dispatch:a})=>{let v=!1;return[a(T.dashboardQueries.util.updateQueryData("GetKanban",{projects:d,assignees:b},f=>{var h,r;const g=f.findIndex(t=>t.id===s);let u={...n};if((h=n==null?void 0:n.attrib)!=null&&h.priority){const{priority:t}=u.attrib;u={...u,priority:t}}if((r=n==null?void 0:n.attrib)!=null&&r.endDate){const{endDate:t}=u.attrib;u={...u,dueDate:t},delete u.attrib.endDate}if(g===-1)l?f.push(l):v=!1;else if(v=!0,!(e==null?void 0:e.some(c=>b.includes(c)))&&e)f.splice(g,1);else{const c={...f[g],...u};f[g]=c}})),v]},L=({operations:b=[],state:d,dispatch:e,entityType:s})=>{const n=b.map(a=>({type:"progress",id:a.id}));let l=w.default.util.selectInvalidatedBy(d,n);if(!l.length)return[];try{return l.map(v=>e(w.default.util.updateQueryData(v.endpointName,v.originalArgs,o=>{var f,g;for(const u of b){const h=u.id,r=u.data;if(s==="task"){const t=(f=u.meta)==null?void 0:f.folderId,c=o.find(i=>i.id===t);if(!c)throw new Error("Patching progress view: folder not found");const k=(g=c.tasks)==null?void 0:g.find(i=>i.id===h);if(!k)throw new Error("Patching progress view: task not found");const y={...k,...r},p={...c,tasks:c.tasks.map(i=>i.id===h?y:i)},S=o.findIndex(i=>i.id===t);o[S]=p}else if(s==="folder"){const t=o.find(p=>p.id===h);if(!t)throw new Error("Patching progress view: folder not found");let c={...r};if(r.name&&t.path){const p=t.path.split("/");p[p.length-1]=r.name,c.path=p.join("/")}const k={...t,...c},y=o.findIndex(p=>p.id===h);o[y]=k}}})))}catch(a){return console.error(a),e(w.default.util.invalidateTags(n)),[]}},O=w.default.injectEndpoints({endpoints:b=>({updateEntity:b.mutation({query:({projectName:d,entityId:e,data:s,entityType:n})=>({url:`/api/projects/${d}/${n}s/${e}`,method:"PATCH",body:s}),async onQueryStarted({projectName:d,entityId:e,data:s,currentAssignees:n,entityType:l},{dispatch:a,queryFulfilled:v,getState:o}){var t,c,k,y,p,S;const f=o(),g=[];let u=[];if(l==="task"){const i=((t=o().dashboard)==null?void 0:t.selectedProjects)||[],E=((c=o().dashboard)==null?void 0:c.tasks.assignees)||[],Q=((k=o().dashboard)==null?void 0:k.tasks.assigneesFilter)==="me",m=s.assignees,j=Q?[(y=o().user)==null?void 0:y.name]:E,B=[...new Set([...n,...m||[]])].some(q=>j.includes(q)),K=i.some(q=>q===d);if(B&&K){const[q,P]=F({assignees:j,projects:i},{newAssignees:m,taskId:e,data:s},{dispatch:a});P&&g.push(q),P||T.getKanbanTasks({projects:[d],taskIds:[e]},a).then(D=>{let A=D.find(R=>R.id===e);A&&(A={...A,assignees:m},F({assignees:j,projects:i},{newAssignees:m,taskId:e,taskData:A},{dispatch:a}))})}const M=[{type:"task",id:e}];if(m!=null&&m.length){const q=new Set(n),P=new Set(m),D=[...q].filter(I=>!P.has(I)),A=[...P].filter(I=>!q.has(I)),$=[...new Set([...D,...A])].map(I=>({type:"kanban",id:"user-"+I+"-project-"+d}));M.push(...$),a(T.dashboardQueries.util.invalidateTags([{type:"watchers",id:e}]))}let N=T.dashboardQueries.util.selectInvalidatedBy(f,M),U=[];for(const q of N){const[P,D]=F({assignees:q.originalArgs.assignees,projects:q.originalArgs.projects},{newAssignees:m,taskId:e,data:s},{dispatch:a});D?g.push(P):U.push(q)}const C={projects:i,assignees:j};U=U.filter(q=>JSON.stringify(q.originalArgs)!==JSON.stringify(C));const J=N.map(q=>({type:"kanban",id:JSON.stringify(q.originalArgs)}));u.push(...J)}const h=[{type:"entities",id:e}],r=w.default.util.selectInvalidatedBy(f,h);for(const i of r){let E=a(G.detailsPanelQueries.util.updateQueryData("getEntitiesDetailsPanel",i.originalArgs,Q=>{for(const m of Q)x.patchDetailsPanelEntity([{entityId:e,data:s,entityType:l}],m)}));g.push(E)}try{await v,u.length&&a(T.dashboardQueries.util.invalidateTags(u))}catch(i){console.error("error updating "+l,i),H.toast.error(((S=(p=i==null?void 0:i.error)==null?void 0:p.data)==null?void 0:S.detail)||"Failed to update task"),g.forEach(E=>E==null?void 0:E.undo())}}}),updateEntities:b.mutation({async queryFn({operations:d=[],entityType:e},{dispatch:s,getState:n}){try{const l=n(),a=[];for(const{projectName:r,data:t,id:c,currentAssignees:k=[]}of d){const y=s(O.endpoints.updateEntity.initiate({projectName:r,entityId:c,data:t,entityType:e,currentAssignees:k}));a.push(y)}let v=[];(e==="task"||e==="folder")&&(v=L({operations:d,state:l,dispatch:s,entityType:e}));const o=[],f=d.map(r=>({...r,entityId:r.id}));if((e==="task"||e==="folder")&&(e==="task"&&x.patchOverviewTasks(f,{state:l,dispatch:s},o),e==="folder"&&(x.patchOverviewFolders(f,{state:l,dispatch:s},o),console.log("invalidate overview folders"),s(w.default.util.invalidateTags([{type:"folder",id:"LIST"}])),s(w.default.util.invalidateTags(f.map(r=>({type:"overviewTask",id:r.entityId})))))),(await Promise.allSettled(a)).some(r=>{var t;return(t=r.value)==null?void 0:t.error}))throw s(w.default.util.invalidateTags(d.map(r=>({type:"kanBanTask",id:r.id})))),v.forEach(r=>r==null?void 0:r.undo()),o.forEach(r=>r==null?void 0:r.undo()),"Failed to update some tasks";const h=[];return h.length&&s(w.default.util.invalidateTags(h)),{data:d}}catch(l){return console.error(l),{error:l}}},invalidatesTags:(d,e,{operations:s})=>[...s.map(n=>({id:n.id,type:"review"}))]})}),overrideExisting:!0}),{useUpdateEntitiesMutation:V,useUpdateEntityMutation:W}=O;exports.entitiesQueries=O;exports.useUpdateEntitiesMutation=V;exports.useUpdateEntityMutation=W;
|
|
2
2
|
//# sourceMappingURL=updateEntity.cjs.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"updateEntity.cjs.js","sources":["../../../../../../src/api/queries/entities/updateEntity.ts"],"sourcesContent":["// @ts-nocheck\n\nimport api from './getEntity'\nimport { detailsPanelQueries } from '@shared/api/queries'\nimport { patchDetailsPanelEntity } from '@shared/api'\nimport { toast } from 'react-toastify'\nimport { dashboardQueries, getKanbanTasks } from '@shared/api/queries/userDashboard'\nimport { patchOverviewFolders, patchOverviewTasks } from '@shared/api/queries/overview'\n\nconst patchKanban = (\n { assignees = [], projects = [] },\n { newAssignees, taskId, data, taskData },\n { dispatch },\n) => {\n let kanbanPatched = false\n const patchResult = dispatch(\n dashboardQueries.util.updateQueryData(\n 'GetKanban',\n { projects: projects, assignees: assignees },\n (draft) => {\n const taskIndex = draft.findIndex((task) => task.id === taskId)\n let patchData = { ...data }\n // if the data include attrib.priority it needs to be transformed to just priority\n // this is because priority is a top level field on kanban query\n if (data?.attrib?.priority) {\n const { priority } = patchData.attrib\n patchData = { ...patchData, priority }\n }\n // if the data include attrib.endDate it needs to be transformed to dueDate\n // this is because dueDate is a top level field on kanban query\n // NOTE TO SELF: Lets try to do these transforms after the cache the future.\n if (data?.attrib?.endDate) {\n const { endDate } = patchData.attrib\n patchData = { ...patchData, dueDate: endDate }\n delete patchData.attrib.endDate\n }\n\n if (taskIndex === -1) {\n // task not found, assignee must have just been added\n if (taskData) {\n // add the task to the cache\n draft.push(taskData)\n } else {\n // we don't have the task data, so we can't add it to the cache\n // we might add it later\n kanbanPatched = false\n }\n } else {\n kanbanPatched = true\n // first check that the task assignees still has a intersection with dashAssignees\n const hasSomeAssignees = newAssignees?.some((assignee) => assignees.includes(assignee))\n\n if (!hasSomeAssignees && newAssignees) {\n // remove from cache\n draft.splice(taskIndex, 1)\n } else {\n // task found: update the task in the cache\n const newData = { ...draft[taskIndex], ...patchData }\n draft[taskIndex] = newData\n }\n }\n },\n ),\n )\n\n return [patchResult, kanbanPatched]\n}\n\n// try to patch the progress view if there are queries that need to be updated\nconst patchProgressView = ({ operations = [], state, dispatch, entityType }) => {\n // create invalidation tags for progress view\n const invalidationTags = operations.map((o) => ({ type: 'progress', id: o.id }))\n // find the entries that need to be updated\n let entries = api.util.selectInvalidatedBy(state, invalidationTags)\n // if there are no entries, return\n if (!entries.length) return []\n\n try {\n // patch each entry with updated task data\n const patches = entries.map((entry) =>\n dispatch(\n api.util.updateQueryData(entry.endpointName, entry.originalArgs, (draft) => {\n for (const operation of operations) {\n const entityId = operation.id\n const patch = operation.data\n\n // patch the updated task data\n if (entityType === 'task') {\n const folderId = operation.meta?.folderId\n const folder = draft.find((folder) => folder.id === folderId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n const task = folder.tasks?.find((task) => task.id === entityId)\n if (!task) throw new Error('Patching progress view: task not found')\n // update task\n const newTask = { ...task, ...patch }\n // update folder\n const newFolder = {\n ...folder,\n tasks: folder.tasks.map((t) => (t.id === entityId ? newTask : t)),\n }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === folderId)\n draft[folderIndex] = newFolder\n } else if (entityType === 'folder') {\n const folder = draft.find((folder) => folder.id === entityId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n\n // If name is being updated, also update the path\n let updatedPatch = { ...patch }\n if (patch.name && folder.path) {\n // Construct new path by replacing the last segment with the new name\n const pathParts = folder.path.split('/')\n pathParts[pathParts.length - 1] = patch.name\n updatedPatch.path = pathParts.join('/')\n }\n\n // update folder\n const newFolder = { ...folder, ...updatedPatch }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === entityId)\n draft[folderIndex] = newFolder\n }\n }\n }),\n ),\n )\n return patches\n } catch (error) {\n console.error(error)\n // invalidate the progress view queries instead\n dispatch(api.util.invalidateTags(invalidationTags))\n return []\n }\n}\n\nconst updateEntity = api.injectEndpoints({\n endpoints: (build) => ({\n updateEntity: build.mutation({\n query: ({ projectName, entityId, data, entityType }) => ({\n url: `/api/projects/${projectName}/${entityType}s/${entityId}`,\n method: 'PATCH',\n body: data,\n }),\n async onQueryStarted(\n { projectName, entityId, data, currentAssignees, entityType },\n { dispatch, queryFulfilled, getState },\n ) {\n const state = getState()\n const patchResults = []\n\n let invalidationTagsAfterComplete = []\n // if task, patch the GetKanban query\n if (entityType === 'task') {\n const dashboardProjects = getState().dashboard?.selectedProjects || []\n const dashboardUsers = getState().dashboard?.tasks.assignees || []\n const dashboardAssigneesIsMe = getState().dashboard?.tasks.assigneesFilter === 'me'\n const newAssignees = data.assignees\n\n const cacheUsers = dashboardAssigneesIsMe ? [getState().user?.name] : dashboardUsers\n\n const entityAssignees = [...new Set([...currentAssignees, ...(newAssignees || [])])]\n const hasSomeAssignees = entityAssignees.some((assignee) => cacheUsers.includes(assignee))\n const hasSomeProjects = dashboardProjects.some((project) => project === projectName)\n const currentDashNeedsUpdating = hasSomeAssignees && hasSomeProjects\n\n if (currentDashNeedsUpdating) {\n const [result, wasPatched] = patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, data },\n { dispatch },\n )\n\n if (wasPatched) patchResults.push(result)\n\n if (!wasPatched) {\n // this means the task is not in the current kanban and it needs to be added\n\n // get the new task data\n getKanbanTasks({ projects: [projectName], taskIds: [entityId] }, dispatch).then(\n // use .then so that the rest of the code can run\n (response) => {\n let newTask = response.find((task) => task.id === entityId)\n if (newTask) {\n // add newAssignees as the actual DB hasn't been updated yet\n newTask = { ...newTask, assignees: newAssignees }\n\n patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, taskData: newTask },\n { dispatch },\n )\n }\n },\n )\n }\n }\n\n // always update the kanban if task id matches\n const tags = [{ type: 'task', id: entityId }]\n\n // are we changing the assignees?\n if (newAssignees?.length) {\n const currentAssigneesSet = new Set(currentAssignees)\n const newAssigneesSet = new Set(newAssignees)\n\n const removedAssignees = [...currentAssigneesSet].filter(\n (assignee) => !newAssigneesSet.has(assignee),\n )\n const addedAssignees = [...newAssigneesSet].filter(\n (assignee) => !currentAssigneesSet.has(assignee),\n )\n\n const changedAssignees = [...new Set([...removedAssignees, ...addedAssignees])]\n\n // any query that has those changed assignees, needs to be updated\n // we are changing the assignees\n const assigneesTags = changedAssignees.map((assignee) => ({\n type: 'kanban',\n id: 'user-' + assignee + '-project-' + projectName,\n }))\n\n tags.push(...assigneesTags)\n\n // invalidate the watchers query\n dispatch(\n dashboardQueries.util.invalidateTags([\n {\n type: 'watchers',\n id: entityId,\n },\n ]),\n )\n }\n\n // invalidate any other caches\n let entries = dashboardQueries.util.selectInvalidatedBy(state, tags)\n let entriesToInvalidate = []\n\n // for each entry try to patch the data into the cache first\n for (const entry of entries) {\n const [patchResult, wasPatched] = patchKanban(\n {\n assignees: entry.originalArgs.assignees,\n projects: entry.originalArgs.projects,\n },\n {\n newAssignees,\n taskId: entityId,\n data,\n },\n { dispatch },\n )\n\n if (wasPatched) {\n patchResults.push(patchResult)\n } else {\n // if we couldn't patch, we need to invalidate the cache\n entriesToInvalidate.push(entry)\n }\n }\n\n // filter out current kanban query if we were able to patch it\n const currentKanbanCacheArgs = { projects: dashboardProjects, assignees: cacheUsers }\n entriesToInvalidate = entriesToInvalidate.filter(\n (entry) =>\n JSON.stringify(entry.originalArgs) !== JSON.stringify(currentKanbanCacheArgs),\n )\n\n // create the invalidation tags from originalArgs\n const invalidationTags = entries.map((entry) => ({\n type: 'kanban',\n id: JSON.stringify(entry.originalArgs),\n }))\n\n // invalidate the tags later, once the query is complete\n invalidationTagsAfterComplete.push(...invalidationTags)\n }\n\n // get all details panel caches that would be affected by this update\n const detailsPanelTags = [\n {\n type: 'entities',\n id: entityId,\n },\n ]\n\n const detailsPanelEntries = api.util.selectInvalidatedBy(state, detailsPanelTags)\n\n for (const entry of detailsPanelEntries) {\n // patch any entity details panels in dashboard\n let entityDetailsResult = dispatch(\n detailsPanelQueries.util.updateQueryData(\n 'getEntitiesDetailsPanel',\n entry.originalArgs,\n (draft) => {\n for (const entity of draft) {\n patchDetailsPanelEntity([{ entityId, data, entityType }], entity)\n }\n },\n ),\n )\n\n patchResults.push(entityDetailsResult)\n }\n\n try {\n await queryFulfilled\n\n // now invalidate any tags\n if (invalidationTagsAfterComplete.length) {\n dispatch(dashboardQueries.util.invalidateTags(invalidationTagsAfterComplete))\n }\n } catch (error) {\n console.error('error updating ' + entityType, error)\n toast.error(error?.error?.data?.detail || 'Failed to update task')\n patchResults.forEach((result) => result?.undo())\n }\n },\n }),\n updateEntities: build.mutation({\n async queryFn({ operations = [], entityType }, { dispatch, getState }) {\n try {\n const state = getState()\n const promises = []\n for (const { projectName, data, id, currentAssignees = [] } of operations) {\n const promise = dispatch(\n updateEntity.endpoints.updateEntity.initiate({\n projectName: projectName,\n entityId: id,\n data,\n entityType,\n currentAssignees,\n }),\n )\n promises.push(promise)\n }\n\n let progressPatches = []\n if (entityType === 'task' || entityType === 'folder') {\n // patch the progress page\n progressPatches = patchProgressView({ operations, state, dispatch, entityType })\n }\n\n const overviewPatches = []\n // convert id in operations to entityId\n const operationsWithEntityId = operations.map((o) => ({ ...o, entityId: o.id }))\n if (entityType === 'task' || entityType === 'folder') {\n // patch the overview page\n if (entityType === 'task') {\n patchOverviewTasks(operationsWithEntityId, { state, dispatch }, overviewPatches)\n }\n if (entityType === 'folder') {\n // patch the overview page\n patchOverviewFolders(operationsWithEntityId, { state, dispatch }, overviewPatches)\n console.log('invalidate overview folders')\n // invalidate overview folders query\n dispatch(api.util.invalidateTags([{ type: 'folder', id: 'LIST' }]))\n // invalidate overview tasks with folder as a parent\n dispatch(\n api.util.invalidateTags(\n operationsWithEntityId.map((o) => ({ type: 'overviewTask', id: o.entityId })),\n ),\n )\n }\n }\n\n // check if any of the requests failed and invalidate the tasks cache again to refetch\n const results = await Promise.allSettled(promises)\n\n // did any of the requests fail?\n const someError = results.some((result) => result.value?.error)\n if (someError) {\n dispatch(\n api.util.invalidateTags(operations.map((o) => ({ type: 'kanBanTask', id: o.id }))),\n )\n\n // revert the progress view patches\n progressPatches.forEach((patch) => patch?.undo())\n\n // revert the overview patches\n overviewPatches.forEach((patch) => patch?.undo())\n\n throw 'Failed to update some tasks'\n }\n\n const activityTags = []\n\n if (activityTags.length) {\n dispatch(api.util.invalidateTags(activityTags))\n }\n\n return { data: operations }\n } catch (error) {\n console.error(error)\n return { error }\n }\n },\n invalidatesTags: (result, error, { operations }) => [\n ...operations.map((o) => ({ id: o.id, type: 'review' })),\n ],\n }),\n }),\n overrideExisting: true,\n})\n\nexport const { useUpdateEntitiesMutation, useUpdateEntityMutation } = updateEntity\nexport { updateEntity as entitiesQueries }\n"],"names":["patchKanban","assignees","projects","newAssignees","taskId","data","taskData","dispatch","kanbanPatched","dashboardQueries","draft","taskIndex","task","patchData","_a","priority","_b","endDate","assignee","newData","patchProgressView","operations","state","entityType","invalidationTags","o","entries","api","entry","operation","entityId","patch","folderId","folder","newTask","newFolder","t","folderIndex","f","updatedPatch","pathParts","error","updateEntity","build","projectName","currentAssignees","queryFulfilled","getState","patchResults","invalidationTagsAfterComplete","dashboardProjects","dashboardUsers","dashboardAssigneesIsMe","_c","cacheUsers","_d","hasSomeAssignees","hasSomeProjects","project","result","wasPatched","getKanbanTasks","response","tags","currentAssigneesSet","newAssigneesSet","removedAssignees","addedAssignees","assigneesTags","entriesToInvalidate","patchResult","currentKanbanCacheArgs","detailsPanelTags","detailsPanelEntries","entityDetailsResult","detailsPanelQueries","entity","patchDetailsPanelEntity","toast","_f","_e","promises","id","promise","progressPatches","overviewPatches","operationsWithEntityId","patchOverviewTasks","patchOverviewFolders","activityTags","useUpdateEntitiesMutation","useUpdateEntityMutation"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"updateEntity.cjs.js","sources":["../../../../../../src/api/queries/entities/updateEntity.ts"],"sourcesContent":["// @ts-nocheck\n\nimport api from './getEntity'\nimport { detailsPanelQueries } from '@shared/api/queries'\nimport { patchDetailsPanelEntity } from '@shared/api'\nimport { toast } from 'react-toastify'\nimport { dashboardQueries, getKanbanTasks } from '@shared/api/queries/userDashboard'\nimport { patchOverviewFolders, patchOverviewTasks } from '@shared/api/queries/overview'\n\nconst patchKanban = (\n { assignees = [], projects = [] },\n { newAssignees, taskId, data, taskData },\n { dispatch },\n) => {\n let kanbanPatched = false\n const patchResult = dispatch(\n dashboardQueries.util.updateQueryData(\n 'GetKanban',\n { projects: projects, assignees: assignees },\n (draft) => {\n const taskIndex = draft.findIndex((task) => task.id === taskId)\n let patchData = { ...data }\n // if the data include attrib.priority it needs to be transformed to just priority\n // this is because priority is a top level field on kanban query\n if (data?.attrib?.priority) {\n const { priority } = patchData.attrib\n patchData = { ...patchData, priority }\n }\n // if the data include attrib.endDate it needs to be transformed to dueDate\n // this is because dueDate is a top level field on kanban query\n // NOTE TO SELF: Lets try to do these transforms after the cache the future.\n if (data?.attrib?.endDate) {\n const { endDate } = patchData.attrib\n patchData = { ...patchData, dueDate: endDate }\n delete patchData.attrib.endDate\n }\n\n if (taskIndex === -1) {\n // task not found, assignee must have just been added\n if (taskData) {\n // add the task to the cache\n draft.push(taskData)\n } else {\n // we don't have the task data, so we can't add it to the cache\n // we might add it later\n kanbanPatched = false\n }\n } else {\n kanbanPatched = true\n // first check that the task assignees still has a intersection with dashAssignees\n const hasSomeAssignees = newAssignees?.some((assignee) => assignees.includes(assignee))\n\n if (!hasSomeAssignees && newAssignees) {\n // remove from cache\n draft.splice(taskIndex, 1)\n } else {\n // task found: update the task in the cache\n const newData = { ...draft[taskIndex], ...patchData }\n draft[taskIndex] = newData\n }\n }\n },\n ),\n )\n\n return [patchResult, kanbanPatched]\n}\n\n// try to patch the progress view if there are queries that need to be updated\nconst patchProgressView = ({ operations = [], state, dispatch, entityType }) => {\n // create invalidation tags for progress view\n const invalidationTags = operations.map((o) => ({ type: 'progress', id: o.id }))\n // find the entries that need to be updated\n let entries = api.util.selectInvalidatedBy(state, invalidationTags)\n // if there are no entries, return\n if (!entries.length) return []\n\n try {\n // patch each entry with updated task data\n const patches = entries.map((entry) =>\n dispatch(\n api.util.updateQueryData(entry.endpointName, entry.originalArgs, (draft) => {\n for (const operation of operations) {\n const entityId = operation.id\n const patch = operation.data\n\n // patch the updated task data\n if (entityType === 'task') {\n const folderId = operation.meta?.folderId\n const folder = draft.find((folder) => folder.id === folderId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n const task = folder.tasks?.find((task) => task.id === entityId)\n if (!task) throw new Error('Patching progress view: task not found')\n // update task\n const newTask = { ...task, ...patch }\n // update folder\n const newFolder = {\n ...folder,\n tasks: folder.tasks.map((t) => (t.id === entityId ? newTask : t)),\n }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === folderId)\n draft[folderIndex] = newFolder\n } else if (entityType === 'folder') {\n const folder = draft.find((folder) => folder.id === entityId)\n if (!folder) throw new Error('Patching progress view: folder not found')\n\n // If name is being updated, also update the path\n let updatedPatch = { ...patch }\n if (patch.name && folder.path) {\n // Construct new path by replacing the last segment with the new name\n const pathParts = folder.path.split('/')\n pathParts[pathParts.length - 1] = patch.name\n updatedPatch.path = pathParts.join('/')\n }\n\n // update folder\n const newFolder = { ...folder, ...updatedPatch }\n // update query\n const folderIndex = draft.findIndex((f) => f.id === entityId)\n draft[folderIndex] = newFolder\n }\n }\n }),\n ),\n )\n return patches\n } catch (error) {\n console.error(error)\n // invalidate the progress view queries instead\n dispatch(api.util.invalidateTags(invalidationTags))\n return []\n }\n}\n\nconst updateEntity = api.injectEndpoints({\n endpoints: (build) => ({\n updateEntity: build.mutation({\n query: ({ projectName, entityId, data, entityType }) => ({\n url: `/api/projects/${projectName}/${entityType}s/${entityId}`,\n method: 'PATCH',\n body: data,\n }),\n async onQueryStarted(\n { projectName, entityId, data, currentAssignees, entityType },\n { dispatch, queryFulfilled, getState },\n ) {\n const state = getState()\n const patchResults = []\n\n let invalidationTagsAfterComplete = []\n // if task, patch the GetKanban query\n if (entityType === 'task') {\n const dashboardProjects = getState().dashboard?.selectedProjects || []\n const dashboardUsers = getState().dashboard?.tasks.assignees || []\n const dashboardAssigneesIsMe = getState().dashboard?.tasks.assigneesFilter === 'me'\n const newAssignees = data.assignees\n\n const cacheUsers = dashboardAssigneesIsMe ? [getState().user?.name] : dashboardUsers\n\n const entityAssignees = [...new Set([...currentAssignees, ...(newAssignees || [])])]\n const hasSomeAssignees = entityAssignees.some((assignee) => cacheUsers.includes(assignee))\n const hasSomeProjects = dashboardProjects.some((project) => project === projectName)\n const currentDashNeedsUpdating = hasSomeAssignees && hasSomeProjects\n\n if (currentDashNeedsUpdating) {\n const [result, wasPatched] = patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, data },\n { dispatch },\n )\n\n if (wasPatched) patchResults.push(result)\n\n if (!wasPatched) {\n // this means the task is not in the current kanban and it needs to be added\n\n // get the new task data\n getKanbanTasks({ projects: [projectName], taskIds: [entityId] }, dispatch).then(\n // use .then so that the rest of the code can run\n (response) => {\n let newTask = response.find((task) => task.id === entityId)\n if (newTask) {\n // add newAssignees as the actual DB hasn't been updated yet\n newTask = { ...newTask, assignees: newAssignees }\n\n patchKanban(\n { assignees: cacheUsers, projects: dashboardProjects },\n { newAssignees, taskId: entityId, taskData: newTask },\n { dispatch },\n )\n }\n },\n )\n }\n }\n\n // always update the kanban if task id matches\n const tags = [{ type: 'task', id: entityId }]\n\n // are we changing the assignees?\n if (newAssignees?.length) {\n const currentAssigneesSet = new Set(currentAssignees)\n const newAssigneesSet = new Set(newAssignees)\n\n const removedAssignees = [...currentAssigneesSet].filter(\n (assignee) => !newAssigneesSet.has(assignee),\n )\n const addedAssignees = [...newAssigneesSet].filter(\n (assignee) => !currentAssigneesSet.has(assignee),\n )\n\n const changedAssignees = [...new Set([...removedAssignees, ...addedAssignees])]\n\n // any query that has those changed assignees, needs to be updated\n // we are changing the assignees\n const assigneesTags = changedAssignees.map((assignee) => ({\n type: 'kanban',\n id: 'user-' + assignee + '-project-' + projectName,\n }))\n\n tags.push(...assigneesTags)\n\n // invalidate the watchers query\n dispatch(\n dashboardQueries.util.invalidateTags([\n {\n type: 'watchers',\n id: entityId,\n },\n ]),\n )\n }\n\n // invalidate any other caches\n let entries = dashboardQueries.util.selectInvalidatedBy(state, tags)\n let entriesToInvalidate = []\n\n // for each entry try to patch the data into the cache first\n for (const entry of entries) {\n const [patchResult, wasPatched] = patchKanban(\n {\n assignees: entry.originalArgs.assignees,\n projects: entry.originalArgs.projects,\n },\n {\n newAssignees,\n taskId: entityId,\n data,\n },\n { dispatch },\n )\n\n if (wasPatched) {\n patchResults.push(patchResult)\n } else {\n // if we couldn't patch, we need to invalidate the cache\n entriesToInvalidate.push(entry)\n }\n }\n\n // filter out current kanban query if we were able to patch it\n const currentKanbanCacheArgs = { projects: dashboardProjects, assignees: cacheUsers }\n entriesToInvalidate = entriesToInvalidate.filter(\n (entry) =>\n JSON.stringify(entry.originalArgs) !== JSON.stringify(currentKanbanCacheArgs),\n )\n\n // create the invalidation tags from originalArgs\n const invalidationTags = entries.map((entry) => ({\n type: 'kanban',\n id: JSON.stringify(entry.originalArgs),\n }))\n\n // invalidate the tags later, once the query is complete\n invalidationTagsAfterComplete.push(...invalidationTags)\n }\n\n // get all details panel caches that would be affected by this update\n const detailsPanelTags = [\n {\n type: 'entities',\n id: entityId,\n },\n ]\n\n const detailsPanelEntries = api.util.selectInvalidatedBy(state, detailsPanelTags)\n\n for (const entry of detailsPanelEntries) {\n // patch any entity details panels in dashboard\n let entityDetailsResult = dispatch(\n detailsPanelQueries.util.updateQueryData(\n 'getEntitiesDetailsPanel',\n entry.originalArgs,\n (draft) => {\n for (const entity of draft) {\n patchDetailsPanelEntity([{ entityId, data, entityType }], entity)\n }\n },\n ),\n )\n\n patchResults.push(entityDetailsResult)\n }\n\n try {\n await queryFulfilled\n\n // now invalidate any tags\n if (invalidationTagsAfterComplete.length) {\n dispatch(dashboardQueries.util.invalidateTags(invalidationTagsAfterComplete))\n }\n } catch (error) {\n console.error('error updating ' + entityType, error)\n toast.error(error?.error?.data?.detail || 'Failed to update task')\n patchResults.forEach((result) => result?.undo())\n }\n },\n }),\n updateEntities: build.mutation({\n async queryFn({ operations = [], entityType }, { dispatch, getState }) {\n try {\n const state = getState()\n const promises = []\n for (const { projectName, data, id, currentAssignees = [] } of operations) {\n const promise = dispatch(\n updateEntity.endpoints.updateEntity.initiate({\n projectName: projectName,\n entityId: id,\n data,\n entityType,\n currentAssignees,\n }),\n )\n promises.push(promise)\n }\n\n let progressPatches = []\n if (entityType === 'task' || entityType === 'folder') {\n // patch the progress page\n progressPatches = patchProgressView({ operations, state, dispatch, entityType })\n }\n\n const overviewPatches = []\n // convert id in operations to entityId\n const operationsWithEntityId = operations.map((o) => ({ ...o, entityId: o.id }))\n if (entityType === 'task' || entityType === 'folder') {\n // patch the overview page\n if (entityType === 'task') {\n patchOverviewTasks(operationsWithEntityId, { state, dispatch }, overviewPatches)\n }\n if (entityType === 'folder') {\n // patch the overview page\n patchOverviewFolders(operationsWithEntityId, { state, dispatch }, overviewPatches)\n console.log('invalidate overview folders')\n // invalidate overview folders query\n dispatch(api.util.invalidateTags([{ type: 'folder', id: 'LIST' }]))\n // invalidate overview tasks with folder as a parent\n dispatch(\n api.util.invalidateTags(\n operationsWithEntityId.map((o) => ({ type: 'overviewTask', id: o.entityId })),\n ),\n )\n }\n }\n\n // check if any of the requests failed and invalidate the tasks cache again to refetch\n const results = await Promise.allSettled(promises)\n\n // did any of the requests fail?\n const someError = results.some((result) => result.value?.error)\n if (someError) {\n dispatch(\n api.util.invalidateTags(operations.map((o) => ({ type: 'kanBanTask', id: o.id }))),\n )\n\n // revert the progress view patches\n progressPatches.forEach((patch) => patch?.undo())\n\n // revert the overview patches\n overviewPatches.forEach((patch) => patch?.undo())\n\n throw 'Failed to update some tasks'\n }\n\n const activityTags = []\n\n if (activityTags.length) {\n dispatch(api.util.invalidateTags(activityTags))\n }\n\n return { data: operations }\n } catch (error) {\n console.error(error)\n return { error }\n }\n },\n invalidatesTags: (result, error, { operations }) => [\n ...operations.map((o) => ({ id: o.id, type: 'review' })),\n ],\n }),\n }),\n overrideExisting: true,\n})\n\nexport const { useUpdateEntitiesMutation, useUpdateEntityMutation } = updateEntity\nexport { updateEntity as entitiesQueries }\n"],"names":["patchKanban","assignees","projects","newAssignees","taskId","data","taskData","dispatch","kanbanPatched","dashboardQueries","draft","taskIndex","task","patchData","_a","priority","_b","endDate","assignee","newData","patchProgressView","operations","state","entityType","invalidationTags","o","entries","api","entry","operation","entityId","patch","folderId","folder","newTask","newFolder","t","folderIndex","f","updatedPatch","pathParts","error","updateEntity","build","projectName","currentAssignees","queryFulfilled","getState","patchResults","invalidationTagsAfterComplete","dashboardProjects","dashboardUsers","dashboardAssigneesIsMe","_c","cacheUsers","_d","hasSomeAssignees","hasSomeProjects","project","result","wasPatched","getKanbanTasks","response","tags","currentAssigneesSet","newAssigneesSet","removedAssignees","addedAssignees","assigneesTags","entriesToInvalidate","patchResult","currentKanbanCacheArgs","detailsPanelTags","detailsPanelEntries","entityDetailsResult","detailsPanelQueries","entity","patchDetailsPanelEntity","toast","_f","_e","promises","id","promise","progressPatches","overviewPatches","operationsWithEntityId","patchOverviewTasks","patchOverviewFolders","activityTags","useUpdateEntitiesMutation","useUpdateEntityMutation"],"mappings":"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"}
|